diff --git a/PointCloud.d.ts b/PointCloud.d.ts index b24d56a..c71c00f 100644 --- a/PointCloud.d.ts +++ b/PointCloud.d.ts @@ -1,7 +1,6 @@ import { Scene } from "@babylonjs/core/scene"; import { Plot, LegendData } from "./babyplots"; export declare class PointCloud extends Plot { - private _SPS; private _pointPicking; private _selectionCallback; private _folded; @@ -15,6 +14,4 @@ export declare class PointCloud extends Plot { private _createPointCloud; resetAnimation(): void; update(): boolean; - private _pointPicker; - updateSize(): void; } diff --git a/PointCloud.ts b/PointCloud.ts index a4bc0b5..d6af5dc 100644 --- a/PointCloud.ts +++ b/PointCloud.ts @@ -19,9 +19,7 @@ import { Scene } from "@babylonjs/core/scene"; import { Mesh } from "@babylonjs/core/Meshes/mesh"; -import { SphereBuilder } from "@babylonjs/core/Meshes/Builders/sphereBuilder"; import { Vector3, Color4, Color3 } from "@babylonjs/core/Maths/math"; -import { SolidParticleSystem } from "@babylonjs/core/Particles/solidParticleSystem"; import { VertexData } from "@babylonjs/core/Meshes/mesh.vertexData"; import { StandardMaterial } from "@babylonjs/core/Materials/standardMaterial"; import { FloatArray } from "@babylonjs/core/types"; @@ -29,7 +27,6 @@ import { PickingInfo } from "@babylonjs/core/Collisions/pickingInfo"; import { Plot, LegendData } from "./babyplots"; export class PointCloud extends Plot { - private _SPS: SolidParticleSystem; private _pointPicking: boolean = false; private _selectionCallback = function (selection: number[]) { return false; }; private _folded: boolean; @@ -106,87 +103,44 @@ export class PointCloud extends Plot { */ private _createPointCloud(): void { // prototype cell - if (this._coords.length > 10000) { - let customMesh = new Mesh("custom", this._scene); - // Set arrays for positions and indices - let positions = []; - let colors = []; - if (this._folded) { - for (let p = 0; p < this._coords.length; p++) { - positions.push( - this._foldedEmbedding[p][0] * this.xScale, - this._foldedEmbedding[p][2] * this.zScale, - this._foldedEmbedding[p][1] * this.yScale - ); - let col = Color4.FromHexString(this._coordColors[p]); - colors.push(col.r, col.g, col.b, col.a); - } - } else { - for (let p = 0; p < this._coords.length; p++) { - positions.push( - this._coords[p][0] * this.xScale, - this._coords[p][2] * this.zScale, - this._coords[p][1] * this.yScale - ); - let col = Color4.FromHexString(this._coordColors[p]); - colors.push(col.r, col.g, col.b, col.a); - } + let customMesh = new Mesh("custom", this._scene); + // Set arrays for positions and indices + let positions = []; + let colors = []; + if (this._folded) { + for (let p = 0; p < this._coords.length; p++) { + positions.push( + this._foldedEmbedding[p][0] * this.xScale, + this._foldedEmbedding[p][2] * this.zScale, + this._foldedEmbedding[p][1] * this.yScale + ); + let col = Color4.FromHexString(this._coordColors[p]); + colors.push(col.r, col.g, col.b, col.a); } - var vertexData = new VertexData(); - // Assign positions - vertexData.positions = positions; - vertexData.colors = colors; - // Apply vertexData to custom mesh - vertexData.applyToMesh(customMesh, true); - var mat = new StandardMaterial("mat", this._scene); - mat.emissiveColor = new Color3(1, 1, 1); - mat.disableLighting = true; - mat.pointsCloud = true; - mat.pointSize = this._size; - customMesh.material = mat; - this.mesh = customMesh; - } - else { - let cell = SphereBuilder.CreateSphere("sphere", { segments: 2, diameter: this._size * 0.1 }, this._scene); - // let cell = MeshBuilder.CreateDisc("disc", {tessellation: 6, radius: this._size}, this._scene); - // particle system - let SPS = new SolidParticleSystem('SPS', this._scene, { - updatable: true, - isPickable: true - }); - // add all cells to SPS - SPS.addShape(cell, this._coords.length); - // position and color cells - if (this._folded) { - for (let i = 0; i < SPS.nbParticles; i++) { - SPS.particles[i].position.x = this._foldedEmbedding[i][0] * this.xScale; - SPS.particles[i].position.z = this._foldedEmbedding[i][1] * this.zScale; - SPS.particles[i].position.y = this._foldedEmbedding[i][2] * this.yScale; - SPS.particles[i].color = Color4.FromHexString(this._coordColors[i]); - } - } else { - for (let i = 0; i < SPS.nbParticles; i++) { - SPS.particles[i].position.x = this._coords[i][0] * this.xScale; - SPS.particles[i].position.z = this._coords[i][1] * this.zScale; - SPS.particles[i].position.y = this._coords[i][2] * this.yScale; - SPS.particles[i].color = Color4.FromHexString(this._coordColors[i]); - } + } else { + for (let p = 0; p < this._coords.length; p++) { + positions.push( + this._coords[p][0] * this.xScale, + this._coords[p][2] * this.zScale, + this._coords[p][1] * this.yScale + ); + let col = Color4.FromHexString(this._coordColors[p]); + colors.push(col.r, col.g, col.b, col.a); } - SPS.buildMesh(); - // scale bounding box to actual size of the SPS particles - SPS.computeBoundingBox = true; - // remove prototype cell - cell.dispose(); - // calculate SPS particles - SPS.setParticles(); - // SPS.billboard = true; - SPS.computeBoundingBox = true; - this._SPS = SPS; - this.mesh = SPS.mesh; - var mat = new StandardMaterial("pointMat", this._scene); - mat.alpha = 1; - this.mesh.material = mat; } + var vertexData = new VertexData(); + // Assign positions + vertexData.positions = positions; + vertexData.colors = colors; + // Apply vertexData to custom mesh + vertexData.applyToMesh(customMesh, true); + var mat = new StandardMaterial("mat", this._scene); + mat.emissiveColor = new Color3(1, 1, 1); + mat.disableLighting = true; + mat.pointsCloud = true; + mat.pointSize = this._size; + customMesh.material = mat; + this.mesh = customMesh; Object.defineProperty(this, "alpha", { set(newAlpha) { this.mesh.material.alpha = newAlpha; @@ -196,53 +150,21 @@ export class PointCloud extends Plot { resetAnimation(): void { this._folded = true; - if (this._SPS) { - for (let i = 0; i < this._SPS.particles.length; i++) { - this._SPS.particles[i].position = new Vector3( - this._foldedEmbedding[i][0] * this.xScale, - this._foldedEmbedding[i][2] * this.zScale, - this._foldedEmbedding[i][1] * this.yScale - ); + let positionFunction = function (positions: FloatArray) { + let numberOfVertices = positions.length / 3; + for (let i = 0; i < numberOfVertices; i++) { + positions[i * 3] = this._foldedEmbedding[i][0] * this.xScale; + positions[i * 3 + 1] = this._foldedEmbedding[i][2] * this.zScale; + positions[i * 3 + 2] = this._foldedEmbedding[i][1] * this.yScale; } - this._SPS.setParticles(); - } else { - let positionFunction = function (positions: FloatArray) { - let numberOfVertices = positions.length / 3; - for (let i = 0; i < numberOfVertices; i++) { - positions[i * 3] = this._foldedEmbedding[i][0] * this.xScale; - positions[i * 3 + 1] = this._foldedEmbedding[i][2] * this.zScale; - positions[i * 3 + 2] = this._foldedEmbedding[i][1] * this.yScale; - } - } - this.mesh.updateMeshPositions(positionFunction.bind(this), true); } + this.mesh.updateMeshPositions(positionFunction.bind(this), true); this.mesh.refreshBoundingInfo(); this._foldCounter = 0; } update(): boolean { - if (this._SPS && this._folded) { - if (this._foldCounter < this._foldDelay) { - this._foldCounter += 1; - } else if (this._foldCounter < this._foldAnimFrames + this._foldDelay) { - for (let i = 0; i < this._SPS.particles.length; i++) { - this._SPS.particles[i].position.addInPlace(this._foldVectorFract[i]); - } - this._foldCounter += 1; - this._SPS.setParticles(); - } else { - this._folded = false; - for (let i = 0; i < this._SPS.particles.length; i++) { - this._SPS.particles[i].position = new Vector3( - this._coords[i][0] * this.xScale, - this._coords[i][2] * this.zScale, - this._coords[i][1] * this.yScale - ); - } - this._SPS.setParticles(); - this.mesh.refreshBoundingInfo(); - } - } else if (this.mesh && this._folded) { + if (this.mesh && this._folded) { if (this._foldCounter < this._foldDelay) { this._foldCounter += 1; } else if (this._foldCounter < this._foldAnimFrames + this._foldDelay) { @@ -277,30 +199,4 @@ export class PointCloud extends Plot { } return this._folded; } - private _pointPicker(_evt: PointerEvent, pickResult: PickingInfo) { - if (this._pointPicking) { - const faceId = pickResult.faceId; - if (faceId == -1) { - return; - } - const idx = this._SPS.pickedParticles[faceId].idx; - for (let i = 0; i < this._SPS.nbParticles; i++) { - this._SPS.particles[i].color = new Color4(0.3, 0.3, 0.8, 1); - } - let p = this._SPS.particles[idx]; - p.color = new Color4(1, 0, 0, 1); - this._SPS.setParticles(); - this.selection = [idx]; - this._selectionCallback(this.selection); - } - } - updateSize(): void { - for (let i = 0; i < this._SPS.nbParticles; i++) { - this._SPS.particles[i].scale.x = this._size; - this._SPS.particles[i].scale.y = this._size; - this._SPS.particles[i].scale.z = this._size; - } - this._SPS.setParticles(); - super.updateSize(); - } } diff --git a/ShapeCloud.d.ts b/ShapeCloud.d.ts new file mode 100644 index 0000000..a298aec --- /dev/null +++ b/ShapeCloud.d.ts @@ -0,0 +1,9 @@ +import { Scene } from "@babylonjs/core/scene"; +import "@babylonjs/core/Meshes/thinInstanceMesh"; +import { Plot, LegendData } from "./babyplots"; +export declare class ShapeCloud extends Plot { + private _shape; + private _shading; + constructor(scene: Scene, coordinates: number[][], colorVar: string[], shape: string, shading: boolean, size: number, legendData: LegendData, xScale?: number, yScale?: number, zScale?: number); + private _createShapeCloud; +} diff --git a/ShapeCloud.ts b/ShapeCloud.ts new file mode 100644 index 0000000..88973c9 --- /dev/null +++ b/ShapeCloud.ts @@ -0,0 +1,115 @@ +/** + * Babyplots - Easy, fast, interactive 3D visualizations + * + * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ + +import { Scene } from "@babylonjs/core/scene"; +import { Mesh } from "@babylonjs/core/Meshes/mesh"; +import "@babylonjs/core/Meshes/thinInstanceMesh"; +import { SphereBuilder } from "@babylonjs/core/Meshes/Builders/sphereBuilder"; +import { BoxBuilder } from "@babylonjs/core/Meshes/Builders/boxBuilder"; +import { TorusBuilder } from "@babylonjs/core/Meshes/Builders/torusBuilder"; +import { CylinderBuilder } from "@babylonjs/core/Meshes/Builders/cylinderBuilder"; +import { Color3, Color4, Matrix } from "@babylonjs/core/Maths/math"; +import { StandardMaterial } from "@babylonjs/core/Materials/standardMaterial"; +import { Plot, LegendData } from "./babyplots"; + +export class ShapeCloud extends Plot { + private _shape: string; + private _shading: boolean; + constructor( + scene: Scene, + coordinates: number[][], + colorVar: string[], + shape: string, + shading: boolean, + size: number, + legendData: LegendData, + xScale: number = 1, + yScale: number = 1, + zScale: number = 1 + ) { + super(scene, coordinates, colorVar, size * 0.1, legendData, xScale, yScale, zScale); + this._shape = shape; + this._shading = shading; + this._createShapeCloud(); + } + /** + * Creates shapes at coordinates + */ + private _createShapeCloud(): void { + let instanceCount = this._coords.length; + + let matricesData = new Float32Array(16 * instanceCount); + let colorData = new Float32Array(4 * instanceCount); + + // set position and color data for shapes + for (let i = 0; i < instanceCount; i++) { + let matrix = Matrix.Translation( + this._coords[i][0] * this.xScale, + this._coords[i][1] * this.zScale, + this._coords[i][2] * this.yScale + ); + + matrix.copyToArray(matricesData, i * 16); + + let col = Color4.FromHexString(this._coordColors[i]); + + colorData.set(col.asArray(), i * 4); + } + + let origMesh: Mesh; + + switch (this._shape) { + case "box": + origMesh = BoxBuilder.CreateBox("root", { size: this._size }); + break; + case "sphere": + origMesh = SphereBuilder.CreateSphere("root", { diameter: this._size }); + break; + case "cone": + origMesh = CylinderBuilder.CreateCylinder("root", { height: this._size, diameterBottom: this._size, diameterTop: 0 }, this._scene); + break; + case "torus": + origMesh = TorusBuilder.CreateTorus("root", { diameter: this._size, thickness: this._size * 0.5 }, this._scene); + break; + case "cylinder": + origMesh = CylinderBuilder.CreateCylinder("root", { height: this._size, diameter: this._size }, this._scene); + break; + default: + origMesh = BoxBuilder.CreateBox("root", { size: 1 }); + break; + } + + origMesh.thinInstanceSetBuffer("matrix", matricesData, 16, true); + origMesh.thinInstanceSetBuffer("color", colorData, 4, true); + + let mat = new StandardMaterial("shapeMat", this._scene); + if (!this._shading) { + mat.disableLighting = true; + mat.emissiveColor = Color3.White(); + } + origMesh.material = mat; + + this.mesh = origMesh; + Object.defineProperty(this, "alpha", { + set(newAlpha) { + this.mesh.material.alpha = newAlpha; + } + }); + } +} diff --git a/babyplots.ts b/babyplots.ts index 917c230..c35a333 100644 --- a/babyplots.ts +++ b/babyplots.ts @@ -282,9 +282,11 @@ export function getUniqueVals(source: string[]): string[] { } import { ImgStack } from "./ImgStack"; +import { ShapeCloud } from "./ShapeCloud"; import { PointCloud } from "./PointCloud"; import { Surface } from "./Surface"; import { HeatMap } from "./HeatMap"; +import { BoundingBox } from "@babylonjs/core/Culling/boundingBox"; export const PLOTTYPES = { 'pointCloud': ['coordinates', 'colorBy', 'colorVar'], @@ -351,8 +353,9 @@ export class Plots { /** * Initialize the 3d visualization - * @param canvasElement ID of the canvas element in the dom - * @param backgroundColor Background color of the plot + * + * @param canvasElement ID of the canvas element in the DOM + * @param options Object with general options. See a list of possible options [here](https://bp.bleb.li/documentation/js#plotsObject). */ constructor(canvasElement: string, options = {}) { // create unique id, needed if multiple babyplots canvases are on the same page. @@ -383,7 +386,7 @@ export class Plots { this.camera = new ArcRotateCamera("Camera", 0, 0, 10, Vector3.Zero(), this.scene); this.camera.attachControl(this.canvas, true); this.scene.activeCamera = this.camera; - this.camera.inputs.attached.keyboard.detachControl(this.canvas); + this.camera.inputs.attached.keyboard.detachControl(); this.camera.wheelPrecision = 50; // background color @@ -427,6 +430,11 @@ export class Plots { }; } + /** + * Load a visualization from a saved JSON object. The R, JavaScript and Python implementations of babyplots as well as the NPC allow the export of visualizations as JSON files. Loading of a saved visualization using fromJSON() overwrites previously set properties of the Plots object. + * + * @param plotData Javascript Object with plot data. + */ fromJSON(plotData: {}): void { if (plotData["turntable"] !== undefined) { this.turntable = plotData["turntable"]; @@ -472,7 +480,7 @@ export class Plots { intensityMode: plot["intensityMode"] } ) - } else if (["pointCloud", "heatMap", "surface"].indexOf(plot["plotType"]) !== -1) { + } else if (["pointCloud", "heatMap", "surface", "shapeCloud"].indexOf(plot["plotType"]) !== -1) { this.addPlot( plot["coordinates"], plot["plotType"], @@ -501,7 +509,8 @@ export class Plots { foldAnimDelay: plot["foldAnimDelay"], foldAnimDuration: plot["foldAnimDuration"], colnames: plot["colnames"], - rownames: plot["rownames"] + rownames: plot["rownames"], + shape: plot["shape"] } ) } @@ -534,6 +543,19 @@ export class Plots { } } + /** + * Create UI buttons to control certain babyplots features. + * + * @param whichBtns Array of buttons to create. Any combination of ["json", "label", "publish", "record"] is allowed. + * + * "json": creates a button that triggers the download of the plot data in .json file format. + * + * "label": creates a button that opens the label manager that allows creation and editing of labels. + * + * "publish": creates a button that opens the publish to bp.bleb.li form. + * + * "record": creates a button to record the plot as a gif. (Requires inclusion of CCapture.js and its gif.worker.js). + */ createButtons(whichBtns = ["json", "label", "publish", "record"]): void { if (whichBtns.indexOf("json") !== -1) { let jsonBtn = document.createElement("div"); @@ -662,7 +684,7 @@ export class Plots { closeBtn.onclick = this._cancelPublish.bind(this); closeBtn.innerText = "Close"; closeBtn.style.display = "none"; - + // Add all form elements to the form formBox.appendChild(usernameLabel); formBox.appendChild(usernameInput); @@ -909,6 +931,16 @@ export class Plots { this.ymax = yRange[1]; } + /** + * Creates a 3-dimensional visualization of an RGB image stack, as generated from e.g. a fluorescent microscope, and adds it to the Plots object to visualize it in a canvas. The data must be in a special format for this function which is optimized for size. The easiest way to create this visualization is using the R implementation of babyplots, which includes a function to directly read .tif files. + * + * @param values An array of intensity values. Currently only 8-bit images are supported (0-255). + * @param indices Indices of the values in the original image. + * @param attributes Image attributes. Only a "dim" attribute is needed containing the dimensions (x, y, c, z) of the image. + * @param options An object with options to customize the visualization. + * + * Find a list of possible options [here](https://bp.bleb.li/documentation/js#addImgStack). + */ addImgStack( values: number[], indices: number[], @@ -990,6 +1022,17 @@ export class Plots { return this; } + /** + * Creates a plot and adds it to the Plots object to visualize it in a canvas. The plot types section below enumerates the different kinds of visualizations that can be created using this method. + * + * @param coordinates An array of arrays with coordinates of data points. + * @param plotType The name of one of the plot types. Either "pointCloud", "heatMap", or "surface". + * @param colorBy How to interpret the colorVar parameter, either "direct", "categories", or "values". If colorVar is an array of hex strings, colorBy should be "direct". If colorVar is an array of discrete values (e.g. category names), colorBy should be "categories". If colorVar is an array of continuous values, colorBy should be "values". + * @param colorVar an array of hex strings, category names, or values, corresponding to the data points in the coordinates parameter. + * @param options An object with general and plot type specific options. + * + * Find a list of possible options [here](https://bp.bleb.li/documentation/js#addPlot). + */ addPlot( coordinates: number[][], plotType: string, @@ -1024,7 +1067,9 @@ export class Plots { foldAnimDelay: null, foldAnimDuration: null, colnames: null, - rownames: null + rownames: null, + shape: null, + shading: true } // apply user options Object.assign(opts, options); @@ -1056,7 +1101,9 @@ export class Plots { foldAnimDelay: opts.foldAnimDelay, foldAnimDuration: opts.foldAnimDuration, colnames: opts.colnames, - rownames: opts.rownames + rownames: opts.rownames, + shape: opts.shape, + shading: opts.shading }) let coordColors: string[] = []; @@ -1214,6 +1261,7 @@ export class Plots { let plot: Plot; let scale: number[]; + let boundingBox: BoundingBox; switch (plotType) { case "pointCloud": plot = new PointCloud( @@ -1230,7 +1278,7 @@ export class Plots { this._yScale, this._zScale ); - let boundingBox = plot.mesh.getBoundingInfo().boundingBox; + boundingBox = plot.mesh.getBoundingInfo().boundingBox; rangeX = [ boundingBox.minimumWorld.x, boundingBox.maximumWorld.x @@ -1272,6 +1320,38 @@ export class Plots { this._zScale, ] break + case "shapeCloud": + plot = new ShapeCloud( + this.scene, + coordinates, + coordColors, + opts.shape, + opts.shading, + opts.size, + legendData, + this._xScale, + this._yScale, + this._zScale + ); + boundingBox = plot.mesh.getBoundingInfo().boundingBox; + rangeX = [ + boundingBox.minimumWorld.x, + boundingBox.maximumWorld.x + ] + rangeY = [ + boundingBox.minimumWorld.y, + boundingBox.maximumWorld.y + ] + rangeZ = [ + boundingBox.minimumWorld.z, + boundingBox.maximumWorld.z + ] + scale = [ + this._xScale, + this._yScale, + this._zScale, + ] + break; case "heatMap": plot = new HeatMap( this.scene, @@ -1591,6 +1671,12 @@ export class Plots { return this; } + /** + * Resizes the visualization to the current size of the canvas. This method should be bound to a resize event of the canvas. It is also recommended to call the resize() method once after the doRender() call. + * + * @param width Optional: Width of the canvas + * @param height Optional: Height of the canvas + */ resize(width?: number, height?: number): Plots { if (width !== undefined && height !== undefined) { if (this.R) { @@ -1608,10 +1694,19 @@ export class Plots { return this } + /** + * Saves a screenshot of the visualization. + * + * @param size Width and height of square thumbnail in pixels + * @param saveCallback Function that takes the created screenshot as base64 encoded string. + */ thumbnail(size: number, saveCallback: (data: string) => void): void { ScreenshotTools.CreateScreenshot(this._engine, this.camera, size, saveCallback); } + /** + * Releases all held resources of the Plots visualization. Useful to clear memory, after a visualization is no longer needed. + */ dispose(): void { this.scene.dispose(); this._engine.dispose(); diff --git a/build/Axes.d.ts b/build/Axes.d.ts index c44cdd4..7668dd9 100644 --- a/build/Axes.d.ts +++ b/build/Axes.d.ts @@ -1,6 +1,27 @@ +/** + * Babyplots - Easy, fast, interactive 3D visualizations + * + * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ import { Scene } from "@babylonjs/core/scene"; import { ArcRotateCamera } from "@babylonjs/core/Cameras/arcRotateCamera"; import { AxisData } from "./babyplots"; +/** + * Class to store and update plot axes. + */ export declare class Axes { private _axes; private _axisLabels; @@ -9,6 +30,11 @@ export declare class Axes { private _tickLines; private _scene; axisData: AxisData; + /** + * Create axes for plot. + * @param axisData object containing all information about axis setup. + * @param scene BABYLON scene. + */ constructor(axisData: AxisData, scene: Scene, heatmap?: boolean); private _roundTicks; private _createAxes; diff --git a/build/Axes.js b/build/Axes.js index f203f95..8b60929 100644 --- a/build/Axes.js +++ b/build/Axes.js @@ -1,4 +1,22 @@ "use strict"; +/** + * Babyplots - Easy, fast, interactive 3D visualizations + * + * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ Object.defineProperty(exports, "__esModule", { value: true }); exports.Axes = void 0; var mesh_1 = require("@babylonjs/core/Meshes/mesh"); @@ -6,7 +24,15 @@ var linesBuilder_1 = require("@babylonjs/core/Meshes/Builders/linesBuilder"); var math_1 = require("@babylonjs/core/Maths/math"); var dynamicTexture_1 = require("@babylonjs/core/Materials/Textures/dynamicTexture"); var standardMaterial_1 = require("@babylonjs/core/Materials/standardMaterial"); -var Axes = (function () { +/** + * Class to store and update plot axes. + */ +var Axes = /** @class */ (function () { + /** + * Create axes for plot. + * @param axisData object containing all information about axis setup. + * @param scene BABYLON scene. + */ function Axes(axisData, scene, heatmap) { if (heatmap === void 0) { heatmap = false; } this._axes = []; @@ -35,41 +61,55 @@ var Axes = (function () { Axes.prototype._createAxes = function (heatmap) { if (heatmap === void 0) { heatmap = false; } if (heatmap) { + // Tick breaks for heat map on x and z coordinates have to match columns and rows this.axisData.tickBreaks[0] = 1; this.axisData.tickBreaks[2] = 1; } + // Apply scaling factor to tick break interval to get distance between ticks var xtickBreaks = this.axisData.tickBreaks[0] * this.axisData.scale[0]; var ytickBreaks = this.axisData.tickBreaks[1] * this.axisData.scale[1]; var ztickBreaks = this.axisData.tickBreaks[2] * this.axisData.scale[2]; + // Find minima and maxima of the axes as a multiple of the tick interval distance var xmin = Math.floor(this.axisData.range[0][0] / xtickBreaks) * xtickBreaks; var ymin = Math.floor(this.axisData.range[1][0] / ytickBreaks) * ytickBreaks; var zmin = Math.floor(this.axisData.range[2][0] / ztickBreaks) * ztickBreaks; var xmax = Math.ceil(this.axisData.range[0][1] / xtickBreaks) * xtickBreaks; var ymax = Math.ceil(this.axisData.range[1][1] / ytickBreaks) * ytickBreaks; var zmax = Math.ceil(this.axisData.range[2][1] / ztickBreaks) * ztickBreaks; + // Create X axis if (this.axisData.showAxes[0]) { + // Create axis line var axisX = linesBuilder_1.LinesBuilder.CreateLines("axisX", { points: [ new math_1.Vector3(xmin, ymin, zmin), new math_1.Vector3(xmax, ymin, zmin) ] }, this._scene); + // Apply axis color axisX.color = math_1.Color3.FromHexString(this.axisData.color[0]); this._axes.push(axisX); + // Create axis label var xChar = this._makeTextPlane(this.axisData.axisLabels[0], 1, this.axisData.color[0]); + // Place label near end of the axis xChar.position = new math_1.Vector3(xmax / 2, ymin - 0.5 * ymax, zmin); this._axisLabels.push(xChar); + // Create ticks and tick lines var xTicks = []; + // Find x coordinates for ticks + // Negative ticks for (var i = 0; i < -Math.ceil(this.axisData.range[0][0] / xtickBreaks); i++) { xTicks.push(-(i + 1) * xtickBreaks); } + // Positive ticks for (var i = 0; i <= Math.ceil(this.axisData.range[0][1] / xtickBreaks); i++) { xTicks.push(i * xtickBreaks); } + // Usually ticks start with 0, heat map starts with 1 var startTick = 0; if (heatmap) { startTick = 1; } + // Create all ticks for (var i = startTick; i < xTicks.length; i++) { var tickPos = xTicks[i]; if (heatmap) { @@ -116,7 +156,9 @@ var Axes = (function () { } } } + // create Y axis if (this.axisData.showAxes[1]) { + // axis var axisY = linesBuilder_1.LinesBuilder.CreateLines("axisY", { points: [ new math_1.Vector3(xmin, ymin, zmin), @@ -125,9 +167,11 @@ var Axes = (function () { }, this._scene); axisY.color = math_1.Color3.FromHexString(this.axisData.color[1]); this._axes.push(axisY); + // label var yChar = this._makeTextPlane(this.axisData.axisLabels[1], 1, this.axisData.color[1]); yChar.position = new math_1.Vector3(xmin, ymax / 2, zmin - 0.5 * ymax); this._axisLabels.push(yChar); + // y ticks and tick lines var yTicks = []; for (var i = 0; i < -Math.ceil(this.axisData.range[1][0] / ytickBreaks); i++) { yTicks.push(-(i + 1) * ytickBreaks); @@ -150,6 +194,7 @@ var Axes = (function () { var tickChar = this._makeTextPlane(tickLabel.toString(), 0.6, this.axisData.color[1]); tickChar.position = new math_1.Vector3(xmin, tickPos, zmin - 0.05 * ymax); this._tickLabels.push(tickChar); + // tick lines if (this.axisData.showTickLines[1][0]) { var tickLine = linesBuilder_1.LinesBuilder.CreateLines("yTicksLines", { points: [ @@ -172,7 +217,9 @@ var Axes = (function () { } } } + // create Z axis if (this.axisData.showAxes[2]) { + // axis var axisZ = linesBuilder_1.LinesBuilder.CreateLines("axisZ", { points: [ new math_1.Vector3(xmin, ymin, zmin), @@ -181,9 +228,11 @@ var Axes = (function () { }, this._scene); axisZ.color = math_1.Color3.FromHexString(this.axisData.color[2]); this._axes.push(axisZ); + // label var zChar = this._makeTextPlane(this.axisData.axisLabels[2], 1, this.axisData.color[2]); zChar.position = new math_1.Vector3(xmin, ymin - 0.5 * ymax, zmax / 2); this._axisLabels.push(zChar); + // z ticks and tick lines var zTicks = []; for (var i = 0; i < -Math.ceil(this.axisData.range[2][0] / ztickBreaks); i++) { zTicks.push(-(i + 1) * ztickBreaks); @@ -219,6 +268,7 @@ var Axes = (function () { var tickChar = this._makeTextPlane(tickLabel, 0.6, this.axisData.color[2]); tickChar.position = new math_1.Vector3(xmin, ymin - 0.1 * ymax, tickPos); this._tickLabels.push(tickChar); + // tick lines if (this.axisData.showTickLines[2][0]) { var tickLine = linesBuilder_1.LinesBuilder.CreateLines("zTickLines", { points: [ diff --git a/build/Axes.js.map b/build/Axes.js.map index 4cb77eb..d9c67fa 100644 --- a/build/Axes.js.map +++ b/build/Axes.js.map @@ -1 +1 @@ -{"version":3,"file":"Axes.js","sourceRoot":"","sources":["../Axes.ts"],"names":[],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"Axes.js","sourceRoot":"","sources":["../Axes.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/build/HeatMap.d.ts b/build/HeatMap.d.ts index 3f13880..b8ba715 100644 --- a/build/HeatMap.d.ts +++ b/build/HeatMap.d.ts @@ -1,3 +1,21 @@ +/** + * Babyplots - Easy, fast, interactive 3D visualizations + * + * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ import { Scene } from "@babylonjs/core/scene"; import { Plot, LegendData } from "./babyplots"; export declare class HeatMap extends Plot { diff --git a/build/HeatMap.js b/build/HeatMap.js index cb0f819..8a6fc4d 100644 --- a/build/HeatMap.js +++ b/build/HeatMap.js @@ -1,9 +1,27 @@ "use strict"; +/** + * Babyplots - Easy, fast, interactive 3D visualizations + * + * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ var __extends = (this && this.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; return extendStatics(d, b); }; return function (d, b) { @@ -19,7 +37,7 @@ var boxBuilder_1 = require("@babylonjs/core/Meshes/Builders/boxBuilder"); var planeBuilder_1 = require("@babylonjs/core/Meshes/Builders/planeBuilder"); var standardMaterial_1 = require("@babylonjs/core/Materials/standardMaterial"); var babyplots_1 = require("./babyplots"); -var HeatMap = (function (_super) { +var HeatMap = /** @class */ (function (_super) { __extends(HeatMap, _super); function HeatMap(scene, coordinates, colorVar, size, legendData, xScale, yScale, zScale) { if (xScale === void 0) { xScale = 1; } diff --git a/build/HeatMap.js.map b/build/HeatMap.js.map index 544697d..af26e02 100644 --- a/build/HeatMap.js.map +++ b/build/HeatMap.js.map @@ -1 +1 @@ -{"version":3,"file":"HeatMap.js","sourceRoot":"","sources":["../HeatMap.ts"],"names":[],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"HeatMap.js","sourceRoot":"","sources":["../HeatMap.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/build/ImgStack.d.ts b/build/ImgStack.d.ts index 3d09781..b2fbfcc 100644 --- a/build/ImgStack.d.ts +++ b/build/ImgStack.d.ts @@ -1,3 +1,21 @@ +/** + * Babyplots - Easy, fast, interactive 3D visualizations + * + * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ import { Scene } from "@babylonjs/core/scene"; import { Plot, LegendData } from "./babyplots"; export declare class ImgStack extends Plot { diff --git a/build/ImgStack.js b/build/ImgStack.js index 68c3d0b..68bb84d 100644 --- a/build/ImgStack.js +++ b/build/ImgStack.js @@ -1,9 +1,27 @@ "use strict"; +/** + * Babyplots - Easy, fast, interactive 3D visualizations + * + * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ var __extends = (this && this.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; return extendStatics(d, b); }; return function (d, b) { @@ -23,7 +41,7 @@ var mesh_vertexData_1 = require("@babylonjs/core/Meshes/mesh.vertexData"); var standardMaterial_1 = require("@babylonjs/core/Materials/standardMaterial"); var babyplots_1 = require("./babyplots"); var chroma_js_1 = __importDefault(require("chroma-js")); -var ImgStack = (function (_super) { +var ImgStack = /** @class */ (function (_super) { __extends(ImgStack, _super); function ImgStack(scene, values, indices, attributes, legendData, size, backgroundColor, intensityMode, xScale, yScale, zScale) { if (xScale === void 0) { xScale = 1; } diff --git a/build/ImgStack.js.map b/build/ImgStack.js.map index 763d34f..6a9bbd9 100644 --- a/build/ImgStack.js.map +++ b/build/ImgStack.js.map @@ -1 +1 @@ -{"version":3,"file":"ImgStack.js","sourceRoot":"","sources":["../ImgStack.ts"],"names":[],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"ImgStack.js","sourceRoot":"","sources":["../ImgStack.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/build/Label.d.ts b/build/Label.d.ts index 1a02f4d..0708e42 100644 --- a/build/Label.d.ts +++ b/build/Label.d.ts @@ -1,3 +1,21 @@ +/** + * Babyplots - Easy, fast, interactive 3D visualizations + * + * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ import { Scene } from "@babylonjs/core/scene"; import { ArcRotateCamera } from "@babylonjs/core/Cameras/arcRotateCamera"; import { Vector3 } from "@babylonjs/core/Maths/math"; @@ -37,7 +55,17 @@ export declare class AnnotationManager { toggleLabelControl(): void; private _addLabelBtnClick; addArrow(from: number[], to: number[]): void; + /** + * Add a 3d label to the plot + * @param text Label title + * @param [moveCallback] On dragging of label in 3d plot, the final position will be passed to this function + */ addLabel(text: string, position?: number[]): number; + /** + * Add multiple labels from a list of labels. + * + * @param labelList List of lists with the first three elements of the inner lists being the x, y and z coordinates, and the fourth the label text. + */ addLabels(labelList: [[number, number, number, string]]): void; private _editLabelText; private _removeLabel; diff --git a/build/Label.js b/build/Label.js index ba97da9..f84672f 100644 --- a/build/Label.js +++ b/build/Label.js @@ -1,4 +1,22 @@ "use strict"; +/** + * Babyplots - Easy, fast, interactive 3D visualizations + * + * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ Object.defineProperty(exports, "__esModule", { value: true }); exports.AnnotationManager = void 0; var math_1 = require("@babylonjs/core/Maths/math"); @@ -8,7 +26,7 @@ var advancedDynamicTexture_1 = require("@babylonjs/gui/2D/advancedDynamicTexture var controls_1 = require("@babylonjs/gui/2D/controls"); var linesBuilder_1 = require("@babylonjs/core/Meshes/Builders/linesBuilder"); var cylinderBuilder_1 = require("@babylonjs/core/Meshes/Builders/cylinderBuilder"); -var Arrow = (function () { +var Arrow = /** @class */ (function () { function Arrow(from, to, scene, color) { this.size = 1; var lines = linesBuilder_1.LinesBuilder.CreateLineSystem('ls', { @@ -29,7 +47,7 @@ var Arrow = (function () { } return Arrow; }()); -var Label = (function () { +var Label = /** @class */ (function () { function Label(text, position, scene, color) { this.size = 100; this.color = "black"; @@ -63,11 +81,13 @@ var Label = (function () { this._text.text = text; }; Label.prototype.update = function (camera, scene) { + // draw 3d labels in plot var axis1 = math_1.Vector3.Cross(camera.position, math_1.Axis.Y); var axis2 = math_1.Vector3.Cross(axis1, camera.position); var axis3 = math_1.Vector3.Cross(axis1, axis2); this._label.rotation = math_1.Vector3.RotationFromAxis(axis1, axis2, axis3); if (!this.fixed) { + // highlighting label under mouse cursor var meshUnderPointer = scene.meshUnderPointer; if (this._label === meshUnderPointer) { this._background.alpha = 1; @@ -100,7 +120,7 @@ var Label = (function () { }; return Label; }()); -var AnnotationManager = (function () { +var AnnotationManager = /** @class */ (function () { function AnnotationManager(canvas, scene, ymax, camera) { this._editLabelForms = []; this._showLabels = false; @@ -172,6 +192,11 @@ var AnnotationManager = (function () { AnnotationManager.prototype.addArrow = function (from, to) { this._arrows.push(new Arrow(math_1.Vector3.FromArray(from), math_1.Vector3.FromArray(to), this._scene)); }; + /** + * Add a 3d label to the plot + * @param text Label title + * @param [moveCallback] On dragging of label in 3d plot, the final position will be passed to this function + */ AnnotationManager.prototype.addLabel = function (text, position) { this._addLabelTextInput.value = ""; var labelIdx = this.labels.length; @@ -208,6 +233,11 @@ var AnnotationManager = (function () { this._showLabels = true; return labelIdx; }; + /** + * Add multiple labels from a list of labels. + * + * @param labelList List of lists with the first three elements of the inner lists being the x, y and z coordinates, and the fourth the label text. + */ AnnotationManager.prototype.addLabels = function (labelList) { for (var i = 0; i < labelList.length; i++) { var label = labelList[i]; diff --git a/build/Label.js.map b/build/Label.js.map index 75a4620..b95ae86 100644 --- a/build/Label.js.map +++ b/build/Label.js.map @@ -1 +1 @@ -{"version":3,"file":"Label.js","sourceRoot":"","sources":["../Label.ts"],"names":[],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"Label.js","sourceRoot":"","sources":["../Label.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/build/PointCloud.d.ts b/build/PointCloud.d.ts index b24d56a..536a2c5 100644 --- a/build/PointCloud.d.ts +++ b/build/PointCloud.d.ts @@ -1,7 +1,24 @@ +/** + * Babyplots - Easy, fast, interactive 3D visualizations + * + * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ import { Scene } from "@babylonjs/core/scene"; import { Plot, LegendData } from "./babyplots"; export declare class PointCloud extends Plot { - private _SPS; private _pointPicking; private _selectionCallback; private _folded; @@ -12,9 +29,10 @@ export declare class PointCloud extends Plot { private _foldVectorFract; private _foldDelay; constructor(scene: Scene, coordinates: number[][], colorVar: string[], size: number, legendData: LegendData, folded?: boolean, foldedEmbedding?: number[][], foldAnimDelay?: number, foldAnimDuration?: number, xScale?: number, yScale?: number, zScale?: number); + /** + * Positions spheres according to coordinates in a SPS + */ private _createPointCloud; resetAnimation(): void; update(): boolean; - private _pointPicker; - updateSize(): void; } diff --git a/build/PointCloud.js b/build/PointCloud.js index d654499..2f84304 100644 --- a/build/PointCloud.js +++ b/build/PointCloud.js @@ -1,9 +1,27 @@ "use strict"; +/** + * Babyplots - Easy, fast, interactive 3D visualizations + * + * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ var __extends = (this && this.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; return extendStatics(d, b); }; return function (d, b) { @@ -15,13 +33,11 @@ var __extends = (this && this.__extends) || (function () { Object.defineProperty(exports, "__esModule", { value: true }); exports.PointCloud = void 0; var mesh_1 = require("@babylonjs/core/Meshes/mesh"); -var sphereBuilder_1 = require("@babylonjs/core/Meshes/Builders/sphereBuilder"); var math_1 = require("@babylonjs/core/Maths/math"); -var solidParticleSystem_1 = require("@babylonjs/core/Particles/solidParticleSystem"); var mesh_vertexData_1 = require("@babylonjs/core/Meshes/mesh.vertexData"); var standardMaterial_1 = require("@babylonjs/core/Materials/standardMaterial"); var babyplots_1 = require("./babyplots"); -var PointCloud = (function (_super) { +var PointCloud = /** @class */ (function (_super) { __extends(PointCloud, _super); function PointCloud(scene, coordinates, colorVar, size, legendData, folded, foldedEmbedding, foldAnimDelay, foldAnimDuration, xScale, yScale, zScale) { if (xScale === void 0) { xScale = 1; } @@ -68,71 +84,42 @@ var PointCloud = (function (_super) { _this._createPointCloud(); return _this; } + /** + * Positions spheres according to coordinates in a SPS + */ PointCloud.prototype._createPointCloud = function () { - if (this._coords.length > 10000) { - var customMesh = new mesh_1.Mesh("custom", this._scene); - var positions = []; - var colors = []; - if (this._folded) { - for (var p = 0; p < this._coords.length; p++) { - positions.push(this._foldedEmbedding[p][0] * this.xScale, this._foldedEmbedding[p][2] * this.zScale, this._foldedEmbedding[p][1] * this.yScale); - var col = math_1.Color4.FromHexString(this._coordColors[p]); - colors.push(col.r, col.g, col.b, col.a); - } - } - else { - for (var p = 0; p < this._coords.length; p++) { - positions.push(this._coords[p][0] * this.xScale, this._coords[p][2] * this.zScale, this._coords[p][1] * this.yScale); - var col = math_1.Color4.FromHexString(this._coordColors[p]); - colors.push(col.r, col.g, col.b, col.a); - } + // prototype cell + var customMesh = new mesh_1.Mesh("custom", this._scene); + // Set arrays for positions and indices + var positions = []; + var colors = []; + if (this._folded) { + for (var p = 0; p < this._coords.length; p++) { + positions.push(this._foldedEmbedding[p][0] * this.xScale, this._foldedEmbedding[p][2] * this.zScale, this._foldedEmbedding[p][1] * this.yScale); + var col = math_1.Color4.FromHexString(this._coordColors[p]); + colors.push(col.r, col.g, col.b, col.a); } - var vertexData = new mesh_vertexData_1.VertexData(); - vertexData.positions = positions; - vertexData.colors = colors; - vertexData.applyToMesh(customMesh, true); - var mat = new standardMaterial_1.StandardMaterial("mat", this._scene); - mat.emissiveColor = new math_1.Color3(1, 1, 1); - mat.disableLighting = true; - mat.pointsCloud = true; - mat.pointSize = this._size; - customMesh.material = mat; - this.mesh = customMesh; } else { - var cell = sphereBuilder_1.SphereBuilder.CreateSphere("sphere", { segments: 2, diameter: this._size * 0.1 }, this._scene); - var SPS = new solidParticleSystem_1.SolidParticleSystem('SPS', this._scene, { - updatable: true, - isPickable: true - }); - SPS.addShape(cell, this._coords.length); - if (this._folded) { - for (var i = 0; i < SPS.nbParticles; i++) { - SPS.particles[i].position.x = this._foldedEmbedding[i][0] * this.xScale; - SPS.particles[i].position.z = this._foldedEmbedding[i][1] * this.zScale; - SPS.particles[i].position.y = this._foldedEmbedding[i][2] * this.yScale; - SPS.particles[i].color = math_1.Color4.FromHexString(this._coordColors[i]); - } - } - else { - for (var i = 0; i < SPS.nbParticles; i++) { - SPS.particles[i].position.x = this._coords[i][0] * this.xScale; - SPS.particles[i].position.z = this._coords[i][1] * this.zScale; - SPS.particles[i].position.y = this._coords[i][2] * this.yScale; - SPS.particles[i].color = math_1.Color4.FromHexString(this._coordColors[i]); - } + for (var p = 0; p < this._coords.length; p++) { + positions.push(this._coords[p][0] * this.xScale, this._coords[p][2] * this.zScale, this._coords[p][1] * this.yScale); + var col = math_1.Color4.FromHexString(this._coordColors[p]); + colors.push(col.r, col.g, col.b, col.a); } - SPS.buildMesh(); - SPS.computeBoundingBox = true; - cell.dispose(); - SPS.setParticles(); - SPS.computeBoundingBox = true; - this._SPS = SPS; - this.mesh = SPS.mesh; - var mat = new standardMaterial_1.StandardMaterial("pointMat", this._scene); - mat.alpha = 1; - this.mesh.material = mat; } + var vertexData = new mesh_vertexData_1.VertexData(); + // Assign positions + vertexData.positions = positions; + vertexData.colors = colors; + // Apply vertexData to custom mesh + vertexData.applyToMesh(customMesh, true); + var mat = new standardMaterial_1.StandardMaterial("mat", this._scene); + mat.emissiveColor = new math_1.Color3(1, 1, 1); + mat.disableLighting = true; + mat.pointsCloud = true; + mat.pointSize = this._size; + customMesh.material = mat; + this.mesh = customMesh; Object.defineProperty(this, "alpha", { set: function (newAlpha) { this.mesh.material.alpha = newAlpha; @@ -141,48 +128,20 @@ var PointCloud = (function (_super) { }; PointCloud.prototype.resetAnimation = function () { this._folded = true; - if (this._SPS) { - for (var i = 0; i < this._SPS.particles.length; i++) { - this._SPS.particles[i].position = new math_1.Vector3(this._foldedEmbedding[i][0] * this.xScale, this._foldedEmbedding[i][2] * this.zScale, this._foldedEmbedding[i][1] * this.yScale); - } - this._SPS.setParticles(); - } - else { - var positionFunction = function (positions) { - var numberOfVertices = positions.length / 3; - for (var i = 0; i < numberOfVertices; i++) { - positions[i * 3] = this._foldedEmbedding[i][0] * this.xScale; - positions[i * 3 + 1] = this._foldedEmbedding[i][2] * this.zScale; - positions[i * 3 + 2] = this._foldedEmbedding[i][1] * this.yScale; - } - }; - this.mesh.updateMeshPositions(positionFunction.bind(this), true); - } + var positionFunction = function (positions) { + var numberOfVertices = positions.length / 3; + for (var i = 0; i < numberOfVertices; i++) { + positions[i * 3] = this._foldedEmbedding[i][0] * this.xScale; + positions[i * 3 + 1] = this._foldedEmbedding[i][2] * this.zScale; + positions[i * 3 + 2] = this._foldedEmbedding[i][1] * this.yScale; + } + }; + this.mesh.updateMeshPositions(positionFunction.bind(this), true); this.mesh.refreshBoundingInfo(); this._foldCounter = 0; }; PointCloud.prototype.update = function () { - if (this._SPS && this._folded) { - if (this._foldCounter < this._foldDelay) { - this._foldCounter += 1; - } - else if (this._foldCounter < this._foldAnimFrames + this._foldDelay) { - for (var i = 0; i < this._SPS.particles.length; i++) { - this._SPS.particles[i].position.addInPlace(this._foldVectorFract[i]); - } - this._foldCounter += 1; - this._SPS.setParticles(); - } - else { - this._folded = false; - for (var i = 0; i < this._SPS.particles.length; i++) { - this._SPS.particles[i].position = new math_1.Vector3(this._coords[i][0] * this.xScale, this._coords[i][2] * this.zScale, this._coords[i][1] * this.yScale); - } - this._SPS.setParticles(); - this.mesh.refreshBoundingInfo(); - } - } - else if (this.mesh && this._folded) { + if (this.mesh && this._folded) { if (this._foldCounter < this._foldDelay) { this._foldCounter += 1; } @@ -215,32 +174,6 @@ var PointCloud = (function (_super) { } return this._folded; }; - PointCloud.prototype._pointPicker = function (_evt, pickResult) { - if (this._pointPicking) { - var faceId = pickResult.faceId; - if (faceId == -1) { - return; - } - var idx = this._SPS.pickedParticles[faceId].idx; - for (var i = 0; i < this._SPS.nbParticles; i++) { - this._SPS.particles[i].color = new math_1.Color4(0.3, 0.3, 0.8, 1); - } - var p = this._SPS.particles[idx]; - p.color = new math_1.Color4(1, 0, 0, 1); - this._SPS.setParticles(); - this.selection = [idx]; - this._selectionCallback(this.selection); - } - }; - PointCloud.prototype.updateSize = function () { - for (var i = 0; i < this._SPS.nbParticles; i++) { - this._SPS.particles[i].scale.x = this._size; - this._SPS.particles[i].scale.y = this._size; - this._SPS.particles[i].scale.z = this._size; - } - this._SPS.setParticles(); - _super.prototype.updateSize.call(this); - }; return PointCloud; }(babyplots_1.Plot)); exports.PointCloud = PointCloud; diff --git a/build/PointCloud.js.map b/build/PointCloud.js.map index 5feb7f3..17be428 100644 --- a/build/PointCloud.js.map +++ b/build/PointCloud.js.map @@ -1 +1 @@ -{"version":3,"file":"PointCloud.js","sourceRoot":"","sources":["../PointCloud.ts"],"names":[],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"PointCloud.js","sourceRoot":"","sources":["../PointCloud.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/build/ShapeCloud.d.ts b/build/ShapeCloud.d.ts new file mode 100644 index 0000000..a1af851 --- /dev/null +++ b/build/ShapeCloud.d.ts @@ -0,0 +1,30 @@ +/** + * Babyplots - Easy, fast, interactive 3D visualizations + * + * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ +import { Scene } from "@babylonjs/core/scene"; +import "@babylonjs/core/Meshes/thinInstanceMesh"; +import { Plot, LegendData } from "./babyplots"; +export declare class ShapeCloud extends Plot { + private _shape; + private _shading; + constructor(scene: Scene, coordinates: number[][], colorVar: string[], shape: string, shading: boolean, size: number, legendData: LegendData, xScale?: number, yScale?: number, zScale?: number); + /** + * Creates shapes at coordinates + */ + private _createShapeCloud; +} diff --git a/build/ShapeCloud.js b/build/ShapeCloud.js new file mode 100644 index 0000000..6092aed --- /dev/null +++ b/build/ShapeCloud.js @@ -0,0 +1,108 @@ +"use strict"; +/** + * Babyplots - Easy, fast, interactive 3D visualizations + * + * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ +var __extends = (this && this.__extends) || (function () { + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; + return extendStatics(d, b); + }; + return function (d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + }; +})(); +Object.defineProperty(exports, "__esModule", { value: true }); +exports.ShapeCloud = void 0; +require("@babylonjs/core/Meshes/thinInstanceMesh"); +var sphereBuilder_1 = require("@babylonjs/core/Meshes/Builders/sphereBuilder"); +var boxBuilder_1 = require("@babylonjs/core/Meshes/Builders/boxBuilder"); +var torusBuilder_1 = require("@babylonjs/core/Meshes/Builders/torusBuilder"); +var cylinderBuilder_1 = require("@babylonjs/core/Meshes/Builders/cylinderBuilder"); +var math_1 = require("@babylonjs/core/Maths/math"); +var standardMaterial_1 = require("@babylonjs/core/Materials/standardMaterial"); +var babyplots_1 = require("./babyplots"); +var ShapeCloud = /** @class */ (function (_super) { + __extends(ShapeCloud, _super); + function ShapeCloud(scene, coordinates, colorVar, shape, shading, size, legendData, xScale, yScale, zScale) { + if (xScale === void 0) { xScale = 1; } + if (yScale === void 0) { yScale = 1; } + if (zScale === void 0) { zScale = 1; } + var _this = _super.call(this, scene, coordinates, colorVar, size * 0.1, legendData, xScale, yScale, zScale) || this; + _this._shape = shape; + _this._shading = shading; + _this._createShapeCloud(); + return _this; + } + /** + * Creates shapes at coordinates + */ + ShapeCloud.prototype._createShapeCloud = function () { + var instanceCount = this._coords.length; + var matricesData = new Float32Array(16 * instanceCount); + var colorData = new Float32Array(4 * instanceCount); + // set position and color data for shapes + for (var i = 0; i < instanceCount; i++) { + var matrix = math_1.Matrix.Translation(this._coords[i][0] * this.xScale, this._coords[i][1] * this.zScale, this._coords[i][2] * this.yScale); + matrix.copyToArray(matricesData, i * 16); + var col = math_1.Color4.FromHexString(this._coordColors[i]); + colorData.set(col.asArray(), i * 4); + } + var origMesh; + switch (this._shape) { + case "box": + origMesh = boxBuilder_1.BoxBuilder.CreateBox("root", { size: this._size }); + break; + case "sphere": + origMesh = sphereBuilder_1.SphereBuilder.CreateSphere("root", { diameter: this._size }); + break; + case "cone": + origMesh = cylinderBuilder_1.CylinderBuilder.CreateCylinder("root", { height: this._size, diameterBottom: this._size, diameterTop: 0 }, this._scene); + break; + case "torus": + origMesh = torusBuilder_1.TorusBuilder.CreateTorus("root", { diameter: this._size, thickness: this._size * 0.5 }, this._scene); + break; + case "cylinder": + origMesh = cylinderBuilder_1.CylinderBuilder.CreateCylinder("root", { height: this._size, diameter: this._size }, this._scene); + break; + default: + origMesh = boxBuilder_1.BoxBuilder.CreateBox("root", { size: 1 }); + break; + } + origMesh.thinInstanceSetBuffer("matrix", matricesData, 16, true); + origMesh.thinInstanceSetBuffer("color", colorData, 4, true); + var mat = new standardMaterial_1.StandardMaterial("shapeMat", this._scene); + if (!this._shading) { + mat.disableLighting = true; + mat.emissiveColor = math_1.Color3.White(); + } + origMesh.material = mat; + this.mesh = origMesh; + Object.defineProperty(this, "alpha", { + set: function (newAlpha) { + this.mesh.material.alpha = newAlpha; + } + }); + }; + return ShapeCloud; +}(babyplots_1.Plot)); +exports.ShapeCloud = ShapeCloud; +//# sourceMappingURL=ShapeCloud.js.map \ No newline at end of file diff --git a/build/ShapeCloud.js.map b/build/ShapeCloud.js.map new file mode 100644 index 0000000..24a4f7d --- /dev/null +++ b/build/ShapeCloud.js.map @@ -0,0 +1 @@ +{"version":3,"file":"ShapeCloud.js","sourceRoot":"","sources":["../ShapeCloud.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/build/Surface.d.ts b/build/Surface.d.ts index 579618a..cb3d4b4 100644 --- a/build/Surface.d.ts +++ b/build/Surface.d.ts @@ -1,3 +1,21 @@ +/** + * Babyplots - Easy, fast, interactive 3D visualizations + * + * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ import { Scene } from "@babylonjs/core/scene"; import { Plot, LegendData } from "./babyplots"; export declare class Surface extends Plot { diff --git a/build/Surface.js b/build/Surface.js index 99d1b4f..f967e1f 100644 --- a/build/Surface.js +++ b/build/Surface.js @@ -1,9 +1,27 @@ "use strict"; +/** + * Babyplots - Easy, fast, interactive 3D visualizations + * + * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ var __extends = (this && this.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; return extendStatics(d, b); }; return function (d, b) { @@ -22,7 +40,7 @@ var mesh_vertexData_1 = require("@babylonjs/core/Meshes/mesh.vertexData"); var standardMaterial_1 = require("@babylonjs/core/Materials/standardMaterial"); var babyplots_1 = require("./babyplots"); var chroma_js_1 = __importDefault(require("chroma-js")); -var Surface = (function (_super) { +var Surface = /** @class */ (function (_super) { __extends(Surface, _super); function Surface(scene, coordinates, colorVar, size, legendData, xScale, yScale, zScale) { if (xScale === void 0) { xScale = 1; } diff --git a/build/Surface.js.map b/build/Surface.js.map index 7f13e6f..51bbbd0 100644 --- a/build/Surface.js.map +++ b/build/Surface.js.map @@ -1 +1 @@ -{"version":3,"file":"Surface.js","sourceRoot":"","sources":["../Surface.ts"],"names":[],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"Surface.js","sourceRoot":"","sources":["../Surface.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/build/babyplots.d.ts b/build/babyplots.d.ts index 9b948c3..5b6aa0a 100644 --- a/build/babyplots.d.ts +++ b/build/babyplots.d.ts @@ -98,6 +98,9 @@ import { Scene } from "@babylonjs/core/scene"; import { Mesh } from "@babylonjs/core/Meshes/mesh"; import { ArcRotateCamera } from "@babylonjs/core/Cameras/arcRotateCamera"; import { AdvancedDynamicTexture } from "@babylonjs/gui/2D/advancedDynamicTexture"; +/** + * Interface for object containing information about axis setup. + */ export interface AxisData { showAxes: boolean[]; static: boolean; @@ -170,6 +173,10 @@ export declare const PLOTTYPES: { heatMap: string[]; imageStack: string[]; }; +/** + * Takes a reasonable guess if a plot can be created from the provided object + * @param plotData Object containing data to be checked for valid plot information + */ export declare function isValidPlot(plotData: {}): boolean; export declare class Plots { private _engine; @@ -201,8 +208,32 @@ export declare class Plots { fixedSize: boolean; ymax: number; R: boolean; + /** + * Initialize the 3d visualization + * + * @param canvasElement ID of the canvas element in the DOM + * @param options Object with general options. See a list of possible options [here](https://bp.bleb.li/documentation/js#plotsObject). + */ constructor(canvasElement: string, options?: {}); + /** + * Load a visualization from a saved JSON object. The R, JavaScript and Python implementations of babyplots as well as the NPC allow the export of visualizations as JSON files. Loading of a saved visualization using fromJSON() overwrites previously set properties of the Plots object. + * + * @param plotData Javascript Object with plot data. + */ fromJSON(plotData: {}): void; + /** + * Create UI buttons to control certain babyplots features. + * + * @param whichBtns Array of buttons to create. Any combination of ["json", "label", "publish", "record"] is allowed. + * + * "json": creates a button that triggers the download of the plot data in .json file format. + * + * "label": creates a button that opens the label manager that allows creation and editing of labels. + * + * "publish": creates a button that opens the publish to bp.bleb.li form. + * + * "record": creates a button to record the plot as a gif. (Requires inclusion of CCapture.js and its gif.worker.js). + */ createButtons(whichBtns?: string[]): void; private _prepDownloadObj; private _downloadJson; @@ -212,18 +243,71 @@ export declare class Plots { private _cancelPublish; private _resetAnimation; private _startRecording; + /** + * Register before render + */ private _prepRender; private _afterRender; + /** + * Zoom camera to fit the complete SPS into the field of view + */ private _cameraFitPlot; + /** + * Creates a 3-dimensional visualization of an RGB image stack, as generated from e.g. a fluorescent microscope, and adds it to the Plots object to visualize it in a canvas. The data must be in a special format for this function which is optimized for size. The easiest way to create this visualization is using the R implementation of babyplots, which includes a function to directly read .tif files. + * + * @param values An array of intensity values. Currently only 8-bit images are supported (0-255). + * @param indices Indices of the values in the original image. + * @param attributes Image attributes. Only a "dim" attribute is needed containing the dimensions (x, y, c, z) of the image. + * @param options An object with options to customize the visualization. + * + * Find a list of possible options [here](https://bp.bleb.li/documentation/js#addImgStack). + */ addImgStack(values: number[], indices: number[], attributes: { dim: number[]; }, options: {}): this; + /** + * Creates a plot and adds it to the Plots object to visualize it in a canvas. The plot types section below enumerates the different kinds of visualizations that can be created using this method. + * + * @param coordinates An array of arrays with coordinates of data points. + * @param plotType The name of one of the plot types. Either "pointCloud", "heatMap", or "surface". + * @param colorBy How to interpret the colorVar parameter, either "direct", "categories", or "values". If colorVar is an array of hex strings, colorBy should be "direct". If colorVar is an array of discrete values (e.g. category names), colorBy should be "categories". If colorVar is an array of continuous values, colorBy should be "values". + * @param colorVar an array of hex strings, category names, or values, corresponding to the data points in the coordinates parameter. + * @param options An object with general and plot type specific options. + * + * Find a list of possible options [here](https://bp.bleb.li/documentation/js#addPlot). + */ addPlot(coordinates: number[][], plotType: string, colorBy: string, colorVar: string[] | number[], options?: {}): Plots; + /** + * Creates a color legend for the plots + */ private _updateLegend; private _createPlotLegend; + /** + * Start rendering the scene + */ doRender(): Plots; + /** + * Resizes the visualization to the current size of the canvas. This method should be bound to a resize event of the canvas. It is also recommended to call the resize() method once after the doRender() call. + * + * @param width Optional: Width of the canvas + * @param height Optional: Height of the canvas + */ resize(width?: number, height?: number): Plots; + /** + * Saves a screenshot of the visualization. + * + * @param size Width and height of square thumbnail in pixels + * @param saveCallback Function that takes the created screenshot as base64 encoded string. + */ thumbnail(size: number, saveCallback: (data: string) => void): void; + /** + * Releases all held resources of the Plots visualization. Useful to clear memory, after a visualization is no longer needed. + */ dispose(): void; + /** + * Add labels from a list of labels. + * + * @param labelList List of lists with the first three elements of the inner lists being the x, y and z coordinates, and the fourth the label text. + */ addLabels(labelList: [[number, number, number, string]]): void; } diff --git a/build/babyplots.js b/build/babyplots.js index 31510d9..efff974 100644 --- a/build/babyplots.js +++ b/build/babyplots.js @@ -148,7 +148,7 @@ exports.styleText = [ ".bbp.publish-form > p.message.warning { color: red; margin-top: 0px; }", ".bbp.publish-form > p.message.success { color: green; }", ].join(" "); -var Plot = (function () { +var Plot = /** @class */ (function () { function Plot(scene, coordinates, colorVar, size, legendData, xScale, yScale, zScale) { if (xScale === void 0) { xScale = 1; } if (yScale === void 0) { yScale = 1; } @@ -218,6 +218,7 @@ function getUniqueVals(source) { } exports.getUniqueVals = getUniqueVals; var ImgStack_1 = require("./ImgStack"); +var ShapeCloud_1 = require("./ShapeCloud"); var PointCloud_1 = require("./PointCloud"); var Surface_1 = require("./Surface"); var HeatMap_1 = require("./HeatMap"); @@ -227,6 +228,10 @@ exports.PLOTTYPES = { 'heatMap': ['coordinates', 'colorBy', 'colorVar'], 'imageStack': ['values', 'indices', 'attributes'] }; +/** + * Takes a reasonable guess if a plot can be created from the provided object + * @param plotData Object containing data to be checked for valid plot information + */ function isValidPlot(plotData) { for (var plotIdx = 0; plotIdx < plotData["plots"].length; plotIdx++) { var plot = plotData["plots"][plotIdx]; @@ -248,7 +253,13 @@ function isValidPlot(plotData) { return true; } exports.isValidPlot = isValidPlot; -var Plots = (function () { +var Plots = /** @class */ (function () { + /** + * Initialize the 3d visualization + * + * @param canvasElement ID of the canvas element in the DOM + * @param options Object with general options. See a list of possible options [here](https://bp.bleb.li/documentation/js#plotsObject). + */ function Plots(canvasElement, options) { if (options === void 0) { options = {}; } this._showLegend = true; @@ -265,7 +276,10 @@ var Plots = (function () { this.fixedSize = false; this.ymax = 0; this.R = false; + // create unique id, needed if multiple babyplots canvases are on the same page. this._uniqID = uuid_1.v4(); + // apply options + // default settings var opts = { backgroundColor: "#ffffffff", xScale: 1, @@ -277,41 +291,56 @@ var Plots = (function () { Object.assign(opts, options); this.turntable = opts.turntable; this.rotationRate = opts.rotationRate; + // setup enginge and scene this._backgroundColor = opts.backgroundColor; this.canvas = document.getElementById(canvasElement); this._engine = new engine_1.Engine(this.canvas, true, { preserveDrawingBuffer: true, stencil: true }); this.scene = new scene_1.Scene(this._engine); + // camera this.camera = new arcRotateCamera_1.ArcRotateCamera("Camera", 0, 0, 10, math_1.Vector3.Zero(), this.scene); this.camera.attachControl(this.canvas, true); this.scene.activeCamera = this.camera; - this.camera.inputs.attached.keyboard.detachControl(this.canvas); + this.camera.inputs.attached.keyboard.detachControl(); this.camera.wheelPrecision = 50; + // background color this.scene.clearColor = math_1.Color4.FromHexString(opts.backgroundColor); + // Axis scales this._xScale = opts.xScale; this._yScale = opts.yScale; this._zScale = opts.zScale; + // two lights to illuminate the cells uniformly (top and bottom) this._hl1 = new hemisphericLight_1.HemisphericLight("HemiLight", new math_1.Vector3(0, 1, 0), this.scene); this._hl1.diffuse = new math_1.Color3(1, 1, 1); this._hl1.specular = new math_1.Color3(0, 0, 0); + // bottom light slightly weaker for better depth perception and orientation this._hl2 = new hemisphericLight_1.HemisphericLight("HemiLight", new math_1.Vector3(0, -1, 0), this.scene); this._hl2.diffuse = new math_1.Color3(0.8, 0.8, 0.8); this._hl2.specular = new math_1.Color3(0, 0, 0); this._annotationManager = new Label_1.AnnotationManager(this.canvas, this.scene, this.ymax, this.camera); this.scene.registerBeforeRender(this._prepRender.bind(this)); this.scene.registerAfterRender(this._afterRender.bind(this)); + // create container for buttons + // create css style var styleElem = document.createElement("style"); styleElem.appendChild(document.createTextNode(exports.styleText)); document.getElementsByTagName('head')[0].appendChild(styleElem); + // create ui elements var buttonBar = document.createElement("div"); buttonBar.className = "bbp button-bar"; buttonBar.style.top = this.canvas.clientTop + 5 + "px"; buttonBar.style.left = this.canvas.clientLeft + 5 + "px"; this.canvas.parentNode.appendChild(buttonBar); this._buttonBar = buttonBar; + // prepare download object this._downloadObj = { plots: [] }; } + /** + * Load a visualization from a saved JSON object. The R, JavaScript and Python implementations of babyplots as well as the NPC allow the export of visualizations as JSON files. Loading of a saved visualization using fromJSON() overwrites previously set properties of the Plots object. + * + * @param plotData Javascript Object with plot data. + */ Plots.prototype.fromJSON = function (plotData) { if (plotData["turntable"] !== undefined) { this.turntable = plotData["turntable"]; @@ -353,7 +382,7 @@ var Plots = (function () { intensityMode: plot["intensityMode"] }); } - else if (["pointCloud", "heatMap", "surface"].indexOf(plot["plotType"]) !== -1) { + else if (["pointCloud", "heatMap", "surface", "shapeCloud"].indexOf(plot["plotType"]) !== -1) { this.addPlot(plot["coordinates"], plot["plotType"], plot["colorBy"], plot["colorVar"], { size: plot["size"], colorScale: plot["colorScale"], @@ -377,7 +406,8 @@ var Plots = (function () { foldAnimDelay: plot["foldAnimDelay"], foldAnimDuration: plot["foldAnimDuration"], colnames: plot["colnames"], - rownames: plot["rownames"] + rownames: plot["rownames"], + shape: plot["shape"] }); } } @@ -389,6 +419,7 @@ var Plots = (function () { this._annotationManager.addLabels(labelData); } else { + // legacy label saving for (var i = 0; i < labelData.length; i++) { var label = labelData[i]; if (label["text"] && label["position"]) { @@ -408,6 +439,19 @@ var Plots = (function () { this.camera.radius = plotData["cameraRadius"]; } }; + /** + * Create UI buttons to control certain babyplots features. + * + * @param whichBtns Array of buttons to create. Any combination of ["json", "label", "publish", "record"] is allowed. + * + * "json": creates a button that triggers the download of the plot data in .json file format. + * + * "label": creates a button that opens the label manager that allows creation and editing of labels. + * + * "publish": creates a button that opens the publish to bp.bleb.li form. + * + * "record": creates a button to record the plot as a gif. (Requires inclusion of CCapture.js and its gif.worker.js). + */ Plots.prototype.createButtons = function (whichBtns) { if (whichBtns === void 0) { whichBtns = ["json", "label", "publish", "record"]; } if (whichBtns.indexOf("json") !== -1) { @@ -487,10 +531,12 @@ var Plots = (function () { formBox.style.boxShadow = "0 0 10px #0003"; formBox.className = "bbp publish-form"; formOverlay.appendChild(formBox); + // Upload description text var formInfo = document.createElement("p"); formInfo.innerText = "Upload the plot to your account on https://bp.bleb.li. Only you will be able to see it. You can change the access settings in your account."; formInfo.className = "form-info"; formBox.appendChild(formInfo); + // Inputs and their labels var usernameLabel = document.createElement("label"); usernameLabel.id = "publishUsernameLabel_" + this._uniqID; usernameLabel.innerText = "Username:"; @@ -509,8 +555,10 @@ var Plots = (function () { var titleInput = document.createElement("input"); titleInput.type = "text"; titleInput.id = "publishTitle_" + this._uniqID; + // message placeholder var msg = document.createElement("p"); msg.id = "publishMessage_" + this._uniqID; + // Buttons var publishBtn = document.createElement("button"); publishBtn.className = "publish-btn"; publishBtn.id = "publishBtn_" + this._uniqID; @@ -527,6 +575,7 @@ var Plots = (function () { closeBtn.onclick = this._cancelPublish.bind(this); closeBtn.innerText = "Close"; closeBtn.style.display = "none"; + // Add all form elements to the form formBox.appendChild(usernameLabel); formBox.appendChild(usernameInput); formBox.appendChild(passwordLabel); @@ -618,10 +667,15 @@ var Plots = (function () { Plots.prototype._startRecording = function () { this._recording = true; }; + /** + * Register before render + */ Plots.prototype._prepRender = function () { + // rotate camera around plot if turntable is true if (this.turntable) { this.camera.alpha += this.rotationRate; } + // update plots with animations if (this._hasAnim) { this._hasAnim = this.plots[0].update(); if (!this._hasAnim) { @@ -642,15 +696,31 @@ var Plots = (function () { this._axes[0].update(this.camera, true); } } + // update axis drawing if (this._axes) { for (var i = 0; i < this._axes.length; i++) { this._axes[i].update(this.camera); } } + // update labels this._annotationManager.update(); + // for (let pltIdx = 0; pltIdx < this.plots.length; pltIdx++) { + // const plot = this.plots[pltIdx]; + // plot.update(); + // } + // if (this._mouseOverCheck) { + // const pickResult = this._scene.pick(this._scene.pointerX, this._scene.pointerY); + // const faceId = pickResult.faceId; + // if (faceId == -1) { + // return; + // } + // const idx = this._SPS.pickedParticles[faceId].idx; + // this._mouseOverCallback(idx); + // } }; Plots.prototype._afterRender = function () { if (this._recording) { + // start recording: if (this._turned === 0) { var worker = "./"; if (this.R) { @@ -664,8 +734,10 @@ var Plots = (function () { quality: 50, workersPath: worker }); + // create capturer, enable turning this._capturer.start(); this.rotationRate = 0.02; + // to return turntable option to its initial state after recording if (this.turntable) { this._wasTurning = true; } @@ -682,11 +754,14 @@ var Plots = (function () { loadingOverlay.appendChild(loadingText); this.canvas.parentNode.appendChild(loadingOverlay); } + // recording in progress: if (this._turned < 2 * Math.PI) { + // while recording, count rotation and capture screenshots this._turned += this.rotationRate; this._capturer.capture(this.canvas); } else { + // after capturing 360°, stop capturing and save gif this._recording = false; this._capturer.stop(); var loadingText = document.getElementById("GIFloadingText_" + this._uniqID); @@ -705,6 +780,9 @@ var Plots = (function () { } } }; + /** + * Zoom camera to fit the complete SPS into the field of view + */ Plots.prototype._cameraFitPlot = function (xRange, yRange, zRange) { var xSize = xRange[1] - xRange[0]; var ySize = yRange[1] - yRange[0]; @@ -728,10 +806,21 @@ var Plots = (function () { this.camera.radius = viewRadius; box.dispose(); this.camera.alpha = 0; - this.camera.beta = 1; + this.camera.beta = 1; // 0 is top view, Pi is bottom this.ymax = yRange[1]; }; + /** + * Creates a 3-dimensional visualization of an RGB image stack, as generated from e.g. a fluorescent microscope, and adds it to the Plots object to visualize it in a canvas. The data must be in a special format for this function which is optimized for size. The easiest way to create this visualization is using the R implementation of babyplots, which includes a function to directly read .tif files. + * + * @param values An array of intensity values. Currently only 8-bit images are supported (0-255). + * @param indices Indices of the values in the original image. + * @param attributes Image attributes. Only a "dim" attribute is needed containing the dimensions (x, y, c, z) of the image. + * @param options An object with options to customize the visualization. + * + * Find a list of possible options [here](https://bp.bleb.li/documentation/js#addImgStack). + */ Plots.prototype.addImgStack = function (values, indices, attributes, options) { + // default options var opts = { size: 1, colorScale: null, @@ -749,7 +838,9 @@ var Plots = (function () { tickLineColors: [["#aaaaaa", "#aaaaaa"], ["#aaaaaa", "#aaaaaa"], ["#aaaaaa", "#aaaaaa"]], intensityMode: "alpha" }; + // apply user options Object.assign(opts, options); + // prepare object for download as json button this._downloadObj["plots"].push({ plotType: "imageStack", values: values, @@ -790,8 +881,20 @@ var Plots = (function () { this.camera.wheelPrecision = 1; return this; }; + /** + * Creates a plot and adds it to the Plots object to visualize it in a canvas. The plot types section below enumerates the different kinds of visualizations that can be created using this method. + * + * @param coordinates An array of arrays with coordinates of data points. + * @param plotType The name of one of the plot types. Either "pointCloud", "heatMap", or "surface". + * @param colorBy How to interpret the colorVar parameter, either "direct", "categories", or "values". If colorVar is an array of hex strings, colorBy should be "direct". If colorVar is an array of discrete values (e.g. category names), colorBy should be "categories". If colorVar is an array of continuous values, colorBy should be "values". + * @param colorVar an array of hex strings, category names, or values, corresponding to the data points in the coordinates parameter. + * @param options An object with general and plot type specific options. + * + * Find a list of possible options [here](https://bp.bleb.li/documentation/js#addPlot). + */ Plots.prototype.addPlot = function (coordinates, plotType, colorBy, colorVar, options) { if (options === void 0) { options = {}; } + // default options var opts = { size: 1, xScale: 1, @@ -818,9 +921,13 @@ var Plots = (function () { foldAnimDelay: null, foldAnimDuration: null, colnames: null, - rownames: null + rownames: null, + shape: null, + shading: true }; + // apply user options Object.assign(opts, options); + // create plot data object for download as json button this._downloadObj["plots"].push({ plotType: plotType, coordinates: coordinates, @@ -848,7 +955,9 @@ var Plots = (function () { foldAnimDelay: opts.foldAnimDelay, foldAnimDuration: opts.foldAnimDuration, colnames: opts.colnames, - rownames: opts.rownames + rownames: opts.rownames, + shape: opts.shape, + shading: opts.shading }); var coordColors = []; var legendData; @@ -865,18 +974,25 @@ var Plots = (function () { } switch (colorBy) { case "categories": + // color plot by discrete categories var groups = colorVar; var uniqueGroups = getUniqueVals(groups); + // sortedCategories can contain an array of category names to order the groups for coloring. + // sortedCategories must be of same length as unique groups in colorVar. + // if no custom ordering is performed through sortedCategories, groups will be sorted alphabetically. uniqueGroups.sort(); if (opts.sortedCategories) { if (uniqueGroups.length === opts.sortedCategories.length) { + // sortedCategories must contain the same category names as those present in colorVar. if (JSON.stringify(uniqueGroups) === JSON.stringify(opts.sortedCategories.slice(0).sort())) { uniqueGroups = opts.sortedCategories; } } } var nColors = uniqueGroups.length; + // Paired is default color scale for discrete variable coloring var colors = chroma_js_1.default.scale(chroma_js_1.default.brewer.Paired).mode('lch').colors(nColors); + // check if color scale should be custom if (opts.colorScale === "custom") { if (opts.customColorScale !== undefined && opts.customColorScale.length !== 0) { if (opts.colorScaleInverted) { @@ -887,10 +1003,12 @@ var Plots = (function () { } } else { + // set colorScale variable to default for legend if custom color scale is invalid opts.colorScale = "Paired"; } } else { + // check if user selected color scale is a valid chromajs color brewer name if (opts.colorScale && chroma_js_1.default.brewer.hasOwnProperty(opts.colorScale)) { if (opts.colorScaleInverted) { colors = chroma_js_1.default.scale(chroma_js_1.default.brewer[opts.colorScale]).domain([1, 0]).mode('lch').colors(nColors); @@ -900,16 +1018,19 @@ var Plots = (function () { } } else { + // set colorScale variable to default for legend if user selected is not valid opts.colorScale = "Paired"; } } for (var i = 0; i < nColors; i++) { colors[i] += "ff"; } + // apply colors to plot points for (var i = 0; i < colorVar.length; i++) { var colorIndex = uniqueGroups.indexOf(groups[i]); coordColors.push(colors[colorIndex]); } + // prepare object for legend drawing legendData = { showLegend: opts.showLegend, discrete: true, @@ -921,10 +1042,14 @@ var Plots = (function () { }; break; case "values": + // color by a continuous variable var min_1 = colorVar.min(); var max_1 = colorVar.max(); + // Oranges is default color scale for continuous variable coloring var colorfunc_1 = chroma_js_1.default.scale(chroma_js_1.default.brewer.Oranges).mode('lch'); + // check if color scale should be custom if (opts.colorScale === "custom") { + // check if custom color scale is valid if (opts.customColorScale !== undefined && opts.customColorScale.length !== 0) { if (opts.colorScaleInverted) { colorfunc_1 = chroma_js_1.default.scale(opts.customColorScale).domain([1, 0]).mode('lch'); @@ -934,10 +1059,12 @@ var Plots = (function () { } } else { + // set colorScale variable to default for legend if custom color scale is invalid opts.colorScale = "Oranges"; } } else { + // check if user selected color scale is a valid chromajs color brewer name if (opts.colorScale && chroma_js_1.default.brewer.hasOwnProperty(opts.colorScale)) { if (opts.colorScaleInverted) { colorfunc_1 = chroma_js_1.default.scale(chroma_js_1.default.brewer[opts.colorScale]).domain([1, 0]).mode('lch'); @@ -947,11 +1074,15 @@ var Plots = (function () { } } else { + // set colorScale variable to default for legend if user selected is not valid opts.colorScale = "Oranges"; } } + // normalize the values to 0-1 range var norm = colorVar.slice().map(function (v) { return (v - min_1) / (max_1 - min_1); }); + // apply colors to plot points coordColors = norm.map(function (v) { return colorfunc_1(v).alpha(1).hex("rgba"); }); + // prepare object for legend drawing legendData = { showLegend: opts.showLegend, discrete: false, @@ -963,6 +1094,7 @@ var Plots = (function () { }; break; case "direct": + // color by color hex strings in colorVar for (var i = 0; i < colorVar.length; i++) { var cl = colorVar[i]; cl = chroma_js_1.default(cl).hex(); @@ -971,6 +1103,7 @@ var Plots = (function () { } coordColors.push(cl); } + // prepare object for legend drawing legendData = { showLegend: false, discrete: false, @@ -982,16 +1115,18 @@ var Plots = (function () { }; break; } + // add remaining properties to legend object legendData.fontSize = opts.fontSize; legendData.fontColor = opts.fontColor; legendData.legendTitle = opts.legendTitle; legendData.legendTitleFontSize = opts.legendTitleFontSize; var plot; var scale; + var boundingBox; switch (plotType) { case "pointCloud": plot = new PointCloud_1.PointCloud(this.scene, coordinates, coordColors, opts.size, legendData, opts.folded, opts.foldedEmbedding, opts.foldAnimDelay, opts.foldAnimDuration, this._xScale, this._yScale, this._zScale); - var boundingBox = plot.mesh.getBoundingInfo().boundingBox; + boundingBox = plot.mesh.getBoundingInfo().boundingBox; rangeX = [ boundingBox.minimumWorld.x, boundingBox.maximumWorld.x @@ -1024,6 +1159,27 @@ var Plots = (function () { this._zScale, ]; break; + case "shapeCloud": + plot = new ShapeCloud_1.ShapeCloud(this.scene, coordinates, coordColors, opts.shape, opts.shading, opts.size, legendData, this._xScale, this._yScale, this._zScale); + boundingBox = plot.mesh.getBoundingInfo().boundingBox; + rangeX = [ + boundingBox.minimumWorld.x, + boundingBox.maximumWorld.x + ]; + rangeY = [ + boundingBox.minimumWorld.y, + boundingBox.maximumWorld.y + ]; + rangeZ = [ + boundingBox.minimumWorld.z, + boundingBox.maximumWorld.z + ]; + scale = [ + this._xScale, + this._yScale, + this._zScale, + ]; + break; case "heatMap": plot = new HeatMap_1.HeatMap(this.scene, coordinates, coordColors, opts.size, legendData, this._xScale, this._yScale, this._zScale); rangeX = [0, coordinates.length * this._xScale]; @@ -1061,10 +1217,14 @@ var Plots = (function () { this._cameraFitPlot(rangeX, rangeY, rangeZ); return this; }; + /** + * Creates a color legend for the plots + */ Plots.prototype._updateLegend = function () { if (this._legend) { this._legend.dispose(); } + // create fullscreen GUI texture var uiLayer = advancedDynamicTexture_1.AdvancedDynamicTexture.CreateFullscreenUI("UI"); var rightFree = true; var leftFree = true; @@ -1107,10 +1267,13 @@ var Plots = (function () { } var n; var breakN = 20; + // create grid for placing legend in correct position var grid = new controls_1.Grid(); uiLayer.addControl(grid); + // main position of legend (right middle) var legendWidth = 0.2; if (legendData.discrete) { + // number of clusters n = legendData.breaks.length; if (n > breakN * 2) { legendWidth = 0.4; @@ -1154,6 +1317,7 @@ var Plots = (function () { legendTitle.horizontalAlignment = controls_1.Control.HORIZONTAL_ALIGNMENT_LEFT; grid.addControl(legendTitle, 0, legendColumn); } + // for continuous measures display color bar and max and min values. if (!legendData.discrete) { var innerGrid_1 = new controls_1.Grid(); innerGrid_1.addColumnDefinition(0.2); @@ -1177,6 +1341,7 @@ var Plots = (function () { innerGrid_1.addRowDefinition(115, true); innerGrid_1.addRowDefinition(padding, true); } + // color bar var colors = void 0; if (legendData.colorScale === "custom") { colors = chroma_js_1.default.scale(legendData.customColorScale).mode('lch').colors(nBreaks); @@ -1199,6 +1364,7 @@ var Plots = (function () { legendColor_1.height = 1; scaleGrid.addControl(legendColor_1, i, 0); } + // label text var labelGrid = new controls_1.Grid(); labelGrid.addColumnDefinition(1); labelGrid.addRowDefinition(labelSpace); @@ -1226,7 +1392,9 @@ var Plots = (function () { labelGrid.addControl(maxText, 0, 0); } else { + // inner Grid contains legend rows and columns for color and text var innerGrid = new controls_1.Grid(); + // two legend columns when more than 15 colors if (n > breakN * 2) { innerGrid.addColumnDefinition(0.1); innerGrid.addColumnDefinition(0.4); @@ -1261,12 +1429,15 @@ var Plots = (function () { else { colors = chroma_js_1.default.scale(chroma_js_1.default.brewer[legendData.colorScale]).mode('lch').colors(n); } + // add color box and legend text for (var i = 0; i < n; i++) { + // color var legendColor = new controls_1.Rectangle(); legendColor.background = colors[i]; legendColor.thickness = 0; legendColor.width = legendData.fontSize + "px"; legendColor.height = legendData.fontSize + "px"; + // use second column for many entries if (i > breakN * 2 - 1) { innerGrid.addControl(legendColor, i - breakN * 2, 4); } @@ -1276,11 +1447,13 @@ var Plots = (function () { else { innerGrid.addControl(legendColor, i, 0); } + // text var legendText = new controls_1.TextBlock(); legendText.text = legendData.breaks[i].toString(); legendText.color = legendData.fontColor; legendText.fontSize = legendData.fontSize + "px"; legendText.textHorizontalAlignment = controls_1.Control.HORIZONTAL_ALIGNMENT_LEFT; + // use second column for many entries if (i > breakN * 2 - 1) { innerGrid.addControl(legendText, i - breakN * 2, 5); } @@ -1294,6 +1467,9 @@ var Plots = (function () { } return uiLayer; }; + /** + * Start rendering the scene + */ Plots.prototype.doRender = function () { var _this = this; this._engine.runRenderLoop(function () { @@ -1301,6 +1477,12 @@ var Plots = (function () { }); return this; }; + /** + * Resizes the visualization to the current size of the canvas. This method should be bound to a resize event of the canvas. It is also recommended to call the resize() method once after the doRender() call. + * + * @param width Optional: Width of the canvas + * @param height Optional: Height of the canvas + */ Plots.prototype.resize = function (width, height) { if (width !== undefined && height !== undefined) { if (this.R) { @@ -1318,13 +1500,27 @@ var Plots = (function () { this._engine.resize(); return this; }; + /** + * Saves a screenshot of the visualization. + * + * @param size Width and height of square thumbnail in pixels + * @param saveCallback Function that takes the created screenshot as base64 encoded string. + */ Plots.prototype.thumbnail = function (size, saveCallback) { screenshotTools_1.ScreenshotTools.CreateScreenshot(this._engine, this.camera, size, saveCallback); }; + /** + * Releases all held resources of the Plots visualization. Useful to clear memory, after a visualization is no longer needed. + */ Plots.prototype.dispose = function () { this.scene.dispose(); this._engine.dispose(); }; + /** + * Add labels from a list of labels. + * + * @param labelList List of lists with the first three elements of the inner lists being the x, y and z coordinates, and the fourth the label text. + */ Plots.prototype.addLabels = function (labelList) { this._annotationManager.addLabels(labelList); }; diff --git a/build/babyplots.js.map b/build/babyplots.js.map index 310ffb1..876788f 100644 --- a/build/babyplots.js.map +++ b/build/babyplots.js.map @@ -1 +1 @@ -{"version":3,"file":"babyplots.js","sourceRoot":"","sources":["../babyplots.ts"],"names":[],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"babyplots.js","sourceRoot":"","sources":["../babyplots.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/dist/babyplots.js b/dist/babyplots.js index b04a423..6ec6c94 100644 --- a/dist/babyplots.js +++ b/dist/babyplots.js @@ -1,3 +1,3 @@ /*! For license information please see babyplots.js.LICENSE.txt */ -var Baby=function(e){var t={};function i(r){if(t[r])return t[r].exports;var n=t[r]={i:r,l:!1,exports:{}};return e[r].call(n.exports,n,n.exports,i),n.l=!0,n.exports}return i.m=e,i.c=t,i.d=function(e,t,r){i.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:r})},i.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},i.t=function(e,t){if(1&t&&(e=i(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var r=Object.create(null);if(i.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var n in e)i.d(r,n,function(t){return e[t]}.bind(null,n));return r},i.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return i.d(t,"a",t),t},i.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},i.p="",i(i.s=64)}([function(e,t,i){"use strict";i.d(t,"d",(function(){return a})),i.d(t,"e",(function(){return h})),i.d(t,"f",(function(){return l})),i.d(t,"b",(function(){return c})),i.d(t,"a",(function(){return u})),i.d(t,"c",(function(){return d}));var r=i(17),n=i(16),o=i(30),s=i(10),a=function(){function e(e,t){void 0===e&&(e=0),void 0===t&&(t=0),this.x=e,this.y=t}return e.prototype.toString=function(){return"{X: "+this.x+" Y:"+this.y+"}"},e.prototype.getClassName=function(){return"Vector2"},e.prototype.getHashCode=function(){var e=0|this.x;return e=397*e^(0|this.y)},e.prototype.toArray=function(e,t){return void 0===t&&(t=0),e[t]=this.x,e[t+1]=this.y,this},e.prototype.asArray=function(){var e=new Array;return this.toArray(e,0),e},e.prototype.copyFrom=function(e){return this.x=e.x,this.y=e.y,this},e.prototype.copyFromFloats=function(e,t){return this.x=e,this.y=t,this},e.prototype.set=function(e,t){return this.copyFromFloats(e,t)},e.prototype.add=function(t){return new e(this.x+t.x,this.y+t.y)},e.prototype.addToRef=function(e,t){return t.x=this.x+e.x,t.y=this.y+e.y,this},e.prototype.addInPlace=function(e){return this.x+=e.x,this.y+=e.y,this},e.prototype.addVector3=function(t){return new e(this.x+t.x,this.y+t.y)},e.prototype.subtract=function(t){return new e(this.x-t.x,this.y-t.y)},e.prototype.subtractToRef=function(e,t){return t.x=this.x-e.x,t.y=this.y-e.y,this},e.prototype.subtractInPlace=function(e){return this.x-=e.x,this.y-=e.y,this},e.prototype.multiplyInPlace=function(e){return this.x*=e.x,this.y*=e.y,this},e.prototype.multiply=function(t){return new e(this.x*t.x,this.y*t.y)},e.prototype.multiplyToRef=function(e,t){return t.x=this.x*e.x,t.y=this.y*e.y,this},e.prototype.multiplyByFloats=function(t,i){return new e(this.x*t,this.y*i)},e.prototype.divide=function(t){return new e(this.x/t.x,this.y/t.y)},e.prototype.divideToRef=function(e,t){return t.x=this.x/e.x,t.y=this.y/e.y,this},e.prototype.divideInPlace=function(e){return this.divideToRef(e,this)},e.prototype.negate=function(){return new e(-this.x,-this.y)},e.prototype.negateInPlace=function(){return this.x*=-1,this.y*=-1,this},e.prototype.negateToRef=function(e){return e.copyFromFloats(-1*this.x,-1*this.y)},e.prototype.scaleInPlace=function(e){return this.x*=e,this.y*=e,this},e.prototype.scale=function(t){var i=new e(0,0);return this.scaleToRef(t,i),i},e.prototype.scaleToRef=function(e,t){return t.x=this.x*e,t.y=this.y*e,this},e.prototype.scaleAndAddToRef=function(e,t){return t.x+=this.x*e,t.y+=this.y*e,this},e.prototype.equals=function(e){return e&&this.x===e.x&&this.y===e.y},e.prototype.equalsWithEpsilon=function(e,t){return void 0===t&&(t=n.a),e&&r.a.WithinEpsilon(this.x,e.x,t)&&r.a.WithinEpsilon(this.y,e.y,t)},e.prototype.floor=function(){return new e(Math.floor(this.x),Math.floor(this.y))},e.prototype.fract=function(){return new e(this.x-Math.floor(this.x),this.y-Math.floor(this.y))},e.prototype.length=function(){return Math.sqrt(this.x*this.x+this.y*this.y)},e.prototype.lengthSquared=function(){return this.x*this.x+this.y*this.y},e.prototype.normalize=function(){var e=this.length();return 0===e||(this.x/=e,this.y/=e),this},e.prototype.clone=function(){return new e(this.x,this.y)},e.Zero=function(){return new e(0,0)},e.One=function(){return new e(1,1)},e.FromArray=function(t,i){return void 0===i&&(i=0),new e(t[i],t[i+1])},e.FromArrayToRef=function(e,t,i){i.x=e[t],i.y=e[t+1]},e.CatmullRom=function(t,i,r,n,o){var s=o*o,a=o*s;return new e(.5*(2*i.x+(-t.x+r.x)*o+(2*t.x-5*i.x+4*r.x-n.x)*s+(-t.x+3*i.x-3*r.x+n.x)*a),.5*(2*i.y+(-t.y+r.y)*o+(2*t.y-5*i.y+4*r.y-n.y)*s+(-t.y+3*i.y-3*r.y+n.y)*a))},e.Clamp=function(t,i,r){var n=t.x;n=(n=n>r.x?r.x:n)r.y?r.y:o)i.x?t.x:i.x,t.y>i.y?t.y:i.y)},e.Transform=function(t,i){var r=e.Zero();return e.TransformToRef(t,i,r),r},e.TransformToRef=function(e,t,i){var r=t.m,n=e.x*r[0]+e.y*r[4]+r[12],o=e.x*r[1]+e.y*r[5]+r[13];i.x=n,i.y=o},e.PointInTriangle=function(e,t,i,r){var n=.5*(-i.y*r.x+t.y*(-i.x+r.x)+t.x*(i.y-r.y)+i.x*r.y),o=n<0?-1:1,s=(t.y*r.x-t.x*r.y+(r.y-t.y)*e.x+(t.x-r.x)*e.y)*o,a=(t.x*i.y-t.y*i.x+(t.y-i.y)*e.x+(i.x-t.x)*e.y)*o;return s>0&&a>0&&s+a<2*n*o},e.Distance=function(t,i){return Math.sqrt(e.DistanceSquared(t,i))},e.DistanceSquared=function(e,t){var i=e.x-t.x,r=e.y-t.y;return i*i+r*r},e.Center=function(e,t){var i=e.add(t);return i.scaleInPlace(.5),i},e.DistanceOfPointFromSegment=function(t,i,r){var n=e.DistanceSquared(i,r);if(0===n)return e.Distance(t,i);var o=r.subtract(i),s=Math.max(0,Math.min(1,e.Dot(t.subtract(i),o)/n)),a=i.add(o.multiplyByFloats(s,s));return e.Distance(t,a)},e}(),h=function(){function e(e,t,i){void 0===e&&(e=0),void 0===t&&(t=0),void 0===i&&(i=0),this.x=e,this.y=t,this.z=i}return e.prototype.toString=function(){return"{X: "+this.x+" Y:"+this.y+" Z:"+this.z+"}"},e.prototype.getClassName=function(){return"Vector3"},e.prototype.getHashCode=function(){var e=0|this.x;return e=397*(e=397*e^(0|this.y))^(0|this.z)},e.prototype.asArray=function(){var e=[];return this.toArray(e,0),e},e.prototype.toArray=function(e,t){return void 0===t&&(t=0),e[t]=this.x,e[t+1]=this.y,e[t+2]=this.z,this},e.prototype.toQuaternion=function(){return c.RotationYawPitchRoll(this.y,this.x,this.z)},e.prototype.addInPlace=function(e){return this.addInPlaceFromFloats(e.x,e.y,e.z)},e.prototype.addInPlaceFromFloats=function(e,t,i){return this.x+=e,this.y+=t,this.z+=i,this},e.prototype.add=function(t){return new e(this.x+t.x,this.y+t.y,this.z+t.z)},e.prototype.addToRef=function(e,t){return t.copyFromFloats(this.x+e.x,this.y+e.y,this.z+e.z)},e.prototype.subtractInPlace=function(e){return this.x-=e.x,this.y-=e.y,this.z-=e.z,this},e.prototype.subtract=function(t){return new e(this.x-t.x,this.y-t.y,this.z-t.z)},e.prototype.subtractToRef=function(e,t){return this.subtractFromFloatsToRef(e.x,e.y,e.z,t)},e.prototype.subtractFromFloats=function(t,i,r){return new e(this.x-t,this.y-i,this.z-r)},e.prototype.subtractFromFloatsToRef=function(e,t,i,r){return r.copyFromFloats(this.x-e,this.y-t,this.z-i)},e.prototype.negate=function(){return new e(-this.x,-this.y,-this.z)},e.prototype.negateInPlace=function(){return this.x*=-1,this.y*=-1,this.z*=-1,this},e.prototype.negateToRef=function(e){return e.copyFromFloats(-1*this.x,-1*this.y,-1*this.z)},e.prototype.scaleInPlace=function(e){return this.x*=e,this.y*=e,this.z*=e,this},e.prototype.scale=function(t){return new e(this.x*t,this.y*t,this.z*t)},e.prototype.scaleToRef=function(e,t){return t.copyFromFloats(this.x*e,this.y*e,this.z*e)},e.prototype.scaleAndAddToRef=function(e,t){return t.addInPlaceFromFloats(this.x*e,this.y*e,this.z*e)},e.prototype.equals=function(e){return e&&this.x===e.x&&this.y===e.y&&this.z===e.z},e.prototype.equalsWithEpsilon=function(e,t){return void 0===t&&(t=n.a),e&&r.a.WithinEpsilon(this.x,e.x,t)&&r.a.WithinEpsilon(this.y,e.y,t)&&r.a.WithinEpsilon(this.z,e.z,t)},e.prototype.equalsToFloats=function(e,t,i){return this.x===e&&this.y===t&&this.z===i},e.prototype.multiplyInPlace=function(e){return this.x*=e.x,this.y*=e.y,this.z*=e.z,this},e.prototype.multiply=function(e){return this.multiplyByFloats(e.x,e.y,e.z)},e.prototype.multiplyToRef=function(e,t){return t.copyFromFloats(this.x*e.x,this.y*e.y,this.z*e.z)},e.prototype.multiplyByFloats=function(t,i,r){return new e(this.x*t,this.y*i,this.z*r)},e.prototype.divide=function(t){return new e(this.x/t.x,this.y/t.y,this.z/t.z)},e.prototype.divideToRef=function(e,t){return t.copyFromFloats(this.x/e.x,this.y/e.y,this.z/e.z)},e.prototype.divideInPlace=function(e){return this.divideToRef(e,this)},e.prototype.minimizeInPlace=function(e){return this.minimizeInPlaceFromFloats(e.x,e.y,e.z)},e.prototype.maximizeInPlace=function(e){return this.maximizeInPlaceFromFloats(e.x,e.y,e.z)},e.prototype.minimizeInPlaceFromFloats=function(e,t,i){return ethis.x&&(this.x=e),t>this.y&&(this.y=t),i>this.z&&(this.z=i),this},e.prototype.isNonUniformWithinEpsilon=function(e){var t=Math.abs(this.x),i=Math.abs(this.y);if(!r.a.WithinEpsilon(t,i,e))return!0;var n=Math.abs(this.z);return!r.a.WithinEpsilon(t,n,e)||!r.a.WithinEpsilon(i,n,e)},Object.defineProperty(e.prototype,"isNonUniform",{get:function(){var e=Math.abs(this.x),t=Math.abs(this.y);if(e!==t)return!0;var i=Math.abs(this.z);return e!==i||t!==i},enumerable:!0,configurable:!0}),e.prototype.floor=function(){return new e(Math.floor(this.x),Math.floor(this.y),Math.floor(this.z))},e.prototype.fract=function(){return new e(this.x-Math.floor(this.x),this.y-Math.floor(this.y),this.z-Math.floor(this.z))},e.prototype.length=function(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)},e.prototype.lengthSquared=function(){return this.x*this.x+this.y*this.y+this.z*this.z},e.prototype.normalize=function(){return this.normalizeFromLength(this.length())},e.prototype.reorderInPlace=function(e){var t=this;return"xyz"===(e=e.toLowerCase())||(f.Vector3[0].copyFrom(this),["x","y","z"].forEach((function(i,r){t[i]=f.Vector3[0][e[r]]}))),this},e.prototype.rotateByQuaternionToRef=function(t,i){return t.toRotationMatrix(f.Matrix[0]),e.TransformCoordinatesToRef(this,f.Matrix[0],i),i},e.prototype.rotateByQuaternionAroundPointToRef=function(e,t,i){return this.subtractToRef(t,f.Vector3[0]),f.Vector3[0].rotateByQuaternionToRef(e,f.Vector3[0]),t.addToRef(f.Vector3[0],i),i},e.prototype.cross=function(t){return e.Cross(this,t)},e.prototype.normalizeFromLength=function(e){return 0===e||1===e?this:this.scaleInPlace(1/e)},e.prototype.normalizeToNew=function(){var t=new e(0,0,0);return this.normalizeToRef(t),t},e.prototype.normalizeToRef=function(e){var t=this.length();return 0===t||1===t?e.copyFromFloats(this.x,this.y,this.z):this.scaleToRef(1/t,e)},e.prototype.clone=function(){return new e(this.x,this.y,this.z)},e.prototype.copyFrom=function(e){return this.copyFromFloats(e.x,e.y,e.z)},e.prototype.copyFromFloats=function(e,t,i){return this.x=e,this.y=t,this.z=i,this},e.prototype.set=function(e,t,i){return this.copyFromFloats(e,t,i)},e.prototype.setAll=function(e){return this.x=this.y=this.z=e,this},e.GetClipFactor=function(t,i,r,n){var o=e.Dot(t,r)-n;return o/(o-(e.Dot(i,r)-n))},e.GetAngleBetweenVectors=function(t,i,r){var n=t.normalizeToRef(f.Vector3[1]),o=i.normalizeToRef(f.Vector3[2]),s=e.Dot(n,o),a=f.Vector3[3];return e.CrossToRef(n,o,a),e.Dot(a,r)>0?Math.acos(s):-Math.acos(s)},e.FromArray=function(t,i){return void 0===i&&(i=0),new e(t[i],t[i+1],t[i+2])},e.FromFloatArray=function(t,i){return e.FromArray(t,i)},e.FromArrayToRef=function(e,t,i){i.x=e[t],i.y=e[t+1],i.z=e[t+2]},e.FromFloatArrayToRef=function(t,i,r){return e.FromArrayToRef(t,i,r)},e.FromFloatsToRef=function(e,t,i,r){r.copyFromFloats(e,t,i)},e.Zero=function(){return new e(0,0,0)},e.One=function(){return new e(1,1,1)},e.Up=function(){return new e(0,1,0)},Object.defineProperty(e,"UpReadOnly",{get:function(){return e._UpReadOnly},enumerable:!0,configurable:!0}),Object.defineProperty(e,"ZeroReadOnly",{get:function(){return e._ZeroReadOnly},enumerable:!0,configurable:!0}),e.Down=function(){return new e(0,-1,0)},e.Forward=function(){return new e(0,0,1)},e.Backward=function(){return new e(0,0,-1)},e.Right=function(){return new e(1,0,0)},e.Left=function(){return new e(-1,0,0)},e.TransformCoordinates=function(t,i){var r=e.Zero();return e.TransformCoordinatesToRef(t,i,r),r},e.TransformCoordinatesToRef=function(t,i,r){e.TransformCoordinatesFromFloatsToRef(t.x,t.y,t.z,i,r)},e.TransformCoordinatesFromFloatsToRef=function(e,t,i,r,n){var o=r.m,s=e*o[0]+t*o[4]+i*o[8]+o[12],a=e*o[1]+t*o[5]+i*o[9]+o[13],h=e*o[2]+t*o[6]+i*o[10]+o[14],l=1/(e*o[3]+t*o[7]+i*o[11]+o[15]);n.x=s*l,n.y=a*l,n.z=h*l},e.TransformNormal=function(t,i){var r=e.Zero();return e.TransformNormalToRef(t,i,r),r},e.TransformNormalToRef=function(e,t,i){this.TransformNormalFromFloatsToRef(e.x,e.y,e.z,t,i)},e.TransformNormalFromFloatsToRef=function(e,t,i,r,n){var o=r.m;n.x=e*o[0]+t*o[4]+i*o[8],n.y=e*o[1]+t*o[5]+i*o[9],n.z=e*o[2]+t*o[6]+i*o[10]},e.CatmullRom=function(t,i,r,n,o){var s=o*o,a=o*s;return new e(.5*(2*i.x+(-t.x+r.x)*o+(2*t.x-5*i.x+4*r.x-n.x)*s+(-t.x+3*i.x-3*r.x+n.x)*a),.5*(2*i.y+(-t.y+r.y)*o+(2*t.y-5*i.y+4*r.y-n.y)*s+(-t.y+3*i.y-3*r.y+n.y)*a),.5*(2*i.z+(-t.z+r.z)*o+(2*t.z-5*i.z+4*r.z-n.z)*s+(-t.z+3*i.z-3*r.z+n.z)*a))},e.Clamp=function(t,i,r){var n=new e;return e.ClampToRef(t,i,r,n),n},e.ClampToRef=function(e,t,i,r){var n=e.x;n=(n=n>i.x?i.x:n)i.y?i.y:o)i.z?i.z:s)this.x&&(this.x=e.x),e.y>this.y&&(this.y=e.y),e.z>this.z&&(this.z=e.z),e.w>this.w&&(this.w=e.w),this},e.prototype.floor=function(){return new e(Math.floor(this.x),Math.floor(this.y),Math.floor(this.z),Math.floor(this.w))},e.prototype.fract=function(){return new e(this.x-Math.floor(this.x),this.y-Math.floor(this.y),this.z-Math.floor(this.z),this.w-Math.floor(this.w))},e.prototype.length=function(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w)},e.prototype.lengthSquared=function(){return this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w},e.prototype.normalize=function(){var e=this.length();return 0===e?this:this.scaleInPlace(1/e)},e.prototype.toVector3=function(){return new h(this.x,this.y,this.z)},e.prototype.clone=function(){return new e(this.x,this.y,this.z,this.w)},e.prototype.copyFrom=function(e){return this.x=e.x,this.y=e.y,this.z=e.z,this.w=e.w,this},e.prototype.copyFromFloats=function(e,t,i,r){return this.x=e,this.y=t,this.z=i,this.w=r,this},e.prototype.set=function(e,t,i,r){return this.copyFromFloats(e,t,i,r)},e.prototype.setAll=function(e){return this.x=this.y=this.z=this.w=e,this},e.FromArray=function(t,i){return i||(i=0),new e(t[i],t[i+1],t[i+2],t[i+3])},e.FromArrayToRef=function(e,t,i){i.x=e[t],i.y=e[t+1],i.z=e[t+2],i.w=e[t+3]},e.FromFloatArrayToRef=function(t,i,r){e.FromArrayToRef(t,i,r)},e.FromFloatsToRef=function(e,t,i,r,n){n.x=e,n.y=t,n.z=i,n.w=r},e.Zero=function(){return new e(0,0,0,0)},e.One=function(){return new e(1,1,1,1)},e.Normalize=function(t){var i=e.Zero();return e.NormalizeToRef(t,i),i},e.NormalizeToRef=function(e,t){t.copyFrom(e),t.normalize()},e.Minimize=function(e,t){var i=e.clone();return i.minimizeInPlace(t),i},e.Maximize=function(e,t){var i=e.clone();return i.maximizeInPlace(t),i},e.Distance=function(t,i){return Math.sqrt(e.DistanceSquared(t,i))},e.DistanceSquared=function(e,t){var i=e.x-t.x,r=e.y-t.y,n=e.z-t.z,o=e.w-t.w;return i*i+r*r+n*n+o*o},e.Center=function(e,t){var i=e.add(t);return i.scaleInPlace(.5),i},e.TransformNormal=function(t,i){var r=e.Zero();return e.TransformNormalToRef(t,i,r),r},e.TransformNormalToRef=function(e,t,i){var r=t.m,n=e.x*r[0]+e.y*r[4]+e.z*r[8],o=e.x*r[1]+e.y*r[5]+e.z*r[9],s=e.x*r[2]+e.y*r[6]+e.z*r[10];i.x=n,i.y=o,i.z=s,i.w=e.w},e.TransformNormalFromFloatsToRef=function(e,t,i,r,n,o){var s=n.m;o.x=e*s[0]+t*s[4]+i*s[8],o.y=e*s[1]+t*s[5]+i*s[9],o.z=e*s[2]+t*s[6]+i*s[10],o.w=r},e.FromVector3=function(t,i){return void 0===i&&(i=0),new e(t.x,t.y,t.z,i)},e}(),c=function(){function e(e,t,i,r){void 0===e&&(e=0),void 0===t&&(t=0),void 0===i&&(i=0),void 0===r&&(r=1),this.x=e,this.y=t,this.z=i,this.w=r}return e.prototype.toString=function(){return"{X: "+this.x+" Y:"+this.y+" Z:"+this.z+" W:"+this.w+"}"},e.prototype.getClassName=function(){return"Quaternion"},e.prototype.getHashCode=function(){var e=0|this.x;return e=397*(e=397*(e=397*e^(0|this.y))^(0|this.z))^(0|this.w)},e.prototype.asArray=function(){return[this.x,this.y,this.z,this.w]},e.prototype.equals=function(e){return e&&this.x===e.x&&this.y===e.y&&this.z===e.z&&this.w===e.w},e.prototype.equalsWithEpsilon=function(e,t){return void 0===t&&(t=n.a),e&&r.a.WithinEpsilon(this.x,e.x,t)&&r.a.WithinEpsilon(this.y,e.y,t)&&r.a.WithinEpsilon(this.z,e.z,t)&&r.a.WithinEpsilon(this.w,e.w,t)},e.prototype.clone=function(){return new e(this.x,this.y,this.z,this.w)},e.prototype.copyFrom=function(e){return this.x=e.x,this.y=e.y,this.z=e.z,this.w=e.w,this},e.prototype.copyFromFloats=function(e,t,i,r){return this.x=e,this.y=t,this.z=i,this.w=r,this},e.prototype.set=function(e,t,i,r){return this.copyFromFloats(e,t,i,r)},e.prototype.add=function(t){return new e(this.x+t.x,this.y+t.y,this.z+t.z,this.w+t.w)},e.prototype.addInPlace=function(e){return this.x+=e.x,this.y+=e.y,this.z+=e.z,this.w+=e.w,this},e.prototype.subtract=function(t){return new e(this.x-t.x,this.y-t.y,this.z-t.z,this.w-t.w)},e.prototype.scale=function(t){return new e(this.x*t,this.y*t,this.z*t,this.w*t)},e.prototype.scaleToRef=function(e,t){return t.x=this.x*e,t.y=this.y*e,t.z=this.z*e,t.w=this.w*e,this},e.prototype.scaleInPlace=function(e){return this.x*=e,this.y*=e,this.z*=e,this.w*=e,this},e.prototype.scaleAndAddToRef=function(e,t){return t.x+=this.x*e,t.y+=this.y*e,t.z+=this.z*e,t.w+=this.w*e,this},e.prototype.multiply=function(t){var i=new e(0,0,0,1);return this.multiplyToRef(t,i),i},e.prototype.multiplyToRef=function(e,t){var i=this.x*e.w+this.y*e.z-this.z*e.y+this.w*e.x,r=-this.x*e.z+this.y*e.w+this.z*e.x+this.w*e.y,n=this.x*e.y-this.y*e.x+this.z*e.w+this.w*e.z,o=-this.x*e.x-this.y*e.y-this.z*e.z+this.w*e.w;return t.copyFromFloats(i,r,n,o),this},e.prototype.multiplyInPlace=function(e){return this.multiplyToRef(e,this),this},e.prototype.conjugateToRef=function(e){return e.copyFromFloats(-this.x,-this.y,-this.z,this.w),this},e.prototype.conjugateInPlace=function(){return this.x*=-1,this.y*=-1,this.z*=-1,this},e.prototype.conjugate=function(){return new e(-this.x,-this.y,-this.z,this.w)},e.prototype.length=function(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w)},e.prototype.normalize=function(){var e=this.length();if(0===e)return this;var t=1/e;return this.x*=t,this.y*=t,this.z*=t,this.w*=t,this},e.prototype.toEulerAngles=function(e){void 0===e&&(e="YZX");var t=h.Zero();return this.toEulerAnglesToRef(t),t},e.prototype.toEulerAnglesToRef=function(e){var t=this.z,i=this.x,r=this.y,n=this.w,o=n*n,s=t*t,a=i*i,h=r*r,l=r*t-i*n,c=.4999999;return l<-c?(e.y=2*Math.atan2(r,n),e.x=Math.PI/2,e.z=0):l>c?(e.y=2*Math.atan2(r,n),e.x=-Math.PI/2,e.z=0):(e.z=Math.atan2(2*(i*r+t*n),-s-a+h+o),e.x=Math.asin(-2*(t*r-i*n)),e.y=Math.atan2(2*(t*i+r*n),s-a-h+o)),this},e.prototype.toRotationMatrix=function(e){return u.FromQuaternionToRef(this,e),this},e.prototype.fromRotationMatrix=function(t){return e.FromRotationMatrixToRef(t,this),this},e.FromRotationMatrix=function(t){var i=new e;return e.FromRotationMatrixToRef(t,i),i},e.FromRotationMatrixToRef=function(e,t){var i,r=e.m,n=r[0],o=r[4],s=r[8],a=r[1],h=r[5],l=r[9],c=r[2],u=r[6],f=r[10],d=n+h+f;d>0?(i=.5/Math.sqrt(d+1),t.w=.25/i,t.x=(u-l)*i,t.y=(s-c)*i,t.z=(a-o)*i):n>h&&n>f?(i=2*Math.sqrt(1+n-h-f),t.w=(u-l)/i,t.x=.25*i,t.y=(o+a)/i,t.z=(s+c)/i):h>f?(i=2*Math.sqrt(1+h-n-f),t.w=(s-c)/i,t.x=(o+a)/i,t.y=.25*i,t.z=(l+u)/i):(i=2*Math.sqrt(1+f-n-h),t.w=(a-o)/i,t.x=(s+c)/i,t.y=(l+u)/i,t.z=.25*i)},e.Dot=function(e,t){return e.x*t.x+e.y*t.y+e.z*t.z+e.w*t.w},e.AreClose=function(t,i){return e.Dot(t,i)>=0},e.Zero=function(){return new e(0,0,0,0)},e.Inverse=function(t){return new e(-t.x,-t.y,-t.z,t.w)},e.InverseToRef=function(e,t){return t.set(-e.x,-e.y,-e.z,e.w),t},e.Identity=function(){return new e(0,0,0,1)},e.IsIdentity=function(e){return e&&0===e.x&&0===e.y&&0===e.z&&1===e.w},e.RotationAxis=function(t,i){return e.RotationAxisToRef(t,i,new e)},e.RotationAxisToRef=function(e,t,i){var r=Math.sin(t/2);return e.normalize(),i.w=Math.cos(t/2),i.x=e.x*r,i.y=e.y*r,i.z=e.z*r,i},e.FromArray=function(t,i){return i||(i=0),new e(t[i],t[i+1],t[i+2],t[i+3])},e.FromEulerAngles=function(t,i,r){var n=new e;return e.RotationYawPitchRollToRef(i,t,r,n),n},e.FromEulerAnglesToRef=function(t,i,r,n){return e.RotationYawPitchRollToRef(i,t,r,n),n},e.FromEulerVector=function(t){var i=new e;return e.RotationYawPitchRollToRef(t.y,t.x,t.z,i),i},e.FromEulerVectorToRef=function(t,i){return e.RotationYawPitchRollToRef(t.y,t.x,t.z,i),i},e.RotationYawPitchRoll=function(t,i,r){var n=new e;return e.RotationYawPitchRollToRef(t,i,r,n),n},e.RotationYawPitchRollToRef=function(e,t,i,r){var n=.5*i,o=.5*t,s=.5*e,a=Math.sin(n),h=Math.cos(n),l=Math.sin(o),c=Math.cos(o),u=Math.sin(s),f=Math.cos(s);r.x=f*l*h+u*c*a,r.y=u*c*h-f*l*a,r.z=f*c*a-u*l*h,r.w=f*c*h+u*l*a},e.RotationAlphaBetaGamma=function(t,i,r){var n=new e;return e.RotationAlphaBetaGammaToRef(t,i,r,n),n},e.RotationAlphaBetaGammaToRef=function(e,t,i,r){var n=.5*(i+e),o=.5*(i-e),s=.5*t;r.x=Math.cos(o)*Math.sin(s),r.y=Math.sin(o)*Math.sin(s),r.z=Math.sin(n)*Math.cos(s),r.w=Math.cos(n)*Math.cos(s)},e.RotationQuaternionFromAxis=function(t,i,r){var n=new e(0,0,0,0);return e.RotationQuaternionFromAxisToRef(t,i,r,n),n},e.RotationQuaternionFromAxisToRef=function(t,i,r,n){var o=f.Matrix[0];u.FromXYZAxesToRef(t.normalize(),i.normalize(),r.normalize(),o),e.FromRotationMatrixToRef(o,n)},e.Slerp=function(t,i,r){var n=e.Identity();return e.SlerpToRef(t,i,r,n),n},e.SlerpToRef=function(e,t,i,r){var n,o,s=e.x*t.x+e.y*t.y+e.z*t.z+e.w*t.w,a=!1;if(s<0&&(a=!0,s=-s),s>.999999)o=1-i,n=a?-i:i;else{var h=Math.acos(s),l=1/Math.sin(h);o=Math.sin((1-i)*h)*l,n=a?-Math.sin(i*h)*l:Math.sin(i*h)*l}r.x=o*e.x+n*t.x,r.y=o*e.y+n*t.y,r.z=o*e.z+n*t.z,r.w=o*e.w+n*t.w},e.Hermite=function(t,i,r,n,o){var s=o*o,a=o*s,h=2*a-3*s+1,l=-2*a+3*s,c=a-2*s+o,u=a-s;return new e(t.x*h+r.x*l+i.x*c+n.x*u,t.y*h+r.y*l+i.y*c+n.y*u,t.z*h+r.z*l+i.z*c+n.z*u,t.w*h+r.w*l+i.w*c+n.w*u)},e}(),u=function(){function e(){this._isIdentity=!1,this._isIdentityDirty=!0,this._isIdentity3x2=!0,this._isIdentity3x2Dirty=!0,this.updateFlag=-1,this._m=new Float32Array(16),this._updateIdentityStatus(!1)}return Object.defineProperty(e.prototype,"m",{get:function(){return this._m},enumerable:!0,configurable:!0}),e.prototype._markAsUpdated=function(){this.updateFlag=e._updateFlagSeed++,this._isIdentity=!1,this._isIdentity3x2=!1,this._isIdentityDirty=!0,this._isIdentity3x2Dirty=!0},e.prototype._updateIdentityStatus=function(t,i,r,n){void 0===i&&(i=!1),void 0===r&&(r=!1),void 0===n&&(n=!0),this.updateFlag=e._updateFlagSeed++,this._isIdentity=t,this._isIdentity3x2=t||r,this._isIdentityDirty=!this._isIdentity&&i,this._isIdentity3x2Dirty=!this._isIdentity3x2&&n},e.prototype.isIdentity=function(){if(this._isIdentityDirty){this._isIdentityDirty=!1;var e=this._m;this._isIdentity=1===e[0]&&0===e[1]&&0===e[2]&&0===e[3]&&0===e[4]&&1===e[5]&&0===e[6]&&0===e[7]&&0===e[8]&&0===e[9]&&1===e[10]&&0===e[11]&&0===e[12]&&0===e[13]&&0===e[14]&&1===e[15]}return this._isIdentity},e.prototype.isIdentityAs3x2=function(){return this._isIdentity3x2Dirty&&(this._isIdentity3x2Dirty=!1,1!==this._m[0]||1!==this._m[5]||1!==this._m[15]||0!==this._m[1]||0!==this._m[2]||0!==this._m[3]||0!==this._m[4]||0!==this._m[6]||0!==this._m[7]||0!==this._m[8]||0!==this._m[9]||0!==this._m[10]||0!==this._m[11]||0!==this._m[12]||0!==this._m[13]||0!==this._m[14]?this._isIdentity3x2=!1:this._isIdentity3x2=!0),this._isIdentity3x2},e.prototype.determinant=function(){if(!0===this._isIdentity)return 1;var e=this._m,t=e[0],i=e[1],r=e[2],n=e[3],o=e[4],s=e[5],a=e[6],h=e[7],l=e[8],c=e[9],u=e[10],f=e[11],d=e[12],p=e[13],_=e[14],g=e[15],m=u*g-_*f,b=c*g-p*f,v=c*_-p*u,y=l*g-d*f,x=l*_-u*d,T=l*p-d*c;return t*+(s*m-a*b+h*v)+i*-(o*m-a*y+h*x)+r*+(o*b-s*y+h*T)+n*-(o*v-s*x+a*T)},e.prototype.toArray=function(){return this._m},e.prototype.asArray=function(){return this._m},e.prototype.invert=function(){return this.invertToRef(this),this},e.prototype.reset=function(){return e.FromValuesToRef(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,this),this._updateIdentityStatus(!1),this},e.prototype.add=function(t){var i=new e;return this.addToRef(t,i),i},e.prototype.addToRef=function(e,t){for(var i=this._m,r=t._m,n=e.m,o=0;o<16;o++)r[o]=i[o]+n[o];return t._markAsUpdated(),this},e.prototype.addToSelf=function(e){for(var t=this._m,i=e.m,r=0;r<16;r++)t[r]+=i[r];return this._markAsUpdated(),this},e.prototype.invertToRef=function(t){if(!0===this._isIdentity)return e.IdentityToRef(t),this;var i=this._m,r=i[0],n=i[1],o=i[2],s=i[3],a=i[4],h=i[5],l=i[6],c=i[7],u=i[8],f=i[9],d=i[10],p=i[11],_=i[12],g=i[13],m=i[14],b=i[15],v=d*b-m*p,y=f*b-g*p,x=f*m-g*d,T=u*b-_*p,E=u*m-d*_,M=u*g-_*f,A=+(h*v-l*y+c*x),O=-(a*v-l*T+c*E),C=+(a*y-h*T+c*M),S=-(a*x-h*E+l*M),P=r*A+n*O+o*C+s*S;if(0===P)return t.copyFrom(this),this;var R=1/P,I=l*b-m*c,w=h*b-g*c,D=h*m-g*l,L=a*b-_*c,F=a*m-_*l,N=a*g-_*h,B=l*p-d*c,k=h*p-f*c,U=h*d-f*l,V=a*p-u*c,z=a*d-u*l,j=a*f-u*h,W=-(n*v-o*y+s*x),G=+(r*v-o*T+s*E),H=-(r*y-n*T+s*M),X=+(r*x-n*E+o*M),K=+(n*I-o*w+s*D),Y=-(r*I-o*L+s*F),q=+(r*w-n*L+s*N),Z=-(r*D-n*F+o*N),Q=-(n*B-o*k+s*U),J=+(r*B-o*V+s*z),$=-(r*k-n*V+s*j),ee=+(r*U-n*z+o*j);return e.FromValuesToRef(A*R,W*R,K*R,Q*R,O*R,G*R,Y*R,J*R,C*R,H*R,q*R,$*R,S*R,X*R,Z*R,ee*R,t),this},e.prototype.addAtIndex=function(e,t){return this._m[e]+=t,this._markAsUpdated(),this},e.prototype.multiplyAtIndex=function(e,t){return this._m[e]*=t,this._markAsUpdated(),this},e.prototype.setTranslationFromFloats=function(e,t,i){return this._m[12]=e,this._m[13]=t,this._m[14]=i,this._markAsUpdated(),this},e.prototype.addTranslationFromFloats=function(e,t,i){return this._m[12]+=e,this._m[13]+=t,this._m[14]+=i,this._markAsUpdated(),this},e.prototype.setTranslation=function(e){return this.setTranslationFromFloats(e.x,e.y,e.z)},e.prototype.getTranslation=function(){return new h(this._m[12],this._m[13],this._m[14])},e.prototype.getTranslationToRef=function(e){return e.x=this._m[12],e.y=this._m[13],e.z=this._m[14],this},e.prototype.removeRotationAndScaling=function(){var t=this.m;return e.FromValuesToRef(1,0,0,0,0,1,0,0,0,0,1,0,t[12],t[13],t[14],t[15],this),this._updateIdentityStatus(0===t[12]&&0===t[13]&&0===t[14]&&1===t[15]),this},e.prototype.multiply=function(t){var i=new e;return this.multiplyToRef(t,i),i},e.prototype.copyFrom=function(e){e.copyToArray(this._m);var t=e;return this._updateIdentityStatus(t._isIdentity,t._isIdentityDirty,t._isIdentity3x2,t._isIdentity3x2Dirty),this},e.prototype.copyToArray=function(e,t){void 0===t&&(t=0);var i=this._m;return e[t]=i[0],e[t+1]=i[1],e[t+2]=i[2],e[t+3]=i[3],e[t+4]=i[4],e[t+5]=i[5],e[t+6]=i[6],e[t+7]=i[7],e[t+8]=i[8],e[t+9]=i[9],e[t+10]=i[10],e[t+11]=i[11],e[t+12]=i[12],e[t+13]=i[13],e[t+14]=i[14],e[t+15]=i[15],this},e.prototype.multiplyToRef=function(e,t){return this._isIdentity?(t.copyFrom(e),this):e._isIdentity?(t.copyFrom(this),this):(this.multiplyToArray(e,t._m,0),t._markAsUpdated(),this)},e.prototype.multiplyToArray=function(e,t,i){var r=this._m,n=e.m,o=r[0],s=r[1],a=r[2],h=r[3],l=r[4],c=r[5],u=r[6],f=r[7],d=r[8],p=r[9],_=r[10],g=r[11],m=r[12],b=r[13],v=r[14],y=r[15],x=n[0],T=n[1],E=n[2],M=n[3],A=n[4],O=n[5],C=n[6],S=n[7],P=n[8],R=n[9],I=n[10],w=n[11],D=n[12],L=n[13],F=n[14],N=n[15];return t[i]=o*x+s*A+a*P+h*D,t[i+1]=o*T+s*O+a*R+h*L,t[i+2]=o*E+s*C+a*I+h*F,t[i+3]=o*M+s*S+a*w+h*N,t[i+4]=l*x+c*A+u*P+f*D,t[i+5]=l*T+c*O+u*R+f*L,t[i+6]=l*E+c*C+u*I+f*F,t[i+7]=l*M+c*S+u*w+f*N,t[i+8]=d*x+p*A+_*P+g*D,t[i+9]=d*T+p*O+_*R+g*L,t[i+10]=d*E+p*C+_*I+g*F,t[i+11]=d*M+p*S+_*w+g*N,t[i+12]=m*x+b*A+v*P+y*D,t[i+13]=m*T+b*O+v*R+y*L,t[i+14]=m*E+b*C+v*I+y*F,t[i+15]=m*M+b*S+v*w+y*N,this},e.prototype.equals=function(e){var t=e;if(!t)return!1;if((this._isIdentity||t._isIdentity)&&!this._isIdentityDirty&&!t._isIdentityDirty)return this._isIdentity&&t._isIdentity;var i=this.m,r=t.m;return i[0]===r[0]&&i[1]===r[1]&&i[2]===r[2]&&i[3]===r[3]&&i[4]===r[4]&&i[5]===r[5]&&i[6]===r[6]&&i[7]===r[7]&&i[8]===r[8]&&i[9]===r[9]&&i[10]===r[10]&&i[11]===r[11]&&i[12]===r[12]&&i[13]===r[13]&&i[14]===r[14]&&i[15]===r[15]},e.prototype.clone=function(){var t=new e;return t.copyFrom(this),t},e.prototype.getClassName=function(){return"Matrix"},e.prototype.getHashCode=function(){for(var e=0|this._m[0],t=1;t<16;t++)e=397*e^(0|this._m[t]);return e},e.prototype.decompose=function(t,i,r){if(this._isIdentity)return r&&r.setAll(0),t&&t.setAll(1),i&&i.copyFromFloats(0,0,0,1),!0;var n=this._m;if(r&&r.copyFromFloats(n[12],n[13],n[14]),(t=t||f.Vector3[0]).x=Math.sqrt(n[0]*n[0]+n[1]*n[1]+n[2]*n[2]),t.y=Math.sqrt(n[4]*n[4]+n[5]*n[5]+n[6]*n[6]),t.z=Math.sqrt(n[8]*n[8]+n[9]*n[9]+n[10]*n[10]),this.determinant()<=0&&(t.y*=-1),0===t.x||0===t.y||0===t.z)return i&&i.copyFromFloats(0,0,0,1),!1;if(i){var o=1/t.x,s=1/t.y,a=1/t.z;e.FromValuesToRef(n[0]*o,n[1]*o,n[2]*o,0,n[4]*s,n[5]*s,n[6]*s,0,n[8]*a,n[9]*a,n[10]*a,0,0,0,0,1,f.Matrix[0]),c.FromRotationMatrixToRef(f.Matrix[0],i)}return!0},e.prototype.getRow=function(e){if(e<0||e>3)return null;var t=4*e;return new l(this._m[t+0],this._m[t+1],this._m[t+2],this._m[t+3])},e.prototype.setRow=function(e,t){return this.setRowFromFloats(e,t.x,t.y,t.z,t.w)},e.prototype.transpose=function(){return e.Transpose(this)},e.prototype.transposeToRef=function(t){return e.TransposeToRef(this,t),this},e.prototype.setRowFromFloats=function(e,t,i,r,n){if(e<0||e>3)return this;var o=4*e;return this._m[o+0]=t,this._m[o+1]=i,this._m[o+2]=r,this._m[o+3]=n,this._markAsUpdated(),this},e.prototype.scale=function(t){var i=new e;return this.scaleToRef(t,i),i},e.prototype.scaleToRef=function(e,t){for(var i=0;i<16;i++)t._m[i]=this._m[i]*e;return t._markAsUpdated(),this},e.prototype.scaleAndAddToRef=function(e,t){for(var i=0;i<16;i++)t._m[i]+=this._m[i]*e;return t._markAsUpdated(),this},e.prototype.toNormalMatrix=function(t){var i=f.Matrix[0];this.invertToRef(i),i.transposeToRef(t);var r=t._m;e.FromValuesToRef(r[0],r[1],r[2],0,r[4],r[5],r[6],0,r[8],r[9],r[10],0,0,0,0,1,t)},e.prototype.getRotationMatrix=function(){var t=new e;return this.getRotationMatrixToRef(t),t},e.prototype.getRotationMatrixToRef=function(t){var i=f.Vector3[0];if(!this.decompose(i))return e.IdentityToRef(t),this;var r=this._m,n=1/i.x,o=1/i.y,s=1/i.z;return e.FromValuesToRef(r[0]*n,r[1]*n,r[2]*n,0,r[4]*o,r[5]*o,r[6]*o,0,r[8]*s,r[9]*s,r[10]*s,0,0,0,0,1,t),this},e.prototype.toggleModelMatrixHandInPlace=function(){var e=this._m;e[2]*=-1,e[6]*=-1,e[8]*=-1,e[9]*=-1,e[14]*=-1,this._markAsUpdated()},e.prototype.toggleProjectionMatrixHandInPlace=function(){var e=this._m;e[8]*=-1,e[9]*=-1,e[10]*=-1,e[11]*=-1,this._markAsUpdated()},e.FromArray=function(t,i){void 0===i&&(i=0);var r=new e;return e.FromArrayToRef(t,i,r),r},e.FromArrayToRef=function(e,t,i){for(var r=0;r<16;r++)i._m[r]=e[r+t];i._markAsUpdated()},e.FromFloat32ArrayToRefScaled=function(e,t,i,r){for(var n=0;n<16;n++)r._m[n]=e[n+t]*i;r._markAsUpdated()},Object.defineProperty(e,"IdentityReadOnly",{get:function(){return e._identityReadOnly},enumerable:!0,configurable:!0}),e.FromValuesToRef=function(e,t,i,r,n,o,s,a,h,l,c,u,f,d,p,_,g){var m=g._m;m[0]=e,m[1]=t,m[2]=i,m[3]=r,m[4]=n,m[5]=o,m[6]=s,m[7]=a,m[8]=h,m[9]=l,m[10]=c,m[11]=u,m[12]=f,m[13]=d,m[14]=p,m[15]=_,g._markAsUpdated()},e.FromValues=function(t,i,r,n,o,s,a,h,l,c,u,f,d,p,_,g){var m=new e,b=m._m;return b[0]=t,b[1]=i,b[2]=r,b[3]=n,b[4]=o,b[5]=s,b[6]=a,b[7]=h,b[8]=l,b[9]=c,b[10]=u,b[11]=f,b[12]=d,b[13]=p,b[14]=_,b[15]=g,m._markAsUpdated(),m},e.Compose=function(t,i,r){var n=new e;return e.ComposeToRef(t,i,r,n),n},e.ComposeToRef=function(e,t,i,r){var n=r._m,o=t.x,s=t.y,a=t.z,h=t.w,l=o+o,c=s+s,u=a+a,f=o*l,d=o*c,p=o*u,_=s*c,g=s*u,m=a*u,b=h*l,v=h*c,y=h*u,x=e.x,T=e.y,E=e.z;n[0]=(1-(_+m))*x,n[1]=(d+y)*x,n[2]=(p-v)*x,n[3]=0,n[4]=(d-y)*T,n[5]=(1-(f+m))*T,n[6]=(g+b)*T,n[7]=0,n[8]=(p+v)*E,n[9]=(g-b)*E,n[10]=(1-(f+_))*E,n[11]=0,n[12]=i.x,n[13]=i.y,n[14]=i.z,n[15]=1,r._markAsUpdated()},e.Identity=function(){var t=e.FromValues(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);return t._updateIdentityStatus(!0),t},e.IdentityToRef=function(t){e.FromValuesToRef(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,t),t._updateIdentityStatus(!0)},e.Zero=function(){var t=e.FromValues(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0);return t._updateIdentityStatus(!1),t},e.RotationX=function(t){var i=new e;return e.RotationXToRef(t,i),i},e.Invert=function(t){var i=new e;return t.invertToRef(i),i},e.RotationXToRef=function(t,i){var r=Math.sin(t),n=Math.cos(t);e.FromValuesToRef(1,0,0,0,0,n,r,0,0,-r,n,0,0,0,0,1,i),i._updateIdentityStatus(1===n&&0===r)},e.RotationY=function(t){var i=new e;return e.RotationYToRef(t,i),i},e.RotationYToRef=function(t,i){var r=Math.sin(t),n=Math.cos(t);e.FromValuesToRef(n,0,-r,0,0,1,0,0,r,0,n,0,0,0,0,1,i),i._updateIdentityStatus(1===n&&0===r)},e.RotationZ=function(t){var i=new e;return e.RotationZToRef(t,i),i},e.RotationZToRef=function(t,i){var r=Math.sin(t),n=Math.cos(t);e.FromValuesToRef(n,r,0,0,-r,n,0,0,0,0,1,0,0,0,0,1,i),i._updateIdentityStatus(1===n&&0===r)},e.RotationAxis=function(t,i){var r=new e;return e.RotationAxisToRef(t,i,r),r},e.RotationAxisToRef=function(e,t,i){var r=Math.sin(-t),n=Math.cos(-t),o=1-n;e.normalize();var s=i._m;s[0]=e.x*e.x*o+n,s[1]=e.x*e.y*o-e.z*r,s[2]=e.x*e.z*o+e.y*r,s[3]=0,s[4]=e.y*e.x*o+e.z*r,s[5]=e.y*e.y*o+n,s[6]=e.y*e.z*o-e.x*r,s[7]=0,s[8]=e.z*e.x*o-e.y*r,s[9]=e.z*e.y*o+e.x*r,s[10]=e.z*e.z*o+n,s[11]=0,s[12]=0,s[13]=0,s[14]=0,s[15]=1,i._markAsUpdated()},e.RotationAlignToRef=function(e,t,i){var r=h.Cross(t,e),n=h.Dot(t,e),o=1/(1+n),s=i._m;s[0]=r.x*r.x*o+n,s[1]=r.y*r.x*o-r.z,s[2]=r.z*r.x*o+r.y,s[3]=0,s[4]=r.x*r.y*o+r.z,s[5]=r.y*r.y*o+n,s[6]=r.z*r.y*o-r.x,s[7]=0,s[8]=r.x*r.z*o-r.y,s[9]=r.y*r.z*o+r.x,s[10]=r.z*r.z*o+n,s[11]=0,s[12]=0,s[13]=0,s[14]=0,s[15]=1,i._markAsUpdated()},e.RotationYawPitchRoll=function(t,i,r){var n=new e;return e.RotationYawPitchRollToRef(t,i,r,n),n},e.RotationYawPitchRollToRef=function(e,t,i,r){c.RotationYawPitchRollToRef(e,t,i,f.Quaternion[0]),f.Quaternion[0].toRotationMatrix(r)},e.Scaling=function(t,i,r){var n=new e;return e.ScalingToRef(t,i,r,n),n},e.ScalingToRef=function(t,i,r,n){e.FromValuesToRef(t,0,0,0,0,i,0,0,0,0,r,0,0,0,0,1,n),n._updateIdentityStatus(1===t&&1===i&&1===r)},e.Translation=function(t,i,r){var n=new e;return e.TranslationToRef(t,i,r,n),n},e.TranslationToRef=function(t,i,r,n){e.FromValuesToRef(1,0,0,0,0,1,0,0,0,0,1,0,t,i,r,1,n),n._updateIdentityStatus(0===t&&0===i&&0===r)},e.Lerp=function(t,i,r){var n=new e;return e.LerpToRef(t,i,r,n),n},e.LerpToRef=function(e,t,i,r){for(var n=r._m,o=e.m,s=t.m,a=0;a<16;a++)n[a]=o[a]*(1-i)+s[a]*i;r._markAsUpdated()},e.DecomposeLerp=function(t,i,r){var n=new e;return e.DecomposeLerpToRef(t,i,r,n),n},e.DecomposeLerpToRef=function(t,i,r,n){var o=f.Vector3[0],s=f.Quaternion[0],a=f.Vector3[1];t.decompose(o,s,a);var l=f.Vector3[2],u=f.Quaternion[1],d=f.Vector3[3];i.decompose(l,u,d);var p=f.Vector3[4];h.LerpToRef(o,l,r,p);var _=f.Quaternion[2];c.SlerpToRef(s,u,r,_);var g=f.Vector3[5];h.LerpToRef(a,d,r,g),e.ComposeToRef(p,_,g,n)},e.LookAtLH=function(t,i,r){var n=new e;return e.LookAtLHToRef(t,i,r,n),n},e.LookAtLHToRef=function(t,i,r,n){var o=f.Vector3[0],s=f.Vector3[1],a=f.Vector3[2];i.subtractToRef(t,a),a.normalize(),h.CrossToRef(r,a,o);var l=o.lengthSquared();0===l?o.x=1:o.normalizeFromLength(Math.sqrt(l)),h.CrossToRef(a,o,s),s.normalize();var c=-h.Dot(o,t),u=-h.Dot(s,t),d=-h.Dot(a,t);e.FromValuesToRef(o.x,s.x,a.x,0,o.y,s.y,a.y,0,o.z,s.z,a.z,0,c,u,d,1,n)},e.LookAtRH=function(t,i,r){var n=new e;return e.LookAtRHToRef(t,i,r,n),n},e.LookAtRHToRef=function(t,i,r,n){var o=f.Vector3[0],s=f.Vector3[1],a=f.Vector3[2];t.subtractToRef(i,a),a.normalize(),h.CrossToRef(r,a,o);var l=o.lengthSquared();0===l?o.x=1:o.normalizeFromLength(Math.sqrt(l)),h.CrossToRef(a,o,s),s.normalize();var c=-h.Dot(o,t),u=-h.Dot(s,t),d=-h.Dot(a,t);e.FromValuesToRef(o.x,s.x,a.x,0,o.y,s.y,a.y,0,o.z,s.z,a.z,0,c,u,d,1,n)},e.OrthoLH=function(t,i,r,n){var o=new e;return e.OrthoLHToRef(t,i,r,n,o),o},e.OrthoLHToRef=function(t,i,r,n,o){var s=2/t,a=2/i,h=2/(n-r),l=-(n+r)/(n-r);e.FromValuesToRef(s,0,0,0,0,a,0,0,0,0,h,0,0,0,l,1,o),o._updateIdentityStatus(1===s&&1===a&&1===h&&0===l)},e.OrthoOffCenterLH=function(t,i,r,n,o,s){var a=new e;return e.OrthoOffCenterLHToRef(t,i,r,n,o,s,a),a},e.OrthoOffCenterLHToRef=function(t,i,r,n,o,s,a){var h=2/(i-t),l=2/(n-r),c=2/(s-o),u=-(s+o)/(s-o),f=(t+i)/(t-i),d=(n+r)/(r-n);e.FromValuesToRef(h,0,0,0,0,l,0,0,0,0,c,0,f,d,u,1,a),a._markAsUpdated()},e.OrthoOffCenterRH=function(t,i,r,n,o,s){var a=new e;return e.OrthoOffCenterRHToRef(t,i,r,n,o,s,a),a},e.OrthoOffCenterRHToRef=function(t,i,r,n,o,s,a){e.OrthoOffCenterLHToRef(t,i,r,n,o,s,a),a._m[10]*=-1},e.PerspectiveLH=function(t,i,r,n){var o=new e,s=2*r/t,a=2*r/i,h=(n+r)/(n-r),l=-2*n*r/(n-r);return e.FromValuesToRef(s,0,0,0,0,a,0,0,0,0,h,1,0,0,l,0,o),o._updateIdentityStatus(!1),o},e.PerspectiveFovLH=function(t,i,r,n){var o=new e;return e.PerspectiveFovLHToRef(t,i,r,n,o),o},e.PerspectiveFovLHToRef=function(t,i,r,n,o,s){void 0===s&&(s=!0);var a=r,h=n,l=1/Math.tan(.5*t),c=s?l/i:l,u=s?l:l*i,f=(h+a)/(h-a),d=-2*h*a/(h-a);e.FromValuesToRef(c,0,0,0,0,u,0,0,0,0,f,1,0,0,d,0,o),o._updateIdentityStatus(!1)},e.PerspectiveFovReverseLHToRef=function(t,i,r,n,o,s){void 0===s&&(s=!0);var a=1/Math.tan(.5*t),h=s?a/i:a,l=s?a:a*i;e.FromValuesToRef(h,0,0,0,0,l,0,0,0,0,-r,1,0,0,1,0,o),o._updateIdentityStatus(!1)},e.PerspectiveFovRH=function(t,i,r,n){var o=new e;return e.PerspectiveFovRHToRef(t,i,r,n,o),o},e.PerspectiveFovRHToRef=function(t,i,r,n,o,s){void 0===s&&(s=!0);var a=r,h=n,l=1/Math.tan(.5*t),c=s?l/i:l,u=s?l:l*i,f=-(h+a)/(h-a),d=-2*h*a/(h-a);e.FromValuesToRef(c,0,0,0,0,u,0,0,0,0,f,-1,0,0,d,0,o),o._updateIdentityStatus(!1)},e.PerspectiveFovReverseRHToRef=function(t,i,r,n,o,s){void 0===s&&(s=!0);var a=1/Math.tan(.5*t),h=s?a/i:a,l=s?a:a*i;e.FromValuesToRef(h,0,0,0,0,l,0,0,0,0,-r,-1,0,0,-1,0,o),o._updateIdentityStatus(!1)},e.PerspectiveFovWebVRToRef=function(e,t,i,r,n){void 0===n&&(n=!1);var o=n?-1:1,s=Math.tan(e.upDegrees*Math.PI/180),a=Math.tan(e.downDegrees*Math.PI/180),h=Math.tan(e.leftDegrees*Math.PI/180),l=Math.tan(e.rightDegrees*Math.PI/180),c=2/(h+l),u=2/(s+a),f=r._m;f[0]=c,f[1]=f[2]=f[3]=f[4]=0,f[5]=u,f[6]=f[7]=0,f[8]=(h-l)*c*.5,f[9]=-(s-a)*u*.5,f[10]=-i/(t-i),f[11]=1*o,f[12]=f[13]=f[15]=0,f[14]=-2*i*t/(i-t),r._markAsUpdated()},e.GetFinalMatrix=function(t,i,r,n,o,s){var a=t.width,h=t.height,l=t.x,c=t.y,u=e.FromValues(a/2,0,0,0,0,-h/2,0,0,0,0,s-o,0,l+a/2,h/2+c,o,1),d=f.Matrix[0];return i.multiplyToRef(r,d),d.multiplyToRef(n,d),d.multiply(u)},e.GetAsMatrix2x2=function(e){var t=e.m;return new Float32Array([t[0],t[1],t[4],t[5]])},e.GetAsMatrix3x3=function(e){var t=e.m;return new Float32Array([t[0],t[1],t[2],t[4],t[5],t[6],t[8],t[9],t[10]])},e.Transpose=function(t){var i=new e;return e.TransposeToRef(t,i),i},e.TransposeToRef=function(e,t){var i=t._m,r=e.m;i[0]=r[0],i[1]=r[4],i[2]=r[8],i[3]=r[12],i[4]=r[1],i[5]=r[5],i[6]=r[9],i[7]=r[13],i[8]=r[2],i[9]=r[6],i[10]=r[10],i[11]=r[14],i[12]=r[3],i[13]=r[7],i[14]=r[11],i[15]=r[15],t._updateIdentityStatus(e._isIdentity,e._isIdentityDirty)},e.Reflection=function(t){var i=new e;return e.ReflectionToRef(t,i),i},e.ReflectionToRef=function(t,i){t.normalize();var r=t.normal.x,n=t.normal.y,o=t.normal.z,s=-2*r,a=-2*n,h=-2*o;e.FromValuesToRef(s*r+1,a*r,h*r,0,s*n,a*n+1,h*n,0,s*o,a*o,h*o+1,0,s*t.d,a*t.d,h*t.d,1,i)},e.FromXYZAxesToRef=function(t,i,r,n){e.FromValuesToRef(t.x,t.y,t.z,0,i.x,i.y,i.z,0,r.x,r.y,r.z,0,0,0,0,1,n)},e.FromQuaternionToRef=function(e,t){var i=e.x*e.x,r=e.y*e.y,n=e.z*e.z,o=e.x*e.y,s=e.z*e.w,a=e.z*e.x,h=e.y*e.w,l=e.y*e.z,c=e.x*e.w;t._m[0]=1-2*(r+n),t._m[1]=2*(o+s),t._m[2]=2*(a-h),t._m[3]=0,t._m[4]=2*(o-s),t._m[5]=1-2*(n+i),t._m[6]=2*(l+c),t._m[7]=0,t._m[8]=2*(a+h),t._m[9]=2*(l-c),t._m[10]=1-2*(r+i),t._m[11]=0,t._m[12]=0,t._m[13]=0,t._m[14]=0,t._m[15]=1,t._markAsUpdated()},e._updateFlagSeed=0,e._identityReadOnly=e.Identity(),e}(),f=function(){function e(){}return e.Vector3=o.a.BuildArray(6,h.Zero),e.Matrix=o.a.BuildArray(2,u.Identity),e.Quaternion=o.a.BuildArray(3,c.Zero),e}(),d=function(){function e(){}return e.Vector2=o.a.BuildArray(3,a.Zero),e.Vector3=o.a.BuildArray(13,h.Zero),e.Vector4=o.a.BuildArray(3,l.Zero),e.Quaternion=o.a.BuildArray(2,c.Zero),e.Matrix=o.a.BuildArray(8,u.Identity),e}();s.a.RegisteredTypes["BABYLON.Vector2"]=a,s.a.RegisteredTypes["BABYLON.Vector3"]=h,s.a.RegisteredTypes["BABYLON.Vector4"]=l,s.a.RegisteredTypes["BABYLON.Matrix"]=u},function(e,t,i){"use strict";i.d(t,"c",(function(){return n})),i.d(t,"a",(function(){return o})),i.d(t,"b",(function(){return s}));var r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var i in t)t.hasOwnProperty(i)&&(e[i]=t[i])})(e,t)};function n(e,t){function i(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(i.prototype=t.prototype,new i)}var o=function(){return(o=Object.assign||function(e){for(var t,i=1,r=arguments.length;i=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,i,s):n(t,i))||s);return o>3&&s&&Object.defineProperty(t,i,s),s}},function(e,t,i){"use strict";i.d(t,"a",(function(){return r})),i.d(t,"b",(function(){return n}));var r=function(){function e(e,t,i,r,n,o,s,a){void 0===r&&(r=0),void 0===n&&(n=!1),void 0===o&&(o=!1),void 0===s&&(s=!1),e.getScene?this._engine=e.getScene().getEngine():this._engine=e,this._updatable=i,this._instanced=o,this._divisor=a||1,this._data=t,this.byteStride=s?r:r*Float32Array.BYTES_PER_ELEMENT,n||this.create()}return e.prototype.createVertexBuffer=function(e,t,i,r,o,s,a){void 0===s&&(s=!1);var h=s?t:t*Float32Array.BYTES_PER_ELEMENT,l=r?s?r:r*Float32Array.BYTES_PER_ELEMENT:this.byteStride;return new n(this._engine,this,e,this._updatable,!0,l,void 0===o?this._instanced:o,h,i,void 0,void 0,!0,this._divisor||a)},e.prototype.isUpdatable=function(){return this._updatable},e.prototype.getData=function(){return this._data},e.prototype.getBuffer=function(){return this._buffer},e.prototype.getStrideSize=function(){return this.byteStride/Float32Array.BYTES_PER_ELEMENT},e.prototype.create=function(e){void 0===e&&(e=null),!e&&this._buffer||(e=e||this._data)&&(this._buffer?this._updatable&&(this._engine.updateDynamicVertexBuffer(this._buffer,e),this._data=e):this._updatable?(this._buffer=this._engine.createDynamicVertexBuffer(e),this._data=e):this._buffer=this._engine.createVertexBuffer(e))},e.prototype._rebuild=function(){this._buffer=null,this.create(this._data)},e.prototype.update=function(e){this.create(e)},e.prototype.updateDirectly=function(e,t,i,r){void 0===r&&(r=!1),this._buffer&&this._updatable&&(this._engine.updateDynamicVertexBuffer(this._buffer,e,r?t:t*Float32Array.BYTES_PER_ELEMENT,i?i*this.byteStride:void 0),this._data=null)},e.prototype.dispose=function(){this._buffer&&this._engine._releaseBuffer(this._buffer)&&(this._buffer=null)},e}(),n=function(){function e(t,i,n,o,s,a,h,l,c,u,f,d,p){if(void 0===f&&(f=!1),void 0===d&&(d=!1),void 0===p&&(p=1),i instanceof r?(this._buffer=i,this._ownsBuffer=!1):(this._buffer=new r(t,i,o,a,s,h,d),this._ownsBuffer=!0),this._kind=n,null==u){var _=this.getData();this.type=e.FLOAT,_ instanceof Int8Array?this.type=e.BYTE:_ instanceof Uint8Array?this.type=e.UNSIGNED_BYTE:_ instanceof Int16Array?this.type=e.SHORT:_ instanceof Uint16Array?this.type=e.UNSIGNED_SHORT:_ instanceof Int32Array?this.type=e.INT:_ instanceof Uint32Array&&(this.type=e.UNSIGNED_INT)}else this.type=u;var g=e.GetTypeByteLength(this.type);d?(this._size=c||(a?a/g:e.DeduceStride(n)),this.byteStride=a||this._buffer.byteStride||this._size*g,this.byteOffset=l||0):(this._size=c||a||e.DeduceStride(n),this.byteStride=a?a*g:this._buffer.byteStride||this._size*g,this.byteOffset=(l||0)*g),this.normalized=f,this._instanced=void 0!==h&&h,this._instanceDivisor=h?p:0}return Object.defineProperty(e.prototype,"instanceDivisor",{get:function(){return this._instanceDivisor},set:function(e){this._instanceDivisor=e,this._instanced=0!=e},enumerable:!0,configurable:!0}),e.prototype._rebuild=function(){this._buffer&&this._buffer._rebuild()},e.prototype.getKind=function(){return this._kind},e.prototype.isUpdatable=function(){return this._buffer.isUpdatable()},e.prototype.getData=function(){return this._buffer.getData()},e.prototype.getBuffer=function(){return this._buffer.getBuffer()},e.prototype.getStrideSize=function(){return this.byteStride/e.GetTypeByteLength(this.type)},e.prototype.getOffset=function(){return this.byteOffset/e.GetTypeByteLength(this.type)},e.prototype.getSize=function(){return this._size},e.prototype.getIsInstanced=function(){return this._instanced},e.prototype.getInstanceDivisor=function(){return this._instanceDivisor},e.prototype.create=function(e){this._buffer.create(e)},e.prototype.update=function(e){this._buffer.update(e)},e.prototype.updateDirectly=function(e,t,i){void 0===i&&(i=!1),this._buffer.updateDirectly(e,t,void 0,i)},e.prototype.dispose=function(){this._ownsBuffer&&this._buffer.dispose()},e.prototype.forEach=function(t,i){e.ForEach(this._buffer.getData(),this.byteOffset,this.byteStride,this._size,this.type,t,this.normalized,i)},e.DeduceStride=function(t){switch(t){case e.UVKind:case e.UV2Kind:case e.UV3Kind:case e.UV4Kind:case e.UV5Kind:case e.UV6Kind:return 2;case e.NormalKind:case e.PositionKind:return 3;case e.ColorKind:case e.MatricesIndicesKind:case e.MatricesIndicesExtraKind:case e.MatricesWeightsKind:case e.MatricesWeightsExtraKind:case e.TangentKind:return 4;default:throw new Error("Invalid kind '"+t+"'")}},e.GetTypeByteLength=function(t){switch(t){case e.BYTE:case e.UNSIGNED_BYTE:return 1;case e.SHORT:case e.UNSIGNED_SHORT:return 2;case e.INT:case e.UNSIGNED_INT:case e.FLOAT:return 4;default:throw new Error("Invalid type '"+t+"'")}},e.ForEach=function(t,i,r,n,o,s,a,h){if(t instanceof Array)for(var l=i/4,c=r/4,u=0;u0},e.prototype.clear=function(){this._observers=new Array,this._onObserverAdded=null},e.prototype.clone=function(){var t=new e;return t._observers=this._observers.slice(0),t},e.prototype.hasSpecificMask=function(e){void 0===e&&(e=-1);for(var t=0,i=this._observers;t1?this.notRenderable=!0:this.notRenderable=!1}else a.b.Error("Cannot move a control to a vector3 if the control is not at root level")},e.prototype.getDescendantsToRef=function(e,t,i){void 0===t&&(t=!1)},e.prototype.getDescendants=function(e,t){var i=new Array;return this.getDescendantsToRef(i,e,t),i},e.prototype.linkWithMesh=function(t){if(!this._host||this.parent&&this.parent!==this._host._rootContainer)t&&a.b.Error("Cannot link a control to a mesh if the control is not at root level");else{var i=this._host._linkedControls.indexOf(this);if(-1!==i)return this._linkedMesh=t,void(t||this._host._linkedControls.splice(i,1));t&&(this.horizontalAlignment=e.HORIZONTAL_ALIGNMENT_LEFT,this.verticalAlignment=e.VERTICAL_ALIGNMENT_TOP,this._linkedMesh=t,this._host._linkedControls.push(this))}},e.prototype._moveToProjectedPosition=function(e){var t=this._left.getValue(this._host),i=this._top.getValue(this._host),r=e.x+this._linkOffsetX.getValue(this._host)-this._currentMeasure.width/2,n=e.y+this._linkOffsetY.getValue(this._host)-this._currentMeasure.height/2;this._left.ignoreAdaptiveScaling&&this._top.ignoreAdaptiveScaling&&(Math.abs(r-t)<.5&&(r=t),Math.abs(n-i)<.5&&(n=i)),this.left=r+"px",this.top=n+"px",this._left.ignoreAdaptiveScaling=!0,this._top.ignoreAdaptiveScaling=!0,this._markAsDirty()},e.prototype._offsetLeft=function(e){this._isDirty=!0,this._currentMeasure.left+=e},e.prototype._offsetTop=function(e){this._isDirty=!0,this._currentMeasure.top+=e},e.prototype._markMatrixAsDirty=function(){this._isMatrixDirty=!0,this._flagDescendantsAsMatrixDirty()},e.prototype._flagDescendantsAsMatrixDirty=function(){},e.prototype._intersectsRect=function(e){return this._currentMeasure.transformToRef(this._transformMatrix,this._tmpMeasureA),!(this._tmpMeasureA.left>=e.left+e.width)&&(!(this._tmpMeasureA.top>=e.top+e.height)&&(!(this._tmpMeasureA.left+this._tmpMeasureA.width<=e.left)&&!(this._tmpMeasureA.top+this._tmpMeasureA.height<=e.top)))},e.prototype.invalidateRect=function(){if(this._transform(),this.host&&this.host.useInvalidateRectOptimization)if(this._currentMeasure.transformToRef(this._transformMatrix,this._tmpMeasureA),l.a.CombineToRef(this._tmpMeasureA,this._prevCurrentMeasureTransformedIntoGlobalSpace,this._tmpMeasureA),this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY){var e=this.shadowOffsetX,t=this.shadowOffsetY,i=this.shadowBlur,r=Math.min(Math.min(e,0)-2*i,0),n=Math.max(Math.max(e,0)+2*i,0),o=Math.min(Math.min(t,0)-2*i,0),s=Math.max(Math.max(t,0)+2*i,0);this.host.invalidateRect(Math.floor(this._tmpMeasureA.left+r),Math.floor(this._tmpMeasureA.top+o),Math.ceil(this._tmpMeasureA.left+this._tmpMeasureA.width+n),Math.ceil(this._tmpMeasureA.top+this._tmpMeasureA.height+s))}else this.host.invalidateRect(Math.floor(this._tmpMeasureA.left),Math.floor(this._tmpMeasureA.top),Math.ceil(this._tmpMeasureA.left+this._tmpMeasureA.width),Math.ceil(this._tmpMeasureA.top+this._tmpMeasureA.height))},e.prototype._markAsDirty=function(e){void 0===e&&(e=!1),(this._isVisible||e)&&(this._isDirty=!0,this._host&&this._host.markAsDirty())},e.prototype._markAllAsDirty=function(){this._markAsDirty(),this._font&&this._prepareFont()},e.prototype._link=function(e){this._host=e,this._host&&(this.uniqueId=this._host.getScene().getUniqueId())},e.prototype._transform=function(e){if(this._isMatrixDirty||1!==this._scaleX||1!==this._scaleY||0!==this._rotation){var t=this._currentMeasure.width*this._transformCenterX+this._currentMeasure.left,i=this._currentMeasure.height*this._transformCenterY+this._currentMeasure.top;e&&(e.translate(t,i),e.rotate(this._rotation),e.scale(this._scaleX,this._scaleY),e.translate(-t,-i)),(this._isMatrixDirty||this._cachedOffsetX!==t||this._cachedOffsetY!==i)&&(this._cachedOffsetX=t,this._cachedOffsetY=i,this._isMatrixDirty=!1,this._flagDescendantsAsMatrixDirty(),d.ComposeToRef(-t,-i,this._rotation,this._scaleX,this._scaleY,this.parent?this.parent._transformMatrix:null,this._transformMatrix),this._transformMatrix.invertToRef(this._invertTransformMatrix))}},e.prototype._renderHighlight=function(e){this.isHighlighted&&(e.save(),e.strokeStyle="#4affff",e.lineWidth=2,this._renderHighlightSpecific(e),e.restore())},e.prototype._renderHighlightSpecific=function(e){e.strokeRect(this._currentMeasure.left,this._currentMeasure.top,this._currentMeasure.width,this._currentMeasure.height)},e.prototype._applyStates=function(t){this._isFontSizeInPercentage&&(this._fontSet=!0),this._fontSet&&(this._prepareFont(),this._fontSet=!1),this._font&&(t.font=this._font),this._color&&(t.fillStyle=this._color),e.AllowAlphaInheritance?t.globalAlpha*=this._alpha:this._alphaSet&&(t.globalAlpha=this.parent?this.parent.alpha*this._alpha:this._alpha)},e.prototype._layout=function(e,t){if(!this.isDirty&&(!this.isVisible||this.notRenderable))return!1;if(this._isDirty||!this._cachedParentMeasure.isEqualsTo(e)){this.host._numLayoutCalls++,this._currentMeasure.transformToRef(this._transformMatrix,this._prevCurrentMeasureTransformedIntoGlobalSpace),t.save(),this._applyStates(t);var i=0;do{this._rebuildLayout=!1,this._processMeasures(e,t),i++}while(this._rebuildLayout&&i<3);i>=3&&s.a.Error("Layout cycle detected in GUI (Control name="+this.name+", uniqueId="+this.uniqueId+")"),t.restore(),this.invalidateRect(),this._evaluateClippingState(e)}return this._wasDirty=this._isDirty,this._isDirty=!1,!0},e.prototype._processMeasures=function(e,t){this._currentMeasure.copyFrom(e),this._preMeasure(e,t),this._measure(),this._computeAlignment(e,t),this._currentMeasure.left=0|this._currentMeasure.left,this._currentMeasure.top=0|this._currentMeasure.top,this._currentMeasure.width=0|this._currentMeasure.width,this._currentMeasure.height=0|this._currentMeasure.height,this._additionalProcessing(e,t),this._cachedParentMeasure.copyFrom(e),this.onDirtyObservable.hasObservers()&&this.onDirtyObservable.notifyObservers(this)},e.prototype._evaluateClippingState=function(e){if(this.parent&&this.parent.clipChildren){if(this._currentMeasure.left>e.left+e.width)return void(this._isClipped=!0);if(this._currentMeasure.left+this._currentMeasure.widthe.top+e.height)return void(this._isClipped=!0);if(this._currentMeasure.top+this._currentMeasure.heightthis._currentMeasure.left+this._currentMeasure.width)&&(!(tthis._currentMeasure.top+this._currentMeasure.height)&&(this.isPointerBlocker&&(this._host._shouldBlockPointer=!0),!0))))},e.prototype._processPicking=function(e,t,i,r,n,o,s){return!!this._isEnabled&&(!(!this.isHitTestVisible||!this.isVisible||this._doNotRender)&&(!!this.contains(e,t)&&(this._processObservables(i,e,t,r,n,o,s),!0)))},e.prototype._onPointerMove=function(e,t,i){this.onPointerMoveObservable.notifyObservers(t,-1,e,this)&&null!=this.parent&&this.parent._onPointerMove(e,t,i)},e.prototype._onPointerEnter=function(e){return!!this._isEnabled&&(!(this._enterCount>0)&&(-1===this._enterCount&&(this._enterCount=0),this._enterCount++,this.onPointerEnterObservable.notifyObservers(this,-1,e,this)&&null!=this.parent&&this.parent._onPointerEnter(e),!0))},e.prototype._onPointerOut=function(e,t){if(void 0===t&&(t=!1),t||this._isEnabled&&e!==this){this._enterCount=0;var i=!0;e.isAscendant(this)||(i=this.onPointerOutObservable.notifyObservers(this,-1,e,this)),i&&null!=this.parent&&this.parent._onPointerOut(e,t)}},e.prototype._onPointerDown=function(e,t,i,r){return this._onPointerEnter(this),0===this._downCount&&(this._downCount++,this._downPointerIds[i]=!0,this.onPointerDownObservable.notifyObservers(new f(t,r),-1,e,this)&&null!=this.parent&&this.parent._onPointerDown(e,t,i,r),!0)},e.prototype._onPointerUp=function(e,t,i,r,n){if(this._isEnabled){this._downCount=0,delete this._downPointerIds[i];var o=n;n&&(this._enterCount>0||-1===this._enterCount)&&(o=this.onPointerClickObservable.notifyObservers(new f(t,r),-1,e,this)),this.onPointerUpObservable.notifyObservers(new f(t,r),-1,e,this)&&null!=this.parent&&this.parent._onPointerUp(e,t,i,r,o)}},e.prototype._forcePointerUp=function(e){if(void 0===e&&(e=null),null!==e)this._onPointerUp(this,n.d.Zero(),e,0,!0);else for(var t in this._downPointerIds)this._onPointerUp(this,n.d.Zero(),+t,0,!0)},e.prototype._onWheelScroll=function(e,t){this._isEnabled&&(this.onWheelObservable.notifyObservers(new n.d(e,t))&&null!=this.parent&&this.parent._onWheelScroll(e,t))},e.prototype._processObservables=function(e,t,i,r,n,s,a){if(!this._isEnabled)return!1;if(this._dummyVector2.copyFromFloats(t,i),e===o.a.POINTERMOVE){this._onPointerMove(this,this._dummyVector2,r);var h=this._host._lastControlOver[r];return h&&h!==this&&h._onPointerOut(this),h!==this&&this._onPointerEnter(this),this._host._lastControlOver[r]=this,!0}return e===o.a.POINTERDOWN?(this._onPointerDown(this,this._dummyVector2,r,n),this._host._registerLastControlDown(this,r),this._host._lastPickedControl=this,!0):e===o.a.POINTERUP?(this._host._lastControlDown[r]&&this._host._lastControlDown[r]._onPointerUp(this,this._dummyVector2,r,n,!0),delete this._host._lastControlDown[r],!0):!(e!==o.a.POINTERWHEEL||!this._host._lastControlOver[r])&&(this._host._lastControlOver[r]._onWheelScroll(s,a),!0)},e.prototype._prepareFont=function(){(this._font||this._fontSet)&&(this._style?this._font=this._style.fontStyle+" "+this._style.fontWeight+" "+this.fontSizeInPixels+"px "+this._style.fontFamily:this._font=this._fontStyle+" "+this._fontWeight+" "+this.fontSizeInPixels+"px "+this._fontFamily,this._fontOffset=e._GetFontOffset(this._font))},e.prototype.dispose=function(){(this.onDirtyObservable.clear(),this.onBeforeDrawObservable.clear(),this.onAfterDrawObservable.clear(),this.onPointerDownObservable.clear(),this.onPointerEnterObservable.clear(),this.onPointerMoveObservable.clear(),this.onPointerOutObservable.clear(),this.onPointerUpObservable.clear(),this.onPointerClickObservable.clear(),this.onWheelObservable.clear(),this._styleObserver&&this._style&&(this._style.onChangedObservable.remove(this._styleObserver),this._styleObserver=null),this.parent&&(this.parent.removeControl(this),this.parent=null),this._host)&&(this._host._linkedControls.indexOf(this)>-1&&this.linkWithMesh(null))},Object.defineProperty(e,"HORIZONTAL_ALIGNMENT_LEFT",{get:function(){return e._HORIZONTAL_ALIGNMENT_LEFT},enumerable:!0,configurable:!0}),Object.defineProperty(e,"HORIZONTAL_ALIGNMENT_RIGHT",{get:function(){return e._HORIZONTAL_ALIGNMENT_RIGHT},enumerable:!0,configurable:!0}),Object.defineProperty(e,"HORIZONTAL_ALIGNMENT_CENTER",{get:function(){return e._HORIZONTAL_ALIGNMENT_CENTER},enumerable:!0,configurable:!0}),Object.defineProperty(e,"VERTICAL_ALIGNMENT_TOP",{get:function(){return e._VERTICAL_ALIGNMENT_TOP},enumerable:!0,configurable:!0}),Object.defineProperty(e,"VERTICAL_ALIGNMENT_BOTTOM",{get:function(){return e._VERTICAL_ALIGNMENT_BOTTOM},enumerable:!0,configurable:!0}),Object.defineProperty(e,"VERTICAL_ALIGNMENT_CENTER",{get:function(){return e._VERTICAL_ALIGNMENT_CENTER},enumerable:!0,configurable:!0}),e._GetFontOffset=function(t){if(e._FontHeightSizes[t])return e._FontHeightSizes[t];var i=document.createElement("span");i.innerHTML="Hg",i.style.font=t;var r=document.createElement("div");r.style.display="inline-block",r.style.width="1px",r.style.height="0px",r.style.verticalAlign="bottom";var n=document.createElement("div");n.appendChild(i),n.appendChild(r),document.body.appendChild(n);var o=0,s=0;try{s=r.getBoundingClientRect().top-i.getBoundingClientRect().top,r.style.verticalAlign="baseline",o=r.getBoundingClientRect().top-i.getBoundingClientRect().top}finally{document.body.removeChild(n)}var a={ascent:o,height:s,descent:s-o};return e._FontHeightSizes[t]=a,a},e.drawEllipse=function(e,t,i,r,n){n.translate(e,t),n.scale(i,r),n.beginPath(),n.arc(0,0,1,0,2*Math.PI),n.closePath(),n.scale(1/i,1/r),n.translate(-e,-t)},e.AllowAlphaInheritance=!1,e._ClipMeasure=new l.a(0,0,0,0),e._HORIZONTAL_ALIGNMENT_LEFT=0,e._HORIZONTAL_ALIGNMENT_RIGHT=1,e._HORIZONTAL_ALIGNMENT_CENTER=2,e._VERTICAL_ALIGNMENT_TOP=0,e._VERTICAL_ALIGNMENT_BOTTOM=1,e._VERTICAL_ALIGNMENT_CENTER=2,e._FontHeightSizes={},e.AddHeader=function(){},e}();p.a.RegisteredTypes["BABYLON.GUI.Control"]=_},function(e,t,i){"use strict";i.d(t,"a",(function(){return a}));var r=i(4),n=i(25),o=i(12),s=i(69),a=function(){function e(t,i,o,a,h,l,c,u,f,d){var p,_,g=this;if(void 0===a&&(a=null),void 0===l&&(l=null),void 0===c&&(c=null),void 0===u&&(u=null),void 0===f&&(f=null),this.name=null,this.defines="",this.onCompiled=null,this.onError=null,this.onBind=null,this.uniqueId=0,this.onCompileObservable=new r.a,this.onErrorObservable=new r.a,this._onBindObservable=null,this._wasPreviouslyReady=!1,this._bonesComputationForcedToCPU=!1,this._uniformBuffersNames={},this._samplers={},this._isReady=!1,this._compilationError="",this._allFallbacksProcessed=!1,this._uniforms={},this._key="",this._fallbacks=null,this._vertexSourceCode="",this._fragmentSourceCode="",this._vertexSourceCodeOverride="",this._fragmentSourceCodeOverride="",this._transformFeedbackVaryings=null,this._pipelineContext=null,this._valueCache={},this.name=t,i.attributes){var m=i;if(this._engine=o,this._attributesNames=m.attributes,this._uniformsNames=m.uniformsNames.concat(m.samplers),this._samplerList=m.samplers.slice(),this.defines=m.defines,this.onError=m.onError,this.onCompiled=m.onCompiled,this._fallbacks=m.fallbacks,this._indexParameters=m.indexParameters,this._transformFeedbackVaryings=m.transformFeedbackVaryings||null,m.uniformBuffersNames)for(var b=0;b=2?"WEBGL2":"WEBGL1"};this._loadShader(p,"Vertex","",(function(e){g._loadShader(_,"Fragment","Pixel",(function(i){s.a.Process(e,y,(function(e){y.isFragment=!0,s.a.Process(i,y,(function(i){g._useFinalCode(e,i,t)}))}))}))}))}return Object.defineProperty(e.prototype,"onBindObservable",{get:function(){return this._onBindObservable||(this._onBindObservable=new r.a),this._onBindObservable},enumerable:!0,configurable:!0}),e.prototype._useFinalCode=function(e,t,i){if(i){var r=i.vertexElement||i.vertex||i.spectorName||i,n=i.fragmentElement||i.fragment||i.spectorName||i;this._vertexSourceCode="#define SHADER_NAME vertex:"+r+"\n"+e,this._fragmentSourceCode="#define SHADER_NAME fragment:"+n+"\n"+t}else this._vertexSourceCode=e,this._fragmentSourceCode=t;this._prepareEffect()},Object.defineProperty(e.prototype,"key",{get:function(){return this._key},enumerable:!0,configurable:!0}),e.prototype.isReady=function(){try{return this._isReadyInternal()}catch(e){return!1}},e.prototype._isReadyInternal=function(){return!!this._isReady||!!this._pipelineContext&&this._pipelineContext.isReady},e.prototype.getEngine=function(){return this._engine},e.prototype.getPipelineContext=function(){return this._pipelineContext},e.prototype.getAttributesNames=function(){return this._attributesNames},e.prototype.getAttributeLocation=function(e){return this._attributes[e]},e.prototype.getAttributeLocationByName=function(e){return this._attributeLocationByName[e]},e.prototype.getAttributesCount=function(){return this._attributes.length},e.prototype.getUniformIndex=function(e){return this._uniformsNames.indexOf(e)},e.prototype.getUniform=function(e){return this._uniforms[e]},e.prototype.getSamplers=function(){return this._samplerList},e.prototype.getCompilationError=function(){return this._compilationError},e.prototype.allFallbacksProcessed=function(){return this._allFallbacksProcessed},e.prototype.executeWhenCompiled=function(e){var t=this;this.isReady()?e(this):(this.onCompileObservable.add((function(t){e(t)})),this._pipelineContext&&!this._pipelineContext.isAsync||setTimeout((function(){t._checkIsReady(null)}),16))},e.prototype._checkIsReady=function(e){var t=this;try{if(this._isReadyInternal())return}catch(t){return void this._processCompilationErrors(t,e)}setTimeout((function(){t._checkIsReady(e)}),16)},e.prototype._loadShader=function(t,i,r,o){var s;if("undefined"!=typeof HTMLElement&&t instanceof HTMLElement)return void o(n.a.GetDOMTextContent(t));"source:"!==t.substr(0,7)?"base64:"!==t.substr(0,7)?e.ShadersStore[t+i+"Shader"]?o(e.ShadersStore[t+i+"Shader"]):r&&e.ShadersStore[t+r+"Shader"]?o(e.ShadersStore[t+r+"Shader"]):(s="."===t[0]||"/"===t[0]||t.indexOf("http")>-1?t:e.ShadersRepository+t,this._engine._loadFile(s+"."+i.toLowerCase()+".fx",o)):o(window.atob(t.substr(7))):o(t.substr(7))},e.prototype._rebuildProgram=function(e,t,i,r){var n=this;this._isReady=!1,this._vertexSourceCodeOverride=e,this._fragmentSourceCodeOverride=t,this.onError=function(e,t){r&&r(t)},this.onCompiled=function(){var e=n.getEngine().scenes;if(e)for(var t=0;t=0&&o<=1?(a=n,h=s):o>=1&&o<=2?(a=s,h=n):o>=2&&o<=3?(h=n,l=s):o>=3&&o<=4?(h=s,l=n):o>=4&&o<=5?(a=s,l=n):o>=5&&o<=6&&(a=n,l=s);var c=i-n;r.set(a+c,h+c,l+c)},e.FromHexString=function(t){if("#"!==t.substring(0,1)||7!==t.length)return new e(0,0,0);var i=parseInt(t.substring(1,3),16),r=parseInt(t.substring(3,5),16),n=parseInt(t.substring(5,7),16);return e.FromInts(i,r,n)},e.FromArray=function(t,i){return void 0===i&&(i=0),new e(t[i],t[i+1],t[i+2])},e.FromInts=function(t,i,r){return new e(t/255,i/255,r/255)},e.Lerp=function(t,i,r){var n=new e(0,0,0);return e.LerpToRef(t,i,r,n),n},e.LerpToRef=function(e,t,i,r){r.r=e.r+(t.r-e.r)*i,r.g=e.g+(t.g-e.g)*i,r.b=e.b+(t.b-e.b)*i},e.Red=function(){return new e(1,0,0)},e.Green=function(){return new e(0,1,0)},e.Blue=function(){return new e(0,0,1)},e.Black=function(){return new e(0,0,0)},Object.defineProperty(e,"BlackReadOnly",{get:function(){return e._BlackReadOnly},enumerable:!0,configurable:!0}),e.White=function(){return new e(1,1,1)},e.Purple=function(){return new e(.5,0,.5)},e.Magenta=function(){return new e(1,0,1)},e.Yellow=function(){return new e(1,1,0)},e.Gray=function(){return new e(.5,.5,.5)},e.Teal=function(){return new e(0,1,1)},e.Random=function(){return new e(Math.random(),Math.random(),Math.random())},e._BlackReadOnly=e.Black(),e}(),h=function(){function e(e,t,i,r){void 0===e&&(e=0),void 0===t&&(t=0),void 0===i&&(i=0),void 0===r&&(r=1),this.r=e,this.g=t,this.b=i,this.a=r}return e.prototype.addInPlace=function(e){return this.r+=e.r,this.g+=e.g,this.b+=e.b,this.a+=e.a,this},e.prototype.asArray=function(){var e=new Array;return this.toArray(e,0),e},e.prototype.toArray=function(e,t){return void 0===t&&(t=0),e[t]=this.r,e[t+1]=this.g,e[t+2]=this.b,e[t+3]=this.a,this},e.prototype.equals=function(e){return e&&this.r===e.r&&this.g===e.g&&this.b===e.b&&this.a===e.a},e.prototype.add=function(t){return new e(this.r+t.r,this.g+t.g,this.b+t.b,this.a+t.a)},e.prototype.subtract=function(t){return new e(this.r-t.r,this.g-t.g,this.b-t.b,this.a-t.a)},e.prototype.subtractToRef=function(e,t){return t.r=this.r-e.r,t.g=this.g-e.g,t.b=this.b-e.b,t.a=this.a-e.a,this},e.prototype.scale=function(t){return new e(this.r*t,this.g*t,this.b*t,this.a*t)},e.prototype.scaleToRef=function(e,t){return t.r=this.r*e,t.g=this.g*e,t.b=this.b*e,t.a=this.a*e,this},e.prototype.scaleAndAddToRef=function(e,t){return t.r+=this.r*e,t.g+=this.g*e,t.b+=this.b*e,t.a+=this.a*e,this},e.prototype.clampToRef=function(e,t,i){return void 0===e&&(e=0),void 0===t&&(t=1),i.r=r.a.Clamp(this.r,e,t),i.g=r.a.Clamp(this.g,e,t),i.b=r.a.Clamp(this.b,e,t),i.a=r.a.Clamp(this.a,e,t),this},e.prototype.multiply=function(t){return new e(this.r*t.r,this.g*t.g,this.b*t.b,this.a*t.a)},e.prototype.multiplyToRef=function(e,t){return t.r=this.r*e.r,t.g=this.g*e.g,t.b=this.b*e.b,t.a=this.a*e.a,t},e.prototype.toString=function(){return"{R: "+this.r+" G:"+this.g+" B:"+this.b+" A:"+this.a+"}"},e.prototype.getClassName=function(){return"Color4"},e.prototype.getHashCode=function(){var e=255*this.r|0;return e=397*(e=397*(e=397*e^(255*this.g|0))^(255*this.b|0))^(255*this.a|0)},e.prototype.clone=function(){return new e(this.r,this.g,this.b,this.a)},e.prototype.copyFrom=function(e){return this.r=e.r,this.g=e.g,this.b=e.b,this.a=e.a,this},e.prototype.copyFromFloats=function(e,t,i,r){return this.r=e,this.g=t,this.b=i,this.a=r,this},e.prototype.set=function(e,t,i,r){return this.copyFromFloats(e,t,i,r)},e.prototype.toHexString=function(){var e=255*this.r|0,t=255*this.g|0,i=255*this.b|0,n=255*this.a|0;return"#"+r.a.ToHex(e)+r.a.ToHex(t)+r.a.ToHex(i)+r.a.ToHex(n)},e.prototype.toLinearSpace=function(){var t=new e;return this.toLinearSpaceToRef(t),t},e.prototype.toLinearSpaceToRef=function(e){return e.r=Math.pow(this.r,n.c),e.g=Math.pow(this.g,n.c),e.b=Math.pow(this.b,n.c),e.a=this.a,this},e.prototype.toGammaSpace=function(){var t=new e;return this.toGammaSpaceToRef(t),t},e.prototype.toGammaSpaceToRef=function(e){return e.r=Math.pow(this.r,n.b),e.g=Math.pow(this.g,n.b),e.b=Math.pow(this.b,n.b),e.a=this.a,this},e.FromHexString=function(t){if("#"!==t.substring(0,1)||9!==t.length)return new e(0,0,0,0);var i=parseInt(t.substring(1,3),16),r=parseInt(t.substring(3,5),16),n=parseInt(t.substring(5,7),16),o=parseInt(t.substring(7,9),16);return e.FromInts(i,r,n,o)},e.Lerp=function(t,i,r){var n=new e(0,0,0,0);return e.LerpToRef(t,i,r,n),n},e.LerpToRef=function(e,t,i,r){r.r=e.r+(t.r-e.r)*i,r.g=e.g+(t.g-e.g)*i,r.b=e.b+(t.b-e.b)*i,r.a=e.a+(t.a-e.a)*i},e.FromColor3=function(t,i){return void 0===i&&(i=1),new e(t.r,t.g,t.b,i)},e.FromArray=function(t,i){return void 0===i&&(i=0),new e(t[i],t[i+1],t[i+2],t[i+3])},e.FromInts=function(t,i,r,n){return new e(t/255,i/255,r/255,n/255)},e.CheckColors4=function(e,t){if(e.length===3*t){for(var i=[],r=0;rn.bbSize.y?n.bbSize.x:n.bbSize.y;$=$>n.bbSize.z?$:n.bbSize.z,D=n.subDiv.X*R/n.bbSize.x,L=n.subDiv.Y*R/n.bbSize.y,F=n.subDiv.Z*R/n.bbSize.z,N=n.subDiv.max*n.subDiv.max,n.facetPartitioning.length=0}for(o=0;o
";e._AddLogEntry(r)},e._WarnDisabled=function(e){},e._WarnEnabled=function(t){var i=e._FormatMessage(t);console.warn("BJS - "+i);var r="
"+i+"

";e._AddLogEntry(r)},e._ErrorDisabled=function(e){},e._ErrorEnabled=function(t){e.errorsCount++;var i=e._FormatMessage(t);console.error("BJS - "+i);var r="
"+i+"

";e._AddLogEntry(r)},Object.defineProperty(e,"LogCache",{get:function(){return e._LogCache},enumerable:!0,configurable:!0}),e.ClearLogCache=function(){e._LogCache="",e.errorsCount=0},Object.defineProperty(e,"LogLevels",{set:function(t){(t&e.MessageLogLevel)===e.MessageLogLevel?e.Log=e._LogEnabled:e.Log=e._LogDisabled,(t&e.WarningLogLevel)===e.WarningLogLevel?e.Warn=e._WarnEnabled:e.Warn=e._WarnDisabled,(t&e.ErrorLogLevel)===e.ErrorLogLevel?e.Error=e._ErrorEnabled:e.Error=e._ErrorDisabled},enumerable:!0,configurable:!0}),e.NoneLogLevel=0,e.MessageLogLevel=1,e.WarningLogLevel=2,e.ErrorLogLevel=4,e.AllLogLevel=7,e._LogCache="",e.errorsCount=0,e.Log=e._LogEnabled,e.Warn=e._WarnEnabled,e.Error=e._ErrorEnabled,e}()},function(e,t,i){"use strict";i.d(t,"b",(function(){return v})),i.d(t,"a",(function(){return y}));var r,n=i(4),o=i(25),s=i(12),a=i(58),h=i(37),l=i(8),c=i(61),u=i(23),f=i(36);!function(e){e[e.Pending=0]="Pending",e[e.Fulfilled=1]="Fulfilled",e[e.Rejected=2]="Rejected"}(r||(r={}));var d=function(){this.count=0,this.target=0,this.results=[]},p=function(){function e(e){var t=this;if(this._state=r.Pending,this._children=new Array,this._rejectWasConsumed=!1,e)try{e((function(e){t._resolve(e)}),(function(e){t._reject(e)}))}catch(e){this._reject(e)}}return Object.defineProperty(e.prototype,"_result",{get:function(){return this._resultValue},set:function(e){this._resultValue=e,this._parent&&void 0===this._parent._result&&(this._parent._result=e)},enumerable:!0,configurable:!0}),e.prototype.catch=function(e){return this.then(void 0,e)},e.prototype.then=function(t,i){var n=this,o=new e;return o._onFulfilled=t,o._onRejected=i,this._children.push(o),o._parent=this,this._state!==r.Pending&&setTimeout((function(){if(n._state===r.Fulfilled||n._rejectWasConsumed){var e=o._resolve(n._result);if(null!=e)if(void 0!==e._state){var t=e;o._children.push(t),t._parent=o,o=t}else o._result=e}else o._reject(n._reason)})),o},e.prototype._moveChildren=function(e){var t,i=this;if((t=this._children).push.apply(t,e.splice(0,e.length)),this._children.forEach((function(e){e._parent=i})),this._state===r.Fulfilled)for(var n=0,o=this._children;n=t)break;if(r(s),o&&o()){e.breakLoop();break}}e.executeNext()}),s)}),n)},e}();u.a.FallbackTexture="",_.Apply()},function(e,t,i){"use strict";i.d(t,"a",(function(){return r}));var r=function(){function e(t,i,r){void 0===i&&(i=e.UNITMODE_PIXEL),void 0===r&&(r=!0),this.unit=i,this.negativeValueAllowed=r,this._value=1,this.ignoreAdaptiveScaling=!1,this._value=t,this._originalUnit=i}return Object.defineProperty(e.prototype,"isPercentage",{get:function(){return this.unit===e.UNITMODE_PERCENTAGE},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isPixel",{get:function(){return this.unit===e.UNITMODE_PIXEL},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"internalValue",{get:function(){return this._value},enumerable:!0,configurable:!0}),e.prototype.getValueInPixel=function(e,t){return this.isPixel?this.getValue(e):this.getValue(e)*t},e.prototype.updateInPlace=function(t,i){return void 0===i&&(i=e.UNITMODE_PIXEL),this._value=t,this.unit=i,this},e.prototype.getValue=function(t){if(t&&!this.ignoreAdaptiveScaling&&this.unit!==e.UNITMODE_PERCENTAGE){var i=0,r=0;if(t.idealWidth&&(i=this._value*t.getSize().width/t.idealWidth),t.idealHeight&&(r=this._value*t.getSize().height/t.idealHeight),t.useSmallestIdeal&&t.idealWidth&&t.idealHeight)return window.innerWidth0&&(this._indexBuffer=this._engine.createIndexBuffer(this._indices)),this._indexBuffer&&(this._indexBuffer.references=t),e._syncGeometryWithMorphTargetManager(),e.synchronizeInstances()},e.prototype.notifyUpdate=function(e){this.onGeometryUpdated&&this.onGeometryUpdated(this,e);for(var t=0,i=this._meshes;t0){for(var t=0;t0){for(t=0;t0){for(t=0;t0){var a=new Float32Array(t,s.positionsAttrDesc.offset,s.positionsAttrDesc.count);i.setVerticesData(u.b.PositionKind,a,!1)}if(s.normalsAttrDesc&&s.normalsAttrDesc.count>0){var h=new Float32Array(t,s.normalsAttrDesc.offset,s.normalsAttrDesc.count);i.setVerticesData(u.b.NormalKind,h,!1)}if(s.tangetsAttrDesc&&s.tangetsAttrDesc.count>0){var c=new Float32Array(t,s.tangetsAttrDesc.offset,s.tangetsAttrDesc.count);i.setVerticesData(u.b.TangentKind,c,!1)}if(s.uvsAttrDesc&&s.uvsAttrDesc.count>0){var f=new Float32Array(t,s.uvsAttrDesc.offset,s.uvsAttrDesc.count);i.setVerticesData(u.b.UVKind,f,!1)}if(s.uvs2AttrDesc&&s.uvs2AttrDesc.count>0){var p=new Float32Array(t,s.uvs2AttrDesc.offset,s.uvs2AttrDesc.count);i.setVerticesData(u.b.UV2Kind,p,!1)}if(s.uvs3AttrDesc&&s.uvs3AttrDesc.count>0){var _=new Float32Array(t,s.uvs3AttrDesc.offset,s.uvs3AttrDesc.count);i.setVerticesData(u.b.UV3Kind,_,!1)}if(s.uvs4AttrDesc&&s.uvs4AttrDesc.count>0){var g=new Float32Array(t,s.uvs4AttrDesc.offset,s.uvs4AttrDesc.count);i.setVerticesData(u.b.UV4Kind,g,!1)}if(s.uvs5AttrDesc&&s.uvs5AttrDesc.count>0){var m=new Float32Array(t,s.uvs5AttrDesc.offset,s.uvs5AttrDesc.count);i.setVerticesData(u.b.UV5Kind,m,!1)}if(s.uvs6AttrDesc&&s.uvs6AttrDesc.count>0){var b=new Float32Array(t,s.uvs6AttrDesc.offset,s.uvs6AttrDesc.count);i.setVerticesData(u.b.UV6Kind,b,!1)}if(s.colorsAttrDesc&&s.colorsAttrDesc.count>0){var v=new Float32Array(t,s.colorsAttrDesc.offset,s.colorsAttrDesc.count);i.setVerticesData(u.b.ColorKind,v,!1,s.colorsAttrDesc.stride)}if(s.matricesIndicesAttrDesc&&s.matricesIndicesAttrDesc.count>0){for(var y=new Int32Array(t,s.matricesIndicesAttrDesc.offset,s.matricesIndicesAttrDesc.count),x=[],T=0;T>8),x.push((16711680&E)>>16),x.push(E>>24)}i.setVerticesData(u.b.MatricesIndicesKind,x,!1)}if(s.matricesWeightsAttrDesc&&s.matricesWeightsAttrDesc.count>0){var M=new Float32Array(t,s.matricesWeightsAttrDesc.offset,s.matricesWeightsAttrDesc.count);i.setVerticesData(u.b.MatricesWeightsKind,M,!1)}if(s.indicesAttrDesc&&s.indicesAttrDesc.count>0){var A=new Int32Array(t,s.indicesAttrDesc.offset,s.indicesAttrDesc.count);i.setIndices(A,null)}if(s.subMeshesAttrDesc&&s.subMeshesAttrDesc.count>0){var O=new Int32Array(t,s.subMeshesAttrDesc.offset,5*s.subMeshesAttrDesc.count);i.subMeshes=[];for(T=0;T>8),x.push((16711680&w)>>16),x.push(w>>24)}i.setVerticesData(u.b.MatricesIndicesKind,x,t.matricesIndices._updatable)}if(t.matricesIndicesExtra)if(t.matricesIndicesExtra._isExpanded)delete t.matricesIndices._isExpanded,i.setVerticesData(u.b.MatricesIndicesExtraKind,t.matricesIndicesExtra,t.matricesIndicesExtra._updatable);else{for(x=[],T=0;T>8),x.push((16711680&w)>>16),x.push(w>>24)}i.setVerticesData(u.b.MatricesIndicesExtraKind,x,t.matricesIndicesExtra._updatable)}t.matricesWeights&&(e._CleanMatricesWeights(t,i),i.setVerticesData(u.b.MatricesWeightsKind,t.matricesWeights,t.matricesWeights._updatable)),t.matricesWeightsExtra&&i.setVerticesData(u.b.MatricesWeightsExtraKind,t.matricesWeightsExtra,t.matricesWeights._updatable),i.setIndices(t.indices,null)}if(t.subMeshes){i.subMeshes=[];for(var D=0;D-1){var n=t.getScene().getLastSkeletonByID(e.skeletonId);if(n){r=n.bones.length;for(var o=t.getVerticesData(u.b.MatricesIndicesKind),s=t.getVerticesData(u.b.MatricesIndicesExtraKind),a=e.matricesWeights,h=e.matricesWeightsExtra,l=e.numBoneInfluencer,c=a.length,f=0;fl-1)&&(_=l-1),d>i){var b=1/d;for(g=0;g<4;g++)a[f+g]*=b;if(h)for(g=0;g<4;g++)h[f+g]*=b}else _>=4?(h[f+_-4]=1-d,s[f+_-4]=r):(a[f+_]=1-d,o[f+_]=r)}t.setVerticesData(u.b.MatricesIndicesKind,o),e.matricesWeightsExtra&&t.setVerticesData(u.b.MatricesIndicesExtraKind,s)}}}},e.Parse=function(t,i,r){if(i.getGeometryByID(t.id))return null;var n=new e(t.id,i,void 0,t.updatable);return a.a&&a.a.AddTagsTo(n,t.tags),t.delayLoadingFile?(n.delayLoadState=4,n.delayLoadingFile=r+t.delayLoadingFile,n._boundingInfo=new _.a(h.e.FromArray(t.boundingBoxMinimum),h.e.FromArray(t.boundingBoxMaximum)),n._delayInfo=[],t.hasUVs&&n._delayInfo.push(u.b.UVKind),t.hasUVs2&&n._delayInfo.push(u.b.UV2Kind),t.hasUVs3&&n._delayInfo.push(u.b.UV3Kind),t.hasUVs4&&n._delayInfo.push(u.b.UV4Kind),t.hasUVs5&&n._delayInfo.push(u.b.UV5Kind),t.hasUVs6&&n._delayInfo.push(u.b.UV6Kind),t.hasColors&&n._delayInfo.push(u.b.ColorKind),t.hasMatricesIndices&&n._delayInfo.push(u.b.MatricesIndicesKind),t.hasMatricesWeights&&n._delayInfo.push(u.b.MatricesWeightsKind),n._delayLoadingFunction=f.VertexData.ImportVertexData):f.VertexData.ImportVertexData(t,n),i.pushGeometry(n,!0),n},e}(),b=i(43),v=i(27),y=i(63),x=i(3),T=i(12),E=i(10),M=i(8),A=i(22),O=function(e,t){this.distance=e,this.mesh=t},C=i(54),S=function(){},P=function(){this.visibleInstances={},this.batchCache=new R,this.instancesBufferSize=2048},R=function(){this.mustReturn=!1,this.visibleInstances=new Array,this.renderSelf=new Array,this.hardwareInstancedRendering=new Array},I=function(){this._areNormalsFrozen=!1,this._source=null,this.meshMap=null,this._preActivateId=-1,this._LODLevels=new Array,this._morphTargetManager=null},w=function(e){function t(i,r,n,o,h,l){void 0===r&&(r=null),void 0===n&&(n=null),void 0===o&&(o=null),void 0===l&&(l=!0);var c=e.call(this,i,r)||this;if(c._internalMeshDataInfo=new I,c.delayLoadState=0,c.instances=new Array,c._creationDataStorage=null,c._geometry=null,c._instanceDataStorage=new P,c._effectiveMaterial=null,c._shouldGenerateFlatShading=!1,c._originalBuilderSideOrientation=t.DEFAULTSIDE,c.overrideMaterialSideOrientation=null,r=c.getScene(),o){if(o._geometry&&o._geometry.applyToMesh(c),s.a.DeepCopy(o,c,["name","material","skeleton","instances","parent","uniqueId","source","metadata","hasLODLevels","geometry","isBlocked","areNormalsFrozen","onBeforeDrawObservable","onBeforeRenderObservable","onAfterRenderObservable","onBeforeDraw","onAfterWorldMatrixUpdateObservable","onCollideObservable","onCollisionPositionChangeObservable","onRebuildObservable","onDisposeObservable","lightSources","morphTargetManager"],["_poseMatrix"]),c._internalMeshDataInfo._source=o,r.useClonedMeshMap&&(o._internalMeshDataInfo.meshMap||(o._internalMeshDataInfo.meshMap={}),o._internalMeshDataInfo.meshMap[c.uniqueId]=c),c._originalBuilderSideOrientation=o._originalBuilderSideOrientation,c._creationDataStorage=o._creationDataStorage,o._ranges){var u=o._ranges;for(var i in u)u.hasOwnProperty(i)&&u[i]&&c.createAnimationRange(i,u[i].from,u[i].to)}var f;if(o.metadata&&o.metadata.clone?c.metadata=o.metadata.clone():c.metadata=o.metadata,a.a&&a.a.HasTags(o)&&a.a.AddTagsTo(c,a.a.GetTags(o,!0)),c.parent=o.parent,c.setPivotMatrix(o.getPivotMatrix()),c.id=i+"."+o.id,c.material=o.material,!h)for(var d=o.getDescendants(!0),p=0;p0},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"morphTargetManager",{get:function(){return this._internalMeshDataInfo._morphTargetManager},set:function(e){this._internalMeshDataInfo._morphTargetManager!==e&&(this._internalMeshDataInfo._morphTargetManager=e,this._syncGeometryWithMorphTargetManager())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"source",{get:function(){return this._internalMeshDataInfo._source},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"isUnIndexed",{get:function(){return this._unIndexed},set:function(e){this._unIndexed!==e&&(this._unIndexed=e,this._markSubMeshesAsAttributesDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"worldMatrixInstancedBuffer",{get:function(){return this._instanceDataStorage.instancesData},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"manualUpdateOfWorldMatrixInstancedBuffer",{get:function(){return this._instanceDataStorage.manualUpdate},set:function(e){this._instanceDataStorage.manualUpdate=e},enumerable:!0,configurable:!0}),t.prototype.instantiateHierarchy=function(e,t,i){void 0===e&&(e=null);var r=!(this.getTotalVertices()>0)||t&&t.doNotInstantiate?this.clone("Clone of "+(this.name||this.id),e||this.parent,!0):this.createInstance("instance of "+(this.name||this.id));r&&(r.parent=e||this.parent,r.position=this.position.clone(),r.scaling=this.scaling.clone(),this.rotationQuaternion?r.rotationQuaternion=this.rotationQuaternion.clone():r.rotation=this.rotation.clone(),i&&i(this,r));for(var n=0,o=this.getChildTransformNodes(!0);n0},enumerable:!0,configurable:!0}),t.prototype.getLODLevels=function(){return this._internalMeshDataInfo._LODLevels},t.prototype._sortLODLevels=function(){this._internalMeshDataInfo._LODLevels.sort((function(e,t){return e.distancet.distance?-1:0}))},t.prototype.addLODLevel=function(e,t){if(t&&t._masterMesh)return T.a.Warn("You cannot use a mesh as LOD level twice"),this;var i=new O(e,t);return this._internalMeshDataInfo._LODLevels.push(i),t&&(t._masterMesh=this),this._sortLODLevels(),this},t.prototype.getLODLevelAtDistance=function(e){for(var t=this._internalMeshDataInfo,i=0;in)return this.onLODLevelSelection&&this.onLODLevelSelection(n,this,this),this;for(var o=0;o0;this.computeWorldMatrix();var s=this.material||n.defaultMaterial;if(s)if(s._storeEffectOnSubMeshes)for(var a=0,h=this.subMeshes;a0){var i=this.getIndices();if(!i)return null;var r=i.length,n=!1;if(e)n=!0;else for(var o=0,s=this.subMeshes;o=r){n=!0;break}if(a.verticesStart+a.verticesCount>=t){n=!0;break}}if(!n)return this.subMeshes[0]}return this.releaseSubMeshes(),new d.b(0,0,t,0,this.getTotalIndices(),this)},t.prototype.subdivide=function(e){if(!(e<1)){for(var t=this.getTotalIndices(),i=t/e|0,r=0;i%3!=0;)i++;this.releaseSubMeshes();for(var n=0;n=t);n++)d.b.CreateFromIndices(0,r,Math.min(i,t-r),this),r+=i;this.synchronizeInstances()}},t.prototype.setVerticesData=function(e,t,i,r){if(void 0===i&&(i=!1),this._geometry)this._geometry.setVerticesData(e,t,i,r);else{var n=new f.VertexData;n.set(t,e);var o=this.getScene();new m(m.RandomId(),o,n,i,this)}return this},t.prototype.removeVerticesData=function(e){this._geometry&&this._geometry.removeVerticesData(e)},t.prototype.markVerticesDataAsUpdatable=function(e,t){void 0===t&&(t=!0);var i=this.getVertexBuffer(e);i&&i.isUpdatable()!==t&&this.setVerticesData(e,this.getVerticesData(e),t)},t.prototype.setVerticesBuffer=function(e){return this._geometry||(this._geometry=m.CreateGeometryForMesh(this)),this._geometry.setVerticesBuffer(e),this},t.prototype.updateVerticesData=function(e,t,i,r){return this._geometry?(r?(this.makeGeometryUnique(),this.updateVerticesData(e,t,i,!1)):this._geometry.updateVerticesData(e,t,i),this):this},t.prototype.updateMeshPositions=function(e,t){void 0===t&&(t=!0);var i=this.getVerticesData(u.b.PositionKind);if(!i)return this;if(e(i),this.updateVerticesData(u.b.PositionKind,i,!1,!1),t){var r=this.getIndices(),n=this.getVerticesData(u.b.NormalKind);if(!n)return this;f.VertexData.ComputeNormals(i,r,n),this.updateVerticesData(u.b.NormalKind,n,!1,!1)}return this},t.prototype.makeGeometryUnique=function(){if(!this._geometry)return this;var e=this._geometry,t=this._geometry.copy(m.RandomId());return e.releaseForMesh(this,!0),t.applyToMesh(this),this},t.prototype.setIndices=function(e,t,i){if(void 0===t&&(t=null),void 0===i&&(i=!1),this._geometry)this._geometry.setIndices(e,t,i);else{var r=new f.VertexData;r.indices=e;var n=this.getScene();new m(m.RandomId(),n,r,i,this)}return this},t.prototype.updateIndices=function(e,t,i){return void 0===i&&(i=!1),this._geometry?(this._geometry.updateIndices(e,t,i),this):this},t.prototype.toLeftHanded=function(){return this._geometry?(this._geometry.toLeftHanded(),this):this},t.prototype._bind=function(e,t,i){if(!this._geometry)return this;var r,n=this.getScene().getEngine();if(this._unIndexed)r=null;else switch(i){case v.a.PointFillMode:r=null;break;case v.a.WireFrameFillMode:r=e._getLinesIndexBuffer(this.getIndices(),n);break;default:case v.a.TriangleFillMode:r=this._geometry.getIndexBuffer()}return this._geometry._bind(t,r),this},t.prototype._draw=function(e,t,i){if(!this._geometry||!this._geometry.getVertexBuffers()||!this._unIndexed&&!this._geometry.getIndexBuffer())return this;this._internalMeshDataInfo._onBeforeDrawObservable&&this._internalMeshDataInfo._onBeforeDrawObservable.notifyObservers(this);var r=this.getScene().getEngine();return this._unIndexed||t==v.a.PointFillMode?r.drawArraysType(t,e.verticesStart,e.verticesCount,i):t==v.a.WireFrameFillMode?r.drawElementsType(t,0,e._linesIndexCount,i):r.drawElementsType(t,e.indexStart,e.indexCount,i),this},t.prototype.registerBeforeRender=function(e){return this.onBeforeRenderObservable.add(e),this},t.prototype.unregisterBeforeRender=function(e){return this.onBeforeRenderObservable.removeCallback(e),this},t.prototype.registerAfterRender=function(e){return this.onAfterRenderObservable.add(e),this},t.prototype.unregisterAfterRender=function(e){return this.onAfterRenderObservable.removeCallback(e),this},t.prototype._getInstancesRenderList=function(e,t){if(void 0===t&&(t=!1),this._instanceDataStorage.isFrozen&&this._instanceDataStorage.previousBatch)return this._instanceDataStorage.previousBatch;var i=this.getScene(),r=i._isInIntermediateRendering(),n=r?this._internalAbstractMeshDataInfo._onlyForInstancesIntermediate:this._internalAbstractMeshDataInfo._onlyForInstances,o=this._instanceDataStorage.batchCache;if(o.mustReturn=!1,o.renderSelf[e]=t||!n&&this.isEnabled()&&this.isVisible,o.visibleInstances[e]=null,this._instanceDataStorage.visibleInstances&&!t){var s=this._instanceDataStorage.visibleInstances,a=i.getRenderId(),h=r?s.intermediateDefaultRenderId:s.defaultRenderId;o.visibleInstances[e]=s[a],!o.visibleInstances[e]&&h&&(o.visibleInstances[e]=s[h])}return o.hardwareInstancedRendering[e]=!t&&this._instanceDataStorage.hardwareInstancedRendering&&null!==o.visibleInstances[e]&&void 0!==o.visibleInstances[e],this._instanceDataStorage.previousBatch=o,o},t.prototype._renderWithInstances=function(e,t,i,r,n){var o=i.visibleInstances[e._id];if(!o)return this;for(var s=this._instanceDataStorage,a=s.instancesBufferSize,h=s.instancesBuffer,l=16*(o.length+1)*4;s.instancesBufferSizec&&r++,0!==_&&d++,f+=_,c=_}if(h[d]++,d>o&&(o=d),0===f)n++;else{var g=1/f,m=0;for(p=0;p.001&&s++}}var b=this.skeleton.bones.length,v=this.getVerticesData(u.b.MatricesIndicesKind),y=this.getVerticesData(u.b.MatricesIndicesExtraKind),x=0;for(l=0;l=b||T<0)&&x++}return{skinned:!0,valid:0===n&&0===s&&0===x,report:"Number of Weights = "+i/4+"\nMaximum influences = "+o+"\nMissing Weights = "+n+"\nNot Sorted = "+r+"\nNot Normalized = "+s+"\nWeightCounts = ["+h+"]\nNumber of bones = "+b+"\nBad Bone Indices = "+x}},t.prototype._checkDelayState=function(){var e=this.getScene();return this._geometry?this._geometry.load(e):4===this.delayLoadState&&(this.delayLoadState=2,this._queueLoad(e)),this},t.prototype._queueLoad=function(e){var t=this;e._addPendingData(this);var i=-1!==this.delayLoadingFile.indexOf(".babylonbinarymeshdata");return o.b.LoadFile(this.delayLoadingFile,(function(i){i instanceof ArrayBuffer?t._delayLoadingFunction(i,t):t._delayLoadingFunction(JSON.parse(i),t),t.instances.forEach((function(e){e.refreshBoundingInfo(),e._syncSubMeshes()})),t.delayLoadState=1,e._removePendingData(t)}),(function(){}),e.offlineProvider,i),this},t.prototype.isInFrustum=function(t){return 2!==this.delayLoadState&&(!!e.prototype.isInFrustum.call(this,t)&&(this._checkDelayState(),!0))},t.prototype.setMaterialByID=function(e){var t,i=this.getScene().materials;for(t=i.length-1;t>-1;t--)if(i[t].id===e)return this.material=i[t],this;var r=this.getScene().multiMaterials;for(t=r.length-1;t>-1;t--)if(r[t].id===e)return this.material=r[t],this;return this},t.prototype.getAnimatables=function(){var e=new Array;return this.material&&e.push(this.material),this.skeleton&&e.push(this.skeleton),e},t.prototype.bakeTransformIntoVertices=function(e){if(!this.isVerticesDataPresent(u.b.PositionKind))return this;var t=this.subMeshes.splice(0);this._resetPointsArrayCache();var i,r=this.getVerticesData(u.b.PositionKind),n=new Array;for(i=0;i-1&&(n.morphTargetManager=i.getMorphTargetManagerById(e.morphTargetManagerId)),e.skeletonId>-1&&(n.skeleton=i.getLastSkeletonByID(e.skeletonId),e.numBoneInfluencers&&(n.numBoneInfluencers=e.numBoneInfluencers)),e.animations){for(var o=0;o4,c=l?this.getVerticesData(u.b.MatricesIndicesExtraKind):null,f=l?this.getVerticesData(u.b.MatricesWeightsExtraKind):null,d=e.getTransformMatrices(this),p=h.e.Zero(),_=new h.a,g=new h.a,m=0,b=0;b0&&(h.a.FromFloat32ArrayToRefScaled(d,Math.floor(16*o[m+a]),v,g),_.addToSelf(g));if(l)for(a=0;a<4;a++)(v=f[m+a])>0&&(h.a.FromFloat32ArrayToRefScaled(d,Math.floor(16*c[m+a]),v,g),_.addToSelf(g));h.e.TransformCoordinatesFromFloatsToRef(t._sourcePositions[b],t._sourcePositions[b+1],t._sourcePositions[b+2],_,p),p.toArray(r,b),h.e.TransformNormalFromFloatsToRef(t._sourceNormals[b],t._sourceNormals[b+1],t._sourceNormals[b+2],_,p),p.toArray(n,b),_.reset()}return this.updateVerticesData(u.b.PositionKind,r),this.updateVerticesData(u.b.NormalKind,n),this},t.MinMax=function(e){var t=null,i=null;return e.forEach((function(e){var r=e.getBoundingInfo().boundingBox;t&&i?(t.minimizeInPlace(r.minimumWorld),i.maximizeInPlace(r.maximumWorld)):(t=r.minimumWorld,i=r.maximumWorld)})),t&&i?{min:t,max:i}:{min:h.e.Zero(),max:h.e.Zero()}},t.Center=function(e){var i=e instanceof Array?t.MinMax(e):e;return h.e.Center(i.min,i.max)},t.MergeMeshes=function(e,i,r,n,o,s){var a;if(void 0===i&&(i=!0),!r){var h=0;for(a=0;a=65536)return T.a.Warn("Cannot merge meshes because resulting mesh will have more than 65536 vertices. Please use allow32BitsIndices = true to use 32 bits indices"),null}if(s){var l,c,u=null;o=!1}var p,_=new Array,g=new Array,m=null,b=new Array,v=null;for(a=0;a0?1:-1},e.Clamp=function(e,t,i){return void 0===t&&(t=0),void 0===i&&(i=1),Math.min(i,Math.max(t,e))},e.Log2=function(e){return Math.log(e)*Math.LOG2E},e.Repeat=function(e,t){return e-Math.floor(e/t)*t},e.Normalize=function(e,t,i){return(e-t)/(i-t)},e.Denormalize=function(e,t,i){return e*(i-t)+t},e.DeltaAngle=function(t,i){var r=e.Repeat(i-t,360);return r>180&&(r-=360),r},e.PingPong=function(t,i){var r=e.Repeat(t,2*i);return i-Math.abs(r-i)},e.SmoothStep=function(t,i,r){var n=e.Clamp(r);return i*(n=-2*n*n*n+3*n*n)+t*(1-n)},e.MoveTowards=function(t,i,r){return Math.abs(i-t)<=r?i:t+e.Sign(i-t)*r},e.MoveTowardsAngle=function(t,i,r){var n=e.DeltaAngle(t,i),o=0;return-r180&&(n-=360),t+n*e.Clamp(r)},e.InverseLerp=function(t,i,r){return t!=i?e.Clamp((r-t)/(i-t)):0},e.Hermite=function(e,t,i,r,n){var o=n*n,s=n*o;return e*(2*s-3*o+1)+i*(-2*s+3*o)+t*(s-2*o+n)+r*(s-o)},e.RandomRange=function(e,t){return e===t?e:Math.random()*(t-e)+e},e.RangeToPercent=function(e,t,i){return(e-t)/(i-t)},e.PercentToRange=function(e,t,i){return(i-t)*e+t},e.NormalizeRadians=function(t){return t-=e.TwoPi*Math.floor((t+Math.PI)/e.TwoPi)},e.TwoPi=2*Math.PI,e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return m}));var r=i(1),n=i(3),o=i(4),s=i(0),a=i(23),h=i(72),l=i(47),c=(i(36),function(){function e(t){this.metadata=null,this.reservedDataStore=null,this._hasAlpha=!1,this.getAlphaFromRGB=!1,this.level=1,this.coordinatesIndex=0,this._coordinatesMode=0,this.wrapU=1,this.wrapV=1,this.wrapR=1,this.anisotropicFilteringLevel=e.DEFAULT_ANISOTROPIC_FILTERING_LEVEL,this.gammaSpace=!0,this.invertZ=!1,this.lodLevelInAlpha=!1,this.isRenderTarget=!1,this.animations=new Array,this.onDisposeObservable=new o.a,this._onDisposeObserver=null,this.delayLoadState=0,this._scene=null,this._texture=null,this._uid=null,this._cachedSize=l.a.Zero(),this._scene=t||a.a.LastCreatedScene,this._scene&&(this.uniqueId=this._scene.getUniqueId(),this._scene.addTexture(this)),this._uid=null}return Object.defineProperty(e.prototype,"hasAlpha",{get:function(){return this._hasAlpha},set:function(e){this._hasAlpha!==e&&(this._hasAlpha=e,this._scene&&this._scene.markAllMaterialsAsDirty(17))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"coordinatesMode",{get:function(){return this._coordinatesMode},set:function(e){this._coordinatesMode!==e&&(this._coordinatesMode=e,this._scene&&this._scene.markAllMaterialsAsDirty(1))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isCube",{get:function(){return!!this._texture&&this._texture.isCube},set:function(e){this._texture&&(this._texture.isCube=e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"is3D",{get:function(){return!!this._texture&&this._texture.is3D},set:function(e){this._texture&&(this._texture.is3D=e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"is2DArray",{get:function(){return!!this._texture&&this._texture.is2DArray},set:function(e){this._texture&&(this._texture.is2DArray=e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isRGBD",{get:function(){return null!=this._texture&&this._texture._isRGBD},set:function(e){this._texture&&(this._texture._isRGBD=e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"noMipmap",{get:function(){return!1},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"lodGenerationOffset",{get:function(){return this._texture?this._texture._lodGenerationOffset:0},set:function(e){this._texture&&(this._texture._lodGenerationOffset=e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"lodGenerationScale",{get:function(){return this._texture?this._texture._lodGenerationScale:0},set:function(e){this._texture&&(this._texture._lodGenerationScale=e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"linearSpecularLOD",{get:function(){return!!this._texture&&this._texture._linearSpecularLOD},set:function(e){this._texture&&(this._texture._linearSpecularLOD=e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"irradianceTexture",{get:function(){return this._texture?this._texture._irradianceTexture:null},set:function(e){this._texture&&(this._texture._irradianceTexture=e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"uid",{get:function(){return this._uid||(this._uid=h.a.RandomId()),this._uid},enumerable:!0,configurable:!0}),e.prototype.toString=function(){return this.name},e.prototype.getClassName=function(){return"BaseTexture"},Object.defineProperty(e.prototype,"onDispose",{set:function(e){this._onDisposeObserver&&this.onDisposeObservable.remove(this._onDisposeObserver),this._onDisposeObserver=this.onDisposeObservable.add(e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isBlocking",{get:function(){return!0},enumerable:!0,configurable:!0}),e.prototype.getScene=function(){return this._scene},e.prototype.getTextureMatrix=function(){return s.a.IdentityReadOnly},e.prototype.getReflectionTextureMatrix=function(){return s.a.IdentityReadOnly},e.prototype.getInternalTexture=function(){return this._texture},e.prototype.isReadyOrNotBlocking=function(){return!this.isBlocking||this.isReady()},e.prototype.isReady=function(){return 4===this.delayLoadState?(this.delayLoad(),!1):!!this._texture&&this._texture.isReady},e.prototype.getSize=function(){if(this._texture){if(this._texture.width)return this._cachedSize.width=this._texture.width,this._cachedSize.height=this._texture.height,this._cachedSize;if(this._texture._size)return this._cachedSize.width=this._texture._size,this._cachedSize.height=this._texture._size,this._cachedSize}return this._cachedSize},e.prototype.getBaseSize=function(){return this.isReady()&&this._texture?this._texture._size?new l.a(this._texture._size,this._texture._size):new l.a(this._texture.baseWidth,this._texture.baseHeight):l.a.Zero()},e.prototype.updateSamplingMode=function(e){if(this._texture){var t=this.getScene();t&&t.getEngine().updateTextureSamplingMode(e,this._texture)}},e.prototype.scale=function(e){},Object.defineProperty(e.prototype,"canRescale",{get:function(){return!1},enumerable:!0,configurable:!0}),e.prototype._getFromCache=function(e,t,i,r){if(!this._scene)return null;for(var n=this._scene.getEngine().getLoadedTexturesCache(),o=0;o=0&&this._scene.textures.splice(e,1),this._scene.onTextureRemovedObservable.notifyObservers(this)}void 0!==this._texture&&(this.releaseInternalTexture(),this.onDisposeObservable.notifyObservers(this),this.onDisposeObservable.clear())},e.prototype.serialize=function(){if(!this.name)return null;var e=n.a.Serialize(this);return n.a.AppendSerializedAnimations(this,e),e},e.WhenAllReady=function(e,t){var i=e.length;if(0!==i)for(var r,n,o=function(){if((r=e[s]).isReady())0==--i&&t();else if(n=r.onLoadObservable){var o=function(){n.removeCallback(o),0==--i&&t()};n.add(o)}},s=0;s0,t.NUM_MORPH_INFLUENCERS=i.numInfluencers):(t.MORPHTARGETS_UV=!1,t.MORPHTARGETS_TANGENT=!1,t.MORPHTARGETS_NORMAL=!1,t.MORPHTARGETS=!1,t.NUM_MORPH_INFLUENCERS=0)},e.PrepareDefinesForAttributes=function(e,t,i,r,n,o){if(void 0===n&&(n=!1),void 0===o&&(o=!0),!t._areAttributesDirty&&t._needNormals===t._normals&&t._needUVs===t._uvs)return!1;if(t._normals=t._needNormals,t._uvs=t._needUVs,t.NORMAL=t._needNormals&&e.isVerticesDataPresent(s.b.NormalKind),t._needNormals&&e.isVerticesDataPresent(s.b.TangentKind)&&(t.TANGENT=!0),t._needUVs?(t.UV1=e.isVerticesDataPresent(s.b.UVKind),t.UV2=e.isVerticesDataPresent(s.b.UV2Kind)):(t.UV1=!1,t.UV2=!1),i){var a=e.useVertexColors&&e.isVerticesDataPresent(s.b.ColorKind);t.VERTEXCOLOR=a,t.VERTEXALPHA=e.hasVertexAlpha&&a&&o}return r&&this.PrepareDefinesForBones(e,t),n&&this.PrepareDefinesForMorphTargets(e,t),!0},e.PrepareDefinesForMultiview=function(e,t){if(e.activeCamera){var i=t.MULTIVIEW;t.MULTIVIEW=null!==e.activeCamera.outputRenderTarget&&e.activeCamera.outputRenderTarget.getViewCount()>1,t.MULTIVIEW!=i&&t.markAsUnprocessed()}},e.PrepareDefinesForLight=function(e,t,i,r,n,o,s){switch(s.needNormals=!0,void 0===n["LIGHT"+r]&&(s.needRebuild=!0),n["LIGHT"+r]=!0,n["SPOTLIGHT"+r]=!1,n["HEMILIGHT"+r]=!1,n["POINTLIGHT"+r]=!1,n["DIRLIGHT"+r]=!1,i.prepareLightSpecificDefines(n,r),n["LIGHT_FALLOFF_PHYSICAL"+r]=!1,n["LIGHT_FALLOFF_GLTF"+r]=!1,n["LIGHT_FALLOFF_STANDARD"+r]=!1,i.falloffType){case a.a.FALLOFF_GLTF:n["LIGHT_FALLOFF_GLTF"+r]=!0;break;case a.a.FALLOFF_PHYSICAL:n["LIGHT_FALLOFF_PHYSICAL"+r]=!0;break;case a.a.FALLOFF_STANDARD:n["LIGHT_FALLOFF_STANDARD"+r]=!0}if(o&&!i.specular.equalsFloats(0,0,0)&&(s.specularEnabled=!0),n["SHADOW"+r]=!1,n["SHADOWCSM"+r]=!1,n["SHADOWCSMDEBUG"+r]=!1,n["SHADOWCSMNUM_CASCADES"+r]=!1,n["SHADOWCSMUSESHADOWMAXZ"+r]=!1,n["SHADOWCSMNOBLEND"+r]=!1,n["SHADOWCSM_RIGHTHANDED"+r]=!1,n["SHADOWPCF"+r]=!1,n["SHADOWPCSS"+r]=!1,n["SHADOWPOISSON"+r]=!1,n["SHADOWESM"+r]=!1,n["SHADOWCUBE"+r]=!1,n["SHADOWLOWQUALITY"+r]=!1,n["SHADOWMEDIUMQUALITY"+r]=!1,t&&t.receiveShadows&&e.shadowsEnabled&&i.shadowEnabled){var h=i.getShadowGenerator();if(h){var l=h.getShadowMap();l&&l.renderList&&l.renderList.length>0&&(s.shadowEnabled=!0,h.prepareDefines(n,r))}}i.lightmapMode!=a.a.LIGHTMAP_DEFAULT?(s.lightmapMode=!0,n["LIGHTMAPEXCLUDED"+r]=!0,n["LIGHTMAPNOSPECULAR"+r]=i.lightmapMode==a.a.LIGHTMAP_SHADOWSONLY):(n["LIGHTMAPEXCLUDED"+r]=!1,n["LIGHTMAPNOSPECULAR"+r]=!1)},e.PrepareDefinesForLights=function(e,t,i,r,n,o){if(void 0===n&&(n=4),void 0===o&&(o=!1),!i._areLightsDirty)return i._needNormals;var s=0,a={needNormals:!1,needRebuild:!1,lightmapMode:!1,shadowEnabled:!1,specularEnabled:!1};if(e.lightsEnabled&&!o)for(var h=0,l=t.lightSources;h0&&(n=r+o,t.addFallback(n,"LIGHT"+o)),e.SHADOWS||(e["SHADOW"+o]&&t.addFallback(r,"SHADOW"+o),e["SHADOWPCF"+o]&&t.addFallback(r,"SHADOWPCF"+o),e["SHADOWPCSS"+o]&&t.addFallback(r,"SHADOWPCSS"+o),e["SHADOWPOISSON"+o]&&t.addFallback(r,"SHADOWPOISSON"+o),e["SHADOWESM"+o]&&t.addFallback(r,"SHADOWESM"+o));return n++},e.PrepareAttributesForMorphTargetsInfluencers=function(e,t,i){this._TmpMorphInfluencers.NUM_MORPH_INFLUENCERS=i,this.PrepareAttributesForMorphTargets(e,t,this._TmpMorphInfluencers)},e.PrepareAttributesForMorphTargets=function(e,t,i){var n=i.NUM_MORPH_INFLUENCERS;if(n>0&&o.a.LastCreatedEngine)for(var a=o.a.LastCreatedEngine.getCaps().maxVertexAttribs,h=t.morphTargetManager,l=h&&h.supportsNormals&&i.NORMAL,c=h&&h.supportsTangents&&i.TANGENT,u=h&&h.supportsUVs&&i.UV1,f=0;fa&&r.a.Error("Cannot add more vertex attributes for mesh "+t.name)},e.PrepareAttributesForBones=function(e,t,i,r){i.NUM_BONE_INFLUENCERS>0&&(r.addCPUSkinningFallback(0,t),e.push(s.b.MatricesIndicesKind),e.push(s.b.MatricesWeightsKind),i.NUM_BONE_INFLUENCERS>4&&(e.push(s.b.MatricesIndicesExtraKind),e.push(s.b.MatricesWeightsExtraKind)))},e.PrepareAttributesForInstances=function(e,t){t.INSTANCES&&this.PushAttributesForInstances(e)},e.PushAttributesForInstances=function(e){e.push("world0"),e.push("world1"),e.push("world2"),e.push("world3")},e.BindLightProperties=function(e,t,i){e.transferToEffect(t,i+"")},e.BindLight=function(e,t,i,r,n,o){void 0===o&&(o=!1),e._bindLight(t,i,r,n,o)},e.BindLights=function(e,t,i,r,n,o){void 0===n&&(n=4),void 0===o&&(o=!1);for(var s=Math.min(t.lightSources.length,n),a=0;a-1){var r=i.getTransformMatrixTexture(e);t.setTexture("boneSampler",r),t.setFloat("boneTextureWidth",4*(i.bones.length+1))}else{var n=i.getTransformMatrices(e);n&&t.setMatrices("mBones",n)}}},e.BindMorphTargetParameters=function(e,t){var i=e.morphTargetManager;e&&i&&t.setFloatArray("morphTargetInfluences",i.influences)},e.BindLogDepth=function(e,t,i){e.LOGARITHMICDEPTH&&t.setFloat("logarithmicDepthConstant",2/(Math.log(i.activeCamera.maxZ+1)/Math.LN2))},e.BindClipPlane=function(e,t){if(t.clipPlane){var i=t.clipPlane;e.setFloat4("vClipPlane",i.normal.x,i.normal.y,i.normal.z,i.d)}if(t.clipPlane2){i=t.clipPlane2;e.setFloat4("vClipPlane2",i.normal.x,i.normal.y,i.normal.z,i.d)}if(t.clipPlane3){i=t.clipPlane3;e.setFloat4("vClipPlane3",i.normal.x,i.normal.y,i.normal.z,i.d)}if(t.clipPlane4){i=t.clipPlane4;e.setFloat4("vClipPlane4",i.normal.x,i.normal.y,i.normal.z,i.d)}if(t.clipPlane5){i=t.clipPlane5;e.setFloat4("vClipPlane5",i.normal.x,i.normal.y,i.normal.z,i.d)}if(t.clipPlane6){i=t.clipPlane6;e.setFloat4("vClipPlane6",i.normal.x,i.normal.y,i.normal.z,i.d)}},e._TmpMorphInfluencers={NUM_MORPH_INFLUENCERS:0},e._tempFogColor=h.a.Black(),e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return _}));var r=i(1),n=i(3),o=i(28),s=i(13),a=i(4),h=i(0),l=i(34),c=i(12),u=i(10),f=i(8),d=i(53),p=i(51),_=function(e){function t(i,r,n,s){void 0===s&&(s=!0);var l=e.call(this,i,n)||this;return l._position=h.e.Zero(),l.upVector=h.e.Up(),l.orthoLeft=null,l.orthoRight=null,l.orthoBottom=null,l.orthoTop=null,l.fov=.8,l.minZ=1,l.maxZ=1e4,l.inertia=.9,l.mode=t.PERSPECTIVE_CAMERA,l.isIntermediate=!1,l.viewport=new d.a(0,0,1,1),l.layerMask=268435455,l.fovMode=t.FOVMODE_VERTICAL_FIXED,l.cameraRigMode=t.RIG_MODE_NONE,l.customRenderTargets=new Array,l.outputRenderTarget=null,l.onViewMatrixChangedObservable=new a.a,l.onProjectionMatrixChangedObservable=new a.a,l.onAfterCheckInputsObservable=new a.a,l.onRestoreStateObservable=new a.a,l.isRigCamera=!1,l._rigCameras=new Array,l._webvrViewMatrix=h.a.Identity(),l._skipRendering=!1,l._projectionMatrix=new h.a,l._postProcesses=new Array,l._activeMeshes=new o.a(256),l._globalPosition=h.e.Zero(),l._computedViewMatrix=h.a.Identity(),l._doNotComputeProjectionMatrix=!1,l._transformMatrix=h.a.Zero(),l._refreshFrustumPlanes=!0,l._isCamera=!0,l._isLeftCamera=!1,l._isRightCamera=!1,l.getScene().addCamera(l),s&&!l.getScene().activeCamera&&(l.getScene().activeCamera=l),l.position=r,l}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"position",{get:function(){return this._position},set:function(e){this._position=e},enumerable:!0,configurable:!0}),t.prototype.storeState=function(){return this._stateStored=!0,this._storedFov=this.fov,this},t.prototype._restoreStateValues=function(){return!!this._stateStored&&(this.fov=this._storedFov,!0)},t.prototype.restoreState=function(){return!!this._restoreStateValues()&&(this.onRestoreStateObservable.notifyObservers(this),!0)},t.prototype.getClassName=function(){return"Camera"},t.prototype.toString=function(e){var t="Name: "+this.name;if(t+=", type: "+this.getClassName(),this.animations)for(var i=0;i-1?(c.a.Error("You're trying to reuse a post process not defined as reusable."),0):(null==t||t<0?this._postProcesses.push(e):null===this._postProcesses[t]?this._postProcesses[t]=e:this._postProcesses.splice(t,0,e),this._cascadePostProcessesToRigCams(),this._postProcesses.indexOf(e))},t.prototype.detachPostProcess=function(e){var t=this._postProcesses.indexOf(e);-1!==t&&(this._postProcesses[t]=null),this._cascadePostProcessesToRigCams()},t.prototype.getWorldMatrix=function(){return this._isSynchronizedViewMatrix()||this.getViewMatrix(),this._worldMatrix},t.prototype._getViewMatrix=function(){return h.a.Identity()},t.prototype.getViewMatrix=function(e){return!e&&this._isSynchronizedViewMatrix()||(this.updateCache(),this._computedViewMatrix=this._getViewMatrix(),this._currentRenderId=this.getScene().getRenderId(),this._childUpdateId++,this._refreshFrustumPlanes=!0,this._cameraRigParams&&this._cameraRigParams.vrPreViewMatrix&&this._computedViewMatrix.multiplyToRef(this._cameraRigParams.vrPreViewMatrix,this._computedViewMatrix),this.parent&&this.parent.onViewMatrixChangedObservable&&this.parent.onViewMatrixChangedObservable.notifyObservers(this.parent),this.onViewMatrixChangedObservable.notifyObservers(this),this._computedViewMatrix.invertToRef(this._worldMatrix)),this._computedViewMatrix},t.prototype.freezeProjectionMatrix=function(e){this._doNotComputeProjectionMatrix=!0,void 0!==e&&(this._projectionMatrix=e)},t.prototype.unfreezeProjectionMatrix=function(){this._doNotComputeProjectionMatrix=!1},t.prototype.getProjectionMatrix=function(e){if(this._doNotComputeProjectionMatrix||!e&&this._isSynchronizedProjectionMatrix())return this._projectionMatrix;this._cache.mode=this.mode,this._cache.minZ=this.minZ,this._cache.maxZ=this.maxZ,this._refreshFrustumPlanes=!0;var i=this.getEngine(),r=this.getScene();if(this.mode===t.PERSPECTIVE_CAMERA){this._cache.fov=this.fov,this._cache.fovMode=this.fovMode,this._cache.aspectRatio=i.getAspectRatio(this),this.minZ<=0&&(this.minZ=.1);var n=i.useReverseDepthBuffer;(r.useRightHandedSystem?n?h.a.PerspectiveFovReverseRHToRef:h.a.PerspectiveFovRHToRef:n?h.a.PerspectiveFovReverseLHToRef:h.a.PerspectiveFovLHToRef)(this.fov,i.getAspectRatio(this),this.minZ,this.maxZ,this._projectionMatrix,this.fovMode===t.FOVMODE_VERTICAL_FIXED)}else{var o=i.getRenderWidth()/2,s=i.getRenderHeight()/2;r.useRightHandedSystem?h.a.OrthoOffCenterRHToRef(this.orthoLeft||-o,this.orthoRight||o,this.orthoBottom||-s,this.orthoTop||s,this.minZ,this.maxZ,this._projectionMatrix):h.a.OrthoOffCenterLHToRef(this.orthoLeft||-o,this.orthoRight||o,this.orthoBottom||-s,this.orthoTop||s,this.minZ,this.maxZ,this._projectionMatrix),this._cache.orthoLeft=this.orthoLeft,this._cache.orthoRight=this.orthoRight,this._cache.orthoBottom=this.orthoBottom,this._cache.orthoTop=this.orthoTop,this._cache.renderWidth=i.getRenderWidth(),this._cache.renderHeight=i.getRenderHeight()}return this.onProjectionMatrixChangedObservable.notifyObservers(this),this._projectionMatrix},t.prototype.getTransformationMatrix=function(){return this._computedViewMatrix.multiplyToRef(this._projectionMatrix,this._transformMatrix),this._transformMatrix},t.prototype._updateFrustumPlanes=function(){this._refreshFrustumPlanes&&(this.getTransformationMatrix(),this._frustumPlanes?p.a.GetPlanesToRef(this._transformMatrix,this._frustumPlanes):this._frustumPlanes=p.a.GetPlanes(this._transformMatrix),this._refreshFrustumPlanes=!1)},t.prototype.isInFrustum=function(e,t){if(void 0===t&&(t=!1),this._updateFrustumPlanes(),t&&this.rigCameras.length>0){var i=!1;return this.rigCameras.forEach((function(t){t._updateFrustumPlanes(),i=i||e.isInFrustum(t._frustumPlanes)})),i}return e.isInFrustum(this._frustumPlanes)},t.prototype.isCompletelyInFrustum=function(e){return this._updateFrustumPlanes(),e.isCompletelyInFrustum(this._frustumPlanes)},t.prototype.getForwardRay=function(e,t,i){throw void 0===e&&(e=100),f.a.WarnImport("Ray")},t.prototype.dispose=function(i,r){for(void 0===r&&(r=!1),this.onViewMatrixChangedObservable.clear(),this.onProjectionMatrixChangedObservable.clear(),this.onAfterCheckInputsObservable.clear(),this.onRestoreStateObservable.clear(),this.inputs&&this.inputs.clear(),this.getScene().stopAnimation(this),this.getScene().removeCamera(this);this._rigCameras.length>0;){var n=this._rigCameras.pop();n&&n.dispose()}if(this._rigPostProcess)this._rigPostProcess.dispose(this),this._rigPostProcess=null,this._postProcesses=[];else if(this.cameraRigMode!==t.RIG_MODE_NONE)this._rigPostProcess=null,this._postProcesses=[];else for(var o=this._postProcesses.length;--o>=0;){var s=this._postProcesses[o];s&&s.dispose(this)}for(o=this.customRenderTargets.length;--o>=0;)this.customRenderTargets[o].dispose();this.customRenderTargets=[],this._activeMeshes.dispose(),e.prototype.dispose.call(this,i,r)},Object.defineProperty(t.prototype,"isLeftCamera",{get:function(){return this._isLeftCamera},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"isRightCamera",{get:function(){return this._isRightCamera},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"leftCamera",{get:function(){return this._rigCameras.length<1?null:this._rigCameras[0]},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"rightCamera",{get:function(){return this._rigCameras.length<2?null:this._rigCameras[1]},enumerable:!0,configurable:!0}),t.prototype.getLeftTarget=function(){return this._rigCameras.length<1?null:this._rigCameras[0].getTarget()},t.prototype.getRightTarget=function(){return this._rigCameras.length<2?null:this._rigCameras[1].getTarget()},t.prototype.setCameraRigMode=function(e,i){if(this.cameraRigMode!==e){for(;this._rigCameras.length>0;){var r=this._rigCameras.pop();r&&r.dispose()}if(this.cameraRigMode=e,this._cameraRigParams={},this._cameraRigParams.interaxialDistance=i.interaxialDistance||.0637,this._cameraRigParams.stereoHalfAngle=s.b.ToRadians(this._cameraRigParams.interaxialDistance/.0637),this.cameraRigMode!==t.RIG_MODE_NONE){var n=this.createRigCamera(this.name+"_L",0);n&&(n._isLeftCamera=!0);var o=this.createRigCamera(this.name+"_R",1);o&&(o._isRightCamera=!0),n&&o&&(this._rigCameras.push(n),this._rigCameras.push(o))}switch(this.cameraRigMode){case t.RIG_MODE_STEREOSCOPIC_ANAGLYPH:t._setStereoscopicAnaglyphRigMode(this);break;case t.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL:case t.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED:case t.RIG_MODE_STEREOSCOPIC_OVERUNDER:case t.RIG_MODE_STEREOSCOPIC_INTERLACED:t._setStereoscopicRigMode(this);break;case t.RIG_MODE_VR:t._setVRRigMode(this,i);break;case t.RIG_MODE_WEBVR:t._setWebVRRigMode(this,i)}this._cascadePostProcessesToRigCams(),this.update()}},t._setStereoscopicRigMode=function(e){throw"Import Cameras/RigModes/stereoscopicRigMode before using stereoscopic rig mode"},t._setStereoscopicAnaglyphRigMode=function(e){throw"Import Cameras/RigModes/stereoscopicAnaglyphRigMode before using stereoscopic anaglyph rig mode"},t._setVRRigMode=function(e,t){throw"Import Cameras/RigModes/vrRigMode before using VR rig mode"},t._setWebVRRigMode=function(e,t){throw"Import Cameras/RigModes/WebVRRigMode before using Web VR rig mode"},t.prototype._getVRProjectionMatrix=function(){return h.a.PerspectiveFovLHToRef(this._cameraRigParams.vrMetrics.aspectRatioFov,this._cameraRigParams.vrMetrics.aspectRatio,this.minZ,this.maxZ,this._cameraRigParams.vrWorkMatrix),this._cameraRigParams.vrWorkMatrix.multiplyToRef(this._cameraRigParams.vrHMatrix,this._projectionMatrix),this._projectionMatrix},t.prototype._updateCameraRotationMatrix=function(){},t.prototype._updateWebVRCameraRotationMatrix=function(){},t.prototype._getWebVRProjectionMatrix=function(){return h.a.Identity()},t.prototype._getWebVRViewMatrix=function(){return h.a.Identity()},t.prototype.setCameraRigParameter=function(e,t){this._cameraRigParams||(this._cameraRigParams={}),this._cameraRigParams[e]=t,"interaxialDistance"===e&&(this._cameraRigParams.stereoHalfAngle=s.b.ToRadians(t/.0637))},t.prototype.createRigCamera=function(e,t){return null},t.prototype._updateRigCameras=function(){for(var e=0;e1)for(var h=0;h1&&a.renderbufferStorageMultisample?a.renderbufferStorageMultisample(a.RENDERBUFFER,i,n,e,t):a.renderbufferStorage(a.RENDERBUFFER,r,e,t),a.framebufferRenderbuffer(a.FRAMEBUFFER,s,a.RENDERBUFFER,h),a.bindRenderbuffer(a.RENDERBUFFER,null),h},this._boundUniforms={};var c=null;if(t){if(r=r||{},t.getContext){if(c=t,this._renderingCanvas=c,null!=i&&(r.antialias=i),void 0===r.deterministicLockstep&&(r.deterministicLockstep=!1),void 0===r.lockstepMaxSteps&&(r.lockstepMaxSteps=4),void 0===r.timeStep&&(r.timeStep=1/60),void 0===r.preserveDrawingBuffer&&(r.preserveDrawingBuffer=!1),void 0===r.audioEngine&&(r.audioEngine=!0),void 0===r.stencil&&(r.stencil=!0),!1===r.premultipliedAlpha&&(this.premultipliedAlpha=!1),this._doNotHandleContextLost=!!r.doNotHandleContextLost,navigator&&navigator.userAgent)for(var p=navigator.userAgent,_=0,g=e.ExceptionList;_0)if(parseInt(E[E.length-1])>=T)continue}for(var M=0,A=y;M1&&(this._shaderProcessor=new d),this._badOS=/iPad/i.test(navigator.userAgent)||/iPhone/i.test(navigator.userAgent),this._badDesktopOS=/^((?!chrome|android).)*safari/i.test(navigator.userAgent),this._creationOptions=r,console.log("Babylon.js v"+e.Version+" - "+this.description)}}return Object.defineProperty(e,"NpmPackage",{get:function(){return"babylonjs@4.1.0"},enumerable:!0,configurable:!0}),Object.defineProperty(e,"Version",{get:function(){return"4.1.0"},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"description",{get:function(){var e="WebGL"+this.webGLVersion;return this._caps.parallelShaderCompile&&(e+=" - Parallel shader compilation"),e},enumerable:!0,configurable:!0}),Object.defineProperty(e,"ShadersRepository",{get:function(){return n.a.ShadersRepository},set:function(e){n.a.ShadersRepository=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"supportsUniformBuffers",{get:function(){return this.webGLVersion>1&&!this.disableUniformBuffers},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"_shouldUseHighPrecisionShader",{get:function(){return!(!this._caps.highPrecisionShaderSupported||!this._highPrecisionShadersAllowed)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"needPOTTextures",{get:function(){return this._webGLVersion<2||this.forcePOTTextures},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"doNotHandleContextLost",{get:function(){return this._doNotHandleContextLost},set:function(e){this._doNotHandleContextLost=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"_supportsHardwareTextureRescaling",{get:function(){return!1},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"framebufferDimensionsObject",{set:function(e){this._framebufferDimensionsObject=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"texturesSupported",{get:function(){return this._texturesSupported},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"textureFormatInUse",{get:function(){return this._textureFormatInUse},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"currentViewport",{get:function(){return this._cachedViewport},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"emptyTexture",{get:function(){return this._emptyTexture||(this._emptyTexture=this.createRawTexture(new Uint8Array(4),1,1,5,!1,!1,1)),this._emptyTexture},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"emptyTexture3D",{get:function(){return this._emptyTexture3D||(this._emptyTexture3D=this.createRawTexture3D(new Uint8Array(4),1,1,1,5,!1,!1,1)),this._emptyTexture3D},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"emptyTexture2DArray",{get:function(){return this._emptyTexture2DArray||(this._emptyTexture2DArray=this.createRawTexture2DArray(new Uint8Array(4),1,1,1,5,!1,!1,1)),this._emptyTexture2DArray},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"emptyCubeTexture",{get:function(){if(!this._emptyCubeTexture){var e=new Uint8Array(4),t=[e,e,e,e,e,e];this._emptyCubeTexture=this.createRawCubeTexture(t,1,5,0,!1,!1,1)}return this._emptyCubeTexture},enumerable:!0,configurable:!0}),e.prototype._rebuildInternalTextures=function(){for(var e=0,t=this._internalTexturesCache.slice();e1?this._gl.getParameter(this._gl.MAX_SAMPLES):1,maxCubemapTextureSize:this._gl.getParameter(this._gl.MAX_CUBE_MAP_TEXTURE_SIZE),maxRenderTextureSize:this._gl.getParameter(this._gl.MAX_RENDERBUFFER_SIZE),maxVertexAttribs:this._gl.getParameter(this._gl.MAX_VERTEX_ATTRIBS),maxVaryingVectors:this._gl.getParameter(this._gl.MAX_VARYING_VECTORS),maxFragmentUniformVectors:this._gl.getParameter(this._gl.MAX_FRAGMENT_UNIFORM_VECTORS),maxVertexUniformVectors:this._gl.getParameter(this._gl.MAX_VERTEX_UNIFORM_VECTORS),parallelShaderCompile:this._gl.getExtension("KHR_parallel_shader_compile"),standardDerivatives:this._webGLVersion>1||null!==this._gl.getExtension("OES_standard_derivatives"),maxAnisotropy:1,astc:this._gl.getExtension("WEBGL_compressed_texture_astc")||this._gl.getExtension("WEBKIT_WEBGL_compressed_texture_astc"),s3tc:this._gl.getExtension("WEBGL_compressed_texture_s3tc")||this._gl.getExtension("WEBKIT_WEBGL_compressed_texture_s3tc"),pvrtc:this._gl.getExtension("WEBGL_compressed_texture_pvrtc")||this._gl.getExtension("WEBKIT_WEBGL_compressed_texture_pvrtc"),etc1:this._gl.getExtension("WEBGL_compressed_texture_etc1")||this._gl.getExtension("WEBKIT_WEBGL_compressed_texture_etc1"),etc2:this._gl.getExtension("WEBGL_compressed_texture_etc")||this._gl.getExtension("WEBKIT_WEBGL_compressed_texture_etc")||this._gl.getExtension("WEBGL_compressed_texture_es3_0"),textureAnisotropicFilterExtension:this._gl.getExtension("EXT_texture_filter_anisotropic")||this._gl.getExtension("WEBKIT_EXT_texture_filter_anisotropic")||this._gl.getExtension("MOZ_EXT_texture_filter_anisotropic"),uintIndices:this._webGLVersion>1||null!==this._gl.getExtension("OES_element_index_uint"),fragmentDepthSupported:this._webGLVersion>1||null!==this._gl.getExtension("EXT_frag_depth"),highPrecisionShaderSupported:!1,timerQuery:this._gl.getExtension("EXT_disjoint_timer_query_webgl2")||this._gl.getExtension("EXT_disjoint_timer_query"),canUseTimestampForTimerQuery:!1,drawBuffersExtension:!1,maxMSAASamples:1,colorBufferFloat:this._webGLVersion>1&&this._gl.getExtension("EXT_color_buffer_float"),textureFloat:!!(this._webGLVersion>1||this._gl.getExtension("OES_texture_float")),textureHalfFloat:!!(this._webGLVersion>1||this._gl.getExtension("OES_texture_half_float")),textureHalfFloatRender:!1,textureFloatLinearFiltering:!1,textureFloatRender:!1,textureHalfFloatLinearFiltering:!1,vertexArrayObject:!1,instancedArrays:!1,textureLOD:!!(this._webGLVersion>1||this._gl.getExtension("EXT_shader_texture_lod")),blendMinMax:!1,multiview:this._gl.getExtension("OVR_multiview2"),oculusMultiview:this._gl.getExtension("OCULUS_multiview"),depthTextureExtension:!1},this._glVersion=this._gl.getParameter(this._gl.VERSION);var e=this._gl.getExtension("WEBGL_debug_renderer_info");if(null!=e&&(this._glRenderer=this._gl.getParameter(e.UNMASKED_RENDERER_WEBGL),this._glVendor=this._gl.getParameter(e.UNMASKED_VENDOR_WEBGL)),this._glVendor||(this._glVendor="Unknown vendor"),this._glRenderer||(this._glRenderer="Unknown renderer"),this._gl.HALF_FLOAT_OES=36193,34842!==this._gl.RGBA16F&&(this._gl.RGBA16F=34842),34836!==this._gl.RGBA32F&&(this._gl.RGBA32F=34836),35056!==this._gl.DEPTH24_STENCIL8&&(this._gl.DEPTH24_STENCIL8=35056),this._caps.timerQuery&&(1===this._webGLVersion&&(this._gl.getQuery=this._caps.timerQuery.getQueryEXT.bind(this._caps.timerQuery)),this._caps.canUseTimestampForTimerQuery=this._gl.getQuery(this._caps.timerQuery.TIMESTAMP_EXT,this._caps.timerQuery.QUERY_COUNTER_BITS_EXT)>0),this._caps.maxAnisotropy=this._caps.textureAnisotropicFilterExtension?this._gl.getParameter(this._caps.textureAnisotropicFilterExtension.MAX_TEXTURE_MAX_ANISOTROPY_EXT):0,this._caps.textureFloatLinearFiltering=!(!this._caps.textureFloat||!this._gl.getExtension("OES_texture_float_linear")),this._caps.textureFloatRender=!(!this._caps.textureFloat||!this._canRenderToFloatFramebuffer()),this._caps.textureHalfFloatLinearFiltering=!!(this._webGLVersion>1||this._caps.textureHalfFloat&&this._gl.getExtension("OES_texture_half_float_linear")),this._webGLVersion>1&&(this._gl.HALF_FLOAT_OES=5131),this._caps.textureHalfFloatRender=this._caps.textureHalfFloat&&this._canRenderToHalfFloatFramebuffer(),this._webGLVersion>1)this._caps.drawBuffersExtension=!0,this._caps.maxMSAASamples=this._gl.getParameter(this._gl.MAX_SAMPLES);else{var t=this._gl.getExtension("WEBGL_draw_buffers");if(null!==t){this._caps.drawBuffersExtension=!0,this._gl.drawBuffers=t.drawBuffersWEBGL.bind(t),this._gl.DRAW_FRAMEBUFFER=this._gl.FRAMEBUFFER;for(var i=0;i<16;i++)this._gl["COLOR_ATTACHMENT"+i+"_WEBGL"]=t["COLOR_ATTACHMENT"+i+"_WEBGL"]}}if(this._webGLVersion>1)this._caps.depthTextureExtension=!0;else{var r=this._gl.getExtension("WEBGL_depth_texture");null!=r&&(this._caps.depthTextureExtension=!0,this._gl.UNSIGNED_INT_24_8=r.UNSIGNED_INT_24_8_WEBGL)}if(this.disableVertexArrayObjects)this._caps.vertexArrayObject=!1;else if(this._webGLVersion>1)this._caps.vertexArrayObject=!0;else{var n=this._gl.getExtension("OES_vertex_array_object");null!=n&&(this._caps.vertexArrayObject=!0,this._gl.createVertexArray=n.createVertexArrayOES.bind(n),this._gl.bindVertexArray=n.bindVertexArrayOES.bind(n),this._gl.deleteVertexArray=n.deleteVertexArrayOES.bind(n))}if(this._webGLVersion>1)this._caps.instancedArrays=!0;else{var o=this._gl.getExtension("ANGLE_instanced_arrays");null!=o?(this._caps.instancedArrays=!0,this._gl.drawArraysInstanced=o.drawArraysInstancedANGLE.bind(o),this._gl.drawElementsInstanced=o.drawElementsInstancedANGLE.bind(o),this._gl.vertexAttribDivisor=o.vertexAttribDivisorANGLE.bind(o)):this._caps.instancedArrays=!1}if(this._caps.astc&&this.texturesSupported.push("-astc.ktx"),this._caps.s3tc&&this.texturesSupported.push("-dxt.ktx"),this._caps.pvrtc&&this.texturesSupported.push("-pvrtc.ktx"),this._caps.etc2&&this.texturesSupported.push("-etc2.ktx"),this._caps.etc1&&this.texturesSupported.push("-etc1.ktx"),this._gl.getShaderPrecisionFormat){var s=this._gl.getShaderPrecisionFormat(this._gl.VERTEX_SHADER,this._gl.HIGH_FLOAT),a=this._gl.getShaderPrecisionFormat(this._gl.FRAGMENT_SHADER,this._gl.HIGH_FLOAT);s&&a&&(this._caps.highPrecisionShaderSupported=0!==s.precision&&0!==a.precision)}if(this._webGLVersion>1)this._caps.blendMinMax=!0;else{var h=this._gl.getExtension("EXT_blend_minmax");null!=h&&(this._caps.blendMinMax=!0,this._gl.MAX=h.MAX_EXT,this._gl.MIN=h.MIN_EXT)}this._depthCullingState.depthTest=!0,this._depthCullingState.depthFunc=this._gl.LEQUAL,this._depthCullingState.depthMask=!0,this._maxSimultaneousTextures=this._caps.maxCombinedTexturesImageUnits;for(var l=0;l=0&&this._activeRenderLoops.splice(t,1)}else this._activeRenderLoops=[]},e.prototype._renderLoop=function(){if(!this._contextWasLost){var e=!0;if(!this.renderEvenInBackground&&this._windowIsBackground&&(e=!1),e){this.beginFrame();for(var t=0;t0?this._frameHandler=this._queueNewFrame(this._boundRenderFunction,this.getHostWindow()):this._renderingQueueLaunched=!1},e.prototype.getRenderingCanvas=function(){return this._renderingCanvas},e.prototype.getHostWindow=function(){return f.a.IsWindowObjectExist()?this._renderingCanvas&&this._renderingCanvas.ownerDocument&&this._renderingCanvas.ownerDocument.defaultView?this._renderingCanvas.ownerDocument.defaultView:window:null},e.prototype.getRenderWidth=function(e){return void 0===e&&(e=!1),!e&&this._currentRenderTarget?this._currentRenderTarget.width:this._framebufferDimensionsObject?this._framebufferDimensionsObject.framebufferWidth:this._gl.drawingBufferWidth},e.prototype.getRenderHeight=function(e){return void 0===e&&(e=!1),!e&&this._currentRenderTarget?this._currentRenderTarget.height:this._framebufferDimensionsObject?this._framebufferDimensionsObject.framebufferHeight:this._gl.drawingBufferHeight},e.prototype._queueNewFrame=function(t,i){return e.QueueNewFrame(t,i)},e.prototype.runRenderLoop=function(e){-1===this._activeRenderLoops.indexOf(e)&&(this._activeRenderLoops.push(e),this._renderingQueueLaunched||(this._renderingQueueLaunched=!0,this._boundRenderFunction=this._renderLoop.bind(this),this._frameHandler=this._queueNewFrame(this._boundRenderFunction,this.getHostWindow())))},e.prototype.clear=function(e,t,i,r){void 0===r&&(r=!1),this.applyStates();var n=0;t&&e&&(this._gl.clearColor(e.r,e.g,e.b,void 0!==e.a?e.a:1),n|=this._gl.COLOR_BUFFER_BIT),i&&(this.useReverseDepthBuffer?(this._depthCullingState.depthFunc=this._gl.GREATER,this._gl.clearDepth(0)):this._gl.clearDepth(1),n|=this._gl.DEPTH_BUFFER_BIT),r&&(this._gl.clearStencil(0),n|=this._gl.STENCIL_BUFFER_BIT),this._gl.clear(n)},e.prototype._viewport=function(e,t,i,r){e===this._viewportCached.x&&t===this._viewportCached.y&&i===this._viewportCached.z&&r===this._viewportCached.w||(this._viewportCached.x=e,this._viewportCached.y=t,this._viewportCached.z=i,this._viewportCached.w=r,this._gl.viewport(e,t,i,r))},e.prototype.setViewport=function(e,t,i){var r=t||this.getRenderWidth(),n=i||this.getRenderHeight(),o=e.x||0,s=e.y||0;this._cachedViewport=e,this._viewport(o*r,s*n,r*e.width,n*e.height)},e.prototype.beginFrame=function(){},e.prototype.endFrame=function(){this._badOS&&this.flushFramebuffer()},e.prototype.resize=function(){var e,t;f.a.IsWindowObjectExist()?(e=this._renderingCanvas?this._renderingCanvas.clientWidth:window.innerWidth,t=this._renderingCanvas?this._renderingCanvas.clientHeight:window.innerHeight):(e=this._renderingCanvas?this._renderingCanvas.width:100,t=this._renderingCanvas?this._renderingCanvas.height:100),this.setSize(e/this._hardwareScalingLevel,t/this._hardwareScalingLevel)},e.prototype.setSize=function(e,t){this._renderingCanvas&&(e|=0,t|=0,this._renderingCanvas.width===e&&this._renderingCanvas.height===t||(this._renderingCanvas.width=e,this._renderingCanvas.height=t))},e.prototype.bindFramebuffer=function(e,t,i,r,n,o,s){void 0===t&&(t=0),void 0===o&&(o=0),void 0===s&&(s=0),this._currentRenderTarget&&this.unBindFramebuffer(this._currentRenderTarget),this._currentRenderTarget=e,this._bindUnboundFramebuffer(e._MSAAFramebuffer?e._MSAAFramebuffer:e._framebuffer);var a=this._gl;e.is2DArray?a.framebufferTextureLayer(a.FRAMEBUFFER,a.COLOR_ATTACHMENT0,e._webGLTexture,o,s):e.isCube&&a.framebufferTexture2D(a.FRAMEBUFFER,a.COLOR_ATTACHMENT0,a.TEXTURE_CUBE_MAP_POSITIVE_X+t,e._webGLTexture,o);var h=e._depthStencilTexture;if(h){var l=h._generateStencilBuffer?a.DEPTH_STENCIL_ATTACHMENT:a.DEPTH_ATTACHMENT;e.is2DArray?a.framebufferTextureLayer(a.FRAMEBUFFER,l,h._webGLTexture,o,s):e.isCube?a.framebufferTexture2D(a.FRAMEBUFFER,l,a.TEXTURE_CUBE_MAP_POSITIVE_X+t,h._webGLTexture,o):a.framebufferTexture2D(a.FRAMEBUFFER,l,a.TEXTURE_2D,h._webGLTexture,o)}this._cachedViewport&&!n?this.setViewport(this._cachedViewport,i,r):(i||(i=e.width,o&&(i/=Math.pow(2,o))),r||(r=e.height,o&&(r/=Math.pow(2,o))),this._viewport(0,0,i,r)),this.wipeCaches()},e.prototype._bindUnboundFramebuffer=function(e){this._currentFramebuffer!==e&&(this._gl.bindFramebuffer(this._gl.FRAMEBUFFER,e),this._currentFramebuffer=e)},e.prototype.unBindFramebuffer=function(e,t,i){void 0===t&&(t=!1),this._currentRenderTarget=null;var r=this._gl;e._MSAAFramebuffer&&(r.bindFramebuffer(r.READ_FRAMEBUFFER,e._MSAAFramebuffer),r.bindFramebuffer(r.DRAW_FRAMEBUFFER,e._framebuffer),r.blitFramebuffer(0,0,e.width,e.height,0,0,e.width,e.height,r.COLOR_BUFFER_BIT,r.NEAREST)),!e.generateMipMaps||t||e.isCube||(this._bindTextureDirectly(r.TEXTURE_2D,e,!0),r.generateMipmap(r.TEXTURE_2D),this._bindTextureDirectly(r.TEXTURE_2D,null)),i&&(e._MSAAFramebuffer&&this._bindUnboundFramebuffer(e._framebuffer),i()),this._bindUnboundFramebuffer(null)},e.prototype.flushFramebuffer=function(){this._gl.flush()},e.prototype.restoreDefaultFramebuffer=function(){this._currentRenderTarget?this.unBindFramebuffer(this._currentRenderTarget):this._bindUnboundFramebuffer(null),this._cachedViewport&&this.setViewport(this._cachedViewport),this.wipeCaches()},e.prototype._resetVertexBufferBinding=function(){this.bindArrayBuffer(null),this._cachedVertexBuffers=null},e.prototype.createVertexBuffer=function(e){return this._createVertexBuffer(e,this._gl.STATIC_DRAW)},e.prototype._createVertexBuffer=function(e,t){var i=this._gl.createBuffer();if(!i)throw new Error("Unable to create vertex buffer");var r=new p.a(i);return this.bindArrayBuffer(r),e instanceof Array?this._gl.bufferData(this._gl.ARRAY_BUFFER,new Float32Array(e),this._gl.STATIC_DRAW):this._gl.bufferData(this._gl.ARRAY_BUFFER,e,this._gl.STATIC_DRAW),this._resetVertexBufferBinding(),r.references=1,r},e.prototype.createDynamicVertexBuffer=function(e){return this._createVertexBuffer(e,this._gl.DYNAMIC_DRAW)},e.prototype._resetIndexBufferBinding=function(){this.bindIndexBuffer(null),this._cachedIndexBuffer=null},e.prototype.createIndexBuffer=function(e,t){var i=this._gl.createBuffer(),r=new p.a(i);if(!i)throw new Error("Unable to create index buffer");this.bindIndexBuffer(r);var n=this._normalizeIndexData(e);return this._gl.bufferData(this._gl.ELEMENT_ARRAY_BUFFER,n,t?this._gl.DYNAMIC_DRAW:this._gl.STATIC_DRAW),this._resetIndexBufferBinding(),r.references=1,r.is32Bits=4===n.BYTES_PER_ELEMENT,r},e.prototype._normalizeIndexData=function(e){if(e instanceof Uint16Array)return e;if(this._caps.uintIndices){if(e instanceof Uint32Array)return e;for(var t=0;t=65535)return new Uint32Array(e);return new Uint16Array(e)}return new Uint16Array(e)},e.prototype.bindArrayBuffer=function(e){this._vaoRecordInProgress||this._unbindVertexArrayObject(),this.bindBuffer(e,this._gl.ARRAY_BUFFER)},e.prototype.bindUniformBlock=function(e,t,i){var r=e.program,n=this._gl.getUniformBlockIndex(r,t);this._gl.uniformBlockBinding(r,n,i)},e.prototype.bindIndexBuffer=function(e){this._vaoRecordInProgress||this._unbindVertexArrayObject(),this.bindBuffer(e,this._gl.ELEMENT_ARRAY_BUFFER)},e.prototype.bindBuffer=function(e,t){(this._vaoRecordInProgress||this._currentBoundBuffer[t]!==e)&&(this._gl.bindBuffer(t,e?e.underlyingResource:null),this._currentBoundBuffer[t]=e)},e.prototype.updateArrayBuffer=function(e){this._gl.bufferSubData(this._gl.ARRAY_BUFFER,0,e)},e.prototype._vertexAttribPointer=function(e,t,i,r,n,o,s){var a=this._currentBufferPointers[t],h=!1;a.active?(a.buffer!==e&&(a.buffer=e,h=!0),a.size!==i&&(a.size=i,h=!0),a.type!==r&&(a.type=r,h=!0),a.normalized!==n&&(a.normalized=n,h=!0),a.stride!==o&&(a.stride=o,h=!0),a.offset!==s&&(a.offset=s,h=!0)):(h=!0,a.active=!0,a.index=t,a.size=i,a.type=r,a.normalized=n,a.stride=o,a.offset=s,a.buffer=e),(h||this._vaoRecordInProgress)&&(this.bindArrayBuffer(e),this._gl.vertexAttribPointer(t,i,r,n,o,s))},e.prototype._bindIndexBufferWithCache=function(e){null!=e&&this._cachedIndexBuffer!==e&&(this._cachedIndexBuffer=e,this.bindIndexBuffer(e),this._uintIndicesCurrentlySet=e.is32Bits)},e.prototype._bindVertexBuffersAttributes=function(e,t){var i=t.getAttributesNames();this._vaoRecordInProgress||this._unbindVertexArrayObject(),this.unbindAllAttributes();for(var r=0;r=0){var o=e[i[r]];if(!o)continue;this._gl.enableVertexAttribArray(n),this._vaoRecordInProgress||(this._vertexAttribArraysEnabled[n]=!0);var s=o.getBuffer();s&&(this._vertexAttribPointer(s,n,o.getSize(),o.type,o.normalized,o.byteStride,o.byteOffset),o.getIsInstanced()&&(this._gl.vertexAttribDivisor(n,o.getInstanceDivisor()),this._vaoRecordInProgress||(this._currentInstanceLocations.push(n),this._currentInstanceBuffers.push(s))))}}},e.prototype.recordVertexArrayObject=function(e,t,i){var r=this._gl.createVertexArray();return this._vaoRecordInProgress=!0,this._gl.bindVertexArray(r),this._mustWipeVertexAttributes=!0,this._bindVertexBuffersAttributes(e,i),this.bindIndexBuffer(t),this._vaoRecordInProgress=!1,this._gl.bindVertexArray(null),r},e.prototype.bindVertexArrayObject=function(e,t){this._cachedVertexArrayObject!==e&&(this._cachedVertexArrayObject=e,this._gl.bindVertexArray(e),this._cachedVertexBuffers=null,this._cachedIndexBuffer=null,this._uintIndicesCurrentlySet=null!=t&&t.is32Bits,this._mustWipeVertexAttributes=!0)},e.prototype.bindBuffersDirectly=function(e,t,i,r,n){if(this._cachedVertexBuffers!==e||this._cachedEffectForVertexBuffers!==n){this._cachedVertexBuffers=e,this._cachedEffectForVertexBuffers=n;var o=n.getAttributesCount();this._unbindVertexArrayObject(),this.unbindAllAttributes();for(var s=0,a=0;a=0&&(this._gl.enableVertexAttribArray(h),this._vertexAttribArraysEnabled[h]=!0,this._vertexAttribPointer(e,h,i[a],this._gl.FLOAT,!1,r,s)),s+=4*i[a]}}this._bindIndexBufferWithCache(t)},e.prototype._unbindVertexArrayObject=function(){this._cachedVertexArrayObject&&(this._cachedVertexArrayObject=null,this._gl.bindVertexArray(null))},e.prototype.bindBuffers=function(e,t,i){this._cachedVertexBuffers===e&&this._cachedEffectForVertexBuffers===i||(this._cachedVertexBuffers=e,this._cachedEffectForVertexBuffers=i,this._bindVertexBuffersAttributes(e,i)),this._bindIndexBufferWithCache(t)},e.prototype.unbindInstanceAttributes=function(){for(var e,t=0,i=this._currentInstanceLocations.length;t1?"#version 300 es\n#define WEBGL2 \n":"",a=this._compileShader(t,"vertex",r,s),h=this._compileShader(i,"fragment",r,s);return this._createShaderProgram(e,a,h,n,o)},e.prototype.createPipelineContext=function(){var e=new _;return e.engine=this,this._caps.parallelShaderCompile&&(e.isParallelCompiled=!0),e},e.prototype._createShaderProgram=function(e,t,i,r,n){void 0===n&&(n=null);var o=r.createProgram();if(e.program=o,!o)throw new Error("Unable to create program");return r.attachShader(o,t),r.attachShader(o,i),r.linkProgram(o),e.context=r,e.vertexShader=t,e.fragmentShader=i,e.isParallelCompiled||this._finalizePipelineContext(e),o},e.prototype._finalizePipelineContext=function(e){var t=e.context,i=e.vertexShader,r=e.fragmentShader,n=e.program;if(!t.getProgramParameter(n,t.LINK_STATUS)){var o,s;if(!this._gl.getShaderParameter(i,this._gl.COMPILE_STATUS))if(o=this._gl.getShaderInfoLog(i))throw e.vertexCompilationError=o,new Error("VERTEX SHADER "+o);if(!this._gl.getShaderParameter(r,this._gl.COMPILE_STATUS))if(o=this._gl.getShaderInfoLog(r))throw e.fragmentCompilationError=o,new Error("FRAGMENT SHADER "+o);if(s=t.getProgramInfoLog(n))throw e.programLinkError=s,new Error(s)}if(this.validateShaderPrograms&&(t.validateProgram(n),!t.getProgramParameter(n,t.VALIDATE_STATUS)&&(s=t.getProgramInfoLog(n))))throw e.programValidationError=s,new Error(s);t.deleteShader(i),t.deleteShader(r),e.vertexShader=void 0,e.fragmentShader=void 0,e.onCompiled&&(e.onCompiled(),e.onCompiled=void 0)},e.prototype._preparePipelineContext=function(e,t,i,r,n,o,s){var a=e;a.program=r?this.createRawShaderProgram(a,t,i,void 0,s):this.createShaderProgram(a,t,i,o,void 0,s),a.program.__SPECTOR_rebuildProgram=n},e.prototype._isRenderingStateCompiled=function(e){var t=e;return!!this._gl.getProgramParameter(t.program,this._caps.parallelShaderCompile.COMPLETION_STATUS_KHR)&&(this._finalizePipelineContext(t),!0)},e.prototype._executeWhenRenderingStateIsCompiled=function(e,t){var i=e;if(i.isParallelCompiled){var r=i.onCompiled;i.onCompiled=r?function(){r(),t()}:t}else t()},e.prototype.getUniforms=function(e,t){for(var i=new Array,r=e,n=0;n-1?g.substring(x).toLowerCase():""),E=null,M=0,A=e._TextureLoaders;Mh||e.height>h||!_._supportsHardwareTextureRescaling)return _._prepareWorkingCanvas(),!(!_._workingCanvas||!_._workingContext)&&(_._workingCanvas.width=t,_._workingCanvas.height=i,_._workingContext.drawImage(e,0,0,e.width,e.height,0,0,t,i),n.texImage2D(n.TEXTURE_2D,0,a,a,n.UNSIGNED_BYTE,_._workingCanvas),y.width=t,y.height=i,!1);var l=new c.a(_,c.b.Temp);return _._bindTextureDirectly(n.TEXTURE_2D,l,!0),n.texImage2D(n.TEXTURE_2D,0,a,a,n.UNSIGNED_BYTE,e),_._rescaleTexture(l,y,o,a,(function(){_._releaseTexture(l),_._bindTextureDirectly(n.TEXTURE_2D,y,!0),r()})),!0}),s)};!m||v?l&&(l.decoding||l.close)?R(l):e._FileToolsLoadImage(g,R,S,o?o.offlineProvider:null,p):"string"==typeof l||l instanceof ArrayBuffer||ArrayBuffer.isView(l)||l instanceof Blob?e._FileToolsLoadImage(l,R,S,o?o.offlineProvider:null,p):l&&R(l)}return y},e._FileToolsLoadImage=function(e,t,i,r,n){throw o.a.WarnImport("FileTools")},e.prototype._rescaleTexture=function(e,t,i,r,n){},e.prototype.createRawTexture=function(e,t,i,r,n,s,a,h,l){throw void 0===h&&(h=null),void 0===l&&(l=0),o.a.WarnImport("Engine.RawTexture")},e.prototype.createRawCubeTexture=function(e,t,i,r,n,s,a,h){throw void 0===h&&(h=null),o.a.WarnImport("Engine.RawTexture")},e.prototype.createRawTexture3D=function(e,t,i,r,n,s,a,h,l,c){throw void 0===l&&(l=null),void 0===c&&(c=0),o.a.WarnImport("Engine.RawTexture")},e.prototype.createRawTexture2DArray=function(e,t,i,r,n,s,a,h,l,c){throw void 0===l&&(l=null),void 0===c&&(c=0),o.a.WarnImport("Engine.RawTexture")},e.prototype._unpackFlipY=function(e){this._unpackFlipYCached!==e&&(this._gl.pixelStorei(this._gl.UNPACK_FLIP_Y_WEBGL,e?1:0),this.enableUnpackFlipYCached&&(this._unpackFlipYCached=e))},e.prototype._getUnpackAlignement=function(){return this._gl.getParameter(this._gl.UNPACK_ALIGNMENT)},e.prototype._getTextureTarget=function(e){return e.isCube?this._gl.TEXTURE_CUBE_MAP:e.is3D?this._gl.TEXTURE_3D:e.is2DArray||e.isMultiview?this._gl.TEXTURE_2D_ARRAY:this._gl.TEXTURE_2D},e.prototype.updateTextureSamplingMode=function(e,t,i){void 0===i&&(i=!1);var r=this._getTextureTarget(t),n=this._getSamplingParameters(e,t.generateMipMaps||i);this._setTextureParameterInteger(r,this._gl.TEXTURE_MAG_FILTER,n.mag,t),this._setTextureParameterInteger(r,this._gl.TEXTURE_MIN_FILTER,n.min),i&&(t.generateMipMaps=!0,this._gl.generateMipmap(r)),this._bindTextureDirectly(r,null),t.samplingMode=e},e.prototype.updateTextureWrappingMode=function(e,t,i,r){void 0===i&&(i=null),void 0===r&&(r=null);var n=this._getTextureTarget(e);null!==t&&(this._setTextureParameterInteger(n,this._gl.TEXTURE_WRAP_S,this._getTextureWrapMode(t),e),e._cachedWrapU=t),null!==i&&(this._setTextureParameterInteger(n,this._gl.TEXTURE_WRAP_T,this._getTextureWrapMode(i),e),e._cachedWrapV=i),(e.is2DArray||e.is3D)&&null!==r&&(this._setTextureParameterInteger(n,this._gl.TEXTURE_WRAP_R,this._getTextureWrapMode(r),e),e._cachedWrapR=r),this._bindTextureDirectly(n,null)},e.prototype._setupDepthStencilTexture=function(e,t,i,r,n){var o=t.width||t,s=t.height||t,a=t.layers||0;e.baseWidth=o,e.baseHeight=s,e.width=o,e.height=s,e.is2DArray=a>0,e.depth=a,e.isReady=!0,e.samples=1,e.generateMipMaps=!1,e._generateDepthBuffer=!0,e._generateStencilBuffer=i,e.samplingMode=r?2:1,e.type=0,e._comparisonFunction=n;var h=this._gl,l=this._getTextureTarget(e),c=this._getSamplingParameters(e.samplingMode,!1);h.texParameteri(l,h.TEXTURE_MAG_FILTER,c.mag),h.texParameteri(l,h.TEXTURE_MIN_FILTER,c.min),h.texParameteri(l,h.TEXTURE_WRAP_S,h.CLAMP_TO_EDGE),h.texParameteri(l,h.TEXTURE_WRAP_T,h.CLAMP_TO_EDGE),0===n?(h.texParameteri(l,h.TEXTURE_COMPARE_FUNC,515),h.texParameteri(l,h.TEXTURE_COMPARE_MODE,h.NONE)):(h.texParameteri(l,h.TEXTURE_COMPARE_FUNC,n),h.texParameteri(l,h.TEXTURE_COMPARE_MODE,h.COMPARE_REF_TO_TEXTURE))},e.prototype._uploadCompressedDataToTextureDirectly=function(e,t,i,r,n,o,s){void 0===o&&(o=0),void 0===s&&(s=0);var a=this._gl,h=a.TEXTURE_2D;e.isCube&&(h=a.TEXTURE_CUBE_MAP_POSITIVE_X+o),this._gl.compressedTexImage2D(h,s,t,i,r,0,n)},e.prototype._uploadDataToTextureDirectly=function(e,t,i,r,n,o){void 0===i&&(i=0),void 0===r&&(r=0),void 0===o&&(o=!1);var s=this._gl,a=this._getWebGLTextureType(e.type),h=this._getInternalFormat(e.format),l=void 0===n?this._getRGBABufferInternalSizedFormat(e.type,e.format):this._getInternalFormat(n);this._unpackFlipY(e.invertY);var c=s.TEXTURE_2D;e.isCube&&(c=s.TEXTURE_CUBE_MAP_POSITIVE_X+i);var u=Math.round(Math.log(e.width)*Math.LOG2E),f=Math.round(Math.log(e.height)*Math.LOG2E),d=o?e.width:Math.pow(2,Math.max(u-r,0)),p=o?e.height:Math.pow(2,Math.max(f-r,0));s.texImage2D(c,r,l,d,p,0,h,a,t)},e.prototype.updateTextureData=function(e,t,i,r,n,o,s,a){void 0===s&&(s=0),void 0===a&&(a=0);var h=this._gl,l=this._getWebGLTextureType(e.type),c=this._getInternalFormat(e.format);this._unpackFlipY(e.invertY);var u=h.TEXTURE_2D;e.isCube&&(u=h.TEXTURE_CUBE_MAP_POSITIVE_X+s),h.texSubImage2D(u,a,i,r,n,o,c,l,t)},e.prototype._uploadArrayBufferViewToTexture=function(e,t,i,r){void 0===i&&(i=0),void 0===r&&(r=0);var n=this._gl,o=e.isCube?n.TEXTURE_CUBE_MAP:n.TEXTURE_2D;this._bindTextureDirectly(o,e,!0),this._uploadDataToTextureDirectly(e,t,i,r),this._bindTextureDirectly(o,null,!0)},e.prototype._prepareWebGLTextureContinuation=function(e,t,i,r,n){var o=this._gl;if(o){var s=this._getSamplingParameters(n,!i);o.texParameteri(o.TEXTURE_2D,o.TEXTURE_MAG_FILTER,s.mag),o.texParameteri(o.TEXTURE_2D,o.TEXTURE_MIN_FILTER,s.min),i||r||o.generateMipmap(o.TEXTURE_2D),this._bindTextureDirectly(o.TEXTURE_2D,null),t&&t._removePendingData(e),e.onLoadedObservable.notifyObservers(e),e.onLoadedObservable.clear()}},e.prototype._prepareWebGLTexture=function(t,i,r,n,o,s,a,h,l){var c=this;void 0===l&&(l=3);var u=this.getCaps().maxTextureSize,f=Math.min(u,this.needPOTTextures?e.GetExponentOfTwo(r,u):r),d=Math.min(u,this.needPOTTextures?e.GetExponentOfTwo(n,u):n),p=this._gl;p&&(t._webGLTexture?(this._bindTextureDirectly(p.TEXTURE_2D,t,!0),this._unpackFlipY(void 0===o||!!o),t.baseWidth=r,t.baseHeight=n,t.width=f,t.height=d,t.isReady=!0,h(f,d,(function(){c._prepareWebGLTextureContinuation(t,i,s,a,l)}))||this._prepareWebGLTextureContinuation(t,i,s,a,l)):i&&i._removePendingData(t))},e.prototype._setupFramebufferDepthAttachments=function(e,t,i,r,n){void 0===n&&(n=1);var o=this._gl;if(e&&t)return this._getDepthStencilBuffer(i,r,n,o.DEPTH_STENCIL,o.DEPTH24_STENCIL8,o.DEPTH_STENCIL_ATTACHMENT);if(t){var s=o.DEPTH_COMPONENT16;return this._webGLVersion>1&&(s=o.DEPTH_COMPONENT32F),this._getDepthStencilBuffer(i,r,n,s,s,o.DEPTH_ATTACHMENT)}return e?this._getDepthStencilBuffer(i,r,n,o.STENCIL_INDEX8,o.STENCIL_INDEX8,o.STENCIL_ATTACHMENT):null},e.prototype._releaseFramebufferObjects=function(e){var t=this._gl;e._framebuffer&&(t.deleteFramebuffer(e._framebuffer),e._framebuffer=null),e._depthStencilBuffer&&(t.deleteRenderbuffer(e._depthStencilBuffer),e._depthStencilBuffer=null),e._MSAAFramebuffer&&(t.deleteFramebuffer(e._MSAAFramebuffer),e._MSAAFramebuffer=null),e._MSAARenderBuffer&&(t.deleteRenderbuffer(e._MSAARenderBuffer),e._MSAARenderBuffer=null)},e.prototype._releaseTexture=function(e){this._releaseFramebufferObjects(e),this._deleteTexture(e._webGLTexture),this.unbindAllTextures();var t=this._internalTexturesCache.indexOf(e);-1!==t&&this._internalTexturesCache.splice(t,1),e._lodTextureHigh&&e._lodTextureHigh.dispose(),e._lodTextureMid&&e._lodTextureMid.dispose(),e._lodTextureLow&&e._lodTextureLow.dispose(),e._irradianceTexture&&e._irradianceTexture.dispose()},e.prototype._deleteTexture=function(e){this._gl.deleteTexture(e)},e.prototype._setProgram=function(e){this._currentProgram!==e&&(this._gl.useProgram(e),this._currentProgram=e)},e.prototype.bindSamplers=function(e){var t=e.getPipelineContext();this._setProgram(t.program);for(var i=e.getSamplers(),r=0;r-1;return i&&o&&(this._activeChannel=t._associatedChannel),this._boundTexturesCache[this._activeChannel]!==t||r?(this._activateCurrentTexture(),t&&t.isMultiview?this._gl.bindTexture(e,t?t._colorTextureArray:null):this._gl.bindTexture(e,t?t._webGLTexture:null),this._boundTexturesCache[this._activeChannel]=t,t&&(t._associatedChannel=this._activeChannel)):i&&(n=!0,this._activateCurrentTexture()),o&&!i&&this._bindSamplerUniformToChannel(t._associatedChannel,this._activeChannel),n},e.prototype._bindTexture=function(e,t){void 0!==e&&(t&&(t._associatedChannel=e),this._activeChannel=e,this._bindTextureDirectly(this._gl.TEXTURE_2D,t))},e.prototype.unbindAllTextures=function(){for(var e=0;e1&&(this._bindTextureDirectly(this._gl.TEXTURE_3D,null),this._bindTextureDirectly(this._gl.TEXTURE_2D_ARRAY,null))},e.prototype.setTexture=function(e,t,i){void 0!==e&&(t&&(this._boundUniforms[e]=t),this._setTexture(e,i))},e.prototype._bindSamplerUniformToChannel=function(e,t){var i=this._boundUniforms[e];i&&i._currentState!==t&&(this._gl.uniform1i(i,t),i._currentState=t)},e.prototype._getTextureWrapMode=function(e){switch(e){case 1:return this._gl.REPEAT;case 0:return this._gl.CLAMP_TO_EDGE;case 2:return this._gl.MIRRORED_REPEAT}return this._gl.REPEAT},e.prototype._setTexture=function(e,t,i,r){if(void 0===i&&(i=!1),void 0===r&&(r=!1),!t)return null!=this._boundTexturesCache[e]&&(this._activeChannel=e,this._bindTextureDirectly(this._gl.TEXTURE_2D,null),this._bindTextureDirectly(this._gl.TEXTURE_CUBE_MAP,null),this.webGLVersion>1&&(this._bindTextureDirectly(this._gl.TEXTURE_3D,null),this._bindTextureDirectly(this._gl.TEXTURE_2D_ARRAY,null))),!1;if(t.video)this._activeChannel=e,t.update();else if(4===t.delayLoadState)return t.delayLoad(),!1;var n;n=r?t.depthStencilTexture:t.isReady()?t.getInternalTexture():t.isCube?this.emptyCubeTexture:t.is3D?this.emptyTexture3D:t.is2DArray?this.emptyTexture2DArray:this.emptyTexture,!i&&n&&(n._associatedChannel=e);var o=!0;this._boundTexturesCache[e]===n&&(i||this._bindSamplerUniformToChannel(n._associatedChannel,e),o=!1),this._activeChannel=e;var s=this._getTextureTarget(n);if(o&&this._bindTextureDirectly(s,n,i),n&&!n.isMultiview){if(n.isCube&&n._cachedCoordinatesMode!==t.coordinatesMode){n._cachedCoordinatesMode=t.coordinatesMode;var a=3!==t.coordinatesMode&&5!==t.coordinatesMode?1:0;t.wrapU=a,t.wrapV=a}n._cachedWrapU!==t.wrapU&&(n._cachedWrapU=t.wrapU,this._setTextureParameterInteger(s,this._gl.TEXTURE_WRAP_S,this._getTextureWrapMode(t.wrapU),n)),n._cachedWrapV!==t.wrapV&&(n._cachedWrapV=t.wrapV,this._setTextureParameterInteger(s,this._gl.TEXTURE_WRAP_T,this._getTextureWrapMode(t.wrapV),n)),n.is3D&&n._cachedWrapR!==t.wrapR&&(n._cachedWrapR=t.wrapR,this._setTextureParameterInteger(s,this._gl.TEXTURE_WRAP_R,this._getTextureWrapMode(t.wrapR),n)),this._setAnisotropicLevel(s,n,t.anisotropicFilteringLevel)}return!0},e.prototype.setTextureArray=function(e,t,i){if(void 0!==e&&t){this._textureUnits&&this._textureUnits.length===i.length||(this._textureUnits=new Int32Array(i.length));for(var r=0;r=this._caps.maxVertexAttribs||!this._vertexAttribArraysEnabled[e]||this.disableAttributeByIndex(e)}},e.prototype.releaseEffects=function(){for(var e in this._compiledEffects){var t=this._compiledEffects[e].getPipelineContext();this._deletePipelineContext(t)}this._compiledEffects={}},e.prototype.dispose=function(){this.stopRenderLoop(),this.onBeforeTextureInitObservable&&this.onBeforeTextureInitObservable.clear(),this._emptyTexture&&(this._releaseTexture(this._emptyTexture),this._emptyTexture=null),this._emptyCubeTexture&&(this._releaseTexture(this._emptyCubeTexture),this._emptyCubeTexture=null),this.releaseEffects(),this.unbindAllAttributes(),this._boundUniforms=[],f.a.IsWindowObjectExist()&&this._renderingCanvas&&(this._doNotHandleContextLost||(this._renderingCanvas.removeEventListener("webglcontextlost",this._onContextLost),this._renderingCanvas.removeEventListener("webglcontextrestored",this._onContextRestored))),this._workingCanvas=null,this._workingContext=null,this._currentBufferPointers=[],this._renderingCanvas=null,this._currentProgram=null,this._boundRenderFunction=null,n.a.ResetCache();for(var e=0,t=this._activeRequests;e1?this._caps.colorBufferFloat:this._canRenderToFramebuffer(1)},e.prototype._canRenderToHalfFloatFramebuffer=function(){return this._webGLVersion>1?this._caps.colorBufferFloat:this._canRenderToFramebuffer(2)},e.prototype._canRenderToFramebuffer=function(e){for(var t=this._gl;t.getError()!==t.NO_ERROR;);var i=!0,r=t.createTexture();t.bindTexture(t.TEXTURE_2D,r),t.texImage2D(t.TEXTURE_2D,0,this._getRGBABufferInternalSizedFormat(e),1,1,0,t.RGBA,this._getWebGLTextureType(e),null),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MIN_FILTER,t.NEAREST),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MAG_FILTER,t.NEAREST);var n=t.createFramebuffer();t.bindFramebuffer(t.FRAMEBUFFER,n),t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,r,0);var o=t.checkFramebufferStatus(t.FRAMEBUFFER);if((i=(i=i&&o===t.FRAMEBUFFER_COMPLETE)&&t.getError()===t.NO_ERROR)&&(t.clear(t.COLOR_BUFFER_BIT),i=i&&t.getError()===t.NO_ERROR),i){t.bindFramebuffer(t.FRAMEBUFFER,null);var s=t.RGBA,a=t.UNSIGNED_BYTE,h=new Uint8Array(4);t.readPixels(0,0,1,1,s,a,h),i=i&&t.getError()===t.NO_ERROR}for(t.deleteTexture(r),t.deleteFramebuffer(n),t.bindFramebuffer(t.FRAMEBUFFER,null);!i&&t.getError()!==t.NO_ERROR;);return i},e.prototype._getWebGLTextureType=function(e){if(1===this._webGLVersion){switch(e){case 1:return this._gl.FLOAT;case 2:return this._gl.HALF_FLOAT_OES;case 0:return this._gl.UNSIGNED_BYTE;case 8:return this._gl.UNSIGNED_SHORT_4_4_4_4;case 9:return this._gl.UNSIGNED_SHORT_5_5_5_1;case 10:return this._gl.UNSIGNED_SHORT_5_6_5}return this._gl.UNSIGNED_BYTE}switch(e){case 3:return this._gl.BYTE;case 0:return this._gl.UNSIGNED_BYTE;case 4:return this._gl.SHORT;case 5:return this._gl.UNSIGNED_SHORT;case 6:return this._gl.INT;case 7:return this._gl.UNSIGNED_INT;case 1:return this._gl.FLOAT;case 2:return this._gl.HALF_FLOAT;case 8:return this._gl.UNSIGNED_SHORT_4_4_4_4;case 9:return this._gl.UNSIGNED_SHORT_5_5_5_1;case 10:return this._gl.UNSIGNED_SHORT_5_6_5;case 11:return this._gl.UNSIGNED_INT_2_10_10_10_REV;case 12:return this._gl.UNSIGNED_INT_24_8;case 13:return this._gl.UNSIGNED_INT_10F_11F_11F_REV;case 14:return this._gl.UNSIGNED_INT_5_9_9_9_REV;case 15:return this._gl.FLOAT_32_UNSIGNED_INT_24_8_REV}return this._gl.UNSIGNED_BYTE},e.prototype._getInternalFormat=function(e){var t=this._gl.RGBA;switch(e){case 0:t=this._gl.ALPHA;break;case 1:t=this._gl.LUMINANCE;break;case 2:t=this._gl.LUMINANCE_ALPHA;break;case 6:t=this._gl.RED;break;case 7:t=this._gl.RG;break;case 4:t=this._gl.RGB;break;case 5:t=this._gl.RGBA}if(this._webGLVersion>1)switch(e){case 8:t=this._gl.RED_INTEGER;break;case 9:t=this._gl.RG_INTEGER;break;case 10:t=this._gl.RGB_INTEGER;break;case 11:t=this._gl.RGBA_INTEGER}return t},e.prototype._getRGBABufferInternalSizedFormat=function(e,t){if(1===this._webGLVersion){if(void 0!==t)switch(t){case 0:return this._gl.ALPHA;case 1:return this._gl.LUMINANCE;case 2:return this._gl.LUMINANCE_ALPHA;case 4:return this._gl.RGB}return this._gl.RGBA}switch(e){case 3:switch(t){case 6:return this._gl.R8_SNORM;case 7:return this._gl.RG8_SNORM;case 4:return this._gl.RGB8_SNORM;case 8:return this._gl.R8I;case 9:return this._gl.RG8I;case 10:return this._gl.RGB8I;case 11:return this._gl.RGBA8I;default:return this._gl.RGBA8_SNORM}case 0:switch(t){case 6:return this._gl.R8;case 7:return this._gl.RG8;case 4:return this._gl.RGB8;case 5:return this._gl.RGBA8;case 8:return this._gl.R8UI;case 9:return this._gl.RG8UI;case 10:return this._gl.RGB8UI;case 11:return this._gl.RGBA8UI;case 0:return this._gl.ALPHA;case 1:return this._gl.LUMINANCE;case 2:return this._gl.LUMINANCE_ALPHA;default:return this._gl.RGBA8}case 4:switch(t){case 8:return this._gl.R16I;case 9:return this._gl.RG16I;case 10:return this._gl.RGB16I;case 11:default:return this._gl.RGBA16I}case 5:switch(t){case 8:return this._gl.R16UI;case 9:return this._gl.RG16UI;case 10:return this._gl.RGB16UI;case 11:default:return this._gl.RGBA16UI}case 6:switch(t){case 8:return this._gl.R32I;case 9:return this._gl.RG32I;case 10:return this._gl.RGB32I;case 11:default:return this._gl.RGBA32I}case 7:switch(t){case 8:return this._gl.R32UI;case 9:return this._gl.RG32UI;case 10:return this._gl.RGB32UI;case 11:default:return this._gl.RGBA32UI}case 1:switch(t){case 6:return this._gl.R32F;case 7:return this._gl.RG32F;case 4:return this._gl.RGB32F;case 5:default:return this._gl.RGBA32F}case 2:switch(t){case 6:return this._gl.R16F;case 7:return this._gl.RG16F;case 4:return this._gl.RGB16F;case 5:default:return this._gl.RGBA16F}case 10:return this._gl.RGB565;case 13:return this._gl.R11F_G11F_B10F;case 14:return this._gl.RGB9_E5;case 8:return this._gl.RGBA4;case 9:return this._gl.RGB5_A1;case 11:switch(t){case 5:return this._gl.RGB10_A2;case 11:return this._gl.RGB10_A2UI;default:return this._gl.RGB10_A2}}return this._gl.RGBA8},e.prototype._getRGBAMultiSampleBufferFormat=function(e){return 1===e?this._gl.RGBA32F:2===e?this._gl.RGBA16F:this._gl.RGBA8},e.prototype._loadFile=function(t,i,r,n,o,s){var a=this,h=e._FileToolsLoadFile(t,i,r,n,o,s);return this._activeRequests.push(h),h.onCompleteObservable.add((function(e){a._activeRequests.splice(a._activeRequests.indexOf(e),1)})),h},e._FileToolsLoadFile=function(e,t,i,r,n,s){throw o.a.WarnImport("FileTools")},e.prototype.readPixels=function(e,t,i,r,n){void 0===n&&(n=!0);var o=n?4:3,s=n?this._gl.RGBA:this._gl.RGB,a=new Uint8Array(r*i*o);return this._gl.readPixels(e,t,i,r,s,this._gl.UNSIGNED_BYTE,a),a},e.isSupported=function(){if(null===this._isSupported)try{var e=g.a.CreateCanvas(1,1),t=e.getContext("webgl")||e.getContext("experimental-webgl");this._isSupported=null!=t&&!!window.WebGLRenderingContext}catch(e){this._isSupported=!1}return this._isSupported},e.CeilingPOT=function(e){return e--,e|=e>>1,e|=e>>2,e|=e>>4,e|=e>>8,e|=e>>16,++e},e.FloorPOT=function(e){return e|=e>>1,e|=e>>2,e|=e>>4,e|=e>>8,(e|=e>>16)-(e>>1)},e.NearestPOT=function(t){var i=e.CeilingPOT(t),r=e.FloorPOT(t);return i-t>t-r?r:i},e.GetExponentOfTwo=function(t,i,r){var n;switch(void 0===r&&(r=2),r){case 1:n=e.FloorPOT(t);break;case 2:n=e.NearestPOT(t);break;case 3:default:n=e.CeilingPOT(t)}return Math.min(n,i)},e.QueueNewFrame=function(e,t){return f.a.IsWindowObjectExist()?(t||(t=window),t.requestAnimationFrame?t.requestAnimationFrame(e):t.msRequestAnimationFrame?t.msRequestAnimationFrame(e):t.webkitRequestAnimationFrame?t.webkitRequestAnimationFrame(e):t.mozRequestAnimationFrame?t.mozRequestAnimationFrame(e):t.oRequestAnimationFrame?t.oRequestAnimationFrame(e):window.setTimeout(e,16)):"undefined"!=typeof requestAnimationFrame?requestAnimationFrame(e):setTimeout(e,16)},e.prototype.getHostDocument=function(){return this._renderingCanvas&&this._renderingCanvas.ownerDocument?this._renderingCanvas.ownerDocument:document},e.ExceptionList=[{key:"Chrome/63.0",capture:"63\\.0\\.3239\\.(\\d+)",captureConstraint:108,targets:["uniformBuffer"]},{key:"Firefox/58",capture:null,captureConstraint:null,targets:["uniformBuffer"]},{key:"Firefox/59",capture:null,captureConstraint:null,targets:["uniformBuffer"]},{key:"Chrome/72.+?Mobile",capture:null,captureConstraint:null,targets:["vao"]},{key:"Chrome/73.+?Mobile",capture:null,captureConstraint:null,targets:["vao"]},{key:"Chrome/74.+?Mobile",capture:null,captureConstraint:null,targets:["vao"]},{key:"Mac OS.+Chrome/71",capture:null,captureConstraint:null,targets:["vao"]},{key:"Mac OS.+Chrome/72",capture:null,captureConstraint:null,targets:["vao"]}],e._TextureLoaders=[],e.CollisionsEpsilon=.001,e._isSupported=null,e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return r}));var r=function(){function e(){}return e.IsWindowObjectExist=function(){return"undefined"!=typeof window},e.IsNavigatorAvailable=function(){return"undefined"!=typeof navigator},e.GetDOMTextContent=function(e){for(var t="",i=e.firstChild;i;)3===i.nodeType&&(t+=i.textContent),i=i.nextSibling;return t},e}()},function(e,t,i){"use strict";i.r(t),i.d(t,"Engine",(function(){return _}));var r=i(1),n=i(4),o=i(25),s=i(23),a=i(8),h=i(24),l=i(37),c=function(){function e(e){void 0===e&&(e=30),this._enabled=!0,this._rollingFrameTime=new u(e)}return e.prototype.sampleFrame=function(e){if(void 0===e&&(e=l.a.Now),this._enabled){if(null!=this._lastFrameTimeMs){var t=e-this._lastFrameTimeMs;this._rollingFrameTime.add(t)}this._lastFrameTimeMs=e}},Object.defineProperty(e.prototype,"averageFrameTime",{get:function(){return this._rollingFrameTime.average},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"averageFrameTimeVariance",{get:function(){return this._rollingFrameTime.variance},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"instantaneousFrameTime",{get:function(){return this._rollingFrameTime.history(0)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"averageFPS",{get:function(){return 1e3/this._rollingFrameTime.average},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"instantaneousFPS",{get:function(){var e=this._rollingFrameTime.history(0);return 0===e?0:1e3/e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isSaturated",{get:function(){return this._rollingFrameTime.isSaturated()},enumerable:!0,configurable:!0}),e.prototype.enable=function(){this._enabled=!0},e.prototype.disable=function(){this._enabled=!1,this._lastFrameTimeMs=null},Object.defineProperty(e.prototype,"isEnabled",{get:function(){return this._enabled},enumerable:!0,configurable:!0}),e.prototype.reset=function(){this._lastFrameTimeMs=null,this._rollingFrameTime.reset()},e}(),u=function(){function e(e){this._samples=new Array(e),this.reset()}return e.prototype.add=function(e){var t;if(this.isSaturated()){var i=this._samples[this._pos];t=i-this.average,this.average-=t/(this._sampleCount-1),this._m2-=t*(i-this.average)}else this._sampleCount++;t=e-this.average,this.average+=t/this._sampleCount,this._m2+=t*(e-this.average),this.variance=this._m2/(this._sampleCount-1),this._samples[this._pos]=e,this._pos++,this._pos%=this._samples.length},e.prototype.history=function(e){if(e>=this._sampleCount||e>=this._samples.length)return 0;var t=this._wrapPosition(this._pos-1);return this._samples[this._wrapPosition(t-e)]},e.prototype.isSaturated=function(){return this._sampleCount>=this._samples.length},e.prototype.reset=function(){this.average=0,this.variance=0,this._sampleCount=0,this._pos=0,this._m2=0},e.prototype._wrapPosition=function(e){var t=this._samples.length;return(e%t+t)%t},e}(),f=i(55),d=i(52),p=i(12);h.a.prototype.setAlphaConstants=function(e,t,i,r){this._alphaState.setAlphaBlendConstants(e,t,i,r)},h.a.prototype.setAlphaMode=function(e,t){if(void 0===t&&(t=!1),this._alphaMode!==e){switch(e){case 0:this._alphaState.alphaBlend=!1;break;case 7:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE,this._gl.ONE_MINUS_SRC_ALPHA,this._gl.ONE,this._gl.ONE),this._alphaState.alphaBlend=!0;break;case 8:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE,this._gl.ONE_MINUS_SRC_ALPHA,this._gl.ONE,this._gl.ONE_MINUS_SRC_ALPHA),this._alphaState.alphaBlend=!0;break;case 2:this._alphaState.setAlphaBlendFunctionParameters(this._gl.SRC_ALPHA,this._gl.ONE_MINUS_SRC_ALPHA,this._gl.ONE,this._gl.ONE),this._alphaState.alphaBlend=!0;break;case 6:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE,this._gl.ONE,this._gl.ZERO,this._gl.ONE),this._alphaState.alphaBlend=!0;break;case 1:this._alphaState.setAlphaBlendFunctionParameters(this._gl.SRC_ALPHA,this._gl.ONE,this._gl.ZERO,this._gl.ONE),this._alphaState.alphaBlend=!0;break;case 3:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ZERO,this._gl.ONE_MINUS_SRC_COLOR,this._gl.ONE,this._gl.ONE),this._alphaState.alphaBlend=!0;break;case 4:this._alphaState.setAlphaBlendFunctionParameters(this._gl.DST_COLOR,this._gl.ZERO,this._gl.ONE,this._gl.ONE),this._alphaState.alphaBlend=!0;break;case 5:this._alphaState.setAlphaBlendFunctionParameters(this._gl.SRC_ALPHA,this._gl.ONE_MINUS_SRC_COLOR,this._gl.ONE,this._gl.ONE),this._alphaState.alphaBlend=!0;break;case 9:this._alphaState.setAlphaBlendFunctionParameters(this._gl.CONSTANT_COLOR,this._gl.ONE_MINUS_CONSTANT_COLOR,this._gl.CONSTANT_ALPHA,this._gl.ONE_MINUS_CONSTANT_ALPHA),this._alphaState.alphaBlend=!0;break;case 10:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE,this._gl.ONE_MINUS_SRC_COLOR,this._gl.ONE,this._gl.ONE_MINUS_SRC_ALPHA),this._alphaState.alphaBlend=!0;break;case 11:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE,this._gl.ONE,this._gl.ONE,this._gl.ONE),this._alphaState.alphaBlend=!0;break;case 12:this._alphaState.setAlphaBlendFunctionParameters(this._gl.DST_ALPHA,this._gl.ONE,this._gl.ZERO,this._gl.ZERO),this._alphaState.alphaBlend=!0;break;case 13:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE_MINUS_DST_COLOR,this._gl.ONE_MINUS_SRC_COLOR,this._gl.ONE_MINUS_DST_ALPHA,this._gl.ONE_MINUS_SRC_ALPHA),this._alphaState.alphaBlend=!0;break;case 14:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE,this._gl.ONE_MINUS_SRC_ALPHA,this._gl.ONE,this._gl.ONE_MINUS_SRC_ALPHA),this._alphaState.alphaBlend=!0;break;case 15:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE,this._gl.ONE,this._gl.ONE,this._gl.ZERO),this._alphaState.alphaBlend=!0;break;case 16:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE_MINUS_DST_COLOR,this._gl.ONE_MINUS_SRC_COLOR,this._gl.ZERO,this._gl.ONE),this._alphaState.alphaBlend=!0}t||(this.depthCullingState.depthMask=0===e),this._alphaMode=e}},h.a.prototype.getAlphaMode=function(){return this._alphaMode},h.a.prototype.setAlphaEquation=function(e){if(this._alphaEquation!==e){switch(e){case 0:this._alphaState.setAlphaEquationParameters(this._gl.FUNC_ADD,this._gl.FUNC_ADD);break;case 1:this._alphaState.setAlphaEquationParameters(this._gl.FUNC_SUBTRACT,this._gl.FUNC_SUBTRACT);break;case 2:this._alphaState.setAlphaEquationParameters(this._gl.FUNC_REVERSE_SUBTRACT,this._gl.FUNC_REVERSE_SUBTRACT);break;case 3:this._alphaState.setAlphaEquationParameters(this._gl.MAX,this._gl.MAX);break;case 4:this._alphaState.setAlphaEquationParameters(this._gl.MIN,this._gl.MIN);break;case 5:this._alphaState.setAlphaEquationParameters(this._gl.MIN,this._gl.FUNC_ADD)}this._alphaEquation=e}},h.a.prototype.getAlphaEquation=function(){return this._alphaEquation};var _=function(e){function t(i,r,s,a){void 0===a&&(a=!1);var h=e.call(this,i,r,s,a)||this;if(h.enableOfflineSupport=!1,h.disableManifestCheck=!1,h.scenes=new Array,h.onNewSceneAddedObservable=new n.a,h.postProcesses=new Array,h.isPointerLock=!1,h.onResizeObservable=new n.a,h.onCanvasBlurObservable=new n.a,h.onCanvasFocusObservable=new n.a,h.onCanvasPointerOutObservable=new n.a,h.onBeginFrameObservable=new n.a,h.customAnimationFrameRequester=null,h.onEndFrameObservable=new n.a,h.onBeforeShaderCompilationObservable=new n.a,h.onAfterShaderCompilationObservable=new n.a,h._deterministicLockstep=!1,h._lockstepMaxSteps=4,h._timeStep=1/60,h._fps=60,h._deltaTime=0,h._drawCalls=new f.a,h.canvasTabIndex=1,h.disablePerformanceMonitorInBackground=!1,h._performanceMonitor=new c,!i)return h;if(s=h._creationOptions,t.Instances.push(h),i.getContext){var l=i;if(h._onCanvasFocus=function(){h.onCanvasFocusObservable.notifyObservers(h)},h._onCanvasBlur=function(){h.onCanvasBlurObservable.notifyObservers(h)},l.addEventListener("focus",h._onCanvasFocus),l.addEventListener("blur",h._onCanvasBlur),h._onBlur=function(){h.disablePerformanceMonitorInBackground&&h._performanceMonitor.disable(),h._windowIsBackground=!0},h._onFocus=function(){h.disablePerformanceMonitorInBackground&&h._performanceMonitor.enable(),h._windowIsBackground=!1},h._onCanvasPointerOut=function(e){h.onCanvasPointerOutObservable.notifyObservers(e)},l.addEventListener("pointerout",h._onCanvasPointerOut),o.a.IsWindowObjectExist()){var u=h.getHostWindow();u.addEventListener("blur",h._onBlur),u.addEventListener("focus",h._onFocus);var d=document;h._onFullscreenChange=function(){void 0!==d.fullscreen?h.isFullscreen=d.fullscreen:void 0!==d.mozFullScreen?h.isFullscreen=d.mozFullScreen:void 0!==d.webkitIsFullScreen?h.isFullscreen=d.webkitIsFullScreen:void 0!==d.msIsFullScreen&&(h.isFullscreen=d.msIsFullScreen),h.isFullscreen&&h._pointerLockRequested&&l&&t._RequestPointerlock(l)},document.addEventListener("fullscreenchange",h._onFullscreenChange,!1),document.addEventListener("mozfullscreenchange",h._onFullscreenChange,!1),document.addEventListener("webkitfullscreenchange",h._onFullscreenChange,!1),document.addEventListener("msfullscreenchange",h._onFullscreenChange,!1),h._onPointerLockChange=function(){h.isPointerLock=d.mozPointerLockElement===l||d.webkitPointerLockElement===l||d.msPointerLockElement===l||d.pointerLockElement===l},document.addEventListener("pointerlockchange",h._onPointerLockChange,!1),document.addEventListener("mspointerlockchange",h._onPointerLockChange,!1),document.addEventListener("mozpointerlockchange",h._onPointerLockChange,!1),document.addEventListener("webkitpointerlockchange",h._onPointerLockChange,!1),!t.audioEngine&&s.audioEngine&&t.AudioEngineFactory&&(t.audioEngine=t.AudioEngineFactory(h.getRenderingCanvas()))}h._connectVREvents(),h.enableOfflineSupport=void 0!==t.OfflineProviderFactory,s.doNotHandleTouchAction||h._disableTouchAction(),h._deterministicLockstep=!!s.deterministicLockstep,h._lockstepMaxSteps=s.lockstepMaxSteps||0,h._timeStep=s.timeStep||1/60}return h._prepareVRComponent(),s.autoEnableWebVR&&h.initWebVR(),h}return Object(r.c)(t,e),Object.defineProperty(t,"NpmPackage",{get:function(){return h.a.NpmPackage},enumerable:!0,configurable:!0}),Object.defineProperty(t,"Version",{get:function(){return h.a.Version},enumerable:!0,configurable:!0}),Object.defineProperty(t,"Instances",{get:function(){return s.a.Instances},enumerable:!0,configurable:!0}),Object.defineProperty(t,"LastCreatedEngine",{get:function(){return s.a.LastCreatedEngine},enumerable:!0,configurable:!0}),Object.defineProperty(t,"LastCreatedScene",{get:function(){return s.a.LastCreatedScene},enumerable:!0,configurable:!0}),t.MarkAllMaterialsAsDirty=function(e,i){for(var r=0;r0?this.customAnimationFrameRequester?(this.customAnimationFrameRequester.requestID=this._queueNewFrame(this.customAnimationFrameRequester.renderFunction||this._boundRenderFunction,this.customAnimationFrameRequester),this._frameHandler=this.customAnimationFrameRequester.requestID):this.isVRPresenting()?this._requestVRFrame():this._frameHandler=this._queueNewFrame(this._boundRenderFunction,this.getHostWindow()):this._renderingQueueLaunched=!1},t.prototype._renderViews=function(){return!1},t.prototype.switchFullscreen=function(e){this.isFullscreen?this.exitFullscreen():this.enterFullscreen(e)},t.prototype.enterFullscreen=function(e){this.isFullscreen||(this._pointerLockRequested=e,this._renderingCanvas&&t._RequestFullscreen(this._renderingCanvas))},t.prototype.exitFullscreen=function(){this.isFullscreen&&t._ExitFullscreen()},t.prototype.enterPointerlock=function(){this._renderingCanvas&&t._RequestPointerlock(this._renderingCanvas)},t.prototype.exitPointerlock=function(){t._ExitPointerlock()},t.prototype.beginFrame=function(){this._measureFps(),this.onBeginFrameObservable.notifyObservers(this),e.prototype.beginFrame.call(this)},t.prototype.endFrame=function(){e.prototype.endFrame.call(this),this._submitVRFrame(),this.onEndFrameObservable.notifyObservers(this)},t.prototype.resize=function(){this.isVRPresenting()||e.prototype.resize.call(this)},t.prototype.setSize=function(t,i){if(this._renderingCanvas&&(e.prototype.setSize.call(this,t,i),this.scenes)){for(var r=0;r=n&&0===i?t instanceof Array?this._gl.bufferSubData(this._gl.ARRAY_BUFFER,i,new Float32Array(t)):this._gl.bufferSubData(this._gl.ARRAY_BUFFER,i,t):t instanceof Array?this._gl.bufferSubData(this._gl.ARRAY_BUFFER,0,new Float32Array(t).subarray(i,i+r)):(t=t instanceof ArrayBuffer?new Uint8Array(t,i,r):new Uint8Array(t.buffer,t.byteOffset+i,r),this._gl.bufferSubData(this._gl.ARRAY_BUFFER,0,t)),this._resetVertexBufferBinding()},t.prototype._deletePipelineContext=function(t){var i=t;i&&i.program&&i.transformFeedback&&(this.deleteTransformFeedback(i.transformFeedback),i.transformFeedback=null),e.prototype._deletePipelineContext.call(this,t)},t.prototype.createShaderProgram=function(t,i,r,n,o,s){void 0===s&&(s=null),o=o||this._gl,this.onBeforeShaderCompilationObservable.notifyObservers(this);var a=e.prototype.createShaderProgram.call(this,t,i,r,n,o,s);return this.onAfterShaderCompilationObservable.notifyObservers(this),a},t.prototype._createShaderProgram=function(e,t,i,r,n){void 0===n&&(n=null);var o=r.createProgram();if(e.program=o,!o)throw new Error("Unable to create program");if(r.attachShader(o,t),r.attachShader(o,i),this.webGLVersion>1&&n){var s=this.createTransformFeedback();this.bindTransformFeedback(s),this.setTranformFeedbackVaryings(o,n),e.transformFeedback=s}return r.linkProgram(o),this.webGLVersion>1&&n&&this.bindTransformFeedback(null),e.context=r,e.vertexShader=t,e.fragmentShader=i,e.isParallelCompiled||this._finalizePipelineContext(e),o},t.prototype._releaseTexture=function(t){e.prototype._releaseTexture.call(this,t),this.scenes.forEach((function(e){e.postProcesses.forEach((function(e){e._outputTexture==t&&(e._outputTexture=null)})),e.cameras.forEach((function(e){e._postProcesses.forEach((function(e){e&&e._outputTexture==t&&(e._outputTexture=null)}))}))}))},t.prototype._rescaleTexture=function(e,i,r,n,o){var s=this;this._gl.texParameteri(this._gl.TEXTURE_2D,this._gl.TEXTURE_MAG_FILTER,this._gl.LINEAR),this._gl.texParameteri(this._gl.TEXTURE_2D,this._gl.TEXTURE_MIN_FILTER,this._gl.LINEAR),this._gl.texParameteri(this._gl.TEXTURE_2D,this._gl.TEXTURE_WRAP_S,this._gl.CLAMP_TO_EDGE),this._gl.texParameteri(this._gl.TEXTURE_2D,this._gl.TEXTURE_WRAP_T,this._gl.CLAMP_TO_EDGE);var a=this.createRenderTargetTexture({width:i.width,height:i.height},{generateMipMaps:!1,type:0,samplingMode:2,generateDepthBuffer:!1,generateStencilBuffer:!1});!this._rescalePostProcess&&t._RescalePostProcessFactory&&(this._rescalePostProcess=t._RescalePostProcessFactory(this)),this._rescalePostProcess.getEffect().executeWhenCompiled((function(){s._rescalePostProcess.onApply=function(t){t._bindTexture("textureSampler",e)};var t=r;t||(t=s.scenes[s.scenes.length-1]),t.postProcessManager.directRender([s._rescalePostProcess],a,!0),s._bindTextureDirectly(s._gl.TEXTURE_2D,i,!0),s._gl.copyTexImage2D(s._gl.TEXTURE_2D,0,n,0,0,i.width,i.height,0),s.unBindFramebuffer(a),s._releaseTexture(a),o&&o()}))},t.prototype.getFps=function(){return this._fps},t.prototype.getDeltaTime=function(){return this._deltaTime},t.prototype._measureFps=function(){this._performanceMonitor.sampleFrame(),this._fps=this._performanceMonitor.averageFPS,this._deltaTime=this._performanceMonitor.instantaneousFrameTime||0},t.prototype._uploadImageToTexture=function(e,t,i,r){void 0===i&&(i=0),void 0===r&&(r=0);var n=this._gl,o=this._getWebGLTextureType(e.type),s=this._getInternalFormat(e.format),a=this._getRGBABufferInternalSizedFormat(e.type,s),h=e.isCube?n.TEXTURE_CUBE_MAP:n.TEXTURE_2D;this._bindTextureDirectly(h,e,!0),this._unpackFlipY(e.invertY);var l=n.TEXTURE_2D;e.isCube&&(l=n.TEXTURE_CUBE_MAP_POSITIVE_X+i),n.texImage2D(l,r,a,s,o,t),this._bindTextureDirectly(h,null,!0)},t.prototype.updateDynamicIndexBuffer=function(e,t,i){var r;void 0===i&&(i=0),this._currentBoundBuffer[this._gl.ELEMENT_ARRAY_BUFFER]=null,this.bindIndexBuffer(e),r=t instanceof Uint16Array||t instanceof Uint32Array?t:e.is32Bits?new Uint32Array(t):new Uint16Array(t),this._gl.bufferData(this._gl.ELEMENT_ARRAY_BUFFER,r,this._gl.DYNAMIC_DRAW),this._resetIndexBufferBinding()},t.prototype.updateRenderTargetTextureSampleCount=function(e,t){if(this.webGLVersion<2||!e)return 1;if(e.samples===t)return t;var i=this._gl;if(t=Math.min(t,this.getCaps().maxMSAASamples),e._depthStencilBuffer&&(i.deleteRenderbuffer(e._depthStencilBuffer),e._depthStencilBuffer=null),e._MSAAFramebuffer&&(i.deleteFramebuffer(e._MSAAFramebuffer),e._MSAAFramebuffer=null),e._MSAARenderBuffer&&(i.deleteRenderbuffer(e._MSAARenderBuffer),e._MSAARenderBuffer=null),t>1&&i.renderbufferStorageMultisample){var r=i.createFramebuffer();if(!r)throw new Error("Unable to create multi sampled framebuffer");e._MSAAFramebuffer=r,this._bindUnboundFramebuffer(e._MSAAFramebuffer);var n=i.createRenderbuffer();if(!n)throw new Error("Unable to create multi sampled framebuffer");i.bindRenderbuffer(i.RENDERBUFFER,n),i.renderbufferStorageMultisample(i.RENDERBUFFER,t,this._getRGBAMultiSampleBufferFormat(e.type),e.width,e.height),i.framebufferRenderbuffer(i.FRAMEBUFFER,i.COLOR_ATTACHMENT0,i.RENDERBUFFER,n),e._MSAARenderBuffer=n}else this._bindUnboundFramebuffer(e._framebuffer);return e.samples=t,e._depthStencilBuffer=this._setupFramebufferDepthAttachments(e._generateStencilBuffer,e._generateDepthBuffer,e.width,e.height,t),this._bindUnboundFramebuffer(null),t},t.prototype.updateTextureComparisonFunction=function(e,t){if(1!==this.webGLVersion){var i=this._gl;e.isCube?(this._bindTextureDirectly(this._gl.TEXTURE_CUBE_MAP,e,!0),0===t?(i.texParameteri(i.TEXTURE_CUBE_MAP,i.TEXTURE_COMPARE_FUNC,515),i.texParameteri(i.TEXTURE_CUBE_MAP,i.TEXTURE_COMPARE_MODE,i.NONE)):(i.texParameteri(i.TEXTURE_CUBE_MAP,i.TEXTURE_COMPARE_FUNC,t),i.texParameteri(i.TEXTURE_CUBE_MAP,i.TEXTURE_COMPARE_MODE,i.COMPARE_REF_TO_TEXTURE)),this._bindTextureDirectly(this._gl.TEXTURE_CUBE_MAP,null)):(this._bindTextureDirectly(this._gl.TEXTURE_2D,e,!0),0===t?(i.texParameteri(i.TEXTURE_2D,i.TEXTURE_COMPARE_FUNC,515),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_COMPARE_MODE,i.NONE)):(i.texParameteri(i.TEXTURE_2D,i.TEXTURE_COMPARE_FUNC,t),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_COMPARE_MODE,i.COMPARE_REF_TO_TEXTURE)),this._bindTextureDirectly(this._gl.TEXTURE_2D,null)),e._comparisonFunction=t}else p.a.Error("WebGL 1 does not support texture comparison.")},t.prototype.createInstancesBuffer=function(e){var t=this._gl.createBuffer();if(!t)throw new Error("Unable to create instance buffer");var i=new d.a(t);return i.capacity=e,this.bindArrayBuffer(i),this._gl.bufferData(this._gl.ARRAY_BUFFER,e,this._gl.DYNAMIC_DRAW),i},t.prototype.deleteInstancesBuffer=function(e){this._gl.deleteBuffer(e)},t.prototype._clientWaitAsync=function(e,t,i){void 0===t&&(t=0),void 0===i&&(i=10);var r=this._gl;return new Promise((function(n,o){var s=function(){var a=r.clientWaitSync(e,t,0);a!=r.WAIT_FAILED?a!=r.TIMEOUT_EXPIRED?n():setTimeout(s,i):o()};s()}))},t.prototype._readPixelsAsync=function(e,t,i,r,n,o,s){if(this._webGLVersion<2)throw new Error("_readPixelsAsync only work on WebGL2+");var a=this._gl,h=a.createBuffer();a.bindBuffer(a.PIXEL_PACK_BUFFER,h),a.bufferData(a.PIXEL_PACK_BUFFER,s.byteLength,a.STREAM_READ),a.readPixels(e,t,i,r,n,o,0),a.bindBuffer(a.PIXEL_PACK_BUFFER,null);var l=a.fenceSync(a.SYNC_GPU_COMMANDS_COMPLETE,0);return l?(a.flush(),this._clientWaitAsync(l,0,10).then((function(){return a.deleteSync(l),a.bindBuffer(a.PIXEL_PACK_BUFFER,h),a.getBufferSubData(a.PIXEL_PACK_BUFFER,0,s),a.bindBuffer(a.PIXEL_PACK_BUFFER,null),a.deleteBuffer(h),s}))):null},t.prototype._readTexturePixels=function(e,t,i,r,n,o){void 0===r&&(r=-1),void 0===n&&(n=0),void 0===o&&(o=null);var s=this._gl;if(!this._dummyFramebuffer){var a=s.createFramebuffer();if(!a)throw new Error("Unable to create dummy framebuffer");this._dummyFramebuffer=a}s.bindFramebuffer(s.FRAMEBUFFER,this._dummyFramebuffer),r>-1?s.framebufferTexture2D(s.FRAMEBUFFER,s.COLOR_ATTACHMENT0,s.TEXTURE_CUBE_MAP_POSITIVE_X+r,e._webGLTexture,n):s.framebufferTexture2D(s.FRAMEBUFFER,s.COLOR_ATTACHMENT0,s.TEXTURE_2D,e._webGLTexture,n);var h=void 0!==e.type?this._getWebGLTextureType(e.type):s.UNSIGNED_BYTE;switch(h){case s.UNSIGNED_BYTE:o||(o=new Uint8Array(4*t*i)),h=s.UNSIGNED_BYTE;break;default:o||(o=new Float32Array(4*t*i)),h=s.FLOAT}return s.readPixels(0,0,t,i,s.RGBA,h,o),s.bindFramebuffer(s.FRAMEBUFFER,this._currentFramebuffer),o},t.prototype.dispose=function(){for(this.hideLoadingUI(),this.onNewSceneAddedObservable.clear();this.postProcesses.length;)this.postProcesses[0].dispose();for(this._rescalePostProcess&&this._rescalePostProcess.dispose();this.scenes.length;)this.scenes[0].dispose();1===t.Instances.length&&t.audioEngine&&t.audioEngine.dispose(),this._dummyFramebuffer&&this._gl.deleteFramebuffer(this._dummyFramebuffer),this.disableVR(),o.a.IsWindowObjectExist()&&(window.removeEventListener("blur",this._onBlur),window.removeEventListener("focus",this._onFocus),this._renderingCanvas&&(this._renderingCanvas.removeEventListener("focus",this._onCanvasFocus),this._renderingCanvas.removeEventListener("blur",this._onCanvasBlur),this._renderingCanvas.removeEventListener("pointerout",this._onCanvasPointerOut)),document.removeEventListener("fullscreenchange",this._onFullscreenChange),document.removeEventListener("mozfullscreenchange",this._onFullscreenChange),document.removeEventListener("webkitfullscreenchange",this._onFullscreenChange),document.removeEventListener("msfullscreenchange",this._onFullscreenChange),document.removeEventListener("pointerlockchange",this._onPointerLockChange),document.removeEventListener("mspointerlockchange",this._onPointerLockChange),document.removeEventListener("mozpointerlockchange",this._onPointerLockChange),document.removeEventListener("webkitpointerlockchange",this._onPointerLockChange)),e.prototype.dispose.call(this);var i=t.Instances.indexOf(this);i>=0&&t.Instances.splice(i,1),this.onResizeObservable.clear(),this.onCanvasBlurObservable.clear(),this.onCanvasFocusObservable.clear(),this.onCanvasPointerOutObservable.clear(),this.onBeginFrameObservable.clear(),this.onEndFrameObservable.clear()},t.prototype._disableTouchAction=function(){this._renderingCanvas&&this._renderingCanvas.setAttribute&&(this._renderingCanvas.setAttribute("touch-action","none"),this._renderingCanvas.style.touchAction="none",this._renderingCanvas.style.msTouchAction="none")},t.prototype.displayLoadingUI=function(){if(o.a.IsWindowObjectExist()){var e=this.loadingScreen;e&&e.displayLoadingUI()}},t.prototype.hideLoadingUI=function(){if(o.a.IsWindowObjectExist()){var e=this._loadingScreen;e&&e.hideLoadingUI()}},Object.defineProperty(t.prototype,"loadingScreen",{get:function(){return!this._loadingScreen&&this._renderingCanvas&&(this._loadingScreen=t.DefaultLoadingScreenFactory(this._renderingCanvas)),this._loadingScreen},set:function(e){this._loadingScreen=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"loadingUIText",{set:function(e){this.loadingScreen.loadingUIText=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"loadingUIBackgroundColor",{set:function(e){this.loadingScreen.loadingUIBackgroundColor=e},enumerable:!0,configurable:!0}),t._RequestPointerlock=function(e){e.requestPointerLock=e.requestPointerLock||e.msRequestPointerLock||e.mozRequestPointerLock||e.webkitRequestPointerLock,e.requestPointerLock&&e.requestPointerLock()},t._ExitPointerlock=function(){var e=document;document.exitPointerLock=document.exitPointerLock||e.msExitPointerLock||e.mozExitPointerLock||e.webkitExitPointerLock,document.exitPointerLock&&document.exitPointerLock()},t._RequestFullscreen=function(e){var t=e.requestFullscreen||e.msRequestFullscreen||e.webkitRequestFullscreen||e.mozRequestFullScreen;t&&t.call(e)},t._ExitFullscreen=function(){var e=document;document.exitFullscreen?document.exitFullscreen():e.mozCancelFullScreen?e.mozCancelFullScreen():e.webkitCancelFullScreen?e.webkitCancelFullScreen():e.msCancelFullScreen&&e.msCancelFullScreen()},t.ALPHA_DISABLE=0,t.ALPHA_ADD=1,t.ALPHA_COMBINE=2,t.ALPHA_SUBTRACT=3,t.ALPHA_MULTIPLY=4,t.ALPHA_MAXIMIZED=5,t.ALPHA_ONEONE=6,t.ALPHA_PREMULTIPLIED=7,t.ALPHA_PREMULTIPLIED_PORTERDUFF=8,t.ALPHA_INTERPOLATE=9,t.ALPHA_SCREENMODE=10,t.DELAYLOADSTATE_NONE=0,t.DELAYLOADSTATE_LOADED=1,t.DELAYLOADSTATE_LOADING=2,t.DELAYLOADSTATE_NOTLOADED=4,t.NEVER=512,t.ALWAYS=519,t.LESS=513,t.EQUAL=514,t.LEQUAL=515,t.GREATER=516,t.GEQUAL=518,t.NOTEQUAL=517,t.KEEP=7680,t.REPLACE=7681,t.INCR=7682,t.DECR=7683,t.INVERT=5386,t.INCR_WRAP=34055,t.DECR_WRAP=34056,t.TEXTURE_CLAMP_ADDRESSMODE=0,t.TEXTURE_WRAP_ADDRESSMODE=1,t.TEXTURE_MIRROR_ADDRESSMODE=2,t.TEXTUREFORMAT_ALPHA=0,t.TEXTUREFORMAT_LUMINANCE=1,t.TEXTUREFORMAT_LUMINANCE_ALPHA=2,t.TEXTUREFORMAT_RGB=4,t.TEXTUREFORMAT_RGBA=5,t.TEXTUREFORMAT_RED=6,t.TEXTUREFORMAT_R=6,t.TEXTUREFORMAT_RG=7,t.TEXTUREFORMAT_RED_INTEGER=8,t.TEXTUREFORMAT_R_INTEGER=8,t.TEXTUREFORMAT_RG_INTEGER=9,t.TEXTUREFORMAT_RGB_INTEGER=10,t.TEXTUREFORMAT_RGBA_INTEGER=11,t.TEXTURETYPE_UNSIGNED_BYTE=0,t.TEXTURETYPE_UNSIGNED_INT=0,t.TEXTURETYPE_FLOAT=1,t.TEXTURETYPE_HALF_FLOAT=2,t.TEXTURETYPE_BYTE=3,t.TEXTURETYPE_SHORT=4,t.TEXTURETYPE_UNSIGNED_SHORT=5,t.TEXTURETYPE_INT=6,t.TEXTURETYPE_UNSIGNED_INTEGER=7,t.TEXTURETYPE_UNSIGNED_SHORT_4_4_4_4=8,t.TEXTURETYPE_UNSIGNED_SHORT_5_5_5_1=9,t.TEXTURETYPE_UNSIGNED_SHORT_5_6_5=10,t.TEXTURETYPE_UNSIGNED_INT_2_10_10_10_REV=11,t.TEXTURETYPE_UNSIGNED_INT_24_8=12,t.TEXTURETYPE_UNSIGNED_INT_10F_11F_11F_REV=13,t.TEXTURETYPE_UNSIGNED_INT_5_9_9_9_REV=14,t.TEXTURETYPE_FLOAT_32_UNSIGNED_INT_24_8_REV=15,t.TEXTURE_NEAREST_SAMPLINGMODE=1,t.TEXTURE_BILINEAR_SAMPLINGMODE=2,t.TEXTURE_TRILINEAR_SAMPLINGMODE=3,t.TEXTURE_NEAREST_NEAREST_MIPLINEAR=8,t.TEXTURE_LINEAR_LINEAR_MIPNEAREST=11,t.TEXTURE_LINEAR_LINEAR_MIPLINEAR=3,t.TEXTURE_NEAREST_NEAREST_MIPNEAREST=4,t.TEXTURE_NEAREST_LINEAR_MIPNEAREST=5,t.TEXTURE_NEAREST_LINEAR_MIPLINEAR=6,t.TEXTURE_NEAREST_LINEAR=7,t.TEXTURE_NEAREST_NEAREST=1,t.TEXTURE_LINEAR_NEAREST_MIPNEAREST=9,t.TEXTURE_LINEAR_NEAREST_MIPLINEAR=10,t.TEXTURE_LINEAR_LINEAR=2,t.TEXTURE_LINEAR_NEAREST=12,t.TEXTURE_EXPLICIT_MODE=0,t.TEXTURE_SPHERICAL_MODE=1,t.TEXTURE_PLANAR_MODE=2,t.TEXTURE_CUBIC_MODE=3,t.TEXTURE_PROJECTION_MODE=4,t.TEXTURE_SKYBOX_MODE=5,t.TEXTURE_INVCUBIC_MODE=6,t.TEXTURE_EQUIRECTANGULAR_MODE=7,t.TEXTURE_FIXED_EQUIRECTANGULAR_MODE=8,t.TEXTURE_FIXED_EQUIRECTANGULAR_MIRRORED_MODE=9,t.SCALEMODE_FLOOR=1,t.SCALEMODE_NEAREST=2,t.SCALEMODE_CEILING=3,t._RescalePostProcessFactory=null,t}(h.a)},function(e,t,i){"use strict";i.d(t,"a",(function(){return f}));var r=i(1),n=i(3),o=i(13),s=i(4),a=i(23),h=i(42),l=i(60),c=i(12),u=i(50),f=function(){function e(t,i,r){this.metadata=null,this.reservedDataStore=null,this.checkReadyOnEveryCall=!1,this.checkReadyOnlyOnce=!1,this.state="",this._alpha=1,this._backFaceCulling=!0,this.onCompiled=null,this.onError=null,this.getRenderTargetTextures=null,this.doNotSerialize=!1,this._storeEffectOnSubMeshes=!1,this.animations=null,this.onDisposeObservable=new s.a,this._onDisposeObserver=null,this._onUnBindObservable=null,this._onBindObserver=null,this._alphaMode=2,this._needDepthPrePass=!1,this.disableDepthWrite=!1,this.forceDepthWrite=!1,this.depthFunction=0,this.separateCullingPass=!1,this._fogEnabled=!0,this.pointSize=1,this.zOffset=0,this._effect=null,this._useUBO=!1,this._fillMode=e.TriangleFillMode,this._cachedDepthWriteState=!1,this._cachedDepthFunctionState=0,this._indexInSceneMaterialArray=-1,this.meshMap=null,this.name=t,this.id=t||o.b.RandomId(),this._scene=i||a.a.LastCreatedScene,this.uniqueId=this._scene.getUniqueId(),this._scene.useRightHandedSystem?this.sideOrientation=e.ClockWiseSideOrientation:this.sideOrientation=e.CounterClockWiseSideOrientation,this._uniformBuffer=new l.a(this._scene.getEngine()),this._useUBO=this.getScene().getEngine().supportsUniformBuffers,r||this._scene.addMaterial(this),this._scene.useMaterialMeshMap&&(this.meshMap={})}return Object.defineProperty(e.prototype,"alpha",{get:function(){return this._alpha},set:function(t){this._alpha!==t&&(this._alpha=t,this.markAsDirty(e.MiscDirtyFlag))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"backFaceCulling",{get:function(){return this._backFaceCulling},set:function(t){this._backFaceCulling!==t&&(this._backFaceCulling=t,this.markAsDirty(e.TextureDirtyFlag))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"hasRenderTargetTextures",{get:function(){return!1},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"onDispose",{set:function(e){this._onDisposeObserver&&this.onDisposeObservable.remove(this._onDisposeObserver),this._onDisposeObserver=this.onDisposeObservable.add(e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"onBindObservable",{get:function(){return this._onBindObservable||(this._onBindObservable=new s.a),this._onBindObservable},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"onBind",{set:function(e){this._onBindObserver&&this.onBindObservable.remove(this._onBindObserver),this._onBindObserver=this.onBindObservable.add(e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"onUnBindObservable",{get:function(){return this._onUnBindObservable||(this._onUnBindObservable=new s.a),this._onUnBindObservable},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"alphaMode",{get:function(){return this._alphaMode},set:function(t){this._alphaMode!==t&&(this._alphaMode=t,this.markAsDirty(e.TextureDirtyFlag))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"needDepthPrePass",{get:function(){return this._needDepthPrePass},set:function(e){this._needDepthPrePass!==e&&(this._needDepthPrePass=e,this._needDepthPrePass&&(this.checkReadyOnEveryCall=!0))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"fogEnabled",{get:function(){return this._fogEnabled},set:function(t){this._fogEnabled!==t&&(this._fogEnabled=t,this.markAsDirty(e.MiscDirtyFlag))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"wireframe",{get:function(){switch(this._fillMode){case e.WireFrameFillMode:case e.LineListDrawMode:case e.LineLoopDrawMode:case e.LineStripDrawMode:return!0}return this._scene.forceWireframe},set:function(t){this.fillMode=t?e.WireFrameFillMode:e.TriangleFillMode},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"pointsCloud",{get:function(){switch(this._fillMode){case e.PointFillMode:case e.PointListDrawMode:return!0}return this._scene.forcePointsCloud},set:function(t){this.fillMode=t?e.PointFillMode:e.TriangleFillMode},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"fillMode",{get:function(){return this._fillMode},set:function(t){this._fillMode!==t&&(this._fillMode=t,this.markAsDirty(e.MiscDirtyFlag))},enumerable:!0,configurable:!0}),e.prototype.toString=function(e){return"Name: "+this.name},e.prototype.getClassName=function(){return"Material"},Object.defineProperty(e.prototype,"isFrozen",{get:function(){return this.checkReadyOnlyOnce},enumerable:!0,configurable:!0}),e.prototype.freeze=function(){this.markDirty(),this.checkReadyOnlyOnce=!0},e.prototype.unfreeze=function(){this.markDirty(),this.checkReadyOnlyOnce=!1},e.prototype.isReady=function(e,t){return!0},e.prototype.isReadyForSubMesh=function(e,t,i){return!1},e.prototype.getEffect=function(){return this._effect},e.prototype.getScene=function(){return this._scene},e.prototype.needAlphaBlending=function(){return this.alpha<1},e.prototype.needAlphaBlendingForMesh=function(e){return this.needAlphaBlending()||e.visibility<1||e.hasVertexAlpha},e.prototype.needAlphaTesting=function(){return!1},e.prototype.getAlphaTestTexture=function(){return null},e.prototype.markDirty=function(){for(var e=0,t=this.getScene().meshes;ethis.data.length&&(this.data.length*=2)},e.prototype.forEach=function(e){for(var t=0;tthis.data.length&&(this.data.length=2*(this.length+e.length));for(var t=0;t=this.length?-1:t},e.prototype.contains=function(e){return-1!==this.indexOf(e)},e._GlobalId=0,e}(),o=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t._duplicateId=0,t}return Object(r.c)(t,e),t.prototype.push=function(t){e.prototype.push.call(this,t),t.__smartArrayFlags||(t.__smartArrayFlags={}),t.__smartArrayFlags[this._id]=this._duplicateId},t.prototype.pushNoDuplicate=function(e){return(!e.__smartArrayFlags||e.__smartArrayFlags[this._id]!==this._duplicateId)&&(this.push(e),!0)},t.prototype.reset=function(){e.prototype.reset.call(this),this._duplicateId++},t.prototype.concatWithNoDuplicate=function(e){if(0!==e.length){this.length+e.length>this.data.length&&(this.data.length=2*(this.length+e.length));for(var t=0;t=1&&i<=7)return!0}return!1},enumerable:!0,configurable:!0}),e.HasSpecificTrigger=function(t){for(var i in e.Triggers){if(e.Triggers.hasOwnProperty(i))if(parseInt(i)===t)return!0}return!1},e.Triggers={},e}(),P=i(45),R=function(){function e(){this._singleClick=!1,this._doubleClick=!1,this._hasSwiped=!1,this._ignore=!1}return Object.defineProperty(e.prototype,"singleClick",{get:function(){return this._singleClick},set:function(e){this._singleClick=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"doubleClick",{get:function(){return this._doubleClick},set:function(e){this._doubleClick=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"hasSwiped",{get:function(){return this._hasSwiped},set:function(e){this._hasSwiped=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"ignore",{get:function(){return this._ignore},set:function(e){this._ignore=e},enumerable:!0,configurable:!0}),e}(),I=function(){function e(e){this._wheelEventName="",this._meshPickProceed=!1,this._currentPickResult=null,this._previousPickResult=null,this._totalPointersPressed=0,this._doubleClickOccured=!1,this._pointerX=0,this._pointerY=0,this._startingPointerPosition=new c.d(0,0),this._previousStartingPointerPosition=new c.d(0,0),this._startingPointerTime=0,this._previousStartingPointerTime=0,this._pointerCaptures={},this._scene=e}return Object.defineProperty(e.prototype,"meshUnderPointer",{get:function(){return this._pointerOverMesh},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"unTranslatedPointer",{get:function(){return new c.d(this._unTranslatedPointerX,this._unTranslatedPointerY)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"pointerX",{get:function(){return this._pointerX},set:function(e){this._pointerX=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"pointerY",{get:function(){return this._pointerY},set:function(e){this._pointerY=e},enumerable:!0,configurable:!0}),e.prototype._updatePointerPosition=function(e){var t=this._scene.getEngine().getInputElementClientRect();t&&(this._pointerX=e.clientX-t.left,this._pointerY=e.clientY-t.top,this._unTranslatedPointerX=this._pointerX,this._unTranslatedPointerY=this._pointerY)},e.prototype._processPointerMove=function(e,t){var i=this._scene,r=i.getEngine(),n=r.getInputElement();if(n){n.tabIndex=r.canvasTabIndex,i.doNotHandleCursors||(n.style.cursor=i.defaultCursor);var o=!!(e&&e.hit&&e.pickedMesh);o?(i.setPointerOverMesh(e.pickedMesh),this._pointerOverMesh&&this._pointerOverMesh.actionManager&&this._pointerOverMesh.actionManager.hasPointerTriggers&&(i.doNotHandleCursors||(this._pointerOverMesh.actionManager.hoverCursor?n.style.cursor=this._pointerOverMesh.actionManager.hoverCursor:n.style.cursor=i.hoverCursor))):i.setPointerOverMesh(null);for(var s=0,a=i._pointerMoveStage;se.LongPressDelay&&!r._isPointerSwiping()&&(r._startingPointerTime=0,o.processTrigger(8,v.CreateNew(t.pickedMesh,i)))}),e.LongPressDelay)}}else for(var s=0,a=n._pointerDownStage;se.DragMovementThreshold||Math.abs(this._startingPointerPosition.y-this._pointerY)>e.DragMovementThreshold},e.prototype.simulatePointerUp=function(e,t,i){var r=new PointerEvent("pointerup",t),n=new R;i?n.doubleClick=!0:n.singleClick=!0,this._checkPrePointerObservable(e,r,C.a.POINTERUP)||this._processPointerUp(e,r,n)},e.prototype._processPointerUp=function(e,t,i){var r=this._scene;if(e&&e&&e.pickedMesh){if(this._pickedUpMesh=e.pickedMesh,this._pickedDownMesh===this._pickedUpMesh&&(r.onPointerPick&&r.onPointerPick(t,e),i.singleClick&&!i.ignore&&r.onPointerObservable.hasObservers())){var n=C.a.POINTERPICK,o=new C.b(n,t,e);this._setRayOnPointerInfo(o),r.onPointerObservable.notifyObservers(o,n)}var s=e.pickedMesh._getActionManagerForTrigger();if(s&&!i.ignore){s.processTrigger(7,v.CreateNew(e.pickedMesh,t)),!i.hasSwiped&&i.singleClick&&s.processTrigger(1,v.CreateNew(e.pickedMesh,t));var a=e.pickedMesh._getActionManagerForTrigger(6);i.doubleClick&&a&&a.processTrigger(6,v.CreateNew(e.pickedMesh,t))}}else if(!i.ignore)for(var h=0,l=r._pointerUpStage;he.DoubleClickDelay&&!s._doubleClickOccured||t!==s._previousButtonPressed)&&(s._doubleClickOccured=!1,i.singleClick=!0,i.ignore=!1,r(i,s._currentPickResult))},this._initClickEvent=function(t,i,r,n){var o=new R;s._currentPickResult=null;var a=null,h=t.hasSpecificMask(C.a.POINTERPICK)||i.hasSpecificMask(C.a.POINTERPICK)||t.hasSpecificMask(C.a.POINTERTAP)||i.hasSpecificMask(C.a.POINTERTAP)||t.hasSpecificMask(C.a.POINTERDOUBLETAP)||i.hasSpecificMask(C.a.POINTERDOUBLETAP);!h&&S&&(a=s._initActionManager(a,o))&&(h=a.hasPickTriggers);var l=!1;if(h){var c=r.button;if(o.hasSwiped=s._isPointerSwiping(),!o.hasSwiped){var u=!e.ExclusiveDoubleClickMode;u||(u=!t.hasSpecificMask(C.a.POINTERDOUBLETAP)&&!i.hasSpecificMask(C.a.POINTERDOUBLETAP))&&!S.HasSpecificTrigger(6)&&(a=s._initActionManager(a,o))&&(u=!a.hasSpecificTrigger(6)),u?(Date.now()-s._previousStartingPointerTime>e.DoubleClickDelay||c!==s._previousButtonPressed)&&(o.singleClick=!0,n(o,s._currentPickResult),l=!0):(s._previousDelayedSimpleClickTimeout=s._delayedSimpleClickTimeout,s._delayedSimpleClickTimeout=window.setTimeout(s._delayedSimpleClick.bind(s,c,o,n),e.DoubleClickDelay));var f=t.hasSpecificMask(C.a.POINTERDOUBLETAP)||i.hasSpecificMask(C.a.POINTERDOUBLETAP);!f&&S.HasSpecificTrigger(6)&&(a=s._initActionManager(a,o))&&(f=a.hasSpecificTrigger(6)),f&&(c===s._previousButtonPressed&&Date.now()-s._previousStartingPointerTime0){for(var e=0,t=this._transientComponents;e0)return!1;for(e=0;e0,n=0,o=this._isReadyForMeshStage;n0)for(var s=0,a=this.activeCameras;s0},enumerable:!0,configurable:!0}),t.prototype.executeWhenReady=function(e){var t=this;this.onReadyObservable.add(e),-1===this._executeWhenReadyTimeoutId&&(this._executeWhenReadyTimeoutId=setTimeout((function(){t._checkIsReady()}),150))},t.prototype.whenReadyAsync=function(){var e=this;return new Promise((function(t){e.executeWhenReady((function(){t()}))}))},t.prototype._checkIsReady=function(){var e=this;return this._registerTransientComponents(),this.isReady()?(this.onReadyObservable.notifyObservers(this),this.onReadyObservable.clear(),void(this._executeWhenReadyTimeoutId=-1)):this._isDisposed?(this.onReadyObservable.clear(),void(this._executeWhenReadyTimeoutId=-1)):void(this._executeWhenReadyTimeoutId=setTimeout((function(){e._checkIsReady()}),150))},Object.defineProperty(t.prototype,"animatables",{get:function(){return this._activeAnimatables},enumerable:!0,configurable:!0}),t.prototype.resetLastAnimationTimeFrame=function(){this._animationTimeLast=o.a.Now},t.prototype.getViewMatrix=function(){return this._viewMatrix},t.prototype.getProjectionMatrix=function(){return this._projectionMatrix},t.prototype.getTransformMatrix=function(){return this._transformMatrix},t.prototype.setTransformMatrix=function(e,t,i,r){this._viewUpdateFlag===e.updateFlag&&this._projectionUpdateFlag===t.updateFlag||(this._viewUpdateFlag=e.updateFlag,this._projectionUpdateFlag=t.updateFlag,this._viewMatrix=e,this._projectionMatrix=t,this._viewMatrix.multiplyToRef(this._projectionMatrix,this._transformMatrix),this._frustumPlanes?L.a.GetPlanesToRef(this._transformMatrix,this._frustumPlanes):this._frustumPlanes=L.a.GetPlanes(this._transformMatrix),this._multiviewSceneUbo&&this._multiviewSceneUbo.useUbo?this._updateMultiviewUbo(i,r):this._sceneUbo.useUbo&&(this._sceneUbo.updateMatrix("viewProjection",this._transformMatrix),this._sceneUbo.updateMatrix("view",this._viewMatrix),this._sceneUbo.update()))},t.prototype.getSceneUniformBuffer=function(){return this._multiviewSceneUbo?this._multiviewSceneUbo:this._sceneUbo},t.prototype.getUniqueId=function(){return F.UniqueId},t.prototype.addMesh=function(e,t){var i=this;void 0===t&&(t=!1),this._blockEntityCollection||(this.meshes.push(e),e._resyncLightSources(),e.parent||e._addToSceneRootNodes(),this.onNewMeshAddedObservable.notifyObservers(e),t&&e.getChildMeshes().forEach((function(e){i.addMesh(e)})))},t.prototype.removeMesh=function(e,t){var i=this;void 0===t&&(t=!1);var r=this.meshes.indexOf(e);return-1!==r&&(this.meshes[r]=this.meshes[this.meshes.length-1],this.meshes.pop(),e.parent||e._removeFromSceneRootNodes()),this.onMeshRemovedObservable.notifyObservers(e),t&&e.getChildMeshes().forEach((function(e){i.removeMesh(e)})),r},t.prototype.addTransformNode=function(e){this._blockEntityCollection||(e._indexInSceneTransformNodesArray=this.transformNodes.length,this.transformNodes.push(e),e.parent||e._addToSceneRootNodes(),this.onNewTransformNodeAddedObservable.notifyObservers(e))},t.prototype.removeTransformNode=function(e){var t=e._indexInSceneTransformNodesArray;if(-1!==t){if(t!==this.transformNodes.length-1){var i=this.transformNodes[this.transformNodes.length-1];this.transformNodes[t]=i,i._indexInSceneTransformNodesArray=t}e._indexInSceneTransformNodesArray=-1,this.transformNodes.pop(),e.parent||e._removeFromSceneRootNodes()}return this.onTransformNodeRemovedObservable.notifyObservers(e),t},t.prototype.removeSkeleton=function(e){var t=this.skeletons.indexOf(e);return-1!==t&&(this.skeletons.splice(t,1),this.onSkeletonRemovedObservable.notifyObservers(e)),t},t.prototype.removeMorphTargetManager=function(e){var t=this.morphTargetManagers.indexOf(e);return-1!==t&&this.morphTargetManagers.splice(t,1),t},t.prototype.removeLight=function(e){var t=this.lights.indexOf(e);if(-1!==t){for(var i=0,r=this.meshes;i0?this.activeCamera=this.cameras[0]:this.activeCamera=null),this.onCameraRemovedObservable.notifyObservers(e),t},t.prototype.removeParticleSystem=function(e){var t=this.particleSystems.indexOf(e);return-1!==t&&this.particleSystems.splice(t,1),t},t.prototype.removeAnimation=function(e){var t=this.animations.indexOf(e);return-1!==t&&this.animations.splice(t,1),t},t.prototype.stopAnimation=function(e,t,i){},t.prototype.removeAnimationGroup=function(e){var t=this.animationGroups.indexOf(e);return-1!==t&&this.animationGroups.splice(t,1),t},t.prototype.removeMultiMaterial=function(e){var t=this.multiMaterials.indexOf(e);return-1!==t&&this.multiMaterials.splice(t,1),t},t.prototype.removeMaterial=function(e){var t=e._indexInSceneMaterialArray;if(-1!==t&&t=0;t--)if(this.materials[t].id===e)return this.materials[t];return null},t.prototype.getMaterialByName=function(e){for(var t=0;t=0;t--)if(this.meshes[t].id===e)return this.meshes[t];return null},t.prototype.getLastEntryByID=function(e){var t;for(t=this.meshes.length-1;t>=0;t--)if(this.meshes[t].id===e)return this.meshes[t];for(t=this.transformNodes.length-1;t>=0;t--)if(this.transformNodes[t].id===e)return this.transformNodes[t];for(t=this.cameras.length-1;t>=0;t--)if(this.cameras[t].id===e)return this.cameras[t];for(t=this.lights.length-1;t>=0;t--)if(this.lights[t].id===e)return this.lights[t];return null},t.prototype.getNodeByID=function(e){var t=this.getMeshByID(e);if(t)return t;var i=this.getTransformNodeByID(e);if(i)return i;var r=this.getLightByID(e);if(r)return r;var n=this.getCameraByID(e);if(n)return n;var o=this.getBoneByID(e);return o||null},t.prototype.getNodeByName=function(e){var t=this.getMeshByName(e);if(t)return t;var i=this.getTransformNodeByName(e);if(i)return i;var r=this.getLightByName(e);if(r)return r;var n=this.getCameraByName(e);if(n)return n;var o=this.getBoneByName(e);return o||null},t.prototype.getMeshByName=function(e){for(var t=0;t=0;t--)if(this.skeletons[t].id===e)return this.skeletons[t];return null},t.prototype.getSkeletonByUniqueId=function(e){for(var t=0;t0&&0!=(s.layerMask&this.activeCamera.layerMask)&&(this._skipFrustumClipping||s.alwaysSelectAsActiveMesh||s.isInFrustum(this._frustumPlanes))&&(this._activeMeshes.push(s),this.activeCamera._activeMeshes.push(s),a!==s&&a._activate(this._renderId,!1),s._activate(this._renderId,!1)&&(s.isAnInstance?s._internalAbstractMeshDataInfo._actAsRegularMesh&&(a=s):a._internalAbstractMeshDataInfo._onlyForInstances=!1,a._internalAbstractMeshDataInfo._isActive=!0,this._activeMesh(s,a)),s._postActivate()))}}if(this.onAfterActiveMeshesEvaluationObservable.notifyObservers(this),this.particlesEnabled){this.onBeforeParticlesRenderingObservable.notifyObservers(this);for(var h=0;h0)for(var n=this.getActiveSubMeshCandidates(t),o=n.length,s=0;s1)this.activeCamera.outputRenderTarget._bindFrameBuffer();else{var e=this.activeCamera.outputRenderTarget.getInternalTexture();e?this.getEngine().bindFramebuffer(e):M.a.Error("Camera contains invalid customDefaultRenderTarget")}}else this.getEngine().restoreDefaultFramebuffer()},t.prototype._renderForCamera=function(e,t){if(!e||!e._skipRendering){var i=this._engine;if(this._activeCamera=e,!this.activeCamera)throw new Error("Active camera not set");i.setViewport(this.activeCamera.viewport),this.resetCachedMaterial(),this._renderId++,this.getEngine().getCaps().multiview&&e.outputRenderTarget&&e.outputRenderTarget.getViewCount()>1?this.setTransformMatrix(e._rigCameras[0].getViewMatrix(),e._rigCameras[0].getProjectionMatrix(),e._rigCameras[1].getViewMatrix(),e._rigCameras[1].getProjectionMatrix()):this.updateTransformMatrix(),this.onBeforeCameraRenderObservable.notifyObservers(this.activeCamera),this._evaluateActiveMeshes();for(var r=0;r0&&this._renderTargets.concatWithNoDuplicate(e.customRenderTargets),t&&t.customRenderTargets&&t.customRenderTargets.length>0&&this._renderTargets.concatWithNoDuplicate(t.customRenderTargets);for(var s=0,a=this._gatherActiveCameraRenderTargetsStage;s0){n.b.StartPerformanceCounter("Render targets",this._renderTargets.length>0);for(var l=0;l0),this._renderId++}for(var f=0,d=this._cameraDrawRenderTargetStage;f1&&this.getEngine().getCaps().multiview)return this._renderForCamera(e),void this.onAfterRenderCameraObservable.notifyObservers(e);if(e._useMultiviewToSingleView)this._renderMultiviewToSingleView(e);else for(var t=0;t-1&&(13===r.trigger&&r._executeCurrent(v.CreateNew(t,void 0,o)),t.actionManager.hasSpecificTrigger(13,(function(e){var t=e instanceof f.a?e:e.mesh;return o===t}))&&13!==r.trigger||t._intersectionsInProgress.splice(a,1))}}}},t.prototype._advancePhysicsEngineStep=function(e){},t.prototype._animate=function(){},t.prototype.animate=function(){if(this._engine.isDeterministicLockStep()){var e=Math.max(t.MinDeltaTime,Math.min(this._engine.getDeltaTime(),t.MaxDeltaTime))+this._timeAccumulator,i=this._engine.getTimeStep(),r=1e3/i/1e3,n=0,o=this._engine.getLockstepMaxSteps(),s=Math.floor(e/i);for(s=Math.min(s,o);e>0&&n0)for(var o=0;o0),this._intermediateRendering=!0;for(var c=0;c0),this._intermediateRendering=!1,this._renderId++}this.activeCamera=l,this._bindFrameBuffer(),this.onAfterRenderTargetsRenderObservable.notifyObservers(this);for(var f=0,p=this._beforeClearStage;f0)for(o=0;o0&&this._engine.clear(null,!1,!0,!0),this._processSubCameras(this.activeCameras[o]);else{if(!this.activeCamera)throw new Error("No camera defined");this._processSubCameras(this.activeCamera)}this._checkIntersections();for(var m=0,b=this._afterRenderStage;m-1&&this._engine.scenes.splice(n,1),this._engine.wipeCaches(!0),this._isDisposed=!0},Object.defineProperty(t.prototype,"isDisposed",{get:function(){return this._isDisposed},enumerable:!0,configurable:!0}),t.prototype.clearCachedVertexData=function(){for(var e=0;ee.zIndex){this._children.splice(i,0,e),t=!0;break}t||this._children.push(e),e.parent=this,this._markAsDirty()},t.prototype._offsetLeft=function(t){e.prototype._offsetLeft.call(this,t);for(var i=0,r=this._children;i=0&&this.width!==r+"px"&&(this.width=r+"px",this._rebuildLayout=!0),this.adaptHeightToChildren&&o>=0&&this.height!==o+"px"&&(this.height=o+"px",this._rebuildLayout=!0),this._postMeasure()}i++}while(this._rebuildLayout&&i=3&&this.logLayoutCycleErrors&&n.a.Error("Layout cycle detected in GUI (Container name="+this.name+", uniqueId="+this.uniqueId+")"),t.restore(),this._isDirty&&(this.invalidateRect(),this._isDirty=!1),!0},t.prototype._postMeasure=function(){},t.prototype._draw=function(e,t){this._localDraw(e),this.clipChildren&&this._clipForChildren(e);for(var i=0,r=this._children;i=0;h--){var l=this._children[h];if(l._processPicking(t,i,r,n,o,s,a))return l.hoverCursor&&this._host._changeCursor(l.hoverCursor),!0}return!!this.isHitTestVisible&&this._processObservables(r,t,i,n,o,s,a)},t.prototype._additionalProcessing=function(t,i){e.prototype._additionalProcessing.call(this,t,i),this._measureForChildren.copyFrom(this._currentMeasure)},t.prototype.dispose=function(){e.prototype.dispose.call(this);for(var t=this.children.length-1;t>=0;t--)this.children[t].dispose()},t}(o.a);a.a.RegisteredTypes["BABYLON.GUI.Container"]=h},function(e,t,i){"use strict";i.d(t,"a",(function(){return f}));var r=i(30),n=i(0),o=i(16),s=function(){function e(e,t,i){this.vectors=r.a.BuildArray(8,n.e.Zero),this.center=n.e.Zero(),this.centerWorld=n.e.Zero(),this.extendSize=n.e.Zero(),this.extendSizeWorld=n.e.Zero(),this.directions=r.a.BuildArray(3,n.e.Zero),this.vectorsWorld=r.a.BuildArray(8,n.e.Zero),this.minimumWorld=n.e.Zero(),this.maximumWorld=n.e.Zero(),this.minimum=n.e.Zero(),this.maximum=n.e.Zero(),this.reConstruct(e,t,i)}return e.prototype.reConstruct=function(e,t,i){var r=e.x,o=e.y,s=e.z,a=t.x,h=t.y,l=t.z,c=this.vectors;this.minimum.copyFromFloats(r,o,s),this.maximum.copyFromFloats(a,h,l),c[0].copyFromFloats(r,o,s),c[1].copyFromFloats(a,h,l),c[2].copyFromFloats(a,o,s),c[3].copyFromFloats(r,h,s),c[4].copyFromFloats(r,o,l),c[5].copyFromFloats(a,h,s),c[6].copyFromFloats(r,h,l),c[7].copyFromFloats(a,o,l),t.addToRef(e,this.center).scaleInPlace(.5),t.subtractToRef(e,this.extendSize).scaleInPlace(.5),this._worldMatrix=i||n.a.IdentityReadOnly,this._update(this._worldMatrix)},e.prototype.scale=function(t){var i=e.TmpVector3,r=this.maximum.subtractToRef(this.minimum,i[0]),n=r.length();r.normalizeFromLength(n);var o=n*t,s=r.scaleInPlace(.5*o),a=this.center.subtractToRef(s,i[1]),h=this.center.addToRef(s,i[2]);return this.reConstruct(a,h,this._worldMatrix),this},e.prototype.getWorldMatrix=function(){return this._worldMatrix},e.prototype._update=function(e){var t=this.minimumWorld,i=this.maximumWorld,r=this.directions,o=this.vectorsWorld,s=this.vectors;if(e.isIdentity()){t.copyFrom(this.minimum),i.copyFrom(this.maximum);for(a=0;a<8;++a)o[a].copyFrom(s[a]);this.extendSizeWorld.copyFrom(this.extendSize),this.centerWorld.copyFrom(this.center)}else{t.setAll(Number.MAX_VALUE),i.setAll(-Number.MAX_VALUE);for(var a=0;a<8;++a){var h=o[a];n.e.TransformCoordinatesToRef(s[a],e,h),t.minimizeInPlace(h),i.maximizeInPlace(h)}i.subtractToRef(t,this.extendSizeWorld).scaleInPlace(.5),i.addToRef(t,this.centerWorld).scaleInPlace(.5)}n.e.FromArrayToRef(e.m,0,r[0]),n.e.FromArrayToRef(e.m,4,r[1]),n.e.FromArrayToRef(e.m,8,r[2]),this._worldMatrix=e},e.prototype.isInFrustum=function(t){return e.IsInFrustum(this.vectorsWorld,t)},e.prototype.isCompletelyInFrustum=function(t){return e.IsCompletelyInFrustum(this.vectorsWorld,t)},e.prototype.intersectsPoint=function(e){var t=this.minimumWorld,i=this.maximumWorld,r=t.x,n=t.y,s=t.z,a=i.x,h=i.y,l=i.z,c=e.x,u=e.y,f=e.z,d=-o.a;return!(a-cc-r)&&(!(h-uu-n)&&!(l-ff-s))},e.prototype.intersectsSphere=function(t){return e.IntersectsSphere(this.minimumWorld,this.maximumWorld,t.centerWorld,t.radiusWorld)},e.prototype.intersectsMinMax=function(e,t){var i=this.minimumWorld,r=this.maximumWorld,n=i.x,o=i.y,s=i.z,a=r.x,h=r.y,l=r.z,c=e.x,u=e.y,f=e.z,d=t.x,p=t.y,_=t.z;return!(ad)&&(!(hp)&&!(l_))},e.Intersects=function(e,t){return e.intersectsMinMax(t.minimumWorld,t.maximumWorld)},e.IntersectsSphere=function(t,i,r,o){var s=e.TmpVector3[0];return n.e.ClampToRef(r,t,i,s),n.e.DistanceSquared(r,s)<=o*o},e.IsCompletelyInFrustum=function(e,t){for(var i=0;i<6;++i)for(var r=t[i],n=0;n<8;++n)if(r.dotCoordinate(e[n])<0)return!1;return!0},e.IsInFrustum=function(e,t){for(var i=0;i<6;++i){for(var r=!0,n=t[i],o=0;o<8;++o)if(n.dotCoordinate(e[o])>=0){r=!1;break}if(r)return!1}return!0},e.TmpVector3=r.a.BuildArray(3,n.e.Zero),e}(),a=i(66),h={min:0,max:0},l={min:0,max:0},c=function(e,t,i){var r=n.e.Dot(t.centerWorld,e),o=Math.abs(n.e.Dot(t.directions[0],e))*t.extendSize.x+Math.abs(n.e.Dot(t.directions[1],e))*t.extendSize.y+Math.abs(n.e.Dot(t.directions[2],e))*t.extendSize.z;i.min=r-o,i.max=r+o},u=function(e,t,i){return c(e,t,h),c(e,i,l),!(h.min>l.max||l.min>h.max)},f=function(){function e(e,t,i){this._isLocked=!1,this.boundingBox=new s(e,t,i),this.boundingSphere=new a.a(e,t,i)}return e.prototype.reConstruct=function(e,t,i){this.boundingBox.reConstruct(e,t,i),this.boundingSphere.reConstruct(e,t,i)},Object.defineProperty(e.prototype,"minimum",{get:function(){return this.boundingBox.minimum},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"maximum",{get:function(){return this.boundingBox.maximum},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isLocked",{get:function(){return this._isLocked},set:function(e){this._isLocked=e},enumerable:!0,configurable:!0}),e.prototype.update=function(e){this._isLocked||(this.boundingBox._update(e),this.boundingSphere._update(e))},e.prototype.centerOn=function(t,i){var r=e.TmpVector3[0].copyFrom(t).subtractInPlace(i),n=e.TmpVector3[1].copyFrom(t).addInPlace(i);return this.boundingBox.reConstruct(r,n,this.boundingBox.getWorldMatrix()),this.boundingSphere.reConstruct(r,n,this.boundingBox.getWorldMatrix()),this},e.prototype.scale=function(e){return this.boundingBox.scale(e),this.boundingSphere.scale(e),this},e.prototype.isInFrustum=function(e,t){return void 0===t&&(t=0),!(2!==t&&3!==t||!this.boundingSphere.isCenterInFrustum(e))||!!this.boundingSphere.isInFrustum(e)&&(!(1!==t&&3!==t)||this.boundingBox.isInFrustum(e))},Object.defineProperty(e.prototype,"diagonalLength",{get:function(){var t=this.boundingBox;return t.maximumWorld.subtractToRef(t.minimumWorld,e.TmpVector3[0]).length()},enumerable:!0,configurable:!0}),e.prototype.isCompletelyInFrustum=function(e){return this.boundingBox.isCompletelyInFrustum(e)},e.prototype._checkCollision=function(e){return e._canDoCollision(this.boundingSphere.centerWorld,this.boundingSphere.radiusWorld,this.boundingBox.minimumWorld,this.boundingBox.maximumWorld)},e.prototype.intersectsPoint=function(e){return!!this.boundingSphere.centerWorld&&(!!this.boundingSphere.intersectsPoint(e)&&!!this.boundingBox.intersectsPoint(e))},e.prototype.intersects=function(e,t){if(!a.a.Intersects(this.boundingSphere,e.boundingSphere))return!1;if(!s.Intersects(this.boundingBox,e.boundingBox))return!1;if(!t)return!0;var i=this.boundingBox,r=e.boundingBox;return!!u(i.directions[0],i,r)&&(!!u(i.directions[1],i,r)&&(!!u(i.directions[2],i,r)&&(!!u(r.directions[0],i,r)&&(!!u(r.directions[1],i,r)&&(!!u(r.directions[2],i,r)&&(!!u(n.e.Cross(i.directions[0],r.directions[0]),i,r)&&(!!u(n.e.Cross(i.directions[0],r.directions[1]),i,r)&&(!!u(n.e.Cross(i.directions[0],r.directions[2]),i,r)&&(!!u(n.e.Cross(i.directions[1],r.directions[0]),i,r)&&(!!u(n.e.Cross(i.directions[1],r.directions[1]),i,r)&&(!!u(n.e.Cross(i.directions[1],r.directions[2]),i,r)&&(!!u(n.e.Cross(i.directions[2],r.directions[0]),i,r)&&(!!u(n.e.Cross(i.directions[2],r.directions[1]),i,r)&&!!u(n.e.Cross(i.directions[2],r.directions[2]),i,r))))))))))))))},e.TmpVector3=r.a.BuildArray(2,n.e.Zero),e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return l}));var r=i(1),n=i(0),o=i(3),s=i(4),a=i(23),h=i(8),l=function(){function e(e,t){void 0===t&&(t=null),this.state="",this.metadata=null,this.reservedDataStore=null,this._doNotSerialize=!1,this._isDisposed=!1,this.animations=new Array,this._ranges={},this.onReady=null,this._isEnabled=!0,this._isParentEnabled=!0,this._isReady=!0,this._currentRenderId=-1,this._parentUpdateId=-1,this._childUpdateId=-1,this._waitingParentId=null,this._cache={},this._parentNode=null,this._children=null,this._worldMatrix=n.a.Identity(),this._worldMatrixDeterminant=0,this._worldMatrixDeterminantIsDirty=!0,this._sceneRootNodesIndex=-1,this._animationPropertiesOverride=null,this._isNode=!0,this.onDisposeObservable=new s.a,this._onDisposeObserver=null,this._behaviors=new Array,this.name=e,this.id=e,this._scene=t||a.a.LastCreatedScene,this.uniqueId=this._scene.getUniqueId(),this._initCache()}return e.AddNodeConstructor=function(e,t){this._NodeConstructors[e]=t},e.Construct=function(e,t,i,r){var n=this._NodeConstructors[e];return n?n(t,i,r):null},Object.defineProperty(e.prototype,"doNotSerialize",{get:function(){return!!this._doNotSerialize||!!this._parentNode&&this._parentNode.doNotSerialize},set:function(e){this._doNotSerialize=e},enumerable:!0,configurable:!0}),e.prototype.isDisposed=function(){return this._isDisposed},Object.defineProperty(e.prototype,"parent",{get:function(){return this._parentNode},set:function(e){if(this._parentNode!==e){var t=this._parentNode;if(this._parentNode&&void 0!==this._parentNode._children&&null!==this._parentNode._children){var i=this._parentNode._children.indexOf(this);-1!==i&&this._parentNode._children.splice(i,1),e||this._isDisposed||this._addToSceneRootNodes()}this._parentNode=e,this._parentNode&&(void 0!==this._parentNode._children&&null!==this._parentNode._children||(this._parentNode._children=new Array),this._parentNode._children.push(this),t||this._removeFromSceneRootNodes()),this._syncParentEnabledState()}},enumerable:!0,configurable:!0}),e.prototype._addToSceneRootNodes=function(){-1===this._sceneRootNodesIndex&&(this._sceneRootNodesIndex=this._scene.rootNodes.length,this._scene.rootNodes.push(this))},e.prototype._removeFromSceneRootNodes=function(){if(-1!==this._sceneRootNodesIndex){var e=this._scene.rootNodes,t=e.length-1;e[this._sceneRootNodesIndex]=e[t],e[this._sceneRootNodesIndex]._sceneRootNodesIndex=this._sceneRootNodesIndex,this._scene.rootNodes.pop(),this._sceneRootNodesIndex=-1}},Object.defineProperty(e.prototype,"animationPropertiesOverride",{get:function(){return this._animationPropertiesOverride?this._animationPropertiesOverride:this._scene.animationPropertiesOverride},set:function(e){this._animationPropertiesOverride=e},enumerable:!0,configurable:!0}),e.prototype.getClassName=function(){return"Node"},Object.defineProperty(e.prototype,"onDispose",{set:function(e){this._onDisposeObserver&&this.onDisposeObservable.remove(this._onDisposeObserver),this._onDisposeObserver=this.onDisposeObservable.add(e)},enumerable:!0,configurable:!0}),e.prototype.getScene=function(){return this._scene},e.prototype.getEngine=function(){return this._scene.getEngine()},e.prototype.addBehavior=function(e,t){var i=this;return void 0===t&&(t=!1),-1!==this._behaviors.indexOf(e)||(e.init(),this._scene.isLoading&&!t?this._scene.onDataLoadedObservable.addOnce((function(){e.attach(i)})):e.attach(this),this._behaviors.push(e)),this},e.prototype.removeBehavior=function(e){var t=this._behaviors.indexOf(e);return-1===t||(this._behaviors[t].detach(),this._behaviors.splice(t,1)),this},Object.defineProperty(e.prototype,"behaviors",{get:function(){return this._behaviors},enumerable:!0,configurable:!0}),e.prototype.getBehaviorByName=function(e){for(var t=0,i=this._behaviors;t=e||-1!==i.indexOf("file:")?-1:Math.pow(2,n)*t}},e}(),l=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return Object(r.c)(t,e),t._setPrototypeOf=Object.setPrototypeOf||function(e,t){return e.__proto__=t,e},t}(Error),c=i(41),u=i(24),f=i(69),d=function(e){function t(i,r){var o=e.call(this,i)||this;return o.name="LoadFileError",l._setPrototypeOf(o,t.prototype),r instanceof n.a?o.request=r:o.file=r,o}return Object(r.c)(t,e),t}(l),p=function(e){function t(i,r){var n=e.call(this,i)||this;return n.request=r,n.name="RequestFileError",l._setPrototypeOf(n,t.prototype),n}return Object(r.c)(t,e),t}(l),_=function(e){function t(i,r){var n=e.call(this,i)||this;return n.file=r,n.name="ReadFileError",l._setPrototypeOf(n,t.prototype),n}return Object(r.c)(t,e),t}(l),g=function(){function e(){}return e._CleanUrl=function(e){return e=e.replace(/#/gm,"%23")},e.SetCorsBehavior=function(t,i){if((!t||0!==t.indexOf("data:"))&&e.CorsBehavior)if("string"==typeof e.CorsBehavior||this.CorsBehavior instanceof String)i.crossOrigin=e.CorsBehavior;else{var r=e.CorsBehavior(t);r&&(i.crossOrigin=r)}},e.LoadImage=function(t,i,r,n,o){var s;void 0===o&&(o="");var h=!1;if(t instanceof ArrayBuffer||ArrayBuffer.isView(t)?"undefined"!=typeof Blob?(s=URL.createObjectURL(new Blob([t],{type:o})),h=!0):s="data:"+o+";base64,"+c.a.EncodeArrayBufferToBase64(t):t instanceof Blob?(s=URL.createObjectURL(t),h=!0):(s=e._CleanUrl(t),s=e.PreprocessUrl(t)),"undefined"==typeof Image)return e.LoadFile(s,(function(e){createImageBitmap(new Blob([e],{type:o})).then((function(e){i(e),h&&URL.revokeObjectURL(s)})).catch((function(e){r&&r("Error while trying to load image: "+t,e)}))}),void 0,n||void 0,!0,(function(e,i){r&&r("Error while trying to load image: "+t,i)})),null;var l=new Image;e.SetCorsBehavior(s,l);var u=function(){l.removeEventListener("load",u),l.removeEventListener("error",f),i(l),h&&l.src&&URL.revokeObjectURL(l.src)},f=function(e){l.removeEventListener("load",u),l.removeEventListener("error",f),r&&r("Error while trying to load image: "+t,e),h&&l.src&&URL.revokeObjectURL(l.src)};l.addEventListener("load",u),l.addEventListener("error",f);var d=function(){l.src=s};if("data:"!==s.substr(0,5)&&n&&n.enableTexturesOffline)n.open((function(){n&&n.loadImage(s,l)}),d);else{if(-1!==s.indexOf("file:")){var p=decodeURIComponent(s.substring(5).toLowerCase());if(a.FilesToLoad[p]){try{var _;try{_=URL.createObjectURL(a.FilesToLoad[p])}catch(e){_=URL.createObjectURL(a.FilesToLoad[p])}l.src=_,h=!0}catch(e){l.src=""}return l}}d()}return l},e.ReadFile=function(e,t,i,r,n){var o=new FileReader,a={onCompleteObservable:new s.a,abort:function(){return o.abort()}};return o.onloadend=function(e){return a.onCompleteObservable.notifyObservers(a)},n&&(o.onerror=function(t){n(new _("Unable to read "+e.name,e))}),o.onload=function(e){t(e.target.result)},i&&(o.onprogress=i),r?o.readAsArrayBuffer(e):o.readAsText(e),a},e.LoadFile=function(t,i,r,n,o,s){if(-1!==t.indexOf("file:")){var h=decodeURIComponent(t.substring(5).toLowerCase());0===h.indexOf("./")&&(h=h.substring(2));var l=a.FilesToLoad[h];if(l)return e.ReadFile(l,i,r,o,s?function(e){return s(void 0,new d(e.message,e.file))}:void 0)}return e.RequestFile(t,(function(e,t){i(e,t?t.responseURL:void 0)}),r,n,o,s?function(e){s(e.request,new d(e.message,e.request))}:void 0)},e.RequestFile=function(t,i,r,a,h,l,c){t=e._CleanUrl(t),t=e.PreprocessUrl(t);var u=e.BaseUrl+t,f=!1,d={onCompleteObservable:new s.a,abort:function(){return f=!0}},_=function(){var t=new n.a,s=null;d.abort=function(){f=!0,t.readyState!==(XMLHttpRequest.DONE||4)&&t.abort(),null!==s&&(clearTimeout(s),s=null)};var a=function(_){t.open("GET",u),c&&c(t),h&&(t.responseType="arraybuffer"),r&&t.addEventListener("progress",r);var g=function(){t.removeEventListener("loadend",g),d.onCompleteObservable.notifyObservers(d),d.onCompleteObservable.clear()};t.addEventListener("loadend",g);var m=function(){if(!f&&t.readyState===(XMLHttpRequest.DONE||4)){if(t.removeEventListener("readystatechange",m),t.status>=200&&t.status<300||0===t.status&&(!o.a.IsWindowObjectExist()||e.IsFileURL()))return void i(h?t.response:t.responseText,t);var r=e.DefaultRetryStrategy;if(r){var c=r(u,t,_);if(-1!==c)return t.removeEventListener("loadend",g),t=new n.a,void(s=setTimeout((function(){return a(_+1)}),c))}var d=new p("Error status: "+t.status+" "+t.statusText+" - Unable to load "+u,t);l&&l(d)}};t.addEventListener("readystatechange",m),t.send()};a(0)};if(a&&a.enableSceneOffline){var g=function(e){e&&e.status>400?l&&l(e):_()};a.open((function(){a&&a.loadFile(e.BaseUrl+t,(function(e){f||i(e),d.onCompleteObservable.notifyObservers(d)}),r?function(e){f||r(e)}:void 0,g,h)}),g)}else _();return d},e.IsFileURL=function(){return"file:"===location.protocol},e.DefaultRetryStrategy=h.ExponentialBackoff(),e.BaseUrl="",e.CorsBehavior="anonymous",e.PreprocessUrl=function(e){return e},e}();u.a._FileToolsLoadImage=g.LoadImage.bind(g),u.a._FileToolsLoadFile=g.LoadFile.bind(g),f.a._FileToolsLoadFile=g.LoadFile.bind(g)},function(e,t,i){"use strict";i.d(t,"a",(function(){return n}));var r=i(25),n=function(){function e(){}return Object.defineProperty(e,"Now",{get:function(){return r.a.IsWindowObjectExist()&&window.performance&&window.performance.now?window.performance.now():Date.now()},enumerable:!0,configurable:!0}),e}()},function(e,t,i){"use strict";i.d(t,"b",(function(){return r})),i.d(t,"a",(function(){return a}));var r,n=i(4),o=i(71),s=i(8);!function(e){e[e.Unknown=0]="Unknown",e[e.Url=1]="Url",e[e.Temp=2]="Temp",e[e.Raw=3]="Raw",e[e.Dynamic=4]="Dynamic",e[e.RenderTarget=5]="RenderTarget",e[e.MultiRenderTarget=6]="MultiRenderTarget",e[e.Cube=7]="Cube",e[e.CubeRaw=8]="CubeRaw",e[e.CubePrefiltered=9]="CubePrefiltered",e[e.Raw3D=10]="Raw3D",e[e.Raw2DArray=11]="Raw2DArray",e[e.Depth=12]="Depth",e[e.CubeRawRGBD=13]="CubeRawRGBD"}(r||(r={}));var a=function(){function e(e,t,i){void 0===i&&(i=!1),this.isReady=!1,this.isCube=!1,this.is3D=!1,this.is2DArray=!1,this.isMultiview=!1,this.url="",this.samplingMode=-1,this.generateMipMaps=!1,this.samples=0,this.type=-1,this.format=-1,this.onLoadedObservable=new n.a,this.width=0,this.height=0,this.depth=0,this.baseWidth=0,this.baseHeight=0,this.baseDepth=0,this.invertY=!1,this._invertVScale=!1,this._associatedChannel=-1,this._source=r.Unknown,this._buffer=null,this._bufferView=null,this._bufferViewArray=null,this._bufferViewArrayArray=null,this._size=0,this._extension="",this._files=null,this._workingCanvas=null,this._workingContext=null,this._framebuffer=null,this._depthStencilBuffer=null,this._MSAAFramebuffer=null,this._MSAARenderBuffer=null,this._attachments=null,this._cachedCoordinatesMode=null,this._cachedWrapU=null,this._cachedWrapV=null,this._cachedWrapR=null,this._cachedAnisotropicFilteringLevel=null,this._isDisabled=!1,this._compression=null,this._generateStencilBuffer=!1,this._generateDepthBuffer=!1,this._comparisonFunction=0,this._sphericalPolynomial=null,this._lodGenerationScale=0,this._lodGenerationOffset=0,this._colorTextureArray=null,this._depthStencilTextureArray=null,this._lodTextureHigh=null,this._lodTextureMid=null,this._lodTextureLow=null,this._isRGBD=!1,this._linearSpecularLOD=!1,this._irradianceTexture=null,this._webGLTexture=null,this._references=1,this._engine=e,this._source=t,i||(this._webGLTexture=e._createTexture())}return e.prototype.getEngine=function(){return this._engine},Object.defineProperty(e.prototype,"source",{get:function(){return this._source},enumerable:!0,configurable:!0}),e.prototype.incrementReferences=function(){this._references++},e.prototype.updateSize=function(e,t,i){void 0===i&&(i=1),this.width=e,this.height=t,this.depth=i,this.baseWidth=e,this.baseHeight=t,this.baseDepth=i,this._size=e*t*i},e.prototype._rebuild=function(){var t,i=this;switch(this.isReady=!1,this._cachedCoordinatesMode=null,this._cachedWrapU=null,this._cachedWrapV=null,this._cachedAnisotropicFilteringLevel=null,this.source){case r.Temp:return;case r.Url:return void(t=this._engine.createTexture(this.url,!this.generateMipMaps,this.invertY,null,this.samplingMode,(function(){t._swapAndDie(i),i.isReady=!0}),null,this._buffer,void 0,this.format));case r.Raw:return(t=this._engine.createRawTexture(this._bufferView,this.baseWidth,this.baseHeight,this.format,this.generateMipMaps,this.invertY,this.samplingMode,this._compression))._swapAndDie(this),void(this.isReady=!0);case r.Raw3D:return(t=this._engine.createRawTexture3D(this._bufferView,this.baseWidth,this.baseHeight,this.baseDepth,this.format,this.generateMipMaps,this.invertY,this.samplingMode,this._compression))._swapAndDie(this),void(this.isReady=!0);case r.Raw2DArray:return(t=this._engine.createRawTexture2DArray(this._bufferView,this.baseWidth,this.baseHeight,this.baseDepth,this.format,this.generateMipMaps,this.invertY,this.samplingMode,this._compression))._swapAndDie(this),void(this.isReady=!0);case r.Dynamic:return(t=this._engine.createDynamicTexture(this.baseWidth,this.baseHeight,this.generateMipMaps,this.samplingMode))._swapAndDie(this),void this._engine.updateDynamicTexture(this,this._engine.getRenderingCanvas(),this.invertY,void 0,void 0,!0);case r.RenderTarget:var n=new o.a;if(n.generateDepthBuffer=this._generateDepthBuffer,n.generateMipMaps=this.generateMipMaps,n.generateStencilBuffer=this._generateStencilBuffer,n.samplingMode=this.samplingMode,n.type=this.type,this.isCube)t=this._engine.createRenderTargetCubeTexture(this.width,n);else{var s={width:this.width,height:this.height,layers:this.is2DArray?this.depth:void 0};t=this._engine.createRenderTargetTexture(s,n)}return t._swapAndDie(this),void(this.isReady=!0);case r.Depth:var a={bilinearFiltering:2!==this.samplingMode,comparisonFunction:this._comparisonFunction,generateStencil:this._generateStencilBuffer,isCube:this.isCube},h={width:this.width,height:this.height,layers:this.is2DArray?this.depth:void 0};return(t=this._engine.createDepthStencilTexture(h,a))._swapAndDie(this),void(this.isReady=!0);case r.Cube:return void(t=this._engine.createCubeTexture(this.url,null,this._files,!this.generateMipMaps,(function(){t._swapAndDie(i),i.isReady=!0}),null,this.format,this._extension));case r.CubeRaw:return(t=this._engine.createRawCubeTexture(this._bufferViewArray,this.width,this.format,this.type,this.generateMipMaps,this.invertY,this.samplingMode,this._compression))._swapAndDie(this),void(this.isReady=!0);case r.CubeRawRGBD:return t=this._engine.createRawCubeTexture(null,this.width,this.format,this.type,this.generateMipMaps,this.invertY,this.samplingMode,this._compression),void e._UpdateRGBDAsync(t,this._bufferViewArrayArray,this._sphericalPolynomial,this._lodGenerationScale,this._lodGenerationOffset).then((function(){t._swapAndDie(i),i.isReady=!0}));case r.CubePrefiltered:return void((t=this._engine.createPrefilteredCubeTexture(this.url,null,this._lodGenerationScale,this._lodGenerationOffset,(function(e){e&&e._swapAndDie(i),i.isReady=!0}),null,this.format,this._extension))._sphericalPolynomial=this._sphericalPolynomial)}},e.prototype._swapAndDie=function(e){e._webGLTexture=this._webGLTexture,e._isRGBD=this._isRGBD,this._framebuffer&&(e._framebuffer=this._framebuffer),this._depthStencilBuffer&&(e._depthStencilBuffer=this._depthStencilBuffer),e._depthStencilTexture=this._depthStencilTexture,this._lodTextureHigh&&(e._lodTextureHigh&&e._lodTextureHigh.dispose(),e._lodTextureHigh=this._lodTextureHigh),this._lodTextureMid&&(e._lodTextureMid&&e._lodTextureMid.dispose(),e._lodTextureMid=this._lodTextureMid),this._lodTextureLow&&(e._lodTextureLow&&e._lodTextureLow.dispose(),e._lodTextureLow=this._lodTextureLow),this._irradianceTexture&&(e._irradianceTexture&&e._irradianceTexture.dispose(),e._irradianceTexture=this._irradianceTexture);var t,i=this._engine.getLoadedTexturesCache();-1!==(t=i.indexOf(this))&&i.splice(t,1),-1===(t=i.indexOf(e))&&i.push(e)},e.prototype.dispose=function(){this._webGLTexture&&(this._references--,0===this._references&&(this._engine._releaseTexture(this),this._webGLTexture=null))},e._UpdateRGBDAsync=function(e,t,i,r,n){throw s.a.WarnImport("environmentTextureTools")},e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return l}));var r=i(1),n=i(3),o=i(4),s=i(0),a=i(34),h=i(35),l=function(e){function t(i,r,n){void 0===r&&(r=null),void 0===n&&(n=!0);var a=e.call(this,i,r)||this;return a._forward=new s.e(0,0,1),a._forwardInverted=new s.e(0,0,-1),a._up=new s.e(0,1,0),a._right=new s.e(1,0,0),a._rightInverted=new s.e(-1,0,0),a._position=s.e.Zero(),a._rotation=s.e.Zero(),a._rotationQuaternion=null,a._scaling=s.e.One(),a._isDirty=!1,a._transformToBoneReferal=null,a._isAbsoluteSynced=!1,a._billboardMode=t.BILLBOARDMODE_NONE,a._preserveParentRotationForBillboard=!1,a.scalingDeterminant=1,a._infiniteDistance=!1,a.ignoreNonUniformScaling=!1,a.reIntegrateRotationIntoRotationQuaternion=!1,a._poseMatrix=null,a._localMatrix=s.a.Zero(),a._usePivotMatrix=!1,a._absolutePosition=s.e.Zero(),a._absoluteScaling=s.e.Zero(),a._absoluteRotationQuaternion=s.b.Identity(),a._pivotMatrix=s.a.Identity(),a._postMultiplyPivotMatrix=!1,a._isWorldMatrixFrozen=!1,a._indexInSceneTransformNodesArray=-1,a.onAfterWorldMatrixUpdateObservable=new o.a,a._nonUniformScaling=!1,n&&a.getScene().addTransformNode(a),a}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"billboardMode",{get:function(){return this._billboardMode},set:function(e){this._billboardMode!==e&&(this._billboardMode=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"preserveParentRotationForBillboard",{get:function(){return this._preserveParentRotationForBillboard},set:function(e){e!==this._preserveParentRotationForBillboard&&(this._preserveParentRotationForBillboard=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"infiniteDistance",{get:function(){return this._infiniteDistance},set:function(e){this._infiniteDistance!==e&&(this._infiniteDistance=e)},enumerable:!0,configurable:!0}),t.prototype.getClassName=function(){return"TransformNode"},Object.defineProperty(t.prototype,"position",{get:function(){return this._position},set:function(e){this._position=e,this._isDirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"rotation",{get:function(){return this._rotation},set:function(e){this._rotation=e,this._rotationQuaternion=null,this._isDirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"scaling",{get:function(){return this._scaling},set:function(e){this._scaling=e,this._isDirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"rotationQuaternion",{get:function(){return this._rotationQuaternion},set:function(e){this._rotationQuaternion=e,e&&this._rotation.setAll(0),this._isDirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"forward",{get:function(){return s.e.Normalize(s.e.TransformNormal(this.getScene().useRightHandedSystem?this._forwardInverted:this._forward,this.getWorldMatrix()))},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"up",{get:function(){return s.e.Normalize(s.e.TransformNormal(this._up,this.getWorldMatrix()))},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"right",{get:function(){return s.e.Normalize(s.e.TransformNormal(this.getScene().useRightHandedSystem?this._rightInverted:this._right,this.getWorldMatrix()))},enumerable:!0,configurable:!0}),t.prototype.updatePoseMatrix=function(e){return this._poseMatrix?(this._poseMatrix.copyFrom(e),this):(this._poseMatrix=e.clone(),this)},t.prototype.getPoseMatrix=function(){return this._poseMatrix||(this._poseMatrix=s.a.Identity()),this._poseMatrix},t.prototype._isSynchronized=function(){var e=this._cache;if(this.billboardMode!==e.billboardMode||this.billboardMode!==t.BILLBOARDMODE_NONE)return!1;if(e.pivotMatrixUpdated)return!1;if(this.infiniteDistance)return!1;if(!e.position.equals(this._position))return!1;if(this._rotationQuaternion){if(!e.rotationQuaternion.equals(this._rotationQuaternion))return!1}else if(!e.rotation.equals(this._rotation))return!1;return!!e.scaling.equals(this._scaling)},t.prototype._initCache=function(){e.prototype._initCache.call(this);var t=this._cache;t.localMatrixUpdated=!1,t.position=s.e.Zero(),t.scaling=s.e.Zero(),t.rotation=s.e.Zero(),t.rotationQuaternion=new s.b(0,0,0,0),t.billboardMode=-1,t.infiniteDistance=!1},t.prototype.markAsDirty=function(e){return this._currentRenderId=Number.MAX_VALUE,this._isDirty=!0,this},Object.defineProperty(t.prototype,"absolutePosition",{get:function(){return this._absolutePosition},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"absoluteScaling",{get:function(){return this._syncAbsoluteScalingAndRotation(),this._absoluteScaling},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"absoluteRotationQuaternion",{get:function(){return this._syncAbsoluteScalingAndRotation(),this._absoluteRotationQuaternion},enumerable:!0,configurable:!0}),t.prototype.setPreTransformMatrix=function(e){return this.setPivotMatrix(e,!1)},t.prototype.setPivotMatrix=function(e,t){return void 0===t&&(t=!0),this._pivotMatrix.copyFrom(e),this._usePivotMatrix=!this._pivotMatrix.isIdentity(),this._cache.pivotMatrixUpdated=!0,this._postMultiplyPivotMatrix=t,this._postMultiplyPivotMatrix&&(this._pivotMatrixInverse?this._pivotMatrix.invertToRef(this._pivotMatrixInverse):this._pivotMatrixInverse=s.a.Invert(this._pivotMatrix)),this},t.prototype.getPivotMatrix=function(){return this._pivotMatrix},t.prototype.instantiateHierarchy=function(e,t,i){void 0===e&&(e=null);var r=this.clone("Clone of "+(this.name||this.id),e||this.parent,!0);r&&i&&i(this,r);for(var n=0,o=this.getChildTransformNodes(!0);n>2,o=(3&t)<<4|(i=c>4,s=(15&i)<<2|(r=c>6,a=63&r,isNaN(i)?s=a=64:isNaN(r)&&(a=64),l+=h.charAt(n)+h.charAt(o)+h.charAt(s)+h.charAt(a);return l},e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return h})),i.d(t,"b",(function(){return l}));var r=i(1),n=i(2),o=i(68),s=i(33),a=i(59),h=function(){function e(){this._materialDefines=null,this._materialEffect=null}return Object.defineProperty(e.prototype,"materialDefines",{get:function(){return this._materialDefines},set:function(e){this._materialDefines=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"effect",{get:function(){return this._materialEffect},enumerable:!0,configurable:!0}),e.prototype.setEffect=function(e,t){void 0===t&&(t=null),this._materialEffect!==e?(this._materialDefines=t,this._materialEffect=e):e||(this._materialDefines=null)},e}(),l=function(e){function t(t,i,r,n,o,s,a,h){void 0===h&&(h=!0);var l=e.call(this)||this;return l.materialIndex=t,l.verticesStart=i,l.verticesCount=r,l.indexStart=n,l.indexCount=o,l._linesIndexCount=0,l._linesIndexBuffer=null,l._lastColliderWorldVertices=null,l._lastColliderTransformMatrix=null,l._renderId=0,l._alphaIndex=0,l._distanceToCamera=0,l._currentMaterial=null,l._mesh=s,l._renderingMesh=a||s,s.subMeshes.push(l),l._trianglePlanes=[],l._id=s.subMeshes.length-1,h&&(l.refreshBoundingInfo(),s.computeWorldMatrix(!0)),l}return Object(r.c)(t,e),t.AddToMesh=function(e,i,r,n,o,s,a,h){return void 0===h&&(h=!0),new t(e,i,r,n,o,s,a,h)},Object.defineProperty(t.prototype,"IsGlobal",{get:function(){return 0===this.verticesStart&&this.verticesCount===this._mesh.getTotalVertices()},enumerable:!0,configurable:!0}),t.prototype.getBoundingInfo=function(){return this.IsGlobal?this._mesh.getBoundingInfo():this._boundingInfo},t.prototype.setBoundingInfo=function(e){return this._boundingInfo=e,this},t.prototype.getMesh=function(){return this._mesh},t.prototype.getRenderingMesh=function(){return this._renderingMesh},t.prototype.getMaterial=function(){var e=this._renderingMesh.material;if(null==e)return this._mesh.getScene().defaultMaterial;if(e.getSubMaterial){var t=e.getSubMaterial(this.materialIndex);return this._currentMaterial!==t&&(this._currentMaterial=t,this._materialDefines=null),t}return e},t.prototype.refreshBoundingInfo=function(e){if(void 0===e&&(e=null),this._lastColliderWorldVertices=null,this.IsGlobal||!this._renderingMesh||!this._renderingMesh.geometry)return this;if(e||(e=this._renderingMesh.getVerticesData(n.b.PositionKind)),!e)return this._boundingInfo=this._mesh.getBoundingInfo(),this;var t,i=this._renderingMesh.getIndices();if(0===this.indexStart&&this.indexCount===i.length){var r=this._renderingMesh.getBoundingInfo();t={minimum:r.minimum.clone(),maximum:r.maximum.clone()}}else t=Object(a.b)(e,i,this.indexStart,this.indexCount,this._renderingMesh.geometry.boundingBias);return this._boundingInfo?this._boundingInfo.reConstruct(t.minimum,t.maximum):this._boundingInfo=new s.a(t.minimum,t.maximum),this},t.prototype._checkCollision=function(e){return this.getBoundingInfo()._checkCollision(e)},t.prototype.updateBoundingInfo=function(e){var t=this.getBoundingInfo();return t||(this.refreshBoundingInfo(),t=this.getBoundingInfo()),t&&t.update(e),this},t.prototype.isInFrustum=function(e){var t=this.getBoundingInfo();return!!t&&t.isInFrustum(e,this._mesh.cullingStrategy)},t.prototype.isCompletelyInFrustum=function(e){var t=this.getBoundingInfo();return!!t&&t.isCompletelyInFrustum(e)},t.prototype.render=function(e){return this._renderingMesh.render(this,e,this._mesh._internalAbstractMeshDataInfo._actAsRegularMesh?this._mesh:void 0),this},t.prototype._getLinesIndexBuffer=function(e,t){if(!this._linesIndexBuffer){for(var i=[],r=this.indexStart;ra&&(a=c)}return new t(e,s,a-s+1,i,r,n,o)},t}(h)},function(e,t,i){"use strict";i.d(t,"a",(function(){return x}));var r=i(1),n=i(13),o=i(4),s=i(0),a=i(26),h=i(2),l=i(11),c=i(39),u=i(48),f=i(33),d=function(){this._checkCollisions=!1,this._collisionMask=-1,this._collisionGroup=-1,this._collider=null,this._oldPositionForCollisions=new s.e(0,0,0),this._diffPositionForCollisions=new s.e(0,0,0)},p=i(8),_=i(59),g=i(7),m=i(16),b=i(35),v=function(){this.facetNb=0,this.partitioningSubdivisions=10,this.partitioningBBoxRatio=1.01,this.facetDataEnabled=!1,this.facetParameters={},this.bbSize=s.e.Zero(),this.subDiv={max:1,X:1,Y:1,Z:1},this.facetDepthSort=!1,this.facetDepthSortEnabled=!1},y=function(){this._hasVertexAlpha=!1,this._useVertexColors=!0,this._numBoneInfluencers=4,this._applyFog=!0,this._receiveShadows=!1,this._facetData=new v,this._visibility=1,this._skeleton=null,this._layerMask=268435455,this._computeBonesUsingShaders=!0,this._isActive=!1,this._onlyForInstances=!1,this._isActiveIntermediate=!1,this._onlyForInstancesIntermediate=!1,this._actAsRegularMesh=!1},x=function(e){function t(i,r){void 0===r&&(r=null);var n=e.call(this,i,r,!1)||this;return n._internalAbstractMeshDataInfo=new y,n.cullingStrategy=t.CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY,n.onCollideObservable=new o.a,n.onCollisionPositionChangeObservable=new o.a,n.onMaterialChangedObservable=new o.a,n.definedFacingForward=!0,n._occlusionQuery=null,n._renderingGroup=null,n.alphaIndex=Number.MAX_VALUE,n.isVisible=!0,n.isPickable=!0,n.showSubMeshesBoundingBox=!1,n.isBlocker=!1,n.enablePointerMoveEvents=!1,n.renderingGroupId=0,n._material=null,n.outlineColor=g.a.Red(),n.outlineWidth=.02,n.overlayColor=g.a.Red(),n.overlayAlpha=.5,n.useOctreeForRenderingSelection=!0,n.useOctreeForPicking=!0,n.useOctreeForCollisions=!0,n.alwaysSelectAsActiveMesh=!1,n.doNotSyncBoundingInfo=!1,n.actionManager=null,n._meshCollisionData=new d,n.ellipsoid=new s.e(.5,1,.5),n.ellipsoidOffset=new s.e(0,0,0),n.edgesWidth=1,n.edgesColor=new g.b(1,0,0,1),n._edgesRenderer=null,n._masterMesh=null,n._boundingInfo=null,n._renderId=0,n._intersectionsInProgress=new Array,n._unIndexed=!1,n._lightSources=new Array,n._waitingData={lods:null,actions:null,freezeWorldMatrix:null},n._bonesTransformMatrices=null,n._transformMatrixTexture=null,n.onRebuildObservable=new o.a,n._onCollisionPositionChange=function(e,t,i){void 0===i&&(i=null),t.subtractToRef(n._meshCollisionData._oldPositionForCollisions,n._meshCollisionData._diffPositionForCollisions),n._meshCollisionData._diffPositionForCollisions.length()>a.Engine.CollisionsEpsilon&&n.position.addInPlace(n._meshCollisionData._diffPositionForCollisions),i&&n.onCollideObservable.notifyObservers(i),n.onCollisionPositionChangeObservable.notifyObservers(n.position)},n.getScene().addMesh(n),n._resyncLightSources(),n}return Object(r.c)(t,e),Object.defineProperty(t,"BILLBOARDMODE_NONE",{get:function(){return c.a.BILLBOARDMODE_NONE},enumerable:!0,configurable:!0}),Object.defineProperty(t,"BILLBOARDMODE_X",{get:function(){return c.a.BILLBOARDMODE_X},enumerable:!0,configurable:!0}),Object.defineProperty(t,"BILLBOARDMODE_Y",{get:function(){return c.a.BILLBOARDMODE_Y},enumerable:!0,configurable:!0}),Object.defineProperty(t,"BILLBOARDMODE_Z",{get:function(){return c.a.BILLBOARDMODE_Z},enumerable:!0,configurable:!0}),Object.defineProperty(t,"BILLBOARDMODE_ALL",{get:function(){return c.a.BILLBOARDMODE_ALL},enumerable:!0,configurable:!0}),Object.defineProperty(t,"BILLBOARDMODE_USE_POSITION",{get:function(){return c.a.BILLBOARDMODE_USE_POSITION},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"facetNb",{get:function(){return this._internalAbstractMeshDataInfo._facetData.facetNb},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"partitioningSubdivisions",{get:function(){return this._internalAbstractMeshDataInfo._facetData.partitioningSubdivisions},set:function(e){this._internalAbstractMeshDataInfo._facetData.partitioningSubdivisions=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"partitioningBBoxRatio",{get:function(){return this._internalAbstractMeshDataInfo._facetData.partitioningBBoxRatio},set:function(e){this._internalAbstractMeshDataInfo._facetData.partitioningBBoxRatio=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"mustDepthSortFacets",{get:function(){return this._internalAbstractMeshDataInfo._facetData.facetDepthSort},set:function(e){this._internalAbstractMeshDataInfo._facetData.facetDepthSort=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"facetDepthSortFrom",{get:function(){return this._internalAbstractMeshDataInfo._facetData.facetDepthSortFrom},set:function(e){this._internalAbstractMeshDataInfo._facetData.facetDepthSortFrom=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"isFacetDataEnabled",{get:function(){return this._internalAbstractMeshDataInfo._facetData.facetDataEnabled},enumerable:!0,configurable:!0}),t.prototype._updateNonUniformScalingState=function(t){return!!e.prototype._updateNonUniformScalingState.call(this,t)&&(this._markSubMeshesAsMiscDirty(),!0)},Object.defineProperty(t.prototype,"onCollide",{set:function(e){this._meshCollisionData._onCollideObserver&&this.onCollideObservable.remove(this._meshCollisionData._onCollideObserver),this._meshCollisionData._onCollideObserver=this.onCollideObservable.add(e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"onCollisionPositionChange",{set:function(e){this._meshCollisionData._onCollisionPositionChangeObserver&&this.onCollisionPositionChangeObservable.remove(this._meshCollisionData._onCollisionPositionChangeObserver),this._meshCollisionData._onCollisionPositionChangeObserver=this.onCollisionPositionChangeObservable.add(e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"visibility",{get:function(){return this._internalAbstractMeshDataInfo._visibility},set:function(e){this._internalAbstractMeshDataInfo._visibility!==e&&(this._internalAbstractMeshDataInfo._visibility=e,this._markSubMeshesAsMiscDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"material",{get:function(){return this._material},set:function(e){this._material!==e&&(this._material&&this._material.meshMap&&(this._material.meshMap[this.uniqueId]=void 0),this._material=e,e&&e.meshMap&&(e.meshMap[this.uniqueId]=this),this.onMaterialChangedObservable.hasObservers()&&this.onMaterialChangedObservable.notifyObservers(this),this.subMeshes&&this._unBindEffect())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"receiveShadows",{get:function(){return this._internalAbstractMeshDataInfo._receiveShadows},set:function(e){this._internalAbstractMeshDataInfo._receiveShadows!==e&&(this._internalAbstractMeshDataInfo._receiveShadows=e,this._markSubMeshesAsLightDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"hasVertexAlpha",{get:function(){return this._internalAbstractMeshDataInfo._hasVertexAlpha},set:function(e){this._internalAbstractMeshDataInfo._hasVertexAlpha!==e&&(this._internalAbstractMeshDataInfo._hasVertexAlpha=e,this._markSubMeshesAsAttributesDirty(),this._markSubMeshesAsMiscDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"useVertexColors",{get:function(){return this._internalAbstractMeshDataInfo._useVertexColors},set:function(e){this._internalAbstractMeshDataInfo._useVertexColors!==e&&(this._internalAbstractMeshDataInfo._useVertexColors=e,this._markSubMeshesAsAttributesDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"computeBonesUsingShaders",{get:function(){return this._internalAbstractMeshDataInfo._computeBonesUsingShaders},set:function(e){this._internalAbstractMeshDataInfo._computeBonesUsingShaders!==e&&(this._internalAbstractMeshDataInfo._computeBonesUsingShaders=e,this._markSubMeshesAsAttributesDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"numBoneInfluencers",{get:function(){return this._internalAbstractMeshDataInfo._numBoneInfluencers},set:function(e){this._internalAbstractMeshDataInfo._numBoneInfluencers!==e&&(this._internalAbstractMeshDataInfo._numBoneInfluencers=e,this._markSubMeshesAsAttributesDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"applyFog",{get:function(){return this._internalAbstractMeshDataInfo._applyFog},set:function(e){this._internalAbstractMeshDataInfo._applyFog!==e&&(this._internalAbstractMeshDataInfo._applyFog=e,this._markSubMeshesAsMiscDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"layerMask",{get:function(){return this._internalAbstractMeshDataInfo._layerMask},set:function(e){e!==this._internalAbstractMeshDataInfo._layerMask&&(this._internalAbstractMeshDataInfo._layerMask=e,this._resyncLightSources())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"collisionMask",{get:function(){return this._meshCollisionData._collisionMask},set:function(e){this._meshCollisionData._collisionMask=isNaN(e)?-1:e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"collisionGroup",{get:function(){return this._meshCollisionData._collisionGroup},set:function(e){this._meshCollisionData._collisionGroup=isNaN(e)?-1:e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"lightSources",{get:function(){return this._lightSources},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"_positions",{get:function(){return null},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"skeleton",{get:function(){return this._internalAbstractMeshDataInfo._skeleton},set:function(e){var t=this._internalAbstractMeshDataInfo._skeleton;t&&t.needInitialSkinMatrix&&t._unregisterMeshWithPoseMatrix(this),e&&e.needInitialSkinMatrix&&e._registerMeshWithPoseMatrix(this),this._internalAbstractMeshDataInfo._skeleton=e,this._internalAbstractMeshDataInfo._skeleton||(this._bonesTransformMatrices=null),this._markSubMeshesAsAttributesDirty()},enumerable:!0,configurable:!0}),t.prototype.getClassName=function(){return"AbstractMesh"},t.prototype.toString=function(e){var t="Name: "+this.name+", isInstance: "+("InstancedMesh"!==this.getClassName()?"YES":"NO");t+=", # of submeshes: "+(this.subMeshes?this.subMeshes.length:0);var i=this._internalAbstractMeshDataInfo._skeleton;return i&&(t+=", skeleton: "+i.name),e&&(t+=", billboard mode: "+["NONE","X","Y",null,"Z",null,null,"ALL"][this.billboardMode],t+=", freeze wrld mat: "+(this._isWorldMatrixFrozen||this._waitingData.freezeWorldMatrix?"YES":"NO")),t},t.prototype._getEffectiveParent=function(){return this._masterMesh&&this.billboardMode!==c.a.BILLBOARDMODE_NONE?this._masterMesh:e.prototype._getEffectiveParent.call(this)},t.prototype._getActionManagerForTrigger=function(e,t){if(void 0===t&&(t=!0),this.actionManager&&(t||this.actionManager.isRecursive)){if(!e)return this.actionManager;if(this.actionManager.hasSpecificTrigger(e))return this.actionManager}return this.parent?this.parent._getActionManagerForTrigger(e,!1):null},t.prototype._rebuild=function(){if(this.onRebuildObservable.notifyObservers(this),this._occlusionQuery&&(this._occlusionQuery=null),this.subMeshes)for(var e=0,t=this.subMeshes;e4,a=o?this.getVerticesData(h.b.MatricesIndicesExtraKind):null,l=o?this.getVerticesData(h.b.MatricesWeightsExtraKind):null;this.skeleton.prepare();for(var c=this.skeleton.getTransformMatrices(this),u=s.c.Vector3[0],f=s.c.Matrix[0],d=s.c.Matrix[1],p=0,_=0;_0&&(s.a.FromFloat32ArrayToRefScaled(c,Math.floor(16*i[p+g]),m,d),f.addToSelf(d));if(o)for(g=0;g<4;g++)(m=l[p+g])>0&&(s.a.FromFloat32ArrayToRefScaled(c,Math.floor(16*a[p+g]),m,d),f.addToSelf(d));s.e.TransformCoordinatesFromFloatsToRef(t[_],t[_+1],t[_+2],f,u),u.toArray(t,_),this._positions&&this._positions[_/3].copyFrom(u)}}}return t},t.prototype._updateBoundingInfo=function(){var e=this._effectiveMesh;return this._boundingInfo?this._boundingInfo.update(e.worldMatrixFromCache):this._boundingInfo=new f.a(this.absolutePosition,this.absolutePosition,e.worldMatrixFromCache),this._updateSubMeshesBoundingInfo(e.worldMatrixFromCache),this},t.prototype._updateSubMeshesBoundingInfo=function(e){if(!this.subMeshes)return this;for(var t=this.subMeshes.length,i=0;i1||!r.IsGlobal)&&r.updateBoundingInfo(e)}return this},t.prototype._afterComputeWorldMatrix=function(){this.doNotSyncBoundingInfo||this._updateBoundingInfo()},Object.defineProperty(t.prototype,"_effectiveMesh",{get:function(){return this.skeleton&&this.skeleton.overrideMesh||this},enumerable:!0,configurable:!0}),t.prototype.isInFrustum=function(e){return null!==this._boundingInfo&&this._boundingInfo.isInFrustum(e,this.cullingStrategy)},t.prototype.isCompletelyInFrustum=function(e){return null!==this._boundingInfo&&this._boundingInfo.isCompletelyInFrustum(e)},t.prototype.intersectsMesh=function(e,t,i){if(void 0===t&&(t=!1),!this._boundingInfo||!e._boundingInfo)return!1;if(this._boundingInfo.intersects(e._boundingInfo,t))return!0;if(i)for(var r=0,n=this.getChildMeshes();r1&&!o._checkCollision(e)||this._collideForSubMesh(o,t,e)}return this},t.prototype._checkCollision=function(e){if(!this._boundingInfo||!this._boundingInfo._checkCollision(e))return this;var t=s.c.Matrix[0],i=s.c.Matrix[1];return s.a.ScalingToRef(1/e._radius.x,1/e._radius.y,1/e._radius.z,t),this.worldMatrixFromCache.multiplyToRef(t,i),this._processCollisionsForSubMeshes(e,i),this},t.prototype._generatePointsArray=function(){return!1},t.prototype.intersects=function(e,t,i){var r=new u.a,n="InstancedLinesMesh"===this.getClassName()||"LinesMesh"===this.getClassName()?this.intersectionThreshold:0,o=this._boundingInfo;if(!(this.subMeshes&&o&&e.intersectsSphere(o.boundingSphere,n)&&e.intersectsBox(o.boundingBox,n)))return r;if(!this._generatePointsArray())return r;for(var a=null,h=this._scene.getIntersectingSubMeshCandidates(this,e),l=h.length,c=0;c1)||f.canIntersects(e)){var d=f.intersects(e,this._positions,this.getIndices(),t,i);if(d&&(t||!a||d.distance65535){o=!0;break}e.depthSortedIndices=o?new Uint32Array(i):new Uint16Array(i)}if(e.facetDepthSortFunction=function(e,t){return t.sqDistance-e.sqDistance},!e.facetDepthSortFrom){var c=this.getScene().activeCamera;e.facetDepthSortFrom=c?c.position:s.e.Zero()}e.depthSortedFacets=[];for(var u=0;um.a?n.maximum.x-n.minimum.x:m.a,e.bbSize.y=n.maximum.y-n.minimum.y>m.a?n.maximum.y-n.minimum.y:m.a,e.bbSize.z=n.maximum.z-n.minimum.z>m.a?n.maximum.z-n.minimum.z:m.a;var d=e.bbSize.x>e.bbSize.y?e.bbSize.x:e.bbSize.y;if(d=d>e.bbSize.z?d:e.bbSize.z,e.subDiv.max=e.partitioningSubdivisions,e.subDiv.X=Math.floor(e.subDiv.max*e.bbSize.x/d),e.subDiv.Y=Math.floor(e.subDiv.max*e.bbSize.y/d),e.subDiv.Z=Math.floor(e.subDiv.max*e.bbSize.z/d),e.subDiv.X=e.subDiv.X<1?1:e.subDiv.X,e.subDiv.Y=e.subDiv.Y<1?1:e.subDiv.Y,e.subDiv.Z=e.subDiv.Z<1?1:e.subDiv.Z,e.facetParameters.facetNormals=this.getFacetLocalNormals(),e.facetParameters.facetPositions=this.getFacetLocalPositions(),e.facetParameters.facetPartitioning=this.getFacetLocalPartitioning(),e.facetParameters.bInfo=n,e.facetParameters.bbSize=e.bbSize,e.facetParameters.subDiv=e.subDiv,e.facetParameters.ratio=this.partitioningBBoxRatio,e.facetParameters.depthSort=e.facetDepthSort,e.facetDepthSort&&e.facetDepthSortEnabled&&(this.computeWorldMatrix(!0),this._worldMatrix.invertToRef(e.invertedMatrix),s.e.TransformCoordinatesToRef(e.facetDepthSortFrom,e.invertedMatrix,e.facetDepthSortOrigin),e.facetParameters.distanceTo=e.facetDepthSortOrigin),e.facetParameters.depthSortedFacets=e.depthSortedFacets,l.VertexData.ComputeNormals(t,i,r,e.facetParameters),e.facetDepthSort&&e.facetDepthSortEnabled){e.depthSortedFacets.sort(e.facetDepthSortFunction);var p=e.depthSortedIndices.length/3|0;for(u=0;un.subDiv.max||s<0||s>n.subDiv.max||a<0||a>n.subDiv.max?null:n.facetPartitioning[o+n.subDiv.max*s+n.subDiv.max*n.subDiv.max*a]},t.prototype.getClosestFacetAtCoordinates=function(e,t,i,r,n,o){void 0===n&&(n=!1),void 0===o&&(o=!0);var a=this.getWorldMatrix(),h=s.c.Matrix[5];a.invertToRef(h);var l=s.c.Vector3[8];s.e.TransformCoordinatesFromFloatsToRef(e,t,i,h,l);var c=this.getClosestFacetAtLocalCoordinates(l.x,l.y,l.z,r,n,o);return r&&s.e.TransformCoordinatesFromFloatsToRef(r.x,r.y,r.z,a,r),c},t.prototype.getClosestFacetAtLocalCoordinates=function(e,t,i,r,n,o){void 0===n&&(n=!1),void 0===o&&(o=!0);var s=null,a=0,h=0,l=0,c=0,u=0,f=0,d=0,p=0,_=this.getFacetLocalPositions(),g=this.getFacetLocalNormals(),m=this.getFacetsAtLocalCoordinates(e,t,i);if(!m)return null;for(var b,v,y,x=Number.MAX_VALUE,T=x,E=0;E=0||n&&!o&&c<=0)&&(c=v.x*y.x+v.y*y.y+v.z*y.z,u=-(v.x*e+v.y*t+v.z*i-c)/(v.x*v.x+v.y*v.y+v.z*v.z),(T=(a=(f=e+v.x*u)-e)*a+(h=(d=t+v.y*u)-t)*h+(l=(p=i+v.z*u)-i)*l)0&&-1===this.includedOnlyMeshes.indexOf(e))&&(!(this.excludedMeshes&&this.excludedMeshes.length>0&&-1!==this.excludedMeshes.indexOf(e))&&((0===this.includeOnlyWithLayerMask||0!=(this.includeOnlyWithLayerMask&e.layerMask))&&!(0!==this.excludeWithLayerMask&&this.excludeWithLayerMask&e.layerMask)))},t.CompareLightsPriority=function(e,t){return e.shadowEnabled!==t.shadowEnabled?(t.shadowEnabled?1:0)-(e.shadowEnabled?1:0):t.renderPriority-e.renderPriority},t.prototype.dispose=function(t,i){void 0===i&&(i=!1),this._shadowGenerator&&(this._shadowGenerator.dispose(),this._shadowGenerator=null),this.getScene().stopAnimation(this);for(var r=0,n=this.getScene().meshes;r0&&(e.excludedMeshesIds=[],this.excludedMeshes.forEach((function(t){e.excludedMeshesIds.push(t.id)}))),this.includedOnlyMeshes.length>0&&(e.includedOnlyMeshesIds=[],this.includedOnlyMeshes.forEach((function(t){e.includedOnlyMeshesIds.push(t.id)}))),n.a.AppendSerializedAnimations(this,e),e.ranges=this.serializeAnimationRanges(),e},t.GetConstructorFromName=function(e,t,i){var r=a.a.Construct("Light_Type_"+e,t,i);return r||null},t.Parse=function(e,i){var r=t.GetConstructorFromName(e.type,e.name,i);if(!r)return null;var o=n.a.Parse(r,e,i);if(e.excludedMeshesIds&&(o._excludedMeshesIds=e.excludedMeshesIds),e.includedOnlyMeshesIds&&(o._includedOnlyMeshesIds=e.includedOnlyMeshesIds),e.parentId&&(o._waitingParentId=e.parentId),void 0!==e.falloffType&&(o.falloffType=e.falloffType),void 0!==e.lightmapMode&&(o.lightmapMode=e.lightmapMode),e.animations){for(var s=0;s0,o.REFLECTIONOVERALPHA=this._useReflectionOverAlpha,o.INVERTCUBICMAP=this._reflectionTexture.coordinatesMode===p.a.INVCUBIC_MODE,o.REFLECTIONMAP_3D=this._reflectionTexture.isCube,this._reflectionTexture.coordinatesMode){case p.a.EXPLICIT_MODE:o.setReflectionMode("REFLECTIONMAP_EXPLICIT");break;case p.a.PLANAR_MODE:o.setReflectionMode("REFLECTIONMAP_PLANAR");break;case p.a.PROJECTION_MODE:o.setReflectionMode("REFLECTIONMAP_PROJECTION");break;case p.a.SKYBOX_MODE:o.setReflectionMode("REFLECTIONMAP_SKYBOX");break;case p.a.SPHERICAL_MODE:o.setReflectionMode("REFLECTIONMAP_SPHERICAL");break;case p.a.EQUIRECTANGULAR_MODE:o.setReflectionMode("REFLECTIONMAP_EQUIRECTANGULAR");break;case p.a.FIXED_EQUIRECTANGULAR_MODE:o.setReflectionMode("REFLECTIONMAP_EQUIRECTANGULAR_FIXED");break;case p.a.FIXED_EQUIRECTANGULAR_MIRRORED_MODE:o.setReflectionMode("REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED");break;case p.a.CUBIC_MODE:case p.a.INVCUBIC_MODE:default:o.setReflectionMode("REFLECTIONMAP_CUBIC")}o.USE_LOCAL_REFLECTIONMAP_CUBIC=!!this._reflectionTexture.boundingBoxSize}else o.REFLECTION=!1;if(this._emissiveTexture&&t.EmissiveTextureEnabled){if(!this._emissiveTexture.isReadyOrNotBlocking())return!1;d.a.PrepareDefinesForMergedUV(this._emissiveTexture,o,"EMISSIVE")}else o.EMISSIVE=!1;if(this._lightmapTexture&&t.LightmapTextureEnabled){if(!this._lightmapTexture.isReadyOrNotBlocking())return!1;d.a.PrepareDefinesForMergedUV(this._lightmapTexture,o,"LIGHTMAP"),o.USELIGHTMAPASSHADOWMAP=this._useLightmapAsShadowmap}else o.LIGHTMAP=!1;if(this._specularTexture&&t.SpecularTextureEnabled){if(!this._specularTexture.isReadyOrNotBlocking())return!1;d.a.PrepareDefinesForMergedUV(this._specularTexture,o,"SPECULAR"),o.GLOSSINESS=this._useGlossinessFromSpecularMapAlpha}else o.SPECULAR=!1;if(n.getEngine().getCaps().standardDerivatives&&this._bumpTexture&&t.BumpTextureEnabled){if(!this._bumpTexture.isReady())return!1;d.a.PrepareDefinesForMergedUV(this._bumpTexture,o,"BUMP"),o.PARALLAX=this._useParallax,o.PARALLAXOCCLUSION=this._useParallaxOcclusion,o.OBJECTSPACE_NORMALMAP=this._useObjectSpaceNormalMap}else o.BUMP=!1;if(this._refractionTexture&&t.RefractionTextureEnabled){if(!this._refractionTexture.isReadyOrNotBlocking())return!1;o._needUVs=!0,o.REFRACTION=!0,o.REFRACTIONMAP_3D=this._refractionTexture.isCube}else o.REFRACTION=!1;o.TWOSIDEDLIGHTING=!this._backFaceCulling&&this._twoSidedLighting}else o.DIFFUSE=!1,o.AMBIENT=!1,o.OPACITY=!1,o.REFLECTION=!1,o.EMISSIVE=!1,o.LIGHTMAP=!1,o.BUMP=!1,o.REFRACTION=!1;o.ALPHAFROMDIFFUSE=this._shouldUseAlphaFromDiffuseTexture(),o.EMISSIVEASILLUMINATION=this._useEmissiveAsIllumination,o.LINKEMISSIVEWITHDIFFUSE=this._linkEmissiveWithDiffuse,o.SPECULAROVERALPHA=this._useSpecularOverAlpha,o.PREMULTIPLYALPHA=7===this.alphaMode||8===this.alphaMode}if(o._areImageProcessingDirty&&this._imageProcessingConfiguration){if(!this._imageProcessingConfiguration.isReady())return!1;this._imageProcessingConfiguration.prepareDefines(o),o.IS_REFLECTION_LINEAR=null!=this.reflectionTexture&&!this.reflectionTexture.gammaSpace,o.IS_REFRACTION_LINEAR=null!=this.refractionTexture&&!this.refractionTexture.gammaSpace}if(o._areFresnelDirty&&(t.FresnelEnabled?(this._diffuseFresnelParameters||this._opacityFresnelParameters||this._emissiveFresnelParameters||this._refractionFresnelParameters||this._reflectionFresnelParameters)&&(o.DIFFUSEFRESNEL=this._diffuseFresnelParameters&&this._diffuseFresnelParameters.isEnabled,o.OPACITYFRESNEL=this._opacityFresnelParameters&&this._opacityFresnelParameters.isEnabled,o.REFLECTIONFRESNEL=this._reflectionFresnelParameters&&this._reflectionFresnelParameters.isEnabled,o.REFLECTIONFRESNELFROMSPECULAR=this._useReflectionFresnelFromSpecular,o.REFRACTIONFRESNEL=this._refractionFresnelParameters&&this._refractionFresnelParameters.isEnabled,o.EMISSIVEFRESNEL=this._emissiveFresnelParameters&&this._emissiveFresnelParameters.isEnabled,o._needNormals=!0,o.FRESNEL=!0):o.FRESNEL=!1),d.a.PrepareDefinesForMisc(e,n,this._useLogarithmicDepth,this.pointsCloud,this.fogEnabled,this._shouldTurnAlphaTestOn(e),o),d.a.PrepareDefinesForAttributes(e,o,!0,!0,!0),d.a.PrepareDefinesForFrameBoundValues(n,s,o,r),o.isDirty){var a=o._areLightsDisposed;o.markAsProcessed();var h=new Z.a;o.REFLECTION&&h.addFallback(0,"REFLECTION"),o.SPECULAR&&h.addFallback(0,"SPECULAR"),o.BUMP&&h.addFallback(0,"BUMP"),o.PARALLAX&&h.addFallback(1,"PARALLAX"),o.PARALLAXOCCLUSION&&h.addFallback(0,"PARALLAXOCCLUSION"),o.SPECULAROVERALPHA&&h.addFallback(0,"SPECULAROVERALPHA"),o.FOG&&h.addFallback(1,"FOG"),o.POINTSIZE&&h.addFallback(0,"POINTSIZE"),o.LOGARITHMICDEPTH&&h.addFallback(0,"LOGARITHMICDEPTH"),d.a.HandleFallbacksForShadows(o,h,this._maxSimultaneousLights),o.SPECULARTERM&&h.addFallback(0,"SPECULARTERM"),o.DIFFUSEFRESNEL&&h.addFallback(1,"DIFFUSEFRESNEL"),o.OPACITYFRESNEL&&h.addFallback(2,"OPACITYFRESNEL"),o.REFLECTIONFRESNEL&&h.addFallback(3,"REFLECTIONFRESNEL"),o.EMISSIVEFRESNEL&&h.addFallback(4,"EMISSIVEFRESNEL"),o.FRESNEL&&h.addFallback(4,"FRESNEL"),o.MULTIVIEW&&h.addFallback(0,"MULTIVIEW");var u=[l.b.PositionKind];o.NORMAL&&u.push(l.b.NormalKind),o.UV1&&u.push(l.b.UVKind),o.UV2&&u.push(l.b.UV2Kind),o.VERTEXCOLOR&&u.push(l.b.ColorKind),d.a.PrepareAttributesForBones(u,e,o,h),d.a.PrepareAttributesForInstances(u,o),d.a.PrepareAttributesForMorphTargets(u,e,o);var f="default",_=["world","view","viewProjection","vEyePosition","vLightsType","vAmbientColor","vDiffuseColor","vSpecularColor","vEmissiveColor","visibility","vFogInfos","vFogColor","pointSize","vDiffuseInfos","vAmbientInfos","vOpacityInfos","vReflectionInfos","vEmissiveInfos","vSpecularInfos","vBumpInfos","vLightmapInfos","vRefractionInfos","mBones","vClipPlane","vClipPlane2","vClipPlane3","vClipPlane4","vClipPlane5","vClipPlane6","diffuseMatrix","ambientMatrix","opacityMatrix","reflectionMatrix","emissiveMatrix","specularMatrix","bumpMatrix","normalMatrix","lightmapMatrix","refractionMatrix","diffuseLeftColor","diffuseRightColor","opacityParts","reflectionLeftColor","reflectionRightColor","emissiveLeftColor","emissiveRightColor","refractionLeftColor","refractionRightColor","vReflectionPosition","vReflectionSize","logarithmicDepthConstant","vTangentSpaceParams","alphaCutOff","boneTextureWidth"],g=["diffuseSampler","ambientSampler","opacitySampler","reflectionCubeSampler","reflection2DSampler","emissiveSampler","specularSampler","bumpSampler","lightmapSampler","refractionCubeSampler","refraction2DSampler","boneSampler"],m=["Material","Scene"];c.a&&(c.a.PrepareUniforms(_,o),c.a.PrepareSamplers(g,o)),d.a.PrepareUniformsAndSamplersList({uniformsNames:_,uniformBuffersNames:m,samplers:g,defines:o,maxSimultaneousLights:this._maxSimultaneousLights}),this.customShaderNameResolve&&(f=this.customShaderNameResolve(f,_,m,g,o));var b=o.toString(),v=i.effect,y=n.getEngine().createEffect(f,{attributes:u,uniformsNames:_,uniformBuffersNames:m,samplers:g,defines:b,fallbacks:h,onCompiled:this.onCompiled,onError:this.onError,indexParameters:{maxSimultaneousLights:this._maxSimultaneousLights,maxSimultaneousMorphTargets:o.NUM_MORPH_INFLUENCERS}},s);if(y)if(this.allowShaderHotSwapping&&v&&!y.isReady()){if(y=v,this._rebuildInParallel=!0,o.markAsUnprocessed(),a)return o._areLightsDisposed=!0,!1}else this._rebuildInParallel=!1,n.resetCachedMaterial(),i.setEffect(y,o),this.buildUniformLayout()}return!(!i.effect||!i.effect.isReady())&&(o._renderId=n.getRenderId(),i.effect._wasPreviouslyReady=!0,!0)},t.prototype.buildUniformLayout=function(){var e=this._uniformBuffer;e.addUniform("diffuseLeftColor",4),e.addUniform("diffuseRightColor",4),e.addUniform("opacityParts",4),e.addUniform("reflectionLeftColor",4),e.addUniform("reflectionRightColor",4),e.addUniform("refractionLeftColor",4),e.addUniform("refractionRightColor",4),e.addUniform("emissiveLeftColor",4),e.addUniform("emissiveRightColor",4),e.addUniform("vDiffuseInfos",2),e.addUniform("vAmbientInfos",2),e.addUniform("vOpacityInfos",2),e.addUniform("vReflectionInfos",2),e.addUniform("vReflectionPosition",3),e.addUniform("vReflectionSize",3),e.addUniform("vEmissiveInfos",2),e.addUniform("vLightmapInfos",2),e.addUniform("vSpecularInfos",2),e.addUniform("vBumpInfos",3),e.addUniform("diffuseMatrix",16),e.addUniform("ambientMatrix",16),e.addUniform("opacityMatrix",16),e.addUniform("reflectionMatrix",16),e.addUniform("emissiveMatrix",16),e.addUniform("lightmapMatrix",16),e.addUniform("specularMatrix",16),e.addUniform("bumpMatrix",16),e.addUniform("vTangentSpaceParams",2),e.addUniform("pointSize",1),e.addUniform("refractionMatrix",16),e.addUniform("vRefractionInfos",4),e.addUniform("vSpecularColor",4),e.addUniform("vEmissiveColor",3),e.addUniform("visibility",1),e.addUniform("vDiffuseColor",4),e.create()},t.prototype.unbind=function(){if(this._activeEffect){var t=!1;this._reflectionTexture&&this._reflectionTexture.isRenderTarget&&(this._activeEffect.setTexture("reflection2DSampler",null),t=!0),this._refractionTexture&&this._refractionTexture.isRenderTarget&&(this._activeEffect.setTexture("refraction2DSampler",null),t=!0),t&&this._markAllSubMeshesAsTexturesDirty()}e.prototype.unbind.call(this)},t.prototype.bindForSubMesh=function(e,i,r){var n=this.getScene(),o=r._materialDefines;if(o){var a=r.effect;if(a){this._activeEffect=a,o.INSTANCES||this.bindOnlyWorldMatrix(e),o.OBJECTSPACE_NORMALMAP&&(e.toNormalMatrix(this._normalMatrix),this.bindOnlyNormalMatrix(this._normalMatrix));var l=this._mustRebind(n,a,i.visibility);d.a.BindBonesParameters(i,a);var c=this._uniformBuffer;if(l){if(c.bindToEffect(a,"Material"),this.bindViewProjection(a),!c.useUbo||!this.isFrozen||!c.isSync){if(t.FresnelEnabled&&o.FRESNEL&&(this.diffuseFresnelParameters&&this.diffuseFresnelParameters.isEnabled&&(c.updateColor4("diffuseLeftColor",this.diffuseFresnelParameters.leftColor,this.diffuseFresnelParameters.power),c.updateColor4("diffuseRightColor",this.diffuseFresnelParameters.rightColor,this.diffuseFresnelParameters.bias)),this.opacityFresnelParameters&&this.opacityFresnelParameters.isEnabled&&c.updateColor4("opacityParts",new h.a(this.opacityFresnelParameters.leftColor.toLuminance(),this.opacityFresnelParameters.rightColor.toLuminance(),this.opacityFresnelParameters.bias),this.opacityFresnelParameters.power),this.reflectionFresnelParameters&&this.reflectionFresnelParameters.isEnabled&&(c.updateColor4("reflectionLeftColor",this.reflectionFresnelParameters.leftColor,this.reflectionFresnelParameters.power),c.updateColor4("reflectionRightColor",this.reflectionFresnelParameters.rightColor,this.reflectionFresnelParameters.bias)),this.refractionFresnelParameters&&this.refractionFresnelParameters.isEnabled&&(c.updateColor4("refractionLeftColor",this.refractionFresnelParameters.leftColor,this.refractionFresnelParameters.power),c.updateColor4("refractionRightColor",this.refractionFresnelParameters.rightColor,this.refractionFresnelParameters.bias)),this.emissiveFresnelParameters&&this.emissiveFresnelParameters.isEnabled&&(c.updateColor4("emissiveLeftColor",this.emissiveFresnelParameters.leftColor,this.emissiveFresnelParameters.power),c.updateColor4("emissiveRightColor",this.emissiveFresnelParameters.rightColor,this.emissiveFresnelParameters.bias))),n.texturesEnabled){if(this._diffuseTexture&&t.DiffuseTextureEnabled&&(c.updateFloat2("vDiffuseInfos",this._diffuseTexture.coordinatesIndex,this._diffuseTexture.level),d.a.BindTextureMatrix(this._diffuseTexture,c,"diffuse"),this._diffuseTexture.hasAlpha&&a.setFloat("alphaCutOff",this.alphaCutOff)),this._ambientTexture&&t.AmbientTextureEnabled&&(c.updateFloat2("vAmbientInfos",this._ambientTexture.coordinatesIndex,this._ambientTexture.level),d.a.BindTextureMatrix(this._ambientTexture,c,"ambient")),this._opacityTexture&&t.OpacityTextureEnabled&&(c.updateFloat2("vOpacityInfos",this._opacityTexture.coordinatesIndex,this._opacityTexture.level),d.a.BindTextureMatrix(this._opacityTexture,c,"opacity")),this._reflectionTexture&&t.ReflectionTextureEnabled&&(c.updateFloat2("vReflectionInfos",this._reflectionTexture.level,this.roughness),c.updateMatrix("reflectionMatrix",this._reflectionTexture.getReflectionTextureMatrix()),this._reflectionTexture.boundingBoxSize)){var u=this._reflectionTexture;c.updateVector3("vReflectionPosition",u.boundingBoxPosition),c.updateVector3("vReflectionSize",u.boundingBoxSize)}if(this._emissiveTexture&&t.EmissiveTextureEnabled&&(c.updateFloat2("vEmissiveInfos",this._emissiveTexture.coordinatesIndex,this._emissiveTexture.level),d.a.BindTextureMatrix(this._emissiveTexture,c,"emissive")),this._lightmapTexture&&t.LightmapTextureEnabled&&(c.updateFloat2("vLightmapInfos",this._lightmapTexture.coordinatesIndex,this._lightmapTexture.level),d.a.BindTextureMatrix(this._lightmapTexture,c,"lightmap")),this._specularTexture&&t.SpecularTextureEnabled&&(c.updateFloat2("vSpecularInfos",this._specularTexture.coordinatesIndex,this._specularTexture.level),d.a.BindTextureMatrix(this._specularTexture,c,"specular")),this._bumpTexture&&n.getEngine().getCaps().standardDerivatives&&t.BumpTextureEnabled&&(c.updateFloat3("vBumpInfos",this._bumpTexture.coordinatesIndex,1/this._bumpTexture.level,this.parallaxScaleBias),d.a.BindTextureMatrix(this._bumpTexture,c,"bump"),n._mirroredCameraPosition?c.updateFloat2("vTangentSpaceParams",this._invertNormalMapX?1:-1,this._invertNormalMapY?1:-1):c.updateFloat2("vTangentSpaceParams",this._invertNormalMapX?-1:1,this._invertNormalMapY?-1:1)),this._refractionTexture&&t.RefractionTextureEnabled){var f=1;this._refractionTexture.isCube||(c.updateMatrix("refractionMatrix",this._refractionTexture.getReflectionTextureMatrix()),this._refractionTexture.depth&&(f=this._refractionTexture.depth)),c.updateFloat4("vRefractionInfos",this._refractionTexture.level,this.indexOfRefraction,f,this.invertRefractionY?-1:1)}}this.pointsCloud&&c.updateFloat("pointSize",this.pointSize),o.SPECULARTERM&&c.updateColor4("vSpecularColor",this.specularColor,this.specularPower),c.updateColor3("vEmissiveColor",t.EmissiveTextureEnabled?this.emissiveColor:h.a.BlackReadOnly),c.updateFloat("visibility",i.visibility),c.updateColor4("vDiffuseColor",this.diffuseColor,this.alpha)}if(n.texturesEnabled&&(this._diffuseTexture&&t.DiffuseTextureEnabled&&a.setTexture("diffuseSampler",this._diffuseTexture),this._ambientTexture&&t.AmbientTextureEnabled&&a.setTexture("ambientSampler",this._ambientTexture),this._opacityTexture&&t.OpacityTextureEnabled&&a.setTexture("opacitySampler",this._opacityTexture),this._reflectionTexture&&t.ReflectionTextureEnabled&&(this._reflectionTexture.isCube?a.setTexture("reflectionCubeSampler",this._reflectionTexture):a.setTexture("reflection2DSampler",this._reflectionTexture)),this._emissiveTexture&&t.EmissiveTextureEnabled&&a.setTexture("emissiveSampler",this._emissiveTexture),this._lightmapTexture&&t.LightmapTextureEnabled&&a.setTexture("lightmapSampler",this._lightmapTexture),this._specularTexture&&t.SpecularTextureEnabled&&a.setTexture("specularSampler",this._specularTexture),this._bumpTexture&&n.getEngine().getCaps().standardDerivatives&&t.BumpTextureEnabled&&a.setTexture("bumpSampler",this._bumpTexture),this._refractionTexture&&t.RefractionTextureEnabled)){f=1;this._refractionTexture.isCube?a.setTexture("refractionCubeSampler",this._refractionTexture):a.setTexture("refraction2DSampler",this._refractionTexture)}d.a.BindClipPlane(a,n),n.ambientColor.multiplyToRef(this.ambientColor,this._globalAmbientColor),d.a.BindEyePosition(a,n),a.setColor3("vAmbientColor",this._globalAmbientColor)}!l&&this.isFrozen||(n.lightsEnabled&&!this._disableLighting&&d.a.BindLights(n,i,a,o,this._maxSimultaneousLights,this._rebuildInParallel),(n.fogEnabled&&i.applyFog&&n.fogMode!==s.Scene.FOGMODE_NONE||this._reflectionTexture||this._refractionTexture)&&this.bindView(a),d.a.BindFogParameters(n,i,a),o.NUM_MORPH_INFLUENCERS&&d.a.BindMorphTargetParameters(i,a),this.useLogarithmicDepth&&d.a.BindLogDepth(o,a,n),this._imageProcessingConfiguration&&!this._imageProcessingConfiguration.applyByPostProcess&&this._imageProcessingConfiguration.bind(this._activeEffect)),c.update(),this._afterBind(i,this._activeEffect)}}},t.prototype.getAnimatables=function(){var e=[];return this._diffuseTexture&&this._diffuseTexture.animations&&this._diffuseTexture.animations.length>0&&e.push(this._diffuseTexture),this._ambientTexture&&this._ambientTexture.animations&&this._ambientTexture.animations.length>0&&e.push(this._ambientTexture),this._opacityTexture&&this._opacityTexture.animations&&this._opacityTexture.animations.length>0&&e.push(this._opacityTexture),this._reflectionTexture&&this._reflectionTexture.animations&&this._reflectionTexture.animations.length>0&&e.push(this._reflectionTexture),this._emissiveTexture&&this._emissiveTexture.animations&&this._emissiveTexture.animations.length>0&&e.push(this._emissiveTexture),this._specularTexture&&this._specularTexture.animations&&this._specularTexture.animations.length>0&&e.push(this._specularTexture),this._bumpTexture&&this._bumpTexture.animations&&this._bumpTexture.animations.length>0&&e.push(this._bumpTexture),this._lightmapTexture&&this._lightmapTexture.animations&&this._lightmapTexture.animations.length>0&&e.push(this._lightmapTexture),this._refractionTexture&&this._refractionTexture.animations&&this._refractionTexture.animations.length>0&&e.push(this._refractionTexture),e},t.prototype.getActiveTextures=function(){var t=e.prototype.getActiveTextures.call(this);return this._diffuseTexture&&t.push(this._diffuseTexture),this._ambientTexture&&t.push(this._ambientTexture),this._opacityTexture&&t.push(this._opacityTexture),this._reflectionTexture&&t.push(this._reflectionTexture),this._emissiveTexture&&t.push(this._emissiveTexture),this._specularTexture&&t.push(this._specularTexture),this._bumpTexture&&t.push(this._bumpTexture),this._lightmapTexture&&t.push(this._lightmapTexture),this._refractionTexture&&t.push(this._refractionTexture),t},t.prototype.hasTexture=function(t){return!!e.prototype.hasTexture.call(this,t)||(this._diffuseTexture===t||(this._ambientTexture===t||(this._opacityTexture===t||(this._reflectionTexture===t||(this._emissiveTexture===t||(this._specularTexture===t||(this._bumpTexture===t||(this._lightmapTexture===t||this._refractionTexture===t))))))))},t.prototype.dispose=function(t,i){i&&(this._diffuseTexture&&this._diffuseTexture.dispose(),this._ambientTexture&&this._ambientTexture.dispose(),this._opacityTexture&&this._opacityTexture.dispose(),this._reflectionTexture&&this._reflectionTexture.dispose(),this._emissiveTexture&&this._emissiveTexture.dispose(),this._specularTexture&&this._specularTexture.dispose(),this._bumpTexture&&this._bumpTexture.dispose(),this._lightmapTexture&&this._lightmapTexture.dispose(),this._refractionTexture&&this._refractionTexture.dispose()),this._imageProcessingConfiguration&&this._imageProcessingObserver&&this._imageProcessingConfiguration.onUpdateParameters.remove(this._imageProcessingObserver),e.prototype.dispose.call(this,t,i)},t.prototype.clone=function(e){var i=this,r=n.a.Clone((function(){return new t(e,i.getScene())}),this);return r.name=e,r.id=e,r},t.prototype.serialize=function(){return n.a.Serialize(this)},t.Parse=function(e,i,r){return n.a.Parse((function(){return new t(e.name,i)}),e,i,r)},Object.defineProperty(t,"DiffuseTextureEnabled",{get:function(){return m.DiffuseTextureEnabled},set:function(e){m.DiffuseTextureEnabled=e},enumerable:!0,configurable:!0}),Object.defineProperty(t,"AmbientTextureEnabled",{get:function(){return m.AmbientTextureEnabled},set:function(e){m.AmbientTextureEnabled=e},enumerable:!0,configurable:!0}),Object.defineProperty(t,"OpacityTextureEnabled",{get:function(){return m.OpacityTextureEnabled},set:function(e){m.OpacityTextureEnabled=e},enumerable:!0,configurable:!0}),Object.defineProperty(t,"ReflectionTextureEnabled",{get:function(){return m.ReflectionTextureEnabled},set:function(e){m.ReflectionTextureEnabled=e},enumerable:!0,configurable:!0}),Object.defineProperty(t,"EmissiveTextureEnabled",{get:function(){return m.EmissiveTextureEnabled},set:function(e){m.EmissiveTextureEnabled=e},enumerable:!0,configurable:!0}),Object.defineProperty(t,"SpecularTextureEnabled",{get:function(){return m.SpecularTextureEnabled},set:function(e){m.SpecularTextureEnabled=e},enumerable:!0,configurable:!0}),Object.defineProperty(t,"BumpTextureEnabled",{get:function(){return m.BumpTextureEnabled},set:function(e){m.BumpTextureEnabled=e},enumerable:!0,configurable:!0}),Object.defineProperty(t,"LightmapTextureEnabled",{get:function(){return m.LightmapTextureEnabled},set:function(e){m.LightmapTextureEnabled=e},enumerable:!0,configurable:!0}),Object.defineProperty(t,"RefractionTextureEnabled",{get:function(){return m.RefractionTextureEnabled},set:function(e){m.RefractionTextureEnabled=e},enumerable:!0,configurable:!0}),Object.defineProperty(t,"ColorGradingTextureEnabled",{get:function(){return m.ColorGradingTextureEnabled},set:function(e){m.ColorGradingTextureEnabled=e},enumerable:!0,configurable:!0}),Object.defineProperty(t,"FresnelEnabled",{get:function(){return m.FresnelEnabled},set:function(e){m.FresnelEnabled=e},enumerable:!0,configurable:!0}),Object(r.b)([Object(n.j)("diffuseTexture")],t.prototype,"_diffuseTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesAndMiscDirty")],t.prototype,"diffuseTexture",void 0),Object(r.b)([Object(n.j)("ambientTexture")],t.prototype,"_ambientTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"ambientTexture",void 0),Object(r.b)([Object(n.j)("opacityTexture")],t.prototype,"_opacityTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesAndMiscDirty")],t.prototype,"opacityTexture",void 0),Object(r.b)([Object(n.j)("reflectionTexture")],t.prototype,"_reflectionTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"reflectionTexture",void 0),Object(r.b)([Object(n.j)("emissiveTexture")],t.prototype,"_emissiveTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"emissiveTexture",void 0),Object(r.b)([Object(n.j)("specularTexture")],t.prototype,"_specularTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"specularTexture",void 0),Object(r.b)([Object(n.j)("bumpTexture")],t.prototype,"_bumpTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"bumpTexture",void 0),Object(r.b)([Object(n.j)("lightmapTexture")],t.prototype,"_lightmapTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"lightmapTexture",void 0),Object(r.b)([Object(n.j)("refractionTexture")],t.prototype,"_refractionTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"refractionTexture",void 0),Object(r.b)([Object(n.d)("ambient")],t.prototype,"ambientColor",void 0),Object(r.b)([Object(n.d)("diffuse")],t.prototype,"diffuseColor",void 0),Object(r.b)([Object(n.d)("specular")],t.prototype,"specularColor",void 0),Object(r.b)([Object(n.d)("emissive")],t.prototype,"emissiveColor",void 0),Object(r.b)([Object(n.c)()],t.prototype,"specularPower",void 0),Object(r.b)([Object(n.c)("useAlphaFromDiffuseTexture")],t.prototype,"_useAlphaFromDiffuseTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useAlphaFromDiffuseTexture",void 0),Object(r.b)([Object(n.c)("useEmissiveAsIllumination")],t.prototype,"_useEmissiveAsIllumination",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useEmissiveAsIllumination",void 0),Object(r.b)([Object(n.c)("linkEmissiveWithDiffuse")],t.prototype,"_linkEmissiveWithDiffuse",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"linkEmissiveWithDiffuse",void 0),Object(r.b)([Object(n.c)("useSpecularOverAlpha")],t.prototype,"_useSpecularOverAlpha",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useSpecularOverAlpha",void 0),Object(r.b)([Object(n.c)("useReflectionOverAlpha")],t.prototype,"_useReflectionOverAlpha",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useReflectionOverAlpha",void 0),Object(r.b)([Object(n.c)("disableLighting")],t.prototype,"_disableLighting",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsLightsDirty")],t.prototype,"disableLighting",void 0),Object(r.b)([Object(n.c)("useObjectSpaceNormalMap")],t.prototype,"_useObjectSpaceNormalMap",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useObjectSpaceNormalMap",void 0),Object(r.b)([Object(n.c)("useParallax")],t.prototype,"_useParallax",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useParallax",void 0),Object(r.b)([Object(n.c)("useParallaxOcclusion")],t.prototype,"_useParallaxOcclusion",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useParallaxOcclusion",void 0),Object(r.b)([Object(n.c)()],t.prototype,"parallaxScaleBias",void 0),Object(r.b)([Object(n.c)("roughness")],t.prototype,"_roughness",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"roughness",void 0),Object(r.b)([Object(n.c)()],t.prototype,"indexOfRefraction",void 0),Object(r.b)([Object(n.c)()],t.prototype,"invertRefractionY",void 0),Object(r.b)([Object(n.c)()],t.prototype,"alphaCutOff",void 0),Object(r.b)([Object(n.c)("useLightmapAsShadowmap")],t.prototype,"_useLightmapAsShadowmap",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useLightmapAsShadowmap",void 0),Object(r.b)([Object(n.g)("diffuseFresnelParameters")],t.prototype,"_diffuseFresnelParameters",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsFresnelDirty")],t.prototype,"diffuseFresnelParameters",void 0),Object(r.b)([Object(n.g)("opacityFresnelParameters")],t.prototype,"_opacityFresnelParameters",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsFresnelAndMiscDirty")],t.prototype,"opacityFresnelParameters",void 0),Object(r.b)([Object(n.g)("reflectionFresnelParameters")],t.prototype,"_reflectionFresnelParameters",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsFresnelDirty")],t.prototype,"reflectionFresnelParameters",void 0),Object(r.b)([Object(n.g)("refractionFresnelParameters")],t.prototype,"_refractionFresnelParameters",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsFresnelDirty")],t.prototype,"refractionFresnelParameters",void 0),Object(r.b)([Object(n.g)("emissiveFresnelParameters")],t.prototype,"_emissiveFresnelParameters",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsFresnelDirty")],t.prototype,"emissiveFresnelParameters",void 0),Object(r.b)([Object(n.c)("useReflectionFresnelFromSpecular")],t.prototype,"_useReflectionFresnelFromSpecular",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsFresnelDirty")],t.prototype,"useReflectionFresnelFromSpecular",void 0),Object(r.b)([Object(n.c)("useGlossinessFromSpecularMapAlpha")],t.prototype,"_useGlossinessFromSpecularMapAlpha",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useGlossinessFromSpecularMapAlpha",void 0),Object(r.b)([Object(n.c)("maxSimultaneousLights")],t.prototype,"_maxSimultaneousLights",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsLightsDirty")],t.prototype,"maxSimultaneousLights",void 0),Object(r.b)([Object(n.c)("invertNormalMapX")],t.prototype,"_invertNormalMapX",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"invertNormalMapX",void 0),Object(r.b)([Object(n.c)("invertNormalMapY")],t.prototype,"_invertNormalMapY",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"invertNormalMapY",void 0),Object(r.b)([Object(n.c)("twoSidedLighting")],t.prototype,"_twoSidedLighting",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"twoSidedLighting",void 0),Object(r.b)([Object(n.c)()],t.prototype,"useLogarithmicDepth",null),t}(f);_.a.RegisteredTypes["BABYLON.StandardMaterial"]=J,s.Scene.DefaultMaterialFactory=function(e){return new J("default material",e)}},function(e,t,i){"use strict";i.d(t,"a",(function(){return n}));var r=i(0),n=function(){function e(e,t,i,n){this.normal=new r.e(e,t,i),this.d=n}return e.prototype.asArray=function(){return[this.normal.x,this.normal.y,this.normal.z,this.d]},e.prototype.clone=function(){return new e(this.normal.x,this.normal.y,this.normal.z,this.d)},e.prototype.getClassName=function(){return"Plane"},e.prototype.getHashCode=function(){var e=this.normal.getHashCode();return e=397*e^(0|this.d)},e.prototype.normalize=function(){var e=Math.sqrt(this.normal.x*this.normal.x+this.normal.y*this.normal.y+this.normal.z*this.normal.z),t=0;return 0!==e&&(t=1/e),this.normal.x*=t,this.normal.y*=t,this.normal.z*=t,this.d*=t,this},e.prototype.transform=function(t){var i=e._TmpMatrix;r.a.TransposeToRef(t,i);var n=i.m,o=this.normal.x,s=this.normal.y,a=this.normal.z,h=this.d;return new e(o*n[0]+s*n[1]+a*n[2]+h*n[3],o*n[4]+s*n[5]+a*n[6]+h*n[7],o*n[8]+s*n[9]+a*n[10]+h*n[11],o*n[12]+s*n[13]+a*n[14]+h*n[15])},e.prototype.dotCoordinate=function(e){return this.normal.x*e.x+this.normal.y*e.y+this.normal.z*e.z+this.d},e.prototype.copyFromPoints=function(e,t,i){var r,n=t.x-e.x,o=t.y-e.y,s=t.z-e.z,a=i.x-e.x,h=i.y-e.y,l=i.z-e.z,c=o*l-s*h,u=s*a-n*l,f=n*h-o*a,d=Math.sqrt(c*c+u*u+f*f);return r=0!==d?1/d:0,this.normal.x=c*r,this.normal.y=u*r,this.normal.z=f*r,this.d=-(this.normal.x*e.x+this.normal.y*e.y+this.normal.z*e.z),this},e.prototype.isFrontFacingTo=function(e,t){return r.e.Dot(this.normal,e)<=t},e.prototype.signedDistanceTo=function(e){return r.e.Dot(e,this.normal)+this.d},e.FromArray=function(t){return new e(t[0],t[1],t[2],t[3])},e.FromPoints=function(t,i,r){var n=new e(0,0,0,0);return n.copyFromPoints(t,i,r),n},e.FromPositionAndNormal=function(t,i){var r=new e(0,0,0,0);return i.normalize(),r.normal=i,r.d=-(i.x*t.x+i.y*t.y+i.z*t.z),r},e.SignedDistanceToPlaneFromPositionAndNormal=function(e,t,i){var n=-(t.x*e.x+t.y*e.y+t.z*e.z);return r.e.Dot(i,t)+n},e._TmpMatrix=r.a.Identity(),e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return n}));var r=i(50),n=function(){function e(){}return e.GetPlanes=function(t){for(var i=[],n=0;n<6;n++)i.push(new r.a(0,0,0,0));return e.GetPlanesToRef(t,i),i},e.GetNearPlaneToRef=function(e,t){var i=e.m;t.normal.x=i[3]+i[2],t.normal.y=i[7]+i[6],t.normal.z=i[11]+i[10],t.d=i[15]+i[14],t.normalize()},e.GetFarPlaneToRef=function(e,t){var i=e.m;t.normal.x=i[3]-i[2],t.normal.y=i[7]-i[6],t.normal.z=i[11]-i[10],t.d=i[15]-i[14],t.normalize()},e.GetLeftPlaneToRef=function(e,t){var i=e.m;t.normal.x=i[3]+i[0],t.normal.y=i[7]+i[4],t.normal.z=i[11]+i[8],t.d=i[15]+i[12],t.normalize()},e.GetRightPlaneToRef=function(e,t){var i=e.m;t.normal.x=i[3]-i[0],t.normal.y=i[7]-i[4],t.normal.z=i[11]-i[8],t.d=i[15]-i[12],t.normalize()},e.GetTopPlaneToRef=function(e,t){var i=e.m;t.normal.x=i[3]-i[1],t.normal.y=i[7]-i[5],t.normal.z=i[11]-i[9],t.d=i[15]-i[13],t.normalize()},e.GetBottomPlaneToRef=function(e,t){var i=e.m;t.normal.x=i[3]+i[1],t.normal.y=i[7]+i[5],t.normal.z=i[11]+i[9],t.d=i[15]+i[13],t.normalize()},e.GetPlanesToRef=function(t,i){e.GetNearPlaneToRef(t,i[0]),e.GetFarPlaneToRef(t,i[1]),e.GetLeftPlaneToRef(t,i[2]),e.GetRightPlaneToRef(t,i[3]),e.GetTopPlaneToRef(t,i[4]),e.GetBottomPlaneToRef(t,i[5])},e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return n}));var r=i(1),n=function(e){function t(t){var i=e.call(this)||this;return i._buffer=t,i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"underlyingResource",{get:function(){return this._buffer},enumerable:!0,configurable:!0}),t}(function(){function e(){this.references=0,this.capacity=0,this.is32Bits=!1}return Object.defineProperty(e.prototype,"underlyingResource",{get:function(){return null},enumerable:!0,configurable:!0}),e}())},function(e,t,i){"use strict";i.d(t,"a",(function(){return r}));var r=function(){function e(e,t,i,r){this.x=e,this.y=t,this.width=i,this.height=r}return e.prototype.toGlobal=function(t,i){return new e(this.x*t,this.y*i,this.width*t,this.height*i)},e.prototype.toGlobalToRef=function(e,t,i){return i.x=this.x*e,i.y=this.y*t,i.width=this.width*e,i.height=this.height*t,this},e.prototype.clone=function(){return new e(this.x,this.y,this.width,this.height)},e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return r}));var r=function(){function e(){}return e.CreateCanvas=function(e,t){if("undefined"==typeof document)return new OffscreenCanvas(e,t);var i=document.createElement("canvas");return i.width=e,i.height=t,i},e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return n}));var r=i(37),n=function(){function e(){this._startMonitoringTime=0,this._min=0,this._max=0,this._average=0,this._lastSecAverage=0,this._current=0,this._totalValueCount=0,this._totalAccumulated=0,this._lastSecAccumulated=0,this._lastSecTime=0,this._lastSecValueCount=0}return Object.defineProperty(e.prototype,"min",{get:function(){return this._min},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"max",{get:function(){return this._max},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"average",{get:function(){return this._average},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"lastSecAverage",{get:function(){return this._lastSecAverage},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"current",{get:function(){return this._current},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"total",{get:function(){return this._totalAccumulated},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"count",{get:function(){return this._totalValueCount},enumerable:!0,configurable:!0}),e.prototype.fetchNewFrame=function(){this._totalValueCount++,this._current=0,this._lastSecValueCount++},e.prototype.addCount=function(t,i){e.Enabled&&(this._current+=t,i&&this._fetchResult())},e.prototype.beginMonitoring=function(){e.Enabled&&(this._startMonitoringTime=r.a.Now)},e.prototype.endMonitoring=function(t){if(void 0===t&&(t=!0),e.Enabled){t&&this.fetchNewFrame();var i=r.a.Now;this._current=i-this._startMonitoringTime,t&&this._fetchResult()}},e.prototype._fetchResult=function(){this._totalAccumulated+=this._current,this._lastSecAccumulated+=this._current,this._min=Math.min(this._min,this._current),this._max=Math.max(this._max,this._current),this._average=this._totalAccumulated/this._totalValueCount;var e=r.a.Now;e-this._lastSecTime>1e3&&(this._lastSecAverage=this._lastSecAccumulated/this._lastSecValueCount,this._lastSecTime=e,this._lastSecAccumulated=0,this._lastSecValueCount=0)},e.Enabled=!0,e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return c}));var r=i(1),n=i(3),o=i(4),s=i(13),a=i(7),h=i(73),l=function(){function e(){this._dirty=!0,this._tempColor=new a.b(0,0,0,0),this._globalCurve=new a.b(0,0,0,0),this._highlightsCurve=new a.b(0,0,0,0),this._midtonesCurve=new a.b(0,0,0,0),this._shadowsCurve=new a.b(0,0,0,0),this._positiveCurve=new a.b(0,0,0,0),this._negativeCurve=new a.b(0,0,0,0),this._globalHue=30,this._globalDensity=0,this._globalSaturation=0,this._globalExposure=0,this._highlightsHue=30,this._highlightsDensity=0,this._highlightsSaturation=0,this._highlightsExposure=0,this._midtonesHue=30,this._midtonesDensity=0,this._midtonesSaturation=0,this._midtonesExposure=0,this._shadowsHue=30,this._shadowsDensity=0,this._shadowsSaturation=0,this._shadowsExposure=0}return Object.defineProperty(e.prototype,"globalHue",{get:function(){return this._globalHue},set:function(e){this._globalHue=e,this._dirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"globalDensity",{get:function(){return this._globalDensity},set:function(e){this._globalDensity=e,this._dirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"globalSaturation",{get:function(){return this._globalSaturation},set:function(e){this._globalSaturation=e,this._dirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"globalExposure",{get:function(){return this._globalExposure},set:function(e){this._globalExposure=e,this._dirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"highlightsHue",{get:function(){return this._highlightsHue},set:function(e){this._highlightsHue=e,this._dirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"highlightsDensity",{get:function(){return this._highlightsDensity},set:function(e){this._highlightsDensity=e,this._dirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"highlightsSaturation",{get:function(){return this._highlightsSaturation},set:function(e){this._highlightsSaturation=e,this._dirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"highlightsExposure",{get:function(){return this._highlightsExposure},set:function(e){this._highlightsExposure=e,this._dirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"midtonesHue",{get:function(){return this._midtonesHue},set:function(e){this._midtonesHue=e,this._dirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"midtonesDensity",{get:function(){return this._midtonesDensity},set:function(e){this._midtonesDensity=e,this._dirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"midtonesSaturation",{get:function(){return this._midtonesSaturation},set:function(e){this._midtonesSaturation=e,this._dirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"midtonesExposure",{get:function(){return this._midtonesExposure},set:function(e){this._midtonesExposure=e,this._dirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"shadowsHue",{get:function(){return this._shadowsHue},set:function(e){this._shadowsHue=e,this._dirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"shadowsDensity",{get:function(){return this._shadowsDensity},set:function(e){this._shadowsDensity=e,this._dirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"shadowsSaturation",{get:function(){return this._shadowsSaturation},set:function(e){this._shadowsSaturation=e,this._dirty=!0},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"shadowsExposure",{get:function(){return this._shadowsExposure},set:function(e){this._shadowsExposure=e,this._dirty=!0},enumerable:!0,configurable:!0}),e.prototype.getClassName=function(){return"ColorCurves"},e.Bind=function(e,t,i,r,n){void 0===i&&(i="vCameraColorCurvePositive"),void 0===r&&(r="vCameraColorCurveNeutral"),void 0===n&&(n="vCameraColorCurveNegative"),e._dirty&&(e._dirty=!1,e.getColorGradingDataToRef(e._globalHue,e._globalDensity,e._globalSaturation,e._globalExposure,e._globalCurve),e.getColorGradingDataToRef(e._highlightsHue,e._highlightsDensity,e._highlightsSaturation,e._highlightsExposure,e._tempColor),e._tempColor.multiplyToRef(e._globalCurve,e._highlightsCurve),e.getColorGradingDataToRef(e._midtonesHue,e._midtonesDensity,e._midtonesSaturation,e._midtonesExposure,e._tempColor),e._tempColor.multiplyToRef(e._globalCurve,e._midtonesCurve),e.getColorGradingDataToRef(e._shadowsHue,e._shadowsDensity,e._shadowsSaturation,e._shadowsExposure,e._tempColor),e._tempColor.multiplyToRef(e._globalCurve,e._shadowsCurve),e._highlightsCurve.subtractToRef(e._midtonesCurve,e._positiveCurve),e._midtonesCurve.subtractToRef(e._shadowsCurve,e._negativeCurve)),t&&(t.setFloat4(i,e._positiveCurve.r,e._positiveCurve.g,e._positiveCurve.b,e._positiveCurve.a),t.setFloat4(r,e._midtonesCurve.r,e._midtonesCurve.g,e._midtonesCurve.b,e._midtonesCurve.a),t.setFloat4(n,e._negativeCurve.r,e._negativeCurve.g,e._negativeCurve.b,e._negativeCurve.a))},e.PrepareUniforms=function(e){e.push("vCameraColorCurveNeutral","vCameraColorCurvePositive","vCameraColorCurveNegative")},e.prototype.getColorGradingDataToRef=function(t,i,r,n,o){null!=t&&(t=e.clamp(t,0,360),i=e.clamp(i,-100,100),r=e.clamp(r,-100,100),n=e.clamp(n,-100,100),i=e.applyColorGradingSliderNonlinear(i),i*=.5,n=e.applyColorGradingSliderNonlinear(n),i<0&&(i*=-1,t=(t+180)%360),e.fromHSBToRef(t,i,50+.25*n,o),o.scaleToRef(2,o),o.a=1+.01*r)},e.applyColorGradingSliderNonlinear=function(e){e/=100;var t=Math.abs(e);return t=Math.pow(t,2),e<0&&(t*=-1),t*=100},e.fromHSBToRef=function(t,i,r,n){var o=e.clamp(t,0,360),s=e.clamp(i/100,0,1),a=e.clamp(r/100,0,1);if(0===s)n.r=a,n.g=a,n.b=a;else{o/=60;var h=Math.floor(o),l=o-h,c=a*(1-s),u=a*(1-s*l),f=a*(1-s*(1-l));switch(h){case 0:n.r=a,n.g=f,n.b=c;break;case 1:n.r=u,n.g=a,n.b=c;break;case 2:n.r=c,n.g=a,n.b=f;break;case 3:n.r=c,n.g=u,n.b=a;break;case 4:n.r=f,n.g=c,n.b=a;break;default:n.r=a,n.g=c,n.b=u}}n.a=1},e.clamp=function(e,t,i){return Math.min(Math.max(e,t),i)},e.prototype.clone=function(){return n.a.Clone((function(){return new e}),this)},e.prototype.serialize=function(){return n.a.Serialize(this)},e.Parse=function(t){return n.a.Parse((function(){return new e}),t,null,null)},Object(r.b)([Object(n.c)()],e.prototype,"_globalHue",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_globalDensity",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_globalSaturation",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_globalExposure",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_highlightsHue",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_highlightsDensity",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_highlightsSaturation",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_highlightsExposure",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_midtonesHue",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_midtonesDensity",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_midtonesSaturation",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_midtonesExposure",void 0),e}();n.a._ColorCurvesParser=l.Parse;!function(e){function t(){var t=e.call(this)||this;return t.IMAGEPROCESSING=!1,t.VIGNETTE=!1,t.VIGNETTEBLENDMODEMULTIPLY=!1,t.VIGNETTEBLENDMODEOPAQUE=!1,t.TONEMAPPING=!1,t.TONEMAPPING_ACES=!1,t.CONTRAST=!1,t.COLORCURVES=!1,t.COLORGRADING=!1,t.COLORGRADING3D=!1,t.SAMPLER3DGREENDEPTH=!1,t.SAMPLER3DBGRMAP=!1,t.IMAGEPROCESSINGPOSTPROCESS=!1,t.EXPOSURE=!1,t.rebuild(),t}Object(r.c)(t,e)}(h.a);var c=function(){function e(){this.colorCurves=new l,this._colorCurvesEnabled=!1,this._colorGradingEnabled=!1,this._colorGradingWithGreenDepth=!0,this._colorGradingBGR=!0,this._exposure=1,this._toneMappingEnabled=!1,this._toneMappingType=e.TONEMAPPING_STANDARD,this._contrast=1,this.vignetteStretch=0,this.vignetteCentreX=0,this.vignetteCentreY=0,this.vignetteWeight=1.5,this.vignetteColor=new a.b(0,0,0,0),this.vignetteCameraFov=.5,this._vignetteBlendMode=e.VIGNETTEMODE_MULTIPLY,this._vignetteEnabled=!1,this._applyByPostProcess=!1,this._isEnabled=!0,this.onUpdateParameters=new o.a}return Object.defineProperty(e.prototype,"colorCurvesEnabled",{get:function(){return this._colorCurvesEnabled},set:function(e){this._colorCurvesEnabled!==e&&(this._colorCurvesEnabled=e,this._updateParameters())},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"colorGradingTexture",{get:function(){return this._colorGradingTexture},set:function(e){this._colorGradingTexture!==e&&(this._colorGradingTexture=e,this._updateParameters())},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"colorGradingEnabled",{get:function(){return this._colorGradingEnabled},set:function(e){this._colorGradingEnabled!==e&&(this._colorGradingEnabled=e,this._updateParameters())},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"colorGradingWithGreenDepth",{get:function(){return this._colorGradingWithGreenDepth},set:function(e){this._colorGradingWithGreenDepth!==e&&(this._colorGradingWithGreenDepth=e,this._updateParameters())},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"colorGradingBGR",{get:function(){return this._colorGradingBGR},set:function(e){this._colorGradingBGR!==e&&(this._colorGradingBGR=e,this._updateParameters())},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"exposure",{get:function(){return this._exposure},set:function(e){this._exposure!==e&&(this._exposure=e,this._updateParameters())},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"toneMappingEnabled",{get:function(){return this._toneMappingEnabled},set:function(e){this._toneMappingEnabled!==e&&(this._toneMappingEnabled=e,this._updateParameters())},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"toneMappingType",{get:function(){return this._toneMappingType},set:function(e){this._toneMappingType!==e&&(this._toneMappingType=e,this._updateParameters())},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"contrast",{get:function(){return this._contrast},set:function(e){this._contrast!==e&&(this._contrast=e,this._updateParameters())},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"vignetteBlendMode",{get:function(){return this._vignetteBlendMode},set:function(e){this._vignetteBlendMode!==e&&(this._vignetteBlendMode=e,this._updateParameters())},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"vignetteEnabled",{get:function(){return this._vignetteEnabled},set:function(e){this._vignetteEnabled!==e&&(this._vignetteEnabled=e,this._updateParameters())},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"applyByPostProcess",{get:function(){return this._applyByPostProcess},set:function(e){this._applyByPostProcess!==e&&(this._applyByPostProcess=e,this._updateParameters())},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isEnabled",{get:function(){return this._isEnabled},set:function(e){this._isEnabled!==e&&(this._isEnabled=e,this._updateParameters())},enumerable:!0,configurable:!0}),e.prototype._updateParameters=function(){this.onUpdateParameters.notifyObservers(this)},e.prototype.getClassName=function(){return"ImageProcessingConfiguration"},e.PrepareUniforms=function(e,t){t.EXPOSURE&&e.push("exposureLinear"),t.CONTRAST&&e.push("contrast"),t.COLORGRADING&&e.push("colorTransformSettings"),t.VIGNETTE&&(e.push("vInverseScreenSize"),e.push("vignetteSettings1"),e.push("vignetteSettings2")),t.COLORCURVES&&l.PrepareUniforms(e)},e.PrepareSamplers=function(e,t){t.COLORGRADING&&e.push("txColorTransform")},e.prototype.prepareDefines=function(t,i){if(void 0===i&&(i=!1),i!==this.applyByPostProcess||!this._isEnabled)return t.VIGNETTE=!1,t.TONEMAPPING=!1,t.TONEMAPPING_ACES=!1,t.CONTRAST=!1,t.EXPOSURE=!1,t.COLORCURVES=!1,t.COLORGRADING=!1,t.COLORGRADING3D=!1,t.IMAGEPROCESSING=!1,void(t.IMAGEPROCESSINGPOSTPROCESS=this.applyByPostProcess&&this._isEnabled);switch(t.VIGNETTE=this.vignetteEnabled,t.VIGNETTEBLENDMODEMULTIPLY=this.vignetteBlendMode===e._VIGNETTEMODE_MULTIPLY,t.VIGNETTEBLENDMODEOPAQUE=!t.VIGNETTEBLENDMODEMULTIPLY,t.TONEMAPPING=this.toneMappingEnabled,this._toneMappingType){case e.TONEMAPPING_ACES:t.TONEMAPPING_ACES=!0;break;default:t.TONEMAPPING_ACES=!1}t.CONTRAST=1!==this.contrast,t.EXPOSURE=1!==this.exposure,t.COLORCURVES=this.colorCurvesEnabled&&!!this.colorCurves,t.COLORGRADING=this.colorGradingEnabled&&!!this.colorGradingTexture,t.COLORGRADING?t.COLORGRADING3D=this.colorGradingTexture.is3D:t.COLORGRADING3D=!1,t.SAMPLER3DGREENDEPTH=this.colorGradingWithGreenDepth,t.SAMPLER3DBGRMAP=this.colorGradingBGR,t.IMAGEPROCESSINGPOSTPROCESS=this.applyByPostProcess,t.IMAGEPROCESSING=t.VIGNETTE||t.TONEMAPPING||t.CONTRAST||t.EXPOSURE||t.COLORCURVES||t.COLORGRADING},e.prototype.isReady=function(){return!this.colorGradingEnabled||!this.colorGradingTexture||this.colorGradingTexture.isReady()},e.prototype.bind=function(e,t){if(this._colorCurvesEnabled&&this.colorCurves&&l.Bind(this.colorCurves,e),this._vignetteEnabled){var i=1/e.getEngine().getRenderWidth(),r=1/e.getEngine().getRenderHeight();e.setFloat2("vInverseScreenSize",i,r);var n=null!=t?t:r/i,o=Math.tan(.5*this.vignetteCameraFov),a=o*n,h=Math.sqrt(a*o);a=s.b.Mix(a,h,this.vignetteStretch),o=s.b.Mix(o,h,this.vignetteStretch),e.setFloat4("vignetteSettings1",a,o,-a*this.vignetteCentreX,-o*this.vignetteCentreY);var c=-2*this.vignetteWeight;e.setFloat4("vignetteSettings2",this.vignetteColor.r,this.vignetteColor.g,this.vignetteColor.b,c)}if(e.setFloat("exposureLinear",this.exposure),e.setFloat("contrast",this.contrast),this.colorGradingTexture){e.setTexture("txColorTransform",this.colorGradingTexture);var u=this.colorGradingTexture.getSize().height;e.setFloat4("colorTransformSettings",(u-1)/u,.5/u,u,this.colorGradingTexture.level)}},e.prototype.clone=function(){return n.a.Clone((function(){return new e}),this)},e.prototype.serialize=function(){return n.a.Serialize(this)},e.Parse=function(t){return n.a.Parse((function(){return new e}),t,null,null)},Object.defineProperty(e,"VIGNETTEMODE_MULTIPLY",{get:function(){return this._VIGNETTEMODE_MULTIPLY},enumerable:!0,configurable:!0}),Object.defineProperty(e,"VIGNETTEMODE_OPAQUE",{get:function(){return this._VIGNETTEMODE_OPAQUE},enumerable:!0,configurable:!0}),e.TONEMAPPING_STANDARD=0,e.TONEMAPPING_ACES=1,e._VIGNETTEMODE_MULTIPLY=0,e._VIGNETTEMODE_OPAQUE=1,Object(r.b)([Object(n.f)()],e.prototype,"colorCurves",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_colorCurvesEnabled",void 0),Object(r.b)([Object(n.j)("colorGradingTexture")],e.prototype,"_colorGradingTexture",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_colorGradingEnabled",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_colorGradingWithGreenDepth",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_colorGradingBGR",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_exposure",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_toneMappingEnabled",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_toneMappingType",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_contrast",void 0),Object(r.b)([Object(n.c)()],e.prototype,"vignetteStretch",void 0),Object(r.b)([Object(n.c)()],e.prototype,"vignetteCentreX",void 0),Object(r.b)([Object(n.c)()],e.prototype,"vignetteCentreY",void 0),Object(r.b)([Object(n.c)()],e.prototype,"vignetteWeight",void 0),Object(r.b)([Object(n.e)()],e.prototype,"vignetteColor",void 0),Object(r.b)([Object(n.c)()],e.prototype,"vignetteCameraFov",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_vignetteBlendMode",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_vignetteEnabled",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_applyByPostProcess",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_isEnabled",void 0),e}();n.a._ImageProcessingConfigurationParser=c.Parse},function(e,t,i){"use strict";i.r(t),i.d(t,"Space",(function(){return r.b})),i.d(t,"Axis",(function(){return r.a})),i.d(t,"Color3",(function(){return n.a})),i.d(t,"Color4",(function(){return n.b})),i.d(t,"TmpColors",(function(){return n.c})),i.d(t,"ToGammaSpace",(function(){return o.b})),i.d(t,"ToLinearSpace",(function(){return o.c})),i.d(t,"Epsilon",(function(){return o.a})),i.d(t,"Frustum",(function(){return s.a})),i.d(t,"Orientation",(function(){return a.e})),i.d(t,"BezierCurve",(function(){return a.c})),i.d(t,"Angle",(function(){return a.a})),i.d(t,"Arc2",(function(){return a.b})),i.d(t,"Path2",(function(){return a.f})),i.d(t,"Path3D",(function(){return a.g})),i.d(t,"Curve3",(function(){return a.d})),i.d(t,"Plane",(function(){return h.a})),i.d(t,"Size",(function(){return l.a})),i.d(t,"Vector2",(function(){return c.d})),i.d(t,"Vector3",(function(){return c.e})),i.d(t,"Vector4",(function(){return c.f})),i.d(t,"Quaternion",(function(){return c.b})),i.d(t,"Matrix",(function(){return c.a})),i.d(t,"TmpVectors",(function(){return c.c})),i.d(t,"PositionNormalVertex",(function(){return u})),i.d(t,"PositionNormalTextureVertex",(function(){return f})),i.d(t,"Viewport",(function(){return d.a}));var r=i(35),n=i(7),o=i(16),s=i(51),a=i(70),h=i(50),l=i(47),c=i(0),u=function(){function e(e,t){void 0===e&&(e=c.e.Zero()),void 0===t&&(t=c.e.Up()),this.position=e,this.normal=t}return e.prototype.clone=function(){return new e(this.position.clone(),this.normal.clone())},e}(),f=function(){function e(e,t,i){void 0===e&&(e=c.e.Zero()),void 0===t&&(t=c.e.Up()),void 0===i&&(i=c.d.Zero()),this.position=e,this.normal=t,this.uv=i}return e.prototype.clone=function(){return new e(this.position.clone(),this.normal.clone(),this.uv.clone())},e}(),d=i(53)},function(e,t,i){"use strict";i.d(t,"a",(function(){return o}));var r=i(41),n=function(e,t){return e?e.getClassName&&"Mesh"===e.getClassName()?null:e.getClassName&&"SubMesh"===e.getClassName()?e.clone(t):e.clone?e.clone():null:null},o=function(){function e(){}return e.DeepCopy=function(e,t,i,o){for(var s in e)if(("_"!==s[0]||o&&-1!==o.indexOf(s))&&!(r.a.EndsWith(s,"Observable")||i&&-1!==i.indexOf(s))){var a=e[s],h=typeof a;if("function"!==h)try{if("object"===h)if(a instanceof Array){if(t[s]=[],a.length>0)if("object"==typeof a[0])for(var l=0;l=this.subMaterials.length?this.getScene().defaultMaterial:this.subMaterials[e]},t.prototype.getActiveTextures=function(){var t;return(t=e.prototype.getActiveTextures.call(this)).concat.apply(t,this.subMaterials.map((function(e){return e?e.getActiveTextures():[]})))},t.prototype.getClassName=function(){return"MultiMaterial"},t.prototype.isReadyForSubMesh=function(e,t,i){for(var r=0;r=0&&n.multiMaterials.splice(o,1),e.prototype.dispose.call(this,t,i)}},t.ParseMultiMaterial=function(e,i){var r=new t(e.name,i);r.id=e.id,o.a&&o.a.AddTagsTo(r,e.tags);for(var n=0;n',toJson:'',labels:'',publish:'',replay:'',record:''},t.styleText=[".bbp.button-bar { position: absolute; z-index: 2; overflow: hidden; padding: 0 10px 4px 0; }",".bbp.button-bar > .button { float: right; width: 75px; height: 30px; cursor: pointer; border-radius: 2px; background-color: #f0f0f0; margin: 0 4px 0 0; }",".bbp.button-bar > .button:hover { background-color: #ddd; }",".bbp.button-bar > .button > svg { width: 75px; height: 30px; }",".bbp.label-control { position: absolute; z-index: 3; font-family: sans-serif; width: 200px; background-color: #f0f0f0; padding: 5px; border-radius: 2px; }",".bbp.label-control > label { font-size: 11pt; }",".bbp.label-control > .edit-container { overflow: auto; }",".bbp.label-control > .edit-container > .label-form { margin-top: 5px; padding-top: 20px; border-top: solid thin #ccc; }",".bbp.label-control .label-form > input { width: 100%; box-sizing: border-box; }",".bbp.label-control .label-form > button { border: none; font-weight: bold; background-color: white; padding: 5px 10px; margin: 5px 0 2px 0; width: 100%; cursor: pointer; }",".bbp.label-control .label-form > button:hover { background-color: #ddd; }",".bbp.overlay { position: absolute; z-index: 3; overflow: hidden; top: 0; left: 0; right: 0; bottom: 0; width: 100%; height: 100%; background-color: #fff5; display: flex; justify-content: center; align-items: center;}",".bbp.overlay > h5.loading-message { color: #000; font-family: Verdana, sans-serif;}",".bbp.publish-form > label { display: block; text-align: left; font-family: Verdana, sans-serif; }",".bbp.publish-form > input { width: 100%; margin-bottom: 15px; box-sizing: border-box; }",".bbp.publish-form > .publish-btn { border: none; font-weight: bold; background-color: #e95420; color: white; padding: 5px 10px; margin: 5px 0 2px 0; width: 100%; cursor: pointer; }",".bbp.publish-form > .publish-btn:hover { background-color: #ca491a }",".bbp.publish-form > .close-btn, .bbp.publish-form > .cancel-btn { border: none; font-weight: bold; background-color: white; padding: 5px 10px; margin: 5px 0 2px 0; width: 100%; cursor: pointer; }",".bbp.publish-form > .close-btn:hover, .bbp.publish-form > .cancel-btn:hover { background-color: #ddd }",".bbp.publish-form > p.form-info { font-size: 8pt; font-family: Verdana, sans-serif; }",".bbp.publish-form > p.message { font-size: 10pt; font-family: Verdana, sans-serif; }",".bbp.publish-form > p.message.warning { color: red; margin-top: 0px; }",".bbp.publish-form > p.message.success { color: green; }"].join(" ");var v=function(){function e(e,t,i,r,n,o,s,a){void 0===o&&(o=1),void 0===s&&(s=1),void 0===a&&(a=1),this._size=1,this._scene=e,this._coords=t,this._coordColors=i,this._size=r,this.legendData=n,this.xScale=o,this.yScale=s,this.zScale=a}return e.prototype.updateSize=function(){},e.prototype.update=function(){return!1},e.prototype.resetAnimation=function(){},e}();function y(e){return e.map((function(e){return e.max()})).max()}function x(e){return e.map((function(e){return e.min()})).min()}function T(e){for(var t=e.length,i=[],r=new Set,n=0;n65536){var e=this[0];return this.forEach((function(t,i,r){t65536){var e=this[0];return this.forEach((function(t,i,r){t>e&&(e=t)})),e}return Math.max.apply(null,this)},t.matrixMax=y,t.matrixMin=x,t.getUniqueVals=T;var E=i(123),M=i(124),A=i(126),O=i(127);t.PLOTTYPES={pointCloud:["coordinates","colorBy","colorVar"],surface:["coordinates","colorBy","colorVar"],heatMap:["coordinates","colorBy","colorVar"],imageStack:["values","indices","attributes"]},t.isValidPlot=function(e){for(var i=0;i0)if(Array.isArray(r[0]))this._annotationManager.addLabels(r);else for(var n=0;n40?o=.4:i>r&&(o=.3));var s=1;if("right"===e.position?(n.addColumnDefinition(1-o),n.addColumnDefinition(o)):(n.addColumnDefinition(o),n.addColumnDefinition(1-o),s=0),e.legendTitle&&""!==e.legendTitle?(n.addRowDefinition(.1),n.addRowDefinition(.85),n.addRowDefinition(.05)):(n.addRowDefinition(.05),n.addRowDefinition(.9),n.addRowDefinition(.05)),e.legendTitle){var a=new u.TextBlock;a.text=e.legendTitle,a.color=e.fontColor,a.fontWeight="bold",e.legendTitleFontSize?a.fontSize=e.legendTitleFontSize+"px":a.fontSize="20px",a.verticalAlignment=u.Control.VERTICAL_ALIGNMENT_BOTTOM,a.horizontalAlignment=u.Control.HORIZONTAL_ALIGNMENT_LEFT,n.addControl(a,0,s)}if(e.discrete){var h=new u.Grid;i>40?(h.addColumnDefinition(.1),h.addColumnDefinition(.4),h.addColumnDefinition(.1),h.addColumnDefinition(.4),h.addColumnDefinition(.1),h.addColumnDefinition(.4)):i>r?(h.addColumnDefinition(.1),h.addColumnDefinition(.4),h.addColumnDefinition(.1),h.addColumnDefinition(.4)):(h.addColumnDefinition(.2),h.addColumnDefinition(.8));for(v=0;vr?h.addRowDefinition(.05):h.addRowDefinition(1/i);n.addControl(h,1,s);m=void 0;m="custom"===e.colorScale?d.default.scale(e.customColorScale).mode("lch").colors(i):d.default.scale(d.default.brewer[e.colorScale]).mode("lch").colors(i);for(v=0;v39?h.addControl(l,v-40,4):v>19?h.addControl(l,v-r,2):h.addControl(l,v,0);var c=new u.TextBlock;c.text=e.breaks[v].toString(),c.color=e.fontColor,c.fontSize=e.fontSize+"px",c.textHorizontalAlignment=u.Control.HORIZONTAL_ALIGNMENT_LEFT,v>39&&h.addControl(c,v-40,5),v>19?h.addControl(c,v-r,3):h.addControl(c,v,1)}}else{var f=new u.Grid;f.addColumnDefinition(.2),f.addColumnDefinition(.8),n.addControl(f,1,s);var p=115,_=.15;if(this.canvas.height<70)p=10,_=.45,f.addRowDefinition(1);else if(this.canvas.height<130)p=50,_=.3,f.addRowDefinition(1);else{var g=(this.canvas.height-115)/2;f.addRowDefinition(g,!0),f.addRowDefinition(115,!0),f.addRowDefinition(g,!0)}var m=void 0;m="custom"===e.colorScale?d.default.scale(e.customColorScale).mode("lch").colors(p):d.default.scale(d.default.brewer[e.colorScale]).mode("lch").colors(p);for(var b=new u.Grid,v=0;v":i=r>n;break;case"<":i=r=":i=r>=n;break;case"==":i=r===n}return i},t}(l),p=i(8),_=function(){function e(){}return e.Process=function(e,t,i){var r=this;this._ProcessIncludes(e,t,(function(e){var n=r._ProcessShaderConversion(e,t);i(n)}))},e._ProcessPrecision=function(e,t){var i=t.shouldUseHighPrecisionShader;return-1===e.indexOf("precision highp float")?e=i?"precision highp float;\n"+e:"precision mediump float;\n"+e:i||(e=e.replace("precision highp float","precision mediump float")),e},e._ExtractOperation=function(e){var t=/defined\((.+)\)/.exec(e);if(t&&t.length)return new c(t[1].trim(),"!"===e[0]);for(var i="",r=0,n=0,o=["==",">=","<=","<",">"];n-1));n++);if(-1===r)return new c(e);var s=e.substring(0,r).trim(),a=e.substring(r+i.length).trim();return new d(s,i,a)},e._BuildSubExpression=function(e){var t=e.indexOf("||");if(-1===t){var i=e.indexOf("&&");if(i>-1){var r=new f,n=e.substring(0,i).trim(),o=e.substring(i+2).trim();return r.leftOperand=this._BuildSubExpression(n),r.rightOperand=this._BuildSubExpression(o),r}return this._ExtractOperation(e)}var s=new u;n=e.substring(0,t).trim(),o=e.substring(t+2).trim();return s.leftOperand=this._BuildSubExpression(n),s.rightOperand=this._BuildSubExpression(o),s},e._BuildExpression=function(e,t){var i=new h,r=e.substring(0,t),n=e.substring(t).trim();return i.testExpression="#ifdef"===r?new c(n):"#ifndef"===r?new c(n,!0):this._BuildSubExpression(n),i},e._MoveCursorWithinIf=function(e,t,i){for(var r=e.currentLine;this._MoveCursor(e,i);){var o=(r=e.currentLine).substring(0,5).toLowerCase();if("#else"===o){var s=new n;return t.children.push(s),void this._MoveCursor(e,s)}if("#elif"===o){var a=this._BuildExpression(r,5);t.children.push(a),i=a}}},e._MoveCursor=function(e,t){for(;e.canRead;){e.lineIndex++;var i=e.currentLine,r=/(#ifdef)|(#else)|(#elif)|(#endif)|(#ifndef)|(#if)/.exec(i);if(r&&r.length){switch(r[0]){case"#ifdef":var o=new a;t.children.push(o);var s=this._BuildExpression(i,6);o.children.push(s),this._MoveCursorWithinIf(e,o,s);break;case"#else":case"#elif":return!0;case"#endif":return!1;case"#ifndef":o=new a;t.children.push(o);s=this._BuildExpression(i,7);o.children.push(s),this._MoveCursorWithinIf(e,o,s);break;case"#if":o=new a,s=this._BuildExpression(i,3);t.children.push(o),o.children.push(s),this._MoveCursorWithinIf(e,o,s)}}else{var h=new n;if(h.line=i,t.children.push(h),"#"===i[0]&&"d"===i[1]){var l=i.replace(";","").split(" ");h.additionalDefineKey=l[1],3===l.length&&(h.additionalDefineValue=l[2])}}}return!1},e._EvaluatePreProcessors=function(e,t,i){var r=new n,s=new o;return s.lineIndex=-1,s.lines=e.split("\n"),this._MoveCursor(s,r),r.process(t,i)},e._PreparePreProcessors=function(e){for(var t={},i=0,r=e.defines;i1?n[1]:""}return t.GL_ES="true",t.__VERSION__=e.version,t[e.platformName]="true",t},e._ProcessShaderConversion=function(e,t){var i=this._ProcessPrecision(e,t);if(!t.processor)return i;if(-1!==i.indexOf("#version 3"))return i.replace("#version 300 es","");var r=t.defines,n=this._PreparePreProcessors(t);return t.processor.preProcessor&&(i=t.processor.preProcessor(i,r,t.isFragment)),i=this._EvaluatePreProcessors(i,n,t),t.processor.postProcessor&&(i=t.processor.postProcessor(i,r,t.isFragment)),i},e._ProcessIncludes=function(t,i,r){for(var n=this,o=/#include<(.+)>(\((.*)\))*(\[(.*)\])*/g,s=o.exec(t),a=new String(t);null!=s;){var h=s[1];if(-1!==h.indexOf("__decl__")&&(h=h.replace(/__decl__/,""),i.supportsUniformBuffers&&(h=(h=h.replace(/Vertex/,"Ubo")).replace(/Fragment/,"Ubo")),h+="Declaration"),!i.includesShadersStore[h]){var l=i.shadersRepository+"ShadersInclude/"+h+".fx";return void e._FileToolsLoadFile(l,(function(e){i.includesShadersStore[h]=e,n._ProcessIncludes(a,i,r)}))}var c=i.includesShadersStore[h];if(s[2])for(var u=s[3].split(","),f=0;f180&&(u-=360),u-c<-180&&(u+=360),f-u>180&&(f-=360),f-u<-180&&(f+=360),this.orientation=u-c<0?r.CW:r.CCW,this.angle=h.FromDegrees(this.orientation===r.CW?c-f:f-c)},c=function(){function e(e,t){this._points=new Array,this._length=0,this.closed=!1,this._points.push(new o.d(e,t))}return e.prototype.addLineTo=function(e,t){if(this.closed)return this;var i=new o.d(e,t),r=this._points[this._points.length-1];return this._points.push(i),this._length+=i.subtract(r).length(),this},e.prototype.addArcTo=function(e,t,i,n,s){if(void 0===s&&(s=36),this.closed)return this;var a=this._points[this._points.length-1],h=new o.d(e,t),c=new o.d(i,n),u=new l(a,h,c),f=u.angle.radians()/s;u.orientation===r.CW&&(f*=-1);for(var d=u.startAngle.radians()+f,p=0;p1)return o.d.Zero();for(var t=e*this.length(),i=0,r=0;r=i&&t<=h){var l=a.normalize(),c=t-i;return new o.d(s.x+l.x*c,s.y+l.y*c)}i=h}return o.d.Zero()},e.StartingAt=function(t,i){return new e(t,i)},e}(),u=function(){function e(e,t,i,r){void 0===t&&(t=null),void 0===r&&(r=!1),this.path=e,this._curve=new Array,this._distances=new Array,this._tangents=new Array,this._normals=new Array,this._binormals=new Array,this._pointAtData={id:0,point:o.e.Zero(),previousPointArrayIndex:0,position:0,subPosition:0,interpolateReady:!1,interpolationMatrix:o.a.Identity()};for(var n=0;ni){var r=t;t=i,i=r}var n=this.getCurve(),o=this.getPointAt(t),s=this.getPreviousPointIndexAt(t),a=this.getPointAt(i),h=this.getPreviousPointIndexAt(i)+1,l=[];return 0!==t&&(s++,l.push(o)),l.push.apply(l,n.slice(s,h)),1===i&&1!==t||l.push(a),new e(l,this.getNormalAt(t),this._raw,this._alignTangentsWithPath)},e.prototype.update=function(e,t,i){void 0===t&&(t=null),void 0===i&&(i=!1);for(var r=0;rt+1;)t++,i=this._curve[e].subtract(this._curve[e-t]);return i},e.prototype._normalVector=function(e,t){var i,r,a=e.length();(0===a&&(a=1),null==t)?(r=n.a.WithinEpsilon(Math.abs(e.y)/a,1,s.a)?n.a.WithinEpsilon(Math.abs(e.x)/a,1,s.a)?n.a.WithinEpsilon(Math.abs(e.z)/a,1,s.a)?o.e.Zero():new o.e(0,0,1):new o.e(1,0,0):new o.e(0,-1,0),i=o.e.Cross(e,r)):(i=o.e.Cross(e,t),o.e.CrossToRef(i,e,i));return i.normalize(),i},e.prototype._updatePointAtData=function(e,t){if(void 0===t&&(t=!1),this._pointAtData.id===e)return this._pointAtData.interpolateReady||this._updateInterpolationMatrix(),this._pointAtData;this._pointAtData.id=e;var i=this.getPoints();if(e<=0)return this._setPointAtData(0,0,i[0],0,t);if(e>=1)return this._setPointAtData(1,1,i[i.length-1],i.length-1,t);for(var r,n=i[0],s=0,a=e*this.length(),h=1;ha){var c=(s-a)/l,u=n.subtract(r),f=r.add(u.scaleInPlace(c));return this._setPointAtData(e,1-c,f,h-1,t)}n=r}return this._pointAtData},e.prototype._setPointAtData=function(e,t,i,r,n){return this._pointAtData.point=i,this._pointAtData.position=e,this._pointAtData.subPosition=t,this._pointAtData.previousPointArrayIndex=r,this._pointAtData.interpolateReady=n,n&&this._updateInterpolationMatrix(),this._pointAtData},e.prototype._updateInterpolationMatrix=function(){this._pointAtData.interpolationMatrix=o.a.Identity();var e=this._pointAtData.previousPointArrayIndex;if(e!==this._tangents.length-1){var t=e+1,i=this._tangents[e].clone(),r=this._normals[e].clone(),n=this._binormals[e].clone(),s=this._tangents[t].clone(),a=this._normals[t].clone(),h=this._binormals[t].clone(),l=o.b.RotationQuaternionFromAxis(r,n,i),c=o.b.RotationQuaternionFromAxis(a,h,s);o.b.Slerp(l,c,this._pointAtData.subPosition).toRotationMatrix(this._pointAtData.interpolationMatrix)}},e}(),f=function(){function e(e){this._length=0,this._points=e,this._length=this._computeLength(e)}return e.CreateQuadraticBezier=function(t,i,r,n){n=n>2?n:3;for(var s=new Array,a=function(e,t,i,r){return(1-e)*(1-e)*t+2*e*(1-e)*i+e*e*r},h=0;h<=n;h++)s.push(new o.e(a(h/n,t.x,i.x,r.x),a(h/n,t.y,i.y,r.y),a(h/n,t.z,i.z,r.z)));return new e(s)},e.CreateCubicBezier=function(t,i,r,n,s){s=s>3?s:4;for(var a=new Array,h=function(e,t,i,r,n){return(1-e)*(1-e)*(1-e)*t+3*e*(1-e)*(1-e)*i+3*e*e*(1-e)*r+e*e*e*n},l=0;l<=s;l++)a.push(new o.e(h(l/s,t.x,i.x,r.x,n.x),h(l/s,t.y,i.y,r.y,n.y),h(l/s,t.z,i.z,r.z,n.z)));return new e(a)},e.CreateHermiteSpline=function(t,i,r,n,s){for(var a=new Array,h=1/s,l=0;l<=s;l++)a.push(o.e.Hermite(t,i,r,n,l*h));return new e(a)},e.CreateCatmullRomSpline=function(t,i,r){var n=new Array,s=1/i,a=0;if(r){for(var h=t.length,l=0;lthis._maxRank&&(this._maxRank=e),this._defines[e]=new Array),this._defines[e].push(t)},e.prototype.addCPUSkinningFallback=function(e,t){this._mesh=t,ethis._maxRank&&(this._maxRank=e)},Object.defineProperty(e.prototype,"hasMoreFallbacks",{get:function(){return this._currentRank<=this._maxRank},enumerable:!0,configurable:!0}),e.prototype.reduce=function(e,t){if(this._mesh&&this._mesh.computeBonesUsingShaders&&this._mesh.numBoneInfluencers>0){this._mesh.computeBonesUsingShaders=!1,e=e.replace("#define NUM_BONE_INFLUENCERS "+this._mesh.numBoneInfluencers,"#define NUM_BONE_INFLUENCERS 0"),t._bonesComputationForcedToCPU=!0;for(var i=this._mesh.getScene(),r=0;r0&&(n.computeBonesUsingShaders=!1)}}else{var a=this._defines[this._currentRank];if(a)for(r=0;ri._alphaIndex?1:t._alphaIndext._distanceToCamera?-1:0},e.frontToBackSortCompare=function(e,t){return e._distanceToCamerat._distanceToCamera?1:0},e.prototype.prepare=function(){this._opaqueSubMeshes.reset(),this._transparentSubMeshes.reset(),this._alphaTestSubMeshes.reset(),this._depthOnlySubMeshes.reset(),this._particleSystems.reset(),this._spriteManagers.reset(),this._edgesRenderers.reset()},e.prototype.dispose=function(){this._opaqueSubMeshes.dispose(),this._transparentSubMeshes.dispose(),this._alphaTestSubMeshes.dispose(),this._depthOnlySubMeshes.dispose(),this._particleSystems.dispose(),this._spriteManagers.dispose(),this._edgesRenderers.dispose()},e.prototype.dispatch=function(e,t,i){void 0===t&&(t=e.getMesh()),void 0===i&&(i=e.getMaterial()),null!=i&&(i.needAlphaBlendingForMesh(t)?this._transparentSubMeshes.push(e):i.needAlphaTesting()?(i.needDepthPrePass&&this._depthOnlySubMeshes.push(e),this._alphaTestSubMeshes.push(e)):(i.needDepthPrePass&&this._depthOnlySubMeshes.push(e),this._opaqueSubMeshes.push(e)),t._renderingGroup=this,t._edgesRenderer&&t._edgesRenderer.isEnabled&&this._edgesRenderers.push(t._edgesRenderer))},e.prototype.dispatchSprites=function(e){this._spriteManagers.push(e)},e.prototype.dispatchParticles=function(e){this._particleSystems.push(e)},e.prototype._renderParticles=function(e){if(0!==this._particleSystems.length){var t=this._scene.activeCamera;this._scene.onBeforeParticlesRenderingObservable.notifyObservers(this._scene);for(var i=0;ii?i:e},t=function(t){t._clipped=!1,t._unclipped=t.slice(0);for(var i=0;i<=3;i++)i<3?((t[i]<0||t[i]>255)&&(t._clipped=!0),t[i]=e(t[i],0,255)):3===i&&(t[i]=e(t[i],0,1));return t},i={},r=0,n=["Boolean","Number","String","Function","Array","Date","RegExp","Undefined","Null"];r=3?Array.prototype.slice.call(e):"object"==s(e[0])&&t?t.split("").filter((function(t){return void 0!==e[0][t]})).map((function(t){return e[0][t]})):e[0]},h=function(e){if(e.length<2)return null;var t=e.length-1;return"string"==s(e[t])?e[t].toLowerCase():null},l=Math.PI,c={clip_rgb:t,limit:e,type:s,unpack:a,last:h,PI:l,TWOPI:2*l,PITHIRD:l/3,DEG2RAD:l/180,RAD2DEG:180/l},u={format:{},autodetect:[]},f=c.last,d=c.clip_rgb,p=c.type,_=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=this;if("object"===p(e[0])&&e[0].constructor&&e[0].constructor===this.constructor)return e[0];var r=f(e),n=!1;if(!r){n=!0,u.sorted||(u.autodetect=u.autodetect.sort((function(e,t){return t.p-e.p})),u.sorted=!0);for(var o=0,s=u.autodetect;o4?e[4]:1;return 1===o?[0,0,0,s]:[i>=1?0:255*(1-i)*(1-o),r>=1?0:255*(1-r)*(1-o),n>=1?0:255*(1-n)*(1-o),s]},M=c.unpack,A=c.type;g.prototype.cmyk=function(){return x(this._rgb)},b.cmyk=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["cmyk"])))},u.format.cmyk=E,u.autodetect.push({p:2,test:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];if(e=M(e,"cmyk"),"array"===A(e)&&4===e.length)return"cmyk"}});var O=c.unpack,C=c.last,S=function(e){return Math.round(100*e)/100},P=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=O(e,"hsla"),r=C(e)||"lsa";return i[0]=S(i[0]||0),i[1]=S(100*i[1])+"%",i[2]=S(100*i[2])+"%","hsla"===r||i.length>3&&i[3]<1?(i[3]=i.length>3?i[3]:1,r="hsla"):i.length=3,r+"("+i.join(",")+")"},R=c.unpack,I=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=(e=R(e,"rgba"))[0],r=e[1],n=e[2];i/=255,r/=255,n/=255;var o,s,a=Math.min(i,r,n),h=Math.max(i,r,n),l=(h+a)/2;return h===a?(o=0,s=Number.NaN):o=l<.5?(h-a)/(h+a):(h-a)/(2-h-a),i==h?s=(r-n)/(h-a):r==h?s=2+(n-i)/(h-a):n==h&&(s=4+(i-r)/(h-a)),(s*=60)<0&&(s+=360),e.length>3&&void 0!==e[3]?[s,o,l,e[3]]:[s,o,l]},w=c.unpack,D=c.last,L=Math.round,F=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=w(e,"rgba"),r=D(e)||"rgb";return"hsl"==r.substr(0,3)?P(I(i),r):(i[0]=L(i[0]),i[1]=L(i[1]),i[2]=L(i[2]),("rgba"===r||i.length>3&&i[3]<1)&&(i[3]=i.length>3?i[3]:1,r="rgba"),r+"("+i.slice(0,"rgb"===r?3:4).join(",")+")")},N=c.unpack,B=Math.round,k=function(){for(var e,t=[],i=arguments.length;i--;)t[i]=arguments[i];var r,n,o,s=(t=N(t,"hsl"))[0],a=t[1],h=t[2];if(0===a)r=n=o=255*h;else{var l=[0,0,0],c=[0,0,0],u=h<.5?h*(1+a):h+a-h*a,f=2*h-u,d=s/360;l[0]=d+1/3,l[1]=d,l[2]=d-1/3;for(var p=0;p<3;p++)l[p]<0&&(l[p]+=1),l[p]>1&&(l[p]-=1),6*l[p]<1?c[p]=f+6*(u-f)*l[p]:2*l[p]<1?c[p]=u:3*l[p]<2?c[p]=f+(u-f)*(2/3-l[p])*6:c[p]=f;r=(e=[B(255*c[0]),B(255*c[1]),B(255*c[2])])[0],n=e[1],o=e[2]}return t.length>3?[r,n,o,t[3]]:[r,n,o,1]},U=/^rgb\(\s*(-?\d+),\s*(-?\d+)\s*,\s*(-?\d+)\s*\)$/,V=/^rgba\(\s*(-?\d+),\s*(-?\d+)\s*,\s*(-?\d+)\s*,\s*([01]|[01]?\.\d+)\)$/,z=/^rgb\(\s*(-?\d+(?:\.\d+)?)%,\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*\)$/,j=/^rgba\(\s*(-?\d+(?:\.\d+)?)%,\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*,\s*([01]|[01]?\.\d+)\)$/,W=/^hsl\(\s*(-?\d+(?:\.\d+)?),\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*\)$/,G=/^hsla\(\s*(-?\d+(?:\.\d+)?),\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*,\s*([01]|[01]?\.\d+)\)$/,H=Math.round,X=function(e){var t;if(e=e.toLowerCase().trim(),u.format.named)try{return u.format.named(e)}catch(e){}if(t=e.match(U)){for(var i=t.slice(1,4),r=0;r<3;r++)i[r]=+i[r];return i[3]=1,i}if(t=e.match(V)){for(var n=t.slice(1,5),o=0;o<4;o++)n[o]=+n[o];return n}if(t=e.match(z)){for(var s=t.slice(1,4),a=0;a<3;a++)s[a]=H(2.55*s[a]);return s[3]=1,s}if(t=e.match(j)){for(var h=t.slice(1,5),l=0;l<3;l++)h[l]=H(2.55*h[l]);return h[3]=+h[3],h}if(t=e.match(W)){var c=t.slice(1,4);c[1]*=.01,c[2]*=.01;var f=k(c);return f[3]=1,f}if(t=e.match(G)){var d=t.slice(1,4);d[1]*=.01,d[2]*=.01;var p=k(d);return p[3]=+t[4],p}};X.test=function(e){return U.test(e)||V.test(e)||z.test(e)||j.test(e)||W.test(e)||G.test(e)};var K=X,Y=c.type;g.prototype.css=function(e){return F(this._rgb,e)},b.css=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["css"])))},u.format.css=K,u.autodetect.push({p:5,test:function(e){for(var t=[],i=arguments.length-1;i-- >0;)t[i]=arguments[i+1];if(!t.length&&"string"===Y(e)&&K.test(e))return"css"}});var q=c.unpack;u.format.gl=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=q(e,"rgba");return i[0]*=255,i[1]*=255,i[2]*=255,i},b.gl=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["gl"])))},g.prototype.gl=function(){var e=this._rgb;return[e[0]/255,e[1]/255,e[2]/255,e[3]]};var Z=c.unpack,Q=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i,r=Z(e,"rgb"),n=r[0],o=r[1],s=r[2],a=Math.min(n,o,s),h=Math.max(n,o,s),l=h-a,c=100*l/255,u=a/(255-l)*100;return 0===l?i=Number.NaN:(n===h&&(i=(o-s)/l),o===h&&(i=2+(s-n)/l),s===h&&(i=4+(n-o)/l),(i*=60)<0&&(i+=360)),[i,c,u]},J=c.unpack,$=Math.floor,ee=function(){for(var e,t,i,r,n,o,s=[],a=arguments.length;a--;)s[a]=arguments[a];var h,l,c,u=(s=J(s,"hcg"))[0],f=s[1],d=s[2];d*=255;var p=255*f;if(0===f)h=l=c=d;else{360===u&&(u=0),u>360&&(u-=360),u<0&&(u+=360);var _=$(u/=60),g=u-_,m=d*(1-f),b=m+p*(1-g),v=m+p*g,y=m+p;switch(_){case 0:h=(e=[y,v,m])[0],l=e[1],c=e[2];break;case 1:h=(t=[b,y,m])[0],l=t[1],c=t[2];break;case 2:h=(i=[m,y,v])[0],l=i[1],c=i[2];break;case 3:h=(r=[m,b,y])[0],l=r[1],c=r[2];break;case 4:h=(n=[v,m,y])[0],l=n[1],c=n[2];break;case 5:h=(o=[y,m,b])[0],l=o[1],c=o[2]}}return[h,l,c,s.length>3?s[3]:1]},te=c.unpack,ie=c.type;g.prototype.hcg=function(){return Q(this._rgb)},b.hcg=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["hcg"])))},u.format.hcg=ee,u.autodetect.push({p:1,test:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];if(e=te(e,"hcg"),"array"===ie(e)&&3===e.length)return"hcg"}});var re=c.unpack,ne=c.last,oe=Math.round,se=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=re(e,"rgba"),r=i[0],n=i[1],o=i[2],s=i[3],a=ne(e)||"auto";void 0===s&&(s=1),"auto"===a&&(a=s<1?"rgba":"rgb");var h="000000"+((r=oe(r))<<16|(n=oe(n))<<8|(o=oe(o))).toString(16);h=h.substr(h.length-6);var l="0"+oe(255*s).toString(16);switch(l=l.substr(l.length-2),a.toLowerCase()){case"rgba":return"#"+h+l;case"argb":return"#"+l+h;default:return"#"+h}},ae=/^#?([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/,he=/^#?([A-Fa-f0-9]{8}|[A-Fa-f0-9]{4})$/,le=function(e){if(e.match(ae)){4!==e.length&&7!==e.length||(e=e.substr(1)),3===e.length&&(e=(e=e.split(""))[0]+e[0]+e[1]+e[1]+e[2]+e[2]);var t=parseInt(e,16);return[t>>16,t>>8&255,255&t,1]}if(e.match(he)){5!==e.length&&9!==e.length||(e=e.substr(1)),4===e.length&&(e=(e=e.split(""))[0]+e[0]+e[1]+e[1]+e[2]+e[2]+e[3]+e[3]);var i=parseInt(e,16);return[i>>24&255,i>>16&255,i>>8&255,Math.round((255&i)/255*100)/100]}throw new Error("unknown hex color: "+e)},ce=c.type;g.prototype.hex=function(e){return se(this._rgb,e)},b.hex=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["hex"])))},u.format.hex=le,u.autodetect.push({p:4,test:function(e){for(var t=[],i=arguments.length-1;i-- >0;)t[i]=arguments[i+1];if(!t.length&&"string"===ce(e)&&[3,4,5,6,7,8,9].indexOf(e.length)>=0)return"hex"}});var ue=c.unpack,fe=c.TWOPI,de=Math.min,pe=Math.sqrt,_e=Math.acos,ge=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i,r=ue(e,"rgb"),n=r[0],o=r[1],s=r[2],a=de(n/=255,o/=255,s/=255),h=(n+o+s)/3,l=h>0?1-a/h:0;return 0===l?i=NaN:(i=(n-o+(n-s))/2,i/=pe((n-o)*(n-o)+(n-s)*(o-s)),i=_e(i),s>o&&(i=fe-i),i/=fe),[360*i,l,h]},me=c.unpack,be=c.limit,ve=c.TWOPI,ye=c.PITHIRD,xe=Math.cos,Te=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i,r,n,o=(e=me(e,"hsi"))[0],s=e[1],a=e[2];return isNaN(o)&&(o=0),isNaN(s)&&(s=0),o>360&&(o-=360),o<0&&(o+=360),(o/=360)<1/3?r=1-((n=(1-s)/3)+(i=(1+s*xe(ve*o)/xe(ye-ve*o))/3)):o<2/3?n=1-((i=(1-s)/3)+(r=(1+s*xe(ve*(o-=1/3))/xe(ye-ve*o))/3)):i=1-((r=(1-s)/3)+(n=(1+s*xe(ve*(o-=2/3))/xe(ye-ve*o))/3)),[255*(i=be(a*i*3)),255*(r=be(a*r*3)),255*(n=be(a*n*3)),e.length>3?e[3]:1]},Ee=c.unpack,Me=c.type;g.prototype.hsi=function(){return ge(this._rgb)},b.hsi=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["hsi"])))},u.format.hsi=Te,u.autodetect.push({p:2,test:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];if(e=Ee(e,"hsi"),"array"===Me(e)&&3===e.length)return"hsi"}});var Ae=c.unpack,Oe=c.type;g.prototype.hsl=function(){return I(this._rgb)},b.hsl=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["hsl"])))},u.format.hsl=k,u.autodetect.push({p:2,test:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];if(e=Ae(e,"hsl"),"array"===Oe(e)&&3===e.length)return"hsl"}});var Ce=c.unpack,Se=Math.min,Pe=Math.max,Re=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i,r,n,o=(e=Ce(e,"rgb"))[0],s=e[1],a=e[2],h=Se(o,s,a),l=Pe(o,s,a),c=l-h;return n=l/255,0===l?(i=Number.NaN,r=0):(r=c/l,o===l&&(i=(s-a)/c),s===l&&(i=2+(a-o)/c),a===l&&(i=4+(o-s)/c),(i*=60)<0&&(i+=360)),[i,r,n]},Ie=c.unpack,we=Math.floor,De=function(){for(var e,t,i,r,n,o,s=[],a=arguments.length;a--;)s[a]=arguments[a];var h,l,c,u=(s=Ie(s,"hsv"))[0],f=s[1],d=s[2];if(d*=255,0===f)h=l=c=d;else{360===u&&(u=0),u>360&&(u-=360),u<0&&(u+=360);var p=we(u/=60),_=u-p,g=d*(1-f),m=d*(1-f*_),b=d*(1-f*(1-_));switch(p){case 0:h=(e=[d,b,g])[0],l=e[1],c=e[2];break;case 1:h=(t=[m,d,g])[0],l=t[1],c=t[2];break;case 2:h=(i=[g,d,b])[0],l=i[1],c=i[2];break;case 3:h=(r=[g,m,d])[0],l=r[1],c=r[2];break;case 4:h=(n=[b,g,d])[0],l=n[1],c=n[2];break;case 5:h=(o=[d,g,m])[0],l=o[1],c=o[2]}}return[h,l,c,s.length>3?s[3]:1]},Le=c.unpack,Fe=c.type;g.prototype.hsv=function(){return Re(this._rgb)},b.hsv=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["hsv"])))},u.format.hsv=De,u.autodetect.push({p:2,test:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];if(e=Le(e,"hsv"),"array"===Fe(e)&&3===e.length)return"hsv"}});var Ne={Kn:18,Xn:.95047,Yn:1,Zn:1.08883,t0:.137931034,t1:.206896552,t2:.12841855,t3:.008856452},Be=c.unpack,ke=Math.pow,Ue=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=Be(e,"rgb"),r=i[0],n=i[1],o=i[2],s=je(r,n,o),a=s[0],h=s[1],l=116*h-16;return[l<0?0:l,500*(a-h),200*(h-s[2])]},Ve=function(e){return(e/=255)<=.04045?e/12.92:ke((e+.055)/1.055,2.4)},ze=function(e){return e>Ne.t3?ke(e,1/3):e/Ne.t2+Ne.t0},je=function(e,t,i){return e=Ve(e),t=Ve(t),i=Ve(i),[ze((.4124564*e+.3575761*t+.1804375*i)/Ne.Xn),ze((.2126729*e+.7151522*t+.072175*i)/Ne.Yn),ze((.0193339*e+.119192*t+.9503041*i)/Ne.Zn)]},We=Ue,Ge=c.unpack,He=Math.pow,Xe=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i,r,n,o=(e=Ge(e,"lab"))[0],s=e[1],a=e[2];return r=(o+16)/116,i=isNaN(s)?r:r+s/500,n=isNaN(a)?r:r-a/200,r=Ne.Yn*Ye(r),i=Ne.Xn*Ye(i),n=Ne.Zn*Ye(n),[Ke(3.2404542*i-1.5371385*r-.4985314*n),Ke(-.969266*i+1.8760108*r+.041556*n),Ke(.0556434*i-.2040259*r+1.0572252*n),e.length>3?e[3]:1]},Ke=function(e){return 255*(e<=.00304?12.92*e:1.055*He(e,1/2.4)-.055)},Ye=function(e){return e>Ne.t1?e*e*e:Ne.t2*(e-Ne.t0)},qe=Xe,Ze=c.unpack,Qe=c.type;g.prototype.lab=function(){return We(this._rgb)},b.lab=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["lab"])))},u.format.lab=qe,u.autodetect.push({p:2,test:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];if(e=Ze(e,"lab"),"array"===Qe(e)&&3===e.length)return"lab"}});var Je=c.unpack,$e=c.RAD2DEG,et=Math.sqrt,tt=Math.atan2,it=Math.round,rt=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=Je(e,"lab"),r=i[0],n=i[1],o=i[2],s=et(n*n+o*o),a=(tt(o,n)*$e+360)%360;return 0===it(1e4*s)&&(a=Number.NaN),[r,s,a]},nt=c.unpack,ot=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=nt(e,"rgb"),r=i[0],n=i[1],o=i[2],s=We(r,n,o),a=s[0],h=s[1],l=s[2];return rt(a,h,l)},st=c.unpack,at=c.DEG2RAD,ht=Math.sin,lt=Math.cos,ct=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=st(e,"lch"),r=i[0],n=i[1],o=i[2];return isNaN(o)&&(o=0),[r,lt(o*=at)*n,ht(o)*n]},ut=c.unpack,ft=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=(e=ut(e,"lch"))[0],r=e[1],n=e[2],o=ct(i,r,n),s=o[0],a=o[1],h=o[2],l=qe(s,a,h);return[l[0],l[1],l[2],e.length>3?e[3]:1]},dt=c.unpack,pt=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=dt(e,"hcl").reverse();return ft.apply(void 0,i)},_t=c.unpack,gt=c.type;g.prototype.lch=function(){return ot(this._rgb)},g.prototype.hcl=function(){return ot(this._rgb).reverse()},b.lch=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["lch"])))},b.hcl=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["hcl"])))},u.format.lch=ft,u.format.hcl=pt,["lch","hcl"].forEach((function(e){return u.autodetect.push({p:2,test:function(){for(var t=[],i=arguments.length;i--;)t[i]=arguments[i];if(t=_t(t,e),"array"===gt(t)&&3===t.length)return e}})}));var mt={aliceblue:"#f0f8ff",antiquewhite:"#faebd7",aqua:"#00ffff",aquamarine:"#7fffd4",azure:"#f0ffff",beige:"#f5f5dc",bisque:"#ffe4c4",black:"#000000",blanchedalmond:"#ffebcd",blue:"#0000ff",blueviolet:"#8a2be2",brown:"#a52a2a",burlywood:"#deb887",cadetblue:"#5f9ea0",chartreuse:"#7fff00",chocolate:"#d2691e",coral:"#ff7f50",cornflower:"#6495ed",cornflowerblue:"#6495ed",cornsilk:"#fff8dc",crimson:"#dc143c",cyan:"#00ffff",darkblue:"#00008b",darkcyan:"#008b8b",darkgoldenrod:"#b8860b",darkgray:"#a9a9a9",darkgreen:"#006400",darkgrey:"#a9a9a9",darkkhaki:"#bdb76b",darkmagenta:"#8b008b",darkolivegreen:"#556b2f",darkorange:"#ff8c00",darkorchid:"#9932cc",darkred:"#8b0000",darksalmon:"#e9967a",darkseagreen:"#8fbc8f",darkslateblue:"#483d8b",darkslategray:"#2f4f4f",darkslategrey:"#2f4f4f",darkturquoise:"#00ced1",darkviolet:"#9400d3",deeppink:"#ff1493",deepskyblue:"#00bfff",dimgray:"#696969",dimgrey:"#696969",dodgerblue:"#1e90ff",firebrick:"#b22222",floralwhite:"#fffaf0",forestgreen:"#228b22",fuchsia:"#ff00ff",gainsboro:"#dcdcdc",ghostwhite:"#f8f8ff",gold:"#ffd700",goldenrod:"#daa520",gray:"#808080",green:"#008000",greenyellow:"#adff2f",grey:"#808080",honeydew:"#f0fff0",hotpink:"#ff69b4",indianred:"#cd5c5c",indigo:"#4b0082",ivory:"#fffff0",khaki:"#f0e68c",laserlemon:"#ffff54",lavender:"#e6e6fa",lavenderblush:"#fff0f5",lawngreen:"#7cfc00",lemonchiffon:"#fffacd",lightblue:"#add8e6",lightcoral:"#f08080",lightcyan:"#e0ffff",lightgoldenrod:"#fafad2",lightgoldenrodyellow:"#fafad2",lightgray:"#d3d3d3",lightgreen:"#90ee90",lightgrey:"#d3d3d3",lightpink:"#ffb6c1",lightsalmon:"#ffa07a",lightseagreen:"#20b2aa",lightskyblue:"#87cefa",lightslategray:"#778899",lightslategrey:"#778899",lightsteelblue:"#b0c4de",lightyellow:"#ffffe0",lime:"#00ff00",limegreen:"#32cd32",linen:"#faf0e6",magenta:"#ff00ff",maroon:"#800000",maroon2:"#7f0000",maroon3:"#b03060",mediumaquamarine:"#66cdaa",mediumblue:"#0000cd",mediumorchid:"#ba55d3",mediumpurple:"#9370db",mediumseagreen:"#3cb371",mediumslateblue:"#7b68ee",mediumspringgreen:"#00fa9a",mediumturquoise:"#48d1cc",mediumvioletred:"#c71585",midnightblue:"#191970",mintcream:"#f5fffa",mistyrose:"#ffe4e1",moccasin:"#ffe4b5",navajowhite:"#ffdead",navy:"#000080",oldlace:"#fdf5e6",olive:"#808000",olivedrab:"#6b8e23",orange:"#ffa500",orangered:"#ff4500",orchid:"#da70d6",palegoldenrod:"#eee8aa",palegreen:"#98fb98",paleturquoise:"#afeeee",palevioletred:"#db7093",papayawhip:"#ffefd5",peachpuff:"#ffdab9",peru:"#cd853f",pink:"#ffc0cb",plum:"#dda0dd",powderblue:"#b0e0e6",purple:"#800080",purple2:"#7f007f",purple3:"#a020f0",rebeccapurple:"#663399",red:"#ff0000",rosybrown:"#bc8f8f",royalblue:"#4169e1",saddlebrown:"#8b4513",salmon:"#fa8072",sandybrown:"#f4a460",seagreen:"#2e8b57",seashell:"#fff5ee",sienna:"#a0522d",silver:"#c0c0c0",skyblue:"#87ceeb",slateblue:"#6a5acd",slategray:"#708090",slategrey:"#708090",snow:"#fffafa",springgreen:"#00ff7f",steelblue:"#4682b4",tan:"#d2b48c",teal:"#008080",thistle:"#d8bfd8",tomato:"#ff6347",turquoise:"#40e0d0",violet:"#ee82ee",wheat:"#f5deb3",white:"#ffffff",whitesmoke:"#f5f5f5",yellow:"#ffff00",yellowgreen:"#9acd32"},bt=c.type;g.prototype.name=function(){for(var e=se(this._rgb,"rgb"),t=0,i=Object.keys(mt);t0;)t[i]=arguments[i+1];if(!t.length&&"string"===bt(e)&&mt[e.toLowerCase()])return"named"}});var vt=c.unpack,yt=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=vt(e,"rgb");return(i[0]<<16)+(i[1]<<8)+i[2]},xt=c.type,Tt=function(e){if("number"==xt(e)&&e>=0&&e<=16777215)return[e>>16,e>>8&255,255&e,1];throw new Error("unknown num color: "+e)},Et=c.type;g.prototype.num=function(){return yt(this._rgb)},b.num=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["num"])))},u.format.num=Tt,u.autodetect.push({p:5,test:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];if(1===e.length&&"number"===Et(e[0])&&e[0]>=0&&e[0]<=16777215)return"num"}});var Mt=c.unpack,At=c.type,Ot=Math.round;g.prototype.rgb=function(e){return void 0===e&&(e=!0),!1===e?this._rgb.slice(0,3):this._rgb.slice(0,3).map(Ot)},g.prototype.rgba=function(e){return void 0===e&&(e=!0),this._rgb.slice(0,4).map((function(t,i){return i<3?!1===e?t:Ot(t):t}))},b.rgb=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["rgb"])))},u.format.rgb=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=Mt(e,"rgba");return void 0===i[3]&&(i[3]=1),i},u.autodetect.push({p:3,test:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];if(e=Mt(e,"rgba"),"array"===At(e)&&(3===e.length||4===e.length&&"number"==At(e[3])&&e[3]>=0&&e[3]<=1))return"rgb"}});var Ct=Math.log,St=function(e){var t,i,r,n=e/100;return n<66?(t=255,i=-155.25485562709179-.44596950469579133*(i=n-2)+104.49216199393888*Ct(i),r=n<20?0:.8274096064007395*(r=n-10)-254.76935184120902+115.67994401066147*Ct(r)):(t=351.97690566805693+.114206453784165*(t=n-55)-40.25366309332127*Ct(t),i=325.4494125711974+.07943456536662342*(i=n-50)-28.0852963507957*Ct(i),r=255),[t,i,r,1]},Pt=c.unpack,Rt=Math.round,It=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];for(var i,r=Pt(e,"rgb"),n=r[0],o=r[2],s=1e3,a=4e4,h=.4;a-s>h;){var l=St(i=.5*(a+s));l[2]/l[0]>=o/n?a=i:s=i}return Rt(i)};g.prototype.temp=g.prototype.kelvin=g.prototype.temperature=function(){return It(this._rgb)},b.temp=b.kelvin=b.temperature=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["temp"])))},u.format.temp=u.format.kelvin=u.format.temperature=St;var wt=c.type;g.prototype.alpha=function(e,t){return void 0===t&&(t=!1),void 0!==e&&"number"===wt(e)?t?(this._rgb[3]=e,this):new g([this._rgb[0],this._rgb[1],this._rgb[2],e],"rgb"):this._rgb[3]},g.prototype.clipped=function(){return this._rgb._clipped||!1},g.prototype.darken=function(e){void 0===e&&(e=1);var t=this,i=t.lab();return i[0]-=Ne.Kn*e,new g(i,"lab").alpha(t.alpha(),!0)},g.prototype.brighten=function(e){return void 0===e&&(e=1),this.darken(-e)},g.prototype.darker=g.prototype.darken,g.prototype.brighter=g.prototype.brighten,g.prototype.get=function(e){var t=e.split("."),i=t[0],r=t[1],n=this[i]();if(r){var o=i.indexOf(r);if(o>-1)return n[o];throw new Error("unknown channel "+r+" in mode "+i)}return n};var Dt=c.type,Lt=Math.pow,Ft=1e-7,Nt=20;g.prototype.luminance=function(e){if(void 0!==e&&"number"===Dt(e)){if(0===e)return new g([0,0,0,this._rgb[3]],"rgb");if(1===e)return new g([255,255,255,this._rgb[3]],"rgb");var t=this.luminance(),i="rgb",r=Nt,n=function(t,o){var s=t.interpolate(o,.5,i),a=s.luminance();return Math.abs(e-a)e?n(t,s):n(s,o)},o=(t>e?n(new g([0,0,0]),this):n(this,new g([255,255,255]))).rgb();return new g(o.concat([this._rgb[3]]))}return Bt.apply(void 0,this._rgb.slice(0,3))};var Bt=function(e,t,i){return.2126*(e=kt(e))+.7152*(t=kt(t))+.0722*(i=kt(i))},kt=function(e){return(e/=255)<=.03928?e/12.92:Lt((e+.055)/1.055,2.4)},Ut={},Vt=c.type,zt=function(e,t,i){void 0===i&&(i=.5);for(var r=[],n=arguments.length-3;n-- >0;)r[n]=arguments[n+3];var o=r[0]||"lrgb";if(Ut[o]||r.length||(o=Object.keys(Ut)[0]),!Ut[o])throw new Error("interpolation mode "+o+" is not defined");return"object"!==Vt(e)&&(e=new g(e)),"object"!==Vt(t)&&(t=new g(t)),Ut[o](e,t,i).alpha(e.alpha()+i*(t.alpha()-e.alpha()))};g.prototype.mix=g.prototype.interpolate=function(e,t){void 0===t&&(t=.5);for(var i=[],r=arguments.length-2;r-- >0;)i[r]=arguments[r+2];return zt.apply(void 0,[this,e,t].concat(i))},g.prototype.premultiply=function(e){void 0===e&&(e=!1);var t=this._rgb,i=t[3];return e?(this._rgb=[t[0]*i,t[1]*i,t[2]*i,i],this):new g([t[0]*i,t[1]*i,t[2]*i,i],"rgb")},g.prototype.saturate=function(e){void 0===e&&(e=1);var t=this,i=t.lch();return i[1]+=Ne.Kn*e,i[1]<0&&(i[1]=0),new g(i,"lch").alpha(t.alpha(),!0)},g.prototype.desaturate=function(e){return void 0===e&&(e=1),this.saturate(-e)};var jt=c.type;g.prototype.set=function(e,t,i){void 0===i&&(i=!1);var r=e.split("."),n=r[0],o=r[1],s=this[n]();if(o){var a=n.indexOf(o);if(a>-1){if("string"==jt(t))switch(t.charAt(0)){case"+":case"-":s[a]+=+t;break;case"*":s[a]*=+t.substr(1);break;case"/":s[a]/=+t.substr(1);break;default:s[a]=+t}else{if("number"!==jt(t))throw new Error("unsupported value for Color.set");s[a]=t}var h=new g(s,n);return i?(this._rgb=h._rgb,this):h}throw new Error("unknown channel "+o+" in mode "+n)}return s};var Wt=function(e,t,i){var r=e._rgb,n=t._rgb;return new g(r[0]+i*(n[0]-r[0]),r[1]+i*(n[1]-r[1]),r[2]+i*(n[2]-r[2]),"rgb")};Ut.rgb=Wt;var Gt=Math.sqrt,Ht=Math.pow,Xt=function(e,t,i){var r=e._rgb,n=r[0],o=r[1],s=r[2],a=t._rgb,h=a[0],l=a[1],c=a[2];return new g(Gt(Ht(n,2)*(1-i)+Ht(h,2)*i),Gt(Ht(o,2)*(1-i)+Ht(l,2)*i),Gt(Ht(s,2)*(1-i)+Ht(c,2)*i),"rgb")};Ut.lrgb=Xt;var Kt=function(e,t,i){var r=e.lab(),n=t.lab();return new g(r[0]+i*(n[0]-r[0]),r[1]+i*(n[1]-r[1]),r[2]+i*(n[2]-r[2]),"lab")};Ut.lab=Kt;var Yt=function(e,t,i,r){var n,o,s,a,h,l,c,u,f,d,p,_;return"hsl"===r?(s=e.hsl(),a=t.hsl()):"hsv"===r?(s=e.hsv(),a=t.hsv()):"hcg"===r?(s=e.hcg(),a=t.hcg()):"hsi"===r?(s=e.hsi(),a=t.hsi()):"lch"!==r&&"hcl"!==r||(r="hcl",s=e.hcl(),a=t.hcl()),"h"===r.substr(0,1)&&(h=(n=s)[0],c=n[1],f=n[2],l=(o=a)[0],u=o[1],d=o[2]),isNaN(h)||isNaN(l)?isNaN(h)?isNaN(l)?_=Number.NaN:(_=l,1!=f&&0!=f||"hsv"==r||(p=u)):(_=h,1!=d&&0!=d||"hsv"==r||(p=c)):_=h+i*(l>h&&l-h>180?l-(h+360):l180?l+360-h:l-h),void 0===p&&(p=c+i*(u-c)),new g([_,p,f+i*(d-f)],r)},qt=function(e,t,i){return Yt(e,t,i,"lch")};Ut.lch=qt,Ut.hcl=qt;var Zt=function(e,t,i){var r=e.num(),n=t.num();return new g(r+i*(n-r),"num")};Ut.num=Zt;var Qt=function(e,t,i){return Yt(e,t,i,"hcg")};Ut.hcg=Qt;var Jt=function(e,t,i){return Yt(e,t,i,"hsi")};Ut.hsi=Jt;var $t=function(e,t,i){return Yt(e,t,i,"hsl")};Ut.hsl=$t;var ei=function(e,t,i){return Yt(e,t,i,"hsv")};Ut.hsv=ei;var ti=c.clip_rgb,ii=Math.pow,ri=Math.sqrt,ni=Math.PI,oi=Math.cos,si=Math.sin,ai=Math.atan2,hi=function(e,t,i){void 0===t&&(t="lrgb"),void 0===i&&(i=null);var r=e.length;i||(i=Array.from(new Array(r)).map((function(){return 1})));var n=r/i.reduce((function(e,t){return e+t}));if(i.forEach((function(e,t){i[t]*=n})),e=e.map((function(e){return new g(e)})),"lrgb"===t)return li(e,i);for(var o=e.shift(),s=o.get(t),a=[],h=0,l=0,c=0;c=360;)p-=360;s[d]=p}else s[d]=s[d]/a[d];return f/=r,new g(s,t).alpha(f>.99999?1:f,!0)},li=function(e,t){for(var i=e.length,r=[0,0,0,0],n=0;n.9999999&&(r[3]=1),new g(ti(r))},ci=c.type,ui=Math.pow,fi=function(e){var t="rgb",i=b("#ccc"),r=0,n=[0,1],o=[],s=[0,0],a=!1,h=[],l=!1,c=0,u=1,f=!1,d={},p=!0,_=1,g=function(e){if((e=e||["#fff","#000"])&&"string"===ci(e)&&b.brewer&&b.brewer[e.toLowerCase()]&&(e=b.brewer[e.toLowerCase()]),"array"===ci(e)){1===e.length&&(e=[e[0],e[0]]),e=e.slice(0);for(var t=0;t=a[i];)i++;return i-1}return 0},v=function(e){return e},y=function(e){return e},x=function(e,r){var n,l;if(null==r&&(r=!1),isNaN(e)||null===e)return i;l=r?e:a&&a.length>2?m(e)/(a.length-2):u!==c?(e-c)/(u-c):1,l=y(l),r||(l=v(l)),1!==_&&(l=ui(l,_)),l=s[0]+l*(1-s[0]-s[1]),l=Math.min(1,Math.max(0,l));var f=Math.floor(1e4*l);if(p&&d[f])n=d[f];else{if("array"===ci(h))for(var g=0;g=x&&g===o.length-1){n=h[g];break}if(l>x&&l2){var l=e.map((function(t,i){return i/(e.length-1)})),f=e.map((function(e){return(e-c)/(u-c)}));f.every((function(e,t){return l[t]===e}))||(y=function(e){if(e<=0||e>=1)return e;for(var t=0;e>=f[t+1];)t++;var i=(e-f[t])/(f[t+1]-f[t]);return l[t]+i*(l[t+1]-l[t])})}}return n=[c,u],E},E.mode=function(e){return arguments.length?(t=e,T(),E):t},E.range=function(e,t){return g(e,t),E},E.out=function(e){return l=e,E},E.spread=function(e){return arguments.length?(r=e,E):r},E.correctLightness=function(e){return null==e&&(e=!0),f=e,T(),v=f?function(e){for(var t=x(0,!0).lab()[0],i=x(1,!0).lab()[0],r=t>i,n=x(e,!0).lab()[0],o=t+(i-t)*e,s=n-o,a=0,h=1,l=20;Math.abs(s)>.01&&l-- >0;)r&&(s*=-1),s<0?(a=e,e+=.5*(h-e)):(h=e,e+=.5*(a-e)),n=x(e,!0).lab()[0],s=n-o;return e}:function(e){return e},E},E.padding=function(e){return null!=e?("number"===ci(e)&&(e=[e,e]),s=e,E):s},E.colors=function(t,i){arguments.length<2&&(i="hex");var r=[];if(0===arguments.length)r=h.slice(0);else if(1===t)r=[E(.5)];else if(t>1){var o=n[0],s=n[1]-o;r=di(0,t,!1).map((function(e){return E(o+e/(t-1)*s)}))}else{e=[];var l=[];if(a&&a.length>2)for(var c=1,u=a.length,f=1<=u;f?cu;f?c++:c--)l.push(.5*(a[c-1]+a[c]));else l=n;r=l.map((function(e){return E(e)}))}return b[i]&&(r=r.map((function(e){return e[i]()}))),r},E.cache=function(e){return null!=e?(p=e,E):p},E.gamma=function(e){return null!=e?(_=e,E):_},E.nodata=function(e){return null!=e?(i=b(e),E):i},E};function di(e,t,i){for(var r=[],n=eo;n?s++:s--)r.push(s);return r}var pi=function(e){var t,i,r,n,o,s,a;if(2===(e=e.map((function(e){return new g(e)}))).length)t=e.map((function(e){return e.lab()})),o=t[0],s=t[1],n=function(e){var t=[0,1,2].map((function(t){return o[t]+e*(s[t]-o[t])}));return new g(t,"lab")};else if(3===e.length)i=e.map((function(e){return e.lab()})),o=i[0],s=i[1],a=i[2],n=function(e){var t=[0,1,2].map((function(t){return(1-e)*(1-e)*o[t]+2*(1-e)*e*s[t]+e*e*a[t]}));return new g(t,"lab")};else if(4===e.length){var h;r=e.map((function(e){return e.lab()})),o=r[0],s=r[1],a=r[2],h=r[3],n=function(e){var t=[0,1,2].map((function(t){return(1-e)*(1-e)*(1-e)*o[t]+3*(1-e)*(1-e)*e*s[t]+3*(1-e)*e*e*a[t]+e*e*e*h[t]}));return new g(t,"lab")}}else if(5===e.length){var l=pi(e.slice(0,3)),c=pi(e.slice(2,5));n=function(e){return e<.5?l(2*e):c(2*(e-.5))}}return n},_i=function(e){var t=pi(e);return t.scale=function(){return fi(t)},t},gi=function(e,t,i){if(!gi[i])throw new Error("unknown blend mode "+i);return gi[i](e,t)},mi=function(e){return function(t,i){var r=b(i).rgb(),n=b(t).rgb();return b.rgb(e(r,n))}},bi=function(e){return function(t,i){var r=[];return r[0]=e(t[0],i[0]),r[1]=e(t[1],i[1]),r[2]=e(t[2],i[2]),r}},vi=function(e){return e},yi=function(e,t){return e*t/255},xi=function(e,t){return e>t?t:e},Ti=function(e,t){return e>t?e:t},Ei=function(e,t){return 255*(1-(1-e/255)*(1-t/255))},Mi=function(e,t){return t<128?2*e*t/255:255*(1-2*(1-e/255)*(1-t/255))},Ai=function(e,t){return 255*(1-(1-t/255)/(e/255))},Oi=function(e,t){return 255===e||(e=t/255*255/(1-e/255))>255?255:e};gi.normal=mi(bi(vi)),gi.multiply=mi(bi(yi)),gi.screen=mi(bi(Ei)),gi.overlay=mi(bi(Mi)),gi.darken=mi(bi(xi)),gi.lighten=mi(bi(Ti)),gi.dodge=mi(bi(Oi)),gi.burn=mi(bi(Ai));for(var Ci=gi,Si=c.type,Pi=c.clip_rgb,Ri=c.TWOPI,Ii=Math.pow,wi=Math.sin,Di=Math.cos,Li=function(e,t,i,r,n){void 0===e&&(e=300),void 0===t&&(t=-1.5),void 0===i&&(i=1),void 0===r&&(r=1),void 0===n&&(n=[0,1]);var o,s=0;"array"===Si(n)?o=n[1]-n[0]:(o=0,n=[n,n]);var a=function(a){var h=Ri*((e+120)/360+t*a),l=Ii(n[0]+o*a,r),c=(0!==s?i[0]+a*s:i)*l*(1-l)/2,u=Di(h),f=wi(h);return b(Pi([255*(l+c*(-.14861*u+1.78277*f)),255*(l+c*(-.29227*u-.90649*f)),255*(l+c*(1.97294*u)),1]))};return a.start=function(t){return null==t?e:(e=t,a)},a.rotations=function(e){return null==e?t:(t=e,a)},a.gamma=function(e){return null==e?r:(r=e,a)},a.hue=function(e){return null==e?i:("array"===Si(i=e)?0==(s=i[1]-i[0])&&(i=i[1]):s=0,a)},a.lightness=function(e){return null==e?n:("array"===Si(e)?(n=e,o=e[1]-e[0]):(n=[e,e],o=0),a)},a.scale=function(){return b.scale(a)},a.hue(i),a},Fi="0123456789abcdef",Ni=Math.floor,Bi=Math.random,ki=function(){for(var e="#",t=0;t<6;t++)e+=Fi.charAt(Ni(16*Bi()));return new g(e,"hex")},Ui=Math.log,Vi=Math.pow,zi=Math.floor,ji=Math.abs,Wi=function(e,t){void 0===t&&(t=null);var i={min:Number.MAX_VALUE,max:-1*Number.MAX_VALUE,sum:0,values:[],count:0};return"object"===s(e)&&(e=Object.values(e)),e.forEach((function(e){t&&"object"===s(e)&&(e=e[t]),null==e||isNaN(e)||(i.values.push(e),i.sum+=e,ei.max&&(i.max=e),i.count+=1)})),i.domain=[i.min,i.max],i.limits=function(e,t){return Gi(i,e,t)},i},Gi=function(e,t,i){void 0===t&&(t="equal"),void 0===i&&(i=7),"array"==s(e)&&(e=Wi(e));var r=e.min,n=e.max,o=e.values.sort((function(e,t){return e-t}));if(1===i)return[r,n];var a=[];if("c"===t.substr(0,1)&&(a.push(r),a.push(n)),"e"===t.substr(0,1)){a.push(r);for(var h=1;h 0");var l=Math.LOG10E*Ui(r),c=Math.LOG10E*Ui(n);a.push(r);for(var u=1;u200&&(y=!1)}for(var N={},B=0;Br?(i+.05)/(r+.05):(r+.05)/(i+.05)},Ki=Math.sqrt,Yi=Math.atan2,qi=Math.abs,Zi=Math.cos,Qi=Math.PI,Ji=function(e,t,i,r){void 0===i&&(i=1),void 0===r&&(r=1),e=new g(e),t=new g(t);for(var n=Array.from(e.lab()),o=n[0],s=n[1],a=n[2],h=Array.from(t.lab()),l=h[0],c=h[1],u=h[2],f=Ki(s*s+a*a),d=Ki(c*c+u*u),p=o<16?.511:.040975*o/(1+.01765*o),_=.0638*f/(1+.0131*f)+.638,m=f<1e-6?0:180*Yi(a,s)/Qi;m<0;)m+=360;for(;m>=360;)m-=360;var b=m>=164&&m<=345?.56+qi(.2*Zi(Qi*(m+168)/180)):.36+qi(.4*Zi(Qi*(m+35)/180)),v=f*f*f*f,y=Ki(v/(v+1900)),x=_*(y*b+1-y),T=f-d,E=s-c,M=a-u,A=(o-l)/(i*p),O=T/(r*_);return Ki(A*A+O*O+(E*E+M*M-T*T)/(x*x))},$i=function(e,t,i){void 0===i&&(i="lab"),e=new g(e),t=new g(t);var r=e.get(i),n=t.get(i),o=0;for(var s in r){var a=(r[s]||0)-(n[s]||0);o+=a*a}return Math.sqrt(o)},er=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];try{return new(Function.prototype.bind.apply(g,[null].concat(e))),!0}catch(e){return!1}},tr={cool:function(){return fi([b.hsl(180,1,.9),b.hsl(250,.7,.4)])},hot:function(){return fi(["#000","#f00","#ff0","#fff"],[0,.25,.75,1]).mode("rgb")}},ir={OrRd:["#fff7ec","#fee8c8","#fdd49e","#fdbb84","#fc8d59","#ef6548","#d7301f","#b30000","#7f0000"],PuBu:["#fff7fb","#ece7f2","#d0d1e6","#a6bddb","#74a9cf","#3690c0","#0570b0","#045a8d","#023858"],BuPu:["#f7fcfd","#e0ecf4","#bfd3e6","#9ebcda","#8c96c6","#8c6bb1","#88419d","#810f7c","#4d004b"],Oranges:["#fff5eb","#fee6ce","#fdd0a2","#fdae6b","#fd8d3c","#f16913","#d94801","#a63603","#7f2704"],BuGn:["#f7fcfd","#e5f5f9","#ccece6","#99d8c9","#66c2a4","#41ae76","#238b45","#006d2c","#00441b"],YlOrBr:["#ffffe5","#fff7bc","#fee391","#fec44f","#fe9929","#ec7014","#cc4c02","#993404","#662506"],YlGn:["#ffffe5","#f7fcb9","#d9f0a3","#addd8e","#78c679","#41ab5d","#238443","#006837","#004529"],Reds:["#fff5f0","#fee0d2","#fcbba1","#fc9272","#fb6a4a","#ef3b2c","#cb181d","#a50f15","#67000d"],RdPu:["#fff7f3","#fde0dd","#fcc5c0","#fa9fb5","#f768a1","#dd3497","#ae017e","#7a0177","#49006a"],Greens:["#f7fcf5","#e5f5e0","#c7e9c0","#a1d99b","#74c476","#41ab5d","#238b45","#006d2c","#00441b"],YlGnBu:["#ffffd9","#edf8b1","#c7e9b4","#7fcdbb","#41b6c4","#1d91c0","#225ea8","#253494","#081d58"],Purples:["#fcfbfd","#efedf5","#dadaeb","#bcbddc","#9e9ac8","#807dba","#6a51a3","#54278f","#3f007d"],GnBu:["#f7fcf0","#e0f3db","#ccebc5","#a8ddb5","#7bccc4","#4eb3d3","#2b8cbe","#0868ac","#084081"],Greys:["#ffffff","#f0f0f0","#d9d9d9","#bdbdbd","#969696","#737373","#525252","#252525","#000000"],YlOrRd:["#ffffcc","#ffeda0","#fed976","#feb24c","#fd8d3c","#fc4e2a","#e31a1c","#bd0026","#800026"],PuRd:["#f7f4f9","#e7e1ef","#d4b9da","#c994c7","#df65b0","#e7298a","#ce1256","#980043","#67001f"],Blues:["#f7fbff","#deebf7","#c6dbef","#9ecae1","#6baed6","#4292c6","#2171b5","#08519c","#08306b"],PuBuGn:["#fff7fb","#ece2f0","#d0d1e6","#a6bddb","#67a9cf","#3690c0","#02818a","#016c59","#014636"],Viridis:["#440154","#482777","#3f4a8a","#31678e","#26838f","#1f9d8a","#6cce5a","#b6de2b","#fee825"],Spectral:["#9e0142","#d53e4f","#f46d43","#fdae61","#fee08b","#ffffbf","#e6f598","#abdda4","#66c2a5","#3288bd","#5e4fa2"],RdYlGn:["#a50026","#d73027","#f46d43","#fdae61","#fee08b","#ffffbf","#d9ef8b","#a6d96a","#66bd63","#1a9850","#006837"],RdBu:["#67001f","#b2182b","#d6604d","#f4a582","#fddbc7","#f7f7f7","#d1e5f0","#92c5de","#4393c3","#2166ac","#053061"],PiYG:["#8e0152","#c51b7d","#de77ae","#f1b6da","#fde0ef","#f7f7f7","#e6f5d0","#b8e186","#7fbc41","#4d9221","#276419"],PRGn:["#40004b","#762a83","#9970ab","#c2a5cf","#e7d4e8","#f7f7f7","#d9f0d3","#a6dba0","#5aae61","#1b7837","#00441b"],RdYlBu:["#a50026","#d73027","#f46d43","#fdae61","#fee090","#ffffbf","#e0f3f8","#abd9e9","#74add1","#4575b4","#313695"],BrBG:["#543005","#8c510a","#bf812d","#dfc27d","#f6e8c3","#f5f5f5","#c7eae5","#80cdc1","#35978f","#01665e","#003c30"],RdGy:["#67001f","#b2182b","#d6604d","#f4a582","#fddbc7","#ffffff","#e0e0e0","#bababa","#878787","#4d4d4d","#1a1a1a"],PuOr:["#7f3b08","#b35806","#e08214","#fdb863","#fee0b6","#f7f7f7","#d8daeb","#b2abd2","#8073ac","#542788","#2d004b"],Set2:["#66c2a5","#fc8d62","#8da0cb","#e78ac3","#a6d854","#ffd92f","#e5c494","#b3b3b3"],Accent:["#7fc97f","#beaed4","#fdc086","#ffff99","#386cb0","#f0027f","#bf5b17","#666666"],Set1:["#e41a1c","#377eb8","#4daf4a","#984ea3","#ff7f00","#ffff33","#a65628","#f781bf","#999999"],Set3:["#8dd3c7","#ffffb3","#bebada","#fb8072","#80b1d3","#fdb462","#b3de69","#fccde5","#d9d9d9","#bc80bd","#ccebc5","#ffed6f"],Dark2:["#1b9e77","#d95f02","#7570b3","#e7298a","#66a61e","#e6ab02","#a6761d","#666666"],Paired:["#a6cee3","#1f78b4","#b2df8a","#33a02c","#fb9a99","#e31a1c","#fdbf6f","#ff7f00","#cab2d6","#6a3d9a","#ffff99","#b15928"],Pastel2:["#b3e2cd","#fdcdac","#cbd5e8","#f4cae4","#e6f5c9","#fff2ae","#f1e2cc","#cccccc"],Pastel1:["#fbb4ae","#b3cde3","#ccebc5","#decbe4","#fed9a6","#ffffcc","#e5d8bd","#fddaec","#f2f2f2"]},rr=0,nr=Object.keys(ir);rr0;)m.unshift(m.pop()),v.unshift(v.pop()),p--;for(;_>0;)b.unshift(b.pop()),y.unshift(y.pop()),_--;m=m.flat(),b=b.flat(),g=g.concat(m).concat(b),i.push(v[0],v[2],v[3],v[0],v[1],v[2]),i.push(y[0],y[2],y[3],y[0],y[1],y[2])}var x=[h/2,l/2,c/2];t=g.reduce((function(e,t,i){return e.concat(t*x[i%3])}),[]);for(var T=0===e.sideOrientation?0:e.sideOrientation||s.VertexData.DEFAULTSIDE,E=e.faceUV||new Array(6),M=e.faceColors,A=[],O=0;O<6;O++)void 0===E[O]&&(E[O]=new r.f(0,0,1,1)),M&&void 0===M[O]&&(M[O]=new n.b(1,1,1,1));for(var C=0;C<6;C++)if(a.push(E[C].z,E[C].w),a.push(E[C].x,E[C].w),a.push(E[C].x,E[C].y),a.push(E[C].z,E[C].y),M)for(var S=0;S<4;S++)A.push(M[C].r,M[C].g,M[C].b,M[C].a);s.VertexData._ComputeSides(T,t,i,o,a,e.frontUVs,e.backUVs);var P=new s.VertexData;if(P.indices=i,P.positions=t,P.normals=o,P.uvs=a,M){var R=T===s.VertexData.DOUBLESIDE?A.concat(A):A;P.colors=R}return P},o.Mesh.CreateBox=function(e,t,i,r,n){void 0===i&&(i=null);var o={size:t,sideOrientation:n,updatable:r};return a.CreateBox(e,o,i)};var a=function(){function e(){}return e.CreateBox=function(e,t,i){void 0===i&&(i=null);var r=new o.Mesh(e,i);return t.sideOrientation=o.Mesh._GetDefaultSideOrientation(t.sideOrientation),r._originalBuilderSideOrientation=t.sideOrientation,s.VertexData.CreateBox(t).applyToMesh(r,t.updatable),r},e}()},function(e,t,i){"use strict";var r="clipPlaneFragmentDeclaration",n="#ifdef CLIPPLANE\nvarying float fClipDistance;\n#endif\n#ifdef CLIPPLANE2\nvarying float fClipDistance2;\n#endif\n#ifdef CLIPPLANE3\nvarying float fClipDistance3;\n#endif\n#ifdef CLIPPLANE4\nvarying float fClipDistance4;\n#endif\n#ifdef CLIPPLANE5\nvarying float fClipDistance5;\n#endif\n#ifdef CLIPPLANE6\nvarying float fClipDistance6;\n#endif";i(6).a.IncludesShadersStore[r]=n},function(e,t,i){"use strict";var r="clipPlaneFragment",n="#ifdef CLIPPLANE\nif (fClipDistance>0.0)\n{\ndiscard;\n}\n#endif\n#ifdef CLIPPLANE2\nif (fClipDistance2>0.0)\n{\ndiscard;\n}\n#endif\n#ifdef CLIPPLANE3\nif (fClipDistance3>0.0)\n{\ndiscard;\n}\n#endif\n#ifdef CLIPPLANE4\nif (fClipDistance4>0.0)\n{\ndiscard;\n}\n#endif\n#ifdef CLIPPLANE5\nif (fClipDistance5>0.0)\n{\ndiscard;\n}\n#endif\n#ifdef CLIPPLANE6\nif (fClipDistance6>0.0)\n{\ndiscard;\n}\n#endif";i(6).a.IncludesShadersStore[r]=n},function(e,t,i){"use strict";var r="bonesDeclaration",n="#if NUM_BONE_INFLUENCERS>0\n#ifdef BONETEXTURE\nuniform sampler2D boneSampler;\nuniform float boneTextureWidth;\n#else\nuniform mat4 mBones[BonesPerMesh];\n#endif\nattribute vec4 matricesIndices;\nattribute vec4 matricesWeights;\n#if NUM_BONE_INFLUENCERS>4\nattribute vec4 matricesIndicesExtra;\nattribute vec4 matricesWeightsExtra;\n#endif\n#ifdef BONETEXTURE\nmat4 readMatrixFromRawSampler(sampler2D smp,float index)\n{\nfloat offset=index*4.0;\nfloat dx=1.0/boneTextureWidth;\nvec4 m0=texture2D(smp,vec2(dx*(offset+0.5),0.));\nvec4 m1=texture2D(smp,vec2(dx*(offset+1.5),0.));\nvec4 m2=texture2D(smp,vec2(dx*(offset+2.5),0.));\nvec4 m3=texture2D(smp,vec2(dx*(offset+3.5),0.));\nreturn mat4(m0,m1,m2,m3);\n}\n#endif\n#endif";i(6).a.IncludesShadersStore[r]=n},function(e,t,i){"use strict";var r="instancesDeclaration",n="#ifdef INSTANCES\nattribute vec4 world0;\nattribute vec4 world1;\nattribute vec4 world2;\nattribute vec4 world3;\n#else\nuniform mat4 world;\n#endif";i(6).a.IncludesShadersStore[r]=n},function(e,t,i){"use strict";var r="clipPlaneVertexDeclaration",n="#ifdef CLIPPLANE\nuniform vec4 vClipPlane;\nvarying float fClipDistance;\n#endif\n#ifdef CLIPPLANE2\nuniform vec4 vClipPlane2;\nvarying float fClipDistance2;\n#endif\n#ifdef CLIPPLANE3\nuniform vec4 vClipPlane3;\nvarying float fClipDistance3;\n#endif\n#ifdef CLIPPLANE4\nuniform vec4 vClipPlane4;\nvarying float fClipDistance4;\n#endif\n#ifdef CLIPPLANE5\nuniform vec4 vClipPlane5;\nvarying float fClipDistance5;\n#endif\n#ifdef CLIPPLANE6\nuniform vec4 vClipPlane6;\nvarying float fClipDistance6;\n#endif";i(6).a.IncludesShadersStore[r]=n},function(e,t,i){"use strict";var r="instancesVertex",n="#ifdef INSTANCES\nmat4 finalWorld=mat4(world0,world1,world2,world3);\n#else\nmat4 finalWorld=world;\n#endif";i(6).a.IncludesShadersStore[r]=n},function(e,t,i){"use strict";var r="bonesVertex",n="#if NUM_BONE_INFLUENCERS>0\nmat4 influence;\n#ifdef BONETEXTURE\ninfluence=readMatrixFromRawSampler(boneSampler,matricesIndices[0])*matricesWeights[0];\n#if NUM_BONE_INFLUENCERS>1\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndices[1])*matricesWeights[1];\n#endif\n#if NUM_BONE_INFLUENCERS>2\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndices[2])*matricesWeights[2];\n#endif\n#if NUM_BONE_INFLUENCERS>3\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndices[3])*matricesWeights[3];\n#endif\n#if NUM_BONE_INFLUENCERS>4\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndicesExtra[0])*matricesWeightsExtra[0];\n#endif\n#if NUM_BONE_INFLUENCERS>5\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndicesExtra[1])*matricesWeightsExtra[1];\n#endif\n#if NUM_BONE_INFLUENCERS>6\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndicesExtra[2])*matricesWeightsExtra[2];\n#endif\n#if NUM_BONE_INFLUENCERS>7\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndicesExtra[3])*matricesWeightsExtra[3];\n#endif\n#else\ninfluence=mBones[int(matricesIndices[0])]*matricesWeights[0];\n#if NUM_BONE_INFLUENCERS>1\ninfluence+=mBones[int(matricesIndices[1])]*matricesWeights[1];\n#endif\n#if NUM_BONE_INFLUENCERS>2\ninfluence+=mBones[int(matricesIndices[2])]*matricesWeights[2];\n#endif\n#if NUM_BONE_INFLUENCERS>3\ninfluence+=mBones[int(matricesIndices[3])]*matricesWeights[3];\n#endif\n#if NUM_BONE_INFLUENCERS>4\ninfluence+=mBones[int(matricesIndicesExtra[0])]*matricesWeightsExtra[0];\n#endif\n#if NUM_BONE_INFLUENCERS>5\ninfluence+=mBones[int(matricesIndicesExtra[1])]*matricesWeightsExtra[1];\n#endif\n#if NUM_BONE_INFLUENCERS>6\ninfluence+=mBones[int(matricesIndicesExtra[2])]*matricesWeightsExtra[2];\n#endif\n#if NUM_BONE_INFLUENCERS>7\ninfluence+=mBones[int(matricesIndicesExtra[3])]*matricesWeightsExtra[3];\n#endif\n#endif\nfinalWorld=finalWorld*influence;\n#endif";i(6).a.IncludesShadersStore[r]=n},function(e,t,i){"use strict";var r="clipPlaneVertex",n="#ifdef CLIPPLANE\nfClipDistance=dot(worldPos,vClipPlane);\n#endif\n#ifdef CLIPPLANE2\nfClipDistance2=dot(worldPos,vClipPlane2);\n#endif\n#ifdef CLIPPLANE3\nfClipDistance3=dot(worldPos,vClipPlane3);\n#endif\n#ifdef CLIPPLANE4\nfClipDistance4=dot(worldPos,vClipPlane4);\n#endif\n#ifdef CLIPPLANE5\nfClipDistance5=dot(worldPos,vClipPlane5);\n#endif\n#ifdef CLIPPLANE6\nfClipDistance6=dot(worldPos,vClipPlane6);\n#endif";i(6).a.IncludesShadersStore[r]=n},function(e,t,i){"use strict";e.exports=function(e,t){return function(){for(var i=new Array(arguments.length),r=0;r=200&&e<300}};h.headers={common:{Accept:"application/json, text/plain, */*"}},r.forEach(["delete","get","head"],(function(e){h.headers[e]={}})),r.forEach(["post","put","patch"],(function(e){h.headers[e]=r.merge(o)})),e.exports=h}).call(this,i(108))},function(e,t,i){"use strict";var r=i(40),n=i(110),o=i(112),s=i(90),a=i(113),h=i(116),l=i(117),c=i(94);e.exports=function(e){return new Promise((function(t,i){var u=e.data,f=e.headers;r.isFormData(u)&&delete f["Content-Type"];var d=new XMLHttpRequest;if(e.auth){var p=e.auth.username||"",_=e.auth.password?unescape(encodeURIComponent(e.auth.password)):"";f.Authorization="Basic "+btoa(p+":"+_)}var g=a(e.baseURL,e.url);if(d.open(e.method.toUpperCase(),s(g,e.params,e.paramsSerializer),!0),d.timeout=e.timeout,d.onreadystatechange=function(){if(d&&4===d.readyState&&(0!==d.status||d.responseURL&&0===d.responseURL.indexOf("file:"))){var r="getAllResponseHeaders"in d?h(d.getAllResponseHeaders()):null,o={data:e.responseType&&"text"!==e.responseType?d.response:d.responseText,status:d.status,statusText:d.statusText,headers:r,config:e,request:d};n(t,i,o),d=null}},d.onabort=function(){d&&(i(c("Request aborted",e,"ECONNABORTED",d)),d=null)},d.onerror=function(){i(c("Network Error",e,null,d)),d=null},d.ontimeout=function(){var t="timeout of "+e.timeout+"ms exceeded";e.timeoutErrorMessage&&(t=e.timeoutErrorMessage),i(c(t,e,"ECONNABORTED",d)),d=null},r.isStandardBrowserEnv()){var m=(e.withCredentials||l(g))&&e.xsrfCookieName?o.read(e.xsrfCookieName):void 0;m&&(f[e.xsrfHeaderName]=m)}if("setRequestHeader"in d&&r.forEach(f,(function(e,t){void 0===u&&"content-type"===t.toLowerCase()?delete f[t]:d.setRequestHeader(t,e)})),r.isUndefined(e.withCredentials)||(d.withCredentials=!!e.withCredentials),e.responseType)try{d.responseType=e.responseType}catch(t){if("json"!==e.responseType)throw t}"function"==typeof e.onDownloadProgress&&d.addEventListener("progress",e.onDownloadProgress),"function"==typeof e.onUploadProgress&&d.upload&&d.upload.addEventListener("progress",e.onUploadProgress),e.cancelToken&&e.cancelToken.promise.then((function(e){d&&(d.abort(),i(e),d=null)})),u||(u=null),d.send(u)}))}},function(e,t,i){"use strict";var r=i(111);e.exports=function(e,t,i,n,o){var s=new Error(e);return r(s,t,i,n,o)}},function(e,t,i){"use strict";var r=i(40);e.exports=function(e,t){t=t||{};var i={},n=["url","method","data"],o=["headers","auth","proxy","params"],s=["baseURL","transformRequest","transformResponse","paramsSerializer","timeout","timeoutMessage","withCredentials","adapter","responseType","xsrfCookieName","xsrfHeaderName","onUploadProgress","onDownloadProgress","decompress","maxContentLength","maxBodyLength","maxRedirects","transport","httpAgent","httpsAgent","cancelToken","socketPath","responseEncoding"],a=["validateStatus"];function h(e,t){return r.isPlainObject(e)&&r.isPlainObject(t)?r.merge(e,t):r.isPlainObject(t)?r.merge({},t):r.isArray(t)?t.slice():t}function l(n){r.isUndefined(t[n])?r.isUndefined(e[n])||(i[n]=h(void 0,e[n])):i[n]=h(e[n],t[n])}r.forEach(n,(function(e){r.isUndefined(t[e])||(i[e]=h(void 0,t[e]))})),r.forEach(o,l),r.forEach(s,(function(n){r.isUndefined(t[n])?r.isUndefined(e[n])||(i[n]=h(void 0,e[n])):i[n]=h(void 0,t[n])})),r.forEach(a,(function(r){r in t?i[r]=h(e[r],t[r]):r in e&&(i[r]=h(void 0,e[r]))}));var c=n.concat(o).concat(s).concat(a),u=Object.keys(e).concat(Object.keys(t)).filter((function(e){return-1===c.indexOf(e)}));return r.forEach(u,l),i}},function(e,t,i){"use strict";function r(e){this.message=e}r.prototype.toString=function(){return"Cancel"+(this.message?": "+this.message:"")},r.prototype.__CANCEL__=!0,e.exports=r},function(e,t,i){"use strict";i.r(t),i.d(t,"Button",(function(){return p})),i.d(t,"Checkbox",(function(){return g})),i.d(t,"ColorPicker",(function(){return T})),i.d(t,"Container",(function(){return n.a})),i.d(t,"Control",(function(){return h.a})),i.d(t,"Ellipse",(function(){return E})),i.d(t,"Grid",(function(){return y})),i.d(t,"Image",(function(){return d})),i.d(t,"InputText",(function(){return v})),i.d(t,"InputPassword",(function(){return M})),i.d(t,"Line",(function(){return O})),i.d(t,"MultiLine",(function(){return P})),i.d(t,"RadioButton",(function(){return R})),i.d(t,"StackPanel",(function(){return _})),i.d(t,"SelectorGroup",(function(){return D})),i.d(t,"CheckboxGroup",(function(){return L})),i.d(t,"RadioGroup",(function(){return F})),i.d(t,"SliderGroup",(function(){return N})),i.d(t,"SelectionPanel",(function(){return B})),i.d(t,"ScrollViewer",(function(){return j})),i.d(t,"TextWrapping",(function(){return a})),i.d(t,"TextBlock",(function(){return u})),i.d(t,"KeyPropertySet",(function(){return W})),i.d(t,"VirtualKeyboard",(function(){return G})),i.d(t,"Rectangle",(function(){return s})),i.d(t,"DisplayGrid",(function(){return H})),i.d(t,"BaseSlider",(function(){return I})),i.d(t,"Slider",(function(){return w})),i.d(t,"ImageBasedSlider",(function(){return X})),i.d(t,"ScrollBar",(function(){return V})),i.d(t,"ImageScrollBar",(function(){return z})),i.d(t,"name",(function(){return K}));var r=i(1),n=i(32),o=i(10),s=function(e){function t(t){var i=e.call(this,t)||this;return i.name=t,i._thickness=1,i._cornerRadius=0,i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"thickness",{get:function(){return this._thickness},set:function(e){this._thickness!==e&&(this._thickness=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"cornerRadius",{get:function(){return this._cornerRadius},set:function(e){e<0&&(e=0),this._cornerRadius!==e&&(this._cornerRadius=e,this._markAsDirty())},enumerable:!0,configurable:!0}),t.prototype._getTypeName=function(){return"Rectangle"},t.prototype._localDraw=function(e){e.save(),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowColor=this.shadowColor,e.shadowBlur=this.shadowBlur,e.shadowOffsetX=this.shadowOffsetX,e.shadowOffsetY=this.shadowOffsetY),this._background&&(e.fillStyle=this._background,this._cornerRadius?(this._drawRoundedRect(e,this._thickness/2),e.fill()):e.fillRect(this._currentMeasure.left,this._currentMeasure.top,this._currentMeasure.width,this._currentMeasure.height)),this._thickness&&((this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowBlur=0,e.shadowOffsetX=0,e.shadowOffsetY=0),this.color&&(e.strokeStyle=this.color),e.lineWidth=this._thickness,this._cornerRadius?(this._drawRoundedRect(e,this._thickness/2),e.stroke()):e.strokeRect(this._currentMeasure.left+this._thickness/2,this._currentMeasure.top+this._thickness/2,this._currentMeasure.width-this._thickness,this._currentMeasure.height-this._thickness)),e.restore()},t.prototype._additionalProcessing=function(t,i){e.prototype._additionalProcessing.call(this,t,i),this._measureForChildren.width-=2*this._thickness,this._measureForChildren.height-=2*this._thickness,this._measureForChildren.left+=this._thickness,this._measureForChildren.top+=this._thickness},t.prototype._drawRoundedRect=function(e,t){void 0===t&&(t=0);var i=this._currentMeasure.left+t,r=this._currentMeasure.top+t,n=this._currentMeasure.width-2*t,o=this._currentMeasure.height-2*t,s=Math.min(o/2-2,Math.min(n/2-2,this._cornerRadius));e.beginPath(),e.moveTo(i+s,r),e.lineTo(i+n-s,r),e.quadraticCurveTo(i+n,r,i+n,r+s),e.lineTo(i+n,r+o-s),e.quadraticCurveTo(i+n,r+o,i+n-s,r+o),e.lineTo(i+s,r+o),e.quadraticCurveTo(i,r+o,i,r+o-s),e.lineTo(i,r+s),e.quadraticCurveTo(i,r,i+s,r),e.closePath()},t.prototype._clipForChildren=function(e){this._cornerRadius&&(this._drawRoundedRect(e,this._thickness),e.clip())},t}(n.a);o.a.RegisteredTypes["BABYLON.GUI.Rectangle"]=s;var a,h=i(5),l=i(4),c=i(14);!function(e){e[e.Clip=0]="Clip",e[e.WordWrap=1]="WordWrap",e[e.Ellipsis=2]="Ellipsis"}(a||(a={}));var u=function(e){function t(t,i){void 0===i&&(i="");var r=e.call(this,t)||this;return r.name=t,r._text="",r._textWrapping=a.Clip,r._textHorizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_CENTER,r._textVerticalAlignment=h.a.VERTICAL_ALIGNMENT_CENTER,r._resizeToFit=!1,r._lineSpacing=new c.a(0),r._outlineWidth=0,r._outlineColor="white",r.onTextChangedObservable=new l.a,r.onLinesReadyObservable=new l.a,r.text=i,r}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"lines",{get:function(){return this._lines},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"resizeToFit",{get:function(){return this._resizeToFit},set:function(e){this._resizeToFit!==e&&(this._resizeToFit=e,this._resizeToFit&&(this._width.ignoreAdaptiveScaling=!0,this._height.ignoreAdaptiveScaling=!0),this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"textWrapping",{get:function(){return this._textWrapping},set:function(e){this._textWrapping!==e&&(this._textWrapping=+e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"text",{get:function(){return this._text},set:function(e){this._text!==e&&(this._text=e,this._markAsDirty(),this.onTextChangedObservable.notifyObservers(this))},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"textHorizontalAlignment",{get:function(){return this._textHorizontalAlignment},set:function(e){this._textHorizontalAlignment!==e&&(this._textHorizontalAlignment=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"textVerticalAlignment",{get:function(){return this._textVerticalAlignment},set:function(e){this._textVerticalAlignment!==e&&(this._textVerticalAlignment=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"lineSpacing",{get:function(){return this._lineSpacing.toString(this._host)},set:function(e){this._lineSpacing.fromString(e)&&this._markAsDirty()},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"outlineWidth",{get:function(){return this._outlineWidth},set:function(e){this._outlineWidth!==e&&(this._outlineWidth=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"outlineColor",{get:function(){return this._outlineColor},set:function(e){this._outlineColor!==e&&(this._outlineColor=e,this._markAsDirty())},enumerable:!0,configurable:!0}),t.prototype._getTypeName=function(){return"TextBlock"},t.prototype._processMeasures=function(t,i){this._fontOffset||(this._fontOffset=h.a._GetFontOffset(i.font)),e.prototype._processMeasures.call(this,t,i),this._lines=this._breakLines(this._currentMeasure.width,i),this.onLinesReadyObservable.notifyObservers(this);for(var r=0,n=0;nr&&(r=o.width)}if(this._resizeToFit){if(this._textWrapping===a.Clip){var s=this.paddingLeftInPixels+this.paddingRightInPixels+r;s!==this._width.internalValue&&(this._width.updateInPlace(s,c.a.UNITMODE_PIXEL),this._rebuildLayout=!0)}var l=this.paddingTopInPixels+this.paddingBottomInPixels+this._fontOffset.height*this._lines.length;if(this._lines.length>0&&0!==this._lineSpacing.internalValue){var u=0;u=this._lineSpacing.isPixel?this._lineSpacing.getValue(this._host):this._lineSpacing.getValue(this._host)*this._height.getValueInPixel(this._host,this._cachedParentMeasure.height),l+=(this._lines.length-1)*u}l!==this._height.internalValue&&(this._height.updateInPlace(l,c.a.UNITMODE_PIXEL),this._rebuildLayout=!0)}},t.prototype._drawText=function(e,t,i,r){var n=this._currentMeasure.width,o=0;switch(this._textHorizontalAlignment){case h.a.HORIZONTAL_ALIGNMENT_LEFT:o=0;break;case h.a.HORIZONTAL_ALIGNMENT_RIGHT:o=n-t;break;case h.a.HORIZONTAL_ALIGNMENT_CENTER:o=(n-t)/2}(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(r.shadowColor=this.shadowColor,r.shadowBlur=this.shadowBlur,r.shadowOffsetX=this.shadowOffsetX,r.shadowOffsetY=this.shadowOffsetY),this.outlineWidth&&r.strokeText(e,this._currentMeasure.left+o,i),r.fillText(e,this._currentMeasure.left+o,i)},t.prototype._draw=function(e,t){e.save(),this._applyStates(e),this._renderLines(e),e.restore()},t.prototype._applyStates=function(t){e.prototype._applyStates.call(this,t),this.outlineWidth&&(t.lineWidth=this.outlineWidth,t.strokeStyle=this.outlineColor)},t.prototype._breakLines=function(e,t){var i=[],r=this.text.split("\n");if(this._textWrapping===a.Ellipsis)for(var n=0,o=r;nt&&(e+="…");e.length>2&&r>t;)e=e.slice(0,-2)+"…",r=i.measureText(e).width;return{text:e,width:r}},t.prototype._parseLineWordWrap=function(e,t,i){void 0===e&&(e="");for(var r=[],n=e.split(" "),o=0,s=0;s0?e+" "+n[s]:n[0],h=i.measureText(a).width;h>t&&s>0?(r.push({text:e,width:o}),e=n[s],o=i.measureText(e).width):(o=h,e=a)}return r.push({text:e,width:o}),r},t.prototype._renderLines=function(e){var t=this._currentMeasure.height,i=0;switch(this._textVerticalAlignment){case h.a.VERTICAL_ALIGNMENT_TOP:i=this._fontOffset.ascent;break;case h.a.VERTICAL_ALIGNMENT_BOTTOM:i=t-this._fontOffset.height*(this._lines.length-1)-this._fontOffset.descent;break;case h.a.VERTICAL_ALIGNMENT_CENTER:i=this._fontOffset.ascent+(t-this._fontOffset.height*this._lines.length)/2}i+=this._currentMeasure.top;for(var r=0;r0&&0!==this._lineSpacing.internalValue){var r=0;r=this._lineSpacing.isPixel?this._lineSpacing.getValue(this._host):this._lineSpacing.getValue(this._host)*this._height.getValueInPixel(this._host,this._cachedParentMeasure.height),i+=(t.length-1)*r}return i}}return 0},t.prototype.dispose=function(){e.prototype.dispose.call(this),this.onTextChangedObservable.clear()},t}(h.a);o.a.RegisteredTypes["BABYLON.GUI.TextBlock"]=u;var f=i(13),d=function(e){function t(i,r){void 0===r&&(r=null);var n=e.call(this,i)||this;return n.name=i,n._workingCanvas=null,n._loaded=!1,n._stretch=t.STRETCH_FILL,n._autoScale=!1,n._sourceLeft=0,n._sourceTop=0,n._sourceWidth=0,n._sourceHeight=0,n._svgAttributesComputationCompleted=!1,n._isSVG=!1,n._cellWidth=0,n._cellHeight=0,n._cellId=-1,n._populateNinePatchSlicesFromImage=!1,n.onImageLoadedObservable=new l.a,n.onSVGAttributesComputedObservable=new l.a,n.source=r,n}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"isLoaded",{get:function(){return this._loaded},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"populateNinePatchSlicesFromImage",{get:function(){return this._populateNinePatchSlicesFromImage},set:function(e){this._populateNinePatchSlicesFromImage!==e&&(this._populateNinePatchSlicesFromImage=e,this._populateNinePatchSlicesFromImage&&this._loaded&&this._extractNinePatchSliceDataFromImage())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"detectPointerOnOpaqueOnly",{get:function(){return this._detectPointerOnOpaqueOnly},set:function(e){this._detectPointerOnOpaqueOnly!==e&&(this._detectPointerOnOpaqueOnly=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"sliceLeft",{get:function(){return this._sliceLeft},set:function(e){this._sliceLeft!==e&&(this._sliceLeft=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"sliceRight",{get:function(){return this._sliceRight},set:function(e){this._sliceRight!==e&&(this._sliceRight=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"sliceTop",{get:function(){return this._sliceTop},set:function(e){this._sliceTop!==e&&(this._sliceTop=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"sliceBottom",{get:function(){return this._sliceBottom},set:function(e){this._sliceBottom!==e&&(this._sliceBottom=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"sourceLeft",{get:function(){return this._sourceLeft},set:function(e){this._sourceLeft!==e&&(this._sourceLeft=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"sourceTop",{get:function(){return this._sourceTop},set:function(e){this._sourceTop!==e&&(this._sourceTop=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"sourceWidth",{get:function(){return this._sourceWidth},set:function(e){this._sourceWidth!==e&&(this._sourceWidth=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"sourceHeight",{get:function(){return this._sourceHeight},set:function(e){this._sourceHeight!==e&&(this._sourceHeight=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"isSVG",{get:function(){return this._isSVG},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"svgAttributesComputationCompleted",{get:function(){return this._svgAttributesComputationCompleted},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"autoScale",{get:function(){return this._autoScale},set:function(e){this._autoScale!==e&&(this._autoScale=e,e&&this._loaded&&this.synchronizeSizeWithContent())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"stretch",{get:function(){return this._stretch},set:function(e){this._stretch!==e&&(this._stretch=e,this._markAsDirty())},enumerable:!0,configurable:!0}),t.prototype._rotate90=function(e,i){void 0===i&&(i=!1);var r=document.createElement("canvas"),n=r.getContext("2d"),o=this._domImage.width,s=this._domImage.height;r.width=s,r.height=o,n.translate(r.width/2,r.height/2),n.rotate(e*Math.PI/2),n.drawImage(this._domImage,0,0,o,s,-o/2,-s/2,o,s);var a=r.toDataURL("image/jpg"),h=new t(this.name+"rotated",a);return i&&(h._stretch=this._stretch,h._autoScale=this._autoScale,h._cellId=this._cellId,h._cellWidth=e%1?this._cellHeight:this._cellWidth,h._cellHeight=e%1?this._cellWidth:this._cellHeight),this._handleRotationForSVGImage(this,h,e),h},t.prototype._handleRotationForSVGImage=function(e,t,i){var r=this;e._isSVG&&(e._svgAttributesComputationCompleted?(this._rotate90SourceProperties(e,t,i),this._markAsDirty()):e.onSVGAttributesComputedObservable.addOnce((function(){r._rotate90SourceProperties(e,t,i),r._markAsDirty()})))},t.prototype._rotate90SourceProperties=function(e,t,i){var r,n,o=e.sourceLeft,s=e.sourceTop,a=e.domImage.width,h=e.domImage.height,l=o,c=s,u=e.sourceWidth,f=e.sourceHeight;if(0!=i){var d=i<0?-1:1;i%=4;for(var p=0;p127&&-1===this._sliceLeft)this._sliceLeft=o;else if(a<127&&this._sliceLeft>-1){this._sliceRight=o;break}}this._sliceTop=-1,this._sliceBottom=-1;for(var s=0;s127&&-1===this._sliceTop)this._sliceTop=s;else if(a<127&&this._sliceTop>-1){this._sliceBottom=s;break}}},Object.defineProperty(t.prototype,"source",{set:function(e){var t=this;this._source!==e&&(this._loaded=!1,this._source=e,e&&(e=this._svgCheck(e)),this._domImage=document.createElement("img"),this._domImage.onload=function(){t._onImageLoaded()},e&&(f.b.SetCorsBehavior(e,this._domImage),this._domImage.src=e))},enumerable:!0,configurable:!0}),t.prototype._svgCheck=function(e){var t=this;if(window.SVGSVGElement&&-1!==e.search(/.svg#/gi)&&e.indexOf("#")===e.lastIndexOf("#")){this._isSVG=!0;var i=e.split("#")[0],r=e.split("#")[1],n=document.body.querySelector('object[data="'+i+'"]');if(n){var o=n.contentDocument;if(o&&o.documentElement){var s=o.documentElement.getAttribute("viewBox"),a=Number(o.documentElement.getAttribute("width")),h=Number(o.documentElement.getAttribute("height"));if(o.getElementById(r)&&s&&a&&h)return this._getSVGAttribs(n,r),e}n.addEventListener("load",(function(){t._getSVGAttribs(n,r)}))}else{var l=document.createElement("object");l.data=i,l.type="image/svg+xml",l.width="0%",l.height="0%",document.body.appendChild(l),l.onload=function(){var e=document.body.querySelector('object[data="'+i+'"]');e&&t._getSVGAttribs(e,r)}}return i}return e},t.prototype._getSVGAttribs=function(e,t){var i=e.contentDocument;if(i&&i.documentElement){var r=i.documentElement.getAttribute("viewBox"),n=Number(i.documentElement.getAttribute("width")),o=Number(i.documentElement.getAttribute("height")),s=i.getElementById(t);if(r&&n&&o&&s){var a=Number(r.split(" ")[2]),h=Number(r.split(" ")[3]),l=s.getBBox(),c=1,u=1,f=0,d=0;s.transform&&s.transform.baseVal.consolidate()&&(c=s.transform.baseVal.consolidate().matrix.a,u=s.transform.baseVal.consolidate().matrix.d,f=s.transform.baseVal.consolidate().matrix.e,d=s.transform.baseVal.consolidate().matrix.f),this.sourceLeft=(c*l.x+f)*n/a,this.sourceTop=(u*l.y+d)*o/h,this.sourceWidth=l.width*c*(n/a),this.sourceHeight=l.height*u*(o/h),this._svgAttributesComputationCompleted=!0,this.onSVGAttributesComputedObservable.notifyObservers(this)}}},Object.defineProperty(t.prototype,"cellWidth",{get:function(){return this._cellWidth},set:function(e){this._cellWidth!==e&&(this._cellWidth=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"cellHeight",{get:function(){return this._cellHeight},set:function(e){this._cellHeight!==e&&(this._cellHeight=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"cellId",{get:function(){return this._cellId},set:function(e){this._cellId!==e&&(this._cellId=e,this._markAsDirty())},enumerable:!0,configurable:!0}),t.prototype.contains=function(t,i){if(!e.prototype.contains.call(this,t,i))return!1;if(!this._detectPointerOnOpaqueOnly||!this._workingCanvas)return!0;var r=this._workingCanvas.getContext("2d"),n=0|this._currentMeasure.width,o=0|this._currentMeasure.height;return r.getImageData(0,0,n,o).data[4*((t=t-this._currentMeasure.left|0)+(i=i-this._currentMeasure.top|0)*this._currentMeasure.width)+3]>0},t.prototype._getTypeName=function(){return"Image"},t.prototype.synchronizeSizeWithContent=function(){this._loaded&&(this.width=this._domImage.width+"px",this.height=this._domImage.height+"px")},t.prototype._processMeasures=function(i,r){if(this._loaded)switch(this._stretch){case t.STRETCH_NONE:case t.STRETCH_FILL:case t.STRETCH_UNIFORM:case t.STRETCH_NINE_PATCH:break;case t.STRETCH_EXTEND:this._autoScale&&this.synchronizeSizeWithContent(),this.parent&&this.parent.parent&&(this.parent.adaptWidthToChildren=!0,this.parent.adaptHeightToChildren=!0)}e.prototype._processMeasures.call(this,i,r)},t.prototype._prepareWorkingCanvasForOpaqueDetection=function(){if(this._detectPointerOnOpaqueOnly){this._workingCanvas||(this._workingCanvas=document.createElement("canvas"));var e=this._workingCanvas,t=this._currentMeasure.width,i=this._currentMeasure.height,r=e.getContext("2d");e.width=t,e.height=i,r.clearRect(0,0,t,i)}},t.prototype._drawImage=function(e,t,i,r,n,o,s,a,h){(e.drawImage(this._domImage,t,i,r,n,o,s,a,h),this._detectPointerOnOpaqueOnly)&&(e=this._workingCanvas.getContext("2d")).drawImage(this._domImage,t,i,r,n,o-this._currentMeasure.left,s-this._currentMeasure.top,a,h)},t.prototype._draw=function(e){var i,r,n,o;if(e.save(),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowColor=this.shadowColor,e.shadowBlur=this.shadowBlur,e.shadowOffsetX=this.shadowOffsetX,e.shadowOffsetY=this.shadowOffsetY),-1==this.cellId)i=this._sourceLeft,r=this._sourceTop,n=this._sourceWidth?this._sourceWidth:this._imageWidth,o=this._sourceHeight?this._sourceHeight:this._imageHeight;else{var s=this._domImage.naturalWidth/this.cellWidth,a=this.cellId/s>>0,h=this.cellId%s;i=this.cellWidth*h,r=this.cellHeight*a,n=this.cellWidth,o=this.cellHeight}if(this._prepareWorkingCanvasForOpaqueDetection(),this._applyStates(e),this._loaded)switch(this._stretch){case t.STRETCH_NONE:case t.STRETCH_FILL:this._drawImage(e,i,r,n,o,this._currentMeasure.left,this._currentMeasure.top,this._currentMeasure.width,this._currentMeasure.height);break;case t.STRETCH_UNIFORM:var l=this._currentMeasure.width/n,c=this._currentMeasure.height/o,u=Math.min(l,c),f=(this._currentMeasure.width-n*u)/2,d=(this._currentMeasure.height-o*u)/2;this._drawImage(e,i,r,n,o,this._currentMeasure.left+f,this._currentMeasure.top+d,n*u,o*u);break;case t.STRETCH_EXTEND:this._drawImage(e,i,r,n,o,this._currentMeasure.left,this._currentMeasure.top,this._currentMeasure.width,this._currentMeasure.height);break;case t.STRETCH_NINE_PATCH:this._renderNinePatch(e)}e.restore()},t.prototype._renderCornerPatch=function(e,t,i,r,n,o,s){this._drawImage(e,t,i,r,n,this._currentMeasure.left+o,this._currentMeasure.top+s,r,n)},t.prototype._renderNinePatch=function(e){var t=this._imageHeight,i=this._sliceLeft,r=this._sliceTop,n=this._imageHeight-this._sliceBottom,o=this._imageWidth-this._sliceRight,s=0,a=0;this._populateNinePatchSlicesFromImage&&(s=1,a=1,t-=2,i-=1,r-=1,n-=1,o-=1);var h=this._sliceRight-this._sliceLeft,l=this._currentMeasure.width-o-this.sliceLeft,c=this._currentMeasure.height-t+this._sliceBottom;this._renderCornerPatch(e,s,a,i,r,0,0),this._renderCornerPatch(e,s,this._sliceBottom,i,t-this._sliceBottom,0,c),this._renderCornerPatch(e,this._sliceRight,a,o,r,this._currentMeasure.width-o,0),this._renderCornerPatch(e,this._sliceRight,this._sliceBottom,o,t-this._sliceBottom,this._currentMeasure.width-o,c),this._drawImage(e,this._sliceLeft,this._sliceTop,h,this._sliceBottom-this._sliceTop,this._currentMeasure.left+i,this._currentMeasure.top+r,l,c-r),this._drawImage(e,s,this._sliceTop,i,this._sliceBottom-this._sliceTop,this._currentMeasure.left,this._currentMeasure.top+r,i,c-r),this._drawImage(e,this._sliceRight,this._sliceTop,i,this._sliceBottom-this._sliceTop,this._currentMeasure.left+this._currentMeasure.width-o,this._currentMeasure.top+r,i,c-r),this._drawImage(e,this._sliceLeft,a,h,r,this._currentMeasure.left+i,this._currentMeasure.top,l,r),this._drawImage(e,this._sliceLeft,this._sliceBottom,h,n,this._currentMeasure.left+i,this._currentMeasure.top+c,l,n)},t.prototype.dispose=function(){e.prototype.dispose.call(this),this.onImageLoadedObservable.clear(),this.onSVGAttributesComputedObservable.clear()},t.STRETCH_NONE=0,t.STRETCH_FILL=1,t.STRETCH_UNIFORM=2,t.STRETCH_EXTEND=3,t.STRETCH_NINE_PATCH=4,t}(h.a);o.a.RegisteredTypes["BABYLON.GUI.Image"]=d;var p=function(e){function t(t){var i=e.call(this,t)||this;i.name=t,i.delegatePickingToChildren=!1,i.thickness=1,i.isPointerBlocker=!0;var r=null;return i.pointerEnterAnimation=function(){r=i.alpha,i.alpha-=.1},i.pointerOutAnimation=function(){null!==r&&(i.alpha=r)},i.pointerDownAnimation=function(){i.scaleX-=.05,i.scaleY-=.05},i.pointerUpAnimation=function(){i.scaleX+=.05,i.scaleY+=.05},i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"image",{get:function(){return this._image},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"textBlock",{get:function(){return this._textBlock},enumerable:!0,configurable:!0}),t.prototype._getTypeName=function(){return"Button"},t.prototype._processPicking=function(t,i,r,n,o,s,a){if(!this._isEnabled||!this.isHitTestVisible||!this.isVisible||this.notRenderable)return!1;if(!e.prototype.contains.call(this,t,i))return!1;if(this.delegatePickingToChildren){for(var h=!1,l=this._children.length-1;l>=0;l--){var c=this._children[l];if(c.isEnabled&&c.isHitTestVisible&&c.isVisible&&!c.notRenderable&&c.contains(t,i)){h=!0;break}}if(!h)return!1}return this._processObservables(r,t,i,n,o,s,a),!0},t.prototype._onPointerEnter=function(t){return!!e.prototype._onPointerEnter.call(this,t)&&(this.pointerEnterAnimation&&this.pointerEnterAnimation(),!0)},t.prototype._onPointerOut=function(t,i){void 0===i&&(i=!1),this.pointerOutAnimation&&this.pointerOutAnimation(),e.prototype._onPointerOut.call(this,t,i)},t.prototype._onPointerDown=function(t,i,r,n){return!!e.prototype._onPointerDown.call(this,t,i,r,n)&&(this.pointerDownAnimation&&this.pointerDownAnimation(),!0)},t.prototype._onPointerUp=function(t,i,r,n,o){this.pointerUpAnimation&&this.pointerUpAnimation(),e.prototype._onPointerUp.call(this,t,i,r,n,o)},t.CreateImageButton=function(e,i,r){var n=new t(e),o=new u(e+"_button",i);o.textWrapping=!0,o.textHorizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_CENTER,o.paddingLeft="20%",n.addControl(o);var s=new d(e+"_icon",r);return s.width="20%",s.stretch=d.STRETCH_UNIFORM,s.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,n.addControl(s),n._image=s,n._textBlock=o,n},t.CreateImageOnlyButton=function(e,i){var r=new t(e),n=new d(e+"_icon",i);return n.stretch=d.STRETCH_FILL,n.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,r.addControl(n),r._image=n,r},t.CreateSimpleButton=function(e,i){var r=new t(e),n=new u(e+"_button",i);return n.textWrapping=!0,n.textHorizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_CENTER,r.addControl(n),r._textBlock=n,r},t.CreateImageWithCenterTextButton=function(e,i,r){var n=new t(e),o=new d(e+"_icon",r);o.stretch=d.STRETCH_FILL,n.addControl(o);var s=new u(e+"_button",i);return s.textWrapping=!0,s.textHorizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_CENTER,n.addControl(s),n._image=o,n._textBlock=s,n},t}(s);o.a.RegisteredTypes["BABYLON.GUI.Button"]=p;var _=function(e){function t(t){var i=e.call(this,t)||this;return i.name=t,i._isVertical=!0,i._manualWidth=!1,i._manualHeight=!1,i._doNotTrackManualChanges=!1,i.ignoreLayoutWarnings=!1,i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"isVertical",{get:function(){return this._isVertical},set:function(e){this._isVertical!==e&&(this._isVertical=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"width",{get:function(){return this._width.toString(this._host)},set:function(e){this._doNotTrackManualChanges||(this._manualWidth=!0),this._width.toString(this._host)!==e&&this._width.fromString(e)&&this._markAsDirty()},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"height",{get:function(){return this._height.toString(this._host)},set:function(e){this._doNotTrackManualChanges||(this._manualHeight=!0),this._height.toString(this._host)!==e&&this._height.fromString(e)&&this._markAsDirty()},enumerable:!0,configurable:!0}),t.prototype._getTypeName=function(){return"StackPanel"},t.prototype._preMeasure=function(t,i){for(var r=0,n=this._children;r0){if(this._isTextHighlightOn)return this.text=this._text.slice(0,this._startHighlightIndex)+this._text.slice(this._endHighlightIndex),this._isTextHighlightOn=!1,this._cursorOffset=this.text.length-this._startHighlightIndex,this._blinkIsEven=!1,void(i&&i.preventDefault());if(0===this._cursorOffset)this.text=this._text.substr(0,this._text.length-1);else(n=this._text.length-this._cursorOffset)>0&&(this.text=this._text.slice(0,n-1)+this._text.slice(n))}return void(i&&i.preventDefault());case 46:if(this._isTextHighlightOn){this.text=this._text.slice(0,this._startHighlightIndex)+this._text.slice(this._endHighlightIndex);for(var r=this._endHighlightIndex-this._startHighlightIndex;r>0&&this._cursorOffset>0;)this._cursorOffset--;return this._isTextHighlightOn=!1,this._cursorOffset=this.text.length-this._startHighlightIndex,void(i&&i.preventDefault())}if(this._text&&this._text.length>0&&this._cursorOffset>0){var n=this._text.length-this._cursorOffset;this.text=this._text.slice(0,n)+this._text.slice(n+1),this._cursorOffset--}return void(i&&i.preventDefault());case 13:return this._host.focusedControl=null,void(this._isTextHighlightOn=!1);case 35:return this._cursorOffset=0,this._blinkIsEven=!1,this._isTextHighlightOn=!1,void this._markAsDirty();case 36:return this._cursorOffset=this._text.length,this._blinkIsEven=!1,this._isTextHighlightOn=!1,void this._markAsDirty();case 37:if(this._cursorOffset++,this._cursorOffset>this._text.length&&(this._cursorOffset=this._text.length),i&&i.shiftKey){if(this._blinkIsEven=!1,i.ctrlKey||i.metaKey){if(!this._isTextHighlightOn){if(this._text.length===this._cursorOffset)return;this._endHighlightIndex=this._text.length-this._cursorOffset+1}return this._startHighlightIndex=0,this._cursorIndex=this._text.length-this._endHighlightIndex,this._cursorOffset=this._text.length,this._isTextHighlightOn=!0,void this._markAsDirty()}return this._isTextHighlightOn?-1===this._cursorIndex&&(this._cursorIndex=this._text.length-this._endHighlightIndex,this._cursorOffset=0===this._startHighlightIndex?this._text.length:this._text.length-this._startHighlightIndex+1):(this._isTextHighlightOn=!0,this._cursorIndex=this._cursorOffset>=this._text.length?this._text.length:this._cursorOffset-1),this._cursorIndexthis._cursorOffset?(this._endHighlightIndex=this._text.length-this._cursorOffset,this._startHighlightIndex=this._text.length-this._cursorIndex):this._isTextHighlightOn=!1,void this._markAsDirty()}return this._isTextHighlightOn&&(this._cursorOffset=this._text.length-this._startHighlightIndex,this._isTextHighlightOn=!1),i&&(i.ctrlKey||i.metaKey)&&(this._cursorOffset=this.text.length,i.preventDefault()),this._blinkIsEven=!1,this._isTextHighlightOn=!1,this._cursorIndex=-1,void this._markAsDirty();case 39:if(this._cursorOffset--,this._cursorOffset<0&&(this._cursorOffset=0),i&&i.shiftKey){if(this._blinkIsEven=!1,i.ctrlKey||i.metaKey){if(!this._isTextHighlightOn){if(0===this._cursorOffset)return;this._startHighlightIndex=this._text.length-this._cursorOffset-1}return this._endHighlightIndex=this._text.length,this._isTextHighlightOn=!0,this._cursorIndex=this._text.length-this._startHighlightIndex,this._cursorOffset=0,void this._markAsDirty()}return this._isTextHighlightOn?-1===this._cursorIndex&&(this._cursorIndex=this._text.length-this._startHighlightIndex,this._cursorOffset=this._text.length===this._endHighlightIndex?0:this._text.length-this._endHighlightIndex-1):(this._isTextHighlightOn=!0,this._cursorIndex=this._cursorOffset<=0?0:this._cursorOffset+1),this._cursorIndexthis._cursorOffset?(this._endHighlightIndex=this._text.length-this._cursorOffset,this._startHighlightIndex=this._text.length-this._cursorIndex):this._isTextHighlightOn=!1,void this._markAsDirty()}return this._isTextHighlightOn&&(this._cursorOffset=this._text.length-this._endHighlightIndex,this._isTextHighlightOn=!1),i&&(i.ctrlKey||i.metaKey)&&(this._cursorOffset=0,i.preventDefault()),this._blinkIsEven=!1,this._isTextHighlightOn=!1,this._cursorIndex=-1,void this._markAsDirty();case 222:i&&i.preventDefault(),this._cursorIndex=-1,this.deadKey=!0}if(t&&(-1===e||32===e||e>47&&e<64||e>64&&e<91||e>159&&e<193||e>218&&e<223||e>95&&e<112)&&(this._currentKey=t,this.onBeforeKeyAddObservable.notifyObservers(this),t=this._currentKey,this._addKey))if(this._isTextHighlightOn)this.text=this._text.slice(0,this._startHighlightIndex)+t+this._text.slice(this._endHighlightIndex),this._cursorOffset=this.text.length-(this._startHighlightIndex+1),this._isTextHighlightOn=!1,this._blinkIsEven=!1,this._markAsDirty();else if(0===this._cursorOffset)this.text+=t;else{var o=this._text.length-this._cursorOffset;this.text=this._text.slice(0,o)+t+this._text.slice(o)}}},t.prototype._updateValueFromCursorIndex=function(e){if(this._blinkIsEven=!1,-1===this._cursorIndex)this._cursorIndex=e;else if(this._cursorIndexthis._cursorOffset))return this._isTextHighlightOn=!1,void this._markAsDirty();this._endHighlightIndex=this._text.length-this._cursorOffset,this._startHighlightIndex=this._text.length-this._cursorIndex}this._isTextHighlightOn=!0,this._markAsDirty()},t.prototype._processDblClick=function(e){this._startHighlightIndex=this._text.length-this._cursorOffset,this._endHighlightIndex=this._startHighlightIndex;var t,i,r=/\w+/g;do{i=this._endHighlightIndex0&&-1!==this._text[this._startHighlightIndex-1].search(r)?--this._startHighlightIndex:0}while(t||i);this._cursorOffset=this.text.length-this._startHighlightIndex,this.onTextHighlightObservable.notifyObservers(this),this._isTextHighlightOn=!0,this._clickedCoordinate=null,this._blinkIsEven=!0,this._cursorIndex=-1,this._markAsDirty()},t.prototype._selectAllText=function(){this._blinkIsEven=!0,this._isTextHighlightOn=!0,this._startHighlightIndex=0,this._endHighlightIndex=this._text.length,this._cursorOffset=this._text.length,this._cursorIndex=-1,this._markAsDirty()},t.prototype.processKeyboard=function(e){this.processKey(e.keyCode,e.key,e),this.onKeyboardEventProcessedObservable.notifyObservers(e)},t.prototype._onCopyText=function(e){this._isTextHighlightOn=!1;try{e.clipboardData&&e.clipboardData.setData("text/plain",this._highlightedText)}catch(e){}this._host.clipboardData=this._highlightedText},t.prototype._onCutText=function(e){if(this._highlightedText){this.text=this._text.slice(0,this._startHighlightIndex)+this._text.slice(this._endHighlightIndex),this._isTextHighlightOn=!1,this._cursorOffset=this.text.length-this._startHighlightIndex;try{e.clipboardData&&e.clipboardData.setData("text/plain",this._highlightedText)}catch(e){}this._host.clipboardData=this._highlightedText,this._highlightedText=""}},t.prototype._onPasteText=function(e){var t="";t=e.clipboardData&&-1!==e.clipboardData.types.indexOf("text/plain")?e.clipboardData.getData("text/plain"):this._host.clipboardData;var i=this._text.length-this._cursorOffset;this.text=this._text.slice(0,i)+t+this._text.slice(i)},t.prototype._draw=function(e,t){var i=this;e.save(),this._applyStates(e),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowColor=this.shadowColor,e.shadowBlur=this.shadowBlur,e.shadowOffsetX=this.shadowOffsetX,e.shadowOffsetY=this.shadowOffsetY),this._isFocused?this._focusedBackground&&(e.fillStyle=this._isEnabled?this._focusedBackground:this._disabledColor,e.fillRect(this._currentMeasure.left,this._currentMeasure.top,this._currentMeasure.width,this._currentMeasure.height)):this._background&&(e.fillStyle=this._isEnabled?this._background:this._disabledColor,e.fillRect(this._currentMeasure.left,this._currentMeasure.top,this._currentMeasure.width,this._currentMeasure.height)),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowBlur=0,e.shadowOffsetX=0,e.shadowOffsetY=0),this._fontOffset||(this._fontOffset=h.a._GetFontOffset(e.font));var r=this._currentMeasure.left+this._margin.getValueInPixel(this._host,this._tempParentMeasure.width);this.color&&(e.fillStyle=this.color);var n=this._beforeRenderText(this._text);this._isFocused||this._text||!this._placeholderText||(n=this._placeholderText,this._placeholderColor&&(e.fillStyle=this._placeholderColor)),this._textWidth=e.measureText(n).width;var o=2*this._margin.getValueInPixel(this._host,this._tempParentMeasure.width);this._autoStretchWidth&&(this.width=Math.min(this._maxWidth.getValueInPixel(this._host,this._tempParentMeasure.width),this._textWidth+o)+"px");var s=this._fontOffset.ascent+(this._currentMeasure.height-this._fontOffset.height)/2,a=this._width.getValueInPixel(this._host,this._tempParentMeasure.width)-o;if(e.save(),e.beginPath(),e.rect(r,this._currentMeasure.top+(this._currentMeasure.height-this._fontOffset.height)/2,a+2,this._currentMeasure.height),e.clip(),this._isFocused&&this._textWidth>a){var l=r-this._textWidth+a;this._scrollLeft||(this._scrollLeft=l)}else this._scrollLeft=r;if(e.fillText(n,this._scrollLeft,this._currentMeasure.top+s),this._isFocused){if(this._clickedCoordinate){var c=this._scrollLeft+this._textWidth-this._clickedCoordinate,u=0;this._cursorOffset=0;var f=0;do{this._cursorOffset&&(f=Math.abs(c-u)),this._cursorOffset++,u=e.measureText(n.substr(n.length-this._cursorOffset,this._cursorOffset)).width}while(u=this._cursorOffset);Math.abs(c-u)>f&&this._cursorOffset--,this._blinkIsEven=!1,this._clickedCoordinate=null}if(!this._blinkIsEven){var d=this.text.substr(this._text.length-this._cursorOffset),p=e.measureText(d).width,_=this._scrollLeft+this._textWidth-p;_r+a&&(this._scrollLeft+=r+a-_,_=r+a,this._markAsDirty()),this._isTextHighlightOn||e.fillRect(_,this._currentMeasure.top+(this._currentMeasure.height-this._fontOffset.height)/2,2,this._fontOffset.height)}if(clearTimeout(this._blinkTimeout),this._blinkTimeout=setTimeout((function(){i._blinkIsEven=!i._blinkIsEven,i._markAsDirty()}),500),this._isTextHighlightOn){clearTimeout(this._blinkTimeout);var g=e.measureText(this.text.substring(this._startHighlightIndex)).width,m=this._scrollLeft+this._textWidth-g;this._highlightedText=this.text.substring(this._startHighlightIndex,this._endHighlightIndex);var b=e.measureText(this.text.substring(this._startHighlightIndex,this._endHighlightIndex)).width;m=this._rowDefinitions.length?null:this._rowDefinitions[e]},t.prototype.getColumnDefinition=function(e){return e<0||e>=this._columnDefinitions.length?null:this._columnDefinitions[e]},t.prototype.addRowDefinition=function(e,t){return void 0===t&&(t=!1),this._rowDefinitions.push(new c.a(e,t?c.a.UNITMODE_PIXEL:c.a.UNITMODE_PERCENTAGE)),this._markAsDirty(),this},t.prototype.addColumnDefinition=function(e,t){return void 0===t&&(t=!1),this._columnDefinitions.push(new c.a(e,t?c.a.UNITMODE_PIXEL:c.a.UNITMODE_PERCENTAGE)),this._markAsDirty(),this},t.prototype.setRowDefinition=function(e,t,i){if(void 0===i&&(i=!1),e<0||e>=this._rowDefinitions.length)return this;var r=this._rowDefinitions[e];return r&&r.isPixel===i&&r.internalValue===t||(this._rowDefinitions[e]=new c.a(t,i?c.a.UNITMODE_PIXEL:c.a.UNITMODE_PERCENTAGE),this._markAsDirty()),this},t.prototype.setColumnDefinition=function(e,t,i){if(void 0===i&&(i=!1),e<0||e>=this._columnDefinitions.length)return this;var r=this._columnDefinitions[e];return r&&r.isPixel===i&&r.internalValue===t||(this._columnDefinitions[e]=new c.a(t,i?c.a.UNITMODE_PIXEL:c.a.UNITMODE_PERCENTAGE),this._markAsDirty()),this},t.prototype.getChildrenAt=function(e,t){var i=this._cells[e+":"+t];return i?i.children:null},t.prototype.getChildCellInfo=function(e){return e._tag},t.prototype._removeCell=function(t,i){if(t){e.prototype.removeControl.call(this,t);for(var r=0,n=t.children;r=this._columnDefinitions.length)return this;for(var t=0;t=this._rowDefinitions.length)return this;for(var t=0;t=1-t._Epsilon&&(this._value.r=1),this._value.g>=1-t._Epsilon&&(this._value.g=1),this._value.b>=1-t._Epsilon&&(this._value.b=1),this.onValueChangedObservable.notifyObservers(this._value))},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"width",{get:function(){return this._width.toString(this._host)},set:function(e){this._width.toString(this._host)!==e&&this._width.fromString(e)&&(this._height.fromString(e),this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"height",{get:function(){return this._height.toString(this._host)},set:function(e){this._height.toString(this._host)!==e&&this._height.fromString(e)&&(this._width.fromString(e),this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"size",{get:function(){return this.width},set:function(e){this.width=e},enumerable:!0,configurable:!0}),t.prototype._getTypeName=function(){return"ColorPicker"},t.prototype._preMeasure=function(e,t){e.widtha||f150?.04:-.16*(e-50)/100+.2;var m=(d-h)/(e-h);o[_+3]=m1-g?255*(1-(m-(1-g))/g):255}}return r.putImageData(n,0,0),i},t.prototype._draw=function(e){e.save(),this._applyStates(e);var t=.5*Math.min(this._currentMeasure.width,this._currentMeasure.height),i=.2*t,r=this._currentMeasure.left,n=this._currentMeasure.top;this._colorWheelCanvas&&this._colorWheelCanvas.width==2*t||(this._colorWheelCanvas=this._createColorWheelCanvas(t,i)),this._updateSquareProps(),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowColor=this.shadowColor,e.shadowBlur=this.shadowBlur,e.shadowOffsetX=this.shadowOffsetX,e.shadowOffsetY=this.shadowOffsetY,e.fillRect(this._squareLeft,this._squareTop,this._squareSize,this._squareSize)),e.drawImage(this._colorWheelCanvas,r,n),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowBlur=0,e.shadowOffsetX=0,e.shadowOffsetY=0),this._drawGradientSquare(this._h,this._squareLeft,this._squareTop,this._squareSize,this._squareSize,e);var o=this._squareLeft+this._squareSize*this._s,s=this._squareTop+this._squareSize*(1-this._v);this._drawCircle(o,s,.04*t,e);var a=t-.5*i;o=r+t+Math.cos((this._h-180)*Math.PI/180)*a,s=n+t+Math.sin((this._h-180)*Math.PI/180)*a,this._drawCircle(o,s,.35*i,e),e.restore()},t.prototype._updateValueFromPointer=function(e,i){if(this._pointerStartedOnWheel){var r=.5*Math.min(this._currentMeasure.width,this._currentMeasure.height),n=r+this._currentMeasure.left,o=r+this._currentMeasure.top;this._h=180*Math.atan2(i-o,e-n)/Math.PI+180}else this._pointerStartedOnSquare&&(this._updateSquareProps(),this._s=(e-this._squareLeft)/this._squareSize,this._v=1-(i-this._squareTop)/this._squareSize,this._s=Math.min(this._s,1),this._s=Math.max(this._s,t._Epsilon),this._v=Math.min(this._v,1),this._v=Math.max(this._v,t._Epsilon));x.a.HSVtoRGBToRef(this._h,this._s,this._v,this._tmpColor),this.value=this._tmpColor},t.prototype._isPointOnSquare=function(e,t){this._updateSquareProps();var i=this._squareLeft,r=this._squareTop,n=this._squareSize;return e>=i&&e<=i+n&&t>=r&&t<=r+n},t.prototype._isPointOnWheel=function(e,t){var i=.5*Math.min(this._currentMeasure.width,this._currentMeasure.height),r=i-.2*i,n=e-(i+this._currentMeasure.left),o=t-(i+this._currentMeasure.top),s=n*n+o*o;return s<=i*i&&s>=r*r},t.prototype._onPointerDown=function(t,i,r,n){if(!e.prototype._onPointerDown.call(this,t,i,r,n))return!1;this._pointerIsDown=!0,this._pointerStartedOnSquare=!1,this._pointerStartedOnWheel=!1,this._invertTransformMatrix.transformCoordinates(i.x,i.y,this._transformedPosition);var o=this._transformedPosition.x,s=this._transformedPosition.y;return this._isPointOnSquare(o,s)?this._pointerStartedOnSquare=!0:this._isPointOnWheel(o,s)&&(this._pointerStartedOnWheel=!0),this._updateValueFromPointer(o,s),this._host._capturingControl[r]=this,this._lastPointerDownID=r,!0},t.prototype._onPointerMove=function(t,i,r){if(r==this._lastPointerDownID){this._invertTransformMatrix.transformCoordinates(i.x,i.y,this._transformedPosition);var n=this._transformedPosition.x,o=this._transformedPosition.y;this._pointerIsDown&&this._updateValueFromPointer(n,o),e.prototype._onPointerMove.call(this,t,i,r)}},t.prototype._onPointerUp=function(t,i,r,n,o){this._pointerIsDown=!1,delete this._host._capturingControl[r],e.prototype._onPointerUp.call(this,t,i,r,n,o)},t.ShowPickerDialogAsync=function(e,i){return new Promise((function(r,n){i.pickerWidth=i.pickerWidth||"640px",i.pickerHeight=i.pickerHeight||"400px",i.headerHeight=i.headerHeight||"35px",i.lastColor=i.lastColor||"#000000",i.swatchLimit=i.swatchLimit||20,i.numSwatchesPerLine=i.numSwatchesPerLine||10;var o,a,l,c,f,d,_,g,m,b,T,E,M,A,O,C,S,P,R,I=i.swatchLimit/i.numSwatchesPerLine,w=parseFloat(i.pickerWidth)/i.numSwatchesPerLine,D=Math.floor(.25*w),L=D*(i.numSwatchesPerLine+1),F=Math.floor((parseFloat(i.pickerWidth)-L)/i.numSwatchesPerLine),N=F*I+D*(I+1),B=(parseInt(i.pickerHeight)+N+Math.floor(.25*F)).toString()+"px",k="#c0c0c0",U="#535353",V="#414141",z="515151",j=x.a.FromHexString("#dddddd"),W=j.r+j.g+j.b,G=["R","G","B"],H="#454545",X="#f0f0f0",K=!1;function Y(e,t){R=t;var i=e.toHexString();if(S.background=i,b.name!=R&&(b.text=Math.floor(255*e.r).toString()),T.name!=R&&(T.text=Math.floor(255*e.g).toString()),E.name!=R&&(E.text=Math.floor(255*e.b).toString()),M.name!=R&&(M.text=e.r.toString()),A.name!=R&&(A.text=e.g.toString()),O.name!=R&&(O.text=e.b.toString()),C.name!=R){var r=i.split("#");C.text=r[1]}m.name!=R&&(m.value=e)}function q(e,t){var i=e.text;if(/[^0-9]/g.test(i))e.text=P;else if(""!=i&&(Math.floor(parseInt(i))<0?i="0":Math.floor(parseInt(i))>255?i="255":isNaN(parseInt(i))&&(i="0")),R==e.name&&(P=i),""!=i){i=parseInt(i).toString(),e.text=i;var r=x.a.FromHexString(S.background);R==e.name&&Y("r"==t?new x.a(parseInt(i)/255,r.g,r.b):"g"==t?new x.a(r.r,parseInt(i)/255,r.b):new x.a(r.r,r.g,parseInt(i)/255),e.name)}}function Z(e,t){var i=e.text;if(/[^0-9\.]/g.test(i))e.text=P;else{""!=i&&"."!=i&&0!=parseFloat(i)&&(parseFloat(i)<0?i="0.0":parseFloat(i)>1?i="1.0":isNaN(parseFloat(i))&&(i="0.0")),R==e.name&&(P=i),""!=i&&"."!=i&&0!=parseFloat(i)?(i=parseFloat(i).toString(),e.text=i):i="0.0";var r=x.a.FromHexString(S.background);R==e.name&&Y("r"==t?new x.a(parseFloat(i),r.g,r.b):"g"==t?new x.a(r.r,parseFloat(i),r.b):new x.a(r.r,r.g,parseFloat(i)),e.name)}}function Q(){if(i.savedColors&&i.savedColors[_]){if(K)var e="b";else e="";var t=p.CreateSimpleButton("Swatch_"+_,e);t.fontFamily="BabylonJSglyphs";var r=x.a.FromHexString(i.savedColors[_]),n=r.r+r.g+r.b;t.color=n>W?"#aaaaaa":"#ffffff",t.fontSize=Math.floor(.7*F),t.textBlock.verticalAlignment=h.a.VERTICAL_ALIGNMENT_CENTER,t.height=t.width=F.toString()+"px",t.background=i.savedColors[_],t.thickness=2;var o=_;return t.pointerDownAnimation=function(){t.thickness=4},t.pointerUpAnimation=function(){t.thickness=3},t.pointerEnterAnimation=function(){t.thickness=3},t.pointerOutAnimation=function(){t.thickness=2},t.onPointerClickObservable.add((function(){var e;K?(e=o,i.savedColors&&i.savedColors.splice(e,1),i.savedColors&&0==i.savedColors.length&&(ee(!1),K=!1),$("",Fe)):i.savedColors&&Y(x.a.FromHexString(i.savedColors[o]),t.name)})),t}return null}function J(e){if(void 0!==e&&(K=e),K){for(var t=0;th*i.numSwatchesPerLine)var l=i.numSwatchesPerLine;else l=i.savedColors.length-(h-1)*i.numSwatchesPerLine;for(var c=Math.min(Math.max(l,0),i.numSwatchesPerLine),u=0,f=1;ui.numSwatchesPerLine)){var d=Q();null!=d&&(g.addControl(d,a,f),f+=2,_++)}}i.savedColors.length>=i.swatchLimit?te(t,!0):te(t,!1)}}function ee(e){e?((l=p.CreateSimpleButton("butEdit","Edit")).width=c,l.height=f,l.left=Math.floor(.1*parseInt(c)).toString()+"px",l.top=(-1*parseFloat(l.left)).toString()+"px",l.verticalAlignment=h.a.VERTICAL_ALIGNMENT_BOTTOM,l.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,l.thickness=2,l.color=k,l.fontSize=a,l.background=U,l.onPointerEnterObservable.add((function(){l.background=V})),l.onPointerOutObservable.add((function(){l.background=U})),l.pointerDownAnimation=function(){l.background=z},l.pointerUpAnimation=function(){l.background=V},l.onPointerClickObservable.add((function(){K=!K,J()})),ge.addControl(l,1,0)):ge.removeControl(l)}function te(e,t){t?(e.color="#555555",e.background="#454545"):(e.color=k,e.background=U)}function ie(t){i.savedColors&&i.savedColors.length>0?r({savedColors:i.savedColors,pickedColor:t}):r({pickedColor:t}),e.removeControl(re)}var re=new y;if(re.name="Dialog Container",re.width=i.pickerWidth,i.savedColors){re.height=B;var ne=parseInt(i.pickerHeight)/parseInt(B);re.addRowDefinition(ne,!1),re.addRowDefinition(1-ne,!1)}else re.height=i.pickerHeight,re.addRowDefinition(1,!1);if(e.addControl(re),i.savedColors){(g=new y).name="Swatch Drawer",g.verticalAlignment=h.a.VERTICAL_ALIGNMENT_TOP,g.background=U,g.width=i.pickerWidth;var oe=i.savedColors.length/i.numSwatchesPerLine;if(0==oe)var se=0;else se=oe+1;g.height=(F*oe+se*D).toString()+"px",g.top=Math.floor(.25*F).toString()+"px";for(var ae=0;ae<2*Math.ceil(i.savedColors.length/i.numSwatchesPerLine)+1;ae++)ae%2!=0?g.addRowDefinition(F,!0):g.addRowDefinition(D,!0);for(ae=0;ae<2*i.numSwatchesPerLine+1;ae++)ae%2!=0?g.addColumnDefinition(F,!0):g.addColumnDefinition(D,!0);re.addControl(g,1,0)}var he=new y;he.name="Picker Panel",he.height=i.pickerHeight;var le=parseInt(i.headerHeight)/parseInt(i.pickerHeight),ce=[le,1-le];he.addRowDefinition(ce[0],!1),he.addRowDefinition(ce[1],!1),re.addControl(he,0,0);var ue=new s;ue.name="Dialogue Header Bar",ue.background="#cccccc",ue.thickness=0,he.addControl(ue,0,0);var fe=p.CreateSimpleButton("closeButton","a");fe.fontFamily="BabylonJSglyphs";var de=x.a.FromHexString(ue.background);o=new x.a(1-de.r,1-de.g,1-de.b),fe.color=o.toHexString(),fe.fontSize=Math.floor(.6*parseInt(i.headerHeight)),fe.textBlock.textVerticalAlignment=h.a.VERTICAL_ALIGNMENT_CENTER,fe.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_RIGHT,fe.height=fe.width=i.headerHeight,fe.background=ue.background,fe.thickness=0,fe.pointerDownAnimation=function(){},fe.pointerUpAnimation=function(){fe.background=ue.background},fe.pointerEnterAnimation=function(){fe.color=ue.background,fe.background="red"},fe.pointerOutAnimation=function(){fe.color=o.toHexString(),fe.background=ue.background},fe.onPointerClickObservable.add((function(){ie(Se.background)})),he.addControl(fe,0,0);var pe=new y;pe.name="Dialogue Body",pe.background=U;var _e=[.4375,.5625];pe.addRowDefinition(1,!1),pe.addColumnDefinition(_e[0],!1),pe.addColumnDefinition(_e[1],!1),he.addControl(pe,1,0);var ge=new y;ge.name="Picker Grid",ge.addRowDefinition(.85,!1),ge.addRowDefinition(.15,!1),pe.addControl(ge,0,0),(m=new t).name="GUI Color Picker",i.pickerHeighti.pickerHeight)var Oe=Ae;else Oe=Me;var Ce=new u;Ce.text="new",Ce.name="New Color Label",Ce.color=k,Ce.fontSize=Oe,xe.addControl(Ce,1,0),(S=new s).name="New Color Swatch",S.background=i.lastColor,S.thickness=0,Ee.addControl(S,0,0);var Se=p.CreateSimpleButton("currentSwatch","");Se.background=i.lastColor,Se.thickness=0,Se.onPointerClickObservable.add((function(){Y(x.a.FromHexString(Se.background),Se.name),J(!1)})),Se.pointerDownAnimation=function(){},Se.pointerUpAnimation=function(){},Se.pointerEnterAnimation=function(){},Se.pointerOutAnimation=function(){},Ee.addControl(Se,1,0);var Pe=new s;Pe.name="Swatch Outline",Pe.width=.67,Pe.thickness=2,Pe.color="#404040",Pe.isHitTestVisible=!1,xe.addControl(Pe,2,0);var Re=new u;Re.name="Current Color Label",Re.text="current",Re.color=k,Re.fontSize=Oe,xe.addControl(Re,3,0);var Ie=new y;Ie.name="Button Grid",Ie.height=.8;var we=1/3;Ie.addRowDefinition(we,!1),Ie.addRowDefinition(we,!1),Ie.addRowDefinition(we,!1),ve.addControl(Ie,0,1),c=Math.floor(parseInt(i.pickerWidth)*_e[1]*ye[1]*.67).toString()+"px",f=Math.floor(parseInt(i.pickerHeight)*ce[1]*be[0]*(parseFloat(Ie.height.toString())/100)*we*.7).toString()+"px",a=parseFloat(c)>parseFloat(f)?Math.floor(.45*parseFloat(f)):Math.floor(.11*parseFloat(c));var De=p.CreateSimpleButton("butOK","OK");De.width=c,De.height=f,De.verticalAlignment=h.a.VERTICAL_ALIGNMENT_CENTER,De.thickness=2,De.color=k,De.fontSize=a,De.background=U,De.onPointerEnterObservable.add((function(){De.background=V})),De.onPointerOutObservable.add((function(){De.background=U})),De.pointerDownAnimation=function(){De.background=z},De.pointerUpAnimation=function(){De.background=V},De.onPointerClickObservable.add((function(){J(!1),ie(S.background)})),Ie.addControl(De,0,0);var Le=p.CreateSimpleButton("butCancel","Cancel");if(Le.width=c,Le.height=f,Le.verticalAlignment=h.a.VERTICAL_ALIGNMENT_CENTER,Le.thickness=2,Le.color=k,Le.fontSize=a,Le.background=U,Le.onPointerEnterObservable.add((function(){Le.background=V})),Le.onPointerOutObservable.add((function(){Le.background=U})),Le.pointerDownAnimation=function(){Le.background=z},Le.pointerUpAnimation=function(){Le.background=V},Le.onPointerClickObservable.add((function(){J(!1),ie(Se.background)})),Ie.addControl(Le,1,0),i.savedColors){var Fe=p.CreateSimpleButton("butSave","Save");Fe.width=c,Fe.height=f,Fe.verticalAlignment=h.a.VERTICAL_ALIGNMENT_CENTER,Fe.thickness=2,Fe.fontSize=a,i.savedColors.length0&&ee(!0),Ie.addControl(Fe,2,0)}var Ne=new y;Ne.name="Dialog Lower Right",Ne.addRowDefinition(.02,!1),Ne.addRowDefinition(.63,!1),Ne.addRowDefinition(.21,!1),Ne.addRowDefinition(.14,!1),me.addControl(Ne,1,0),d=x.a.FromHexString(i.lastColor);var Be=new y;Be.name="RGB Values",Be.width=.82,Be.verticalAlignment=h.a.VERTICAL_ALIGNMENT_CENTER,Be.addRowDefinition(1/3,!1),Be.addRowDefinition(1/3,!1),Be.addRowDefinition(1/3,!1),Be.addColumnDefinition(.1,!1),Be.addColumnDefinition(.2,!1),Be.addColumnDefinition(.7,!1),Ne.addControl(Be,1,0);for(ae=0;ae6||t)&&R==C.name)C.text=P;else{if(C.text.length<6)for(var i=6-C.text.length,r=0;r0&&$("",Fe)}))},t._Epsilon=1e-6,t}(h.a);o.a.RegisteredTypes["BABYLON.GUI.ColorPicker"]=T;var E=function(e){function t(t){var i=e.call(this,t)||this;return i.name=t,i._thickness=1,i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"thickness",{get:function(){return this._thickness},set:function(e){this._thickness!==e&&(this._thickness=e,this._markAsDirty())},enumerable:!0,configurable:!0}),t.prototype._getTypeName=function(){return"Ellipse"},t.prototype._localDraw=function(e){e.save(),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowColor=this.shadowColor,e.shadowBlur=this.shadowBlur,e.shadowOffsetX=this.shadowOffsetX,e.shadowOffsetY=this.shadowOffsetY),h.a.drawEllipse(this._currentMeasure.left+this._currentMeasure.width/2,this._currentMeasure.top+this._currentMeasure.height/2,this._currentMeasure.width/2-this._thickness/2,this._currentMeasure.height/2-this._thickness/2,e),this._background&&(e.fillStyle=this._background,e.fill()),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowBlur=0,e.shadowOffsetX=0,e.shadowOffsetY=0),this._thickness&&(this.color&&(e.strokeStyle=this.color),e.lineWidth=this._thickness,e.stroke()),e.restore()},t.prototype._additionalProcessing=function(t,i){e.prototype._additionalProcessing.call(this,t,i),this._measureForChildren.width-=2*this._thickness,this._measureForChildren.height-=2*this._thickness,this._measureForChildren.left+=this._thickness,this._measureForChildren.top+=this._thickness},t.prototype._clipForChildren=function(e){h.a.drawEllipse(this._currentMeasure.left+this._currentMeasure.width/2,this._currentMeasure.top+this._currentMeasure.height/2,this._currentMeasure.width/2,this._currentMeasure.height/2,e),e.clip()},t}(n.a);o.a.RegisteredTypes["BABYLON.GUI.Ellipse"]=E;var M=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return Object(r.c)(t,e),t.prototype._beforeRenderText=function(e){for(var t="",i=0;i1?this.notRenderable=!0:this.notRenderable=!1}else f.b.Error("Cannot move a control to a vector3 if the control is not at root level")},t.prototype._moveToProjectedPosition=function(e,t){void 0===t&&(t=!1);var i=e.x+this._linkOffsetX.getValue(this._host)+"px",r=e.y+this._linkOffsetY.getValue(this._host)+"px";t?(this.x2=i,this.y2=r,this._x2.ignoreAdaptiveScaling=!0,this._y2.ignoreAdaptiveScaling=!0):(this.x1=i,this.y1=r,this._x1.ignoreAdaptiveScaling=!0,this._y1.ignoreAdaptiveScaling=!0)},t}(h.a);o.a.RegisteredTypes["BABYLON.GUI.Line"]=O;var C=i(43),S=function(){function e(e){this._multiLine=e,this._x=new c.a(0),this._y=new c.a(0),this._point=new A.d(0,0)}return Object.defineProperty(e.prototype,"x",{get:function(){return this._x.toString(this._multiLine._host)},set:function(e){this._x.toString(this._multiLine._host)!==e&&this._x.fromString(e)&&this._multiLine._markAsDirty()},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"y",{get:function(){return this._y.toString(this._multiLine._host)},set:function(e){this._y.toString(this._multiLine._host)!==e&&this._y.fromString(e)&&this._multiLine._markAsDirty()},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"control",{get:function(){return this._control},set:function(e){this._control!==e&&(this._control&&this._controlObserver&&(this._control.onDirtyObservable.remove(this._controlObserver),this._controlObserver=null),this._control=e,this._control&&(this._controlObserver=this._control.onDirtyObservable.add(this._multiLine.onPointUpdate)),this._multiLine._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"mesh",{get:function(){return this._mesh},set:function(e){this._mesh!==e&&(this._mesh&&this._meshObserver&&this._mesh.getScene().onAfterCameraRenderObservable.remove(this._meshObserver),this._mesh=e,this._mesh&&(this._meshObserver=this._mesh.getScene().onAfterCameraRenderObservable.add(this._multiLine.onPointUpdate)),this._multiLine._markAsDirty())},enumerable:!0,configurable:!0}),e.prototype.resetLinks=function(){this.control=null,this.mesh=null},e.prototype.translate=function(){return this._point=this._translatePoint(),this._point},e.prototype._translatePoint=function(){if(null!=this._mesh)return this._multiLine._host.getProjectedPosition(this._mesh.getBoundingInfo().boundingSphere.center,this._mesh.getWorldMatrix());if(null!=this._control)return new A.d(this._control.centerX,this._control.centerY);var e=this._multiLine._host,t=this._x.getValueInPixel(e,Number(e._canvas.width)),i=this._y.getValueInPixel(e,Number(e._canvas.height));return new A.d(t,i)},e.prototype.dispose=function(){this.resetLinks()},e}(),P=function(e){function t(t){var i=e.call(this,t)||this;return i.name=t,i._lineWidth=1,i.onPointUpdate=function(){i._markAsDirty()},i._automaticSize=!0,i.isHitTestVisible=!1,i._horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,i._verticalAlignment=h.a.VERTICAL_ALIGNMENT_TOP,i._dash=[],i._points=[],i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"dash",{get:function(){return this._dash},set:function(e){this._dash!==e&&(this._dash=e,this._markAsDirty())},enumerable:!0,configurable:!0}),t.prototype.getAt=function(e){return this._points[e]||(this._points[e]=new S(this)),this._points[e]},t.prototype.add=function(){for(var e=this,t=[],i=0;i0;)this.remove(this._points.length-1)},t.prototype.resetLinks=function(){this._points.forEach((function(e){null!=e&&e.resetLinks()}))},Object.defineProperty(t.prototype,"lineWidth",{get:function(){return this._lineWidth},set:function(e){this._lineWidth!==e&&(this._lineWidth=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"horizontalAlignment",{set:function(e){},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"verticalAlignment",{set:function(e){},enumerable:!0,configurable:!0}),t.prototype._getTypeName=function(){return"MultiLine"},t.prototype._draw=function(e,t){e.save(),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowColor=this.shadowColor,e.shadowBlur=this.shadowBlur,e.shadowOffsetX=this.shadowOffsetX,e.shadowOffsetY=this.shadowOffsetY),this._applyStates(e),e.strokeStyle=this.color,e.lineWidth=this._lineWidth,e.setLineDash(this._dash),e.beginPath();var i=!0;this._points.forEach((function(t){t&&(i?(e.moveTo(t._point.x,t._point.y),i=!1):e.lineTo(t._point.x,t._point.y))})),e.stroke(),e.restore()},t.prototype._additionalProcessing=function(e,t){var i=this;this._minX=null,this._minY=null,this._maxX=null,this._maxY=null,this._points.forEach((function(e,t){e&&(e.translate(),(null==i._minX||e._point.xi._maxX)&&(i._maxX=e._point.x),(null==i._maxY||e._point.y>i._maxY)&&(i._maxY=e._point.y))})),null==this._minX&&(this._minX=0),null==this._minY&&(this._minY=0),null==this._maxX&&(this._maxX=0),null==this._maxY&&(this._maxY=0)},t.prototype._measure=function(){null!=this._minX&&null!=this._maxX&&null!=this._minY&&null!=this._maxY&&(this._currentMeasure.width=Math.abs(this._maxX-this._minX)+this._lineWidth,this._currentMeasure.height=Math.abs(this._maxY-this._minY)+this._lineWidth)},t.prototype._computeAlignment=function(e,t){null!=this._minX&&null!=this._minY&&(this._currentMeasure.left=this._minX-this._lineWidth/2,this._currentMeasure.top=this._minY-this._lineWidth/2)},t.prototype.dispose=function(){this.reset(),e.prototype.dispose.call(this)},t}(h.a);o.a.RegisteredTypes["BABYLON.GUI.MultiLine"]=P;var R=function(e){function t(t){var i=e.call(this,t)||this;return i.name=t,i._isChecked=!1,i._background="black",i._checkSizeRatio=.8,i._thickness=1,i.group="",i.onIsCheckedChangedObservable=new l.a,i.isPointerBlocker=!0,i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"thickness",{get:function(){return this._thickness},set:function(e){this._thickness!==e&&(this._thickness=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"checkSizeRatio",{get:function(){return this._checkSizeRatio},set:function(e){e=Math.max(Math.min(1,e),0),this._checkSizeRatio!==e&&(this._checkSizeRatio=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"background",{get:function(){return this._background},set:function(e){this._background!==e&&(this._background=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"isChecked",{get:function(){return this._isChecked},set:function(e){var t=this;this._isChecked!==e&&(this._isChecked=e,this._markAsDirty(),this.onIsCheckedChangedObservable.notifyObservers(e),this._isChecked&&this._host&&this._host.executeOnAllControls((function(e){if(e!==t&&void 0!==e.group){var i=e;i.group===t.group&&(i.isChecked=!1)}})))},enumerable:!0,configurable:!0}),t.prototype._getTypeName=function(){return"RadioButton"},t.prototype._draw=function(e){e.save(),this._applyStates(e);var t=this._currentMeasure.width-this._thickness,i=this._currentMeasure.height-this._thickness;if((this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowColor=this.shadowColor,e.shadowBlur=this.shadowBlur,e.shadowOffsetX=this.shadowOffsetX,e.shadowOffsetY=this.shadowOffsetY),h.a.drawEllipse(this._currentMeasure.left+this._currentMeasure.width/2,this._currentMeasure.top+this._currentMeasure.height/2,this._currentMeasure.width/2-this._thickness/2,this._currentMeasure.height/2-this._thickness/2,e),e.fillStyle=this._isEnabled?this._background:this._disabledColor,e.fill(),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowBlur=0,e.shadowOffsetX=0,e.shadowOffsetY=0),e.strokeStyle=this.color,e.lineWidth=this._thickness,e.stroke(),this._isChecked){e.fillStyle=this._isEnabled?this.color:this._disabledColor;var r=t*this._checkSizeRatio,n=i*this._checkSizeRatio;h.a.drawEllipse(this._currentMeasure.left+this._currentMeasure.width/2,this._currentMeasure.top+this._currentMeasure.height/2,r/2-this._thickness/2,n/2-this._thickness/2,e),e.fill()}e.restore()},t.prototype._onPointerDown=function(t,i,r,n){return!!e.prototype._onPointerDown.call(this,t,i,r,n)&&(this.isChecked||(this.isChecked=!0),!0)},t.AddRadioButtonWithHeader=function(e,i,r,n){var o=new _;o.isVertical=!1,o.height="30px";var s=new t;s.width="20px",s.height="20px",s.isChecked=r,s.color="green",s.group=i,s.onIsCheckedChangedObservable.add((function(e){return n(s,e)})),o.addControl(s);var a=new u;return a.text=e,a.width="180px",a.paddingLeft="5px",a.textHorizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,a.color="white",o.addControl(a),o},t}(h.a);o.a.RegisteredTypes["BABYLON.GUI.RadioButton"]=R;var I=function(e){function t(t){var i=e.call(this,t)||this;return i.name=t,i._thumbWidth=new c.a(20,c.a.UNITMODE_PIXEL,!1),i._minimum=0,i._maximum=100,i._value=50,i._isVertical=!1,i._barOffset=new c.a(5,c.a.UNITMODE_PIXEL,!1),i._isThumbClamped=!1,i._displayThumb=!0,i._step=0,i._lastPointerDownID=-1,i._effectiveBarOffset=0,i.onValueChangedObservable=new l.a,i._pointerIsDown=!1,i.isPointerBlocker=!0,i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"displayThumb",{get:function(){return this._displayThumb},set:function(e){this._displayThumb!==e&&(this._displayThumb=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"step",{get:function(){return this._step},set:function(e){this._step!==e&&(this._step=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"barOffset",{get:function(){return this._barOffset.toString(this._host)},set:function(e){this._barOffset.toString(this._host)!==e&&this._barOffset.fromString(e)&&this._markAsDirty()},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"barOffsetInPixels",{get:function(){return this._barOffset.getValueInPixel(this._host,this._cachedParentMeasure.width)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"thumbWidth",{get:function(){return this._thumbWidth.toString(this._host)},set:function(e){this._thumbWidth.toString(this._host)!==e&&this._thumbWidth.fromString(e)&&this._markAsDirty()},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"thumbWidthInPixels",{get:function(){return this._thumbWidth.getValueInPixel(this._host,this._cachedParentMeasure.width)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"minimum",{get:function(){return this._minimum},set:function(e){this._minimum!==e&&(this._minimum=e,this._markAsDirty(),this.value=Math.max(Math.min(this.value,this._maximum),this._minimum))},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"maximum",{get:function(){return this._maximum},set:function(e){this._maximum!==e&&(this._maximum=e,this._markAsDirty(),this.value=Math.max(Math.min(this.value,this._maximum),this._minimum))},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"value",{get:function(){return this._value},set:function(e){e=Math.max(Math.min(e,this._maximum),this._minimum),this._value!==e&&(this._value=e,this._markAsDirty(),this.onValueChangedObservable.notifyObservers(this._value))},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"isVertical",{get:function(){return this._isVertical},set:function(e){this._isVertical!==e&&(this._isVertical=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"isThumbClamped",{get:function(){return this._isThumbClamped},set:function(e){this._isThumbClamped!==e&&(this._isThumbClamped=e,this._markAsDirty())},enumerable:!0,configurable:!0}),t.prototype._getTypeName=function(){return"BaseSlider"},t.prototype._getThumbPosition=function(){return this.isVertical?(this.maximum-this.value)/(this.maximum-this.minimum)*this._backgroundBoxLength:(this.value-this.minimum)/(this.maximum-this.minimum)*this._backgroundBoxLength},t.prototype._getThumbThickness=function(e){var t=0;switch(e){case"circle":t=this._thumbWidth.isPixel?Math.max(this._thumbWidth.getValue(this._host),this._backgroundBoxThickness):this._backgroundBoxThickness*this._thumbWidth.getValue(this._host);break;case"rectangle":t=this._thumbWidth.isPixel?Math.min(this._thumbWidth.getValue(this._host),this._backgroundBoxThickness):this._backgroundBoxThickness*this._thumbWidth.getValue(this._host)}return t},t.prototype._prepareRenderingData=function(e){this._effectiveBarOffset=0,this._renderLeft=this._currentMeasure.left,this._renderTop=this._currentMeasure.top,this._renderWidth=this._currentMeasure.width,this._renderHeight=this._currentMeasure.height,this._backgroundBoxLength=Math.max(this._currentMeasure.width,this._currentMeasure.height),this._backgroundBoxThickness=Math.min(this._currentMeasure.width,this._currentMeasure.height),this._effectiveThumbThickness=this._getThumbThickness(e),this.displayThumb&&(this._backgroundBoxLength-=this._effectiveThumbThickness),this.isVertical&&this._currentMeasure.height=this._selectors.length))return this._selectors[e]},e.prototype.removeSelector=function(e){e<0||e>=this._selectors.length||(this._groupPanel.removeControl(this._selectors[e]),this._selectors.splice(e,1))},e}(),L=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return Object(r.c)(t,e),t.prototype.addCheckbox=function(e,t,i){void 0===t&&(t=function(e){}),void 0===i&&(i=!1);i=i||!1;var r=new g;r.width="20px",r.height="20px",r.color="#364249",r.background="#CCCCCC",r.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,r.onIsCheckedChangedObservable.add((function(e){t(e)}));var n=h.a.AddHeader(r,e,"200px",{isHorizontal:!0,controlFirst:!0});n.height="30px",n.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,n.left="4px",this.groupPanel.addControl(n),this.selectors.push(n),r.isChecked=i,this.groupPanel.parent&&this.groupPanel.parent.parent&&(r.color=this.groupPanel.parent.parent.buttonColor,r.background=this.groupPanel.parent.parent.buttonBackground)},t.prototype._setSelectorLabel=function(e,t){this.selectors[e].children[1].text=t},t.prototype._setSelectorLabelColor=function(e,t){this.selectors[e].children[1].color=t},t.prototype._setSelectorButtonColor=function(e,t){this.selectors[e].children[0].color=t},t.prototype._setSelectorButtonBackground=function(e,t){this.selectors[e].children[0].background=t},t}(D),F=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t._selectNb=0,t}return Object(r.c)(t,e),t.prototype.addRadio=function(e,t,i){void 0===t&&(t=function(e){}),void 0===i&&(i=!1);var r=this._selectNb++,n=new R;n.name=e,n.width="20px",n.height="20px",n.color="#364249",n.background="#CCCCCC",n.group=this.name,n.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,n.onIsCheckedChangedObservable.add((function(e){e&&t(r)}));var o=h.a.AddHeader(n,e,"200px",{isHorizontal:!0,controlFirst:!0});o.height="30px",o.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,o.left="4px",this.groupPanel.addControl(o),this.selectors.push(o),n.isChecked=i,this.groupPanel.parent&&this.groupPanel.parent.parent&&(n.color=this.groupPanel.parent.parent.buttonColor,n.background=this.groupPanel.parent.parent.buttonBackground)},t.prototype._setSelectorLabel=function(e,t){this.selectors[e].children[1].text=t},t.prototype._setSelectorLabelColor=function(e,t){this.selectors[e].children[1].color=t},t.prototype._setSelectorButtonColor=function(e,t){this.selectors[e].children[0].color=t},t.prototype._setSelectorButtonBackground=function(e,t){this.selectors[e].children[0].background=t},t}(D),N=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return Object(r.c)(t,e),t.prototype.addSlider=function(e,t,i,r,n,o,s){void 0===t&&(t=function(e){}),void 0===i&&(i="Units"),void 0===r&&(r=0),void 0===n&&(n=0),void 0===o&&(o=0),void 0===s&&(s=function(e){return 0|e});var a=new w;a.name=i,a.value=o,a.minimum=r,a.maximum=n,a.width=.9,a.height="20px",a.color="#364249",a.background="#CCCCCC",a.borderColor="black",a.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,a.left="4px",a.paddingBottom="4px",a.onValueChangedObservable.add((function(e){a.parent.children[0].text=a.parent.children[0].name+": "+s(e)+" "+a.name,t(e)}));var l=h.a.AddHeader(a,e+": "+s(o)+" "+i,"30px",{isHorizontal:!1,controlFirst:!1});l.height="60px",l.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,l.left="4px",l.children[0].name=e,this.groupPanel.addControl(l),this.selectors.push(l),this.groupPanel.parent&&this.groupPanel.parent.parent&&(a.color=this.groupPanel.parent.parent.buttonColor,a.background=this.groupPanel.parent.parent.buttonBackground)},t.prototype._setSelectorLabel=function(e,t){this.selectors[e].children[0].name=t,this.selectors[e].children[0].text=t+": "+this.selectors[e].children[1].value+" "+this.selectors[e].children[1].name},t.prototype._setSelectorLabelColor=function(e,t){this.selectors[e].children[0].color=t},t.prototype._setSelectorButtonColor=function(e,t){this.selectors[e].children[1].color=t},t.prototype._setSelectorButtonBackground=function(e,t){this.selectors[e].children[1].background=t},t}(D),B=function(e){function t(t,i){void 0===i&&(i=[]);var r=e.call(this,t)||this;if(r.name=t,r.groups=i,r._buttonColor="#364249",r._buttonBackground="#CCCCCC",r._headerColor="black",r._barColor="white",r._barHeight="2px",r._spacerHeight="20px",r._bars=new Array,r._groups=i,r.thickness=2,r._panel=new _,r._panel.verticalAlignment=h.a.VERTICAL_ALIGNMENT_TOP,r._panel.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,r._panel.top=5,r._panel.left=5,r._panel.width=.95,i.length>0){for(var n=0;n0&&this._addSpacer(),this._panel.addControl(e.groupPanel),this._groups.push(e),e.groupPanel.children[0].color=this._headerColor;for(var t=0;t=this._groups.length)){var t=this._groups[e];this._panel.removeControl(t.groupPanel),this._groups.splice(e,1),e=this._groups.length||(this._groups[t].groupPanel.children[0].text=e)},t.prototype.relabel=function(e,t,i){if(!(t<0||t>=this._groups.length)){var r=this._groups[t];i<0||i>=r.selectors.length||r._setSelectorLabel(i,e)}},t.prototype.removeFromGroupSelector=function(e,t){if(!(e<0||e>=this._groups.length)){var i=this._groups[e];t<0||t>=i.selectors.length||i.removeSelector(t)}},t.prototype.addToGroupCheckbox=function(e,t,i,r){(void 0===i&&(i=function(){}),void 0===r&&(r=!1),e<0||e>=this._groups.length)||this._groups[e].addCheckbox(t,i,r)},t.prototype.addToGroupRadio=function(e,t,i,r){(void 0===i&&(i=function(){}),void 0===r&&(r=!1),e<0||e>=this._groups.length)||this._groups[e].addRadio(t,i,r)},t.prototype.addToGroupSlider=function(e,t,i,r,n,o,s,a){(void 0===i&&(i=function(){}),void 0===r&&(r="Units"),void 0===n&&(n=0),void 0===o&&(o=0),void 0===s&&(s=0),void 0===a&&(a=function(e){return 0|e}),e<0||e>=this._groups.length)||this._groups[e].addSlider(t,i,r,n,o,s,a)},t}(s),k=i(29),U=function(e){function t(t){var i=e.call(this,t)||this;return i._freezeControls=!1,i._bucketWidth=0,i._bucketHeight=0,i._buckets={},i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"freezeControls",{get:function(){return this._freezeControls},set:function(e){if(this._freezeControls!==e){this._freezeControls=!1;var t=this.host.getSize(),i=t.width,r=t.height,n=this.host.getContext(),o=new k.a(0,0,i,r);this.host._numLayoutCalls=0,this.host._rootContainer._layout(o,n),e&&(this._updateMeasures(),this._useBuckets()&&this._makeBuckets()),this._freezeControls=e,this.host.markAsDirty()}},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"bucketWidth",{get:function(){return this._bucketWidth},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"bucketHeight",{get:function(){return this._bucketHeight},enumerable:!0,configurable:!0}),t.prototype.setBucketSizes=function(e,t){this._bucketWidth=e,this._bucketHeight=t,this._useBuckets()?this._freezeControls&&this._makeBuckets():this._buckets={}},t.prototype._useBuckets=function(){return this._bucketWidth>0&&this._bucketHeight>0},t.prototype._makeBuckets=function(){this._buckets={},this._bucketLen=Math.ceil(this.widthInPixels/this._bucketWidth),this._dispatchInBuckets(this._children)},t.prototype._dispatchInBuckets=function(e){for(var t=0;t0&&this._dispatchInBuckets(i._children)}},t.prototype._updateMeasures=function(){var e=0|this.leftInPixels,t=0|this.topInPixels;this._measureForChildren.left-=e,this._measureForChildren.top-=t,this._currentMeasure.left-=e,this._currentMeasure.top-=t,this._updateChildrenMeasures(this._children,e,t)},t.prototype._updateChildrenMeasures=function(e,t,i){for(var r=0;r0&&this._updateChildrenMeasures(o._children,t,i)}},t.prototype._getTypeName=function(){return"ScrollViewerWindow"},t.prototype._additionalProcessing=function(t,i){e.prototype._additionalProcessing.call(this,t,i),this._parentMeasure=t,this._measureForChildren.left=this._currentMeasure.left,this._measureForChildren.top=this._currentMeasure.top,this._measureForChildren.width=t.width,this._measureForChildren.height=t.height},t.prototype._layout=function(t,i){return this._freezeControls?(this.invalidateRect(),!1):e.prototype._layout.call(this,t,i)},t.prototype._scrollChildren=function(e,t,i){for(var r=0;r0&&this._scrollChildren(o._children,t,i)}},t.prototype._scrollChildrenWithBuckets=function(e,t,i,r){for(var n=Math.max(0,Math.floor(-e/this._bucketWidth)),o=Math.floor((-e+this._parentMeasure.width-1)/this._bucketWidth),s=Math.max(0,Math.floor(-t/this._bucketHeight)),a=Math.floor((-t+this._parentMeasure.height-1)/this._bucketHeight);s<=a;){for(var h=n;h<=o;++h){var l=s*this._bucketLen+h,c=this._buckets[l];if(c)for(var u=0;uthis._tempMeasure.left+this._tempMeasure.width||tthis._tempMeasure.top+this._tempMeasure.height)&&(this.isVertical?this.value=this.minimum+(1-(t-this._currentMeasure.top)/this._currentMeasure.height)*(this.maximum-this.minimum):this.value=this.minimum+(e-this._currentMeasure.left)/this._currentMeasure.width*(this.maximum-this.minimum)));var i=0;i=this.isVertical?-(t-this._originY)/(this._currentMeasure.height-this._effectiveThumbThickness):(e-this._originX)/(this._currentMeasure.width-this._effectiveThumbThickness),this.value+=i*(this.maximum-this.minimum),this._originX=e,this._originY=t},t.prototype._onPointerDown=function(t,i,r,n){return this._first=!0,e.prototype._onPointerDown.call(this,t,i,r,n)},t}(I),z=function(e){function t(t){var i=e.call(this,t)||this;return i.name=t,i._thumbLength=.5,i._thumbHeight=1,i._barImageHeight=1,i._tempMeasure=new k.a(0,0,0,0),i.num90RotationInVerticalMode=1,i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"backgroundImage",{get:function(){return this._backgroundBaseImage},set:function(e){var t=this;this._backgroundBaseImage!==e&&(this._backgroundBaseImage=e,this.isVertical&&0!==this.num90RotationInVerticalMode?e.isLoaded?(this._backgroundImage=e._rotate90(this.num90RotationInVerticalMode,!0),this._markAsDirty()):e.onImageLoadedObservable.addOnce((function(){var i=e._rotate90(t.num90RotationInVerticalMode,!0);t._backgroundImage=i,i.isLoaded||i.onImageLoadedObservable.addOnce((function(){t._markAsDirty()})),t._markAsDirty()})):(this._backgroundImage=e,e&&!e.isLoaded&&e.onImageLoadedObservable.addOnce((function(){t._markAsDirty()})),this._markAsDirty()))},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"thumbImage",{get:function(){return this._thumbBaseImage},set:function(e){var t=this;this._thumbBaseImage!==e&&(this._thumbBaseImage=e,this.isVertical&&0!==this.num90RotationInVerticalMode?e.isLoaded?(this._thumbImage=e._rotate90(-this.num90RotationInVerticalMode,!0),this._markAsDirty()):e.onImageLoadedObservable.addOnce((function(){var i=e._rotate90(-t.num90RotationInVerticalMode,!0);t._thumbImage=i,i.isLoaded||i.onImageLoadedObservable.addOnce((function(){t._markAsDirty()})),t._markAsDirty()})):(this._thumbImage=e,e&&!e.isLoaded&&e.onImageLoadedObservable.addOnce((function(){t._markAsDirty()})),this._markAsDirty()))},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"thumbLength",{get:function(){return this._thumbLength},set:function(e){this._thumbLength!==e&&(this._thumbLength=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"thumbHeight",{get:function(){return this._thumbHeight},set:function(e){this._thumbLength!==e&&(this._thumbHeight=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"barImageHeight",{get:function(){return this._barImageHeight},set:function(e){this._barImageHeight!==e&&(this._barImageHeight=e,this._markAsDirty())},enumerable:!0,configurable:!0}),t.prototype._getTypeName=function(){return"ImageScrollBar"},t.prototype._getThumbThickness=function(){return this._thumbWidth.isPixel?this._thumbWidth.getValue(this._host):this._backgroundBoxThickness*this._thumbWidth.getValue(this._host)},t.prototype._draw=function(e){e.save(),this._applyStates(e),this._prepareRenderingData("rectangle");var t=this._getThumbPosition(),i=this._renderLeft,r=this._renderTop,n=this._renderWidth,o=this._renderHeight;this._backgroundImage&&(this._tempMeasure.copyFromFloats(i,r,n,o),this.isVertical?(this._tempMeasure.copyFromFloats(i+n*(1-this._barImageHeight)*.5,this._currentMeasure.top,n*this._barImageHeight,o),this._tempMeasure.height+=this._effectiveThumbThickness,this._backgroundImage._currentMeasure.copyFrom(this._tempMeasure)):(this._tempMeasure.copyFromFloats(this._currentMeasure.left,r+o*(1-this._barImageHeight)*.5,n,o*this._barImageHeight),this._tempMeasure.width+=this._effectiveThumbThickness,this._backgroundImage._currentMeasure.copyFrom(this._tempMeasure)),this._backgroundImage._draw(e)),this.isVertical?this._tempMeasure.copyFromFloats(i-this._effectiveBarOffset+this._currentMeasure.width*(1-this._thumbHeight)*.5,this._currentMeasure.top+t,this._currentMeasure.width*this._thumbHeight,this._effectiveThumbThickness):this._tempMeasure.copyFromFloats(this._currentMeasure.left+t,this._currentMeasure.top+this._currentMeasure.height*(1-this._thumbHeight)*.5,this._effectiveThumbThickness,this._currentMeasure.height*this._thumbHeight),this._thumbImage&&(this._thumbImage._currentMeasure.copyFrom(this._tempMeasure),this._thumbImage._draw(e)),e.restore()},t.prototype._updateValueFromPointer=function(e,t){0!=this.rotation&&(this._invertTransformMatrix.transformCoordinates(e,t,this._transformedPosition),e=this._transformedPosition.x,t=this._transformedPosition.y),this._first&&(this._first=!1,this._originX=e,this._originY=t,(ethis._tempMeasure.left+this._tempMeasure.width||tthis._tempMeasure.top+this._tempMeasure.height)&&(this.isVertical?this.value=this.minimum+(1-(t-this._currentMeasure.top)/this._currentMeasure.height)*(this.maximum-this.minimum):this.value=this.minimum+(e-this._currentMeasure.left)/this._currentMeasure.width*(this.maximum-this.minimum)));var i=0;i=this.isVertical?-(t-this._originY)/(this._currentMeasure.height-this._effectiveThumbThickness):(e-this._originX)/(this._currentMeasure.width-this._effectiveThumbThickness),this.value+=i*(this.maximum-this.minimum),this._originX=e,this._originY=t},t.prototype._onPointerDown=function(t,i,r,n){return this._first=!0,e.prototype._onPointerDown.call(this,t,i,r,n)},t}(I),j=function(e){function t(t,i){var r=e.call(this,t)||this;return r._barSize=20,r._pointerIsOver=!1,r._wheelPrecision=.05,r._thumbLength=.5,r._thumbHeight=1,r._barImageHeight=1,r._horizontalBarImageHeight=1,r._verticalBarImageHeight=1,r._forceHorizontalBar=!1,r._forceVerticalBar=!1,r._useImageBar=i||!1,r.onDirtyObservable.add((function(){r._horizontalBarSpace.color=r.color,r._verticalBarSpace.color=r.color,r._dragSpace.color=r.color})),r.onPointerEnterObservable.add((function(){r._pointerIsOver=!0})),r.onPointerOutObservable.add((function(){r._pointerIsOver=!1})),r._grid=new y,r._useImageBar?(r._horizontalBar=new z,r._verticalBar=new z):(r._horizontalBar=new V,r._verticalBar=new V),r._window=new U("scrollViewer_window"),r._window.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,r._window.verticalAlignment=h.a.VERTICAL_ALIGNMENT_TOP,r._grid.addColumnDefinition(1),r._grid.addColumnDefinition(0,!0),r._grid.addRowDefinition(1),r._grid.addRowDefinition(0,!0),e.prototype.addControl.call(r,r._grid),r._grid.addControl(r._window,0,0),r._verticalBarSpace=new s,r._verticalBarSpace.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,r._verticalBarSpace.verticalAlignment=h.a.VERTICAL_ALIGNMENT_TOP,r._verticalBarSpace.thickness=1,r._grid.addControl(r._verticalBarSpace,0,1),r._addBar(r._verticalBar,r._verticalBarSpace,!0,Math.PI),r._horizontalBarSpace=new s,r._horizontalBarSpace.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,r._horizontalBarSpace.verticalAlignment=h.a.VERTICAL_ALIGNMENT_TOP,r._horizontalBarSpace.thickness=1,r._grid.addControl(r._horizontalBarSpace,1,0),r._addBar(r._horizontalBar,r._horizontalBarSpace,!1,0),r._dragSpace=new s,r._dragSpace.thickness=1,r._grid.addControl(r._dragSpace,1,1),r._useImageBar||(r.barColor="grey",r.barBackground="transparent"),r}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"horizontalBar",{get:function(){return this._horizontalBar},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"verticalBar",{get:function(){return this._verticalBar},enumerable:!0,configurable:!0}),t.prototype.addControl=function(e){return e?(this._window.addControl(e),this):this},t.prototype.removeControl=function(e){return this._window.removeControl(e),this},Object.defineProperty(t.prototype,"children",{get:function(){return this._window.children},enumerable:!0,configurable:!0}),t.prototype._flagDescendantsAsMatrixDirty=function(){for(var e=0,t=this._children;e1&&(e=1),this._wheelPrecision=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"scrollBackground",{get:function(){return this._horizontalBarSpace.background},set:function(e){this._horizontalBarSpace.background!==e&&(this._horizontalBarSpace.background=e,this._verticalBarSpace.background=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"barColor",{get:function(){return this._barColor},set:function(e){this._barColor!==e&&(this._barColor=e,this._horizontalBar.color=e,this._verticalBar.color=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"thumbImage",{get:function(){return this._barImage},set:function(e){if(this._barImage!==e){this._barImage=e;var t=this._horizontalBar,i=this._verticalBar;t.thumbImage=e,i.thumbImage=e}},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"horizontalThumbImage",{get:function(){return this._horizontalBarImage},set:function(e){this._horizontalBarImage!==e&&(this._horizontalBarImage=e,this._horizontalBar.thumbImage=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"verticalThumbImage",{get:function(){return this._verticalBarImage},set:function(e){this._verticalBarImage!==e&&(this._verticalBarImage=e,this._verticalBar.thumbImage=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"barSize",{get:function(){return this._barSize},set:function(e){this._barSize!==e&&(this._barSize=e,this._markAsDirty(),this._horizontalBar.isVisible&&this._grid.setRowDefinition(1,this._barSize,!0),this._verticalBar.isVisible&&this._grid.setColumnDefinition(1,this._barSize,!0))},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"thumbLength",{get:function(){return this._thumbLength},set:function(e){if(this._thumbLength!==e){e<=0&&(e=.1),e>1&&(e=1),this._thumbLength=e;var t=this._horizontalBar,i=this._verticalBar;t.thumbLength=e,i.thumbLength=e,this._markAsDirty()}},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"thumbHeight",{get:function(){return this._thumbHeight},set:function(e){if(this._thumbHeight!==e){e<=0&&(e=.1),e>1&&(e=1),this._thumbHeight=e;var t=this._horizontalBar,i=this._verticalBar;t.thumbHeight=e,i.thumbHeight=e,this._markAsDirty()}},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"barImageHeight",{get:function(){return this._barImageHeight},set:function(e){if(this._barImageHeight!==e){e<=0&&(e=.1),e>1&&(e=1),this._barImageHeight=e;var t=this._horizontalBar,i=this._verticalBar;t.barImageHeight=e,i.barImageHeight=e,this._markAsDirty()}},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"horizontalBarImageHeight",{get:function(){return this._horizontalBarImageHeight},set:function(e){this._horizontalBarImageHeight!==e&&(e<=0&&(e=.1),e>1&&(e=1),this._horizontalBarImageHeight=e,this._horizontalBar.barImageHeight=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"verticalBarImageHeight",{get:function(){return this._verticalBarImageHeight},set:function(e){this._verticalBarImageHeight!==e&&(e<=0&&(e=.1),e>1&&(e=1),this._verticalBarImageHeight=e,this._verticalBar.barImageHeight=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"barBackground",{get:function(){return this._barBackground},set:function(e){if(this._barBackground!==e){this._barBackground=e;var t=this._horizontalBar,i=this._verticalBar;t.background=e,i.background=e,this._dragSpace.background=e}},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"barImage",{get:function(){return this._barBackgroundImage},set:function(e){this._barBackgroundImage,this._barBackgroundImage=e;var t=this._horizontalBar,i=this._verticalBar;t.backgroundImage=e,i.backgroundImage=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"horizontalBarImage",{get:function(){return this._horizontalBarBackgroundImage},set:function(e){this._horizontalBarBackgroundImage,this._horizontalBarBackgroundImage=e,this._horizontalBar.backgroundImage=e},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"verticalBarImage",{get:function(){return this._verticalBarBackgroundImage},set:function(e){this._verticalBarBackgroundImage,this._verticalBarBackgroundImage=e,this._verticalBar.backgroundImage=e},enumerable:!0,configurable:!0}),t.prototype._setWindowPosition=function(){var e=this.host.idealRatio,t=this._window._currentMeasure.width,i=this._window._currentMeasure.height,r=this._clientWidth-t,n=this._clientHeight-i,o=this._horizontalBar.value/e*r+"px",s=this._verticalBar.value/e*n+"px";o!==this._window.left&&(this._window.left=o,this.freezeControls||(this._rebuildLayout=!0)),s!==this._window.top&&(this._window.top=s,this.freezeControls||(this._rebuildLayout=!0))},t.prototype._updateScroller=function(){var e=this._window._currentMeasure.width,t=this._window._currentMeasure.height;this._horizontalBar.isVisible&&e<=this._clientWidth&&!this.forceHorizontalBar?(this._grid.setRowDefinition(1,0,!0),this._horizontalBar.isVisible=!1,this._horizontalBar.value=0,this._rebuildLayout=!0):!this._horizontalBar.isVisible&&(e>this._clientWidth||this.forceHorizontalBar)&&(this._grid.setRowDefinition(1,this._barSize,!0),this._horizontalBar.isVisible=!0,this._rebuildLayout=!0),this._verticalBar.isVisible&&t<=this._clientHeight&&!this.forceVerticalBar?(this._grid.setColumnDefinition(1,0,!0),this._verticalBar.isVisible=!1,this._verticalBar.value=0,this._rebuildLayout=!0):!this._verticalBar.isVisible&&(t>this._clientHeight||this.forceVerticalBar)&&(this._grid.setColumnDefinition(1,this._barSize,!0),this._verticalBar.isVisible=!0,this._rebuildLayout=!0),this._buildClientSizes();var i=this.host.idealRatio;this._horizontalBar.thumbWidth=.9*this._thumbLength*(this._clientWidth/i)+"px",this._verticalBar.thumbWidth=.9*this._thumbLength*(this._clientHeight/i)+"px"},t.prototype._link=function(t){e.prototype._link.call(this,t),this._attachWheel()},t.prototype._addBar=function(e,t,i,r){var n=this;e.paddingLeft=0,e.width="100%",e.height="100%",e.barOffset=0,e.value=0,e.maximum=1,e.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_CENTER,e.verticalAlignment=h.a.VERTICAL_ALIGNMENT_CENTER,e.isVertical=i,e.rotation=r,e.isVisible=!1,t.addControl(e),e.onValueChangedObservable.add((function(e){n._setWindowPosition()}))},t.prototype._attachWheel=function(){var e=this;this._host&&!this._onWheelObserver&&(this._onWheelObserver=this.onWheelObservable.add((function(t){e._pointerIsOver&&(1==e._verticalBar.isVisible&&(t.y<0&&e._verticalBar.value>0?e._verticalBar.value-=e._wheelPrecision:t.y>0&&e._verticalBar.value0&&e._horizontalBar.value>0&&(e._horizontalBar.value-=e._wheelPrecision)))})))},t.prototype._renderHighlightSpecific=function(t){this.isHighlighted&&(e.prototype._renderHighlightSpecific.call(this,t),this._grid._renderHighlightSpecific(t),t.restore())},t.prototype.dispose=function(){this.onWheelObservable.remove(this._onWheelObserver),this._onWheelObserver=null,e.prototype.dispose.call(this)},t}(s);o.a.RegisteredTypes["BABYLON.GUI.ScrollViewer"]=j;var W=function(){},G=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.onKeyPressObservable=new l.a,t.defaultButtonWidth="40px",t.defaultButtonHeight="40px",t.defaultButtonPaddingLeft="2px",t.defaultButtonPaddingRight="2px",t.defaultButtonPaddingTop="2px",t.defaultButtonPaddingBottom="2px",t.defaultButtonColor="#DDD",t.defaultButtonBackground="#070707",t.shiftButtonColor="#7799FF",t.selectedShiftThickness=1,t.shiftState=0,t._currentlyConnectedInputText=null,t._connectedInputTexts=[],t._onKeyPressObserver=null,t}return Object(r.c)(t,e),t.prototype._getTypeName=function(){return"VirtualKeyboard"},t.prototype._createKey=function(e,t){var i=this,r=p.CreateSimpleButton(e,e);return r.width=t&&t.width?t.width:this.defaultButtonWidth,r.height=t&&t.height?t.height:this.defaultButtonHeight,r.color=t&&t.color?t.color:this.defaultButtonColor,r.background=t&&t.background?t.background:this.defaultButtonBackground,r.paddingLeft=t&&t.paddingLeft?t.paddingLeft:this.defaultButtonPaddingLeft,r.paddingRight=t&&t.paddingRight?t.paddingRight:this.defaultButtonPaddingRight,r.paddingTop=t&&t.paddingTop?t.paddingTop:this.defaultButtonPaddingTop,r.paddingBottom=t&&t.paddingBottom?t.paddingBottom:this.defaultButtonPaddingBottom,r.thickness=0,r.isFocusInvisible=!0,r.shadowColor=this.shadowColor,r.shadowBlur=this.shadowBlur,r.shadowOffsetX=this.shadowOffsetX,r.shadowOffsetY=this.shadowOffsetY,r.onPointerUpObservable.add((function(){i.onKeyPressObservable.notifyObservers(e)})),r},t.prototype.addKeysRow=function(e,t){var i=new _;i.isVertical=!1,i.isFocusInvisible=!0;for(var r=null,n=0;nr.heightInPixels)&&(r=s),i.addControl(s)}i.height=r?r.height:this.defaultButtonHeight,this.addControl(i)},t.prototype.applyShiftState=function(e){if(this.children)for(var t=0;t1?this.selectedShiftThickness:0),s.text=e>0?s.text.toUpperCase():s.text.toLowerCase()}}}},Object.defineProperty(t.prototype,"connectedInputText",{get:function(){return this._currentlyConnectedInputText},enumerable:!0,configurable:!0}),t.prototype.connect=function(e){var t=this;if(!this._connectedInputTexts.some((function(t){return t.input===e}))){null===this._onKeyPressObserver&&(this._onKeyPressObserver=this.onKeyPressObservable.add((function(e){if(t._currentlyConnectedInputText){switch(t._currentlyConnectedInputText._host.focusedControl=t._currentlyConnectedInputText,e){case"⇧":return t.shiftState++,t.shiftState>2&&(t.shiftState=0),void t.applyShiftState(t.shiftState);case"←":return void t._currentlyConnectedInputText.processKey(8);case"↵":return void t._currentlyConnectedInputText.processKey(13)}t._currentlyConnectedInputText.processKey(-1,t.shiftState?e.toUpperCase():e),1===t.shiftState&&(t.shiftState=0,t.applyShiftState(t.shiftState))}}))),this.isVisible=!1,this._currentlyConnectedInputText=e,e._connectedVirtualKeyboard=this;var i=e.onFocusObservable.add((function(){t._currentlyConnectedInputText=e,e._connectedVirtualKeyboard=t,t.isVisible=!0})),r=e.onBlurObservable.add((function(){e._connectedVirtualKeyboard=null,t._currentlyConnectedInputText=null,t.isVisible=!1}));this._connectedInputTexts.push({input:e,onBlurObserver:r,onFocusObserver:i})}},t.prototype.disconnect=function(e){var t=this;if(e){var i=this._connectedInputTexts.filter((function(t){return t.input===e}));1===i.length&&(this._removeConnectedInputObservables(i[0]),this._connectedInputTexts=this._connectedInputTexts.filter((function(t){return t.input!==e})),this._currentlyConnectedInputText===e&&(this._currentlyConnectedInputText=null))}else this._connectedInputTexts.forEach((function(e){t._removeConnectedInputObservables(e)})),this._connectedInputTexts=[];0===this._connectedInputTexts.length&&(this._currentlyConnectedInputText=null,this.onKeyPressObservable.remove(this._onKeyPressObserver),this._onKeyPressObserver=null)},t.prototype._removeConnectedInputObservables=function(e){e.input._connectedVirtualKeyboard=null,e.input.onFocusObservable.remove(e.onFocusObserver),e.input.onBlurObservable.remove(e.onBlurObserver)},t.prototype.dispose=function(){e.prototype.dispose.call(this),this.disconnect()},t.CreateDefaultLayout=function(e){var i=new t(e);return i.addKeysRow(["1","2","3","4","5","6","7","8","9","0","←"]),i.addKeysRow(["q","w","e","r","t","y","u","i","o","p"]),i.addKeysRow(["a","s","d","f","g","h","j","k","l",";","'","↵"]),i.addKeysRow(["⇧","z","x","c","v","b","n","m",",",".","/"]),i.addKeysRow([" "],[{width:"200px"}]),i},t}(_);o.a.RegisteredTypes["BABYLON.GUI.VirtualKeyboard"]=G;var H=function(e){function t(t){var i=e.call(this,t)||this;return i.name=t,i._cellWidth=20,i._cellHeight=20,i._minorLineTickness=1,i._minorLineColor="DarkGray",i._majorLineTickness=2,i._majorLineColor="White",i._majorLineFrequency=5,i._background="Black",i._displayMajorLines=!0,i._displayMinorLines=!0,i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"displayMinorLines",{get:function(){return this._displayMinorLines},set:function(e){this._displayMinorLines!==e&&(this._displayMinorLines=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"displayMajorLines",{get:function(){return this._displayMajorLines},set:function(e){this._displayMajorLines!==e&&(this._displayMajorLines=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"background",{get:function(){return this._background},set:function(e){this._background!==e&&(this._background=e,this._markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"cellWidth",{get:function(){return this._cellWidth},set:function(e){this._cellWidth=e,this._markAsDirty()},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"cellHeight",{get:function(){return this._cellHeight},set:function(e){this._cellHeight=e,this._markAsDirty()},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"minorLineTickness",{get:function(){return this._minorLineTickness},set:function(e){this._minorLineTickness=e,this._markAsDirty()},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"minorLineColor",{get:function(){return this._minorLineColor},set:function(e){this._minorLineColor=e,this._markAsDirty()},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"majorLineTickness",{get:function(){return this._majorLineTickness},set:function(e){this._majorLineTickness=e,this._markAsDirty()},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"majorLineColor",{get:function(){return this._majorLineColor},set:function(e){this._majorLineColor=e,this._markAsDirty()},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"majorLineFrequency",{get:function(){return this._majorLineFrequency},set:function(e){this._majorLineFrequency=e,this._markAsDirty()},enumerable:!0,configurable:!0}),t.prototype._draw=function(e,t){if(e.save(),this._applyStates(e),this._isEnabled){this._background&&(e.fillStyle=this._background,e.fillRect(this._currentMeasure.left,this._currentMeasure.top,this._currentMeasure.width,this._currentMeasure.height));var i=this._currentMeasure.width/this._cellWidth,r=this._currentMeasure.height/this._cellHeight,n=this._currentMeasure.left+this._currentMeasure.width/2,o=this._currentMeasure.top+this._currentMeasure.height/2;if(this._displayMinorLines){e.strokeStyle=this._minorLineColor,e.lineWidth=this._minorLineTickness;for(var s=-i/2;s0&&e.isBackground===t&&e.renderTargetTextures.indexOf(r)>-1&&0!=(e.layerMask&i)},e.prototype._drawRenderTargetBackground=function(e){var t=this;this._draw((function(i){return t._drawRenderTargetPredicate(i,!0,t.scene.activeCamera.layerMask,e)}))},e.prototype._drawRenderTargetForeground=function(e){var t=this;this._draw((function(i){return t._drawRenderTargetPredicate(i,!1,t.scene.activeCamera.layerMask,e)}))},e.prototype.addFromContainer=function(e){var t=this;e.layers&&e.layers.forEach((function(e){t.scene.layers.push(e)}))},e.prototype.removeFromContainer=function(e,t){var i=this;void 0===t&&(t=!1),e.layers&&e.layers.forEach((function(e){var r=i.scene.layers.indexOf(e);-1!==r&&i.scene.layers.splice(r,1),t&&e.dispose()}))},e}(),v=i(6),y=(i(76),"\nvarying vec2 vUV;\nuniform sampler2D textureSampler;\n\nuniform vec4 color;\n\n#include\nvoid main(void) {\nvec4 baseColor=texture2D(textureSampler,vUV);\n#ifdef LINEAR\nbaseColor.rgb=toGammaSpace(baseColor.rgb);\n#endif\n#ifdef ALPHATEST\nif (baseColor.a<0.4)\ndiscard;\n#endif\ngl_FragColor=baseColor*color;\n}");v.a.ShadersStore.layerPixelShader=y;var x="\nattribute vec2 position;\n\nuniform vec2 scale;\nuniform vec2 offset;\nuniform mat4 textureMatrix;\n\nvarying vec2 vUV;\nconst vec2 madd=vec2(0.5,0.5);\nvoid main(void) {\nvec2 shiftedPosition=position*scale+offset;\nvUV=vec2(textureMatrix*vec4(shiftedPosition*madd+madd,1.0,0.0));\ngl_Position=vec4(shiftedPosition,0.0,1.0);\n}";v.a.ShadersStore.layerVertexShader=x;var T=function(){function e(e,t,i,r,s){this.name=e,this.scale=new o.d(1,1),this.offset=new o.d(0,0),this.alphaBlendingMode=2,this.layerMask=268435455,this.renderTargetTextures=[],this.renderOnlyInRenderTargetTextures=!1,this._vertexBuffers={},this.onDisposeObservable=new n.a,this.onBeforeRenderObservable=new n.a,this.onAfterRenderObservable=new n.a,this.texture=t?new u.a(t,i,!0):null,this.isBackground=void 0===r||r,this.color=void 0===s?new d.b(1,1,1,1):s,this._scene=i||p.a.LastCreatedScene;var a=this._scene._getComponent(m.a.NAME_LAYER);a||(a=new b(this._scene),this._scene._addComponent(a)),this._scene.layers.push(this);var h=this._scene.getEngine(),l=[];l.push(1,1),l.push(-1,1),l.push(-1,-1),l.push(1,-1);var c=new _.b(h,l,_.b.PositionKind,!1,!1,2);this._vertexBuffers[_.b.PositionKind]=c,this._createIndexBuffer()}return Object.defineProperty(e.prototype,"onDispose",{set:function(e){this._onDisposeObserver&&this.onDisposeObservable.remove(this._onDisposeObserver),this._onDisposeObserver=this.onDisposeObservable.add(e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"onBeforeRender",{set:function(e){this._onBeforeRenderObserver&&this.onBeforeRenderObservable.remove(this._onBeforeRenderObserver),this._onBeforeRenderObserver=this.onBeforeRenderObservable.add(e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"onAfterRender",{set:function(e){this._onAfterRenderObserver&&this.onAfterRenderObservable.remove(this._onAfterRenderObserver),this._onAfterRenderObserver=this.onAfterRenderObservable.add(e)},enumerable:!0,configurable:!0}),e.prototype._createIndexBuffer=function(){var e=this._scene.getEngine(),t=[];t.push(0),t.push(1),t.push(2),t.push(0),t.push(2),t.push(3),this._indexBuffer=e.createIndexBuffer(t)},e.prototype._rebuild=function(){var e=this._vertexBuffers[_.b.PositionKind];e&&e._rebuild(),this._createIndexBuffer()},e.prototype.render=function(){var e=this._scene.getEngine(),t="";this.alphaTest&&(t="#define ALPHATEST"),this.texture&&!this.texture.gammaSpace&&(t+="\r\n#define LINEAR"),this._previousDefines!==t&&(this._previousDefines=t,this._effect=e.createEffect("layer",[_.b.PositionKind],["textureMatrix","color","scale","offset"],["textureSampler"],t));var i=this._effect;if(i&&i.isReady()&&this.texture&&this.texture.isReady()){e=this._scene.getEngine();this.onBeforeRenderObservable.notifyObservers(this),e.enableEffect(i),e.setState(!1),i.setTexture("textureSampler",this.texture),i.setMatrix("textureMatrix",this.texture.getTextureMatrix()),i.setFloat4("color",this.color.r,this.color.g,this.color.b,this.color.a),i.setVector2("offset",this.offset),i.setVector2("scale",this.scale),e.bindBuffers(this._vertexBuffers,this._indexBuffer,i),this.alphaTest?e.drawElementsType(g.a.TriangleFillMode,0,6):(e.setAlphaMode(this.alphaBlendingMode),e.drawElementsType(g.a.TriangleFillMode,0,6),e.setAlphaMode(0)),this.onAfterRenderObservable.notifyObservers(this)}},e.prototype.dispose=function(){var e=this._vertexBuffers[_.b.PositionKind];e&&(e.dispose(),this._vertexBuffers[_.b.PositionKind]=null),this._indexBuffer&&(this._scene.getEngine()._releaseBuffer(this._indexBuffer),this._indexBuffer=null),this.texture&&(this.texture.dispose(),this.texture=null),this.renderTargetTextures=[];var t=this._scene.layers.indexOf(this);this._scene.layers.splice(t,1),this.onDisposeObservable.notifyObservers(this),this.onDisposeObservable.clear(),this.onAfterRenderObservable.clear(),this.onBeforeRenderObservable.clear()},e}(),E=i(32),M=i(14),A=function(){function e(e){this._fontFamily="Arial",this._fontStyle="",this._fontWeight="",this._fontSize=new M.a(18,M.a.UNITMODE_PIXEL,!1),this.onChangedObservable=new n.a,this._host=e}return Object.defineProperty(e.prototype,"fontSize",{get:function(){return this._fontSize.toString(this._host)},set:function(e){this._fontSize.toString(this._host)!==e&&this._fontSize.fromString(e)&&this.onChangedObservable.notifyObservers(this)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"fontFamily",{get:function(){return this._fontFamily},set:function(e){this._fontFamily!==e&&(this._fontFamily=e,this.onChangedObservable.notifyObservers(this))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"fontStyle",{get:function(){return this._fontStyle},set:function(e){this._fontStyle!==e&&(this._fontStyle=e,this.onChangedObservable.notifyObservers(this))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"fontWeight",{get:function(){return this._fontWeight},set:function(e){this._fontWeight!==e&&(this._fontWeight=e,this.onChangedObservable.notifyObservers(this))},enumerable:!0,configurable:!0}),e.prototype.dispose=function(){this.onChangedObservable.clear()},e}(),O=i(29),C=function(){function e(){}return e.ALPHA_DISABLE=0,e.ALPHA_ADD=1,e.ALPHA_COMBINE=2,e.ALPHA_SUBTRACT=3,e.ALPHA_MULTIPLY=4,e.ALPHA_MAXIMIZED=5,e.ALPHA_ONEONE=6,e.ALPHA_PREMULTIPLIED=7,e.ALPHA_PREMULTIPLIED_PORTERDUFF=8,e.ALPHA_INTERPOLATE=9,e.ALPHA_SCREENMODE=10,e.ALPHA_ONEONE_ONEONE=11,e.ALPHA_ALPHATOCOLOR=12,e.ALPHA_REVERSEONEMINUS=13,e.ALPHA_SRC_DSTONEMINUSSRCALPHA=14,e.ALPHA_ONEONE_ONEZERO=15,e.ALPHA_EXCLUSION=16,e.ALPHA_EQUATION_ADD=0,e.ALPHA_EQUATION_SUBSTRACT=1,e.ALPHA_EQUATION_REVERSE_SUBTRACT=2,e.ALPHA_EQUATION_MAX=3,e.ALPHA_EQUATION_MIN=4,e.ALPHA_EQUATION_DARKEN=5,e.DELAYLOADSTATE_NONE=0,e.DELAYLOADSTATE_LOADED=1,e.DELAYLOADSTATE_LOADING=2,e.DELAYLOADSTATE_NOTLOADED=4,e.NEVER=512,e.ALWAYS=519,e.LESS=513,e.EQUAL=514,e.LEQUAL=515,e.GREATER=516,e.GEQUAL=518,e.NOTEQUAL=517,e.KEEP=7680,e.REPLACE=7681,e.INCR=7682,e.DECR=7683,e.INVERT=5386,e.INCR_WRAP=34055,e.DECR_WRAP=34056,e.TEXTURE_CLAMP_ADDRESSMODE=0,e.TEXTURE_WRAP_ADDRESSMODE=1,e.TEXTURE_MIRROR_ADDRESSMODE=2,e.TEXTUREFORMAT_ALPHA=0,e.TEXTUREFORMAT_LUMINANCE=1,e.TEXTUREFORMAT_LUMINANCE_ALPHA=2,e.TEXTUREFORMAT_RGB=4,e.TEXTUREFORMAT_RGBA=5,e.TEXTUREFORMAT_RED=6,e.TEXTUREFORMAT_R=6,e.TEXTUREFORMAT_RG=7,e.TEXTUREFORMAT_RED_INTEGER=8,e.TEXTUREFORMAT_R_INTEGER=8,e.TEXTUREFORMAT_RG_INTEGER=9,e.TEXTUREFORMAT_RGB_INTEGER=10,e.TEXTUREFORMAT_RGBA_INTEGER=11,e.TEXTURETYPE_UNSIGNED_BYTE=0,e.TEXTURETYPE_UNSIGNED_INT=0,e.TEXTURETYPE_FLOAT=1,e.TEXTURETYPE_HALF_FLOAT=2,e.TEXTURETYPE_BYTE=3,e.TEXTURETYPE_SHORT=4,e.TEXTURETYPE_UNSIGNED_SHORT=5,e.TEXTURETYPE_INT=6,e.TEXTURETYPE_UNSIGNED_INTEGER=7,e.TEXTURETYPE_UNSIGNED_SHORT_4_4_4_4=8,e.TEXTURETYPE_UNSIGNED_SHORT_5_5_5_1=9,e.TEXTURETYPE_UNSIGNED_SHORT_5_6_5=10,e.TEXTURETYPE_UNSIGNED_INT_2_10_10_10_REV=11,e.TEXTURETYPE_UNSIGNED_INT_24_8=12,e.TEXTURETYPE_UNSIGNED_INT_10F_11F_11F_REV=13,e.TEXTURETYPE_UNSIGNED_INT_5_9_9_9_REV=14,e.TEXTURETYPE_FLOAT_32_UNSIGNED_INT_24_8_REV=15,e.TEXTURE_NEAREST_SAMPLINGMODE=1,e.TEXTURE_NEAREST_NEAREST=1,e.TEXTURE_BILINEAR_SAMPLINGMODE=2,e.TEXTURE_LINEAR_LINEAR=2,e.TEXTURE_TRILINEAR_SAMPLINGMODE=3,e.TEXTURE_LINEAR_LINEAR_MIPLINEAR=3,e.TEXTURE_NEAREST_NEAREST_MIPNEAREST=4,e.TEXTURE_NEAREST_LINEAR_MIPNEAREST=5,e.TEXTURE_NEAREST_LINEAR_MIPLINEAR=6,e.TEXTURE_NEAREST_LINEAR=7,e.TEXTURE_NEAREST_NEAREST_MIPLINEAR=8,e.TEXTURE_LINEAR_NEAREST_MIPNEAREST=9,e.TEXTURE_LINEAR_NEAREST_MIPLINEAR=10,e.TEXTURE_LINEAR_LINEAR_MIPNEAREST=11,e.TEXTURE_LINEAR_NEAREST=12,e.TEXTURE_EXPLICIT_MODE=0,e.TEXTURE_SPHERICAL_MODE=1,e.TEXTURE_PLANAR_MODE=2,e.TEXTURE_CUBIC_MODE=3,e.TEXTURE_PROJECTION_MODE=4,e.TEXTURE_SKYBOX_MODE=5,e.TEXTURE_INVCUBIC_MODE=6,e.TEXTURE_EQUIRECTANGULAR_MODE=7,e.TEXTURE_FIXED_EQUIRECTANGULAR_MODE=8,e.TEXTURE_FIXED_EQUIRECTANGULAR_MIRRORED_MODE=9,e.SCALEMODE_FLOOR=1,e.SCALEMODE_NEAREST=2,e.SCALEMODE_CEILING=3,e.MATERIAL_TextureDirtyFlag=1,e.MATERIAL_LightDirtyFlag=2,e.MATERIAL_FresnelDirtyFlag=4,e.MATERIAL_AttributesDirtyFlag=8,e.MATERIAL_MiscDirtyFlag=16,e.MATERIAL_AllDirtyFlag=31,e.MATERIAL_TriangleFillMode=0,e.MATERIAL_WireFrameFillMode=1,e.MATERIAL_PointFillMode=2,e.MATERIAL_PointListDrawMode=3,e.MATERIAL_LineListDrawMode=4,e.MATERIAL_LineLoopDrawMode=5,e.MATERIAL_LineStripDrawMode=6,e.MATERIAL_TriangleStripDrawMode=7,e.MATERIAL_TriangleFanDrawMode=8,e.MATERIAL_ClockWiseSideOrientation=0,e.MATERIAL_CounterClockWiseSideOrientation=1,e.ACTION_NothingTrigger=0,e.ACTION_OnPickTrigger=1,e.ACTION_OnLeftPickTrigger=2,e.ACTION_OnRightPickTrigger=3,e.ACTION_OnCenterPickTrigger=4,e.ACTION_OnPickDownTrigger=5,e.ACTION_OnDoublePickTrigger=6,e.ACTION_OnPickUpTrigger=7,e.ACTION_OnPickOutTrigger=16,e.ACTION_OnLongPressTrigger=8,e.ACTION_OnPointerOverTrigger=9,e.ACTION_OnPointerOutTrigger=10,e.ACTION_OnEveryFrameTrigger=11,e.ACTION_OnIntersectionEnterTrigger=12,e.ACTION_OnIntersectionExitTrigger=13,e.ACTION_OnKeyDownTrigger=14,e.ACTION_OnKeyUpTrigger=15,e.PARTICLES_BILLBOARDMODE_Y=2,e.PARTICLES_BILLBOARDMODE_ALL=7,e.PARTICLES_BILLBOARDMODE_STRETCHED=8,e.MESHES_CULLINGSTRATEGY_STANDARD=0,e.MESHES_CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY=1,e.MESHES_CULLINGSTRATEGY_OPTIMISTIC_INCLUSION=2,e.MESHES_CULLINGSTRATEGY_OPTIMISTIC_INCLUSION_THEN_BSPHERE_ONLY=3,e.SCENELOADER_NO_LOGGING=0,e.SCENELOADER_MINIMAL_LOGGING=1,e.SCENELOADER_SUMMARY_LOGGING=2,e.SCENELOADER_DETAILED_LOGGING=3,e}(),S=i(53),P=function(e){function t(t,i,r,o,s,a){void 0===i&&(i=0),void 0===r&&(r=0),void 0===s&&(s=!1),void 0===a&&(a=u.a.NEAREST_SAMPLINGMODE);var c=e.call(this,t,{width:i,height:r},o,s,a,C.TEXTUREFORMAT_RGBA)||this;return c._isDirty=!1,c._rootContainer=new E.a("root"),c._lastControlOver={},c._lastControlDown={},c._capturingControl={},c._linkedControls=new Array,c._isFullscreen=!1,c._fullscreenViewport=new S.a(0,0,1,1),c._idealWidth=0,c._idealHeight=0,c._useSmallestIdeal=!1,c._renderAtIdealSize=!1,c._blockNextFocusCheck=!1,c._renderScale=1,c._cursorChanged=!1,c._defaultMousePointerId=0,c._numLayoutCalls=0,c._numRenderCalls=0,c._clipboardData="",c.onClipboardObservable=new n.a,c.onControlPickedObservable=new n.a,c.onBeginLayoutObservable=new n.a,c.onEndLayoutObservable=new n.a,c.onBeginRenderObservable=new n.a,c.onEndRenderObservable=new n.a,c.premulAlpha=!1,c._useInvalidateRectOptimization=!0,c._invalidatedRectangle=null,c._clearMeasure=new O.a(0,0,0,0),c.onClipboardCopy=function(e){var t=e,i=new h.b(h.a.COPY,t);c.onClipboardObservable.notifyObservers(i),t.preventDefault()},c.onClipboardCut=function(e){var t=e,i=new h.b(h.a.CUT,t);c.onClipboardObservable.notifyObservers(i),t.preventDefault()},c.onClipboardPaste=function(e){var t=e,i=new h.b(h.a.PASTE,t);c.onClipboardObservable.notifyObservers(i),t.preventDefault()},(o=c.getScene())&&c._texture?(c._rootElement=o.getEngine().getInputElement(),c._renderObserver=o.onBeforeCameraRenderObservable.add((function(e){return c._checkUpdate(e)})),c._preKeyboardObserver=o.onPreKeyboardObservable.add((function(e){c._focusedControl&&(e.type===l.a.KEYDOWN&&c._focusedControl.processKeyboard(e.event),e.skipOnPointerObservable=!0)})),c._rootContainer._link(c),c.hasAlpha=!0,i&&r||(c._resizeObserver=o.getEngine().onResizeObservable.add((function(){return c._onResize()})),c._onResize()),c._texture.isReady=!0,c):c}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"numLayoutCalls",{get:function(){return this._numLayoutCalls},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"numRenderCalls",{get:function(){return this._numRenderCalls},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"renderScale",{get:function(){return this._renderScale},set:function(e){e!==this._renderScale&&(this._renderScale=e,this._onResize())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"background",{get:function(){return this._background},set:function(e){this._background!==e&&(this._background=e,this.markAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"idealWidth",{get:function(){return this._idealWidth},set:function(e){this._idealWidth!==e&&(this._idealWidth=e,this.markAsDirty(),this._rootContainer._markAllAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"idealHeight",{get:function(){return this._idealHeight},set:function(e){this._idealHeight!==e&&(this._idealHeight=e,this.markAsDirty(),this._rootContainer._markAllAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"useSmallestIdeal",{get:function(){return this._useSmallestIdeal},set:function(e){this._useSmallestIdeal!==e&&(this._useSmallestIdeal=e,this.markAsDirty(),this._rootContainer._markAllAsDirty())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"renderAtIdealSize",{get:function(){return this._renderAtIdealSize},set:function(e){this._renderAtIdealSize!==e&&(this._renderAtIdealSize=e,this._onResize())},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"idealRatio",{get:function(){var e=0,t=0;return this._idealWidth&&(e=this.getSize().width/this._idealWidth),this._idealHeight&&(t=this.getSize().height/this._idealHeight),this._useSmallestIdeal&&this._idealWidth&&this._idealHeight?window.innerWidth1?a.notRenderable=!0:(a.notRenderable=!1,c.scaleInPlace(this.renderScale),a._moveToProjectedPosition(c))}else s.b.SetImmediate((function(){a.linkWithMesh(null)}))}}}(this._isDirty||this._rootContainer.isDirty)&&(this._isDirty=!1,this._render(),this.update(!0,this.premulAlpha))}},t.prototype._render=function(){var e=this.getSize(),t=e.width,i=e.height,r=this.getContext();r.font="18px Arial",r.strokeStyle="white",this.onBeginLayoutObservable.notifyObservers(this);var n=new O.a(0,0,t,i);this._numLayoutCalls=0,this._rootContainer._layout(n,r),this.onEndLayoutObservable.notifyObservers(this),this._isDirty=!1,this._invalidatedRectangle?this._clearMeasure.copyFrom(this._invalidatedRectangle):this._clearMeasure.copyFromFloats(0,0,t,i),r.clearRect(this._clearMeasure.left,this._clearMeasure.top,this._clearMeasure.width,this._clearMeasure.height),this._background&&(r.save(),r.fillStyle=this._background,r.fillRect(this._clearMeasure.left,this._clearMeasure.top,this._clearMeasure.width,this._clearMeasure.height),r.restore()),this.onBeginRenderObservable.notifyObservers(this),this._numRenderCalls=0,this._rootContainer._render(r,this._invalidatedRectangle),this.onEndRenderObservable.notifyObservers(this),this._invalidatedRectangle=null},t.prototype._changeCursor=function(e){this._rootElement&&(this._rootElement.style.cursor=e,this._cursorChanged=!0)},t.prototype._registerLastControlDown=function(e,t){this._lastControlDown[t]=e,this.onControlPickedObservable.notifyObservers(e)},t.prototype._doPicking=function(e,t,i,r,n,o,s){var h=this.getScene();if(h){var l=h.getEngine(),c=this.getSize();if(this._isFullscreen){var u=(h.cameraToUseForPointers||h.activeCamera).viewport;e*=c.width/(l.getRenderWidth()*u.width),t*=c.height/(l.getRenderHeight()*u.height)}this._capturingControl[r]?this._capturingControl[r]._processObservables(i,e,t,r,n):(this._cursorChanged=!1,this._rootContainer._processPicking(e,t,i,r,n,o,s)||(this._changeCursor(""),i===a.a.POINTERMOVE&&this._lastControlOver[r]&&(this._lastControlOver[r]._onPointerOut(this._lastControlOver[r]),delete this._lastControlOver[r])),this._cursorChanged||this._changeCursor(""),this._manageFocus())}},t.prototype._cleanControlAfterRemovalFromList=function(e,t){for(var i in e){if(e.hasOwnProperty(i))e[i]===t&&delete e[i]}},t.prototype._cleanControlAfterRemoval=function(e){this._cleanControlAfterRemovalFromList(this._lastControlDown,e),this._cleanControlAfterRemovalFromList(this._lastControlOver,e)},t.prototype.attach=function(){var e=this,t=this.getScene();if(t){var i=new S.a(0,0,0,0);this._pointerMoveObserver=t.onPrePointerObservable.add((function(r,n){if(!t.isPointerCaptured(r.event.pointerId)&&(r.type===a.a.POINTERMOVE||r.type===a.a.POINTERUP||r.type===a.a.POINTERDOWN||r.type===a.a.POINTERWHEEL)&&t){r.type===a.a.POINTERMOVE&&r.event.pointerId&&(e._defaultMousePointerId=r.event.pointerId);var o=t.cameraToUseForPointers||t.activeCamera,s=t.getEngine();o?o.viewport.toGlobalToRef(s.getRenderWidth(),s.getRenderHeight(),i):(i.x=0,i.y=0,i.width=s.getRenderWidth(),i.height=s.getRenderHeight());var h=t.pointerX/s.getHardwareScalingLevel()-i.x,l=t.pointerY/s.getHardwareScalingLevel()-(s.getRenderHeight()-i.y-i.height);e._shouldBlockPointer=!1;var c=r.event.pointerId||e._defaultMousePointerId;e._doPicking(h,l,r.type,c,r.event.button,r.event.deltaX,r.event.deltaY),e._shouldBlockPointer&&(r.skipOnPointerObservable=e._shouldBlockPointer)}})),this._attachToOnPointerOut(t)}},t.prototype.registerClipboardEvents=function(){self.addEventListener("copy",this.onClipboardCopy,!1),self.addEventListener("cut",this.onClipboardCut,!1),self.addEventListener("paste",this.onClipboardPaste,!1)},t.prototype.unRegisterClipboardEvents=function(){self.removeEventListener("copy",this.onClipboardCopy),self.removeEventListener("cut",this.onClipboardCut),self.removeEventListener("paste",this.onClipboardPaste)},t.prototype.attachToMesh=function(e,t){var i=this;void 0===t&&(t=!0);var r=this.getScene();r&&(this._pointerObserver=r.onPointerObservable.add((function(t,r){if(t.type===a.a.POINTERMOVE||t.type===a.a.POINTERUP||t.type===a.a.POINTERDOWN){var n=t.event.pointerId||i._defaultMousePointerId;if(t.pickInfo&&t.pickInfo.hit&&t.pickInfo.pickedMesh===e){var o=t.pickInfo.getTextureCoordinates();if(o){var s=i.getSize();i._doPicking(o.x*s.width,(1-o.y)*s.height,t.type,n,t.event.button)}}else if(t.type===a.a.POINTERUP){if(i._lastControlDown[n]&&i._lastControlDown[n]._forcePointerUp(n),delete i._lastControlDown[n],i.focusedControl){var h=i.focusedControl.keepsFocusWith(),l=!0;if(h)for(var c=0,u=h;c0!=this._getWorldMatrixDeterminant()>0)return this._internalAbstractMeshDataInfo._actAsRegularMesh=!0,!0;if(this._internalAbstractMeshDataInfo._actAsRegularMesh=!1,this._currentLOD._registerInstanceForRenderId(this,e),t){if(!this._currentLOD._internalAbstractMeshDataInfo._isActiveIntermediate)return this._currentLOD._internalAbstractMeshDataInfo._onlyForInstancesIntermediate=!0,!0}else if(!this._currentLOD._internalAbstractMeshDataInfo._isActive)return this._currentLOD._internalAbstractMeshDataInfo._onlyForInstances=!0,!0}return!1},t.prototype._postActivate=function(){this._edgesRenderer&&this._edgesRenderer.isEnabled&&this._sourceMesh._renderingGroup&&this._sourceMesh._renderingGroup._edgesRenderers.push(this._edgesRenderer)},t.prototype.getWorldMatrix=function(){if(this._currentLOD&&this._currentLOD.billboardMode!==f.a.BILLBOARDMODE_NONE&&this._currentLOD._masterMesh!==this){var t=this._currentLOD._masterMesh;return this._currentLOD._masterMesh=this,r.c.Vector3[7].copyFrom(this._currentLOD.position),this._currentLOD.position.set(0,0,0),r.c.Matrix[0].copyFrom(this._currentLOD.computeWorldMatrix(!0)),this._currentLOD.position.copyFrom(r.c.Vector3[7]),this._currentLOD._masterMesh=t,r.c.Matrix[0]}return e.prototype.getWorldMatrix.call(this)},Object.defineProperty(t.prototype,"isAnInstance",{get:function(){return!0},enumerable:!0,configurable:!0}),t.prototype.getLOD=function(e){if(!e)return this;var t=this.getBoundingInfo();return this._currentLOD=this.sourceMesh.getLOD(e,t.boundingSphere),this._currentLOD===this.sourceMesh?this.sourceMesh:this._currentLOD},t.prototype._preActivateForIntermediateRendering=function(e){return this.sourceMesh._preActivateForIntermediateRendering(e)},t.prototype._syncSubMeshes=function(){if(this.releaseSubMeshes(),this._sourceMesh.subMeshes)for(var e=0;e1&&(this._multiview=!0,n.push("#define MULTIVIEW"),-1!==this._options.uniforms.indexOf("viewProjection")&&-1===this._options.uniforms.push("viewProjectionR")&&this._options.uniforms.push("viewProjectionR"));for(var a=0;a4&&(o.push(h.b.MatricesIndicesExtraKind),o.push(h.b.MatricesWeightsExtraKind));var l=e.skeleton;n.push("#define NUM_BONE_INFLUENCERS "+e.numBoneInfluencers),s.addCPUSkinningFallback(0,e),l.isUsingTextureForMatrices?(n.push("#define BONETEXTURE"),-1===this._options.uniforms.indexOf("boneTextureWidth")&&this._options.uniforms.push("boneTextureWidth"),-1===this._options.samplers.indexOf("boneSampler")&&this._options.samplers.push("boneSampler")):(n.push("#define BonesPerMesh "+(l.bones.length+1)),-1===this._options.uniforms.indexOf("mBones")&&this._options.uniforms.push("mBones"))}else n.push("#define NUM_BONE_INFLUENCERS 0");for(var c in this._textures)if(!this._textures[c].isReady())return!1;e&&this._shouldTurnAlphaTestOn(e)&&n.push("#define ALPHATEST");var u=this._effect,f=n.join("\n");return this._effect=r.createEffect(this._shaderPath,{attributes:o,uniformsNames:this._options.uniforms,uniformBuffersNames:this._options.uniformBuffers,samplers:this._options.samplers,defines:f,fallbacks:s,onCompiled:this.onCompiled,onError:this.onError},r),!!this._effect.isReady()&&(u!==this._effect&&i.resetCachedMaterial(),this._renderId=i.getRenderId(),this._effect._wasPreviouslyReady=!0,!0)},t.prototype.bindOnlyWorldMatrix=function(e){var t=this.getScene();this._effect&&(-1!==this._options.uniforms.indexOf("world")&&this._effect.setMatrix("world",e),-1!==this._options.uniforms.indexOf("worldView")&&(e.multiplyToRef(t.getViewMatrix(),this._cachedWorldViewMatrix),this._effect.setMatrix("worldView",this._cachedWorldViewMatrix)),-1!==this._options.uniforms.indexOf("worldViewProjection")&&(e.multiplyToRef(t.getTransformMatrix(),this._cachedWorldViewProjectionMatrix),this._effect.setMatrix("worldViewProjection",this._cachedWorldViewProjectionMatrix)))},t.prototype.bind=function(e,t){if(this.bindOnlyWorldMatrix(e),this._effect&&this.getScene().getCachedMaterial()!==this){var i;for(i in-1!==this._options.uniforms.indexOf("view")&&this._effect.setMatrix("view",this.getScene().getViewMatrix()),-1!==this._options.uniforms.indexOf("projection")&&this._effect.setMatrix("projection",this.getScene().getProjectionMatrix()),-1!==this._options.uniforms.indexOf("viewProjection")&&(this._effect.setMatrix("viewProjection",this.getScene().getTransformMatrix()),this._multiview&&this._effect.setMatrix("viewProjectionR",this.getScene()._transformMatrixR)),this.getScene().activeCamera&&-1!==this._options.uniforms.indexOf("cameraPosition")&&this._effect.setVector3("cameraPosition",this.getScene().activeCamera.globalPosition),m.a.BindBonesParameters(t,this._effect),this._textures)this._effect.setTexture(i,this._textures[i]);for(i in this._textureArrays)this._effect.setTextureArray(i,this._textureArrays[i]);for(i in this._ints)this._effect.setInt(i,this._ints[i]);for(i in this._floats)this._effect.setFloat(i,this._floats[i]);for(i in this._floatsArrays)this._effect.setArray(i,this._floatsArrays[i]);for(i in this._colors3)this._effect.setColor3(i,this._colors3[i]);for(i in this._colors3Arrays)this._effect.setArray3(i,this._colors3Arrays[i]);for(i in this._colors4){var r=this._colors4[i];this._effect.setFloat4(i,r.r,r.g,r.b,r.a)}for(i in this._colors4Arrays)this._effect.setArray4(i,this._colors4Arrays[i]);for(i in this._vectors2)this._effect.setVector2(i,this._vectors2[i]);for(i in this._vectors3)this._effect.setVector3(i,this._vectors3[i]);for(i in this._vectors4)this._effect.setVector4(i,this._vectors4[i]);for(i in this._matrices)this._effect.setMatrix(i,this._matrices[i]);for(i in this._matrixArrays)this._effect.setMatrices(i,this._matrixArrays[i]);for(i in this._matrices3x3)this._effect.setMatrix3x3(i,this._matrices3x3[i]);for(i in this._matrices2x2)this._effect.setMatrix2x2(i,this._matrices2x2[i]);for(i in this._vectors2Arrays)this._effect.setArray2(i,this._vectors2Arrays[i]);for(i in this._vectors3Arrays)this._effect.setArray3(i,this._vectors3Arrays[i]);for(i in this._vectors4Arrays)this._effect.setArray4(i,this._vectors4Arrays[i])}this._afterBind(t)},t.prototype.getActiveTextures=function(){var t=e.prototype.getActiveTextures.call(this);for(var i in this._textures)t.push(this._textures[i]);for(var i in this._textureArrays)for(var r=this._textureArrays[i],n=0;n\nvoid main(void) {\n#include\n#ifdef VERTEXCOLOR\ngl_FragColor=vColor;\n#else\ngl_FragColor=color;\n#endif\n}");x.a.ShadersStore.colorPixelShader=T;i(83),i(85),i(84),i(86),i(87),i(88);var E="\nattribute vec3 position;\n#ifdef VERTEXCOLOR\nattribute vec4 color;\n#endif\n#include\n#include\n\n#include\nuniform mat4 viewProjection;\n#ifdef MULTIVIEW\nuniform mat4 viewProjectionR;\n#endif\n\n#ifdef VERTEXCOLOR\nvarying vec4 vColor;\n#endif\nvoid main(void) {\n#include\n#include\nvec4 worldPos=finalWorld*vec4(position,1.0);\n#ifdef MULTIVIEW\nif (gl_ViewID_OVR == 0u) {\ngl_Position=viewProjection*worldPos;\n} else {\ngl_Position=viewProjectionR*worldPos;\n}\n#else\ngl_Position=viewProjection*worldPos;\n#endif\n#include\n#ifdef VERTEXCOLOR\n\nvColor=color;\n#endif\n}";x.a.ShadersStore.colorVertexShader=E;var M=function(e){function t(t,i,r,n,o,s,l){void 0===i&&(i=null),void 0===r&&(r=null),void 0===n&&(n=null);var c=e.call(this,t,i,r,n,o)||this;c.useVertexColor=s,c.useVertexAlpha=l,c.color=new a.a(1,1,1),c.alpha=1,n&&(c.color=n.color.clone(),c.alpha=n.alpha,c.useVertexColor=n.useVertexColor,c.useVertexAlpha=n.useVertexAlpha),c.intersectionThreshold=.1;var u={attributes:[h.b.PositionKind,"world0","world1","world2","world3"],uniforms:["vClipPlane","vClipPlane2","vClipPlane3","vClipPlane4","vClipPlane5","vClipPlane6","world","viewProjection"],needAlphaBlending:!0,defines:[]};return!1===l&&(u.needAlphaBlending=!1),s?(u.defines.push("#define VERTEXCOLOR"),u.attributes.push(h.b.ColorKind)):(u.uniforms.push("color"),c.color4=new a.b),c._colorShader=new y("colorShader",c.getScene(),"color",u),c}return Object(s.c)(t,e),t.prototype._addClipPlaneDefine=function(e){var t="#define "+e;-1===this._colorShader.options.defines.indexOf(t)&&this._colorShader.options.defines.push(t)},t.prototype._removeClipPlaneDefine=function(e){var t="#define "+e,i=this._colorShader.options.defines.indexOf(t);-1!==i&&this._colorShader.options.defines.splice(i,1)},t.prototype.isReady=function(){var t=this.getScene();return t.clipPlane?this._addClipPlaneDefine("CLIPPLANE"):this._removeClipPlaneDefine("CLIPPLANE"),t.clipPlane2?this._addClipPlaneDefine("CLIPPLANE2"):this._removeClipPlaneDefine("CLIPPLANE2"),t.clipPlane3?this._addClipPlaneDefine("CLIPPLANE3"):this._removeClipPlaneDefine("CLIPPLANE3"),t.clipPlane4?this._addClipPlaneDefine("CLIPPLANE4"):this._removeClipPlaneDefine("CLIPPLANE4"),t.clipPlane5?this._addClipPlaneDefine("CLIPPLANE5"):this._removeClipPlaneDefine("CLIPPLANE5"),t.clipPlane6?this._addClipPlaneDefine("CLIPPLANE6"):this._removeClipPlaneDefine("CLIPPLANE6"),!!this._colorShader.isReady()&&e.prototype.isReady.call(this)},t.prototype.getClassName=function(){return"LinesMesh"},Object.defineProperty(t.prototype,"material",{get:function(){return this._colorShader},set:function(e){},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"checkCollisions",{get:function(){return!1},enumerable:!0,configurable:!0}),t.prototype._bind=function(e,t,i){if(!this._geometry)return this;var r=this._colorShader.getEffect(),n=this.isUnIndexed?null:this._geometry.getIndexBuffer();if(this._geometry._bind(r,n),!this.useVertexColor){var o=this.color,s=o.r,a=o.g,h=o.b;this.color4.set(s,a,h,this.alpha),this._colorShader.setColor4("color",this.color4)}return m.a.BindClipPlane(r,this.getScene()),this},t.prototype._draw=function(e,t,i){if(!this._geometry||!this._geometry.getVertexBuffers()||!this._unIndexed&&!this._geometry.getIndexBuffer())return this;var r=this.getScene().getEngine();return this._unIndexed?r.drawArraysType(p.a.LineListDrawMode,e.verticesStart,e.verticesCount,i):r.drawElementsType(p.a.LineListDrawMode,e.indexStart,e.indexCount,i),this},t.prototype.dispose=function(t){this._colorShader.dispose(!1,!1,!0),e.prototype.dispose.call(this,t)},t.prototype.clone=function(e,i,r){return void 0===i&&(i=null),new t(e,this.getScene(),i,this,r)},t.prototype.createInstance=function(e){return new A(e,this)},t}(n.Mesh),A=function(e){function t(t,i){var r=e.call(this,t,i)||this;return r.intersectionThreshold=i.intersectionThreshold,r}return Object(s.c)(t,e),t.prototype.getClassName=function(){return"InstancedLinesMesh"},t}(d);o.VertexData.CreateLineSystem=function(e){for(var t=[],i=[],r=e.lines,n=e.colors,s=[],a=0,h=0;h0&&(t.push(a-1),t.push(a)),a++}var f=new o.VertexData;return f.indices=t,f.positions=i,n&&(f.colors=s),f},o.VertexData.CreateDashedLines=function(e){var t,i,n=e.dashSize||3,s=e.gapSize||1,a=e.dashNb||200,h=e.points,l=new Array,c=new Array,u=r.e.Zero(),f=0,d=0,p=0,_=0,g=0;for(g=0;g2096103.424&&d!==f))return navigator.msSaveBlob?navigator.msSaveBlob(v(l),p):y(l);h=(l=v(l)).type||a}else if(/([\x80-\xff])/.test(l)){for(var g=0,m=new Uint8Array(l.length),b=m.length;g1)for(var i=1;i=0)return;s[t]="set-cookie"===t?(s[t]?s[t]:[]).concat([i]):s[t]?s[t]+", "+i:i}})),s):s}},function(e,t,i){"use strict";var r=i(40);e.exports=r.isStandardBrowserEnv()?function(){var e,t=/(msie|trident)/i.test(navigator.userAgent),i=document.createElement("a");function n(e){var r=e;return t&&(i.setAttribute("href",r),r=i.href),i.setAttribute("href",r),{href:i.href,protocol:i.protocol?i.protocol.replace(/:$/,""):"",host:i.host,search:i.search?i.search.replace(/^\?/,""):"",hash:i.hash?i.hash.replace(/^#/,""):"",hostname:i.hostname,port:i.port,pathname:"/"===i.pathname.charAt(0)?i.pathname:"/"+i.pathname}}return e=n(window.location.href),function(t){var i=r.isString(t)?n(t):t;return i.protocol===e.protocol&&i.host===e.host}}():function(){return!0}},function(e,t,i){"use strict";var r=i(96);function n(e){if("function"!=typeof e)throw new TypeError("executor must be a function.");var t;this.promise=new Promise((function(e){t=e}));var i=this;e((function(e){i.reason||(i.reason=new r(e),t(i.reason))}))}n.prototype.throwIfRequested=function(){if(this.reason)throw this.reason},n.source=function(){var e;return{token:new n((function(t){e=t})),cancel:e}},e.exports=n},function(e,t,i){"use strict";e.exports=function(e){return function(t){return e.apply(null,t)}}},function(e,t,i){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.AnnotationManager=void 0;var r=i(57),n=i(78),o=i(131),s=i(98),a=i(97),h=i(99),l=i(121),c=function(e,t,i,n){this.size=1;var o=h.LinesBuilder.CreateLineSystem("ls",{lines:[[e,t]],updatable:!0},i);o.color=new r.Color3(0,0,0),void 0!==n&&(o.color=r.Color3.FromHexString(n)),this._lines=o,l.CylinderBuilder.CreateCylinder("tip",{diameterTop:0,diameterBottom:this.size,tessellation:36},i).position=t},u=function(){function e(e,t,i,r){this.size=100,this.color="black",this.fixed=!1;var o=n.PlaneBuilder.CreatePlane("label",{width:5,height:5},i);void 0!==r&&(this.color=r),o.position=t;var h=s.AdvancedDynamicTexture.CreateForMesh(o),l=new a.Rectangle;l.color="red",l.alpha=0,h.addControl(l),this._background=l;var c=new a.TextBlock;c.text=e,c.color=this.color,c.fontSize=this.size,h.addControl(c),this._text=c,this.fixed||d(o),this._label=o}return e.prototype.setText=function(e){this._text.text=e},e.prototype.update=function(e,t){var i=r.Vector3.Cross(e.position,r.Axis.Y),n=r.Vector3.Cross(i,e.position),o=r.Vector3.Cross(i,n);if(this._label.rotation=r.Vector3.RotationFromAxis(i,n,o),!this.fixed){var s=t.meshUnderPointer;this._label===s?this._background.alpha=1:this._background.alpha=0}},e.prototype.fix=function(){this._label.removeBehavior(this._label.getBehaviorByName("PointerDrag")),this.fixed=!0},e.prototype.unfix=function(){d(this._label),this.fixed=!1},e.prototype.dispose=function(){this._text.dispose(),this._background.dispose(),this._label.dispose()},e.prototype.export=function(){return[this._label.position.x,this._label.position.y,this._label.position.z,this._text.text]},e}(),f=function(){function e(e,t,i,r){this._editLabelForms=[],this._showLabels=!1,this._arrows=[],this._showArrows=!1,this.labels=[],this.fixedLabels=!1,this.fixedArrows=!1,this._canvas=e,this._scene=t,this._ymax=i,this._camera=r,this._createLabelForms()}return e.prototype._createLabelForms=function(){var e=document.createElement("div");e.className="bbp label-control",e.style.display="none",e.style.top=this._canvas.clientTop+40+"px",e.style.left=this._canvas.clientTop+5+"px";var t=document.createElement("div");t.className="label-form";var i=document.createElement("label");i.innerText="Label Text:",i.htmlFor="addLabelInput";var r=document.createElement("input");r.name="addLabelInput",r.type="text",this._addLabelTextInput=r;var n=document.createElement("button");n.innerText="Add Label",n.onclick=this._addLabelBtnClick.bind(this),t.appendChild(i),t.appendChild(r),t.appendChild(n),e.appendChild(t);var o=document.createElement("div");o.className="edit-container",o.style.maxHeight=(this._canvas.height-100).toString()+"px",e.appendChild(o),this._editLabelContainer=o,this._labelControlBox=e,this._canvas.parentNode.appendChild(e)},e.prototype.update=function(){if(this._showArrows,this._showLabels)for(var e=0;er){var i=parseInt(e.dataset.labelnum),n=(i-1).toString();e.dataset.labelnum=n,e.querySelector('input[data-labelnum="'+i+'"]').dataset.labelnum=n,e.querySelector('button[data-labelnum="'+i+'"]').dataset.labelnum=n}})),t.parentNode.removeChild(t)},e.prototype.exportLabels=function(){for(var e=[],t=0;t1)?1:e.arc||1,g=0===e.sideOrientation?0:e.sideOrientation||s.VertexData.DEFAULTSIDE,m=e.faceUV||new Array(3),b=e.faceColors,v=2+(1+(1!==_&&d?2:0))*(f?u:1);for(l=0;l0&&(r="+"),+(Math.round(parseFloat(+i[0].toString()+"e"+r.toString()+(+i[1].toString()+t.toString())))+"e-"+t)}return+(Math.round(parseFloat(e.toString()+"e+"+t.toString()))+"e-"+t)},e.prototype._createAxes=function(e){void 0===e&&(e=!1),e&&(this.axisData.tickBreaks[0]=1,this.axisData.tickBreaks[2]=1);var t=this.axisData.tickBreaks[0]*this.axisData.scale[0],i=this.axisData.tickBreaks[1]*this.axisData.scale[1],r=this.axisData.tickBreaks[2]*this.axisData.scale[2],s=Math.floor(this.axisData.range[0][0]/t)*t,a=Math.floor(this.axisData.range[1][0]/i)*i,h=Math.floor(this.axisData.range[2][0]/r)*r,l=Math.ceil(this.axisData.range[0][1]/t)*t,c=Math.ceil(this.axisData.range[1][1]/i)*i,u=Math.ceil(this.axisData.range[2][1]/r)*r;if(this.axisData.showAxes[0]){var f=n.LinesBuilder.CreateLines("axisX",{points:[new o.Vector3(s,a,h),new o.Vector3(l,a,h)]},this._scene);f.color=o.Color3.FromHexString(this.axisData.color[0]),this._axes.push(f);var d=this._makeTextPlane(this.axisData.axisLabels[0],1,this.axisData.color[0]);d.position=new o.Vector3(l/2,a-.5*c,h),this._axisLabels.push(d);for(var p=[],_=0;_<-Math.ceil(this.axisData.range[0][0]/t);_++)p.push(-(_+1)*t);for(_=0;_<=Math.ceil(this.axisData.range[0][1]/t);_++)p.push(_*t);var g=0;e&&(g=1);for(_=g;_1e4){var e=new o.Mesh("custom",this._scene),t=[],i=[];if(this._folded)for(var r=0;r1)?1:e.arc||1,h=e.slice&&e.slice<=0?1:e.slice||1,l=0===e.sideOrientation?0:e.sideOrientation||o.VertexData.DEFAULTSIDE,c=new r.e(i/2,n/2,s/2),u=2+t,f=2*u,d=[],p=[],_=[],g=[],m=0;m<=u;m++){for(var b=m/u,v=b*Math.PI*h,y=0;y<=f;y++){var x=y/f,T=x*Math.PI*2*a,E=r.a.RotationZ(-v),M=r.a.RotationY(T),A=r.e.TransformCoordinates(r.e.Up(),E),O=r.e.TransformCoordinates(A,M),C=O.multiply(c),S=O.divide(c).normalize();p.push(C.x,C.y,C.z),_.push(S.x,S.y,S.z),g.push(x,b)}if(m>0)for(var P=p.length/3,R=P-2*(f+1);R+f+20){var l=n*this.yScale;(c=s.BoxBuilder.CreateBox("box_"+t+"-"+r,{height:l,width:this.xScale*this._size,depth:this.zScale*this._size},this._scene)).position=new o.Vector3(t*this.xScale+.5*this.xScale,l/2,r*this.zScale+.5*this.zScale),(u=new h.StandardMaterial("box_"+t+"-"+r+"_color",this._scene)).alpha=1,u.diffuseColor=o.Color3.FromHexString(this._coordColors[r+t*i.length].substring(0,7)),c.material=u,e.push(c)}else{var c,u;(c=a.PlaneBuilder.CreatePlane("box_"+t+"-"+r,{width:this.xScale*this._size,height:this.zScale*this._size},this._scene)).position=new o.Vector3(t*this.xScale+.5*this.xScale,0,r*this.zScale+.5*this.zScale),c.rotation.x=Math.PI/2,(u=new h.StandardMaterial("box_"+t+"-"+r+"_color",this._scene)).alpha=1,u.diffuseColor=o.Color3.FromHexString(this._coordColors[r+t*i.length].substring(0,7)),u.backFaceCulling=!1,c.material=u,e.push(c)}}this.meshes=e,Object.defineProperty(this,"alpha",{set:function(e){for(var t=0;t0},enumerable:!0,configurable:!0}),e.prototype.init=function(){},e.prototype.attach=function(e){var t=this;this._attachedCamera=e;var i=this._attachedCamera.getScene();this._onPrePointerObservableObserver=i.onPrePointerObservable.add((function(e){e.type!==c.a.POINTERDOWN?e.type===c.a.POINTERUP&&(t._isPointerDown=!1):t._isPointerDown=!0})),this._onAfterCheckInputsObserver=e.onAfterCheckInputsObservable.add((function(){var e=u.a.Now,i=0;null!=t._lastFrameTime&&(i=e-t._lastFrameTime),t._lastFrameTime=e,t._applyUserInteraction();var r=e-t._lastInteractionTime-t._idleRotationWaitTime,n=Math.max(Math.min(r/t._idleRotationSpinupTime,1),0);t._cameraRotationSpeed=t._idleRotationSpeed*n,t._attachedCamera&&(t._attachedCamera.alpha-=t._cameraRotationSpeed*(i/1e3))}))},e.prototype.detach=function(){if(this._attachedCamera){var e=this._attachedCamera.getScene();this._onPrePointerObservableObserver&&e.onPrePointerObservable.remove(this._onPrePointerObservableObserver),this._attachedCamera.onAfterCheckInputsObservable.remove(this._onAfterCheckInputsObserver),this._attachedCamera=null}},e.prototype._userIsZooming=function(){return!!this._attachedCamera&&0!==this._attachedCamera.inertialRadiusOffset},e.prototype._shouldAnimationStopForInteraction=function(){if(!this._attachedCamera)return!1;var e=!1;return this._lastFrameRadius===this._attachedCamera.radius&&0!==this._attachedCamera.inertialRadiusOffset&&(e=!0),this._lastFrameRadius=this._attachedCamera.radius,this._zoomStopsAnimation?e:this._userIsZooming()},e.prototype._applyUserInteraction=function(){this._userIsMoving()&&!this._shouldAnimationStopForInteraction()&&(this._lastInteractionTime=u.a.Now)},e.prototype._userIsMoving=function(){return!!this._attachedCamera&&(0!==this._attachedCamera.inertialAlphaOffset||0!==this._attachedCamera.inertialBetaOffset||0!==this._attachedCamera.inertialRadiusOffset||0!==this._attachedCamera.inertialPanningX||0!==this._attachedCamera.inertialPanningY||this._isPointerDown)},e}(),d=i(70),p=function(){function e(){this._easingMode=e.EASINGMODE_EASEIN}return e.prototype.setEasingMode=function(e){var t=Math.min(Math.max(e,0),2);this._easingMode=t},e.prototype.getEasingMode=function(){return this._easingMode},e.prototype.easeInCore=function(e){throw new Error("You must implement this method")},e.prototype.ease=function(t){switch(this._easingMode){case e.EASINGMODE_EASEIN:return this.easeInCore(t);case e.EASINGMODE_EASEOUT:return 1-this.easeInCore(1-t)}return t>=.5?.5*(1-this.easeInCore(2*(1-t)))+.5:.5*this.easeInCore(2*t)},e.EASINGMODE_EASEIN=0,e.EASINGMODE_EASEOUT=1,e.EASINGMODE_EASEINOUT=2,e}(),_=(function(e){function t(){return null!==e&&e.apply(this,arguments)||this}Object(n.c)(t,e),t.prototype.easeInCore=function(e){return e=Math.max(0,Math.min(1,e)),1-Math.sqrt(1-e*e)}}(p),function(e){function t(t){void 0===t&&(t=1);var i=e.call(this)||this;return i.amplitude=t,i}return Object(n.c)(t,e),t.prototype.easeInCore=function(e){var t=Math.max(0,this.amplitude);return Math.pow(e,3)-e*t*Math.sin(3.141592653589793*e)},t}(p)),g=(function(e){function t(t,i){void 0===t&&(t=3),void 0===i&&(i=2);var r=e.call(this)||this;return r.bounces=t,r.bounciness=i,r}Object(n.c)(t,e),t.prototype.easeInCore=function(e){var t=Math.max(0,this.bounces),i=this.bounciness;i<=1&&(i=1.001);var r=Math.pow(i,t),n=1-i,o=(1-r)/n+.5*r,s=e*o,a=Math.log(-s*(1-i)+1)/Math.log(i),h=Math.floor(a),l=h+1,c=(1-Math.pow(i,h))/(n*o),u=.5*(c+(1-Math.pow(i,l))/(n*o)),f=e-u,d=u-c;return-Math.pow(1/i,t-h)/(d*d)*(f-d)*(f+d)}}(p),function(e){function t(){return null!==e&&e.apply(this,arguments)||this}Object(n.c)(t,e),t.prototype.easeInCore=function(e){return e*e*e}}(p),function(e){function t(t,i){void 0===t&&(t=3),void 0===i&&(i=3);var r=e.call(this)||this;return r.oscillations=t,r.springiness=i,r}Object(n.c)(t,e),t.prototype.easeInCore=function(e){var t=Math.max(0,this.oscillations),i=Math.max(0,this.springiness);return(0==i?e:(Math.exp(i*e)-1)/(Math.exp(i)-1))*Math.sin((6.283185307179586*t+1.5707963267948966)*e)}}(p),function(e){function t(t){void 0===t&&(t=2);var i=e.call(this)||this;return i.exponent=t,i}return Object(n.c)(t,e),t.prototype.easeInCore=function(e){return this.exponent<=0?e:(Math.exp(this.exponent*e)-1)/(Math.exp(this.exponent)-1)},t}(p)),m=(function(e){function t(t){void 0===t&&(t=2);var i=e.call(this)||this;return i.power=t,i}Object(n.c)(t,e),t.prototype.easeInCore=function(e){var t=Math.max(0,this.power);return Math.pow(e,t)}}(p),function(e){function t(){return null!==e&&e.apply(this,arguments)||this}Object(n.c)(t,e),t.prototype.easeInCore=function(e){return e*e}}(p),function(e){function t(){return null!==e&&e.apply(this,arguments)||this}Object(n.c)(t,e),t.prototype.easeInCore=function(e){return e*e*e*e}}(p),function(e){function t(){return null!==e&&e.apply(this,arguments)||this}Object(n.c)(t,e),t.prototype.easeInCore=function(e){return e*e*e*e*e}}(p),function(e){function t(){return null!==e&&e.apply(this,arguments)||this}Object(n.c)(t,e),t.prototype.easeInCore=function(e){return 1-Math.sin(1.5707963267948966*(1-e))}}(p),function(e){function t(t,i,r,n){void 0===t&&(t=0),void 0===i&&(i=0),void 0===r&&(r=1),void 0===n&&(n=1);var o=e.call(this)||this;return o.x1=t,o.y1=i,o.x2=r,o.y2=n,o}Object(n.c)(t,e),t.prototype.easeInCore=function(e){return d.c.Interpolate(e,this.x1,this.y1,this.x2,this.y2)}}(p),i(7)),b=i(17),v=i(10);!function(e){e[e.STEP=1]="STEP"}(r||(r={}));var y=function(){function e(e,t,i){this.name=e,this.from=t,this.to=i}return e.prototype.clone=function(){return new e(this.name,this.from,this.to)},e}(),x=i(47),T=function(){function e(t,i,r,n,o,s){this.name=t,this.targetProperty=i,this.framePerSecond=r,this.dataType=n,this.loopMode=o,this.enableBlending=s,this._runtimeAnimations=new Array,this._events=new Array,this.blendingSpeed=.01,this._ranges={},this.targetPropertyPath=i.split("."),this.dataType=n,this.loopMode=void 0===o?e.ANIMATIONLOOPMODE_CYCLE:o}return e._PrepareAnimation=function(t,i,r,n,o,s,h,l){var c=void 0;if(!isNaN(parseFloat(o))&&isFinite(o)?c=e.ANIMATIONTYPE_FLOAT:o instanceof a.b?c=e.ANIMATIONTYPE_QUATERNION:o instanceof a.e?c=e.ANIMATIONTYPE_VECTOR3:o instanceof a.d?c=e.ANIMATIONTYPE_VECTOR2:o instanceof m.a?c=e.ANIMATIONTYPE_COLOR3:o instanceof m.b?c=e.ANIMATIONTYPE_COLOR4:o instanceof x.a&&(c=e.ANIMATIONTYPE_SIZE),null==c)return null;var u=new e(t,i,r,c,h),f=[{frame:0,value:o},{frame:n,value:s}];return u.setKeys(f),void 0!==l&&u.setEasingFunction(l),u},e.CreateAnimation=function(t,i,r,n){var o=new e(t+"Animation",t,r,i,e.ANIMATIONLOOPMODE_CONSTANT);return o.setEasingFunction(n),o},e.CreateAndStartAnimation=function(t,i,r,n,o,s,a,h,l,c){var u=e._PrepareAnimation(t,r,n,o,s,a,h,l);return u?i.getScene().beginDirectAnimation(i,[u],0,o,1===u.loopMode,1,c):null},e.CreateAndStartHierarchyAnimation=function(t,i,r,n,o,s,a,h,l,c,u){var f=e._PrepareAnimation(t,n,o,s,a,h,l,c);return f?i.getScene().beginDirectHierarchyAnimation(i,r,[f],0,s,1===f.loopMode,1,u):null},e.CreateMergeAndStartAnimation=function(t,i,r,n,o,s,a,h,l,c){var u=e._PrepareAnimation(t,r,n,o,s,a,h,l);return u?(i.animations.push(u),i.getScene().beginAnimation(i,0,o,1===u.loopMode,1,c)):null},e.TransitionTo=function(e,t,i,r,n,o,s,a){if(void 0===a&&(a=null),s<=0)return i[e]=t,a&&a(),null;var h=n*(s/1e3);o.setKeys([{frame:0,value:i[e].clone?i[e].clone():i[e]},{frame:h,value:t}]),i.animations||(i.animations=[]),i.animations.push(o);var l=r.beginAnimation(i,0,h,!1);return l.onAnimationEnd=a,l},Object.defineProperty(e.prototype,"runtimeAnimations",{get:function(){return this._runtimeAnimations},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"hasRunningRuntimeAnimations",{get:function(){for(var e=0,t=this._runtimeAnimations;e=0;o--)this._keys[o].frame>=r&&this._keys[o].frame<=n&&this._keys.splice(o,1);this._ranges[e]=null}},e.prototype.getRange=function(e){return this._ranges[e]},e.prototype.getKeys=function(){return this._keys},e.prototype.getHighestFrame=function(){for(var e=0,t=0,i=this._keys.length;t0)return i.highLimitValue.clone?i.highLimitValue.clone():i.highLimitValue;var n=this._keys;if(1===n.length)return this._getKeyValue(n[0].value);var o=i.key;if(n[o].frame>=t)for(;o-1>=0&&n[o].frame>=t;)o--;for(var s=o;s=t){i.key=s;var h=n[s],l=this._getKeyValue(h.value);if(h.interpolation===r.STEP)return l;var c=this._getKeyValue(a.value),u=void 0!==h.outTangent&&void 0!==a.inTangent,f=a.frame-h.frame,d=(t-h.frame)/f,p=this.getEasingFunction();switch(null!=p&&(d=p.ease(d)),this.dataType){case e.ANIMATIONTYPE_FLOAT:var _=u?this.floatInterpolateFunctionWithTangents(l,h.outTangent*f,c,a.inTangent*f,d):this.floatInterpolateFunction(l,c,d);switch(i.loopMode){case e.ANIMATIONLOOPMODE_CYCLE:case e.ANIMATIONLOOPMODE_CONSTANT:return _;case e.ANIMATIONLOOPMODE_RELATIVE:return i.offsetValue*i.repeatCount+_}break;case e.ANIMATIONTYPE_QUATERNION:var g=u?this.quaternionInterpolateFunctionWithTangents(l,h.outTangent.scale(f),c,a.inTangent.scale(f),d):this.quaternionInterpolateFunction(l,c,d);switch(i.loopMode){case e.ANIMATIONLOOPMODE_CYCLE:case e.ANIMATIONLOOPMODE_CONSTANT:return g;case e.ANIMATIONLOOPMODE_RELATIVE:return g.addInPlace(i.offsetValue.scale(i.repeatCount))}return g;case e.ANIMATIONTYPE_VECTOR3:var m=u?this.vector3InterpolateFunctionWithTangents(l,h.outTangent.scale(f),c,a.inTangent.scale(f),d):this.vector3InterpolateFunction(l,c,d);switch(i.loopMode){case e.ANIMATIONLOOPMODE_CYCLE:case e.ANIMATIONLOOPMODE_CONSTANT:return m;case e.ANIMATIONLOOPMODE_RELATIVE:return m.add(i.offsetValue.scale(i.repeatCount))}case e.ANIMATIONTYPE_VECTOR2:var b=u?this.vector2InterpolateFunctionWithTangents(l,h.outTangent.scale(f),c,a.inTangent.scale(f),d):this.vector2InterpolateFunction(l,c,d);switch(i.loopMode){case e.ANIMATIONLOOPMODE_CYCLE:case e.ANIMATIONLOOPMODE_CONSTANT:return b;case e.ANIMATIONLOOPMODE_RELATIVE:return b.add(i.offsetValue.scale(i.repeatCount))}case e.ANIMATIONTYPE_SIZE:switch(i.loopMode){case e.ANIMATIONLOOPMODE_CYCLE:case e.ANIMATIONLOOPMODE_CONSTANT:return this.sizeInterpolateFunction(l,c,d);case e.ANIMATIONLOOPMODE_RELATIVE:return this.sizeInterpolateFunction(l,c,d).add(i.offsetValue.scale(i.repeatCount))}case e.ANIMATIONTYPE_COLOR3:switch(i.loopMode){case e.ANIMATIONLOOPMODE_CYCLE:case e.ANIMATIONLOOPMODE_CONSTANT:return this.color3InterpolateFunction(l,c,d);case e.ANIMATIONLOOPMODE_RELATIVE:return this.color3InterpolateFunction(l,c,d).add(i.offsetValue.scale(i.repeatCount))}case e.ANIMATIONTYPE_COLOR4:switch(i.loopMode){case e.ANIMATIONLOOPMODE_CYCLE:case e.ANIMATIONLOOPMODE_CONSTANT:return this.color4InterpolateFunction(l,c,d);case e.ANIMATIONLOOPMODE_RELATIVE:return this.color4InterpolateFunction(l,c,d).add(i.offsetValue.scale(i.repeatCount))}case e.ANIMATIONTYPE_MATRIX:switch(i.loopMode){case e.ANIMATIONLOOPMODE_CYCLE:case e.ANIMATIONLOOPMODE_CONSTANT:if(e.AllowMatricesInterpolation)return this.matrixInterpolateFunction(l,c,d,i.workValue);case e.ANIMATIONLOOPMODE_RELATIVE:return l}}break}}return this._getKeyValue(n[n.length-1].value)},e.prototype.matrixInterpolateFunction=function(t,i,r,n){return e.AllowMatrixDecomposeForInterpolation?n?(a.a.DecomposeLerpToRef(t,i,r,n),n):a.a.DecomposeLerp(t,i,r):n?(a.a.LerpToRef(t,i,r,n),n):a.a.Lerp(t,i,r)},e.prototype.clone=function(){var t=new e(this.name,this.targetPropertyPath.join("."),this.framePerSecond,this.dataType,this.loopMode);if(t.enableBlending=this.enableBlending,t.blendingSpeed=this.blendingSpeed,this._keys&&t.setKeys(this._keys),this._ranges)for(var i in t._ranges={},this._ranges){var r=this._ranges[i];r&&(t._ranges[i]=r.clone())}return t},e.prototype.setKeys=function(e){this._keys=e.slice(0)},e.prototype.serialize=function(){var t={};t.name=this.name,t.property=this.targetProperty,t.framePerSecond=this.framePerSecond,t.dataType=this.dataType,t.loopBehavior=this.loopMode,t.enableBlending=this.enableBlending,t.blendingSpeed=this.blendingSpeed;var i=this.dataType;t.keys=[];for(var r=this.getKeys(),n=0;n=1&&(h=c.values[1]),c.values.length>=2&&(l=c.values[2]);break;case e.ANIMATIONTYPE_QUATERNION:if(i=a.b.FromArray(c.values),c.values.length>=8){var u=a.b.FromArray(c.values.slice(4,8));u.equals(a.b.Zero())||(h=u)}if(c.values.length>=12){var f=a.b.FromArray(c.values.slice(8,12));f.equals(a.b.Zero())||(l=f)}break;case e.ANIMATIONTYPE_MATRIX:i=a.a.FromArray(c.values);break;case e.ANIMATIONTYPE_COLOR3:i=m.a.FromArray(c.values);break;case e.ANIMATIONTYPE_COLOR4:i=m.b.FromArray(c.values);break;case e.ANIMATIONTYPE_VECTOR3:default:i=a.e.FromArray(c.values)}var d={};d.frame=c.frame,d.value=i,null!=h&&(d.inTangent=h),null!=l&&(d.outTangent=l),s.push(d)}if(n.setKeys(s),t.ranges)for(r=0;rl.upperRadiusLimit?l.upperRadiusLimit:h),h):0},e.prototype._maintainCameraAboveGround=function(){var t=this;if(!(this._elevationReturnTime<0)){var i=u.a.Now-this._lastInteractionTime,r=.5*Math.PI-this._defaultElevation,n=.5*Math.PI;if(this._attachedCamera&&!this._betaIsAnimating&&this._attachedCamera.beta>n&&i>=this._elevationReturnWaitTime){this._betaIsAnimating=!0,this.stopAllAnimations(),this._betaTransition||(this._betaTransition=T.CreateAnimation("beta",T.ANIMATIONTYPE_FLOAT,60,e.EasingFunction));var o=T.TransitionTo("beta",r,this._attachedCamera,this._attachedCamera.getScene(),60,this._betaTransition,this._elevationReturnTime,(function(){t._clearAnimationLocks(),t.stopAllAnimations()}));o&&this._animatables.push(o)}}},e.prototype._getFrustumSlope=function(){var e=this._attachedCamera;if(!e)return a.d.Zero();var t=e.getScene().getEngine().getAspectRatio(e),i=Math.tan(e.fov/2),r=i*t;return new a.d(r,i)},e.prototype._clearAnimationLocks=function(){this._betaIsAnimating=!1},e.prototype._applyUserInteraction=function(){this.isUserIsMoving&&(this._lastInteractionTime=u.a.Now,this.stopAllAnimations(),this._clearAnimationLocks())},e.prototype.stopAllAnimations=function(){for(this._attachedCamera&&(this._attachedCamera.animations=[]);this._animatables.length;)this._animatables[0]&&(this._animatables[0].onAnimationEnd=null,this._animatables[0].stop()),this._animatables.shift()},Object.defineProperty(e.prototype,"isUserIsMoving",{get:function(){return!!this._attachedCamera&&(0!==this._attachedCamera.inertialAlphaOffset||0!==this._attachedCamera.inertialBetaOffset||0!==this._attachedCamera.inertialRadiusOffset||0!==this._attachedCamera.inertialPanningX||0!==this._attachedCamera.inertialPanningY||this._isPointerDown)},enumerable:!0,configurable:!0}),e.EasingFunction=new g,e.EasingMode=p.EASINGMODE_EASEINOUT,e.IgnoreBoundsSizeMode=0,e.FitFrustumSidesMode=1,e}(),A=i(20),O=i(16),C=i(35),S=function(e){function t(t,i,r,n){void 0===n&&(n=!0);var o=e.call(this,t,i,r,n)||this;return o.cameraDirection=new a.e(0,0,0),o.cameraRotation=new a.d(0,0),o.updateUpVectorFromRotation=!1,o._tmpQuaternion=new a.b,o.rotation=new a.e(0,0,0),o.speed=2,o.noRotationConstraint=!1,o.lockedTarget=null,o._currentTarget=a.e.Zero(),o._initialFocalDistance=1,o._viewMatrix=a.a.Zero(),o._camMatrix=a.a.Zero(),o._cameraTransformMatrix=a.a.Zero(),o._cameraRotationMatrix=a.a.Zero(),o._referencePoint=new a.e(0,0,1),o._transformedReferencePoint=a.e.Zero(),o._globalCurrentTarget=a.e.Zero(),o._globalCurrentUpVector=a.e.Zero(),o._defaultUp=a.e.Up(),o._cachedRotationZ=0,o._cachedQuaternionRotationZ=0,o}return Object(n.c)(t,e),t.prototype.getFrontPosition=function(e){this.getWorldMatrix();var t=this.getTarget().subtract(this.position);return t.normalize(),t.scaleInPlace(e),this.globalPosition.add(t)},t.prototype._getLockedTargetPosition=function(){return this.lockedTarget?(this.lockedTarget.absolutePosition&&this.lockedTarget.computeWorldMatrix(),this.lockedTarget.absolutePosition||this.lockedTarget):null},t.prototype.storeState=function(){return this._storedPosition=this.position.clone(),this._storedRotation=this.rotation.clone(),this.rotationQuaternion&&(this._storedRotationQuaternion=this.rotationQuaternion.clone()),e.prototype.storeState.call(this)},t.prototype._restoreStateValues=function(){return!!e.prototype._restoreStateValues.call(this)&&(this.position=this._storedPosition.clone(),this.rotation=this._storedRotation.clone(),this.rotationQuaternion&&(this.rotationQuaternion=this._storedRotationQuaternion.clone()),this.cameraDirection.copyFromFloats(0,0,0),this.cameraRotation.copyFromFloats(0,0),!0)},t.prototype._initCache=function(){e.prototype._initCache.call(this),this._cache.lockedTarget=new a.e(Number.MAX_VALUE,Number.MAX_VALUE,Number.MAX_VALUE),this._cache.rotation=new a.e(Number.MAX_VALUE,Number.MAX_VALUE,Number.MAX_VALUE),this._cache.rotationQuaternion=new a.b(Number.MAX_VALUE,Number.MAX_VALUE,Number.MAX_VALUE,Number.MAX_VALUE)},t.prototype._updateCache=function(t){t||e.prototype._updateCache.call(this);var i=this._getLockedTargetPosition();i?this._cache.lockedTarget?this._cache.lockedTarget.copyFrom(i):this._cache.lockedTarget=i.clone():this._cache.lockedTarget=null,this._cache.rotation.copyFrom(this.rotation),this.rotationQuaternion&&this._cache.rotationQuaternion.copyFrom(this.rotationQuaternion)},t.prototype._isSynchronizedViewMatrix=function(){if(!e.prototype._isSynchronizedViewMatrix.call(this))return!1;var t=this._getLockedTargetPosition();return(this._cache.lockedTarget?this._cache.lockedTarget.equals(t):!t)&&(this.rotationQuaternion?this.rotationQuaternion.equals(this._cache.rotationQuaternion):this._cache.rotation.equals(this.rotation))},t.prototype._computeLocalCameraSpeed=function(){var e=this.getEngine();return this.speed*Math.sqrt(e.getDeltaTime()/(100*e.getFps()))},t.prototype.setTarget=function(e){this.upVector.normalize(),this._initialFocalDistance=e.subtract(this.position).length(),this.position.z===e.z&&(this.position.z+=O.a),a.a.LookAtLHToRef(this.position,e,this._defaultUp,this._camMatrix),this._camMatrix.invert(),this.rotation.x=Math.atan(this._camMatrix.m[6]/this._camMatrix.m[10]);var t=e.subtract(this.position);t.x>=0?this.rotation.y=-Math.atan(t.z/t.x)+Math.PI/2:this.rotation.y=-Math.atan(t.z/t.x)-Math.PI/2,this.rotation.z=0,isNaN(this.rotation.x)&&(this.rotation.x=0),isNaN(this.rotation.y)&&(this.rotation.y=0),isNaN(this.rotation.z)&&(this.rotation.z=0),this.rotationQuaternion&&a.b.RotationYawPitchRollToRef(this.rotation.y,this.rotation.x,this.rotation.z,this.rotationQuaternion)},t.prototype.getTarget=function(){return this._currentTarget},t.prototype._decideIfNeedsToMove=function(){return Math.abs(this.cameraDirection.x)>0||Math.abs(this.cameraDirection.y)>0||Math.abs(this.cameraDirection.z)>0},t.prototype._updatePosition=function(){if(this.parent)return this.parent.getWorldMatrix().invertToRef(a.c.Matrix[0]),a.e.TransformNormalToRef(this.cameraDirection,a.c.Matrix[0],a.c.Vector3[0]),void this.position.addInPlace(a.c.Vector3[0]);this.position.addInPlace(this.cameraDirection)},t.prototype._checkInputs=function(){var t=this._decideIfNeedsToMove(),i=Math.abs(this.cameraRotation.x)>0||Math.abs(this.cameraRotation.y)>0;if(t&&this._updatePosition(),i){if(this.rotation.x+=this.cameraRotation.x,this.rotation.y+=this.cameraRotation.y,this.rotationQuaternion)this.rotation.lengthSquared()&&a.b.RotationYawPitchRollToRef(this.rotation.y,this.rotation.x,this.rotation.z,this.rotationQuaternion);if(!this.noRotationConstraint){var r=1.570796;this.rotation.x>r&&(this.rotation.x=r),this.rotation.x<-r&&(this.rotation.x=-r)}}t&&(Math.abs(this.cameraDirection.x)this.camera.pinchToPanMaxDistance)this.pinchDeltaPercentage?this.camera.inertialRadiusOffset+=.001*(r-i)*this.camera.radius*this.pinchDeltaPercentage:this.camera.inertialRadiusOffset+=(r-i)/(this.pinchPrecision*s*(this.angularSensibilityX+this.angularSensibilityY)/2),this._isPinching=!0;else if(0!==this.panningSensibility&&this.multiTouchPanning&&o&&n){a=o.x-n.x,h=o.y-n.y;this.camera.inertialPanningX+=-a/this.panningSensibility,this.camera.inertialPanningY+=h/this.panningSensibility}}}},t.prototype.onButtonDown=function(e){this._isPanClick=e.button===this.camera._panningMouseButton},t.prototype.onButtonUp=function(e){this._twoFingerActivityCount=0,this._isPinching=!1},t.prototype.onLostFocus=function(){this._isPanClick=!1,this._twoFingerActivityCount=0,this._isPinching=!1},Object(n.b)([Object(o.c)()],t.prototype,"buttons",void 0),Object(n.b)([Object(o.c)()],t.prototype,"angularSensibilityX",void 0),Object(n.b)([Object(o.c)()],t.prototype,"angularSensibilityY",void 0),Object(n.b)([Object(o.c)()],t.prototype,"pinchPrecision",void 0),Object(n.b)([Object(o.c)()],t.prototype,"pinchDeltaPercentage",void 0),Object(n.b)([Object(o.c)()],t.prototype,"useNaturalPinchZoom",void 0),Object(n.b)([Object(o.c)()],t.prototype,"panningSensibility",void 0),Object(n.b)([Object(o.c)()],t.prototype,"multiTouchPanning",void 0),Object(n.b)([Object(o.c)()],t.prototype,"multiTouchPanAndZoom",void 0),t}(function(){function e(){this.buttons=[0,1,2]}return e.prototype.attachControl=function(e,t){var i=this,r=this.camera.getEngine(),n=0,o=null;this.pointA=null,this.pointB=null,this._altKey=!1,this._ctrlKey=!1,this._metaKey=!1,this._shiftKey=!1,this._buttonsPressed=0,this._pointerInput=function(s,a){var h=s.event,l="touch"===h.pointerType;if(!r.isInVRExclusivePointerMode&&(s.type===c.a.POINTERMOVE||-1!==i.buttons.indexOf(h.button))){var u=h.srcElement||h.target;if(i._altKey=h.altKey,i._ctrlKey=h.ctrlKey,i._metaKey=h.metaKey,i._shiftKey=h.shiftKey,i._buttonsPressed=h.buttons,r.isPointerLock){var f=h.movementX||h.mozMovementX||h.webkitMovementX||h.msMovementX||0,d=h.movementY||h.mozMovementY||h.webkitMovementY||h.msMovementY||0;i.onTouch(null,f,d),i.pointA=null,i.pointB=null}else if(s.type===c.a.POINTERDOWN&&u){try{u.setPointerCapture(h.pointerId)}catch(e){}null===i.pointA?i.pointA={x:h.clientX,y:h.clientY,pointerId:h.pointerId,type:h.pointerType}:null===i.pointB&&(i.pointB={x:h.clientX,y:h.clientY,pointerId:h.pointerId,type:h.pointerType}),i.onButtonDown(h),t||(h.preventDefault(),e.focus())}else if(s.type===c.a.POINTERDOUBLETAP)i.onDoubleTap(h.pointerType);else if(s.type===c.a.POINTERUP&&u){try{u.releasePointerCapture(h.pointerId)}catch(e){}l||(i.pointB=null),r._badOS?i.pointA=i.pointB=null:i.pointB&&i.pointA&&i.pointA.pointerId==h.pointerId?(i.pointA=i.pointB,i.pointB=null):i.pointA&&i.pointB&&i.pointB.pointerId==h.pointerId?i.pointB=null:i.pointA=i.pointB=null,(0!==n||o)&&(i.onMultiTouch(i.pointA,i.pointB,n,0,o,null),n=0,o=null),i.onButtonUp(h),t||h.preventDefault()}else if(s.type===c.a.POINTERMOVE)if(t||h.preventDefault(),i.pointA&&null===i.pointB){f=h.clientX-i.pointA.x,d=h.clientY-i.pointA.y;i.onTouch(i.pointA,f,d),i.pointA.x=h.clientX,i.pointA.y=h.clientY}else if(i.pointA&&i.pointB){var p=i.pointA.pointerId===h.pointerId?i.pointA:i.pointB;p.x=h.clientX,p.y=h.clientY;var _=i.pointA.x-i.pointB.x,g=i.pointA.y-i.pointB.y,m=_*_+g*g,b={x:(i.pointA.x+i.pointB.x)/2,y:(i.pointA.y+i.pointB.y)/2,pointerId:h.pointerId,type:s.type};i.onMultiTouch(i.pointA,i.pointB,n,m,o,b),o=b,n=m}}},this._observer=this.camera.getScene().onPointerObservable.add(this._pointerInput,c.a.POINTERDOWN|c.a.POINTERUP|c.a.POINTERMOVE),this._onLostFocus=function(){i.pointA=i.pointB=null,n=0,o=null,i.onLostFocus()},e.addEventListener("contextmenu",this.onContextMenu.bind(this),!1);var s=this.camera.getScene().getEngine().getHostWindow();s&&w.b.RegisterTopRootEvents(s,[{name:"blur",handler:this._onLostFocus}])},e.prototype.detachControl=function(e){if(this._onLostFocus){var t=this.camera.getScene().getEngine().getHostWindow();t&&w.b.UnregisterTopRootEvents(t,[{name:"blur",handler:this._onLostFocus}])}e&&this._observer&&(this.camera.getScene().onPointerObservable.remove(this._observer),this._observer=null,this.onContextMenu&&e.removeEventListener("contextmenu",this.onContextMenu),this._onLostFocus=null),this._altKey=!1,this._ctrlKey=!1,this._metaKey=!1,this._shiftKey=!1,this._buttonsPressed=0},e.prototype.getClassName=function(){return"BaseCameraPointersInput"},e.prototype.getSimpleName=function(){return"pointers"},e.prototype.onDoubleTap=function(e){},e.prototype.onTouch=function(e,t,i){},e.prototype.onMultiTouch=function(e,t,i,r,n,o){},e.prototype.onContextMenu=function(e){e.preventDefault()},e.prototype.onButtonDown=function(e){},e.prototype.onButtonUp=function(e){},e.prototype.onLostFocus=function(){},Object(n.b)([Object(o.c)()],e.prototype,"buttons",void 0),e}());R.ArcRotateCameraPointersInput=D;var L=i(45),F=function(){function e(){this.keysUp=[38],this.keysDown=[40],this.keysLeft=[37],this.keysRight=[39],this.keysReset=[220],this.panningSensibility=50,this.zoomingSensibility=25,this.useAltToZoom=!0,this.angularSpeed=.01,this._keys=new Array}return e.prototype.attachControl=function(e,t){var i=this;this._onCanvasBlurObserver||(this._scene=this.camera.getScene(),this._engine=this._scene.getEngine(),this._onCanvasBlurObserver=this._engine.onCanvasBlurObservable.add((function(){i._keys=[]})),this._onKeyboardObserver=this._scene.onKeyboardObservable.add((function(e){var r,n=e.event;n.metaKey||(e.type===L.a.KEYDOWN?(i._ctrlPressed=n.ctrlKey,i._altPressed=n.altKey,(-1!==i.keysUp.indexOf(n.keyCode)||-1!==i.keysDown.indexOf(n.keyCode)||-1!==i.keysLeft.indexOf(n.keyCode)||-1!==i.keysRight.indexOf(n.keyCode)||-1!==i.keysReset.indexOf(n.keyCode))&&(-1===(r=i._keys.indexOf(n.keyCode))&&i._keys.push(n.keyCode),n.preventDefault&&(t||n.preventDefault()))):-1===i.keysUp.indexOf(n.keyCode)&&-1===i.keysDown.indexOf(n.keyCode)&&-1===i.keysLeft.indexOf(n.keyCode)&&-1===i.keysRight.indexOf(n.keyCode)&&-1===i.keysReset.indexOf(n.keyCode)||((r=i._keys.indexOf(n.keyCode))>=0&&i._keys.splice(r,1),n.preventDefault&&(t||n.preventDefault())))})))},e.prototype.detachControl=function(e){this._scene&&(this._onKeyboardObserver&&this._scene.onKeyboardObservable.remove(this._onKeyboardObserver),this._onCanvasBlurObserver&&this._engine.onCanvasBlurObservable.remove(this._onCanvasBlurObserver),this._onKeyboardObserver=null,this._onCanvasBlurObserver=null),this._keys=[]},e.prototype.checkInputs=function(){if(this._onKeyboardObserver)for(var e=this.camera,t=0;t0?i/(1+this.wheelDeltaPercentage):i*(1+this.wheelDeltaPercentage)},e.prototype.attachControl=function(e,t){var i=this;this._wheel=function(e,r){if(e.type===c.a.POINTERWHEEL){var n=e.event,o=0,s=n,a=0;if(a=s.wheelDelta?s.wheelDelta:60*-(n.deltaY||n.detail),i.wheelDeltaPercentage){if((o=i.computeDeltaFromMouseWheelLegacyEvent(a,i.camera.radius))>0){for(var h=i.camera.radius,l=i.camera.inertialRadiusOffset+o,u=0;u<20&&Math.abs(l)>.001;u++)h-=l,l*=i.camera.inertia;h=b.a.Clamp(h,0,Number.MAX_VALUE),o=i.computeDeltaFromMouseWheelLegacyEvent(a,h)}}else o=a/(40*i.wheelPrecision);o&&(i.camera.inertialRadiusOffset+=o),n.preventDefault&&(t||n.preventDefault())}},this._observer=this.camera.getScene().onPointerObservable.add(this._wheel,c.a.POINTERWHEEL)},e.prototype.detachControl=function(e){this._observer&&e&&(this.camera.getScene().onPointerObservable.remove(this._observer),this._observer=null,this._wheel=null)},e.prototype.getClassName=function(){return"ArcRotateCameraMouseWheelInput"},e.prototype.getSimpleName=function(){return"mousewheel"},Object(n.b)([Object(o.c)()],e.prototype,"wheelPrecision",void 0),Object(n.b)([Object(o.c)()],e.prototype,"wheelDeltaPercentage",void 0),e}();R.ArcRotateCameraMouseWheelInput=N;var B=function(e){function t(t){return e.call(this,t)||this}return Object(n.c)(t,e),t.prototype.addMouseWheel=function(){return this.add(new N),this},t.prototype.addPointers=function(){return this.add(new D),this},t.prototype.addKeyboard=function(){return this.add(new F),this},t}(I);h.a.AddNodeConstructor("ArcRotateCamera",(function(e,t){return function(){return new k(e,0,0,1,a.e.Zero(),t)}}));var k=function(e){function t(t,i,r,n,o,h,l){void 0===l&&(l=!0);var c=e.call(this,t,a.e.Zero(),h,l)||this;return c._upVector=a.e.Up(),c.inertialAlphaOffset=0,c.inertialBetaOffset=0,c.inertialRadiusOffset=0,c.lowerAlphaLimit=null,c.upperAlphaLimit=null,c.lowerBetaLimit=.01,c.upperBetaLimit=Math.PI-.01,c.lowerRadiusLimit=null,c.upperRadiusLimit=null,c.inertialPanningX=0,c.inertialPanningY=0,c.pinchToPanMaxDistance=20,c.panningDistanceLimit=null,c.panningOriginTarget=a.e.Zero(),c.panningInertia=.9,c.zoomOnFactor=1,c.targetScreenOffset=a.d.Zero(),c.allowUpsideDown=!0,c.useInputToRestoreState=!0,c._viewMatrix=new a.a,c.panningAxis=new a.e(1,1,0),c.onMeshTargetChangedObservable=new s.a,c.checkCollisions=!1,c.collisionRadius=new a.e(.5,.5,.5),c._previousPosition=a.e.Zero(),c._collisionVelocity=a.e.Zero(),c._newPosition=a.e.Zero(),c._computationVector=a.e.Zero(),c._onCollisionPositionChange=function(e,t,i){void 0===i&&(i=null),i?(c.setPosition(t),c.onCollide&&c.onCollide(i)):c._previousPosition.copyFrom(c._position);var r=Math.cos(c.alpha),n=Math.sin(c.alpha),o=Math.cos(c.beta),s=Math.sin(c.beta);0===s&&(s=1e-4);var a=c._getTargetPosition();c._computationVector.copyFromFloats(c.radius*r*s,c.radius*o,c.radius*n*s),a.addToRef(c._computationVector,c._newPosition),c._position.copyFrom(c._newPosition);var h=c.upVector;c.allowUpsideDown&&c.beta<0&&(h=(h=h.clone()).negate()),c._computeViewMatrix(c._position,a,h),c._viewMatrix.addAtIndex(12,c.targetScreenOffset.x),c._viewMatrix.addAtIndex(13,c.targetScreenOffset.y),c._collisionTriggered=!1},c._target=a.e.Zero(),o&&c.setTarget(o),c.alpha=i,c.beta=r,c.radius=n,c.getViewMatrix(),c.inputs=new B(c),c.inputs.addKeyboard().addMouseWheel().addPointers(),c}return Object(n.c)(t,e),Object.defineProperty(t.prototype,"target",{get:function(){return this._target},set:function(e){this.setTarget(e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"position",{get:function(){return this._position},set:function(e){this.setPosition(e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"upVector",{get:function(){return this._upVector},set:function(e){this._upToYMatrix||(this._YToUpMatrix=new a.a,this._upToYMatrix=new a.a,this._upVector=a.e.Zero()),e.normalize(),this._upVector.copyFrom(e),this.setMatUp()},enumerable:!0,configurable:!0}),t.prototype.setMatUp=function(){a.a.RotationAlignToRef(a.e.UpReadOnly,this._upVector,this._YToUpMatrix),a.a.RotationAlignToRef(this._upVector,a.e.UpReadOnly,this._upToYMatrix)},Object.defineProperty(t.prototype,"angularSensibilityX",{get:function(){var e=this.inputs.attached.pointers;return e?e.angularSensibilityX:0},set:function(e){var t=this.inputs.attached.pointers;t&&(t.angularSensibilityX=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"angularSensibilityY",{get:function(){var e=this.inputs.attached.pointers;return e?e.angularSensibilityY:0},set:function(e){var t=this.inputs.attached.pointers;t&&(t.angularSensibilityY=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"pinchPrecision",{get:function(){var e=this.inputs.attached.pointers;return e?e.pinchPrecision:0},set:function(e){var t=this.inputs.attached.pointers;t&&(t.pinchPrecision=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"pinchDeltaPercentage",{get:function(){var e=this.inputs.attached.pointers;return e?e.pinchDeltaPercentage:0},set:function(e){var t=this.inputs.attached.pointers;t&&(t.pinchDeltaPercentage=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"useNaturalPinchZoom",{get:function(){var e=this.inputs.attached.pointers;return!!e&&e.useNaturalPinchZoom},set:function(e){var t=this.inputs.attached.pointers;t&&(t.useNaturalPinchZoom=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"panningSensibility",{get:function(){var e=this.inputs.attached.pointers;return e?e.panningSensibility:0},set:function(e){var t=this.inputs.attached.pointers;t&&(t.panningSensibility=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"keysUp",{get:function(){var e=this.inputs.attached.keyboard;return e?e.keysUp:[]},set:function(e){var t=this.inputs.attached.keyboard;t&&(t.keysUp=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"keysDown",{get:function(){var e=this.inputs.attached.keyboard;return e?e.keysDown:[]},set:function(e){var t=this.inputs.attached.keyboard;t&&(t.keysDown=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"keysLeft",{get:function(){var e=this.inputs.attached.keyboard;return e?e.keysLeft:[]},set:function(e){var t=this.inputs.attached.keyboard;t&&(t.keysLeft=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"keysRight",{get:function(){var e=this.inputs.attached.keyboard;return e?e.keysRight:[]},set:function(e){var t=this.inputs.attached.keyboard;t&&(t.keysRight=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"wheelPrecision",{get:function(){var e=this.inputs.attached.mousewheel;return e?e.wheelPrecision:0},set:function(e){var t=this.inputs.attached.mousewheel;t&&(t.wheelPrecision=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"wheelDeltaPercentage",{get:function(){var e=this.inputs.attached.mousewheel;return e?e.wheelDeltaPercentage:0},set:function(e){var t=this.inputs.attached.mousewheel;t&&(t.wheelDeltaPercentage=e)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"bouncingBehavior",{get:function(){return this._bouncingBehavior},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"useBouncingBehavior",{get:function(){return null!=this._bouncingBehavior},set:function(e){e!==this.useBouncingBehavior&&(e?(this._bouncingBehavior=new E,this.addBehavior(this._bouncingBehavior)):this._bouncingBehavior&&(this.removeBehavior(this._bouncingBehavior),this._bouncingBehavior=null))},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"framingBehavior",{get:function(){return this._framingBehavior},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"useFramingBehavior",{get:function(){return null!=this._framingBehavior},set:function(e){e!==this.useFramingBehavior&&(e?(this._framingBehavior=new M,this.addBehavior(this._framingBehavior)):this._framingBehavior&&(this.removeBehavior(this._framingBehavior),this._framingBehavior=null))},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"autoRotationBehavior",{get:function(){return this._autoRotationBehavior},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"useAutoRotationBehavior",{get:function(){return null!=this._autoRotationBehavior},set:function(e){e!==this.useAutoRotationBehavior&&(e?(this._autoRotationBehavior=new f,this.addBehavior(this._autoRotationBehavior)):this._autoRotationBehavior&&(this.removeBehavior(this._autoRotationBehavior),this._autoRotationBehavior=null))},enumerable:!0,configurable:!0}),t.prototype._initCache=function(){e.prototype._initCache.call(this),this._cache._target=new a.e(Number.MAX_VALUE,Number.MAX_VALUE,Number.MAX_VALUE),this._cache.alpha=void 0,this._cache.beta=void 0,this._cache.radius=void 0,this._cache.targetScreenOffset=a.d.Zero()},t.prototype._updateCache=function(t){t||e.prototype._updateCache.call(this),this._cache._target.copyFrom(this._getTargetPosition()),this._cache.alpha=this.alpha,this._cache.beta=this.beta,this._cache.radius=this.radius,this._cache.targetScreenOffset.copyFrom(this.targetScreenOffset)},t.prototype._getTargetPosition=function(){if(this._targetHost&&this._targetHost.getAbsolutePosition){var e=this._targetHost.absolutePosition;this._targetBoundingCenter?e.addToRef(this._targetBoundingCenter,this._target):this._target.copyFrom(e)}var t=this._getLockedTargetPosition();return t||this._target},t.prototype.storeState=function(){return this._storedAlpha=this.alpha,this._storedBeta=this.beta,this._storedRadius=this.radius,this._storedTarget=this._getTargetPosition().clone(),this._storedTargetScreenOffset=this.targetScreenOffset.clone(),e.prototype.storeState.call(this)},t.prototype._restoreStateValues=function(){return!!e.prototype._restoreStateValues.call(this)&&(this.setTarget(this._storedTarget.clone()),this.alpha=this._storedAlpha,this.beta=this._storedBeta,this.radius=this._storedRadius,this.targetScreenOffset=this._storedTargetScreenOffset.clone(),this.inertialAlphaOffset=0,this.inertialBetaOffset=0,this.inertialRadiusOffset=0,this.inertialPanningX=0,this.inertialPanningY=0,!0)},t.prototype._isSynchronizedViewMatrix=function(){return!!e.prototype._isSynchronizedViewMatrix.call(this)&&(this._cache._target.equals(this._getTargetPosition())&&this._cache.alpha===this.alpha&&this._cache.beta===this.beta&&this._cache.radius===this.radius&&this._cache.targetScreenOffset.equals(this.targetScreenOffset))},t.prototype.attachControl=function(e,t,i,r){var n=this;void 0===i&&(i=!0),void 0===r&&(r=2),this._useCtrlForPanning=i,this._panningMouseButton=r,this.inputs.attachElement(e,t),this._reset=function(){n.inertialAlphaOffset=0,n.inertialBetaOffset=0,n.inertialRadiusOffset=0,n.inertialPanningX=0,n.inertialPanningY=0}},t.prototype.detachControl=function(e){this.inputs.detachElement(e),this._reset&&this._reset()},t.prototype._checkInputs=function(){if(!this._collisionTriggered){if(this.inputs.checkInputs(),0!==this.inertialAlphaOffset||0!==this.inertialBetaOffset||0!==this.inertialRadiusOffset){var t=this.inertialAlphaOffset;this.beta<=0&&(t*=-1),this.getScene().useRightHandedSystem&&(t*=-1),this.parent&&this.parent._getWorldMatrixDeterminant()<0&&(t*=-1),this.alpha+=t,this.beta+=this.inertialBetaOffset,this.radius-=this.inertialRadiusOffset,this.inertialAlphaOffset*=this.inertia,this.inertialBetaOffset*=this.inertia,this.inertialRadiusOffset*=this.inertia,Math.abs(this.inertialAlphaOffset)Math.PI&&(this.beta=this.beta-2*Math.PI):this.betathis.upperBetaLimit&&(this.beta=this.upperBetaLimit),null!==this.lowerAlphaLimit&&this.alphathis.upperAlphaLimit&&(this.alpha=this.upperAlphaLimit),null!==this.lowerRadiusLimit&&this.radiusthis.upperRadiusLimit&&(this.radius=this.upperRadiusLimit,this.inertialRadiusOffset=0)},t.prototype.rebuildAnglesAndRadius=function(){this._position.subtractToRef(this._getTargetPosition(),this._computationVector),0===this._upVector.x&&1===this._upVector.y&&0===this._upVector.z||a.e.TransformCoordinatesToRef(this._computationVector,this._upToYMatrix,this._computationVector),this.radius=this._computationVector.length(),0===this.radius&&(this.radius=1e-4),0===this._computationVector.x&&0===this._computationVector.z?this.alpha=Math.PI/2:this.alpha=Math.acos(this._computationVector.x/Math.sqrt(Math.pow(this._computationVector.x,2)+Math.pow(this._computationVector.z,2))),this._computationVector.z<0&&(this.alpha=2*Math.PI-this.alpha),this.beta=Math.acos(this._computationVector.y/this.radius),this._checkLimits()},t.prototype.setPosition=function(e){this._position.equals(e)||(this._position.copyFrom(e),this.rebuildAnglesAndRadius())},t.prototype.setTarget=function(e,t,i){if(void 0===t&&(t=!1),void 0===i&&(i=!1),e.getBoundingInfo)this._targetBoundingCenter=t?e.getBoundingInfo().boundingBox.centerWorld.clone():null,e.computeWorldMatrix(),this._targetHost=e,this._target=this._getTargetPosition(),this.onMeshTargetChangedObservable.notifyObservers(this._targetHost);else{var r=e,n=this._getTargetPosition();if(n&&!i&&n.equals(r))return;this._targetHost=null,this._target=r,this._targetBoundingCenter=null,this.onMeshTargetChangedObservable.notifyObservers(null)}this.rebuildAnglesAndRadius()},t.prototype._getViewMatrix=function(){var e=Math.cos(this.alpha),t=Math.sin(this.alpha),i=Math.cos(this.beta),r=Math.sin(this.beta);0===r&&(r=1e-4);var n=this._getTargetPosition();if(this._computationVector.copyFromFloats(this.radius*e*r,this.radius*i,this.radius*t*r),0===this._upVector.x&&1===this._upVector.y&&0===this._upVector.z||a.e.TransformCoordinatesToRef(this._computationVector,this._YToUpMatrix,this._computationVector),n.addToRef(this._computationVector,this._newPosition),this.getScene().collisionsEnabled&&this.checkCollisions){var o=this.getScene().collisionCoordinator;this._collider||(this._collider=o.createCollider()),this._collider._radius=this.collisionRadius,this._newPosition.subtractToRef(this._position,this._collisionVelocity),this._collisionTriggered=!0,o.getNewPosition(this._position,this._collisionVelocity,this._collider,3,null,this._onCollisionPositionChange,this.uniqueId)}else{this._position.copyFrom(this._newPosition);var s=this.upVector;this.allowUpsideDown&&r<0&&(s=s.negate()),this._computeViewMatrix(this._position,n,s),this._viewMatrix.addAtIndex(12,this.targetScreenOffset.x),this._viewMatrix.addAtIndex(13,this.targetScreenOffset.y)}return this._currentTarget=n,this._viewMatrix},t.prototype.zoomOn=function(e,t){void 0===t&&(t=!1),e=e||this.getScene().meshes;var i=l.Mesh.MinMax(e),r=a.e.Distance(i.min,i.max);this.radius=r*this.zoomOnFactor,this.focusOn({min:i.min,max:i.max,distance:r},t)},t.prototype.focusOn=function(e,t){var i,r;if(void 0===t&&(t=!1),void 0===e.min){var n=e||this.getScene().meshes;i=l.Mesh.MinMax(n),r=a.e.Distance(i.min,i.max)}else{i=e,r=e.distance}this._target=l.Mesh.Center(i),t||(this.maxZ=2*r)},t.prototype.createRigCamera=function(e,i){var r=0;switch(this.cameraRigMode){case A.a.RIG_MODE_STEREOSCOPIC_ANAGLYPH:case A.a.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL:case A.a.RIG_MODE_STEREOSCOPIC_OVERUNDER:case A.a.RIG_MODE_STEREOSCOPIC_INTERLACED:case A.a.RIG_MODE_VR:r=this._cameraRigParams.stereoHalfAngle*(0===i?1:-1);break;case A.a.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED:r=this._cameraRigParams.stereoHalfAngle*(0===i?-1:1)}var n=new t(e,this.alpha+r,this.beta,this.radius,this._target,this.getScene());return n._cameraRigParams={},n.isRigCamera=!0,n.rigParent=this,n},t.prototype._updateRigCameras=function(){var t=this._rigCameras[0],i=this._rigCameras[1];switch(t.beta=i.beta=this.beta,this.cameraRigMode){case A.a.RIG_MODE_STEREOSCOPIC_ANAGLYPH:case A.a.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL:case A.a.RIG_MODE_STEREOSCOPIC_OVERUNDER:case A.a.RIG_MODE_STEREOSCOPIC_INTERLACED:case A.a.RIG_MODE_VR:t.alpha=this.alpha-this._cameraRigParams.stereoHalfAngle,i.alpha=this.alpha+this._cameraRigParams.stereoHalfAngle;break;case A.a.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED:t.alpha=this.alpha+this._cameraRigParams.stereoHalfAngle,i.alpha=this.alpha-this._cameraRigParams.stereoHalfAngle}e.prototype._updateRigCameras.call(this)},t.prototype.dispose=function(){this.inputs.clear(),e.prototype.dispose.call(this)},t.prototype.getClassName=function(){return"ArcRotateCamera"},Object(n.b)([Object(o.c)()],t.prototype,"alpha",void 0),Object(n.b)([Object(o.c)()],t.prototype,"beta",void 0),Object(n.b)([Object(o.c)()],t.prototype,"radius",void 0),Object(n.b)([Object(o.k)("target")],t.prototype,"_target",void 0),Object(n.b)([Object(o.k)("upVector")],t.prototype,"_upVector",void 0),Object(n.b)([Object(o.c)()],t.prototype,"inertialAlphaOffset",void 0),Object(n.b)([Object(o.c)()],t.prototype,"inertialBetaOffset",void 0),Object(n.b)([Object(o.c)()],t.prototype,"inertialRadiusOffset",void 0),Object(n.b)([Object(o.c)()],t.prototype,"lowerAlphaLimit",void 0),Object(n.b)([Object(o.c)()],t.prototype,"upperAlphaLimit",void 0),Object(n.b)([Object(o.c)()],t.prototype,"lowerBetaLimit",void 0),Object(n.b)([Object(o.c)()],t.prototype,"upperBetaLimit",void 0),Object(n.b)([Object(o.c)()],t.prototype,"lowerRadiusLimit",void 0),Object(n.b)([Object(o.c)()],t.prototype,"upperRadiusLimit",void 0),Object(n.b)([Object(o.c)()],t.prototype,"inertialPanningX",void 0),Object(n.b)([Object(o.c)()],t.prototype,"inertialPanningY",void 0),Object(n.b)([Object(o.c)()],t.prototype,"pinchToPanMaxDistance",void 0),Object(n.b)([Object(o.c)()],t.prototype,"panningDistanceLimit",void 0),Object(n.b)([Object(o.k)()],t.prototype,"panningOriginTarget",void 0),Object(n.b)([Object(o.c)()],t.prototype,"panningInertia",void 0),Object(n.b)([Object(o.c)()],t.prototype,"zoomOnFactor",void 0),Object(n.b)([Object(o.c)()],t.prototype,"targetScreenOffset",void 0),Object(n.b)([Object(o.c)()],t.prototype,"allowUpsideDown",void 0),Object(n.b)([Object(o.c)()],t.prototype,"useInputToRestoreState",void 0),t}(S)},function(e,t,i){"use strict";i.r(t),i.d(t,"v1",(function(){return _})),i.d(t,"v3",(function(){return A})),i.d(t,"v4",(function(){return O})),i.d(t,"v5",(function(){return P})),i.d(t,"NIL",(function(){return R})),i.d(t,"version",(function(){return I})),i.d(t,"validate",(function(){return a})),i.d(t,"stringify",(function(){return f})),i.d(t,"parse",(function(){return g}));var r="undefined"!=typeof crypto&&crypto.getRandomValues&&crypto.getRandomValues.bind(crypto)||"undefined"!=typeof msCrypto&&"function"==typeof msCrypto.getRandomValues&&msCrypto.getRandomValues.bind(msCrypto),n=new Uint8Array(16);function o(){if(!r)throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");return r(n)}var s=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;for(var a=function(e){return"string"==typeof e&&s.test(e)},h=[],l=0;l<256;++l)h.push((l+256).toString(16).substr(1));var c,u,f=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=(h[e[t+0]]+h[e[t+1]]+h[e[t+2]]+h[e[t+3]]+"-"+h[e[t+4]]+h[e[t+5]]+"-"+h[e[t+6]]+h[e[t+7]]+"-"+h[e[t+8]]+h[e[t+9]]+"-"+h[e[t+10]]+h[e[t+11]]+h[e[t+12]]+h[e[t+13]]+h[e[t+14]]+h[e[t+15]]).toLowerCase();if(!a(i))throw TypeError("Stringified UUID is invalid");return i},d=0,p=0;var _=function(e,t,i){var r=t&&i||0,n=t||new Array(16),s=(e=e||{}).node||c,a=void 0!==e.clockseq?e.clockseq:u;if(null==s||null==a){var h=e.random||(e.rng||o)();null==s&&(s=c=[1|h[0],h[1],h[2],h[3],h[4],h[5]]),null==a&&(a=u=16383&(h[6]<<8|h[7]))}var l=void 0!==e.msecs?e.msecs:Date.now(),_=void 0!==e.nsecs?e.nsecs:p+1,g=l-d+(_-p)/1e4;if(g<0&&void 0===e.clockseq&&(a=a+1&16383),(g<0||l>d)&&void 0===e.nsecs&&(_=0),_>=1e4)throw new Error("uuid.v1(): Can't create more than 10M uuids/sec");d=l,p=_,u=a;var m=(1e4*(268435455&(l+=122192928e5))+_)%4294967296;n[r++]=m>>>24&255,n[r++]=m>>>16&255,n[r++]=m>>>8&255,n[r++]=255&m;var b=l/4294967296*1e4&268435455;n[r++]=b>>>8&255,n[r++]=255&b,n[r++]=b>>>24&15|16,n[r++]=b>>>16&255,n[r++]=a>>>8|128,n[r++]=255&a;for(var v=0;v<6;++v)n[r+v]=s[v];return t||f(n)};var g=function(e){if(!a(e))throw TypeError("Invalid UUID");var t,i=new Uint8Array(16);return i[0]=(t=parseInt(e.slice(0,8),16))>>>24,i[1]=t>>>16&255,i[2]=t>>>8&255,i[3]=255&t,i[4]=(t=parseInt(e.slice(9,13),16))>>>8,i[5]=255&t,i[6]=(t=parseInt(e.slice(14,18),16))>>>8,i[7]=255&t,i[8]=(t=parseInt(e.slice(19,23),16))>>>8,i[9]=255&t,i[10]=(t=parseInt(e.slice(24,36),16))/1099511627776&255,i[11]=t/4294967296&255,i[12]=t>>>24&255,i[13]=t>>>16&255,i[14]=t>>>8&255,i[15]=255&t,i};var m=function(e,t,i){function r(e,r,n,o){if("string"==typeof e&&(e=function(e){e=unescape(encodeURIComponent(e));for(var t=[],i=0;i>>9<<4)+1}function v(e,t){var i=(65535&e)+(65535&t);return(e>>16)+(t>>16)+(i>>16)<<16|65535&i}function y(e,t,i,r,n,o){return v((s=v(v(t,e),v(r,o)))<<(a=n)|s>>>32-a,i);var s,a}function x(e,t,i,r,n,o,s){return y(t&i|~t&r,e,t,n,o,s)}function T(e,t,i,r,n,o,s){return y(t&r|i&~r,e,t,n,o,s)}function E(e,t,i,r,n,o,s){return y(t^i^r,e,t,n,o,s)}function M(e,t,i,r,n,o,s){return y(i^(t|~r),e,t,n,o,s)}var A=m("v3",48,(function(e){if("string"==typeof e){var t=unescape(encodeURIComponent(e));e=new Uint8Array(t.length);for(var i=0;i>5]>>>n%32&255,s=parseInt(r.charAt(o>>>4&15)+r.charAt(15&o),16);t.push(s)}return t}(function(e,t){e[t>>5]|=128<>5]|=(255&e[r/8])<>>32-t}var P=m("v5",80,(function(e){var t=[1518500249,1859775393,2400959708,3395469782],i=[1732584193,4023233417,2562383102,271733878,3285377520];if("string"==typeof e){var r=unescape(encodeURIComponent(e));e=[];for(var n=0;n>>0;v=b,b=m,m=S(g,30)>>>0,g=_,_=T}i[0]=i[0]+_>>>0,i[1]=i[1]+g>>>0,i[2]=i[2]+m>>>0,i[3]=i[3]+b>>>0,i[4]=i[4]+v>>>0}return[i[0]>>24&255,i[0]>>16&255,i[0]>>8&255,255&i[0],i[1]>>24&255,i[1]>>16&255,i[1]>>8&255,255&i[1],i[2]>>24&255,i[2]>>16&255,i[2]>>8&255,255&i[2],i[3]>>24&255,i[3]>>16&255,i[3]>>8&255,255&i[3],i[4]>>24&255,i[4]>>16&255,i[4]>>8&255,255&i[4]]})),R="00000000-0000-0000-0000-000000000000";var I=function(e){if(!a(e))throw TypeError("Invalid UUID");return parseInt(e.substr(14,1),16)}},function(e,t,i){"use strict";i.r(t),i.d(t,"ScreenshotTools",(function(){return E}));var r=i(18),n=i(1),o=i(4),s=i(13),a=i(0),h=i(67),l=i(75),c=i(38),u=i(12),f=i(71),d=i(24);d.a.prototype.createRenderTargetTexture=function(e,t){var i=new f.a;void 0!==t&&"object"==typeof t?(i.generateMipMaps=t.generateMipMaps,i.generateDepthBuffer=!!t.generateDepthBuffer,i.generateStencilBuffer=!!t.generateStencilBuffer,i.type=void 0===t.type?0:t.type,i.samplingMode=void 0===t.samplingMode?3:t.samplingMode,i.format=void 0===t.format?5:t.format):(i.generateMipMaps=t,i.generateDepthBuffer=!0,i.generateStencilBuffer=!1,i.type=0,i.samplingMode=3,i.format=5),(1!==i.type||this._caps.textureFloatLinearFiltering)&&(2!==i.type||this._caps.textureHalfFloatLinearFiltering)||(i.samplingMode=1),1!==i.type||this._caps.textureFloat||(i.type=0,u.a.Warn("Float textures are not supported. Render target forced to TEXTURETYPE_UNSIGNED_BYTE type"));var r=this._gl,n=new c.a(this,c.b.RenderTarget),o=e.width||e,s=e.height||e,a=e.layers||0,h=this._getSamplingParameters(i.samplingMode,!!i.generateMipMaps),l=0!==a?r.TEXTURE_2D_ARRAY:r.TEXTURE_2D,d=this._getRGBABufferInternalSizedFormat(i.type,i.format),p=this._getInternalFormat(i.format),_=this._getWebGLTextureType(i.type);this._bindTextureDirectly(l,n),0!==a?(n.is2DArray=!0,r.texImage3D(l,0,d,o,s,a,0,p,_,null)):r.texImage2D(l,0,d,o,s,0,p,_,null),r.texParameteri(l,r.TEXTURE_MAG_FILTER,h.mag),r.texParameteri(l,r.TEXTURE_MIN_FILTER,h.min),r.texParameteri(l,r.TEXTURE_WRAP_S,r.CLAMP_TO_EDGE),r.texParameteri(l,r.TEXTURE_WRAP_T,r.CLAMP_TO_EDGE),i.generateMipMaps&&this._gl.generateMipmap(l),this._bindTextureDirectly(l,null);var g=r.createFramebuffer();return this._bindUnboundFramebuffer(g),n._depthStencilBuffer=this._setupFramebufferDepthAttachments(!!i.generateStencilBuffer,i.generateDepthBuffer,o,s),n.is2DArray||r.framebufferTexture2D(r.FRAMEBUFFER,r.COLOR_ATTACHMENT0,r.TEXTURE_2D,n._webGLTexture,0),this._bindUnboundFramebuffer(null),n._framebuffer=g,n.baseWidth=o,n.baseHeight=s,n.width=o,n.height=s,n.depth=a,n.isReady=!0,n.samples=1,n.generateMipMaps=!!i.generateMipMaps,n.samplingMode=i.samplingMode,n.type=i.type,n.format=i.format,n._generateDepthBuffer=i.generateDepthBuffer,n._generateStencilBuffer=!!i.generateStencilBuffer,this._internalTexturesCache.push(n),n},d.a.prototype.createDepthStencilTexture=function(e,t){if(t.isCube){var i=e.width||e;return this._createDepthStencilCubeTexture(i,t)}return this._createDepthStencilTexture(e,t)},d.a.prototype._createDepthStencilTexture=function(e,t){var i=this._gl,r=e.layers||0,o=0!==r?i.TEXTURE_2D_ARRAY:i.TEXTURE_2D,s=new c.a(this,c.b.Depth);if(!this._caps.depthTextureExtension)return u.a.Error("Depth texture is not supported by your browser or hardware."),s;var a=Object(n.a)({bilinearFiltering:!1,comparisonFunction:0,generateStencil:!1},t);this._bindTextureDirectly(o,s,!0),this._setupDepthStencilTexture(s,e,a.generateStencil,a.bilinearFiltering,a.comparisonFunction);var h=a.generateStencil?i.UNSIGNED_INT_24_8:i.UNSIGNED_INT,l=a.generateStencil?i.DEPTH_STENCIL:i.DEPTH_COMPONENT,f=l;return this.webGLVersion>1&&(f=a.generateStencil?i.DEPTH24_STENCIL8:i.DEPTH_COMPONENT24),s.is2DArray?i.texImage3D(o,0,f,s.width,s.height,r,0,l,h,null):i.texImage2D(o,0,f,s.width,s.height,0,l,h,null),this._bindTextureDirectly(o,null),s},d.a.prototype.createRenderTargetCubeTexture=function(e,t){var i=Object(n.a)({generateMipMaps:!0,generateDepthBuffer:!0,generateStencilBuffer:!1,type:0,samplingMode:3,format:5},t);i.generateStencilBuffer=i.generateDepthBuffer&&i.generateStencilBuffer,(1!==i.type||this._caps.textureFloatLinearFiltering)&&(2!==i.type||this._caps.textureHalfFloatLinearFiltering)||(i.samplingMode=1);var r=this._gl,o=new c.a(this,c.b.RenderTarget);this._bindTextureDirectly(r.TEXTURE_CUBE_MAP,o,!0);var s=this._getSamplingParameters(i.samplingMode,i.generateMipMaps);1!==i.type||this._caps.textureFloat||(i.type=0,u.a.Warn("Float textures are not supported. Cube render target forced to TEXTURETYPE_UNESIGNED_BYTE type")),r.texParameteri(r.TEXTURE_CUBE_MAP,r.TEXTURE_MAG_FILTER,s.mag),r.texParameteri(r.TEXTURE_CUBE_MAP,r.TEXTURE_MIN_FILTER,s.min),r.texParameteri(r.TEXTURE_CUBE_MAP,r.TEXTURE_WRAP_S,r.CLAMP_TO_EDGE),r.texParameteri(r.TEXTURE_CUBE_MAP,r.TEXTURE_WRAP_T,r.CLAMP_TO_EDGE);for(var a=0;a<6;a++)r.texImage2D(r.TEXTURE_CUBE_MAP_POSITIVE_X+a,0,this._getRGBABufferInternalSizedFormat(i.type,i.format),e,e,0,this._getInternalFormat(i.format),this._getWebGLTextureType(i.type),null);var h=r.createFramebuffer();return this._bindUnboundFramebuffer(h),o._depthStencilBuffer=this._setupFramebufferDepthAttachments(i.generateStencilBuffer,i.generateDepthBuffer,e,e),i.generateMipMaps&&r.generateMipmap(r.TEXTURE_CUBE_MAP),this._bindTextureDirectly(r.TEXTURE_CUBE_MAP,null),this._bindUnboundFramebuffer(null),o._framebuffer=h,o.width=e,o.height=e,o.isReady=!0,o.isCube=!0,o.samples=1,o.generateMipMaps=i.generateMipMaps,o.samplingMode=i.samplingMode,o.type=i.type,o.format=i.format,o._generateDepthBuffer=i.generateDepthBuffer,o._generateStencilBuffer=i.generateStencilBuffer,this._internalTexturesCache.push(o),o};var p=i(26),_=function(e){function t(t,i,n,s,h,c,u,f,d,p,_,g,m){void 0===h&&(h=!0),void 0===c&&(c=0),void 0===u&&(u=!1),void 0===f&&(f=r.a.TRILINEAR_SAMPLINGMODE),void 0===d&&(d=!0),void 0===p&&(p=!1),void 0===_&&(_=!1),void 0===g&&(g=5),void 0===m&&(m=!1);var b=e.call(this,null,n,!s)||this;return b.isCube=u,b.renderParticles=!0,b.renderSprites=!1,b.coordinatesMode=r.a.PROJECTION_MODE,b.ignoreCameraViewport=!1,b.onBeforeBindObservable=new o.a,b.onAfterUnbindObservable=new o.a,b.onBeforeRenderObservable=new o.a,b.onAfterRenderObservable=new o.a,b.onClearObservable=new o.a,b.onResizeObservable=new o.a,b._currentRefreshId=-1,b._refreshRate=1,b._samples=1,b.boundingBoxPosition=a.e.Zero(),(n=b.getScene())?(b.renderList=new Array,b._engine=n.getEngine(),b.name=t,b.isRenderTarget=!0,b._initialSizeParameter=i,b._processSizeParameter(i),b._resizeObserver=b.getScene().getEngine().onResizeObservable.add((function(){})),b._generateMipMaps=!!s,b._doNotChangeAspectRatio=h,b._renderingManager=new l.a(n),b._renderingManager._useSceneAutoClearSetup=!0,_||(b._renderTargetOptions={generateMipMaps:s,type:c,format:g,samplingMode:f,generateDepthBuffer:d,generateStencilBuffer:p},f===r.a.NEAREST_SAMPLINGMODE&&(b.wrapU=r.a.CLAMP_ADDRESSMODE,b.wrapV=r.a.CLAMP_ADDRESSMODE),m||(u?(b._texture=n.getEngine().createRenderTargetCubeTexture(b.getRenderSize(),b._renderTargetOptions),b.coordinatesMode=r.a.INVCUBIC_MODE,b._textureMatrix=a.a.Identity()):b._texture=n.getEngine().createRenderTargetTexture(b._size,b._renderTargetOptions))),b):b}return Object(n.c)(t,e),Object.defineProperty(t.prototype,"renderList",{get:function(){return this._renderList},set:function(e){this._renderList=e,this._renderList&&this._hookArray(this._renderList)},enumerable:!0,configurable:!0}),t.prototype._hookArray=function(e){var t=this,i=e.push;e.push=function(){for(var r=[],n=0;n0&&(this._postProcesses[0].autoClear=!1))}},t.prototype._shouldRender=function(){return-1===this._currentRefreshId||this.refreshRate===this._currentRefreshId?(this._currentRefreshId=1,!0):(this._currentRefreshId++,!1)},t.prototype.getRenderSize=function(){return this.getRenderWidth()},t.prototype.getRenderWidth=function(){return this._size.width?this._size.width:this._size},t.prototype.getRenderHeight=function(){return this._size.width?this._size.height:this._size},t.prototype.getRenderLayers=function(){var e=this._size.layers;return e||0},Object.defineProperty(t.prototype,"canRescale",{get:function(){return!0},enumerable:!0,configurable:!0}),t.prototype.scale=function(e){var t=Math.max(1,this.getRenderSize()*e);this.resize(t)},t.prototype.getReflectionTextureMatrix=function(){return this.isCube?this._textureMatrix:e.prototype.getReflectionTextureMatrix.call(this)},t.prototype.resize=function(e){var t=this.isCube;this.releaseInternalTexture();var i=this.getScene();i&&(this._processSizeParameter(e),this._texture=t?i.getEngine().createRenderTargetCubeTexture(this.getRenderSize(),this._renderTargetOptions):i.getEngine().createRenderTargetTexture(this._size,this._renderTargetOptions),this.onResizeObservable.hasObservers()&&this.onResizeObservable.notifyObservers(this))},t.prototype.render=function(e,t){if(void 0===e&&(e=!1),void 0===t&&(t=!1),a=this.getScene()){var i,r=a.getEngine();if(void 0!==this.useCameraPostProcesses&&(e=this.useCameraPostProcesses),this._waitingRenderList){this.renderList=[];for(var n=0;n1||this.activeCamera&&this.activeCamera!==a.activeCamera)&&a.setTransformMatrix(a.activeCamera.getViewMatrix(),a.activeCamera.getProjectionMatrix(!0)),r.setViewport(a.activeCamera.viewport)),a.resetCachedMaterial()}},t.prototype._bestReflectionRenderTargetDimension=function(e,t){var i=e*t,r=p.Engine.NearestPOT(i+16384/(128+i));return Math.min(p.Engine.FloorPOT(e),r)},t.prototype._prepareRenderingManager=function(e,t,i,r){var n=this.getScene();if(n){this._renderingManager.reset();for(var o=n.getRenderId(),s=0;s=0&&this._renderingManager.dispatchParticles(f))}}},t.prototype._bindFrameBuffer=function(e,t){void 0===e&&(e=0),void 0===t&&(t=0);var i=this.getScene();if(i){var r=i.getEngine();this._texture&&r.bindFramebuffer(this._texture,this.isCube?e:void 0,void 0,void 0,this.ignoreCameraViewport,0,t)}},t.prototype.unbindFrameBuffer=function(e,t){var i=this;this._texture&&e.unBindFramebuffer(this._texture,this.isCube,(function(){i.onAfterRenderObservable.notifyObservers(t)}))},t.prototype.renderToTarget=function(e,t,i,r,n){void 0===r&&(r=0),void 0===n&&(n=null);var o=this.getScene();if(o){var a=o.getEngine();if(this._texture){this._postProcessManager?this._postProcessManager._prepareFrame(this._texture,this._postProcesses):t&&o.postProcessManager._prepareFrame(this._texture)||this._bindFrameBuffer(e,r),this.is2DArray?this.onBeforeRenderObservable.notifyObservers(r):this.onBeforeRenderObservable.notifyObservers(e);var h=null,l=this.renderList?this.renderList:o.getActiveMeshes().data,c=this.renderList?this.renderList.length:o.getActiveMeshes().length;this.getCustomRenderList&&(h=this.getCustomRenderList(this.is2DArray?r:e,l,c)),h?this._prepareRenderingManager(h,h.length,n,!1):(this._defaultRenderListPrepared||(this._prepareRenderingManager(l,c,n,!this.renderList),this._defaultRenderListPrepared=!0),h=l),this.onClearObservable.hasObservers()?this.onClearObservable.notifyObservers(a):a.clear(this.clearColor||o.clearColor,!0,!0,!0),this._doNotChangeAspectRatio||o.updateTransformMatrix(!0);for(var u=0,f=o._beforeRenderTargetDrawStage;u=0&&t.customRenderTargets.splice(i,1);for(var r=0,n=t.cameras;r=0&&o.customRenderTargets.splice(i,1)}this.depthStencilTexture&&this.getScene().getEngine()._releaseTexture(this.depthStencilTexture),e.prototype.dispose.call(this)}},t.prototype._rebuild=function(){this.refreshRate===t.REFRESHRATE_RENDER_ONCE&&(this.refreshRate=t.REFRESHRATE_RENDER_ONCE),this._postProcessManager&&this._postProcessManager._rebuild()},t.prototype.freeRenderingGroups=function(){this._renderingManager&&this._renderingManager.freeRenderingGroups()},t.prototype.getViewCount=function(){return 1},t.REFRESHRATE_RENDER_ONCE=0,t.REFRESHRATE_RENDER_ONEVERYFRAME=1,t.REFRESHRATE_RENDER_ONEVERYTWOFRAMES=2,t}(r.a);r.a._CreateRenderTargetTexture=function(e,t,i,r){return new _(e,t,i,r)};var g=i(28),m=i(6),b="\nattribute vec2 position;\nuniform vec2 scale;\n\nvarying vec2 vUV;\nconst vec2 madd=vec2(0.5,0.5);\nvoid main(void) {\nvUV=(position*madd+madd)*scale;\ngl_Position=vec4(position,0.0,1.0);\n}";m.a.ShadersStore.postprocessVertexShader=b;var v=function(){function e(e,t,i,r,n,s,h,l,c,u,f,d,p,_,m){void 0===h&&(h=1),void 0===u&&(u=null),void 0===f&&(f=0),void 0===d&&(d="postprocess"),void 0===_&&(_=!1),void 0===m&&(m=5),this.name=e,this.width=-1,this.height=-1,this._outputTexture=null,this.autoClear=!0,this.alphaMode=0,this.animations=new Array,this.enablePixelPerfectMode=!1,this.forceFullscreenViewport=!0,this.scaleMode=1,this.alwaysForcePOT=!1,this._samples=1,this.adaptScaleToCurrentViewport=!1,this._reusable=!1,this._textures=new g.a(2),this._currentRenderTextureInd=0,this._scaleRatio=new a.d(1,1),this._texelSize=a.d.Zero(),this.onActivateObservable=new o.a,this.onSizeChangedObservable=new o.a,this.onApplyObservable=new o.a,this.onBeforeRenderObservable=new o.a,this.onAfterRenderObservable=new o.a,null!=s?(this._camera=s,this._scene=s.getScene(),s.attachPostProcess(this),this._engine=this._scene.getEngine(),this._scene.postProcesses.push(this),this.uniqueId=this._scene.getUniqueId()):l&&(this._engine=l,this._engine.postProcesses.push(this)),this._options=n,this.renderTargetSamplingMode=h||1,this._reusable=c||!1,this._textureType=f,this._textureFormat=m,this._samplers=r||[],this._samplers.push("textureSampler"),this._fragmentUrl=t,this._vertexUrl=d,this._parameters=i||[],this._parameters.push("scale"),this._indexParameters=p,_||this.updateEffect(u)}return Object.defineProperty(e.prototype,"samples",{get:function(){return this._samples},set:function(e){var t=this;this._samples=Math.min(e,this._engine.getCaps().maxMSAASamples),this._textures.forEach((function(e){e.samples!==t._samples&&t._engine.updateRenderTargetTextureSampleCount(e,t._samples)}))},enumerable:!0,configurable:!0}),e.prototype.getEffectName=function(){return this._fragmentUrl},Object.defineProperty(e.prototype,"onActivate",{set:function(e){this._onActivateObserver&&this.onActivateObservable.remove(this._onActivateObserver),e&&(this._onActivateObserver=this.onActivateObservable.add(e))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"onSizeChanged",{set:function(e){this._onSizeChangedObserver&&this.onSizeChangedObservable.remove(this._onSizeChangedObserver),this._onSizeChangedObserver=this.onSizeChangedObservable.add(e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"onApply",{set:function(e){this._onApplyObserver&&this.onApplyObservable.remove(this._onApplyObserver),this._onApplyObserver=this.onApplyObservable.add(e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"onBeforeRender",{set:function(e){this._onBeforeRenderObserver&&this.onBeforeRenderObservable.remove(this._onBeforeRenderObserver),this._onBeforeRenderObserver=this.onBeforeRenderObservable.add(e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"onAfterRender",{set:function(e){this._onAfterRenderObserver&&this.onAfterRenderObservable.remove(this._onAfterRenderObserver),this._onAfterRenderObserver=this.onAfterRenderObservable.add(e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"inputTexture",{get:function(){return this._textures.data[this._currentRenderTextureInd]},set:function(e){this._forcedOutputTexture=e},enumerable:!0,configurable:!0}),e.prototype.getCamera=function(){return this._camera},Object.defineProperty(e.prototype,"texelSize",{get:function(){return this._shareOutputWithPostProcess?this._shareOutputWithPostProcess.texelSize:(this._forcedOutputTexture&&this._texelSize.copyFromFloats(1/this._forcedOutputTexture.width,1/this._forcedOutputTexture.height),this._texelSize)},enumerable:!0,configurable:!0}),e.prototype.getClassName=function(){return"PostProcess"},e.prototype.getEngine=function(){return this._engine},e.prototype.getEffect=function(){return this._effect},e.prototype.shareOutputWith=function(e){return this._disposeTextures(),this._shareOutputWithPostProcess=e,this},e.prototype.useOwnOutput=function(){0==this._textures.length&&(this._textures=new g.a(2)),this._shareOutputWithPostProcess=null},e.prototype.updateEffect=function(e,t,i,r,n,o){void 0===e&&(e=null),void 0===t&&(t=null),void 0===i&&(i=null),this._effect=this._engine.createEffect({vertex:this._vertexUrl,fragment:this._fragmentUrl},["position"],t||this._parameters,i||this._samplers,null!==e?e:"",void 0,n,o,r||this._indexParameters)},e.prototype.isReusable=function(){return this._reusable},e.prototype.markTextureDirty=function(){this.width=-1},e.prototype.activate=function(e,t,i){var r=this;void 0===t&&(t=null);var n=(e=e||this._camera).getScene(),o=n.getEngine(),s=o.getCaps().maxTextureSize,a=(t?t.width:this._engine.getRenderWidth(!0))*this._options|0,h=(t?t.height:this._engine.getRenderHeight(!0))*this._options|0,l=e.parent;!l||l.leftCamera!=e&&l.rightCamera!=e||(a/=2);var c,u=this._options.width||a,f=this._options.height||h,d=7!==this.renderTargetSamplingMode&&1!==this.renderTargetSamplingMode&&2!==this.renderTargetSamplingMode;if(!this._shareOutputWithPostProcess&&!this._forcedOutputTexture){if(this.adaptScaleToCurrentViewport){var _=o.currentViewport;_&&(u*=_.width,f*=_.height)}if((d||this.alwaysForcePOT)&&(this._options.width||(u=o.needPOTTextures?p.Engine.GetExponentOfTwo(u,s,this.scaleMode):u),this._options.height||(f=o.needPOTTextures?p.Engine.GetExponentOfTwo(f,s,this.scaleMode):f)),this.width!==u||this.height!==f){if(this._textures.length>0){for(var g=0;g0)for(var e=0;e0){var r=this._camera._getFirstPostProcess();r&&r.markTextureDirty()}this.onActivateObservable.clear(),this.onAfterRenderObservable.clear(),this.onApplyObservable.clear(),this.onBeforeRenderObservable.clear(),this.onSizeChangedObservable.clear()}},e}(),y="uniform sampler2D textureSampler;\nuniform vec2 texelSize;\nvarying vec2 vUV;\nvarying vec2 sampleCoordS;\nvarying vec2 sampleCoordE;\nvarying vec2 sampleCoordN;\nvarying vec2 sampleCoordW;\nvarying vec2 sampleCoordNW;\nvarying vec2 sampleCoordSE;\nvarying vec2 sampleCoordNE;\nvarying vec2 sampleCoordSW;\nconst float fxaaQualitySubpix=1.0;\nconst float fxaaQualityEdgeThreshold=0.166;\nconst float fxaaQualityEdgeThresholdMin=0.0833;\nconst vec3 kLumaCoefficients=vec3(0.2126,0.7152,0.0722);\n#define FxaaLuma(rgba) dot(rgba.rgb,kLumaCoefficients)\nvoid main(){\nvec2 posM;\nposM.x=vUV.x;\nposM.y=vUV.y;\nvec4 rgbyM=texture2D(textureSampler,vUV,0.0);\nfloat lumaM=FxaaLuma(rgbyM);\nfloat lumaS=FxaaLuma(texture2D(textureSampler,sampleCoordS,0.0));\nfloat lumaE=FxaaLuma(texture2D(textureSampler,sampleCoordE,0.0));\nfloat lumaN=FxaaLuma(texture2D(textureSampler,sampleCoordN,0.0));\nfloat lumaW=FxaaLuma(texture2D(textureSampler,sampleCoordW,0.0));\nfloat maxSM=max(lumaS,lumaM);\nfloat minSM=min(lumaS,lumaM);\nfloat maxESM=max(lumaE,maxSM);\nfloat minESM=min(lumaE,minSM);\nfloat maxWN=max(lumaN,lumaW);\nfloat minWN=min(lumaN,lumaW);\nfloat rangeMax=max(maxWN,maxESM);\nfloat rangeMin=min(minWN,minESM);\nfloat rangeMaxScaled=rangeMax*fxaaQualityEdgeThreshold;\nfloat range=rangeMax-rangeMin;\nfloat rangeMaxClamped=max(fxaaQualityEdgeThresholdMin,rangeMaxScaled);\n#ifndef MALI\nif(range=edgeVert;\nfloat subpixA=subpixNSWE*2.0+subpixNWSWNESE;\nif (!horzSpan)\n{\nlumaN=lumaW;\n}\nif (!horzSpan)\n{\nlumaS=lumaE;\n}\nif (horzSpan)\n{\nlengthSign=texelSize.y;\n}\nfloat subpixB=(subpixA*(1.0/12.0))-lumaM;\nfloat gradientN=lumaN-lumaM;\nfloat gradientS=lumaS-lumaM;\nfloat lumaNN=lumaN+lumaM;\nfloat lumaSS=lumaS+lumaM;\nbool pairN=abs(gradientN)>=abs(gradientS);\nfloat gradient=max(abs(gradientN),abs(gradientS));\nif (pairN)\n{\nlengthSign=-lengthSign;\n}\nfloat subpixC=clamp(abs(subpixB)*subpixRcpRange,0.0,1.0);\nvec2 posB;\nposB.x=posM.x;\nposB.y=posM.y;\nvec2 offNP;\noffNP.x=(!horzSpan) ? 0.0 : texelSize.x;\noffNP.y=(horzSpan) ? 0.0 : texelSize.y;\nif (!horzSpan)\n{\nposB.x+=lengthSign*0.5;\n}\nif (horzSpan)\n{\nposB.y+=lengthSign*0.5;\n}\nvec2 posN;\nposN.x=posB.x-offNP.x*1.5;\nposN.y=posB.y-offNP.y*1.5;\nvec2 posP;\nposP.x=posB.x+offNP.x*1.5;\nposP.y=posB.y+offNP.y*1.5;\nfloat subpixD=((-2.0)*subpixC)+3.0;\nfloat lumaEndN=FxaaLuma(texture2D(textureSampler,posN,0.0));\nfloat subpixE=subpixC*subpixC;\nfloat lumaEndP=FxaaLuma(texture2D(textureSampler,posP,0.0));\nif (!pairN)\n{\nlumaNN=lumaSS;\n}\nfloat gradientScaled=gradient*1.0/4.0;\nfloat lumaMM=lumaM-lumaNN*0.5;\nfloat subpixF=subpixD*subpixE;\nbool lumaMLTZero=lumaMM<0.0;\nlumaEndN-=lumaNN*0.5;\nlumaEndP-=lumaNN*0.5;\nbool doneN=abs(lumaEndN)>=gradientScaled;\nbool doneP=abs(lumaEndP)>=gradientScaled;\nif (!doneN)\n{\nposN.x-=offNP.x*3.0;\n}\nif (!doneN)\n{\nposN.y-=offNP.y*3.0;\n}\nbool doneNP=(!doneN) || (!doneP);\nif (!doneP)\n{\nposP.x+=offNP.x*3.0;\n}\nif (!doneP)\n{\nposP.y+=offNP.y*3.0;\n}\nif (doneNP)\n{\nif (!doneN) lumaEndN=FxaaLuma(texture2D(textureSampler,posN.xy,0.0));\nif (!doneP) lumaEndP=FxaaLuma(texture2D(textureSampler,posP.xy,0.0));\nif (!doneN) lumaEndN=lumaEndN-lumaNN*0.5;\nif (!doneP) lumaEndP=lumaEndP-lumaNN*0.5;\ndoneN=abs(lumaEndN)>=gradientScaled;\ndoneP=abs(lumaEndP)>=gradientScaled;\nif (!doneN) posN.x-=offNP.x*12.0;\nif (!doneN) posN.y-=offNP.y*12.0;\ndoneNP=(!doneN) || (!doneP);\nif (!doneP) posP.x+=offNP.x*12.0;\nif (!doneP) posP.y+=offNP.y*12.0;\n}\nfloat dstN=posM.x-posN.x;\nfloat dstP=posP.x-posM.x;\nif (!horzSpan)\n{\ndstN=posM.y-posN.y;\n}\nif (!horzSpan)\n{\ndstP=posP.y-posM.y;\n}\nbool goodSpanN=(lumaEndN<0.0) != lumaMLTZero;\nfloat spanLength=(dstP+dstN);\nbool goodSpanP=(lumaEndP<0.0) != lumaMLTZero;\nfloat spanLengthRcp=1.0/spanLength;\nbool directionN=dstN-1?"#define MALI 1\n":null},t}(v),E=function(){function e(){}return e.CreateScreenshot=function(t,i,r,n,o){void 0===o&&(o="image/png");var a=e._getScreenshotSize(t,i,r),h=a.height,l=a.width;if(h&&l){s.b._ScreenshotCanvas||(s.b._ScreenshotCanvas=document.createElement("canvas")),s.b._ScreenshotCanvas.width=l,s.b._ScreenshotCanvas.height=h;var c=s.b._ScreenshotCanvas.getContext("2d"),f=t.getRenderWidth()/t.getRenderHeight(),d=l,p=d/f;p>h&&(d=(p=h)*f);var _=Math.max(0,l-d)/2,g=Math.max(0,h-p)/2,m=t.getRenderingCanvas();c&&m&&c.drawImage(m,_,g,d,p),s.b.EncodeScreenshotCanvasData(n,o)}else u.a.Error("Invalid 'size' parameter !")},e.CreateScreenshotAsync=function(t,i,r,n){return void 0===n&&(n="image/png"),new Promise((function(o,s){e.CreateScreenshot(t,i,r,(function(e){void 0!==e?o(e):s(new Error("Data is undefined"))}),n)}))},e.CreateScreenshotUsingRenderTarget=function(t,i,n,o,a,h,l,c,f){void 0===a&&(a="image/png"),void 0===h&&(h=1),void 0===l&&(l=!1),void 0===f&&(f=!1);var d=e._getScreenshotSize(t,i,n),p=d.height,g=d.width,m={width:g,height:p};if(p&&g){var b=i.getScene(),v=null;b.activeCamera!==i&&(v=b.activeCamera,b.activeCamera=i);var y=t.getRenderingCanvas();if(y){var x={width:y.width,height:y.height};t.setSize(g,p),b.render();var E=new _("screenShot",m,b,!1,!1,0,!1,r.a.NEAREST_SAMPLINGMODE);E.renderList=null,E.samples=h,E.renderSprites=f,E.onAfterRenderObservable.add((function(){s.b.DumpFramebuffer(g,p,t,o,a,c)}));var M=function(){b.incrementRenderId(),b.resetCachedMaterial(),E.render(!0),E.dispose(),v&&(b.activeCamera=v),t.setSize(x.width,x.height),i.getProjectionMatrix(!0)};if(l){var A=new T("antialiasing",1,b.activeCamera);E.addPostProcess(A),A.getEffect().isReady()?M():A.getEffect().onCompiled=function(){M()}}else M()}else u.a.Error("No rendering canvas found !")}else u.a.Error("Invalid 'size' parameter !")},e.CreateScreenshotUsingRenderTargetAsync=function(t,i,r,n,o,s,a,h){return void 0===n&&(n="image/png"),void 0===o&&(o=1),void 0===s&&(s=!1),void 0===h&&(h=!1),new Promise((function(l,c){e.CreateScreenshotUsingRenderTarget(t,i,r,(function(e){void 0!==e?l(e):c(new Error("Data is undefined"))}),n,o,s,a,h)}))},e._getScreenshotSize=function(e,t,i){var r=0,n=0;if("object"==typeof i){var o=i.precision?Math.abs(i.precision):1;i.width&&i.height?(r=i.height*o,n=i.width*o):i.width&&!i.height?(n=i.width*o,r=Math.round(n/e.getAspectRatio(t))):i.height&&!i.width?(r=i.height*o,n=Math.round(r*e.getAspectRatio(t))):(n=Math.round(e.getRenderWidth()*o),r=Math.round(n/e.getAspectRatio(t)))}else isNaN(i)||(r=i,n=i);return n&&(n=Math.floor(n)),r&&(r=Math.floor(r)),{height:0|r,width:0|n}},e}();s.b.CreateScreenshot=E.CreateScreenshot,s.b.CreateScreenshotAsync=E.CreateScreenshotAsync,s.b.CreateScreenshotUsingRenderTarget=E.CreateScreenshotUsingRenderTarget,s.b.CreateScreenshotUsingRenderTargetAsync=E.CreateScreenshotUsingRenderTargetAsync},function(e,t,i){"use strict";i.r(t),i.d(t,"PointerDragBehavior",(function(){return p}));var r=i(15),n=i(31),o=i(4),s=i(0),a=i(9),h=i(30),l=i(48),c=i(68),u=i(20),f=function(){function e(e,t,i){void 0===i&&(i=Number.MAX_VALUE),this.origin=e,this.direction=t,this.length=i}return e.prototype.intersectsBoxMinMax=function(t,i,r){void 0===r&&(r=0);var n,o,s,a,h=e.TmpVector3[0].copyFromFloats(t.x-r,t.y-r,t.z-r),l=e.TmpVector3[1].copyFromFloats(i.x+r,i.y+r,i.z+r),c=0,u=Number.MAX_VALUE;if(Math.abs(this.direction.x)<1e-7){if(this.origin.xl.x)return!1}else if(n=1/this.direction.x,o=(h.x-this.origin.x)*n,(s=(l.x-this.origin.x)*n)===-1/0&&(s=1/0),o>s&&(a=o,o=s,s=a),(c=Math.max(o,c))>(u=Math.min(s,u)))return!1;if(Math.abs(this.direction.y)<1e-7){if(this.origin.yl.y)return!1}else if(n=1/this.direction.y,o=(h.y-this.origin.y)*n,(s=(l.y-this.origin.y)*n)===-1/0&&(s=1/0),o>s&&(a=o,o=s,s=a),(c=Math.max(o,c))>(u=Math.min(s,u)))return!1;if(Math.abs(this.direction.z)<1e-7){if(this.origin.zl.z)return!1}else if(n=1/this.direction.z,o=(h.z-this.origin.z)*n,(s=(l.z-this.origin.z)*n)===-1/0&&(s=1/0),o>s&&(a=o,o=s,s=a),(c=Math.max(o,c))>(u=Math.min(s,u)))return!1;return!0},e.prototype.intersectsBox=function(e,t){return void 0===t&&(t=0),this.intersectsBoxMinMax(e.minimum,e.maximum,t)},e.prototype.intersectsSphere=function(e,t){void 0===t&&(t=0);var i=e.center.x-this.origin.x,r=e.center.y-this.origin.y,n=e.center.z-this.origin.z,o=i*i+r*r+n*n,s=e.radius+t,a=s*s;if(o<=a)return!0;var h=i*this.direction.x+r*this.direction.y+n*this.direction.z;return!(h<0)&&o-h*h<=a},e.prototype.intersectsTriangle=function(t,i,r){var n=e.TmpVector3[0],o=e.TmpVector3[1],a=e.TmpVector3[2],h=e.TmpVector3[3],l=e.TmpVector3[4];i.subtractToRef(t,n),r.subtractToRef(t,o),s.e.CrossToRef(this.direction,o,a);var u=s.e.Dot(n,a);if(0===u)return null;var f=1/u;this.origin.subtractToRef(t,h);var d=s.e.Dot(h,a)*f;if(d<0||d>1)return null;s.e.CrossToRef(h,n,l);var p=s.e.Dot(this.direction,l)*f;if(p<0||d+p>1)return null;var _=s.e.Dot(o,l)*f;return _>this.length?null:new c.a(1-d-p,d,_)},e.prototype.intersectsPlane=function(e){var t,i=s.e.Dot(e.normal,this.direction);if(Math.abs(i)<9.99999997475243e-7)return null;var r=s.e.Dot(e.normal,this.origin);return(t=(-e.d-r)/i)<0?t<-9.99999997475243e-7?null:0:t},e.prototype.intersectsAxis=function(e,t){switch(void 0===t&&(t=0),e){case"y":return(i=(this.origin.y-t)/this.direction.y)>0?null:new s.e(this.origin.x+this.direction.x*-i,t,this.origin.z+this.direction.z*-i);case"x":return(i=(this.origin.x-t)/this.direction.x)>0?null:new s.e(t,this.origin.y+this.direction.y*-i,this.origin.z+this.direction.z*-i);case"z":var i;return(i=(this.origin.z-t)/this.direction.z)>0?null:new s.e(this.origin.x+this.direction.x*-i,this.origin.y+this.direction.y*-i,t);default:return null}},e.prototype.intersectsMesh=function(t,i){var r=s.c.Matrix[0];return t.getWorldMatrix().invertToRef(r),this._tmpRay?e.TransformToRef(this,r,this._tmpRay):this._tmpRay=e.Transform(this,r),t.intersects(this._tmpRay,i)},e.prototype.intersectsMeshes=function(e,t,i){i?i.length=0:i=[];for(var r=0;rt.distance?1:0},e.prototype.intersectionSegment=function(t,i,r){var n=this.origin,o=s.c.Vector3[0],a=s.c.Vector3[1],h=s.c.Vector3[2],l=s.c.Vector3[3];i.subtractToRef(t,o),this.direction.scaleToRef(e.rayl,h),n.addToRef(h,a),t.subtractToRef(n,l);var c,u,f,d,p=s.e.Dot(o,o),_=s.e.Dot(o,h),g=s.e.Dot(h,h),m=s.e.Dot(o,l),b=s.e.Dot(h,l),v=p*g-_*_,y=v,x=v;vy&&(u=y,d=b+_,x=g)),d<0?(d=0,-m<0?u=0:-m>p?u=y:(u=-m,y=p)):d>x&&(d=x,-m+_<0?u=0:-m+_>p?u=y:(u=-m+_,y=p)),c=Math.abs(u)0&&f<=this.length&&M.lengthSquared()=n.distance))&&(n=h,i)))break}return n||new l.a},n.Scene.prototype._internalMultiPick=function(e,t,i){if(!l.a)return null;for(var r=new Array,n=0;n1)throw"Multiple drag modes specified in dragBehavior options. Only one expected"}return Object.defineProperty(e.prototype,"options",{get:function(){return this._options},set:function(e){this._options=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"name",{get:function(){return"PointerDrag"},enumerable:!0,configurable:!0}),e.prototype.init=function(){},e.prototype.attach=function(t,i){var o=this;this._scene=t.getScene(),this.attachedNode=t,e._planeScene||(this._debugMode?e._planeScene=this._scene:(e._planeScene=new n.Scene(this._scene.getEngine(),{virtual:!0}),e._planeScene.detachControl(),this._scene.onDisposeObservable.addOnce((function(){e._planeScene.dispose(),e._planeScene=null})))),this._dragPlane=r.Mesh.CreatePlane("pointerDragPlane",this._debugMode?1:1e4,e._planeScene,!1,r.Mesh.DOUBLESIDE),this.lastDragPosition=new s.e(0,0,0);var h=i||function(e){return o.attachedNode==e||e.isDescendantOf(o.attachedNode)};this._pointerObserver=this._scene.onPointerObservable.add((function(t,i){if(o.enabled)if(t.type==a.a.POINTERDOWN)o.startAndReleaseDragOnPointerEvents&&!o.dragging&&t.pickInfo&&t.pickInfo.hit&&t.pickInfo.pickedMesh&&t.pickInfo.pickedPoint&&t.pickInfo.ray&&h(t.pickInfo.pickedMesh)&&o._startDrag(t.event.pointerId,t.pickInfo.ray,t.pickInfo.pickedPoint);else if(t.type==a.a.POINTERUP)o.startAndReleaseDragOnPointerEvents&&o.currentDraggingPointerID==t.event.pointerId&&o.releaseDrag();else if(t.type==a.a.POINTERMOVE){var r=t.event.pointerId;o.currentDraggingPointerID===e._AnyMouseID&&r!==e._AnyMouseID&&"mouse"==t.event.pointerType&&(o._lastPointerRay[o.currentDraggingPointerID]&&(o._lastPointerRay[r]=o._lastPointerRay[o.currentDraggingPointerID],delete o._lastPointerRay[o.currentDraggingPointerID]),o.currentDraggingPointerID=r),o._lastPointerRay[r]||(o._lastPointerRay[r]=new f(new s.e,new s.e)),t.pickInfo&&t.pickInfo.ray&&(o._lastPointerRay[r].origin.copyFrom(t.pickInfo.ray.origin),o._lastPointerRay[r].direction.copyFrom(t.pickInfo.ray.direction),o.currentDraggingPointerID==r&&o.dragging&&o._moveDrag(t.pickInfo.ray))}})),this._beforeRenderObserver=this._scene.onBeforeRenderObservable.add((function(){o._moving&&o.moveAttached&&(d._RemoveAndStorePivotPoint(o.attachedNode),o._targetPosition.subtractToRef(o.attachedNode.absolutePosition,o._tmpVector),o._tmpVector.scaleInPlace(o.dragDeltaRatio),o.attachedNode.getAbsolutePosition().addToRef(o._tmpVector,o._tmpVector),o.validateDrag(o._tmpVector)&&o.attachedNode.setAbsolutePosition(o._tmpVector),d._RestorePivotPoint(o.attachedNode))}))},e.prototype.releaseDrag=function(){this.dragging&&(this.onDragEndObservable.notifyObservers({dragPlanePoint:this.lastDragPosition,pointerId:this.currentDraggingPointerID}),this.dragging=!1),this.currentDraggingPointerID=-1,this._moving=!1,this.detachCameraControls&&this._attachedElement&&this._scene.activeCamera&&!this._scene.activeCamera.leftCamera&&this._scene.activeCamera.attachControl(this._attachedElement,!this._scene.activeCamera.inputs||this._scene.activeCamera.inputs.noPreventDefault)},e.prototype.startDrag=function(t,i,r){void 0===t&&(t=e._AnyMouseID),this._startDrag(t,i,r);var n=this._lastPointerRay[t];t===e._AnyMouseID&&(n=this._lastPointerRay[Object.keys(this._lastPointerRay)[0]]),n&&this._moveDrag(n)},e.prototype._startDrag=function(e,t,i){if(this._scene.activeCamera&&!this.dragging&&this.attachedNode){d._RemoveAndStorePivotPoint(this.attachedNode),t?(this._startDragRay.direction.copyFrom(t.direction),this._startDragRay.origin.copyFrom(t.origin)):(this._startDragRay.origin.copyFrom(this._scene.activeCamera.position),this.attachedNode.getWorldMatrix().getTranslationToRef(this._tmpVector),this._tmpVector.subtractToRef(this._scene.activeCamera.position,this._startDragRay.direction)),this._updateDragPlanePosition(this._startDragRay,i||this._tmpVector);var r=this._pickWithRayOnDragPlane(this._startDragRay);r&&(this.dragging=!0,this.currentDraggingPointerID=e,this.lastDragPosition.copyFrom(r),this.onDragStartObservable.notifyObservers({dragPlanePoint:r,pointerId:this.currentDraggingPointerID}),this._targetPosition.copyFrom(this.attachedNode.absolutePosition),this.detachCameraControls&&this._scene.activeCamera&&this._scene.activeCamera.inputs&&!this._scene.activeCamera.leftCamera&&(this._scene.activeCamera.inputs.attachedElement?(this._attachedElement=this._scene.activeCamera.inputs.attachedElement,this._scene.activeCamera.detachControl(this._scene.activeCamera.inputs.attachedElement)):this._attachedElement=null)),d._RestorePivotPoint(this.attachedNode)}},e.prototype._moveDrag=function(e){this._moving=!0;var t=this._pickWithRayOnDragPlane(e);if(t){this.updateDragPlane&&this._updateDragPlanePosition(e,t);var i=0;this._options.dragAxis?(this.useObjectOrientationForDragging?s.e.TransformCoordinatesToRef(this._options.dragAxis,this.attachedNode.getWorldMatrix().getRotationMatrix(),this._worldDragAxis):this._worldDragAxis.copyFrom(this._options.dragAxis),t.subtractToRef(this.lastDragPosition,this._tmpVector),i=s.e.Dot(this._tmpVector,this._worldDragAxis),this._worldDragAxis.scaleToRef(i,this._dragDelta)):(i=this._dragDelta.length(),t.subtractToRef(this.lastDragPosition,this._dragDelta)),this._targetPosition.addInPlace(this._dragDelta),this.onDragObservable.notifyObservers({dragDistance:i,delta:this._dragDelta,dragPlanePoint:t,dragPlaneNormal:this._dragPlane.forward,pointerId:this.currentDraggingPointerID}),this.lastDragPosition.copyFrom(t)}},e.prototype._pickWithRayOnDragPlane=function(t){var i=this;if(!t)return null;var r=Math.acos(s.e.Dot(this._dragPlane.forward,t.direction));if(r>Math.PI/2&&(r=Math.PI-r),this.maxDragAngle>0&&r>this.maxDragAngle){if(this._useAlternatePickedPointAboveMaxDragAngle){this._tmpVector.copyFrom(t.direction),this.attachedNode.absolutePosition.subtractToRef(t.origin,this._alternatePickedPoint),this._alternatePickedPoint.normalize(),this._alternatePickedPoint.scaleInPlace(this._useAlternatePickedPointAboveMaxDragAngleDragSpeed*s.e.Dot(this._alternatePickedPoint,this._tmpVector)),this._tmpVector.addInPlace(this._alternatePickedPoint);var n=s.e.Dot(this._dragPlane.forward,this._tmpVector);return this._dragPlane.forward.scaleToRef(-n,this._alternatePickedPoint),this._alternatePickedPoint.addInPlace(this._tmpVector),this._alternatePickedPoint.addInPlace(this.attachedNode.absolutePosition),this._alternatePickedPoint}return null}var o=e._planeScene.pickWithRay(t,(function(e){return e==i._dragPlane}));return o&&o.hit&&o.pickedMesh&&o.pickedPoint?o.pickedPoint:null},e.prototype._updateDragPlanePosition=function(e,t){this._pointA.copyFrom(t),this._options.dragAxis?(this.useObjectOrientationForDragging?s.e.TransformCoordinatesToRef(this._options.dragAxis,this.attachedNode.getWorldMatrix().getRotationMatrix(),this._localAxis):this._localAxis.copyFrom(this._options.dragAxis),this._pointA.addToRef(this._localAxis,this._pointB),e.origin.subtractToRef(this._pointA,this._pointC),this._pointA.addToRef(this._pointC.normalize(),this._pointC),this._pointB.subtractToRef(this._pointA,this._lineA),this._pointC.subtractToRef(this._pointA,this._lineB),s.e.CrossToRef(this._lineA,this._lineB,this._lookAt),s.e.CrossToRef(this._lineA,this._lookAt,this._lookAt),this._lookAt.normalize(),this._dragPlane.position.copyFrom(this._pointA),this._pointA.addToRef(this._lookAt,this._lookAt),this._dragPlane.lookAt(this._lookAt)):this._options.dragPlaneNormal?(this.useObjectOrientationForDragging?s.e.TransformCoordinatesToRef(this._options.dragPlaneNormal,this.attachedNode.getWorldMatrix().getRotationMatrix(),this._localAxis):this._localAxis.copyFrom(this._options.dragPlaneNormal),this._dragPlane.position.copyFrom(this._pointA),this._pointA.addToRef(this._localAxis,this._lookAt),this._dragPlane.lookAt(this._lookAt)):(this._dragPlane.position.copyFrom(this._pointA),this._dragPlane.lookAt(e.origin)),this._dragPlane.position.copyFrom(this.attachedNode.absolutePosition),this._dragPlane.computeWorldMatrix(!0)},e.prototype.detach=function(){this._pointerObserver&&this._scene.onPointerObservable.remove(this._pointerObserver),this._beforeRenderObserver&&this._scene.onBeforeRenderObservable.remove(this._beforeRenderObserver),this.releaseDrag()},e._AnyMouseID=-2,e}())},function(e,t,i){"use strict";i.r(t),i.d(t,"SolidParticleSystem",(function(){return y}));var r=i(0),n=i(7),o=i(2),s=i(11),a=i(15);s.VertexData.CreateDisc=function(e){var t=new Array,i=new Array,r=new Array,n=new Array,o=e.radius||.5,a=e.tessellation||64,h=e.arc&&(e.arc<=0||e.arc>1)?1:e.arc||1,l=0===e.sideOrientation?0:e.sideOrientation||s.VertexData.DEFAULTSIDE;t.push(0,0,0),n.push(.5,.5);for(var c=2*Math.PI*h,u=c/a,f=0;f0&&i.set(this._uvs32,o.b.UVKind),this._colors32.length>0&&i.set(this._colors32,o.b.ColorKind),i.applyToMesh(this.mesh,this._updatable),this.mesh.isPickable=this._pickable,this._multimaterialEnabled&&this.setMultiMaterial(this._materials),this._expandable||(this._depthSort||this._multimaterialEnabled||(this._indices=null),this._positions=null,this._normals=null,this._uvs=null,this._colors=null,this._updatable||(this.particles.length=0)),this._isNotBuilt=!1,this.recomputeNormals=!1,this.mesh},e.prototype.digest=function(e,t){var i=t&&t.facetNb||1,n=t&&t.number||0,s=t&&t.delta||0,a=e.getVerticesData(o.b.PositionKind),h=e.getIndices(),l=e.getVerticesData(o.b.UVKind),u=e.getVerticesData(o.b.ColorKind),f=e.getVerticesData(o.b.NormalKind),d=t&&t.storage?t.storage:null,_=0,g=h.length/3;n?(n=n>g?g:n,i=Math.round(g/n),s=0):i=i>g?g:i;for(var m=[],b=[],v=[],y=[],x=[],T=r.e.Zero(),E=i;_g-(i=E+Math.floor((1+s)*Math.random()))&&(i=g-_),m.length=0,b.length=0,v.length=0,y.length=0,x.length=0;for(var M=0,A=3*_;A<3*(_+i);A++){v.push(M);var O=h[A],C=3*O;if(m.push(a[C],a[C+1],a[C+2]),b.push(f[C],f[C+1],f[C+2]),l){var S=2*O;y.push(l[S],l[S+1])}if(u){var P=4*O;x.push(u[P],u[P+1],u[P+2],u[P+3])}M++}var R,I=this.nbParticles,w=this._posToShape(m),D=this._uvsToShapeUV(y),L=Array.from(v),F=Array.from(x),N=Array.from(b);for(T.copyFromFloats(0,0,0),R=0;R65535&&(this._needs32Bits=!0)}if(this._pickable){var N=o.length/3;for(b=0;b=this.nbParticles||!this._updatable)return[];var r=this.particles,n=this.nbParticles;if(t=this.nbParticles?this.nbParticles-1:t,this._computeBoundingBox&&(0!=e||t!=this.nbParticles-1)){var L=this.mesh._boundingInfo;L&&(T.copyFrom(L.minimum),E.copyFrom(L.maximum))}var F=(S=this.particles[e]._pos)/3|0;R=4*F,w=2*F;for(var N=e;N<=t;N++){var B=this.particles[N];this.updateParticle(B);var k=B._model._shape,U=B._model._shapeUV,V=B._rotationMatrix,z=B.position,j=B.rotation,W=B.scaling,G=B._globalPosition;if(this._depthSort&&this._depthSortParticles){var H=this.depthSortedParticles[N];H.ind=B._ind,H.indicesLength=B._model._indicesLength,H.sqDistance=r.e.DistanceSquared(B.position,M)}if(!B.alive||B._stillInvisible&&!B.isVisible)S+=3*(D=k.length),R+=4*D,w+=2*D;else{if(B.isVisible){B._stillInvisible=!1;var X=b[12];if(B.pivot.multiplyToRef(W,X),this.billboard&&(j.x=0,j.y=0),(this._computeParticleRotation||this.billboard)&&B.getRotationMatrix(n),null!==B.parentId){var K=this.getParticleById(B.parentId);if(K){var Y=K._rotationMatrix,q=K._globalPosition,Z=z.x*Y[1]+z.y*Y[4]+z.z*Y[7],Q=z.x*Y[0]+z.y*Y[3]+z.z*Y[6],J=z.x*Y[2]+z.y*Y[5]+z.z*Y[8];if(G.x=q.x+Q,G.y=q.y+Z,G.z=q.z+J,this._computeParticleRotation||this.billboard){var $=n.m;V[0]=$[0]*Y[0]+$[1]*Y[3]+$[2]*Y[6],V[1]=$[0]*Y[1]+$[1]*Y[4]+$[2]*Y[7],V[2]=$[0]*Y[2]+$[1]*Y[5]+$[2]*Y[8],V[3]=$[4]*Y[0]+$[5]*Y[3]+$[6]*Y[6],V[4]=$[4]*Y[1]+$[5]*Y[4]+$[6]*Y[7],V[5]=$[4]*Y[2]+$[5]*Y[5]+$[6]*Y[8],V[6]=$[8]*Y[0]+$[9]*Y[3]+$[10]*Y[6],V[7]=$[8]*Y[1]+$[9]*Y[4]+$[10]*Y[7],V[8]=$[8]*Y[2]+$[9]*Y[5]+$[10]*Y[8]}}else B.parentId=null}else if(G.x=z.x,G.y=z.y,G.z=z.z,this._computeParticleRotation||this.billboard){$=n.m;V[0]=$[0],V[1]=$[1],V[2]=$[2],V[3]=$[4],V[4]=$[5],V[5]=$[6],V[6]=$[8],V[7]=$[9],V[8]=$[10]}var ee=b[11];for(B.translateFromPivot?ee.setAll(0):ee.copyFrom(X),D=0;D0)for(var t=0;tr.x?r.x:n)r.y?r.y:o)i.x?t.x:i.x,t.y>i.y?t.y:i.y)},e.Transform=function(t,i){var r=e.Zero();return e.TransformToRef(t,i,r),r},e.TransformToRef=function(e,t,i){var r=t.m,n=e.x*r[0]+e.y*r[4]+r[12],o=e.x*r[1]+e.y*r[5]+r[13];i.x=n,i.y=o},e.PointInTriangle=function(e,t,i,r){var n=.5*(-i.y*r.x+t.y*(-i.x+r.x)+t.x*(i.y-r.y)+i.x*r.y),o=n<0?-1:1,s=(t.y*r.x-t.x*r.y+(r.y-t.y)*e.x+(t.x-r.x)*e.y)*o,a=(t.x*i.y-t.y*i.x+(t.y-i.y)*e.x+(i.x-t.x)*e.y)*o;return s>0&&a>0&&s+a<2*n*o},e.Distance=function(t,i){return Math.sqrt(e.DistanceSquared(t,i))},e.DistanceSquared=function(e,t){var i=e.x-t.x,r=e.y-t.y;return i*i+r*r},e.Center=function(e,t){var i=e.add(t);return i.scaleInPlace(.5),i},e.DistanceOfPointFromSegment=function(t,i,r){var n=e.DistanceSquared(i,r);if(0===n)return e.Distance(t,i);var o=r.subtract(i),s=Math.max(0,Math.min(1,e.Dot(t.subtract(i),o)/n)),a=i.add(o.multiplyByFloats(s,s));return e.Distance(t,a)},e}(),l=function(){function e(e,t,i){void 0===e&&(e=0),void 0===t&&(t=0),void 0===i&&(i=0),this._isDirty=!0,this._x=e,this._y=t,this._z=i}return Object.defineProperty(e.prototype,"x",{get:function(){return this._x},set:function(e){this._x=e,this._isDirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"y",{get:function(){return this._y},set:function(e){this._y=e,this._isDirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"z",{get:function(){return this._z},set:function(e){this._z=e,this._isDirty=!0},enumerable:!1,configurable:!0}),e.prototype.toString=function(){return"{X: "+this._x+" Y:"+this._y+" Z:"+this._z+"}"},e.prototype.getClassName=function(){return"Vector3"},e.prototype.getHashCode=function(){var e=0|this._x;return e=397*(e=397*e^(0|this._y))^(0|this._z)},e.prototype.asArray=function(){var e=[];return this.toArray(e,0),e},e.prototype.toArray=function(e,t){return void 0===t&&(t=0),e[t]=this._x,e[t+1]=this._y,e[t+2]=this._z,this},e.prototype.fromArray=function(t,i){return void 0===i&&(i=0),e.FromArrayToRef(t,i,this),this},e.prototype.toQuaternion=function(){return u.RotationYawPitchRoll(this._y,this._x,this._z)},e.prototype.addInPlace=function(e){return this.addInPlaceFromFloats(e._x,e._y,e._z)},e.prototype.addInPlaceFromFloats=function(e,t,i){return this.x+=e,this.y+=t,this.z+=i,this},e.prototype.add=function(t){return new e(this._x+t._x,this._y+t._y,this._z+t._z)},e.prototype.addToRef=function(e,t){return t.copyFromFloats(this._x+e._x,this._y+e._y,this._z+e._z)},e.prototype.subtractInPlace=function(e){return this.x-=e._x,this.y-=e._y,this.z-=e._z,this},e.prototype.subtract=function(t){return new e(this._x-t._x,this._y-t._y,this._z-t._z)},e.prototype.subtractToRef=function(e,t){return this.subtractFromFloatsToRef(e._x,e._y,e._z,t)},e.prototype.subtractFromFloats=function(t,i,r){return new e(this._x-t,this._y-i,this._z-r)},e.prototype.subtractFromFloatsToRef=function(e,t,i,r){return r.copyFromFloats(this._x-e,this._y-t,this._z-i)},e.prototype.negate=function(){return new e(-this._x,-this._y,-this._z)},e.prototype.negateInPlace=function(){return this.x*=-1,this.y*=-1,this.z*=-1,this},e.prototype.negateToRef=function(e){return e.copyFromFloats(-1*this._x,-1*this._y,-1*this._z)},e.prototype.scaleInPlace=function(e){return this.x*=e,this.y*=e,this.z*=e,this},e.prototype.scale=function(t){return new e(this._x*t,this._y*t,this._z*t)},e.prototype.scaleToRef=function(e,t){return t.copyFromFloats(this._x*e,this._y*e,this._z*e)},e.prototype.scaleAndAddToRef=function(e,t){return t.addInPlaceFromFloats(this._x*e,this._y*e,this._z*e)},e.prototype.projectOnPlane=function(t,i){var r=e.Zero();return this.projectOnPlaneToRef(t,i,r),r},e.prototype.projectOnPlaneToRef=function(t,i,r){var n=t.normal,o=t.d,s=d.Vector3[0];this.subtractToRef(i,s),s.normalize();var a=e.Dot(s,n),h=-(e.Dot(i,n)+o)/a,l=s.scaleInPlace(h);i.addToRef(l,r)},e.prototype.equals=function(e){return e&&this._x===e._x&&this._y===e._y&&this._z===e._z},e.prototype.equalsWithEpsilon=function(e,t){return void 0===t&&(t=n.a),e&&r.a.WithinEpsilon(this._x,e._x,t)&&r.a.WithinEpsilon(this._y,e._y,t)&&r.a.WithinEpsilon(this._z,e._z,t)},e.prototype.equalsToFloats=function(e,t,i){return this._x===e&&this._y===t&&this._z===i},e.prototype.multiplyInPlace=function(e){return this.x*=e._x,this.y*=e._y,this.z*=e._z,this},e.prototype.multiply=function(e){return this.multiplyByFloats(e._x,e._y,e._z)},e.prototype.multiplyToRef=function(e,t){return t.copyFromFloats(this._x*e._x,this._y*e._y,this._z*e._z)},e.prototype.multiplyByFloats=function(t,i,r){return new e(this._x*t,this._y*i,this._z*r)},e.prototype.divide=function(t){return new e(this._x/t._x,this._y/t._y,this._z/t._z)},e.prototype.divideToRef=function(e,t){return t.copyFromFloats(this._x/e._x,this._y/e._y,this._z/e._z)},e.prototype.divideInPlace=function(e){return this.divideToRef(e,this)},e.prototype.minimizeInPlace=function(e){return this.minimizeInPlaceFromFloats(e._x,e._y,e._z)},e.prototype.maximizeInPlace=function(e){return this.maximizeInPlaceFromFloats(e._x,e._y,e._z)},e.prototype.minimizeInPlaceFromFloats=function(e,t,i){return ethis._x&&(this.x=e),t>this._y&&(this.y=t),i>this._z&&(this.z=i),this},e.prototype.isNonUniformWithinEpsilon=function(e){var t=Math.abs(this._x),i=Math.abs(this._y);if(!r.a.WithinEpsilon(t,i,e))return!0;var n=Math.abs(this._z);return!r.a.WithinEpsilon(t,n,e)||!r.a.WithinEpsilon(i,n,e)},Object.defineProperty(e.prototype,"isNonUniform",{get:function(){var e=Math.abs(this._x);return e!==Math.abs(this._y)||e!==Math.abs(this._z)},enumerable:!1,configurable:!0}),e.prototype.floor=function(){return new e(Math.floor(this._x),Math.floor(this._y),Math.floor(this._z))},e.prototype.fract=function(){return new e(this._x-Math.floor(this._x),this._y-Math.floor(this._y),this._z-Math.floor(this._z))},e.prototype.length=function(){return Math.sqrt(this._x*this._x+this._y*this._y+this._z*this._z)},e.prototype.lengthSquared=function(){return this._x*this._x+this._y*this._y+this._z*this._z},e.prototype.normalize=function(){return this.normalizeFromLength(this.length())},e.prototype.reorderInPlace=function(e){var t=this;return"xyz"===(e=e.toLowerCase())||(d.Vector3[0].copyFrom(this),["x","y","z"].forEach((function(i,r){t[i]=d.Vector3[0][e[r]]}))),this},e.prototype.rotateByQuaternionToRef=function(t,i){return t.toRotationMatrix(d.Matrix[0]),e.TransformCoordinatesToRef(this,d.Matrix[0],i),i},e.prototype.rotateByQuaternionAroundPointToRef=function(e,t,i){return this.subtractToRef(t,d.Vector3[0]),d.Vector3[0].rotateByQuaternionToRef(e,d.Vector3[0]),t.addToRef(d.Vector3[0],i),i},e.prototype.cross=function(t){return e.Cross(this,t)},e.prototype.normalizeFromLength=function(e){return 0===e||1===e?this:this.scaleInPlace(1/e)},e.prototype.normalizeToNew=function(){var t=new e(0,0,0);return this.normalizeToRef(t),t},e.prototype.normalizeToRef=function(e){var t=this.length();return 0===t||1===t?e.copyFromFloats(this._x,this._y,this._z):this.scaleToRef(1/t,e)},e.prototype.clone=function(){return new e(this._x,this._y,this._z)},e.prototype.copyFrom=function(e){return this.copyFromFloats(e._x,e._y,e._z)},e.prototype.copyFromFloats=function(e,t,i){return this.x=e,this.y=t,this.z=i,this},e.prototype.set=function(e,t,i){return this.copyFromFloats(e,t,i)},e.prototype.setAll=function(e){return this.x=this.y=this.z=e,this},e.GetClipFactor=function(t,i,r,n){var o=e.Dot(t,r)-n;return o/(o-(e.Dot(i,r)-n))},e.GetAngleBetweenVectors=function(t,i,r){var n=t.normalizeToRef(d.Vector3[1]),o=i.normalizeToRef(d.Vector3[2]),s=e.Dot(n,o),a=d.Vector3[3];return e.CrossToRef(n,o,a),e.Dot(a,r)>0?Math.acos(s):-Math.acos(s)},e.FromArray=function(t,i){return void 0===i&&(i=0),new e(t[i],t[i+1],t[i+2])},e.FromFloatArray=function(t,i){return e.FromArray(t,i)},e.FromArrayToRef=function(e,t,i){i.x=e[t],i.y=e[t+1],i.z=e[t+2]},e.FromFloatArrayToRef=function(t,i,r){return e.FromArrayToRef(t,i,r)},e.FromFloatsToRef=function(e,t,i,r){r.copyFromFloats(e,t,i)},e.Zero=function(){return new e(0,0,0)},e.One=function(){return new e(1,1,1)},e.Up=function(){return new e(0,1,0)},Object.defineProperty(e,"UpReadOnly",{get:function(){return e._UpReadOnly},enumerable:!1,configurable:!0}),Object.defineProperty(e,"ZeroReadOnly",{get:function(){return e._ZeroReadOnly},enumerable:!1,configurable:!0}),e.Down=function(){return new e(0,-1,0)},e.Forward=function(t){return void 0===t&&(t=!1),new e(0,0,t?-1:1)},e.Backward=function(t){return void 0===t&&(t=!1),new e(0,0,t?1:-1)},e.Right=function(){return new e(1,0,0)},e.Left=function(){return new e(-1,0,0)},e.TransformCoordinates=function(t,i){var r=e.Zero();return e.TransformCoordinatesToRef(t,i,r),r},e.TransformCoordinatesToRef=function(t,i,r){e.TransformCoordinatesFromFloatsToRef(t._x,t._y,t._z,i,r)},e.TransformCoordinatesFromFloatsToRef=function(e,t,i,r,n){var o=r.m,s=e*o[0]+t*o[4]+i*o[8]+o[12],a=e*o[1]+t*o[5]+i*o[9]+o[13],h=e*o[2]+t*o[6]+i*o[10]+o[14],l=1/(e*o[3]+t*o[7]+i*o[11]+o[15]);n.x=s*l,n.y=a*l,n.z=h*l},e.TransformNormal=function(t,i){var r=e.Zero();return e.TransformNormalToRef(t,i,r),r},e.TransformNormalToRef=function(e,t,i){this.TransformNormalFromFloatsToRef(e._x,e._y,e._z,t,i)},e.TransformNormalFromFloatsToRef=function(e,t,i,r,n){var o=r.m;n.x=e*o[0]+t*o[4]+i*o[8],n.y=e*o[1]+t*o[5]+i*o[9],n.z=e*o[2]+t*o[6]+i*o[10]},e.CatmullRom=function(t,i,r,n,o){var s=o*o,a=o*s;return new e(.5*(2*i._x+(-t._x+r._x)*o+(2*t._x-5*i._x+4*r._x-n._x)*s+(-t._x+3*i._x-3*r._x+n._x)*a),.5*(2*i._y+(-t._y+r._y)*o+(2*t._y-5*i._y+4*r._y-n._y)*s+(-t._y+3*i._y-3*r._y+n._y)*a),.5*(2*i._z+(-t._z+r._z)*o+(2*t._z-5*i._z+4*r._z-n._z)*s+(-t._z+3*i._z-3*r._z+n._z)*a))},e.Clamp=function(t,i,r){var n=new e;return e.ClampToRef(t,i,r,n),n},e.ClampToRef=function(e,t,i,r){var n=e._x;n=(n=n>i._x?i._x:n)i._y?i._y:o)i._z?i._z:s)this.x&&(this.x=e.x),e.y>this.y&&(this.y=e.y),e.z>this.z&&(this.z=e.z),e.w>this.w&&(this.w=e.w),this},e.prototype.floor=function(){return new e(Math.floor(this.x),Math.floor(this.y),Math.floor(this.z),Math.floor(this.w))},e.prototype.fract=function(){return new e(this.x-Math.floor(this.x),this.y-Math.floor(this.y),this.z-Math.floor(this.z),this.w-Math.floor(this.w))},e.prototype.length=function(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w)},e.prototype.lengthSquared=function(){return this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w},e.prototype.normalize=function(){var e=this.length();return 0===e?this:this.scaleInPlace(1/e)},e.prototype.toVector3=function(){return new l(this.x,this.y,this.z)},e.prototype.clone=function(){return new e(this.x,this.y,this.z,this.w)},e.prototype.copyFrom=function(e){return this.x=e.x,this.y=e.y,this.z=e.z,this.w=e.w,this},e.prototype.copyFromFloats=function(e,t,i,r){return this.x=e,this.y=t,this.z=i,this.w=r,this},e.prototype.set=function(e,t,i,r){return this.copyFromFloats(e,t,i,r)},e.prototype.setAll=function(e){return this.x=this.y=this.z=this.w=e,this},e.FromArray=function(t,i){return i||(i=0),new e(t[i],t[i+1],t[i+2],t[i+3])},e.FromArrayToRef=function(e,t,i){i.x=e[t],i.y=e[t+1],i.z=e[t+2],i.w=e[t+3]},e.FromFloatArrayToRef=function(t,i,r){e.FromArrayToRef(t,i,r)},e.FromFloatsToRef=function(e,t,i,r,n){n.x=e,n.y=t,n.z=i,n.w=r},e.Zero=function(){return new e(0,0,0,0)},e.One=function(){return new e(1,1,1,1)},e.Normalize=function(t){var i=e.Zero();return e.NormalizeToRef(t,i),i},e.NormalizeToRef=function(e,t){t.copyFrom(e),t.normalize()},e.Minimize=function(e,t){var i=e.clone();return i.minimizeInPlace(t),i},e.Maximize=function(e,t){var i=e.clone();return i.maximizeInPlace(t),i},e.Distance=function(t,i){return Math.sqrt(e.DistanceSquared(t,i))},e.DistanceSquared=function(e,t){var i=e.x-t.x,r=e.y-t.y,n=e.z-t.z,o=e.w-t.w;return i*i+r*r+n*n+o*o},e.Center=function(e,t){var i=e.add(t);return i.scaleInPlace(.5),i},e.TransformNormal=function(t,i){var r=e.Zero();return e.TransformNormalToRef(t,i,r),r},e.TransformNormalToRef=function(e,t,i){var r=t.m,n=e.x*r[0]+e.y*r[4]+e.z*r[8],o=e.x*r[1]+e.y*r[5]+e.z*r[9],s=e.x*r[2]+e.y*r[6]+e.z*r[10];i.x=n,i.y=o,i.z=s,i.w=e.w},e.TransformNormalFromFloatsToRef=function(e,t,i,r,n,o){var s=n.m;o.x=e*s[0]+t*s[4]+i*s[8],o.y=e*s[1]+t*s[5]+i*s[9],o.z=e*s[2]+t*s[6]+i*s[10],o.w=r},e.FromVector3=function(t,i){return void 0===i&&(i=0),new e(t._x,t._y,t._z,i)},e}(),u=function(){function e(e,t,i,r){void 0===e&&(e=0),void 0===t&&(t=0),void 0===i&&(i=0),void 0===r&&(r=1),this._isDirty=!0,this._x=e,this._y=t,this._z=i,this._w=r}return Object.defineProperty(e.prototype,"x",{get:function(){return this._x},set:function(e){this._x=e,this._isDirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"y",{get:function(){return this._y},set:function(e){this._y=e,this._isDirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"z",{get:function(){return this._z},set:function(e){this._z=e,this._isDirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"w",{get:function(){return this._w},set:function(e){this._w=e,this._isDirty=!0},enumerable:!1,configurable:!0}),e.prototype.toString=function(){return"{X: "+this._x+" Y:"+this._y+" Z:"+this._z+" W:"+this._w+"}"},e.prototype.getClassName=function(){return"Quaternion"},e.prototype.getHashCode=function(){var e=0|this._x;return e=397*(e=397*(e=397*e^(0|this._y))^(0|this._z))^(0|this._w)},e.prototype.asArray=function(){return[this._x,this._y,this._z,this._w]},e.prototype.equals=function(e){return e&&this._x===e._x&&this._y===e._y&&this._z===e._z&&this._w===e._w},e.prototype.equalsWithEpsilon=function(e,t){return void 0===t&&(t=n.a),e&&r.a.WithinEpsilon(this._x,e._x,t)&&r.a.WithinEpsilon(this._y,e._y,t)&&r.a.WithinEpsilon(this._z,e._z,t)&&r.a.WithinEpsilon(this._w,e._w,t)},e.prototype.clone=function(){return new e(this._x,this._y,this._z,this._w)},e.prototype.copyFrom=function(e){return this.x=e._x,this.y=e._y,this.z=e._z,this.w=e._w,this},e.prototype.copyFromFloats=function(e,t,i,r){return this.x=e,this.y=t,this.z=i,this.w=r,this},e.prototype.set=function(e,t,i,r){return this.copyFromFloats(e,t,i,r)},e.prototype.add=function(t){return new e(this._x+t._x,this._y+t._y,this._z+t._z,this._w+t._w)},e.prototype.addInPlace=function(e){return this._x+=e._x,this._y+=e._y,this._z+=e._z,this._w+=e._w,this},e.prototype.subtract=function(t){return new e(this._x-t._x,this._y-t._y,this._z-t._z,this._w-t._w)},e.prototype.scale=function(t){return new e(this._x*t,this._y*t,this._z*t,this._w*t)},e.prototype.scaleToRef=function(e,t){return t.x=this._x*e,t.y=this._y*e,t.z=this._z*e,t.w=this._w*e,this},e.prototype.scaleInPlace=function(e){return this.x*=e,this.y*=e,this.z*=e,this.w*=e,this},e.prototype.scaleAndAddToRef=function(e,t){return t.x+=this._x*e,t.y+=this._y*e,t.z+=this._z*e,t.w+=this._w*e,this},e.prototype.multiply=function(t){var i=new e(0,0,0,1);return this.multiplyToRef(t,i),i},e.prototype.multiplyToRef=function(e,t){var i=this._x*e._w+this._y*e._z-this._z*e._y+this._w*e._x,r=-this._x*e._z+this._y*e._w+this._z*e._x+this._w*e._y,n=this._x*e._y-this._y*e._x+this._z*e._w+this._w*e._z,o=-this._x*e._x-this._y*e._y-this._z*e._z+this._w*e._w;return t.copyFromFloats(i,r,n,o),this},e.prototype.multiplyInPlace=function(e){return this.multiplyToRef(e,this),this},e.prototype.conjugateToRef=function(e){return e.copyFromFloats(-this._x,-this._y,-this._z,this._w),this},e.prototype.conjugateInPlace=function(){return this.x*=-1,this.y*=-1,this.z*=-1,this},e.prototype.conjugate=function(){return new e(-this._x,-this._y,-this._z,this._w)},e.prototype.length=function(){return Math.sqrt(this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w)},e.prototype.normalize=function(){var e=this.length();if(0===e)return this;var t=1/e;return this.x*=t,this.y*=t,this.z*=t,this.w*=t,this},e.prototype.toEulerAngles=function(e){void 0===e&&(e="YZX");var t=l.Zero();return this.toEulerAnglesToRef(t),t},e.prototype.toEulerAnglesToRef=function(e){var t=this._z,i=this._x,r=this._y,n=this._w,o=n*n,s=t*t,a=i*i,h=r*r,l=r*t-i*n,c=.4999999;return l<-c?(e.y=2*Math.atan2(r,n),e.x=Math.PI/2,e.z=0):l>c?(e.y=2*Math.atan2(r,n),e.x=-Math.PI/2,e.z=0):(e.z=Math.atan2(2*(i*r+t*n),-s-a+h+o),e.x=Math.asin(-2*(t*r-i*n)),e.y=Math.atan2(2*(t*i+r*n),s-a-h+o)),this},e.prototype.toRotationMatrix=function(e){return f.FromQuaternionToRef(this,e),this},e.prototype.fromRotationMatrix=function(t){return e.FromRotationMatrixToRef(t,this),this},e.FromRotationMatrix=function(t){var i=new e;return e.FromRotationMatrixToRef(t,i),i},e.FromRotationMatrixToRef=function(e,t){var i,r=e.m,n=r[0],o=r[4],s=r[8],a=r[1],h=r[5],l=r[9],c=r[2],u=r[6],f=r[10],d=n+h+f;d>0?(i=.5/Math.sqrt(d+1),t.w=.25/i,t.x=(u-l)*i,t.y=(s-c)*i,t.z=(a-o)*i):n>h&&n>f?(i=2*Math.sqrt(1+n-h-f),t.w=(u-l)/i,t.x=.25*i,t.y=(o+a)/i,t.z=(s+c)/i):h>f?(i=2*Math.sqrt(1+h-n-f),t.w=(s-c)/i,t.x=(o+a)/i,t.y=.25*i,t.z=(l+u)/i):(i=2*Math.sqrt(1+f-n-h),t.w=(a-o)/i,t.x=(s+c)/i,t.y=(l+u)/i,t.z=.25*i)},e.Dot=function(e,t){return e._x*t._x+e._y*t._y+e._z*t._z+e._w*t._w},e.AreClose=function(t,i){return e.Dot(t,i)>=0},e.Zero=function(){return new e(0,0,0,0)},e.Inverse=function(t){return new e(-t._x,-t._y,-t._z,t._w)},e.InverseToRef=function(e,t){return t.set(-e._x,-e._y,-e._z,e._w),t},e.Identity=function(){return new e(0,0,0,1)},e.IsIdentity=function(e){return e&&0===e._x&&0===e._y&&0===e._z&&1===e._w},e.RotationAxis=function(t,i){return e.RotationAxisToRef(t,i,new e)},e.RotationAxisToRef=function(e,t,i){var r=Math.sin(t/2);return e.normalize(),i.w=Math.cos(t/2),i.x=e._x*r,i.y=e._y*r,i.z=e._z*r,i},e.FromArray=function(t,i){return i||(i=0),new e(t[i],t[i+1],t[i+2],t[i+3])},e.FromArrayToRef=function(e,t,i){i.x=e[t],i.y=e[t+1],i.z=e[t+2],i.w=e[t+3]},e.FromEulerAngles=function(t,i,r){var n=new e;return e.RotationYawPitchRollToRef(i,t,r,n),n},e.FromEulerAnglesToRef=function(t,i,r,n){return e.RotationYawPitchRollToRef(i,t,r,n),n},e.FromEulerVector=function(t){var i=new e;return e.RotationYawPitchRollToRef(t._y,t._x,t._z,i),i},e.FromEulerVectorToRef=function(t,i){return e.RotationYawPitchRollToRef(t._y,t._x,t._z,i),i},e.RotationYawPitchRoll=function(t,i,r){var n=new e;return e.RotationYawPitchRollToRef(t,i,r,n),n},e.RotationYawPitchRollToRef=function(e,t,i,r){var n=.5*i,o=.5*t,s=.5*e,a=Math.sin(n),h=Math.cos(n),l=Math.sin(o),c=Math.cos(o),u=Math.sin(s),f=Math.cos(s);r.x=f*l*h+u*c*a,r.y=u*c*h-f*l*a,r.z=f*c*a-u*l*h,r.w=f*c*h+u*l*a},e.RotationAlphaBetaGamma=function(t,i,r){var n=new e;return e.RotationAlphaBetaGammaToRef(t,i,r,n),n},e.RotationAlphaBetaGammaToRef=function(e,t,i,r){var n=.5*(i+e),o=.5*(i-e),s=.5*t;r.x=Math.cos(o)*Math.sin(s),r.y=Math.sin(o)*Math.sin(s),r.z=Math.sin(n)*Math.cos(s),r.w=Math.cos(n)*Math.cos(s)},e.RotationQuaternionFromAxis=function(t,i,r){var n=new e(0,0,0,0);return e.RotationQuaternionFromAxisToRef(t,i,r,n),n},e.RotationQuaternionFromAxisToRef=function(t,i,r,n){var o=d.Matrix[0];f.FromXYZAxesToRef(t.normalize(),i.normalize(),r.normalize(),o),e.FromRotationMatrixToRef(o,n)},e.Slerp=function(t,i,r){var n=e.Identity();return e.SlerpToRef(t,i,r,n),n},e.SlerpToRef=function(e,t,i,r){var n,o,s=e._x*t._x+e._y*t._y+e._z*t._z+e._w*t._w,a=!1;if(s<0&&(a=!0,s=-s),s>.999999)o=1-i,n=a?-i:i;else{var h=Math.acos(s),l=1/Math.sin(h);o=Math.sin((1-i)*h)*l,n=a?-Math.sin(i*h)*l:Math.sin(i*h)*l}r.x=o*e._x+n*t._x,r.y=o*e._y+n*t._y,r.z=o*e._z+n*t._z,r.w=o*e._w+n*t._w},e.Hermite=function(t,i,r,n,o){var s=o*o,a=o*s,h=2*a-3*s+1,l=-2*a+3*s,c=a-2*s+o,u=a-s;return new e(t._x*h+r._x*l+i._x*c+n._x*u,t._y*h+r._y*l+i._y*c+n._y*u,t._z*h+r._z*l+i._z*c+n._z*u,t._w*h+r._w*l+i._w*c+n._w*u)},e}(),f=function(){function e(){this._isIdentity=!1,this._isIdentityDirty=!0,this._isIdentity3x2=!0,this._isIdentity3x2Dirty=!0,this.updateFlag=-1,a.a.MatrixTrackPrecisionChange&&a.a.MatrixTrackedMatrices.push(this),this._m=new a.a.MatrixCurrentType(16),this._updateIdentityStatus(!1)}return Object.defineProperty(e,"Use64Bits",{get:function(){return a.a.MatrixUse64Bits},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"m",{get:function(){return this._m},enumerable:!1,configurable:!0}),e.prototype._markAsUpdated=function(){this.updateFlag=e._updateFlagSeed++,this._isIdentity=!1,this._isIdentity3x2=!1,this._isIdentityDirty=!0,this._isIdentity3x2Dirty=!0},e.prototype._updateIdentityStatus=function(t,i,r,n){void 0===i&&(i=!1),void 0===r&&(r=!1),void 0===n&&(n=!0),this.updateFlag=e._updateFlagSeed++,this._isIdentity=t,this._isIdentity3x2=t||r,this._isIdentityDirty=!this._isIdentity&&i,this._isIdentity3x2Dirty=!this._isIdentity3x2&&n},e.prototype.isIdentity=function(){if(this._isIdentityDirty){this._isIdentityDirty=!1;var e=this._m;this._isIdentity=1===e[0]&&0===e[1]&&0===e[2]&&0===e[3]&&0===e[4]&&1===e[5]&&0===e[6]&&0===e[7]&&0===e[8]&&0===e[9]&&1===e[10]&&0===e[11]&&0===e[12]&&0===e[13]&&0===e[14]&&1===e[15]}return this._isIdentity},e.prototype.isIdentityAs3x2=function(){return this._isIdentity3x2Dirty&&(this._isIdentity3x2Dirty=!1,1!==this._m[0]||1!==this._m[5]||1!==this._m[15]||0!==this._m[1]||0!==this._m[2]||0!==this._m[3]||0!==this._m[4]||0!==this._m[6]||0!==this._m[7]||0!==this._m[8]||0!==this._m[9]||0!==this._m[10]||0!==this._m[11]||0!==this._m[12]||0!==this._m[13]||0!==this._m[14]?this._isIdentity3x2=!1:this._isIdentity3x2=!0),this._isIdentity3x2},e.prototype.determinant=function(){if(!0===this._isIdentity)return 1;var e=this._m,t=e[0],i=e[1],r=e[2],n=e[3],o=e[4],s=e[5],a=e[6],h=e[7],l=e[8],c=e[9],u=e[10],f=e[11],d=e[12],p=e[13],_=e[14],g=e[15],m=u*g-_*f,v=c*g-p*f,b=c*_-p*u,y=l*g-d*f,T=l*_-u*d,x=l*p-d*c;return t*+(s*m-a*v+h*b)+i*-(o*m-a*y+h*T)+r*+(o*v-s*y+h*x)+n*-(o*b-s*T+a*x)},e.prototype.toArray=function(){return this._m},e.prototype.asArray=function(){return this._m},e.prototype.invert=function(){return this.invertToRef(this),this},e.prototype.reset=function(){return e.FromValuesToRef(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,this),this._updateIdentityStatus(!1),this},e.prototype.add=function(t){var i=new e;return this.addToRef(t,i),i},e.prototype.addToRef=function(e,t){for(var i=this._m,r=t._m,n=e.m,o=0;o<16;o++)r[o]=i[o]+n[o];return t._markAsUpdated(),this},e.prototype.addToSelf=function(e){for(var t=this._m,i=e.m,r=0;r<16;r++)t[r]+=i[r];return this._markAsUpdated(),this},e.prototype.invertToRef=function(t){if(!0===this._isIdentity)return e.IdentityToRef(t),this;var i=this._m,r=i[0],n=i[1],o=i[2],s=i[3],a=i[4],h=i[5],l=i[6],c=i[7],u=i[8],f=i[9],d=i[10],p=i[11],_=i[12],g=i[13],m=i[14],v=i[15],b=d*v-m*p,y=f*v-g*p,T=f*m-g*d,x=u*v-_*p,E=u*m-d*_,A=u*g-_*f,M=+(h*b-l*y+c*T),S=-(a*b-l*x+c*E),O=+(a*y-h*x+c*A),P=-(a*T-h*E+l*A),C=r*M+n*S+o*O+s*P;if(0===C)return t.copyFrom(this),this;var I=1/C,R=l*v-m*c,D=h*v-g*c,w=h*m-g*l,L=a*v-_*c,F=a*m-_*l,N=a*g-_*h,B=l*p-d*c,k=h*p-f*c,U=h*d-f*l,V=a*p-u*c,j=a*d-u*l,z=a*f-u*h,W=-(n*b-o*y+s*T),G=+(r*b-o*x+s*E),H=-(r*y-n*x+s*A),X=+(r*T-n*E+o*A),K=+(n*R-o*D+s*w),Y=-(r*R-o*L+s*F),q=+(r*D-n*L+s*N),Z=-(r*w-n*F+o*N),Q=-(n*B-o*k+s*U),J=+(r*B-o*V+s*j),$=-(r*k-n*V+s*z),ee=+(r*U-n*j+o*z);return e.FromValuesToRef(M*I,W*I,K*I,Q*I,S*I,G*I,Y*I,J*I,O*I,H*I,q*I,$*I,P*I,X*I,Z*I,ee*I,t),this},e.prototype.addAtIndex=function(e,t){return this._m[e]+=t,this._markAsUpdated(),this},e.prototype.multiplyAtIndex=function(e,t){return this._m[e]*=t,this._markAsUpdated(),this},e.prototype.setTranslationFromFloats=function(e,t,i){return this._m[12]=e,this._m[13]=t,this._m[14]=i,this._markAsUpdated(),this},e.prototype.addTranslationFromFloats=function(e,t,i){return this._m[12]+=e,this._m[13]+=t,this._m[14]+=i,this._markAsUpdated(),this},e.prototype.setTranslation=function(e){return this.setTranslationFromFloats(e._x,e._y,e._z)},e.prototype.getTranslation=function(){return new l(this._m[12],this._m[13],this._m[14])},e.prototype.getTranslationToRef=function(e){return e.x=this._m[12],e.y=this._m[13],e.z=this._m[14],this},e.prototype.removeRotationAndScaling=function(){var t=this.m;return e.FromValuesToRef(1,0,0,0,0,1,0,0,0,0,1,0,t[12],t[13],t[14],t[15],this),this._updateIdentityStatus(0===t[12]&&0===t[13]&&0===t[14]&&1===t[15]),this},e.prototype.multiply=function(t){var i=new e;return this.multiplyToRef(t,i),i},e.prototype.copyFrom=function(e){e.copyToArray(this._m);var t=e;return this._updateIdentityStatus(t._isIdentity,t._isIdentityDirty,t._isIdentity3x2,t._isIdentity3x2Dirty),this},e.prototype.copyToArray=function(e,t){void 0===t&&(t=0);var i=this._m;return e[t]=i[0],e[t+1]=i[1],e[t+2]=i[2],e[t+3]=i[3],e[t+4]=i[4],e[t+5]=i[5],e[t+6]=i[6],e[t+7]=i[7],e[t+8]=i[8],e[t+9]=i[9],e[t+10]=i[10],e[t+11]=i[11],e[t+12]=i[12],e[t+13]=i[13],e[t+14]=i[14],e[t+15]=i[15],this},e.prototype.multiplyToRef=function(e,t){return this._isIdentity?(t.copyFrom(e),this):e._isIdentity?(t.copyFrom(this),this):(this.multiplyToArray(e,t._m,0),t._markAsUpdated(),this)},e.prototype.multiplyToArray=function(e,t,i){var r=this._m,n=e.m,o=r[0],s=r[1],a=r[2],h=r[3],l=r[4],c=r[5],u=r[6],f=r[7],d=r[8],p=r[9],_=r[10],g=r[11],m=r[12],v=r[13],b=r[14],y=r[15],T=n[0],x=n[1],E=n[2],A=n[3],M=n[4],S=n[5],O=n[6],P=n[7],C=n[8],I=n[9],R=n[10],D=n[11],w=n[12],L=n[13],F=n[14],N=n[15];return t[i]=o*T+s*M+a*C+h*w,t[i+1]=o*x+s*S+a*I+h*L,t[i+2]=o*E+s*O+a*R+h*F,t[i+3]=o*A+s*P+a*D+h*N,t[i+4]=l*T+c*M+u*C+f*w,t[i+5]=l*x+c*S+u*I+f*L,t[i+6]=l*E+c*O+u*R+f*F,t[i+7]=l*A+c*P+u*D+f*N,t[i+8]=d*T+p*M+_*C+g*w,t[i+9]=d*x+p*S+_*I+g*L,t[i+10]=d*E+p*O+_*R+g*F,t[i+11]=d*A+p*P+_*D+g*N,t[i+12]=m*T+v*M+b*C+y*w,t[i+13]=m*x+v*S+b*I+y*L,t[i+14]=m*E+v*O+b*R+y*F,t[i+15]=m*A+v*P+b*D+y*N,this},e.prototype.equals=function(e){var t=e;if(!t)return!1;if((this._isIdentity||t._isIdentity)&&!this._isIdentityDirty&&!t._isIdentityDirty)return this._isIdentity&&t._isIdentity;var i=this.m,r=t.m;return i[0]===r[0]&&i[1]===r[1]&&i[2]===r[2]&&i[3]===r[3]&&i[4]===r[4]&&i[5]===r[5]&&i[6]===r[6]&&i[7]===r[7]&&i[8]===r[8]&&i[9]===r[9]&&i[10]===r[10]&&i[11]===r[11]&&i[12]===r[12]&&i[13]===r[13]&&i[14]===r[14]&&i[15]===r[15]},e.prototype.clone=function(){var t=new e;return t.copyFrom(this),t},e.prototype.getClassName=function(){return"Matrix"},e.prototype.getHashCode=function(){for(var e=0|this._m[0],t=1;t<16;t++)e=397*e^(0|this._m[t]);return e},e.prototype.decompose=function(t,i,r){if(this._isIdentity)return r&&r.setAll(0),t&&t.setAll(1),i&&i.copyFromFloats(0,0,0,1),!0;var n=this._m;if(r&&r.copyFromFloats(n[12],n[13],n[14]),(t=t||d.Vector3[0]).x=Math.sqrt(n[0]*n[0]+n[1]*n[1]+n[2]*n[2]),t.y=Math.sqrt(n[4]*n[4]+n[5]*n[5]+n[6]*n[6]),t.z=Math.sqrt(n[8]*n[8]+n[9]*n[9]+n[10]*n[10]),this.determinant()<=0&&(t.y*=-1),0===t._x||0===t._y||0===t._z)return i&&i.copyFromFloats(0,0,0,1),!1;if(i){var o=1/t._x,s=1/t._y,a=1/t._z;e.FromValuesToRef(n[0]*o,n[1]*o,n[2]*o,0,n[4]*s,n[5]*s,n[6]*s,0,n[8]*a,n[9]*a,n[10]*a,0,0,0,0,1,d.Matrix[0]),u.FromRotationMatrixToRef(d.Matrix[0],i)}return!0},e.prototype.getRow=function(e){if(e<0||e>3)return null;var t=4*e;return new c(this._m[t+0],this._m[t+1],this._m[t+2],this._m[t+3])},e.prototype.setRow=function(e,t){return this.setRowFromFloats(e,t.x,t.y,t.z,t.w)},e.prototype.transpose=function(){return e.Transpose(this)},e.prototype.transposeToRef=function(t){return e.TransposeToRef(this,t),this},e.prototype.setRowFromFloats=function(e,t,i,r,n){if(e<0||e>3)return this;var o=4*e;return this._m[o+0]=t,this._m[o+1]=i,this._m[o+2]=r,this._m[o+3]=n,this._markAsUpdated(),this},e.prototype.scale=function(t){var i=new e;return this.scaleToRef(t,i),i},e.prototype.scaleToRef=function(e,t){for(var i=0;i<16;i++)t._m[i]=this._m[i]*e;return t._markAsUpdated(),this},e.prototype.scaleAndAddToRef=function(e,t){for(var i=0;i<16;i++)t._m[i]+=this._m[i]*e;return t._markAsUpdated(),this},e.prototype.toNormalMatrix=function(t){var i=d.Matrix[0];this.invertToRef(i),i.transposeToRef(t);var r=t._m;e.FromValuesToRef(r[0],r[1],r[2],0,r[4],r[5],r[6],0,r[8],r[9],r[10],0,0,0,0,1,t)},e.prototype.getRotationMatrix=function(){var t=new e;return this.getRotationMatrixToRef(t),t},e.prototype.getRotationMatrixToRef=function(t){var i=d.Vector3[0];if(!this.decompose(i))return e.IdentityToRef(t),this;var r=this._m,n=1/i._x,o=1/i._y,s=1/i._z;return e.FromValuesToRef(r[0]*n,r[1]*n,r[2]*n,0,r[4]*o,r[5]*o,r[6]*o,0,r[8]*s,r[9]*s,r[10]*s,0,0,0,0,1,t),this},e.prototype.toggleModelMatrixHandInPlace=function(){var e=this._m;e[2]*=-1,e[6]*=-1,e[8]*=-1,e[9]*=-1,e[14]*=-1,this._markAsUpdated()},e.prototype.toggleProjectionMatrixHandInPlace=function(){var e=this._m;e[8]*=-1,e[9]*=-1,e[10]*=-1,e[11]*=-1,this._markAsUpdated()},e.FromArray=function(t,i){void 0===i&&(i=0);var r=new e;return e.FromArrayToRef(t,i,r),r},e.FromArrayToRef=function(e,t,i){for(var r=0;r<16;r++)i._m[r]=e[r+t];i._markAsUpdated()},e.FromFloat32ArrayToRefScaled=function(e,t,i,r){for(var n=0;n<16;n++)r._m[n]=e[n+t]*i;r._markAsUpdated()},Object.defineProperty(e,"IdentityReadOnly",{get:function(){return e._identityReadOnly},enumerable:!1,configurable:!0}),e.FromValuesToRef=function(e,t,i,r,n,o,s,a,h,l,c,u,f,d,p,_,g){var m=g._m;m[0]=e,m[1]=t,m[2]=i,m[3]=r,m[4]=n,m[5]=o,m[6]=s,m[7]=a,m[8]=h,m[9]=l,m[10]=c,m[11]=u,m[12]=f,m[13]=d,m[14]=p,m[15]=_,g._markAsUpdated()},e.FromValues=function(t,i,r,n,o,s,a,h,l,c,u,f,d,p,_,g){var m=new e,v=m._m;return v[0]=t,v[1]=i,v[2]=r,v[3]=n,v[4]=o,v[5]=s,v[6]=a,v[7]=h,v[8]=l,v[9]=c,v[10]=u,v[11]=f,v[12]=d,v[13]=p,v[14]=_,v[15]=g,m._markAsUpdated(),m},e.Compose=function(t,i,r){var n=new e;return e.ComposeToRef(t,i,r,n),n},e.ComposeToRef=function(e,t,i,r){var n=r._m,o=t._x,s=t._y,a=t._z,h=t._w,l=o+o,c=s+s,u=a+a,f=o*l,d=o*c,p=o*u,_=s*c,g=s*u,m=a*u,v=h*l,b=h*c,y=h*u,T=e._x,x=e._y,E=e._z;n[0]=(1-(_+m))*T,n[1]=(d+y)*T,n[2]=(p-b)*T,n[3]=0,n[4]=(d-y)*x,n[5]=(1-(f+m))*x,n[6]=(g+v)*x,n[7]=0,n[8]=(p+b)*E,n[9]=(g-v)*E,n[10]=(1-(f+_))*E,n[11]=0,n[12]=i._x,n[13]=i._y,n[14]=i._z,n[15]=1,r._markAsUpdated()},e.Identity=function(){var t=e.FromValues(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);return t._updateIdentityStatus(!0),t},e.IdentityToRef=function(t){e.FromValuesToRef(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,t),t._updateIdentityStatus(!0)},e.Zero=function(){var t=e.FromValues(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0);return t._updateIdentityStatus(!1),t},e.RotationX=function(t){var i=new e;return e.RotationXToRef(t,i),i},e.Invert=function(t){var i=new e;return t.invertToRef(i),i},e.RotationXToRef=function(t,i){var r=Math.sin(t),n=Math.cos(t);e.FromValuesToRef(1,0,0,0,0,n,r,0,0,-r,n,0,0,0,0,1,i),i._updateIdentityStatus(1===n&&0===r)},e.RotationY=function(t){var i=new e;return e.RotationYToRef(t,i),i},e.RotationYToRef=function(t,i){var r=Math.sin(t),n=Math.cos(t);e.FromValuesToRef(n,0,-r,0,0,1,0,0,r,0,n,0,0,0,0,1,i),i._updateIdentityStatus(1===n&&0===r)},e.RotationZ=function(t){var i=new e;return e.RotationZToRef(t,i),i},e.RotationZToRef=function(t,i){var r=Math.sin(t),n=Math.cos(t);e.FromValuesToRef(n,r,0,0,-r,n,0,0,0,0,1,0,0,0,0,1,i),i._updateIdentityStatus(1===n&&0===r)},e.RotationAxis=function(t,i){var r=new e;return e.RotationAxisToRef(t,i,r),r},e.RotationAxisToRef=function(e,t,i){var r=Math.sin(-t),n=Math.cos(-t),o=1-n;e.normalize();var s=i._m;s[0]=e._x*e._x*o+n,s[1]=e._x*e._y*o-e._z*r,s[2]=e._x*e._z*o+e._y*r,s[3]=0,s[4]=e._y*e._x*o+e._z*r,s[5]=e._y*e._y*o+n,s[6]=e._y*e._z*o-e._x*r,s[7]=0,s[8]=e._z*e._x*o-e._y*r,s[9]=e._z*e._y*o+e._x*r,s[10]=e._z*e._z*o+n,s[11]=0,s[12]=0,s[13]=0,s[14]=0,s[15]=1,i._markAsUpdated()},e.RotationAlignToRef=function(e,t,i){var r=l.Cross(t,e),n=l.Dot(t,e),o=1/(1+n),s=i._m;s[0]=r._x*r._x*o+n,s[1]=r._y*r._x*o-r._z,s[2]=r._z*r._x*o+r._y,s[3]=0,s[4]=r._x*r._y*o+r._z,s[5]=r._y*r._y*o+n,s[6]=r._z*r._y*o-r._x,s[7]=0,s[8]=r._x*r._z*o-r._y,s[9]=r._y*r._z*o+r._x,s[10]=r._z*r._z*o+n,s[11]=0,s[12]=0,s[13]=0,s[14]=0,s[15]=1,i._markAsUpdated()},e.RotationYawPitchRoll=function(t,i,r){var n=new e;return e.RotationYawPitchRollToRef(t,i,r,n),n},e.RotationYawPitchRollToRef=function(e,t,i,r){u.RotationYawPitchRollToRef(e,t,i,d.Quaternion[0]),d.Quaternion[0].toRotationMatrix(r)},e.Scaling=function(t,i,r){var n=new e;return e.ScalingToRef(t,i,r,n),n},e.ScalingToRef=function(t,i,r,n){e.FromValuesToRef(t,0,0,0,0,i,0,0,0,0,r,0,0,0,0,1,n),n._updateIdentityStatus(1===t&&1===i&&1===r)},e.Translation=function(t,i,r){var n=new e;return e.TranslationToRef(t,i,r,n),n},e.TranslationToRef=function(t,i,r,n){e.FromValuesToRef(1,0,0,0,0,1,0,0,0,0,1,0,t,i,r,1,n),n._updateIdentityStatus(0===t&&0===i&&0===r)},e.Lerp=function(t,i,r){var n=new e;return e.LerpToRef(t,i,r,n),n},e.LerpToRef=function(e,t,i,r){for(var n=r._m,o=e.m,s=t.m,a=0;a<16;a++)n[a]=o[a]*(1-i)+s[a]*i;r._markAsUpdated()},e.DecomposeLerp=function(t,i,r){var n=new e;return e.DecomposeLerpToRef(t,i,r,n),n},e.DecomposeLerpToRef=function(t,i,r,n){var o=d.Vector3[0],s=d.Quaternion[0],a=d.Vector3[1];t.decompose(o,s,a);var h=d.Vector3[2],c=d.Quaternion[1],f=d.Vector3[3];i.decompose(h,c,f);var p=d.Vector3[4];l.LerpToRef(o,h,r,p);var _=d.Quaternion[2];u.SlerpToRef(s,c,r,_);var g=d.Vector3[5];l.LerpToRef(a,f,r,g),e.ComposeToRef(p,_,g,n)},e.LookAtLH=function(t,i,r){var n=new e;return e.LookAtLHToRef(t,i,r,n),n},e.LookAtLHToRef=function(t,i,r,n){var o=d.Vector3[0],s=d.Vector3[1],a=d.Vector3[2];i.subtractToRef(t,a),a.normalize(),l.CrossToRef(r,a,o);var h=o.lengthSquared();0===h?o.x=1:o.normalizeFromLength(Math.sqrt(h)),l.CrossToRef(a,o,s),s.normalize();var c=-l.Dot(o,t),u=-l.Dot(s,t),f=-l.Dot(a,t);e.FromValuesToRef(o._x,s._x,a._x,0,o._y,s._y,a._y,0,o._z,s._z,a._z,0,c,u,f,1,n)},e.LookAtRH=function(t,i,r){var n=new e;return e.LookAtRHToRef(t,i,r,n),n},e.LookAtRHToRef=function(t,i,r,n){var o=d.Vector3[0],s=d.Vector3[1],a=d.Vector3[2];t.subtractToRef(i,a),a.normalize(),l.CrossToRef(r,a,o);var h=o.lengthSquared();0===h?o.x=1:o.normalizeFromLength(Math.sqrt(h)),l.CrossToRef(a,o,s),s.normalize();var c=-l.Dot(o,t),u=-l.Dot(s,t),f=-l.Dot(a,t);e.FromValuesToRef(o._x,s._x,a._x,0,o._y,s._y,a._y,0,o._z,s._z,a._z,0,c,u,f,1,n)},e.OrthoLH=function(t,i,r,n){var o=new e;return e.OrthoLHToRef(t,i,r,n,o),o},e.OrthoLHToRef=function(t,i,r,n,o){var s=2/t,a=2/i,h=2/(n-r),l=-(n+r)/(n-r);e.FromValuesToRef(s,0,0,0,0,a,0,0,0,0,h,0,0,0,l,1,o),o._updateIdentityStatus(1===s&&1===a&&1===h&&0===l)},e.OrthoOffCenterLH=function(t,i,r,n,o,s){var a=new e;return e.OrthoOffCenterLHToRef(t,i,r,n,o,s,a),a},e.OrthoOffCenterLHToRef=function(t,i,r,n,o,s,a){var h=2/(i-t),l=2/(n-r),c=2/(s-o),u=-(s+o)/(s-o),f=(t+i)/(t-i),d=(n+r)/(r-n);e.FromValuesToRef(h,0,0,0,0,l,0,0,0,0,c,0,f,d,u,1,a),a._markAsUpdated()},e.OrthoOffCenterRH=function(t,i,r,n,o,s){var a=new e;return e.OrthoOffCenterRHToRef(t,i,r,n,o,s,a),a},e.OrthoOffCenterRHToRef=function(t,i,r,n,o,s,a){e.OrthoOffCenterLHToRef(t,i,r,n,o,s,a),a._m[10]*=-1},e.PerspectiveLH=function(t,i,r,n){var o=new e,s=2*r/t,a=2*r/i,h=(n+r)/(n-r),l=-2*n*r/(n-r);return e.FromValuesToRef(s,0,0,0,0,a,0,0,0,0,h,1,0,0,l,0,o),o._updateIdentityStatus(!1),o},e.PerspectiveFovLH=function(t,i,r,n){var o=new e;return e.PerspectiveFovLHToRef(t,i,r,n,o),o},e.PerspectiveFovLHToRef=function(t,i,r,n,o,s){void 0===s&&(s=!0);var a=r,h=n,l=1/Math.tan(.5*t),c=s?l/i:l,u=s?l:l*i,f=(h+a)/(h-a),d=-2*h*a/(h-a);e.FromValuesToRef(c,0,0,0,0,u,0,0,0,0,f,1,0,0,d,0,o),o._updateIdentityStatus(!1)},e.PerspectiveFovReverseLHToRef=function(t,i,r,n,o,s){void 0===s&&(s=!0);var a=1/Math.tan(.5*t),h=s?a/i:a,l=s?a:a*i;e.FromValuesToRef(h,0,0,0,0,l,0,0,0,0,-r,1,0,0,1,0,o),o._updateIdentityStatus(!1)},e.PerspectiveFovRH=function(t,i,r,n){var o=new e;return e.PerspectiveFovRHToRef(t,i,r,n,o),o},e.PerspectiveFovRHToRef=function(t,i,r,n,o,s){void 0===s&&(s=!0);var a=r,h=n,l=1/Math.tan(.5*t),c=s?l/i:l,u=s?l:l*i,f=-(h+a)/(h-a),d=-2*h*a/(h-a);e.FromValuesToRef(c,0,0,0,0,u,0,0,0,0,f,-1,0,0,d,0,o),o._updateIdentityStatus(!1)},e.PerspectiveFovReverseRHToRef=function(t,i,r,n,o,s){void 0===s&&(s=!0);var a=1/Math.tan(.5*t),h=s?a/i:a,l=s?a:a*i;e.FromValuesToRef(h,0,0,0,0,l,0,0,0,0,-r,-1,0,0,-1,0,o),o._updateIdentityStatus(!1)},e.PerspectiveFovWebVRToRef=function(e,t,i,r,n){void 0===n&&(n=!1);var o=n?-1:1,s=Math.tan(e.upDegrees*Math.PI/180),a=Math.tan(e.downDegrees*Math.PI/180),h=Math.tan(e.leftDegrees*Math.PI/180),l=Math.tan(e.rightDegrees*Math.PI/180),c=2/(h+l),u=2/(s+a),f=r._m;f[0]=c,f[1]=f[2]=f[3]=f[4]=0,f[5]=u,f[6]=f[7]=0,f[8]=(h-l)*c*.5,f[9]=-(s-a)*u*.5,f[10]=-i/(t-i),f[11]=1*o,f[12]=f[13]=f[15]=0,f[14]=-2*i*t/(i-t),r._markAsUpdated()},e.GetFinalMatrix=function(t,i,r,n,o,s){var a=t.width,h=t.height,l=t.x,c=t.y,u=e.FromValues(a/2,0,0,0,0,-h/2,0,0,0,0,s-o,0,l+a/2,h/2+c,o,1),f=d.Matrix[0];return i.multiplyToRef(r,f),f.multiplyToRef(n,f),f.multiply(u)},e.GetAsMatrix2x2=function(e){var t=e.m,i=[t[0],t[1],t[4],t[5]];return a.a.MatrixUse64Bits?i:new Float32Array(i)},e.GetAsMatrix3x3=function(e){var t=e.m,i=[t[0],t[1],t[2],t[4],t[5],t[6],t[8],t[9],t[10]];return a.a.MatrixUse64Bits?i:new Float32Array(i)},e.Transpose=function(t){var i=new e;return e.TransposeToRef(t,i),i},e.TransposeToRef=function(e,t){var i=t._m,r=e.m;i[0]=r[0],i[1]=r[4],i[2]=r[8],i[3]=r[12],i[4]=r[1],i[5]=r[5],i[6]=r[9],i[7]=r[13],i[8]=r[2],i[9]=r[6],i[10]=r[10],i[11]=r[14],i[12]=r[3],i[13]=r[7],i[14]=r[11],i[15]=r[15],t._updateIdentityStatus(e._isIdentity,e._isIdentityDirty)},e.Reflection=function(t){var i=new e;return e.ReflectionToRef(t,i),i},e.ReflectionToRef=function(t,i){t.normalize();var r=t.normal.x,n=t.normal.y,o=t.normal.z,s=-2*r,a=-2*n,h=-2*o;e.FromValuesToRef(s*r+1,a*r,h*r,0,s*n,a*n+1,h*n,0,s*o,a*o,h*o+1,0,s*t.d,a*t.d,h*t.d,1,i)},e.FromXYZAxesToRef=function(t,i,r,n){e.FromValuesToRef(t._x,t._y,t._z,0,i._x,i._y,i._z,0,r._x,r._y,r._z,0,0,0,0,1,n)},e.FromQuaternionToRef=function(e,t){var i=e._x*e._x,r=e._y*e._y,n=e._z*e._z,o=e._x*e._y,s=e._z*e._w,a=e._z*e._x,h=e._y*e._w,l=e._y*e._z,c=e._x*e._w;t._m[0]=1-2*(r+n),t._m[1]=2*(o+s),t._m[2]=2*(a-h),t._m[3]=0,t._m[4]=2*(o-s),t._m[5]=1-2*(n+i),t._m[6]=2*(l+c),t._m[7]=0,t._m[8]=2*(a+h),t._m[9]=2*(l-c),t._m[10]=1-2*(r+i),t._m[11]=0,t._m[12]=0,t._m[13]=0,t._m[14]=0,t._m[15]=1,t._markAsUpdated()},e._updateFlagSeed=0,e._identityReadOnly=e.Identity(),e}(),d=function(){function e(){}return e.Vector3=o.a.BuildArray(6,l.Zero),e.Matrix=o.a.BuildArray(2,f.Identity),e.Quaternion=o.a.BuildArray(3,u.Zero),e}(),p=function(){function e(){}return e.Vector2=o.a.BuildArray(3,h.Zero),e.Vector3=o.a.BuildArray(13,l.Zero),e.Vector4=o.a.BuildArray(3,c.Zero),e.Quaternion=o.a.BuildArray(2,u.Zero),e.Matrix=o.a.BuildArray(8,f.Identity),e}();s.a.RegisteredTypes["BABYLON.Vector2"]=h,s.a.RegisteredTypes["BABYLON.Vector3"]=l,s.a.RegisteredTypes["BABYLON.Vector4"]=c,s.a.RegisteredTypes["BABYLON.Matrix"]=f},function(e,t,i){"use strict";i.d(t,"c",(function(){return n})),i.d(t,"a",(function(){return o})),i.d(t,"b",(function(){return s})),i.d(t,"d",(function(){return a}));var r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var i in t)Object.prototype.hasOwnProperty.call(t,i)&&(e[i]=t[i])})(e,t)};function n(e,t){function i(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(i.prototype=t.prototype,new i)}var o=function(){return(o=Object.assign||function(e){for(var t,i=1,r=arguments.length;i=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,i,s):n(t,i))||s);return o>3&&s&&Object.defineProperty(t,i,s),s}Object.create;function a(){for(var e=0,t=0,i=arguments.length;t0},e.prototype.clear=function(){this._observers=new Array,this._onObserverAdded=null},e.prototype.clone=function(){var t=new e;return t._observers=this._observers.slice(0),t},e.prototype.hasSpecificMask=function(e){void 0===e&&(e=-1);for(var t=0,i=this._observers;t=2?"WEBGL2":"WEBGL1"};this._loadShader(g,"Vertex","",(function(e){_._rawVertexSourceCode=e,_._loadShader(m,"Fragment","Pixel",(function(i){_._rawFragmentSourceCode=i,s.a.Process(e,x,(function(e){v&&(e=v("vertex",e)),x.isFragment=!0,s.a.Process(i,x,(function(i){v&&(i=v("fragment",i)),_._useFinalCode(e,i,t)}),_._engine)}),_._engine)}))}))}return Object.defineProperty(e.prototype,"onBindObservable",{get:function(){return this._onBindObservable||(this._onBindObservable=new r.a),this._onBindObservable},enumerable:!1,configurable:!0}),e.prototype._useFinalCode=function(e,t,i){if(i){var r=i.vertexElement||i.vertex||i.spectorName||i,n=i.fragmentElement||i.fragment||i.spectorName||i;this._vertexSourceCode="#define SHADER_NAME vertex:"+r+"\n"+e,this._fragmentSourceCode="#define SHADER_NAME fragment:"+n+"\n"+t}else this._vertexSourceCode=e,this._fragmentSourceCode=t;this._prepareEffect()},Object.defineProperty(e.prototype,"key",{get:function(){return this._key},enumerable:!1,configurable:!0}),e.prototype.isReady=function(){try{return this._isReadyInternal()}catch(e){return!1}},e.prototype._isReadyInternal=function(){return!!this._isReady||!!this._pipelineContext&&this._pipelineContext.isReady},e.prototype.getEngine=function(){return this._engine},e.prototype.getPipelineContext=function(){return this._pipelineContext},e.prototype.getAttributesNames=function(){return this._attributesNames},e.prototype.getAttributeLocation=function(e){return this._attributes[e]},e.prototype.getAttributeLocationByName=function(e){return this._attributeLocationByName[e]},e.prototype.getAttributesCount=function(){return this._attributes.length},e.prototype.getUniformIndex=function(e){return this._uniformsNames.indexOf(e)},e.prototype.getUniform=function(e){return this._uniforms[e]},e.prototype.getSamplers=function(){return this._samplerList},e.prototype.getUniformNames=function(){return this._uniformsNames},e.prototype.getUniformBuffersNames=function(){return this._uniformBuffersNamesList},e.prototype.getIndexParameters=function(){return this._indexParameters},e.prototype.getCompilationError=function(){return this._compilationError},e.prototype.allFallbacksProcessed=function(){return this._allFallbacksProcessed},e.prototype.executeWhenCompiled=function(e){var t=this;this.isReady()?e(this):(this.onCompileObservable.add((function(t){e(t)})),this._pipelineContext&&!this._pipelineContext.isAsync||setTimeout((function(){t._checkIsReady(null)}),16))},e.prototype._checkIsReady=function(e){var t=this;try{if(this._isReadyInternal())return}catch(t){return void this._processCompilationErrors(t,e)}setTimeout((function(){t._checkIsReady(e)}),16)},e.prototype._loadShader=function(t,i,r,o){var s;if("undefined"!=typeof HTMLElement&&t instanceof HTMLElement)return void o(n.a.GetDOMTextContent(t));"source:"!==t.substr(0,7)?"base64:"!==t.substr(0,7)?e.ShadersStore[t+i+"Shader"]?o(e.ShadersStore[t+i+"Shader"]):r&&e.ShadersStore[t+r+"Shader"]?o(e.ShadersStore[t+r+"Shader"]):(s="."===t[0]||"/"===t[0]||t.indexOf("http")>-1?t:e.ShadersRepository+t,this._engine._loadFile(s+"."+i.toLowerCase()+".fx",o)):o(window.atob(t.substr(7))):o(t.substr(7))},Object.defineProperty(e.prototype,"vertexSourceCode",{get:function(){return this._vertexSourceCodeOverride&&this._fragmentSourceCodeOverride?this._vertexSourceCodeOverride:this._vertexSourceCode},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"fragmentSourceCode",{get:function(){return this._vertexSourceCodeOverride&&this._fragmentSourceCodeOverride?this._fragmentSourceCodeOverride:this._fragmentSourceCode},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"rawVertexSourceCode",{get:function(){return this._rawVertexSourceCode},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"rawFragmentSourceCode",{get:function(){return this._rawFragmentSourceCode},enumerable:!1,configurable:!0}),e.prototype._rebuildProgram=function(e,t,i,r){var n=this;this._isReady=!1,this._vertexSourceCodeOverride=e,this._fragmentSourceCodeOverride=t,this.onError=function(e,t){r&&r(t)},this.onCompiled=function(){var e=n.getEngine().scenes;if(e)for(var t=0;t=s&&(n="Offending line ["+s+"] in "+(i?"fragment":"vertex")+" code: "+a[s-1])}}return[e,n]},e.prototype._processCompilationErrors=function(t,i){var r,n,s,a,h;void 0===i&&(i=null),this._compilationError=t.message;var l=this._attributesNames,c=this._fallbacks;if(o.a.Error("Unable to compile effect:"),o.a.Error("Uniforms: "+this._uniformsNames.map((function(e){return" "+e}))),o.a.Error("Attributes: "+l.map((function(e){return" "+e}))),o.a.Error("Defines:\r\n"+this.defines),e.LogShaderCodeOnCompilationError){var u=null,f=null,d=null;(null===(s=this._pipelineContext)||void 0===s?void 0:s._getVertexShaderCode())&&(d=(r=this._getShaderCodeAndErrorLine(this._pipelineContext._getVertexShaderCode(),this._compilationError,!1))[0],u=r[1],d&&(o.a.Error("Vertex code:"),o.a.Error(d))),(null===(a=this._pipelineContext)||void 0===a?void 0:a._getFragmentShaderCode())&&(d=(n=this._getShaderCodeAndErrorLine(null===(h=this._pipelineContext)||void 0===h?void 0:h._getFragmentShaderCode(),this._compilationError,!0))[0],f=n[1],d&&(o.a.Error("Fragment code:"),o.a.Error(d))),u&&o.a.Error(u),f&&o.a.Error(f)}o.a.Error("Error: "+this._compilationError),i&&(this._pipelineContext=i,this._isReady=!0,this.onError&&this.onError(this,this._compilationError),this.onErrorObservable.notifyObservers(this)),c?(this._pipelineContext=null,c.hasMoreFallbacks?(this._allFallbacksProcessed=!1,o.a.Error("Trying next fallback."),this.defines=c.reduce(this.defines,this),this._prepareEffect()):(this._allFallbacksProcessed=!0,this.onError&&this.onError(this,this._compilationError),this.onErrorObservable.notifyObservers(this),this.onErrorObservable.clear(),this._fallbacks&&this._fallbacks.unBindMesh())):this._allFallbacksProcessed=!0},Object.defineProperty(e.prototype,"isSupported",{get:function(){return""===this._compilationError},enumerable:!1,configurable:!0}),e.prototype._bindTexture=function(e,t){this._engine._bindTexture(this._samplers[e],t)},e.prototype.setTexture=function(e,t){this._engine.setTexture(this._samplers[e],this._uniforms[e],t)},e.prototype.setDepthStencilTexture=function(e,t){this._engine.setDepthStencilTexture(this._samplers[e],this._uniforms[e],t)},e.prototype.setTextureArray=function(e,t){var i=e+"Ex";if(-1===this._samplerList.indexOf(i+"0")){for(var r=this._samplerList.indexOf(e),n=1;n1?this.notRenderable=!0:this.notRenderable=!1}else a.b.Error("Cannot move a control to a vector3 if the control is not at root level")},e.prototype.getDescendantsToRef=function(e,t,i){void 0===t&&(t=!1)},e.prototype.getDescendants=function(e,t){var i=new Array;return this.getDescendantsToRef(i,e,t),i},e.prototype.linkWithMesh=function(t){if(!this._host||this.parent&&this.parent!==this._host._rootContainer)t&&a.b.Error("Cannot link a control to a mesh if the control is not at root level");else{var i=this._host._linkedControls.indexOf(this);if(-1!==i)return this._linkedMesh=t,void(t||this._host._linkedControls.splice(i,1));t&&(this.horizontalAlignment=e.HORIZONTAL_ALIGNMENT_LEFT,this.verticalAlignment=e.VERTICAL_ALIGNMENT_TOP,this._linkedMesh=t,this._host._linkedControls.push(this))}},e.prototype._moveToProjectedPosition=function(e){var t=this._left.getValue(this._host),i=this._top.getValue(this._host),r=e.x+this._linkOffsetX.getValue(this._host)-this._currentMeasure.width/2,n=e.y+this._linkOffsetY.getValue(this._host)-this._currentMeasure.height/2;this._left.ignoreAdaptiveScaling&&this._top.ignoreAdaptiveScaling&&(Math.abs(r-t)<.5&&(r=t),Math.abs(n-i)<.5&&(n=i)),this.left=r+"px",this.top=n+"px",this._left.ignoreAdaptiveScaling=!0,this._top.ignoreAdaptiveScaling=!0,this._markAsDirty()},e.prototype._offsetLeft=function(e){this._isDirty=!0,this._currentMeasure.left+=e},e.prototype._offsetTop=function(e){this._isDirty=!0,this._currentMeasure.top+=e},e.prototype._markMatrixAsDirty=function(){this._isMatrixDirty=!0,this._flagDescendantsAsMatrixDirty()},e.prototype._flagDescendantsAsMatrixDirty=function(){},e.prototype._intersectsRect=function(e){return this._currentMeasure.transformToRef(this._transformMatrix,this._tmpMeasureA),!(this._tmpMeasureA.left>=e.left+e.width)&&(!(this._tmpMeasureA.top>=e.top+e.height)&&(!(this._tmpMeasureA.left+this._tmpMeasureA.width<=e.left)&&!(this._tmpMeasureA.top+this._tmpMeasureA.height<=e.top)))},e.prototype.invalidateRect=function(){if(this._transform(),this.host&&this.host.useInvalidateRectOptimization)if(this._currentMeasure.transformToRef(this._transformMatrix,this._tmpMeasureA),l.a.CombineToRef(this._tmpMeasureA,this._prevCurrentMeasureTransformedIntoGlobalSpace,this._tmpMeasureA),this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY){var e=this.shadowOffsetX,t=this.shadowOffsetY,i=this.shadowBlur,r=Math.min(Math.min(e,0)-2*i,0),n=Math.max(Math.max(e,0)+2*i,0),o=Math.min(Math.min(t,0)-2*i,0),s=Math.max(Math.max(t,0)+2*i,0);this.host.invalidateRect(Math.floor(this._tmpMeasureA.left+r),Math.floor(this._tmpMeasureA.top+o),Math.ceil(this._tmpMeasureA.left+this._tmpMeasureA.width+n),Math.ceil(this._tmpMeasureA.top+this._tmpMeasureA.height+s))}else this.host.invalidateRect(Math.floor(this._tmpMeasureA.left),Math.floor(this._tmpMeasureA.top),Math.ceil(this._tmpMeasureA.left+this._tmpMeasureA.width),Math.ceil(this._tmpMeasureA.top+this._tmpMeasureA.height))},e.prototype._markAsDirty=function(e){void 0===e&&(e=!1),(this._isVisible||e)&&(this._isDirty=!0,this._host&&this._host.markAsDirty())},e.prototype._markAllAsDirty=function(){this._markAsDirty(),this._font&&this._prepareFont()},e.prototype._link=function(e){this._host=e,this._host&&(this.uniqueId=this._host.getScene().getUniqueId())},e.prototype._transform=function(e){if(this._isMatrixDirty||1!==this._scaleX||1!==this._scaleY||0!==this._rotation){var t=this._currentMeasure.width*this._transformCenterX+this._currentMeasure.left,i=this._currentMeasure.height*this._transformCenterY+this._currentMeasure.top;e&&(e.translate(t,i),e.rotate(this._rotation),e.scale(this._scaleX,this._scaleY),e.translate(-t,-i)),(this._isMatrixDirty||this._cachedOffsetX!==t||this._cachedOffsetY!==i)&&(this._cachedOffsetX=t,this._cachedOffsetY=i,this._isMatrixDirty=!1,this._flagDescendantsAsMatrixDirty(),d.ComposeToRef(-t,-i,this._rotation,this._scaleX,this._scaleY,this.parent?this.parent._transformMatrix:null,this._transformMatrix),this._transformMatrix.invertToRef(this._invertTransformMatrix))}},e.prototype._renderHighlight=function(e){this.isHighlighted&&(e.save(),e.strokeStyle="#4affff",e.lineWidth=2,this._renderHighlightSpecific(e),e.restore())},e.prototype._renderHighlightSpecific=function(e){e.strokeRect(this._currentMeasure.left,this._currentMeasure.top,this._currentMeasure.width,this._currentMeasure.height)},e.prototype._applyStates=function(t){this._isFontSizeInPercentage&&(this._fontSet=!0),this._fontSet&&(this._prepareFont(),this._fontSet=!1),this._font&&(t.font=this._font),this._color&&(t.fillStyle=this._color),e.AllowAlphaInheritance?t.globalAlpha*=this._alpha:this._alphaSet&&(t.globalAlpha=this.parent?this.parent.alpha*this._alpha:this._alpha)},e.prototype._layout=function(e,t){if(!this.isDirty&&(!this.isVisible||this.notRenderable))return!1;if(this._isDirty||!this._cachedParentMeasure.isEqualsTo(e)){this.host._numLayoutCalls++,this._currentMeasure.addAndTransformToRef(this._transformMatrix,0|-this.paddingLeftInPixels,0|-this.paddingTopInPixels,0|this.paddingRightInPixels,0|this.paddingBottomInPixels,this._prevCurrentMeasureTransformedIntoGlobalSpace),t.save(),this._applyStates(t);var i=0;do{this._rebuildLayout=!1,this._processMeasures(e,t),i++}while(this._rebuildLayout&&i<3);i>=3&&s.a.Error("Layout cycle detected in GUI (Control name="+this.name+", uniqueId="+this.uniqueId+")"),t.restore(),this.invalidateRect(),this._evaluateClippingState(e)}return this._wasDirty=this._isDirty,this._isDirty=!1,!0},e.prototype._processMeasures=function(e,t){this._currentMeasure.copyFrom(e),this._preMeasure(e,t),this._measure(),this._computeAlignment(e,t),this._currentMeasure.left=0|this._currentMeasure.left,this._currentMeasure.top=0|this._currentMeasure.top,this._currentMeasure.width=0|this._currentMeasure.width,this._currentMeasure.height=0|this._currentMeasure.height,this._additionalProcessing(e,t),this._cachedParentMeasure.copyFrom(e),this.onDirtyObservable.hasObservers()&&this.onDirtyObservable.notifyObservers(this)},e.prototype._evaluateClippingState=function(e){if(this.parent&&this.parent.clipChildren){if(this._currentMeasure.left>e.left+e.width)return void(this._isClipped=!0);if(this._currentMeasure.left+this._currentMeasure.widthe.top+e.height)return void(this._isClipped=!0);if(this._currentMeasure.top+this._currentMeasure.heightthis._currentMeasure.left+this._currentMeasure.width)&&(!(tthis._currentMeasure.top+this._currentMeasure.height)&&(this.isPointerBlocker&&(this._host._shouldBlockPointer=!0),!0))))},e.prototype._processPicking=function(e,t,i,r,n,o,s,a){return!!this._isEnabled&&(!(!this.isHitTestVisible||!this.isVisible||this._doNotRender)&&(!!this.contains(e,t)&&(this._processObservables(r,e,t,i,n,o,s,a),!0)))},e.prototype._onPointerMove=function(e,t,i,r){this.onPointerMoveObservable.notifyObservers(t,-1,e,this,r)&&null!=this.parent&&this.parent._onPointerMove(e,t,i,r)},e.prototype._onPointerEnter=function(e,t){return!!this._isEnabled&&(!(this._enterCount>0)&&(-1===this._enterCount&&(this._enterCount=0),this._enterCount++,this.onPointerEnterObservable.notifyObservers(this,-1,e,this,t)&&null!=this.parent&&this.parent._onPointerEnter(e,t),!0))},e.prototype._onPointerOut=function(e,t,i){if(void 0===i&&(i=!1),i||this._isEnabled&&e!==this){this._enterCount=0;var r=!0;e.isAscendant(this)||(r=this.onPointerOutObservable.notifyObservers(this,-1,e,this,t)),r&&null!=this.parent&&this.parent._onPointerOut(e,t,i)}},e.prototype._onPointerDown=function(e,t,i,r,n){return this._onPointerEnter(this,n),0===this._downCount&&(this._downCount++,this._downPointerIds[i]=!0,this.onPointerDownObservable.notifyObservers(new f(t,r),-1,e,this,n)&&null!=this.parent&&this.parent._onPointerDown(e,t,i,r,n),!0)},e.prototype._onPointerUp=function(e,t,i,r,n,o){if(this._isEnabled){this._downCount=0,delete this._downPointerIds[i];var s=n;n&&(this._enterCount>0||-1===this._enterCount)&&(s=this.onPointerClickObservable.notifyObservers(new f(t,r),-1,e,this,o)),this.onPointerUpObservable.notifyObservers(new f(t,r),-1,e,this,o)&&null!=this.parent&&this.parent._onPointerUp(e,t,i,r,s,o)}},e.prototype._forcePointerUp=function(e){if(void 0===e&&(e=null),null!==e)this._onPointerUp(this,n.d.Zero(),e,0,!0);else for(var t in this._downPointerIds)this._onPointerUp(this,n.d.Zero(),+t,0,!0)},e.prototype._onWheelScroll=function(e,t){this._isEnabled&&(this.onWheelObservable.notifyObservers(new n.d(e,t))&&null!=this.parent&&this.parent._onWheelScroll(e,t))},e.prototype._onCanvasBlur=function(){},e.prototype._processObservables=function(e,t,i,r,n,s,a,h){if(!this._isEnabled)return!1;if(this._dummyVector2.copyFromFloats(t,i),e===o.a.POINTERMOVE){this._onPointerMove(this,this._dummyVector2,n,r);var l=this._host._lastControlOver[n];return l&&l!==this&&l._onPointerOut(this,r),l!==this&&this._onPointerEnter(this,r),this._host._lastControlOver[n]=this,!0}return e===o.a.POINTERDOWN?(this._onPointerDown(this,this._dummyVector2,n,s,r),this._host._registerLastControlDown(this,n),this._host._lastPickedControl=this,!0):e===o.a.POINTERUP?(this._host._lastControlDown[n]&&this._host._lastControlDown[n]._onPointerUp(this,this._dummyVector2,n,s,!0,r),delete this._host._lastControlDown[n],!0):!(e!==o.a.POINTERWHEEL||!this._host._lastControlOver[n])&&(this._host._lastControlOver[n]._onWheelScroll(a,h),!0)},e.prototype._prepareFont=function(){(this._font||this._fontSet)&&(this._style?this._font=this._style.fontStyle+" "+this._style.fontWeight+" "+this.fontSizeInPixels+"px "+this._style.fontFamily:this._font=this._fontStyle+" "+this._fontWeight+" "+this.fontSizeInPixels+"px "+this._fontFamily,this._fontOffset=e._GetFontOffset(this._font))},e.prototype.dispose=function(){(this.onDirtyObservable.clear(),this.onBeforeDrawObservable.clear(),this.onAfterDrawObservable.clear(),this.onPointerDownObservable.clear(),this.onPointerEnterObservable.clear(),this.onPointerMoveObservable.clear(),this.onPointerOutObservable.clear(),this.onPointerUpObservable.clear(),this.onPointerClickObservable.clear(),this.onWheelObservable.clear(),this._styleObserver&&this._style&&(this._style.onChangedObservable.remove(this._styleObserver),this._styleObserver=null),this.parent&&(this.parent.removeControl(this),this.parent=null),this._host)&&(this._host._linkedControls.indexOf(this)>-1&&this.linkWithMesh(null));this.onDisposeObservable.notifyObservers(this),this.onDisposeObservable.clear()},Object.defineProperty(e,"HORIZONTAL_ALIGNMENT_LEFT",{get:function(){return e._HORIZONTAL_ALIGNMENT_LEFT},enumerable:!1,configurable:!0}),Object.defineProperty(e,"HORIZONTAL_ALIGNMENT_RIGHT",{get:function(){return e._HORIZONTAL_ALIGNMENT_RIGHT},enumerable:!1,configurable:!0}),Object.defineProperty(e,"HORIZONTAL_ALIGNMENT_CENTER",{get:function(){return e._HORIZONTAL_ALIGNMENT_CENTER},enumerable:!1,configurable:!0}),Object.defineProperty(e,"VERTICAL_ALIGNMENT_TOP",{get:function(){return e._VERTICAL_ALIGNMENT_TOP},enumerable:!1,configurable:!0}),Object.defineProperty(e,"VERTICAL_ALIGNMENT_BOTTOM",{get:function(){return e._VERTICAL_ALIGNMENT_BOTTOM},enumerable:!1,configurable:!0}),Object.defineProperty(e,"VERTICAL_ALIGNMENT_CENTER",{get:function(){return e._VERTICAL_ALIGNMENT_CENTER},enumerable:!1,configurable:!0}),e._GetFontOffset=function(t){if(e._FontHeightSizes[t])return e._FontHeightSizes[t];var i=document.createElement("span");i.innerHTML="Hg",i.style.font=t;var r=document.createElement("div");r.style.display="inline-block",r.style.width="1px",r.style.height="0px",r.style.verticalAlign="bottom";var n=document.createElement("div");n.style.whiteSpace="nowrap",n.appendChild(i),n.appendChild(r),document.body.appendChild(n);var o=0,s=0;try{s=r.getBoundingClientRect().top-i.getBoundingClientRect().top,r.style.verticalAlign="baseline",o=r.getBoundingClientRect().top-i.getBoundingClientRect().top}finally{document.body.removeChild(n)}var a={ascent:o,height:s,descent:s-o};return e._FontHeightSizes[t]=a,a},e.drawEllipse=function(e,t,i,r,n){n.translate(e,t),n.scale(i,r),n.beginPath(),n.arc(0,0,1,0,2*Math.PI),n.closePath(),n.scale(1/i,1/r),n.translate(-e,-t)},e.AllowAlphaInheritance=!1,e._ClipMeasure=new l.a(0,0,0,0),e._HORIZONTAL_ALIGNMENT_LEFT=0,e._HORIZONTAL_ALIGNMENT_RIGHT=1,e._HORIZONTAL_ALIGNMENT_CENTER=2,e._VERTICAL_ALIGNMENT_TOP=0,e._VERTICAL_ALIGNMENT_BOTTOM=1,e._VERTICAL_ALIGNMENT_CENTER=2,e._FontHeightSizes={},e.AddHeader=function(){},e}();p.a.RegisteredTypes["BABYLON.GUI.Control"]=_},function(e,t,i){"use strict";i.d(t,"a",(function(){return a})),i.d(t,"b",(function(){return h})),i.d(t,"c",(function(){return l}));var r=i(17),n=i(16),o=i(31),s=i(9),a=function(){function e(e,t,i){void 0===e&&(e=0),void 0===t&&(t=0),void 0===i&&(i=0),this.r=e,this.g=t,this.b=i}return e.prototype.toString=function(){return"{R: "+this.r+" G:"+this.g+" B:"+this.b+"}"},e.prototype.getClassName=function(){return"Color3"},e.prototype.getHashCode=function(){var e=255*this.r|0;return e=397*(e=397*e^(255*this.g|0))^(255*this.b|0)},e.prototype.toArray=function(e,t){return void 0===t&&(t=0),e[t]=this.r,e[t+1]=this.g,e[t+2]=this.b,this},e.prototype.fromArray=function(t,i){return void 0===i&&(i=0),e.FromArrayToRef(t,i,this),this},e.prototype.toColor4=function(e){return void 0===e&&(e=1),new h(this.r,this.g,this.b,e)},e.prototype.asArray=function(){var e=new Array;return this.toArray(e,0),e},e.prototype.toLuminance=function(){return.3*this.r+.59*this.g+.11*this.b},e.prototype.multiply=function(t){return new e(this.r*t.r,this.g*t.g,this.b*t.b)},e.prototype.multiplyToRef=function(e,t){return t.r=this.r*e.r,t.g=this.g*e.g,t.b=this.b*e.b,this},e.prototype.equals=function(e){return e&&this.r===e.r&&this.g===e.g&&this.b===e.b},e.prototype.equalsFloats=function(e,t,i){return this.r===e&&this.g===t&&this.b===i},e.prototype.scale=function(t){return new e(this.r*t,this.g*t,this.b*t)},e.prototype.scaleToRef=function(e,t){return t.r=this.r*e,t.g=this.g*e,t.b=this.b*e,this},e.prototype.scaleAndAddToRef=function(e,t){return t.r+=this.r*e,t.g+=this.g*e,t.b+=this.b*e,this},e.prototype.clampToRef=function(e,t,i){return void 0===e&&(e=0),void 0===t&&(t=1),i.r=r.a.Clamp(this.r,e,t),i.g=r.a.Clamp(this.g,e,t),i.b=r.a.Clamp(this.b,e,t),this},e.prototype.add=function(t){return new e(this.r+t.r,this.g+t.g,this.b+t.b)},e.prototype.addToRef=function(e,t){return t.r=this.r+e.r,t.g=this.g+e.g,t.b=this.b+e.b,this},e.prototype.subtract=function(t){return new e(this.r-t.r,this.g-t.g,this.b-t.b)},e.prototype.subtractToRef=function(e,t){return t.r=this.r-e.r,t.g=this.g-e.g,t.b=this.b-e.b,this},e.prototype.clone=function(){return new e(this.r,this.g,this.b)},e.prototype.copyFrom=function(e){return this.r=e.r,this.g=e.g,this.b=e.b,this},e.prototype.copyFromFloats=function(e,t,i){return this.r=e,this.g=t,this.b=i,this},e.prototype.set=function(e,t,i){return this.copyFromFloats(e,t,i)},e.prototype.toHexString=function(){var e=255*this.r|0,t=255*this.g|0,i=255*this.b|0;return"#"+r.a.ToHex(e)+r.a.ToHex(t)+r.a.ToHex(i)},e.prototype.toLinearSpace=function(){var t=new e;return this.toLinearSpaceToRef(t),t},e.prototype.toHSV=function(){var t=new e;return this.toHSVToRef(t),t},e.prototype.toHSVToRef=function(e){var t=this.r,i=this.g,r=this.b,n=Math.max(t,i,r),o=Math.min(t,i,r),s=0,a=0,h=n,l=n-o;0!==n&&(a=l/n),n!=o&&(n==t?(s=(i-r)/l,i=0&&o<=1?(a=n,h=s):o>=1&&o<=2?(a=s,h=n):o>=2&&o<=3?(h=n,l=s):o>=3&&o<=4?(h=s,l=n):o>=4&&o<=5?(a=s,l=n):o>=5&&o<=6&&(a=n,l=s);var c=i-n;r.set(a+c,h+c,l+c)},e.FromHexString=function(t){if("#"!==t.substring(0,1)||7!==t.length)return new e(0,0,0);var i=parseInt(t.substring(1,3),16),r=parseInt(t.substring(3,5),16),n=parseInt(t.substring(5,7),16);return e.FromInts(i,r,n)},e.FromArray=function(t,i){return void 0===i&&(i=0),new e(t[i],t[i+1],t[i+2])},e.FromArrayToRef=function(e,t,i){void 0===t&&(t=0),i.r=e[t],i.g=e[t+1],i.b=e[t+2]},e.FromInts=function(t,i,r){return new e(t/255,i/255,r/255)},e.Lerp=function(t,i,r){var n=new e(0,0,0);return e.LerpToRef(t,i,r,n),n},e.LerpToRef=function(e,t,i,r){r.r=e.r+(t.r-e.r)*i,r.g=e.g+(t.g-e.g)*i,r.b=e.b+(t.b-e.b)*i},e.Red=function(){return new e(1,0,0)},e.Green=function(){return new e(0,1,0)},e.Blue=function(){return new e(0,0,1)},e.Black=function(){return new e(0,0,0)},Object.defineProperty(e,"BlackReadOnly",{get:function(){return e._BlackReadOnly},enumerable:!1,configurable:!0}),e.White=function(){return new e(1,1,1)},e.Purple=function(){return new e(.5,0,.5)},e.Magenta=function(){return new e(1,0,1)},e.Yellow=function(){return new e(1,1,0)},e.Gray=function(){return new e(.5,.5,.5)},e.Teal=function(){return new e(0,1,1)},e.Random=function(){return new e(Math.random(),Math.random(),Math.random())},e._BlackReadOnly=e.Black(),e}(),h=function(){function e(e,t,i,r){void 0===e&&(e=0),void 0===t&&(t=0),void 0===i&&(i=0),void 0===r&&(r=1),this.r=e,this.g=t,this.b=i,this.a=r}return e.prototype.addInPlace=function(e){return this.r+=e.r,this.g+=e.g,this.b+=e.b,this.a+=e.a,this},e.prototype.asArray=function(){var e=new Array;return this.toArray(e,0),e},e.prototype.toArray=function(e,t){return void 0===t&&(t=0),e[t]=this.r,e[t+1]=this.g,e[t+2]=this.b,e[t+3]=this.a,this},e.prototype.fromArray=function(t,i){return void 0===i&&(i=0),e.FromArrayToRef(t,i,this),this},e.prototype.equals=function(e){return e&&this.r===e.r&&this.g===e.g&&this.b===e.b&&this.a===e.a},e.prototype.add=function(t){return new e(this.r+t.r,this.g+t.g,this.b+t.b,this.a+t.a)},e.prototype.subtract=function(t){return new e(this.r-t.r,this.g-t.g,this.b-t.b,this.a-t.a)},e.prototype.subtractToRef=function(e,t){return t.r=this.r-e.r,t.g=this.g-e.g,t.b=this.b-e.b,t.a=this.a-e.a,this},e.prototype.scale=function(t){return new e(this.r*t,this.g*t,this.b*t,this.a*t)},e.prototype.scaleToRef=function(e,t){return t.r=this.r*e,t.g=this.g*e,t.b=this.b*e,t.a=this.a*e,this},e.prototype.scaleAndAddToRef=function(e,t){return t.r+=this.r*e,t.g+=this.g*e,t.b+=this.b*e,t.a+=this.a*e,this},e.prototype.clampToRef=function(e,t,i){return void 0===e&&(e=0),void 0===t&&(t=1),i.r=r.a.Clamp(this.r,e,t),i.g=r.a.Clamp(this.g,e,t),i.b=r.a.Clamp(this.b,e,t),i.a=r.a.Clamp(this.a,e,t),this},e.prototype.multiply=function(t){return new e(this.r*t.r,this.g*t.g,this.b*t.b,this.a*t.a)},e.prototype.multiplyToRef=function(e,t){return t.r=this.r*e.r,t.g=this.g*e.g,t.b=this.b*e.b,t.a=this.a*e.a,t},e.prototype.toString=function(){return"{R: "+this.r+" G:"+this.g+" B:"+this.b+" A:"+this.a+"}"},e.prototype.getClassName=function(){return"Color4"},e.prototype.getHashCode=function(){var e=255*this.r|0;return e=397*(e=397*(e=397*e^(255*this.g|0))^(255*this.b|0))^(255*this.a|0)},e.prototype.clone=function(){return new e(this.r,this.g,this.b,this.a)},e.prototype.copyFrom=function(e){return this.r=e.r,this.g=e.g,this.b=e.b,this.a=e.a,this},e.prototype.copyFromFloats=function(e,t,i,r){return this.r=e,this.g=t,this.b=i,this.a=r,this},e.prototype.set=function(e,t,i,r){return this.copyFromFloats(e,t,i,r)},e.prototype.toHexString=function(e){void 0===e&&(e=!1);var t=255*this.r|0,i=255*this.g|0,n=255*this.b|0;if(e)return"#"+r.a.ToHex(t)+r.a.ToHex(i)+r.a.ToHex(n);var o=255*this.a|0;return"#"+r.a.ToHex(t)+r.a.ToHex(i)+r.a.ToHex(n)+r.a.ToHex(o)},e.prototype.toLinearSpace=function(){var t=new e;return this.toLinearSpaceToRef(t),t},e.prototype.toLinearSpaceToRef=function(e){return e.r=Math.pow(this.r,n.c),e.g=Math.pow(this.g,n.c),e.b=Math.pow(this.b,n.c),e.a=this.a,this},e.prototype.toGammaSpace=function(){var t=new e;return this.toGammaSpaceToRef(t),t},e.prototype.toGammaSpaceToRef=function(e){return e.r=Math.pow(this.r,n.b),e.g=Math.pow(this.g,n.b),e.b=Math.pow(this.b,n.b),e.a=this.a,this},e.FromHexString=function(t){if("#"!==t.substring(0,1)||9!==t.length)return new e(0,0,0,0);var i=parseInt(t.substring(1,3),16),r=parseInt(t.substring(3,5),16),n=parseInt(t.substring(5,7),16),o=parseInt(t.substring(7,9),16);return e.FromInts(i,r,n,o)},e.Lerp=function(t,i,r){var n=new e(0,0,0,0);return e.LerpToRef(t,i,r,n),n},e.LerpToRef=function(e,t,i,r){r.r=e.r+(t.r-e.r)*i,r.g=e.g+(t.g-e.g)*i,r.b=e.b+(t.b-e.b)*i,r.a=e.a+(t.a-e.a)*i},e.FromColor3=function(t,i){return void 0===i&&(i=1),new e(t.r,t.g,t.b,i)},e.FromArray=function(t,i){return void 0===i&&(i=0),new e(t[i],t[i+1],t[i+2],t[i+3])},e.FromArrayToRef=function(e,t,i){void 0===t&&(t=0),i.r=e[t],i.g=e[t+1],i.b=e[t+2],i.a=e[t+3]},e.FromInts=function(t,i,r,n){return new e(t/255,i/255,r/255,n/255)},e.CheckColors4=function(e,t){if(e.length===3*t){for(var i=[],r=0;r
";e._AddLogEntry(r)},e._WarnDisabled=function(e){},e._WarnEnabled=function(t){var i=e._FormatMessage(t);console.warn("BJS - "+i);var r="
"+i+"

";e._AddLogEntry(r)},e._ErrorDisabled=function(e){},e._ErrorEnabled=function(t){e.errorsCount++;var i=e._FormatMessage(t);console.error("BJS - "+i);var r="
"+i+"

";e._AddLogEntry(r)},Object.defineProperty(e,"LogCache",{get:function(){return e._LogCache},enumerable:!1,configurable:!0}),e.ClearLogCache=function(){e._LogCache="",e.errorsCount=0},Object.defineProperty(e,"LogLevels",{set:function(t){(t&e.MessageLogLevel)===e.MessageLogLevel?e.Log=e._LogEnabled:e.Log=e._LogDisabled,(t&e.WarningLogLevel)===e.WarningLogLevel?e.Warn=e._WarnEnabled:e.Warn=e._WarnDisabled,(t&e.ErrorLogLevel)===e.ErrorLogLevel?e.Error=e._ErrorEnabled:e.Error=e._ErrorDisabled},enumerable:!1,configurable:!0}),e.NoneLogLevel=0,e.MessageLogLevel=1,e.WarningLogLevel=2,e.ErrorLogLevel=4,e.AllLogLevel=7,e._LogCache="",e.errorsCount=0,e.Log=e._LogEnabled,e.Warn=e._WarnEnabled,e.Error=e._ErrorEnabled,e}()},function(e,t,i){"use strict";i.d(t,"b",(function(){return b})),i.d(t,"a",(function(){return y}));var r,n=i(4),o=i(27),s=i(11),a=i(61),h=i(36),l=i(8),c=i(42),u=i(26),f=i(34);!function(e){e[e.Pending=0]="Pending",e[e.Fulfilled=1]="Fulfilled",e[e.Rejected=2]="Rejected"}(r||(r={}));var d=function(){this.count=0,this.target=0,this.results=[]},p=function(){function e(e){var t=this;if(this._state=r.Pending,this._children=new Array,this._rejectWasConsumed=!1,e)try{e((function(e){t._resolve(e)}),(function(e){t._reject(e)}))}catch(e){this._reject(e)}}return Object.defineProperty(e.prototype,"_result",{get:function(){return this._resultValue},set:function(e){this._resultValue=e,this._parent&&void 0===this._parent._result&&(this._parent._result=e)},enumerable:!1,configurable:!0}),e.prototype.catch=function(e){return this.then(void 0,e)},e.prototype.then=function(t,i){var n=this,o=new e;return o._onFulfilled=t,o._onRejected=i,this._children.push(o),o._parent=this,this._state!==r.Pending&&setTimeout((function(){if(n._state===r.Fulfilled||n._rejectWasConsumed){var e=o._resolve(n._result);if(null!=e)if(void 0!==e._state){var t=e;o._children.push(t),t._parent=o,o=t}else o._result=e}else o._reject(n._reason)})),o},e.prototype._moveChildren=function(e){var t,i=this;if((t=this._children).push.apply(t,e.splice(0,e.length)),this._children.forEach((function(e){e._parent=i})),this._state===r.Fulfilled)for(var n=0,o=this._children;n=t)break;if(r(s),o&&o()){e.breakLoop();break}}e.executeNext()}),s)}),n)},e}();u.a.FallbackTexture="",_.Apply()},function(e,t,i){"use strict";i.r(t),i.d(t,"_CreationDataStorage",(function(){return P})),i.d(t,"_InstancesBatch",(function(){return I})),i.d(t,"Mesh",(function(){return w}));var r=i(1),n=i(4),o=i(12),s=i(61),a=i(22),h=i(0),l=i(7),c=i(33),u=i(2),f=i(14),d=i(45),p=function(){function e(){}return Object.defineProperty(e,"ForceFullSceneLoadingForIncremental",{get:function(){return e._ForceFullSceneLoadingForIncremental},set:function(t){e._ForceFullSceneLoadingForIncremental=t},enumerable:!1,configurable:!0}),Object.defineProperty(e,"ShowLoadingScreen",{get:function(){return e._ShowLoadingScreen},set:function(t){e._ShowLoadingScreen=t},enumerable:!1,configurable:!0}),Object.defineProperty(e,"loggingLevel",{get:function(){return e._loggingLevel},set:function(t){e._loggingLevel=t},enumerable:!1,configurable:!0}),Object.defineProperty(e,"CleanBoneMatrixWeights",{get:function(){return e._CleanBoneMatrixWeights},set:function(t){e._CleanBoneMatrixWeights=t},enumerable:!1,configurable:!0}),e._ForceFullSceneLoadingForIncremental=!1,e._ShowLoadingScreen=!0,e._CleanBoneMatrixWeights=!1,e._loggingLevel=0,e}(),_=i(37),g=i(62),m=function(){function e(e,t,i,r,n){void 0===r&&(r=!1),void 0===n&&(n=null),this.delayLoadState=0,this._totalVertices=0,this._isDisposed=!1,this._indexBufferIsUpdatable=!1,this._positionsCache=[],this.useBoundingInfoFromGeometry=!1,this.id=e,this.uniqueId=t.getUniqueId(),this._engine=t.getEngine(),this._meshes=[],this._scene=t,this._vertexBuffers={},this._indices=[],this._updatable=r,i?this.setAllVerticesData(i,r):(this._totalVertices=0,this._indices=[]),this._engine.getCaps().vertexArrayObject&&(this._vertexArrayObjects={}),n&&(this.applyToMesh(n),n.computeWorldMatrix(!0))}return Object.defineProperty(e.prototype,"boundingBias",{get:function(){return this._boundingBias},set:function(e){this._boundingBias?this._boundingBias.copyFrom(e):this._boundingBias=e.clone(),this._updateBoundingInfo(!0,null)},enumerable:!1,configurable:!0}),e.CreateGeometryForMesh=function(t){var i=new e(e.RandomId(),t.getScene());return i.applyToMesh(t),i},Object.defineProperty(e.prototype,"meshes",{get:function(){return this._meshes},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"extend",{get:function(){return this._extend},enumerable:!1,configurable:!0}),e.prototype.getScene=function(){return this._scene},e.prototype.getEngine=function(){return this._engine},e.prototype.isReady=function(){return 1===this.delayLoadState||0===this.delayLoadState},Object.defineProperty(e.prototype,"doNotSerialize",{get:function(){for(var e=0;e0&&(this._indexBuffer=this._engine.createIndexBuffer(this._indices)),this._indexBuffer&&(this._indexBuffer.references=t),e._syncGeometryWithMorphTargetManager(),e.synchronizeInstances()},e.prototype.notifyUpdate=function(e){this.onGeometryUpdated&&this.onGeometryUpdated(this,e);for(var t=0,i=this._meshes;t0){for(var t=0;t0){for(t=0;t0){for(t=0;t0){var a=new Float32Array(t,s.positionsAttrDesc.offset,s.positionsAttrDesc.count);i.setVerticesData(u.b.PositionKind,a,!1)}if(s.normalsAttrDesc&&s.normalsAttrDesc.count>0){var h=new Float32Array(t,s.normalsAttrDesc.offset,s.normalsAttrDesc.count);i.setVerticesData(u.b.NormalKind,h,!1)}if(s.tangetsAttrDesc&&s.tangetsAttrDesc.count>0){var c=new Float32Array(t,s.tangetsAttrDesc.offset,s.tangetsAttrDesc.count);i.setVerticesData(u.b.TangentKind,c,!1)}if(s.uvsAttrDesc&&s.uvsAttrDesc.count>0){var f=new Float32Array(t,s.uvsAttrDesc.offset,s.uvsAttrDesc.count);i.setVerticesData(u.b.UVKind,f,!1)}if(s.uvs2AttrDesc&&s.uvs2AttrDesc.count>0){var p=new Float32Array(t,s.uvs2AttrDesc.offset,s.uvs2AttrDesc.count);i.setVerticesData(u.b.UV2Kind,p,!1)}if(s.uvs3AttrDesc&&s.uvs3AttrDesc.count>0){var _=new Float32Array(t,s.uvs3AttrDesc.offset,s.uvs3AttrDesc.count);i.setVerticesData(u.b.UV3Kind,_,!1)}if(s.uvs4AttrDesc&&s.uvs4AttrDesc.count>0){var g=new Float32Array(t,s.uvs4AttrDesc.offset,s.uvs4AttrDesc.count);i.setVerticesData(u.b.UV4Kind,g,!1)}if(s.uvs5AttrDesc&&s.uvs5AttrDesc.count>0){var m=new Float32Array(t,s.uvs5AttrDesc.offset,s.uvs5AttrDesc.count);i.setVerticesData(u.b.UV5Kind,m,!1)}if(s.uvs6AttrDesc&&s.uvs6AttrDesc.count>0){var v=new Float32Array(t,s.uvs6AttrDesc.offset,s.uvs6AttrDesc.count);i.setVerticesData(u.b.UV6Kind,v,!1)}if(s.colorsAttrDesc&&s.colorsAttrDesc.count>0){var b=new Float32Array(t,s.colorsAttrDesc.offset,s.colorsAttrDesc.count);i.setVerticesData(u.b.ColorKind,b,!1,s.colorsAttrDesc.stride)}if(s.matricesIndicesAttrDesc&&s.matricesIndicesAttrDesc.count>0){for(var y=new Int32Array(t,s.matricesIndicesAttrDesc.offset,s.matricesIndicesAttrDesc.count),T=[],x=0;x>8),T.push((16711680&E)>>16),T.push(E>>24&255)}i.setVerticesData(u.b.MatricesIndicesKind,T,!1)}if(s.matricesIndicesExtraAttrDesc&&s.matricesIndicesExtraAttrDesc.count>0){for(y=new Int32Array(t,s.matricesIndicesExtraAttrDesc.offset,s.matricesIndicesExtraAttrDesc.count),T=[],x=0;x>8),T.push((16711680&E)>>16),T.push(E>>24&255)}i.setVerticesData(u.b.MatricesIndicesExtraKind,T,!1)}if(s.matricesWeightsAttrDesc&&s.matricesWeightsAttrDesc.count>0){var A=new Float32Array(t,s.matricesWeightsAttrDesc.offset,s.matricesWeightsAttrDesc.count);i.setVerticesData(u.b.MatricesWeightsKind,A,!1)}if(s.indicesAttrDesc&&s.indicesAttrDesc.count>0){var M=new Int32Array(t,s.indicesAttrDesc.offset,s.indicesAttrDesc.count);i.setIndices(M,null)}if(s.subMeshesAttrDesc&&s.subMeshesAttrDesc.count>0){var S=new Int32Array(t,s.subMeshesAttrDesc.offset,5*s.subMeshesAttrDesc.count);i.subMeshes=[];for(x=0;x>8),T.push((16711680&D)>>16),T.push(D>>24&255)}i.setVerticesData(u.b.MatricesIndicesKind,T,t.matricesIndices._updatable)}if(t.matricesIndicesExtra)if(t.matricesIndicesExtra._isExpanded)delete t.matricesIndices._isExpanded,i.setVerticesData(u.b.MatricesIndicesExtraKind,t.matricesIndicesExtra,t.matricesIndicesExtra._updatable);else{for(T=[],x=0;x>8),T.push((16711680&D)>>16),T.push(D>>24&255)}i.setVerticesData(u.b.MatricesIndicesExtraKind,T,t.matricesIndicesExtra._updatable)}t.matricesWeights&&(e._CleanMatricesWeights(t,i),i.setVerticesData(u.b.MatricesWeightsKind,t.matricesWeights,t.matricesWeights._updatable)),t.matricesWeightsExtra&&i.setVerticesData(u.b.MatricesWeightsExtraKind,t.matricesWeightsExtra,t.matricesWeights._updatable),i.setIndices(t.indices,null)}if(t.subMeshes){i.subMeshes=[];for(var w=0;w-1){var n=t.getScene().getLastSkeletonByID(e.skeletonId);if(n){r=n.bones.length;for(var o=t.getVerticesData(u.b.MatricesIndicesKind),s=t.getVerticesData(u.b.MatricesIndicesExtraKind),a=e.matricesWeights,h=e.matricesWeightsExtra,l=e.numBoneInfluencer,c=a.length,f=0;fl-1)&&(_=l-1),d>i){var v=1/d;for(g=0;g<4;g++)a[f+g]*=v;if(h)for(g=0;g<4;g++)h[f+g]*=v}else _>=4?(h[f+_-4]=1-d,s[f+_-4]=r):(a[f+_]=1-d,o[f+_]=r)}t.setVerticesData(u.b.MatricesIndicesKind,o),e.matricesWeightsExtra&&t.setVerticesData(u.b.MatricesIndicesExtraKind,s)}}}},e.Parse=function(t,i,r){if(i.getGeometryByID(t.id))return null;var n=new e(t.id,i,void 0,t.updatable);return a.a&&a.a.AddTagsTo(n,t.tags),t.delayLoadingFile?(n.delayLoadState=4,n.delayLoadingFile=r+t.delayLoadingFile,n._boundingInfo=new _.a(h.e.FromArray(t.boundingBoxMinimum),h.e.FromArray(t.boundingBoxMaximum)),n._delayInfo=[],t.hasUVs&&n._delayInfo.push(u.b.UVKind),t.hasUVs2&&n._delayInfo.push(u.b.UV2Kind),t.hasUVs3&&n._delayInfo.push(u.b.UV3Kind),t.hasUVs4&&n._delayInfo.push(u.b.UV4Kind),t.hasUVs5&&n._delayInfo.push(u.b.UV5Kind),t.hasUVs6&&n._delayInfo.push(u.b.UV6Kind),t.hasColors&&n._delayInfo.push(u.b.ColorKind),t.hasMatricesIndices&&n._delayInfo.push(u.b.MatricesIndicesKind),t.hasMatricesWeights&&n._delayInfo.push(u.b.MatricesWeightsKind),n._delayLoadingFunction=f.VertexData.ImportVertexData):f.VertexData.ImportVertexData(t,n),i.pushGeometry(n,!0),n},e}(),v=i(48),b=i(24),y=i(9),T=function(e){function t(t,i){var r=e.call(this,t,i,!0)||this;return i.multiMaterials.push(r),r.subMaterials=new Array,r._storeEffectOnSubMeshes=!0,r}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"subMaterials",{get:function(){return this._subMaterials},set:function(e){this._subMaterials=e,this._hookArray(e)},enumerable:!1,configurable:!0}),t.prototype.getChildren=function(){return this.subMaterials},t.prototype._hookArray=function(e){var t=this,i=e.push;e.push=function(){for(var r=[],n=0;n=this.subMaterials.length?this.getScene().defaultMaterial:this.subMaterials[e]},t.prototype.getActiveTextures=function(){var t;return(t=e.prototype.getActiveTextures.call(this)).concat.apply(t,this.subMaterials.map((function(e){return e?e.getActiveTextures():[]})))},t.prototype.hasTexture=function(t){var i;if(e.prototype.hasTexture.call(this,t))return!0;for(var r=0;r=0&&n.multiMaterials.splice(o,1),e.prototype.dispose.call(this,t,i)}},t.ParseMultiMaterial=function(e,i){var r=new t(e.name,i);r.id=e.id,a.a&&a.a.AddTagsTo(r,e.tags);for(var n=0;n0},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"hasThinInstances",{get:function(){var e;return(null!==(e=this._thinInstanceDataStorage.instancesCount)&&void 0!==e?e:0)>0},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"morphTargetManager",{get:function(){return this._internalMeshDataInfo._morphTargetManager},set:function(e){this._internalMeshDataInfo._morphTargetManager!==e&&(this._internalMeshDataInfo._morphTargetManager=e,this._syncGeometryWithMorphTargetManager())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"source",{get:function(){return this._internalMeshDataInfo._source},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"cloneMeshMap",{get:function(){return this._internalMeshDataInfo.meshMap},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isUnIndexed",{get:function(){return this._unIndexed},set:function(e){this._unIndexed!==e&&(this._unIndexed=e,this._markSubMeshesAsAttributesDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"worldMatrixInstancedBuffer",{get:function(){return this._instanceDataStorage.instancesData},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"manualUpdateOfWorldMatrixInstancedBuffer",{get:function(){return this._instanceDataStorage.manualUpdate},set:function(e){this._instanceDataStorage.manualUpdate=e},enumerable:!1,configurable:!0}),t.prototype.instantiateHierarchy=function(e,t,i){void 0===e&&(e=null);var r=!(this.getTotalVertices()>0)||t&&t.doNotInstantiate?this.clone("Clone of "+(this.name||this.id),e||this.parent,!0):this.createInstance("instance of "+(this.name||this.id));r&&(r.parent=e||this.parent,r.position=this.position.clone(),r.scaling=this.scaling.clone(),this.rotationQuaternion?r.rotationQuaternion=this.rotationQuaternion.clone():r.rotation=this.rotation.clone(),i&&i(this,r));for(var n=0,o=this.getChildTransformNodes(!0);n0},enumerable:!1,configurable:!0}),t.prototype.getLODLevels=function(){return this._internalMeshDataInfo._LODLevels},t.prototype._sortLODLevels=function(){this._internalMeshDataInfo._LODLevels.sort((function(e,t){return e.distancet.distance?-1:0}))},t.prototype.addLODLevel=function(e,t){if(t&&t._masterMesh)return E.a.Warn("You cannot use a mesh as LOD level twice"),this;var i=new S(e,t);return this._internalMeshDataInfo._LODLevels.push(i),t&&(t._masterMesh=this),this._sortLODLevels(),this},t.prototype.getLODLevelAtDistance=function(e){for(var t=this._internalMeshDataInfo,i=0;in)return this.onLODLevelSelection&&this.onLODLevelSelection(n,this,this),this;for(var o=0;o0||this.hasThinInstances);this.computeWorldMatrix();var f=this.material||c.defaultMaterial;if(f)if(f._storeEffectOnSubMeshes)for(var d=0,p=this.subMeshes;d0){var i=this.getIndices();if(!i)return null;var r=i.length,n=!1;if(e)n=!0;else for(var o=0,s=this.subMeshes;or){n=!0;break}if(a.verticesStart+a.verticesCount>t){n=!0;break}}if(!n)return this.subMeshes[0]}return this.releaseSubMeshes(),new d.a(0,0,t,0,this.getTotalIndices(),this)},t.prototype.subdivide=function(e){if(!(e<1)){for(var t=this.getTotalIndices(),i=t/e|0,r=0;i%3!=0;)i++;this.releaseSubMeshes();for(var n=0;n=t);n++)d.a.CreateFromIndices(0,r,n===e-1?t-r:i,this),r+=i;this.synchronizeInstances()}},t.prototype.setVerticesData=function(e,t,i,r){if(void 0===i&&(i=!1),this._geometry)this._geometry.setVerticesData(e,t,i,r);else{var n=new f.VertexData;n.set(t,e);var o=this.getScene();new m(m.RandomId(),o,n,i,this)}return this},t.prototype.removeVerticesData=function(e){this._geometry&&this._geometry.removeVerticesData(e)},t.prototype.markVerticesDataAsUpdatable=function(e,t){void 0===t&&(t=!0);var i=this.getVertexBuffer(e);i&&i.isUpdatable()!==t&&this.setVerticesData(e,this.getVerticesData(e),t)},t.prototype.setVerticesBuffer=function(e){return this._geometry||(this._geometry=m.CreateGeometryForMesh(this)),this._geometry.setVerticesBuffer(e),this},t.prototype.updateVerticesData=function(e,t,i,r){return this._geometry?(r?(this.makeGeometryUnique(),this.updateVerticesData(e,t,i,!1)):this._geometry.updateVerticesData(e,t,i),this):this},t.prototype.updateMeshPositions=function(e,t){void 0===t&&(t=!0);var i=this.getVerticesData(u.b.PositionKind);if(!i)return this;if(e(i),this.updateVerticesData(u.b.PositionKind,i,!1,!1),t){var r=this.getIndices(),n=this.getVerticesData(u.b.NormalKind);if(!n)return this;f.VertexData.ComputeNormals(i,r,n),this.updateVerticesData(u.b.NormalKind,n,!1,!1)}return this},t.prototype.makeGeometryUnique=function(){if(!this._geometry)return this;if(1===this._geometry.meshes.length)return this;var e=this._geometry,t=this._geometry.copy(m.RandomId());return e.releaseForMesh(this,!0),t.applyToMesh(this),this},t.prototype.setIndices=function(e,t,i){if(void 0===t&&(t=null),void 0===i&&(i=!1),this._geometry)this._geometry.setIndices(e,t,i);else{var r=new f.VertexData;r.indices=e;var n=this.getScene();new m(m.RandomId(),n,r,i,this)}return this},t.prototype.updateIndices=function(e,t,i){return void 0===i&&(i=!1),this._geometry?(this._geometry.updateIndices(e,t,i),this):this},t.prototype.toLeftHanded=function(){return this._geometry?(this._geometry.toLeftHanded(),this):this},t.prototype._bind=function(e,t,i){if(!this._geometry)return this;var r,n=this.getScene().getEngine();if(this._unIndexed)r=null;else switch(i){case b.a.PointFillMode:r=null;break;case b.a.WireFrameFillMode:r=e._getLinesIndexBuffer(this.getIndices(),n);break;default:case b.a.TriangleFillMode:r=this._geometry.getIndexBuffer()}return this._geometry._bind(t,r),this},t.prototype._draw=function(e,t,i){if(!this._geometry||!this._geometry.getVertexBuffers()||!this._unIndexed&&!this._geometry.getIndexBuffer())return this;this._internalMeshDataInfo._onBeforeDrawObservable&&this._internalMeshDataInfo._onBeforeDrawObservable.notifyObservers(this);var r=this.getScene().getEngine();return this._unIndexed||t==b.a.PointFillMode?r.drawArraysType(t,e.verticesStart,e.verticesCount,i):t==b.a.WireFrameFillMode?r.drawElementsType(t,0,e._linesIndexCount,i):r.drawElementsType(t,e.indexStart,e.indexCount,i),this},t.prototype.registerBeforeRender=function(e){return this.onBeforeRenderObservable.add(e),this},t.prototype.unregisterBeforeRender=function(e){return this.onBeforeRenderObservable.removeCallback(e),this},t.prototype.registerAfterRender=function(e){return this.onAfterRenderObservable.add(e),this},t.prototype.unregisterAfterRender=function(e){return this.onAfterRenderObservable.removeCallback(e),this},t.prototype._getInstancesRenderList=function(e,t){if(void 0===t&&(t=!1),this._instanceDataStorage.isFrozen&&this._instanceDataStorage.previousBatch)return this._instanceDataStorage.previousBatch;var i=this.getScene(),r=i._isInIntermediateRendering(),n=r?this._internalAbstractMeshDataInfo._onlyForInstancesIntermediate:this._internalAbstractMeshDataInfo._onlyForInstances,o=this._instanceDataStorage.batchCache;if(o.mustReturn=!1,o.renderSelf[e]=t||!n&&this.isEnabled()&&this.isVisible,o.visibleInstances[e]=null,this._instanceDataStorage.visibleInstances&&!t){var s=this._instanceDataStorage.visibleInstances,a=i.getRenderId(),h=r?s.intermediateDefaultRenderId:s.defaultRenderId;o.visibleInstances[e]=s[a],!o.visibleInstances[e]&&h&&(o.visibleInstances[e]=s[h])}return o.hardwareInstancedRendering[e]=!t&&this._instanceDataStorage.hardwareInstancedRendering&&null!==o.visibleInstances[e]&&void 0!==o.visibleInstances[e],this._instanceDataStorage.previousBatch=o,o},t.prototype._renderWithInstances=function(e,t,i,r,n){var o=i.visibleInstances[e._id];if(!o)return this;for(var s=this._instanceDataStorage,a=s.instancesBufferSize,h=s.instancesBuffer,l=16*(o.length+1)*4;s.instancesBufferSizec&&r++,0!==_&&d++,f+=_,c=_}if(h[d]++,d>o&&(o=d),0===f)n++;else{var g=1/f,m=0;for(p=0;p.001&&s++}}var v=this.skeleton.bones.length,b=this.getVerticesData(u.b.MatricesIndicesKind),y=this.getVerticesData(u.b.MatricesIndicesExtraKind),T=0;for(l=0;l=v||x<0)&&T++}return{skinned:!0,valid:0===n&&0===s&&0===T,report:"Number of Weights = "+i/4+"\nMaximum influences = "+o+"\nMissing Weights = "+n+"\nNot Sorted = "+r+"\nNot Normalized = "+s+"\nWeightCounts = ["+h+"]\nNumber of bones = "+v+"\nBad Bone Indices = "+T}},t.prototype._checkDelayState=function(){var e=this.getScene();return this._geometry?this._geometry.load(e):4===this.delayLoadState&&(this.delayLoadState=2,this._queueLoad(e)),this},t.prototype._queueLoad=function(e){var t=this;e._addPendingData(this);var i=-1!==this.delayLoadingFile.indexOf(".babylonbinarymeshdata");return o.b.LoadFile(this.delayLoadingFile,(function(i){i instanceof ArrayBuffer?t._delayLoadingFunction(i,t):t._delayLoadingFunction(JSON.parse(i),t),t.instances.forEach((function(e){e.refreshBoundingInfo(),e._syncSubMeshes()})),t.delayLoadState=1,e._removePendingData(t)}),(function(){}),e.offlineProvider,i),this},t.prototype.isInFrustum=function(t){return 2!==this.delayLoadState&&(!!e.prototype.isInFrustum.call(this,t)&&(this._checkDelayState(),!0))},t.prototype.setMaterialByID=function(e){var t,i=this.getScene().materials;for(t=i.length-1;t>-1;t--)if(i[t].id===e)return this.material=i[t],this;var r=this.getScene().multiMaterials;for(t=r.length-1;t>-1;t--)if(r[t].id===e)return this.material=r[t],this;return this},t.prototype.getAnimatables=function(){var e=new Array;return this.material&&e.push(this.material),this.skeleton&&e.push(this.skeleton),e},t.prototype.bakeTransformIntoVertices=function(e){if(!this.isVerticesDataPresent(u.b.PositionKind))return this;var t=this.subMeshes.splice(0);this._resetPointsArrayCache();var i,r=this.getVerticesData(u.b.PositionKind),n=new Array;for(i=0;i1)for(var r=0,n=i.meshes.slice(0);r-1&&(n.morphTargetManager=i.getMorphTargetManagerById(e.morphTargetManagerId)),void 0!==e.skeletonId&&null!==e.skeletonId&&(n.skeleton=i.getLastSkeletonByID(e.skeletonId),e.numBoneInfluencers&&(n.numBoneInfluencers=e.numBoneInfluencers)),e.animations){for(var o=0;o4,f=c?this.getVerticesData(u.b.MatricesIndicesExtraKind):null,d=c?this.getVerticesData(u.b.MatricesWeightsExtraKind):null,p=e.getTransformMatrices(this),_=h.e.Zero(),g=new h.a,m=new h.a,v=0,b=0;b0&&(h.a.FromFloat32ArrayToRefScaled(p,Math.floor(16*s[v+l]),y,m),g.addToSelf(m));if(c)for(l=0;l<4;l++)(y=d[v+l])>0&&(h.a.FromFloat32ArrayToRefScaled(p,Math.floor(16*f[v+l]),y,m),g.addToSelf(m));h.e.TransformCoordinatesFromFloatsToRef(i._sourcePositions[b],i._sourcePositions[b+1],i._sourcePositions[b+2],g,_),_.toArray(n,b),t&&(h.e.TransformNormalFromFloatsToRef(i._sourceNormals[b],i._sourceNormals[b+1],i._sourceNormals[b+2],g,_),_.toArray(o,b)),g.reset()}return this.updateVerticesData(u.b.PositionKind,n),t&&this.updateVerticesData(u.b.NormalKind,o),this},t.MinMax=function(e){var t=null,i=null;return e.forEach((function(e){var r=e.getBoundingInfo().boundingBox;t&&i?(t.minimizeInPlace(r.minimumWorld),i.maximizeInPlace(r.maximumWorld)):(t=r.minimumWorld,i=r.maximumWorld)})),t&&i?{min:t,max:i}:{min:h.e.Zero(),max:h.e.Zero()}},t.Center=function(e){var i=e instanceof Array?t.MinMax(e):e;return h.e.Center(i.min,i.max)},t.MergeMeshes=function(e,i,r,n,o,s){var a;if(void 0===i&&(i=!0),!r){var h=0;for(a=0;a=65536)return E.a.Warn("Cannot merge meshes because resulting mesh will have more than 65536 vertices. Please use allow32BitsIndices = true to use 32 bits indices"),null}if(s){var l,c,u=null;o=!1}var p,_=new Array,g=new Array,m=null,v=new Array,b=null;for(a=0;an.bbSize.y?n.bbSize.x:n.bbSize.y;$=$>n.bbSize.z?$:n.bbSize.z,w=n.subDiv.X*I/n.bbSize.x,L=n.subDiv.Y*I/n.bbSize.y,F=n.subDiv.Z*I/n.bbSize.z,N=n.subDiv.max*n.subDiv.max,n.facetPartitioning.length=0}for(o=0;o0?1:-1},e.Clamp=function(e,t,i){return void 0===t&&(t=0),void 0===i&&(i=1),Math.min(i,Math.max(t,e))},e.Log2=function(e){return Math.log(e)*Math.LOG2E},e.Repeat=function(e,t){return e-Math.floor(e/t)*t},e.Normalize=function(e,t,i){return(e-t)/(i-t)},e.Denormalize=function(e,t,i){return e*(i-t)+t},e.DeltaAngle=function(t,i){var r=e.Repeat(i-t,360);return r>180&&(r-=360),r},e.PingPong=function(t,i){var r=e.Repeat(t,2*i);return i-Math.abs(r-i)},e.SmoothStep=function(t,i,r){var n=e.Clamp(r);return i*(n=-2*n*n*n+3*n*n)+t*(1-n)},e.MoveTowards=function(t,i,r){return Math.abs(i-t)<=r?i:t+e.Sign(i-t)*r},e.MoveTowardsAngle=function(t,i,r){var n=e.DeltaAngle(t,i),o=0;return-r180&&(n-=360),t+n*e.Clamp(r)},e.InverseLerp=function(t,i,r){return t!=i?e.Clamp((r-t)/(i-t)):0},e.Hermite=function(e,t,i,r,n){var o=n*n,s=n*o;return e*(2*s-3*o+1)+i*(-2*s+3*o)+t*(s-2*o+n)+r*(s-o)},e.RandomRange=function(e,t){return e===t?e:Math.random()*(t-e)+e},e.RangeToPercent=function(e,t,i){return(e-t)/(i-t)},e.PercentToRange=function(e,t,i){return(i-t)*e+t},e.NormalizeRadians=function(t){return t-=e.TwoPi*Math.floor((t+Math.PI)/e.TwoPi)},e.TwoPi=2*Math.PI,e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return c}));var r=i(11),n=i(28),o=i(26),s=i(2),a=i(44),h=i(7),l=function(){function e(){}return e.BindClipPlane=function(e,t){if(t.clipPlane){var i=t.clipPlane;e.setFloat4("vClipPlane",i.normal.x,i.normal.y,i.normal.z,i.d)}if(t.clipPlane2){i=t.clipPlane2;e.setFloat4("vClipPlane2",i.normal.x,i.normal.y,i.normal.z,i.d)}if(t.clipPlane3){i=t.clipPlane3;e.setFloat4("vClipPlane3",i.normal.x,i.normal.y,i.normal.z,i.d)}if(t.clipPlane4){i=t.clipPlane4;e.setFloat4("vClipPlane4",i.normal.x,i.normal.y,i.normal.z,i.d)}if(t.clipPlane5){i=t.clipPlane5;e.setFloat4("vClipPlane5",i.normal.x,i.normal.y,i.normal.z,i.d)}if(t.clipPlane6){i=t.clipPlane6;e.setFloat4("vClipPlane6",i.normal.x,i.normal.y,i.normal.z,i.d)}},e}(),c=function(){function e(){}return e.BindEyePosition=function(e,t,i){if(void 0===i&&(i="vEyePosition"),t._forcedViewPosition)e.setVector3(i,t._forcedViewPosition);else{var r=t.activeCamera.globalPosition;r||(r=t.activeCamera.devicePosition),e.setVector3(i,t._mirroredCameraPosition?t._mirroredCameraPosition:r)}},e.PrepareDefinesForMergedUV=function(e,t,i){t._needUVs=!0,t[i]=!0,e.getTextureMatrix().isIdentityAs3x2()?(t[i+"DIRECTUV"]=e.coordinatesIndex+1,0===e.coordinatesIndex?t.MAINUV1=!0:t.MAINUV2=!0):t[i+"DIRECTUV"]=0},e.BindTextureMatrix=function(e,t,i){var r=e.getTextureMatrix();t.updateMatrix(i+"Matrix",r)},e.GetFogState=function(e,t){return t.fogEnabled&&e.applyFog&&t.fogMode!==n.Scene.FOGMODE_NONE},e.PrepareDefinesForMisc=function(e,t,i,r,n,o,s){s._areMiscDirty&&(s.LOGARITHMICDEPTH=i,s.POINTSIZE=r,s.FOG=n&&this.GetFogState(e,t),s.NONUNIFORMSCALING=e.nonUniformScaling,s.ALPHATEST=o)},e.PrepareDefinesForFrameBoundValues=function(e,t,i,r,n,o){void 0===n&&(n=null),void 0===o&&(o=!1);var s,a,h,l,c,u,f=!1;s=null==n?void 0!==e.clipPlane&&null!==e.clipPlane:n,a=null==n?void 0!==e.clipPlane2&&null!==e.clipPlane2:n,h=null==n?void 0!==e.clipPlane3&&null!==e.clipPlane3:n,l=null==n?void 0!==e.clipPlane4&&null!==e.clipPlane4:n,c=null==n?void 0!==e.clipPlane5&&null!==e.clipPlane5:n,u=null==n?void 0!==e.clipPlane6&&null!==e.clipPlane6:n,i.CLIPPLANE!==s&&(i.CLIPPLANE=s,f=!0),i.CLIPPLANE2!==a&&(i.CLIPPLANE2=a,f=!0),i.CLIPPLANE3!==h&&(i.CLIPPLANE3=h,f=!0),i.CLIPPLANE4!==l&&(i.CLIPPLANE4=l,f=!0),i.CLIPPLANE5!==c&&(i.CLIPPLANE5=c,f=!0),i.CLIPPLANE6!==u&&(i.CLIPPLANE6=u,f=!0),i.DEPTHPREPASS!==!t.getColorWrite()&&(i.DEPTHPREPASS=!i.DEPTHPREPASS,f=!0),i.INSTANCES!==r&&(i.INSTANCES=r,f=!0),i.THIN_INSTANCES!==o&&(i.THIN_INSTANCES=o,f=!0),f&&i.markAsUnprocessed()},e.PrepareDefinesForBones=function(e,t){if(e.useBones&&e.computeBonesUsingShaders&&e.skeleton){t.NUM_BONE_INFLUENCERS=e.numBoneInfluencers;var i=void 0!==t.BONETEXTURE;if(e.skeleton.isUsingTextureForMatrices&&i)t.BONETEXTURE=!0;else{t.BonesPerMesh=e.skeleton.bones.length+1,t.BONETEXTURE=!i&&void 0;var r=e.getScene().prePassRenderer;if(r&&r.enabled){var n=-1===r.excludedSkinnedMesh.indexOf(e);t.BONES_VELOCITY_ENABLED=n}}}else t.NUM_BONE_INFLUENCERS=0,t.BonesPerMesh=0},e.PrepareDefinesForMorphTargets=function(e,t){var i=e.morphTargetManager;i?(t.MORPHTARGETS_UV=i.supportsUVs&&t.UV1,t.MORPHTARGETS_TANGENT=i.supportsTangents&&t.TANGENT,t.MORPHTARGETS_NORMAL=i.supportsNormals&&t.NORMAL,t.MORPHTARGETS=i.numInfluencers>0,t.NUM_MORPH_INFLUENCERS=i.numInfluencers):(t.MORPHTARGETS_UV=!1,t.MORPHTARGETS_TANGENT=!1,t.MORPHTARGETS_NORMAL=!1,t.MORPHTARGETS=!1,t.NUM_MORPH_INFLUENCERS=0)},e.PrepareDefinesForAttributes=function(e,t,i,r,n,o){if(void 0===n&&(n=!1),void 0===o&&(o=!0),!t._areAttributesDirty&&t._needNormals===t._normals&&t._needUVs===t._uvs)return!1;if(t._normals=t._needNormals,t._uvs=t._needUVs,t.NORMAL=t._needNormals&&e.isVerticesDataPresent(s.b.NormalKind),t._needNormals&&e.isVerticesDataPresent(s.b.TangentKind)&&(t.TANGENT=!0),t._needUVs?(t.UV1=e.isVerticesDataPresent(s.b.UVKind),t.UV2=e.isVerticesDataPresent(s.b.UV2Kind)):(t.UV1=!1,t.UV2=!1),i){var a=e.useVertexColors&&e.isVerticesDataPresent(s.b.ColorKind);t.VERTEXCOLOR=a,t.VERTEXALPHA=e.hasVertexAlpha&&a&&o}return r&&this.PrepareDefinesForBones(e,t),n&&this.PrepareDefinesForMorphTargets(e,t),!0},e.PrepareDefinesForMultiview=function(e,t){if(e.activeCamera){var i=t.MULTIVIEW;t.MULTIVIEW=null!==e.activeCamera.outputRenderTarget&&e.activeCamera.outputRenderTarget.getViewCount()>1,t.MULTIVIEW!=i&&t.markAsUnprocessed()}},e.PrepareDefinesForPrePass=function(e,t,i){var r=t.PREPASS;if(t._arePrePassDirty){var n=[{type:1,define:"PREPASS_POSITION",index:"PREPASS_POSITION_INDEX"},{type:2,define:"PREPASS_VELOCITY",index:"PREPASS_VELOCITY_INDEX"},{type:3,define:"PREPASS_REFLECTIVITY",index:"PREPASS_REFLECTIVITY_INDEX"},{type:0,define:"PREPASS_IRRADIANCE",index:"PREPASS_IRRADIANCE_INDEX"},{type:6,define:"PREPASS_ALBEDO",index:"PREPASS_ALBEDO_INDEX"},{type:5,define:"PREPASS_DEPTHNORMAL",index:"PREPASS_DEPTHNORMAL_INDEX"}];if(e.prePassRenderer&&e.prePassRenderer.enabled&&i){t.PREPASS=!0,t.SCENE_MRT_COUNT=e.prePassRenderer.mrtCount;for(var o=0;o0&&(s.shadowEnabled=!0,h.prepareDefines(n,r))}}i.lightmapMode!=a.a.LIGHTMAP_DEFAULT?(s.lightmapMode=!0,n["LIGHTMAPEXCLUDED"+r]=!0,n["LIGHTMAPNOSPECULAR"+r]=i.lightmapMode==a.a.LIGHTMAP_SHADOWSONLY):(n["LIGHTMAPEXCLUDED"+r]=!1,n["LIGHTMAPNOSPECULAR"+r]=!1)},e.PrepareDefinesForLights=function(e,t,i,r,n,o){if(void 0===n&&(n=4),void 0===o&&(o=!1),!i._areLightsDirty)return i._needNormals;var s=0,a={needNormals:!1,needRebuild:!1,lightmapMode:!1,shadowEnabled:!1,specularEnabled:!1};if(e.lightsEnabled&&!o)for(var h=0,l=t.lightSources;h0&&(n=r+o,t.addFallback(n,"LIGHT"+o)),e.SHADOWS||(e["SHADOW"+o]&&t.addFallback(r,"SHADOW"+o),e["SHADOWPCF"+o]&&t.addFallback(r,"SHADOWPCF"+o),e["SHADOWPCSS"+o]&&t.addFallback(r,"SHADOWPCSS"+o),e["SHADOWPOISSON"+o]&&t.addFallback(r,"SHADOWPOISSON"+o),e["SHADOWESM"+o]&&t.addFallback(r,"SHADOWESM"+o),e["SHADOWCLOSEESM"+o]&&t.addFallback(r,"SHADOWCLOSEESM"+o));return n++},e.PrepareAttributesForMorphTargetsInfluencers=function(e,t,i){this._TmpMorphInfluencers.NUM_MORPH_INFLUENCERS=i,this.PrepareAttributesForMorphTargets(e,t,this._TmpMorphInfluencers)},e.PrepareAttributesForMorphTargets=function(e,t,i){var n=i.NUM_MORPH_INFLUENCERS;if(n>0&&o.a.LastCreatedEngine)for(var a=o.a.LastCreatedEngine.getCaps().maxVertexAttribs,h=t.morphTargetManager,l=h&&h.supportsNormals&&i.NORMAL,c=h&&h.supportsTangents&&i.TANGENT,u=h&&h.supportsUVs&&i.UV1,f=0;fa&&r.a.Error("Cannot add more vertex attributes for mesh "+t.name)},e.PrepareAttributesForBones=function(e,t,i,r){i.NUM_BONE_INFLUENCERS>0&&(r.addCPUSkinningFallback(0,t),e.push(s.b.MatricesIndicesKind),e.push(s.b.MatricesWeightsKind),i.NUM_BONE_INFLUENCERS>4&&(e.push(s.b.MatricesIndicesExtraKind),e.push(s.b.MatricesWeightsExtraKind)))},e.PrepareAttributesForInstances=function(e,t){(t.INSTANCES||t.THIN_INSTANCES)&&this.PushAttributesForInstances(e)},e.PushAttributesForInstances=function(e){e.push("world0"),e.push("world1"),e.push("world2"),e.push("world3")},e.BindLightProperties=function(e,t,i){e.transferToEffect(t,i+"")},e.BindLight=function(e,t,i,r,n,o){void 0===o&&(o=!1),e._bindLight(t,i,r,n,o)},e.BindLights=function(e,t,i,r,n,o){void 0===n&&(n=4),void 0===o&&(o=!1);for(var s=Math.min(t.lightSources.length,n),a=0;a-1){var o=n.getTransformMatrixTexture(t);i.setTexture("boneSampler",o),i.setFloat("boneTextureWidth",4*(n.bones.length+1))}else{var s=n.getTransformMatrices(t);s&&(i.setMatrices("mBones",s),r&&t.getScene().prePassRenderer&&t.getScene().prePassRenderer.getIndex(2)&&(r.previousBones[t.uniqueId]&&i.setMatrices("mPreviousBones",r.previousBones[t.uniqueId]),e._CopyBonesTransformationMatrices(s,r.previousBones[t.uniqueId])))}}},e._CopyBonesTransformationMatrices=function(e,t){return t.set(e),t},e.BindMorphTargetParameters=function(e,t){var i=e.morphTargetManager;e&&i&&t.setFloatArray("morphTargetInfluences",i.influences)},e.BindLogDepth=function(e,t,i){e.LOGARITHMICDEPTH&&t.setFloat("logarithmicDepthConstant",2/(Math.log(i.activeCamera.maxZ+1)/Math.LN2))},e.BindClipPlane=function(e,t){l.BindClipPlane(e,t)},e._TmpMorphInfluencers={NUM_MORPH_INFLUENCERS:0},e._tempFogColor=h.a.Black(),e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return v}));var r=i(1),n=i(3),o=i(4),s=i(0),a=i(26),h=i(71),l=(i(34),i(53)),c=function(e){function t(i){var r=e.call(this,null)||this;return r.metadata=null,r.reservedDataStore=null,r._hasAlpha=!1,r.getAlphaFromRGB=!1,r.level=1,r.coordinatesIndex=0,r._coordinatesMode=0,r.wrapR=1,r.anisotropicFilteringLevel=t.DEFAULT_ANISOTROPIC_FILTERING_LEVEL,r._isCube=!1,r._gammaSpace=!0,r.invertZ=!1,r.lodLevelInAlpha=!1,r.isRenderTarget=!1,r._prefiltered=!1,r.animations=new Array,r.onDisposeObservable=new o.a,r._onDisposeObserver=null,r._scene=null,r._texture=null,r._uid=null,i?t._isScene(i)?r._scene=i:r._engine=i:r._scene=a.a.LastCreatedScene,r._scene&&(r.uniqueId=r._scene.getUniqueId(),r._scene.addTexture(r),r._engine=r._scene.getEngine()),r._uid=null,r}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"hasAlpha",{get:function(){return this._hasAlpha},set:function(e){this._hasAlpha!==e&&(this._hasAlpha=e,this._scene&&this._scene.markAllMaterialsAsDirty(17))},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"coordinatesMode",{get:function(){return this._coordinatesMode},set:function(e){this._coordinatesMode!==e&&(this._coordinatesMode=e,this._scene&&this._scene.markAllMaterialsAsDirty(1))},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"wrapU",{get:function(){return this._wrapU},set:function(e){this._wrapU=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"wrapV",{get:function(){return this._wrapV},set:function(e){this._wrapV=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isCube",{get:function(){return this._texture?this._texture.isCube:this._isCube},set:function(e){this._texture?this._texture.isCube=e:this._isCube=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"is3D",{get:function(){return!!this._texture&&this._texture.is3D},set:function(e){this._texture&&(this._texture.is3D=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"is2DArray",{get:function(){return!!this._texture&&this._texture.is2DArray},set:function(e){this._texture&&(this._texture.is2DArray=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"gammaSpace",{get:function(){return this._texture?(null===this._texture._gammaSpace&&(this._texture._gammaSpace=this._gammaSpace),this._texture._gammaSpace):this._gammaSpace},set:function(e){if(this._texture){if(this._texture._gammaSpace===e)return;this._texture._gammaSpace=e}else{if(this._gammaSpace===e)return;this._gammaSpace=e}this._markAllSubMeshesAsTexturesDirty()},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isRGBD",{get:function(){return null!=this._texture&&this._texture._isRGBD},set:function(e){this._texture&&(this._texture._isRGBD=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"noMipmap",{get:function(){return!1},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"lodGenerationOffset",{get:function(){return this._texture?this._texture._lodGenerationOffset:0},set:function(e){this._texture&&(this._texture._lodGenerationOffset=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"lodGenerationScale",{get:function(){return this._texture?this._texture._lodGenerationScale:0},set:function(e){this._texture&&(this._texture._lodGenerationScale=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"linearSpecularLOD",{get:function(){return!!this._texture&&this._texture._linearSpecularLOD},set:function(e){this._texture&&(this._texture._linearSpecularLOD=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"irradianceTexture",{get:function(){return this._texture?this._texture._irradianceTexture:null},set:function(e){this._texture&&(this._texture._irradianceTexture=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"uid",{get:function(){return this._uid||(this._uid=h.a.RandomId()),this._uid},enumerable:!1,configurable:!0}),t.prototype.toString=function(){return this.name},t.prototype.getClassName=function(){return"BaseTexture"},Object.defineProperty(t.prototype,"onDispose",{set:function(e){this._onDisposeObserver&&this.onDisposeObservable.remove(this._onDisposeObserver),this._onDisposeObserver=this.onDisposeObservable.add(e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isBlocking",{get:function(){return!0},enumerable:!1,configurable:!0}),t.prototype.getScene=function(){return this._scene},t.prototype._getEngine=function(){return this._engine},t.prototype.checkTransformsAreIdentical=function(e){return null!==e},t.prototype.getTextureMatrix=function(){return s.a.IdentityReadOnly},t.prototype.getReflectionTextureMatrix=function(){return s.a.IdentityReadOnly},t.prototype.isReadyOrNotBlocking=function(){return!this.isBlocking||this.isReady()},t.prototype.scale=function(e){},Object.defineProperty(t.prototype,"canRescale",{get:function(){return!1},enumerable:!1,configurable:!0}),t.prototype._getFromCache=function(e,t,i,r){var n=this._getEngine();if(!n)return null;for(var o=n.getLoadedTexturesCache(),s=0;s=0&&this._scene.textures.splice(t,1),this._scene.onTextureRemovedObservable.notifyObservers(this),this._scene=null}this.onDisposeObservable.notifyObservers(this),this.onDisposeObservable.clear(),e.prototype.dispose.call(this)},t.prototype.serialize=function(){if(!this.name)return null;var e=n.a.Serialize(this);return n.a.AppendSerializedAnimations(this,e),e},t.WhenAllReady=function(e,t){var i=e.length;if(0!==i)for(var r=0;r=0;){var c=n[h];c<0?c=0:c>1&&(c=1),l[h]=255*c}n=l}var u=document.createElement("canvas");u.width=s,u.height=a;var f=u.getContext("2d");if(!f)return null;var d=f.createImageData(s,a);if(d.data.set(n),f.putImageData(d,0,0),r.invertY){var p=document.createElement("canvas");p.width=s,p.height=a;var _=p.getContext("2d");return _?(_.translate(0,a),_.scale(1,-1),_.drawImage(u,0,0),p.toDataURL("image/png")):null}return u.toDataURL("image/png")},e}(),v=function(e){function t(i,r,n,s,a,h,l,c,u,f,p,_){void 0===n&&(n=!1),void 0===s&&(s=!0),void 0===a&&(a=t.TRILINEAR_SAMPLINGMODE),void 0===h&&(h=null),void 0===l&&(l=null),void 0===c&&(c=null),void 0===u&&(u=!1);var g=e.call(this,r)||this;g.url=null,g.uOffset=0,g.vOffset=0,g.uScale=1,g.vScale=1,g.uAng=0,g.vAng=0,g.wAng=0,g.uRotationCenter=.5,g.vRotationCenter=.5,g.wRotationCenter=.5,g.homogeneousRotationInUVTransform=!1,g.inspectableCustomProperties=null,g._noMipmap=!1,g._invertY=!1,g._rowGenerationMatrix=null,g._cachedTextureMatrix=null,g._projectionModeMatrix=null,g._t0=null,g._t1=null,g._t2=null,g._cachedUOffset=-1,g._cachedVOffset=-1,g._cachedUScale=0,g._cachedVScale=0,g._cachedUAng=-1,g._cachedVAng=-1,g._cachedWAng=-1,g._cachedProjectionMatrixId=-1,g._cachedURotationCenter=-1,g._cachedVRotationCenter=-1,g._cachedWRotationCenter=-1,g._cachedHomogeneousRotationInUVTransform=!1,g._cachedCoordinatesMode=-1,g._initialSamplingMode=t.BILINEAR_SAMPLINGMODE,g._buffer=null,g._deleteBuffer=!1,g._format=null,g._delayedOnLoad=null,g._delayedOnError=null,g.onLoadObservable=new o.a,g._isBlocking=!0,g.name=i||"",g.url=i,g._noMipmap=n,g._invertY=s,g._initialSamplingMode=a,g._buffer=c,g._deleteBuffer=u,g._mimeType=p,g._loaderOptions=_,f&&(g._format=f);var m=g.getScene(),v=g._getEngine();if(!v)return g;v.onBeforeTextureInitObservable.notifyObservers(g);var b=function(){g._texture&&(g._texture._invertVScale&&(g.vScale*=-1,g.vOffset+=1),null!==g._texture._cachedWrapU&&(g.wrapU=g._texture._cachedWrapU,g._texture._cachedWrapU=null),null!==g._texture._cachedWrapV&&(g.wrapV=g._texture._cachedWrapV,g._texture._cachedWrapV=null),null!==g._texture._cachedWrapR&&(g.wrapR=g._texture._cachedWrapR,g._texture._cachedWrapR=null)),g.onLoadObservable.hasObservers()&&g.onLoadObservable.notifyObservers(g),h&&h(),!g.isBlocking&&m&&m.resetCachedMaterial()};return g.url?(g._texture=g._getFromCache(g.url,n,a,s),g._texture?g._texture.isReady?d.a.SetImmediate((function(){return b()})):g._texture.onLoadedObservable.add(b):m&&m.useDelayedTextureLoading?(g.delayLoadState=4,g._delayedOnLoad=b,g._delayedOnError=l):(g._texture=v.createTexture(g.url,n,s,m,a,b,l,g._buffer,void 0,g._format,null,p,_),u&&(g._buffer=null)),g):(g._delayedOnLoad=b,g._delayedOnError=l,g)}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"noMipmap",{get:function(){return this._noMipmap},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"mimeType",{get:function(){return this._mimeType},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isBlocking",{get:function(){return this._isBlocking},set:function(e){this._isBlocking=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"samplingMode",{get:function(){return this._texture?this._texture.samplingMode:this._initialSamplingMode},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"invertY",{get:function(){return this._invertY},enumerable:!1,configurable:!0}),t.prototype.updateURL=function(e,t,i){void 0===t&&(t=null),this.url&&(this.releaseInternalTexture(),this.getScene().markAllMaterialsAsDirty(1)),this.name&&!g.a.StartsWith(this.name,"data:")||(this.name=e),this.url=e,this._buffer=t,this.delayLoadState=4,i&&(this._delayedOnLoad=i),this.delayLoad()},t.prototype.delayLoad=function(){if(4===this.delayLoadState){var e=this.getScene();e&&(this.delayLoadState=1,this._texture=this._getFromCache(this.url,this._noMipmap,this.samplingMode,this._invertY),this._texture?this._delayedOnLoad&&(this._texture.isReady?d.a.SetImmediate(this._delayedOnLoad):this._texture.onLoadedObservable.add(this._delayedOnLoad)):(this._texture=e.getEngine().createTexture(this.url,this._noMipmap,this._invertY,e,this.samplingMode,this._delayedOnLoad,this._delayedOnError,this._buffer,null,this._format,null,this._mimeType,this._loaderOptions),this._deleteBuffer&&(this._buffer=null)),this._delayedOnLoad=null,this._delayedOnError=null)}},t.prototype._prepareRowForTextureGeneration=function(e,t,i,r){e*=this._cachedUScale,t*=this._cachedVScale,e-=this.uRotationCenter*this._cachedUScale,t-=this.vRotationCenter*this._cachedVScale,i-=this.wRotationCenter,s.e.TransformCoordinatesFromFloatsToRef(e,t,i,this._rowGenerationMatrix,r),r.x+=this.uRotationCenter*this._cachedUScale+this._cachedUOffset,r.y+=this.vRotationCenter*this._cachedVScale+this._cachedVOffset,r.z+=this.wRotationCenter},t.prototype.checkTransformsAreIdentical=function(e){return null!==e&&this.uOffset===e.uOffset&&this.vOffset===e.vOffset&&this.uScale===e.uScale&&this.vScale===e.vScale&&this.uAng===e.uAng&&this.vAng===e.vAng&&this.wAng===e.wAng},t.prototype.getTextureMatrix=function(e){var t=this;if(void 0===e&&(e=1),this.uOffset===this._cachedUOffset&&this.vOffset===this._cachedVOffset&&this.uScale*e===this._cachedUScale&&this.vScale===this._cachedVScale&&this.uAng===this._cachedUAng&&this.vAng===this._cachedVAng&&this.wAng===this._cachedWAng&&this.uRotationCenter===this._cachedURotationCenter&&this.vRotationCenter===this._cachedVRotationCenter&&this.wRotationCenter===this._cachedWRotationCenter&&this.homogeneousRotationInUVTransform===this._cachedHomogeneousRotationInUVTransform)return this._cachedTextureMatrix;this._cachedUOffset=this.uOffset,this._cachedVOffset=this.vOffset,this._cachedUScale=this.uScale*e,this._cachedVScale=this.vScale,this._cachedUAng=this.uAng,this._cachedVAng=this.vAng,this._cachedWAng=this.wAng,this._cachedURotationCenter=this.uRotationCenter,this._cachedVRotationCenter=this.vRotationCenter,this._cachedWRotationCenter=this.wRotationCenter,this._cachedHomogeneousRotationInUVTransform=this.homogeneousRotationInUVTransform,this._cachedTextureMatrix&&this._rowGenerationMatrix||(this._cachedTextureMatrix=s.a.Zero(),this._rowGenerationMatrix=new s.a,this._t0=s.e.Zero(),this._t1=s.e.Zero(),this._t2=s.e.Zero()),s.a.RotationYawPitchRollToRef(this.vAng,this.uAng,this.wAng,this._rowGenerationMatrix),this.homogeneousRotationInUVTransform?(s.a.TranslationToRef(-this._cachedURotationCenter,-this._cachedVRotationCenter,-this._cachedWRotationCenter,s.c.Matrix[0]),s.a.TranslationToRef(this._cachedURotationCenter,this._cachedVRotationCenter,this._cachedWRotationCenter,s.c.Matrix[1]),s.a.ScalingToRef(this._cachedUScale,this._cachedVScale,0,s.c.Matrix[2]),s.a.TranslationToRef(this._cachedUOffset,this._cachedVOffset,0,s.c.Matrix[3]),s.c.Matrix[0].multiplyToRef(this._rowGenerationMatrix,this._cachedTextureMatrix),this._cachedTextureMatrix.multiplyToRef(s.c.Matrix[1],this._cachedTextureMatrix),this._cachedTextureMatrix.multiplyToRef(s.c.Matrix[2],this._cachedTextureMatrix),this._cachedTextureMatrix.multiplyToRef(s.c.Matrix[3],this._cachedTextureMatrix),this._cachedTextureMatrix.setRowFromFloats(2,this._cachedTextureMatrix.m[12],this._cachedTextureMatrix.m[13],this._cachedTextureMatrix.m[14],1)):(this._prepareRowForTextureGeneration(0,0,0,this._t0),this._prepareRowForTextureGeneration(1,0,0,this._t1),this._prepareRowForTextureGeneration(0,1,0,this._t2),this._t1.subtractInPlace(this._t0),this._t2.subtractInPlace(this._t0),s.a.FromValuesToRef(this._t1.x,this._t1.y,this._t1.z,0,this._t2.x,this._t2.y,this._t2.z,0,this._t0.x,this._t0.y,this._t0.z,0,0,0,0,1,this._cachedTextureMatrix));var i=this.getScene();return i?(i.markAllMaterialsAsDirty(1,(function(e){return e.hasTexture(t)})),this._cachedTextureMatrix):this._cachedTextureMatrix},t.prototype.getReflectionTextureMatrix=function(){var e=this,i=this.getScene();if(!i)return this._cachedTextureMatrix;if(this.uOffset===this._cachedUOffset&&this.vOffset===this._cachedVOffset&&this.uScale===this._cachedUScale&&this.vScale===this._cachedVScale&&this.coordinatesMode===this._cachedCoordinatesMode){if(this.coordinatesMode!==t.PROJECTION_MODE)return this._cachedTextureMatrix;if(this._cachedProjectionMatrixId===i.getProjectionMatrix().updateFlag)return this._cachedTextureMatrix}switch(this._cachedTextureMatrix||(this._cachedTextureMatrix=s.a.Zero()),this._projectionModeMatrix||(this._projectionModeMatrix=s.a.Zero()),this._cachedUOffset=this.uOffset,this._cachedVOffset=this.vOffset,this._cachedUScale=this.uScale,this._cachedVScale=this.vScale,this._cachedCoordinatesMode=this.coordinatesMode,this.coordinatesMode){case t.PLANAR_MODE:s.a.IdentityToRef(this._cachedTextureMatrix),this._cachedTextureMatrix[0]=this.uScale,this._cachedTextureMatrix[5]=this.vScale,this._cachedTextureMatrix[12]=this.uOffset,this._cachedTextureMatrix[13]=this.vOffset;break;case t.PROJECTION_MODE:s.a.FromValuesToRef(.5,0,0,0,0,-.5,0,0,0,0,0,0,.5,.5,1,1,this._projectionModeMatrix);var r=i.getProjectionMatrix();this._cachedProjectionMatrixId=r.updateFlag,r.multiplyToRef(this._projectionModeMatrix,this._cachedTextureMatrix);break;default:s.a.IdentityToRef(this._cachedTextureMatrix)}return i.markAllMaterialsAsDirty(1,(function(t){return-1!==t.getActiveTextures().indexOf(e)})),this._cachedTextureMatrix},t.prototype.clone=function(){var e=this;return n.a.Clone((function(){return new t(e._texture?e._texture.url:null,e.getScene(),e._noMipmap,e._invertY,e.samplingMode,void 0,void 0,e._texture?e._texture._buffer:void 0)}),this)},t.prototype.serialize=function(){var i=this.name;t.SerializeBuffers||g.a.StartsWith(this.name,"data:")&&(this.name=""),g.a.StartsWith(this.name,"data:")&&this.url===this.name&&(this.url="");var r=e.prototype.serialize.call(this);return r?((t.SerializeBuffers||t.ForceSerializeBuffers)&&("string"==typeof this._buffer&&"data:"===this._buffer.substr(0,5)?(r.base64String=this._buffer,r.name=r.name.replace("data:","")):this.url&&g.a.StartsWith(this.url,"data:")&&this._buffer instanceof Uint8Array?r.base64String="data:image/png;base64,"+g.a.EncodeArrayBufferToBase64(this._buffer):t.ForceSerializeBuffers&&(r.base64String=m.GenerateBase64StringFromTexture(this))),r.invertY=this._invertY,r.samplingMode=this.samplingMode,this.name=i,r):null},t.prototype.getClassName=function(){return"Texture"},t.prototype.dispose=function(){e.prototype.dispose.call(this),this.onLoadObservable.clear(),this._delayedOnLoad=null,this._delayedOnError=null},t.Parse=function(e,i,r){if(e.customType){var o=p.a.Instantiate(e.customType).Parse(e,i,r);return e.samplingMode&&o.updateSamplingMode&&o._samplingMode&&o._samplingMode!==e.samplingMode&&o.updateSamplingMode(e.samplingMode),o}if(e.isCube&&!e.isRenderTarget)return t._CubeTextureParser(e,i,r);if(!e.name&&!e.isRenderTarget)return null;var s=function(){if(a&&a._texture&&(a._texture._cachedWrapU=null,a._texture._cachedWrapV=null,a._texture._cachedWrapR=null),e.samplingMode){var t=e.samplingMode;a&&a.samplingMode!==t&&a.updateSamplingMode(t)}if(a&&e.animations)for(var i=0;i0?e.name:r+e.name,(g.a.StartsWith(e.url,"data:")||t.UseSerializedUrlIfAny&&e.url)&&(u=e.url),n=new t(u,i,!o,e.invertY,void 0,s)}return n}),e,i);return a},t.CreateFromBase64String=function(e,i,r,n,o,s,a,h,l){return void 0===s&&(s=t.TRILINEAR_SAMPLINGMODE),void 0===a&&(a=null),void 0===h&&(h=null),void 0===l&&(l=5),new t("data:"+i,r,n,o,s,a,h,e,!1,l)},t.LoadFromDataString=function(e,i,r,n,o,s,a,h,l,c){return void 0===n&&(n=!1),void 0===o&&(o=!1),void 0===s&&(s=!0),void 0===a&&(a=t.TRILINEAR_SAMPLINGMODE),void 0===h&&(h=null),void 0===l&&(l=null),void 0===c&&(c=5),"data:"!==e.substr(0,5)&&(e="data:"+e),new t(e,r,o,s,a,h,l,i,n,c)},t.SerializeBuffers=!0,t.ForceSerializeBuffers=!1,t._CubeTextureParser=function(e,t,i){throw f.a.WarnImport("CubeTexture")},t._CreateMirror=function(e,t,i,r){throw f.a.WarnImport("MirrorTexture")},t._CreateRenderTargetTexture=function(e,t,i,r){throw f.a.WarnImport("RenderTargetTexture")},t.NEAREST_SAMPLINGMODE=1,t.NEAREST_NEAREST_MIPLINEAR=8,t.BILINEAR_SAMPLINGMODE=2,t.LINEAR_LINEAR_MIPNEAREST=11,t.TRILINEAR_SAMPLINGMODE=3,t.LINEAR_LINEAR_MIPLINEAR=3,t.NEAREST_NEAREST_MIPNEAREST=4,t.NEAREST_LINEAR_MIPNEAREST=5,t.NEAREST_LINEAR_MIPLINEAR=6,t.NEAREST_LINEAR=7,t.NEAREST_NEAREST=1,t.LINEAR_NEAREST_MIPNEAREST=9,t.LINEAR_NEAREST_MIPLINEAR=10,t.LINEAR_LINEAR=2,t.LINEAR_NEAREST=12,t.EXPLICIT_MODE=0,t.SPHERICAL_MODE=1,t.PLANAR_MODE=2,t.CUBIC_MODE=3,t.PROJECTION_MODE=4,t.SKYBOX_MODE=5,t.INVCUBIC_MODE=6,t.EQUIRECTANGULAR_MODE=7,t.FIXED_EQUIRECTANGULAR_MODE=8,t.FIXED_EQUIRECTANGULAR_MIRRORED_MODE=9,t.CLAMP_ADDRESSMODE=0,t.WRAP_ADDRESSMODE=1,t.MIRROR_ADDRESSMODE=2,t.UseSerializedUrlIfAny=!1,Object(r.b)([Object(n.c)()],t.prototype,"url",void 0),Object(r.b)([Object(n.c)()],t.prototype,"uOffset",void 0),Object(r.b)([Object(n.c)()],t.prototype,"vOffset",void 0),Object(r.b)([Object(n.c)()],t.prototype,"uScale",void 0),Object(r.b)([Object(n.c)()],t.prototype,"vScale",void 0),Object(r.b)([Object(n.c)()],t.prototype,"uAng",void 0),Object(r.b)([Object(n.c)()],t.prototype,"vAng",void 0),Object(r.b)([Object(n.c)()],t.prototype,"wAng",void 0),Object(r.b)([Object(n.c)()],t.prototype,"uRotationCenter",void 0),Object(r.b)([Object(n.c)()],t.prototype,"vRotationCenter",void 0),Object(r.b)([Object(n.c)()],t.prototype,"wRotationCenter",void 0),Object(r.b)([Object(n.c)()],t.prototype,"homogeneousRotationInUVTransform",void 0),Object(r.b)([Object(n.c)()],t.prototype,"isBlocking",null),t}(c);u.a.RegisteredTypes["BABYLON.Texture"]=v,n.a._TextureParser=v.Parse},function(e,t,i){"use strict";i.d(t,"a",(function(){return y}));var r=i(26),n=i(5),o=i(8),s=i(4),a=function(){function e(){this._isDepthTestDirty=!1,this._isDepthMaskDirty=!1,this._isDepthFuncDirty=!1,this._isCullFaceDirty=!1,this._isCullDirty=!1,this._isZOffsetDirty=!1,this._isFrontFaceDirty=!1,this.reset()}return Object.defineProperty(e.prototype,"isDirty",{get:function(){return this._isDepthFuncDirty||this._isDepthTestDirty||this._isDepthMaskDirty||this._isCullFaceDirty||this._isCullDirty||this._isZOffsetDirty||this._isFrontFaceDirty},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"zOffset",{get:function(){return this._zOffset},set:function(e){this._zOffset!==e&&(this._zOffset=e,this._isZOffsetDirty=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"cullFace",{get:function(){return this._cullFace},set:function(e){this._cullFace!==e&&(this._cullFace=e,this._isCullFaceDirty=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"cull",{get:function(){return this._cull},set:function(e){this._cull!==e&&(this._cull=e,this._isCullDirty=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"depthFunc",{get:function(){return this._depthFunc},set:function(e){this._depthFunc!==e&&(this._depthFunc=e,this._isDepthFuncDirty=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"depthMask",{get:function(){return this._depthMask},set:function(e){this._depthMask!==e&&(this._depthMask=e,this._isDepthMaskDirty=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"depthTest",{get:function(){return this._depthTest},set:function(e){this._depthTest!==e&&(this._depthTest=e,this._isDepthTestDirty=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"frontFace",{get:function(){return this._frontFace},set:function(e){this._frontFace!==e&&(this._frontFace=e,this._isFrontFaceDirty=!0)},enumerable:!1,configurable:!0}),e.prototype.reset=function(){this._depthMask=!0,this._depthTest=!0,this._depthFunc=null,this._cullFace=null,this._cull=null,this._zOffset=0,this._frontFace=null,this._isDepthTestDirty=!0,this._isDepthMaskDirty=!0,this._isDepthFuncDirty=!1,this._isCullFaceDirty=!1,this._isCullDirty=!1,this._isZOffsetDirty=!1,this._isFrontFaceDirty=!1},e.prototype.apply=function(e){this.isDirty&&(this._isCullDirty&&(this.cull?e.enable(e.CULL_FACE):e.disable(e.CULL_FACE),this._isCullDirty=!1),this._isCullFaceDirty&&(e.cullFace(this.cullFace),this._isCullFaceDirty=!1),this._isDepthMaskDirty&&(e.depthMask(this.depthMask),this._isDepthMaskDirty=!1),this._isDepthTestDirty&&(this.depthTest?e.enable(e.DEPTH_TEST):e.disable(e.DEPTH_TEST),this._isDepthTestDirty=!1),this._isDepthFuncDirty&&(e.depthFunc(this.depthFunc),this._isDepthFuncDirty=!1),this._isZOffsetDirty&&(this.zOffset?(e.enable(e.POLYGON_OFFSET_FILL),e.polygonOffset(this.zOffset,0)):e.disable(e.POLYGON_OFFSET_FILL),this._isZOffsetDirty=!1),this._isFrontFaceDirty&&(e.frontFace(this.frontFace),this._isFrontFaceDirty=!1))},e}(),h=function(){function e(){this._isStencilTestDirty=!1,this._isStencilMaskDirty=!1,this._isStencilFuncDirty=!1,this._isStencilOpDirty=!1,this.reset()}return Object.defineProperty(e.prototype,"isDirty",{get:function(){return this._isStencilTestDirty||this._isStencilMaskDirty||this._isStencilFuncDirty||this._isStencilOpDirty},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"stencilFunc",{get:function(){return this._stencilFunc},set:function(e){this._stencilFunc!==e&&(this._stencilFunc=e,this._isStencilFuncDirty=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"stencilFuncRef",{get:function(){return this._stencilFuncRef},set:function(e){this._stencilFuncRef!==e&&(this._stencilFuncRef=e,this._isStencilFuncDirty=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"stencilFuncMask",{get:function(){return this._stencilFuncMask},set:function(e){this._stencilFuncMask!==e&&(this._stencilFuncMask=e,this._isStencilFuncDirty=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"stencilOpStencilFail",{get:function(){return this._stencilOpStencilFail},set:function(e){this._stencilOpStencilFail!==e&&(this._stencilOpStencilFail=e,this._isStencilOpDirty=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"stencilOpDepthFail",{get:function(){return this._stencilOpDepthFail},set:function(e){this._stencilOpDepthFail!==e&&(this._stencilOpDepthFail=e,this._isStencilOpDirty=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"stencilOpStencilDepthPass",{get:function(){return this._stencilOpStencilDepthPass},set:function(e){this._stencilOpStencilDepthPass!==e&&(this._stencilOpStencilDepthPass=e,this._isStencilOpDirty=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"stencilMask",{get:function(){return this._stencilMask},set:function(e){this._stencilMask!==e&&(this._stencilMask=e,this._isStencilMaskDirty=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"stencilTest",{get:function(){return this._stencilTest},set:function(e){this._stencilTest!==e&&(this._stencilTest=e,this._isStencilTestDirty=!0)},enumerable:!1,configurable:!0}),e.prototype.reset=function(){this._stencilTest=!1,this._stencilMask=255,this._stencilFunc=e.ALWAYS,this._stencilFuncRef=1,this._stencilFuncMask=255,this._stencilOpStencilFail=e.KEEP,this._stencilOpDepthFail=e.KEEP,this._stencilOpStencilDepthPass=e.REPLACE,this._isStencilTestDirty=!0,this._isStencilMaskDirty=!0,this._isStencilFuncDirty=!0,this._isStencilOpDirty=!0},e.prototype.apply=function(e){this.isDirty&&(this._isStencilTestDirty&&(this.stencilTest?e.enable(e.STENCIL_TEST):e.disable(e.STENCIL_TEST),this._isStencilTestDirty=!1),this._isStencilMaskDirty&&(e.stencilMask(this.stencilMask),this._isStencilMaskDirty=!1),this._isStencilFuncDirty&&(e.stencilFunc(this.stencilFunc,this.stencilFuncRef,this.stencilFuncMask),this._isStencilFuncDirty=!1),this._isStencilOpDirty&&(e.stencilOp(this.stencilOpStencilFail,this.stencilOpDepthFail,this.stencilOpStencilDepthPass),this._isStencilOpDirty=!1))},e.ALWAYS=519,e.KEEP=7680,e.REPLACE=7681,e}(),l=function(){function e(){this._isAlphaBlendDirty=!1,this._isBlendFunctionParametersDirty=!1,this._isBlendEquationParametersDirty=!1,this._isBlendConstantsDirty=!1,this._alphaBlend=!1,this._blendFunctionParameters=new Array(4),this._blendEquationParameters=new Array(2),this._blendConstants=new Array(4),this.reset()}return Object.defineProperty(e.prototype,"isDirty",{get:function(){return this._isAlphaBlendDirty||this._isBlendFunctionParametersDirty},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"alphaBlend",{get:function(){return this._alphaBlend},set:function(e){this._alphaBlend!==e&&(this._alphaBlend=e,this._isAlphaBlendDirty=!0)},enumerable:!1,configurable:!0}),e.prototype.setAlphaBlendConstants=function(e,t,i,r){this._blendConstants[0]===e&&this._blendConstants[1]===t&&this._blendConstants[2]===i&&this._blendConstants[3]===r||(this._blendConstants[0]=e,this._blendConstants[1]=t,this._blendConstants[2]=i,this._blendConstants[3]=r,this._isBlendConstantsDirty=!0)},e.prototype.setAlphaBlendFunctionParameters=function(e,t,i,r){this._blendFunctionParameters[0]===e&&this._blendFunctionParameters[1]===t&&this._blendFunctionParameters[2]===i&&this._blendFunctionParameters[3]===r||(this._blendFunctionParameters[0]=e,this._blendFunctionParameters[1]=t,this._blendFunctionParameters[2]=i,this._blendFunctionParameters[3]=r,this._isBlendFunctionParametersDirty=!0)},e.prototype.setAlphaEquationParameters=function(e,t){this._blendEquationParameters[0]===e&&this._blendEquationParameters[1]===t||(this._blendEquationParameters[0]=e,this._blendEquationParameters[1]=t,this._isBlendEquationParametersDirty=!0)},e.prototype.reset=function(){this._alphaBlend=!1,this._blendFunctionParameters[0]=null,this._blendFunctionParameters[1]=null,this._blendFunctionParameters[2]=null,this._blendFunctionParameters[3]=null,this._blendEquationParameters[0]=null,this._blendEquationParameters[1]=null,this._blendConstants[0]=null,this._blendConstants[1]=null,this._blendConstants[2]=null,this._blendConstants[3]=null,this._isAlphaBlendDirty=!0,this._isBlendFunctionParametersDirty=!1,this._isBlendEquationParametersDirty=!1,this._isBlendConstantsDirty=!1},e.prototype.apply=function(e){this.isDirty&&(this._isAlphaBlendDirty&&(this._alphaBlend?e.enable(e.BLEND):e.disable(e.BLEND),this._isAlphaBlendDirty=!1),this._isBlendFunctionParametersDirty&&(e.blendFuncSeparate(this._blendFunctionParameters[0],this._blendFunctionParameters[1],this._blendFunctionParameters[2],this._blendFunctionParameters[3]),this._isBlendFunctionParametersDirty=!1),this._isBlendEquationParametersDirty&&(e.blendEquationSeparate(this._blendEquationParameters[0],this._blendEquationParameters[1]),this._isBlendEquationParametersDirty=!1),this._isBlendConstantsDirty&&(e.blendColor(this._blendConstants[0],this._blendConstants[1],this._blendConstants[2],this._blendConstants[3]),this._isBlendConstantsDirty=!1))},e}(),c=i(38),u=i(11),f=i(27),d=function(){function e(){}return e.prototype.postProcessor=function(e,t,i,r){if(!r.getCaps().drawBuffersExtension){e=e.replace(/#extension.+GL_EXT_draw_buffers.+(enable|require)/g,"")}return e},e}(),p=function(){function e(){}return e.prototype.attributeProcessor=function(e){return e.replace("attribute","in")},e.prototype.varyingProcessor=function(e,t){return e.replace("varying",t?"in":"out")},e.prototype.postProcessor=function(e,t,i){var r=-1!==e.search(/#extension.+GL_EXT_draw_buffers.+require/);if(e=(e=e.replace(/#extension.+(GL_OVR_multiview2|GL_OES_standard_derivatives|GL_EXT_shader_texture_lod|GL_EXT_frag_depth|GL_EXT_draw_buffers).+(enable|require)/g,"")).replace(/texture2D\s*\(/g,"texture("),i)e=(e=(e=(e=(e=(e=(e=e.replace(/texture2DLodEXT\s*\(/g,"textureLod(")).replace(/textureCubeLodEXT\s*\(/g,"textureLod(")).replace(/textureCube\s*\(/g,"texture(")).replace(/gl_FragDepthEXT/g,"gl_FragDepth")).replace(/gl_FragColor/g,"glFragColor")).replace(/gl_FragData/g,"glFragData")).replace(/void\s+?main\s*\(/g,(r?"":"out vec4 glFragColor;\n")+"void main(");else if(-1!==t.indexOf("#define MULTIVIEW"))return"#extension GL_OVR_multiview2 : require\nlayout (num_views = 2) in;\n"+e;return e},e}(),_=i(55),g=function(){function e(){this.vertexCompilationError=null,this.fragmentCompilationError=null,this.programLinkError=null,this.programValidationError=null}return Object.defineProperty(e.prototype,"isAsync",{get:function(){return this.isParallelCompiled},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"isReady",{get:function(){return!!this.program&&(!this.isParallelCompiled||this.engine._isRenderingStateCompiled(this))},enumerable:!1,configurable:!0}),e.prototype._handlesSpectorRebuildCallback=function(e){e&&this.program&&e(this.program)},e.prototype._getVertexShaderCode=function(){return this.vertexShader?this.engine._getShaderSource(this.vertexShader):null},e.prototype._getFragmentShaderCode=function(){return this.fragmentShader?this.engine._getShaderSource(this.fragmentShader):null},e}(),m=i(54),v=i(49),b=function(){},y=function(){function e(t,i,r,n){var o=this;void 0===n&&(n=!1),this.forcePOTTextures=!1,this.isFullscreen=!1,this.cullBackFaces=!0,this.renderEvenInBackground=!0,this.preventCacheWipeBetweenFrames=!1,this.validateShaderPrograms=!1,this.useReverseDepthBuffer=!1,this.disableUniformBuffers=!1,this._uniformBuffers=new Array,this._webGLVersion=1,this._windowIsBackground=!1,this._highPrecisionShadersAllowed=!0,this._badOS=!1,this._badDesktopOS=!1,this._renderingQueueLaunched=!1,this._activeRenderLoops=new Array,this.onContextLostObservable=new s.a,this.onContextRestoredObservable=new s.a,this._contextWasLost=!1,this._doNotHandleContextLost=!1,this.disableVertexArrayObjects=!1,this._colorWrite=!0,this._colorWriteChanged=!0,this._depthCullingState=new a,this._stencilState=new h,this._alphaState=new l,this._alphaMode=1,this._alphaEquation=0,this._internalTexturesCache=new Array,this._activeChannel=0,this._currentTextureChannel=-1,this._boundTexturesCache={},this._compiledEffects={},this._vertexAttribArraysEnabled=[],this._uintIndicesCurrentlySet=!1,this._currentBoundBuffer=new Array,this._currentFramebuffer=null,this._dummyFramebuffer=null,this._currentBufferPointers=new Array,this._currentInstanceLocations=new Array,this._currentInstanceBuffers=new Array,this._vaoRecordInProgress=!1,this._mustWipeVertexAttributes=!1,this._nextFreeTextureSlots=new Array,this._maxSimultaneousTextures=0,this._activeRequests=new Array,this._transformTextureUrl=null,this.hostInformation={isMobile:!1},this.premultipliedAlpha=!0,this.onBeforeTextureInitObservable=new s.a,this._viewportCached={x:0,y:0,z:0,w:0},this._unpackFlipYCached=null,this.enableUnpackFlipYCached=!0,this._getDepthStencilBuffer=function(e,t,i,r,n,s){var a=o._gl,h=a.createRenderbuffer();return a.bindRenderbuffer(a.RENDERBUFFER,h),i>1&&a.renderbufferStorageMultisample?a.renderbufferStorageMultisample(a.RENDERBUFFER,i,n,e,t):a.renderbufferStorage(a.RENDERBUFFER,r,e,t),a.framebufferRenderbuffer(a.FRAMEBUFFER,s,a.RENDERBUFFER,h),a.bindRenderbuffer(a.RENDERBUFFER,null),h},this._boundUniforms={};var c=null;if(t){if(r=r||{},v.a.SetMatrixPrecision(!!r.useHighPrecisionMatrix),t.getContext){if(c=t,this._renderingCanvas=c,null!=i&&(r.antialias=i),void 0===r.deterministicLockstep&&(r.deterministicLockstep=!1),void 0===r.lockstepMaxSteps&&(r.lockstepMaxSteps=4),void 0===r.timeStep&&(r.timeStep=1/60),void 0===r.preserveDrawingBuffer&&(r.preserveDrawingBuffer=!1),void 0===r.audioEngine&&(r.audioEngine=!0),void 0===r.stencil&&(r.stencil=!0),!1===r.premultipliedAlpha&&(this.premultipliedAlpha=!1),void 0===r.xrCompatible&&(r.xrCompatible=!0),this._doNotHandleContextLost=!!r.doNotHandleContextLost,navigator&&navigator.userAgent){var _=navigator.userAgent;this.hostInformation.isMobile=-1!==_.indexOf("Mobile");for(var g=0,m=e.ExceptionList;g0)if(parseInt(M[M.length-1])>=A)continue}for(var S=0,O=x;S1?this._shaderProcessor=new p:this._shaderProcessor=new d,this._badOS=/iPad/i.test(navigator.userAgent)||/iPhone/i.test(navigator.userAgent),this._badDesktopOS=/^((?!chrome|android).)*safari/i.test(navigator.userAgent),this._creationOptions=r,console.log("Babylon.js v"+e.Version+" - "+this.description)}}return Object.defineProperty(e,"NpmPackage",{get:function(){return"babylonjs@4.2.0"},enumerable:!1,configurable:!0}),Object.defineProperty(e,"Version",{get:function(){return"4.2.0"},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"description",{get:function(){var e="WebGL"+this.webGLVersion;return this._caps.parallelShaderCompile&&(e+=" - Parallel shader compilation"),e},enumerable:!1,configurable:!0}),Object.defineProperty(e,"ShadersRepository",{get:function(){return n.a.ShadersRepository},set:function(e){n.a.ShadersRepository=e},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"supportsUniformBuffers",{get:function(){return this.webGLVersion>1&&!this.disableUniformBuffers},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"_shouldUseHighPrecisionShader",{get:function(){return!(!this._caps.highPrecisionShaderSupported||!this._highPrecisionShadersAllowed)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"needPOTTextures",{get:function(){return this._webGLVersion<2||this.forcePOTTextures},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"doNotHandleContextLost",{get:function(){return this._doNotHandleContextLost},set:function(e){this._doNotHandleContextLost=e},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"_supportsHardwareTextureRescaling",{get:function(){return!1},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"framebufferDimensionsObject",{set:function(e){this._framebufferDimensionsObject=e},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"currentViewport",{get:function(){return this._cachedViewport},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"emptyTexture",{get:function(){return this._emptyTexture||(this._emptyTexture=this.createRawTexture(new Uint8Array(4),1,1,5,!1,!1,1)),this._emptyTexture},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"emptyTexture3D",{get:function(){return this._emptyTexture3D||(this._emptyTexture3D=this.createRawTexture3D(new Uint8Array(4),1,1,1,5,!1,!1,1)),this._emptyTexture3D},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"emptyTexture2DArray",{get:function(){return this._emptyTexture2DArray||(this._emptyTexture2DArray=this.createRawTexture2DArray(new Uint8Array(4),1,1,1,5,!1,!1,1)),this._emptyTexture2DArray},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"emptyCubeTexture",{get:function(){if(!this._emptyCubeTexture){var e=new Uint8Array(4),t=[e,e,e,e,e,e];this._emptyCubeTexture=this.createRawCubeTexture(t,1,5,0,!1,!1,1)}return this._emptyCubeTexture},enumerable:!1,configurable:!0}),e.prototype._rebuildInternalTextures=function(){for(var e=0,t=this._internalTexturesCache.slice();e1?this._gl.getParameter(this._gl.MAX_SAMPLES):1,maxCubemapTextureSize:this._gl.getParameter(this._gl.MAX_CUBE_MAP_TEXTURE_SIZE),maxRenderTextureSize:this._gl.getParameter(this._gl.MAX_RENDERBUFFER_SIZE),maxVertexAttribs:this._gl.getParameter(this._gl.MAX_VERTEX_ATTRIBS),maxVaryingVectors:this._gl.getParameter(this._gl.MAX_VARYING_VECTORS),maxFragmentUniformVectors:this._gl.getParameter(this._gl.MAX_FRAGMENT_UNIFORM_VECTORS),maxVertexUniformVectors:this._gl.getParameter(this._gl.MAX_VERTEX_UNIFORM_VECTORS),parallelShaderCompile:this._gl.getExtension("KHR_parallel_shader_compile"),standardDerivatives:this._webGLVersion>1||null!==this._gl.getExtension("OES_standard_derivatives"),maxAnisotropy:1,astc:this._gl.getExtension("WEBGL_compressed_texture_astc")||this._gl.getExtension("WEBKIT_WEBGL_compressed_texture_astc"),bptc:this._gl.getExtension("EXT_texture_compression_bptc")||this._gl.getExtension("WEBKIT_EXT_texture_compression_bptc"),s3tc:this._gl.getExtension("WEBGL_compressed_texture_s3tc")||this._gl.getExtension("WEBKIT_WEBGL_compressed_texture_s3tc"),pvrtc:this._gl.getExtension("WEBGL_compressed_texture_pvrtc")||this._gl.getExtension("WEBKIT_WEBGL_compressed_texture_pvrtc"),etc1:this._gl.getExtension("WEBGL_compressed_texture_etc1")||this._gl.getExtension("WEBKIT_WEBGL_compressed_texture_etc1"),etc2:this._gl.getExtension("WEBGL_compressed_texture_etc")||this._gl.getExtension("WEBKIT_WEBGL_compressed_texture_etc")||this._gl.getExtension("WEBGL_compressed_texture_es3_0"),textureAnisotropicFilterExtension:this._gl.getExtension("EXT_texture_filter_anisotropic")||this._gl.getExtension("WEBKIT_EXT_texture_filter_anisotropic")||this._gl.getExtension("MOZ_EXT_texture_filter_anisotropic"),uintIndices:this._webGLVersion>1||null!==this._gl.getExtension("OES_element_index_uint"),fragmentDepthSupported:this._webGLVersion>1||null!==this._gl.getExtension("EXT_frag_depth"),highPrecisionShaderSupported:!1,timerQuery:this._gl.getExtension("EXT_disjoint_timer_query_webgl2")||this._gl.getExtension("EXT_disjoint_timer_query"),canUseTimestampForTimerQuery:!1,drawBuffersExtension:!1,maxMSAASamples:1,colorBufferFloat:this._webGLVersion>1&&this._gl.getExtension("EXT_color_buffer_float"),textureFloat:!!(this._webGLVersion>1||this._gl.getExtension("OES_texture_float")),textureHalfFloat:!!(this._webGLVersion>1||this._gl.getExtension("OES_texture_half_float")),textureHalfFloatRender:!1,textureFloatLinearFiltering:!1,textureFloatRender:!1,textureHalfFloatLinearFiltering:!1,vertexArrayObject:!1,instancedArrays:!1,textureLOD:!!(this._webGLVersion>1||this._gl.getExtension("EXT_shader_texture_lod")),blendMinMax:!1,multiview:this._gl.getExtension("OVR_multiview2"),oculusMultiview:this._gl.getExtension("OCULUS_multiview"),depthTextureExtension:!1},this._glVersion=this._gl.getParameter(this._gl.VERSION);var e=this._gl.getExtension("WEBGL_debug_renderer_info");if(null!=e&&(this._glRenderer=this._gl.getParameter(e.UNMASKED_RENDERER_WEBGL),this._glVendor=this._gl.getParameter(e.UNMASKED_VENDOR_WEBGL)),this._glVendor||(this._glVendor="Unknown vendor"),this._glRenderer||(this._glRenderer="Unknown renderer"),36193!==this._gl.HALF_FLOAT_OES&&(this._gl.HALF_FLOAT_OES=36193),34842!==this._gl.RGBA16F&&(this._gl.RGBA16F=34842),34836!==this._gl.RGBA32F&&(this._gl.RGBA32F=34836),35056!==this._gl.DEPTH24_STENCIL8&&(this._gl.DEPTH24_STENCIL8=35056),this._caps.timerQuery&&(1===this._webGLVersion&&(this._gl.getQuery=this._caps.timerQuery.getQueryEXT.bind(this._caps.timerQuery)),this._caps.canUseTimestampForTimerQuery=this._gl.getQuery(this._caps.timerQuery.TIMESTAMP_EXT,this._caps.timerQuery.QUERY_COUNTER_BITS_EXT)>0),this._caps.maxAnisotropy=this._caps.textureAnisotropicFilterExtension?this._gl.getParameter(this._caps.textureAnisotropicFilterExtension.MAX_TEXTURE_MAX_ANISOTROPY_EXT):0,this._caps.textureFloatLinearFiltering=!(!this._caps.textureFloat||!this._gl.getExtension("OES_texture_float_linear")),this._caps.textureFloatRender=!(!this._caps.textureFloat||!this._canRenderToFloatFramebuffer()),this._caps.textureHalfFloatLinearFiltering=!!(this._webGLVersion>1||this._caps.textureHalfFloat&&this._gl.getExtension("OES_texture_half_float_linear")),this._webGLVersion>1&&5131!==this._gl.HALF_FLOAT_OES&&(this._gl.HALF_FLOAT_OES=5131),this._caps.textureHalfFloatRender=this._caps.textureHalfFloat&&this._canRenderToHalfFloatFramebuffer(),this._webGLVersion>1)this._caps.drawBuffersExtension=!0,this._caps.maxMSAASamples=this._gl.getParameter(this._gl.MAX_SAMPLES);else{var t=this._gl.getExtension("WEBGL_draw_buffers");if(null!==t){this._caps.drawBuffersExtension=!0,this._gl.drawBuffers=t.drawBuffersWEBGL.bind(t),this._gl.DRAW_FRAMEBUFFER=this._gl.FRAMEBUFFER;for(var i=0;i<16;i++)this._gl["COLOR_ATTACHMENT"+i+"_WEBGL"]=t["COLOR_ATTACHMENT"+i+"_WEBGL"]}}if(this._webGLVersion>1)this._caps.depthTextureExtension=!0;else{var r=this._gl.getExtension("WEBGL_depth_texture");null!=r&&(this._caps.depthTextureExtension=!0,this._gl.UNSIGNED_INT_24_8=r.UNSIGNED_INT_24_8_WEBGL)}if(this.disableVertexArrayObjects)this._caps.vertexArrayObject=!1;else if(this._webGLVersion>1)this._caps.vertexArrayObject=!0;else{var n=this._gl.getExtension("OES_vertex_array_object");null!=n&&(this._caps.vertexArrayObject=!0,this._gl.createVertexArray=n.createVertexArrayOES.bind(n),this._gl.bindVertexArray=n.bindVertexArrayOES.bind(n),this._gl.deleteVertexArray=n.deleteVertexArrayOES.bind(n))}if(this._webGLVersion>1)this._caps.instancedArrays=!0;else{var o=this._gl.getExtension("ANGLE_instanced_arrays");null!=o?(this._caps.instancedArrays=!0,this._gl.drawArraysInstanced=o.drawArraysInstancedANGLE.bind(o),this._gl.drawElementsInstanced=o.drawElementsInstancedANGLE.bind(o),this._gl.vertexAttribDivisor=o.vertexAttribDivisorANGLE.bind(o)):this._caps.instancedArrays=!1}if(this._gl.getShaderPrecisionFormat){var s=this._gl.getShaderPrecisionFormat(this._gl.VERTEX_SHADER,this._gl.HIGH_FLOAT),a=this._gl.getShaderPrecisionFormat(this._gl.FRAGMENT_SHADER,this._gl.HIGH_FLOAT);s&&a&&(this._caps.highPrecisionShaderSupported=0!==s.precision&&0!==a.precision)}if(this._webGLVersion>1)this._caps.blendMinMax=!0;else{var h=this._gl.getExtension("EXT_blend_minmax");null!=h&&(this._caps.blendMinMax=!0,this._gl.MAX=h.MAX_EXT,this._gl.MIN=h.MIN_EXT)}this._depthCullingState.depthTest=!0,this._depthCullingState.depthFunc=this._gl.LEQUAL,this._depthCullingState.depthMask=!0,this._maxSimultaneousTextures=this._caps.maxCombinedTexturesImageUnits;for(var l=0;l=0&&this._activeRenderLoops.splice(t,1)}else this._activeRenderLoops=[]},e.prototype._renderLoop=function(){if(!this._contextWasLost){var e=!0;if(!this.renderEvenInBackground&&this._windowIsBackground&&(e=!1),e){this.beginFrame();for(var t=0;t0?this._frameHandler=this._queueNewFrame(this._boundRenderFunction,this.getHostWindow()):this._renderingQueueLaunched=!1},e.prototype.getRenderingCanvas=function(){return this._renderingCanvas},e.prototype.getHostWindow=function(){return f.a.IsWindowObjectExist()?this._renderingCanvas&&this._renderingCanvas.ownerDocument&&this._renderingCanvas.ownerDocument.defaultView?this._renderingCanvas.ownerDocument.defaultView:window:null},e.prototype.getRenderWidth=function(e){return void 0===e&&(e=!1),!e&&this._currentRenderTarget?this._currentRenderTarget.width:this._framebufferDimensionsObject?this._framebufferDimensionsObject.framebufferWidth:this._gl.drawingBufferWidth},e.prototype.getRenderHeight=function(e){return void 0===e&&(e=!1),!e&&this._currentRenderTarget?this._currentRenderTarget.height:this._framebufferDimensionsObject?this._framebufferDimensionsObject.framebufferHeight:this._gl.drawingBufferHeight},e.prototype._queueNewFrame=function(t,i){return e.QueueNewFrame(t,i)},e.prototype.runRenderLoop=function(e){-1===this._activeRenderLoops.indexOf(e)&&(this._activeRenderLoops.push(e),this._renderingQueueLaunched||(this._renderingQueueLaunched=!0,this._boundRenderFunction=this._renderLoop.bind(this),this._frameHandler=this._queueNewFrame(this._boundRenderFunction,this.getHostWindow())))},e.prototype.clear=function(e,t,i,r){void 0===r&&(r=!1),this.applyStates();var n=0;t&&e&&(this._gl.clearColor(e.r,e.g,e.b,void 0!==e.a?e.a:1),n|=this._gl.COLOR_BUFFER_BIT),i&&(this.useReverseDepthBuffer?(this._depthCullingState.depthFunc=this._gl.GREATER,this._gl.clearDepth(0)):this._gl.clearDepth(1),n|=this._gl.DEPTH_BUFFER_BIT),r&&(this._gl.clearStencil(0),n|=this._gl.STENCIL_BUFFER_BIT),this._gl.clear(n)},e.prototype._viewport=function(e,t,i,r){e===this._viewportCached.x&&t===this._viewportCached.y&&i===this._viewportCached.z&&r===this._viewportCached.w||(this._viewportCached.x=e,this._viewportCached.y=t,this._viewportCached.z=i,this._viewportCached.w=r,this._gl.viewport(e,t,i,r))},e.prototype.setViewport=function(e,t,i){var r=t||this.getRenderWidth(),n=i||this.getRenderHeight(),o=e.x||0,s=e.y||0;this._cachedViewport=e,this._viewport(o*r,s*n,r*e.width,n*e.height)},e.prototype.beginFrame=function(){},e.prototype.endFrame=function(){this._badOS&&this.flushFramebuffer()},e.prototype.resize=function(){var e,t;f.a.IsWindowObjectExist()?(e=this._renderingCanvas?this._renderingCanvas.clientWidth||this._renderingCanvas.width:window.innerWidth,t=this._renderingCanvas?this._renderingCanvas.clientHeight||this._renderingCanvas.height:window.innerHeight):(e=this._renderingCanvas?this._renderingCanvas.width:100,t=this._renderingCanvas?this._renderingCanvas.height:100),this.setSize(e/this._hardwareScalingLevel,t/this._hardwareScalingLevel)},e.prototype.setSize=function(e,t){return!!this._renderingCanvas&&(e|=0,t|=0,(this._renderingCanvas.width!==e||this._renderingCanvas.height!==t)&&(this._renderingCanvas.width=e,this._renderingCanvas.height=t,!0))},e.prototype.bindFramebuffer=function(e,t,i,r,n,o,s){void 0===t&&(t=0),void 0===o&&(o=0),void 0===s&&(s=0),this._currentRenderTarget&&this.unBindFramebuffer(this._currentRenderTarget),this._currentRenderTarget=e,this._bindUnboundFramebuffer(e._MSAAFramebuffer?e._MSAAFramebuffer:e._framebuffer);var a=this._gl;e.is2DArray?a.framebufferTextureLayer(a.FRAMEBUFFER,a.COLOR_ATTACHMENT0,e._webGLTexture,o,s):e.isCube&&a.framebufferTexture2D(a.FRAMEBUFFER,a.COLOR_ATTACHMENT0,a.TEXTURE_CUBE_MAP_POSITIVE_X+t,e._webGLTexture,o);var h=e._depthStencilTexture;if(h){var l=h._generateStencilBuffer?a.DEPTH_STENCIL_ATTACHMENT:a.DEPTH_ATTACHMENT;e.is2DArray?a.framebufferTextureLayer(a.FRAMEBUFFER,l,h._webGLTexture,o,s):e.isCube?a.framebufferTexture2D(a.FRAMEBUFFER,l,a.TEXTURE_CUBE_MAP_POSITIVE_X+t,h._webGLTexture,o):a.framebufferTexture2D(a.FRAMEBUFFER,l,a.TEXTURE_2D,h._webGLTexture,o)}this._cachedViewport&&!n?this.setViewport(this._cachedViewport,i,r):(i||(i=e.width,o&&(i/=Math.pow(2,o))),r||(r=e.height,o&&(r/=Math.pow(2,o))),this._viewport(0,0,i,r)),this.wipeCaches()},e.prototype._bindUnboundFramebuffer=function(e){this._currentFramebuffer!==e&&(this._gl.bindFramebuffer(this._gl.FRAMEBUFFER,e),this._currentFramebuffer=e)},e.prototype.unBindFramebuffer=function(e,t,i){void 0===t&&(t=!1),this._currentRenderTarget=null;var r=this._gl;if(e._MSAAFramebuffer){if(e._textureArray)return void this.unBindMultiColorAttachmentFramebuffer(e._textureArray,t,i);r.bindFramebuffer(r.READ_FRAMEBUFFER,e._MSAAFramebuffer),r.bindFramebuffer(r.DRAW_FRAMEBUFFER,e._framebuffer),r.blitFramebuffer(0,0,e.width,e.height,0,0,e.width,e.height,r.COLOR_BUFFER_BIT,r.NEAREST)}!e.generateMipMaps||t||e.isCube||(this._bindTextureDirectly(r.TEXTURE_2D,e,!0),r.generateMipmap(r.TEXTURE_2D),this._bindTextureDirectly(r.TEXTURE_2D,null)),i&&(e._MSAAFramebuffer&&this._bindUnboundFramebuffer(e._framebuffer),i()),this._bindUnboundFramebuffer(null)},e.prototype.flushFramebuffer=function(){this._gl.flush()},e.prototype.restoreDefaultFramebuffer=function(){this._currentRenderTarget?this.unBindFramebuffer(this._currentRenderTarget):this._bindUnboundFramebuffer(null),this._cachedViewport&&this.setViewport(this._cachedViewport),this.wipeCaches()},e.prototype._resetVertexBufferBinding=function(){this.bindArrayBuffer(null),this._cachedVertexBuffers=null},e.prototype.createVertexBuffer=function(e){return this._createVertexBuffer(e,this._gl.STATIC_DRAW)},e.prototype._createVertexBuffer=function(e,t){var i=this._gl.createBuffer();if(!i)throw new Error("Unable to create vertex buffer");var r=new _.a(i);return this.bindArrayBuffer(r),e instanceof Array?this._gl.bufferData(this._gl.ARRAY_BUFFER,new Float32Array(e),this._gl.STATIC_DRAW):this._gl.bufferData(this._gl.ARRAY_BUFFER,e,this._gl.STATIC_DRAW),this._resetVertexBufferBinding(),r.references=1,r},e.prototype.createDynamicVertexBuffer=function(e){return this._createVertexBuffer(e,this._gl.DYNAMIC_DRAW)},e.prototype._resetIndexBufferBinding=function(){this.bindIndexBuffer(null),this._cachedIndexBuffer=null},e.prototype.createIndexBuffer=function(e,t){var i=this._gl.createBuffer(),r=new _.a(i);if(!i)throw new Error("Unable to create index buffer");this.bindIndexBuffer(r);var n=this._normalizeIndexData(e);return this._gl.bufferData(this._gl.ELEMENT_ARRAY_BUFFER,n,t?this._gl.DYNAMIC_DRAW:this._gl.STATIC_DRAW),this._resetIndexBufferBinding(),r.references=1,r.is32Bits=4===n.BYTES_PER_ELEMENT,r},e.prototype._normalizeIndexData=function(e){if(e instanceof Uint16Array)return e;if(this._caps.uintIndices){if(e instanceof Uint32Array)return e;for(var t=0;t=65535)return new Uint32Array(e);return new Uint16Array(e)}return new Uint16Array(e)},e.prototype.bindArrayBuffer=function(e){this._vaoRecordInProgress||this._unbindVertexArrayObject(),this.bindBuffer(e,this._gl.ARRAY_BUFFER)},e.prototype.bindUniformBlock=function(e,t,i){var r=e.program,n=this._gl.getUniformBlockIndex(r,t);this._gl.uniformBlockBinding(r,n,i)},e.prototype.bindIndexBuffer=function(e){this._vaoRecordInProgress||this._unbindVertexArrayObject(),this.bindBuffer(e,this._gl.ELEMENT_ARRAY_BUFFER)},e.prototype.bindBuffer=function(e,t){(this._vaoRecordInProgress||this._currentBoundBuffer[t]!==e)&&(this._gl.bindBuffer(t,e?e.underlyingResource:null),this._currentBoundBuffer[t]=e)},e.prototype.updateArrayBuffer=function(e){this._gl.bufferSubData(this._gl.ARRAY_BUFFER,0,e)},e.prototype._vertexAttribPointer=function(e,t,i,r,n,o,s){var a=this._currentBufferPointers[t];if(a){var h=!1;a.active?(a.buffer!==e&&(a.buffer=e,h=!0),a.size!==i&&(a.size=i,h=!0),a.type!==r&&(a.type=r,h=!0),a.normalized!==n&&(a.normalized=n,h=!0),a.stride!==o&&(a.stride=o,h=!0),a.offset!==s&&(a.offset=s,h=!0)):(h=!0,a.active=!0,a.index=t,a.size=i,a.type=r,a.normalized=n,a.stride=o,a.offset=s,a.buffer=e),(h||this._vaoRecordInProgress)&&(this.bindArrayBuffer(e),this._gl.vertexAttribPointer(t,i,r,n,o,s))}},e.prototype._bindIndexBufferWithCache=function(e){null!=e&&this._cachedIndexBuffer!==e&&(this._cachedIndexBuffer=e,this.bindIndexBuffer(e),this._uintIndicesCurrentlySet=e.is32Bits)},e.prototype._bindVertexBuffersAttributes=function(e,t){var i=t.getAttributesNames();this._vaoRecordInProgress||this._unbindVertexArrayObject(),this.unbindAllAttributes();for(var r=0;r=0){var o=e[i[r]];if(!o)continue;this._gl.enableVertexAttribArray(n),this._vaoRecordInProgress||(this._vertexAttribArraysEnabled[n]=!0);var s=o.getBuffer();s&&(this._vertexAttribPointer(s,n,o.getSize(),o.type,o.normalized,o.byteStride,o.byteOffset),o.getIsInstanced()&&(this._gl.vertexAttribDivisor(n,o.getInstanceDivisor()),this._vaoRecordInProgress||(this._currentInstanceLocations.push(n),this._currentInstanceBuffers.push(s))))}}},e.prototype.recordVertexArrayObject=function(e,t,i){var r=this._gl.createVertexArray();return this._vaoRecordInProgress=!0,this._gl.bindVertexArray(r),this._mustWipeVertexAttributes=!0,this._bindVertexBuffersAttributes(e,i),this.bindIndexBuffer(t),this._vaoRecordInProgress=!1,this._gl.bindVertexArray(null),r},e.prototype.bindVertexArrayObject=function(e,t){this._cachedVertexArrayObject!==e&&(this._cachedVertexArrayObject=e,this._gl.bindVertexArray(e),this._cachedVertexBuffers=null,this._cachedIndexBuffer=null,this._uintIndicesCurrentlySet=null!=t&&t.is32Bits,this._mustWipeVertexAttributes=!0)},e.prototype.bindBuffersDirectly=function(e,t,i,r,n){if(this._cachedVertexBuffers!==e||this._cachedEffectForVertexBuffers!==n){this._cachedVertexBuffers=e,this._cachedEffectForVertexBuffers=n;var o=n.getAttributesCount();this._unbindVertexArrayObject(),this.unbindAllAttributes();for(var s=0,a=0;a=0&&(this._gl.enableVertexAttribArray(h),this._vertexAttribArraysEnabled[h]=!0,this._vertexAttribPointer(e,h,i[a],this._gl.FLOAT,!1,r,s)),s+=4*i[a]}}this._bindIndexBufferWithCache(t)},e.prototype._unbindVertexArrayObject=function(){this._cachedVertexArrayObject&&(this._cachedVertexArrayObject=null,this._gl.bindVertexArray(null))},e.prototype.bindBuffers=function(e,t,i){this._cachedVertexBuffers===e&&this._cachedEffectForVertexBuffers===i||(this._cachedVertexBuffers=e,this._cachedEffectForVertexBuffers=i,this._bindVertexBuffersAttributes(e,i)),this._bindIndexBufferWithCache(t)},e.prototype.unbindInstanceAttributes=function(){for(var e,t=0,i=this._currentInstanceLocations.length;t1?"#version 300 es\n#define WEBGL2 \n":"",a=this._compileShader(t,"vertex",r,s),h=this._compileShader(i,"fragment",r,s);return this._createShaderProgram(e,a,h,n,o)},e.prototype.createPipelineContext=function(){var e=new g;return e.engine=this,this._caps.parallelShaderCompile&&(e.isParallelCompiled=!0),e},e.prototype._createShaderProgram=function(e,t,i,r,n){void 0===n&&(n=null);var o=r.createProgram();if(e.program=o,!o)throw new Error("Unable to create program");return r.attachShader(o,t),r.attachShader(o,i),r.linkProgram(o),e.context=r,e.vertexShader=t,e.fragmentShader=i,e.isParallelCompiled||this._finalizePipelineContext(e),o},e.prototype._finalizePipelineContext=function(e){var t=e.context,i=e.vertexShader,r=e.fragmentShader,n=e.program;if(!t.getProgramParameter(n,t.LINK_STATUS)){var o,s;if(!this._gl.getShaderParameter(i,this._gl.COMPILE_STATUS))if(o=this._gl.getShaderInfoLog(i))throw e.vertexCompilationError=o,new Error("VERTEX SHADER "+o);if(!this._gl.getShaderParameter(r,this._gl.COMPILE_STATUS))if(o=this._gl.getShaderInfoLog(r))throw e.fragmentCompilationError=o,new Error("FRAGMENT SHADER "+o);if(s=t.getProgramInfoLog(n))throw e.programLinkError=s,new Error(s)}if(this.validateShaderPrograms&&(t.validateProgram(n),!t.getProgramParameter(n,t.VALIDATE_STATUS)&&(s=t.getProgramInfoLog(n))))throw e.programValidationError=s,new Error(s);t.deleteShader(i),t.deleteShader(r),e.vertexShader=void 0,e.fragmentShader=void 0,e.onCompiled&&(e.onCompiled(),e.onCompiled=void 0)},e.prototype._preparePipelineContext=function(e,t,i,r,n,o,s){var a=e;a.program=r?this.createRawShaderProgram(a,t,i,void 0,s):this.createShaderProgram(a,t,i,o,void 0,s),a.program.__SPECTOR_rebuildProgram=n},e.prototype._isRenderingStateCompiled=function(e){var t=e;return!!this._gl.getProgramParameter(t.program,this._caps.parallelShaderCompile.COMPLETION_STATUS_KHR)&&(this._finalizePipelineContext(t),!0)},e.prototype._executeWhenRenderingStateIsCompiled=function(e,t){var i=e;if(i.isParallelCompiled){var r=i.onCompiled;i.onCompiled=r?function(){r(),t()}:t}else t()},e.prototype.getUniforms=function(e,t){for(var i=new Array,r=e,n=0;n-1?t.substring(E).toLowerCase():""),M=null;A.indexOf("?")>-1&&(A=A.split("?")[0]);for(var S=0,O=e._TextureLoaders;Sh||e.height>h||!m._supportsHardwareTextureRescaling)return m._prepareWorkingCanvas(),!(!m._workingCanvas||!m._workingContext)&&(m._workingCanvas.width=t,m._workingCanvas.height=i,m._workingContext.drawImage(e,0,0,e.width,e.height,0,0,t,i),n.texImage2D(n.TEXTURE_2D,0,a,a,n.UNSIGNED_BYTE,m._workingCanvas),T.width=t,T.height=i,!1);var l=new c.a(m,c.b.Temp);return m._bindTextureDirectly(n.TEXTURE_2D,l,!0),n.texImage2D(n.TEXTURE_2D,0,a,a,n.UNSIGNED_BYTE,e),m._rescaleTexture(l,T,o,a,(function(){m._releaseTexture(l),m._bindTextureDirectly(n.TEXTURE_2D,T,!0),r()})),!0}),s)};!v||y?l&&(l.decoding||l.close)?D(l):e._FileToolsLoadImage(t,D,I,o?o.offlineProvider:null,_):"string"==typeof l||l instanceof ArrayBuffer||ArrayBuffer.isView(l)||l instanceof Blob?e._FileToolsLoadImage(l,D,I,o?o.offlineProvider:null,_):l&&D(l)}return T},e._FileToolsLoadImage=function(e,t,i,r,n){throw o.a.WarnImport("FileTools")},e.prototype._rescaleTexture=function(e,t,i,r,n){},e.prototype.createRawTexture=function(e,t,i,r,n,s,a,h,l){throw void 0===h&&(h=null),void 0===l&&(l=0),o.a.WarnImport("Engine.RawTexture")},e.prototype.createRawCubeTexture=function(e,t,i,r,n,s,a,h){throw void 0===h&&(h=null),o.a.WarnImport("Engine.RawTexture")},e.prototype.createRawTexture3D=function(e,t,i,r,n,s,a,h,l,c){throw void 0===l&&(l=null),void 0===c&&(c=0),o.a.WarnImport("Engine.RawTexture")},e.prototype.createRawTexture2DArray=function(e,t,i,r,n,s,a,h,l,c){throw void 0===l&&(l=null),void 0===c&&(c=0),o.a.WarnImport("Engine.RawTexture")},e.prototype._unpackFlipY=function(e){this._unpackFlipYCached!==e&&(this._gl.pixelStorei(this._gl.UNPACK_FLIP_Y_WEBGL,e?1:0),this.enableUnpackFlipYCached&&(this._unpackFlipYCached=e))},e.prototype._getUnpackAlignement=function(){return this._gl.getParameter(this._gl.UNPACK_ALIGNMENT)},e.prototype._getTextureTarget=function(e){return e.isCube?this._gl.TEXTURE_CUBE_MAP:e.is3D?this._gl.TEXTURE_3D:e.is2DArray||e.isMultiview?this._gl.TEXTURE_2D_ARRAY:this._gl.TEXTURE_2D},e.prototype.updateTextureSamplingMode=function(e,t,i){void 0===i&&(i=!1);var r=this._getTextureTarget(t),n=this._getSamplingParameters(e,t.generateMipMaps||i);this._setTextureParameterInteger(r,this._gl.TEXTURE_MAG_FILTER,n.mag,t),this._setTextureParameterInteger(r,this._gl.TEXTURE_MIN_FILTER,n.min),i&&(t.generateMipMaps=!0,this._gl.generateMipmap(r)),this._bindTextureDirectly(r,null),t.samplingMode=e},e.prototype.updateTextureWrappingMode=function(e,t,i,r){void 0===i&&(i=null),void 0===r&&(r=null);var n=this._getTextureTarget(e);null!==t&&(this._setTextureParameterInteger(n,this._gl.TEXTURE_WRAP_S,this._getTextureWrapMode(t),e),e._cachedWrapU=t),null!==i&&(this._setTextureParameterInteger(n,this._gl.TEXTURE_WRAP_T,this._getTextureWrapMode(i),e),e._cachedWrapV=i),(e.is2DArray||e.is3D)&&null!==r&&(this._setTextureParameterInteger(n,this._gl.TEXTURE_WRAP_R,this._getTextureWrapMode(r),e),e._cachedWrapR=r),this._bindTextureDirectly(n,null)},e.prototype._setupDepthStencilTexture=function(e,t,i,r,n){var o=t.width||t,s=t.height||t,a=t.layers||0;e.baseWidth=o,e.baseHeight=s,e.width=o,e.height=s,e.is2DArray=a>0,e.depth=a,e.isReady=!0,e.samples=1,e.generateMipMaps=!1,e._generateDepthBuffer=!0,e._generateStencilBuffer=i,e.samplingMode=r?2:1,e.type=0,e._comparisonFunction=n;var h=this._gl,l=this._getTextureTarget(e),c=this._getSamplingParameters(e.samplingMode,!1);h.texParameteri(l,h.TEXTURE_MAG_FILTER,c.mag),h.texParameteri(l,h.TEXTURE_MIN_FILTER,c.min),h.texParameteri(l,h.TEXTURE_WRAP_S,h.CLAMP_TO_EDGE),h.texParameteri(l,h.TEXTURE_WRAP_T,h.CLAMP_TO_EDGE),0===n?(h.texParameteri(l,h.TEXTURE_COMPARE_FUNC,515),h.texParameteri(l,h.TEXTURE_COMPARE_MODE,h.NONE)):(h.texParameteri(l,h.TEXTURE_COMPARE_FUNC,n),h.texParameteri(l,h.TEXTURE_COMPARE_MODE,h.COMPARE_REF_TO_TEXTURE))},e.prototype._uploadCompressedDataToTextureDirectly=function(e,t,i,r,n,o,s){void 0===o&&(o=0),void 0===s&&(s=0);var a=this._gl,h=a.TEXTURE_2D;e.isCube&&(h=a.TEXTURE_CUBE_MAP_POSITIVE_X+o),this._gl.compressedTexImage2D(h,s,t,i,r,0,n)},e.prototype._uploadDataToTextureDirectly=function(e,t,i,r,n,o){void 0===i&&(i=0),void 0===r&&(r=0),void 0===o&&(o=!1);var s=this._gl,a=this._getWebGLTextureType(e.type),h=this._getInternalFormat(e.format),l=void 0===n?this._getRGBABufferInternalSizedFormat(e.type,e.format):this._getInternalFormat(n);this._unpackFlipY(e.invertY);var c=s.TEXTURE_2D;e.isCube&&(c=s.TEXTURE_CUBE_MAP_POSITIVE_X+i);var u=Math.round(Math.log(e.width)*Math.LOG2E),f=Math.round(Math.log(e.height)*Math.LOG2E),d=o?e.width:Math.pow(2,Math.max(u-r,0)),p=o?e.height:Math.pow(2,Math.max(f-r,0));s.texImage2D(c,r,l,d,p,0,h,a,t)},e.prototype.updateTextureData=function(e,t,i,r,n,o,s,a){void 0===s&&(s=0),void 0===a&&(a=0);var h=this._gl,l=this._getWebGLTextureType(e.type),c=this._getInternalFormat(e.format);this._unpackFlipY(e.invertY);var u=h.TEXTURE_2D;e.isCube&&(u=h.TEXTURE_CUBE_MAP_POSITIVE_X+s),h.texSubImage2D(u,a,i,r,n,o,c,l,t)},e.prototype._uploadArrayBufferViewToTexture=function(e,t,i,r){void 0===i&&(i=0),void 0===r&&(r=0);var n=this._gl,o=e.isCube?n.TEXTURE_CUBE_MAP:n.TEXTURE_2D;this._bindTextureDirectly(o,e,!0),this._uploadDataToTextureDirectly(e,t,i,r),this._bindTextureDirectly(o,null,!0)},e.prototype._prepareWebGLTextureContinuation=function(e,t,i,r,n){var o=this._gl;if(o){var s=this._getSamplingParameters(n,!i);o.texParameteri(o.TEXTURE_2D,o.TEXTURE_MAG_FILTER,s.mag),o.texParameteri(o.TEXTURE_2D,o.TEXTURE_MIN_FILTER,s.min),i||r||o.generateMipmap(o.TEXTURE_2D),this._bindTextureDirectly(o.TEXTURE_2D,null),t&&t._removePendingData(e),e.onLoadedObservable.notifyObservers(e),e.onLoadedObservable.clear()}},e.prototype._prepareWebGLTexture=function(t,i,r,n,o,s,a,h,l){var c=this;void 0===l&&(l=3);var u=this.getCaps().maxTextureSize,f=Math.min(u,this.needPOTTextures?e.GetExponentOfTwo(r,u):r),d=Math.min(u,this.needPOTTextures?e.GetExponentOfTwo(n,u):n),p=this._gl;p&&(t._webGLTexture?(this._bindTextureDirectly(p.TEXTURE_2D,t,!0),this._unpackFlipY(void 0===o||!!o),t.baseWidth=r,t.baseHeight=n,t.width=f,t.height=d,t.isReady=!0,h(f,d,(function(){c._prepareWebGLTextureContinuation(t,i,s,a,l)}))||this._prepareWebGLTextureContinuation(t,i,s,a,l)):i&&i._removePendingData(t))},e.prototype._setupFramebufferDepthAttachments=function(e,t,i,r,n){void 0===n&&(n=1);var o=this._gl;if(e&&t)return this._getDepthStencilBuffer(i,r,n,o.DEPTH_STENCIL,o.DEPTH24_STENCIL8,o.DEPTH_STENCIL_ATTACHMENT);if(t){var s=o.DEPTH_COMPONENT16;return this._webGLVersion>1&&(s=o.DEPTH_COMPONENT32F),this._getDepthStencilBuffer(i,r,n,s,s,o.DEPTH_ATTACHMENT)}return e?this._getDepthStencilBuffer(i,r,n,o.STENCIL_INDEX8,o.STENCIL_INDEX8,o.STENCIL_ATTACHMENT):null},e.prototype._releaseFramebufferObjects=function(e){var t=this._gl;e._framebuffer&&(t.deleteFramebuffer(e._framebuffer),e._framebuffer=null),e._depthStencilBuffer&&(t.deleteRenderbuffer(e._depthStencilBuffer),e._depthStencilBuffer=null),e._MSAAFramebuffer&&(t.deleteFramebuffer(e._MSAAFramebuffer),e._MSAAFramebuffer=null),e._MSAARenderBuffer&&(t.deleteRenderbuffer(e._MSAARenderBuffer),e._MSAARenderBuffer=null)},e.prototype._releaseTexture=function(e){this._releaseFramebufferObjects(e),this._deleteTexture(e._webGLTexture),this.unbindAllTextures();var t=this._internalTexturesCache.indexOf(e);-1!==t&&this._internalTexturesCache.splice(t,1),e._lodTextureHigh&&e._lodTextureHigh.dispose(),e._lodTextureMid&&e._lodTextureMid.dispose(),e._lodTextureLow&&e._lodTextureLow.dispose(),e._irradianceTexture&&e._irradianceTexture.dispose()},e.prototype._deleteTexture=function(e){this._gl.deleteTexture(e)},e.prototype._setProgram=function(e){this._currentProgram!==e&&(this._gl.useProgram(e),this._currentProgram=e)},e.prototype.bindSamplers=function(e){var t=e.getPipelineContext();this._setProgram(t.program);for(var i=e.getSamplers(),r=0;r-1;return i&&o&&(this._activeChannel=t._associatedChannel),this._boundTexturesCache[this._activeChannel]!==t||r?(this._activateCurrentTexture(),t&&t.isMultiview?this._gl.bindTexture(e,t?t._colorTextureArray:null):this._gl.bindTexture(e,t?t._webGLTexture:null),this._boundTexturesCache[this._activeChannel]=t,t&&(t._associatedChannel=this._activeChannel)):i&&(n=!0,this._activateCurrentTexture()),o&&!i&&this._bindSamplerUniformToChannel(t._associatedChannel,this._activeChannel),n},e.prototype._bindTexture=function(e,t){if(void 0!==e){t&&(t._associatedChannel=e),this._activeChannel=e;var i=t?this._getTextureTarget(t):this._gl.TEXTURE_2D;this._bindTextureDirectly(i,t)}},e.prototype.unbindAllTextures=function(){for(var e=0;e1&&(this._bindTextureDirectly(this._gl.TEXTURE_3D,null),this._bindTextureDirectly(this._gl.TEXTURE_2D_ARRAY,null))},e.prototype.setTexture=function(e,t,i){void 0!==e&&(t&&(this._boundUniforms[e]=t),this._setTexture(e,i))},e.prototype._bindSamplerUniformToChannel=function(e,t){var i=this._boundUniforms[e];i&&i._currentState!==t&&(this._gl.uniform1i(i,t),i._currentState=t)},e.prototype._getTextureWrapMode=function(e){switch(e){case 1:return this._gl.REPEAT;case 0:return this._gl.CLAMP_TO_EDGE;case 2:return this._gl.MIRRORED_REPEAT}return this._gl.REPEAT},e.prototype._setTexture=function(e,t,i,r){if(void 0===i&&(i=!1),void 0===r&&(r=!1),!t)return null!=this._boundTexturesCache[e]&&(this._activeChannel=e,this._bindTextureDirectly(this._gl.TEXTURE_2D,null),this._bindTextureDirectly(this._gl.TEXTURE_CUBE_MAP,null),this.webGLVersion>1&&(this._bindTextureDirectly(this._gl.TEXTURE_3D,null),this._bindTextureDirectly(this._gl.TEXTURE_2D_ARRAY,null))),!1;if(t.video)this._activeChannel=e,t.update();else if(4===t.delayLoadState)return t.delayLoad(),!1;var n;n=r?t.depthStencilTexture:t.isReady()?t.getInternalTexture():t.isCube?this.emptyCubeTexture:t.is3D?this.emptyTexture3D:t.is2DArray?this.emptyTexture2DArray:this.emptyTexture,!i&&n&&(n._associatedChannel=e);var o=!0;this._boundTexturesCache[e]===n&&(i||this._bindSamplerUniformToChannel(n._associatedChannel,e),o=!1),this._activeChannel=e;var s=this._getTextureTarget(n);if(o&&this._bindTextureDirectly(s,n,i),n&&!n.isMultiview){if(n.isCube&&n._cachedCoordinatesMode!==t.coordinatesMode){n._cachedCoordinatesMode=t.coordinatesMode;var a=3!==t.coordinatesMode&&5!==t.coordinatesMode?1:0;t.wrapU=a,t.wrapV=a}n._cachedWrapU!==t.wrapU&&(n._cachedWrapU=t.wrapU,this._setTextureParameterInteger(s,this._gl.TEXTURE_WRAP_S,this._getTextureWrapMode(t.wrapU),n)),n._cachedWrapV!==t.wrapV&&(n._cachedWrapV=t.wrapV,this._setTextureParameterInteger(s,this._gl.TEXTURE_WRAP_T,this._getTextureWrapMode(t.wrapV),n)),n.is3D&&n._cachedWrapR!==t.wrapR&&(n._cachedWrapR=t.wrapR,this._setTextureParameterInteger(s,this._gl.TEXTURE_WRAP_R,this._getTextureWrapMode(t.wrapR),n)),this._setAnisotropicLevel(s,n,t.anisotropicFilteringLevel)}return!0},e.prototype.setTextureArray=function(e,t,i){if(void 0!==e&&t){this._textureUnits&&this._textureUnits.length===i.length||(this._textureUnits=new Int32Array(i.length));for(var r=0;r=this._caps.maxVertexAttribs||!this._vertexAttribArraysEnabled[e]||this.disableAttributeByIndex(e)}},e.prototype.releaseEffects=function(){for(var e in this._compiledEffects){var t=this._compiledEffects[e].getPipelineContext();this._deletePipelineContext(t)}this._compiledEffects={}},e.prototype.dispose=function(){this.stopRenderLoop(),this.onBeforeTextureInitObservable&&this.onBeforeTextureInitObservable.clear(),this._emptyTexture&&(this._releaseTexture(this._emptyTexture),this._emptyTexture=null),this._emptyCubeTexture&&(this._releaseTexture(this._emptyCubeTexture),this._emptyCubeTexture=null),this._dummyFramebuffer&&this._gl.deleteFramebuffer(this._dummyFramebuffer),this.releaseEffects(),this.unbindAllAttributes(),this._boundUniforms=[],f.a.IsWindowObjectExist()&&this._renderingCanvas&&(this._doNotHandleContextLost||(this._renderingCanvas.removeEventListener("webglcontextlost",this._onContextLost),this._renderingCanvas.removeEventListener("webglcontextrestored",this._onContextRestored))),this._workingCanvas=null,this._workingContext=null,this._currentBufferPointers=[],this._renderingCanvas=null,this._currentProgram=null,this._boundRenderFunction=null,n.a.ResetCache();for(var e=0,t=this._activeRequests;e1?this._caps.colorBufferFloat:this._canRenderToFramebuffer(1)},e.prototype._canRenderToHalfFloatFramebuffer=function(){return this._webGLVersion>1?this._caps.colorBufferFloat:this._canRenderToFramebuffer(2)},e.prototype._canRenderToFramebuffer=function(e){for(var t=this._gl;t.getError()!==t.NO_ERROR;);var i=!0,r=t.createTexture();t.bindTexture(t.TEXTURE_2D,r),t.texImage2D(t.TEXTURE_2D,0,this._getRGBABufferInternalSizedFormat(e),1,1,0,t.RGBA,this._getWebGLTextureType(e),null),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MIN_FILTER,t.NEAREST),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MAG_FILTER,t.NEAREST);var n=t.createFramebuffer();t.bindFramebuffer(t.FRAMEBUFFER,n),t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,r,0);var o=t.checkFramebufferStatus(t.FRAMEBUFFER);if((i=(i=i&&o===t.FRAMEBUFFER_COMPLETE)&&t.getError()===t.NO_ERROR)&&(t.clear(t.COLOR_BUFFER_BIT),i=i&&t.getError()===t.NO_ERROR),i){t.bindFramebuffer(t.FRAMEBUFFER,null);var s=t.RGBA,a=t.UNSIGNED_BYTE,h=new Uint8Array(4);t.readPixels(0,0,1,1,s,a,h),i=i&&t.getError()===t.NO_ERROR}for(t.deleteTexture(r),t.deleteFramebuffer(n),t.bindFramebuffer(t.FRAMEBUFFER,null);!i&&t.getError()!==t.NO_ERROR;);return i},e.prototype._getWebGLTextureType=function(e){if(1===this._webGLVersion){switch(e){case 1:return this._gl.FLOAT;case 2:return this._gl.HALF_FLOAT_OES;case 0:return this._gl.UNSIGNED_BYTE;case 8:return this._gl.UNSIGNED_SHORT_4_4_4_4;case 9:return this._gl.UNSIGNED_SHORT_5_5_5_1;case 10:return this._gl.UNSIGNED_SHORT_5_6_5}return this._gl.UNSIGNED_BYTE}switch(e){case 3:return this._gl.BYTE;case 0:return this._gl.UNSIGNED_BYTE;case 4:return this._gl.SHORT;case 5:return this._gl.UNSIGNED_SHORT;case 6:return this._gl.INT;case 7:return this._gl.UNSIGNED_INT;case 1:return this._gl.FLOAT;case 2:return this._gl.HALF_FLOAT;case 8:return this._gl.UNSIGNED_SHORT_4_4_4_4;case 9:return this._gl.UNSIGNED_SHORT_5_5_5_1;case 10:return this._gl.UNSIGNED_SHORT_5_6_5;case 11:return this._gl.UNSIGNED_INT_2_10_10_10_REV;case 12:return this._gl.UNSIGNED_INT_24_8;case 13:return this._gl.UNSIGNED_INT_10F_11F_11F_REV;case 14:return this._gl.UNSIGNED_INT_5_9_9_9_REV;case 15:return this._gl.FLOAT_32_UNSIGNED_INT_24_8_REV}return this._gl.UNSIGNED_BYTE},e.prototype._getInternalFormat=function(e){var t=this._gl.RGBA;switch(e){case 0:t=this._gl.ALPHA;break;case 1:t=this._gl.LUMINANCE;break;case 2:t=this._gl.LUMINANCE_ALPHA;break;case 6:t=this._gl.RED;break;case 7:t=this._gl.RG;break;case 4:t=this._gl.RGB;break;case 5:t=this._gl.RGBA}if(this._webGLVersion>1)switch(e){case 8:t=this._gl.RED_INTEGER;break;case 9:t=this._gl.RG_INTEGER;break;case 10:t=this._gl.RGB_INTEGER;break;case 11:t=this._gl.RGBA_INTEGER}return t},e.prototype._getRGBABufferInternalSizedFormat=function(e,t){if(1===this._webGLVersion){if(void 0!==t)switch(t){case 0:return this._gl.ALPHA;case 1:return this._gl.LUMINANCE;case 2:return this._gl.LUMINANCE_ALPHA;case 4:return this._gl.RGB}return this._gl.RGBA}switch(e){case 3:switch(t){case 6:return this._gl.R8_SNORM;case 7:return this._gl.RG8_SNORM;case 4:return this._gl.RGB8_SNORM;case 8:return this._gl.R8I;case 9:return this._gl.RG8I;case 10:return this._gl.RGB8I;case 11:return this._gl.RGBA8I;default:return this._gl.RGBA8_SNORM}case 0:switch(t){case 6:return this._gl.R8;case 7:return this._gl.RG8;case 4:return this._gl.RGB8;case 5:return this._gl.RGBA8;case 8:return this._gl.R8UI;case 9:return this._gl.RG8UI;case 10:return this._gl.RGB8UI;case 11:return this._gl.RGBA8UI;case 0:return this._gl.ALPHA;case 1:return this._gl.LUMINANCE;case 2:return this._gl.LUMINANCE_ALPHA;default:return this._gl.RGBA8}case 4:switch(t){case 8:return this._gl.R16I;case 9:return this._gl.RG16I;case 10:return this._gl.RGB16I;case 11:default:return this._gl.RGBA16I}case 5:switch(t){case 8:return this._gl.R16UI;case 9:return this._gl.RG16UI;case 10:return this._gl.RGB16UI;case 11:default:return this._gl.RGBA16UI}case 6:switch(t){case 8:return this._gl.R32I;case 9:return this._gl.RG32I;case 10:return this._gl.RGB32I;case 11:default:return this._gl.RGBA32I}case 7:switch(t){case 8:return this._gl.R32UI;case 9:return this._gl.RG32UI;case 10:return this._gl.RGB32UI;case 11:default:return this._gl.RGBA32UI}case 1:switch(t){case 6:return this._gl.R32F;case 7:return this._gl.RG32F;case 4:return this._gl.RGB32F;case 5:default:return this._gl.RGBA32F}case 2:switch(t){case 6:return this._gl.R16F;case 7:return this._gl.RG16F;case 4:return this._gl.RGB16F;case 5:default:return this._gl.RGBA16F}case 10:return this._gl.RGB565;case 13:return this._gl.R11F_G11F_B10F;case 14:return this._gl.RGB9_E5;case 8:return this._gl.RGBA4;case 9:return this._gl.RGB5_A1;case 11:switch(t){case 5:return this._gl.RGB10_A2;case 11:return this._gl.RGB10_A2UI;default:return this._gl.RGB10_A2}}return this._gl.RGBA8},e.prototype._getRGBAMultiSampleBufferFormat=function(e){return 1===e?this._gl.RGBA32F:2===e?this._gl.RGBA16F:this._gl.RGBA8},e.prototype._loadFile=function(t,i,r,n,o,s){var a=this,h=e._FileToolsLoadFile(t,i,r,n,o,s);return this._activeRequests.push(h),h.onCompleteObservable.add((function(e){a._activeRequests.splice(a._activeRequests.indexOf(e),1)})),h},e._FileToolsLoadFile=function(e,t,i,r,n,s){throw o.a.WarnImport("FileTools")},e.prototype.readPixels=function(e,t,i,r,n){void 0===n&&(n=!0);var o=n?4:3,s=n?this._gl.RGBA:this._gl.RGB,a=new Uint8Array(r*i*o);return this._gl.readPixels(e,t,i,r,s,this._gl.UNSIGNED_BYTE,a),a},Object.defineProperty(e,"IsSupported",{get:function(){return this.isSupported()},enumerable:!1,configurable:!0}),e.isSupported=function(){if(null!==this._HasMajorPerformanceCaveat)return!this._HasMajorPerformanceCaveat;if(null===this._IsSupported)try{var e=m.a.CreateCanvas(1,1),t=e.getContext("webgl")||e.getContext("experimental-webgl");this._IsSupported=null!=t&&!!window.WebGLRenderingContext}catch(e){this._IsSupported=!1}return this._IsSupported},Object.defineProperty(e,"HasMajorPerformanceCaveat",{get:function(){if(null===this._HasMajorPerformanceCaveat)try{var e=m.a.CreateCanvas(1,1),t=e.getContext("webgl",{failIfMajorPerformanceCaveat:!0})||e.getContext("experimental-webgl",{failIfMajorPerformanceCaveat:!0});this._HasMajorPerformanceCaveat=!t}catch(e){this._HasMajorPerformanceCaveat=!1}return this._HasMajorPerformanceCaveat},enumerable:!1,configurable:!0}),e.CeilingPOT=function(e){return e--,e|=e>>1,e|=e>>2,e|=e>>4,e|=e>>8,e|=e>>16,++e},e.FloorPOT=function(e){return e|=e>>1,e|=e>>2,e|=e>>4,e|=e>>8,(e|=e>>16)-(e>>1)},e.NearestPOT=function(t){var i=e.CeilingPOT(t),r=e.FloorPOT(t);return i-t>t-r?r:i},e.GetExponentOfTwo=function(t,i,r){var n;switch(void 0===r&&(r=2),r){case 1:n=e.FloorPOT(t);break;case 2:n=e.NearestPOT(t);break;case 3:default:n=e.CeilingPOT(t)}return Math.min(n,i)},e.QueueNewFrame=function(e,t){return f.a.IsWindowObjectExist()?(t||(t=window),t.requestPostAnimationFrame?t.requestPostAnimationFrame(e):t.requestAnimationFrame?t.requestAnimationFrame(e):t.msRequestAnimationFrame?t.msRequestAnimationFrame(e):t.webkitRequestAnimationFrame?t.webkitRequestAnimationFrame(e):t.mozRequestAnimationFrame?t.mozRequestAnimationFrame(e):t.oRequestAnimationFrame?t.oRequestAnimationFrame(e):window.setTimeout(e,16)):"undefined"!=typeof requestAnimationFrame?requestAnimationFrame(e):setTimeout(e,16)},e.prototype.getHostDocument=function(){return this._renderingCanvas&&this._renderingCanvas.ownerDocument?this._renderingCanvas.ownerDocument:document},e.ExceptionList=[{key:"Chrome/63.0",capture:"63\\.0\\.3239\\.(\\d+)",captureConstraint:108,targets:["uniformBuffer"]},{key:"Firefox/58",capture:null,captureConstraint:null,targets:["uniformBuffer"]},{key:"Firefox/59",capture:null,captureConstraint:null,targets:["uniformBuffer"]},{key:"Chrome/72.+?Mobile",capture:null,captureConstraint:null,targets:["vao"]},{key:"Chrome/73.+?Mobile",capture:null,captureConstraint:null,targets:["vao"]},{key:"Chrome/74.+?Mobile",capture:null,captureConstraint:null,targets:["vao"]},{key:"Mac OS.+Chrome/71",capture:null,captureConstraint:null,targets:["vao"]},{key:"Mac OS.+Chrome/72",capture:null,captureConstraint:null,targets:["vao"]}],e._TextureLoaders=[],e.CollisionsEpsilon=.001,e._IsSupported=null,e._HasMajorPerformanceCaveat=null,e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return _}));var r=i(1),n=i(3),o=i(29),s=i(12),a=i(4),h=i(0),l=i(33),c=i(11),u=i(9),f=i(8),d=i(57),p=i(52),_=function(e){function t(i,r,n,s){void 0===s&&(s=!0);var l=e.call(this,i,n)||this;return l._position=h.e.Zero(),l._upVector=h.e.Up(),l.orthoLeft=null,l.orthoRight=null,l.orthoBottom=null,l.orthoTop=null,l.fov=.8,l.minZ=1,l.maxZ=1e4,l.inertia=.9,l.mode=t.PERSPECTIVE_CAMERA,l.isIntermediate=!1,l.viewport=new d.a(0,0,1,1),l.layerMask=268435455,l.fovMode=t.FOVMODE_VERTICAL_FIXED,l.cameraRigMode=t.RIG_MODE_NONE,l.customRenderTargets=new Array,l.outputRenderTarget=null,l.onViewMatrixChangedObservable=new a.a,l.onProjectionMatrixChangedObservable=new a.a,l.onAfterCheckInputsObservable=new a.a,l.onRestoreStateObservable=new a.a,l.isRigCamera=!1,l._rigCameras=new Array,l._webvrViewMatrix=h.a.Identity(),l._skipRendering=!1,l._projectionMatrix=new h.a,l._postProcesses=new Array,l._activeMeshes=new o.a(256),l._globalPosition=h.e.Zero(),l._computedViewMatrix=h.a.Identity(),l._doNotComputeProjectionMatrix=!1,l._transformMatrix=h.a.Zero(),l._refreshFrustumPlanes=!0,l._isCamera=!0,l._isLeftCamera=!1,l._isRightCamera=!1,l.getScene().addCamera(l),s&&!l.getScene().activeCamera&&(l.getScene().activeCamera=l),l.position=r,l}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"position",{get:function(){return this._position},set:function(e){this._position=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"upVector",{get:function(){return this._upVector},set:function(e){this._upVector=e},enumerable:!1,configurable:!0}),t.prototype.storeState=function(){return this._stateStored=!0,this._storedFov=this.fov,this},t.prototype._restoreStateValues=function(){return!!this._stateStored&&(this.fov=this._storedFov,!0)},t.prototype.restoreState=function(){return!!this._restoreStateValues()&&(this.onRestoreStateObservable.notifyObservers(this),!0)},t.prototype.getClassName=function(){return"Camera"},t.prototype.toString=function(e){var t="Name: "+this.name;if(t+=", type: "+this.getClassName(),this.animations)for(var i=0;i-1?(c.a.Error("You're trying to reuse a post process not defined as reusable."),0):(null==t||t<0?this._postProcesses.push(e):null===this._postProcesses[t]?this._postProcesses[t]=e:this._postProcesses.splice(t,0,e),this._cascadePostProcessesToRigCams(),this._scene.prePassRenderer&&this._scene.prePassRenderer.markAsDirty(),this._postProcesses.indexOf(e))},t.prototype.detachPostProcess=function(e){var t=this._postProcesses.indexOf(e);-1!==t&&(this._postProcesses[t]=null),this._scene.prePassRenderer&&this._scene.prePassRenderer.markAsDirty(),this._cascadePostProcessesToRigCams()},t.prototype.getWorldMatrix=function(){return this._isSynchronizedViewMatrix()||this.getViewMatrix(),this._worldMatrix},t.prototype._getViewMatrix=function(){return h.a.Identity()},t.prototype.getViewMatrix=function(e){return!e&&this._isSynchronizedViewMatrix()||(this.updateCache(),this._computedViewMatrix=this._getViewMatrix(),this._currentRenderId=this.getScene().getRenderId(),this._childUpdateId++,this._refreshFrustumPlanes=!0,this._cameraRigParams&&this._cameraRigParams.vrPreViewMatrix&&this._computedViewMatrix.multiplyToRef(this._cameraRigParams.vrPreViewMatrix,this._computedViewMatrix),this.parent&&this.parent.onViewMatrixChangedObservable&&this.parent.onViewMatrixChangedObservable.notifyObservers(this.parent),this.onViewMatrixChangedObservable.notifyObservers(this),this._computedViewMatrix.invertToRef(this._worldMatrix)),this._computedViewMatrix},t.prototype.freezeProjectionMatrix=function(e){this._doNotComputeProjectionMatrix=!0,void 0!==e&&(this._projectionMatrix=e)},t.prototype.unfreezeProjectionMatrix=function(){this._doNotComputeProjectionMatrix=!1},t.prototype.getProjectionMatrix=function(e){var i,r,n,o,s,a,l,c;if(this._doNotComputeProjectionMatrix||!e&&this._isSynchronizedProjectionMatrix())return this._projectionMatrix;this._cache.mode=this.mode,this._cache.minZ=this.minZ,this._cache.maxZ=this.maxZ,this._refreshFrustumPlanes=!0;var u=this.getEngine(),f=this.getScene();if(this.mode===t.PERSPECTIVE_CAMERA){this._cache.fov=this.fov,this._cache.fovMode=this.fovMode,this._cache.aspectRatio=u.getAspectRatio(this),this.minZ<=0&&(this.minZ=.1);var d=u.useReverseDepthBuffer;(f.useRightHandedSystem?d?h.a.PerspectiveFovReverseRHToRef:h.a.PerspectiveFovRHToRef:d?h.a.PerspectiveFovReverseLHToRef:h.a.PerspectiveFovLHToRef)(this.fov,u.getAspectRatio(this),this.minZ,this.maxZ,this._projectionMatrix,this.fovMode===t.FOVMODE_VERTICAL_FIXED)}else{var p=u.getRenderWidth()/2,_=u.getRenderHeight()/2;f.useRightHandedSystem?h.a.OrthoOffCenterRHToRef(null!==(i=this.orthoLeft)&&void 0!==i?i:-p,null!==(r=this.orthoRight)&&void 0!==r?r:p,null!==(n=this.orthoBottom)&&void 0!==n?n:-_,null!==(o=this.orthoTop)&&void 0!==o?o:_,this.minZ,this.maxZ,this._projectionMatrix):h.a.OrthoOffCenterLHToRef(null!==(s=this.orthoLeft)&&void 0!==s?s:-p,null!==(a=this.orthoRight)&&void 0!==a?a:p,null!==(l=this.orthoBottom)&&void 0!==l?l:-_,null!==(c=this.orthoTop)&&void 0!==c?c:_,this.minZ,this.maxZ,this._projectionMatrix),this._cache.orthoLeft=this.orthoLeft,this._cache.orthoRight=this.orthoRight,this._cache.orthoBottom=this.orthoBottom,this._cache.orthoTop=this.orthoTop,this._cache.renderWidth=u.getRenderWidth(),this._cache.renderHeight=u.getRenderHeight()}return this.onProjectionMatrixChangedObservable.notifyObservers(this),this._projectionMatrix},t.prototype.getTransformationMatrix=function(){return this._computedViewMatrix.multiplyToRef(this._projectionMatrix,this._transformMatrix),this._transformMatrix},t.prototype._updateFrustumPlanes=function(){this._refreshFrustumPlanes&&(this.getTransformationMatrix(),this._frustumPlanes?p.a.GetPlanesToRef(this._transformMatrix,this._frustumPlanes):this._frustumPlanes=p.a.GetPlanes(this._transformMatrix),this._refreshFrustumPlanes=!1)},t.prototype.isInFrustum=function(e,t){if(void 0===t&&(t=!1),this._updateFrustumPlanes(),t&&this.rigCameras.length>0){var i=!1;return this.rigCameras.forEach((function(t){t._updateFrustumPlanes(),i=i||e.isInFrustum(t._frustumPlanes)})),i}return e.isInFrustum(this._frustumPlanes)},t.prototype.isCompletelyInFrustum=function(e){return this._updateFrustumPlanes(),e.isCompletelyInFrustum(this._frustumPlanes)},t.prototype.getForwardRay=function(e,t,i){throw void 0===e&&(e=100),f.a.WarnImport("Ray")},t.prototype.getForwardRayToRef=function(e,t,i,r){throw void 0===t&&(t=100),f.a.WarnImport("Ray")},t.prototype.dispose=function(i,r){for(void 0===r&&(r=!1),this.onViewMatrixChangedObservable.clear(),this.onProjectionMatrixChangedObservable.clear(),this.onAfterCheckInputsObservable.clear(),this.onRestoreStateObservable.clear(),this.inputs&&this.inputs.clear(),this.getScene().stopAnimation(this),this.getScene().removeCamera(this);this._rigCameras.length>0;){var n=this._rigCameras.pop();n&&n.dispose()}if(this._rigPostProcess)this._rigPostProcess.dispose(this),this._rigPostProcess=null,this._postProcesses=[];else if(this.cameraRigMode!==t.RIG_MODE_NONE)this._rigPostProcess=null,this._postProcesses=[];else for(var o=this._postProcesses.length;--o>=0;){var s=this._postProcesses[o];s&&s.dispose(this)}for(o=this.customRenderTargets.length;--o>=0;)this.customRenderTargets[o].dispose();this.customRenderTargets=[],this._activeMeshes.dispose(),e.prototype.dispose.call(this,i,r)},Object.defineProperty(t.prototype,"isLeftCamera",{get:function(){return this._isLeftCamera},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isRightCamera",{get:function(){return this._isRightCamera},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"leftCamera",{get:function(){return this._rigCameras.length<1?null:this._rigCameras[0]},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"rightCamera",{get:function(){return this._rigCameras.length<2?null:this._rigCameras[1]},enumerable:!1,configurable:!0}),t.prototype.getLeftTarget=function(){return this._rigCameras.length<1?null:this._rigCameras[0].getTarget()},t.prototype.getRightTarget=function(){return this._rigCameras.length<2?null:this._rigCameras[1].getTarget()},t.prototype.setCameraRigMode=function(e,i){if(this.cameraRigMode!==e){for(;this._rigCameras.length>0;){var r=this._rigCameras.pop();r&&r.dispose()}if(this.cameraRigMode=e,this._cameraRigParams={},this._cameraRigParams.interaxialDistance=i.interaxialDistance||.0637,this._cameraRigParams.stereoHalfAngle=s.b.ToRadians(this._cameraRigParams.interaxialDistance/.0637),this.cameraRigMode!==t.RIG_MODE_NONE){var n=this.createRigCamera(this.name+"_L",0);n&&(n._isLeftCamera=!0);var o=this.createRigCamera(this.name+"_R",1);o&&(o._isRightCamera=!0),n&&o&&(this._rigCameras.push(n),this._rigCameras.push(o))}switch(this.cameraRigMode){case t.RIG_MODE_STEREOSCOPIC_ANAGLYPH:t._setStereoscopicAnaglyphRigMode(this);break;case t.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL:case t.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED:case t.RIG_MODE_STEREOSCOPIC_OVERUNDER:case t.RIG_MODE_STEREOSCOPIC_INTERLACED:t._setStereoscopicRigMode(this);break;case t.RIG_MODE_VR:t._setVRRigMode(this,i);break;case t.RIG_MODE_WEBVR:t._setWebVRRigMode(this,i)}this._cascadePostProcessesToRigCams(),this.update()}},t._setStereoscopicRigMode=function(e){throw"Import Cameras/RigModes/stereoscopicRigMode before using stereoscopic rig mode"},t._setStereoscopicAnaglyphRigMode=function(e){throw"Import Cameras/RigModes/stereoscopicAnaglyphRigMode before using stereoscopic anaglyph rig mode"},t._setVRRigMode=function(e,t){throw"Import Cameras/RigModes/vrRigMode before using VR rig mode"},t._setWebVRRigMode=function(e,t){throw"Import Cameras/RigModes/WebVRRigMode before using Web VR rig mode"},t.prototype._getVRProjectionMatrix=function(){return h.a.PerspectiveFovLHToRef(this._cameraRigParams.vrMetrics.aspectRatioFov,this._cameraRigParams.vrMetrics.aspectRatio,this.minZ,this.maxZ,this._cameraRigParams.vrWorkMatrix),this._cameraRigParams.vrWorkMatrix.multiplyToRef(this._cameraRigParams.vrHMatrix,this._projectionMatrix),this._projectionMatrix},t.prototype._updateCameraRotationMatrix=function(){},t.prototype._updateWebVRCameraRotationMatrix=function(){},t.prototype._getWebVRProjectionMatrix=function(){return h.a.Identity()},t.prototype._getWebVRViewMatrix=function(){return h.a.Identity()},t.prototype.setCameraRigParameter=function(e,t){this._cameraRigParams||(this._cameraRigParams={}),this._cameraRigParams[e]=t,"interaxialDistance"===e&&(this._cameraRigParams.stereoHalfAngle=s.b.ToRadians(t/.0637))},t.prototype.createRigCamera=function(e,t){return null},t.prototype._updateRigCameras=function(){for(var e=0;e1)for(var h=0;h=1)&&(this.needAlphaBlending()||e.visibility<1||e.hasVertexAlpha)},e.prototype.needAlphaTesting=function(){return!!this._forceAlphaTest},e.prototype._shouldTurnAlphaTestOn=function(e){return!this.needAlphaBlendingForMesh(e)&&this.needAlphaTesting()},e.prototype.getAlphaTestTexture=function(){return null},e.prototype.markDirty=function(){for(var e=0,t=this.getScene().meshes;e=this._sampleCount||e>=this._samples.length)return 0;var t=this._wrapPosition(this._pos-1);return this._samples[this._wrapPosition(t-e)]},e.prototype.isSaturated=function(){return this._sampleCount>=this._samples.length},e.prototype.reset=function(){this.average=0,this.variance=0,this._sampleCount=0,this._pos=0,this._m2=0},e.prototype._wrapPosition=function(e){var t=this._samples.length;return(e%t+t)%t},e}(),f=i(58),d=i(55),p=i(11);h.a.prototype.setAlphaConstants=function(e,t,i,r){this._alphaState.setAlphaBlendConstants(e,t,i,r)},h.a.prototype.setAlphaMode=function(e,t){if(void 0===t&&(t=!1),this._alphaMode!==e){switch(e){case 0:this._alphaState.alphaBlend=!1;break;case 7:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE,this._gl.ONE_MINUS_SRC_ALPHA,this._gl.ONE,this._gl.ONE),this._alphaState.alphaBlend=!0;break;case 8:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE,this._gl.ONE_MINUS_SRC_ALPHA,this._gl.ONE,this._gl.ONE_MINUS_SRC_ALPHA),this._alphaState.alphaBlend=!0;break;case 2:this._alphaState.setAlphaBlendFunctionParameters(this._gl.SRC_ALPHA,this._gl.ONE_MINUS_SRC_ALPHA,this._gl.ONE,this._gl.ONE),this._alphaState.alphaBlend=!0;break;case 6:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE,this._gl.ONE,this._gl.ZERO,this._gl.ONE),this._alphaState.alphaBlend=!0;break;case 1:this._alphaState.setAlphaBlendFunctionParameters(this._gl.SRC_ALPHA,this._gl.ONE,this._gl.ZERO,this._gl.ONE),this._alphaState.alphaBlend=!0;break;case 3:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ZERO,this._gl.ONE_MINUS_SRC_COLOR,this._gl.ONE,this._gl.ONE),this._alphaState.alphaBlend=!0;break;case 4:this._alphaState.setAlphaBlendFunctionParameters(this._gl.DST_COLOR,this._gl.ZERO,this._gl.ONE,this._gl.ONE),this._alphaState.alphaBlend=!0;break;case 5:this._alphaState.setAlphaBlendFunctionParameters(this._gl.SRC_ALPHA,this._gl.ONE_MINUS_SRC_COLOR,this._gl.ONE,this._gl.ONE),this._alphaState.alphaBlend=!0;break;case 9:this._alphaState.setAlphaBlendFunctionParameters(this._gl.CONSTANT_COLOR,this._gl.ONE_MINUS_CONSTANT_COLOR,this._gl.CONSTANT_ALPHA,this._gl.ONE_MINUS_CONSTANT_ALPHA),this._alphaState.alphaBlend=!0;break;case 10:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE,this._gl.ONE_MINUS_SRC_COLOR,this._gl.ONE,this._gl.ONE_MINUS_SRC_ALPHA),this._alphaState.alphaBlend=!0;break;case 11:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE,this._gl.ONE,this._gl.ONE,this._gl.ONE),this._alphaState.alphaBlend=!0;break;case 12:this._alphaState.setAlphaBlendFunctionParameters(this._gl.DST_ALPHA,this._gl.ONE,this._gl.ZERO,this._gl.ZERO),this._alphaState.alphaBlend=!0;break;case 13:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE_MINUS_DST_COLOR,this._gl.ONE_MINUS_SRC_COLOR,this._gl.ONE_MINUS_DST_ALPHA,this._gl.ONE_MINUS_SRC_ALPHA),this._alphaState.alphaBlend=!0;break;case 14:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE,this._gl.ONE_MINUS_SRC_ALPHA,this._gl.ONE,this._gl.ONE_MINUS_SRC_ALPHA),this._alphaState.alphaBlend=!0;break;case 15:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE,this._gl.ONE,this._gl.ONE,this._gl.ZERO),this._alphaState.alphaBlend=!0;break;case 16:this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE_MINUS_DST_COLOR,this._gl.ONE_MINUS_SRC_COLOR,this._gl.ZERO,this._gl.ONE),this._alphaState.alphaBlend=!0}t||(this.depthCullingState.depthMask=0===e),this._alphaMode=e}},h.a.prototype.getAlphaMode=function(){return this._alphaMode},h.a.prototype.setAlphaEquation=function(e){if(this._alphaEquation!==e){switch(e){case 0:this._alphaState.setAlphaEquationParameters(this._gl.FUNC_ADD,this._gl.FUNC_ADD);break;case 1:this._alphaState.setAlphaEquationParameters(this._gl.FUNC_SUBTRACT,this._gl.FUNC_SUBTRACT);break;case 2:this._alphaState.setAlphaEquationParameters(this._gl.FUNC_REVERSE_SUBTRACT,this._gl.FUNC_REVERSE_SUBTRACT);break;case 3:this._alphaState.setAlphaEquationParameters(this._gl.MAX,this._gl.MAX);break;case 4:this._alphaState.setAlphaEquationParameters(this._gl.MIN,this._gl.MIN);break;case 5:this._alphaState.setAlphaEquationParameters(this._gl.MIN,this._gl.FUNC_ADD)}this._alphaEquation=e}},h.a.prototype.getAlphaEquation=function(){return this._alphaEquation},h.a.prototype._readTexturePixels=function(e,t,i,r,n,o){void 0===r&&(r=-1),void 0===n&&(n=0),void 0===o&&(o=null);var s=this._gl;if(!s)throw new Error("Engine does not have gl rendering context.");if(!this._dummyFramebuffer){var a=s.createFramebuffer();if(!a)throw new Error("Unable to create dummy framebuffer");this._dummyFramebuffer=a}s.bindFramebuffer(s.FRAMEBUFFER,this._dummyFramebuffer),r>-1?s.framebufferTexture2D(s.FRAMEBUFFER,s.COLOR_ATTACHMENT0,s.TEXTURE_CUBE_MAP_POSITIVE_X+r,e._webGLTexture,n):s.framebufferTexture2D(s.FRAMEBUFFER,s.COLOR_ATTACHMENT0,s.TEXTURE_2D,e._webGLTexture,n);var h=void 0!==e.type?this._getWebGLTextureType(e.type):s.UNSIGNED_BYTE;switch(h){case s.UNSIGNED_BYTE:o||(o=new Uint8Array(4*t*i)),h=s.UNSIGNED_BYTE;break;default:o||(o=new Float32Array(4*t*i)),h=s.FLOAT}return s.readPixels(0,0,t,i,s.RGBA,h,o),s.bindFramebuffer(s.FRAMEBUFFER,this._currentFramebuffer),o},h.a.prototype.updateDynamicIndexBuffer=function(e,t,i){var r;void 0===i&&(i=0),this._currentBoundBuffer[this._gl.ELEMENT_ARRAY_BUFFER]=null,this.bindIndexBuffer(e),r=t instanceof Uint16Array||t instanceof Uint32Array?t:e.is32Bits?new Uint32Array(t):new Uint16Array(t),this._gl.bufferData(this._gl.ELEMENT_ARRAY_BUFFER,r,this._gl.DYNAMIC_DRAW),this._resetIndexBufferBinding()},h.a.prototype.updateDynamicVertexBuffer=function(e,t,i,r){this.bindArrayBuffer(e),void 0===i&&(i=0);var n=t.length||t.byteLength;void 0===r||r>=n&&0===i?t instanceof Array?this._gl.bufferSubData(this._gl.ARRAY_BUFFER,i,new Float32Array(t)):this._gl.bufferSubData(this._gl.ARRAY_BUFFER,i,t):t instanceof Array?this._gl.bufferSubData(this._gl.ARRAY_BUFFER,0,new Float32Array(t).subarray(i,i+r)):(t=t instanceof ArrayBuffer?new Uint8Array(t,i,r):new Uint8Array(t.buffer,t.byteOffset+i,r),this._gl.bufferSubData(this._gl.ARRAY_BUFFER,0,t)),this._resetVertexBufferBinding()};var _=function(e){function t(i,r,s,a){void 0===a&&(a=!1);var h=e.call(this,i,r,s,a)||this;if(h.enableOfflineSupport=!1,h.disableManifestCheck=!1,h.scenes=new Array,h.onNewSceneAddedObservable=new n.a,h.postProcesses=new Array,h.isPointerLock=!1,h.onResizeObservable=new n.a,h.onCanvasBlurObservable=new n.a,h.onCanvasFocusObservable=new n.a,h.onCanvasPointerOutObservable=new n.a,h.onBeginFrameObservable=new n.a,h.customAnimationFrameRequester=null,h.onEndFrameObservable=new n.a,h.onBeforeShaderCompilationObservable=new n.a,h.onAfterShaderCompilationObservable=new n.a,h._deterministicLockstep=!1,h._lockstepMaxSteps=4,h._timeStep=1/60,h._fps=60,h._deltaTime=0,h._drawCalls=new f.a,h.canvasTabIndex=1,h.disablePerformanceMonitorInBackground=!1,h._performanceMonitor=new c,t.Instances.push(h),!i)return h;if(s=h._creationOptions,i.getContext){var l=i;if(h._onCanvasFocus=function(){h.onCanvasFocusObservable.notifyObservers(h)},h._onCanvasBlur=function(){h.onCanvasBlurObservable.notifyObservers(h)},l.addEventListener("focus",h._onCanvasFocus),l.addEventListener("blur",h._onCanvasBlur),h._onBlur=function(){h.disablePerformanceMonitorInBackground&&h._performanceMonitor.disable(),h._windowIsBackground=!0},h._onFocus=function(){h.disablePerformanceMonitorInBackground&&h._performanceMonitor.enable(),h._windowIsBackground=!1},h._onCanvasPointerOut=function(e){h.onCanvasPointerOutObservable.notifyObservers(e)},l.addEventListener("pointerout",h._onCanvasPointerOut),o.a.IsWindowObjectExist()){var u=h.getHostWindow();u.addEventListener("blur",h._onBlur),u.addEventListener("focus",h._onFocus);var d=document;h._onFullscreenChange=function(){void 0!==d.fullscreen?h.isFullscreen=d.fullscreen:void 0!==d.mozFullScreen?h.isFullscreen=d.mozFullScreen:void 0!==d.webkitIsFullScreen?h.isFullscreen=d.webkitIsFullScreen:void 0!==d.msIsFullScreen&&(h.isFullscreen=d.msIsFullScreen),h.isFullscreen&&h._pointerLockRequested&&l&&t._RequestPointerlock(l)},document.addEventListener("fullscreenchange",h._onFullscreenChange,!1),document.addEventListener("mozfullscreenchange",h._onFullscreenChange,!1),document.addEventListener("webkitfullscreenchange",h._onFullscreenChange,!1),document.addEventListener("msfullscreenchange",h._onFullscreenChange,!1),h._onPointerLockChange=function(){h.isPointerLock=d.mozPointerLockElement===l||d.webkitPointerLockElement===l||d.msPointerLockElement===l||d.pointerLockElement===l},document.addEventListener("pointerlockchange",h._onPointerLockChange,!1),document.addEventListener("mspointerlockchange",h._onPointerLockChange,!1),document.addEventListener("mozpointerlockchange",h._onPointerLockChange,!1),document.addEventListener("webkitpointerlockchange",h._onPointerLockChange,!1),!t.audioEngine&&s.audioEngine&&t.AudioEngineFactory&&(t.audioEngine=t.AudioEngineFactory(h.getRenderingCanvas()))}h._connectVREvents(),h.enableOfflineSupport=void 0!==t.OfflineProviderFactory,s.doNotHandleTouchAction||h._disableTouchAction(),h._deterministicLockstep=!!s.deterministicLockstep,h._lockstepMaxSteps=s.lockstepMaxSteps||0,h._timeStep=s.timeStep||1/60}return h._prepareVRComponent(),s.autoEnableWebVR&&h.initWebVR(),h}return Object(r.c)(t,e),Object.defineProperty(t,"NpmPackage",{get:function(){return h.a.NpmPackage},enumerable:!1,configurable:!0}),Object.defineProperty(t,"Version",{get:function(){return h.a.Version},enumerable:!1,configurable:!0}),Object.defineProperty(t,"Instances",{get:function(){return s.a.Instances},enumerable:!1,configurable:!0}),Object.defineProperty(t,"LastCreatedEngine",{get:function(){return s.a.LastCreatedEngine},enumerable:!1,configurable:!0}),Object.defineProperty(t,"LastCreatedScene",{get:function(){return s.a.LastCreatedScene},enumerable:!1,configurable:!0}),t.MarkAllMaterialsAsDirty=function(e,i){for(var r=0;r0?this.customAnimationFrameRequester?(this.customAnimationFrameRequester.requestID=this._queueNewFrame(this.customAnimationFrameRequester.renderFunction||this._boundRenderFunction,this.customAnimationFrameRequester),this._frameHandler=this.customAnimationFrameRequester.requestID):this.isVRPresenting()?this._requestVRFrame():this._frameHandler=this._queueNewFrame(this._boundRenderFunction,this.getHostWindow()):this._renderingQueueLaunched=!1},t.prototype._renderViews=function(){return!1},t.prototype.switchFullscreen=function(e){this.isFullscreen?this.exitFullscreen():this.enterFullscreen(e)},t.prototype.enterFullscreen=function(e){this.isFullscreen||(this._pointerLockRequested=e,this._renderingCanvas&&t._RequestFullscreen(this._renderingCanvas))},t.prototype.exitFullscreen=function(){this.isFullscreen&&t._ExitFullscreen()},t.prototype.enterPointerlock=function(){this._renderingCanvas&&t._RequestPointerlock(this._renderingCanvas)},t.prototype.exitPointerlock=function(){t._ExitPointerlock()},t.prototype.beginFrame=function(){this._measureFps(),this.onBeginFrameObservable.notifyObservers(this),e.prototype.beginFrame.call(this)},t.prototype.endFrame=function(){e.prototype.endFrame.call(this),this._submitVRFrame(),this.onEndFrameObservable.notifyObservers(this)},t.prototype.resize=function(){this.isVRPresenting()||e.prototype.resize.call(this)},t.prototype.setSize=function(t,i){if(!this._renderingCanvas)return!1;if(!e.prototype.setSize.call(this,t,i))return!1;if(this.scenes){for(var r=0;r1&&n){var s=this.createTransformFeedback();this.bindTransformFeedback(s),this.setTranformFeedbackVaryings(o,n),e.transformFeedback=s}return r.linkProgram(o),this.webGLVersion>1&&n&&this.bindTransformFeedback(null),e.context=r,e.vertexShader=t,e.fragmentShader=i,e.isParallelCompiled||this._finalizePipelineContext(e),o},t.prototype._releaseTexture=function(t){e.prototype._releaseTexture.call(this,t),this.scenes.forEach((function(e){e.postProcesses.forEach((function(e){e._outputTexture==t&&(e._outputTexture=null)})),e.cameras.forEach((function(e){e._postProcesses.forEach((function(e){e&&e._outputTexture==t&&(e._outputTexture=null)}))}))}))},t.prototype._rescaleTexture=function(e,i,r,n,o){var s=this;this._gl.texParameteri(this._gl.TEXTURE_2D,this._gl.TEXTURE_MAG_FILTER,this._gl.LINEAR),this._gl.texParameteri(this._gl.TEXTURE_2D,this._gl.TEXTURE_MIN_FILTER,this._gl.LINEAR),this._gl.texParameteri(this._gl.TEXTURE_2D,this._gl.TEXTURE_WRAP_S,this._gl.CLAMP_TO_EDGE),this._gl.texParameteri(this._gl.TEXTURE_2D,this._gl.TEXTURE_WRAP_T,this._gl.CLAMP_TO_EDGE);var a=this.createRenderTargetTexture({width:i.width,height:i.height},{generateMipMaps:!1,type:0,samplingMode:2,generateDepthBuffer:!1,generateStencilBuffer:!1});!this._rescalePostProcess&&t._RescalePostProcessFactory&&(this._rescalePostProcess=t._RescalePostProcessFactory(this)),this._rescalePostProcess.getEffect().executeWhenCompiled((function(){s._rescalePostProcess.onApply=function(t){t._bindTexture("textureSampler",e)};var t=r;t||(t=s.scenes[s.scenes.length-1]),t.postProcessManager.directRender([s._rescalePostProcess],a,!0),s._bindTextureDirectly(s._gl.TEXTURE_2D,i,!0),s._gl.copyTexImage2D(s._gl.TEXTURE_2D,0,n,0,0,i.width,i.height,0),s.unBindFramebuffer(a),s._releaseTexture(a),o&&o()}))},t.prototype.getFps=function(){return this._fps},t.prototype.getDeltaTime=function(){return this._deltaTime},t.prototype._measureFps=function(){this._performanceMonitor.sampleFrame(),this._fps=this._performanceMonitor.averageFPS,this._deltaTime=this._performanceMonitor.instantaneousFrameTime||0},t.prototype._uploadImageToTexture=function(e,t,i,r){void 0===i&&(i=0),void 0===r&&(r=0);var n=this._gl,o=this._getWebGLTextureType(e.type),s=this._getInternalFormat(e.format),a=this._getRGBABufferInternalSizedFormat(e.type,s),h=e.isCube?n.TEXTURE_CUBE_MAP:n.TEXTURE_2D;this._bindTextureDirectly(h,e,!0),this._unpackFlipY(e.invertY);var l=n.TEXTURE_2D;e.isCube&&(l=n.TEXTURE_CUBE_MAP_POSITIVE_X+i),n.texImage2D(l,r,a,s,o,t),this._bindTextureDirectly(h,null,!0)},t.prototype.updateRenderTargetTextureSampleCount=function(e,t){if(this.webGLVersion<2||!e)return 1;if(e.samples===t)return t;var i=this._gl;if(t=Math.min(t,this.getCaps().maxMSAASamples),e._depthStencilBuffer&&(i.deleteRenderbuffer(e._depthStencilBuffer),e._depthStencilBuffer=null),e._MSAAFramebuffer&&(i.deleteFramebuffer(e._MSAAFramebuffer),e._MSAAFramebuffer=null),e._MSAARenderBuffer&&(i.deleteRenderbuffer(e._MSAARenderBuffer),e._MSAARenderBuffer=null),t>1&&i.renderbufferStorageMultisample){var r=i.createFramebuffer();if(!r)throw new Error("Unable to create multi sampled framebuffer");e._MSAAFramebuffer=r,this._bindUnboundFramebuffer(e._MSAAFramebuffer);var n=i.createRenderbuffer();if(!n)throw new Error("Unable to create multi sampled framebuffer");i.bindRenderbuffer(i.RENDERBUFFER,n),i.renderbufferStorageMultisample(i.RENDERBUFFER,t,this._getRGBAMultiSampleBufferFormat(e.type),e.width,e.height),i.framebufferRenderbuffer(i.FRAMEBUFFER,i.COLOR_ATTACHMENT0,i.RENDERBUFFER,n),e._MSAARenderBuffer=n}else this._bindUnboundFramebuffer(e._framebuffer);return e.samples=t,e._depthStencilBuffer=this._setupFramebufferDepthAttachments(e._generateStencilBuffer,e._generateDepthBuffer,e.width,e.height,t),this._bindUnboundFramebuffer(null),t},t.prototype.updateTextureComparisonFunction=function(e,t){if(1!==this.webGLVersion){var i=this._gl;e.isCube?(this._bindTextureDirectly(this._gl.TEXTURE_CUBE_MAP,e,!0),0===t?(i.texParameteri(i.TEXTURE_CUBE_MAP,i.TEXTURE_COMPARE_FUNC,515),i.texParameteri(i.TEXTURE_CUBE_MAP,i.TEXTURE_COMPARE_MODE,i.NONE)):(i.texParameteri(i.TEXTURE_CUBE_MAP,i.TEXTURE_COMPARE_FUNC,t),i.texParameteri(i.TEXTURE_CUBE_MAP,i.TEXTURE_COMPARE_MODE,i.COMPARE_REF_TO_TEXTURE)),this._bindTextureDirectly(this._gl.TEXTURE_CUBE_MAP,null)):(this._bindTextureDirectly(this._gl.TEXTURE_2D,e,!0),0===t?(i.texParameteri(i.TEXTURE_2D,i.TEXTURE_COMPARE_FUNC,515),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_COMPARE_MODE,i.NONE)):(i.texParameteri(i.TEXTURE_2D,i.TEXTURE_COMPARE_FUNC,t),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_COMPARE_MODE,i.COMPARE_REF_TO_TEXTURE)),this._bindTextureDirectly(this._gl.TEXTURE_2D,null)),e._comparisonFunction=t}else p.a.Error("WebGL 1 does not support texture comparison.")},t.prototype.createInstancesBuffer=function(e){var t=this._gl.createBuffer();if(!t)throw new Error("Unable to create instance buffer");var i=new d.a(t);return i.capacity=e,this.bindArrayBuffer(i),this._gl.bufferData(this._gl.ARRAY_BUFFER,e,this._gl.DYNAMIC_DRAW),i},t.prototype.deleteInstancesBuffer=function(e){this._gl.deleteBuffer(e)},t.prototype._clientWaitAsync=function(e,t,i){void 0===t&&(t=0),void 0===i&&(i=10);var r=this._gl;return new Promise((function(n,o){var s=function(){var a=r.clientWaitSync(e,t,0);a!=r.WAIT_FAILED?a!=r.TIMEOUT_EXPIRED?n():setTimeout(s,i):o()};s()}))},t.prototype._readPixelsAsync=function(e,t,i,r,n,o,s){if(this._webGLVersion<2)throw new Error("_readPixelsAsync only work on WebGL2+");var a=this._gl,h=a.createBuffer();a.bindBuffer(a.PIXEL_PACK_BUFFER,h),a.bufferData(a.PIXEL_PACK_BUFFER,s.byteLength,a.STREAM_READ),a.readPixels(e,t,i,r,n,o,0),a.bindBuffer(a.PIXEL_PACK_BUFFER,null);var l=a.fenceSync(a.SYNC_GPU_COMMANDS_COMPLETE,0);return l?(a.flush(),this._clientWaitAsync(l,0,10).then((function(){return a.deleteSync(l),a.bindBuffer(a.PIXEL_PACK_BUFFER,h),a.getBufferSubData(a.PIXEL_PACK_BUFFER,0,s),a.bindBuffer(a.PIXEL_PACK_BUFFER,null),a.deleteBuffer(h),s}))):null},t.prototype.dispose=function(){for(this.hideLoadingUI(),this.onNewSceneAddedObservable.clear();this.postProcesses.length;)this.postProcesses[0].dispose();for(this._rescalePostProcess&&this._rescalePostProcess.dispose();this.scenes.length;)this.scenes[0].dispose();1===t.Instances.length&&t.audioEngine&&t.audioEngine.dispose(),this.disableVR(),o.a.IsWindowObjectExist()&&(window.removeEventListener("blur",this._onBlur),window.removeEventListener("focus",this._onFocus),this._renderingCanvas&&(this._renderingCanvas.removeEventListener("focus",this._onCanvasFocus),this._renderingCanvas.removeEventListener("blur",this._onCanvasBlur),this._renderingCanvas.removeEventListener("pointerout",this._onCanvasPointerOut)),o.a.IsDocumentAvailable()&&(document.removeEventListener("fullscreenchange",this._onFullscreenChange),document.removeEventListener("mozfullscreenchange",this._onFullscreenChange),document.removeEventListener("webkitfullscreenchange",this._onFullscreenChange),document.removeEventListener("msfullscreenchange",this._onFullscreenChange),document.removeEventListener("pointerlockchange",this._onPointerLockChange),document.removeEventListener("mspointerlockchange",this._onPointerLockChange),document.removeEventListener("mozpointerlockchange",this._onPointerLockChange),document.removeEventListener("webkitpointerlockchange",this._onPointerLockChange))),e.prototype.dispose.call(this);var i=t.Instances.indexOf(this);i>=0&&t.Instances.splice(i,1),this.onResizeObservable.clear(),this.onCanvasBlurObservable.clear(),this.onCanvasFocusObservable.clear(),this.onCanvasPointerOutObservable.clear(),this.onBeginFrameObservable.clear(),this.onEndFrameObservable.clear()},t.prototype._disableTouchAction=function(){this._renderingCanvas&&this._renderingCanvas.setAttribute&&(this._renderingCanvas.setAttribute("touch-action","none"),this._renderingCanvas.style.touchAction="none",this._renderingCanvas.style.msTouchAction="none")},t.prototype.displayLoadingUI=function(){if(o.a.IsWindowObjectExist()){var e=this.loadingScreen;e&&e.displayLoadingUI()}},t.prototype.hideLoadingUI=function(){if(o.a.IsWindowObjectExist()){var e=this._loadingScreen;e&&e.hideLoadingUI()}},Object.defineProperty(t.prototype,"loadingScreen",{get:function(){return!this._loadingScreen&&this._renderingCanvas&&(this._loadingScreen=t.DefaultLoadingScreenFactory(this._renderingCanvas)),this._loadingScreen},set:function(e){this._loadingScreen=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"loadingUIText",{set:function(e){this.loadingScreen.loadingUIText=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"loadingUIBackgroundColor",{set:function(e){this.loadingScreen.loadingUIBackgroundColor=e},enumerable:!1,configurable:!0}),t._RequestPointerlock=function(e){e.requestPointerLock=e.requestPointerLock||e.msRequestPointerLock||e.mozRequestPointerLock||e.webkitRequestPointerLock,e.requestPointerLock&&e.requestPointerLock()},t._ExitPointerlock=function(){var e=document;document.exitPointerLock=document.exitPointerLock||e.msExitPointerLock||e.mozExitPointerLock||e.webkitExitPointerLock,document.exitPointerLock&&document.exitPointerLock()},t._RequestFullscreen=function(e){var t=e.requestFullscreen||e.msRequestFullscreen||e.webkitRequestFullscreen||e.mozRequestFullScreen;t&&t.call(e)},t._ExitFullscreen=function(){var e=document;document.exitFullscreen?document.exitFullscreen():e.mozCancelFullScreen?e.mozCancelFullScreen():e.webkitCancelFullScreen?e.webkitCancelFullScreen():e.msCancelFullScreen&&e.msCancelFullScreen()},t.ALPHA_DISABLE=0,t.ALPHA_ADD=1,t.ALPHA_COMBINE=2,t.ALPHA_SUBTRACT=3,t.ALPHA_MULTIPLY=4,t.ALPHA_MAXIMIZED=5,t.ALPHA_ONEONE=6,t.ALPHA_PREMULTIPLIED=7,t.ALPHA_PREMULTIPLIED_PORTERDUFF=8,t.ALPHA_INTERPOLATE=9,t.ALPHA_SCREENMODE=10,t.DELAYLOADSTATE_NONE=0,t.DELAYLOADSTATE_LOADED=1,t.DELAYLOADSTATE_LOADING=2,t.DELAYLOADSTATE_NOTLOADED=4,t.NEVER=512,t.ALWAYS=519,t.LESS=513,t.EQUAL=514,t.LEQUAL=515,t.GREATER=516,t.GEQUAL=518,t.NOTEQUAL=517,t.KEEP=7680,t.REPLACE=7681,t.INCR=7682,t.DECR=7683,t.INVERT=5386,t.INCR_WRAP=34055,t.DECR_WRAP=34056,t.TEXTURE_CLAMP_ADDRESSMODE=0,t.TEXTURE_WRAP_ADDRESSMODE=1,t.TEXTURE_MIRROR_ADDRESSMODE=2,t.TEXTUREFORMAT_ALPHA=0,t.TEXTUREFORMAT_LUMINANCE=1,t.TEXTUREFORMAT_LUMINANCE_ALPHA=2,t.TEXTUREFORMAT_RGB=4,t.TEXTUREFORMAT_RGBA=5,t.TEXTUREFORMAT_RED=6,t.TEXTUREFORMAT_R=6,t.TEXTUREFORMAT_RG=7,t.TEXTUREFORMAT_RED_INTEGER=8,t.TEXTUREFORMAT_R_INTEGER=8,t.TEXTUREFORMAT_RG_INTEGER=9,t.TEXTUREFORMAT_RGB_INTEGER=10,t.TEXTUREFORMAT_RGBA_INTEGER=11,t.TEXTURETYPE_UNSIGNED_BYTE=0,t.TEXTURETYPE_UNSIGNED_INT=0,t.TEXTURETYPE_FLOAT=1,t.TEXTURETYPE_HALF_FLOAT=2,t.TEXTURETYPE_BYTE=3,t.TEXTURETYPE_SHORT=4,t.TEXTURETYPE_UNSIGNED_SHORT=5,t.TEXTURETYPE_INT=6,t.TEXTURETYPE_UNSIGNED_INTEGER=7,t.TEXTURETYPE_UNSIGNED_SHORT_4_4_4_4=8,t.TEXTURETYPE_UNSIGNED_SHORT_5_5_5_1=9,t.TEXTURETYPE_UNSIGNED_SHORT_5_6_5=10,t.TEXTURETYPE_UNSIGNED_INT_2_10_10_10_REV=11,t.TEXTURETYPE_UNSIGNED_INT_24_8=12,t.TEXTURETYPE_UNSIGNED_INT_10F_11F_11F_REV=13,t.TEXTURETYPE_UNSIGNED_INT_5_9_9_9_REV=14,t.TEXTURETYPE_FLOAT_32_UNSIGNED_INT_24_8_REV=15,t.TEXTURE_NEAREST_SAMPLINGMODE=1,t.TEXTURE_BILINEAR_SAMPLINGMODE=2,t.TEXTURE_TRILINEAR_SAMPLINGMODE=3,t.TEXTURE_NEAREST_NEAREST_MIPLINEAR=8,t.TEXTURE_LINEAR_LINEAR_MIPNEAREST=11,t.TEXTURE_LINEAR_LINEAR_MIPLINEAR=3,t.TEXTURE_NEAREST_NEAREST_MIPNEAREST=4,t.TEXTURE_NEAREST_LINEAR_MIPNEAREST=5,t.TEXTURE_NEAREST_LINEAR_MIPLINEAR=6,t.TEXTURE_NEAREST_LINEAR=7,t.TEXTURE_NEAREST_NEAREST=1,t.TEXTURE_LINEAR_NEAREST_MIPNEAREST=9,t.TEXTURE_LINEAR_NEAREST_MIPLINEAR=10,t.TEXTURE_LINEAR_LINEAR=2,t.TEXTURE_LINEAR_NEAREST=12,t.TEXTURE_EXPLICIT_MODE=0,t.TEXTURE_SPHERICAL_MODE=1,t.TEXTURE_PLANAR_MODE=2,t.TEXTURE_CUBIC_MODE=3,t.TEXTURE_PROJECTION_MODE=4,t.TEXTURE_SKYBOX_MODE=5,t.TEXTURE_INVCUBIC_MODE=6,t.TEXTURE_EQUIRECTANGULAR_MODE=7,t.TEXTURE_FIXED_EQUIRECTANGULAR_MODE=8,t.TEXTURE_FIXED_EQUIRECTANGULAR_MIRRORED_MODE=9,t.SCALEMODE_FLOOR=1,t.SCALEMODE_NEAREST=2,t.SCALEMODE_CEILING=3,t._RescalePostProcessFactory=null,t}(h.a)},function(e,t,i){"use strict";i.d(t,"a",(function(){return r}));var r=function(){function e(){}return Object.defineProperty(e,"LastCreatedEngine",{get:function(){return 0===this.Instances.length?null:this.Instances[this.Instances.length-1]},enumerable:!1,configurable:!0}),Object.defineProperty(e,"LastCreatedScene",{get:function(){return this._LastCreatedScene},enumerable:!1,configurable:!0}),e.Instances=new Array,e._LastCreatedScene=null,e.UseFallbackTexture=!0,e.FallbackTexture="",e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return r}));var r=function(){function e(){}return e.IsWindowObjectExist=function(){return"undefined"!=typeof window},e.IsNavigatorAvailable=function(){return"undefined"!=typeof navigator},e.IsDocumentAvailable=function(){return"undefined"!=typeof document},e.GetDOMTextContent=function(e){for(var t="",i=e.firstChild;i;)3===i.nodeType&&(t+=i.textContent),i=i.nextSibling;return t},e}()},function(e,t,i){"use strict";i.r(t),i.d(t,"Scene",(function(){return B}));var r=i(1),n=i(12),o=i(36),s=i(4),a=i(29),h=function(){function e(){this._count=0,this._data={}}return e.prototype.copyFrom=function(e){var t=this;this.clear(),e.forEach((function(e,i){return t.add(e,i)}))},e.prototype.get=function(e){var t=this._data[e];if(void 0!==t)return t},e.prototype.getOrAddWithFactory=function(e,t){var i=this.get(e);return void 0!==i||(i=t(e))&&this.add(e,i),i},e.prototype.getOrAdd=function(e,t){var i=this.get(e);return void 0!==i?i:(this.add(e,t),t)},e.prototype.contains=function(e){return void 0!==this._data[e]},e.prototype.add=function(e,t){return void 0===this._data[e]&&(this._data[e]=t,++this._count,!0)},e.prototype.set=function(e,t){return void 0!==this._data[e]&&(this._data[e]=t,!0)},e.prototype.getAndRemove=function(e){var t=this.get(e);return void 0!==t?(delete this._data[e],--this._count,t):null},e.prototype.remove=function(e){return!!this.contains(e)&&(delete this._data[e],--this._count,!0)},e.prototype.clear=function(){this._data={},this._count=0},Object.defineProperty(e.prototype,"count",{get:function(){return this._count},enumerable:!1,configurable:!0}),e.prototype.forEach=function(e){for(var t in this._data){e(t,this._data[t])}},e.prototype.first=function(e){for(var t in this._data){var i=e(t,this._data[t]);if(i)return i}return null},e}(),l=i(22),c=i(0),u=i(40),f=i(48),d=i(21),p=function(){function e(){this.rootNodes=new Array,this.cameras=new Array,this.lights=new Array,this.meshes=new Array,this.skeletons=new Array,this.particleSystems=new Array,this.animations=[],this.animationGroups=new Array,this.multiMaterials=new Array,this.materials=new Array,this.morphTargetManagers=new Array,this.geometries=new Array,this.transformNodes=new Array,this.actionManagers=new Array,this.textures=new Array,this._environmentTexture=null,this.postProcesses=new Array}return e.AddParser=function(e,t){this._BabylonFileParsers[e]=t},e.GetParser=function(e){return this._BabylonFileParsers[e]?this._BabylonFileParsers[e]:null},e.AddIndividualParser=function(e,t){this._IndividualBabylonFileParsers[e]=t},e.GetIndividualParser=function(e){return this._IndividualBabylonFileParsers[e]?this._IndividualBabylonFileParsers[e]:null},e.Parse=function(e,t,i,r){for(var n in this._BabylonFileParsers)this._BabylonFileParsers.hasOwnProperty(n)&&this._BabylonFileParsers[n](e,t,i,r)},Object.defineProperty(e.prototype,"environmentTexture",{get:function(){return this._environmentTexture},set:function(e){this._environmentTexture=e},enumerable:!1,configurable:!0}),e.prototype.getNodes=function(){var e=new Array;return e=(e=(e=(e=e.concat(this.meshes)).concat(this.lights)).concat(this.cameras)).concat(this.transformNodes),this.skeletons.forEach((function(t){return e=e.concat(t.bones)})),e},e._BabylonFileParsers={},e._IndividualBabylonFileParsers={},e}(),_=i(59),g=i(63),m=i(44),v=i(43),b=function(){function e(e,t,i,r,n,o){this.source=e,this.pointerX=t,this.pointerY=i,this.meshUnderPointer=r,this.sourceEvent=n,this.additionalData=o}return e.CreateNew=function(t,i,r){var n=t.getScene();return new e(t,n.pointerX,n.pointerY,n.meshUnderPointer||t,i,r)},e.CreateNewFromSprite=function(t,i,r,n){return new e(t,i.pointerX,i.pointerY,i.meshUnderPointer,r,n)},e.CreateNewFromScene=function(t,i){return new e(null,t.pointerX,t.pointerY,t.meshUnderPointer,i)},e.CreateNewFromPrimitive=function(t,i,r,n){return new e(t,i.x,i.y,null,r,n)},e}(),y=i(66),T=i(74),x=i(23),E=i(27),A=i(11),M=i(26),S=i(8),O=i(10),P=function(){function e(){this.hoverCursor="",this.actions=new Array,this.isRecursive=!1}return Object.defineProperty(e,"HasTriggers",{get:function(){for(var t in e.Triggers)if(e.Triggers.hasOwnProperty(t))return!0;return!1},enumerable:!1,configurable:!0}),Object.defineProperty(e,"HasPickTriggers",{get:function(){for(var t in e.Triggers)if(e.Triggers.hasOwnProperty(t)){var i=parseInt(t);if(i>=1&&i<=7)return!0}return!1},enumerable:!1,configurable:!0}),e.HasSpecificTrigger=function(t){for(var i in e.Triggers){if(e.Triggers.hasOwnProperty(i))if(parseInt(i)===t)return!0}return!1},e.Triggers={},e}(),C=i(46),I=function(){function e(){this._singleClick=!1,this._doubleClick=!1,this._hasSwiped=!1,this._ignore=!1}return Object.defineProperty(e.prototype,"singleClick",{get:function(){return this._singleClick},set:function(e){this._singleClick=e},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"doubleClick",{get:function(){return this._doubleClick},set:function(e){this._doubleClick=e},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"hasSwiped",{get:function(){return this._hasSwiped},set:function(e){this._hasSwiped=e},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"ignore",{get:function(){return this._ignore},set:function(e){this._ignore=e},enumerable:!1,configurable:!0}),e}(),R=function(){function e(e){this._alreadyAttached=!1,this._wheelEventName="",this._meshPickProceed=!1,this._currentPickResult=null,this._previousPickResult=null,this._totalPointersPressed=0,this._doubleClickOccured=!1,this._pointerX=0,this._pointerY=0,this._startingPointerPosition=new c.d(0,0),this._previousStartingPointerPosition=new c.d(0,0),this._startingPointerTime=0,this._previousStartingPointerTime=0,this._pointerCaptures={},this._meshUnderPointerId=[],this._keyboardIsAttached=!1,this._scene=e}return Object.defineProperty(e.prototype,"meshUnderPointer",{get:function(){return this._pointerOverMesh},enumerable:!1,configurable:!0}),e.prototype.getMeshUnderPointerByPointerId=function(e){return this._meshUnderPointerId[e]},Object.defineProperty(e.prototype,"unTranslatedPointer",{get:function(){return new c.d(this._unTranslatedPointerX,this._unTranslatedPointerY)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"pointerX",{get:function(){return this._pointerX},set:function(e){this._pointerX=e},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"pointerY",{get:function(){return this._pointerY},set:function(e){this._pointerY=e},enumerable:!1,configurable:!0}),e.prototype._updatePointerPosition=function(e){var t=this._scene.getEngine().getInputElementClientRect();t&&(this._pointerX=e.clientX-t.left,this._pointerY=e.clientY-t.top,this._unTranslatedPointerX=this._pointerX,this._unTranslatedPointerY=this._pointerY)},e.prototype._processPointerMove=function(e,t){var i=this._scene,r=i.getEngine(),n=r.getInputElement();if(n){n.tabIndex=r.canvasTabIndex,i.doNotHandleCursors||(n.style.cursor=i.defaultCursor);var o=!!(e&&e.hit&&e.pickedMesh);o?(i.setPointerOverMesh(e.pickedMesh,t.pointerId),this._pointerOverMesh&&this._pointerOverMesh.actionManager&&this._pointerOverMesh.actionManager.hasPointerTriggers&&(i.doNotHandleCursors||(this._pointerOverMesh.actionManager.hoverCursor?n.style.cursor=this._pointerOverMesh.actionManager.hoverCursor:n.style.cursor=i.hoverCursor))):i.setPointerOverMesh(null,t.pointerId);for(var s=0,a=i._pointerMoveStage;se.LongPressDelay&&!r._isPointerSwiping()&&(r._startingPointerTime=0,o.processTrigger(8,b.CreateNew(t.pickedMesh,i)))}),e.LongPressDelay)}}else for(var s=0,a=n._pointerDownStage;se.DragMovementThreshold||Math.abs(this._startingPointerPosition.y-this._pointerY)>e.DragMovementThreshold},e.prototype.simulatePointerUp=function(e,t,i){var r=new PointerEvent("pointerup",t),n=new I;i?n.doubleClick=!0:n.singleClick=!0,this._checkPrePointerObservable(e,r,O.a.POINTERUP)||this._processPointerUp(e,r,n)},e.prototype._processPointerUp=function(e,t,i){var r=this._scene;if(e&&e&&e.pickedMesh){if(this._pickedUpMesh=e.pickedMesh,this._pickedDownMesh===this._pickedUpMesh&&(r.onPointerPick&&r.onPointerPick(t,e),i.singleClick&&!i.ignore&&r.onPointerObservable.hasObservers())){var n=O.a.POINTERPICK,o=new O.b(n,t,e);this._setRayOnPointerInfo(o),r.onPointerObservable.notifyObservers(o,n)}var s=e.pickedMesh._getActionManagerForTrigger();if(s&&!i.ignore){s.processTrigger(7,b.CreateNew(e.pickedMesh,t)),!i.hasSwiped&&i.singleClick&&s.processTrigger(1,b.CreateNew(e.pickedMesh,t));var a=e.pickedMesh._getActionManagerForTrigger(6);i.doubleClick&&a&&a.processTrigger(6,b.CreateNew(e.pickedMesh,t))}}else if(!i.ignore)for(var h=0,l=r._pointerUpStage;he.DoubleClickDelay&&!s._doubleClickOccured||t!==s._previousButtonPressed)&&(s._doubleClickOccured=!1,i.singleClick=!0,i.ignore=!1,r(i,s._currentPickResult))},this._initClickEvent=function(t,i,r,n){var o=new I;s._currentPickResult=null;var a=null,h=t.hasSpecificMask(O.a.POINTERPICK)||i.hasSpecificMask(O.a.POINTERPICK)||t.hasSpecificMask(O.a.POINTERTAP)||i.hasSpecificMask(O.a.POINTERTAP)||t.hasSpecificMask(O.a.POINTERDOUBLETAP)||i.hasSpecificMask(O.a.POINTERDOUBLETAP);!h&&P&&(a=s._initActionManager(a,o))&&(h=a.hasPickTriggers);var l=!1;if(h){var c=r.button;if(o.hasSwiped=s._isPointerSwiping(),!o.hasSwiped){var u=!e.ExclusiveDoubleClickMode;u||(u=!t.hasSpecificMask(O.a.POINTERDOUBLETAP)&&!i.hasSpecificMask(O.a.POINTERDOUBLETAP))&&!P.HasSpecificTrigger(6)&&(a=s._initActionManager(a,o))&&(u=!a.hasSpecificTrigger(6)),u?(Date.now()-s._previousStartingPointerTime>e.DoubleClickDelay||c!==s._previousButtonPressed)&&(o.singleClick=!0,n(o,s._currentPickResult),l=!0):(s._previousDelayedSimpleClickTimeout=s._delayedSimpleClickTimeout,s._delayedSimpleClickTimeout=window.setTimeout(s._delayedSimpleClick.bind(s,c,o,n),e.DoubleClickDelay));var f=t.hasSpecificMask(O.a.POINTERDOUBLETAP)||i.hasSpecificMask(O.a.POINTERDOUBLETAP);!f&&P.HasSpecificTrigger(6)&&(a=s._initActionManager(a,o))&&(f=a.hasSpecificTrigger(6)),f&&(c===s._previousButtonPressed&&Date.now()-s._previousStartingPointerTime0){for(var e=0,t=this._transientComponents;e0)return!1;for(e=0;e0,n=0,o=this._isReadyForMeshStage;n0)for(var s=0,a=this.activeCameras;s0},enumerable:!1,configurable:!0}),t.prototype.executeWhenReady=function(e){var t=this;this.onReadyObservable.add(e),-1===this._executeWhenReadyTimeoutId&&(this._executeWhenReadyTimeoutId=setTimeout((function(){t._checkIsReady()}),150))},t.prototype.whenReadyAsync=function(){var e=this;return new Promise((function(t){e.executeWhenReady((function(){t()}))}))},t.prototype._checkIsReady=function(){var e=this;return this._registerTransientComponents(),this.isReady()?(this.onReadyObservable.notifyObservers(this),this.onReadyObservable.clear(),void(this._executeWhenReadyTimeoutId=-1)):this._isDisposed?(this.onReadyObservable.clear(),void(this._executeWhenReadyTimeoutId=-1)):void(this._executeWhenReadyTimeoutId=setTimeout((function(){e._checkIsReady()}),150))},Object.defineProperty(t.prototype,"animatables",{get:function(){return this._activeAnimatables},enumerable:!1,configurable:!0}),t.prototype.resetLastAnimationTimeFrame=function(){this._animationTimeLast=o.a.Now},t.prototype.getViewMatrix=function(){return this._viewMatrix},t.prototype.getProjectionMatrix=function(){return this._projectionMatrix},t.prototype.getTransformMatrix=function(){return this._transformMatrix},t.prototype.setTransformMatrix=function(e,t,i,r){this._viewUpdateFlag===e.updateFlag&&this._projectionUpdateFlag===t.updateFlag||(this._viewUpdateFlag=e.updateFlag,this._projectionUpdateFlag=t.updateFlag,this._viewMatrix=e,this._projectionMatrix=t,this._viewMatrix.multiplyToRef(this._projectionMatrix,this._transformMatrix),this._frustumPlanes?L.a.GetPlanesToRef(this._transformMatrix,this._frustumPlanes):this._frustumPlanes=L.a.GetPlanes(this._transformMatrix),this._multiviewSceneUbo&&this._multiviewSceneUbo.useUbo?this._updateMultiviewUbo(i,r):this._sceneUbo.useUbo&&(this._sceneUbo.updateMatrix("viewProjection",this._transformMatrix),this._sceneUbo.updateMatrix("view",this._viewMatrix),this._sceneUbo.update()))},t.prototype.getSceneUniformBuffer=function(){return this._multiviewSceneUbo?this._multiviewSceneUbo:this._sceneUbo},t.prototype.getUniqueId=function(){return F.UniqueId},t.prototype.addMesh=function(e,t){var i=this;void 0===t&&(t=!1),this._blockEntityCollection||(this.meshes.push(e),e._resyncLightSources(),e.parent||e._addToSceneRootNodes(),this.onNewMeshAddedObservable.notifyObservers(e),t&&e.getChildMeshes().forEach((function(e){i.addMesh(e)})))},t.prototype.removeMesh=function(e,t){var i=this;void 0===t&&(t=!1);var r=this.meshes.indexOf(e);return-1!==r&&(this.meshes[r]=this.meshes[this.meshes.length-1],this.meshes.pop(),e.parent||e._removeFromSceneRootNodes()),this.onMeshRemovedObservable.notifyObservers(e),t&&e.getChildMeshes().forEach((function(e){i.removeMesh(e)})),r},t.prototype.addTransformNode=function(e){this._blockEntityCollection||(e._indexInSceneTransformNodesArray=this.transformNodes.length,this.transformNodes.push(e),e.parent||e._addToSceneRootNodes(),this.onNewTransformNodeAddedObservable.notifyObservers(e))},t.prototype.removeTransformNode=function(e){var t=e._indexInSceneTransformNodesArray;if(-1!==t){if(t!==this.transformNodes.length-1){var i=this.transformNodes[this.transformNodes.length-1];this.transformNodes[t]=i,i._indexInSceneTransformNodesArray=t}e._indexInSceneTransformNodesArray=-1,this.transformNodes.pop(),e.parent||e._removeFromSceneRootNodes()}return this.onTransformNodeRemovedObservable.notifyObservers(e),t},t.prototype.removeSkeleton=function(e){var t=this.skeletons.indexOf(e);return-1!==t&&(this.skeletons.splice(t,1),this.onSkeletonRemovedObservable.notifyObservers(e)),t},t.prototype.removeMorphTargetManager=function(e){var t=this.morphTargetManagers.indexOf(e);return-1!==t&&this.morphTargetManagers.splice(t,1),t},t.prototype.removeLight=function(e){var t=this.lights.indexOf(e);if(-1!==t){for(var i=0,r=this.meshes;i0?this.activeCamera=this.cameras[0]:this.activeCamera=null),this.onCameraRemovedObservable.notifyObservers(e),t},t.prototype.removeParticleSystem=function(e){var t=this.particleSystems.indexOf(e);return-1!==t&&this.particleSystems.splice(t,1),t},t.prototype.removeAnimation=function(e){var t=this.animations.indexOf(e);return-1!==t&&this.animations.splice(t,1),t},t.prototype.stopAnimation=function(e,t,i){},t.prototype.removeAnimationGroup=function(e){var t=this.animationGroups.indexOf(e);return-1!==t&&this.animationGroups.splice(t,1),t},t.prototype.removeMultiMaterial=function(e){var t=this.multiMaterials.indexOf(e);return-1!==t&&this.multiMaterials.splice(t,1),this.onMultiMaterialRemovedObservable.notifyObservers(e),t},t.prototype.removeMaterial=function(e){var t=e._indexInSceneMaterialArray;if(-1!==t&&t=0;t--)if(this.materials[t].id===e)return this.materials[t];return null},t.prototype.getMaterialByName=function(e){for(var t=0;t=0;t--)if(this.meshes[t].id===e)return this.meshes[t];return null},t.prototype.getLastEntryByID=function(e){var t;for(t=this.meshes.length-1;t>=0;t--)if(this.meshes[t].id===e)return this.meshes[t];for(t=this.transformNodes.length-1;t>=0;t--)if(this.transformNodes[t].id===e)return this.transformNodes[t];for(t=this.cameras.length-1;t>=0;t--)if(this.cameras[t].id===e)return this.cameras[t];for(t=this.lights.length-1;t>=0;t--)if(this.lights[t].id===e)return this.lights[t];return null},t.prototype.getNodeByID=function(e){var t=this.getMeshByID(e);if(t)return t;var i=this.getTransformNodeByID(e);if(i)return i;var r=this.getLightByID(e);if(r)return r;var n=this.getCameraByID(e);if(n)return n;var o=this.getBoneByID(e);return o||null},t.prototype.getNodeByName=function(e){var t=this.getMeshByName(e);if(t)return t;var i=this.getTransformNodeByName(e);if(i)return i;var r=this.getLightByName(e);if(r)return r;var n=this.getCameraByName(e);if(n)return n;var o=this.getBoneByName(e);return o||null},t.prototype.getMeshByName=function(e){for(var t=0;t=0;t--)if(this.skeletons[t].id===e)return this.skeletons[t];return null},t.prototype.getSkeletonByUniqueId=function(e){for(var t=0;t0&&0!=(a.layerMask&this.activeCamera.layerMask)&&(this._skipFrustumClipping||a.alwaysSelectAsActiveMesh||a.isInFrustum(this._frustumPlanes)))){this._activeMeshes.push(a),this.activeCamera._activeMeshes.push(a),h!==a&&h._activate(this._renderId,!1);for(var l=0,c=this._preActiveMeshStage;l0)for(var i=this.getActiveSubMeshCandidates(t),r=i.length,n=0;n1)this.activeCamera.outputRenderTarget._bindFrameBuffer();else{var e=this.activeCamera.outputRenderTarget.getInternalTexture();e?this.getEngine().bindFramebuffer(e):A.a.Error("Camera contains invalid customDefaultRenderTarget")}}else this.getEngine().restoreDefaultFramebuffer()},t.prototype._renderForCamera=function(e,t){if(!e||!e._skipRendering){var i=this._engine;if(this._activeCamera=e,!this.activeCamera)throw new Error("Active camera not set");i.setViewport(this.activeCamera.viewport),this.resetCachedMaterial(),this._renderId++,this.getEngine().getCaps().multiview&&e.outputRenderTarget&&e.outputRenderTarget.getViewCount()>1?this.setTransformMatrix(e._rigCameras[0].getViewMatrix(),e._rigCameras[0].getProjectionMatrix(),e._rigCameras[1].getViewMatrix(),e._rigCameras[1].getProjectionMatrix()):this.updateTransformMatrix(),this.onBeforeCameraRenderObservable.notifyObservers(this.activeCamera),this._evaluateActiveMeshes();for(var r=0;r0&&this._renderTargets.concatWithNoDuplicate(e.customRenderTargets),t&&t.customRenderTargets&&t.customRenderTargets.length>0&&this._renderTargets.concatWithNoDuplicate(t.customRenderTargets);for(var s=0,a=this._gatherActiveCameraRenderTargetsStage;s0){n.b.StartPerformanceCounter("Render targets",this._renderTargets.length>0);for(var l=0;l0),this._renderId++}for(var f=0,d=this._cameraDrawRenderTargetStage;f1&&this.getEngine().getCaps().multiview)return this._renderForCamera(e),void this.onAfterRenderCameraObservable.notifyObservers(e);if(e._useMultiviewToSingleView)this._renderMultiviewToSingleView(e);else for(var t=0;t-1&&(13===r.trigger&&r._executeCurrent(b.CreateNew(t,void 0,o)),t.actionManager.hasSpecificTrigger(13,(function(e){var t=e instanceof f.a?e:e.mesh;return o===t}))&&13!==r.trigger||t._intersectionsInProgress.splice(a,1))}}}},t.prototype._advancePhysicsEngineStep=function(e){},t.prototype._animate=function(){},t.prototype.animate=function(){if(this._engine.isDeterministicLockStep()){var e=Math.max(t.MinDeltaTime,Math.min(this._engine.getDeltaTime(),t.MaxDeltaTime))+this._timeAccumulator,i=this._engine.getTimeStep(),r=1e3/i/1e3,n=0,o=this._engine.getLockstepMaxSteps(),s=Math.floor(e/i);for(s=Math.min(s,o);e>0&&n0)for(var o=0;o0),this._intermediateRendering=!0;for(var c=0;c0),this._intermediateRendering=!1,this._renderId++}this.activeCamera=l,this._activeCamera&&this._activeCamera.cameraRigMode!==d.a.RIG_MODE_CUSTOM&&!this.prePass&&this._bindFrameBuffer(),this.onAfterRenderTargetsRenderObservable.notifyObservers(this);for(var f=0,p=this._beforeClearStage;f0)for(o=0;o0&&this._engine.clear(null,!1,!0,!0),this._processSubCameras(this.activeCameras[o]);else{if(!this.activeCamera)throw new Error("No camera defined");this._processSubCameras(this.activeCamera)}this._checkIntersections();for(var m=0,v=this._afterRenderStage;m-1&&this._engine.scenes.splice(n,1),this._engine.wipeCaches(!0),this._isDisposed=!0},Object.defineProperty(t.prototype,"isDisposed",{get:function(){return this._isDisposed},enumerable:!1,configurable:!0}),t.prototype.clearCachedVertexData=function(){for(var e=0;ethis.data.length&&(this.data.length*=2)},e.prototype.forEach=function(e){for(var t=0;tthis.data.length&&(this.data.length=2*(this.length+e.length));for(var t=0;t=this.length?-1:t},e.prototype.contains=function(e){return-1!==this.indexOf(e)},e._GlobalId=0,e}(),o=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t._duplicateId=0,t}return Object(r.c)(t,e),t.prototype.push=function(t){e.prototype.push.call(this,t),t.__smartArrayFlags||(t.__smartArrayFlags={}),t.__smartArrayFlags[this._id]=this._duplicateId},t.prototype.pushNoDuplicate=function(e){return(!e.__smartArrayFlags||e.__smartArrayFlags[this._id]!==this._duplicateId)&&(this.push(e),!0)},t.prototype.reset=function(){e.prototype.reset.call(this),this._duplicateId++},t.prototype.concatWithNoDuplicate=function(e){if(0!==e.length){this.length+e.length>this.data.length&&(this.data.length=2*(this.length+e.length));for(var t=0;te.zIndex){this._children.splice(i,0,e),t=!0;break}t||this._children.push(e),e.parent=this,this._markAsDirty()},t.prototype._offsetLeft=function(t){e.prototype._offsetLeft.call(this,t);for(var i=0,r=this._children;i=0&&(r+=this.paddingLeftInPixels+this.paddingRightInPixels,this.width!==r+"px"&&(this.width=r+"px",this._rebuildLayout=!0)),this.adaptHeightToChildren&&o>=0&&(o+=this.paddingTopInPixels+this.paddingBottomInPixels,this.height!==o+"px"&&(this.height=o+"px",this._rebuildLayout=!0)),this._postMeasure()}i++}while(this._rebuildLayout&&i=3&&this.logLayoutCycleErrors&&n.a.Error("Layout cycle detected in GUI (Container name="+this.name+", uniqueId="+this.uniqueId+")"),t.restore(),this._isDirty&&(this.invalidateRect(),this._isDirty=!1),!0},t.prototype._postMeasure=function(){},t.prototype._draw=function(e,t){this._localDraw(e),this.clipChildren&&this._clipForChildren(e);for(var i=0,r=this._children;i=0;l--){var c=this._children[l];if(c._processPicking(t,i,r,n,o,s,a,h))return c.hoverCursor&&this._host._changeCursor(c.hoverCursor),!0}return!!this.isHitTestVisible&&this._processObservables(n,t,i,r,o,s,a,h)},t.prototype._additionalProcessing=function(t,i){e.prototype._additionalProcessing.call(this,t,i),this._measureForChildren.copyFrom(this._currentMeasure)},t.prototype.dispose=function(){e.prototype.dispose.call(this);for(var t=this.children.length-1;t>=0;t--)this.children[t].dispose()},t}(o.a);a.a.RegisteredTypes["BABYLON.GUI.Container"]=h},function(e,t,i){"use strict";i.d(t,"a",(function(){return l}));var r=i(1),n=i(0),o=i(3),s=i(4),a=i(26),h=i(8),l=function(){function e(e,t){void 0===t&&(t=null),this.state="",this.metadata=null,this.reservedDataStore=null,this._doNotSerialize=!1,this._isDisposed=!1,this.animations=new Array,this._ranges={},this.onReady=null,this._isEnabled=!0,this._isParentEnabled=!0,this._isReady=!0,this._currentRenderId=-1,this._parentUpdateId=-1,this._childUpdateId=-1,this._waitingParentId=null,this._cache={},this._parentNode=null,this._children=null,this._worldMatrix=n.a.Identity(),this._worldMatrixDeterminant=0,this._worldMatrixDeterminantIsDirty=!0,this._sceneRootNodesIndex=-1,this._animationPropertiesOverride=null,this._isNode=!0,this.onDisposeObservable=new s.a,this._onDisposeObserver=null,this._behaviors=new Array,this.name=e,this.id=e,this._scene=t||a.a.LastCreatedScene,this.uniqueId=this._scene.getUniqueId(),this._initCache()}return e.AddNodeConstructor=function(e,t){this._NodeConstructors[e]=t},e.Construct=function(e,t,i,r){var n=this._NodeConstructors[e];return n?n(t,i,r):null},Object.defineProperty(e.prototype,"doNotSerialize",{get:function(){return!!this._doNotSerialize||!!this._parentNode&&this._parentNode.doNotSerialize},set:function(e){this._doNotSerialize=e},enumerable:!1,configurable:!0}),e.prototype.isDisposed=function(){return this._isDisposed},Object.defineProperty(e.prototype,"parent",{get:function(){return this._parentNode},set:function(e){if(this._parentNode!==e){var t=this._parentNode;if(this._parentNode&&void 0!==this._parentNode._children&&null!==this._parentNode._children){var i=this._parentNode._children.indexOf(this);-1!==i&&this._parentNode._children.splice(i,1),e||this._isDisposed||this._addToSceneRootNodes()}this._parentNode=e,this._parentNode&&(void 0!==this._parentNode._children&&null!==this._parentNode._children||(this._parentNode._children=new Array),this._parentNode._children.push(this),t||this._removeFromSceneRootNodes()),this._syncParentEnabledState()}},enumerable:!1,configurable:!0}),e.prototype._addToSceneRootNodes=function(){-1===this._sceneRootNodesIndex&&(this._sceneRootNodesIndex=this._scene.rootNodes.length,this._scene.rootNodes.push(this))},e.prototype._removeFromSceneRootNodes=function(){if(-1!==this._sceneRootNodesIndex){var e=this._scene.rootNodes,t=e.length-1;e[this._sceneRootNodesIndex]=e[t],e[this._sceneRootNodesIndex]._sceneRootNodesIndex=this._sceneRootNodesIndex,this._scene.rootNodes.pop(),this._sceneRootNodesIndex=-1}},Object.defineProperty(e.prototype,"animationPropertiesOverride",{get:function(){return this._animationPropertiesOverride?this._animationPropertiesOverride:this._scene.animationPropertiesOverride},set:function(e){this._animationPropertiesOverride=e},enumerable:!1,configurable:!0}),e.prototype.getClassName=function(){return"Node"},Object.defineProperty(e.prototype,"onDispose",{set:function(e){this._onDisposeObserver&&this.onDisposeObservable.remove(this._onDisposeObserver),this._onDisposeObserver=this.onDisposeObservable.add(e)},enumerable:!1,configurable:!0}),e.prototype.getScene=function(){return this._scene},e.prototype.getEngine=function(){return this._scene.getEngine()},e.prototype.addBehavior=function(e,t){var i=this;return void 0===t&&(t=!1),-1!==this._behaviors.indexOf(e)||(e.init(),this._scene.isLoading&&!t?this._scene.onDataLoadedObservable.addOnce((function(){e.attach(i)})):e.attach(this),this._behaviors.push(e)),this},e.prototype.removeBehavior=function(e){var t=this._behaviors.indexOf(e);return-1===t||(this._behaviors[t].detach(),this._behaviors.splice(t,1)),this},Object.defineProperty(e.prototype,"behaviors",{get:function(){return this._behaviors},enumerable:!1,configurable:!0}),e.prototype.getBehaviorByName=function(e){for(var t=0,i=this._behaviors;t=e||-1!==i.indexOf("file:")?-1:Math.pow(2,n)*t}},e}(),l=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return Object(r.c)(t,e),t._setPrototypeOf=Object.setPrototypeOf||function(e,t){return e.__proto__=t,e},t}(Error),c=i(39),u=i(20),f=i(68),d=function(e){function t(i,r){var o=e.call(this,i)||this;return o.name="LoadFileError",l._setPrototypeOf(o,t.prototype),r instanceof n.a?o.request=r:o.file=r,o}return Object(r.c)(t,e),t}(l),p=function(e){function t(i,r){var n=e.call(this,i)||this;return n.request=r,n.name="RequestFileError",l._setPrototypeOf(n,t.prototype),n}return Object(r.c)(t,e),t}(l),_=function(e){function t(i,r){var n=e.call(this,i)||this;return n.file=r,n.name="ReadFileError",l._setPrototypeOf(n,t.prototype),n}return Object(r.c)(t,e),t}(l),g=function(){function e(){}return e._CleanUrl=function(e){return e=e.replace(/#/gm,"%23")},e.SetCorsBehavior=function(t,i){if((!t||0!==t.indexOf("data:"))&&e.CorsBehavior)if("string"==typeof e.CorsBehavior||this.CorsBehavior instanceof String)i.crossOrigin=e.CorsBehavior;else{var r=e.CorsBehavior(t);r&&(i.crossOrigin=r)}},e.LoadImage=function(t,i,r,n,o){var s;void 0===o&&(o="");var h=!1;if(t instanceof ArrayBuffer||ArrayBuffer.isView(t)?"undefined"!=typeof Blob?(s=URL.createObjectURL(new Blob([t],{type:o})),h=!0):s="data:"+o+";base64,"+c.a.EncodeArrayBufferToBase64(t):t instanceof Blob?(s=URL.createObjectURL(t),h=!0):(s=e._CleanUrl(t),s=e.PreprocessUrl(t)),"undefined"==typeof Image)return e.LoadFile(s,(function(e){createImageBitmap(new Blob([e],{type:o})).then((function(e){i(e),h&&URL.revokeObjectURL(s)})).catch((function(e){r&&r("Error while trying to load image: "+t,e)}))}),void 0,n||void 0,!0,(function(e,i){r&&r("Error while trying to load image: "+t,i)})),null;var l=new Image;e.SetCorsBehavior(s,l);var u=function(){l.removeEventListener("load",u),l.removeEventListener("error",f),i(l),h&&l.src&&URL.revokeObjectURL(l.src)},f=function(e){if(l.removeEventListener("load",u),l.removeEventListener("error",f),r){var i=t.toString();r("Error while trying to load image: "+(i.length<32?i:i.slice(0,32)+"..."),e)}h&&l.src&&URL.revokeObjectURL(l.src)};l.addEventListener("load",u),l.addEventListener("error",f);var d=function(){l.src=s};if("data:"!==s.substr(0,5)&&n&&n.enableTexturesOffline)n.open((function(){n&&n.loadImage(s,l)}),d);else{if(-1!==s.indexOf("file:")){var p=decodeURIComponent(s.substring(5).toLowerCase());if(a.FilesToLoad[p]){try{var _;try{_=URL.createObjectURL(a.FilesToLoad[p])}catch(e){_=URL.createObjectURL(a.FilesToLoad[p])}l.src=_,h=!0}catch(e){l.src=""}return l}}d()}return l},e.ReadFile=function(e,t,i,r,n){var o=new FileReader,a={onCompleteObservable:new s.a,abort:function(){return o.abort()}};return o.onloadend=function(e){return a.onCompleteObservable.notifyObservers(a)},n&&(o.onerror=function(t){n(new _("Unable to read "+e.name,e))}),o.onload=function(e){t(e.target.result)},i&&(o.onprogress=i),r?o.readAsArrayBuffer(e):o.readAsText(e),a},e.LoadFile=function(t,i,r,n,o,s){if(-1!==t.indexOf("file:")){var h=decodeURIComponent(t.substring(5).toLowerCase());0===h.indexOf("./")&&(h=h.substring(2));var l=a.FilesToLoad[h];if(l)return e.ReadFile(l,i,r,o,s?function(e){return s(void 0,new d(e.message,e.file))}:void 0)}return e.RequestFile(t,(function(e,t){i(e,t?t.responseURL:void 0)}),r,n,o,s?function(e){s(e.request,new d(e.message,e.request))}:void 0)},e.RequestFile=function(t,i,r,a,h,l,c){t=e._CleanUrl(t),t=e.PreprocessUrl(t);var u=e.BaseUrl+t,f=!1,d={onCompleteObservable:new s.a,abort:function(){return f=!0}},_=function(){var t=new n.a,s=null;d.abort=function(){f=!0,t.readyState!==(XMLHttpRequest.DONE||4)&&t.abort(),null!==s&&(clearTimeout(s),s=null)};var a=function(_){t.open("GET",u),c&&c(t),h&&(t.responseType="arraybuffer"),r&&t.addEventListener("progress",r);var g=function(){t.removeEventListener("loadend",g),d.onCompleteObservable.notifyObservers(d),d.onCompleteObservable.clear()};t.addEventListener("loadend",g);var m=function(){if(!f&&t.readyState===(XMLHttpRequest.DONE||4)){if(t.removeEventListener("readystatechange",m),t.status>=200&&t.status<300||0===t.status&&(!o.a.IsWindowObjectExist()||e.IsFileURL()))return void i(h?t.response:t.responseText,t);var r=e.DefaultRetryStrategy;if(r){var c=r(u,t,_);if(-1!==c)return t.removeEventListener("loadend",g),t=new n.a,void(s=setTimeout((function(){return a(_+1)}),c))}var d=new p("Error status: "+t.status+" "+t.statusText+" - Unable to load "+u,t);l&&l(d)}};t.addEventListener("readystatechange",m),t.send()};a(0)};if(a&&a.enableSceneOffline){var g=function(e){e&&e.status>400?l&&l(e):_()};a.open((function(){a&&a.loadFile(e.BaseUrl+t,(function(e){f||i(e),d.onCompleteObservable.notifyObservers(d)}),r?function(e){f||r(e)}:void 0,g,h)}),g)}else _();return d},e.IsFileURL=function(){return"undefined"!=typeof location&&"file:"===location.protocol},e.DefaultRetryStrategy=h.ExponentialBackoff(),e.BaseUrl="",e.CorsBehavior="anonymous",e.PreprocessUrl=function(e){return e},e}();u.a._FileToolsLoadImage=g.LoadImage.bind(g),u.a._FileToolsLoadFile=g.LoadFile.bind(g),f.a._FileToolsLoadFile=g.LoadFile.bind(g)},function(e,t,i){"use strict";i.d(t,"c",(function(){return r})),i.d(t,"a",(function(){return s})),i.d(t,"b",(function(){return o}));var r,n=i(0);!function(e){e[e.LOCAL=0]="LOCAL",e[e.WORLD=1]="WORLD",e[e.BONE=2]="BONE"}(r||(r={}));var o,s=function(){function e(){}return e.X=new n.e(1,0,0),e.Y=new n.e(0,1,0),e.Z=new n.e(0,0,1),e}();!function(e){e[e.X=0]="X",e[e.Y=1]="Y",e[e.Z=2]="Z"}(o||(o={}))},function(e,t,i){"use strict";i.d(t,"a",(function(){return n}));var r=i(27),n=function(){function e(){}return Object.defineProperty(e,"Now",{get:function(){return r.a.IsWindowObjectExist()&&window.performance&&window.performance.now?window.performance.now():Date.now()},enumerable:!1,configurable:!0}),e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return f}));var r=i(31),n=i(0),o=i(16),s=function(){function e(e,t,i){this.vectors=r.a.BuildArray(8,n.e.Zero),this.center=n.e.Zero(),this.centerWorld=n.e.Zero(),this.extendSize=n.e.Zero(),this.extendSizeWorld=n.e.Zero(),this.directions=r.a.BuildArray(3,n.e.Zero),this.vectorsWorld=r.a.BuildArray(8,n.e.Zero),this.minimumWorld=n.e.Zero(),this.maximumWorld=n.e.Zero(),this.minimum=n.e.Zero(),this.maximum=n.e.Zero(),this.reConstruct(e,t,i)}return e.prototype.reConstruct=function(e,t,i){var r=e.x,o=e.y,s=e.z,a=t.x,h=t.y,l=t.z,c=this.vectors;this.minimum.copyFromFloats(r,o,s),this.maximum.copyFromFloats(a,h,l),c[0].copyFromFloats(r,o,s),c[1].copyFromFloats(a,h,l),c[2].copyFromFloats(a,o,s),c[3].copyFromFloats(r,h,s),c[4].copyFromFloats(r,o,l),c[5].copyFromFloats(a,h,s),c[6].copyFromFloats(r,h,l),c[7].copyFromFloats(a,o,l),t.addToRef(e,this.center).scaleInPlace(.5),t.subtractToRef(e,this.extendSize).scaleInPlace(.5),this._worldMatrix=i||n.a.IdentityReadOnly,this._update(this._worldMatrix)},e.prototype.scale=function(t){var i=e.TmpVector3,r=this.maximum.subtractToRef(this.minimum,i[0]),n=r.length();r.normalizeFromLength(n);var o=n*t,s=r.scaleInPlace(.5*o),a=this.center.subtractToRef(s,i[1]),h=this.center.addToRef(s,i[2]);return this.reConstruct(a,h,this._worldMatrix),this},e.prototype.getWorldMatrix=function(){return this._worldMatrix},e.prototype._update=function(e){var t=this.minimumWorld,i=this.maximumWorld,r=this.directions,o=this.vectorsWorld,s=this.vectors;if(e.isIdentity()){t.copyFrom(this.minimum),i.copyFrom(this.maximum);for(a=0;a<8;++a)o[a].copyFrom(s[a]);this.extendSizeWorld.copyFrom(this.extendSize),this.centerWorld.copyFrom(this.center)}else{t.setAll(Number.MAX_VALUE),i.setAll(-Number.MAX_VALUE);for(var a=0;a<8;++a){var h=o[a];n.e.TransformCoordinatesToRef(s[a],e,h),t.minimizeInPlace(h),i.maximizeInPlace(h)}i.subtractToRef(t,this.extendSizeWorld).scaleInPlace(.5),i.addToRef(t,this.centerWorld).scaleInPlace(.5)}n.e.FromArrayToRef(e.m,0,r[0]),n.e.FromArrayToRef(e.m,4,r[1]),n.e.FromArrayToRef(e.m,8,r[2]),this._worldMatrix=e},e.prototype.isInFrustum=function(t){return e.IsInFrustum(this.vectorsWorld,t)},e.prototype.isCompletelyInFrustum=function(t){return e.IsCompletelyInFrustum(this.vectorsWorld,t)},e.prototype.intersectsPoint=function(e){var t=this.minimumWorld,i=this.maximumWorld,r=t.x,n=t.y,s=t.z,a=i.x,h=i.y,l=i.z,c=e.x,u=e.y,f=e.z,d=-o.a;return!(a-cc-r)&&(!(h-uu-n)&&!(l-ff-s))},e.prototype.intersectsSphere=function(t){return e.IntersectsSphere(this.minimumWorld,this.maximumWorld,t.centerWorld,t.radiusWorld)},e.prototype.intersectsMinMax=function(e,t){var i=this.minimumWorld,r=this.maximumWorld,n=i.x,o=i.y,s=i.z,a=r.x,h=r.y,l=r.z,c=e.x,u=e.y,f=e.z,d=t.x,p=t.y,_=t.z;return!(ad)&&(!(hp)&&!(l_))},e.Intersects=function(e,t){return e.intersectsMinMax(t.minimumWorld,t.maximumWorld)},e.IntersectsSphere=function(t,i,r,o){var s=e.TmpVector3[0];return n.e.ClampToRef(r,t,i,s),n.e.DistanceSquared(r,s)<=o*o},e.IsCompletelyInFrustum=function(e,t){for(var i=0;i<6;++i)for(var r=t[i],n=0;n<8;++n)if(r.dotCoordinate(e[n])<0)return!1;return!0},e.IsInFrustum=function(e,t){for(var i=0;i<6;++i){for(var r=!0,n=t[i],o=0;o<8;++o)if(n.dotCoordinate(e[o])>=0){r=!1;break}if(r)return!1}return!0},e.TmpVector3=r.a.BuildArray(3,n.e.Zero),e}(),a=function(){function e(e,t,i){this.center=n.e.Zero(),this.centerWorld=n.e.Zero(),this.minimum=n.e.Zero(),this.maximum=n.e.Zero(),this.reConstruct(e,t,i)}return e.prototype.reConstruct=function(e,t,i){this.minimum.copyFrom(e),this.maximum.copyFrom(t);var r=n.e.Distance(e,t);t.addToRef(e,this.center).scaleInPlace(.5),this.radius=.5*r,this._update(i||n.a.IdentityReadOnly)},e.prototype.scale=function(t){var i=this.radius*t,r=e.TmpVector3,n=r[0].setAll(i),o=this.center.subtractToRef(n,r[1]),s=this.center.addToRef(n,r[2]);return this.reConstruct(o,s,this._worldMatrix),this},e.prototype.getWorldMatrix=function(){return this._worldMatrix},e.prototype._update=function(t){if(t.isIdentity())this.centerWorld.copyFrom(this.center),this.radiusWorld=this.radius;else{n.e.TransformCoordinatesToRef(this.center,t,this.centerWorld);var i=e.TmpVector3[0];n.e.TransformNormalFromFloatsToRef(1,1,1,t,i),this.radiusWorld=Math.max(Math.abs(i.x),Math.abs(i.y),Math.abs(i.z))*this.radius}},e.prototype.isInFrustum=function(e){for(var t=this.centerWorld,i=this.radiusWorld,r=0;r<6;r++)if(e[r].dotCoordinate(t)<=-i)return!1;return!0},e.prototype.isCenterInFrustum=function(e){for(var t=this.centerWorld,i=0;i<6;i++)if(e[i].dotCoordinate(t)<0)return!1;return!0},e.prototype.intersectsPoint=function(e){var t=n.e.DistanceSquared(this.centerWorld,e);return!(this.radiusWorld*this.radiusWorldl.max||l.min>h.max)},f=function(){function e(e,t,i){this._isLocked=!1,this.boundingBox=new s(e,t,i),this.boundingSphere=new a(e,t,i)}return e.prototype.reConstruct=function(e,t,i){this.boundingBox.reConstruct(e,t,i),this.boundingSphere.reConstruct(e,t,i)},Object.defineProperty(e.prototype,"minimum",{get:function(){return this.boundingBox.minimum},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"maximum",{get:function(){return this.boundingBox.maximum},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"isLocked",{get:function(){return this._isLocked},set:function(e){this._isLocked=e},enumerable:!1,configurable:!0}),e.prototype.update=function(e){this._isLocked||(this.boundingBox._update(e),this.boundingSphere._update(e))},e.prototype.centerOn=function(t,i){var r=e.TmpVector3[0].copyFrom(t).subtractInPlace(i),n=e.TmpVector3[1].copyFrom(t).addInPlace(i);return this.boundingBox.reConstruct(r,n,this.boundingBox.getWorldMatrix()),this.boundingSphere.reConstruct(r,n,this.boundingBox.getWorldMatrix()),this},e.prototype.scale=function(e){return this.boundingBox.scale(e),this.boundingSphere.scale(e),this},e.prototype.isInFrustum=function(e,t){return void 0===t&&(t=0),!(2!==t&&3!==t||!this.boundingSphere.isCenterInFrustum(e))||!!this.boundingSphere.isInFrustum(e)&&(!(1!==t&&3!==t)||this.boundingBox.isInFrustum(e))},Object.defineProperty(e.prototype,"diagonalLength",{get:function(){var t=this.boundingBox;return t.maximumWorld.subtractToRef(t.minimumWorld,e.TmpVector3[0]).length()},enumerable:!1,configurable:!0}),e.prototype.isCompletelyInFrustum=function(e){return this.boundingBox.isCompletelyInFrustum(e)},e.prototype._checkCollision=function(e){return e._canDoCollision(this.boundingSphere.centerWorld,this.boundingSphere.radiusWorld,this.boundingBox.minimumWorld,this.boundingBox.maximumWorld)},e.prototype.intersectsPoint=function(e){return!!this.boundingSphere.centerWorld&&(!!this.boundingSphere.intersectsPoint(e)&&!!this.boundingBox.intersectsPoint(e))},e.prototype.intersects=function(e,t){if(!a.Intersects(this.boundingSphere,e.boundingSphere))return!1;if(!s.Intersects(this.boundingBox,e.boundingBox))return!1;if(!t)return!0;var i=this.boundingBox,r=e.boundingBox;return!!u(i.directions[0],i,r)&&(!!u(i.directions[1],i,r)&&(!!u(i.directions[2],i,r)&&(!!u(r.directions[0],i,r)&&(!!u(r.directions[1],i,r)&&(!!u(r.directions[2],i,r)&&(!!u(n.e.Cross(i.directions[0],r.directions[0]),i,r)&&(!!u(n.e.Cross(i.directions[0],r.directions[1]),i,r)&&(!!u(n.e.Cross(i.directions[0],r.directions[2]),i,r)&&(!!u(n.e.Cross(i.directions[1],r.directions[0]),i,r)&&(!!u(n.e.Cross(i.directions[1],r.directions[1]),i,r)&&(!!u(n.e.Cross(i.directions[1],r.directions[2]),i,r)&&(!!u(n.e.Cross(i.directions[2],r.directions[0]),i,r)&&(!!u(n.e.Cross(i.directions[2],r.directions[1]),i,r)&&!!u(n.e.Cross(i.directions[2],r.directions[2]),i,r))))))))))))))},e.TmpVector3=r.a.BuildArray(2,n.e.Zero),e}()},function(e,t,i){"use strict";i.d(t,"b",(function(){return r})),i.d(t,"a",(function(){return a}));var r,n=i(4),o=i(70),s=i(8);!function(e){e[e.Unknown=0]="Unknown",e[e.Url=1]="Url",e[e.Temp=2]="Temp",e[e.Raw=3]="Raw",e[e.Dynamic=4]="Dynamic",e[e.RenderTarget=5]="RenderTarget",e[e.MultiRenderTarget=6]="MultiRenderTarget",e[e.Cube=7]="Cube",e[e.CubeRaw=8]="CubeRaw",e[e.CubePrefiltered=9]="CubePrefiltered",e[e.Raw3D=10]="Raw3D",e[e.Raw2DArray=11]="Raw2DArray",e[e.Depth=12]="Depth",e[e.CubeRawRGBD=13]="CubeRawRGBD"}(r||(r={}));var a=function(){function e(e,t,i){void 0===i&&(i=!1),this.isReady=!1,this.isCube=!1,this.is3D=!1,this.is2DArray=!1,this.isMultiview=!1,this.url="",this.samplingMode=-1,this.generateMipMaps=!1,this.samples=0,this.type=-1,this.format=-1,this.onLoadedObservable=new n.a,this.width=0,this.height=0,this.depth=0,this.baseWidth=0,this.baseHeight=0,this.baseDepth=0,this.invertY=!1,this._invertVScale=!1,this._associatedChannel=-1,this._source=r.Unknown,this._buffer=null,this._bufferView=null,this._bufferViewArray=null,this._bufferViewArrayArray=null,this._size=0,this._extension="",this._files=null,this._workingCanvas=null,this._workingContext=null,this._framebuffer=null,this._depthStencilBuffer=null,this._MSAAFramebuffer=null,this._MSAARenderBuffer=null,this._attachments=null,this._textureArray=null,this._cachedCoordinatesMode=null,this._cachedWrapU=null,this._cachedWrapV=null,this._cachedWrapR=null,this._cachedAnisotropicFilteringLevel=null,this._isDisabled=!1,this._compression=null,this._generateStencilBuffer=!1,this._generateDepthBuffer=!1,this._comparisonFunction=0,this._sphericalPolynomial=null,this._lodGenerationScale=0,this._lodGenerationOffset=0,this._colorTextureArray=null,this._depthStencilTextureArray=null,this._lodTextureHigh=null,this._lodTextureMid=null,this._lodTextureLow=null,this._isRGBD=!1,this._linearSpecularLOD=!1,this._irradianceTexture=null,this._webGLTexture=null,this._references=1,this._gammaSpace=null,this._engine=e,this._source=t,i||(this._webGLTexture=e._createTexture())}return e.prototype.getEngine=function(){return this._engine},Object.defineProperty(e.prototype,"source",{get:function(){return this._source},enumerable:!1,configurable:!0}),e.prototype.incrementReferences=function(){this._references++},e.prototype.updateSize=function(e,t,i){void 0===i&&(i=1),this.width=e,this.height=t,this.depth=i,this.baseWidth=e,this.baseHeight=t,this.baseDepth=i,this._size=e*t*i},e.prototype._rebuild=function(){var t,i,n=this;switch(this.isReady=!1,this._cachedCoordinatesMode=null,this._cachedWrapU=null,this._cachedWrapV=null,this._cachedAnisotropicFilteringLevel=null,this.source){case r.Temp:return;case r.Url:return void(i=this._engine.createTexture(null!==(t=this._originalUrl)&&void 0!==t?t:this.url,!this.generateMipMaps,this.invertY,null,this.samplingMode,(function(){i._swapAndDie(n),n.isReady=!0}),null,this._buffer,void 0,this.format));case r.Raw:return(i=this._engine.createRawTexture(this._bufferView,this.baseWidth,this.baseHeight,this.format,this.generateMipMaps,this.invertY,this.samplingMode,this._compression))._swapAndDie(this),void(this.isReady=!0);case r.Raw3D:return(i=this._engine.createRawTexture3D(this._bufferView,this.baseWidth,this.baseHeight,this.baseDepth,this.format,this.generateMipMaps,this.invertY,this.samplingMode,this._compression))._swapAndDie(this),void(this.isReady=!0);case r.Raw2DArray:return(i=this._engine.createRawTexture2DArray(this._bufferView,this.baseWidth,this.baseHeight,this.baseDepth,this.format,this.generateMipMaps,this.invertY,this.samplingMode,this._compression))._swapAndDie(this),void(this.isReady=!0);case r.Dynamic:return(i=this._engine.createDynamicTexture(this.baseWidth,this.baseHeight,this.generateMipMaps,this.samplingMode))._swapAndDie(this),void this._engine.updateDynamicTexture(this,this._engine.getRenderingCanvas(),this.invertY,void 0,void 0,!0);case r.RenderTarget:var s=new o.a;if(s.generateDepthBuffer=this._generateDepthBuffer,s.generateMipMaps=this.generateMipMaps,s.generateStencilBuffer=this._generateStencilBuffer,s.samplingMode=this.samplingMode,s.type=this.type,this.isCube)i=this._engine.createRenderTargetCubeTexture(this.width,s);else{var a={width:this.width,height:this.height,layers:this.is2DArray?this.depth:void 0};i=this._engine.createRenderTargetTexture(a,s)}return i._swapAndDie(this),void(this.isReady=!0);case r.Depth:var h={bilinearFiltering:2!==this.samplingMode,comparisonFunction:this._comparisonFunction,generateStencil:this._generateStencilBuffer,isCube:this.isCube},l={width:this.width,height:this.height,layers:this.is2DArray?this.depth:void 0};return(i=this._engine.createDepthStencilTexture(l,h))._swapAndDie(this),void(this.isReady=!0);case r.Cube:return void(i=this._engine.createCubeTexture(this.url,null,this._files,!this.generateMipMaps,(function(){i._swapAndDie(n),n.isReady=!0}),null,this.format,this._extension));case r.CubeRaw:return(i=this._engine.createRawCubeTexture(this._bufferViewArray,this.width,this.format,this.type,this.generateMipMaps,this.invertY,this.samplingMode,this._compression))._swapAndDie(this),void(this.isReady=!0);case r.CubeRawRGBD:return i=this._engine.createRawCubeTexture(null,this.width,this.format,this.type,this.generateMipMaps,this.invertY,this.samplingMode,this._compression),void e._UpdateRGBDAsync(i,this._bufferViewArrayArray,this._sphericalPolynomial,this._lodGenerationScale,this._lodGenerationOffset).then((function(){i._swapAndDie(n),n.isReady=!0}));case r.CubePrefiltered:return void((i=this._engine.createPrefilteredCubeTexture(this.url,null,this._lodGenerationScale,this._lodGenerationOffset,(function(e){e&&e._swapAndDie(n),n.isReady=!0}),null,this.format,this._extension))._sphericalPolynomial=this._sphericalPolynomial)}},e.prototype._swapAndDie=function(e){e._webGLTexture=this._webGLTexture,e._isRGBD=this._isRGBD,this._framebuffer&&(e._framebuffer=this._framebuffer),this._depthStencilBuffer&&(e._depthStencilBuffer=this._depthStencilBuffer),e._depthStencilTexture=this._depthStencilTexture,this._lodTextureHigh&&(e._lodTextureHigh&&e._lodTextureHigh.dispose(),e._lodTextureHigh=this._lodTextureHigh),this._lodTextureMid&&(e._lodTextureMid&&e._lodTextureMid.dispose(),e._lodTextureMid=this._lodTextureMid),this._lodTextureLow&&(e._lodTextureLow&&e._lodTextureLow.dispose(),e._lodTextureLow=this._lodTextureLow),this._irradianceTexture&&(e._irradianceTexture&&e._irradianceTexture.dispose(),e._irradianceTexture=this._irradianceTexture);var t,i=this._engine.getLoadedTexturesCache();-1!==(t=i.indexOf(this))&&i.splice(t,1),-1===(t=i.indexOf(e))&&i.push(e)},e.prototype.dispose=function(){this._webGLTexture&&(this._references--,0===this._references&&(this._engine._releaseTexture(this),this._webGLTexture=null))},e._UpdateRGBDAsync=function(e,t,i,r,n){throw s.a.WarnImport("environmentTextureTools")},e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return r}));var r=function(){function e(){}return e.EndsWith=function(e,t){return-1!==e.indexOf(t,e.length-t.length)},e.StartsWith=function(e,t){return!!e&&0===e.indexOf(t)},e.Decode=function(e){if("undefined"!=typeof TextDecoder)return(new TextDecoder).decode(e);for(var t="",i=0;i>2,o=(3&t)<<4|(i=c>4,s=(15&i)<<2|(r=c>6,a=63&r,isNaN(i)?s=a=64:isNaN(r)&&(a=64),l+=h.charAt(n)+h.charAt(o)+h.charAt(s)+h.charAt(a);return l},e.PadNumber=function(e,t){for(var i=String(e);i.length0&&-1===this.includedOnlyMeshes.indexOf(e))&&(!(this.excludedMeshes&&this.excludedMeshes.length>0&&-1!==this.excludedMeshes.indexOf(e))&&((0===this.includeOnlyWithLayerMask||0!=(this.includeOnlyWithLayerMask&e.layerMask))&&!(0!==this.excludeWithLayerMask&&this.excludeWithLayerMask&e.layerMask)))},t.CompareLightsPriority=function(e,t){return e.shadowEnabled!==t.shadowEnabled?(t.shadowEnabled?1:0)-(e.shadowEnabled?1:0):t.renderPriority-e.renderPriority},t.prototype.dispose=function(t,i){void 0===i&&(i=!1),this._shadowGenerator&&(this._shadowGenerator.dispose(),this._shadowGenerator=null),this.getScene().stopAnimation(this);for(var r=0,n=this.getScene().meshes;r0&&(e.excludedMeshesIds=[],this.excludedMeshes.forEach((function(t){e.excludedMeshesIds.push(t.id)}))),this.includedOnlyMeshes.length>0&&(e.includedOnlyMeshesIds=[],this.includedOnlyMeshes.forEach((function(t){e.includedOnlyMeshesIds.push(t.id)}))),n.a.AppendSerializedAnimations(this,e),e.ranges=this.serializeAnimationRanges(),e},t.GetConstructorFromName=function(e,t,i){var r=a.a.Construct("Light_Type_"+e,t,i);return r||null},t.Parse=function(e,i){var r=t.GetConstructorFromName(e.type,e.name,i);if(!r)return null;var o=n.a.Parse(r,e,i);if(e.excludedMeshesIds&&(o._excludedMeshesIds=e.excludedMeshesIds),e.includedOnlyMeshesIds&&(o._includedOnlyMeshesIds=e.includedOnlyMeshesIds),e.parentId&&(o._waitingParentId=e.parentId),void 0!==e.falloffType&&(o.falloffType=e.falloffType),void 0!==e.lightmapMode&&(o.lightmapMode=e.lightmapMode),e.animations){for(var s=0;sa&&(a=c)}return new e(t,s,a-s+1,i,r,n,o)},e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return n})),i.d(t,"b",(function(){return o})),i.d(t,"c",(function(){return s}));var r=i(1),n=function(){function e(){}return e.KEYDOWN=1,e.KEYUP=2,e}(),o=function(e,t){this.type=e,this.event=t},s=function(e){function t(t,i){var r=e.call(this,t,i)||this;return r.type=t,r.event=i,r.skipOnPointerObservable=!1,r}return Object(r.c)(t,e),t}(o)},function(e,t,i){"use strict";i.d(t,"a",(function(){return r})),i.d(t,"b",(function(){return n}));var r=function(){function e(){}return e.COPY=1,e.CUT=2,e.PASTE=3,e}(),n=function(){function e(e,t){this.type=e,this.event=t}return e.GetTypeFromCharacter=function(e){switch(e){case 67:return r.COPY;case 86:return r.PASTE;case 88:return r.CUT;default:return-1}},e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return x}));var r=i(1),n=i(12),o=i(4),s=i(0),a=i(25),h=i(2),l=i(14),c=i(40),u=i(43),f=i(37),d=function(){this._checkCollisions=!1,this._collisionMask=-1,this._collisionGroup=-1,this._surroundingMeshes=null,this._collider=null,this._oldPositionForCollisions=new s.e(0,0,0),this._diffPositionForCollisions=new s.e(0,0,0),this._collisionResponse=!0},p=i(8),_=i(62),g=i(7),m=i(16),v=i(35),b=i(9),y=function(){this.facetNb=0,this.partitioningSubdivisions=10,this.partitioningBBoxRatio=1.01,this.facetDataEnabled=!1,this.facetParameters={},this.bbSize=s.e.Zero(),this.subDiv={max:1,X:1,Y:1,Z:1},this.facetDepthSort=!1,this.facetDepthSortEnabled=!1},T=function(){this._hasVertexAlpha=!1,this._useVertexColors=!0,this._numBoneInfluencers=4,this._applyFog=!0,this._receiveShadows=!1,this._facetData=new y,this._visibility=1,this._skeleton=null,this._layerMask=268435455,this._computeBonesUsingShaders=!0,this._isActive=!1,this._onlyForInstances=!1,this._isActiveIntermediate=!1,this._onlyForInstancesIntermediate=!1,this._actAsRegularMesh=!1,this._currentLOD=null,this._currentLODIsUpToDate=!1},x=function(e){function t(i,r){void 0===r&&(r=null);var n=e.call(this,i,r,!1)||this;return n._internalAbstractMeshDataInfo=new T,n.cullingStrategy=t.CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY,n.onCollideObservable=new o.a,n.onCollisionPositionChangeObservable=new o.a,n.onMaterialChangedObservable=new o.a,n.definedFacingForward=!0,n._occlusionQuery=null,n._renderingGroup=null,n.alphaIndex=Number.MAX_VALUE,n.isVisible=!0,n.isPickable=!0,n.showSubMeshesBoundingBox=!1,n.isBlocker=!1,n.enablePointerMoveEvents=!1,n._renderingGroupId=0,n._material=null,n.outlineColor=g.a.Red(),n.outlineWidth=.02,n.overlayColor=g.a.Red(),n.overlayAlpha=.5,n.useOctreeForRenderingSelection=!0,n.useOctreeForPicking=!0,n.useOctreeForCollisions=!0,n.alwaysSelectAsActiveMesh=!1,n.doNotSyncBoundingInfo=!1,n.actionManager=null,n._meshCollisionData=new d,n.ellipsoid=new s.e(.5,1,.5),n.ellipsoidOffset=new s.e(0,0,0),n.edgesWidth=1,n.edgesColor=new g.b(1,0,0,1),n._edgesRenderer=null,n._masterMesh=null,n._boundingInfo=null,n._renderId=0,n._intersectionsInProgress=new Array,n._unIndexed=!1,n._lightSources=new Array,n._waitingData={lods:null,actions:null,freezeWorldMatrix:null},n._bonesTransformMatrices=null,n._transformMatrixTexture=null,n.onRebuildObservable=new o.a,n._onCollisionPositionChange=function(e,t,i){void 0===i&&(i=null),t.subtractToRef(n._meshCollisionData._oldPositionForCollisions,n._meshCollisionData._diffPositionForCollisions),n._meshCollisionData._diffPositionForCollisions.length()>a.Engine.CollisionsEpsilon&&n.position.addInPlace(n._meshCollisionData._diffPositionForCollisions),i&&n.onCollideObservable.notifyObservers(i),n.onCollisionPositionChangeObservable.notifyObservers(n.position)},n.getScene().addMesh(n),n._resyncLightSources(),n}return Object(r.c)(t,e),Object.defineProperty(t,"BILLBOARDMODE_NONE",{get:function(){return c.a.BILLBOARDMODE_NONE},enumerable:!1,configurable:!0}),Object.defineProperty(t,"BILLBOARDMODE_X",{get:function(){return c.a.BILLBOARDMODE_X},enumerable:!1,configurable:!0}),Object.defineProperty(t,"BILLBOARDMODE_Y",{get:function(){return c.a.BILLBOARDMODE_Y},enumerable:!1,configurable:!0}),Object.defineProperty(t,"BILLBOARDMODE_Z",{get:function(){return c.a.BILLBOARDMODE_Z},enumerable:!1,configurable:!0}),Object.defineProperty(t,"BILLBOARDMODE_ALL",{get:function(){return c.a.BILLBOARDMODE_ALL},enumerable:!1,configurable:!0}),Object.defineProperty(t,"BILLBOARDMODE_USE_POSITION",{get:function(){return c.a.BILLBOARDMODE_USE_POSITION},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"facetNb",{get:function(){return this._internalAbstractMeshDataInfo._facetData.facetNb},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"partitioningSubdivisions",{get:function(){return this._internalAbstractMeshDataInfo._facetData.partitioningSubdivisions},set:function(e){this._internalAbstractMeshDataInfo._facetData.partitioningSubdivisions=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"partitioningBBoxRatio",{get:function(){return this._internalAbstractMeshDataInfo._facetData.partitioningBBoxRatio},set:function(e){this._internalAbstractMeshDataInfo._facetData.partitioningBBoxRatio=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"mustDepthSortFacets",{get:function(){return this._internalAbstractMeshDataInfo._facetData.facetDepthSort},set:function(e){this._internalAbstractMeshDataInfo._facetData.facetDepthSort=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"facetDepthSortFrom",{get:function(){return this._internalAbstractMeshDataInfo._facetData.facetDepthSortFrom},set:function(e){this._internalAbstractMeshDataInfo._facetData.facetDepthSortFrom=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isFacetDataEnabled",{get:function(){return this._internalAbstractMeshDataInfo._facetData.facetDataEnabled},enumerable:!1,configurable:!0}),t.prototype._updateNonUniformScalingState=function(t){return!!e.prototype._updateNonUniformScalingState.call(this,t)&&(this._markSubMeshesAsMiscDirty(),!0)},Object.defineProperty(t.prototype,"onCollide",{set:function(e){this._meshCollisionData._onCollideObserver&&this.onCollideObservable.remove(this._meshCollisionData._onCollideObserver),this._meshCollisionData._onCollideObserver=this.onCollideObservable.add(e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onCollisionPositionChange",{set:function(e){this._meshCollisionData._onCollisionPositionChangeObserver&&this.onCollisionPositionChangeObservable.remove(this._meshCollisionData._onCollisionPositionChangeObserver),this._meshCollisionData._onCollisionPositionChangeObserver=this.onCollisionPositionChangeObservable.add(e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"visibility",{get:function(){return this._internalAbstractMeshDataInfo._visibility},set:function(e){this._internalAbstractMeshDataInfo._visibility!==e&&(this._internalAbstractMeshDataInfo._visibility=e,this._markSubMeshesAsMiscDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"renderingGroupId",{get:function(){return this._renderingGroupId},set:function(e){this._renderingGroupId=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"material",{get:function(){return this._material},set:function(e){this._material!==e&&(this._material&&this._material.meshMap&&(this._material.meshMap[this.uniqueId]=void 0),this._material=e,e&&e.meshMap&&(e.meshMap[this.uniqueId]=this),this.onMaterialChangedObservable.hasObservers()&&this.onMaterialChangedObservable.notifyObservers(this),this.subMeshes&&this._unBindEffect())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"receiveShadows",{get:function(){return this._internalAbstractMeshDataInfo._receiveShadows},set:function(e){this._internalAbstractMeshDataInfo._receiveShadows!==e&&(this._internalAbstractMeshDataInfo._receiveShadows=e,this._markSubMeshesAsLightDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"hasVertexAlpha",{get:function(){return this._internalAbstractMeshDataInfo._hasVertexAlpha},set:function(e){this._internalAbstractMeshDataInfo._hasVertexAlpha!==e&&(this._internalAbstractMeshDataInfo._hasVertexAlpha=e,this._markSubMeshesAsAttributesDirty(),this._markSubMeshesAsMiscDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"useVertexColors",{get:function(){return this._internalAbstractMeshDataInfo._useVertexColors},set:function(e){this._internalAbstractMeshDataInfo._useVertexColors!==e&&(this._internalAbstractMeshDataInfo._useVertexColors=e,this._markSubMeshesAsAttributesDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"computeBonesUsingShaders",{get:function(){return this._internalAbstractMeshDataInfo._computeBonesUsingShaders},set:function(e){this._internalAbstractMeshDataInfo._computeBonesUsingShaders!==e&&(this._internalAbstractMeshDataInfo._computeBonesUsingShaders=e,this._markSubMeshesAsAttributesDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"numBoneInfluencers",{get:function(){return this._internalAbstractMeshDataInfo._numBoneInfluencers},set:function(e){this._internalAbstractMeshDataInfo._numBoneInfluencers!==e&&(this._internalAbstractMeshDataInfo._numBoneInfluencers=e,this._markSubMeshesAsAttributesDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"applyFog",{get:function(){return this._internalAbstractMeshDataInfo._applyFog},set:function(e){this._internalAbstractMeshDataInfo._applyFog!==e&&(this._internalAbstractMeshDataInfo._applyFog=e,this._markSubMeshesAsMiscDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"layerMask",{get:function(){return this._internalAbstractMeshDataInfo._layerMask},set:function(e){e!==this._internalAbstractMeshDataInfo._layerMask&&(this._internalAbstractMeshDataInfo._layerMask=e,this._resyncLightSources())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"collisionMask",{get:function(){return this._meshCollisionData._collisionMask},set:function(e){this._meshCollisionData._collisionMask=isNaN(e)?-1:e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"collisionResponse",{get:function(){return this._meshCollisionData._collisionResponse},set:function(e){this._meshCollisionData._collisionResponse=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"collisionGroup",{get:function(){return this._meshCollisionData._collisionGroup},set:function(e){this._meshCollisionData._collisionGroup=isNaN(e)?-1:e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"surroundingMeshes",{get:function(){return this._meshCollisionData._surroundingMeshes},set:function(e){this._meshCollisionData._surroundingMeshes=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"lightSources",{get:function(){return this._lightSources},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"_positions",{get:function(){return null},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"skeleton",{get:function(){return this._internalAbstractMeshDataInfo._skeleton},set:function(e){var t=this._internalAbstractMeshDataInfo._skeleton;t&&t.needInitialSkinMatrix&&t._unregisterMeshWithPoseMatrix(this),e&&e.needInitialSkinMatrix&&e._registerMeshWithPoseMatrix(this),this._internalAbstractMeshDataInfo._skeleton=e,this._internalAbstractMeshDataInfo._skeleton||(this._bonesTransformMatrices=null),this._markSubMeshesAsAttributesDirty()},enumerable:!1,configurable:!0}),t.prototype.getClassName=function(){return"AbstractMesh"},t.prototype.toString=function(e){var t="Name: "+this.name+", isInstance: "+("InstancedMesh"!==this.getClassName()?"YES":"NO");t+=", # of submeshes: "+(this.subMeshes?this.subMeshes.length:0);var i=this._internalAbstractMeshDataInfo._skeleton;return i&&(t+=", skeleton: "+i.name),e&&(t+=", billboard mode: "+["NONE","X","Y",null,"Z",null,null,"ALL"][this.billboardMode],t+=", freeze wrld mat: "+(this._isWorldMatrixFrozen||this._waitingData.freezeWorldMatrix?"YES":"NO")),t},t.prototype._getEffectiveParent=function(){return this._masterMesh&&this.billboardMode!==c.a.BILLBOARDMODE_NONE?this._masterMesh:e.prototype._getEffectiveParent.call(this)},t.prototype._getActionManagerForTrigger=function(e,t){if(void 0===t&&(t=!0),this.actionManager&&(t||this.actionManager.isRecursive)){if(!e)return this.actionManager;if(this.actionManager.hasSpecificTrigger(e))return this.actionManager}return this.parent?this.parent._getActionManagerForTrigger(e,!1):null},t.prototype._rebuild=function(){if(this.onRebuildObservable.notifyObservers(this),this._occlusionQuery&&(this._occlusionQuery=null),this.subMeshes)for(var e=0,t=this.subMeshes;e4,a=o?this.getVerticesData(h.b.MatricesIndicesExtraKind):null,l=o?this.getVerticesData(h.b.MatricesWeightsExtraKind):null;this.skeleton.prepare();for(var c=this.skeleton.getTransformMatrices(this),u=s.c.Vector3[0],f=s.c.Matrix[0],d=s.c.Matrix[1],p=0,_=0;_0&&(s.a.FromFloat32ArrayToRefScaled(c,Math.floor(16*i[p+g]),m,d),f.addToSelf(d));if(o)for(g=0;g<4;g++)(m=l[p+g])>0&&(s.a.FromFloat32ArrayToRefScaled(c,Math.floor(16*a[p+g]),m,d),f.addToSelf(d));s.e.TransformCoordinatesFromFloatsToRef(t[_],t[_+1],t[_+2],f,u),u.toArray(t,_),this._positions&&this._positions[_/3].copyFrom(u)}}}return t},t.prototype._updateBoundingInfo=function(){var e=this._effectiveMesh;return this._boundingInfo?this._boundingInfo.update(e.worldMatrixFromCache):this._boundingInfo=new f.a(this.absolutePosition,this.absolutePosition,e.worldMatrixFromCache),this._updateSubMeshesBoundingInfo(e.worldMatrixFromCache),this},t.prototype._updateSubMeshesBoundingInfo=function(e){if(!this.subMeshes)return this;for(var t=this.subMeshes.length,i=0;i1||!r.IsGlobal)&&r.updateBoundingInfo(e)}return this},t.prototype._afterComputeWorldMatrix=function(){this.doNotSyncBoundingInfo||this._updateBoundingInfo()},Object.defineProperty(t.prototype,"_effectiveMesh",{get:function(){return this.skeleton&&this.skeleton.overrideMesh||this},enumerable:!1,configurable:!0}),t.prototype.isInFrustum=function(e){return null!==this._boundingInfo&&this._boundingInfo.isInFrustum(e,this.cullingStrategy)},t.prototype.isCompletelyInFrustum=function(e){return null!==this._boundingInfo&&this._boundingInfo.isCompletelyInFrustum(e)},t.prototype.intersectsMesh=function(e,t,i){if(void 0===t&&(t=!1),!this._boundingInfo||!e._boundingInfo)return!1;if(this._boundingInfo.intersects(e._boundingInfo,t))return!0;if(i)for(var r=0,n=this.getChildMeshes();r1&&!o._checkCollision(e)||this._collideForSubMesh(o,t,e)}return this},t.prototype._checkCollision=function(e){if(!this._boundingInfo||!this._boundingInfo._checkCollision(e))return this;var t=s.c.Matrix[0],i=s.c.Matrix[1];return s.a.ScalingToRef(1/e._radius.x,1/e._radius.y,1/e._radius.z,t),this.worldMatrixFromCache.multiplyToRef(t,i),this._processCollisionsForSubMeshes(e,i),this},t.prototype._generatePointsArray=function(){return!1},t.prototype.intersects=function(e,t,i,r,n,o){var a;void 0===r&&(r=!1),void 0===o&&(o=!1);var h=new u.a,l="InstancedLinesMesh"===this.getClassName()||"LinesMesh"===this.getClassName()?this.intersectionThreshold:0,c=this._boundingInfo;if(!this.subMeshes||!c)return h;if(!(o||e.intersectsSphere(c.boundingSphere,l)&&e.intersectsBox(c.boundingBox,l)))return h;if(r)return h.hit=!o,h.pickedMesh=o?null:this,h.distance=o?0:s.e.Distance(e.origin,c.boundingSphere.center),h.subMeshId=0,h;if(!this._generatePointsArray())return h;for(var f=null,d=this._scene.getIntersectingSubMeshCandidates(this,e),p=d.length,_=!1,g=0;g1)||v.canIntersects(e)){var b=v.intersects(e,this._positions,this.getIndices(),t,i);if(b&&(t||!f||b.distance65535){o=!0;break}e.depthSortedIndices=o?new Uint32Array(i):new Uint16Array(i)}if(e.facetDepthSortFunction=function(e,t){return t.sqDistance-e.sqDistance},!e.facetDepthSortFrom){var c=this.getScene().activeCamera;e.facetDepthSortFrom=c?c.position:s.e.Zero()}e.depthSortedFacets=[];for(var u=0;um.a?n.maximum.x-n.minimum.x:m.a,e.bbSize.y=n.maximum.y-n.minimum.y>m.a?n.maximum.y-n.minimum.y:m.a,e.bbSize.z=n.maximum.z-n.minimum.z>m.a?n.maximum.z-n.minimum.z:m.a;var d=e.bbSize.x>e.bbSize.y?e.bbSize.x:e.bbSize.y;if(d=d>e.bbSize.z?d:e.bbSize.z,e.subDiv.max=e.partitioningSubdivisions,e.subDiv.X=Math.floor(e.subDiv.max*e.bbSize.x/d),e.subDiv.Y=Math.floor(e.subDiv.max*e.bbSize.y/d),e.subDiv.Z=Math.floor(e.subDiv.max*e.bbSize.z/d),e.subDiv.X=e.subDiv.X<1?1:e.subDiv.X,e.subDiv.Y=e.subDiv.Y<1?1:e.subDiv.Y,e.subDiv.Z=e.subDiv.Z<1?1:e.subDiv.Z,e.facetParameters.facetNormals=this.getFacetLocalNormals(),e.facetParameters.facetPositions=this.getFacetLocalPositions(),e.facetParameters.facetPartitioning=this.getFacetLocalPartitioning(),e.facetParameters.bInfo=n,e.facetParameters.bbSize=e.bbSize,e.facetParameters.subDiv=e.subDiv,e.facetParameters.ratio=this.partitioningBBoxRatio,e.facetParameters.depthSort=e.facetDepthSort,e.facetDepthSort&&e.facetDepthSortEnabled&&(this.computeWorldMatrix(!0),this._worldMatrix.invertToRef(e.invertedMatrix),s.e.TransformCoordinatesToRef(e.facetDepthSortFrom,e.invertedMatrix,e.facetDepthSortOrigin),e.facetParameters.distanceTo=e.facetDepthSortOrigin),e.facetParameters.depthSortedFacets=e.depthSortedFacets,l.VertexData.ComputeNormals(t,i,r,e.facetParameters),e.facetDepthSort&&e.facetDepthSortEnabled){e.depthSortedFacets.sort(e.facetDepthSortFunction);var p=e.depthSortedIndices.length/3|0;for(u=0;un.subDiv.max||s<0||s>n.subDiv.max||a<0||a>n.subDiv.max?null:n.facetPartitioning[o+n.subDiv.max*s+n.subDiv.max*n.subDiv.max*a]},t.prototype.getClosestFacetAtCoordinates=function(e,t,i,r,n,o){void 0===n&&(n=!1),void 0===o&&(o=!0);var a=this.getWorldMatrix(),h=s.c.Matrix[5];a.invertToRef(h);var l=s.c.Vector3[8];s.e.TransformCoordinatesFromFloatsToRef(e,t,i,h,l);var c=this.getClosestFacetAtLocalCoordinates(l.x,l.y,l.z,r,n,o);return r&&s.e.TransformCoordinatesFromFloatsToRef(r.x,r.y,r.z,a,r),c},t.prototype.getClosestFacetAtLocalCoordinates=function(e,t,i,r,n,o){void 0===n&&(n=!1),void 0===o&&(o=!0);var s=null,a=0,h=0,l=0,c=0,u=0,f=0,d=0,p=0,_=this.getFacetLocalPositions(),g=this.getFacetLocalNormals(),m=this.getFacetsAtLocalCoordinates(e,t,i);if(!m)return null;for(var v,b,y,T=Number.MAX_VALUE,x=T,E=0;E=0||n&&!o&&c<=0)&&(c=b.x*y.x+b.y*y.y+b.z*y.z,u=-(b.x*e+b.y*t+b.z*i-c)/(b.x*b.x+b.y*b.y+b.z*b.z),(x=(a=(f=e+b.x*u)-e)*a+(h=(d=t+b.y*u)-t)*h+(l=(p=i+b.z*u)-i)*l)0&&e.push(this._texture)},e.prototype.dispose=function(e){var t;e&&(null===(t=this._texture)||void 0===t||t.dispose())},e.prototype.getClassName=function(){return"DetailMap"},e.AddUniforms=function(e){e.push("vDetailInfos")},e.AddSamplers=function(e){e.push("detailSampler")},e.PrepareUniformBuffer=function(e){e.addUniform("vDetailInfos",4),e.addUniform("detailMatrix",16)},e.prototype.copyTo=function(e){n.a.Clone((function(){return e}),this)},e.prototype.serialize=function(){return n.a.Serialize(this)},e.prototype.parse=function(e,t,i){var r=this;n.a.Parse((function(){return r}),e,t,i)},Object(r.b)([Object(n.j)("detailTexture"),Object(n.b)("_markAllSubMeshesAsTexturesDirty")],e.prototype,"texture",void 0),Object(r.b)([Object(n.c)()],e.prototype,"diffuseBlendLevel",void 0),Object(r.b)([Object(n.c)()],e.prototype,"roughnessBlendLevel",void 0),Object(r.b)([Object(n.c)()],e.prototype,"bumpLevel",void 0),Object(r.b)([Object(n.c)(),Object(n.b)("_markAllSubMeshesAsTexturesDirty")],e.prototype,"normalBlendMethod",void 0),Object(r.b)([Object(n.c)(),Object(n.b)("_markAllSubMeshesAsTexturesDirty")],e.prototype,"isEnabled",void 0),e}(),ne={effect:null,subMesh:null},oe=function(e){function t(){var t=e.call(this)||this;return t.MAINUV1=!1,t.MAINUV2=!1,t.DIFFUSE=!1,t.DIFFUSEDIRECTUV=0,t.DETAIL=!1,t.DETAILDIRECTUV=0,t.DETAIL_NORMALBLENDMETHOD=0,t.AMBIENT=!1,t.AMBIENTDIRECTUV=0,t.OPACITY=!1,t.OPACITYDIRECTUV=0,t.OPACITYRGB=!1,t.REFLECTION=!1,t.EMISSIVE=!1,t.EMISSIVEDIRECTUV=0,t.SPECULAR=!1,t.SPECULARDIRECTUV=0,t.BUMP=!1,t.BUMPDIRECTUV=0,t.PARALLAX=!1,t.PARALLAXOCCLUSION=!1,t.SPECULAROVERALPHA=!1,t.CLIPPLANE=!1,t.CLIPPLANE2=!1,t.CLIPPLANE3=!1,t.CLIPPLANE4=!1,t.CLIPPLANE5=!1,t.CLIPPLANE6=!1,t.ALPHATEST=!1,t.DEPTHPREPASS=!1,t.ALPHAFROMDIFFUSE=!1,t.POINTSIZE=!1,t.FOG=!1,t.SPECULARTERM=!1,t.DIFFUSEFRESNEL=!1,t.OPACITYFRESNEL=!1,t.REFLECTIONFRESNEL=!1,t.REFRACTIONFRESNEL=!1,t.EMISSIVEFRESNEL=!1,t.FRESNEL=!1,t.NORMAL=!1,t.UV1=!1,t.UV2=!1,t.VERTEXCOLOR=!1,t.VERTEXALPHA=!1,t.NUM_BONE_INFLUENCERS=0,t.BonesPerMesh=0,t.BONETEXTURE=!1,t.BONES_VELOCITY_ENABLED=!1,t.INSTANCES=!1,t.THIN_INSTANCES=!1,t.GLOSSINESS=!1,t.ROUGHNESS=!1,t.EMISSIVEASILLUMINATION=!1,t.LINKEMISSIVEWITHDIFFUSE=!1,t.REFLECTIONFRESNELFROMSPECULAR=!1,t.LIGHTMAP=!1,t.LIGHTMAPDIRECTUV=0,t.OBJECTSPACE_NORMALMAP=!1,t.USELIGHTMAPASSHADOWMAP=!1,t.REFLECTIONMAP_3D=!1,t.REFLECTIONMAP_SPHERICAL=!1,t.REFLECTIONMAP_PLANAR=!1,t.REFLECTIONMAP_CUBIC=!1,t.USE_LOCAL_REFLECTIONMAP_CUBIC=!1,t.REFLECTIONMAP_PROJECTION=!1,t.REFLECTIONMAP_SKYBOX=!1,t.REFLECTIONMAP_EXPLICIT=!1,t.REFLECTIONMAP_EQUIRECTANGULAR=!1,t.REFLECTIONMAP_EQUIRECTANGULAR_FIXED=!1,t.REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED=!1,t.INVERTCUBICMAP=!1,t.LOGARITHMICDEPTH=!1,t.REFRACTION=!1,t.REFRACTIONMAP_3D=!1,t.REFLECTIONOVERALPHA=!1,t.TWOSIDEDLIGHTING=!1,t.SHADOWFLOAT=!1,t.MORPHTARGETS=!1,t.MORPHTARGETS_NORMAL=!1,t.MORPHTARGETS_TANGENT=!1,t.MORPHTARGETS_UV=!1,t.NUM_MORPH_INFLUENCERS=0,t.NONUNIFORMSCALING=!1,t.PREMULTIPLYALPHA=!1,t.ALPHATEST_AFTERALLALPHACOMPUTATIONS=!1,t.ALPHABLEND=!0,t.PREPASS=!1,t.PREPASS_IRRADIANCE=!1,t.PREPASS_IRRADIANCE_INDEX=-1,t.PREPASS_ALBEDO=!1,t.PREPASS_ALBEDO_INDEX=-1,t.PREPASS_DEPTHNORMAL=!1,t.PREPASS_DEPTHNORMAL_INDEX=-1,t.PREPASS_POSITION=!1,t.PREPASS_POSITION_INDEX=-1,t.PREPASS_VELOCITY=!1,t.PREPASS_VELOCITY_INDEX=-1,t.PREPASS_REFLECTIVITY=!1,t.PREPASS_REFLECTIVITY_INDEX=-1,t.SCENE_MRT_COUNT=0,t.RGBDLIGHTMAP=!1,t.RGBDREFLECTION=!1,t.RGBDREFRACTION=!1,t.IMAGEPROCESSING=!1,t.VIGNETTE=!1,t.VIGNETTEBLENDMODEMULTIPLY=!1,t.VIGNETTEBLENDMODEOPAQUE=!1,t.TONEMAPPING=!1,t.TONEMAPPING_ACES=!1,t.CONTRAST=!1,t.COLORCURVES=!1,t.COLORGRADING=!1,t.COLORGRADING3D=!1,t.SAMPLER3DGREENDEPTH=!1,t.SAMPLER3DBGRMAP=!1,t.IMAGEPROCESSINGPOSTPROCESS=!1,t.MULTIVIEW=!1,t.IS_REFLECTION_LINEAR=!1,t.IS_REFRACTION_LINEAR=!1,t.EXPOSURE=!1,t.rebuild(),t}return Object(r.c)(t,e),t.prototype.setReflectionMode=function(e){for(var t=0,i=["REFLECTIONMAP_CUBIC","REFLECTIONMAP_EXPLICIT","REFLECTIONMAP_PLANAR","REFLECTIONMAP_PROJECTION","REFLECTIONMAP_PROJECTION","REFLECTIONMAP_SKYBOX","REFLECTIONMAP_SPHERICAL","REFLECTIONMAP_EQUIRECTANGULAR","REFLECTIONMAP_EQUIRECTANGULAR_FIXED","REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED"];t0,o.REFLECTIONOVERALPHA=this._useReflectionOverAlpha,o.INVERTCUBICMAP=this._reflectionTexture.coordinatesMode===g.a.INVCUBIC_MODE,o.REFLECTIONMAP_3D=this._reflectionTexture.isCube,o.RGBDREFLECTION=this._reflectionTexture.isRGBD,this._reflectionTexture.coordinatesMode){case g.a.EXPLICIT_MODE:o.setReflectionMode("REFLECTIONMAP_EXPLICIT");break;case g.a.PLANAR_MODE:o.setReflectionMode("REFLECTIONMAP_PLANAR");break;case g.a.PROJECTION_MODE:o.setReflectionMode("REFLECTIONMAP_PROJECTION");break;case g.a.SKYBOX_MODE:o.setReflectionMode("REFLECTIONMAP_SKYBOX");break;case g.a.SPHERICAL_MODE:o.setReflectionMode("REFLECTIONMAP_SPHERICAL");break;case g.a.EQUIRECTANGULAR_MODE:o.setReflectionMode("REFLECTIONMAP_EQUIRECTANGULAR");break;case g.a.FIXED_EQUIRECTANGULAR_MODE:o.setReflectionMode("REFLECTIONMAP_EQUIRECTANGULAR_FIXED");break;case g.a.FIXED_EQUIRECTANGULAR_MIRRORED_MODE:o.setReflectionMode("REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED");break;case g.a.CUBIC_MODE:case g.a.INVCUBIC_MODE:default:o.setReflectionMode("REFLECTIONMAP_CUBIC")}o.USE_LOCAL_REFLECTIONMAP_CUBIC=!!this._reflectionTexture.boundingBoxSize}else o.REFLECTION=!1;if(this._emissiveTexture&&t.EmissiveTextureEnabled){if(!this._emissiveTexture.isReadyOrNotBlocking())return!1;_.a.PrepareDefinesForMergedUV(this._emissiveTexture,o,"EMISSIVE")}else o.EMISSIVE=!1;if(this._lightmapTexture&&t.LightmapTextureEnabled){if(!this._lightmapTexture.isReadyOrNotBlocking())return!1;_.a.PrepareDefinesForMergedUV(this._lightmapTexture,o,"LIGHTMAP"),o.USELIGHTMAPASSHADOWMAP=this._useLightmapAsShadowmap,o.RGBDLIGHTMAP=this._lightmapTexture.isRGBD}else o.LIGHTMAP=!1;if(this._specularTexture&&t.SpecularTextureEnabled){if(!this._specularTexture.isReadyOrNotBlocking())return!1;_.a.PrepareDefinesForMergedUV(this._specularTexture,o,"SPECULAR"),o.GLOSSINESS=this._useGlossinessFromSpecularMapAlpha}else o.SPECULAR=!1;if(n.getEngine().getCaps().standardDerivatives&&this._bumpTexture&&t.BumpTextureEnabled){if(!this._bumpTexture.isReady())return!1;_.a.PrepareDefinesForMergedUV(this._bumpTexture,o,"BUMP"),o.PARALLAX=this._useParallax,o.PARALLAXOCCLUSION=this._useParallaxOcclusion,o.OBJECTSPACE_NORMALMAP=this._useObjectSpaceNormalMap}else o.BUMP=!1;if(this._refractionTexture&&t.RefractionTextureEnabled){if(!this._refractionTexture.isReadyOrNotBlocking())return!1;o._needUVs=!0,o.REFRACTION=!0,o.REFRACTIONMAP_3D=this._refractionTexture.isCube,o.RGBDREFRACTION=this._refractionTexture.isRGBD}else o.REFRACTION=!1;o.TWOSIDEDLIGHTING=!this._backFaceCulling&&this._twoSidedLighting}else o.DIFFUSE=!1,o.AMBIENT=!1,o.OPACITY=!1,o.REFLECTION=!1,o.EMISSIVE=!1,o.LIGHTMAP=!1,o.BUMP=!1,o.REFRACTION=!1;o.ALPHAFROMDIFFUSE=this._shouldUseAlphaFromDiffuseTexture(),o.EMISSIVEASILLUMINATION=this._useEmissiveAsIllumination,o.LINKEMISSIVEWITHDIFFUSE=this._linkEmissiveWithDiffuse,o.SPECULAROVERALPHA=this._useSpecularOverAlpha,o.PREMULTIPLYALPHA=7===this.alphaMode||8===this.alphaMode,o.ALPHATEST_AFTERALLALPHACOMPUTATIONS=null!==this.transparencyMode,o.ALPHABLEND=null===this.transparencyMode||this.needAlphaBlendingForMesh(e)}if(!this.detailMap.isReadyForSubMesh(o,n))return!1;if(o._areImageProcessingDirty&&this._imageProcessingConfiguration){if(!this._imageProcessingConfiguration.isReady())return!1;this._imageProcessingConfiguration.prepareDefines(o),o.IS_REFLECTION_LINEAR=null!=this.reflectionTexture&&!this.reflectionTexture.gammaSpace,o.IS_REFRACTION_LINEAR=null!=this.refractionTexture&&!this.refractionTexture.gammaSpace}if(o._areFresnelDirty&&(t.FresnelEnabled?(this._diffuseFresnelParameters||this._opacityFresnelParameters||this._emissiveFresnelParameters||this._refractionFresnelParameters||this._reflectionFresnelParameters)&&(o.DIFFUSEFRESNEL=this._diffuseFresnelParameters&&this._diffuseFresnelParameters.isEnabled,o.OPACITYFRESNEL=this._opacityFresnelParameters&&this._opacityFresnelParameters.isEnabled,o.REFLECTIONFRESNEL=this._reflectionFresnelParameters&&this._reflectionFresnelParameters.isEnabled,o.REFLECTIONFRESNELFROMSPECULAR=this._useReflectionFresnelFromSpecular,o.REFRACTIONFRESNEL=this._refractionFresnelParameters&&this._refractionFresnelParameters.isEnabled,o.EMISSIVEFRESNEL=this._emissiveFresnelParameters&&this._emissiveFresnelParameters.isEnabled,o._needNormals=!0,o.FRESNEL=!0):o.FRESNEL=!1),_.a.PrepareDefinesForMisc(e,n,this._useLogarithmicDepth,this.pointsCloud,this.fogEnabled,this._shouldTurnAlphaTestOn(e)||this._forceAlphaTest,o),_.a.PrepareDefinesForAttributes(e,o,!0,!0,!0),_.a.PrepareDefinesForFrameBoundValues(n,s,o,r,null,i.getRenderingMesh().hasThinInstances),this.detailMap.prepareDefines(o,n),o.isDirty){var a=o._areLightsDisposed;o.markAsProcessed();var h=new ie.a;o.REFLECTION&&h.addFallback(0,"REFLECTION"),o.SPECULAR&&h.addFallback(0,"SPECULAR"),o.BUMP&&h.addFallback(0,"BUMP"),o.PARALLAX&&h.addFallback(1,"PARALLAX"),o.PARALLAXOCCLUSION&&h.addFallback(0,"PARALLAXOCCLUSION"),o.SPECULAROVERALPHA&&h.addFallback(0,"SPECULAROVERALPHA"),o.FOG&&h.addFallback(1,"FOG"),o.POINTSIZE&&h.addFallback(0,"POINTSIZE"),o.LOGARITHMICDEPTH&&h.addFallback(0,"LOGARITHMICDEPTH"),_.a.HandleFallbacksForShadows(o,h,this._maxSimultaneousLights),o.SPECULARTERM&&h.addFallback(0,"SPECULARTERM"),o.DIFFUSEFRESNEL&&h.addFallback(1,"DIFFUSEFRESNEL"),o.OPACITYFRESNEL&&h.addFallback(2,"OPACITYFRESNEL"),o.REFLECTIONFRESNEL&&h.addFallback(3,"REFLECTIONFRESNEL"),o.EMISSIVEFRESNEL&&h.addFallback(4,"EMISSIVEFRESNEL"),o.FRESNEL&&h.addFallback(4,"FRESNEL"),o.MULTIVIEW&&h.addFallback(0,"MULTIVIEW");var f=[l.b.PositionKind];o.NORMAL&&f.push(l.b.NormalKind),o.UV1&&f.push(l.b.UVKind),o.UV2&&f.push(l.b.UV2Kind),o.VERTEXCOLOR&&f.push(l.b.ColorKind),_.a.PrepareAttributesForBones(f,e,o,h),_.a.PrepareAttributesForInstances(f,o),_.a.PrepareAttributesForMorphTargets(f,e,o);var d="default",p=["world","view","viewProjection","vEyePosition","vLightsType","vAmbientColor","vDiffuseColor","vSpecularColor","vEmissiveColor","visibility","vFogInfos","vFogColor","pointSize","vDiffuseInfos","vAmbientInfos","vOpacityInfos","vReflectionInfos","vEmissiveInfos","vSpecularInfos","vBumpInfos","vLightmapInfos","vRefractionInfos","mBones","vClipPlane","vClipPlane2","vClipPlane3","vClipPlane4","vClipPlane5","vClipPlane6","diffuseMatrix","ambientMatrix","opacityMatrix","reflectionMatrix","emissiveMatrix","specularMatrix","bumpMatrix","normalMatrix","lightmapMatrix","refractionMatrix","diffuseLeftColor","diffuseRightColor","opacityParts","reflectionLeftColor","reflectionRightColor","emissiveLeftColor","emissiveRightColor","refractionLeftColor","refractionRightColor","vReflectionPosition","vReflectionSize","logarithmicDepthConstant","vTangentSpaceParams","alphaCutOff","boneTextureWidth"],m=["diffuseSampler","ambientSampler","opacitySampler","reflectionCubeSampler","reflection2DSampler","emissiveSampler","specularSampler","bumpSampler","lightmapSampler","refractionCubeSampler","refraction2DSampler","boneSampler"],v=["Material","Scene"];re.AddUniforms(p),re.AddSamplers(m),c.AddUniforms(p),c.AddSamplers(p),u.a&&(u.a.PrepareUniforms(p,o),u.a.PrepareSamplers(m,o)),_.a.PrepareUniformsAndSamplersList({uniformsNames:p,uniformBuffersNames:v,samplers:m,defines:o,maxSimultaneousLights:this._maxSimultaneousLights});var b={};this.customShaderNameResolve&&(d=this.customShaderNameResolve(d,p,v,m,o,f,b));var y=o.toString(),T=i.effect,x=n.getEngine().createEffect(d,{attributes:f,uniformsNames:p,uniformBuffersNames:v,samplers:m,defines:y,fallbacks:h,onCompiled:this.onCompiled,onError:this.onError,indexParameters:{maxSimultaneousLights:this._maxSimultaneousLights,maxSimultaneousMorphTargets:o.NUM_MORPH_INFLUENCERS},processFinalCode:b.processFinalCode,multiTarget:o.PREPASS},s);if(x)if(this._onEffectCreatedObservable&&(ne.effect=x,ne.subMesh=i,this._onEffectCreatedObservable.notifyObservers(ne)),this.allowShaderHotSwapping&&T&&!x.isReady()){if(x=T,this._rebuildInParallel=!0,o.markAsUnprocessed(),a)return o._areLightsDisposed=!0,!1}else this._rebuildInParallel=!1,n.resetCachedMaterial(),i.setEffect(x,o),this.buildUniformLayout()}return!(!i.effect||!i.effect.isReady())&&(o._renderId=n.getRenderId(),i.effect._wasPreviouslyReady=!0,!0)},t.prototype.buildUniformLayout=function(){var e=this._uniformBuffer;e.addUniform("diffuseLeftColor",4),e.addUniform("diffuseRightColor",4),e.addUniform("opacityParts",4),e.addUniform("reflectionLeftColor",4),e.addUniform("reflectionRightColor",4),e.addUniform("refractionLeftColor",4),e.addUniform("refractionRightColor",4),e.addUniform("emissiveLeftColor",4),e.addUniform("emissiveRightColor",4),e.addUniform("vDiffuseInfos",2),e.addUniform("vAmbientInfos",2),e.addUniform("vOpacityInfos",2),e.addUniform("vReflectionInfos",2),e.addUniform("vReflectionPosition",3),e.addUniform("vReflectionSize",3),e.addUniform("vEmissiveInfos",2),e.addUniform("vLightmapInfos",2),e.addUniform("vSpecularInfos",2),e.addUniform("vBumpInfos",3),e.addUniform("diffuseMatrix",16),e.addUniform("ambientMatrix",16),e.addUniform("opacityMatrix",16),e.addUniform("reflectionMatrix",16),e.addUniform("emissiveMatrix",16),e.addUniform("lightmapMatrix",16),e.addUniform("specularMatrix",16),e.addUniform("bumpMatrix",16),e.addUniform("vTangentSpaceParams",2),e.addUniform("pointSize",1),e.addUniform("refractionMatrix",16),e.addUniform("vRefractionInfos",4),e.addUniform("vSpecularColor",4),e.addUniform("vEmissiveColor",3),e.addUniform("visibility",1),e.addUniform("vDiffuseColor",4),re.PrepareUniformBuffer(e),e.create()},t.prototype.unbind=function(){if(this._activeEffect){var t=!1;this._reflectionTexture&&this._reflectionTexture.isRenderTarget&&(this._activeEffect.setTexture("reflection2DSampler",null),t=!0),this._refractionTexture&&this._refractionTexture.isRenderTarget&&(this._activeEffect.setTexture("refraction2DSampler",null),t=!0),t&&this._markAllSubMeshesAsTexturesDirty()}e.prototype.unbind.call(this)},t.prototype.bindForSubMesh=function(e,i,r){var n=this.getScene(),o=r._materialDefines;if(o){var a=r.effect;if(a){this._activeEffect=a,o.INSTANCES&&!o.THIN_INSTANCES||this.bindOnlyWorldMatrix(e),this.prePassConfiguration.bindForSubMesh(this._activeEffect,n,i,e,this.isFrozen),o.OBJECTSPACE_NORMALMAP&&(e.toNormalMatrix(this._normalMatrix),this.bindOnlyNormalMatrix(this._normalMatrix));var l=this._mustRebind(n,a,i.visibility);_.a.BindBonesParameters(i,a);var c=this._uniformBuffer;if(l){if(c.bindToEffect(a,"Material"),this.bindViewProjection(a),!c.useUbo||!this.isFrozen||!c.isSync){if(t.FresnelEnabled&&o.FRESNEL&&(this.diffuseFresnelParameters&&this.diffuseFresnelParameters.isEnabled&&(c.updateColor4("diffuseLeftColor",this.diffuseFresnelParameters.leftColor,this.diffuseFresnelParameters.power),c.updateColor4("diffuseRightColor",this.diffuseFresnelParameters.rightColor,this.diffuseFresnelParameters.bias)),this.opacityFresnelParameters&&this.opacityFresnelParameters.isEnabled&&c.updateColor4("opacityParts",new h.a(this.opacityFresnelParameters.leftColor.toLuminance(),this.opacityFresnelParameters.rightColor.toLuminance(),this.opacityFresnelParameters.bias),this.opacityFresnelParameters.power),this.reflectionFresnelParameters&&this.reflectionFresnelParameters.isEnabled&&(c.updateColor4("reflectionLeftColor",this.reflectionFresnelParameters.leftColor,this.reflectionFresnelParameters.power),c.updateColor4("reflectionRightColor",this.reflectionFresnelParameters.rightColor,this.reflectionFresnelParameters.bias)),this.refractionFresnelParameters&&this.refractionFresnelParameters.isEnabled&&(c.updateColor4("refractionLeftColor",this.refractionFresnelParameters.leftColor,this.refractionFresnelParameters.power),c.updateColor4("refractionRightColor",this.refractionFresnelParameters.rightColor,this.refractionFresnelParameters.bias)),this.emissiveFresnelParameters&&this.emissiveFresnelParameters.isEnabled&&(c.updateColor4("emissiveLeftColor",this.emissiveFresnelParameters.leftColor,this.emissiveFresnelParameters.power),c.updateColor4("emissiveRightColor",this.emissiveFresnelParameters.rightColor,this.emissiveFresnelParameters.bias))),n.texturesEnabled){if(this._diffuseTexture&&t.DiffuseTextureEnabled&&(c.updateFloat2("vDiffuseInfos",this._diffuseTexture.coordinatesIndex,this._diffuseTexture.level),_.a.BindTextureMatrix(this._diffuseTexture,c,"diffuse")),this._ambientTexture&&t.AmbientTextureEnabled&&(c.updateFloat2("vAmbientInfos",this._ambientTexture.coordinatesIndex,this._ambientTexture.level),_.a.BindTextureMatrix(this._ambientTexture,c,"ambient")),this._opacityTexture&&t.OpacityTextureEnabled&&(c.updateFloat2("vOpacityInfos",this._opacityTexture.coordinatesIndex,this._opacityTexture.level),_.a.BindTextureMatrix(this._opacityTexture,c,"opacity")),this._hasAlphaChannel()&&a.setFloat("alphaCutOff",this.alphaCutOff),this._reflectionTexture&&t.ReflectionTextureEnabled&&(c.updateFloat2("vReflectionInfos",this._reflectionTexture.level,this.roughness),c.updateMatrix("reflectionMatrix",this._reflectionTexture.getReflectionTextureMatrix()),this._reflectionTexture.boundingBoxSize)){var u=this._reflectionTexture;c.updateVector3("vReflectionPosition",u.boundingBoxPosition),c.updateVector3("vReflectionSize",u.boundingBoxSize)}if(this._emissiveTexture&&t.EmissiveTextureEnabled&&(c.updateFloat2("vEmissiveInfos",this._emissiveTexture.coordinatesIndex,this._emissiveTexture.level),_.a.BindTextureMatrix(this._emissiveTexture,c,"emissive")),this._lightmapTexture&&t.LightmapTextureEnabled&&(c.updateFloat2("vLightmapInfos",this._lightmapTexture.coordinatesIndex,this._lightmapTexture.level),_.a.BindTextureMatrix(this._lightmapTexture,c,"lightmap")),this._specularTexture&&t.SpecularTextureEnabled&&(c.updateFloat2("vSpecularInfos",this._specularTexture.coordinatesIndex,this._specularTexture.level),_.a.BindTextureMatrix(this._specularTexture,c,"specular")),this._bumpTexture&&n.getEngine().getCaps().standardDerivatives&&t.BumpTextureEnabled&&(c.updateFloat3("vBumpInfos",this._bumpTexture.coordinatesIndex,1/this._bumpTexture.level,this.parallaxScaleBias),_.a.BindTextureMatrix(this._bumpTexture,c,"bump"),n._mirroredCameraPosition?c.updateFloat2("vTangentSpaceParams",this._invertNormalMapX?1:-1,this._invertNormalMapY?1:-1):c.updateFloat2("vTangentSpaceParams",this._invertNormalMapX?-1:1,this._invertNormalMapY?-1:1)),this._refractionTexture&&t.RefractionTextureEnabled){var f=1;this._refractionTexture.isCube||(c.updateMatrix("refractionMatrix",this._refractionTexture.getReflectionTextureMatrix()),this._refractionTexture.depth&&(f=this._refractionTexture.depth)),c.updateFloat4("vRefractionInfos",this._refractionTexture.level,this.indexOfRefraction,f,this.invertRefractionY?-1:1)}}this.pointsCloud&&c.updateFloat("pointSize",this.pointSize),o.SPECULARTERM&&c.updateColor4("vSpecularColor",this.specularColor,this.specularPower),c.updateColor3("vEmissiveColor",t.EmissiveTextureEnabled?this.emissiveColor:h.a.BlackReadOnly),c.updateColor4("vDiffuseColor",this.diffuseColor,this.alpha)}if(c.updateFloat("visibility",i.visibility),n.texturesEnabled&&(this._diffuseTexture&&t.DiffuseTextureEnabled&&a.setTexture("diffuseSampler",this._diffuseTexture),this._ambientTexture&&t.AmbientTextureEnabled&&a.setTexture("ambientSampler",this._ambientTexture),this._opacityTexture&&t.OpacityTextureEnabled&&a.setTexture("opacitySampler",this._opacityTexture),this._reflectionTexture&&t.ReflectionTextureEnabled&&(this._reflectionTexture.isCube?a.setTexture("reflectionCubeSampler",this._reflectionTexture):a.setTexture("reflection2DSampler",this._reflectionTexture)),this._emissiveTexture&&t.EmissiveTextureEnabled&&a.setTexture("emissiveSampler",this._emissiveTexture),this._lightmapTexture&&t.LightmapTextureEnabled&&a.setTexture("lightmapSampler",this._lightmapTexture),this._specularTexture&&t.SpecularTextureEnabled&&a.setTexture("specularSampler",this._specularTexture),this._bumpTexture&&n.getEngine().getCaps().standardDerivatives&&t.BumpTextureEnabled&&a.setTexture("bumpSampler",this._bumpTexture),this._refractionTexture&&t.RefractionTextureEnabled)){f=1;this._refractionTexture.isCube?a.setTexture("refractionCubeSampler",this._refractionTexture):a.setTexture("refraction2DSampler",this._refractionTexture)}this.detailMap.bindForSubMesh(c,n,this.isFrozen),_.a.BindClipPlane(a,n),n.ambientColor.multiplyToRef(this.ambientColor,this._globalAmbientColor),_.a.BindEyePosition(a,n),a.setColor3("vAmbientColor",this._globalAmbientColor)}!l&&this.isFrozen||(n.lightsEnabled&&!this._disableLighting&&_.a.BindLights(n,i,a,o,this._maxSimultaneousLights,this._rebuildInParallel),(n.fogEnabled&&i.applyFog&&n.fogMode!==s.Scene.FOGMODE_NONE||this._reflectionTexture||this._refractionTexture)&&this.bindView(a),_.a.BindFogParameters(n,i,a),o.NUM_MORPH_INFLUENCERS&&_.a.BindMorphTargetParameters(i,a),this.useLogarithmicDepth&&_.a.BindLogDepth(o,a,n),this._imageProcessingConfiguration&&!this._imageProcessingConfiguration.applyByPostProcess&&this._imageProcessingConfiguration.bind(this._activeEffect)),c.update(),this._afterBind(i,this._activeEffect)}}},t.prototype.getAnimatables=function(){var e=[];return this._diffuseTexture&&this._diffuseTexture.animations&&this._diffuseTexture.animations.length>0&&e.push(this._diffuseTexture),this._ambientTexture&&this._ambientTexture.animations&&this._ambientTexture.animations.length>0&&e.push(this._ambientTexture),this._opacityTexture&&this._opacityTexture.animations&&this._opacityTexture.animations.length>0&&e.push(this._opacityTexture),this._reflectionTexture&&this._reflectionTexture.animations&&this._reflectionTexture.animations.length>0&&e.push(this._reflectionTexture),this._emissiveTexture&&this._emissiveTexture.animations&&this._emissiveTexture.animations.length>0&&e.push(this._emissiveTexture),this._specularTexture&&this._specularTexture.animations&&this._specularTexture.animations.length>0&&e.push(this._specularTexture),this._bumpTexture&&this._bumpTexture.animations&&this._bumpTexture.animations.length>0&&e.push(this._bumpTexture),this._lightmapTexture&&this._lightmapTexture.animations&&this._lightmapTexture.animations.length>0&&e.push(this._lightmapTexture),this._refractionTexture&&this._refractionTexture.animations&&this._refractionTexture.animations.length>0&&e.push(this._refractionTexture),this.detailMap.getAnimatables(e),e},t.prototype.getActiveTextures=function(){var t=e.prototype.getActiveTextures.call(this);return this._diffuseTexture&&t.push(this._diffuseTexture),this._ambientTexture&&t.push(this._ambientTexture),this._opacityTexture&&t.push(this._opacityTexture),this._reflectionTexture&&t.push(this._reflectionTexture),this._emissiveTexture&&t.push(this._emissiveTexture),this._specularTexture&&t.push(this._specularTexture),this._bumpTexture&&t.push(this._bumpTexture),this._lightmapTexture&&t.push(this._lightmapTexture),this._refractionTexture&&t.push(this._refractionTexture),this.detailMap.getActiveTextures(t),t},t.prototype.hasTexture=function(t){return!!e.prototype.hasTexture.call(this,t)||(this._diffuseTexture===t||(this._ambientTexture===t||(this._opacityTexture===t||(this._reflectionTexture===t||(this._emissiveTexture===t||(this._specularTexture===t||(this._bumpTexture===t||(this._lightmapTexture===t||(this._refractionTexture===t||this.detailMap.hasTexture(t))))))))))},t.prototype.dispose=function(t,i){var r,n,o,s,a,h,l,c,u;i&&(null===(r=this._diffuseTexture)||void 0===r||r.dispose(),null===(n=this._ambientTexture)||void 0===n||n.dispose(),null===(o=this._opacityTexture)||void 0===o||o.dispose(),null===(s=this._reflectionTexture)||void 0===s||s.dispose(),null===(a=this._emissiveTexture)||void 0===a||a.dispose(),null===(h=this._specularTexture)||void 0===h||h.dispose(),null===(l=this._bumpTexture)||void 0===l||l.dispose(),null===(c=this._lightmapTexture)||void 0===c||c.dispose(),null===(u=this._refractionTexture)||void 0===u||u.dispose()),this.detailMap.dispose(i),this._imageProcessingConfiguration&&this._imageProcessingObserver&&this._imageProcessingConfiguration.onUpdateParameters.remove(this._imageProcessingObserver),e.prototype.dispose.call(this,t,i)},t.prototype.clone=function(e){var i=this,r=n.a.Clone((function(){return new t(e,i.getScene())}),this);return r.name=e,r.id=e,r},t.prototype.serialize=function(){return n.a.Serialize(this)},t.Parse=function(e,i,r){return n.a.Parse((function(){return new t(e.name,i)}),e,i,r)},Object.defineProperty(t,"DiffuseTextureEnabled",{get:function(){return b.DiffuseTextureEnabled},set:function(e){b.DiffuseTextureEnabled=e},enumerable:!1,configurable:!0}),Object.defineProperty(t,"DetailTextureEnabled",{get:function(){return b.DetailTextureEnabled},set:function(e){b.DetailTextureEnabled=e},enumerable:!1,configurable:!0}),Object.defineProperty(t,"AmbientTextureEnabled",{get:function(){return b.AmbientTextureEnabled},set:function(e){b.AmbientTextureEnabled=e},enumerable:!1,configurable:!0}),Object.defineProperty(t,"OpacityTextureEnabled",{get:function(){return b.OpacityTextureEnabled},set:function(e){b.OpacityTextureEnabled=e},enumerable:!1,configurable:!0}),Object.defineProperty(t,"ReflectionTextureEnabled",{get:function(){return b.ReflectionTextureEnabled},set:function(e){b.ReflectionTextureEnabled=e},enumerable:!1,configurable:!0}),Object.defineProperty(t,"EmissiveTextureEnabled",{get:function(){return b.EmissiveTextureEnabled},set:function(e){b.EmissiveTextureEnabled=e},enumerable:!1,configurable:!0}),Object.defineProperty(t,"SpecularTextureEnabled",{get:function(){return b.SpecularTextureEnabled},set:function(e){b.SpecularTextureEnabled=e},enumerable:!1,configurable:!0}),Object.defineProperty(t,"BumpTextureEnabled",{get:function(){return b.BumpTextureEnabled},set:function(e){b.BumpTextureEnabled=e},enumerable:!1,configurable:!0}),Object.defineProperty(t,"LightmapTextureEnabled",{get:function(){return b.LightmapTextureEnabled},set:function(e){b.LightmapTextureEnabled=e},enumerable:!1,configurable:!0}),Object.defineProperty(t,"RefractionTextureEnabled",{get:function(){return b.RefractionTextureEnabled},set:function(e){b.RefractionTextureEnabled=e},enumerable:!1,configurable:!0}),Object.defineProperty(t,"ColorGradingTextureEnabled",{get:function(){return b.ColorGradingTextureEnabled},set:function(e){b.ColorGradingTextureEnabled=e},enumerable:!1,configurable:!0}),Object.defineProperty(t,"FresnelEnabled",{get:function(){return b.FresnelEnabled},set:function(e){b.FresnelEnabled=e},enumerable:!1,configurable:!0}),Object(r.b)([Object(n.j)("diffuseTexture")],t.prototype,"_diffuseTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesAndMiscDirty")],t.prototype,"diffuseTexture",void 0),Object(r.b)([Object(n.j)("ambientTexture")],t.prototype,"_ambientTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"ambientTexture",void 0),Object(r.b)([Object(n.j)("opacityTexture")],t.prototype,"_opacityTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesAndMiscDirty")],t.prototype,"opacityTexture",void 0),Object(r.b)([Object(n.j)("reflectionTexture")],t.prototype,"_reflectionTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"reflectionTexture",void 0),Object(r.b)([Object(n.j)("emissiveTexture")],t.prototype,"_emissiveTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"emissiveTexture",void 0),Object(r.b)([Object(n.j)("specularTexture")],t.prototype,"_specularTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"specularTexture",void 0),Object(r.b)([Object(n.j)("bumpTexture")],t.prototype,"_bumpTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"bumpTexture",void 0),Object(r.b)([Object(n.j)("lightmapTexture")],t.prototype,"_lightmapTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"lightmapTexture",void 0),Object(r.b)([Object(n.j)("refractionTexture")],t.prototype,"_refractionTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"refractionTexture",void 0),Object(r.b)([Object(n.d)("ambient")],t.prototype,"ambientColor",void 0),Object(r.b)([Object(n.d)("diffuse")],t.prototype,"diffuseColor",void 0),Object(r.b)([Object(n.d)("specular")],t.prototype,"specularColor",void 0),Object(r.b)([Object(n.d)("emissive")],t.prototype,"emissiveColor",void 0),Object(r.b)([Object(n.c)()],t.prototype,"specularPower",void 0),Object(r.b)([Object(n.c)("useAlphaFromDiffuseTexture")],t.prototype,"_useAlphaFromDiffuseTexture",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesAndMiscDirty")],t.prototype,"useAlphaFromDiffuseTexture",void 0),Object(r.b)([Object(n.c)("useEmissiveAsIllumination")],t.prototype,"_useEmissiveAsIllumination",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useEmissiveAsIllumination",void 0),Object(r.b)([Object(n.c)("linkEmissiveWithDiffuse")],t.prototype,"_linkEmissiveWithDiffuse",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"linkEmissiveWithDiffuse",void 0),Object(r.b)([Object(n.c)("useSpecularOverAlpha")],t.prototype,"_useSpecularOverAlpha",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useSpecularOverAlpha",void 0),Object(r.b)([Object(n.c)("useReflectionOverAlpha")],t.prototype,"_useReflectionOverAlpha",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useReflectionOverAlpha",void 0),Object(r.b)([Object(n.c)("disableLighting")],t.prototype,"_disableLighting",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsLightsDirty")],t.prototype,"disableLighting",void 0),Object(r.b)([Object(n.c)("useObjectSpaceNormalMap")],t.prototype,"_useObjectSpaceNormalMap",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useObjectSpaceNormalMap",void 0),Object(r.b)([Object(n.c)("useParallax")],t.prototype,"_useParallax",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useParallax",void 0),Object(r.b)([Object(n.c)("useParallaxOcclusion")],t.prototype,"_useParallaxOcclusion",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useParallaxOcclusion",void 0),Object(r.b)([Object(n.c)()],t.prototype,"parallaxScaleBias",void 0),Object(r.b)([Object(n.c)("roughness")],t.prototype,"_roughness",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"roughness",void 0),Object(r.b)([Object(n.c)()],t.prototype,"indexOfRefraction",void 0),Object(r.b)([Object(n.c)()],t.prototype,"invertRefractionY",void 0),Object(r.b)([Object(n.c)()],t.prototype,"alphaCutOff",void 0),Object(r.b)([Object(n.c)("useLightmapAsShadowmap")],t.prototype,"_useLightmapAsShadowmap",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useLightmapAsShadowmap",void 0),Object(r.b)([Object(n.g)("diffuseFresnelParameters")],t.prototype,"_diffuseFresnelParameters",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsFresnelDirty")],t.prototype,"diffuseFresnelParameters",void 0),Object(r.b)([Object(n.g)("opacityFresnelParameters")],t.prototype,"_opacityFresnelParameters",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsFresnelAndMiscDirty")],t.prototype,"opacityFresnelParameters",void 0),Object(r.b)([Object(n.g)("reflectionFresnelParameters")],t.prototype,"_reflectionFresnelParameters",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsFresnelDirty")],t.prototype,"reflectionFresnelParameters",void 0),Object(r.b)([Object(n.g)("refractionFresnelParameters")],t.prototype,"_refractionFresnelParameters",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsFresnelDirty")],t.prototype,"refractionFresnelParameters",void 0),Object(r.b)([Object(n.g)("emissiveFresnelParameters")],t.prototype,"_emissiveFresnelParameters",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsFresnelDirty")],t.prototype,"emissiveFresnelParameters",void 0),Object(r.b)([Object(n.c)("useReflectionFresnelFromSpecular")],t.prototype,"_useReflectionFresnelFromSpecular",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsFresnelDirty")],t.prototype,"useReflectionFresnelFromSpecular",void 0),Object(r.b)([Object(n.c)("useGlossinessFromSpecularMapAlpha")],t.prototype,"_useGlossinessFromSpecularMapAlpha",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"useGlossinessFromSpecularMapAlpha",void 0),Object(r.b)([Object(n.c)("maxSimultaneousLights")],t.prototype,"_maxSimultaneousLights",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsLightsDirty")],t.prototype,"maxSimultaneousLights",void 0),Object(r.b)([Object(n.c)("invertNormalMapX")],t.prototype,"_invertNormalMapX",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"invertNormalMapX",void 0),Object(r.b)([Object(n.c)("invertNormalMapY")],t.prototype,"_invertNormalMapY",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"invertNormalMapY",void 0),Object(r.b)([Object(n.c)("twoSidedLighting")],t.prototype,"_twoSidedLighting",void 0),Object(r.b)([Object(n.b)("_markAllSubMeshesAsTexturesDirty")],t.prototype,"twoSidedLighting",void 0),Object(r.b)([Object(n.c)()],t.prototype,"useLogarithmicDepth",null),t}(p);m.a.RegisteredTypes["BABYLON.StandardMaterial"]=se,s.Scene.DefaultMaterialFactory=function(e){return new se("default material",e)}},function(e,t,i){"use strict";i.d(t,"a",(function(){return n}));var r=i(0),n=function(){function e(e,t,i,n){this.normal=new r.e(e,t,i),this.d=n}return e.prototype.asArray=function(){return[this.normal.x,this.normal.y,this.normal.z,this.d]},e.prototype.clone=function(){return new e(this.normal.x,this.normal.y,this.normal.z,this.d)},e.prototype.getClassName=function(){return"Plane"},e.prototype.getHashCode=function(){var e=this.normal.getHashCode();return e=397*e^(0|this.d)},e.prototype.normalize=function(){var e=Math.sqrt(this.normal.x*this.normal.x+this.normal.y*this.normal.y+this.normal.z*this.normal.z),t=0;return 0!==e&&(t=1/e),this.normal.x*=t,this.normal.y*=t,this.normal.z*=t,this.d*=t,this},e.prototype.transform=function(t){var i=e._TmpMatrix;t.invertToRef(i);var r=i.m,n=this.normal.x,o=this.normal.y,s=this.normal.z,a=this.d;return new e(n*r[0]+o*r[1]+s*r[2]+a*r[3],n*r[4]+o*r[5]+s*r[6]+a*r[7],n*r[8]+o*r[9]+s*r[10]+a*r[11],n*r[12]+o*r[13]+s*r[14]+a*r[15])},e.prototype.dotCoordinate=function(e){return this.normal.x*e.x+this.normal.y*e.y+this.normal.z*e.z+this.d},e.prototype.copyFromPoints=function(e,t,i){var r,n=t.x-e.x,o=t.y-e.y,s=t.z-e.z,a=i.x-e.x,h=i.y-e.y,l=i.z-e.z,c=o*l-s*h,u=s*a-n*l,f=n*h-o*a,d=Math.sqrt(c*c+u*u+f*f);return r=0!==d?1/d:0,this.normal.x=c*r,this.normal.y=u*r,this.normal.z=f*r,this.d=-(this.normal.x*e.x+this.normal.y*e.y+this.normal.z*e.z),this},e.prototype.isFrontFacingTo=function(e,t){return r.e.Dot(this.normal,e)<=t},e.prototype.signedDistanceTo=function(e){return r.e.Dot(e,this.normal)+this.d},e.FromArray=function(t){return new e(t[0],t[1],t[2],t[3])},e.FromPoints=function(t,i,r){var n=new e(0,0,0,0);return n.copyFromPoints(t,i,r),n},e.FromPositionAndNormal=function(t,i){var r=new e(0,0,0,0);return i.normalize(),r.normal=i,r.d=-(i.x*t.x+i.y*t.y+i.z*t.z),r},e.SignedDistanceToPlaneFromPositionAndNormal=function(e,t,i){var n=-(t.x*e.x+t.y*e.y+t.z*e.z);return r.e.Dot(i,t)+n},e._TmpMatrix=r.a.Identity(),e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return n}));var r=i(51),n=function(){function e(){}return e.GetPlanes=function(t){for(var i=[],n=0;n<6;n++)i.push(new r.a(0,0,0,0));return e.GetPlanesToRef(t,i),i},e.GetNearPlaneToRef=function(e,t){var i=e.m;t.normal.x=i[3]+i[2],t.normal.y=i[7]+i[6],t.normal.z=i[11]+i[10],t.d=i[15]+i[14],t.normalize()},e.GetFarPlaneToRef=function(e,t){var i=e.m;t.normal.x=i[3]-i[2],t.normal.y=i[7]-i[6],t.normal.z=i[11]-i[10],t.d=i[15]-i[14],t.normalize()},e.GetLeftPlaneToRef=function(e,t){var i=e.m;t.normal.x=i[3]+i[0],t.normal.y=i[7]+i[4],t.normal.z=i[11]+i[8],t.d=i[15]+i[12],t.normalize()},e.GetRightPlaneToRef=function(e,t){var i=e.m;t.normal.x=i[3]-i[0],t.normal.y=i[7]-i[4],t.normal.z=i[11]-i[8],t.d=i[15]-i[12],t.normalize()},e.GetTopPlaneToRef=function(e,t){var i=e.m;t.normal.x=i[3]-i[1],t.normal.y=i[7]-i[5],t.normal.z=i[11]-i[9],t.d=i[15]-i[13],t.normalize()},e.GetBottomPlaneToRef=function(e,t){var i=e.m;t.normal.x=i[3]+i[1],t.normal.y=i[7]+i[5],t.normal.z=i[11]+i[9],t.d=i[15]+i[13],t.normalize()},e.GetPlanesToRef=function(t,i){e.GetNearPlaneToRef(t,i[0]),e.GetFarPlaneToRef(t,i[1]),e.GetLeftPlaneToRef(t,i[2]),e.GetRightPlaneToRef(t,i[3]),e.GetTopPlaneToRef(t,i[4]),e.GetBottomPlaneToRef(t,i[5])},e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return r}));var r=function(){function e(e,t){this.width=e,this.height=t}return e.prototype.toString=function(){return"{W: "+this.width+", H: "+this.height+"}"},e.prototype.getClassName=function(){return"Size"},e.prototype.getHashCode=function(){var e=0|this.width;return e=397*e^(0|this.height)},e.prototype.copyFrom=function(e){this.width=e.width,this.height=e.height},e.prototype.copyFromFloats=function(e,t){return this.width=e,this.height=t,this},e.prototype.set=function(e,t){return this.copyFromFloats(e,t)},e.prototype.multiplyByFloats=function(t,i){return new e(this.width*t,this.height*i)},e.prototype.clone=function(){return new e(this.width,this.height)},e.prototype.equals=function(e){return!!e&&(this.width===e.width&&this.height===e.height)},Object.defineProperty(e.prototype,"surface",{get:function(){return this.width*this.height},enumerable:!1,configurable:!0}),e.Zero=function(){return new e(0,0)},e.prototype.add=function(t){return new e(this.width+t.width,this.height+t.height)},e.prototype.subtract=function(t){return new e(this.width-t.width,this.height-t.height)},e.Lerp=function(t,i,r){return new e(t.width+(i.width-t.width)*r,t.height+(i.height-t.height)*r)},e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return r}));var r=function(){function e(){}return e.CreateCanvas=function(e,t){if("undefined"==typeof document)return new OffscreenCanvas(e,t);var i=document.createElement("canvas");return i.width=e,i.height=t,i},e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return n}));var r=i(1),n=function(e){function t(t){var i=e.call(this)||this;return i._buffer=t,i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"underlyingResource",{get:function(){return this._buffer},enumerable:!1,configurable:!0}),t}(function(){function e(){this.references=0,this.capacity=0,this.is32Bits=!1}return Object.defineProperty(e.prototype,"underlyingResource",{get:function(){return null},enumerable:!1,configurable:!0}),e}())},function(e,t,i){"use strict";i.r(t),i.d(t,"Space",(function(){return r.c})),i.d(t,"Axis",(function(){return r.a})),i.d(t,"Coordinate",(function(){return r.b})),i.d(t,"Color3",(function(){return n.a})),i.d(t,"Color4",(function(){return n.b})),i.d(t,"TmpColors",(function(){return n.c})),i.d(t,"ToGammaSpace",(function(){return o.b})),i.d(t,"ToLinearSpace",(function(){return o.c})),i.d(t,"Epsilon",(function(){return o.a})),i.d(t,"Frustum",(function(){return s.a})),i.d(t,"Orientation",(function(){return a.e})),i.d(t,"BezierCurve",(function(){return a.c})),i.d(t,"Angle",(function(){return a.a})),i.d(t,"Arc2",(function(){return a.b})),i.d(t,"Path2",(function(){return a.f})),i.d(t,"Path3D",(function(){return a.g})),i.d(t,"Curve3",(function(){return a.d})),i.d(t,"Plane",(function(){return h.a})),i.d(t,"Size",(function(){return l.a})),i.d(t,"Vector2",(function(){return c.d})),i.d(t,"Vector3",(function(){return c.e})),i.d(t,"Vector4",(function(){return c.f})),i.d(t,"Quaternion",(function(){return c.b})),i.d(t,"Matrix",(function(){return c.a})),i.d(t,"TmpVectors",(function(){return c.c})),i.d(t,"PositionNormalVertex",(function(){return u})),i.d(t,"PositionNormalTextureVertex",(function(){return f})),i.d(t,"Viewport",(function(){return d.a}));var r=i(35),n=i(7),o=i(16),s=i(52),a=i(69),h=i(51),l=i(53),c=i(0),u=function(){function e(e,t){void 0===e&&(e=c.e.Zero()),void 0===t&&(t=c.e.Up()),this.position=e,this.normal=t}return e.prototype.clone=function(){return new e(this.position.clone(),this.normal.clone())},e}(),f=function(){function e(e,t,i){void 0===e&&(e=c.e.Zero()),void 0===t&&(t=c.e.Up()),void 0===i&&(i=c.d.Zero()),this.position=e,this.normal=t,this.uv=i}return e.prototype.clone=function(){return new e(this.position.clone(),this.normal.clone(),this.uv.clone())},e}(),d=i(57)},function(e,t,i){"use strict";i.d(t,"a",(function(){return r}));var r=function(){function e(e,t,i,r){this.x=e,this.y=t,this.width=i,this.height=r}return e.prototype.toGlobal=function(t,i){return new e(this.x*t,this.y*i,this.width*t,this.height*i)},e.prototype.toGlobalToRef=function(e,t,i){return i.x=this.x*e,i.y=this.y*t,i.width=this.width*e,i.height=this.height*t,this},e.prototype.clone=function(){return new e(this.x,this.y,this.width,this.height)},e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return n}));var r=i(36),n=function(){function e(){this._startMonitoringTime=0,this._min=0,this._max=0,this._average=0,this._lastSecAverage=0,this._current=0,this._totalValueCount=0,this._totalAccumulated=0,this._lastSecAccumulated=0,this._lastSecTime=0,this._lastSecValueCount=0}return Object.defineProperty(e.prototype,"min",{get:function(){return this._min},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"max",{get:function(){return this._max},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"average",{get:function(){return this._average},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"lastSecAverage",{get:function(){return this._lastSecAverage},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"current",{get:function(){return this._current},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"total",{get:function(){return this._totalAccumulated},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"count",{get:function(){return this._totalValueCount},enumerable:!1,configurable:!0}),e.prototype.fetchNewFrame=function(){this._totalValueCount++,this._current=0,this._lastSecValueCount++},e.prototype.addCount=function(t,i){e.Enabled&&(this._current+=t,i&&this._fetchResult())},e.prototype.beginMonitoring=function(){e.Enabled&&(this._startMonitoringTime=r.a.Now)},e.prototype.endMonitoring=function(t){if(void 0===t&&(t=!0),e.Enabled){t&&this.fetchNewFrame();var i=r.a.Now;this._current=i-this._startMonitoringTime,t&&this._fetchResult()}},e.prototype._fetchResult=function(){this._totalAccumulated+=this._current,this._lastSecAccumulated+=this._current,this._min=Math.min(this._min,this._current),this._max=Math.max(this._max,this._current),this._average=this._totalAccumulated/this._totalValueCount;var e=r.a.Now;e-this._lastSecTime>1e3&&(this._lastSecAverage=this._lastSecAccumulated/this._lastSecValueCount,this._lastSecTime=e,this._lastSecAccumulated=0,this._lastSecValueCount=0)},e.Enabled=!0,e}()},function(e,t,i){"use strict";i.d(t,"a",(function(){return c}));var r=i(1),n=i(3),o=i(4),s=i(12),a=i(7),h=i(72),l=function(){function e(){this._dirty=!0,this._tempColor=new a.b(0,0,0,0),this._globalCurve=new a.b(0,0,0,0),this._highlightsCurve=new a.b(0,0,0,0),this._midtonesCurve=new a.b(0,0,0,0),this._shadowsCurve=new a.b(0,0,0,0),this._positiveCurve=new a.b(0,0,0,0),this._negativeCurve=new a.b(0,0,0,0),this._globalHue=30,this._globalDensity=0,this._globalSaturation=0,this._globalExposure=0,this._highlightsHue=30,this._highlightsDensity=0,this._highlightsSaturation=0,this._highlightsExposure=0,this._midtonesHue=30,this._midtonesDensity=0,this._midtonesSaturation=0,this._midtonesExposure=0,this._shadowsHue=30,this._shadowsDensity=0,this._shadowsSaturation=0,this._shadowsExposure=0}return Object.defineProperty(e.prototype,"globalHue",{get:function(){return this._globalHue},set:function(e){this._globalHue=e,this._dirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"globalDensity",{get:function(){return this._globalDensity},set:function(e){this._globalDensity=e,this._dirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"globalSaturation",{get:function(){return this._globalSaturation},set:function(e){this._globalSaturation=e,this._dirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"globalExposure",{get:function(){return this._globalExposure},set:function(e){this._globalExposure=e,this._dirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"highlightsHue",{get:function(){return this._highlightsHue},set:function(e){this._highlightsHue=e,this._dirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"highlightsDensity",{get:function(){return this._highlightsDensity},set:function(e){this._highlightsDensity=e,this._dirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"highlightsSaturation",{get:function(){return this._highlightsSaturation},set:function(e){this._highlightsSaturation=e,this._dirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"highlightsExposure",{get:function(){return this._highlightsExposure},set:function(e){this._highlightsExposure=e,this._dirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"midtonesHue",{get:function(){return this._midtonesHue},set:function(e){this._midtonesHue=e,this._dirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"midtonesDensity",{get:function(){return this._midtonesDensity},set:function(e){this._midtonesDensity=e,this._dirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"midtonesSaturation",{get:function(){return this._midtonesSaturation},set:function(e){this._midtonesSaturation=e,this._dirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"midtonesExposure",{get:function(){return this._midtonesExposure},set:function(e){this._midtonesExposure=e,this._dirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"shadowsHue",{get:function(){return this._shadowsHue},set:function(e){this._shadowsHue=e,this._dirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"shadowsDensity",{get:function(){return this._shadowsDensity},set:function(e){this._shadowsDensity=e,this._dirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"shadowsSaturation",{get:function(){return this._shadowsSaturation},set:function(e){this._shadowsSaturation=e,this._dirty=!0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"shadowsExposure",{get:function(){return this._shadowsExposure},set:function(e){this._shadowsExposure=e,this._dirty=!0},enumerable:!1,configurable:!0}),e.prototype.getClassName=function(){return"ColorCurves"},e.Bind=function(e,t,i,r,n){void 0===i&&(i="vCameraColorCurvePositive"),void 0===r&&(r="vCameraColorCurveNeutral"),void 0===n&&(n="vCameraColorCurveNegative"),e._dirty&&(e._dirty=!1,e.getColorGradingDataToRef(e._globalHue,e._globalDensity,e._globalSaturation,e._globalExposure,e._globalCurve),e.getColorGradingDataToRef(e._highlightsHue,e._highlightsDensity,e._highlightsSaturation,e._highlightsExposure,e._tempColor),e._tempColor.multiplyToRef(e._globalCurve,e._highlightsCurve),e.getColorGradingDataToRef(e._midtonesHue,e._midtonesDensity,e._midtonesSaturation,e._midtonesExposure,e._tempColor),e._tempColor.multiplyToRef(e._globalCurve,e._midtonesCurve),e.getColorGradingDataToRef(e._shadowsHue,e._shadowsDensity,e._shadowsSaturation,e._shadowsExposure,e._tempColor),e._tempColor.multiplyToRef(e._globalCurve,e._shadowsCurve),e._highlightsCurve.subtractToRef(e._midtonesCurve,e._positiveCurve),e._midtonesCurve.subtractToRef(e._shadowsCurve,e._negativeCurve)),t&&(t.setFloat4(i,e._positiveCurve.r,e._positiveCurve.g,e._positiveCurve.b,e._positiveCurve.a),t.setFloat4(r,e._midtonesCurve.r,e._midtonesCurve.g,e._midtonesCurve.b,e._midtonesCurve.a),t.setFloat4(n,e._negativeCurve.r,e._negativeCurve.g,e._negativeCurve.b,e._negativeCurve.a))},e.PrepareUniforms=function(e){e.push("vCameraColorCurveNeutral","vCameraColorCurvePositive","vCameraColorCurveNegative")},e.prototype.getColorGradingDataToRef=function(t,i,r,n,o){null!=t&&(t=e.clamp(t,0,360),i=e.clamp(i,-100,100),r=e.clamp(r,-100,100),n=e.clamp(n,-100,100),i=e.applyColorGradingSliderNonlinear(i),i*=.5,n=e.applyColorGradingSliderNonlinear(n),i<0&&(i*=-1,t=(t+180)%360),e.fromHSBToRef(t,i,50+.25*n,o),o.scaleToRef(2,o),o.a=1+.01*r)},e.applyColorGradingSliderNonlinear=function(e){e/=100;var t=Math.abs(e);return t=Math.pow(t,2),e<0&&(t*=-1),t*=100},e.fromHSBToRef=function(t,i,r,n){var o=e.clamp(t,0,360),s=e.clamp(i/100,0,1),a=e.clamp(r/100,0,1);if(0===s)n.r=a,n.g=a,n.b=a;else{o/=60;var h=Math.floor(o),l=o-h,c=a*(1-s),u=a*(1-s*l),f=a*(1-s*(1-l));switch(h){case 0:n.r=a,n.g=f,n.b=c;break;case 1:n.r=u,n.g=a,n.b=c;break;case 2:n.r=c,n.g=a,n.b=f;break;case 3:n.r=c,n.g=u,n.b=a;break;case 4:n.r=f,n.g=c,n.b=a;break;default:n.r=a,n.g=c,n.b=u}}n.a=1},e.clamp=function(e,t,i){return Math.min(Math.max(e,t),i)},e.prototype.clone=function(){return n.a.Clone((function(){return new e}),this)},e.prototype.serialize=function(){return n.a.Serialize(this)},e.Parse=function(t){return n.a.Parse((function(){return new e}),t,null,null)},Object(r.b)([Object(n.c)()],e.prototype,"_globalHue",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_globalDensity",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_globalSaturation",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_globalExposure",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_highlightsHue",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_highlightsDensity",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_highlightsSaturation",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_highlightsExposure",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_midtonesHue",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_midtonesDensity",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_midtonesSaturation",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_midtonesExposure",void 0),e}();n.a._ColorCurvesParser=l.Parse;!function(e){function t(){var t=e.call(this)||this;return t.IMAGEPROCESSING=!1,t.VIGNETTE=!1,t.VIGNETTEBLENDMODEMULTIPLY=!1,t.VIGNETTEBLENDMODEOPAQUE=!1,t.TONEMAPPING=!1,t.TONEMAPPING_ACES=!1,t.CONTRAST=!1,t.COLORCURVES=!1,t.COLORGRADING=!1,t.COLORGRADING3D=!1,t.SAMPLER3DGREENDEPTH=!1,t.SAMPLER3DBGRMAP=!1,t.IMAGEPROCESSINGPOSTPROCESS=!1,t.EXPOSURE=!1,t.rebuild(),t}Object(r.c)(t,e)}(h.a);var c=function(){function e(){this.colorCurves=new l,this._colorCurvesEnabled=!1,this._colorGradingEnabled=!1,this._colorGradingWithGreenDepth=!0,this._colorGradingBGR=!0,this._exposure=1,this._toneMappingEnabled=!1,this._toneMappingType=e.TONEMAPPING_STANDARD,this._contrast=1,this.vignetteStretch=0,this.vignetteCentreX=0,this.vignetteCentreY=0,this.vignetteWeight=1.5,this.vignetteColor=new a.b(0,0,0,0),this.vignetteCameraFov=.5,this._vignetteBlendMode=e.VIGNETTEMODE_MULTIPLY,this._vignetteEnabled=!1,this._applyByPostProcess=!1,this._isEnabled=!0,this.onUpdateParameters=new o.a}return Object.defineProperty(e.prototype,"colorCurvesEnabled",{get:function(){return this._colorCurvesEnabled},set:function(e){this._colorCurvesEnabled!==e&&(this._colorCurvesEnabled=e,this._updateParameters())},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"colorGradingTexture",{get:function(){return this._colorGradingTexture},set:function(e){this._colorGradingTexture!==e&&(this._colorGradingTexture=e,this._updateParameters())},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"colorGradingEnabled",{get:function(){return this._colorGradingEnabled},set:function(e){this._colorGradingEnabled!==e&&(this._colorGradingEnabled=e,this._updateParameters())},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"colorGradingWithGreenDepth",{get:function(){return this._colorGradingWithGreenDepth},set:function(e){this._colorGradingWithGreenDepth!==e&&(this._colorGradingWithGreenDepth=e,this._updateParameters())},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"colorGradingBGR",{get:function(){return this._colorGradingBGR},set:function(e){this._colorGradingBGR!==e&&(this._colorGradingBGR=e,this._updateParameters())},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"exposure",{get:function(){return this._exposure},set:function(e){this._exposure!==e&&(this._exposure=e,this._updateParameters())},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"toneMappingEnabled",{get:function(){return this._toneMappingEnabled},set:function(e){this._toneMappingEnabled!==e&&(this._toneMappingEnabled=e,this._updateParameters())},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"toneMappingType",{get:function(){return this._toneMappingType},set:function(e){this._toneMappingType!==e&&(this._toneMappingType=e,this._updateParameters())},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"contrast",{get:function(){return this._contrast},set:function(e){this._contrast!==e&&(this._contrast=e,this._updateParameters())},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"vignetteBlendMode",{get:function(){return this._vignetteBlendMode},set:function(e){this._vignetteBlendMode!==e&&(this._vignetteBlendMode=e,this._updateParameters())},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"vignetteEnabled",{get:function(){return this._vignetteEnabled},set:function(e){this._vignetteEnabled!==e&&(this._vignetteEnabled=e,this._updateParameters())},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"applyByPostProcess",{get:function(){return this._applyByPostProcess},set:function(e){this._applyByPostProcess!==e&&(this._applyByPostProcess=e,this._updateParameters())},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"isEnabled",{get:function(){return this._isEnabled},set:function(e){this._isEnabled!==e&&(this._isEnabled=e,this._updateParameters())},enumerable:!1,configurable:!0}),e.prototype._updateParameters=function(){this.onUpdateParameters.notifyObservers(this)},e.prototype.getClassName=function(){return"ImageProcessingConfiguration"},e.PrepareUniforms=function(e,t){t.EXPOSURE&&e.push("exposureLinear"),t.CONTRAST&&e.push("contrast"),t.COLORGRADING&&e.push("colorTransformSettings"),t.VIGNETTE&&(e.push("vInverseScreenSize"),e.push("vignetteSettings1"),e.push("vignetteSettings2")),t.COLORCURVES&&l.PrepareUniforms(e)},e.PrepareSamplers=function(e,t){t.COLORGRADING&&e.push("txColorTransform")},e.prototype.prepareDefines=function(t,i){if(void 0===i&&(i=!1),i!==this.applyByPostProcess||!this._isEnabled)return t.VIGNETTE=!1,t.TONEMAPPING=!1,t.TONEMAPPING_ACES=!1,t.CONTRAST=!1,t.EXPOSURE=!1,t.COLORCURVES=!1,t.COLORGRADING=!1,t.COLORGRADING3D=!1,t.IMAGEPROCESSING=!1,void(t.IMAGEPROCESSINGPOSTPROCESS=this.applyByPostProcess&&this._isEnabled);switch(t.VIGNETTE=this.vignetteEnabled,t.VIGNETTEBLENDMODEMULTIPLY=this.vignetteBlendMode===e._VIGNETTEMODE_MULTIPLY,t.VIGNETTEBLENDMODEOPAQUE=!t.VIGNETTEBLENDMODEMULTIPLY,t.TONEMAPPING=this.toneMappingEnabled,this._toneMappingType){case e.TONEMAPPING_ACES:t.TONEMAPPING_ACES=!0;break;default:t.TONEMAPPING_ACES=!1}t.CONTRAST=1!==this.contrast,t.EXPOSURE=1!==this.exposure,t.COLORCURVES=this.colorCurvesEnabled&&!!this.colorCurves,t.COLORGRADING=this.colorGradingEnabled&&!!this.colorGradingTexture,t.COLORGRADING?t.COLORGRADING3D=this.colorGradingTexture.is3D:t.COLORGRADING3D=!1,t.SAMPLER3DGREENDEPTH=this.colorGradingWithGreenDepth,t.SAMPLER3DBGRMAP=this.colorGradingBGR,t.IMAGEPROCESSINGPOSTPROCESS=this.applyByPostProcess,t.IMAGEPROCESSING=t.VIGNETTE||t.TONEMAPPING||t.CONTRAST||t.EXPOSURE||t.COLORCURVES||t.COLORGRADING},e.prototype.isReady=function(){return!this.colorGradingEnabled||!this.colorGradingTexture||this.colorGradingTexture.isReady()},e.prototype.bind=function(e,t){if(this._colorCurvesEnabled&&this.colorCurves&&l.Bind(this.colorCurves,e),this._vignetteEnabled){var i=1/e.getEngine().getRenderWidth(),r=1/e.getEngine().getRenderHeight();e.setFloat2("vInverseScreenSize",i,r);var n=null!=t?t:r/i,o=Math.tan(.5*this.vignetteCameraFov),a=o*n,h=Math.sqrt(a*o);a=s.b.Mix(a,h,this.vignetteStretch),o=s.b.Mix(o,h,this.vignetteStretch),e.setFloat4("vignetteSettings1",a,o,-a*this.vignetteCentreX,-o*this.vignetteCentreY);var c=-2*this.vignetteWeight;e.setFloat4("vignetteSettings2",this.vignetteColor.r,this.vignetteColor.g,this.vignetteColor.b,c)}if(e.setFloat("exposureLinear",this.exposure),e.setFloat("contrast",this.contrast),this.colorGradingTexture){e.setTexture("txColorTransform",this.colorGradingTexture);var u=this.colorGradingTexture.getSize().height;e.setFloat4("colorTransformSettings",(u-1)/u,.5/u,u,this.colorGradingTexture.level)}},e.prototype.clone=function(){return n.a.Clone((function(){return new e}),this)},e.prototype.serialize=function(){return n.a.Serialize(this)},e.Parse=function(t){return n.a.Parse((function(){return new e}),t,null,null)},Object.defineProperty(e,"VIGNETTEMODE_MULTIPLY",{get:function(){return this._VIGNETTEMODE_MULTIPLY},enumerable:!1,configurable:!0}),Object.defineProperty(e,"VIGNETTEMODE_OPAQUE",{get:function(){return this._VIGNETTEMODE_OPAQUE},enumerable:!1,configurable:!0}),e.TONEMAPPING_STANDARD=0,e.TONEMAPPING_ACES=1,e._VIGNETTEMODE_MULTIPLY=0,e._VIGNETTEMODE_OPAQUE=1,Object(r.b)([Object(n.f)()],e.prototype,"colorCurves",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_colorCurvesEnabled",void 0),Object(r.b)([Object(n.j)("colorGradingTexture")],e.prototype,"_colorGradingTexture",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_colorGradingEnabled",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_colorGradingWithGreenDepth",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_colorGradingBGR",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_exposure",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_toneMappingEnabled",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_toneMappingType",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_contrast",void 0),Object(r.b)([Object(n.c)()],e.prototype,"vignetteStretch",void 0),Object(r.b)([Object(n.c)()],e.prototype,"vignetteCentreX",void 0),Object(r.b)([Object(n.c)()],e.prototype,"vignetteCentreY",void 0),Object(r.b)([Object(n.c)()],e.prototype,"vignetteWeight",void 0),Object(r.b)([Object(n.e)()],e.prototype,"vignetteColor",void 0),Object(r.b)([Object(n.c)()],e.prototype,"vignetteCameraFov",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_vignetteBlendMode",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_vignetteEnabled",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_applyByPostProcess",void 0),Object(r.b)([Object(n.c)()],e.prototype,"_isEnabled",void 0),e}();n.a._ImageProcessingConfigurationParser=c.Parse},function(e,t,i){"use strict";var r=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(t,"__esModule",{value:!0}),t.Plots=t.isValidPlot=t.PLOTTYPES=t.getUniqueVals=t.matrixMin=t.matrixMax=t.Plot=t.styleText=t.buttonSVGs=void 0;var n=i(28),o=i(25),s=i(130),a=i(100),h=i(56),l=i(75),c=i(98),u=i(97),f=i(132),d=r(i(77)),p=r(i(101)),_=i(131),g=i(102).default,m=i(120),v=i(121);t.buttonSVGs={logo:'',toJson:'',labels:'',publish:'',replay:'',record:''},t.styleText=[".bbp.button-bar { position: absolute; z-index: 2; overflow: hidden; padding: 0 10px 4px 0; }",".bbp.button-bar > .button { float: right; width: 75px; height: 30px; cursor: pointer; border-radius: 2px; background-color: #f0f0f0; margin: 0 4px 0 0; }",".bbp.button-bar > .button:hover { background-color: #ddd; }",".bbp.button-bar > .button > svg { width: 75px; height: 30px; }",".bbp.label-control { position: absolute; z-index: 3; font-family: sans-serif; width: 200px; background-color: #f0f0f0; padding: 5px; border-radius: 2px; }",".bbp.label-control > label { font-size: 11pt; }",".bbp.label-control > .edit-container { overflow: auto; }",".bbp.label-control > .edit-container > .label-form { margin-top: 5px; padding-top: 20px; border-top: solid thin #ccc; }",".bbp.label-control .label-form > input { width: 100%; box-sizing: border-box; }",".bbp.label-control .label-form > button { border: none; font-weight: bold; background-color: white; padding: 5px 10px; margin: 5px 0 2px 0; width: 100%; cursor: pointer; }",".bbp.label-control .label-form > button:hover { background-color: #ddd; }",".bbp.overlay { position: absolute; z-index: 3; overflow: hidden; top: 0; left: 0; right: 0; bottom: 0; width: 100%; height: 100%; background-color: #fff5; display: flex; justify-content: center; align-items: center;}",".bbp.overlay > h5.loading-message { color: #000; font-family: Verdana, sans-serif;}",".bbp.publish-form > label { display: block; text-align: left; font-family: Verdana, sans-serif; }",".bbp.publish-form > input { width: 100%; margin-bottom: 15px; box-sizing: border-box; }",".bbp.publish-form > .publish-btn { border: none; font-weight: bold; background-color: #e95420; color: white; padding: 5px 10px; margin: 5px 0 2px 0; width: 100%; cursor: pointer; }",".bbp.publish-form > .publish-btn:hover { background-color: #ca491a }",".bbp.publish-form > .close-btn, .bbp.publish-form > .cancel-btn { border: none; font-weight: bold; background-color: white; padding: 5px 10px; margin: 5px 0 2px 0; width: 100%; cursor: pointer; }",".bbp.publish-form > .close-btn:hover, .bbp.publish-form > .cancel-btn:hover { background-color: #ddd }",".bbp.publish-form > p.form-info { font-size: 8pt; font-family: Verdana, sans-serif; }",".bbp.publish-form > p.message { font-size: 10pt; font-family: Verdana, sans-serif; }",".bbp.publish-form > p.message.warning { color: red; margin-top: 0px; }",".bbp.publish-form > p.message.success { color: green; }"].join(" ");var b=function(){function e(e,t,i,r,n,o,s,a){void 0===o&&(o=1),void 0===s&&(s=1),void 0===a&&(a=1),this._size=1,this._scene=e,this._coords=t,this._coordColors=i,this._size=r,this.legendData=n,this.xScale=o,this.yScale=s,this.zScale=a}return e.prototype.updateSize=function(){},e.prototype.update=function(){return!1},e.prototype.resetAnimation=function(){},e}();function y(e){return e.map((function(e){return e.max()})).max()}function T(e){return e.map((function(e){return e.min()})).min()}function x(e){for(var t=e.length,i=[],r=new Set,n=0;n65536){var e=this[0];return this.forEach((function(t,i,r){t65536){var e=this[0];return this.forEach((function(t,i,r){t>e&&(e=t)})),e}return Math.max.apply(null,this)},t.matrixMax=y,t.matrixMin=T,t.getUniqueVals=x;var E=i(122),A=i(123),M=i(127),S=i(128),O=i(129);t.PLOTTYPES={pointCloud:["coordinates","colorBy","colorVar"],surface:["coordinates","colorBy","colorVar"],heatMap:["coordinates","colorBy","colorVar"],imageStack:["values","indices","attributes"]},t.isValidPlot=function(e){for(var i=0;i0)if(Array.isArray(r[0]))this._annotationManager.addLabels(r);else for(var n=0;n40?o=.4:i>r&&(o=.3));var s=1;if("right"===e.position?(n.addColumnDefinition(1-o),n.addColumnDefinition(o)):(n.addColumnDefinition(o),n.addColumnDefinition(1-o),s=0),e.legendTitle&&""!==e.legendTitle?(n.addRowDefinition(.1),n.addRowDefinition(.85),n.addRowDefinition(.05)):(n.addRowDefinition(.05),n.addRowDefinition(.9),n.addRowDefinition(.05)),e.legendTitle){var a=new u.TextBlock;a.text=e.legendTitle,a.color=e.fontColor,a.fontWeight="bold",e.legendTitleFontSize?a.fontSize=e.legendTitleFontSize+"px":a.fontSize="20px",a.verticalAlignment=u.Control.VERTICAL_ALIGNMENT_BOTTOM,a.horizontalAlignment=u.Control.HORIZONTAL_ALIGNMENT_LEFT,n.addControl(a,0,s)}if(e.discrete){var h=new u.Grid;i>40?(h.addColumnDefinition(.1),h.addColumnDefinition(.4),h.addColumnDefinition(.1),h.addColumnDefinition(.4),h.addColumnDefinition(.1),h.addColumnDefinition(.4)):i>r?(h.addColumnDefinition(.1),h.addColumnDefinition(.4),h.addColumnDefinition(.1),h.addColumnDefinition(.4)):(h.addColumnDefinition(.2),h.addColumnDefinition(.8));for(b=0;br?h.addRowDefinition(.05):h.addRowDefinition(1/i);n.addControl(h,1,s);m=void 0;m="custom"===e.colorScale?d.default.scale(e.customColorScale).mode("lch").colors(i):d.default.scale(d.default.brewer[e.colorScale]).mode("lch").colors(i);for(b=0;b39?h.addControl(l,b-40,4):b>19?h.addControl(l,b-r,2):h.addControl(l,b,0);var c=new u.TextBlock;c.text=e.breaks[b].toString(),c.color=e.fontColor,c.fontSize=e.fontSize+"px",c.textHorizontalAlignment=u.Control.HORIZONTAL_ALIGNMENT_LEFT,b>39&&h.addControl(c,b-40,5),b>19?h.addControl(c,b-r,3):h.addControl(c,b,1)}}else{var f=new u.Grid;f.addColumnDefinition(.2),f.addColumnDefinition(.8),n.addControl(f,1,s);var p=115,_=.15;if(this.canvas.height<70)p=10,_=.45,f.addRowDefinition(1);else if(this.canvas.height<130)p=50,_=.3,f.addRowDefinition(1);else{var g=(this.canvas.height-115)/2;f.addRowDefinition(g,!0),f.addRowDefinition(115,!0),f.addRowDefinition(g,!0)}var m=void 0;m="custom"===e.colorScale?d.default.scale(e.customColorScale).mode("lch").colors(p):d.default.scale(d.default.brewer[e.colorScale]).mode("lch").colors(p);for(var v=new u.Grid,b=0;b0)if("object"==typeof c[0])for(var f=0;f1){for(n();-1!==r&&e._OperatorPriority[s()]>=e._OperatorPriority[u];)i.push(a());o(u),h++}else l+=c;h++}for(n();-1!==r;)"("===s()?a():i.push(a());return i},e._OperatorPriority={")":0,"(":1,"||":2,"&&":3},e._Stack=["","","","","","","","","","","","","","","","","","","",""],e}(),c=function(e){function t(t,i){void 0===i&&(i=!1);var r=e.call(this)||this;return r.define=t,r.not=i,r}return Object(s.c)(t,e),t.prototype.isTrue=function(e){var t=void 0!==e[this.define];return this.not&&(t=!t),t},t}(l),u=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return Object(s.c)(t,e),t.prototype.isTrue=function(e){return this.leftOperand.isTrue(e)||this.rightOperand.isTrue(e)},t}(l),f=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return Object(s.c)(t,e),t.prototype.isTrue=function(e){return this.leftOperand.isTrue(e)&&this.rightOperand.isTrue(e)},t}(l),d=function(e){function t(t,i,r){var n=e.call(this)||this;return n.define=t,n.operand=i,n.testValue=r,n}return Object(s.c)(t,e),t.prototype.isTrue=function(e){var t=e[this.define];void 0===t&&(t=this.define);var i=!1,r=parseInt(t),n=parseInt(this.testValue);switch(this.operand){case">":i=r>n;break;case"<":i=r=":i=r>=n;break;case"==":i=r===n}return i},t}(l),p=i(8),_=/defined\s*?\((.+?)\)/g,g=/defined\s*?\[(.+?)\]/g,m=function(){function e(){}return e.Process=function(e,t,i,r){var n=this;this._ProcessIncludes(e,t,(function(e){var o=n._ProcessShaderConversion(e,t,r);i(o)}))},e._ProcessPrecision=function(e,t){var i=t.shouldUseHighPrecisionShader;return-1===e.indexOf("precision highp float")?e=i?"precision highp float;\n"+e:"precision mediump float;\n"+e:i||(e=e.replace("precision highp float","precision mediump float")),e},e._ExtractOperation=function(e){var t=/defined\((.+)\)/.exec(e);if(t&&t.length)return new c(t[1].trim(),"!"===e[0]);for(var i="",r=0,n=0,o=["==",">=","<=","<",">"];n-1));n++);if(-1===r)return new c(e);var s=e.substring(0,r).trim(),a=e.substring(r+i.length).trim();return new d(s,i,a)},e._BuildSubExpression=function(e){e=e.replace(_,"defined[$1]");for(var t=[],i=0,r=l.infixToPostfix(e);i=2){var o=t[t.length-1],s=t[t.length-2];t.length-=2;var a="&&"==n?new f:new u;"string"==typeof o&&(o=o.replace(g,"defined($1)")),"string"==typeof s&&(s=s.replace(g,"defined($1)")),a.leftOperand="string"==typeof s?this._ExtractOperation(s):s,a.rightOperand="string"==typeof o?this._ExtractOperation(o):o,t.push(a)}}var h=t[t.length-1];return"string"==typeof h&&(h=h.replace(g,"defined($1)")),"string"==typeof h?this._ExtractOperation(h):h},e._BuildExpression=function(e,t){var i=new h,r=e.substring(0,t),n=e.substring(t);return n=n.substring(0,(n.indexOf("//")+1||n.length+1)-1).trim(),i.testExpression="#ifdef"===r?new c(n):"#ifndef"===r?new c(n,!0):this._BuildSubExpression(n),i},e._MoveCursorWithinIf=function(e,t,i){for(var r=e.currentLine;this._MoveCursor(e,i);){var o=(r=e.currentLine).substring(0,5).toLowerCase();if("#else"===o){var s=new n;return t.children.push(s),void this._MoveCursor(e,s)}if("#elif"===o){var a=this._BuildExpression(r,5);t.children.push(a),i=a}}},e._MoveCursor=function(e,t){for(;e.canRead;){e.lineIndex++;var i=e.currentLine,r=/(#ifdef)|(#else)|(#elif)|(#endif)|(#ifndef)|(#if)/.exec(i);if(r&&r.length){switch(r[0]){case"#ifdef":var o=new a;t.children.push(o);var s=this._BuildExpression(i,6);o.children.push(s),this._MoveCursorWithinIf(e,o,s);break;case"#else":case"#elif":return!0;case"#endif":return!1;case"#ifndef":o=new a;t.children.push(o);s=this._BuildExpression(i,7);o.children.push(s),this._MoveCursorWithinIf(e,o,s);break;case"#if":o=new a,s=this._BuildExpression(i,3);t.children.push(o),o.children.push(s),this._MoveCursorWithinIf(e,o,s)}}else{var h=new n;if(h.line=i,t.children.push(h),"#"===i[0]&&"d"===i[1]){var l=i.replace(";","").split(" ");h.additionalDefineKey=l[1],3===l.length&&(h.additionalDefineValue=l[2])}}}return!1},e._EvaluatePreProcessors=function(e,t,i){var r=new n,s=new o;return s.lineIndex=-1,s.lines=e.split("\n"),this._MoveCursor(s,r),r.process(t,i)},e._PreparePreProcessors=function(e){for(var t={},i=0,r=e.defines;i1?n[1]:""}return t.GL_ES="true",t.__VERSION__=e.version,t[e.platformName]="true",t},e._ProcessShaderConversion=function(e,t,i){var r=this._ProcessPrecision(e,t);if(!t.processor)return r;if(-1!==r.indexOf("#version 3"))return r.replace("#version 300 es","");var n=t.defines,o=this._PreparePreProcessors(t);return t.processor.preProcessor&&(r=t.processor.preProcessor(r,n,t.isFragment)),r=this._EvaluatePreProcessors(r,o,t),t.processor.postProcessor&&(r=t.processor.postProcessor(r,n,t.isFragment,i)),r},e._ProcessIncludes=function(t,i,r){for(var n=this,o=/#include<(.+)>(\((.*)\))*(\[(.*)\])*/g,s=o.exec(t),a=new String(t),h=!1;null!=s;){var l=s[1];if(-1!==l.indexOf("__decl__")&&(l=l.replace(/__decl__/,""),i.supportsUniformBuffers&&(l=(l=l.replace(/Vertex/,"Ubo")).replace(/Fragment/,"Ubo")),l+="Declaration"),!i.includesShadersStore[l]){var c=i.shadersRepository+"ShadersInclude/"+l+".fx";return void e._FileToolsLoadFile(c,(function(e){i.includesShadersStore[l]=e,n._ProcessIncludes(a,i,r)}))}var u=i.includesShadersStore[l];if(s[2])for(var f=s[3].split(","),d=0;d=0,s=o.exec(t)}h?this._ProcessIncludes(a.toString(),i,r):r(a)},e._FileToolsLoadFile=function(e,t,i,r,n,o){throw p.a.WarnImport("FileTools")},e}()},function(e,t,i){"use strict";i.d(t,"e",(function(){return r})),i.d(t,"c",(function(){return a})),i.d(t,"a",(function(){return h})),i.d(t,"b",(function(){return l})),i.d(t,"f",(function(){return c})),i.d(t,"g",(function(){return u})),i.d(t,"d",(function(){return f}));var r,n=i(17),o=i(0),s=i(16);!function(e){e[e.CW=0]="CW",e[e.CCW=1]="CCW"}(r||(r={}));var a=function(){function e(){}return e.Interpolate=function(e,t,i,r,n){for(var o=1-3*r+3*t,s=3*r-6*t,a=3*t,h=e,l=0;l<5;l++){var c=h*h;h-=(o*(c*h)+s*c+a*h-e)*(1/(3*o*c+2*s*h+a)),h=Math.min(1,Math.max(0,h))}return 3*Math.pow(1-h,2)*h*i+3*(1-h)*Math.pow(h,2)*n+Math.pow(h,3)},e}(),h=function(){function e(e){this._radians=e,this._radians<0&&(this._radians+=2*Math.PI)}return e.prototype.degrees=function(){return 180*this._radians/Math.PI},e.prototype.radians=function(){return this._radians},e.BetweenTwoPoints=function(t,i){var r=i.subtract(t);return new e(Math.atan2(r.y,r.x))},e.FromRadians=function(t){return new e(t)},e.FromDegrees=function(t){return new e(t*Math.PI/180)},e}(),l=function(e,t,i){this.startPoint=e,this.midPoint=t,this.endPoint=i;var n=Math.pow(t.x,2)+Math.pow(t.y,2),s=(Math.pow(e.x,2)+Math.pow(e.y,2)-n)/2,a=(n-Math.pow(i.x,2)-Math.pow(i.y,2))/2,l=(e.x-t.x)*(t.y-i.y)-(t.x-i.x)*(e.y-t.y);this.centerPoint=new o.d((s*(t.y-i.y)-a*(e.y-t.y))/l,((e.x-t.x)*a-(t.x-i.x)*s)/l),this.radius=this.centerPoint.subtract(this.startPoint).length(),this.startAngle=h.BetweenTwoPoints(this.centerPoint,this.startPoint);var c=this.startAngle.degrees(),u=h.BetweenTwoPoints(this.centerPoint,this.midPoint).degrees(),f=h.BetweenTwoPoints(this.centerPoint,this.endPoint).degrees();u-c>180&&(u-=360),u-c<-180&&(u+=360),f-u>180&&(f-=360),f-u<-180&&(f+=360),this.orientation=u-c<0?r.CW:r.CCW,this.angle=h.FromDegrees(this.orientation===r.CW?c-f:f-c)},c=function(){function e(e,t){this._points=new Array,this._length=0,this.closed=!1,this._points.push(new o.d(e,t))}return e.prototype.addLineTo=function(e,t){if(this.closed)return this;var i=new o.d(e,t),r=this._points[this._points.length-1];return this._points.push(i),this._length+=i.subtract(r).length(),this},e.prototype.addArcTo=function(e,t,i,n,s){if(void 0===s&&(s=36),this.closed)return this;var a=this._points[this._points.length-1],h=new o.d(e,t),c=new o.d(i,n),u=new l(a,h,c),f=u.angle.radians()/s;u.orientation===r.CW&&(f*=-1);for(var d=u.startAngle.radians()+f,p=0;p1)return o.d.Zero();for(var t=e*this.length(),i=0,r=0;r=i&&t<=h){var l=a.normalize(),c=t-i;return new o.d(s.x+l.x*c,s.y+l.y*c)}i=h}return o.d.Zero()},e.StartingAt=function(t,i){return new e(t,i)},e}(),u=function(){function e(e,t,i,r){void 0===t&&(t=null),void 0===r&&(r=!1),this.path=e,this._curve=new Array,this._distances=new Array,this._tangents=new Array,this._normals=new Array,this._binormals=new Array,this._pointAtData={id:0,point:o.e.Zero(),previousPointArrayIndex:0,position:0,subPosition:0,interpolateReady:!1,interpolationMatrix:o.a.Identity()};for(var n=0;ni){var r=t;t=i,i=r}var n=this.getCurve(),o=this.getPointAt(t),s=this.getPreviousPointIndexAt(t),a=this.getPointAt(i),h=this.getPreviousPointIndexAt(i)+1,l=[];return 0!==t&&(s++,l.push(o)),l.push.apply(l,n.slice(s,h)),1===i&&1!==t||l.push(a),new e(l,this.getNormalAt(t),this._raw,this._alignTangentsWithPath)},e.prototype.update=function(e,t,i){void 0===t&&(t=null),void 0===i&&(i=!1);for(var r=0;rt+1;)t++,i=this._curve[e].subtract(this._curve[e-t]);return i},e.prototype._normalVector=function(e,t){var i,r,a=e.length();(0===a&&(a=1),null==t)?(r=n.a.WithinEpsilon(Math.abs(e.y)/a,1,s.a)?n.a.WithinEpsilon(Math.abs(e.x)/a,1,s.a)?n.a.WithinEpsilon(Math.abs(e.z)/a,1,s.a)?o.e.Zero():new o.e(0,0,1):new o.e(1,0,0):new o.e(0,-1,0),i=o.e.Cross(e,r)):(i=o.e.Cross(e,t),o.e.CrossToRef(i,e,i));return i.normalize(),i},e.prototype._updatePointAtData=function(e,t){if(void 0===t&&(t=!1),this._pointAtData.id===e)return this._pointAtData.interpolateReady||this._updateInterpolationMatrix(),this._pointAtData;this._pointAtData.id=e;var i=this.getPoints();if(e<=0)return this._setPointAtData(0,0,i[0],0,t);if(e>=1)return this._setPointAtData(1,1,i[i.length-1],i.length-1,t);for(var r,n=i[0],s=0,a=e*this.length(),h=1;ha){var c=(s-a)/l,u=n.subtract(r),f=r.add(u.scaleInPlace(c));return this._setPointAtData(e,1-c,f,h-1,t)}n=r}return this._pointAtData},e.prototype._setPointAtData=function(e,t,i,r,n){return this._pointAtData.point=i,this._pointAtData.position=e,this._pointAtData.subPosition=t,this._pointAtData.previousPointArrayIndex=r,this._pointAtData.interpolateReady=n,n&&this._updateInterpolationMatrix(),this._pointAtData},e.prototype._updateInterpolationMatrix=function(){this._pointAtData.interpolationMatrix=o.a.Identity();var e=this._pointAtData.previousPointArrayIndex;if(e!==this._tangents.length-1){var t=e+1,i=this._tangents[e].clone(),r=this._normals[e].clone(),n=this._binormals[e].clone(),s=this._tangents[t].clone(),a=this._normals[t].clone(),h=this._binormals[t].clone(),l=o.b.RotationQuaternionFromAxis(r,n,i),c=o.b.RotationQuaternionFromAxis(a,h,s);o.b.Slerp(l,c,this._pointAtData.subPosition).toRotationMatrix(this._pointAtData.interpolationMatrix)}},e}(),f=function(){function e(e){this._length=0,this._points=e,this._length=this._computeLength(e)}return e.CreateQuadraticBezier=function(t,i,r,n){n=n>2?n:3;for(var s=new Array,a=function(e,t,i,r){return(1-e)*(1-e)*t+2*e*(1-e)*i+e*e*r},h=0;h<=n;h++)s.push(new o.e(a(h/n,t.x,i.x,r.x),a(h/n,t.y,i.y,r.y),a(h/n,t.z,i.z,r.z)));return new e(s)},e.CreateCubicBezier=function(t,i,r,n,s){s=s>3?s:4;for(var a=new Array,h=function(e,t,i,r,n){return(1-e)*(1-e)*(1-e)*t+3*e*(1-e)*(1-e)*i+3*e*e*(1-e)*r+e*e*e*n},l=0;l<=s;l++)a.push(new o.e(h(l/s,t.x,i.x,r.x,n.x),h(l/s,t.y,i.y,r.y,n.y),h(l/s,t.z,i.z,r.z,n.z)));return new e(a)},e.CreateHermiteSpline=function(t,i,r,n,s){for(var a=new Array,h=1/s,l=0;l<=s;l++)a.push(o.e.Hermite(t,i,r,n,l*h));return new e(a)},e.CreateCatmullRomSpline=function(t,i,r){var n=new Array,s=1/i,a=0;if(r){for(var h=t.length,l=0;lthis._maxRank&&(this._maxRank=e),this._defines[e]=new Array),this._defines[e].push(t)},e.prototype.addCPUSkinningFallback=function(e,t){this._mesh=t,ethis._maxRank&&(this._maxRank=e)},Object.defineProperty(e.prototype,"hasMoreFallbacks",{get:function(){return this._currentRank<=this._maxRank},enumerable:!1,configurable:!0}),e.prototype.reduce=function(e,t){if(this._mesh&&this._mesh.computeBonesUsingShaders&&this._mesh.numBoneInfluencers>0){this._mesh.computeBonesUsingShaders=!1,e=e.replace("#define NUM_BONE_INFLUENCERS "+this._mesh.numBoneInfluencers,"#define NUM_BONE_INFLUENCERS 0"),t._bonesComputationForcedToCPU=!0;for(var i=this._mesh.getScene(),r=0;r0&&(n.computeBonesUsingShaders=!1)}}else{var a=this._defines[this._currentRank];if(a)for(r=0;ri._alphaIndex?1:t._alphaIndext._distanceToCamera?-1:0},e.frontToBackSortCompare=function(e,t){return e._distanceToCamerat._distanceToCamera?1:0},e.prototype.prepare=function(){this._opaqueSubMeshes.reset(),this._transparentSubMeshes.reset(),this._alphaTestSubMeshes.reset(),this._depthOnlySubMeshes.reset(),this._particleSystems.reset(),this._spriteManagers.reset(),this._edgesRenderers.reset()},e.prototype.dispose=function(){this._opaqueSubMeshes.dispose(),this._transparentSubMeshes.dispose(),this._alphaTestSubMeshes.dispose(),this._depthOnlySubMeshes.dispose(),this._particleSystems.dispose(),this._spriteManagers.dispose(),this._edgesRenderers.dispose()},e.prototype.dispatch=function(e,t,i){void 0===t&&(t=e.getMesh()),void 0===i&&(i=e.getMaterial()),null!=i&&(i.needAlphaBlendingForMesh(t)?this._transparentSubMeshes.push(e):i.needAlphaTesting()?(i.needDepthPrePass&&this._depthOnlySubMeshes.push(e),this._alphaTestSubMeshes.push(e)):(i.needDepthPrePass&&this._depthOnlySubMeshes.push(e),this._opaqueSubMeshes.push(e)),t._renderingGroup=this,t._edgesRenderer&&t._edgesRenderer.isEnabled&&this._edgesRenderers.pushNoDuplicate(t._edgesRenderer))},e.prototype.dispatchSprites=function(e){this._spriteManagers.push(e)},e.prototype.dispatchParticles=function(e){this._particleSystems.push(e)},e.prototype._renderParticles=function(e){if(0!==this._particleSystems.length){var t=this._scene.activeCamera;this._scene.onBeforeParticlesRenderingObservable.notifyObservers(this._scene);for(var i=0;i0;)m.unshift(m.pop()),b.unshift(b.pop()),p--;for(;_>0;)v.unshift(v.pop()),y.unshift(y.pop()),_--;m=m.flat(),v=v.flat(),g=g.concat(m).concat(v),i.push(b[0],b[2],b[3],b[0],b[1],b[2]),i.push(y[0],y[2],y[3],y[0],y[1],y[2])}var T=[h/2,l/2,c/2];t=g.reduce((function(e,t,i){return e.concat(t*T[i%3])}),[]);for(var x=0===e.sideOrientation?0:e.sideOrientation||s.VertexData.DEFAULTSIDE,E=e.faceUV||new Array(6),A=e.faceColors,M=[],S=0;S<6;S++)void 0===E[S]&&(E[S]=new r.f(0,0,1,1)),A&&void 0===A[S]&&(A[S]=new n.b(1,1,1,1));for(var O=0;O<6;O++)if(a.push(E[O].z,E[O].w),a.push(E[O].x,E[O].w),a.push(E[O].x,E[O].y),a.push(E[O].z,E[O].y),A)for(var P=0;P<4;P++)M.push(A[O].r,A[O].g,A[O].b,A[O].a);s.VertexData._ComputeSides(x,t,i,o,a,e.frontUVs,e.backUVs);var C=new s.VertexData;if(C.indices=i,C.positions=t,C.normals=o,C.uvs=a,A){var I=x===s.VertexData.DOUBLESIDE?M.concat(M):M;C.colors=I}return C},o.Mesh.CreateBox=function(e,t,i,r,n){void 0===i&&(i=null);var o={size:t,sideOrientation:n,updatable:r};return a.CreateBox(e,o,i)};var a=function(){function e(){}return e.CreateBox=function(e,t,i){void 0===i&&(i=null);var r=new o.Mesh(e,i);return t.sideOrientation=o.Mesh._GetDefaultSideOrientation(t.sideOrientation),r._originalBuilderSideOrientation=t.sideOrientation,s.VertexData.CreateBox(t).applyToMesh(r,t.updatable),r},e}()},function(e,t,i){"use strict";var r="helperFunctions",n="const float PI=3.1415926535897932384626433832795;\nconst float HALF_MIN=5.96046448e-08;\nconst float LinearEncodePowerApprox=2.2;\nconst float GammaEncodePowerApprox=1.0/LinearEncodePowerApprox;\nconst vec3 LuminanceEncodeApprox=vec3(0.2126,0.7152,0.0722);\nconst float Epsilon=0.0000001;\n#define saturate(x) clamp(x,0.0,1.0)\n#define absEps(x) abs(x)+Epsilon\n#define maxEps(x) max(x,Epsilon)\n#define saturateEps(x) clamp(x,Epsilon,1.0)\nmat3 transposeMat3(mat3 inMatrix) {\nvec3 i0=inMatrix[0];\nvec3 i1=inMatrix[1];\nvec3 i2=inMatrix[2];\nmat3 outMatrix=mat3(\nvec3(i0.x,i1.x,i2.x),\nvec3(i0.y,i1.y,i2.y),\nvec3(i0.z,i1.z,i2.z)\n);\nreturn outMatrix;\n}\n\nmat3 inverseMat3(mat3 inMatrix) {\nfloat a00=inMatrix[0][0],a01=inMatrix[0][1],a02=inMatrix[0][2];\nfloat a10=inMatrix[1][0],a11=inMatrix[1][1],a12=inMatrix[1][2];\nfloat a20=inMatrix[2][0],a21=inMatrix[2][1],a22=inMatrix[2][2];\nfloat b01=a22*a11-a12*a21;\nfloat b11=-a22*a10+a12*a20;\nfloat b21=a21*a10-a11*a20;\nfloat det=a00*b01+a01*b11+a02*b21;\nreturn mat3(b01,(-a22*a01+a02*a21),(a12*a01-a02*a11),\nb11,(a22*a00-a02*a20),(-a12*a00+a02*a10),\nb21,(-a21*a00+a01*a20),(a11*a00-a01*a10))/det;\n}\nfloat toLinearSpace(float color)\n{\nreturn pow(color,LinearEncodePowerApprox);\n}\nvec3 toLinearSpace(vec3 color)\n{\nreturn pow(color,vec3(LinearEncodePowerApprox));\n}\nvec4 toLinearSpace(vec4 color)\n{\nreturn vec4(pow(color.rgb,vec3(LinearEncodePowerApprox)),color.a);\n}\nvec3 toGammaSpace(vec3 color)\n{\nreturn pow(color,vec3(GammaEncodePowerApprox));\n}\nvec4 toGammaSpace(vec4 color)\n{\nreturn vec4(pow(color.rgb,vec3(GammaEncodePowerApprox)),color.a);\n}\nfloat toGammaSpace(float color)\n{\nreturn pow(color,GammaEncodePowerApprox);\n}\nfloat square(float value)\n{\nreturn value*value;\n}\nfloat pow5(float value) {\nfloat sq=value*value;\nreturn sq*sq*value;\n}\nfloat getLuminance(vec3 color)\n{\nreturn clamp(dot(color,LuminanceEncodeApprox),0.,1.);\n}\n\nfloat getRand(vec2 seed) {\nreturn fract(sin(dot(seed.xy ,vec2(12.9898,78.233)))*43758.5453);\n}\nfloat dither(vec2 seed,float varianceAmount) {\nfloat rand=getRand(seed);\nfloat dither=mix(-varianceAmount/255.0,varianceAmount/255.0,rand);\nreturn dither;\n}\n\nconst float rgbdMaxRange=255.0;\nvec4 toRGBD(vec3 color) {\nfloat maxRGB=maxEps(max(color.r,max(color.g,color.b)));\nfloat D=max(rgbdMaxRange/maxRGB,1.);\nD=clamp(floor(D)/255.0,0.,1.);\n\nvec3 rgb=color.rgb*D;\n\nrgb=toGammaSpace(rgb);\nreturn vec4(rgb,D);\n}\nvec3 fromRGBD(vec4 rgbd) {\n\nrgbd.rgb=toLinearSpace(rgbd.rgb);\n\nreturn rgbd.rgb/rgbd.a;\n}\n";i(5).a.IncludesShadersStore[r]=n},function(e,t,i){e.exports=function(){"use strict";for(var e=function(e,t,i){return void 0===t&&(t=0),void 0===i&&(i=1),ei?i:e},t=function(t){t._clipped=!1,t._unclipped=t.slice(0);for(var i=0;i<=3;i++)i<3?((t[i]<0||t[i]>255)&&(t._clipped=!0),t[i]=e(t[i],0,255)):3===i&&(t[i]=e(t[i],0,1));return t},i={},r=0,n=["Boolean","Number","String","Function","Array","Date","RegExp","Undefined","Null"];r=3?Array.prototype.slice.call(e):"object"==s(e[0])&&t?t.split("").filter((function(t){return void 0!==e[0][t]})).map((function(t){return e[0][t]})):e[0]},h=function(e){if(e.length<2)return null;var t=e.length-1;return"string"==s(e[t])?e[t].toLowerCase():null},l=Math.PI,c={clip_rgb:t,limit:e,type:s,unpack:a,last:h,PI:l,TWOPI:2*l,PITHIRD:l/3,DEG2RAD:l/180,RAD2DEG:180/l},u={format:{},autodetect:[]},f=c.last,d=c.clip_rgb,p=c.type,_=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=this;if("object"===p(e[0])&&e[0].constructor&&e[0].constructor===this.constructor)return e[0];var r=f(e),n=!1;if(!r){n=!0,u.sorted||(u.autodetect=u.autodetect.sort((function(e,t){return t.p-e.p})),u.sorted=!0);for(var o=0,s=u.autodetect;o4?e[4]:1;return 1===o?[0,0,0,s]:[i>=1?0:255*(1-i)*(1-o),r>=1?0:255*(1-r)*(1-o),n>=1?0:255*(1-n)*(1-o),s]},A=c.unpack,M=c.type;g.prototype.cmyk=function(){return T(this._rgb)},v.cmyk=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["cmyk"])))},u.format.cmyk=E,u.autodetect.push({p:2,test:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];if(e=A(e,"cmyk"),"array"===M(e)&&4===e.length)return"cmyk"}});var S=c.unpack,O=c.last,P=function(e){return Math.round(100*e)/100},C=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=S(e,"hsla"),r=O(e)||"lsa";return i[0]=P(i[0]||0),i[1]=P(100*i[1])+"%",i[2]=P(100*i[2])+"%","hsla"===r||i.length>3&&i[3]<1?(i[3]=i.length>3?i[3]:1,r="hsla"):i.length=3,r+"("+i.join(",")+")"},I=c.unpack,R=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=(e=I(e,"rgba"))[0],r=e[1],n=e[2];i/=255,r/=255,n/=255;var o,s,a=Math.min(i,r,n),h=Math.max(i,r,n),l=(h+a)/2;return h===a?(o=0,s=Number.NaN):o=l<.5?(h-a)/(h+a):(h-a)/(2-h-a),i==h?s=(r-n)/(h-a):r==h?s=2+(n-i)/(h-a):n==h&&(s=4+(i-r)/(h-a)),(s*=60)<0&&(s+=360),e.length>3&&void 0!==e[3]?[s,o,l,e[3]]:[s,o,l]},D=c.unpack,w=c.last,L=Math.round,F=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=D(e,"rgba"),r=w(e)||"rgb";return"hsl"==r.substr(0,3)?C(R(i),r):(i[0]=L(i[0]),i[1]=L(i[1]),i[2]=L(i[2]),("rgba"===r||i.length>3&&i[3]<1)&&(i[3]=i.length>3?i[3]:1,r="rgba"),r+"("+i.slice(0,"rgb"===r?3:4).join(",")+")")},N=c.unpack,B=Math.round,k=function(){for(var e,t=[],i=arguments.length;i--;)t[i]=arguments[i];var r,n,o,s=(t=N(t,"hsl"))[0],a=t[1],h=t[2];if(0===a)r=n=o=255*h;else{var l=[0,0,0],c=[0,0,0],u=h<.5?h*(1+a):h+a-h*a,f=2*h-u,d=s/360;l[0]=d+1/3,l[1]=d,l[2]=d-1/3;for(var p=0;p<3;p++)l[p]<0&&(l[p]+=1),l[p]>1&&(l[p]-=1),6*l[p]<1?c[p]=f+6*(u-f)*l[p]:2*l[p]<1?c[p]=u:3*l[p]<2?c[p]=f+(u-f)*(2/3-l[p])*6:c[p]=f;r=(e=[B(255*c[0]),B(255*c[1]),B(255*c[2])])[0],n=e[1],o=e[2]}return t.length>3?[r,n,o,t[3]]:[r,n,o,1]},U=/^rgb\(\s*(-?\d+),\s*(-?\d+)\s*,\s*(-?\d+)\s*\)$/,V=/^rgba\(\s*(-?\d+),\s*(-?\d+)\s*,\s*(-?\d+)\s*,\s*([01]|[01]?\.\d+)\)$/,j=/^rgb\(\s*(-?\d+(?:\.\d+)?)%,\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*\)$/,z=/^rgba\(\s*(-?\d+(?:\.\d+)?)%,\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*,\s*([01]|[01]?\.\d+)\)$/,W=/^hsl\(\s*(-?\d+(?:\.\d+)?),\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*\)$/,G=/^hsla\(\s*(-?\d+(?:\.\d+)?),\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*,\s*([01]|[01]?\.\d+)\)$/,H=Math.round,X=function(e){var t;if(e=e.toLowerCase().trim(),u.format.named)try{return u.format.named(e)}catch(e){}if(t=e.match(U)){for(var i=t.slice(1,4),r=0;r<3;r++)i[r]=+i[r];return i[3]=1,i}if(t=e.match(V)){for(var n=t.slice(1,5),o=0;o<4;o++)n[o]=+n[o];return n}if(t=e.match(j)){for(var s=t.slice(1,4),a=0;a<3;a++)s[a]=H(2.55*s[a]);return s[3]=1,s}if(t=e.match(z)){for(var h=t.slice(1,5),l=0;l<3;l++)h[l]=H(2.55*h[l]);return h[3]=+h[3],h}if(t=e.match(W)){var c=t.slice(1,4);c[1]*=.01,c[2]*=.01;var f=k(c);return f[3]=1,f}if(t=e.match(G)){var d=t.slice(1,4);d[1]*=.01,d[2]*=.01;var p=k(d);return p[3]=+t[4],p}};X.test=function(e){return U.test(e)||V.test(e)||j.test(e)||z.test(e)||W.test(e)||G.test(e)};var K=X,Y=c.type;g.prototype.css=function(e){return F(this._rgb,e)},v.css=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["css"])))},u.format.css=K,u.autodetect.push({p:5,test:function(e){for(var t=[],i=arguments.length-1;i-- >0;)t[i]=arguments[i+1];if(!t.length&&"string"===Y(e)&&K.test(e))return"css"}});var q=c.unpack;u.format.gl=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=q(e,"rgba");return i[0]*=255,i[1]*=255,i[2]*=255,i},v.gl=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["gl"])))},g.prototype.gl=function(){var e=this._rgb;return[e[0]/255,e[1]/255,e[2]/255,e[3]]};var Z=c.unpack,Q=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i,r=Z(e,"rgb"),n=r[0],o=r[1],s=r[2],a=Math.min(n,o,s),h=Math.max(n,o,s),l=h-a,c=100*l/255,u=a/(255-l)*100;return 0===l?i=Number.NaN:(n===h&&(i=(o-s)/l),o===h&&(i=2+(s-n)/l),s===h&&(i=4+(n-o)/l),(i*=60)<0&&(i+=360)),[i,c,u]},J=c.unpack,$=Math.floor,ee=function(){for(var e,t,i,r,n,o,s=[],a=arguments.length;a--;)s[a]=arguments[a];var h,l,c,u=(s=J(s,"hcg"))[0],f=s[1],d=s[2];d*=255;var p=255*f;if(0===f)h=l=c=d;else{360===u&&(u=0),u>360&&(u-=360),u<0&&(u+=360);var _=$(u/=60),g=u-_,m=d*(1-f),v=m+p*(1-g),b=m+p*g,y=m+p;switch(_){case 0:h=(e=[y,b,m])[0],l=e[1],c=e[2];break;case 1:h=(t=[v,y,m])[0],l=t[1],c=t[2];break;case 2:h=(i=[m,y,b])[0],l=i[1],c=i[2];break;case 3:h=(r=[m,v,y])[0],l=r[1],c=r[2];break;case 4:h=(n=[b,m,y])[0],l=n[1],c=n[2];break;case 5:h=(o=[y,m,v])[0],l=o[1],c=o[2]}}return[h,l,c,s.length>3?s[3]:1]},te=c.unpack,ie=c.type;g.prototype.hcg=function(){return Q(this._rgb)},v.hcg=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["hcg"])))},u.format.hcg=ee,u.autodetect.push({p:1,test:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];if(e=te(e,"hcg"),"array"===ie(e)&&3===e.length)return"hcg"}});var re=c.unpack,ne=c.last,oe=Math.round,se=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=re(e,"rgba"),r=i[0],n=i[1],o=i[2],s=i[3],a=ne(e)||"auto";void 0===s&&(s=1),"auto"===a&&(a=s<1?"rgba":"rgb");var h="000000"+((r=oe(r))<<16|(n=oe(n))<<8|(o=oe(o))).toString(16);h=h.substr(h.length-6);var l="0"+oe(255*s).toString(16);switch(l=l.substr(l.length-2),a.toLowerCase()){case"rgba":return"#"+h+l;case"argb":return"#"+l+h;default:return"#"+h}},ae=/^#?([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/,he=/^#?([A-Fa-f0-9]{8}|[A-Fa-f0-9]{4})$/,le=function(e){if(e.match(ae)){4!==e.length&&7!==e.length||(e=e.substr(1)),3===e.length&&(e=(e=e.split(""))[0]+e[0]+e[1]+e[1]+e[2]+e[2]);var t=parseInt(e,16);return[t>>16,t>>8&255,255&t,1]}if(e.match(he)){5!==e.length&&9!==e.length||(e=e.substr(1)),4===e.length&&(e=(e=e.split(""))[0]+e[0]+e[1]+e[1]+e[2]+e[2]+e[3]+e[3]);var i=parseInt(e,16);return[i>>24&255,i>>16&255,i>>8&255,Math.round((255&i)/255*100)/100]}throw new Error("unknown hex color: "+e)},ce=c.type;g.prototype.hex=function(e){return se(this._rgb,e)},v.hex=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["hex"])))},u.format.hex=le,u.autodetect.push({p:4,test:function(e){for(var t=[],i=arguments.length-1;i-- >0;)t[i]=arguments[i+1];if(!t.length&&"string"===ce(e)&&[3,4,5,6,7,8,9].indexOf(e.length)>=0)return"hex"}});var ue=c.unpack,fe=c.TWOPI,de=Math.min,pe=Math.sqrt,_e=Math.acos,ge=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i,r=ue(e,"rgb"),n=r[0],o=r[1],s=r[2],a=de(n/=255,o/=255,s/=255),h=(n+o+s)/3,l=h>0?1-a/h:0;return 0===l?i=NaN:(i=(n-o+(n-s))/2,i/=pe((n-o)*(n-o)+(n-s)*(o-s)),i=_e(i),s>o&&(i=fe-i),i/=fe),[360*i,l,h]},me=c.unpack,ve=c.limit,be=c.TWOPI,ye=c.PITHIRD,Te=Math.cos,xe=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i,r,n,o=(e=me(e,"hsi"))[0],s=e[1],a=e[2];return isNaN(o)&&(o=0),isNaN(s)&&(s=0),o>360&&(o-=360),o<0&&(o+=360),(o/=360)<1/3?r=1-((n=(1-s)/3)+(i=(1+s*Te(be*o)/Te(ye-be*o))/3)):o<2/3?n=1-((i=(1-s)/3)+(r=(1+s*Te(be*(o-=1/3))/Te(ye-be*o))/3)):i=1-((r=(1-s)/3)+(n=(1+s*Te(be*(o-=2/3))/Te(ye-be*o))/3)),[255*(i=ve(a*i*3)),255*(r=ve(a*r*3)),255*(n=ve(a*n*3)),e.length>3?e[3]:1]},Ee=c.unpack,Ae=c.type;g.prototype.hsi=function(){return ge(this._rgb)},v.hsi=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["hsi"])))},u.format.hsi=xe,u.autodetect.push({p:2,test:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];if(e=Ee(e,"hsi"),"array"===Ae(e)&&3===e.length)return"hsi"}});var Me=c.unpack,Se=c.type;g.prototype.hsl=function(){return R(this._rgb)},v.hsl=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["hsl"])))},u.format.hsl=k,u.autodetect.push({p:2,test:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];if(e=Me(e,"hsl"),"array"===Se(e)&&3===e.length)return"hsl"}});var Oe=c.unpack,Pe=Math.min,Ce=Math.max,Ie=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i,r,n,o=(e=Oe(e,"rgb"))[0],s=e[1],a=e[2],h=Pe(o,s,a),l=Ce(o,s,a),c=l-h;return n=l/255,0===l?(i=Number.NaN,r=0):(r=c/l,o===l&&(i=(s-a)/c),s===l&&(i=2+(a-o)/c),a===l&&(i=4+(o-s)/c),(i*=60)<0&&(i+=360)),[i,r,n]},Re=c.unpack,De=Math.floor,we=function(){for(var e,t,i,r,n,o,s=[],a=arguments.length;a--;)s[a]=arguments[a];var h,l,c,u=(s=Re(s,"hsv"))[0],f=s[1],d=s[2];if(d*=255,0===f)h=l=c=d;else{360===u&&(u=0),u>360&&(u-=360),u<0&&(u+=360);var p=De(u/=60),_=u-p,g=d*(1-f),m=d*(1-f*_),v=d*(1-f*(1-_));switch(p){case 0:h=(e=[d,v,g])[0],l=e[1],c=e[2];break;case 1:h=(t=[m,d,g])[0],l=t[1],c=t[2];break;case 2:h=(i=[g,d,v])[0],l=i[1],c=i[2];break;case 3:h=(r=[g,m,d])[0],l=r[1],c=r[2];break;case 4:h=(n=[v,g,d])[0],l=n[1],c=n[2];break;case 5:h=(o=[d,g,m])[0],l=o[1],c=o[2]}}return[h,l,c,s.length>3?s[3]:1]},Le=c.unpack,Fe=c.type;g.prototype.hsv=function(){return Ie(this._rgb)},v.hsv=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["hsv"])))},u.format.hsv=we,u.autodetect.push({p:2,test:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];if(e=Le(e,"hsv"),"array"===Fe(e)&&3===e.length)return"hsv"}});var Ne={Kn:18,Xn:.95047,Yn:1,Zn:1.08883,t0:.137931034,t1:.206896552,t2:.12841855,t3:.008856452},Be=c.unpack,ke=Math.pow,Ue=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=Be(e,"rgb"),r=i[0],n=i[1],o=i[2],s=ze(r,n,o),a=s[0],h=s[1],l=116*h-16;return[l<0?0:l,500*(a-h),200*(h-s[2])]},Ve=function(e){return(e/=255)<=.04045?e/12.92:ke((e+.055)/1.055,2.4)},je=function(e){return e>Ne.t3?ke(e,1/3):e/Ne.t2+Ne.t0},ze=function(e,t,i){return e=Ve(e),t=Ve(t),i=Ve(i),[je((.4124564*e+.3575761*t+.1804375*i)/Ne.Xn),je((.2126729*e+.7151522*t+.072175*i)/Ne.Yn),je((.0193339*e+.119192*t+.9503041*i)/Ne.Zn)]},We=Ue,Ge=c.unpack,He=Math.pow,Xe=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i,r,n,o=(e=Ge(e,"lab"))[0],s=e[1],a=e[2];return r=(o+16)/116,i=isNaN(s)?r:r+s/500,n=isNaN(a)?r:r-a/200,r=Ne.Yn*Ye(r),i=Ne.Xn*Ye(i),n=Ne.Zn*Ye(n),[Ke(3.2404542*i-1.5371385*r-.4985314*n),Ke(-.969266*i+1.8760108*r+.041556*n),Ke(.0556434*i-.2040259*r+1.0572252*n),e.length>3?e[3]:1]},Ke=function(e){return 255*(e<=.00304?12.92*e:1.055*He(e,1/2.4)-.055)},Ye=function(e){return e>Ne.t1?e*e*e:Ne.t2*(e-Ne.t0)},qe=Xe,Ze=c.unpack,Qe=c.type;g.prototype.lab=function(){return We(this._rgb)},v.lab=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["lab"])))},u.format.lab=qe,u.autodetect.push({p:2,test:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];if(e=Ze(e,"lab"),"array"===Qe(e)&&3===e.length)return"lab"}});var Je=c.unpack,$e=c.RAD2DEG,et=Math.sqrt,tt=Math.atan2,it=Math.round,rt=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=Je(e,"lab"),r=i[0],n=i[1],o=i[2],s=et(n*n+o*o),a=(tt(o,n)*$e+360)%360;return 0===it(1e4*s)&&(a=Number.NaN),[r,s,a]},nt=c.unpack,ot=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=nt(e,"rgb"),r=i[0],n=i[1],o=i[2],s=We(r,n,o),a=s[0],h=s[1],l=s[2];return rt(a,h,l)},st=c.unpack,at=c.DEG2RAD,ht=Math.sin,lt=Math.cos,ct=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=st(e,"lch"),r=i[0],n=i[1],o=i[2];return isNaN(o)&&(o=0),[r,lt(o*=at)*n,ht(o)*n]},ut=c.unpack,ft=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=(e=ut(e,"lch"))[0],r=e[1],n=e[2],o=ct(i,r,n),s=o[0],a=o[1],h=o[2],l=qe(s,a,h);return[l[0],l[1],l[2],e.length>3?e[3]:1]},dt=c.unpack,pt=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=dt(e,"hcl").reverse();return ft.apply(void 0,i)},_t=c.unpack,gt=c.type;g.prototype.lch=function(){return ot(this._rgb)},g.prototype.hcl=function(){return ot(this._rgb).reverse()},v.lch=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["lch"])))},v.hcl=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["hcl"])))},u.format.lch=ft,u.format.hcl=pt,["lch","hcl"].forEach((function(e){return u.autodetect.push({p:2,test:function(){for(var t=[],i=arguments.length;i--;)t[i]=arguments[i];if(t=_t(t,e),"array"===gt(t)&&3===t.length)return e}})}));var mt={aliceblue:"#f0f8ff",antiquewhite:"#faebd7",aqua:"#00ffff",aquamarine:"#7fffd4",azure:"#f0ffff",beige:"#f5f5dc",bisque:"#ffe4c4",black:"#000000",blanchedalmond:"#ffebcd",blue:"#0000ff",blueviolet:"#8a2be2",brown:"#a52a2a",burlywood:"#deb887",cadetblue:"#5f9ea0",chartreuse:"#7fff00",chocolate:"#d2691e",coral:"#ff7f50",cornflower:"#6495ed",cornflowerblue:"#6495ed",cornsilk:"#fff8dc",crimson:"#dc143c",cyan:"#00ffff",darkblue:"#00008b",darkcyan:"#008b8b",darkgoldenrod:"#b8860b",darkgray:"#a9a9a9",darkgreen:"#006400",darkgrey:"#a9a9a9",darkkhaki:"#bdb76b",darkmagenta:"#8b008b",darkolivegreen:"#556b2f",darkorange:"#ff8c00",darkorchid:"#9932cc",darkred:"#8b0000",darksalmon:"#e9967a",darkseagreen:"#8fbc8f",darkslateblue:"#483d8b",darkslategray:"#2f4f4f",darkslategrey:"#2f4f4f",darkturquoise:"#00ced1",darkviolet:"#9400d3",deeppink:"#ff1493",deepskyblue:"#00bfff",dimgray:"#696969",dimgrey:"#696969",dodgerblue:"#1e90ff",firebrick:"#b22222",floralwhite:"#fffaf0",forestgreen:"#228b22",fuchsia:"#ff00ff",gainsboro:"#dcdcdc",ghostwhite:"#f8f8ff",gold:"#ffd700",goldenrod:"#daa520",gray:"#808080",green:"#008000",greenyellow:"#adff2f",grey:"#808080",honeydew:"#f0fff0",hotpink:"#ff69b4",indianred:"#cd5c5c",indigo:"#4b0082",ivory:"#fffff0",khaki:"#f0e68c",laserlemon:"#ffff54",lavender:"#e6e6fa",lavenderblush:"#fff0f5",lawngreen:"#7cfc00",lemonchiffon:"#fffacd",lightblue:"#add8e6",lightcoral:"#f08080",lightcyan:"#e0ffff",lightgoldenrod:"#fafad2",lightgoldenrodyellow:"#fafad2",lightgray:"#d3d3d3",lightgreen:"#90ee90",lightgrey:"#d3d3d3",lightpink:"#ffb6c1",lightsalmon:"#ffa07a",lightseagreen:"#20b2aa",lightskyblue:"#87cefa",lightslategray:"#778899",lightslategrey:"#778899",lightsteelblue:"#b0c4de",lightyellow:"#ffffe0",lime:"#00ff00",limegreen:"#32cd32",linen:"#faf0e6",magenta:"#ff00ff",maroon:"#800000",maroon2:"#7f0000",maroon3:"#b03060",mediumaquamarine:"#66cdaa",mediumblue:"#0000cd",mediumorchid:"#ba55d3",mediumpurple:"#9370db",mediumseagreen:"#3cb371",mediumslateblue:"#7b68ee",mediumspringgreen:"#00fa9a",mediumturquoise:"#48d1cc",mediumvioletred:"#c71585",midnightblue:"#191970",mintcream:"#f5fffa",mistyrose:"#ffe4e1",moccasin:"#ffe4b5",navajowhite:"#ffdead",navy:"#000080",oldlace:"#fdf5e6",olive:"#808000",olivedrab:"#6b8e23",orange:"#ffa500",orangered:"#ff4500",orchid:"#da70d6",palegoldenrod:"#eee8aa",palegreen:"#98fb98",paleturquoise:"#afeeee",palevioletred:"#db7093",papayawhip:"#ffefd5",peachpuff:"#ffdab9",peru:"#cd853f",pink:"#ffc0cb",plum:"#dda0dd",powderblue:"#b0e0e6",purple:"#800080",purple2:"#7f007f",purple3:"#a020f0",rebeccapurple:"#663399",red:"#ff0000",rosybrown:"#bc8f8f",royalblue:"#4169e1",saddlebrown:"#8b4513",salmon:"#fa8072",sandybrown:"#f4a460",seagreen:"#2e8b57",seashell:"#fff5ee",sienna:"#a0522d",silver:"#c0c0c0",skyblue:"#87ceeb",slateblue:"#6a5acd",slategray:"#708090",slategrey:"#708090",snow:"#fffafa",springgreen:"#00ff7f",steelblue:"#4682b4",tan:"#d2b48c",teal:"#008080",thistle:"#d8bfd8",tomato:"#ff6347",turquoise:"#40e0d0",violet:"#ee82ee",wheat:"#f5deb3",white:"#ffffff",whitesmoke:"#f5f5f5",yellow:"#ffff00",yellowgreen:"#9acd32"},vt=c.type;g.prototype.name=function(){for(var e=se(this._rgb,"rgb"),t=0,i=Object.keys(mt);t0;)t[i]=arguments[i+1];if(!t.length&&"string"===vt(e)&&mt[e.toLowerCase()])return"named"}});var bt=c.unpack,yt=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=bt(e,"rgb");return(i[0]<<16)+(i[1]<<8)+i[2]},Tt=c.type,xt=function(e){if("number"==Tt(e)&&e>=0&&e<=16777215)return[e>>16,e>>8&255,255&e,1];throw new Error("unknown num color: "+e)},Et=c.type;g.prototype.num=function(){return yt(this._rgb)},v.num=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["num"])))},u.format.num=xt,u.autodetect.push({p:5,test:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];if(1===e.length&&"number"===Et(e[0])&&e[0]>=0&&e[0]<=16777215)return"num"}});var At=c.unpack,Mt=c.type,St=Math.round;g.prototype.rgb=function(e){return void 0===e&&(e=!0),!1===e?this._rgb.slice(0,3):this._rgb.slice(0,3).map(St)},g.prototype.rgba=function(e){return void 0===e&&(e=!0),this._rgb.slice(0,4).map((function(t,i){return i<3?!1===e?t:St(t):t}))},v.rgb=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["rgb"])))},u.format.rgb=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var i=At(e,"rgba");return void 0===i[3]&&(i[3]=1),i},u.autodetect.push({p:3,test:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];if(e=At(e,"rgba"),"array"===Mt(e)&&(3===e.length||4===e.length&&"number"==Mt(e[3])&&e[3]>=0&&e[3]<=1))return"rgb"}});var Ot=Math.log,Pt=function(e){var t,i,r,n=e/100;return n<66?(t=255,i=-155.25485562709179-.44596950469579133*(i=n-2)+104.49216199393888*Ot(i),r=n<20?0:.8274096064007395*(r=n-10)-254.76935184120902+115.67994401066147*Ot(r)):(t=351.97690566805693+.114206453784165*(t=n-55)-40.25366309332127*Ot(t),i=325.4494125711974+.07943456536662342*(i=n-50)-28.0852963507957*Ot(i),r=255),[t,i,r,1]},Ct=c.unpack,It=Math.round,Rt=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];for(var i,r=Ct(e,"rgb"),n=r[0],o=r[2],s=1e3,a=4e4,h=.4;a-s>h;){var l=Pt(i=.5*(a+s));l[2]/l[0]>=o/n?a=i:s=i}return It(i)};g.prototype.temp=g.prototype.kelvin=g.prototype.temperature=function(){return Rt(this._rgb)},v.temp=v.kelvin=v.temperature=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];return new(Function.prototype.bind.apply(g,[null].concat(e,["temp"])))},u.format.temp=u.format.kelvin=u.format.temperature=Pt;var Dt=c.type;g.prototype.alpha=function(e,t){return void 0===t&&(t=!1),void 0!==e&&"number"===Dt(e)?t?(this._rgb[3]=e,this):new g([this._rgb[0],this._rgb[1],this._rgb[2],e],"rgb"):this._rgb[3]},g.prototype.clipped=function(){return this._rgb._clipped||!1},g.prototype.darken=function(e){void 0===e&&(e=1);var t=this,i=t.lab();return i[0]-=Ne.Kn*e,new g(i,"lab").alpha(t.alpha(),!0)},g.prototype.brighten=function(e){return void 0===e&&(e=1),this.darken(-e)},g.prototype.darker=g.prototype.darken,g.prototype.brighter=g.prototype.brighten,g.prototype.get=function(e){var t=e.split("."),i=t[0],r=t[1],n=this[i]();if(r){var o=i.indexOf(r);if(o>-1)return n[o];throw new Error("unknown channel "+r+" in mode "+i)}return n};var wt=c.type,Lt=Math.pow,Ft=1e-7,Nt=20;g.prototype.luminance=function(e){if(void 0!==e&&"number"===wt(e)){if(0===e)return new g([0,0,0,this._rgb[3]],"rgb");if(1===e)return new g([255,255,255,this._rgb[3]],"rgb");var t=this.luminance(),i="rgb",r=Nt,n=function(t,o){var s=t.interpolate(o,.5,i),a=s.luminance();return Math.abs(e-a)e?n(t,s):n(s,o)},o=(t>e?n(new g([0,0,0]),this):n(this,new g([255,255,255]))).rgb();return new g(o.concat([this._rgb[3]]))}return Bt.apply(void 0,this._rgb.slice(0,3))};var Bt=function(e,t,i){return.2126*(e=kt(e))+.7152*(t=kt(t))+.0722*(i=kt(i))},kt=function(e){return(e/=255)<=.03928?e/12.92:Lt((e+.055)/1.055,2.4)},Ut={},Vt=c.type,jt=function(e,t,i){void 0===i&&(i=.5);for(var r=[],n=arguments.length-3;n-- >0;)r[n]=arguments[n+3];var o=r[0]||"lrgb";if(Ut[o]||r.length||(o=Object.keys(Ut)[0]),!Ut[o])throw new Error("interpolation mode "+o+" is not defined");return"object"!==Vt(e)&&(e=new g(e)),"object"!==Vt(t)&&(t=new g(t)),Ut[o](e,t,i).alpha(e.alpha()+i*(t.alpha()-e.alpha()))};g.prototype.mix=g.prototype.interpolate=function(e,t){void 0===t&&(t=.5);for(var i=[],r=arguments.length-2;r-- >0;)i[r]=arguments[r+2];return jt.apply(void 0,[this,e,t].concat(i))},g.prototype.premultiply=function(e){void 0===e&&(e=!1);var t=this._rgb,i=t[3];return e?(this._rgb=[t[0]*i,t[1]*i,t[2]*i,i],this):new g([t[0]*i,t[1]*i,t[2]*i,i],"rgb")},g.prototype.saturate=function(e){void 0===e&&(e=1);var t=this,i=t.lch();return i[1]+=Ne.Kn*e,i[1]<0&&(i[1]=0),new g(i,"lch").alpha(t.alpha(),!0)},g.prototype.desaturate=function(e){return void 0===e&&(e=1),this.saturate(-e)};var zt=c.type;g.prototype.set=function(e,t,i){void 0===i&&(i=!1);var r=e.split("."),n=r[0],o=r[1],s=this[n]();if(o){var a=n.indexOf(o);if(a>-1){if("string"==zt(t))switch(t.charAt(0)){case"+":case"-":s[a]+=+t;break;case"*":s[a]*=+t.substr(1);break;case"/":s[a]/=+t.substr(1);break;default:s[a]=+t}else{if("number"!==zt(t))throw new Error("unsupported value for Color.set");s[a]=t}var h=new g(s,n);return i?(this._rgb=h._rgb,this):h}throw new Error("unknown channel "+o+" in mode "+n)}return s};var Wt=function(e,t,i){var r=e._rgb,n=t._rgb;return new g(r[0]+i*(n[0]-r[0]),r[1]+i*(n[1]-r[1]),r[2]+i*(n[2]-r[2]),"rgb")};Ut.rgb=Wt;var Gt=Math.sqrt,Ht=Math.pow,Xt=function(e,t,i){var r=e._rgb,n=r[0],o=r[1],s=r[2],a=t._rgb,h=a[0],l=a[1],c=a[2];return new g(Gt(Ht(n,2)*(1-i)+Ht(h,2)*i),Gt(Ht(o,2)*(1-i)+Ht(l,2)*i),Gt(Ht(s,2)*(1-i)+Ht(c,2)*i),"rgb")};Ut.lrgb=Xt;var Kt=function(e,t,i){var r=e.lab(),n=t.lab();return new g(r[0]+i*(n[0]-r[0]),r[1]+i*(n[1]-r[1]),r[2]+i*(n[2]-r[2]),"lab")};Ut.lab=Kt;var Yt=function(e,t,i,r){var n,o,s,a,h,l,c,u,f,d,p,_;return"hsl"===r?(s=e.hsl(),a=t.hsl()):"hsv"===r?(s=e.hsv(),a=t.hsv()):"hcg"===r?(s=e.hcg(),a=t.hcg()):"hsi"===r?(s=e.hsi(),a=t.hsi()):"lch"!==r&&"hcl"!==r||(r="hcl",s=e.hcl(),a=t.hcl()),"h"===r.substr(0,1)&&(h=(n=s)[0],c=n[1],f=n[2],l=(o=a)[0],u=o[1],d=o[2]),isNaN(h)||isNaN(l)?isNaN(h)?isNaN(l)?_=Number.NaN:(_=l,1!=f&&0!=f||"hsv"==r||(p=u)):(_=h,1!=d&&0!=d||"hsv"==r||(p=c)):_=h+i*(l>h&&l-h>180?l-(h+360):l180?l+360-h:l-h),void 0===p&&(p=c+i*(u-c)),new g([_,p,f+i*(d-f)],r)},qt=function(e,t,i){return Yt(e,t,i,"lch")};Ut.lch=qt,Ut.hcl=qt;var Zt=function(e,t,i){var r=e.num(),n=t.num();return new g(r+i*(n-r),"num")};Ut.num=Zt;var Qt=function(e,t,i){return Yt(e,t,i,"hcg")};Ut.hcg=Qt;var Jt=function(e,t,i){return Yt(e,t,i,"hsi")};Ut.hsi=Jt;var $t=function(e,t,i){return Yt(e,t,i,"hsl")};Ut.hsl=$t;var ei=function(e,t,i){return Yt(e,t,i,"hsv")};Ut.hsv=ei;var ti=c.clip_rgb,ii=Math.pow,ri=Math.sqrt,ni=Math.PI,oi=Math.cos,si=Math.sin,ai=Math.atan2,hi=function(e,t,i){void 0===t&&(t="lrgb"),void 0===i&&(i=null);var r=e.length;i||(i=Array.from(new Array(r)).map((function(){return 1})));var n=r/i.reduce((function(e,t){return e+t}));if(i.forEach((function(e,t){i[t]*=n})),e=e.map((function(e){return new g(e)})),"lrgb"===t)return li(e,i);for(var o=e.shift(),s=o.get(t),a=[],h=0,l=0,c=0;c=360;)p-=360;s[d]=p}else s[d]=s[d]/a[d];return f/=r,new g(s,t).alpha(f>.99999?1:f,!0)},li=function(e,t){for(var i=e.length,r=[0,0,0,0],n=0;n.9999999&&(r[3]=1),new g(ti(r))},ci=c.type,ui=Math.pow,fi=function(e){var t="rgb",i=v("#ccc"),r=0,n=[0,1],o=[],s=[0,0],a=!1,h=[],l=!1,c=0,u=1,f=!1,d={},p=!0,_=1,g=function(e){if((e=e||["#fff","#000"])&&"string"===ci(e)&&v.brewer&&v.brewer[e.toLowerCase()]&&(e=v.brewer[e.toLowerCase()]),"array"===ci(e)){1===e.length&&(e=[e[0],e[0]]),e=e.slice(0);for(var t=0;t=a[i];)i++;return i-1}return 0},b=function(e){return e},y=function(e){return e},T=function(e,r){var n,l;if(null==r&&(r=!1),isNaN(e)||null===e)return i;l=r?e:a&&a.length>2?m(e)/(a.length-2):u!==c?(e-c)/(u-c):1,l=y(l),r||(l=b(l)),1!==_&&(l=ui(l,_)),l=s[0]+l*(1-s[0]-s[1]),l=Math.min(1,Math.max(0,l));var f=Math.floor(1e4*l);if(p&&d[f])n=d[f];else{if("array"===ci(h))for(var g=0;g=T&&g===o.length-1){n=h[g];break}if(l>T&&l2){var l=e.map((function(t,i){return i/(e.length-1)})),f=e.map((function(e){return(e-c)/(u-c)}));f.every((function(e,t){return l[t]===e}))||(y=function(e){if(e<=0||e>=1)return e;for(var t=0;e>=f[t+1];)t++;var i=(e-f[t])/(f[t+1]-f[t]);return l[t]+i*(l[t+1]-l[t])})}}return n=[c,u],E},E.mode=function(e){return arguments.length?(t=e,x(),E):t},E.range=function(e,t){return g(e,t),E},E.out=function(e){return l=e,E},E.spread=function(e){return arguments.length?(r=e,E):r},E.correctLightness=function(e){return null==e&&(e=!0),f=e,x(),b=f?function(e){for(var t=T(0,!0).lab()[0],i=T(1,!0).lab()[0],r=t>i,n=T(e,!0).lab()[0],o=t+(i-t)*e,s=n-o,a=0,h=1,l=20;Math.abs(s)>.01&&l-- >0;)r&&(s*=-1),s<0?(a=e,e+=.5*(h-e)):(h=e,e+=.5*(a-e)),n=T(e,!0).lab()[0],s=n-o;return e}:function(e){return e},E},E.padding=function(e){return null!=e?("number"===ci(e)&&(e=[e,e]),s=e,E):s},E.colors=function(t,i){arguments.length<2&&(i="hex");var r=[];if(0===arguments.length)r=h.slice(0);else if(1===t)r=[E(.5)];else if(t>1){var o=n[0],s=n[1]-o;r=di(0,t,!1).map((function(e){return E(o+e/(t-1)*s)}))}else{e=[];var l=[];if(a&&a.length>2)for(var c=1,u=a.length,f=1<=u;f?cu;f?c++:c--)l.push(.5*(a[c-1]+a[c]));else l=n;r=l.map((function(e){return E(e)}))}return v[i]&&(r=r.map((function(e){return e[i]()}))),r},E.cache=function(e){return null!=e?(p=e,E):p},E.gamma=function(e){return null!=e?(_=e,E):_},E.nodata=function(e){return null!=e?(i=v(e),E):i},E};function di(e,t,i){for(var r=[],n=eo;n?s++:s--)r.push(s);return r}var pi=function(e){var t,i,r,n,o,s,a;if(2===(e=e.map((function(e){return new g(e)}))).length)t=e.map((function(e){return e.lab()})),o=t[0],s=t[1],n=function(e){var t=[0,1,2].map((function(t){return o[t]+e*(s[t]-o[t])}));return new g(t,"lab")};else if(3===e.length)i=e.map((function(e){return e.lab()})),o=i[0],s=i[1],a=i[2],n=function(e){var t=[0,1,2].map((function(t){return(1-e)*(1-e)*o[t]+2*(1-e)*e*s[t]+e*e*a[t]}));return new g(t,"lab")};else if(4===e.length){var h;r=e.map((function(e){return e.lab()})),o=r[0],s=r[1],a=r[2],h=r[3],n=function(e){var t=[0,1,2].map((function(t){return(1-e)*(1-e)*(1-e)*o[t]+3*(1-e)*(1-e)*e*s[t]+3*(1-e)*e*e*a[t]+e*e*e*h[t]}));return new g(t,"lab")}}else if(5===e.length){var l=pi(e.slice(0,3)),c=pi(e.slice(2,5));n=function(e){return e<.5?l(2*e):c(2*(e-.5))}}return n},_i=function(e){var t=pi(e);return t.scale=function(){return fi(t)},t},gi=function(e,t,i){if(!gi[i])throw new Error("unknown blend mode "+i);return gi[i](e,t)},mi=function(e){return function(t,i){var r=v(i).rgb(),n=v(t).rgb();return v.rgb(e(r,n))}},vi=function(e){return function(t,i){var r=[];return r[0]=e(t[0],i[0]),r[1]=e(t[1],i[1]),r[2]=e(t[2],i[2]),r}},bi=function(e){return e},yi=function(e,t){return e*t/255},Ti=function(e,t){return e>t?t:e},xi=function(e,t){return e>t?e:t},Ei=function(e,t){return 255*(1-(1-e/255)*(1-t/255))},Ai=function(e,t){return t<128?2*e*t/255:255*(1-2*(1-e/255)*(1-t/255))},Mi=function(e,t){return 255*(1-(1-t/255)/(e/255))},Si=function(e,t){return 255===e||(e=t/255*255/(1-e/255))>255?255:e};gi.normal=mi(vi(bi)),gi.multiply=mi(vi(yi)),gi.screen=mi(vi(Ei)),gi.overlay=mi(vi(Ai)),gi.darken=mi(vi(Ti)),gi.lighten=mi(vi(xi)),gi.dodge=mi(vi(Si)),gi.burn=mi(vi(Mi));for(var Oi=gi,Pi=c.type,Ci=c.clip_rgb,Ii=c.TWOPI,Ri=Math.pow,Di=Math.sin,wi=Math.cos,Li=function(e,t,i,r,n){void 0===e&&(e=300),void 0===t&&(t=-1.5),void 0===i&&(i=1),void 0===r&&(r=1),void 0===n&&(n=[0,1]);var o,s=0;"array"===Pi(n)?o=n[1]-n[0]:(o=0,n=[n,n]);var a=function(a){var h=Ii*((e+120)/360+t*a),l=Ri(n[0]+o*a,r),c=(0!==s?i[0]+a*s:i)*l*(1-l)/2,u=wi(h),f=Di(h);return v(Ci([255*(l+c*(-.14861*u+1.78277*f)),255*(l+c*(-.29227*u-.90649*f)),255*(l+c*(1.97294*u)),1]))};return a.start=function(t){return null==t?e:(e=t,a)},a.rotations=function(e){return null==e?t:(t=e,a)},a.gamma=function(e){return null==e?r:(r=e,a)},a.hue=function(e){return null==e?i:("array"===Pi(i=e)?0==(s=i[1]-i[0])&&(i=i[1]):s=0,a)},a.lightness=function(e){return null==e?n:("array"===Pi(e)?(n=e,o=e[1]-e[0]):(n=[e,e],o=0),a)},a.scale=function(){return v.scale(a)},a.hue(i),a},Fi="0123456789abcdef",Ni=Math.floor,Bi=Math.random,ki=function(){for(var e="#",t=0;t<6;t++)e+=Fi.charAt(Ni(16*Bi()));return new g(e,"hex")},Ui=Math.log,Vi=Math.pow,ji=Math.floor,zi=Math.abs,Wi=function(e,t){void 0===t&&(t=null);var i={min:Number.MAX_VALUE,max:-1*Number.MAX_VALUE,sum:0,values:[],count:0};return"object"===s(e)&&(e=Object.values(e)),e.forEach((function(e){t&&"object"===s(e)&&(e=e[t]),null==e||isNaN(e)||(i.values.push(e),i.sum+=e,ei.max&&(i.max=e),i.count+=1)})),i.domain=[i.min,i.max],i.limits=function(e,t){return Gi(i,e,t)},i},Gi=function(e,t,i){void 0===t&&(t="equal"),void 0===i&&(i=7),"array"==s(e)&&(e=Wi(e));var r=e.min,n=e.max,o=e.values.sort((function(e,t){return e-t}));if(1===i)return[r,n];var a=[];if("c"===t.substr(0,1)&&(a.push(r),a.push(n)),"e"===t.substr(0,1)){a.push(r);for(var h=1;h 0");var l=Math.LOG10E*Ui(r),c=Math.LOG10E*Ui(n);a.push(r);for(var u=1;u200&&(y=!1)}for(var N={},B=0;Br?(i+.05)/(r+.05):(r+.05)/(i+.05)},Ki=Math.sqrt,Yi=Math.atan2,qi=Math.abs,Zi=Math.cos,Qi=Math.PI,Ji=function(e,t,i,r){void 0===i&&(i=1),void 0===r&&(r=1),e=new g(e),t=new g(t);for(var n=Array.from(e.lab()),o=n[0],s=n[1],a=n[2],h=Array.from(t.lab()),l=h[0],c=h[1],u=h[2],f=Ki(s*s+a*a),d=Ki(c*c+u*u),p=o<16?.511:.040975*o/(1+.01765*o),_=.0638*f/(1+.0131*f)+.638,m=f<1e-6?0:180*Yi(a,s)/Qi;m<0;)m+=360;for(;m>=360;)m-=360;var v=m>=164&&m<=345?.56+qi(.2*Zi(Qi*(m+168)/180)):.36+qi(.4*Zi(Qi*(m+35)/180)),b=f*f*f*f,y=Ki(b/(b+1900)),T=_*(y*v+1-y),x=f-d,E=s-c,A=a-u,M=(o-l)/(i*p),S=x/(r*_);return Ki(M*M+S*S+(E*E+A*A-x*x)/(T*T))},$i=function(e,t,i){void 0===i&&(i="lab"),e=new g(e),t=new g(t);var r=e.get(i),n=t.get(i),o=0;for(var s in r){var a=(r[s]||0)-(n[s]||0);o+=a*a}return Math.sqrt(o)},er=function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];try{return new(Function.prototype.bind.apply(g,[null].concat(e))),!0}catch(e){return!1}},tr={cool:function(){return fi([v.hsl(180,1,.9),v.hsl(250,.7,.4)])},hot:function(){return fi(["#000","#f00","#ff0","#fff"],[0,.25,.75,1]).mode("rgb")}},ir={OrRd:["#fff7ec","#fee8c8","#fdd49e","#fdbb84","#fc8d59","#ef6548","#d7301f","#b30000","#7f0000"],PuBu:["#fff7fb","#ece7f2","#d0d1e6","#a6bddb","#74a9cf","#3690c0","#0570b0","#045a8d","#023858"],BuPu:["#f7fcfd","#e0ecf4","#bfd3e6","#9ebcda","#8c96c6","#8c6bb1","#88419d","#810f7c","#4d004b"],Oranges:["#fff5eb","#fee6ce","#fdd0a2","#fdae6b","#fd8d3c","#f16913","#d94801","#a63603","#7f2704"],BuGn:["#f7fcfd","#e5f5f9","#ccece6","#99d8c9","#66c2a4","#41ae76","#238b45","#006d2c","#00441b"],YlOrBr:["#ffffe5","#fff7bc","#fee391","#fec44f","#fe9929","#ec7014","#cc4c02","#993404","#662506"],YlGn:["#ffffe5","#f7fcb9","#d9f0a3","#addd8e","#78c679","#41ab5d","#238443","#006837","#004529"],Reds:["#fff5f0","#fee0d2","#fcbba1","#fc9272","#fb6a4a","#ef3b2c","#cb181d","#a50f15","#67000d"],RdPu:["#fff7f3","#fde0dd","#fcc5c0","#fa9fb5","#f768a1","#dd3497","#ae017e","#7a0177","#49006a"],Greens:["#f7fcf5","#e5f5e0","#c7e9c0","#a1d99b","#74c476","#41ab5d","#238b45","#006d2c","#00441b"],YlGnBu:["#ffffd9","#edf8b1","#c7e9b4","#7fcdbb","#41b6c4","#1d91c0","#225ea8","#253494","#081d58"],Purples:["#fcfbfd","#efedf5","#dadaeb","#bcbddc","#9e9ac8","#807dba","#6a51a3","#54278f","#3f007d"],GnBu:["#f7fcf0","#e0f3db","#ccebc5","#a8ddb5","#7bccc4","#4eb3d3","#2b8cbe","#0868ac","#084081"],Greys:["#ffffff","#f0f0f0","#d9d9d9","#bdbdbd","#969696","#737373","#525252","#252525","#000000"],YlOrRd:["#ffffcc","#ffeda0","#fed976","#feb24c","#fd8d3c","#fc4e2a","#e31a1c","#bd0026","#800026"],PuRd:["#f7f4f9","#e7e1ef","#d4b9da","#c994c7","#df65b0","#e7298a","#ce1256","#980043","#67001f"],Blues:["#f7fbff","#deebf7","#c6dbef","#9ecae1","#6baed6","#4292c6","#2171b5","#08519c","#08306b"],PuBuGn:["#fff7fb","#ece2f0","#d0d1e6","#a6bddb","#67a9cf","#3690c0","#02818a","#016c59","#014636"],Viridis:["#440154","#482777","#3f4a8a","#31678e","#26838f","#1f9d8a","#6cce5a","#b6de2b","#fee825"],Spectral:["#9e0142","#d53e4f","#f46d43","#fdae61","#fee08b","#ffffbf","#e6f598","#abdda4","#66c2a5","#3288bd","#5e4fa2"],RdYlGn:["#a50026","#d73027","#f46d43","#fdae61","#fee08b","#ffffbf","#d9ef8b","#a6d96a","#66bd63","#1a9850","#006837"],RdBu:["#67001f","#b2182b","#d6604d","#f4a582","#fddbc7","#f7f7f7","#d1e5f0","#92c5de","#4393c3","#2166ac","#053061"],PiYG:["#8e0152","#c51b7d","#de77ae","#f1b6da","#fde0ef","#f7f7f7","#e6f5d0","#b8e186","#7fbc41","#4d9221","#276419"],PRGn:["#40004b","#762a83","#9970ab","#c2a5cf","#e7d4e8","#f7f7f7","#d9f0d3","#a6dba0","#5aae61","#1b7837","#00441b"],RdYlBu:["#a50026","#d73027","#f46d43","#fdae61","#fee090","#ffffbf","#e0f3f8","#abd9e9","#74add1","#4575b4","#313695"],BrBG:["#543005","#8c510a","#bf812d","#dfc27d","#f6e8c3","#f5f5f5","#c7eae5","#80cdc1","#35978f","#01665e","#003c30"],RdGy:["#67001f","#b2182b","#d6604d","#f4a582","#fddbc7","#ffffff","#e0e0e0","#bababa","#878787","#4d4d4d","#1a1a1a"],PuOr:["#7f3b08","#b35806","#e08214","#fdb863","#fee0b6","#f7f7f7","#d8daeb","#b2abd2","#8073ac","#542788","#2d004b"],Set2:["#66c2a5","#fc8d62","#8da0cb","#e78ac3","#a6d854","#ffd92f","#e5c494","#b3b3b3"],Accent:["#7fc97f","#beaed4","#fdc086","#ffff99","#386cb0","#f0027f","#bf5b17","#666666"],Set1:["#e41a1c","#377eb8","#4daf4a","#984ea3","#ff7f00","#ffff33","#a65628","#f781bf","#999999"],Set3:["#8dd3c7","#ffffb3","#bebada","#fb8072","#80b1d3","#fdb462","#b3de69","#fccde5","#d9d9d9","#bc80bd","#ccebc5","#ffed6f"],Dark2:["#1b9e77","#d95f02","#7570b3","#e7298a","#66a61e","#e6ab02","#a6761d","#666666"],Paired:["#a6cee3","#1f78b4","#b2df8a","#33a02c","#fb9a99","#e31a1c","#fdbf6f","#ff7f00","#cab2d6","#6a3d9a","#ffff99","#b15928"],Pastel2:["#b3e2cd","#fdcdac","#cbd5e8","#f4cae4","#e6f5c9","#fff2ae","#f1e2cc","#cccccc"],Pastel1:["#fbb4ae","#b3cde3","#ccebc5","#decbe4","#fed9a6","#ffffcc","#e5d8bd","#fddaec","#f2f2f2"]},rr=0,nr=Object.keys(ir);rr=200&&e<300}};h.headers={common:{Accept:"application/json, text/plain, */*"}},r.forEach(["delete","get","head"],(function(e){h.headers[e]={}})),r.forEach(["post","put","patch"],(function(e){h.headers[e]=r.merge(o)})),e.exports=h}).call(this,i(108))},function(e,t,i){"use strict";var r=i(41),n=i(110),o=i(112),s=i(89),a=i(113),h=i(116),l=i(117),c=i(93);e.exports=function(e){return new Promise((function(t,i){var u=e.data,f=e.headers;r.isFormData(u)&&delete f["Content-Type"];var d=new XMLHttpRequest;if(e.auth){var p=e.auth.username||"",_=e.auth.password?unescape(encodeURIComponent(e.auth.password)):"";f.Authorization="Basic "+btoa(p+":"+_)}var g=a(e.baseURL,e.url);if(d.open(e.method.toUpperCase(),s(g,e.params,e.paramsSerializer),!0),d.timeout=e.timeout,d.onreadystatechange=function(){if(d&&4===d.readyState&&(0!==d.status||d.responseURL&&0===d.responseURL.indexOf("file:"))){var r="getAllResponseHeaders"in d?h(d.getAllResponseHeaders()):null,o={data:e.responseType&&"text"!==e.responseType?d.response:d.responseText,status:d.status,statusText:d.statusText,headers:r,config:e,request:d};n(t,i,o),d=null}},d.onabort=function(){d&&(i(c("Request aborted",e,"ECONNABORTED",d)),d=null)},d.onerror=function(){i(c("Network Error",e,null,d)),d=null},d.ontimeout=function(){var t="timeout of "+e.timeout+"ms exceeded";e.timeoutErrorMessage&&(t=e.timeoutErrorMessage),i(c(t,e,"ECONNABORTED",d)),d=null},r.isStandardBrowserEnv()){var m=(e.withCredentials||l(g))&&e.xsrfCookieName?o.read(e.xsrfCookieName):void 0;m&&(f[e.xsrfHeaderName]=m)}if("setRequestHeader"in d&&r.forEach(f,(function(e,t){void 0===u&&"content-type"===t.toLowerCase()?delete f[t]:d.setRequestHeader(t,e)})),r.isUndefined(e.withCredentials)||(d.withCredentials=!!e.withCredentials),e.responseType)try{d.responseType=e.responseType}catch(t){if("json"!==e.responseType)throw t}"function"==typeof e.onDownloadProgress&&d.addEventListener("progress",e.onDownloadProgress),"function"==typeof e.onUploadProgress&&d.upload&&d.upload.addEventListener("progress",e.onUploadProgress),e.cancelToken&&e.cancelToken.promise.then((function(e){d&&(d.abort(),i(e),d=null)})),u||(u=null),d.send(u)}))}},function(e,t,i){"use strict";var r=i(111);e.exports=function(e,t,i,n,o){var s=new Error(e);return r(s,t,i,n,o)}},function(e,t,i){"use strict";var r=i(41);e.exports=function(e,t){t=t||{};var i={},n=["url","method","data"],o=["headers","auth","proxy","params"],s=["baseURL","transformRequest","transformResponse","paramsSerializer","timeout","timeoutMessage","withCredentials","adapter","responseType","xsrfCookieName","xsrfHeaderName","onUploadProgress","onDownloadProgress","decompress","maxContentLength","maxBodyLength","maxRedirects","transport","httpAgent","httpsAgent","cancelToken","socketPath","responseEncoding"],a=["validateStatus"];function h(e,t){return r.isPlainObject(e)&&r.isPlainObject(t)?r.merge(e,t):r.isPlainObject(t)?r.merge({},t):r.isArray(t)?t.slice():t}function l(n){r.isUndefined(t[n])?r.isUndefined(e[n])||(i[n]=h(void 0,e[n])):i[n]=h(e[n],t[n])}r.forEach(n,(function(e){r.isUndefined(t[e])||(i[e]=h(void 0,t[e]))})),r.forEach(o,l),r.forEach(s,(function(n){r.isUndefined(t[n])?r.isUndefined(e[n])||(i[n]=h(void 0,e[n])):i[n]=h(void 0,t[n])})),r.forEach(a,(function(r){r in t?i[r]=h(e[r],t[r]):r in e&&(i[r]=h(void 0,e[r]))}));var c=n.concat(o).concat(s).concat(a),u=Object.keys(e).concat(Object.keys(t)).filter((function(e){return-1===c.indexOf(e)}));return r.forEach(u,l),i}},function(e,t,i){"use strict";function r(e){this.message=e}r.prototype.toString=function(){return"Cancel"+(this.message?": "+this.message:"")},r.prototype.__CANCEL__=!0,e.exports=r},function(e,t,i){"use strict";i.r(t),i.d(t,"CylinderBuilder",(function(){return l}));var r=i(0),n=i(7),o=i(13),s=i(14),a=i(28),h=i(35);s.VertexData.CreateCylinder=function(e){var t=e.height||2,i=0===e.diameterTop?0:e.diameterTop||e.diameter||1,a=0===e.diameterBottom?0:e.diameterBottom||e.diameter||1;i=i||1e-5,a=a||1e-5;var l,c=e.tessellation||24,u=e.subdivisions||1,f=!!e.hasRings,d=!!e.enclose,p=0===e.cap?0:e.cap||o.Mesh.CAP_ALL,_=e.arc&&(e.arc<=0||e.arc>1)?1:e.arc||1,g=0===e.sideOrientation?0:e.sideOrientation||s.VertexData.DEFAULTSIDE,m=e.faceUV||new Array(3),v=e.faceColors,b=2+(1+(1!==_&&d?2:0))*(f?u:1);for(l=0;lr&&(r=o.width)}if(this._resizeToFit){if(this._textWrapping===a.Clip){var s=this.paddingLeftInPixels+this.paddingRightInPixels+r|0;s!==this._width.internalValue&&(this._width.updateInPlace(s,c.a.UNITMODE_PIXEL),this._rebuildLayout=!0)}var l=this.paddingTopInPixels+this.paddingBottomInPixels+this._fontOffset.height*this._lines.length|0;if(this._lines.length>0&&0!==this._lineSpacing.internalValue){var u=0;u=this._lineSpacing.isPixel?this._lineSpacing.getValue(this._host):this._lineSpacing.getValue(this._host)*this._height.getValueInPixel(this._host,this._cachedParentMeasure.height),l+=(this._lines.length-1)*u}l!==this._height.internalValue&&(this._height.updateInPlace(l,c.a.UNITMODE_PIXEL),this._rebuildLayout=!0)}},t.prototype._drawText=function(e,t,i,r){var n=this._currentMeasure.width,o=0;switch(this._textHorizontalAlignment){case h.a.HORIZONTAL_ALIGNMENT_LEFT:o=0;break;case h.a.HORIZONTAL_ALIGNMENT_RIGHT:o=n-t;break;case h.a.HORIZONTAL_ALIGNMENT_CENTER:o=(n-t)/2}(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(r.shadowColor=this.shadowColor,r.shadowBlur=this.shadowBlur,r.shadowOffsetX=this.shadowOffsetX,r.shadowOffsetY=this.shadowOffsetY),this.outlineWidth&&r.strokeText(e,this._currentMeasure.left+o,i),r.fillText(e,this._currentMeasure.left+o,i),this._underline&&(r.beginPath(),r.lineWidth=Math.round(.05*this.fontSizeInPixels),r.moveTo(this._currentMeasure.left+o,i+3),r.lineTo(this._currentMeasure.left+o+t,i+3),r.stroke(),r.closePath()),this._lineThrough&&(r.beginPath(),r.lineWidth=Math.round(.05*this.fontSizeInPixels),r.moveTo(this._currentMeasure.left+o,i-this.fontSizeInPixels/3),r.lineTo(this._currentMeasure.left+o+t,i-this.fontSizeInPixels/3),r.stroke(),r.closePath())},t.prototype._draw=function(e,t){e.save(),this._applyStates(e),this._renderLines(e),e.restore()},t.prototype._applyStates=function(t){e.prototype._applyStates.call(this,t),this.outlineWidth&&(t.lineWidth=this.outlineWidth,t.strokeStyle=this.outlineColor,t.lineJoin="miter",t.miterLimit=2)},t.prototype._breakLines=function(e,t){var i=[],r=this.text.split("\n");if(this._textWrapping===a.Ellipsis)for(var n=0,o=r;nt&&(e+="…");var n=Array.from&&Array.from(e);if(n)for(;n.length&&r>t;)n.pop(),e=n.join("")+"...",r=i.measureText(e).width;else for(;e.length>2&&r>t;)e=e.slice(0,-2)+"…",r=i.measureText(e).width;return{text:e,width:r}},t.prototype._parseLineWordWrap=function(e,t,i){void 0===e&&(e="");for(var r=[],n=this.wordSplittingFunction?this.wordSplittingFunction(e):e.split(" "),o=0,s=0;s0?e+" "+n[s]:n[0],h=i.measureText(a).width;h>t&&s>0?(r.push({text:e,width:o}),e=n[s],o=i.measureText(e).width):(o=h,e=a)}return r.push({text:e,width:o}),r},t.prototype._renderLines=function(e){var t=this._currentMeasure.height,i=0;switch(this._textVerticalAlignment){case h.a.VERTICAL_ALIGNMENT_TOP:i=this._fontOffset.ascent;break;case h.a.VERTICAL_ALIGNMENT_BOTTOM:i=t-this._fontOffset.height*(this._lines.length-1)-this._fontOffset.descent;break;case h.a.VERTICAL_ALIGNMENT_CENTER:i=this._fontOffset.ascent+(t-this._fontOffset.height*this._lines.length)/2}i+=this._currentMeasure.top;for(var r=0;r0&&0!==this._lineSpacing.internalValue){var r=0;r=this._lineSpacing.isPixel?this._lineSpacing.getValue(this._host):this._lineSpacing.getValue(this._host)*this._height.getValueInPixel(this._host,this._cachedParentMeasure.height),i+=(t.length-1)*r}return i}}return 0},t.prototype.dispose=function(){e.prototype.dispose.call(this),this.onTextChangedObservable.clear()},t}(h.a);o.a.RegisteredTypes["BABYLON.GUI.TextBlock"]=u;var f=i(12),d=function(e){function t(i,r){void 0===r&&(r=null);var n=e.call(this,i)||this;return n.name=i,n._workingCanvas=null,n._loaded=!1,n._stretch=t.STRETCH_FILL,n._autoScale=!1,n._sourceLeft=0,n._sourceTop=0,n._sourceWidth=0,n._sourceHeight=0,n._svgAttributesComputationCompleted=!1,n._isSVG=!1,n._cellWidth=0,n._cellHeight=0,n._cellId=-1,n._populateNinePatchSlicesFromImage=!1,n._imageDataCache={data:null,key:""},n.onImageLoadedObservable=new l.a,n.onSVGAttributesComputedObservable=new l.a,n.source=r,n}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"isLoaded",{get:function(){return this._loaded},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"populateNinePatchSlicesFromImage",{get:function(){return this._populateNinePatchSlicesFromImage},set:function(e){this._populateNinePatchSlicesFromImage!==e&&(this._populateNinePatchSlicesFromImage=e,this._populateNinePatchSlicesFromImage&&this._loaded&&this._extractNinePatchSliceDataFromImage())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"detectPointerOnOpaqueOnly",{get:function(){return this._detectPointerOnOpaqueOnly},set:function(e){this._detectPointerOnOpaqueOnly!==e&&(this._detectPointerOnOpaqueOnly=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"sliceLeft",{get:function(){return this._sliceLeft},set:function(e){this._sliceLeft!==e&&(this._sliceLeft=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"sliceRight",{get:function(){return this._sliceRight},set:function(e){this._sliceRight!==e&&(this._sliceRight=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"sliceTop",{get:function(){return this._sliceTop},set:function(e){this._sliceTop!==e&&(this._sliceTop=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"sliceBottom",{get:function(){return this._sliceBottom},set:function(e){this._sliceBottom!==e&&(this._sliceBottom=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"sourceLeft",{get:function(){return this._sourceLeft},set:function(e){this._sourceLeft!==e&&(this._sourceLeft=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"sourceTop",{get:function(){return this._sourceTop},set:function(e){this._sourceTop!==e&&(this._sourceTop=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"sourceWidth",{get:function(){return this._sourceWidth},set:function(e){this._sourceWidth!==e&&(this._sourceWidth=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"sourceHeight",{get:function(){return this._sourceHeight},set:function(e){this._sourceHeight!==e&&(this._sourceHeight=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isSVG",{get:function(){return this._isSVG},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"svgAttributesComputationCompleted",{get:function(){return this._svgAttributesComputationCompleted},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"autoScale",{get:function(){return this._autoScale},set:function(e){this._autoScale!==e&&(this._autoScale=e,e&&this._loaded&&this.synchronizeSizeWithContent())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"stretch",{get:function(){return this._stretch},set:function(e){this._stretch!==e&&(this._stretch=e,this._markAsDirty())},enumerable:!1,configurable:!0}),t.prototype._rotate90=function(e,i){void 0===i&&(i=!1);var r=document.createElement("canvas"),n=r.getContext("2d"),o=this._domImage.width,s=this._domImage.height;r.width=s,r.height=o,n.translate(r.width/2,r.height/2),n.rotate(e*Math.PI/2),n.drawImage(this._domImage,0,0,o,s,-o/2,-s/2,o,s);var a=r.toDataURL("image/jpg"),h=new t(this.name+"rotated",a);return i&&(h._stretch=this._stretch,h._autoScale=this._autoScale,h._cellId=this._cellId,h._cellWidth=e%1?this._cellHeight:this._cellWidth,h._cellHeight=e%1?this._cellWidth:this._cellHeight),this._handleRotationForSVGImage(this,h,e),this._imageDataCache.data=null,h},t.prototype._handleRotationForSVGImage=function(e,t,i){var r=this;e._isSVG&&(e._svgAttributesComputationCompleted?(this._rotate90SourceProperties(e,t,i),this._markAsDirty()):e.onSVGAttributesComputedObservable.addOnce((function(){r._rotate90SourceProperties(e,t,i),r._markAsDirty()})))},t.prototype._rotate90SourceProperties=function(e,t,i){var r,n,o=e.sourceLeft,s=e.sourceTop,a=e.domImage.width,h=e.domImage.height,l=o,c=s,u=e.sourceWidth,f=e.sourceHeight;if(0!=i){var d=i<0?-1:1;i%=4;for(var p=0;p127&&-1===this._sliceLeft)this._sliceLeft=o;else if(a<127&&this._sliceLeft>-1){this._sliceRight=o;break}}this._sliceTop=-1,this._sliceBottom=-1;for(var s=0;s127&&-1===this._sliceTop)this._sliceTop=s;else if(a<127&&this._sliceTop>-1){this._sliceBottom=s;break}}},Object.defineProperty(t.prototype,"source",{set:function(e){var t=this;this._source!==e&&(this._loaded=!1,this._source=e,this._imageDataCache.data=null,e&&(e=this._svgCheck(e)),this._domImage=document.createElement("img"),this._domImage.onload=function(){t._onImageLoaded()},e&&(f.b.SetCorsBehavior(e,this._domImage),this._domImage.src=e))},enumerable:!1,configurable:!0}),t.prototype._svgCheck=function(e){var t=this;if(window.SVGSVGElement&&-1!==e.search(/.svg#/gi)&&e.indexOf("#")===e.lastIndexOf("#")){this._isSVG=!0;var i=e.split("#")[0],r=e.split("#")[1],n=document.body.querySelector('object[data="'+i+'"]');if(n){var o=n.contentDocument;if(o&&o.documentElement){var s=o.documentElement.getAttribute("viewBox"),a=Number(o.documentElement.getAttribute("width")),h=Number(o.documentElement.getAttribute("height"));if(o.getElementById(r)&&s&&a&&h)return this._getSVGAttribs(n,r),e}n.addEventListener("load",(function(){t._getSVGAttribs(n,r)}))}else{var l=document.createElement("object");l.data=i,l.type="image/svg+xml",l.width="0%",l.height="0%",document.body.appendChild(l),l.onload=function(){var e=document.body.querySelector('object[data="'+i+'"]');e&&t._getSVGAttribs(e,r)}}return i}return e},t.prototype._getSVGAttribs=function(e,t){var i=e.contentDocument;if(i&&i.documentElement){var r=i.documentElement.getAttribute("viewBox"),n=Number(i.documentElement.getAttribute("width")),o=Number(i.documentElement.getAttribute("height")),s=i.getElementById(t);if(r&&n&&o&&s){var a=Number(r.split(" ")[2]),h=Number(r.split(" ")[3]),l=s.getBBox(),c=1,u=1,f=0,d=0;s.transform&&s.transform.baseVal.consolidate()&&(c=s.transform.baseVal.consolidate().matrix.a,u=s.transform.baseVal.consolidate().matrix.d,f=s.transform.baseVal.consolidate().matrix.e,d=s.transform.baseVal.consolidate().matrix.f),this.sourceLeft=(c*l.x+f)*n/a,this.sourceTop=(u*l.y+d)*o/h,this.sourceWidth=l.width*c*(n/a),this.sourceHeight=l.height*u*(o/h),this._svgAttributesComputationCompleted=!0,this.onSVGAttributesComputedObservable.notifyObservers(this)}}},Object.defineProperty(t.prototype,"cellWidth",{get:function(){return this._cellWidth},set:function(e){this._cellWidth!==e&&(this._cellWidth=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"cellHeight",{get:function(){return this._cellHeight},set:function(e){this._cellHeight!==e&&(this._cellHeight=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"cellId",{get:function(){return this._cellId},set:function(e){this._cellId!==e&&(this._cellId=e,this._markAsDirty())},enumerable:!1,configurable:!0}),t.prototype.contains=function(t,i){if(!e.prototype.contains.call(this,t,i))return!1;if(!this._detectPointerOnOpaqueOnly||!this._workingCanvas)return!0;var r=0|this._currentMeasure.width,n=0|this._currentMeasure.height,o=r+"_"+n,s=this._imageDataCache.data;if(!s||this._imageDataCache.key!==o){var a=this._workingCanvas.getContext("2d");this._imageDataCache.data=s=a.getImageData(0,0,r,n).data,this._imageDataCache.key=o}return s[4*((t=t-this._currentMeasure.left|0)+(i=i-this._currentMeasure.top|0)*r)+3]>0},t.prototype._getTypeName=function(){return"Image"},t.prototype.synchronizeSizeWithContent=function(){this._loaded&&(this.width=this._domImage.width+"px",this.height=this._domImage.height+"px")},t.prototype._processMeasures=function(i,r){if(this._loaded)switch(this._stretch){case t.STRETCH_NONE:case t.STRETCH_FILL:case t.STRETCH_UNIFORM:case t.STRETCH_NINE_PATCH:break;case t.STRETCH_EXTEND:this._autoScale&&this.synchronizeSizeWithContent(),this.parent&&this.parent.parent&&(this.parent.adaptWidthToChildren=!0,this.parent.adaptHeightToChildren=!0)}e.prototype._processMeasures.call(this,i,r)},t.prototype._prepareWorkingCanvasForOpaqueDetection=function(){if(this._detectPointerOnOpaqueOnly){this._workingCanvas||(this._workingCanvas=document.createElement("canvas"));var e=this._workingCanvas,t=this._currentMeasure.width,i=this._currentMeasure.height,r=e.getContext("2d");e.width=t,e.height=i,r.clearRect(0,0,t,i)}},t.prototype._drawImage=function(e,t,i,r,n,o,s,a,h){(e.drawImage(this._domImage,t,i,r,n,o,s,a,h),this._detectPointerOnOpaqueOnly)&&(e=this._workingCanvas.getContext("2d")).drawImage(this._domImage,t,i,r,n,o-this._currentMeasure.left,s-this._currentMeasure.top,a,h)},t.prototype._draw=function(e){var i,r,n,o;if(e.save(),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowColor=this.shadowColor,e.shadowBlur=this.shadowBlur,e.shadowOffsetX=this.shadowOffsetX,e.shadowOffsetY=this.shadowOffsetY),-1==this.cellId)i=this._sourceLeft,r=this._sourceTop,n=this._sourceWidth?this._sourceWidth:this._imageWidth,o=this._sourceHeight?this._sourceHeight:this._imageHeight;else{var s=this._domImage.naturalWidth/this.cellWidth,a=this.cellId/s>>0,h=this.cellId%s;i=this.cellWidth*h,r=this.cellHeight*a,n=this.cellWidth,o=this.cellHeight}if(this._prepareWorkingCanvasForOpaqueDetection(),this._applyStates(e),this._loaded)switch(this._stretch){case t.STRETCH_NONE:case t.STRETCH_FILL:this._drawImage(e,i,r,n,o,this._currentMeasure.left,this._currentMeasure.top,this._currentMeasure.width,this._currentMeasure.height);break;case t.STRETCH_UNIFORM:var l=this._currentMeasure.width/n,c=this._currentMeasure.height/o,u=Math.min(l,c),f=(this._currentMeasure.width-n*u)/2,d=(this._currentMeasure.height-o*u)/2;this._drawImage(e,i,r,n,o,this._currentMeasure.left+f,this._currentMeasure.top+d,n*u,o*u);break;case t.STRETCH_EXTEND:this._drawImage(e,i,r,n,o,this._currentMeasure.left,this._currentMeasure.top,this._currentMeasure.width,this._currentMeasure.height);break;case t.STRETCH_NINE_PATCH:this._renderNinePatch(e)}e.restore()},t.prototype._renderCornerPatch=function(e,t,i,r,n,o,s){this._drawImage(e,t,i,r,n,this._currentMeasure.left+o,this._currentMeasure.top+s,r,n)},t.prototype._renderNinePatch=function(e){var t=this._imageHeight,i=this._sliceLeft,r=this._sliceTop,n=this._imageHeight-this._sliceBottom,o=this._imageWidth-this._sliceRight,s=0,a=0;this._populateNinePatchSlicesFromImage&&(s=1,a=1,t-=2,i-=1,r-=1,n-=1,o-=1);var h=this._sliceRight-this._sliceLeft,l=this._currentMeasure.width-o-this.sliceLeft,c=this._currentMeasure.height-t+this._sliceBottom;this._renderCornerPatch(e,s,a,i,r,0,0),this._renderCornerPatch(e,s,this._sliceBottom,i,t-this._sliceBottom,0,c),this._renderCornerPatch(e,this._sliceRight,a,o,r,this._currentMeasure.width-o,0),this._renderCornerPatch(e,this._sliceRight,this._sliceBottom,o,t-this._sliceBottom,this._currentMeasure.width-o,c),this._drawImage(e,this._sliceLeft,this._sliceTop,h,this._sliceBottom-this._sliceTop,this._currentMeasure.left+i,this._currentMeasure.top+r,l,c-r),this._drawImage(e,s,this._sliceTop,i,this._sliceBottom-this._sliceTop,this._currentMeasure.left,this._currentMeasure.top+r,i,c-r),this._drawImage(e,this._sliceRight,this._sliceTop,i,this._sliceBottom-this._sliceTop,this._currentMeasure.left+this._currentMeasure.width-o,this._currentMeasure.top+r,i,c-r),this._drawImage(e,this._sliceLeft,a,h,r,this._currentMeasure.left+i,this._currentMeasure.top,l,r),this._drawImage(e,this._sliceLeft,this._sliceBottom,h,n,this._currentMeasure.left+i,this._currentMeasure.top+c,l,n)},t.prototype.dispose=function(){e.prototype.dispose.call(this),this.onImageLoadedObservable.clear(),this.onSVGAttributesComputedObservable.clear()},t.STRETCH_NONE=0,t.STRETCH_FILL=1,t.STRETCH_UNIFORM=2,t.STRETCH_EXTEND=3,t.STRETCH_NINE_PATCH=4,t}(h.a);o.a.RegisteredTypes["BABYLON.GUI.Image"]=d;var p=function(e){function t(t){var i=e.call(this,t)||this;i.name=t,i.delegatePickingToChildren=!1,i.thickness=1,i.isPointerBlocker=!0;var r=null;return i.pointerEnterAnimation=function(){r=i.alpha,i.alpha-=.1},i.pointerOutAnimation=function(){null!==r&&(i.alpha=r)},i.pointerDownAnimation=function(){i.scaleX-=.05,i.scaleY-=.05},i.pointerUpAnimation=function(){i.scaleX+=.05,i.scaleY+=.05},i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"image",{get:function(){return this._image},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"textBlock",{get:function(){return this._textBlock},enumerable:!1,configurable:!0}),t.prototype._getTypeName=function(){return"Button"},t.prototype._processPicking=function(t,i,r,n,o,s,a,h){if(!this._isEnabled||!this.isHitTestVisible||!this.isVisible||this.notRenderable)return!1;if(!e.prototype.contains.call(this,t,i))return!1;if(this.delegatePickingToChildren){for(var l=!1,c=this._children.length-1;c>=0;c--){var u=this._children[c];if(u.isEnabled&&u.isHitTestVisible&&u.isVisible&&!u.notRenderable&&u.contains(t,i)){l=!0;break}}if(!l)return!1}return this._processObservables(n,t,i,r,o,s,a,h),!0},t.prototype._onPointerEnter=function(t,i){return!!e.prototype._onPointerEnter.call(this,t,i)&&(this.pointerEnterAnimation&&this.pointerEnterAnimation(),!0)},t.prototype._onPointerOut=function(t,i,r){void 0===r&&(r=!1),this.pointerOutAnimation&&this.pointerOutAnimation(),e.prototype._onPointerOut.call(this,t,i,r)},t.prototype._onPointerDown=function(t,i,r,n,o){return!!e.prototype._onPointerDown.call(this,t,i,r,n,o)&&(this.pointerDownAnimation&&this.pointerDownAnimation(),!0)},t.prototype._onPointerUp=function(t,i,r,n,o,s){this.pointerUpAnimation&&this.pointerUpAnimation(),e.prototype._onPointerUp.call(this,t,i,r,n,o,s)},t.CreateImageButton=function(e,i,r){var n=new t(e),o=new u(e+"_button",i);o.textWrapping=!0,o.textHorizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_CENTER,o.paddingLeft="20%",n.addControl(o);var s=new d(e+"_icon",r);return s.width="20%",s.stretch=d.STRETCH_UNIFORM,s.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,n.addControl(s),n._image=s,n._textBlock=o,n},t.CreateImageOnlyButton=function(e,i){var r=new t(e),n=new d(e+"_icon",i);return n.stretch=d.STRETCH_FILL,n.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,r.addControl(n),r._image=n,r},t.CreateSimpleButton=function(e,i){var r=new t(e),n=new u(e+"_button",i);return n.textWrapping=!0,n.textHorizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_CENTER,r.addControl(n),r._textBlock=n,r},t.CreateImageWithCenterTextButton=function(e,i,r){var n=new t(e),o=new d(e+"_icon",r);o.stretch=d.STRETCH_FILL,n.addControl(o);var s=new u(e+"_button",i);return s.textWrapping=!0,s.textHorizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_CENTER,n.addControl(s),n._image=o,n._textBlock=s,n},t}(s);o.a.RegisteredTypes["BABYLON.GUI.Button"]=p;var _=function(e){function t(t){var i=e.call(this,t)||this;return i.name=t,i._isVertical=!0,i._manualWidth=!1,i._manualHeight=!1,i._doNotTrackManualChanges=!1,i.ignoreLayoutWarnings=!1,i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"isVertical",{get:function(){return this._isVertical},set:function(e){this._isVertical!==e&&(this._isVertical=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"width",{get:function(){return this._width.toString(this._host)},set:function(e){this._doNotTrackManualChanges||(this._manualWidth=!0),this._width.toString(this._host)!==e&&this._width.fromString(e)&&this._markAsDirty()},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"height",{get:function(){return this._height.toString(this._host)},set:function(e){this._doNotTrackManualChanges||(this._manualHeight=!0),this._height.toString(this._host)!==e&&this._height.fromString(e)&&this._markAsDirty()},enumerable:!1,configurable:!0}),t.prototype._getTypeName=function(){return"StackPanel"},t.prototype._preMeasure=function(t,i){for(var r=0,n=this._children;r=0?Math.min(e,this._characters.length):this._characters.length+Math.max(e,-this._characters.length),void 0===t?t=this._characters.length-e:(isNaN(t)||t<0)&&(t=0);for(var i=[];--t>=0;)i[t]=this._characters[e+t];return i.join("")}return this._text.substr(e,t)},e.prototype.substring=function(e,t){if(this._characters){isNaN(e)?e=0:e>this._characters.length?e=this._characters.length:e<0&&(e=0),void 0===t?t=this._characters.length:isNaN(t)?t=0:t>this._characters.length?t=this._characters.length:t<0&&(t=0);for(var i=[],r=0;e0){if(this._isTextHighlightOn)return this._textWrapper.removePart(this._startHighlightIndex,this._endHighlightIndex),this._textHasChanged(),this._isTextHighlightOn=!1,this._cursorOffset=this._textWrapper.length-this._startHighlightIndex,this._blinkIsEven=!1,void(i&&i.preventDefault());if(0===this._cursorOffset)this.text=this._textWrapper.substr(0,this._textWrapper.length-1);else(r=this._textWrapper.length-this._cursorOffset)>0&&(this._textWrapper.removePart(r-1,r),this._textHasChanged())}return void(i&&i.preventDefault());case 46:if(this._isTextHighlightOn)return this._textWrapper.removePart(this._startHighlightIndex,this._endHighlightIndex),this._textHasChanged(),this._isTextHighlightOn=!1,this._cursorOffset=this._textWrapper.length-this._startHighlightIndex,void(i&&i.preventDefault());if(this._textWrapper.text&&this._textWrapper.length>0&&this._cursorOffset>0){var r=this._textWrapper.length-this._cursorOffset;this._textWrapper.removePart(r,r+1),this._textHasChanged(),this._cursorOffset--}return void(i&&i.preventDefault());case 13:return this._host.focusedControl=null,void(this._isTextHighlightOn=!1);case 35:return this._cursorOffset=0,this._blinkIsEven=!1,this._isTextHighlightOn=!1,void this._markAsDirty();case 36:return this._cursorOffset=this._textWrapper.length,this._blinkIsEven=!1,this._isTextHighlightOn=!1,void this._markAsDirty();case 37:if(this._cursorOffset++,this._cursorOffset>this._textWrapper.length&&(this._cursorOffset=this._textWrapper.length),i&&i.shiftKey){if(this._blinkIsEven=!1,i.ctrlKey||i.metaKey){if(!this._isTextHighlightOn){if(this._textWrapper.length===this._cursorOffset)return;this._endHighlightIndex=this._textWrapper.length-this._cursorOffset+1}return this._startHighlightIndex=0,this._cursorIndex=this._textWrapper.length-this._endHighlightIndex,this._cursorOffset=this._textWrapper.length,this._isTextHighlightOn=!0,void this._markAsDirty()}return this._isTextHighlightOn?-1===this._cursorIndex&&(this._cursorIndex=this._textWrapper.length-this._endHighlightIndex,this._cursorOffset=0===this._startHighlightIndex?this._textWrapper.length:this._textWrapper.length-this._startHighlightIndex+1):(this._isTextHighlightOn=!0,this._cursorIndex=this._cursorOffset>=this._textWrapper.length?this._textWrapper.length:this._cursorOffset-1),this._cursorIndexthis._cursorOffset?(this._endHighlightIndex=this._textWrapper.length-this._cursorOffset,this._startHighlightIndex=this._textWrapper.length-this._cursorIndex):this._isTextHighlightOn=!1,void this._markAsDirty()}return this._isTextHighlightOn&&(this._cursorOffset=this._textWrapper.length-this._startHighlightIndex,this._isTextHighlightOn=!1),i&&(i.ctrlKey||i.metaKey)&&(this._cursorOffset=this._textWrapper.length,i.preventDefault()),this._blinkIsEven=!1,this._isTextHighlightOn=!1,this._cursorIndex=-1,void this._markAsDirty();case 39:if(this._cursorOffset--,this._cursorOffset<0&&(this._cursorOffset=0),i&&i.shiftKey){if(this._blinkIsEven=!1,i.ctrlKey||i.metaKey){if(!this._isTextHighlightOn){if(0===this._cursorOffset)return;this._startHighlightIndex=this._textWrapper.length-this._cursorOffset-1}return this._endHighlightIndex=this._textWrapper.length,this._isTextHighlightOn=!0,this._cursorIndex=this._textWrapper.length-this._startHighlightIndex,this._cursorOffset=0,void this._markAsDirty()}return this._isTextHighlightOn?-1===this._cursorIndex&&(this._cursorIndex=this._textWrapper.length-this._startHighlightIndex,this._cursorOffset=this._textWrapper.length===this._endHighlightIndex?0:this._textWrapper.length-this._endHighlightIndex-1):(this._isTextHighlightOn=!0,this._cursorIndex=this._cursorOffset<=0?0:this._cursorOffset+1),this._cursorIndexthis._cursorOffset?(this._endHighlightIndex=this._textWrapper.length-this._cursorOffset,this._startHighlightIndex=this._textWrapper.length-this._cursorIndex):this._isTextHighlightOn=!1,void this._markAsDirty()}return this._isTextHighlightOn&&(this._cursorOffset=this._textWrapper.length-this._endHighlightIndex,this._isTextHighlightOn=!1),i&&(i.ctrlKey||i.metaKey)&&(this._cursorOffset=0,i.preventDefault()),this._blinkIsEven=!1,this._isTextHighlightOn=!1,this._cursorIndex=-1,void this._markAsDirty();case 222:i&&i.preventDefault(),this._cursorIndex=-1,this.deadKey=!0}if(t&&(-1===e||32===e||e>47&&e<64||e>64&&e<91||e>159&&e<193||e>218&&e<223||e>95&&e<112)&&(this._currentKey=t,this.onBeforeKeyAddObservable.notifyObservers(this),t=this._currentKey,this._addKey))if(this._isTextHighlightOn)this._textWrapper.removePart(this._startHighlightIndex,this._endHighlightIndex,t),this._textHasChanged(),this._cursorOffset=this._textWrapper.length-(this._startHighlightIndex+1),this._isTextHighlightOn=!1,this._blinkIsEven=!1,this._markAsDirty();else if(0===this._cursorOffset)this.text+=t;else{var n=this._textWrapper.length-this._cursorOffset;this._textWrapper.removePart(n,n,t),this._textHasChanged()}}},t.prototype._updateValueFromCursorIndex=function(e){if(this._blinkIsEven=!1,-1===this._cursorIndex)this._cursorIndex=e;else if(this._cursorIndexthis._cursorOffset))return this._isTextHighlightOn=!1,void this._markAsDirty();this._endHighlightIndex=this._textWrapper.length-this._cursorOffset,this._startHighlightIndex=this._textWrapper.length-this._cursorIndex}this._isTextHighlightOn=!0,this._markAsDirty()},t.prototype._processDblClick=function(e){var t,i;this._startHighlightIndex=this._textWrapper.length-this._cursorOffset,this._endHighlightIndex=this._startHighlightIndex;do{i=this._endHighlightIndex0&&this._textWrapper.isWord(this._startHighlightIndex-1)?--this._startHighlightIndex:0}while(t||i);this._cursorOffset=this._textWrapper.length-this._startHighlightIndex,this.onTextHighlightObservable.notifyObservers(this),this._isTextHighlightOn=!0,this._clickedCoordinate=null,this._blinkIsEven=!0,this._cursorIndex=-1,this._markAsDirty()},t.prototype._selectAllText=function(){this._blinkIsEven=!0,this._isTextHighlightOn=!0,this._startHighlightIndex=0,this._endHighlightIndex=this._textWrapper.length,this._cursorOffset=this._textWrapper.length,this._cursorIndex=-1,this._markAsDirty()},t.prototype.processKeyboard=function(e){this.processKey(e.keyCode,e.key,e),this.onKeyboardEventProcessedObservable.notifyObservers(e)},t.prototype._onCopyText=function(e){this._isTextHighlightOn=!1;try{e.clipboardData&&e.clipboardData.setData("text/plain",this._highlightedText)}catch(e){}this._host.clipboardData=this._highlightedText},t.prototype._onCutText=function(e){if(this._highlightedText){this._textWrapper.removePart(this._startHighlightIndex,this._endHighlightIndex),this._textHasChanged(),this._isTextHighlightOn=!1,this._cursorOffset=this._textWrapper.length-this._startHighlightIndex;try{e.clipboardData&&e.clipboardData.setData("text/plain",this._highlightedText)}catch(e){}this._host.clipboardData=this._highlightedText,this._highlightedText=""}},t.prototype._onPasteText=function(e){var t="";t=e.clipboardData&&-1!==e.clipboardData.types.indexOf("text/plain")?e.clipboardData.getData("text/plain"):this._host.clipboardData;var i=this._textWrapper.length-this._cursorOffset;this._textWrapper.removePart(i,i,t),this._textHasChanged()},t.prototype._draw=function(e,t){var i=this;e.save(),this._applyStates(e),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowColor=this.shadowColor,e.shadowBlur=this.shadowBlur,e.shadowOffsetX=this.shadowOffsetX,e.shadowOffsetY=this.shadowOffsetY),this._isFocused?this._focusedBackground&&(e.fillStyle=this._isEnabled?this._focusedBackground:this._disabledColor,e.fillRect(this._currentMeasure.left,this._currentMeasure.top,this._currentMeasure.width,this._currentMeasure.height)):this._background&&(e.fillStyle=this._isEnabled?this._background:this._disabledColor,e.fillRect(this._currentMeasure.left,this._currentMeasure.top,this._currentMeasure.width,this._currentMeasure.height)),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowBlur=0,e.shadowOffsetX=0,e.shadowOffsetY=0),this._fontOffset||(this._fontOffset=h.a._GetFontOffset(e.font));var r=this._currentMeasure.left+this._margin.getValueInPixel(this._host,this._tempParentMeasure.width);this.color&&(e.fillStyle=this.color);var n=this._beforeRenderText(this._textWrapper);this._isFocused||this._textWrapper.text||!this._placeholderText||((n=new b).text=this._placeholderText,this._placeholderColor&&(e.fillStyle=this._placeholderColor)),this._textWidth=e.measureText(n.text).width;var o=2*this._margin.getValueInPixel(this._host,this._tempParentMeasure.width);this._autoStretchWidth&&(this.width=Math.min(this._maxWidth.getValueInPixel(this._host,this._tempParentMeasure.width),this._textWidth+o)+"px");var s=this._fontOffset.ascent+(this._currentMeasure.height-this._fontOffset.height)/2,a=this._width.getValueInPixel(this._host,this._tempParentMeasure.width)-o;if(e.save(),e.beginPath(),e.rect(r,this._currentMeasure.top+(this._currentMeasure.height-this._fontOffset.height)/2,a+2,this._currentMeasure.height),e.clip(),this._isFocused&&this._textWidth>a){var l=r-this._textWidth+a;this._scrollLeft||(this._scrollLeft=l)}else this._scrollLeft=r;if(e.fillText(n.text,this._scrollLeft,this._currentMeasure.top+s),this._isFocused){if(this._clickedCoordinate){var c=this._scrollLeft+this._textWidth-this._clickedCoordinate,u=0;this._cursorOffset=0;var f=0;do{this._cursorOffset&&(f=Math.abs(c-u)),this._cursorOffset++,u=e.measureText(n.substr(n.length-this._cursorOffset,this._cursorOffset)).width}while(u=this._cursorOffset);Math.abs(c-u)>f&&this._cursorOffset--,this._blinkIsEven=!1,this._clickedCoordinate=null}if(!this._blinkIsEven){var d=n.substr(n.length-this._cursorOffset),p=e.measureText(d).width,_=this._scrollLeft+this._textWidth-p;_r+a&&(this._scrollLeft+=r+a-_,_=r+a,this._markAsDirty()),this._isTextHighlightOn||e.fillRect(_,this._currentMeasure.top+(this._currentMeasure.height-this._fontOffset.height)/2,2,this._fontOffset.height)}if(clearTimeout(this._blinkTimeout),this._blinkTimeout=setTimeout((function(){i._blinkIsEven=!i._blinkIsEven,i._markAsDirty()}),500),this._isTextHighlightOn){clearTimeout(this._blinkTimeout);var g=e.measureText(n.substring(this._startHighlightIndex)).width,m=this._scrollLeft+this._textWidth-g;this._highlightedText=n.substring(this._startHighlightIndex,this._endHighlightIndex);var v=e.measureText(n.substring(this._startHighlightIndex,this._endHighlightIndex)).width;m=this._rowDefinitions.length?null:this._rowDefinitions[e]},t.prototype.getColumnDefinition=function(e){return e<0||e>=this._columnDefinitions.length?null:this._columnDefinitions[e]},t.prototype.addRowDefinition=function(e,t){return void 0===t&&(t=!1),this._rowDefinitions.push(new c.a(e,t?c.a.UNITMODE_PIXEL:c.a.UNITMODE_PERCENTAGE)),this._markAsDirty(),this},t.prototype.addColumnDefinition=function(e,t){return void 0===t&&(t=!1),this._columnDefinitions.push(new c.a(e,t?c.a.UNITMODE_PIXEL:c.a.UNITMODE_PERCENTAGE)),this._markAsDirty(),this},t.prototype.setRowDefinition=function(e,t,i){if(void 0===i&&(i=!1),e<0||e>=this._rowDefinitions.length)return this;var r=this._rowDefinitions[e];return r&&r.isPixel===i&&r.internalValue===t||(this._rowDefinitions[e]=new c.a(t,i?c.a.UNITMODE_PIXEL:c.a.UNITMODE_PERCENTAGE),this._markAsDirty()),this},t.prototype.setColumnDefinition=function(e,t,i){if(void 0===i&&(i=!1),e<0||e>=this._columnDefinitions.length)return this;var r=this._columnDefinitions[e];return r&&r.isPixel===i&&r.internalValue===t||(this._columnDefinitions[e]=new c.a(t,i?c.a.UNITMODE_PIXEL:c.a.UNITMODE_PERCENTAGE),this._markAsDirty()),this},t.prototype.getChildrenAt=function(e,t){var i=this._cells[e+":"+t];return i?i.children:null},t.prototype.getChildCellInfo=function(e){return e._tag},t.prototype._removeCell=function(t,i){if(t){e.prototype.removeControl.call(this,t);for(var r=0,n=t.children;r=this._columnDefinitions.length)return this;for(var t=0;t=this._rowDefinitions.length)return this;for(var t=0;t=1-t._Epsilon&&(this._value.r=1),this._value.g>=1-t._Epsilon&&(this._value.g=1),this._value.b>=1-t._Epsilon&&(this._value.b=1),this.onValueChangedObservable.notifyObservers(this._value))},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"width",{get:function(){return this._width.toString(this._host)},set:function(e){this._width.toString(this._host)!==e&&this._width.fromString(e)&&(this._height.fromString(e),this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"height",{get:function(){return this._height.toString(this._host)},set:function(e){this._height.toString(this._host)!==e&&this._height.fromString(e)&&(this._width.fromString(e),this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"size",{get:function(){return this.width},set:function(e){this.width=e},enumerable:!1,configurable:!0}),t.prototype._getTypeName=function(){return"ColorPicker"},t.prototype._preMeasure=function(e,t){e.widtha||f150?.04:-.16*(e-50)/100+.2;var m=(d-h)/(e-h);o[_+3]=m1-g?255*(1-(m-(1-g))/g):255}}return r.putImageData(n,0,0),i},t.prototype._draw=function(e){e.save(),this._applyStates(e);var t=.5*Math.min(this._currentMeasure.width,this._currentMeasure.height),i=.2*t,r=this._currentMeasure.left,n=this._currentMeasure.top;this._colorWheelCanvas&&this._colorWheelCanvas.width==2*t||(this._colorWheelCanvas=this._createColorWheelCanvas(t,i)),this._updateSquareProps(),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowColor=this.shadowColor,e.shadowBlur=this.shadowBlur,e.shadowOffsetX=this.shadowOffsetX,e.shadowOffsetY=this.shadowOffsetY,e.fillRect(this._squareLeft,this._squareTop,this._squareSize,this._squareSize)),e.drawImage(this._colorWheelCanvas,r,n),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowBlur=0,e.shadowOffsetX=0,e.shadowOffsetY=0),this._drawGradientSquare(this._h,this._squareLeft,this._squareTop,this._squareSize,this._squareSize,e);var o=this._squareLeft+this._squareSize*this._s,s=this._squareTop+this._squareSize*(1-this._v);this._drawCircle(o,s,.04*t,e);var a=t-.5*i;o=r+t+Math.cos((this._h-180)*Math.PI/180)*a,s=n+t+Math.sin((this._h-180)*Math.PI/180)*a,this._drawCircle(o,s,.35*i,e),e.restore()},t.prototype._updateValueFromPointer=function(e,i){if(this._pointerStartedOnWheel){var r=.5*Math.min(this._currentMeasure.width,this._currentMeasure.height),n=r+this._currentMeasure.left,o=r+this._currentMeasure.top;this._h=180*Math.atan2(i-o,e-n)/Math.PI+180}else this._pointerStartedOnSquare&&(this._updateSquareProps(),this._s=(e-this._squareLeft)/this._squareSize,this._v=1-(i-this._squareTop)/this._squareSize,this._s=Math.min(this._s,1),this._s=Math.max(this._s,t._Epsilon),this._v=Math.min(this._v,1),this._v=Math.max(this._v,t._Epsilon));x.a.HSVtoRGBToRef(this._h,this._s,this._v,this._tmpColor),this.value=this._tmpColor},t.prototype._isPointOnSquare=function(e,t){this._updateSquareProps();var i=this._squareLeft,r=this._squareTop,n=this._squareSize;return e>=i&&e<=i+n&&t>=r&&t<=r+n},t.prototype._isPointOnWheel=function(e,t){var i=.5*Math.min(this._currentMeasure.width,this._currentMeasure.height),r=i-.2*i,n=e-(i+this._currentMeasure.left),o=t-(i+this._currentMeasure.top),s=n*n+o*o;return s<=i*i&&s>=r*r},t.prototype._onPointerDown=function(t,i,r,n,o){if(!e.prototype._onPointerDown.call(this,t,i,r,n,o))return!1;this._pointerIsDown=!0,this._pointerStartedOnSquare=!1,this._pointerStartedOnWheel=!1,this._invertTransformMatrix.transformCoordinates(i.x,i.y,this._transformedPosition);var s=this._transformedPosition.x,a=this._transformedPosition.y;return this._isPointOnSquare(s,a)?this._pointerStartedOnSquare=!0:this._isPointOnWheel(s,a)&&(this._pointerStartedOnWheel=!0),this._updateValueFromPointer(s,a),this._host._capturingControl[r]=this,this._lastPointerDownID=r,!0},t.prototype._onPointerMove=function(t,i,r,n){if(r==this._lastPointerDownID){this._invertTransformMatrix.transformCoordinates(i.x,i.y,this._transformedPosition);var o=this._transformedPosition.x,s=this._transformedPosition.y;this._pointerIsDown&&this._updateValueFromPointer(o,s),e.prototype._onPointerMove.call(this,t,i,r,n)}},t.prototype._onPointerUp=function(t,i,r,n,o,s){this._pointerIsDown=!1,delete this._host._capturingControl[r],e.prototype._onPointerUp.call(this,t,i,r,n,o,s)},t.prototype._onCanvasBlur=function(){this._forcePointerUp(),e.prototype._onCanvasBlur.call(this)},t.ShowPickerDialogAsync=function(e,i){return new Promise((function(r,n){i.pickerWidth=i.pickerWidth||"640px",i.pickerHeight=i.pickerHeight||"400px",i.headerHeight=i.headerHeight||"35px",i.lastColor=i.lastColor||"#000000",i.swatchLimit=i.swatchLimit||20,i.numSwatchesPerLine=i.numSwatchesPerLine||10;var o,a,l,c,f,d,_,g,m,v,b,E,A,M,S,O,P,C,I,R=i.swatchLimit/i.numSwatchesPerLine,D=parseFloat(i.pickerWidth)/i.numSwatchesPerLine,w=Math.floor(.25*D),L=w*(i.numSwatchesPerLine+1),F=Math.floor((parseFloat(i.pickerWidth)-L)/i.numSwatchesPerLine),N=F*R+w*(R+1),B=(parseInt(i.pickerHeight)+N+Math.floor(.25*F)).toString()+"px",k="#c0c0c0",U="#535353",V="#414141",j="515151",z=x.a.FromHexString("#dddddd"),W=z.r+z.g+z.b,G=["R","G","B"],H="#454545",X="#f0f0f0",K=!1;function Y(e,t){I=t;var i=e.toHexString();if(P.background=i,v.name!=I&&(v.text=Math.floor(255*e.r).toString()),b.name!=I&&(b.text=Math.floor(255*e.g).toString()),E.name!=I&&(E.text=Math.floor(255*e.b).toString()),A.name!=I&&(A.text=e.r.toString()),M.name!=I&&(M.text=e.g.toString()),S.name!=I&&(S.text=e.b.toString()),O.name!=I){var r=i.split("#");O.text=r[1]}m.name!=I&&(m.value=e)}function q(e,t){var i=e.text;if(/[^0-9]/g.test(i))e.text=C;else if(""!=i&&(Math.floor(parseInt(i))<0?i="0":Math.floor(parseInt(i))>255?i="255":isNaN(parseInt(i))&&(i="0")),I==e.name&&(C=i),""!=i){i=parseInt(i).toString(),e.text=i;var r=x.a.FromHexString(P.background);I==e.name&&Y("r"==t?new x.a(parseInt(i)/255,r.g,r.b):"g"==t?new x.a(r.r,parseInt(i)/255,r.b):new x.a(r.r,r.g,parseInt(i)/255),e.name)}}function Z(e,t){var i=e.text;if(/[^0-9\.]/g.test(i))e.text=C;else{""!=i&&"."!=i&&0!=parseFloat(i)&&(parseFloat(i)<0?i="0.0":parseFloat(i)>1?i="1.0":isNaN(parseFloat(i))&&(i="0.0")),I==e.name&&(C=i),""!=i&&"."!=i&&0!=parseFloat(i)?(i=parseFloat(i).toString(),e.text=i):i="0.0";var r=x.a.FromHexString(P.background);I==e.name&&Y("r"==t?new x.a(parseFloat(i),r.g,r.b):"g"==t?new x.a(r.r,parseFloat(i),r.b):new x.a(r.r,r.g,parseFloat(i)),e.name)}}function Q(){if(i.savedColors&&i.savedColors[_]){if(K)var e="b";else e="";var t=p.CreateSimpleButton("Swatch_"+_,e);t.fontFamily="BabylonJSglyphs";var r=x.a.FromHexString(i.savedColors[_]),n=r.r+r.g+r.b;t.color=n>W?"#aaaaaa":"#ffffff",t.fontSize=Math.floor(.7*F),t.textBlock.verticalAlignment=h.a.VERTICAL_ALIGNMENT_CENTER,t.height=t.width=F.toString()+"px",t.background=i.savedColors[_],t.thickness=2;var o=_;return t.pointerDownAnimation=function(){t.thickness=4},t.pointerUpAnimation=function(){t.thickness=3},t.pointerEnterAnimation=function(){t.thickness=3},t.pointerOutAnimation=function(){t.thickness=2},t.onPointerClickObservable.add((function(){var e;K?(e=o,i.savedColors&&i.savedColors.splice(e,1),i.savedColors&&0==i.savedColors.length&&(ee(!1),K=!1),$("",Fe)):i.savedColors&&Y(x.a.FromHexString(i.savedColors[o]),t.name)})),t}return null}function J(e){if(void 0!==e&&(K=e),K){for(var t=0;th*i.numSwatchesPerLine)var l=i.numSwatchesPerLine;else l=i.savedColors.length-(h-1)*i.numSwatchesPerLine;for(var c=Math.min(Math.max(l,0),i.numSwatchesPerLine),u=0,f=1;ui.numSwatchesPerLine)){var d=Q();null!=d&&(g.addControl(d,a,f),f+=2,_++)}}i.savedColors.length>=i.swatchLimit?te(t,!0):te(t,!1)}}function ee(e){e?((l=p.CreateSimpleButton("butEdit","Edit")).width=c,l.height=f,l.left=Math.floor(.1*parseInt(c)).toString()+"px",l.top=(-1*parseFloat(l.left)).toString()+"px",l.verticalAlignment=h.a.VERTICAL_ALIGNMENT_BOTTOM,l.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,l.thickness=2,l.color=k,l.fontSize=a,l.background=U,l.onPointerEnterObservable.add((function(){l.background=V})),l.onPointerOutObservable.add((function(){l.background=U})),l.pointerDownAnimation=function(){l.background=j},l.pointerUpAnimation=function(){l.background=V},l.onPointerClickObservable.add((function(){K=!K,J()})),ge.addControl(l,1,0)):ge.removeControl(l)}function te(e,t){t?(e.color="#555555",e.background="#454545"):(e.color=k,e.background=U)}function ie(t){i.savedColors&&i.savedColors.length>0?r({savedColors:i.savedColors,pickedColor:t}):r({pickedColor:t}),e.removeControl(re)}var re=new T;if(re.name="Dialog Container",re.width=i.pickerWidth,i.savedColors){re.height=B;var ne=parseInt(i.pickerHeight)/parseInt(B);re.addRowDefinition(ne,!1),re.addRowDefinition(1-ne,!1)}else re.height=i.pickerHeight,re.addRowDefinition(1,!1);if(e.addControl(re),i.savedColors){(g=new T).name="Swatch Drawer",g.verticalAlignment=h.a.VERTICAL_ALIGNMENT_TOP,g.background=U,g.width=i.pickerWidth;var oe=i.savedColors.length/i.numSwatchesPerLine;if(0==oe)var se=0;else se=oe+1;g.height=(F*oe+se*w).toString()+"px",g.top=Math.floor(.25*F).toString()+"px";for(var ae=0;ae<2*Math.ceil(i.savedColors.length/i.numSwatchesPerLine)+1;ae++)ae%2!=0?g.addRowDefinition(F,!0):g.addRowDefinition(w,!0);for(ae=0;ae<2*i.numSwatchesPerLine+1;ae++)ae%2!=0?g.addColumnDefinition(F,!0):g.addColumnDefinition(w,!0);re.addControl(g,1,0)}var he=new T;he.name="Picker Panel",he.height=i.pickerHeight;var le=parseInt(i.headerHeight)/parseInt(i.pickerHeight),ce=[le,1-le];he.addRowDefinition(ce[0],!1),he.addRowDefinition(ce[1],!1),re.addControl(he,0,0);var ue=new s;ue.name="Dialogue Header Bar",ue.background="#cccccc",ue.thickness=0,he.addControl(ue,0,0);var fe=p.CreateSimpleButton("closeButton","a");fe.fontFamily="BabylonJSglyphs";var de=x.a.FromHexString(ue.background);o=new x.a(1-de.r,1-de.g,1-de.b),fe.color=o.toHexString(),fe.fontSize=Math.floor(.6*parseInt(i.headerHeight)),fe.textBlock.textVerticalAlignment=h.a.VERTICAL_ALIGNMENT_CENTER,fe.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_RIGHT,fe.height=fe.width=i.headerHeight,fe.background=ue.background,fe.thickness=0,fe.pointerDownAnimation=function(){},fe.pointerUpAnimation=function(){fe.background=ue.background},fe.pointerEnterAnimation=function(){fe.color=ue.background,fe.background="red"},fe.pointerOutAnimation=function(){fe.color=o.toHexString(),fe.background=ue.background},fe.onPointerClickObservable.add((function(){ie(Pe.background)})),he.addControl(fe,0,0);var pe=new T;pe.name="Dialogue Body",pe.background=U;var _e=[.4375,.5625];pe.addRowDefinition(1,!1),pe.addColumnDefinition(_e[0],!1),pe.addColumnDefinition(_e[1],!1),he.addControl(pe,1,0);var ge=new T;ge.name="Picker Grid",ge.addRowDefinition(.85,!1),ge.addRowDefinition(.15,!1),pe.addControl(ge,0,0),(m=new t).name="GUI Color Picker",i.pickerHeighti.pickerHeight)var Se=Me;else Se=Ae;var Oe=new u;Oe.text="new",Oe.name="New Color Label",Oe.color=k,Oe.fontSize=Se,Te.addControl(Oe,1,0),(P=new s).name="New Color Swatch",P.background=i.lastColor,P.thickness=0,Ee.addControl(P,0,0);var Pe=p.CreateSimpleButton("currentSwatch","");Pe.background=i.lastColor,Pe.thickness=0,Pe.onPointerClickObservable.add((function(){Y(x.a.FromHexString(Pe.background),Pe.name),J(!1)})),Pe.pointerDownAnimation=function(){},Pe.pointerUpAnimation=function(){},Pe.pointerEnterAnimation=function(){},Pe.pointerOutAnimation=function(){},Ee.addControl(Pe,1,0);var Ce=new s;Ce.name="Swatch Outline",Ce.width=.67,Ce.thickness=2,Ce.color="#404040",Ce.isHitTestVisible=!1,Te.addControl(Ce,2,0);var Ie=new u;Ie.name="Current Color Label",Ie.text="current",Ie.color=k,Ie.fontSize=Se,Te.addControl(Ie,3,0);var Re=new T;Re.name="Button Grid",Re.height=.8;var De=1/3;Re.addRowDefinition(De,!1),Re.addRowDefinition(De,!1),Re.addRowDefinition(De,!1),be.addControl(Re,0,1),c=Math.floor(parseInt(i.pickerWidth)*_e[1]*ye[1]*.67).toString()+"px",f=Math.floor(parseInt(i.pickerHeight)*ce[1]*ve[0]*(parseFloat(Re.height.toString())/100)*De*.7).toString()+"px",a=parseFloat(c)>parseFloat(f)?Math.floor(.45*parseFloat(f)):Math.floor(.11*parseFloat(c));var we=p.CreateSimpleButton("butOK","OK");we.width=c,we.height=f,we.verticalAlignment=h.a.VERTICAL_ALIGNMENT_CENTER,we.thickness=2,we.color=k,we.fontSize=a,we.background=U,we.onPointerEnterObservable.add((function(){we.background=V})),we.onPointerOutObservable.add((function(){we.background=U})),we.pointerDownAnimation=function(){we.background=j},we.pointerUpAnimation=function(){we.background=V},we.onPointerClickObservable.add((function(){J(!1),ie(P.background)})),Re.addControl(we,0,0);var Le=p.CreateSimpleButton("butCancel","Cancel");if(Le.width=c,Le.height=f,Le.verticalAlignment=h.a.VERTICAL_ALIGNMENT_CENTER,Le.thickness=2,Le.color=k,Le.fontSize=a,Le.background=U,Le.onPointerEnterObservable.add((function(){Le.background=V})),Le.onPointerOutObservable.add((function(){Le.background=U})),Le.pointerDownAnimation=function(){Le.background=j},Le.pointerUpAnimation=function(){Le.background=V},Le.onPointerClickObservable.add((function(){J(!1),ie(Pe.background)})),Re.addControl(Le,1,0),i.savedColors){var Fe=p.CreateSimpleButton("butSave","Save");Fe.width=c,Fe.height=f,Fe.verticalAlignment=h.a.VERTICAL_ALIGNMENT_CENTER,Fe.thickness=2,Fe.fontSize=a,i.savedColors.length0&&ee(!0),Re.addControl(Fe,2,0)}var Ne=new T;Ne.name="Dialog Lower Right",Ne.addRowDefinition(.02,!1),Ne.addRowDefinition(.63,!1),Ne.addRowDefinition(.21,!1),Ne.addRowDefinition(.14,!1),me.addControl(Ne,1,0),d=x.a.FromHexString(i.lastColor);var Be=new T;Be.name="RGB Values",Be.width=.82,Be.verticalAlignment=h.a.VERTICAL_ALIGNMENT_CENTER,Be.addRowDefinition(1/3,!1),Be.addRowDefinition(1/3,!1),Be.addRowDefinition(1/3,!1),Be.addColumnDefinition(.1,!1),Be.addColumnDefinition(.2,!1),Be.addColumnDefinition(.7,!1),Ne.addControl(Be,1,0);for(ae=0;ae6||t)&&I==O.name)O.text=C;else{if(O.text.length<6)for(var i=6-O.text.length,r=0;r0&&$("",Fe)}))},t._Epsilon=1e-6,t}(h.a);o.a.RegisteredTypes["BABYLON.GUI.ColorPicker"]=E;var A=function(e){function t(t){var i=e.call(this,t)||this;return i.name=t,i._thickness=1,i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"thickness",{get:function(){return this._thickness},set:function(e){this._thickness!==e&&(this._thickness=e,this._markAsDirty())},enumerable:!1,configurable:!0}),t.prototype._getTypeName=function(){return"Ellipse"},t.prototype._localDraw=function(e){e.save(),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowColor=this.shadowColor,e.shadowBlur=this.shadowBlur,e.shadowOffsetX=this.shadowOffsetX,e.shadowOffsetY=this.shadowOffsetY),h.a.drawEllipse(this._currentMeasure.left+this._currentMeasure.width/2,this._currentMeasure.top+this._currentMeasure.height/2,this._currentMeasure.width/2-this._thickness/2,this._currentMeasure.height/2-this._thickness/2,e),this._background&&(e.fillStyle=this._background,e.fill()),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowBlur=0,e.shadowOffsetX=0,e.shadowOffsetY=0),this._thickness&&(this.color&&(e.strokeStyle=this.color),e.lineWidth=this._thickness,e.stroke()),e.restore()},t.prototype._additionalProcessing=function(t,i){e.prototype._additionalProcessing.call(this,t,i),this._measureForChildren.width-=2*this._thickness,this._measureForChildren.height-=2*this._thickness,this._measureForChildren.left+=this._thickness,this._measureForChildren.top+=this._thickness},t.prototype._clipForChildren=function(e){h.a.drawEllipse(this._currentMeasure.left+this._currentMeasure.width/2,this._currentMeasure.top+this._currentMeasure.height/2,this._currentMeasure.width/2,this._currentMeasure.height/2,e),e.clip()},t}(n.a);o.a.RegisteredTypes["BABYLON.GUI.Ellipse"]=A;var M=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return Object(r.c)(t,e),t.prototype._beforeRenderText=function(e){for(var t=new b,i="",r=0;r1?this.notRenderable=!0:this.notRenderable=!1}else f.b.Error("Cannot move a control to a vector3 if the control is not at root level")},t.prototype._moveToProjectedPosition=function(e,t){void 0===t&&(t=!1);var i=e.x+this._linkOffsetX.getValue(this._host)+"px",r=e.y+this._linkOffsetY.getValue(this._host)+"px";t?(this.x2=i,this.y2=r,this._x2.ignoreAdaptiveScaling=!0,this._y2.ignoreAdaptiveScaling=!0):(this.x1=i,this.y1=r,this._x1.ignoreAdaptiveScaling=!0,this._y1.ignoreAdaptiveScaling=!0)},t}(h.a);o.a.RegisteredTypes["BABYLON.GUI.Line"]=O;var P=i(48),C=i(16),I=function(){function e(e){this._multiLine=e,this._x=new c.a(0),this._y=new c.a(0),this._point=new S.e(0,0,0)}return Object.defineProperty(e.prototype,"x",{get:function(){return this._x.toString(this._multiLine._host)},set:function(e){this._x.toString(this._multiLine._host)!==e&&this._x.fromString(e)&&this._multiLine._markAsDirty()},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"y",{get:function(){return this._y.toString(this._multiLine._host)},set:function(e){this._y.toString(this._multiLine._host)!==e&&this._y.fromString(e)&&this._multiLine._markAsDirty()},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"control",{get:function(){return this._control},set:function(e){this._control!==e&&(this._control&&this._controlObserver&&(this._control.onDirtyObservable.remove(this._controlObserver),this._controlObserver=null),this._control=e,this._control&&(this._controlObserver=this._control.onDirtyObservable.add(this._multiLine.onPointUpdate)),this._multiLine._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"mesh",{get:function(){return this._mesh},set:function(e){this._mesh!==e&&(this._mesh&&this._meshObserver&&this._mesh.getScene().onAfterCameraRenderObservable.remove(this._meshObserver),this._mesh=e,this._mesh&&(this._meshObserver=this._mesh.getScene().onAfterCameraRenderObservable.add(this._multiLine.onPointUpdate)),this._multiLine._markAsDirty())},enumerable:!1,configurable:!0}),e.prototype.resetLinks=function(){this.control=null,this.mesh=null},e.prototype.translate=function(){return this._point=this._translatePoint(),this._point},e.prototype._translatePoint=function(){if(null!=this._mesh)return this._multiLine._host.getProjectedPositionWithZ(this._mesh.getBoundingInfo().boundingSphere.center,this._mesh.getWorldMatrix());if(null!=this._control)return new S.e(this._control.centerX,this._control.centerY,1-C.a);var e=this._multiLine._host,t=this._x.getValueInPixel(e,Number(e._canvas.width)),i=this._y.getValueInPixel(e,Number(e._canvas.height));return new S.e(t,i,1-C.a)},e.prototype.dispose=function(){this.resetLinks()},e}(),R=function(e){function t(t){var i=e.call(this,t)||this;return i.name=t,i._lineWidth=1,i.onPointUpdate=function(){i._markAsDirty()},i._automaticSize=!0,i.isHitTestVisible=!1,i._horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,i._verticalAlignment=h.a.VERTICAL_ALIGNMENT_TOP,i._dash=[],i._points=[],i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"dash",{get:function(){return this._dash},set:function(e){this._dash!==e&&(this._dash=e,this._markAsDirty())},enumerable:!1,configurable:!0}),t.prototype.getAt=function(e){return this._points[e]||(this._points[e]=new I(this)),this._points[e]},t.prototype.add=function(){for(var e=this,t=[],i=0;i0;)this.remove(this._points.length-1)},t.prototype.resetLinks=function(){this._points.forEach((function(e){null!=e&&e.resetLinks()}))},Object.defineProperty(t.prototype,"lineWidth",{get:function(){return this._lineWidth},set:function(e){this._lineWidth!==e&&(this._lineWidth=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"horizontalAlignment",{set:function(e){},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"verticalAlignment",{set:function(e){},enumerable:!1,configurable:!0}),t.prototype._getTypeName=function(){return"MultiLine"},t.prototype._draw=function(e,t){e.save(),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowColor=this.shadowColor,e.shadowBlur=this.shadowBlur,e.shadowOffsetX=this.shadowOffsetX,e.shadowOffsetY=this.shadowOffsetY),this._applyStates(e),e.strokeStyle=this.color,e.lineWidth=this._lineWidth,e.setLineDash(this._dash),e.beginPath();var i,r=!0;this._points.forEach((function(t){t&&(r?(e.moveTo(t._point.x,t._point.y),r=!1):t._point.z<1&&i.z<1?e.lineTo(t._point.x,t._point.y):e.moveTo(t._point.x,t._point.y),i=t._point)})),e.stroke(),e.restore()},t.prototype._additionalProcessing=function(e,t){var i=this;this._minX=null,this._minY=null,this._maxX=null,this._maxY=null,this._points.forEach((function(e,t){e&&(e.translate(),(null==i._minX||e._point.xi._maxX)&&(i._maxX=e._point.x),(null==i._maxY||e._point.y>i._maxY)&&(i._maxY=e._point.y))})),null==this._minX&&(this._minX=0),null==this._minY&&(this._minY=0),null==this._maxX&&(this._maxX=0),null==this._maxY&&(this._maxY=0)},t.prototype._measure=function(){null!=this._minX&&null!=this._maxX&&null!=this._minY&&null!=this._maxY&&(this._currentMeasure.width=Math.abs(this._maxX-this._minX)+this._lineWidth,this._currentMeasure.height=Math.abs(this._maxY-this._minY)+this._lineWidth)},t.prototype._computeAlignment=function(e,t){null!=this._minX&&null!=this._minY&&(this._currentMeasure.left=this._minX-this._lineWidth/2,this._currentMeasure.top=this._minY-this._lineWidth/2)},t.prototype.dispose=function(){this.reset(),e.prototype.dispose.call(this)},t}(h.a);o.a.RegisteredTypes["BABYLON.GUI.MultiLine"]=R;var D=function(e){function t(t){var i=e.call(this,t)||this;return i.name=t,i._isChecked=!1,i._background="black",i._checkSizeRatio=.8,i._thickness=1,i.group="",i.onIsCheckedChangedObservable=new l.a,i.isPointerBlocker=!0,i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"thickness",{get:function(){return this._thickness},set:function(e){this._thickness!==e&&(this._thickness=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"checkSizeRatio",{get:function(){return this._checkSizeRatio},set:function(e){e=Math.max(Math.min(1,e),0),this._checkSizeRatio!==e&&(this._checkSizeRatio=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"background",{get:function(){return this._background},set:function(e){this._background!==e&&(this._background=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isChecked",{get:function(){return this._isChecked},set:function(e){var t=this;this._isChecked!==e&&(this._isChecked=e,this._markAsDirty(),this.onIsCheckedChangedObservable.notifyObservers(e),this._isChecked&&this._host&&this._host.executeOnAllControls((function(e){if(e!==t&&void 0!==e.group){var i=e;i.group===t.group&&(i.isChecked=!1)}})))},enumerable:!1,configurable:!0}),t.prototype._getTypeName=function(){return"RadioButton"},t.prototype._draw=function(e){e.save(),this._applyStates(e);var t=this._currentMeasure.width-this._thickness,i=this._currentMeasure.height-this._thickness;if((this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowColor=this.shadowColor,e.shadowBlur=this.shadowBlur,e.shadowOffsetX=this.shadowOffsetX,e.shadowOffsetY=this.shadowOffsetY),h.a.drawEllipse(this._currentMeasure.left+this._currentMeasure.width/2,this._currentMeasure.top+this._currentMeasure.height/2,this._currentMeasure.width/2-this._thickness/2,this._currentMeasure.height/2-this._thickness/2,e),e.fillStyle=this._isEnabled?this._background:this._disabledColor,e.fill(),(this.shadowBlur||this.shadowOffsetX||this.shadowOffsetY)&&(e.shadowBlur=0,e.shadowOffsetX=0,e.shadowOffsetY=0),e.strokeStyle=this.color,e.lineWidth=this._thickness,e.stroke(),this._isChecked){e.fillStyle=this._isEnabled?this.color:this._disabledColor;var r=t*this._checkSizeRatio,n=i*this._checkSizeRatio;h.a.drawEllipse(this._currentMeasure.left+this._currentMeasure.width/2,this._currentMeasure.top+this._currentMeasure.height/2,r/2-this._thickness/2,n/2-this._thickness/2,e),e.fill()}e.restore()},t.prototype._onPointerDown=function(t,i,r,n,o){return!!e.prototype._onPointerDown.call(this,t,i,r,n,o)&&(this.isChecked||(this.isChecked=!0),!0)},t.AddRadioButtonWithHeader=function(e,i,r,n){var o=new _;o.isVertical=!1,o.height="30px";var s=new t;s.width="20px",s.height="20px",s.isChecked=r,s.color="green",s.group=i,s.onIsCheckedChangedObservable.add((function(e){return n(s,e)})),o.addControl(s);var a=new u;return a.text=e,a.width="180px",a.paddingLeft="5px",a.textHorizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,a.color="white",o.addControl(a),o},t}(h.a);o.a.RegisteredTypes["BABYLON.GUI.RadioButton"]=D;var w=function(e){function t(t){var i=e.call(this,t)||this;return i.name=t,i._thumbWidth=new c.a(20,c.a.UNITMODE_PIXEL,!1),i._minimum=0,i._maximum=100,i._value=50,i._isVertical=!1,i._barOffset=new c.a(5,c.a.UNITMODE_PIXEL,!1),i._isThumbClamped=!1,i._displayThumb=!0,i._step=0,i._lastPointerDownID=-1,i._effectiveBarOffset=0,i.onValueChangedObservable=new l.a,i._pointerIsDown=!1,i.isPointerBlocker=!0,i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"displayThumb",{get:function(){return this._displayThumb},set:function(e){this._displayThumb!==e&&(this._displayThumb=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"step",{get:function(){return this._step},set:function(e){this._step!==e&&(this._step=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"barOffset",{get:function(){return this._barOffset.toString(this._host)},set:function(e){this._barOffset.toString(this._host)!==e&&this._barOffset.fromString(e)&&this._markAsDirty()},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"barOffsetInPixels",{get:function(){return this._barOffset.getValueInPixel(this._host,this._cachedParentMeasure.width)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"thumbWidth",{get:function(){return this._thumbWidth.toString(this._host)},set:function(e){this._thumbWidth.toString(this._host)!==e&&this._thumbWidth.fromString(e)&&this._markAsDirty()},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"thumbWidthInPixels",{get:function(){return this._thumbWidth.getValueInPixel(this._host,this._cachedParentMeasure.width)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"minimum",{get:function(){return this._minimum},set:function(e){this._minimum!==e&&(this._minimum=e,this._markAsDirty(),this.value=Math.max(Math.min(this.value,this._maximum),this._minimum))},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"maximum",{get:function(){return this._maximum},set:function(e){this._maximum!==e&&(this._maximum=e,this._markAsDirty(),this.value=Math.max(Math.min(this.value,this._maximum),this._minimum))},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"value",{get:function(){return this._value},set:function(e){e=Math.max(Math.min(e,this._maximum),this._minimum),this._value!==e&&(this._value=e,this._markAsDirty(),this.onValueChangedObservable.notifyObservers(this._value))},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isVertical",{get:function(){return this._isVertical},set:function(e){this._isVertical!==e&&(this._isVertical=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isThumbClamped",{get:function(){return this._isThumbClamped},set:function(e){this._isThumbClamped!==e&&(this._isThumbClamped=e,this._markAsDirty())},enumerable:!1,configurable:!0}),t.prototype._getTypeName=function(){return"BaseSlider"},t.prototype._getThumbPosition=function(){return this.isVertical?(this.maximum-this.value)/(this.maximum-this.minimum)*this._backgroundBoxLength:(this.value-this.minimum)/(this.maximum-this.minimum)*this._backgroundBoxLength},t.prototype._getThumbThickness=function(e){var t=0;switch(e){case"circle":t=this._thumbWidth.isPixel?Math.max(this._thumbWidth.getValue(this._host),this._backgroundBoxThickness):this._backgroundBoxThickness*this._thumbWidth.getValue(this._host);break;case"rectangle":t=this._thumbWidth.isPixel?Math.min(this._thumbWidth.getValue(this._host),this._backgroundBoxThickness):this._backgroundBoxThickness*this._thumbWidth.getValue(this._host)}return t},t.prototype._prepareRenderingData=function(e){this._effectiveBarOffset=0,this._renderLeft=this._currentMeasure.left,this._renderTop=this._currentMeasure.top,this._renderWidth=this._currentMeasure.width,this._renderHeight=this._currentMeasure.height,this._backgroundBoxLength=Math.max(this._currentMeasure.width,this._currentMeasure.height),this._backgroundBoxThickness=Math.min(this._currentMeasure.width,this._currentMeasure.height),this._effectiveThumbThickness=this._getThumbThickness(e),this.displayThumb&&(this._backgroundBoxLength-=this._effectiveThumbThickness),this.isVertical&&this._currentMeasure.height=this._selectors.length))return this._selectors[e]},e.prototype.removeSelector=function(e){e<0||e>=this._selectors.length||(this._groupPanel.removeControl(this._selectors[e]),this._selectors.splice(e,1))},e}(),N=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return Object(r.c)(t,e),t.prototype.addCheckbox=function(e,t,i){void 0===t&&(t=function(e){}),void 0===i&&(i=!1);i=i||!1;var r=new g;r.width="20px",r.height="20px",r.color="#364249",r.background="#CCCCCC",r.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,r.onIsCheckedChangedObservable.add((function(e){t(e)}));var n=h.a.AddHeader(r,e,"200px",{isHorizontal:!0,controlFirst:!0});n.height="30px",n.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,n.left="4px",this.groupPanel.addControl(n),this.selectors.push(n),r.isChecked=i,this.groupPanel.parent&&this.groupPanel.parent.parent&&(r.color=this.groupPanel.parent.parent.buttonColor,r.background=this.groupPanel.parent.parent.buttonBackground)},t.prototype._setSelectorLabel=function(e,t){this.selectors[e].children[1].text=t},t.prototype._setSelectorLabelColor=function(e,t){this.selectors[e].children[1].color=t},t.prototype._setSelectorButtonColor=function(e,t){this.selectors[e].children[0].color=t},t.prototype._setSelectorButtonBackground=function(e,t){this.selectors[e].children[0].background=t},t}(F),B=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t._selectNb=0,t}return Object(r.c)(t,e),t.prototype.addRadio=function(e,t,i){void 0===t&&(t=function(e){}),void 0===i&&(i=!1);var r=this._selectNb++,n=new D;n.name=e,n.width="20px",n.height="20px",n.color="#364249",n.background="#CCCCCC",n.group=this.name,n.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,n.onIsCheckedChangedObservable.add((function(e){e&&t(r)}));var o=h.a.AddHeader(n,e,"200px",{isHorizontal:!0,controlFirst:!0});o.height="30px",o.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,o.left="4px",this.groupPanel.addControl(o),this.selectors.push(o),n.isChecked=i,this.groupPanel.parent&&this.groupPanel.parent.parent&&(n.color=this.groupPanel.parent.parent.buttonColor,n.background=this.groupPanel.parent.parent.buttonBackground)},t.prototype._setSelectorLabel=function(e,t){this.selectors[e].children[1].text=t},t.prototype._setSelectorLabelColor=function(e,t){this.selectors[e].children[1].color=t},t.prototype._setSelectorButtonColor=function(e,t){this.selectors[e].children[0].color=t},t.prototype._setSelectorButtonBackground=function(e,t){this.selectors[e].children[0].background=t},t}(F),k=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return Object(r.c)(t,e),t.prototype.addSlider=function(e,t,i,r,n,o,s){void 0===t&&(t=function(e){}),void 0===i&&(i="Units"),void 0===r&&(r=0),void 0===n&&(n=0),void 0===o&&(o=0),void 0===s&&(s=function(e){return 0|e});var a=new L;a.name=i,a.value=o,a.minimum=r,a.maximum=n,a.width=.9,a.height="20px",a.color="#364249",a.background="#CCCCCC",a.borderColor="black",a.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,a.left="4px",a.paddingBottom="4px",a.onValueChangedObservable.add((function(e){a.parent.children[0].text=a.parent.children[0].name+": "+s(e)+" "+a.name,t(e)}));var l=h.a.AddHeader(a,e+": "+s(o)+" "+i,"30px",{isHorizontal:!1,controlFirst:!1});l.height="60px",l.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,l.left="4px",l.children[0].name=e,this.groupPanel.addControl(l),this.selectors.push(l),this.groupPanel.parent&&this.groupPanel.parent.parent&&(a.color=this.groupPanel.parent.parent.buttonColor,a.background=this.groupPanel.parent.parent.buttonBackground)},t.prototype._setSelectorLabel=function(e,t){this.selectors[e].children[0].name=t,this.selectors[e].children[0].text=t+": "+this.selectors[e].children[1].value+" "+this.selectors[e].children[1].name},t.prototype._setSelectorLabelColor=function(e,t){this.selectors[e].children[0].color=t},t.prototype._setSelectorButtonColor=function(e,t){this.selectors[e].children[1].color=t},t.prototype._setSelectorButtonBackground=function(e,t){this.selectors[e].children[1].background=t},t}(F),U=function(e){function t(t,i){void 0===i&&(i=[]);var r=e.call(this,t)||this;if(r.name=t,r.groups=i,r._buttonColor="#364249",r._buttonBackground="#CCCCCC",r._headerColor="black",r._barColor="white",r._barHeight="2px",r._spacerHeight="20px",r._bars=new Array,r._groups=i,r.thickness=2,r._panel=new _,r._panel.verticalAlignment=h.a.VERTICAL_ALIGNMENT_TOP,r._panel.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,r._panel.top=5,r._panel.left=5,r._panel.width=.95,i.length>0){for(var n=0;n0&&this._addSpacer(),this._panel.addControl(e.groupPanel),this._groups.push(e),e.groupPanel.children[0].color=this._headerColor;for(var t=0;t=this._groups.length)){var t=this._groups[e];this._panel.removeControl(t.groupPanel),this._groups.splice(e,1),e=this._groups.length||(this._groups[t].groupPanel.children[0].text=e)},t.prototype.relabel=function(e,t,i){if(!(t<0||t>=this._groups.length)){var r=this._groups[t];i<0||i>=r.selectors.length||r._setSelectorLabel(i,e)}},t.prototype.removeFromGroupSelector=function(e,t){if(!(e<0||e>=this._groups.length)){var i=this._groups[e];t<0||t>=i.selectors.length||i.removeSelector(t)}},t.prototype.addToGroupCheckbox=function(e,t,i,r){(void 0===i&&(i=function(){}),void 0===r&&(r=!1),e<0||e>=this._groups.length)||this._groups[e].addCheckbox(t,i,r)},t.prototype.addToGroupRadio=function(e,t,i,r){(void 0===i&&(i=function(){}),void 0===r&&(r=!1),e<0||e>=this._groups.length)||this._groups[e].addRadio(t,i,r)},t.prototype.addToGroupSlider=function(e,t,i,r,n,o,s,a){(void 0===i&&(i=function(){}),void 0===r&&(r="Units"),void 0===n&&(n=0),void 0===o&&(o=0),void 0===s&&(s=0),void 0===a&&(a=function(e){return 0|e}),e<0||e>=this._groups.length)||this._groups[e].addSlider(t,i,r,n,o,s,a)},t}(s),V=i(30),j=function(e){function t(t){var i=e.call(this,t)||this;return i._freezeControls=!1,i._bucketWidth=0,i._bucketHeight=0,i._buckets={},i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"freezeControls",{get:function(){return this._freezeControls},set:function(e){if(this._freezeControls!==e){e||this._restoreMeasures(),this._freezeControls=!1;var t=this.host.getSize(),i=t.width,r=t.height,n=this.host.getContext(),o=new V.a(0,0,i,r);this.host._numLayoutCalls=0,this.host._rootContainer._layout(o,n),e&&(this._updateMeasures(),this._useBuckets()&&this._makeBuckets()),this._freezeControls=e,this.host.markAsDirty()}},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"bucketWidth",{get:function(){return this._bucketWidth},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"bucketHeight",{get:function(){return this._bucketHeight},enumerable:!1,configurable:!0}),t.prototype.setBucketSizes=function(e,t){this._bucketWidth=e,this._bucketHeight=t,this._useBuckets()?this._freezeControls&&this._makeBuckets():this._buckets={}},t.prototype._useBuckets=function(){return this._bucketWidth>0&&this._bucketHeight>0},t.prototype._makeBuckets=function(){this._buckets={},this._bucketLen=Math.ceil(this.widthInPixels/this._bucketWidth),this._dispatchInBuckets(this._children),this._oldLeft=null,this._oldTop=null},t.prototype._dispatchInBuckets=function(e){for(var t=0;t0&&this._dispatchInBuckets(i._children)}},t.prototype._updateMeasures=function(){var e=0|this.leftInPixels,t=0|this.topInPixels;this._measureForChildren.left-=e,this._measureForChildren.top-=t,this._currentMeasure.left-=e,this._currentMeasure.top-=t,this._customData.origLeftForChildren=this._measureForChildren.left,this._customData.origTopForChildren=this._measureForChildren.top,this._customData.origLeft=this._currentMeasure.left,this._customData.origTop=this._currentMeasure.top,this._updateChildrenMeasures(this._children,e,t)},t.prototype._updateChildrenMeasures=function(e,t,i){for(var r=0;r0&&this._updateChildrenMeasures(o._children,t,i)}},t.prototype._restoreMeasures=function(){var e=0|this.leftInPixels,t=0|this.topInPixels;this._measureForChildren.left=this._customData.origLeftForChildren+e,this._measureForChildren.top=this._customData.origTopForChildren+t,this._currentMeasure.left=this._customData.origLeft+e,this._currentMeasure.top=this._customData.origTop+t},t.prototype._getTypeName=function(){return"ScrollViewerWindow"},t.prototype._additionalProcessing=function(t,i){e.prototype._additionalProcessing.call(this,t,i),this._parentMeasure=t,this._measureForChildren.left=this._currentMeasure.left,this._measureForChildren.top=this._currentMeasure.top,this._measureForChildren.width=t.width,this._measureForChildren.height=t.height},t.prototype._layout=function(t,i){return this._freezeControls?(this.invalidateRect(),!1):e.prototype._layout.call(this,t,i)},t.prototype._scrollChildren=function(e,t,i){for(var r=0;r0&&this._scrollChildren(o._children,t,i)}},t.prototype._scrollChildrenWithBuckets=function(e,t,i,r){for(var n=Math.max(0,Math.floor(-e/this._bucketWidth)),o=Math.floor((-e+this._parentMeasure.width-1)/this._bucketWidth),s=Math.max(0,Math.floor(-t/this._bucketHeight)),a=Math.floor((-t+this._parentMeasure.height-1)/this._bucketHeight);s<=a;){for(var h=n;h<=o;++h){var l=s*this._bucketLen+h,c=this._buckets[l];if(c)for(var u=0;uthis._tempMeasure.left+this._tempMeasure.width||tthis._tempMeasure.top+this._tempMeasure.height)&&(this.isVertical?this.value=this.minimum+(1-(t-this._currentMeasure.top)/this._currentMeasure.height)*(this.maximum-this.minimum):this.value=this.minimum+(e-this._currentMeasure.left)/this._currentMeasure.width*(this.maximum-this.minimum)));var i=0;i=this.isVertical?-(t-this._originY)/(this._currentMeasure.height-this._effectiveThumbThickness):(e-this._originX)/(this._currentMeasure.width-this._effectiveThumbThickness),this.value+=i*(this.maximum-this.minimum),this._originX=e,this._originY=t},t.prototype._onPointerDown=function(t,i,r,n,o){return this._first=!0,e.prototype._onPointerDown.call(this,t,i,r,n,o)},t}(w),W=function(e){function t(t){var i=e.call(this,t)||this;return i.name=t,i._thumbLength=.5,i._thumbHeight=1,i._barImageHeight=1,i._tempMeasure=new V.a(0,0,0,0),i.num90RotationInVerticalMode=1,i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"backgroundImage",{get:function(){return this._backgroundBaseImage},set:function(e){var t=this;this._backgroundBaseImage!==e&&(this._backgroundBaseImage=e,this.isVertical&&0!==this.num90RotationInVerticalMode?e.isLoaded?(this._backgroundImage=e._rotate90(this.num90RotationInVerticalMode,!0),this._markAsDirty()):e.onImageLoadedObservable.addOnce((function(){var i=e._rotate90(t.num90RotationInVerticalMode,!0);t._backgroundImage=i,i.isLoaded||i.onImageLoadedObservable.addOnce((function(){t._markAsDirty()})),t._markAsDirty()})):(this._backgroundImage=e,e&&!e.isLoaded&&e.onImageLoadedObservable.addOnce((function(){t._markAsDirty()})),this._markAsDirty()))},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"thumbImage",{get:function(){return this._thumbBaseImage},set:function(e){var t=this;this._thumbBaseImage!==e&&(this._thumbBaseImage=e,this.isVertical&&0!==this.num90RotationInVerticalMode?e.isLoaded?(this._thumbImage=e._rotate90(-this.num90RotationInVerticalMode,!0),this._markAsDirty()):e.onImageLoadedObservable.addOnce((function(){var i=e._rotate90(-t.num90RotationInVerticalMode,!0);t._thumbImage=i,i.isLoaded||i.onImageLoadedObservable.addOnce((function(){t._markAsDirty()})),t._markAsDirty()})):(this._thumbImage=e,e&&!e.isLoaded&&e.onImageLoadedObservable.addOnce((function(){t._markAsDirty()})),this._markAsDirty()))},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"thumbLength",{get:function(){return this._thumbLength},set:function(e){this._thumbLength!==e&&(this._thumbLength=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"thumbHeight",{get:function(){return this._thumbHeight},set:function(e){this._thumbLength!==e&&(this._thumbHeight=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"barImageHeight",{get:function(){return this._barImageHeight},set:function(e){this._barImageHeight!==e&&(this._barImageHeight=e,this._markAsDirty())},enumerable:!1,configurable:!0}),t.prototype._getTypeName=function(){return"ImageScrollBar"},t.prototype._getThumbThickness=function(){return this._thumbWidth.isPixel?this._thumbWidth.getValue(this._host):this._backgroundBoxThickness*this._thumbWidth.getValue(this._host)},t.prototype._draw=function(e){e.save(),this._applyStates(e),this._prepareRenderingData("rectangle");var t=this._getThumbPosition(),i=this._renderLeft,r=this._renderTop,n=this._renderWidth,o=this._renderHeight;this._backgroundImage&&(this._tempMeasure.copyFromFloats(i,r,n,o),this.isVertical?(this._tempMeasure.copyFromFloats(i+n*(1-this._barImageHeight)*.5,this._currentMeasure.top,n*this._barImageHeight,o),this._tempMeasure.height+=this._effectiveThumbThickness,this._backgroundImage._currentMeasure.copyFrom(this._tempMeasure)):(this._tempMeasure.copyFromFloats(this._currentMeasure.left,r+o*(1-this._barImageHeight)*.5,n,o*this._barImageHeight),this._tempMeasure.width+=this._effectiveThumbThickness,this._backgroundImage._currentMeasure.copyFrom(this._tempMeasure)),this._backgroundImage._draw(e)),this.isVertical?this._tempMeasure.copyFromFloats(i-this._effectiveBarOffset+this._currentMeasure.width*(1-this._thumbHeight)*.5,this._currentMeasure.top+t,this._currentMeasure.width*this._thumbHeight,this._effectiveThumbThickness):this._tempMeasure.copyFromFloats(this._currentMeasure.left+t,this._currentMeasure.top+this._currentMeasure.height*(1-this._thumbHeight)*.5,this._effectiveThumbThickness,this._currentMeasure.height*this._thumbHeight),this._thumbImage&&(this._thumbImage._currentMeasure.copyFrom(this._tempMeasure),this._thumbImage._draw(e)),e.restore()},t.prototype._updateValueFromPointer=function(e,t){0!=this.rotation&&(this._invertTransformMatrix.transformCoordinates(e,t,this._transformedPosition),e=this._transformedPosition.x,t=this._transformedPosition.y),this._first&&(this._first=!1,this._originX=e,this._originY=t,(ethis._tempMeasure.left+this._tempMeasure.width||tthis._tempMeasure.top+this._tempMeasure.height)&&(this.isVertical?this.value=this.minimum+(1-(t-this._currentMeasure.top)/this._currentMeasure.height)*(this.maximum-this.minimum):this.value=this.minimum+(e-this._currentMeasure.left)/this._currentMeasure.width*(this.maximum-this.minimum)));var i=0;i=this.isVertical?-(t-this._originY)/(this._currentMeasure.height-this._effectiveThumbThickness):(e-this._originX)/(this._currentMeasure.width-this._effectiveThumbThickness),this.value+=i*(this.maximum-this.minimum),this._originX=e,this._originY=t},t.prototype._onPointerDown=function(t,i,r,n,o){return this._first=!0,e.prototype._onPointerDown.call(this,t,i,r,n,o)},t}(w),G=function(e){function t(t,i){var r=e.call(this,t)||this;return r._barSize=20,r._pointerIsOver=!1,r._wheelPrecision=.05,r._thumbLength=.5,r._thumbHeight=1,r._barImageHeight=1,r._horizontalBarImageHeight=1,r._verticalBarImageHeight=1,r._oldWindowContentsWidth=0,r._oldWindowContentsHeight=0,r._forceHorizontalBar=!1,r._forceVerticalBar=!1,r._useImageBar=i||!1,r.onDirtyObservable.add((function(){r._horizontalBarSpace.color=r.color,r._verticalBarSpace.color=r.color,r._dragSpace.color=r.color})),r.onPointerEnterObservable.add((function(){r._pointerIsOver=!0})),r.onPointerOutObservable.add((function(){r._pointerIsOver=!1})),r._grid=new T,r._useImageBar?(r._horizontalBar=new W,r._verticalBar=new W):(r._horizontalBar=new z,r._verticalBar=new z),r._window=new j("scrollViewer_window"),r._window.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,r._window.verticalAlignment=h.a.VERTICAL_ALIGNMENT_TOP,r._grid.addColumnDefinition(1),r._grid.addColumnDefinition(0,!0),r._grid.addRowDefinition(1),r._grid.addRowDefinition(0,!0),e.prototype.addControl.call(r,r._grid),r._grid.addControl(r._window,0,0),r._verticalBarSpace=new s,r._verticalBarSpace.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,r._verticalBarSpace.verticalAlignment=h.a.VERTICAL_ALIGNMENT_TOP,r._verticalBarSpace.thickness=1,r._grid.addControl(r._verticalBarSpace,0,1),r._addBar(r._verticalBar,r._verticalBarSpace,!0,Math.PI),r._horizontalBarSpace=new s,r._horizontalBarSpace.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_LEFT,r._horizontalBarSpace.verticalAlignment=h.a.VERTICAL_ALIGNMENT_TOP,r._horizontalBarSpace.thickness=1,r._grid.addControl(r._horizontalBarSpace,1,0),r._addBar(r._horizontalBar,r._horizontalBarSpace,!1,0),r._dragSpace=new s,r._dragSpace.thickness=1,r._grid.addControl(r._dragSpace,1,1),r._useImageBar||(r.barColor="grey",r.barBackground="transparent"),r}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"horizontalBar",{get:function(){return this._horizontalBar},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"verticalBar",{get:function(){return this._verticalBar},enumerable:!1,configurable:!0}),t.prototype.addControl=function(e){return e?(this._window.addControl(e),this):this},t.prototype.removeControl=function(e){return this._window.removeControl(e),this},Object.defineProperty(t.prototype,"children",{get:function(){return this._window.children},enumerable:!1,configurable:!0}),t.prototype._flagDescendantsAsMatrixDirty=function(){for(var e=0,t=this._children;e1&&(e=1),this._wheelPrecision=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"scrollBackground",{get:function(){return this._horizontalBarSpace.background},set:function(e){this._horizontalBarSpace.background!==e&&(this._horizontalBarSpace.background=e,this._verticalBarSpace.background=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"barColor",{get:function(){return this._barColor},set:function(e){this._barColor!==e&&(this._barColor=e,this._horizontalBar.color=e,this._verticalBar.color=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"thumbImage",{get:function(){return this._barImage},set:function(e){if(this._barImage!==e){this._barImage=e;var t=this._horizontalBar,i=this._verticalBar;t.thumbImage=e,i.thumbImage=e}},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"horizontalThumbImage",{get:function(){return this._horizontalBarImage},set:function(e){this._horizontalBarImage!==e&&(this._horizontalBarImage=e,this._horizontalBar.thumbImage=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"verticalThumbImage",{get:function(){return this._verticalBarImage},set:function(e){this._verticalBarImage!==e&&(this._verticalBarImage=e,this._verticalBar.thumbImage=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"barSize",{get:function(){return this._barSize},set:function(e){this._barSize!==e&&(this._barSize=e,this._markAsDirty(),this._horizontalBar.isVisible&&this._grid.setRowDefinition(1,this._barSize,!0),this._verticalBar.isVisible&&this._grid.setColumnDefinition(1,this._barSize,!0))},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"thumbLength",{get:function(){return this._thumbLength},set:function(e){if(this._thumbLength!==e){e<=0&&(e=.1),e>1&&(e=1),this._thumbLength=e;var t=this._horizontalBar,i=this._verticalBar;t.thumbLength=e,i.thumbLength=e,this._markAsDirty()}},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"thumbHeight",{get:function(){return this._thumbHeight},set:function(e){if(this._thumbHeight!==e){e<=0&&(e=.1),e>1&&(e=1),this._thumbHeight=e;var t=this._horizontalBar,i=this._verticalBar;t.thumbHeight=e,i.thumbHeight=e,this._markAsDirty()}},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"barImageHeight",{get:function(){return this._barImageHeight},set:function(e){if(this._barImageHeight!==e){e<=0&&(e=.1),e>1&&(e=1),this._barImageHeight=e;var t=this._horizontalBar,i=this._verticalBar;t.barImageHeight=e,i.barImageHeight=e,this._markAsDirty()}},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"horizontalBarImageHeight",{get:function(){return this._horizontalBarImageHeight},set:function(e){this._horizontalBarImageHeight!==e&&(e<=0&&(e=.1),e>1&&(e=1),this._horizontalBarImageHeight=e,this._horizontalBar.barImageHeight=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"verticalBarImageHeight",{get:function(){return this._verticalBarImageHeight},set:function(e){this._verticalBarImageHeight!==e&&(e<=0&&(e=.1),e>1&&(e=1),this._verticalBarImageHeight=e,this._verticalBar.barImageHeight=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"barBackground",{get:function(){return this._barBackground},set:function(e){if(this._barBackground!==e){this._barBackground=e;var t=this._horizontalBar,i=this._verticalBar;t.background=e,i.background=e,this._dragSpace.background=e}},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"barImage",{get:function(){return this._barBackgroundImage},set:function(e){this._barBackgroundImage,this._barBackgroundImage=e;var t=this._horizontalBar,i=this._verticalBar;t.backgroundImage=e,i.backgroundImage=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"horizontalBarImage",{get:function(){return this._horizontalBarBackgroundImage},set:function(e){this._horizontalBarBackgroundImage,this._horizontalBarBackgroundImage=e,this._horizontalBar.backgroundImage=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"verticalBarImage",{get:function(){return this._verticalBarBackgroundImage},set:function(e){this._verticalBarBackgroundImage,this._verticalBarBackgroundImage=e,this._verticalBar.backgroundImage=e},enumerable:!1,configurable:!0}),t.prototype._setWindowPosition=function(e){void 0===e&&(e=!0);var t=this.host.idealRatio,i=this._window._currentMeasure.width,r=this._window._currentMeasure.height;if(e||this._oldWindowContentsWidth!==i||this._oldWindowContentsHeight!==r){this._oldWindowContentsWidth=i,this._oldWindowContentsHeight=r;var n=this._clientWidth-i,o=this._clientHeight-r,s=this._horizontalBar.value/t*n+"px",a=this._verticalBar.value/t*o+"px";s!==this._window.left&&(this._window.left=s,this.freezeControls||(this._rebuildLayout=!0)),a!==this._window.top&&(this._window.top=a,this.freezeControls||(this._rebuildLayout=!0))}},t.prototype._updateScroller=function(){var e=this._window._currentMeasure.width,t=this._window._currentMeasure.height;this._horizontalBar.isVisible&&e<=this._clientWidth&&!this.forceHorizontalBar?(this._grid.setRowDefinition(1,0,!0),this._horizontalBar.isVisible=!1,this._horizontalBar.value=0,this._rebuildLayout=!0):!this._horizontalBar.isVisible&&(e>this._clientWidth||this.forceHorizontalBar)&&(this._grid.setRowDefinition(1,this._barSize,!0),this._horizontalBar.isVisible=!0,this._rebuildLayout=!0),this._verticalBar.isVisible&&t<=this._clientHeight&&!this.forceVerticalBar?(this._grid.setColumnDefinition(1,0,!0),this._verticalBar.isVisible=!1,this._verticalBar.value=0,this._rebuildLayout=!0):!this._verticalBar.isVisible&&(t>this._clientHeight||this.forceVerticalBar)&&(this._grid.setColumnDefinition(1,this._barSize,!0),this._verticalBar.isVisible=!0,this._rebuildLayout=!0),this._buildClientSizes();var i=this.host.idealRatio;this._horizontalBar.thumbWidth=.9*this._thumbLength*(this._clientWidth/i)+"px",this._verticalBar.thumbWidth=.9*this._thumbLength*(this._clientHeight/i)+"px"},t.prototype._link=function(t){e.prototype._link.call(this,t),this._attachWheel()},t.prototype._addBar=function(e,t,i,r){var n=this;e.paddingLeft=0,e.width="100%",e.height="100%",e.barOffset=0,e.value=0,e.maximum=1,e.horizontalAlignment=h.a.HORIZONTAL_ALIGNMENT_CENTER,e.verticalAlignment=h.a.VERTICAL_ALIGNMENT_CENTER,e.isVertical=i,e.rotation=r,e.isVisible=!1,t.addControl(e),e.onValueChangedObservable.add((function(e){n._setWindowPosition()}))},t.prototype._attachWheel=function(){var e=this;this._host&&!this._onWheelObserver&&(this._onWheelObserver=this.onWheelObservable.add((function(t){e._pointerIsOver&&(1==e._verticalBar.isVisible&&(t.y<0&&e._verticalBar.value>0?e._verticalBar.value-=e._wheelPrecision:t.y>0&&e._verticalBar.value0&&e._horizontalBar.value>0&&(e._horizontalBar.value-=e._wheelPrecision)))})))},t.prototype._renderHighlightSpecific=function(t){this.isHighlighted&&(e.prototype._renderHighlightSpecific.call(this,t),this._grid._renderHighlightSpecific(t),t.restore())},t.prototype.dispose=function(){this.onWheelObservable.remove(this._onWheelObserver),this._onWheelObserver=null,e.prototype.dispose.call(this)},t}(s);o.a.RegisteredTypes["BABYLON.GUI.ScrollViewer"]=G;var H=function(){},X=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.onKeyPressObservable=new l.a,t.defaultButtonWidth="40px",t.defaultButtonHeight="40px",t.defaultButtonPaddingLeft="2px",t.defaultButtonPaddingRight="2px",t.defaultButtonPaddingTop="2px",t.defaultButtonPaddingBottom="2px",t.defaultButtonColor="#DDD",t.defaultButtonBackground="#070707",t.shiftButtonColor="#7799FF",t.selectedShiftThickness=1,t.shiftState=0,t._currentlyConnectedInputText=null,t._connectedInputTexts=[],t._onKeyPressObserver=null,t}return Object(r.c)(t,e),t.prototype._getTypeName=function(){return"VirtualKeyboard"},t.prototype._createKey=function(e,t){var i=this,r=p.CreateSimpleButton(e,e);return r.width=t&&t.width?t.width:this.defaultButtonWidth,r.height=t&&t.height?t.height:this.defaultButtonHeight,r.color=t&&t.color?t.color:this.defaultButtonColor,r.background=t&&t.background?t.background:this.defaultButtonBackground,r.paddingLeft=t&&t.paddingLeft?t.paddingLeft:this.defaultButtonPaddingLeft,r.paddingRight=t&&t.paddingRight?t.paddingRight:this.defaultButtonPaddingRight,r.paddingTop=t&&t.paddingTop?t.paddingTop:this.defaultButtonPaddingTop,r.paddingBottom=t&&t.paddingBottom?t.paddingBottom:this.defaultButtonPaddingBottom,r.thickness=0,r.isFocusInvisible=!0,r.shadowColor=this.shadowColor,r.shadowBlur=this.shadowBlur,r.shadowOffsetX=this.shadowOffsetX,r.shadowOffsetY=this.shadowOffsetY,r.onPointerUpObservable.add((function(){i.onKeyPressObservable.notifyObservers(e)})),r},t.prototype.addKeysRow=function(e,t){var i=new _;i.isVertical=!1,i.isFocusInvisible=!0;for(var r=null,n=0;nr.heightInPixels)&&(r=s),i.addControl(s)}i.height=r?r.height:this.defaultButtonHeight,this.addControl(i)},t.prototype.applyShiftState=function(e){if(this.children)for(var t=0;t1?this.selectedShiftThickness:0),s.text=e>0?s.text.toUpperCase():s.text.toLowerCase()}}}},Object.defineProperty(t.prototype,"connectedInputText",{get:function(){return this._currentlyConnectedInputText},enumerable:!1,configurable:!0}),t.prototype.connect=function(e){var t=this;if(!this._connectedInputTexts.some((function(t){return t.input===e}))){null===this._onKeyPressObserver&&(this._onKeyPressObserver=this.onKeyPressObservable.add((function(e){if(t._currentlyConnectedInputText){switch(t._currentlyConnectedInputText._host.focusedControl=t._currentlyConnectedInputText,e){case"⇧":return t.shiftState++,t.shiftState>2&&(t.shiftState=0),void t.applyShiftState(t.shiftState);case"←":return void t._currentlyConnectedInputText.processKey(8);case"↵":return void t._currentlyConnectedInputText.processKey(13)}t._currentlyConnectedInputText.processKey(-1,t.shiftState?e.toUpperCase():e),1===t.shiftState&&(t.shiftState=0,t.applyShiftState(t.shiftState))}}))),this.isVisible=!1,this._currentlyConnectedInputText=e,e._connectedVirtualKeyboard=this;var i=e.onFocusObservable.add((function(){t._currentlyConnectedInputText=e,e._connectedVirtualKeyboard=t,t.isVisible=!0})),r=e.onBlurObservable.add((function(){e._connectedVirtualKeyboard=null,t._currentlyConnectedInputText=null,t.isVisible=!1}));this._connectedInputTexts.push({input:e,onBlurObserver:r,onFocusObserver:i})}},t.prototype.disconnect=function(e){var t=this;if(e){var i=this._connectedInputTexts.filter((function(t){return t.input===e}));1===i.length&&(this._removeConnectedInputObservables(i[0]),this._connectedInputTexts=this._connectedInputTexts.filter((function(t){return t.input!==e})),this._currentlyConnectedInputText===e&&(this._currentlyConnectedInputText=null))}else this._connectedInputTexts.forEach((function(e){t._removeConnectedInputObservables(e)})),this._connectedInputTexts=[];0===this._connectedInputTexts.length&&(this._currentlyConnectedInputText=null,this.onKeyPressObservable.remove(this._onKeyPressObserver),this._onKeyPressObserver=null)},t.prototype._removeConnectedInputObservables=function(e){e.input._connectedVirtualKeyboard=null,e.input.onFocusObservable.remove(e.onFocusObserver),e.input.onBlurObservable.remove(e.onBlurObserver)},t.prototype.dispose=function(){e.prototype.dispose.call(this),this.disconnect()},t.CreateDefaultLayout=function(e){var i=new t(e);return i.addKeysRow(["1","2","3","4","5","6","7","8","9","0","←"]),i.addKeysRow(["q","w","e","r","t","y","u","i","o","p"]),i.addKeysRow(["a","s","d","f","g","h","j","k","l",";","'","↵"]),i.addKeysRow(["⇧","z","x","c","v","b","n","m",",",".","/"]),i.addKeysRow([" "],[{width:"200px"}]),i},t}(_);o.a.RegisteredTypes["BABYLON.GUI.VirtualKeyboard"]=X;var K=function(e){function t(t){var i=e.call(this,t)||this;return i.name=t,i._cellWidth=20,i._cellHeight=20,i._minorLineTickness=1,i._minorLineColor="DarkGray",i._majorLineTickness=2,i._majorLineColor="White",i._majorLineFrequency=5,i._background="Black",i._displayMajorLines=!0,i._displayMinorLines=!0,i}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"displayMinorLines",{get:function(){return this._displayMinorLines},set:function(e){this._displayMinorLines!==e&&(this._displayMinorLines=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"displayMajorLines",{get:function(){return this._displayMajorLines},set:function(e){this._displayMajorLines!==e&&(this._displayMajorLines=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"background",{get:function(){return this._background},set:function(e){this._background!==e&&(this._background=e,this._markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"cellWidth",{get:function(){return this._cellWidth},set:function(e){this._cellWidth=e,this._markAsDirty()},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"cellHeight",{get:function(){return this._cellHeight},set:function(e){this._cellHeight=e,this._markAsDirty()},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"minorLineTickness",{get:function(){return this._minorLineTickness},set:function(e){this._minorLineTickness=e,this._markAsDirty()},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"minorLineColor",{get:function(){return this._minorLineColor},set:function(e){this._minorLineColor=e,this._markAsDirty()},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"majorLineTickness",{get:function(){return this._majorLineTickness},set:function(e){this._majorLineTickness=e,this._markAsDirty()},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"majorLineColor",{get:function(){return this._majorLineColor},set:function(e){this._majorLineColor=e,this._markAsDirty()},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"majorLineFrequency",{get:function(){return this._majorLineFrequency},set:function(e){this._majorLineFrequency=e,this._markAsDirty()},enumerable:!1,configurable:!0}),t.prototype._draw=function(e,t){if(e.save(),this._applyStates(e),this._isEnabled){this._background&&(e.fillStyle=this._background,e.fillRect(this._currentMeasure.left,this._currentMeasure.top,this._currentMeasure.width,this._currentMeasure.height));var i=this._currentMeasure.width/this._cellWidth,r=this._currentMeasure.height/this._cellHeight,n=this._currentMeasure.left+this._currentMeasure.width/2,o=this._currentMeasure.top+this._currentMeasure.height/2;if(this._displayMinorLines){e.strokeStyle=this._minorLineColor,e.lineWidth=this._minorLineTickness;for(var s=-i/2;s0&&e.isBackground===t&&e.renderTargetTextures.indexOf(r)>-1&&0!=(e.layerMask&i)},e.prototype._drawRenderTargetBackground=function(e){var t=this;this._draw((function(i){return t._drawRenderTargetPredicate(i,!0,t.scene.activeCamera.layerMask,e)}))},e.prototype._drawRenderTargetForeground=function(e){var t=this;this._draw((function(i){return t._drawRenderTargetPredicate(i,!1,t.scene.activeCamera.layerMask,e)}))},e.prototype.addFromContainer=function(e){var t=this;e.layers&&e.layers.forEach((function(e){t.scene.layers.push(e)}))},e.prototype.removeFromContainer=function(e,t){var i=this;void 0===t&&(t=!1),e.layers&&e.layers.forEach((function(e){var r=i.scene.layers.indexOf(e);-1!==r&&i.scene.layers.splice(r,1),t&&e.dispose()}))},e}(),b=i(5),y=(i(76),"\nvarying vec2 vUV;\nuniform sampler2D textureSampler;\n\nuniform vec4 color;\n\n#include\nvoid main(void) {\nvec4 baseColor=texture2D(textureSampler,vUV);\n#ifdef LINEAR\nbaseColor.rgb=toGammaSpace(baseColor.rgb);\n#endif\n#ifdef ALPHATEST\nif (baseColor.a<0.4)\ndiscard;\n#endif\ngl_FragColor=baseColor*color;\n}");b.a.ShadersStore.layerPixelShader=y;var T="\nattribute vec2 position;\n\nuniform vec2 scale;\nuniform vec2 offset;\nuniform mat4 textureMatrix;\n\nvarying vec2 vUV;\nconst vec2 madd=vec2(0.5,0.5);\nvoid main(void) {\nvec2 shiftedPosition=position*scale+offset;\nvUV=vec2(textureMatrix*vec4(shiftedPosition*madd+madd,1.0,0.0));\ngl_Position=vec4(shiftedPosition,0.0,1.0);\n}";b.a.ShadersStore.layerVertexShader=T;var x=function(){function e(e,t,i,r,s){this.name=e,this.scale=new o.d(1,1),this.offset=new o.d(0,0),this.alphaBlendingMode=2,this.layerMask=268435455,this.renderTargetTextures=[],this.renderOnlyInRenderTargetTextures=!1,this._vertexBuffers={},this.onDisposeObservable=new n.a,this.onBeforeRenderObservable=new n.a,this.onAfterRenderObservable=new n.a,this.texture=t?new u.a(t,i,!0):null,this.isBackground=void 0===r||r,this.color=void 0===s?new d.b(1,1,1,1):s,this._scene=i||p.a.LastCreatedScene;var a=this._scene._getComponent(m.a.NAME_LAYER);a||(a=new v(this._scene),this._scene._addComponent(a)),this._scene.layers.push(this);var h=this._scene.getEngine(),l=[];l.push(1,1),l.push(-1,1),l.push(-1,-1),l.push(1,-1);var c=new _.b(h,l,_.b.PositionKind,!1,!1,2);this._vertexBuffers[_.b.PositionKind]=c,this._createIndexBuffer()}return Object.defineProperty(e.prototype,"onDispose",{set:function(e){this._onDisposeObserver&&this.onDisposeObservable.remove(this._onDisposeObserver),this._onDisposeObserver=this.onDisposeObservable.add(e)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onBeforeRender",{set:function(e){this._onBeforeRenderObserver&&this.onBeforeRenderObservable.remove(this._onBeforeRenderObserver),this._onBeforeRenderObserver=this.onBeforeRenderObservable.add(e)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onAfterRender",{set:function(e){this._onAfterRenderObserver&&this.onAfterRenderObservable.remove(this._onAfterRenderObserver),this._onAfterRenderObserver=this.onAfterRenderObservable.add(e)},enumerable:!1,configurable:!0}),e.prototype._createIndexBuffer=function(){var e=this._scene.getEngine(),t=[];t.push(0),t.push(1),t.push(2),t.push(0),t.push(2),t.push(3),this._indexBuffer=e.createIndexBuffer(t)},e.prototype._rebuild=function(){var e=this._vertexBuffers[_.b.PositionKind];e&&e._rebuild(),this._createIndexBuffer()},e.prototype.render=function(){var e=this._scene.getEngine(),t="";this.alphaTest&&(t="#define ALPHATEST"),this.texture&&!this.texture.gammaSpace&&(t+="\r\n#define LINEAR"),this._previousDefines!==t&&(this._previousDefines=t,this._effect=e.createEffect("layer",[_.b.PositionKind],["textureMatrix","color","scale","offset"],["textureSampler"],t));var i=this._effect;if(i&&i.isReady()&&this.texture&&this.texture.isReady()){e=this._scene.getEngine();this.onBeforeRenderObservable.notifyObservers(this),e.enableEffect(i),e.setState(!1),i.setTexture("textureSampler",this.texture),i.setMatrix("textureMatrix",this.texture.getTextureMatrix()),i.setFloat4("color",this.color.r,this.color.g,this.color.b,this.color.a),i.setVector2("offset",this.offset),i.setVector2("scale",this.scale),e.bindBuffers(this._vertexBuffers,this._indexBuffer,i),this.alphaTest?e.drawElementsType(g.a.TriangleFillMode,0,6):(e.setAlphaMode(this.alphaBlendingMode),e.drawElementsType(g.a.TriangleFillMode,0,6),e.setAlphaMode(0)),this.onAfterRenderObservable.notifyObservers(this)}},e.prototype.dispose=function(){var e=this._vertexBuffers[_.b.PositionKind];e&&(e.dispose(),this._vertexBuffers[_.b.PositionKind]=null),this._indexBuffer&&(this._scene.getEngine()._releaseBuffer(this._indexBuffer),this._indexBuffer=null),this.texture&&(this.texture.dispose(),this.texture=null),this.renderTargetTextures=[];var t=this._scene.layers.indexOf(this);this._scene.layers.splice(t,1),this.onDisposeObservable.notifyObservers(this),this.onDisposeObservable.clear(),this.onAfterRenderObservable.clear(),this.onBeforeRenderObservable.clear()},e}(),E=i(32),A=i(15),M=function(){function e(e){this._fontFamily="Arial",this._fontStyle="",this._fontWeight="",this._fontSize=new A.a(18,A.a.UNITMODE_PIXEL,!1),this.onChangedObservable=new n.a,this._host=e}return Object.defineProperty(e.prototype,"fontSize",{get:function(){return this._fontSize.toString(this._host)},set:function(e){this._fontSize.toString(this._host)!==e&&this._fontSize.fromString(e)&&this.onChangedObservable.notifyObservers(this)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"fontFamily",{get:function(){return this._fontFamily},set:function(e){this._fontFamily!==e&&(this._fontFamily=e,this.onChangedObservable.notifyObservers(this))},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"fontStyle",{get:function(){return this._fontStyle},set:function(e){this._fontStyle!==e&&(this._fontStyle=e,this.onChangedObservable.notifyObservers(this))},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"fontWeight",{get:function(){return this._fontWeight},set:function(e){this._fontWeight!==e&&(this._fontWeight=e,this.onChangedObservable.notifyObservers(this))},enumerable:!1,configurable:!0}),e.prototype.dispose=function(){this.onChangedObservable.clear()},e}(),S=i(30),O=function(){function e(){}return e.ALPHA_DISABLE=0,e.ALPHA_ADD=1,e.ALPHA_COMBINE=2,e.ALPHA_SUBTRACT=3,e.ALPHA_MULTIPLY=4,e.ALPHA_MAXIMIZED=5,e.ALPHA_ONEONE=6,e.ALPHA_PREMULTIPLIED=7,e.ALPHA_PREMULTIPLIED_PORTERDUFF=8,e.ALPHA_INTERPOLATE=9,e.ALPHA_SCREENMODE=10,e.ALPHA_ONEONE_ONEONE=11,e.ALPHA_ALPHATOCOLOR=12,e.ALPHA_REVERSEONEMINUS=13,e.ALPHA_SRC_DSTONEMINUSSRCALPHA=14,e.ALPHA_ONEONE_ONEZERO=15,e.ALPHA_EXCLUSION=16,e.ALPHA_EQUATION_ADD=0,e.ALPHA_EQUATION_SUBSTRACT=1,e.ALPHA_EQUATION_REVERSE_SUBTRACT=2,e.ALPHA_EQUATION_MAX=3,e.ALPHA_EQUATION_MIN=4,e.ALPHA_EQUATION_DARKEN=5,e.DELAYLOADSTATE_NONE=0,e.DELAYLOADSTATE_LOADED=1,e.DELAYLOADSTATE_LOADING=2,e.DELAYLOADSTATE_NOTLOADED=4,e.NEVER=512,e.ALWAYS=519,e.LESS=513,e.EQUAL=514,e.LEQUAL=515,e.GREATER=516,e.GEQUAL=518,e.NOTEQUAL=517,e.KEEP=7680,e.REPLACE=7681,e.INCR=7682,e.DECR=7683,e.INVERT=5386,e.INCR_WRAP=34055,e.DECR_WRAP=34056,e.TEXTURE_CLAMP_ADDRESSMODE=0,e.TEXTURE_WRAP_ADDRESSMODE=1,e.TEXTURE_MIRROR_ADDRESSMODE=2,e.TEXTUREFORMAT_ALPHA=0,e.TEXTUREFORMAT_LUMINANCE=1,e.TEXTUREFORMAT_LUMINANCE_ALPHA=2,e.TEXTUREFORMAT_RGB=4,e.TEXTUREFORMAT_RGBA=5,e.TEXTUREFORMAT_RED=6,e.TEXTUREFORMAT_R=6,e.TEXTUREFORMAT_RG=7,e.TEXTUREFORMAT_RED_INTEGER=8,e.TEXTUREFORMAT_R_INTEGER=8,e.TEXTUREFORMAT_RG_INTEGER=9,e.TEXTUREFORMAT_RGB_INTEGER=10,e.TEXTUREFORMAT_RGBA_INTEGER=11,e.TEXTURETYPE_UNSIGNED_BYTE=0,e.TEXTURETYPE_UNSIGNED_INT=0,e.TEXTURETYPE_FLOAT=1,e.TEXTURETYPE_HALF_FLOAT=2,e.TEXTURETYPE_BYTE=3,e.TEXTURETYPE_SHORT=4,e.TEXTURETYPE_UNSIGNED_SHORT=5,e.TEXTURETYPE_INT=6,e.TEXTURETYPE_UNSIGNED_INTEGER=7,e.TEXTURETYPE_UNSIGNED_SHORT_4_4_4_4=8,e.TEXTURETYPE_UNSIGNED_SHORT_5_5_5_1=9,e.TEXTURETYPE_UNSIGNED_SHORT_5_6_5=10,e.TEXTURETYPE_UNSIGNED_INT_2_10_10_10_REV=11,e.TEXTURETYPE_UNSIGNED_INT_24_8=12,e.TEXTURETYPE_UNSIGNED_INT_10F_11F_11F_REV=13,e.TEXTURETYPE_UNSIGNED_INT_5_9_9_9_REV=14,e.TEXTURETYPE_FLOAT_32_UNSIGNED_INT_24_8_REV=15,e.TEXTURE_NEAREST_SAMPLINGMODE=1,e.TEXTURE_NEAREST_NEAREST=1,e.TEXTURE_BILINEAR_SAMPLINGMODE=2,e.TEXTURE_LINEAR_LINEAR=2,e.TEXTURE_TRILINEAR_SAMPLINGMODE=3,e.TEXTURE_LINEAR_LINEAR_MIPLINEAR=3,e.TEXTURE_NEAREST_NEAREST_MIPNEAREST=4,e.TEXTURE_NEAREST_LINEAR_MIPNEAREST=5,e.TEXTURE_NEAREST_LINEAR_MIPLINEAR=6,e.TEXTURE_NEAREST_LINEAR=7,e.TEXTURE_NEAREST_NEAREST_MIPLINEAR=8,e.TEXTURE_LINEAR_NEAREST_MIPNEAREST=9,e.TEXTURE_LINEAR_NEAREST_MIPLINEAR=10,e.TEXTURE_LINEAR_LINEAR_MIPNEAREST=11,e.TEXTURE_LINEAR_NEAREST=12,e.TEXTURE_EXPLICIT_MODE=0,e.TEXTURE_SPHERICAL_MODE=1,e.TEXTURE_PLANAR_MODE=2,e.TEXTURE_CUBIC_MODE=3,e.TEXTURE_PROJECTION_MODE=4,e.TEXTURE_SKYBOX_MODE=5,e.TEXTURE_INVCUBIC_MODE=6,e.TEXTURE_EQUIRECTANGULAR_MODE=7,e.TEXTURE_FIXED_EQUIRECTANGULAR_MODE=8,e.TEXTURE_FIXED_EQUIRECTANGULAR_MIRRORED_MODE=9,e.TEXTURE_FILTERING_QUALITY_OFFLINE=4096,e.TEXTURE_FILTERING_QUALITY_HIGH=64,e.TEXTURE_FILTERING_QUALITY_MEDIUM=16,e.TEXTURE_FILTERING_QUALITY_LOW=8,e.SCALEMODE_FLOOR=1,e.SCALEMODE_NEAREST=2,e.SCALEMODE_CEILING=3,e.MATERIAL_TextureDirtyFlag=1,e.MATERIAL_LightDirtyFlag=2,e.MATERIAL_FresnelDirtyFlag=4,e.MATERIAL_AttributesDirtyFlag=8,e.MATERIAL_MiscDirtyFlag=16,e.MATERIAL_PrePassDirtyFlag=32,e.MATERIAL_AllDirtyFlag=63,e.MATERIAL_TriangleFillMode=0,e.MATERIAL_WireFrameFillMode=1,e.MATERIAL_PointFillMode=2,e.MATERIAL_PointListDrawMode=3,e.MATERIAL_LineListDrawMode=4,e.MATERIAL_LineLoopDrawMode=5,e.MATERIAL_LineStripDrawMode=6,e.MATERIAL_TriangleStripDrawMode=7,e.MATERIAL_TriangleFanDrawMode=8,e.MATERIAL_ClockWiseSideOrientation=0,e.MATERIAL_CounterClockWiseSideOrientation=1,e.ACTION_NothingTrigger=0,e.ACTION_OnPickTrigger=1,e.ACTION_OnLeftPickTrigger=2,e.ACTION_OnRightPickTrigger=3,e.ACTION_OnCenterPickTrigger=4,e.ACTION_OnPickDownTrigger=5,e.ACTION_OnDoublePickTrigger=6,e.ACTION_OnPickUpTrigger=7,e.ACTION_OnPickOutTrigger=16,e.ACTION_OnLongPressTrigger=8,e.ACTION_OnPointerOverTrigger=9,e.ACTION_OnPointerOutTrigger=10,e.ACTION_OnEveryFrameTrigger=11,e.ACTION_OnIntersectionEnterTrigger=12,e.ACTION_OnIntersectionExitTrigger=13,e.ACTION_OnKeyDownTrigger=14,e.ACTION_OnKeyUpTrigger=15,e.PARTICLES_BILLBOARDMODE_Y=2,e.PARTICLES_BILLBOARDMODE_ALL=7,e.PARTICLES_BILLBOARDMODE_STRETCHED=8,e.MESHES_CULLINGSTRATEGY_STANDARD=0,e.MESHES_CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY=1,e.MESHES_CULLINGSTRATEGY_OPTIMISTIC_INCLUSION=2,e.MESHES_CULLINGSTRATEGY_OPTIMISTIC_INCLUSION_THEN_BSPHERE_ONLY=3,e.SCENELOADER_NO_LOGGING=0,e.SCENELOADER_MINIMAL_LOGGING=1,e.SCENELOADER_SUMMARY_LOGGING=2,e.SCENELOADER_DETAILED_LOGGING=3,e.PREPASS_IRRADIANCE_TEXTURE_TYPE=0,e.PREPASS_POSITION_TEXTURE_TYPE=1,e.PREPASS_VELOCITY_TEXTURE_TYPE=2,e.PREPASS_REFLECTIVITY_TEXTURE_TYPE=3,e.PREPASS_COLOR_TEXTURE_TYPE=4,e.PREPASS_DEPTHNORMAL_TEXTURE_TYPE=5,e.PREPASS_ALBEDO_TEXTURE_TYPE=6,e}(),P=i(57),C=function(e){function t(t,i,r,o,s,a,c){void 0===i&&(i=0),void 0===r&&(r=0),void 0===s&&(s=!1),void 0===a&&(a=u.a.NEAREST_SAMPLINGMODE);var f=e.call(this,t,{width:i,height:r},o,s,a,O.TEXTUREFORMAT_RGBA,c)||this;return f._isDirty=!1,f._rootContainer=new E.a("root"),f._lastControlOver={},f._lastControlDown={},f._capturingControl={},f._linkedControls=new Array,f._isFullscreen=!1,f._fullscreenViewport=new P.a(0,0,1,1),f._idealWidth=0,f._idealHeight=0,f._useSmallestIdeal=!1,f._renderAtIdealSize=!1,f._blockNextFocusCheck=!1,f._renderScale=1,f._cursorChanged=!1,f._defaultMousePointerId=0,f._numLayoutCalls=0,f._numRenderCalls=0,f._clipboardData="",f.onClipboardObservable=new n.a,f.onControlPickedObservable=new n.a,f.onBeginLayoutObservable=new n.a,f.onEndLayoutObservable=new n.a,f.onBeginRenderObservable=new n.a,f.onEndRenderObservable=new n.a,f.premulAlpha=!1,f.applyYInversionOnUpdate=!0,f._useInvalidateRectOptimization=!0,f._invalidatedRectangle=null,f._clearMeasure=new S.a(0,0,0,0),f.onClipboardCopy=function(e){var t=e,i=new h.b(h.a.COPY,t);f.onClipboardObservable.notifyObservers(i),t.preventDefault()},f.onClipboardCut=function(e){var t=e,i=new h.b(h.a.CUT,t);f.onClipboardObservable.notifyObservers(i),t.preventDefault()},f.onClipboardPaste=function(e){var t=e,i=new h.b(h.a.PASTE,t);f.onClipboardObservable.notifyObservers(i),t.preventDefault()},(o=f.getScene())&&f._texture?(f._rootElement=o.getEngine().getInputElement(),f._renderObserver=o.onBeforeCameraRenderObservable.add((function(e){return f._checkUpdate(e)})),f._preKeyboardObserver=o.onPreKeyboardObservable.add((function(e){f._focusedControl&&(e.type===l.a.KEYDOWN&&f._focusedControl.processKeyboard(e.event),e.skipOnPointerObservable=!0)})),f._rootContainer._link(f),f.hasAlpha=!0,i&&r||(f._resizeObserver=o.getEngine().onResizeObservable.add((function(){return f._onResize()})),f._onResize()),f._texture.isReady=!0,f):f}return Object(r.c)(t,e),Object.defineProperty(t.prototype,"numLayoutCalls",{get:function(){return this._numLayoutCalls},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"numRenderCalls",{get:function(){return this._numRenderCalls},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"renderScale",{get:function(){return this._renderScale},set:function(e){e!==this._renderScale&&(this._renderScale=e,this._onResize())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"background",{get:function(){return this._background},set:function(e){this._background!==e&&(this._background=e,this.markAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"idealWidth",{get:function(){return this._idealWidth},set:function(e){this._idealWidth!==e&&(this._idealWidth=e,this.markAsDirty(),this._rootContainer._markAllAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"idealHeight",{get:function(){return this._idealHeight},set:function(e){this._idealHeight!==e&&(this._idealHeight=e,this.markAsDirty(),this._rootContainer._markAllAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"useSmallestIdeal",{get:function(){return this._useSmallestIdeal},set:function(e){this._useSmallestIdeal!==e&&(this._useSmallestIdeal=e,this.markAsDirty(),this._rootContainer._markAllAsDirty())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"renderAtIdealSize",{get:function(){return this._renderAtIdealSize},set:function(e){this._renderAtIdealSize!==e&&(this._renderAtIdealSize=e,this._onResize())},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"idealRatio",{get:function(){var e=0,t=0;return this._idealWidth&&(e=this.getSize().width/this._idealWidth),this._idealHeight&&(t=this.getSize().height/this._idealHeight),this._useSmallestIdeal&&this._idealWidth&&this._idealHeight?window.innerWidth1)return e.notRenderable=!0,"continue";e.notRenderable=!1,h.scaleInPlace(n.renderScale),e._moveToProjectedPosition(h)},n=this,a=0,h=this._linkedControls;a0!=this._getWorldMatrixDeterminant()>0)return this._internalAbstractMeshDataInfo._actAsRegularMesh=!0,!0;if(this._internalAbstractMeshDataInfo._actAsRegularMesh=!1,this._currentLOD._registerInstanceForRenderId(this,e),t){if(!this._currentLOD._internalAbstractMeshDataInfo._isActiveIntermediate)return this._currentLOD._internalAbstractMeshDataInfo._onlyForInstancesIntermediate=!0,!0}else if(!this._currentLOD._internalAbstractMeshDataInfo._isActive)return this._currentLOD._internalAbstractMeshDataInfo._onlyForInstances=!0,!0}return!1},t.prototype._postActivate=function(){this._sourceMesh.edgesShareWithInstances&&this._sourceMesh._edgesRenderer&&this._sourceMesh._edgesRenderer.isEnabled&&this._sourceMesh._renderingGroup?(this._sourceMesh._renderingGroup._edgesRenderers.pushNoDuplicate(this._sourceMesh._edgesRenderer),this._sourceMesh._edgesRenderer.customInstances.push(this.getWorldMatrix())):this._edgesRenderer&&this._edgesRenderer.isEnabled&&this._sourceMesh._renderingGroup&&this._sourceMesh._renderingGroup._edgesRenderers.push(this._edgesRenderer)},t.prototype.getWorldMatrix=function(){if(this._currentLOD&&this._currentLOD.billboardMode!==f.a.BILLBOARDMODE_NONE&&this._currentLOD._masterMesh!==this){var t=this._currentLOD._masterMesh;return this._currentLOD._masterMesh=this,r.c.Vector3[7].copyFrom(this._currentLOD.position),this._currentLOD.position.set(0,0,0),r.c.Matrix[0].copyFrom(this._currentLOD.computeWorldMatrix(!0)),this._currentLOD.position.copyFrom(r.c.Vector3[7]),this._currentLOD._masterMesh=t,r.c.Matrix[0]}return e.prototype.getWorldMatrix.call(this)},Object.defineProperty(t.prototype,"isAnInstance",{get:function(){return!0},enumerable:!1,configurable:!0}),t.prototype.getLOD=function(e){if(!e)return this;var t=this.getBoundingInfo();return this._currentLOD=this.sourceMesh.getLOD(e,t.boundingSphere),this._currentLOD===this.sourceMesh?this.sourceMesh:this._currentLOD},t.prototype._preActivateForIntermediateRendering=function(e){return this.sourceMesh._preActivateForIntermediateRendering(e)},t.prototype._syncSubMeshes=function(){if(this.releaseSubMeshes(),this._sourceMesh.subMeshes)for(var e=0;e1&&(this._multiview=!0,s.push("#define MULTIVIEW"),-1!==this._options.uniforms.indexOf("viewProjection")&&-1===this._options.uniforms.push("viewProjectionR")&&this._options.uniforms.push("viewProjectionR"));for(var c=0;c4&&(a.push(h.b.MatricesIndicesExtraKind),a.push(h.b.MatricesWeightsExtraKind));var f=e.skeleton;u=e.numBoneInfluencers,s.push("#define NUM_BONE_INFLUENCERS "+u),l.addCPUSkinningFallback(0,e),f.isUsingTextureForMatrices?(s.push("#define BONETEXTURE"),-1===this._options.uniforms.indexOf("boneTextureWidth")&&this._options.uniforms.push("boneTextureWidth"),-1===this._options.samplers.indexOf("boneSampler")&&this._options.samplers.push("boneSampler")):(s.push("#define BonesPerMesh "+(f.bones.length+1)),-1===this._options.uniforms.indexOf("mBones")&&this._options.uniforms.push("mBones"))}else s.push("#define NUM_BONE_INFLUENCERS 0");for(var d in this._textures)if(!this._textures[d].isReady())return!1;e&&this._shouldTurnAlphaTestOn(e)&&s.push("#define ALPHATEST");var p=this._shaderPath,_=this._options.uniforms,g=this._options.uniformBuffers,m=this._options.samplers;this.customShaderNameResolve&&(_=_.slice(),g=g.slice(),m=m.slice(),p=this.customShaderNameResolve(p,_,g,m,s,a));var v=this._effect,y=s.join("\n");return this._cachedDefines!==y&&(this._cachedDefines=y,this._effect=o.createEffect(p,{attributes:a,uniformsNames:_,uniformBuffersNames:g,samplers:m,defines:y,fallbacks:l,onCompiled:this.onCompiled,onError:this.onError,indexParameters:{maxSimultaneousMorphTargets:u}},o),this._onEffectCreatedObservable&&(A.effect=this._effect,this._onEffectCreatedObservable.notifyObservers(A))),null!==(r=!(null===(i=this._effect)||void 0===i?void 0:i.isReady()))&&void 0!==r&&!r&&(v!==this._effect&&n.resetCachedMaterial(),this._renderId=n.getRenderId(),this._effect._wasPreviouslyReady=!0,!0)},t.prototype.bindOnlyWorldMatrix=function(e,t){var i=this.getScene(),r=null!=t?t:this._effect;r&&(-1!==this._options.uniforms.indexOf("world")&&r.setMatrix("world",e),-1!==this._options.uniforms.indexOf("worldView")&&(e.multiplyToRef(i.getViewMatrix(),this._cachedWorldViewMatrix),r.setMatrix("worldView",this._cachedWorldViewMatrix)),-1!==this._options.uniforms.indexOf("worldViewProjection")&&(e.multiplyToRef(i.getTransformMatrix(),this._cachedWorldViewProjectionMatrix),r.setMatrix("worldViewProjection",this._cachedWorldViewProjectionMatrix)))},t.prototype.bindForSubMesh=function(e,t,i){this.bind(e,t,i._effectOverride)},t.prototype.bind=function(e,t,i){this.bindOnlyWorldMatrix(e,i);var r=null!=i?i:this._effect;if(r&&this.getScene().getCachedMaterial()!==this){var n;for(n in-1!==this._options.uniforms.indexOf("view")&&r.setMatrix("view",this.getScene().getViewMatrix()),-1!==this._options.uniforms.indexOf("projection")&&r.setMatrix("projection",this.getScene().getProjectionMatrix()),-1!==this._options.uniforms.indexOf("viewProjection")&&(r.setMatrix("viewProjection",this.getScene().getTransformMatrix()),this._multiview&&r.setMatrix("viewProjectionR",this.getScene()._transformMatrixR)),this.getScene().activeCamera&&-1!==this._options.uniforms.indexOf("cameraPosition")&&r.setVector3("cameraPosition",this.getScene().activeCamera.globalPosition),b.a.BindBonesParameters(t,r),this._textures)r.setTexture(n,this._textures[n]);for(n in this._textureArrays)r.setTextureArray(n,this._textureArrays[n]);for(n in this._ints)r.setInt(n,this._ints[n]);for(n in this._floats)r.setFloat(n,this._floats[n]);for(n in this._floatsArrays)r.setArray(n,this._floatsArrays[n]);for(n in this._colors3)r.setColor3(n,this._colors3[n]);for(n in this._colors3Arrays)r.setArray3(n,this._colors3Arrays[n]);for(n in this._colors4){var o=this._colors4[n];r.setFloat4(n,o.r,o.g,o.b,o.a)}for(n in this._colors4Arrays)r.setArray4(n,this._colors4Arrays[n]);for(n in this._vectors2)r.setVector2(n,this._vectors2[n]);for(n in this._vectors3)r.setVector3(n,this._vectors3[n]);for(n in this._vectors4)r.setVector4(n,this._vectors4[n]);for(n in this._matrices)r.setMatrix(n,this._matrices[n]);for(n in this._matrixArrays)r.setMatrices(n,this._matrixArrays[n]);for(n in this._matrices3x3)r.setMatrix3x3(n,this._matrices3x3[n]);for(n in this._matrices2x2)r.setMatrix2x2(n,this._matrices2x2[n]);for(n in this._vectors2Arrays)r.setArray2(n,this._vectors2Arrays[n]);for(n in this._vectors3Arrays)r.setArray3(n,this._vectors3Arrays[n]);for(n in this._vectors4Arrays)r.setArray4(n,this._vectors4Arrays[n])}var s=this._effect;this._effect=r,this._afterBind(t),this._effect=s},t.prototype._afterBind=function(t){e.prototype._afterBind.call(this,t),this.getScene()._cachedEffect=this._effect},t.prototype.getActiveTextures=function(){var t=e.prototype.getActiveTextures.call(this);for(var i in this._textures)t.push(this._textures[i]);for(var i in this._textureArrays)for(var r=this._textureArrays[i],n=0;n\nvoid main(void) {\n#include\n#ifdef VERTEXCOLOR\ngl_FragColor=vColor;\n#else\ngl_FragColor=color;\n#endif\n}");S.a.ShadersStore.colorPixelShader=O;i(82),i(84),i(83),i(85),i(86),i(87);var P="\nattribute vec3 position;\n#ifdef VERTEXCOLOR\nattribute vec4 color;\n#endif\n#include\n#include\n\n#include\nuniform mat4 viewProjection;\n#ifdef MULTIVIEW\nuniform mat4 viewProjectionR;\n#endif\n\n#ifdef VERTEXCOLOR\nvarying vec4 vColor;\n#endif\nvoid main(void) {\n#include\n#include\nvec4 worldPos=finalWorld*vec4(position,1.0);\n#ifdef MULTIVIEW\nif (gl_ViewID_OVR == 0u) {\ngl_Position=viewProjection*worldPos;\n} else {\ngl_Position=viewProjectionR*worldPos;\n}\n#else\ngl_Position=viewProjection*worldPos;\n#endif\n#include\n#ifdef VERTEXCOLOR\n\nvColor=color;\n#endif\n}";S.a.ShadersStore.colorVertexShader=P;var C=function(e){function t(t,i,r,n,o,s,l){void 0===i&&(i=null),void 0===r&&(r=null),void 0===n&&(n=null);var c=e.call(this,t,i,r,n,o)||this;c.useVertexColor=s,c.useVertexAlpha=l,c.color=new a.a(1,1,1),c.alpha=1,n&&(c.color=n.color.clone(),c.alpha=n.alpha,c.useVertexColor=n.useVertexColor,c.useVertexAlpha=n.useVertexAlpha),c.intersectionThreshold=.1;var u={attributes:[h.b.PositionKind,"world0","world1","world2","world3"],uniforms:["vClipPlane","vClipPlane2","vClipPlane3","vClipPlane4","vClipPlane5","vClipPlane6","world","viewProjection"],needAlphaBlending:!0,defines:[]};return!1===l&&(u.needAlphaBlending=!1),s?(u.defines.push("#define VERTEXCOLOR"),u.attributes.push(h.b.ColorKind)):(u.uniforms.push("color"),c.color4=new a.b),c._colorShader=new M("colorShader",c.getScene(),"color",u),c}return Object(s.c)(t,e),t.prototype._addClipPlaneDefine=function(e){var t="#define "+e;-1===this._colorShader.options.defines.indexOf(t)&&this._colorShader.options.defines.push(t)},t.prototype._removeClipPlaneDefine=function(e){var t="#define "+e,i=this._colorShader.options.defines.indexOf(t);-1!==i&&this._colorShader.options.defines.splice(i,1)},t.prototype.isReady=function(){var t=this.getScene();return t.clipPlane?this._addClipPlaneDefine("CLIPPLANE"):this._removeClipPlaneDefine("CLIPPLANE"),t.clipPlane2?this._addClipPlaneDefine("CLIPPLANE2"):this._removeClipPlaneDefine("CLIPPLANE2"),t.clipPlane3?this._addClipPlaneDefine("CLIPPLANE3"):this._removeClipPlaneDefine("CLIPPLANE3"),t.clipPlane4?this._addClipPlaneDefine("CLIPPLANE4"):this._removeClipPlaneDefine("CLIPPLANE4"),t.clipPlane5?this._addClipPlaneDefine("CLIPPLANE5"):this._removeClipPlaneDefine("CLIPPLANE5"),t.clipPlane6?this._addClipPlaneDefine("CLIPPLANE6"):this._removeClipPlaneDefine("CLIPPLANE6"),!!this._colorShader.isReady(this)&&e.prototype.isReady.call(this)},t.prototype.getClassName=function(){return"LinesMesh"},Object.defineProperty(t.prototype,"material",{get:function(){return this._colorShader},set:function(e){},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"checkCollisions",{get:function(){return!1},enumerable:!1,configurable:!0}),t.prototype._bind=function(e,t,i){if(!this._geometry)return this;var r=this._colorShader.getEffect(),n=this.isUnIndexed?null:this._geometry.getIndexBuffer();if(this._geometry._bind(r,n),!this.useVertexColor){var o=this.color,s=o.r,a=o.g,h=o.b;this.color4.set(s,a,h,this.alpha),this._colorShader.setColor4("color",this.color4)}return b.a.BindClipPlane(r,this.getScene()),this},t.prototype._draw=function(e,t,i){if(!this._geometry||!this._geometry.getVertexBuffers()||!this._unIndexed&&!this._geometry.getIndexBuffer())return this;var r=this.getScene().getEngine();return this._unIndexed?r.drawArraysType(g.a.LineListDrawMode,e.verticesStart,e.verticesCount,i):r.drawElementsType(g.a.LineListDrawMode,e.indexStart,e.indexCount,i),this},t.prototype.dispose=function(t){this._colorShader.dispose(!1,!1,!0),e.prototype.dispose.call(this,t)},t.prototype.clone=function(e,i,r){return void 0===i&&(i=null),new t(e,this.getScene(),i,this,r)},t.prototype.createInstance=function(e){return new I(e,this)},t}(n.Mesh),I=function(e){function t(t,i){var r=e.call(this,t,i)||this;return r.intersectionThreshold=i.intersectionThreshold,r}return Object(s.c)(t,e),t.prototype.getClassName=function(){return"InstancedLinesMesh"},t}(_);o.VertexData.CreateLineSystem=function(e){for(var t=[],i=[],r=e.lines,n=e.colors,s=[],a=0,h=0;h0&&(t.push(a-1),t.push(a)),a++}var f=new o.VertexData;return f.indices=t,f.positions=i,n&&(f.colors=s),f},o.VertexData.CreateDashedLines=function(e){var t,i,n=e.dashSize||3,s=e.gapSize||1,a=e.dashNb||200,h=e.points,l=new Array,c=new Array,u=r.e.Zero(),f=0,d=0,p=0,_=0,g=0;for(g=0;g2096103.424&&d!==f))return navigator.msSaveBlob?navigator.msSaveBlob(b(l),p):y(l);h=(l=b(l)).type||a}else if(/([\x80-\xff])/.test(l)){for(var g=0,m=new Uint8Array(l.length),v=m.length;g1)for(var i=1;i=0)return;s[t]="set-cookie"===t?(s[t]?s[t]:[]).concat([i]):s[t]?s[t]+", "+i:i}})),s):s}},function(e,t,i){"use strict";var r=i(41);e.exports=r.isStandardBrowserEnv()?function(){var e,t=/(msie|trident)/i.test(navigator.userAgent),i=document.createElement("a");function n(e){var r=e;return t&&(i.setAttribute("href",r),r=i.href),i.setAttribute("href",r),{href:i.href,protocol:i.protocol?i.protocol.replace(/:$/,""):"",host:i.host,search:i.search?i.search.replace(/^\?/,""):"",hash:i.hash?i.hash.replace(/^#/,""):"",hostname:i.hostname,port:i.port,pathname:"/"===i.pathname.charAt(0)?i.pathname:"/"+i.pathname}}return e=n(window.location.href),function(t){var i=r.isString(t)?n(t):t;return i.protocol===e.protocol&&i.host===e.host}}():function(){return!0}},function(e,t,i){"use strict";var r=i(95);function n(e){if("function"!=typeof e)throw new TypeError("executor must be a function.");var t;this.promise=new Promise((function(e){t=e}));var i=this;e((function(e){i.reason||(i.reason=new r(e),t(i.reason))}))}n.prototype.throwIfRequested=function(){if(this.reason)throw this.reason},n.source=function(){var e;return{token:new n((function(t){e=t})),cancel:e}},e.exports=n},function(e,t,i){"use strict";e.exports=function(e){return function(t){return e.apply(null,t)}}},function(e,t,i){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.AnnotationManager=void 0;var r=i(56),n=i(78),o=i(133),s=i(98),a=i(97),h=i(99),l=i(96),c=function(e,t,i,n){this.size=1;var o=h.LinesBuilder.CreateLineSystem("ls",{lines:[[e,t]],updatable:!0},i);o.color=new r.Color3(0,0,0),void 0!==n&&(o.color=r.Color3.FromHexString(n)),this._lines=o,l.CylinderBuilder.CreateCylinder("tip",{diameterTop:0,diameterBottom:this.size,tessellation:36},i).position=t},u=function(){function e(e,t,i,r){this.size=100,this.color="black",this.fixed=!1;var o=n.PlaneBuilder.CreatePlane("label",{width:5,height:5},i);void 0!==r&&(this.color=r),o.position=t;var h=s.AdvancedDynamicTexture.CreateForMesh(o),l=new a.Rectangle;l.color="red",l.alpha=0,h.addControl(l),this._background=l;var c=new a.TextBlock;c.text=e,c.color=this.color,c.fontSize=this.size,h.addControl(c),this._text=c,this.fixed||d(o),this._label=o}return e.prototype.setText=function(e){this._text.text=e},e.prototype.update=function(e,t){var i=r.Vector3.Cross(e.position,r.Axis.Y),n=r.Vector3.Cross(i,e.position),o=r.Vector3.Cross(i,n);if(this._label.rotation=r.Vector3.RotationFromAxis(i,n,o),!this.fixed){var s=t.meshUnderPointer;this._label===s?this._background.alpha=1:this._background.alpha=0}},e.prototype.fix=function(){this._label.removeBehavior(this._label.getBehaviorByName("PointerDrag")),this.fixed=!0},e.prototype.unfix=function(){d(this._label),this.fixed=!1},e.prototype.dispose=function(){this._text.dispose(),this._background.dispose(),this._label.dispose()},e.prototype.export=function(){return[this._label.position.x,this._label.position.y,this._label.position.z,this._text.text]},e}(),f=function(){function e(e,t,i,r){this._editLabelForms=[],this._showLabels=!1,this._arrows=[],this._showArrows=!1,this.labels=[],this.fixedLabels=!1,this.fixedArrows=!1,this._canvas=e,this._scene=t,this._ymax=i,this._camera=r,this._createLabelForms()}return e.prototype._createLabelForms=function(){var e=document.createElement("div");e.className="bbp label-control",e.style.display="none",e.style.top=this._canvas.clientTop+40+"px",e.style.left=this._canvas.clientTop+5+"px";var t=document.createElement("div");t.className="label-form";var i=document.createElement("label");i.innerText="Label Text:",i.htmlFor="addLabelInput";var r=document.createElement("input");r.name="addLabelInput",r.type="text",this._addLabelTextInput=r;var n=document.createElement("button");n.innerText="Add Label",n.onclick=this._addLabelBtnClick.bind(this),t.appendChild(i),t.appendChild(r),t.appendChild(n),e.appendChild(t);var o=document.createElement("div");o.className="edit-container",o.style.maxHeight=(this._canvas.height-100).toString()+"px",e.appendChild(o),this._editLabelContainer=o,this._labelControlBox=e,this._canvas.parentNode.appendChild(e)},e.prototype.update=function(){if(this._showArrows,this._showLabels)for(var e=0;er){var i=parseInt(e.dataset.labelnum),n=(i-1).toString();e.dataset.labelnum=n,e.querySelector('input[data-labelnum="'+i+'"]').dataset.labelnum=n,e.querySelector('button[data-labelnum="'+i+'"]').dataset.labelnum=n}})),t.parentNode.removeChild(t)},e.prototype.exportLabels=function(){for(var e=[],t=0;t0&&(r="+"),+(Math.round(parseFloat(+i[0].toString()+"e"+r.toString()+(+i[1].toString()+t.toString())))+"e-"+t)}return+(Math.round(parseFloat(e.toString()+"e+"+t.toString()))+"e-"+t)},e.prototype._createAxes=function(e){void 0===e&&(e=!1),e&&(this.axisData.tickBreaks[0]=1,this.axisData.tickBreaks[2]=1);var t=this.axisData.tickBreaks[0]*this.axisData.scale[0],i=this.axisData.tickBreaks[1]*this.axisData.scale[1],r=this.axisData.tickBreaks[2]*this.axisData.scale[2],s=Math.floor(this.axisData.range[0][0]/t)*t,a=Math.floor(this.axisData.range[1][0]/i)*i,h=Math.floor(this.axisData.range[2][0]/r)*r,l=Math.ceil(this.axisData.range[0][1]/t)*t,c=Math.ceil(this.axisData.range[1][1]/i)*i,u=Math.ceil(this.axisData.range[2][1]/r)*r;if(this.axisData.showAxes[0]){var f=n.LinesBuilder.CreateLines("axisX",{points:[new o.Vector3(s,a,h),new o.Vector3(l,a,h)]},this._scene);f.color=o.Color3.FromHexString(this.axisData.color[0]),this._axes.push(f);var d=this._makeTextPlane(this.axisData.axisLabels[0],1,this.axisData.color[0]);d.position=new o.Vector3(l/2,a-.5*c,h),this._axisLabels.push(d);for(var p=[],_=0;_<-Math.ceil(this.axisData.range[0][0]/t);_++)p.push(-(_+1)*t);for(_=0;_<=Math.ceil(this.axisData.range[0][1]/t);_++)p.push(_*t);var g=0;e&&(g=1);for(_=g;_=this._thinInstanceDataStorage.instancesCount)return!1;var r=this._thinInstanceDataStorage.matrixData;return t.copyToArray(r,16*e),this._thinInstanceDataStorage.worldMatrices&&(this._thinInstanceDataStorage.worldMatrices[e]=t),i&&(this.thinInstanceBufferUpdated("matrix"),this.doNotSyncBoundingInfo||this.thinInstanceRefreshBoundingInfo(!1)),!0},r.Mesh.prototype.thinInstanceSetAttributeAt=function(e,t,i,r){return void 0===r&&(r=!0),!(!this._userThinInstanceBuffersStorage||!this._userThinInstanceBuffersStorage.data[e]||t>=this._thinInstanceDataStorage.instancesCount)&&(this._thinInstanceUpdateBufferSize(e,0),this._userThinInstanceBuffersStorage.data[e].set(i,t*this._userThinInstanceBuffersStorage.strides[e]),r&&this.thinInstanceBufferUpdated(e),!0)},Object.defineProperty(r.Mesh.prototype,"thinInstanceCount",{get:function(){return this._thinInstanceDataStorage.instancesCount},set:function(e){var t,i;e<=(null!==(i=null===(t=this._thinInstanceDataStorage.matrixData)||void 0===t?void 0:t.length)&&void 0!==i?i:0)/16&&(this._thinInstanceDataStorage.instancesCount=e)},enumerable:!0,configurable:!0}),r.Mesh.prototype.thinInstanceSetBuffer=function(e,t,i,r){var o,s;if(void 0===i&&(i=0),void 0===r&&(r=!1),i=i||16,"matrix"===e)if(null===(o=this._thinInstanceDataStorage.matrixBuffer)||void 0===o||o.dispose(),this._thinInstanceDataStorage.matrixBuffer=null,this._thinInstanceDataStorage.matrixBufferSize=t?t.length:32*i,this._thinInstanceDataStorage.matrixData=t,this._thinInstanceDataStorage.worldMatrices=null,null!==t){this._thinInstanceDataStorage.instancesCount=t.length/i;var a=new n.a(this.getEngine(),t,!r,i,!1,!0);this._thinInstanceDataStorage.matrixBuffer=a,this.setVerticesBuffer(a.createVertexBuffer("world0",0,4)),this.setVerticesBuffer(a.createVertexBuffer("world1",4,4)),this.setVerticesBuffer(a.createVertexBuffer("world2",8,4)),this.setVerticesBuffer(a.createVertexBuffer("world3",12,4)),this.doNotSyncBoundingInfo||this.thinInstanceRefreshBoundingInfo(!1)}else this._thinInstanceDataStorage.instancesCount=0,this.doNotSyncBoundingInfo||this.refreshBoundingInfo(!0);else null===t?(null===(s=this._userThinInstanceBuffersStorage)||void 0===s?void 0:s.data[e])&&(this.removeVerticesData(e),delete this._userThinInstanceBuffersStorage.data[e],delete this._userThinInstanceBuffersStorage.strides[e],delete this._userThinInstanceBuffersStorage.sizes[e],delete this._userThinInstanceBuffersStorage.vertexBuffers[e]):(this._thinInstanceInitializeUserStorage(),this._userThinInstanceBuffersStorage.data[e]=t,this._userThinInstanceBuffersStorage.strides[e]=i,this._userThinInstanceBuffersStorage.sizes[e]=t.length,this._userThinInstanceBuffersStorage.vertexBuffers[e]=new n.b(this.getEngine(),t,e,!r,!1,i,!0),this.setVerticesBuffer(this._userThinInstanceBuffersStorage.vertexBuffers[e]))},r.Mesh.prototype.thinInstanceBufferUpdated=function(e){var t;"matrix"===e?this._thinInstanceDataStorage.matrixBuffer&&this._thinInstanceDataStorage.matrixBuffer.updateDirectly(this._thinInstanceDataStorage.matrixData,0,this._thinInstanceDataStorage.instancesCount):(null===(t=this._userThinInstanceBuffersStorage)||void 0===t?void 0:t.vertexBuffers[e])&&this._userThinInstanceBuffersStorage.vertexBuffers[e].updateDirectly(this._userThinInstanceBuffersStorage.data[e],0)},r.Mesh.prototype.thinInstancePartialBufferUpdate=function(e,t,i){var r;"matrix"===e?this._thinInstanceDataStorage.matrixBuffer&&this._thinInstanceDataStorage.matrixBuffer.updateDirectly(t,i):(null===(r=this._userThinInstanceBuffersStorage)||void 0===r?void 0:r.vertexBuffers[e])&&this._userThinInstanceBuffersStorage.vertexBuffers[e].updateDirectly(t,i)},r.Mesh.prototype.thinInstanceGetWorldMatrices=function(){if(!this._thinInstanceDataStorage.matrixData||!this._thinInstanceDataStorage.matrixBuffer)return[];var e=this._thinInstanceDataStorage.matrixData;if(!this._thinInstanceDataStorage.worldMatrices){this._thinInstanceDataStorage.worldMatrices=new Array;for(var t=0;t1)?1:e.arc||1,h=e.slice&&e.slice<=0?1:e.slice||1,l=0===e.sideOrientation?0:e.sideOrientation||o.VertexData.DEFAULTSIDE,c=!!e.dedupTopBottomIndices,u=new r.e(i/2,n/2,s/2),f=2+t,d=2*f,p=[],_=[],g=[],m=[],v=0;v<=f;v++){for(var b=v/f,y=b*Math.PI*h,T=0;T<=d;T++){var x=T/d,E=x*Math.PI*2*a,A=r.a.RotationZ(-y),M=r.a.RotationY(E),S=r.e.TransformCoordinates(r.e.Up(),A),O=r.e.TransformCoordinates(S,M),P=O.multiply(u),C=O.divide(u).normalize();_.push(P.x,P.y,P.z),g.push(C.x,C.y,C.z),m.push(x,b)}if(v>0)for(var I=_.length/3,R=I-2*(d+1);R+d+21&&(p.push(R),p.push(R+1),p.push(R+d+1)),(v0){var l=n*this.yScale;(c=s.BoxBuilder.CreateBox("box_"+t+"-"+r,{height:l,width:this.xScale*this._size,depth:this.zScale*this._size},this._scene)).position=new o.Vector3(t*this.xScale+.5*this.xScale,l/2,r*this.zScale+.5*this.zScale),(u=new h.StandardMaterial("box_"+t+"-"+r+"_color",this._scene)).alpha=1,u.diffuseColor=o.Color3.FromHexString(this._coordColors[r+t*i.length].substring(0,7)),c.material=u,e.push(c)}else{var c,u;(c=a.PlaneBuilder.CreatePlane("box_"+t+"-"+r,{width:this.xScale*this._size,height:this.zScale*this._size},this._scene)).position=new o.Vector3(t*this.xScale+.5*this.xScale,0,r*this.zScale+.5*this.zScale),c.rotation.x=Math.PI/2,(u=new h.StandardMaterial("box_"+t+"-"+r+"_color",this._scene)).alpha=1,u.diffuseColor=o.Color3.FromHexString(this._coordColors[r+t*i.length].substring(0,7)),u.backFaceCulling=!1,c.material=u,e.push(c)}}this.meshes=e,Object.defineProperty(this,"alpha",{set:function(e){for(var t=0;t0},enumerable:!1,configurable:!0}),e.prototype.init=function(){},e.prototype.attach=function(e){var t=this;this._attachedCamera=e;var i=this._attachedCamera.getScene();this._onPrePointerObservableObserver=i.onPrePointerObservable.add((function(e){e.type!==c.a.POINTERDOWN?e.type===c.a.POINTERUP&&(t._isPointerDown=!1):t._isPointerDown=!0})),this._onAfterCheckInputsObserver=e.onAfterCheckInputsObservable.add((function(){var e=u.a.Now,i=0;null!=t._lastFrameTime&&(i=e-t._lastFrameTime),t._lastFrameTime=e,t._applyUserInteraction();var r=e-t._lastInteractionTime-t._idleRotationWaitTime,n=Math.max(Math.min(r/t._idleRotationSpinupTime,1),0);t._cameraRotationSpeed=t._idleRotationSpeed*n,t._attachedCamera&&(t._attachedCamera.alpha-=t._cameraRotationSpeed*(i/1e3))}))},e.prototype.detach=function(){if(this._attachedCamera){var e=this._attachedCamera.getScene();this._onPrePointerObservableObserver&&e.onPrePointerObservable.remove(this._onPrePointerObservableObserver),this._attachedCamera.onAfterCheckInputsObservable.remove(this._onAfterCheckInputsObserver),this._attachedCamera=null}},e.prototype._userIsZooming=function(){return!!this._attachedCamera&&0!==this._attachedCamera.inertialRadiusOffset},e.prototype._shouldAnimationStopForInteraction=function(){if(!this._attachedCamera)return!1;var e=!1;return this._lastFrameRadius===this._attachedCamera.radius&&0!==this._attachedCamera.inertialRadiusOffset&&(e=!0),this._lastFrameRadius=this._attachedCamera.radius,this._zoomStopsAnimation?e:this._userIsZooming()},e.prototype._applyUserInteraction=function(){this._userIsMoving()&&!this._shouldAnimationStopForInteraction()&&(this._lastInteractionTime=u.a.Now)},e.prototype._userIsMoving=function(){return!!this._attachedCamera&&(0!==this._attachedCamera.inertialAlphaOffset||0!==this._attachedCamera.inertialBetaOffset||0!==this._attachedCamera.inertialRadiusOffset||0!==this._attachedCamera.inertialPanningX||0!==this._attachedCamera.inertialPanningY||this._isPointerDown)},e}(),d=i(69),p=function(){function e(){this._easingMode=e.EASINGMODE_EASEIN}return e.prototype.setEasingMode=function(e){var t=Math.min(Math.max(e,0),2);this._easingMode=t},e.prototype.getEasingMode=function(){return this._easingMode},e.prototype.easeInCore=function(e){throw new Error("You must implement this method")},e.prototype.ease=function(t){switch(this._easingMode){case e.EASINGMODE_EASEIN:return this.easeInCore(t);case e.EASINGMODE_EASEOUT:return 1-this.easeInCore(1-t)}return t>=.5?.5*(1-this.easeInCore(2*(1-t)))+.5:.5*this.easeInCore(2*t)},e.EASINGMODE_EASEIN=0,e.EASINGMODE_EASEOUT=1,e.EASINGMODE_EASEINOUT=2,e}(),_=(function(e){function t(){return null!==e&&e.apply(this,arguments)||this}Object(n.c)(t,e),t.prototype.easeInCore=function(e){return e=Math.max(0,Math.min(1,e)),1-Math.sqrt(1-e*e)}}(p),function(e){function t(t){void 0===t&&(t=1);var i=e.call(this)||this;return i.amplitude=t,i}return Object(n.c)(t,e),t.prototype.easeInCore=function(e){var t=Math.max(0,this.amplitude);return Math.pow(e,3)-e*t*Math.sin(3.141592653589793*e)},t}(p)),g=(function(e){function t(t,i){void 0===t&&(t=3),void 0===i&&(i=2);var r=e.call(this)||this;return r.bounces=t,r.bounciness=i,r}Object(n.c)(t,e),t.prototype.easeInCore=function(e){var t=Math.max(0,this.bounces),i=this.bounciness;i<=1&&(i=1.001);var r=Math.pow(i,t),n=1-i,o=(1-r)/n+.5*r,s=e*o,a=Math.log(-s*(1-i)+1)/Math.log(i),h=Math.floor(a),l=h+1,c=(1-Math.pow(i,h))/(n*o),u=.5*(c+(1-Math.pow(i,l))/(n*o)),f=e-u,d=u-c;return-Math.pow(1/i,t-h)/(d*d)*(f-d)*(f+d)}}(p),function(e){function t(){return null!==e&&e.apply(this,arguments)||this}Object(n.c)(t,e),t.prototype.easeInCore=function(e){return e*e*e}}(p),function(e){function t(t,i){void 0===t&&(t=3),void 0===i&&(i=3);var r=e.call(this)||this;return r.oscillations=t,r.springiness=i,r}Object(n.c)(t,e),t.prototype.easeInCore=function(e){var t=Math.max(0,this.oscillations),i=Math.max(0,this.springiness);return(0==i?e:(Math.exp(i*e)-1)/(Math.exp(i)-1))*Math.sin((6.283185307179586*t+1.5707963267948966)*e)}}(p),function(e){function t(t){void 0===t&&(t=2);var i=e.call(this)||this;return i.exponent=t,i}return Object(n.c)(t,e),t.prototype.easeInCore=function(e){return this.exponent<=0?e:(Math.exp(this.exponent*e)-1)/(Math.exp(this.exponent)-1)},t}(p)),m=(function(e){function t(t){void 0===t&&(t=2);var i=e.call(this)||this;return i.power=t,i}Object(n.c)(t,e),t.prototype.easeInCore=function(e){var t=Math.max(0,this.power);return Math.pow(e,t)}}(p),function(e){function t(){return null!==e&&e.apply(this,arguments)||this}Object(n.c)(t,e),t.prototype.easeInCore=function(e){return e*e}}(p),function(e){function t(){return null!==e&&e.apply(this,arguments)||this}Object(n.c)(t,e),t.prototype.easeInCore=function(e){return e*e*e*e}}(p),function(e){function t(){return null!==e&&e.apply(this,arguments)||this}Object(n.c)(t,e),t.prototype.easeInCore=function(e){return e*e*e*e*e}}(p),function(e){function t(){return null!==e&&e.apply(this,arguments)||this}Object(n.c)(t,e),t.prototype.easeInCore=function(e){return 1-Math.sin(1.5707963267948966*(1-e))}}(p),function(e){function t(t,i,r,n){void 0===t&&(t=0),void 0===i&&(i=0),void 0===r&&(r=1),void 0===n&&(n=1);var o=e.call(this)||this;return o.x1=t,o.y1=i,o.x2=r,o.y2=n,o}Object(n.c)(t,e),t.prototype.easeInCore=function(e){return d.c.Interpolate(e,this.x1,this.y1,this.x2,this.y2)}}(p),i(7)),v=i(17),b=i(9);!function(e){e[e.STEP=1]="STEP"}(r||(r={}));var y=function(){function e(e,t,i){this.name=e,this.from=t,this.to=i}return e.prototype.clone=function(){return new e(this.name,this.from,this.to)},e}(),T=i(53),x=i(42),E=function(){function e(t,i,r,n,o,s){this.name=t,this.targetProperty=i,this.framePerSecond=r,this.dataType=n,this.loopMode=o,this.enableBlending=s,this._runtimeAnimations=new Array,this._events=new Array,this.blendingSpeed=.01,this._ranges={},this.targetPropertyPath=i.split("."),this.dataType=n,this.loopMode=void 0===o?e.ANIMATIONLOOPMODE_CYCLE:o}return e._PrepareAnimation=function(t,i,r,n,o,s,h,l){var c=void 0;if(!isNaN(parseFloat(o))&&isFinite(o)?c=e.ANIMATIONTYPE_FLOAT:o instanceof a.b?c=e.ANIMATIONTYPE_QUATERNION:o instanceof a.e?c=e.ANIMATIONTYPE_VECTOR3:o instanceof a.d?c=e.ANIMATIONTYPE_VECTOR2:o instanceof m.a?c=e.ANIMATIONTYPE_COLOR3:o instanceof m.b?c=e.ANIMATIONTYPE_COLOR4:o instanceof T.a&&(c=e.ANIMATIONTYPE_SIZE),null==c)return null;var u=new e(t,i,r,c,h),f=[{frame:0,value:o},{frame:n,value:s}];return u.setKeys(f),void 0!==l&&u.setEasingFunction(l),u},e.CreateAnimation=function(t,i,r,n){var o=new e(t+"Animation",t,r,i,e.ANIMATIONLOOPMODE_CONSTANT);return o.setEasingFunction(n),o},e.CreateAndStartAnimation=function(t,i,r,n,o,s,a,h,l,c){var u=e._PrepareAnimation(t,r,n,o,s,a,h,l);return u?i.getScene().beginDirectAnimation(i,[u],0,o,1===u.loopMode,1,c):null},e.CreateAndStartHierarchyAnimation=function(t,i,r,n,o,s,a,h,l,c,u){var f=e._PrepareAnimation(t,n,o,s,a,h,l,c);return f?i.getScene().beginDirectHierarchyAnimation(i,r,[f],0,s,1===f.loopMode,1,u):null},e.CreateMergeAndStartAnimation=function(t,i,r,n,o,s,a,h,l,c){var u=e._PrepareAnimation(t,r,n,o,s,a,h,l);return u?(i.animations.push(u),i.getScene().beginAnimation(i,0,o,1===u.loopMode,1,c)):null},e.MakeAnimationAdditive=function(t,i,r,n,o){void 0===i&&(i=0),void 0===n&&(n=!1);var s=t;if(n&&((s=t.clone()).name=o||s.name),!s._keys.length)return s;i=i>=0?i:0;var h=0,l=s._keys[0],c=s._keys.length-1,u=s._keys[c],f={referenceValue:l.value,referencePosition:a.c.Vector3[0],referenceQuaternion:a.c.Quaternion[0],referenceScaling:a.c.Vector3[1],keyPosition:a.c.Vector3[2],keyQuaternion:a.c.Quaternion[1],keyScaling:a.c.Vector3[3]},d=!1,p=l.frame,_=u.frame;if(r){var g=s.getRange(r);g&&(p=g.from,_=g.to)}var m=l.frame===p,v=u.frame===_;if(1===s._keys.length){var b=s._getKeyValue(s._keys[0]);f.referenceValue=b.clone?b.clone():b,d=!0}else if(i<=l.frame){b=s._getKeyValue(l.value);f.referenceValue=b.clone?b.clone():b,d=!0}else if(i>=u.frame){b=s._getKeyValue(u.value);f.referenceValue=b.clone?b.clone():b,d=!0}for(var y=0;!d||!m||!v&&y=T.frame&&i<=x.frame){b=void 0;if(i===T.frame)b=s._getKeyValue(T.value);else if(i===x.frame)b=s._getKeyValue(x.value);else{var E={key:y,repeatCount:0,loopMode:this.ANIMATIONLOOPMODE_CONSTANT};b=s._interpolate(i,E)}f.referenceValue=b.clone?b.clone():b,d=!0}if(!m&&p>=T.frame&&p<=x.frame){if(p===T.frame)h=y;else if(p===x.frame)h=y+1;else{E={key:y,repeatCount:0,loopMode:this.ANIMATIONLOOPMODE_CONSTANT};var A={frame:p,value:(b=s._interpolate(p,E)).clone?b.clone():b};s._keys.splice(y+1,0,A),h=y+1}m=!0}if(!v&&_>=T.frame&&_<=x.frame){if(_===T.frame)c=y;else if(_===x.frame)c=y+1;else{E={key:y,repeatCount:0,loopMode:this.ANIMATIONLOOPMODE_CONSTANT},A={frame:_,value:(b=s._interpolate(_,E)).clone?b.clone():b};s._keys.splice(y+1,0,A),c=y+1}v=!0}y++}s.dataType===e.ANIMATIONTYPE_QUATERNION?f.referenceValue.normalize().conjugateInPlace():s.dataType===e.ANIMATIONTYPE_MATRIX&&(f.referenceValue.decompose(f.referenceScaling,f.referenceQuaternion,f.referencePosition),f.referenceQuaternion.normalize().conjugateInPlace());for(y=h;y<=c;y++){A=s._keys[y];if(!y||s.dataType===e.ANIMATIONTYPE_FLOAT||A.value!==l.value)switch(s.dataType){case e.ANIMATIONTYPE_MATRIX:A.value.decompose(f.keyScaling,f.keyQuaternion,f.keyPosition),f.keyPosition.subtractInPlace(f.referencePosition),f.keyScaling.divideInPlace(f.referenceScaling),f.referenceQuaternion.multiplyToRef(f.keyQuaternion,f.keyQuaternion),a.a.ComposeToRef(f.keyScaling,f.keyQuaternion,f.keyPosition,A.value);break;case e.ANIMATIONTYPE_QUATERNION:f.referenceValue.multiplyToRef(A.value,A.value);break;case e.ANIMATIONTYPE_VECTOR2:case e.ANIMATIONTYPE_VECTOR3:case e.ANIMATIONTYPE_COLOR3:case e.ANIMATIONTYPE_COLOR4:A.value.subtractToRef(f.referenceValue,A.value);break;case e.ANIMATIONTYPE_SIZE:A.value.width-=f.referenceValue.width,A.value.height-=f.referenceValue.height;break;default:A.value-=f.referenceValue}}return s},e.TransitionTo=function(e,t,i,r,n,o,s,a){if(void 0===a&&(a=null),s<=0)return i[e]=t,a&&a(),null;var h=n*(s/1e3);o.setKeys([{frame:0,value:i[e].clone?i[e].clone():i[e]},{frame:h,value:t}]),i.animations||(i.animations=[]),i.animations.push(o);var l=r.beginAnimation(i,0,h,!1);return l.onAnimationEnd=a,l},Object.defineProperty(e.prototype,"runtimeAnimations",{get:function(){return this._runtimeAnimations},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"hasRunningRuntimeAnimations",{get:function(){for(var e=0,t=this._runtimeAnimations;e=0;o--)this._keys[o].frame>=r&&this._keys[o].frame<=n&&this._keys.splice(o,1);this._ranges[e]=null}},e.prototype.getRange=function(e){return this._ranges[e]},e.prototype.getKeys=function(){return this._keys},e.prototype.getHighestFrame=function(){for(var e=0,t=0,i=this._keys.length;t0)return i.highLimitValue.clone?i.highLimitValue.clone():i.highLimitValue;var n=this._keys;if(1===n.length)return this._getKeyValue(n[0].value);var o=i.key;if(n[o].frame>=t)for(;o-1>=0&&n[o].frame>=t;)o--;for(var s=o;s=t){i.key=s;var h=n[s],l=this._getKeyValue(h.value);if(h.interpolation===r.STEP)return l;var c=this._getKeyValue(a.value),u=void 0!==h.outTangent&&void 0!==a.inTangent,f=a.frame-h.frame,d=(t-h.frame)/f,p=this.getEasingFunction();switch(null!=p&&(d=p.ease(d)),this.dataType){case e.ANIMATIONTYPE_FLOAT:var _=u?this.floatInterpolateFunctionWithTangents(l,h.outTangent*f,c,a.inTangent*f,d):this.floatInterpolateFunction(l,c,d);switch(i.loopMode){case e.ANIMATIONLOOPMODE_CYCLE:case e.ANIMATIONLOOPMODE_CONSTANT:return _;case e.ANIMATIONLOOPMODE_RELATIVE:return i.offsetValue*i.repeatCount+_}break;case e.ANIMATIONTYPE_QUATERNION:var g=u?this.quaternionInterpolateFunctionWithTangents(l,h.outTangent.scale(f),c,a.inTangent.scale(f),d):this.quaternionInterpolateFunction(l,c,d);switch(i.loopMode){case e.ANIMATIONLOOPMODE_CYCLE:case e.ANIMATIONLOOPMODE_CONSTANT:return g;case e.ANIMATIONLOOPMODE_RELATIVE:return g.addInPlace(i.offsetValue.scale(i.repeatCount))}return g;case e.ANIMATIONTYPE_VECTOR3:var m=u?this.vector3InterpolateFunctionWithTangents(l,h.outTangent.scale(f),c,a.inTangent.scale(f),d):this.vector3InterpolateFunction(l,c,d);switch(i.loopMode){case e.ANIMATIONLOOPMODE_CYCLE:case e.ANIMATIONLOOPMODE_CONSTANT:return m;case e.ANIMATIONLOOPMODE_RELATIVE:return m.add(i.offsetValue.scale(i.repeatCount))}case e.ANIMATIONTYPE_VECTOR2:var v=u?this.vector2InterpolateFunctionWithTangents(l,h.outTangent.scale(f),c,a.inTangent.scale(f),d):this.vector2InterpolateFunction(l,c,d);switch(i.loopMode){case e.ANIMATIONLOOPMODE_CYCLE:case e.ANIMATIONLOOPMODE_CONSTANT:return v;case e.ANIMATIONLOOPMODE_RELATIVE:return v.add(i.offsetValue.scale(i.repeatCount))}case e.ANIMATIONTYPE_SIZE:switch(i.loopMode){case e.ANIMATIONLOOPMODE_CYCLE:case e.ANIMATIONLOOPMODE_CONSTANT:return this.sizeInterpolateFunction(l,c,d);case e.ANIMATIONLOOPMODE_RELATIVE:return this.sizeInterpolateFunction(l,c,d).add(i.offsetValue.scale(i.repeatCount))}case e.ANIMATIONTYPE_COLOR3:switch(i.loopMode){case e.ANIMATIONLOOPMODE_CYCLE:case e.ANIMATIONLOOPMODE_CONSTANT:return this.color3InterpolateFunction(l,c,d);case e.ANIMATIONLOOPMODE_RELATIVE:return this.color3InterpolateFunction(l,c,d).add(i.offsetValue.scale(i.repeatCount))}case e.ANIMATIONTYPE_COLOR4:switch(i.loopMode){case e.ANIMATIONLOOPMODE_CYCLE:case e.ANIMATIONLOOPMODE_CONSTANT:return this.color4InterpolateFunction(l,c,d);case e.ANIMATIONLOOPMODE_RELATIVE:return this.color4InterpolateFunction(l,c,d).add(i.offsetValue.scale(i.repeatCount))}case e.ANIMATIONTYPE_MATRIX:switch(i.loopMode){case e.ANIMATIONLOOPMODE_CYCLE:case e.ANIMATIONLOOPMODE_CONSTANT:if(e.AllowMatricesInterpolation)return this.matrixInterpolateFunction(l,c,d,i.workValue);case e.ANIMATIONLOOPMODE_RELATIVE:return l}}break}}return this._getKeyValue(n[n.length-1].value)},e.prototype.matrixInterpolateFunction=function(t,i,r,n){return e.AllowMatrixDecomposeForInterpolation?n?(a.a.DecomposeLerpToRef(t,i,r,n),n):a.a.DecomposeLerp(t,i,r):n?(a.a.LerpToRef(t,i,r,n),n):a.a.Lerp(t,i,r)},e.prototype.clone=function(){var t=new e(this.name,this.targetPropertyPath.join("."),this.framePerSecond,this.dataType,this.loopMode);if(t.enableBlending=this.enableBlending,t.blendingSpeed=this.blendingSpeed,this._keys&&t.setKeys(this._keys),this._ranges)for(var i in t._ranges={},this._ranges){var r=this._ranges[i];r&&(t._ranges[i]=r.clone())}return t},e.prototype.setKeys=function(e){this._keys=e.slice(0)},e.prototype.serialize=function(){var t={};t.name=this.name,t.property=this.targetProperty,t.framePerSecond=this.framePerSecond,t.dataType=this.dataType,t.loopBehavior=this.loopMode,t.enableBlending=this.enableBlending,t.blendingSpeed=this.blendingSpeed;var i=this.dataType;t.keys=[];for(var r=this.getKeys(),n=0;n=1&&(h=c.values[1]),c.values.length>=2&&(l=c.values[2]);break;case e.ANIMATIONTYPE_QUATERNION:if(i=a.b.FromArray(c.values),c.values.length>=8){var u=a.b.FromArray(c.values.slice(4,8));u.equals(a.b.Zero())||(h=u)}if(c.values.length>=12){var f=a.b.FromArray(c.values.slice(8,12));f.equals(a.b.Zero())||(l=f)}break;case e.ANIMATIONTYPE_MATRIX:i=a.a.FromArray(c.values);break;case e.ANIMATIONTYPE_COLOR3:i=m.a.FromArray(c.values);break;case e.ANIMATIONTYPE_COLOR4:i=m.b.FromArray(c.values);break;case e.ANIMATIONTYPE_VECTOR3:default:i=a.e.FromArray(c.values)}var d={};d.frame=c.frame,d.value=i,null!=h&&(d.inTangent=h),null!=l&&(d.outTangent=l),s.push(d)}if(n.setKeys(s),t.ranges)for(r=0;rl.upperRadiusLimit?l.upperRadiusLimit:h),h):0},e.prototype._maintainCameraAboveGround=function(){var t=this;if(!(this._elevationReturnTime<0)){var i=u.a.Now-this._lastInteractionTime,r=.5*Math.PI-this._defaultElevation,n=.5*Math.PI;if(this._attachedCamera&&!this._betaIsAnimating&&this._attachedCamera.beta>n&&i>=this._elevationReturnWaitTime){this._betaIsAnimating=!0,this.stopAllAnimations(),this._betaTransition||(this._betaTransition=E.CreateAnimation("beta",E.ANIMATIONTYPE_FLOAT,60,e.EasingFunction));var o=E.TransitionTo("beta",r,this._attachedCamera,this._attachedCamera.getScene(),60,this._betaTransition,this._elevationReturnTime,(function(){t._clearAnimationLocks(),t.stopAllAnimations()}));o&&this._animatables.push(o)}}},e.prototype._getFrustumSlope=function(){var e=this._attachedCamera;if(!e)return a.d.Zero();var t=e.getScene().getEngine().getAspectRatio(e),i=Math.tan(e.fov/2),r=i*t;return new a.d(r,i)},e.prototype._clearAnimationLocks=function(){this._betaIsAnimating=!1},e.prototype._applyUserInteraction=function(){this.isUserIsMoving&&(this._lastInteractionTime=u.a.Now,this.stopAllAnimations(),this._clearAnimationLocks())},e.prototype.stopAllAnimations=function(){for(this._attachedCamera&&(this._attachedCamera.animations=[]);this._animatables.length;)this._animatables[0]&&(this._animatables[0].onAnimationEnd=null,this._animatables[0].stop()),this._animatables.shift()},Object.defineProperty(e.prototype,"isUserIsMoving",{get:function(){return!!this._attachedCamera&&(0!==this._attachedCamera.inertialAlphaOffset||0!==this._attachedCamera.inertialBetaOffset||0!==this._attachedCamera.inertialRadiusOffset||0!==this._attachedCamera.inertialPanningX||0!==this._attachedCamera.inertialPanningY||this._isPointerDown)},enumerable:!1,configurable:!0}),e.EasingFunction=new g,e.EasingMode=p.EASINGMODE_EASEINOUT,e.IgnoreBoundsSizeMode=0,e.FitFrustumSidesMode=1,e}(),S=i(21),O=i(16),P=i(35),C=function(e){function t(t,i,r,n){void 0===n&&(n=!0);var o=e.call(this,t,i,r,n)||this;return o._tmpUpVector=a.e.Zero(),o._tmpTargetVector=a.e.Zero(),o.cameraDirection=new a.e(0,0,0),o.cameraRotation=new a.d(0,0),o.ignoreParentScaling=!1,o.updateUpVectorFromRotation=!1,o._tmpQuaternion=new a.b,o.rotation=new a.e(0,0,0),o.speed=2,o.noRotationConstraint=!1,o.invertRotation=!1,o.inverseRotationSpeed=.2,o.lockedTarget=null,o._currentTarget=a.e.Zero(),o._initialFocalDistance=1,o._viewMatrix=a.a.Zero(),o._camMatrix=a.a.Zero(),o._cameraTransformMatrix=a.a.Zero(),o._cameraRotationMatrix=a.a.Zero(),o._referencePoint=new a.e(0,0,1),o._transformedReferencePoint=a.e.Zero(),o._defaultUp=a.e.Up(),o._cachedRotationZ=0,o._cachedQuaternionRotationZ=0,o}return Object(n.c)(t,e),t.prototype.getFrontPosition=function(e){this.getWorldMatrix();var t=this.getTarget().subtract(this.position);return t.normalize(),t.scaleInPlace(e),this.globalPosition.add(t)},t.prototype._getLockedTargetPosition=function(){return this.lockedTarget?(this.lockedTarget.absolutePosition&&this.lockedTarget.computeWorldMatrix(),this.lockedTarget.absolutePosition||this.lockedTarget):null},t.prototype.storeState=function(){return this._storedPosition=this.position.clone(),this._storedRotation=this.rotation.clone(),this.rotationQuaternion&&(this._storedRotationQuaternion=this.rotationQuaternion.clone()),e.prototype.storeState.call(this)},t.prototype._restoreStateValues=function(){return!!e.prototype._restoreStateValues.call(this)&&(this.position=this._storedPosition.clone(),this.rotation=this._storedRotation.clone(),this.rotationQuaternion&&(this.rotationQuaternion=this._storedRotationQuaternion.clone()),this.cameraDirection.copyFromFloats(0,0,0),this.cameraRotation.copyFromFloats(0,0),!0)},t.prototype._initCache=function(){e.prototype._initCache.call(this),this._cache.lockedTarget=new a.e(Number.MAX_VALUE,Number.MAX_VALUE,Number.MAX_VALUE),this._cache.rotation=new a.e(Number.MAX_VALUE,Number.MAX_VALUE,Number.MAX_VALUE),this._cache.rotationQuaternion=new a.b(Number.MAX_VALUE,Number.MAX_VALUE,Number.MAX_VALUE,Number.MAX_VALUE)},t.prototype._updateCache=function(t){t||e.prototype._updateCache.call(this);var i=this._getLockedTargetPosition();i?this._cache.lockedTarget?this._cache.lockedTarget.copyFrom(i):this._cache.lockedTarget=i.clone():this._cache.lockedTarget=null,this._cache.rotation.copyFrom(this.rotation),this.rotationQuaternion&&this._cache.rotationQuaternion.copyFrom(this.rotationQuaternion)},t.prototype._isSynchronizedViewMatrix=function(){if(!e.prototype._isSynchronizedViewMatrix.call(this))return!1;var t=this._getLockedTargetPosition();return(this._cache.lockedTarget?this._cache.lockedTarget.equals(t):!t)&&(this.rotationQuaternion?this.rotationQuaternion.equals(this._cache.rotationQuaternion):this._cache.rotation.equals(this.rotation))},t.prototype._computeLocalCameraSpeed=function(){var e=this.getEngine();return this.speed*Math.sqrt(e.getDeltaTime()/(100*e.getFps()))},t.prototype.setTarget=function(e){this.upVector.normalize(),this._initialFocalDistance=e.subtract(this.position).length(),this.position.z===e.z&&(this.position.z+=O.a),this._referencePoint.normalize().scaleInPlace(this._initialFocalDistance),a.a.LookAtLHToRef(this.position,e,this._defaultUp,this._camMatrix),this._camMatrix.invert(),this.rotation.x=Math.atan(this._camMatrix.m[6]/this._camMatrix.m[10]);var t=e.subtract(this.position);t.x>=0?this.rotation.y=-Math.atan(t.z/t.x)+Math.PI/2:this.rotation.y=-Math.atan(t.z/t.x)-Math.PI/2,this.rotation.z=0,isNaN(this.rotation.x)&&(this.rotation.x=0),isNaN(this.rotation.y)&&(this.rotation.y=0),isNaN(this.rotation.z)&&(this.rotation.z=0),this.rotationQuaternion&&a.b.RotationYawPitchRollToRef(this.rotation.y,this.rotation.x,this.rotation.z,this.rotationQuaternion)},Object.defineProperty(t.prototype,"target",{get:function(){return this.getTarget()},set:function(e){this.setTarget(e)},enumerable:!1,configurable:!0}),t.prototype.getTarget=function(){return this._currentTarget},t.prototype._decideIfNeedsToMove=function(){return Math.abs(this.cameraDirection.x)>0||Math.abs(this.cameraDirection.y)>0||Math.abs(this.cameraDirection.z)>0},t.prototype._updatePosition=function(){if(this.parent)return this.parent.getWorldMatrix().invertToRef(a.c.Matrix[0]),a.e.TransformNormalToRef(this.cameraDirection,a.c.Matrix[0],a.c.Vector3[0]),void this.position.addInPlace(a.c.Vector3[0]);this.position.addInPlace(this.cameraDirection)},t.prototype._checkInputs=function(){var t=this.invertRotation?-this.inverseRotationSpeed:1,i=this._decideIfNeedsToMove(),r=Math.abs(this.cameraRotation.x)>0||Math.abs(this.cameraRotation.y)>0;if(i&&this._updatePosition(),r){if(this.rotationQuaternion&&this.rotationQuaternion.toEulerAnglesToRef(this.rotation),this.rotation.x+=this.cameraRotation.x*t,this.rotation.y+=this.cameraRotation.y*t,!this.noRotationConstraint){var n=1.570796;this.rotation.x>n&&(this.rotation.x=n),this.rotation.x<-n&&(this.rotation.x=-n)}if(this.rotationQuaternion)this.rotation.lengthSquared()&&a.b.RotationYawPitchRollToRef(this.rotation.y,this.rotation.x,this.rotation.z,this.rotationQuaternion)}i&&(Math.abs(this.cameraDirection.x)this.camera.pinchToPanMaxDistance)this.pinchDeltaPercentage?this.camera.inertialRadiusOffset+=.001*(r-i)*this.camera.radius*this.pinchDeltaPercentage:this.camera.inertialRadiusOffset+=(r-i)/(this.pinchPrecision*s*(this.angularSensibilityX+this.angularSensibilityY)/2),this._isPinching=!0;else if(0!==this.panningSensibility&&this.multiTouchPanning&&o&&n){a=o.x-n.x,h=o.y-n.y;this.camera.inertialPanningX+=-a/this.panningSensibility,this.camera.inertialPanningY+=h/this.panningSensibility}}}},t.prototype.onButtonDown=function(e){this._isPanClick=e.button===this.camera._panningMouseButton},t.prototype.onButtonUp=function(e){this._twoFingerActivityCount=0,this._isPinching=!1},t.prototype.onLostFocus=function(){this._isPanClick=!1,this._twoFingerActivityCount=0,this._isPinching=!1},Object(n.b)([Object(o.c)()],t.prototype,"buttons",void 0),Object(n.b)([Object(o.c)()],t.prototype,"angularSensibilityX",void 0),Object(n.b)([Object(o.c)()],t.prototype,"angularSensibilityY",void 0),Object(n.b)([Object(o.c)()],t.prototype,"pinchPrecision",void 0),Object(n.b)([Object(o.c)()],t.prototype,"pinchDeltaPercentage",void 0),Object(n.b)([Object(o.c)()],t.prototype,"useNaturalPinchZoom",void 0),Object(n.b)([Object(o.c)()],t.prototype,"panningSensibility",void 0),Object(n.b)([Object(o.c)()],t.prototype,"multiTouchPanning",void 0),Object(n.b)([Object(o.c)()],t.prototype,"multiTouchPanAndZoom",void 0),t}(function(){function e(){this.buttons=[0,1,2]}return e.prototype.attachControl=function(e){var t=this;e=w.b.BackCompatCameraNoPreventDefault(arguments);var i=this.camera.getEngine(),r=i.getInputElement(),n=0,o=null;this.pointA=null,this.pointB=null,this._altKey=!1,this._ctrlKey=!1,this._metaKey=!1,this._shiftKey=!1,this._buttonsPressed=0,this._pointerInput=function(s,a){var h=s.event,l="touch"===h.pointerType;if(!i.isInVRExclusivePointerMode&&(s.type===c.a.POINTERMOVE||-1!==t.buttons.indexOf(h.button))){var u=h.srcElement||h.target;if(t._altKey=h.altKey,t._ctrlKey=h.ctrlKey,t._metaKey=h.metaKey,t._shiftKey=h.shiftKey,t._buttonsPressed=h.buttons,i.isPointerLock){var f=h.movementX||h.mozMovementX||h.webkitMovementX||h.msMovementX||0,d=h.movementY||h.mozMovementY||h.webkitMovementY||h.msMovementY||0;t.onTouch(null,f,d),t.pointA=null,t.pointB=null}else if(s.type===c.a.POINTERDOWN&&u){try{u.setPointerCapture(h.pointerId)}catch(e){}null===t.pointA?t.pointA={x:h.clientX,y:h.clientY,pointerId:h.pointerId,type:h.pointerType}:null===t.pointB&&(t.pointB={x:h.clientX,y:h.clientY,pointerId:h.pointerId,type:h.pointerType}),t.onButtonDown(h),e||(h.preventDefault(),r&&r.focus())}else if(s.type===c.a.POINTERDOUBLETAP)t.onDoubleTap(h.pointerType);else if(s.type===c.a.POINTERUP&&u){try{u.releasePointerCapture(h.pointerId)}catch(e){}l||(t.pointB=null),i._badOS?t.pointA=t.pointB=null:t.pointB&&t.pointA&&t.pointA.pointerId==h.pointerId?(t.pointA=t.pointB,t.pointB=null):t.pointA&&t.pointB&&t.pointB.pointerId==h.pointerId?t.pointB=null:t.pointA=t.pointB=null,(0!==n||o)&&(t.onMultiTouch(t.pointA,t.pointB,n,0,o,null),n=0,o=null),t.onButtonUp(h),e||h.preventDefault()}else if(s.type===c.a.POINTERMOVE)if(e||h.preventDefault(),t.pointA&&null===t.pointB){f=h.clientX-t.pointA.x,d=h.clientY-t.pointA.y;t.onTouch(t.pointA,f,d),t.pointA.x=h.clientX,t.pointA.y=h.clientY}else if(t.pointA&&t.pointB){var p=t.pointA.pointerId===h.pointerId?t.pointA:t.pointB;p.x=h.clientX,p.y=h.clientY;var _=t.pointA.x-t.pointB.x,g=t.pointA.y-t.pointB.y,m=_*_+g*g,v={x:(t.pointA.x+t.pointB.x)/2,y:(t.pointA.y+t.pointB.y)/2,pointerId:h.pointerId,type:s.type};t.onMultiTouch(t.pointA,t.pointB,n,m,o,v),o=v,n=m}}},this._observer=this.camera.getScene().onPointerObservable.add(this._pointerInput,c.a.POINTERDOWN|c.a.POINTERUP|c.a.POINTERMOVE),this._onLostFocus=function(){t.pointA=t.pointB=null,n=0,o=null,t.onLostFocus()},r&&r.addEventListener("contextmenu",this.onContextMenu.bind(this),!1);var s=this.camera.getScene().getEngine().getHostWindow();s&&w.b.RegisterTopRootEvents(s,[{name:"blur",handler:this._onLostFocus}])},e.prototype.detachControl=function(e){if(this._onLostFocus){var t=this.camera.getScene().getEngine().getHostWindow();t&&w.b.UnregisterTopRootEvents(t,[{name:"blur",handler:this._onLostFocus}])}if(this._observer){if(this.camera.getScene().onPointerObservable.remove(this._observer),this._observer=null,this.onContextMenu){var i=this.camera.getScene().getEngine().getInputElement();i&&i.removeEventListener("contextmenu",this.onContextMenu)}this._onLostFocus=null}this._altKey=!1,this._ctrlKey=!1,this._metaKey=!1,this._shiftKey=!1,this._buttonsPressed=0},e.prototype.getClassName=function(){return"BaseCameraPointersInput"},e.prototype.getSimpleName=function(){return"pointers"},e.prototype.onDoubleTap=function(e){},e.prototype.onTouch=function(e,t,i){},e.prototype.onMultiTouch=function(e,t,i,r,n,o){},e.prototype.onContextMenu=function(e){e.preventDefault()},e.prototype.onButtonDown=function(e){},e.prototype.onButtonUp=function(e){},e.prototype.onLostFocus=function(){},Object(n.b)([Object(o.c)()],e.prototype,"buttons",void 0),e}());R.ArcRotateCameraPointersInput=L;var F=i(46),N=function(){function e(){this.keysUp=[38],this.keysDown=[40],this.keysLeft=[37],this.keysRight=[39],this.keysReset=[220],this.panningSensibility=50,this.zoomingSensibility=25,this.useAltToZoom=!0,this.angularSpeed=.01,this._keys=new Array}return e.prototype.attachControl=function(e){var t=this;e=w.b.BackCompatCameraNoPreventDefault(arguments),this._onCanvasBlurObserver||(this._scene=this.camera.getScene(),this._engine=this._scene.getEngine(),this._onCanvasBlurObserver=this._engine.onCanvasBlurObservable.add((function(){t._keys=[]})),this._onKeyboardObserver=this._scene.onKeyboardObservable.add((function(i){var r,n=i.event;n.metaKey||(i.type===F.a.KEYDOWN?(t._ctrlPressed=n.ctrlKey,t._altPressed=n.altKey,(-1!==t.keysUp.indexOf(n.keyCode)||-1!==t.keysDown.indexOf(n.keyCode)||-1!==t.keysLeft.indexOf(n.keyCode)||-1!==t.keysRight.indexOf(n.keyCode)||-1!==t.keysReset.indexOf(n.keyCode))&&(-1===(r=t._keys.indexOf(n.keyCode))&&t._keys.push(n.keyCode),n.preventDefault&&(e||n.preventDefault()))):-1===t.keysUp.indexOf(n.keyCode)&&-1===t.keysDown.indexOf(n.keyCode)&&-1===t.keysLeft.indexOf(n.keyCode)&&-1===t.keysRight.indexOf(n.keyCode)&&-1===t.keysReset.indexOf(n.keyCode)||((r=t._keys.indexOf(n.keyCode))>=0&&t._keys.splice(r,1),n.preventDefault&&(e||n.preventDefault())))})))},e.prototype.detachControl=function(e){this._scene&&(this._onKeyboardObserver&&this._scene.onKeyboardObservable.remove(this._onKeyboardObserver),this._onCanvasBlurObserver&&this._engine.onCanvasBlurObservable.remove(this._onCanvasBlurObserver),this._onKeyboardObserver=null,this._onCanvasBlurObserver=null),this._keys=[]},e.prototype.checkInputs=function(){if(this._onKeyboardObserver)for(var e=this.camera,t=0;t0?i/(1+this.wheelDeltaPercentage):i*(1+this.wheelDeltaPercentage)},e.prototype.attachControl=function(e){var t=this;e=w.b.BackCompatCameraNoPreventDefault(arguments),this._wheel=function(i,r){if(i.type===c.a.POINTERWHEEL){var n=i.event,o=0,s=n,a=0;if(a=s.wheelDelta?s.wheelDelta:60*-(n.deltaY||n.detail),t.wheelDeltaPercentage){if((o=t.computeDeltaFromMouseWheelLegacyEvent(a,t.camera.radius))>0){for(var h=t.camera.radius,l=t.camera.inertialRadiusOffset+o,u=0;u<20&&Math.abs(l)>.001;u++)h-=l,l*=t.camera.inertia;h=v.a.Clamp(h,0,Number.MAX_VALUE),o=t.computeDeltaFromMouseWheelLegacyEvent(a,h)}}else o=a/(40*t.wheelPrecision);o&&(t.camera.inertialRadiusOffset+=o),n.preventDefault&&(e||n.preventDefault())}},this._observer=this.camera.getScene().onPointerObservable.add(this._wheel,c.a.POINTERWHEEL)},e.prototype.detachControl=function(e){this._observer&&(this.camera.getScene().onPointerObservable.remove(this._observer),this._observer=null,this._wheel=null)},e.prototype.getClassName=function(){return"ArcRotateCameraMouseWheelInput"},e.prototype.getSimpleName=function(){return"mousewheel"},Object(n.b)([Object(o.c)()],e.prototype,"wheelPrecision",void 0),Object(n.b)([Object(o.c)()],e.prototype,"wheelDeltaPercentage",void 0),e}();R.ArcRotateCameraMouseWheelInput=B;var k=function(e){function t(t){return e.call(this,t)||this}return Object(n.c)(t,e),t.prototype.addMouseWheel=function(){return this.add(new B),this},t.prototype.addPointers=function(){return this.add(new L),this},t.prototype.addKeyboard=function(){return this.add(new N),this},t}(D);h.a.AddNodeConstructor("ArcRotateCamera",(function(e,t){return function(){return new U(e,0,0,1,a.e.Zero(),t)}}));var U=function(e){function t(t,i,r,n,o,h,l){void 0===l&&(l=!0);var c=e.call(this,t,a.e.Zero(),h,l)||this;return c.inertialAlphaOffset=0,c.inertialBetaOffset=0,c.inertialRadiusOffset=0,c.lowerAlphaLimit=null,c.upperAlphaLimit=null,c.lowerBetaLimit=.01,c.upperBetaLimit=Math.PI-.01,c.lowerRadiusLimit=null,c.upperRadiusLimit=null,c.inertialPanningX=0,c.inertialPanningY=0,c.pinchToPanMaxDistance=20,c.panningDistanceLimit=null,c.panningOriginTarget=a.e.Zero(),c.panningInertia=.9,c.zoomOnFactor=1,c.targetScreenOffset=a.d.Zero(),c.allowUpsideDown=!0,c.useInputToRestoreState=!0,c._viewMatrix=new a.a,c.panningAxis=new a.e(1,1,0),c.onMeshTargetChangedObservable=new s.a,c.checkCollisions=!1,c.collisionRadius=new a.e(.5,.5,.5),c._previousPosition=a.e.Zero(),c._collisionVelocity=a.e.Zero(),c._newPosition=a.e.Zero(),c._computationVector=a.e.Zero(),c._onCollisionPositionChange=function(e,t,i){void 0===i&&(i=null),i?(c.setPosition(t),c.onCollide&&c.onCollide(i)):c._previousPosition.copyFrom(c._position);var r=Math.cos(c.alpha),n=Math.sin(c.alpha),o=Math.cos(c.beta),s=Math.sin(c.beta);0===s&&(s=1e-4);var a=c._getTargetPosition();c._computationVector.copyFromFloats(c.radius*r*s,c.radius*o,c.radius*n*s),a.addToRef(c._computationVector,c._newPosition),c._position.copyFrom(c._newPosition);var h=c.upVector;c.allowUpsideDown&&c.beta<0&&(h=(h=h.clone()).negate()),c._computeViewMatrix(c._position,a,h),c._viewMatrix.addAtIndex(12,c.targetScreenOffset.x),c._viewMatrix.addAtIndex(13,c.targetScreenOffset.y),c._collisionTriggered=!1},c._target=a.e.Zero(),o&&c.setTarget(o),c.alpha=i,c.beta=r,c.radius=n,c.getViewMatrix(),c.inputs=new k(c),c.inputs.addKeyboard().addMouseWheel().addPointers(),c}return Object(n.c)(t,e),Object.defineProperty(t.prototype,"target",{get:function(){return this._target},set:function(e){this.setTarget(e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"position",{get:function(){return this._position},set:function(e){this.setPosition(e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"upVector",{get:function(){return this._upVector},set:function(e){this._upToYMatrix||(this._YToUpMatrix=new a.a,this._upToYMatrix=new a.a,this._upVector=a.e.Zero()),e.normalize(),this._upVector.copyFrom(e),this.setMatUp()},enumerable:!1,configurable:!0}),t.prototype.setMatUp=function(){a.a.RotationAlignToRef(a.e.UpReadOnly,this._upVector,this._YToUpMatrix),a.a.RotationAlignToRef(this._upVector,a.e.UpReadOnly,this._upToYMatrix)},Object.defineProperty(t.prototype,"angularSensibilityX",{get:function(){var e=this.inputs.attached.pointers;return e?e.angularSensibilityX:0},set:function(e){var t=this.inputs.attached.pointers;t&&(t.angularSensibilityX=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"angularSensibilityY",{get:function(){var e=this.inputs.attached.pointers;return e?e.angularSensibilityY:0},set:function(e){var t=this.inputs.attached.pointers;t&&(t.angularSensibilityY=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"pinchPrecision",{get:function(){var e=this.inputs.attached.pointers;return e?e.pinchPrecision:0},set:function(e){var t=this.inputs.attached.pointers;t&&(t.pinchPrecision=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"pinchDeltaPercentage",{get:function(){var e=this.inputs.attached.pointers;return e?e.pinchDeltaPercentage:0},set:function(e){var t=this.inputs.attached.pointers;t&&(t.pinchDeltaPercentage=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"useNaturalPinchZoom",{get:function(){var e=this.inputs.attached.pointers;return!!e&&e.useNaturalPinchZoom},set:function(e){var t=this.inputs.attached.pointers;t&&(t.useNaturalPinchZoom=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"panningSensibility",{get:function(){var e=this.inputs.attached.pointers;return e?e.panningSensibility:0},set:function(e){var t=this.inputs.attached.pointers;t&&(t.panningSensibility=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"keysUp",{get:function(){var e=this.inputs.attached.keyboard;return e?e.keysUp:[]},set:function(e){var t=this.inputs.attached.keyboard;t&&(t.keysUp=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"keysDown",{get:function(){var e=this.inputs.attached.keyboard;return e?e.keysDown:[]},set:function(e){var t=this.inputs.attached.keyboard;t&&(t.keysDown=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"keysLeft",{get:function(){var e=this.inputs.attached.keyboard;return e?e.keysLeft:[]},set:function(e){var t=this.inputs.attached.keyboard;t&&(t.keysLeft=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"keysRight",{get:function(){var e=this.inputs.attached.keyboard;return e?e.keysRight:[]},set:function(e){var t=this.inputs.attached.keyboard;t&&(t.keysRight=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"wheelPrecision",{get:function(){var e=this.inputs.attached.mousewheel;return e?e.wheelPrecision:0},set:function(e){var t=this.inputs.attached.mousewheel;t&&(t.wheelPrecision=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"wheelDeltaPercentage",{get:function(){var e=this.inputs.attached.mousewheel;return e?e.wheelDeltaPercentage:0},set:function(e){var t=this.inputs.attached.mousewheel;t&&(t.wheelDeltaPercentage=e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"bouncingBehavior",{get:function(){return this._bouncingBehavior},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"useBouncingBehavior",{get:function(){return null!=this._bouncingBehavior},set:function(e){e!==this.useBouncingBehavior&&(e?(this._bouncingBehavior=new A,this.addBehavior(this._bouncingBehavior)):this._bouncingBehavior&&(this.removeBehavior(this._bouncingBehavior),this._bouncingBehavior=null))},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"framingBehavior",{get:function(){return this._framingBehavior},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"useFramingBehavior",{get:function(){return null!=this._framingBehavior},set:function(e){e!==this.useFramingBehavior&&(e?(this._framingBehavior=new M,this.addBehavior(this._framingBehavior)):this._framingBehavior&&(this.removeBehavior(this._framingBehavior),this._framingBehavior=null))},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"autoRotationBehavior",{get:function(){return this._autoRotationBehavior},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"useAutoRotationBehavior",{get:function(){return null!=this._autoRotationBehavior},set:function(e){e!==this.useAutoRotationBehavior&&(e?(this._autoRotationBehavior=new f,this.addBehavior(this._autoRotationBehavior)):this._autoRotationBehavior&&(this.removeBehavior(this._autoRotationBehavior),this._autoRotationBehavior=null))},enumerable:!1,configurable:!0}),t.prototype._initCache=function(){e.prototype._initCache.call(this),this._cache._target=new a.e(Number.MAX_VALUE,Number.MAX_VALUE,Number.MAX_VALUE),this._cache.alpha=void 0,this._cache.beta=void 0,this._cache.radius=void 0,this._cache.targetScreenOffset=a.d.Zero()},t.prototype._updateCache=function(t){t||e.prototype._updateCache.call(this),this._cache._target.copyFrom(this._getTargetPosition()),this._cache.alpha=this.alpha,this._cache.beta=this.beta,this._cache.radius=this.radius,this._cache.targetScreenOffset.copyFrom(this.targetScreenOffset)},t.prototype._getTargetPosition=function(){if(this._targetHost&&this._targetHost.getAbsolutePosition){var e=this._targetHost.absolutePosition;this._targetBoundingCenter?e.addToRef(this._targetBoundingCenter,this._target):this._target.copyFrom(e)}var t=this._getLockedTargetPosition();return t||this._target},t.prototype.storeState=function(){return this._storedAlpha=this.alpha,this._storedBeta=this.beta,this._storedRadius=this.radius,this._storedTarget=this._getTargetPosition().clone(),this._storedTargetScreenOffset=this.targetScreenOffset.clone(),e.prototype.storeState.call(this)},t.prototype._restoreStateValues=function(){return!!e.prototype._restoreStateValues.call(this)&&(this.setTarget(this._storedTarget.clone()),this.alpha=this._storedAlpha,this.beta=this._storedBeta,this.radius=this._storedRadius,this.targetScreenOffset=this._storedTargetScreenOffset.clone(),this.inertialAlphaOffset=0,this.inertialBetaOffset=0,this.inertialRadiusOffset=0,this.inertialPanningX=0,this.inertialPanningY=0,!0)},t.prototype._isSynchronizedViewMatrix=function(){return!!e.prototype._isSynchronizedViewMatrix.call(this)&&(this._cache._target.equals(this._getTargetPosition())&&this._cache.alpha===this.alpha&&this._cache.beta===this.beta&&this._cache.radius===this.radius&&this._cache.targetScreenOffset.equals(this.targetScreenOffset))},t.prototype.attachControl=function(e,t,i,r){var n=this;void 0===i&&(i=!0),void 0===r&&(r=2),t=w.b.BackCompatCameraNoPreventDefault(arguments),this._useCtrlForPanning=i,this._panningMouseButton=r,"boolean"==typeof arguments[0]&&(arguments.length>1&&(this._useCtrlForPanning=arguments[1]),arguments.length>2&&(this._panningMouseButton=arguments[2])),this.inputs.attachElement(t),this._reset=function(){n.inertialAlphaOffset=0,n.inertialBetaOffset=0,n.inertialRadiusOffset=0,n.inertialPanningX=0,n.inertialPanningY=0}},t.prototype.detachControl=function(e){this.inputs.detachElement(),this._reset&&this._reset()},t.prototype._checkInputs=function(){if(!this._collisionTriggered){if(this.inputs.checkInputs(),0!==this.inertialAlphaOffset||0!==this.inertialBetaOffset||0!==this.inertialRadiusOffset){var t=this.inertialAlphaOffset;this.beta<=0&&(t*=-1),this.getScene().useRightHandedSystem&&(t*=-1),this.parent&&this.parent._getWorldMatrixDeterminant()<0&&(t*=-1),this.alpha+=t,this.beta+=this.inertialBetaOffset,this.radius-=this.inertialRadiusOffset,this.inertialAlphaOffset*=this.inertia,this.inertialBetaOffset*=this.inertia,this.inertialRadiusOffset*=this.inertia,Math.abs(this.inertialAlphaOffset)Math.PI&&(this.beta=this.beta-2*Math.PI):this.betathis.upperBetaLimit&&(this.beta=this.upperBetaLimit),null!==this.lowerAlphaLimit&&this.alphathis.upperAlphaLimit&&(this.alpha=this.upperAlphaLimit),null!==this.lowerRadiusLimit&&this.radiusthis.upperRadiusLimit&&(this.radius=this.upperRadiusLimit,this.inertialRadiusOffset=0)},t.prototype.rebuildAnglesAndRadius=function(){this._position.subtractToRef(this._getTargetPosition(),this._computationVector),0===this._upVector.x&&1===this._upVector.y&&0===this._upVector.z||a.e.TransformCoordinatesToRef(this._computationVector,this._upToYMatrix,this._computationVector),this.radius=this._computationVector.length(),0===this.radius&&(this.radius=1e-4);var e=this.alpha;0===this._computationVector.x&&0===this._computationVector.z?this.alpha=Math.PI/2:this.alpha=Math.acos(this._computationVector.x/Math.sqrt(Math.pow(this._computationVector.x,2)+Math.pow(this._computationVector.z,2))),this._computationVector.z<0&&(this.alpha=2*Math.PI-this.alpha);var t=Math.round((e-this.alpha)/(2*Math.PI));this.alpha+=2*t*Math.PI,this.beta=Math.acos(this._computationVector.y/this.radius),this._checkLimits()},t.prototype.setPosition=function(e){this._position.equals(e)||(this._position.copyFrom(e),this.rebuildAnglesAndRadius())},t.prototype.setTarget=function(e,t,i){if(void 0===t&&(t=!1),void 0===i&&(i=!1),e.getBoundingInfo)this._targetBoundingCenter=t?e.getBoundingInfo().boundingBox.centerWorld.clone():null,e.computeWorldMatrix(),this._targetHost=e,this._target=this._getTargetPosition(),this.onMeshTargetChangedObservable.notifyObservers(this._targetHost);else{var r=e,n=this._getTargetPosition();if(n&&!i&&n.equals(r))return;this._targetHost=null,this._target=r,this._targetBoundingCenter=null,this.onMeshTargetChangedObservable.notifyObservers(null)}this.rebuildAnglesAndRadius()},t.prototype._getViewMatrix=function(){var e=Math.cos(this.alpha),t=Math.sin(this.alpha),i=Math.cos(this.beta),r=Math.sin(this.beta);0===r&&(r=1e-4),0===this.radius&&(this.radius=1e-4);var n=this._getTargetPosition();if(this._computationVector.copyFromFloats(this.radius*e*r,this.radius*i,this.radius*t*r),0===this._upVector.x&&1===this._upVector.y&&0===this._upVector.z||a.e.TransformCoordinatesToRef(this._computationVector,this._YToUpMatrix,this._computationVector),n.addToRef(this._computationVector,this._newPosition),this.getScene().collisionsEnabled&&this.checkCollisions){var o=this.getScene().collisionCoordinator;this._collider||(this._collider=o.createCollider()),this._collider._radius=this.collisionRadius,this._newPosition.subtractToRef(this._position,this._collisionVelocity),this._collisionTriggered=!0,o.getNewPosition(this._position,this._collisionVelocity,this._collider,3,null,this._onCollisionPositionChange,this.uniqueId)}else{this._position.copyFrom(this._newPosition);var s=this.upVector;this.allowUpsideDown&&r<0&&(s=s.negate()),this._computeViewMatrix(this._position,n,s),this._viewMatrix.addAtIndex(12,this.targetScreenOffset.x),this._viewMatrix.addAtIndex(13,this.targetScreenOffset.y)}return this._currentTarget=n,this._viewMatrix},t.prototype.zoomOn=function(e,t){void 0===t&&(t=!1),e=e||this.getScene().meshes;var i=l.Mesh.MinMax(e),r=a.e.Distance(i.min,i.max);this.radius=r*this.zoomOnFactor,this.focusOn({min:i.min,max:i.max,distance:r},t)},t.prototype.focusOn=function(e,t){var i,r;if(void 0===t&&(t=!1),void 0===e.min){var n=e||this.getScene().meshes;i=l.Mesh.MinMax(n),r=a.e.Distance(i.min,i.max)}else{i=e,r=e.distance}this._target=l.Mesh.Center(i),t||(this.maxZ=2*r)},t.prototype.createRigCamera=function(e,i){var r=0;switch(this.cameraRigMode){case S.a.RIG_MODE_STEREOSCOPIC_ANAGLYPH:case S.a.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL:case S.a.RIG_MODE_STEREOSCOPIC_OVERUNDER:case S.a.RIG_MODE_STEREOSCOPIC_INTERLACED:case S.a.RIG_MODE_VR:r=this._cameraRigParams.stereoHalfAngle*(0===i?1:-1);break;case S.a.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED:r=this._cameraRigParams.stereoHalfAngle*(0===i?-1:1)}var n=new t(e,this.alpha+r,this.beta,this.radius,this._target,this.getScene());return n._cameraRigParams={},n.isRigCamera=!0,n.rigParent=this,n.upVector=this.upVector,n},t.prototype._updateRigCameras=function(){var t=this._rigCameras[0],i=this._rigCameras[1];switch(t.beta=i.beta=this.beta,this.cameraRigMode){case S.a.RIG_MODE_STEREOSCOPIC_ANAGLYPH:case S.a.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL:case S.a.RIG_MODE_STEREOSCOPIC_OVERUNDER:case S.a.RIG_MODE_STEREOSCOPIC_INTERLACED:case S.a.RIG_MODE_VR:t.alpha=this.alpha-this._cameraRigParams.stereoHalfAngle,i.alpha=this.alpha+this._cameraRigParams.stereoHalfAngle;break;case S.a.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED:t.alpha=this.alpha+this._cameraRigParams.stereoHalfAngle,i.alpha=this.alpha-this._cameraRigParams.stereoHalfAngle}e.prototype._updateRigCameras.call(this)},t.prototype.dispose=function(){this.inputs.clear(),e.prototype.dispose.call(this)},t.prototype.getClassName=function(){return"ArcRotateCamera"},Object(n.b)([Object(o.c)()],t.prototype,"alpha",void 0),Object(n.b)([Object(o.c)()],t.prototype,"beta",void 0),Object(n.b)([Object(o.c)()],t.prototype,"radius",void 0),Object(n.b)([Object(o.k)("target")],t.prototype,"_target",void 0),Object(n.b)([Object(o.c)()],t.prototype,"inertialAlphaOffset",void 0),Object(n.b)([Object(o.c)()],t.prototype,"inertialBetaOffset",void 0),Object(n.b)([Object(o.c)()],t.prototype,"inertialRadiusOffset",void 0),Object(n.b)([Object(o.c)()],t.prototype,"lowerAlphaLimit",void 0),Object(n.b)([Object(o.c)()],t.prototype,"upperAlphaLimit",void 0),Object(n.b)([Object(o.c)()],t.prototype,"lowerBetaLimit",void 0),Object(n.b)([Object(o.c)()],t.prototype,"upperBetaLimit",void 0),Object(n.b)([Object(o.c)()],t.prototype,"lowerRadiusLimit",void 0),Object(n.b)([Object(o.c)()],t.prototype,"upperRadiusLimit",void 0),Object(n.b)([Object(o.c)()],t.prototype,"inertialPanningX",void 0),Object(n.b)([Object(o.c)()],t.prototype,"inertialPanningY",void 0),Object(n.b)([Object(o.c)()],t.prototype,"pinchToPanMaxDistance",void 0),Object(n.b)([Object(o.c)()],t.prototype,"panningDistanceLimit",void 0),Object(n.b)([Object(o.k)()],t.prototype,"panningOriginTarget",void 0),Object(n.b)([Object(o.c)()],t.prototype,"panningInertia",void 0),Object(n.b)([Object(o.c)()],t.prototype,"zoomOnFactor",void 0),Object(n.b)([Object(o.c)()],t.prototype,"targetScreenOffset",void 0),Object(n.b)([Object(o.c)()],t.prototype,"allowUpsideDown",void 0),Object(n.b)([Object(o.c)()],t.prototype,"useInputToRestoreState",void 0),t}(C)},function(e,t,i){"use strict";i.r(t),i.d(t,"v1",(function(){return _})),i.d(t,"v3",(function(){return M})),i.d(t,"v4",(function(){return S})),i.d(t,"v5",(function(){return C})),i.d(t,"NIL",(function(){return I})),i.d(t,"version",(function(){return R})),i.d(t,"validate",(function(){return a})),i.d(t,"stringify",(function(){return f})),i.d(t,"parse",(function(){return g}));var r="undefined"!=typeof crypto&&crypto.getRandomValues&&crypto.getRandomValues.bind(crypto)||"undefined"!=typeof msCrypto&&"function"==typeof msCrypto.getRandomValues&&msCrypto.getRandomValues.bind(msCrypto),n=new Uint8Array(16);function o(){if(!r)throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");return r(n)}var s=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;for(var a=function(e){return"string"==typeof e&&s.test(e)},h=[],l=0;l<256;++l)h.push((l+256).toString(16).substr(1));var c,u,f=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=(h[e[t+0]]+h[e[t+1]]+h[e[t+2]]+h[e[t+3]]+"-"+h[e[t+4]]+h[e[t+5]]+"-"+h[e[t+6]]+h[e[t+7]]+"-"+h[e[t+8]]+h[e[t+9]]+"-"+h[e[t+10]]+h[e[t+11]]+h[e[t+12]]+h[e[t+13]]+h[e[t+14]]+h[e[t+15]]).toLowerCase();if(!a(i))throw TypeError("Stringified UUID is invalid");return i},d=0,p=0;var _=function(e,t,i){var r=t&&i||0,n=t||new Array(16),s=(e=e||{}).node||c,a=void 0!==e.clockseq?e.clockseq:u;if(null==s||null==a){var h=e.random||(e.rng||o)();null==s&&(s=c=[1|h[0],h[1],h[2],h[3],h[4],h[5]]),null==a&&(a=u=16383&(h[6]<<8|h[7]))}var l=void 0!==e.msecs?e.msecs:Date.now(),_=void 0!==e.nsecs?e.nsecs:p+1,g=l-d+(_-p)/1e4;if(g<0&&void 0===e.clockseq&&(a=a+1&16383),(g<0||l>d)&&void 0===e.nsecs&&(_=0),_>=1e4)throw new Error("uuid.v1(): Can't create more than 10M uuids/sec");d=l,p=_,u=a;var m=(1e4*(268435455&(l+=122192928e5))+_)%4294967296;n[r++]=m>>>24&255,n[r++]=m>>>16&255,n[r++]=m>>>8&255,n[r++]=255&m;var v=l/4294967296*1e4&268435455;n[r++]=v>>>8&255,n[r++]=255&v,n[r++]=v>>>24&15|16,n[r++]=v>>>16&255,n[r++]=a>>>8|128,n[r++]=255&a;for(var b=0;b<6;++b)n[r+b]=s[b];return t||f(n)};var g=function(e){if(!a(e))throw TypeError("Invalid UUID");var t,i=new Uint8Array(16);return i[0]=(t=parseInt(e.slice(0,8),16))>>>24,i[1]=t>>>16&255,i[2]=t>>>8&255,i[3]=255&t,i[4]=(t=parseInt(e.slice(9,13),16))>>>8,i[5]=255&t,i[6]=(t=parseInt(e.slice(14,18),16))>>>8,i[7]=255&t,i[8]=(t=parseInt(e.slice(19,23),16))>>>8,i[9]=255&t,i[10]=(t=parseInt(e.slice(24,36),16))/1099511627776&255,i[11]=t/4294967296&255,i[12]=t>>>24&255,i[13]=t>>>16&255,i[14]=t>>>8&255,i[15]=255&t,i};var m=function(e,t,i){function r(e,r,n,o){if("string"==typeof e&&(e=function(e){e=unescape(encodeURIComponent(e));for(var t=[],i=0;i>>9<<4)+1}function b(e,t){var i=(65535&e)+(65535&t);return(e>>16)+(t>>16)+(i>>16)<<16|65535&i}function y(e,t,i,r,n,o){return b((s=b(b(t,e),b(r,o)))<<(a=n)|s>>>32-a,i);var s,a}function T(e,t,i,r,n,o,s){return y(t&i|~t&r,e,t,n,o,s)}function x(e,t,i,r,n,o,s){return y(t&r|i&~r,e,t,n,o,s)}function E(e,t,i,r,n,o,s){return y(t^i^r,e,t,n,o,s)}function A(e,t,i,r,n,o,s){return y(i^(t|~r),e,t,n,o,s)}var M=m("v3",48,(function(e){if("string"==typeof e){var t=unescape(encodeURIComponent(e));e=new Uint8Array(t.length);for(var i=0;i>5]>>>n%32&255,s=parseInt(r.charAt(o>>>4&15)+r.charAt(15&o),16);t.push(s)}return t}(function(e,t){e[t>>5]|=128<>5]|=(255&e[r/8])<>>32-t}var C=m("v5",80,(function(e){var t=[1518500249,1859775393,2400959708,3395469782],i=[1732584193,4023233417,2562383102,271733878,3285377520];if("string"==typeof e){var r=unescape(encodeURIComponent(e));e=[];for(var n=0;n>>0;b=v,v=m,m=P(g,30)>>>0,g=_,_=x}i[0]=i[0]+_>>>0,i[1]=i[1]+g>>>0,i[2]=i[2]+m>>>0,i[3]=i[3]+v>>>0,i[4]=i[4]+b>>>0}return[i[0]>>24&255,i[0]>>16&255,i[0]>>8&255,255&i[0],i[1]>>24&255,i[1]>>16&255,i[1]>>8&255,255&i[1],i[2]>>24&255,i[2]>>16&255,i[2]>>8&255,255&i[2],i[3]>>24&255,i[3]>>16&255,i[3]>>8&255,255&i[3],i[4]>>24&255,i[4]>>16&255,i[4]>>8&255,255&i[4]]})),I="00000000-0000-0000-0000-000000000000";var R=function(e){if(!a(e))throw TypeError("Invalid UUID");return parseInt(e.substr(14,1),16)}},function(e,t,i){"use strict";i.r(t),i.d(t,"ScreenshotTools",(function(){return M}));var r=i(19),n=i(1),o=i(4),s=i(12),a=i(0),h=i(66),l=i(74),c=i(38),u=i(11),f=i(70),d=i(20);d.a.prototype.createRenderTargetTexture=function(e,t){var i=new f.a;void 0!==t&&"object"==typeof t?(i.generateMipMaps=t.generateMipMaps,i.generateDepthBuffer=!!t.generateDepthBuffer,i.generateStencilBuffer=!!t.generateStencilBuffer,i.type=void 0===t.type?0:t.type,i.samplingMode=void 0===t.samplingMode?3:t.samplingMode,i.format=void 0===t.format?5:t.format):(i.generateMipMaps=t,i.generateDepthBuffer=!0,i.generateStencilBuffer=!1,i.type=0,i.samplingMode=3,i.format=5),(1!==i.type||this._caps.textureFloatLinearFiltering)&&(2!==i.type||this._caps.textureHalfFloatLinearFiltering)||(i.samplingMode=1),1!==i.type||this._caps.textureFloat||(i.type=0,u.a.Warn("Float textures are not supported. Render target forced to TEXTURETYPE_UNSIGNED_BYTE type"));var r=this._gl,n=new c.a(this,c.b.RenderTarget),o=e.width||e,s=e.height||e,a=e.layers||0,h=this._getSamplingParameters(i.samplingMode,!!i.generateMipMaps),l=0!==a?r.TEXTURE_2D_ARRAY:r.TEXTURE_2D,d=this._getRGBABufferInternalSizedFormat(i.type,i.format),p=this._getInternalFormat(i.format),_=this._getWebGLTextureType(i.type);this._bindTextureDirectly(l,n),0!==a?(n.is2DArray=!0,r.texImage3D(l,0,d,o,s,a,0,p,_,null)):r.texImage2D(l,0,d,o,s,0,p,_,null),r.texParameteri(l,r.TEXTURE_MAG_FILTER,h.mag),r.texParameteri(l,r.TEXTURE_MIN_FILTER,h.min),r.texParameteri(l,r.TEXTURE_WRAP_S,r.CLAMP_TO_EDGE),r.texParameteri(l,r.TEXTURE_WRAP_T,r.CLAMP_TO_EDGE),i.generateMipMaps&&this._gl.generateMipmap(l),this._bindTextureDirectly(l,null);var g=this._currentFramebuffer,m=r.createFramebuffer();return this._bindUnboundFramebuffer(m),n._depthStencilBuffer=this._setupFramebufferDepthAttachments(!!i.generateStencilBuffer,i.generateDepthBuffer,o,s),n.is2DArray||r.framebufferTexture2D(r.FRAMEBUFFER,r.COLOR_ATTACHMENT0,r.TEXTURE_2D,n._webGLTexture,0),this._bindUnboundFramebuffer(g),n._framebuffer=m,n.baseWidth=o,n.baseHeight=s,n.width=o,n.height=s,n.depth=a,n.isReady=!0,n.samples=1,n.generateMipMaps=!!i.generateMipMaps,n.samplingMode=i.samplingMode,n.type=i.type,n.format=i.format,n._generateDepthBuffer=i.generateDepthBuffer,n._generateStencilBuffer=!!i.generateStencilBuffer,this._internalTexturesCache.push(n),n},d.a.prototype.createDepthStencilTexture=function(e,t){if(t.isCube){var i=e.width||e;return this._createDepthStencilCubeTexture(i,t)}return this._createDepthStencilTexture(e,t)},d.a.prototype._createDepthStencilTexture=function(e,t){var i=this._gl,r=e.layers||0,o=0!==r?i.TEXTURE_2D_ARRAY:i.TEXTURE_2D,s=new c.a(this,c.b.Depth);if(!this._caps.depthTextureExtension)return u.a.Error("Depth texture is not supported by your browser or hardware."),s;var a=Object(n.a)({bilinearFiltering:!1,comparisonFunction:0,generateStencil:!1},t);this._bindTextureDirectly(o,s,!0),this._setupDepthStencilTexture(s,e,a.generateStencil,a.bilinearFiltering,a.comparisonFunction);var h=a.generateStencil?i.UNSIGNED_INT_24_8:i.UNSIGNED_INT,l=a.generateStencil?i.DEPTH_STENCIL:i.DEPTH_COMPONENT,f=l;return this.webGLVersion>1&&(f=a.generateStencil?i.DEPTH24_STENCIL8:i.DEPTH_COMPONENT24),s.is2DArray?i.texImage3D(o,0,f,s.width,s.height,r,0,l,h,null):i.texImage2D(o,0,f,s.width,s.height,0,l,h,null),this._bindTextureDirectly(o,null),s},d.a.prototype.createRenderTargetCubeTexture=function(e,t){var i=Object(n.a)({generateMipMaps:!0,generateDepthBuffer:!0,generateStencilBuffer:!1,type:0,samplingMode:3,format:5},t);i.generateStencilBuffer=i.generateDepthBuffer&&i.generateStencilBuffer,(1!==i.type||this._caps.textureFloatLinearFiltering)&&(2!==i.type||this._caps.textureHalfFloatLinearFiltering)||(i.samplingMode=1);var r=this._gl,o=new c.a(this,c.b.RenderTarget);this._bindTextureDirectly(r.TEXTURE_CUBE_MAP,o,!0);var s=this._getSamplingParameters(i.samplingMode,i.generateMipMaps);1!==i.type||this._caps.textureFloat||(i.type=0,u.a.Warn("Float textures are not supported. Cube render target forced to TEXTURETYPE_UNESIGNED_BYTE type")),r.texParameteri(r.TEXTURE_CUBE_MAP,r.TEXTURE_MAG_FILTER,s.mag),r.texParameteri(r.TEXTURE_CUBE_MAP,r.TEXTURE_MIN_FILTER,s.min),r.texParameteri(r.TEXTURE_CUBE_MAP,r.TEXTURE_WRAP_S,r.CLAMP_TO_EDGE),r.texParameteri(r.TEXTURE_CUBE_MAP,r.TEXTURE_WRAP_T,r.CLAMP_TO_EDGE);for(var a=0;a<6;a++)r.texImage2D(r.TEXTURE_CUBE_MAP_POSITIVE_X+a,0,this._getRGBABufferInternalSizedFormat(i.type,i.format),e,e,0,this._getInternalFormat(i.format),this._getWebGLTextureType(i.type),null);var h=r.createFramebuffer();return this._bindUnboundFramebuffer(h),o._depthStencilBuffer=this._setupFramebufferDepthAttachments(i.generateStencilBuffer,i.generateDepthBuffer,e,e),i.generateMipMaps&&r.generateMipmap(r.TEXTURE_CUBE_MAP),this._bindTextureDirectly(r.TEXTURE_CUBE_MAP,null),this._bindUnboundFramebuffer(null),o._framebuffer=h,o.width=e,o.height=e,o.isReady=!0,o.isCube=!0,o.samples=1,o.generateMipMaps=i.generateMipMaps,o.samplingMode=i.samplingMode,o.type=i.type,o.format=i.format,o._generateDepthBuffer=i.generateDepthBuffer,o._generateStencilBuffer=i.generateStencilBuffer,this._internalTexturesCache.push(o),o};var p=i(25),_=function(e){function t(t,i,n,s,h,c,u,f,d,p,_,g,m){void 0===h&&(h=!0),void 0===c&&(c=0),void 0===u&&(u=!1),void 0===f&&(f=r.a.TRILINEAR_SAMPLINGMODE),void 0===d&&(d=!0),void 0===p&&(p=!1),void 0===_&&(_=!1),void 0===g&&(g=5),void 0===m&&(m=!1);var v=e.call(this,null,n,!s)||this;return v.renderParticles=!0,v.renderSprites=!1,v.ignoreCameraViewport=!1,v.onBeforeBindObservable=new o.a,v.onAfterUnbindObservable=new o.a,v.onBeforeRenderObservable=new o.a,v.onAfterRenderObservable=new o.a,v.onClearObservable=new o.a,v.onResizeObservable=new o.a,v._currentRefreshId=-1,v._refreshRate=1,v._samples=1,v.boundingBoxPosition=a.e.Zero(),(n=v.getScene())?(v._coordinatesMode=r.a.PROJECTION_MODE,v.renderList=new Array,v.name=t,v.isRenderTarget=!0,v._initialSizeParameter=i,v._processSizeParameter(i),v._resizeObserver=v.getScene().getEngine().onResizeObservable.add((function(){})),v._generateMipMaps=!!s,v._doNotChangeAspectRatio=h,v._renderingManager=new l.a(n),v._renderingManager._useSceneAutoClearSetup=!0,_||(v._renderTargetOptions={generateMipMaps:s,type:c,format:g,samplingMode:f,generateDepthBuffer:d,generateStencilBuffer:p},f===r.a.NEAREST_SAMPLINGMODE&&(v.wrapU=r.a.CLAMP_ADDRESSMODE,v.wrapV=r.a.CLAMP_ADDRESSMODE),m||(u?(v._texture=n.getEngine().createRenderTargetCubeTexture(v.getRenderSize(),v._renderTargetOptions),v.coordinatesMode=r.a.INVCUBIC_MODE,v._textureMatrix=a.a.Identity()):v._texture=n.getEngine().createRenderTargetTexture(v._size,v._renderTargetOptions))),v):v}return Object(n.c)(t,e),Object.defineProperty(t.prototype,"renderList",{get:function(){return this._renderList},set:function(e){this._renderList=e,this._renderList&&this._hookArray(this._renderList)},enumerable:!1,configurable:!0}),t.prototype._hookArray=function(e){var t=this,i=e.push;e.push=function(){for(var r=[],n=0;n0&&(this._postProcesses[0].autoClear=!1))}},t.prototype._shouldRender=function(){return-1===this._currentRefreshId||this.refreshRate===this._currentRefreshId?(this._currentRefreshId=1,!0):(this._currentRefreshId++,!1)},t.prototype.getRenderSize=function(){return this.getRenderWidth()},t.prototype.getRenderWidth=function(){return this._size.width?this._size.width:this._size},t.prototype.getRenderHeight=function(){return this._size.width?this._size.height:this._size},t.prototype.getRenderLayers=function(){var e=this._size.layers;return e||0},Object.defineProperty(t.prototype,"canRescale",{get:function(){return!0},enumerable:!1,configurable:!0}),t.prototype.scale=function(e){var t=Math.max(1,this.getRenderSize()*e);this.resize(t)},t.prototype.getReflectionTextureMatrix=function(){return this.isCube?this._textureMatrix:e.prototype.getReflectionTextureMatrix.call(this)},t.prototype.resize=function(e){var t=this.isCube;this.releaseInternalTexture();var i=this.getScene();i&&(this._processSizeParameter(e),this._texture=t?i.getEngine().createRenderTargetCubeTexture(this.getRenderSize(),this._renderTargetOptions):i.getEngine().createRenderTargetTexture(this._size,this._renderTargetOptions),this.onResizeObservable.hasObservers()&&this.onResizeObservable.notifyObservers(this))},t.prototype.render=function(e,t){if(void 0===e&&(e=!1),void 0===t&&(t=!1),a=this.getScene()){var i,r=a.getEngine();if(void 0!==this.useCameraPostProcesses&&(e=this.useCameraPostProcesses),this._waitingRenderList){this.renderList=[];for(var n=0;n1||this.activeCamera&&this.activeCamera!==a.activeCamera)&&a.setTransformMatrix(a.activeCamera.getViewMatrix(),a.activeCamera.getProjectionMatrix(!0)),r.setViewport(a.activeCamera.viewport)),a.resetCachedMaterial()}},t.prototype._bestReflectionRenderTargetDimension=function(e,t){var i=e*t,r=p.Engine.NearestPOT(i+16384/(128+i));return Math.min(p.Engine.FloorPOT(e),r)},t.prototype._prepareRenderingManager=function(e,t,i,r){var n=this.getScene();if(n){this._renderingManager.reset();for(var o=n.getRenderId(),s=0;s=0&&this._renderingManager.dispatchParticles(d))}}},t.prototype._bindFrameBuffer=function(e,t){void 0===e&&(e=0),void 0===t&&(t=0);var i=this.getScene();if(i){var r=i.getEngine();this._texture&&r.bindFramebuffer(this._texture,this.isCube?e:void 0,void 0,void 0,this.ignoreCameraViewport,0,t)}},t.prototype.unbindFrameBuffer=function(e,t){var i=this;this._texture&&e.unBindFramebuffer(this._texture,this.isCube,(function(){i.onAfterRenderObservable.notifyObservers(t)}))},t.prototype.renderToTarget=function(e,t,i,r,n){void 0===r&&(r=0),void 0===n&&(n=null);var o=this.getScene();if(o){var a=o.getEngine();if(this._texture){this._postProcessManager?this._postProcessManager._prepareFrame(this._texture,this._postProcesses):t&&o.postProcessManager._prepareFrame(this._texture)||this._bindFrameBuffer(e,r),this.is2DArray?this.onBeforeRenderObservable.notifyObservers(r):this.onBeforeRenderObservable.notifyObservers(e);var h=null,l=this.renderList?this.renderList:o.getActiveMeshes().data,c=this.renderList?this.renderList.length:o.getActiveMeshes().length;this.getCustomRenderList&&(h=this.getCustomRenderList(this.is2DArray?r:e,l,c)),h?this._prepareRenderingManager(h,h.length,n,!1):(this._defaultRenderListPrepared||(this._prepareRenderingManager(l,c,n,!this.renderList),this._defaultRenderListPrepared=!0),h=l),this.onClearObservable.hasObservers()?this.onClearObservable.notifyObservers(a):a.clear(this.clearColor||o.clearColor,!0,!0,!0),this._doNotChangeAspectRatio||o.updateTransformMatrix(!0);for(var u=0,f=o._beforeRenderTargetDrawStage;u=0&&t.customRenderTargets.splice(i,1);for(var r=0,n=t.cameras;r=0&&o.customRenderTargets.splice(i,1)}this.depthStencilTexture&&this.getScene().getEngine()._releaseTexture(this.depthStencilTexture),e.prototype.dispose.call(this)}},t.prototype._rebuild=function(){this.refreshRate===t.REFRESHRATE_RENDER_ONCE&&(this.refreshRate=t.REFRESHRATE_RENDER_ONCE),this._postProcessManager&&this._postProcessManager._rebuild()},t.prototype.freeRenderingGroups=function(){this._renderingManager&&this._renderingManager.freeRenderingGroups()},t.prototype.getViewCount=function(){return 1},t.REFRESHRATE_RENDER_ONCE=0,t.REFRESHRATE_RENDER_ONEVERYFRAME=1,t.REFRESHRATE_RENDER_ONEVERYTWOFRAMES=2,t}(r.a);r.a._CreateRenderTargetTexture=function(e,t,i,r){return new _(e,t,i,r)};var g=i(29),m=i(5),v="\nattribute vec2 position;\nuniform vec2 scale;\n\nvarying vec2 vUV;\nconst vec2 madd=vec2(0.5,0.5);\nvoid main(void) {\nvUV=(position*madd+madd)*scale;\ngl_Position=vec4(position,0.0,1.0);\n}";m.a.ShadersStore.postprocessVertexShader=v;var b=i(3),y=i(9),T=function(){function e(e,t,i,r,n,s,h,l,c,u,f,d,p,_,m){void 0===h&&(h=1),void 0===u&&(u=null),void 0===f&&(f=0),void 0===d&&(d="postprocess"),void 0===_&&(_=!1),void 0===m&&(m=5),this.width=-1,this.height=-1,this.nodeMaterialSource=null,this._outputTexture=null,this.autoClear=!0,this.alphaMode=0,this.animations=new Array,this.enablePixelPerfectMode=!1,this.forceFullscreenViewport=!0,this.scaleMode=1,this.alwaysForcePOT=!1,this._samples=1,this.adaptScaleToCurrentViewport=!1,this._reusable=!1,this._textures=new g.a(2),this._currentRenderTextureInd=0,this._scaleRatio=new a.d(1,1),this._texelSize=a.d.Zero(),this.onActivateObservable=new o.a,this.onSizeChangedObservable=new o.a,this.onApplyObservable=new o.a,this.onBeforeRenderObservable=new o.a,this.onAfterRenderObservable=new o.a,this.name=e,null!=s?(this._camera=s,this._scene=s.getScene(),s.attachPostProcess(this),this._engine=this._scene.getEngine(),this._scene.postProcesses.push(this),this.uniqueId=this._scene.getUniqueId()):l&&(this._engine=l,this._engine.postProcesses.push(this)),this._options=n,this.renderTargetSamplingMode=h||1,this._reusable=c||!1,this._textureType=f,this._textureFormat=m,this._samplers=r||[],this._samplers.push("textureSampler"),this._fragmentUrl=t,this._vertexUrl=d,this._parameters=i||[],this._parameters.push("scale"),this._indexParameters=p,_||this.updateEffect(u)}return Object.defineProperty(e.prototype,"samples",{get:function(){return this._samples},set:function(e){var t=this;this._samples=Math.min(e,this._engine.getCaps().maxMSAASamples),this._textures.forEach((function(e){e.samples!==t._samples&&t._engine.updateRenderTargetTextureSampleCount(e,t._samples)}))},enumerable:!1,configurable:!0}),e.prototype.getEffectName=function(){return this._fragmentUrl},Object.defineProperty(e.prototype,"onActivate",{set:function(e){this._onActivateObserver&&this.onActivateObservable.remove(this._onActivateObserver),e&&(this._onActivateObserver=this.onActivateObservable.add(e))},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onSizeChanged",{set:function(e){this._onSizeChangedObserver&&this.onSizeChangedObservable.remove(this._onSizeChangedObserver),this._onSizeChangedObserver=this.onSizeChangedObservable.add(e)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onApply",{set:function(e){this._onApplyObserver&&this.onApplyObservable.remove(this._onApplyObserver),this._onApplyObserver=this.onApplyObservable.add(e)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onBeforeRender",{set:function(e){this._onBeforeRenderObserver&&this.onBeforeRenderObservable.remove(this._onBeforeRenderObserver),this._onBeforeRenderObserver=this.onBeforeRenderObservable.add(e)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onAfterRender",{set:function(e){this._onAfterRenderObserver&&this.onAfterRenderObservable.remove(this._onAfterRenderObserver),this._onAfterRenderObserver=this.onAfterRenderObservable.add(e)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"inputTexture",{get:function(){return this._textures.data[this._currentRenderTextureInd]},set:function(e){this._forcedOutputTexture=e},enumerable:!1,configurable:!0}),e.prototype.restoreDefaultInputTexture=function(){this._forcedOutputTexture=null},e.prototype.getCamera=function(){return this._camera},Object.defineProperty(e.prototype,"texelSize",{get:function(){return this._shareOutputWithPostProcess?this._shareOutputWithPostProcess.texelSize:(this._forcedOutputTexture&&this._texelSize.copyFromFloats(1/this._forcedOutputTexture.width,1/this._forcedOutputTexture.height),this._texelSize)},enumerable:!1,configurable:!0}),e.prototype.getClassName=function(){return"PostProcess"},e.prototype.getEngine=function(){return this._engine},e.prototype.getEffect=function(){return this._effect},e.prototype.shareOutputWith=function(e){return this._disposeTextures(),this._shareOutputWithPostProcess=e,this},e.prototype.useOwnOutput=function(){0==this._textures.length&&(this._textures=new g.a(2)),this._shareOutputWithPostProcess=null},e.prototype.updateEffect=function(e,t,i,r,n,o,s,a){void 0===e&&(e=null),void 0===t&&(t=null),void 0===i&&(i=null),this._effect=this._engine.createEffect({vertex:null!=s?s:this._vertexUrl,fragment:null!=a?a:this._fragmentUrl},["position"],t||this._parameters,i||this._samplers,null!==e?e:"",void 0,n,o,r||this._indexParameters)},e.prototype.isReusable=function(){return this._reusable},e.prototype.markTextureDirty=function(){this.width=-1},e.prototype.activate=function(e,t,i){var r=this;void 0===t&&(t=null);var n=(e=e||this._camera).getScene(),o=n.getEngine(),s=o.getCaps().maxTextureSize,a=(t?t.width:this._engine.getRenderWidth(!0))*this._options|0,h=(t?t.height:this._engine.getRenderHeight(!0))*this._options|0,l=e.parent;!l||l.leftCamera!=e&&l.rightCamera!=e||(a/=2);var c,u=this._options.width||a,f=this._options.height||h,d=7!==this.renderTargetSamplingMode&&1!==this.renderTargetSamplingMode&&2!==this.renderTargetSamplingMode;if(!this._shareOutputWithPostProcess&&!this._forcedOutputTexture){if(this.adaptScaleToCurrentViewport){var _=o.currentViewport;_&&(u*=_.width,f*=_.height)}if((d||this.alwaysForcePOT)&&(this._options.width||(u=o.needPOTTextures?p.Engine.GetExponentOfTwo(u,s,this.scaleMode):u),this._options.height||(f=o.needPOTTextures?p.Engine.GetExponentOfTwo(f,s,this.scaleMode):f)),this.width!==u||this.height!==f){if(this._textures.length>0){for(var g=0;g0)for(var e=0;e0){var i=this._camera._getFirstPostProcess();i&&i.markTextureDirty()}this.onActivateObservable.clear(),this.onAfterRenderObservable.clear(),this.onApplyObservable.clear(),this.onBeforeRenderObservable.clear(),this.onSizeChangedObservable.clear()}},e.prototype.serialize=function(){var e=b.a.Serialize(this);return e.customType="BABYLON."+this.getClassName(),e.cameraId=this.getCamera().id,e.reusable=this._reusable,e.options=this._options,e.textureType=this._textureType,e},e.Parse=function(e,t,i){var r=y.a.GetClass(e.customType);if(!r||!r._Parse)return null;var n=t.getCameraByID(e.cameraId);return n?r._Parse(e,n,t,i):null},Object(n.b)([Object(b.c)()],e.prototype,"uniqueId",void 0),Object(n.b)([Object(b.c)()],e.prototype,"name",void 0),Object(n.b)([Object(b.c)()],e.prototype,"width",void 0),Object(n.b)([Object(b.c)()],e.prototype,"height",void 0),Object(n.b)([Object(b.c)()],e.prototype,"renderTargetSamplingMode",void 0),Object(n.b)([Object(b.e)()],e.prototype,"clearColor",void 0),Object(n.b)([Object(b.c)()],e.prototype,"autoClear",void 0),Object(n.b)([Object(b.c)()],e.prototype,"alphaMode",void 0),Object(n.b)([Object(b.c)()],e.prototype,"alphaConstants",void 0),Object(n.b)([Object(b.c)()],e.prototype,"enablePixelPerfectMode",void 0),Object(n.b)([Object(b.c)()],e.prototype,"forceFullscreenViewport",void 0),Object(n.b)([Object(b.c)()],e.prototype,"scaleMode",void 0),Object(n.b)([Object(b.c)()],e.prototype,"alwaysForcePOT",void 0),Object(n.b)([Object(b.c)("samples")],e.prototype,"_samples",void 0),Object(n.b)([Object(b.c)()],e.prototype,"adaptScaleToCurrentViewport",void 0),e}();y.a.RegisteredTypes["BABYLON.PostProcess"]=T;var x="uniform sampler2D textureSampler;\nuniform vec2 texelSize;\nvarying vec2 vUV;\nvarying vec2 sampleCoordS;\nvarying vec2 sampleCoordE;\nvarying vec2 sampleCoordN;\nvarying vec2 sampleCoordW;\nvarying vec2 sampleCoordNW;\nvarying vec2 sampleCoordSE;\nvarying vec2 sampleCoordNE;\nvarying vec2 sampleCoordSW;\nconst float fxaaQualitySubpix=1.0;\nconst float fxaaQualityEdgeThreshold=0.166;\nconst float fxaaQualityEdgeThresholdMin=0.0833;\nconst vec3 kLumaCoefficients=vec3(0.2126,0.7152,0.0722);\n#define FxaaLuma(rgba) dot(rgba.rgb,kLumaCoefficients)\nvoid main(){\nvec2 posM;\nposM.x=vUV.x;\nposM.y=vUV.y;\nvec4 rgbyM=texture2D(textureSampler,vUV,0.0);\nfloat lumaM=FxaaLuma(rgbyM);\nfloat lumaS=FxaaLuma(texture2D(textureSampler,sampleCoordS,0.0));\nfloat lumaE=FxaaLuma(texture2D(textureSampler,sampleCoordE,0.0));\nfloat lumaN=FxaaLuma(texture2D(textureSampler,sampleCoordN,0.0));\nfloat lumaW=FxaaLuma(texture2D(textureSampler,sampleCoordW,0.0));\nfloat maxSM=max(lumaS,lumaM);\nfloat minSM=min(lumaS,lumaM);\nfloat maxESM=max(lumaE,maxSM);\nfloat minESM=min(lumaE,minSM);\nfloat maxWN=max(lumaN,lumaW);\nfloat minWN=min(lumaN,lumaW);\nfloat rangeMax=max(maxWN,maxESM);\nfloat rangeMin=min(minWN,minESM);\nfloat rangeMaxScaled=rangeMax*fxaaQualityEdgeThreshold;\nfloat range=rangeMax-rangeMin;\nfloat rangeMaxClamped=max(fxaaQualityEdgeThresholdMin,rangeMaxScaled);\n#ifndef MALI\nif(range=edgeVert;\nfloat subpixA=subpixNSWE*2.0+subpixNWSWNESE;\nif (!horzSpan)\n{\nlumaN=lumaW;\n}\nif (!horzSpan)\n{\nlumaS=lumaE;\n}\nif (horzSpan)\n{\nlengthSign=texelSize.y;\n}\nfloat subpixB=(subpixA*(1.0/12.0))-lumaM;\nfloat gradientN=lumaN-lumaM;\nfloat gradientS=lumaS-lumaM;\nfloat lumaNN=lumaN+lumaM;\nfloat lumaSS=lumaS+lumaM;\nbool pairN=abs(gradientN)>=abs(gradientS);\nfloat gradient=max(abs(gradientN),abs(gradientS));\nif (pairN)\n{\nlengthSign=-lengthSign;\n}\nfloat subpixC=clamp(abs(subpixB)*subpixRcpRange,0.0,1.0);\nvec2 posB;\nposB.x=posM.x;\nposB.y=posM.y;\nvec2 offNP;\noffNP.x=(!horzSpan) ? 0.0 : texelSize.x;\noffNP.y=(horzSpan) ? 0.0 : texelSize.y;\nif (!horzSpan)\n{\nposB.x+=lengthSign*0.5;\n}\nif (horzSpan)\n{\nposB.y+=lengthSign*0.5;\n}\nvec2 posN;\nposN.x=posB.x-offNP.x*1.5;\nposN.y=posB.y-offNP.y*1.5;\nvec2 posP;\nposP.x=posB.x+offNP.x*1.5;\nposP.y=posB.y+offNP.y*1.5;\nfloat subpixD=((-2.0)*subpixC)+3.0;\nfloat lumaEndN=FxaaLuma(texture2D(textureSampler,posN,0.0));\nfloat subpixE=subpixC*subpixC;\nfloat lumaEndP=FxaaLuma(texture2D(textureSampler,posP,0.0));\nif (!pairN)\n{\nlumaNN=lumaSS;\n}\nfloat gradientScaled=gradient*1.0/4.0;\nfloat lumaMM=lumaM-lumaNN*0.5;\nfloat subpixF=subpixD*subpixE;\nbool lumaMLTZero=lumaMM<0.0;\nlumaEndN-=lumaNN*0.5;\nlumaEndP-=lumaNN*0.5;\nbool doneN=abs(lumaEndN)>=gradientScaled;\nbool doneP=abs(lumaEndP)>=gradientScaled;\nif (!doneN)\n{\nposN.x-=offNP.x*3.0;\n}\nif (!doneN)\n{\nposN.y-=offNP.y*3.0;\n}\nbool doneNP=(!doneN) || (!doneP);\nif (!doneP)\n{\nposP.x+=offNP.x*3.0;\n}\nif (!doneP)\n{\nposP.y+=offNP.y*3.0;\n}\nif (doneNP)\n{\nif (!doneN) lumaEndN=FxaaLuma(texture2D(textureSampler,posN.xy,0.0));\nif (!doneP) lumaEndP=FxaaLuma(texture2D(textureSampler,posP.xy,0.0));\nif (!doneN) lumaEndN=lumaEndN-lumaNN*0.5;\nif (!doneP) lumaEndP=lumaEndP-lumaNN*0.5;\ndoneN=abs(lumaEndN)>=gradientScaled;\ndoneP=abs(lumaEndP)>=gradientScaled;\nif (!doneN) posN.x-=offNP.x*12.0;\nif (!doneN) posN.y-=offNP.y*12.0;\ndoneNP=(!doneN) || (!doneP);\nif (!doneP) posP.x+=offNP.x*12.0;\nif (!doneP) posP.y+=offNP.y*12.0;\n}\nfloat dstN=posM.x-posN.x;\nfloat dstP=posP.x-posM.x;\nif (!horzSpan)\n{\ndstN=posM.y-posN.y;\n}\nif (!horzSpan)\n{\ndstP=posP.y-posM.y;\n}\nbool goodSpanN=(lumaEndN<0.0) != lumaMLTZero;\nfloat spanLength=(dstP+dstN);\nbool goodSpanP=(lumaEndP<0.0) != lumaMLTZero;\nfloat spanLengthRcp=1.0/spanLength;\nbool directionN=dstN-1?"#define MALI 1\n":null},t._Parse=function(e,i,r,n){return b.a.Parse((function(){return new t(e.name,e.options,i,e.renderTargetSamplingMode,r.getEngine(),e.reusable)}),e,r,n)},t}(T);y.a.RegisteredTypes["BABYLON.FxaaPostProcess"]=A;var M=function(){function e(){}return e.CreateScreenshot=function(t,i,r,n,o){void 0===o&&(o="image/png");var a=e._getScreenshotSize(t,i,r),h=a.height,l=a.width;if(h&&l){s.b._ScreenshotCanvas||(s.b._ScreenshotCanvas=document.createElement("canvas")),s.b._ScreenshotCanvas.width=l,s.b._ScreenshotCanvas.height=h;var c=s.b._ScreenshotCanvas.getContext("2d"),f=t.getRenderWidth()/t.getRenderHeight(),d=l,p=d/f;p>h&&(d=(p=h)*f);var _=Math.max(0,l-d)/2,g=Math.max(0,h-p)/2,m=t.getRenderingCanvas();c&&m&&c.drawImage(m,_,g,d,p),s.b.EncodeScreenshotCanvasData(n,o)}else u.a.Error("Invalid 'size' parameter !")},e.CreateScreenshotAsync=function(t,i,r,n){return void 0===n&&(n="image/png"),new Promise((function(o,s){e.CreateScreenshot(t,i,r,(function(e){void 0!==e?o(e):s(new Error("Data is undefined"))}),n)}))},e.CreateScreenshotUsingRenderTarget=function(t,i,n,o,a,h,l,c,f,d){void 0===a&&(a="image/png"),void 0===h&&(h=1),void 0===l&&(l=!1),void 0===f&&(f=!1),void 0===d&&(d=!1);var p=e._getScreenshotSize(t,i,n),g=p.height,m=p.width,v={width:m,height:g};if(g&&m){var b=t.getRenderingCanvas();if(b){var y={width:b.width,height:b.height};t.setSize(m,g);var T=i.getScene(),x=null,E=T.activeCameras;(T.activeCamera!==i||T.activeCameras&&T.activeCameras.length)&&(x=T.activeCamera,T.activeCamera=i),T.render();var M=new _("screenShot",v,T,!1,!1,0,!1,r.a.NEAREST_SAMPLINGMODE,void 0,d);M.renderList=null,M.samples=h,M.renderSprites=f,M.onAfterRenderObservable.add((function(){s.b.DumpFramebuffer(m,g,t,o,a,c)}));var S=function(){T.incrementRenderId(),T.resetCachedMaterial(),M.render(!0),M.dispose(),x&&(T.activeCamera=x),T.activeCameras=E,t.setSize(y.width,y.height),i.getProjectionMatrix(!0)};if(l){var O=new A("antialiasing",1,T.activeCamera);M.addPostProcess(O),O.getEffect().isReady()?S():O.getEffect().onCompiled=function(){S()}}else S()}else u.a.Error("No rendering canvas found !")}else u.a.Error("Invalid 'size' parameter !")},e.CreateScreenshotUsingRenderTargetAsync=function(t,i,r,n,o,s,a,h){return void 0===n&&(n="image/png"),void 0===o&&(o=1),void 0===s&&(s=!1),void 0===h&&(h=!1),new Promise((function(l,c){e.CreateScreenshotUsingRenderTarget(t,i,r,(function(e){void 0!==e?l(e):c(new Error("Data is undefined"))}),n,o,s,a,h)}))},e._getScreenshotSize=function(e,t,i){var r=0,n=0;if("object"==typeof i){var o=i.precision?Math.abs(i.precision):1;i.width&&i.height?(r=i.height*o,n=i.width*o):i.width&&!i.height?(n=i.width*o,r=Math.round(n/e.getAspectRatio(t))):i.height&&!i.width?(r=i.height*o,n=Math.round(r*e.getAspectRatio(t))):(n=Math.round(e.getRenderWidth()*o),r=Math.round(n/e.getAspectRatio(t)))}else isNaN(i)||(r=i,n=i);return n&&(n=Math.floor(n)),r&&(r=Math.floor(r)),{height:0|r,width:0|n}},e}();s.b.CreateScreenshot=M.CreateScreenshot,s.b.CreateScreenshotAsync=M.CreateScreenshotAsync,s.b.CreateScreenshotUsingRenderTarget=M.CreateScreenshotUsingRenderTarget,s.b.CreateScreenshotUsingRenderTargetAsync=M.CreateScreenshotUsingRenderTargetAsync},function(e,t,i){"use strict";i.r(t),i.d(t,"PointerDragBehavior",(function(){return p}));var r=i(13),n=i(28),o=i(4),s=i(0),a=i(10),h=i(31),l=i(43),c=i(67),u=i(21),f=function(){function e(e,t,i){void 0===i&&(i=Number.MAX_VALUE),this.origin=e,this.direction=t,this.length=i}return e.prototype.intersectsBoxMinMax=function(t,i,r){void 0===r&&(r=0);var n,o,s,a,h=e._TmpVector3[0].copyFromFloats(t.x-r,t.y-r,t.z-r),l=e._TmpVector3[1].copyFromFloats(i.x+r,i.y+r,i.z+r),c=0,u=Number.MAX_VALUE;if(Math.abs(this.direction.x)<1e-7){if(this.origin.xl.x)return!1}else if(n=1/this.direction.x,o=(h.x-this.origin.x)*n,(s=(l.x-this.origin.x)*n)===-1/0&&(s=1/0),o>s&&(a=o,o=s,s=a),(c=Math.max(o,c))>(u=Math.min(s,u)))return!1;if(Math.abs(this.direction.y)<1e-7){if(this.origin.yl.y)return!1}else if(n=1/this.direction.y,o=(h.y-this.origin.y)*n,(s=(l.y-this.origin.y)*n)===-1/0&&(s=1/0),o>s&&(a=o,o=s,s=a),(c=Math.max(o,c))>(u=Math.min(s,u)))return!1;if(Math.abs(this.direction.z)<1e-7){if(this.origin.zl.z)return!1}else if(n=1/this.direction.z,o=(h.z-this.origin.z)*n,(s=(l.z-this.origin.z)*n)===-1/0&&(s=1/0),o>s&&(a=o,o=s,s=a),(c=Math.max(o,c))>(u=Math.min(s,u)))return!1;return!0},e.prototype.intersectsBox=function(e,t){return void 0===t&&(t=0),this.intersectsBoxMinMax(e.minimum,e.maximum,t)},e.prototype.intersectsSphere=function(e,t){void 0===t&&(t=0);var i=e.center.x-this.origin.x,r=e.center.y-this.origin.y,n=e.center.z-this.origin.z,o=i*i+r*r+n*n,s=e.radius+t,a=s*s;if(o<=a)return!0;var h=i*this.direction.x+r*this.direction.y+n*this.direction.z;return!(h<0)&&o-h*h<=a},e.prototype.intersectsTriangle=function(t,i,r){var n=e._TmpVector3[0],o=e._TmpVector3[1],a=e._TmpVector3[2],h=e._TmpVector3[3],l=e._TmpVector3[4];i.subtractToRef(t,n),r.subtractToRef(t,o),s.e.CrossToRef(this.direction,o,a);var u=s.e.Dot(n,a);if(0===u)return null;var f=1/u;this.origin.subtractToRef(t,h);var d=s.e.Dot(h,a)*f;if(d<0||d>1)return null;s.e.CrossToRef(h,n,l);var p=s.e.Dot(this.direction,l)*f;if(p<0||d+p>1)return null;var _=s.e.Dot(o,l)*f;return _>this.length?null:new c.a(1-d-p,d,_)},e.prototype.intersectsPlane=function(e){var t,i=s.e.Dot(e.normal,this.direction);if(Math.abs(i)<9.99999997475243e-7)return null;var r=s.e.Dot(e.normal,this.origin);return(t=(-e.d-r)/i)<0?t<-9.99999997475243e-7?null:0:t},e.prototype.intersectsAxis=function(e,t){switch(void 0===t&&(t=0),e){case"y":return(i=(this.origin.y-t)/this.direction.y)>0?null:new s.e(this.origin.x+this.direction.x*-i,t,this.origin.z+this.direction.z*-i);case"x":return(i=(this.origin.x-t)/this.direction.x)>0?null:new s.e(t,this.origin.y+this.direction.y*-i,this.origin.z+this.direction.z*-i);case"z":var i;return(i=(this.origin.z-t)/this.direction.z)>0?null:new s.e(this.origin.x+this.direction.x*-i,this.origin.y+this.direction.y*-i,t);default:return null}},e.prototype.intersectsMesh=function(t,i){var r=s.c.Matrix[0];return t.getWorldMatrix().invertToRef(r),this._tmpRay?e.TransformToRef(this,r,this._tmpRay):this._tmpRay=e.Transform(this,r),t.intersects(this._tmpRay,i)},e.prototype.intersectsMeshes=function(e,t,i){i?i.length=0:i=[];for(var r=0;rt.distance?1:0},e.prototype.intersectionSegment=function(t,i,r){var n=this.origin,o=s.c.Vector3[0],a=s.c.Vector3[1],h=s.c.Vector3[2],l=s.c.Vector3[3];i.subtractToRef(t,o),this.direction.scaleToRef(e.rayl,h),n.addToRef(h,a),t.subtractToRef(n,l);var c,u,f,d,p=s.e.Dot(o,o),_=s.e.Dot(o,h),g=s.e.Dot(h,h),m=s.e.Dot(o,l),v=s.e.Dot(h,l),b=p*g-_*_,y=b,T=b;by&&(u=y,d=v+_,T=g)),d<0?(d=0,-m<0?u=0:-m>p?u=y:(u=-m,y=p)):d>T&&(d=T,-m+_<0?u=0:-m+_>p?u=y:(u=-m+_,y=p)),c=Math.abs(u)0&&f<=this.length&&A.lengthSquared()=e.distance?null:l:null},n.Scene.prototype._internalPick=function(e,t,i,r,n){if(!l.a)return null;for(var o=null,a=0;a1)throw"Multiple drag modes specified in dragBehavior options. Only one expected"}return Object.defineProperty(e.prototype,"options",{get:function(){return this._options},set:function(e){this._options=e},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"name",{get:function(){return"PointerDrag"},enumerable:!1,configurable:!0}),e.prototype.init=function(){},e.prototype.attach=function(t,i){var o=this;this._scene=t.getScene(),this.attachedNode=t,e._planeScene||(this._debugMode?e._planeScene=this._scene:(e._planeScene=new n.Scene(this._scene.getEngine(),{virtual:!0}),e._planeScene.detachControl(),this._scene.onDisposeObservable.addOnce((function(){e._planeScene.dispose(),e._planeScene=null})))),this._dragPlane=r.Mesh.CreatePlane("pointerDragPlane",this._debugMode?1:1e4,e._planeScene,!1,r.Mesh.DOUBLESIDE),this.lastDragPosition=new s.e(0,0,0);var h=i||function(e){return o.attachedNode==e||e.isDescendantOf(o.attachedNode)};this._pointerObserver=this._scene.onPointerObservable.add((function(t,i){if(o.enabled)if(t.type==a.a.POINTERDOWN)o.startAndReleaseDragOnPointerEvents&&!o.dragging&&t.pickInfo&&t.pickInfo.hit&&t.pickInfo.pickedMesh&&t.pickInfo.pickedPoint&&t.pickInfo.ray&&h(t.pickInfo.pickedMesh)&&o._startDrag(t.event.pointerId,t.pickInfo.ray,t.pickInfo.pickedPoint);else if(t.type==a.a.POINTERUP)o.startAndReleaseDragOnPointerEvents&&o.currentDraggingPointerID==t.event.pointerId&&o.releaseDrag();else if(t.type==a.a.POINTERMOVE){var r=t.event.pointerId;if(o.currentDraggingPointerID===e._AnyMouseID&&r!==e._AnyMouseID){var n=t.event;("mouse"===n.pointerType||!o._scene.getEngine().hostInformation.isMobile&&n instanceof MouseEvent)&&(o._lastPointerRay[o.currentDraggingPointerID]&&(o._lastPointerRay[r]=o._lastPointerRay[o.currentDraggingPointerID],delete o._lastPointerRay[o.currentDraggingPointerID]),o.currentDraggingPointerID=r)}o._lastPointerRay[r]||(o._lastPointerRay[r]=new f(new s.e,new s.e)),t.pickInfo&&t.pickInfo.ray&&(o._lastPointerRay[r].origin.copyFrom(t.pickInfo.ray.origin),o._lastPointerRay[r].direction.copyFrom(t.pickInfo.ray.direction),o.currentDraggingPointerID==r&&o.dragging&&o._moveDrag(t.pickInfo.ray))}})),this._beforeRenderObserver=this._scene.onBeforeRenderObservable.add((function(){o._moving&&o.moveAttached&&(d._RemoveAndStorePivotPoint(o.attachedNode),o._targetPosition.subtractToRef(o.attachedNode.absolutePosition,o._tmpVector),o._tmpVector.scaleInPlace(o.dragDeltaRatio),o.attachedNode.getAbsolutePosition().addToRef(o._tmpVector,o._tmpVector),o.validateDrag(o._tmpVector)&&o.attachedNode.setAbsolutePosition(o._tmpVector),d._RestorePivotPoint(o.attachedNode))}))},e.prototype.releaseDrag=function(){if(this.dragging&&(this.dragging=!1,this.onDragEndObservable.notifyObservers({dragPlanePoint:this.lastDragPosition,pointerId:this.currentDraggingPointerID})),this.currentDraggingPointerID=-1,this._moving=!1,this.detachCameraControls&&this._attachedToElement&&this._scene.activeCamera&&!this._scene.activeCamera.leftCamera){if("ArcRotateCamera"===this._scene.activeCamera.getClassName()){var e=this._scene.activeCamera;e.attachControl(!e.inputs||e.inputs.noPreventDefault,e._useCtrlForPanning,e._panningMouseButton)}else this._scene.activeCamera.attachControl(!this._scene.activeCamera.inputs||this._scene.activeCamera.inputs.noPreventDefault);this._attachedToElement=!1}},e.prototype.startDrag=function(t,i,r){void 0===t&&(t=e._AnyMouseID),this._startDrag(t,i,r);var n=this._lastPointerRay[t];t===e._AnyMouseID&&(n=this._lastPointerRay[Object.keys(this._lastPointerRay)[0]]),n&&this._moveDrag(n)},e.prototype._startDrag=function(e,t,i){if(this._scene.activeCamera&&!this.dragging&&this.attachedNode){d._RemoveAndStorePivotPoint(this.attachedNode),t?(this._startDragRay.direction.copyFrom(t.direction),this._startDragRay.origin.copyFrom(t.origin)):(this._startDragRay.origin.copyFrom(this._scene.activeCamera.position),this.attachedNode.getWorldMatrix().getTranslationToRef(this._tmpVector),this._tmpVector.subtractToRef(this._scene.activeCamera.position,this._startDragRay.direction)),this._updateDragPlanePosition(this._startDragRay,i||this._tmpVector);var r=this._pickWithRayOnDragPlane(this._startDragRay);r&&(this.dragging=!0,this.currentDraggingPointerID=e,this.lastDragPosition.copyFrom(r),this.onDragStartObservable.notifyObservers({dragPlanePoint:r,pointerId:this.currentDraggingPointerID}),this._targetPosition.copyFrom(this.attachedNode.absolutePosition),this.detachCameraControls&&this._scene.activeCamera&&this._scene.activeCamera.inputs&&!this._scene.activeCamera.leftCamera&&(this._scene.activeCamera.inputs.attachedToElement?(this._scene.activeCamera.detachControl(),this._attachedToElement=!0):this._attachedToElement=!1)),d._RestorePivotPoint(this.attachedNode)}},e.prototype._moveDrag=function(e){this._moving=!0;var t=this._pickWithRayOnDragPlane(e);if(t){this.updateDragPlane&&this._updateDragPlanePosition(e,t);var i=0;this._options.dragAxis?(this.useObjectOrientationForDragging?s.e.TransformCoordinatesToRef(this._options.dragAxis,this.attachedNode.getWorldMatrix().getRotationMatrix(),this._worldDragAxis):this._worldDragAxis.copyFrom(this._options.dragAxis),t.subtractToRef(this.lastDragPosition,this._tmpVector),i=s.e.Dot(this._tmpVector,this._worldDragAxis),this._worldDragAxis.scaleToRef(i,this._dragDelta)):(i=this._dragDelta.length(),t.subtractToRef(this.lastDragPosition,this._dragDelta)),this._targetPosition.addInPlace(this._dragDelta),this.onDragObservable.notifyObservers({dragDistance:i,delta:this._dragDelta,dragPlanePoint:t,dragPlaneNormal:this._dragPlane.forward,pointerId:this.currentDraggingPointerID}),this.lastDragPosition.copyFrom(t)}},e.prototype._pickWithRayOnDragPlane=function(t){var i=this;if(!t)return null;var r=Math.acos(s.e.Dot(this._dragPlane.forward,t.direction));if(r>Math.PI/2&&(r=Math.PI-r),this.maxDragAngle>0&&r>this.maxDragAngle){if(this._useAlternatePickedPointAboveMaxDragAngle){this._tmpVector.copyFrom(t.direction),this.attachedNode.absolutePosition.subtractToRef(t.origin,this._alternatePickedPoint),this._alternatePickedPoint.normalize(),this._alternatePickedPoint.scaleInPlace(this._useAlternatePickedPointAboveMaxDragAngleDragSpeed*s.e.Dot(this._alternatePickedPoint,this._tmpVector)),this._tmpVector.addInPlace(this._alternatePickedPoint);var n=s.e.Dot(this._dragPlane.forward,this._tmpVector);return this._dragPlane.forward.scaleToRef(-n,this._alternatePickedPoint),this._alternatePickedPoint.addInPlace(this._tmpVector),this._alternatePickedPoint.addInPlace(this.attachedNode.absolutePosition),this._alternatePickedPoint}return null}var o=e._planeScene.pickWithRay(t,(function(e){return e==i._dragPlane}));return o&&o.hit&&o.pickedMesh&&o.pickedPoint?o.pickedPoint:null},e.prototype._updateDragPlanePosition=function(e,t){this._pointA.copyFrom(t),this._options.dragAxis?(this.useObjectOrientationForDragging?s.e.TransformCoordinatesToRef(this._options.dragAxis,this.attachedNode.getWorldMatrix().getRotationMatrix(),this._localAxis):this._localAxis.copyFrom(this._options.dragAxis),e.origin.subtractToRef(this._pointA,this._pointC),this._pointC.normalize(),Math.abs(s.e.Dot(this._localAxis,this._pointC))>.999?Math.abs(s.e.Dot(s.e.UpReadOnly,this._pointC))>.999?this._lookAt.copyFrom(s.e.Right()):this._lookAt.copyFrom(s.e.UpReadOnly):(s.e.CrossToRef(this._localAxis,this._pointC,this._lookAt),s.e.CrossToRef(this._localAxis,this._lookAt,this._lookAt),this._lookAt.normalize()),this._dragPlane.position.copyFrom(this._pointA),this._pointA.addToRef(this._lookAt,this._lookAt),this._dragPlane.lookAt(this._lookAt)):this._options.dragPlaneNormal?(this.useObjectOrientationForDragging?s.e.TransformCoordinatesToRef(this._options.dragPlaneNormal,this.attachedNode.getWorldMatrix().getRotationMatrix(),this._localAxis):this._localAxis.copyFrom(this._options.dragPlaneNormal),this._dragPlane.position.copyFrom(this._pointA),this._pointA.addToRef(this._localAxis,this._lookAt),this._dragPlane.lookAt(this._lookAt)):(this._dragPlane.position.copyFrom(this._pointA),this._dragPlane.lookAt(e.origin)),this._dragPlane.position.copyFrom(this.attachedNode.absolutePosition),this._dragPlane.computeWorldMatrix(!0)},e.prototype.detach=function(){this._pointerObserver&&this._scene.onPointerObservable.remove(this._pointerObserver),this._beforeRenderObserver&&this._scene.onBeforeRenderObservable.remove(this._beforeRenderObserver),this.releaseDrag()},e._AnyMouseID=-2,e}())}]); //# sourceMappingURL=babyplots.js.map \ No newline at end of file diff --git a/dist/babyplots.js.LICENSE.txt b/dist/babyplots.js.LICENSE.txt index 333fc82..b535eb1 100644 --- a/dist/babyplots.js.LICENSE.txt +++ b/dist/babyplots.js.LICENSE.txt @@ -96,18 +96,18 @@ */ /*! ***************************************************************************** -Copyright (c) Microsoft Corporation. All rights reserved. -Licensed under the Apache License, Version 2.0 (the "License"); you may not use -this file except in compliance with the License. You may obtain a copy of the -License at http://www.apache.org/licenses/LICENSE-2.0 +Copyright (c) Microsoft Corporation. -THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY -KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED -WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, -MERCHANTABLITY OR NON-INFRINGEMENT. +Permission to use, copy, modify, and/or distribute this software for any +purpose with or without fee is hereby granted. -See the Apache Version 2.0 License for specific language governing permissions -and limitations under the License. +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH +REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY +AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, +INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM +LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR +OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR +PERFORMANCE OF THIS SOFTWARE. ***************************************************************************** */ /** diff --git a/dist/babyplots.js.map b/dist/babyplots.js.map index 73b666a..03e9e24 100644 --- a/dist/babyplots.js.map +++ b/dist/babyplots.js.map @@ -1 +1 @@ -{"version":3,"sources":["webpack://Baby/webpack/bootstrap","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.vector.js","webpack://Baby/./node_modules/tslib/tslib.es6.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/buffer.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/decorators.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/observable.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/math2D.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/control.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/effect.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.color.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/devTools.js","webpack://Baby/./node_modules/@babylonjs/core/Events/pointerEvents.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/typeStore.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/mesh.vertexData.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/logger.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/promise.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/tools.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/valueAndUnit.js","webpack://Baby/./node_modules/@babylonjs/core/Loading/sceneLoaderFlags.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/geometry.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/meshLODLevel.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/mesh.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.constants.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.scalar.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/Textures/baseTexture.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/Textures/texture.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/materialHelper.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/camera.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/andOrNotEvaluator.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/tags.js","webpack://Baby/./node_modules/@babylonjs/core/sceneComponent.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/engineStore.js","webpack://Baby/./node_modules/@babylonjs/core/States/depthCullingState.js","webpack://Baby/./node_modules/@babylonjs/core/States/stencilState.js","webpack://Baby/./node_modules/@babylonjs/core/States/alphaCullingState.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/WebGL/webGL2ShaderProcessors.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/WebGL/webGLPipelineContext.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/thinEngine.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/domManagement.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/performanceMonitor.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Extensions/engine.alpha.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/engine.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/material.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/smartArray.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/measure.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/arrayTools.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/stringDictionary.js","webpack://Baby/./node_modules/@babylonjs/core/abstractScene.js","webpack://Baby/./node_modules/@babylonjs/core/Actions/actionEvent.js","webpack://Baby/./node_modules/@babylonjs/core/Actions/abstractActionManager.js","webpack://Baby/./node_modules/@babylonjs/core/Inputs/scene.inputManager.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/uniqueIdGenerator.js","webpack://Baby/./node_modules/@babylonjs/core/scene.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/container.js","webpack://Baby/./node_modules/@babylonjs/core/Culling/boundingBox.js","webpack://Baby/./node_modules/@babylonjs/core/Culling/boundingInfo.js","webpack://Baby/./node_modules/@babylonjs/core/node.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.axis.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/filesInputStore.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/retryStrategy.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/baseError.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/fileTools.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/precisionDate.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/Textures/internalTexture.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/transformNode.js","webpack://Baby/./node_modules/axios/lib/utils.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/stringTools.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/subMesh.js","webpack://Baby/./node_modules/@babylonjs/core/Collisions/meshCollisionData.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/abstractMesh.js","webpack://Baby/./node_modules/@babylonjs/core/Lights/light.js","webpack://Baby/./node_modules/@babylonjs/core/Events/keyboardEvents.js","webpack://Baby/./node_modules/@babylonjs/core/Events/clipboardEvents.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.size.js","webpack://Baby/./node_modules/@babylonjs/core/Collisions/pickingInfo.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/pushMaterial.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/materialFlags.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/defaultFragmentDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/defaultUboDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/lightFragmentDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/lightUboDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/lightsFragmentFunctions.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/shadowsFragmentFunctions.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/fresnelFunction.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/reflectionFunction.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/imageProcessingDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/imageProcessingFunctions.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/bumpFragmentFunctions.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/logDepthDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/fogFragmentDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/bumpFragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/depthPrePass.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/lightFragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/logDepthFragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/fogFragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/default.fragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/defaultVertexDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/bumpVertexDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/fogVertexDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/morphTargetsVertexGlobalDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/morphTargetsVertexDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/morphTargetsVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/bumpVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/fogVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/shadowsVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/pointCloudVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/logDepthVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/default.vertex.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/standardMaterial.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.plane.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.frustum.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/WebGL/webGLDataBuffer.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/dataBuffer.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.viewport.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/canvasGenerator.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/perfCounter.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/colorCurves.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/imageProcessingConfiguration.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.vertexFormat.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/deepCopier.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.functions.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Extensions/engine.uniformBuffer.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/uniformBuffer.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/webRequest.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/instantiationTools.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/multiMaterial.js","webpack://Baby/./babyplots.ts","webpack://Baby/./node_modules/@babylonjs/core/Misc/timingTools.js","webpack://Baby/./node_modules/@babylonjs/core/Culling/boundingSphere.js","webpack://Baby/./node_modules/@babylonjs/core/PostProcesses/postProcessManager.js","webpack://Baby/./node_modules/@babylonjs/core/Collisions/intersectionInfo.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/shaderCodeNode.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/shaderCodeCursor.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/shaderCodeConditionNode.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/shaderCodeTestNode.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/Expressions/shaderDefineExpression.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/Expressions/Operators/shaderDefineIsDefinedOperator.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/Expressions/Operators/shaderDefineOrOperator.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/Expressions/Operators/shaderDefineAndOperator.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/Expressions/Operators/shaderDefineArithmeticOperator.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/shaderProcessor.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.path.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/Textures/renderTargetCreationOptions.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/guid.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/materialDefines.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/effectFallbacks.js","webpack://Baby/./node_modules/@babylonjs/core/Rendering/renderingGroup.js","webpack://Baby/./node_modules/@babylonjs/core/Rendering/renderingManager.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/helperFunctions.js","webpack://Baby/./node_modules/chroma-js/chroma.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/Builders/planeBuilder.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Extensions/engine.dynamicTexture.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/Textures/dynamicTexture.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/Builders/boxBuilder.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/clipPlaneFragmentDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/clipPlaneFragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/bonesDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/instancesDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/clipPlaneVertexDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/instancesVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/bonesVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/clipPlaneVertex.js","webpack://Baby/./node_modules/axios/lib/helpers/bind.js","webpack://Baby/./node_modules/axios/lib/helpers/buildURL.js","webpack://Baby/./node_modules/axios/lib/cancel/isCancel.js","webpack://Baby/./node_modules/axios/lib/defaults.js","webpack://Baby/./node_modules/axios/lib/adapters/xhr.js","webpack://Baby/./node_modules/axios/lib/core/createError.js","webpack://Baby/./node_modules/axios/lib/core/mergeConfig.js","webpack://Baby/./node_modules/axios/lib/cancel/Cancel.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/rectangle.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/textBlock.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/image.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/button.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/stackPanel.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/checkbox.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/inputText.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/grid.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/colorpicker.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/ellipse.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/inputPassword.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/line.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/multiLinePoint.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/multiLine.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/radioButton.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/sliders/baseSlider.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/sliders/slider.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/selector.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/scrollViewers/scrollViewerWindow.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/sliders/scrollBar.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/sliders/imageScrollBar.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/scrollViewers/scrollViewer.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/virtualKeyboard.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/displayGrid.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/sliders/imageBasedSlider.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/statics.js","webpack://Baby/./node_modules/@babylonjs/core/Layers/layerSceneComponent.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/layer.fragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/layer.vertex.js","webpack://Baby/./node_modules/@babylonjs/core/Layers/layer.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/style.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/constants.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/advancedDynamicTexture.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/instancedMesh.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/shaderMaterial.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/color.fragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/color.vertex.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/linesMesh.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/Builders/linesBuilder.js","webpack://Baby/./node_modules/@babylonjs/core/Lights/hemisphericLight.js","webpack://Baby/./node_modules/downloadjs/download.js","webpack://Baby/./node_modules/axios/index.js","webpack://Baby/./node_modules/axios/lib/axios.js","webpack://Baby/./node_modules/axios/lib/core/Axios.js","webpack://Baby/./node_modules/axios/lib/core/InterceptorManager.js","webpack://Baby/./node_modules/axios/lib/core/dispatchRequest.js","webpack://Baby/./node_modules/axios/lib/core/transformData.js","webpack://Baby/./node_modules/process/browser.js","webpack://Baby/./node_modules/axios/lib/helpers/normalizeHeaderName.js","webpack://Baby/./node_modules/axios/lib/core/settle.js","webpack://Baby/./node_modules/axios/lib/core/enhanceError.js","webpack://Baby/./node_modules/axios/lib/helpers/cookies.js","webpack://Baby/./node_modules/axios/lib/core/buildFullPath.js","webpack://Baby/./node_modules/axios/lib/helpers/isAbsoluteURL.js","webpack://Baby/./node_modules/axios/lib/helpers/combineURLs.js","webpack://Baby/./node_modules/axios/lib/helpers/parseHeaders.js","webpack://Baby/./node_modules/axios/lib/helpers/isURLSameOrigin.js","webpack://Baby/./node_modules/axios/lib/cancel/CancelToken.js","webpack://Baby/./node_modules/axios/lib/helpers/spread.js","webpack://Baby/./Label.ts","webpack://Baby/./node_modules/@babylonjs/core/Meshes/Builders/cylinderBuilder.js","webpack://Baby/./Axes.ts","webpack://Baby/./ImgStack.ts","webpack://Baby/./PointCloud.ts","webpack://Baby/./node_modules/@babylonjs/core/Meshes/Builders/sphereBuilder.js","webpack://Baby/./Surface.ts","webpack://Baby/./HeatMap.ts","webpack://Baby/./node_modules/@babylonjs/core/Animations/animationKey.js","webpack://Baby/./node_modules/@babylonjs/core/Behaviors/Cameras/autoRotationBehavior.js","webpack://Baby/./node_modules/@babylonjs/core/Animations/easing.js","webpack://Baby/./node_modules/@babylonjs/core/Animations/animationRange.js","webpack://Baby/./node_modules/@babylonjs/core/Animations/animation.js","webpack://Baby/./node_modules/@babylonjs/core/Behaviors/Cameras/bouncingBehavior.js","webpack://Baby/./node_modules/@babylonjs/core/Behaviors/Cameras/framingBehavior.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/targetCamera.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/cameraInputsManager.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/Inputs/arcRotateCameraPointersInput.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/Inputs/BaseCameraPointersInput.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/Inputs/arcRotateCameraKeyboardMoveInput.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/Inputs/arcRotateCameraMouseWheelInput.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/arcRotateCameraInputsManager.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/arcRotateCamera.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/rng.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/regex.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/stringify.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/validate.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/v1.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/parse.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/v35.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/md5.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/v3.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/v4.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/sha1.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/v5.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/nil.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/version.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Extensions/engine.renderTarget.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Extensions/engine.renderTargetCube.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/Textures/renderTargetTexture.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/postprocess.vertex.js","webpack://Baby/./node_modules/@babylonjs/core/PostProcesses/postProcess.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/fxaa.fragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/fxaa.vertex.js","webpack://Baby/./node_modules/@babylonjs/core/PostProcesses/fxaaPostProcess.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/screenshotTools.js","webpack://Baby/./node_modules/@babylonjs/core/Culling/ray.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/pivotTools.js","webpack://Baby/./node_modules/@babylonjs/core/Behaviors/Meshes/pointerDragBehavior.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/Builders/discBuilder.js","webpack://Baby/./node_modules/@babylonjs/core/Particles/solidParticle.js","webpack://Baby/./node_modules/@babylonjs/core/Particles/solidParticleSystem.js"],"names":["installedModules","__webpack_require__","moduleId","exports","module","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","Vector2","x","y","this","toString","getClassName","getHashCode","hash","toArray","array","index","asArray","result","Array","copyFrom","source","copyFromFloats","set","add","otherVector","addToRef","addInPlace","addVector3","subtract","subtractToRef","subtractInPlace","multiplyInPlace","multiply","multiplyToRef","multiplyByFloats","divide","divideToRef","divideInPlace","negate","negateInPlace","negateToRef","scaleInPlace","scale","scaleToRef","scaleAndAddToRef","equals","equalsWithEpsilon","epsilon","WithinEpsilon","floor","Math","fract","length","sqrt","lengthSquared","normalize","len","clone","Zero","One","FromArray","offset","FromArrayToRef","CatmullRom","value1","value2","value3","value4","amount","squared","cubed","Clamp","min","max","Hermite","tangent1","tangent2","part1","part2","part3","part4","Lerp","start","end","Dot","left","right","Normalize","vector","newVector","Minimize","Maximize","Transform","transformation","TransformToRef","PointInTriangle","p0","p1","p2","a","sign","Distance","DistanceSquared","Center","center","DistanceOfPointFromSegment","segA","segB","l2","v","proj","Vector3","z","toQuaternion","Quaternion","RotationYawPitchRoll","addInPlaceFromFloats","subtractFromFloatsToRef","subtractFromFloats","equalsToFloats","minimizeInPlace","other","minimizeInPlaceFromFloats","maximizeInPlace","maximizeInPlaceFromFloats","isNonUniformWithinEpsilon","absX","abs","absY","absZ","configurable","normalizeFromLength","reorderInPlace","order","_this","toLowerCase","MathTmp","forEach","val","rotateByQuaternionToRef","quaternion","toRotationMatrix","Matrix","TransformCoordinatesToRef","rotateByQuaternionAroundPointToRef","point","cross","Cross","normalizeToNew","normalized","normalizeToRef","reference","setAll","GetClipFactor","vector0","vector1","axis","size","d0","GetAngleBetweenVectors","normal","v0","v1","dot","CrossToRef","acos","FromFloatArray","FromFloatArrayToRef","FromFloatsToRef","Up","_UpReadOnly","_ZeroReadOnly","Down","Forward","Backward","Right","Left","TransformCoordinates","TransformCoordinatesFromFloatsToRef","rx","ry","rz","rw","TransformNormal","TransformNormalToRef","TransformNormalFromFloatsToRef","ClampToRef","CheckExtends","LerpToRef","NormalizeToRef","Project","world","transform","viewport","cw","width","ch","height","cx","cy","viewportMatrix","FromValuesToRef","matrix","_UnprojectFromInvertedMatrixToRef","num","UnprojectFromTransform","viewportWidth","viewportHeight","invert","Unproject","view","projection","UnprojectToRef","UnprojectFloatsToRef","sourceX","sourceY","sourceZ","screenSource","RotationFromAxis","axis1","axis2","axis3","rotation","RotationFromAxisToRef","ref","quat","RotationQuaternionFromAxisToRef","toEulerAnglesToRef","Vector4","w","undefined","toVector3","FromVector3","otherQuaternion","q1","conjugateToRef","conjugateInPlace","conjugate","inv","toEulerAngles","qz","qx","qy","qw","sqw","sqz","sqx","sqy","zAxisY","limit","atan2","PI","asin","FromQuaternionToRef","fromRotationMatrix","FromRotationMatrixToRef","FromRotationMatrix","data","m11","m12","m13","m21","m22","m23","m31","m32","m33","trace","AreClose","quat0","quat1","Inverse","q","InverseToRef","Identity","IsIdentity","RotationAxis","angle","RotationAxisToRef","sin","cos","FromEulerAngles","RotationYawPitchRollToRef","FromEulerAnglesToRef","FromEulerVector","vec","FromEulerVectorToRef","yaw","pitch","roll","halfRoll","halfPitch","halfYaw","sinRoll","cosRoll","sinPitch","cosPitch","sinYaw","cosYaw","RotationAlphaBetaGamma","alpha","beta","gamma","RotationAlphaBetaGammaToRef","halfGammaPlusAlpha","halfGammaMinusAlpha","halfBeta","RotationQuaternionFromAxis","rotMat","FromXYZAxesToRef","Slerp","SlerpToRef","num2","num3","num4","flag","num5","num6","_isIdentity","_isIdentityDirty","_isIdentity3x2","_isIdentity3x2Dirty","updateFlag","_m","Float32Array","_updateIdentityStatus","_markAsUpdated","_updateFlagSeed","isIdentity","isIdentityDirty","isIdentity3x2","isIdentity3x2Dirty","isIdentityAs3x2","determinant","m00","m01","m02","m03","m10","m20","m30","det_22_33","det_21_33","det_21_32","det_20_33","det_20_32","det_20_31","invertToRef","reset","resultM","otherM","addToSelf","IdentityToRef","cofact_00","cofact_01","cofact_02","cofact_03","det","detInv","det_12_33","det_11_33","det_11_32","det_10_33","det_10_32","det_10_31","det_12_23","det_11_23","det_11_22","det_10_23","det_10_22","det_10_21","cofact_10","cofact_11","cofact_12","cofact_13","cofact_20","cofact_21","cofact_22","cofact_23","cofact_30","cofact_31","cofact_32","cofact_33","addAtIndex","multiplyAtIndex","setTranslationFromFloats","addTranslationFromFloats","setTranslation","vector3","getTranslation","getTranslationToRef","removeRotationAndScaling","copyToArray","multiplyToArray","tm0","tm1","tm2","tm3","tm4","tm5","tm6","tm7","tm8","tm9","tm10","tm11","tm12","tm13","tm14","tm15","om0","om1","om2","om3","om4","om5","om6","om7","om8","om9","om10","om11","om12","om13","om14","om15","om","decompose","translation","sx","sy","sz","getRow","setRow","row","setRowFromFloats","transpose","Transpose","transposeToRef","TransposeToRef","toNormalMatrix","tmp","getRotationMatrix","getRotationMatrixToRef","toggleModelMatrixHandInPlace","toggleProjectionMatrixHandInPlace","FromFloat32ArrayToRefScaled","_identityReadOnly","initialM11","initialM12","initialM13","initialM14","initialM21","initialM22","initialM23","initialM24","initialM31","initialM32","initialM33","initialM34","initialM41","initialM42","initialM43","initialM44","FromValues","Compose","ComposeToRef","x2","y2","z2","xx","xy","xz","yy","yz","zz","wx","wy","wz","identity","zero","RotationX","RotationXToRef","Invert","RotationY","RotationYToRef","RotationZ","RotationZToRef","c1","RotationAlignToRef","from","to","k","Scaling","ScalingToRef","Translation","TranslationToRef","startValue","endValue","gradient","startM","endM","DecomposeLerp","DecomposeLerpToRef","startScale","startRotation","startTranslation","endScale","endRotation","endTranslation","resultScale","resultRotation","resultTranslation","LookAtLH","eye","target","up","LookAtLHToRef","xAxis","yAxis","zAxis","xSquareLength","ex","ey","ez","LookAtRH","LookAtRHToRef","OrthoLH","znear","zfar","OrthoLHToRef","b","OrthoOffCenterLH","bottom","top","OrthoOffCenterLHToRef","i0","i1","OrthoOffCenterRH","OrthoOffCenterRHToRef","PerspectiveLH","PerspectiveFovLH","fov","aspect","PerspectiveFovLHToRef","isVerticalFovFixed","f","tan","PerspectiveFovReverseLHToRef","PerspectiveFovRH","PerspectiveFovRHToRef","PerspectiveFovReverseRHToRef","PerspectiveFovWebVRToRef","rightHanded","rightHandedFactor","upTan","upDegrees","downTan","downDegrees","leftTan","leftDegrees","rightTan","rightDegrees","xScale","yScale","GetFinalMatrix","zmin","zmax","GetAsMatrix2x2","GetAsMatrix3x3","rm","mm","Reflection","plane","ReflectionToRef","temp","temp2","temp3","xaxis","yaxis","zaxis","zw","zx","yw","xw","BuildArray","TmpVectors","RegisteredTypes","extendStatics","setPrototypeOf","__proto__","__extends","__","constructor","__assign","assign","arguments","apply","__decorate","decorators","desc","getOwnPropertyDescriptor","Reflect","decorate","Buffer","engine","updatable","stride","postponeInternalCreation","instanced","useBytes","divisor","getScene","_engine","getEngine","_updatable","_instanced","_divisor","_data","byteStride","BYTES_PER_ELEMENT","createVertexBuffer","kind","byteOffset","VertexBuffer","isUpdatable","getData","getBuffer","_buffer","getStrideSize","updateDynamicVertexBuffer","createDynamicVertexBuffer","_rebuild","update","updateDirectly","vertexCount","dispose","_releaseBuffer","type","_ownsBuffer","_kind","data_1","FLOAT","Int8Array","BYTE","Uint8Array","UNSIGNED_BYTE","Int16Array","SHORT","Uint16Array","UNSIGNED_SHORT","Int32Array","INT","Uint32Array","UNSIGNED_INT","typeByteLength","GetTypeByteLength","_size","DeduceStride","_instanceDivisor","getKind","getOffset","getSize","getIsInstanced","getInstanceDivisor","count","callback","ForEach","UVKind","UV2Kind","UV3Kind","UV4Kind","UV5Kind","UV6Kind","NormalKind","PositionKind","ColorKind","MatricesIndicesKind","MatricesIndicesExtraKind","MatricesWeightsKind","MatricesWeightsExtraKind","TangentKind","Error","componentCount","componentType","componentIndex","dataView","ArrayBuffer","DataView","buffer","byteLength","componentByteLength","componentByteOffset","_GetFloatValue","getInt8","getUint8","getInt16","getUint16","getInt32","getUint32","getFloat32","__decoratorInitialStore","__mergedStore","_copySource","creationFunction","instanciate","destination","AddTagsTo","tags","classStore","getMergedStore","propertyDescriptor","sourceProperty","propertyType","isRenderTarget","classKey","store","currentTarget","currentKey","initialStore","parent_1","done","getPrototypeOf","generateSerializableMember","sourceName","propertyKey","getDirectStore","expandToProperty","targetKey","setCallback","generateExpandMember","serialize","serializeAsTexture","serializeAsColor3","serializeAsFresnelParameters","serializeAsVector3","serializeAsMeshReference","serializeAsColorCurves","serializeAsColor4","serializeAsQuaternion","SerializationHelper","AppendSerializedAnimations","animations","animationIndex","animation","push","Serialize","entity","serializationObject","GetTags","serializedProperties","targetPropertyName","id","Parse","scene","rootUrl","dest","_TextureParser","_FresnelParametersParser","getLastMeshByID","_ColorCurvesParser","_ImageProcessingConfigurationParser","getCameraByID","Clone","Instanciate","WarnImport","EventState","mask","skipNextObservers","initalize","Observer","scope","_willBeUnregistered","unregisterOnNextCall","Observable","MultiObserver","_observers","_observables","remove","Watch","observables","_i","observables_1","observer","onObserverAdded","_eventState","_onObserverAdded","insertFirst","unregisterOnFirstCall","unshift","addOnce","indexOf","_deferUnregister","removeCallback","setTimeout","_remove","splice","makeObserverTopPriority","makeObserverBottomPriority","notifyObservers","eventData","state","lastReturnValue","_a","obs","notifyObserversWithPromise","Promise","resolve","then","lastReturnedValue","notifyObserver","hasObservers","clear","slice","hasSpecificMask","_super","Vector2WithInfo","buttonIndex","Matrix2D","fromValues","l0","l1","l3","l4","l5","detDiv","det4","det5","r0","r1","r2","r3","r4","r5","transformCoordinates","RotationToRef","tx","ty","scaleX","scaleY","parentMatrix","_TempPreTranslationMatrix","_TempScalingMatrix","_TempRotationMatrix","_TempPostTranslationMatrix","_TempCompose0","_TempCompose1","_TempCompose2","Control","_alpha","_alphaSet","_zIndex","_currentMeasure","Empty","_fontFamily","_fontStyle","_fontWeight","_fontSize","UNITMODE_PIXEL","_width","UNITMODE_PERCENTAGE","_height","_color","_style","_horizontalAlignment","HORIZONTAL_ALIGNMENT_CENTER","_verticalAlignment","VERTICAL_ALIGNMENT_CENTER","_isDirty","_wasDirty","_tempParentMeasure","_prevCurrentMeasureTransformedIntoGlobalSpace","_cachedParentMeasure","_paddingLeft","_paddingRight","_paddingTop","_paddingBottom","_left","_top","_scaleX","_scaleY","_rotation","_transformCenterX","_transformCenterY","_transformMatrix","_invertTransformMatrix","_transformedPosition","_isMatrixDirty","_isVisible","_isHighlighted","_fontSet","_dummyVector2","_downCount","_enterCount","_doNotRender","_downPointerIds","_isEnabled","_disabledColor","_disabledColorItem","_rebuildLayout","_customData","_isClipped","_automaticSize","metadata","isHitTestVisible","isPointerBlocker","isFocusInvisible","clipChildren","clipContent","useBitmapCache","_shadowOffsetX","_shadowOffsetY","_shadowBlur","_shadowColor","hoverCursor","_linkOffsetX","_linkOffsetY","onWheelObservable","onPointerMoveObservable","onPointerOutObservable","onPointerDownObservable","onPointerUpObservable","onPointerClickObservable","onPointerEnterObservable","onDirtyObservable","onBeforeDrawObservable","onAfterDrawObservable","_tmpMeasureA","_markAsDirty","_getTypeName","_host","_fontOffset","_markMatrixAsDirty","fromString","getValueInPixel","isNaN","_resetFontCache","onChangedObservable","_styleObserver","isPercentage","fontSizeToUse","isPixel","getValue","fontSize","zIndex","parent","_reOrderControl","_linkedMesh","paddingLeft","paddingRight","paddingTop","paddingBottom","linkOffsetX","linkOffsetY","getAscendantOfClass","className","isAscendant","container","getLocalCoordinates","globalCoordinates","getLocalCoordinatesToRef","getParentLocalCoordinates","moveToVector3","position","_rootContainer","horizontalAlignment","HORIZONTAL_ALIGNMENT_LEFT","verticalAlignment","VERTICAL_ALIGNMENT_TOP","globalViewport","_getGlobalViewport","projectedPosition","getTransformMatrix","_moveToProjectedPosition","notRenderable","getDescendantsToRef","results","directDescendantsOnly","predicate","getDescendants","linkWithMesh","mesh","_linkedControls","oldLeft","oldTop","newLeft","newTop","ignoreAdaptiveScaling","_offsetLeft","_offsetTop","_flagDescendantsAsMatrixDirty","_intersectsRect","rect","transformToRef","invalidateRect","_transform","host","useInvalidateRectOptimization","CombineToRef","shadowBlur","shadowOffsetX","shadowOffsetY","leftShadowOffset","rightShadowOffset","topShadowOffset","bottomShadowOffset","ceil","force","markAsDirty","_markAllAsDirty","_font","_prepareFont","_link","uniqueId","getUniqueId","context","offsetX","offsetY","translate","rotate","_cachedOffsetX","_cachedOffsetY","_renderHighlight","isHighlighted","save","strokeStyle","lineWidth","_renderHighlightSpecific","restore","strokeRect","_applyStates","_isFontSizeInPercentage","font","fillStyle","AllowAlphaInheritance","globalAlpha","_layout","parentMeasure","isDirty","isVisible","isEqualsTo","_numLayoutCalls","rebuildCount","_processMeasures","_evaluateClippingState","_preMeasure","_measure","_computeAlignment","_additionalProcessing","parentWidth","parentHeight","HORIZONTAL_ALIGNMENT_RIGHT","VERTICAL_ALIGNMENT_BOTTOM","_clipForChildren","_clip","invalidatedRectangle","beginPath","_ClipMeasure","intersection","clip","_render","_numRenderCalls","_cacheData","putImageData","_draw","getImageData","contains","_shouldBlockPointer","_processPicking","pointerId","deltaX","deltaY","_processObservables","_onPointerMove","coordinates","_onPointerEnter","_onPointerOut","canNotify","_onPointerDown","_onPointerUp","notifyClick","canNotifyClick","_forcePointerUp","_onWheelScroll","POINTERMOVE","previousControlOver","_lastControlOver","POINTERDOWN","_registerLastControlDown","_lastPickedControl","POINTERUP","_lastControlDown","POINTERWHEEL","fontStyle","fontWeight","fontSizeInPixels","fontFamily","_GetFontOffset","removeControl","_HORIZONTAL_ALIGNMENT_LEFT","_HORIZONTAL_ALIGNMENT_RIGHT","_HORIZONTAL_ALIGNMENT_CENTER","_VERTICAL_ALIGNMENT_TOP","_VERTICAL_ALIGNMENT_BOTTOM","_VERTICAL_ALIGNMENT_CENTER","_FontHeightSizes","text","document","createElement","innerHTML","style","block","display","verticalAlign","div","appendChild","body","fontAscent","fontHeight","getBoundingClientRect","removeChild","ascent","descent","drawEllipse","arc","closePath","AddHeader","Effect","baseName","attributesNamesOrOptions","uniformsNamesOrEngine","samplers","defines","fallbacks","onCompiled","onError","indexParameters","vertexSource","fragmentSource","onBind","onCompileObservable","onErrorObservable","_onBindObservable","_wasPreviouslyReady","_bonesComputationForcedToCPU","_uniformBuffersNames","_samplers","_isReady","_compilationError","_allFallbacksProcessed","_uniforms","_key","_fallbacks","_vertexSourceCode","_fragmentSourceCode","_vertexSourceCodeOverride","_fragmentSourceCodeOverride","_transformFeedbackVaryings","_pipelineContext","_valueCache","attributes","options","_attributesNames","_uniformsNames","uniformsNames","concat","_samplerList","_indexParameters","transformFeedbackVaryings","uniformBuffersNames","_attributeLocationByName","_uniqueIdSeed","hostDocument","IsWindowObjectExist","getHostDocument","vertexElement","getElementById","vertex","fragmentElement","fragment","processorOptions","split","isFragment","shouldUseHighPrecisionShader","_shouldUseHighPrecisionShader","processor","_shaderProcessor","supportsUniformBuffers","shadersRepository","ShadersRepository","includesShadersStore","IncludesShadersStore","version","webGLVersion","platformName","_loadShader","vertexCode","fragmentCode","Process","migratedVertexCode","migratedFragmentCode","_useFinalCode","spectorName","_prepareEffect","isReady","_isReadyInternal","getPipelineContext","getAttributesNames","getAttributeLocation","_attributes","getAttributeLocationByName","getAttributesCount","getUniformIndex","uniformName","getUniform","getSamplers","getCompilationError","allFallbacksProcessed","executeWhenCompiled","func","effect","isAsync","_checkIsReady","previousPipelineContext","e","_processCompilationErrors","shader","optionalKey","shaderUrl","HTMLElement","GetDOMTextContent","substr","ShadersStore","_loadFile","window","atob","_rebuildProgram","vertexSourceCode","fragmentSourceCode","error","scenes","markAllMaterialsAsDirty","_handlesSpectorRebuildCallback","attributesNames","engine_1","createPipelineContext","rebuildRebind","_preparePipelineContext","_executeWhenRenderingStateIsCompiled","bindUniformBlock","getUniforms","uniform","getAttributes","name_1","bindSamplers","unBindMesh","_deletePipelineContext","message","map","attribute","hasMoreFallbacks","reduce","_bindTexture","channel","texture","setTexture","setDepthStencilTexture","setTextureArray","textures","exName","initialPos","currentExName","channelIndex","setTextureFromPostProcess","postProcess","setTextureFromPostProcessOutput","_cacheMatrix","cache","_cacheFloat2","changed","_cacheFloat3","_cacheFloat4","bindUniformBuffer","bufferName","_baseCache","bindUniformBufferBase","blockName","setInt","setIntArray","setIntArray2","setIntArray3","setIntArray4","setFloatArray","setArray","setFloatArray2","setArray2","setFloatArray3","setArray3","setFloatArray4","setArray4","setMatrices","matrices","setMatrix","setMatrix3x3","setMatrix2x2","setFloat","setBool","bool","setVector2","vector2","setFloat2","setVector3","setFloat3","setVector4","vector4","setFloat4","setColor3","color3","g","setColor4","setDirectColor4","color4","_releaseEffect","RegisterShader","pixelShader","vertexShader","ResetCache","Color3","toColor4","Color4","toLuminance","otherColor","equalsFloats","clampToRef","toHexString","intR","intG","intB","ToHex","toLinearSpace","convertedColor","toLinearSpaceToRef","toHSV","toHSVToRef","h","dm","pow","toGammaSpace","toGammaSpaceToRef","HSVtoRGBToRef","hue","saturation","chroma","FromHexString","hex","substring","parseInt","FromInts","Red","Green","Blue","Black","_BlackReadOnly","White","Purple","Magenta","Yellow","Gray","Teal","Random","random","color","intA","FromColor3","CheckColors4","colors","colors4","newIndex","TmpColors","_DevTools","PointerEventTypes","POINTERPICK","POINTERTAP","POINTERDOUBLETAP","PointerInfoBase","event","PointerInfoPre","localX","localY","ray","skipOnPointerObservable","localPosition","PointerInfo","pickInfo","_TypeStore","GetClass","fqdn","VertexData","positions","normals","tangents","uvs","uvs2","uvs3","uvs4","uvs5","uvs6","matricesIndices","matricesWeights","matricesIndicesExtra","matricesWeightsExtra","applyToMesh","_applyTo","applyToGeometry","geometry","updateMesh","_update","updateGeometry","meshOrGeometry","setVerticesData","indices","setIndices","updateExtends","makeItUnique","updateVerticesData","flip","transformed","tangent","tangentTransformed","merge","use32BitsIndices","_validate","decal","_mergeElement","isSrcTypedArray","isOthTypedArray","ret32","ret","getElementCount","values","positionsElementCount","validateElementCount","elementCount","_isExpanded","ExtractFromMesh","copyWhenShared","forceCopy","_ExtractFrom","ExtractFromGeometry","isVerticesDataPresent","getVerticesData","getIndices","CreateRibbon","CreateBox","CreateTiledBox","CreateTiledPlane","CreateSphere","CreateCylinder","CreateTorus","CreateLineSystem","CreateDashedLines","CreateGround","CreateTiledGround","CreateGroundFromHeightMap","CreatePlane","CreateDisc","CreatePolygon","polygon","sideOrientation","fUV","fColors","frontUVs","backUVs","CreateIcoSphere","CreatePolyhedron","CreateTorusKnot","ComputeNormals","p1p2x","p1p2y","p1p2z","p3p2x","p3p2y","p3p2z","faceNormalx","faceNormaly","faceNormalz","v1x","v1y","v1z","v2x","v2y","v2z","v3x","v3y","v3z","computeFacetNormals","computeFacetPositions","computeFacetPartitioning","computeDepthSort","faceNormalSign","ratio","distanceTo","useRightHandedSystem","depthSortedFacets","xSubRatio","ySubRatio","zSubRatio","subSq","bbSize","ox","oy","oz","b1x","b1y","b1z","b2x","b2y","b2z","b3x","b3y","b3z","block_idx_o","block_idx_v1","block_idx_v2","block_idx_v3","bbSizeMax","subDiv","X","Y","Z","facetPartitioning","nbFaces","facetNormals","facetPositions","bInfo","minimum","dsf","ind","sqDistance","_ComputeSides","li","ln","DEFAULTSIDE","FRONTSIDE","BACKSIDE","DOUBLESIDE","lp","lu","u","ImportVertexData","parsedVertexData","vertexData","uv2s","uv3s","uv4s","uv5s","uv6s","setAllVerticesData","Logger","_AddLogEntry","entry","_LogCache","OnNewCacheEntry","_FormatMessage","padStr","date","Date","getHours","getMinutes","getSeconds","_LogDisabled","_LogEnabled","formattedMessage","console","log","_WarnDisabled","_WarnEnabled","warn","_ErrorDisabled","_ErrorEnabled","errorsCount","ClearLogCache","level","MessageLogLevel","Log","WarningLogLevel","Warn","ErrorLogLevel","NoneLogLevel","AllLogLevel","PromiseStates","FulFillmentAgregator","InternalPromise","resolver","_state","Pending","_children","_rejectWasConsumed","_resolve","reason","_reject","_resultValue","_parent","_result","catch","onRejected","onFulfilled","newPromise","_onFulfilled","_onRejected","Fulfilled","returnedValue","returnedPromise","_reason","_moveChildren","children","child","_b","Rejected","_c","_d","onLocalThrow","_RegisterForFulfillment","promise","agregator","rootPromise","all","promises","race","promises_1","PromisePolyfill","Apply","Tools","BaseUrl","DefaultRetryStrategy","strategy","UseFallbackTexture","RegisteredExternalClasses","classes","FallbackTexture","FetchToRef","pixels","Mix","Instantiate","Slice","SetImmediate","action","IsExponentOfTwo","FloatRound","fround","_tmpFloatArray","GetFilename","path","lastIndexOf","GetFolderPath","uri","returnUnchangedIfNoSlash","ToDegrees","ToRadians","MakeArray","obj","allowsNullUndefined","isArray","GetPointerPrefix","eventPrefix","PointerEvent","IsNavigatorAvailable","navigator","pointerEnabled","SetCorsBehavior","url","element","CleanUrl","replace","PreprocessUrl","LoadImage","input","onLoad","offlineProvider","mimeType","LoadFile","onSuccess","onProgress","useArrayBuffer","LoadFileAsync","reject","request","exception","LoadScript","scriptUrl","scriptId","head","getElementsByTagName","script","setAttribute","onload","onerror","LoadScriptAsync","ReadFileAsDataURL","fileToLoad","progressCallback","reader","FileReader","onCompleteObservable","abort","onloadend","onprogress","readAsDataURL","ReadFile","file","FileAsURL","content","fileBlob","Blob","URL","webkitURL","createObjectURL","Format","decimals","toFixed","DeepCopy","doNotCopyList","mustCopyList","IsEmpty","RegisterTopRootEvents","windowElement","events","addEventListener","handler","UnregisterTopRootEvents","removeEventListener","DumpFramebuffer","successCallback","fileName","numberOfChannelsByLine","halfHeight","readPixels","j","currentCell","targetCell","_ScreenshotCanvas","getContext","imageData","createImageData","EncodeScreenshotCanvasData","ToBlob","canvas","toBlob","quality","binStr","toDataURL","arr","charCodeAt","blob","stringDate","getFullYear","getMonth","getDate","Download","newWindow","open","img","revokeObjectURL","src","msSaveBlob","href","download","parentElement","click","CreateScreenshot","camera","CreateScreenshotAsync","CreateScreenshotUsingRenderTarget","samples","antialiasing","CreateScreenshotUsingRenderTargetAsync","RandomId","IsBase64","DecodeBase64","decodedString","bufferLength","bufferView","GetAbsoluteUrl","LogCache","LogLevels","PerformanceUserMarkLogLevel","StartPerformanceCounter","_StartUserMark","EndPerformanceCounter","_EndUserMark","PerformanceConsoleLogLevel","_StartPerformanceConsole","_EndPerformanceConsole","_StartPerformanceCounterDisabled","_EndPerformanceCounterDisabled","counterName","condition","_performance","performance","mark","measure","time","timeEnd","Now","GetClassName","isType","First","array_1","el","getFullClassName","moduleName","classObj","DelayAsync","delay","IsSafari","test","userAgent","UseCustomRequestHeaders","CustomRequestHeaders","CorsBehavior","PerformanceNoneLogLevel","AsyncLoop","iterations","_done","_fn","_successCallback","executeNext","breakLoop","Run","fn","loop","SyncAsyncForLoop","syncedIterations","breakFunction","timeout","iteration","ValueAndUnit","unit","negativeValueAllowed","_value","_originalUnit","refValue","updateInPlace","idealWidth","idealHeight","useSmallestIdeal","innerWidth","innerHeight","percentage","match","_Regex","exec","sourceValue","parseFloat","sourceUnit","_UNITMODE_PERCENTAGE","_UNITMODE_PIXEL","SceneLoaderFlags","_ForceFullSceneLoadingForIncremental","_ShowLoadingScreen","_loggingLevel","_CleanBoneMatrixWeights","Geometry","delayLoadState","_totalVertices","_isDisposed","_indexBufferIsUpdatable","_meshes","_scene","_vertexBuffers","_indices","getCaps","vertexArrayObject","_vertexArrayObjects","computeWorldMatrix","_boundingBias","_updateBoundingInfo","CreateGeometryForMesh","_extend","doNotSerialize","_indexBuffer","createIndexBuffer","notifyUpdate","setVerticesBuffer","removeVerticesData","totalVertices","_updateExtend","_resetPointsArrayCache","meshes","numOfMeshes","_boundingInfo","maximum","_createGlobalSubMesh","_disposeVertexArrayObjects","updateVerticesDataDirectly","vertexBuffer","getVertexBuffer","meshes_1","reConstruct","subMeshes_1","subMeshes","refreshBoundingInfo","_bind","indexToBind","vbs","getVertexBuffers","recordVertexArrayObject","bindVertexArrayObject","bindBuffers","getTotalVertices","tightlyPackedByteStride","copy_1","isVertexBufferUpdatable","vb","_delayInfo","getVerticesDataKinds","updateIndices","gpuMemoryOnly","needToUpdateSubMeshes","updateDynamicIndexBuffer","getTotalIndices","orig","copy","getIndexBuffer","_releaseVertexArrayObject","releaseVertexArrayObject","releaseForMesh","shouldDispose","_geometry","previousGeometry","pushGeometry","_applyToMesh","boundingBias","references","_syncGeometryWithMorphTargetManager","synchronizeInstances","onGeometryUpdated","_markSubMeshesAsAttributesDirty","load","onLoaded","_queueLoad","delayLoadingFile","_addPendingData","_delayLoadingFunction","JSON","parse","_removePendingData","toLeftHanded","tIndices","tTemp","tPositions","tNormals","_positions","_generatePointsArray","isDisposed","removeGeometry","stopChecking","HasTags","toNumberArray","origin","serializeVerticeData","tangets","_ImportGeometry","parsedGeometry","geometryId","getGeometryByID","binaryInfo","_binaryInfo","positionsAttrDesc","positionsData","normalsAttrDesc","normalsData","tangetsAttrDesc","tangentsData","uvsAttrDesc","uvsData","uvs2AttrDesc","uvs2Data","uvs3AttrDesc","uvs3Data","uvs4AttrDesc","uvs4Data","uvs5AttrDesc","uvs5Data","uvs6AttrDesc","uvs6Data","colorsAttrDesc","colorsData","matricesIndicesAttrDesc","matricesIndicesData","floatIndices","matricesWeightsAttrDesc","matricesWeightsData","indicesAttrDesc","indicesData","subMeshesAttrDesc","subMeshesData","materialIndex","verticesStart","verticesCount","indexStart","indexCount","AddToMesh","matricesIndex","_CleanMatricesWeights","subIndex","parsedSubMesh","_shouldGenerateFlatShading","convertToFlatShadedMesh","onMeshImportedObservable","CleanBoneMatrixWeights","noInfluenceBoneIndex","skeletonId","skeleton","getLastSkeletonByID","bones","influencers","numBoneInfluencer","weight","firstZeroWeight","mweight","boundingBoxMinimum","boundingBoxMaximum","hasUVs","hasUVs2","hasUVs3","hasUVs4","hasUVs5","hasUVs6","hasColors","hasMatricesIndices","hasMatricesWeights","MeshLODLevel","distance","_CreationDataStorage","_InstanceDataStorage","visibleInstances","batchCache","_InstancesBatch","instancesBufferSize","mustReturn","renderSelf","hardwareInstancedRendering","_InternalMeshDataInfo","_areNormalsFrozen","_source","meshMap","_preActivateId","_LODLevels","_morphTargetManager","Mesh","doNotCloneChildren","clonePhysicsImpostor","_internalMeshDataInfo","instances","_creationDataStorage","_instanceDataStorage","_effectiveMaterial","_originalBuilderSideOrientation","overrideMaterialSideOrientation","useClonedMeshMap","_ranges","ranges","createAnimationRange","setPivotMatrix","getPivotMatrix","material","directDescendants","index_1","morphTargetManager","getPhysicsEngine","physicsEngine","impostor","getImpostorForPhysicsObject","physicsImpostor","particleSystems","system","emitter","instancedArrays","_GetDefaultSideOrientation","orientation","_onBeforeRenderObservable","_onBeforeBindObservable","_onAfterRenderObservable","_onBeforeDrawObservable","_onBeforeDrawObserver","_unIndexed","instancesData","manualUpdate","instantiateHierarchy","newParent","onNewNodeCreated","instance","doNotInstantiate","createInstance","scaling","rotationQuaternion","getChildTransformNodes","fullDetails","_waitingParentId","ib","_unBindEffect","getLODLevels","_sortLODLevels","sort","addLODLevel","_masterMesh","getLODLevelAtDistance","internalDataInfo","removeLODLevel","getLOD","boundingSphere","bSphere","getBoundingInfo","distanceToCamera","centerWorld","globalPosition","onLODLevelSelection","_preActivate","_updateSubMeshesBoundingInfo","worldMatrixFromCache","completeCheck","forceInstanceSupport","mat","defaultMaterial","_storeEffectOnSubMeshes","effectiveMaterial","subMesh","getMaterial","isReadyForSubMesh","lightSources","generator","getShadowGenerator","_e","_f","_g","lod","freezeNormals","unfreezeNormals","overridenInstanceCount","sceneRenderId","getRenderId","_preActivateForIntermediateRendering","renderId","intermediateDefaultRenderId","_registerInstanceForRenderId","defaultRenderId","selfDefaultRenderId","_renderId","applySkeleton","isLocked","bias","_refreshBoundingInfo","_getPositionData","totalIndices","needToRecreate","submesh","releaseSubMeshes","subdivide","subdivisionSize","CreateFromIndices","markVerticesDataAsUpdatable","makeGeometryUnique","updateMeshPositions","positionFunction","computeNormals","oldGeometry","fillMode","PointFillMode","WireFrameFillMode","_getLinesIndexBuffer","TriangleFillMode","instancesCount","drawArraysType","drawElementsType","_linesIndexCount","registerBeforeRender","onBeforeRenderObservable","unregisterBeforeRender","registerAfterRender","onAfterRenderObservable","unregisterAfterRender","_getInstancesRenderList","subMeshId","isReplacementMode","isFrozen","previousBatch","isInIntermediateRendering","_isInIntermediateRendering","onlyForInstances","_internalAbstractMeshDataInfo","_onlyForInstancesIntermediate","_onlyForInstances","isEnabled","currentRenderId","_renderWithInstances","batch","_id","instanceStorage","currentInstancesBufferSize","instancesBuffer","bufferSize","_effectiveMesh","getWorldMatrix","instanceIndex","_processInstancedBuffers","_activeIndices","addCount","unbindInstanceAttributes","_processRendering","onBeforeDraw","instanceCount","visibleInstancesForSubMesh","visibleInstanceCount","_freeze","_unFreeze","render","enableAlphaMode","effectiveMeshReplacement","_isActiveIntermediate","_isActive","_checkOcclusionQuery","instanceDataStorage","setAlphaMode","alphaMode","_beforeRenderingMeshStage","getEffect","effectiveMesh","backFaceCulling","mainDeterminant","_getWorldMatrixDeterminant","ClockWiseSideOrientation","CounterClockWiseSideOrientation","reverse","_preBind","forceDepthWrite","setDepthWrite","forcePointsCloud","forceWireframe","bindForSubMesh","separateCullingPass","setState","zOffset","_onBeforeDraw","unbind","_afterRenderingMeshStage","isInstance","bindOnlyWorldMatrix","cleanMatrixWeights","normalizeSkinWeightsAndExtra","normalizeSkinFourWeights","numWeights","recip","validateSkinning","skinned","valid","report","numberNotSorted","missingWeights","maxUsedWeights","numberNotNormalized","numInfluences","usedWeightCounts","lastWeight","usedWeights","tolerance","numBones","numBadBoneIndices","_checkDelayState","getBinaryData","_syncSubMeshes","isInFrustum","frustumPlanes","setMaterialByID","materials","multiMaterials","getAnimatables","bakeTransformIntoVertices","submeshes","flipFaces","bakeCurrentTransformIntoVertices","bakeIndependenlyOfChildren","resetLocalMatrix","doNotRecurse","disposeMaterialAndTextures","_disposeInstanceSpecificData","applyDisplacementMap","minHeight","maxHeight","uvOffset","uvScale","forceUpdate","heightMapWidth","heightMapHeight","CreateCanvas","drawImage","applyDisplacementMapFromBuffer","uv","pos","kindIndex","kinds","newdata","updatableNormals","previousSubmeshes","vertexIndex","p3","p1p2","p3p2","localIndex","submeshIndex","previousOne","convertToUnIndexedMesh","flipNormals","vertex_data","increaseVertices","numberPerEdge","currentIndices","segments","tempIndices","deltaPosition","deltaNormal","deltaUV","side","positionPtr","uvPtr","idx","forceSharedVertices","currentUVs","currentPositions","currentColors","ptr","facet","pstring","indexPtr","uniquePositions","_instancedMeshFactory","_PhysicsImpostorParser","physicObject","jsonObject","optimizeIndices","vectorPositions","dupes","realPos","testedPosition","againstPosition","originalSubMeshes","_postMultiplyPivotMatrix","pivotMatrix","localMatrix","infiniteDistance","pickable","isPickable","receiveShadows","billboardMode","visibility","checkCollisions","isBlocker","parentId","isUnIndexed","materialId","morphTargetManagerId","_getComponent","NAME_PHYSICSENGINE","getPhysicsImpostor","physicsMass","getParam","physicsFriction","physicsRestitution","serializationInstance","serializeAnimationRanges","layerMask","alphaIndex","hasVertexAlpha","overlayAlpha","overlayColor","renderOverlay","applyFog","actionManager","actions","numInfluencers","morphTarget","getActiveTarget","getPositions","getNormals","getTangents","getUVs","parsedMesh","_GroundMeshParser","setPreTransformMatrix","setEnabled","showBoundingBox","showSubMeshesBoundingBox","useFlatShading","freezeWorldMatrix","_waitingData","ForceFullSceneLoadingForIncremental","getMorphTargetManagerById","numBoneInfluencers","parsedAnimation","internalClass","ParseAnimationRanges","autoAnimate","beginAnimation","autoAnimateFrom","autoAnimateTo","autoAnimateLoop","autoAnimateSpeed","lodMeshIds","lods","ids","distances","lodDistances","coverages","lodCoverages","parsedInstance","pathArray","closeArray","radius","tessellation","diameter","CreateHemisphere","diameterTop","diameterBottom","subdivisions","thickness","tube","radialSegments","tubularSegments","CreateLines","points","dashSize","gapSize","dashNb","shape","holes","earcutInjection","earcut","ExtrudePolygon","depth","ExtrudeShape","cap","ExtrudeShapeCustom","scaleFunction","rotationFunction","ribbonCloseArray","ribbonClosePath","CreateLathe","xmin","xmax","precision","onReady","alphaFilter","CreateTube","radiusFunction","CreateDecal","sourceMesh","setPositionsForCPUSkinning","_sourcePositions","setNormalsForCPUSkinning","_sourceNormals","_softwareSkinningFrameId","getFrameId","inf","needExtras","matricesIndicesExtraData","matricesWeightsExtraData","skeletonMatrices","getTransformMatrices","tempVector3","finalMatrix","tempMatrix","matWeightIdx","MinMax","minVector","maxVector","boundingBox","minimumWorld","maximumWorld","meshesOrMinMaxVector","minMaxVector","MergeMeshes","disposeSource","allow32BitsIndices","meshSubclass","subdivideWithSubMeshes","multiMultiMaterials","matIndex","newMultiMaterial","otherVertexData","materialArray","materialIndexArray","indiceArray","isAnInstance","wm","subMaterials","addInstance","_indexInSourceMeshInstanceArray","removeInstance","last","pop","NO_CAP","CAP_START","CAP_END","CAP_ALL","NO_FLIP","FLIP_TILE","ROTATE_TILE","FLIP_ROW","ROTATE_ROW","FLIP_N_ROTATE_TILE","FLIP_N_ROTATE_ROW","CENTER","LEFT","RIGHT","TOP","BOTTOM","ToGammaSpace","ToLinearSpace","Epsilon","Scalar","str","toUpperCase","Sign","Log2","LOG2E","Repeat","Denormalize","DeltaAngle","current","PingPong","SmoothStep","MoveTowards","maxDelta","MoveTowardsAngle","LerpAngle","InverseLerp","RandomRange","RangeToPercent","number","PercentToRange","percent","NormalizeRadians","TwoPi","BaseTexture","reservedDataStore","_hasAlpha","getAlphaFromRGB","coordinatesIndex","_coordinatesMode","wrapU","wrapV","wrapR","anisotropicFilteringLevel","DEFAULT_ANISOTROPIC_FILTERING_LEVEL","gammaSpace","invertZ","lodLevelInAlpha","onDisposeObservable","_onDisposeObserver","_texture","_uid","_cachedSize","LastCreatedScene","addTexture","isCube","is3D","is2DArray","_isRGBD","_lodGenerationOffset","_lodGenerationScale","_linearSpecularLOD","_irradianceTexture","getTextureMatrix","IdentityReadOnly","getReflectionTextureMatrix","getInternalTexture","isReadyOrNotBlocking","isBlocking","delayLoad","getBaseSize","baseWidth","baseHeight","updateSamplingMode","samplingMode","updateTextureSamplingMode","_getFromCache","noMipmap","sampling","invertY","texturesCache","getLoadedTexturesCache","texturesCacheEntry","generateMipMaps","incrementReferences","format","_markAllSubMeshesAsTexturesDirty","faceIndex","round","_readTexturePixels","releaseInternalTexture","_lodTextureHigh","_lodTextureMid","_lodTextureLow","stopAnimation","onTextureRemovedObservable","WhenAllReady","numRemaining","onLoadObservable","_loop_1","onLoadCallback_1","Texture","sceneOrEngine","deleteBuffer","TRILINEAR_SAMPLINGMODE","uOffset","vOffset","uScale","vScale","uAng","vAng","wAng","uRotationCenter","vRotationCenter","wRotationCenter","inspectableCustomProperties","_noMipmap","_invertY","_rowGenerationMatrix","_cachedTextureMatrix","_projectionModeMatrix","_t0","_t1","_t2","_cachedUOffset","_cachedVOffset","_cachedUScale","_cachedVScale","_cachedUAng","_cachedVAng","_cachedWAng","_cachedProjectionMatrixId","_cachedCoordinatesMode","_initialSamplingMode","BILINEAR_SAMPLINGMODE","_deleteBuffer","_format","_delayedOnLoad","_delayedOnError","_isBlocking","_mimeType","onBeforeTextureInitObservable","_invertVScale","_cachedWrapU","_cachedWrapV","_cachedWrapR","resetCachedMaterial","onLoadedObservable","useDelayedTextureLoading","createTexture","updateURL","StartsWith","_prepareRowForTextureGeneration","uBase","hasTexture","coordinatesMode","PROJECTION_MODE","getProjectionMatrix","PLANAR_MODE","projectionMatrix","getActiveTextures","savedName","SerializeBuffers","base64String","EncodeArrayBufferToBase64","parsedTexture","customType","parsedCustomTexture","_samplingMode","_CubeTextureParser","mirrorPlane","mirrorTexture","_CreateMirror","renderTargetSize","_waitingRenderList","renderList","renderTargetTexture","reflectionProbes","probe","cubeTexture","_CreateRenderTargetTexture","CreateFromBase64String","UseSerializedUrlIfAny","LoadFromDataString","jsonTexture","NEAREST_SAMPLINGMODE","NEAREST_NEAREST_MIPLINEAR","LINEAR_LINEAR_MIPNEAREST","LINEAR_LINEAR_MIPLINEAR","NEAREST_NEAREST_MIPNEAREST","NEAREST_LINEAR_MIPNEAREST","NEAREST_LINEAR_MIPLINEAR","NEAREST_LINEAR","NEAREST_NEAREST","LINEAR_NEAREST_MIPNEAREST","LINEAR_NEAREST_MIPLINEAR","LINEAR_LINEAR","LINEAR_NEAREST","EXPLICIT_MODE","SPHERICAL_MODE","CUBIC_MODE","SKYBOX_MODE","INVCUBIC_MODE","EQUIRECTANGULAR_MODE","FIXED_EQUIRECTANGULAR_MODE","FIXED_EQUIRECTANGULAR_MIRRORED_MODE","CLAMP_ADDRESSMODE","WRAP_ADDRESSMODE","MIRROR_ADDRESSMODE","MaterialHelper","BindEyePosition","_forcedViewPosition","activeCamera","devicePosition","_mirroredCameraPosition","PrepareDefinesForMergedUV","_needUVs","BindTextureMatrix","uniformBuffer","updateMatrix","GetFogState","fogEnabled","fogMode","FOGMODE_NONE","PrepareDefinesForMisc","useLogarithmicDepth","pointsCloud","alphaTest","_areMiscDirty","nonUniformScaling","PrepareDefinesForFrameBoundValues","useInstances","useClipPlane","useClipPlane1","useClipPlane2","useClipPlane3","useClipPlane4","useClipPlane5","useClipPlane6","clipPlane","clipPlane2","clipPlane3","clipPlane4","clipPlane5","clipPlane6","getColorWrite","markAsUnprocessed","PrepareDefinesForBones","useBones","computeBonesUsingShaders","materialSupportsBoneTexture","isUsingTextureForMatrices","PrepareDefinesForMorphTargets","manager","supportsUVs","supportsTangents","supportsNormals","PrepareDefinesForAttributes","useVertexColor","useMorphTargets","useVertexAlpha","_areAttributesDirty","_needNormals","_normals","_uvs","hasVertexColors","useVertexColors","PrepareDefinesForMultiview","previousMultiview","MULTIVIEW","outputRenderTarget","getViewCount","PrepareDefinesForLight","light","lightIndex","specularSupported","needNormals","needRebuild","prepareLightSpecificDefines","falloffType","FALLOFF_GLTF","FALLOFF_PHYSICAL","FALLOFF_STANDARD","specular","specularEnabled","shadowsEnabled","shadowEnabled","shadowGenerator","shadowMap","getShadowMap","prepareDefines","lightmapMode","LIGHTMAP_DEFAULT","LIGHTMAP_SHADOWSONLY","PrepareDefinesForLights","maxSimultaneousLights","disableLighting","_areLightsDirty","lightsEnabled","caps","textureFloatRender","textureFloatLinearFiltering","textureHalfFloatRender","textureHalfFloatLinearFiltering","rebuild","PrepareUniformsAndSamplersForLight","uniformsList","samplersList","projectedLightTexture","uniformBuffersList","PrepareUniformsAndSamplersList","uniformsListOrOptions","HandleFallbacksForShadows","rank","lightFallbackRank","addFallback","PrepareAttributesForMorphTargetsInfluencers","attribs","_TmpMorphInfluencers","NUM_MORPH_INFLUENCERS","PrepareAttributesForMorphTargets","LastCreatedEngine","maxAttributesCount","maxVertexAttribs","PrepareAttributesForBones","addCPUSkinningFallback","PrepareAttributesForInstances","PushAttributesForInstances","BindLightProperties","transferToEffect","BindLight","useSpecular","rebuildInParallel","_bindLight","BindLights","BindFogParameters","linearSpace","fogStart","fogEnd","fogDensity","fogColor","_tempFogColor","BindBonesParameters","boneTexture","getTransformMatrixTexture","BindMorphTargetParameters","abstractMesh","influences","BindLogDepth","maxZ","LN2","BindClipPlane","Camera","setActiveOnSceneIfNoneActive","_position","upVector","orthoLeft","orthoRight","orthoBottom","orthoTop","minZ","inertia","PERSPECTIVE_CAMERA","isIntermediate","fovMode","FOVMODE_VERTICAL_FIXED","cameraRigMode","RIG_MODE_NONE","customRenderTargets","onViewMatrixChangedObservable","onProjectionMatrixChangedObservable","onAfterCheckInputsObservable","onRestoreStateObservable","isRigCamera","_rigCameras","_webvrViewMatrix","_skipRendering","_projectionMatrix","_postProcesses","_activeMeshes","_globalPosition","_computedViewMatrix","_doNotComputeProjectionMatrix","_refreshFrustumPlanes","_isCamera","_isLeftCamera","_isRightCamera","addCamera","newPosition","storeState","_stateStored","_storedFov","_restoreStateValues","restoreState","getActiveMeshes","isActiveMesh","pp","_initCache","_cache","Number","MAX_VALUE","aspectRatio","renderWidth","renderHeight","_updateCache","ignoreParentClass","_isSynchronized","_isSynchronizedViewMatrix","_isSynchronizedProjectionMatrix","isSynchronizedWithParent","check","getAspectRatio","getRenderWidth","getRenderHeight","attachControl","noPreventDefault","detachControl","_checkInputs","_updateRigCameras","_rigPostProcess","_getFirstPostProcess","ppIndex","_cascadePostProcessesToRigCams","firstPostProcess","markTextureDirty","cam","rigPostProcess","getEffectName","attachPostProcess","insertAt","isReusable","detachPostProcess","getViewMatrix","_worldMatrix","_getViewMatrix","updateCache","_currentRenderId","_childUpdateId","_cameraRigParams","vrPreViewMatrix","freezeProjectionMatrix","unfreezeProjectionMatrix","reverseDepth","useReverseDepthBuffer","halfWidth","getTransformationMatrix","_updateFrustumPlanes","_frustumPlanes","GetPlanesToRef","GetPlanes","checkRigCameras","rigCameras","isCompletelyInFrustum","getForwardRay","inputs","removeCamera","getLeftTarget","getTarget","getRightTarget","setCameraRigMode","rigParams","interaxialDistance","stereoHalfAngle","leftCamera","createRigCamera","rightCamera","RIG_MODE_STEREOSCOPIC_ANAGLYPH","_setStereoscopicAnaglyphRigMode","RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL","RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED","RIG_MODE_STEREOSCOPIC_OVERUNDER","RIG_MODE_STEREOSCOPIC_INTERLACED","_setStereoscopicRigMode","RIG_MODE_VR","_setVRRigMode","RIG_MODE_WEBVR","_setWebVRRigMode","_getVRProjectionMatrix","vrMetrics","aspectRatioFov","vrWorkMatrix","vrHMatrix","_updateCameraRotationMatrix","_updateWebVRCameraRotationMatrix","_getWebVRProjectionMatrix","_getWebVRViewMatrix","setCameraRigParameter","cameraIndex","_setupInputs","GetConstructorFromName","isStereoscopicSideBySide","getDirection","localAxis","getDirectionToRef","interaxial_distance","constructorFunc","Construct","_createDefaultParsedCamera","parsedCamera","construct","setPosition","setTarget","ORTHOGRAPHIC_CAMERA","FOVMODE_HORIZONTAL_FIXED","RIG_MODE_CUSTOM","ForceAttachControlToAlwaysPreventDefault","AndOrNotEvaluator","Eval","query","evaluateCallback","_HandleParenthesisContent","parenthesisContent","or","ori","_SimplifyNegation","trim","and","andj","booleanString","Tags","EnableFor","_tags","hasTags","addTags","tagsString","removeTags","RemoveTagsFrom","matchesTagsQuery","tagsQuery","MatchesQuery","DisableFor","asString","tagsArray","tag","join","_AddTagTo","_RemoveTagFrom","SceneComponentConstants","NAME_EFFECTLAYER","NAME_LAYER","NAME_LENSFLARESYSTEM","NAME_BOUNDINGBOXRENDERER","NAME_PARTICLESYSTEM","NAME_GAMEPAD","NAME_SIMPLIFICATIONQUEUE","NAME_GEOMETRYBUFFERRENDERER","NAME_DEPTHRENDERER","NAME_POSTPROCESSRENDERPIPELINEMANAGER","NAME_SPRITE","NAME_OUTLINERENDERER","NAME_PROCEDURALTEXTURE","NAME_SHADOWGENERATOR","NAME_OCTREE","NAME_AUDIO","STEP_ISREADYFORMESH_EFFECTLAYER","STEP_BEFOREEVALUATEACTIVEMESH_BOUNDINGBOXRENDERER","STEP_EVALUATESUBMESH_BOUNDINGBOXRENDERER","STEP_ACTIVEMESH_BOUNDINGBOXRENDERER","STEP_CAMERADRAWRENDERTARGET_EFFECTLAYER","STEP_BEFORECAMERADRAW_EFFECTLAYER","STEP_BEFORECAMERADRAW_LAYER","STEP_BEFORERENDERTARGETDRAW_LAYER","STEP_BEFORERENDERINGMESH_OUTLINE","STEP_AFTERRENDERINGMESH_OUTLINE","STEP_AFTERRENDERINGGROUPDRAW_EFFECTLAYER_DRAW","STEP_AFTERRENDERINGGROUPDRAW_BOUNDINGBOXRENDERER","STEP_BEFORECAMERAUPDATE_SIMPLIFICATIONQUEUE","STEP_BEFORECAMERAUPDATE_GAMEPAD","STEP_BEFORECLEAR_PROCEDURALTEXTURE","STEP_AFTERRENDERTARGETDRAW_LAYER","STEP_AFTERCAMERADRAW_EFFECTLAYER","STEP_AFTERCAMERADRAW_LENSFLARESYSTEM","STEP_AFTERCAMERADRAW_EFFECTLAYER_DRAW","STEP_AFTERCAMERADRAW_LAYER","STEP_AFTERRENDER_AUDIO","STEP_GATHERRENDERTARGETS_DEPTHRENDERER","STEP_GATHERRENDERTARGETS_GEOMETRYBUFFERRENDERER","STEP_GATHERRENDERTARGETS_SHADOWGENERATOR","STEP_GATHERRENDERTARGETS_POSTPROCESSRENDERPIPELINEMANAGER","STEP_GATHERACTIVECAMERARENDERTARGETS_DEPTHRENDERER","STEP_POINTERMOVE_SPRITE","STEP_POINTERDOWN_SPRITE","STEP_POINTERUP_SPRITE","Stage","items","Create","registerStep","component","EngineStore","Instances","_LastCreatedScene","DepthCullingState","_isDepthTestDirty","_isDepthMaskDirty","_isDepthFuncDirty","_isCullFaceDirty","_isCullDirty","_isZOffsetDirty","_isFrontFaceDirty","_zOffset","_cullFace","_cull","_depthFunc","_depthMask","_depthTest","_frontFace","gl","cull","enable","CULL_FACE","disable","cullFace","depthMask","depthTest","DEPTH_TEST","depthFunc","POLYGON_OFFSET_FILL","polygonOffset","frontFace","StencilState","_isStencilTestDirty","_isStencilMaskDirty","_isStencilFuncDirty","_isStencilOpDirty","_stencilFunc","_stencilFuncRef","_stencilFuncMask","_stencilOpStencilFail","_stencilOpDepthFail","_stencilOpStencilDepthPass","_stencilMask","_stencilTest","ALWAYS","KEEP","REPLACE","stencilTest","STENCIL_TEST","stencilMask","stencilFunc","stencilFuncRef","stencilFuncMask","stencilOp","stencilOpStencilFail","stencilOpDepthFail","stencilOpStencilDepthPass","AlphaState","_isAlphaBlendDirty","_isBlendFunctionParametersDirty","_isBlendEquationParametersDirty","_isBlendConstantsDirty","_alphaBlend","_blendFunctionParameters","_blendEquationParameters","_blendConstants","setAlphaBlendConstants","setAlphaBlendFunctionParameters","value0","setAlphaEquationParameters","rgb","BLEND","blendFuncSeparate","blendEquationSeparate","blendColor","WebGL2ShaderProcessor","attributeProcessor","varyingProcessor","varying","postProcessor","code","hasDrawBuffersExtension","search","WebGLPipelineContext","vertexCompilationError","fragmentCompilationError","programLinkError","programValidationError","isParallelCompiled","program","_isRenderingStateCompiled","BufferPointer","ThinEngine","canvasOrContext","antialias","adaptToDeviceRatio","forcePOTTextures","isFullscreen","cullBackFaces","renderEvenInBackground","preventCacheWipeBetweenFrames","validateShaderPrograms","disableUniformBuffers","_uniformBuffers","_webGLVersion","_windowIsBackground","_highPrecisionShadersAllowed","_badOS","_badDesktopOS","_renderingQueueLaunched","_activeRenderLoops","onContextLostObservable","onContextRestoredObservable","_contextWasLost","_doNotHandleContextLost","disableVertexArrayObjects","_colorWrite","_colorWriteChanged","_depthCullingState","_stencilState","_alphaState","_alphaMode","_alphaEquation","_internalTexturesCache","_activeChannel","_currentTextureChannel","_boundTexturesCache","_compiledEffects","_vertexAttribArraysEnabled","_uintIndicesCurrentlySet","_currentBoundBuffer","_currentFramebuffer","_currentBufferPointers","_currentInstanceLocations","_currentInstanceBuffers","_vaoRecordInProgress","_mustWipeVertexAttributes","_nextFreeTextureSlots","_maxSimultaneousTextures","_activeRequests","_texturesSupported","premultipliedAlpha","_viewportCached","_unpackFlipYCached","enableUnpackFlipYCached","_getDepthStencilBuffer","internalFormat","msInternalFormat","attachment","_gl","depthStencilBuffer","createRenderbuffer","bindRenderbuffer","RENDERBUFFER","renderbufferStorageMultisample","renderbufferStorage","framebufferRenderbuffer","FRAMEBUFFER","_boundUniforms","_renderingCanvas","deterministicLockstep","lockstepMaxSteps","timeStep","preserveDrawingBuffer","audioEngine","stencil","doNotHandleContextLost","ua","ExceptionList","targets","RegExp","capture","captureConstraint","constraint","matches","targets_1","_onContextLost","evt","preventDefault","_onContextRestored","_initGLContext","_rebuildEffects","_rebuildInternalTextures","_rebuildBuffers","wipeCaches","powerPreference","disableWebGL2Support","deleteQuery","getContextAttributes","pixelStorei","UNPACK_COLORSPACE_CONVERSION_WEBGL","NONE","useHighPrecisionFloats","devicePixelRatio","limitDeviceRatio","_hardwareScalingLevel","resize","_isStencilEnable","_caps","_creationOptions","Version","description","parallelShaderCompile","highPrecisionShaderSupported","dimensions","_framebufferDimensionsObject","_textureFormatInUse","_cachedViewport","_emptyTexture","createRawTexture","_emptyTexture3D","createRawTexture3D","_emptyTexture2DArray","createRawTexture2DArray","_emptyCubeTexture","faceData","cubeData","createRawCubeTexture","currentState_1","areAllEffectsReady","maxTexturesImageUnits","getParameter","MAX_TEXTURE_IMAGE_UNITS","maxCombinedTexturesImageUnits","MAX_COMBINED_TEXTURE_IMAGE_UNITS","maxVertexTextureImageUnits","MAX_VERTEX_TEXTURE_IMAGE_UNITS","maxTextureSize","MAX_TEXTURE_SIZE","maxSamples","MAX_SAMPLES","maxCubemapTextureSize","MAX_CUBE_MAP_TEXTURE_SIZE","maxRenderTextureSize","MAX_RENDERBUFFER_SIZE","MAX_VERTEX_ATTRIBS","maxVaryingVectors","MAX_VARYING_VECTORS","maxFragmentUniformVectors","MAX_FRAGMENT_UNIFORM_VECTORS","maxVertexUniformVectors","MAX_VERTEX_UNIFORM_VECTORS","getExtension","standardDerivatives","maxAnisotropy","astc","s3tc","pvrtc","etc1","etc2","textureAnisotropicFilterExtension","uintIndices","fragmentDepthSupported","timerQuery","canUseTimestampForTimerQuery","drawBuffersExtension","maxMSAASamples","colorBufferFloat","textureFloat","textureHalfFloat","textureLOD","blendMinMax","multiview","oculusMultiview","depthTextureExtension","_glVersion","VERSION","rendererInfo","_glRenderer","UNMASKED_RENDERER_WEBGL","_glVendor","UNMASKED_VENDOR_WEBGL","HALF_FLOAT_OES","RGBA16F","RGBA32F","DEPTH24_STENCIL8","getQuery","getQueryEXT","TIMESTAMP_EXT","QUERY_COUNTER_BITS_EXT","MAX_TEXTURE_MAX_ANISOTROPY_EXT","_canRenderToFloatFramebuffer","_canRenderToHalfFloatFramebuffer","drawBuffers","drawBuffersWEBGL","DRAW_FRAMEBUFFER","UNSIGNED_INT_24_8","UNSIGNED_INT_24_8_WEBGL","vertexArrayObjectExtension","createVertexArray","createVertexArrayOES","bindVertexArray","bindVertexArrayOES","deleteVertexArray","deleteVertexArrayOES","instanceExtension","drawArraysInstanced","drawArraysInstancedANGLE","drawElementsInstanced","drawElementsInstancedANGLE","vertexAttribDivisor","vertexAttribDivisorANGLE","texturesSupported","getShaderPrecisionFormat","vertex_highp","VERTEX_SHADER","HIGH_FLOAT","fragment_highp","FRAGMENT_SHADER","blendMinMaxExtension","MAX","MAX_EXT","MIN","MIN_EXT","LEQUAL","slot","_prepareWorkingCanvas","_workingCanvas","_workingContext","resetTextureCache","getGlInfo","vendor","renderer","setHardwareScalingLevel","getHardwareScalingLevel","stopRenderLoop","renderFunction","_renderLoop","shouldRender","beginFrame","endFrame","_frameHandler","_queueNewFrame","_boundRenderFunction","getHostWindow","getRenderingCanvas","ownerDocument","defaultView","useScreen","_currentRenderTarget","framebufferWidth","drawingBufferWidth","framebufferHeight","drawingBufferHeight","bindedRenderFunction","requester","QueueNewFrame","runRenderLoop","backBuffer","applyStates","clearColor","COLOR_BUFFER_BIT","GREATER","clearDepth","DEPTH_BUFFER_BIT","clearStencil","STENCIL_BUFFER_BIT","_viewport","setViewport","requiredWidth","requiredHeight","flushFramebuffer","clientWidth","clientHeight","setSize","bindFramebuffer","forceFullscreenViewport","lodLevel","layer","unBindFramebuffer","_bindUnboundFramebuffer","_MSAAFramebuffer","_framebuffer","framebufferTextureLayer","COLOR_ATTACHMENT0","_webGLTexture","framebufferTexture2D","TEXTURE_CUBE_MAP_POSITIVE_X","depthStencilTexture","_depthStencilTexture","DEPTH_STENCIL_ATTACHMENT","DEPTH_ATTACHMENT","TEXTURE_2D","framebuffer","disableGenerateMipMaps","onBeforeUnbind","READ_FRAMEBUFFER","blitFramebuffer","NEAREST","_bindTextureDirectly","generateMipmap","flush","restoreDefaultFramebuffer","_resetVertexBufferBinding","bindArrayBuffer","_cachedVertexBuffers","_createVertexBuffer","STATIC_DRAW","usage","vbo","createBuffer","dataBuffer","bufferData","ARRAY_BUFFER","DYNAMIC_DRAW","_resetIndexBufferBinding","bindIndexBuffer","_cachedIndexBuffer","_normalizeIndexData","ELEMENT_ARRAY_BUFFER","is32Bits","_unbindVertexArrayObject","bindBuffer","pipelineContext","uniformLocation","getUniformBlockIndex","uniformBlockBinding","underlyingResource","updateArrayBuffer","bufferSubData","_vertexAttribPointer","indx","pointer","active","vertexAttribPointer","_bindIndexBufferWithCache","indexBuffer","_bindVertexBuffersAttributes","vertexBuffers","unbindAllAttributes","enableVertexAttribArray","vao","_cachedVertexArrayObject","bindBuffersDirectly","vertexDeclaration","vertexStrideSize","_cachedEffectForVertexBuffers","attributesCount","boundBuffer","ul","offsetLocation","updateAndBindInstancesBuffer","offsetLocations","bindInstancesBuffer","attributesInfo","computeStride","ai","attributeSize","_currentEffect","attributeName","attributeType","disableInstanceAttributeByName","attributeLocation","disableInstanceAttribute","shouldClean","disableAttributeByIndex","disableVertexAttribArray","draw","useTriangles","drawPointClouds","drawUnIndexed","_reportDrawCall","drawMode","_drawMode","indexFormat","mult","drawElements","drawArrays","TRIANGLES","POINTS","LINES","LINE_LOOP","LINE_STRIP","TRIANGLE_STRIP","TRIANGLE_FAN","webGLPipelineContext","__SPECTOR_rebuildProgram","deleteProgram","createEffect","compiledEffect","_ConcatenateShader","shaderVersion","_compileShader","_compileRawShader","createShader","shaderSource","compileShader","createRawShaderProgram","fragmentShader","_createShaderProgram","createShaderProgram","shaderProgram","createProgram","attachShader","linkProgram","_finalizePipelineContext","getProgramParameter","LINK_STATUS","getShaderParameter","COMPILE_STATUS","getShaderInfoLog","getProgramInfoLog","validateProgram","VALIDATE_STATUS","deleteShader","createAsRaw","webGLRenderingState","COMPLETION_STATUS_KHR","oldHandler","getUniformLocation","getAttribLocation","enableEffect","uniform1i","uniform1iv","uniform2iv","uniform3iv","uniform4iv","uniform1fv","uniform2fv","uniform3fv","uniform4fv","uniformMatrix4fv","uniformMatrix3fv","uniformMatrix2fv","uniform1f","uniform2f","uniform3f","uniform4f","colorMask","setColorWrite","clearInternalTexturesCache","bruteForce","_currentProgram","UNPACK_PREMULTIPLY_ALPHA_WEBGL","_getSamplingParameters","magFilter","minFilter","LINEAR","LINEAR_MIPMAP_NEAREST","LINEAR_MIPMAP_LINEAR","NEAREST_MIPMAP_LINEAR","NEAREST_MIPMAP_NEAREST","mag","_createTexture","urlArg","fallback","forcedExtension","String","fromData","fromBlob","isBase64","Url","lastDot","extension","loader","_TextureLoaders","availableLoader","canLoad","onLoadObserver","onInternalError","loadData","loadMipmap","isCompressed","loadFailed","_prepareWebGLTexture","isView","responseURL","potWidth","potHeight","continuationCallback","isPot","_getInternalFormat","RGB","RGBA","texImage2D","_supportsHardwareTextureRescaling","source_1","Temp","_rescaleTexture","_releaseTexture","decoding","close","_FileToolsLoadImage","onComplete","compression","textureType","_unpackFlipY","UNPACK_FLIP_Y_WEBGL","_getUnpackAlignement","UNPACK_ALIGNMENT","_getTextureTarget","TEXTURE_CUBE_MAP","TEXTURE_3D","isMultiview","TEXTURE_2D_ARRAY","filters","_setTextureParameterInteger","TEXTURE_MAG_FILTER","TEXTURE_MIN_FILTER","updateTextureWrappingMode","TEXTURE_WRAP_S","_getTextureWrapMode","TEXTURE_WRAP_T","TEXTURE_WRAP_R","_setupDepthStencilTexture","internalTexture","generateStencil","bilinearFiltering","comparisonFunction","layers","_generateDepthBuffer","_generateStencilBuffer","_comparisonFunction","samplingParameters","texParameteri","CLAMP_TO_EDGE","TEXTURE_COMPARE_FUNC","TEXTURE_COMPARE_MODE","COMPARE_REF_TO_TEXTURE","_uploadCompressedDataToTextureDirectly","compressedTexImage2D","_uploadDataToTextureDirectly","babylonInternalFormat","useTextureWidthAndHeight","_getWebGLTextureType","_getRGBABufferInternalSizedFormat","lodMaxWidth","lodMaxHeight","updateTextureData","xOffset","yOffset","texSubImage2D","_uploadArrayBufferViewToTexture","bindTarget","_prepareWebGLTextureContinuation","processFunction","needPOTTextures","GetExponentOfTwo","_setupFramebufferDepthAttachments","generateStencilBuffer","generateDepthBuffer","DEPTH_STENCIL","depthFormat","DEPTH_COMPONENT16","DEPTH_COMPONENT32F","STENCIL_INDEX8","STENCIL_ATTACHMENT","_releaseFramebufferObjects","deleteFramebuffer","_depthStencilBuffer","deleteRenderbuffer","_MSAARenderBuffer","_deleteTexture","unbindAllTextures","deleteTexture","_setProgram","useProgram","_activateCurrentTexture","activeTexture","TEXTURE0","forTextureDataUpdate","wasPreviouslyBound","isTextureForRendering","_associatedChannel","bindTexture","_colorTextureArray","_bindSamplerUniformToChannel","_setTexture","sourceSlot","_currentState","REPEAT","MIRRORED_REPEAT","isPartOfTextureArray","video","emptyCubeTexture","emptyTexture3D","emptyTexture2DArray","emptyTexture","needToBind","textureWrapMode","_setAnisotropicLevel","_textureUnits","anisotropicFilterExtension","_cachedAnisotropicFilteringLevel","_setTextureParameterFloat","TEXTURE_MAX_ANISOTROPY_EXT","parameter","texParameterf","releaseEffects","attachContextLostEvent","attachContextRestoredEvent","getError","_canRenderToFramebuffer","NO_ERROR","successful","fb","createFramebuffer","status","checkFramebufferStatus","FRAMEBUFFER_COMPLETE","readFormat","readType","UNSIGNED_SHORT_4_4_4_4","UNSIGNED_SHORT_5_5_5_1","UNSIGNED_SHORT_5_6_5","HALF_FLOAT","UNSIGNED_INT_2_10_10_10_REV","UNSIGNED_INT_10F_11F_11F_REV","UNSIGNED_INT_5_9_9_9_REV","FLOAT_32_UNSIGNED_INT_24_8_REV","ALPHA","LUMINANCE","LUMINANCE_ALPHA","RED","RG","RED_INTEGER","RG_INTEGER","RGB_INTEGER","RGBA_INTEGER","R8_SNORM","RG8_SNORM","RGB8_SNORM","R8I","RG8I","RGB8I","RGBA8I","RGBA8_SNORM","R8","RG8","RGB8","RGBA8","R8UI","RG8UI","RGB8UI","RGBA8UI","R16I","RG16I","RGB16I","RGBA16I","R16UI","RG16UI","RGB16UI","RGBA16UI","R32I","RG32I","RGB32I","RGBA32I","R32UI","RG32UI","RGB32UI","RGBA32UI","R32F","RG32F","RGB32F","R16F","RG16F","RGB16F","RGB565","R11F_G11F_B10F","RGB9_E5","RGBA4","RGB5_A1","RGB10_A2","RGB10_A2UI","_getRGBAMultiSampleBufferFormat","_FileToolsLoadFile","hasAlpha","numChannels","isSupported","_isSupported","tempcanvas","WebGLRenderingContext","CeilingPOT","FloorPOT","NearestPOT","pot","requestAnimationFrame","msRequestAnimationFrame","webkitRequestAnimationFrame","mozRequestAnimationFrame","oRequestAnimationFrame","CollisionsEpsilon","DomManagement","firstChild","nodeType","textContent","PerformanceMonitor","frameSampleSize","_enabled","_rollingFrameTime","RollingAverage","sampleFrame","timeMs","_lastFrameTimeMs","dt","average","variance","history","isSaturated","_samples","delta","bottomValue","_pos","_sampleCount","_m2","_wrapPosition","setAlphaConstants","noDepthWriteChange","alphaBlend","ONE","ONE_MINUS_SRC_ALPHA","SRC_ALPHA","ZERO","ONE_MINUS_SRC_COLOR","DST_COLOR","CONSTANT_COLOR","ONE_MINUS_CONSTANT_COLOR","CONSTANT_ALPHA","ONE_MINUS_CONSTANT_ALPHA","DST_ALPHA","ONE_MINUS_DST_COLOR","ONE_MINUS_DST_ALPHA","depthCullingState","getAlphaMode","setAlphaEquation","equation","FUNC_ADD","FUNC_SUBTRACT","FUNC_REVERSE_SUBTRACT","getAlphaEquation","Engine","enableOfflineSupport","disableManifestCheck","onNewSceneAddedObservable","postProcesses","isPointerLock","onResizeObservable","onCanvasBlurObservable","onCanvasFocusObservable","onCanvasPointerOutObservable","onBeginFrameObservable","customAnimationFrameRequester","onEndFrameObservable","onBeforeShaderCompilationObservable","onAfterShaderCompilationObservable","_deterministicLockstep","_lockstepMaxSteps","_timeStep","_fps","_deltaTime","_drawCalls","canvasTabIndex","disablePerformanceMonitorInBackground","_performanceMonitor","canvas_1","_onCanvasFocus","_onCanvasBlur","_onBlur","_onFocus","_onCanvasPointerOut","ev","hostWindow","anyDoc_1","_onFullscreenChange","fullscreen","mozFullScreen","webkitIsFullScreen","msIsFullScreen","_pointerLockRequested","_RequestPointerlock","_onPointerLockChange","mozPointerLockElement","webkitPointerLockElement","msPointerLockElement","pointerLockElement","AudioEngineFactory","_connectVREvents","OfflineProviderFactory","doNotHandleTouchAction","_disableTouchAction","_prepareVRComponent","autoEnableWebVR","initWebVR","NpmPackage","MarkAllMaterialsAsDirty","engineIndex","sceneIndex","DefaultLoadingScreenFactory","_RescalePostProcessFactory","getInputElement","viewportOwner","getScreenAspectRatio","getRenderingCanvasClientRect","getInputElementClientRect","isDeterministicLockStep","getLockstepMaxSteps","getTimeStep","generateMipMapsForCubemap","culling","reverseSide","BACK","FRONT","setZOffset","CW","CCW","getZOffset","setDepthBuffer","getDepthWrite","getStencilBuffer","setStencilBuffer","getStencilMask","setStencilMask","getStencilFunction","getStencilFunctionReference","getStencilFunctionMask","setStencilFunction","setStencilFunctionReference","setStencilFunctionMask","getStencilOperationFail","getStencilOperationDepthFail","getStencilOperationPass","setStencilOperationFail","operation","setStencilOperationDepthFail","setStencilOperationPass","setDitheringState","DITHER","setRasterizerState","RASTERIZER_DISCARD","getDepthFunction","setDepthFunction","setDepthFunctionToGreater","setDepthFunctionToGreaterOrEqual","GEQUAL","setDepthFunctionToLess","LESS","setDepthFunctionToLessOrEqual","cacheStencilState","_cachedStencilBuffer","_cachedStencilFunction","_cachedStencilMask","_cachedStencilOperationPass","_cachedStencilOperationFail","_cachedStencilOperationDepthFail","_cachedStencilReference","restoreStencilState","setDirectViewport","currentViewport","scissorClear","enableScissor","disableScissor","SCISSOR_TEST","scissor","_submitVRFrame","disableVR","isVRPresenting","_requestVRFrame","_loadFileAsync","getVertexShaderSource","shaders","getAttachedShaders","getShaderSource","getFragmentShaderSource","_textures","_currentRenderTextureInd","_outputTexture","_convertRGBtoRGBATextureData","rgbData","rgbaData","_rebuildGeometries","_rebuildTextures","_renderFrame","_renderViews","requestID","switchFullscreen","requestPointerLock","exitFullscreen","enterFullscreen","_RequestFullscreen","_ExitFullscreen","enterPointerlock","exitPointerlock","_ExitPointerlock","_measureFps","camIndex","cameras","dataLength","subarray","transformFeedback","deleteTransformFeedback","createTransformFeedback","bindTransformFeedback","setTranformFeedbackVaryings","rtt","createRenderTargetTexture","_rescalePostProcess","onApply","hostingScene","postProcessManager","directRender","copyTexImage2D","getFps","getDeltaTime","averageFPS","instantaneousFrameTime","_uploadImageToTexture","image","arrayBuffer","updateRenderTargetTextureSampleCount","colorRenderbuffer","updateTextureComparisonFunction","createInstancesBuffer","capacity","deleteInstancesBuffer","_clientWaitAsync","sync","flags","interval_ms","res","clientWaitSync","WAIT_FAILED","TIMEOUT_EXPIRED","_readPixelsAsync","outputBuffer","buf","PIXEL_PACK_BUFFER","STREAM_READ","fenceSync","SYNC_GPU_COMMANDS_COMPLETE","deleteSync","getBufferSubData","_dummyFramebuffer","dummy","hideLoadingUI","touchAction","msTouchAction","displayLoadingUI","loadingScreen","_loadingScreen","loadingUIText","loadingUIBackgroundColor","msRequestPointerLock","mozRequestPointerLock","webkitRequestPointerLock","anyDoc","exitPointerLock","msExitPointerLock","mozExitPointerLock","webkitExitPointerLock","requestFunction","requestFullscreen","msRequestFullscreen","webkitRequestFullscreen","mozRequestFullScreen","mozCancelFullScreen","webkitCancelFullScreen","msCancelFullScreen","ALPHA_DISABLE","ALPHA_ADD","ALPHA_COMBINE","ALPHA_SUBTRACT","ALPHA_MULTIPLY","ALPHA_MAXIMIZED","ALPHA_ONEONE","ALPHA_PREMULTIPLIED","ALPHA_PREMULTIPLIED_PORTERDUFF","ALPHA_INTERPOLATE","ALPHA_SCREENMODE","DELAYLOADSTATE_NONE","DELAYLOADSTATE_LOADED","DELAYLOADSTATE_LOADING","DELAYLOADSTATE_NOTLOADED","NEVER","EQUAL","NOTEQUAL","INCR","DECR","INVERT","INCR_WRAP","DECR_WRAP","TEXTURE_CLAMP_ADDRESSMODE","TEXTURE_WRAP_ADDRESSMODE","TEXTURE_MIRROR_ADDRESSMODE","TEXTUREFORMAT_ALPHA","TEXTUREFORMAT_LUMINANCE","TEXTUREFORMAT_LUMINANCE_ALPHA","TEXTUREFORMAT_RGB","TEXTUREFORMAT_RGBA","TEXTUREFORMAT_RED","TEXTUREFORMAT_R","TEXTUREFORMAT_RG","TEXTUREFORMAT_RED_INTEGER","TEXTUREFORMAT_R_INTEGER","TEXTUREFORMAT_RG_INTEGER","TEXTUREFORMAT_RGB_INTEGER","TEXTUREFORMAT_RGBA_INTEGER","TEXTURETYPE_UNSIGNED_BYTE","TEXTURETYPE_UNSIGNED_INT","TEXTURETYPE_FLOAT","TEXTURETYPE_HALF_FLOAT","TEXTURETYPE_BYTE","TEXTURETYPE_SHORT","TEXTURETYPE_UNSIGNED_SHORT","TEXTURETYPE_INT","TEXTURETYPE_UNSIGNED_INTEGER","TEXTURETYPE_UNSIGNED_SHORT_4_4_4_4","TEXTURETYPE_UNSIGNED_SHORT_5_5_5_1","TEXTURETYPE_UNSIGNED_SHORT_5_6_5","TEXTURETYPE_UNSIGNED_INT_2_10_10_10_REV","TEXTURETYPE_UNSIGNED_INT_24_8","TEXTURETYPE_UNSIGNED_INT_10F_11F_11F_REV","TEXTURETYPE_UNSIGNED_INT_5_9_9_9_REV","TEXTURETYPE_FLOAT_32_UNSIGNED_INT_24_8_REV","TEXTURE_NEAREST_SAMPLINGMODE","TEXTURE_BILINEAR_SAMPLINGMODE","TEXTURE_TRILINEAR_SAMPLINGMODE","TEXTURE_NEAREST_NEAREST_MIPLINEAR","TEXTURE_LINEAR_LINEAR_MIPNEAREST","TEXTURE_LINEAR_LINEAR_MIPLINEAR","TEXTURE_NEAREST_NEAREST_MIPNEAREST","TEXTURE_NEAREST_LINEAR_MIPNEAREST","TEXTURE_NEAREST_LINEAR_MIPLINEAR","TEXTURE_NEAREST_LINEAR","TEXTURE_NEAREST_NEAREST","TEXTURE_LINEAR_NEAREST_MIPNEAREST","TEXTURE_LINEAR_NEAREST_MIPLINEAR","TEXTURE_LINEAR_LINEAR","TEXTURE_LINEAR_NEAREST","TEXTURE_EXPLICIT_MODE","TEXTURE_SPHERICAL_MODE","TEXTURE_PLANAR_MODE","TEXTURE_CUBIC_MODE","TEXTURE_PROJECTION_MODE","TEXTURE_SKYBOX_MODE","TEXTURE_INVCUBIC_MODE","TEXTURE_EQUIRECTANGULAR_MODE","TEXTURE_FIXED_EQUIRECTANGULAR_MODE","TEXTURE_FIXED_EQUIRECTANGULAR_MIRRORED_MODE","SCALEMODE_FLOOR","SCALEMODE_NEAREST","SCALEMODE_CEILING","Material","doNotAdd","checkReadyOnEveryCall","checkReadyOnlyOnce","_backFaceCulling","getRenderTargetTextures","_onUnBindObservable","_onBindObserver","_needDepthPrePass","disableDepthWrite","depthFunction","_fogEnabled","pointSize","_effect","_useUBO","_fillMode","_cachedDepthWriteState","_cachedDepthFunctionState","_indexInSceneMaterialArray","_uniformBuffer","addMaterial","useMaterialMeshMap","MiscDirtyFlag","TextureDirtyFlag","onBindObservable","LineListDrawMode","LineLoopDrawMode","LineStripDrawMode","PointListDrawMode","freeze","markDirty","unfreeze","needAlphaBlending","needAlphaBlendingForMesh","needAlphaTesting","getAlphaTestTexture","overrideOrientation","bindSceneUniformBuffer","sceneUbo","bindToEffect","bindView","getSceneUniformBuffer","bindViewProjection","_shouldTurnAlphaTestOn","_afterBind","_cachedMaterial","_cachedVisibility","getBindedMeshes","meshId","filter","forceCompilation","localOptions","checkReady","_materialDefines","clipPlaneState","forceCompilationAsync","blockMaterialDirtyMechanism","_DirtyCallbackArray","_TextureDirtyCallBack","LightDirtyFlag","_LightsDirtyCallBack","FresnelDirtyFlag","_FresnelDirtyCallBack","AttributesDirtyFlag","_AttributeDirtyCallBack","_MiscDirtyCallBack","_markAllSubMeshesAsDirty","_RunDirtyCallBacks","meshes_2","_markAllSubMeshesAsAllDirty","_AllDirtyCallBack","_markAllSubMeshesAsImageProcessingDirty","_ImageProcessingDirtyCallBack","_markAllSubMeshesAsFresnelDirty","_markAllSubMeshesAsFresnelAndMiscDirty","_FresnelAndMiscDirtyCallBack","_markAllSubMeshesAsLightsDirty","_markAllSubMeshesAsAttributesDirty","_markAllSubMeshesAsMiscDirty","_markAllSubMeshesAsTexturesAndMiscDirty","_TextureAndMiscDirtyCallBack","forceDisposeEffect","forceDisposeTextures","notBoundToMesh","freeProcessedMaterials","removeMaterial","meshes_3","_materialEffect","parsedMaterial","overloadedAlbedo","BABYLON","LegacyPBRMaterial","TriangleStripDrawMode","TriangleFanDrawMode","AllDirtyFlag","markAllAsDirty","markAsImageProcessingDirty","markAsTexturesDirty","markAsFresnelDirty","markAsMiscDirty","markAsLightDirty","markAsAttributesDirty","cb","SmartArray","_GlobalId","compareFn","SmartArrayNoDuplicate","_duplicateId","__smartArrayFlags","pushNoDuplicate","concatWithNoDuplicate","item","tmpRect","tmpRect2","tmpV1","tmpV2","Measure","ArrayTools","itemBuilder","StringDictionary","_count","getOrAddWithFactory","factory","getOrAdd","curVal","getAndRemove","cur","first","AbstractScene","rootNodes","lights","skeletons","animationGroups","morphTargetManagers","geometries","transformNodes","actionManagers","environmentTexture","AddParser","parser","_BabylonFileParsers","GetParser","AddIndividualParser","_IndividualBabylonFileParsers","GetIndividualParser","jsonData","parserName","getNodes","nodes","ActionEvent","pointerX","pointerY","meshUnderPointer","sourceEvent","additionalData","CreateNew","CreateNewFromSprite","CreateNewFromScene","CreateNewFromPrimitive","prim","pointerPos","AbstractActionManager","isRecursive","Triggers","t_int","HasSpecificTrigger","trigger","_ClickInfo","_singleClick","_doubleClick","_hasSwiped","_ignore","InputManager","_wheelEventName","_meshPickProceed","_currentPickResult","_previousPickResult","_totalPointersPressed","_doubleClickOccured","_pointerX","_pointerY","_startingPointerPosition","_previousStartingPointerPosition","_startingPointerTime","_previousStartingPointerTime","_pointerCaptures","_pointerOverMesh","_unTranslatedPointerX","_unTranslatedPointerY","_updatePointerPosition","canvasRect","clientX","clientY","_processPointerMove","pickResult","tabIndex","doNotHandleCursors","cursor","defaultCursor","isMeshPicked","hit","pickedMesh","setPointerOverMesh","hasPointerTriggers","_pointerMoveStage","onPointerMove","onPointerObservable","pi","_setRayOnPointerInfo","pointerInfo","_pickingUnavailable","createPickingRay","_checkPrePointerObservable","onPrePointerObservable","simulatePointerMove","pointerEventInit","simulatePointerDown","_processPointerDown","_pickedDownMesh","_getActionManagerForTrigger","hasPickTriggers","processTrigger","button","hasSpecificTrigger","pick","cameraToUseForPointers","now","LongPressDelay","_isPointerSwiping","_pointerDownStage","onPointerDown","DragMovementThreshold","simulatePointerUp","doubleTap","clickInfo","doubleClick","singleClick","_processPointerUp","_pickedUpMesh","onPointerPick","ignore","type_1","hasSwiped","doubleClickActionManager","_pointerUpStage","pickedDownActionManager","onPointerUp","isPointerCaptured","attachUp","attachDown","attachMove","elementToAttachTo","_initActionManager","act","pointerDownPredicate","_delayedSimpleClick","btn","DoubleClickDelay","_previousButtonPressed","_initClickEvent","obs1","obs2","checkPicking","needToIgnoreNext","checkSingleClickImmediately","ExclusiveDoubleClickMode","_previousDelayedSimpleClickTimeout","_delayedSimpleClickTimeout","checkDoubleClick","clearTimeout","pointerMovePredicate","enablePointerMoveEvents","constantlyUpdateMeshUnderPointer","preventDefaultOnPointerDown","focus","preventDefaultOnPointerUp","pointerUpPredicate","HasTriggers","_onKeyDown","KEYDOWN","onPreKeyboardObservable","onKeyboardObservable","_onKeyUp","KEYUP","_onCanvasFocusObserver","activeElement","_onCanvasBlurObserver","onmousewheel","getPointerOverMesh","UniqueIdGenerator","_UniqueIdCounter","Scene","_inputManager","_isScene","_blockEntityCollection","autoClear","autoClearDepthAndStencil","ambientColor","_environmentIntensity","_forceWireframe","_skipFrustumClipping","_forcePointsCloud","animationsEnabled","_animationPropertiesOverride","useConstantAnimationDeltaTime","disableOfflineSupportExceptionRules","_onBeforeRenderObserver","onAfterRenderCameraObservable","_onAfterRenderObserver","onBeforeAnimationsObservable","onAfterAnimationsObservable","onBeforeDrawPhaseObservable","onAfterDrawPhaseObservable","onReadyObservable","onBeforeCameraRenderObservable","_onBeforeCameraRenderObserver","onAfterCameraRenderObservable","_onAfterCameraRenderObserver","onBeforeActiveMeshesEvaluationObservable","onAfterActiveMeshesEvaluationObservable","onBeforeParticlesRenderingObservable","onAfterParticlesRenderingObservable","onDataLoadedObservable","onNewCameraAddedObservable","onCameraRemovedObservable","onNewLightAddedObservable","onLightRemovedObservable","onNewGeometryAddedObservable","onGeometryRemovedObservable","onNewTransformNodeAddedObservable","onTransformNodeRemovedObservable","onNewMeshAddedObservable","onMeshRemovedObservable","onNewSkeletonAddedObservable","onSkeletonRemovedObservable","onNewMaterialAddedObservable","onMaterialRemovedObservable","onNewTextureAddedObservable","onBeforeRenderTargetsRenderObservable","onAfterRenderTargetsRenderObservable","onBeforeStepObservable","onAfterStepObservable","onActiveCameraChanged","onBeforeRenderingGroupObservable","onAfterRenderingGroupObservable","onAnimationFileImportedObservable","_registeredForLateAnimationBindings","_useRightHandedSystem","_timeAccumulator","_currentStepId","_currentInternalStep","_fogMode","_shadowsEnabled","_lightsEnabled","activeCameras","_texturesEnabled","particlesEnabled","spritesEnabled","_skeletonsEnabled","lensFlaresEnabled","collisionsEnabled","gravity","postProcessesEnabled","renderTargetsEnabled","dumpNextRenderTargets","importedMeshesFiles","probesEnabled","_meshesForIntersections","proceduralTexturesEnabled","_activeParticles","_activeBones","_animationTime","animationTimeScale","_frameId","_executeWhenReadyTimeoutId","_intermediateRendering","_viewUpdateFlag","_projectionUpdateFlag","_toBeDisposed","_pendingData","dispatchAllSubMeshesOfActiveMeshes","_processedMaterials","_renderTargets","_activeParticleSystems","_activeSkeletons","_softwareSkinnedMeshes","_activeAnimatables","requireLightSorting","_components","_serializableComponents","_transientComponents","_beforeCameraUpdateStage","_beforeClearStage","_gatherRenderTargetsStage","_gatherActiveCameraRenderTargetsStage","_isReadyForMeshStage","_beforeEvaluateActiveMeshStage","_evaluateSubMeshStage","_activeMeshStage","_cameraDrawRenderTargetStage","_beforeCameraDrawStage","_beforeRenderTargetDrawStage","_beforeRenderingGroupDrawStage","_afterRenderingGroupDrawStage","_afterCameraDrawStage","_afterRenderTargetDrawStage","_afterRenderStage","geometriesByUniqueId","_defaultMeshCandidates","_defaultSubMeshCandidates","_preventFreeActiveMeshesAndRenderingGroups","_activeMeshesFrozen","_skipEvaluateActiveMeshesCompletely","_allowPostProcessClearColor","getDeterministicFrameTime","_blockMaterialDirtyMechanism","fullOptions","useGeometryUniqueIdsMap","virtual","_renderingManager","_createUbo","_imageProcessingConfiguration","setDefaultCandidateProviders","DefaultMaterialFactory","CollisionCoordinatorFactory","_environmentTexture","unTranslatedPointer","setStepId","newStepId","getStepId","getInternalStep","_activeCamera","_defaultMaterial","_collisionCoordinator","init","_registerTransientComponents","register","_addComponent","serializableComponent","addFromContainer","_getDefaultMeshCandidates","_getDefaultSubMeshCandidates","getActiveMeshCandidates","getActiveSubMeshCandidates","getIntersectingSubMeshCandidates","getCollidingSubMeshCandidates","getCachedMaterial","getCachedEffect","_cachedEffect","getCachedVisibility","isCachedMaterialInvalid","getActiveIndices","getActiveParticles","getActiveBones","getAnimationRatio","_animationRatio","incrementRenderId","_sceneUbo","addUniform","_executeOnceBeforeRender","execFunc","executeOnceBeforeRender","wasLoading","isLoading","getWaitingItemsCount","executeWhenReady","whenReadyAsync","resetLastAnimationTimeFrame","_animationTimeLast","_viewMatrix","setTransformMatrix","viewL","projectionL","viewR","projectionR","_multiviewSceneUbo","useUbo","_updateMultiviewUbo","UniqueId","addMesh","newMesh","recursive","_resyncLightSources","_addToSceneRootNodes","getChildMeshes","removeMesh","toRemove","_removeFromSceneRootNodes","addTransformNode","newTransformNode","_indexInSceneTransformNodesArray","removeTransformNode","lastNode","removeSkeleton","removeMorphTargetManager","removeLight","_removeLightSource","sortLightsByPriority","index2","removeParticleSystem","removeAnimation","animationName","targetMask","removeAnimationGroup","removeMultiMaterial","lastMaterial","removeActionManager","removeTexture","addLight","newLight","CompareLightsPriority","newCamera","addSkeleton","newSkeleton","addParticleSystem","newParticleSystem","addAnimation","newAnimation","addAnimationGroup","newAnimationGroup","addMultiMaterial","newMaterial","addMorphTargetManager","newMorphTargetManager","addGeometry","newGeometry","addActionManager","newActionManager","newTexture","switchActiveCamera","setActiveCameraByID","setActiveCameraByName","getCameraByName","getAnimationGroupByName","getMaterialByUniqueID","getMaterialByID","getLastMaterialByID","getMaterialByName","getTextureByUniqueID","getCameraByUniqueID","getBoneByID","skeletonIndex","boneIndex","getBoneByName","getLightByName","getLightByID","getLightByUniqueID","getParticleSystemByID","_getGeometryByUniqueID","lastGeometry","getGeometries","getMeshByID","getMeshesByID","getTransformNodeByID","getTransformNodeByUniqueID","getTransformNodesByID","getMeshByUniqueID","getLastEntryByID","getNodeByID","transformNode","bone","getNodeByName","getMeshByName","getTransformNodeByName","getSkeletonByUniqueId","getSkeletonById","getSkeletonByName","getMorphTargetById","managerIndex","numTargets","addExternalData","_externalData","getExternalData","getOrAddExternalDataWithFactory","removeExternalData","_evaluateSubMesh","initialMesh","hasInstances","alwaysSelectAsActiveMesh","hasRenderTargetTextures","dispatch","freeActiveMeshes","freeRenderingGroups","blockfreeActiveMeshesAndRenderingGroups","freezeActiveMeshes","skipEvaluateActiveMeshes","_evaluateActiveMeshes","unfreezeActiveMeshes","len_1","isBlocked","hasSpecificTriggers2","meshToRender","customLODSelector","BILLBOARDMODE_NONE","_activate","_actAsRegularMesh","_activeMesh","_postActivate","particleIndex","particleSystem","isStarted","animate","dispatchParticles","prepare","updateTransformMatrix","_bindFrameBuffer","_multiviewTexture","_renderForCamera","rigParent","softwareSkinnedMeshIndex","needRebind","renderIndex","renderTarget","_shouldRender","hasSpecialRenderTargetCamera","_prepareFrame","_finalizeFrame","_processSubCameras","_useMultiviewToSingleView","_renderMultiviewToSingleView","_checkIntersections","actionIndex","parameters","getTriggerParameter","otherMesh","areIntersecting","intersectsMesh","usePreciseIntersection","currentIntersectionInProgress","_intersectionsInProgress","_executeCurrent","parameterMesh","_advancePhysicsEngineStep","step","_animate","deltaTime","MinDeltaTime","MaxDeltaTime","defaultFrameTime","defaultFPS","stepsTaken","maxSubSteps","internalSteps","updateCameras","ignoreAnimations","fetchNewFrame","currentActiveCamera","customIndex","afterRender","freezeMaterials","unfreezeMaterials","beforeRender","stopAllAnimations","clearCachedVertexData","meshIndex","vbName","cleanCachedTextureBuffer","baseTexture","getWorldExtends","filterPredicate","boundingInfo","minBox","maxBox","cameraViewSpace","createPickingRayToRef","createPickingRayInCameraSpace","createPickingRayInCameraSpaceToRef","fastCheck","trianglePredicate","pickWithRay","multiPick","multiPickWithRay","_getByTags","list","listByTags","getMeshesByTags","getCamerasByTags","getLightsByTags","getMaterialByTags","setRenderingOrder","renderingGroupId","opaqueSortCompareFn","alphaTestSortCompareFn","transparentSortCompareFn","setRenderingAutoClearDepthStencil","autoClearDepthStencil","getAutoClearDepthStencilSetup","useOfflineSupport","_requestFile","onOpened","RequestFile","_requestFileAsync","_readFile","_readFileAsync","FOGMODE_EXP","FOGMODE_EXP2","FOGMODE_LINEAR","Container","_measureForChildren","_background","_adaptWidthToChildren","_adaptHeightToChildren","logLayoutCycleErrors","maxLayoutCycle","getChildByName","getChildByType","typeName","containsControl","control","addControl","clearControls","children_1","_cleanControlAfterRemoval","wasAdded","_localDraw","shadowColor","fillRect","_beforeLayout","computedWidth","computedHeight","adaptWidthToChildren","adaptHeightToChildren","_postMeasure","_changeCursor","BoundingBox","worldMatrix","vectors","extendSize","extendSizeWorld","directions","vectorsWorld","minX","minY","maxX","maxY","factor","tmpVectors","TmpVector3","diff","newRadius","minWorld","maxWorld","IsInFrustum","IsCompletelyInFrustum","intersectsPoint","pointX","pointY","pointZ","intersectsSphere","sphere","IntersectsSphere","radiusWorld","intersectsMinMax","myMin","myMax","myMinX","myMinY","myMinZ","myMaxX","myMaxY","myMaxZ","Intersects","box0","box1","minPoint","maxPoint","sphereCenter","sphereRadius","boundingVectors","frustumPlane","dotCoordinate","canReturnFalse","_result0","_result1","computeBoxExtents","box","axisOverlap","BoundingInfo","_isLocked","centerOn","extend","isCenterInFrustum","_checkCollision","collider","_canDoCollision","intersects","precise","Node","_doNotSerialize","_isParentEnabled","_parentUpdateId","_parentNode","_worldMatrixDeterminant","_worldMatrixDeterminantIsDirty","_sceneRootNodesIndex","_isNode","_behaviors","AddNodeConstructor","_NodeConstructors","previousParentNode","_syncParentEnabledState","lastIdx","animationPropertiesOverride","addBehavior","behavior","attachImmediately","attach","removeBehavior","detach","getBehaviorByName","isSynchronized","initialCall","_markSyncedWithParent","checkAncestors","isDescendantOf","ancestor","_getDescendants","node","cullingStrategy","getChildren","_setReady","getAnimationByName","_AnimationRangeFactory","nAnimations","createRange","deleteAnimationRange","deleteFrames","deleteRange","getAnimationRange","getAnimationRanges","animationRanges","speedRatio","onAnimationEnd","range","serializationRanges","localRange","nodes_1","parsedNode","getHierarchyBoundingVectors","includeDescendants","thisAbstractMesh","descendants_1","childMesh","Space","Axis","FilesInputStore","FilesToLoad","RetryStrategy","ExponentialBackoff","maxRetries","baseInterval","retryIndex","BaseError","_setPrototypeOf","proto","LoadFileError","RequestFileError","ReadFileError","FileTools","_CleanUrl","crossOrigin","usingObjectURL","Image","createImageBitmap","imgBmp","loadHandler","errorHandler","err","noOfflineSupport","enableTexturesOffline","loadImage","textureName","decodeURIComponent","blobURL","readAsArrayBuffer","readAsText","loadUrl","aborted","fileRequest","requestFile","retryHandle","readyState","XMLHttpRequest","DONE","retryLoop","responseType","onLoadEnd","onReadyStateChange","IsFileURL","response","responseText","retryStrategy","waitTime","statusText","send","enableSceneOffline","noOfflineSupport_1","loadFile","location","protocol","PrecisionDate","InternalTextureSource","InternalTexture","delayAllocation","baseDepth","Unknown","_bufferView","_bufferViewArray","_bufferViewArrayArray","_extension","_files","_attachments","_isDisabled","_compression","_sphericalPolynomial","_depthStencilTextureArray","_references","updateSize","proxy","_swapAndDie","Raw","Raw3D","Raw2DArray","Dynamic","createDynamicTexture","updateDynamicTexture","RenderTarget","createRenderTargetCubeTexture","size_1","Depth","depthTextureOptions","createDepthStencilTexture","Cube","createCubeTexture","CubeRaw","CubeRawRGBD","_UpdateRGBDAsync","CubePrefiltered","createPrefilteredCubeTexture","sphericalPolynomial","lodScale","lodOffset","TransformNode","isPure","_forward","_forwardInverted","_up","_right","_rightInverted","_rotationQuaternion","_scaling","_transformToBoneReferal","_isAbsoluteSynced","_billboardMode","_preserveParentRotationForBillboard","scalingDeterminant","_infiniteDistance","ignoreNonUniformScaling","reIntegrateRotationIntoRotationQuaternion","_poseMatrix","_localMatrix","_usePivotMatrix","_absolutePosition","_absoluteScaling","_absoluteRotationQuaternion","_pivotMatrix","_isWorldMatrixFrozen","onAfterWorldMatrixUpdateObservable","_nonUniformScaling","newRotation","newScaling","updatePoseMatrix","getPoseMatrix","pivotMatrixUpdated","localMatrixUpdated","_syncAbsoluteScalingAndRotation","postMultiplyPivotMatrix","_pivotMatrixInverse","newWorldMatrix","unfreezeWorldMatrix","getAbsolutePosition","setAbsolutePosition","absolutePosition","absolutePositionX","absolutePositionY","absolutePositionZ","invertParentWorldMatrix","setPositionWithLocalVector","getPositionExpressedInLocalSpace","invLocalWorldMatrix","locallyTranslate","lookAt","targetPoint","yawCor","pitchCor","rollCor","space","LOCAL","dv","_lookAtVectorCache","setDirection","WORLD","rotationMatrix","parentRotationMatrix","quaternionRotation","setPivotPoint","tmat","getPivotPoint","getPivotPointToRef","getAbsolutePivotPoint","getAbsolutePivotPointToRef","setParent","quatRotation","diffMatrix","invParentMatrix","_updateNonUniformScalingState","attachToBone","affectedTransformNode","detachFromBone","_rotationAxisCache","rotateAround","tmpVector","finalScale","finalTranslation","finalRotation","translationMatrix","translationMatrixInv","displacementVector","tempV3","addRotation","accumulation","_getEffectiveParent","useBillboardPosition","BILLBOARDMODE_USE_POSITION","useBillboardPath","preserveParentRotationForBillboard","BILLBOARDMODE_X","BILLBOARDMODE_Y","BILLBOARDMODE_Z","cameraWorldMatrix","cameraGlobalPosition","scaleMatrix","translation_1","storedTranslation","BILLBOARDMODE_ALL","eulerAngles","isNonUniform","_afterComputeWorldMatrix","independentOfChildren","bakedMatrix","tmpRotationQuaternion","registerAfterWorldMatrixUpdate","unregisterAfterWorldMatrixUpdate","getPositionInCameraSpace","getDistanceToCamera","currentSerializationObject","parsedTransformNode","transformNodes_1","normalizeToUnitCube","ignoreRotation","storedRotation","storedRotationQuaternion","sizeVec","maxDimension","isUndefined","isObject","isPlainObject","isFunction","isArrayBuffer","isBuffer","isFormData","FormData","isArrayBufferView","isString","isNumber","isDate","isFile","isBlob","isStream","pipe","isURLSearchParams","URLSearchParams","isStandardBrowserEnv","product","assignValue","thisArg","stripBOM","StringTools","EndsWith","suffix","Decode","TextDecoder","decode","fromCharCode","chr1","chr2","chr3","enc1","enc2","enc3","enc4","keyStr","output","bytes","NaN","charAt","BaseSubMesh","setEffect","SubMesh","renderingMesh","createBoundingBox","_linesIndexBuffer","_lastColliderWorldVertices","_lastColliderTransformMatrix","_alphaIndex","_distanceToCamera","_currentMaterial","_mesh","_renderingMesh","_trianglePlanes","IsGlobal","setBoundingInfo","getMesh","getRenderingMesh","rootMaterial","getSubMaterial","updateBoundingInfo","linesIndices","canIntersects","intersectsBox","checkStopper","_intersectLines","intersectionThreshold","_intersectUnIndexedLines","_intersectUnIndexedTriangles","_intersectTriangles","intersectInfo","intersectionSegment","faceId","faceID","indexA","indexB","indexC","currentIntersectInfo","intersectsTriangle","newRenderingMesh","startIndex","minVertexIndex","maxVertexIndex","_checkCollisions","_collisionMask","_collisionGroup","_collider","_oldPositionForCollisions","_diffPositionForCollisions","facetNb","partitioningSubdivisions","partitioningBBoxRatio","facetDataEnabled","facetParameters","facetDepthSort","facetDepthSortEnabled","_InternalAbstractMeshDataInfo","_hasVertexAlpha","_useVertexColors","_numBoneInfluencers","_applyFog","_receiveShadows","_facetData","_visibility","_skeleton","_layerMask","_computeBonesUsingShaders","AbstractMesh","CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY","onCollideObservable","onCollisionPositionChangeObservable","onMaterialChangedObservable","definedFacingForward","_occlusionQuery","_renderingGroup","_material","outlineColor","outlineWidth","useOctreeForRenderingSelection","useOctreeForPicking","useOctreeForCollisions","doNotSyncBoundingInfo","_meshCollisionData","ellipsoid","ellipsoidOffset","edgesWidth","edgesColor","_edgesRenderer","_lightSources","_bonesTransformMatrices","_transformMatrixTexture","onRebuildObservable","_onCollisionPositionChange","collisionId","collidedMesh","nb","facetDepthSortFrom","_markSubMeshesAsMiscDirty","_onCollideObserver","_onCollisionPositionChangeObserver","_markSubMeshesAsLightDirty","needInitialSkinMatrix","_unregisterMeshWithPoseMatrix","_registerMeshWithPoseMatrix","canAffectMesh","_resyncLightSource","isIn","_markSubMeshesAsDirty","skeletonsEnabled","intermediateRendering","movePOV","amountRight","amountUp","amountForward","calcMovePOV","rotMatrix","translationDelta","defForwardMult","rotatePOV","flipBack","twirlClockwise","tiltRight","calcRotatePOV","tempVector","overrideMesh","collisionEnabled","moveWithCollisions","displacement","coordinator","collisionCoordinator","createCollider","_radius","getNewPosition","_collideForSubMesh","transformMatrix","_collide","_processCollisionsForSubMeshes","collisionsScalingMatrix","collisionsTransformMatrix","pickingInfo","worldOrigin","direction","pickedPoint","bu","bv","includedOnlyMeshes","excludedMeshes","isOcclusionQueryInProgress","disableFacetData","addChild","_initFacetData","updateFacetData","depthSortedIndices","needs32bits","facetDepthSortFunction","f1","f2","depthSortedFacet","invertedMatrix","facetDepthSortOrigin","getFacetLocalNormals","getFacetLocalPositions","getFacetLocalPartitioning","depthSort","sind","facetData","getFacetPosition","getFacetPositionToRef","localPos","getFacetNormal","norm","getFacetNormalToRef","localNorm","getFacetsAtLocalCoordinates","getClosestFacetAtCoordinates","projected","checkFace","facing","invMat","invVect","closest","getClosestFacetAtLocalCoordinates","tmpx","tmpy","tmpz","t0","projx","projy","projz","facetsInBlock","fib","shortest","tmpDistance","getFacetDataParameters","createNormals","alignWithNormal","upDirection","axisX","axisZ","disableEdgesRendering","enableEdgesRendering","checkVerticesInsteadOfIndices","OCCLUSION_TYPE_NONE","OCCLUSION_TYPE_OPTIMISTIC","OCCLUSION_TYPE_STRICT","OCCLUSION_ALGORITHM_TYPE_ACCURATE","OCCLUSION_ALGORITHM_TYPE_CONSERVATIVE","CULLINGSTRATEGY_STANDARD","CULLINGSTRATEGY_OPTIMISTIC_INCLUSION","CULLINGSTRATEGY_OPTIMISTIC_INCLUSION_THEN_BSPHERE_ONLY","Light","diffuse","FALLOFF_DEFAULT","intensity","_range","_inverseSquaredRange","_photometricScale","_intensityMode","INTENSITYMODE_AUTOMATIC","renderPriority","_shadowEnabled","_excludeWithLayerMask","_includeOnlyWithLayerMask","_lightmapMode","_excludedMeshesIds","_includedOnlyMeshesIds","_isLight","_buildUniformLayout","_resyncMeshes","_computePhotometricScale","_markMeshesAsLightDirty","_includedOnlyMeshes","_hookArrayForIncludedOnly","_excludedMeshes","_hookArrayForExcluded","transferTexturesToEffect","iAsString","needUpdate","_alreadyBound","scaledIntensity","getScaledIntensity","updateColor4","bindShadowLight","getTypeID","_shadowGenerator","includeOnlyWithLayerMask","excludeWithLayerMask","excludedMeshesIds","includedOnlyMeshesIds","parsedLight","oldPush","items_1","oldSplice","deleteCount","deleted","deleted_1","_getPhotometricScale","photometricScale","lightTypeID","photometricMode","intensityMode","LIGHTTYPEID_DIRECTIONALLIGHT","INTENSITYMODE_ILLUMINANCE","INTENSITYMODE_LUMINOUSINTENSITY","LIGHTTYPEID_POINTLIGHT","LIGHTTYPEID_SPOTLIGHT","INTENSITYMODE_LUMINOUSPOWER","INTENSITYMODE_LUMINANCE","apexAngleRadians","LIGHTTYPEID_HEMISPHERICLIGHT","_reorderLightsInScene","_renderPriority","LIGHTMAP_SPECULAR","KeyboardEventTypes","KeyboardInfo","KeyboardInfoPre","ClipboardEventTypes","COPY","CUT","PASTE","ClipboardInfo","GetTypeFromCharacter","keyCode","Size","otherSize","PickingInfo","pickedSprite","originMesh","getNormal","useWorldCoordinates","useVerticesNormals","normal0","normal1","normal2","vertex1","vertex2","vertex3","getTextureCoordinates","uv0","uv1","uv2","PushMaterial","_normalMatrix","allowShaderHotSwapping","_activeEffect","bindOnlyNormalMatrix","normalMatrix","_mustRebind","MaterialFlags","_DiffuseTextureEnabled","_AmbientTextureEnabled","_OpacityTextureEnabled","_ReflectionTextureEnabled","_EmissiveTextureEnabled","_SpecularTextureEnabled","_BumpTextureEnabled","_LightmapTextureEnabled","_RefractionTextureEnabled","_ColorGradingTextureEnabled","_FresnelEnabled","_ClearCoatTextureEnabled","_ClearCoatBumpTextureEnabled","_ClearCoatTintTextureEnabled","_SheenTextureEnabled","_AnisotropicTextureEnabled","_ThicknessTextureEnabled","StandardMaterialDefines","MAINUV1","MAINUV2","DIFFUSE","DIFFUSEDIRECTUV","AMBIENT","AMBIENTDIRECTUV","OPACITY","OPACITYDIRECTUV","OPACITYRGB","REFLECTION","EMISSIVE","EMISSIVEDIRECTUV","SPECULAR","SPECULARDIRECTUV","BUMP","BUMPDIRECTUV","PARALLAX","PARALLAXOCCLUSION","SPECULAROVERALPHA","CLIPPLANE","CLIPPLANE2","CLIPPLANE3","CLIPPLANE4","CLIPPLANE5","CLIPPLANE6","ALPHATEST","DEPTHPREPASS","ALPHAFROMDIFFUSE","POINTSIZE","FOG","SPECULARTERM","DIFFUSEFRESNEL","OPACITYFRESNEL","REFLECTIONFRESNEL","REFRACTIONFRESNEL","EMISSIVEFRESNEL","FRESNEL","NORMAL","UV1","UV2","VERTEXCOLOR","VERTEXALPHA","NUM_BONE_INFLUENCERS","BonesPerMesh","BONETEXTURE","INSTANCES","GLOSSINESS","ROUGHNESS","EMISSIVEASILLUMINATION","LINKEMISSIVEWITHDIFFUSE","REFLECTIONFRESNELFROMSPECULAR","LIGHTMAP","LIGHTMAPDIRECTUV","OBJECTSPACE_NORMALMAP","USELIGHTMAPASSHADOWMAP","REFLECTIONMAP_3D","REFLECTIONMAP_SPHERICAL","REFLECTIONMAP_PLANAR","REFLECTIONMAP_CUBIC","USE_LOCAL_REFLECTIONMAP_CUBIC","REFLECTIONMAP_PROJECTION","REFLECTIONMAP_SKYBOX","REFLECTIONMAP_EXPLICIT","REFLECTIONMAP_EQUIRECTANGULAR","REFLECTIONMAP_EQUIRECTANGULAR_FIXED","REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED","INVERTCUBICMAP","LOGARITHMICDEPTH","REFRACTION","REFRACTIONMAP_3D","REFLECTIONOVERALPHA","TWOSIDEDLIGHTING","SHADOWFLOAT","MORPHTARGETS","MORPHTARGETS_NORMAL","MORPHTARGETS_TANGENT","MORPHTARGETS_UV","NONUNIFORMSCALING","PREMULTIPLYALPHA","IMAGEPROCESSING","VIGNETTE","VIGNETTEBLENDMODEMULTIPLY","VIGNETTEBLENDMODEOPAQUE","TONEMAPPING","TONEMAPPING_ACES","CONTRAST","COLORCURVES","COLORGRADING","COLORGRADING3D","SAMPLER3DGREENDEPTH","SAMPLER3DBGRMAP","IMAGEPROCESSINGPOSTPROCESS","IS_REFLECTION_LINEAR","IS_REFRACTION_LINEAR","EXPOSURE","setReflectionMode","modeToEnable","modes_1","StandardMaterial","_diffuseTexture","_ambientTexture","_opacityTexture","_reflectionTexture","_emissiveTexture","_specularTexture","_bumpTexture","_lightmapTexture","_refractionTexture","diffuseColor","specularColor","emissiveColor","specularPower","_useAlphaFromDiffuseTexture","_useEmissiveAsIllumination","_linkEmissiveWithDiffuse","_useSpecularOverAlpha","_useReflectionOverAlpha","_disableLighting","_useObjectSpaceNormalMap","_useParallax","_useParallaxOcclusion","parallaxScaleBias","_roughness","indexOfRefraction","invertRefractionY","alphaCutOff","_useLightmapAsShadowmap","_useReflectionFresnelFromSpecular","_useGlossinessFromSpecularMapAlpha","_maxSimultaneousLights","_invertNormalMapX","_invertNormalMapY","_twoSidedLighting","_worldViewProjectionMatrix","_globalAmbientColor","_rebuildInParallel","_attachImageProcessingConfiguration","ReflectionTextureEnabled","RefractionTextureEnabled","configuration","_imageProcessingObserver","onUpdateParameters","imageProcessingConfiguration","colorCurvesEnabled","colorGradingEnabled","toneMappingEnabled","exposure","contrast","colorGradingTexture","colorCurves","_useLogarithmicDepth","_shouldUseAlphaFromDiffuseTexture","_opacityFresnelParameters","_areTexturesDirty","texturesEnabled","DiffuseTextureEnabled","AmbientTextureEnabled","OpacityTextureEnabled","boundingBoxSize","EmissiveTextureEnabled","LightmapTextureEnabled","SpecularTextureEnabled","BumpTextureEnabled","_areImageProcessingDirty","reflectionTexture","refractionTexture","_areFresnelDirty","FresnelEnabled","_diffuseFresnelParameters","_emissiveFresnelParameters","_refractionFresnelParameters","_reflectionFresnelParameters","lightDisposed","_areLightsDisposed","markAsProcessed","shaderName","uniforms","uniformBuffers","PrepareUniforms","PrepareSamplers","customShaderNameResolve","previousEffect","maxSimultaneousMorphTargets","buildUniformLayout","ubo","needFlag","mustRebind","isSync","diffuseFresnelParameters","leftColor","power","rightColor","opacityFresnelParameters","reflectionFresnelParameters","refractionFresnelParameters","emissiveFresnelParameters","updateFloat2","roughness","updateVector3","boundingBoxPosition","updateFloat3","updateFloat4","updateFloat","updateColor3","BlackReadOnly","applyByPostProcess","activeTextures","ColorGradingTextureEnabled","Plane","magnitude","transposedMatrix","_TmpMatrix","copyFromPoints","point1","point2","point3","invPyth","x1","y1","z1","pyth","isFrontFacingTo","signedDistanceTo","FromPoints","FromPositionAndNormal","SignedDistanceToPlaneFromPositionAndNormal","Frustum","GetNearPlaneToRef","GetFarPlaneToRef","GetLeftPlaneToRef","GetRightPlaneToRef","GetTopPlaneToRef","GetBottomPlaneToRef","WebGLDataBuffer","resource","DataBuffer","Viewport","toGlobal","toGlobalToRef","CanvasGenerator","OffscreenCanvas","PerfCounter","_startMonitoringTime","_min","_max","_average","_lastSecAverage","_current","_totalValueCount","_totalAccumulated","_lastSecAccumulated","_lastSecTime","_lastSecValueCount","newCount","fetchResult","Enabled","_fetchResult","beginMonitoring","endMonitoring","newFrame","currentTime","ColorCurves","_dirty","_tempColor","_globalCurve","_highlightsCurve","_midtonesCurve","_shadowsCurve","_positiveCurve","_negativeCurve","_globalHue","_globalDensity","_globalSaturation","_globalExposure","_highlightsHue","_highlightsDensity","_highlightsSaturation","_highlightsExposure","_midtonesHue","_midtonesDensity","_midtonesSaturation","_midtonesExposure","_shadowsHue","_shadowsDensity","_shadowsSaturation","_shadowsExposure","Bind","positiveUniform","neutralUniform","negativeUniform","getColorGradingDataToRef","density","clamp","applyColorGradingSliderNonlinear","fromHSBToRef","brightness","ImageProcessingConfigurationDefines","ImageProcessingConfiguration","_colorCurvesEnabled","_colorGradingEnabled","_colorGradingWithGreenDepth","_colorGradingBGR","_exposure","_toneMappingEnabled","_toneMappingType","TONEMAPPING_STANDARD","_contrast","vignetteStretch","vignetteCentreX","vignetteCentreY","vignetteWeight","vignetteColor","vignetteCameraFov","_vignetteBlendMode","VIGNETTEMODE_MULTIPLY","_vignetteEnabled","_applyByPostProcess","_updateParameters","_colorGradingTexture","forPostProcess","vignetteEnabled","vignetteBlendMode","_VIGNETTEMODE_MULTIPLY","colorGradingWithGreenDepth","colorGradingBGR","overrideAspectRatio","inverseWidth","inverseHeight","vignetteScaleY","vignetteScaleX","vignetteScaleGeometricMean","vignettePower","textureSize","_VIGNETTEMODE_OPAQUE","PositionNormalVertex","PositionNormalTextureVertex","cloneValue","destinationObject","DeepCopier","prop","typeOfSourceValue","clonedValue","extractMinAndMaxIndexed","extractMinAndMax","createUniformBuffer","elements","UNIFORM_BUFFER","createDynamicUniformBuffer","updateUniformBuffer","bindBufferBase","UniformBuffer","dynamic","_noUBO","_dynamic","_uniformLocations","_uniformSizes","_uniformLocationPointer","_needSync","updateMatrix3x3","_updateMatrix3x3ForEffect","updateMatrix2x2","_updateMatrix2x2ForEffect","_updateFloatForEffect","_updateFloat2ForEffect","_updateFloat3ForEffect","_updateFloat4ForEffect","_updateMatrixForEffect","_updateVector3ForEffect","updateVector4","_updateVector4ForEffect","_updateColor3ForEffect","_updateColor4ForEffect","_updateMatrix3x3ForUniform","_updateMatrix2x2ForUniform","_updateFloatForUniform","_updateFloat2ForUniform","_updateFloat3ForUniform","_updateFloat4ForUniform","_updateMatrixForUniform","_updateVector3ForUniform","_updateVector4ForUniform","_updateColor3ForUniform","_updateColor4ForUniform","isDynamic","_bufferData","_fillAlignment","alignment","oldPointer","addMatrix","addFloat2","addFloat3","addColor3","addColor4","addMatrix3x3","addMatrix2x2","updateUniform","_tempBuffer","updateUniformDirectly","_MAX_UNIFORM_SIZE","WebRequest","_xhr","_injectCustomRequestHeaders","setRequestHeader","listener","method","CustomRequestModifiers","getResponseHeader","InstantiationTools","MultiMaterial","_subMaterials","_hookArray","subMaterial","cloneChildren","subMat","forceDisposeChildren","ParseMultiMaterial","parsedMultiMaterial","multiMaterial","subMatId","axios","default","buttonSVGs","logo","toJson","labels","publish","replay","record","styleText","colorVar","legendData","zScale","_coords","_coordColors","resetAnimation","matrixMax","matrixMin","getUniqueVals","seen","Set","has","Plot","PLOTTYPES","plotData","plotIdx","plot","pltType","canvasElement","_showLegend","_hasAnim","_axes","_downloadObj","_recording","_turned","_wasTurning","_xScale","_yScale","_zScale","plots","fixedSize","ymax","R","_uniqID","opts","backgroundColor","turntable","rotationRate","_backgroundColor","ArcRotateCamera","attached","keyboard","wheelPrecision","_hl1","HemisphericLight","_hl2","_annotationManager","AnnotationManager","_prepRender","_afterRender","styleElem","createTextNode","buttonBar","clientTop","clientLeft","parentNode","_buttonBar","fromJSON","addImgStack","colorScale","showLegend","fontColor","legendTitle","legendTitleFontSize","legendPosition","showAxes","axisLabels","axisColors","tickBreaks","showTickLines","tickLineColors","addPlot","customColorScale","colorScaleInverted","sortedCategories","folded","foldedEmbedding","foldAnimDelay","foldAnimDuration","colnames","rownames","fixedLabels","labelData","addLabels","label","addLabel","createButtons","whichBtns","jsonBtn","onclick","_downloadJson","labelBtn","toggleLabelControl","recordBtn","_startRecording","publishBtn","_createPublishForm","_prepDownloadObj","exportLabels","dlElement","dlContent","encodeURIComponent","stringify","_publishFormOverlay","formOverlay","formBox","margin","padding","borderRadius","boxShadow","formInfo","innerText","usernameLabel","usernameInput","passwordLabel","passwordInput","titleLabel","titleInput","msg","_tryPublish","cancelBtn","_cancelPublish","closeBtn","_resizePublishOverlay","thumbnail","thumb_data","headers","username","password","plotName","thumb","_resetAnimation","rangeX","rangeY","rangeZ","axisData","worker","_capturer","CCapture","framerate","verbose","workersPath","loadingOverlay","loadingText","stop","_cameraFitPlot","xRange","yRange","zRange","xSize","ySize","zSize","BoxBuilder","xCenter","yCenter","zCenter","halfMinFov","atan","viewRadius","plotType","discrete","breaks","inverted","ImgStack","_updateLegend","dim","colorBy","coordColors","replayBtn","groups","uniqueGroups","nColors","brewer","Paired","domain","colorIndex","Oranges","cl","PointCloud","Surface","HeatMap","static","tickLineColor","showPlanes","planeColor","Axes","_legend","uiLayer","AdvancedDynamicTexture","CreateFullscreenUI","rightFree","leftFree","_createPlotLegend","breakN","grid","Grid","legendWidth","legendColumn","addColumnDefinition","addRowDefinition","TextBlock","innerGrid","legendColor","Rectangle","background","legendText","textHorizontalAlignment","nBreaks","labelSpace","scaleGrid","labelGrid","minText","maxText","doRender","pad","saveCallback","ScreenshotTools","labelList","Plots","TimingTools","setImmediate","BoundingSphere","tempRadiusVector","squareDistance","sphere0","sphere1","radiusSum","PostProcessManager","_prepareBuffers","vertices","_buildIndexBuffer","sourceTexture","activate","targetTexture","doNotPresent","IntersectionInfo","ShaderCodeNode","isValid","preprocessors","process","line","lineProcessor","uniformProcessor","uniformBufferProcessor","lookForClosingBracketForUniformBuffer","endOfUniformBufferProcessor","additionalDefineKey","additionalDefineValue","ShaderCodeCursor","_lines","lineIndex","value_1","subLine","ShaderCodeConditionNode","ShaderCodeTestNode","testExpression","isTrue","ShaderDefineExpression","ShaderDefineIsDefinedOperator","define","not","ShaderDefineOrOperator","leftOperand","rightOperand","ShaderDefineAndOperator","ShaderDefineArithmeticOperator","operand","testValue","ShaderProcessor","sourceCode","_ProcessIncludes","codeWithIncludes","migratedCode","_ProcessShaderConversion","_ProcessPrecision","_ExtractOperation","expression","operator","indexOperator","operators_1","_BuildSubExpression","indexOr","indexAnd","andOperator","leftPart","rightPart","orOperator","_BuildExpression","command","_MoveCursorWithinIf","rootNode","ifNode","currentLine","_MoveCursor","first5","elseNode","elifNode","canRead","newRootNode","newNode","_EvaluatePreProcessors","lines","_PreparePreProcessors","defines_1","preparedSourceCode","preProcessor","regex","returnValue","includeFile","includeShaderUrl","fileContent","includeContent","splits","indexString","indexSplits","minIndex","maxIndex","sourceIncludeContent","Orientation","BezierCurve","Interpolate","f0","refinedT","refinedT2","Angle","radians","_radians","degrees","BetweenTwoPoints","FromRadians","FromDegrees","Arc2","startPoint","midPoint","endPoint","startToMid","midToEnd","centerPoint","startAngle","a1","a2","a3","Path2","_points","_length","closed","addLineTo","newPoint","previousPoint","addArcTo","midX","midY","endX","endY","numberOfSegments","increment","currentAngle","lastPoint","getPoints","getPointAtLengthPosition","normalizedLengthPosition","lengthPosition","previousOffset","bToA","nextOffset","dir","localOffset","StartingAt","Path3D","firstNormal","raw","alignTangentsWithPath","_curve","_distances","_tangents","_binormals","_pointAtData","previousPointArrayIndex","subPosition","interpolateReady","interpolationMatrix","_raw","_alignTangentsWithPath","_compute","getCurve","getBinormals","getDistances","getPointAt","_updatePointAtData","getTangentAt","interpolated","getNormalAt","getBinormalAt","UpReadOnly","getDistanceAt","getPreviousPointIndexAt","getSubPositionAt","getClosestPositionTo","smallestDistance","closestPosition","subLength","_start","curvePoints","endIndex","slicePoints","_getFirstNonNullVector","prev","curTang","prevNor","prevBinor","tg0","pp0","_normalVector","_getLastNonNullVector","nNVector","nLVector","vt","va","tgl","interpolateTNB","_updateInterpolationMatrix","_setPointAtData","currentPoint","currentLength","targetLength","parentIndex","tangentFrom","normalFrom","binormalFrom","tangentTo","normalTo","binormalTo","quatFrom","quatTo","Curve3","_computeLength","CreateQuadraticBezier","v2","nbPoints","bez","val0","val1","val2","CreateCubicBezier","v3","val3","CreateHermiteSpline","t1","t2","hermite","CreateCatmullRomSpline","catmullRom","pointsCount","totalPoints","continue","curve","continuedPoints","RenderTargetCreationOptions","GUID","MaterialDefines","disposed","_keys","keys","isEqual","cloneTo","EffectFallbacks","_defines","_currentRank","_maxRank","currentDefines","currentFallbacks","RenderingGroup","_opaqueSubMeshes","_transparentSubMeshes","_alphaTestSubMeshes","_depthOnlySubMeshes","_particleSystems","_spriteManagers","_edgesRenderers","_opaqueSortCompareFn","_renderOpaque","renderOpaqueSorted","renderUnsorted","_alphaTestSortCompareFn","_renderAlphaTest","renderAlphaTestSorted","_transparentSortCompareFn","defaultTransparentSortCompare","_renderTransparent","renderTransparentSorted","customRenderFunction","renderSprites","renderParticles","activeMeshes","stencilState","_renderSprites","_renderParticles","onBeforeTransparentRendering","edgesRendererIndex","renderSorted","sortCompareFn","transparent","cameraPosition","_zeroVector","sortedArray","needDepthPrePass","backToFrontSortCompare","frontToBackSortCompare","dispatchSprites","spriteManager","onBeforeSpritesRenderingObservable","onAfterSpritesRenderingObservable","RenderingGroupInfo","RenderingManager","_useSceneAutoClearSetup","_renderingGroups","_autoClearDepthStencil","_customOpaqueSortCompareFn","_customAlphaTestSortCompareFn","_customTransparentSortCompareFn","_renderingGroupInfo","MIN_RENDERINGGROUPS","MAX_RENDERINGGROUPS","_clearDepthStencilBuffer","_depthStencilBufferAlreadyCleaned","info","spriteManagers","renderingGroup","renderingGroupMask","AUTOCLEAR","_prepareRenderingGroup","group","clip_rgb","_clipped","_unclipped","classToType","unpack","args","keyOrder","utils","TWOPI","PITHIRD","DEG2RAD","RAD2DEG","autodetect","last$1","clip_rgb$1","type$1","Color","me","sorted","chk","_rgb","Color_1","Function","chroma_1","unpack$1","rgb2cmyk_1","unpack$2","cmyk2rgb_1","unpack$3","type$2","cmyk","unpack$4","last$2","rnd","hsl2css_1","hsla","unpack$5","rgb2hsl_1","unpack$6","last$3","rgb2css_1","rgba","unpack$7","round$1","hsl2rgb_1","t3","h_","RE_RGB","RE_RGBA","RE_RGB_PCT","RE_RGBA_PCT","RE_HSL","RE_HSLA","round$2","css2rgb","css","named","rgb$1","i$1","rgb$2","i$2","rgb$3","i$3","hsl","rgb$4","hsl$1","rgb$5","css2rgb_1","type$3","rest","unpack$8","unpack$9","rgb2hcg_1","unpack$a","hcg2rgb_1","assign$1","assign$2","assign$3","assign$4","assign$5","unpack$b","type$4","hcg","unpack$c","last$4","round$3","rgb2hex_1","hxa","RE_HEX","RE_HEXA","hex2rgb_1","u$1","type$5","unpack$d","rgb2hsi_1","min_","unpack$e","limit$1","TWOPI$1","hsi2rgb_1","unpack$f","type$6","hsi","unpack$g","type$7","unpack$h","min$1","max$1","rgb2hsv","max_","unpack$i","floor$1","hsv2rgb_1","unpack$j","type$8","hsv","labConstants","Kn","Xn","Yn","Zn","unpack$k","rgb2lab","ref$1","rgb2xyz","rgb_xyz","xyz_lab","rgb2lab_1","unpack$l","pow$1","lab2rgb","lab_xyz","xyz_rgb","lab2rgb_1","unpack$m","type$9","lab","unpack$n","sqrt$1","round$4","lab2lch_1","unpack$o","rgb2lch_1","b_","unpack$p","cos$1","lch2lab_1","unpack$q","lch2rgb_1","L","unpack$r","hcl2rgb_1","hcl","unpack$s","type$a","lch","w3cx11_1","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflower","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgreen","darkgrey","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","green","greenyellow","grey","honeydew","hotpink","indianred","indigo","ivory","khaki","laserlemon","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrod","lightgoldenrodyellow","lightgray","lightgreen","lightgrey","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","maroon2","maroon3","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","purple2","purple3","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen","type$b","unpack$t","rgb2num_1","type$c","num2rgb_1","type$d","unpack$u","type$e","round$5","temperature2rgb_1","kelvin","unpack$v","round$6","rgb2temperature_1","minTemp","maxTemp","eps","temperature","type$f","mutate","clipped","darken","brighten","darker","brighter","mc","type$g","pow$2","EPS","MAX_ITER","luminance","lum","cur_lum","max_iter","low","high","mid","interpolate","lm","rgb2luminance","luminance_x","interpolator","type$h","mix","col1","col2","premultiply","saturate","desaturate","type$i","out","xyz0","xyz1","sqrt$2","pow$3","lrgb","lab$1","_hsx","hue0","hue1","sat0","sat1","lbv0","lbv1","sat","lch$1","num$1","c2","hcg$1","hsi$1","hsv$1","clip_rgb$2","pow$4","sqrt$3","PI$1","cos$2","sin$1","atan2$1","weights","_average_lrgb","shift","xyz","cnt","dx","dy","A","ci","xyz2","A$1","col","type$j","pow$5","_mode","_nacol","_spread","_domain","_padding","_classes","_colors","_out","_correctLightness","_colorCache","_useCache","_gamma","setColors","c$1","resetCache","getClass","tMapLightness","tMapDomain","getColor","bypassMap","analyze","limits","tOut","tBreaks","every","_o","spread","correctLightness","L0","L1","pol","L_actual","L_ideal","L_diff","numColors","dd","__range__","asc","nodata","inclusive","ascending","bezier","I","lab0","lab1","lab2","lab3","I0","I1","bezier_1","blend","blend_f","c0","each","darken$1","lighten","screen","overlay","burn","dodge","blend_1","type$k","clip_rgb$3","TWOPI$2","pow$6","sin$2","cos$3","cubehelix","rotations","lightness","dl","dh","amp","cos_a","sin_a","digits","floor$2","random_1","log$1","pow$7","floor$3","sum","min_log","LOG10E","max_log","pb","pr","cluster","assignments","clusterSizes","repeat","nb_iters","centroids","i$4","mindist","best","j$1","dist","newCentroids","j$2","i$5","j$3","j$4","kClusters","j$5","i$6","tmpKMeansBreaks","j$6","i$7","analyze_1","sqrt$4","atan2$2","abs$1","cos$4","PI$2","deltaE","C","b1","L2","b2","sl","sc","h1","c4","sh","delC","delA","delB","sum_sq","scales","cool","hot","colorbrewer","OrRd","PuBu","BuPu","BuGn","YlOrBr","YlGn","Reds","RdPu","Greens","YlGnBu","Purples","GnBu","Greys","YlOrRd","PuRd","Blues","PuBuGn","Viridis","Spectral","RdYlGn","RdBu","PiYG","PRGn","RdYlBu","BrBG","RdGy","PuOr","Set2","Accent","Set1","Set3","Dark2","Pastel2","Pastel1","list$1","colorbrewer_1","PlaneBuilder","sourcePlane","premulAlpha","forceBindTexture","DynamicTexture","_generateMipMaps","_canvas","_context","_recreate","scaleTo","drawText","textSize","measureText","fillText","wrap","topBaseAt","bottomBaseAt","topIndex","bottomIndex","basePositions","topFaceBase","bottomFaceBase","topFaceOrder","bottomFaceOrder","flat","scaleArray","accumulator","currentValue","currentIndex","faceUV","faceColors","totalColors","encode","params","paramsSerializer","serializedParams","parts","toISOString","hashmarkIndex","__CANCEL__","normalizeHeaderName","DEFAULT_CONTENT_TYPE","setContentTypeIfUnset","adapter","defaults","transformRequest","transformResponse","xsrfCookieName","xsrfHeaderName","maxContentLength","maxBodyLength","validateStatus","common","settle","cookies","buildURL","buildFullPath","parseHeaders","isURLSameOrigin","createError","config","requestData","requestHeaders","auth","unescape","Authorization","btoa","fullPath","baseURL","onreadystatechange","responseHeaders","getAllResponseHeaders","onabort","ontimeout","timeoutErrorMessage","xsrfValue","withCredentials","read","onDownloadProgress","onUploadProgress","upload","cancelToken","cancel","enhanceError","config1","config2","valueFromConfig2Keys","mergeDeepPropertiesKeys","defaultToConfig2Keys","directMergeKeys","getMergedValue","mergeDeepProperties","axiosKeys","otherKeys","Cancel","_thickness","_cornerRadius","_drawRoundedRect","fill","stroke","moveTo","lineTo","quadraticCurveTo","TextWrapping","_text","_textWrapping","Clip","_textHorizontalAlignment","_textVerticalAlignment","_resizeToFit","_lineSpacing","_outlineWidth","_outlineColor","onTextChangedObservable","onLinesReadyObservable","_breakLines","maxLineWidth","newWidth","paddingLeftInPixels","paddingRightInPixels","internalValue","newHeight","paddingTopInPixels","paddingBottomInPixels","lineSpacing","_drawText","textWidth","strokeText","_renderLines","refWidth","Ellipsis","_lines_1","_line","_parseLineEllipsis","WordWrap","_lines_2","_parseLineWordWrap","_lines_3","_parseLine","words","testLine","testWidth","rootY","computeExpectedHeight","widthInPixels","context_1","_loaded","_stretch","STRETCH_FILL","_autoScale","_sourceLeft","_sourceTop","_sourceWidth","_sourceHeight","_svgAttributesComputationCompleted","_isSVG","_cellWidth","_cellHeight","_cellId","_populateNinePatchSlicesFromImage","onImageLoadedObservable","onSVGAttributesComputedObservable","_extractNinePatchSliceDataFromImage","_detectPointerOnOpaqueOnly","_sliceLeft","_sliceRight","_sliceTop","_sliceBottom","synchronizeSizeWithContent","_rotate90","preserveProperties","_domImage","dataUrl","rotatedImage","_handleRotationForSVGImage","srcImage","dstImage","_rotate90SourceProperties","srcLeft","sourceLeft","srcTop","sourceTop","srcWidth","domImage","srcHeight","dstLeft","dstTop","dstWidth","sourceWidth","dstHeight","sourceHeight","_onImageLoaded","_imageWidth","_imageHeight","_svgCheck","SVGSVGElement","svgsrc","elemid","svgExist","querySelector","svgDoc","contentDocument","documentElement","getAttribute","docwidth","docheight","_getSVGAttribs","svgImage","svgobj","elem","vb_width","vb_height","elem_bbox","getBBox","elem_matrix_a","elem_matrix_d","elem_matrix_e","elem_matrix_f","baseVal","consolidate","STRETCH_NONE","STRETCH_UNIFORM","STRETCH_NINE_PATCH","STRETCH_EXTEND","_prepareWorkingCanvasForOpaqueDetection","clearRect","_drawImage","sw","tw","th","cellId","rowCount","naturalWidth","cellWidth","column","cellHeight","hRatio","vRatio","centerX","centerY","_renderNinePatch","_renderCornerPatch","targetX","targetY","leftWidth","topHeight","bottomHeight","rightWidth","centerWidth","targetCenterWidth","sliceLeft","targetTopHeight","Button","delegatePickingToChildren","alphaStore","pointerEnterAnimation","pointerOutAnimation","pointerDownAnimation","pointerUpAnimation","_image","_textBlock","CreateImageButton","imageUrl","textBlock","textWrapping","iconImage","stretch","CreateImageOnlyButton","CreateSimpleButton","CreateImageWithCenterTextButton","StackPanel","_isVertical","_manualWidth","_manualHeight","_doNotTrackManualChanges","ignoreLayoutWarnings","isVertical","stackWidth","stackHeight","panelWidthChanged","panelHeightChanged","previousHeight","previousWidth","Checkbox","_isChecked","_checkSizeRatio","onIsCheckedChangedObservable","actualWidth","actualHeight","offsetWidth","offseHeight","isChecked","AddCheckBoxWithHeader","title","onValueChanged","panel","checkbox","header","InputText","_placeholderText","_focusedBackground","_focusedColor","_placeholderColor","_margin","_autoStretchWidth","_maxWidth","_isFocused","_blinkIsEven","_cursorOffset","_deadKey","_addKey","_currentKey","_isTextHighlightOn","_textHighlightColor","_highligherOpacity","_highlightedText","_startHighlightIndex","_endHighlightIndex","_cursorIndex","_onFocusSelectAll","_isPointerDown","promptMessage","disableMobilePrompt","onBeforeKeyAddObservable","onFocusObservable","onBlurObservable","onTextHighlightObservable","onTextCopyObservable","onTextCutObservable","onTextPasteObservable","onKeyboardEventProcessedObservable","valueAsString","autoStretchWidth","onBlur","_scrollLeft","_blinkTimeout","unRegisterClipboardEvents","_onClipboardObserver","onClipboardObservable","_onPointerDblTapObserver","onFocus","prompt","focusedControl","registerClipboardEvents","clipboardInfo","_onCopyText","_onCutText","_onPasteText","_processDblClick","_selectAllText","keepsFocusWith","_connectedVirtualKeyboard","processKey","ctrlKey","metaKey","deletePosition","decrementor","shiftKey","deadKey","insertPosition","_updateValueFromCursorIndex","moveLeft","moveRight","rWord","_clickedCoordinate","processKeyboard","clipboardData","setData","types","clipTextLeft","_beforeRenderText","_textWidth","marginWidth","availableWidth","textLeft","absoluteCursorPosition","currentSize","previousDist","cursorOffsetText","cursorOffsetWidth","cursorLeft","highlightCursorOffsetWidth","highlightCursorLeft","focusedColor","_capturingControl","_rowDefinitions","_columnDefinitions","_cells","_childControls","getRowDefinition","getColumnDefinition","setRowDefinition","setColumnDefinition","getChildrenAt","cell","getChildCellInfo","_tag","_removeCell","childIndex","_offsetCell","previousKey","removeColumnDefinition","removeRowDefinition","goodContainer","_getGridDefinitions","definitionCallback","widths","heights","lefts","tops","globalWidthPercentage","availableHeight","globalHeightPercentage","top_1","ColorPicker","_tmpColor","_pointerStartedOnSquare","_pointerStartedOnWheel","_squareLeft","_squareTop","_squareSize","_h","_s","_v","_lastPointerDownID","onValueChangedObservable","_pointerIsDown","_Epsilon","_updateSquareProps","squareSize","_drawGradientSquare","hueValue","lgh","createLinearGradient","addColorStop","lgv","_drawCircle","_createColorWheelCanvas","maxDistSq","innerRadius","minDistSq","distSq","ang","alphaAmount","alphaRatio","wheelThickness","_colorWheelCanvas","_updateValueFromPointer","_isPointOnSquare","_isPointOnWheel","ShowPickerDialogAsync","advancedTexture","pickerWidth","pickerHeight","headerHeight","lastColor","swatchLimit","numSwatchesPerLine","closeIconColor","buttonFontSize","butEdit","buttonWidth","buttonHeight","currentColor","swatchNumber","swatchDrawer","picker","rValInt","gValInt","bValInt","rValDec","gValDec","bValDec","hexVal","newSwatch","lastVal","activeField","drawerMaxRows","rawSwatchSize","gutterSize","colGutters","swatchSize","drawerMaxSize","containerSize","buttonColor","buttonBackgroundColor","buttonBackgroundHoverColor","buttonBackgroundClickColor","luminanceLimitColor","luminanceLimit","inputFieldLabels","inputTextBackgroundColor","inputTextColor","editSwatchMode","updateValues","inputField","pickedColor","minusPound","updateInt","field","newValue","newSwatchRGB","createSwatch","savedColors","icon","swatch","swatchColor","swatchLuminence","metadata_1","setEditButtonVisibility","updateSwatches","butSave","editSwatches","gutterCount","currentRows","thisRow","totalButtonsThisRow","buttonIterations","disableButton","enableButton","pickerGrid","disabled","closePicker","dialogContainer","topRow","initialRows","pickerPanel","panelHead","pickerPanelRows","closeButton","headerColor3","textVerticalAlignment","currentSwatch","dialogBody","dialogBodyCols","pickerBodyRight","pickerBodyRightRows","pickerSwatchesButtons","pickerButtonsCol","pickerSwatches","pickeSwatchesRows","activeSwatches","labelWidth","labelHeight","labelTextSize","newText","swatchOutline","currentText","buttonGrid","buttonGridRows","butOK","butCancel","pickerColorValues","rgbValuesQuadrant","labelText","hexValueQuadrant","newHexValue","checkHex","leadingZero","Ellipse","InputPassword","txt","Line","_lineWidth","_x1","_y1","_x2","_y2","_dash","_connectedControl","_connectedControlDirtyObserver","setLineDash","_effectiveX2","_effectiveY2","MultiLinePoint","multiLine","_multiLine","_x","_y","_point","_control","_controlObserver","onPointUpdate","_meshObserver","resetLinks","_translatePoint","getProjectedPosition","xValue","yValue","MultiLine","getAt","_minX","_minY","_maxX","_maxY","RadioButton","executeOnAllControls","childRadio","AddRadioButtonWithHeader","radio","BaseSlider","_thumbWidth","_minimum","_maximum","_barOffset","_isThumbClamped","_displayThumb","_step","_effectiveBarOffset","_getThumbPosition","_backgroundBoxLength","_getThumbThickness","thumbThickness","_backgroundBoxThickness","_prepareRenderingData","_renderLeft","_renderTop","_renderWidth","_renderHeight","_effectiveThumbThickness","displayThumb","isThumbClamped","Slider","_borderColor","_isThumbCircle","_displayValueBar","isThumbCircle","thumbPosition","SelectorGroup","_groupPanel","_selectors","_groupHeader","_addGroupHeader","groupHeading","_getSelector","selectorNb","removeSelector","CheckboxGroup","addCheckbox","checked","_selector","isHorizontal","controlFirst","groupPanel","selectors","buttonBackground","_setSelectorLabel","_setSelectorLabelColor","_setSelectorButtonColor","_setSelectorButtonBackground","RadioGroup","_selectNb","addRadio","SliderGroup","addSlider","onValueChange","borderColor","SelectionPanel","_buttonColor","_buttonBackground","_headerColor","_barColor","_barHeight","_spacerHeight","_bars","_groups","_panel","_addSpacer","_setHeaderColor","_setbuttonColor","_labelColor","_setLabelColor","_setButtonBackground","_setBarColor","_setBarHeight","_setSpacerHeight","separator","bar","addGroup","removeGroup","groupNb","setHeaderName","relabel","removeFromGroupSelector","addToGroupCheckbox","addToGroupRadio","addToGroupSlider","onVal","_ScrollViewerWindow","_freezeControls","_bucketWidth","_bucketHeight","_buckets","_updateMeasures","_useBuckets","_makeBuckets","setBucketSizes","_bucketLen","_dispatchInBuckets","bStartX","bEndX","bStartY","bEndY","bucket","lstc","leftInPixels","topInPixels","_updateChildrenMeasures","_origLeft","_origTop","_parentMeasure","_scrollChildren","_scrollChildrenWithBuckets","scrollLeft","scrollTop","_oldLeft","_oldTop","maxWidth","parentClientWidth","parentClientHeight","ScrollBar","_tempMeasure","_first","_originX","_originY","ImageScrollBar","_thumbLength","_thumbHeight","_barImageHeight","num90RotationInVerticalMode","_backgroundBaseImage","isLoaded","_backgroundImage","rotatedValue","_thumbBaseImage","_thumbImage","ScrollViewer","isImageBased","_barSize","_pointerIsOver","_wheelPrecision","_horizontalBarImageHeight","_verticalBarImageHeight","_forceHorizontalBar","_forceVerticalBar","_useImageBar","_horizontalBarSpace","_verticalBarSpace","_dragSpace","_grid","_horizontalBar","_verticalBar","_window","_addBar","barColor","barBackground","freezeControls","bucketWidth","bucketHeight","resetWindow","_buildClientSizes","idealRatio","forceVerticalBar","forceHorizontalBar","_clientWidth","_clientHeight","_updateScroller","_barImage","hb","thumbImage","_horizontalBarImage","_verticalBarImage","thumbLength","thumbHeight","barImageHeight","_barBackground","_barBackgroundImage","backgroundImage","_horizontalBarBackgroundImage","_verticalBarBackgroundImage","_setWindowPosition","windowContentsWidth","windowContentsHeight","_endLeft","_endTop","thumbWidth","_attachWheel","barControl","barContainer","barOffset","_onWheelObserver","KeyPropertySet","VirtualKeyboard","onKeyPressObservable","defaultButtonWidth","defaultButtonHeight","defaultButtonPaddingLeft","defaultButtonPaddingRight","defaultButtonPaddingTop","defaultButtonPaddingBottom","defaultButtonColor","defaultButtonBackground","shiftButtonColor","selectedShiftThickness","shiftState","_currentlyConnectedInputText","_connectedInputTexts","_onKeyPressObserver","_createKey","propertySet","addKeysRow","propertySets","maxKey","properties","heightInPixels","applyShiftState","rowContainer","button_tblock","connect","some","onFocusObserver","onBlurObserver","disconnect","filtered","_removeConnectedInputObservables","connectedInputText","CreateDefaultLayout","DisplayGrid","_minorLineTickness","_minorLineColor","_majorLineTickness","_majorLineColor","_majorLineFrequency","_displayMajorLines","_displayMinorLines","cellCountX","cellCountY","cellX","cellY","ImageBasedSlider","_valueBarImage","LayerSceneComponent","_drawCameraBackground","_drawCameraForeground","_drawRenderTargetBackground","_drawRenderTargetForeground","layers_1","layers_2","_drawCameraPredicate","isBackground","cameraLayerMask","renderOnlyInRenderTargetTextures","_drawRenderTargetPredicate","renderTargetTextures","removeFromContainer","Layer","imgUrl","alphaBlendingMode","layerComponent","_createIndexBuffer","_previousDefines","currentEffect","Style","Constants","ALPHA_ONEONE_ONEONE","ALPHA_ALPHATOCOLOR","ALPHA_REVERSEONEMINUS","ALPHA_SRC_DSTONEMINUSSRCALPHA","ALPHA_ONEONE_ONEZERO","ALPHA_EXCLUSION","ALPHA_EQUATION_ADD","ALPHA_EQUATION_SUBSTRACT","ALPHA_EQUATION_REVERSE_SUBTRACT","ALPHA_EQUATION_MAX","ALPHA_EQUATION_MIN","ALPHA_EQUATION_DARKEN","MATERIAL_TextureDirtyFlag","MATERIAL_LightDirtyFlag","MATERIAL_FresnelDirtyFlag","MATERIAL_AttributesDirtyFlag","MATERIAL_MiscDirtyFlag","MATERIAL_AllDirtyFlag","MATERIAL_TriangleFillMode","MATERIAL_WireFrameFillMode","MATERIAL_PointFillMode","MATERIAL_PointListDrawMode","MATERIAL_LineListDrawMode","MATERIAL_LineLoopDrawMode","MATERIAL_LineStripDrawMode","MATERIAL_TriangleStripDrawMode","MATERIAL_TriangleFanDrawMode","MATERIAL_ClockWiseSideOrientation","MATERIAL_CounterClockWiseSideOrientation","ACTION_NothingTrigger","ACTION_OnPickTrigger","ACTION_OnLeftPickTrigger","ACTION_OnRightPickTrigger","ACTION_OnCenterPickTrigger","ACTION_OnPickDownTrigger","ACTION_OnDoublePickTrigger","ACTION_OnPickUpTrigger","ACTION_OnPickOutTrigger","ACTION_OnLongPressTrigger","ACTION_OnPointerOverTrigger","ACTION_OnPointerOutTrigger","ACTION_OnEveryFrameTrigger","ACTION_OnIntersectionEnterTrigger","ACTION_OnIntersectionExitTrigger","ACTION_OnKeyDownTrigger","ACTION_OnKeyUpTrigger","PARTICLES_BILLBOARDMODE_Y","PARTICLES_BILLBOARDMODE_ALL","PARTICLES_BILLBOARDMODE_STRETCHED","MESHES_CULLINGSTRATEGY_STANDARD","MESHES_CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY","MESHES_CULLINGSTRATEGY_OPTIMISTIC_INCLUSION","MESHES_CULLINGSTRATEGY_OPTIMISTIC_INCLUSION_THEN_BSPHERE_ONLY","SCENELOADER_NO_LOGGING","SCENELOADER_MINIMAL_LOGGING","SCENELOADER_SUMMARY_LOGGING","SCENELOADER_DETAILED_LOGGING","_isFullscreen","_fullscreenViewport","_idealWidth","_idealHeight","_useSmallestIdeal","_renderAtIdealSize","_blockNextFocusCheck","_renderScale","_cursorChanged","_defaultMousePointerId","_clipboardData","onControlPickedObservable","onBeginLayoutObservable","onEndLayoutObservable","onBeginRenderObservable","onEndRenderObservable","_useInvalidateRectOptimization","_invalidatedRectangle","_clearMeasure","onClipboardCopy","rawEvt","onClipboardCut","onClipboardPaste","_rootElement","_renderObserver","_checkUpdate","_preKeyboardObserver","_focusedControl","_resizeObserver","_onResize","rwidth","rheight","_layerToDispose","invalidMinX","invalidMinY","invalidMaxX","invalidMaxY","createStyle","_pointerMoveObserver","_pointerObserver","_canvasPointerOutObserver","renderScale","ZeroReadOnly","_doPicking","_manageFocus","_cleanControlAfterRemovalFromList","tempViewport","_attachToOnPointerOut","self","attachToMesh","supportPointerMove","friendlyControls","canMoveFocus","friendlyControls_1","otherHost","moveFocusToControl","pointerEvent","CreateForMesh","onlyAlphaTesting","diffuseTexture","emissiveTexture","opacityTexture","foreground","instancedBuffers","InstancedMesh","_sourceMesh","_currentLOD","tempMaster","registerInstancedBuffer","_userInstancedBuffersStorage","strides","sizes","expectedSize","ShaderMaterial","shaderPath","_textureArrays","_floats","_ints","_floatsArrays","_colors3","_colors3Arrays","_colors4","_colors4Arrays","_vectors2","_vectors3","_vectors4","_matrices","_matrixArrays","_matrices3x3","_matrices2x2","_vectors2Arrays","_vectors3Arrays","_vectors4Arrays","_cachedWorldViewMatrix","_cachedWorldViewProjectionMatrix","_multiview","_shaderPath","_options","_checkUniform","setFloats","setColor3Array","setColor4Array","float32Array","_checkCache","_transformMatrixR","propName","propValue","textureArrays","floats","FloatArrays","colors3","colors3Arrays","colors4Arrays","vectors2","vectors3","vectors4","matrixArray","matrices3x3","matrices2x2","vectors2Arrays","vectors3Arrays","vectors4Arrays","textureArray","floatsArrays","LinesMesh","_colorShader","_addClipPlaneDefine","_removeClipPlaneDefine","colorEffect","InstancedLinesMesh","vertexColors","shft","dashshft","curvect","lg","curshft","LinesBuilder","vertexColor","lineColors","lineSystem","nbSeg","dashedLines","groundColor","setDirectionToTarget","normalizeDirection","transferToNodeMaterialEffect","lightDataUniformName","strFileName","strMimeType","defaultMime","payload","anchor","myBlob","MozBlob","WebKitBlob","ajax","dataUrlToBlob","saver","tempUiArr","mx","strUrl","binData","uiArr","winMode","confirm","Axios","mergeConfig","defaultConfig","instanceConfig","CancelToken","isCancel","InterceptorManager","dispatchRequest","interceptors","chain","interceptor","fulfilled","rejected","getUri","handlers","use","eject","transformData","throwIfCancellationRequested","throwIfRequested","fns","cachedSetTimeout","cachedClearTimeout","defaultSetTimout","defaultClearTimeout","runTimeout","fun","currentQueue","queue","draining","queueIndex","cleanUpNextTick","drainQueue","run","marker","runClearTimeout","Item","noop","nextTick","browser","env","argv","versions","on","addListener","once","off","removeListener","removeAllListeners","emit","prependListener","prependOnceListener","listeners","binding","cwd","chdir","umask","normalizedName","isAxiosError","toJSON","lineNumber","columnNumber","stack","write","expires","secure","cookie","toGMTString","isAbsoluteURL","combineURLs","requestedURL","relativeURL","ignoreDuplicateOf","parsed","originURL","msie","urlParsingNode","resolveURL","hostname","port","pathname","requestURL","executor","TypeError","resolvePromise","token","CylinderBuilder","fixed","makeDraggable","_label","setText","fix","unfix","export","_editLabelForms","_showLabels","_arrows","_showArrows","fixedArrows","_ymax","_camera","_createLabelForms","labelBox","addLabelForm","addLabelLabel","htmlFor","addLabelInput","_addLabelTextInput","addLabelBtn","_addLabelBtnClick","editLabelContainer","_editLabelContainer","_labelControlBox","unfixLabels","fixLabels","addArrow","Arrow","labelIdx","newLabel","Label","editLabelForm","editLabelLabel","editLabelInput","dataset","labelnum","onkeyup","_editLabelText","rmvLabelBtn","_removeLabel","inputElem","thisForm","labelNum","eLabelForm","oldNum","newNum","labelDragBehavior","PointerDragBehavior","hasRings","enclose","surfaceNb","angle_step","ringVertex","ringNormal","ringFirstVertex","ringFirstNormal","quadNormal","ringIdx","cs","i2","i3","createCylinderCap","isTop","circleVector","vbase","textureScale","textureCoordinate","cylinder","heatmap","_axisLabels","_ticks","_tickLabels","_tickLines","_createAxes","_roundTicks","includes","sig","xtickBreaks","ytickBreaks","ztickBreaks","ymin","xChar","_makeTextPlane","xTicks","startTick","tickPos","tick","tickLabel","tickChar","tickLine","axisY","yChar","yTicks","zChar","zTicks","dynamicTexture","updateAxisData","colSize","rowSize","channels","channelSize","sliceSize","coords","Intensities","sliceIndex","_channelCoords","_channelCoordIntensities","_createImgStack","channelIntensities","channelCoords","channelColor","channelColorRGB","minIntensity","alphaPositions","alphaColors","alphaIntensities","intens","testIntensity","intensIdx","customMesh","colormix","_pointPicking","_selectionCallback","selection","_foldVectors","_foldCounter","_foldAnimFrames","_foldVectorFract","_foldDelay","_folded","fv","_foldedEmbedding","_createPointCloud","SphereBuilder","SPS","SolidParticleSystem","addShape","nbParticles","particles","buildMesh","computeBoundingBox","setParticles","_SPS","newAlpha","numberOfVertices","posVector","_pointPicker","_evt","pickedParticles","diameterX","diameterY","diameterZ","totalZRotationSteps","totalYRotationSteps","zRotationStep","normalizedZ","angleZ","yRotationStep","normalizedY","angleY","rotationZ","rotationY","afterRotZ","complete","firstIndex","_createSurface","surface","rowCoords","coord","_createHeatMap","boxes","AnimationKeyInterpolation","AutoRotationBehavior","_zoomStopsAnimation","_idleRotationSpeed","_idleRotationWaitTime","_idleRotationSpinupTime","_lastFrameTime","_lastInteractionTime","Infinity","_cameraRotationSpeed","_lastFrameRadius","speed","_attachedCamera","_onPrePointerObservableObserver","pointerInfoPre","_onAfterCheckInputsObserver","_applyUserInteraction","timeToRotation","_userIsZooming","inertialRadiusOffset","_shouldAnimationStopForInteraction","zoomHasHitLimit","_userIsMoving","inertialAlphaOffset","inertialBetaOffset","inertialPanningX","inertialPanningY","EasingFunction","_easingMode","EASINGMODE_EASEIN","setEasingMode","easingMode","getEasingMode","easeInCore","ease","EASINGMODE_EASEOUT","EASINGMODE_EASEINOUT","CircleEase","BackEase","amplitude","BounceEase","bounces","bounciness","num9","num15","num65","num13","num8","num7","CubicEase","ElasticEase","oscillations","springiness","exp","ExponentialEase","exponent","PowerEase","QuadraticEase","QuarticEase","QuinticEase","SineEase","BezierCurveEase","AnimationRange","Animation","targetProperty","framePerSecond","dataType","loopMode","enableBlending","_runtimeAnimations","_events","blendingSpeed","targetPropertyPath","ANIMATIONLOOPMODE_CYCLE","_PrepareAnimation","totalFrame","easingFunction","isFinite","ANIMATIONTYPE_FLOAT","ANIMATIONTYPE_QUATERNION","ANIMATIONTYPE_VECTOR3","ANIMATIONTYPE_VECTOR2","ANIMATIONTYPE_COLOR3","ANIMATIONTYPE_COLOR4","ANIMATIONTYPE_SIZE","frame","setKeys","setEasingFunction","CreateAnimation","animationType","ANIMATIONLOOPMODE_CONSTANT","CreateAndStartAnimation","beginDirectAnimation","CreateAndStartHierarchyAnimation","beginDirectHierarchyAnimation","CreateMergeAndStartAnimation","TransitionTo","targetValue","frameRate","transition","duration","isStopped","addEvent","removeEvents","getEvents","getRange","getKeys","getHighestFrame","nKeys","getEasingFunction","_easingFunction","floatInterpolateFunction","floatInterpolateFunctionWithTangents","outTangent","inTangent","quaternionInterpolateFunction","quaternionInterpolateFunctionWithTangents","vector3InterpolateFunction","vector3InterpolateFunctionWithTangents","vector2InterpolateFunction","vector2InterpolateFunctionWithTangents","sizeInterpolateFunction","color3InterpolateFunction","color4InterpolateFunction","_getKeyValue","_interpolate","currentFrame","repeatCount","highLimitValue","startKeyIndex","endKey","startKey","interpolation","STEP","useTangent","frameDelta","floatValue","ANIMATIONLOOPMODE_RELATIVE","offsetValue","quatValue","vec3Value","vec2Value","ANIMATIONTYPE_MATRIX","AllowMatricesInterpolation","matrixInterpolateFunction","workValue","AllowMatrixDecomposeForInterpolation","loopBehavior","animationKey","_UniversalLerp","_inTangent","_outTangent","keyData","BouncingBehavior","transitionDuration","lowerRadiusTransitionRange","upperRadiusTransitionRange","_autoTransitionRange","_radiusIsAnimating","_radiusBounceTransition","_animatables","_onMeshTargetChangedObserver","onMeshTargetChangedObservable","diagonal","diagonalLength","_isRadiusAtLimit","lowerRadiusLimit","_applyBoundRadiusAnimation","upperRadiusLimit","radiusLimit","radiusDelta","EasingMode","_cachedWheelPrecision","animatable","_clearAnimationLocks","FramingBehavior","FitFrustumSidesMode","_radiusScale","_positionScale","_defaultElevation","_elevationReturnTime","_elevationReturnWaitTime","_framingTime","autoCorrectCameraLimitsAndSensibility","_betaIsAnimating","elevation","zoomOnMesh","_maintainCameraAboveGround","focusOnOriginXZ","zoomOnBoundingInfo","zoomOnMeshHierarchy","zoomOnMeshesHierarchy","zoomTarget","zoomTargetY","_vectorTransition","_calculateLowerRadiusFromModelBoundingSphere","IgnoreBoundsSizeMode","panningSensibility","_radiusTransition","useInputToRestoreState","boxVectorGlobalDiagonal","frustumSlope","_getFrustumSlope","distanceForHorizontalFrustum","distanceForVerticalFrustum","timeSinceInteraction","defaultBeta","limitBeta","_betaTransition","animatabe","frustumSlopeY","frustumSlopeX","isUserIsMoving","TargetCamera","cameraDirection","cameraRotation","updateUpVectorFromRotation","_tmpQuaternion","noRotationConstraint","lockedTarget","_currentTarget","_initialFocalDistance","_camMatrix","_cameraTransformMatrix","_cameraRotationMatrix","_referencePoint","_transformedReferencePoint","_globalCurrentTarget","_globalCurrentUpVector","_defaultUp","_cachedRotationZ","_cachedQuaternionRotationZ","getFrontPosition","_getLockedTargetPosition","_storedPosition","_storedRotation","_storedRotationQuaternion","lockedTargetPosition","_computeLocalCameraSpeed","vDir","_decideIfNeedsToMove","_updatePosition","needToMove","needToRotate","_rotateUpVectorWithCameraRotationMatrix","_computeViewMatrix","parentWorldMatrix","rigCamera","camLeft","camRight","leftSign","rightSign","_getRigCamPositionAndTarget","halfSpace","_TargetFocalPoint","newFocalTarget","_TargetTransformMatrix","_RigCamTransformMatrix","CameraInputTypes","CameraInputsManager","checkInputs","getSimpleName","_addCheckInputs","attachedElement","inputToRemove","rebuildInputCheck","removeByType","inputType","attachInput","attachElement","detachElement","serializedCamera","inputsmgr","parsedInputs","parsedinput","ArcRotateCameraPointersInput","buttons","angularSensibilityX","angularSensibilityY","pinchPrecision","pinchDeltaPercentage","useNaturalPinchZoom","multiTouchPanning","multiTouchPanAndZoom","pinchInwards","_isPanClick","_twoFingerActivityCount","_isPinching","onTouch","_ctrlKey","_useCtrlForPanning","onDoubleTap","onMultiTouch","pointA","pointB","previousPinchSquaredDistance","pinchSquaredDistance","previousMultiTouchPanPosition","multiTouchPanPosition","moveDeltaX","moveDeltaY","previousPinchDistance","pinchDistance","pinchToPanMaxDistance","onButtonDown","_panningMouseButton","onButtonUp","onLostFocus","BaseCameraPointersInput","_altKey","_metaKey","_shiftKey","_buttonsPressed","_pointerInput","isTouch","pointerType","isInVRExclusivePointerMode","srcElement","altKey","movementX","mozMovementX","webkitMovementX","msMovementX","movementY","mozMovementY","webkitMovementY","msMovementY","setPointerCapture","releasePointerCapture","ed","distX","distY","_observer","_onLostFocus","onContextMenu","ArcRotateCameraKeyboardMoveInput","keysUp","keysDown","keysLeft","keysRight","keysReset","zoomingSensibility","useAltToZoom","angularSpeed","_onKeyboardObserver","_ctrlPressed","_altPressed","ArcRotateCameraMouseWheelInput","wheelDeltaPercentage","computeDeltaFromMouseWheelLegacyEvent","mouseWheelDelta","wheelDelta","_wheel","mouseWheelLegacyEvent","detail","estimatedTargetRadius","targetInertia","ArcRotateCameraInputsManager","addMouseWheel","addPointers","addKeyboard","_upVector","lowerAlphaLimit","upperAlphaLimit","lowerBetaLimit","upperBetaLimit","panningDistanceLimit","panningOriginTarget","panningInertia","zoomOnFactor","targetScreenOffset","allowUpsideDown","panningAxis","collisionRadius","_previousPosition","_collisionVelocity","_newPosition","_computationVector","onCollide","cosa","sina","cosb","sinb","_getTargetPosition","_collisionTriggered","_target","_upToYMatrix","_YToUpMatrix","setMatUp","pointers","mousewheel","_bouncingBehavior","useBouncingBehavior","_framingBehavior","useFramingBehavior","_autoRotationBehavior","useAutoRotationBehavior","_targetHost","_targetBoundingCenter","_storedAlpha","_storedBeta","_storedRadius","_storedTarget","_storedTargetScreenOffset","useCtrlForPanning","panningMouseButton","_reset","_localDirection","_transformedDirection","_checkLimits","rebuildAnglesAndRadius","toBoundingCenter","allowSamePosition","newTarget","zoomOn","doNotUpdateMaxZ","focusOn","meshesOrMinMaxVectorAndDistance","alphaShift","rigCam","getRandomValues","crypto","msCrypto","rnds8","rng","uuid","byteToHex","_nodeId","_clockseq","_lastMSecs","_lastNSecs","clockseq","seedBytes","msecs","nsecs","tl","tmh","generateUUID","namespace","stringToBytes","hashfunc","DNS","getOutputLength","inputLength8","safeAdd","lsw","md5cmn","md5ff","md5gg","md5hh","md5ii","v35","length32","hexTab","md5ToHexEncodedArray","olda","oldb","oldc","oldd","wordsToMd5","length8","bytesToWords","rnds","ROTL","K","H","N","M","_i2","W","_t","T","sizedFormat","texImage3D","_createDepthStencilCubeTexture","_createDepthStencilTexture","internalOptions","DEPTH_COMPONENT","DEPTH_COMPONENT24","face","RenderTargetTexture","doNotChangeAspectRatio","isMulti","ignoreCameraViewport","onBeforeBindObservable","onAfterUnbindObservable","onClearObservable","_currentRefreshId","_refreshRate","_initialSizeParameter","_processSizeParameter","_doNotChangeAspectRatio","_renderTargetOptions","getRenderSize","_textureMatrix","_renderList","wasEmpty","_onAfterUnbindObserver","_onClearObserver","_onRatioRescale","_sizeRatio","_boundingBoxSize","_bestReflectionRenderTargetDimension","resetRefreshCounter","addPostProcess","_postProcessManager","clearPostProcesses","removePostProcess","refreshRate","getRenderLayers","newSize","wasCube","useCameraPostProcess","dumpForDebug","useCameraPostProcesses","mesh_1","renderListPredicate","sceneMeshes","_defaultRenderListPrepared","renderToTarget","renderDimension","curved","_prepareRenderingManager","currentRenderList","currentRenderListLength","checkLayerMask","isMasked","unbindFrameBuffer","defaultRenderList","defaultRenderListLength","getCustomRenderList","disposeFramebufferObjects","objBuffer","REFRESHRATE_RENDER_ONCE","REFRESHRATE_RENDER_ONEVERYFRAME","REFRESHRATE_RENDER_ONEVERYTWOFRAMES","PostProcess","fragmentUrl","reusable","vertexUrl","blockCompilation","textureFormat","enablePixelPerfectMode","scaleMode","alwaysForcePOT","adaptScaleToCurrentViewport","_reusable","_scaleRatio","_texelSize","onActivateObservable","onSizeChangedObservable","onApplyObservable","renderTargetSamplingMode","_textureType","_textureFormat","_fragmentUrl","_vertexUrl","_parameters","updateEffect","_onActivateObserver","_onSizeChangedObserver","_onApplyObserver","_forcedOutputTexture","getCamera","_shareOutputWithPostProcess","texelSize","shareOutputWith","_disposeTextures","useOwnOutput","forceDepthStencil","maxSize","webVRCamera","desiredWidth","desiredHeight","needMipMaps","textureOptions","isStencilEnable","inputTexture","alphaConstants","index_2","FxaaPostProcess","_getDefines","glInfo","_getScreenshotSize","renderContext","renderingCanvas","targetTextureSize","previousCamera","renderCanvas","originalSize","renderToTexture","fxaaPostProcess","Ray","intersectsBoxMinMax","intersectionTreshold","newMinimum","newMaximum","maxValue","rr","vertex0","edge1","edge2","pvec","tvec","qvec","invdet","bw","intersectsPlane","result1","result2","intersectsAxis","tm","_tmpRay","intersectsMeshes","_comparePickingInfo","pickingInfoA","pickingInfoB","sega","segb","threshold","rsegb","rayl","sN","tc","tN","D","sD","tD","smallnum","qtc","qsc","dP","unprojectRayToRef","CreateNewFromTo","nearScreenSource","farScreenSource","nearVec3","farVec3","_internalPick","rayFunction","_internalMultiPick","pickingInfos","_tempPickingRay","_pickWithRayInverseMatrix","_cachedRayForTransform","forward","forwardWorld","PivotTools","_RemoveAndStorePivotPoint","_PivotCached","_OldPivotPoint","_PivotTranslation","_PivotTmpVector","_RestorePivotPoint","_useAlternatePickedPointAboveMaxDragAngleDragSpeed","maxDragAngle","_useAlternatePickedPointAboveMaxDragAngle","currentDraggingPointerID","dragging","dragDeltaRatio","updateDragPlane","_debugMode","_moving","onDragObservable","onDragStartObservable","onDragEndObservable","moveAttached","enabled","startAndReleaseDragOnPointerEvents","detachCameraControls","useObjectOrientationForDragging","validateDrag","targetPosition","_tmpVector","_alternatePickedPoint","_worldDragAxis","_targetPosition","_attachedElement","_startDragRay","_lastPointerRay","_dragDelta","_pointA","_pointB","_pointC","_lineA","_lineB","_localAxis","_lookAt","optionCount","dragAxis","dragPlaneNormal","ownerNode","attachedNode","_planeScene","_dragPlane","lastDragPosition","pickPredicate","eventState","_startDrag","releaseDrag","_AnyMouseID","_moveDrag","_beforeRenderObserver","dragPlanePoint","startDrag","fromRay","startPickedPoint","lastRay","_updateDragPlanePosition","_pickWithRayOnDragPlane","dragLength","dragDistance","dragPlanePosition","theta","vertexNb","DiscBuilder","disc","SolidParticle","particleId","positionIndex","indiceIndex","model","shapeId","idxInShape","sps","modelBoundingInfo","velocity","pivot","translateFromPivot","alive","_ind","_stillInvisible","_rotationMatrix","_model","_sps","_modelBoundingInfo","copyToRef","_bSphereOnly","ModelShape","shapeUV","posFunction","vtxFunction","_indicesLength","shapeID","_shape","_shapeUV","_shapeColors","_positionFunction","_vertexFunction","DepthSortedParticle","indLength","indicesLength","billboard","recomputeNormals","counter","vars","_bSphereRadiusFactor","_index","_pickable","_isVisibilityBoxLocked","_alwaysVisible","_depthSort","_expandable","_shapeCounter","_copy","_computeParticleColor","_computeParticleTexture","_computeParticleRotation","_computeParticleVertex","_computeBoundingBox","_depthSortParticles","_mustUnrotateFixedNormals","_particlesIntersect","_needs32Bits","_isNotBuilt","_lastParticleId","_idxOfId","_multimaterialEnabled","_useModelMaterial","_depthSortFunction","_materialSortFunction","_autoUpdateSubMeshes","enableDepthSort","enableMultiMaterial","useModelMaterial","expandable","particleIntersection","boundingSphereOnly","bSphereRadiusFactor","depthSortedParticles","_multimaterial","_materials","_materialIndexesById","triangle","_indices32","_positions32","_uvs32","_colors32","_sortParticlesByMaterial","_normals32","_fixedNormal32","_unrotateFixedNormals","setMultiMaterial","digest","meshPos","meshInd","meshUV","meshCol","meshNor","storage","totalFacets","facetPos","facetNor","facetInd","facetUV","facetCol","barycenter","sizeO","fi","i4","_posToShape","_uvsToShapeUV","shapeInd","shapeCol","shapeNor","_setDefaultMaterial","modelShape","currentPos","currentInd","_meshBuilder","_addParticle","tmpNormal","invertedRotMatrix","particle","pt","_resetCopy","storeApart","materialIndexesById","matIdx","tmpVertex","tmpRotated","pivotBackTranslation","scaledPivot","someVertexFunction","vertexFunction","copyUvs","current_ind","nbfaces","idxpos","idxind","sp","shapeNormals","shapeColors","bbInfo","posfunc","vtxfunc","_insertNewParticle","_rebuildParticle","rebuildMesh","removeParticles","currentNb","firstRemaining","shiftPos","shifInd","part","removed","particlesLength","modelIndices","modelNormals","modelColors","modelUVs","insertParticlesFromArray","solidParticleArray","currentShapeId","noNor","newPart","currentCopy","beforeUpdateParticles","colors32","positions32","normals32","uvs32","indices32","fixedNormal32","tempVectors","camAxisX","camAxisY","camAxisZ","camInvertedPosition","colidx","uvidx","uvIndex","isFacetDataEnabled","vpos","updateParticle","particleRotationMatrix","particlePosition","particleRotation","particleScaling","particleGlobalPosition","dsp","getParticleById","parentGlobalPosition","rotatedY","rotatedX","rotatedZ","rotMatrixValues","updateParticleVertex","vertexX","vertexY","vertexZ","px","py","pz","normalx","normaly","normalz","rotatedx","rotatedy","rotatedz","colors32_1","bBox","modelBoundingInfoVectors","tempMin","tempMax","scaledX","scaledY","scaledZ","minBbox","maxBbox","bSphereCenter","halfDiag","bSphereMinBbox","bSphereMaxBbox","areNormalsFrozen","dspl","sid","lind","computeSubMeshes","afterUpdateParticles","getParticlesByShapeId","getParticlesByShapeIdToRef","sortedPart","indicesByMaterial","_indicesByMaterial","materialIndexes","_materialIndexes","vcount","lastMatIndex","_setMaterialIndexesById","_filterUniqueMaterialId","refreshVisibleSize","setVisibilityBox","vis","initParticles","recycleParticle"],"mappings":"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","file":"babyplots.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 64);\n","import { Scalar } from \"./math.scalar\";\r\nimport { Epsilon } from './math.constants';\r\nimport { ArrayTools } from '../Misc/arrayTools';\r\nimport { _TypeStore } from '../Misc/typeStore';\r\n/**\r\n * Class representing a vector containing 2 coordinates\r\n */\r\nvar Vector2 = /** @class */ (function () {\r\n /**\r\n * Creates a new Vector2 from the given x and y coordinates\r\n * @param x defines the first coordinate\r\n * @param y defines the second coordinate\r\n */\r\n function Vector2(\r\n /** defines the first coordinate */\r\n x, \r\n /** defines the second coordinate */\r\n y) {\r\n if (x === void 0) { x = 0; }\r\n if (y === void 0) { y = 0; }\r\n this.x = x;\r\n this.y = y;\r\n }\r\n /**\r\n * Gets a string with the Vector2 coordinates\r\n * @returns a string with the Vector2 coordinates\r\n */\r\n Vector2.prototype.toString = function () {\r\n return \"{X: \" + this.x + \" Y:\" + this.y + \"}\";\r\n };\r\n /**\r\n * Gets class name\r\n * @returns the string \"Vector2\"\r\n */\r\n Vector2.prototype.getClassName = function () {\r\n return \"Vector2\";\r\n };\r\n /**\r\n * Gets current vector hash code\r\n * @returns the Vector2 hash code as a number\r\n */\r\n Vector2.prototype.getHashCode = function () {\r\n var hash = this.x | 0;\r\n hash = (hash * 397) ^ (this.y | 0);\r\n return hash;\r\n };\r\n // Operators\r\n /**\r\n * Sets the Vector2 coordinates in the given array or Float32Array from the given index.\r\n * @param array defines the source array\r\n * @param index defines the offset in source array\r\n * @returns the current Vector2\r\n */\r\n Vector2.prototype.toArray = function (array, index) {\r\n if (index === void 0) { index = 0; }\r\n array[index] = this.x;\r\n array[index + 1] = this.y;\r\n return this;\r\n };\r\n /**\r\n * Copy the current vector to an array\r\n * @returns a new array with 2 elements: the Vector2 coordinates.\r\n */\r\n Vector2.prototype.asArray = function () {\r\n var result = new Array();\r\n this.toArray(result, 0);\r\n return result;\r\n };\r\n /**\r\n * Sets the Vector2 coordinates with the given Vector2 coordinates\r\n * @param source defines the source Vector2\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.copyFrom = function (source) {\r\n this.x = source.x;\r\n this.y = source.y;\r\n return this;\r\n };\r\n /**\r\n * Sets the Vector2 coordinates with the given floats\r\n * @param x defines the first coordinate\r\n * @param y defines the second coordinate\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.copyFromFloats = function (x, y) {\r\n this.x = x;\r\n this.y = y;\r\n return this;\r\n };\r\n /**\r\n * Sets the Vector2 coordinates with the given floats\r\n * @param x defines the first coordinate\r\n * @param y defines the second coordinate\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.set = function (x, y) {\r\n return this.copyFromFloats(x, y);\r\n };\r\n /**\r\n * Add another vector with the current one\r\n * @param otherVector defines the other vector\r\n * @returns a new Vector2 set with the addition of the current Vector2 and the given one coordinates\r\n */\r\n Vector2.prototype.add = function (otherVector) {\r\n return new Vector2(this.x + otherVector.x, this.y + otherVector.y);\r\n };\r\n /**\r\n * Sets the \"result\" coordinates with the addition of the current Vector2 and the given one coordinates\r\n * @param otherVector defines the other vector\r\n * @param result defines the target vector\r\n * @returns the unmodified current Vector2\r\n */\r\n Vector2.prototype.addToRef = function (otherVector, result) {\r\n result.x = this.x + otherVector.x;\r\n result.y = this.y + otherVector.y;\r\n return this;\r\n };\r\n /**\r\n * Set the Vector2 coordinates by adding the given Vector2 coordinates\r\n * @param otherVector defines the other vector\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.addInPlace = function (otherVector) {\r\n this.x += otherVector.x;\r\n this.y += otherVector.y;\r\n return this;\r\n };\r\n /**\r\n * Gets a new Vector2 by adding the current Vector2 coordinates to the given Vector3 x, y coordinates\r\n * @param otherVector defines the other vector\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.addVector3 = function (otherVector) {\r\n return new Vector2(this.x + otherVector.x, this.y + otherVector.y);\r\n };\r\n /**\r\n * Gets a new Vector2 set with the subtracted coordinates of the given one from the current Vector2\r\n * @param otherVector defines the other vector\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.subtract = function (otherVector) {\r\n return new Vector2(this.x - otherVector.x, this.y - otherVector.y);\r\n };\r\n /**\r\n * Sets the \"result\" coordinates with the subtraction of the given one from the current Vector2 coordinates.\r\n * @param otherVector defines the other vector\r\n * @param result defines the target vector\r\n * @returns the unmodified current Vector2\r\n */\r\n Vector2.prototype.subtractToRef = function (otherVector, result) {\r\n result.x = this.x - otherVector.x;\r\n result.y = this.y - otherVector.y;\r\n return this;\r\n };\r\n /**\r\n * Sets the current Vector2 coordinates by subtracting from it the given one coordinates\r\n * @param otherVector defines the other vector\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.subtractInPlace = function (otherVector) {\r\n this.x -= otherVector.x;\r\n this.y -= otherVector.y;\r\n return this;\r\n };\r\n /**\r\n * Multiplies in place the current Vector2 coordinates by the given ones\r\n * @param otherVector defines the other vector\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.multiplyInPlace = function (otherVector) {\r\n this.x *= otherVector.x;\r\n this.y *= otherVector.y;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector2 set with the multiplication of the current Vector2 and the given one coordinates\r\n * @param otherVector defines the other vector\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.multiply = function (otherVector) {\r\n return new Vector2(this.x * otherVector.x, this.y * otherVector.y);\r\n };\r\n /**\r\n * Sets \"result\" coordinates with the multiplication of the current Vector2 and the given one coordinates\r\n * @param otherVector defines the other vector\r\n * @param result defines the target vector\r\n * @returns the unmodified current Vector2\r\n */\r\n Vector2.prototype.multiplyToRef = function (otherVector, result) {\r\n result.x = this.x * otherVector.x;\r\n result.y = this.y * otherVector.y;\r\n return this;\r\n };\r\n /**\r\n * Gets a new Vector2 set with the Vector2 coordinates multiplied by the given floats\r\n * @param x defines the first coordinate\r\n * @param y defines the second coordinate\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.multiplyByFloats = function (x, y) {\r\n return new Vector2(this.x * x, this.y * y);\r\n };\r\n /**\r\n * Returns a new Vector2 set with the Vector2 coordinates divided by the given one coordinates\r\n * @param otherVector defines the other vector\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.divide = function (otherVector) {\r\n return new Vector2(this.x / otherVector.x, this.y / otherVector.y);\r\n };\r\n /**\r\n * Sets the \"result\" coordinates with the Vector2 divided by the given one coordinates\r\n * @param otherVector defines the other vector\r\n * @param result defines the target vector\r\n * @returns the unmodified current Vector2\r\n */\r\n Vector2.prototype.divideToRef = function (otherVector, result) {\r\n result.x = this.x / otherVector.x;\r\n result.y = this.y / otherVector.y;\r\n return this;\r\n };\r\n /**\r\n * Divides the current Vector2 coordinates by the given ones\r\n * @param otherVector defines the other vector\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.divideInPlace = function (otherVector) {\r\n return this.divideToRef(otherVector, this);\r\n };\r\n /**\r\n * Gets a new Vector2 with current Vector2 negated coordinates\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.negate = function () {\r\n return new Vector2(-this.x, -this.y);\r\n };\r\n /**\r\n * Negate this vector in place\r\n * @returns this\r\n */\r\n Vector2.prototype.negateInPlace = function () {\r\n this.x *= -1;\r\n this.y *= -1;\r\n return this;\r\n };\r\n /**\r\n * Negate the current Vector2 and stores the result in the given vector \"result\" coordinates\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector2\r\n */\r\n Vector2.prototype.negateToRef = function (result) {\r\n return result.copyFromFloats(this.x * -1, this.y * -1);\r\n };\r\n /**\r\n * Multiply the Vector2 coordinates by scale\r\n * @param scale defines the scaling factor\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.scaleInPlace = function (scale) {\r\n this.x *= scale;\r\n this.y *= scale;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector2 scaled by \"scale\" from the current Vector2\r\n * @param scale defines the scaling factor\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.scale = function (scale) {\r\n var result = new Vector2(0, 0);\r\n this.scaleToRef(scale, result);\r\n return result;\r\n };\r\n /**\r\n * Scale the current Vector2 values by a factor to a given Vector2\r\n * @param scale defines the scale factor\r\n * @param result defines the Vector2 object where to store the result\r\n * @returns the unmodified current Vector2\r\n */\r\n Vector2.prototype.scaleToRef = function (scale, result) {\r\n result.x = this.x * scale;\r\n result.y = this.y * scale;\r\n return this;\r\n };\r\n /**\r\n * Scale the current Vector2 values by a factor and add the result to a given Vector2\r\n * @param scale defines the scale factor\r\n * @param result defines the Vector2 object where to store the result\r\n * @returns the unmodified current Vector2\r\n */\r\n Vector2.prototype.scaleAndAddToRef = function (scale, result) {\r\n result.x += this.x * scale;\r\n result.y += this.y * scale;\r\n return this;\r\n };\r\n /**\r\n * Gets a boolean if two vectors are equals\r\n * @param otherVector defines the other vector\r\n * @returns true if the given vector coordinates strictly equal the current Vector2 ones\r\n */\r\n Vector2.prototype.equals = function (otherVector) {\r\n return otherVector && this.x === otherVector.x && this.y === otherVector.y;\r\n };\r\n /**\r\n * Gets a boolean if two vectors are equals (using an epsilon value)\r\n * @param otherVector defines the other vector\r\n * @param epsilon defines the minimal distance to consider equality\r\n * @returns true if the given vector coordinates are close to the current ones by a distance of epsilon.\r\n */\r\n Vector2.prototype.equalsWithEpsilon = function (otherVector, epsilon) {\r\n if (epsilon === void 0) { epsilon = Epsilon; }\r\n return otherVector && Scalar.WithinEpsilon(this.x, otherVector.x, epsilon) && Scalar.WithinEpsilon(this.y, otherVector.y, epsilon);\r\n };\r\n /**\r\n * Gets a new Vector2 from current Vector2 floored values\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.floor = function () {\r\n return new Vector2(Math.floor(this.x), Math.floor(this.y));\r\n };\r\n /**\r\n * Gets a new Vector2 from current Vector2 floored values\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.fract = function () {\r\n return new Vector2(this.x - Math.floor(this.x), this.y - Math.floor(this.y));\r\n };\r\n // Properties\r\n /**\r\n * Gets the length of the vector\r\n * @returns the vector length (float)\r\n */\r\n Vector2.prototype.length = function () {\r\n return Math.sqrt(this.x * this.x + this.y * this.y);\r\n };\r\n /**\r\n * Gets the vector squared length\r\n * @returns the vector squared length (float)\r\n */\r\n Vector2.prototype.lengthSquared = function () {\r\n return (this.x * this.x + this.y * this.y);\r\n };\r\n // Methods\r\n /**\r\n * Normalize the vector\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.normalize = function () {\r\n var len = this.length();\r\n if (len === 0) {\r\n return this;\r\n }\r\n this.x /= len;\r\n this.y /= len;\r\n return this;\r\n };\r\n /**\r\n * Gets a new Vector2 copied from the Vector2\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.clone = function () {\r\n return new Vector2(this.x, this.y);\r\n };\r\n // Statics\r\n /**\r\n * Gets a new Vector2(0, 0)\r\n * @returns a new Vector2\r\n */\r\n Vector2.Zero = function () {\r\n return new Vector2(0, 0);\r\n };\r\n /**\r\n * Gets a new Vector2(1, 1)\r\n * @returns a new Vector2\r\n */\r\n Vector2.One = function () {\r\n return new Vector2(1, 1);\r\n };\r\n /**\r\n * Gets a new Vector2 set from the given index element of the given array\r\n * @param array defines the data source\r\n * @param offset defines the offset in the data source\r\n * @returns a new Vector2\r\n */\r\n Vector2.FromArray = function (array, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n return new Vector2(array[offset], array[offset + 1]);\r\n };\r\n /**\r\n * Sets \"result\" from the given index element of the given array\r\n * @param array defines the data source\r\n * @param offset defines the offset in the data source\r\n * @param result defines the target vector\r\n */\r\n Vector2.FromArrayToRef = function (array, offset, result) {\r\n result.x = array[offset];\r\n result.y = array[offset + 1];\r\n };\r\n /**\r\n * Gets a new Vector2 located for \"amount\" (float) on the CatmullRom spline defined by the given four Vector2\r\n * @param value1 defines 1st point of control\r\n * @param value2 defines 2nd point of control\r\n * @param value3 defines 3rd point of control\r\n * @param value4 defines 4th point of control\r\n * @param amount defines the interpolation factor\r\n * @returns a new Vector2\r\n */\r\n Vector2.CatmullRom = function (value1, value2, value3, value4, amount) {\r\n var squared = amount * amount;\r\n var cubed = amount * squared;\r\n var x = 0.5 * ((((2.0 * value2.x) + ((-value1.x + value3.x) * amount)) +\r\n (((((2.0 * value1.x) - (5.0 * value2.x)) + (4.0 * value3.x)) - value4.x) * squared)) +\r\n ((((-value1.x + (3.0 * value2.x)) - (3.0 * value3.x)) + value4.x) * cubed));\r\n var y = 0.5 * ((((2.0 * value2.y) + ((-value1.y + value3.y) * amount)) +\r\n (((((2.0 * value1.y) - (5.0 * value2.y)) + (4.0 * value3.y)) - value4.y) * squared)) +\r\n ((((-value1.y + (3.0 * value2.y)) - (3.0 * value3.y)) + value4.y) * cubed));\r\n return new Vector2(x, y);\r\n };\r\n /**\r\n * Returns a new Vector2 set with same the coordinates than \"value\" ones if the vector \"value\" is in the square defined by \"min\" and \"max\".\r\n * If a coordinate of \"value\" is lower than \"min\" coordinates, the returned Vector2 is given this \"min\" coordinate.\r\n * If a coordinate of \"value\" is greater than \"max\" coordinates, the returned Vector2 is given this \"max\" coordinate\r\n * @param value defines the value to clamp\r\n * @param min defines the lower limit\r\n * @param max defines the upper limit\r\n * @returns a new Vector2\r\n */\r\n Vector2.Clamp = function (value, min, max) {\r\n var x = value.x;\r\n x = (x > max.x) ? max.x : x;\r\n x = (x < min.x) ? min.x : x;\r\n var y = value.y;\r\n y = (y > max.y) ? max.y : y;\r\n y = (y < min.y) ? min.y : y;\r\n return new Vector2(x, y);\r\n };\r\n /**\r\n * Returns a new Vector2 located for \"amount\" (float) on the Hermite spline defined by the vectors \"value1\", \"value3\", \"tangent1\", \"tangent2\"\r\n * @param value1 defines the 1st control point\r\n * @param tangent1 defines the outgoing tangent\r\n * @param value2 defines the 2nd control point\r\n * @param tangent2 defines the incoming tangent\r\n * @param amount defines the interpolation factor\r\n * @returns a new Vector2\r\n */\r\n Vector2.Hermite = function (value1, tangent1, value2, tangent2, amount) {\r\n var squared = amount * amount;\r\n var cubed = amount * squared;\r\n var part1 = ((2.0 * cubed) - (3.0 * squared)) + 1.0;\r\n var part2 = (-2.0 * cubed) + (3.0 * squared);\r\n var part3 = (cubed - (2.0 * squared)) + amount;\r\n var part4 = cubed - squared;\r\n var x = (((value1.x * part1) + (value2.x * part2)) + (tangent1.x * part3)) + (tangent2.x * part4);\r\n var y = (((value1.y * part1) + (value2.y * part2)) + (tangent1.y * part3)) + (tangent2.y * part4);\r\n return new Vector2(x, y);\r\n };\r\n /**\r\n * Returns a new Vector2 located for \"amount\" (float) on the linear interpolation between the vector \"start\" adn the vector \"end\".\r\n * @param start defines the start vector\r\n * @param end defines the end vector\r\n * @param amount defines the interpolation factor\r\n * @returns a new Vector2\r\n */\r\n Vector2.Lerp = function (start, end, amount) {\r\n var x = start.x + ((end.x - start.x) * amount);\r\n var y = start.y + ((end.y - start.y) * amount);\r\n return new Vector2(x, y);\r\n };\r\n /**\r\n * Gets the dot product of the vector \"left\" and the vector \"right\"\r\n * @param left defines first vector\r\n * @param right defines second vector\r\n * @returns the dot product (float)\r\n */\r\n Vector2.Dot = function (left, right) {\r\n return left.x * right.x + left.y * right.y;\r\n };\r\n /**\r\n * Returns a new Vector2 equal to the normalized given vector\r\n * @param vector defines the vector to normalize\r\n * @returns a new Vector2\r\n */\r\n Vector2.Normalize = function (vector) {\r\n var newVector = vector.clone();\r\n newVector.normalize();\r\n return newVector;\r\n };\r\n /**\r\n * Gets a new Vector2 set with the minimal coordinate values from the \"left\" and \"right\" vectors\r\n * @param left defines 1st vector\r\n * @param right defines 2nd vector\r\n * @returns a new Vector2\r\n */\r\n Vector2.Minimize = function (left, right) {\r\n var x = (left.x < right.x) ? left.x : right.x;\r\n var y = (left.y < right.y) ? left.y : right.y;\r\n return new Vector2(x, y);\r\n };\r\n /**\r\n * Gets a new Vecto2 set with the maximal coordinate values from the \"left\" and \"right\" vectors\r\n * @param left defines 1st vector\r\n * @param right defines 2nd vector\r\n * @returns a new Vector2\r\n */\r\n Vector2.Maximize = function (left, right) {\r\n var x = (left.x > right.x) ? left.x : right.x;\r\n var y = (left.y > right.y) ? left.y : right.y;\r\n return new Vector2(x, y);\r\n };\r\n /**\r\n * Gets a new Vector2 set with the transformed coordinates of the given vector by the given transformation matrix\r\n * @param vector defines the vector to transform\r\n * @param transformation defines the matrix to apply\r\n * @returns a new Vector2\r\n */\r\n Vector2.Transform = function (vector, transformation) {\r\n var r = Vector2.Zero();\r\n Vector2.TransformToRef(vector, transformation, r);\r\n return r;\r\n };\r\n /**\r\n * Transforms the given vector coordinates by the given transformation matrix and stores the result in the vector \"result\" coordinates\r\n * @param vector defines the vector to transform\r\n * @param transformation defines the matrix to apply\r\n * @param result defines the target vector\r\n */\r\n Vector2.TransformToRef = function (vector, transformation, result) {\r\n var m = transformation.m;\r\n var x = (vector.x * m[0]) + (vector.y * m[4]) + m[12];\r\n var y = (vector.x * m[1]) + (vector.y * m[5]) + m[13];\r\n result.x = x;\r\n result.y = y;\r\n };\r\n /**\r\n * Determines if a given vector is included in a triangle\r\n * @param p defines the vector to test\r\n * @param p0 defines 1st triangle point\r\n * @param p1 defines 2nd triangle point\r\n * @param p2 defines 3rd triangle point\r\n * @returns true if the point \"p\" is in the triangle defined by the vertors \"p0\", \"p1\", \"p2\"\r\n */\r\n Vector2.PointInTriangle = function (p, p0, p1, p2) {\r\n var a = 1 / 2 * (-p1.y * p2.x + p0.y * (-p1.x + p2.x) + p0.x * (p1.y - p2.y) + p1.x * p2.y);\r\n var sign = a < 0 ? -1 : 1;\r\n var s = (p0.y * p2.x - p0.x * p2.y + (p2.y - p0.y) * p.x + (p0.x - p2.x) * p.y) * sign;\r\n var t = (p0.x * p1.y - p0.y * p1.x + (p0.y - p1.y) * p.x + (p1.x - p0.x) * p.y) * sign;\r\n return s > 0 && t > 0 && (s + t) < 2 * a * sign;\r\n };\r\n /**\r\n * Gets the distance between the vectors \"value1\" and \"value2\"\r\n * @param value1 defines first vector\r\n * @param value2 defines second vector\r\n * @returns the distance between vectors\r\n */\r\n Vector2.Distance = function (value1, value2) {\r\n return Math.sqrt(Vector2.DistanceSquared(value1, value2));\r\n };\r\n /**\r\n * Returns the squared distance between the vectors \"value1\" and \"value2\"\r\n * @param value1 defines first vector\r\n * @param value2 defines second vector\r\n * @returns the squared distance between vectors\r\n */\r\n Vector2.DistanceSquared = function (value1, value2) {\r\n var x = value1.x - value2.x;\r\n var y = value1.y - value2.y;\r\n return (x * x) + (y * y);\r\n };\r\n /**\r\n * Gets a new Vector2 located at the center of the vectors \"value1\" and \"value2\"\r\n * @param value1 defines first vector\r\n * @param value2 defines second vector\r\n * @returns a new Vector2\r\n */\r\n Vector2.Center = function (value1, value2) {\r\n var center = value1.add(value2);\r\n center.scaleInPlace(0.5);\r\n return center;\r\n };\r\n /**\r\n * Gets the shortest distance (float) between the point \"p\" and the segment defined by the two points \"segA\" and \"segB\".\r\n * @param p defines the middle point\r\n * @param segA defines one point of the segment\r\n * @param segB defines the other point of the segment\r\n * @returns the shortest distance\r\n */\r\n Vector2.DistanceOfPointFromSegment = function (p, segA, segB) {\r\n var l2 = Vector2.DistanceSquared(segA, segB);\r\n if (l2 === 0.0) {\r\n return Vector2.Distance(p, segA);\r\n }\r\n var v = segB.subtract(segA);\r\n var t = Math.max(0, Math.min(1, Vector2.Dot(p.subtract(segA), v) / l2));\r\n var proj = segA.add(v.multiplyByFloats(t, t));\r\n return Vector2.Distance(p, proj);\r\n };\r\n return Vector2;\r\n}());\r\nexport { Vector2 };\r\n/**\r\n * Class used to store (x,y,z) vector representation\r\n * A Vector3 is the main object used in 3D geometry\r\n * It can represent etiher the coordinates of a point the space, either a direction\r\n * Reminder: js uses a left handed forward facing system\r\n */\r\nvar Vector3 = /** @class */ (function () {\r\n /**\r\n * Creates a new Vector3 object from the given x, y, z (floats) coordinates.\r\n * @param x defines the first coordinates (on X axis)\r\n * @param y defines the second coordinates (on Y axis)\r\n * @param z defines the third coordinates (on Z axis)\r\n */\r\n function Vector3(\r\n /**\r\n * Defines the first coordinates (on X axis)\r\n */\r\n x, \r\n /**\r\n * Defines the second coordinates (on Y axis)\r\n */\r\n y, \r\n /**\r\n * Defines the third coordinates (on Z axis)\r\n */\r\n z) {\r\n if (x === void 0) { x = 0; }\r\n if (y === void 0) { y = 0; }\r\n if (z === void 0) { z = 0; }\r\n this.x = x;\r\n this.y = y;\r\n this.z = z;\r\n }\r\n /**\r\n * Creates a string representation of the Vector3\r\n * @returns a string with the Vector3 coordinates.\r\n */\r\n Vector3.prototype.toString = function () {\r\n return \"{X: \" + this.x + \" Y:\" + this.y + \" Z:\" + this.z + \"}\";\r\n };\r\n /**\r\n * Gets the class name\r\n * @returns the string \"Vector3\"\r\n */\r\n Vector3.prototype.getClassName = function () {\r\n return \"Vector3\";\r\n };\r\n /**\r\n * Creates the Vector3 hash code\r\n * @returns a number which tends to be unique between Vector3 instances\r\n */\r\n Vector3.prototype.getHashCode = function () {\r\n var hash = this.x | 0;\r\n hash = (hash * 397) ^ (this.y | 0);\r\n hash = (hash * 397) ^ (this.z | 0);\r\n return hash;\r\n };\r\n // Operators\r\n /**\r\n * Creates an array containing three elements : the coordinates of the Vector3\r\n * @returns a new array of numbers\r\n */\r\n Vector3.prototype.asArray = function () {\r\n var result = [];\r\n this.toArray(result, 0);\r\n return result;\r\n };\r\n /**\r\n * Populates the given array or Float32Array from the given index with the successive coordinates of the Vector3\r\n * @param array defines the destination array\r\n * @param index defines the offset in the destination array\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.toArray = function (array, index) {\r\n if (index === void 0) { index = 0; }\r\n array[index] = this.x;\r\n array[index + 1] = this.y;\r\n array[index + 2] = this.z;\r\n return this;\r\n };\r\n /**\r\n * Converts the current Vector3 into a quaternion (considering that the Vector3 contains Euler angles representation of a rotation)\r\n * @returns a new Quaternion object, computed from the Vector3 coordinates\r\n */\r\n Vector3.prototype.toQuaternion = function () {\r\n return Quaternion.RotationYawPitchRoll(this.y, this.x, this.z);\r\n };\r\n /**\r\n * Adds the given vector to the current Vector3\r\n * @param otherVector defines the second operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.addInPlace = function (otherVector) {\r\n return this.addInPlaceFromFloats(otherVector.x, otherVector.y, otherVector.z);\r\n };\r\n /**\r\n * Adds the given coordinates to the current Vector3\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.addInPlaceFromFloats = function (x, y, z) {\r\n this.x += x;\r\n this.y += y;\r\n this.z += z;\r\n return this;\r\n };\r\n /**\r\n * Gets a new Vector3, result of the addition the current Vector3 and the given vector\r\n * @param otherVector defines the second operand\r\n * @returns the resulting Vector3\r\n */\r\n Vector3.prototype.add = function (otherVector) {\r\n return new Vector3(this.x + otherVector.x, this.y + otherVector.y, this.z + otherVector.z);\r\n };\r\n /**\r\n * Adds the current Vector3 to the given one and stores the result in the vector \"result\"\r\n * @param otherVector defines the second operand\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.addToRef = function (otherVector, result) {\r\n return result.copyFromFloats(this.x + otherVector.x, this.y + otherVector.y, this.z + otherVector.z);\r\n };\r\n /**\r\n * Subtract the given vector from the current Vector3\r\n * @param otherVector defines the second operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.subtractInPlace = function (otherVector) {\r\n this.x -= otherVector.x;\r\n this.y -= otherVector.y;\r\n this.z -= otherVector.z;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector3, result of the subtraction of the given vector from the current Vector3\r\n * @param otherVector defines the second operand\r\n * @returns the resulting Vector3\r\n */\r\n Vector3.prototype.subtract = function (otherVector) {\r\n return new Vector3(this.x - otherVector.x, this.y - otherVector.y, this.z - otherVector.z);\r\n };\r\n /**\r\n * Subtracts the given vector from the current Vector3 and stores the result in the vector \"result\".\r\n * @param otherVector defines the second operand\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.subtractToRef = function (otherVector, result) {\r\n return this.subtractFromFloatsToRef(otherVector.x, otherVector.y, otherVector.z, result);\r\n };\r\n /**\r\n * Returns a new Vector3 set with the subtraction of the given floats from the current Vector3 coordinates\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @returns the resulting Vector3\r\n */\r\n Vector3.prototype.subtractFromFloats = function (x, y, z) {\r\n return new Vector3(this.x - x, this.y - y, this.z - z);\r\n };\r\n /**\r\n * Subtracts the given floats from the current Vector3 coordinates and set the given vector \"result\" with this result\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.subtractFromFloatsToRef = function (x, y, z, result) {\r\n return result.copyFromFloats(this.x - x, this.y - y, this.z - z);\r\n };\r\n /**\r\n * Gets a new Vector3 set with the current Vector3 negated coordinates\r\n * @returns a new Vector3\r\n */\r\n Vector3.prototype.negate = function () {\r\n return new Vector3(-this.x, -this.y, -this.z);\r\n };\r\n /**\r\n * Negate this vector in place\r\n * @returns this\r\n */\r\n Vector3.prototype.negateInPlace = function () {\r\n this.x *= -1;\r\n this.y *= -1;\r\n this.z *= -1;\r\n return this;\r\n };\r\n /**\r\n * Negate the current Vector3 and stores the result in the given vector \"result\" coordinates\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.negateToRef = function (result) {\r\n return result.copyFromFloats(this.x * -1, this.y * -1, this.z * -1);\r\n };\r\n /**\r\n * Multiplies the Vector3 coordinates by the float \"scale\"\r\n * @param scale defines the multiplier factor\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.scaleInPlace = function (scale) {\r\n this.x *= scale;\r\n this.y *= scale;\r\n this.z *= scale;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector3 set with the current Vector3 coordinates multiplied by the float \"scale\"\r\n * @param scale defines the multiplier factor\r\n * @returns a new Vector3\r\n */\r\n Vector3.prototype.scale = function (scale) {\r\n return new Vector3(this.x * scale, this.y * scale, this.z * scale);\r\n };\r\n /**\r\n * Multiplies the current Vector3 coordinates by the float \"scale\" and stores the result in the given vector \"result\" coordinates\r\n * @param scale defines the multiplier factor\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.scaleToRef = function (scale, result) {\r\n return result.copyFromFloats(this.x * scale, this.y * scale, this.z * scale);\r\n };\r\n /**\r\n * Scale the current Vector3 values by a factor and add the result to a given Vector3\r\n * @param scale defines the scale factor\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the unmodified current Vector3\r\n */\r\n Vector3.prototype.scaleAndAddToRef = function (scale, result) {\r\n return result.addInPlaceFromFloats(this.x * scale, this.y * scale, this.z * scale);\r\n };\r\n /**\r\n * Returns true if the current Vector3 and the given vector coordinates are strictly equal\r\n * @param otherVector defines the second operand\r\n * @returns true if both vectors are equals\r\n */\r\n Vector3.prototype.equals = function (otherVector) {\r\n return otherVector && this.x === otherVector.x && this.y === otherVector.y && this.z === otherVector.z;\r\n };\r\n /**\r\n * Returns true if the current Vector3 and the given vector coordinates are distant less than epsilon\r\n * @param otherVector defines the second operand\r\n * @param epsilon defines the minimal distance to define values as equals\r\n * @returns true if both vectors are distant less than epsilon\r\n */\r\n Vector3.prototype.equalsWithEpsilon = function (otherVector, epsilon) {\r\n if (epsilon === void 0) { epsilon = Epsilon; }\r\n return otherVector && Scalar.WithinEpsilon(this.x, otherVector.x, epsilon) && Scalar.WithinEpsilon(this.y, otherVector.y, epsilon) && Scalar.WithinEpsilon(this.z, otherVector.z, epsilon);\r\n };\r\n /**\r\n * Returns true if the current Vector3 coordinates equals the given floats\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @returns true if both vectors are equals\r\n */\r\n Vector3.prototype.equalsToFloats = function (x, y, z) {\r\n return this.x === x && this.y === y && this.z === z;\r\n };\r\n /**\r\n * Multiplies the current Vector3 coordinates by the given ones\r\n * @param otherVector defines the second operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.multiplyInPlace = function (otherVector) {\r\n this.x *= otherVector.x;\r\n this.y *= otherVector.y;\r\n this.z *= otherVector.z;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector3, result of the multiplication of the current Vector3 by the given vector\r\n * @param otherVector defines the second operand\r\n * @returns the new Vector3\r\n */\r\n Vector3.prototype.multiply = function (otherVector) {\r\n return this.multiplyByFloats(otherVector.x, otherVector.y, otherVector.z);\r\n };\r\n /**\r\n * Multiplies the current Vector3 by the given one and stores the result in the given vector \"result\"\r\n * @param otherVector defines the second operand\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.multiplyToRef = function (otherVector, result) {\r\n return result.copyFromFloats(this.x * otherVector.x, this.y * otherVector.y, this.z * otherVector.z);\r\n };\r\n /**\r\n * Returns a new Vector3 set with the result of the mulliplication of the current Vector3 coordinates by the given floats\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @returns the new Vector3\r\n */\r\n Vector3.prototype.multiplyByFloats = function (x, y, z) {\r\n return new Vector3(this.x * x, this.y * y, this.z * z);\r\n };\r\n /**\r\n * Returns a new Vector3 set with the result of the division of the current Vector3 coordinates by the given ones\r\n * @param otherVector defines the second operand\r\n * @returns the new Vector3\r\n */\r\n Vector3.prototype.divide = function (otherVector) {\r\n return new Vector3(this.x / otherVector.x, this.y / otherVector.y, this.z / otherVector.z);\r\n };\r\n /**\r\n * Divides the current Vector3 coordinates by the given ones and stores the result in the given vector \"result\"\r\n * @param otherVector defines the second operand\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.divideToRef = function (otherVector, result) {\r\n return result.copyFromFloats(this.x / otherVector.x, this.y / otherVector.y, this.z / otherVector.z);\r\n };\r\n /**\r\n * Divides the current Vector3 coordinates by the given ones.\r\n * @param otherVector defines the second operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.divideInPlace = function (otherVector) {\r\n return this.divideToRef(otherVector, this);\r\n };\r\n /**\r\n * Updates the current Vector3 with the minimal coordinate values between its and the given vector ones\r\n * @param other defines the second operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.minimizeInPlace = function (other) {\r\n return this.minimizeInPlaceFromFloats(other.x, other.y, other.z);\r\n };\r\n /**\r\n * Updates the current Vector3 with the maximal coordinate values between its and the given vector ones.\r\n * @param other defines the second operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.maximizeInPlace = function (other) {\r\n return this.maximizeInPlaceFromFloats(other.x, other.y, other.z);\r\n };\r\n /**\r\n * Updates the current Vector3 with the minimal coordinate values between its and the given coordinates\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.minimizeInPlaceFromFloats = function (x, y, z) {\r\n if (x < this.x) {\r\n this.x = x;\r\n }\r\n if (y < this.y) {\r\n this.y = y;\r\n }\r\n if (z < this.z) {\r\n this.z = z;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Updates the current Vector3 with the maximal coordinate values between its and the given coordinates.\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.maximizeInPlaceFromFloats = function (x, y, z) {\r\n if (x > this.x) {\r\n this.x = x;\r\n }\r\n if (y > this.y) {\r\n this.y = y;\r\n }\r\n if (z > this.z) {\r\n this.z = z;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Due to float precision, scale of a mesh could be uniform but float values are off by a small fraction\r\n * Check if is non uniform within a certain amount of decimal places to account for this\r\n * @param epsilon the amount the values can differ\r\n * @returns if the the vector is non uniform to a certain number of decimal places\r\n */\r\n Vector3.prototype.isNonUniformWithinEpsilon = function (epsilon) {\r\n var absX = Math.abs(this.x);\r\n var absY = Math.abs(this.y);\r\n if (!Scalar.WithinEpsilon(absX, absY, epsilon)) {\r\n return true;\r\n }\r\n var absZ = Math.abs(this.z);\r\n if (!Scalar.WithinEpsilon(absX, absZ, epsilon)) {\r\n return true;\r\n }\r\n if (!Scalar.WithinEpsilon(absY, absZ, epsilon)) {\r\n return true;\r\n }\r\n return false;\r\n };\r\n Object.defineProperty(Vector3.prototype, \"isNonUniform\", {\r\n /**\r\n * Gets a boolean indicating that the vector is non uniform meaning x, y or z are not all the same\r\n */\r\n get: function () {\r\n var absX = Math.abs(this.x);\r\n var absY = Math.abs(this.y);\r\n if (absX !== absY) {\r\n return true;\r\n }\r\n var absZ = Math.abs(this.z);\r\n if (absX !== absZ) {\r\n return true;\r\n }\r\n if (absY !== absZ) {\r\n return true;\r\n }\r\n return false;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets a new Vector3 from current Vector3 floored values\r\n * @returns a new Vector3\r\n */\r\n Vector3.prototype.floor = function () {\r\n return new Vector3(Math.floor(this.x), Math.floor(this.y), Math.floor(this.z));\r\n };\r\n /**\r\n * Gets a new Vector3 from current Vector3 floored values\r\n * @returns a new Vector3\r\n */\r\n Vector3.prototype.fract = function () {\r\n return new Vector3(this.x - Math.floor(this.x), this.y - Math.floor(this.y), this.z - Math.floor(this.z));\r\n };\r\n // Properties\r\n /**\r\n * Gets the length of the Vector3\r\n * @returns the length of the Vector3\r\n */\r\n Vector3.prototype.length = function () {\r\n return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z);\r\n };\r\n /**\r\n * Gets the squared length of the Vector3\r\n * @returns squared length of the Vector3\r\n */\r\n Vector3.prototype.lengthSquared = function () {\r\n return (this.x * this.x + this.y * this.y + this.z * this.z);\r\n };\r\n /**\r\n * Normalize the current Vector3.\r\n * Please note that this is an in place operation.\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.normalize = function () {\r\n return this.normalizeFromLength(this.length());\r\n };\r\n /**\r\n * Reorders the x y z properties of the vector in place\r\n * @param order new ordering of the properties (eg. for vector 1,2,3 with \"ZYX\" will produce 3,2,1)\r\n * @returns the current updated vector\r\n */\r\n Vector3.prototype.reorderInPlace = function (order) {\r\n var _this = this;\r\n order = order.toLowerCase();\r\n if (order === \"xyz\") {\r\n return this;\r\n }\r\n MathTmp.Vector3[0].copyFrom(this);\r\n [\"x\", \"y\", \"z\"].forEach(function (val, i) {\r\n _this[val] = MathTmp.Vector3[0][order[i]];\r\n });\r\n return this;\r\n };\r\n /**\r\n * Rotates the vector around 0,0,0 by a quaternion\r\n * @param quaternion the rotation quaternion\r\n * @param result vector to store the result\r\n * @returns the resulting vector\r\n */\r\n Vector3.prototype.rotateByQuaternionToRef = function (quaternion, result) {\r\n quaternion.toRotationMatrix(MathTmp.Matrix[0]);\r\n Vector3.TransformCoordinatesToRef(this, MathTmp.Matrix[0], result);\r\n return result;\r\n };\r\n /**\r\n * Rotates a vector around a given point\r\n * @param quaternion the rotation quaternion\r\n * @param point the point to rotate around\r\n * @param result vector to store the result\r\n * @returns the resulting vector\r\n */\r\n Vector3.prototype.rotateByQuaternionAroundPointToRef = function (quaternion, point, result) {\r\n this.subtractToRef(point, MathTmp.Vector3[0]);\r\n MathTmp.Vector3[0].rotateByQuaternionToRef(quaternion, MathTmp.Vector3[0]);\r\n point.addToRef(MathTmp.Vector3[0], result);\r\n return result;\r\n };\r\n /**\r\n * Returns a new Vector3 as the cross product of the current vector and the \"other\" one\r\n * The cross product is then orthogonal to both current and \"other\"\r\n * @param other defines the right operand\r\n * @returns the cross product\r\n */\r\n Vector3.prototype.cross = function (other) {\r\n return Vector3.Cross(this, other);\r\n };\r\n /**\r\n * Normalize the current Vector3 with the given input length.\r\n * Please note that this is an in place operation.\r\n * @param len the length of the vector\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.normalizeFromLength = function (len) {\r\n if (len === 0 || len === 1.0) {\r\n return this;\r\n }\r\n return this.scaleInPlace(1.0 / len);\r\n };\r\n /**\r\n * Normalize the current Vector3 to a new vector\r\n * @returns the new Vector3\r\n */\r\n Vector3.prototype.normalizeToNew = function () {\r\n var normalized = new Vector3(0, 0, 0);\r\n this.normalizeToRef(normalized);\r\n return normalized;\r\n };\r\n /**\r\n * Normalize the current Vector3 to the reference\r\n * @param reference define the Vector3 to update\r\n * @returns the updated Vector3\r\n */\r\n Vector3.prototype.normalizeToRef = function (reference) {\r\n var len = this.length();\r\n if (len === 0 || len === 1.0) {\r\n return reference.copyFromFloats(this.x, this.y, this.z);\r\n }\r\n return this.scaleToRef(1.0 / len, reference);\r\n };\r\n /**\r\n * Creates a new Vector3 copied from the current Vector3\r\n * @returns the new Vector3\r\n */\r\n Vector3.prototype.clone = function () {\r\n return new Vector3(this.x, this.y, this.z);\r\n };\r\n /**\r\n * Copies the given vector coordinates to the current Vector3 ones\r\n * @param source defines the source Vector3\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.copyFrom = function (source) {\r\n return this.copyFromFloats(source.x, source.y, source.z);\r\n };\r\n /**\r\n * Copies the given floats to the current Vector3 coordinates\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.copyFromFloats = function (x, y, z) {\r\n this.x = x;\r\n this.y = y;\r\n this.z = z;\r\n return this;\r\n };\r\n /**\r\n * Copies the given floats to the current Vector3 coordinates\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.set = function (x, y, z) {\r\n return this.copyFromFloats(x, y, z);\r\n };\r\n /**\r\n * Copies the given float to the current Vector3 coordinates\r\n * @param v defines the x, y and z coordinates of the operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.setAll = function (v) {\r\n this.x = this.y = this.z = v;\r\n return this;\r\n };\r\n // Statics\r\n /**\r\n * Get the clip factor between two vectors\r\n * @param vector0 defines the first operand\r\n * @param vector1 defines the second operand\r\n * @param axis defines the axis to use\r\n * @param size defines the size along the axis\r\n * @returns the clip factor\r\n */\r\n Vector3.GetClipFactor = function (vector0, vector1, axis, size) {\r\n var d0 = Vector3.Dot(vector0, axis) - size;\r\n var d1 = Vector3.Dot(vector1, axis) - size;\r\n var s = d0 / (d0 - d1);\r\n return s;\r\n };\r\n /**\r\n * Get angle between two vectors\r\n * @param vector0 angle between vector0 and vector1\r\n * @param vector1 angle between vector0 and vector1\r\n * @param normal direction of the normal\r\n * @return the angle between vector0 and vector1\r\n */\r\n Vector3.GetAngleBetweenVectors = function (vector0, vector1, normal) {\r\n var v0 = vector0.normalizeToRef(MathTmp.Vector3[1]);\r\n var v1 = vector1.normalizeToRef(MathTmp.Vector3[2]);\r\n var dot = Vector3.Dot(v0, v1);\r\n var n = MathTmp.Vector3[3];\r\n Vector3.CrossToRef(v0, v1, n);\r\n if (Vector3.Dot(n, normal) > 0) {\r\n return Math.acos(dot);\r\n }\r\n return -Math.acos(dot);\r\n };\r\n /**\r\n * Returns a new Vector3 set from the index \"offset\" of the given array\r\n * @param array defines the source array\r\n * @param offset defines the offset in the source array\r\n * @returns the new Vector3\r\n */\r\n Vector3.FromArray = function (array, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n return new Vector3(array[offset], array[offset + 1], array[offset + 2]);\r\n };\r\n /**\r\n * Returns a new Vector3 set from the index \"offset\" of the given Float32Array\r\n * @param array defines the source array\r\n * @param offset defines the offset in the source array\r\n * @returns the new Vector3\r\n * @deprecated Please use FromArray instead.\r\n */\r\n Vector3.FromFloatArray = function (array, offset) {\r\n return Vector3.FromArray(array, offset);\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the element values from the index \"offset\" of the given array\r\n * @param array defines the source array\r\n * @param offset defines the offset in the source array\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.FromArrayToRef = function (array, offset, result) {\r\n result.x = array[offset];\r\n result.y = array[offset + 1];\r\n result.z = array[offset + 2];\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the element values from the index \"offset\" of the given Float32Array\r\n * @param array defines the source array\r\n * @param offset defines the offset in the source array\r\n * @param result defines the Vector3 where to store the result\r\n * @deprecated Please use FromArrayToRef instead.\r\n */\r\n Vector3.FromFloatArrayToRef = function (array, offset, result) {\r\n return Vector3.FromArrayToRef(array, offset, result);\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the given floats.\r\n * @param x defines the x coordinate of the source\r\n * @param y defines the y coordinate of the source\r\n * @param z defines the z coordinate of the source\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.FromFloatsToRef = function (x, y, z, result) {\r\n result.copyFromFloats(x, y, z);\r\n };\r\n /**\r\n * Returns a new Vector3 set to (0.0, 0.0, 0.0)\r\n * @returns a new empty Vector3\r\n */\r\n Vector3.Zero = function () {\r\n return new Vector3(0.0, 0.0, 0.0);\r\n };\r\n /**\r\n * Returns a new Vector3 set to (1.0, 1.0, 1.0)\r\n * @returns a new unit Vector3\r\n */\r\n Vector3.One = function () {\r\n return new Vector3(1.0, 1.0, 1.0);\r\n };\r\n /**\r\n * Returns a new Vector3 set to (0.0, 1.0, 0.0)\r\n * @returns a new up Vector3\r\n */\r\n Vector3.Up = function () {\r\n return new Vector3(0.0, 1.0, 0.0);\r\n };\r\n Object.defineProperty(Vector3, \"UpReadOnly\", {\r\n /**\r\n * Gets a up Vector3 that must not be updated\r\n */\r\n get: function () {\r\n return Vector3._UpReadOnly;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Vector3, \"ZeroReadOnly\", {\r\n /**\r\n * Gets a zero Vector3 that must not be updated\r\n */\r\n get: function () {\r\n return Vector3._ZeroReadOnly;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Returns a new Vector3 set to (0.0, -1.0, 0.0)\r\n * @returns a new down Vector3\r\n */\r\n Vector3.Down = function () {\r\n return new Vector3(0.0, -1.0, 0.0);\r\n };\r\n /**\r\n * Returns a new Vector3 set to (0.0, 0.0, 1.0)\r\n * @returns a new forward Vector3\r\n */\r\n Vector3.Forward = function () {\r\n return new Vector3(0.0, 0.0, 1.0);\r\n };\r\n /**\r\n * Returns a new Vector3 set to (0.0, 0.0, -1.0)\r\n * @returns a new forward Vector3\r\n */\r\n Vector3.Backward = function () {\r\n return new Vector3(0.0, 0.0, -1.0);\r\n };\r\n /**\r\n * Returns a new Vector3 set to (1.0, 0.0, 0.0)\r\n * @returns a new right Vector3\r\n */\r\n Vector3.Right = function () {\r\n return new Vector3(1.0, 0.0, 0.0);\r\n };\r\n /**\r\n * Returns a new Vector3 set to (-1.0, 0.0, 0.0)\r\n * @returns a new left Vector3\r\n */\r\n Vector3.Left = function () {\r\n return new Vector3(-1.0, 0.0, 0.0);\r\n };\r\n /**\r\n * Returns a new Vector3 set with the result of the transformation by the given matrix of the given vector.\r\n * This method computes tranformed coordinates only, not transformed direction vectors (ie. it takes translation in account)\r\n * @param vector defines the Vector3 to transform\r\n * @param transformation defines the transformation matrix\r\n * @returns the transformed Vector3\r\n */\r\n Vector3.TransformCoordinates = function (vector, transformation) {\r\n var result = Vector3.Zero();\r\n Vector3.TransformCoordinatesToRef(vector, transformation, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given vector \"result\" coordinates with the result of the transformation by the given matrix of the given vector\r\n * This method computes tranformed coordinates only, not transformed direction vectors (ie. it takes translation in account)\r\n * @param vector defines the Vector3 to transform\r\n * @param transformation defines the transformation matrix\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.TransformCoordinatesToRef = function (vector, transformation, result) {\r\n Vector3.TransformCoordinatesFromFloatsToRef(vector.x, vector.y, vector.z, transformation, result);\r\n };\r\n /**\r\n * Sets the given vector \"result\" coordinates with the result of the transformation by the given matrix of the given floats (x, y, z)\r\n * This method computes tranformed coordinates only, not transformed direction vectors\r\n * @param x define the x coordinate of the source vector\r\n * @param y define the y coordinate of the source vector\r\n * @param z define the z coordinate of the source vector\r\n * @param transformation defines the transformation matrix\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.TransformCoordinatesFromFloatsToRef = function (x, y, z, transformation, result) {\r\n var m = transformation.m;\r\n var rx = x * m[0] + y * m[4] + z * m[8] + m[12];\r\n var ry = x * m[1] + y * m[5] + z * m[9] + m[13];\r\n var rz = x * m[2] + y * m[6] + z * m[10] + m[14];\r\n var rw = 1 / (x * m[3] + y * m[7] + z * m[11] + m[15]);\r\n result.x = rx * rw;\r\n result.y = ry * rw;\r\n result.z = rz * rw;\r\n };\r\n /**\r\n * Returns a new Vector3 set with the result of the normal transformation by the given matrix of the given vector\r\n * This methods computes transformed normalized direction vectors only (ie. it does not apply translation)\r\n * @param vector defines the Vector3 to transform\r\n * @param transformation defines the transformation matrix\r\n * @returns the new Vector3\r\n */\r\n Vector3.TransformNormal = function (vector, transformation) {\r\n var result = Vector3.Zero();\r\n Vector3.TransformNormalToRef(vector, transformation, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the result of the normal transformation by the given matrix of the given vector\r\n * This methods computes transformed normalized direction vectors only (ie. it does not apply translation)\r\n * @param vector defines the Vector3 to transform\r\n * @param transformation defines the transformation matrix\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.TransformNormalToRef = function (vector, transformation, result) {\r\n this.TransformNormalFromFloatsToRef(vector.x, vector.y, vector.z, transformation, result);\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the result of the normal transformation by the given matrix of the given floats (x, y, z)\r\n * This methods computes transformed normalized direction vectors only (ie. it does not apply translation)\r\n * @param x define the x coordinate of the source vector\r\n * @param y define the y coordinate of the source vector\r\n * @param z define the z coordinate of the source vector\r\n * @param transformation defines the transformation matrix\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.TransformNormalFromFloatsToRef = function (x, y, z, transformation, result) {\r\n var m = transformation.m;\r\n result.x = x * m[0] + y * m[4] + z * m[8];\r\n result.y = x * m[1] + y * m[5] + z * m[9];\r\n result.z = x * m[2] + y * m[6] + z * m[10];\r\n };\r\n /**\r\n * Returns a new Vector3 located for \"amount\" on the CatmullRom interpolation spline defined by the vectors \"value1\", \"value2\", \"value3\", \"value4\"\r\n * @param value1 defines the first control point\r\n * @param value2 defines the second control point\r\n * @param value3 defines the third control point\r\n * @param value4 defines the fourth control point\r\n * @param amount defines the amount on the spline to use\r\n * @returns the new Vector3\r\n */\r\n Vector3.CatmullRom = function (value1, value2, value3, value4, amount) {\r\n var squared = amount * amount;\r\n var cubed = amount * squared;\r\n var x = 0.5 * ((((2.0 * value2.x) + ((-value1.x + value3.x) * amount)) +\r\n (((((2.0 * value1.x) - (5.0 * value2.x)) + (4.0 * value3.x)) - value4.x) * squared)) +\r\n ((((-value1.x + (3.0 * value2.x)) - (3.0 * value3.x)) + value4.x) * cubed));\r\n var y = 0.5 * ((((2.0 * value2.y) + ((-value1.y + value3.y) * amount)) +\r\n (((((2.0 * value1.y) - (5.0 * value2.y)) + (4.0 * value3.y)) - value4.y) * squared)) +\r\n ((((-value1.y + (3.0 * value2.y)) - (3.0 * value3.y)) + value4.y) * cubed));\r\n var z = 0.5 * ((((2.0 * value2.z) + ((-value1.z + value3.z) * amount)) +\r\n (((((2.0 * value1.z) - (5.0 * value2.z)) + (4.0 * value3.z)) - value4.z) * squared)) +\r\n ((((-value1.z + (3.0 * value2.z)) - (3.0 * value3.z)) + value4.z) * cubed));\r\n return new Vector3(x, y, z);\r\n };\r\n /**\r\n * Returns a new Vector3 set with the coordinates of \"value\", if the vector \"value\" is in the cube defined by the vectors \"min\" and \"max\"\r\n * If a coordinate value of \"value\" is lower than one of the \"min\" coordinate, then this \"value\" coordinate is set with the \"min\" one\r\n * If a coordinate value of \"value\" is greater than one of the \"max\" coordinate, then this \"value\" coordinate is set with the \"max\" one\r\n * @param value defines the current value\r\n * @param min defines the lower range value\r\n * @param max defines the upper range value\r\n * @returns the new Vector3\r\n */\r\n Vector3.Clamp = function (value, min, max) {\r\n var v = new Vector3();\r\n Vector3.ClampToRef(value, min, max, v);\r\n return v;\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the coordinates of \"value\", if the vector \"value\" is in the cube defined by the vectors \"min\" and \"max\"\r\n * If a coordinate value of \"value\" is lower than one of the \"min\" coordinate, then this \"value\" coordinate is set with the \"min\" one\r\n * If a coordinate value of \"value\" is greater than one of the \"max\" coordinate, then this \"value\" coordinate is set with the \"max\" one\r\n * @param value defines the current value\r\n * @param min defines the lower range value\r\n * @param max defines the upper range value\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.ClampToRef = function (value, min, max, result) {\r\n var x = value.x;\r\n x = (x > max.x) ? max.x : x;\r\n x = (x < min.x) ? min.x : x;\r\n var y = value.y;\r\n y = (y > max.y) ? max.y : y;\r\n y = (y < min.y) ? min.y : y;\r\n var z = value.z;\r\n z = (z > max.z) ? max.z : z;\r\n z = (z < min.z) ? min.z : z;\r\n result.copyFromFloats(x, y, z);\r\n };\r\n /**\r\n * Checks if a given vector is inside a specific range\r\n * @param v defines the vector to test\r\n * @param min defines the minimum range\r\n * @param max defines the maximum range\r\n */\r\n Vector3.CheckExtends = function (v, min, max) {\r\n min.minimizeInPlace(v);\r\n max.maximizeInPlace(v);\r\n };\r\n /**\r\n * Returns a new Vector3 located for \"amount\" (float) on the Hermite interpolation spline defined by the vectors \"value1\", \"tangent1\", \"value2\", \"tangent2\"\r\n * @param value1 defines the first control point\r\n * @param tangent1 defines the first tangent vector\r\n * @param value2 defines the second control point\r\n * @param tangent2 defines the second tangent vector\r\n * @param amount defines the amount on the interpolation spline (between 0 and 1)\r\n * @returns the new Vector3\r\n */\r\n Vector3.Hermite = function (value1, tangent1, value2, tangent2, amount) {\r\n var squared = amount * amount;\r\n var cubed = amount * squared;\r\n var part1 = ((2.0 * cubed) - (3.0 * squared)) + 1.0;\r\n var part2 = (-2.0 * cubed) + (3.0 * squared);\r\n var part3 = (cubed - (2.0 * squared)) + amount;\r\n var part4 = cubed - squared;\r\n var x = (((value1.x * part1) + (value2.x * part2)) + (tangent1.x * part3)) + (tangent2.x * part4);\r\n var y = (((value1.y * part1) + (value2.y * part2)) + (tangent1.y * part3)) + (tangent2.y * part4);\r\n var z = (((value1.z * part1) + (value2.z * part2)) + (tangent1.z * part3)) + (tangent2.z * part4);\r\n return new Vector3(x, y, z);\r\n };\r\n /**\r\n * Returns a new Vector3 located for \"amount\" (float) on the linear interpolation between the vectors \"start\" and \"end\"\r\n * @param start defines the start value\r\n * @param end defines the end value\r\n * @param amount max defines amount between both (between 0 and 1)\r\n * @returns the new Vector3\r\n */\r\n Vector3.Lerp = function (start, end, amount) {\r\n var result = new Vector3(0, 0, 0);\r\n Vector3.LerpToRef(start, end, amount, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the result of the linear interpolation from the vector \"start\" for \"amount\" to the vector \"end\"\r\n * @param start defines the start value\r\n * @param end defines the end value\r\n * @param amount max defines amount between both (between 0 and 1)\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.LerpToRef = function (start, end, amount, result) {\r\n result.x = start.x + ((end.x - start.x) * amount);\r\n result.y = start.y + ((end.y - start.y) * amount);\r\n result.z = start.z + ((end.z - start.z) * amount);\r\n };\r\n /**\r\n * Returns the dot product (float) between the vectors \"left\" and \"right\"\r\n * @param left defines the left operand\r\n * @param right defines the right operand\r\n * @returns the dot product\r\n */\r\n Vector3.Dot = function (left, right) {\r\n return (left.x * right.x + left.y * right.y + left.z * right.z);\r\n };\r\n /**\r\n * Returns a new Vector3 as the cross product of the vectors \"left\" and \"right\"\r\n * The cross product is then orthogonal to both \"left\" and \"right\"\r\n * @param left defines the left operand\r\n * @param right defines the right operand\r\n * @returns the cross product\r\n */\r\n Vector3.Cross = function (left, right) {\r\n var result = Vector3.Zero();\r\n Vector3.CrossToRef(left, right, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the cross product of \"left\" and \"right\"\r\n * The cross product is then orthogonal to both \"left\" and \"right\"\r\n * @param left defines the left operand\r\n * @param right defines the right operand\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.CrossToRef = function (left, right, result) {\r\n var x = left.y * right.z - left.z * right.y;\r\n var y = left.z * right.x - left.x * right.z;\r\n var z = left.x * right.y - left.y * right.x;\r\n result.copyFromFloats(x, y, z);\r\n };\r\n /**\r\n * Returns a new Vector3 as the normalization of the given vector\r\n * @param vector defines the Vector3 to normalize\r\n * @returns the new Vector3\r\n */\r\n Vector3.Normalize = function (vector) {\r\n var result = Vector3.Zero();\r\n Vector3.NormalizeToRef(vector, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the normalization of the given first vector\r\n * @param vector defines the Vector3 to normalize\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.NormalizeToRef = function (vector, result) {\r\n vector.normalizeToRef(result);\r\n };\r\n /**\r\n * Project a Vector3 onto screen space\r\n * @param vector defines the Vector3 to project\r\n * @param world defines the world matrix to use\r\n * @param transform defines the transform (view x projection) matrix to use\r\n * @param viewport defines the screen viewport to use\r\n * @returns the new Vector3\r\n */\r\n Vector3.Project = function (vector, world, transform, viewport) {\r\n var cw = viewport.width;\r\n var ch = viewport.height;\r\n var cx = viewport.x;\r\n var cy = viewport.y;\r\n var viewportMatrix = MathTmp.Matrix[1];\r\n Matrix.FromValuesToRef(cw / 2.0, 0, 0, 0, 0, -ch / 2.0, 0, 0, 0, 0, 0.5, 0, cx + cw / 2.0, ch / 2.0 + cy, 0.5, 1, viewportMatrix);\r\n var matrix = MathTmp.Matrix[0];\r\n world.multiplyToRef(transform, matrix);\r\n matrix.multiplyToRef(viewportMatrix, matrix);\r\n return Vector3.TransformCoordinates(vector, matrix);\r\n };\r\n /** @hidden */\r\n Vector3._UnprojectFromInvertedMatrixToRef = function (source, matrix, result) {\r\n Vector3.TransformCoordinatesToRef(source, matrix, result);\r\n var m = matrix.m;\r\n var num = source.x * m[3] + source.y * m[7] + source.z * m[11] + m[15];\r\n if (Scalar.WithinEpsilon(num, 1.0)) {\r\n result.scaleInPlace(1.0 / num);\r\n }\r\n };\r\n /**\r\n * Unproject from screen space to object space\r\n * @param source defines the screen space Vector3 to use\r\n * @param viewportWidth defines the current width of the viewport\r\n * @param viewportHeight defines the current height of the viewport\r\n * @param world defines the world matrix to use (can be set to Identity to go to world space)\r\n * @param transform defines the transform (view x projection) matrix to use\r\n * @returns the new Vector3\r\n */\r\n Vector3.UnprojectFromTransform = function (source, viewportWidth, viewportHeight, world, transform) {\r\n var matrix = MathTmp.Matrix[0];\r\n world.multiplyToRef(transform, matrix);\r\n matrix.invert();\r\n source.x = source.x / viewportWidth * 2 - 1;\r\n source.y = -(source.y / viewportHeight * 2 - 1);\r\n var vector = new Vector3();\r\n Vector3._UnprojectFromInvertedMatrixToRef(source, matrix, vector);\r\n return vector;\r\n };\r\n /**\r\n * Unproject from screen space to object space\r\n * @param source defines the screen space Vector3 to use\r\n * @param viewportWidth defines the current width of the viewport\r\n * @param viewportHeight defines the current height of the viewport\r\n * @param world defines the world matrix to use (can be set to Identity to go to world space)\r\n * @param view defines the view matrix to use\r\n * @param projection defines the projection matrix to use\r\n * @returns the new Vector3\r\n */\r\n Vector3.Unproject = function (source, viewportWidth, viewportHeight, world, view, projection) {\r\n var result = Vector3.Zero();\r\n Vector3.UnprojectToRef(source, viewportWidth, viewportHeight, world, view, projection, result);\r\n return result;\r\n };\r\n /**\r\n * Unproject from screen space to object space\r\n * @param source defines the screen space Vector3 to use\r\n * @param viewportWidth defines the current width of the viewport\r\n * @param viewportHeight defines the current height of the viewport\r\n * @param world defines the world matrix to use (can be set to Identity to go to world space)\r\n * @param view defines the view matrix to use\r\n * @param projection defines the projection matrix to use\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.UnprojectToRef = function (source, viewportWidth, viewportHeight, world, view, projection, result) {\r\n Vector3.UnprojectFloatsToRef(source.x, source.y, source.z, viewportWidth, viewportHeight, world, view, projection, result);\r\n };\r\n /**\r\n * Unproject from screen space to object space\r\n * @param sourceX defines the screen space x coordinate to use\r\n * @param sourceY defines the screen space y coordinate to use\r\n * @param sourceZ defines the screen space z coordinate to use\r\n * @param viewportWidth defines the current width of the viewport\r\n * @param viewportHeight defines the current height of the viewport\r\n * @param world defines the world matrix to use (can be set to Identity to go to world space)\r\n * @param view defines the view matrix to use\r\n * @param projection defines the projection matrix to use\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.UnprojectFloatsToRef = function (sourceX, sourceY, sourceZ, viewportWidth, viewportHeight, world, view, projection, result) {\r\n var matrix = MathTmp.Matrix[0];\r\n world.multiplyToRef(view, matrix);\r\n matrix.multiplyToRef(projection, matrix);\r\n matrix.invert();\r\n var screenSource = MathTmp.Vector3[0];\r\n screenSource.x = sourceX / viewportWidth * 2 - 1;\r\n screenSource.y = -(sourceY / viewportHeight * 2 - 1);\r\n screenSource.z = 2 * sourceZ - 1.0;\r\n Vector3._UnprojectFromInvertedMatrixToRef(screenSource, matrix, result);\r\n };\r\n /**\r\n * Gets the minimal coordinate values between two Vector3\r\n * @param left defines the first operand\r\n * @param right defines the second operand\r\n * @returns the new Vector3\r\n */\r\n Vector3.Minimize = function (left, right) {\r\n var min = left.clone();\r\n min.minimizeInPlace(right);\r\n return min;\r\n };\r\n /**\r\n * Gets the maximal coordinate values between two Vector3\r\n * @param left defines the first operand\r\n * @param right defines the second operand\r\n * @returns the new Vector3\r\n */\r\n Vector3.Maximize = function (left, right) {\r\n var max = left.clone();\r\n max.maximizeInPlace(right);\r\n return max;\r\n };\r\n /**\r\n * Returns the distance between the vectors \"value1\" and \"value2\"\r\n * @param value1 defines the first operand\r\n * @param value2 defines the second operand\r\n * @returns the distance\r\n */\r\n Vector3.Distance = function (value1, value2) {\r\n return Math.sqrt(Vector3.DistanceSquared(value1, value2));\r\n };\r\n /**\r\n * Returns the squared distance between the vectors \"value1\" and \"value2\"\r\n * @param value1 defines the first operand\r\n * @param value2 defines the second operand\r\n * @returns the squared distance\r\n */\r\n Vector3.DistanceSquared = function (value1, value2) {\r\n var x = value1.x - value2.x;\r\n var y = value1.y - value2.y;\r\n var z = value1.z - value2.z;\r\n return (x * x) + (y * y) + (z * z);\r\n };\r\n /**\r\n * Returns a new Vector3 located at the center between \"value1\" and \"value2\"\r\n * @param value1 defines the first operand\r\n * @param value2 defines the second operand\r\n * @returns the new Vector3\r\n */\r\n Vector3.Center = function (value1, value2) {\r\n var center = value1.add(value2);\r\n center.scaleInPlace(0.5);\r\n return center;\r\n };\r\n /**\r\n * Given three orthogonal normalized left-handed oriented Vector3 axis in space (target system),\r\n * RotationFromAxis() returns the rotation Euler angles (ex : rotation.x, rotation.y, rotation.z) to apply\r\n * to something in order to rotate it from its local system to the given target system\r\n * Note: axis1, axis2 and axis3 are normalized during this operation\r\n * @param axis1 defines the first axis\r\n * @param axis2 defines the second axis\r\n * @param axis3 defines the third axis\r\n * @returns a new Vector3\r\n */\r\n Vector3.RotationFromAxis = function (axis1, axis2, axis3) {\r\n var rotation = Vector3.Zero();\r\n Vector3.RotationFromAxisToRef(axis1, axis2, axis3, rotation);\r\n return rotation;\r\n };\r\n /**\r\n * The same than RotationFromAxis but updates the given ref Vector3 parameter instead of returning a new Vector3\r\n * @param axis1 defines the first axis\r\n * @param axis2 defines the second axis\r\n * @param axis3 defines the third axis\r\n * @param ref defines the Vector3 where to store the result\r\n */\r\n Vector3.RotationFromAxisToRef = function (axis1, axis2, axis3, ref) {\r\n var quat = MathTmp.Quaternion[0];\r\n Quaternion.RotationQuaternionFromAxisToRef(axis1, axis2, axis3, quat);\r\n quat.toEulerAnglesToRef(ref);\r\n };\r\n Vector3._UpReadOnly = Vector3.Up();\r\n Vector3._ZeroReadOnly = Vector3.Zero();\r\n return Vector3;\r\n}());\r\nexport { Vector3 };\r\n/**\r\n * Vector4 class created for EulerAngle class conversion to Quaternion\r\n */\r\nvar Vector4 = /** @class */ (function () {\r\n /**\r\n * Creates a Vector4 object from the given floats.\r\n * @param x x value of the vector\r\n * @param y y value of the vector\r\n * @param z z value of the vector\r\n * @param w w value of the vector\r\n */\r\n function Vector4(\r\n /** x value of the vector */\r\n x, \r\n /** y value of the vector */\r\n y, \r\n /** z value of the vector */\r\n z, \r\n /** w value of the vector */\r\n w) {\r\n this.x = x;\r\n this.y = y;\r\n this.z = z;\r\n this.w = w;\r\n }\r\n /**\r\n * Returns the string with the Vector4 coordinates.\r\n * @returns a string containing all the vector values\r\n */\r\n Vector4.prototype.toString = function () {\r\n return \"{X: \" + this.x + \" Y:\" + this.y + \" Z:\" + this.z + \" W:\" + this.w + \"}\";\r\n };\r\n /**\r\n * Returns the string \"Vector4\".\r\n * @returns \"Vector4\"\r\n */\r\n Vector4.prototype.getClassName = function () {\r\n return \"Vector4\";\r\n };\r\n /**\r\n * Returns the Vector4 hash code.\r\n * @returns a unique hash code\r\n */\r\n Vector4.prototype.getHashCode = function () {\r\n var hash = this.x | 0;\r\n hash = (hash * 397) ^ (this.y | 0);\r\n hash = (hash * 397) ^ (this.z | 0);\r\n hash = (hash * 397) ^ (this.w | 0);\r\n return hash;\r\n };\r\n // Operators\r\n /**\r\n * Returns a new array populated with 4 elements : the Vector4 coordinates.\r\n * @returns the resulting array\r\n */\r\n Vector4.prototype.asArray = function () {\r\n var result = new Array();\r\n this.toArray(result, 0);\r\n return result;\r\n };\r\n /**\r\n * Populates the given array from the given index with the Vector4 coordinates.\r\n * @param array array to populate\r\n * @param index index of the array to start at (default: 0)\r\n * @returns the Vector4.\r\n */\r\n Vector4.prototype.toArray = function (array, index) {\r\n if (index === undefined) {\r\n index = 0;\r\n }\r\n array[index] = this.x;\r\n array[index + 1] = this.y;\r\n array[index + 2] = this.z;\r\n array[index + 3] = this.w;\r\n return this;\r\n };\r\n /**\r\n * Adds the given vector to the current Vector4.\r\n * @param otherVector the vector to add\r\n * @returns the updated Vector4.\r\n */\r\n Vector4.prototype.addInPlace = function (otherVector) {\r\n this.x += otherVector.x;\r\n this.y += otherVector.y;\r\n this.z += otherVector.z;\r\n this.w += otherVector.w;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector4 as the result of the addition of the current Vector4 and the given one.\r\n * @param otherVector the vector to add\r\n * @returns the resulting vector\r\n */\r\n Vector4.prototype.add = function (otherVector) {\r\n return new Vector4(this.x + otherVector.x, this.y + otherVector.y, this.z + otherVector.z, this.w + otherVector.w);\r\n };\r\n /**\r\n * Updates the given vector \"result\" with the result of the addition of the current Vector4 and the given one.\r\n * @param otherVector the vector to add\r\n * @param result the vector to store the result\r\n * @returns the current Vector4.\r\n */\r\n Vector4.prototype.addToRef = function (otherVector, result) {\r\n result.x = this.x + otherVector.x;\r\n result.y = this.y + otherVector.y;\r\n result.z = this.z + otherVector.z;\r\n result.w = this.w + otherVector.w;\r\n return this;\r\n };\r\n /**\r\n * Subtract in place the given vector from the current Vector4.\r\n * @param otherVector the vector to subtract\r\n * @returns the updated Vector4.\r\n */\r\n Vector4.prototype.subtractInPlace = function (otherVector) {\r\n this.x -= otherVector.x;\r\n this.y -= otherVector.y;\r\n this.z -= otherVector.z;\r\n this.w -= otherVector.w;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector4 with the result of the subtraction of the given vector from the current Vector4.\r\n * @param otherVector the vector to add\r\n * @returns the new vector with the result\r\n */\r\n Vector4.prototype.subtract = function (otherVector) {\r\n return new Vector4(this.x - otherVector.x, this.y - otherVector.y, this.z - otherVector.z, this.w - otherVector.w);\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the result of the subtraction of the given vector from the current Vector4.\r\n * @param otherVector the vector to subtract\r\n * @param result the vector to store the result\r\n * @returns the current Vector4.\r\n */\r\n Vector4.prototype.subtractToRef = function (otherVector, result) {\r\n result.x = this.x - otherVector.x;\r\n result.y = this.y - otherVector.y;\r\n result.z = this.z - otherVector.z;\r\n result.w = this.w - otherVector.w;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector4 set with the result of the subtraction of the given floats from the current Vector4 coordinates.\r\n */\r\n /**\r\n * Returns a new Vector4 set with the result of the subtraction of the given floats from the current Vector4 coordinates.\r\n * @param x value to subtract\r\n * @param y value to subtract\r\n * @param z value to subtract\r\n * @param w value to subtract\r\n * @returns new vector containing the result\r\n */\r\n Vector4.prototype.subtractFromFloats = function (x, y, z, w) {\r\n return new Vector4(this.x - x, this.y - y, this.z - z, this.w - w);\r\n };\r\n /**\r\n * Sets the given vector \"result\" set with the result of the subtraction of the given floats from the current Vector4 coordinates.\r\n * @param x value to subtract\r\n * @param y value to subtract\r\n * @param z value to subtract\r\n * @param w value to subtract\r\n * @param result the vector to store the result in\r\n * @returns the current Vector4.\r\n */\r\n Vector4.prototype.subtractFromFloatsToRef = function (x, y, z, w, result) {\r\n result.x = this.x - x;\r\n result.y = this.y - y;\r\n result.z = this.z - z;\r\n result.w = this.w - w;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector4 set with the current Vector4 negated coordinates.\r\n * @returns a new vector with the negated values\r\n */\r\n Vector4.prototype.negate = function () {\r\n return new Vector4(-this.x, -this.y, -this.z, -this.w);\r\n };\r\n /**\r\n * Negate this vector in place\r\n * @returns this\r\n */\r\n Vector4.prototype.negateInPlace = function () {\r\n this.x *= -1;\r\n this.y *= -1;\r\n this.z *= -1;\r\n this.w *= -1;\r\n return this;\r\n };\r\n /**\r\n * Negate the current Vector4 and stores the result in the given vector \"result\" coordinates\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector4\r\n */\r\n Vector4.prototype.negateToRef = function (result) {\r\n return result.copyFromFloats(this.x * -1, this.y * -1, this.z * -1, this.w * -1);\r\n };\r\n /**\r\n * Multiplies the current Vector4 coordinates by scale (float).\r\n * @param scale the number to scale with\r\n * @returns the updated Vector4.\r\n */\r\n Vector4.prototype.scaleInPlace = function (scale) {\r\n this.x *= scale;\r\n this.y *= scale;\r\n this.z *= scale;\r\n this.w *= scale;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector4 set with the current Vector4 coordinates multiplied by scale (float).\r\n * @param scale the number to scale with\r\n * @returns a new vector with the result\r\n */\r\n Vector4.prototype.scale = function (scale) {\r\n return new Vector4(this.x * scale, this.y * scale, this.z * scale, this.w * scale);\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the current Vector4 coordinates multiplied by scale (float).\r\n * @param scale the number to scale with\r\n * @param result a vector to store the result in\r\n * @returns the current Vector4.\r\n */\r\n Vector4.prototype.scaleToRef = function (scale, result) {\r\n result.x = this.x * scale;\r\n result.y = this.y * scale;\r\n result.z = this.z * scale;\r\n result.w = this.w * scale;\r\n return this;\r\n };\r\n /**\r\n * Scale the current Vector4 values by a factor and add the result to a given Vector4\r\n * @param scale defines the scale factor\r\n * @param result defines the Vector4 object where to store the result\r\n * @returns the unmodified current Vector4\r\n */\r\n Vector4.prototype.scaleAndAddToRef = function (scale, result) {\r\n result.x += this.x * scale;\r\n result.y += this.y * scale;\r\n result.z += this.z * scale;\r\n result.w += this.w * scale;\r\n return this;\r\n };\r\n /**\r\n * Boolean : True if the current Vector4 coordinates are stricly equal to the given ones.\r\n * @param otherVector the vector to compare against\r\n * @returns true if they are equal\r\n */\r\n Vector4.prototype.equals = function (otherVector) {\r\n return otherVector && this.x === otherVector.x && this.y === otherVector.y && this.z === otherVector.z && this.w === otherVector.w;\r\n };\r\n /**\r\n * Boolean : True if the current Vector4 coordinates are each beneath the distance \"epsilon\" from the given vector ones.\r\n * @param otherVector vector to compare against\r\n * @param epsilon (Default: very small number)\r\n * @returns true if they are equal\r\n */\r\n Vector4.prototype.equalsWithEpsilon = function (otherVector, epsilon) {\r\n if (epsilon === void 0) { epsilon = Epsilon; }\r\n return otherVector\r\n && Scalar.WithinEpsilon(this.x, otherVector.x, epsilon)\r\n && Scalar.WithinEpsilon(this.y, otherVector.y, epsilon)\r\n && Scalar.WithinEpsilon(this.z, otherVector.z, epsilon)\r\n && Scalar.WithinEpsilon(this.w, otherVector.w, epsilon);\r\n };\r\n /**\r\n * Boolean : True if the given floats are strictly equal to the current Vector4 coordinates.\r\n * @param x x value to compare against\r\n * @param y y value to compare against\r\n * @param z z value to compare against\r\n * @param w w value to compare against\r\n * @returns true if equal\r\n */\r\n Vector4.prototype.equalsToFloats = function (x, y, z, w) {\r\n return this.x === x && this.y === y && this.z === z && this.w === w;\r\n };\r\n /**\r\n * Multiplies in place the current Vector4 by the given one.\r\n * @param otherVector vector to multiple with\r\n * @returns the updated Vector4.\r\n */\r\n Vector4.prototype.multiplyInPlace = function (otherVector) {\r\n this.x *= otherVector.x;\r\n this.y *= otherVector.y;\r\n this.z *= otherVector.z;\r\n this.w *= otherVector.w;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector4 set with the multiplication result of the current Vector4 and the given one.\r\n * @param otherVector vector to multiple with\r\n * @returns resulting new vector\r\n */\r\n Vector4.prototype.multiply = function (otherVector) {\r\n return new Vector4(this.x * otherVector.x, this.y * otherVector.y, this.z * otherVector.z, this.w * otherVector.w);\r\n };\r\n /**\r\n * Updates the given vector \"result\" with the multiplication result of the current Vector4 and the given one.\r\n * @param otherVector vector to multiple with\r\n * @param result vector to store the result\r\n * @returns the current Vector4.\r\n */\r\n Vector4.prototype.multiplyToRef = function (otherVector, result) {\r\n result.x = this.x * otherVector.x;\r\n result.y = this.y * otherVector.y;\r\n result.z = this.z * otherVector.z;\r\n result.w = this.w * otherVector.w;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector4 set with the multiplication result of the given floats and the current Vector4 coordinates.\r\n * @param x x value multiply with\r\n * @param y y value multiply with\r\n * @param z z value multiply with\r\n * @param w w value multiply with\r\n * @returns resulting new vector\r\n */\r\n Vector4.prototype.multiplyByFloats = function (x, y, z, w) {\r\n return new Vector4(this.x * x, this.y * y, this.z * z, this.w * w);\r\n };\r\n /**\r\n * Returns a new Vector4 set with the division result of the current Vector4 by the given one.\r\n * @param otherVector vector to devide with\r\n * @returns resulting new vector\r\n */\r\n Vector4.prototype.divide = function (otherVector) {\r\n return new Vector4(this.x / otherVector.x, this.y / otherVector.y, this.z / otherVector.z, this.w / otherVector.w);\r\n };\r\n /**\r\n * Updates the given vector \"result\" with the division result of the current Vector4 by the given one.\r\n * @param otherVector vector to devide with\r\n * @param result vector to store the result\r\n * @returns the current Vector4.\r\n */\r\n Vector4.prototype.divideToRef = function (otherVector, result) {\r\n result.x = this.x / otherVector.x;\r\n result.y = this.y / otherVector.y;\r\n result.z = this.z / otherVector.z;\r\n result.w = this.w / otherVector.w;\r\n return this;\r\n };\r\n /**\r\n * Divides the current Vector3 coordinates by the given ones.\r\n * @param otherVector vector to devide with\r\n * @returns the updated Vector3.\r\n */\r\n Vector4.prototype.divideInPlace = function (otherVector) {\r\n return this.divideToRef(otherVector, this);\r\n };\r\n /**\r\n * Updates the Vector4 coordinates with the minimum values between its own and the given vector ones\r\n * @param other defines the second operand\r\n * @returns the current updated Vector4\r\n */\r\n Vector4.prototype.minimizeInPlace = function (other) {\r\n if (other.x < this.x) {\r\n this.x = other.x;\r\n }\r\n if (other.y < this.y) {\r\n this.y = other.y;\r\n }\r\n if (other.z < this.z) {\r\n this.z = other.z;\r\n }\r\n if (other.w < this.w) {\r\n this.w = other.w;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Updates the Vector4 coordinates with the maximum values between its own and the given vector ones\r\n * @param other defines the second operand\r\n * @returns the current updated Vector4\r\n */\r\n Vector4.prototype.maximizeInPlace = function (other) {\r\n if (other.x > this.x) {\r\n this.x = other.x;\r\n }\r\n if (other.y > this.y) {\r\n this.y = other.y;\r\n }\r\n if (other.z > this.z) {\r\n this.z = other.z;\r\n }\r\n if (other.w > this.w) {\r\n this.w = other.w;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Gets a new Vector4 from current Vector4 floored values\r\n * @returns a new Vector4\r\n */\r\n Vector4.prototype.floor = function () {\r\n return new Vector4(Math.floor(this.x), Math.floor(this.y), Math.floor(this.z), Math.floor(this.w));\r\n };\r\n /**\r\n * Gets a new Vector4 from current Vector3 floored values\r\n * @returns a new Vector4\r\n */\r\n Vector4.prototype.fract = function () {\r\n return new Vector4(this.x - Math.floor(this.x), this.y - Math.floor(this.y), this.z - Math.floor(this.z), this.w - Math.floor(this.w));\r\n };\r\n // Properties\r\n /**\r\n * Returns the Vector4 length (float).\r\n * @returns the length\r\n */\r\n Vector4.prototype.length = function () {\r\n return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w);\r\n };\r\n /**\r\n * Returns the Vector4 squared length (float).\r\n * @returns the length squared\r\n */\r\n Vector4.prototype.lengthSquared = function () {\r\n return (this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w);\r\n };\r\n // Methods\r\n /**\r\n * Normalizes in place the Vector4.\r\n * @returns the updated Vector4.\r\n */\r\n Vector4.prototype.normalize = function () {\r\n var len = this.length();\r\n if (len === 0) {\r\n return this;\r\n }\r\n return this.scaleInPlace(1.0 / len);\r\n };\r\n /**\r\n * Returns a new Vector3 from the Vector4 (x, y, z) coordinates.\r\n * @returns this converted to a new vector3\r\n */\r\n Vector4.prototype.toVector3 = function () {\r\n return new Vector3(this.x, this.y, this.z);\r\n };\r\n /**\r\n * Returns a new Vector4 copied from the current one.\r\n * @returns the new cloned vector\r\n */\r\n Vector4.prototype.clone = function () {\r\n return new Vector4(this.x, this.y, this.z, this.w);\r\n };\r\n /**\r\n * Updates the current Vector4 with the given one coordinates.\r\n * @param source the source vector to copy from\r\n * @returns the updated Vector4.\r\n */\r\n Vector4.prototype.copyFrom = function (source) {\r\n this.x = source.x;\r\n this.y = source.y;\r\n this.z = source.z;\r\n this.w = source.w;\r\n return this;\r\n };\r\n /**\r\n * Updates the current Vector4 coordinates with the given floats.\r\n * @param x float to copy from\r\n * @param y float to copy from\r\n * @param z float to copy from\r\n * @param w float to copy from\r\n * @returns the updated Vector4.\r\n */\r\n Vector4.prototype.copyFromFloats = function (x, y, z, w) {\r\n this.x = x;\r\n this.y = y;\r\n this.z = z;\r\n this.w = w;\r\n return this;\r\n };\r\n /**\r\n * Updates the current Vector4 coordinates with the given floats.\r\n * @param x float to set from\r\n * @param y float to set from\r\n * @param z float to set from\r\n * @param w float to set from\r\n * @returns the updated Vector4.\r\n */\r\n Vector4.prototype.set = function (x, y, z, w) {\r\n return this.copyFromFloats(x, y, z, w);\r\n };\r\n /**\r\n * Copies the given float to the current Vector3 coordinates\r\n * @param v defines the x, y, z and w coordinates of the operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector4.prototype.setAll = function (v) {\r\n this.x = this.y = this.z = this.w = v;\r\n return this;\r\n };\r\n // Statics\r\n /**\r\n * Returns a new Vector4 set from the starting index of the given array.\r\n * @param array the array to pull values from\r\n * @param offset the offset into the array to start at\r\n * @returns the new vector\r\n */\r\n Vector4.FromArray = function (array, offset) {\r\n if (!offset) {\r\n offset = 0;\r\n }\r\n return new Vector4(array[offset], array[offset + 1], array[offset + 2], array[offset + 3]);\r\n };\r\n /**\r\n * Updates the given vector \"result\" from the starting index of the given array.\r\n * @param array the array to pull values from\r\n * @param offset the offset into the array to start at\r\n * @param result the vector to store the result in\r\n */\r\n Vector4.FromArrayToRef = function (array, offset, result) {\r\n result.x = array[offset];\r\n result.y = array[offset + 1];\r\n result.z = array[offset + 2];\r\n result.w = array[offset + 3];\r\n };\r\n /**\r\n * Updates the given vector \"result\" from the starting index of the given Float32Array.\r\n * @param array the array to pull values from\r\n * @param offset the offset into the array to start at\r\n * @param result the vector to store the result in\r\n */\r\n Vector4.FromFloatArrayToRef = function (array, offset, result) {\r\n Vector4.FromArrayToRef(array, offset, result);\r\n };\r\n /**\r\n * Updates the given vector \"result\" coordinates from the given floats.\r\n * @param x float to set from\r\n * @param y float to set from\r\n * @param z float to set from\r\n * @param w float to set from\r\n * @param result the vector to the floats in\r\n */\r\n Vector4.FromFloatsToRef = function (x, y, z, w, result) {\r\n result.x = x;\r\n result.y = y;\r\n result.z = z;\r\n result.w = w;\r\n };\r\n /**\r\n * Returns a new Vector4 set to (0.0, 0.0, 0.0, 0.0)\r\n * @returns the new vector\r\n */\r\n Vector4.Zero = function () {\r\n return new Vector4(0.0, 0.0, 0.0, 0.0);\r\n };\r\n /**\r\n * Returns a new Vector4 set to (1.0, 1.0, 1.0, 1.0)\r\n * @returns the new vector\r\n */\r\n Vector4.One = function () {\r\n return new Vector4(1.0, 1.0, 1.0, 1.0);\r\n };\r\n /**\r\n * Returns a new normalized Vector4 from the given one.\r\n * @param vector the vector to normalize\r\n * @returns the vector\r\n */\r\n Vector4.Normalize = function (vector) {\r\n var result = Vector4.Zero();\r\n Vector4.NormalizeToRef(vector, result);\r\n return result;\r\n };\r\n /**\r\n * Updates the given vector \"result\" from the normalization of the given one.\r\n * @param vector the vector to normalize\r\n * @param result the vector to store the result in\r\n */\r\n Vector4.NormalizeToRef = function (vector, result) {\r\n result.copyFrom(vector);\r\n result.normalize();\r\n };\r\n /**\r\n * Returns a vector with the minimum values from the left and right vectors\r\n * @param left left vector to minimize\r\n * @param right right vector to minimize\r\n * @returns a new vector with the minimum of the left and right vector values\r\n */\r\n Vector4.Minimize = function (left, right) {\r\n var min = left.clone();\r\n min.minimizeInPlace(right);\r\n return min;\r\n };\r\n /**\r\n * Returns a vector with the maximum values from the left and right vectors\r\n * @param left left vector to maximize\r\n * @param right right vector to maximize\r\n * @returns a new vector with the maximum of the left and right vector values\r\n */\r\n Vector4.Maximize = function (left, right) {\r\n var max = left.clone();\r\n max.maximizeInPlace(right);\r\n return max;\r\n };\r\n /**\r\n * Returns the distance (float) between the vectors \"value1\" and \"value2\".\r\n * @param value1 value to calulate the distance between\r\n * @param value2 value to calulate the distance between\r\n * @return the distance between the two vectors\r\n */\r\n Vector4.Distance = function (value1, value2) {\r\n return Math.sqrt(Vector4.DistanceSquared(value1, value2));\r\n };\r\n /**\r\n * Returns the squared distance (float) between the vectors \"value1\" and \"value2\".\r\n * @param value1 value to calulate the distance between\r\n * @param value2 value to calulate the distance between\r\n * @return the distance between the two vectors squared\r\n */\r\n Vector4.DistanceSquared = function (value1, value2) {\r\n var x = value1.x - value2.x;\r\n var y = value1.y - value2.y;\r\n var z = value1.z - value2.z;\r\n var w = value1.w - value2.w;\r\n return (x * x) + (y * y) + (z * z) + (w * w);\r\n };\r\n /**\r\n * Returns a new Vector4 located at the center between the vectors \"value1\" and \"value2\".\r\n * @param value1 value to calulate the center between\r\n * @param value2 value to calulate the center between\r\n * @return the center between the two vectors\r\n */\r\n Vector4.Center = function (value1, value2) {\r\n var center = value1.add(value2);\r\n center.scaleInPlace(0.5);\r\n return center;\r\n };\r\n /**\r\n * Returns a new Vector4 set with the result of the normal transformation by the given matrix of the given vector.\r\n * This methods computes transformed normalized direction vectors only.\r\n * @param vector the vector to transform\r\n * @param transformation the transformation matrix to apply\r\n * @returns the new vector\r\n */\r\n Vector4.TransformNormal = function (vector, transformation) {\r\n var result = Vector4.Zero();\r\n Vector4.TransformNormalToRef(vector, transformation, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the result of the normal transformation by the given matrix of the given vector.\r\n * This methods computes transformed normalized direction vectors only.\r\n * @param vector the vector to transform\r\n * @param transformation the transformation matrix to apply\r\n * @param result the vector to store the result in\r\n */\r\n Vector4.TransformNormalToRef = function (vector, transformation, result) {\r\n var m = transformation.m;\r\n var x = (vector.x * m[0]) + (vector.y * m[4]) + (vector.z * m[8]);\r\n var y = (vector.x * m[1]) + (vector.y * m[5]) + (vector.z * m[9]);\r\n var z = (vector.x * m[2]) + (vector.y * m[6]) + (vector.z * m[10]);\r\n result.x = x;\r\n result.y = y;\r\n result.z = z;\r\n result.w = vector.w;\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the result of the normal transformation by the given matrix of the given floats (x, y, z, w).\r\n * This methods computes transformed normalized direction vectors only.\r\n * @param x value to transform\r\n * @param y value to transform\r\n * @param z value to transform\r\n * @param w value to transform\r\n * @param transformation the transformation matrix to apply\r\n * @param result the vector to store the results in\r\n */\r\n Vector4.TransformNormalFromFloatsToRef = function (x, y, z, w, transformation, result) {\r\n var m = transformation.m;\r\n result.x = (x * m[0]) + (y * m[4]) + (z * m[8]);\r\n result.y = (x * m[1]) + (y * m[5]) + (z * m[9]);\r\n result.z = (x * m[2]) + (y * m[6]) + (z * m[10]);\r\n result.w = w;\r\n };\r\n /**\r\n * Creates a new Vector4 from a Vector3\r\n * @param source defines the source data\r\n * @param w defines the 4th component (default is 0)\r\n * @returns a new Vector4\r\n */\r\n Vector4.FromVector3 = function (source, w) {\r\n if (w === void 0) { w = 0; }\r\n return new Vector4(source.x, source.y, source.z, w);\r\n };\r\n return Vector4;\r\n}());\r\nexport { Vector4 };\r\n/**\r\n * Class used to store quaternion data\r\n * @see https://en.wikipedia.org/wiki/Quaternion\r\n * @see http://doc.babylonjs.com/features/position,_rotation,_scaling\r\n */\r\nvar Quaternion = /** @class */ (function () {\r\n /**\r\n * Creates a new Quaternion from the given floats\r\n * @param x defines the first component (0 by default)\r\n * @param y defines the second component (0 by default)\r\n * @param z defines the third component (0 by default)\r\n * @param w defines the fourth component (1.0 by default)\r\n */\r\n function Quaternion(\r\n /** defines the first component (0 by default) */\r\n x, \r\n /** defines the second component (0 by default) */\r\n y, \r\n /** defines the third component (0 by default) */\r\n z, \r\n /** defines the fourth component (1.0 by default) */\r\n w) {\r\n if (x === void 0) { x = 0.0; }\r\n if (y === void 0) { y = 0.0; }\r\n if (z === void 0) { z = 0.0; }\r\n if (w === void 0) { w = 1.0; }\r\n this.x = x;\r\n this.y = y;\r\n this.z = z;\r\n this.w = w;\r\n }\r\n /**\r\n * Gets a string representation for the current quaternion\r\n * @returns a string with the Quaternion coordinates\r\n */\r\n Quaternion.prototype.toString = function () {\r\n return \"{X: \" + this.x + \" Y:\" + this.y + \" Z:\" + this.z + \" W:\" + this.w + \"}\";\r\n };\r\n /**\r\n * Gets the class name of the quaternion\r\n * @returns the string \"Quaternion\"\r\n */\r\n Quaternion.prototype.getClassName = function () {\r\n return \"Quaternion\";\r\n };\r\n /**\r\n * Gets a hash code for this quaternion\r\n * @returns the quaternion hash code\r\n */\r\n Quaternion.prototype.getHashCode = function () {\r\n var hash = this.x | 0;\r\n hash = (hash * 397) ^ (this.y | 0);\r\n hash = (hash * 397) ^ (this.z | 0);\r\n hash = (hash * 397) ^ (this.w | 0);\r\n return hash;\r\n };\r\n /**\r\n * Copy the quaternion to an array\r\n * @returns a new array populated with 4 elements from the quaternion coordinates\r\n */\r\n Quaternion.prototype.asArray = function () {\r\n return [this.x, this.y, this.z, this.w];\r\n };\r\n /**\r\n * Check if two quaternions are equals\r\n * @param otherQuaternion defines the second operand\r\n * @return true if the current quaternion and the given one coordinates are strictly equals\r\n */\r\n Quaternion.prototype.equals = function (otherQuaternion) {\r\n return otherQuaternion && this.x === otherQuaternion.x && this.y === otherQuaternion.y && this.z === otherQuaternion.z && this.w === otherQuaternion.w;\r\n };\r\n /**\r\n * Gets a boolean if two quaternions are equals (using an epsilon value)\r\n * @param otherQuaternion defines the other quaternion\r\n * @param epsilon defines the minimal distance to consider equality\r\n * @returns true if the given quaternion coordinates are close to the current ones by a distance of epsilon.\r\n */\r\n Quaternion.prototype.equalsWithEpsilon = function (otherQuaternion, epsilon) {\r\n if (epsilon === void 0) { epsilon = Epsilon; }\r\n return otherQuaternion\r\n && Scalar.WithinEpsilon(this.x, otherQuaternion.x, epsilon)\r\n && Scalar.WithinEpsilon(this.y, otherQuaternion.y, epsilon)\r\n && Scalar.WithinEpsilon(this.z, otherQuaternion.z, epsilon)\r\n && Scalar.WithinEpsilon(this.w, otherQuaternion.w, epsilon);\r\n };\r\n /**\r\n * Clone the current quaternion\r\n * @returns a new quaternion copied from the current one\r\n */\r\n Quaternion.prototype.clone = function () {\r\n return new Quaternion(this.x, this.y, this.z, this.w);\r\n };\r\n /**\r\n * Copy a quaternion to the current one\r\n * @param other defines the other quaternion\r\n * @returns the updated current quaternion\r\n */\r\n Quaternion.prototype.copyFrom = function (other) {\r\n this.x = other.x;\r\n this.y = other.y;\r\n this.z = other.z;\r\n this.w = other.w;\r\n return this;\r\n };\r\n /**\r\n * Updates the current quaternion with the given float coordinates\r\n * @param x defines the x coordinate\r\n * @param y defines the y coordinate\r\n * @param z defines the z coordinate\r\n * @param w defines the w coordinate\r\n * @returns the updated current quaternion\r\n */\r\n Quaternion.prototype.copyFromFloats = function (x, y, z, w) {\r\n this.x = x;\r\n this.y = y;\r\n this.z = z;\r\n this.w = w;\r\n return this;\r\n };\r\n /**\r\n * Updates the current quaternion from the given float coordinates\r\n * @param x defines the x coordinate\r\n * @param y defines the y coordinate\r\n * @param z defines the z coordinate\r\n * @param w defines the w coordinate\r\n * @returns the updated current quaternion\r\n */\r\n Quaternion.prototype.set = function (x, y, z, w) {\r\n return this.copyFromFloats(x, y, z, w);\r\n };\r\n /**\r\n * Adds two quaternions\r\n * @param other defines the second operand\r\n * @returns a new quaternion as the addition result of the given one and the current quaternion\r\n */\r\n Quaternion.prototype.add = function (other) {\r\n return new Quaternion(this.x + other.x, this.y + other.y, this.z + other.z, this.w + other.w);\r\n };\r\n /**\r\n * Add a quaternion to the current one\r\n * @param other defines the quaternion to add\r\n * @returns the current quaternion\r\n */\r\n Quaternion.prototype.addInPlace = function (other) {\r\n this.x += other.x;\r\n this.y += other.y;\r\n this.z += other.z;\r\n this.w += other.w;\r\n return this;\r\n };\r\n /**\r\n * Subtract two quaternions\r\n * @param other defines the second operand\r\n * @returns a new quaternion as the subtraction result of the given one from the current one\r\n */\r\n Quaternion.prototype.subtract = function (other) {\r\n return new Quaternion(this.x - other.x, this.y - other.y, this.z - other.z, this.w - other.w);\r\n };\r\n /**\r\n * Multiplies the current quaternion by a scale factor\r\n * @param value defines the scale factor\r\n * @returns a new quaternion set by multiplying the current quaternion coordinates by the float \"scale\"\r\n */\r\n Quaternion.prototype.scale = function (value) {\r\n return new Quaternion(this.x * value, this.y * value, this.z * value, this.w * value);\r\n };\r\n /**\r\n * Scale the current quaternion values by a factor and stores the result to a given quaternion\r\n * @param scale defines the scale factor\r\n * @param result defines the Quaternion object where to store the result\r\n * @returns the unmodified current quaternion\r\n */\r\n Quaternion.prototype.scaleToRef = function (scale, result) {\r\n result.x = this.x * scale;\r\n result.y = this.y * scale;\r\n result.z = this.z * scale;\r\n result.w = this.w * scale;\r\n return this;\r\n };\r\n /**\r\n * Multiplies in place the current quaternion by a scale factor\r\n * @param value defines the scale factor\r\n * @returns the current modified quaternion\r\n */\r\n Quaternion.prototype.scaleInPlace = function (value) {\r\n this.x *= value;\r\n this.y *= value;\r\n this.z *= value;\r\n this.w *= value;\r\n return this;\r\n };\r\n /**\r\n * Scale the current quaternion values by a factor and add the result to a given quaternion\r\n * @param scale defines the scale factor\r\n * @param result defines the Quaternion object where to store the result\r\n * @returns the unmodified current quaternion\r\n */\r\n Quaternion.prototype.scaleAndAddToRef = function (scale, result) {\r\n result.x += this.x * scale;\r\n result.y += this.y * scale;\r\n result.z += this.z * scale;\r\n result.w += this.w * scale;\r\n return this;\r\n };\r\n /**\r\n * Multiplies two quaternions\r\n * @param q1 defines the second operand\r\n * @returns a new quaternion set as the multiplication result of the current one with the given one \"q1\"\r\n */\r\n Quaternion.prototype.multiply = function (q1) {\r\n var result = new Quaternion(0, 0, 0, 1.0);\r\n this.multiplyToRef(q1, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given \"result\" as the the multiplication result of the current one with the given one \"q1\"\r\n * @param q1 defines the second operand\r\n * @param result defines the target quaternion\r\n * @returns the current quaternion\r\n */\r\n Quaternion.prototype.multiplyToRef = function (q1, result) {\r\n var x = this.x * q1.w + this.y * q1.z - this.z * q1.y + this.w * q1.x;\r\n var y = -this.x * q1.z + this.y * q1.w + this.z * q1.x + this.w * q1.y;\r\n var z = this.x * q1.y - this.y * q1.x + this.z * q1.w + this.w * q1.z;\r\n var w = -this.x * q1.x - this.y * q1.y - this.z * q1.z + this.w * q1.w;\r\n result.copyFromFloats(x, y, z, w);\r\n return this;\r\n };\r\n /**\r\n * Updates the current quaternion with the multiplication of itself with the given one \"q1\"\r\n * @param q1 defines the second operand\r\n * @returns the currentupdated quaternion\r\n */\r\n Quaternion.prototype.multiplyInPlace = function (q1) {\r\n this.multiplyToRef(q1, this);\r\n return this;\r\n };\r\n /**\r\n * Conjugates (1-q) the current quaternion and stores the result in the given quaternion\r\n * @param ref defines the target quaternion\r\n * @returns the current quaternion\r\n */\r\n Quaternion.prototype.conjugateToRef = function (ref) {\r\n ref.copyFromFloats(-this.x, -this.y, -this.z, this.w);\r\n return this;\r\n };\r\n /**\r\n * Conjugates in place (1-q) the current quaternion\r\n * @returns the current updated quaternion\r\n */\r\n Quaternion.prototype.conjugateInPlace = function () {\r\n this.x *= -1;\r\n this.y *= -1;\r\n this.z *= -1;\r\n return this;\r\n };\r\n /**\r\n * Conjugates in place (1-q) the current quaternion\r\n * @returns a new quaternion\r\n */\r\n Quaternion.prototype.conjugate = function () {\r\n var result = new Quaternion(-this.x, -this.y, -this.z, this.w);\r\n return result;\r\n };\r\n /**\r\n * Gets length of current quaternion\r\n * @returns the quaternion length (float)\r\n */\r\n Quaternion.prototype.length = function () {\r\n return Math.sqrt((this.x * this.x) + (this.y * this.y) + (this.z * this.z) + (this.w * this.w));\r\n };\r\n /**\r\n * Normalize in place the current quaternion\r\n * @returns the current updated quaternion\r\n */\r\n Quaternion.prototype.normalize = function () {\r\n var len = this.length();\r\n if (len === 0) {\r\n return this;\r\n }\r\n var inv = 1.0 / len;\r\n this.x *= inv;\r\n this.y *= inv;\r\n this.z *= inv;\r\n this.w *= inv;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector3 set with the Euler angles translated from the current quaternion\r\n * @param order is a reserved parameter and is ignore for now\r\n * @returns a new Vector3 containing the Euler angles\r\n */\r\n Quaternion.prototype.toEulerAngles = function (order) {\r\n if (order === void 0) { order = \"YZX\"; }\r\n var result = Vector3.Zero();\r\n this.toEulerAnglesToRef(result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given vector3 \"result\" with the Euler angles translated from the current quaternion\r\n * @param result defines the vector which will be filled with the Euler angles\r\n * @param order is a reserved parameter and is ignore for now\r\n * @returns the current unchanged quaternion\r\n */\r\n Quaternion.prototype.toEulerAnglesToRef = function (result) {\r\n var qz = this.z;\r\n var qx = this.x;\r\n var qy = this.y;\r\n var qw = this.w;\r\n var sqw = qw * qw;\r\n var sqz = qz * qz;\r\n var sqx = qx * qx;\r\n var sqy = qy * qy;\r\n var zAxisY = qy * qz - qx * qw;\r\n var limit = .4999999;\r\n if (zAxisY < -limit) {\r\n result.y = 2 * Math.atan2(qy, qw);\r\n result.x = Math.PI / 2;\r\n result.z = 0;\r\n }\r\n else if (zAxisY > limit) {\r\n result.y = 2 * Math.atan2(qy, qw);\r\n result.x = -Math.PI / 2;\r\n result.z = 0;\r\n }\r\n else {\r\n result.z = Math.atan2(2.0 * (qx * qy + qz * qw), (-sqz - sqx + sqy + sqw));\r\n result.x = Math.asin(-2.0 * (qz * qy - qx * qw));\r\n result.y = Math.atan2(2.0 * (qz * qx + qy * qw), (sqz - sqx - sqy + sqw));\r\n }\r\n return this;\r\n };\r\n /**\r\n * Updates the given rotation matrix with the current quaternion values\r\n * @param result defines the target matrix\r\n * @returns the current unchanged quaternion\r\n */\r\n Quaternion.prototype.toRotationMatrix = function (result) {\r\n Matrix.FromQuaternionToRef(this, result);\r\n return this;\r\n };\r\n /**\r\n * Updates the current quaternion from the given rotation matrix values\r\n * @param matrix defines the source matrix\r\n * @returns the current updated quaternion\r\n */\r\n Quaternion.prototype.fromRotationMatrix = function (matrix) {\r\n Quaternion.FromRotationMatrixToRef(matrix, this);\r\n return this;\r\n };\r\n // Statics\r\n /**\r\n * Creates a new quaternion from a rotation matrix\r\n * @param matrix defines the source matrix\r\n * @returns a new quaternion created from the given rotation matrix values\r\n */\r\n Quaternion.FromRotationMatrix = function (matrix) {\r\n var result = new Quaternion();\r\n Quaternion.FromRotationMatrixToRef(matrix, result);\r\n return result;\r\n };\r\n /**\r\n * Updates the given quaternion with the given rotation matrix values\r\n * @param matrix defines the source matrix\r\n * @param result defines the target quaternion\r\n */\r\n Quaternion.FromRotationMatrixToRef = function (matrix, result) {\r\n var data = matrix.m;\r\n var m11 = data[0], m12 = data[4], m13 = data[8];\r\n var m21 = data[1], m22 = data[5], m23 = data[9];\r\n var m31 = data[2], m32 = data[6], m33 = data[10];\r\n var trace = m11 + m22 + m33;\r\n var s;\r\n if (trace > 0) {\r\n s = 0.5 / Math.sqrt(trace + 1.0);\r\n result.w = 0.25 / s;\r\n result.x = (m32 - m23) * s;\r\n result.y = (m13 - m31) * s;\r\n result.z = (m21 - m12) * s;\r\n }\r\n else if (m11 > m22 && m11 > m33) {\r\n s = 2.0 * Math.sqrt(1.0 + m11 - m22 - m33);\r\n result.w = (m32 - m23) / s;\r\n result.x = 0.25 * s;\r\n result.y = (m12 + m21) / s;\r\n result.z = (m13 + m31) / s;\r\n }\r\n else if (m22 > m33) {\r\n s = 2.0 * Math.sqrt(1.0 + m22 - m11 - m33);\r\n result.w = (m13 - m31) / s;\r\n result.x = (m12 + m21) / s;\r\n result.y = 0.25 * s;\r\n result.z = (m23 + m32) / s;\r\n }\r\n else {\r\n s = 2.0 * Math.sqrt(1.0 + m33 - m11 - m22);\r\n result.w = (m21 - m12) / s;\r\n result.x = (m13 + m31) / s;\r\n result.y = (m23 + m32) / s;\r\n result.z = 0.25 * s;\r\n }\r\n };\r\n /**\r\n * Returns the dot product (float) between the quaternions \"left\" and \"right\"\r\n * @param left defines the left operand\r\n * @param right defines the right operand\r\n * @returns the dot product\r\n */\r\n Quaternion.Dot = function (left, right) {\r\n return (left.x * right.x + left.y * right.y + left.z * right.z + left.w * right.w);\r\n };\r\n /**\r\n * Checks if the two quaternions are close to each other\r\n * @param quat0 defines the first quaternion to check\r\n * @param quat1 defines the second quaternion to check\r\n * @returns true if the two quaternions are close to each other\r\n */\r\n Quaternion.AreClose = function (quat0, quat1) {\r\n var dot = Quaternion.Dot(quat0, quat1);\r\n return dot >= 0;\r\n };\r\n /**\r\n * Creates an empty quaternion\r\n * @returns a new quaternion set to (0.0, 0.0, 0.0)\r\n */\r\n Quaternion.Zero = function () {\r\n return new Quaternion(0.0, 0.0, 0.0, 0.0);\r\n };\r\n /**\r\n * Inverse a given quaternion\r\n * @param q defines the source quaternion\r\n * @returns a new quaternion as the inverted current quaternion\r\n */\r\n Quaternion.Inverse = function (q) {\r\n return new Quaternion(-q.x, -q.y, -q.z, q.w);\r\n };\r\n /**\r\n * Inverse a given quaternion\r\n * @param q defines the source quaternion\r\n * @param result the quaternion the result will be stored in\r\n * @returns the result quaternion\r\n */\r\n Quaternion.InverseToRef = function (q, result) {\r\n result.set(-q.x, -q.y, -q.z, q.w);\r\n return result;\r\n };\r\n /**\r\n * Creates an identity quaternion\r\n * @returns the identity quaternion\r\n */\r\n Quaternion.Identity = function () {\r\n return new Quaternion(0.0, 0.0, 0.0, 1.0);\r\n };\r\n /**\r\n * Gets a boolean indicating if the given quaternion is identity\r\n * @param quaternion defines the quaternion to check\r\n * @returns true if the quaternion is identity\r\n */\r\n Quaternion.IsIdentity = function (quaternion) {\r\n return quaternion && quaternion.x === 0 && quaternion.y === 0 && quaternion.z === 0 && quaternion.w === 1;\r\n };\r\n /**\r\n * Creates a quaternion from a rotation around an axis\r\n * @param axis defines the axis to use\r\n * @param angle defines the angle to use\r\n * @returns a new quaternion created from the given axis (Vector3) and angle in radians (float)\r\n */\r\n Quaternion.RotationAxis = function (axis, angle) {\r\n return Quaternion.RotationAxisToRef(axis, angle, new Quaternion());\r\n };\r\n /**\r\n * Creates a rotation around an axis and stores it into the given quaternion\r\n * @param axis defines the axis to use\r\n * @param angle defines the angle to use\r\n * @param result defines the target quaternion\r\n * @returns the target quaternion\r\n */\r\n Quaternion.RotationAxisToRef = function (axis, angle, result) {\r\n var sin = Math.sin(angle / 2);\r\n axis.normalize();\r\n result.w = Math.cos(angle / 2);\r\n result.x = axis.x * sin;\r\n result.y = axis.y * sin;\r\n result.z = axis.z * sin;\r\n return result;\r\n };\r\n /**\r\n * Creates a new quaternion from data stored into an array\r\n * @param array defines the data source\r\n * @param offset defines the offset in the source array where the data starts\r\n * @returns a new quaternion\r\n */\r\n Quaternion.FromArray = function (array, offset) {\r\n if (!offset) {\r\n offset = 0;\r\n }\r\n return new Quaternion(array[offset], array[offset + 1], array[offset + 2], array[offset + 3]);\r\n };\r\n /**\r\n * Create a quaternion from Euler rotation angles\r\n * @param x Pitch\r\n * @param y Yaw\r\n * @param z Roll\r\n * @returns the new Quaternion\r\n */\r\n Quaternion.FromEulerAngles = function (x, y, z) {\r\n var q = new Quaternion();\r\n Quaternion.RotationYawPitchRollToRef(y, x, z, q);\r\n return q;\r\n };\r\n /**\r\n * Updates a quaternion from Euler rotation angles\r\n * @param x Pitch\r\n * @param y Yaw\r\n * @param z Roll\r\n * @param result the quaternion to store the result\r\n * @returns the updated quaternion\r\n */\r\n Quaternion.FromEulerAnglesToRef = function (x, y, z, result) {\r\n Quaternion.RotationYawPitchRollToRef(y, x, z, result);\r\n return result;\r\n };\r\n /**\r\n * Create a quaternion from Euler rotation vector\r\n * @param vec the Euler vector (x Pitch, y Yaw, z Roll)\r\n * @returns the new Quaternion\r\n */\r\n Quaternion.FromEulerVector = function (vec) {\r\n var q = new Quaternion();\r\n Quaternion.RotationYawPitchRollToRef(vec.y, vec.x, vec.z, q);\r\n return q;\r\n };\r\n /**\r\n * Updates a quaternion from Euler rotation vector\r\n * @param vec the Euler vector (x Pitch, y Yaw, z Roll)\r\n * @param result the quaternion to store the result\r\n * @returns the updated quaternion\r\n */\r\n Quaternion.FromEulerVectorToRef = function (vec, result) {\r\n Quaternion.RotationYawPitchRollToRef(vec.y, vec.x, vec.z, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a new quaternion from the given Euler float angles (y, x, z)\r\n * @param yaw defines the rotation around Y axis\r\n * @param pitch defines the rotation around X axis\r\n * @param roll defines the rotation around Z axis\r\n * @returns the new quaternion\r\n */\r\n Quaternion.RotationYawPitchRoll = function (yaw, pitch, roll) {\r\n var q = new Quaternion();\r\n Quaternion.RotationYawPitchRollToRef(yaw, pitch, roll, q);\r\n return q;\r\n };\r\n /**\r\n * Creates a new rotation from the given Euler float angles (y, x, z) and stores it in the target quaternion\r\n * @param yaw defines the rotation around Y axis\r\n * @param pitch defines the rotation around X axis\r\n * @param roll defines the rotation around Z axis\r\n * @param result defines the target quaternion\r\n */\r\n Quaternion.RotationYawPitchRollToRef = function (yaw, pitch, roll, result) {\r\n // Produces a quaternion from Euler angles in the z-y-x orientation (Tait-Bryan angles)\r\n var halfRoll = roll * 0.5;\r\n var halfPitch = pitch * 0.5;\r\n var halfYaw = yaw * 0.5;\r\n var sinRoll = Math.sin(halfRoll);\r\n var cosRoll = Math.cos(halfRoll);\r\n var sinPitch = Math.sin(halfPitch);\r\n var cosPitch = Math.cos(halfPitch);\r\n var sinYaw = Math.sin(halfYaw);\r\n var cosYaw = Math.cos(halfYaw);\r\n result.x = (cosYaw * sinPitch * cosRoll) + (sinYaw * cosPitch * sinRoll);\r\n result.y = (sinYaw * cosPitch * cosRoll) - (cosYaw * sinPitch * sinRoll);\r\n result.z = (cosYaw * cosPitch * sinRoll) - (sinYaw * sinPitch * cosRoll);\r\n result.w = (cosYaw * cosPitch * cosRoll) + (sinYaw * sinPitch * sinRoll);\r\n };\r\n /**\r\n * Creates a new quaternion from the given Euler float angles expressed in z-x-z orientation\r\n * @param alpha defines the rotation around first axis\r\n * @param beta defines the rotation around second axis\r\n * @param gamma defines the rotation around third axis\r\n * @returns the new quaternion\r\n */\r\n Quaternion.RotationAlphaBetaGamma = function (alpha, beta, gamma) {\r\n var result = new Quaternion();\r\n Quaternion.RotationAlphaBetaGammaToRef(alpha, beta, gamma, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a new quaternion from the given Euler float angles expressed in z-x-z orientation and stores it in the target quaternion\r\n * @param alpha defines the rotation around first axis\r\n * @param beta defines the rotation around second axis\r\n * @param gamma defines the rotation around third axis\r\n * @param result defines the target quaternion\r\n */\r\n Quaternion.RotationAlphaBetaGammaToRef = function (alpha, beta, gamma, result) {\r\n // Produces a quaternion from Euler angles in the z-x-z orientation\r\n var halfGammaPlusAlpha = (gamma + alpha) * 0.5;\r\n var halfGammaMinusAlpha = (gamma - alpha) * 0.5;\r\n var halfBeta = beta * 0.5;\r\n result.x = Math.cos(halfGammaMinusAlpha) * Math.sin(halfBeta);\r\n result.y = Math.sin(halfGammaMinusAlpha) * Math.sin(halfBeta);\r\n result.z = Math.sin(halfGammaPlusAlpha) * Math.cos(halfBeta);\r\n result.w = Math.cos(halfGammaPlusAlpha) * Math.cos(halfBeta);\r\n };\r\n /**\r\n * Creates a new quaternion containing the rotation value to reach the target (axis1, axis2, axis3) orientation as a rotated XYZ system (axis1, axis2 and axis3 are normalized during this operation)\r\n * @param axis1 defines the first axis\r\n * @param axis2 defines the second axis\r\n * @param axis3 defines the third axis\r\n * @returns the new quaternion\r\n */\r\n Quaternion.RotationQuaternionFromAxis = function (axis1, axis2, axis3) {\r\n var quat = new Quaternion(0.0, 0.0, 0.0, 0.0);\r\n Quaternion.RotationQuaternionFromAxisToRef(axis1, axis2, axis3, quat);\r\n return quat;\r\n };\r\n /**\r\n * Creates a rotation value to reach the target (axis1, axis2, axis3) orientation as a rotated XYZ system (axis1, axis2 and axis3 are normalized during this operation) and stores it in the target quaternion\r\n * @param axis1 defines the first axis\r\n * @param axis2 defines the second axis\r\n * @param axis3 defines the third axis\r\n * @param ref defines the target quaternion\r\n */\r\n Quaternion.RotationQuaternionFromAxisToRef = function (axis1, axis2, axis3, ref) {\r\n var rotMat = MathTmp.Matrix[0];\r\n Matrix.FromXYZAxesToRef(axis1.normalize(), axis2.normalize(), axis3.normalize(), rotMat);\r\n Quaternion.FromRotationMatrixToRef(rotMat, ref);\r\n };\r\n /**\r\n * Interpolates between two quaternions\r\n * @param left defines first quaternion\r\n * @param right defines second quaternion\r\n * @param amount defines the gradient to use\r\n * @returns the new interpolated quaternion\r\n */\r\n Quaternion.Slerp = function (left, right, amount) {\r\n var result = Quaternion.Identity();\r\n Quaternion.SlerpToRef(left, right, amount, result);\r\n return result;\r\n };\r\n /**\r\n * Interpolates between two quaternions and stores it into a target quaternion\r\n * @param left defines first quaternion\r\n * @param right defines second quaternion\r\n * @param amount defines the gradient to use\r\n * @param result defines the target quaternion\r\n */\r\n Quaternion.SlerpToRef = function (left, right, amount, result) {\r\n var num2;\r\n var num3;\r\n var num4 = (((left.x * right.x) + (left.y * right.y)) + (left.z * right.z)) + (left.w * right.w);\r\n var flag = false;\r\n if (num4 < 0) {\r\n flag = true;\r\n num4 = -num4;\r\n }\r\n if (num4 > 0.999999) {\r\n num3 = 1 - amount;\r\n num2 = flag ? -amount : amount;\r\n }\r\n else {\r\n var num5 = Math.acos(num4);\r\n var num6 = (1.0 / Math.sin(num5));\r\n num3 = (Math.sin((1.0 - amount) * num5)) * num6;\r\n num2 = flag ? ((-Math.sin(amount * num5)) * num6) : ((Math.sin(amount * num5)) * num6);\r\n }\r\n result.x = (num3 * left.x) + (num2 * right.x);\r\n result.y = (num3 * left.y) + (num2 * right.y);\r\n result.z = (num3 * left.z) + (num2 * right.z);\r\n result.w = (num3 * left.w) + (num2 * right.w);\r\n };\r\n /**\r\n * Interpolate between two quaternions using Hermite interpolation\r\n * @param value1 defines first quaternion\r\n * @param tangent1 defines the incoming tangent\r\n * @param value2 defines second quaternion\r\n * @param tangent2 defines the outgoing tangent\r\n * @param amount defines the target quaternion\r\n * @returns the new interpolated quaternion\r\n */\r\n Quaternion.Hermite = function (value1, tangent1, value2, tangent2, amount) {\r\n var squared = amount * amount;\r\n var cubed = amount * squared;\r\n var part1 = ((2.0 * cubed) - (3.0 * squared)) + 1.0;\r\n var part2 = (-2.0 * cubed) + (3.0 * squared);\r\n var part3 = (cubed - (2.0 * squared)) + amount;\r\n var part4 = cubed - squared;\r\n var x = (((value1.x * part1) + (value2.x * part2)) + (tangent1.x * part3)) + (tangent2.x * part4);\r\n var y = (((value1.y * part1) + (value2.y * part2)) + (tangent1.y * part3)) + (tangent2.y * part4);\r\n var z = (((value1.z * part1) + (value2.z * part2)) + (tangent1.z * part3)) + (tangent2.z * part4);\r\n var w = (((value1.w * part1) + (value2.w * part2)) + (tangent1.w * part3)) + (tangent2.w * part4);\r\n return new Quaternion(x, y, z, w);\r\n };\r\n return Quaternion;\r\n}());\r\nexport { Quaternion };\r\n/**\r\n * Class used to store matrix data (4x4)\r\n */\r\nvar Matrix = /** @class */ (function () {\r\n /**\r\n * Creates an empty matrix (filled with zeros)\r\n */\r\n function Matrix() {\r\n this._isIdentity = false;\r\n this._isIdentityDirty = true;\r\n this._isIdentity3x2 = true;\r\n this._isIdentity3x2Dirty = true;\r\n /**\r\n * Gets the update flag of the matrix which is an unique number for the matrix.\r\n * It will be incremented every time the matrix data change.\r\n * You can use it to speed the comparison between two versions of the same matrix.\r\n */\r\n this.updateFlag = -1;\r\n this._m = new Float32Array(16);\r\n this._updateIdentityStatus(false);\r\n }\r\n Object.defineProperty(Matrix.prototype, \"m\", {\r\n /**\r\n * Gets the internal data of the matrix\r\n */\r\n get: function () { return this._m; },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n Matrix.prototype._markAsUpdated = function () {\r\n this.updateFlag = Matrix._updateFlagSeed++;\r\n this._isIdentity = false;\r\n this._isIdentity3x2 = false;\r\n this._isIdentityDirty = true;\r\n this._isIdentity3x2Dirty = true;\r\n };\r\n /** @hidden */\r\n Matrix.prototype._updateIdentityStatus = function (isIdentity, isIdentityDirty, isIdentity3x2, isIdentity3x2Dirty) {\r\n if (isIdentityDirty === void 0) { isIdentityDirty = false; }\r\n if (isIdentity3x2 === void 0) { isIdentity3x2 = false; }\r\n if (isIdentity3x2Dirty === void 0) { isIdentity3x2Dirty = true; }\r\n this.updateFlag = Matrix._updateFlagSeed++;\r\n this._isIdentity = isIdentity;\r\n this._isIdentity3x2 = isIdentity || isIdentity3x2;\r\n this._isIdentityDirty = this._isIdentity ? false : isIdentityDirty;\r\n this._isIdentity3x2Dirty = this._isIdentity3x2 ? false : isIdentity3x2Dirty;\r\n };\r\n // Properties\r\n /**\r\n * Check if the current matrix is identity\r\n * @returns true is the matrix is the identity matrix\r\n */\r\n Matrix.prototype.isIdentity = function () {\r\n if (this._isIdentityDirty) {\r\n this._isIdentityDirty = false;\r\n var m = this._m;\r\n this._isIdentity = (m[0] === 1.0 && m[1] === 0.0 && m[2] === 0.0 && m[3] === 0.0 &&\r\n m[4] === 0.0 && m[5] === 1.0 && m[6] === 0.0 && m[7] === 0.0 &&\r\n m[8] === 0.0 && m[9] === 0.0 && m[10] === 1.0 && m[11] === 0.0 &&\r\n m[12] === 0.0 && m[13] === 0.0 && m[14] === 0.0 && m[15] === 1.0);\r\n }\r\n return this._isIdentity;\r\n };\r\n /**\r\n * Check if the current matrix is identity as a texture matrix (3x2 store in 4x4)\r\n * @returns true is the matrix is the identity matrix\r\n */\r\n Matrix.prototype.isIdentityAs3x2 = function () {\r\n if (this._isIdentity3x2Dirty) {\r\n this._isIdentity3x2Dirty = false;\r\n if (this._m[0] !== 1.0 || this._m[5] !== 1.0 || this._m[15] !== 1.0) {\r\n this._isIdentity3x2 = false;\r\n }\r\n else if (this._m[1] !== 0.0 || this._m[2] !== 0.0 || this._m[3] !== 0.0 ||\r\n this._m[4] !== 0.0 || this._m[6] !== 0.0 || this._m[7] !== 0.0 ||\r\n this._m[8] !== 0.0 || this._m[9] !== 0.0 || this._m[10] !== 0.0 || this._m[11] !== 0.0 ||\r\n this._m[12] !== 0.0 || this._m[13] !== 0.0 || this._m[14] !== 0.0) {\r\n this._isIdentity3x2 = false;\r\n }\r\n else {\r\n this._isIdentity3x2 = true;\r\n }\r\n }\r\n return this._isIdentity3x2;\r\n };\r\n /**\r\n * Gets the determinant of the matrix\r\n * @returns the matrix determinant\r\n */\r\n Matrix.prototype.determinant = function () {\r\n if (this._isIdentity === true) {\r\n return 1;\r\n }\r\n var m = this._m;\r\n var m00 = m[0], m01 = m[1], m02 = m[2], m03 = m[3];\r\n var m10 = m[4], m11 = m[5], m12 = m[6], m13 = m[7];\r\n var m20 = m[8], m21 = m[9], m22 = m[10], m23 = m[11];\r\n var m30 = m[12], m31 = m[13], m32 = m[14], m33 = m[15];\r\n // https://en.wikipedia.org/wiki/Laplace_expansion\r\n // to compute the deterrminant of a 4x4 Matrix we compute the cofactors of any row or column,\r\n // then we multiply each Cofactor by its corresponding matrix value and sum them all to get the determinant\r\n // Cofactor(i, j) = sign(i,j) * det(Minor(i, j))\r\n // where\r\n // - sign(i,j) = (i+j) % 2 === 0 ? 1 : -1\r\n // - Minor(i, j) is the 3x3 matrix we get by removing row i and column j from current Matrix\r\n //\r\n // Here we do that for the 1st row.\r\n var det_22_33 = m22 * m33 - m32 * m23;\r\n var det_21_33 = m21 * m33 - m31 * m23;\r\n var det_21_32 = m21 * m32 - m31 * m22;\r\n var det_20_33 = m20 * m33 - m30 * m23;\r\n var det_20_32 = m20 * m32 - m22 * m30;\r\n var det_20_31 = m20 * m31 - m30 * m21;\r\n var cofact_00 = +(m11 * det_22_33 - m12 * det_21_33 + m13 * det_21_32);\r\n var cofact_01 = -(m10 * det_22_33 - m12 * det_20_33 + m13 * det_20_32);\r\n var cofact_02 = +(m10 * det_21_33 - m11 * det_20_33 + m13 * det_20_31);\r\n var cofact_03 = -(m10 * det_21_32 - m11 * det_20_32 + m12 * det_20_31);\r\n return m00 * cofact_00 + m01 * cofact_01 + m02 * cofact_02 + m03 * cofact_03;\r\n };\r\n // Methods\r\n /**\r\n * Returns the matrix as a Float32Array\r\n * @returns the matrix underlying array\r\n */\r\n Matrix.prototype.toArray = function () {\r\n return this._m;\r\n };\r\n /**\r\n * Returns the matrix as a Float32Array\r\n * @returns the matrix underlying array.\r\n */\r\n Matrix.prototype.asArray = function () {\r\n return this._m;\r\n };\r\n /**\r\n * Inverts the current matrix in place\r\n * @returns the current inverted matrix\r\n */\r\n Matrix.prototype.invert = function () {\r\n this.invertToRef(this);\r\n return this;\r\n };\r\n /**\r\n * Sets all the matrix elements to zero\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.reset = function () {\r\n Matrix.FromValuesToRef(0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, this);\r\n this._updateIdentityStatus(false);\r\n return this;\r\n };\r\n /**\r\n * Adds the current matrix with a second one\r\n * @param other defines the matrix to add\r\n * @returns a new matrix as the addition of the current matrix and the given one\r\n */\r\n Matrix.prototype.add = function (other) {\r\n var result = new Matrix();\r\n this.addToRef(other, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given matrix \"result\" to the addition of the current matrix and the given one\r\n * @param other defines the matrix to add\r\n * @param result defines the target matrix\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.addToRef = function (other, result) {\r\n var m = this._m;\r\n var resultM = result._m;\r\n var otherM = other.m;\r\n for (var index = 0; index < 16; index++) {\r\n resultM[index] = m[index] + otherM[index];\r\n }\r\n result._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Adds in place the given matrix to the current matrix\r\n * @param other defines the second operand\r\n * @returns the current updated matrix\r\n */\r\n Matrix.prototype.addToSelf = function (other) {\r\n var m = this._m;\r\n var otherM = other.m;\r\n for (var index = 0; index < 16; index++) {\r\n m[index] += otherM[index];\r\n }\r\n this._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Sets the given matrix to the current inverted Matrix\r\n * @param other defines the target matrix\r\n * @returns the unmodified current matrix\r\n */\r\n Matrix.prototype.invertToRef = function (other) {\r\n if (this._isIdentity === true) {\r\n Matrix.IdentityToRef(other);\r\n return this;\r\n }\r\n // the inverse of a Matrix is the transpose of cofactor matrix divided by the determinant\r\n var m = this._m;\r\n var m00 = m[0], m01 = m[1], m02 = m[2], m03 = m[3];\r\n var m10 = m[4], m11 = m[5], m12 = m[6], m13 = m[7];\r\n var m20 = m[8], m21 = m[9], m22 = m[10], m23 = m[11];\r\n var m30 = m[12], m31 = m[13], m32 = m[14], m33 = m[15];\r\n var det_22_33 = m22 * m33 - m32 * m23;\r\n var det_21_33 = m21 * m33 - m31 * m23;\r\n var det_21_32 = m21 * m32 - m31 * m22;\r\n var det_20_33 = m20 * m33 - m30 * m23;\r\n var det_20_32 = m20 * m32 - m22 * m30;\r\n var det_20_31 = m20 * m31 - m30 * m21;\r\n var cofact_00 = +(m11 * det_22_33 - m12 * det_21_33 + m13 * det_21_32);\r\n var cofact_01 = -(m10 * det_22_33 - m12 * det_20_33 + m13 * det_20_32);\r\n var cofact_02 = +(m10 * det_21_33 - m11 * det_20_33 + m13 * det_20_31);\r\n var cofact_03 = -(m10 * det_21_32 - m11 * det_20_32 + m12 * det_20_31);\r\n var det = m00 * cofact_00 + m01 * cofact_01 + m02 * cofact_02 + m03 * cofact_03;\r\n if (det === 0) {\r\n // not invertible\r\n other.copyFrom(this);\r\n return this;\r\n }\r\n var detInv = 1 / det;\r\n var det_12_33 = m12 * m33 - m32 * m13;\r\n var det_11_33 = m11 * m33 - m31 * m13;\r\n var det_11_32 = m11 * m32 - m31 * m12;\r\n var det_10_33 = m10 * m33 - m30 * m13;\r\n var det_10_32 = m10 * m32 - m30 * m12;\r\n var det_10_31 = m10 * m31 - m30 * m11;\r\n var det_12_23 = m12 * m23 - m22 * m13;\r\n var det_11_23 = m11 * m23 - m21 * m13;\r\n var det_11_22 = m11 * m22 - m21 * m12;\r\n var det_10_23 = m10 * m23 - m20 * m13;\r\n var det_10_22 = m10 * m22 - m20 * m12;\r\n var det_10_21 = m10 * m21 - m20 * m11;\r\n var cofact_10 = -(m01 * det_22_33 - m02 * det_21_33 + m03 * det_21_32);\r\n var cofact_11 = +(m00 * det_22_33 - m02 * det_20_33 + m03 * det_20_32);\r\n var cofact_12 = -(m00 * det_21_33 - m01 * det_20_33 + m03 * det_20_31);\r\n var cofact_13 = +(m00 * det_21_32 - m01 * det_20_32 + m02 * det_20_31);\r\n var cofact_20 = +(m01 * det_12_33 - m02 * det_11_33 + m03 * det_11_32);\r\n var cofact_21 = -(m00 * det_12_33 - m02 * det_10_33 + m03 * det_10_32);\r\n var cofact_22 = +(m00 * det_11_33 - m01 * det_10_33 + m03 * det_10_31);\r\n var cofact_23 = -(m00 * det_11_32 - m01 * det_10_32 + m02 * det_10_31);\r\n var cofact_30 = -(m01 * det_12_23 - m02 * det_11_23 + m03 * det_11_22);\r\n var cofact_31 = +(m00 * det_12_23 - m02 * det_10_23 + m03 * det_10_22);\r\n var cofact_32 = -(m00 * det_11_23 - m01 * det_10_23 + m03 * det_10_21);\r\n var cofact_33 = +(m00 * det_11_22 - m01 * det_10_22 + m02 * det_10_21);\r\n Matrix.FromValuesToRef(cofact_00 * detInv, cofact_10 * detInv, cofact_20 * detInv, cofact_30 * detInv, cofact_01 * detInv, cofact_11 * detInv, cofact_21 * detInv, cofact_31 * detInv, cofact_02 * detInv, cofact_12 * detInv, cofact_22 * detInv, cofact_32 * detInv, cofact_03 * detInv, cofact_13 * detInv, cofact_23 * detInv, cofact_33 * detInv, other);\r\n return this;\r\n };\r\n /**\r\n * add a value at the specified position in the current Matrix\r\n * @param index the index of the value within the matrix. between 0 and 15.\r\n * @param value the value to be added\r\n * @returns the current updated matrix\r\n */\r\n Matrix.prototype.addAtIndex = function (index, value) {\r\n this._m[index] += value;\r\n this._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * mutiply the specified position in the current Matrix by a value\r\n * @param index the index of the value within the matrix. between 0 and 15.\r\n * @param value the value to be added\r\n * @returns the current updated matrix\r\n */\r\n Matrix.prototype.multiplyAtIndex = function (index, value) {\r\n this._m[index] *= value;\r\n this._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Inserts the translation vector (using 3 floats) in the current matrix\r\n * @param x defines the 1st component of the translation\r\n * @param y defines the 2nd component of the translation\r\n * @param z defines the 3rd component of the translation\r\n * @returns the current updated matrix\r\n */\r\n Matrix.prototype.setTranslationFromFloats = function (x, y, z) {\r\n this._m[12] = x;\r\n this._m[13] = y;\r\n this._m[14] = z;\r\n this._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Adds the translation vector (using 3 floats) in the current matrix\r\n * @param x defines the 1st component of the translation\r\n * @param y defines the 2nd component of the translation\r\n * @param z defines the 3rd component of the translation\r\n * @returns the current updated matrix\r\n */\r\n Matrix.prototype.addTranslationFromFloats = function (x, y, z) {\r\n this._m[12] += x;\r\n this._m[13] += y;\r\n this._m[14] += z;\r\n this._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Inserts the translation vector in the current matrix\r\n * @param vector3 defines the translation to insert\r\n * @returns the current updated matrix\r\n */\r\n Matrix.prototype.setTranslation = function (vector3) {\r\n return this.setTranslationFromFloats(vector3.x, vector3.y, vector3.z);\r\n };\r\n /**\r\n * Gets the translation value of the current matrix\r\n * @returns a new Vector3 as the extracted translation from the matrix\r\n */\r\n Matrix.prototype.getTranslation = function () {\r\n return new Vector3(this._m[12], this._m[13], this._m[14]);\r\n };\r\n /**\r\n * Fill a Vector3 with the extracted translation from the matrix\r\n * @param result defines the Vector3 where to store the translation\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.getTranslationToRef = function (result) {\r\n result.x = this._m[12];\r\n result.y = this._m[13];\r\n result.z = this._m[14];\r\n return this;\r\n };\r\n /**\r\n * Remove rotation and scaling part from the matrix\r\n * @returns the updated matrix\r\n */\r\n Matrix.prototype.removeRotationAndScaling = function () {\r\n var m = this.m;\r\n Matrix.FromValuesToRef(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, m[12], m[13], m[14], m[15], this);\r\n this._updateIdentityStatus(m[12] === 0 && m[13] === 0 && m[14] === 0 && m[15] === 1);\r\n return this;\r\n };\r\n /**\r\n * Multiply two matrices\r\n * @param other defines the second operand\r\n * @returns a new matrix set with the multiplication result of the current Matrix and the given one\r\n */\r\n Matrix.prototype.multiply = function (other) {\r\n var result = new Matrix();\r\n this.multiplyToRef(other, result);\r\n return result;\r\n };\r\n /**\r\n * Copy the current matrix from the given one\r\n * @param other defines the source matrix\r\n * @returns the current updated matrix\r\n */\r\n Matrix.prototype.copyFrom = function (other) {\r\n other.copyToArray(this._m);\r\n var o = other;\r\n this._updateIdentityStatus(o._isIdentity, o._isIdentityDirty, o._isIdentity3x2, o._isIdentity3x2Dirty);\r\n return this;\r\n };\r\n /**\r\n * Populates the given array from the starting index with the current matrix values\r\n * @param array defines the target array\r\n * @param offset defines the offset in the target array where to start storing values\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.copyToArray = function (array, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n var source = this._m;\r\n array[offset] = source[0];\r\n array[offset + 1] = source[1];\r\n array[offset + 2] = source[2];\r\n array[offset + 3] = source[3];\r\n array[offset + 4] = source[4];\r\n array[offset + 5] = source[5];\r\n array[offset + 6] = source[6];\r\n array[offset + 7] = source[7];\r\n array[offset + 8] = source[8];\r\n array[offset + 9] = source[9];\r\n array[offset + 10] = source[10];\r\n array[offset + 11] = source[11];\r\n array[offset + 12] = source[12];\r\n array[offset + 13] = source[13];\r\n array[offset + 14] = source[14];\r\n array[offset + 15] = source[15];\r\n return this;\r\n };\r\n /**\r\n * Sets the given matrix \"result\" with the multiplication result of the current Matrix and the given one\r\n * @param other defines the second operand\r\n * @param result defines the matrix where to store the multiplication\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.multiplyToRef = function (other, result) {\r\n if (this._isIdentity) {\r\n result.copyFrom(other);\r\n return this;\r\n }\r\n if (other._isIdentity) {\r\n result.copyFrom(this);\r\n return this;\r\n }\r\n this.multiplyToArray(other, result._m, 0);\r\n result._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Sets the Float32Array \"result\" from the given index \"offset\" with the multiplication of the current matrix and the given one\r\n * @param other defines the second operand\r\n * @param result defines the array where to store the multiplication\r\n * @param offset defines the offset in the target array where to start storing values\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.multiplyToArray = function (other, result, offset) {\r\n var m = this._m;\r\n var otherM = other.m;\r\n var tm0 = m[0], tm1 = m[1], tm2 = m[2], tm3 = m[3];\r\n var tm4 = m[4], tm5 = m[5], tm6 = m[6], tm7 = m[7];\r\n var tm8 = m[8], tm9 = m[9], tm10 = m[10], tm11 = m[11];\r\n var tm12 = m[12], tm13 = m[13], tm14 = m[14], tm15 = m[15];\r\n var om0 = otherM[0], om1 = otherM[1], om2 = otherM[2], om3 = otherM[3];\r\n var om4 = otherM[4], om5 = otherM[5], om6 = otherM[6], om7 = otherM[7];\r\n var om8 = otherM[8], om9 = otherM[9], om10 = otherM[10], om11 = otherM[11];\r\n var om12 = otherM[12], om13 = otherM[13], om14 = otherM[14], om15 = otherM[15];\r\n result[offset] = tm0 * om0 + tm1 * om4 + tm2 * om8 + tm3 * om12;\r\n result[offset + 1] = tm0 * om1 + tm1 * om5 + tm2 * om9 + tm3 * om13;\r\n result[offset + 2] = tm0 * om2 + tm1 * om6 + tm2 * om10 + tm3 * om14;\r\n result[offset + 3] = tm0 * om3 + tm1 * om7 + tm2 * om11 + tm3 * om15;\r\n result[offset + 4] = tm4 * om0 + tm5 * om4 + tm6 * om8 + tm7 * om12;\r\n result[offset + 5] = tm4 * om1 + tm5 * om5 + tm6 * om9 + tm7 * om13;\r\n result[offset + 6] = tm4 * om2 + tm5 * om6 + tm6 * om10 + tm7 * om14;\r\n result[offset + 7] = tm4 * om3 + tm5 * om7 + tm6 * om11 + tm7 * om15;\r\n result[offset + 8] = tm8 * om0 + tm9 * om4 + tm10 * om8 + tm11 * om12;\r\n result[offset + 9] = tm8 * om1 + tm9 * om5 + tm10 * om9 + tm11 * om13;\r\n result[offset + 10] = tm8 * om2 + tm9 * om6 + tm10 * om10 + tm11 * om14;\r\n result[offset + 11] = tm8 * om3 + tm9 * om7 + tm10 * om11 + tm11 * om15;\r\n result[offset + 12] = tm12 * om0 + tm13 * om4 + tm14 * om8 + tm15 * om12;\r\n result[offset + 13] = tm12 * om1 + tm13 * om5 + tm14 * om9 + tm15 * om13;\r\n result[offset + 14] = tm12 * om2 + tm13 * om6 + tm14 * om10 + tm15 * om14;\r\n result[offset + 15] = tm12 * om3 + tm13 * om7 + tm14 * om11 + tm15 * om15;\r\n return this;\r\n };\r\n /**\r\n * Check equality between this matrix and a second one\r\n * @param value defines the second matrix to compare\r\n * @returns true is the current matrix and the given one values are strictly equal\r\n */\r\n Matrix.prototype.equals = function (value) {\r\n var other = value;\r\n if (!other) {\r\n return false;\r\n }\r\n if (this._isIdentity || other._isIdentity) {\r\n if (!this._isIdentityDirty && !other._isIdentityDirty) {\r\n return this._isIdentity && other._isIdentity;\r\n }\r\n }\r\n var m = this.m;\r\n var om = other.m;\r\n return (m[0] === om[0] && m[1] === om[1] && m[2] === om[2] && m[3] === om[3] &&\r\n m[4] === om[4] && m[5] === om[5] && m[6] === om[6] && m[7] === om[7] &&\r\n m[8] === om[8] && m[9] === om[9] && m[10] === om[10] && m[11] === om[11] &&\r\n m[12] === om[12] && m[13] === om[13] && m[14] === om[14] && m[15] === om[15]);\r\n };\r\n /**\r\n * Clone the current matrix\r\n * @returns a new matrix from the current matrix\r\n */\r\n Matrix.prototype.clone = function () {\r\n var matrix = new Matrix();\r\n matrix.copyFrom(this);\r\n return matrix;\r\n };\r\n /**\r\n * Returns the name of the current matrix class\r\n * @returns the string \"Matrix\"\r\n */\r\n Matrix.prototype.getClassName = function () {\r\n return \"Matrix\";\r\n };\r\n /**\r\n * Gets the hash code of the current matrix\r\n * @returns the hash code\r\n */\r\n Matrix.prototype.getHashCode = function () {\r\n var hash = this._m[0] | 0;\r\n for (var i = 1; i < 16; i++) {\r\n hash = (hash * 397) ^ (this._m[i] | 0);\r\n }\r\n return hash;\r\n };\r\n /**\r\n * Decomposes the current Matrix into a translation, rotation and scaling components\r\n * @param scale defines the scale vector3 given as a reference to update\r\n * @param rotation defines the rotation quaternion given as a reference to update\r\n * @param translation defines the translation vector3 given as a reference to update\r\n * @returns true if operation was successful\r\n */\r\n Matrix.prototype.decompose = function (scale, rotation, translation) {\r\n if (this._isIdentity) {\r\n if (translation) {\r\n translation.setAll(0);\r\n }\r\n if (scale) {\r\n scale.setAll(1);\r\n }\r\n if (rotation) {\r\n rotation.copyFromFloats(0, 0, 0, 1);\r\n }\r\n return true;\r\n }\r\n var m = this._m;\r\n if (translation) {\r\n translation.copyFromFloats(m[12], m[13], m[14]);\r\n }\r\n scale = scale || MathTmp.Vector3[0];\r\n scale.x = Math.sqrt(m[0] * m[0] + m[1] * m[1] + m[2] * m[2]);\r\n scale.y = Math.sqrt(m[4] * m[4] + m[5] * m[5] + m[6] * m[6]);\r\n scale.z = Math.sqrt(m[8] * m[8] + m[9] * m[9] + m[10] * m[10]);\r\n if (this.determinant() <= 0) {\r\n scale.y *= -1;\r\n }\r\n if (scale.x === 0 || scale.y === 0 || scale.z === 0) {\r\n if (rotation) {\r\n rotation.copyFromFloats(0.0, 0.0, 0.0, 1.0);\r\n }\r\n return false;\r\n }\r\n if (rotation) {\r\n var sx = 1 / scale.x, sy = 1 / scale.y, sz = 1 / scale.z;\r\n Matrix.FromValuesToRef(m[0] * sx, m[1] * sx, m[2] * sx, 0.0, m[4] * sy, m[5] * sy, m[6] * sy, 0.0, m[8] * sz, m[9] * sz, m[10] * sz, 0.0, 0.0, 0.0, 0.0, 1.0, MathTmp.Matrix[0]);\r\n Quaternion.FromRotationMatrixToRef(MathTmp.Matrix[0], rotation);\r\n }\r\n return true;\r\n };\r\n /**\r\n * Gets specific row of the matrix\r\n * @param index defines the number of the row to get\r\n * @returns the index-th row of the current matrix as a new Vector4\r\n */\r\n Matrix.prototype.getRow = function (index) {\r\n if (index < 0 || index > 3) {\r\n return null;\r\n }\r\n var i = index * 4;\r\n return new Vector4(this._m[i + 0], this._m[i + 1], this._m[i + 2], this._m[i + 3]);\r\n };\r\n /**\r\n * Sets the index-th row of the current matrix to the vector4 values\r\n * @param index defines the number of the row to set\r\n * @param row defines the target vector4\r\n * @returns the updated current matrix\r\n */\r\n Matrix.prototype.setRow = function (index, row) {\r\n return this.setRowFromFloats(index, row.x, row.y, row.z, row.w);\r\n };\r\n /**\r\n * Compute the transpose of the matrix\r\n * @returns the new transposed matrix\r\n */\r\n Matrix.prototype.transpose = function () {\r\n return Matrix.Transpose(this);\r\n };\r\n /**\r\n * Compute the transpose of the matrix and store it in a given matrix\r\n * @param result defines the target matrix\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.transposeToRef = function (result) {\r\n Matrix.TransposeToRef(this, result);\r\n return this;\r\n };\r\n /**\r\n * Sets the index-th row of the current matrix with the given 4 x float values\r\n * @param index defines the row index\r\n * @param x defines the x component to set\r\n * @param y defines the y component to set\r\n * @param z defines the z component to set\r\n * @param w defines the w component to set\r\n * @returns the updated current matrix\r\n */\r\n Matrix.prototype.setRowFromFloats = function (index, x, y, z, w) {\r\n if (index < 0 || index > 3) {\r\n return this;\r\n }\r\n var i = index * 4;\r\n this._m[i + 0] = x;\r\n this._m[i + 1] = y;\r\n this._m[i + 2] = z;\r\n this._m[i + 3] = w;\r\n this._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Compute a new matrix set with the current matrix values multiplied by scale (float)\r\n * @param scale defines the scale factor\r\n * @returns a new matrix\r\n */\r\n Matrix.prototype.scale = function (scale) {\r\n var result = new Matrix();\r\n this.scaleToRef(scale, result);\r\n return result;\r\n };\r\n /**\r\n * Scale the current matrix values by a factor to a given result matrix\r\n * @param scale defines the scale factor\r\n * @param result defines the matrix to store the result\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.scaleToRef = function (scale, result) {\r\n for (var index = 0; index < 16; index++) {\r\n result._m[index] = this._m[index] * scale;\r\n }\r\n result._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Scale the current matrix values by a factor and add the result to a given matrix\r\n * @param scale defines the scale factor\r\n * @param result defines the Matrix to store the result\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.scaleAndAddToRef = function (scale, result) {\r\n for (var index = 0; index < 16; index++) {\r\n result._m[index] += this._m[index] * scale;\r\n }\r\n result._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Writes to the given matrix a normal matrix, computed from this one (using values from identity matrix for fourth row and column).\r\n * @param ref matrix to store the result\r\n */\r\n Matrix.prototype.toNormalMatrix = function (ref) {\r\n var tmp = MathTmp.Matrix[0];\r\n this.invertToRef(tmp);\r\n tmp.transposeToRef(ref);\r\n var m = ref._m;\r\n Matrix.FromValuesToRef(m[0], m[1], m[2], 0.0, m[4], m[5], m[6], 0.0, m[8], m[9], m[10], 0.0, 0.0, 0.0, 0.0, 1.0, ref);\r\n };\r\n /**\r\n * Gets only rotation part of the current matrix\r\n * @returns a new matrix sets to the extracted rotation matrix from the current one\r\n */\r\n Matrix.prototype.getRotationMatrix = function () {\r\n var result = new Matrix();\r\n this.getRotationMatrixToRef(result);\r\n return result;\r\n };\r\n /**\r\n * Extracts the rotation matrix from the current one and sets it as the given \"result\"\r\n * @param result defines the target matrix to store data to\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.getRotationMatrixToRef = function (result) {\r\n var scale = MathTmp.Vector3[0];\r\n if (!this.decompose(scale)) {\r\n Matrix.IdentityToRef(result);\r\n return this;\r\n }\r\n var m = this._m;\r\n var sx = 1 / scale.x, sy = 1 / scale.y, sz = 1 / scale.z;\r\n Matrix.FromValuesToRef(m[0] * sx, m[1] * sx, m[2] * sx, 0.0, m[4] * sy, m[5] * sy, m[6] * sy, 0.0, m[8] * sz, m[9] * sz, m[10] * sz, 0.0, 0.0, 0.0, 0.0, 1.0, result);\r\n return this;\r\n };\r\n /**\r\n * Toggles model matrix from being right handed to left handed in place and vice versa\r\n */\r\n Matrix.prototype.toggleModelMatrixHandInPlace = function () {\r\n var m = this._m;\r\n m[2] *= -1;\r\n m[6] *= -1;\r\n m[8] *= -1;\r\n m[9] *= -1;\r\n m[14] *= -1;\r\n this._markAsUpdated();\r\n };\r\n /**\r\n * Toggles projection matrix from being right handed to left handed in place and vice versa\r\n */\r\n Matrix.prototype.toggleProjectionMatrixHandInPlace = function () {\r\n var m = this._m;\r\n m[8] *= -1;\r\n m[9] *= -1;\r\n m[10] *= -1;\r\n m[11] *= -1;\r\n this._markAsUpdated();\r\n };\r\n // Statics\r\n /**\r\n * Creates a matrix from an array\r\n * @param array defines the source array\r\n * @param offset defines an offset in the source array\r\n * @returns a new Matrix set from the starting index of the given array\r\n */\r\n Matrix.FromArray = function (array, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n var result = new Matrix();\r\n Matrix.FromArrayToRef(array, offset, result);\r\n return result;\r\n };\r\n /**\r\n * Copy the content of an array into a given matrix\r\n * @param array defines the source array\r\n * @param offset defines an offset in the source array\r\n * @param result defines the target matrix\r\n */\r\n Matrix.FromArrayToRef = function (array, offset, result) {\r\n for (var index = 0; index < 16; index++) {\r\n result._m[index] = array[index + offset];\r\n }\r\n result._markAsUpdated();\r\n };\r\n /**\r\n * Stores an array into a matrix after having multiplied each component by a given factor\r\n * @param array defines the source array\r\n * @param offset defines the offset in the source array\r\n * @param scale defines the scaling factor\r\n * @param result defines the target matrix\r\n */\r\n Matrix.FromFloat32ArrayToRefScaled = function (array, offset, scale, result) {\r\n for (var index = 0; index < 16; index++) {\r\n result._m[index] = array[index + offset] * scale;\r\n }\r\n result._markAsUpdated();\r\n };\r\n Object.defineProperty(Matrix, \"IdentityReadOnly\", {\r\n /**\r\n * Gets an identity matrix that must not be updated\r\n */\r\n get: function () {\r\n return Matrix._identityReadOnly;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Stores a list of values (16) inside a given matrix\r\n * @param initialM11 defines 1st value of 1st row\r\n * @param initialM12 defines 2nd value of 1st row\r\n * @param initialM13 defines 3rd value of 1st row\r\n * @param initialM14 defines 4th value of 1st row\r\n * @param initialM21 defines 1st value of 2nd row\r\n * @param initialM22 defines 2nd value of 2nd row\r\n * @param initialM23 defines 3rd value of 2nd row\r\n * @param initialM24 defines 4th value of 2nd row\r\n * @param initialM31 defines 1st value of 3rd row\r\n * @param initialM32 defines 2nd value of 3rd row\r\n * @param initialM33 defines 3rd value of 3rd row\r\n * @param initialM34 defines 4th value of 3rd row\r\n * @param initialM41 defines 1st value of 4th row\r\n * @param initialM42 defines 2nd value of 4th row\r\n * @param initialM43 defines 3rd value of 4th row\r\n * @param initialM44 defines 4th value of 4th row\r\n * @param result defines the target matrix\r\n */\r\n Matrix.FromValuesToRef = function (initialM11, initialM12, initialM13, initialM14, initialM21, initialM22, initialM23, initialM24, initialM31, initialM32, initialM33, initialM34, initialM41, initialM42, initialM43, initialM44, result) {\r\n var m = result._m;\r\n m[0] = initialM11;\r\n m[1] = initialM12;\r\n m[2] = initialM13;\r\n m[3] = initialM14;\r\n m[4] = initialM21;\r\n m[5] = initialM22;\r\n m[6] = initialM23;\r\n m[7] = initialM24;\r\n m[8] = initialM31;\r\n m[9] = initialM32;\r\n m[10] = initialM33;\r\n m[11] = initialM34;\r\n m[12] = initialM41;\r\n m[13] = initialM42;\r\n m[14] = initialM43;\r\n m[15] = initialM44;\r\n result._markAsUpdated();\r\n };\r\n /**\r\n * Creates new matrix from a list of values (16)\r\n * @param initialM11 defines 1st value of 1st row\r\n * @param initialM12 defines 2nd value of 1st row\r\n * @param initialM13 defines 3rd value of 1st row\r\n * @param initialM14 defines 4th value of 1st row\r\n * @param initialM21 defines 1st value of 2nd row\r\n * @param initialM22 defines 2nd value of 2nd row\r\n * @param initialM23 defines 3rd value of 2nd row\r\n * @param initialM24 defines 4th value of 2nd row\r\n * @param initialM31 defines 1st value of 3rd row\r\n * @param initialM32 defines 2nd value of 3rd row\r\n * @param initialM33 defines 3rd value of 3rd row\r\n * @param initialM34 defines 4th value of 3rd row\r\n * @param initialM41 defines 1st value of 4th row\r\n * @param initialM42 defines 2nd value of 4th row\r\n * @param initialM43 defines 3rd value of 4th row\r\n * @param initialM44 defines 4th value of 4th row\r\n * @returns the new matrix\r\n */\r\n Matrix.FromValues = function (initialM11, initialM12, initialM13, initialM14, initialM21, initialM22, initialM23, initialM24, initialM31, initialM32, initialM33, initialM34, initialM41, initialM42, initialM43, initialM44) {\r\n var result = new Matrix();\r\n var m = result._m;\r\n m[0] = initialM11;\r\n m[1] = initialM12;\r\n m[2] = initialM13;\r\n m[3] = initialM14;\r\n m[4] = initialM21;\r\n m[5] = initialM22;\r\n m[6] = initialM23;\r\n m[7] = initialM24;\r\n m[8] = initialM31;\r\n m[9] = initialM32;\r\n m[10] = initialM33;\r\n m[11] = initialM34;\r\n m[12] = initialM41;\r\n m[13] = initialM42;\r\n m[14] = initialM43;\r\n m[15] = initialM44;\r\n result._markAsUpdated();\r\n return result;\r\n };\r\n /**\r\n * Creates a new matrix composed by merging scale (vector3), rotation (quaternion) and translation (vector3)\r\n * @param scale defines the scale vector3\r\n * @param rotation defines the rotation quaternion\r\n * @param translation defines the translation vector3\r\n * @returns a new matrix\r\n */\r\n Matrix.Compose = function (scale, rotation, translation) {\r\n var result = new Matrix();\r\n Matrix.ComposeToRef(scale, rotation, translation, result);\r\n return result;\r\n };\r\n /**\r\n * Sets a matrix to a value composed by merging scale (vector3), rotation (quaternion) and translation (vector3)\r\n * @param scale defines the scale vector3\r\n * @param rotation defines the rotation quaternion\r\n * @param translation defines the translation vector3\r\n * @param result defines the target matrix\r\n */\r\n Matrix.ComposeToRef = function (scale, rotation, translation, result) {\r\n var m = result._m;\r\n var x = rotation.x, y = rotation.y, z = rotation.z, w = rotation.w;\r\n var x2 = x + x, y2 = y + y, z2 = z + z;\r\n var xx = x * x2, xy = x * y2, xz = x * z2;\r\n var yy = y * y2, yz = y * z2, zz = z * z2;\r\n var wx = w * x2, wy = w * y2, wz = w * z2;\r\n var sx = scale.x, sy = scale.y, sz = scale.z;\r\n m[0] = (1 - (yy + zz)) * sx;\r\n m[1] = (xy + wz) * sx;\r\n m[2] = (xz - wy) * sx;\r\n m[3] = 0;\r\n m[4] = (xy - wz) * sy;\r\n m[5] = (1 - (xx + zz)) * sy;\r\n m[6] = (yz + wx) * sy;\r\n m[7] = 0;\r\n m[8] = (xz + wy) * sz;\r\n m[9] = (yz - wx) * sz;\r\n m[10] = (1 - (xx + yy)) * sz;\r\n m[11] = 0;\r\n m[12] = translation.x;\r\n m[13] = translation.y;\r\n m[14] = translation.z;\r\n m[15] = 1;\r\n result._markAsUpdated();\r\n };\r\n /**\r\n * Creates a new identity matrix\r\n * @returns a new identity matrix\r\n */\r\n Matrix.Identity = function () {\r\n var identity = Matrix.FromValues(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0);\r\n identity._updateIdentityStatus(true);\r\n return identity;\r\n };\r\n /**\r\n * Creates a new identity matrix and stores the result in a given matrix\r\n * @param result defines the target matrix\r\n */\r\n Matrix.IdentityToRef = function (result) {\r\n Matrix.FromValuesToRef(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, result);\r\n result._updateIdentityStatus(true);\r\n };\r\n /**\r\n * Creates a new zero matrix\r\n * @returns a new zero matrix\r\n */\r\n Matrix.Zero = function () {\r\n var zero = Matrix.FromValues(0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0);\r\n zero._updateIdentityStatus(false);\r\n return zero;\r\n };\r\n /**\r\n * Creates a new rotation matrix for \"angle\" radians around the X axis\r\n * @param angle defines the angle (in radians) to use\r\n * @return the new matrix\r\n */\r\n Matrix.RotationX = function (angle) {\r\n var result = new Matrix();\r\n Matrix.RotationXToRef(angle, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a new matrix as the invert of a given matrix\r\n * @param source defines the source matrix\r\n * @returns the new matrix\r\n */\r\n Matrix.Invert = function (source) {\r\n var result = new Matrix();\r\n source.invertToRef(result);\r\n return result;\r\n };\r\n /**\r\n * Creates a new rotation matrix for \"angle\" radians around the X axis and stores it in a given matrix\r\n * @param angle defines the angle (in radians) to use\r\n * @param result defines the target matrix\r\n */\r\n Matrix.RotationXToRef = function (angle, result) {\r\n var s = Math.sin(angle);\r\n var c = Math.cos(angle);\r\n Matrix.FromValuesToRef(1.0, 0.0, 0.0, 0.0, 0.0, c, s, 0.0, 0.0, -s, c, 0.0, 0.0, 0.0, 0.0, 1.0, result);\r\n result._updateIdentityStatus(c === 1 && s === 0);\r\n };\r\n /**\r\n * Creates a new rotation matrix for \"angle\" radians around the Y axis\r\n * @param angle defines the angle (in radians) to use\r\n * @return the new matrix\r\n */\r\n Matrix.RotationY = function (angle) {\r\n var result = new Matrix();\r\n Matrix.RotationYToRef(angle, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a new rotation matrix for \"angle\" radians around the Y axis and stores it in a given matrix\r\n * @param angle defines the angle (in radians) to use\r\n * @param result defines the target matrix\r\n */\r\n Matrix.RotationYToRef = function (angle, result) {\r\n var s = Math.sin(angle);\r\n var c = Math.cos(angle);\r\n Matrix.FromValuesToRef(c, 0.0, -s, 0.0, 0.0, 1.0, 0.0, 0.0, s, 0.0, c, 0.0, 0.0, 0.0, 0.0, 1.0, result);\r\n result._updateIdentityStatus(c === 1 && s === 0);\r\n };\r\n /**\r\n * Creates a new rotation matrix for \"angle\" radians around the Z axis\r\n * @param angle defines the angle (in radians) to use\r\n * @return the new matrix\r\n */\r\n Matrix.RotationZ = function (angle) {\r\n var result = new Matrix();\r\n Matrix.RotationZToRef(angle, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a new rotation matrix for \"angle\" radians around the Z axis and stores it in a given matrix\r\n * @param angle defines the angle (in radians) to use\r\n * @param result defines the target matrix\r\n */\r\n Matrix.RotationZToRef = function (angle, result) {\r\n var s = Math.sin(angle);\r\n var c = Math.cos(angle);\r\n Matrix.FromValuesToRef(c, s, 0.0, 0.0, -s, c, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, result);\r\n result._updateIdentityStatus(c === 1 && s === 0);\r\n };\r\n /**\r\n * Creates a new rotation matrix for \"angle\" radians around the given axis\r\n * @param axis defines the axis to use\r\n * @param angle defines the angle (in radians) to use\r\n * @return the new matrix\r\n */\r\n Matrix.RotationAxis = function (axis, angle) {\r\n var result = new Matrix();\r\n Matrix.RotationAxisToRef(axis, angle, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a new rotation matrix for \"angle\" radians around the given axis and stores it in a given matrix\r\n * @param axis defines the axis to use\r\n * @param angle defines the angle (in radians) to use\r\n * @param result defines the target matrix\r\n */\r\n Matrix.RotationAxisToRef = function (axis, angle, result) {\r\n var s = Math.sin(-angle);\r\n var c = Math.cos(-angle);\r\n var c1 = 1 - c;\r\n axis.normalize();\r\n var m = result._m;\r\n m[0] = (axis.x * axis.x) * c1 + c;\r\n m[1] = (axis.x * axis.y) * c1 - (axis.z * s);\r\n m[2] = (axis.x * axis.z) * c1 + (axis.y * s);\r\n m[3] = 0.0;\r\n m[4] = (axis.y * axis.x) * c1 + (axis.z * s);\r\n m[5] = (axis.y * axis.y) * c1 + c;\r\n m[6] = (axis.y * axis.z) * c1 - (axis.x * s);\r\n m[7] = 0.0;\r\n m[8] = (axis.z * axis.x) * c1 - (axis.y * s);\r\n m[9] = (axis.z * axis.y) * c1 + (axis.x * s);\r\n m[10] = (axis.z * axis.z) * c1 + c;\r\n m[11] = 0.0;\r\n m[12] = 0.0;\r\n m[13] = 0.0;\r\n m[14] = 0.0;\r\n m[15] = 1.0;\r\n result._markAsUpdated();\r\n };\r\n /**\r\n * Takes normalised vectors and returns a rotation matrix to align \"from\" with \"to\".\r\n * Taken from http://www.iquilezles.org/www/articles/noacos/noacos.htm\r\n * @param from defines the vector to align\r\n * @param to defines the vector to align to\r\n * @param result defines the target matrix\r\n */\r\n Matrix.RotationAlignToRef = function (from, to, result) {\r\n var v = Vector3.Cross(to, from);\r\n var c = Vector3.Dot(to, from);\r\n var k = 1 / (1 + c);\r\n var m = result._m;\r\n m[0] = v.x * v.x * k + c;\r\n m[1] = v.y * v.x * k - v.z;\r\n m[2] = v.z * v.x * k + v.y;\r\n m[3] = 0;\r\n m[4] = v.x * v.y * k + v.z;\r\n m[5] = v.y * v.y * k + c;\r\n m[6] = v.z * v.y * k - v.x;\r\n m[7] = 0;\r\n m[8] = v.x * v.z * k - v.y;\r\n m[9] = v.y * v.z * k + v.x;\r\n m[10] = v.z * v.z * k + c;\r\n m[11] = 0;\r\n m[12] = 0;\r\n m[13] = 0;\r\n m[14] = 0;\r\n m[15] = 1;\r\n result._markAsUpdated();\r\n };\r\n /**\r\n * Creates a rotation matrix\r\n * @param yaw defines the yaw angle in radians (Y axis)\r\n * @param pitch defines the pitch angle in radians (X axis)\r\n * @param roll defines the roll angle in radians (X axis)\r\n * @returns the new rotation matrix\r\n */\r\n Matrix.RotationYawPitchRoll = function (yaw, pitch, roll) {\r\n var result = new Matrix();\r\n Matrix.RotationYawPitchRollToRef(yaw, pitch, roll, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a rotation matrix and stores it in a given matrix\r\n * @param yaw defines the yaw angle in radians (Y axis)\r\n * @param pitch defines the pitch angle in radians (X axis)\r\n * @param roll defines the roll angle in radians (X axis)\r\n * @param result defines the target matrix\r\n */\r\n Matrix.RotationYawPitchRollToRef = function (yaw, pitch, roll, result) {\r\n Quaternion.RotationYawPitchRollToRef(yaw, pitch, roll, MathTmp.Quaternion[0]);\r\n MathTmp.Quaternion[0].toRotationMatrix(result);\r\n };\r\n /**\r\n * Creates a scaling matrix\r\n * @param x defines the scale factor on X axis\r\n * @param y defines the scale factor on Y axis\r\n * @param z defines the scale factor on Z axis\r\n * @returns the new matrix\r\n */\r\n Matrix.Scaling = function (x, y, z) {\r\n var result = new Matrix();\r\n Matrix.ScalingToRef(x, y, z, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a scaling matrix and stores it in a given matrix\r\n * @param x defines the scale factor on X axis\r\n * @param y defines the scale factor on Y axis\r\n * @param z defines the scale factor on Z axis\r\n * @param result defines the target matrix\r\n */\r\n Matrix.ScalingToRef = function (x, y, z, result) {\r\n Matrix.FromValuesToRef(x, 0.0, 0.0, 0.0, 0.0, y, 0.0, 0.0, 0.0, 0.0, z, 0.0, 0.0, 0.0, 0.0, 1.0, result);\r\n result._updateIdentityStatus(x === 1 && y === 1 && z === 1);\r\n };\r\n /**\r\n * Creates a translation matrix\r\n * @param x defines the translation on X axis\r\n * @param y defines the translation on Y axis\r\n * @param z defines the translationon Z axis\r\n * @returns the new matrix\r\n */\r\n Matrix.Translation = function (x, y, z) {\r\n var result = new Matrix();\r\n Matrix.TranslationToRef(x, y, z, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a translation matrix and stores it in a given matrix\r\n * @param x defines the translation on X axis\r\n * @param y defines the translation on Y axis\r\n * @param z defines the translationon Z axis\r\n * @param result defines the target matrix\r\n */\r\n Matrix.TranslationToRef = function (x, y, z, result) {\r\n Matrix.FromValuesToRef(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, x, y, z, 1.0, result);\r\n result._updateIdentityStatus(x === 0 && y === 0 && z === 0);\r\n };\r\n /**\r\n * Returns a new Matrix whose values are the interpolated values for \"gradient\" (float) between the ones of the matrices \"startValue\" and \"endValue\".\r\n * @param startValue defines the start value\r\n * @param endValue defines the end value\r\n * @param gradient defines the gradient factor\r\n * @returns the new matrix\r\n */\r\n Matrix.Lerp = function (startValue, endValue, gradient) {\r\n var result = new Matrix();\r\n Matrix.LerpToRef(startValue, endValue, gradient, result);\r\n return result;\r\n };\r\n /**\r\n * Set the given matrix \"result\" as the interpolated values for \"gradient\" (float) between the ones of the matrices \"startValue\" and \"endValue\".\r\n * @param startValue defines the start value\r\n * @param endValue defines the end value\r\n * @param gradient defines the gradient factor\r\n * @param result defines the Matrix object where to store data\r\n */\r\n Matrix.LerpToRef = function (startValue, endValue, gradient, result) {\r\n var resultM = result._m;\r\n var startM = startValue.m;\r\n var endM = endValue.m;\r\n for (var index = 0; index < 16; index++) {\r\n resultM[index] = startM[index] * (1.0 - gradient) + endM[index] * gradient;\r\n }\r\n result._markAsUpdated();\r\n };\r\n /**\r\n * Builds a new matrix whose values are computed by:\r\n * * decomposing the the \"startValue\" and \"endValue\" matrices into their respective scale, rotation and translation matrices\r\n * * interpolating for \"gradient\" (float) the values between each of these decomposed matrices between the start and the end\r\n * * recomposing a new matrix from these 3 interpolated scale, rotation and translation matrices\r\n * @param startValue defines the first matrix\r\n * @param endValue defines the second matrix\r\n * @param gradient defines the gradient between the two matrices\r\n * @returns the new matrix\r\n */\r\n Matrix.DecomposeLerp = function (startValue, endValue, gradient) {\r\n var result = new Matrix();\r\n Matrix.DecomposeLerpToRef(startValue, endValue, gradient, result);\r\n return result;\r\n };\r\n /**\r\n * Update a matrix to values which are computed by:\r\n * * decomposing the the \"startValue\" and \"endValue\" matrices into their respective scale, rotation and translation matrices\r\n * * interpolating for \"gradient\" (float) the values between each of these decomposed matrices between the start and the end\r\n * * recomposing a new matrix from these 3 interpolated scale, rotation and translation matrices\r\n * @param startValue defines the first matrix\r\n * @param endValue defines the second matrix\r\n * @param gradient defines the gradient between the two matrices\r\n * @param result defines the target matrix\r\n */\r\n Matrix.DecomposeLerpToRef = function (startValue, endValue, gradient, result) {\r\n var startScale = MathTmp.Vector3[0];\r\n var startRotation = MathTmp.Quaternion[0];\r\n var startTranslation = MathTmp.Vector3[1];\r\n startValue.decompose(startScale, startRotation, startTranslation);\r\n var endScale = MathTmp.Vector3[2];\r\n var endRotation = MathTmp.Quaternion[1];\r\n var endTranslation = MathTmp.Vector3[3];\r\n endValue.decompose(endScale, endRotation, endTranslation);\r\n var resultScale = MathTmp.Vector3[4];\r\n Vector3.LerpToRef(startScale, endScale, gradient, resultScale);\r\n var resultRotation = MathTmp.Quaternion[2];\r\n Quaternion.SlerpToRef(startRotation, endRotation, gradient, resultRotation);\r\n var resultTranslation = MathTmp.Vector3[5];\r\n Vector3.LerpToRef(startTranslation, endTranslation, gradient, resultTranslation);\r\n Matrix.ComposeToRef(resultScale, resultRotation, resultTranslation, result);\r\n };\r\n /**\r\n * Gets a new rotation matrix used to rotate an entity so as it looks at the target vector3, from the eye vector3 position, the up vector3 being oriented like \"up\"\r\n * This function works in left handed mode\r\n * @param eye defines the final position of the entity\r\n * @param target defines where the entity should look at\r\n * @param up defines the up vector for the entity\r\n * @returns the new matrix\r\n */\r\n Matrix.LookAtLH = function (eye, target, up) {\r\n var result = new Matrix();\r\n Matrix.LookAtLHToRef(eye, target, up, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given \"result\" Matrix to a rotation matrix used to rotate an entity so that it looks at the target vector3, from the eye vector3 position, the up vector3 being oriented like \"up\".\r\n * This function works in left handed mode\r\n * @param eye defines the final position of the entity\r\n * @param target defines where the entity should look at\r\n * @param up defines the up vector for the entity\r\n * @param result defines the target matrix\r\n */\r\n Matrix.LookAtLHToRef = function (eye, target, up, result) {\r\n var xAxis = MathTmp.Vector3[0];\r\n var yAxis = MathTmp.Vector3[1];\r\n var zAxis = MathTmp.Vector3[2];\r\n // Z axis\r\n target.subtractToRef(eye, zAxis);\r\n zAxis.normalize();\r\n // X axis\r\n Vector3.CrossToRef(up, zAxis, xAxis);\r\n var xSquareLength = xAxis.lengthSquared();\r\n if (xSquareLength === 0) {\r\n xAxis.x = 1.0;\r\n }\r\n else {\r\n xAxis.normalizeFromLength(Math.sqrt(xSquareLength));\r\n }\r\n // Y axis\r\n Vector3.CrossToRef(zAxis, xAxis, yAxis);\r\n yAxis.normalize();\r\n // Eye angles\r\n var ex = -Vector3.Dot(xAxis, eye);\r\n var ey = -Vector3.Dot(yAxis, eye);\r\n var ez = -Vector3.Dot(zAxis, eye);\r\n Matrix.FromValuesToRef(xAxis.x, yAxis.x, zAxis.x, 0.0, xAxis.y, yAxis.y, zAxis.y, 0.0, xAxis.z, yAxis.z, zAxis.z, 0.0, ex, ey, ez, 1.0, result);\r\n };\r\n /**\r\n * Gets a new rotation matrix used to rotate an entity so as it looks at the target vector3, from the eye vector3 position, the up vector3 being oriented like \"up\"\r\n * This function works in right handed mode\r\n * @param eye defines the final position of the entity\r\n * @param target defines where the entity should look at\r\n * @param up defines the up vector for the entity\r\n * @returns the new matrix\r\n */\r\n Matrix.LookAtRH = function (eye, target, up) {\r\n var result = new Matrix();\r\n Matrix.LookAtRHToRef(eye, target, up, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given \"result\" Matrix to a rotation matrix used to rotate an entity so that it looks at the target vector3, from the eye vector3 position, the up vector3 being oriented like \"up\".\r\n * This function works in right handed mode\r\n * @param eye defines the final position of the entity\r\n * @param target defines where the entity should look at\r\n * @param up defines the up vector for the entity\r\n * @param result defines the target matrix\r\n */\r\n Matrix.LookAtRHToRef = function (eye, target, up, result) {\r\n var xAxis = MathTmp.Vector3[0];\r\n var yAxis = MathTmp.Vector3[1];\r\n var zAxis = MathTmp.Vector3[2];\r\n // Z axis\r\n eye.subtractToRef(target, zAxis);\r\n zAxis.normalize();\r\n // X axis\r\n Vector3.CrossToRef(up, zAxis, xAxis);\r\n var xSquareLength = xAxis.lengthSquared();\r\n if (xSquareLength === 0) {\r\n xAxis.x = 1.0;\r\n }\r\n else {\r\n xAxis.normalizeFromLength(Math.sqrt(xSquareLength));\r\n }\r\n // Y axis\r\n Vector3.CrossToRef(zAxis, xAxis, yAxis);\r\n yAxis.normalize();\r\n // Eye angles\r\n var ex = -Vector3.Dot(xAxis, eye);\r\n var ey = -Vector3.Dot(yAxis, eye);\r\n var ez = -Vector3.Dot(zAxis, eye);\r\n Matrix.FromValuesToRef(xAxis.x, yAxis.x, zAxis.x, 0.0, xAxis.y, yAxis.y, zAxis.y, 0.0, xAxis.z, yAxis.z, zAxis.z, 0.0, ex, ey, ez, 1.0, result);\r\n };\r\n /**\r\n * Create a left-handed orthographic projection matrix\r\n * @param width defines the viewport width\r\n * @param height defines the viewport height\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @returns a new matrix as a left-handed orthographic projection matrix\r\n */\r\n Matrix.OrthoLH = function (width, height, znear, zfar) {\r\n var matrix = new Matrix();\r\n Matrix.OrthoLHToRef(width, height, znear, zfar, matrix);\r\n return matrix;\r\n };\r\n /**\r\n * Store a left-handed orthographic projection to a given matrix\r\n * @param width defines the viewport width\r\n * @param height defines the viewport height\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @param result defines the target matrix\r\n */\r\n Matrix.OrthoLHToRef = function (width, height, znear, zfar, result) {\r\n var n = znear;\r\n var f = zfar;\r\n var a = 2.0 / width;\r\n var b = 2.0 / height;\r\n var c = 2.0 / (f - n);\r\n var d = -(f + n) / (f - n);\r\n Matrix.FromValuesToRef(a, 0.0, 0.0, 0.0, 0.0, b, 0.0, 0.0, 0.0, 0.0, c, 0.0, 0.0, 0.0, d, 1.0, result);\r\n result._updateIdentityStatus(a === 1 && b === 1 && c === 1 && d === 0);\r\n };\r\n /**\r\n * Create a left-handed orthographic projection matrix\r\n * @param left defines the viewport left coordinate\r\n * @param right defines the viewport right coordinate\r\n * @param bottom defines the viewport bottom coordinate\r\n * @param top defines the viewport top coordinate\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @returns a new matrix as a left-handed orthographic projection matrix\r\n */\r\n Matrix.OrthoOffCenterLH = function (left, right, bottom, top, znear, zfar) {\r\n var matrix = new Matrix();\r\n Matrix.OrthoOffCenterLHToRef(left, right, bottom, top, znear, zfar, matrix);\r\n return matrix;\r\n };\r\n /**\r\n * Stores a left-handed orthographic projection into a given matrix\r\n * @param left defines the viewport left coordinate\r\n * @param right defines the viewport right coordinate\r\n * @param bottom defines the viewport bottom coordinate\r\n * @param top defines the viewport top coordinate\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @param result defines the target matrix\r\n */\r\n Matrix.OrthoOffCenterLHToRef = function (left, right, bottom, top, znear, zfar, result) {\r\n var n = znear;\r\n var f = zfar;\r\n var a = 2.0 / (right - left);\r\n var b = 2.0 / (top - bottom);\r\n var c = 2.0 / (f - n);\r\n var d = -(f + n) / (f - n);\r\n var i0 = (left + right) / (left - right);\r\n var i1 = (top + bottom) / (bottom - top);\r\n Matrix.FromValuesToRef(a, 0.0, 0.0, 0.0, 0.0, b, 0.0, 0.0, 0.0, 0.0, c, 0.0, i0, i1, d, 1.0, result);\r\n result._markAsUpdated();\r\n };\r\n /**\r\n * Creates a right-handed orthographic projection matrix\r\n * @param left defines the viewport left coordinate\r\n * @param right defines the viewport right coordinate\r\n * @param bottom defines the viewport bottom coordinate\r\n * @param top defines the viewport top coordinate\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @returns a new matrix as a right-handed orthographic projection matrix\r\n */\r\n Matrix.OrthoOffCenterRH = function (left, right, bottom, top, znear, zfar) {\r\n var matrix = new Matrix();\r\n Matrix.OrthoOffCenterRHToRef(left, right, bottom, top, znear, zfar, matrix);\r\n return matrix;\r\n };\r\n /**\r\n * Stores a right-handed orthographic projection into a given matrix\r\n * @param left defines the viewport left coordinate\r\n * @param right defines the viewport right coordinate\r\n * @param bottom defines the viewport bottom coordinate\r\n * @param top defines the viewport top coordinate\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @param result defines the target matrix\r\n */\r\n Matrix.OrthoOffCenterRHToRef = function (left, right, bottom, top, znear, zfar, result) {\r\n Matrix.OrthoOffCenterLHToRef(left, right, bottom, top, znear, zfar, result);\r\n result._m[10] *= -1; // No need to call _markAsUpdated as previous function already called it and let _isIdentityDirty to true\r\n };\r\n /**\r\n * Creates a left-handed perspective projection matrix\r\n * @param width defines the viewport width\r\n * @param height defines the viewport height\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @returns a new matrix as a left-handed perspective projection matrix\r\n */\r\n Matrix.PerspectiveLH = function (width, height, znear, zfar) {\r\n var matrix = new Matrix();\r\n var n = znear;\r\n var f = zfar;\r\n var a = 2.0 * n / width;\r\n var b = 2.0 * n / height;\r\n var c = (f + n) / (f - n);\r\n var d = -2.0 * f * n / (f - n);\r\n Matrix.FromValuesToRef(a, 0.0, 0.0, 0.0, 0.0, b, 0.0, 0.0, 0.0, 0.0, c, 1.0, 0.0, 0.0, d, 0.0, matrix);\r\n matrix._updateIdentityStatus(false);\r\n return matrix;\r\n };\r\n /**\r\n * Creates a left-handed perspective projection matrix\r\n * @param fov defines the horizontal field of view\r\n * @param aspect defines the aspect ratio\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @returns a new matrix as a left-handed perspective projection matrix\r\n */\r\n Matrix.PerspectiveFovLH = function (fov, aspect, znear, zfar) {\r\n var matrix = new Matrix();\r\n Matrix.PerspectiveFovLHToRef(fov, aspect, znear, zfar, matrix);\r\n return matrix;\r\n };\r\n /**\r\n * Stores a left-handed perspective projection into a given matrix\r\n * @param fov defines the horizontal field of view\r\n * @param aspect defines the aspect ratio\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @param result defines the target matrix\r\n * @param isVerticalFovFixed defines it the fov is vertically fixed (default) or horizontally\r\n */\r\n Matrix.PerspectiveFovLHToRef = function (fov, aspect, znear, zfar, result, isVerticalFovFixed) {\r\n if (isVerticalFovFixed === void 0) { isVerticalFovFixed = true; }\r\n var n = znear;\r\n var f = zfar;\r\n var t = 1.0 / (Math.tan(fov * 0.5));\r\n var a = isVerticalFovFixed ? (t / aspect) : t;\r\n var b = isVerticalFovFixed ? t : (t * aspect);\r\n var c = (f + n) / (f - n);\r\n var d = -2.0 * f * n / (f - n);\r\n Matrix.FromValuesToRef(a, 0.0, 0.0, 0.0, 0.0, b, 0.0, 0.0, 0.0, 0.0, c, 1.0, 0.0, 0.0, d, 0.0, result);\r\n result._updateIdentityStatus(false);\r\n };\r\n /**\r\n * Stores a left-handed perspective projection into a given matrix with depth reversed\r\n * @param fov defines the horizontal field of view\r\n * @param aspect defines the aspect ratio\r\n * @param znear defines the near clip plane\r\n * @param zfar not used as infinity is used as far clip\r\n * @param result defines the target matrix\r\n * @param isVerticalFovFixed defines it the fov is vertically fixed (default) or horizontally\r\n */\r\n Matrix.PerspectiveFovReverseLHToRef = function (fov, aspect, znear, zfar, result, isVerticalFovFixed) {\r\n if (isVerticalFovFixed === void 0) { isVerticalFovFixed = true; }\r\n var t = 1.0 / (Math.tan(fov * 0.5));\r\n var a = isVerticalFovFixed ? (t / aspect) : t;\r\n var b = isVerticalFovFixed ? t : (t * aspect);\r\n Matrix.FromValuesToRef(a, 0.0, 0.0, 0.0, 0.0, b, 0.0, 0.0, 0.0, 0.0, -znear, 1.0, 0.0, 0.0, 1.0, 0.0, result);\r\n result._updateIdentityStatus(false);\r\n };\r\n /**\r\n * Creates a right-handed perspective projection matrix\r\n * @param fov defines the horizontal field of view\r\n * @param aspect defines the aspect ratio\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @returns a new matrix as a right-handed perspective projection matrix\r\n */\r\n Matrix.PerspectiveFovRH = function (fov, aspect, znear, zfar) {\r\n var matrix = new Matrix();\r\n Matrix.PerspectiveFovRHToRef(fov, aspect, znear, zfar, matrix);\r\n return matrix;\r\n };\r\n /**\r\n * Stores a right-handed perspective projection into a given matrix\r\n * @param fov defines the horizontal field of view\r\n * @param aspect defines the aspect ratio\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @param result defines the target matrix\r\n * @param isVerticalFovFixed defines it the fov is vertically fixed (default) or horizontally\r\n */\r\n Matrix.PerspectiveFovRHToRef = function (fov, aspect, znear, zfar, result, isVerticalFovFixed) {\r\n //alternatively this could be expressed as:\r\n // m = PerspectiveFovLHToRef\r\n // m[10] *= -1.0;\r\n // m[11] *= -1.0;\r\n if (isVerticalFovFixed === void 0) { isVerticalFovFixed = true; }\r\n var n = znear;\r\n var f = zfar;\r\n var t = 1.0 / (Math.tan(fov * 0.5));\r\n var a = isVerticalFovFixed ? (t / aspect) : t;\r\n var b = isVerticalFovFixed ? t : (t * aspect);\r\n var c = -(f + n) / (f - n);\r\n var d = -2 * f * n / (f - n);\r\n Matrix.FromValuesToRef(a, 0.0, 0.0, 0.0, 0.0, b, 0.0, 0.0, 0.0, 0.0, c, -1.0, 0.0, 0.0, d, 0.0, result);\r\n result._updateIdentityStatus(false);\r\n };\r\n /**\r\n * Stores a right-handed perspective projection into a given matrix\r\n * @param fov defines the horizontal field of view\r\n * @param aspect defines the aspect ratio\r\n * @param znear defines the near clip plane\r\n * @param zfar not used as infinity is used as far clip\r\n * @param result defines the target matrix\r\n * @param isVerticalFovFixed defines it the fov is vertically fixed (default) or horizontally\r\n */\r\n Matrix.PerspectiveFovReverseRHToRef = function (fov, aspect, znear, zfar, result, isVerticalFovFixed) {\r\n //alternatively this could be expressed as:\r\n // m = PerspectiveFovLHToRef\r\n // m[10] *= -1.0;\r\n // m[11] *= -1.0;\r\n if (isVerticalFovFixed === void 0) { isVerticalFovFixed = true; }\r\n var t = 1.0 / (Math.tan(fov * 0.5));\r\n var a = isVerticalFovFixed ? (t / aspect) : t;\r\n var b = isVerticalFovFixed ? t : (t * aspect);\r\n Matrix.FromValuesToRef(a, 0.0, 0.0, 0.0, 0.0, b, 0.0, 0.0, 0.0, 0.0, -znear, -1.0, 0.0, 0.0, -1.0, 0.0, result);\r\n result._updateIdentityStatus(false);\r\n };\r\n /**\r\n * Stores a perspective projection for WebVR info a given matrix\r\n * @param fov defines the field of view\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @param result defines the target matrix\r\n * @param rightHanded defines if the matrix must be in right-handed mode (false by default)\r\n */\r\n Matrix.PerspectiveFovWebVRToRef = function (fov, znear, zfar, result, rightHanded) {\r\n if (rightHanded === void 0) { rightHanded = false; }\r\n var rightHandedFactor = rightHanded ? -1 : 1;\r\n var upTan = Math.tan(fov.upDegrees * Math.PI / 180.0);\r\n var downTan = Math.tan(fov.downDegrees * Math.PI / 180.0);\r\n var leftTan = Math.tan(fov.leftDegrees * Math.PI / 180.0);\r\n var rightTan = Math.tan(fov.rightDegrees * Math.PI / 180.0);\r\n var xScale = 2.0 / (leftTan + rightTan);\r\n var yScale = 2.0 / (upTan + downTan);\r\n var m = result._m;\r\n m[0] = xScale;\r\n m[1] = m[2] = m[3] = m[4] = 0.0;\r\n m[5] = yScale;\r\n m[6] = m[7] = 0.0;\r\n m[8] = ((leftTan - rightTan) * xScale * 0.5);\r\n m[9] = -((upTan - downTan) * yScale * 0.5);\r\n m[10] = -zfar / (znear - zfar);\r\n m[11] = 1.0 * rightHandedFactor;\r\n m[12] = m[13] = m[15] = 0.0;\r\n m[14] = -(2.0 * zfar * znear) / (zfar - znear);\r\n result._markAsUpdated();\r\n };\r\n /**\r\n * Computes a complete transformation matrix\r\n * @param viewport defines the viewport to use\r\n * @param world defines the world matrix\r\n * @param view defines the view matrix\r\n * @param projection defines the projection matrix\r\n * @param zmin defines the near clip plane\r\n * @param zmax defines the far clip plane\r\n * @returns the transformation matrix\r\n */\r\n Matrix.GetFinalMatrix = function (viewport, world, view, projection, zmin, zmax) {\r\n var cw = viewport.width;\r\n var ch = viewport.height;\r\n var cx = viewport.x;\r\n var cy = viewport.y;\r\n var viewportMatrix = Matrix.FromValues(cw / 2.0, 0.0, 0.0, 0.0, 0.0, -ch / 2.0, 0.0, 0.0, 0.0, 0.0, zmax - zmin, 0.0, cx + cw / 2.0, ch / 2.0 + cy, zmin, 1.0);\r\n var matrix = MathTmp.Matrix[0];\r\n world.multiplyToRef(view, matrix);\r\n matrix.multiplyToRef(projection, matrix);\r\n return matrix.multiply(viewportMatrix);\r\n };\r\n /**\r\n * Extracts a 2x2 matrix from a given matrix and store the result in a Float32Array\r\n * @param matrix defines the matrix to use\r\n * @returns a new Float32Array array with 4 elements : the 2x2 matrix extracted from the given matrix\r\n */\r\n Matrix.GetAsMatrix2x2 = function (matrix) {\r\n var m = matrix.m;\r\n return new Float32Array([m[0], m[1], m[4], m[5]]);\r\n };\r\n /**\r\n * Extracts a 3x3 matrix from a given matrix and store the result in a Float32Array\r\n * @param matrix defines the matrix to use\r\n * @returns a new Float32Array array with 9 elements : the 3x3 matrix extracted from the given matrix\r\n */\r\n Matrix.GetAsMatrix3x3 = function (matrix) {\r\n var m = matrix.m;\r\n return new Float32Array([\r\n m[0], m[1], m[2],\r\n m[4], m[5], m[6],\r\n m[8], m[9], m[10]\r\n ]);\r\n };\r\n /**\r\n * Compute the transpose of a given matrix\r\n * @param matrix defines the matrix to transpose\r\n * @returns the new matrix\r\n */\r\n Matrix.Transpose = function (matrix) {\r\n var result = new Matrix();\r\n Matrix.TransposeToRef(matrix, result);\r\n return result;\r\n };\r\n /**\r\n * Compute the transpose of a matrix and store it in a target matrix\r\n * @param matrix defines the matrix to transpose\r\n * @param result defines the target matrix\r\n */\r\n Matrix.TransposeToRef = function (matrix, result) {\r\n var rm = result._m;\r\n var mm = matrix.m;\r\n rm[0] = mm[0];\r\n rm[1] = mm[4];\r\n rm[2] = mm[8];\r\n rm[3] = mm[12];\r\n rm[4] = mm[1];\r\n rm[5] = mm[5];\r\n rm[6] = mm[9];\r\n rm[7] = mm[13];\r\n rm[8] = mm[2];\r\n rm[9] = mm[6];\r\n rm[10] = mm[10];\r\n rm[11] = mm[14];\r\n rm[12] = mm[3];\r\n rm[13] = mm[7];\r\n rm[14] = mm[11];\r\n rm[15] = mm[15];\r\n // identity-ness does not change when transposing\r\n result._updateIdentityStatus(matrix._isIdentity, matrix._isIdentityDirty);\r\n };\r\n /**\r\n * Computes a reflection matrix from a plane\r\n * @param plane defines the reflection plane\r\n * @returns a new matrix\r\n */\r\n Matrix.Reflection = function (plane) {\r\n var matrix = new Matrix();\r\n Matrix.ReflectionToRef(plane, matrix);\r\n return matrix;\r\n };\r\n /**\r\n * Computes a reflection matrix from a plane\r\n * @param plane defines the reflection plane\r\n * @param result defines the target matrix\r\n */\r\n Matrix.ReflectionToRef = function (plane, result) {\r\n plane.normalize();\r\n var x = plane.normal.x;\r\n var y = plane.normal.y;\r\n var z = plane.normal.z;\r\n var temp = -2 * x;\r\n var temp2 = -2 * y;\r\n var temp3 = -2 * z;\r\n Matrix.FromValuesToRef(temp * x + 1, temp2 * x, temp3 * x, 0.0, temp * y, temp2 * y + 1, temp3 * y, 0.0, temp * z, temp2 * z, temp3 * z + 1, 0.0, temp * plane.d, temp2 * plane.d, temp3 * plane.d, 1.0, result);\r\n };\r\n /**\r\n * Sets the given matrix as a rotation matrix composed from the 3 left handed axes\r\n * @param xaxis defines the value of the 1st axis\r\n * @param yaxis defines the value of the 2nd axis\r\n * @param zaxis defines the value of the 3rd axis\r\n * @param result defines the target matrix\r\n */\r\n Matrix.FromXYZAxesToRef = function (xaxis, yaxis, zaxis, result) {\r\n Matrix.FromValuesToRef(xaxis.x, xaxis.y, xaxis.z, 0.0, yaxis.x, yaxis.y, yaxis.z, 0.0, zaxis.x, zaxis.y, zaxis.z, 0.0, 0.0, 0.0, 0.0, 1.0, result);\r\n };\r\n /**\r\n * Creates a rotation matrix from a quaternion and stores it in a target matrix\r\n * @param quat defines the quaternion to use\r\n * @param result defines the target matrix\r\n */\r\n Matrix.FromQuaternionToRef = function (quat, result) {\r\n var xx = quat.x * quat.x;\r\n var yy = quat.y * quat.y;\r\n var zz = quat.z * quat.z;\r\n var xy = quat.x * quat.y;\r\n var zw = quat.z * quat.w;\r\n var zx = quat.z * quat.x;\r\n var yw = quat.y * quat.w;\r\n var yz = quat.y * quat.z;\r\n var xw = quat.x * quat.w;\r\n result._m[0] = 1.0 - (2.0 * (yy + zz));\r\n result._m[1] = 2.0 * (xy + zw);\r\n result._m[2] = 2.0 * (zx - yw);\r\n result._m[3] = 0.0;\r\n result._m[4] = 2.0 * (xy - zw);\r\n result._m[5] = 1.0 - (2.0 * (zz + xx));\r\n result._m[6] = 2.0 * (yz + xw);\r\n result._m[7] = 0.0;\r\n result._m[8] = 2.0 * (zx + yw);\r\n result._m[9] = 2.0 * (yz - xw);\r\n result._m[10] = 1.0 - (2.0 * (yy + xx));\r\n result._m[11] = 0.0;\r\n result._m[12] = 0.0;\r\n result._m[13] = 0.0;\r\n result._m[14] = 0.0;\r\n result._m[15] = 1.0;\r\n result._markAsUpdated();\r\n };\r\n Matrix._updateFlagSeed = 0;\r\n Matrix._identityReadOnly = Matrix.Identity();\r\n return Matrix;\r\n}());\r\nexport { Matrix };\r\n/**\r\n * @hidden\r\n * Same as Tmp but not exported to keep it only for math functions to avoid conflicts\r\n */\r\nvar MathTmp = /** @class */ (function () {\r\n function MathTmp() {\r\n }\r\n MathTmp.Vector3 = ArrayTools.BuildArray(6, Vector3.Zero);\r\n MathTmp.Matrix = ArrayTools.BuildArray(2, Matrix.Identity);\r\n MathTmp.Quaternion = ArrayTools.BuildArray(3, Quaternion.Zero);\r\n return MathTmp;\r\n}());\r\n/**\r\n * @hidden\r\n */\r\nvar TmpVectors = /** @class */ (function () {\r\n function TmpVectors() {\r\n }\r\n TmpVectors.Vector2 = ArrayTools.BuildArray(3, Vector2.Zero); // 3 temp Vector2 at once should be enough\r\n TmpVectors.Vector3 = ArrayTools.BuildArray(13, Vector3.Zero); // 13 temp Vector3 at once should be enough\r\n TmpVectors.Vector4 = ArrayTools.BuildArray(3, Vector4.Zero); // 3 temp Vector4 at once should be enough\r\n TmpVectors.Quaternion = ArrayTools.BuildArray(2, Quaternion.Zero); // 2 temp Quaternion at once should be enough\r\n TmpVectors.Matrix = ArrayTools.BuildArray(8, Matrix.Identity); // 8 temp Matrices at once should be enough\r\n return TmpVectors;\r\n}());\r\nexport { TmpVectors };\r\n_TypeStore.RegisteredTypes[\"BABYLON.Vector2\"] = Vector2;\r\n_TypeStore.RegisteredTypes[\"BABYLON.Vector3\"] = Vector3;\r\n_TypeStore.RegisteredTypes[\"BABYLON.Vector4\"] = Vector4;\r\n_TypeStore.RegisteredTypes[\"BABYLON.Matrix\"] = Matrix;\r\n//# sourceMappingURL=math.vector.js.map","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport function __exportStar(m, exports) {\r\n for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\r\n result.default = mod;\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, privateMap) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to get private field on non-instance\");\r\n }\r\n return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to set private field on non-instance\");\r\n }\r\n privateMap.set(receiver, value);\r\n return value;\r\n}\r\n","/**\r\n * Class used to store data that will be store in GPU memory\r\n */\r\nvar Buffer = /** @class */ (function () {\r\n /**\r\n * Constructor\r\n * @param engine the engine\r\n * @param data the data to use for this buffer\r\n * @param updatable whether the data is updatable\r\n * @param stride the stride (optional)\r\n * @param postponeInternalCreation whether to postpone creating the internal WebGL buffer (optional)\r\n * @param instanced whether the buffer is instanced (optional)\r\n * @param useBytes set to true if the stride in in bytes (optional)\r\n * @param divisor sets an optional divisor for instances (1 by default)\r\n */\r\n function Buffer(engine, data, updatable, stride, postponeInternalCreation, instanced, useBytes, divisor) {\r\n if (stride === void 0) { stride = 0; }\r\n if (postponeInternalCreation === void 0) { postponeInternalCreation = false; }\r\n if (instanced === void 0) { instanced = false; }\r\n if (useBytes === void 0) { useBytes = false; }\r\n if (engine.getScene) { // old versions of VertexBuffer accepted 'mesh' instead of 'engine'\r\n this._engine = engine.getScene().getEngine();\r\n }\r\n else {\r\n this._engine = engine;\r\n }\r\n this._updatable = updatable;\r\n this._instanced = instanced;\r\n this._divisor = divisor || 1;\r\n this._data = data;\r\n this.byteStride = useBytes ? stride : stride * Float32Array.BYTES_PER_ELEMENT;\r\n if (!postponeInternalCreation) { // by default\r\n this.create();\r\n }\r\n }\r\n /**\r\n * Create a new VertexBuffer based on the current buffer\r\n * @param kind defines the vertex buffer kind (position, normal, etc.)\r\n * @param offset defines offset in the buffer (0 by default)\r\n * @param size defines the size in floats of attributes (position is 3 for instance)\r\n * @param stride defines the stride size in floats in the buffer (the offset to apply to reach next value when data is interleaved)\r\n * @param instanced defines if the vertex buffer contains indexed data\r\n * @param useBytes defines if the offset and stride are in bytes *\r\n * @param divisor sets an optional divisor for instances (1 by default)\r\n * @returns the new vertex buffer\r\n */\r\n Buffer.prototype.createVertexBuffer = function (kind, offset, size, stride, instanced, useBytes, divisor) {\r\n if (useBytes === void 0) { useBytes = false; }\r\n var byteOffset = useBytes ? offset : offset * Float32Array.BYTES_PER_ELEMENT;\r\n var byteStride = stride ? (useBytes ? stride : stride * Float32Array.BYTES_PER_ELEMENT) : this.byteStride;\r\n // a lot of these parameters are ignored as they are overriden by the buffer\r\n return new VertexBuffer(this._engine, this, kind, this._updatable, true, byteStride, instanced === undefined ? this._instanced : instanced, byteOffset, size, undefined, undefined, true, this._divisor || divisor);\r\n };\r\n // Properties\r\n /**\r\n * Gets a boolean indicating if the Buffer is updatable?\r\n * @returns true if the buffer is updatable\r\n */\r\n Buffer.prototype.isUpdatable = function () {\r\n return this._updatable;\r\n };\r\n /**\r\n * Gets current buffer's data\r\n * @returns a DataArray or null\r\n */\r\n Buffer.prototype.getData = function () {\r\n return this._data;\r\n };\r\n /**\r\n * Gets underlying native buffer\r\n * @returns underlying native buffer\r\n */\r\n Buffer.prototype.getBuffer = function () {\r\n return this._buffer;\r\n };\r\n /**\r\n * Gets the stride in float32 units (i.e. byte stride / 4).\r\n * May not be an integer if the byte stride is not divisible by 4.\r\n * @returns the stride in float32 units\r\n * @deprecated Please use byteStride instead.\r\n */\r\n Buffer.prototype.getStrideSize = function () {\r\n return this.byteStride / Float32Array.BYTES_PER_ELEMENT;\r\n };\r\n // Methods\r\n /**\r\n * Store data into the buffer. If the buffer was already used it will be either recreated or updated depending on isUpdatable property\r\n * @param data defines the data to store\r\n */\r\n Buffer.prototype.create = function (data) {\r\n if (data === void 0) { data = null; }\r\n if (!data && this._buffer) {\r\n return; // nothing to do\r\n }\r\n data = data || this._data;\r\n if (!data) {\r\n return;\r\n }\r\n if (!this._buffer) { // create buffer\r\n if (this._updatable) {\r\n this._buffer = this._engine.createDynamicVertexBuffer(data);\r\n this._data = data;\r\n }\r\n else {\r\n this._buffer = this._engine.createVertexBuffer(data);\r\n }\r\n }\r\n else if (this._updatable) { // update buffer\r\n this._engine.updateDynamicVertexBuffer(this._buffer, data);\r\n this._data = data;\r\n }\r\n };\r\n /** @hidden */\r\n Buffer.prototype._rebuild = function () {\r\n this._buffer = null;\r\n this.create(this._data);\r\n };\r\n /**\r\n * Update current buffer data\r\n * @param data defines the data to store\r\n */\r\n Buffer.prototype.update = function (data) {\r\n this.create(data);\r\n };\r\n /**\r\n * Updates the data directly.\r\n * @param data the new data\r\n * @param offset the new offset\r\n * @param vertexCount the vertex count (optional)\r\n * @param useBytes set to true if the offset is in bytes\r\n */\r\n Buffer.prototype.updateDirectly = function (data, offset, vertexCount, useBytes) {\r\n if (useBytes === void 0) { useBytes = false; }\r\n if (!this._buffer) {\r\n return;\r\n }\r\n if (this._updatable) { // update buffer\r\n this._engine.updateDynamicVertexBuffer(this._buffer, data, useBytes ? offset : offset * Float32Array.BYTES_PER_ELEMENT, (vertexCount ? vertexCount * this.byteStride : undefined));\r\n this._data = null;\r\n }\r\n };\r\n /**\r\n * Release all resources\r\n */\r\n Buffer.prototype.dispose = function () {\r\n if (!this._buffer) {\r\n return;\r\n }\r\n if (this._engine._releaseBuffer(this._buffer)) {\r\n this._buffer = null;\r\n }\r\n };\r\n return Buffer;\r\n}());\r\nexport { Buffer };\r\n/**\r\n * Specialized buffer used to store vertex data\r\n */\r\nvar VertexBuffer = /** @class */ (function () {\r\n /**\r\n * Constructor\r\n * @param engine the engine\r\n * @param data the data to use for this vertex buffer\r\n * @param kind the vertex buffer kind\r\n * @param updatable whether the data is updatable\r\n * @param postponeInternalCreation whether to postpone creating the internal WebGL buffer (optional)\r\n * @param stride the stride (optional)\r\n * @param instanced whether the buffer is instanced (optional)\r\n * @param offset the offset of the data (optional)\r\n * @param size the number of components (optional)\r\n * @param type the type of the component (optional)\r\n * @param normalized whether the data contains normalized data (optional)\r\n * @param useBytes set to true if stride and offset are in bytes (optional)\r\n * @param divisor defines the instance divisor to use (1 by default)\r\n */\r\n function VertexBuffer(engine, data, kind, updatable, postponeInternalCreation, stride, instanced, offset, size, type, normalized, useBytes, divisor) {\r\n if (normalized === void 0) { normalized = false; }\r\n if (useBytes === void 0) { useBytes = false; }\r\n if (divisor === void 0) { divisor = 1; }\r\n if (data instanceof Buffer) {\r\n this._buffer = data;\r\n this._ownsBuffer = false;\r\n }\r\n else {\r\n this._buffer = new Buffer(engine, data, updatable, stride, postponeInternalCreation, instanced, useBytes);\r\n this._ownsBuffer = true;\r\n }\r\n this._kind = kind;\r\n if (type == undefined) {\r\n var data_1 = this.getData();\r\n this.type = VertexBuffer.FLOAT;\r\n if (data_1 instanceof Int8Array) {\r\n this.type = VertexBuffer.BYTE;\r\n }\r\n else if (data_1 instanceof Uint8Array) {\r\n this.type = VertexBuffer.UNSIGNED_BYTE;\r\n }\r\n else if (data_1 instanceof Int16Array) {\r\n this.type = VertexBuffer.SHORT;\r\n }\r\n else if (data_1 instanceof Uint16Array) {\r\n this.type = VertexBuffer.UNSIGNED_SHORT;\r\n }\r\n else if (data_1 instanceof Int32Array) {\r\n this.type = VertexBuffer.INT;\r\n }\r\n else if (data_1 instanceof Uint32Array) {\r\n this.type = VertexBuffer.UNSIGNED_INT;\r\n }\r\n }\r\n else {\r\n this.type = type;\r\n }\r\n var typeByteLength = VertexBuffer.GetTypeByteLength(this.type);\r\n if (useBytes) {\r\n this._size = size || (stride ? (stride / typeByteLength) : VertexBuffer.DeduceStride(kind));\r\n this.byteStride = stride || this._buffer.byteStride || (this._size * typeByteLength);\r\n this.byteOffset = offset || 0;\r\n }\r\n else {\r\n this._size = size || stride || VertexBuffer.DeduceStride(kind);\r\n this.byteStride = stride ? (stride * typeByteLength) : (this._buffer.byteStride || (this._size * typeByteLength));\r\n this.byteOffset = (offset || 0) * typeByteLength;\r\n }\r\n this.normalized = normalized;\r\n this._instanced = instanced !== undefined ? instanced : false;\r\n this._instanceDivisor = instanced ? divisor : 0;\r\n }\r\n Object.defineProperty(VertexBuffer.prototype, \"instanceDivisor\", {\r\n /**\r\n * Gets or sets the instance divisor when in instanced mode\r\n */\r\n get: function () {\r\n return this._instanceDivisor;\r\n },\r\n set: function (value) {\r\n this._instanceDivisor = value;\r\n if (value == 0) {\r\n this._instanced = false;\r\n }\r\n else {\r\n this._instanced = true;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n VertexBuffer.prototype._rebuild = function () {\r\n if (!this._buffer) {\r\n return;\r\n }\r\n this._buffer._rebuild();\r\n };\r\n /**\r\n * Returns the kind of the VertexBuffer (string)\r\n * @returns a string\r\n */\r\n VertexBuffer.prototype.getKind = function () {\r\n return this._kind;\r\n };\r\n // Properties\r\n /**\r\n * Gets a boolean indicating if the VertexBuffer is updatable?\r\n * @returns true if the buffer is updatable\r\n */\r\n VertexBuffer.prototype.isUpdatable = function () {\r\n return this._buffer.isUpdatable();\r\n };\r\n /**\r\n * Gets current buffer's data\r\n * @returns a DataArray or null\r\n */\r\n VertexBuffer.prototype.getData = function () {\r\n return this._buffer.getData();\r\n };\r\n /**\r\n * Gets underlying native buffer\r\n * @returns underlying native buffer\r\n */\r\n VertexBuffer.prototype.getBuffer = function () {\r\n return this._buffer.getBuffer();\r\n };\r\n /**\r\n * Gets the stride in float32 units (i.e. byte stride / 4).\r\n * May not be an integer if the byte stride is not divisible by 4.\r\n * @returns the stride in float32 units\r\n * @deprecated Please use byteStride instead.\r\n */\r\n VertexBuffer.prototype.getStrideSize = function () {\r\n return this.byteStride / VertexBuffer.GetTypeByteLength(this.type);\r\n };\r\n /**\r\n * Returns the offset as a multiple of the type byte length.\r\n * @returns the offset in bytes\r\n * @deprecated Please use byteOffset instead.\r\n */\r\n VertexBuffer.prototype.getOffset = function () {\r\n return this.byteOffset / VertexBuffer.GetTypeByteLength(this.type);\r\n };\r\n /**\r\n * Returns the number of components per vertex attribute (integer)\r\n * @returns the size in float\r\n */\r\n VertexBuffer.prototype.getSize = function () {\r\n return this._size;\r\n };\r\n /**\r\n * Gets a boolean indicating is the internal buffer of the VertexBuffer is instanced\r\n * @returns true if this buffer is instanced\r\n */\r\n VertexBuffer.prototype.getIsInstanced = function () {\r\n return this._instanced;\r\n };\r\n /**\r\n * Returns the instancing divisor, zero for non-instanced (integer).\r\n * @returns a number\r\n */\r\n VertexBuffer.prototype.getInstanceDivisor = function () {\r\n return this._instanceDivisor;\r\n };\r\n // Methods\r\n /**\r\n * Store data into the buffer. If the buffer was already used it will be either recreated or updated depending on isUpdatable property\r\n * @param data defines the data to store\r\n */\r\n VertexBuffer.prototype.create = function (data) {\r\n this._buffer.create(data);\r\n };\r\n /**\r\n * Updates the underlying buffer according to the passed numeric array or Float32Array.\r\n * This function will create a new buffer if the current one is not updatable\r\n * @param data defines the data to store\r\n */\r\n VertexBuffer.prototype.update = function (data) {\r\n this._buffer.update(data);\r\n };\r\n /**\r\n * Updates directly the underlying WebGLBuffer according to the passed numeric array or Float32Array.\r\n * Returns the directly updated WebGLBuffer.\r\n * @param data the new data\r\n * @param offset the new offset\r\n * @param useBytes set to true if the offset is in bytes\r\n */\r\n VertexBuffer.prototype.updateDirectly = function (data, offset, useBytes) {\r\n if (useBytes === void 0) { useBytes = false; }\r\n this._buffer.updateDirectly(data, offset, undefined, useBytes);\r\n };\r\n /**\r\n * Disposes the VertexBuffer and the underlying WebGLBuffer.\r\n */\r\n VertexBuffer.prototype.dispose = function () {\r\n if (this._ownsBuffer) {\r\n this._buffer.dispose();\r\n }\r\n };\r\n /**\r\n * Enumerates each value of this vertex buffer as numbers.\r\n * @param count the number of values to enumerate\r\n * @param callback the callback function called for each value\r\n */\r\n VertexBuffer.prototype.forEach = function (count, callback) {\r\n VertexBuffer.ForEach(this._buffer.getData(), this.byteOffset, this.byteStride, this._size, this.type, count, this.normalized, callback);\r\n };\r\n /**\r\n * Deduces the stride given a kind.\r\n * @param kind The kind string to deduce\r\n * @returns The deduced stride\r\n */\r\n VertexBuffer.DeduceStride = function (kind) {\r\n switch (kind) {\r\n case VertexBuffer.UVKind:\r\n case VertexBuffer.UV2Kind:\r\n case VertexBuffer.UV3Kind:\r\n case VertexBuffer.UV4Kind:\r\n case VertexBuffer.UV5Kind:\r\n case VertexBuffer.UV6Kind:\r\n return 2;\r\n case VertexBuffer.NormalKind:\r\n case VertexBuffer.PositionKind:\r\n return 3;\r\n case VertexBuffer.ColorKind:\r\n case VertexBuffer.MatricesIndicesKind:\r\n case VertexBuffer.MatricesIndicesExtraKind:\r\n case VertexBuffer.MatricesWeightsKind:\r\n case VertexBuffer.MatricesWeightsExtraKind:\r\n case VertexBuffer.TangentKind:\r\n return 4;\r\n default:\r\n throw new Error(\"Invalid kind '\" + kind + \"'\");\r\n }\r\n };\r\n /**\r\n * Gets the byte length of the given type.\r\n * @param type the type\r\n * @returns the number of bytes\r\n */\r\n VertexBuffer.GetTypeByteLength = function (type) {\r\n switch (type) {\r\n case VertexBuffer.BYTE:\r\n case VertexBuffer.UNSIGNED_BYTE:\r\n return 1;\r\n case VertexBuffer.SHORT:\r\n case VertexBuffer.UNSIGNED_SHORT:\r\n return 2;\r\n case VertexBuffer.INT:\r\n case VertexBuffer.UNSIGNED_INT:\r\n case VertexBuffer.FLOAT:\r\n return 4;\r\n default:\r\n throw new Error(\"Invalid type '\" + type + \"'\");\r\n }\r\n };\r\n /**\r\n * Enumerates each value of the given parameters as numbers.\r\n * @param data the data to enumerate\r\n * @param byteOffset the byte offset of the data\r\n * @param byteStride the byte stride of the data\r\n * @param componentCount the number of components per element\r\n * @param componentType the type of the component\r\n * @param count the number of values to enumerate\r\n * @param normalized whether the data is normalized\r\n * @param callback the callback function called for each value\r\n */\r\n VertexBuffer.ForEach = function (data, byteOffset, byteStride, componentCount, componentType, count, normalized, callback) {\r\n if (data instanceof Array) {\r\n var offset = byteOffset / 4;\r\n var stride = byteStride / 4;\r\n for (var index = 0; index < count; index += componentCount) {\r\n for (var componentIndex = 0; componentIndex < componentCount; componentIndex++) {\r\n callback(data[offset + componentIndex], index + componentIndex);\r\n }\r\n offset += stride;\r\n }\r\n }\r\n else {\r\n var dataView = data instanceof ArrayBuffer ? new DataView(data) : new DataView(data.buffer, data.byteOffset, data.byteLength);\r\n var componentByteLength = VertexBuffer.GetTypeByteLength(componentType);\r\n for (var index = 0; index < count; index += componentCount) {\r\n var componentByteOffset = byteOffset;\r\n for (var componentIndex = 0; componentIndex < componentCount; componentIndex++) {\r\n var value = VertexBuffer._GetFloatValue(dataView, componentType, componentByteOffset, normalized);\r\n callback(value, index + componentIndex);\r\n componentByteOffset += componentByteLength;\r\n }\r\n byteOffset += byteStride;\r\n }\r\n }\r\n };\r\n VertexBuffer._GetFloatValue = function (dataView, type, byteOffset, normalized) {\r\n switch (type) {\r\n case VertexBuffer.BYTE: {\r\n var value = dataView.getInt8(byteOffset);\r\n if (normalized) {\r\n value = Math.max(value / 127, -1);\r\n }\r\n return value;\r\n }\r\n case VertexBuffer.UNSIGNED_BYTE: {\r\n var value = dataView.getUint8(byteOffset);\r\n if (normalized) {\r\n value = value / 255;\r\n }\r\n return value;\r\n }\r\n case VertexBuffer.SHORT: {\r\n var value = dataView.getInt16(byteOffset, true);\r\n if (normalized) {\r\n value = Math.max(value / 32767, -1);\r\n }\r\n return value;\r\n }\r\n case VertexBuffer.UNSIGNED_SHORT: {\r\n var value = dataView.getUint16(byteOffset, true);\r\n if (normalized) {\r\n value = value / 65535;\r\n }\r\n return value;\r\n }\r\n case VertexBuffer.INT: {\r\n return dataView.getInt32(byteOffset, true);\r\n }\r\n case VertexBuffer.UNSIGNED_INT: {\r\n return dataView.getUint32(byteOffset, true);\r\n }\r\n case VertexBuffer.FLOAT: {\r\n return dataView.getFloat32(byteOffset, true);\r\n }\r\n default: {\r\n throw new Error(\"Invalid component type \" + type);\r\n }\r\n }\r\n };\r\n /**\r\n * The byte type.\r\n */\r\n VertexBuffer.BYTE = 5120;\r\n /**\r\n * The unsigned byte type.\r\n */\r\n VertexBuffer.UNSIGNED_BYTE = 5121;\r\n /**\r\n * The short type.\r\n */\r\n VertexBuffer.SHORT = 5122;\r\n /**\r\n * The unsigned short type.\r\n */\r\n VertexBuffer.UNSIGNED_SHORT = 5123;\r\n /**\r\n * The integer type.\r\n */\r\n VertexBuffer.INT = 5124;\r\n /**\r\n * The unsigned integer type.\r\n */\r\n VertexBuffer.UNSIGNED_INT = 5125;\r\n /**\r\n * The float type.\r\n */\r\n VertexBuffer.FLOAT = 5126;\r\n // Enums\r\n /**\r\n * Positions\r\n */\r\n VertexBuffer.PositionKind = \"position\";\r\n /**\r\n * Normals\r\n */\r\n VertexBuffer.NormalKind = \"normal\";\r\n /**\r\n * Tangents\r\n */\r\n VertexBuffer.TangentKind = \"tangent\";\r\n /**\r\n * Texture coordinates\r\n */\r\n VertexBuffer.UVKind = \"uv\";\r\n /**\r\n * Texture coordinates 2\r\n */\r\n VertexBuffer.UV2Kind = \"uv2\";\r\n /**\r\n * Texture coordinates 3\r\n */\r\n VertexBuffer.UV3Kind = \"uv3\";\r\n /**\r\n * Texture coordinates 4\r\n */\r\n VertexBuffer.UV4Kind = \"uv4\";\r\n /**\r\n * Texture coordinates 5\r\n */\r\n VertexBuffer.UV5Kind = \"uv5\";\r\n /**\r\n * Texture coordinates 6\r\n */\r\n VertexBuffer.UV6Kind = \"uv6\";\r\n /**\r\n * Colors\r\n */\r\n VertexBuffer.ColorKind = \"color\";\r\n /**\r\n * Matrix indices (for bones)\r\n */\r\n VertexBuffer.MatricesIndicesKind = \"matricesIndices\";\r\n /**\r\n * Matrix weights (for bones)\r\n */\r\n VertexBuffer.MatricesWeightsKind = \"matricesWeights\";\r\n /**\r\n * Additional matrix indices (for bones)\r\n */\r\n VertexBuffer.MatricesIndicesExtraKind = \"matricesIndicesExtra\";\r\n /**\r\n * Additional matrix weights (for bones)\r\n */\r\n VertexBuffer.MatricesWeightsExtraKind = \"matricesWeightsExtra\";\r\n return VertexBuffer;\r\n}());\r\nexport { VertexBuffer };\r\n//# sourceMappingURL=buffer.js.map","import { Tags } from \"../Misc/tags\";\r\nimport { Quaternion, Vector2, Vector3, Matrix } from \"../Maths/math.vector\";\r\nimport { _DevTools } from './devTools';\r\nimport { Color4, Color3 } from '../Maths/math.color';\r\nvar __decoratorInitialStore = {};\r\nvar __mergedStore = {};\r\nvar _copySource = function (creationFunction, source, instanciate) {\r\n var destination = creationFunction();\r\n // Tags\r\n if (Tags) {\r\n Tags.AddTagsTo(destination, source.tags);\r\n }\r\n var classStore = getMergedStore(destination);\r\n // Properties\r\n for (var property in classStore) {\r\n var propertyDescriptor = classStore[property];\r\n var sourceProperty = source[property];\r\n var propertyType = propertyDescriptor.type;\r\n if (sourceProperty !== undefined && sourceProperty !== null && property !== \"uniqueId\") {\r\n switch (propertyType) {\r\n case 0: // Value\r\n case 6: // Mesh reference\r\n case 11: // Camera reference\r\n destination[property] = sourceProperty;\r\n break;\r\n case 1: // Texture\r\n destination[property] = (instanciate || sourceProperty.isRenderTarget) ? sourceProperty : sourceProperty.clone();\r\n break;\r\n case 2: // Color3\r\n case 3: // FresnelParameters\r\n case 4: // Vector2\r\n case 5: // Vector3\r\n case 7: // Color Curves\r\n case 10: // Quaternion\r\n case 12: // Matrix\r\n destination[property] = instanciate ? sourceProperty : sourceProperty.clone();\r\n break;\r\n }\r\n }\r\n }\r\n return destination;\r\n};\r\nfunction getDirectStore(target) {\r\n var classKey = target.getClassName();\r\n if (!__decoratorInitialStore[classKey]) {\r\n __decoratorInitialStore[classKey] = {};\r\n }\r\n return __decoratorInitialStore[classKey];\r\n}\r\n/**\r\n * Return the list of properties flagged as serializable\r\n * @param target: host object\r\n */\r\nfunction getMergedStore(target) {\r\n var classKey = target.getClassName();\r\n if (__mergedStore[classKey]) {\r\n return __mergedStore[classKey];\r\n }\r\n __mergedStore[classKey] = {};\r\n var store = __mergedStore[classKey];\r\n var currentTarget = target;\r\n var currentKey = classKey;\r\n while (currentKey) {\r\n var initialStore = __decoratorInitialStore[currentKey];\r\n for (var property in initialStore) {\r\n store[property] = initialStore[property];\r\n }\r\n var parent_1 = void 0;\r\n var done = false;\r\n do {\r\n parent_1 = Object.getPrototypeOf(currentTarget);\r\n if (!parent_1.getClassName) {\r\n done = true;\r\n break;\r\n }\r\n if (parent_1.getClassName() !== currentKey) {\r\n break;\r\n }\r\n currentTarget = parent_1;\r\n } while (parent_1);\r\n if (done) {\r\n break;\r\n }\r\n currentKey = parent_1.getClassName();\r\n currentTarget = parent_1;\r\n }\r\n return store;\r\n}\r\nfunction generateSerializableMember(type, sourceName) {\r\n return function (target, propertyKey) {\r\n var classStore = getDirectStore(target);\r\n if (!classStore[propertyKey]) {\r\n classStore[propertyKey] = { type: type, sourceName: sourceName };\r\n }\r\n };\r\n}\r\nfunction generateExpandMember(setCallback, targetKey) {\r\n if (targetKey === void 0) { targetKey = null; }\r\n return function (target, propertyKey) {\r\n var key = targetKey || (\"_\" + propertyKey);\r\n Object.defineProperty(target, propertyKey, {\r\n get: function () {\r\n return this[key];\r\n },\r\n set: function (value) {\r\n if (this[key] === value) {\r\n return;\r\n }\r\n this[key] = value;\r\n target[setCallback].apply(this);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n };\r\n}\r\nexport function expandToProperty(callback, targetKey) {\r\n if (targetKey === void 0) { targetKey = null; }\r\n return generateExpandMember(callback, targetKey);\r\n}\r\nexport function serialize(sourceName) {\r\n return generateSerializableMember(0, sourceName); // value member\r\n}\r\nexport function serializeAsTexture(sourceName) {\r\n return generateSerializableMember(1, sourceName); // texture member\r\n}\r\nexport function serializeAsColor3(sourceName) {\r\n return generateSerializableMember(2, sourceName); // color3 member\r\n}\r\nexport function serializeAsFresnelParameters(sourceName) {\r\n return generateSerializableMember(3, sourceName); // fresnel parameters member\r\n}\r\nexport function serializeAsVector2(sourceName) {\r\n return generateSerializableMember(4, sourceName); // vector2 member\r\n}\r\nexport function serializeAsVector3(sourceName) {\r\n return generateSerializableMember(5, sourceName); // vector3 member\r\n}\r\nexport function serializeAsMeshReference(sourceName) {\r\n return generateSerializableMember(6, sourceName); // mesh reference member\r\n}\r\nexport function serializeAsColorCurves(sourceName) {\r\n return generateSerializableMember(7, sourceName); // color curves\r\n}\r\nexport function serializeAsColor4(sourceName) {\r\n return generateSerializableMember(8, sourceName); // color 4\r\n}\r\nexport function serializeAsImageProcessingConfiguration(sourceName) {\r\n return generateSerializableMember(9, sourceName); // image processing\r\n}\r\nexport function serializeAsQuaternion(sourceName) {\r\n return generateSerializableMember(10, sourceName); // quaternion member\r\n}\r\nexport function serializeAsMatrix(sourceName) {\r\n return generateSerializableMember(12, sourceName); // matrix member\r\n}\r\n/**\r\n * Decorator used to define property that can be serialized as reference to a camera\r\n * @param sourceName defines the name of the property to decorate\r\n */\r\nexport function serializeAsCameraReference(sourceName) {\r\n return generateSerializableMember(11, sourceName); // camera reference member\r\n}\r\n/**\r\n * Class used to help serialization objects\r\n */\r\nvar SerializationHelper = /** @class */ (function () {\r\n function SerializationHelper() {\r\n }\r\n /**\r\n * Appends the serialized animations from the source animations\r\n * @param source Source containing the animations\r\n * @param destination Target to store the animations\r\n */\r\n SerializationHelper.AppendSerializedAnimations = function (source, destination) {\r\n if (source.animations) {\r\n destination.animations = [];\r\n for (var animationIndex = 0; animationIndex < source.animations.length; animationIndex++) {\r\n var animation = source.animations[animationIndex];\r\n destination.animations.push(animation.serialize());\r\n }\r\n }\r\n };\r\n /**\r\n * Static function used to serialized a specific entity\r\n * @param entity defines the entity to serialize\r\n * @param serializationObject defines the optional target obecjt where serialization data will be stored\r\n * @returns a JSON compatible object representing the serialization of the entity\r\n */\r\n SerializationHelper.Serialize = function (entity, serializationObject) {\r\n if (!serializationObject) {\r\n serializationObject = {};\r\n }\r\n // Tags\r\n if (Tags) {\r\n serializationObject.tags = Tags.GetTags(entity);\r\n }\r\n var serializedProperties = getMergedStore(entity);\r\n // Properties\r\n for (var property in serializedProperties) {\r\n var propertyDescriptor = serializedProperties[property];\r\n var targetPropertyName = propertyDescriptor.sourceName || property;\r\n var propertyType = propertyDescriptor.type;\r\n var sourceProperty = entity[property];\r\n if (sourceProperty !== undefined && sourceProperty !== null) {\r\n switch (propertyType) {\r\n case 0: // Value\r\n serializationObject[targetPropertyName] = sourceProperty;\r\n break;\r\n case 1: // Texture\r\n serializationObject[targetPropertyName] = sourceProperty.serialize();\r\n break;\r\n case 2: // Color3\r\n serializationObject[targetPropertyName] = sourceProperty.asArray();\r\n break;\r\n case 3: // FresnelParameters\r\n serializationObject[targetPropertyName] = sourceProperty.serialize();\r\n break;\r\n case 4: // Vector2\r\n serializationObject[targetPropertyName] = sourceProperty.asArray();\r\n break;\r\n case 5: // Vector3\r\n serializationObject[targetPropertyName] = sourceProperty.asArray();\r\n break;\r\n case 6: // Mesh reference\r\n serializationObject[targetPropertyName] = sourceProperty.id;\r\n break;\r\n case 7: // Color Curves\r\n serializationObject[targetPropertyName] = sourceProperty.serialize();\r\n break;\r\n case 8: // Color 4\r\n serializationObject[targetPropertyName] = sourceProperty.asArray();\r\n break;\r\n case 9: // Image Processing\r\n serializationObject[targetPropertyName] = sourceProperty.serialize();\r\n break;\r\n case 10: // Quaternion\r\n serializationObject[targetPropertyName] = sourceProperty.asArray();\r\n break;\r\n case 11: // Camera reference\r\n serializationObject[targetPropertyName] = sourceProperty.id;\r\n case 12: // Matrix\r\n serializationObject[targetPropertyName] = sourceProperty.asArray();\r\n break;\r\n }\r\n }\r\n }\r\n return serializationObject;\r\n };\r\n /**\r\n * Creates a new entity from a serialization data object\r\n * @param creationFunction defines a function used to instanciated the new entity\r\n * @param source defines the source serialization data\r\n * @param scene defines the hosting scene\r\n * @param rootUrl defines the root url for resources\r\n * @returns a new entity\r\n */\r\n SerializationHelper.Parse = function (creationFunction, source, scene, rootUrl) {\r\n if (rootUrl === void 0) { rootUrl = null; }\r\n var destination = creationFunction();\r\n if (!rootUrl) {\r\n rootUrl = \"\";\r\n }\r\n // Tags\r\n if (Tags) {\r\n Tags.AddTagsTo(destination, source.tags);\r\n }\r\n var classStore = getMergedStore(destination);\r\n // Properties\r\n for (var property in classStore) {\r\n var propertyDescriptor = classStore[property];\r\n var sourceProperty = source[propertyDescriptor.sourceName || property];\r\n var propertyType = propertyDescriptor.type;\r\n if (sourceProperty !== undefined && sourceProperty !== null) {\r\n var dest = destination;\r\n switch (propertyType) {\r\n case 0: // Value\r\n dest[property] = sourceProperty;\r\n break;\r\n case 1: // Texture\r\n if (scene) {\r\n dest[property] = SerializationHelper._TextureParser(sourceProperty, scene, rootUrl);\r\n }\r\n break;\r\n case 2: // Color3\r\n dest[property] = Color3.FromArray(sourceProperty);\r\n break;\r\n case 3: // FresnelParameters\r\n dest[property] = SerializationHelper._FresnelParametersParser(sourceProperty);\r\n break;\r\n case 4: // Vector2\r\n dest[property] = Vector2.FromArray(sourceProperty);\r\n break;\r\n case 5: // Vector3\r\n dest[property] = Vector3.FromArray(sourceProperty);\r\n break;\r\n case 6: // Mesh reference\r\n if (scene) {\r\n dest[property] = scene.getLastMeshByID(sourceProperty);\r\n }\r\n break;\r\n case 7: // Color Curves\r\n dest[property] = SerializationHelper._ColorCurvesParser(sourceProperty);\r\n break;\r\n case 8: // Color 4\r\n dest[property] = Color4.FromArray(sourceProperty);\r\n break;\r\n case 9: // Image Processing\r\n dest[property] = SerializationHelper._ImageProcessingConfigurationParser(sourceProperty);\r\n break;\r\n case 10: // Quaternion\r\n dest[property] = Quaternion.FromArray(sourceProperty);\r\n break;\r\n case 11: // Camera reference\r\n if (scene) {\r\n dest[property] = scene.getCameraByID(sourceProperty);\r\n }\r\n case 12: // Matrix\r\n dest[property] = Matrix.FromArray(sourceProperty);\r\n break;\r\n }\r\n }\r\n }\r\n return destination;\r\n };\r\n /**\r\n * Clones an object\r\n * @param creationFunction defines the function used to instanciate the new object\r\n * @param source defines the source object\r\n * @returns the cloned object\r\n */\r\n SerializationHelper.Clone = function (creationFunction, source) {\r\n return _copySource(creationFunction, source, false);\r\n };\r\n /**\r\n * Instanciates a new object based on a source one (some data will be shared between both object)\r\n * @param creationFunction defines the function used to instanciate the new object\r\n * @param source defines the source object\r\n * @returns the new object\r\n */\r\n SerializationHelper.Instanciate = function (creationFunction, source) {\r\n return _copySource(creationFunction, source, true);\r\n };\r\n /** @hidden */\r\n SerializationHelper._ImageProcessingConfigurationParser = function (sourceProperty) {\r\n throw _DevTools.WarnImport(\"ImageProcessingConfiguration\");\r\n };\r\n /** @hidden */\r\n SerializationHelper._FresnelParametersParser = function (sourceProperty) {\r\n throw _DevTools.WarnImport(\"FresnelParameters\");\r\n };\r\n /** @hidden */\r\n SerializationHelper._ColorCurvesParser = function (sourceProperty) {\r\n throw _DevTools.WarnImport(\"ColorCurves\");\r\n };\r\n /** @hidden */\r\n SerializationHelper._TextureParser = function (sourceProperty, scene, rootUrl) {\r\n throw _DevTools.WarnImport(\"Texture\");\r\n };\r\n return SerializationHelper;\r\n}());\r\nexport { SerializationHelper };\r\n//# sourceMappingURL=decorators.js.map","/**\r\n * A class serves as a medium between the observable and its observers\r\n */\r\nvar EventState = /** @class */ (function () {\r\n /**\r\n * Create a new EventState\r\n * @param mask defines the mask associated with this state\r\n * @param skipNextObservers defines a flag which will instruct the observable to skip following observers when set to true\r\n * @param target defines the original target of the state\r\n * @param currentTarget defines the current target of the state\r\n */\r\n function EventState(mask, skipNextObservers, target, currentTarget) {\r\n if (skipNextObservers === void 0) { skipNextObservers = false; }\r\n this.initalize(mask, skipNextObservers, target, currentTarget);\r\n }\r\n /**\r\n * Initialize the current event state\r\n * @param mask defines the mask associated with this state\r\n * @param skipNextObservers defines a flag which will instruct the observable to skip following observers when set to true\r\n * @param target defines the original target of the state\r\n * @param currentTarget defines the current target of the state\r\n * @returns the current event state\r\n */\r\n EventState.prototype.initalize = function (mask, skipNextObservers, target, currentTarget) {\r\n if (skipNextObservers === void 0) { skipNextObservers = false; }\r\n this.mask = mask;\r\n this.skipNextObservers = skipNextObservers;\r\n this.target = target;\r\n this.currentTarget = currentTarget;\r\n return this;\r\n };\r\n return EventState;\r\n}());\r\nexport { EventState };\r\n/**\r\n * Represent an Observer registered to a given Observable object.\r\n */\r\nvar Observer = /** @class */ (function () {\r\n /**\r\n * Creates a new observer\r\n * @param callback defines the callback to call when the observer is notified\r\n * @param mask defines the mask of the observer (used to filter notifications)\r\n * @param scope defines the current scope used to restore the JS context\r\n */\r\n function Observer(\r\n /**\r\n * Defines the callback to call when the observer is notified\r\n */\r\n callback, \r\n /**\r\n * Defines the mask of the observer (used to filter notifications)\r\n */\r\n mask, \r\n /**\r\n * Defines the current scope used to restore the JS context\r\n */\r\n scope) {\r\n if (scope === void 0) { scope = null; }\r\n this.callback = callback;\r\n this.mask = mask;\r\n this.scope = scope;\r\n /** @hidden */\r\n this._willBeUnregistered = false;\r\n /**\r\n * Gets or sets a property defining that the observer as to be unregistered after the next notification\r\n */\r\n this.unregisterOnNextCall = false;\r\n }\r\n return Observer;\r\n}());\r\nexport { Observer };\r\n/**\r\n * Represent a list of observers registered to multiple Observables object.\r\n */\r\nvar MultiObserver = /** @class */ (function () {\r\n function MultiObserver() {\r\n }\r\n /**\r\n * Release associated resources\r\n */\r\n MultiObserver.prototype.dispose = function () {\r\n if (this._observers && this._observables) {\r\n for (var index = 0; index < this._observers.length; index++) {\r\n this._observables[index].remove(this._observers[index]);\r\n }\r\n }\r\n this._observers = null;\r\n this._observables = null;\r\n };\r\n /**\r\n * Raise a callback when one of the observable will notify\r\n * @param observables defines a list of observables to watch\r\n * @param callback defines the callback to call on notification\r\n * @param mask defines the mask used to filter notifications\r\n * @param scope defines the current scope used to restore the JS context\r\n * @returns the new MultiObserver\r\n */\r\n MultiObserver.Watch = function (observables, callback, mask, scope) {\r\n if (mask === void 0) { mask = -1; }\r\n if (scope === void 0) { scope = null; }\r\n var result = new MultiObserver();\r\n result._observers = new Array();\r\n result._observables = observables;\r\n for (var _i = 0, observables_1 = observables; _i < observables_1.length; _i++) {\r\n var observable = observables_1[_i];\r\n var observer = observable.add(callback, mask, false, scope);\r\n if (observer) {\r\n result._observers.push(observer);\r\n }\r\n }\r\n return result;\r\n };\r\n return MultiObserver;\r\n}());\r\nexport { MultiObserver };\r\n/**\r\n * The Observable class is a simple implementation of the Observable pattern.\r\n *\r\n * There's one slight particularity though: a given Observable can notify its observer using a particular mask value, only the Observers registered with this mask value will be notified.\r\n * This enable a more fine grained execution without having to rely on multiple different Observable objects.\r\n * For instance you may have a given Observable that have four different types of notifications: Move (mask = 0x01), Stop (mask = 0x02), Turn Right (mask = 0X04), Turn Left (mask = 0X08).\r\n * A given observer can register itself with only Move and Stop (mask = 0x03), then it will only be notified when one of these two occurs and will never be for Turn Left/Right.\r\n */\r\nvar Observable = /** @class */ (function () {\r\n /**\r\n * Creates a new observable\r\n * @param onObserverAdded defines a callback to call when a new observer is added\r\n */\r\n function Observable(onObserverAdded) {\r\n this._observers = new Array();\r\n this._eventState = new EventState(0);\r\n if (onObserverAdded) {\r\n this._onObserverAdded = onObserverAdded;\r\n }\r\n }\r\n Object.defineProperty(Observable.prototype, \"observers\", {\r\n /**\r\n * Gets the list of observers\r\n */\r\n get: function () {\r\n return this._observers;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Create a new Observer with the specified callback\r\n * @param callback the callback that will be executed for that Observer\r\n * @param mask the mask used to filter observers\r\n * @param insertFirst if true the callback will be inserted at the first position, hence executed before the others ones. If false (default behavior) the callback will be inserted at the last position, executed after all the others already present.\r\n * @param scope optional scope for the callback to be called from\r\n * @param unregisterOnFirstCall defines if the observer as to be unregistered after the next notification\r\n * @returns the new observer created for the callback\r\n */\r\n Observable.prototype.add = function (callback, mask, insertFirst, scope, unregisterOnFirstCall) {\r\n if (mask === void 0) { mask = -1; }\r\n if (insertFirst === void 0) { insertFirst = false; }\r\n if (scope === void 0) { scope = null; }\r\n if (unregisterOnFirstCall === void 0) { unregisterOnFirstCall = false; }\r\n if (!callback) {\r\n return null;\r\n }\r\n var observer = new Observer(callback, mask, scope);\r\n observer.unregisterOnNextCall = unregisterOnFirstCall;\r\n if (insertFirst) {\r\n this._observers.unshift(observer);\r\n }\r\n else {\r\n this._observers.push(observer);\r\n }\r\n if (this._onObserverAdded) {\r\n this._onObserverAdded(observer);\r\n }\r\n return observer;\r\n };\r\n /**\r\n * Create a new Observer with the specified callback and unregisters after the next notification\r\n * @param callback the callback that will be executed for that Observer\r\n * @returns the new observer created for the callback\r\n */\r\n Observable.prototype.addOnce = function (callback) {\r\n return this.add(callback, undefined, undefined, undefined, true);\r\n };\r\n /**\r\n * Remove an Observer from the Observable object\r\n * @param observer the instance of the Observer to remove\r\n * @returns false if it doesn't belong to this Observable\r\n */\r\n Observable.prototype.remove = function (observer) {\r\n if (!observer) {\r\n return false;\r\n }\r\n var index = this._observers.indexOf(observer);\r\n if (index !== -1) {\r\n this._deferUnregister(observer);\r\n return true;\r\n }\r\n return false;\r\n };\r\n /**\r\n * Remove a callback from the Observable object\r\n * @param callback the callback to remove\r\n * @param scope optional scope. If used only the callbacks with this scope will be removed\r\n * @returns false if it doesn't belong to this Observable\r\n */\r\n Observable.prototype.removeCallback = function (callback, scope) {\r\n for (var index = 0; index < this._observers.length; index++) {\r\n var observer = this._observers[index];\r\n if (observer._willBeUnregistered) {\r\n continue;\r\n }\r\n if (observer.callback === callback && (!scope || scope === observer.scope)) {\r\n this._deferUnregister(observer);\r\n return true;\r\n }\r\n }\r\n return false;\r\n };\r\n Observable.prototype._deferUnregister = function (observer) {\r\n var _this = this;\r\n observer.unregisterOnNextCall = false;\r\n observer._willBeUnregistered = true;\r\n setTimeout(function () {\r\n _this._remove(observer);\r\n }, 0);\r\n };\r\n // This should only be called when not iterating over _observers to avoid callback skipping.\r\n // Removes an observer from the _observer Array.\r\n Observable.prototype._remove = function (observer) {\r\n if (!observer) {\r\n return false;\r\n }\r\n var index = this._observers.indexOf(observer);\r\n if (index !== -1) {\r\n this._observers.splice(index, 1);\r\n return true;\r\n }\r\n return false;\r\n };\r\n /**\r\n * Moves the observable to the top of the observer list making it get called first when notified\r\n * @param observer the observer to move\r\n */\r\n Observable.prototype.makeObserverTopPriority = function (observer) {\r\n this._remove(observer);\r\n this._observers.unshift(observer);\r\n };\r\n /**\r\n * Moves the observable to the bottom of the observer list making it get called last when notified\r\n * @param observer the observer to move\r\n */\r\n Observable.prototype.makeObserverBottomPriority = function (observer) {\r\n this._remove(observer);\r\n this._observers.push(observer);\r\n };\r\n /**\r\n * Notify all Observers by calling their respective callback with the given data\r\n * Will return true if all observers were executed, false if an observer set skipNextObservers to true, then prevent the subsequent ones to execute\r\n * @param eventData defines the data to send to all observers\r\n * @param mask defines the mask of the current notification (observers with incompatible mask (ie mask & observer.mask === 0) will not be notified)\r\n * @param target defines the original target of the state\r\n * @param currentTarget defines the current target of the state\r\n * @returns false if the complete observer chain was not processed (because one observer set the skipNextObservers to true)\r\n */\r\n Observable.prototype.notifyObservers = function (eventData, mask, target, currentTarget) {\r\n if (mask === void 0) { mask = -1; }\r\n if (!this._observers.length) {\r\n return true;\r\n }\r\n var state = this._eventState;\r\n state.mask = mask;\r\n state.target = target;\r\n state.currentTarget = currentTarget;\r\n state.skipNextObservers = false;\r\n state.lastReturnValue = eventData;\r\n for (var _i = 0, _a = this._observers; _i < _a.length; _i++) {\r\n var obs = _a[_i];\r\n if (obs._willBeUnregistered) {\r\n continue;\r\n }\r\n if (obs.mask & mask) {\r\n if (obs.scope) {\r\n state.lastReturnValue = obs.callback.apply(obs.scope, [eventData, state]);\r\n }\r\n else {\r\n state.lastReturnValue = obs.callback(eventData, state);\r\n }\r\n if (obs.unregisterOnNextCall) {\r\n this._deferUnregister(obs);\r\n }\r\n }\r\n if (state.skipNextObservers) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Calling this will execute each callback, expecting it to be a promise or return a value.\r\n * If at any point in the chain one function fails, the promise will fail and the execution will not continue.\r\n * This is useful when a chain of events (sometimes async events) is needed to initialize a certain object\r\n * and it is crucial that all callbacks will be executed.\r\n * The order of the callbacks is kept, callbacks are not executed parallel.\r\n *\r\n * @param eventData The data to be sent to each callback\r\n * @param mask is used to filter observers defaults to -1\r\n * @param target defines the callback target (see EventState)\r\n * @param currentTarget defines he current object in the bubbling phase\r\n * @returns {Promise} will return a Promise than resolves when all callbacks executed successfully.\r\n */\r\n Observable.prototype.notifyObserversWithPromise = function (eventData, mask, target, currentTarget) {\r\n var _this = this;\r\n if (mask === void 0) { mask = -1; }\r\n // create an empty promise\r\n var p = Promise.resolve(eventData);\r\n // no observers? return this promise.\r\n if (!this._observers.length) {\r\n return p;\r\n }\r\n var state = this._eventState;\r\n state.mask = mask;\r\n state.target = target;\r\n state.currentTarget = currentTarget;\r\n state.skipNextObservers = false;\r\n // execute one callback after another (not using Promise.all, the order is important)\r\n this._observers.forEach(function (obs) {\r\n if (state.skipNextObservers) {\r\n return;\r\n }\r\n if (obs._willBeUnregistered) {\r\n return;\r\n }\r\n if (obs.mask & mask) {\r\n if (obs.scope) {\r\n p = p.then(function (lastReturnedValue) {\r\n state.lastReturnValue = lastReturnedValue;\r\n return obs.callback.apply(obs.scope, [eventData, state]);\r\n });\r\n }\r\n else {\r\n p = p.then(function (lastReturnedValue) {\r\n state.lastReturnValue = lastReturnedValue;\r\n return obs.callback(eventData, state);\r\n });\r\n }\r\n if (obs.unregisterOnNextCall) {\r\n _this._deferUnregister(obs);\r\n }\r\n }\r\n });\r\n // return the eventData\r\n return p.then(function () { return eventData; });\r\n };\r\n /**\r\n * Notify a specific observer\r\n * @param observer defines the observer to notify\r\n * @param eventData defines the data to be sent to each callback\r\n * @param mask is used to filter observers defaults to -1\r\n */\r\n Observable.prototype.notifyObserver = function (observer, eventData, mask) {\r\n if (mask === void 0) { mask = -1; }\r\n var state = this._eventState;\r\n state.mask = mask;\r\n state.skipNextObservers = false;\r\n observer.callback(eventData, state);\r\n };\r\n /**\r\n * Gets a boolean indicating if the observable has at least one observer\r\n * @returns true is the Observable has at least one Observer registered\r\n */\r\n Observable.prototype.hasObservers = function () {\r\n return this._observers.length > 0;\r\n };\r\n /**\r\n * Clear the list of observers\r\n */\r\n Observable.prototype.clear = function () {\r\n this._observers = new Array();\r\n this._onObserverAdded = null;\r\n };\r\n /**\r\n * Clone the current observable\r\n * @returns a new observable\r\n */\r\n Observable.prototype.clone = function () {\r\n var result = new Observable();\r\n result._observers = this._observers.slice(0);\r\n return result;\r\n };\r\n /**\r\n * Does this observable handles observer registered with a given mask\r\n * @param mask defines the mask to be tested\r\n * @return whether or not one observer registered with the given mask is handeled\r\n **/\r\n Observable.prototype.hasSpecificMask = function (mask) {\r\n if (mask === void 0) { mask = -1; }\r\n for (var _i = 0, _a = this._observers; _i < _a.length; _i++) {\r\n var obs = _a[_i];\r\n if (obs.mask & mask || obs.mask === mask) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n };\r\n return Observable;\r\n}());\r\nexport { Observable };\r\n//# sourceMappingURL=observable.js.map","import { __extends } from \"tslib\";\r\nimport { Vector2 } from \"@babylonjs/core/Maths/math.vector\";\r\nimport { Epsilon } from '@babylonjs/core/Maths/math.constants';\r\n/**\r\n * Class used to transport Vector2 information for pointer events\r\n */\r\nvar Vector2WithInfo = /** @class */ (function (_super) {\r\n __extends(Vector2WithInfo, _super);\r\n /**\r\n * Creates a new Vector2WithInfo\r\n * @param source defines the vector2 data to transport\r\n * @param buttonIndex defines the current mouse button index\r\n */\r\n function Vector2WithInfo(source, \r\n /** defines the current mouse button index */\r\n buttonIndex) {\r\n if (buttonIndex === void 0) { buttonIndex = 0; }\r\n var _this = _super.call(this, source.x, source.y) || this;\r\n _this.buttonIndex = buttonIndex;\r\n return _this;\r\n }\r\n return Vector2WithInfo;\r\n}(Vector2));\r\nexport { Vector2WithInfo };\r\n/** Class used to provide 2D matrix features */\r\nvar Matrix2D = /** @class */ (function () {\r\n /**\r\n * Creates a new matrix\r\n * @param m00 defines value for (0, 0)\r\n * @param m01 defines value for (0, 1)\r\n * @param m10 defines value for (1, 0)\r\n * @param m11 defines value for (1, 1)\r\n * @param m20 defines value for (2, 0)\r\n * @param m21 defines value for (2, 1)\r\n */\r\n function Matrix2D(m00, m01, m10, m11, m20, m21) {\r\n /** Gets the internal array of 6 floats used to store matrix data */\r\n this.m = new Float32Array(6);\r\n this.fromValues(m00, m01, m10, m11, m20, m21);\r\n }\r\n /**\r\n * Fills the matrix from direct values\r\n * @param m00 defines value for (0, 0)\r\n * @param m01 defines value for (0, 1)\r\n * @param m10 defines value for (1, 0)\r\n * @param m11 defines value for (1, 1)\r\n * @param m20 defines value for (2, 0)\r\n * @param m21 defines value for (2, 1)\r\n * @returns the current modified matrix\r\n */\r\n Matrix2D.prototype.fromValues = function (m00, m01, m10, m11, m20, m21) {\r\n this.m[0] = m00;\r\n this.m[1] = m01;\r\n this.m[2] = m10;\r\n this.m[3] = m11;\r\n this.m[4] = m20;\r\n this.m[5] = m21;\r\n return this;\r\n };\r\n /**\r\n * Gets matrix determinant\r\n * @returns the determinant\r\n */\r\n Matrix2D.prototype.determinant = function () {\r\n return this.m[0] * this.m[3] - this.m[1] * this.m[2];\r\n };\r\n /**\r\n * Inverses the matrix and stores it in a target matrix\r\n * @param result defines the target matrix\r\n * @returns the current matrix\r\n */\r\n Matrix2D.prototype.invertToRef = function (result) {\r\n var l0 = this.m[0];\r\n var l1 = this.m[1];\r\n var l2 = this.m[2];\r\n var l3 = this.m[3];\r\n var l4 = this.m[4];\r\n var l5 = this.m[5];\r\n var det = this.determinant();\r\n if (det < (Epsilon * Epsilon)) {\r\n result.m[0] = 0;\r\n result.m[1] = 0;\r\n result.m[2] = 0;\r\n result.m[3] = 0;\r\n result.m[4] = 0;\r\n result.m[5] = 0;\r\n return this;\r\n }\r\n var detDiv = 1 / det;\r\n var det4 = l2 * l5 - l3 * l4;\r\n var det5 = l1 * l4 - l0 * l5;\r\n result.m[0] = l3 * detDiv;\r\n result.m[1] = -l1 * detDiv;\r\n result.m[2] = -l2 * detDiv;\r\n result.m[3] = l0 * detDiv;\r\n result.m[4] = det4 * detDiv;\r\n result.m[5] = det5 * detDiv;\r\n return this;\r\n };\r\n /**\r\n * Multiplies the current matrix with another one\r\n * @param other defines the second operand\r\n * @param result defines the target matrix\r\n * @returns the current matrix\r\n */\r\n Matrix2D.prototype.multiplyToRef = function (other, result) {\r\n var l0 = this.m[0];\r\n var l1 = this.m[1];\r\n var l2 = this.m[2];\r\n var l3 = this.m[3];\r\n var l4 = this.m[4];\r\n var l5 = this.m[5];\r\n var r0 = other.m[0];\r\n var r1 = other.m[1];\r\n var r2 = other.m[2];\r\n var r3 = other.m[3];\r\n var r4 = other.m[4];\r\n var r5 = other.m[5];\r\n result.m[0] = l0 * r0 + l1 * r2;\r\n result.m[1] = l0 * r1 + l1 * r3;\r\n result.m[2] = l2 * r0 + l3 * r2;\r\n result.m[3] = l2 * r1 + l3 * r3;\r\n result.m[4] = l4 * r0 + l5 * r2 + r4;\r\n result.m[5] = l4 * r1 + l5 * r3 + r5;\r\n return this;\r\n };\r\n /**\r\n * Applies the current matrix to a set of 2 floats and stores the result in a vector2\r\n * @param x defines the x coordinate to transform\r\n * @param y defines the x coordinate to transform\r\n * @param result defines the target vector2\r\n * @returns the current matrix\r\n */\r\n Matrix2D.prototype.transformCoordinates = function (x, y, result) {\r\n result.x = x * this.m[0] + y * this.m[2] + this.m[4];\r\n result.y = x * this.m[1] + y * this.m[3] + this.m[5];\r\n return this;\r\n };\r\n // Statics\r\n /**\r\n * Creates an identity matrix\r\n * @returns a new matrix\r\n */\r\n Matrix2D.Identity = function () {\r\n return new Matrix2D(1, 0, 0, 1, 0, 0);\r\n };\r\n /**\r\n * Creates a translation matrix and stores it in a target matrix\r\n * @param x defines the x coordinate of the translation\r\n * @param y defines the y coordinate of the translation\r\n * @param result defines the target matrix\r\n */\r\n Matrix2D.TranslationToRef = function (x, y, result) {\r\n result.fromValues(1, 0, 0, 1, x, y);\r\n };\r\n /**\r\n * Creates a scaling matrix and stores it in a target matrix\r\n * @param x defines the x coordinate of the scaling\r\n * @param y defines the y coordinate of the scaling\r\n * @param result defines the target matrix\r\n */\r\n Matrix2D.ScalingToRef = function (x, y, result) {\r\n result.fromValues(x, 0, 0, y, 0, 0);\r\n };\r\n /**\r\n * Creates a rotation matrix and stores it in a target matrix\r\n * @param angle defines the rotation angle\r\n * @param result defines the target matrix\r\n */\r\n Matrix2D.RotationToRef = function (angle, result) {\r\n var s = Math.sin(angle);\r\n var c = Math.cos(angle);\r\n result.fromValues(c, s, -s, c, 0, 0);\r\n };\r\n /**\r\n * Composes a matrix from translation, rotation, scaling and parent matrix and stores it in a target matrix\r\n * @param tx defines the x coordinate of the translation\r\n * @param ty defines the y coordinate of the translation\r\n * @param angle defines the rotation angle\r\n * @param scaleX defines the x coordinate of the scaling\r\n * @param scaleY defines the y coordinate of the scaling\r\n * @param parentMatrix defines the parent matrix to multiply by (can be null)\r\n * @param result defines the target matrix\r\n */\r\n Matrix2D.ComposeToRef = function (tx, ty, angle, scaleX, scaleY, parentMatrix, result) {\r\n Matrix2D.TranslationToRef(tx, ty, Matrix2D._TempPreTranslationMatrix);\r\n Matrix2D.ScalingToRef(scaleX, scaleY, Matrix2D._TempScalingMatrix);\r\n Matrix2D.RotationToRef(angle, Matrix2D._TempRotationMatrix);\r\n Matrix2D.TranslationToRef(-tx, -ty, Matrix2D._TempPostTranslationMatrix);\r\n Matrix2D._TempPreTranslationMatrix.multiplyToRef(Matrix2D._TempScalingMatrix, Matrix2D._TempCompose0);\r\n Matrix2D._TempCompose0.multiplyToRef(Matrix2D._TempRotationMatrix, Matrix2D._TempCompose1);\r\n if (parentMatrix) {\r\n Matrix2D._TempCompose1.multiplyToRef(Matrix2D._TempPostTranslationMatrix, Matrix2D._TempCompose2);\r\n Matrix2D._TempCompose2.multiplyToRef(parentMatrix, result);\r\n }\r\n else {\r\n Matrix2D._TempCompose1.multiplyToRef(Matrix2D._TempPostTranslationMatrix, result);\r\n }\r\n };\r\n Matrix2D._TempPreTranslationMatrix = Matrix2D.Identity();\r\n Matrix2D._TempPostTranslationMatrix = Matrix2D.Identity();\r\n Matrix2D._TempRotationMatrix = Matrix2D.Identity();\r\n Matrix2D._TempScalingMatrix = Matrix2D.Identity();\r\n Matrix2D._TempCompose0 = Matrix2D.Identity();\r\n Matrix2D._TempCompose1 = Matrix2D.Identity();\r\n Matrix2D._TempCompose2 = Matrix2D.Identity();\r\n return Matrix2D;\r\n}());\r\nexport { Matrix2D };\r\n//# sourceMappingURL=math2D.js.map","import { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { Vector2, Vector3, Matrix } from \"@babylonjs/core/Maths/math.vector\";\r\nimport { PointerEventTypes } from '@babylonjs/core/Events/pointerEvents';\r\nimport { Logger } from \"@babylonjs/core/Misc/logger\";\r\nimport { Tools } from \"@babylonjs/core/Misc/tools\";\r\nimport { ValueAndUnit } from \"../valueAndUnit\";\r\nimport { Measure } from \"../measure\";\r\nimport { Matrix2D, Vector2WithInfo } from \"../math2D\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Root class used for all 2D controls\r\n * @see http://doc.babylonjs.com/how_to/gui#controls\r\n */\r\nvar Control = /** @class */ (function () {\r\n // Functions\r\n /**\r\n * Creates a new control\r\n * @param name defines the name of the control\r\n */\r\n function Control(\r\n /** defines the name of the control */\r\n name) {\r\n this.name = name;\r\n this._alpha = 1;\r\n this._alphaSet = false;\r\n this._zIndex = 0;\r\n /** @hidden */\r\n this._currentMeasure = Measure.Empty();\r\n this._fontFamily = \"Arial\";\r\n this._fontStyle = \"\";\r\n this._fontWeight = \"\";\r\n this._fontSize = new ValueAndUnit(18, ValueAndUnit.UNITMODE_PIXEL, false);\r\n /** @hidden */\r\n this._width = new ValueAndUnit(1, ValueAndUnit.UNITMODE_PERCENTAGE, false);\r\n /** @hidden */\r\n this._height = new ValueAndUnit(1, ValueAndUnit.UNITMODE_PERCENTAGE, false);\r\n this._color = \"\";\r\n this._style = null;\r\n /** @hidden */\r\n this._horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_CENTER;\r\n /** @hidden */\r\n this._verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n /** @hidden */\r\n this._isDirty = true;\r\n /** @hidden */\r\n this._wasDirty = false;\r\n /** @hidden */\r\n this._tempParentMeasure = Measure.Empty();\r\n /** @hidden */\r\n this._prevCurrentMeasureTransformedIntoGlobalSpace = Measure.Empty();\r\n /** @hidden */\r\n this._cachedParentMeasure = Measure.Empty();\r\n this._paddingLeft = new ValueAndUnit(0);\r\n this._paddingRight = new ValueAndUnit(0);\r\n this._paddingTop = new ValueAndUnit(0);\r\n this._paddingBottom = new ValueAndUnit(0);\r\n /** @hidden */\r\n this._left = new ValueAndUnit(0);\r\n /** @hidden */\r\n this._top = new ValueAndUnit(0);\r\n this._scaleX = 1.0;\r\n this._scaleY = 1.0;\r\n this._rotation = 0;\r\n this._transformCenterX = 0.5;\r\n this._transformCenterY = 0.5;\r\n /** @hidden */\r\n this._transformMatrix = Matrix2D.Identity();\r\n /** @hidden */\r\n this._invertTransformMatrix = Matrix2D.Identity();\r\n /** @hidden */\r\n this._transformedPosition = Vector2.Zero();\r\n this._isMatrixDirty = true;\r\n this._isVisible = true;\r\n this._isHighlighted = false;\r\n this._fontSet = false;\r\n this._dummyVector2 = Vector2.Zero();\r\n this._downCount = 0;\r\n this._enterCount = -1;\r\n this._doNotRender = false;\r\n this._downPointerIds = {};\r\n this._isEnabled = true;\r\n this._disabledColor = \"#9a9a9a\";\r\n this._disabledColorItem = \"#6a6a6a\";\r\n /** @hidden */\r\n this._rebuildLayout = false;\r\n /** @hidden */\r\n this._customData = {};\r\n /** @hidden */\r\n this._isClipped = false;\r\n /** @hidden */\r\n this._automaticSize = false;\r\n /**\r\n * Gets or sets an object used to store user defined information for the node\r\n */\r\n this.metadata = null;\r\n /** Gets or sets a boolean indicating if the control can be hit with pointer events */\r\n this.isHitTestVisible = true;\r\n /** Gets or sets a boolean indicating if the control can block pointer events */\r\n this.isPointerBlocker = false;\r\n /** Gets or sets a boolean indicating if the control can be focusable */\r\n this.isFocusInvisible = false;\r\n /**\r\n * Gets or sets a boolean indicating if the children are clipped to the current control bounds.\r\n * Please note that not clipping children may generate issues with adt.useInvalidateRectOptimization so it is recommended to turn this optimization off if you want to use unclipped children\r\n */\r\n this.clipChildren = true;\r\n /**\r\n * Gets or sets a boolean indicating that control content must be clipped\r\n * Please note that not clipping children may generate issues with adt.useInvalidateRectOptimization so it is recommended to turn this optimization off if you want to use unclipped children\r\n */\r\n this.clipContent = true;\r\n /**\r\n * Gets or sets a boolean indicating that the current control should cache its rendering (useful when the control does not change often)\r\n */\r\n this.useBitmapCache = false;\r\n this._shadowOffsetX = 0;\r\n this._shadowOffsetY = 0;\r\n this._shadowBlur = 0;\r\n this._shadowColor = 'black';\r\n /** Gets or sets the cursor to use when the control is hovered */\r\n this.hoverCursor = \"\";\r\n /** @hidden */\r\n this._linkOffsetX = new ValueAndUnit(0);\r\n /** @hidden */\r\n this._linkOffsetY = new ValueAndUnit(0);\r\n /**\r\n * An event triggered when pointer wheel is scrolled\r\n */\r\n this.onWheelObservable = new Observable();\r\n /**\r\n * An event triggered when the pointer move over the control.\r\n */\r\n this.onPointerMoveObservable = new Observable();\r\n /**\r\n * An event triggered when the pointer move out of the control.\r\n */\r\n this.onPointerOutObservable = new Observable();\r\n /**\r\n * An event triggered when the pointer taps the control\r\n */\r\n this.onPointerDownObservable = new Observable();\r\n /**\r\n * An event triggered when pointer up\r\n */\r\n this.onPointerUpObservable = new Observable();\r\n /**\r\n * An event triggered when a control is clicked on\r\n */\r\n this.onPointerClickObservable = new Observable();\r\n /**\r\n * An event triggered when pointer enters the control\r\n */\r\n this.onPointerEnterObservable = new Observable();\r\n /**\r\n * An event triggered when the control is marked as dirty\r\n */\r\n this.onDirtyObservable = new Observable();\r\n /**\r\n * An event triggered before drawing the control\r\n */\r\n this.onBeforeDrawObservable = new Observable();\r\n /**\r\n * An event triggered after the control was drawn\r\n */\r\n this.onAfterDrawObservable = new Observable();\r\n this._tmpMeasureA = new Measure(0, 0, 0, 0);\r\n }\r\n Object.defineProperty(Control.prototype, \"shadowOffsetX\", {\r\n /** Gets or sets a value indicating the offset to apply on X axis to render the shadow */\r\n get: function () {\r\n return this._shadowOffsetX;\r\n },\r\n set: function (value) {\r\n if (this._shadowOffsetX === value) {\r\n return;\r\n }\r\n this._shadowOffsetX = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"shadowOffsetY\", {\r\n /** Gets or sets a value indicating the offset to apply on Y axis to render the shadow */\r\n get: function () {\r\n return this._shadowOffsetY;\r\n },\r\n set: function (value) {\r\n if (this._shadowOffsetY === value) {\r\n return;\r\n }\r\n this._shadowOffsetY = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"shadowBlur\", {\r\n /** Gets or sets a value indicating the amount of blur to use to render the shadow */\r\n get: function () {\r\n return this._shadowBlur;\r\n },\r\n set: function (value) {\r\n if (this._shadowBlur === value) {\r\n return;\r\n }\r\n this._shadowBlur = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"shadowColor\", {\r\n /** Gets or sets a value indicating the color of the shadow (black by default ie. \"#000\") */\r\n get: function () {\r\n return this._shadowColor;\r\n },\r\n set: function (value) {\r\n if (this._shadowColor === value) {\r\n return;\r\n }\r\n this._shadowColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"typeName\", {\r\n // Properties\r\n /** Gets the control type name */\r\n get: function () {\r\n return this._getTypeName();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Get the current class name of the control.\r\n * @returns current class name\r\n */\r\n Control.prototype.getClassName = function () {\r\n return this._getTypeName();\r\n };\r\n Object.defineProperty(Control.prototype, \"host\", {\r\n /**\r\n * Get the hosting AdvancedDynamicTexture\r\n */\r\n get: function () {\r\n return this._host;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"fontOffset\", {\r\n /** Gets or set information about font offsets (used to render and align text) */\r\n get: function () {\r\n return this._fontOffset;\r\n },\r\n set: function (offset) {\r\n this._fontOffset = offset;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"alpha\", {\r\n /** Gets or sets alpha value for the control (1 means opaque and 0 means entirely transparent) */\r\n get: function () {\r\n return this._alpha;\r\n },\r\n set: function (value) {\r\n if (this._alpha === value) {\r\n return;\r\n }\r\n this._alphaSet = true;\r\n this._alpha = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"isHighlighted\", {\r\n /**\r\n * Gets or sets a boolean indicating that we want to highlight the control (mostly for debugging purpose)\r\n */\r\n get: function () {\r\n return this._isHighlighted;\r\n },\r\n set: function (value) {\r\n if (this._isHighlighted === value) {\r\n return;\r\n }\r\n this._isHighlighted = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"scaleX\", {\r\n /** Gets or sets a value indicating the scale factor on X axis (1 by default)\r\n * @see http://doc.babylonjs.com/how_to/gui#rotation-and-scaling\r\n */\r\n get: function () {\r\n return this._scaleX;\r\n },\r\n set: function (value) {\r\n if (this._scaleX === value) {\r\n return;\r\n }\r\n this._scaleX = value;\r\n this._markAsDirty();\r\n this._markMatrixAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"scaleY\", {\r\n /** Gets or sets a value indicating the scale factor on Y axis (1 by default)\r\n * @see http://doc.babylonjs.com/how_to/gui#rotation-and-scaling\r\n */\r\n get: function () {\r\n return this._scaleY;\r\n },\r\n set: function (value) {\r\n if (this._scaleY === value) {\r\n return;\r\n }\r\n this._scaleY = value;\r\n this._markAsDirty();\r\n this._markMatrixAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"rotation\", {\r\n /** Gets or sets the rotation angle (0 by default)\r\n * @see http://doc.babylonjs.com/how_to/gui#rotation-and-scaling\r\n */\r\n get: function () {\r\n return this._rotation;\r\n },\r\n set: function (value) {\r\n if (this._rotation === value) {\r\n return;\r\n }\r\n this._rotation = value;\r\n this._markAsDirty();\r\n this._markMatrixAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"transformCenterY\", {\r\n /** Gets or sets the transformation center on Y axis (0 by default)\r\n * @see http://doc.babylonjs.com/how_to/gui#rotation-and-scaling\r\n */\r\n get: function () {\r\n return this._transformCenterY;\r\n },\r\n set: function (value) {\r\n if (this._transformCenterY === value) {\r\n return;\r\n }\r\n this._transformCenterY = value;\r\n this._markAsDirty();\r\n this._markMatrixAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"transformCenterX\", {\r\n /** Gets or sets the transformation center on X axis (0 by default)\r\n * @see http://doc.babylonjs.com/how_to/gui#rotation-and-scaling\r\n */\r\n get: function () {\r\n return this._transformCenterX;\r\n },\r\n set: function (value) {\r\n if (this._transformCenterX === value) {\r\n return;\r\n }\r\n this._transformCenterX = value;\r\n this._markAsDirty();\r\n this._markMatrixAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"horizontalAlignment\", {\r\n /**\r\n * Gets or sets the horizontal alignment\r\n * @see http://doc.babylonjs.com/how_to/gui#alignments\r\n */\r\n get: function () {\r\n return this._horizontalAlignment;\r\n },\r\n set: function (value) {\r\n if (this._horizontalAlignment === value) {\r\n return;\r\n }\r\n this._horizontalAlignment = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"verticalAlignment\", {\r\n /**\r\n * Gets or sets the vertical alignment\r\n * @see http://doc.babylonjs.com/how_to/gui#alignments\r\n */\r\n get: function () {\r\n return this._verticalAlignment;\r\n },\r\n set: function (value) {\r\n if (this._verticalAlignment === value) {\r\n return;\r\n }\r\n this._verticalAlignment = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"width\", {\r\n /**\r\n * Gets or sets control width\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._width.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._width.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._width.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"widthInPixels\", {\r\n /**\r\n * Gets or sets the control width in pixel\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._width.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.width = value + \"px\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"height\", {\r\n /**\r\n * Gets or sets control height\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._height.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._height.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._height.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"heightInPixels\", {\r\n /**\r\n * Gets or sets control height in pixel\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._height.getValueInPixel(this._host, this._cachedParentMeasure.height);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.height = value + \"px\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"fontFamily\", {\r\n /** Gets or set font family */\r\n get: function () {\r\n if (!this._fontSet) {\r\n return \"\";\r\n }\r\n return this._fontFamily;\r\n },\r\n set: function (value) {\r\n if (this._fontFamily === value) {\r\n return;\r\n }\r\n this._fontFamily = value;\r\n this._resetFontCache();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"fontStyle\", {\r\n /** Gets or sets font style */\r\n get: function () {\r\n return this._fontStyle;\r\n },\r\n set: function (value) {\r\n if (this._fontStyle === value) {\r\n return;\r\n }\r\n this._fontStyle = value;\r\n this._resetFontCache();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"fontWeight\", {\r\n /** Gets or sets font weight */\r\n get: function () {\r\n return this._fontWeight;\r\n },\r\n set: function (value) {\r\n if (this._fontWeight === value) {\r\n return;\r\n }\r\n this._fontWeight = value;\r\n this._resetFontCache();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"style\", {\r\n /**\r\n * Gets or sets style\r\n * @see http://doc.babylonjs.com/how_to/gui#styles\r\n */\r\n get: function () {\r\n return this._style;\r\n },\r\n set: function (value) {\r\n var _this = this;\r\n if (this._style) {\r\n this._style.onChangedObservable.remove(this._styleObserver);\r\n this._styleObserver = null;\r\n }\r\n this._style = value;\r\n if (this._style) {\r\n this._styleObserver = this._style.onChangedObservable.add(function () {\r\n _this._markAsDirty();\r\n _this._resetFontCache();\r\n });\r\n }\r\n this._markAsDirty();\r\n this._resetFontCache();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"_isFontSizeInPercentage\", {\r\n /** @hidden */\r\n get: function () {\r\n return this._fontSize.isPercentage;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"fontSizeInPixels\", {\r\n /** Gets or sets font size in pixels */\r\n get: function () {\r\n var fontSizeToUse = this._style ? this._style._fontSize : this._fontSize;\r\n if (fontSizeToUse.isPixel) {\r\n return fontSizeToUse.getValue(this._host);\r\n }\r\n return fontSizeToUse.getValueInPixel(this._host, this._tempParentMeasure.height || this._cachedParentMeasure.height);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.fontSize = value + \"px\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"fontSize\", {\r\n /** Gets or sets font size */\r\n get: function () {\r\n return this._fontSize.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._fontSize.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._fontSize.fromString(value)) {\r\n this._markAsDirty();\r\n this._resetFontCache();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"color\", {\r\n /** Gets or sets foreground color */\r\n get: function () {\r\n return this._color;\r\n },\r\n set: function (value) {\r\n if (this._color === value) {\r\n return;\r\n }\r\n this._color = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"zIndex\", {\r\n /** Gets or sets z index which is used to reorder controls on the z axis */\r\n get: function () {\r\n return this._zIndex;\r\n },\r\n set: function (value) {\r\n if (this.zIndex === value) {\r\n return;\r\n }\r\n this._zIndex = value;\r\n if (this.parent) {\r\n this.parent._reOrderControl(this);\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"notRenderable\", {\r\n /** Gets or sets a boolean indicating if the control can be rendered */\r\n get: function () {\r\n return this._doNotRender;\r\n },\r\n set: function (value) {\r\n if (this._doNotRender === value) {\r\n return;\r\n }\r\n this._doNotRender = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"isVisible\", {\r\n /** Gets or sets a boolean indicating if the control is visible */\r\n get: function () {\r\n return this._isVisible;\r\n },\r\n set: function (value) {\r\n if (this._isVisible === value) {\r\n return;\r\n }\r\n this._isVisible = value;\r\n this._markAsDirty(true);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"isDirty\", {\r\n /** Gets a boolean indicating that the control needs to update its rendering */\r\n get: function () {\r\n return this._isDirty;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"linkedMesh\", {\r\n /**\r\n * Gets the current linked mesh (or null if none)\r\n */\r\n get: function () {\r\n return this._linkedMesh;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"paddingLeft\", {\r\n /**\r\n * Gets or sets a value indicating the padding to use on the left of the control\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._paddingLeft.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._paddingLeft.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"paddingLeftInPixels\", {\r\n /**\r\n * Gets or sets a value indicating the padding in pixels to use on the left of the control\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._paddingLeft.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.paddingLeft = value + \"px\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"paddingRight\", {\r\n /**\r\n * Gets or sets a value indicating the padding to use on the right of the control\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._paddingRight.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._paddingRight.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"paddingRightInPixels\", {\r\n /**\r\n * Gets or sets a value indicating the padding in pixels to use on the right of the control\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._paddingRight.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.paddingRight = value + \"px\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"paddingTop\", {\r\n /**\r\n * Gets or sets a value indicating the padding to use on the top of the control\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._paddingTop.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._paddingTop.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"paddingTopInPixels\", {\r\n /**\r\n * Gets or sets a value indicating the padding in pixels to use on the top of the control\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._paddingTop.getValueInPixel(this._host, this._cachedParentMeasure.height);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.paddingTop = value + \"px\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"paddingBottom\", {\r\n /**\r\n * Gets or sets a value indicating the padding to use on the bottom of the control\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._paddingBottom.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._paddingBottom.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"paddingBottomInPixels\", {\r\n /**\r\n * Gets or sets a value indicating the padding in pixels to use on the bottom of the control\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._paddingBottom.getValueInPixel(this._host, this._cachedParentMeasure.height);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.paddingBottom = value + \"px\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"left\", {\r\n /**\r\n * Gets or sets a value indicating the left coordinate of the control\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._left.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._left.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"leftInPixels\", {\r\n /**\r\n * Gets or sets a value indicating the left coordinate in pixels of the control\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._left.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.left = value + \"px\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"top\", {\r\n /**\r\n * Gets or sets a value indicating the top coordinate of the control\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._top.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._top.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"topInPixels\", {\r\n /**\r\n * Gets or sets a value indicating the top coordinate in pixels of the control\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._top.getValueInPixel(this._host, this._cachedParentMeasure.height);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.top = value + \"px\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"linkOffsetX\", {\r\n /**\r\n * Gets or sets a value indicating the offset on X axis to the linked mesh\r\n * @see http://doc.babylonjs.com/how_to/gui#tracking-positions\r\n */\r\n get: function () {\r\n return this._linkOffsetX.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._linkOffsetX.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"linkOffsetXInPixels\", {\r\n /**\r\n * Gets or sets a value indicating the offset in pixels on X axis to the linked mesh\r\n * @see http://doc.babylonjs.com/how_to/gui#tracking-positions\r\n */\r\n get: function () {\r\n return this._linkOffsetX.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.linkOffsetX = value + \"px\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"linkOffsetY\", {\r\n /**\r\n * Gets or sets a value indicating the offset on Y axis to the linked mesh\r\n * @see http://doc.babylonjs.com/how_to/gui#tracking-positions\r\n */\r\n get: function () {\r\n return this._linkOffsetY.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._linkOffsetY.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"linkOffsetYInPixels\", {\r\n /**\r\n * Gets or sets a value indicating the offset in pixels on Y axis to the linked mesh\r\n * @see http://doc.babylonjs.com/how_to/gui#tracking-positions\r\n */\r\n get: function () {\r\n return this._linkOffsetY.getValueInPixel(this._host, this._cachedParentMeasure.height);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.linkOffsetY = value + \"px\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"centerX\", {\r\n /** Gets the center coordinate on X axis */\r\n get: function () {\r\n return this._currentMeasure.left + this._currentMeasure.width / 2;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"centerY\", {\r\n /** Gets the center coordinate on Y axis */\r\n get: function () {\r\n return this._currentMeasure.top + this._currentMeasure.height / 2;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"isEnabled\", {\r\n /** Gets or sets if control is Enabled*/\r\n get: function () {\r\n return this._isEnabled;\r\n },\r\n set: function (value) {\r\n if (this._isEnabled === value) {\r\n return;\r\n }\r\n this._isEnabled = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"disabledColor\", {\r\n /** Gets or sets background color of control if it's disabled*/\r\n get: function () {\r\n return this._disabledColor;\r\n },\r\n set: function (value) {\r\n if (this._disabledColor === value) {\r\n return;\r\n }\r\n this._disabledColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"disabledColorItem\", {\r\n /** Gets or sets front color of control if it's disabled*/\r\n get: function () {\r\n return this._disabledColorItem;\r\n },\r\n set: function (value) {\r\n if (this._disabledColorItem === value) {\r\n return;\r\n }\r\n this._disabledColorItem = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n Control.prototype._getTypeName = function () {\r\n return \"Control\";\r\n };\r\n /**\r\n * Gets the first ascendant in the hierarchy of the given type\r\n * @param className defines the required type\r\n * @returns the ascendant or null if not found\r\n */\r\n Control.prototype.getAscendantOfClass = function (className) {\r\n if (!this.parent) {\r\n return null;\r\n }\r\n if (this.parent.getClassName() === className) {\r\n return this.parent;\r\n }\r\n return this.parent.getAscendantOfClass(className);\r\n };\r\n /** @hidden */\r\n Control.prototype._resetFontCache = function () {\r\n this._fontSet = true;\r\n this._markAsDirty();\r\n };\r\n /**\r\n * Determines if a container is an ascendant of the current control\r\n * @param container defines the container to look for\r\n * @returns true if the container is one of the ascendant of the control\r\n */\r\n Control.prototype.isAscendant = function (container) {\r\n if (!this.parent) {\r\n return false;\r\n }\r\n if (this.parent === container) {\r\n return true;\r\n }\r\n return this.parent.isAscendant(container);\r\n };\r\n /**\r\n * Gets coordinates in local control space\r\n * @param globalCoordinates defines the coordinates to transform\r\n * @returns the new coordinates in local space\r\n */\r\n Control.prototype.getLocalCoordinates = function (globalCoordinates) {\r\n var result = Vector2.Zero();\r\n this.getLocalCoordinatesToRef(globalCoordinates, result);\r\n return result;\r\n };\r\n /**\r\n * Gets coordinates in local control space\r\n * @param globalCoordinates defines the coordinates to transform\r\n * @param result defines the target vector2 where to store the result\r\n * @returns the current control\r\n */\r\n Control.prototype.getLocalCoordinatesToRef = function (globalCoordinates, result) {\r\n result.x = globalCoordinates.x - this._currentMeasure.left;\r\n result.y = globalCoordinates.y - this._currentMeasure.top;\r\n return this;\r\n };\r\n /**\r\n * Gets coordinates in parent local control space\r\n * @param globalCoordinates defines the coordinates to transform\r\n * @returns the new coordinates in parent local space\r\n */\r\n Control.prototype.getParentLocalCoordinates = function (globalCoordinates) {\r\n var result = Vector2.Zero();\r\n result.x = globalCoordinates.x - this._cachedParentMeasure.left;\r\n result.y = globalCoordinates.y - this._cachedParentMeasure.top;\r\n return result;\r\n };\r\n /**\r\n * Move the current control to a vector3 position projected onto the screen.\r\n * @param position defines the target position\r\n * @param scene defines the hosting scene\r\n */\r\n Control.prototype.moveToVector3 = function (position, scene) {\r\n if (!this._host || this.parent !== this._host._rootContainer) {\r\n Tools.Error(\"Cannot move a control to a vector3 if the control is not at root level\");\r\n return;\r\n }\r\n this.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n this.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n var globalViewport = this._host._getGlobalViewport(scene);\r\n var projectedPosition = Vector3.Project(position, Matrix.Identity(), scene.getTransformMatrix(), globalViewport);\r\n this._moveToProjectedPosition(projectedPosition);\r\n if (projectedPosition.z < 0 || projectedPosition.z > 1) {\r\n this.notRenderable = true;\r\n return;\r\n }\r\n this.notRenderable = false;\r\n };\r\n /**\r\n * Will store all controls that have this control as ascendant in a given array\r\n * @param results defines the array where to store the descendants\r\n * @param directDescendantsOnly defines if true only direct descendants of 'this' will be considered, if false direct and also indirect (children of children, an so on in a recursive manner) descendants of 'this' will be considered\r\n * @param predicate defines an optional predicate that will be called on every evaluated child, the predicate must return true for a given child to be part of the result, otherwise it will be ignored\r\n */\r\n Control.prototype.getDescendantsToRef = function (results, directDescendantsOnly, predicate) {\r\n if (directDescendantsOnly === void 0) { directDescendantsOnly = false; }\r\n // Do nothing by default\r\n };\r\n /**\r\n * Will return all controls that have this control as ascendant\r\n * @param directDescendantsOnly defines if true only direct descendants of 'this' will be considered, if false direct and also indirect (children of children, an so on in a recursive manner) descendants of 'this' will be considered\r\n * @param predicate defines an optional predicate that will be called on every evaluated child, the predicate must return true for a given child to be part of the result, otherwise it will be ignored\r\n * @return all child controls\r\n */\r\n Control.prototype.getDescendants = function (directDescendantsOnly, predicate) {\r\n var results = new Array();\r\n this.getDescendantsToRef(results, directDescendantsOnly, predicate);\r\n return results;\r\n };\r\n /**\r\n * Link current control with a target mesh\r\n * @param mesh defines the mesh to link with\r\n * @see http://doc.babylonjs.com/how_to/gui#tracking-positions\r\n */\r\n Control.prototype.linkWithMesh = function (mesh) {\r\n if (!this._host || this.parent && this.parent !== this._host._rootContainer) {\r\n if (mesh) {\r\n Tools.Error(\"Cannot link a control to a mesh if the control is not at root level\");\r\n }\r\n return;\r\n }\r\n var index = this._host._linkedControls.indexOf(this);\r\n if (index !== -1) {\r\n this._linkedMesh = mesh;\r\n if (!mesh) {\r\n this._host._linkedControls.splice(index, 1);\r\n }\r\n return;\r\n }\r\n else if (!mesh) {\r\n return;\r\n }\r\n this.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n this.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n this._linkedMesh = mesh;\r\n this._host._linkedControls.push(this);\r\n };\r\n /** @hidden */\r\n Control.prototype._moveToProjectedPosition = function (projectedPosition) {\r\n var oldLeft = this._left.getValue(this._host);\r\n var oldTop = this._top.getValue(this._host);\r\n var newLeft = ((projectedPosition.x + this._linkOffsetX.getValue(this._host)) - this._currentMeasure.width / 2);\r\n var newTop = ((projectedPosition.y + this._linkOffsetY.getValue(this._host)) - this._currentMeasure.height / 2);\r\n if (this._left.ignoreAdaptiveScaling && this._top.ignoreAdaptiveScaling) {\r\n if (Math.abs(newLeft - oldLeft) < 0.5) {\r\n newLeft = oldLeft;\r\n }\r\n if (Math.abs(newTop - oldTop) < 0.5) {\r\n newTop = oldTop;\r\n }\r\n }\r\n this.left = newLeft + \"px\";\r\n this.top = newTop + \"px\";\r\n this._left.ignoreAdaptiveScaling = true;\r\n this._top.ignoreAdaptiveScaling = true;\r\n this._markAsDirty();\r\n };\r\n /** @hidden */\r\n Control.prototype._offsetLeft = function (offset) {\r\n this._isDirty = true;\r\n this._currentMeasure.left += offset;\r\n };\r\n /** @hidden */\r\n Control.prototype._offsetTop = function (offset) {\r\n this._isDirty = true;\r\n this._currentMeasure.top += offset;\r\n };\r\n /** @hidden */\r\n Control.prototype._markMatrixAsDirty = function () {\r\n this._isMatrixDirty = true;\r\n this._flagDescendantsAsMatrixDirty();\r\n };\r\n /** @hidden */\r\n Control.prototype._flagDescendantsAsMatrixDirty = function () {\r\n // No child\r\n };\r\n /** @hidden */\r\n Control.prototype._intersectsRect = function (rect) {\r\n // Rotate the control's current measure into local space and check if it intersects the passed in rectangle\r\n this._currentMeasure.transformToRef(this._transformMatrix, this._tmpMeasureA);\r\n if (this._tmpMeasureA.left >= rect.left + rect.width) {\r\n return false;\r\n }\r\n if (this._tmpMeasureA.top >= rect.top + rect.height) {\r\n return false;\r\n }\r\n if (this._tmpMeasureA.left + this._tmpMeasureA.width <= rect.left) {\r\n return false;\r\n }\r\n if (this._tmpMeasureA.top + this._tmpMeasureA.height <= rect.top) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n /** @hidden */\r\n Control.prototype.invalidateRect = function () {\r\n this._transform();\r\n if (this.host && this.host.useInvalidateRectOptimization) {\r\n // Rotate by transform to get the measure transformed to global space\r\n this._currentMeasure.transformToRef(this._transformMatrix, this._tmpMeasureA);\r\n // get the boudning box of the current measure and last frames measure in global space and invalidate it\r\n // the previous measure is used to properly clear a control that is scaled down\r\n Measure.CombineToRef(this._tmpMeasureA, this._prevCurrentMeasureTransformedIntoGlobalSpace, this._tmpMeasureA);\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n // Expand rect based on shadows\r\n var shadowOffsetX = this.shadowOffsetX;\r\n var shadowOffsetY = this.shadowOffsetY;\r\n var shadowBlur = this.shadowBlur;\r\n var leftShadowOffset = Math.min(Math.min(shadowOffsetX, 0) - shadowBlur * 2, 0);\r\n var rightShadowOffset = Math.max(Math.max(shadowOffsetX, 0) + shadowBlur * 2, 0);\r\n var topShadowOffset = Math.min(Math.min(shadowOffsetY, 0) - shadowBlur * 2, 0);\r\n var bottomShadowOffset = Math.max(Math.max(shadowOffsetY, 0) + shadowBlur * 2, 0);\r\n this.host.invalidateRect(Math.floor(this._tmpMeasureA.left + leftShadowOffset), Math.floor(this._tmpMeasureA.top + topShadowOffset), Math.ceil(this._tmpMeasureA.left + this._tmpMeasureA.width + rightShadowOffset), Math.ceil(this._tmpMeasureA.top + this._tmpMeasureA.height + bottomShadowOffset));\r\n }\r\n else {\r\n this.host.invalidateRect(Math.floor(this._tmpMeasureA.left), Math.floor(this._tmpMeasureA.top), Math.ceil(this._tmpMeasureA.left + this._tmpMeasureA.width), Math.ceil(this._tmpMeasureA.top + this._tmpMeasureA.height));\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._markAsDirty = function (force) {\r\n if (force === void 0) { force = false; }\r\n if (!this._isVisible && !force) {\r\n return;\r\n }\r\n this._isDirty = true;\r\n // Redraw only this rectangle\r\n if (this._host) {\r\n this._host.markAsDirty();\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._markAllAsDirty = function () {\r\n this._markAsDirty();\r\n if (this._font) {\r\n this._prepareFont();\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._link = function (host) {\r\n this._host = host;\r\n if (this._host) {\r\n this.uniqueId = this._host.getScene().getUniqueId();\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._transform = function (context) {\r\n if (!this._isMatrixDirty && this._scaleX === 1 && this._scaleY === 1 && this._rotation === 0) {\r\n return;\r\n }\r\n // postTranslate\r\n var offsetX = this._currentMeasure.width * this._transformCenterX + this._currentMeasure.left;\r\n var offsetY = this._currentMeasure.height * this._transformCenterY + this._currentMeasure.top;\r\n if (context) {\r\n context.translate(offsetX, offsetY);\r\n // rotate\r\n context.rotate(this._rotation);\r\n // scale\r\n context.scale(this._scaleX, this._scaleY);\r\n // preTranslate\r\n context.translate(-offsetX, -offsetY);\r\n }\r\n // Need to update matrices?\r\n if (this._isMatrixDirty || this._cachedOffsetX !== offsetX || this._cachedOffsetY !== offsetY) {\r\n this._cachedOffsetX = offsetX;\r\n this._cachedOffsetY = offsetY;\r\n this._isMatrixDirty = false;\r\n this._flagDescendantsAsMatrixDirty();\r\n Matrix2D.ComposeToRef(-offsetX, -offsetY, this._rotation, this._scaleX, this._scaleY, this.parent ? this.parent._transformMatrix : null, this._transformMatrix);\r\n this._transformMatrix.invertToRef(this._invertTransformMatrix);\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._renderHighlight = function (context) {\r\n if (!this.isHighlighted) {\r\n return;\r\n }\r\n context.save();\r\n context.strokeStyle = \"#4affff\";\r\n context.lineWidth = 2;\r\n this._renderHighlightSpecific(context);\r\n context.restore();\r\n };\r\n /** @hidden */\r\n Control.prototype._renderHighlightSpecific = function (context) {\r\n context.strokeRect(this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n };\r\n /** @hidden */\r\n Control.prototype._applyStates = function (context) {\r\n if (this._isFontSizeInPercentage) {\r\n this._fontSet = true;\r\n }\r\n if (this._fontSet) {\r\n this._prepareFont();\r\n this._fontSet = false;\r\n }\r\n if (this._font) {\r\n context.font = this._font;\r\n }\r\n if (this._color) {\r\n context.fillStyle = this._color;\r\n }\r\n if (Control.AllowAlphaInheritance) {\r\n context.globalAlpha *= this._alpha;\r\n }\r\n else if (this._alphaSet) {\r\n context.globalAlpha = this.parent ? this.parent.alpha * this._alpha : this._alpha;\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._layout = function (parentMeasure, context) {\r\n if (!this.isDirty && (!this.isVisible || this.notRenderable)) {\r\n return false;\r\n }\r\n if (this._isDirty || !this._cachedParentMeasure.isEqualsTo(parentMeasure)) {\r\n this.host._numLayoutCalls++;\r\n this._currentMeasure.transformToRef(this._transformMatrix, this._prevCurrentMeasureTransformedIntoGlobalSpace);\r\n context.save();\r\n this._applyStates(context);\r\n var rebuildCount = 0;\r\n do {\r\n this._rebuildLayout = false;\r\n this._processMeasures(parentMeasure, context);\r\n rebuildCount++;\r\n } while (this._rebuildLayout && rebuildCount < 3);\r\n if (rebuildCount >= 3) {\r\n Logger.Error(\"Layout cycle detected in GUI (Control name=\" + this.name + \", uniqueId=\" + this.uniqueId + \")\");\r\n }\r\n context.restore();\r\n this.invalidateRect();\r\n this._evaluateClippingState(parentMeasure);\r\n }\r\n this._wasDirty = this._isDirty;\r\n this._isDirty = false;\r\n return true;\r\n };\r\n /** @hidden */\r\n Control.prototype._processMeasures = function (parentMeasure, context) {\r\n this._currentMeasure.copyFrom(parentMeasure);\r\n // Let children take some pre-measurement actions\r\n this._preMeasure(parentMeasure, context);\r\n this._measure();\r\n this._computeAlignment(parentMeasure, context);\r\n // Convert to int values\r\n this._currentMeasure.left = this._currentMeasure.left | 0;\r\n this._currentMeasure.top = this._currentMeasure.top | 0;\r\n this._currentMeasure.width = this._currentMeasure.width | 0;\r\n this._currentMeasure.height = this._currentMeasure.height | 0;\r\n // Let children add more features\r\n this._additionalProcessing(parentMeasure, context);\r\n this._cachedParentMeasure.copyFrom(parentMeasure);\r\n if (this.onDirtyObservable.hasObservers()) {\r\n this.onDirtyObservable.notifyObservers(this);\r\n }\r\n };\r\n Control.prototype._evaluateClippingState = function (parentMeasure) {\r\n if (this.parent && this.parent.clipChildren) {\r\n // Early clip\r\n if (this._currentMeasure.left > parentMeasure.left + parentMeasure.width) {\r\n this._isClipped = true;\r\n return;\r\n }\r\n if (this._currentMeasure.left + this._currentMeasure.width < parentMeasure.left) {\r\n this._isClipped = true;\r\n return;\r\n }\r\n if (this._currentMeasure.top > parentMeasure.top + parentMeasure.height) {\r\n this._isClipped = true;\r\n return;\r\n }\r\n if (this._currentMeasure.top + this._currentMeasure.height < parentMeasure.top) {\r\n this._isClipped = true;\r\n return;\r\n }\r\n }\r\n this._isClipped = false;\r\n };\r\n /** @hidden */\r\n Control.prototype._measure = function () {\r\n // Width / Height\r\n if (this._width.isPixel) {\r\n this._currentMeasure.width = this._width.getValue(this._host);\r\n }\r\n else {\r\n this._currentMeasure.width *= this._width.getValue(this._host);\r\n }\r\n if (this._height.isPixel) {\r\n this._currentMeasure.height = this._height.getValue(this._host);\r\n }\r\n else {\r\n this._currentMeasure.height *= this._height.getValue(this._host);\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._computeAlignment = function (parentMeasure, context) {\r\n var width = this._currentMeasure.width;\r\n var height = this._currentMeasure.height;\r\n var parentWidth = parentMeasure.width;\r\n var parentHeight = parentMeasure.height;\r\n // Left / top\r\n var x = 0;\r\n var y = 0;\r\n switch (this.horizontalAlignment) {\r\n case Control.HORIZONTAL_ALIGNMENT_LEFT:\r\n x = 0;\r\n break;\r\n case Control.HORIZONTAL_ALIGNMENT_RIGHT:\r\n x = parentWidth - width;\r\n break;\r\n case Control.HORIZONTAL_ALIGNMENT_CENTER:\r\n x = (parentWidth - width) / 2;\r\n break;\r\n }\r\n switch (this.verticalAlignment) {\r\n case Control.VERTICAL_ALIGNMENT_TOP:\r\n y = 0;\r\n break;\r\n case Control.VERTICAL_ALIGNMENT_BOTTOM:\r\n y = parentHeight - height;\r\n break;\r\n case Control.VERTICAL_ALIGNMENT_CENTER:\r\n y = (parentHeight - height) / 2;\r\n break;\r\n }\r\n if (this._paddingLeft.isPixel) {\r\n this._currentMeasure.left += this._paddingLeft.getValue(this._host);\r\n this._currentMeasure.width -= this._paddingLeft.getValue(this._host);\r\n }\r\n else {\r\n this._currentMeasure.left += parentWidth * this._paddingLeft.getValue(this._host);\r\n this._currentMeasure.width -= parentWidth * this._paddingLeft.getValue(this._host);\r\n }\r\n if (this._paddingRight.isPixel) {\r\n this._currentMeasure.width -= this._paddingRight.getValue(this._host);\r\n }\r\n else {\r\n this._currentMeasure.width -= parentWidth * this._paddingRight.getValue(this._host);\r\n }\r\n if (this._paddingTop.isPixel) {\r\n this._currentMeasure.top += this._paddingTop.getValue(this._host);\r\n this._currentMeasure.height -= this._paddingTop.getValue(this._host);\r\n }\r\n else {\r\n this._currentMeasure.top += parentHeight * this._paddingTop.getValue(this._host);\r\n this._currentMeasure.height -= parentHeight * this._paddingTop.getValue(this._host);\r\n }\r\n if (this._paddingBottom.isPixel) {\r\n this._currentMeasure.height -= this._paddingBottom.getValue(this._host);\r\n }\r\n else {\r\n this._currentMeasure.height -= parentHeight * this._paddingBottom.getValue(this._host);\r\n }\r\n if (this._left.isPixel) {\r\n this._currentMeasure.left += this._left.getValue(this._host);\r\n }\r\n else {\r\n this._currentMeasure.left += parentWidth * this._left.getValue(this._host);\r\n }\r\n if (this._top.isPixel) {\r\n this._currentMeasure.top += this._top.getValue(this._host);\r\n }\r\n else {\r\n this._currentMeasure.top += parentHeight * this._top.getValue(this._host);\r\n }\r\n this._currentMeasure.left += x;\r\n this._currentMeasure.top += y;\r\n };\r\n /** @hidden */\r\n Control.prototype._preMeasure = function (parentMeasure, context) {\r\n // Do nothing\r\n };\r\n /** @hidden */\r\n Control.prototype._additionalProcessing = function (parentMeasure, context) {\r\n // Do nothing\r\n };\r\n /** @hidden */\r\n Control.prototype._clipForChildren = function (context) {\r\n // DO nothing\r\n };\r\n Control.prototype._clip = function (context, invalidatedRectangle) {\r\n context.beginPath();\r\n Control._ClipMeasure.copyFrom(this._currentMeasure);\r\n if (invalidatedRectangle) {\r\n // Rotate the invalidated rect into the control's space\r\n invalidatedRectangle.transformToRef(this._invertTransformMatrix, this._tmpMeasureA);\r\n // Get the intersection of the rect in context space and the current context\r\n var intersection = new Measure(0, 0, 0, 0);\r\n intersection.left = Math.max(this._tmpMeasureA.left, this._currentMeasure.left);\r\n intersection.top = Math.max(this._tmpMeasureA.top, this._currentMeasure.top);\r\n intersection.width = Math.min(this._tmpMeasureA.left + this._tmpMeasureA.width, this._currentMeasure.left + this._currentMeasure.width) - intersection.left;\r\n intersection.height = Math.min(this._tmpMeasureA.top + this._tmpMeasureA.height, this._currentMeasure.top + this._currentMeasure.height) - intersection.top;\r\n Control._ClipMeasure.copyFrom(intersection);\r\n }\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n var shadowOffsetX = this.shadowOffsetX;\r\n var shadowOffsetY = this.shadowOffsetY;\r\n var shadowBlur = this.shadowBlur;\r\n var leftShadowOffset = Math.min(Math.min(shadowOffsetX, 0) - shadowBlur * 2, 0);\r\n var rightShadowOffset = Math.max(Math.max(shadowOffsetX, 0) + shadowBlur * 2, 0);\r\n var topShadowOffset = Math.min(Math.min(shadowOffsetY, 0) - shadowBlur * 2, 0);\r\n var bottomShadowOffset = Math.max(Math.max(shadowOffsetY, 0) + shadowBlur * 2, 0);\r\n context.rect(Control._ClipMeasure.left + leftShadowOffset, Control._ClipMeasure.top + topShadowOffset, Control._ClipMeasure.width + rightShadowOffset - leftShadowOffset, Control._ClipMeasure.height + bottomShadowOffset - topShadowOffset);\r\n }\r\n else {\r\n context.rect(Control._ClipMeasure.left, Control._ClipMeasure.top, Control._ClipMeasure.width, Control._ClipMeasure.height);\r\n }\r\n context.clip();\r\n };\r\n /** @hidden */\r\n Control.prototype._render = function (context, invalidatedRectangle) {\r\n if (!this.isVisible || this.notRenderable || this._isClipped) {\r\n this._isDirty = false;\r\n return false;\r\n }\r\n this.host._numRenderCalls++;\r\n context.save();\r\n this._applyStates(context);\r\n // Transform\r\n this._transform(context);\r\n // Clip\r\n if (this.clipContent) {\r\n this._clip(context, invalidatedRectangle);\r\n }\r\n if (this.onBeforeDrawObservable.hasObservers()) {\r\n this.onBeforeDrawObservable.notifyObservers(this);\r\n }\r\n if (this.useBitmapCache && !this._wasDirty && this._cacheData) {\r\n context.putImageData(this._cacheData, this._currentMeasure.left, this._currentMeasure.top);\r\n }\r\n else {\r\n this._draw(context, invalidatedRectangle);\r\n }\r\n if (this.useBitmapCache && this._wasDirty) {\r\n this._cacheData = context.getImageData(this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n }\r\n this._renderHighlight(context);\r\n if (this.onAfterDrawObservable.hasObservers()) {\r\n this.onAfterDrawObservable.notifyObservers(this);\r\n }\r\n context.restore();\r\n return true;\r\n };\r\n /** @hidden */\r\n Control.prototype._draw = function (context, invalidatedRectangle) {\r\n // Do nothing\r\n };\r\n /**\r\n * Tests if a given coordinates belong to the current control\r\n * @param x defines x coordinate to test\r\n * @param y defines y coordinate to test\r\n * @returns true if the coordinates are inside the control\r\n */\r\n Control.prototype.contains = function (x, y) {\r\n // Invert transform\r\n this._invertTransformMatrix.transformCoordinates(x, y, this._transformedPosition);\r\n x = this._transformedPosition.x;\r\n y = this._transformedPosition.y;\r\n // Check\r\n if (x < this._currentMeasure.left) {\r\n return false;\r\n }\r\n if (x > this._currentMeasure.left + this._currentMeasure.width) {\r\n return false;\r\n }\r\n if (y < this._currentMeasure.top) {\r\n return false;\r\n }\r\n if (y > this._currentMeasure.top + this._currentMeasure.height) {\r\n return false;\r\n }\r\n if (this.isPointerBlocker) {\r\n this._host._shouldBlockPointer = true;\r\n }\r\n return true;\r\n };\r\n /** @hidden */\r\n Control.prototype._processPicking = function (x, y, type, pointerId, buttonIndex, deltaX, deltaY) {\r\n if (!this._isEnabled) {\r\n return false;\r\n }\r\n if (!this.isHitTestVisible || !this.isVisible || this._doNotRender) {\r\n return false;\r\n }\r\n if (!this.contains(x, y)) {\r\n return false;\r\n }\r\n this._processObservables(type, x, y, pointerId, buttonIndex, deltaX, deltaY);\r\n return true;\r\n };\r\n /** @hidden */\r\n Control.prototype._onPointerMove = function (target, coordinates, pointerId) {\r\n var canNotify = this.onPointerMoveObservable.notifyObservers(coordinates, -1, target, this);\r\n if (canNotify && this.parent != null) {\r\n this.parent._onPointerMove(target, coordinates, pointerId);\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._onPointerEnter = function (target) {\r\n if (!this._isEnabled) {\r\n return false;\r\n }\r\n if (this._enterCount > 0) {\r\n return false;\r\n }\r\n if (this._enterCount === -1) { // -1 is for touch input, we are now sure we are with a mouse or pencil\r\n this._enterCount = 0;\r\n }\r\n this._enterCount++;\r\n var canNotify = this.onPointerEnterObservable.notifyObservers(this, -1, target, this);\r\n if (canNotify && this.parent != null) {\r\n this.parent._onPointerEnter(target);\r\n }\r\n return true;\r\n };\r\n /** @hidden */\r\n Control.prototype._onPointerOut = function (target, force) {\r\n if (force === void 0) { force = false; }\r\n if (!force && (!this._isEnabled || target === this)) {\r\n return;\r\n }\r\n this._enterCount = 0;\r\n var canNotify = true;\r\n if (!target.isAscendant(this)) {\r\n canNotify = this.onPointerOutObservable.notifyObservers(this, -1, target, this);\r\n }\r\n if (canNotify && this.parent != null) {\r\n this.parent._onPointerOut(target, force);\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex) {\r\n // Prevent pointerout to lose control context.\r\n // Event redundancy is checked inside the function.\r\n this._onPointerEnter(this);\r\n if (this._downCount !== 0) {\r\n return false;\r\n }\r\n this._downCount++;\r\n this._downPointerIds[pointerId] = true;\r\n var canNotify = this.onPointerDownObservable.notifyObservers(new Vector2WithInfo(coordinates, buttonIndex), -1, target, this);\r\n if (canNotify && this.parent != null) {\r\n this.parent._onPointerDown(target, coordinates, pointerId, buttonIndex);\r\n }\r\n return true;\r\n };\r\n /** @hidden */\r\n Control.prototype._onPointerUp = function (target, coordinates, pointerId, buttonIndex, notifyClick) {\r\n if (!this._isEnabled) {\r\n return;\r\n }\r\n this._downCount = 0;\r\n delete this._downPointerIds[pointerId];\r\n var canNotifyClick = notifyClick;\r\n if (notifyClick && (this._enterCount > 0 || this._enterCount === -1)) {\r\n canNotifyClick = this.onPointerClickObservable.notifyObservers(new Vector2WithInfo(coordinates, buttonIndex), -1, target, this);\r\n }\r\n var canNotify = this.onPointerUpObservable.notifyObservers(new Vector2WithInfo(coordinates, buttonIndex), -1, target, this);\r\n if (canNotify && this.parent != null) {\r\n this.parent._onPointerUp(target, coordinates, pointerId, buttonIndex, canNotifyClick);\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._forcePointerUp = function (pointerId) {\r\n if (pointerId === void 0) { pointerId = null; }\r\n if (pointerId !== null) {\r\n this._onPointerUp(this, Vector2.Zero(), pointerId, 0, true);\r\n }\r\n else {\r\n for (var key in this._downPointerIds) {\r\n this._onPointerUp(this, Vector2.Zero(), +key, 0, true);\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._onWheelScroll = function (deltaX, deltaY) {\r\n if (!this._isEnabled) {\r\n return;\r\n }\r\n var canNotify = this.onWheelObservable.notifyObservers(new Vector2(deltaX, deltaY));\r\n if (canNotify && this.parent != null) {\r\n this.parent._onWheelScroll(deltaX, deltaY);\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._processObservables = function (type, x, y, pointerId, buttonIndex, deltaX, deltaY) {\r\n if (!this._isEnabled) {\r\n return false;\r\n }\r\n this._dummyVector2.copyFromFloats(x, y);\r\n if (type === PointerEventTypes.POINTERMOVE) {\r\n this._onPointerMove(this, this._dummyVector2, pointerId);\r\n var previousControlOver = this._host._lastControlOver[pointerId];\r\n if (previousControlOver && previousControlOver !== this) {\r\n previousControlOver._onPointerOut(this);\r\n }\r\n if (previousControlOver !== this) {\r\n this._onPointerEnter(this);\r\n }\r\n this._host._lastControlOver[pointerId] = this;\r\n return true;\r\n }\r\n if (type === PointerEventTypes.POINTERDOWN) {\r\n this._onPointerDown(this, this._dummyVector2, pointerId, buttonIndex);\r\n this._host._registerLastControlDown(this, pointerId);\r\n this._host._lastPickedControl = this;\r\n return true;\r\n }\r\n if (type === PointerEventTypes.POINTERUP) {\r\n if (this._host._lastControlDown[pointerId]) {\r\n this._host._lastControlDown[pointerId]._onPointerUp(this, this._dummyVector2, pointerId, buttonIndex, true);\r\n }\r\n delete this._host._lastControlDown[pointerId];\r\n return true;\r\n }\r\n if (type === PointerEventTypes.POINTERWHEEL) {\r\n if (this._host._lastControlOver[pointerId]) {\r\n this._host._lastControlOver[pointerId]._onWheelScroll(deltaX, deltaY);\r\n return true;\r\n }\r\n }\r\n return false;\r\n };\r\n Control.prototype._prepareFont = function () {\r\n if (!this._font && !this._fontSet) {\r\n return;\r\n }\r\n if (this._style) {\r\n this._font = this._style.fontStyle + \" \" + this._style.fontWeight + \" \" + this.fontSizeInPixels + \"px \" + this._style.fontFamily;\r\n }\r\n else {\r\n this._font = this._fontStyle + \" \" + this._fontWeight + \" \" + this.fontSizeInPixels + \"px \" + this._fontFamily;\r\n }\r\n this._fontOffset = Control._GetFontOffset(this._font);\r\n };\r\n /** Releases associated resources */\r\n Control.prototype.dispose = function () {\r\n this.onDirtyObservable.clear();\r\n this.onBeforeDrawObservable.clear();\r\n this.onAfterDrawObservable.clear();\r\n this.onPointerDownObservable.clear();\r\n this.onPointerEnterObservable.clear();\r\n this.onPointerMoveObservable.clear();\r\n this.onPointerOutObservable.clear();\r\n this.onPointerUpObservable.clear();\r\n this.onPointerClickObservable.clear();\r\n this.onWheelObservable.clear();\r\n if (this._styleObserver && this._style) {\r\n this._style.onChangedObservable.remove(this._styleObserver);\r\n this._styleObserver = null;\r\n }\r\n if (this.parent) {\r\n this.parent.removeControl(this);\r\n this.parent = null;\r\n }\r\n if (this._host) {\r\n var index = this._host._linkedControls.indexOf(this);\r\n if (index > -1) {\r\n this.linkWithMesh(null);\r\n }\r\n }\r\n };\r\n Object.defineProperty(Control, \"HORIZONTAL_ALIGNMENT_LEFT\", {\r\n /** HORIZONTAL_ALIGNMENT_LEFT */\r\n get: function () {\r\n return Control._HORIZONTAL_ALIGNMENT_LEFT;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control, \"HORIZONTAL_ALIGNMENT_RIGHT\", {\r\n /** HORIZONTAL_ALIGNMENT_RIGHT */\r\n get: function () {\r\n return Control._HORIZONTAL_ALIGNMENT_RIGHT;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control, \"HORIZONTAL_ALIGNMENT_CENTER\", {\r\n /** HORIZONTAL_ALIGNMENT_CENTER */\r\n get: function () {\r\n return Control._HORIZONTAL_ALIGNMENT_CENTER;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control, \"VERTICAL_ALIGNMENT_TOP\", {\r\n /** VERTICAL_ALIGNMENT_TOP */\r\n get: function () {\r\n return Control._VERTICAL_ALIGNMENT_TOP;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control, \"VERTICAL_ALIGNMENT_BOTTOM\", {\r\n /** VERTICAL_ALIGNMENT_BOTTOM */\r\n get: function () {\r\n return Control._VERTICAL_ALIGNMENT_BOTTOM;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control, \"VERTICAL_ALIGNMENT_CENTER\", {\r\n /** VERTICAL_ALIGNMENT_CENTER */\r\n get: function () {\r\n return Control._VERTICAL_ALIGNMENT_CENTER;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n Control._GetFontOffset = function (font) {\r\n if (Control._FontHeightSizes[font]) {\r\n return Control._FontHeightSizes[font];\r\n }\r\n var text = document.createElement(\"span\");\r\n text.innerHTML = \"Hg\";\r\n text.style.font = font;\r\n var block = document.createElement(\"div\");\r\n block.style.display = \"inline-block\";\r\n block.style.width = \"1px\";\r\n block.style.height = \"0px\";\r\n block.style.verticalAlign = \"bottom\";\r\n var div = document.createElement(\"div\");\r\n div.appendChild(text);\r\n div.appendChild(block);\r\n document.body.appendChild(div);\r\n var fontAscent = 0;\r\n var fontHeight = 0;\r\n try {\r\n fontHeight = block.getBoundingClientRect().top - text.getBoundingClientRect().top;\r\n block.style.verticalAlign = \"baseline\";\r\n fontAscent = block.getBoundingClientRect().top - text.getBoundingClientRect().top;\r\n }\r\n finally {\r\n document.body.removeChild(div);\r\n }\r\n var result = { ascent: fontAscent, height: fontHeight, descent: fontHeight - fontAscent };\r\n Control._FontHeightSizes[font] = result;\r\n return result;\r\n };\r\n /** @hidden */\r\n Control.drawEllipse = function (x, y, width, height, context) {\r\n context.translate(x, y);\r\n context.scale(width, height);\r\n context.beginPath();\r\n context.arc(0, 0, 1, 0, 2 * Math.PI);\r\n context.closePath();\r\n context.scale(1 / width, 1 / height);\r\n context.translate(-x, -y);\r\n };\r\n /**\r\n * Gets or sets a boolean indicating if alpha must be an inherited value (false by default)\r\n */\r\n Control.AllowAlphaInheritance = false;\r\n Control._ClipMeasure = new Measure(0, 0, 0, 0);\r\n // Statics\r\n Control._HORIZONTAL_ALIGNMENT_LEFT = 0;\r\n Control._HORIZONTAL_ALIGNMENT_RIGHT = 1;\r\n Control._HORIZONTAL_ALIGNMENT_CENTER = 2;\r\n Control._VERTICAL_ALIGNMENT_TOP = 0;\r\n Control._VERTICAL_ALIGNMENT_BOTTOM = 1;\r\n Control._VERTICAL_ALIGNMENT_CENTER = 2;\r\n Control._FontHeightSizes = {};\r\n /**\r\n * Creates a stack panel that can be used to render headers\r\n * @param control defines the control to associate with the header\r\n * @param text defines the text of the header\r\n * @param size defines the size of the header\r\n * @param options defines options used to configure the header\r\n * @returns a new StackPanel\r\n * @ignore\r\n * @hidden\r\n */\r\n Control.AddHeader = function () { };\r\n return Control;\r\n}());\r\nexport { Control };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Control\"] = Control;\r\n//# sourceMappingURL=control.js.map","import { Observable } from \"../Misc/observable\";\r\nimport { DomManagement } from \"../Misc/domManagement\";\r\nimport { Logger } from \"../Misc/logger\";\r\nimport { ShaderProcessor } from '../Engines/Processors/shaderProcessor';\r\n/**\r\n * Effect containing vertex and fragment shader that can be executed on an object.\r\n */\r\nvar Effect = /** @class */ (function () {\r\n /**\r\n * Instantiates an effect.\r\n * An effect can be used to create/manage/execute vertex and fragment shaders.\r\n * @param baseName Name of the effect.\r\n * @param attributesNamesOrOptions List of attribute names that will be passed to the shader or set of all options to create the effect.\r\n * @param uniformsNamesOrEngine List of uniform variable names that will be passed to the shader or the engine that will be used to render effect.\r\n * @param samplers List of sampler variables that will be passed to the shader.\r\n * @param engine Engine to be used to render the effect\r\n * @param defines Define statements to be added to the shader.\r\n * @param fallbacks Possible fallbacks for this effect to improve performance when needed.\r\n * @param onCompiled Callback that will be called when the shader is compiled.\r\n * @param onError Callback that will be called if an error occurs during shader compilation.\r\n * @param indexParameters Parameters to be used with Babylons include syntax to iterate over an array (eg. {lights: 10})\r\n */\r\n function Effect(baseName, attributesNamesOrOptions, uniformsNamesOrEngine, samplers, engine, defines, fallbacks, onCompiled, onError, indexParameters) {\r\n var _this = this;\r\n if (samplers === void 0) { samplers = null; }\r\n if (defines === void 0) { defines = null; }\r\n if (fallbacks === void 0) { fallbacks = null; }\r\n if (onCompiled === void 0) { onCompiled = null; }\r\n if (onError === void 0) { onError = null; }\r\n /**\r\n * Name of the effect.\r\n */\r\n this.name = null;\r\n /**\r\n * String container all the define statements that should be set on the shader.\r\n */\r\n this.defines = \"\";\r\n /**\r\n * Callback that will be called when the shader is compiled.\r\n */\r\n this.onCompiled = null;\r\n /**\r\n * Callback that will be called if an error occurs during shader compilation.\r\n */\r\n this.onError = null;\r\n /**\r\n * Callback that will be called when effect is bound.\r\n */\r\n this.onBind = null;\r\n /**\r\n * Unique ID of the effect.\r\n */\r\n this.uniqueId = 0;\r\n /**\r\n * Observable that will be called when the shader is compiled.\r\n * It is recommended to use executeWhenCompile() or to make sure that scene.isReady() is called to get this observable raised.\r\n */\r\n this.onCompileObservable = new Observable();\r\n /**\r\n * Observable that will be called if an error occurs during shader compilation.\r\n */\r\n this.onErrorObservable = new Observable();\r\n /** @hidden */\r\n this._onBindObservable = null;\r\n /**\r\n * @hidden\r\n * Specifies if the effect was previously ready\r\n */\r\n this._wasPreviouslyReady = false;\r\n /** @hidden */\r\n this._bonesComputationForcedToCPU = false;\r\n this._uniformBuffersNames = {};\r\n this._samplers = {};\r\n this._isReady = false;\r\n this._compilationError = \"\";\r\n this._allFallbacksProcessed = false;\r\n this._uniforms = {};\r\n /**\r\n * Key for the effect.\r\n * @hidden\r\n */\r\n this._key = \"\";\r\n this._fallbacks = null;\r\n this._vertexSourceCode = \"\";\r\n this._fragmentSourceCode = \"\";\r\n this._vertexSourceCodeOverride = \"\";\r\n this._fragmentSourceCodeOverride = \"\";\r\n this._transformFeedbackVaryings = null;\r\n /**\r\n * Compiled shader to webGL program.\r\n * @hidden\r\n */\r\n this._pipelineContext = null;\r\n this._valueCache = {};\r\n this.name = baseName;\r\n if (attributesNamesOrOptions.attributes) {\r\n var options = attributesNamesOrOptions;\r\n this._engine = uniformsNamesOrEngine;\r\n this._attributesNames = options.attributes;\r\n this._uniformsNames = options.uniformsNames.concat(options.samplers);\r\n this._samplerList = options.samplers.slice();\r\n this.defines = options.defines;\r\n this.onError = options.onError;\r\n this.onCompiled = options.onCompiled;\r\n this._fallbacks = options.fallbacks;\r\n this._indexParameters = options.indexParameters;\r\n this._transformFeedbackVaryings = options.transformFeedbackVaryings || null;\r\n if (options.uniformBuffersNames) {\r\n for (var i = 0; i < options.uniformBuffersNames.length; i++) {\r\n this._uniformBuffersNames[options.uniformBuffersNames[i]] = i;\r\n }\r\n }\r\n }\r\n else {\r\n this._engine = engine;\r\n this.defines = (defines == null ? \"\" : defines);\r\n this._uniformsNames = uniformsNamesOrEngine.concat(samplers);\r\n this._samplerList = samplers ? samplers.slice() : [];\r\n this._attributesNames = attributesNamesOrOptions;\r\n this.onError = onError;\r\n this.onCompiled = onCompiled;\r\n this._indexParameters = indexParameters;\r\n this._fallbacks = fallbacks;\r\n }\r\n this._attributeLocationByName = {};\r\n this.uniqueId = Effect._uniqueIdSeed++;\r\n var vertexSource;\r\n var fragmentSource;\r\n var hostDocument = DomManagement.IsWindowObjectExist() ? this._engine.getHostDocument() : null;\r\n if (baseName.vertexSource) {\r\n vertexSource = \"source:\" + baseName.vertexSource;\r\n }\r\n else if (baseName.vertexElement) {\r\n vertexSource = hostDocument ? hostDocument.getElementById(baseName.vertexElement) : null;\r\n if (!vertexSource) {\r\n vertexSource = baseName.vertexElement;\r\n }\r\n }\r\n else {\r\n vertexSource = baseName.vertex || baseName;\r\n }\r\n if (baseName.fragmentSource) {\r\n fragmentSource = \"source:\" + baseName.fragmentSource;\r\n }\r\n else if (baseName.fragmentElement) {\r\n fragmentSource = hostDocument ? hostDocument.getElementById(baseName.fragmentElement) : null;\r\n if (!fragmentSource) {\r\n fragmentSource = baseName.fragmentElement;\r\n }\r\n }\r\n else {\r\n fragmentSource = baseName.fragment || baseName;\r\n }\r\n var processorOptions = {\r\n defines: this.defines.split(\"\\n\"),\r\n indexParameters: this._indexParameters,\r\n isFragment: false,\r\n shouldUseHighPrecisionShader: this._engine._shouldUseHighPrecisionShader,\r\n processor: this._engine._shaderProcessor,\r\n supportsUniformBuffers: this._engine.supportsUniformBuffers,\r\n shadersRepository: Effect.ShadersRepository,\r\n includesShadersStore: Effect.IncludesShadersStore,\r\n version: (this._engine.webGLVersion * 100).toString(),\r\n platformName: this._engine.webGLVersion >= 2 ? \"WEBGL2\" : \"WEBGL1\"\r\n };\r\n this._loadShader(vertexSource, \"Vertex\", \"\", function (vertexCode) {\r\n _this._loadShader(fragmentSource, \"Fragment\", \"Pixel\", function (fragmentCode) {\r\n ShaderProcessor.Process(vertexCode, processorOptions, function (migratedVertexCode) {\r\n processorOptions.isFragment = true;\r\n ShaderProcessor.Process(fragmentCode, processorOptions, function (migratedFragmentCode) {\r\n _this._useFinalCode(migratedVertexCode, migratedFragmentCode, baseName);\r\n });\r\n });\r\n });\r\n });\r\n }\r\n Object.defineProperty(Effect.prototype, \"onBindObservable\", {\r\n /**\r\n * Observable that will be called when effect is bound.\r\n */\r\n get: function () {\r\n if (!this._onBindObservable) {\r\n this._onBindObservable = new Observable();\r\n }\r\n return this._onBindObservable;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Effect.prototype._useFinalCode = function (migratedVertexCode, migratedFragmentCode, baseName) {\r\n if (baseName) {\r\n var vertex = baseName.vertexElement || baseName.vertex || baseName.spectorName || baseName;\r\n var fragment = baseName.fragmentElement || baseName.fragment || baseName.spectorName || baseName;\r\n this._vertexSourceCode = \"#define SHADER_NAME vertex:\" + vertex + \"\\n\" + migratedVertexCode;\r\n this._fragmentSourceCode = \"#define SHADER_NAME fragment:\" + fragment + \"\\n\" + migratedFragmentCode;\r\n }\r\n else {\r\n this._vertexSourceCode = migratedVertexCode;\r\n this._fragmentSourceCode = migratedFragmentCode;\r\n }\r\n this._prepareEffect();\r\n };\r\n Object.defineProperty(Effect.prototype, \"key\", {\r\n /**\r\n * Unique key for this effect\r\n */\r\n get: function () {\r\n return this._key;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * If the effect has been compiled and prepared.\r\n * @returns if the effect is compiled and prepared.\r\n */\r\n Effect.prototype.isReady = function () {\r\n try {\r\n return this._isReadyInternal();\r\n }\r\n catch (_a) {\r\n return false;\r\n }\r\n };\r\n Effect.prototype._isReadyInternal = function () {\r\n if (this._isReady) {\r\n return true;\r\n }\r\n if (this._pipelineContext) {\r\n return this._pipelineContext.isReady;\r\n }\r\n return false;\r\n };\r\n /**\r\n * The engine the effect was initialized with.\r\n * @returns the engine.\r\n */\r\n Effect.prototype.getEngine = function () {\r\n return this._engine;\r\n };\r\n /**\r\n * The pipeline context for this effect\r\n * @returns the associated pipeline context\r\n */\r\n Effect.prototype.getPipelineContext = function () {\r\n return this._pipelineContext;\r\n };\r\n /**\r\n * The set of names of attribute variables for the shader.\r\n * @returns An array of attribute names.\r\n */\r\n Effect.prototype.getAttributesNames = function () {\r\n return this._attributesNames;\r\n };\r\n /**\r\n * Returns the attribute at the given index.\r\n * @param index The index of the attribute.\r\n * @returns The location of the attribute.\r\n */\r\n Effect.prototype.getAttributeLocation = function (index) {\r\n return this._attributes[index];\r\n };\r\n /**\r\n * Returns the attribute based on the name of the variable.\r\n * @param name of the attribute to look up.\r\n * @returns the attribute location.\r\n */\r\n Effect.prototype.getAttributeLocationByName = function (name) {\r\n return this._attributeLocationByName[name];\r\n };\r\n /**\r\n * The number of attributes.\r\n * @returns the numnber of attributes.\r\n */\r\n Effect.prototype.getAttributesCount = function () {\r\n return this._attributes.length;\r\n };\r\n /**\r\n * Gets the index of a uniform variable.\r\n * @param uniformName of the uniform to look up.\r\n * @returns the index.\r\n */\r\n Effect.prototype.getUniformIndex = function (uniformName) {\r\n return this._uniformsNames.indexOf(uniformName);\r\n };\r\n /**\r\n * Returns the attribute based on the name of the variable.\r\n * @param uniformName of the uniform to look up.\r\n * @returns the location of the uniform.\r\n */\r\n Effect.prototype.getUniform = function (uniformName) {\r\n return this._uniforms[uniformName];\r\n };\r\n /**\r\n * Returns an array of sampler variable names\r\n * @returns The array of sampler variable neames.\r\n */\r\n Effect.prototype.getSamplers = function () {\r\n return this._samplerList;\r\n };\r\n /**\r\n * The error from the last compilation.\r\n * @returns the error string.\r\n */\r\n Effect.prototype.getCompilationError = function () {\r\n return this._compilationError;\r\n };\r\n /**\r\n * Gets a boolean indicating that all fallbacks were used during compilation\r\n * @returns true if all fallbacks were used\r\n */\r\n Effect.prototype.allFallbacksProcessed = function () {\r\n return this._allFallbacksProcessed;\r\n };\r\n /**\r\n * Adds a callback to the onCompiled observable and call the callback imediatly if already ready.\r\n * @param func The callback to be used.\r\n */\r\n Effect.prototype.executeWhenCompiled = function (func) {\r\n var _this = this;\r\n if (this.isReady()) {\r\n func(this);\r\n return;\r\n }\r\n this.onCompileObservable.add(function (effect) {\r\n func(effect);\r\n });\r\n if (!this._pipelineContext || this._pipelineContext.isAsync) {\r\n setTimeout(function () {\r\n _this._checkIsReady(null);\r\n }, 16);\r\n }\r\n };\r\n Effect.prototype._checkIsReady = function (previousPipelineContext) {\r\n var _this = this;\r\n try {\r\n if (this._isReadyInternal()) {\r\n return;\r\n }\r\n }\r\n catch (e) {\r\n this._processCompilationErrors(e, previousPipelineContext);\r\n return;\r\n }\r\n setTimeout(function () {\r\n _this._checkIsReady(previousPipelineContext);\r\n }, 16);\r\n };\r\n Effect.prototype._loadShader = function (shader, key, optionalKey, callback) {\r\n if (typeof (HTMLElement) !== \"undefined\") {\r\n // DOM element ?\r\n if (shader instanceof HTMLElement) {\r\n var shaderCode = DomManagement.GetDOMTextContent(shader);\r\n callback(shaderCode);\r\n return;\r\n }\r\n }\r\n // Direct source ?\r\n if (shader.substr(0, 7) === \"source:\") {\r\n callback(shader.substr(7));\r\n return;\r\n }\r\n // Base64 encoded ?\r\n if (shader.substr(0, 7) === \"base64:\") {\r\n var shaderBinary = window.atob(shader.substr(7));\r\n callback(shaderBinary);\r\n return;\r\n }\r\n // Is in local store ?\r\n if (Effect.ShadersStore[shader + key + \"Shader\"]) {\r\n callback(Effect.ShadersStore[shader + key + \"Shader\"]);\r\n return;\r\n }\r\n if (optionalKey && Effect.ShadersStore[shader + optionalKey + \"Shader\"]) {\r\n callback(Effect.ShadersStore[shader + optionalKey + \"Shader\"]);\r\n return;\r\n }\r\n var shaderUrl;\r\n if (shader[0] === \".\" || shader[0] === \"/\" || shader.indexOf(\"http\") > -1) {\r\n shaderUrl = shader;\r\n }\r\n else {\r\n shaderUrl = Effect.ShadersRepository + shader;\r\n }\r\n // Vertex shader\r\n this._engine._loadFile(shaderUrl + \".\" + key.toLowerCase() + \".fx\", callback);\r\n };\r\n /**\r\n * Recompiles the webGL program\r\n * @param vertexSourceCode The source code for the vertex shader.\r\n * @param fragmentSourceCode The source code for the fragment shader.\r\n * @param onCompiled Callback called when completed.\r\n * @param onError Callback called on error.\r\n * @hidden\r\n */\r\n Effect.prototype._rebuildProgram = function (vertexSourceCode, fragmentSourceCode, onCompiled, onError) {\r\n var _this = this;\r\n this._isReady = false;\r\n this._vertexSourceCodeOverride = vertexSourceCode;\r\n this._fragmentSourceCodeOverride = fragmentSourceCode;\r\n this.onError = function (effect, error) {\r\n if (onError) {\r\n onError(error);\r\n }\r\n };\r\n this.onCompiled = function () {\r\n var scenes = _this.getEngine().scenes;\r\n if (scenes) {\r\n for (var i = 0; i < scenes.length; i++) {\r\n scenes[i].markAllMaterialsAsDirty(31);\r\n }\r\n }\r\n _this._pipelineContext._handlesSpectorRebuildCallback(onCompiled);\r\n };\r\n this._fallbacks = null;\r\n this._prepareEffect();\r\n };\r\n /**\r\n * Prepares the effect\r\n * @hidden\r\n */\r\n Effect.prototype._prepareEffect = function () {\r\n var _this = this;\r\n var attributesNames = this._attributesNames;\r\n var defines = this.defines;\r\n this._valueCache = {};\r\n var previousPipelineContext = this._pipelineContext;\r\n try {\r\n var engine_1 = this._engine;\r\n this._pipelineContext = engine_1.createPipelineContext();\r\n var rebuildRebind = this._rebuildProgram.bind(this);\r\n if (this._vertexSourceCodeOverride && this._fragmentSourceCodeOverride) {\r\n engine_1._preparePipelineContext(this._pipelineContext, this._vertexSourceCodeOverride, this._fragmentSourceCodeOverride, true, rebuildRebind, null, this._transformFeedbackVaryings);\r\n }\r\n else {\r\n engine_1._preparePipelineContext(this._pipelineContext, this._vertexSourceCode, this._fragmentSourceCode, false, rebuildRebind, defines, this._transformFeedbackVaryings);\r\n }\r\n engine_1._executeWhenRenderingStateIsCompiled(this._pipelineContext, function () {\r\n if (engine_1.supportsUniformBuffers) {\r\n for (var name in _this._uniformBuffersNames) {\r\n _this.bindUniformBlock(name, _this._uniformBuffersNames[name]);\r\n }\r\n }\r\n var uniforms = engine_1.getUniforms(_this._pipelineContext, _this._uniformsNames);\r\n uniforms.forEach(function (uniform, index) {\r\n _this._uniforms[_this._uniformsNames[index]] = uniform;\r\n });\r\n _this._attributes = engine_1.getAttributes(_this._pipelineContext, attributesNames);\r\n if (attributesNames) {\r\n for (var i = 0; i < attributesNames.length; i++) {\r\n var name_1 = attributesNames[i];\r\n _this._attributeLocationByName[name_1] = _this._attributes[i];\r\n }\r\n }\r\n var index;\r\n for (index = 0; index < _this._samplerList.length; index++) {\r\n var sampler = _this.getUniform(_this._samplerList[index]);\r\n if (sampler == null) {\r\n _this._samplerList.splice(index, 1);\r\n index--;\r\n }\r\n }\r\n _this._samplerList.forEach(function (name, index) {\r\n _this._samplers[name] = index;\r\n });\r\n engine_1.bindSamplers(_this);\r\n _this._compilationError = \"\";\r\n _this._isReady = true;\r\n if (_this.onCompiled) {\r\n _this.onCompiled(_this);\r\n }\r\n _this.onCompileObservable.notifyObservers(_this);\r\n _this.onCompileObservable.clear();\r\n // Unbind mesh reference in fallbacks\r\n if (_this._fallbacks) {\r\n _this._fallbacks.unBindMesh();\r\n }\r\n if (previousPipelineContext) {\r\n _this.getEngine()._deletePipelineContext(previousPipelineContext);\r\n }\r\n });\r\n if (this._pipelineContext.isAsync) {\r\n this._checkIsReady(previousPipelineContext);\r\n }\r\n }\r\n catch (e) {\r\n this._processCompilationErrors(e, previousPipelineContext);\r\n }\r\n };\r\n Effect.prototype._processCompilationErrors = function (e, previousPipelineContext) {\r\n if (previousPipelineContext === void 0) { previousPipelineContext = null; }\r\n this._compilationError = e.message;\r\n var attributesNames = this._attributesNames;\r\n var fallbacks = this._fallbacks;\r\n // Let's go through fallbacks then\r\n Logger.Error(\"Unable to compile effect:\");\r\n Logger.Error(\"Uniforms: \" + this._uniformsNames.map(function (uniform) {\r\n return \" \" + uniform;\r\n }));\r\n Logger.Error(\"Attributes: \" + attributesNames.map(function (attribute) {\r\n return \" \" + attribute;\r\n }));\r\n Logger.Error(\"Defines:\\r\\n\" + this.defines);\r\n Logger.Error(\"Error: \" + this._compilationError);\r\n if (previousPipelineContext) {\r\n this._pipelineContext = previousPipelineContext;\r\n this._isReady = true;\r\n if (this.onError) {\r\n this.onError(this, this._compilationError);\r\n }\r\n this.onErrorObservable.notifyObservers(this);\r\n }\r\n if (fallbacks) {\r\n this._pipelineContext = null;\r\n if (fallbacks.hasMoreFallbacks) {\r\n this._allFallbacksProcessed = false;\r\n Logger.Error(\"Trying next fallback.\");\r\n this.defines = fallbacks.reduce(this.defines, this);\r\n this._prepareEffect();\r\n }\r\n else { // Sorry we did everything we can\r\n this._allFallbacksProcessed = true;\r\n if (this.onError) {\r\n this.onError(this, this._compilationError);\r\n }\r\n this.onErrorObservable.notifyObservers(this);\r\n this.onErrorObservable.clear();\r\n // Unbind mesh reference in fallbacks\r\n if (this._fallbacks) {\r\n this._fallbacks.unBindMesh();\r\n }\r\n }\r\n }\r\n else {\r\n this._allFallbacksProcessed = true;\r\n }\r\n };\r\n Object.defineProperty(Effect.prototype, \"isSupported\", {\r\n /**\r\n * Checks if the effect is supported. (Must be called after compilation)\r\n */\r\n get: function () {\r\n return this._compilationError === \"\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Binds a texture to the engine to be used as output of the shader.\r\n * @param channel Name of the output variable.\r\n * @param texture Texture to bind.\r\n * @hidden\r\n */\r\n Effect.prototype._bindTexture = function (channel, texture) {\r\n this._engine._bindTexture(this._samplers[channel], texture);\r\n };\r\n /**\r\n * Sets a texture on the engine to be used in the shader.\r\n * @param channel Name of the sampler variable.\r\n * @param texture Texture to set.\r\n */\r\n Effect.prototype.setTexture = function (channel, texture) {\r\n this._engine.setTexture(this._samplers[channel], this._uniforms[channel], texture);\r\n };\r\n /**\r\n * Sets a depth stencil texture from a render target on the engine to be used in the shader.\r\n * @param channel Name of the sampler variable.\r\n * @param texture Texture to set.\r\n */\r\n Effect.prototype.setDepthStencilTexture = function (channel, texture) {\r\n this._engine.setDepthStencilTexture(this._samplers[channel], this._uniforms[channel], texture);\r\n };\r\n /**\r\n * Sets an array of textures on the engine to be used in the shader.\r\n * @param channel Name of the variable.\r\n * @param textures Textures to set.\r\n */\r\n Effect.prototype.setTextureArray = function (channel, textures) {\r\n var exName = channel + \"Ex\";\r\n if (this._samplerList.indexOf(exName + \"0\") === -1) {\r\n var initialPos = this._samplerList.indexOf(channel);\r\n for (var index = 1; index < textures.length; index++) {\r\n var currentExName = exName + (index - 1).toString();\r\n this._samplerList.splice(initialPos + index, 0, currentExName);\r\n }\r\n // Reset every channels\r\n var channelIndex = 0;\r\n for (var _i = 0, _a = this._samplerList; _i < _a.length; _i++) {\r\n var key = _a[_i];\r\n this._samplers[key] = channelIndex;\r\n channelIndex += 1;\r\n }\r\n }\r\n this._engine.setTextureArray(this._samplers[channel], this._uniforms[channel], textures);\r\n };\r\n /**\r\n * Sets a texture to be the input of the specified post process. (To use the output, pass in the next post process in the pipeline)\r\n * @param channel Name of the sampler variable.\r\n * @param postProcess Post process to get the input texture from.\r\n */\r\n Effect.prototype.setTextureFromPostProcess = function (channel, postProcess) {\r\n this._engine.setTextureFromPostProcess(this._samplers[channel], postProcess);\r\n };\r\n /**\r\n * (Warning! setTextureFromPostProcessOutput may be desired instead)\r\n * Sets the input texture of the passed in post process to be input of this effect. (To use the output of the passed in post process use setTextureFromPostProcessOutput)\r\n * @param channel Name of the sampler variable.\r\n * @param postProcess Post process to get the output texture from.\r\n */\r\n Effect.prototype.setTextureFromPostProcessOutput = function (channel, postProcess) {\r\n this._engine.setTextureFromPostProcessOutput(this._samplers[channel], postProcess);\r\n };\r\n /** @hidden */\r\n Effect.prototype._cacheMatrix = function (uniformName, matrix) {\r\n var cache = this._valueCache[uniformName];\r\n var flag = matrix.updateFlag;\r\n if (cache !== undefined && cache === flag) {\r\n return false;\r\n }\r\n this._valueCache[uniformName] = flag;\r\n return true;\r\n };\r\n /** @hidden */\r\n Effect.prototype._cacheFloat2 = function (uniformName, x, y) {\r\n var cache = this._valueCache[uniformName];\r\n if (!cache || cache.length !== 2) {\r\n cache = [x, y];\r\n this._valueCache[uniformName] = cache;\r\n return true;\r\n }\r\n var changed = false;\r\n if (cache[0] !== x) {\r\n cache[0] = x;\r\n changed = true;\r\n }\r\n if (cache[1] !== y) {\r\n cache[1] = y;\r\n changed = true;\r\n }\r\n return changed;\r\n };\r\n /** @hidden */\r\n Effect.prototype._cacheFloat3 = function (uniformName, x, y, z) {\r\n var cache = this._valueCache[uniformName];\r\n if (!cache || cache.length !== 3) {\r\n cache = [x, y, z];\r\n this._valueCache[uniformName] = cache;\r\n return true;\r\n }\r\n var changed = false;\r\n if (cache[0] !== x) {\r\n cache[0] = x;\r\n changed = true;\r\n }\r\n if (cache[1] !== y) {\r\n cache[1] = y;\r\n changed = true;\r\n }\r\n if (cache[2] !== z) {\r\n cache[2] = z;\r\n changed = true;\r\n }\r\n return changed;\r\n };\r\n /** @hidden */\r\n Effect.prototype._cacheFloat4 = function (uniformName, x, y, z, w) {\r\n var cache = this._valueCache[uniformName];\r\n if (!cache || cache.length !== 4) {\r\n cache = [x, y, z, w];\r\n this._valueCache[uniformName] = cache;\r\n return true;\r\n }\r\n var changed = false;\r\n if (cache[0] !== x) {\r\n cache[0] = x;\r\n changed = true;\r\n }\r\n if (cache[1] !== y) {\r\n cache[1] = y;\r\n changed = true;\r\n }\r\n if (cache[2] !== z) {\r\n cache[2] = z;\r\n changed = true;\r\n }\r\n if (cache[3] !== w) {\r\n cache[3] = w;\r\n changed = true;\r\n }\r\n return changed;\r\n };\r\n /**\r\n * Binds a buffer to a uniform.\r\n * @param buffer Buffer to bind.\r\n * @param name Name of the uniform variable to bind to.\r\n */\r\n Effect.prototype.bindUniformBuffer = function (buffer, name) {\r\n var bufferName = this._uniformBuffersNames[name];\r\n if (bufferName === undefined || Effect._baseCache[bufferName] === buffer) {\r\n return;\r\n }\r\n Effect._baseCache[bufferName] = buffer;\r\n this._engine.bindUniformBufferBase(buffer, bufferName);\r\n };\r\n /**\r\n * Binds block to a uniform.\r\n * @param blockName Name of the block to bind.\r\n * @param index Index to bind.\r\n */\r\n Effect.prototype.bindUniformBlock = function (blockName, index) {\r\n this._engine.bindUniformBlock(this._pipelineContext, blockName, index);\r\n };\r\n /**\r\n * Sets an interger value on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param value Value to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setInt = function (uniformName, value) {\r\n var cache = this._valueCache[uniformName];\r\n if (cache !== undefined && cache === value) {\r\n return this;\r\n }\r\n this._valueCache[uniformName] = value;\r\n this._engine.setInt(this._uniforms[uniformName], value);\r\n return this;\r\n };\r\n /**\r\n * Sets an int array on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setIntArray = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setIntArray(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an int array 2 on a uniform variable. (Array is specified as single array eg. [1,2,3,4] will result in [[1,2],[3,4]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setIntArray2 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setIntArray2(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an int array 3 on a uniform variable. (Array is specified as single array eg. [1,2,3,4,5,6] will result in [[1,2,3],[4,5,6]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setIntArray3 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setIntArray3(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an int array 4 on a uniform variable. (Array is specified as single array eg. [1,2,3,4,5,6,7,8] will result in [[1,2,3,4],[5,6,7,8]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setIntArray4 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setIntArray4(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an float array on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setFloatArray = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setArray(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an float array 2 on a uniform variable. (Array is specified as single array eg. [1,2,3,4] will result in [[1,2],[3,4]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setFloatArray2 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setArray2(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an float array 3 on a uniform variable. (Array is specified as single array eg. [1,2,3,4,5,6] will result in [[1,2,3],[4,5,6]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setFloatArray3 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setArray3(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an float array 4 on a uniform variable. (Array is specified as single array eg. [1,2,3,4,5,6,7,8] will result in [[1,2,3,4],[5,6,7,8]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setFloatArray4 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setArray4(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an array on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setArray = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setArray(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an array 2 on a uniform variable. (Array is specified as single array eg. [1,2,3,4] will result in [[1,2],[3,4]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setArray2 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setArray2(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an array 3 on a uniform variable. (Array is specified as single array eg. [1,2,3,4,5,6] will result in [[1,2,3],[4,5,6]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setArray3 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setArray3(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an array 4 on a uniform variable. (Array is specified as single array eg. [1,2,3,4,5,6,7,8] will result in [[1,2,3,4],[5,6,7,8]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setArray4 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setArray4(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets matrices on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param matrices matrices to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setMatrices = function (uniformName, matrices) {\r\n if (!matrices) {\r\n return this;\r\n }\r\n this._valueCache[uniformName] = null;\r\n this._engine.setMatrices(this._uniforms[uniformName], matrices);\r\n return this;\r\n };\r\n /**\r\n * Sets matrix on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param matrix matrix to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setMatrix = function (uniformName, matrix) {\r\n if (this._cacheMatrix(uniformName, matrix)) {\r\n this._engine.setMatrices(this._uniforms[uniformName], matrix.toArray());\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a 3x3 matrix on a uniform variable. (Speicified as [1,2,3,4,5,6,7,8,9] will result in [1,2,3][4,5,6][7,8,9] matrix)\r\n * @param uniformName Name of the variable.\r\n * @param matrix matrix to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setMatrix3x3 = function (uniformName, matrix) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setMatrix3x3(this._uniforms[uniformName], matrix);\r\n return this;\r\n };\r\n /**\r\n * Sets a 2x2 matrix on a uniform variable. (Speicified as [1,2,3,4] will result in [1,2][3,4] matrix)\r\n * @param uniformName Name of the variable.\r\n * @param matrix matrix to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setMatrix2x2 = function (uniformName, matrix) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setMatrix2x2(this._uniforms[uniformName], matrix);\r\n return this;\r\n };\r\n /**\r\n * Sets a float on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param value value to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setFloat = function (uniformName, value) {\r\n var cache = this._valueCache[uniformName];\r\n if (cache !== undefined && cache === value) {\r\n return this;\r\n }\r\n this._valueCache[uniformName] = value;\r\n this._engine.setFloat(this._uniforms[uniformName], value);\r\n return this;\r\n };\r\n /**\r\n * Sets a boolean on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param bool value to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setBool = function (uniformName, bool) {\r\n var cache = this._valueCache[uniformName];\r\n if (cache !== undefined && cache === bool) {\r\n return this;\r\n }\r\n this._valueCache[uniformName] = bool;\r\n this._engine.setInt(this._uniforms[uniformName], bool ? 1 : 0);\r\n return this;\r\n };\r\n /**\r\n * Sets a Vector2 on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param vector2 vector2 to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setVector2 = function (uniformName, vector2) {\r\n if (this._cacheFloat2(uniformName, vector2.x, vector2.y)) {\r\n this._engine.setFloat2(this._uniforms[uniformName], vector2.x, vector2.y);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a float2 on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param x First float in float2.\r\n * @param y Second float in float2.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setFloat2 = function (uniformName, x, y) {\r\n if (this._cacheFloat2(uniformName, x, y)) {\r\n this._engine.setFloat2(this._uniforms[uniformName], x, y);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a Vector3 on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param vector3 Value to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setVector3 = function (uniformName, vector3) {\r\n if (this._cacheFloat3(uniformName, vector3.x, vector3.y, vector3.z)) {\r\n this._engine.setFloat3(this._uniforms[uniformName], vector3.x, vector3.y, vector3.z);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a float3 on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param x First float in float3.\r\n * @param y Second float in float3.\r\n * @param z Third float in float3.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setFloat3 = function (uniformName, x, y, z) {\r\n if (this._cacheFloat3(uniformName, x, y, z)) {\r\n this._engine.setFloat3(this._uniforms[uniformName], x, y, z);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a Vector4 on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param vector4 Value to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setVector4 = function (uniformName, vector4) {\r\n if (this._cacheFloat4(uniformName, vector4.x, vector4.y, vector4.z, vector4.w)) {\r\n this._engine.setFloat4(this._uniforms[uniformName], vector4.x, vector4.y, vector4.z, vector4.w);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a float4 on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param x First float in float4.\r\n * @param y Second float in float4.\r\n * @param z Third float in float4.\r\n * @param w Fourth float in float4.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setFloat4 = function (uniformName, x, y, z, w) {\r\n if (this._cacheFloat4(uniformName, x, y, z, w)) {\r\n this._engine.setFloat4(this._uniforms[uniformName], x, y, z, w);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a Color3 on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param color3 Value to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setColor3 = function (uniformName, color3) {\r\n if (this._cacheFloat3(uniformName, color3.r, color3.g, color3.b)) {\r\n this._engine.setFloat3(this._uniforms[uniformName], color3.r, color3.g, color3.b);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a Color4 on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param color3 Value to be set.\r\n * @param alpha Alpha value to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setColor4 = function (uniformName, color3, alpha) {\r\n if (this._cacheFloat4(uniformName, color3.r, color3.g, color3.b, alpha)) {\r\n this._engine.setFloat4(this._uniforms[uniformName], color3.r, color3.g, color3.b, alpha);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a Color4 on a uniform variable\r\n * @param uniformName defines the name of the variable\r\n * @param color4 defines the value to be set\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setDirectColor4 = function (uniformName, color4) {\r\n if (this._cacheFloat4(uniformName, color4.r, color4.g, color4.b, color4.a)) {\r\n this._engine.setFloat4(this._uniforms[uniformName], color4.r, color4.g, color4.b, color4.a);\r\n }\r\n return this;\r\n };\r\n /** Release all associated resources */\r\n Effect.prototype.dispose = function () {\r\n this._engine._releaseEffect(this);\r\n };\r\n /**\r\n * This function will add a new shader to the shader store\r\n * @param name the name of the shader\r\n * @param pixelShader optional pixel shader content\r\n * @param vertexShader optional vertex shader content\r\n */\r\n Effect.RegisterShader = function (name, pixelShader, vertexShader) {\r\n if (pixelShader) {\r\n Effect.ShadersStore[name + \"PixelShader\"] = pixelShader;\r\n }\r\n if (vertexShader) {\r\n Effect.ShadersStore[name + \"VertexShader\"] = vertexShader;\r\n }\r\n };\r\n /**\r\n * Resets the cache of effects.\r\n */\r\n Effect.ResetCache = function () {\r\n Effect._baseCache = {};\r\n };\r\n /**\r\n * Gets or sets the relative url used to load shaders if using the engine in non-minified mode\r\n */\r\n Effect.ShadersRepository = \"src/Shaders/\";\r\n Effect._uniqueIdSeed = 0;\r\n Effect._baseCache = {};\r\n /**\r\n * Store of each shader (The can be looked up using effect.key)\r\n */\r\n Effect.ShadersStore = {};\r\n /**\r\n * Store of each included file for a shader (The can be looked up using effect.key)\r\n */\r\n Effect.IncludesShadersStore = {};\r\n return Effect;\r\n}());\r\nexport { Effect };\r\n//# sourceMappingURL=effect.js.map","import { Scalar } from './math.scalar';\r\nimport { ToLinearSpace, ToGammaSpace } from './math.constants';\r\nimport { ArrayTools } from '../Misc/arrayTools';\r\nimport { _TypeStore } from '../Misc/typeStore';\r\n/**\r\n * Class used to hold a RBG color\r\n */\r\nvar Color3 = /** @class */ (function () {\r\n /**\r\n * Creates a new Color3 object from red, green, blue values, all between 0 and 1\r\n * @param r defines the red component (between 0 and 1, default is 0)\r\n * @param g defines the green component (between 0 and 1, default is 0)\r\n * @param b defines the blue component (between 0 and 1, default is 0)\r\n */\r\n function Color3(\r\n /**\r\n * Defines the red component (between 0 and 1, default is 0)\r\n */\r\n r, \r\n /**\r\n * Defines the green component (between 0 and 1, default is 0)\r\n */\r\n g, \r\n /**\r\n * Defines the blue component (between 0 and 1, default is 0)\r\n */\r\n b) {\r\n if (r === void 0) { r = 0; }\r\n if (g === void 0) { g = 0; }\r\n if (b === void 0) { b = 0; }\r\n this.r = r;\r\n this.g = g;\r\n this.b = b;\r\n }\r\n /**\r\n * Creates a string with the Color3 current values\r\n * @returns the string representation of the Color3 object\r\n */\r\n Color3.prototype.toString = function () {\r\n return \"{R: \" + this.r + \" G:\" + this.g + \" B:\" + this.b + \"}\";\r\n };\r\n /**\r\n * Returns the string \"Color3\"\r\n * @returns \"Color3\"\r\n */\r\n Color3.prototype.getClassName = function () {\r\n return \"Color3\";\r\n };\r\n /**\r\n * Compute the Color3 hash code\r\n * @returns an unique number that can be used to hash Color3 objects\r\n */\r\n Color3.prototype.getHashCode = function () {\r\n var hash = (this.r * 255) | 0;\r\n hash = (hash * 397) ^ ((this.g * 255) | 0);\r\n hash = (hash * 397) ^ ((this.b * 255) | 0);\r\n return hash;\r\n };\r\n // Operators\r\n /**\r\n * Stores in the given array from the given starting index the red, green, blue values as successive elements\r\n * @param array defines the array where to store the r,g,b components\r\n * @param index defines an optional index in the target array to define where to start storing values\r\n * @returns the current Color3 object\r\n */\r\n Color3.prototype.toArray = function (array, index) {\r\n if (index === void 0) { index = 0; }\r\n array[index] = this.r;\r\n array[index + 1] = this.g;\r\n array[index + 2] = this.b;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Color4 object from the current Color3 and the given alpha\r\n * @param alpha defines the alpha component on the new Color4 object (default is 1)\r\n * @returns a new Color4 object\r\n */\r\n Color3.prototype.toColor4 = function (alpha) {\r\n if (alpha === void 0) { alpha = 1; }\r\n return new Color4(this.r, this.g, this.b, alpha);\r\n };\r\n /**\r\n * Returns a new array populated with 3 numeric elements : red, green and blue values\r\n * @returns the new array\r\n */\r\n Color3.prototype.asArray = function () {\r\n var result = new Array();\r\n this.toArray(result, 0);\r\n return result;\r\n };\r\n /**\r\n * Returns the luminance value\r\n * @returns a float value\r\n */\r\n Color3.prototype.toLuminance = function () {\r\n return this.r * 0.3 + this.g * 0.59 + this.b * 0.11;\r\n };\r\n /**\r\n * Multiply each Color3 rgb values by the given Color3 rgb values in a new Color3 object\r\n * @param otherColor defines the second operand\r\n * @returns the new Color3 object\r\n */\r\n Color3.prototype.multiply = function (otherColor) {\r\n return new Color3(this.r * otherColor.r, this.g * otherColor.g, this.b * otherColor.b);\r\n };\r\n /**\r\n * Multiply the rgb values of the Color3 and the given Color3 and stores the result in the object \"result\"\r\n * @param otherColor defines the second operand\r\n * @param result defines the Color3 object where to store the result\r\n * @returns the current Color3\r\n */\r\n Color3.prototype.multiplyToRef = function (otherColor, result) {\r\n result.r = this.r * otherColor.r;\r\n result.g = this.g * otherColor.g;\r\n result.b = this.b * otherColor.b;\r\n return this;\r\n };\r\n /**\r\n * Determines equality between Color3 objects\r\n * @param otherColor defines the second operand\r\n * @returns true if the rgb values are equal to the given ones\r\n */\r\n Color3.prototype.equals = function (otherColor) {\r\n return otherColor && this.r === otherColor.r && this.g === otherColor.g && this.b === otherColor.b;\r\n };\r\n /**\r\n * Determines equality between the current Color3 object and a set of r,b,g values\r\n * @param r defines the red component to check\r\n * @param g defines the green component to check\r\n * @param b defines the blue component to check\r\n * @returns true if the rgb values are equal to the given ones\r\n */\r\n Color3.prototype.equalsFloats = function (r, g, b) {\r\n return this.r === r && this.g === g && this.b === b;\r\n };\r\n /**\r\n * Multiplies in place each rgb value by scale\r\n * @param scale defines the scaling factor\r\n * @returns the updated Color3\r\n */\r\n Color3.prototype.scale = function (scale) {\r\n return new Color3(this.r * scale, this.g * scale, this.b * scale);\r\n };\r\n /**\r\n * Multiplies the rgb values by scale and stores the result into \"result\"\r\n * @param scale defines the scaling factor\r\n * @param result defines the Color3 object where to store the result\r\n * @returns the unmodified current Color3\r\n */\r\n Color3.prototype.scaleToRef = function (scale, result) {\r\n result.r = this.r * scale;\r\n result.g = this.g * scale;\r\n result.b = this.b * scale;\r\n return this;\r\n };\r\n /**\r\n * Scale the current Color3 values by a factor and add the result to a given Color3\r\n * @param scale defines the scale factor\r\n * @param result defines color to store the result into\r\n * @returns the unmodified current Color3\r\n */\r\n Color3.prototype.scaleAndAddToRef = function (scale, result) {\r\n result.r += this.r * scale;\r\n result.g += this.g * scale;\r\n result.b += this.b * scale;\r\n return this;\r\n };\r\n /**\r\n * Clamps the rgb values by the min and max values and stores the result into \"result\"\r\n * @param min defines minimum clamping value (default is 0)\r\n * @param max defines maximum clamping value (default is 1)\r\n * @param result defines color to store the result into\r\n * @returns the original Color3\r\n */\r\n Color3.prototype.clampToRef = function (min, max, result) {\r\n if (min === void 0) { min = 0; }\r\n if (max === void 0) { max = 1; }\r\n result.r = Scalar.Clamp(this.r, min, max);\r\n result.g = Scalar.Clamp(this.g, min, max);\r\n result.b = Scalar.Clamp(this.b, min, max);\r\n return this;\r\n };\r\n /**\r\n * Creates a new Color3 set with the added values of the current Color3 and of the given one\r\n * @param otherColor defines the second operand\r\n * @returns the new Color3\r\n */\r\n Color3.prototype.add = function (otherColor) {\r\n return new Color3(this.r + otherColor.r, this.g + otherColor.g, this.b + otherColor.b);\r\n };\r\n /**\r\n * Stores the result of the addition of the current Color3 and given one rgb values into \"result\"\r\n * @param otherColor defines the second operand\r\n * @param result defines Color3 object to store the result into\r\n * @returns the unmodified current Color3\r\n */\r\n Color3.prototype.addToRef = function (otherColor, result) {\r\n result.r = this.r + otherColor.r;\r\n result.g = this.g + otherColor.g;\r\n result.b = this.b + otherColor.b;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Color3 set with the subtracted values of the given one from the current Color3\r\n * @param otherColor defines the second operand\r\n * @returns the new Color3\r\n */\r\n Color3.prototype.subtract = function (otherColor) {\r\n return new Color3(this.r - otherColor.r, this.g - otherColor.g, this.b - otherColor.b);\r\n };\r\n /**\r\n * Stores the result of the subtraction of given one from the current Color3 rgb values into \"result\"\r\n * @param otherColor defines the second operand\r\n * @param result defines Color3 object to store the result into\r\n * @returns the unmodified current Color3\r\n */\r\n Color3.prototype.subtractToRef = function (otherColor, result) {\r\n result.r = this.r - otherColor.r;\r\n result.g = this.g - otherColor.g;\r\n result.b = this.b - otherColor.b;\r\n return this;\r\n };\r\n /**\r\n * Copy the current object\r\n * @returns a new Color3 copied the current one\r\n */\r\n Color3.prototype.clone = function () {\r\n return new Color3(this.r, this.g, this.b);\r\n };\r\n /**\r\n * Copies the rgb values from the source in the current Color3\r\n * @param source defines the source Color3 object\r\n * @returns the updated Color3 object\r\n */\r\n Color3.prototype.copyFrom = function (source) {\r\n this.r = source.r;\r\n this.g = source.g;\r\n this.b = source.b;\r\n return this;\r\n };\r\n /**\r\n * Updates the Color3 rgb values from the given floats\r\n * @param r defines the red component to read from\r\n * @param g defines the green component to read from\r\n * @param b defines the blue component to read from\r\n * @returns the current Color3 object\r\n */\r\n Color3.prototype.copyFromFloats = function (r, g, b) {\r\n this.r = r;\r\n this.g = g;\r\n this.b = b;\r\n return this;\r\n };\r\n /**\r\n * Updates the Color3 rgb values from the given floats\r\n * @param r defines the red component to read from\r\n * @param g defines the green component to read from\r\n * @param b defines the blue component to read from\r\n * @returns the current Color3 object\r\n */\r\n Color3.prototype.set = function (r, g, b) {\r\n return this.copyFromFloats(r, g, b);\r\n };\r\n /**\r\n * Compute the Color3 hexadecimal code as a string\r\n * @returns a string containing the hexadecimal representation of the Color3 object\r\n */\r\n Color3.prototype.toHexString = function () {\r\n var intR = (this.r * 255) | 0;\r\n var intG = (this.g * 255) | 0;\r\n var intB = (this.b * 255) | 0;\r\n return \"#\" + Scalar.ToHex(intR) + Scalar.ToHex(intG) + Scalar.ToHex(intB);\r\n };\r\n /**\r\n * Computes a new Color3 converted from the current one to linear space\r\n * @returns a new Color3 object\r\n */\r\n Color3.prototype.toLinearSpace = function () {\r\n var convertedColor = new Color3();\r\n this.toLinearSpaceToRef(convertedColor);\r\n return convertedColor;\r\n };\r\n /**\r\n * Converts current color in rgb space to HSV values\r\n * @returns a new color3 representing the HSV values\r\n */\r\n Color3.prototype.toHSV = function () {\r\n var result = new Color3();\r\n this.toHSVToRef(result);\r\n return result;\r\n };\r\n /**\r\n * Converts current color in rgb space to HSV values\r\n * @param result defines the Color3 where to store the HSV values\r\n */\r\n Color3.prototype.toHSVToRef = function (result) {\r\n var r = this.r;\r\n var g = this.g;\r\n var b = this.b;\r\n var max = Math.max(r, g, b);\r\n var min = Math.min(r, g, b);\r\n var h = 0;\r\n var s = 0;\r\n var v = max;\r\n var dm = max - min;\r\n if (max !== 0) {\r\n s = dm / max;\r\n }\r\n if (max != min) {\r\n if (max == r) {\r\n h = (g - b) / dm;\r\n if (g < b) {\r\n h += 6;\r\n }\r\n }\r\n else if (max == g) {\r\n h = (b - r) / dm + 2;\r\n }\r\n else if (max == b) {\r\n h = (r - g) / dm + 4;\r\n }\r\n h *= 60;\r\n }\r\n result.r = h;\r\n result.g = s;\r\n result.b = v;\r\n };\r\n /**\r\n * Converts the Color3 values to linear space and stores the result in \"convertedColor\"\r\n * @param convertedColor defines the Color3 object where to store the linear space version\r\n * @returns the unmodified Color3\r\n */\r\n Color3.prototype.toLinearSpaceToRef = function (convertedColor) {\r\n convertedColor.r = Math.pow(this.r, ToLinearSpace);\r\n convertedColor.g = Math.pow(this.g, ToLinearSpace);\r\n convertedColor.b = Math.pow(this.b, ToLinearSpace);\r\n return this;\r\n };\r\n /**\r\n * Computes a new Color3 converted from the current one to gamma space\r\n * @returns a new Color3 object\r\n */\r\n Color3.prototype.toGammaSpace = function () {\r\n var convertedColor = new Color3();\r\n this.toGammaSpaceToRef(convertedColor);\r\n return convertedColor;\r\n };\r\n /**\r\n * Converts the Color3 values to gamma space and stores the result in \"convertedColor\"\r\n * @param convertedColor defines the Color3 object where to store the gamma space version\r\n * @returns the unmodified Color3\r\n */\r\n Color3.prototype.toGammaSpaceToRef = function (convertedColor) {\r\n convertedColor.r = Math.pow(this.r, ToGammaSpace);\r\n convertedColor.g = Math.pow(this.g, ToGammaSpace);\r\n convertedColor.b = Math.pow(this.b, ToGammaSpace);\r\n return this;\r\n };\r\n /**\r\n * Convert Hue, saturation and value to a Color3 (RGB)\r\n * @param hue defines the hue\r\n * @param saturation defines the saturation\r\n * @param value defines the value\r\n * @param result defines the Color3 where to store the RGB values\r\n */\r\n Color3.HSVtoRGBToRef = function (hue, saturation, value, result) {\r\n var chroma = value * saturation;\r\n var h = hue / 60;\r\n var x = chroma * (1 - Math.abs((h % 2) - 1));\r\n var r = 0;\r\n var g = 0;\r\n var b = 0;\r\n if (h >= 0 && h <= 1) {\r\n r = chroma;\r\n g = x;\r\n }\r\n else if (h >= 1 && h <= 2) {\r\n r = x;\r\n g = chroma;\r\n }\r\n else if (h >= 2 && h <= 3) {\r\n g = chroma;\r\n b = x;\r\n }\r\n else if (h >= 3 && h <= 4) {\r\n g = x;\r\n b = chroma;\r\n }\r\n else if (h >= 4 && h <= 5) {\r\n r = x;\r\n b = chroma;\r\n }\r\n else if (h >= 5 && h <= 6) {\r\n r = chroma;\r\n b = x;\r\n }\r\n var m = value - chroma;\r\n result.set((r + m), (g + m), (b + m));\r\n };\r\n /**\r\n * Creates a new Color3 from the string containing valid hexadecimal values\r\n * @param hex defines a string containing valid hexadecimal values\r\n * @returns a new Color3 object\r\n */\r\n Color3.FromHexString = function (hex) {\r\n if (hex.substring(0, 1) !== \"#\" || hex.length !== 7) {\r\n return new Color3(0, 0, 0);\r\n }\r\n var r = parseInt(hex.substring(1, 3), 16);\r\n var g = parseInt(hex.substring(3, 5), 16);\r\n var b = parseInt(hex.substring(5, 7), 16);\r\n return Color3.FromInts(r, g, b);\r\n };\r\n /**\r\n * Creates a new Color3 from the starting index of the given array\r\n * @param array defines the source array\r\n * @param offset defines an offset in the source array\r\n * @returns a new Color3 object\r\n */\r\n Color3.FromArray = function (array, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n return new Color3(array[offset], array[offset + 1], array[offset + 2]);\r\n };\r\n /**\r\n * Creates a new Color3 from integer values (< 256)\r\n * @param r defines the red component to read from (value between 0 and 255)\r\n * @param g defines the green component to read from (value between 0 and 255)\r\n * @param b defines the blue component to read from (value between 0 and 255)\r\n * @returns a new Color3 object\r\n */\r\n Color3.FromInts = function (r, g, b) {\r\n return new Color3(r / 255.0, g / 255.0, b / 255.0);\r\n };\r\n /**\r\n * Creates a new Color3 with values linearly interpolated of \"amount\" between the start Color3 and the end Color3\r\n * @param start defines the start Color3 value\r\n * @param end defines the end Color3 value\r\n * @param amount defines the gradient value between start and end\r\n * @returns a new Color3 object\r\n */\r\n Color3.Lerp = function (start, end, amount) {\r\n var result = new Color3(0.0, 0.0, 0.0);\r\n Color3.LerpToRef(start, end, amount, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a new Color3 with values linearly interpolated of \"amount\" between the start Color3 and the end Color3\r\n * @param left defines the start value\r\n * @param right defines the end value\r\n * @param amount defines the gradient factor\r\n * @param result defines the Color3 object where to store the result\r\n */\r\n Color3.LerpToRef = function (left, right, amount, result) {\r\n result.r = left.r + ((right.r - left.r) * amount);\r\n result.g = left.g + ((right.g - left.g) * amount);\r\n result.b = left.b + ((right.b - left.b) * amount);\r\n };\r\n /**\r\n * Returns a Color3 value containing a red color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Red = function () { return new Color3(1, 0, 0); };\r\n /**\r\n * Returns a Color3 value containing a green color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Green = function () { return new Color3(0, 1, 0); };\r\n /**\r\n * Returns a Color3 value containing a blue color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Blue = function () { return new Color3(0, 0, 1); };\r\n /**\r\n * Returns a Color3 value containing a black color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Black = function () { return new Color3(0, 0, 0); };\r\n Object.defineProperty(Color3, \"BlackReadOnly\", {\r\n /**\r\n * Gets a Color3 value containing a black color that must not be updated\r\n */\r\n get: function () {\r\n return Color3._BlackReadOnly;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Returns a Color3 value containing a white color\r\n * @returns a new Color3 object\r\n */\r\n Color3.White = function () { return new Color3(1, 1, 1); };\r\n /**\r\n * Returns a Color3 value containing a purple color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Purple = function () { return new Color3(0.5, 0, 0.5); };\r\n /**\r\n * Returns a Color3 value containing a magenta color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Magenta = function () { return new Color3(1, 0, 1); };\r\n /**\r\n * Returns a Color3 value containing a yellow color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Yellow = function () { return new Color3(1, 1, 0); };\r\n /**\r\n * Returns a Color3 value containing a gray color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Gray = function () { return new Color3(0.5, 0.5, 0.5); };\r\n /**\r\n * Returns a Color3 value containing a teal color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Teal = function () { return new Color3(0, 1.0, 1.0); };\r\n /**\r\n * Returns a Color3 value containing a random color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Random = function () { return new Color3(Math.random(), Math.random(), Math.random()); };\r\n // Statics\r\n Color3._BlackReadOnly = Color3.Black();\r\n return Color3;\r\n}());\r\nexport { Color3 };\r\n/**\r\n * Class used to hold a RBGA color\r\n */\r\nvar Color4 = /** @class */ (function () {\r\n /**\r\n * Creates a new Color4 object from red, green, blue values, all between 0 and 1\r\n * @param r defines the red component (between 0 and 1, default is 0)\r\n * @param g defines the green component (between 0 and 1, default is 0)\r\n * @param b defines the blue component (between 0 and 1, default is 0)\r\n * @param a defines the alpha component (between 0 and 1, default is 1)\r\n */\r\n function Color4(\r\n /**\r\n * Defines the red component (between 0 and 1, default is 0)\r\n */\r\n r, \r\n /**\r\n * Defines the green component (between 0 and 1, default is 0)\r\n */\r\n g, \r\n /**\r\n * Defines the blue component (between 0 and 1, default is 0)\r\n */\r\n b, \r\n /**\r\n * Defines the alpha component (between 0 and 1, default is 1)\r\n */\r\n a) {\r\n if (r === void 0) { r = 0; }\r\n if (g === void 0) { g = 0; }\r\n if (b === void 0) { b = 0; }\r\n if (a === void 0) { a = 1; }\r\n this.r = r;\r\n this.g = g;\r\n this.b = b;\r\n this.a = a;\r\n }\r\n // Operators\r\n /**\r\n * Adds in place the given Color4 values to the current Color4 object\r\n * @param right defines the second operand\r\n * @returns the current updated Color4 object\r\n */\r\n Color4.prototype.addInPlace = function (right) {\r\n this.r += right.r;\r\n this.g += right.g;\r\n this.b += right.b;\r\n this.a += right.a;\r\n return this;\r\n };\r\n /**\r\n * Creates a new array populated with 4 numeric elements : red, green, blue, alpha values\r\n * @returns the new array\r\n */\r\n Color4.prototype.asArray = function () {\r\n var result = new Array();\r\n this.toArray(result, 0);\r\n return result;\r\n };\r\n /**\r\n * Stores from the starting index in the given array the Color4 successive values\r\n * @param array defines the array where to store the r,g,b components\r\n * @param index defines an optional index in the target array to define where to start storing values\r\n * @returns the current Color4 object\r\n */\r\n Color4.prototype.toArray = function (array, index) {\r\n if (index === void 0) { index = 0; }\r\n array[index] = this.r;\r\n array[index + 1] = this.g;\r\n array[index + 2] = this.b;\r\n array[index + 3] = this.a;\r\n return this;\r\n };\r\n /**\r\n * Determines equality between Color4 objects\r\n * @param otherColor defines the second operand\r\n * @returns true if the rgba values are equal to the given ones\r\n */\r\n Color4.prototype.equals = function (otherColor) {\r\n return otherColor && this.r === otherColor.r && this.g === otherColor.g && this.b === otherColor.b && this.a === otherColor.a;\r\n };\r\n /**\r\n * Creates a new Color4 set with the added values of the current Color4 and of the given one\r\n * @param right defines the second operand\r\n * @returns a new Color4 object\r\n */\r\n Color4.prototype.add = function (right) {\r\n return new Color4(this.r + right.r, this.g + right.g, this.b + right.b, this.a + right.a);\r\n };\r\n /**\r\n * Creates a new Color4 set with the subtracted values of the given one from the current Color4\r\n * @param right defines the second operand\r\n * @returns a new Color4 object\r\n */\r\n Color4.prototype.subtract = function (right) {\r\n return new Color4(this.r - right.r, this.g - right.g, this.b - right.b, this.a - right.a);\r\n };\r\n /**\r\n * Subtracts the given ones from the current Color4 values and stores the results in \"result\"\r\n * @param right defines the second operand\r\n * @param result defines the Color4 object where to store the result\r\n * @returns the current Color4 object\r\n */\r\n Color4.prototype.subtractToRef = function (right, result) {\r\n result.r = this.r - right.r;\r\n result.g = this.g - right.g;\r\n result.b = this.b - right.b;\r\n result.a = this.a - right.a;\r\n return this;\r\n };\r\n /**\r\n * Creates a new Color4 with the current Color4 values multiplied by scale\r\n * @param scale defines the scaling factor to apply\r\n * @returns a new Color4 object\r\n */\r\n Color4.prototype.scale = function (scale) {\r\n return new Color4(this.r * scale, this.g * scale, this.b * scale, this.a * scale);\r\n };\r\n /**\r\n * Multiplies the current Color4 values by scale and stores the result in \"result\"\r\n * @param scale defines the scaling factor to apply\r\n * @param result defines the Color4 object where to store the result\r\n * @returns the current unmodified Color4\r\n */\r\n Color4.prototype.scaleToRef = function (scale, result) {\r\n result.r = this.r * scale;\r\n result.g = this.g * scale;\r\n result.b = this.b * scale;\r\n result.a = this.a * scale;\r\n return this;\r\n };\r\n /**\r\n * Scale the current Color4 values by a factor and add the result to a given Color4\r\n * @param scale defines the scale factor\r\n * @param result defines the Color4 object where to store the result\r\n * @returns the unmodified current Color4\r\n */\r\n Color4.prototype.scaleAndAddToRef = function (scale, result) {\r\n result.r += this.r * scale;\r\n result.g += this.g * scale;\r\n result.b += this.b * scale;\r\n result.a += this.a * scale;\r\n return this;\r\n };\r\n /**\r\n * Clamps the rgb values by the min and max values and stores the result into \"result\"\r\n * @param min defines minimum clamping value (default is 0)\r\n * @param max defines maximum clamping value (default is 1)\r\n * @param result defines color to store the result into.\r\n * @returns the cuurent Color4\r\n */\r\n Color4.prototype.clampToRef = function (min, max, result) {\r\n if (min === void 0) { min = 0; }\r\n if (max === void 0) { max = 1; }\r\n result.r = Scalar.Clamp(this.r, min, max);\r\n result.g = Scalar.Clamp(this.g, min, max);\r\n result.b = Scalar.Clamp(this.b, min, max);\r\n result.a = Scalar.Clamp(this.a, min, max);\r\n return this;\r\n };\r\n /**\r\n * Multipy an Color4 value by another and return a new Color4 object\r\n * @param color defines the Color4 value to multiply by\r\n * @returns a new Color4 object\r\n */\r\n Color4.prototype.multiply = function (color) {\r\n return new Color4(this.r * color.r, this.g * color.g, this.b * color.b, this.a * color.a);\r\n };\r\n /**\r\n * Multipy a Color4 value by another and push the result in a reference value\r\n * @param color defines the Color4 value to multiply by\r\n * @param result defines the Color4 to fill the result in\r\n * @returns the result Color4\r\n */\r\n Color4.prototype.multiplyToRef = function (color, result) {\r\n result.r = this.r * color.r;\r\n result.g = this.g * color.g;\r\n result.b = this.b * color.b;\r\n result.a = this.a * color.a;\r\n return result;\r\n };\r\n /**\r\n * Creates a string with the Color4 current values\r\n * @returns the string representation of the Color4 object\r\n */\r\n Color4.prototype.toString = function () {\r\n return \"{R: \" + this.r + \" G:\" + this.g + \" B:\" + this.b + \" A:\" + this.a + \"}\";\r\n };\r\n /**\r\n * Returns the string \"Color4\"\r\n * @returns \"Color4\"\r\n */\r\n Color4.prototype.getClassName = function () {\r\n return \"Color4\";\r\n };\r\n /**\r\n * Compute the Color4 hash code\r\n * @returns an unique number that can be used to hash Color4 objects\r\n */\r\n Color4.prototype.getHashCode = function () {\r\n var hash = (this.r * 255) | 0;\r\n hash = (hash * 397) ^ ((this.g * 255) | 0);\r\n hash = (hash * 397) ^ ((this.b * 255) | 0);\r\n hash = (hash * 397) ^ ((this.a * 255) | 0);\r\n return hash;\r\n };\r\n /**\r\n * Creates a new Color4 copied from the current one\r\n * @returns a new Color4 object\r\n */\r\n Color4.prototype.clone = function () {\r\n return new Color4(this.r, this.g, this.b, this.a);\r\n };\r\n /**\r\n * Copies the given Color4 values into the current one\r\n * @param source defines the source Color4 object\r\n * @returns the current updated Color4 object\r\n */\r\n Color4.prototype.copyFrom = function (source) {\r\n this.r = source.r;\r\n this.g = source.g;\r\n this.b = source.b;\r\n this.a = source.a;\r\n return this;\r\n };\r\n /**\r\n * Copies the given float values into the current one\r\n * @param r defines the red component to read from\r\n * @param g defines the green component to read from\r\n * @param b defines the blue component to read from\r\n * @param a defines the alpha component to read from\r\n * @returns the current updated Color4 object\r\n */\r\n Color4.prototype.copyFromFloats = function (r, g, b, a) {\r\n this.r = r;\r\n this.g = g;\r\n this.b = b;\r\n this.a = a;\r\n return this;\r\n };\r\n /**\r\n * Copies the given float values into the current one\r\n * @param r defines the red component to read from\r\n * @param g defines the green component to read from\r\n * @param b defines the blue component to read from\r\n * @param a defines the alpha component to read from\r\n * @returns the current updated Color4 object\r\n */\r\n Color4.prototype.set = function (r, g, b, a) {\r\n return this.copyFromFloats(r, g, b, a);\r\n };\r\n /**\r\n * Compute the Color4 hexadecimal code as a string\r\n * @returns a string containing the hexadecimal representation of the Color4 object\r\n */\r\n Color4.prototype.toHexString = function () {\r\n var intR = (this.r * 255) | 0;\r\n var intG = (this.g * 255) | 0;\r\n var intB = (this.b * 255) | 0;\r\n var intA = (this.a * 255) | 0;\r\n return \"#\" + Scalar.ToHex(intR) + Scalar.ToHex(intG) + Scalar.ToHex(intB) + Scalar.ToHex(intA);\r\n };\r\n /**\r\n * Computes a new Color4 converted from the current one to linear space\r\n * @returns a new Color4 object\r\n */\r\n Color4.prototype.toLinearSpace = function () {\r\n var convertedColor = new Color4();\r\n this.toLinearSpaceToRef(convertedColor);\r\n return convertedColor;\r\n };\r\n /**\r\n * Converts the Color4 values to linear space and stores the result in \"convertedColor\"\r\n * @param convertedColor defines the Color4 object where to store the linear space version\r\n * @returns the unmodified Color4\r\n */\r\n Color4.prototype.toLinearSpaceToRef = function (convertedColor) {\r\n convertedColor.r = Math.pow(this.r, ToLinearSpace);\r\n convertedColor.g = Math.pow(this.g, ToLinearSpace);\r\n convertedColor.b = Math.pow(this.b, ToLinearSpace);\r\n convertedColor.a = this.a;\r\n return this;\r\n };\r\n /**\r\n * Computes a new Color4 converted from the current one to gamma space\r\n * @returns a new Color4 object\r\n */\r\n Color4.prototype.toGammaSpace = function () {\r\n var convertedColor = new Color4();\r\n this.toGammaSpaceToRef(convertedColor);\r\n return convertedColor;\r\n };\r\n /**\r\n * Converts the Color4 values to gamma space and stores the result in \"convertedColor\"\r\n * @param convertedColor defines the Color4 object where to store the gamma space version\r\n * @returns the unmodified Color4\r\n */\r\n Color4.prototype.toGammaSpaceToRef = function (convertedColor) {\r\n convertedColor.r = Math.pow(this.r, ToGammaSpace);\r\n convertedColor.g = Math.pow(this.g, ToGammaSpace);\r\n convertedColor.b = Math.pow(this.b, ToGammaSpace);\r\n convertedColor.a = this.a;\r\n return this;\r\n };\r\n // Statics\r\n /**\r\n * Creates a new Color4 from the string containing valid hexadecimal values\r\n * @param hex defines a string containing valid hexadecimal values\r\n * @returns a new Color4 object\r\n */\r\n Color4.FromHexString = function (hex) {\r\n if (hex.substring(0, 1) !== \"#\" || hex.length !== 9) {\r\n return new Color4(0.0, 0.0, 0.0, 0.0);\r\n }\r\n var r = parseInt(hex.substring(1, 3), 16);\r\n var g = parseInt(hex.substring(3, 5), 16);\r\n var b = parseInt(hex.substring(5, 7), 16);\r\n var a = parseInt(hex.substring(7, 9), 16);\r\n return Color4.FromInts(r, g, b, a);\r\n };\r\n /**\r\n * Creates a new Color4 object set with the linearly interpolated values of \"amount\" between the left Color4 object and the right Color4 object\r\n * @param left defines the start value\r\n * @param right defines the end value\r\n * @param amount defines the gradient factor\r\n * @returns a new Color4 object\r\n */\r\n Color4.Lerp = function (left, right, amount) {\r\n var result = new Color4(0.0, 0.0, 0.0, 0.0);\r\n Color4.LerpToRef(left, right, amount, result);\r\n return result;\r\n };\r\n /**\r\n * Set the given \"result\" with the linearly interpolated values of \"amount\" between the left Color4 object and the right Color4 object\r\n * @param left defines the start value\r\n * @param right defines the end value\r\n * @param amount defines the gradient factor\r\n * @param result defines the Color4 object where to store data\r\n */\r\n Color4.LerpToRef = function (left, right, amount, result) {\r\n result.r = left.r + (right.r - left.r) * amount;\r\n result.g = left.g + (right.g - left.g) * amount;\r\n result.b = left.b + (right.b - left.b) * amount;\r\n result.a = left.a + (right.a - left.a) * amount;\r\n };\r\n /**\r\n * Creates a new Color4 from a Color3 and an alpha value\r\n * @param color3 defines the source Color3 to read from\r\n * @param alpha defines the alpha component (1.0 by default)\r\n * @returns a new Color4 object\r\n */\r\n Color4.FromColor3 = function (color3, alpha) {\r\n if (alpha === void 0) { alpha = 1.0; }\r\n return new Color4(color3.r, color3.g, color3.b, alpha);\r\n };\r\n /**\r\n * Creates a new Color4 from the starting index element of the given array\r\n * @param array defines the source array to read from\r\n * @param offset defines the offset in the source array\r\n * @returns a new Color4 object\r\n */\r\n Color4.FromArray = function (array, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n return new Color4(array[offset], array[offset + 1], array[offset + 2], array[offset + 3]);\r\n };\r\n /**\r\n * Creates a new Color3 from integer values (< 256)\r\n * @param r defines the red component to read from (value between 0 and 255)\r\n * @param g defines the green component to read from (value between 0 and 255)\r\n * @param b defines the blue component to read from (value between 0 and 255)\r\n * @param a defines the alpha component to read from (value between 0 and 255)\r\n * @returns a new Color3 object\r\n */\r\n Color4.FromInts = function (r, g, b, a) {\r\n return new Color4(r / 255.0, g / 255.0, b / 255.0, a / 255.0);\r\n };\r\n /**\r\n * Check the content of a given array and convert it to an array containing RGBA data\r\n * If the original array was already containing count * 4 values then it is returned directly\r\n * @param colors defines the array to check\r\n * @param count defines the number of RGBA data to expect\r\n * @returns an array containing count * 4 values (RGBA)\r\n */\r\n Color4.CheckColors4 = function (colors, count) {\r\n // Check if color3 was used\r\n if (colors.length === count * 3) {\r\n var colors4 = [];\r\n for (var index = 0; index < colors.length; index += 3) {\r\n var newIndex = (index / 3) * 4;\r\n colors4[newIndex] = colors[index];\r\n colors4[newIndex + 1] = colors[index + 1];\r\n colors4[newIndex + 2] = colors[index + 2];\r\n colors4[newIndex + 3] = 1.0;\r\n }\r\n return colors4;\r\n }\r\n return colors;\r\n };\r\n return Color4;\r\n}());\r\nexport { Color4 };\r\n/**\r\n * @hidden\r\n */\r\nvar TmpColors = /** @class */ (function () {\r\n function TmpColors() {\r\n }\r\n TmpColors.Color3 = ArrayTools.BuildArray(3, Color3.Black);\r\n TmpColors.Color4 = ArrayTools.BuildArray(3, function () { return new Color4(0, 0, 0, 0); });\r\n return TmpColors;\r\n}());\r\nexport { TmpColors };\r\n_TypeStore.RegisteredTypes[\"BABYLON.Color3\"] = Color3;\r\n_TypeStore.RegisteredTypes[\"BABYLON.Color4\"] = Color4;\r\n//# sourceMappingURL=math.color.js.map","/** @hidden */\r\nvar _DevTools = /** @class */ (function () {\r\n function _DevTools() {\r\n }\r\n _DevTools.WarnImport = function (name) {\r\n return name + \" needs to be imported before as it contains a side-effect required by your code.\";\r\n };\r\n return _DevTools;\r\n}());\r\nexport { _DevTools };\r\n//# sourceMappingURL=devTools.js.map","import { __extends } from \"tslib\";\r\nimport { Vector2 } from \"../Maths/math.vector\";\r\n/**\r\n * Gather the list of pointer event types as constants.\r\n */\r\nvar PointerEventTypes = /** @class */ (function () {\r\n function PointerEventTypes() {\r\n }\r\n /**\r\n * The pointerdown event is fired when a pointer becomes active. For mouse, it is fired when the device transitions from no buttons depressed to at least one button depressed. For touch, it is fired when physical contact is made with the digitizer. For pen, it is fired when the stylus makes physical contact with the digitizer.\r\n */\r\n PointerEventTypes.POINTERDOWN = 0x01;\r\n /**\r\n * The pointerup event is fired when a pointer is no longer active.\r\n */\r\n PointerEventTypes.POINTERUP = 0x02;\r\n /**\r\n * The pointermove event is fired when a pointer changes coordinates.\r\n */\r\n PointerEventTypes.POINTERMOVE = 0x04;\r\n /**\r\n * The pointerwheel event is fired when a mouse wheel has been rotated.\r\n */\r\n PointerEventTypes.POINTERWHEEL = 0x08;\r\n /**\r\n * The pointerpick event is fired when a mesh or sprite has been picked by the pointer.\r\n */\r\n PointerEventTypes.POINTERPICK = 0x10;\r\n /**\r\n * The pointertap event is fired when a the object has been touched and released without drag.\r\n */\r\n PointerEventTypes.POINTERTAP = 0x20;\r\n /**\r\n * The pointerdoubletap event is fired when a the object has been touched and released twice without drag.\r\n */\r\n PointerEventTypes.POINTERDOUBLETAP = 0x40;\r\n return PointerEventTypes;\r\n}());\r\nexport { PointerEventTypes };\r\n/**\r\n * Base class of pointer info types.\r\n */\r\nvar PointerInfoBase = /** @class */ (function () {\r\n /**\r\n * Instantiates the base class of pointers info.\r\n * @param type Defines the type of event (PointerEventTypes)\r\n * @param event Defines the related dom event\r\n */\r\n function PointerInfoBase(\r\n /**\r\n * Defines the type of event (PointerEventTypes)\r\n */\r\n type, \r\n /**\r\n * Defines the related dom event\r\n */\r\n event) {\r\n this.type = type;\r\n this.event = event;\r\n }\r\n return PointerInfoBase;\r\n}());\r\nexport { PointerInfoBase };\r\n/**\r\n * This class is used to store pointer related info for the onPrePointerObservable event.\r\n * Set the skipOnPointerObservable property to true if you want the engine to stop any process after this event is triggered, even not calling onPointerObservable\r\n */\r\nvar PointerInfoPre = /** @class */ (function (_super) {\r\n __extends(PointerInfoPre, _super);\r\n /**\r\n * Instantiates a PointerInfoPre to store pointer related info to the onPrePointerObservable event.\r\n * @param type Defines the type of event (PointerEventTypes)\r\n * @param event Defines the related dom event\r\n * @param localX Defines the local x coordinates of the pointer when the event occured\r\n * @param localY Defines the local y coordinates of the pointer when the event occured\r\n */\r\n function PointerInfoPre(type, event, localX, localY) {\r\n var _this = _super.call(this, type, event) || this;\r\n /**\r\n * Ray from a pointer if availible (eg. 6dof controller)\r\n */\r\n _this.ray = null;\r\n _this.skipOnPointerObservable = false;\r\n _this.localPosition = new Vector2(localX, localY);\r\n return _this;\r\n }\r\n return PointerInfoPre;\r\n}(PointerInfoBase));\r\nexport { PointerInfoPre };\r\n/**\r\n * This type contains all the data related to a pointer event in Babylon.js.\r\n * The event member is an instance of PointerEvent for all types except PointerWheel and is of type MouseWheelEvent when type equals PointerWheel. The different event types can be found in the PointerEventTypes class.\r\n */\r\nvar PointerInfo = /** @class */ (function (_super) {\r\n __extends(PointerInfo, _super);\r\n /**\r\n * Instantiates a PointerInfo to store pointer related info to the onPointerObservable event.\r\n * @param type Defines the type of event (PointerEventTypes)\r\n * @param event Defines the related dom event\r\n * @param pickInfo Defines the picking info associated to the info (if any)\\\r\n */\r\n function PointerInfo(type, event, \r\n /**\r\n * Defines the picking info associated to the info (if any)\\\r\n */\r\n pickInfo) {\r\n var _this = _super.call(this, type, event) || this;\r\n _this.pickInfo = pickInfo;\r\n return _this;\r\n }\r\n return PointerInfo;\r\n}(PointerInfoBase));\r\nexport { PointerInfo };\r\n//# sourceMappingURL=pointerEvents.js.map","/** @hidden */\r\nvar _TypeStore = /** @class */ (function () {\r\n function _TypeStore() {\r\n }\r\n /** @hidden */\r\n _TypeStore.GetClass = function (fqdn) {\r\n if (this.RegisteredTypes && this.RegisteredTypes[fqdn]) {\r\n return this.RegisteredTypes[fqdn];\r\n }\r\n return null;\r\n };\r\n /** @hidden */\r\n _TypeStore.RegisteredTypes = {};\r\n return _TypeStore;\r\n}());\r\nexport { _TypeStore };\r\n//# sourceMappingURL=typeStore.js.map","import { Vector3, Vector4 } from \"../Maths/math.vector\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { _DevTools } from '../Misc/devTools';\r\nimport { Color4 } from '../Maths/math.color';\r\n/**\r\n * This class contains the various kinds of data on every vertex of a mesh used in determining its shape and appearance\r\n */\r\nvar VertexData = /** @class */ (function () {\r\n function VertexData() {\r\n }\r\n /**\r\n * Uses the passed data array to set the set the values for the specified kind of data\r\n * @param data a linear array of floating numbers\r\n * @param kind the type of data that is being set, eg positions, colors etc\r\n */\r\n VertexData.prototype.set = function (data, kind) {\r\n switch (kind) {\r\n case VertexBuffer.PositionKind:\r\n this.positions = data;\r\n break;\r\n case VertexBuffer.NormalKind:\r\n this.normals = data;\r\n break;\r\n case VertexBuffer.TangentKind:\r\n this.tangents = data;\r\n break;\r\n case VertexBuffer.UVKind:\r\n this.uvs = data;\r\n break;\r\n case VertexBuffer.UV2Kind:\r\n this.uvs2 = data;\r\n break;\r\n case VertexBuffer.UV3Kind:\r\n this.uvs3 = data;\r\n break;\r\n case VertexBuffer.UV4Kind:\r\n this.uvs4 = data;\r\n break;\r\n case VertexBuffer.UV5Kind:\r\n this.uvs5 = data;\r\n break;\r\n case VertexBuffer.UV6Kind:\r\n this.uvs6 = data;\r\n break;\r\n case VertexBuffer.ColorKind:\r\n this.colors = data;\r\n break;\r\n case VertexBuffer.MatricesIndicesKind:\r\n this.matricesIndices = data;\r\n break;\r\n case VertexBuffer.MatricesWeightsKind:\r\n this.matricesWeights = data;\r\n break;\r\n case VertexBuffer.MatricesIndicesExtraKind:\r\n this.matricesIndicesExtra = data;\r\n break;\r\n case VertexBuffer.MatricesWeightsExtraKind:\r\n this.matricesWeightsExtra = data;\r\n break;\r\n }\r\n };\r\n /**\r\n * Associates the vertexData to the passed Mesh.\r\n * Sets it as updatable or not (default `false`)\r\n * @param mesh the mesh the vertexData is applied to\r\n * @param updatable when used and having the value true allows new data to update the vertexData\r\n * @returns the VertexData\r\n */\r\n VertexData.prototype.applyToMesh = function (mesh, updatable) {\r\n this._applyTo(mesh, updatable);\r\n return this;\r\n };\r\n /**\r\n * Associates the vertexData to the passed Geometry.\r\n * Sets it as updatable or not (default `false`)\r\n * @param geometry the geometry the vertexData is applied to\r\n * @param updatable when used and having the value true allows new data to update the vertexData\r\n * @returns VertexData\r\n */\r\n VertexData.prototype.applyToGeometry = function (geometry, updatable) {\r\n this._applyTo(geometry, updatable);\r\n return this;\r\n };\r\n /**\r\n * Updates the associated mesh\r\n * @param mesh the mesh to be updated\r\n * @param updateExtends when true the mesh BoundingInfo will be renewed when and if position kind is updated, optional with default false\r\n * @param makeItUnique when true, and when and if position kind is updated, a new global geometry will be created from these positions and set to the mesh, optional with default false\r\n * @returns VertexData\r\n */\r\n VertexData.prototype.updateMesh = function (mesh) {\r\n this._update(mesh);\r\n return this;\r\n };\r\n /**\r\n * Updates the associated geometry\r\n * @param geometry the geometry to be updated\r\n * @param updateExtends when true BoundingInfo will be renewed when and if position kind is updated, optional with default false\r\n * @param makeItUnique when true, and when and if position kind is updated, a new global geometry will be created from these positions and set to the mesh, optional with default false\r\n * @returns VertexData.\r\n */\r\n VertexData.prototype.updateGeometry = function (geometry) {\r\n this._update(geometry);\r\n return this;\r\n };\r\n VertexData.prototype._applyTo = function (meshOrGeometry, updatable) {\r\n if (updatable === void 0) { updatable = false; }\r\n if (this.positions) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.PositionKind, this.positions, updatable);\r\n }\r\n if (this.normals) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.NormalKind, this.normals, updatable);\r\n }\r\n if (this.tangents) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.TangentKind, this.tangents, updatable);\r\n }\r\n if (this.uvs) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.UVKind, this.uvs, updatable);\r\n }\r\n if (this.uvs2) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.UV2Kind, this.uvs2, updatable);\r\n }\r\n if (this.uvs3) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.UV3Kind, this.uvs3, updatable);\r\n }\r\n if (this.uvs4) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.UV4Kind, this.uvs4, updatable);\r\n }\r\n if (this.uvs5) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.UV5Kind, this.uvs5, updatable);\r\n }\r\n if (this.uvs6) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.UV6Kind, this.uvs6, updatable);\r\n }\r\n if (this.colors) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.ColorKind, this.colors, updatable);\r\n }\r\n if (this.matricesIndices) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.MatricesIndicesKind, this.matricesIndices, updatable);\r\n }\r\n if (this.matricesWeights) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.MatricesWeightsKind, this.matricesWeights, updatable);\r\n }\r\n if (this.matricesIndicesExtra) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.MatricesIndicesExtraKind, this.matricesIndicesExtra, updatable);\r\n }\r\n if (this.matricesWeightsExtra) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.MatricesWeightsExtraKind, this.matricesWeightsExtra, updatable);\r\n }\r\n if (this.indices) {\r\n meshOrGeometry.setIndices(this.indices, null, updatable);\r\n }\r\n else {\r\n meshOrGeometry.setIndices([], null);\r\n }\r\n return this;\r\n };\r\n VertexData.prototype._update = function (meshOrGeometry, updateExtends, makeItUnique) {\r\n if (this.positions) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.PositionKind, this.positions, updateExtends, makeItUnique);\r\n }\r\n if (this.normals) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.NormalKind, this.normals, updateExtends, makeItUnique);\r\n }\r\n if (this.tangents) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.TangentKind, this.tangents, updateExtends, makeItUnique);\r\n }\r\n if (this.uvs) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.UVKind, this.uvs, updateExtends, makeItUnique);\r\n }\r\n if (this.uvs2) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.UV2Kind, this.uvs2, updateExtends, makeItUnique);\r\n }\r\n if (this.uvs3) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.UV3Kind, this.uvs3, updateExtends, makeItUnique);\r\n }\r\n if (this.uvs4) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.UV4Kind, this.uvs4, updateExtends, makeItUnique);\r\n }\r\n if (this.uvs5) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.UV5Kind, this.uvs5, updateExtends, makeItUnique);\r\n }\r\n if (this.uvs6) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.UV6Kind, this.uvs6, updateExtends, makeItUnique);\r\n }\r\n if (this.colors) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.ColorKind, this.colors, updateExtends, makeItUnique);\r\n }\r\n if (this.matricesIndices) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.MatricesIndicesKind, this.matricesIndices, updateExtends, makeItUnique);\r\n }\r\n if (this.matricesWeights) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.MatricesWeightsKind, this.matricesWeights, updateExtends, makeItUnique);\r\n }\r\n if (this.matricesIndicesExtra) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.MatricesIndicesExtraKind, this.matricesIndicesExtra, updateExtends, makeItUnique);\r\n }\r\n if (this.matricesWeightsExtra) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.MatricesWeightsExtraKind, this.matricesWeightsExtra, updateExtends, makeItUnique);\r\n }\r\n if (this.indices) {\r\n meshOrGeometry.setIndices(this.indices, null);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Transforms each position and each normal of the vertexData according to the passed Matrix\r\n * @param matrix the transforming matrix\r\n * @returns the VertexData\r\n */\r\n VertexData.prototype.transform = function (matrix) {\r\n var flip = matrix.m[0] * matrix.m[5] * matrix.m[10] < 0;\r\n var transformed = Vector3.Zero();\r\n var index;\r\n if (this.positions) {\r\n var position = Vector3.Zero();\r\n for (index = 0; index < this.positions.length; index += 3) {\r\n Vector3.FromArrayToRef(this.positions, index, position);\r\n Vector3.TransformCoordinatesToRef(position, matrix, transformed);\r\n this.positions[index] = transformed.x;\r\n this.positions[index + 1] = transformed.y;\r\n this.positions[index + 2] = transformed.z;\r\n }\r\n }\r\n if (this.normals) {\r\n var normal = Vector3.Zero();\r\n for (index = 0; index < this.normals.length; index += 3) {\r\n Vector3.FromArrayToRef(this.normals, index, normal);\r\n Vector3.TransformNormalToRef(normal, matrix, transformed);\r\n this.normals[index] = transformed.x;\r\n this.normals[index + 1] = transformed.y;\r\n this.normals[index + 2] = transformed.z;\r\n }\r\n }\r\n if (this.tangents) {\r\n var tangent = Vector4.Zero();\r\n var tangentTransformed = Vector4.Zero();\r\n for (index = 0; index < this.tangents.length; index += 4) {\r\n Vector4.FromArrayToRef(this.tangents, index, tangent);\r\n Vector4.TransformNormalToRef(tangent, matrix, tangentTransformed);\r\n this.tangents[index] = tangentTransformed.x;\r\n this.tangents[index + 1] = tangentTransformed.y;\r\n this.tangents[index + 2] = tangentTransformed.z;\r\n this.tangents[index + 3] = tangentTransformed.w;\r\n }\r\n }\r\n if (flip && this.indices) {\r\n for (index = 0; index < this.indices.length; index += 3) {\r\n var tmp = this.indices[index + 1];\r\n this.indices[index + 1] = this.indices[index + 2];\r\n this.indices[index + 2] = tmp;\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Merges the passed VertexData into the current one\r\n * @param other the VertexData to be merged into the current one\r\n * @param use32BitsIndices defines a boolean indicating if indices must be store in a 32 bits array\r\n * @returns the modified VertexData\r\n */\r\n VertexData.prototype.merge = function (other, use32BitsIndices) {\r\n if (use32BitsIndices === void 0) { use32BitsIndices = false; }\r\n this._validate();\r\n other._validate();\r\n if (!this.normals !== !other.normals ||\r\n !this.tangents !== !other.tangents ||\r\n !this.uvs !== !other.uvs ||\r\n !this.uvs2 !== !other.uvs2 ||\r\n !this.uvs3 !== !other.uvs3 ||\r\n !this.uvs4 !== !other.uvs4 ||\r\n !this.uvs5 !== !other.uvs5 ||\r\n !this.uvs6 !== !other.uvs6 ||\r\n !this.colors !== !other.colors ||\r\n !this.matricesIndices !== !other.matricesIndices ||\r\n !this.matricesWeights !== !other.matricesWeights ||\r\n !this.matricesIndicesExtra !== !other.matricesIndicesExtra ||\r\n !this.matricesWeightsExtra !== !other.matricesWeightsExtra) {\r\n throw new Error(\"Cannot merge vertex data that do not have the same set of attributes\");\r\n }\r\n if (other.indices) {\r\n if (!this.indices) {\r\n this.indices = [];\r\n }\r\n var offset = this.positions ? this.positions.length / 3 : 0;\r\n var isSrcTypedArray = this.indices.BYTES_PER_ELEMENT !== undefined;\r\n if (isSrcTypedArray) {\r\n var len = this.indices.length + other.indices.length;\r\n var temp = use32BitsIndices || this.indices instanceof Uint32Array ? new Uint32Array(len) : new Uint16Array(len);\r\n temp.set(this.indices);\r\n var decal = this.indices.length;\r\n for (var index = 0; index < other.indices.length; index++) {\r\n temp[decal + index] = other.indices[index] + offset;\r\n }\r\n this.indices = temp;\r\n }\r\n else {\r\n for (var index = 0; index < other.indices.length; index++) {\r\n this.indices.push(other.indices[index] + offset);\r\n }\r\n }\r\n }\r\n this.positions = this._mergeElement(this.positions, other.positions);\r\n this.normals = this._mergeElement(this.normals, other.normals);\r\n this.tangents = this._mergeElement(this.tangents, other.tangents);\r\n this.uvs = this._mergeElement(this.uvs, other.uvs);\r\n this.uvs2 = this._mergeElement(this.uvs2, other.uvs2);\r\n this.uvs3 = this._mergeElement(this.uvs3, other.uvs3);\r\n this.uvs4 = this._mergeElement(this.uvs4, other.uvs4);\r\n this.uvs5 = this._mergeElement(this.uvs5, other.uvs5);\r\n this.uvs6 = this._mergeElement(this.uvs6, other.uvs6);\r\n this.colors = this._mergeElement(this.colors, other.colors);\r\n this.matricesIndices = this._mergeElement(this.matricesIndices, other.matricesIndices);\r\n this.matricesWeights = this._mergeElement(this.matricesWeights, other.matricesWeights);\r\n this.matricesIndicesExtra = this._mergeElement(this.matricesIndicesExtra, other.matricesIndicesExtra);\r\n this.matricesWeightsExtra = this._mergeElement(this.matricesWeightsExtra, other.matricesWeightsExtra);\r\n return this;\r\n };\r\n VertexData.prototype._mergeElement = function (source, other) {\r\n if (!source) {\r\n return other;\r\n }\r\n if (!other) {\r\n return source;\r\n }\r\n var len = other.length + source.length;\r\n var isSrcTypedArray = source instanceof Float32Array;\r\n var isOthTypedArray = other instanceof Float32Array;\r\n // use non-loop method when the source is Float32Array\r\n if (isSrcTypedArray) {\r\n var ret32 = new Float32Array(len);\r\n ret32.set(source);\r\n ret32.set(other, source.length);\r\n return ret32;\r\n // source is number[], when other is also use concat\r\n }\r\n else if (!isOthTypedArray) {\r\n return source.concat(other);\r\n // source is a number[], but other is a Float32Array, loop required\r\n }\r\n else {\r\n var ret = source.slice(0); // copy source to a separate array\r\n for (var i = 0, len = other.length; i < len; i++) {\r\n ret.push(other[i]);\r\n }\r\n return ret;\r\n }\r\n };\r\n VertexData.prototype._validate = function () {\r\n if (!this.positions) {\r\n throw new Error(\"Positions are required\");\r\n }\r\n var getElementCount = function (kind, values) {\r\n var stride = VertexBuffer.DeduceStride(kind);\r\n if ((values.length % stride) !== 0) {\r\n throw new Error(\"The \" + kind + \"s array count must be a multiple of \" + stride);\r\n }\r\n return values.length / stride;\r\n };\r\n var positionsElementCount = getElementCount(VertexBuffer.PositionKind, this.positions);\r\n var validateElementCount = function (kind, values) {\r\n var elementCount = getElementCount(kind, values);\r\n if (elementCount !== positionsElementCount) {\r\n throw new Error(\"The \" + kind + \"s element count (\" + elementCount + \") does not match the positions count (\" + positionsElementCount + \")\");\r\n }\r\n };\r\n if (this.normals) {\r\n validateElementCount(VertexBuffer.NormalKind, this.normals);\r\n }\r\n if (this.tangents) {\r\n validateElementCount(VertexBuffer.TangentKind, this.tangents);\r\n }\r\n if (this.uvs) {\r\n validateElementCount(VertexBuffer.UVKind, this.uvs);\r\n }\r\n if (this.uvs2) {\r\n validateElementCount(VertexBuffer.UV2Kind, this.uvs2);\r\n }\r\n if (this.uvs3) {\r\n validateElementCount(VertexBuffer.UV3Kind, this.uvs3);\r\n }\r\n if (this.uvs4) {\r\n validateElementCount(VertexBuffer.UV4Kind, this.uvs4);\r\n }\r\n if (this.uvs5) {\r\n validateElementCount(VertexBuffer.UV5Kind, this.uvs5);\r\n }\r\n if (this.uvs6) {\r\n validateElementCount(VertexBuffer.UV6Kind, this.uvs6);\r\n }\r\n if (this.colors) {\r\n validateElementCount(VertexBuffer.ColorKind, this.colors);\r\n }\r\n if (this.matricesIndices) {\r\n validateElementCount(VertexBuffer.MatricesIndicesKind, this.matricesIndices);\r\n }\r\n if (this.matricesWeights) {\r\n validateElementCount(VertexBuffer.MatricesWeightsKind, this.matricesWeights);\r\n }\r\n if (this.matricesIndicesExtra) {\r\n validateElementCount(VertexBuffer.MatricesIndicesExtraKind, this.matricesIndicesExtra);\r\n }\r\n if (this.matricesWeightsExtra) {\r\n validateElementCount(VertexBuffer.MatricesWeightsExtraKind, this.matricesWeightsExtra);\r\n }\r\n };\r\n /**\r\n * Serializes the VertexData\r\n * @returns a serialized object\r\n */\r\n VertexData.prototype.serialize = function () {\r\n var serializationObject = this.serialize();\r\n if (this.positions) {\r\n serializationObject.positions = this.positions;\r\n }\r\n if (this.normals) {\r\n serializationObject.normals = this.normals;\r\n }\r\n if (this.tangents) {\r\n serializationObject.tangents = this.tangents;\r\n }\r\n if (this.uvs) {\r\n serializationObject.uvs = this.uvs;\r\n }\r\n if (this.uvs2) {\r\n serializationObject.uvs2 = this.uvs2;\r\n }\r\n if (this.uvs3) {\r\n serializationObject.uvs3 = this.uvs3;\r\n }\r\n if (this.uvs4) {\r\n serializationObject.uvs4 = this.uvs4;\r\n }\r\n if (this.uvs5) {\r\n serializationObject.uvs5 = this.uvs5;\r\n }\r\n if (this.uvs6) {\r\n serializationObject.uvs6 = this.uvs6;\r\n }\r\n if (this.colors) {\r\n serializationObject.colors = this.colors;\r\n }\r\n if (this.matricesIndices) {\r\n serializationObject.matricesIndices = this.matricesIndices;\r\n serializationObject.matricesIndices._isExpanded = true;\r\n }\r\n if (this.matricesWeights) {\r\n serializationObject.matricesWeights = this.matricesWeights;\r\n }\r\n if (this.matricesIndicesExtra) {\r\n serializationObject.matricesIndicesExtra = this.matricesIndicesExtra;\r\n serializationObject.matricesIndicesExtra._isExpanded = true;\r\n }\r\n if (this.matricesWeightsExtra) {\r\n serializationObject.matricesWeightsExtra = this.matricesWeightsExtra;\r\n }\r\n serializationObject.indices = this.indices;\r\n return serializationObject;\r\n };\r\n // Statics\r\n /**\r\n * Extracts the vertexData from a mesh\r\n * @param mesh the mesh from which to extract the VertexData\r\n * @param copyWhenShared defines if the VertexData must be cloned when shared between multiple meshes, optional, default false\r\n * @param forceCopy indicating that the VertexData must be cloned, optional, default false\r\n * @returns the object VertexData associated to the passed mesh\r\n */\r\n VertexData.ExtractFromMesh = function (mesh, copyWhenShared, forceCopy) {\r\n return VertexData._ExtractFrom(mesh, copyWhenShared, forceCopy);\r\n };\r\n /**\r\n * Extracts the vertexData from the geometry\r\n * @param geometry the geometry from which to extract the VertexData\r\n * @param copyWhenShared defines if the VertexData must be cloned when the geometrty is shared between multiple meshes, optional, default false\r\n * @param forceCopy indicating that the VertexData must be cloned, optional, default false\r\n * @returns the object VertexData associated to the passed mesh\r\n */\r\n VertexData.ExtractFromGeometry = function (geometry, copyWhenShared, forceCopy) {\r\n return VertexData._ExtractFrom(geometry, copyWhenShared, forceCopy);\r\n };\r\n VertexData._ExtractFrom = function (meshOrGeometry, copyWhenShared, forceCopy) {\r\n var result = new VertexData();\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.PositionKind)) {\r\n result.positions = meshOrGeometry.getVerticesData(VertexBuffer.PositionKind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.NormalKind)) {\r\n result.normals = meshOrGeometry.getVerticesData(VertexBuffer.NormalKind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.TangentKind)) {\r\n result.tangents = meshOrGeometry.getVerticesData(VertexBuffer.TangentKind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.UVKind)) {\r\n result.uvs = meshOrGeometry.getVerticesData(VertexBuffer.UVKind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.UV2Kind)) {\r\n result.uvs2 = meshOrGeometry.getVerticesData(VertexBuffer.UV2Kind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.UV3Kind)) {\r\n result.uvs3 = meshOrGeometry.getVerticesData(VertexBuffer.UV3Kind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.UV4Kind)) {\r\n result.uvs4 = meshOrGeometry.getVerticesData(VertexBuffer.UV4Kind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.UV5Kind)) {\r\n result.uvs5 = meshOrGeometry.getVerticesData(VertexBuffer.UV5Kind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.UV6Kind)) {\r\n result.uvs6 = meshOrGeometry.getVerticesData(VertexBuffer.UV6Kind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.ColorKind)) {\r\n result.colors = meshOrGeometry.getVerticesData(VertexBuffer.ColorKind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.MatricesIndicesKind)) {\r\n result.matricesIndices = meshOrGeometry.getVerticesData(VertexBuffer.MatricesIndicesKind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.MatricesWeightsKind)) {\r\n result.matricesWeights = meshOrGeometry.getVerticesData(VertexBuffer.MatricesWeightsKind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.MatricesIndicesExtraKind)) {\r\n result.matricesIndicesExtra = meshOrGeometry.getVerticesData(VertexBuffer.MatricesIndicesExtraKind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.MatricesWeightsExtraKind)) {\r\n result.matricesWeightsExtra = meshOrGeometry.getVerticesData(VertexBuffer.MatricesWeightsExtraKind, copyWhenShared, forceCopy);\r\n }\r\n result.indices = meshOrGeometry.getIndices(copyWhenShared, forceCopy);\r\n return result;\r\n };\r\n /**\r\n * Creates the VertexData for a Ribbon\r\n * @param options an object used to set the following optional parameters for the ribbon, required but can be empty\r\n * * pathArray array of paths, each of which an array of successive Vector3\r\n * * closeArray creates a seam between the first and the last paths of the pathArray, optional, default false\r\n * * closePath creates a seam between the first and the last points of each path of the path array, optional, default false\r\n * * offset a positive integer, only used when pathArray contains a single path (offset = 10 means the point 1 is joined to the point 11), default rounded half size of the pathArray length\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * * invertUV swaps in the U and V coordinates when applying a texture, optional, default false\r\n * * uvs a linear array, of length 2 * number of vertices, of custom UV values, optional\r\n * * colors a linear array, of length 4 * number of vertices, of custom color values, optional\r\n * @returns the VertexData of the ribbon\r\n */\r\n VertexData.CreateRibbon = function (options) {\r\n throw _DevTools.WarnImport(\"ribbonBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for a box\r\n * @param options an object used to set the following optional parameters for the box, required but can be empty\r\n * * size sets the width, height and depth of the box to the value of size, optional default 1\r\n * * width sets the width (x direction) of the box, overwrites the width set by size, optional, default size\r\n * * height sets the height (y direction) of the box, overwrites the height set by size, optional, default size\r\n * * depth sets the depth (z direction) of the box, overwrites the depth set by size, optional, default size\r\n * * faceUV an array of 6 Vector4 elements used to set different images to each box side\r\n * * faceColors an array of 6 Color3 elements used to set different colors to each box side\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the box\r\n */\r\n VertexData.CreateBox = function (options) {\r\n throw _DevTools.WarnImport(\"boxBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for a tiled box\r\n * @param options an object used to set the following optional parameters for the box, required but can be empty\r\n * * faceTiles sets the pattern, tile size and number of tiles for a face\r\n * * faceUV an array of 6 Vector4 elements used to set different images to each box side\r\n * * faceColors an array of 6 Color3 elements used to set different colors to each box side\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * @returns the VertexData of the box\r\n */\r\n VertexData.CreateTiledBox = function (options) {\r\n throw _DevTools.WarnImport(\"tiledBoxBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for a tiled plane\r\n * @param options an object used to set the following optional parameters for the box, required but can be empty\r\n * * pattern a limited pattern arrangement depending on the number\r\n * * tileSize sets the width, height and depth of the tile to the value of size, optional default 1\r\n * * tileWidth sets the width (x direction) of the tile, overwrites the width set by size, optional, default size\r\n * * tileHeight sets the height (y direction) of the tile, overwrites the height set by size, optional, default size\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the tiled plane\r\n */\r\n VertexData.CreateTiledPlane = function (options) {\r\n throw _DevTools.WarnImport(\"tiledPlaneBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for an ellipsoid, defaults to a sphere\r\n * @param options an object used to set the following optional parameters for the box, required but can be empty\r\n * * segments sets the number of horizontal strips optional, default 32\r\n * * diameter sets the axes dimensions, diameterX, diameterY and diameterZ to the value of diameter, optional default 1\r\n * * diameterX sets the diameterX (x direction) of the ellipsoid, overwrites the diameterX set by diameter, optional, default diameter\r\n * * diameterY sets the diameterY (y direction) of the ellipsoid, overwrites the diameterY set by diameter, optional, default diameter\r\n * * diameterZ sets the diameterZ (z direction) of the ellipsoid, overwrites the diameterZ set by diameter, optional, default diameter\r\n * * arc a number from 0 to 1, to create an unclosed ellipsoid based on the fraction of the circumference (latitude) given by the arc value, optional, default 1\r\n * * slice a number from 0 to 1, to create an unclosed ellipsoid based on the fraction of the height (latitude) given by the arc value, optional, default 1\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the ellipsoid\r\n */\r\n VertexData.CreateSphere = function (options) {\r\n throw _DevTools.WarnImport(\"sphereBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for a cylinder, cone or prism\r\n * @param options an object used to set the following optional parameters for the box, required but can be empty\r\n * * height sets the height (y direction) of the cylinder, optional, default 2\r\n * * diameterTop sets the diameter of the top of the cone, overwrites diameter, optional, default diameter\r\n * * diameterBottom sets the diameter of the bottom of the cone, overwrites diameter, optional, default diameter\r\n * * diameter sets the diameter of the top and bottom of the cone, optional default 1\r\n * * tessellation the number of prism sides, 3 for a triangular prism, optional, default 24\r\n * * subdivisions` the number of rings along the cylinder height, optional, default 1\r\n * * arc a number from 0 to 1, to create an unclosed cylinder based on the fraction of the circumference given by the arc value, optional, default 1\r\n * * faceColors an array of Color3 elements used to set different colors to the top, rings and bottom respectively\r\n * * faceUV an array of Vector4 elements used to set different images to the top, rings and bottom respectively\r\n * * hasRings when true makes each subdivision independantly treated as a face for faceUV and faceColors, optional, default false\r\n * * enclose when true closes an open cylinder by adding extra flat faces between the height axis and vertical edges, think cut cake\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the cylinder, cone or prism\r\n */\r\n VertexData.CreateCylinder = function (options) {\r\n throw _DevTools.WarnImport(\"cylinderBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for a torus\r\n * @param options an object used to set the following optional parameters for the box, required but can be empty\r\n * * diameter the diameter of the torus, optional default 1\r\n * * thickness the diameter of the tube forming the torus, optional default 0.5\r\n * * tessellation the number of prism sides, 3 for a triangular prism, optional, default 24\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the torus\r\n */\r\n VertexData.CreateTorus = function (options) {\r\n throw _DevTools.WarnImport(\"torusBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData of the LineSystem\r\n * @param options an object used to set the following optional parameters for the LineSystem, required but can be empty\r\n * - lines an array of lines, each line being an array of successive Vector3\r\n * - colors an array of line colors, each of the line colors being an array of successive Color4, one per line point\r\n * @returns the VertexData of the LineSystem\r\n */\r\n VertexData.CreateLineSystem = function (options) {\r\n throw _DevTools.WarnImport(\"linesBuilder\");\r\n };\r\n /**\r\n * Create the VertexData for a DashedLines\r\n * @param options an object used to set the following optional parameters for the DashedLines, required but can be empty\r\n * - points an array successive Vector3\r\n * - dashSize the size of the dashes relative to the dash number, optional, default 3\r\n * - gapSize the size of the gap between two successive dashes relative to the dash number, optional, default 1\r\n * - dashNb the intended total number of dashes, optional, default 200\r\n * @returns the VertexData for the DashedLines\r\n */\r\n VertexData.CreateDashedLines = function (options) {\r\n throw _DevTools.WarnImport(\"linesBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for a Ground\r\n * @param options an object used to set the following optional parameters for the Ground, required but can be empty\r\n * - width the width (x direction) of the ground, optional, default 1\r\n * - height the height (z direction) of the ground, optional, default 1\r\n * - subdivisions the number of subdivisions per side, optional, default 1\r\n * @returns the VertexData of the Ground\r\n */\r\n VertexData.CreateGround = function (options) {\r\n throw _DevTools.WarnImport(\"groundBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for a TiledGround by subdividing the ground into tiles\r\n * @param options an object used to set the following optional parameters for the Ground, required but can be empty\r\n * * xmin the ground minimum X coordinate, optional, default -1\r\n * * zmin the ground minimum Z coordinate, optional, default -1\r\n * * xmax the ground maximum X coordinate, optional, default 1\r\n * * zmax the ground maximum Z coordinate, optional, default 1\r\n * * subdivisions a javascript object {w: positive integer, h: positive integer}, `w` and `h` are the numbers of subdivisions on the ground width and height creating 'tiles', default {w: 6, h: 6}\r\n * * precision a javascript object {w: positive integer, h: positive integer}, `w` and `h` are the numbers of subdivisions on the tile width and height, default {w: 2, h: 2}\r\n * @returns the VertexData of the TiledGround\r\n */\r\n VertexData.CreateTiledGround = function (options) {\r\n throw _DevTools.WarnImport(\"groundBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData of the Ground designed from a heightmap\r\n * @param options an object used to set the following parameters for the Ground, required and provided by MeshBuilder.CreateGroundFromHeightMap\r\n * * width the width (x direction) of the ground\r\n * * height the height (z direction) of the ground\r\n * * subdivisions the number of subdivisions per side\r\n * * minHeight the minimum altitude on the ground, optional, default 0\r\n * * maxHeight the maximum altitude on the ground, optional default 1\r\n * * colorFilter the filter to apply to the image pixel colors to compute the height, optional Color3, default (0.3, 0.59, 0.11)\r\n * * buffer the array holding the image color data\r\n * * bufferWidth the width of image\r\n * * bufferHeight the height of image\r\n * * alphaFilter Remove any data where the alpha channel is below this value, defaults 0 (all data visible)\r\n * @returns the VertexData of the Ground designed from a heightmap\r\n */\r\n VertexData.CreateGroundFromHeightMap = function (options) {\r\n throw _DevTools.WarnImport(\"groundBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for a Plane\r\n * @param options an object used to set the following optional parameters for the plane, required but can be empty\r\n * * size sets the width and height of the plane to the value of size, optional default 1\r\n * * width sets the width (x direction) of the plane, overwrites the width set by size, optional, default size\r\n * * height sets the height (y direction) of the plane, overwrites the height set by size, optional, default size\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the box\r\n */\r\n VertexData.CreatePlane = function (options) {\r\n throw _DevTools.WarnImport(\"planeBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData of the Disc or regular Polygon\r\n * @param options an object used to set the following optional parameters for the disc, required but can be empty\r\n * * radius the radius of the disc, optional default 0.5\r\n * * tessellation the number of polygon sides, optional, default 64\r\n * * arc a number from 0 to 1, to create an unclosed polygon based on the fraction of the circumference given by the arc value, optional, default 1\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the box\r\n */\r\n VertexData.CreateDisc = function (options) {\r\n throw _DevTools.WarnImport(\"discBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for an irregular Polygon in the XoZ plane using a mesh built by polygonTriangulation.build()\r\n * All parameters are provided by MeshBuilder.CreatePolygon as needed\r\n * @param polygon a mesh built from polygonTriangulation.build()\r\n * @param sideOrientation takes the values Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * @param fUV an array of Vector4 elements used to set different images to the top, rings and bottom respectively\r\n * @param fColors an array of Color3 elements used to set different colors to the top, rings and bottom respectively\r\n * @param frontUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * @param backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the Polygon\r\n */\r\n VertexData.CreatePolygon = function (polygon, sideOrientation, fUV, fColors, frontUVs, backUVs) {\r\n throw _DevTools.WarnImport(\"polygonBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData of the IcoSphere\r\n * @param options an object used to set the following optional parameters for the IcoSphere, required but can be empty\r\n * * radius the radius of the IcoSphere, optional default 1\r\n * * radiusX allows stretching in the x direction, optional, default radius\r\n * * radiusY allows stretching in the y direction, optional, default radius\r\n * * radiusZ allows stretching in the z direction, optional, default radius\r\n * * flat when true creates a flat shaded mesh, optional, default true\r\n * * subdivisions increasing the subdivisions increases the number of faces, optional, default 4\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the IcoSphere\r\n */\r\n VertexData.CreateIcoSphere = function (options) {\r\n throw _DevTools.WarnImport(\"icoSphereBuilder\");\r\n };\r\n // inspired from // http://stemkoski.github.io/Three.js/Polyhedra.html\r\n /**\r\n * Creates the VertexData for a Polyhedron\r\n * @param options an object used to set the following optional parameters for the polyhedron, required but can be empty\r\n * * type provided types are:\r\n * * 0 : Tetrahedron, 1 : Octahedron, 2 : Dodecahedron, 3 : Icosahedron, 4 : Rhombicuboctahedron, 5 : Triangular Prism, 6 : Pentagonal Prism, 7 : Hexagonal Prism, 8 : Square Pyramid (J1)\r\n * * 9 : Pentagonal Pyramid (J2), 10 : Triangular Dipyramid (J12), 11 : Pentagonal Dipyramid (J13), 12 : Elongated Square Dipyramid (J15), 13 : Elongated Pentagonal Dipyramid (J16), 14 : Elongated Pentagonal Cupola (J20)\r\n * * size the size of the IcoSphere, optional default 1\r\n * * sizeX allows stretching in the x direction, optional, default size\r\n * * sizeY allows stretching in the y direction, optional, default size\r\n * * sizeZ allows stretching in the z direction, optional, default size\r\n * * custom a number that overwrites the type to create from an extended set of polyhedron from https://www.babylonjs-playground.com/#21QRSK#15 with minimised editor\r\n * * faceUV an array of Vector4 elements used to set different images to the top, rings and bottom respectively\r\n * * faceColors an array of Color3 elements used to set different colors to the top, rings and bottom respectively\r\n * * flat when true creates a flat shaded mesh, optional, default true\r\n * * subdivisions increasing the subdivisions increases the number of faces, optional, default 4\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the Polyhedron\r\n */\r\n VertexData.CreatePolyhedron = function (options) {\r\n throw _DevTools.WarnImport(\"polyhedronBuilder\");\r\n };\r\n // based on http://code.google.com/p/away3d/source/browse/trunk/fp10/Away3D/src/away3d/primitives/TorusKnot.as?spec=svn2473&r=2473\r\n /**\r\n * Creates the VertexData for a TorusKnot\r\n * @param options an object used to set the following optional parameters for the TorusKnot, required but can be empty\r\n * * radius the radius of the torus knot, optional, default 2\r\n * * tube the thickness of the tube, optional, default 0.5\r\n * * radialSegments the number of sides on each tube segments, optional, default 32\r\n * * tubularSegments the number of tubes to decompose the knot into, optional, default 32\r\n * * p the number of windings around the z axis, optional, default 2\r\n * * q the number of windings around the x axis, optional, default 3\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the Torus Knot\r\n */\r\n VertexData.CreateTorusKnot = function (options) {\r\n throw _DevTools.WarnImport(\"torusKnotBuilder\");\r\n };\r\n // Tools\r\n /**\r\n * Compute normals for given positions and indices\r\n * @param positions an array of vertex positions, [...., x, y, z, ......]\r\n * @param indices an array of indices in groups of three for each triangular facet, [...., i, j, k, ......]\r\n * @param normals an array of vertex normals, [...., x, y, z, ......]\r\n * @param options an object used to set the following optional parameters for the TorusKnot, optional\r\n * * facetNormals : optional array of facet normals (vector3)\r\n * * facetPositions : optional array of facet positions (vector3)\r\n * * facetPartitioning : optional partitioning array. facetPositions is required for facetPartitioning computation\r\n * * ratio : optional partitioning ratio / bounding box, required for facetPartitioning computation\r\n * * bInfo : optional bounding info, required for facetPartitioning computation\r\n * * bbSize : optional bounding box size data, required for facetPartitioning computation\r\n * * subDiv : optional partitioning data about subdivsions on each axis (int), required for facetPartitioning computation\r\n * * useRightHandedSystem: optional boolean to for right handed system computation\r\n * * depthSort : optional boolean to enable the facet depth sort computation\r\n * * distanceTo : optional Vector3 to compute the facet depth from this location\r\n * * depthSortedFacets : optional array of depthSortedFacets to store the facet distances from the reference location\r\n */\r\n VertexData.ComputeNormals = function (positions, indices, normals, options) {\r\n // temporary scalar variables\r\n var index = 0; // facet index\r\n var p1p2x = 0.0; // p1p2 vector x coordinate\r\n var p1p2y = 0.0; // p1p2 vector y coordinate\r\n var p1p2z = 0.0; // p1p2 vector z coordinate\r\n var p3p2x = 0.0; // p3p2 vector x coordinate\r\n var p3p2y = 0.0; // p3p2 vector y coordinate\r\n var p3p2z = 0.0; // p3p2 vector z coordinate\r\n var faceNormalx = 0.0; // facet normal x coordinate\r\n var faceNormaly = 0.0; // facet normal y coordinate\r\n var faceNormalz = 0.0; // facet normal z coordinate\r\n var length = 0.0; // facet normal length before normalization\r\n var v1x = 0; // vector1 x index in the positions array\r\n var v1y = 0; // vector1 y index in the positions array\r\n var v1z = 0; // vector1 z index in the positions array\r\n var v2x = 0; // vector2 x index in the positions array\r\n var v2y = 0; // vector2 y index in the positions array\r\n var v2z = 0; // vector2 z index in the positions array\r\n var v3x = 0; // vector3 x index in the positions array\r\n var v3y = 0; // vector3 y index in the positions array\r\n var v3z = 0; // vector3 z index in the positions array\r\n var computeFacetNormals = false;\r\n var computeFacetPositions = false;\r\n var computeFacetPartitioning = false;\r\n var computeDepthSort = false;\r\n var faceNormalSign = 1;\r\n var ratio = 0;\r\n var distanceTo = null;\r\n if (options) {\r\n computeFacetNormals = (options.facetNormals) ? true : false;\r\n computeFacetPositions = (options.facetPositions) ? true : false;\r\n computeFacetPartitioning = (options.facetPartitioning) ? true : false;\r\n faceNormalSign = (options.useRightHandedSystem === true) ? -1 : 1;\r\n ratio = options.ratio || 0;\r\n computeDepthSort = (options.depthSort) ? true : false;\r\n distanceTo = (options.distanceTo);\r\n if (computeDepthSort) {\r\n if (distanceTo === undefined) {\r\n distanceTo = Vector3.Zero();\r\n }\r\n var depthSortedFacets = options.depthSortedFacets;\r\n }\r\n }\r\n // facetPartitioning reinit if needed\r\n var xSubRatio = 0;\r\n var ySubRatio = 0;\r\n var zSubRatio = 0;\r\n var subSq = 0;\r\n if (computeFacetPartitioning && options && options.bbSize) {\r\n var ox = 0; // X partitioning index for facet position\r\n var oy = 0; // Y partinioning index for facet position\r\n var oz = 0; // Z partinioning index for facet position\r\n var b1x = 0; // X partitioning index for facet v1 vertex\r\n var b1y = 0; // Y partitioning index for facet v1 vertex\r\n var b1z = 0; // z partitioning index for facet v1 vertex\r\n var b2x = 0; // X partitioning index for facet v2 vertex\r\n var b2y = 0; // Y partitioning index for facet v2 vertex\r\n var b2z = 0; // Z partitioning index for facet v2 vertex\r\n var b3x = 0; // X partitioning index for facet v3 vertex\r\n var b3y = 0; // Y partitioning index for facet v3 vertex\r\n var b3z = 0; // Z partitioning index for facet v3 vertex\r\n var block_idx_o = 0; // facet barycenter block index\r\n var block_idx_v1 = 0; // v1 vertex block index\r\n var block_idx_v2 = 0; // v2 vertex block index\r\n var block_idx_v3 = 0; // v3 vertex block index\r\n var bbSizeMax = (options.bbSize.x > options.bbSize.y) ? options.bbSize.x : options.bbSize.y;\r\n bbSizeMax = (bbSizeMax > options.bbSize.z) ? bbSizeMax : options.bbSize.z;\r\n xSubRatio = options.subDiv.X * ratio / options.bbSize.x;\r\n ySubRatio = options.subDiv.Y * ratio / options.bbSize.y;\r\n zSubRatio = options.subDiv.Z * ratio / options.bbSize.z;\r\n subSq = options.subDiv.max * options.subDiv.max;\r\n options.facetPartitioning.length = 0;\r\n }\r\n // reset the normals\r\n for (index = 0; index < positions.length; index++) {\r\n normals[index] = 0.0;\r\n }\r\n // Loop : 1 indice triplet = 1 facet\r\n var nbFaces = (indices.length / 3) | 0;\r\n for (index = 0; index < nbFaces; index++) {\r\n // get the indexes of the coordinates of each vertex of the facet\r\n v1x = indices[index * 3] * 3;\r\n v1y = v1x + 1;\r\n v1z = v1x + 2;\r\n v2x = indices[index * 3 + 1] * 3;\r\n v2y = v2x + 1;\r\n v2z = v2x + 2;\r\n v3x = indices[index * 3 + 2] * 3;\r\n v3y = v3x + 1;\r\n v3z = v3x + 2;\r\n p1p2x = positions[v1x] - positions[v2x]; // compute two vectors per facet : p1p2 and p3p2\r\n p1p2y = positions[v1y] - positions[v2y];\r\n p1p2z = positions[v1z] - positions[v2z];\r\n p3p2x = positions[v3x] - positions[v2x];\r\n p3p2y = positions[v3y] - positions[v2y];\r\n p3p2z = positions[v3z] - positions[v2z];\r\n // compute the face normal with the cross product\r\n faceNormalx = faceNormalSign * (p1p2y * p3p2z - p1p2z * p3p2y);\r\n faceNormaly = faceNormalSign * (p1p2z * p3p2x - p1p2x * p3p2z);\r\n faceNormalz = faceNormalSign * (p1p2x * p3p2y - p1p2y * p3p2x);\r\n // normalize this normal and store it in the array facetData\r\n length = Math.sqrt(faceNormalx * faceNormalx + faceNormaly * faceNormaly + faceNormalz * faceNormalz);\r\n length = (length === 0) ? 1.0 : length;\r\n faceNormalx /= length;\r\n faceNormaly /= length;\r\n faceNormalz /= length;\r\n if (computeFacetNormals && options) {\r\n options.facetNormals[index].x = faceNormalx;\r\n options.facetNormals[index].y = faceNormaly;\r\n options.facetNormals[index].z = faceNormalz;\r\n }\r\n if (computeFacetPositions && options) {\r\n // compute and the facet barycenter coordinates in the array facetPositions\r\n options.facetPositions[index].x = (positions[v1x] + positions[v2x] + positions[v3x]) / 3.0;\r\n options.facetPositions[index].y = (positions[v1y] + positions[v2y] + positions[v3y]) / 3.0;\r\n options.facetPositions[index].z = (positions[v1z] + positions[v2z] + positions[v3z]) / 3.0;\r\n }\r\n if (computeFacetPartitioning && options) {\r\n // store the facet indexes in arrays in the main facetPartitioning array :\r\n // compute each facet vertex (+ facet barycenter) index in the partiniong array\r\n ox = Math.floor((options.facetPositions[index].x - options.bInfo.minimum.x * ratio) * xSubRatio);\r\n oy = Math.floor((options.facetPositions[index].y - options.bInfo.minimum.y * ratio) * ySubRatio);\r\n oz = Math.floor((options.facetPositions[index].z - options.bInfo.minimum.z * ratio) * zSubRatio);\r\n b1x = Math.floor((positions[v1x] - options.bInfo.minimum.x * ratio) * xSubRatio);\r\n b1y = Math.floor((positions[v1y] - options.bInfo.minimum.y * ratio) * ySubRatio);\r\n b1z = Math.floor((positions[v1z] - options.bInfo.minimum.z * ratio) * zSubRatio);\r\n b2x = Math.floor((positions[v2x] - options.bInfo.minimum.x * ratio) * xSubRatio);\r\n b2y = Math.floor((positions[v2y] - options.bInfo.minimum.y * ratio) * ySubRatio);\r\n b2z = Math.floor((positions[v2z] - options.bInfo.minimum.z * ratio) * zSubRatio);\r\n b3x = Math.floor((positions[v3x] - options.bInfo.minimum.x * ratio) * xSubRatio);\r\n b3y = Math.floor((positions[v3y] - options.bInfo.minimum.y * ratio) * ySubRatio);\r\n b3z = Math.floor((positions[v3z] - options.bInfo.minimum.z * ratio) * zSubRatio);\r\n block_idx_v1 = b1x + options.subDiv.max * b1y + subSq * b1z;\r\n block_idx_v2 = b2x + options.subDiv.max * b2y + subSq * b2z;\r\n block_idx_v3 = b3x + options.subDiv.max * b3y + subSq * b3z;\r\n block_idx_o = ox + options.subDiv.max * oy + subSq * oz;\r\n options.facetPartitioning[block_idx_o] = options.facetPartitioning[block_idx_o] ? options.facetPartitioning[block_idx_o] : new Array();\r\n options.facetPartitioning[block_idx_v1] = options.facetPartitioning[block_idx_v1] ? options.facetPartitioning[block_idx_v1] : new Array();\r\n options.facetPartitioning[block_idx_v2] = options.facetPartitioning[block_idx_v2] ? options.facetPartitioning[block_idx_v2] : new Array();\r\n options.facetPartitioning[block_idx_v3] = options.facetPartitioning[block_idx_v3] ? options.facetPartitioning[block_idx_v3] : new Array();\r\n // push each facet index in each block containing the vertex\r\n options.facetPartitioning[block_idx_v1].push(index);\r\n if (block_idx_v2 != block_idx_v1) {\r\n options.facetPartitioning[block_idx_v2].push(index);\r\n }\r\n if (!(block_idx_v3 == block_idx_v2 || block_idx_v3 == block_idx_v1)) {\r\n options.facetPartitioning[block_idx_v3].push(index);\r\n }\r\n if (!(block_idx_o == block_idx_v1 || block_idx_o == block_idx_v2 || block_idx_o == block_idx_v3)) {\r\n options.facetPartitioning[block_idx_o].push(index);\r\n }\r\n }\r\n if (computeDepthSort && options && options.facetPositions) {\r\n var dsf = depthSortedFacets[index];\r\n dsf.ind = index * 3;\r\n dsf.sqDistance = Vector3.DistanceSquared(options.facetPositions[index], distanceTo);\r\n }\r\n // compute the normals anyway\r\n normals[v1x] += faceNormalx; // accumulate all the normals per face\r\n normals[v1y] += faceNormaly;\r\n normals[v1z] += faceNormalz;\r\n normals[v2x] += faceNormalx;\r\n normals[v2y] += faceNormaly;\r\n normals[v2z] += faceNormalz;\r\n normals[v3x] += faceNormalx;\r\n normals[v3y] += faceNormaly;\r\n normals[v3z] += faceNormalz;\r\n }\r\n // last normalization of each normal\r\n for (index = 0; index < normals.length / 3; index++) {\r\n faceNormalx = normals[index * 3];\r\n faceNormaly = normals[index * 3 + 1];\r\n faceNormalz = normals[index * 3 + 2];\r\n length = Math.sqrt(faceNormalx * faceNormalx + faceNormaly * faceNormaly + faceNormalz * faceNormalz);\r\n length = (length === 0) ? 1.0 : length;\r\n faceNormalx /= length;\r\n faceNormaly /= length;\r\n faceNormalz /= length;\r\n normals[index * 3] = faceNormalx;\r\n normals[index * 3 + 1] = faceNormaly;\r\n normals[index * 3 + 2] = faceNormalz;\r\n }\r\n };\r\n /** @hidden */\r\n VertexData._ComputeSides = function (sideOrientation, positions, indices, normals, uvs, frontUVs, backUVs) {\r\n var li = indices.length;\r\n var ln = normals.length;\r\n var i;\r\n var n;\r\n sideOrientation = sideOrientation || VertexData.DEFAULTSIDE;\r\n switch (sideOrientation) {\r\n case VertexData.FRONTSIDE:\r\n // nothing changed\r\n break;\r\n case VertexData.BACKSIDE:\r\n var tmp;\r\n // indices\r\n for (i = 0; i < li; i += 3) {\r\n tmp = indices[i];\r\n indices[i] = indices[i + 2];\r\n indices[i + 2] = tmp;\r\n }\r\n // normals\r\n for (n = 0; n < ln; n++) {\r\n normals[n] = -normals[n];\r\n }\r\n break;\r\n case VertexData.DOUBLESIDE:\r\n // positions\r\n var lp = positions.length;\r\n var l = lp / 3;\r\n for (var p = 0; p < lp; p++) {\r\n positions[lp + p] = positions[p];\r\n }\r\n // indices\r\n for (i = 0; i < li; i += 3) {\r\n indices[i + li] = indices[i + 2] + l;\r\n indices[i + 1 + li] = indices[i + 1] + l;\r\n indices[i + 2 + li] = indices[i] + l;\r\n }\r\n // normals\r\n for (n = 0; n < ln; n++) {\r\n normals[ln + n] = -normals[n];\r\n }\r\n // uvs\r\n var lu = uvs.length;\r\n var u = 0;\r\n for (u = 0; u < lu; u++) {\r\n uvs[u + lu] = uvs[u];\r\n }\r\n frontUVs = frontUVs ? frontUVs : new Vector4(0.0, 0.0, 1.0, 1.0);\r\n backUVs = backUVs ? backUVs : new Vector4(0.0, 0.0, 1.0, 1.0);\r\n u = 0;\r\n for (i = 0; i < lu / 2; i++) {\r\n uvs[u] = frontUVs.x + (frontUVs.z - frontUVs.x) * uvs[u];\r\n uvs[u + 1] = frontUVs.y + (frontUVs.w - frontUVs.y) * uvs[u + 1];\r\n uvs[u + lu] = backUVs.x + (backUVs.z - backUVs.x) * uvs[u + lu];\r\n uvs[u + lu + 1] = backUVs.y + (backUVs.w - backUVs.y) * uvs[u + lu + 1];\r\n u += 2;\r\n }\r\n break;\r\n }\r\n };\r\n /**\r\n * Applies VertexData created from the imported parameters to the geometry\r\n * @param parsedVertexData the parsed data from an imported file\r\n * @param geometry the geometry to apply the VertexData to\r\n */\r\n VertexData.ImportVertexData = function (parsedVertexData, geometry) {\r\n var vertexData = new VertexData();\r\n // positions\r\n var positions = parsedVertexData.positions;\r\n if (positions) {\r\n vertexData.set(positions, VertexBuffer.PositionKind);\r\n }\r\n // normals\r\n var normals = parsedVertexData.normals;\r\n if (normals) {\r\n vertexData.set(normals, VertexBuffer.NormalKind);\r\n }\r\n // tangents\r\n var tangents = parsedVertexData.tangents;\r\n if (tangents) {\r\n vertexData.set(tangents, VertexBuffer.TangentKind);\r\n }\r\n // uvs\r\n var uvs = parsedVertexData.uvs;\r\n if (uvs) {\r\n vertexData.set(uvs, VertexBuffer.UVKind);\r\n }\r\n // uv2s\r\n var uv2s = parsedVertexData.uv2s;\r\n if (uv2s) {\r\n vertexData.set(uv2s, VertexBuffer.UV2Kind);\r\n }\r\n // uv3s\r\n var uv3s = parsedVertexData.uv3s;\r\n if (uv3s) {\r\n vertexData.set(uv3s, VertexBuffer.UV3Kind);\r\n }\r\n // uv4s\r\n var uv4s = parsedVertexData.uv4s;\r\n if (uv4s) {\r\n vertexData.set(uv4s, VertexBuffer.UV4Kind);\r\n }\r\n // uv5s\r\n var uv5s = parsedVertexData.uv5s;\r\n if (uv5s) {\r\n vertexData.set(uv5s, VertexBuffer.UV5Kind);\r\n }\r\n // uv6s\r\n var uv6s = parsedVertexData.uv6s;\r\n if (uv6s) {\r\n vertexData.set(uv6s, VertexBuffer.UV6Kind);\r\n }\r\n // colors\r\n var colors = parsedVertexData.colors;\r\n if (colors) {\r\n vertexData.set(Color4.CheckColors4(colors, positions.length / 3), VertexBuffer.ColorKind);\r\n }\r\n // matricesIndices\r\n var matricesIndices = parsedVertexData.matricesIndices;\r\n if (matricesIndices) {\r\n vertexData.set(matricesIndices, VertexBuffer.MatricesIndicesKind);\r\n }\r\n // matricesWeights\r\n var matricesWeights = parsedVertexData.matricesWeights;\r\n if (matricesWeights) {\r\n vertexData.set(matricesWeights, VertexBuffer.MatricesWeightsKind);\r\n }\r\n // indices\r\n var indices = parsedVertexData.indices;\r\n if (indices) {\r\n vertexData.indices = indices;\r\n }\r\n geometry.setAllVerticesData(vertexData, parsedVertexData.updatable);\r\n };\r\n /**\r\n * Mesh side orientation : usually the external or front surface\r\n */\r\n VertexData.FRONTSIDE = 0;\r\n /**\r\n * Mesh side orientation : usually the internal or back surface\r\n */\r\n VertexData.BACKSIDE = 1;\r\n /**\r\n * Mesh side orientation : both internal and external or front and back surfaces\r\n */\r\n VertexData.DOUBLESIDE = 2;\r\n /**\r\n * Mesh side orientation : by default, `FRONTSIDE`\r\n */\r\n VertexData.DEFAULTSIDE = 0;\r\n return VertexData;\r\n}());\r\nexport { VertexData };\r\n//# sourceMappingURL=mesh.vertexData.js.map","/**\r\n * Logger used througouht the application to allow configuration of\r\n * the log level required for the messages.\r\n */\r\nvar Logger = /** @class */ (function () {\r\n function Logger() {\r\n }\r\n Logger._AddLogEntry = function (entry) {\r\n Logger._LogCache = entry + Logger._LogCache;\r\n if (Logger.OnNewCacheEntry) {\r\n Logger.OnNewCacheEntry(entry);\r\n }\r\n };\r\n Logger._FormatMessage = function (message) {\r\n var padStr = function (i) { return (i < 10) ? \"0\" + i : \"\" + i; };\r\n var date = new Date();\r\n return \"[\" + padStr(date.getHours()) + \":\" + padStr(date.getMinutes()) + \":\" + padStr(date.getSeconds()) + \"]: \" + message;\r\n };\r\n Logger._LogDisabled = function (message) {\r\n // nothing to do\r\n };\r\n Logger._LogEnabled = function (message) {\r\n var formattedMessage = Logger._FormatMessage(message);\r\n console.log(\"BJS - \" + formattedMessage);\r\n var entry = \"
\" + formattedMessage + \"

\";\r\n Logger._AddLogEntry(entry);\r\n };\r\n Logger._WarnDisabled = function (message) {\r\n // nothing to do\r\n };\r\n Logger._WarnEnabled = function (message) {\r\n var formattedMessage = Logger._FormatMessage(message);\r\n console.warn(\"BJS - \" + formattedMessage);\r\n var entry = \"
\" + formattedMessage + \"

\";\r\n Logger._AddLogEntry(entry);\r\n };\r\n Logger._ErrorDisabled = function (message) {\r\n // nothing to do\r\n };\r\n Logger._ErrorEnabled = function (message) {\r\n Logger.errorsCount++;\r\n var formattedMessage = Logger._FormatMessage(message);\r\n console.error(\"BJS - \" + formattedMessage);\r\n var entry = \"
\" + formattedMessage + \"

\";\r\n Logger._AddLogEntry(entry);\r\n };\r\n Object.defineProperty(Logger, \"LogCache\", {\r\n /**\r\n * Gets current log cache (list of logs)\r\n */\r\n get: function () {\r\n return Logger._LogCache;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Clears the log cache\r\n */\r\n Logger.ClearLogCache = function () {\r\n Logger._LogCache = \"\";\r\n Logger.errorsCount = 0;\r\n };\r\n Object.defineProperty(Logger, \"LogLevels\", {\r\n /**\r\n * Sets the current log level (MessageLogLevel / WarningLogLevel / ErrorLogLevel)\r\n */\r\n set: function (level) {\r\n if ((level & Logger.MessageLogLevel) === Logger.MessageLogLevel) {\r\n Logger.Log = Logger._LogEnabled;\r\n }\r\n else {\r\n Logger.Log = Logger._LogDisabled;\r\n }\r\n if ((level & Logger.WarningLogLevel) === Logger.WarningLogLevel) {\r\n Logger.Warn = Logger._WarnEnabled;\r\n }\r\n else {\r\n Logger.Warn = Logger._WarnDisabled;\r\n }\r\n if ((level & Logger.ErrorLogLevel) === Logger.ErrorLogLevel) {\r\n Logger.Error = Logger._ErrorEnabled;\r\n }\r\n else {\r\n Logger.Error = Logger._ErrorDisabled;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * No log\r\n */\r\n Logger.NoneLogLevel = 0;\r\n /**\r\n * Only message logs\r\n */\r\n Logger.MessageLogLevel = 1;\r\n /**\r\n * Only warning logs\r\n */\r\n Logger.WarningLogLevel = 2;\r\n /**\r\n * Only error logs\r\n */\r\n Logger.ErrorLogLevel = 4;\r\n /**\r\n * All logs\r\n */\r\n Logger.AllLogLevel = 7;\r\n Logger._LogCache = \"\";\r\n /**\r\n * Gets a value indicating the number of loading errors\r\n * @ignorenaming\r\n */\r\n Logger.errorsCount = 0;\r\n /**\r\n * Log a message to the console\r\n */\r\n Logger.Log = Logger._LogEnabled;\r\n /**\r\n * Write a warning message to the console\r\n */\r\n Logger.Warn = Logger._WarnEnabled;\r\n /**\r\n * Write an error message to the console\r\n */\r\n Logger.Error = Logger._ErrorEnabled;\r\n return Logger;\r\n}());\r\nexport { Logger };\r\n//# sourceMappingURL=logger.js.map","var PromiseStates;\r\n(function (PromiseStates) {\r\n PromiseStates[PromiseStates[\"Pending\"] = 0] = \"Pending\";\r\n PromiseStates[PromiseStates[\"Fulfilled\"] = 1] = \"Fulfilled\";\r\n PromiseStates[PromiseStates[\"Rejected\"] = 2] = \"Rejected\";\r\n})(PromiseStates || (PromiseStates = {}));\r\nvar FulFillmentAgregator = /** @class */ (function () {\r\n function FulFillmentAgregator() {\r\n this.count = 0;\r\n this.target = 0;\r\n this.results = [];\r\n }\r\n return FulFillmentAgregator;\r\n}());\r\nvar InternalPromise = /** @class */ (function () {\r\n function InternalPromise(resolver) {\r\n var _this = this;\r\n this._state = PromiseStates.Pending;\r\n this._children = new Array();\r\n this._rejectWasConsumed = false;\r\n if (!resolver) {\r\n return;\r\n }\r\n try {\r\n resolver(function (value) {\r\n _this._resolve(value);\r\n }, function (reason) {\r\n _this._reject(reason);\r\n });\r\n }\r\n catch (e) {\r\n this._reject(e);\r\n }\r\n }\r\n Object.defineProperty(InternalPromise.prototype, \"_result\", {\r\n get: function () {\r\n return this._resultValue;\r\n },\r\n set: function (value) {\r\n this._resultValue = value;\r\n if (this._parent && this._parent._result === undefined) {\r\n this._parent._result = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n InternalPromise.prototype.catch = function (onRejected) {\r\n return this.then(undefined, onRejected);\r\n };\r\n InternalPromise.prototype.then = function (onFulfilled, onRejected) {\r\n var _this = this;\r\n var newPromise = new InternalPromise();\r\n newPromise._onFulfilled = onFulfilled;\r\n newPromise._onRejected = onRejected;\r\n // Composition\r\n this._children.push(newPromise);\r\n newPromise._parent = this;\r\n if (this._state !== PromiseStates.Pending) {\r\n setTimeout(function () {\r\n if (_this._state === PromiseStates.Fulfilled || _this._rejectWasConsumed) {\r\n var returnedValue = newPromise._resolve(_this._result);\r\n if (returnedValue !== undefined && returnedValue !== null) {\r\n if (returnedValue._state !== undefined) {\r\n var returnedPromise = returnedValue;\r\n newPromise._children.push(returnedPromise);\r\n returnedPromise._parent = newPromise;\r\n newPromise = returnedPromise;\r\n }\r\n else {\r\n newPromise._result = returnedValue;\r\n }\r\n }\r\n }\r\n else {\r\n newPromise._reject(_this._reason);\r\n }\r\n });\r\n }\r\n return newPromise;\r\n };\r\n InternalPromise.prototype._moveChildren = function (children) {\r\n var _a;\r\n var _this = this;\r\n (_a = this._children).push.apply(_a, children.splice(0, children.length));\r\n this._children.forEach(function (child) {\r\n child._parent = _this;\r\n });\r\n if (this._state === PromiseStates.Fulfilled) {\r\n for (var _i = 0, _b = this._children; _i < _b.length; _i++) {\r\n var child = _b[_i];\r\n child._resolve(this._result);\r\n }\r\n }\r\n else if (this._state === PromiseStates.Rejected) {\r\n for (var _c = 0, _d = this._children; _c < _d.length; _c++) {\r\n var child = _d[_c];\r\n child._reject(this._reason);\r\n }\r\n }\r\n };\r\n InternalPromise.prototype._resolve = function (value) {\r\n try {\r\n this._state = PromiseStates.Fulfilled;\r\n var returnedValue = null;\r\n if (this._onFulfilled) {\r\n returnedValue = this._onFulfilled(value);\r\n }\r\n if (returnedValue !== undefined && returnedValue !== null) {\r\n if (returnedValue._state !== undefined) {\r\n // Transmit children\r\n var returnedPromise = returnedValue;\r\n returnedPromise._parent = this;\r\n returnedPromise._moveChildren(this._children);\r\n value = returnedPromise._result;\r\n }\r\n else {\r\n value = returnedValue;\r\n }\r\n }\r\n this._result = value;\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child._resolve(value);\r\n }\r\n this._children.length = 0;\r\n delete this._onFulfilled;\r\n delete this._onRejected;\r\n }\r\n catch (e) {\r\n this._reject(e, true);\r\n }\r\n };\r\n InternalPromise.prototype._reject = function (reason, onLocalThrow) {\r\n if (onLocalThrow === void 0) { onLocalThrow = false; }\r\n this._state = PromiseStates.Rejected;\r\n this._reason = reason;\r\n if (this._onRejected && !onLocalThrow) {\r\n try {\r\n this._onRejected(reason);\r\n this._rejectWasConsumed = true;\r\n }\r\n catch (e) {\r\n reason = e;\r\n }\r\n }\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (this._rejectWasConsumed) {\r\n child._resolve(null);\r\n }\r\n else {\r\n child._reject(reason);\r\n }\r\n }\r\n this._children.length = 0;\r\n delete this._onFulfilled;\r\n delete this._onRejected;\r\n };\r\n InternalPromise.resolve = function (value) {\r\n var newPromise = new InternalPromise();\r\n newPromise._resolve(value);\r\n return newPromise;\r\n };\r\n InternalPromise._RegisterForFulfillment = function (promise, agregator, index) {\r\n promise.then(function (value) {\r\n agregator.results[index] = value;\r\n agregator.count++;\r\n if (agregator.count === agregator.target) {\r\n agregator.rootPromise._resolve(agregator.results);\r\n }\r\n return null;\r\n }, function (reason) {\r\n if (agregator.rootPromise._state !== PromiseStates.Rejected) {\r\n agregator.rootPromise._reject(reason);\r\n }\r\n });\r\n };\r\n InternalPromise.all = function (promises) {\r\n var newPromise = new InternalPromise();\r\n var agregator = new FulFillmentAgregator();\r\n agregator.target = promises.length;\r\n agregator.rootPromise = newPromise;\r\n if (promises.length) {\r\n for (var index = 0; index < promises.length; index++) {\r\n InternalPromise._RegisterForFulfillment(promises[index], agregator, index);\r\n }\r\n }\r\n else {\r\n newPromise._resolve([]);\r\n }\r\n return newPromise;\r\n };\r\n InternalPromise.race = function (promises) {\r\n var newPromise = new InternalPromise();\r\n if (promises.length) {\r\n for (var _i = 0, promises_1 = promises; _i < promises_1.length; _i++) {\r\n var promise = promises_1[_i];\r\n promise.then(function (value) {\r\n if (newPromise) {\r\n newPromise._resolve(value);\r\n newPromise = null;\r\n }\r\n return null;\r\n }, function (reason) {\r\n if (newPromise) {\r\n newPromise._reject(reason);\r\n newPromise = null;\r\n }\r\n });\r\n }\r\n }\r\n return newPromise;\r\n };\r\n return InternalPromise;\r\n}());\r\n/**\r\n * Helper class that provides a small promise polyfill\r\n */\r\nvar PromisePolyfill = /** @class */ (function () {\r\n function PromisePolyfill() {\r\n }\r\n /**\r\n * Static function used to check if the polyfill is required\r\n * If this is the case then the function will inject the polyfill to window.Promise\r\n * @param force defines a boolean used to force the injection (mostly for testing purposes)\r\n */\r\n PromisePolyfill.Apply = function (force) {\r\n if (force === void 0) { force = false; }\r\n if (force || typeof Promise === 'undefined') {\r\n var root = window;\r\n root.Promise = InternalPromise;\r\n }\r\n };\r\n return PromisePolyfill;\r\n}());\r\nexport { PromisePolyfill };\r\n//# sourceMappingURL=promise.js.map","import { Observable } from \"./observable\";\r\nimport { DomManagement } from \"./domManagement\";\r\nimport { Logger } from \"./logger\";\r\nimport { DeepCopier } from \"./deepCopier\";\r\nimport { PrecisionDate } from './precisionDate';\r\nimport { _DevTools } from './devTools';\r\nimport { WebRequest } from './webRequest';\r\nimport { EngineStore } from '../Engines/engineStore';\r\nimport { FileTools } from './fileTools';\r\nimport { PromisePolyfill } from './promise';\r\nimport { TimingTools } from './timingTools';\r\nimport { InstantiationTools } from './instantiationTools';\r\nimport { GUID } from './guid';\r\n/**\r\n * Class containing a set of static utilities functions\r\n */\r\nvar Tools = /** @class */ (function () {\r\n function Tools() {\r\n }\r\n Object.defineProperty(Tools, \"BaseUrl\", {\r\n /**\r\n * Gets or sets the base URL to use to load assets\r\n */\r\n get: function () {\r\n return FileTools.BaseUrl;\r\n },\r\n set: function (value) {\r\n FileTools.BaseUrl = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Tools, \"DefaultRetryStrategy\", {\r\n /**\r\n * Gets or sets the retry strategy to apply when an error happens while loading an asset\r\n */\r\n get: function () {\r\n return FileTools.DefaultRetryStrategy;\r\n },\r\n set: function (strategy) {\r\n FileTools.DefaultRetryStrategy = strategy;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Tools, \"UseFallbackTexture\", {\r\n /**\r\n * Gets or sets a global variable indicating if fallback texture must be used when a texture cannot be loaded\r\n * @ignorenaming\r\n */\r\n get: function () {\r\n return EngineStore.UseFallbackTexture;\r\n },\r\n set: function (value) {\r\n EngineStore.UseFallbackTexture = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Tools, \"RegisteredExternalClasses\", {\r\n /**\r\n * Use this object to register external classes like custom textures or material\r\n * to allow the laoders to instantiate them\r\n */\r\n get: function () {\r\n return InstantiationTools.RegisteredExternalClasses;\r\n },\r\n set: function (classes) {\r\n InstantiationTools.RegisteredExternalClasses = classes;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Tools, \"fallbackTexture\", {\r\n /**\r\n * Texture content used if a texture cannot loaded\r\n * @ignorenaming\r\n */\r\n get: function () {\r\n return EngineStore.FallbackTexture;\r\n },\r\n set: function (value) {\r\n EngineStore.FallbackTexture = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Read the content of a byte array at a specified coordinates (taking in account wrapping)\r\n * @param u defines the coordinate on X axis\r\n * @param v defines the coordinate on Y axis\r\n * @param width defines the width of the source data\r\n * @param height defines the height of the source data\r\n * @param pixels defines the source byte array\r\n * @param color defines the output color\r\n */\r\n Tools.FetchToRef = function (u, v, width, height, pixels, color) {\r\n var wrappedU = ((Math.abs(u) * width) % width) | 0;\r\n var wrappedV = ((Math.abs(v) * height) % height) | 0;\r\n var position = (wrappedU + wrappedV * width) * 4;\r\n color.r = pixels[position] / 255;\r\n color.g = pixels[position + 1] / 255;\r\n color.b = pixels[position + 2] / 255;\r\n color.a = pixels[position + 3] / 255;\r\n };\r\n /**\r\n * Interpolates between a and b via alpha\r\n * @param a The lower value (returned when alpha = 0)\r\n * @param b The upper value (returned when alpha = 1)\r\n * @param alpha The interpolation-factor\r\n * @return The mixed value\r\n */\r\n Tools.Mix = function (a, b, alpha) {\r\n return a * (1 - alpha) + b * alpha;\r\n };\r\n /**\r\n * Tries to instantiate a new object from a given class name\r\n * @param className defines the class name to instantiate\r\n * @returns the new object or null if the system was not able to do the instantiation\r\n */\r\n Tools.Instantiate = function (className) {\r\n return InstantiationTools.Instantiate(className);\r\n };\r\n /**\r\n * Provides a slice function that will work even on IE\r\n * @param data defines the array to slice\r\n * @param start defines the start of the data (optional)\r\n * @param end defines the end of the data (optional)\r\n * @returns the new sliced array\r\n */\r\n Tools.Slice = function (data, start, end) {\r\n if (data.slice) {\r\n return data.slice(start, end);\r\n }\r\n return Array.prototype.slice.call(data, start, end);\r\n };\r\n /**\r\n * Polyfill for setImmediate\r\n * @param action defines the action to execute after the current execution block\r\n */\r\n Tools.SetImmediate = function (action) {\r\n TimingTools.SetImmediate(action);\r\n };\r\n /**\r\n * Function indicating if a number is an exponent of 2\r\n * @param value defines the value to test\r\n * @returns true if the value is an exponent of 2\r\n */\r\n Tools.IsExponentOfTwo = function (value) {\r\n var count = 1;\r\n do {\r\n count *= 2;\r\n } while (count < value);\r\n return count === value;\r\n };\r\n /**\r\n * Returns the nearest 32-bit single precision float representation of a Number\r\n * @param value A Number. If the parameter is of a different type, it will get converted\r\n * to a number or to NaN if it cannot be converted\r\n * @returns number\r\n */\r\n Tools.FloatRound = function (value) {\r\n if (Math.fround) {\r\n return Math.fround(value);\r\n }\r\n return (Tools._tmpFloatArray[0] = value);\r\n };\r\n /**\r\n * Extracts the filename from a path\r\n * @param path defines the path to use\r\n * @returns the filename\r\n */\r\n Tools.GetFilename = function (path) {\r\n var index = path.lastIndexOf(\"/\");\r\n if (index < 0) {\r\n return path;\r\n }\r\n return path.substring(index + 1);\r\n };\r\n /**\r\n * Extracts the \"folder\" part of a path (everything before the filename).\r\n * @param uri The URI to extract the info from\r\n * @param returnUnchangedIfNoSlash Do not touch the URI if no slashes are present\r\n * @returns The \"folder\" part of the path\r\n */\r\n Tools.GetFolderPath = function (uri, returnUnchangedIfNoSlash) {\r\n if (returnUnchangedIfNoSlash === void 0) { returnUnchangedIfNoSlash = false; }\r\n var index = uri.lastIndexOf(\"/\");\r\n if (index < 0) {\r\n if (returnUnchangedIfNoSlash) {\r\n return uri;\r\n }\r\n return \"\";\r\n }\r\n return uri.substring(0, index + 1);\r\n };\r\n /**\r\n * Convert an angle in radians to degrees\r\n * @param angle defines the angle to convert\r\n * @returns the angle in degrees\r\n */\r\n Tools.ToDegrees = function (angle) {\r\n return angle * 180 / Math.PI;\r\n };\r\n /**\r\n * Convert an angle in degrees to radians\r\n * @param angle defines the angle to convert\r\n * @returns the angle in radians\r\n */\r\n Tools.ToRadians = function (angle) {\r\n return angle * Math.PI / 180;\r\n };\r\n /**\r\n * Returns an array if obj is not an array\r\n * @param obj defines the object to evaluate as an array\r\n * @param allowsNullUndefined defines a boolean indicating if obj is allowed to be null or undefined\r\n * @returns either obj directly if obj is an array or a new array containing obj\r\n */\r\n Tools.MakeArray = function (obj, allowsNullUndefined) {\r\n if (allowsNullUndefined !== true && (obj === undefined || obj == null)) {\r\n return null;\r\n }\r\n return Array.isArray(obj) ? obj : [obj];\r\n };\r\n /**\r\n * Gets the pointer prefix to use\r\n * @returns \"pointer\" if touch is enabled. Else returns \"mouse\"\r\n */\r\n Tools.GetPointerPrefix = function () {\r\n var eventPrefix = \"pointer\";\r\n // Check if pointer events are supported\r\n if (DomManagement.IsWindowObjectExist() && !window.PointerEvent && DomManagement.IsNavigatorAvailable() && !navigator.pointerEnabled) {\r\n eventPrefix = \"mouse\";\r\n }\r\n return eventPrefix;\r\n };\r\n /**\r\n * Sets the cors behavior on a dom element. This will add the required Tools.CorsBehavior to the element.\r\n * @param url define the url we are trying\r\n * @param element define the dom element where to configure the cors policy\r\n */\r\n Tools.SetCorsBehavior = function (url, element) {\r\n FileTools.SetCorsBehavior(url, element);\r\n };\r\n // External files\r\n /**\r\n * Removes unwanted characters from an url\r\n * @param url defines the url to clean\r\n * @returns the cleaned url\r\n */\r\n Tools.CleanUrl = function (url) {\r\n url = url.replace(/#/mg, \"%23\");\r\n return url;\r\n };\r\n Object.defineProperty(Tools, \"PreprocessUrl\", {\r\n /**\r\n * Gets or sets a function used to pre-process url before using them to load assets\r\n */\r\n get: function () {\r\n return FileTools.PreprocessUrl;\r\n },\r\n set: function (processor) {\r\n FileTools.PreprocessUrl = processor;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Loads an image as an HTMLImageElement.\r\n * @param input url string, ArrayBuffer, or Blob to load\r\n * @param onLoad callback called when the image successfully loads\r\n * @param onError callback called when the image fails to load\r\n * @param offlineProvider offline provider for caching\r\n * @param mimeType optional mime type\r\n * @returns the HTMLImageElement of the loaded image\r\n */\r\n Tools.LoadImage = function (input, onLoad, onError, offlineProvider, mimeType) {\r\n return FileTools.LoadImage(input, onLoad, onError, offlineProvider, mimeType);\r\n };\r\n /**\r\n * Loads a file from a url\r\n * @param url url string, ArrayBuffer, or Blob to load\r\n * @param onSuccess callback called when the file successfully loads\r\n * @param onProgress callback called while file is loading (if the server supports this mode)\r\n * @param offlineProvider defines the offline provider for caching\r\n * @param useArrayBuffer defines a boolean indicating that date must be returned as ArrayBuffer\r\n * @param onError callback called when the file fails to load\r\n * @returns a file request object\r\n */\r\n Tools.LoadFile = function (url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError) {\r\n return FileTools.LoadFile(url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError);\r\n };\r\n /**\r\n * Loads a file from a url\r\n * @param url the file url to load\r\n * @param useArrayBuffer defines a boolean indicating that date must be returned as ArrayBuffer\r\n * @returns a promise containing an ArrayBuffer corresponding to the loaded file\r\n */\r\n Tools.LoadFileAsync = function (url, useArrayBuffer) {\r\n if (useArrayBuffer === void 0) { useArrayBuffer = true; }\r\n return new Promise(function (resolve, reject) {\r\n FileTools.LoadFile(url, function (data) {\r\n resolve(data);\r\n }, undefined, undefined, useArrayBuffer, function (request, exception) {\r\n reject(exception);\r\n });\r\n });\r\n };\r\n /**\r\n * Load a script (identified by an url). When the url returns, the\r\n * content of this file is added into a new script element, attached to the DOM (body element)\r\n * @param scriptUrl defines the url of the script to laod\r\n * @param onSuccess defines the callback called when the script is loaded\r\n * @param onError defines the callback to call if an error occurs\r\n * @param scriptId defines the id of the script element\r\n */\r\n Tools.LoadScript = function (scriptUrl, onSuccess, onError, scriptId) {\r\n if (!DomManagement.IsWindowObjectExist()) {\r\n return;\r\n }\r\n var head = document.getElementsByTagName('head')[0];\r\n var script = document.createElement('script');\r\n script.setAttribute('type', 'text/javascript');\r\n script.setAttribute('src', scriptUrl);\r\n if (scriptId) {\r\n script.id = scriptId;\r\n }\r\n script.onload = function () {\r\n if (onSuccess) {\r\n onSuccess();\r\n }\r\n };\r\n script.onerror = function (e) {\r\n if (onError) {\r\n onError(\"Unable to load script '\" + scriptUrl + \"'\", e);\r\n }\r\n };\r\n head.appendChild(script);\r\n };\r\n /**\r\n * Load an asynchronous script (identified by an url). When the url returns, the\r\n * content of this file is added into a new script element, attached to the DOM (body element)\r\n * @param scriptUrl defines the url of the script to laod\r\n * @param scriptId defines the id of the script element\r\n * @returns a promise request object\r\n */\r\n Tools.LoadScriptAsync = function (scriptUrl, scriptId) {\r\n var _this = this;\r\n return new Promise(function (resolve, reject) {\r\n _this.LoadScript(scriptUrl, function () {\r\n resolve();\r\n }, function (message, exception) {\r\n reject(exception);\r\n });\r\n });\r\n };\r\n /**\r\n * Loads a file from a blob\r\n * @param fileToLoad defines the blob to use\r\n * @param callback defines the callback to call when data is loaded\r\n * @param progressCallback defines the callback to call during loading process\r\n * @returns a file request object\r\n */\r\n Tools.ReadFileAsDataURL = function (fileToLoad, callback, progressCallback) {\r\n var reader = new FileReader();\r\n var request = {\r\n onCompleteObservable: new Observable(),\r\n abort: function () { return reader.abort(); },\r\n };\r\n reader.onloadend = function (e) {\r\n request.onCompleteObservable.notifyObservers(request);\r\n };\r\n reader.onload = function (e) {\r\n //target doesn't have result from ts 1.3\r\n callback(e.target['result']);\r\n };\r\n reader.onprogress = progressCallback;\r\n reader.readAsDataURL(fileToLoad);\r\n return request;\r\n };\r\n /**\r\n * Reads a file from a File object\r\n * @param file defines the file to load\r\n * @param onSuccess defines the callback to call when data is loaded\r\n * @param onProgress defines the callback to call during loading process\r\n * @param useArrayBuffer defines a boolean indicating that data must be returned as an ArrayBuffer\r\n * @param onError defines the callback to call when an error occurs\r\n * @returns a file request object\r\n */\r\n Tools.ReadFile = function (file, onSuccess, onProgress, useArrayBuffer, onError) {\r\n return FileTools.ReadFile(file, onSuccess, onProgress, useArrayBuffer, onError);\r\n };\r\n /**\r\n * Creates a data url from a given string content\r\n * @param content defines the content to convert\r\n * @returns the new data url link\r\n */\r\n Tools.FileAsURL = function (content) {\r\n var fileBlob = new Blob([content]);\r\n var url = window.URL || window.webkitURL;\r\n var link = url.createObjectURL(fileBlob);\r\n return link;\r\n };\r\n /**\r\n * Format the given number to a specific decimal format\r\n * @param value defines the number to format\r\n * @param decimals defines the number of decimals to use\r\n * @returns the formatted string\r\n */\r\n Tools.Format = function (value, decimals) {\r\n if (decimals === void 0) { decimals = 2; }\r\n return value.toFixed(decimals);\r\n };\r\n /**\r\n * Tries to copy an object by duplicating every property\r\n * @param source defines the source object\r\n * @param destination defines the target object\r\n * @param doNotCopyList defines a list of properties to avoid\r\n * @param mustCopyList defines a list of properties to copy (even if they start with _)\r\n */\r\n Tools.DeepCopy = function (source, destination, doNotCopyList, mustCopyList) {\r\n DeepCopier.DeepCopy(source, destination, doNotCopyList, mustCopyList);\r\n };\r\n /**\r\n * Gets a boolean indicating if the given object has no own property\r\n * @param obj defines the object to test\r\n * @returns true if object has no own property\r\n */\r\n Tools.IsEmpty = function (obj) {\r\n for (var i in obj) {\r\n if (obj.hasOwnProperty(i)) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Function used to register events at window level\r\n * @param windowElement defines the Window object to use\r\n * @param events defines the events to register\r\n */\r\n Tools.RegisterTopRootEvents = function (windowElement, events) {\r\n for (var index = 0; index < events.length; index++) {\r\n var event = events[index];\r\n windowElement.addEventListener(event.name, event.handler, false);\r\n try {\r\n if (window.parent) {\r\n window.parent.addEventListener(event.name, event.handler, false);\r\n }\r\n }\r\n catch (e) {\r\n // Silently fails...\r\n }\r\n }\r\n };\r\n /**\r\n * Function used to unregister events from window level\r\n * @param windowElement defines the Window object to use\r\n * @param events defines the events to unregister\r\n */\r\n Tools.UnregisterTopRootEvents = function (windowElement, events) {\r\n for (var index = 0; index < events.length; index++) {\r\n var event = events[index];\r\n windowElement.removeEventListener(event.name, event.handler);\r\n try {\r\n if (windowElement.parent) {\r\n windowElement.parent.removeEventListener(event.name, event.handler);\r\n }\r\n }\r\n catch (e) {\r\n // Silently fails...\r\n }\r\n }\r\n };\r\n /**\r\n * Dumps the current bound framebuffer\r\n * @param width defines the rendering width\r\n * @param height defines the rendering height\r\n * @param engine defines the hosting engine\r\n * @param successCallback defines the callback triggered once the data are available\r\n * @param mimeType defines the mime type of the result\r\n * @param fileName defines the filename to download. If present, the result will automatically be downloaded\r\n */\r\n Tools.DumpFramebuffer = function (width, height, engine, successCallback, mimeType, fileName) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n // Read the contents of the framebuffer\r\n var numberOfChannelsByLine = width * 4;\r\n var halfHeight = height / 2;\r\n //Reading datas from WebGL\r\n var data = engine.readPixels(0, 0, width, height);\r\n //To flip image on Y axis.\r\n for (var i = 0; i < halfHeight; i++) {\r\n for (var j = 0; j < numberOfChannelsByLine; j++) {\r\n var currentCell = j + i * numberOfChannelsByLine;\r\n var targetLine = height - i - 1;\r\n var targetCell = j + targetLine * numberOfChannelsByLine;\r\n var temp = data[currentCell];\r\n data[currentCell] = data[targetCell];\r\n data[targetCell] = temp;\r\n }\r\n }\r\n // Create a 2D canvas to store the result\r\n if (!Tools._ScreenshotCanvas) {\r\n Tools._ScreenshotCanvas = document.createElement('canvas');\r\n }\r\n Tools._ScreenshotCanvas.width = width;\r\n Tools._ScreenshotCanvas.height = height;\r\n var context = Tools._ScreenshotCanvas.getContext('2d');\r\n if (context) {\r\n // Copy the pixels to a 2D canvas\r\n var imageData = context.createImageData(width, height);\r\n var castData = (imageData.data);\r\n castData.set(data);\r\n context.putImageData(imageData, 0, 0);\r\n Tools.EncodeScreenshotCanvasData(successCallback, mimeType, fileName);\r\n }\r\n };\r\n /**\r\n * Converts the canvas data to blob.\r\n * This acts as a polyfill for browsers not supporting the to blob function.\r\n * @param canvas Defines the canvas to extract the data from\r\n * @param successCallback Defines the callback triggered once the data are available\r\n * @param mimeType Defines the mime type of the result\r\n */\r\n Tools.ToBlob = function (canvas, successCallback, mimeType) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n // We need HTMLCanvasElement.toBlob for HD screenshots\r\n if (!canvas.toBlob) {\r\n // low performance polyfill based on toDataURL (https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob)\r\n canvas.toBlob = function (callback, type, quality) {\r\n var _this = this;\r\n setTimeout(function () {\r\n var binStr = atob(_this.toDataURL(type, quality).split(',')[1]), len = binStr.length, arr = new Uint8Array(len);\r\n for (var i = 0; i < len; i++) {\r\n arr[i] = binStr.charCodeAt(i);\r\n }\r\n callback(new Blob([arr]));\r\n });\r\n };\r\n }\r\n canvas.toBlob(function (blob) {\r\n successCallback(blob);\r\n }, mimeType);\r\n };\r\n /**\r\n * Encodes the canvas data to base 64 or automatically download the result if filename is defined\r\n * @param successCallback defines the callback triggered once the data are available\r\n * @param mimeType defines the mime type of the result\r\n * @param fileName defines he filename to download. If present, the result will automatically be downloaded\r\n */\r\n Tools.EncodeScreenshotCanvasData = function (successCallback, mimeType, fileName) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n if (successCallback) {\r\n var base64Image = Tools._ScreenshotCanvas.toDataURL(mimeType);\r\n successCallback(base64Image);\r\n }\r\n else {\r\n this.ToBlob(Tools._ScreenshotCanvas, function (blob) {\r\n //Creating a link if the browser have the download attribute on the a tag, to automatically start download generated image.\r\n if ((\"download\" in document.createElement(\"a\"))) {\r\n if (!fileName) {\r\n var date = new Date();\r\n var stringDate = (date.getFullYear() + \"-\" + (date.getMonth() + 1)).slice(2) + \"-\" + date.getDate() + \"_\" + date.getHours() + \"-\" + ('0' + date.getMinutes()).slice(-2);\r\n fileName = \"screenshot_\" + stringDate + \".png\";\r\n }\r\n Tools.Download(blob, fileName);\r\n }\r\n else {\r\n var url = URL.createObjectURL(blob);\r\n var newWindow = window.open(\"\");\r\n if (!newWindow) {\r\n return;\r\n }\r\n var img = newWindow.document.createElement(\"img\");\r\n img.onload = function () {\r\n // no longer need to read the blob so it's revoked\r\n URL.revokeObjectURL(url);\r\n };\r\n img.src = url;\r\n newWindow.document.body.appendChild(img);\r\n }\r\n }, mimeType);\r\n }\r\n };\r\n /**\r\n * Downloads a blob in the browser\r\n * @param blob defines the blob to download\r\n * @param fileName defines the name of the downloaded file\r\n */\r\n Tools.Download = function (blob, fileName) {\r\n if (navigator && navigator.msSaveBlob) {\r\n navigator.msSaveBlob(blob, fileName);\r\n return;\r\n }\r\n var url = window.URL.createObjectURL(blob);\r\n var a = document.createElement(\"a\");\r\n document.body.appendChild(a);\r\n a.style.display = \"none\";\r\n a.href = url;\r\n a.download = fileName;\r\n a.addEventListener(\"click\", function () {\r\n if (a.parentElement) {\r\n a.parentElement.removeChild(a);\r\n }\r\n });\r\n a.click();\r\n window.URL.revokeObjectURL(url);\r\n };\r\n /**\r\n * Captures a screenshot of the current rendering\r\n * @see http://doc.babylonjs.com/how_to/render_scene_on_a_png\r\n * @param engine defines the rendering engine\r\n * @param camera defines the source camera\r\n * @param size This parameter can be set to a single number or to an object with the\r\n * following (optional) properties: precision, width, height. If a single number is passed,\r\n * it will be used for both width and height. If an object is passed, the screenshot size\r\n * will be derived from the parameters. The precision property is a multiplier allowing\r\n * rendering at a higher or lower resolution\r\n * @param successCallback defines the callback receives a single parameter which contains the\r\n * screenshot as a string of base64-encoded characters. This string can be assigned to the\r\n * src parameter of an to display it\r\n * @param mimeType defines the MIME type of the screenshot image (default: image/png).\r\n * Check your browser for supported MIME types\r\n */\r\n Tools.CreateScreenshot = function (engine, camera, size, successCallback, mimeType) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n throw _DevTools.WarnImport(\"ScreenshotTools\");\r\n };\r\n /**\r\n * Captures a screenshot of the current rendering\r\n * @see http://doc.babylonjs.com/how_to/render_scene_on_a_png\r\n * @param engine defines the rendering engine\r\n * @param camera defines the source camera\r\n * @param size This parameter can be set to a single number or to an object with the\r\n * following (optional) properties: precision, width, height. If a single number is passed,\r\n * it will be used for both width and height. If an object is passed, the screenshot size\r\n * will be derived from the parameters. The precision property is a multiplier allowing\r\n * rendering at a higher or lower resolution\r\n * @param mimeType defines the MIME type of the screenshot image (default: image/png).\r\n * Check your browser for supported MIME types\r\n * @returns screenshot as a string of base64-encoded characters. This string can be assigned\r\n * to the src parameter of an to display it\r\n */\r\n Tools.CreateScreenshotAsync = function (engine, camera, size, mimeType) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n throw _DevTools.WarnImport(\"ScreenshotTools\");\r\n };\r\n /**\r\n * Generates an image screenshot from the specified camera.\r\n * @see http://doc.babylonjs.com/how_to/render_scene_on_a_png\r\n * @param engine The engine to use for rendering\r\n * @param camera The camera to use for rendering\r\n * @param size This parameter can be set to a single number or to an object with the\r\n * following (optional) properties: precision, width, height. If a single number is passed,\r\n * it will be used for both width and height. If an object is passed, the screenshot size\r\n * will be derived from the parameters. The precision property is a multiplier allowing\r\n * rendering at a higher or lower resolution\r\n * @param successCallback The callback receives a single parameter which contains the\r\n * screenshot as a string of base64-encoded characters. This string can be assigned to the\r\n * src parameter of an to display it\r\n * @param mimeType The MIME type of the screenshot image (default: image/png).\r\n * Check your browser for supported MIME types\r\n * @param samples Texture samples (default: 1)\r\n * @param antialiasing Whether antialiasing should be turned on or not (default: false)\r\n * @param fileName A name for for the downloaded file.\r\n */\r\n Tools.CreateScreenshotUsingRenderTarget = function (engine, camera, size, successCallback, mimeType, samples, antialiasing, fileName) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n if (samples === void 0) { samples = 1; }\r\n if (antialiasing === void 0) { antialiasing = false; }\r\n throw _DevTools.WarnImport(\"ScreenshotTools\");\r\n };\r\n /**\r\n * Generates an image screenshot from the specified camera.\r\n * @see http://doc.babylonjs.com/how_to/render_scene_on_a_png\r\n * @param engine The engine to use for rendering\r\n * @param camera The camera to use for rendering\r\n * @param size This parameter can be set to a single number or to an object with the\r\n * following (optional) properties: precision, width, height. If a single number is passed,\r\n * it will be used for both width and height. If an object is passed, the screenshot size\r\n * will be derived from the parameters. The precision property is a multiplier allowing\r\n * rendering at a higher or lower resolution\r\n * @param mimeType The MIME type of the screenshot image (default: image/png).\r\n * Check your browser for supported MIME types\r\n * @param samples Texture samples (default: 1)\r\n * @param antialiasing Whether antialiasing should be turned on or not (default: false)\r\n * @param fileName A name for for the downloaded file.\r\n * @returns screenshot as a string of base64-encoded characters. This string can be assigned\r\n * to the src parameter of an to display it\r\n */\r\n Tools.CreateScreenshotUsingRenderTargetAsync = function (engine, camera, size, mimeType, samples, antialiasing, fileName) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n if (samples === void 0) { samples = 1; }\r\n if (antialiasing === void 0) { antialiasing = false; }\r\n throw _DevTools.WarnImport(\"ScreenshotTools\");\r\n };\r\n /**\r\n * Implementation from http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/2117523#answer-2117523\r\n * Be aware Math.random() could cause collisions, but:\r\n * \"All but 6 of the 128 bits of the ID are randomly generated, which means that for any two ids, there's a 1 in 2^^122 (or 5.3x10^^36) chance they'll collide\"\r\n * @returns a pseudo random id\r\n */\r\n Tools.RandomId = function () {\r\n return GUID.RandomId();\r\n };\r\n /**\r\n * Test if the given uri is a base64 string\r\n * @param uri The uri to test\r\n * @return True if the uri is a base64 string or false otherwise\r\n */\r\n Tools.IsBase64 = function (uri) {\r\n return uri.length < 5 ? false : uri.substr(0, 5) === \"data:\";\r\n };\r\n /**\r\n * Decode the given base64 uri.\r\n * @param uri The uri to decode\r\n * @return The decoded base64 data.\r\n */\r\n Tools.DecodeBase64 = function (uri) {\r\n var decodedString = atob(uri.split(\",\")[1]);\r\n var bufferLength = decodedString.length;\r\n var bufferView = new Uint8Array(new ArrayBuffer(bufferLength));\r\n for (var i = 0; i < bufferLength; i++) {\r\n bufferView[i] = decodedString.charCodeAt(i);\r\n }\r\n return bufferView.buffer;\r\n };\r\n /**\r\n * Gets the absolute url.\r\n * @param url the input url\r\n * @return the absolute url\r\n */\r\n Tools.GetAbsoluteUrl = function (url) {\r\n var a = document.createElement(\"a\");\r\n a.href = url;\r\n return a.href;\r\n };\r\n Object.defineProperty(Tools, \"errorsCount\", {\r\n /**\r\n * Gets a value indicating the number of loading errors\r\n * @ignorenaming\r\n */\r\n get: function () {\r\n return Logger.errorsCount;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Log a message to the console\r\n * @param message defines the message to log\r\n */\r\n Tools.Log = function (message) {\r\n Logger.Log(message);\r\n };\r\n /**\r\n * Write a warning message to the console\r\n * @param message defines the message to log\r\n */\r\n Tools.Warn = function (message) {\r\n Logger.Warn(message);\r\n };\r\n /**\r\n * Write an error message to the console\r\n * @param message defines the message to log\r\n */\r\n Tools.Error = function (message) {\r\n Logger.Error(message);\r\n };\r\n Object.defineProperty(Tools, \"LogCache\", {\r\n /**\r\n * Gets current log cache (list of logs)\r\n */\r\n get: function () {\r\n return Logger.LogCache;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Clears the log cache\r\n */\r\n Tools.ClearLogCache = function () {\r\n Logger.ClearLogCache();\r\n };\r\n Object.defineProperty(Tools, \"LogLevels\", {\r\n /**\r\n * Sets the current log level (MessageLogLevel / WarningLogLevel / ErrorLogLevel)\r\n */\r\n set: function (level) {\r\n Logger.LogLevels = level;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Tools, \"PerformanceLogLevel\", {\r\n /**\r\n * Sets the current performance log level\r\n */\r\n set: function (level) {\r\n if ((level & Tools.PerformanceUserMarkLogLevel) === Tools.PerformanceUserMarkLogLevel) {\r\n Tools.StartPerformanceCounter = Tools._StartUserMark;\r\n Tools.EndPerformanceCounter = Tools._EndUserMark;\r\n return;\r\n }\r\n if ((level & Tools.PerformanceConsoleLogLevel) === Tools.PerformanceConsoleLogLevel) {\r\n Tools.StartPerformanceCounter = Tools._StartPerformanceConsole;\r\n Tools.EndPerformanceCounter = Tools._EndPerformanceConsole;\r\n return;\r\n }\r\n Tools.StartPerformanceCounter = Tools._StartPerformanceCounterDisabled;\r\n Tools.EndPerformanceCounter = Tools._EndPerformanceCounterDisabled;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Tools._StartPerformanceCounterDisabled = function (counterName, condition) {\r\n };\r\n Tools._EndPerformanceCounterDisabled = function (counterName, condition) {\r\n };\r\n Tools._StartUserMark = function (counterName, condition) {\r\n if (condition === void 0) { condition = true; }\r\n if (!Tools._performance) {\r\n if (!DomManagement.IsWindowObjectExist()) {\r\n return;\r\n }\r\n Tools._performance = window.performance;\r\n }\r\n if (!condition || !Tools._performance.mark) {\r\n return;\r\n }\r\n Tools._performance.mark(counterName + \"-Begin\");\r\n };\r\n Tools._EndUserMark = function (counterName, condition) {\r\n if (condition === void 0) { condition = true; }\r\n if (!condition || !Tools._performance.mark) {\r\n return;\r\n }\r\n Tools._performance.mark(counterName + \"-End\");\r\n Tools._performance.measure(counterName, counterName + \"-Begin\", counterName + \"-End\");\r\n };\r\n Tools._StartPerformanceConsole = function (counterName, condition) {\r\n if (condition === void 0) { condition = true; }\r\n if (!condition) {\r\n return;\r\n }\r\n Tools._StartUserMark(counterName, condition);\r\n if (console.time) {\r\n console.time(counterName);\r\n }\r\n };\r\n Tools._EndPerformanceConsole = function (counterName, condition) {\r\n if (condition === void 0) { condition = true; }\r\n if (!condition) {\r\n return;\r\n }\r\n Tools._EndUserMark(counterName, condition);\r\n console.timeEnd(counterName);\r\n };\r\n Object.defineProperty(Tools, \"Now\", {\r\n /**\r\n * Gets either window.performance.now() if supported or Date.now() else\r\n */\r\n get: function () {\r\n return PrecisionDate.Now;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * This method will return the name of the class used to create the instance of the given object.\r\n * It will works only on Javascript basic data types (number, string, ...) and instance of class declared with the @className decorator.\r\n * @param object the object to get the class name from\r\n * @param isType defines if the object is actually a type\r\n * @returns the name of the class, will be \"object\" for a custom data type not using the @className decorator\r\n */\r\n Tools.GetClassName = function (object, isType) {\r\n if (isType === void 0) { isType = false; }\r\n var name = null;\r\n if (!isType && object.getClassName) {\r\n name = object.getClassName();\r\n }\r\n else {\r\n if (object instanceof Object) {\r\n var classObj = isType ? object : Object.getPrototypeOf(object);\r\n name = classObj.constructor[\"__bjsclassName__\"];\r\n }\r\n if (!name) {\r\n name = typeof object;\r\n }\r\n }\r\n return name;\r\n };\r\n /**\r\n * Gets the first element of an array satisfying a given predicate\r\n * @param array defines the array to browse\r\n * @param predicate defines the predicate to use\r\n * @returns null if not found or the element\r\n */\r\n Tools.First = function (array, predicate) {\r\n for (var _i = 0, array_1 = array; _i < array_1.length; _i++) {\r\n var el = array_1[_i];\r\n if (predicate(el)) {\r\n return el;\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * This method will return the name of the full name of the class, including its owning module (if any).\r\n * It will works only on Javascript basic data types (number, string, ...) and instance of class declared with the @className decorator or implementing a method getClassName():string (in which case the module won't be specified).\r\n * @param object the object to get the class name from\r\n * @param isType defines if the object is actually a type\r\n * @return a string that can have two forms: \"moduleName.className\" if module was specified when the class' Name was registered or \"className\" if there was not module specified.\r\n * @ignorenaming\r\n */\r\n Tools.getFullClassName = function (object, isType) {\r\n if (isType === void 0) { isType = false; }\r\n var className = null;\r\n var moduleName = null;\r\n if (!isType && object.getClassName) {\r\n className = object.getClassName();\r\n }\r\n else {\r\n if (object instanceof Object) {\r\n var classObj = isType ? object : Object.getPrototypeOf(object);\r\n className = classObj.constructor[\"__bjsclassName__\"];\r\n moduleName = classObj.constructor[\"__bjsmoduleName__\"];\r\n }\r\n if (!className) {\r\n className = typeof object;\r\n }\r\n }\r\n if (!className) {\r\n return null;\r\n }\r\n return ((moduleName != null) ? (moduleName + \".\") : \"\") + className;\r\n };\r\n /**\r\n * Returns a promise that resolves after the given amount of time.\r\n * @param delay Number of milliseconds to delay\r\n * @returns Promise that resolves after the given amount of time\r\n */\r\n Tools.DelayAsync = function (delay) {\r\n return new Promise(function (resolve) {\r\n setTimeout(function () {\r\n resolve();\r\n }, delay);\r\n });\r\n };\r\n /**\r\n * Utility function to detect if the current user agent is Safari\r\n * @returns whether or not the current user agent is safari\r\n */\r\n Tools.IsSafari = function () {\r\n return /^((?!chrome|android).)*safari/i.test(navigator.userAgent);\r\n };\r\n /**\r\n * Enable/Disable Custom HTTP Request Headers globally.\r\n * default = false\r\n * @see CustomRequestHeaders\r\n */\r\n Tools.UseCustomRequestHeaders = false;\r\n /**\r\n * Custom HTTP Request Headers to be sent with XMLHttpRequests\r\n * i.e. when loading files, where the server/service expects an Authorization header\r\n */\r\n Tools.CustomRequestHeaders = WebRequest.CustomRequestHeaders;\r\n /**\r\n * Default behaviour for cors in the application.\r\n * It can be a string if the expected behavior is identical in the entire app.\r\n * Or a callback to be able to set it per url or on a group of them (in case of Video source for instance)\r\n */\r\n Tools.CorsBehavior = \"anonymous\";\r\n Tools._tmpFloatArray = new Float32Array(1);\r\n /**\r\n * Extracts text content from a DOM element hierarchy\r\n * Back Compat only, please use DomManagement.GetDOMTextContent instead.\r\n */\r\n Tools.GetDOMTextContent = DomManagement.GetDOMTextContent;\r\n // Logs\r\n /**\r\n * No log\r\n */\r\n Tools.NoneLogLevel = Logger.NoneLogLevel;\r\n /**\r\n * Only message logs\r\n */\r\n Tools.MessageLogLevel = Logger.MessageLogLevel;\r\n /**\r\n * Only warning logs\r\n */\r\n Tools.WarningLogLevel = Logger.WarningLogLevel;\r\n /**\r\n * Only error logs\r\n */\r\n Tools.ErrorLogLevel = Logger.ErrorLogLevel;\r\n /**\r\n * All logs\r\n */\r\n Tools.AllLogLevel = Logger.AllLogLevel;\r\n /**\r\n * Checks if the window object exists\r\n * Back Compat only, please use DomManagement.IsWindowObjectExist instead.\r\n */\r\n Tools.IsWindowObjectExist = DomManagement.IsWindowObjectExist;\r\n // Performances\r\n /**\r\n * No performance log\r\n */\r\n Tools.PerformanceNoneLogLevel = 0;\r\n /**\r\n * Use user marks to log performance\r\n */\r\n Tools.PerformanceUserMarkLogLevel = 1;\r\n /**\r\n * Log performance to the console\r\n */\r\n Tools.PerformanceConsoleLogLevel = 2;\r\n /**\r\n * Starts a performance counter\r\n */\r\n Tools.StartPerformanceCounter = Tools._StartPerformanceCounterDisabled;\r\n /**\r\n * Ends a specific performance coutner\r\n */\r\n Tools.EndPerformanceCounter = Tools._EndPerformanceCounterDisabled;\r\n return Tools;\r\n}());\r\nexport { Tools };\r\n/**\r\n * Use this className as a decorator on a given class definition to add it a name and optionally its module.\r\n * You can then use the Tools.getClassName(obj) on an instance to retrieve its class name.\r\n * This method is the only way to get it done in all cases, even if the .js file declaring the class is minified\r\n * @param name The name of the class, case should be preserved\r\n * @param module The name of the Module hosting the class, optional, but strongly recommended to specify if possible. Case should be preserved.\r\n */\r\nexport function className(name, module) {\r\n return function (target) {\r\n target[\"__bjsclassName__\"] = name;\r\n target[\"__bjsmoduleName__\"] = (module != null) ? module : null;\r\n };\r\n}\r\n/**\r\n * An implementation of a loop for asynchronous functions.\r\n */\r\nvar AsyncLoop = /** @class */ (function () {\r\n /**\r\n * Constructor.\r\n * @param iterations the number of iterations.\r\n * @param func the function to run each iteration\r\n * @param successCallback the callback that will be called upon succesful execution\r\n * @param offset starting offset.\r\n */\r\n function AsyncLoop(\r\n /**\r\n * Defines the number of iterations for the loop\r\n */\r\n iterations, func, successCallback, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n this.iterations = iterations;\r\n this.index = offset - 1;\r\n this._done = false;\r\n this._fn = func;\r\n this._successCallback = successCallback;\r\n }\r\n /**\r\n * Execute the next iteration. Must be called after the last iteration was finished.\r\n */\r\n AsyncLoop.prototype.executeNext = function () {\r\n if (!this._done) {\r\n if (this.index + 1 < this.iterations) {\r\n ++this.index;\r\n this._fn(this);\r\n }\r\n else {\r\n this.breakLoop();\r\n }\r\n }\r\n };\r\n /**\r\n * Break the loop and run the success callback.\r\n */\r\n AsyncLoop.prototype.breakLoop = function () {\r\n this._done = true;\r\n this._successCallback();\r\n };\r\n /**\r\n * Create and run an async loop.\r\n * @param iterations the number of iterations.\r\n * @param fn the function to run each iteration\r\n * @param successCallback the callback that will be called upon succesful execution\r\n * @param offset starting offset.\r\n * @returns the created async loop object\r\n */\r\n AsyncLoop.Run = function (iterations, fn, successCallback, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n var loop = new AsyncLoop(iterations, fn, successCallback, offset);\r\n loop.executeNext();\r\n return loop;\r\n };\r\n /**\r\n * A for-loop that will run a given number of iterations synchronous and the rest async.\r\n * @param iterations total number of iterations\r\n * @param syncedIterations number of synchronous iterations in each async iteration.\r\n * @param fn the function to call each iteration.\r\n * @param callback a success call back that will be called when iterating stops.\r\n * @param breakFunction a break condition (optional)\r\n * @param timeout timeout settings for the setTimeout function. default - 0.\r\n * @returns the created async loop object\r\n */\r\n AsyncLoop.SyncAsyncForLoop = function (iterations, syncedIterations, fn, callback, breakFunction, timeout) {\r\n if (timeout === void 0) { timeout = 0; }\r\n return AsyncLoop.Run(Math.ceil(iterations / syncedIterations), function (loop) {\r\n if (breakFunction && breakFunction()) {\r\n loop.breakLoop();\r\n }\r\n else {\r\n setTimeout(function () {\r\n for (var i = 0; i < syncedIterations; ++i) {\r\n var iteration = (loop.index * syncedIterations) + i;\r\n if (iteration >= iterations) {\r\n break;\r\n }\r\n fn(iteration);\r\n if (breakFunction && breakFunction()) {\r\n loop.breakLoop();\r\n break;\r\n }\r\n }\r\n loop.executeNext();\r\n }, timeout);\r\n }\r\n }, callback);\r\n };\r\n return AsyncLoop;\r\n}());\r\nexport { AsyncLoop };\r\n// Will only be define if Tools is imported freeing up some space when only engine is required\r\nEngineStore.FallbackTexture = \"\";\r\n// Register promise fallback for IE\r\nPromisePolyfill.Apply();\r\n//# sourceMappingURL=tools.js.map","/**\r\n * Class used to specific a value and its associated unit\r\n */\r\nvar ValueAndUnit = /** @class */ (function () {\r\n /**\r\n * Creates a new ValueAndUnit\r\n * @param value defines the value to store\r\n * @param unit defines the unit to store\r\n * @param negativeValueAllowed defines a boolean indicating if the value can be negative\r\n */\r\n function ValueAndUnit(value, \r\n /** defines the unit to store */\r\n unit, \r\n /** defines a boolean indicating if the value can be negative */\r\n negativeValueAllowed) {\r\n if (unit === void 0) { unit = ValueAndUnit.UNITMODE_PIXEL; }\r\n if (negativeValueAllowed === void 0) { negativeValueAllowed = true; }\r\n this.unit = unit;\r\n this.negativeValueAllowed = negativeValueAllowed;\r\n this._value = 1;\r\n /**\r\n * Gets or sets a value indicating that this value will not scale accordingly with adaptive scaling property\r\n * @see http://doc.babylonjs.com/how_to/gui#adaptive-scaling\r\n */\r\n this.ignoreAdaptiveScaling = false;\r\n this._value = value;\r\n this._originalUnit = unit;\r\n }\r\n Object.defineProperty(ValueAndUnit.prototype, \"isPercentage\", {\r\n /** Gets a boolean indicating if the value is a percentage */\r\n get: function () {\r\n return this.unit === ValueAndUnit.UNITMODE_PERCENTAGE;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ValueAndUnit.prototype, \"isPixel\", {\r\n /** Gets a boolean indicating if the value is store as pixel */\r\n get: function () {\r\n return this.unit === ValueAndUnit.UNITMODE_PIXEL;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ValueAndUnit.prototype, \"internalValue\", {\r\n /** Gets direct internal value */\r\n get: function () {\r\n return this._value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets value as pixel\r\n * @param host defines the root host\r\n * @param refValue defines the reference value for percentages\r\n * @returns the value as pixel\r\n */\r\n ValueAndUnit.prototype.getValueInPixel = function (host, refValue) {\r\n if (this.isPixel) {\r\n return this.getValue(host);\r\n }\r\n return this.getValue(host) * refValue;\r\n };\r\n /**\r\n * Update the current value and unit. This should be done cautiously as the GUi won't be marked as dirty with this function.\r\n * @param value defines the value to store\r\n * @param unit defines the unit to store\r\n * @returns the current ValueAndUnit\r\n */\r\n ValueAndUnit.prototype.updateInPlace = function (value, unit) {\r\n if (unit === void 0) { unit = ValueAndUnit.UNITMODE_PIXEL; }\r\n this._value = value;\r\n this.unit = unit;\r\n return this;\r\n };\r\n /**\r\n * Gets the value accordingly to its unit\r\n * @param host defines the root host\r\n * @returns the value\r\n */\r\n ValueAndUnit.prototype.getValue = function (host) {\r\n if (host && !this.ignoreAdaptiveScaling && this.unit !== ValueAndUnit.UNITMODE_PERCENTAGE) {\r\n var width = 0;\r\n var height = 0;\r\n if (host.idealWidth) {\r\n width = (this._value * host.getSize().width) / host.idealWidth;\r\n }\r\n if (host.idealHeight) {\r\n height = (this._value * host.getSize().height) / host.idealHeight;\r\n }\r\n if (host.useSmallestIdeal && host.idealWidth && host.idealHeight) {\r\n return window.innerWidth < window.innerHeight ? width : height;\r\n }\r\n if (host.idealWidth) { // horizontal\r\n return width;\r\n }\r\n if (host.idealHeight) { // vertical\r\n return height;\r\n }\r\n }\r\n return this._value;\r\n };\r\n /**\r\n * Gets a string representation of the value\r\n * @param host defines the root host\r\n * @param decimals defines an optional number of decimals to display\r\n * @returns a string\r\n */\r\n ValueAndUnit.prototype.toString = function (host, decimals) {\r\n switch (this.unit) {\r\n case ValueAndUnit.UNITMODE_PERCENTAGE:\r\n var percentage = this.getValue(host) * 100;\r\n return (decimals ? percentage.toFixed(decimals) : percentage) + \"%\";\r\n case ValueAndUnit.UNITMODE_PIXEL:\r\n var pixels = this.getValue(host);\r\n return (decimals ? pixels.toFixed(decimals) : pixels) + \"px\";\r\n }\r\n return this.unit.toString();\r\n };\r\n /**\r\n * Store a value parsed from a string\r\n * @param source defines the source string\r\n * @returns true if the value was successfully parsed\r\n */\r\n ValueAndUnit.prototype.fromString = function (source) {\r\n var match = ValueAndUnit._Regex.exec(source.toString());\r\n if (!match || match.length === 0) {\r\n return false;\r\n }\r\n var sourceValue = parseFloat(match[1]);\r\n var sourceUnit = this._originalUnit;\r\n if (!this.negativeValueAllowed) {\r\n if (sourceValue < 0) {\r\n sourceValue = 0;\r\n }\r\n }\r\n if (match.length === 4) {\r\n switch (match[3]) {\r\n case \"px\":\r\n sourceUnit = ValueAndUnit.UNITMODE_PIXEL;\r\n break;\r\n case \"%\":\r\n sourceUnit = ValueAndUnit.UNITMODE_PERCENTAGE;\r\n sourceValue /= 100.0;\r\n break;\r\n }\r\n }\r\n if (sourceValue === this._value && sourceUnit === this.unit) {\r\n return false;\r\n }\r\n this._value = sourceValue;\r\n this.unit = sourceUnit;\r\n return true;\r\n };\r\n Object.defineProperty(ValueAndUnit, \"UNITMODE_PERCENTAGE\", {\r\n /** UNITMODE_PERCENTAGE */\r\n get: function () {\r\n return ValueAndUnit._UNITMODE_PERCENTAGE;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ValueAndUnit, \"UNITMODE_PIXEL\", {\r\n /** UNITMODE_PIXEL */\r\n get: function () {\r\n return ValueAndUnit._UNITMODE_PIXEL;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n // Static\r\n ValueAndUnit._Regex = /(^-?\\d*(\\.\\d+)?)(%|px)?/;\r\n ValueAndUnit._UNITMODE_PERCENTAGE = 0;\r\n ValueAndUnit._UNITMODE_PIXEL = 1;\r\n return ValueAndUnit;\r\n}());\r\nexport { ValueAndUnit };\r\n//# sourceMappingURL=valueAndUnit.js.map","/**\r\n * Class used to represent data loading progression\r\n */\r\nvar SceneLoaderFlags = /** @class */ (function () {\r\n function SceneLoaderFlags() {\r\n }\r\n Object.defineProperty(SceneLoaderFlags, \"ForceFullSceneLoadingForIncremental\", {\r\n /**\r\n * Gets or sets a boolean indicating if entire scene must be loaded even if scene contains incremental data\r\n */\r\n get: function () {\r\n return SceneLoaderFlags._ForceFullSceneLoadingForIncremental;\r\n },\r\n set: function (value) {\r\n SceneLoaderFlags._ForceFullSceneLoadingForIncremental = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SceneLoaderFlags, \"ShowLoadingScreen\", {\r\n /**\r\n * Gets or sets a boolean indicating if loading screen must be displayed while loading a scene\r\n */\r\n get: function () {\r\n return SceneLoaderFlags._ShowLoadingScreen;\r\n },\r\n set: function (value) {\r\n SceneLoaderFlags._ShowLoadingScreen = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SceneLoaderFlags, \"loggingLevel\", {\r\n /**\r\n * Defines the current logging level (while loading the scene)\r\n * @ignorenaming\r\n */\r\n get: function () {\r\n return SceneLoaderFlags._loggingLevel;\r\n },\r\n set: function (value) {\r\n SceneLoaderFlags._loggingLevel = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SceneLoaderFlags, \"CleanBoneMatrixWeights\", {\r\n /**\r\n * Gets or set a boolean indicating if matrix weights must be cleaned upon loading\r\n */\r\n get: function () {\r\n return SceneLoaderFlags._CleanBoneMatrixWeights;\r\n },\r\n set: function (value) {\r\n SceneLoaderFlags._CleanBoneMatrixWeights = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n // Flags\r\n SceneLoaderFlags._ForceFullSceneLoadingForIncremental = false;\r\n SceneLoaderFlags._ShowLoadingScreen = true;\r\n SceneLoaderFlags._CleanBoneMatrixWeights = false;\r\n SceneLoaderFlags._loggingLevel = 0;\r\n return SceneLoaderFlags;\r\n}());\r\nexport { SceneLoaderFlags };\r\n//# sourceMappingURL=sceneLoaderFlags.js.map","import { Vector3 } from \"../Maths/math.vector\";\r\nimport { Color4 } from '../Maths/math.color';\r\nimport { VertexData } from \"../Meshes/mesh.vertexData\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { SubMesh } from \"../Meshes/subMesh\";\r\nimport { SceneLoaderFlags } from \"../Loading/sceneLoaderFlags\";\r\nimport { BoundingInfo } from \"../Culling/boundingInfo\";\r\nimport { Tools } from \"../Misc/tools\";\r\nimport { Tags } from \"../Misc/tags\";\r\nimport { extractMinAndMax } from '../Maths/math.functions';\r\n/**\r\n * Class used to store geometry data (vertex buffers + index buffer)\r\n */\r\nvar Geometry = /** @class */ (function () {\r\n /**\r\n * Creates a new geometry\r\n * @param id defines the unique ID\r\n * @param scene defines the hosting scene\r\n * @param vertexData defines the VertexData used to get geometry data\r\n * @param updatable defines if geometry must be updatable (false by default)\r\n * @param mesh defines the mesh that will be associated with the geometry\r\n */\r\n function Geometry(id, scene, vertexData, updatable, mesh) {\r\n if (updatable === void 0) { updatable = false; }\r\n if (mesh === void 0) { mesh = null; }\r\n /**\r\n * Gets the delay loading state of the geometry (none by default which means not delayed)\r\n */\r\n this.delayLoadState = 0;\r\n this._totalVertices = 0;\r\n this._isDisposed = false;\r\n this._indexBufferIsUpdatable = false;\r\n this.id = id;\r\n this.uniqueId = scene.getUniqueId();\r\n this._engine = scene.getEngine();\r\n this._meshes = [];\r\n this._scene = scene;\r\n //Init vertex buffer cache\r\n this._vertexBuffers = {};\r\n this._indices = [];\r\n this._updatable = updatable;\r\n // vertexData\r\n if (vertexData) {\r\n this.setAllVerticesData(vertexData, updatable);\r\n }\r\n else {\r\n this._totalVertices = 0;\r\n this._indices = [];\r\n }\r\n if (this._engine.getCaps().vertexArrayObject) {\r\n this._vertexArrayObjects = {};\r\n }\r\n // applyToMesh\r\n if (mesh) {\r\n this.applyToMesh(mesh);\r\n mesh.computeWorldMatrix(true);\r\n }\r\n }\r\n Object.defineProperty(Geometry.prototype, \"boundingBias\", {\r\n /**\r\n * Gets or sets the Bias Vector to apply on the bounding elements (box/sphere), the max extend is computed as v += v * bias.x + bias.y, the min is computed as v -= v * bias.x + bias.y\r\n */\r\n get: function () {\r\n return this._boundingBias;\r\n },\r\n /**\r\n * Gets or sets the Bias Vector to apply on the bounding elements (box/sphere), the max extend is computed as v += v * bias.x + bias.y, the min is computed as v -= v * bias.x + bias.y\r\n */\r\n set: function (value) {\r\n if (this._boundingBias) {\r\n this._boundingBias.copyFrom(value);\r\n }\r\n else {\r\n this._boundingBias = value.clone();\r\n }\r\n this._updateBoundingInfo(true, null);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Static function used to attach a new empty geometry to a mesh\r\n * @param mesh defines the mesh to attach the geometry to\r\n * @returns the new Geometry\r\n */\r\n Geometry.CreateGeometryForMesh = function (mesh) {\r\n var geometry = new Geometry(Geometry.RandomId(), mesh.getScene());\r\n geometry.applyToMesh(mesh);\r\n return geometry;\r\n };\r\n Object.defineProperty(Geometry.prototype, \"extend\", {\r\n /**\r\n * Gets the current extend of the geometry\r\n */\r\n get: function () {\r\n return this._extend;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the hosting scene\r\n * @returns the hosting Scene\r\n */\r\n Geometry.prototype.getScene = function () {\r\n return this._scene;\r\n };\r\n /**\r\n * Gets the hosting engine\r\n * @returns the hosting Engine\r\n */\r\n Geometry.prototype.getEngine = function () {\r\n return this._engine;\r\n };\r\n /**\r\n * Defines if the geometry is ready to use\r\n * @returns true if the geometry is ready to be used\r\n */\r\n Geometry.prototype.isReady = function () {\r\n return this.delayLoadState === 1 || this.delayLoadState === 0;\r\n };\r\n Object.defineProperty(Geometry.prototype, \"doNotSerialize\", {\r\n /**\r\n * Gets a value indicating that the geometry should not be serialized\r\n */\r\n get: function () {\r\n for (var index = 0; index < this._meshes.length; index++) {\r\n if (!this._meshes[index].doNotSerialize) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n Geometry.prototype._rebuild = function () {\r\n if (this._vertexArrayObjects) {\r\n this._vertexArrayObjects = {};\r\n }\r\n // Index buffer\r\n if (this._meshes.length !== 0 && this._indices) {\r\n this._indexBuffer = this._engine.createIndexBuffer(this._indices);\r\n }\r\n // Vertex buffers\r\n for (var key in this._vertexBuffers) {\r\n var vertexBuffer = this._vertexBuffers[key];\r\n vertexBuffer._rebuild();\r\n }\r\n };\r\n /**\r\n * Affects all geometry data in one call\r\n * @param vertexData defines the geometry data\r\n * @param updatable defines if the geometry must be flagged as updatable (false as default)\r\n */\r\n Geometry.prototype.setAllVerticesData = function (vertexData, updatable) {\r\n vertexData.applyToGeometry(this, updatable);\r\n this.notifyUpdate();\r\n };\r\n /**\r\n * Set specific vertex data\r\n * @param kind defines the data kind (Position, normal, etc...)\r\n * @param data defines the vertex data to use\r\n * @param updatable defines if the vertex must be flagged as updatable (false as default)\r\n * @param stride defines the stride to use (0 by default). This value is deduced from the kind value if not specified\r\n */\r\n Geometry.prototype.setVerticesData = function (kind, data, updatable, stride) {\r\n if (updatable === void 0) { updatable = false; }\r\n var buffer = new VertexBuffer(this._engine, data, kind, updatable, this._meshes.length === 0, stride);\r\n this.setVerticesBuffer(buffer);\r\n };\r\n /**\r\n * Removes a specific vertex data\r\n * @param kind defines the data kind (Position, normal, etc...)\r\n */\r\n Geometry.prototype.removeVerticesData = function (kind) {\r\n if (this._vertexBuffers[kind]) {\r\n this._vertexBuffers[kind].dispose();\r\n delete this._vertexBuffers[kind];\r\n }\r\n };\r\n /**\r\n * Affect a vertex buffer to the geometry. the vertexBuffer.getKind() function is used to determine where to store the data\r\n * @param buffer defines the vertex buffer to use\r\n * @param totalVertices defines the total number of vertices for position kind (could be null)\r\n */\r\n Geometry.prototype.setVerticesBuffer = function (buffer, totalVertices) {\r\n if (totalVertices === void 0) { totalVertices = null; }\r\n var kind = buffer.getKind();\r\n if (this._vertexBuffers[kind]) {\r\n this._vertexBuffers[kind].dispose();\r\n }\r\n this._vertexBuffers[kind] = buffer;\r\n if (kind === VertexBuffer.PositionKind) {\r\n var data = buffer.getData();\r\n if (totalVertices != null) {\r\n this._totalVertices = totalVertices;\r\n }\r\n else {\r\n if (data != null) {\r\n this._totalVertices = data.length / (buffer.byteStride / 4);\r\n }\r\n }\r\n this._updateExtend(data);\r\n this._resetPointsArrayCache();\r\n var meshes = this._meshes;\r\n var numOfMeshes = meshes.length;\r\n for (var index = 0; index < numOfMeshes; index++) {\r\n var mesh = meshes[index];\r\n mesh._boundingInfo = new BoundingInfo(this._extend.minimum, this._extend.maximum);\r\n mesh._createGlobalSubMesh(false);\r\n mesh.computeWorldMatrix(true);\r\n }\r\n }\r\n this.notifyUpdate(kind);\r\n if (this._vertexArrayObjects) {\r\n this._disposeVertexArrayObjects();\r\n this._vertexArrayObjects = {}; // Will trigger a rebuild of the VAO if supported\r\n }\r\n };\r\n /**\r\n * Update a specific vertex buffer\r\n * This function will directly update the underlying DataBuffer according to the passed numeric array or Float32Array\r\n * It will do nothing if the buffer is not updatable\r\n * @param kind defines the data kind (Position, normal, etc...)\r\n * @param data defines the data to use\r\n * @param offset defines the offset in the target buffer where to store the data\r\n * @param useBytes set to true if the offset is in bytes\r\n */\r\n Geometry.prototype.updateVerticesDataDirectly = function (kind, data, offset, useBytes) {\r\n if (useBytes === void 0) { useBytes = false; }\r\n var vertexBuffer = this.getVertexBuffer(kind);\r\n if (!vertexBuffer) {\r\n return;\r\n }\r\n vertexBuffer.updateDirectly(data, offset, useBytes);\r\n this.notifyUpdate(kind);\r\n };\r\n /**\r\n * Update a specific vertex buffer\r\n * This function will create a new buffer if the current one is not updatable\r\n * @param kind defines the data kind (Position, normal, etc...)\r\n * @param data defines the data to use\r\n * @param updateExtends defines if the geometry extends must be recomputed (false by default)\r\n */\r\n Geometry.prototype.updateVerticesData = function (kind, data, updateExtends) {\r\n if (updateExtends === void 0) { updateExtends = false; }\r\n var vertexBuffer = this.getVertexBuffer(kind);\r\n if (!vertexBuffer) {\r\n return;\r\n }\r\n vertexBuffer.update(data);\r\n if (kind === VertexBuffer.PositionKind) {\r\n this._updateBoundingInfo(updateExtends, data);\r\n }\r\n this.notifyUpdate(kind);\r\n };\r\n Geometry.prototype._updateBoundingInfo = function (updateExtends, data) {\r\n if (updateExtends) {\r\n this._updateExtend(data);\r\n }\r\n this._resetPointsArrayCache();\r\n if (updateExtends) {\r\n var meshes = this._meshes;\r\n for (var _i = 0, meshes_1 = meshes; _i < meshes_1.length; _i++) {\r\n var mesh = meshes_1[_i];\r\n if (mesh._boundingInfo) {\r\n mesh._boundingInfo.reConstruct(this._extend.minimum, this._extend.maximum);\r\n }\r\n else {\r\n mesh._boundingInfo = new BoundingInfo(this._extend.minimum, this._extend.maximum);\r\n }\r\n var subMeshes = mesh.subMeshes;\r\n for (var _a = 0, subMeshes_1 = subMeshes; _a < subMeshes_1.length; _a++) {\r\n var subMesh = subMeshes_1[_a];\r\n subMesh.refreshBoundingInfo();\r\n }\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n Geometry.prototype._bind = function (effect, indexToBind) {\r\n if (!effect) {\r\n return;\r\n }\r\n if (indexToBind === undefined) {\r\n indexToBind = this._indexBuffer;\r\n }\r\n var vbs = this.getVertexBuffers();\r\n if (!vbs) {\r\n return;\r\n }\r\n if (indexToBind != this._indexBuffer || !this._vertexArrayObjects) {\r\n this._engine.bindBuffers(vbs, indexToBind, effect);\r\n return;\r\n }\r\n // Using VAO\r\n if (!this._vertexArrayObjects[effect.key]) {\r\n this._vertexArrayObjects[effect.key] = this._engine.recordVertexArrayObject(vbs, indexToBind, effect);\r\n }\r\n this._engine.bindVertexArrayObject(this._vertexArrayObjects[effect.key], indexToBind);\r\n };\r\n /**\r\n * Gets total number of vertices\r\n * @returns the total number of vertices\r\n */\r\n Geometry.prototype.getTotalVertices = function () {\r\n if (!this.isReady()) {\r\n return 0;\r\n }\r\n return this._totalVertices;\r\n };\r\n /**\r\n * Gets a specific vertex data attached to this geometry. Float data is constructed if the vertex buffer data cannot be returned directly.\r\n * @param kind defines the data kind (Position, normal, etc...)\r\n * @param copyWhenShared defines if the returned array must be cloned upon returning it if the current geometry is shared between multiple meshes\r\n * @param forceCopy defines a boolean indicating that the returned array must be cloned upon returning it\r\n * @returns a float array containing vertex data\r\n */\r\n Geometry.prototype.getVerticesData = function (kind, copyWhenShared, forceCopy) {\r\n var vertexBuffer = this.getVertexBuffer(kind);\r\n if (!vertexBuffer) {\r\n return null;\r\n }\r\n var data = vertexBuffer.getData();\r\n if (!data) {\r\n return null;\r\n }\r\n var tightlyPackedByteStride = vertexBuffer.getSize() * VertexBuffer.GetTypeByteLength(vertexBuffer.type);\r\n var count = this._totalVertices * vertexBuffer.getSize();\r\n if (vertexBuffer.type !== VertexBuffer.FLOAT || vertexBuffer.byteStride !== tightlyPackedByteStride) {\r\n var copy_1 = [];\r\n vertexBuffer.forEach(count, function (value) { return copy_1.push(value); });\r\n return copy_1;\r\n }\r\n if (!((data instanceof Array) || (data instanceof Float32Array)) || vertexBuffer.byteOffset !== 0 || data.length !== count) {\r\n if (data instanceof Array) {\r\n var offset = vertexBuffer.byteOffset / 4;\r\n return Tools.Slice(data, offset, offset + count);\r\n }\r\n else if (data instanceof ArrayBuffer) {\r\n return new Float32Array(data, vertexBuffer.byteOffset, count);\r\n }\r\n else {\r\n var offset = data.byteOffset + vertexBuffer.byteOffset;\r\n if (forceCopy || (copyWhenShared && this._meshes.length !== 1)) {\r\n var result = new Float32Array(count);\r\n var source = new Float32Array(data.buffer, offset, count);\r\n result.set(source);\r\n return result;\r\n }\r\n return new Float32Array(data.buffer, offset, count);\r\n }\r\n }\r\n if (forceCopy || (copyWhenShared && this._meshes.length !== 1)) {\r\n return Tools.Slice(data);\r\n }\r\n return data;\r\n };\r\n /**\r\n * Returns a boolean defining if the vertex data for the requested `kind` is updatable\r\n * @param kind defines the data kind (Position, normal, etc...)\r\n * @returns true if the vertex buffer with the specified kind is updatable\r\n */\r\n Geometry.prototype.isVertexBufferUpdatable = function (kind) {\r\n var vb = this._vertexBuffers[kind];\r\n if (!vb) {\r\n return false;\r\n }\r\n return vb.isUpdatable();\r\n };\r\n /**\r\n * Gets a specific vertex buffer\r\n * @param kind defines the data kind (Position, normal, etc...)\r\n * @returns a VertexBuffer\r\n */\r\n Geometry.prototype.getVertexBuffer = function (kind) {\r\n if (!this.isReady()) {\r\n return null;\r\n }\r\n return this._vertexBuffers[kind];\r\n };\r\n /**\r\n * Returns all vertex buffers\r\n * @return an object holding all vertex buffers indexed by kind\r\n */\r\n Geometry.prototype.getVertexBuffers = function () {\r\n if (!this.isReady()) {\r\n return null;\r\n }\r\n return this._vertexBuffers;\r\n };\r\n /**\r\n * Gets a boolean indicating if specific vertex buffer is present\r\n * @param kind defines the data kind (Position, normal, etc...)\r\n * @returns true if data is present\r\n */\r\n Geometry.prototype.isVerticesDataPresent = function (kind) {\r\n if (!this._vertexBuffers) {\r\n if (this._delayInfo) {\r\n return this._delayInfo.indexOf(kind) !== -1;\r\n }\r\n return false;\r\n }\r\n return this._vertexBuffers[kind] !== undefined;\r\n };\r\n /**\r\n * Gets a list of all attached data kinds (Position, normal, etc...)\r\n * @returns a list of string containing all kinds\r\n */\r\n Geometry.prototype.getVerticesDataKinds = function () {\r\n var result = [];\r\n var kind;\r\n if (!this._vertexBuffers && this._delayInfo) {\r\n for (kind in this._delayInfo) {\r\n result.push(kind);\r\n }\r\n }\r\n else {\r\n for (kind in this._vertexBuffers) {\r\n result.push(kind);\r\n }\r\n }\r\n return result;\r\n };\r\n /**\r\n * Update index buffer\r\n * @param indices defines the indices to store in the index buffer\r\n * @param offset defines the offset in the target buffer where to store the data\r\n * @param gpuMemoryOnly defines a boolean indicating that only the GPU memory must be updated leaving the CPU version of the indices unchanged (false by default)\r\n */\r\n Geometry.prototype.updateIndices = function (indices, offset, gpuMemoryOnly) {\r\n if (gpuMemoryOnly === void 0) { gpuMemoryOnly = false; }\r\n if (!this._indexBuffer) {\r\n return;\r\n }\r\n if (!this._indexBufferIsUpdatable) {\r\n this.setIndices(indices, null, true);\r\n }\r\n else {\r\n var needToUpdateSubMeshes = indices.length !== this._indices.length;\r\n if (!gpuMemoryOnly) {\r\n this._indices = indices.slice();\r\n }\r\n this._engine.updateDynamicIndexBuffer(this._indexBuffer, indices, offset);\r\n if (needToUpdateSubMeshes) {\r\n for (var _i = 0, _a = this._meshes; _i < _a.length; _i++) {\r\n var mesh = _a[_i];\r\n mesh._createGlobalSubMesh(true);\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Creates a new index buffer\r\n * @param indices defines the indices to store in the index buffer\r\n * @param totalVertices defines the total number of vertices (could be null)\r\n * @param updatable defines if the index buffer must be flagged as updatable (false by default)\r\n */\r\n Geometry.prototype.setIndices = function (indices, totalVertices, updatable) {\r\n if (totalVertices === void 0) { totalVertices = null; }\r\n if (updatable === void 0) { updatable = false; }\r\n if (this._indexBuffer) {\r\n this._engine._releaseBuffer(this._indexBuffer);\r\n }\r\n this._disposeVertexArrayObjects();\r\n this._indices = indices;\r\n this._indexBufferIsUpdatable = updatable;\r\n if (this._meshes.length !== 0 && this._indices) {\r\n this._indexBuffer = this._engine.createIndexBuffer(this._indices, updatable);\r\n }\r\n if (totalVertices != undefined) { // including null and undefined\r\n this._totalVertices = totalVertices;\r\n }\r\n for (var _i = 0, _a = this._meshes; _i < _a.length; _i++) {\r\n var mesh = _a[_i];\r\n mesh._createGlobalSubMesh(true);\r\n }\r\n this.notifyUpdate();\r\n };\r\n /**\r\n * Return the total number of indices\r\n * @returns the total number of indices\r\n */\r\n Geometry.prototype.getTotalIndices = function () {\r\n if (!this.isReady()) {\r\n return 0;\r\n }\r\n return this._indices.length;\r\n };\r\n /**\r\n * Gets the index buffer array\r\n * @param copyWhenShared defines if the returned array must be cloned upon returning it if the current geometry is shared between multiple meshes\r\n * @param forceCopy defines a boolean indicating that the returned array must be cloned upon returning it\r\n * @returns the index buffer array\r\n */\r\n Geometry.prototype.getIndices = function (copyWhenShared, forceCopy) {\r\n if (!this.isReady()) {\r\n return null;\r\n }\r\n var orig = this._indices;\r\n if (!forceCopy && (!copyWhenShared || this._meshes.length === 1)) {\r\n return orig;\r\n }\r\n else {\r\n var len = orig.length;\r\n var copy = [];\r\n for (var i = 0; i < len; i++) {\r\n copy.push(orig[i]);\r\n }\r\n return copy;\r\n }\r\n };\r\n /**\r\n * Gets the index buffer\r\n * @return the index buffer\r\n */\r\n Geometry.prototype.getIndexBuffer = function () {\r\n if (!this.isReady()) {\r\n return null;\r\n }\r\n return this._indexBuffer;\r\n };\r\n /** @hidden */\r\n Geometry.prototype._releaseVertexArrayObject = function (effect) {\r\n if (effect === void 0) { effect = null; }\r\n if (!effect || !this._vertexArrayObjects) {\r\n return;\r\n }\r\n if (this._vertexArrayObjects[effect.key]) {\r\n this._engine.releaseVertexArrayObject(this._vertexArrayObjects[effect.key]);\r\n delete this._vertexArrayObjects[effect.key];\r\n }\r\n };\r\n /**\r\n * Release the associated resources for a specific mesh\r\n * @param mesh defines the source mesh\r\n * @param shouldDispose defines if the geometry must be disposed if there is no more mesh pointing to it\r\n */\r\n Geometry.prototype.releaseForMesh = function (mesh, shouldDispose) {\r\n var meshes = this._meshes;\r\n var index = meshes.indexOf(mesh);\r\n if (index === -1) {\r\n return;\r\n }\r\n meshes.splice(index, 1);\r\n mesh._geometry = null;\r\n if (meshes.length === 0 && shouldDispose) {\r\n this.dispose();\r\n }\r\n };\r\n /**\r\n * Apply current geometry to a given mesh\r\n * @param mesh defines the mesh to apply geometry to\r\n */\r\n Geometry.prototype.applyToMesh = function (mesh) {\r\n if (mesh._geometry === this) {\r\n return;\r\n }\r\n var previousGeometry = mesh._geometry;\r\n if (previousGeometry) {\r\n previousGeometry.releaseForMesh(mesh);\r\n }\r\n var meshes = this._meshes;\r\n // must be done before setting vertexBuffers because of mesh._createGlobalSubMesh()\r\n mesh._geometry = this;\r\n this._scene.pushGeometry(this);\r\n meshes.push(mesh);\r\n if (this.isReady()) {\r\n this._applyToMesh(mesh);\r\n }\r\n else {\r\n mesh._boundingInfo = this._boundingInfo;\r\n }\r\n };\r\n Geometry.prototype._updateExtend = function (data) {\r\n if (data === void 0) { data = null; }\r\n if (!data) {\r\n data = this.getVerticesData(VertexBuffer.PositionKind);\r\n }\r\n this._extend = extractMinAndMax(data, 0, this._totalVertices, this.boundingBias, 3);\r\n };\r\n Geometry.prototype._applyToMesh = function (mesh) {\r\n var numOfMeshes = this._meshes.length;\r\n // vertexBuffers\r\n for (var kind in this._vertexBuffers) {\r\n if (numOfMeshes === 1) {\r\n this._vertexBuffers[kind].create();\r\n }\r\n var buffer = this._vertexBuffers[kind].getBuffer();\r\n if (buffer) {\r\n buffer.references = numOfMeshes;\r\n }\r\n if (kind === VertexBuffer.PositionKind) {\r\n if (!this._extend) {\r\n this._updateExtend();\r\n }\r\n mesh._boundingInfo = new BoundingInfo(this._extend.minimum, this._extend.maximum);\r\n mesh._createGlobalSubMesh(false);\r\n //bounding info was just created again, world matrix should be applied again.\r\n mesh._updateBoundingInfo();\r\n }\r\n }\r\n // indexBuffer\r\n if (numOfMeshes === 1 && this._indices && this._indices.length > 0) {\r\n this._indexBuffer = this._engine.createIndexBuffer(this._indices);\r\n }\r\n if (this._indexBuffer) {\r\n this._indexBuffer.references = numOfMeshes;\r\n }\r\n // morphTargets\r\n mesh._syncGeometryWithMorphTargetManager();\r\n // instances\r\n mesh.synchronizeInstances();\r\n };\r\n Geometry.prototype.notifyUpdate = function (kind) {\r\n if (this.onGeometryUpdated) {\r\n this.onGeometryUpdated(this, kind);\r\n }\r\n for (var _i = 0, _a = this._meshes; _i < _a.length; _i++) {\r\n var mesh = _a[_i];\r\n mesh._markSubMeshesAsAttributesDirty();\r\n }\r\n };\r\n /**\r\n * Load the geometry if it was flagged as delay loaded\r\n * @param scene defines the hosting scene\r\n * @param onLoaded defines a callback called when the geometry is loaded\r\n */\r\n Geometry.prototype.load = function (scene, onLoaded) {\r\n if (this.delayLoadState === 2) {\r\n return;\r\n }\r\n if (this.isReady()) {\r\n if (onLoaded) {\r\n onLoaded();\r\n }\r\n return;\r\n }\r\n this.delayLoadState = 2;\r\n this._queueLoad(scene, onLoaded);\r\n };\r\n Geometry.prototype._queueLoad = function (scene, onLoaded) {\r\n var _this = this;\r\n if (!this.delayLoadingFile) {\r\n return;\r\n }\r\n scene._addPendingData(this);\r\n scene._loadFile(this.delayLoadingFile, function (data) {\r\n if (!_this._delayLoadingFunction) {\r\n return;\r\n }\r\n _this._delayLoadingFunction(JSON.parse(data), _this);\r\n _this.delayLoadState = 1;\r\n _this._delayInfo = [];\r\n scene._removePendingData(_this);\r\n var meshes = _this._meshes;\r\n var numOfMeshes = meshes.length;\r\n for (var index = 0; index < numOfMeshes; index++) {\r\n _this._applyToMesh(meshes[index]);\r\n }\r\n if (onLoaded) {\r\n onLoaded();\r\n }\r\n }, undefined, true);\r\n };\r\n /**\r\n * Invert the geometry to move from a right handed system to a left handed one.\r\n */\r\n Geometry.prototype.toLeftHanded = function () {\r\n // Flip faces\r\n var tIndices = this.getIndices(false);\r\n if (tIndices != null && tIndices.length > 0) {\r\n for (var i = 0; i < tIndices.length; i += 3) {\r\n var tTemp = tIndices[i + 0];\r\n tIndices[i + 0] = tIndices[i + 2];\r\n tIndices[i + 2] = tTemp;\r\n }\r\n this.setIndices(tIndices);\r\n }\r\n // Negate position.z\r\n var tPositions = this.getVerticesData(VertexBuffer.PositionKind, false);\r\n if (tPositions != null && tPositions.length > 0) {\r\n for (var i = 0; i < tPositions.length; i += 3) {\r\n tPositions[i + 2] = -tPositions[i + 2];\r\n }\r\n this.setVerticesData(VertexBuffer.PositionKind, tPositions, false);\r\n }\r\n // Negate normal.z\r\n var tNormals = this.getVerticesData(VertexBuffer.NormalKind, false);\r\n if (tNormals != null && tNormals.length > 0) {\r\n for (var i = 0; i < tNormals.length; i += 3) {\r\n tNormals[i + 2] = -tNormals[i + 2];\r\n }\r\n this.setVerticesData(VertexBuffer.NormalKind, tNormals, false);\r\n }\r\n };\r\n // Cache\r\n /** @hidden */\r\n Geometry.prototype._resetPointsArrayCache = function () {\r\n this._positions = null;\r\n };\r\n /** @hidden */\r\n Geometry.prototype._generatePointsArray = function () {\r\n if (this._positions) {\r\n return true;\r\n }\r\n var data = this.getVerticesData(VertexBuffer.PositionKind);\r\n if (!data || data.length === 0) {\r\n return false;\r\n }\r\n this._positions = [];\r\n for (var index = 0; index < data.length; index += 3) {\r\n this._positions.push(Vector3.FromArray(data, index));\r\n }\r\n return true;\r\n };\r\n /**\r\n * Gets a value indicating if the geometry is disposed\r\n * @returns true if the geometry was disposed\r\n */\r\n Geometry.prototype.isDisposed = function () {\r\n return this._isDisposed;\r\n };\r\n Geometry.prototype._disposeVertexArrayObjects = function () {\r\n if (this._vertexArrayObjects) {\r\n for (var kind in this._vertexArrayObjects) {\r\n this._engine.releaseVertexArrayObject(this._vertexArrayObjects[kind]);\r\n }\r\n this._vertexArrayObjects = {};\r\n }\r\n };\r\n /**\r\n * Free all associated resources\r\n */\r\n Geometry.prototype.dispose = function () {\r\n var meshes = this._meshes;\r\n var numOfMeshes = meshes.length;\r\n var index;\r\n for (index = 0; index < numOfMeshes; index++) {\r\n this.releaseForMesh(meshes[index]);\r\n }\r\n this._meshes = [];\r\n this._disposeVertexArrayObjects();\r\n for (var kind in this._vertexBuffers) {\r\n this._vertexBuffers[kind].dispose();\r\n }\r\n this._vertexBuffers = {};\r\n this._totalVertices = 0;\r\n if (this._indexBuffer) {\r\n this._engine._releaseBuffer(this._indexBuffer);\r\n }\r\n this._indexBuffer = null;\r\n this._indices = [];\r\n this.delayLoadState = 0;\r\n this.delayLoadingFile = null;\r\n this._delayLoadingFunction = null;\r\n this._delayInfo = [];\r\n this._boundingInfo = null;\r\n this._scene.removeGeometry(this);\r\n this._isDisposed = true;\r\n };\r\n /**\r\n * Clone the current geometry into a new geometry\r\n * @param id defines the unique ID of the new geometry\r\n * @returns a new geometry object\r\n */\r\n Geometry.prototype.copy = function (id) {\r\n var vertexData = new VertexData();\r\n vertexData.indices = [];\r\n var indices = this.getIndices();\r\n if (indices) {\r\n for (var index = 0; index < indices.length; index++) {\r\n vertexData.indices.push(indices[index]);\r\n }\r\n }\r\n var updatable = false;\r\n var stopChecking = false;\r\n var kind;\r\n for (kind in this._vertexBuffers) {\r\n // using slice() to make a copy of the array and not just reference it\r\n var data = this.getVerticesData(kind);\r\n if (data) {\r\n if (data instanceof Float32Array) {\r\n vertexData.set(new Float32Array(data), kind);\r\n }\r\n else {\r\n vertexData.set(data.slice(0), kind);\r\n }\r\n if (!stopChecking) {\r\n var vb = this.getVertexBuffer(kind);\r\n if (vb) {\r\n updatable = vb.isUpdatable();\r\n stopChecking = !updatable;\r\n }\r\n }\r\n }\r\n }\r\n var geometry = new Geometry(id, this._scene, vertexData, updatable);\r\n geometry.delayLoadState = this.delayLoadState;\r\n geometry.delayLoadingFile = this.delayLoadingFile;\r\n geometry._delayLoadingFunction = this._delayLoadingFunction;\r\n for (kind in this._delayInfo) {\r\n geometry._delayInfo = geometry._delayInfo || [];\r\n geometry._delayInfo.push(kind);\r\n }\r\n // Bounding info\r\n geometry._boundingInfo = new BoundingInfo(this._extend.minimum, this._extend.maximum);\r\n return geometry;\r\n };\r\n /**\r\n * Serialize the current geometry info (and not the vertices data) into a JSON object\r\n * @return a JSON representation of the current geometry data (without the vertices data)\r\n */\r\n Geometry.prototype.serialize = function () {\r\n var serializationObject = {};\r\n serializationObject.id = this.id;\r\n serializationObject.updatable = this._updatable;\r\n if (Tags && Tags.HasTags(this)) {\r\n serializationObject.tags = Tags.GetTags(this);\r\n }\r\n return serializationObject;\r\n };\r\n Geometry.prototype.toNumberArray = function (origin) {\r\n if (Array.isArray(origin)) {\r\n return origin;\r\n }\r\n else {\r\n return Array.prototype.slice.call(origin);\r\n }\r\n };\r\n /**\r\n * Serialize all vertices data into a JSON oject\r\n * @returns a JSON representation of the current geometry data\r\n */\r\n Geometry.prototype.serializeVerticeData = function () {\r\n var serializationObject = this.serialize();\r\n if (this.isVerticesDataPresent(VertexBuffer.PositionKind)) {\r\n serializationObject.positions = this.toNumberArray(this.getVerticesData(VertexBuffer.PositionKind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.PositionKind)) {\r\n serializationObject.positions._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.NormalKind)) {\r\n serializationObject.normals = this.toNumberArray(this.getVerticesData(VertexBuffer.NormalKind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.NormalKind)) {\r\n serializationObject.normals._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.TangentKind)) {\r\n serializationObject.tangets = this.toNumberArray(this.getVerticesData(VertexBuffer.TangentKind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.TangentKind)) {\r\n serializationObject.tangets._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.UVKind)) {\r\n serializationObject.uvs = this.toNumberArray(this.getVerticesData(VertexBuffer.UVKind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.UVKind)) {\r\n serializationObject.uvs._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.UV2Kind)) {\r\n serializationObject.uv2s = this.toNumberArray(this.getVerticesData(VertexBuffer.UV2Kind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.UV2Kind)) {\r\n serializationObject.uv2s._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.UV3Kind)) {\r\n serializationObject.uv3s = this.toNumberArray(this.getVerticesData(VertexBuffer.UV3Kind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.UV3Kind)) {\r\n serializationObject.uv3s._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.UV4Kind)) {\r\n serializationObject.uv4s = this.toNumberArray(this.getVerticesData(VertexBuffer.UV4Kind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.UV4Kind)) {\r\n serializationObject.uv4s._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.UV5Kind)) {\r\n serializationObject.uv5s = this.toNumberArray(this.getVerticesData(VertexBuffer.UV5Kind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.UV5Kind)) {\r\n serializationObject.uv5s._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.UV6Kind)) {\r\n serializationObject.uv6s = this.toNumberArray(this.getVerticesData(VertexBuffer.UV6Kind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.UV6Kind)) {\r\n serializationObject.uv6s._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.ColorKind)) {\r\n serializationObject.colors = this.toNumberArray(this.getVerticesData(VertexBuffer.ColorKind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.ColorKind)) {\r\n serializationObject.colors._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.MatricesIndicesKind)) {\r\n serializationObject.matricesIndices = this.toNumberArray(this.getVerticesData(VertexBuffer.MatricesIndicesKind));\r\n serializationObject.matricesIndices._isExpanded = true;\r\n if (this.isVertexBufferUpdatable(VertexBuffer.MatricesIndicesKind)) {\r\n serializationObject.matricesIndices._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.MatricesWeightsKind)) {\r\n serializationObject.matricesWeights = this.toNumberArray(this.getVerticesData(VertexBuffer.MatricesWeightsKind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.MatricesWeightsKind)) {\r\n serializationObject.matricesWeights._updatable = true;\r\n }\r\n }\r\n serializationObject.indices = this.toNumberArray(this.getIndices());\r\n return serializationObject;\r\n };\r\n // Statics\r\n /**\r\n * Extracts a clone of a mesh geometry\r\n * @param mesh defines the source mesh\r\n * @param id defines the unique ID of the new geometry object\r\n * @returns the new geometry object\r\n */\r\n Geometry.ExtractFromMesh = function (mesh, id) {\r\n var geometry = mesh._geometry;\r\n if (!geometry) {\r\n return null;\r\n }\r\n return geometry.copy(id);\r\n };\r\n /**\r\n * You should now use Tools.RandomId(), this method is still here for legacy reasons.\r\n * Implementation from http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/2117523#answer-2117523\r\n * Be aware Math.random() could cause collisions, but:\r\n * \"All but 6 of the 128 bits of the ID are randomly generated, which means that for any two ids, there's a 1 in 2^^122 (or 5.3x10^^36) chance they'll collide\"\r\n * @returns a string containing a new GUID\r\n */\r\n Geometry.RandomId = function () {\r\n return Tools.RandomId();\r\n };\r\n /** @hidden */\r\n Geometry._ImportGeometry = function (parsedGeometry, mesh) {\r\n var scene = mesh.getScene();\r\n // Geometry\r\n var geometryId = parsedGeometry.geometryId;\r\n if (geometryId) {\r\n var geometry = scene.getGeometryByID(geometryId);\r\n if (geometry) {\r\n geometry.applyToMesh(mesh);\r\n }\r\n }\r\n else if (parsedGeometry instanceof ArrayBuffer) {\r\n var binaryInfo = mesh._binaryInfo;\r\n if (binaryInfo.positionsAttrDesc && binaryInfo.positionsAttrDesc.count > 0) {\r\n var positionsData = new Float32Array(parsedGeometry, binaryInfo.positionsAttrDesc.offset, binaryInfo.positionsAttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.PositionKind, positionsData, false);\r\n }\r\n if (binaryInfo.normalsAttrDesc && binaryInfo.normalsAttrDesc.count > 0) {\r\n var normalsData = new Float32Array(parsedGeometry, binaryInfo.normalsAttrDesc.offset, binaryInfo.normalsAttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.NormalKind, normalsData, false);\r\n }\r\n if (binaryInfo.tangetsAttrDesc && binaryInfo.tangetsAttrDesc.count > 0) {\r\n var tangentsData = new Float32Array(parsedGeometry, binaryInfo.tangetsAttrDesc.offset, binaryInfo.tangetsAttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.TangentKind, tangentsData, false);\r\n }\r\n if (binaryInfo.uvsAttrDesc && binaryInfo.uvsAttrDesc.count > 0) {\r\n var uvsData = new Float32Array(parsedGeometry, binaryInfo.uvsAttrDesc.offset, binaryInfo.uvsAttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.UVKind, uvsData, false);\r\n }\r\n if (binaryInfo.uvs2AttrDesc && binaryInfo.uvs2AttrDesc.count > 0) {\r\n var uvs2Data = new Float32Array(parsedGeometry, binaryInfo.uvs2AttrDesc.offset, binaryInfo.uvs2AttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.UV2Kind, uvs2Data, false);\r\n }\r\n if (binaryInfo.uvs3AttrDesc && binaryInfo.uvs3AttrDesc.count > 0) {\r\n var uvs3Data = new Float32Array(parsedGeometry, binaryInfo.uvs3AttrDesc.offset, binaryInfo.uvs3AttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.UV3Kind, uvs3Data, false);\r\n }\r\n if (binaryInfo.uvs4AttrDesc && binaryInfo.uvs4AttrDesc.count > 0) {\r\n var uvs4Data = new Float32Array(parsedGeometry, binaryInfo.uvs4AttrDesc.offset, binaryInfo.uvs4AttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.UV4Kind, uvs4Data, false);\r\n }\r\n if (binaryInfo.uvs5AttrDesc && binaryInfo.uvs5AttrDesc.count > 0) {\r\n var uvs5Data = new Float32Array(parsedGeometry, binaryInfo.uvs5AttrDesc.offset, binaryInfo.uvs5AttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.UV5Kind, uvs5Data, false);\r\n }\r\n if (binaryInfo.uvs6AttrDesc && binaryInfo.uvs6AttrDesc.count > 0) {\r\n var uvs6Data = new Float32Array(parsedGeometry, binaryInfo.uvs6AttrDesc.offset, binaryInfo.uvs6AttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.UV6Kind, uvs6Data, false);\r\n }\r\n if (binaryInfo.colorsAttrDesc && binaryInfo.colorsAttrDesc.count > 0) {\r\n var colorsData = new Float32Array(parsedGeometry, binaryInfo.colorsAttrDesc.offset, binaryInfo.colorsAttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.ColorKind, colorsData, false, binaryInfo.colorsAttrDesc.stride);\r\n }\r\n if (binaryInfo.matricesIndicesAttrDesc && binaryInfo.matricesIndicesAttrDesc.count > 0) {\r\n var matricesIndicesData = new Int32Array(parsedGeometry, binaryInfo.matricesIndicesAttrDesc.offset, binaryInfo.matricesIndicesAttrDesc.count);\r\n var floatIndices = [];\r\n for (var i = 0; i < matricesIndicesData.length; i++) {\r\n var index = matricesIndicesData[i];\r\n floatIndices.push(index & 0x000000FF);\r\n floatIndices.push((index & 0x0000FF00) >> 8);\r\n floatIndices.push((index & 0x00FF0000) >> 16);\r\n floatIndices.push(index >> 24);\r\n }\r\n mesh.setVerticesData(VertexBuffer.MatricesIndicesKind, floatIndices, false);\r\n }\r\n if (binaryInfo.matricesWeightsAttrDesc && binaryInfo.matricesWeightsAttrDesc.count > 0) {\r\n var matricesWeightsData = new Float32Array(parsedGeometry, binaryInfo.matricesWeightsAttrDesc.offset, binaryInfo.matricesWeightsAttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.MatricesWeightsKind, matricesWeightsData, false);\r\n }\r\n if (binaryInfo.indicesAttrDesc && binaryInfo.indicesAttrDesc.count > 0) {\r\n var indicesData = new Int32Array(parsedGeometry, binaryInfo.indicesAttrDesc.offset, binaryInfo.indicesAttrDesc.count);\r\n mesh.setIndices(indicesData, null);\r\n }\r\n if (binaryInfo.subMeshesAttrDesc && binaryInfo.subMeshesAttrDesc.count > 0) {\r\n var subMeshesData = new Int32Array(parsedGeometry, binaryInfo.subMeshesAttrDesc.offset, binaryInfo.subMeshesAttrDesc.count * 5);\r\n mesh.subMeshes = [];\r\n for (var i = 0; i < binaryInfo.subMeshesAttrDesc.count; i++) {\r\n var materialIndex = subMeshesData[(i * 5) + 0];\r\n var verticesStart = subMeshesData[(i * 5) + 1];\r\n var verticesCount = subMeshesData[(i * 5) + 2];\r\n var indexStart = subMeshesData[(i * 5) + 3];\r\n var indexCount = subMeshesData[(i * 5) + 4];\r\n SubMesh.AddToMesh(materialIndex, verticesStart, verticesCount, indexStart, indexCount, mesh);\r\n }\r\n }\r\n }\r\n else if (parsedGeometry.positions && parsedGeometry.normals && parsedGeometry.indices) {\r\n mesh.setVerticesData(VertexBuffer.PositionKind, parsedGeometry.positions, parsedGeometry.positions._updatable);\r\n mesh.setVerticesData(VertexBuffer.NormalKind, parsedGeometry.normals, parsedGeometry.normals._updatable);\r\n if (parsedGeometry.tangents) {\r\n mesh.setVerticesData(VertexBuffer.TangentKind, parsedGeometry.tangents, parsedGeometry.tangents._updatable);\r\n }\r\n if (parsedGeometry.uvs) {\r\n mesh.setVerticesData(VertexBuffer.UVKind, parsedGeometry.uvs, parsedGeometry.uvs._updatable);\r\n }\r\n if (parsedGeometry.uvs2) {\r\n mesh.setVerticesData(VertexBuffer.UV2Kind, parsedGeometry.uvs2, parsedGeometry.uvs2._updatable);\r\n }\r\n if (parsedGeometry.uvs3) {\r\n mesh.setVerticesData(VertexBuffer.UV3Kind, parsedGeometry.uvs3, parsedGeometry.uvs3._updatable);\r\n }\r\n if (parsedGeometry.uvs4) {\r\n mesh.setVerticesData(VertexBuffer.UV4Kind, parsedGeometry.uvs4, parsedGeometry.uvs4._updatable);\r\n }\r\n if (parsedGeometry.uvs5) {\r\n mesh.setVerticesData(VertexBuffer.UV5Kind, parsedGeometry.uvs5, parsedGeometry.uvs5._updatable);\r\n }\r\n if (parsedGeometry.uvs6) {\r\n mesh.setVerticesData(VertexBuffer.UV6Kind, parsedGeometry.uvs6, parsedGeometry.uvs6._updatable);\r\n }\r\n if (parsedGeometry.colors) {\r\n mesh.setVerticesData(VertexBuffer.ColorKind, Color4.CheckColors4(parsedGeometry.colors, parsedGeometry.positions.length / 3), parsedGeometry.colors._updatable);\r\n }\r\n if (parsedGeometry.matricesIndices) {\r\n if (!parsedGeometry.matricesIndices._isExpanded) {\r\n var floatIndices = [];\r\n for (var i = 0; i < parsedGeometry.matricesIndices.length; i++) {\r\n var matricesIndex = parsedGeometry.matricesIndices[i];\r\n floatIndices.push(matricesIndex & 0x000000FF);\r\n floatIndices.push((matricesIndex & 0x0000FF00) >> 8);\r\n floatIndices.push((matricesIndex & 0x00FF0000) >> 16);\r\n floatIndices.push(matricesIndex >> 24);\r\n }\r\n mesh.setVerticesData(VertexBuffer.MatricesIndicesKind, floatIndices, parsedGeometry.matricesIndices._updatable);\r\n }\r\n else {\r\n delete parsedGeometry.matricesIndices._isExpanded;\r\n mesh.setVerticesData(VertexBuffer.MatricesIndicesKind, parsedGeometry.matricesIndices, parsedGeometry.matricesIndices._updatable);\r\n }\r\n }\r\n if (parsedGeometry.matricesIndicesExtra) {\r\n if (!parsedGeometry.matricesIndicesExtra._isExpanded) {\r\n var floatIndices = [];\r\n for (var i = 0; i < parsedGeometry.matricesIndicesExtra.length; i++) {\r\n var matricesIndex = parsedGeometry.matricesIndicesExtra[i];\r\n floatIndices.push(matricesIndex & 0x000000FF);\r\n floatIndices.push((matricesIndex & 0x0000FF00) >> 8);\r\n floatIndices.push((matricesIndex & 0x00FF0000) >> 16);\r\n floatIndices.push(matricesIndex >> 24);\r\n }\r\n mesh.setVerticesData(VertexBuffer.MatricesIndicesExtraKind, floatIndices, parsedGeometry.matricesIndicesExtra._updatable);\r\n }\r\n else {\r\n delete parsedGeometry.matricesIndices._isExpanded;\r\n mesh.setVerticesData(VertexBuffer.MatricesIndicesExtraKind, parsedGeometry.matricesIndicesExtra, parsedGeometry.matricesIndicesExtra._updatable);\r\n }\r\n }\r\n if (parsedGeometry.matricesWeights) {\r\n Geometry._CleanMatricesWeights(parsedGeometry, mesh);\r\n mesh.setVerticesData(VertexBuffer.MatricesWeightsKind, parsedGeometry.matricesWeights, parsedGeometry.matricesWeights._updatable);\r\n }\r\n if (parsedGeometry.matricesWeightsExtra) {\r\n mesh.setVerticesData(VertexBuffer.MatricesWeightsExtraKind, parsedGeometry.matricesWeightsExtra, parsedGeometry.matricesWeights._updatable);\r\n }\r\n mesh.setIndices(parsedGeometry.indices, null);\r\n }\r\n // SubMeshes\r\n if (parsedGeometry.subMeshes) {\r\n mesh.subMeshes = [];\r\n for (var subIndex = 0; subIndex < parsedGeometry.subMeshes.length; subIndex++) {\r\n var parsedSubMesh = parsedGeometry.subMeshes[subIndex];\r\n SubMesh.AddToMesh(parsedSubMesh.materialIndex, parsedSubMesh.verticesStart, parsedSubMesh.verticesCount, parsedSubMesh.indexStart, parsedSubMesh.indexCount, mesh);\r\n }\r\n }\r\n // Flat shading\r\n if (mesh._shouldGenerateFlatShading) {\r\n mesh.convertToFlatShadedMesh();\r\n delete mesh._shouldGenerateFlatShading;\r\n }\r\n // Update\r\n mesh.computeWorldMatrix(true);\r\n scene.onMeshImportedObservable.notifyObservers(mesh);\r\n };\r\n Geometry._CleanMatricesWeights = function (parsedGeometry, mesh) {\r\n var epsilon = 1e-3;\r\n if (!SceneLoaderFlags.CleanBoneMatrixWeights) {\r\n return;\r\n }\r\n var noInfluenceBoneIndex = 0.0;\r\n if (parsedGeometry.skeletonId > -1) {\r\n var skeleton = mesh.getScene().getLastSkeletonByID(parsedGeometry.skeletonId);\r\n if (!skeleton) {\r\n return;\r\n }\r\n noInfluenceBoneIndex = skeleton.bones.length;\r\n }\r\n else {\r\n return;\r\n }\r\n var matricesIndices = mesh.getVerticesData(VertexBuffer.MatricesIndicesKind);\r\n var matricesIndicesExtra = mesh.getVerticesData(VertexBuffer.MatricesIndicesExtraKind);\r\n var matricesWeights = parsedGeometry.matricesWeights;\r\n var matricesWeightsExtra = parsedGeometry.matricesWeightsExtra;\r\n var influencers = parsedGeometry.numBoneInfluencer;\r\n var size = matricesWeights.length;\r\n for (var i = 0; i < size; i += 4) {\r\n var weight = 0.0;\r\n var firstZeroWeight = -1;\r\n for (var j = 0; j < 4; j++) {\r\n var w = matricesWeights[i + j];\r\n weight += w;\r\n if (w < epsilon && firstZeroWeight < 0) {\r\n firstZeroWeight = j;\r\n }\r\n }\r\n if (matricesWeightsExtra) {\r\n for (var j = 0; j < 4; j++) {\r\n var w = matricesWeightsExtra[i + j];\r\n weight += w;\r\n if (w < epsilon && firstZeroWeight < 0) {\r\n firstZeroWeight = j + 4;\r\n }\r\n }\r\n }\r\n if (firstZeroWeight < 0 || firstZeroWeight > (influencers - 1)) {\r\n firstZeroWeight = influencers - 1;\r\n }\r\n if (weight > epsilon) {\r\n var mweight = 1.0 / weight;\r\n for (var j = 0; j < 4; j++) {\r\n matricesWeights[i + j] *= mweight;\r\n }\r\n if (matricesWeightsExtra) {\r\n for (var j = 0; j < 4; j++) {\r\n matricesWeightsExtra[i + j] *= mweight;\r\n }\r\n }\r\n }\r\n else {\r\n if (firstZeroWeight >= 4) {\r\n matricesWeightsExtra[i + firstZeroWeight - 4] = 1.0 - weight;\r\n matricesIndicesExtra[i + firstZeroWeight - 4] = noInfluenceBoneIndex;\r\n }\r\n else {\r\n matricesWeights[i + firstZeroWeight] = 1.0 - weight;\r\n matricesIndices[i + firstZeroWeight] = noInfluenceBoneIndex;\r\n }\r\n }\r\n }\r\n mesh.setVerticesData(VertexBuffer.MatricesIndicesKind, matricesIndices);\r\n if (parsedGeometry.matricesWeightsExtra) {\r\n mesh.setVerticesData(VertexBuffer.MatricesIndicesExtraKind, matricesIndicesExtra);\r\n }\r\n };\r\n /**\r\n * Create a new geometry from persisted data (Using .babylon file format)\r\n * @param parsedVertexData defines the persisted data\r\n * @param scene defines the hosting scene\r\n * @param rootUrl defines the root url to use to load assets (like delayed data)\r\n * @returns the new geometry object\r\n */\r\n Geometry.Parse = function (parsedVertexData, scene, rootUrl) {\r\n if (scene.getGeometryByID(parsedVertexData.id)) {\r\n return null; // null since geometry could be something else than a box...\r\n }\r\n var geometry = new Geometry(parsedVertexData.id, scene, undefined, parsedVertexData.updatable);\r\n if (Tags) {\r\n Tags.AddTagsTo(geometry, parsedVertexData.tags);\r\n }\r\n if (parsedVertexData.delayLoadingFile) {\r\n geometry.delayLoadState = 4;\r\n geometry.delayLoadingFile = rootUrl + parsedVertexData.delayLoadingFile;\r\n geometry._boundingInfo = new BoundingInfo(Vector3.FromArray(parsedVertexData.boundingBoxMinimum), Vector3.FromArray(parsedVertexData.boundingBoxMaximum));\r\n geometry._delayInfo = [];\r\n if (parsedVertexData.hasUVs) {\r\n geometry._delayInfo.push(VertexBuffer.UVKind);\r\n }\r\n if (parsedVertexData.hasUVs2) {\r\n geometry._delayInfo.push(VertexBuffer.UV2Kind);\r\n }\r\n if (parsedVertexData.hasUVs3) {\r\n geometry._delayInfo.push(VertexBuffer.UV3Kind);\r\n }\r\n if (parsedVertexData.hasUVs4) {\r\n geometry._delayInfo.push(VertexBuffer.UV4Kind);\r\n }\r\n if (parsedVertexData.hasUVs5) {\r\n geometry._delayInfo.push(VertexBuffer.UV5Kind);\r\n }\r\n if (parsedVertexData.hasUVs6) {\r\n geometry._delayInfo.push(VertexBuffer.UV6Kind);\r\n }\r\n if (parsedVertexData.hasColors) {\r\n geometry._delayInfo.push(VertexBuffer.ColorKind);\r\n }\r\n if (parsedVertexData.hasMatricesIndices) {\r\n geometry._delayInfo.push(VertexBuffer.MatricesIndicesKind);\r\n }\r\n if (parsedVertexData.hasMatricesWeights) {\r\n geometry._delayInfo.push(VertexBuffer.MatricesWeightsKind);\r\n }\r\n geometry._delayLoadingFunction = VertexData.ImportVertexData;\r\n }\r\n else {\r\n VertexData.ImportVertexData(parsedVertexData, geometry);\r\n }\r\n scene.pushGeometry(geometry, true);\r\n return geometry;\r\n };\r\n return Geometry;\r\n}());\r\nexport { Geometry };\r\n//# sourceMappingURL=geometry.js.map","/**\r\n * Class used to represent a specific level of detail of a mesh\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_lod\r\n */\r\nvar MeshLODLevel = /** @class */ (function () {\r\n /**\r\n * Creates a new LOD level\r\n * @param distance defines the distance where this level should star being displayed\r\n * @param mesh defines the mesh to use to render this level\r\n */\r\n function MeshLODLevel(\r\n /** Defines the distance where this level should start being displayed */\r\n distance, \r\n /** Defines the mesh to use to render this level */\r\n mesh) {\r\n this.distance = distance;\r\n this.mesh = mesh;\r\n }\r\n return MeshLODLevel;\r\n}());\r\nexport { MeshLODLevel };\r\n//# sourceMappingURL=meshLODLevel.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { Tools, AsyncLoop } from \"../Misc/tools\";\r\nimport { DeepCopier } from \"../Misc/deepCopier\";\r\nimport { Tags } from \"../Misc/tags\";\r\nimport { Quaternion, Matrix, Vector3, Vector2 } from \"../Maths/math.vector\";\r\nimport { Color3 } from '../Maths/math.color';\r\nimport { Node } from \"../node\";\r\nimport { VertexBuffer } from \"./buffer\";\r\nimport { VertexData } from \"./mesh.vertexData\";\r\nimport { Buffer } from \"./buffer\";\r\nimport { Geometry } from \"./geometry\";\r\nimport { AbstractMesh } from \"./abstractMesh\";\r\nimport { SubMesh } from \"./subMesh\";\r\nimport { BoundingInfo } from \"../Culling/boundingInfo\";\r\nimport { Material } from \"../Materials/material\";\r\nimport { MultiMaterial } from \"../Materials/multiMaterial\";\r\nimport { SceneLoaderFlags } from \"../Loading/sceneLoaderFlags\";\r\nimport { SerializationHelper } from \"../Misc/decorators\";\r\nimport { Logger } from \"../Misc/logger\";\r\nimport { _TypeStore } from '../Misc/typeStore';\r\nimport { _DevTools } from '../Misc/devTools';\r\nimport { SceneComponentConstants } from \"../sceneComponent\";\r\nimport { MeshLODLevel } from './meshLODLevel';\r\nimport { CanvasGenerator } from '../Misc/canvasGenerator';\r\n/**\r\n * @hidden\r\n **/\r\nvar _CreationDataStorage = /** @class */ (function () {\r\n function _CreationDataStorage() {\r\n }\r\n return _CreationDataStorage;\r\n}());\r\nexport { _CreationDataStorage };\r\n/**\r\n * @hidden\r\n **/\r\nvar _InstanceDataStorage = /** @class */ (function () {\r\n function _InstanceDataStorage() {\r\n this.visibleInstances = {};\r\n this.batchCache = new _InstancesBatch();\r\n this.instancesBufferSize = 32 * 16 * 4; // let's start with a maximum of 32 instances\r\n }\r\n return _InstanceDataStorage;\r\n}());\r\n/**\r\n * @hidden\r\n **/\r\nvar _InstancesBatch = /** @class */ (function () {\r\n function _InstancesBatch() {\r\n this.mustReturn = false;\r\n this.visibleInstances = new Array();\r\n this.renderSelf = new Array();\r\n this.hardwareInstancedRendering = new Array();\r\n }\r\n return _InstancesBatch;\r\n}());\r\nexport { _InstancesBatch };\r\n/**\r\n * @hidden\r\n **/\r\nvar _InternalMeshDataInfo = /** @class */ (function () {\r\n function _InternalMeshDataInfo() {\r\n this._areNormalsFrozen = false; // Will be used by ribbons mainly\r\n // Will be used to save a source mesh reference, If any\r\n this._source = null;\r\n // Will be used to for fast cloned mesh lookup\r\n this.meshMap = null;\r\n this._preActivateId = -1;\r\n this._LODLevels = new Array();\r\n // Morph\r\n this._morphTargetManager = null;\r\n }\r\n return _InternalMeshDataInfo;\r\n}());\r\n/**\r\n * Class used to represent renderable models\r\n */\r\nvar Mesh = /** @class */ (function (_super) {\r\n __extends(Mesh, _super);\r\n /**\r\n * @constructor\r\n * @param name The value used by scene.getMeshByName() to do a lookup.\r\n * @param scene The scene to add this mesh to.\r\n * @param parent The parent of this mesh, if it has one\r\n * @param source An optional Mesh from which geometry is shared, cloned.\r\n * @param doNotCloneChildren When cloning, skip cloning child meshes of source, default False.\r\n * When false, achieved by calling a clone(), also passing False.\r\n * This will make creation of children, recursive.\r\n * @param clonePhysicsImpostor When cloning, include cloning mesh physics impostor, default True.\r\n */\r\n function Mesh(name, scene, parent, source, doNotCloneChildren, clonePhysicsImpostor) {\r\n if (scene === void 0) { scene = null; }\r\n if (parent === void 0) { parent = null; }\r\n if (source === void 0) { source = null; }\r\n if (clonePhysicsImpostor === void 0) { clonePhysicsImpostor = true; }\r\n var _this = _super.call(this, name, scene) || this;\r\n // Internal data\r\n _this._internalMeshDataInfo = new _InternalMeshDataInfo();\r\n // Members\r\n /**\r\n * Gets the delay loading state of the mesh (when delay loading is turned on)\r\n * @see http://doc.babylonjs.com/how_to/using_the_incremental_loading_system\r\n */\r\n _this.delayLoadState = 0;\r\n /**\r\n * Gets the list of instances created from this mesh\r\n * it is not supposed to be modified manually.\r\n * Note also that the order of the InstancedMesh wihin the array is not significant and might change.\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_instances\r\n */\r\n _this.instances = new Array();\r\n // Private\r\n /** @hidden */\r\n _this._creationDataStorage = null;\r\n /** @hidden */\r\n _this._geometry = null;\r\n /** @hidden */\r\n _this._instanceDataStorage = new _InstanceDataStorage();\r\n _this._effectiveMaterial = null;\r\n /** @hidden */\r\n _this._shouldGenerateFlatShading = false;\r\n // Use by builder only to know what orientation were the mesh build in.\r\n /** @hidden */\r\n _this._originalBuilderSideOrientation = Mesh.DEFAULTSIDE;\r\n /**\r\n * Use this property to change the original side orientation defined at construction time\r\n */\r\n _this.overrideMaterialSideOrientation = null;\r\n scene = _this.getScene();\r\n if (source) {\r\n // Geometry\r\n if (source._geometry) {\r\n source._geometry.applyToMesh(_this);\r\n }\r\n // Deep copy\r\n DeepCopier.DeepCopy(source, _this, [\"name\", \"material\", \"skeleton\", \"instances\", \"parent\", \"uniqueId\",\r\n \"source\", \"metadata\", \"hasLODLevels\", \"geometry\", \"isBlocked\", \"areNormalsFrozen\",\r\n \"onBeforeDrawObservable\", \"onBeforeRenderObservable\", \"onAfterRenderObservable\", \"onBeforeDraw\",\r\n \"onAfterWorldMatrixUpdateObservable\", \"onCollideObservable\", \"onCollisionPositionChangeObservable\", \"onRebuildObservable\",\r\n \"onDisposeObservable\", \"lightSources\", \"morphTargetManager\"\r\n ], [\"_poseMatrix\"]);\r\n // Source mesh\r\n _this._internalMeshDataInfo._source = source;\r\n if (scene.useClonedMeshMap) {\r\n if (!source._internalMeshDataInfo.meshMap) {\r\n source._internalMeshDataInfo.meshMap = {};\r\n }\r\n source._internalMeshDataInfo.meshMap[_this.uniqueId] = _this;\r\n }\r\n // Construction Params\r\n // Clone parameters allowing mesh to be updated in case of parametric shapes.\r\n _this._originalBuilderSideOrientation = source._originalBuilderSideOrientation;\r\n _this._creationDataStorage = source._creationDataStorage;\r\n // Animation ranges\r\n if (source._ranges) {\r\n var ranges = source._ranges;\r\n for (var name in ranges) {\r\n if (!ranges.hasOwnProperty(name)) {\r\n continue;\r\n }\r\n if (!ranges[name]) {\r\n continue;\r\n }\r\n _this.createAnimationRange(name, ranges[name].from, ranges[name].to);\r\n }\r\n }\r\n // Metadata\r\n if (source.metadata && source.metadata.clone) {\r\n _this.metadata = source.metadata.clone();\r\n }\r\n else {\r\n _this.metadata = source.metadata;\r\n }\r\n // Tags\r\n if (Tags && Tags.HasTags(source)) {\r\n Tags.AddTagsTo(_this, Tags.GetTags(source, true));\r\n }\r\n // Parent\r\n _this.parent = source.parent;\r\n // Pivot\r\n _this.setPivotMatrix(source.getPivotMatrix());\r\n _this.id = name + \".\" + source.id;\r\n // Material\r\n _this.material = source.material;\r\n var index;\r\n if (!doNotCloneChildren) {\r\n // Children\r\n var directDescendants = source.getDescendants(true);\r\n for (var index_1 = 0; index_1 < directDescendants.length; index_1++) {\r\n var child = directDescendants[index_1];\r\n if (child.clone) {\r\n child.clone(name + \".\" + child.name, _this);\r\n }\r\n }\r\n }\r\n // Morphs\r\n if (source.morphTargetManager) {\r\n _this.morphTargetManager = source.morphTargetManager;\r\n }\r\n // Physics clone\r\n if (scene.getPhysicsEngine) {\r\n var physicsEngine = scene.getPhysicsEngine();\r\n if (clonePhysicsImpostor && physicsEngine) {\r\n var impostor = physicsEngine.getImpostorForPhysicsObject(source);\r\n if (impostor) {\r\n _this.physicsImpostor = impostor.clone(_this);\r\n }\r\n }\r\n }\r\n // Particles\r\n for (index = 0; index < scene.particleSystems.length; index++) {\r\n var system = scene.particleSystems[index];\r\n if (system.emitter === source) {\r\n system.clone(system.name, _this);\r\n }\r\n }\r\n _this.refreshBoundingInfo();\r\n _this.computeWorldMatrix(true);\r\n }\r\n // Parent\r\n if (parent !== null) {\r\n _this.parent = parent;\r\n }\r\n _this._instanceDataStorage.hardwareInstancedRendering = _this.getEngine().getCaps().instancedArrays;\r\n return _this;\r\n }\r\n /**\r\n * Gets the default side orientation.\r\n * @param orientation the orientation to value to attempt to get\r\n * @returns the default orientation\r\n * @hidden\r\n */\r\n Mesh._GetDefaultSideOrientation = function (orientation) {\r\n return orientation || Mesh.FRONTSIDE; // works as Mesh.FRONTSIDE is 0\r\n };\r\n Object.defineProperty(Mesh.prototype, \"onBeforeRenderObservable\", {\r\n /**\r\n * An event triggered before rendering the mesh\r\n */\r\n get: function () {\r\n if (!this._internalMeshDataInfo._onBeforeRenderObservable) {\r\n this._internalMeshDataInfo._onBeforeRenderObservable = new Observable();\r\n }\r\n return this._internalMeshDataInfo._onBeforeRenderObservable;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"onBeforeBindObservable\", {\r\n /**\r\n * An event triggered before binding the mesh\r\n */\r\n get: function () {\r\n if (!this._internalMeshDataInfo._onBeforeBindObservable) {\r\n this._internalMeshDataInfo._onBeforeBindObservable = new Observable();\r\n }\r\n return this._internalMeshDataInfo._onBeforeBindObservable;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"onAfterRenderObservable\", {\r\n /**\r\n * An event triggered after rendering the mesh\r\n */\r\n get: function () {\r\n if (!this._internalMeshDataInfo._onAfterRenderObservable) {\r\n this._internalMeshDataInfo._onAfterRenderObservable = new Observable();\r\n }\r\n return this._internalMeshDataInfo._onAfterRenderObservable;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"onBeforeDrawObservable\", {\r\n /**\r\n * An event triggered before drawing the mesh\r\n */\r\n get: function () {\r\n if (!this._internalMeshDataInfo._onBeforeDrawObservable) {\r\n this._internalMeshDataInfo._onBeforeDrawObservable = new Observable();\r\n }\r\n return this._internalMeshDataInfo._onBeforeDrawObservable;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"onBeforeDraw\", {\r\n /**\r\n * Sets a callback to call before drawing the mesh. It is recommended to use onBeforeDrawObservable instead\r\n */\r\n set: function (callback) {\r\n if (this._onBeforeDrawObserver) {\r\n this.onBeforeDrawObservable.remove(this._onBeforeDrawObserver);\r\n }\r\n this._onBeforeDrawObserver = this.onBeforeDrawObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"hasInstances\", {\r\n get: function () {\r\n return this.instances.length > 0;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"morphTargetManager\", {\r\n /**\r\n * Gets or sets the morph target manager\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_morphtargets\r\n */\r\n get: function () {\r\n return this._internalMeshDataInfo._morphTargetManager;\r\n },\r\n set: function (value) {\r\n if (this._internalMeshDataInfo._morphTargetManager === value) {\r\n return;\r\n }\r\n this._internalMeshDataInfo._morphTargetManager = value;\r\n this._syncGeometryWithMorphTargetManager();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"source\", {\r\n /**\r\n * Gets the source mesh (the one used to clone this one from)\r\n */\r\n get: function () {\r\n return this._internalMeshDataInfo._source;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"isUnIndexed\", {\r\n /**\r\n * Gets or sets a boolean indicating that this mesh does not use index buffer\r\n */\r\n get: function () {\r\n return this._unIndexed;\r\n },\r\n set: function (value) {\r\n if (this._unIndexed !== value) {\r\n this._unIndexed = value;\r\n this._markSubMeshesAsAttributesDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"worldMatrixInstancedBuffer\", {\r\n /** Gets the array buffer used to store the instanced buffer used for instances' world matrices */\r\n get: function () {\r\n return this._instanceDataStorage.instancesData;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"manualUpdateOfWorldMatrixInstancedBuffer\", {\r\n /** Gets or sets a boolean indicating that the update of the instance buffer of the world matrices is manual */\r\n get: function () {\r\n return this._instanceDataStorage.manualUpdate;\r\n },\r\n set: function (value) {\r\n this._instanceDataStorage.manualUpdate = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n // Methods\r\n Mesh.prototype.instantiateHierarchy = function (newParent, options, onNewNodeCreated) {\r\n if (newParent === void 0) { newParent = null; }\r\n var instance = (this.getTotalVertices() > 0 && (!options || !options.doNotInstantiate)) ? this.createInstance(\"instance of \" + (this.name || this.id)) : this.clone(\"Clone of \" + (this.name || this.id), newParent || this.parent, true);\r\n if (instance) {\r\n instance.parent = newParent || this.parent;\r\n instance.position = this.position.clone();\r\n instance.scaling = this.scaling.clone();\r\n if (this.rotationQuaternion) {\r\n instance.rotationQuaternion = this.rotationQuaternion.clone();\r\n }\r\n else {\r\n instance.rotation = this.rotation.clone();\r\n }\r\n if (onNewNodeCreated) {\r\n onNewNodeCreated(this, instance);\r\n }\r\n }\r\n for (var _i = 0, _a = this.getChildTransformNodes(true); _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child.instantiateHierarchy(instance, options, onNewNodeCreated);\r\n }\r\n return instance;\r\n };\r\n /**\r\n * Gets the class name\r\n * @returns the string \"Mesh\".\r\n */\r\n Mesh.prototype.getClassName = function () {\r\n return \"Mesh\";\r\n };\r\n Object.defineProperty(Mesh.prototype, \"_isMesh\", {\r\n /** @hidden */\r\n get: function () {\r\n return true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Returns a description of this mesh\r\n * @param fullDetails define if full details about this mesh must be used\r\n * @returns a descriptive string representing this mesh\r\n */\r\n Mesh.prototype.toString = function (fullDetails) {\r\n var ret = _super.prototype.toString.call(this, fullDetails);\r\n ret += \", n vertices: \" + this.getTotalVertices();\r\n ret += \", parent: \" + (this._waitingParentId ? this._waitingParentId : (this.parent ? this.parent.name : \"NONE\"));\r\n if (this.animations) {\r\n for (var i = 0; i < this.animations.length; i++) {\r\n ret += \", animation[0]: \" + this.animations[i].toString(fullDetails);\r\n }\r\n }\r\n if (fullDetails) {\r\n if (this._geometry) {\r\n var ib = this.getIndices();\r\n var vb = this.getVerticesData(VertexBuffer.PositionKind);\r\n if (vb && ib) {\r\n ret += \", flat shading: \" + (vb.length / 3 === ib.length ? \"YES\" : \"NO\");\r\n }\r\n }\r\n else {\r\n ret += \", flat shading: UNKNOWN\";\r\n }\r\n }\r\n return ret;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._unBindEffect = function () {\r\n _super.prototype._unBindEffect.call(this);\r\n for (var _i = 0, _a = this.instances; _i < _a.length; _i++) {\r\n var instance = _a[_i];\r\n instance._unBindEffect();\r\n }\r\n };\r\n Object.defineProperty(Mesh.prototype, \"hasLODLevels\", {\r\n /**\r\n * Gets a boolean indicating if this mesh has LOD\r\n */\r\n get: function () {\r\n return this._internalMeshDataInfo._LODLevels.length > 0;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the list of MeshLODLevel associated with the current mesh\r\n * @returns an array of MeshLODLevel\r\n */\r\n Mesh.prototype.getLODLevels = function () {\r\n return this._internalMeshDataInfo._LODLevels;\r\n };\r\n Mesh.prototype._sortLODLevels = function () {\r\n this._internalMeshDataInfo._LODLevels.sort(function (a, b) {\r\n if (a.distance < b.distance) {\r\n return 1;\r\n }\r\n if (a.distance > b.distance) {\r\n return -1;\r\n }\r\n return 0;\r\n });\r\n };\r\n /**\r\n * Add a mesh as LOD level triggered at the given distance.\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_lod\r\n * @param distance The distance from the center of the object to show this level\r\n * @param mesh The mesh to be added as LOD level (can be null)\r\n * @return This mesh (for chaining)\r\n */\r\n Mesh.prototype.addLODLevel = function (distance, mesh) {\r\n if (mesh && mesh._masterMesh) {\r\n Logger.Warn(\"You cannot use a mesh as LOD level twice\");\r\n return this;\r\n }\r\n var level = new MeshLODLevel(distance, mesh);\r\n this._internalMeshDataInfo._LODLevels.push(level);\r\n if (mesh) {\r\n mesh._masterMesh = this;\r\n }\r\n this._sortLODLevels();\r\n return this;\r\n };\r\n /**\r\n * Returns the LOD level mesh at the passed distance or null if not found.\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_lod\r\n * @param distance The distance from the center of the object to show this level\r\n * @returns a Mesh or `null`\r\n */\r\n Mesh.prototype.getLODLevelAtDistance = function (distance) {\r\n var internalDataInfo = this._internalMeshDataInfo;\r\n for (var index = 0; index < internalDataInfo._LODLevels.length; index++) {\r\n var level = internalDataInfo._LODLevels[index];\r\n if (level.distance === distance) {\r\n return level.mesh;\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Remove a mesh from the LOD array\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_lod\r\n * @param mesh defines the mesh to be removed\r\n * @return This mesh (for chaining)\r\n */\r\n Mesh.prototype.removeLODLevel = function (mesh) {\r\n var internalDataInfo = this._internalMeshDataInfo;\r\n for (var index = 0; index < internalDataInfo._LODLevels.length; index++) {\r\n if (internalDataInfo._LODLevels[index].mesh === mesh) {\r\n internalDataInfo._LODLevels.splice(index, 1);\r\n if (mesh) {\r\n mesh._masterMesh = null;\r\n }\r\n }\r\n }\r\n this._sortLODLevels();\r\n return this;\r\n };\r\n /**\r\n * Returns the registered LOD mesh distant from the parameter `camera` position if any, else returns the current mesh.\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_lod\r\n * @param camera defines the camera to use to compute distance\r\n * @param boundingSphere defines a custom bounding sphere to use instead of the one from this mesh\r\n * @return This mesh (for chaining)\r\n */\r\n Mesh.prototype.getLOD = function (camera, boundingSphere) {\r\n var internalDataInfo = this._internalMeshDataInfo;\r\n if (!internalDataInfo._LODLevels || internalDataInfo._LODLevels.length === 0) {\r\n return this;\r\n }\r\n var bSphere;\r\n if (boundingSphere) {\r\n bSphere = boundingSphere;\r\n }\r\n else {\r\n var boundingInfo = this.getBoundingInfo();\r\n bSphere = boundingInfo.boundingSphere;\r\n }\r\n var distanceToCamera = bSphere.centerWorld.subtract(camera.globalPosition).length();\r\n if (internalDataInfo._LODLevels[internalDataInfo._LODLevels.length - 1].distance > distanceToCamera) {\r\n if (this.onLODLevelSelection) {\r\n this.onLODLevelSelection(distanceToCamera, this, this);\r\n }\r\n return this;\r\n }\r\n for (var index = 0; index < internalDataInfo._LODLevels.length; index++) {\r\n var level = internalDataInfo._LODLevels[index];\r\n if (level.distance < distanceToCamera) {\r\n if (level.mesh) {\r\n level.mesh._preActivate();\r\n level.mesh._updateSubMeshesBoundingInfo(this.worldMatrixFromCache);\r\n }\r\n if (this.onLODLevelSelection) {\r\n this.onLODLevelSelection(distanceToCamera, this, level.mesh);\r\n }\r\n return level.mesh;\r\n }\r\n }\r\n if (this.onLODLevelSelection) {\r\n this.onLODLevelSelection(distanceToCamera, this, this);\r\n }\r\n return this;\r\n };\r\n Object.defineProperty(Mesh.prototype, \"geometry\", {\r\n /**\r\n * Gets the mesh internal Geometry object\r\n */\r\n get: function () {\r\n return this._geometry;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Returns the total number of vertices within the mesh geometry or zero if the mesh has no geometry.\r\n * @returns the total number of vertices\r\n */\r\n Mesh.prototype.getTotalVertices = function () {\r\n if (this._geometry === null || this._geometry === undefined) {\r\n return 0;\r\n }\r\n return this._geometry.getTotalVertices();\r\n };\r\n /**\r\n * Returns the content of an associated vertex buffer\r\n * @param kind defines which buffer to read from (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n * @param copyWhenShared defines a boolean indicating that if the mesh geometry is shared among some other meshes, the returned array is a copy of the internal one\r\n * @param forceCopy defines a boolean forcing the copy of the buffer no matter what the value of copyWhenShared is\r\n * @returns a FloatArray or null if the mesh has no geometry or no vertex buffer for this kind.\r\n */\r\n Mesh.prototype.getVerticesData = function (kind, copyWhenShared, forceCopy) {\r\n if (!this._geometry) {\r\n return null;\r\n }\r\n return this._geometry.getVerticesData(kind, copyWhenShared, forceCopy);\r\n };\r\n /**\r\n * Returns the mesh VertexBuffer object from the requested `kind`\r\n * @param kind defines which buffer to read from (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.NormalKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n * @returns a FloatArray or null if the mesh has no vertex buffer for this kind.\r\n */\r\n Mesh.prototype.getVertexBuffer = function (kind) {\r\n if (!this._geometry) {\r\n return null;\r\n }\r\n return this._geometry.getVertexBuffer(kind);\r\n };\r\n /**\r\n * Tests if a specific vertex buffer is associated with this mesh\r\n * @param kind defines which buffer to check (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.NormalKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n * @returns a boolean\r\n */\r\n Mesh.prototype.isVerticesDataPresent = function (kind) {\r\n if (!this._geometry) {\r\n if (this._delayInfo) {\r\n return this._delayInfo.indexOf(kind) !== -1;\r\n }\r\n return false;\r\n }\r\n return this._geometry.isVerticesDataPresent(kind);\r\n };\r\n /**\r\n * Returns a boolean defining if the vertex data for the requested `kind` is updatable.\r\n * @param kind defines which buffer to check (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n * @returns a boolean\r\n */\r\n Mesh.prototype.isVertexBufferUpdatable = function (kind) {\r\n if (!this._geometry) {\r\n if (this._delayInfo) {\r\n return this._delayInfo.indexOf(kind) !== -1;\r\n }\r\n return false;\r\n }\r\n return this._geometry.isVertexBufferUpdatable(kind);\r\n };\r\n /**\r\n * Returns a string which contains the list of existing `kinds` of Vertex Data associated with this mesh.\r\n * @param kind defines which buffer to read from (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.NormalKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n * @returns an array of strings\r\n */\r\n Mesh.prototype.getVerticesDataKinds = function () {\r\n if (!this._geometry) {\r\n var result = new Array();\r\n if (this._delayInfo) {\r\n this._delayInfo.forEach(function (kind) {\r\n result.push(kind);\r\n });\r\n }\r\n return result;\r\n }\r\n return this._geometry.getVerticesDataKinds();\r\n };\r\n /**\r\n * Returns a positive integer : the total number of indices in this mesh geometry.\r\n * @returns the numner of indices or zero if the mesh has no geometry.\r\n */\r\n Mesh.prototype.getTotalIndices = function () {\r\n if (!this._geometry) {\r\n return 0;\r\n }\r\n return this._geometry.getTotalIndices();\r\n };\r\n /**\r\n * Returns an array of integers or a typed array (Int32Array, Uint32Array, Uint16Array) populated with the mesh indices.\r\n * @param copyWhenShared If true (default false) and and if the mesh geometry is shared among some other meshes, the returned array is a copy of the internal one.\r\n * @param forceCopy defines a boolean indicating that the returned array must be cloned upon returning it\r\n * @returns the indices array or an empty array if the mesh has no geometry\r\n */\r\n Mesh.prototype.getIndices = function (copyWhenShared, forceCopy) {\r\n if (!this._geometry) {\r\n return [];\r\n }\r\n return this._geometry.getIndices(copyWhenShared, forceCopy);\r\n };\r\n Object.defineProperty(Mesh.prototype, \"isBlocked\", {\r\n get: function () {\r\n return this._masterMesh !== null && this._masterMesh !== undefined;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Determine if the current mesh is ready to be rendered\r\n * @param completeCheck defines if a complete check (including materials and lights) has to be done (false by default)\r\n * @param forceInstanceSupport will check if the mesh will be ready when used with instances (false by default)\r\n * @returns true if all associated assets are ready (material, textures, shaders)\r\n */\r\n Mesh.prototype.isReady = function (completeCheck, forceInstanceSupport) {\r\n if (completeCheck === void 0) { completeCheck = false; }\r\n if (forceInstanceSupport === void 0) { forceInstanceSupport = false; }\r\n if (this.delayLoadState === 2) {\r\n return false;\r\n }\r\n if (!_super.prototype.isReady.call(this, completeCheck)) {\r\n return false;\r\n }\r\n if (!this.subMeshes || this.subMeshes.length === 0) {\r\n return true;\r\n }\r\n if (!completeCheck) {\r\n return true;\r\n }\r\n var engine = this.getEngine();\r\n var scene = this.getScene();\r\n var hardwareInstancedRendering = forceInstanceSupport || engine.getCaps().instancedArrays && this.instances.length > 0;\r\n this.computeWorldMatrix();\r\n var mat = this.material || scene.defaultMaterial;\r\n if (mat) {\r\n if (mat._storeEffectOnSubMeshes) {\r\n for (var _i = 0, _a = this.subMeshes; _i < _a.length; _i++) {\r\n var subMesh = _a[_i];\r\n var effectiveMaterial = subMesh.getMaterial();\r\n if (effectiveMaterial) {\r\n if (effectiveMaterial._storeEffectOnSubMeshes) {\r\n if (!effectiveMaterial.isReadyForSubMesh(this, subMesh, hardwareInstancedRendering)) {\r\n return false;\r\n }\r\n }\r\n else {\r\n if (!effectiveMaterial.isReady(this, hardwareInstancedRendering)) {\r\n return false;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n if (!mat.isReady(this, hardwareInstancedRendering)) {\r\n return false;\r\n }\r\n }\r\n }\r\n // Shadows\r\n for (var _b = 0, _c = this.lightSources; _b < _c.length; _b++) {\r\n var light = _c[_b];\r\n var generator = light.getShadowGenerator();\r\n if (generator) {\r\n for (var _d = 0, _e = this.subMeshes; _d < _e.length; _d++) {\r\n var subMesh = _e[_d];\r\n if (!generator.isReady(subMesh, hardwareInstancedRendering)) {\r\n return false;\r\n }\r\n }\r\n }\r\n }\r\n // LOD\r\n for (var _f = 0, _g = this._internalMeshDataInfo._LODLevels; _f < _g.length; _f++) {\r\n var lod = _g[_f];\r\n if (lod.mesh && !lod.mesh.isReady(hardwareInstancedRendering)) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n Object.defineProperty(Mesh.prototype, \"areNormalsFrozen\", {\r\n /**\r\n * Gets a boolean indicating if the normals aren't to be recomputed on next mesh `positions` array update. This property is pertinent only for updatable parametric shapes.\r\n */\r\n get: function () {\r\n return this._internalMeshDataInfo._areNormalsFrozen;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * This function affects parametric shapes on vertex position update only : ribbons, tubes, etc. It has no effect at all on other shapes. It prevents the mesh normals from being recomputed on next `positions` array update.\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.freezeNormals = function () {\r\n this._internalMeshDataInfo._areNormalsFrozen = true;\r\n return this;\r\n };\r\n /**\r\n * This function affects parametric shapes on vertex position update only : ribbons, tubes, etc. It has no effect at all on other shapes. It reactivates the mesh normals computation if it was previously frozen\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.unfreezeNormals = function () {\r\n this._internalMeshDataInfo._areNormalsFrozen = false;\r\n return this;\r\n };\r\n Object.defineProperty(Mesh.prototype, \"overridenInstanceCount\", {\r\n /**\r\n * Sets a value overriding the instance count. Only applicable when custom instanced InterleavedVertexBuffer are used rather than InstancedMeshs\r\n */\r\n set: function (count) {\r\n this._instanceDataStorage.overridenInstanceCount = count;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n // Methods\r\n /** @hidden */\r\n Mesh.prototype._preActivate = function () {\r\n var internalDataInfo = this._internalMeshDataInfo;\r\n var sceneRenderId = this.getScene().getRenderId();\r\n if (internalDataInfo._preActivateId === sceneRenderId) {\r\n return this;\r\n }\r\n internalDataInfo._preActivateId = sceneRenderId;\r\n this._instanceDataStorage.visibleInstances = null;\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._preActivateForIntermediateRendering = function (renderId) {\r\n if (this._instanceDataStorage.visibleInstances) {\r\n this._instanceDataStorage.visibleInstances.intermediateDefaultRenderId = renderId;\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._registerInstanceForRenderId = function (instance, renderId) {\r\n if (!this._instanceDataStorage.visibleInstances) {\r\n this._instanceDataStorage.visibleInstances = {\r\n defaultRenderId: renderId,\r\n selfDefaultRenderId: this._renderId\r\n };\r\n }\r\n if (!this._instanceDataStorage.visibleInstances[renderId]) {\r\n this._instanceDataStorage.visibleInstances[renderId] = new Array();\r\n }\r\n this._instanceDataStorage.visibleInstances[renderId].push(instance);\r\n return this;\r\n };\r\n /**\r\n * This method recomputes and sets a new BoundingInfo to the mesh unless it is locked.\r\n * This means the mesh underlying bounding box and sphere are recomputed.\r\n * @param applySkeleton defines whether to apply the skeleton before computing the bounding info\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.refreshBoundingInfo = function (applySkeleton) {\r\n if (applySkeleton === void 0) { applySkeleton = false; }\r\n if (this._boundingInfo && this._boundingInfo.isLocked) {\r\n return this;\r\n }\r\n var bias = this.geometry ? this.geometry.boundingBias : null;\r\n this._refreshBoundingInfo(this._getPositionData(applySkeleton), bias);\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._createGlobalSubMesh = function (force) {\r\n var totalVertices = this.getTotalVertices();\r\n if (!totalVertices || !this.getIndices()) {\r\n return null;\r\n }\r\n // Check if we need to recreate the submeshes\r\n if (this.subMeshes && this.subMeshes.length > 0) {\r\n var ib = this.getIndices();\r\n if (!ib) {\r\n return null;\r\n }\r\n var totalIndices = ib.length;\r\n var needToRecreate = false;\r\n if (force) {\r\n needToRecreate = true;\r\n }\r\n else {\r\n for (var _i = 0, _a = this.subMeshes; _i < _a.length; _i++) {\r\n var submesh = _a[_i];\r\n if (submesh.indexStart + submesh.indexCount >= totalIndices) {\r\n needToRecreate = true;\r\n break;\r\n }\r\n if (submesh.verticesStart + submesh.verticesCount >= totalVertices) {\r\n needToRecreate = true;\r\n break;\r\n }\r\n }\r\n }\r\n if (!needToRecreate) {\r\n return this.subMeshes[0];\r\n }\r\n }\r\n this.releaseSubMeshes();\r\n return new SubMesh(0, 0, totalVertices, 0, this.getTotalIndices(), this);\r\n };\r\n /**\r\n * This function will subdivide the mesh into multiple submeshes\r\n * @param count defines the expected number of submeshes\r\n */\r\n Mesh.prototype.subdivide = function (count) {\r\n if (count < 1) {\r\n return;\r\n }\r\n var totalIndices = this.getTotalIndices();\r\n var subdivisionSize = (totalIndices / count) | 0;\r\n var offset = 0;\r\n // Ensure that subdivisionSize is a multiple of 3\r\n while (subdivisionSize % 3 !== 0) {\r\n subdivisionSize++;\r\n }\r\n this.releaseSubMeshes();\r\n for (var index = 0; index < count; index++) {\r\n if (offset >= totalIndices) {\r\n break;\r\n }\r\n SubMesh.CreateFromIndices(0, offset, Math.min(subdivisionSize, totalIndices - offset), this);\r\n offset += subdivisionSize;\r\n }\r\n this.synchronizeInstances();\r\n };\r\n /**\r\n * Copy a FloatArray into a specific associated vertex buffer\r\n * @param kind defines which buffer to write to (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n * @param data defines the data source\r\n * @param updatable defines if the updated vertex buffer must be flagged as updatable\r\n * @param stride defines the data stride size (can be null)\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.setVerticesData = function (kind, data, updatable, stride) {\r\n if (updatable === void 0) { updatable = false; }\r\n if (!this._geometry) {\r\n var vertexData = new VertexData();\r\n vertexData.set(data, kind);\r\n var scene = this.getScene();\r\n new Geometry(Geometry.RandomId(), scene, vertexData, updatable, this);\r\n }\r\n else {\r\n this._geometry.setVerticesData(kind, data, updatable, stride);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Delete a vertex buffer associated with this mesh\r\n * @param kind defines which buffer to delete (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n */\r\n Mesh.prototype.removeVerticesData = function (kind) {\r\n if (!this._geometry) {\r\n return;\r\n }\r\n this._geometry.removeVerticesData(kind);\r\n };\r\n /**\r\n * Flags an associated vertex buffer as updatable\r\n * @param kind defines which buffer to use (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n * @param updatable defines if the updated vertex buffer must be flagged as updatable\r\n */\r\n Mesh.prototype.markVerticesDataAsUpdatable = function (kind, updatable) {\r\n if (updatable === void 0) { updatable = true; }\r\n var vb = this.getVertexBuffer(kind);\r\n if (!vb || vb.isUpdatable() === updatable) {\r\n return;\r\n }\r\n this.setVerticesData(kind, this.getVerticesData(kind), updatable);\r\n };\r\n /**\r\n * Sets the mesh global Vertex Buffer\r\n * @param buffer defines the buffer to use\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.setVerticesBuffer = function (buffer) {\r\n if (!this._geometry) {\r\n this._geometry = Geometry.CreateGeometryForMesh(this);\r\n }\r\n this._geometry.setVerticesBuffer(buffer);\r\n return this;\r\n };\r\n /**\r\n * Update a specific associated vertex buffer\r\n * @param kind defines which buffer to write to (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n * @param data defines the data source\r\n * @param updateExtends defines if extends info of the mesh must be updated (can be null). This is mostly useful for \"position\" kind\r\n * @param makeItUnique defines if the geometry associated with the mesh must be cloned to make the change only for this mesh (and not all meshes associated with the same geometry)\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.updateVerticesData = function (kind, data, updateExtends, makeItUnique) {\r\n if (!this._geometry) {\r\n return this;\r\n }\r\n if (!makeItUnique) {\r\n this._geometry.updateVerticesData(kind, data, updateExtends);\r\n }\r\n else {\r\n this.makeGeometryUnique();\r\n this.updateVerticesData(kind, data, updateExtends, false);\r\n }\r\n return this;\r\n };\r\n /**\r\n * This method updates the vertex positions of an updatable mesh according to the `positionFunction` returned values.\r\n * @see http://doc.babylonjs.com/how_to/how_to_dynamically_morph_a_mesh#other-shapes-updatemeshpositions\r\n * @param positionFunction is a simple JS function what is passed the mesh `positions` array. It doesn't need to return anything\r\n * @param computeNormals is a boolean (default true) to enable/disable the mesh normal recomputation after the vertex position update\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.updateMeshPositions = function (positionFunction, computeNormals) {\r\n if (computeNormals === void 0) { computeNormals = true; }\r\n var positions = this.getVerticesData(VertexBuffer.PositionKind);\r\n if (!positions) {\r\n return this;\r\n }\r\n positionFunction(positions);\r\n this.updateVerticesData(VertexBuffer.PositionKind, positions, false, false);\r\n if (computeNormals) {\r\n var indices = this.getIndices();\r\n var normals = this.getVerticesData(VertexBuffer.NormalKind);\r\n if (!normals) {\r\n return this;\r\n }\r\n VertexData.ComputeNormals(positions, indices, normals);\r\n this.updateVerticesData(VertexBuffer.NormalKind, normals, false, false);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Creates a un-shared specific occurence of the geometry for the mesh.\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.makeGeometryUnique = function () {\r\n if (!this._geometry) {\r\n return this;\r\n }\r\n var oldGeometry = this._geometry;\r\n var geometry = this._geometry.copy(Geometry.RandomId());\r\n oldGeometry.releaseForMesh(this, true);\r\n geometry.applyToMesh(this);\r\n return this;\r\n };\r\n /**\r\n * Set the index buffer of this mesh\r\n * @param indices defines the source data\r\n * @param totalVertices defines the total number of vertices referenced by this index data (can be null)\r\n * @param updatable defines if the updated index buffer must be flagged as updatable (default is false)\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.setIndices = function (indices, totalVertices, updatable) {\r\n if (totalVertices === void 0) { totalVertices = null; }\r\n if (updatable === void 0) { updatable = false; }\r\n if (!this._geometry) {\r\n var vertexData = new VertexData();\r\n vertexData.indices = indices;\r\n var scene = this.getScene();\r\n new Geometry(Geometry.RandomId(), scene, vertexData, updatable, this);\r\n }\r\n else {\r\n this._geometry.setIndices(indices, totalVertices, updatable);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Update the current index buffer\r\n * @param indices defines the source data\r\n * @param offset defines the offset in the index buffer where to store the new data (can be null)\r\n * @param gpuMemoryOnly defines a boolean indicating that only the GPU memory must be updated leaving the CPU version of the indices unchanged (false by default)\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.updateIndices = function (indices, offset, gpuMemoryOnly) {\r\n if (gpuMemoryOnly === void 0) { gpuMemoryOnly = false; }\r\n if (!this._geometry) {\r\n return this;\r\n }\r\n this._geometry.updateIndices(indices, offset, gpuMemoryOnly);\r\n return this;\r\n };\r\n /**\r\n * Invert the geometry to move from a right handed system to a left handed one.\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.toLeftHanded = function () {\r\n if (!this._geometry) {\r\n return this;\r\n }\r\n this._geometry.toLeftHanded();\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._bind = function (subMesh, effect, fillMode) {\r\n if (!this._geometry) {\r\n return this;\r\n }\r\n var engine = this.getScene().getEngine();\r\n // Wireframe\r\n var indexToBind;\r\n if (this._unIndexed) {\r\n indexToBind = null;\r\n }\r\n else {\r\n switch (fillMode) {\r\n case Material.PointFillMode:\r\n indexToBind = null;\r\n break;\r\n case Material.WireFrameFillMode:\r\n indexToBind = subMesh._getLinesIndexBuffer(this.getIndices(), engine);\r\n break;\r\n default:\r\n case Material.TriangleFillMode:\r\n indexToBind = this._geometry.getIndexBuffer();\r\n break;\r\n }\r\n }\r\n // VBOs\r\n this._geometry._bind(effect, indexToBind);\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._draw = function (subMesh, fillMode, instancesCount) {\r\n if (!this._geometry || !this._geometry.getVertexBuffers() || (!this._unIndexed && !this._geometry.getIndexBuffer())) {\r\n return this;\r\n }\r\n if (this._internalMeshDataInfo._onBeforeDrawObservable) {\r\n this._internalMeshDataInfo._onBeforeDrawObservable.notifyObservers(this);\r\n }\r\n var scene = this.getScene();\r\n var engine = scene.getEngine();\r\n if (this._unIndexed || fillMode == Material.PointFillMode) {\r\n // or triangles as points\r\n engine.drawArraysType(fillMode, subMesh.verticesStart, subMesh.verticesCount, instancesCount);\r\n }\r\n else if (fillMode == Material.WireFrameFillMode) {\r\n // Triangles as wireframe\r\n engine.drawElementsType(fillMode, 0, subMesh._linesIndexCount, instancesCount);\r\n }\r\n else {\r\n engine.drawElementsType(fillMode, subMesh.indexStart, subMesh.indexCount, instancesCount);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Registers for this mesh a javascript function called just before the rendering process\r\n * @param func defines the function to call before rendering this mesh\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.registerBeforeRender = function (func) {\r\n this.onBeforeRenderObservable.add(func);\r\n return this;\r\n };\r\n /**\r\n * Disposes a previously registered javascript function called before the rendering\r\n * @param func defines the function to remove\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.unregisterBeforeRender = function (func) {\r\n this.onBeforeRenderObservable.removeCallback(func);\r\n return this;\r\n };\r\n /**\r\n * Registers for this mesh a javascript function called just after the rendering is complete\r\n * @param func defines the function to call after rendering this mesh\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.registerAfterRender = function (func) {\r\n this.onAfterRenderObservable.add(func);\r\n return this;\r\n };\r\n /**\r\n * Disposes a previously registered javascript function called after the rendering.\r\n * @param func defines the function to remove\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.unregisterAfterRender = function (func) {\r\n this.onAfterRenderObservable.removeCallback(func);\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._getInstancesRenderList = function (subMeshId, isReplacementMode) {\r\n if (isReplacementMode === void 0) { isReplacementMode = false; }\r\n if (this._instanceDataStorage.isFrozen && this._instanceDataStorage.previousBatch) {\r\n return this._instanceDataStorage.previousBatch;\r\n }\r\n var scene = this.getScene();\r\n var isInIntermediateRendering = scene._isInIntermediateRendering();\r\n var onlyForInstances = isInIntermediateRendering ? this._internalAbstractMeshDataInfo._onlyForInstancesIntermediate : this._internalAbstractMeshDataInfo._onlyForInstances;\r\n var batchCache = this._instanceDataStorage.batchCache;\r\n batchCache.mustReturn = false;\r\n batchCache.renderSelf[subMeshId] = isReplacementMode || (!onlyForInstances && this.isEnabled() && this.isVisible);\r\n batchCache.visibleInstances[subMeshId] = null;\r\n if (this._instanceDataStorage.visibleInstances && !isReplacementMode) {\r\n var visibleInstances = this._instanceDataStorage.visibleInstances;\r\n var currentRenderId = scene.getRenderId();\r\n var defaultRenderId = (isInIntermediateRendering ? visibleInstances.intermediateDefaultRenderId : visibleInstances.defaultRenderId);\r\n batchCache.visibleInstances[subMeshId] = visibleInstances[currentRenderId];\r\n if (!batchCache.visibleInstances[subMeshId] && defaultRenderId) {\r\n batchCache.visibleInstances[subMeshId] = visibleInstances[defaultRenderId];\r\n }\r\n }\r\n batchCache.hardwareInstancedRendering[subMeshId] =\r\n !isReplacementMode &&\r\n this._instanceDataStorage.hardwareInstancedRendering\r\n && (batchCache.visibleInstances[subMeshId] !== null)\r\n && (batchCache.visibleInstances[subMeshId] !== undefined);\r\n this._instanceDataStorage.previousBatch = batchCache;\r\n return batchCache;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._renderWithInstances = function (subMesh, fillMode, batch, effect, engine) {\r\n var visibleInstances = batch.visibleInstances[subMesh._id];\r\n if (!visibleInstances) {\r\n return this;\r\n }\r\n var instanceStorage = this._instanceDataStorage;\r\n var currentInstancesBufferSize = instanceStorage.instancesBufferSize;\r\n var instancesBuffer = instanceStorage.instancesBuffer;\r\n var matricesCount = visibleInstances.length + 1;\r\n var bufferSize = matricesCount * 16 * 4;\r\n while (instanceStorage.instancesBufferSize < bufferSize) {\r\n instanceStorage.instancesBufferSize *= 2;\r\n }\r\n if (!instanceStorage.instancesData || currentInstancesBufferSize != instanceStorage.instancesBufferSize) {\r\n instanceStorage.instancesData = new Float32Array(instanceStorage.instancesBufferSize / 4);\r\n }\r\n var offset = 0;\r\n var instancesCount = 0;\r\n var renderSelf = batch.renderSelf[subMesh._id];\r\n if (!this._instanceDataStorage.manualUpdate) {\r\n var world = this._effectiveMesh.getWorldMatrix();\r\n if (renderSelf) {\r\n world.copyToArray(instanceStorage.instancesData, offset);\r\n offset += 16;\r\n instancesCount++;\r\n }\r\n if (visibleInstances) {\r\n for (var instanceIndex = 0; instanceIndex < visibleInstances.length; instanceIndex++) {\r\n var instance = visibleInstances[instanceIndex];\r\n instance.getWorldMatrix().copyToArray(instanceStorage.instancesData, offset);\r\n offset += 16;\r\n instancesCount++;\r\n }\r\n }\r\n }\r\n else {\r\n instancesCount = (renderSelf ? 1 : 0) + visibleInstances.length;\r\n }\r\n if (!instancesBuffer || currentInstancesBufferSize != instanceStorage.instancesBufferSize) {\r\n if (instancesBuffer) {\r\n instancesBuffer.dispose();\r\n }\r\n instancesBuffer = new Buffer(engine, instanceStorage.instancesData, true, 16, false, true);\r\n instanceStorage.instancesBuffer = instancesBuffer;\r\n this.setVerticesBuffer(instancesBuffer.createVertexBuffer(\"world0\", 0, 4));\r\n this.setVerticesBuffer(instancesBuffer.createVertexBuffer(\"world1\", 4, 4));\r\n this.setVerticesBuffer(instancesBuffer.createVertexBuffer(\"world2\", 8, 4));\r\n this.setVerticesBuffer(instancesBuffer.createVertexBuffer(\"world3\", 12, 4));\r\n }\r\n else {\r\n instancesBuffer.updateDirectly(instanceStorage.instancesData, 0, instancesCount);\r\n }\r\n this._processInstancedBuffers(visibleInstances, renderSelf);\r\n // Stats\r\n this.getScene()._activeIndices.addCount(subMesh.indexCount * instancesCount, false);\r\n // Draw\r\n this._bind(subMesh, effect, fillMode);\r\n this._draw(subMesh, fillMode, instancesCount);\r\n engine.unbindInstanceAttributes();\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._processInstancedBuffers = function (visibleInstances, renderSelf) {\r\n // Do nothing\r\n };\r\n /** @hidden */\r\n Mesh.prototype._processRendering = function (subMesh, effect, fillMode, batch, hardwareInstancedRendering, onBeforeDraw, effectiveMaterial) {\r\n var scene = this.getScene();\r\n var engine = scene.getEngine();\r\n if (hardwareInstancedRendering) {\r\n this._renderWithInstances(subMesh, fillMode, batch, effect, engine);\r\n }\r\n else {\r\n var instanceCount = 0;\r\n if (batch.renderSelf[subMesh._id]) {\r\n // Draw\r\n if (onBeforeDraw) {\r\n onBeforeDraw(false, this._effectiveMesh.getWorldMatrix(), effectiveMaterial);\r\n }\r\n instanceCount++;\r\n this._draw(subMesh, fillMode, this._instanceDataStorage.overridenInstanceCount);\r\n }\r\n var visibleInstancesForSubMesh = batch.visibleInstances[subMesh._id];\r\n if (visibleInstancesForSubMesh) {\r\n var visibleInstanceCount = visibleInstancesForSubMesh.length;\r\n instanceCount += visibleInstanceCount;\r\n // Stats\r\n for (var instanceIndex = 0; instanceIndex < visibleInstanceCount; instanceIndex++) {\r\n var instance = visibleInstancesForSubMesh[instanceIndex];\r\n // World\r\n var world = instance.getWorldMatrix();\r\n if (onBeforeDraw) {\r\n onBeforeDraw(true, world, effectiveMaterial);\r\n }\r\n // Draw\r\n this._draw(subMesh, fillMode);\r\n }\r\n }\r\n // Stats\r\n scene._activeIndices.addCount(subMesh.indexCount * instanceCount, false);\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._rebuild = function () {\r\n if (this._instanceDataStorage.instancesBuffer) {\r\n // Dispose instance buffer to be recreated in _renderWithInstances when rendered\r\n this._instanceDataStorage.instancesBuffer.dispose();\r\n this._instanceDataStorage.instancesBuffer = null;\r\n }\r\n _super.prototype._rebuild.call(this);\r\n };\r\n /** @hidden */\r\n Mesh.prototype._freeze = function () {\r\n if (!this.subMeshes) {\r\n return;\r\n }\r\n // Prepare batches\r\n for (var index = 0; index < this.subMeshes.length; index++) {\r\n this._getInstancesRenderList(index);\r\n }\r\n this._effectiveMaterial = null;\r\n this._instanceDataStorage.isFrozen = true;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._unFreeze = function () {\r\n this._instanceDataStorage.isFrozen = false;\r\n this._instanceDataStorage.previousBatch = null;\r\n };\r\n /**\r\n * Triggers the draw call for the mesh. Usually, you don't need to call this method by your own because the mesh rendering is handled by the scene rendering manager\r\n * @param subMesh defines the subMesh to render\r\n * @param enableAlphaMode defines if alpha mode can be changed\r\n * @param effectiveMeshReplacement defines an optional mesh used to provide info for the rendering\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.render = function (subMesh, enableAlphaMode, effectiveMeshReplacement) {\r\n var scene = this.getScene();\r\n if (this._internalAbstractMeshDataInfo._isActiveIntermediate) {\r\n this._internalAbstractMeshDataInfo._isActiveIntermediate = false;\r\n }\r\n else {\r\n this._internalAbstractMeshDataInfo._isActive = false;\r\n }\r\n if (this._checkOcclusionQuery()) {\r\n return this;\r\n }\r\n // Managing instances\r\n var batch = this._getInstancesRenderList(subMesh._id, !!effectiveMeshReplacement);\r\n if (batch.mustReturn) {\r\n return this;\r\n }\r\n // Checking geometry state\r\n if (!this._geometry || !this._geometry.getVertexBuffers() || (!this._unIndexed && !this._geometry.getIndexBuffer())) {\r\n return this;\r\n }\r\n if (this._internalMeshDataInfo._onBeforeRenderObservable) {\r\n this._internalMeshDataInfo._onBeforeRenderObservable.notifyObservers(this);\r\n }\r\n var engine = scene.getEngine();\r\n var hardwareInstancedRendering = batch.hardwareInstancedRendering[subMesh._id];\r\n var instanceDataStorage = this._instanceDataStorage;\r\n var material = subMesh.getMaterial();\r\n if (!material) {\r\n return this;\r\n }\r\n // Material\r\n if (!instanceDataStorage.isFrozen || !this._effectiveMaterial || this._effectiveMaterial !== material) {\r\n if (material._storeEffectOnSubMeshes) {\r\n if (!material.isReadyForSubMesh(this, subMesh, hardwareInstancedRendering)) {\r\n return this;\r\n }\r\n }\r\n else if (!material.isReady(this, hardwareInstancedRendering)) {\r\n return this;\r\n }\r\n this._effectiveMaterial = material;\r\n }\r\n // Alpha mode\r\n if (enableAlphaMode) {\r\n engine.setAlphaMode(this._effectiveMaterial.alphaMode);\r\n }\r\n for (var _i = 0, _a = scene._beforeRenderingMeshStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n step.action(this, subMesh, batch);\r\n }\r\n var effect;\r\n if (this._effectiveMaterial._storeEffectOnSubMeshes) {\r\n effect = subMesh.effect;\r\n }\r\n else {\r\n effect = this._effectiveMaterial.getEffect();\r\n }\r\n if (!effect) {\r\n return this;\r\n }\r\n var effectiveMesh = effectiveMeshReplacement || this._effectiveMesh;\r\n var sideOrientation;\r\n if (!instanceDataStorage.isFrozen && this._effectiveMaterial.backFaceCulling) {\r\n var mainDeterminant = effectiveMesh._getWorldMatrixDeterminant();\r\n sideOrientation = this.overrideMaterialSideOrientation;\r\n if (sideOrientation == null) {\r\n sideOrientation = this._effectiveMaterial.sideOrientation;\r\n }\r\n if (mainDeterminant < 0) {\r\n sideOrientation = (sideOrientation === Material.ClockWiseSideOrientation ? Material.CounterClockWiseSideOrientation : Material.ClockWiseSideOrientation);\r\n }\r\n instanceDataStorage.sideOrientation = sideOrientation;\r\n }\r\n else {\r\n sideOrientation = instanceDataStorage.sideOrientation;\r\n }\r\n var reverse = this._effectiveMaterial._preBind(effect, sideOrientation);\r\n if (this._effectiveMaterial.forceDepthWrite) {\r\n engine.setDepthWrite(true);\r\n }\r\n // Bind\r\n var fillMode = scene.forcePointsCloud ? Material.PointFillMode : (scene.forceWireframe ? Material.WireFrameFillMode : this._effectiveMaterial.fillMode);\r\n if (this._internalMeshDataInfo._onBeforeBindObservable) {\r\n this._internalMeshDataInfo._onBeforeBindObservable.notifyObservers(this);\r\n }\r\n if (!hardwareInstancedRendering) { // Binding will be done later because we need to add more info to the VB\r\n this._bind(subMesh, effect, fillMode);\r\n }\r\n var world = effectiveMesh.getWorldMatrix();\r\n if (this._effectiveMaterial._storeEffectOnSubMeshes) {\r\n this._effectiveMaterial.bindForSubMesh(world, this, subMesh);\r\n }\r\n else {\r\n this._effectiveMaterial.bind(world, this);\r\n }\r\n if (!this._effectiveMaterial.backFaceCulling && this._effectiveMaterial.separateCullingPass) {\r\n engine.setState(true, this._effectiveMaterial.zOffset, false, !reverse);\r\n this._processRendering(subMesh, effect, fillMode, batch, hardwareInstancedRendering, this._onBeforeDraw, this._effectiveMaterial);\r\n engine.setState(true, this._effectiveMaterial.zOffset, false, reverse);\r\n }\r\n // Draw\r\n this._processRendering(subMesh, effect, fillMode, batch, hardwareInstancedRendering, this._onBeforeDraw, this._effectiveMaterial);\r\n // Unbind\r\n this._effectiveMaterial.unbind();\r\n for (var _b = 0, _c = scene._afterRenderingMeshStage; _b < _c.length; _b++) {\r\n var step = _c[_b];\r\n step.action(this, subMesh, batch);\r\n }\r\n if (this._internalMeshDataInfo._onAfterRenderObservable) {\r\n this._internalMeshDataInfo._onAfterRenderObservable.notifyObservers(this);\r\n }\r\n return this;\r\n };\r\n Mesh.prototype._onBeforeDraw = function (isInstance, world, effectiveMaterial) {\r\n if (isInstance && effectiveMaterial) {\r\n effectiveMaterial.bindOnlyWorldMatrix(world);\r\n }\r\n };\r\n /**\r\n * Renormalize the mesh and patch it up if there are no weights\r\n * Similar to normalization by adding the weights compute the reciprocal and multiply all elements, this wil ensure that everything adds to 1.\r\n * However in the case of zero weights then we set just a single influence to 1.\r\n * We check in the function for extra's present and if so we use the normalizeSkinWeightsWithExtras rather than the FourWeights version.\r\n */\r\n Mesh.prototype.cleanMatrixWeights = function () {\r\n if (this.isVerticesDataPresent(VertexBuffer.MatricesWeightsKind)) {\r\n if (this.isVerticesDataPresent(VertexBuffer.MatricesWeightsExtraKind)) {\r\n this.normalizeSkinWeightsAndExtra();\r\n }\r\n else {\r\n this.normalizeSkinFourWeights();\r\n }\r\n }\r\n };\r\n // faster 4 weight version.\r\n Mesh.prototype.normalizeSkinFourWeights = function () {\r\n var matricesWeights = this.getVerticesData(VertexBuffer.MatricesWeightsKind);\r\n var numWeights = matricesWeights.length;\r\n for (var a = 0; a < numWeights; a += 4) {\r\n // accumulate weights\r\n var t = matricesWeights[a] + matricesWeights[a + 1] + matricesWeights[a + 2] + matricesWeights[a + 3];\r\n // check for invalid weight and just set it to 1.\r\n if (t === 0) {\r\n matricesWeights[a] = 1;\r\n }\r\n else {\r\n // renormalize so everything adds to 1 use reciprical\r\n var recip = 1 / t;\r\n matricesWeights[a] *= recip;\r\n matricesWeights[a + 1] *= recip;\r\n matricesWeights[a + 2] *= recip;\r\n matricesWeights[a + 3] *= recip;\r\n }\r\n }\r\n this.setVerticesData(VertexBuffer.MatricesWeightsKind, matricesWeights);\r\n };\r\n // handle special case of extra verts. (in theory gltf can handle 12 influences)\r\n Mesh.prototype.normalizeSkinWeightsAndExtra = function () {\r\n var matricesWeightsExtra = this.getVerticesData(VertexBuffer.MatricesWeightsExtraKind);\r\n var matricesWeights = this.getVerticesData(VertexBuffer.MatricesWeightsKind);\r\n var numWeights = matricesWeights.length;\r\n for (var a = 0; a < numWeights; a += 4) {\r\n // accumulate weights\r\n var t = matricesWeights[a] + matricesWeights[a + 1] + matricesWeights[a + 2] + matricesWeights[a + 3];\r\n t += matricesWeightsExtra[a] + matricesWeightsExtra[a + 1] + matricesWeightsExtra[a + 2] + matricesWeightsExtra[a + 3];\r\n // check for invalid weight and just set it to 1.\r\n if (t === 0) {\r\n matricesWeights[a] = 1;\r\n }\r\n else {\r\n // renormalize so everything adds to 1 use reciprical\r\n var recip = 1 / t;\r\n matricesWeights[a] *= recip;\r\n matricesWeights[a + 1] *= recip;\r\n matricesWeights[a + 2] *= recip;\r\n matricesWeights[a + 3] *= recip;\r\n // same goes for extras\r\n matricesWeightsExtra[a] *= recip;\r\n matricesWeightsExtra[a + 1] *= recip;\r\n matricesWeightsExtra[a + 2] *= recip;\r\n matricesWeightsExtra[a + 3] *= recip;\r\n }\r\n }\r\n this.setVerticesData(VertexBuffer.MatricesWeightsKind, matricesWeights);\r\n this.setVerticesData(VertexBuffer.MatricesWeightsKind, matricesWeightsExtra);\r\n };\r\n /**\r\n * ValidateSkinning is used to determine that a mesh has valid skinning data along with skin metrics, if missing weights,\r\n * or not normalized it is returned as invalid mesh the string can be used for console logs, or on screen messages to let\r\n * the user know there was an issue with importing the mesh\r\n * @returns a validation object with skinned, valid and report string\r\n */\r\n Mesh.prototype.validateSkinning = function () {\r\n var matricesWeightsExtra = this.getVerticesData(VertexBuffer.MatricesWeightsExtraKind);\r\n var matricesWeights = this.getVerticesData(VertexBuffer.MatricesWeightsKind);\r\n if (matricesWeights === null || this.skeleton == null) {\r\n return { skinned: false, valid: true, report: \"not skinned\" };\r\n }\r\n var numWeights = matricesWeights.length;\r\n var numberNotSorted = 0;\r\n var missingWeights = 0;\r\n var maxUsedWeights = 0;\r\n var numberNotNormalized = 0;\r\n var numInfluences = matricesWeightsExtra === null ? 4 : 8;\r\n var usedWeightCounts = new Array();\r\n for (var a = 0; a <= numInfluences; a++) {\r\n usedWeightCounts[a] = 0;\r\n }\r\n var toleranceEpsilon = 0.001;\r\n for (var a = 0; a < numWeights; a += 4) {\r\n var lastWeight = matricesWeights[a];\r\n var t = lastWeight;\r\n var usedWeights = t === 0 ? 0 : 1;\r\n for (var b = 1; b < numInfluences; b++) {\r\n var d = b < 4 ? matricesWeights[a + b] : matricesWeightsExtra[a + b - 4];\r\n if (d > lastWeight) {\r\n numberNotSorted++;\r\n }\r\n if (d !== 0) {\r\n usedWeights++;\r\n }\r\n t += d;\r\n lastWeight = d;\r\n }\r\n // count the buffer weights usage\r\n usedWeightCounts[usedWeights]++;\r\n // max influences\r\n if (usedWeights > maxUsedWeights) {\r\n maxUsedWeights = usedWeights;\r\n }\r\n // check for invalid weight and just set it to 1.\r\n if (t === 0) {\r\n missingWeights++;\r\n }\r\n else {\r\n // renormalize so everything adds to 1 use reciprical\r\n var recip = 1 / t;\r\n var tolerance = 0;\r\n for (b = 0; b < numInfluences; b++) {\r\n if (b < 4) {\r\n tolerance += Math.abs(matricesWeights[a + b] - (matricesWeights[a + b] * recip));\r\n }\r\n else {\r\n tolerance += Math.abs(matricesWeightsExtra[a + b - 4] - (matricesWeightsExtra[a + b - 4] * recip));\r\n }\r\n }\r\n // arbitary epsilon value for dicdating not normalized\r\n if (tolerance > toleranceEpsilon) {\r\n numberNotNormalized++;\r\n }\r\n }\r\n }\r\n // validate bone indices are in range of the skeleton\r\n var numBones = this.skeleton.bones.length;\r\n var matricesIndices = this.getVerticesData(VertexBuffer.MatricesIndicesKind);\r\n var matricesIndicesExtra = this.getVerticesData(VertexBuffer.MatricesIndicesExtraKind);\r\n var numBadBoneIndices = 0;\r\n for (var a = 0; a < numWeights; a++) {\r\n for (var b = 0; b < numInfluences; b++) {\r\n var index = b < 4 ? matricesIndices[b] : matricesIndicesExtra[b - 4];\r\n if (index >= numBones || index < 0) {\r\n numBadBoneIndices++;\r\n }\r\n }\r\n }\r\n // log mesh stats\r\n var output = \"Number of Weights = \" + numWeights / 4 + \"\\nMaximum influences = \" + maxUsedWeights +\r\n \"\\nMissing Weights = \" + missingWeights + \"\\nNot Sorted = \" + numberNotSorted +\r\n \"\\nNot Normalized = \" + numberNotNormalized + \"\\nWeightCounts = [\" + usedWeightCounts + \"]\" +\r\n \"\\nNumber of bones = \" + numBones + \"\\nBad Bone Indices = \" + numBadBoneIndices;\r\n return { skinned: true, valid: missingWeights === 0 && numberNotNormalized === 0 && numBadBoneIndices === 0, report: output };\r\n };\r\n /** @hidden */\r\n Mesh.prototype._checkDelayState = function () {\r\n var scene = this.getScene();\r\n if (this._geometry) {\r\n this._geometry.load(scene);\r\n }\r\n else if (this.delayLoadState === 4) {\r\n this.delayLoadState = 2;\r\n this._queueLoad(scene);\r\n }\r\n return this;\r\n };\r\n Mesh.prototype._queueLoad = function (scene) {\r\n var _this = this;\r\n scene._addPendingData(this);\r\n var getBinaryData = (this.delayLoadingFile.indexOf(\".babylonbinarymeshdata\") !== -1);\r\n Tools.LoadFile(this.delayLoadingFile, function (data) {\r\n if (data instanceof ArrayBuffer) {\r\n _this._delayLoadingFunction(data, _this);\r\n }\r\n else {\r\n _this._delayLoadingFunction(JSON.parse(data), _this);\r\n }\r\n _this.instances.forEach(function (instance) {\r\n instance.refreshBoundingInfo();\r\n instance._syncSubMeshes();\r\n });\r\n _this.delayLoadState = 1;\r\n scene._removePendingData(_this);\r\n }, function () { }, scene.offlineProvider, getBinaryData);\r\n return this;\r\n };\r\n /**\r\n * Returns `true` if the mesh is within the frustum defined by the passed array of planes.\r\n * A mesh is in the frustum if its bounding box intersects the frustum\r\n * @param frustumPlanes defines the frustum to test\r\n * @returns true if the mesh is in the frustum planes\r\n */\r\n Mesh.prototype.isInFrustum = function (frustumPlanes) {\r\n if (this.delayLoadState === 2) {\r\n return false;\r\n }\r\n if (!_super.prototype.isInFrustum.call(this, frustumPlanes)) {\r\n return false;\r\n }\r\n this._checkDelayState();\r\n return true;\r\n };\r\n /**\r\n * Sets the mesh material by the material or multiMaterial `id` property\r\n * @param id is a string identifying the material or the multiMaterial\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.setMaterialByID = function (id) {\r\n var materials = this.getScene().materials;\r\n var index;\r\n for (index = materials.length - 1; index > -1; index--) {\r\n if (materials[index].id === id) {\r\n this.material = materials[index];\r\n return this;\r\n }\r\n }\r\n // Multi\r\n var multiMaterials = this.getScene().multiMaterials;\r\n for (index = multiMaterials.length - 1; index > -1; index--) {\r\n if (multiMaterials[index].id === id) {\r\n this.material = multiMaterials[index];\r\n return this;\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Returns as a new array populated with the mesh material and/or skeleton, if any.\r\n * @returns an array of IAnimatable\r\n */\r\n Mesh.prototype.getAnimatables = function () {\r\n var results = new Array();\r\n if (this.material) {\r\n results.push(this.material);\r\n }\r\n if (this.skeleton) {\r\n results.push(this.skeleton);\r\n }\r\n return results;\r\n };\r\n /**\r\n * Modifies the mesh geometry according to the passed transformation matrix.\r\n * This method returns nothing but it really modifies the mesh even if it's originally not set as updatable.\r\n * The mesh normals are modified using the same transformation.\r\n * Note that, under the hood, this method sets a new VertexBuffer each call.\r\n * @param transform defines the transform matrix to use\r\n * @see http://doc.babylonjs.com/resources/baking_transformations\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.bakeTransformIntoVertices = function (transform) {\r\n // Position\r\n if (!this.isVerticesDataPresent(VertexBuffer.PositionKind)) {\r\n return this;\r\n }\r\n var submeshes = this.subMeshes.splice(0);\r\n this._resetPointsArrayCache();\r\n var data = this.getVerticesData(VertexBuffer.PositionKind);\r\n var temp = new Array();\r\n var index;\r\n for (index = 0; index < data.length; index += 3) {\r\n Vector3.TransformCoordinates(Vector3.FromArray(data, index), transform).toArray(temp, index);\r\n }\r\n this.setVerticesData(VertexBuffer.PositionKind, temp, this.getVertexBuffer(VertexBuffer.PositionKind).isUpdatable());\r\n // Normals\r\n if (this.isVerticesDataPresent(VertexBuffer.NormalKind)) {\r\n data = this.getVerticesData(VertexBuffer.NormalKind);\r\n temp = [];\r\n for (index = 0; index < data.length; index += 3) {\r\n Vector3.TransformNormal(Vector3.FromArray(data, index), transform).normalize().toArray(temp, index);\r\n }\r\n this.setVerticesData(VertexBuffer.NormalKind, temp, this.getVertexBuffer(VertexBuffer.NormalKind).isUpdatable());\r\n }\r\n // flip faces?\r\n if (transform.m[0] * transform.m[5] * transform.m[10] < 0) {\r\n this.flipFaces();\r\n }\r\n // Restore submeshes\r\n this.releaseSubMeshes();\r\n this.subMeshes = submeshes;\r\n return this;\r\n };\r\n /**\r\n * Modifies the mesh geometry according to its own current World Matrix.\r\n * The mesh World Matrix is then reset.\r\n * This method returns nothing but really modifies the mesh even if it's originally not set as updatable.\r\n * Note that, under the hood, this method sets a new VertexBuffer each call.\r\n * @see http://doc.babylonjs.com/resources/baking_transformations\r\n * @param bakeIndependenlyOfChildren indicates whether to preserve all child nodes' World Matrix during baking\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.bakeCurrentTransformIntoVertices = function (bakeIndependenlyOfChildren) {\r\n if (bakeIndependenlyOfChildren === void 0) { bakeIndependenlyOfChildren = true; }\r\n this.bakeTransformIntoVertices(this.computeWorldMatrix(true));\r\n this.resetLocalMatrix(bakeIndependenlyOfChildren);\r\n return this;\r\n };\r\n Object.defineProperty(Mesh.prototype, \"_positions\", {\r\n // Cache\r\n /** @hidden */\r\n get: function () {\r\n if (this._geometry) {\r\n return this._geometry._positions;\r\n }\r\n return null;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n Mesh.prototype._resetPointsArrayCache = function () {\r\n if (this._geometry) {\r\n this._geometry._resetPointsArrayCache();\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._generatePointsArray = function () {\r\n if (this._geometry) {\r\n return this._geometry._generatePointsArray();\r\n }\r\n return false;\r\n };\r\n /**\r\n * Returns a new Mesh object generated from the current mesh properties.\r\n * This method must not get confused with createInstance()\r\n * @param name is a string, the name given to the new mesh\r\n * @param newParent can be any Node object (default `null`)\r\n * @param doNotCloneChildren allows/denies the recursive cloning of the original mesh children if any (default `false`)\r\n * @param clonePhysicsImpostor allows/denies the cloning in the same time of the original mesh `body` used by the physics engine, if any (default `true`)\r\n * @returns a new mesh\r\n */\r\n Mesh.prototype.clone = function (name, newParent, doNotCloneChildren, clonePhysicsImpostor) {\r\n if (name === void 0) { name = \"\"; }\r\n if (newParent === void 0) { newParent = null; }\r\n if (clonePhysicsImpostor === void 0) { clonePhysicsImpostor = true; }\r\n return new Mesh(name, this.getScene(), newParent, this, doNotCloneChildren, clonePhysicsImpostor);\r\n };\r\n /**\r\n * Releases resources associated with this mesh.\r\n * @param doNotRecurse Set to true to not recurse into each children (recurse into each children by default)\r\n * @param disposeMaterialAndTextures Set to true to also dispose referenced materials and textures (false by default)\r\n */\r\n Mesh.prototype.dispose = function (doNotRecurse, disposeMaterialAndTextures) {\r\n if (disposeMaterialAndTextures === void 0) { disposeMaterialAndTextures = false; }\r\n this.morphTargetManager = null;\r\n if (this._geometry) {\r\n this._geometry.releaseForMesh(this, true);\r\n }\r\n var internalDataInfo = this._internalMeshDataInfo;\r\n if (internalDataInfo._onBeforeDrawObservable) {\r\n internalDataInfo._onBeforeDrawObservable.clear();\r\n }\r\n if (internalDataInfo._onBeforeBindObservable) {\r\n internalDataInfo._onBeforeBindObservable.clear();\r\n }\r\n if (internalDataInfo._onBeforeRenderObservable) {\r\n internalDataInfo._onBeforeRenderObservable.clear();\r\n }\r\n if (internalDataInfo._onAfterRenderObservable) {\r\n internalDataInfo._onAfterRenderObservable.clear();\r\n }\r\n // Sources\r\n if (this._scene.useClonedMeshMap) {\r\n if (internalDataInfo.meshMap) {\r\n for (var uniqueId in internalDataInfo.meshMap) {\r\n var mesh = internalDataInfo.meshMap[uniqueId];\r\n if (mesh) {\r\n mesh._internalMeshDataInfo._source = null;\r\n internalDataInfo.meshMap[uniqueId] = undefined;\r\n }\r\n }\r\n }\r\n if (internalDataInfo._source && internalDataInfo._source._internalMeshDataInfo.meshMap) {\r\n internalDataInfo._source._internalMeshDataInfo.meshMap[this.uniqueId] = undefined;\r\n }\r\n }\r\n else {\r\n var meshes = this.getScene().meshes;\r\n for (var _i = 0, meshes_1 = meshes; _i < meshes_1.length; _i++) {\r\n var abstractMesh = meshes_1[_i];\r\n var mesh = abstractMesh;\r\n if (mesh._internalMeshDataInfo && mesh._internalMeshDataInfo._source && mesh._internalMeshDataInfo._source === this) {\r\n mesh._internalMeshDataInfo._source = null;\r\n }\r\n }\r\n }\r\n internalDataInfo._source = null;\r\n // Instances\r\n this._disposeInstanceSpecificData();\r\n _super.prototype.dispose.call(this, doNotRecurse, disposeMaterialAndTextures);\r\n };\r\n /** @hidden */\r\n Mesh.prototype._disposeInstanceSpecificData = function () {\r\n // Do nothing\r\n };\r\n /**\r\n * Modifies the mesh geometry according to a displacement map.\r\n * A displacement map is a colored image. Each pixel color value (actually a gradient computed from red, green, blue values) will give the displacement to apply to each mesh vertex.\r\n * The mesh must be set as updatable. Its internal geometry is directly modified, no new buffer are allocated.\r\n * @param url is a string, the URL from the image file is to be downloaded.\r\n * @param minHeight is the lower limit of the displacement.\r\n * @param maxHeight is the upper limit of the displacement.\r\n * @param onSuccess is an optional Javascript function to be called just after the mesh is modified. It is passed the modified mesh and must return nothing.\r\n * @param uvOffset is an optional vector2 used to offset UV.\r\n * @param uvScale is an optional vector2 used to scale UV.\r\n * @param forceUpdate defines whether or not to force an update of the generated buffers. This is useful to apply on a deserialized model for instance.\r\n * @returns the Mesh.\r\n */\r\n Mesh.prototype.applyDisplacementMap = function (url, minHeight, maxHeight, onSuccess, uvOffset, uvScale, forceUpdate) {\r\n var _this = this;\r\n if (forceUpdate === void 0) { forceUpdate = false; }\r\n var scene = this.getScene();\r\n var onload = function (img) {\r\n // Getting height map data\r\n var heightMapWidth = img.width;\r\n var heightMapHeight = img.height;\r\n var canvas = CanvasGenerator.CreateCanvas(heightMapWidth, heightMapHeight);\r\n var context = canvas.getContext(\"2d\");\r\n context.drawImage(img, 0, 0);\r\n // Create VertexData from map data\r\n //Cast is due to wrong definition in lib.d.ts from ts 1.3 - https://github.com/Microsoft/TypeScript/issues/949\r\n var buffer = context.getImageData(0, 0, heightMapWidth, heightMapHeight).data;\r\n _this.applyDisplacementMapFromBuffer(buffer, heightMapWidth, heightMapHeight, minHeight, maxHeight, uvOffset, uvScale, forceUpdate);\r\n //execute success callback, if set\r\n if (onSuccess) {\r\n onSuccess(_this);\r\n }\r\n };\r\n Tools.LoadImage(url, onload, function () { }, scene.offlineProvider);\r\n return this;\r\n };\r\n /**\r\n * Modifies the mesh geometry according to a displacementMap buffer.\r\n * A displacement map is a colored image. Each pixel color value (actually a gradient computed from red, green, blue values) will give the displacement to apply to each mesh vertex.\r\n * The mesh must be set as updatable. Its internal geometry is directly modified, no new buffer are allocated.\r\n * @param buffer is a `Uint8Array` buffer containing series of `Uint8` lower than 255, the red, green, blue and alpha values of each successive pixel.\r\n * @param heightMapWidth is the width of the buffer image.\r\n * @param heightMapHeight is the height of the buffer image.\r\n * @param minHeight is the lower limit of the displacement.\r\n * @param maxHeight is the upper limit of the displacement.\r\n * @param onSuccess is an optional Javascript function to be called just after the mesh is modified. It is passed the modified mesh and must return nothing.\r\n * @param uvOffset is an optional vector2 used to offset UV.\r\n * @param uvScale is an optional vector2 used to scale UV.\r\n * @param forceUpdate defines whether or not to force an update of the generated buffers. This is useful to apply on a deserialized model for instance.\r\n * @returns the Mesh.\r\n */\r\n Mesh.prototype.applyDisplacementMapFromBuffer = function (buffer, heightMapWidth, heightMapHeight, minHeight, maxHeight, uvOffset, uvScale, forceUpdate) {\r\n if (forceUpdate === void 0) { forceUpdate = false; }\r\n if (!this.isVerticesDataPresent(VertexBuffer.PositionKind)\r\n || !this.isVerticesDataPresent(VertexBuffer.NormalKind)\r\n || !this.isVerticesDataPresent(VertexBuffer.UVKind)) {\r\n Logger.Warn(\"Cannot call applyDisplacementMap: Given mesh is not complete. Position, Normal or UV are missing\");\r\n return this;\r\n }\r\n var positions = this.getVerticesData(VertexBuffer.PositionKind, true, true);\r\n var normals = this.getVerticesData(VertexBuffer.NormalKind);\r\n var uvs = this.getVerticesData(VertexBuffer.UVKind);\r\n var position = Vector3.Zero();\r\n var normal = Vector3.Zero();\r\n var uv = Vector2.Zero();\r\n uvOffset = uvOffset || Vector2.Zero();\r\n uvScale = uvScale || new Vector2(1, 1);\r\n for (var index = 0; index < positions.length; index += 3) {\r\n Vector3.FromArrayToRef(positions, index, position);\r\n Vector3.FromArrayToRef(normals, index, normal);\r\n Vector2.FromArrayToRef(uvs, (index / 3) * 2, uv);\r\n // Compute height\r\n var u = ((Math.abs(uv.x * uvScale.x + uvOffset.x) * heightMapWidth) % heightMapWidth) | 0;\r\n var v = ((Math.abs(uv.y * uvScale.y + uvOffset.y) * heightMapHeight) % heightMapHeight) | 0;\r\n var pos = (u + v * heightMapWidth) * 4;\r\n var r = buffer[pos] / 255.0;\r\n var g = buffer[pos + 1] / 255.0;\r\n var b = buffer[pos + 2] / 255.0;\r\n var gradient = r * 0.3 + g * 0.59 + b * 0.11;\r\n normal.normalize();\r\n normal.scaleInPlace(minHeight + (maxHeight - minHeight) * gradient);\r\n position = position.add(normal);\r\n position.toArray(positions, index);\r\n }\r\n VertexData.ComputeNormals(positions, this.getIndices(), normals);\r\n if (forceUpdate) {\r\n this.setVerticesData(VertexBuffer.PositionKind, positions);\r\n this.setVerticesData(VertexBuffer.NormalKind, normals);\r\n }\r\n else {\r\n this.updateVerticesData(VertexBuffer.PositionKind, positions);\r\n this.updateVerticesData(VertexBuffer.NormalKind, normals);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Modify the mesh to get a flat shading rendering.\r\n * This means each mesh facet will then have its own normals. Usually new vertices are added in the mesh geometry to get this result.\r\n * Warning : the mesh is really modified even if not set originally as updatable and, under the hood, a new VertexBuffer is allocated.\r\n * @returns current mesh\r\n */\r\n Mesh.prototype.convertToFlatShadedMesh = function () {\r\n var kinds = this.getVerticesDataKinds();\r\n var vbs = {};\r\n var data = {};\r\n var newdata = {};\r\n var updatableNormals = false;\r\n var kindIndex;\r\n var kind;\r\n for (kindIndex = 0; kindIndex < kinds.length; kindIndex++) {\r\n kind = kinds[kindIndex];\r\n var vertexBuffer = this.getVertexBuffer(kind);\r\n if (kind === VertexBuffer.NormalKind) {\r\n updatableNormals = vertexBuffer.isUpdatable();\r\n kinds.splice(kindIndex, 1);\r\n kindIndex--;\r\n continue;\r\n }\r\n vbs[kind] = vertexBuffer;\r\n data[kind] = vbs[kind].getData();\r\n newdata[kind] = [];\r\n }\r\n // Save previous submeshes\r\n var previousSubmeshes = this.subMeshes.slice(0);\r\n var indices = this.getIndices();\r\n var totalIndices = this.getTotalIndices();\r\n // Generating unique vertices per face\r\n var index;\r\n for (index = 0; index < totalIndices; index++) {\r\n var vertexIndex = indices[index];\r\n for (kindIndex = 0; kindIndex < kinds.length; kindIndex++) {\r\n kind = kinds[kindIndex];\r\n var stride = vbs[kind].getStrideSize();\r\n for (var offset = 0; offset < stride; offset++) {\r\n newdata[kind].push(data[kind][vertexIndex * stride + offset]);\r\n }\r\n }\r\n }\r\n // Updating faces & normal\r\n var normals = [];\r\n var positions = newdata[VertexBuffer.PositionKind];\r\n for (index = 0; index < totalIndices; index += 3) {\r\n indices[index] = index;\r\n indices[index + 1] = index + 1;\r\n indices[index + 2] = index + 2;\r\n var p1 = Vector3.FromArray(positions, index * 3);\r\n var p2 = Vector3.FromArray(positions, (index + 1) * 3);\r\n var p3 = Vector3.FromArray(positions, (index + 2) * 3);\r\n var p1p2 = p1.subtract(p2);\r\n var p3p2 = p3.subtract(p2);\r\n var normal = Vector3.Normalize(Vector3.Cross(p1p2, p3p2));\r\n // Store same normals for every vertex\r\n for (var localIndex = 0; localIndex < 3; localIndex++) {\r\n normals.push(normal.x);\r\n normals.push(normal.y);\r\n normals.push(normal.z);\r\n }\r\n }\r\n this.setIndices(indices);\r\n this.setVerticesData(VertexBuffer.NormalKind, normals, updatableNormals);\r\n // Updating vertex buffers\r\n for (kindIndex = 0; kindIndex < kinds.length; kindIndex++) {\r\n kind = kinds[kindIndex];\r\n this.setVerticesData(kind, newdata[kind], vbs[kind].isUpdatable());\r\n }\r\n // Updating submeshes\r\n this.releaseSubMeshes();\r\n for (var submeshIndex = 0; submeshIndex < previousSubmeshes.length; submeshIndex++) {\r\n var previousOne = previousSubmeshes[submeshIndex];\r\n SubMesh.AddToMesh(previousOne.materialIndex, previousOne.indexStart, previousOne.indexCount, previousOne.indexStart, previousOne.indexCount, this);\r\n }\r\n this.synchronizeInstances();\r\n return this;\r\n };\r\n /**\r\n * This method removes all the mesh indices and add new vertices (duplication) in order to unfold facets into buffers.\r\n * In other words, more vertices, no more indices and a single bigger VBO.\r\n * The mesh is really modified even if not set originally as updatable. Under the hood, a new VertexBuffer is allocated.\r\n * @returns current mesh\r\n */\r\n Mesh.prototype.convertToUnIndexedMesh = function () {\r\n var kinds = this.getVerticesDataKinds();\r\n var vbs = {};\r\n var data = {};\r\n var newdata = {};\r\n var kindIndex;\r\n var kind;\r\n for (kindIndex = 0; kindIndex < kinds.length; kindIndex++) {\r\n kind = kinds[kindIndex];\r\n var vertexBuffer = this.getVertexBuffer(kind);\r\n vbs[kind] = vertexBuffer;\r\n data[kind] = vbs[kind].getData();\r\n newdata[kind] = [];\r\n }\r\n // Save previous submeshes\r\n var previousSubmeshes = this.subMeshes.slice(0);\r\n var indices = this.getIndices();\r\n var totalIndices = this.getTotalIndices();\r\n // Generating unique vertices per face\r\n var index;\r\n for (index = 0; index < totalIndices; index++) {\r\n var vertexIndex = indices[index];\r\n for (kindIndex = 0; kindIndex < kinds.length; kindIndex++) {\r\n kind = kinds[kindIndex];\r\n var stride = vbs[kind].getStrideSize();\r\n for (var offset = 0; offset < stride; offset++) {\r\n newdata[kind].push(data[kind][vertexIndex * stride + offset]);\r\n }\r\n }\r\n }\r\n // Updating indices\r\n for (index = 0; index < totalIndices; index += 3) {\r\n indices[index] = index;\r\n indices[index + 1] = index + 1;\r\n indices[index + 2] = index + 2;\r\n }\r\n this.setIndices(indices);\r\n // Updating vertex buffers\r\n for (kindIndex = 0; kindIndex < kinds.length; kindIndex++) {\r\n kind = kinds[kindIndex];\r\n this.setVerticesData(kind, newdata[kind], vbs[kind].isUpdatable());\r\n }\r\n // Updating submeshes\r\n this.releaseSubMeshes();\r\n for (var submeshIndex = 0; submeshIndex < previousSubmeshes.length; submeshIndex++) {\r\n var previousOne = previousSubmeshes[submeshIndex];\r\n SubMesh.AddToMesh(previousOne.materialIndex, previousOne.indexStart, previousOne.indexCount, previousOne.indexStart, previousOne.indexCount, this);\r\n }\r\n this._unIndexed = true;\r\n this.synchronizeInstances();\r\n return this;\r\n };\r\n /**\r\n * Inverses facet orientations.\r\n * Warning : the mesh is really modified even if not set originally as updatable. A new VertexBuffer is created under the hood each call.\r\n * @param flipNormals will also inverts the normals\r\n * @returns current mesh\r\n */\r\n Mesh.prototype.flipFaces = function (flipNormals) {\r\n if (flipNormals === void 0) { flipNormals = false; }\r\n var vertex_data = VertexData.ExtractFromMesh(this);\r\n var i;\r\n if (flipNormals && this.isVerticesDataPresent(VertexBuffer.NormalKind) && vertex_data.normals) {\r\n for (i = 0; i < vertex_data.normals.length; i++) {\r\n vertex_data.normals[i] *= -1;\r\n }\r\n }\r\n if (vertex_data.indices) {\r\n var temp;\r\n for (i = 0; i < vertex_data.indices.length; i += 3) {\r\n // reassign indices\r\n temp = vertex_data.indices[i + 1];\r\n vertex_data.indices[i + 1] = vertex_data.indices[i + 2];\r\n vertex_data.indices[i + 2] = temp;\r\n }\r\n }\r\n vertex_data.applyToMesh(this, this.isVertexBufferUpdatable(VertexBuffer.PositionKind));\r\n return this;\r\n };\r\n /**\r\n * Increase the number of facets and hence vertices in a mesh\r\n * Vertex normals are interpolated from existing vertex normals\r\n * Warning : the mesh is really modified even if not set originally as updatable. A new VertexBuffer is created under the hood each call.\r\n * @param numberPerEdge the number of new vertices to add to each edge of a facet, optional default 1\r\n */\r\n Mesh.prototype.increaseVertices = function (numberPerEdge) {\r\n var vertex_data = VertexData.ExtractFromMesh(this);\r\n var uvs = vertex_data.uvs;\r\n var currentIndices = vertex_data.indices;\r\n var positions = vertex_data.positions;\r\n var normals = vertex_data.normals;\r\n if (currentIndices === null || positions === null || normals === null || uvs === null) {\r\n Logger.Warn(\"VertexData contains null entries\");\r\n }\r\n else {\r\n var segments = numberPerEdge + 1; //segments per current facet edge, become sides of new facets\r\n var tempIndices = new Array();\r\n for (var i = 0; i < segments + 1; i++) {\r\n tempIndices[i] = new Array();\r\n }\r\n var a; //vertex index of one end of a side\r\n var b; //vertex index of other end of the side\r\n var deltaPosition = new Vector3(0, 0, 0);\r\n var deltaNormal = new Vector3(0, 0, 0);\r\n var deltaUV = new Vector2(0, 0);\r\n var indices = new Array();\r\n var vertexIndex = new Array();\r\n var side = new Array();\r\n var len;\r\n var positionPtr = positions.length;\r\n var uvPtr = uvs.length;\r\n for (var i = 0; i < currentIndices.length; i += 3) {\r\n vertexIndex[0] = currentIndices[i];\r\n vertexIndex[1] = currentIndices[i + 1];\r\n vertexIndex[2] = currentIndices[i + 2];\r\n for (var j = 0; j < 3; j++) {\r\n a = vertexIndex[j];\r\n b = vertexIndex[(j + 1) % 3];\r\n if (side[a] === undefined && side[b] === undefined) {\r\n side[a] = new Array();\r\n side[b] = new Array();\r\n }\r\n else {\r\n if (side[a] === undefined) {\r\n side[a] = new Array();\r\n }\r\n if (side[b] === undefined) {\r\n side[b] = new Array();\r\n }\r\n }\r\n if (side[a][b] === undefined && side[b][a] === undefined) {\r\n side[a][b] = [];\r\n deltaPosition.x = (positions[3 * b] - positions[3 * a]) / segments;\r\n deltaPosition.y = (positions[3 * b + 1] - positions[3 * a + 1]) / segments;\r\n deltaPosition.z = (positions[3 * b + 2] - positions[3 * a + 2]) / segments;\r\n deltaNormal.x = (normals[3 * b] - normals[3 * a]) / segments;\r\n deltaNormal.y = (normals[3 * b + 1] - normals[3 * a + 1]) / segments;\r\n deltaNormal.z = (normals[3 * b + 2] - normals[3 * a + 2]) / segments;\r\n deltaUV.x = (uvs[2 * b] - uvs[2 * a]) / segments;\r\n deltaUV.y = (uvs[2 * b + 1] - uvs[2 * a + 1]) / segments;\r\n side[a][b].push(a);\r\n for (var k = 1; k < segments; k++) {\r\n side[a][b].push(positions.length / 3);\r\n positions[positionPtr] = positions[3 * a] + k * deltaPosition.x;\r\n normals[positionPtr++] = normals[3 * a] + k * deltaNormal.x;\r\n positions[positionPtr] = positions[3 * a + 1] + k * deltaPosition.y;\r\n normals[positionPtr++] = normals[3 * a + 1] + k * deltaNormal.y;\r\n positions[positionPtr] = positions[3 * a + 2] + k * deltaPosition.z;\r\n normals[positionPtr++] = normals[3 * a + 2] + k * deltaNormal.z;\r\n uvs[uvPtr++] = uvs[2 * a] + k * deltaUV.x;\r\n uvs[uvPtr++] = uvs[2 * a + 1] + k * deltaUV.y;\r\n }\r\n side[a][b].push(b);\r\n side[b][a] = new Array();\r\n len = side[a][b].length;\r\n for (var idx = 0; idx < len; idx++) {\r\n side[b][a][idx] = side[a][b][len - 1 - idx];\r\n }\r\n }\r\n }\r\n //Calculate positions, normals and uvs of new internal vertices\r\n tempIndices[0][0] = currentIndices[i];\r\n tempIndices[1][0] = side[currentIndices[i]][currentIndices[i + 1]][1];\r\n tempIndices[1][1] = side[currentIndices[i]][currentIndices[i + 2]][1];\r\n for (var k = 2; k < segments; k++) {\r\n tempIndices[k][0] = side[currentIndices[i]][currentIndices[i + 1]][k];\r\n tempIndices[k][k] = side[currentIndices[i]][currentIndices[i + 2]][k];\r\n deltaPosition.x = (positions[3 * tempIndices[k][k]] - positions[3 * tempIndices[k][0]]) / k;\r\n deltaPosition.y = (positions[3 * tempIndices[k][k] + 1] - positions[3 * tempIndices[k][0] + 1]) / k;\r\n deltaPosition.z = (positions[3 * tempIndices[k][k] + 2] - positions[3 * tempIndices[k][0] + 2]) / k;\r\n deltaNormal.x = (normals[3 * tempIndices[k][k]] - normals[3 * tempIndices[k][0]]) / k;\r\n deltaNormal.y = (normals[3 * tempIndices[k][k] + 1] - normals[3 * tempIndices[k][0] + 1]) / k;\r\n deltaNormal.z = (normals[3 * tempIndices[k][k] + 2] - normals[3 * tempIndices[k][0] + 2]) / k;\r\n deltaUV.x = (uvs[2 * tempIndices[k][k]] - uvs[2 * tempIndices[k][0]]) / k;\r\n deltaUV.y = (uvs[2 * tempIndices[k][k] + 1] - uvs[2 * tempIndices[k][0] + 1]) / k;\r\n for (var j = 1; j < k; j++) {\r\n tempIndices[k][j] = positions.length / 3;\r\n positions[positionPtr] = positions[3 * tempIndices[k][0]] + j * deltaPosition.x;\r\n normals[positionPtr++] = normals[3 * tempIndices[k][0]] + j * deltaNormal.x;\r\n positions[positionPtr] = positions[3 * tempIndices[k][0] + 1] + j * deltaPosition.y;\r\n normals[positionPtr++] = normals[3 * tempIndices[k][0] + 1] + j * deltaNormal.y;\r\n positions[positionPtr] = positions[3 * tempIndices[k][0] + 2] + j * deltaPosition.z;\r\n normals[positionPtr++] = normals[3 * tempIndices[k][0] + 2] + j * deltaNormal.z;\r\n uvs[uvPtr++] = uvs[2 * tempIndices[k][0]] + j * deltaUV.x;\r\n uvs[uvPtr++] = uvs[2 * tempIndices[k][0] + 1] + j * deltaUV.y;\r\n }\r\n }\r\n tempIndices[segments] = side[currentIndices[i + 1]][currentIndices[i + 2]];\r\n // reform indices\r\n indices.push(tempIndices[0][0], tempIndices[1][0], tempIndices[1][1]);\r\n for (var k = 1; k < segments; k++) {\r\n for (var j = 0; j < k; j++) {\r\n indices.push(tempIndices[k][j], tempIndices[k + 1][j], tempIndices[k + 1][j + 1]);\r\n indices.push(tempIndices[k][j], tempIndices[k + 1][j + 1], tempIndices[k][j + 1]);\r\n }\r\n indices.push(tempIndices[k][j], tempIndices[k + 1][j], tempIndices[k + 1][j + 1]);\r\n }\r\n }\r\n vertex_data.indices = indices;\r\n vertex_data.applyToMesh(this, this.isVertexBufferUpdatable(VertexBuffer.PositionKind));\r\n }\r\n };\r\n /**\r\n * Force adjacent facets to share vertices and remove any facets that have all vertices in a line\r\n * This will undo any application of covertToFlatShadedMesh\r\n * Warning : the mesh is really modified even if not set originally as updatable. A new VertexBuffer is created under the hood each call.\r\n */\r\n Mesh.prototype.forceSharedVertices = function () {\r\n var vertex_data = VertexData.ExtractFromMesh(this);\r\n var currentUVs = vertex_data.uvs;\r\n var currentIndices = vertex_data.indices;\r\n var currentPositions = vertex_data.positions;\r\n var currentColors = vertex_data.colors;\r\n if (currentIndices === void 0 || currentPositions === void 0 || currentIndices === null || currentPositions === null) {\r\n Logger.Warn(\"VertexData contains empty entries\");\r\n }\r\n else {\r\n var positions = new Array();\r\n var indices = new Array();\r\n var uvs = new Array();\r\n var colors = new Array();\r\n var pstring = new Array(); //lists facet vertex positions (a,b,c) as string \"a|b|c\"\r\n var indexPtr = 0; // pointer to next available index value\r\n var uniquePositions = new Array(); // unique vertex positions\r\n var ptr; // pointer to element in uniquePositions\r\n var facet;\r\n for (var i = 0; i < currentIndices.length; i += 3) {\r\n facet = [currentIndices[i], currentIndices[i + 1], currentIndices[i + 2]]; //facet vertex indices\r\n pstring = new Array();\r\n for (var j = 0; j < 3; j++) {\r\n pstring[j] = \"\";\r\n for (var k = 0; k < 3; k++) {\r\n //small values make 0\r\n if (Math.abs(currentPositions[3 * facet[j] + k]) < 0.00000001) {\r\n currentPositions[3 * facet[j] + k] = 0;\r\n }\r\n pstring[j] += currentPositions[3 * facet[j] + k] + \"|\";\r\n }\r\n pstring[j] = pstring[j].slice(0, -1);\r\n }\r\n //check facet vertices to see that none are repeated\r\n // do not process any facet that has a repeated vertex, ie is a line\r\n if (!(pstring[0] == pstring[1] || pstring[0] == pstring[2] || pstring[1] == pstring[2])) {\r\n //for each facet position check if already listed in uniquePositions\r\n // if not listed add to uniquePositions and set index pointer\r\n // if listed use its index in uniquePositions and new index pointer\r\n for (var j = 0; j < 3; j++) {\r\n ptr = uniquePositions.indexOf(pstring[j]);\r\n if (ptr < 0) {\r\n uniquePositions.push(pstring[j]);\r\n ptr = indexPtr++;\r\n //not listed so add individual x, y, z coordinates to positions\r\n for (var k = 0; k < 3; k++) {\r\n positions.push(currentPositions[3 * facet[j] + k]);\r\n }\r\n if (currentColors !== null && currentColors !== void 0) {\r\n for (var k = 0; k < 4; k++) {\r\n colors.push(currentColors[4 * facet[j] + k]);\r\n }\r\n }\r\n if (currentUVs !== null && currentUVs !== void 0) {\r\n for (var k = 0; k < 2; k++) {\r\n uvs.push(currentUVs[2 * facet[j] + k]);\r\n }\r\n }\r\n }\r\n // add new index pointer to indices array\r\n indices.push(ptr);\r\n }\r\n }\r\n }\r\n var normals = new Array();\r\n VertexData.ComputeNormals(positions, indices, normals);\r\n //create new vertex data object and update\r\n vertex_data.positions = positions;\r\n vertex_data.indices = indices;\r\n vertex_data.normals = normals;\r\n if (currentUVs !== null && currentUVs !== void 0) {\r\n vertex_data.uvs = uvs;\r\n }\r\n if (currentColors !== null && currentColors !== void 0) {\r\n vertex_data.colors = colors;\r\n }\r\n vertex_data.applyToMesh(this, this.isVertexBufferUpdatable(VertexBuffer.PositionKind));\r\n }\r\n };\r\n // Instances\r\n /** @hidden */\r\n Mesh._instancedMeshFactory = function (name, mesh) {\r\n throw _DevTools.WarnImport(\"InstancedMesh\");\r\n };\r\n /** @hidden */\r\n Mesh._PhysicsImpostorParser = function (scene, physicObject, jsonObject) {\r\n throw _DevTools.WarnImport(\"PhysicsImpostor\");\r\n };\r\n /**\r\n * Creates a new InstancedMesh object from the mesh model.\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_instances\r\n * @param name defines the name of the new instance\r\n * @returns a new InstancedMesh\r\n */\r\n Mesh.prototype.createInstance = function (name) {\r\n return Mesh._instancedMeshFactory(name, this);\r\n };\r\n /**\r\n * Synchronises all the mesh instance submeshes to the current mesh submeshes, if any.\r\n * After this call, all the mesh instances have the same submeshes than the current mesh.\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.synchronizeInstances = function () {\r\n for (var instanceIndex = 0; instanceIndex < this.instances.length; instanceIndex++) {\r\n var instance = this.instances[instanceIndex];\r\n instance._syncSubMeshes();\r\n }\r\n return this;\r\n };\r\n /**\r\n * Optimization of the mesh's indices, in case a mesh has duplicated vertices.\r\n * The function will only reorder the indices and will not remove unused vertices to avoid problems with submeshes.\r\n * This should be used together with the simplification to avoid disappearing triangles.\r\n * @param successCallback an optional success callback to be called after the optimization finished.\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.optimizeIndices = function (successCallback) {\r\n var _this = this;\r\n var indices = this.getIndices();\r\n var positions = this.getVerticesData(VertexBuffer.PositionKind);\r\n if (!positions || !indices) {\r\n return this;\r\n }\r\n var vectorPositions = new Array();\r\n for (var pos = 0; pos < positions.length; pos = pos + 3) {\r\n vectorPositions.push(Vector3.FromArray(positions, pos));\r\n }\r\n var dupes = new Array();\r\n AsyncLoop.SyncAsyncForLoop(vectorPositions.length, 40, function (iteration) {\r\n var realPos = vectorPositions.length - 1 - iteration;\r\n var testedPosition = vectorPositions[realPos];\r\n for (var j = 0; j < realPos; ++j) {\r\n var againstPosition = vectorPositions[j];\r\n if (testedPosition.equals(againstPosition)) {\r\n dupes[realPos] = j;\r\n break;\r\n }\r\n }\r\n }, function () {\r\n for (var i = 0; i < indices.length; ++i) {\r\n indices[i] = dupes[indices[i]] || indices[i];\r\n }\r\n //indices are now reordered\r\n var originalSubMeshes = _this.subMeshes.slice(0);\r\n _this.setIndices(indices);\r\n _this.subMeshes = originalSubMeshes;\r\n if (successCallback) {\r\n successCallback(_this);\r\n }\r\n });\r\n return this;\r\n };\r\n /**\r\n * Serialize current mesh\r\n * @param serializationObject defines the object which will receive the serialization data\r\n */\r\n Mesh.prototype.serialize = function (serializationObject) {\r\n serializationObject.name = this.name;\r\n serializationObject.id = this.id;\r\n serializationObject.type = this.getClassName();\r\n if (Tags && Tags.HasTags(this)) {\r\n serializationObject.tags = Tags.GetTags(this);\r\n }\r\n serializationObject.position = this.position.asArray();\r\n if (this.rotationQuaternion) {\r\n serializationObject.rotationQuaternion = this.rotationQuaternion.asArray();\r\n }\r\n else if (this.rotation) {\r\n serializationObject.rotation = this.rotation.asArray();\r\n }\r\n serializationObject.scaling = this.scaling.asArray();\r\n if (this._postMultiplyPivotMatrix) {\r\n serializationObject.pivotMatrix = this.getPivotMatrix().asArray();\r\n }\r\n else {\r\n serializationObject.localMatrix = this.getPivotMatrix().asArray();\r\n }\r\n serializationObject.isEnabled = this.isEnabled(false);\r\n serializationObject.isVisible = this.isVisible;\r\n serializationObject.infiniteDistance = this.infiniteDistance;\r\n serializationObject.pickable = this.isPickable;\r\n serializationObject.receiveShadows = this.receiveShadows;\r\n serializationObject.billboardMode = this.billboardMode;\r\n serializationObject.visibility = this.visibility;\r\n serializationObject.checkCollisions = this.checkCollisions;\r\n serializationObject.isBlocker = this.isBlocker;\r\n serializationObject.overrideMaterialSideOrientation = this.overrideMaterialSideOrientation;\r\n // Parent\r\n if (this.parent) {\r\n serializationObject.parentId = this.parent.id;\r\n }\r\n // Geometry\r\n serializationObject.isUnIndexed = this.isUnIndexed;\r\n var geometry = this._geometry;\r\n if (geometry) {\r\n var geometryId = geometry.id;\r\n serializationObject.geometryId = geometryId;\r\n // SubMeshes\r\n serializationObject.subMeshes = [];\r\n for (var subIndex = 0; subIndex < this.subMeshes.length; subIndex++) {\r\n var subMesh = this.subMeshes[subIndex];\r\n serializationObject.subMeshes.push({\r\n materialIndex: subMesh.materialIndex,\r\n verticesStart: subMesh.verticesStart,\r\n verticesCount: subMesh.verticesCount,\r\n indexStart: subMesh.indexStart,\r\n indexCount: subMesh.indexCount\r\n });\r\n }\r\n }\r\n // Material\r\n if (this.material) {\r\n if (!this.material.doNotSerialize) {\r\n serializationObject.materialId = this.material.id;\r\n }\r\n }\r\n else {\r\n this.material = null;\r\n }\r\n // Morph targets\r\n if (this.morphTargetManager) {\r\n serializationObject.morphTargetManagerId = this.morphTargetManager.uniqueId;\r\n }\r\n // Skeleton\r\n if (this.skeleton) {\r\n serializationObject.skeletonId = this.skeleton.id;\r\n }\r\n // Physics\r\n //TODO implement correct serialization for physics impostors.\r\n if (this.getScene()._getComponent(SceneComponentConstants.NAME_PHYSICSENGINE)) {\r\n var impostor = this.getPhysicsImpostor();\r\n if (impostor) {\r\n serializationObject.physicsMass = impostor.getParam(\"mass\");\r\n serializationObject.physicsFriction = impostor.getParam(\"friction\");\r\n serializationObject.physicsRestitution = impostor.getParam(\"mass\");\r\n serializationObject.physicsImpostor = impostor.type;\r\n }\r\n }\r\n // Metadata\r\n if (this.metadata) {\r\n serializationObject.metadata = this.metadata;\r\n }\r\n // Instances\r\n serializationObject.instances = [];\r\n for (var index = 0; index < this.instances.length; index++) {\r\n var instance = this.instances[index];\r\n if (instance.doNotSerialize) {\r\n continue;\r\n }\r\n var serializationInstance = {\r\n name: instance.name,\r\n id: instance.id,\r\n position: instance.position.asArray(),\r\n scaling: instance.scaling.asArray()\r\n };\r\n if (instance.parent) {\r\n serializationInstance.parentId = instance.parent.id;\r\n }\r\n if (instance.rotationQuaternion) {\r\n serializationInstance.rotationQuaternion = instance.rotationQuaternion.asArray();\r\n }\r\n else if (instance.rotation) {\r\n serializationInstance.rotation = instance.rotation.asArray();\r\n }\r\n serializationObject.instances.push(serializationInstance);\r\n // Animations\r\n SerializationHelper.AppendSerializedAnimations(instance, serializationInstance);\r\n serializationInstance.ranges = instance.serializeAnimationRanges();\r\n }\r\n //\r\n // Animations\r\n SerializationHelper.AppendSerializedAnimations(this, serializationObject);\r\n serializationObject.ranges = this.serializeAnimationRanges();\r\n // Layer mask\r\n serializationObject.layerMask = this.layerMask;\r\n // Alpha\r\n serializationObject.alphaIndex = this.alphaIndex;\r\n serializationObject.hasVertexAlpha = this.hasVertexAlpha;\r\n // Overlay\r\n serializationObject.overlayAlpha = this.overlayAlpha;\r\n serializationObject.overlayColor = this.overlayColor.asArray();\r\n serializationObject.renderOverlay = this.renderOverlay;\r\n // Fog\r\n serializationObject.applyFog = this.applyFog;\r\n // Action Manager\r\n if (this.actionManager) {\r\n serializationObject.actions = this.actionManager.serialize(this.name);\r\n }\r\n };\r\n /** @hidden */\r\n Mesh.prototype._syncGeometryWithMorphTargetManager = function () {\r\n if (!this.geometry) {\r\n return;\r\n }\r\n this._markSubMeshesAsAttributesDirty();\r\n var morphTargetManager = this._internalMeshDataInfo._morphTargetManager;\r\n if (morphTargetManager && morphTargetManager.vertexCount) {\r\n if (morphTargetManager.vertexCount !== this.getTotalVertices()) {\r\n Logger.Error(\"Mesh is incompatible with morph targets. Targets and mesh must all have the same vertices count.\");\r\n this.morphTargetManager = null;\r\n return;\r\n }\r\n for (var index = 0; index < morphTargetManager.numInfluencers; index++) {\r\n var morphTarget = morphTargetManager.getActiveTarget(index);\r\n var positions = morphTarget.getPositions();\r\n if (!positions) {\r\n Logger.Error(\"Invalid morph target. Target must have positions.\");\r\n return;\r\n }\r\n this.geometry.setVerticesData(VertexBuffer.PositionKind + index, positions, false, 3);\r\n var normals = morphTarget.getNormals();\r\n if (normals) {\r\n this.geometry.setVerticesData(VertexBuffer.NormalKind + index, normals, false, 3);\r\n }\r\n var tangents = morphTarget.getTangents();\r\n if (tangents) {\r\n this.geometry.setVerticesData(VertexBuffer.TangentKind + index, tangents, false, 3);\r\n }\r\n var uvs = morphTarget.getUVs();\r\n if (uvs) {\r\n this.geometry.setVerticesData(VertexBuffer.UVKind + \"_\" + index, uvs, false, 2);\r\n }\r\n }\r\n }\r\n else {\r\n var index = 0;\r\n // Positions\r\n while (this.geometry.isVerticesDataPresent(VertexBuffer.PositionKind + index)) {\r\n this.geometry.removeVerticesData(VertexBuffer.PositionKind + index);\r\n if (this.geometry.isVerticesDataPresent(VertexBuffer.NormalKind + index)) {\r\n this.geometry.removeVerticesData(VertexBuffer.NormalKind + index);\r\n }\r\n if (this.geometry.isVerticesDataPresent(VertexBuffer.TangentKind + index)) {\r\n this.geometry.removeVerticesData(VertexBuffer.TangentKind + index);\r\n }\r\n if (this.geometry.isVerticesDataPresent(VertexBuffer.UVKind + index)) {\r\n this.geometry.removeVerticesData(VertexBuffer.UVKind + \"_\" + index);\r\n }\r\n index++;\r\n }\r\n }\r\n };\r\n /**\r\n * Returns a new Mesh object parsed from the source provided.\r\n * @param parsedMesh is the source\r\n * @param scene defines the hosting scene\r\n * @param rootUrl is the root URL to prefix the `delayLoadingFile` property with\r\n * @returns a new Mesh\r\n */\r\n Mesh.Parse = function (parsedMesh, scene, rootUrl) {\r\n var mesh;\r\n if (parsedMesh.type && parsedMesh.type === \"GroundMesh\") {\r\n mesh = Mesh._GroundMeshParser(parsedMesh, scene);\r\n }\r\n else {\r\n mesh = new Mesh(parsedMesh.name, scene);\r\n }\r\n mesh.id = parsedMesh.id;\r\n if (Tags) {\r\n Tags.AddTagsTo(mesh, parsedMesh.tags);\r\n }\r\n mesh.position = Vector3.FromArray(parsedMesh.position);\r\n if (parsedMesh.metadata !== undefined) {\r\n mesh.metadata = parsedMesh.metadata;\r\n }\r\n if (parsedMesh.rotationQuaternion) {\r\n mesh.rotationQuaternion = Quaternion.FromArray(parsedMesh.rotationQuaternion);\r\n }\r\n else if (parsedMesh.rotation) {\r\n mesh.rotation = Vector3.FromArray(parsedMesh.rotation);\r\n }\r\n mesh.scaling = Vector3.FromArray(parsedMesh.scaling);\r\n if (parsedMesh.localMatrix) {\r\n mesh.setPreTransformMatrix(Matrix.FromArray(parsedMesh.localMatrix));\r\n }\r\n else if (parsedMesh.pivotMatrix) {\r\n mesh.setPivotMatrix(Matrix.FromArray(parsedMesh.pivotMatrix));\r\n }\r\n mesh.setEnabled(parsedMesh.isEnabled);\r\n mesh.isVisible = parsedMesh.isVisible;\r\n mesh.infiniteDistance = parsedMesh.infiniteDistance;\r\n mesh.showBoundingBox = parsedMesh.showBoundingBox;\r\n mesh.showSubMeshesBoundingBox = parsedMesh.showSubMeshesBoundingBox;\r\n if (parsedMesh.applyFog !== undefined) {\r\n mesh.applyFog = parsedMesh.applyFog;\r\n }\r\n if (parsedMesh.pickable !== undefined) {\r\n mesh.isPickable = parsedMesh.pickable;\r\n }\r\n if (parsedMesh.alphaIndex !== undefined) {\r\n mesh.alphaIndex = parsedMesh.alphaIndex;\r\n }\r\n mesh.receiveShadows = parsedMesh.receiveShadows;\r\n mesh.billboardMode = parsedMesh.billboardMode;\r\n if (parsedMesh.visibility !== undefined) {\r\n mesh.visibility = parsedMesh.visibility;\r\n }\r\n mesh.checkCollisions = parsedMesh.checkCollisions;\r\n mesh.overrideMaterialSideOrientation = parsedMesh.overrideMaterialSideOrientation;\r\n if (parsedMesh.isBlocker !== undefined) {\r\n mesh.isBlocker = parsedMesh.isBlocker;\r\n }\r\n mesh._shouldGenerateFlatShading = parsedMesh.useFlatShading;\r\n // freezeWorldMatrix\r\n if (parsedMesh.freezeWorldMatrix) {\r\n mesh._waitingData.freezeWorldMatrix = parsedMesh.freezeWorldMatrix;\r\n }\r\n // Parent\r\n if (parsedMesh.parentId) {\r\n mesh._waitingParentId = parsedMesh.parentId;\r\n }\r\n // Actions\r\n if (parsedMesh.actions !== undefined) {\r\n mesh._waitingData.actions = parsedMesh.actions;\r\n }\r\n // Overlay\r\n if (parsedMesh.overlayAlpha !== undefined) {\r\n mesh.overlayAlpha = parsedMesh.overlayAlpha;\r\n }\r\n if (parsedMesh.overlayColor !== undefined) {\r\n mesh.overlayColor = Color3.FromArray(parsedMesh.overlayColor);\r\n }\r\n if (parsedMesh.renderOverlay !== undefined) {\r\n mesh.renderOverlay = parsedMesh.renderOverlay;\r\n }\r\n // Geometry\r\n mesh.isUnIndexed = !!parsedMesh.isUnIndexed;\r\n mesh.hasVertexAlpha = parsedMesh.hasVertexAlpha;\r\n if (parsedMesh.delayLoadingFile) {\r\n mesh.delayLoadState = 4;\r\n mesh.delayLoadingFile = rootUrl + parsedMesh.delayLoadingFile;\r\n mesh._boundingInfo = new BoundingInfo(Vector3.FromArray(parsedMesh.boundingBoxMinimum), Vector3.FromArray(parsedMesh.boundingBoxMaximum));\r\n if (parsedMesh._binaryInfo) {\r\n mesh._binaryInfo = parsedMesh._binaryInfo;\r\n }\r\n mesh._delayInfo = [];\r\n if (parsedMesh.hasUVs) {\r\n mesh._delayInfo.push(VertexBuffer.UVKind);\r\n }\r\n if (parsedMesh.hasUVs2) {\r\n mesh._delayInfo.push(VertexBuffer.UV2Kind);\r\n }\r\n if (parsedMesh.hasUVs3) {\r\n mesh._delayInfo.push(VertexBuffer.UV3Kind);\r\n }\r\n if (parsedMesh.hasUVs4) {\r\n mesh._delayInfo.push(VertexBuffer.UV4Kind);\r\n }\r\n if (parsedMesh.hasUVs5) {\r\n mesh._delayInfo.push(VertexBuffer.UV5Kind);\r\n }\r\n if (parsedMesh.hasUVs6) {\r\n mesh._delayInfo.push(VertexBuffer.UV6Kind);\r\n }\r\n if (parsedMesh.hasColors) {\r\n mesh._delayInfo.push(VertexBuffer.ColorKind);\r\n }\r\n if (parsedMesh.hasMatricesIndices) {\r\n mesh._delayInfo.push(VertexBuffer.MatricesIndicesKind);\r\n }\r\n if (parsedMesh.hasMatricesWeights) {\r\n mesh._delayInfo.push(VertexBuffer.MatricesWeightsKind);\r\n }\r\n mesh._delayLoadingFunction = Geometry._ImportGeometry;\r\n if (SceneLoaderFlags.ForceFullSceneLoadingForIncremental) {\r\n mesh._checkDelayState();\r\n }\r\n }\r\n else {\r\n Geometry._ImportGeometry(parsedMesh, mesh);\r\n }\r\n // Material\r\n if (parsedMesh.materialId) {\r\n mesh.setMaterialByID(parsedMesh.materialId);\r\n }\r\n else {\r\n mesh.material = null;\r\n }\r\n // Morph targets\r\n if (parsedMesh.morphTargetManagerId > -1) {\r\n mesh.morphTargetManager = scene.getMorphTargetManagerById(parsedMesh.morphTargetManagerId);\r\n }\r\n // Skeleton\r\n if (parsedMesh.skeletonId > -1) {\r\n mesh.skeleton = scene.getLastSkeletonByID(parsedMesh.skeletonId);\r\n if (parsedMesh.numBoneInfluencers) {\r\n mesh.numBoneInfluencers = parsedMesh.numBoneInfluencers;\r\n }\r\n }\r\n // Animations\r\n if (parsedMesh.animations) {\r\n for (var animationIndex = 0; animationIndex < parsedMesh.animations.length; animationIndex++) {\r\n var parsedAnimation = parsedMesh.animations[animationIndex];\r\n var internalClass = _TypeStore.GetClass(\"BABYLON.Animation\");\r\n if (internalClass) {\r\n mesh.animations.push(internalClass.Parse(parsedAnimation));\r\n }\r\n }\r\n Node.ParseAnimationRanges(mesh, parsedMesh, scene);\r\n }\r\n if (parsedMesh.autoAnimate) {\r\n scene.beginAnimation(mesh, parsedMesh.autoAnimateFrom, parsedMesh.autoAnimateTo, parsedMesh.autoAnimateLoop, parsedMesh.autoAnimateSpeed || 1.0);\r\n }\r\n // Layer Mask\r\n if (parsedMesh.layerMask && (!isNaN(parsedMesh.layerMask))) {\r\n mesh.layerMask = Math.abs(parseInt(parsedMesh.layerMask));\r\n }\r\n else {\r\n mesh.layerMask = 0x0FFFFFFF;\r\n }\r\n // Physics\r\n if (parsedMesh.physicsImpostor) {\r\n Mesh._PhysicsImpostorParser(scene, mesh, parsedMesh);\r\n }\r\n // Levels\r\n if (parsedMesh.lodMeshIds) {\r\n mesh._waitingData.lods = {\r\n ids: parsedMesh.lodMeshIds,\r\n distances: (parsedMesh.lodDistances) ? parsedMesh.lodDistances : null,\r\n coverages: (parsedMesh.lodCoverages) ? parsedMesh.lodCoverages : null\r\n };\r\n }\r\n // Instances\r\n if (parsedMesh.instances) {\r\n for (var index = 0; index < parsedMesh.instances.length; index++) {\r\n var parsedInstance = parsedMesh.instances[index];\r\n var instance = mesh.createInstance(parsedInstance.name);\r\n if (parsedInstance.id) {\r\n instance.id = parsedInstance.id;\r\n }\r\n if (Tags) {\r\n if (parsedInstance.tags) {\r\n Tags.AddTagsTo(instance, parsedInstance.tags);\r\n }\r\n else {\r\n Tags.AddTagsTo(instance, parsedMesh.tags);\r\n }\r\n }\r\n instance.position = Vector3.FromArray(parsedInstance.position);\r\n if (parsedInstance.metadata !== undefined) {\r\n instance.metadata = parsedInstance.metadata;\r\n }\r\n if (parsedInstance.parentId) {\r\n instance._waitingParentId = parsedInstance.parentId;\r\n }\r\n if (parsedInstance.rotationQuaternion) {\r\n instance.rotationQuaternion = Quaternion.FromArray(parsedInstance.rotationQuaternion);\r\n }\r\n else if (parsedInstance.rotation) {\r\n instance.rotation = Vector3.FromArray(parsedInstance.rotation);\r\n }\r\n instance.scaling = Vector3.FromArray(parsedInstance.scaling);\r\n if (parsedInstance.checkCollisions != undefined && parsedInstance.checkCollisions != null) {\r\n instance.checkCollisions = parsedInstance.checkCollisions;\r\n }\r\n if (parsedInstance.pickable != undefined && parsedInstance.pickable != null) {\r\n instance.isPickable = parsedInstance.pickable;\r\n }\r\n if (parsedInstance.showBoundingBox != undefined && parsedInstance.showBoundingBox != null) {\r\n instance.showBoundingBox = parsedInstance.showBoundingBox;\r\n }\r\n if (parsedInstance.showSubMeshesBoundingBox != undefined && parsedInstance.showSubMeshesBoundingBox != null) {\r\n instance.showSubMeshesBoundingBox = parsedInstance.showSubMeshesBoundingBox;\r\n }\r\n if (parsedInstance.alphaIndex != undefined && parsedInstance.showSubMeshesBoundingBox != null) {\r\n instance.alphaIndex = parsedInstance.alphaIndex;\r\n }\r\n // Physics\r\n if (parsedInstance.physicsImpostor) {\r\n Mesh._PhysicsImpostorParser(scene, instance, parsedInstance);\r\n }\r\n // Animation\r\n if (parsedInstance.animations) {\r\n for (animationIndex = 0; animationIndex < parsedInstance.animations.length; animationIndex++) {\r\n parsedAnimation = parsedInstance.animations[animationIndex];\r\n var internalClass = _TypeStore.GetClass(\"BABYLON.Animation\");\r\n if (internalClass) {\r\n instance.animations.push(internalClass.Parse(parsedAnimation));\r\n }\r\n }\r\n Node.ParseAnimationRanges(instance, parsedInstance, scene);\r\n if (parsedInstance.autoAnimate) {\r\n scene.beginAnimation(instance, parsedInstance.autoAnimateFrom, parsedInstance.autoAnimateTo, parsedInstance.autoAnimateLoop, parsedInstance.autoAnimateSpeed || 1.0);\r\n }\r\n }\r\n }\r\n }\r\n return mesh;\r\n };\r\n /**\r\n * Creates a ribbon mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @see http://doc.babylonjs.com/how_to/parametric_shapes\r\n * @param name defines the name of the mesh to create\r\n * @param pathArray is a required array of paths, what are each an array of successive Vector3. The pathArray parameter depicts the ribbon geometry.\r\n * @param closeArray creates a seam between the first and the last paths of the path array (default is false)\r\n * @param closePath creates a seam between the first and the last points of each path of the path array\r\n * @param offset is taken in account only if the `pathArray` is containing a single path\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (http://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @param instance defines an instance of an existing Ribbon object to be updated with the passed `pathArray` parameter (http://doc.babylonjs.com/how_to/How_to_dynamically_morph_a_mesh#ribbon)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateRibbon = function (name, pathArray, closeArray, closePath, offset, scene, updatable, sideOrientation, instance) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a plane polygonal mesh. By default, this is a disc. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param radius sets the radius size (float) of the polygon (default 0.5)\r\n * @param tessellation sets the number of polygon sides (positive integer, default 64). So a tessellation valued to 3 will build a triangle, to 4 a square, etc\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (http://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateDisc = function (name, radius, tessellation, scene, updatable, sideOrientation) {\r\n if (scene === void 0) { scene = null; }\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a box mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param size sets the size (float) of each box side (default 1)\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (http://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateBox = function (name, size, scene, updatable, sideOrientation) {\r\n if (scene === void 0) { scene = null; }\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a sphere mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param segments sets the sphere number of horizontal stripes (positive integer, default 32)\r\n * @param diameter sets the diameter size (float) of the sphere (default 1)\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (http://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateSphere = function (name, segments, diameter, scene, updatable, sideOrientation) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a hemisphere mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param segments sets the sphere number of horizontal stripes (positive integer, default 32)\r\n * @param diameter sets the diameter size (float) of the sphere (default 1)\r\n * @param scene defines the hosting scene\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateHemisphere = function (name, segments, diameter, scene) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a cylinder or a cone mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param height sets the height size (float) of the cylinder/cone (float, default 2)\r\n * @param diameterTop set the top cap diameter (floats, default 1)\r\n * @param diameterBottom set the bottom cap diameter (floats, default 1). This value can't be zero\r\n * @param tessellation sets the number of cylinder sides (positive integer, default 24). Set it to 3 to get a prism for instance\r\n * @param subdivisions sets the number of rings along the cylinder height (positive integer, default 1)\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (http://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateCylinder = function (name, height, diameterTop, diameterBottom, tessellation, subdivisions, scene, updatable, sideOrientation) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n // Torus (Code from SharpDX.org)\r\n /**\r\n * Creates a torus mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param diameter sets the diameter size (float) of the torus (default 1)\r\n * @param thickness sets the diameter size of the tube of the torus (float, default 0.5)\r\n * @param tessellation sets the number of torus sides (postive integer, default 16)\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (http://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateTorus = function (name, diameter, thickness, tessellation, scene, updatable, sideOrientation) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a torus knot mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param radius sets the global radius size (float) of the torus knot (default 2)\r\n * @param tube sets the diameter size of the tube of the torus (float, default 0.5)\r\n * @param radialSegments sets the number of sides on each tube segments (positive integer, default 32)\r\n * @param tubularSegments sets the number of tubes to decompose the knot into (positive integer, default 32)\r\n * @param p the number of windings on X axis (positive integers, default 2)\r\n * @param q the number of windings on Y axis (positive integers, default 3)\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (http://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateTorusKnot = function (name, radius, tube, radialSegments, tubularSegments, p, q, scene, updatable, sideOrientation) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a line mesh. Please consider using the same method from the MeshBuilder class instead.\r\n * @param name defines the name of the mesh to create\r\n * @param points is an array successive Vector3\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param instance is an instance of an existing LineMesh object to be updated with the passed `points` parameter (http://doc.babylonjs.com/how_to/How_to_dynamically_morph_a_mesh#lines-and-dashedlines).\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateLines = function (name, points, scene, updatable, instance) {\r\n if (scene === void 0) { scene = null; }\r\n if (updatable === void 0) { updatable = false; }\r\n if (instance === void 0) { instance = null; }\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a dashed line mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param points is an array successive Vector3\r\n * @param dashSize is the size of the dashes relatively the dash number (positive float, default 3)\r\n * @param gapSize is the size of the gap between two successive dashes relatively the dash number (positive float, default 1)\r\n * @param dashNb is the intended total number of dashes (positive integer, default 200)\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param instance is an instance of an existing LineMesh object to be updated with the passed `points` parameter (http://doc.babylonjs.com/how_to/How_to_dynamically_morph_a_mesh#lines-and-dashedlines)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateDashedLines = function (name, points, dashSize, gapSize, dashNb, scene, updatable, instance) {\r\n if (scene === void 0) { scene = null; }\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a polygon mesh.Please consider using the same method from the MeshBuilder class instead\r\n * The polygon's shape will depend on the input parameters and is constructed parallel to a ground mesh.\r\n * The parameter `shape` is a required array of successive Vector3 representing the corners of the polygon in th XoZ plane, that is y = 0 for all vectors.\r\n * You can set the mesh side orientation with the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created.\r\n * Remember you can only change the shape positions, not their number when updating a polygon.\r\n * @see http://doc.babylonjs.com/how_to/parametric_shapes#non-regular-polygon\r\n * @param name defines the name of the mesh to create\r\n * @param shape is a required array of successive Vector3 representing the corners of the polygon in th XoZ plane, that is y = 0 for all vectors\r\n * @param scene defines the hosting scene\r\n * @param holes is a required array of arrays of successive Vector3 used to defines holes in the polygon\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (http://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @param earcutInjection can be used to inject your own earcut reference\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreatePolygon = function (name, shape, scene, holes, updatable, sideOrientation, earcutInjection) {\r\n if (earcutInjection === void 0) { earcutInjection = earcut; }\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates an extruded polygon mesh, with depth in the Y direction. Please consider using the same method from the MeshBuilder class instead.\r\n * @see http://doc.babylonjs.com/how_to/parametric_shapes#extruded-non-regular-polygon\r\n * @param name defines the name of the mesh to create\r\n * @param shape is a required array of successive Vector3 representing the corners of the polygon in th XoZ plane, that is y = 0 for all vectors\r\n * @param depth defines the height of extrusion\r\n * @param scene defines the hosting scene\r\n * @param holes is a required array of arrays of successive Vector3 used to defines holes in the polygon\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (http://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @param earcutInjection can be used to inject your own earcut reference\r\n * @returns a new Mesh\r\n */\r\n Mesh.ExtrudePolygon = function (name, shape, depth, scene, holes, updatable, sideOrientation, earcutInjection) {\r\n if (earcutInjection === void 0) { earcutInjection = earcut; }\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates an extruded shape mesh.\r\n * The extrusion is a parametric shape. It has no predefined shape. Its final shape will depend on the input parameters. Please consider using the same method from the MeshBuilder class instead\r\n * @see http://doc.babylonjs.com/how_to/parametric_shapes\r\n * @see http://doc.babylonjs.com/how_to/parametric_shapes#extruded-shapes\r\n * @param name defines the name of the mesh to create\r\n * @param shape is a required array of successive Vector3. This array depicts the shape to be extruded in its local space : the shape must be designed in the xOy plane and will be extruded along the Z axis\r\n * @param path is a required array of successive Vector3. This is the axis curve the shape is extruded along\r\n * @param scale is the value to scale the shape\r\n * @param rotation is the angle value to rotate the shape each step (each path point), from the former step (so rotation added each step) along the curve\r\n * @param cap sets the way the extruded shape is capped. Possible values : Mesh.NO_CAP (default), Mesh.CAP_START, Mesh.CAP_END, Mesh.CAP_ALL\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (http://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @param instance is an instance of an existing ExtrudedShape object to be updated with the passed `shape`, `path`, `scale` or `rotation` parameters (http://doc.babylonjs.com/how_to/How_to_dynamically_morph_a_mesh#extruded-shape)\r\n * @returns a new Mesh\r\n */\r\n Mesh.ExtrudeShape = function (name, shape, path, scale, rotation, cap, scene, updatable, sideOrientation, instance) {\r\n if (scene === void 0) { scene = null; }\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates an custom extruded shape mesh.\r\n * The custom extrusion is a parametric shape.\r\n * It has no predefined shape. Its final shape will depend on the input parameters.\r\n * Please consider using the same method from the MeshBuilder class instead\r\n * @see http://doc.babylonjs.com/how_to/parametric_shapes#extruded-shapes\r\n * @param name defines the name of the mesh to create\r\n * @param shape is a required array of successive Vector3. This array depicts the shape to be extruded in its local space : the shape must be designed in the xOy plane and will be extruded along the Z axis\r\n * @param path is a required array of successive Vector3. This is the axis curve the shape is extruded along\r\n * @param scaleFunction is a custom Javascript function called on each path point\r\n * @param rotationFunction is a custom Javascript function called on each path point\r\n * @param ribbonCloseArray forces the extrusion underlying ribbon to close all the paths in its `pathArray`\r\n * @param ribbonClosePath forces the extrusion underlying ribbon to close its `pathArray`\r\n * @param cap sets the way the extruded shape is capped. Possible values : Mesh.NO_CAP (default), Mesh.CAP_START, Mesh.CAP_END, Mesh.CAP_ALL\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (http://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @param instance is an instance of an existing ExtrudedShape object to be updated with the passed `shape`, `path`, `scale` or `rotation` parameters (http://doc.babylonjs.com/how_to/how_to_dynamically_morph_a_mesh#extruded-shape)\r\n * @returns a new Mesh\r\n */\r\n Mesh.ExtrudeShapeCustom = function (name, shape, path, scaleFunction, rotationFunction, ribbonCloseArray, ribbonClosePath, cap, scene, updatable, sideOrientation, instance) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates lathe mesh.\r\n * The lathe is a shape with a symetry axis : a 2D model shape is rotated around this axis to design the lathe.\r\n * Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param shape is a required array of successive Vector3. This array depicts the shape to be rotated in its local space : the shape must be designed in the xOy plane and will be rotated around the Y axis. It's usually a 2D shape, so the Vector3 z coordinates are often set to zero\r\n * @param radius is the radius value of the lathe\r\n * @param tessellation is the side number of the lathe.\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (http://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateLathe = function (name, shape, radius, tessellation, scene, updatable, sideOrientation) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a plane mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param size sets the size (float) of both sides of the plane at once (default 1)\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (http://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreatePlane = function (name, size, scene, updatable, sideOrientation) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a ground mesh.\r\n * Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param width set the width of the ground\r\n * @param height set the height of the ground\r\n * @param subdivisions sets the number of subdivisions per side\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateGround = function (name, width, height, subdivisions, scene, updatable) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a tiled ground mesh.\r\n * Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param xmin set the ground minimum X coordinate\r\n * @param zmin set the ground minimum Y coordinate\r\n * @param xmax set the ground maximum X coordinate\r\n * @param zmax set the ground maximum Z coordinate\r\n * @param subdivisions is an object `{w: positive integer, h: positive integer}` (default `{w: 6, h: 6}`). `w` and `h` are the numbers of subdivisions on the ground width and height. Each subdivision is called a tile\r\n * @param precision is an object `{w: positive integer, h: positive integer}` (default `{w: 2, h: 2}`). `w` and `h` are the numbers of subdivisions on the ground width and height of each tile\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateTiledGround = function (name, xmin, zmin, xmax, zmax, subdivisions, precision, scene, updatable) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a ground mesh from a height map.\r\n * Please consider using the same method from the MeshBuilder class instead\r\n * @see http://doc.babylonjs.com/babylon101/height_map\r\n * @param name defines the name of the mesh to create\r\n * @param url sets the URL of the height map image resource\r\n * @param width set the ground width size\r\n * @param height set the ground height size\r\n * @param subdivisions sets the number of subdivision per side\r\n * @param minHeight is the minimum altitude on the ground\r\n * @param maxHeight is the maximum altitude on the ground\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param onReady is a callback function that will be called once the mesh is built (the height map download can last some time)\r\n * @param alphaFilter will filter any data where the alpha channel is below this value, defaults 0 (all data visible)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateGroundFromHeightMap = function (name, url, width, height, subdivisions, minHeight, maxHeight, scene, updatable, onReady, alphaFilter) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a tube mesh.\r\n * The tube is a parametric shape.\r\n * It has no predefined shape. Its final shape will depend on the input parameters.\r\n * Please consider using the same method from the MeshBuilder class instead\r\n * @see http://doc.babylonjs.com/how_to/parametric_shapes\r\n * @param name defines the name of the mesh to create\r\n * @param path is a required array of successive Vector3. It is the curve used as the axis of the tube\r\n * @param radius sets the tube radius size\r\n * @param tessellation is the number of sides on the tubular surface\r\n * @param radiusFunction is a custom function. If it is not null, it overwrittes the parameter `radius`. This function is called on each point of the tube path and is passed the index `i` of the i-th point and the distance of this point from the first point of the path\r\n * @param cap sets the way the extruded shape is capped. Possible values : Mesh.NO_CAP (default), Mesh.CAP_START, Mesh.CAP_END, Mesh.CAP_ALL\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (http://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @param instance is an instance of an existing Tube object to be updated with the passed `pathArray` parameter (http://doc.babylonjs.com/how_to/How_to_dynamically_morph_a_mesh#tube)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateTube = function (name, path, radius, tessellation, radiusFunction, cap, scene, updatable, sideOrientation, instance) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a polyhedron mesh.\r\n * Please consider using the same method from the MeshBuilder class instead.\r\n * * The parameter `type` (positive integer, max 14, default 0) sets the polyhedron type to build among the 15 embbeded types. Please refer to the type sheet in the tutorial to choose the wanted type\r\n * * The parameter `size` (positive float, default 1) sets the polygon size\r\n * * You can overwrite the `size` on each dimension bu using the parameters `sizeX`, `sizeY` or `sizeZ` (positive floats, default to `size` value)\r\n * * You can build other polyhedron types than the 15 embbeded ones by setting the parameter `custom` (`polyhedronObject`, default null). If you set the parameter `custom`, this overwrittes the parameter `type`\r\n * * A `polyhedronObject` is a formatted javascript object. You'll find a full file with pre-set polyhedra here : https://github.com/BabylonJS/Extensions/tree/master/Polyhedron\r\n * * You can set the color and the UV of each side of the polyhedron with the parameters `faceColors` (Color4, default `(1, 1, 1, 1)`) and faceUV (Vector4, default `(0, 0, 1, 1)`)\r\n * * To understand how to set `faceUV` or `faceColors`, please read this by considering the right number of faces of your polyhedron, instead of only 6 for the box : https://doc.babylonjs.com/how_to/createbox_per_face_textures_and_colors\r\n * * The parameter `flat` (boolean, default true). If set to false, it gives the polyhedron a single global face, so less vertices and shared normals. In this case, `faceColors` and `faceUV` are ignored\r\n * * You can also set the mesh side orientation with the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * If you create a double-sided mesh, you can choose what parts of the texture image to crop and stick respectively on the front and the back sides with the parameters `frontUVs` and `backUVs` (Vector4). Detail here : http://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @param name defines the name of the mesh to create\r\n * @param options defines the options used to create the mesh\r\n * @param scene defines the hosting scene\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreatePolyhedron = function (name, options, scene) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a sphere based upon an icosahedron with 20 triangular faces which can be subdivided\r\n * * The parameter `radius` sets the radius size (float) of the icosphere (default 1)\r\n * * You can set some different icosphere dimensions, for instance to build an ellipsoid, by using the parameters `radiusX`, `radiusY` and `radiusZ` (all by default have the same value than `radius`)\r\n * * The parameter `subdivisions` sets the number of subdivisions (postive integer, default 4). The more subdivisions, the more faces on the icosphere whatever its size\r\n * * The parameter `flat` (boolean, default true) gives each side its own normals. Set it to false to get a smooth continuous light reflection on the surface\r\n * * You can also set the mesh side orientation with the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * If you create a double-sided mesh, you can choose what parts of the texture image to crop and stick respectively on the front and the back sides with the parameters `frontUVs` and `backUVs` (Vector4). Detail here : http://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @param name defines the name of the mesh\r\n * @param options defines the options used to create the mesh\r\n * @param scene defines the hosting scene\r\n * @returns a new Mesh\r\n * @see http://doc.babylonjs.com/how_to/polyhedra_shapes#icosphere\r\n */\r\n Mesh.CreateIcoSphere = function (name, options, scene) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a decal mesh.\r\n * Please consider using the same method from the MeshBuilder class instead.\r\n * A decal is a mesh usually applied as a model onto the surface of another mesh\r\n * @param name defines the name of the mesh\r\n * @param sourceMesh defines the mesh receiving the decal\r\n * @param position sets the position of the decal in world coordinates\r\n * @param normal sets the normal of the mesh where the decal is applied onto in world coordinates\r\n * @param size sets the decal scaling\r\n * @param angle sets the angle to rotate the decal\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateDecal = function (name, sourceMesh, position, normal, size, angle) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n // Skeletons\r\n /**\r\n * Prepare internal position array for software CPU skinning\r\n * @returns original positions used for CPU skinning. Useful for integrating Morphing with skeletons in same mesh\r\n */\r\n Mesh.prototype.setPositionsForCPUSkinning = function () {\r\n var internalDataInfo = this._internalMeshDataInfo;\r\n if (!internalDataInfo._sourcePositions) {\r\n var source = this.getVerticesData(VertexBuffer.PositionKind);\r\n if (!source) {\r\n return internalDataInfo._sourcePositions;\r\n }\r\n internalDataInfo._sourcePositions = new Float32Array(source);\r\n if (!this.isVertexBufferUpdatable(VertexBuffer.PositionKind)) {\r\n this.setVerticesData(VertexBuffer.PositionKind, source, true);\r\n }\r\n }\r\n return internalDataInfo._sourcePositions;\r\n };\r\n /**\r\n * Prepare internal normal array for software CPU skinning\r\n * @returns original normals used for CPU skinning. Useful for integrating Morphing with skeletons in same mesh.\r\n */\r\n Mesh.prototype.setNormalsForCPUSkinning = function () {\r\n var internalDataInfo = this._internalMeshDataInfo;\r\n if (!internalDataInfo._sourceNormals) {\r\n var source = this.getVerticesData(VertexBuffer.NormalKind);\r\n if (!source) {\r\n return internalDataInfo._sourceNormals;\r\n }\r\n internalDataInfo._sourceNormals = new Float32Array(source);\r\n if (!this.isVertexBufferUpdatable(VertexBuffer.NormalKind)) {\r\n this.setVerticesData(VertexBuffer.NormalKind, source, true);\r\n }\r\n }\r\n return internalDataInfo._sourceNormals;\r\n };\r\n /**\r\n * Updates the vertex buffer by applying transformation from the bones\r\n * @param skeleton defines the skeleton to apply to current mesh\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.applySkeleton = function (skeleton) {\r\n if (!this.geometry) {\r\n return this;\r\n }\r\n if (this.geometry._softwareSkinningFrameId == this.getScene().getFrameId()) {\r\n return this;\r\n }\r\n this.geometry._softwareSkinningFrameId = this.getScene().getFrameId();\r\n if (!this.isVerticesDataPresent(VertexBuffer.PositionKind)) {\r\n return this;\r\n }\r\n if (!this.isVerticesDataPresent(VertexBuffer.NormalKind)) {\r\n return this;\r\n }\r\n if (!this.isVerticesDataPresent(VertexBuffer.MatricesIndicesKind)) {\r\n return this;\r\n }\r\n if (!this.isVerticesDataPresent(VertexBuffer.MatricesWeightsKind)) {\r\n return this;\r\n }\r\n var internalDataInfo = this._internalMeshDataInfo;\r\n if (!internalDataInfo._sourcePositions) {\r\n var submeshes = this.subMeshes.slice();\r\n this.setPositionsForCPUSkinning();\r\n this.subMeshes = submeshes;\r\n }\r\n if (!internalDataInfo._sourceNormals) {\r\n this.setNormalsForCPUSkinning();\r\n }\r\n // positionsData checks for not being Float32Array will only pass at most once\r\n var positionsData = this.getVerticesData(VertexBuffer.PositionKind);\r\n if (!positionsData) {\r\n return this;\r\n }\r\n if (!(positionsData instanceof Float32Array)) {\r\n positionsData = new Float32Array(positionsData);\r\n }\r\n // normalsData checks for not being Float32Array will only pass at most once\r\n var normalsData = this.getVerticesData(VertexBuffer.NormalKind);\r\n if (!normalsData) {\r\n return this;\r\n }\r\n if (!(normalsData instanceof Float32Array)) {\r\n normalsData = new Float32Array(normalsData);\r\n }\r\n var matricesIndicesData = this.getVerticesData(VertexBuffer.MatricesIndicesKind);\r\n var matricesWeightsData = this.getVerticesData(VertexBuffer.MatricesWeightsKind);\r\n if (!matricesWeightsData || !matricesIndicesData) {\r\n return this;\r\n }\r\n var needExtras = this.numBoneInfluencers > 4;\r\n var matricesIndicesExtraData = needExtras ? this.getVerticesData(VertexBuffer.MatricesIndicesExtraKind) : null;\r\n var matricesWeightsExtraData = needExtras ? this.getVerticesData(VertexBuffer.MatricesWeightsExtraKind) : null;\r\n var skeletonMatrices = skeleton.getTransformMatrices(this);\r\n var tempVector3 = Vector3.Zero();\r\n var finalMatrix = new Matrix();\r\n var tempMatrix = new Matrix();\r\n var matWeightIdx = 0;\r\n var inf;\r\n for (var index = 0; index < positionsData.length; index += 3, matWeightIdx += 4) {\r\n var weight;\r\n for (inf = 0; inf < 4; inf++) {\r\n weight = matricesWeightsData[matWeightIdx + inf];\r\n if (weight > 0) {\r\n Matrix.FromFloat32ArrayToRefScaled(skeletonMatrices, Math.floor(matricesIndicesData[matWeightIdx + inf] * 16), weight, tempMatrix);\r\n finalMatrix.addToSelf(tempMatrix);\r\n }\r\n }\r\n if (needExtras) {\r\n for (inf = 0; inf < 4; inf++) {\r\n weight = matricesWeightsExtraData[matWeightIdx + inf];\r\n if (weight > 0) {\r\n Matrix.FromFloat32ArrayToRefScaled(skeletonMatrices, Math.floor(matricesIndicesExtraData[matWeightIdx + inf] * 16), weight, tempMatrix);\r\n finalMatrix.addToSelf(tempMatrix);\r\n }\r\n }\r\n }\r\n Vector3.TransformCoordinatesFromFloatsToRef(internalDataInfo._sourcePositions[index], internalDataInfo._sourcePositions[index + 1], internalDataInfo._sourcePositions[index + 2], finalMatrix, tempVector3);\r\n tempVector3.toArray(positionsData, index);\r\n Vector3.TransformNormalFromFloatsToRef(internalDataInfo._sourceNormals[index], internalDataInfo._sourceNormals[index + 1], internalDataInfo._sourceNormals[index + 2], finalMatrix, tempVector3);\r\n tempVector3.toArray(normalsData, index);\r\n finalMatrix.reset();\r\n }\r\n this.updateVerticesData(VertexBuffer.PositionKind, positionsData);\r\n this.updateVerticesData(VertexBuffer.NormalKind, normalsData);\r\n return this;\r\n };\r\n // Tools\r\n /**\r\n * Returns an object containing a min and max Vector3 which are the minimum and maximum vectors of each mesh bounding box from the passed array, in the world coordinates\r\n * @param meshes defines the list of meshes to scan\r\n * @returns an object `{min:` Vector3`, max:` Vector3`}`\r\n */\r\n Mesh.MinMax = function (meshes) {\r\n var minVector = null;\r\n var maxVector = null;\r\n meshes.forEach(function (mesh) {\r\n var boundingInfo = mesh.getBoundingInfo();\r\n var boundingBox = boundingInfo.boundingBox;\r\n if (!minVector || !maxVector) {\r\n minVector = boundingBox.minimumWorld;\r\n maxVector = boundingBox.maximumWorld;\r\n }\r\n else {\r\n minVector.minimizeInPlace(boundingBox.minimumWorld);\r\n maxVector.maximizeInPlace(boundingBox.maximumWorld);\r\n }\r\n });\r\n if (!minVector || !maxVector) {\r\n return {\r\n min: Vector3.Zero(),\r\n max: Vector3.Zero()\r\n };\r\n }\r\n return {\r\n min: minVector,\r\n max: maxVector\r\n };\r\n };\r\n /**\r\n * Returns the center of the `{min:` Vector3`, max:` Vector3`}` or the center of MinMax vector3 computed from a mesh array\r\n * @param meshesOrMinMaxVector could be an array of meshes or a `{min:` Vector3`, max:` Vector3`}` object\r\n * @returns a vector3\r\n */\r\n Mesh.Center = function (meshesOrMinMaxVector) {\r\n var minMaxVector = (meshesOrMinMaxVector instanceof Array) ? Mesh.MinMax(meshesOrMinMaxVector) : meshesOrMinMaxVector;\r\n return Vector3.Center(minMaxVector.min, minMaxVector.max);\r\n };\r\n /**\r\n * Merge the array of meshes into a single mesh for performance reasons.\r\n * @param meshes defines he vertices source. They should all be of the same material. Entries can empty\r\n * @param disposeSource when true (default), dispose of the vertices from the source meshes\r\n * @param allow32BitsIndices when the sum of the vertices > 64k, this must be set to true\r\n * @param meshSubclass when set, vertices inserted into this Mesh. Meshes can then be merged into a Mesh sub-class.\r\n * @param subdivideWithSubMeshes when true (false default), subdivide mesh to his subMesh array with meshes source.\r\n * @param multiMultiMaterials when true (false default), subdivide mesh and accept multiple multi materials, ignores subdivideWithSubMeshes.\r\n * @returns a new mesh\r\n */\r\n Mesh.MergeMeshes = function (meshes, disposeSource, allow32BitsIndices, meshSubclass, subdivideWithSubMeshes, multiMultiMaterials) {\r\n if (disposeSource === void 0) { disposeSource = true; }\r\n var index;\r\n if (!allow32BitsIndices) {\r\n var totalVertices = 0;\r\n // Counting vertices\r\n for (index = 0; index < meshes.length; index++) {\r\n if (meshes[index]) {\r\n totalVertices += meshes[index].getTotalVertices();\r\n if (totalVertices >= 65536) {\r\n Logger.Warn(\"Cannot merge meshes because resulting mesh will have more than 65536 vertices. Please use allow32BitsIndices = true to use 32 bits indices\");\r\n return null;\r\n }\r\n }\r\n }\r\n }\r\n if (multiMultiMaterials) {\r\n var newMultiMaterial = null;\r\n var subIndex;\r\n var matIndex;\r\n subdivideWithSubMeshes = false;\r\n }\r\n var materialArray = new Array();\r\n var materialIndexArray = new Array();\r\n // Merge\r\n var vertexData = null;\r\n var otherVertexData;\r\n var indiceArray = new Array();\r\n var source = null;\r\n for (index = 0; index < meshes.length; index++) {\r\n if (meshes[index]) {\r\n var mesh = meshes[index];\r\n if (mesh.isAnInstance) {\r\n Logger.Warn(\"Cannot merge instance meshes.\");\r\n return null;\r\n }\r\n var wm = mesh.computeWorldMatrix(true);\r\n otherVertexData = VertexData.ExtractFromMesh(mesh, true, true);\r\n otherVertexData.transform(wm);\r\n if (vertexData) {\r\n vertexData.merge(otherVertexData, allow32BitsIndices);\r\n }\r\n else {\r\n vertexData = otherVertexData;\r\n source = mesh;\r\n }\r\n if (subdivideWithSubMeshes) {\r\n indiceArray.push(mesh.getTotalIndices());\r\n }\r\n if (multiMultiMaterials) {\r\n if (mesh.material) {\r\n var material = mesh.material;\r\n if (material instanceof MultiMaterial) {\r\n for (matIndex = 0; matIndex < material.subMaterials.length; matIndex++) {\r\n if (materialArray.indexOf(material.subMaterials[matIndex]) < 0) {\r\n materialArray.push(material.subMaterials[matIndex]);\r\n }\r\n }\r\n for (subIndex = 0; subIndex < mesh.subMeshes.length; subIndex++) {\r\n materialIndexArray.push(materialArray.indexOf(material.subMaterials[mesh.subMeshes[subIndex].materialIndex]));\r\n indiceArray.push(mesh.subMeshes[subIndex].indexCount);\r\n }\r\n }\r\n else {\r\n if (materialArray.indexOf(material) < 0) {\r\n materialArray.push(material);\r\n }\r\n for (subIndex = 0; subIndex < mesh.subMeshes.length; subIndex++) {\r\n materialIndexArray.push(materialArray.indexOf(material));\r\n indiceArray.push(mesh.subMeshes[subIndex].indexCount);\r\n }\r\n }\r\n }\r\n else {\r\n for (subIndex = 0; subIndex < mesh.subMeshes.length; subIndex++) {\r\n materialIndexArray.push(0);\r\n indiceArray.push(mesh.subMeshes[subIndex].indexCount);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n source = source;\r\n if (!meshSubclass) {\r\n meshSubclass = new Mesh(source.name + \"_merged\", source.getScene());\r\n }\r\n vertexData.applyToMesh(meshSubclass);\r\n // Setting properties\r\n meshSubclass.checkCollisions = source.checkCollisions;\r\n // Cleaning\r\n if (disposeSource) {\r\n for (index = 0; index < meshes.length; index++) {\r\n if (meshes[index]) {\r\n meshes[index].dispose();\r\n }\r\n }\r\n }\r\n // Subdivide\r\n if (subdivideWithSubMeshes || multiMultiMaterials) {\r\n //-- removal of global submesh\r\n meshSubclass.releaseSubMeshes();\r\n index = 0;\r\n var offset = 0;\r\n //-- apply subdivision according to index table\r\n while (index < indiceArray.length) {\r\n SubMesh.CreateFromIndices(0, offset, indiceArray[index], meshSubclass);\r\n offset += indiceArray[index];\r\n index++;\r\n }\r\n }\r\n if (multiMultiMaterials) {\r\n newMultiMaterial = new MultiMaterial(source.name + \"_merged\", source.getScene());\r\n newMultiMaterial.subMaterials = materialArray;\r\n for (subIndex = 0; subIndex < meshSubclass.subMeshes.length; subIndex++) {\r\n meshSubclass.subMeshes[subIndex].materialIndex = materialIndexArray[subIndex];\r\n }\r\n meshSubclass.material = newMultiMaterial;\r\n }\r\n else {\r\n meshSubclass.material = source.material;\r\n }\r\n return meshSubclass;\r\n };\r\n /** @hidden */\r\n Mesh.prototype.addInstance = function (instance) {\r\n instance._indexInSourceMeshInstanceArray = this.instances.length;\r\n this.instances.push(instance);\r\n };\r\n /** @hidden */\r\n Mesh.prototype.removeInstance = function (instance) {\r\n // Remove from mesh\r\n var index = instance._indexInSourceMeshInstanceArray;\r\n if (index != -1) {\r\n if (index !== this.instances.length - 1) {\r\n var last = this.instances[this.instances.length - 1];\r\n this.instances[index] = last;\r\n last._indexInSourceMeshInstanceArray = index;\r\n }\r\n instance._indexInSourceMeshInstanceArray = -1;\r\n this.instances.pop();\r\n }\r\n };\r\n // Consts\r\n /**\r\n * Mesh side orientation : usually the external or front surface\r\n */\r\n Mesh.FRONTSIDE = VertexData.FRONTSIDE;\r\n /**\r\n * Mesh side orientation : usually the internal or back surface\r\n */\r\n Mesh.BACKSIDE = VertexData.BACKSIDE;\r\n /**\r\n * Mesh side orientation : both internal and external or front and back surfaces\r\n */\r\n Mesh.DOUBLESIDE = VertexData.DOUBLESIDE;\r\n /**\r\n * Mesh side orientation : by default, `FRONTSIDE`\r\n */\r\n Mesh.DEFAULTSIDE = VertexData.DEFAULTSIDE;\r\n /**\r\n * Mesh cap setting : no cap\r\n */\r\n Mesh.NO_CAP = 0;\r\n /**\r\n * Mesh cap setting : one cap at the beginning of the mesh\r\n */\r\n Mesh.CAP_START = 1;\r\n /**\r\n * Mesh cap setting : one cap at the end of the mesh\r\n */\r\n Mesh.CAP_END = 2;\r\n /**\r\n * Mesh cap setting : two caps, one at the beginning and one at the end of the mesh\r\n */\r\n Mesh.CAP_ALL = 3;\r\n /**\r\n * Mesh pattern setting : no flip or rotate\r\n */\r\n Mesh.NO_FLIP = 0;\r\n /**\r\n * Mesh pattern setting : flip (reflect in y axis) alternate tiles on each row or column\r\n */\r\n Mesh.FLIP_TILE = 1;\r\n /**\r\n * Mesh pattern setting : rotate (180degs) alternate tiles on each row or column\r\n */\r\n Mesh.ROTATE_TILE = 2;\r\n /**\r\n * Mesh pattern setting : flip (reflect in y axis) all tiles on alternate rows\r\n */\r\n Mesh.FLIP_ROW = 3;\r\n /**\r\n * Mesh pattern setting : rotate (180degs) all tiles on alternate rows\r\n */\r\n Mesh.ROTATE_ROW = 4;\r\n /**\r\n * Mesh pattern setting : flip and rotate alternate tiles on each row or column\r\n */\r\n Mesh.FLIP_N_ROTATE_TILE = 5;\r\n /**\r\n * Mesh pattern setting : rotate pattern and rotate\r\n */\r\n Mesh.FLIP_N_ROTATE_ROW = 6;\r\n /**\r\n * Mesh tile positioning : part tiles same on left/right or top/bottom\r\n */\r\n Mesh.CENTER = 0;\r\n /**\r\n * Mesh tile positioning : part tiles on left\r\n */\r\n Mesh.LEFT = 1;\r\n /**\r\n * Mesh tile positioning : part tiles on right\r\n */\r\n Mesh.RIGHT = 2;\r\n /**\r\n * Mesh tile positioning : part tiles on top\r\n */\r\n Mesh.TOP = 3;\r\n /**\r\n * Mesh tile positioning : part tiles on bottom\r\n */\r\n Mesh.BOTTOM = 4;\r\n // Statics\r\n /** @hidden */\r\n Mesh._GroundMeshParser = function (parsedMesh, scene) {\r\n throw _DevTools.WarnImport(\"GroundMesh\");\r\n };\r\n return Mesh;\r\n}(AbstractMesh));\r\nexport { Mesh };\r\n//# sourceMappingURL=mesh.js.map","/**\r\n * Constant used to convert a value to gamma space\r\n * @ignorenaming\r\n */\r\nexport var ToGammaSpace = 1 / 2.2;\r\n/**\r\n * Constant used to convert a value to linear space\r\n * @ignorenaming\r\n */\r\nexport var ToLinearSpace = 2.2;\r\n/**\r\n * Constant used to define the minimal number value in Babylon.js\r\n * @ignorenaming\r\n */\r\nvar Epsilon = 0.001;\r\nexport { Epsilon };\r\n//# sourceMappingURL=math.constants.js.map","/**\r\n * Scalar computation library\r\n */\r\nvar Scalar = /** @class */ (function () {\r\n function Scalar() {\r\n }\r\n /**\r\n * Boolean : true if the absolute difference between a and b is lower than epsilon (default = 1.401298E-45)\r\n * @param a number\r\n * @param b number\r\n * @param epsilon (default = 1.401298E-45)\r\n * @returns true if the absolute difference between a and b is lower than epsilon (default = 1.401298E-45)\r\n */\r\n Scalar.WithinEpsilon = function (a, b, epsilon) {\r\n if (epsilon === void 0) { epsilon = 1.401298E-45; }\r\n var num = a - b;\r\n return -epsilon <= num && num <= epsilon;\r\n };\r\n /**\r\n * Returns a string : the upper case translation of the number i to hexadecimal.\r\n * @param i number\r\n * @returns the upper case translation of the number i to hexadecimal.\r\n */\r\n Scalar.ToHex = function (i) {\r\n var str = i.toString(16);\r\n if (i <= 15) {\r\n return (\"0\" + str).toUpperCase();\r\n }\r\n return str.toUpperCase();\r\n };\r\n /**\r\n * Returns -1 if value is negative and +1 is value is positive.\r\n * @param value the value\r\n * @returns the value itself if it's equal to zero.\r\n */\r\n Scalar.Sign = function (value) {\r\n value = +value; // convert to a number\r\n if (value === 0 || isNaN(value)) {\r\n return value;\r\n }\r\n return value > 0 ? 1 : -1;\r\n };\r\n /**\r\n * Returns the value itself if it's between min and max.\r\n * Returns min if the value is lower than min.\r\n * Returns max if the value is greater than max.\r\n * @param value the value to clmap\r\n * @param min the min value to clamp to (default: 0)\r\n * @param max the max value to clamp to (default: 1)\r\n * @returns the clamped value\r\n */\r\n Scalar.Clamp = function (value, min, max) {\r\n if (min === void 0) { min = 0; }\r\n if (max === void 0) { max = 1; }\r\n return Math.min(max, Math.max(min, value));\r\n };\r\n /**\r\n * the log2 of value.\r\n * @param value the value to compute log2 of\r\n * @returns the log2 of value.\r\n */\r\n Scalar.Log2 = function (value) {\r\n return Math.log(value) * Math.LOG2E;\r\n };\r\n /**\r\n * Loops the value, so that it is never larger than length and never smaller than 0.\r\n *\r\n * This is similar to the modulo operator but it works with floating point numbers.\r\n * For example, using 3.0 for t and 2.5 for length, the result would be 0.5.\r\n * With t = 5 and length = 2.5, the result would be 0.0.\r\n * Note, however, that the behaviour is not defined for negative numbers as it is for the modulo operator\r\n * @param value the value\r\n * @param length the length\r\n * @returns the looped value\r\n */\r\n Scalar.Repeat = function (value, length) {\r\n return value - Math.floor(value / length) * length;\r\n };\r\n /**\r\n * Normalize the value between 0.0 and 1.0 using min and max values\r\n * @param value value to normalize\r\n * @param min max to normalize between\r\n * @param max min to normalize between\r\n * @returns the normalized value\r\n */\r\n Scalar.Normalize = function (value, min, max) {\r\n return (value - min) / (max - min);\r\n };\r\n /**\r\n * Denormalize the value from 0.0 and 1.0 using min and max values\r\n * @param normalized value to denormalize\r\n * @param min max to denormalize between\r\n * @param max min to denormalize between\r\n * @returns the denormalized value\r\n */\r\n Scalar.Denormalize = function (normalized, min, max) {\r\n return (normalized * (max - min) + min);\r\n };\r\n /**\r\n * Calculates the shortest difference between two given angles given in degrees.\r\n * @param current current angle in degrees\r\n * @param target target angle in degrees\r\n * @returns the delta\r\n */\r\n Scalar.DeltaAngle = function (current, target) {\r\n var num = Scalar.Repeat(target - current, 360.0);\r\n if (num > 180.0) {\r\n num -= 360.0;\r\n }\r\n return num;\r\n };\r\n /**\r\n * PingPongs the value t, so that it is never larger than length and never smaller than 0.\r\n * @param tx value\r\n * @param length length\r\n * @returns The returned value will move back and forth between 0 and length\r\n */\r\n Scalar.PingPong = function (tx, length) {\r\n var t = Scalar.Repeat(tx, length * 2.0);\r\n return length - Math.abs(t - length);\r\n };\r\n /**\r\n * Interpolates between min and max with smoothing at the limits.\r\n *\r\n * This function interpolates between min and max in a similar way to Lerp. However, the interpolation will gradually speed up\r\n * from the start and slow down toward the end. This is useful for creating natural-looking animation, fading and other transitions.\r\n * @param from from\r\n * @param to to\r\n * @param tx value\r\n * @returns the smooth stepped value\r\n */\r\n Scalar.SmoothStep = function (from, to, tx) {\r\n var t = Scalar.Clamp(tx);\r\n t = -2.0 * t * t * t + 3.0 * t * t;\r\n return to * t + from * (1.0 - t);\r\n };\r\n /**\r\n * Moves a value current towards target.\r\n *\r\n * This is essentially the same as Mathf.Lerp but instead the function will ensure that the speed never exceeds maxDelta.\r\n * Negative values of maxDelta pushes the value away from target.\r\n * @param current current value\r\n * @param target target value\r\n * @param maxDelta max distance to move\r\n * @returns resulting value\r\n */\r\n Scalar.MoveTowards = function (current, target, maxDelta) {\r\n var result = 0;\r\n if (Math.abs(target - current) <= maxDelta) {\r\n result = target;\r\n }\r\n else {\r\n result = current + Scalar.Sign(target - current) * maxDelta;\r\n }\r\n return result;\r\n };\r\n /**\r\n * Same as MoveTowards but makes sure the values interpolate correctly when they wrap around 360 degrees.\r\n *\r\n * Variables current and target are assumed to be in degrees. For optimization reasons, negative values of maxDelta\r\n * are not supported and may cause oscillation. To push current away from a target angle, add 180 to that angle instead.\r\n * @param current current value\r\n * @param target target value\r\n * @param maxDelta max distance to move\r\n * @returns resulting angle\r\n */\r\n Scalar.MoveTowardsAngle = function (current, target, maxDelta) {\r\n var num = Scalar.DeltaAngle(current, target);\r\n var result = 0;\r\n if (-maxDelta < num && num < maxDelta) {\r\n result = target;\r\n }\r\n else {\r\n target = current + num;\r\n result = Scalar.MoveTowards(current, target, maxDelta);\r\n }\r\n return result;\r\n };\r\n /**\r\n * Creates a new scalar with values linearly interpolated of \"amount\" between the start scalar and the end scalar.\r\n * @param start start value\r\n * @param end target value\r\n * @param amount amount to lerp between\r\n * @returns the lerped value\r\n */\r\n Scalar.Lerp = function (start, end, amount) {\r\n return start + ((end - start) * amount);\r\n };\r\n /**\r\n * Same as Lerp but makes sure the values interpolate correctly when they wrap around 360 degrees.\r\n * The parameter t is clamped to the range [0, 1]. Variables a and b are assumed to be in degrees.\r\n * @param start start value\r\n * @param end target value\r\n * @param amount amount to lerp between\r\n * @returns the lerped value\r\n */\r\n Scalar.LerpAngle = function (start, end, amount) {\r\n var num = Scalar.Repeat(end - start, 360.0);\r\n if (num > 180.0) {\r\n num -= 360.0;\r\n }\r\n return start + num * Scalar.Clamp(amount);\r\n };\r\n /**\r\n * Calculates the linear parameter t that produces the interpolant value within the range [a, b].\r\n * @param a start value\r\n * @param b target value\r\n * @param value value between a and b\r\n * @returns the inverseLerp value\r\n */\r\n Scalar.InverseLerp = function (a, b, value) {\r\n var result = 0;\r\n if (a != b) {\r\n result = Scalar.Clamp((value - a) / (b - a));\r\n }\r\n else {\r\n result = 0.0;\r\n }\r\n return result;\r\n };\r\n /**\r\n * Returns a new scalar located for \"amount\" (float) on the Hermite spline defined by the scalars \"value1\", \"value3\", \"tangent1\", \"tangent2\".\r\n * @see http://mathworld.wolfram.com/HermitePolynomial.html\r\n * @param value1 spline value\r\n * @param tangent1 spline value\r\n * @param value2 spline value\r\n * @param tangent2 spline value\r\n * @param amount input value\r\n * @returns hermite result\r\n */\r\n Scalar.Hermite = function (value1, tangent1, value2, tangent2, amount) {\r\n var squared = amount * amount;\r\n var cubed = amount * squared;\r\n var part1 = ((2.0 * cubed) - (3.0 * squared)) + 1.0;\r\n var part2 = (-2.0 * cubed) + (3.0 * squared);\r\n var part3 = (cubed - (2.0 * squared)) + amount;\r\n var part4 = cubed - squared;\r\n return (((value1 * part1) + (value2 * part2)) + (tangent1 * part3)) + (tangent2 * part4);\r\n };\r\n /**\r\n * Returns a random float number between and min and max values\r\n * @param min min value of random\r\n * @param max max value of random\r\n * @returns random value\r\n */\r\n Scalar.RandomRange = function (min, max) {\r\n if (min === max) {\r\n return min;\r\n }\r\n return ((Math.random() * (max - min)) + min);\r\n };\r\n /**\r\n * This function returns percentage of a number in a given range.\r\n *\r\n * RangeToPercent(40,20,60) will return 0.5 (50%)\r\n * RangeToPercent(34,0,100) will return 0.34 (34%)\r\n * @param number to convert to percentage\r\n * @param min min range\r\n * @param max max range\r\n * @returns the percentage\r\n */\r\n Scalar.RangeToPercent = function (number, min, max) {\r\n return ((number - min) / (max - min));\r\n };\r\n /**\r\n * This function returns number that corresponds to the percentage in a given range.\r\n *\r\n * PercentToRange(0.34,0,100) will return 34.\r\n * @param percent to convert to number\r\n * @param min min range\r\n * @param max max range\r\n * @returns the number\r\n */\r\n Scalar.PercentToRange = function (percent, min, max) {\r\n return ((max - min) * percent + min);\r\n };\r\n /**\r\n * Returns the angle converted to equivalent value between -Math.PI and Math.PI radians.\r\n * @param angle The angle to normalize in radian.\r\n * @return The converted angle.\r\n */\r\n Scalar.NormalizeRadians = function (angle) {\r\n // More precise but slower version kept for reference.\r\n // angle = angle % Tools.TwoPi;\r\n // angle = (angle + Tools.TwoPi) % Tools.TwoPi;\r\n //if (angle > Math.PI) {\r\n //\tangle -= Tools.TwoPi;\r\n //}\r\n angle -= (Scalar.TwoPi * Math.floor((angle + Math.PI) / Scalar.TwoPi));\r\n return angle;\r\n };\r\n /**\r\n * Two pi constants convenient for computation.\r\n */\r\n Scalar.TwoPi = Math.PI * 2;\r\n return Scalar;\r\n}());\r\nexport { Scalar };\r\n//# sourceMappingURL=math.scalar.js.map","import { __decorate } from \"tslib\";\r\nimport { serialize, SerializationHelper, serializeAsTexture, expandToProperty } from \"../../Misc/decorators\";\r\nimport { Observable } from \"../../Misc/observable\";\r\nimport { Matrix } from \"../../Maths/math.vector\";\r\nimport { EngineStore } from \"../../Engines/engineStore\";\r\nimport { GUID } from '../../Misc/guid';\r\nimport { Size } from '../../Maths/math.size';\r\nimport \"../../Misc/fileTools\";\r\n/**\r\n * Base class of all the textures in babylon.\r\n * It groups all the common properties the materials, post process, lights... might need\r\n * in order to make a correct use of the texture.\r\n */\r\nvar BaseTexture = /** @class */ (function () {\r\n /**\r\n * Instantiates a new BaseTexture.\r\n * Base class of all the textures in babylon.\r\n * It groups all the common properties the materials, post process, lights... might need\r\n * in order to make a correct use of the texture.\r\n * @param scene Define the scene the texture blongs to\r\n */\r\n function BaseTexture(scene) {\r\n /**\r\n * Gets or sets an object used to store user defined information.\r\n */\r\n this.metadata = null;\r\n /**\r\n * For internal use only. Please do not use.\r\n */\r\n this.reservedDataStore = null;\r\n this._hasAlpha = false;\r\n /**\r\n * Defines if the alpha value should be determined via the rgb values.\r\n * If true the luminance of the pixel might be used to find the corresponding alpha value.\r\n */\r\n this.getAlphaFromRGB = false;\r\n /**\r\n * Intensity or strength of the texture.\r\n * It is commonly used by materials to fine tune the intensity of the texture\r\n */\r\n this.level = 1;\r\n /**\r\n * Define the UV chanel to use starting from 0 and defaulting to 0.\r\n * This is part of the texture as textures usually maps to one uv set.\r\n */\r\n this.coordinatesIndex = 0;\r\n this._coordinatesMode = 0;\r\n /**\r\n * | Value | Type | Description |\r\n * | ----- | ------------------ | ----------- |\r\n * | 0 | CLAMP_ADDRESSMODE | |\r\n * | 1 | WRAP_ADDRESSMODE | |\r\n * | 2 | MIRROR_ADDRESSMODE | |\r\n */\r\n this.wrapU = 1;\r\n /**\r\n * | Value | Type | Description |\r\n * | ----- | ------------------ | ----------- |\r\n * | 0 | CLAMP_ADDRESSMODE | |\r\n * | 1 | WRAP_ADDRESSMODE | |\r\n * | 2 | MIRROR_ADDRESSMODE | |\r\n */\r\n this.wrapV = 1;\r\n /**\r\n * | Value | Type | Description |\r\n * | ----- | ------------------ | ----------- |\r\n * | 0 | CLAMP_ADDRESSMODE | |\r\n * | 1 | WRAP_ADDRESSMODE | |\r\n * | 2 | MIRROR_ADDRESSMODE | |\r\n */\r\n this.wrapR = 1;\r\n /**\r\n * With compliant hardware and browser (supporting anisotropic filtering)\r\n * this defines the level of anisotropic filtering in the texture.\r\n * The higher the better but the slower. This defaults to 4 as it seems to be the best tradeoff.\r\n */\r\n this.anisotropicFilteringLevel = BaseTexture.DEFAULT_ANISOTROPIC_FILTERING_LEVEL;\r\n /**\r\n * Define if the texture contains data in gamma space (most of the png/jpg aside bump).\r\n * HDR texture are usually stored in linear space.\r\n * This only impacts the PBR and Background materials\r\n */\r\n this.gammaSpace = true;\r\n /**\r\n * Is Z inverted in the texture (useful in a cube texture).\r\n */\r\n this.invertZ = false;\r\n /**\r\n * @hidden\r\n */\r\n this.lodLevelInAlpha = false;\r\n /**\r\n * Define if the texture is a render target.\r\n */\r\n this.isRenderTarget = false;\r\n /**\r\n * Define the list of animation attached to the texture.\r\n */\r\n this.animations = new Array();\r\n /**\r\n * An event triggered when the texture is disposed.\r\n */\r\n this.onDisposeObservable = new Observable();\r\n this._onDisposeObserver = null;\r\n /**\r\n * Define the current state of the loading sequence when in delayed load mode.\r\n */\r\n this.delayLoadState = 0;\r\n this._scene = null;\r\n /** @hidden */\r\n this._texture = null;\r\n this._uid = null;\r\n this._cachedSize = Size.Zero();\r\n this._scene = scene || EngineStore.LastCreatedScene;\r\n if (this._scene) {\r\n this.uniqueId = this._scene.getUniqueId();\r\n this._scene.addTexture(this);\r\n }\r\n this._uid = null;\r\n }\r\n Object.defineProperty(BaseTexture.prototype, \"hasAlpha\", {\r\n get: function () {\r\n return this._hasAlpha;\r\n },\r\n /**\r\n * Define if the texture is having a usable alpha value (can be use for transparency or glossiness for instance).\r\n */\r\n set: function (value) {\r\n if (this._hasAlpha === value) {\r\n return;\r\n }\r\n this._hasAlpha = value;\r\n if (this._scene) {\r\n this._scene.markAllMaterialsAsDirty(1 | 16);\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"coordinatesMode\", {\r\n get: function () {\r\n return this._coordinatesMode;\r\n },\r\n /**\r\n * How a texture is mapped.\r\n *\r\n * | Value | Type | Description |\r\n * | ----- | ----------------------------------- | ----------- |\r\n * | 0 | EXPLICIT_MODE | |\r\n * | 1 | SPHERICAL_MODE | |\r\n * | 2 | PLANAR_MODE | |\r\n * | 3 | CUBIC_MODE | |\r\n * | 4 | PROJECTION_MODE | |\r\n * | 5 | SKYBOX_MODE | |\r\n * | 6 | INVCUBIC_MODE | |\r\n * | 7 | EQUIRECTANGULAR_MODE | |\r\n * | 8 | FIXED_EQUIRECTANGULAR_MODE | |\r\n * | 9 | FIXED_EQUIRECTANGULAR_MIRRORED_MODE | |\r\n */\r\n set: function (value) {\r\n if (this._coordinatesMode === value) {\r\n return;\r\n }\r\n this._coordinatesMode = value;\r\n if (this._scene) {\r\n this._scene.markAllMaterialsAsDirty(1);\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"isCube\", {\r\n /**\r\n * Define if the texture is a cube texture or if false a 2d texture.\r\n */\r\n get: function () {\r\n if (!this._texture) {\r\n return false;\r\n }\r\n return this._texture.isCube;\r\n },\r\n set: function (value) {\r\n if (!this._texture) {\r\n return;\r\n }\r\n this._texture.isCube = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"is3D\", {\r\n /**\r\n * Define if the texture is a 3d texture (webgl 2) or if false a 2d texture.\r\n */\r\n get: function () {\r\n if (!this._texture) {\r\n return false;\r\n }\r\n return this._texture.is3D;\r\n },\r\n set: function (value) {\r\n if (!this._texture) {\r\n return;\r\n }\r\n this._texture.is3D = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"is2DArray\", {\r\n /**\r\n * Define if the texture is a 2d array texture (webgl 2) or if false a 2d texture.\r\n */\r\n get: function () {\r\n if (!this._texture) {\r\n return false;\r\n }\r\n return this._texture.is2DArray;\r\n },\r\n set: function (value) {\r\n if (!this._texture) {\r\n return;\r\n }\r\n this._texture.is2DArray = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"isRGBD\", {\r\n /**\r\n * Gets or sets whether or not the texture contains RGBD data.\r\n */\r\n get: function () {\r\n return this._texture != null && this._texture._isRGBD;\r\n },\r\n set: function (value) {\r\n if (this._texture) {\r\n this._texture._isRGBD = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"noMipmap\", {\r\n /**\r\n * Are mip maps generated for this texture or not.\r\n */\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"lodGenerationOffset\", {\r\n /**\r\n * With prefiltered texture, defined the offset used during the prefiltering steps.\r\n */\r\n get: function () {\r\n if (this._texture) {\r\n return this._texture._lodGenerationOffset;\r\n }\r\n return 0.0;\r\n },\r\n set: function (value) {\r\n if (this._texture) {\r\n this._texture._lodGenerationOffset = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"lodGenerationScale\", {\r\n /**\r\n * With prefiltered texture, defined the scale used during the prefiltering steps.\r\n */\r\n get: function () {\r\n if (this._texture) {\r\n return this._texture._lodGenerationScale;\r\n }\r\n return 0.0;\r\n },\r\n set: function (value) {\r\n if (this._texture) {\r\n this._texture._lodGenerationScale = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"linearSpecularLOD\", {\r\n /**\r\n * With prefiltered texture, defined if the specular generation is based on a linear ramp.\r\n * By default we are using a log2 of the linear roughness helping to keep a better resolution for\r\n * average roughness values.\r\n */\r\n get: function () {\r\n if (this._texture) {\r\n return this._texture._linearSpecularLOD;\r\n }\r\n return false;\r\n },\r\n set: function (value) {\r\n if (this._texture) {\r\n this._texture._linearSpecularLOD = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"irradianceTexture\", {\r\n /**\r\n * In case a better definition than spherical harmonics is required for the diffuse part of the environment.\r\n * You can set the irradiance texture to rely on a texture instead of the spherical approach.\r\n * This texture need to have the same characteristics than its parent (Cube vs 2d, coordinates mode, Gamma/Linear, RGBD).\r\n */\r\n get: function () {\r\n if (this._texture) {\r\n return this._texture._irradianceTexture;\r\n }\r\n return null;\r\n },\r\n set: function (value) {\r\n if (this._texture) {\r\n this._texture._irradianceTexture = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"uid\", {\r\n /**\r\n * Define the unique id of the texture in the scene.\r\n */\r\n get: function () {\r\n if (!this._uid) {\r\n this._uid = GUID.RandomId();\r\n }\r\n return this._uid;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Return a string representation of the texture.\r\n * @returns the texture as a string\r\n */\r\n BaseTexture.prototype.toString = function () {\r\n return this.name;\r\n };\r\n /**\r\n * Get the class name of the texture.\r\n * @returns \"BaseTexture\"\r\n */\r\n BaseTexture.prototype.getClassName = function () {\r\n return \"BaseTexture\";\r\n };\r\n Object.defineProperty(BaseTexture.prototype, \"onDispose\", {\r\n /**\r\n * Callback triggered when the texture has been disposed.\r\n * Kept for back compatibility, you can use the onDisposeObservable instead.\r\n */\r\n set: function (callback) {\r\n if (this._onDisposeObserver) {\r\n this.onDisposeObservable.remove(this._onDisposeObserver);\r\n }\r\n this._onDisposeObserver = this.onDisposeObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"isBlocking\", {\r\n /**\r\n * Define if the texture is preventinga material to render or not.\r\n * If not and the texture is not ready, the engine will use a default black texture instead.\r\n */\r\n get: function () {\r\n return true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Get the scene the texture belongs to.\r\n * @returns the scene or null if undefined\r\n */\r\n BaseTexture.prototype.getScene = function () {\r\n return this._scene;\r\n };\r\n /**\r\n * Get the texture transform matrix used to offset tile the texture for istance.\r\n * @returns the transformation matrix\r\n */\r\n BaseTexture.prototype.getTextureMatrix = function () {\r\n return Matrix.IdentityReadOnly;\r\n };\r\n /**\r\n * Get the texture reflection matrix used to rotate/transform the reflection.\r\n * @returns the reflection matrix\r\n */\r\n BaseTexture.prototype.getReflectionTextureMatrix = function () {\r\n return Matrix.IdentityReadOnly;\r\n };\r\n /**\r\n * Get the underlying lower level texture from Babylon.\r\n * @returns the insternal texture\r\n */\r\n BaseTexture.prototype.getInternalTexture = function () {\r\n return this._texture;\r\n };\r\n /**\r\n * Get if the texture is ready to be consumed (either it is ready or it is not blocking)\r\n * @returns true if ready or not blocking\r\n */\r\n BaseTexture.prototype.isReadyOrNotBlocking = function () {\r\n return !this.isBlocking || this.isReady();\r\n };\r\n /**\r\n * Get if the texture is ready to be used (downloaded, converted, mip mapped...).\r\n * @returns true if fully ready\r\n */\r\n BaseTexture.prototype.isReady = function () {\r\n if (this.delayLoadState === 4) {\r\n this.delayLoad();\r\n return false;\r\n }\r\n if (this._texture) {\r\n return this._texture.isReady;\r\n }\r\n return false;\r\n };\r\n /**\r\n * Get the size of the texture.\r\n * @returns the texture size.\r\n */\r\n BaseTexture.prototype.getSize = function () {\r\n if (this._texture) {\r\n if (this._texture.width) {\r\n this._cachedSize.width = this._texture.width;\r\n this._cachedSize.height = this._texture.height;\r\n return this._cachedSize;\r\n }\r\n if (this._texture._size) {\r\n this._cachedSize.width = this._texture._size;\r\n this._cachedSize.height = this._texture._size;\r\n return this._cachedSize;\r\n }\r\n }\r\n return this._cachedSize;\r\n };\r\n /**\r\n * Get the base size of the texture.\r\n * It can be different from the size if the texture has been resized for POT for instance\r\n * @returns the base size\r\n */\r\n BaseTexture.prototype.getBaseSize = function () {\r\n if (!this.isReady() || !this._texture) {\r\n return Size.Zero();\r\n }\r\n if (this._texture._size) {\r\n return new Size(this._texture._size, this._texture._size);\r\n }\r\n return new Size(this._texture.baseWidth, this._texture.baseHeight);\r\n };\r\n /**\r\n * Update the sampling mode of the texture.\r\n * Default is Trilinear mode.\r\n *\r\n * | Value | Type | Description |\r\n * | ----- | ------------------ | ----------- |\r\n * | 1 | NEAREST_SAMPLINGMODE or NEAREST_NEAREST_MIPLINEAR | Nearest is: mag = nearest, min = nearest, mip = linear |\r\n * | 2 | BILINEAR_SAMPLINGMODE or LINEAR_LINEAR_MIPNEAREST | Bilinear is: mag = linear, min = linear, mip = nearest |\r\n * | 3 | TRILINEAR_SAMPLINGMODE or LINEAR_LINEAR_MIPLINEAR | Trilinear is: mag = linear, min = linear, mip = linear |\r\n * | 4 | NEAREST_NEAREST_MIPNEAREST | |\r\n * | 5 | NEAREST_LINEAR_MIPNEAREST | |\r\n * | 6 | NEAREST_LINEAR_MIPLINEAR | |\r\n * | 7 | NEAREST_LINEAR | |\r\n * | 8 | NEAREST_NEAREST | |\r\n * | 9 | LINEAR_NEAREST_MIPNEAREST | |\r\n * | 10 | LINEAR_NEAREST_MIPLINEAR | |\r\n * | 11 | LINEAR_LINEAR | |\r\n * | 12 | LINEAR_NEAREST | |\r\n *\r\n * > _mag_: magnification filter (close to the viewer)\r\n * > _min_: minification filter (far from the viewer)\r\n * > _mip_: filter used between mip map levels\r\n *@param samplingMode Define the new sampling mode of the texture\r\n */\r\n BaseTexture.prototype.updateSamplingMode = function (samplingMode) {\r\n if (!this._texture) {\r\n return;\r\n }\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n scene.getEngine().updateTextureSamplingMode(samplingMode, this._texture);\r\n };\r\n /**\r\n * Scales the texture if is `canRescale()`\r\n * @param ratio the resize factor we want to use to rescale\r\n */\r\n BaseTexture.prototype.scale = function (ratio) {\r\n };\r\n Object.defineProperty(BaseTexture.prototype, \"canRescale\", {\r\n /**\r\n * Get if the texture can rescale.\r\n */\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n BaseTexture.prototype._getFromCache = function (url, noMipmap, sampling, invertY) {\r\n if (!this._scene) {\r\n return null;\r\n }\r\n var texturesCache = this._scene.getEngine().getLoadedTexturesCache();\r\n for (var index = 0; index < texturesCache.length; index++) {\r\n var texturesCacheEntry = texturesCache[index];\r\n if (invertY === undefined || invertY === texturesCacheEntry.invertY) {\r\n if (texturesCacheEntry.url === url && texturesCacheEntry.generateMipMaps === !noMipmap) {\r\n if (!sampling || sampling === texturesCacheEntry.samplingMode) {\r\n texturesCacheEntry.incrementReferences();\r\n return texturesCacheEntry;\r\n }\r\n }\r\n }\r\n }\r\n return null;\r\n };\r\n /** @hidden */\r\n BaseTexture.prototype._rebuild = function () {\r\n };\r\n /**\r\n * Triggers the load sequence in delayed load mode.\r\n */\r\n BaseTexture.prototype.delayLoad = function () {\r\n };\r\n /**\r\n * Clones the texture.\r\n * @returns the cloned texture\r\n */\r\n BaseTexture.prototype.clone = function () {\r\n return null;\r\n };\r\n Object.defineProperty(BaseTexture.prototype, \"textureType\", {\r\n /**\r\n * Get the texture underlying type (INT, FLOAT...)\r\n */\r\n get: function () {\r\n if (!this._texture) {\r\n return 0;\r\n }\r\n return (this._texture.type !== undefined) ? this._texture.type : 0;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"textureFormat\", {\r\n /**\r\n * Get the texture underlying format (RGB, RGBA...)\r\n */\r\n get: function () {\r\n if (!this._texture) {\r\n return 5;\r\n }\r\n return (this._texture.format !== undefined) ? this._texture.format : 5;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Indicates that textures need to be re-calculated for all materials\r\n */\r\n BaseTexture.prototype._markAllSubMeshesAsTexturesDirty = function () {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n scene.markAllMaterialsAsDirty(1);\r\n };\r\n /**\r\n * Reads the pixels stored in the webgl texture and returns them as an ArrayBuffer.\r\n * This will returns an RGBA array buffer containing either in values (0-255) or\r\n * float values (0-1) depending of the underlying buffer type.\r\n * @param faceIndex defines the face of the texture to read (in case of cube texture)\r\n * @param level defines the LOD level of the texture to read (in case of Mip Maps)\r\n * @param buffer defines a user defined buffer to fill with data (can be null)\r\n * @returns The Array buffer containing the pixels data.\r\n */\r\n BaseTexture.prototype.readPixels = function (faceIndex, level, buffer) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (level === void 0) { level = 0; }\r\n if (buffer === void 0) { buffer = null; }\r\n if (!this._texture) {\r\n return null;\r\n }\r\n var size = this.getSize();\r\n var width = size.width;\r\n var height = size.height;\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return null;\r\n }\r\n var engine = scene.getEngine();\r\n if (level != 0) {\r\n width = width / Math.pow(2, level);\r\n height = height / Math.pow(2, level);\r\n width = Math.round(width);\r\n height = Math.round(height);\r\n }\r\n if (this._texture.isCube) {\r\n return engine._readTexturePixels(this._texture, width, height, faceIndex, level, buffer);\r\n }\r\n return engine._readTexturePixels(this._texture, width, height, -1, level, buffer);\r\n };\r\n /**\r\n * Release and destroy the underlying lower level texture aka internalTexture.\r\n */\r\n BaseTexture.prototype.releaseInternalTexture = function () {\r\n if (this._texture) {\r\n this._texture.dispose();\r\n this._texture = null;\r\n }\r\n };\r\n Object.defineProperty(BaseTexture.prototype, \"_lodTextureHigh\", {\r\n /** @hidden */\r\n get: function () {\r\n if (this._texture) {\r\n return this._texture._lodTextureHigh;\r\n }\r\n return null;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"_lodTextureMid\", {\r\n /** @hidden */\r\n get: function () {\r\n if (this._texture) {\r\n return this._texture._lodTextureMid;\r\n }\r\n return null;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"_lodTextureLow\", {\r\n /** @hidden */\r\n get: function () {\r\n if (this._texture) {\r\n return this._texture._lodTextureLow;\r\n }\r\n return null;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Dispose the texture and release its associated resources.\r\n */\r\n BaseTexture.prototype.dispose = function () {\r\n if (this._scene) {\r\n // Animations\r\n if (this._scene.stopAnimation) {\r\n this._scene.stopAnimation(this);\r\n }\r\n // Remove from scene\r\n this._scene._removePendingData(this);\r\n var index = this._scene.textures.indexOf(this);\r\n if (index >= 0) {\r\n this._scene.textures.splice(index, 1);\r\n }\r\n this._scene.onTextureRemovedObservable.notifyObservers(this);\r\n }\r\n if (this._texture === undefined) {\r\n return;\r\n }\r\n // Release\r\n this.releaseInternalTexture();\r\n // Callback\r\n this.onDisposeObservable.notifyObservers(this);\r\n this.onDisposeObservable.clear();\r\n };\r\n /**\r\n * Serialize the texture into a JSON representation that can be parsed later on.\r\n * @returns the JSON representation of the texture\r\n */\r\n BaseTexture.prototype.serialize = function () {\r\n if (!this.name) {\r\n return null;\r\n }\r\n var serializationObject = SerializationHelper.Serialize(this);\r\n // Animations\r\n SerializationHelper.AppendSerializedAnimations(this, serializationObject);\r\n return serializationObject;\r\n };\r\n /**\r\n * Helper function to be called back once a list of texture contains only ready textures.\r\n * @param textures Define the list of textures to wait for\r\n * @param callback Define the callback triggered once the entire list will be ready\r\n */\r\n BaseTexture.WhenAllReady = function (textures, callback) {\r\n var numRemaining = textures.length;\r\n if (numRemaining === 0) {\r\n callback();\r\n return;\r\n }\r\n var _loop_1 = function () {\r\n texture = textures[i];\r\n if (texture.isReady()) {\r\n if (--numRemaining === 0) {\r\n callback();\r\n }\r\n }\r\n else {\r\n onLoadObservable = texture.onLoadObservable;\r\n if (onLoadObservable) {\r\n var onLoadCallback_1 = function () {\r\n onLoadObservable.removeCallback(onLoadCallback_1);\r\n if (--numRemaining === 0) {\r\n callback();\r\n }\r\n };\r\n onLoadObservable.add(onLoadCallback_1);\r\n }\r\n }\r\n };\r\n var texture, onLoadObservable;\r\n for (var i = 0; i < textures.length; i++) {\r\n _loop_1();\r\n }\r\n };\r\n /**\r\n * Default anisotropic filtering level for the application.\r\n * It is set to 4 as a good tradeoff between perf and quality.\r\n */\r\n BaseTexture.DEFAULT_ANISOTROPIC_FILTERING_LEVEL = 4;\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"uniqueId\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"name\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"metadata\", void 0);\r\n __decorate([\r\n serialize(\"hasAlpha\")\r\n ], BaseTexture.prototype, \"_hasAlpha\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"getAlphaFromRGB\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"level\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"coordinatesIndex\", void 0);\r\n __decorate([\r\n serialize(\"coordinatesMode\")\r\n ], BaseTexture.prototype, \"_coordinatesMode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"wrapU\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"wrapV\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"wrapR\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"anisotropicFilteringLevel\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"isCube\", null);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"is3D\", null);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"is2DArray\", null);\r\n __decorate([\r\n serialize(),\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], BaseTexture.prototype, \"gammaSpace\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"invertZ\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"lodLevelInAlpha\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"lodGenerationOffset\", null);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"lodGenerationScale\", null);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"linearSpecularLOD\", null);\r\n __decorate([\r\n serializeAsTexture()\r\n ], BaseTexture.prototype, \"irradianceTexture\", null);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"isRenderTarget\", void 0);\r\n return BaseTexture;\r\n}());\r\nexport { BaseTexture };\r\n//# sourceMappingURL=baseTexture.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, SerializationHelper } from \"../../Misc/decorators\";\r\nimport { Observable } from \"../../Misc/observable\";\r\nimport { Matrix, Vector3 } from \"../../Maths/math.vector\";\r\nimport { BaseTexture } from \"../../Materials/Textures/baseTexture\";\r\nimport { _TypeStore } from '../../Misc/typeStore';\r\nimport { _DevTools } from '../../Misc/devTools';\r\nimport { TimingTools } from '../../Misc/timingTools';\r\nimport { InstantiationTools } from '../../Misc/instantiationTools';\r\nimport { Plane } from '../../Maths/math.plane';\r\nimport { StringTools } from '../../Misc/stringTools';\r\n/**\r\n * This represents a texture in babylon. It can be easily loaded from a network, base64 or html input.\r\n * @see http://doc.babylonjs.com/babylon101/materials#texture\r\n */\r\nvar Texture = /** @class */ (function (_super) {\r\n __extends(Texture, _super);\r\n /**\r\n * Instantiates a new texture.\r\n * This represents a texture in babylon. It can be easily loaded from a network, base64 or html input.\r\n * @see http://doc.babylonjs.com/babylon101/materials#texture\r\n * @param url defines the url of the picture to load as a texture\r\n * @param scene defines the scene or engine the texture will belong to\r\n * @param noMipmap defines if the texture will require mip maps or not\r\n * @param invertY defines if the texture needs to be inverted on the y axis during loading\r\n * @param samplingMode defines the sampling mode we want for the texture while fectching from it (Texture.NEAREST_SAMPLINGMODE...)\r\n * @param onLoad defines a callback triggered when the texture has been loaded\r\n * @param onError defines a callback triggered when an error occurred during the loading session\r\n * @param buffer defines the buffer to load the texture from in case the texture is loaded from a buffer representation\r\n * @param deleteBuffer defines if the buffer we are loading the texture from should be deleted after load\r\n * @param format defines the format of the texture we are trying to load (Engine.TEXTUREFORMAT_RGBA...)\r\n * @param mimeType defines an optional mime type information\r\n */\r\n function Texture(url, sceneOrEngine, noMipmap, invertY, samplingMode, onLoad, onError, buffer, deleteBuffer, format, mimeType) {\r\n if (noMipmap === void 0) { noMipmap = false; }\r\n if (invertY === void 0) { invertY = true; }\r\n if (samplingMode === void 0) { samplingMode = Texture.TRILINEAR_SAMPLINGMODE; }\r\n if (onLoad === void 0) { onLoad = null; }\r\n if (onError === void 0) { onError = null; }\r\n if (buffer === void 0) { buffer = null; }\r\n if (deleteBuffer === void 0) { deleteBuffer = false; }\r\n var _this = _super.call(this, (sceneOrEngine && sceneOrEngine.getClassName() === \"Scene\") ? sceneOrEngine : null) || this;\r\n /**\r\n * Define the url of the texture.\r\n */\r\n _this.url = null;\r\n /**\r\n * Define an offset on the texture to offset the u coordinates of the UVs\r\n * @see http://doc.babylonjs.com/how_to/more_materials#offsetting\r\n */\r\n _this.uOffset = 0;\r\n /**\r\n * Define an offset on the texture to offset the v coordinates of the UVs\r\n * @see http://doc.babylonjs.com/how_to/more_materials#offsetting\r\n */\r\n _this.vOffset = 0;\r\n /**\r\n * Define an offset on the texture to scale the u coordinates of the UVs\r\n * @see http://doc.babylonjs.com/how_to/more_materials#tiling\r\n */\r\n _this.uScale = 1.0;\r\n /**\r\n * Define an offset on the texture to scale the v coordinates of the UVs\r\n * @see http://doc.babylonjs.com/how_to/more_materials#tiling\r\n */\r\n _this.vScale = 1.0;\r\n /**\r\n * Define an offset on the texture to rotate around the u coordinates of the UVs\r\n * @see http://doc.babylonjs.com/how_to/more_materials\r\n */\r\n _this.uAng = 0;\r\n /**\r\n * Define an offset on the texture to rotate around the v coordinates of the UVs\r\n * @see http://doc.babylonjs.com/how_to/more_materials\r\n */\r\n _this.vAng = 0;\r\n /**\r\n * Define an offset on the texture to rotate around the w coordinates of the UVs (in case of 3d texture)\r\n * @see http://doc.babylonjs.com/how_to/more_materials\r\n */\r\n _this.wAng = 0;\r\n /**\r\n * Defines the center of rotation (U)\r\n */\r\n _this.uRotationCenter = 0.5;\r\n /**\r\n * Defines the center of rotation (V)\r\n */\r\n _this.vRotationCenter = 0.5;\r\n /**\r\n * Defines the center of rotation (W)\r\n */\r\n _this.wRotationCenter = 0.5;\r\n /**\r\n * List of inspectable custom properties (used by the Inspector)\r\n * @see https://doc.babylonjs.com/how_to/debug_layer#extensibility\r\n */\r\n _this.inspectableCustomProperties = null;\r\n _this._noMipmap = false;\r\n /** @hidden */\r\n _this._invertY = false;\r\n _this._rowGenerationMatrix = null;\r\n _this._cachedTextureMatrix = null;\r\n _this._projectionModeMatrix = null;\r\n _this._t0 = null;\r\n _this._t1 = null;\r\n _this._t2 = null;\r\n _this._cachedUOffset = -1;\r\n _this._cachedVOffset = -1;\r\n _this._cachedUScale = 0;\r\n _this._cachedVScale = 0;\r\n _this._cachedUAng = -1;\r\n _this._cachedVAng = -1;\r\n _this._cachedWAng = -1;\r\n _this._cachedProjectionMatrixId = -1;\r\n _this._cachedCoordinatesMode = -1;\r\n /** @hidden */\r\n _this._initialSamplingMode = Texture.BILINEAR_SAMPLINGMODE;\r\n /** @hidden */\r\n _this._buffer = null;\r\n _this._deleteBuffer = false;\r\n _this._format = null;\r\n _this._delayedOnLoad = null;\r\n _this._delayedOnError = null;\r\n /**\r\n * Observable triggered once the texture has been loaded.\r\n */\r\n _this.onLoadObservable = new Observable();\r\n _this._isBlocking = true;\r\n _this.name = url || \"\";\r\n _this.url = url;\r\n _this._noMipmap = noMipmap;\r\n _this._invertY = invertY;\r\n _this._initialSamplingMode = samplingMode;\r\n _this._buffer = buffer;\r\n _this._deleteBuffer = deleteBuffer;\r\n _this._mimeType = mimeType;\r\n if (format) {\r\n _this._format = format;\r\n }\r\n var scene = _this.getScene();\r\n var engine = (sceneOrEngine && sceneOrEngine.getCaps) ? sceneOrEngine : (scene ? scene.getEngine() : null);\r\n if (!engine) {\r\n return _this;\r\n }\r\n engine.onBeforeTextureInitObservable.notifyObservers(_this);\r\n var load = function () {\r\n if (_this._texture) {\r\n if (_this._texture._invertVScale) {\r\n _this.vScale *= -1;\r\n _this.vOffset += 1;\r\n }\r\n // Update texutre to match internal texture's wrapping\r\n if (_this._texture._cachedWrapU !== null) {\r\n _this.wrapU = _this._texture._cachedWrapU;\r\n _this._texture._cachedWrapU = null;\r\n }\r\n if (_this._texture._cachedWrapV !== null) {\r\n _this.wrapV = _this._texture._cachedWrapV;\r\n _this._texture._cachedWrapV = null;\r\n }\r\n if (_this._texture._cachedWrapR !== null) {\r\n _this.wrapR = _this._texture._cachedWrapR;\r\n _this._texture._cachedWrapR = null;\r\n }\r\n }\r\n if (_this.onLoadObservable.hasObservers()) {\r\n _this.onLoadObservable.notifyObservers(_this);\r\n }\r\n if (onLoad) {\r\n onLoad();\r\n }\r\n if (!_this.isBlocking && scene) {\r\n scene.resetCachedMaterial();\r\n }\r\n };\r\n if (!_this.url) {\r\n _this._delayedOnLoad = load;\r\n _this._delayedOnError = onError;\r\n return _this;\r\n }\r\n _this._texture = _this._getFromCache(_this.url, noMipmap, samplingMode, invertY);\r\n if (!_this._texture) {\r\n if (!scene || !scene.useDelayedTextureLoading) {\r\n _this._texture = engine.createTexture(_this.url, noMipmap, invertY, scene, samplingMode, load, onError, _this._buffer, undefined, _this._format, null, mimeType);\r\n if (deleteBuffer) {\r\n delete _this._buffer;\r\n }\r\n }\r\n else {\r\n _this.delayLoadState = 4;\r\n _this._delayedOnLoad = load;\r\n _this._delayedOnError = onError;\r\n }\r\n }\r\n else {\r\n if (_this._texture.isReady) {\r\n TimingTools.SetImmediate(function () { return load(); });\r\n }\r\n else {\r\n _this._texture.onLoadedObservable.add(load);\r\n }\r\n }\r\n return _this;\r\n }\r\n Object.defineProperty(Texture.prototype, \"noMipmap\", {\r\n /**\r\n * Are mip maps generated for this texture or not.\r\n */\r\n get: function () {\r\n return this._noMipmap;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Texture.prototype, \"isBlocking\", {\r\n get: function () {\r\n return this._isBlocking;\r\n },\r\n /**\r\n * Is the texture preventing material to render while loading.\r\n * If false, a default texture will be used instead of the loading one during the preparation step.\r\n */\r\n set: function (value) {\r\n this._isBlocking = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Texture.prototype, \"samplingMode\", {\r\n /**\r\n * Get the current sampling mode associated with the texture.\r\n */\r\n get: function () {\r\n if (!this._texture) {\r\n return this._initialSamplingMode;\r\n }\r\n return this._texture.samplingMode;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Texture.prototype, \"invertY\", {\r\n /**\r\n * Gets a boolean indicating if the texture needs to be inverted on the y axis during loading\r\n */\r\n get: function () {\r\n return this._invertY;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Update the url (and optional buffer) of this texture if url was null during construction.\r\n * @param url the url of the texture\r\n * @param buffer the buffer of the texture (defaults to null)\r\n * @param onLoad callback called when the texture is loaded (defaults to null)\r\n */\r\n Texture.prototype.updateURL = function (url, buffer, onLoad) {\r\n if (buffer === void 0) { buffer = null; }\r\n if (this.url) {\r\n this.releaseInternalTexture();\r\n this.getScene().markAllMaterialsAsDirty(1);\r\n }\r\n if (!this.name || StringTools.StartsWith(this.name, \"data:\")) {\r\n this.name = url;\r\n }\r\n this.url = url;\r\n this._buffer = buffer;\r\n this.delayLoadState = 4;\r\n if (onLoad) {\r\n this._delayedOnLoad = onLoad;\r\n }\r\n this.delayLoad();\r\n };\r\n /**\r\n * Finish the loading sequence of a texture flagged as delayed load.\r\n * @hidden\r\n */\r\n Texture.prototype.delayLoad = function () {\r\n if (this.delayLoadState !== 4) {\r\n return;\r\n }\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n this.delayLoadState = 1;\r\n this._texture = this._getFromCache(this.url, this._noMipmap, this.samplingMode, this._invertY);\r\n if (!this._texture) {\r\n this._texture = scene.getEngine().createTexture(this.url, this._noMipmap, this._invertY, scene, this.samplingMode, this._delayedOnLoad, this._delayedOnError, this._buffer, null, this._format, null, this._mimeType);\r\n if (this._deleteBuffer) {\r\n delete this._buffer;\r\n }\r\n }\r\n else {\r\n if (this._delayedOnLoad) {\r\n if (this._texture.isReady) {\r\n TimingTools.SetImmediate(this._delayedOnLoad);\r\n }\r\n else {\r\n this._texture.onLoadedObservable.add(this._delayedOnLoad);\r\n }\r\n }\r\n }\r\n this._delayedOnLoad = null;\r\n this._delayedOnError = null;\r\n };\r\n Texture.prototype._prepareRowForTextureGeneration = function (x, y, z, t) {\r\n x *= this._cachedUScale;\r\n y *= this._cachedVScale;\r\n x -= this.uRotationCenter * this._cachedUScale;\r\n y -= this.vRotationCenter * this._cachedVScale;\r\n z -= this.wRotationCenter;\r\n Vector3.TransformCoordinatesFromFloatsToRef(x, y, z, this._rowGenerationMatrix, t);\r\n t.x += this.uRotationCenter * this._cachedUScale + this._cachedUOffset;\r\n t.y += this.vRotationCenter * this._cachedVScale + this._cachedVOffset;\r\n t.z += this.wRotationCenter;\r\n };\r\n /**\r\n * Get the current texture matrix which includes the requested offsetting, tiling and rotation components.\r\n * @returns the transform matrix of the texture.\r\n */\r\n Texture.prototype.getTextureMatrix = function (uBase) {\r\n var _this = this;\r\n if (uBase === void 0) { uBase = 1; }\r\n if (this.uOffset === this._cachedUOffset &&\r\n this.vOffset === this._cachedVOffset &&\r\n this.uScale * uBase === this._cachedUScale &&\r\n this.vScale === this._cachedVScale &&\r\n this.uAng === this._cachedUAng &&\r\n this.vAng === this._cachedVAng &&\r\n this.wAng === this._cachedWAng) {\r\n return this._cachedTextureMatrix;\r\n }\r\n this._cachedUOffset = this.uOffset;\r\n this._cachedVOffset = this.vOffset;\r\n this._cachedUScale = this.uScale * uBase;\r\n this._cachedVScale = this.vScale;\r\n this._cachedUAng = this.uAng;\r\n this._cachedVAng = this.vAng;\r\n this._cachedWAng = this.wAng;\r\n if (!this._cachedTextureMatrix) {\r\n this._cachedTextureMatrix = Matrix.Zero();\r\n this._rowGenerationMatrix = new Matrix();\r\n this._t0 = Vector3.Zero();\r\n this._t1 = Vector3.Zero();\r\n this._t2 = Vector3.Zero();\r\n }\r\n Matrix.RotationYawPitchRollToRef(this.vAng, this.uAng, this.wAng, this._rowGenerationMatrix);\r\n this._prepareRowForTextureGeneration(0, 0, 0, this._t0);\r\n this._prepareRowForTextureGeneration(1.0, 0, 0, this._t1);\r\n this._prepareRowForTextureGeneration(0, 1.0, 0, this._t2);\r\n this._t1.subtractInPlace(this._t0);\r\n this._t2.subtractInPlace(this._t0);\r\n Matrix.FromValuesToRef(this._t1.x, this._t1.y, this._t1.z, 0.0, this._t2.x, this._t2.y, this._t2.z, 0.0, this._t0.x, this._t0.y, this._t0.z, 0.0, 0.0, 0.0, 0.0, 1.0, this._cachedTextureMatrix);\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return this._cachedTextureMatrix;\r\n }\r\n scene.markAllMaterialsAsDirty(1, function (mat) {\r\n return mat.hasTexture(_this);\r\n });\r\n return this._cachedTextureMatrix;\r\n };\r\n /**\r\n * Get the current matrix used to apply reflection. This is useful to rotate an environment texture for instance.\r\n * @returns The reflection texture transform\r\n */\r\n Texture.prototype.getReflectionTextureMatrix = function () {\r\n var _this = this;\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return this._cachedTextureMatrix;\r\n }\r\n if (this.uOffset === this._cachedUOffset &&\r\n this.vOffset === this._cachedVOffset &&\r\n this.uScale === this._cachedUScale &&\r\n this.vScale === this._cachedVScale &&\r\n this.coordinatesMode === this._cachedCoordinatesMode) {\r\n if (this.coordinatesMode === Texture.PROJECTION_MODE) {\r\n if (this._cachedProjectionMatrixId === scene.getProjectionMatrix().updateFlag) {\r\n return this._cachedTextureMatrix;\r\n }\r\n }\r\n else {\r\n return this._cachedTextureMatrix;\r\n }\r\n }\r\n if (!this._cachedTextureMatrix) {\r\n this._cachedTextureMatrix = Matrix.Zero();\r\n }\r\n if (!this._projectionModeMatrix) {\r\n this._projectionModeMatrix = Matrix.Zero();\r\n }\r\n this._cachedUOffset = this.uOffset;\r\n this._cachedVOffset = this.vOffset;\r\n this._cachedUScale = this.uScale;\r\n this._cachedVScale = this.vScale;\r\n this._cachedCoordinatesMode = this.coordinatesMode;\r\n switch (this.coordinatesMode) {\r\n case Texture.PLANAR_MODE:\r\n Matrix.IdentityToRef(this._cachedTextureMatrix);\r\n this._cachedTextureMatrix[0] = this.uScale;\r\n this._cachedTextureMatrix[5] = this.vScale;\r\n this._cachedTextureMatrix[12] = this.uOffset;\r\n this._cachedTextureMatrix[13] = this.vOffset;\r\n break;\r\n case Texture.PROJECTION_MODE:\r\n Matrix.FromValuesToRef(0.5, 0.0, 0.0, 0.0, 0.0, -0.5, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.5, 0.5, 1.0, 1.0, this._projectionModeMatrix);\r\n var projectionMatrix = scene.getProjectionMatrix();\r\n this._cachedProjectionMatrixId = projectionMatrix.updateFlag;\r\n projectionMatrix.multiplyToRef(this._projectionModeMatrix, this._cachedTextureMatrix);\r\n break;\r\n default:\r\n Matrix.IdentityToRef(this._cachedTextureMatrix);\r\n break;\r\n }\r\n scene.markAllMaterialsAsDirty(1, function (mat) {\r\n return (mat.getActiveTextures().indexOf(_this) !== -1);\r\n });\r\n return this._cachedTextureMatrix;\r\n };\r\n /**\r\n * Clones the texture.\r\n * @returns the cloned texture\r\n */\r\n Texture.prototype.clone = function () {\r\n var _this = this;\r\n return SerializationHelper.Clone(function () {\r\n return new Texture(_this._texture ? _this._texture.url : null, _this.getScene(), _this._noMipmap, _this._invertY, _this.samplingMode, undefined, undefined, _this._texture ? _this._texture._buffer : undefined);\r\n }, this);\r\n };\r\n /**\r\n * Serialize the texture to a JSON representation we can easily use in the resepective Parse function.\r\n * @returns The JSON representation of the texture\r\n */\r\n Texture.prototype.serialize = function () {\r\n var savedName = this.name;\r\n if (!Texture.SerializeBuffers) {\r\n if (StringTools.StartsWith(this.name, \"data:\")) {\r\n this.name = \"\";\r\n }\r\n }\r\n var serializationObject = _super.prototype.serialize.call(this);\r\n if (!serializationObject) {\r\n return null;\r\n }\r\n if (Texture.SerializeBuffers) {\r\n if (typeof this._buffer === \"string\" && this._buffer.substr(0, 5) === \"data:\") {\r\n serializationObject.base64String = this._buffer;\r\n serializationObject.name = serializationObject.name.replace(\"data:\", \"\");\r\n }\r\n else if (this.url && StringTools.StartsWith(this.url, \"data:\") && this._buffer instanceof Uint8Array) {\r\n serializationObject.base64String = \"data:image/png;base64,\" + StringTools.EncodeArrayBufferToBase64(this._buffer);\r\n }\r\n }\r\n serializationObject.invertY = this._invertY;\r\n serializationObject.samplingMode = this.samplingMode;\r\n this.name = savedName;\r\n return serializationObject;\r\n };\r\n /**\r\n * Get the current class name of the texture useful for serialization or dynamic coding.\r\n * @returns \"Texture\"\r\n */\r\n Texture.prototype.getClassName = function () {\r\n return \"Texture\";\r\n };\r\n /**\r\n * Dispose the texture and release its associated resources.\r\n */\r\n Texture.prototype.dispose = function () {\r\n _super.prototype.dispose.call(this);\r\n this.onLoadObservable.clear();\r\n this._delayedOnLoad = null;\r\n this._delayedOnError = null;\r\n };\r\n /**\r\n * Parse the JSON representation of a texture in order to recreate the texture in the given scene.\r\n * @param parsedTexture Define the JSON representation of the texture\r\n * @param scene Define the scene the parsed texture should be instantiated in\r\n * @param rootUrl Define the root url of the parsing sequence in the case of relative dependencies\r\n * @returns The parsed texture if successful\r\n */\r\n Texture.Parse = function (parsedTexture, scene, rootUrl) {\r\n if (parsedTexture.customType) {\r\n var customTexture = InstantiationTools.Instantiate(parsedTexture.customType);\r\n // Update Sampling Mode\r\n var parsedCustomTexture = customTexture.Parse(parsedTexture, scene, rootUrl);\r\n if (parsedTexture.samplingMode && parsedCustomTexture.updateSamplingMode && parsedCustomTexture._samplingMode) {\r\n if (parsedCustomTexture._samplingMode !== parsedTexture.samplingMode) {\r\n parsedCustomTexture.updateSamplingMode(parsedTexture.samplingMode);\r\n }\r\n }\r\n return parsedCustomTexture;\r\n }\r\n if (parsedTexture.isCube && !parsedTexture.isRenderTarget) {\r\n return Texture._CubeTextureParser(parsedTexture, scene, rootUrl);\r\n }\r\n if (!parsedTexture.name && !parsedTexture.isRenderTarget) {\r\n return null;\r\n }\r\n var texture = SerializationHelper.Parse(function () {\r\n var generateMipMaps = true;\r\n if (parsedTexture.noMipmap) {\r\n generateMipMaps = false;\r\n }\r\n if (parsedTexture.mirrorPlane) {\r\n var mirrorTexture = Texture._CreateMirror(parsedTexture.name, parsedTexture.renderTargetSize, scene, generateMipMaps);\r\n mirrorTexture._waitingRenderList = parsedTexture.renderList;\r\n mirrorTexture.mirrorPlane = Plane.FromArray(parsedTexture.mirrorPlane);\r\n return mirrorTexture;\r\n }\r\n else if (parsedTexture.isRenderTarget) {\r\n var renderTargetTexture = null;\r\n if (parsedTexture.isCube) {\r\n // Search for an existing reflection probe (which contains a cube render target texture)\r\n if (scene.reflectionProbes) {\r\n for (var index = 0; index < scene.reflectionProbes.length; index++) {\r\n var probe = scene.reflectionProbes[index];\r\n if (probe.name === parsedTexture.name) {\r\n return probe.cubeTexture;\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n renderTargetTexture = Texture._CreateRenderTargetTexture(parsedTexture.name, parsedTexture.renderTargetSize, scene, generateMipMaps);\r\n renderTargetTexture._waitingRenderList = parsedTexture.renderList;\r\n }\r\n return renderTargetTexture;\r\n }\r\n else {\r\n var texture;\r\n if (parsedTexture.base64String) {\r\n texture = Texture.CreateFromBase64String(parsedTexture.base64String, parsedTexture.name, scene, !generateMipMaps, parsedTexture.invertY);\r\n }\r\n else {\r\n var url = rootUrl + parsedTexture.name;\r\n if (Texture.UseSerializedUrlIfAny && parsedTexture.url) {\r\n url = parsedTexture.url;\r\n }\r\n texture = new Texture(url, scene, !generateMipMaps, parsedTexture.invertY);\r\n }\r\n return texture;\r\n }\r\n }, parsedTexture, scene);\r\n // Clear cache\r\n if (texture && texture._texture) {\r\n texture._texture._cachedWrapU = null;\r\n texture._texture._cachedWrapV = null;\r\n texture._texture._cachedWrapR = null;\r\n }\r\n // Update Sampling Mode\r\n if (parsedTexture.samplingMode) {\r\n var sampling = parsedTexture.samplingMode;\r\n if (texture && texture.samplingMode !== sampling) {\r\n texture.updateSamplingMode(sampling);\r\n }\r\n }\r\n // Animations\r\n if (texture && parsedTexture.animations) {\r\n for (var animationIndex = 0; animationIndex < parsedTexture.animations.length; animationIndex++) {\r\n var parsedAnimation = parsedTexture.animations[animationIndex];\r\n var internalClass = _TypeStore.GetClass(\"BABYLON.Animation\");\r\n if (internalClass) {\r\n texture.animations.push(internalClass.Parse(parsedAnimation));\r\n }\r\n }\r\n }\r\n return texture;\r\n };\r\n /**\r\n * Creates a texture from its base 64 representation.\r\n * @param data Define the base64 payload without the data: prefix\r\n * @param name Define the name of the texture in the scene useful fo caching purpose for instance\r\n * @param scene Define the scene the texture should belong to\r\n * @param noMipmap Forces the texture to not create mip map information if true\r\n * @param invertY define if the texture needs to be inverted on the y axis during loading\r\n * @param samplingMode define the sampling mode we want for the texture while fectching from it (Texture.NEAREST_SAMPLINGMODE...)\r\n * @param onLoad define a callback triggered when the texture has been loaded\r\n * @param onError define a callback triggered when an error occurred during the loading session\r\n * @param format define the format of the texture we are trying to load (Engine.TEXTUREFORMAT_RGBA...)\r\n * @returns the created texture\r\n */\r\n Texture.CreateFromBase64String = function (data, name, scene, noMipmap, invertY, samplingMode, onLoad, onError, format) {\r\n if (samplingMode === void 0) { samplingMode = Texture.TRILINEAR_SAMPLINGMODE; }\r\n if (onLoad === void 0) { onLoad = null; }\r\n if (onError === void 0) { onError = null; }\r\n if (format === void 0) { format = 5; }\r\n return new Texture(\"data:\" + name, scene, noMipmap, invertY, samplingMode, onLoad, onError, data, false, format);\r\n };\r\n /**\r\n * Creates a texture from its data: representation. (data: will be added in case only the payload has been passed in)\r\n * @param data Define the base64 payload without the data: prefix\r\n * @param name Define the name of the texture in the scene useful fo caching purpose for instance\r\n * @param buffer define the buffer to load the texture from in case the texture is loaded from a buffer representation\r\n * @param scene Define the scene the texture should belong to\r\n * @param deleteBuffer define if the buffer we are loading the texture from should be deleted after load\r\n * @param noMipmap Forces the texture to not create mip map information if true\r\n * @param invertY define if the texture needs to be inverted on the y axis during loading\r\n * @param samplingMode define the sampling mode we want for the texture while fectching from it (Texture.NEAREST_SAMPLINGMODE...)\r\n * @param onLoad define a callback triggered when the texture has been loaded\r\n * @param onError define a callback triggered when an error occurred during the loading session\r\n * @param format define the format of the texture we are trying to load (Engine.TEXTUREFORMAT_RGBA...)\r\n * @returns the created texture\r\n */\r\n Texture.LoadFromDataString = function (name, buffer, scene, deleteBuffer, noMipmap, invertY, samplingMode, onLoad, onError, format) {\r\n if (deleteBuffer === void 0) { deleteBuffer = false; }\r\n if (noMipmap === void 0) { noMipmap = false; }\r\n if (invertY === void 0) { invertY = true; }\r\n if (samplingMode === void 0) { samplingMode = Texture.TRILINEAR_SAMPLINGMODE; }\r\n if (onLoad === void 0) { onLoad = null; }\r\n if (onError === void 0) { onError = null; }\r\n if (format === void 0) { format = 5; }\r\n if (name.substr(0, 5) !== \"data:\") {\r\n name = \"data:\" + name;\r\n }\r\n return new Texture(name, scene, noMipmap, invertY, samplingMode, onLoad, onError, buffer, deleteBuffer, format);\r\n };\r\n /**\r\n * Gets or sets a general boolean used to indicate that textures containing direct data (buffers) must be saved as part of the serialization process\r\n */\r\n Texture.SerializeBuffers = true;\r\n /** @hidden */\r\n Texture._CubeTextureParser = function (jsonTexture, scene, rootUrl) {\r\n throw _DevTools.WarnImport(\"CubeTexture\");\r\n };\r\n /** @hidden */\r\n Texture._CreateMirror = function (name, renderTargetSize, scene, generateMipMaps) {\r\n throw _DevTools.WarnImport(\"MirrorTexture\");\r\n };\r\n /** @hidden */\r\n Texture._CreateRenderTargetTexture = function (name, renderTargetSize, scene, generateMipMaps) {\r\n throw _DevTools.WarnImport(\"RenderTargetTexture\");\r\n };\r\n /** nearest is mag = nearest and min = nearest and mip = linear */\r\n Texture.NEAREST_SAMPLINGMODE = 1;\r\n /** nearest is mag = nearest and min = nearest and mip = linear */\r\n Texture.NEAREST_NEAREST_MIPLINEAR = 8; // nearest is mag = nearest and min = nearest and mip = linear\r\n /** Bilinear is mag = linear and min = linear and mip = nearest */\r\n Texture.BILINEAR_SAMPLINGMODE = 2;\r\n /** Bilinear is mag = linear and min = linear and mip = nearest */\r\n Texture.LINEAR_LINEAR_MIPNEAREST = 11; // Bilinear is mag = linear and min = linear and mip = nearest\r\n /** Trilinear is mag = linear and min = linear and mip = linear */\r\n Texture.TRILINEAR_SAMPLINGMODE = 3;\r\n /** Trilinear is mag = linear and min = linear and mip = linear */\r\n Texture.LINEAR_LINEAR_MIPLINEAR = 3; // Trilinear is mag = linear and min = linear and mip = linear\r\n /** mag = nearest and min = nearest and mip = nearest */\r\n Texture.NEAREST_NEAREST_MIPNEAREST = 4;\r\n /** mag = nearest and min = linear and mip = nearest */\r\n Texture.NEAREST_LINEAR_MIPNEAREST = 5;\r\n /** mag = nearest and min = linear and mip = linear */\r\n Texture.NEAREST_LINEAR_MIPLINEAR = 6;\r\n /** mag = nearest and min = linear and mip = none */\r\n Texture.NEAREST_LINEAR = 7;\r\n /** mag = nearest and min = nearest and mip = none */\r\n Texture.NEAREST_NEAREST = 1;\r\n /** mag = linear and min = nearest and mip = nearest */\r\n Texture.LINEAR_NEAREST_MIPNEAREST = 9;\r\n /** mag = linear and min = nearest and mip = linear */\r\n Texture.LINEAR_NEAREST_MIPLINEAR = 10;\r\n /** mag = linear and min = linear and mip = none */\r\n Texture.LINEAR_LINEAR = 2;\r\n /** mag = linear and min = nearest and mip = none */\r\n Texture.LINEAR_NEAREST = 12;\r\n /** Explicit coordinates mode */\r\n Texture.EXPLICIT_MODE = 0;\r\n /** Spherical coordinates mode */\r\n Texture.SPHERICAL_MODE = 1;\r\n /** Planar coordinates mode */\r\n Texture.PLANAR_MODE = 2;\r\n /** Cubic coordinates mode */\r\n Texture.CUBIC_MODE = 3;\r\n /** Projection coordinates mode */\r\n Texture.PROJECTION_MODE = 4;\r\n /** Inverse Cubic coordinates mode */\r\n Texture.SKYBOX_MODE = 5;\r\n /** Inverse Cubic coordinates mode */\r\n Texture.INVCUBIC_MODE = 6;\r\n /** Equirectangular coordinates mode */\r\n Texture.EQUIRECTANGULAR_MODE = 7;\r\n /** Equirectangular Fixed coordinates mode */\r\n Texture.FIXED_EQUIRECTANGULAR_MODE = 8;\r\n /** Equirectangular Fixed Mirrored coordinates mode */\r\n Texture.FIXED_EQUIRECTANGULAR_MIRRORED_MODE = 9;\r\n /** Texture is not repeating outside of 0..1 UVs */\r\n Texture.CLAMP_ADDRESSMODE = 0;\r\n /** Texture is repeating outside of 0..1 UVs */\r\n Texture.WRAP_ADDRESSMODE = 1;\r\n /** Texture is repeating and mirrored */\r\n Texture.MIRROR_ADDRESSMODE = 2;\r\n /**\r\n * Gets or sets a boolean which defines if the texture url must be build from the serialized URL instead of just using the name and loading them side by side with the scene file\r\n */\r\n Texture.UseSerializedUrlIfAny = false;\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"url\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"uOffset\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"vOffset\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"uScale\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"vScale\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"uAng\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"vAng\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"wAng\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"uRotationCenter\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"vRotationCenter\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"wRotationCenter\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"isBlocking\", null);\r\n return Texture;\r\n}(BaseTexture));\r\nexport { Texture };\r\n// References the dependencies.\r\nSerializationHelper._TextureParser = Texture.Parse;\r\n//# sourceMappingURL=texture.js.map","import { Logger } from \"../Misc/logger\";\r\nimport { Scene } from \"../scene\";\r\nimport { EngineStore } from \"../Engines/engineStore\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { Light } from \"../Lights/light\";\r\nimport { Color3 } from '../Maths/math.color';\r\n/**\r\n * \"Static Class\" containing the most commonly used helper while dealing with material for\r\n * rendering purpose.\r\n *\r\n * It contains the basic tools to help defining defines, binding uniform for the common part of the materials.\r\n *\r\n * This works by convention in BabylonJS but is meant to be use only with shader following the in place naming rules and conventions.\r\n */\r\nvar MaterialHelper = /** @class */ (function () {\r\n function MaterialHelper() {\r\n }\r\n /**\r\n * Bind the current view position to an effect.\r\n * @param effect The effect to be bound\r\n * @param scene The scene the eyes position is used from\r\n */\r\n MaterialHelper.BindEyePosition = function (effect, scene) {\r\n if (scene._forcedViewPosition) {\r\n effect.setVector3(\"vEyePosition\", scene._forcedViewPosition);\r\n return;\r\n }\r\n var globalPosition = scene.activeCamera.globalPosition;\r\n if (!globalPosition) {\r\n // Use WebVRFreecamera's device position as global position is not it's actual position in babylon space\r\n globalPosition = scene.activeCamera.devicePosition;\r\n }\r\n effect.setVector3(\"vEyePosition\", scene._mirroredCameraPosition ? scene._mirroredCameraPosition : globalPosition);\r\n };\r\n /**\r\n * Helps preparing the defines values about the UVs in used in the effect.\r\n * UVs are shared as much as we can accross channels in the shaders.\r\n * @param texture The texture we are preparing the UVs for\r\n * @param defines The defines to update\r\n * @param key The channel key \"diffuse\", \"specular\"... used in the shader\r\n */\r\n MaterialHelper.PrepareDefinesForMergedUV = function (texture, defines, key) {\r\n defines._needUVs = true;\r\n defines[key] = true;\r\n if (texture.getTextureMatrix().isIdentityAs3x2()) {\r\n defines[key + \"DIRECTUV\"] = texture.coordinatesIndex + 1;\r\n if (texture.coordinatesIndex === 0) {\r\n defines[\"MAINUV1\"] = true;\r\n }\r\n else {\r\n defines[\"MAINUV2\"] = true;\r\n }\r\n }\r\n else {\r\n defines[key + \"DIRECTUV\"] = 0;\r\n }\r\n };\r\n /**\r\n * Binds a texture matrix value to its corrsponding uniform\r\n * @param texture The texture to bind the matrix for\r\n * @param uniformBuffer The uniform buffer receivin the data\r\n * @param key The channel key \"diffuse\", \"specular\"... used in the shader\r\n */\r\n MaterialHelper.BindTextureMatrix = function (texture, uniformBuffer, key) {\r\n var matrix = texture.getTextureMatrix();\r\n uniformBuffer.updateMatrix(key + \"Matrix\", matrix);\r\n };\r\n /**\r\n * Gets the current status of the fog (should it be enabled?)\r\n * @param mesh defines the mesh to evaluate for fog support\r\n * @param scene defines the hosting scene\r\n * @returns true if fog must be enabled\r\n */\r\n MaterialHelper.GetFogState = function (mesh, scene) {\r\n return (scene.fogEnabled && mesh.applyFog && scene.fogMode !== Scene.FOGMODE_NONE);\r\n };\r\n /**\r\n * Helper used to prepare the list of defines associated with misc. values for shader compilation\r\n * @param mesh defines the current mesh\r\n * @param scene defines the current scene\r\n * @param useLogarithmicDepth defines if logarithmic depth has to be turned on\r\n * @param pointsCloud defines if point cloud rendering has to be turned on\r\n * @param fogEnabled defines if fog has to be turned on\r\n * @param alphaTest defines if alpha testing has to be turned on\r\n * @param defines defines the current list of defines\r\n */\r\n MaterialHelper.PrepareDefinesForMisc = function (mesh, scene, useLogarithmicDepth, pointsCloud, fogEnabled, alphaTest, defines) {\r\n if (defines._areMiscDirty) {\r\n defines[\"LOGARITHMICDEPTH\"] = useLogarithmicDepth;\r\n defines[\"POINTSIZE\"] = pointsCloud;\r\n defines[\"FOG\"] = fogEnabled && this.GetFogState(mesh, scene);\r\n defines[\"NONUNIFORMSCALING\"] = mesh.nonUniformScaling;\r\n defines[\"ALPHATEST\"] = alphaTest;\r\n }\r\n };\r\n /**\r\n * Helper used to prepare the list of defines associated with frame values for shader compilation\r\n * @param scene defines the current scene\r\n * @param engine defines the current engine\r\n * @param defines specifies the list of active defines\r\n * @param useInstances defines if instances have to be turned on\r\n * @param useClipPlane defines if clip plane have to be turned on\r\n */\r\n MaterialHelper.PrepareDefinesForFrameBoundValues = function (scene, engine, defines, useInstances, useClipPlane) {\r\n if (useClipPlane === void 0) { useClipPlane = null; }\r\n var changed = false;\r\n var useClipPlane1 = false;\r\n var useClipPlane2 = false;\r\n var useClipPlane3 = false;\r\n var useClipPlane4 = false;\r\n var useClipPlane5 = false;\r\n var useClipPlane6 = false;\r\n useClipPlane1 = useClipPlane == null ? (scene.clipPlane !== undefined && scene.clipPlane !== null) : useClipPlane;\r\n useClipPlane2 = useClipPlane == null ? (scene.clipPlane2 !== undefined && scene.clipPlane2 !== null) : useClipPlane;\r\n useClipPlane3 = useClipPlane == null ? (scene.clipPlane3 !== undefined && scene.clipPlane3 !== null) : useClipPlane;\r\n useClipPlane4 = useClipPlane == null ? (scene.clipPlane4 !== undefined && scene.clipPlane4 !== null) : useClipPlane;\r\n useClipPlane5 = useClipPlane == null ? (scene.clipPlane5 !== undefined && scene.clipPlane5 !== null) : useClipPlane;\r\n useClipPlane6 = useClipPlane == null ? (scene.clipPlane6 !== undefined && scene.clipPlane6 !== null) : useClipPlane;\r\n if (defines[\"CLIPPLANE\"] !== useClipPlane1) {\r\n defines[\"CLIPPLANE\"] = useClipPlane1;\r\n changed = true;\r\n }\r\n if (defines[\"CLIPPLANE2\"] !== useClipPlane2) {\r\n defines[\"CLIPPLANE2\"] = useClipPlane2;\r\n changed = true;\r\n }\r\n if (defines[\"CLIPPLANE3\"] !== useClipPlane3) {\r\n defines[\"CLIPPLANE3\"] = useClipPlane3;\r\n changed = true;\r\n }\r\n if (defines[\"CLIPPLANE4\"] !== useClipPlane4) {\r\n defines[\"CLIPPLANE4\"] = useClipPlane4;\r\n changed = true;\r\n }\r\n if (defines[\"CLIPPLANE5\"] !== useClipPlane5) {\r\n defines[\"CLIPPLANE5\"] = useClipPlane5;\r\n changed = true;\r\n }\r\n if (defines[\"CLIPPLANE6\"] !== useClipPlane6) {\r\n defines[\"CLIPPLANE6\"] = useClipPlane6;\r\n changed = true;\r\n }\r\n if (defines[\"DEPTHPREPASS\"] !== !engine.getColorWrite()) {\r\n defines[\"DEPTHPREPASS\"] = !defines[\"DEPTHPREPASS\"];\r\n changed = true;\r\n }\r\n if (defines[\"INSTANCES\"] !== useInstances) {\r\n defines[\"INSTANCES\"] = useInstances;\r\n changed = true;\r\n }\r\n if (changed) {\r\n defines.markAsUnprocessed();\r\n }\r\n };\r\n /**\r\n * Prepares the defines for bones\r\n * @param mesh The mesh containing the geometry data we will draw\r\n * @param defines The defines to update\r\n */\r\n MaterialHelper.PrepareDefinesForBones = function (mesh, defines) {\r\n if (mesh.useBones && mesh.computeBonesUsingShaders && mesh.skeleton) {\r\n defines[\"NUM_BONE_INFLUENCERS\"] = mesh.numBoneInfluencers;\r\n var materialSupportsBoneTexture = defines[\"BONETEXTURE\"] !== undefined;\r\n if (mesh.skeleton.isUsingTextureForMatrices && materialSupportsBoneTexture) {\r\n defines[\"BONETEXTURE\"] = true;\r\n }\r\n else {\r\n defines[\"BonesPerMesh\"] = (mesh.skeleton.bones.length + 1);\r\n defines[\"BONETEXTURE\"] = materialSupportsBoneTexture ? false : undefined;\r\n }\r\n }\r\n else {\r\n defines[\"NUM_BONE_INFLUENCERS\"] = 0;\r\n defines[\"BonesPerMesh\"] = 0;\r\n }\r\n };\r\n /**\r\n * Prepares the defines for morph targets\r\n * @param mesh The mesh containing the geometry data we will draw\r\n * @param defines The defines to update\r\n */\r\n MaterialHelper.PrepareDefinesForMorphTargets = function (mesh, defines) {\r\n var manager = mesh.morphTargetManager;\r\n if (manager) {\r\n defines[\"MORPHTARGETS_UV\"] = manager.supportsUVs && defines[\"UV1\"];\r\n defines[\"MORPHTARGETS_TANGENT\"] = manager.supportsTangents && defines[\"TANGENT\"];\r\n defines[\"MORPHTARGETS_NORMAL\"] = manager.supportsNormals && defines[\"NORMAL\"];\r\n defines[\"MORPHTARGETS\"] = (manager.numInfluencers > 0);\r\n defines[\"NUM_MORPH_INFLUENCERS\"] = manager.numInfluencers;\r\n }\r\n else {\r\n defines[\"MORPHTARGETS_UV\"] = false;\r\n defines[\"MORPHTARGETS_TANGENT\"] = false;\r\n defines[\"MORPHTARGETS_NORMAL\"] = false;\r\n defines[\"MORPHTARGETS\"] = false;\r\n defines[\"NUM_MORPH_INFLUENCERS\"] = 0;\r\n }\r\n };\r\n /**\r\n * Prepares the defines used in the shader depending on the attributes data available in the mesh\r\n * @param mesh The mesh containing the geometry data we will draw\r\n * @param defines The defines to update\r\n * @param useVertexColor Precise whether vertex colors should be used or not (override mesh info)\r\n * @param useBones Precise whether bones should be used or not (override mesh info)\r\n * @param useMorphTargets Precise whether morph targets should be used or not (override mesh info)\r\n * @param useVertexAlpha Precise whether vertex alpha should be used or not (override mesh info)\r\n * @returns false if defines are considered not dirty and have not been checked\r\n */\r\n MaterialHelper.PrepareDefinesForAttributes = function (mesh, defines, useVertexColor, useBones, useMorphTargets, useVertexAlpha) {\r\n if (useMorphTargets === void 0) { useMorphTargets = false; }\r\n if (useVertexAlpha === void 0) { useVertexAlpha = true; }\r\n if (!defines._areAttributesDirty && defines._needNormals === defines._normals && defines._needUVs === defines._uvs) {\r\n return false;\r\n }\r\n defines._normals = defines._needNormals;\r\n defines._uvs = defines._needUVs;\r\n defines[\"NORMAL\"] = (defines._needNormals && mesh.isVerticesDataPresent(VertexBuffer.NormalKind));\r\n if (defines._needNormals && mesh.isVerticesDataPresent(VertexBuffer.TangentKind)) {\r\n defines[\"TANGENT\"] = true;\r\n }\r\n if (defines._needUVs) {\r\n defines[\"UV1\"] = mesh.isVerticesDataPresent(VertexBuffer.UVKind);\r\n defines[\"UV2\"] = mesh.isVerticesDataPresent(VertexBuffer.UV2Kind);\r\n }\r\n else {\r\n defines[\"UV1\"] = false;\r\n defines[\"UV2\"] = false;\r\n }\r\n if (useVertexColor) {\r\n var hasVertexColors = mesh.useVertexColors && mesh.isVerticesDataPresent(VertexBuffer.ColorKind);\r\n defines[\"VERTEXCOLOR\"] = hasVertexColors;\r\n defines[\"VERTEXALPHA\"] = mesh.hasVertexAlpha && hasVertexColors && useVertexAlpha;\r\n }\r\n if (useBones) {\r\n this.PrepareDefinesForBones(mesh, defines);\r\n }\r\n if (useMorphTargets) {\r\n this.PrepareDefinesForMorphTargets(mesh, defines);\r\n }\r\n return true;\r\n };\r\n /**\r\n * Prepares the defines related to multiview\r\n * @param scene The scene we are intending to draw\r\n * @param defines The defines to update\r\n */\r\n MaterialHelper.PrepareDefinesForMultiview = function (scene, defines) {\r\n if (scene.activeCamera) {\r\n var previousMultiview = defines.MULTIVIEW;\r\n defines.MULTIVIEW = (scene.activeCamera.outputRenderTarget !== null && scene.activeCamera.outputRenderTarget.getViewCount() > 1);\r\n if (defines.MULTIVIEW != previousMultiview) {\r\n defines.markAsUnprocessed();\r\n }\r\n }\r\n };\r\n /**\r\n * Prepares the defines related to the light information passed in parameter\r\n * @param scene The scene we are intending to draw\r\n * @param mesh The mesh the effect is compiling for\r\n * @param light The light the effect is compiling for\r\n * @param lightIndex The index of the light\r\n * @param defines The defines to update\r\n * @param specularSupported Specifies whether specular is supported or not (override lights data)\r\n * @param state Defines the current state regarding what is needed (normals, etc...)\r\n */\r\n MaterialHelper.PrepareDefinesForLight = function (scene, mesh, light, lightIndex, defines, specularSupported, state) {\r\n state.needNormals = true;\r\n if (defines[\"LIGHT\" + lightIndex] === undefined) {\r\n state.needRebuild = true;\r\n }\r\n defines[\"LIGHT\" + lightIndex] = true;\r\n defines[\"SPOTLIGHT\" + lightIndex] = false;\r\n defines[\"HEMILIGHT\" + lightIndex] = false;\r\n defines[\"POINTLIGHT\" + lightIndex] = false;\r\n defines[\"DIRLIGHT\" + lightIndex] = false;\r\n light.prepareLightSpecificDefines(defines, lightIndex);\r\n // FallOff.\r\n defines[\"LIGHT_FALLOFF_PHYSICAL\" + lightIndex] = false;\r\n defines[\"LIGHT_FALLOFF_GLTF\" + lightIndex] = false;\r\n defines[\"LIGHT_FALLOFF_STANDARD\" + lightIndex] = false;\r\n switch (light.falloffType) {\r\n case Light.FALLOFF_GLTF:\r\n defines[\"LIGHT_FALLOFF_GLTF\" + lightIndex] = true;\r\n break;\r\n case Light.FALLOFF_PHYSICAL:\r\n defines[\"LIGHT_FALLOFF_PHYSICAL\" + lightIndex] = true;\r\n break;\r\n case Light.FALLOFF_STANDARD:\r\n defines[\"LIGHT_FALLOFF_STANDARD\" + lightIndex] = true;\r\n break;\r\n }\r\n // Specular\r\n if (specularSupported && !light.specular.equalsFloats(0, 0, 0)) {\r\n state.specularEnabled = true;\r\n }\r\n // Shadows\r\n defines[\"SHADOW\" + lightIndex] = false;\r\n defines[\"SHADOWCSM\" + lightIndex] = false;\r\n defines[\"SHADOWCSMDEBUG\" + lightIndex] = false;\r\n defines[\"SHADOWCSMNUM_CASCADES\" + lightIndex] = false;\r\n defines[\"SHADOWCSMUSESHADOWMAXZ\" + lightIndex] = false;\r\n defines[\"SHADOWCSMNOBLEND\" + lightIndex] = false;\r\n defines[\"SHADOWCSM_RIGHTHANDED\" + lightIndex] = false;\r\n defines[\"SHADOWPCF\" + lightIndex] = false;\r\n defines[\"SHADOWPCSS\" + lightIndex] = false;\r\n defines[\"SHADOWPOISSON\" + lightIndex] = false;\r\n defines[\"SHADOWESM\" + lightIndex] = false;\r\n defines[\"SHADOWCUBE\" + lightIndex] = false;\r\n defines[\"SHADOWLOWQUALITY\" + lightIndex] = false;\r\n defines[\"SHADOWMEDIUMQUALITY\" + lightIndex] = false;\r\n if (mesh && mesh.receiveShadows && scene.shadowsEnabled && light.shadowEnabled) {\r\n var shadowGenerator = light.getShadowGenerator();\r\n if (shadowGenerator) {\r\n var shadowMap = shadowGenerator.getShadowMap();\r\n if (shadowMap) {\r\n if (shadowMap.renderList && shadowMap.renderList.length > 0) {\r\n state.shadowEnabled = true;\r\n shadowGenerator.prepareDefines(defines, lightIndex);\r\n }\r\n }\r\n }\r\n }\r\n if (light.lightmapMode != Light.LIGHTMAP_DEFAULT) {\r\n state.lightmapMode = true;\r\n defines[\"LIGHTMAPEXCLUDED\" + lightIndex] = true;\r\n defines[\"LIGHTMAPNOSPECULAR\" + lightIndex] = (light.lightmapMode == Light.LIGHTMAP_SHADOWSONLY);\r\n }\r\n else {\r\n defines[\"LIGHTMAPEXCLUDED\" + lightIndex] = false;\r\n defines[\"LIGHTMAPNOSPECULAR\" + lightIndex] = false;\r\n }\r\n };\r\n /**\r\n * Prepares the defines related to the light information passed in parameter\r\n * @param scene The scene we are intending to draw\r\n * @param mesh The mesh the effect is compiling for\r\n * @param defines The defines to update\r\n * @param specularSupported Specifies whether specular is supported or not (override lights data)\r\n * @param maxSimultaneousLights Specfies how manuy lights can be added to the effect at max\r\n * @param disableLighting Specifies whether the lighting is disabled (override scene and light)\r\n * @returns true if normals will be required for the rest of the effect\r\n */\r\n MaterialHelper.PrepareDefinesForLights = function (scene, mesh, defines, specularSupported, maxSimultaneousLights, disableLighting) {\r\n if (maxSimultaneousLights === void 0) { maxSimultaneousLights = 4; }\r\n if (disableLighting === void 0) { disableLighting = false; }\r\n if (!defines._areLightsDirty) {\r\n return defines._needNormals;\r\n }\r\n var lightIndex = 0;\r\n var state = {\r\n needNormals: false,\r\n needRebuild: false,\r\n lightmapMode: false,\r\n shadowEnabled: false,\r\n specularEnabled: false\r\n };\r\n if (scene.lightsEnabled && !disableLighting) {\r\n for (var _i = 0, _a = mesh.lightSources; _i < _a.length; _i++) {\r\n var light = _a[_i];\r\n this.PrepareDefinesForLight(scene, mesh, light, lightIndex, defines, specularSupported, state);\r\n lightIndex++;\r\n if (lightIndex === maxSimultaneousLights) {\r\n break;\r\n }\r\n }\r\n }\r\n defines[\"SPECULARTERM\"] = state.specularEnabled;\r\n defines[\"SHADOWS\"] = state.shadowEnabled;\r\n // Resetting all other lights if any\r\n for (var index = lightIndex; index < maxSimultaneousLights; index++) {\r\n if (defines[\"LIGHT\" + index] !== undefined) {\r\n defines[\"LIGHT\" + index] = false;\r\n defines[\"HEMILIGHT\" + index] = false;\r\n defines[\"POINTLIGHT\" + index] = false;\r\n defines[\"DIRLIGHT\" + index] = false;\r\n defines[\"SPOTLIGHT\" + index] = false;\r\n defines[\"SHADOW\" + index] = false;\r\n defines[\"SHADOWCSM\" + index] = false;\r\n defines[\"SHADOWCSMDEBUG\" + index] = false;\r\n defines[\"SHADOWCSMNUM_CASCADES\" + index] = false;\r\n defines[\"SHADOWCSMUSESHADOWMAXZ\" + index] = false;\r\n defines[\"SHADOWCSMNOBLEND\" + index] = false;\r\n defines[\"SHADOWCSM_RIGHTHANDED\" + index] = false;\r\n defines[\"SHADOWPCF\" + index] = false;\r\n defines[\"SHADOWPCSS\" + index] = false;\r\n defines[\"SHADOWPOISSON\" + index] = false;\r\n defines[\"SHADOWESM\" + index] = false;\r\n defines[\"SHADOWCUBE\" + index] = false;\r\n defines[\"SHADOWLOWQUALITY\" + index] = false;\r\n defines[\"SHADOWMEDIUMQUALITY\" + index] = false;\r\n }\r\n }\r\n var caps = scene.getEngine().getCaps();\r\n if (defines[\"SHADOWFLOAT\"] === undefined) {\r\n state.needRebuild = true;\r\n }\r\n defines[\"SHADOWFLOAT\"] = state.shadowEnabled &&\r\n ((caps.textureFloatRender && caps.textureFloatLinearFiltering) ||\r\n (caps.textureHalfFloatRender && caps.textureHalfFloatLinearFiltering));\r\n defines[\"LIGHTMAPEXCLUDED\"] = state.lightmapMode;\r\n if (state.needRebuild) {\r\n defines.rebuild();\r\n }\r\n return state.needNormals;\r\n };\r\n /**\r\n * Prepares the uniforms and samplers list to be used in the effect (for a specific light)\r\n * @param lightIndex defines the light index\r\n * @param uniformsList The uniform list\r\n * @param samplersList The sampler list\r\n * @param projectedLightTexture defines if projected texture must be used\r\n * @param uniformBuffersList defines an optional list of uniform buffers\r\n */\r\n MaterialHelper.PrepareUniformsAndSamplersForLight = function (lightIndex, uniformsList, samplersList, projectedLightTexture, uniformBuffersList) {\r\n if (uniformBuffersList === void 0) { uniformBuffersList = null; }\r\n uniformsList.push(\"vLightData\" + lightIndex, \"vLightDiffuse\" + lightIndex, \"vLightSpecular\" + lightIndex, \"vLightDirection\" + lightIndex, \"vLightFalloff\" + lightIndex, \"vLightGround\" + lightIndex, \"lightMatrix\" + lightIndex, \"shadowsInfo\" + lightIndex, \"depthValues\" + lightIndex);\r\n if (uniformBuffersList) {\r\n uniformBuffersList.push(\"Light\" + lightIndex);\r\n }\r\n samplersList.push(\"shadowSampler\" + lightIndex);\r\n samplersList.push(\"depthSampler\" + lightIndex);\r\n uniformsList.push(\"viewFrustumZ\" + lightIndex, \"cascadeBlendFactor\" + lightIndex, \"lightSizeUVCorrection\" + lightIndex, \"depthCorrection\" + lightIndex, \"penumbraDarkness\" + lightIndex, \"frustumLengths\" + lightIndex);\r\n if (projectedLightTexture) {\r\n samplersList.push(\"projectionLightSampler\" + lightIndex);\r\n uniformsList.push(\"textureProjectionMatrix\" + lightIndex);\r\n }\r\n };\r\n /**\r\n * Prepares the uniforms and samplers list to be used in the effect\r\n * @param uniformsListOrOptions The uniform names to prepare or an EffectCreationOptions containing the liist and extra information\r\n * @param samplersList The sampler list\r\n * @param defines The defines helping in the list generation\r\n * @param maxSimultaneousLights The maximum number of simultanous light allowed in the effect\r\n */\r\n MaterialHelper.PrepareUniformsAndSamplersList = function (uniformsListOrOptions, samplersList, defines, maxSimultaneousLights) {\r\n if (maxSimultaneousLights === void 0) { maxSimultaneousLights = 4; }\r\n var uniformsList;\r\n var uniformBuffersList = null;\r\n if (uniformsListOrOptions.uniformsNames) {\r\n var options = uniformsListOrOptions;\r\n uniformsList = options.uniformsNames;\r\n uniformBuffersList = options.uniformBuffersNames;\r\n samplersList = options.samplers;\r\n defines = options.defines;\r\n maxSimultaneousLights = options.maxSimultaneousLights || 0;\r\n }\r\n else {\r\n uniformsList = uniformsListOrOptions;\r\n if (!samplersList) {\r\n samplersList = [];\r\n }\r\n }\r\n for (var lightIndex = 0; lightIndex < maxSimultaneousLights; lightIndex++) {\r\n if (!defines[\"LIGHT\" + lightIndex]) {\r\n break;\r\n }\r\n this.PrepareUniformsAndSamplersForLight(lightIndex, uniformsList, samplersList, defines[\"PROJECTEDLIGHTTEXTURE\" + lightIndex], uniformBuffersList);\r\n }\r\n if (defines[\"NUM_MORPH_INFLUENCERS\"]) {\r\n uniformsList.push(\"morphTargetInfluences\");\r\n }\r\n };\r\n /**\r\n * This helps decreasing rank by rank the shadow quality (0 being the highest rank and quality)\r\n * @param defines The defines to update while falling back\r\n * @param fallbacks The authorized effect fallbacks\r\n * @param maxSimultaneousLights The maximum number of lights allowed\r\n * @param rank the current rank of the Effect\r\n * @returns The newly affected rank\r\n */\r\n MaterialHelper.HandleFallbacksForShadows = function (defines, fallbacks, maxSimultaneousLights, rank) {\r\n if (maxSimultaneousLights === void 0) { maxSimultaneousLights = 4; }\r\n if (rank === void 0) { rank = 0; }\r\n var lightFallbackRank = 0;\r\n for (var lightIndex = 0; lightIndex < maxSimultaneousLights; lightIndex++) {\r\n if (!defines[\"LIGHT\" + lightIndex]) {\r\n break;\r\n }\r\n if (lightIndex > 0) {\r\n lightFallbackRank = rank + lightIndex;\r\n fallbacks.addFallback(lightFallbackRank, \"LIGHT\" + lightIndex);\r\n }\r\n if (!defines[\"SHADOWS\"]) {\r\n if (defines[\"SHADOW\" + lightIndex]) {\r\n fallbacks.addFallback(rank, \"SHADOW\" + lightIndex);\r\n }\r\n if (defines[\"SHADOWPCF\" + lightIndex]) {\r\n fallbacks.addFallback(rank, \"SHADOWPCF\" + lightIndex);\r\n }\r\n if (defines[\"SHADOWPCSS\" + lightIndex]) {\r\n fallbacks.addFallback(rank, \"SHADOWPCSS\" + lightIndex);\r\n }\r\n if (defines[\"SHADOWPOISSON\" + lightIndex]) {\r\n fallbacks.addFallback(rank, \"SHADOWPOISSON\" + lightIndex);\r\n }\r\n if (defines[\"SHADOWESM\" + lightIndex]) {\r\n fallbacks.addFallback(rank, \"SHADOWESM\" + lightIndex);\r\n }\r\n }\r\n }\r\n return lightFallbackRank++;\r\n };\r\n /**\r\n * Prepares the list of attributes required for morph targets according to the effect defines.\r\n * @param attribs The current list of supported attribs\r\n * @param mesh The mesh to prepare the morph targets attributes for\r\n * @param influencers The number of influencers\r\n */\r\n MaterialHelper.PrepareAttributesForMorphTargetsInfluencers = function (attribs, mesh, influencers) {\r\n this._TmpMorphInfluencers.NUM_MORPH_INFLUENCERS = influencers;\r\n this.PrepareAttributesForMorphTargets(attribs, mesh, this._TmpMorphInfluencers);\r\n };\r\n /**\r\n * Prepares the list of attributes required for morph targets according to the effect defines.\r\n * @param attribs The current list of supported attribs\r\n * @param mesh The mesh to prepare the morph targets attributes for\r\n * @param defines The current Defines of the effect\r\n */\r\n MaterialHelper.PrepareAttributesForMorphTargets = function (attribs, mesh, defines) {\r\n var influencers = defines[\"NUM_MORPH_INFLUENCERS\"];\r\n if (influencers > 0 && EngineStore.LastCreatedEngine) {\r\n var maxAttributesCount = EngineStore.LastCreatedEngine.getCaps().maxVertexAttribs;\r\n var manager = mesh.morphTargetManager;\r\n var normal = manager && manager.supportsNormals && defines[\"NORMAL\"];\r\n var tangent = manager && manager.supportsTangents && defines[\"TANGENT\"];\r\n var uv = manager && manager.supportsUVs && defines[\"UV1\"];\r\n for (var index = 0; index < influencers; index++) {\r\n attribs.push(VertexBuffer.PositionKind + index);\r\n if (normal) {\r\n attribs.push(VertexBuffer.NormalKind + index);\r\n }\r\n if (tangent) {\r\n attribs.push(VertexBuffer.TangentKind + index);\r\n }\r\n if (uv) {\r\n attribs.push(VertexBuffer.UVKind + \"_\" + index);\r\n }\r\n if (attribs.length > maxAttributesCount) {\r\n Logger.Error(\"Cannot add more vertex attributes for mesh \" + mesh.name);\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Prepares the list of attributes required for bones according to the effect defines.\r\n * @param attribs The current list of supported attribs\r\n * @param mesh The mesh to prepare the bones attributes for\r\n * @param defines The current Defines of the effect\r\n * @param fallbacks The current efffect fallback strategy\r\n */\r\n MaterialHelper.PrepareAttributesForBones = function (attribs, mesh, defines, fallbacks) {\r\n if (defines[\"NUM_BONE_INFLUENCERS\"] > 0) {\r\n fallbacks.addCPUSkinningFallback(0, mesh);\r\n attribs.push(VertexBuffer.MatricesIndicesKind);\r\n attribs.push(VertexBuffer.MatricesWeightsKind);\r\n if (defines[\"NUM_BONE_INFLUENCERS\"] > 4) {\r\n attribs.push(VertexBuffer.MatricesIndicesExtraKind);\r\n attribs.push(VertexBuffer.MatricesWeightsExtraKind);\r\n }\r\n }\r\n };\r\n /**\r\n * Check and prepare the list of attributes required for instances according to the effect defines.\r\n * @param attribs The current list of supported attribs\r\n * @param defines The current MaterialDefines of the effect\r\n */\r\n MaterialHelper.PrepareAttributesForInstances = function (attribs, defines) {\r\n if (defines[\"INSTANCES\"]) {\r\n this.PushAttributesForInstances(attribs);\r\n }\r\n };\r\n /**\r\n * Add the list of attributes required for instances to the attribs array.\r\n * @param attribs The current list of supported attribs\r\n */\r\n MaterialHelper.PushAttributesForInstances = function (attribs) {\r\n attribs.push(\"world0\");\r\n attribs.push(\"world1\");\r\n attribs.push(\"world2\");\r\n attribs.push(\"world3\");\r\n };\r\n /**\r\n * Binds the light information to the effect.\r\n * @param light The light containing the generator\r\n * @param effect The effect we are binding the data to\r\n * @param lightIndex The light index in the effect used to render\r\n */\r\n MaterialHelper.BindLightProperties = function (light, effect, lightIndex) {\r\n light.transferToEffect(effect, lightIndex + \"\");\r\n };\r\n /**\r\n * Binds the lights information from the scene to the effect for the given mesh.\r\n * @param light Light to bind\r\n * @param lightIndex Light index\r\n * @param scene The scene where the light belongs to\r\n * @param effect The effect we are binding the data to\r\n * @param useSpecular Defines if specular is supported\r\n * @param rebuildInParallel Specifies whether the shader is rebuilding in parallel\r\n */\r\n MaterialHelper.BindLight = function (light, lightIndex, scene, effect, useSpecular, rebuildInParallel) {\r\n if (rebuildInParallel === void 0) { rebuildInParallel = false; }\r\n light._bindLight(lightIndex, scene, effect, useSpecular, rebuildInParallel);\r\n };\r\n /**\r\n * Binds the lights information from the scene to the effect for the given mesh.\r\n * @param scene The scene the lights belongs to\r\n * @param mesh The mesh we are binding the information to render\r\n * @param effect The effect we are binding the data to\r\n * @param defines The generated defines for the effect\r\n * @param maxSimultaneousLights The maximum number of light that can be bound to the effect\r\n * @param rebuildInParallel Specifies whether the shader is rebuilding in parallel\r\n */\r\n MaterialHelper.BindLights = function (scene, mesh, effect, defines, maxSimultaneousLights, rebuildInParallel) {\r\n if (maxSimultaneousLights === void 0) { maxSimultaneousLights = 4; }\r\n if (rebuildInParallel === void 0) { rebuildInParallel = false; }\r\n var len = Math.min(mesh.lightSources.length, maxSimultaneousLights);\r\n for (var i = 0; i < len; i++) {\r\n var light = mesh.lightSources[i];\r\n this.BindLight(light, i, scene, effect, typeof defines === \"boolean\" ? defines : defines[\"SPECULARTERM\"], rebuildInParallel);\r\n }\r\n };\r\n /**\r\n * Binds the fog information from the scene to the effect for the given mesh.\r\n * @param scene The scene the lights belongs to\r\n * @param mesh The mesh we are binding the information to render\r\n * @param effect The effect we are binding the data to\r\n * @param linearSpace Defines if the fog effect is applied in linear space\r\n */\r\n MaterialHelper.BindFogParameters = function (scene, mesh, effect, linearSpace) {\r\n if (linearSpace === void 0) { linearSpace = false; }\r\n if (scene.fogEnabled && mesh.applyFog && scene.fogMode !== Scene.FOGMODE_NONE) {\r\n effect.setFloat4(\"vFogInfos\", scene.fogMode, scene.fogStart, scene.fogEnd, scene.fogDensity);\r\n // Convert fog color to linear space if used in a linear space computed shader.\r\n if (linearSpace) {\r\n scene.fogColor.toLinearSpaceToRef(this._tempFogColor);\r\n effect.setColor3(\"vFogColor\", this._tempFogColor);\r\n }\r\n else {\r\n effect.setColor3(\"vFogColor\", scene.fogColor);\r\n }\r\n }\r\n };\r\n /**\r\n * Binds the bones information from the mesh to the effect.\r\n * @param mesh The mesh we are binding the information to render\r\n * @param effect The effect we are binding the data to\r\n */\r\n MaterialHelper.BindBonesParameters = function (mesh, effect) {\r\n if (!effect || !mesh) {\r\n return;\r\n }\r\n if (mesh.computeBonesUsingShaders && effect._bonesComputationForcedToCPU) {\r\n mesh.computeBonesUsingShaders = false;\r\n }\r\n if (mesh.useBones && mesh.computeBonesUsingShaders && mesh.skeleton) {\r\n var skeleton = mesh.skeleton;\r\n if (skeleton.isUsingTextureForMatrices && effect.getUniformIndex(\"boneTextureWidth\") > -1) {\r\n var boneTexture = skeleton.getTransformMatrixTexture(mesh);\r\n effect.setTexture(\"boneSampler\", boneTexture);\r\n effect.setFloat(\"boneTextureWidth\", 4.0 * (skeleton.bones.length + 1));\r\n }\r\n else {\r\n var matrices = skeleton.getTransformMatrices(mesh);\r\n if (matrices) {\r\n effect.setMatrices(\"mBones\", matrices);\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Binds the morph targets information from the mesh to the effect.\r\n * @param abstractMesh The mesh we are binding the information to render\r\n * @param effect The effect we are binding the data to\r\n */\r\n MaterialHelper.BindMorphTargetParameters = function (abstractMesh, effect) {\r\n var manager = abstractMesh.morphTargetManager;\r\n if (!abstractMesh || !manager) {\r\n return;\r\n }\r\n effect.setFloatArray(\"morphTargetInfluences\", manager.influences);\r\n };\r\n /**\r\n * Binds the logarithmic depth information from the scene to the effect for the given defines.\r\n * @param defines The generated defines used in the effect\r\n * @param effect The effect we are binding the data to\r\n * @param scene The scene we are willing to render with logarithmic scale for\r\n */\r\n MaterialHelper.BindLogDepth = function (defines, effect, scene) {\r\n if (defines[\"LOGARITHMICDEPTH\"]) {\r\n effect.setFloat(\"logarithmicDepthConstant\", 2.0 / (Math.log(scene.activeCamera.maxZ + 1.0) / Math.LN2));\r\n }\r\n };\r\n /**\r\n * Binds the clip plane information from the scene to the effect.\r\n * @param scene The scene the clip plane information are extracted from\r\n * @param effect The effect we are binding the data to\r\n */\r\n MaterialHelper.BindClipPlane = function (effect, scene) {\r\n if (scene.clipPlane) {\r\n var clipPlane = scene.clipPlane;\r\n effect.setFloat4(\"vClipPlane\", clipPlane.normal.x, clipPlane.normal.y, clipPlane.normal.z, clipPlane.d);\r\n }\r\n if (scene.clipPlane2) {\r\n var clipPlane = scene.clipPlane2;\r\n effect.setFloat4(\"vClipPlane2\", clipPlane.normal.x, clipPlane.normal.y, clipPlane.normal.z, clipPlane.d);\r\n }\r\n if (scene.clipPlane3) {\r\n var clipPlane = scene.clipPlane3;\r\n effect.setFloat4(\"vClipPlane3\", clipPlane.normal.x, clipPlane.normal.y, clipPlane.normal.z, clipPlane.d);\r\n }\r\n if (scene.clipPlane4) {\r\n var clipPlane = scene.clipPlane4;\r\n effect.setFloat4(\"vClipPlane4\", clipPlane.normal.x, clipPlane.normal.y, clipPlane.normal.z, clipPlane.d);\r\n }\r\n if (scene.clipPlane5) {\r\n var clipPlane = scene.clipPlane5;\r\n effect.setFloat4(\"vClipPlane5\", clipPlane.normal.x, clipPlane.normal.y, clipPlane.normal.z, clipPlane.d);\r\n }\r\n if (scene.clipPlane6) {\r\n var clipPlane = scene.clipPlane6;\r\n effect.setFloat4(\"vClipPlane6\", clipPlane.normal.x, clipPlane.normal.y, clipPlane.normal.z, clipPlane.d);\r\n }\r\n };\r\n MaterialHelper._TmpMorphInfluencers = { \"NUM_MORPH_INFLUENCERS\": 0 };\r\n MaterialHelper._tempFogColor = Color3.Black();\r\n return MaterialHelper;\r\n}());\r\nexport { MaterialHelper };\r\n//# sourceMappingURL=materialHelper.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, SerializationHelper, serializeAsVector3 } from \"../Misc/decorators\";\r\nimport { SmartArray } from \"../Misc/smartArray\";\r\nimport { Tools } from \"../Misc/tools\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { Matrix, Vector3, Quaternion } from \"../Maths/math.vector\";\r\nimport { Node } from \"../node\";\r\nimport { Logger } from \"../Misc/logger\";\r\nimport { _TypeStore } from '../Misc/typeStore';\r\nimport { _DevTools } from '../Misc/devTools';\r\nimport { Viewport } from '../Maths/math.viewport';\r\nimport { Frustum } from '../Maths/math.frustum';\r\n/**\r\n * This is the base class of all the camera used in the application.\r\n * @see http://doc.babylonjs.com/features/cameras\r\n */\r\nvar Camera = /** @class */ (function (_super) {\r\n __extends(Camera, _super);\r\n /**\r\n * Instantiates a new camera object.\r\n * This should not be used directly but through the inherited cameras: ArcRotate, Free...\r\n * @see http://doc.babylonjs.com/features/cameras\r\n * @param name Defines the name of the camera in the scene\r\n * @param position Defines the position of the camera\r\n * @param scene Defines the scene the camera belongs too\r\n * @param setActiveOnSceneIfNoneActive Defines if the camera should be set as active after creation if no other camera have been defined in the scene\r\n */\r\n function Camera(name, position, scene, setActiveOnSceneIfNoneActive) {\r\n if (setActiveOnSceneIfNoneActive === void 0) { setActiveOnSceneIfNoneActive = true; }\r\n var _this = _super.call(this, name, scene) || this;\r\n /** @hidden */\r\n _this._position = Vector3.Zero();\r\n /**\r\n * The vector the camera should consider as up.\r\n * (default is Vector3(0, 1, 0) aka Vector3.Up())\r\n */\r\n _this.upVector = Vector3.Up();\r\n /**\r\n * Define the current limit on the left side for an orthographic camera\r\n * In scene unit\r\n */\r\n _this.orthoLeft = null;\r\n /**\r\n * Define the current limit on the right side for an orthographic camera\r\n * In scene unit\r\n */\r\n _this.orthoRight = null;\r\n /**\r\n * Define the current limit on the bottom side for an orthographic camera\r\n * In scene unit\r\n */\r\n _this.orthoBottom = null;\r\n /**\r\n * Define the current limit on the top side for an orthographic camera\r\n * In scene unit\r\n */\r\n _this.orthoTop = null;\r\n /**\r\n * Field Of View is set in Radians. (default is 0.8)\r\n */\r\n _this.fov = 0.8;\r\n /**\r\n * Define the minimum distance the camera can see from.\r\n * This is important to note that the depth buffer are not infinite and the closer it starts\r\n * the more your scene might encounter depth fighting issue.\r\n */\r\n _this.minZ = 1;\r\n /**\r\n * Define the maximum distance the camera can see to.\r\n * This is important to note that the depth buffer are not infinite and the further it end\r\n * the more your scene might encounter depth fighting issue.\r\n */\r\n _this.maxZ = 10000.0;\r\n /**\r\n * Define the default inertia of the camera.\r\n * This helps giving a smooth feeling to the camera movement.\r\n */\r\n _this.inertia = 0.9;\r\n /**\r\n * Define the mode of the camera (Camera.PERSPECTIVE_CAMERA or Camera.ORTHOGRAPHIC_CAMERA)\r\n */\r\n _this.mode = Camera.PERSPECTIVE_CAMERA;\r\n /**\r\n * Define whether the camera is intermediate.\r\n * This is useful to not present the output directly to the screen in case of rig without post process for instance\r\n */\r\n _this.isIntermediate = false;\r\n /**\r\n * Define the viewport of the camera.\r\n * This correspond to the portion of the screen the camera will render to in normalized 0 to 1 unit.\r\n */\r\n _this.viewport = new Viewport(0, 0, 1.0, 1.0);\r\n /**\r\n * Restricts the camera to viewing objects with the same layerMask.\r\n * A camera with a layerMask of 1 will render mesh.layerMask & camera.layerMask!== 0\r\n */\r\n _this.layerMask = 0x0FFFFFFF;\r\n /**\r\n * fovMode sets the camera frustum bounds to the viewport bounds. (default is FOVMODE_VERTICAL_FIXED)\r\n */\r\n _this.fovMode = Camera.FOVMODE_VERTICAL_FIXED;\r\n /**\r\n * Rig mode of the camera.\r\n * This is useful to create the camera with two \"eyes\" instead of one to create VR or stereoscopic scenes.\r\n * This is normally controlled byt the camera themselves as internal use.\r\n */\r\n _this.cameraRigMode = Camera.RIG_MODE_NONE;\r\n /**\r\n * Defines the list of custom render target which are rendered to and then used as the input to this camera's render. Eg. display another camera view on a TV in the main scene\r\n * This is pretty helpfull if you wish to make a camera render to a texture you could reuse somewhere\r\n * else in the scene. (Eg. security camera)\r\n *\r\n * To change the final output target of the camera, camera.outputRenderTarget should be used instead (eg. webXR renders to a render target corrisponding to an HMD)\r\n */\r\n _this.customRenderTargets = new Array();\r\n /**\r\n * When set, the camera will render to this render target instead of the default canvas\r\n *\r\n * If the desire is to use the output of a camera as a texture in the scene consider using camera.customRenderTargets instead\r\n */\r\n _this.outputRenderTarget = null;\r\n /**\r\n * Observable triggered when the camera view matrix has changed.\r\n */\r\n _this.onViewMatrixChangedObservable = new Observable();\r\n /**\r\n * Observable triggered when the camera Projection matrix has changed.\r\n */\r\n _this.onProjectionMatrixChangedObservable = new Observable();\r\n /**\r\n * Observable triggered when the inputs have been processed.\r\n */\r\n _this.onAfterCheckInputsObservable = new Observable();\r\n /**\r\n * Observable triggered when reset has been called and applied to the camera.\r\n */\r\n _this.onRestoreStateObservable = new Observable();\r\n /**\r\n * Is this camera a part of a rig system?\r\n */\r\n _this.isRigCamera = false;\r\n /** @hidden */\r\n _this._rigCameras = new Array();\r\n _this._webvrViewMatrix = Matrix.Identity();\r\n /** @hidden */\r\n _this._skipRendering = false;\r\n /** @hidden */\r\n _this._projectionMatrix = new Matrix();\r\n /** @hidden */\r\n _this._postProcesses = new Array();\r\n /** @hidden */\r\n _this._activeMeshes = new SmartArray(256);\r\n _this._globalPosition = Vector3.Zero();\r\n /** @hidden */\r\n _this._computedViewMatrix = Matrix.Identity();\r\n _this._doNotComputeProjectionMatrix = false;\r\n _this._transformMatrix = Matrix.Zero();\r\n _this._refreshFrustumPlanes = true;\r\n /** @hidden */\r\n _this._isCamera = true;\r\n /** @hidden */\r\n _this._isLeftCamera = false;\r\n /** @hidden */\r\n _this._isRightCamera = false;\r\n _this.getScene().addCamera(_this);\r\n if (setActiveOnSceneIfNoneActive && !_this.getScene().activeCamera) {\r\n _this.getScene().activeCamera = _this;\r\n }\r\n _this.position = position;\r\n return _this;\r\n }\r\n Object.defineProperty(Camera.prototype, \"position\", {\r\n /**\r\n * Define the current local position of the camera in the scene\r\n */\r\n get: function () {\r\n return this._position;\r\n },\r\n set: function (newPosition) {\r\n this._position = newPosition;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Store current camera state (fov, position, etc..)\r\n * @returns the camera\r\n */\r\n Camera.prototype.storeState = function () {\r\n this._stateStored = true;\r\n this._storedFov = this.fov;\r\n return this;\r\n };\r\n /**\r\n * Restores the camera state values if it has been stored. You must call storeState() first\r\n */\r\n Camera.prototype._restoreStateValues = function () {\r\n if (!this._stateStored) {\r\n return false;\r\n }\r\n this.fov = this._storedFov;\r\n return true;\r\n };\r\n /**\r\n * Restored camera state. You must call storeState() first.\r\n * @returns true if restored and false otherwise\r\n */\r\n Camera.prototype.restoreState = function () {\r\n if (this._restoreStateValues()) {\r\n this.onRestoreStateObservable.notifyObservers(this);\r\n return true;\r\n }\r\n return false;\r\n };\r\n /**\r\n * Gets the class name of the camera.\r\n * @returns the class name\r\n */\r\n Camera.prototype.getClassName = function () {\r\n return \"Camera\";\r\n };\r\n /**\r\n * Gets a string representation of the camera useful for debug purpose.\r\n * @param fullDetails Defines that a more verboe level of logging is required\r\n * @returns the string representation\r\n */\r\n Camera.prototype.toString = function (fullDetails) {\r\n var ret = \"Name: \" + this.name;\r\n ret += \", type: \" + this.getClassName();\r\n if (this.animations) {\r\n for (var i = 0; i < this.animations.length; i++) {\r\n ret += \", animation[0]: \" + this.animations[i].toString(fullDetails);\r\n }\r\n }\r\n if (fullDetails) {\r\n }\r\n return ret;\r\n };\r\n Object.defineProperty(Camera.prototype, \"globalPosition\", {\r\n /**\r\n * Gets the current world space position of the camera.\r\n */\r\n get: function () {\r\n return this._globalPosition;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the list of active meshes this frame (meshes no culled or excluded by lod s in the frame)\r\n * @returns the active meshe list\r\n */\r\n Camera.prototype.getActiveMeshes = function () {\r\n return this._activeMeshes;\r\n };\r\n /**\r\n * Check whether a mesh is part of the current active mesh list of the camera\r\n * @param mesh Defines the mesh to check\r\n * @returns true if active, false otherwise\r\n */\r\n Camera.prototype.isActiveMesh = function (mesh) {\r\n return (this._activeMeshes.indexOf(mesh) !== -1);\r\n };\r\n /**\r\n * Is this camera ready to be used/rendered\r\n * @param completeCheck defines if a complete check (including post processes) has to be done (false by default)\r\n * @return true if the camera is ready\r\n */\r\n Camera.prototype.isReady = function (completeCheck) {\r\n if (completeCheck === void 0) { completeCheck = false; }\r\n if (completeCheck) {\r\n for (var _i = 0, _a = this._postProcesses; _i < _a.length; _i++) {\r\n var pp = _a[_i];\r\n if (pp && !pp.isReady()) {\r\n return false;\r\n }\r\n }\r\n }\r\n return _super.prototype.isReady.call(this, completeCheck);\r\n };\r\n /** @hidden */\r\n Camera.prototype._initCache = function () {\r\n _super.prototype._initCache.call(this);\r\n this._cache.position = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n this._cache.upVector = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n this._cache.mode = undefined;\r\n this._cache.minZ = undefined;\r\n this._cache.maxZ = undefined;\r\n this._cache.fov = undefined;\r\n this._cache.fovMode = undefined;\r\n this._cache.aspectRatio = undefined;\r\n this._cache.orthoLeft = undefined;\r\n this._cache.orthoRight = undefined;\r\n this._cache.orthoBottom = undefined;\r\n this._cache.orthoTop = undefined;\r\n this._cache.renderWidth = undefined;\r\n this._cache.renderHeight = undefined;\r\n };\r\n /** @hidden */\r\n Camera.prototype._updateCache = function (ignoreParentClass) {\r\n if (!ignoreParentClass) {\r\n _super.prototype._updateCache.call(this);\r\n }\r\n this._cache.position.copyFrom(this.position);\r\n this._cache.upVector.copyFrom(this.upVector);\r\n };\r\n /** @hidden */\r\n Camera.prototype._isSynchronized = function () {\r\n return this._isSynchronizedViewMatrix() && this._isSynchronizedProjectionMatrix();\r\n };\r\n /** @hidden */\r\n Camera.prototype._isSynchronizedViewMatrix = function () {\r\n if (!_super.prototype._isSynchronized.call(this)) {\r\n return false;\r\n }\r\n return this._cache.position.equals(this.position)\r\n && this._cache.upVector.equals(this.upVector)\r\n && this.isSynchronizedWithParent();\r\n };\r\n /** @hidden */\r\n Camera.prototype._isSynchronizedProjectionMatrix = function () {\r\n var check = this._cache.mode === this.mode\r\n && this._cache.minZ === this.minZ\r\n && this._cache.maxZ === this.maxZ;\r\n if (!check) {\r\n return false;\r\n }\r\n var engine = this.getEngine();\r\n if (this.mode === Camera.PERSPECTIVE_CAMERA) {\r\n check = this._cache.fov === this.fov\r\n && this._cache.fovMode === this.fovMode\r\n && this._cache.aspectRatio === engine.getAspectRatio(this);\r\n }\r\n else {\r\n check = this._cache.orthoLeft === this.orthoLeft\r\n && this._cache.orthoRight === this.orthoRight\r\n && this._cache.orthoBottom === this.orthoBottom\r\n && this._cache.orthoTop === this.orthoTop\r\n && this._cache.renderWidth === engine.getRenderWidth()\r\n && this._cache.renderHeight === engine.getRenderHeight();\r\n }\r\n return check;\r\n };\r\n /**\r\n * Attach the input controls to a specific dom element to get the input from.\r\n * @param element Defines the element the controls should be listened from\r\n * @param noPreventDefault Defines whether event caught by the controls should call preventdefault() (https://developer.mozilla.org/en-US/docs/Web/API/Event/preventDefault)\r\n */\r\n Camera.prototype.attachControl = function (element, noPreventDefault) {\r\n };\r\n /**\r\n * Detach the current controls from the specified dom element.\r\n * @param element Defines the element to stop listening the inputs from\r\n */\r\n Camera.prototype.detachControl = function (element) {\r\n };\r\n /**\r\n * Update the camera state according to the different inputs gathered during the frame.\r\n */\r\n Camera.prototype.update = function () {\r\n this._checkInputs();\r\n if (this.cameraRigMode !== Camera.RIG_MODE_NONE) {\r\n this._updateRigCameras();\r\n }\r\n };\r\n /** @hidden */\r\n Camera.prototype._checkInputs = function () {\r\n this.onAfterCheckInputsObservable.notifyObservers(this);\r\n };\r\n Object.defineProperty(Camera.prototype, \"rigCameras\", {\r\n /** @hidden */\r\n get: function () {\r\n return this._rigCameras;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Camera.prototype, \"rigPostProcess\", {\r\n /**\r\n * Gets the post process used by the rig cameras\r\n */\r\n get: function () {\r\n return this._rigPostProcess;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Internal, gets the first post proces.\r\n * @returns the first post process to be run on this camera.\r\n */\r\n Camera.prototype._getFirstPostProcess = function () {\r\n for (var ppIndex = 0; ppIndex < this._postProcesses.length; ppIndex++) {\r\n if (this._postProcesses[ppIndex] !== null) {\r\n return this._postProcesses[ppIndex];\r\n }\r\n }\r\n return null;\r\n };\r\n Camera.prototype._cascadePostProcessesToRigCams = function () {\r\n // invalidate framebuffer\r\n var firstPostProcess = this._getFirstPostProcess();\r\n if (firstPostProcess) {\r\n firstPostProcess.markTextureDirty();\r\n }\r\n // glue the rigPostProcess to the end of the user postprocesses & assign to each sub-camera\r\n for (var i = 0, len = this._rigCameras.length; i < len; i++) {\r\n var cam = this._rigCameras[i];\r\n var rigPostProcess = cam._rigPostProcess;\r\n // for VR rig, there does not have to be a post process\r\n if (rigPostProcess) {\r\n var isPass = rigPostProcess.getEffectName() === \"pass\";\r\n if (isPass) {\r\n // any rig which has a PassPostProcess for rig[0], cannot be isIntermediate when there are also user postProcesses\r\n cam.isIntermediate = this._postProcesses.length === 0;\r\n }\r\n cam._postProcesses = this._postProcesses.slice(0).concat(rigPostProcess);\r\n rigPostProcess.markTextureDirty();\r\n }\r\n else {\r\n cam._postProcesses = this._postProcesses.slice(0);\r\n }\r\n }\r\n };\r\n /**\r\n * Attach a post process to the camera.\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_postprocesses#attach-postprocess\r\n * @param postProcess The post process to attach to the camera\r\n * @param insertAt The position of the post process in case several of them are in use in the scene\r\n * @returns the position the post process has been inserted at\r\n */\r\n Camera.prototype.attachPostProcess = function (postProcess, insertAt) {\r\n if (insertAt === void 0) { insertAt = null; }\r\n if (!postProcess.isReusable() && this._postProcesses.indexOf(postProcess) > -1) {\r\n Logger.Error(\"You're trying to reuse a post process not defined as reusable.\");\r\n return 0;\r\n }\r\n if (insertAt == null || insertAt < 0) {\r\n this._postProcesses.push(postProcess);\r\n }\r\n else if (this._postProcesses[insertAt] === null) {\r\n this._postProcesses[insertAt] = postProcess;\r\n }\r\n else {\r\n this._postProcesses.splice(insertAt, 0, postProcess);\r\n }\r\n this._cascadePostProcessesToRigCams(); // also ensures framebuffer invalidated\r\n return this._postProcesses.indexOf(postProcess);\r\n };\r\n /**\r\n * Detach a post process to the camera.\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_postprocesses#attach-postprocess\r\n * @param postProcess The post process to detach from the camera\r\n */\r\n Camera.prototype.detachPostProcess = function (postProcess) {\r\n var idx = this._postProcesses.indexOf(postProcess);\r\n if (idx !== -1) {\r\n this._postProcesses[idx] = null;\r\n }\r\n this._cascadePostProcessesToRigCams(); // also ensures framebuffer invalidated\r\n };\r\n /**\r\n * Gets the current world matrix of the camera\r\n */\r\n Camera.prototype.getWorldMatrix = function () {\r\n if (this._isSynchronizedViewMatrix()) {\r\n return this._worldMatrix;\r\n }\r\n // Getting the the view matrix will also compute the world matrix.\r\n this.getViewMatrix();\r\n return this._worldMatrix;\r\n };\r\n /** @hidden */\r\n Camera.prototype._getViewMatrix = function () {\r\n return Matrix.Identity();\r\n };\r\n /**\r\n * Gets the current view matrix of the camera.\r\n * @param force forces the camera to recompute the matrix without looking at the cached state\r\n * @returns the view matrix\r\n */\r\n Camera.prototype.getViewMatrix = function (force) {\r\n if (!force && this._isSynchronizedViewMatrix()) {\r\n return this._computedViewMatrix;\r\n }\r\n this.updateCache();\r\n this._computedViewMatrix = this._getViewMatrix();\r\n this._currentRenderId = this.getScene().getRenderId();\r\n this._childUpdateId++;\r\n this._refreshFrustumPlanes = true;\r\n if (this._cameraRigParams && this._cameraRigParams.vrPreViewMatrix) {\r\n this._computedViewMatrix.multiplyToRef(this._cameraRigParams.vrPreViewMatrix, this._computedViewMatrix);\r\n }\r\n // Notify parent camera if rig camera is changed\r\n if (this.parent && this.parent.onViewMatrixChangedObservable) {\r\n this.parent.onViewMatrixChangedObservable.notifyObservers(this.parent);\r\n }\r\n this.onViewMatrixChangedObservable.notifyObservers(this);\r\n this._computedViewMatrix.invertToRef(this._worldMatrix);\r\n return this._computedViewMatrix;\r\n };\r\n /**\r\n * Freeze the projection matrix.\r\n * It will prevent the cache check of the camera projection compute and can speed up perf\r\n * if no parameter of the camera are meant to change\r\n * @param projection Defines manually a projection if necessary\r\n */\r\n Camera.prototype.freezeProjectionMatrix = function (projection) {\r\n this._doNotComputeProjectionMatrix = true;\r\n if (projection !== undefined) {\r\n this._projectionMatrix = projection;\r\n }\r\n };\r\n /**\r\n * Unfreeze the projection matrix if it has previously been freezed by freezeProjectionMatrix.\r\n */\r\n Camera.prototype.unfreezeProjectionMatrix = function () {\r\n this._doNotComputeProjectionMatrix = false;\r\n };\r\n /**\r\n * Gets the current projection matrix of the camera.\r\n * @param force forces the camera to recompute the matrix without looking at the cached state\r\n * @returns the projection matrix\r\n */\r\n Camera.prototype.getProjectionMatrix = function (force) {\r\n if (this._doNotComputeProjectionMatrix || (!force && this._isSynchronizedProjectionMatrix())) {\r\n return this._projectionMatrix;\r\n }\r\n // Cache\r\n this._cache.mode = this.mode;\r\n this._cache.minZ = this.minZ;\r\n this._cache.maxZ = this.maxZ;\r\n // Matrix\r\n this._refreshFrustumPlanes = true;\r\n var engine = this.getEngine();\r\n var scene = this.getScene();\r\n if (this.mode === Camera.PERSPECTIVE_CAMERA) {\r\n this._cache.fov = this.fov;\r\n this._cache.fovMode = this.fovMode;\r\n this._cache.aspectRatio = engine.getAspectRatio(this);\r\n if (this.minZ <= 0) {\r\n this.minZ = 0.1;\r\n }\r\n var reverseDepth = engine.useReverseDepthBuffer;\r\n var getProjectionMatrix = void 0;\r\n if (scene.useRightHandedSystem) {\r\n getProjectionMatrix = reverseDepth ? Matrix.PerspectiveFovReverseRHToRef : Matrix.PerspectiveFovRHToRef;\r\n }\r\n else {\r\n getProjectionMatrix = reverseDepth ? Matrix.PerspectiveFovReverseLHToRef : Matrix.PerspectiveFovLHToRef;\r\n }\r\n getProjectionMatrix(this.fov, engine.getAspectRatio(this), this.minZ, this.maxZ, this._projectionMatrix, this.fovMode === Camera.FOVMODE_VERTICAL_FIXED);\r\n }\r\n else {\r\n var halfWidth = engine.getRenderWidth() / 2.0;\r\n var halfHeight = engine.getRenderHeight() / 2.0;\r\n if (scene.useRightHandedSystem) {\r\n Matrix.OrthoOffCenterRHToRef(this.orthoLeft || -halfWidth, this.orthoRight || halfWidth, this.orthoBottom || -halfHeight, this.orthoTop || halfHeight, this.minZ, this.maxZ, this._projectionMatrix);\r\n }\r\n else {\r\n Matrix.OrthoOffCenterLHToRef(this.orthoLeft || -halfWidth, this.orthoRight || halfWidth, this.orthoBottom || -halfHeight, this.orthoTop || halfHeight, this.minZ, this.maxZ, this._projectionMatrix);\r\n }\r\n this._cache.orthoLeft = this.orthoLeft;\r\n this._cache.orthoRight = this.orthoRight;\r\n this._cache.orthoBottom = this.orthoBottom;\r\n this._cache.orthoTop = this.orthoTop;\r\n this._cache.renderWidth = engine.getRenderWidth();\r\n this._cache.renderHeight = engine.getRenderHeight();\r\n }\r\n this.onProjectionMatrixChangedObservable.notifyObservers(this);\r\n return this._projectionMatrix;\r\n };\r\n /**\r\n * Gets the transformation matrix (ie. the multiplication of view by projection matrices)\r\n * @returns a Matrix\r\n */\r\n Camera.prototype.getTransformationMatrix = function () {\r\n this._computedViewMatrix.multiplyToRef(this._projectionMatrix, this._transformMatrix);\r\n return this._transformMatrix;\r\n };\r\n Camera.prototype._updateFrustumPlanes = function () {\r\n if (!this._refreshFrustumPlanes) {\r\n return;\r\n }\r\n this.getTransformationMatrix();\r\n if (!this._frustumPlanes) {\r\n this._frustumPlanes = Frustum.GetPlanes(this._transformMatrix);\r\n }\r\n else {\r\n Frustum.GetPlanesToRef(this._transformMatrix, this._frustumPlanes);\r\n }\r\n this._refreshFrustumPlanes = false;\r\n };\r\n /**\r\n * Checks if a cullable object (mesh...) is in the camera frustum\r\n * This checks the bounding box center. See isCompletelyInFrustum for a full bounding check\r\n * @param target The object to check\r\n * @param checkRigCameras If the rig cameras should be checked (eg. with webVR camera both eyes should be checked) (Default: false)\r\n * @returns true if the object is in frustum otherwise false\r\n */\r\n Camera.prototype.isInFrustum = function (target, checkRigCameras) {\r\n if (checkRigCameras === void 0) { checkRigCameras = false; }\r\n this._updateFrustumPlanes();\r\n if (checkRigCameras && this.rigCameras.length > 0) {\r\n var result = false;\r\n this.rigCameras.forEach(function (cam) {\r\n cam._updateFrustumPlanes();\r\n result = result || target.isInFrustum(cam._frustumPlanes);\r\n });\r\n return result;\r\n }\r\n else {\r\n return target.isInFrustum(this._frustumPlanes);\r\n }\r\n };\r\n /**\r\n * Checks if a cullable object (mesh...) is in the camera frustum\r\n * Unlike isInFrustum this cheks the full bounding box\r\n * @param target The object to check\r\n * @returns true if the object is in frustum otherwise false\r\n */\r\n Camera.prototype.isCompletelyInFrustum = function (target) {\r\n this._updateFrustumPlanes();\r\n return target.isCompletelyInFrustum(this._frustumPlanes);\r\n };\r\n /**\r\n * Gets a ray in the forward direction from the camera.\r\n * @param length Defines the length of the ray to create\r\n * @param transform Defines the transform to apply to the ray, by default the world matrx is used to create a workd space ray\r\n * @param origin Defines the start point of the ray which defaults to the camera position\r\n * @returns the forward ray\r\n */\r\n Camera.prototype.getForwardRay = function (length, transform, origin) {\r\n if (length === void 0) { length = 100; }\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /**\r\n * Releases resources associated with this node.\r\n * @param doNotRecurse Set to true to not recurse into each children (recurse into each children by default)\r\n * @param disposeMaterialAndTextures Set to true to also dispose referenced materials and textures (false by default)\r\n */\r\n Camera.prototype.dispose = function (doNotRecurse, disposeMaterialAndTextures) {\r\n if (disposeMaterialAndTextures === void 0) { disposeMaterialAndTextures = false; }\r\n // Observables\r\n this.onViewMatrixChangedObservable.clear();\r\n this.onProjectionMatrixChangedObservable.clear();\r\n this.onAfterCheckInputsObservable.clear();\r\n this.onRestoreStateObservable.clear();\r\n // Inputs\r\n if (this.inputs) {\r\n this.inputs.clear();\r\n }\r\n // Animations\r\n this.getScene().stopAnimation(this);\r\n // Remove from scene\r\n this.getScene().removeCamera(this);\r\n while (this._rigCameras.length > 0) {\r\n var camera = this._rigCameras.pop();\r\n if (camera) {\r\n camera.dispose();\r\n }\r\n }\r\n // Postprocesses\r\n if (this._rigPostProcess) {\r\n this._rigPostProcess.dispose(this);\r\n this._rigPostProcess = null;\r\n this._postProcesses = [];\r\n }\r\n else if (this.cameraRigMode !== Camera.RIG_MODE_NONE) {\r\n this._rigPostProcess = null;\r\n this._postProcesses = [];\r\n }\r\n else {\r\n var i = this._postProcesses.length;\r\n while (--i >= 0) {\r\n var postProcess = this._postProcesses[i];\r\n if (postProcess) {\r\n postProcess.dispose(this);\r\n }\r\n }\r\n }\r\n // Render targets\r\n var i = this.customRenderTargets.length;\r\n while (--i >= 0) {\r\n this.customRenderTargets[i].dispose();\r\n }\r\n this.customRenderTargets = [];\r\n // Active Meshes\r\n this._activeMeshes.dispose();\r\n _super.prototype.dispose.call(this, doNotRecurse, disposeMaterialAndTextures);\r\n };\r\n Object.defineProperty(Camera.prototype, \"isLeftCamera\", {\r\n /**\r\n * Gets the left camera of a rig setup in case of Rigged Camera\r\n */\r\n get: function () {\r\n return this._isLeftCamera;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Camera.prototype, \"isRightCamera\", {\r\n /**\r\n * Gets the right camera of a rig setup in case of Rigged Camera\r\n */\r\n get: function () {\r\n return this._isRightCamera;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Camera.prototype, \"leftCamera\", {\r\n /**\r\n * Gets the left camera of a rig setup in case of Rigged Camera\r\n */\r\n get: function () {\r\n if (this._rigCameras.length < 1) {\r\n return null;\r\n }\r\n return this._rigCameras[0];\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Camera.prototype, \"rightCamera\", {\r\n /**\r\n * Gets the right camera of a rig setup in case of Rigged Camera\r\n */\r\n get: function () {\r\n if (this._rigCameras.length < 2) {\r\n return null;\r\n }\r\n return this._rigCameras[1];\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the left camera target of a rig setup in case of Rigged Camera\r\n * @returns the target position\r\n */\r\n Camera.prototype.getLeftTarget = function () {\r\n if (this._rigCameras.length < 1) {\r\n return null;\r\n }\r\n return this._rigCameras[0].getTarget();\r\n };\r\n /**\r\n * Gets the right camera target of a rig setup in case of Rigged Camera\r\n * @returns the target position\r\n */\r\n Camera.prototype.getRightTarget = function () {\r\n if (this._rigCameras.length < 2) {\r\n return null;\r\n }\r\n return this._rigCameras[1].getTarget();\r\n };\r\n /**\r\n * @hidden\r\n */\r\n Camera.prototype.setCameraRigMode = function (mode, rigParams) {\r\n if (this.cameraRigMode === mode) {\r\n return;\r\n }\r\n while (this._rigCameras.length > 0) {\r\n var camera = this._rigCameras.pop();\r\n if (camera) {\r\n camera.dispose();\r\n }\r\n }\r\n this.cameraRigMode = mode;\r\n this._cameraRigParams = {};\r\n //we have to implement stereo camera calcultating left and right viewpoints from interaxialDistance and target,\r\n //not from a given angle as it is now, but until that complete code rewriting provisional stereoHalfAngle value is introduced\r\n this._cameraRigParams.interaxialDistance = rigParams.interaxialDistance || 0.0637;\r\n this._cameraRigParams.stereoHalfAngle = Tools.ToRadians(this._cameraRigParams.interaxialDistance / 0.0637);\r\n // create the rig cameras, unless none\r\n if (this.cameraRigMode !== Camera.RIG_MODE_NONE) {\r\n var leftCamera = this.createRigCamera(this.name + \"_L\", 0);\r\n if (leftCamera) {\r\n leftCamera._isLeftCamera = true;\r\n }\r\n var rightCamera = this.createRigCamera(this.name + \"_R\", 1);\r\n if (rightCamera) {\r\n rightCamera._isRightCamera = true;\r\n }\r\n if (leftCamera && rightCamera) {\r\n this._rigCameras.push(leftCamera);\r\n this._rigCameras.push(rightCamera);\r\n }\r\n }\r\n switch (this.cameraRigMode) {\r\n case Camera.RIG_MODE_STEREOSCOPIC_ANAGLYPH:\r\n Camera._setStereoscopicAnaglyphRigMode(this);\r\n break;\r\n case Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL:\r\n case Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED:\r\n case Camera.RIG_MODE_STEREOSCOPIC_OVERUNDER:\r\n case Camera.RIG_MODE_STEREOSCOPIC_INTERLACED:\r\n Camera._setStereoscopicRigMode(this);\r\n break;\r\n case Camera.RIG_MODE_VR:\r\n Camera._setVRRigMode(this, rigParams);\r\n break;\r\n case Camera.RIG_MODE_WEBVR:\r\n Camera._setWebVRRigMode(this, rigParams);\r\n break;\r\n }\r\n this._cascadePostProcessesToRigCams();\r\n this.update();\r\n };\r\n /** @hidden */\r\n Camera._setStereoscopicRigMode = function (camera) {\r\n throw \"Import Cameras/RigModes/stereoscopicRigMode before using stereoscopic rig mode\";\r\n };\r\n /** @hidden */\r\n Camera._setStereoscopicAnaglyphRigMode = function (camera) {\r\n throw \"Import Cameras/RigModes/stereoscopicAnaglyphRigMode before using stereoscopic anaglyph rig mode\";\r\n };\r\n /** @hidden */\r\n Camera._setVRRigMode = function (camera, rigParams) {\r\n throw \"Import Cameras/RigModes/vrRigMode before using VR rig mode\";\r\n };\r\n /** @hidden */\r\n Camera._setWebVRRigMode = function (camera, rigParams) {\r\n throw \"Import Cameras/RigModes/WebVRRigMode before using Web VR rig mode\";\r\n };\r\n /** @hidden */\r\n Camera.prototype._getVRProjectionMatrix = function () {\r\n Matrix.PerspectiveFovLHToRef(this._cameraRigParams.vrMetrics.aspectRatioFov, this._cameraRigParams.vrMetrics.aspectRatio, this.minZ, this.maxZ, this._cameraRigParams.vrWorkMatrix);\r\n this._cameraRigParams.vrWorkMatrix.multiplyToRef(this._cameraRigParams.vrHMatrix, this._projectionMatrix);\r\n return this._projectionMatrix;\r\n };\r\n Camera.prototype._updateCameraRotationMatrix = function () {\r\n //Here for WebVR\r\n };\r\n Camera.prototype._updateWebVRCameraRotationMatrix = function () {\r\n //Here for WebVR\r\n };\r\n /**\r\n * This function MUST be overwritten by the different WebVR cameras available.\r\n * The context in which it is running is the RIG camera. So 'this' is the TargetCamera, left or right.\r\n * @hidden\r\n */\r\n Camera.prototype._getWebVRProjectionMatrix = function () {\r\n return Matrix.Identity();\r\n };\r\n /**\r\n * This function MUST be overwritten by the different WebVR cameras available.\r\n * The context in which it is running is the RIG camera. So 'this' is the TargetCamera, left or right.\r\n * @hidden\r\n */\r\n Camera.prototype._getWebVRViewMatrix = function () {\r\n return Matrix.Identity();\r\n };\r\n /** @hidden */\r\n Camera.prototype.setCameraRigParameter = function (name, value) {\r\n if (!this._cameraRigParams) {\r\n this._cameraRigParams = {};\r\n }\r\n this._cameraRigParams[name] = value;\r\n //provisionnally:\r\n if (name === \"interaxialDistance\") {\r\n this._cameraRigParams.stereoHalfAngle = Tools.ToRadians(value / 0.0637);\r\n }\r\n };\r\n /**\r\n * needs to be overridden by children so sub has required properties to be copied\r\n * @hidden\r\n */\r\n Camera.prototype.createRigCamera = function (name, cameraIndex) {\r\n return null;\r\n };\r\n /**\r\n * May need to be overridden by children\r\n * @hidden\r\n */\r\n Camera.prototype._updateRigCameras = function () {\r\n for (var i = 0; i < this._rigCameras.length; i++) {\r\n this._rigCameras[i].minZ = this.minZ;\r\n this._rigCameras[i].maxZ = this.maxZ;\r\n this._rigCameras[i].fov = this.fov;\r\n this._rigCameras[i].upVector.copyFrom(this.upVector);\r\n }\r\n // only update viewport when ANAGLYPH\r\n if (this.cameraRigMode === Camera.RIG_MODE_STEREOSCOPIC_ANAGLYPH) {\r\n this._rigCameras[0].viewport = this._rigCameras[1].viewport = this.viewport;\r\n }\r\n };\r\n /** @hidden */\r\n Camera.prototype._setupInputs = function () {\r\n };\r\n /**\r\n * Serialiaze the camera setup to a json represention\r\n * @returns the JSON representation\r\n */\r\n Camera.prototype.serialize = function () {\r\n var serializationObject = SerializationHelper.Serialize(this);\r\n // Type\r\n serializationObject.type = this.getClassName();\r\n // Parent\r\n if (this.parent) {\r\n serializationObject.parentId = this.parent.id;\r\n }\r\n if (this.inputs) {\r\n this.inputs.serialize(serializationObject);\r\n }\r\n // Animations\r\n SerializationHelper.AppendSerializedAnimations(this, serializationObject);\r\n serializationObject.ranges = this.serializeAnimationRanges();\r\n return serializationObject;\r\n };\r\n /**\r\n * Clones the current camera.\r\n * @param name The cloned camera name\r\n * @returns the cloned camera\r\n */\r\n Camera.prototype.clone = function (name) {\r\n return SerializationHelper.Clone(Camera.GetConstructorFromName(this.getClassName(), name, this.getScene(), this.interaxialDistance, this.isStereoscopicSideBySide), this);\r\n };\r\n /**\r\n * Gets the direction of the camera relative to a given local axis.\r\n * @param localAxis Defines the reference axis to provide a relative direction.\r\n * @return the direction\r\n */\r\n Camera.prototype.getDirection = function (localAxis) {\r\n var result = Vector3.Zero();\r\n this.getDirectionToRef(localAxis, result);\r\n return result;\r\n };\r\n Object.defineProperty(Camera.prototype, \"absoluteRotation\", {\r\n /**\r\n * Returns the current camera absolute rotation\r\n */\r\n get: function () {\r\n var result = Quaternion.Zero();\r\n this.getWorldMatrix().decompose(undefined, result);\r\n return result;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the direction of the camera relative to a given local axis into a passed vector.\r\n * @param localAxis Defines the reference axis to provide a relative direction.\r\n * @param result Defines the vector to store the result in\r\n */\r\n Camera.prototype.getDirectionToRef = function (localAxis, result) {\r\n Vector3.TransformNormalToRef(localAxis, this.getWorldMatrix(), result);\r\n };\r\n /**\r\n * Gets a camera constructor for a given camera type\r\n * @param type The type of the camera to construct (should be equal to one of the camera class name)\r\n * @param name The name of the camera the result will be able to instantiate\r\n * @param scene The scene the result will construct the camera in\r\n * @param interaxial_distance In case of stereoscopic setup, the distance between both eyes\r\n * @param isStereoscopicSideBySide In case of stereoscopic setup, should the sereo be side b side\r\n * @returns a factory method to construc the camera\r\n */\r\n Camera.GetConstructorFromName = function (type, name, scene, interaxial_distance, isStereoscopicSideBySide) {\r\n if (interaxial_distance === void 0) { interaxial_distance = 0; }\r\n if (isStereoscopicSideBySide === void 0) { isStereoscopicSideBySide = true; }\r\n var constructorFunc = Node.Construct(type, name, scene, {\r\n interaxial_distance: interaxial_distance,\r\n isStereoscopicSideBySide: isStereoscopicSideBySide\r\n });\r\n if (constructorFunc) {\r\n return constructorFunc;\r\n }\r\n // Default to universal camera\r\n return function () { return Camera._createDefaultParsedCamera(name, scene); };\r\n };\r\n /**\r\n * Compute the world matrix of the camera.\r\n * @returns the camera world matrix\r\n */\r\n Camera.prototype.computeWorldMatrix = function () {\r\n return this.getWorldMatrix();\r\n };\r\n /**\r\n * Parse a JSON and creates the camera from the parsed information\r\n * @param parsedCamera The JSON to parse\r\n * @param scene The scene to instantiate the camera in\r\n * @returns the newly constructed camera\r\n */\r\n Camera.Parse = function (parsedCamera, scene) {\r\n var type = parsedCamera.type;\r\n var construct = Camera.GetConstructorFromName(type, parsedCamera.name, scene, parsedCamera.interaxial_distance, parsedCamera.isStereoscopicSideBySide);\r\n var camera = SerializationHelper.Parse(construct, parsedCamera, scene);\r\n // Parent\r\n if (parsedCamera.parentId) {\r\n camera._waitingParentId = parsedCamera.parentId;\r\n }\r\n //If camera has an input manager, let it parse inputs settings\r\n if (camera.inputs) {\r\n camera.inputs.parse(parsedCamera);\r\n camera._setupInputs();\r\n }\r\n if (camera.setPosition) { // need to force position\r\n camera.position.copyFromFloats(0, 0, 0);\r\n camera.setPosition(Vector3.FromArray(parsedCamera.position));\r\n }\r\n // Target\r\n if (parsedCamera.target) {\r\n if (camera.setTarget) {\r\n camera.setTarget(Vector3.FromArray(parsedCamera.target));\r\n }\r\n }\r\n // Apply 3d rig, when found\r\n if (parsedCamera.cameraRigMode) {\r\n var rigParams = (parsedCamera.interaxial_distance) ? { interaxialDistance: parsedCamera.interaxial_distance } : {};\r\n camera.setCameraRigMode(parsedCamera.cameraRigMode, rigParams);\r\n }\r\n // Animations\r\n if (parsedCamera.animations) {\r\n for (var animationIndex = 0; animationIndex < parsedCamera.animations.length; animationIndex++) {\r\n var parsedAnimation = parsedCamera.animations[animationIndex];\r\n var internalClass = _TypeStore.GetClass(\"BABYLON.Animation\");\r\n if (internalClass) {\r\n camera.animations.push(internalClass.Parse(parsedAnimation));\r\n }\r\n }\r\n Node.ParseAnimationRanges(camera, parsedCamera, scene);\r\n }\r\n if (parsedCamera.autoAnimate) {\r\n scene.beginAnimation(camera, parsedCamera.autoAnimateFrom, parsedCamera.autoAnimateTo, parsedCamera.autoAnimateLoop, parsedCamera.autoAnimateSpeed || 1.0);\r\n }\r\n return camera;\r\n };\r\n /** @hidden */\r\n Camera._createDefaultParsedCamera = function (name, scene) {\r\n throw _DevTools.WarnImport(\"UniversalCamera\");\r\n };\r\n /**\r\n * This is the default projection mode used by the cameras.\r\n * It helps recreating a feeling of perspective and better appreciate depth.\r\n * This is the best way to simulate real life cameras.\r\n */\r\n Camera.PERSPECTIVE_CAMERA = 0;\r\n /**\r\n * This helps creating camera with an orthographic mode.\r\n * Orthographic is commonly used in engineering as a means to produce object specifications that communicate dimensions unambiguously, each line of 1 unit length (cm, meter..whatever) will appear to have the same length everywhere on the drawing. This allows the drafter to dimension only a subset of lines and let the reader know that other lines of that length on the drawing are also that length in reality. Every parallel line in the drawing is also parallel in the object.\r\n */\r\n Camera.ORTHOGRAPHIC_CAMERA = 1;\r\n /**\r\n * This is the default FOV mode for perspective cameras.\r\n * This setting aligns the upper and lower bounds of the viewport to the upper and lower bounds of the camera frustum.\r\n */\r\n Camera.FOVMODE_VERTICAL_FIXED = 0;\r\n /**\r\n * This setting aligns the left and right bounds of the viewport to the left and right bounds of the camera frustum.\r\n */\r\n Camera.FOVMODE_HORIZONTAL_FIXED = 1;\r\n /**\r\n * This specifies ther is no need for a camera rig.\r\n * Basically only one eye is rendered corresponding to the camera.\r\n */\r\n Camera.RIG_MODE_NONE = 0;\r\n /**\r\n * Simulates a camera Rig with one blue eye and one red eye.\r\n * This can be use with 3d blue and red glasses.\r\n */\r\n Camera.RIG_MODE_STEREOSCOPIC_ANAGLYPH = 10;\r\n /**\r\n * Defines that both eyes of the camera will be rendered side by side with a parallel target.\r\n */\r\n Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL = 11;\r\n /**\r\n * Defines that both eyes of the camera will be rendered side by side with a none parallel target.\r\n */\r\n Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED = 12;\r\n /**\r\n * Defines that both eyes of the camera will be rendered over under each other.\r\n */\r\n Camera.RIG_MODE_STEREOSCOPIC_OVERUNDER = 13;\r\n /**\r\n * Defines that both eyes of the camera will be rendered on successive lines interlaced for passive 3d monitors.\r\n */\r\n Camera.RIG_MODE_STEREOSCOPIC_INTERLACED = 14;\r\n /**\r\n * Defines that both eyes of the camera should be renderered in a VR mode (carbox).\r\n */\r\n Camera.RIG_MODE_VR = 20;\r\n /**\r\n * Defines that both eyes of the camera should be renderered in a VR mode (webVR).\r\n */\r\n Camera.RIG_MODE_WEBVR = 21;\r\n /**\r\n * Custom rig mode allowing rig cameras to be populated manually with any number of cameras\r\n */\r\n Camera.RIG_MODE_CUSTOM = 22;\r\n /**\r\n * Defines if by default attaching controls should prevent the default javascript event to continue.\r\n */\r\n Camera.ForceAttachControlToAlwaysPreventDefault = false;\r\n __decorate([\r\n serializeAsVector3(\"position\")\r\n ], Camera.prototype, \"_position\", void 0);\r\n __decorate([\r\n serializeAsVector3()\r\n ], Camera.prototype, \"upVector\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"orthoLeft\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"orthoRight\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"orthoBottom\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"orthoTop\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"fov\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"minZ\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"maxZ\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"inertia\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"mode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"layerMask\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"fovMode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"cameraRigMode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"interaxialDistance\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"isStereoscopicSideBySide\", void 0);\r\n return Camera;\r\n}(Node));\r\nexport { Camera };\r\n//# sourceMappingURL=camera.js.map","/**\r\n * Class used to evalaute queries containing `and` and `or` operators\r\n */\r\nvar AndOrNotEvaluator = /** @class */ (function () {\r\n function AndOrNotEvaluator() {\r\n }\r\n /**\r\n * Evaluate a query\r\n * @param query defines the query to evaluate\r\n * @param evaluateCallback defines the callback used to filter result\r\n * @returns true if the query matches\r\n */\r\n AndOrNotEvaluator.Eval = function (query, evaluateCallback) {\r\n if (!query.match(/\\([^\\(\\)]*\\)/g)) {\r\n query = AndOrNotEvaluator._HandleParenthesisContent(query, evaluateCallback);\r\n }\r\n else {\r\n query = query.replace(/\\([^\\(\\)]*\\)/g, function (r) {\r\n // remove parenthesis\r\n r = r.slice(1, r.length - 1);\r\n return AndOrNotEvaluator._HandleParenthesisContent(r, evaluateCallback);\r\n });\r\n }\r\n if (query === \"true\") {\r\n return true;\r\n }\r\n if (query === \"false\") {\r\n return false;\r\n }\r\n return AndOrNotEvaluator.Eval(query, evaluateCallback);\r\n };\r\n AndOrNotEvaluator._HandleParenthesisContent = function (parenthesisContent, evaluateCallback) {\r\n evaluateCallback = evaluateCallback || (function (r) {\r\n return r === \"true\" ? true : false;\r\n });\r\n var result;\r\n var or = parenthesisContent.split(\"||\");\r\n for (var i in or) {\r\n if (or.hasOwnProperty(i)) {\r\n var ori = AndOrNotEvaluator._SimplifyNegation(or[i].trim());\r\n var and = ori.split(\"&&\");\r\n if (and.length > 1) {\r\n for (var j = 0; j < and.length; ++j) {\r\n var andj = AndOrNotEvaluator._SimplifyNegation(and[j].trim());\r\n if (andj !== \"true\" && andj !== \"false\") {\r\n if (andj[0] === \"!\") {\r\n result = !evaluateCallback(andj.substring(1));\r\n }\r\n else {\r\n result = evaluateCallback(andj);\r\n }\r\n }\r\n else {\r\n result = andj === \"true\" ? true : false;\r\n }\r\n if (!result) { // no need to continue since 'false && ... && ...' will always return false\r\n ori = \"false\";\r\n break;\r\n }\r\n }\r\n }\r\n if (result || ori === \"true\") { // no need to continue since 'true || ... || ...' will always return true\r\n result = true;\r\n break;\r\n }\r\n // result equals false (or undefined)\r\n if (ori !== \"true\" && ori !== \"false\") {\r\n if (ori[0] === \"!\") {\r\n result = !evaluateCallback(ori.substring(1));\r\n }\r\n else {\r\n result = evaluateCallback(ori);\r\n }\r\n }\r\n else {\r\n result = ori === \"true\" ? true : false;\r\n }\r\n }\r\n }\r\n // the whole parenthesis scope is replaced by 'true' or 'false'\r\n return result ? \"true\" : \"false\";\r\n };\r\n AndOrNotEvaluator._SimplifyNegation = function (booleanString) {\r\n booleanString = booleanString.replace(/^[\\s!]+/, function (r) {\r\n // remove whitespaces\r\n r = r.replace(/[\\s]/g, function () { return \"\"; });\r\n return r.length % 2 ? \"!\" : \"\";\r\n });\r\n booleanString = booleanString.trim();\r\n if (booleanString === \"!true\") {\r\n booleanString = \"false\";\r\n }\r\n else if (booleanString === \"!false\") {\r\n booleanString = \"true\";\r\n }\r\n return booleanString;\r\n };\r\n return AndOrNotEvaluator;\r\n}());\r\nexport { AndOrNotEvaluator };\r\n//# sourceMappingURL=andOrNotEvaluator.js.map","import { AndOrNotEvaluator } from \"./andOrNotEvaluator\";\r\n/**\r\n * Class used to store custom tags\r\n */\r\nvar Tags = /** @class */ (function () {\r\n function Tags() {\r\n }\r\n /**\r\n * Adds support for tags on the given object\r\n * @param obj defines the object to use\r\n */\r\n Tags.EnableFor = function (obj) {\r\n obj._tags = obj._tags || {};\r\n obj.hasTags = function () {\r\n return Tags.HasTags(obj);\r\n };\r\n obj.addTags = function (tagsString) {\r\n return Tags.AddTagsTo(obj, tagsString);\r\n };\r\n obj.removeTags = function (tagsString) {\r\n return Tags.RemoveTagsFrom(obj, tagsString);\r\n };\r\n obj.matchesTagsQuery = function (tagsQuery) {\r\n return Tags.MatchesQuery(obj, tagsQuery);\r\n };\r\n };\r\n /**\r\n * Removes tags support\r\n * @param obj defines the object to use\r\n */\r\n Tags.DisableFor = function (obj) {\r\n delete obj._tags;\r\n delete obj.hasTags;\r\n delete obj.addTags;\r\n delete obj.removeTags;\r\n delete obj.matchesTagsQuery;\r\n };\r\n /**\r\n * Gets a boolean indicating if the given object has tags\r\n * @param obj defines the object to use\r\n * @returns a boolean\r\n */\r\n Tags.HasTags = function (obj) {\r\n if (!obj._tags) {\r\n return false;\r\n }\r\n var tags = obj._tags;\r\n for (var i in tags) {\r\n if (tags.hasOwnProperty(i)) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n };\r\n /**\r\n * Gets the tags available on a given object\r\n * @param obj defines the object to use\r\n * @param asString defines if the tags must be returned as a string instead of an array of strings\r\n * @returns the tags\r\n */\r\n Tags.GetTags = function (obj, asString) {\r\n if (asString === void 0) { asString = true; }\r\n if (!obj._tags) {\r\n return null;\r\n }\r\n if (asString) {\r\n var tagsArray = [];\r\n for (var tag in obj._tags) {\r\n if (obj._tags.hasOwnProperty(tag) && obj._tags[tag] === true) {\r\n tagsArray.push(tag);\r\n }\r\n }\r\n return tagsArray.join(\" \");\r\n }\r\n else {\r\n return obj._tags;\r\n }\r\n };\r\n /**\r\n * Adds tags to an object\r\n * @param obj defines the object to use\r\n * @param tagsString defines the tag string. The tags 'true' and 'false' are reserved and cannot be used as tags.\r\n * A tag cannot start with '||', '&&', and '!'. It cannot contain whitespaces\r\n */\r\n Tags.AddTagsTo = function (obj, tagsString) {\r\n if (!tagsString) {\r\n return;\r\n }\r\n if (typeof tagsString !== \"string\") {\r\n return;\r\n }\r\n var tags = tagsString.split(\" \");\r\n tags.forEach(function (tag, index, array) {\r\n Tags._AddTagTo(obj, tag);\r\n });\r\n };\r\n /**\r\n * @hidden\r\n */\r\n Tags._AddTagTo = function (obj, tag) {\r\n tag = tag.trim();\r\n if (tag === \"\" || tag === \"true\" || tag === \"false\") {\r\n return;\r\n }\r\n if (tag.match(/[\\s]/) || tag.match(/^([!]|([|]|[&]){2})/)) {\r\n return;\r\n }\r\n Tags.EnableFor(obj);\r\n obj._tags[tag] = true;\r\n };\r\n /**\r\n * Removes specific tags from a specific object\r\n * @param obj defines the object to use\r\n * @param tagsString defines the tags to remove\r\n */\r\n Tags.RemoveTagsFrom = function (obj, tagsString) {\r\n if (!Tags.HasTags(obj)) {\r\n return;\r\n }\r\n var tags = tagsString.split(\" \");\r\n for (var t in tags) {\r\n Tags._RemoveTagFrom(obj, tags[t]);\r\n }\r\n };\r\n /**\r\n * @hidden\r\n */\r\n Tags._RemoveTagFrom = function (obj, tag) {\r\n delete obj._tags[tag];\r\n };\r\n /**\r\n * Defines if tags hosted on an object match a given query\r\n * @param obj defines the object to use\r\n * @param tagsQuery defines the tag query\r\n * @returns a boolean\r\n */\r\n Tags.MatchesQuery = function (obj, tagsQuery) {\r\n if (tagsQuery === undefined) {\r\n return true;\r\n }\r\n if (tagsQuery === \"\") {\r\n return Tags.HasTags(obj);\r\n }\r\n return AndOrNotEvaluator.Eval(tagsQuery, function (r) { return Tags.HasTags(obj) && obj._tags[r]; });\r\n };\r\n return Tags;\r\n}());\r\nexport { Tags };\r\n//# sourceMappingURL=tags.js.map","import { __extends } from \"tslib\";\r\n/**\r\n * Groups all the scene component constants in one place to ease maintenance.\r\n * @hidden\r\n */\r\nvar SceneComponentConstants = /** @class */ (function () {\r\n function SceneComponentConstants() {\r\n }\r\n SceneComponentConstants.NAME_EFFECTLAYER = \"EffectLayer\";\r\n SceneComponentConstants.NAME_LAYER = \"Layer\";\r\n SceneComponentConstants.NAME_LENSFLARESYSTEM = \"LensFlareSystem\";\r\n SceneComponentConstants.NAME_BOUNDINGBOXRENDERER = \"BoundingBoxRenderer\";\r\n SceneComponentConstants.NAME_PARTICLESYSTEM = \"ParticleSystem\";\r\n SceneComponentConstants.NAME_GAMEPAD = \"Gamepad\";\r\n SceneComponentConstants.NAME_SIMPLIFICATIONQUEUE = \"SimplificationQueue\";\r\n SceneComponentConstants.NAME_GEOMETRYBUFFERRENDERER = \"GeometryBufferRenderer\";\r\n SceneComponentConstants.NAME_DEPTHRENDERER = \"DepthRenderer\";\r\n SceneComponentConstants.NAME_POSTPROCESSRENDERPIPELINEMANAGER = \"PostProcessRenderPipelineManager\";\r\n SceneComponentConstants.NAME_SPRITE = \"Sprite\";\r\n SceneComponentConstants.NAME_OUTLINERENDERER = \"Outline\";\r\n SceneComponentConstants.NAME_PROCEDURALTEXTURE = \"ProceduralTexture\";\r\n SceneComponentConstants.NAME_SHADOWGENERATOR = \"ShadowGenerator\";\r\n SceneComponentConstants.NAME_OCTREE = \"Octree\";\r\n SceneComponentConstants.NAME_PHYSICSENGINE = \"PhysicsEngine\";\r\n SceneComponentConstants.NAME_AUDIO = \"Audio\";\r\n SceneComponentConstants.STEP_ISREADYFORMESH_EFFECTLAYER = 0;\r\n SceneComponentConstants.STEP_BEFOREEVALUATEACTIVEMESH_BOUNDINGBOXRENDERER = 0;\r\n SceneComponentConstants.STEP_EVALUATESUBMESH_BOUNDINGBOXRENDERER = 0;\r\n SceneComponentConstants.STEP_ACTIVEMESH_BOUNDINGBOXRENDERER = 0;\r\n SceneComponentConstants.STEP_CAMERADRAWRENDERTARGET_EFFECTLAYER = 1;\r\n SceneComponentConstants.STEP_BEFORECAMERADRAW_EFFECTLAYER = 0;\r\n SceneComponentConstants.STEP_BEFORECAMERADRAW_LAYER = 1;\r\n SceneComponentConstants.STEP_BEFORERENDERTARGETDRAW_LAYER = 0;\r\n SceneComponentConstants.STEP_BEFORERENDERINGMESH_OUTLINE = 0;\r\n SceneComponentConstants.STEP_AFTERRENDERINGMESH_OUTLINE = 0;\r\n SceneComponentConstants.STEP_AFTERRENDERINGGROUPDRAW_EFFECTLAYER_DRAW = 0;\r\n SceneComponentConstants.STEP_AFTERRENDERINGGROUPDRAW_BOUNDINGBOXRENDERER = 1;\r\n SceneComponentConstants.STEP_BEFORECAMERAUPDATE_SIMPLIFICATIONQUEUE = 0;\r\n SceneComponentConstants.STEP_BEFORECAMERAUPDATE_GAMEPAD = 1;\r\n SceneComponentConstants.STEP_BEFORECLEAR_PROCEDURALTEXTURE = 0;\r\n SceneComponentConstants.STEP_AFTERRENDERTARGETDRAW_LAYER = 0;\r\n SceneComponentConstants.STEP_AFTERCAMERADRAW_EFFECTLAYER = 0;\r\n SceneComponentConstants.STEP_AFTERCAMERADRAW_LENSFLARESYSTEM = 1;\r\n SceneComponentConstants.STEP_AFTERCAMERADRAW_EFFECTLAYER_DRAW = 2;\r\n SceneComponentConstants.STEP_AFTERCAMERADRAW_LAYER = 3;\r\n SceneComponentConstants.STEP_AFTERRENDER_AUDIO = 0;\r\n SceneComponentConstants.STEP_GATHERRENDERTARGETS_DEPTHRENDERER = 0;\r\n SceneComponentConstants.STEP_GATHERRENDERTARGETS_GEOMETRYBUFFERRENDERER = 1;\r\n SceneComponentConstants.STEP_GATHERRENDERTARGETS_SHADOWGENERATOR = 2;\r\n SceneComponentConstants.STEP_GATHERRENDERTARGETS_POSTPROCESSRENDERPIPELINEMANAGER = 3;\r\n SceneComponentConstants.STEP_GATHERACTIVECAMERARENDERTARGETS_DEPTHRENDERER = 0;\r\n SceneComponentConstants.STEP_POINTERMOVE_SPRITE = 0;\r\n SceneComponentConstants.STEP_POINTERDOWN_SPRITE = 0;\r\n SceneComponentConstants.STEP_POINTERUP_SPRITE = 0;\r\n return SceneComponentConstants;\r\n}());\r\nexport { SceneComponentConstants };\r\n/**\r\n * Representation of a stage in the scene (Basically a list of ordered steps)\r\n * @hidden\r\n */\r\nvar Stage = /** @class */ (function (_super) {\r\n __extends(Stage, _super);\r\n /**\r\n * Hide ctor from the rest of the world.\r\n * @param items The items to add.\r\n */\r\n function Stage(items) {\r\n return _super.apply(this, items) || this;\r\n }\r\n /**\r\n * Creates a new Stage.\r\n * @returns A new instance of a Stage\r\n */\r\n Stage.Create = function () {\r\n return Object.create(Stage.prototype);\r\n };\r\n /**\r\n * Registers a step in an ordered way in the targeted stage.\r\n * @param index Defines the position to register the step in\r\n * @param component Defines the component attached to the step\r\n * @param action Defines the action to launch during the step\r\n */\r\n Stage.prototype.registerStep = function (index, component, action) {\r\n var i = 0;\r\n var maxIndex = Number.MAX_VALUE;\r\n for (; i < this.length; i++) {\r\n var step = this[i];\r\n maxIndex = step.index;\r\n if (index < maxIndex) {\r\n break;\r\n }\r\n }\r\n this.splice(i, 0, { index: index, component: component, action: action.bind(component) });\r\n };\r\n /**\r\n * Clears all the steps from the stage.\r\n */\r\n Stage.prototype.clear = function () {\r\n this.length = 0;\r\n };\r\n return Stage;\r\n}(Array));\r\nexport { Stage };\r\n//# sourceMappingURL=sceneComponent.js.map","/**\r\n * The engine store class is responsible to hold all the instances of Engine and Scene created\r\n * during the life time of the application.\r\n */\r\nvar EngineStore = /** @class */ (function () {\r\n function EngineStore() {\r\n }\r\n Object.defineProperty(EngineStore, \"LastCreatedEngine\", {\r\n /**\r\n * Gets the latest created engine\r\n */\r\n get: function () {\r\n if (this.Instances.length === 0) {\r\n return null;\r\n }\r\n return this.Instances[this.Instances.length - 1];\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(EngineStore, \"LastCreatedScene\", {\r\n /**\r\n * Gets the latest created scene\r\n */\r\n get: function () {\r\n return this._LastCreatedScene;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** Gets the list of created engines */\r\n EngineStore.Instances = new Array();\r\n /** @hidden */\r\n EngineStore._LastCreatedScene = null;\r\n /**\r\n * Gets or sets a global variable indicating if fallback texture must be used when a texture cannot be loaded\r\n * @ignorenaming\r\n */\r\n EngineStore.UseFallbackTexture = true;\r\n /**\r\n * Texture content used if a texture cannot loaded\r\n * @ignorenaming\r\n */\r\n EngineStore.FallbackTexture = \"\";\r\n return EngineStore;\r\n}());\r\nexport { EngineStore };\r\n//# sourceMappingURL=engineStore.js.map","/**\r\n * @hidden\r\n **/\r\nvar DepthCullingState = /** @class */ (function () {\r\n /**\r\n * Initializes the state.\r\n */\r\n function DepthCullingState() {\r\n this._isDepthTestDirty = false;\r\n this._isDepthMaskDirty = false;\r\n this._isDepthFuncDirty = false;\r\n this._isCullFaceDirty = false;\r\n this._isCullDirty = false;\r\n this._isZOffsetDirty = false;\r\n this._isFrontFaceDirty = false;\r\n this.reset();\r\n }\r\n Object.defineProperty(DepthCullingState.prototype, \"isDirty\", {\r\n get: function () {\r\n return this._isDepthFuncDirty || this._isDepthTestDirty || this._isDepthMaskDirty || this._isCullFaceDirty || this._isCullDirty || this._isZOffsetDirty || this._isFrontFaceDirty;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DepthCullingState.prototype, \"zOffset\", {\r\n get: function () {\r\n return this._zOffset;\r\n },\r\n set: function (value) {\r\n if (this._zOffset === value) {\r\n return;\r\n }\r\n this._zOffset = value;\r\n this._isZOffsetDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DepthCullingState.prototype, \"cullFace\", {\r\n get: function () {\r\n return this._cullFace;\r\n },\r\n set: function (value) {\r\n if (this._cullFace === value) {\r\n return;\r\n }\r\n this._cullFace = value;\r\n this._isCullFaceDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DepthCullingState.prototype, \"cull\", {\r\n get: function () {\r\n return this._cull;\r\n },\r\n set: function (value) {\r\n if (this._cull === value) {\r\n return;\r\n }\r\n this._cull = value;\r\n this._isCullDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DepthCullingState.prototype, \"depthFunc\", {\r\n get: function () {\r\n return this._depthFunc;\r\n },\r\n set: function (value) {\r\n if (this._depthFunc === value) {\r\n return;\r\n }\r\n this._depthFunc = value;\r\n this._isDepthFuncDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DepthCullingState.prototype, \"depthMask\", {\r\n get: function () {\r\n return this._depthMask;\r\n },\r\n set: function (value) {\r\n if (this._depthMask === value) {\r\n return;\r\n }\r\n this._depthMask = value;\r\n this._isDepthMaskDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DepthCullingState.prototype, \"depthTest\", {\r\n get: function () {\r\n return this._depthTest;\r\n },\r\n set: function (value) {\r\n if (this._depthTest === value) {\r\n return;\r\n }\r\n this._depthTest = value;\r\n this._isDepthTestDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DepthCullingState.prototype, \"frontFace\", {\r\n get: function () {\r\n return this._frontFace;\r\n },\r\n set: function (value) {\r\n if (this._frontFace === value) {\r\n return;\r\n }\r\n this._frontFace = value;\r\n this._isFrontFaceDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n DepthCullingState.prototype.reset = function () {\r\n this._depthMask = true;\r\n this._depthTest = true;\r\n this._depthFunc = null;\r\n this._cullFace = null;\r\n this._cull = null;\r\n this._zOffset = 0;\r\n this._frontFace = null;\r\n this._isDepthTestDirty = true;\r\n this._isDepthMaskDirty = true;\r\n this._isDepthFuncDirty = false;\r\n this._isCullFaceDirty = false;\r\n this._isCullDirty = false;\r\n this._isZOffsetDirty = false;\r\n this._isFrontFaceDirty = false;\r\n };\r\n DepthCullingState.prototype.apply = function (gl) {\r\n if (!this.isDirty) {\r\n return;\r\n }\r\n // Cull\r\n if (this._isCullDirty) {\r\n if (this.cull) {\r\n gl.enable(gl.CULL_FACE);\r\n }\r\n else {\r\n gl.disable(gl.CULL_FACE);\r\n }\r\n this._isCullDirty = false;\r\n }\r\n // Cull face\r\n if (this._isCullFaceDirty) {\r\n gl.cullFace(this.cullFace);\r\n this._isCullFaceDirty = false;\r\n }\r\n // Depth mask\r\n if (this._isDepthMaskDirty) {\r\n gl.depthMask(this.depthMask);\r\n this._isDepthMaskDirty = false;\r\n }\r\n // Depth test\r\n if (this._isDepthTestDirty) {\r\n if (this.depthTest) {\r\n gl.enable(gl.DEPTH_TEST);\r\n }\r\n else {\r\n gl.disable(gl.DEPTH_TEST);\r\n }\r\n this._isDepthTestDirty = false;\r\n }\r\n // Depth func\r\n if (this._isDepthFuncDirty) {\r\n gl.depthFunc(this.depthFunc);\r\n this._isDepthFuncDirty = false;\r\n }\r\n // zOffset\r\n if (this._isZOffsetDirty) {\r\n if (this.zOffset) {\r\n gl.enable(gl.POLYGON_OFFSET_FILL);\r\n gl.polygonOffset(this.zOffset, 0);\r\n }\r\n else {\r\n gl.disable(gl.POLYGON_OFFSET_FILL);\r\n }\r\n this._isZOffsetDirty = false;\r\n }\r\n // Front face\r\n if (this._isFrontFaceDirty) {\r\n gl.frontFace(this.frontFace);\r\n this._isFrontFaceDirty = false;\r\n }\r\n };\r\n return DepthCullingState;\r\n}());\r\nexport { DepthCullingState };\r\n//# sourceMappingURL=depthCullingState.js.map","/**\r\n * @hidden\r\n **/\r\nvar StencilState = /** @class */ (function () {\r\n function StencilState() {\r\n this._isStencilTestDirty = false;\r\n this._isStencilMaskDirty = false;\r\n this._isStencilFuncDirty = false;\r\n this._isStencilOpDirty = false;\r\n this.reset();\r\n }\r\n Object.defineProperty(StencilState.prototype, \"isDirty\", {\r\n get: function () {\r\n return this._isStencilTestDirty || this._isStencilMaskDirty || this._isStencilFuncDirty || this._isStencilOpDirty;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StencilState.prototype, \"stencilFunc\", {\r\n get: function () {\r\n return this._stencilFunc;\r\n },\r\n set: function (value) {\r\n if (this._stencilFunc === value) {\r\n return;\r\n }\r\n this._stencilFunc = value;\r\n this._isStencilFuncDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StencilState.prototype, \"stencilFuncRef\", {\r\n get: function () {\r\n return this._stencilFuncRef;\r\n },\r\n set: function (value) {\r\n if (this._stencilFuncRef === value) {\r\n return;\r\n }\r\n this._stencilFuncRef = value;\r\n this._isStencilFuncDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StencilState.prototype, \"stencilFuncMask\", {\r\n get: function () {\r\n return this._stencilFuncMask;\r\n },\r\n set: function (value) {\r\n if (this._stencilFuncMask === value) {\r\n return;\r\n }\r\n this._stencilFuncMask = value;\r\n this._isStencilFuncDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StencilState.prototype, \"stencilOpStencilFail\", {\r\n get: function () {\r\n return this._stencilOpStencilFail;\r\n },\r\n set: function (value) {\r\n if (this._stencilOpStencilFail === value) {\r\n return;\r\n }\r\n this._stencilOpStencilFail = value;\r\n this._isStencilOpDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StencilState.prototype, \"stencilOpDepthFail\", {\r\n get: function () {\r\n return this._stencilOpDepthFail;\r\n },\r\n set: function (value) {\r\n if (this._stencilOpDepthFail === value) {\r\n return;\r\n }\r\n this._stencilOpDepthFail = value;\r\n this._isStencilOpDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StencilState.prototype, \"stencilOpStencilDepthPass\", {\r\n get: function () {\r\n return this._stencilOpStencilDepthPass;\r\n },\r\n set: function (value) {\r\n if (this._stencilOpStencilDepthPass === value) {\r\n return;\r\n }\r\n this._stencilOpStencilDepthPass = value;\r\n this._isStencilOpDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StencilState.prototype, \"stencilMask\", {\r\n get: function () {\r\n return this._stencilMask;\r\n },\r\n set: function (value) {\r\n if (this._stencilMask === value) {\r\n return;\r\n }\r\n this._stencilMask = value;\r\n this._isStencilMaskDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StencilState.prototype, \"stencilTest\", {\r\n get: function () {\r\n return this._stencilTest;\r\n },\r\n set: function (value) {\r\n if (this._stencilTest === value) {\r\n return;\r\n }\r\n this._stencilTest = value;\r\n this._isStencilTestDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n StencilState.prototype.reset = function () {\r\n this._stencilTest = false;\r\n this._stencilMask = 0xFF;\r\n this._stencilFunc = StencilState.ALWAYS;\r\n this._stencilFuncRef = 1;\r\n this._stencilFuncMask = 0xFF;\r\n this._stencilOpStencilFail = StencilState.KEEP;\r\n this._stencilOpDepthFail = StencilState.KEEP;\r\n this._stencilOpStencilDepthPass = StencilState.REPLACE;\r\n this._isStencilTestDirty = true;\r\n this._isStencilMaskDirty = true;\r\n this._isStencilFuncDirty = true;\r\n this._isStencilOpDirty = true;\r\n };\r\n StencilState.prototype.apply = function (gl) {\r\n if (!this.isDirty) {\r\n return;\r\n }\r\n // Stencil test\r\n if (this._isStencilTestDirty) {\r\n if (this.stencilTest) {\r\n gl.enable(gl.STENCIL_TEST);\r\n }\r\n else {\r\n gl.disable(gl.STENCIL_TEST);\r\n }\r\n this._isStencilTestDirty = false;\r\n }\r\n // Stencil mask\r\n if (this._isStencilMaskDirty) {\r\n gl.stencilMask(this.stencilMask);\r\n this._isStencilMaskDirty = false;\r\n }\r\n // Stencil func\r\n if (this._isStencilFuncDirty) {\r\n gl.stencilFunc(this.stencilFunc, this.stencilFuncRef, this.stencilFuncMask);\r\n this._isStencilFuncDirty = false;\r\n }\r\n // Stencil op\r\n if (this._isStencilOpDirty) {\r\n gl.stencilOp(this.stencilOpStencilFail, this.stencilOpDepthFail, this.stencilOpStencilDepthPass);\r\n this._isStencilOpDirty = false;\r\n }\r\n };\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will always pass. i.e. Pixels will be drawn in the order they are drawn */\r\n StencilState.ALWAYS = 519;\r\n /** Passed to stencilOperation to specify that stencil value must be kept */\r\n StencilState.KEEP = 7680;\r\n /** Passed to stencilOperation to specify that stencil value must be replaced */\r\n StencilState.REPLACE = 7681;\r\n return StencilState;\r\n}());\r\nexport { StencilState };\r\n//# sourceMappingURL=stencilState.js.map","/**\r\n * @hidden\r\n **/\r\nvar AlphaState = /** @class */ (function () {\r\n /**\r\n * Initializes the state.\r\n */\r\n function AlphaState() {\r\n this._isAlphaBlendDirty = false;\r\n this._isBlendFunctionParametersDirty = false;\r\n this._isBlendEquationParametersDirty = false;\r\n this._isBlendConstantsDirty = false;\r\n this._alphaBlend = false;\r\n this._blendFunctionParameters = new Array(4);\r\n this._blendEquationParameters = new Array(2);\r\n this._blendConstants = new Array(4);\r\n this.reset();\r\n }\r\n Object.defineProperty(AlphaState.prototype, \"isDirty\", {\r\n get: function () {\r\n return this._isAlphaBlendDirty || this._isBlendFunctionParametersDirty;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AlphaState.prototype, \"alphaBlend\", {\r\n get: function () {\r\n return this._alphaBlend;\r\n },\r\n set: function (value) {\r\n if (this._alphaBlend === value) {\r\n return;\r\n }\r\n this._alphaBlend = value;\r\n this._isAlphaBlendDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n AlphaState.prototype.setAlphaBlendConstants = function (r, g, b, a) {\r\n if (this._blendConstants[0] === r &&\r\n this._blendConstants[1] === g &&\r\n this._blendConstants[2] === b &&\r\n this._blendConstants[3] === a) {\r\n return;\r\n }\r\n this._blendConstants[0] = r;\r\n this._blendConstants[1] = g;\r\n this._blendConstants[2] = b;\r\n this._blendConstants[3] = a;\r\n this._isBlendConstantsDirty = true;\r\n };\r\n AlphaState.prototype.setAlphaBlendFunctionParameters = function (value0, value1, value2, value3) {\r\n if (this._blendFunctionParameters[0] === value0 &&\r\n this._blendFunctionParameters[1] === value1 &&\r\n this._blendFunctionParameters[2] === value2 &&\r\n this._blendFunctionParameters[3] === value3) {\r\n return;\r\n }\r\n this._blendFunctionParameters[0] = value0;\r\n this._blendFunctionParameters[1] = value1;\r\n this._blendFunctionParameters[2] = value2;\r\n this._blendFunctionParameters[3] = value3;\r\n this._isBlendFunctionParametersDirty = true;\r\n };\r\n AlphaState.prototype.setAlphaEquationParameters = function (rgb, alpha) {\r\n if (this._blendEquationParameters[0] === rgb &&\r\n this._blendEquationParameters[1] === alpha) {\r\n return;\r\n }\r\n this._blendEquationParameters[0] = rgb;\r\n this._blendEquationParameters[1] = alpha;\r\n this._isBlendEquationParametersDirty = true;\r\n };\r\n AlphaState.prototype.reset = function () {\r\n this._alphaBlend = false;\r\n this._blendFunctionParameters[0] = null;\r\n this._blendFunctionParameters[1] = null;\r\n this._blendFunctionParameters[2] = null;\r\n this._blendFunctionParameters[3] = null;\r\n this._blendEquationParameters[0] = null;\r\n this._blendEquationParameters[1] = null;\r\n this._blendConstants[0] = null;\r\n this._blendConstants[1] = null;\r\n this._blendConstants[2] = null;\r\n this._blendConstants[3] = null;\r\n this._isAlphaBlendDirty = true;\r\n this._isBlendFunctionParametersDirty = false;\r\n this._isBlendEquationParametersDirty = false;\r\n this._isBlendConstantsDirty = false;\r\n };\r\n AlphaState.prototype.apply = function (gl) {\r\n if (!this.isDirty) {\r\n return;\r\n }\r\n // Alpha blend\r\n if (this._isAlphaBlendDirty) {\r\n if (this._alphaBlend) {\r\n gl.enable(gl.BLEND);\r\n }\r\n else {\r\n gl.disable(gl.BLEND);\r\n }\r\n this._isAlphaBlendDirty = false;\r\n }\r\n // Alpha function\r\n if (this._isBlendFunctionParametersDirty) {\r\n gl.blendFuncSeparate(this._blendFunctionParameters[0], this._blendFunctionParameters[1], this._blendFunctionParameters[2], this._blendFunctionParameters[3]);\r\n this._isBlendFunctionParametersDirty = false;\r\n }\r\n // Alpha equation\r\n if (this._isBlendEquationParametersDirty) {\r\n gl.blendEquationSeparate(this._blendEquationParameters[0], this._blendEquationParameters[1]);\r\n this._isBlendEquationParametersDirty = false;\r\n }\r\n // Constants\r\n if (this._isBlendConstantsDirty) {\r\n gl.blendColor(this._blendConstants[0], this._blendConstants[1], this._blendConstants[2], this._blendConstants[3]);\r\n this._isBlendConstantsDirty = false;\r\n }\r\n };\r\n return AlphaState;\r\n}());\r\nexport { AlphaState };\r\n//# sourceMappingURL=alphaCullingState.js.map","/** @hidden */\r\nvar WebGL2ShaderProcessor = /** @class */ (function () {\r\n function WebGL2ShaderProcessor() {\r\n }\r\n WebGL2ShaderProcessor.prototype.attributeProcessor = function (attribute) {\r\n return attribute.replace(\"attribute\", \"in\");\r\n };\r\n WebGL2ShaderProcessor.prototype.varyingProcessor = function (varying, isFragment) {\r\n return varying.replace(\"varying\", isFragment ? \"in\" : \"out\");\r\n };\r\n WebGL2ShaderProcessor.prototype.postProcessor = function (code, defines, isFragment) {\r\n var hasDrawBuffersExtension = code.search(/#extension.+GL_EXT_draw_buffers.+require/) !== -1;\r\n // Remove extensions\r\n var regex = /#extension.+(GL_OVR_multiview2|GL_OES_standard_derivatives|GL_EXT_shader_texture_lod|GL_EXT_frag_depth|GL_EXT_draw_buffers).+(enable|require)/g;\r\n code = code.replace(regex, \"\");\r\n // Replace instructions\r\n code = code.replace(/texture2D\\s*\\(/g, \"texture(\");\r\n if (isFragment) {\r\n code = code.replace(/texture2DLodEXT\\s*\\(/g, \"textureLod(\");\r\n code = code.replace(/textureCubeLodEXT\\s*\\(/g, \"textureLod(\");\r\n code = code.replace(/textureCube\\s*\\(/g, \"texture(\");\r\n code = code.replace(/gl_FragDepthEXT/g, \"gl_FragDepth\");\r\n code = code.replace(/gl_FragColor/g, \"glFragColor\");\r\n code = code.replace(/gl_FragData/g, \"glFragData\");\r\n code = code.replace(/void\\s+?main\\s*\\(/g, (hasDrawBuffersExtension ? \"\" : \"out vec4 glFragColor;\\n\") + \"void main(\");\r\n }\r\n else {\r\n var hasMultiviewExtension = defines.indexOf(\"#define MULTIVIEW\") !== -1;\r\n if (hasMultiviewExtension) {\r\n return \"#extension GL_OVR_multiview2 : require\\nlayout (num_views = 2) in;\\n\" + code;\r\n }\r\n }\r\n return code;\r\n };\r\n return WebGL2ShaderProcessor;\r\n}());\r\nexport { WebGL2ShaderProcessor };\r\n//# sourceMappingURL=webGL2ShaderProcessors.js.map","/** @hidden */\r\nvar WebGLPipelineContext = /** @class */ (function () {\r\n function WebGLPipelineContext() {\r\n this.vertexCompilationError = null;\r\n this.fragmentCompilationError = null;\r\n this.programLinkError = null;\r\n this.programValidationError = null;\r\n }\r\n Object.defineProperty(WebGLPipelineContext.prototype, \"isAsync\", {\r\n get: function () {\r\n return this.isParallelCompiled;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(WebGLPipelineContext.prototype, \"isReady\", {\r\n get: function () {\r\n if (this.program) {\r\n if (this.isParallelCompiled) {\r\n return this.engine._isRenderingStateCompiled(this);\r\n }\r\n return true;\r\n }\r\n return false;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n WebGLPipelineContext.prototype._handlesSpectorRebuildCallback = function (onCompiled) {\r\n if (onCompiled && this.program) {\r\n onCompiled(this.program);\r\n }\r\n };\r\n return WebGLPipelineContext;\r\n}());\r\nexport { WebGLPipelineContext };\r\n//# sourceMappingURL=webGLPipelineContext.js.map","import { EngineStore } from './engineStore';\r\nimport { Effect } from '../Materials/effect';\r\nimport { _DevTools } from '../Misc/devTools';\r\nimport { Observable } from '../Misc/observable';\r\nimport { DepthCullingState } from '../States/depthCullingState';\r\nimport { StencilState } from '../States/stencilState';\r\nimport { AlphaState } from '../States/alphaCullingState';\r\nimport { InternalTexture, InternalTextureSource } from '../Materials/Textures/internalTexture';\r\nimport { Logger } from '../Misc/logger';\r\nimport { DomManagement } from '../Misc/domManagement';\r\nimport { WebGL2ShaderProcessor } from './WebGL/webGL2ShaderProcessors';\r\nimport { WebGLDataBuffer } from '../Meshes/WebGL/webGLDataBuffer';\r\nimport { WebGLPipelineContext } from './WebGL/webGLPipelineContext';\r\nimport { CanvasGenerator } from '../Misc/canvasGenerator';\r\n/**\r\n * Keeps track of all the buffer info used in engine.\r\n */\r\nvar BufferPointer = /** @class */ (function () {\r\n function BufferPointer() {\r\n }\r\n return BufferPointer;\r\n}());\r\n/**\r\n * The base engine class (root of all engines)\r\n */\r\nvar ThinEngine = /** @class */ (function () {\r\n /**\r\n * Creates a new engine\r\n * @param canvasOrContext defines the canvas or WebGL context to use for rendering. If you provide a WebGL context, Babylon.js will not hook events on the canvas (like pointers, keyboards, etc...) so no event observables will be available. This is mostly used when Babylon.js is used as a plugin on a system which alreay used the WebGL context\r\n * @param antialias defines enable antialiasing (default: false)\r\n * @param options defines further options to be sent to the getContext() function\r\n * @param adaptToDeviceRatio defines whether to adapt to the device's viewport characteristics (default: false)\r\n */\r\n function ThinEngine(canvasOrContext, antialias, options, adaptToDeviceRatio) {\r\n var _this = this;\r\n if (adaptToDeviceRatio === void 0) { adaptToDeviceRatio = false; }\r\n /**\r\n * Gets or sets a boolean that indicates if textures must be forced to power of 2 size even if not required\r\n */\r\n this.forcePOTTextures = false;\r\n /**\r\n * Gets a boolean indicating if the engine is currently rendering in fullscreen mode\r\n */\r\n this.isFullscreen = false;\r\n /**\r\n * Gets or sets a boolean indicating if back faces must be culled (true by default)\r\n */\r\n this.cullBackFaces = true;\r\n /**\r\n * Gets or sets a boolean indicating if the engine must keep rendering even if the window is not in foregroun\r\n */\r\n this.renderEvenInBackground = true;\r\n /**\r\n * Gets or sets a boolean indicating that cache can be kept between frames\r\n */\r\n this.preventCacheWipeBetweenFrames = false;\r\n /** Gets or sets a boolean indicating if the engine should validate programs after compilation */\r\n this.validateShaderPrograms = false;\r\n /**\r\n * Gets or sets a boolean indicating if depth buffer should be reverse, going from far to near.\r\n * This can provide greater z depth for distant objects.\r\n */\r\n this.useReverseDepthBuffer = false;\r\n // Uniform buffers list\r\n /**\r\n * Gets or sets a boolean indicating that uniform buffers must be disabled even if they are supported\r\n */\r\n this.disableUniformBuffers = false;\r\n /** @hidden */\r\n this._uniformBuffers = new Array();\r\n /** @hidden */\r\n this._webGLVersion = 1.0;\r\n this._windowIsBackground = false;\r\n this._highPrecisionShadersAllowed = true;\r\n /** @hidden */\r\n this._badOS = false;\r\n /** @hidden */\r\n this._badDesktopOS = false;\r\n this._renderingQueueLaunched = false;\r\n this._activeRenderLoops = new Array();\r\n // Lost context\r\n /**\r\n * Observable signaled when a context lost event is raised\r\n */\r\n this.onContextLostObservable = new Observable();\r\n /**\r\n * Observable signaled when a context restored event is raised\r\n */\r\n this.onContextRestoredObservable = new Observable();\r\n this._contextWasLost = false;\r\n /** @hidden */\r\n this._doNotHandleContextLost = false;\r\n /**\r\n * Gets or sets a boolean indicating that vertex array object must be disabled even if they are supported\r\n */\r\n this.disableVertexArrayObjects = false;\r\n // States\r\n /** @hidden */\r\n this._colorWrite = true;\r\n /** @hidden */\r\n this._colorWriteChanged = true;\r\n /** @hidden */\r\n this._depthCullingState = new DepthCullingState();\r\n /** @hidden */\r\n this._stencilState = new StencilState();\r\n /** @hidden */\r\n this._alphaState = new AlphaState();\r\n /** @hidden */\r\n this._alphaMode = 1;\r\n /** @hidden */\r\n this._alphaEquation = 0;\r\n // Cache\r\n /** @hidden */\r\n this._internalTexturesCache = new Array();\r\n /** @hidden */\r\n this._activeChannel = 0;\r\n this._currentTextureChannel = -1;\r\n /** @hidden */\r\n this._boundTexturesCache = {};\r\n this._compiledEffects = {};\r\n this._vertexAttribArraysEnabled = [];\r\n this._uintIndicesCurrentlySet = false;\r\n this._currentBoundBuffer = new Array();\r\n /** @hidden */\r\n this._currentFramebuffer = null;\r\n this._currentBufferPointers = new Array();\r\n this._currentInstanceLocations = new Array();\r\n this._currentInstanceBuffers = new Array();\r\n this._vaoRecordInProgress = false;\r\n this._mustWipeVertexAttributes = false;\r\n this._nextFreeTextureSlots = new Array();\r\n this._maxSimultaneousTextures = 0;\r\n this._activeRequests = new Array();\r\n // Hardware supported Compressed Textures\r\n this._texturesSupported = new Array();\r\n /**\r\n * Defines whether the engine has been created with the premultipliedAlpha option on or not.\r\n */\r\n this.premultipliedAlpha = true;\r\n /**\r\n * Observable event triggered before each texture is initialized\r\n */\r\n this.onBeforeTextureInitObservable = new Observable();\r\n this._viewportCached = { x: 0, y: 0, z: 0, w: 0 };\r\n this._unpackFlipYCached = null;\r\n /**\r\n * In case you are sharing the context with other applications, it might\r\n * be interested to not cache the unpack flip y state to ensure a consistent\r\n * value would be set.\r\n */\r\n this.enableUnpackFlipYCached = true;\r\n this._getDepthStencilBuffer = function (width, height, samples, internalFormat, msInternalFormat, attachment) {\r\n var gl = _this._gl;\r\n var depthStencilBuffer = gl.createRenderbuffer();\r\n gl.bindRenderbuffer(gl.RENDERBUFFER, depthStencilBuffer);\r\n if (samples > 1 && gl.renderbufferStorageMultisample) {\r\n gl.renderbufferStorageMultisample(gl.RENDERBUFFER, samples, msInternalFormat, width, height);\r\n }\r\n else {\r\n gl.renderbufferStorage(gl.RENDERBUFFER, internalFormat, width, height);\r\n }\r\n gl.framebufferRenderbuffer(gl.FRAMEBUFFER, attachment, gl.RENDERBUFFER, depthStencilBuffer);\r\n gl.bindRenderbuffer(gl.RENDERBUFFER, null);\r\n return depthStencilBuffer;\r\n };\r\n this._boundUniforms = {};\r\n var canvas = null;\r\n if (!canvasOrContext) {\r\n return;\r\n }\r\n options = options || {};\r\n if (canvasOrContext.getContext) {\r\n canvas = canvasOrContext;\r\n this._renderingCanvas = canvas;\r\n if (antialias != null) {\r\n options.antialias = antialias;\r\n }\r\n if (options.deterministicLockstep === undefined) {\r\n options.deterministicLockstep = false;\r\n }\r\n if (options.lockstepMaxSteps === undefined) {\r\n options.lockstepMaxSteps = 4;\r\n }\r\n if (options.timeStep === undefined) {\r\n options.timeStep = 1 / 60;\r\n }\r\n if (options.preserveDrawingBuffer === undefined) {\r\n options.preserveDrawingBuffer = false;\r\n }\r\n if (options.audioEngine === undefined) {\r\n options.audioEngine = true;\r\n }\r\n if (options.stencil === undefined) {\r\n options.stencil = true;\r\n }\r\n if (options.premultipliedAlpha === false) {\r\n this.premultipliedAlpha = false;\r\n }\r\n this._doNotHandleContextLost = options.doNotHandleContextLost ? true : false;\r\n // Exceptions\r\n if (navigator && navigator.userAgent) {\r\n var ua = navigator.userAgent;\r\n for (var _i = 0, _a = ThinEngine.ExceptionList; _i < _a.length; _i++) {\r\n var exception = _a[_i];\r\n var key = exception.key;\r\n var targets = exception.targets;\r\n var check = new RegExp(key);\r\n if (check.test(ua)) {\r\n if (exception.capture && exception.captureConstraint) {\r\n var capture = exception.capture;\r\n var constraint = exception.captureConstraint;\r\n var regex = new RegExp(capture);\r\n var matches = regex.exec(ua);\r\n if (matches && matches.length > 0) {\r\n var capturedValue = parseInt(matches[matches.length - 1]);\r\n if (capturedValue >= constraint) {\r\n continue;\r\n }\r\n }\r\n }\r\n for (var _b = 0, targets_1 = targets; _b < targets_1.length; _b++) {\r\n var target = targets_1[_b];\r\n switch (target) {\r\n case \"uniformBuffer\":\r\n this.disableUniformBuffers = true;\r\n break;\r\n case \"vao\":\r\n this.disableVertexArrayObjects = true;\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n // Context lost\r\n if (!this._doNotHandleContextLost) {\r\n this._onContextLost = function (evt) {\r\n evt.preventDefault();\r\n _this._contextWasLost = true;\r\n Logger.Warn(\"WebGL context lost.\");\r\n _this.onContextLostObservable.notifyObservers(_this);\r\n };\r\n this._onContextRestored = function () {\r\n // Adding a timeout to avoid race condition at browser level\r\n setTimeout(function () {\r\n // Rebuild gl context\r\n _this._initGLContext();\r\n // Rebuild effects\r\n _this._rebuildEffects();\r\n // Rebuild textures\r\n _this._rebuildInternalTextures();\r\n // Rebuild buffers\r\n _this._rebuildBuffers();\r\n // Cache\r\n _this.wipeCaches(true);\r\n Logger.Warn(\"WebGL context successfully restored.\");\r\n _this.onContextRestoredObservable.notifyObservers(_this);\r\n _this._contextWasLost = false;\r\n }, 0);\r\n };\r\n canvas.addEventListener(\"webglcontextlost\", this._onContextLost, false);\r\n canvas.addEventListener(\"webglcontextrestored\", this._onContextRestored, false);\r\n options.powerPreference = \"high-performance\";\r\n }\r\n // GL\r\n if (!options.disableWebGL2Support) {\r\n try {\r\n this._gl = (canvas.getContext(\"webgl2\", options) || canvas.getContext(\"experimental-webgl2\", options));\r\n if (this._gl) {\r\n this._webGLVersion = 2.0;\r\n // Prevent weird browsers to lie (yeah that happens!)\r\n if (!this._gl.deleteQuery) {\r\n this._webGLVersion = 1.0;\r\n }\r\n }\r\n }\r\n catch (e) {\r\n // Do nothing\r\n }\r\n }\r\n if (!this._gl) {\r\n if (!canvas) {\r\n throw new Error(\"The provided canvas is null or undefined.\");\r\n }\r\n try {\r\n this._gl = (canvas.getContext(\"webgl\", options) || canvas.getContext(\"experimental-webgl\", options));\r\n }\r\n catch (e) {\r\n throw new Error(\"WebGL not supported\");\r\n }\r\n }\r\n if (!this._gl) {\r\n throw new Error(\"WebGL not supported\");\r\n }\r\n }\r\n else {\r\n this._gl = canvasOrContext;\r\n this._renderingCanvas = this._gl.canvas;\r\n if (this._gl.renderbufferStorageMultisample) {\r\n this._webGLVersion = 2.0;\r\n }\r\n var attributes = this._gl.getContextAttributes();\r\n if (attributes) {\r\n options.stencil = attributes.stencil;\r\n }\r\n }\r\n // Ensures a consistent color space unpacking of textures cross browser.\r\n this._gl.pixelStorei(this._gl.UNPACK_COLORSPACE_CONVERSION_WEBGL, this._gl.NONE);\r\n if (options.useHighPrecisionFloats !== undefined) {\r\n this._highPrecisionShadersAllowed = options.useHighPrecisionFloats;\r\n }\r\n // Viewport\r\n var devicePixelRatio = DomManagement.IsWindowObjectExist() ? (window.devicePixelRatio || 1.0) : 1.0;\r\n var limitDeviceRatio = options.limitDeviceRatio || devicePixelRatio;\r\n this._hardwareScalingLevel = adaptToDeviceRatio ? 1.0 / Math.min(limitDeviceRatio, devicePixelRatio) : 1.0;\r\n this.resize();\r\n this._isStencilEnable = options.stencil ? true : false;\r\n this._initGLContext();\r\n // Prepare buffer pointers\r\n for (var i = 0; i < this._caps.maxVertexAttribs; i++) {\r\n this._currentBufferPointers[i] = new BufferPointer();\r\n }\r\n // Shader processor\r\n if (this.webGLVersion > 1) {\r\n this._shaderProcessor = new WebGL2ShaderProcessor();\r\n }\r\n // Detect if we are running on a faulty buggy OS.\r\n this._badOS = /iPad/i.test(navigator.userAgent) || /iPhone/i.test(navigator.userAgent);\r\n // Detect if we are running on a faulty buggy desktop OS.\r\n this._badDesktopOS = /^((?!chrome|android).)*safari/i.test(navigator.userAgent);\r\n this._creationOptions = options;\r\n console.log(\"Babylon.js v\" + ThinEngine.Version + \" - \" + this.description);\r\n }\r\n Object.defineProperty(ThinEngine, \"NpmPackage\", {\r\n /**\r\n * Returns the current npm package of the sdk\r\n */\r\n // Not mixed with Version for tooling purpose.\r\n get: function () {\r\n return \"babylonjs@4.1.0\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine, \"Version\", {\r\n /**\r\n * Returns the current version of the framework\r\n */\r\n get: function () {\r\n return \"4.1.0\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"description\", {\r\n /**\r\n * Returns a string describing the current engine\r\n */\r\n get: function () {\r\n var description = \"WebGL\" + this.webGLVersion;\r\n if (this._caps.parallelShaderCompile) {\r\n description += \" - Parallel shader compilation\";\r\n }\r\n return description;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine, \"ShadersRepository\", {\r\n /**\r\n * Gets or sets the relative url used to load shaders if using the engine in non-minified mode\r\n */\r\n get: function () {\r\n return Effect.ShadersRepository;\r\n },\r\n set: function (value) {\r\n Effect.ShadersRepository = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"supportsUniformBuffers\", {\r\n /**\r\n * Gets a boolean indicating that the engine supports uniform buffers\r\n * @see http://doc.babylonjs.com/features/webgl2#uniform-buffer-objets\r\n */\r\n get: function () {\r\n return this.webGLVersion > 1 && !this.disableUniformBuffers;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"_shouldUseHighPrecisionShader\", {\r\n /** @hidden */\r\n get: function () {\r\n return !!(this._caps.highPrecisionShaderSupported && this._highPrecisionShadersAllowed);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"needPOTTextures\", {\r\n /**\r\n * Gets a boolean indicating that only power of 2 textures are supported\r\n * Please note that you can still use non power of 2 textures but in this case the engine will forcefully convert them\r\n */\r\n get: function () {\r\n return this._webGLVersion < 2 || this.forcePOTTextures;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"doNotHandleContextLost\", {\r\n /**\r\n * Gets or sets a boolean indicating if resources should be retained to be able to handle context lost events\r\n * @see http://doc.babylonjs.com/how_to/optimizing_your_scene#handling-webgl-context-lost\r\n */\r\n get: function () {\r\n return this._doNotHandleContextLost;\r\n },\r\n set: function (value) {\r\n this._doNotHandleContextLost = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"_supportsHardwareTextureRescaling\", {\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"framebufferDimensionsObject\", {\r\n /**\r\n * sets the object from which width and height will be taken from when getting render width and height\r\n * Will fallback to the gl object\r\n * @param dimensions the framebuffer width and height that will be used.\r\n */\r\n set: function (dimensions) {\r\n this._framebufferDimensionsObject = dimensions;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"texturesSupported\", {\r\n /**\r\n * Gets the list of texture formats supported\r\n */\r\n get: function () {\r\n return this._texturesSupported;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"textureFormatInUse\", {\r\n /**\r\n * Gets the list of texture formats in use\r\n */\r\n get: function () {\r\n return this._textureFormatInUse;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"currentViewport\", {\r\n /**\r\n * Gets the current viewport\r\n */\r\n get: function () {\r\n return this._cachedViewport;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"emptyTexture\", {\r\n /**\r\n * Gets the default empty texture\r\n */\r\n get: function () {\r\n if (!this._emptyTexture) {\r\n this._emptyTexture = this.createRawTexture(new Uint8Array(4), 1, 1, 5, false, false, 1);\r\n }\r\n return this._emptyTexture;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"emptyTexture3D\", {\r\n /**\r\n * Gets the default empty 3D texture\r\n */\r\n get: function () {\r\n if (!this._emptyTexture3D) {\r\n this._emptyTexture3D = this.createRawTexture3D(new Uint8Array(4), 1, 1, 1, 5, false, false, 1);\r\n }\r\n return this._emptyTexture3D;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"emptyTexture2DArray\", {\r\n /**\r\n * Gets the default empty 2D array texture\r\n */\r\n get: function () {\r\n if (!this._emptyTexture2DArray) {\r\n this._emptyTexture2DArray = this.createRawTexture2DArray(new Uint8Array(4), 1, 1, 1, 5, false, false, 1);\r\n }\r\n return this._emptyTexture2DArray;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"emptyCubeTexture\", {\r\n /**\r\n * Gets the default empty cube texture\r\n */\r\n get: function () {\r\n if (!this._emptyCubeTexture) {\r\n var faceData = new Uint8Array(4);\r\n var cubeData = [faceData, faceData, faceData, faceData, faceData, faceData];\r\n this._emptyCubeTexture = this.createRawCubeTexture(cubeData, 1, 5, 0, false, false, 1);\r\n }\r\n return this._emptyCubeTexture;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n ThinEngine.prototype._rebuildInternalTextures = function () {\r\n var currentState = this._internalTexturesCache.slice(); // Do a copy because the rebuild will add proxies\r\n for (var _i = 0, currentState_1 = currentState; _i < currentState_1.length; _i++) {\r\n var internalTexture = currentState_1[_i];\r\n internalTexture._rebuild();\r\n }\r\n };\r\n ThinEngine.prototype._rebuildEffects = function () {\r\n for (var key in this._compiledEffects) {\r\n var effect = this._compiledEffects[key];\r\n effect._prepareEffect();\r\n }\r\n Effect.ResetCache();\r\n };\r\n /**\r\n * Gets a boolean indicating if all created effects are ready\r\n * @returns true if all effects are ready\r\n */\r\n ThinEngine.prototype.areAllEffectsReady = function () {\r\n for (var key in this._compiledEffects) {\r\n var effect = this._compiledEffects[key];\r\n if (!effect.isReady()) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n ThinEngine.prototype._rebuildBuffers = function () {\r\n // Uniforms\r\n for (var _i = 0, _a = this._uniformBuffers; _i < _a.length; _i++) {\r\n var uniformBuffer = _a[_i];\r\n uniformBuffer._rebuild();\r\n }\r\n };\r\n ThinEngine.prototype._initGLContext = function () {\r\n // Caps\r\n this._caps = {\r\n maxTexturesImageUnits: this._gl.getParameter(this._gl.MAX_TEXTURE_IMAGE_UNITS),\r\n maxCombinedTexturesImageUnits: this._gl.getParameter(this._gl.MAX_COMBINED_TEXTURE_IMAGE_UNITS),\r\n maxVertexTextureImageUnits: this._gl.getParameter(this._gl.MAX_VERTEX_TEXTURE_IMAGE_UNITS),\r\n maxTextureSize: this._gl.getParameter(this._gl.MAX_TEXTURE_SIZE),\r\n maxSamples: this._webGLVersion > 1 ? this._gl.getParameter(this._gl.MAX_SAMPLES) : 1,\r\n maxCubemapTextureSize: this._gl.getParameter(this._gl.MAX_CUBE_MAP_TEXTURE_SIZE),\r\n maxRenderTextureSize: this._gl.getParameter(this._gl.MAX_RENDERBUFFER_SIZE),\r\n maxVertexAttribs: this._gl.getParameter(this._gl.MAX_VERTEX_ATTRIBS),\r\n maxVaryingVectors: this._gl.getParameter(this._gl.MAX_VARYING_VECTORS),\r\n maxFragmentUniformVectors: this._gl.getParameter(this._gl.MAX_FRAGMENT_UNIFORM_VECTORS),\r\n maxVertexUniformVectors: this._gl.getParameter(this._gl.MAX_VERTEX_UNIFORM_VECTORS),\r\n parallelShaderCompile: this._gl.getExtension('KHR_parallel_shader_compile'),\r\n standardDerivatives: this._webGLVersion > 1 || (this._gl.getExtension('OES_standard_derivatives') !== null),\r\n maxAnisotropy: 1,\r\n astc: this._gl.getExtension('WEBGL_compressed_texture_astc') || this._gl.getExtension('WEBKIT_WEBGL_compressed_texture_astc'),\r\n s3tc: this._gl.getExtension('WEBGL_compressed_texture_s3tc') || this._gl.getExtension('WEBKIT_WEBGL_compressed_texture_s3tc'),\r\n pvrtc: this._gl.getExtension('WEBGL_compressed_texture_pvrtc') || this._gl.getExtension('WEBKIT_WEBGL_compressed_texture_pvrtc'),\r\n etc1: this._gl.getExtension('WEBGL_compressed_texture_etc1') || this._gl.getExtension('WEBKIT_WEBGL_compressed_texture_etc1'),\r\n etc2: this._gl.getExtension('WEBGL_compressed_texture_etc') || this._gl.getExtension('WEBKIT_WEBGL_compressed_texture_etc') ||\r\n this._gl.getExtension('WEBGL_compressed_texture_es3_0'),\r\n textureAnisotropicFilterExtension: this._gl.getExtension('EXT_texture_filter_anisotropic') || this._gl.getExtension('WEBKIT_EXT_texture_filter_anisotropic') || this._gl.getExtension('MOZ_EXT_texture_filter_anisotropic'),\r\n uintIndices: this._webGLVersion > 1 || this._gl.getExtension('OES_element_index_uint') !== null,\r\n fragmentDepthSupported: this._webGLVersion > 1 || this._gl.getExtension('EXT_frag_depth') !== null,\r\n highPrecisionShaderSupported: false,\r\n timerQuery: this._gl.getExtension('EXT_disjoint_timer_query_webgl2') || this._gl.getExtension(\"EXT_disjoint_timer_query\"),\r\n canUseTimestampForTimerQuery: false,\r\n drawBuffersExtension: false,\r\n maxMSAASamples: 1,\r\n colorBufferFloat: this._webGLVersion > 1 && this._gl.getExtension('EXT_color_buffer_float'),\r\n textureFloat: (this._webGLVersion > 1 || this._gl.getExtension('OES_texture_float')) ? true : false,\r\n textureHalfFloat: (this._webGLVersion > 1 || this._gl.getExtension('OES_texture_half_float')) ? true : false,\r\n textureHalfFloatRender: false,\r\n textureFloatLinearFiltering: false,\r\n textureFloatRender: false,\r\n textureHalfFloatLinearFiltering: false,\r\n vertexArrayObject: false,\r\n instancedArrays: false,\r\n textureLOD: (this._webGLVersion > 1 || this._gl.getExtension('EXT_shader_texture_lod')) ? true : false,\r\n blendMinMax: false,\r\n multiview: this._gl.getExtension('OVR_multiview2'),\r\n oculusMultiview: this._gl.getExtension('OCULUS_multiview'),\r\n depthTextureExtension: false\r\n };\r\n // Infos\r\n this._glVersion = this._gl.getParameter(this._gl.VERSION);\r\n var rendererInfo = this._gl.getExtension(\"WEBGL_debug_renderer_info\");\r\n if (rendererInfo != null) {\r\n this._glRenderer = this._gl.getParameter(rendererInfo.UNMASKED_RENDERER_WEBGL);\r\n this._glVendor = this._gl.getParameter(rendererInfo.UNMASKED_VENDOR_WEBGL);\r\n }\r\n if (!this._glVendor) {\r\n this._glVendor = \"Unknown vendor\";\r\n }\r\n if (!this._glRenderer) {\r\n this._glRenderer = \"Unknown renderer\";\r\n }\r\n // Constants\r\n this._gl.HALF_FLOAT_OES = 0x8D61; // Half floating-point type (16-bit).\r\n if (this._gl.RGBA16F !== 0x881A) {\r\n this._gl.RGBA16F = 0x881A; // RGBA 16-bit floating-point color-renderable internal sized format.\r\n }\r\n if (this._gl.RGBA32F !== 0x8814) {\r\n this._gl.RGBA32F = 0x8814; // RGBA 32-bit floating-point color-renderable internal sized format.\r\n }\r\n if (this._gl.DEPTH24_STENCIL8 !== 35056) {\r\n this._gl.DEPTH24_STENCIL8 = 35056;\r\n }\r\n // Extensions\r\n if (this._caps.timerQuery) {\r\n if (this._webGLVersion === 1) {\r\n this._gl.getQuery = this._caps.timerQuery.getQueryEXT.bind(this._caps.timerQuery);\r\n }\r\n this._caps.canUseTimestampForTimerQuery = this._gl.getQuery(this._caps.timerQuery.TIMESTAMP_EXT, this._caps.timerQuery.QUERY_COUNTER_BITS_EXT) > 0;\r\n }\r\n this._caps.maxAnisotropy = this._caps.textureAnisotropicFilterExtension ? this._gl.getParameter(this._caps.textureAnisotropicFilterExtension.MAX_TEXTURE_MAX_ANISOTROPY_EXT) : 0;\r\n this._caps.textureFloatLinearFiltering = this._caps.textureFloat && this._gl.getExtension('OES_texture_float_linear') ? true : false;\r\n this._caps.textureFloatRender = this._caps.textureFloat && this._canRenderToFloatFramebuffer() ? true : false;\r\n this._caps.textureHalfFloatLinearFiltering = (this._webGLVersion > 1 || (this._caps.textureHalfFloat && this._gl.getExtension('OES_texture_half_float_linear'))) ? true : false;\r\n // Checks if some of the format renders first to allow the use of webgl inspector.\r\n if (this._webGLVersion > 1) {\r\n this._gl.HALF_FLOAT_OES = 0x140B;\r\n }\r\n this._caps.textureHalfFloatRender = this._caps.textureHalfFloat && this._canRenderToHalfFloatFramebuffer();\r\n // Draw buffers\r\n if (this._webGLVersion > 1) {\r\n this._caps.drawBuffersExtension = true;\r\n this._caps.maxMSAASamples = this._gl.getParameter(this._gl.MAX_SAMPLES);\r\n }\r\n else {\r\n var drawBuffersExtension = this._gl.getExtension('WEBGL_draw_buffers');\r\n if (drawBuffersExtension !== null) {\r\n this._caps.drawBuffersExtension = true;\r\n this._gl.drawBuffers = drawBuffersExtension.drawBuffersWEBGL.bind(drawBuffersExtension);\r\n this._gl.DRAW_FRAMEBUFFER = this._gl.FRAMEBUFFER;\r\n for (var i = 0; i < 16; i++) {\r\n this._gl[\"COLOR_ATTACHMENT\" + i + \"_WEBGL\"] = drawBuffersExtension[\"COLOR_ATTACHMENT\" + i + \"_WEBGL\"];\r\n }\r\n }\r\n }\r\n // Depth Texture\r\n if (this._webGLVersion > 1) {\r\n this._caps.depthTextureExtension = true;\r\n }\r\n else {\r\n var depthTextureExtension = this._gl.getExtension('WEBGL_depth_texture');\r\n if (depthTextureExtension != null) {\r\n this._caps.depthTextureExtension = true;\r\n this._gl.UNSIGNED_INT_24_8 = depthTextureExtension.UNSIGNED_INT_24_8_WEBGL;\r\n }\r\n }\r\n // Vertex array object\r\n if (this.disableVertexArrayObjects) {\r\n this._caps.vertexArrayObject = false;\r\n }\r\n else if (this._webGLVersion > 1) {\r\n this._caps.vertexArrayObject = true;\r\n }\r\n else {\r\n var vertexArrayObjectExtension = this._gl.getExtension('OES_vertex_array_object');\r\n if (vertexArrayObjectExtension != null) {\r\n this._caps.vertexArrayObject = true;\r\n this._gl.createVertexArray = vertexArrayObjectExtension.createVertexArrayOES.bind(vertexArrayObjectExtension);\r\n this._gl.bindVertexArray = vertexArrayObjectExtension.bindVertexArrayOES.bind(vertexArrayObjectExtension);\r\n this._gl.deleteVertexArray = vertexArrayObjectExtension.deleteVertexArrayOES.bind(vertexArrayObjectExtension);\r\n }\r\n }\r\n // Instances count\r\n if (this._webGLVersion > 1) {\r\n this._caps.instancedArrays = true;\r\n }\r\n else {\r\n var instanceExtension = this._gl.getExtension('ANGLE_instanced_arrays');\r\n if (instanceExtension != null) {\r\n this._caps.instancedArrays = true;\r\n this._gl.drawArraysInstanced = instanceExtension.drawArraysInstancedANGLE.bind(instanceExtension);\r\n this._gl.drawElementsInstanced = instanceExtension.drawElementsInstancedANGLE.bind(instanceExtension);\r\n this._gl.vertexAttribDivisor = instanceExtension.vertexAttribDivisorANGLE.bind(instanceExtension);\r\n }\r\n else {\r\n this._caps.instancedArrays = false;\r\n }\r\n }\r\n // Intelligently add supported compressed formats in order to check for.\r\n // Check for ASTC support first as it is most powerful and to be very cross platform.\r\n // Next PVRTC & DXT, which are probably superior to ETC1/2.\r\n // Likely no hardware which supports both PVR & DXT, so order matters little.\r\n // ETC2 is newer and handles ETC1 (no alpha capability), so check for first.\r\n if (this._caps.astc) {\r\n this.texturesSupported.push('-astc.ktx');\r\n }\r\n if (this._caps.s3tc) {\r\n this.texturesSupported.push('-dxt.ktx');\r\n }\r\n if (this._caps.pvrtc) {\r\n this.texturesSupported.push('-pvrtc.ktx');\r\n }\r\n if (this._caps.etc2) {\r\n this.texturesSupported.push('-etc2.ktx');\r\n }\r\n if (this._caps.etc1) {\r\n this.texturesSupported.push('-etc1.ktx');\r\n }\r\n if (this._gl.getShaderPrecisionFormat) {\r\n var vertex_highp = this._gl.getShaderPrecisionFormat(this._gl.VERTEX_SHADER, this._gl.HIGH_FLOAT);\r\n var fragment_highp = this._gl.getShaderPrecisionFormat(this._gl.FRAGMENT_SHADER, this._gl.HIGH_FLOAT);\r\n if (vertex_highp && fragment_highp) {\r\n this._caps.highPrecisionShaderSupported = vertex_highp.precision !== 0 && fragment_highp.precision !== 0;\r\n }\r\n }\r\n if (this._webGLVersion > 1) {\r\n this._caps.blendMinMax = true;\r\n }\r\n else {\r\n var blendMinMaxExtension = this._gl.getExtension('EXT_blend_minmax');\r\n if (blendMinMaxExtension != null) {\r\n this._caps.blendMinMax = true;\r\n this._gl.MAX = blendMinMaxExtension.MAX_EXT;\r\n this._gl.MIN = blendMinMaxExtension.MIN_EXT;\r\n }\r\n }\r\n // Depth buffer\r\n this._depthCullingState.depthTest = true;\r\n this._depthCullingState.depthFunc = this._gl.LEQUAL;\r\n this._depthCullingState.depthMask = true;\r\n // Texture maps\r\n this._maxSimultaneousTextures = this._caps.maxCombinedTexturesImageUnits;\r\n for (var slot = 0; slot < this._maxSimultaneousTextures; slot++) {\r\n this._nextFreeTextureSlots.push(slot);\r\n }\r\n };\r\n Object.defineProperty(ThinEngine.prototype, \"webGLVersion\", {\r\n /**\r\n * Gets version of the current webGL context\r\n */\r\n get: function () {\r\n return this._webGLVersion;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets a string idenfifying the name of the class\r\n * @returns \"Engine\" string\r\n */\r\n ThinEngine.prototype.getClassName = function () {\r\n return \"ThinEngine\";\r\n };\r\n Object.defineProperty(ThinEngine.prototype, \"isStencilEnable\", {\r\n /**\r\n * Returns true if the stencil buffer has been enabled through the creation option of the context.\r\n */\r\n get: function () {\r\n return this._isStencilEnable;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n ThinEngine.prototype._prepareWorkingCanvas = function () {\r\n if (this._workingCanvas) {\r\n return;\r\n }\r\n this._workingCanvas = CanvasGenerator.CreateCanvas(1, 1);\r\n var context = this._workingCanvas.getContext(\"2d\");\r\n if (context) {\r\n this._workingContext = context;\r\n }\r\n };\r\n /**\r\n * Reset the texture cache to empty state\r\n */\r\n ThinEngine.prototype.resetTextureCache = function () {\r\n for (var key in this._boundTexturesCache) {\r\n if (!this._boundTexturesCache.hasOwnProperty(key)) {\r\n continue;\r\n }\r\n this._boundTexturesCache[key] = null;\r\n }\r\n this._currentTextureChannel = -1;\r\n };\r\n /**\r\n * Gets an object containing information about the current webGL context\r\n * @returns an object containing the vender, the renderer and the version of the current webGL context\r\n */\r\n ThinEngine.prototype.getGlInfo = function () {\r\n return {\r\n vendor: this._glVendor,\r\n renderer: this._glRenderer,\r\n version: this._glVersion\r\n };\r\n };\r\n /**\r\n * Defines the hardware scaling level.\r\n * By default the hardware scaling level is computed from the window device ratio.\r\n * if level = 1 then the engine will render at the exact resolution of the canvas. If level = 0.5 then the engine will render at twice the size of the canvas.\r\n * @param level defines the level to use\r\n */\r\n ThinEngine.prototype.setHardwareScalingLevel = function (level) {\r\n this._hardwareScalingLevel = level;\r\n this.resize();\r\n };\r\n /**\r\n * Gets the current hardware scaling level.\r\n * By default the hardware scaling level is computed from the window device ratio.\r\n * if level = 1 then the engine will render at the exact resolution of the canvas. If level = 0.5 then the engine will render at twice the size of the canvas.\r\n * @returns a number indicating the current hardware scaling level\r\n */\r\n ThinEngine.prototype.getHardwareScalingLevel = function () {\r\n return this._hardwareScalingLevel;\r\n };\r\n /**\r\n * Gets the list of loaded textures\r\n * @returns an array containing all loaded textures\r\n */\r\n ThinEngine.prototype.getLoadedTexturesCache = function () {\r\n return this._internalTexturesCache;\r\n };\r\n /**\r\n * Gets the object containing all engine capabilities\r\n * @returns the EngineCapabilities object\r\n */\r\n ThinEngine.prototype.getCaps = function () {\r\n return this._caps;\r\n };\r\n /**\r\n * stop executing a render loop function and remove it from the execution array\r\n * @param renderFunction defines the function to be removed. If not provided all functions will be removed.\r\n */\r\n ThinEngine.prototype.stopRenderLoop = function (renderFunction) {\r\n if (!renderFunction) {\r\n this._activeRenderLoops = [];\r\n return;\r\n }\r\n var index = this._activeRenderLoops.indexOf(renderFunction);\r\n if (index >= 0) {\r\n this._activeRenderLoops.splice(index, 1);\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._renderLoop = function () {\r\n if (!this._contextWasLost) {\r\n var shouldRender = true;\r\n if (!this.renderEvenInBackground && this._windowIsBackground) {\r\n shouldRender = false;\r\n }\r\n if (shouldRender) {\r\n // Start new frame\r\n this.beginFrame();\r\n for (var index = 0; index < this._activeRenderLoops.length; index++) {\r\n var renderFunction = this._activeRenderLoops[index];\r\n renderFunction();\r\n }\r\n // Present\r\n this.endFrame();\r\n }\r\n }\r\n if (this._activeRenderLoops.length > 0) {\r\n this._frameHandler = this._queueNewFrame(this._boundRenderFunction, this.getHostWindow());\r\n }\r\n else {\r\n this._renderingQueueLaunched = false;\r\n }\r\n };\r\n /**\r\n * Gets the HTML canvas attached with the current webGL context\r\n * @returns a HTML canvas\r\n */\r\n ThinEngine.prototype.getRenderingCanvas = function () {\r\n return this._renderingCanvas;\r\n };\r\n /**\r\n * Gets host window\r\n * @returns the host window object\r\n */\r\n ThinEngine.prototype.getHostWindow = function () {\r\n if (!DomManagement.IsWindowObjectExist()) {\r\n return null;\r\n }\r\n if (this._renderingCanvas && this._renderingCanvas.ownerDocument && this._renderingCanvas.ownerDocument.defaultView) {\r\n return this._renderingCanvas.ownerDocument.defaultView;\r\n }\r\n return window;\r\n };\r\n /**\r\n * Gets the current render width\r\n * @param useScreen defines if screen size must be used (or the current render target if any)\r\n * @returns a number defining the current render width\r\n */\r\n ThinEngine.prototype.getRenderWidth = function (useScreen) {\r\n if (useScreen === void 0) { useScreen = false; }\r\n if (!useScreen && this._currentRenderTarget) {\r\n return this._currentRenderTarget.width;\r\n }\r\n return this._framebufferDimensionsObject ? this._framebufferDimensionsObject.framebufferWidth : this._gl.drawingBufferWidth;\r\n };\r\n /**\r\n * Gets the current render height\r\n * @param useScreen defines if screen size must be used (or the current render target if any)\r\n * @returns a number defining the current render height\r\n */\r\n ThinEngine.prototype.getRenderHeight = function (useScreen) {\r\n if (useScreen === void 0) { useScreen = false; }\r\n if (!useScreen && this._currentRenderTarget) {\r\n return this._currentRenderTarget.height;\r\n }\r\n return this._framebufferDimensionsObject ? this._framebufferDimensionsObject.framebufferHeight : this._gl.drawingBufferHeight;\r\n };\r\n /**\r\n * Can be used to override the current requestAnimationFrame requester.\r\n * @hidden\r\n */\r\n ThinEngine.prototype._queueNewFrame = function (bindedRenderFunction, requester) {\r\n return ThinEngine.QueueNewFrame(bindedRenderFunction, requester);\r\n };\r\n /**\r\n * Register and execute a render loop. The engine can have more than one render function\r\n * @param renderFunction defines the function to continuously execute\r\n */\r\n ThinEngine.prototype.runRenderLoop = function (renderFunction) {\r\n if (this._activeRenderLoops.indexOf(renderFunction) !== -1) {\r\n return;\r\n }\r\n this._activeRenderLoops.push(renderFunction);\r\n if (!this._renderingQueueLaunched) {\r\n this._renderingQueueLaunched = true;\r\n this._boundRenderFunction = this._renderLoop.bind(this);\r\n this._frameHandler = this._queueNewFrame(this._boundRenderFunction, this.getHostWindow());\r\n }\r\n };\r\n /**\r\n * Clear the current render buffer or the current render target (if any is set up)\r\n * @param color defines the color to use\r\n * @param backBuffer defines if the back buffer must be cleared\r\n * @param depth defines if the depth buffer must be cleared\r\n * @param stencil defines if the stencil buffer must be cleared\r\n */\r\n ThinEngine.prototype.clear = function (color, backBuffer, depth, stencil) {\r\n if (stencil === void 0) { stencil = false; }\r\n this.applyStates();\r\n var mode = 0;\r\n if (backBuffer && color) {\r\n this._gl.clearColor(color.r, color.g, color.b, color.a !== undefined ? color.a : 1.0);\r\n mode |= this._gl.COLOR_BUFFER_BIT;\r\n }\r\n if (depth) {\r\n if (this.useReverseDepthBuffer) {\r\n this._depthCullingState.depthFunc = this._gl.GREATER;\r\n this._gl.clearDepth(0.0);\r\n }\r\n else {\r\n this._gl.clearDepth(1.0);\r\n }\r\n mode |= this._gl.DEPTH_BUFFER_BIT;\r\n }\r\n if (stencil) {\r\n this._gl.clearStencil(0);\r\n mode |= this._gl.STENCIL_BUFFER_BIT;\r\n }\r\n this._gl.clear(mode);\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._viewport = function (x, y, width, height) {\r\n if (x !== this._viewportCached.x ||\r\n y !== this._viewportCached.y ||\r\n width !== this._viewportCached.z ||\r\n height !== this._viewportCached.w) {\r\n this._viewportCached.x = x;\r\n this._viewportCached.y = y;\r\n this._viewportCached.z = width;\r\n this._viewportCached.w = height;\r\n this._gl.viewport(x, y, width, height);\r\n }\r\n };\r\n /**\r\n * Set the WebGL's viewport\r\n * @param viewport defines the viewport element to be used\r\n * @param requiredWidth defines the width required for rendering. If not provided the rendering canvas' width is used\r\n * @param requiredHeight defines the height required for rendering. If not provided the rendering canvas' height is used\r\n */\r\n ThinEngine.prototype.setViewport = function (viewport, requiredWidth, requiredHeight) {\r\n var width = requiredWidth || this.getRenderWidth();\r\n var height = requiredHeight || this.getRenderHeight();\r\n var x = viewport.x || 0;\r\n var y = viewport.y || 0;\r\n this._cachedViewport = viewport;\r\n this._viewport(x * width, y * height, width * viewport.width, height * viewport.height);\r\n };\r\n /**\r\n * Begin a new frame\r\n */\r\n ThinEngine.prototype.beginFrame = function () {\r\n };\r\n /**\r\n * Enf the current frame\r\n */\r\n ThinEngine.prototype.endFrame = function () {\r\n // Force a flush in case we are using a bad OS.\r\n if (this._badOS) {\r\n this.flushFramebuffer();\r\n }\r\n };\r\n /**\r\n * Resize the view according to the canvas' size\r\n */\r\n ThinEngine.prototype.resize = function () {\r\n var width;\r\n var height;\r\n if (DomManagement.IsWindowObjectExist()) {\r\n width = this._renderingCanvas ? this._renderingCanvas.clientWidth : window.innerWidth;\r\n height = this._renderingCanvas ? this._renderingCanvas.clientHeight : window.innerHeight;\r\n }\r\n else {\r\n width = this._renderingCanvas ? this._renderingCanvas.width : 100;\r\n height = this._renderingCanvas ? this._renderingCanvas.height : 100;\r\n }\r\n this.setSize(width / this._hardwareScalingLevel, height / this._hardwareScalingLevel);\r\n };\r\n /**\r\n * Force a specific size of the canvas\r\n * @param width defines the new canvas' width\r\n * @param height defines the new canvas' height\r\n */\r\n ThinEngine.prototype.setSize = function (width, height) {\r\n if (!this._renderingCanvas) {\r\n return;\r\n }\r\n width = width | 0;\r\n height = height | 0;\r\n if (this._renderingCanvas.width === width && this._renderingCanvas.height === height) {\r\n return;\r\n }\r\n this._renderingCanvas.width = width;\r\n this._renderingCanvas.height = height;\r\n };\r\n /**\r\n * Binds the frame buffer to the specified texture.\r\n * @param texture The texture to render to or null for the default canvas\r\n * @param faceIndex The face of the texture to render to in case of cube texture\r\n * @param requiredWidth The width of the target to render to\r\n * @param requiredHeight The height of the target to render to\r\n * @param forceFullscreenViewport Forces the viewport to be the entire texture/screen if true\r\n * @param lodLevel defines the lod level to bind to the frame buffer\r\n * @param layer defines the 2d array index to bind to frame buffer to\r\n */\r\n ThinEngine.prototype.bindFramebuffer = function (texture, faceIndex, requiredWidth, requiredHeight, forceFullscreenViewport, lodLevel, layer) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (lodLevel === void 0) { lodLevel = 0; }\r\n if (layer === void 0) { layer = 0; }\r\n if (this._currentRenderTarget) {\r\n this.unBindFramebuffer(this._currentRenderTarget);\r\n }\r\n this._currentRenderTarget = texture;\r\n this._bindUnboundFramebuffer(texture._MSAAFramebuffer ? texture._MSAAFramebuffer : texture._framebuffer);\r\n var gl = this._gl;\r\n if (texture.is2DArray) {\r\n gl.framebufferTextureLayer(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, texture._webGLTexture, lodLevel, layer);\r\n }\r\n else if (texture.isCube) {\r\n gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_CUBE_MAP_POSITIVE_X + faceIndex, texture._webGLTexture, lodLevel);\r\n }\r\n var depthStencilTexture = texture._depthStencilTexture;\r\n if (depthStencilTexture) {\r\n var attachment = (depthStencilTexture._generateStencilBuffer) ? gl.DEPTH_STENCIL_ATTACHMENT : gl.DEPTH_ATTACHMENT;\r\n if (texture.is2DArray) {\r\n gl.framebufferTextureLayer(gl.FRAMEBUFFER, attachment, depthStencilTexture._webGLTexture, lodLevel, layer);\r\n }\r\n else if (texture.isCube) {\r\n gl.framebufferTexture2D(gl.FRAMEBUFFER, attachment, gl.TEXTURE_CUBE_MAP_POSITIVE_X + faceIndex, depthStencilTexture._webGLTexture, lodLevel);\r\n }\r\n else {\r\n gl.framebufferTexture2D(gl.FRAMEBUFFER, attachment, gl.TEXTURE_2D, depthStencilTexture._webGLTexture, lodLevel);\r\n }\r\n }\r\n if (this._cachedViewport && !forceFullscreenViewport) {\r\n this.setViewport(this._cachedViewport, requiredWidth, requiredHeight);\r\n }\r\n else {\r\n if (!requiredWidth) {\r\n requiredWidth = texture.width;\r\n if (lodLevel) {\r\n requiredWidth = requiredWidth / Math.pow(2, lodLevel);\r\n }\r\n }\r\n if (!requiredHeight) {\r\n requiredHeight = texture.height;\r\n if (lodLevel) {\r\n requiredHeight = requiredHeight / Math.pow(2, lodLevel);\r\n }\r\n }\r\n this._viewport(0, 0, requiredWidth, requiredHeight);\r\n }\r\n this.wipeCaches();\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._bindUnboundFramebuffer = function (framebuffer) {\r\n if (this._currentFramebuffer !== framebuffer) {\r\n this._gl.bindFramebuffer(this._gl.FRAMEBUFFER, framebuffer);\r\n this._currentFramebuffer = framebuffer;\r\n }\r\n };\r\n /**\r\n * Unbind the current render target texture from the webGL context\r\n * @param texture defines the render target texture to unbind\r\n * @param disableGenerateMipMaps defines a boolean indicating that mipmaps must not be generated\r\n * @param onBeforeUnbind defines a function which will be called before the effective unbind\r\n */\r\n ThinEngine.prototype.unBindFramebuffer = function (texture, disableGenerateMipMaps, onBeforeUnbind) {\r\n if (disableGenerateMipMaps === void 0) { disableGenerateMipMaps = false; }\r\n this._currentRenderTarget = null;\r\n // If MSAA, we need to bitblt back to main texture\r\n var gl = this._gl;\r\n if (texture._MSAAFramebuffer) {\r\n gl.bindFramebuffer(gl.READ_FRAMEBUFFER, texture._MSAAFramebuffer);\r\n gl.bindFramebuffer(gl.DRAW_FRAMEBUFFER, texture._framebuffer);\r\n gl.blitFramebuffer(0, 0, texture.width, texture.height, 0, 0, texture.width, texture.height, gl.COLOR_BUFFER_BIT, gl.NEAREST);\r\n }\r\n if (texture.generateMipMaps && !disableGenerateMipMaps && !texture.isCube) {\r\n this._bindTextureDirectly(gl.TEXTURE_2D, texture, true);\r\n gl.generateMipmap(gl.TEXTURE_2D);\r\n this._bindTextureDirectly(gl.TEXTURE_2D, null);\r\n }\r\n if (onBeforeUnbind) {\r\n if (texture._MSAAFramebuffer) {\r\n // Bind the correct framebuffer\r\n this._bindUnboundFramebuffer(texture._framebuffer);\r\n }\r\n onBeforeUnbind();\r\n }\r\n this._bindUnboundFramebuffer(null);\r\n };\r\n /**\r\n * Force a webGL flush (ie. a flush of all waiting webGL commands)\r\n */\r\n ThinEngine.prototype.flushFramebuffer = function () {\r\n this._gl.flush();\r\n };\r\n /**\r\n * Unbind the current render target and bind the default framebuffer\r\n */\r\n ThinEngine.prototype.restoreDefaultFramebuffer = function () {\r\n if (this._currentRenderTarget) {\r\n this.unBindFramebuffer(this._currentRenderTarget);\r\n }\r\n else {\r\n this._bindUnboundFramebuffer(null);\r\n }\r\n if (this._cachedViewport) {\r\n this.setViewport(this._cachedViewport);\r\n }\r\n this.wipeCaches();\r\n };\r\n // VBOs\r\n /** @hidden */\r\n ThinEngine.prototype._resetVertexBufferBinding = function () {\r\n this.bindArrayBuffer(null);\r\n this._cachedVertexBuffers = null;\r\n };\r\n /**\r\n * Creates a vertex buffer\r\n * @param data the data for the vertex buffer\r\n * @returns the new WebGL static buffer\r\n */\r\n ThinEngine.prototype.createVertexBuffer = function (data) {\r\n return this._createVertexBuffer(data, this._gl.STATIC_DRAW);\r\n };\r\n ThinEngine.prototype._createVertexBuffer = function (data, usage) {\r\n var vbo = this._gl.createBuffer();\r\n if (!vbo) {\r\n throw new Error(\"Unable to create vertex buffer\");\r\n }\r\n var dataBuffer = new WebGLDataBuffer(vbo);\r\n this.bindArrayBuffer(dataBuffer);\r\n if (data instanceof Array) {\r\n this._gl.bufferData(this._gl.ARRAY_BUFFER, new Float32Array(data), this._gl.STATIC_DRAW);\r\n }\r\n else {\r\n this._gl.bufferData(this._gl.ARRAY_BUFFER, data, this._gl.STATIC_DRAW);\r\n }\r\n this._resetVertexBufferBinding();\r\n dataBuffer.references = 1;\r\n return dataBuffer;\r\n };\r\n /**\r\n * Creates a dynamic vertex buffer\r\n * @param data the data for the dynamic vertex buffer\r\n * @returns the new WebGL dynamic buffer\r\n */\r\n ThinEngine.prototype.createDynamicVertexBuffer = function (data) {\r\n return this._createVertexBuffer(data, this._gl.DYNAMIC_DRAW);\r\n };\r\n ThinEngine.prototype._resetIndexBufferBinding = function () {\r\n this.bindIndexBuffer(null);\r\n this._cachedIndexBuffer = null;\r\n };\r\n /**\r\n * Creates a new index buffer\r\n * @param indices defines the content of the index buffer\r\n * @param updatable defines if the index buffer must be updatable\r\n * @returns a new webGL buffer\r\n */\r\n ThinEngine.prototype.createIndexBuffer = function (indices, updatable) {\r\n var vbo = this._gl.createBuffer();\r\n var dataBuffer = new WebGLDataBuffer(vbo);\r\n if (!vbo) {\r\n throw new Error(\"Unable to create index buffer\");\r\n }\r\n this.bindIndexBuffer(dataBuffer);\r\n var data = this._normalizeIndexData(indices);\r\n this._gl.bufferData(this._gl.ELEMENT_ARRAY_BUFFER, data, updatable ? this._gl.DYNAMIC_DRAW : this._gl.STATIC_DRAW);\r\n this._resetIndexBufferBinding();\r\n dataBuffer.references = 1;\r\n dataBuffer.is32Bits = (data.BYTES_PER_ELEMENT === 4);\r\n return dataBuffer;\r\n };\r\n ThinEngine.prototype._normalizeIndexData = function (indices) {\r\n if (indices instanceof Uint16Array) {\r\n return indices;\r\n }\r\n // Check 32 bit support\r\n if (this._caps.uintIndices) {\r\n if (indices instanceof Uint32Array) {\r\n return indices;\r\n }\r\n else {\r\n // number[] or Int32Array, check if 32 bit is necessary\r\n for (var index = 0; index < indices.length; index++) {\r\n if (indices[index] >= 65535) {\r\n return new Uint32Array(indices);\r\n }\r\n }\r\n return new Uint16Array(indices);\r\n }\r\n }\r\n // No 32 bit support, force conversion to 16 bit (values greater 16 bit are lost)\r\n return new Uint16Array(indices);\r\n };\r\n /**\r\n * Bind a webGL buffer to the webGL context\r\n * @param buffer defines the buffer to bind\r\n */\r\n ThinEngine.prototype.bindArrayBuffer = function (buffer) {\r\n if (!this._vaoRecordInProgress) {\r\n this._unbindVertexArrayObject();\r\n }\r\n this.bindBuffer(buffer, this._gl.ARRAY_BUFFER);\r\n };\r\n /**\r\n * Bind a specific block at a given index in a specific shader program\r\n * @param pipelineContext defines the pipeline context to use\r\n * @param blockName defines the block name\r\n * @param index defines the index where to bind the block\r\n */\r\n ThinEngine.prototype.bindUniformBlock = function (pipelineContext, blockName, index) {\r\n var program = pipelineContext.program;\r\n var uniformLocation = this._gl.getUniformBlockIndex(program, blockName);\r\n this._gl.uniformBlockBinding(program, uniformLocation, index);\r\n };\r\n ThinEngine.prototype.bindIndexBuffer = function (buffer) {\r\n if (!this._vaoRecordInProgress) {\r\n this._unbindVertexArrayObject();\r\n }\r\n this.bindBuffer(buffer, this._gl.ELEMENT_ARRAY_BUFFER);\r\n };\r\n ThinEngine.prototype.bindBuffer = function (buffer, target) {\r\n if (this._vaoRecordInProgress || this._currentBoundBuffer[target] !== buffer) {\r\n this._gl.bindBuffer(target, buffer ? buffer.underlyingResource : null);\r\n this._currentBoundBuffer[target] = buffer;\r\n }\r\n };\r\n /**\r\n * update the bound buffer with the given data\r\n * @param data defines the data to update\r\n */\r\n ThinEngine.prototype.updateArrayBuffer = function (data) {\r\n this._gl.bufferSubData(this._gl.ARRAY_BUFFER, 0, data);\r\n };\r\n ThinEngine.prototype._vertexAttribPointer = function (buffer, indx, size, type, normalized, stride, offset) {\r\n var pointer = this._currentBufferPointers[indx];\r\n var changed = false;\r\n if (!pointer.active) {\r\n changed = true;\r\n pointer.active = true;\r\n pointer.index = indx;\r\n pointer.size = size;\r\n pointer.type = type;\r\n pointer.normalized = normalized;\r\n pointer.stride = stride;\r\n pointer.offset = offset;\r\n pointer.buffer = buffer;\r\n }\r\n else {\r\n if (pointer.buffer !== buffer) {\r\n pointer.buffer = buffer;\r\n changed = true;\r\n }\r\n if (pointer.size !== size) {\r\n pointer.size = size;\r\n changed = true;\r\n }\r\n if (pointer.type !== type) {\r\n pointer.type = type;\r\n changed = true;\r\n }\r\n if (pointer.normalized !== normalized) {\r\n pointer.normalized = normalized;\r\n changed = true;\r\n }\r\n if (pointer.stride !== stride) {\r\n pointer.stride = stride;\r\n changed = true;\r\n }\r\n if (pointer.offset !== offset) {\r\n pointer.offset = offset;\r\n changed = true;\r\n }\r\n }\r\n if (changed || this._vaoRecordInProgress) {\r\n this.bindArrayBuffer(buffer);\r\n this._gl.vertexAttribPointer(indx, size, type, normalized, stride, offset);\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._bindIndexBufferWithCache = function (indexBuffer) {\r\n if (indexBuffer == null) {\r\n return;\r\n }\r\n if (this._cachedIndexBuffer !== indexBuffer) {\r\n this._cachedIndexBuffer = indexBuffer;\r\n this.bindIndexBuffer(indexBuffer);\r\n this._uintIndicesCurrentlySet = indexBuffer.is32Bits;\r\n }\r\n };\r\n ThinEngine.prototype._bindVertexBuffersAttributes = function (vertexBuffers, effect) {\r\n var attributes = effect.getAttributesNames();\r\n if (!this._vaoRecordInProgress) {\r\n this._unbindVertexArrayObject();\r\n }\r\n this.unbindAllAttributes();\r\n for (var index = 0; index < attributes.length; index++) {\r\n var order = effect.getAttributeLocation(index);\r\n if (order >= 0) {\r\n var vertexBuffer = vertexBuffers[attributes[index]];\r\n if (!vertexBuffer) {\r\n continue;\r\n }\r\n this._gl.enableVertexAttribArray(order);\r\n if (!this._vaoRecordInProgress) {\r\n this._vertexAttribArraysEnabled[order] = true;\r\n }\r\n var buffer = vertexBuffer.getBuffer();\r\n if (buffer) {\r\n this._vertexAttribPointer(buffer, order, vertexBuffer.getSize(), vertexBuffer.type, vertexBuffer.normalized, vertexBuffer.byteStride, vertexBuffer.byteOffset);\r\n if (vertexBuffer.getIsInstanced()) {\r\n this._gl.vertexAttribDivisor(order, vertexBuffer.getInstanceDivisor());\r\n if (!this._vaoRecordInProgress) {\r\n this._currentInstanceLocations.push(order);\r\n this._currentInstanceBuffers.push(buffer);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Records a vertex array object\r\n * @see http://doc.babylonjs.com/features/webgl2#vertex-array-objects\r\n * @param vertexBuffers defines the list of vertex buffers to store\r\n * @param indexBuffer defines the index buffer to store\r\n * @param effect defines the effect to store\r\n * @returns the new vertex array object\r\n */\r\n ThinEngine.prototype.recordVertexArrayObject = function (vertexBuffers, indexBuffer, effect) {\r\n var vao = this._gl.createVertexArray();\r\n this._vaoRecordInProgress = true;\r\n this._gl.bindVertexArray(vao);\r\n this._mustWipeVertexAttributes = true;\r\n this._bindVertexBuffersAttributes(vertexBuffers, effect);\r\n this.bindIndexBuffer(indexBuffer);\r\n this._vaoRecordInProgress = false;\r\n this._gl.bindVertexArray(null);\r\n return vao;\r\n };\r\n /**\r\n * Bind a specific vertex array object\r\n * @see http://doc.babylonjs.com/features/webgl2#vertex-array-objects\r\n * @param vertexArrayObject defines the vertex array object to bind\r\n * @param indexBuffer defines the index buffer to bind\r\n */\r\n ThinEngine.prototype.bindVertexArrayObject = function (vertexArrayObject, indexBuffer) {\r\n if (this._cachedVertexArrayObject !== vertexArrayObject) {\r\n this._cachedVertexArrayObject = vertexArrayObject;\r\n this._gl.bindVertexArray(vertexArrayObject);\r\n this._cachedVertexBuffers = null;\r\n this._cachedIndexBuffer = null;\r\n this._uintIndicesCurrentlySet = indexBuffer != null && indexBuffer.is32Bits;\r\n this._mustWipeVertexAttributes = true;\r\n }\r\n };\r\n /**\r\n * Bind webGl buffers directly to the webGL context\r\n * @param vertexBuffer defines the vertex buffer to bind\r\n * @param indexBuffer defines the index buffer to bind\r\n * @param vertexDeclaration defines the vertex declaration to use with the vertex buffer\r\n * @param vertexStrideSize defines the vertex stride of the vertex buffer\r\n * @param effect defines the effect associated with the vertex buffer\r\n */\r\n ThinEngine.prototype.bindBuffersDirectly = function (vertexBuffer, indexBuffer, vertexDeclaration, vertexStrideSize, effect) {\r\n if (this._cachedVertexBuffers !== vertexBuffer || this._cachedEffectForVertexBuffers !== effect) {\r\n this._cachedVertexBuffers = vertexBuffer;\r\n this._cachedEffectForVertexBuffers = effect;\r\n var attributesCount = effect.getAttributesCount();\r\n this._unbindVertexArrayObject();\r\n this.unbindAllAttributes();\r\n var offset = 0;\r\n for (var index = 0; index < attributesCount; index++) {\r\n if (index < vertexDeclaration.length) {\r\n var order = effect.getAttributeLocation(index);\r\n if (order >= 0) {\r\n this._gl.enableVertexAttribArray(order);\r\n this._vertexAttribArraysEnabled[order] = true;\r\n this._vertexAttribPointer(vertexBuffer, order, vertexDeclaration[index], this._gl.FLOAT, false, vertexStrideSize, offset);\r\n }\r\n offset += vertexDeclaration[index] * 4;\r\n }\r\n }\r\n }\r\n this._bindIndexBufferWithCache(indexBuffer);\r\n };\r\n ThinEngine.prototype._unbindVertexArrayObject = function () {\r\n if (!this._cachedVertexArrayObject) {\r\n return;\r\n }\r\n this._cachedVertexArrayObject = null;\r\n this._gl.bindVertexArray(null);\r\n };\r\n /**\r\n * Bind a list of vertex buffers to the webGL context\r\n * @param vertexBuffers defines the list of vertex buffers to bind\r\n * @param indexBuffer defines the index buffer to bind\r\n * @param effect defines the effect associated with the vertex buffers\r\n */\r\n ThinEngine.prototype.bindBuffers = function (vertexBuffers, indexBuffer, effect) {\r\n if (this._cachedVertexBuffers !== vertexBuffers || this._cachedEffectForVertexBuffers !== effect) {\r\n this._cachedVertexBuffers = vertexBuffers;\r\n this._cachedEffectForVertexBuffers = effect;\r\n this._bindVertexBuffersAttributes(vertexBuffers, effect);\r\n }\r\n this._bindIndexBufferWithCache(indexBuffer);\r\n };\r\n /**\r\n * Unbind all instance attributes\r\n */\r\n ThinEngine.prototype.unbindInstanceAttributes = function () {\r\n var boundBuffer;\r\n for (var i = 0, ul = this._currentInstanceLocations.length; i < ul; i++) {\r\n var instancesBuffer = this._currentInstanceBuffers[i];\r\n if (boundBuffer != instancesBuffer && instancesBuffer.references) {\r\n boundBuffer = instancesBuffer;\r\n this.bindArrayBuffer(instancesBuffer);\r\n }\r\n var offsetLocation = this._currentInstanceLocations[i];\r\n this._gl.vertexAttribDivisor(offsetLocation, 0);\r\n }\r\n this._currentInstanceBuffers.length = 0;\r\n this._currentInstanceLocations.length = 0;\r\n };\r\n /**\r\n * Release and free the memory of a vertex array object\r\n * @param vao defines the vertex array object to delete\r\n */\r\n ThinEngine.prototype.releaseVertexArrayObject = function (vao) {\r\n this._gl.deleteVertexArray(vao);\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._releaseBuffer = function (buffer) {\r\n buffer.references--;\r\n if (buffer.references === 0) {\r\n this._deleteBuffer(buffer);\r\n return true;\r\n }\r\n return false;\r\n };\r\n ThinEngine.prototype._deleteBuffer = function (buffer) {\r\n this._gl.deleteBuffer(buffer.underlyingResource);\r\n };\r\n /**\r\n * Update the content of a webGL buffer used with instanciation and bind it to the webGL context\r\n * @param instancesBuffer defines the webGL buffer to update and bind\r\n * @param data defines the data to store in the buffer\r\n * @param offsetLocations defines the offsets or attributes information used to determine where data must be stored in the buffer\r\n */\r\n ThinEngine.prototype.updateAndBindInstancesBuffer = function (instancesBuffer, data, offsetLocations) {\r\n this.bindArrayBuffer(instancesBuffer);\r\n if (data) {\r\n this._gl.bufferSubData(this._gl.ARRAY_BUFFER, 0, data);\r\n }\r\n if (offsetLocations[0].index !== undefined) {\r\n this.bindInstancesBuffer(instancesBuffer, offsetLocations, true);\r\n }\r\n else {\r\n for (var index = 0; index < 4; index++) {\r\n var offsetLocation = offsetLocations[index];\r\n if (!this._vertexAttribArraysEnabled[offsetLocation]) {\r\n this._gl.enableVertexAttribArray(offsetLocation);\r\n this._vertexAttribArraysEnabled[offsetLocation] = true;\r\n }\r\n this._vertexAttribPointer(instancesBuffer, offsetLocation, 4, this._gl.FLOAT, false, 64, index * 16);\r\n this._gl.vertexAttribDivisor(offsetLocation, 1);\r\n this._currentInstanceLocations.push(offsetLocation);\r\n this._currentInstanceBuffers.push(instancesBuffer);\r\n }\r\n }\r\n };\r\n /**\r\n * Bind the content of a webGL buffer used with instantiation\r\n * @param instancesBuffer defines the webGL buffer to bind\r\n * @param attributesInfo defines the offsets or attributes information used to determine where data must be stored in the buffer\r\n * @param computeStride defines Whether to compute the strides from the info or use the default 0\r\n */\r\n ThinEngine.prototype.bindInstancesBuffer = function (instancesBuffer, attributesInfo, computeStride) {\r\n if (computeStride === void 0) { computeStride = true; }\r\n this.bindArrayBuffer(instancesBuffer);\r\n var stride = 0;\r\n if (computeStride) {\r\n for (var i = 0; i < attributesInfo.length; i++) {\r\n var ai = attributesInfo[i];\r\n stride += ai.attributeSize * 4;\r\n }\r\n }\r\n for (var i = 0; i < attributesInfo.length; i++) {\r\n var ai = attributesInfo[i];\r\n if (ai.index === undefined) {\r\n ai.index = this._currentEffect.getAttributeLocationByName(ai.attributeName);\r\n }\r\n if (!this._vertexAttribArraysEnabled[ai.index]) {\r\n this._gl.enableVertexAttribArray(ai.index);\r\n this._vertexAttribArraysEnabled[ai.index] = true;\r\n }\r\n this._vertexAttribPointer(instancesBuffer, ai.index, ai.attributeSize, ai.attributeType || this._gl.FLOAT, ai.normalized || false, stride, ai.offset);\r\n this._gl.vertexAttribDivisor(ai.index, ai.divisor === undefined ? 1 : ai.divisor);\r\n this._currentInstanceLocations.push(ai.index);\r\n this._currentInstanceBuffers.push(instancesBuffer);\r\n }\r\n };\r\n /**\r\n * Disable the instance attribute corresponding to the name in parameter\r\n * @param name defines the name of the attribute to disable\r\n */\r\n ThinEngine.prototype.disableInstanceAttributeByName = function (name) {\r\n if (!this._currentEffect) {\r\n return;\r\n }\r\n var attributeLocation = this._currentEffect.getAttributeLocationByName(name);\r\n this.disableInstanceAttribute(attributeLocation);\r\n };\r\n /**\r\n * Disable the instance attribute corresponding to the location in parameter\r\n * @param attributeLocation defines the attribute location of the attribute to disable\r\n */\r\n ThinEngine.prototype.disableInstanceAttribute = function (attributeLocation) {\r\n var shouldClean = false;\r\n var index;\r\n while ((index = this._currentInstanceLocations.indexOf(attributeLocation)) !== -1) {\r\n this._currentInstanceLocations.splice(index, 1);\r\n this._currentInstanceBuffers.splice(index, 1);\r\n shouldClean = true;\r\n index = this._currentInstanceLocations.indexOf(attributeLocation);\r\n }\r\n if (shouldClean) {\r\n this._gl.vertexAttribDivisor(attributeLocation, 0);\r\n this.disableAttributeByIndex(attributeLocation);\r\n }\r\n };\r\n /**\r\n * Disable the attribute corresponding to the location in parameter\r\n * @param attributeLocation defines the attribute location of the attribute to disable\r\n */\r\n ThinEngine.prototype.disableAttributeByIndex = function (attributeLocation) {\r\n this._gl.disableVertexAttribArray(attributeLocation);\r\n this._vertexAttribArraysEnabled[attributeLocation] = false;\r\n this._currentBufferPointers[attributeLocation].active = false;\r\n };\r\n /**\r\n * Send a draw order\r\n * @param useTriangles defines if triangles must be used to draw (else wireframe will be used)\r\n * @param indexStart defines the starting index\r\n * @param indexCount defines the number of index to draw\r\n * @param instancesCount defines the number of instances to draw (if instanciation is enabled)\r\n */\r\n ThinEngine.prototype.draw = function (useTriangles, indexStart, indexCount, instancesCount) {\r\n this.drawElementsType(useTriangles ? 0 : 1, indexStart, indexCount, instancesCount);\r\n };\r\n /**\r\n * Draw a list of points\r\n * @param verticesStart defines the index of first vertex to draw\r\n * @param verticesCount defines the count of vertices to draw\r\n * @param instancesCount defines the number of instances to draw (if instanciation is enabled)\r\n */\r\n ThinEngine.prototype.drawPointClouds = function (verticesStart, verticesCount, instancesCount) {\r\n this.drawArraysType(2, verticesStart, verticesCount, instancesCount);\r\n };\r\n /**\r\n * Draw a list of unindexed primitives\r\n * @param useTriangles defines if triangles must be used to draw (else wireframe will be used)\r\n * @param verticesStart defines the index of first vertex to draw\r\n * @param verticesCount defines the count of vertices to draw\r\n * @param instancesCount defines the number of instances to draw (if instanciation is enabled)\r\n */\r\n ThinEngine.prototype.drawUnIndexed = function (useTriangles, verticesStart, verticesCount, instancesCount) {\r\n this.drawArraysType(useTriangles ? 0 : 1, verticesStart, verticesCount, instancesCount);\r\n };\r\n /**\r\n * Draw a list of indexed primitives\r\n * @param fillMode defines the primitive to use\r\n * @param indexStart defines the starting index\r\n * @param indexCount defines the number of index to draw\r\n * @param instancesCount defines the number of instances to draw (if instanciation is enabled)\r\n */\r\n ThinEngine.prototype.drawElementsType = function (fillMode, indexStart, indexCount, instancesCount) {\r\n // Apply states\r\n this.applyStates();\r\n this._reportDrawCall();\r\n // Render\r\n var drawMode = this._drawMode(fillMode);\r\n var indexFormat = this._uintIndicesCurrentlySet ? this._gl.UNSIGNED_INT : this._gl.UNSIGNED_SHORT;\r\n var mult = this._uintIndicesCurrentlySet ? 4 : 2;\r\n if (instancesCount) {\r\n this._gl.drawElementsInstanced(drawMode, indexCount, indexFormat, indexStart * mult, instancesCount);\r\n }\r\n else {\r\n this._gl.drawElements(drawMode, indexCount, indexFormat, indexStart * mult);\r\n }\r\n };\r\n /**\r\n * Draw a list of unindexed primitives\r\n * @param fillMode defines the primitive to use\r\n * @param verticesStart defines the index of first vertex to draw\r\n * @param verticesCount defines the count of vertices to draw\r\n * @param instancesCount defines the number of instances to draw (if instanciation is enabled)\r\n */\r\n ThinEngine.prototype.drawArraysType = function (fillMode, verticesStart, verticesCount, instancesCount) {\r\n // Apply states\r\n this.applyStates();\r\n this._reportDrawCall();\r\n var drawMode = this._drawMode(fillMode);\r\n if (instancesCount) {\r\n this._gl.drawArraysInstanced(drawMode, verticesStart, verticesCount, instancesCount);\r\n }\r\n else {\r\n this._gl.drawArrays(drawMode, verticesStart, verticesCount);\r\n }\r\n };\r\n ThinEngine.prototype._drawMode = function (fillMode) {\r\n switch (fillMode) {\r\n // Triangle views\r\n case 0:\r\n return this._gl.TRIANGLES;\r\n case 2:\r\n return this._gl.POINTS;\r\n case 1:\r\n return this._gl.LINES;\r\n // Draw modes\r\n case 3:\r\n return this._gl.POINTS;\r\n case 4:\r\n return this._gl.LINES;\r\n case 5:\r\n return this._gl.LINE_LOOP;\r\n case 6:\r\n return this._gl.LINE_STRIP;\r\n case 7:\r\n return this._gl.TRIANGLE_STRIP;\r\n case 8:\r\n return this._gl.TRIANGLE_FAN;\r\n default:\r\n return this._gl.TRIANGLES;\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._reportDrawCall = function () {\r\n // Will be implemented by children\r\n };\r\n // Shaders\r\n /** @hidden */\r\n ThinEngine.prototype._releaseEffect = function (effect) {\r\n if (this._compiledEffects[effect._key]) {\r\n delete this._compiledEffects[effect._key];\r\n this._deletePipelineContext(effect.getPipelineContext());\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._deletePipelineContext = function (pipelineContext) {\r\n var webGLPipelineContext = pipelineContext;\r\n if (webGLPipelineContext && webGLPipelineContext.program) {\r\n webGLPipelineContext.program.__SPECTOR_rebuildProgram = null;\r\n this._gl.deleteProgram(webGLPipelineContext.program);\r\n }\r\n };\r\n /**\r\n * Create a new effect (used to store vertex/fragment shaders)\r\n * @param baseName defines the base name of the effect (The name of file without .fragment.fx or .vertex.fx)\r\n * @param attributesNamesOrOptions defines either a list of attribute names or an IEffectCreationOptions object\r\n * @param uniformsNamesOrEngine defines either a list of uniform names or the engine to use\r\n * @param samplers defines an array of string used to represent textures\r\n * @param defines defines the string containing the defines to use to compile the shaders\r\n * @param fallbacks defines the list of potential fallbacks to use if shader conmpilation fails\r\n * @param onCompiled defines a function to call when the effect creation is successful\r\n * @param onError defines a function to call when the effect creation has failed\r\n * @param indexParameters defines an object containing the index values to use to compile shaders (like the maximum number of simultaneous lights)\r\n * @returns the new Effect\r\n */\r\n ThinEngine.prototype.createEffect = function (baseName, attributesNamesOrOptions, uniformsNamesOrEngine, samplers, defines, fallbacks, onCompiled, onError, indexParameters) {\r\n var vertex = baseName.vertexElement || baseName.vertex || baseName;\r\n var fragment = baseName.fragmentElement || baseName.fragment || baseName;\r\n var name = vertex + \"+\" + fragment + \"@\" + (defines ? defines : attributesNamesOrOptions.defines);\r\n if (this._compiledEffects[name]) {\r\n var compiledEffect = this._compiledEffects[name];\r\n if (onCompiled && compiledEffect.isReady()) {\r\n onCompiled(compiledEffect);\r\n }\r\n return compiledEffect;\r\n }\r\n var effect = new Effect(baseName, attributesNamesOrOptions, uniformsNamesOrEngine, samplers, this, defines, fallbacks, onCompiled, onError, indexParameters);\r\n effect._key = name;\r\n this._compiledEffects[name] = effect;\r\n return effect;\r\n };\r\n ThinEngine._ConcatenateShader = function (source, defines, shaderVersion) {\r\n if (shaderVersion === void 0) { shaderVersion = \"\"; }\r\n return shaderVersion + (defines ? defines + \"\\n\" : \"\") + source;\r\n };\r\n ThinEngine.prototype._compileShader = function (source, type, defines, shaderVersion) {\r\n return this._compileRawShader(ThinEngine._ConcatenateShader(source, defines, shaderVersion), type);\r\n };\r\n ThinEngine.prototype._compileRawShader = function (source, type) {\r\n var gl = this._gl;\r\n var shader = gl.createShader(type === \"vertex\" ? gl.VERTEX_SHADER : gl.FRAGMENT_SHADER);\r\n if (!shader) {\r\n throw new Error(\"Something went wrong while compile the shader.\");\r\n }\r\n gl.shaderSource(shader, source);\r\n gl.compileShader(shader);\r\n return shader;\r\n };\r\n /**\r\n * Directly creates a webGL program\r\n * @param pipelineContext defines the pipeline context to attach to\r\n * @param vertexCode defines the vertex shader code to use\r\n * @param fragmentCode defines the fragment shader code to use\r\n * @param context defines the webGL context to use (if not set, the current one will be used)\r\n * @param transformFeedbackVaryings defines the list of transform feedback varyings to use\r\n * @returns the new webGL program\r\n */\r\n ThinEngine.prototype.createRawShaderProgram = function (pipelineContext, vertexCode, fragmentCode, context, transformFeedbackVaryings) {\r\n if (transformFeedbackVaryings === void 0) { transformFeedbackVaryings = null; }\r\n context = context || this._gl;\r\n var vertexShader = this._compileRawShader(vertexCode, \"vertex\");\r\n var fragmentShader = this._compileRawShader(fragmentCode, \"fragment\");\r\n return this._createShaderProgram(pipelineContext, vertexShader, fragmentShader, context, transformFeedbackVaryings);\r\n };\r\n /**\r\n * Creates a webGL program\r\n * @param pipelineContext defines the pipeline context to attach to\r\n * @param vertexCode defines the vertex shader code to use\r\n * @param fragmentCode defines the fragment shader code to use\r\n * @param defines defines the string containing the defines to use to compile the shaders\r\n * @param context defines the webGL context to use (if not set, the current one will be used)\r\n * @param transformFeedbackVaryings defines the list of transform feedback varyings to use\r\n * @returns the new webGL program\r\n */\r\n ThinEngine.prototype.createShaderProgram = function (pipelineContext, vertexCode, fragmentCode, defines, context, transformFeedbackVaryings) {\r\n if (transformFeedbackVaryings === void 0) { transformFeedbackVaryings = null; }\r\n context = context || this._gl;\r\n var shaderVersion = (this._webGLVersion > 1) ? \"#version 300 es\\n#define WEBGL2 \\n\" : \"\";\r\n var vertexShader = this._compileShader(vertexCode, \"vertex\", defines, shaderVersion);\r\n var fragmentShader = this._compileShader(fragmentCode, \"fragment\", defines, shaderVersion);\r\n return this._createShaderProgram(pipelineContext, vertexShader, fragmentShader, context, transformFeedbackVaryings);\r\n };\r\n /**\r\n * Creates a new pipeline context\r\n * @returns the new pipeline\r\n */\r\n ThinEngine.prototype.createPipelineContext = function () {\r\n var pipelineContext = new WebGLPipelineContext();\r\n pipelineContext.engine = this;\r\n if (this._caps.parallelShaderCompile) {\r\n pipelineContext.isParallelCompiled = true;\r\n }\r\n return pipelineContext;\r\n };\r\n ThinEngine.prototype._createShaderProgram = function (pipelineContext, vertexShader, fragmentShader, context, transformFeedbackVaryings) {\r\n if (transformFeedbackVaryings === void 0) { transformFeedbackVaryings = null; }\r\n var shaderProgram = context.createProgram();\r\n pipelineContext.program = shaderProgram;\r\n if (!shaderProgram) {\r\n throw new Error(\"Unable to create program\");\r\n }\r\n context.attachShader(shaderProgram, vertexShader);\r\n context.attachShader(shaderProgram, fragmentShader);\r\n context.linkProgram(shaderProgram);\r\n pipelineContext.context = context;\r\n pipelineContext.vertexShader = vertexShader;\r\n pipelineContext.fragmentShader = fragmentShader;\r\n if (!pipelineContext.isParallelCompiled) {\r\n this._finalizePipelineContext(pipelineContext);\r\n }\r\n return shaderProgram;\r\n };\r\n ThinEngine.prototype._finalizePipelineContext = function (pipelineContext) {\r\n var context = pipelineContext.context;\r\n var vertexShader = pipelineContext.vertexShader;\r\n var fragmentShader = pipelineContext.fragmentShader;\r\n var program = pipelineContext.program;\r\n var linked = context.getProgramParameter(program, context.LINK_STATUS);\r\n if (!linked) { // Get more info\r\n // Vertex\r\n if (!this._gl.getShaderParameter(vertexShader, this._gl.COMPILE_STATUS)) {\r\n var log = this._gl.getShaderInfoLog(vertexShader);\r\n if (log) {\r\n pipelineContext.vertexCompilationError = log;\r\n throw new Error(\"VERTEX SHADER \" + log);\r\n }\r\n }\r\n // Fragment\r\n if (!this._gl.getShaderParameter(fragmentShader, this._gl.COMPILE_STATUS)) {\r\n var log = this._gl.getShaderInfoLog(fragmentShader);\r\n if (log) {\r\n pipelineContext.fragmentCompilationError = log;\r\n throw new Error(\"FRAGMENT SHADER \" + log);\r\n }\r\n }\r\n var error = context.getProgramInfoLog(program);\r\n if (error) {\r\n pipelineContext.programLinkError = error;\r\n throw new Error(error);\r\n }\r\n }\r\n if (this.validateShaderPrograms) {\r\n context.validateProgram(program);\r\n var validated = context.getProgramParameter(program, context.VALIDATE_STATUS);\r\n if (!validated) {\r\n var error = context.getProgramInfoLog(program);\r\n if (error) {\r\n pipelineContext.programValidationError = error;\r\n throw new Error(error);\r\n }\r\n }\r\n }\r\n context.deleteShader(vertexShader);\r\n context.deleteShader(fragmentShader);\r\n pipelineContext.vertexShader = undefined;\r\n pipelineContext.fragmentShader = undefined;\r\n if (pipelineContext.onCompiled) {\r\n pipelineContext.onCompiled();\r\n pipelineContext.onCompiled = undefined;\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._preparePipelineContext = function (pipelineContext, vertexSourceCode, fragmentSourceCode, createAsRaw, rebuildRebind, defines, transformFeedbackVaryings) {\r\n var webGLRenderingState = pipelineContext;\r\n if (createAsRaw) {\r\n webGLRenderingState.program = this.createRawShaderProgram(webGLRenderingState, vertexSourceCode, fragmentSourceCode, undefined, transformFeedbackVaryings);\r\n }\r\n else {\r\n webGLRenderingState.program = this.createShaderProgram(webGLRenderingState, vertexSourceCode, fragmentSourceCode, defines, undefined, transformFeedbackVaryings);\r\n }\r\n webGLRenderingState.program.__SPECTOR_rebuildProgram = rebuildRebind;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._isRenderingStateCompiled = function (pipelineContext) {\r\n var webGLPipelineContext = pipelineContext;\r\n if (this._gl.getProgramParameter(webGLPipelineContext.program, this._caps.parallelShaderCompile.COMPLETION_STATUS_KHR)) {\r\n this._finalizePipelineContext(webGLPipelineContext);\r\n return true;\r\n }\r\n return false;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._executeWhenRenderingStateIsCompiled = function (pipelineContext, action) {\r\n var webGLPipelineContext = pipelineContext;\r\n if (!webGLPipelineContext.isParallelCompiled) {\r\n action();\r\n return;\r\n }\r\n var oldHandler = webGLPipelineContext.onCompiled;\r\n if (oldHandler) {\r\n webGLPipelineContext.onCompiled = function () {\r\n oldHandler();\r\n action();\r\n };\r\n }\r\n else {\r\n webGLPipelineContext.onCompiled = action;\r\n }\r\n };\r\n /**\r\n * Gets the list of webGL uniform locations associated with a specific program based on a list of uniform names\r\n * @param pipelineContext defines the pipeline context to use\r\n * @param uniformsNames defines the list of uniform names\r\n * @returns an array of webGL uniform locations\r\n */\r\n ThinEngine.prototype.getUniforms = function (pipelineContext, uniformsNames) {\r\n var results = new Array();\r\n var webGLPipelineContext = pipelineContext;\r\n for (var index = 0; index < uniformsNames.length; index++) {\r\n results.push(this._gl.getUniformLocation(webGLPipelineContext.program, uniformsNames[index]));\r\n }\r\n return results;\r\n };\r\n /**\r\n * Gets the lsit of active attributes for a given webGL program\r\n * @param pipelineContext defines the pipeline context to use\r\n * @param attributesNames defines the list of attribute names to get\r\n * @returns an array of indices indicating the offset of each attribute\r\n */\r\n ThinEngine.prototype.getAttributes = function (pipelineContext, attributesNames) {\r\n var results = [];\r\n var webGLPipelineContext = pipelineContext;\r\n for (var index = 0; index < attributesNames.length; index++) {\r\n try {\r\n results.push(this._gl.getAttribLocation(webGLPipelineContext.program, attributesNames[index]));\r\n }\r\n catch (e) {\r\n results.push(-1);\r\n }\r\n }\r\n return results;\r\n };\r\n /**\r\n * Activates an effect, mkaing it the current one (ie. the one used for rendering)\r\n * @param effect defines the effect to activate\r\n */\r\n ThinEngine.prototype.enableEffect = function (effect) {\r\n if (!effect || effect === this._currentEffect) {\r\n return;\r\n }\r\n // Use program\r\n this.bindSamplers(effect);\r\n this._currentEffect = effect;\r\n if (effect.onBind) {\r\n effect.onBind(effect);\r\n }\r\n if (effect._onBindObservable) {\r\n effect._onBindObservable.notifyObservers(effect);\r\n }\r\n };\r\n /**\r\n * Set the value of an uniform to a number (int)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param value defines the int number to store\r\n */\r\n ThinEngine.prototype.setInt = function (uniform, value) {\r\n if (!uniform) {\r\n return;\r\n }\r\n this._gl.uniform1i(uniform, value);\r\n };\r\n /**\r\n * Set the value of an uniform to an array of int32\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param array defines the array of int32 to store\r\n */\r\n ThinEngine.prototype.setIntArray = function (uniform, array) {\r\n if (!uniform) {\r\n return;\r\n }\r\n this._gl.uniform1iv(uniform, array);\r\n };\r\n /**\r\n * Set the value of an uniform to an array of int32 (stored as vec2)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param array defines the array of int32 to store\r\n */\r\n ThinEngine.prototype.setIntArray2 = function (uniform, array) {\r\n if (!uniform || array.length % 2 !== 0) {\r\n return;\r\n }\r\n this._gl.uniform2iv(uniform, array);\r\n };\r\n /**\r\n * Set the value of an uniform to an array of int32 (stored as vec3)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param array defines the array of int32 to store\r\n */\r\n ThinEngine.prototype.setIntArray3 = function (uniform, array) {\r\n if (!uniform || array.length % 3 !== 0) {\r\n return;\r\n }\r\n this._gl.uniform3iv(uniform, array);\r\n };\r\n /**\r\n * Set the value of an uniform to an array of int32 (stored as vec4)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param array defines the array of int32 to store\r\n */\r\n ThinEngine.prototype.setIntArray4 = function (uniform, array) {\r\n if (!uniform || array.length % 4 !== 0) {\r\n return;\r\n }\r\n this._gl.uniform4iv(uniform, array);\r\n };\r\n /**\r\n * Set the value of an uniform to an array of number\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param array defines the array of number to store\r\n */\r\n ThinEngine.prototype.setArray = function (uniform, array) {\r\n if (!uniform) {\r\n return;\r\n }\r\n this._gl.uniform1fv(uniform, array);\r\n };\r\n /**\r\n * Set the value of an uniform to an array of number (stored as vec2)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param array defines the array of number to store\r\n */\r\n ThinEngine.prototype.setArray2 = function (uniform, array) {\r\n if (!uniform || array.length % 2 !== 0) {\r\n return;\r\n }\r\n this._gl.uniform2fv(uniform, array);\r\n };\r\n /**\r\n * Set the value of an uniform to an array of number (stored as vec3)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param array defines the array of number to store\r\n */\r\n ThinEngine.prototype.setArray3 = function (uniform, array) {\r\n if (!uniform || array.length % 3 !== 0) {\r\n return;\r\n }\r\n this._gl.uniform3fv(uniform, array);\r\n };\r\n /**\r\n * Set the value of an uniform to an array of number (stored as vec4)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param array defines the array of number to store\r\n */\r\n ThinEngine.prototype.setArray4 = function (uniform, array) {\r\n if (!uniform || array.length % 4 !== 0) {\r\n return;\r\n }\r\n this._gl.uniform4fv(uniform, array);\r\n };\r\n /**\r\n * Set the value of an uniform to an array of float32 (stored as matrices)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param matrices defines the array of float32 to store\r\n */\r\n ThinEngine.prototype.setMatrices = function (uniform, matrices) {\r\n if (!uniform) {\r\n return;\r\n }\r\n this._gl.uniformMatrix4fv(uniform, false, matrices);\r\n };\r\n /**\r\n * Set the value of an uniform to a matrix (3x3)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param matrix defines the Float32Array representing the 3x3 matrix to store\r\n */\r\n ThinEngine.prototype.setMatrix3x3 = function (uniform, matrix) {\r\n if (!uniform) {\r\n return;\r\n }\r\n this._gl.uniformMatrix3fv(uniform, false, matrix);\r\n };\r\n /**\r\n * Set the value of an uniform to a matrix (2x2)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param matrix defines the Float32Array representing the 2x2 matrix to store\r\n */\r\n ThinEngine.prototype.setMatrix2x2 = function (uniform, matrix) {\r\n if (!uniform) {\r\n return;\r\n }\r\n this._gl.uniformMatrix2fv(uniform, false, matrix);\r\n };\r\n /**\r\n * Set the value of an uniform to a number (float)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param value defines the float number to store\r\n */\r\n ThinEngine.prototype.setFloat = function (uniform, value) {\r\n if (!uniform) {\r\n return;\r\n }\r\n this._gl.uniform1f(uniform, value);\r\n };\r\n /**\r\n * Set the value of an uniform to a vec2\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param x defines the 1st component of the value\r\n * @param y defines the 2nd component of the value\r\n */\r\n ThinEngine.prototype.setFloat2 = function (uniform, x, y) {\r\n if (!uniform) {\r\n return;\r\n }\r\n this._gl.uniform2f(uniform, x, y);\r\n };\r\n /**\r\n * Set the value of an uniform to a vec3\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param x defines the 1st component of the value\r\n * @param y defines the 2nd component of the value\r\n * @param z defines the 3rd component of the value\r\n */\r\n ThinEngine.prototype.setFloat3 = function (uniform, x, y, z) {\r\n if (!uniform) {\r\n return;\r\n }\r\n this._gl.uniform3f(uniform, x, y, z);\r\n };\r\n /**\r\n * Set the value of an uniform to a vec4\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param x defines the 1st component of the value\r\n * @param y defines the 2nd component of the value\r\n * @param z defines the 3rd component of the value\r\n * @param w defines the 4th component of the value\r\n */\r\n ThinEngine.prototype.setFloat4 = function (uniform, x, y, z, w) {\r\n if (!uniform) {\r\n return;\r\n }\r\n this._gl.uniform4f(uniform, x, y, z, w);\r\n };\r\n // States\r\n /**\r\n * Apply all cached states (depth, culling, stencil and alpha)\r\n */\r\n ThinEngine.prototype.applyStates = function () {\r\n this._depthCullingState.apply(this._gl);\r\n this._stencilState.apply(this._gl);\r\n this._alphaState.apply(this._gl);\r\n if (this._colorWriteChanged) {\r\n this._colorWriteChanged = false;\r\n var enable = this._colorWrite;\r\n this._gl.colorMask(enable, enable, enable, enable);\r\n }\r\n };\r\n /**\r\n * Enable or disable color writing\r\n * @param enable defines the state to set\r\n */\r\n ThinEngine.prototype.setColorWrite = function (enable) {\r\n if (enable !== this._colorWrite) {\r\n this._colorWriteChanged = true;\r\n this._colorWrite = enable;\r\n }\r\n };\r\n /**\r\n * Gets a boolean indicating if color writing is enabled\r\n * @returns the current color writing state\r\n */\r\n ThinEngine.prototype.getColorWrite = function () {\r\n return this._colorWrite;\r\n };\r\n Object.defineProperty(ThinEngine.prototype, \"depthCullingState\", {\r\n /**\r\n * Gets the depth culling state manager\r\n */\r\n get: function () {\r\n return this._depthCullingState;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"alphaState\", {\r\n /**\r\n * Gets the alpha state manager\r\n */\r\n get: function () {\r\n return this._alphaState;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"stencilState\", {\r\n /**\r\n * Gets the stencil state manager\r\n */\r\n get: function () {\r\n return this._stencilState;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n // Textures\r\n /**\r\n * Clears the list of texture accessible through engine.\r\n * This can help preventing texture load conflict due to name collision.\r\n */\r\n ThinEngine.prototype.clearInternalTexturesCache = function () {\r\n this._internalTexturesCache = [];\r\n };\r\n /**\r\n * Force the entire cache to be cleared\r\n * You should not have to use this function unless your engine needs to share the webGL context with another engine\r\n * @param bruteForce defines a boolean to force clearing ALL caches (including stencil, detoh and alpha states)\r\n */\r\n ThinEngine.prototype.wipeCaches = function (bruteForce) {\r\n if (this.preventCacheWipeBetweenFrames && !bruteForce) {\r\n return;\r\n }\r\n this._currentEffect = null;\r\n this._viewportCached.x = 0;\r\n this._viewportCached.y = 0;\r\n this._viewportCached.z = 0;\r\n this._viewportCached.w = 0;\r\n // Done before in case we clean the attributes\r\n this._unbindVertexArrayObject();\r\n if (bruteForce) {\r\n this._currentProgram = null;\r\n this.resetTextureCache();\r\n this._stencilState.reset();\r\n this._depthCullingState.reset();\r\n this._depthCullingState.depthFunc = this._gl.LEQUAL;\r\n this._alphaState.reset();\r\n this._alphaMode = 1;\r\n this._alphaEquation = 0;\r\n this._colorWrite = true;\r\n this._colorWriteChanged = true;\r\n this._unpackFlipYCached = null;\r\n this._gl.pixelStorei(this._gl.UNPACK_COLORSPACE_CONVERSION_WEBGL, this._gl.NONE);\r\n this._gl.pixelStorei(this._gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, 0);\r\n this._mustWipeVertexAttributes = true;\r\n this.unbindAllAttributes();\r\n }\r\n this._resetVertexBufferBinding();\r\n this._cachedIndexBuffer = null;\r\n this._cachedEffectForVertexBuffers = null;\r\n this.bindIndexBuffer(null);\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._getSamplingParameters = function (samplingMode, generateMipMaps) {\r\n var gl = this._gl;\r\n var magFilter = gl.NEAREST;\r\n var minFilter = gl.NEAREST;\r\n switch (samplingMode) {\r\n case 11:\r\n magFilter = gl.LINEAR;\r\n if (generateMipMaps) {\r\n minFilter = gl.LINEAR_MIPMAP_NEAREST;\r\n }\r\n else {\r\n minFilter = gl.LINEAR;\r\n }\r\n break;\r\n case 3:\r\n magFilter = gl.LINEAR;\r\n if (generateMipMaps) {\r\n minFilter = gl.LINEAR_MIPMAP_LINEAR;\r\n }\r\n else {\r\n minFilter = gl.LINEAR;\r\n }\r\n break;\r\n case 8:\r\n magFilter = gl.NEAREST;\r\n if (generateMipMaps) {\r\n minFilter = gl.NEAREST_MIPMAP_LINEAR;\r\n }\r\n else {\r\n minFilter = gl.NEAREST;\r\n }\r\n break;\r\n case 4:\r\n magFilter = gl.NEAREST;\r\n if (generateMipMaps) {\r\n minFilter = gl.NEAREST_MIPMAP_NEAREST;\r\n }\r\n else {\r\n minFilter = gl.NEAREST;\r\n }\r\n break;\r\n case 5:\r\n magFilter = gl.NEAREST;\r\n if (generateMipMaps) {\r\n minFilter = gl.LINEAR_MIPMAP_NEAREST;\r\n }\r\n else {\r\n minFilter = gl.LINEAR;\r\n }\r\n break;\r\n case 6:\r\n magFilter = gl.NEAREST;\r\n if (generateMipMaps) {\r\n minFilter = gl.LINEAR_MIPMAP_LINEAR;\r\n }\r\n else {\r\n minFilter = gl.LINEAR;\r\n }\r\n break;\r\n case 7:\r\n magFilter = gl.NEAREST;\r\n minFilter = gl.LINEAR;\r\n break;\r\n case 1:\r\n magFilter = gl.NEAREST;\r\n minFilter = gl.NEAREST;\r\n break;\r\n case 9:\r\n magFilter = gl.LINEAR;\r\n if (generateMipMaps) {\r\n minFilter = gl.NEAREST_MIPMAP_NEAREST;\r\n }\r\n else {\r\n minFilter = gl.NEAREST;\r\n }\r\n break;\r\n case 10:\r\n magFilter = gl.LINEAR;\r\n if (generateMipMaps) {\r\n minFilter = gl.NEAREST_MIPMAP_LINEAR;\r\n }\r\n else {\r\n minFilter = gl.NEAREST;\r\n }\r\n break;\r\n case 2:\r\n magFilter = gl.LINEAR;\r\n minFilter = gl.LINEAR;\r\n break;\r\n case 12:\r\n magFilter = gl.LINEAR;\r\n minFilter = gl.NEAREST;\r\n break;\r\n }\r\n return {\r\n min: minFilter,\r\n mag: magFilter\r\n };\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._createTexture = function () {\r\n var texture = this._gl.createTexture();\r\n if (!texture) {\r\n throw new Error(\"Unable to create texture\");\r\n }\r\n return texture;\r\n };\r\n /**\r\n * Usually called from Texture.ts.\r\n * Passed information to create a WebGLTexture\r\n * @param urlArg defines a value which contains one of the following:\r\n * * A conventional http URL, e.g. 'http://...' or 'file://...'\r\n * * A base64 string of in-line texture data, e.g. '...'\r\n * * An indicator that data being passed using the buffer parameter, e.g. 'data:mytexture.jpg'\r\n * @param noMipmap defines a boolean indicating that no mipmaps shall be generated. Ignored for compressed textures. They must be in the file\r\n * @param invertY when true, image is flipped when loaded. You probably want true. Certain compressed textures may invert this if their default is inverted (eg. ktx)\r\n * @param scene needed for loading to the correct scene\r\n * @param samplingMode mode with should be used sample / access the texture (Default: Texture.TRILINEAR_SAMPLINGMODE)\r\n * @param onLoad optional callback to be called upon successful completion\r\n * @param onError optional callback to be called upon failure\r\n * @param buffer a source of a file previously fetched as either a base64 string, an ArrayBuffer (compressed or image format), HTMLImageElement (image format), or a Blob\r\n * @param fallback an internal argument in case the function must be called again, due to etc1 not having alpha capabilities\r\n * @param format internal format. Default: RGB when extension is '.jpg' else RGBA. Ignored for compressed textures\r\n * @param forcedExtension defines the extension to use to pick the right loader\r\n * @param mimeType defines an optional mime type\r\n * @returns a InternalTexture for assignment back into BABYLON.Texture\r\n */\r\n ThinEngine.prototype.createTexture = function (urlArg, noMipmap, invertY, scene, samplingMode, onLoad, onError, buffer, fallback, format, forcedExtension, mimeType) {\r\n var _this = this;\r\n if (samplingMode === void 0) { samplingMode = 3; }\r\n if (onLoad === void 0) { onLoad = null; }\r\n if (onError === void 0) { onError = null; }\r\n if (buffer === void 0) { buffer = null; }\r\n if (fallback === void 0) { fallback = null; }\r\n if (format === void 0) { format = null; }\r\n if (forcedExtension === void 0) { forcedExtension = null; }\r\n var url = String(urlArg); // assign a new string, so that the original is still available in case of fallback\r\n var fromData = url.substr(0, 5) === \"data:\";\r\n var fromBlob = url.substr(0, 5) === \"blob:\";\r\n var isBase64 = fromData && url.indexOf(\";base64,\") !== -1;\r\n var texture = fallback ? fallback : new InternalTexture(this, InternalTextureSource.Url);\r\n // establish the file extension, if possible\r\n var lastDot = url.lastIndexOf('.');\r\n var extension = forcedExtension ? forcedExtension : (lastDot > -1 ? url.substring(lastDot).toLowerCase() : \"\");\r\n var loader = null;\r\n for (var _i = 0, _a = ThinEngine._TextureLoaders; _i < _a.length; _i++) {\r\n var availableLoader = _a[_i];\r\n if (availableLoader.canLoad(extension)) {\r\n loader = availableLoader;\r\n break;\r\n }\r\n }\r\n if (scene) {\r\n scene._addPendingData(texture);\r\n }\r\n texture.url = url;\r\n texture.generateMipMaps = !noMipmap;\r\n texture.samplingMode = samplingMode;\r\n texture.invertY = invertY;\r\n if (!this._doNotHandleContextLost) {\r\n // Keep a link to the buffer only if we plan to handle context lost\r\n texture._buffer = buffer;\r\n }\r\n var onLoadObserver = null;\r\n if (onLoad && !fallback) {\r\n onLoadObserver = texture.onLoadedObservable.add(onLoad);\r\n }\r\n if (!fallback) {\r\n this._internalTexturesCache.push(texture);\r\n }\r\n var onInternalError = function (message, exception) {\r\n if (scene) {\r\n scene._removePendingData(texture);\r\n }\r\n if (onLoadObserver) {\r\n texture.onLoadedObservable.remove(onLoadObserver);\r\n }\r\n if (EngineStore.UseFallbackTexture) {\r\n _this.createTexture(EngineStore.FallbackTexture, noMipmap, texture.invertY, scene, samplingMode, null, onError, buffer, texture);\r\n return;\r\n }\r\n if (onError) {\r\n onError(message || \"Unknown error\", exception);\r\n }\r\n };\r\n // processing for non-image formats\r\n if (loader) {\r\n var callback = function (data) {\r\n loader.loadData(data, texture, function (width, height, loadMipmap, isCompressed, done, loadFailed) {\r\n if (loadFailed) {\r\n onInternalError(\"TextureLoader failed to load data\");\r\n }\r\n else {\r\n _this._prepareWebGLTexture(texture, scene, width, height, texture.invertY, !loadMipmap, isCompressed, function () {\r\n done();\r\n return false;\r\n }, samplingMode);\r\n }\r\n });\r\n };\r\n if (!buffer) {\r\n this._loadFile(url, function (data) { return callback(new Uint8Array(data)); }, undefined, scene ? scene.offlineProvider : undefined, true, function (request, exception) {\r\n onInternalError(\"Unable to load \" + (request ? request.responseURL : url, exception));\r\n });\r\n }\r\n else {\r\n if (buffer instanceof ArrayBuffer) {\r\n callback(new Uint8Array(buffer));\r\n }\r\n else if (ArrayBuffer.isView(buffer)) {\r\n callback(buffer);\r\n }\r\n else {\r\n if (onError) {\r\n onError(\"Unable to load: only ArrayBuffer or ArrayBufferView is supported\", null);\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n var onload = function (img) {\r\n if (fromBlob && !_this._doNotHandleContextLost) {\r\n // We need to store the image if we need to rebuild the texture\r\n // in case of a webgl context lost\r\n texture._buffer = img;\r\n }\r\n _this._prepareWebGLTexture(texture, scene, img.width, img.height, texture.invertY, noMipmap, false, function (potWidth, potHeight, continuationCallback) {\r\n var gl = _this._gl;\r\n var isPot = (img.width === potWidth && img.height === potHeight);\r\n var internalFormat = format ? _this._getInternalFormat(format) : ((extension === \".jpg\") ? gl.RGB : gl.RGBA);\r\n if (isPot) {\r\n gl.texImage2D(gl.TEXTURE_2D, 0, internalFormat, internalFormat, gl.UNSIGNED_BYTE, img);\r\n return false;\r\n }\r\n var maxTextureSize = _this._caps.maxTextureSize;\r\n if (img.width > maxTextureSize || img.height > maxTextureSize || !_this._supportsHardwareTextureRescaling) {\r\n _this._prepareWorkingCanvas();\r\n if (!_this._workingCanvas || !_this._workingContext) {\r\n return false;\r\n }\r\n _this._workingCanvas.width = potWidth;\r\n _this._workingCanvas.height = potHeight;\r\n _this._workingContext.drawImage(img, 0, 0, img.width, img.height, 0, 0, potWidth, potHeight);\r\n gl.texImage2D(gl.TEXTURE_2D, 0, internalFormat, internalFormat, gl.UNSIGNED_BYTE, _this._workingCanvas);\r\n texture.width = potWidth;\r\n texture.height = potHeight;\r\n return false;\r\n }\r\n else {\r\n // Using shaders when possible to rescale because canvas.drawImage is lossy\r\n var source_1 = new InternalTexture(_this, InternalTextureSource.Temp);\r\n _this._bindTextureDirectly(gl.TEXTURE_2D, source_1, true);\r\n gl.texImage2D(gl.TEXTURE_2D, 0, internalFormat, internalFormat, gl.UNSIGNED_BYTE, img);\r\n _this._rescaleTexture(source_1, texture, scene, internalFormat, function () {\r\n _this._releaseTexture(source_1);\r\n _this._bindTextureDirectly(gl.TEXTURE_2D, texture, true);\r\n continuationCallback();\r\n });\r\n }\r\n return true;\r\n }, samplingMode);\r\n };\r\n if (!fromData || isBase64) {\r\n if (buffer && (buffer.decoding || buffer.close)) {\r\n onload(buffer);\r\n }\r\n else {\r\n ThinEngine._FileToolsLoadImage(url, onload, onInternalError, scene ? scene.offlineProvider : null, mimeType);\r\n }\r\n }\r\n else if (typeof buffer === \"string\" || buffer instanceof ArrayBuffer || ArrayBuffer.isView(buffer) || buffer instanceof Blob) {\r\n ThinEngine._FileToolsLoadImage(buffer, onload, onInternalError, scene ? scene.offlineProvider : null, mimeType);\r\n }\r\n else if (buffer) {\r\n onload(buffer);\r\n }\r\n }\r\n return texture;\r\n };\r\n /**\r\n * Loads an image as an HTMLImageElement.\r\n * @param input url string, ArrayBuffer, or Blob to load\r\n * @param onLoad callback called when the image successfully loads\r\n * @param onError callback called when the image fails to load\r\n * @param offlineProvider offline provider for caching\r\n * @param mimeType optional mime type\r\n * @returns the HTMLImageElement of the loaded image\r\n * @hidden\r\n */\r\n ThinEngine._FileToolsLoadImage = function (input, onLoad, onError, offlineProvider, mimeType) {\r\n throw _DevTools.WarnImport(\"FileTools\");\r\n };\r\n /**\r\n * @hidden\r\n */\r\n ThinEngine.prototype._rescaleTexture = function (source, destination, scene, internalFormat, onComplete) {\r\n };\r\n /**\r\n * Creates a raw texture\r\n * @param data defines the data to store in the texture\r\n * @param width defines the width of the texture\r\n * @param height defines the height of the texture\r\n * @param format defines the format of the data\r\n * @param generateMipMaps defines if the engine should generate the mip levels\r\n * @param invertY defines if data must be stored with Y axis inverted\r\n * @param samplingMode defines the required sampling mode (Texture.NEAREST_SAMPLINGMODE by default)\r\n * @param compression defines the compression used (null by default)\r\n * @param type defines the type fo the data (Engine.TEXTURETYPE_UNSIGNED_INT by default)\r\n * @returns the raw texture inside an InternalTexture\r\n */\r\n ThinEngine.prototype.createRawTexture = function (data, width, height, format, generateMipMaps, invertY, samplingMode, compression, type) {\r\n if (compression === void 0) { compression = null; }\r\n if (type === void 0) { type = 0; }\r\n throw _DevTools.WarnImport(\"Engine.RawTexture\");\r\n };\r\n /**\r\n * Creates a new raw cube texture\r\n * @param data defines the array of data to use to create each face\r\n * @param size defines the size of the textures\r\n * @param format defines the format of the data\r\n * @param type defines the type of the data (like Engine.TEXTURETYPE_UNSIGNED_INT)\r\n * @param generateMipMaps defines if the engine should generate the mip levels\r\n * @param invertY defines if data must be stored with Y axis inverted\r\n * @param samplingMode defines the required sampling mode (like Texture.NEAREST_SAMPLINGMODE)\r\n * @param compression defines the compression used (null by default)\r\n * @returns the cube texture as an InternalTexture\r\n */\r\n ThinEngine.prototype.createRawCubeTexture = function (data, size, format, type, generateMipMaps, invertY, samplingMode, compression) {\r\n if (compression === void 0) { compression = null; }\r\n throw _DevTools.WarnImport(\"Engine.RawTexture\");\r\n };\r\n /**\r\n * Creates a new raw 3D texture\r\n * @param data defines the data used to create the texture\r\n * @param width defines the width of the texture\r\n * @param height defines the height of the texture\r\n * @param depth defines the depth of the texture\r\n * @param format defines the format of the texture\r\n * @param generateMipMaps defines if the engine must generate mip levels\r\n * @param invertY defines if data must be stored with Y axis inverted\r\n * @param samplingMode defines the required sampling mode (like Texture.NEAREST_SAMPLINGMODE)\r\n * @param compression defines the compressed used (can be null)\r\n * @param textureType defines the compressed used (can be null)\r\n * @returns a new raw 3D texture (stored in an InternalTexture)\r\n */\r\n ThinEngine.prototype.createRawTexture3D = function (data, width, height, depth, format, generateMipMaps, invertY, samplingMode, compression, textureType) {\r\n if (compression === void 0) { compression = null; }\r\n if (textureType === void 0) { textureType = 0; }\r\n throw _DevTools.WarnImport(\"Engine.RawTexture\");\r\n };\r\n /**\r\n * Creates a new raw 2D array texture\r\n * @param data defines the data used to create the texture\r\n * @param width defines the width of the texture\r\n * @param height defines the height of the texture\r\n * @param depth defines the number of layers of the texture\r\n * @param format defines the format of the texture\r\n * @param generateMipMaps defines if the engine must generate mip levels\r\n * @param invertY defines if data must be stored with Y axis inverted\r\n * @param samplingMode defines the required sampling mode (like Texture.NEAREST_SAMPLINGMODE)\r\n * @param compression defines the compressed used (can be null)\r\n * @param textureType defines the compressed used (can be null)\r\n * @returns a new raw 2D array texture (stored in an InternalTexture)\r\n */\r\n ThinEngine.prototype.createRawTexture2DArray = function (data, width, height, depth, format, generateMipMaps, invertY, samplingMode, compression, textureType) {\r\n if (compression === void 0) { compression = null; }\r\n if (textureType === void 0) { textureType = 0; }\r\n throw _DevTools.WarnImport(\"Engine.RawTexture\");\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._unpackFlipY = function (value) {\r\n if (this._unpackFlipYCached !== value) {\r\n this._gl.pixelStorei(this._gl.UNPACK_FLIP_Y_WEBGL, value ? 1 : 0);\r\n if (this.enableUnpackFlipYCached) {\r\n this._unpackFlipYCached = value;\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._getUnpackAlignement = function () {\r\n return this._gl.getParameter(this._gl.UNPACK_ALIGNMENT);\r\n };\r\n ThinEngine.prototype._getTextureTarget = function (texture) {\r\n if (texture.isCube) {\r\n return this._gl.TEXTURE_CUBE_MAP;\r\n }\r\n else if (texture.is3D) {\r\n return this._gl.TEXTURE_3D;\r\n }\r\n else if (texture.is2DArray || texture.isMultiview) {\r\n return this._gl.TEXTURE_2D_ARRAY;\r\n }\r\n return this._gl.TEXTURE_2D;\r\n };\r\n /**\r\n * Update the sampling mode of a given texture\r\n * @param samplingMode defines the required sampling mode\r\n * @param texture defines the texture to update\r\n * @param generateMipMaps defines whether to generate mipmaps for the texture\r\n */\r\n ThinEngine.prototype.updateTextureSamplingMode = function (samplingMode, texture, generateMipMaps) {\r\n if (generateMipMaps === void 0) { generateMipMaps = false; }\r\n var target = this._getTextureTarget(texture);\r\n var filters = this._getSamplingParameters(samplingMode, texture.generateMipMaps || generateMipMaps);\r\n this._setTextureParameterInteger(target, this._gl.TEXTURE_MAG_FILTER, filters.mag, texture);\r\n this._setTextureParameterInteger(target, this._gl.TEXTURE_MIN_FILTER, filters.min);\r\n if (generateMipMaps) {\r\n texture.generateMipMaps = true;\r\n this._gl.generateMipmap(target);\r\n }\r\n this._bindTextureDirectly(target, null);\r\n texture.samplingMode = samplingMode;\r\n };\r\n /**\r\n * Update the sampling mode of a given texture\r\n * @param texture defines the texture to update\r\n * @param wrapU defines the texture wrap mode of the u coordinates\r\n * @param wrapV defines the texture wrap mode of the v coordinates\r\n * @param wrapR defines the texture wrap mode of the r coordinates\r\n */\r\n ThinEngine.prototype.updateTextureWrappingMode = function (texture, wrapU, wrapV, wrapR) {\r\n if (wrapV === void 0) { wrapV = null; }\r\n if (wrapR === void 0) { wrapR = null; }\r\n var target = this._getTextureTarget(texture);\r\n if (wrapU !== null) {\r\n this._setTextureParameterInteger(target, this._gl.TEXTURE_WRAP_S, this._getTextureWrapMode(wrapU), texture);\r\n texture._cachedWrapU = wrapU;\r\n }\r\n if (wrapV !== null) {\r\n this._setTextureParameterInteger(target, this._gl.TEXTURE_WRAP_T, this._getTextureWrapMode(wrapV), texture);\r\n texture._cachedWrapV = wrapV;\r\n }\r\n if ((texture.is2DArray || texture.is3D) && (wrapR !== null)) {\r\n this._setTextureParameterInteger(target, this._gl.TEXTURE_WRAP_R, this._getTextureWrapMode(wrapR), texture);\r\n texture._cachedWrapR = wrapR;\r\n }\r\n this._bindTextureDirectly(target, null);\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._setupDepthStencilTexture = function (internalTexture, size, generateStencil, bilinearFiltering, comparisonFunction) {\r\n var width = size.width || size;\r\n var height = size.height || size;\r\n var layers = size.layers || 0;\r\n internalTexture.baseWidth = width;\r\n internalTexture.baseHeight = height;\r\n internalTexture.width = width;\r\n internalTexture.height = height;\r\n internalTexture.is2DArray = layers > 0;\r\n internalTexture.depth = layers;\r\n internalTexture.isReady = true;\r\n internalTexture.samples = 1;\r\n internalTexture.generateMipMaps = false;\r\n internalTexture._generateDepthBuffer = true;\r\n internalTexture._generateStencilBuffer = generateStencil;\r\n internalTexture.samplingMode = bilinearFiltering ? 2 : 1;\r\n internalTexture.type = 0;\r\n internalTexture._comparisonFunction = comparisonFunction;\r\n var gl = this._gl;\r\n var target = this._getTextureTarget(internalTexture);\r\n var samplingParameters = this._getSamplingParameters(internalTexture.samplingMode, false);\r\n gl.texParameteri(target, gl.TEXTURE_MAG_FILTER, samplingParameters.mag);\r\n gl.texParameteri(target, gl.TEXTURE_MIN_FILTER, samplingParameters.min);\r\n gl.texParameteri(target, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\r\n gl.texParameteri(target, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\r\n if (comparisonFunction === 0) {\r\n gl.texParameteri(target, gl.TEXTURE_COMPARE_FUNC, 515);\r\n gl.texParameteri(target, gl.TEXTURE_COMPARE_MODE, gl.NONE);\r\n }\r\n else {\r\n gl.texParameteri(target, gl.TEXTURE_COMPARE_FUNC, comparisonFunction);\r\n gl.texParameteri(target, gl.TEXTURE_COMPARE_MODE, gl.COMPARE_REF_TO_TEXTURE);\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._uploadCompressedDataToTextureDirectly = function (texture, internalFormat, width, height, data, faceIndex, lod) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (lod === void 0) { lod = 0; }\r\n var gl = this._gl;\r\n var target = gl.TEXTURE_2D;\r\n if (texture.isCube) {\r\n target = gl.TEXTURE_CUBE_MAP_POSITIVE_X + faceIndex;\r\n }\r\n this._gl.compressedTexImage2D(target, lod, internalFormat, width, height, 0, data);\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._uploadDataToTextureDirectly = function (texture, imageData, faceIndex, lod, babylonInternalFormat, useTextureWidthAndHeight) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (lod === void 0) { lod = 0; }\r\n if (useTextureWidthAndHeight === void 0) { useTextureWidthAndHeight = false; }\r\n var gl = this._gl;\r\n var textureType = this._getWebGLTextureType(texture.type);\r\n var format = this._getInternalFormat(texture.format);\r\n var internalFormat = babylonInternalFormat === undefined ? this._getRGBABufferInternalSizedFormat(texture.type, texture.format) : this._getInternalFormat(babylonInternalFormat);\r\n this._unpackFlipY(texture.invertY);\r\n var target = gl.TEXTURE_2D;\r\n if (texture.isCube) {\r\n target = gl.TEXTURE_CUBE_MAP_POSITIVE_X + faceIndex;\r\n }\r\n var lodMaxWidth = Math.round(Math.log(texture.width) * Math.LOG2E);\r\n var lodMaxHeight = Math.round(Math.log(texture.height) * Math.LOG2E);\r\n var width = useTextureWidthAndHeight ? texture.width : Math.pow(2, Math.max(lodMaxWidth - lod, 0));\r\n var height = useTextureWidthAndHeight ? texture.height : Math.pow(2, Math.max(lodMaxHeight - lod, 0));\r\n gl.texImage2D(target, lod, internalFormat, width, height, 0, format, textureType, imageData);\r\n };\r\n /**\r\n * Update a portion of an internal texture\r\n * @param texture defines the texture to update\r\n * @param imageData defines the data to store into the texture\r\n * @param xOffset defines the x coordinates of the update rectangle\r\n * @param yOffset defines the y coordinates of the update rectangle\r\n * @param width defines the width of the update rectangle\r\n * @param height defines the height of the update rectangle\r\n * @param faceIndex defines the face index if texture is a cube (0 by default)\r\n * @param lod defines the lod level to update (0 by default)\r\n */\r\n ThinEngine.prototype.updateTextureData = function (texture, imageData, xOffset, yOffset, width, height, faceIndex, lod) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (lod === void 0) { lod = 0; }\r\n var gl = this._gl;\r\n var textureType = this._getWebGLTextureType(texture.type);\r\n var format = this._getInternalFormat(texture.format);\r\n this._unpackFlipY(texture.invertY);\r\n var target = gl.TEXTURE_2D;\r\n if (texture.isCube) {\r\n target = gl.TEXTURE_CUBE_MAP_POSITIVE_X + faceIndex;\r\n }\r\n gl.texSubImage2D(target, lod, xOffset, yOffset, width, height, format, textureType, imageData);\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._uploadArrayBufferViewToTexture = function (texture, imageData, faceIndex, lod) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (lod === void 0) { lod = 0; }\r\n var gl = this._gl;\r\n var bindTarget = texture.isCube ? gl.TEXTURE_CUBE_MAP : gl.TEXTURE_2D;\r\n this._bindTextureDirectly(bindTarget, texture, true);\r\n this._uploadDataToTextureDirectly(texture, imageData, faceIndex, lod);\r\n this._bindTextureDirectly(bindTarget, null, true);\r\n };\r\n ThinEngine.prototype._prepareWebGLTextureContinuation = function (texture, scene, noMipmap, isCompressed, samplingMode) {\r\n var gl = this._gl;\r\n if (!gl) {\r\n return;\r\n }\r\n var filters = this._getSamplingParameters(samplingMode, !noMipmap);\r\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, filters.mag);\r\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, filters.min);\r\n if (!noMipmap && !isCompressed) {\r\n gl.generateMipmap(gl.TEXTURE_2D);\r\n }\r\n this._bindTextureDirectly(gl.TEXTURE_2D, null);\r\n // this.resetTextureCache();\r\n if (scene) {\r\n scene._removePendingData(texture);\r\n }\r\n texture.onLoadedObservable.notifyObservers(texture);\r\n texture.onLoadedObservable.clear();\r\n };\r\n ThinEngine.prototype._prepareWebGLTexture = function (texture, scene, width, height, invertY, noMipmap, isCompressed, processFunction, samplingMode) {\r\n var _this = this;\r\n if (samplingMode === void 0) { samplingMode = 3; }\r\n var maxTextureSize = this.getCaps().maxTextureSize;\r\n var potWidth = Math.min(maxTextureSize, this.needPOTTextures ? ThinEngine.GetExponentOfTwo(width, maxTextureSize) : width);\r\n var potHeight = Math.min(maxTextureSize, this.needPOTTextures ? ThinEngine.GetExponentOfTwo(height, maxTextureSize) : height);\r\n var gl = this._gl;\r\n if (!gl) {\r\n return;\r\n }\r\n if (!texture._webGLTexture) {\r\n // this.resetTextureCache();\r\n if (scene) {\r\n scene._removePendingData(texture);\r\n }\r\n return;\r\n }\r\n this._bindTextureDirectly(gl.TEXTURE_2D, texture, true);\r\n this._unpackFlipY(invertY === undefined ? true : (invertY ? true : false));\r\n texture.baseWidth = width;\r\n texture.baseHeight = height;\r\n texture.width = potWidth;\r\n texture.height = potHeight;\r\n texture.isReady = true;\r\n if (processFunction(potWidth, potHeight, function () {\r\n _this._prepareWebGLTextureContinuation(texture, scene, noMipmap, isCompressed, samplingMode);\r\n })) {\r\n // Returning as texture needs extra async steps\r\n return;\r\n }\r\n this._prepareWebGLTextureContinuation(texture, scene, noMipmap, isCompressed, samplingMode);\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._setupFramebufferDepthAttachments = function (generateStencilBuffer, generateDepthBuffer, width, height, samples) {\r\n if (samples === void 0) { samples = 1; }\r\n var gl = this._gl;\r\n // Create the depth/stencil buffer\r\n if (generateStencilBuffer && generateDepthBuffer) {\r\n return this._getDepthStencilBuffer(width, height, samples, gl.DEPTH_STENCIL, gl.DEPTH24_STENCIL8, gl.DEPTH_STENCIL_ATTACHMENT);\r\n }\r\n if (generateDepthBuffer) {\r\n var depthFormat = gl.DEPTH_COMPONENT16;\r\n if (this._webGLVersion > 1) {\r\n depthFormat = gl.DEPTH_COMPONENT32F;\r\n }\r\n return this._getDepthStencilBuffer(width, height, samples, depthFormat, depthFormat, gl.DEPTH_ATTACHMENT);\r\n }\r\n if (generateStencilBuffer) {\r\n return this._getDepthStencilBuffer(width, height, samples, gl.STENCIL_INDEX8, gl.STENCIL_INDEX8, gl.STENCIL_ATTACHMENT);\r\n }\r\n return null;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._releaseFramebufferObjects = function (texture) {\r\n var gl = this._gl;\r\n if (texture._framebuffer) {\r\n gl.deleteFramebuffer(texture._framebuffer);\r\n texture._framebuffer = null;\r\n }\r\n if (texture._depthStencilBuffer) {\r\n gl.deleteRenderbuffer(texture._depthStencilBuffer);\r\n texture._depthStencilBuffer = null;\r\n }\r\n if (texture._MSAAFramebuffer) {\r\n gl.deleteFramebuffer(texture._MSAAFramebuffer);\r\n texture._MSAAFramebuffer = null;\r\n }\r\n if (texture._MSAARenderBuffer) {\r\n gl.deleteRenderbuffer(texture._MSAARenderBuffer);\r\n texture._MSAARenderBuffer = null;\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._releaseTexture = function (texture) {\r\n this._releaseFramebufferObjects(texture);\r\n this._deleteTexture(texture._webGLTexture);\r\n // Unbind channels\r\n this.unbindAllTextures();\r\n var index = this._internalTexturesCache.indexOf(texture);\r\n if (index !== -1) {\r\n this._internalTexturesCache.splice(index, 1);\r\n }\r\n // Integrated fixed lod samplers.\r\n if (texture._lodTextureHigh) {\r\n texture._lodTextureHigh.dispose();\r\n }\r\n if (texture._lodTextureMid) {\r\n texture._lodTextureMid.dispose();\r\n }\r\n if (texture._lodTextureLow) {\r\n texture._lodTextureLow.dispose();\r\n }\r\n // Integrated irradiance map.\r\n if (texture._irradianceTexture) {\r\n texture._irradianceTexture.dispose();\r\n }\r\n };\r\n ThinEngine.prototype._deleteTexture = function (texture) {\r\n this._gl.deleteTexture(texture);\r\n };\r\n ThinEngine.prototype._setProgram = function (program) {\r\n if (this._currentProgram !== program) {\r\n this._gl.useProgram(program);\r\n this._currentProgram = program;\r\n }\r\n };\r\n /**\r\n * Binds an effect to the webGL context\r\n * @param effect defines the effect to bind\r\n */\r\n ThinEngine.prototype.bindSamplers = function (effect) {\r\n var webGLPipelineContext = effect.getPipelineContext();\r\n this._setProgram(webGLPipelineContext.program);\r\n var samplers = effect.getSamplers();\r\n for (var index = 0; index < samplers.length; index++) {\r\n var uniform = effect.getUniform(samplers[index]);\r\n if (uniform) {\r\n this._boundUniforms[index] = uniform;\r\n }\r\n }\r\n this._currentEffect = null;\r\n };\r\n ThinEngine.prototype._activateCurrentTexture = function () {\r\n if (this._currentTextureChannel !== this._activeChannel) {\r\n this._gl.activeTexture(this._gl.TEXTURE0 + this._activeChannel);\r\n this._currentTextureChannel = this._activeChannel;\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._bindTextureDirectly = function (target, texture, forTextureDataUpdate, force) {\r\n if (forTextureDataUpdate === void 0) { forTextureDataUpdate = false; }\r\n if (force === void 0) { force = false; }\r\n var wasPreviouslyBound = false;\r\n var isTextureForRendering = texture && texture._associatedChannel > -1;\r\n if (forTextureDataUpdate && isTextureForRendering) {\r\n this._activeChannel = texture._associatedChannel;\r\n }\r\n var currentTextureBound = this._boundTexturesCache[this._activeChannel];\r\n if (currentTextureBound !== texture || force) {\r\n this._activateCurrentTexture();\r\n if (texture && texture.isMultiview) {\r\n this._gl.bindTexture(target, texture ? texture._colorTextureArray : null);\r\n }\r\n else {\r\n this._gl.bindTexture(target, texture ? texture._webGLTexture : null);\r\n }\r\n this._boundTexturesCache[this._activeChannel] = texture;\r\n if (texture) {\r\n texture._associatedChannel = this._activeChannel;\r\n }\r\n }\r\n else if (forTextureDataUpdate) {\r\n wasPreviouslyBound = true;\r\n this._activateCurrentTexture();\r\n }\r\n if (isTextureForRendering && !forTextureDataUpdate) {\r\n this._bindSamplerUniformToChannel(texture._associatedChannel, this._activeChannel);\r\n }\r\n return wasPreviouslyBound;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._bindTexture = function (channel, texture) {\r\n if (channel === undefined) {\r\n return;\r\n }\r\n if (texture) {\r\n texture._associatedChannel = channel;\r\n }\r\n this._activeChannel = channel;\r\n this._bindTextureDirectly(this._gl.TEXTURE_2D, texture);\r\n };\r\n /**\r\n * Unbind all textures from the webGL context\r\n */\r\n ThinEngine.prototype.unbindAllTextures = function () {\r\n for (var channel = 0; channel < this._maxSimultaneousTextures; channel++) {\r\n this._activeChannel = channel;\r\n this._bindTextureDirectly(this._gl.TEXTURE_2D, null);\r\n this._bindTextureDirectly(this._gl.TEXTURE_CUBE_MAP, null);\r\n if (this.webGLVersion > 1) {\r\n this._bindTextureDirectly(this._gl.TEXTURE_3D, null);\r\n this._bindTextureDirectly(this._gl.TEXTURE_2D_ARRAY, null);\r\n }\r\n }\r\n };\r\n /**\r\n * Sets a texture to the according uniform.\r\n * @param channel The texture channel\r\n * @param uniform The uniform to set\r\n * @param texture The texture to apply\r\n */\r\n ThinEngine.prototype.setTexture = function (channel, uniform, texture) {\r\n if (channel === undefined) {\r\n return;\r\n }\r\n if (uniform) {\r\n this._boundUniforms[channel] = uniform;\r\n }\r\n this._setTexture(channel, texture);\r\n };\r\n ThinEngine.prototype._bindSamplerUniformToChannel = function (sourceSlot, destination) {\r\n var uniform = this._boundUniforms[sourceSlot];\r\n if (!uniform || uniform._currentState === destination) {\r\n return;\r\n }\r\n this._gl.uniform1i(uniform, destination);\r\n uniform._currentState = destination;\r\n };\r\n ThinEngine.prototype._getTextureWrapMode = function (mode) {\r\n switch (mode) {\r\n case 1:\r\n return this._gl.REPEAT;\r\n case 0:\r\n return this._gl.CLAMP_TO_EDGE;\r\n case 2:\r\n return this._gl.MIRRORED_REPEAT;\r\n }\r\n return this._gl.REPEAT;\r\n };\r\n ThinEngine.prototype._setTexture = function (channel, texture, isPartOfTextureArray, depthStencilTexture) {\r\n if (isPartOfTextureArray === void 0) { isPartOfTextureArray = false; }\r\n if (depthStencilTexture === void 0) { depthStencilTexture = false; }\r\n // Not ready?\r\n if (!texture) {\r\n if (this._boundTexturesCache[channel] != null) {\r\n this._activeChannel = channel;\r\n this._bindTextureDirectly(this._gl.TEXTURE_2D, null);\r\n this._bindTextureDirectly(this._gl.TEXTURE_CUBE_MAP, null);\r\n if (this.webGLVersion > 1) {\r\n this._bindTextureDirectly(this._gl.TEXTURE_3D, null);\r\n this._bindTextureDirectly(this._gl.TEXTURE_2D_ARRAY, null);\r\n }\r\n }\r\n return false;\r\n }\r\n // Video\r\n if (texture.video) {\r\n this._activeChannel = channel;\r\n texture.update();\r\n }\r\n else if (texture.delayLoadState === 4) { // Delay loading\r\n texture.delayLoad();\r\n return false;\r\n }\r\n var internalTexture;\r\n if (depthStencilTexture) {\r\n internalTexture = texture.depthStencilTexture;\r\n }\r\n else if (texture.isReady()) {\r\n internalTexture = texture.getInternalTexture();\r\n }\r\n else if (texture.isCube) {\r\n internalTexture = this.emptyCubeTexture;\r\n }\r\n else if (texture.is3D) {\r\n internalTexture = this.emptyTexture3D;\r\n }\r\n else if (texture.is2DArray) {\r\n internalTexture = this.emptyTexture2DArray;\r\n }\r\n else {\r\n internalTexture = this.emptyTexture;\r\n }\r\n if (!isPartOfTextureArray && internalTexture) {\r\n internalTexture._associatedChannel = channel;\r\n }\r\n var needToBind = true;\r\n if (this._boundTexturesCache[channel] === internalTexture) {\r\n if (!isPartOfTextureArray) {\r\n this._bindSamplerUniformToChannel(internalTexture._associatedChannel, channel);\r\n }\r\n needToBind = false;\r\n }\r\n this._activeChannel = channel;\r\n var target = this._getTextureTarget(internalTexture);\r\n if (needToBind) {\r\n this._bindTextureDirectly(target, internalTexture, isPartOfTextureArray);\r\n }\r\n if (internalTexture && !internalTexture.isMultiview) {\r\n // CUBIC_MODE and SKYBOX_MODE both require CLAMP_TO_EDGE. All other modes use REPEAT.\r\n if (internalTexture.isCube && internalTexture._cachedCoordinatesMode !== texture.coordinatesMode) {\r\n internalTexture._cachedCoordinatesMode = texture.coordinatesMode;\r\n var textureWrapMode = (texture.coordinatesMode !== 3 && texture.coordinatesMode !== 5) ? 1 : 0;\r\n texture.wrapU = textureWrapMode;\r\n texture.wrapV = textureWrapMode;\r\n }\r\n if (internalTexture._cachedWrapU !== texture.wrapU) {\r\n internalTexture._cachedWrapU = texture.wrapU;\r\n this._setTextureParameterInteger(target, this._gl.TEXTURE_WRAP_S, this._getTextureWrapMode(texture.wrapU), internalTexture);\r\n }\r\n if (internalTexture._cachedWrapV !== texture.wrapV) {\r\n internalTexture._cachedWrapV = texture.wrapV;\r\n this._setTextureParameterInteger(target, this._gl.TEXTURE_WRAP_T, this._getTextureWrapMode(texture.wrapV), internalTexture);\r\n }\r\n if (internalTexture.is3D && internalTexture._cachedWrapR !== texture.wrapR) {\r\n internalTexture._cachedWrapR = texture.wrapR;\r\n this._setTextureParameterInteger(target, this._gl.TEXTURE_WRAP_R, this._getTextureWrapMode(texture.wrapR), internalTexture);\r\n }\r\n this._setAnisotropicLevel(target, internalTexture, texture.anisotropicFilteringLevel);\r\n }\r\n return true;\r\n };\r\n /**\r\n * Sets an array of texture to the webGL context\r\n * @param channel defines the channel where the texture array must be set\r\n * @param uniform defines the associated uniform location\r\n * @param textures defines the array of textures to bind\r\n */\r\n ThinEngine.prototype.setTextureArray = function (channel, uniform, textures) {\r\n if (channel === undefined || !uniform) {\r\n return;\r\n }\r\n if (!this._textureUnits || this._textureUnits.length !== textures.length) {\r\n this._textureUnits = new Int32Array(textures.length);\r\n }\r\n for (var i = 0; i < textures.length; i++) {\r\n var texture = textures[i].getInternalTexture();\r\n if (texture) {\r\n this._textureUnits[i] = channel + i;\r\n texture._associatedChannel = channel + i;\r\n }\r\n else {\r\n this._textureUnits[i] = -1;\r\n }\r\n }\r\n this._gl.uniform1iv(uniform, this._textureUnits);\r\n for (var index = 0; index < textures.length; index++) {\r\n this._setTexture(this._textureUnits[index], textures[index], true);\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._setAnisotropicLevel = function (target, internalTexture, anisotropicFilteringLevel) {\r\n var anisotropicFilterExtension = this._caps.textureAnisotropicFilterExtension;\r\n if (internalTexture.samplingMode !== 11\r\n && internalTexture.samplingMode !== 3\r\n && internalTexture.samplingMode !== 2) {\r\n anisotropicFilteringLevel = 1; // Forcing the anisotropic to 1 because else webgl will force filters to linear\r\n }\r\n if (anisotropicFilterExtension && internalTexture._cachedAnisotropicFilteringLevel !== anisotropicFilteringLevel) {\r\n this._setTextureParameterFloat(target, anisotropicFilterExtension.TEXTURE_MAX_ANISOTROPY_EXT, Math.min(anisotropicFilteringLevel, this._caps.maxAnisotropy), internalTexture);\r\n internalTexture._cachedAnisotropicFilteringLevel = anisotropicFilteringLevel;\r\n }\r\n };\r\n ThinEngine.prototype._setTextureParameterFloat = function (target, parameter, value, texture) {\r\n this._bindTextureDirectly(target, texture, true, true);\r\n this._gl.texParameterf(target, parameter, value);\r\n };\r\n ThinEngine.prototype._setTextureParameterInteger = function (target, parameter, value, texture) {\r\n if (texture) {\r\n this._bindTextureDirectly(target, texture, true, true);\r\n }\r\n this._gl.texParameteri(target, parameter, value);\r\n };\r\n /**\r\n * Unbind all vertex attributes from the webGL context\r\n */\r\n ThinEngine.prototype.unbindAllAttributes = function () {\r\n if (this._mustWipeVertexAttributes) {\r\n this._mustWipeVertexAttributes = false;\r\n for (var i = 0; i < this._caps.maxVertexAttribs; i++) {\r\n this.disableAttributeByIndex(i);\r\n }\r\n return;\r\n }\r\n for (var i = 0, ul = this._vertexAttribArraysEnabled.length; i < ul; i++) {\r\n if (i >= this._caps.maxVertexAttribs || !this._vertexAttribArraysEnabled[i]) {\r\n continue;\r\n }\r\n this.disableAttributeByIndex(i);\r\n }\r\n };\r\n /**\r\n * Force the engine to release all cached effects. This means that next effect compilation will have to be done completely even if a similar effect was already compiled\r\n */\r\n ThinEngine.prototype.releaseEffects = function () {\r\n for (var name in this._compiledEffects) {\r\n var webGLPipelineContext = this._compiledEffects[name].getPipelineContext();\r\n this._deletePipelineContext(webGLPipelineContext);\r\n }\r\n this._compiledEffects = {};\r\n };\r\n /**\r\n * Dispose and release all associated resources\r\n */\r\n ThinEngine.prototype.dispose = function () {\r\n this.stopRenderLoop();\r\n // Clear observables\r\n if (this.onBeforeTextureInitObservable) {\r\n this.onBeforeTextureInitObservable.clear();\r\n }\r\n // Empty texture\r\n if (this._emptyTexture) {\r\n this._releaseTexture(this._emptyTexture);\r\n this._emptyTexture = null;\r\n }\r\n if (this._emptyCubeTexture) {\r\n this._releaseTexture(this._emptyCubeTexture);\r\n this._emptyCubeTexture = null;\r\n }\r\n // Release effects\r\n this.releaseEffects();\r\n // Unbind\r\n this.unbindAllAttributes();\r\n this._boundUniforms = [];\r\n // Events\r\n if (DomManagement.IsWindowObjectExist()) {\r\n if (this._renderingCanvas) {\r\n if (!this._doNotHandleContextLost) {\r\n this._renderingCanvas.removeEventListener(\"webglcontextlost\", this._onContextLost);\r\n this._renderingCanvas.removeEventListener(\"webglcontextrestored\", this._onContextRestored);\r\n }\r\n }\r\n }\r\n this._workingCanvas = null;\r\n this._workingContext = null;\r\n this._currentBufferPointers = [];\r\n this._renderingCanvas = null;\r\n this._currentProgram = null;\r\n this._boundRenderFunction = null;\r\n Effect.ResetCache();\r\n // Abort active requests\r\n for (var _i = 0, _a = this._activeRequests; _i < _a.length; _i++) {\r\n var request = _a[_i];\r\n request.abort();\r\n }\r\n };\r\n /**\r\n * Attach a new callback raised when context lost event is fired\r\n * @param callback defines the callback to call\r\n */\r\n ThinEngine.prototype.attachContextLostEvent = function (callback) {\r\n if (this._renderingCanvas) {\r\n this._renderingCanvas.addEventListener(\"webglcontextlost\", callback, false);\r\n }\r\n };\r\n /**\r\n * Attach a new callback raised when context restored event is fired\r\n * @param callback defines the callback to call\r\n */\r\n ThinEngine.prototype.attachContextRestoredEvent = function (callback) {\r\n if (this._renderingCanvas) {\r\n this._renderingCanvas.addEventListener(\"webglcontextrestored\", callback, false);\r\n }\r\n };\r\n /**\r\n * Get the current error code of the webGL context\r\n * @returns the error code\r\n * @see https://developer.mozilla.org/en-US/docs/Web/API/WebGLRenderingContext/getError\r\n */\r\n ThinEngine.prototype.getError = function () {\r\n return this._gl.getError();\r\n };\r\n ThinEngine.prototype._canRenderToFloatFramebuffer = function () {\r\n if (this._webGLVersion > 1) {\r\n return this._caps.colorBufferFloat;\r\n }\r\n return this._canRenderToFramebuffer(1);\r\n };\r\n ThinEngine.prototype._canRenderToHalfFloatFramebuffer = function () {\r\n if (this._webGLVersion > 1) {\r\n return this._caps.colorBufferFloat;\r\n }\r\n return this._canRenderToFramebuffer(2);\r\n };\r\n // Thank you : http://stackoverflow.com/questions/28827511/webgl-ios-render-to-floating-point-texture\r\n ThinEngine.prototype._canRenderToFramebuffer = function (type) {\r\n var gl = this._gl;\r\n //clear existing errors\r\n while (gl.getError() !== gl.NO_ERROR) { }\r\n var successful = true;\r\n var texture = gl.createTexture();\r\n gl.bindTexture(gl.TEXTURE_2D, texture);\r\n gl.texImage2D(gl.TEXTURE_2D, 0, this._getRGBABufferInternalSizedFormat(type), 1, 1, 0, gl.RGBA, this._getWebGLTextureType(type), null);\r\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);\r\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);\r\n var fb = gl.createFramebuffer();\r\n gl.bindFramebuffer(gl.FRAMEBUFFER, fb);\r\n gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture, 0);\r\n var status = gl.checkFramebufferStatus(gl.FRAMEBUFFER);\r\n successful = successful && (status === gl.FRAMEBUFFER_COMPLETE);\r\n successful = successful && (gl.getError() === gl.NO_ERROR);\r\n //try render by clearing frame buffer's color buffer\r\n if (successful) {\r\n gl.clear(gl.COLOR_BUFFER_BIT);\r\n successful = successful && (gl.getError() === gl.NO_ERROR);\r\n }\r\n //try reading from frame to ensure render occurs (just creating the FBO is not sufficient to determine if rendering is supported)\r\n if (successful) {\r\n //in practice it's sufficient to just read from the backbuffer rather than handle potentially issues reading from the texture\r\n gl.bindFramebuffer(gl.FRAMEBUFFER, null);\r\n var readFormat = gl.RGBA;\r\n var readType = gl.UNSIGNED_BYTE;\r\n var buffer = new Uint8Array(4);\r\n gl.readPixels(0, 0, 1, 1, readFormat, readType, buffer);\r\n successful = successful && (gl.getError() === gl.NO_ERROR);\r\n }\r\n //clean up\r\n gl.deleteTexture(texture);\r\n gl.deleteFramebuffer(fb);\r\n gl.bindFramebuffer(gl.FRAMEBUFFER, null);\r\n //clear accumulated errors\r\n while (!successful && (gl.getError() !== gl.NO_ERROR)) { }\r\n return successful;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._getWebGLTextureType = function (type) {\r\n if (this._webGLVersion === 1) {\r\n switch (type) {\r\n case 1:\r\n return this._gl.FLOAT;\r\n case 2:\r\n return this._gl.HALF_FLOAT_OES;\r\n case 0:\r\n return this._gl.UNSIGNED_BYTE;\r\n case 8:\r\n return this._gl.UNSIGNED_SHORT_4_4_4_4;\r\n case 9:\r\n return this._gl.UNSIGNED_SHORT_5_5_5_1;\r\n case 10:\r\n return this._gl.UNSIGNED_SHORT_5_6_5;\r\n }\r\n return this._gl.UNSIGNED_BYTE;\r\n }\r\n switch (type) {\r\n case 3:\r\n return this._gl.BYTE;\r\n case 0:\r\n return this._gl.UNSIGNED_BYTE;\r\n case 4:\r\n return this._gl.SHORT;\r\n case 5:\r\n return this._gl.UNSIGNED_SHORT;\r\n case 6:\r\n return this._gl.INT;\r\n case 7: // Refers to UNSIGNED_INT\r\n return this._gl.UNSIGNED_INT;\r\n case 1:\r\n return this._gl.FLOAT;\r\n case 2:\r\n return this._gl.HALF_FLOAT;\r\n case 8:\r\n return this._gl.UNSIGNED_SHORT_4_4_4_4;\r\n case 9:\r\n return this._gl.UNSIGNED_SHORT_5_5_5_1;\r\n case 10:\r\n return this._gl.UNSIGNED_SHORT_5_6_5;\r\n case 11:\r\n return this._gl.UNSIGNED_INT_2_10_10_10_REV;\r\n case 12:\r\n return this._gl.UNSIGNED_INT_24_8;\r\n case 13:\r\n return this._gl.UNSIGNED_INT_10F_11F_11F_REV;\r\n case 14:\r\n return this._gl.UNSIGNED_INT_5_9_9_9_REV;\r\n case 15:\r\n return this._gl.FLOAT_32_UNSIGNED_INT_24_8_REV;\r\n }\r\n return this._gl.UNSIGNED_BYTE;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._getInternalFormat = function (format) {\r\n var internalFormat = this._gl.RGBA;\r\n switch (format) {\r\n case 0:\r\n internalFormat = this._gl.ALPHA;\r\n break;\r\n case 1:\r\n internalFormat = this._gl.LUMINANCE;\r\n break;\r\n case 2:\r\n internalFormat = this._gl.LUMINANCE_ALPHA;\r\n break;\r\n case 6:\r\n internalFormat = this._gl.RED;\r\n break;\r\n case 7:\r\n internalFormat = this._gl.RG;\r\n break;\r\n case 4:\r\n internalFormat = this._gl.RGB;\r\n break;\r\n case 5:\r\n internalFormat = this._gl.RGBA;\r\n break;\r\n }\r\n if (this._webGLVersion > 1) {\r\n switch (format) {\r\n case 8:\r\n internalFormat = this._gl.RED_INTEGER;\r\n break;\r\n case 9:\r\n internalFormat = this._gl.RG_INTEGER;\r\n break;\r\n case 10:\r\n internalFormat = this._gl.RGB_INTEGER;\r\n break;\r\n case 11:\r\n internalFormat = this._gl.RGBA_INTEGER;\r\n break;\r\n }\r\n }\r\n return internalFormat;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._getRGBABufferInternalSizedFormat = function (type, format) {\r\n if (this._webGLVersion === 1) {\r\n if (format !== undefined) {\r\n switch (format) {\r\n case 0:\r\n return this._gl.ALPHA;\r\n case 1:\r\n return this._gl.LUMINANCE;\r\n case 2:\r\n return this._gl.LUMINANCE_ALPHA;\r\n case 4:\r\n return this._gl.RGB;\r\n }\r\n }\r\n return this._gl.RGBA;\r\n }\r\n switch (type) {\r\n case 3:\r\n switch (format) {\r\n case 6:\r\n return this._gl.R8_SNORM;\r\n case 7:\r\n return this._gl.RG8_SNORM;\r\n case 4:\r\n return this._gl.RGB8_SNORM;\r\n case 8:\r\n return this._gl.R8I;\r\n case 9:\r\n return this._gl.RG8I;\r\n case 10:\r\n return this._gl.RGB8I;\r\n case 11:\r\n return this._gl.RGBA8I;\r\n default:\r\n return this._gl.RGBA8_SNORM;\r\n }\r\n case 0:\r\n switch (format) {\r\n case 6:\r\n return this._gl.R8;\r\n case 7:\r\n return this._gl.RG8;\r\n case 4:\r\n return this._gl.RGB8; // By default. Other possibilities are RGB565, SRGB8.\r\n case 5:\r\n return this._gl.RGBA8; // By default. Other possibilities are RGB5_A1, RGBA4, SRGB8_ALPHA8.\r\n case 8:\r\n return this._gl.R8UI;\r\n case 9:\r\n return this._gl.RG8UI;\r\n case 10:\r\n return this._gl.RGB8UI;\r\n case 11:\r\n return this._gl.RGBA8UI;\r\n case 0:\r\n return this._gl.ALPHA;\r\n case 1:\r\n return this._gl.LUMINANCE;\r\n case 2:\r\n return this._gl.LUMINANCE_ALPHA;\r\n default:\r\n return this._gl.RGBA8;\r\n }\r\n case 4:\r\n switch (format) {\r\n case 8:\r\n return this._gl.R16I;\r\n case 9:\r\n return this._gl.RG16I;\r\n case 10:\r\n return this._gl.RGB16I;\r\n case 11:\r\n return this._gl.RGBA16I;\r\n default:\r\n return this._gl.RGBA16I;\r\n }\r\n case 5:\r\n switch (format) {\r\n case 8:\r\n return this._gl.R16UI;\r\n case 9:\r\n return this._gl.RG16UI;\r\n case 10:\r\n return this._gl.RGB16UI;\r\n case 11:\r\n return this._gl.RGBA16UI;\r\n default:\r\n return this._gl.RGBA16UI;\r\n }\r\n case 6:\r\n switch (format) {\r\n case 8:\r\n return this._gl.R32I;\r\n case 9:\r\n return this._gl.RG32I;\r\n case 10:\r\n return this._gl.RGB32I;\r\n case 11:\r\n return this._gl.RGBA32I;\r\n default:\r\n return this._gl.RGBA32I;\r\n }\r\n case 7: // Refers to UNSIGNED_INT\r\n switch (format) {\r\n case 8:\r\n return this._gl.R32UI;\r\n case 9:\r\n return this._gl.RG32UI;\r\n case 10:\r\n return this._gl.RGB32UI;\r\n case 11:\r\n return this._gl.RGBA32UI;\r\n default:\r\n return this._gl.RGBA32UI;\r\n }\r\n case 1:\r\n switch (format) {\r\n case 6:\r\n return this._gl.R32F; // By default. Other possibility is R16F.\r\n case 7:\r\n return this._gl.RG32F; // By default. Other possibility is RG16F.\r\n case 4:\r\n return this._gl.RGB32F; // By default. Other possibilities are RGB16F, R11F_G11F_B10F, RGB9_E5.\r\n case 5:\r\n return this._gl.RGBA32F; // By default. Other possibility is RGBA16F.\r\n default:\r\n return this._gl.RGBA32F;\r\n }\r\n case 2:\r\n switch (format) {\r\n case 6:\r\n return this._gl.R16F;\r\n case 7:\r\n return this._gl.RG16F;\r\n case 4:\r\n return this._gl.RGB16F; // By default. Other possibilities are R11F_G11F_B10F, RGB9_E5.\r\n case 5:\r\n return this._gl.RGBA16F;\r\n default:\r\n return this._gl.RGBA16F;\r\n }\r\n case 10:\r\n return this._gl.RGB565;\r\n case 13:\r\n return this._gl.R11F_G11F_B10F;\r\n case 14:\r\n return this._gl.RGB9_E5;\r\n case 8:\r\n return this._gl.RGBA4;\r\n case 9:\r\n return this._gl.RGB5_A1;\r\n case 11:\r\n switch (format) {\r\n case 5:\r\n return this._gl.RGB10_A2; // By default. Other possibility is RGB5_A1.\r\n case 11:\r\n return this._gl.RGB10_A2UI;\r\n default:\r\n return this._gl.RGB10_A2;\r\n }\r\n }\r\n return this._gl.RGBA8;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._getRGBAMultiSampleBufferFormat = function (type) {\r\n if (type === 1) {\r\n return this._gl.RGBA32F;\r\n }\r\n else if (type === 2) {\r\n return this._gl.RGBA16F;\r\n }\r\n return this._gl.RGBA8;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._loadFile = function (url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError) {\r\n var _this = this;\r\n var request = ThinEngine._FileToolsLoadFile(url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError);\r\n this._activeRequests.push(request);\r\n request.onCompleteObservable.add(function (request) {\r\n _this._activeRequests.splice(_this._activeRequests.indexOf(request), 1);\r\n });\r\n return request;\r\n };\r\n /**\r\n * Loads a file from a url\r\n * @param url url to load\r\n * @param onSuccess callback called when the file successfully loads\r\n * @param onProgress callback called while file is loading (if the server supports this mode)\r\n * @param offlineProvider defines the offline provider for caching\r\n * @param useArrayBuffer defines a boolean indicating that date must be returned as ArrayBuffer\r\n * @param onError callback called when the file fails to load\r\n * @returns a file request object\r\n * @hidden\r\n */\r\n ThinEngine._FileToolsLoadFile = function (url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError) {\r\n throw _DevTools.WarnImport(\"FileTools\");\r\n };\r\n /**\r\n * Reads pixels from the current frame buffer. Please note that this function can be slow\r\n * @param x defines the x coordinate of the rectangle where pixels must be read\r\n * @param y defines the y coordinate of the rectangle where pixels must be read\r\n * @param width defines the width of the rectangle where pixels must be read\r\n * @param height defines the height of the rectangle where pixels must be read\r\n * @param hasAlpha defines whether the output should have alpha or not (defaults to true)\r\n * @returns a Uint8Array containing RGBA colors\r\n */\r\n ThinEngine.prototype.readPixels = function (x, y, width, height, hasAlpha) {\r\n if (hasAlpha === void 0) { hasAlpha = true; }\r\n var numChannels = hasAlpha ? 4 : 3;\r\n var format = hasAlpha ? this._gl.RGBA : this._gl.RGB;\r\n var data = new Uint8Array(height * width * numChannels);\r\n this._gl.readPixels(x, y, width, height, format, this._gl.UNSIGNED_BYTE, data);\r\n return data;\r\n };\r\n /**\r\n * Gets a boolean indicating if the engine can be instanciated (ie. if a webGL context can be found)\r\n * @returns true if the engine can be created\r\n * @ignorenaming\r\n */\r\n ThinEngine.isSupported = function () {\r\n if (this._isSupported === null) {\r\n try {\r\n var tempcanvas = CanvasGenerator.CreateCanvas(1, 1);\r\n var gl = tempcanvas.getContext(\"webgl\") || tempcanvas.getContext(\"experimental-webgl\");\r\n this._isSupported = gl != null && !!window.WebGLRenderingContext;\r\n }\r\n catch (e) {\r\n this._isSupported = false;\r\n }\r\n }\r\n return this._isSupported;\r\n };\r\n /**\r\n * Find the next highest power of two.\r\n * @param x Number to start search from.\r\n * @return Next highest power of two.\r\n */\r\n ThinEngine.CeilingPOT = function (x) {\r\n x--;\r\n x |= x >> 1;\r\n x |= x >> 2;\r\n x |= x >> 4;\r\n x |= x >> 8;\r\n x |= x >> 16;\r\n x++;\r\n return x;\r\n };\r\n /**\r\n * Find the next lowest power of two.\r\n * @param x Number to start search from.\r\n * @return Next lowest power of two.\r\n */\r\n ThinEngine.FloorPOT = function (x) {\r\n x = x | (x >> 1);\r\n x = x | (x >> 2);\r\n x = x | (x >> 4);\r\n x = x | (x >> 8);\r\n x = x | (x >> 16);\r\n return x - (x >> 1);\r\n };\r\n /**\r\n * Find the nearest power of two.\r\n * @param x Number to start search from.\r\n * @return Next nearest power of two.\r\n */\r\n ThinEngine.NearestPOT = function (x) {\r\n var c = ThinEngine.CeilingPOT(x);\r\n var f = ThinEngine.FloorPOT(x);\r\n return (c - x) > (x - f) ? f : c;\r\n };\r\n /**\r\n * Get the closest exponent of two\r\n * @param value defines the value to approximate\r\n * @param max defines the maximum value to return\r\n * @param mode defines how to define the closest value\r\n * @returns closest exponent of two of the given value\r\n */\r\n ThinEngine.GetExponentOfTwo = function (value, max, mode) {\r\n if (mode === void 0) { mode = 2; }\r\n var pot;\r\n switch (mode) {\r\n case 1:\r\n pot = ThinEngine.FloorPOT(value);\r\n break;\r\n case 2:\r\n pot = ThinEngine.NearestPOT(value);\r\n break;\r\n case 3:\r\n default:\r\n pot = ThinEngine.CeilingPOT(value);\r\n break;\r\n }\r\n return Math.min(pot, max);\r\n };\r\n /**\r\n * Queue a new function into the requested animation frame pool (ie. this function will be executed byt the browser for the next frame)\r\n * @param func - the function to be called\r\n * @param requester - the object that will request the next frame. Falls back to window.\r\n * @returns frame number\r\n */\r\n ThinEngine.QueueNewFrame = function (func, requester) {\r\n if (!DomManagement.IsWindowObjectExist()) {\r\n if (typeof requestAnimationFrame !== \"undefined\") {\r\n return requestAnimationFrame(func);\r\n }\r\n return setTimeout(func, 16);\r\n }\r\n if (!requester) {\r\n requester = window;\r\n }\r\n if (requester.requestAnimationFrame) {\r\n return requester.requestAnimationFrame(func);\r\n }\r\n else if (requester.msRequestAnimationFrame) {\r\n return requester.msRequestAnimationFrame(func);\r\n }\r\n else if (requester.webkitRequestAnimationFrame) {\r\n return requester.webkitRequestAnimationFrame(func);\r\n }\r\n else if (requester.mozRequestAnimationFrame) {\r\n return requester.mozRequestAnimationFrame(func);\r\n }\r\n else if (requester.oRequestAnimationFrame) {\r\n return requester.oRequestAnimationFrame(func);\r\n }\r\n else {\r\n return window.setTimeout(func, 16);\r\n }\r\n };\r\n /**\r\n * Gets host document\r\n * @returns the host document object\r\n */\r\n ThinEngine.prototype.getHostDocument = function () {\r\n if (this._renderingCanvas && this._renderingCanvas.ownerDocument) {\r\n return this._renderingCanvas.ownerDocument;\r\n }\r\n return document;\r\n };\r\n /** Use this array to turn off some WebGL2 features on known buggy browsers version */\r\n ThinEngine.ExceptionList = [\r\n { key: \"Chrome\\/63\\.0\", capture: \"63\\\\.0\\\\.3239\\\\.(\\\\d+)\", captureConstraint: 108, targets: [\"uniformBuffer\"] },\r\n { key: \"Firefox\\/58\", capture: null, captureConstraint: null, targets: [\"uniformBuffer\"] },\r\n { key: \"Firefox\\/59\", capture: null, captureConstraint: null, targets: [\"uniformBuffer\"] },\r\n { key: \"Chrome\\/72.+?Mobile\", capture: null, captureConstraint: null, targets: [\"vao\"] },\r\n { key: \"Chrome\\/73.+?Mobile\", capture: null, captureConstraint: null, targets: [\"vao\"] },\r\n { key: \"Chrome\\/74.+?Mobile\", capture: null, captureConstraint: null, targets: [\"vao\"] },\r\n { key: \"Mac OS.+Chrome\\/71\", capture: null, captureConstraint: null, targets: [\"vao\"] },\r\n { key: \"Mac OS.+Chrome\\/72\", capture: null, captureConstraint: null, targets: [\"vao\"] }\r\n ];\r\n /** @hidden */\r\n ThinEngine._TextureLoaders = [];\r\n // Updatable statics so stick with vars here\r\n /**\r\n * Gets or sets the epsilon value used by collision engine\r\n */\r\n ThinEngine.CollisionsEpsilon = 0.001;\r\n // Statics\r\n ThinEngine._isSupported = null;\r\n return ThinEngine;\r\n}());\r\nexport { ThinEngine };\r\n//# sourceMappingURL=thinEngine.js.map","/**\r\n * Sets of helpers dealing with the DOM and some of the recurrent functions needed in\r\n * Babylon.js\r\n */\r\nvar DomManagement = /** @class */ (function () {\r\n function DomManagement() {\r\n }\r\n /**\r\n * Checks if the window object exists\r\n * @returns true if the window object exists\r\n */\r\n DomManagement.IsWindowObjectExist = function () {\r\n return (typeof window) !== \"undefined\";\r\n };\r\n /**\r\n * Checks if the navigator object exists\r\n * @returns true if the navigator object exists\r\n */\r\n DomManagement.IsNavigatorAvailable = function () {\r\n return (typeof navigator) !== \"undefined\";\r\n };\r\n /**\r\n * Extracts text content from a DOM element hierarchy\r\n * @param element defines the root element\r\n * @returns a string\r\n */\r\n DomManagement.GetDOMTextContent = function (element) {\r\n var result = \"\";\r\n var child = element.firstChild;\r\n while (child) {\r\n if (child.nodeType === 3) {\r\n result += child.textContent;\r\n }\r\n child = (child.nextSibling);\r\n }\r\n return result;\r\n };\r\n return DomManagement;\r\n}());\r\nexport { DomManagement };\r\n//# sourceMappingURL=domManagement.js.map","import { PrecisionDate } from \"./precisionDate\";\r\n/**\r\n * Performance monitor tracks rolling average frame-time and frame-time variance over a user defined sliding-window\r\n */\r\nvar PerformanceMonitor = /** @class */ (function () {\r\n /**\r\n * constructor\r\n * @param frameSampleSize The number of samples required to saturate the sliding window\r\n */\r\n function PerformanceMonitor(frameSampleSize) {\r\n if (frameSampleSize === void 0) { frameSampleSize = 30; }\r\n this._enabled = true;\r\n this._rollingFrameTime = new RollingAverage(frameSampleSize);\r\n }\r\n /**\r\n * Samples current frame\r\n * @param timeMs A timestamp in milliseconds of the current frame to compare with other frames\r\n */\r\n PerformanceMonitor.prototype.sampleFrame = function (timeMs) {\r\n if (timeMs === void 0) { timeMs = PrecisionDate.Now; }\r\n if (!this._enabled) {\r\n return;\r\n }\r\n if (this._lastFrameTimeMs != null) {\r\n var dt = timeMs - this._lastFrameTimeMs;\r\n this._rollingFrameTime.add(dt);\r\n }\r\n this._lastFrameTimeMs = timeMs;\r\n };\r\n Object.defineProperty(PerformanceMonitor.prototype, \"averageFrameTime\", {\r\n /**\r\n * Returns the average frame time in milliseconds over the sliding window (or the subset of frames sampled so far)\r\n */\r\n get: function () {\r\n return this._rollingFrameTime.average;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerformanceMonitor.prototype, \"averageFrameTimeVariance\", {\r\n /**\r\n * Returns the variance frame time in milliseconds over the sliding window (or the subset of frames sampled so far)\r\n */\r\n get: function () {\r\n return this._rollingFrameTime.variance;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerformanceMonitor.prototype, \"instantaneousFrameTime\", {\r\n /**\r\n * Returns the frame time of the most recent frame\r\n */\r\n get: function () {\r\n return this._rollingFrameTime.history(0);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerformanceMonitor.prototype, \"averageFPS\", {\r\n /**\r\n * Returns the average framerate in frames per second over the sliding window (or the subset of frames sampled so far)\r\n */\r\n get: function () {\r\n return 1000.0 / this._rollingFrameTime.average;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerformanceMonitor.prototype, \"instantaneousFPS\", {\r\n /**\r\n * Returns the average framerate in frames per second using the most recent frame time\r\n */\r\n get: function () {\r\n var history = this._rollingFrameTime.history(0);\r\n if (history === 0) {\r\n return 0;\r\n }\r\n return 1000.0 / history;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerformanceMonitor.prototype, \"isSaturated\", {\r\n /**\r\n * Returns true if enough samples have been taken to completely fill the sliding window\r\n */\r\n get: function () {\r\n return this._rollingFrameTime.isSaturated();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Enables contributions to the sliding window sample set\r\n */\r\n PerformanceMonitor.prototype.enable = function () {\r\n this._enabled = true;\r\n };\r\n /**\r\n * Disables contributions to the sliding window sample set\r\n * Samples will not be interpolated over the disabled period\r\n */\r\n PerformanceMonitor.prototype.disable = function () {\r\n this._enabled = false;\r\n //clear last sample to avoid interpolating over the disabled period when next enabled\r\n this._lastFrameTimeMs = null;\r\n };\r\n Object.defineProperty(PerformanceMonitor.prototype, \"isEnabled\", {\r\n /**\r\n * Returns true if sampling is enabled\r\n */\r\n get: function () {\r\n return this._enabled;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Resets performance monitor\r\n */\r\n PerformanceMonitor.prototype.reset = function () {\r\n //clear last sample to avoid interpolating over the disabled period when next enabled\r\n this._lastFrameTimeMs = null;\r\n //wipe record\r\n this._rollingFrameTime.reset();\r\n };\r\n return PerformanceMonitor;\r\n}());\r\nexport { PerformanceMonitor };\r\n/**\r\n * RollingAverage\r\n *\r\n * Utility to efficiently compute the rolling average and variance over a sliding window of samples\r\n */\r\nvar RollingAverage = /** @class */ (function () {\r\n /**\r\n * constructor\r\n * @param length The number of samples required to saturate the sliding window\r\n */\r\n function RollingAverage(length) {\r\n this._samples = new Array(length);\r\n this.reset();\r\n }\r\n /**\r\n * Adds a sample to the sample set\r\n * @param v The sample value\r\n */\r\n RollingAverage.prototype.add = function (v) {\r\n //http://en.wikipedia.org/wiki/Algorithms_for_calculating_variance\r\n var delta;\r\n //we need to check if we've already wrapped round\r\n if (this.isSaturated()) {\r\n //remove bottom of stack from mean\r\n var bottomValue = this._samples[this._pos];\r\n delta = bottomValue - this.average;\r\n this.average -= delta / (this._sampleCount - 1);\r\n this._m2 -= delta * (bottomValue - this.average);\r\n }\r\n else {\r\n this._sampleCount++;\r\n }\r\n //add new value to mean\r\n delta = v - this.average;\r\n this.average += delta / (this._sampleCount);\r\n this._m2 += delta * (v - this.average);\r\n //set the new variance\r\n this.variance = this._m2 / (this._sampleCount - 1);\r\n this._samples[this._pos] = v;\r\n this._pos++;\r\n this._pos %= this._samples.length; //positive wrap around\r\n };\r\n /**\r\n * Returns previously added values or null if outside of history or outside the sliding window domain\r\n * @param i Index in history. For example, pass 0 for the most recent value and 1 for the value before that\r\n * @return Value previously recorded with add() or null if outside of range\r\n */\r\n RollingAverage.prototype.history = function (i) {\r\n if ((i >= this._sampleCount) || (i >= this._samples.length)) {\r\n return 0;\r\n }\r\n var i0 = this._wrapPosition(this._pos - 1.0);\r\n return this._samples[this._wrapPosition(i0 - i)];\r\n };\r\n /**\r\n * Returns true if enough samples have been taken to completely fill the sliding window\r\n * @return true if sample-set saturated\r\n */\r\n RollingAverage.prototype.isSaturated = function () {\r\n return this._sampleCount >= this._samples.length;\r\n };\r\n /**\r\n * Resets the rolling average (equivalent to 0 samples taken so far)\r\n */\r\n RollingAverage.prototype.reset = function () {\r\n this.average = 0;\r\n this.variance = 0;\r\n this._sampleCount = 0;\r\n this._pos = 0;\r\n this._m2 = 0;\r\n };\r\n /**\r\n * Wraps a value around the sample range boundaries\r\n * @param i Position in sample range, for example if the sample length is 5, and i is -3, then 2 will be returned.\r\n * @return Wrapped position in sample range\r\n */\r\n RollingAverage.prototype._wrapPosition = function (i) {\r\n var max = this._samples.length;\r\n return ((i % max) + max) % max;\r\n };\r\n return RollingAverage;\r\n}());\r\nexport { RollingAverage };\r\n//# sourceMappingURL=performanceMonitor.js.map","import { ThinEngine } from \"../../Engines/thinEngine\";\r\nThinEngine.prototype.setAlphaConstants = function (r, g, b, a) {\r\n this._alphaState.setAlphaBlendConstants(r, g, b, a);\r\n};\r\nThinEngine.prototype.setAlphaMode = function (mode, noDepthWriteChange) {\r\n if (noDepthWriteChange === void 0) { noDepthWriteChange = false; }\r\n if (this._alphaMode === mode) {\r\n return;\r\n }\r\n switch (mode) {\r\n case 0:\r\n this._alphaState.alphaBlend = false;\r\n break;\r\n case 7:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE, this._gl.ONE_MINUS_SRC_ALPHA, this._gl.ONE, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 8:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE, this._gl.ONE_MINUS_SRC_ALPHA, this._gl.ONE, this._gl.ONE_MINUS_SRC_ALPHA);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 2:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.SRC_ALPHA, this._gl.ONE_MINUS_SRC_ALPHA, this._gl.ONE, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 6:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE, this._gl.ONE, this._gl.ZERO, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 1:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.SRC_ALPHA, this._gl.ONE, this._gl.ZERO, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 3:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ZERO, this._gl.ONE_MINUS_SRC_COLOR, this._gl.ONE, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 4:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.DST_COLOR, this._gl.ZERO, this._gl.ONE, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 5:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.SRC_ALPHA, this._gl.ONE_MINUS_SRC_COLOR, this._gl.ONE, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 9:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.CONSTANT_COLOR, this._gl.ONE_MINUS_CONSTANT_COLOR, this._gl.CONSTANT_ALPHA, this._gl.ONE_MINUS_CONSTANT_ALPHA);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 10:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE, this._gl.ONE_MINUS_SRC_COLOR, this._gl.ONE, this._gl.ONE_MINUS_SRC_ALPHA);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 11:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE, this._gl.ONE, this._gl.ONE, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 12:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.DST_ALPHA, this._gl.ONE, this._gl.ZERO, this._gl.ZERO);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 13:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE_MINUS_DST_COLOR, this._gl.ONE_MINUS_SRC_COLOR, this._gl.ONE_MINUS_DST_ALPHA, this._gl.ONE_MINUS_SRC_ALPHA);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 14:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE, this._gl.ONE_MINUS_SRC_ALPHA, this._gl.ONE, this._gl.ONE_MINUS_SRC_ALPHA);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 15:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE, this._gl.ONE, this._gl.ONE, this._gl.ZERO);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 16:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE_MINUS_DST_COLOR, this._gl.ONE_MINUS_SRC_COLOR, this._gl.ZERO, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n }\r\n if (!noDepthWriteChange) {\r\n this.depthCullingState.depthMask = (mode === 0);\r\n }\r\n this._alphaMode = mode;\r\n};\r\nThinEngine.prototype.getAlphaMode = function () {\r\n return this._alphaMode;\r\n};\r\nThinEngine.prototype.setAlphaEquation = function (equation) {\r\n if (this._alphaEquation === equation) {\r\n return;\r\n }\r\n switch (equation) {\r\n case 0:\r\n this._alphaState.setAlphaEquationParameters(this._gl.FUNC_ADD, this._gl.FUNC_ADD);\r\n break;\r\n case 1:\r\n this._alphaState.setAlphaEquationParameters(this._gl.FUNC_SUBTRACT, this._gl.FUNC_SUBTRACT);\r\n break;\r\n case 2:\r\n this._alphaState.setAlphaEquationParameters(this._gl.FUNC_REVERSE_SUBTRACT, this._gl.FUNC_REVERSE_SUBTRACT);\r\n break;\r\n case 3:\r\n this._alphaState.setAlphaEquationParameters(this._gl.MAX, this._gl.MAX);\r\n break;\r\n case 4:\r\n this._alphaState.setAlphaEquationParameters(this._gl.MIN, this._gl.MIN);\r\n break;\r\n case 5:\r\n this._alphaState.setAlphaEquationParameters(this._gl.MIN, this._gl.FUNC_ADD);\r\n break;\r\n }\r\n this._alphaEquation = equation;\r\n};\r\nThinEngine.prototype.getAlphaEquation = function () {\r\n return this._alphaEquation;\r\n};\r\n//# sourceMappingURL=engine.alpha.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { DomManagement } from \"../Misc/domManagement\";\r\nimport { EngineStore } from \"./engineStore\";\r\nimport { _DevTools } from '../Misc/devTools';\r\nimport { ThinEngine } from './thinEngine';\r\nimport { PerformanceMonitor } from '../Misc/performanceMonitor';\r\nimport { PerfCounter } from '../Misc/perfCounter';\r\nimport { WebGLDataBuffer } from '../Meshes/WebGL/webGLDataBuffer';\r\nimport { Logger } from '../Misc/logger';\r\nimport \"./Extensions/engine.alpha\";\r\n/**\r\n * The engine class is responsible for interfacing with all lower-level APIs such as WebGL and Audio\r\n */\r\nvar Engine = /** @class */ (function (_super) {\r\n __extends(Engine, _super);\r\n /**\r\n * Creates a new engine\r\n * @param canvasOrContext defines the canvas or WebGL context to use for rendering. If you provide a WebGL context, Babylon.js will not hook events on the canvas (like pointers, keyboards, etc...) so no event observables will be available. This is mostly used when Babylon.js is used as a plugin on a system which alreay used the WebGL context\r\n * @param antialias defines enable antialiasing (default: false)\r\n * @param options defines further options to be sent to the getContext() function\r\n * @param adaptToDeviceRatio defines whether to adapt to the device's viewport characteristics (default: false)\r\n */\r\n function Engine(canvasOrContext, antialias, options, adaptToDeviceRatio) {\r\n if (adaptToDeviceRatio === void 0) { adaptToDeviceRatio = false; }\r\n var _this = _super.call(this, canvasOrContext, antialias, options, adaptToDeviceRatio) || this;\r\n // Members\r\n /**\r\n * Gets or sets a boolean to enable/disable IndexedDB support and avoid XHR on .manifest\r\n **/\r\n _this.enableOfflineSupport = false;\r\n /**\r\n * Gets or sets a boolean to enable/disable checking manifest if IndexedDB support is enabled (js will always consider the database is up to date)\r\n **/\r\n _this.disableManifestCheck = false;\r\n /**\r\n * Gets the list of created scenes\r\n */\r\n _this.scenes = new Array();\r\n /**\r\n * Event raised when a new scene is created\r\n */\r\n _this.onNewSceneAddedObservable = new Observable();\r\n /**\r\n * Gets the list of created postprocesses\r\n */\r\n _this.postProcesses = new Array();\r\n /**\r\n * Gets a boolean indicating if the pointer is currently locked\r\n */\r\n _this.isPointerLock = false;\r\n // Observables\r\n /**\r\n * Observable event triggered each time the rendering canvas is resized\r\n */\r\n _this.onResizeObservable = new Observable();\r\n /**\r\n * Observable event triggered each time the canvas loses focus\r\n */\r\n _this.onCanvasBlurObservable = new Observable();\r\n /**\r\n * Observable event triggered each time the canvas gains focus\r\n */\r\n _this.onCanvasFocusObservable = new Observable();\r\n /**\r\n * Observable event triggered each time the canvas receives pointerout event\r\n */\r\n _this.onCanvasPointerOutObservable = new Observable();\r\n /**\r\n * Observable raised when the engine begins a new frame\r\n */\r\n _this.onBeginFrameObservable = new Observable();\r\n /**\r\n * If set, will be used to request the next animation frame for the render loop\r\n */\r\n _this.customAnimationFrameRequester = null;\r\n /**\r\n * Observable raised when the engine ends the current frame\r\n */\r\n _this.onEndFrameObservable = new Observable();\r\n /**\r\n * Observable raised when the engine is about to compile a shader\r\n */\r\n _this.onBeforeShaderCompilationObservable = new Observable();\r\n /**\r\n * Observable raised when the engine has jsut compiled a shader\r\n */\r\n _this.onAfterShaderCompilationObservable = new Observable();\r\n // Deterministic lockstepMaxSteps\r\n _this._deterministicLockstep = false;\r\n _this._lockstepMaxSteps = 4;\r\n _this._timeStep = 1 / 60;\r\n // FPS\r\n _this._fps = 60;\r\n _this._deltaTime = 0;\r\n /** @hidden */\r\n _this._drawCalls = new PerfCounter();\r\n /** Gets or sets the tab index to set to the rendering canvas. 1 is the minimum value to set to be able to capture keyboard events */\r\n _this.canvasTabIndex = 1;\r\n /**\r\n * Turn this value on if you want to pause FPS computation when in background\r\n */\r\n _this.disablePerformanceMonitorInBackground = false;\r\n _this._performanceMonitor = new PerformanceMonitor();\r\n if (!canvasOrContext) {\r\n return _this;\r\n }\r\n options = _this._creationOptions;\r\n Engine.Instances.push(_this);\r\n if (canvasOrContext.getContext) {\r\n var canvas_1 = canvasOrContext;\r\n _this._onCanvasFocus = function () {\r\n _this.onCanvasFocusObservable.notifyObservers(_this);\r\n };\r\n _this._onCanvasBlur = function () {\r\n _this.onCanvasBlurObservable.notifyObservers(_this);\r\n };\r\n canvas_1.addEventListener(\"focus\", _this._onCanvasFocus);\r\n canvas_1.addEventListener(\"blur\", _this._onCanvasBlur);\r\n _this._onBlur = function () {\r\n if (_this.disablePerformanceMonitorInBackground) {\r\n _this._performanceMonitor.disable();\r\n }\r\n _this._windowIsBackground = true;\r\n };\r\n _this._onFocus = function () {\r\n if (_this.disablePerformanceMonitorInBackground) {\r\n _this._performanceMonitor.enable();\r\n }\r\n _this._windowIsBackground = false;\r\n };\r\n _this._onCanvasPointerOut = function (ev) {\r\n _this.onCanvasPointerOutObservable.notifyObservers(ev);\r\n };\r\n canvas_1.addEventListener(\"pointerout\", _this._onCanvasPointerOut);\r\n if (DomManagement.IsWindowObjectExist()) {\r\n var hostWindow = _this.getHostWindow();\r\n hostWindow.addEventListener(\"blur\", _this._onBlur);\r\n hostWindow.addEventListener(\"focus\", _this._onFocus);\r\n var anyDoc_1 = document;\r\n // Fullscreen\r\n _this._onFullscreenChange = function () {\r\n if (anyDoc_1.fullscreen !== undefined) {\r\n _this.isFullscreen = anyDoc_1.fullscreen;\r\n }\r\n else if (anyDoc_1.mozFullScreen !== undefined) {\r\n _this.isFullscreen = anyDoc_1.mozFullScreen;\r\n }\r\n else if (anyDoc_1.webkitIsFullScreen !== undefined) {\r\n _this.isFullscreen = anyDoc_1.webkitIsFullScreen;\r\n }\r\n else if (anyDoc_1.msIsFullScreen !== undefined) {\r\n _this.isFullscreen = anyDoc_1.msIsFullScreen;\r\n }\r\n // Pointer lock\r\n if (_this.isFullscreen && _this._pointerLockRequested && canvas_1) {\r\n Engine._RequestPointerlock(canvas_1);\r\n }\r\n };\r\n document.addEventListener(\"fullscreenchange\", _this._onFullscreenChange, false);\r\n document.addEventListener(\"mozfullscreenchange\", _this._onFullscreenChange, false);\r\n document.addEventListener(\"webkitfullscreenchange\", _this._onFullscreenChange, false);\r\n document.addEventListener(\"msfullscreenchange\", _this._onFullscreenChange, false);\r\n // Pointer lock\r\n _this._onPointerLockChange = function () {\r\n _this.isPointerLock = (anyDoc_1.mozPointerLockElement === canvas_1 ||\r\n anyDoc_1.webkitPointerLockElement === canvas_1 ||\r\n anyDoc_1.msPointerLockElement === canvas_1 ||\r\n anyDoc_1.pointerLockElement === canvas_1);\r\n };\r\n document.addEventListener(\"pointerlockchange\", _this._onPointerLockChange, false);\r\n document.addEventListener(\"mspointerlockchange\", _this._onPointerLockChange, false);\r\n document.addEventListener(\"mozpointerlockchange\", _this._onPointerLockChange, false);\r\n document.addEventListener(\"webkitpointerlockchange\", _this._onPointerLockChange, false);\r\n // Create Audio Engine if needed.\r\n if (!Engine.audioEngine && options.audioEngine && Engine.AudioEngineFactory) {\r\n Engine.audioEngine = Engine.AudioEngineFactory(_this.getRenderingCanvas());\r\n }\r\n }\r\n _this._connectVREvents();\r\n _this.enableOfflineSupport = Engine.OfflineProviderFactory !== undefined;\r\n if (!options.doNotHandleTouchAction) {\r\n _this._disableTouchAction();\r\n }\r\n _this._deterministicLockstep = !!options.deterministicLockstep;\r\n _this._lockstepMaxSteps = options.lockstepMaxSteps || 0;\r\n _this._timeStep = options.timeStep || 1 / 60;\r\n }\r\n // Load WebVR Devices\r\n _this._prepareVRComponent();\r\n if (options.autoEnableWebVR) {\r\n _this.initWebVR();\r\n }\r\n return _this;\r\n }\r\n Object.defineProperty(Engine, \"NpmPackage\", {\r\n /**\r\n * Returns the current npm package of the sdk\r\n */\r\n // Not mixed with Version for tooling purpose.\r\n get: function () {\r\n return ThinEngine.NpmPackage;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Engine, \"Version\", {\r\n /**\r\n * Returns the current version of the framework\r\n */\r\n get: function () {\r\n return ThinEngine.Version;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Engine, \"Instances\", {\r\n /** Gets the list of created engines */\r\n get: function () {\r\n return EngineStore.Instances;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Engine, \"LastCreatedEngine\", {\r\n /**\r\n * Gets the latest created engine\r\n */\r\n get: function () {\r\n return EngineStore.LastCreatedEngine;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Engine, \"LastCreatedScene\", {\r\n /**\r\n * Gets the latest created scene\r\n */\r\n get: function () {\r\n return EngineStore.LastCreatedScene;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Will flag all materials in all scenes in all engines as dirty to trigger new shader compilation\r\n * @param flag defines which part of the materials must be marked as dirty\r\n * @param predicate defines a predicate used to filter which materials should be affected\r\n */\r\n Engine.MarkAllMaterialsAsDirty = function (flag, predicate) {\r\n for (var engineIndex = 0; engineIndex < Engine.Instances.length; engineIndex++) {\r\n var engine = Engine.Instances[engineIndex];\r\n for (var sceneIndex = 0; sceneIndex < engine.scenes.length; sceneIndex++) {\r\n engine.scenes[sceneIndex].markAllMaterialsAsDirty(flag, predicate);\r\n }\r\n }\r\n };\r\n /**\r\n * Method called to create the default loading screen.\r\n * This can be overriden in your own app.\r\n * @param canvas The rendering canvas element\r\n * @returns The loading screen\r\n */\r\n Engine.DefaultLoadingScreenFactory = function (canvas) {\r\n throw _DevTools.WarnImport(\"LoadingScreen\");\r\n };\r\n Object.defineProperty(Engine.prototype, \"_supportsHardwareTextureRescaling\", {\r\n get: function () {\r\n return !!Engine._RescalePostProcessFactory;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Engine.prototype, \"performanceMonitor\", {\r\n /**\r\n * Gets the performance monitor attached to this engine\r\n * @see http://doc.babylonjs.com/how_to/optimizing_your_scene#engineinstrumentation\r\n */\r\n get: function () {\r\n return this._performanceMonitor;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n // Events\r\n /**\r\n * Gets the HTML element used to attach event listeners\r\n * @returns a HTML element\r\n */\r\n Engine.prototype.getInputElement = function () {\r\n return this._renderingCanvas;\r\n };\r\n /**\r\n * Gets current aspect ratio\r\n * @param viewportOwner defines the camera to use to get the aspect ratio\r\n * @param useScreen defines if screen size must be used (or the current render target if any)\r\n * @returns a number defining the aspect ratio\r\n */\r\n Engine.prototype.getAspectRatio = function (viewportOwner, useScreen) {\r\n if (useScreen === void 0) { useScreen = false; }\r\n var viewport = viewportOwner.viewport;\r\n return (this.getRenderWidth(useScreen) * viewport.width) / (this.getRenderHeight(useScreen) * viewport.height);\r\n };\r\n /**\r\n * Gets current screen aspect ratio\r\n * @returns a number defining the aspect ratio\r\n */\r\n Engine.prototype.getScreenAspectRatio = function () {\r\n return (this.getRenderWidth(true)) / (this.getRenderHeight(true));\r\n };\r\n /**\r\n * Gets the client rect of the HTML canvas attached with the current webGL context\r\n * @returns a client rectanglee\r\n */\r\n Engine.prototype.getRenderingCanvasClientRect = function () {\r\n if (!this._renderingCanvas) {\r\n return null;\r\n }\r\n return this._renderingCanvas.getBoundingClientRect();\r\n };\r\n /**\r\n * Gets the client rect of the HTML element used for events\r\n * @returns a client rectanglee\r\n */\r\n Engine.prototype.getInputElementClientRect = function () {\r\n if (!this._renderingCanvas) {\r\n return null;\r\n }\r\n return this.getInputElement().getBoundingClientRect();\r\n };\r\n /**\r\n * Gets a boolean indicating that the engine is running in deterministic lock step mode\r\n * @see http://doc.babylonjs.com/babylon101/animations#deterministic-lockstep\r\n * @returns true if engine is in deterministic lock step mode\r\n */\r\n Engine.prototype.isDeterministicLockStep = function () {\r\n return this._deterministicLockstep;\r\n };\r\n /**\r\n * Gets the max steps when engine is running in deterministic lock step\r\n * @see http://doc.babylonjs.com/babylon101/animations#deterministic-lockstep\r\n * @returns the max steps\r\n */\r\n Engine.prototype.getLockstepMaxSteps = function () {\r\n return this._lockstepMaxSteps;\r\n };\r\n /**\r\n * Returns the time in ms between steps when using deterministic lock step.\r\n * @returns time step in (ms)\r\n */\r\n Engine.prototype.getTimeStep = function () {\r\n return this._timeStep * 1000;\r\n };\r\n /**\r\n * Force the mipmap generation for the given render target texture\r\n * @param texture defines the render target texture to use\r\n * @param unbind defines whether or not to unbind the texture after generation. Defaults to true.\r\n */\r\n Engine.prototype.generateMipMapsForCubemap = function (texture, unbind) {\r\n if (unbind === void 0) { unbind = true; }\r\n if (texture.generateMipMaps) {\r\n var gl = this._gl;\r\n this._bindTextureDirectly(gl.TEXTURE_CUBE_MAP, texture, true);\r\n gl.generateMipmap(gl.TEXTURE_CUBE_MAP);\r\n if (unbind) {\r\n this._bindTextureDirectly(gl.TEXTURE_CUBE_MAP, null);\r\n }\r\n }\r\n };\r\n /** States */\r\n /**\r\n * Set various states to the webGL context\r\n * @param culling defines backface culling state\r\n * @param zOffset defines the value to apply to zOffset (0 by default)\r\n * @param force defines if states must be applied even if cache is up to date\r\n * @param reverseSide defines if culling must be reversed (CCW instead of CW and CW instead of CCW)\r\n */\r\n Engine.prototype.setState = function (culling, zOffset, force, reverseSide) {\r\n if (zOffset === void 0) { zOffset = 0; }\r\n if (reverseSide === void 0) { reverseSide = false; }\r\n // Culling\r\n if (this._depthCullingState.cull !== culling || force) {\r\n this._depthCullingState.cull = culling;\r\n }\r\n // Cull face\r\n var cullFace = this.cullBackFaces ? this._gl.BACK : this._gl.FRONT;\r\n if (this._depthCullingState.cullFace !== cullFace || force) {\r\n this._depthCullingState.cullFace = cullFace;\r\n }\r\n // Z offset\r\n this.setZOffset(zOffset);\r\n // Front face\r\n var frontFace = reverseSide ? this._gl.CW : this._gl.CCW;\r\n if (this._depthCullingState.frontFace !== frontFace || force) {\r\n this._depthCullingState.frontFace = frontFace;\r\n }\r\n };\r\n /**\r\n * Set the z offset to apply to current rendering\r\n * @param value defines the offset to apply\r\n */\r\n Engine.prototype.setZOffset = function (value) {\r\n this._depthCullingState.zOffset = value;\r\n };\r\n /**\r\n * Gets the current value of the zOffset\r\n * @returns the current zOffset state\r\n */\r\n Engine.prototype.getZOffset = function () {\r\n return this._depthCullingState.zOffset;\r\n };\r\n /**\r\n * Enable or disable depth buffering\r\n * @param enable defines the state to set\r\n */\r\n Engine.prototype.setDepthBuffer = function (enable) {\r\n this._depthCullingState.depthTest = enable;\r\n };\r\n /**\r\n * Gets a boolean indicating if depth writing is enabled\r\n * @returns the current depth writing state\r\n */\r\n Engine.prototype.getDepthWrite = function () {\r\n return this._depthCullingState.depthMask;\r\n };\r\n /**\r\n * Enable or disable depth writing\r\n * @param enable defines the state to set\r\n */\r\n Engine.prototype.setDepthWrite = function (enable) {\r\n this._depthCullingState.depthMask = enable;\r\n };\r\n /**\r\n * Gets a boolean indicating if stencil buffer is enabled\r\n * @returns the current stencil buffer state\r\n */\r\n Engine.prototype.getStencilBuffer = function () {\r\n return this._stencilState.stencilTest;\r\n };\r\n /**\r\n * Enable or disable the stencil buffer\r\n * @param enable defines if the stencil buffer must be enabled or disabled\r\n */\r\n Engine.prototype.setStencilBuffer = function (enable) {\r\n this._stencilState.stencilTest = enable;\r\n };\r\n /**\r\n * Gets the current stencil mask\r\n * @returns a number defining the new stencil mask to use\r\n */\r\n Engine.prototype.getStencilMask = function () {\r\n return this._stencilState.stencilMask;\r\n };\r\n /**\r\n * Sets the current stencil mask\r\n * @param mask defines the new stencil mask to use\r\n */\r\n Engine.prototype.setStencilMask = function (mask) {\r\n this._stencilState.stencilMask = mask;\r\n };\r\n /**\r\n * Gets the current stencil function\r\n * @returns a number defining the stencil function to use\r\n */\r\n Engine.prototype.getStencilFunction = function () {\r\n return this._stencilState.stencilFunc;\r\n };\r\n /**\r\n * Gets the current stencil reference value\r\n * @returns a number defining the stencil reference value to use\r\n */\r\n Engine.prototype.getStencilFunctionReference = function () {\r\n return this._stencilState.stencilFuncRef;\r\n };\r\n /**\r\n * Gets the current stencil mask\r\n * @returns a number defining the stencil mask to use\r\n */\r\n Engine.prototype.getStencilFunctionMask = function () {\r\n return this._stencilState.stencilFuncMask;\r\n };\r\n /**\r\n * Sets the current stencil function\r\n * @param stencilFunc defines the new stencil function to use\r\n */\r\n Engine.prototype.setStencilFunction = function (stencilFunc) {\r\n this._stencilState.stencilFunc = stencilFunc;\r\n };\r\n /**\r\n * Sets the current stencil reference\r\n * @param reference defines the new stencil reference to use\r\n */\r\n Engine.prototype.setStencilFunctionReference = function (reference) {\r\n this._stencilState.stencilFuncRef = reference;\r\n };\r\n /**\r\n * Sets the current stencil mask\r\n * @param mask defines the new stencil mask to use\r\n */\r\n Engine.prototype.setStencilFunctionMask = function (mask) {\r\n this._stencilState.stencilFuncMask = mask;\r\n };\r\n /**\r\n * Gets the current stencil operation when stencil fails\r\n * @returns a number defining stencil operation to use when stencil fails\r\n */\r\n Engine.prototype.getStencilOperationFail = function () {\r\n return this._stencilState.stencilOpStencilFail;\r\n };\r\n /**\r\n * Gets the current stencil operation when depth fails\r\n * @returns a number defining stencil operation to use when depth fails\r\n */\r\n Engine.prototype.getStencilOperationDepthFail = function () {\r\n return this._stencilState.stencilOpDepthFail;\r\n };\r\n /**\r\n * Gets the current stencil operation when stencil passes\r\n * @returns a number defining stencil operation to use when stencil passes\r\n */\r\n Engine.prototype.getStencilOperationPass = function () {\r\n return this._stencilState.stencilOpStencilDepthPass;\r\n };\r\n /**\r\n * Sets the stencil operation to use when stencil fails\r\n * @param operation defines the stencil operation to use when stencil fails\r\n */\r\n Engine.prototype.setStencilOperationFail = function (operation) {\r\n this._stencilState.stencilOpStencilFail = operation;\r\n };\r\n /**\r\n * Sets the stencil operation to use when depth fails\r\n * @param operation defines the stencil operation to use when depth fails\r\n */\r\n Engine.prototype.setStencilOperationDepthFail = function (operation) {\r\n this._stencilState.stencilOpDepthFail = operation;\r\n };\r\n /**\r\n * Sets the stencil operation to use when stencil passes\r\n * @param operation defines the stencil operation to use when stencil passes\r\n */\r\n Engine.prototype.setStencilOperationPass = function (operation) {\r\n this._stencilState.stencilOpStencilDepthPass = operation;\r\n };\r\n /**\r\n * Sets a boolean indicating if the dithering state is enabled or disabled\r\n * @param value defines the dithering state\r\n */\r\n Engine.prototype.setDitheringState = function (value) {\r\n if (value) {\r\n this._gl.enable(this._gl.DITHER);\r\n }\r\n else {\r\n this._gl.disable(this._gl.DITHER);\r\n }\r\n };\r\n /**\r\n * Sets a boolean indicating if the rasterizer state is enabled or disabled\r\n * @param value defines the rasterizer state\r\n */\r\n Engine.prototype.setRasterizerState = function (value) {\r\n if (value) {\r\n this._gl.disable(this._gl.RASTERIZER_DISCARD);\r\n }\r\n else {\r\n this._gl.enable(this._gl.RASTERIZER_DISCARD);\r\n }\r\n };\r\n /**\r\n * Gets the current depth function\r\n * @returns a number defining the depth function\r\n */\r\n Engine.prototype.getDepthFunction = function () {\r\n return this._depthCullingState.depthFunc;\r\n };\r\n /**\r\n * Sets the current depth function\r\n * @param depthFunc defines the function to use\r\n */\r\n Engine.prototype.setDepthFunction = function (depthFunc) {\r\n this._depthCullingState.depthFunc = depthFunc;\r\n };\r\n /**\r\n * Sets the current depth function to GREATER\r\n */\r\n Engine.prototype.setDepthFunctionToGreater = function () {\r\n this._depthCullingState.depthFunc = this._gl.GREATER;\r\n };\r\n /**\r\n * Sets the current depth function to GEQUAL\r\n */\r\n Engine.prototype.setDepthFunctionToGreaterOrEqual = function () {\r\n this._depthCullingState.depthFunc = this._gl.GEQUAL;\r\n };\r\n /**\r\n * Sets the current depth function to LESS\r\n */\r\n Engine.prototype.setDepthFunctionToLess = function () {\r\n this._depthCullingState.depthFunc = this._gl.LESS;\r\n };\r\n /**\r\n * Sets the current depth function to LEQUAL\r\n */\r\n Engine.prototype.setDepthFunctionToLessOrEqual = function () {\r\n this._depthCullingState.depthFunc = this._gl.LEQUAL;\r\n };\r\n /**\r\n * Caches the the state of the stencil buffer\r\n */\r\n Engine.prototype.cacheStencilState = function () {\r\n this._cachedStencilBuffer = this.getStencilBuffer();\r\n this._cachedStencilFunction = this.getStencilFunction();\r\n this._cachedStencilMask = this.getStencilMask();\r\n this._cachedStencilOperationPass = this.getStencilOperationPass();\r\n this._cachedStencilOperationFail = this.getStencilOperationFail();\r\n this._cachedStencilOperationDepthFail = this.getStencilOperationDepthFail();\r\n this._cachedStencilReference = this.getStencilFunctionReference();\r\n };\r\n /**\r\n * Restores the state of the stencil buffer\r\n */\r\n Engine.prototype.restoreStencilState = function () {\r\n this.setStencilFunction(this._cachedStencilFunction);\r\n this.setStencilMask(this._cachedStencilMask);\r\n this.setStencilBuffer(this._cachedStencilBuffer);\r\n this.setStencilOperationPass(this._cachedStencilOperationPass);\r\n this.setStencilOperationFail(this._cachedStencilOperationFail);\r\n this.setStencilOperationDepthFail(this._cachedStencilOperationDepthFail);\r\n this.setStencilFunctionReference(this._cachedStencilReference);\r\n };\r\n /**\r\n * Directly set the WebGL Viewport\r\n * @param x defines the x coordinate of the viewport (in screen space)\r\n * @param y defines the y coordinate of the viewport (in screen space)\r\n * @param width defines the width of the viewport (in screen space)\r\n * @param height defines the height of the viewport (in screen space)\r\n * @return the current viewport Object (if any) that is being replaced by this call. You can restore this viewport later on to go back to the original state\r\n */\r\n Engine.prototype.setDirectViewport = function (x, y, width, height) {\r\n var currentViewport = this._cachedViewport;\r\n this._cachedViewport = null;\r\n this._viewport(x, y, width, height);\r\n return currentViewport;\r\n };\r\n /**\r\n * Executes a scissor clear (ie. a clear on a specific portion of the screen)\r\n * @param x defines the x-coordinate of the top left corner of the clear rectangle\r\n * @param y defines the y-coordinate of the corner of the clear rectangle\r\n * @param width defines the width of the clear rectangle\r\n * @param height defines the height of the clear rectangle\r\n * @param clearColor defines the clear color\r\n */\r\n Engine.prototype.scissorClear = function (x, y, width, height, clearColor) {\r\n this.enableScissor(x, y, width, height);\r\n this.clear(clearColor, true, true, true);\r\n this.disableScissor();\r\n };\r\n /**\r\n * Enable scissor test on a specific rectangle (ie. render will only be executed on a specific portion of the screen)\r\n * @param x defines the x-coordinate of the top left corner of the clear rectangle\r\n * @param y defines the y-coordinate of the corner of the clear rectangle\r\n * @param width defines the width of the clear rectangle\r\n * @param height defines the height of the clear rectangle\r\n */\r\n Engine.prototype.enableScissor = function (x, y, width, height) {\r\n var gl = this._gl;\r\n // Change state\r\n gl.enable(gl.SCISSOR_TEST);\r\n gl.scissor(x, y, width, height);\r\n };\r\n /**\r\n * Disable previously set scissor test rectangle\r\n */\r\n Engine.prototype.disableScissor = function () {\r\n var gl = this._gl;\r\n gl.disable(gl.SCISSOR_TEST);\r\n };\r\n Engine.prototype._reportDrawCall = function () {\r\n this._drawCalls.addCount(1, false);\r\n };\r\n /**\r\n * Initializes a webVR display and starts listening to display change events\r\n * The onVRDisplayChangedObservable will be notified upon these changes\r\n * @returns The onVRDisplayChangedObservable\r\n */\r\n Engine.prototype.initWebVR = function () {\r\n throw _DevTools.WarnImport(\"WebVRCamera\");\r\n };\r\n /** @hidden */\r\n Engine.prototype._prepareVRComponent = function () {\r\n // Do nothing as the engine side effect will overload it\r\n };\r\n /** @hidden */\r\n Engine.prototype._connectVREvents = function (canvas, document) {\r\n // Do nothing as the engine side effect will overload it\r\n };\r\n /** @hidden */\r\n Engine.prototype._submitVRFrame = function () {\r\n // Do nothing as the engine side effect will overload it\r\n };\r\n /**\r\n * Call this function to leave webVR mode\r\n * Will do nothing if webVR is not supported or if there is no webVR device\r\n * @see http://doc.babylonjs.com/how_to/webvr_camera\r\n */\r\n Engine.prototype.disableVR = function () {\r\n // Do nothing as the engine side effect will overload it\r\n };\r\n /**\r\n * Gets a boolean indicating that the system is in VR mode and is presenting\r\n * @returns true if VR mode is engaged\r\n */\r\n Engine.prototype.isVRPresenting = function () {\r\n return false;\r\n };\r\n /** @hidden */\r\n Engine.prototype._requestVRFrame = function () {\r\n // Do nothing as the engine side effect will overload it\r\n };\r\n /** @hidden */\r\n Engine.prototype._loadFileAsync = function (url, offlineProvider, useArrayBuffer) {\r\n var _this = this;\r\n return new Promise(function (resolve, reject) {\r\n _this._loadFile(url, function (data) {\r\n resolve(data);\r\n }, undefined, offlineProvider, useArrayBuffer, function (request, exception) {\r\n reject(exception);\r\n });\r\n });\r\n };\r\n /**\r\n * Gets the source code of the vertex shader associated with a specific webGL program\r\n * @param program defines the program to use\r\n * @returns a string containing the source code of the vertex shader associated with the program\r\n */\r\n Engine.prototype.getVertexShaderSource = function (program) {\r\n var shaders = this._gl.getAttachedShaders(program);\r\n if (!shaders) {\r\n return null;\r\n }\r\n return this._gl.getShaderSource(shaders[0]);\r\n };\r\n /**\r\n * Gets the source code of the fragment shader associated with a specific webGL program\r\n * @param program defines the program to use\r\n * @returns a string containing the source code of the fragment shader associated with the program\r\n */\r\n Engine.prototype.getFragmentShaderSource = function (program) {\r\n var shaders = this._gl.getAttachedShaders(program);\r\n if (!shaders) {\r\n return null;\r\n }\r\n return this._gl.getShaderSource(shaders[1]);\r\n };\r\n /**\r\n * Sets a depth stencil texture from a render target to the according uniform.\r\n * @param channel The texture channel\r\n * @param uniform The uniform to set\r\n * @param texture The render target texture containing the depth stencil texture to apply\r\n */\r\n Engine.prototype.setDepthStencilTexture = function (channel, uniform, texture) {\r\n if (channel === undefined) {\r\n return;\r\n }\r\n if (uniform) {\r\n this._boundUniforms[channel] = uniform;\r\n }\r\n if (!texture || !texture.depthStencilTexture) {\r\n this._setTexture(channel, null);\r\n }\r\n else {\r\n this._setTexture(channel, texture, false, true);\r\n }\r\n };\r\n /**\r\n * Sets a texture to the webGL context from a postprocess\r\n * @param channel defines the channel to use\r\n * @param postProcess defines the source postprocess\r\n */\r\n Engine.prototype.setTextureFromPostProcess = function (channel, postProcess) {\r\n this._bindTexture(channel, postProcess ? postProcess._textures.data[postProcess._currentRenderTextureInd] : null);\r\n };\r\n /**\r\n * Binds the output of the passed in post process to the texture channel specified\r\n * @param channel The channel the texture should be bound to\r\n * @param postProcess The post process which's output should be bound\r\n */\r\n Engine.prototype.setTextureFromPostProcessOutput = function (channel, postProcess) {\r\n this._bindTexture(channel, postProcess ? postProcess._outputTexture : null);\r\n };\r\n /** @hidden */\r\n Engine.prototype._convertRGBtoRGBATextureData = function (rgbData, width, height, textureType) {\r\n // Create new RGBA data container.\r\n var rgbaData;\r\n if (textureType === 1) {\r\n rgbaData = new Float32Array(width * height * 4);\r\n }\r\n else {\r\n rgbaData = new Uint32Array(width * height * 4);\r\n }\r\n // Convert each pixel.\r\n for (var x = 0; x < width; x++) {\r\n for (var y = 0; y < height; y++) {\r\n var index = (y * width + x) * 3;\r\n var newIndex = (y * width + x) * 4;\r\n // Map Old Value to new value.\r\n rgbaData[newIndex + 0] = rgbData[index + 0];\r\n rgbaData[newIndex + 1] = rgbData[index + 1];\r\n rgbaData[newIndex + 2] = rgbData[index + 2];\r\n // Add fully opaque alpha channel.\r\n rgbaData[newIndex + 3] = 1;\r\n }\r\n }\r\n return rgbaData;\r\n };\r\n Engine.prototype._rebuildBuffers = function () {\r\n // Index / Vertex\r\n for (var _i = 0, _a = this.scenes; _i < _a.length; _i++) {\r\n var scene = _a[_i];\r\n scene.resetCachedMaterial();\r\n scene._rebuildGeometries();\r\n scene._rebuildTextures();\r\n }\r\n _super.prototype._rebuildBuffers.call(this);\r\n };\r\n /** @hidden */\r\n Engine.prototype._renderFrame = function () {\r\n for (var index = 0; index < this._activeRenderLoops.length; index++) {\r\n var renderFunction = this._activeRenderLoops[index];\r\n renderFunction();\r\n }\r\n };\r\n Engine.prototype._renderLoop = function () {\r\n if (!this._contextWasLost) {\r\n var shouldRender = true;\r\n if (!this.renderEvenInBackground && this._windowIsBackground) {\r\n shouldRender = false;\r\n }\r\n if (shouldRender) {\r\n // Start new frame\r\n this.beginFrame();\r\n // Child canvases\r\n if (!this._renderViews()) {\r\n // Main frame\r\n this._renderFrame();\r\n }\r\n // Present\r\n this.endFrame();\r\n }\r\n }\r\n if (this._activeRenderLoops.length > 0) {\r\n // Register new frame\r\n if (this.customAnimationFrameRequester) {\r\n this.customAnimationFrameRequester.requestID = this._queueNewFrame(this.customAnimationFrameRequester.renderFunction || this._boundRenderFunction, this.customAnimationFrameRequester);\r\n this._frameHandler = this.customAnimationFrameRequester.requestID;\r\n }\r\n else if (this.isVRPresenting()) {\r\n this._requestVRFrame();\r\n }\r\n else {\r\n this._frameHandler = this._queueNewFrame(this._boundRenderFunction, this.getHostWindow());\r\n }\r\n }\r\n else {\r\n this._renderingQueueLaunched = false;\r\n }\r\n };\r\n /** @hidden */\r\n Engine.prototype._renderViews = function () {\r\n return false;\r\n };\r\n /**\r\n * Toggle full screen mode\r\n * @param requestPointerLock defines if a pointer lock should be requested from the user\r\n */\r\n Engine.prototype.switchFullscreen = function (requestPointerLock) {\r\n if (this.isFullscreen) {\r\n this.exitFullscreen();\r\n }\r\n else {\r\n this.enterFullscreen(requestPointerLock);\r\n }\r\n };\r\n /**\r\n * Enters full screen mode\r\n * @param requestPointerLock defines if a pointer lock should be requested from the user\r\n */\r\n Engine.prototype.enterFullscreen = function (requestPointerLock) {\r\n if (!this.isFullscreen) {\r\n this._pointerLockRequested = requestPointerLock;\r\n if (this._renderingCanvas) {\r\n Engine._RequestFullscreen(this._renderingCanvas);\r\n }\r\n }\r\n };\r\n /**\r\n * Exits full screen mode\r\n */\r\n Engine.prototype.exitFullscreen = function () {\r\n if (this.isFullscreen) {\r\n Engine._ExitFullscreen();\r\n }\r\n };\r\n /**\r\n * Enters Pointerlock mode\r\n */\r\n Engine.prototype.enterPointerlock = function () {\r\n if (this._renderingCanvas) {\r\n Engine._RequestPointerlock(this._renderingCanvas);\r\n }\r\n };\r\n /**\r\n * Exits Pointerlock mode\r\n */\r\n Engine.prototype.exitPointerlock = function () {\r\n Engine._ExitPointerlock();\r\n };\r\n /**\r\n * Begin a new frame\r\n */\r\n Engine.prototype.beginFrame = function () {\r\n this._measureFps();\r\n this.onBeginFrameObservable.notifyObservers(this);\r\n _super.prototype.beginFrame.call(this);\r\n };\r\n /**\r\n * Enf the current frame\r\n */\r\n Engine.prototype.endFrame = function () {\r\n _super.prototype.endFrame.call(this);\r\n this._submitVRFrame();\r\n this.onEndFrameObservable.notifyObservers(this);\r\n };\r\n Engine.prototype.resize = function () {\r\n // We're not resizing the size of the canvas while in VR mode & presenting\r\n if (this.isVRPresenting()) {\r\n return;\r\n }\r\n _super.prototype.resize.call(this);\r\n };\r\n /**\r\n * Force a specific size of the canvas\r\n * @param width defines the new canvas' width\r\n * @param height defines the new canvas' height\r\n */\r\n Engine.prototype.setSize = function (width, height) {\r\n if (!this._renderingCanvas) {\r\n return;\r\n }\r\n _super.prototype.setSize.call(this, width, height);\r\n if (this.scenes) {\r\n for (var index = 0; index < this.scenes.length; index++) {\r\n var scene = this.scenes[index];\r\n for (var camIndex = 0; camIndex < scene.cameras.length; camIndex++) {\r\n var cam = scene.cameras[camIndex];\r\n cam._currentRenderId = 0;\r\n }\r\n }\r\n if (this.onResizeObservable.hasObservers) {\r\n this.onResizeObservable.notifyObservers(this);\r\n }\r\n }\r\n };\r\n /**\r\n * Updates a dynamic vertex buffer.\r\n * @param vertexBuffer the vertex buffer to update\r\n * @param data the data used to update the vertex buffer\r\n * @param byteOffset the byte offset of the data\r\n * @param byteLength the byte length of the data\r\n */\r\n Engine.prototype.updateDynamicVertexBuffer = function (vertexBuffer, data, byteOffset, byteLength) {\r\n this.bindArrayBuffer(vertexBuffer);\r\n if (byteOffset === undefined) {\r\n byteOffset = 0;\r\n }\r\n var dataLength = data.length || data.byteLength;\r\n if (byteLength === undefined || byteLength >= dataLength && byteOffset === 0) {\r\n if (data instanceof Array) {\r\n this._gl.bufferSubData(this._gl.ARRAY_BUFFER, byteOffset, new Float32Array(data));\r\n }\r\n else {\r\n this._gl.bufferSubData(this._gl.ARRAY_BUFFER, byteOffset, data);\r\n }\r\n }\r\n else {\r\n if (data instanceof Array) {\r\n this._gl.bufferSubData(this._gl.ARRAY_BUFFER, 0, new Float32Array(data).subarray(byteOffset, byteOffset + byteLength));\r\n }\r\n else {\r\n if (data instanceof ArrayBuffer) {\r\n data = new Uint8Array(data, byteOffset, byteLength);\r\n }\r\n else {\r\n data = new Uint8Array(data.buffer, data.byteOffset + byteOffset, byteLength);\r\n }\r\n this._gl.bufferSubData(this._gl.ARRAY_BUFFER, 0, data);\r\n }\r\n }\r\n this._resetVertexBufferBinding();\r\n };\r\n Engine.prototype._deletePipelineContext = function (pipelineContext) {\r\n var webGLPipelineContext = pipelineContext;\r\n if (webGLPipelineContext && webGLPipelineContext.program) {\r\n if (webGLPipelineContext.transformFeedback) {\r\n this.deleteTransformFeedback(webGLPipelineContext.transformFeedback);\r\n webGLPipelineContext.transformFeedback = null;\r\n }\r\n }\r\n _super.prototype._deletePipelineContext.call(this, pipelineContext);\r\n };\r\n Engine.prototype.createShaderProgram = function (pipelineContext, vertexCode, fragmentCode, defines, context, transformFeedbackVaryings) {\r\n if (transformFeedbackVaryings === void 0) { transformFeedbackVaryings = null; }\r\n context = context || this._gl;\r\n this.onBeforeShaderCompilationObservable.notifyObservers(this);\r\n var program = _super.prototype.createShaderProgram.call(this, pipelineContext, vertexCode, fragmentCode, defines, context, transformFeedbackVaryings);\r\n this.onAfterShaderCompilationObservable.notifyObservers(this);\r\n return program;\r\n };\r\n Engine.prototype._createShaderProgram = function (pipelineContext, vertexShader, fragmentShader, context, transformFeedbackVaryings) {\r\n if (transformFeedbackVaryings === void 0) { transformFeedbackVaryings = null; }\r\n var shaderProgram = context.createProgram();\r\n pipelineContext.program = shaderProgram;\r\n if (!shaderProgram) {\r\n throw new Error(\"Unable to create program\");\r\n }\r\n context.attachShader(shaderProgram, vertexShader);\r\n context.attachShader(shaderProgram, fragmentShader);\r\n if (this.webGLVersion > 1 && transformFeedbackVaryings) {\r\n var transformFeedback = this.createTransformFeedback();\r\n this.bindTransformFeedback(transformFeedback);\r\n this.setTranformFeedbackVaryings(shaderProgram, transformFeedbackVaryings);\r\n pipelineContext.transformFeedback = transformFeedback;\r\n }\r\n context.linkProgram(shaderProgram);\r\n if (this.webGLVersion > 1 && transformFeedbackVaryings) {\r\n this.bindTransformFeedback(null);\r\n }\r\n pipelineContext.context = context;\r\n pipelineContext.vertexShader = vertexShader;\r\n pipelineContext.fragmentShader = fragmentShader;\r\n if (!pipelineContext.isParallelCompiled) {\r\n this._finalizePipelineContext(pipelineContext);\r\n }\r\n return shaderProgram;\r\n };\r\n Engine.prototype._releaseTexture = function (texture) {\r\n _super.prototype._releaseTexture.call(this, texture);\r\n // Set output texture of post process to null if the texture has been released/disposed\r\n this.scenes.forEach(function (scene) {\r\n scene.postProcesses.forEach(function (postProcess) {\r\n if (postProcess._outputTexture == texture) {\r\n postProcess._outputTexture = null;\r\n }\r\n });\r\n scene.cameras.forEach(function (camera) {\r\n camera._postProcesses.forEach(function (postProcess) {\r\n if (postProcess) {\r\n if (postProcess._outputTexture == texture) {\r\n postProcess._outputTexture = null;\r\n }\r\n }\r\n });\r\n });\r\n });\r\n };\r\n /**\r\n * @hidden\r\n * Rescales a texture\r\n * @param source input texutre\r\n * @param destination destination texture\r\n * @param scene scene to use to render the resize\r\n * @param internalFormat format to use when resizing\r\n * @param onComplete callback to be called when resize has completed\r\n */\r\n Engine.prototype._rescaleTexture = function (source, destination, scene, internalFormat, onComplete) {\r\n var _this = this;\r\n this._gl.texParameteri(this._gl.TEXTURE_2D, this._gl.TEXTURE_MAG_FILTER, this._gl.LINEAR);\r\n this._gl.texParameteri(this._gl.TEXTURE_2D, this._gl.TEXTURE_MIN_FILTER, this._gl.LINEAR);\r\n this._gl.texParameteri(this._gl.TEXTURE_2D, this._gl.TEXTURE_WRAP_S, this._gl.CLAMP_TO_EDGE);\r\n this._gl.texParameteri(this._gl.TEXTURE_2D, this._gl.TEXTURE_WRAP_T, this._gl.CLAMP_TO_EDGE);\r\n var rtt = this.createRenderTargetTexture({\r\n width: destination.width,\r\n height: destination.height,\r\n }, {\r\n generateMipMaps: false,\r\n type: 0,\r\n samplingMode: 2,\r\n generateDepthBuffer: false,\r\n generateStencilBuffer: false\r\n });\r\n if (!this._rescalePostProcess && Engine._RescalePostProcessFactory) {\r\n this._rescalePostProcess = Engine._RescalePostProcessFactory(this);\r\n }\r\n this._rescalePostProcess.getEffect().executeWhenCompiled(function () {\r\n _this._rescalePostProcess.onApply = function (effect) {\r\n effect._bindTexture(\"textureSampler\", source);\r\n };\r\n var hostingScene = scene;\r\n if (!hostingScene) {\r\n hostingScene = _this.scenes[_this.scenes.length - 1];\r\n }\r\n hostingScene.postProcessManager.directRender([_this._rescalePostProcess], rtt, true);\r\n _this._bindTextureDirectly(_this._gl.TEXTURE_2D, destination, true);\r\n _this._gl.copyTexImage2D(_this._gl.TEXTURE_2D, 0, internalFormat, 0, 0, destination.width, destination.height, 0);\r\n _this.unBindFramebuffer(rtt);\r\n _this._releaseTexture(rtt);\r\n if (onComplete) {\r\n onComplete();\r\n }\r\n });\r\n };\r\n // FPS\r\n /**\r\n * Gets the current framerate\r\n * @returns a number representing the framerate\r\n */\r\n Engine.prototype.getFps = function () {\r\n return this._fps;\r\n };\r\n /**\r\n * Gets the time spent between current and previous frame\r\n * @returns a number representing the delta time in ms\r\n */\r\n Engine.prototype.getDeltaTime = function () {\r\n return this._deltaTime;\r\n };\r\n Engine.prototype._measureFps = function () {\r\n this._performanceMonitor.sampleFrame();\r\n this._fps = this._performanceMonitor.averageFPS;\r\n this._deltaTime = this._performanceMonitor.instantaneousFrameTime || 0;\r\n };\r\n /** @hidden */\r\n Engine.prototype._uploadImageToTexture = function (texture, image, faceIndex, lod) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (lod === void 0) { lod = 0; }\r\n var gl = this._gl;\r\n var textureType = this._getWebGLTextureType(texture.type);\r\n var format = this._getInternalFormat(texture.format);\r\n var internalFormat = this._getRGBABufferInternalSizedFormat(texture.type, format);\r\n var bindTarget = texture.isCube ? gl.TEXTURE_CUBE_MAP : gl.TEXTURE_2D;\r\n this._bindTextureDirectly(bindTarget, texture, true);\r\n this._unpackFlipY(texture.invertY);\r\n var target = gl.TEXTURE_2D;\r\n if (texture.isCube) {\r\n target = gl.TEXTURE_CUBE_MAP_POSITIVE_X + faceIndex;\r\n }\r\n gl.texImage2D(target, lod, internalFormat, format, textureType, image);\r\n this._bindTextureDirectly(bindTarget, null, true);\r\n };\r\n /**\r\n * Update a dynamic index buffer\r\n * @param indexBuffer defines the target index buffer\r\n * @param indices defines the data to update\r\n * @param offset defines the offset in the target index buffer where update should start\r\n */\r\n Engine.prototype.updateDynamicIndexBuffer = function (indexBuffer, indices, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n // Force cache update\r\n this._currentBoundBuffer[this._gl.ELEMENT_ARRAY_BUFFER] = null;\r\n this.bindIndexBuffer(indexBuffer);\r\n var arrayBuffer;\r\n if (indices instanceof Uint16Array || indices instanceof Uint32Array) {\r\n arrayBuffer = indices;\r\n }\r\n else {\r\n arrayBuffer = indexBuffer.is32Bits ? new Uint32Array(indices) : new Uint16Array(indices);\r\n }\r\n this._gl.bufferData(this._gl.ELEMENT_ARRAY_BUFFER, arrayBuffer, this._gl.DYNAMIC_DRAW);\r\n this._resetIndexBufferBinding();\r\n };\r\n /**\r\n * Updates the sample count of a render target texture\r\n * @see http://doc.babylonjs.com/features/webgl2#multisample-render-targets\r\n * @param texture defines the texture to update\r\n * @param samples defines the sample count to set\r\n * @returns the effective sample count (could be 0 if multisample render targets are not supported)\r\n */\r\n Engine.prototype.updateRenderTargetTextureSampleCount = function (texture, samples) {\r\n if (this.webGLVersion < 2 || !texture) {\r\n return 1;\r\n }\r\n if (texture.samples === samples) {\r\n return samples;\r\n }\r\n var gl = this._gl;\r\n samples = Math.min(samples, this.getCaps().maxMSAASamples);\r\n // Dispose previous render buffers\r\n if (texture._depthStencilBuffer) {\r\n gl.deleteRenderbuffer(texture._depthStencilBuffer);\r\n texture._depthStencilBuffer = null;\r\n }\r\n if (texture._MSAAFramebuffer) {\r\n gl.deleteFramebuffer(texture._MSAAFramebuffer);\r\n texture._MSAAFramebuffer = null;\r\n }\r\n if (texture._MSAARenderBuffer) {\r\n gl.deleteRenderbuffer(texture._MSAARenderBuffer);\r\n texture._MSAARenderBuffer = null;\r\n }\r\n if (samples > 1 && gl.renderbufferStorageMultisample) {\r\n var framebuffer = gl.createFramebuffer();\r\n if (!framebuffer) {\r\n throw new Error(\"Unable to create multi sampled framebuffer\");\r\n }\r\n texture._MSAAFramebuffer = framebuffer;\r\n this._bindUnboundFramebuffer(texture._MSAAFramebuffer);\r\n var colorRenderbuffer = gl.createRenderbuffer();\r\n if (!colorRenderbuffer) {\r\n throw new Error(\"Unable to create multi sampled framebuffer\");\r\n }\r\n gl.bindRenderbuffer(gl.RENDERBUFFER, colorRenderbuffer);\r\n gl.renderbufferStorageMultisample(gl.RENDERBUFFER, samples, this._getRGBAMultiSampleBufferFormat(texture.type), texture.width, texture.height);\r\n gl.framebufferRenderbuffer(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.RENDERBUFFER, colorRenderbuffer);\r\n texture._MSAARenderBuffer = colorRenderbuffer;\r\n }\r\n else {\r\n this._bindUnboundFramebuffer(texture._framebuffer);\r\n }\r\n texture.samples = samples;\r\n texture._depthStencilBuffer = this._setupFramebufferDepthAttachments(texture._generateStencilBuffer, texture._generateDepthBuffer, texture.width, texture.height, samples);\r\n this._bindUnboundFramebuffer(null);\r\n return samples;\r\n };\r\n /**\r\n * Updates a depth texture Comparison Mode and Function.\r\n * If the comparison Function is equal to 0, the mode will be set to none.\r\n * Otherwise, this only works in webgl 2 and requires a shadow sampler in the shader.\r\n * @param texture The texture to set the comparison function for\r\n * @param comparisonFunction The comparison function to set, 0 if no comparison required\r\n */\r\n Engine.prototype.updateTextureComparisonFunction = function (texture, comparisonFunction) {\r\n if (this.webGLVersion === 1) {\r\n Logger.Error(\"WebGL 1 does not support texture comparison.\");\r\n return;\r\n }\r\n var gl = this._gl;\r\n if (texture.isCube) {\r\n this._bindTextureDirectly(this._gl.TEXTURE_CUBE_MAP, texture, true);\r\n if (comparisonFunction === 0) {\r\n gl.texParameteri(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_COMPARE_FUNC, 515);\r\n gl.texParameteri(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_COMPARE_MODE, gl.NONE);\r\n }\r\n else {\r\n gl.texParameteri(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_COMPARE_FUNC, comparisonFunction);\r\n gl.texParameteri(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_COMPARE_MODE, gl.COMPARE_REF_TO_TEXTURE);\r\n }\r\n this._bindTextureDirectly(this._gl.TEXTURE_CUBE_MAP, null);\r\n }\r\n else {\r\n this._bindTextureDirectly(this._gl.TEXTURE_2D, texture, true);\r\n if (comparisonFunction === 0) {\r\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_COMPARE_FUNC, 515);\r\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_COMPARE_MODE, gl.NONE);\r\n }\r\n else {\r\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_COMPARE_FUNC, comparisonFunction);\r\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_COMPARE_MODE, gl.COMPARE_REF_TO_TEXTURE);\r\n }\r\n this._bindTextureDirectly(this._gl.TEXTURE_2D, null);\r\n }\r\n texture._comparisonFunction = comparisonFunction;\r\n };\r\n /**\r\n * Creates a webGL buffer to use with instanciation\r\n * @param capacity defines the size of the buffer\r\n * @returns the webGL buffer\r\n */\r\n Engine.prototype.createInstancesBuffer = function (capacity) {\r\n var buffer = this._gl.createBuffer();\r\n if (!buffer) {\r\n throw new Error(\"Unable to create instance buffer\");\r\n }\r\n var result = new WebGLDataBuffer(buffer);\r\n result.capacity = capacity;\r\n this.bindArrayBuffer(result);\r\n this._gl.bufferData(this._gl.ARRAY_BUFFER, capacity, this._gl.DYNAMIC_DRAW);\r\n return result;\r\n };\r\n /**\r\n * Delete a webGL buffer used with instanciation\r\n * @param buffer defines the webGL buffer to delete\r\n */\r\n Engine.prototype.deleteInstancesBuffer = function (buffer) {\r\n this._gl.deleteBuffer(buffer);\r\n };\r\n Engine.prototype._clientWaitAsync = function (sync, flags, interval_ms) {\r\n if (flags === void 0) { flags = 0; }\r\n if (interval_ms === void 0) { interval_ms = 10; }\r\n var gl = this._gl;\r\n return new Promise(function (resolve, reject) {\r\n var check = function () {\r\n var res = gl.clientWaitSync(sync, flags, 0);\r\n if (res == gl.WAIT_FAILED) {\r\n reject();\r\n return;\r\n }\r\n if (res == gl.TIMEOUT_EXPIRED) {\r\n setTimeout(check, interval_ms);\r\n return;\r\n }\r\n resolve();\r\n };\r\n check();\r\n });\r\n };\r\n /** @hidden */\r\n Engine.prototype._readPixelsAsync = function (x, y, w, h, format, type, outputBuffer) {\r\n if (this._webGLVersion < 2) {\r\n throw new Error(\"_readPixelsAsync only work on WebGL2+\");\r\n }\r\n var gl = this._gl;\r\n var buf = gl.createBuffer();\r\n gl.bindBuffer(gl.PIXEL_PACK_BUFFER, buf);\r\n gl.bufferData(gl.PIXEL_PACK_BUFFER, outputBuffer.byteLength, gl.STREAM_READ);\r\n gl.readPixels(x, y, w, h, format, type, 0);\r\n gl.bindBuffer(gl.PIXEL_PACK_BUFFER, null);\r\n var sync = gl.fenceSync(gl.SYNC_GPU_COMMANDS_COMPLETE, 0);\r\n if (!sync) {\r\n return null;\r\n }\r\n gl.flush();\r\n return this._clientWaitAsync(sync, 0, 10).then(function () {\r\n gl.deleteSync(sync);\r\n gl.bindBuffer(gl.PIXEL_PACK_BUFFER, buf);\r\n gl.getBufferSubData(gl.PIXEL_PACK_BUFFER, 0, outputBuffer);\r\n gl.bindBuffer(gl.PIXEL_PACK_BUFFER, null);\r\n gl.deleteBuffer(buf);\r\n return outputBuffer;\r\n });\r\n };\r\n /** @hidden */\r\n Engine.prototype._readTexturePixels = function (texture, width, height, faceIndex, level, buffer) {\r\n if (faceIndex === void 0) { faceIndex = -1; }\r\n if (level === void 0) { level = 0; }\r\n if (buffer === void 0) { buffer = null; }\r\n var gl = this._gl;\r\n if (!this._dummyFramebuffer) {\r\n var dummy = gl.createFramebuffer();\r\n if (!dummy) {\r\n throw new Error(\"Unable to create dummy framebuffer\");\r\n }\r\n this._dummyFramebuffer = dummy;\r\n }\r\n gl.bindFramebuffer(gl.FRAMEBUFFER, this._dummyFramebuffer);\r\n if (faceIndex > -1) {\r\n gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_CUBE_MAP_POSITIVE_X + faceIndex, texture._webGLTexture, level);\r\n }\r\n else {\r\n gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture._webGLTexture, level);\r\n }\r\n var readType = (texture.type !== undefined) ? this._getWebGLTextureType(texture.type) : gl.UNSIGNED_BYTE;\r\n switch (readType) {\r\n case gl.UNSIGNED_BYTE:\r\n if (!buffer) {\r\n buffer = new Uint8Array(4 * width * height);\r\n }\r\n readType = gl.UNSIGNED_BYTE;\r\n break;\r\n default:\r\n if (!buffer) {\r\n buffer = new Float32Array(4 * width * height);\r\n }\r\n readType = gl.FLOAT;\r\n break;\r\n }\r\n gl.readPixels(0, 0, width, height, gl.RGBA, readType, buffer);\r\n gl.bindFramebuffer(gl.FRAMEBUFFER, this._currentFramebuffer);\r\n return buffer;\r\n };\r\n Engine.prototype.dispose = function () {\r\n this.hideLoadingUI();\r\n this.onNewSceneAddedObservable.clear();\r\n // Release postProcesses\r\n while (this.postProcesses.length) {\r\n this.postProcesses[0].dispose();\r\n }\r\n // Rescale PP\r\n if (this._rescalePostProcess) {\r\n this._rescalePostProcess.dispose();\r\n }\r\n // Release scenes\r\n while (this.scenes.length) {\r\n this.scenes[0].dispose();\r\n }\r\n // Release audio engine\r\n if (Engine.Instances.length === 1 && Engine.audioEngine) {\r\n Engine.audioEngine.dispose();\r\n }\r\n if (this._dummyFramebuffer) {\r\n this._gl.deleteFramebuffer(this._dummyFramebuffer);\r\n }\r\n //WebVR\r\n this.disableVR();\r\n // Events\r\n if (DomManagement.IsWindowObjectExist()) {\r\n window.removeEventListener(\"blur\", this._onBlur);\r\n window.removeEventListener(\"focus\", this._onFocus);\r\n if (this._renderingCanvas) {\r\n this._renderingCanvas.removeEventListener(\"focus\", this._onCanvasFocus);\r\n this._renderingCanvas.removeEventListener(\"blur\", this._onCanvasBlur);\r\n this._renderingCanvas.removeEventListener(\"pointerout\", this._onCanvasPointerOut);\r\n }\r\n document.removeEventListener(\"fullscreenchange\", this._onFullscreenChange);\r\n document.removeEventListener(\"mozfullscreenchange\", this._onFullscreenChange);\r\n document.removeEventListener(\"webkitfullscreenchange\", this._onFullscreenChange);\r\n document.removeEventListener(\"msfullscreenchange\", this._onFullscreenChange);\r\n document.removeEventListener(\"pointerlockchange\", this._onPointerLockChange);\r\n document.removeEventListener(\"mspointerlockchange\", this._onPointerLockChange);\r\n document.removeEventListener(\"mozpointerlockchange\", this._onPointerLockChange);\r\n document.removeEventListener(\"webkitpointerlockchange\", this._onPointerLockChange);\r\n }\r\n _super.prototype.dispose.call(this);\r\n // Remove from Instances\r\n var index = Engine.Instances.indexOf(this);\r\n if (index >= 0) {\r\n Engine.Instances.splice(index, 1);\r\n }\r\n // Observables\r\n this.onResizeObservable.clear();\r\n this.onCanvasBlurObservable.clear();\r\n this.onCanvasFocusObservable.clear();\r\n this.onCanvasPointerOutObservable.clear();\r\n this.onBeginFrameObservable.clear();\r\n this.onEndFrameObservable.clear();\r\n };\r\n Engine.prototype._disableTouchAction = function () {\r\n if (!this._renderingCanvas || !this._renderingCanvas.setAttribute) {\r\n return;\r\n }\r\n this._renderingCanvas.setAttribute(\"touch-action\", \"none\");\r\n this._renderingCanvas.style.touchAction = \"none\";\r\n this._renderingCanvas.style.msTouchAction = \"none\";\r\n };\r\n // Loading screen\r\n /**\r\n * Display the loading screen\r\n * @see http://doc.babylonjs.com/how_to/creating_a_custom_loading_screen\r\n */\r\n Engine.prototype.displayLoadingUI = function () {\r\n if (!DomManagement.IsWindowObjectExist()) {\r\n return;\r\n }\r\n var loadingScreen = this.loadingScreen;\r\n if (loadingScreen) {\r\n loadingScreen.displayLoadingUI();\r\n }\r\n };\r\n /**\r\n * Hide the loading screen\r\n * @see http://doc.babylonjs.com/how_to/creating_a_custom_loading_screen\r\n */\r\n Engine.prototype.hideLoadingUI = function () {\r\n if (!DomManagement.IsWindowObjectExist()) {\r\n return;\r\n }\r\n var loadingScreen = this._loadingScreen;\r\n if (loadingScreen) {\r\n loadingScreen.hideLoadingUI();\r\n }\r\n };\r\n Object.defineProperty(Engine.prototype, \"loadingScreen\", {\r\n /**\r\n * Gets the current loading screen object\r\n * @see http://doc.babylonjs.com/how_to/creating_a_custom_loading_screen\r\n */\r\n get: function () {\r\n if (!this._loadingScreen && this._renderingCanvas) {\r\n this._loadingScreen = Engine.DefaultLoadingScreenFactory(this._renderingCanvas);\r\n }\r\n return this._loadingScreen;\r\n },\r\n /**\r\n * Sets the current loading screen object\r\n * @see http://doc.babylonjs.com/how_to/creating_a_custom_loading_screen\r\n */\r\n set: function (loadingScreen) {\r\n this._loadingScreen = loadingScreen;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Engine.prototype, \"loadingUIText\", {\r\n /**\r\n * Sets the current loading screen text\r\n * @see http://doc.babylonjs.com/how_to/creating_a_custom_loading_screen\r\n */\r\n set: function (text) {\r\n this.loadingScreen.loadingUIText = text;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Engine.prototype, \"loadingUIBackgroundColor\", {\r\n /**\r\n * Sets the current loading screen background color\r\n * @see http://doc.babylonjs.com/how_to/creating_a_custom_loading_screen\r\n */\r\n set: function (color) {\r\n this.loadingScreen.loadingUIBackgroundColor = color;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** Pointerlock and fullscreen */\r\n /**\r\n * Ask the browser to promote the current element to pointerlock mode\r\n * @param element defines the DOM element to promote\r\n */\r\n Engine._RequestPointerlock = function (element) {\r\n element.requestPointerLock = element.requestPointerLock || element.msRequestPointerLock || element.mozRequestPointerLock || element.webkitRequestPointerLock;\r\n if (element.requestPointerLock) {\r\n element.requestPointerLock();\r\n }\r\n };\r\n /**\r\n * Asks the browser to exit pointerlock mode\r\n */\r\n Engine._ExitPointerlock = function () {\r\n var anyDoc = document;\r\n document.exitPointerLock = document.exitPointerLock || anyDoc.msExitPointerLock || anyDoc.mozExitPointerLock || anyDoc.webkitExitPointerLock;\r\n if (document.exitPointerLock) {\r\n document.exitPointerLock();\r\n }\r\n };\r\n /**\r\n * Ask the browser to promote the current element to fullscreen rendering mode\r\n * @param element defines the DOM element to promote\r\n */\r\n Engine._RequestFullscreen = function (element) {\r\n var requestFunction = element.requestFullscreen || element.msRequestFullscreen || element.webkitRequestFullscreen || element.mozRequestFullScreen;\r\n if (!requestFunction) {\r\n return;\r\n }\r\n requestFunction.call(element);\r\n };\r\n /**\r\n * Asks the browser to exit fullscreen mode\r\n */\r\n Engine._ExitFullscreen = function () {\r\n var anyDoc = document;\r\n if (document.exitFullscreen) {\r\n document.exitFullscreen();\r\n }\r\n else if (anyDoc.mozCancelFullScreen) {\r\n anyDoc.mozCancelFullScreen();\r\n }\r\n else if (anyDoc.webkitCancelFullScreen) {\r\n anyDoc.webkitCancelFullScreen();\r\n }\r\n else if (anyDoc.msCancelFullScreen) {\r\n anyDoc.msCancelFullScreen();\r\n }\r\n };\r\n // Const statics\r\n /** Defines that alpha blending is disabled */\r\n Engine.ALPHA_DISABLE = 0;\r\n /** Defines that alpha blending to SRC ALPHA * SRC + DEST */\r\n Engine.ALPHA_ADD = 1;\r\n /** Defines that alpha blending to SRC ALPHA * SRC + (1 - SRC ALPHA) * DEST */\r\n Engine.ALPHA_COMBINE = 2;\r\n /** Defines that alpha blending to DEST - SRC * DEST */\r\n Engine.ALPHA_SUBTRACT = 3;\r\n /** Defines that alpha blending to SRC * DEST */\r\n Engine.ALPHA_MULTIPLY = 4;\r\n /** Defines that alpha blending to SRC ALPHA * SRC + (1 - SRC) * DEST */\r\n Engine.ALPHA_MAXIMIZED = 5;\r\n /** Defines that alpha blending to SRC + DEST */\r\n Engine.ALPHA_ONEONE = 6;\r\n /** Defines that alpha blending to SRC + (1 - SRC ALPHA) * DEST */\r\n Engine.ALPHA_PREMULTIPLIED = 7;\r\n /**\r\n * Defines that alpha blending to SRC + (1 - SRC ALPHA) * DEST\r\n * Alpha will be set to (1 - SRC ALPHA) * DEST ALPHA\r\n */\r\n Engine.ALPHA_PREMULTIPLIED_PORTERDUFF = 8;\r\n /** Defines that alpha blending to CST * SRC + (1 - CST) * DEST */\r\n Engine.ALPHA_INTERPOLATE = 9;\r\n /**\r\n * Defines that alpha blending to SRC + (1 - SRC) * DEST\r\n * Alpha will be set to SRC ALPHA + (1 - SRC ALPHA) * DEST ALPHA\r\n */\r\n Engine.ALPHA_SCREENMODE = 10;\r\n /** Defines that the ressource is not delayed*/\r\n Engine.DELAYLOADSTATE_NONE = 0;\r\n /** Defines that the ressource was successfully delay loaded */\r\n Engine.DELAYLOADSTATE_LOADED = 1;\r\n /** Defines that the ressource is currently delay loading */\r\n Engine.DELAYLOADSTATE_LOADING = 2;\r\n /** Defines that the ressource is delayed and has not started loading */\r\n Engine.DELAYLOADSTATE_NOTLOADED = 4;\r\n // Depht or Stencil test Constants.\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will never pass. i.e. Nothing will be drawn */\r\n Engine.NEVER = 512;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will always pass. i.e. Pixels will be drawn in the order they are drawn */\r\n Engine.ALWAYS = 519;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is less than the stored value */\r\n Engine.LESS = 513;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is equals to the stored value */\r\n Engine.EQUAL = 514;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is less than or equal to the stored value */\r\n Engine.LEQUAL = 515;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is greater than the stored value */\r\n Engine.GREATER = 516;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is greater than or equal to the stored value */\r\n Engine.GEQUAL = 518;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is not equal to the stored value */\r\n Engine.NOTEQUAL = 517;\r\n // Stencil Actions Constants.\r\n /** Passed to stencilOperation to specify that stencil value must be kept */\r\n Engine.KEEP = 7680;\r\n /** Passed to stencilOperation to specify that stencil value must be replaced */\r\n Engine.REPLACE = 7681;\r\n /** Passed to stencilOperation to specify that stencil value must be incremented */\r\n Engine.INCR = 7682;\r\n /** Passed to stencilOperation to specify that stencil value must be decremented */\r\n Engine.DECR = 7683;\r\n /** Passed to stencilOperation to specify that stencil value must be inverted */\r\n Engine.INVERT = 5386;\r\n /** Passed to stencilOperation to specify that stencil value must be incremented with wrapping */\r\n Engine.INCR_WRAP = 34055;\r\n /** Passed to stencilOperation to specify that stencil value must be decremented with wrapping */\r\n Engine.DECR_WRAP = 34056;\r\n /** Texture is not repeating outside of 0..1 UVs */\r\n Engine.TEXTURE_CLAMP_ADDRESSMODE = 0;\r\n /** Texture is repeating outside of 0..1 UVs */\r\n Engine.TEXTURE_WRAP_ADDRESSMODE = 1;\r\n /** Texture is repeating and mirrored */\r\n Engine.TEXTURE_MIRROR_ADDRESSMODE = 2;\r\n /** ALPHA */\r\n Engine.TEXTUREFORMAT_ALPHA = 0;\r\n /** LUMINANCE */\r\n Engine.TEXTUREFORMAT_LUMINANCE = 1;\r\n /** LUMINANCE_ALPHA */\r\n Engine.TEXTUREFORMAT_LUMINANCE_ALPHA = 2;\r\n /** RGB */\r\n Engine.TEXTUREFORMAT_RGB = 4;\r\n /** RGBA */\r\n Engine.TEXTUREFORMAT_RGBA = 5;\r\n /** RED */\r\n Engine.TEXTUREFORMAT_RED = 6;\r\n /** RED (2nd reference) */\r\n Engine.TEXTUREFORMAT_R = 6;\r\n /** RG */\r\n Engine.TEXTUREFORMAT_RG = 7;\r\n /** RED_INTEGER */\r\n Engine.TEXTUREFORMAT_RED_INTEGER = 8;\r\n /** RED_INTEGER (2nd reference) */\r\n Engine.TEXTUREFORMAT_R_INTEGER = 8;\r\n /** RG_INTEGER */\r\n Engine.TEXTUREFORMAT_RG_INTEGER = 9;\r\n /** RGB_INTEGER */\r\n Engine.TEXTUREFORMAT_RGB_INTEGER = 10;\r\n /** RGBA_INTEGER */\r\n Engine.TEXTUREFORMAT_RGBA_INTEGER = 11;\r\n /** UNSIGNED_BYTE */\r\n Engine.TEXTURETYPE_UNSIGNED_BYTE = 0;\r\n /** UNSIGNED_BYTE (2nd reference) */\r\n Engine.TEXTURETYPE_UNSIGNED_INT = 0;\r\n /** FLOAT */\r\n Engine.TEXTURETYPE_FLOAT = 1;\r\n /** HALF_FLOAT */\r\n Engine.TEXTURETYPE_HALF_FLOAT = 2;\r\n /** BYTE */\r\n Engine.TEXTURETYPE_BYTE = 3;\r\n /** SHORT */\r\n Engine.TEXTURETYPE_SHORT = 4;\r\n /** UNSIGNED_SHORT */\r\n Engine.TEXTURETYPE_UNSIGNED_SHORT = 5;\r\n /** INT */\r\n Engine.TEXTURETYPE_INT = 6;\r\n /** UNSIGNED_INT */\r\n Engine.TEXTURETYPE_UNSIGNED_INTEGER = 7;\r\n /** UNSIGNED_SHORT_4_4_4_4 */\r\n Engine.TEXTURETYPE_UNSIGNED_SHORT_4_4_4_4 = 8;\r\n /** UNSIGNED_SHORT_5_5_5_1 */\r\n Engine.TEXTURETYPE_UNSIGNED_SHORT_5_5_5_1 = 9;\r\n /** UNSIGNED_SHORT_5_6_5 */\r\n Engine.TEXTURETYPE_UNSIGNED_SHORT_5_6_5 = 10;\r\n /** UNSIGNED_INT_2_10_10_10_REV */\r\n Engine.TEXTURETYPE_UNSIGNED_INT_2_10_10_10_REV = 11;\r\n /** UNSIGNED_INT_24_8 */\r\n Engine.TEXTURETYPE_UNSIGNED_INT_24_8 = 12;\r\n /** UNSIGNED_INT_10F_11F_11F_REV */\r\n Engine.TEXTURETYPE_UNSIGNED_INT_10F_11F_11F_REV = 13;\r\n /** UNSIGNED_INT_5_9_9_9_REV */\r\n Engine.TEXTURETYPE_UNSIGNED_INT_5_9_9_9_REV = 14;\r\n /** FLOAT_32_UNSIGNED_INT_24_8_REV */\r\n Engine.TEXTURETYPE_FLOAT_32_UNSIGNED_INT_24_8_REV = 15;\r\n /** nearest is mag = nearest and min = nearest and mip = linear */\r\n Engine.TEXTURE_NEAREST_SAMPLINGMODE = 1;\r\n /** Bilinear is mag = linear and min = linear and mip = nearest */\r\n Engine.TEXTURE_BILINEAR_SAMPLINGMODE = 2;\r\n /** Trilinear is mag = linear and min = linear and mip = linear */\r\n Engine.TEXTURE_TRILINEAR_SAMPLINGMODE = 3;\r\n /** nearest is mag = nearest and min = nearest and mip = linear */\r\n Engine.TEXTURE_NEAREST_NEAREST_MIPLINEAR = 8;\r\n /** Bilinear is mag = linear and min = linear and mip = nearest */\r\n Engine.TEXTURE_LINEAR_LINEAR_MIPNEAREST = 11;\r\n /** Trilinear is mag = linear and min = linear and mip = linear */\r\n Engine.TEXTURE_LINEAR_LINEAR_MIPLINEAR = 3;\r\n /** mag = nearest and min = nearest and mip = nearest */\r\n Engine.TEXTURE_NEAREST_NEAREST_MIPNEAREST = 4;\r\n /** mag = nearest and min = linear and mip = nearest */\r\n Engine.TEXTURE_NEAREST_LINEAR_MIPNEAREST = 5;\r\n /** mag = nearest and min = linear and mip = linear */\r\n Engine.TEXTURE_NEAREST_LINEAR_MIPLINEAR = 6;\r\n /** mag = nearest and min = linear and mip = none */\r\n Engine.TEXTURE_NEAREST_LINEAR = 7;\r\n /** mag = nearest and min = nearest and mip = none */\r\n Engine.TEXTURE_NEAREST_NEAREST = 1;\r\n /** mag = linear and min = nearest and mip = nearest */\r\n Engine.TEXTURE_LINEAR_NEAREST_MIPNEAREST = 9;\r\n /** mag = linear and min = nearest and mip = linear */\r\n Engine.TEXTURE_LINEAR_NEAREST_MIPLINEAR = 10;\r\n /** mag = linear and min = linear and mip = none */\r\n Engine.TEXTURE_LINEAR_LINEAR = 2;\r\n /** mag = linear and min = nearest and mip = none */\r\n Engine.TEXTURE_LINEAR_NEAREST = 12;\r\n /** Explicit coordinates mode */\r\n Engine.TEXTURE_EXPLICIT_MODE = 0;\r\n /** Spherical coordinates mode */\r\n Engine.TEXTURE_SPHERICAL_MODE = 1;\r\n /** Planar coordinates mode */\r\n Engine.TEXTURE_PLANAR_MODE = 2;\r\n /** Cubic coordinates mode */\r\n Engine.TEXTURE_CUBIC_MODE = 3;\r\n /** Projection coordinates mode */\r\n Engine.TEXTURE_PROJECTION_MODE = 4;\r\n /** Skybox coordinates mode */\r\n Engine.TEXTURE_SKYBOX_MODE = 5;\r\n /** Inverse Cubic coordinates mode */\r\n Engine.TEXTURE_INVCUBIC_MODE = 6;\r\n /** Equirectangular coordinates mode */\r\n Engine.TEXTURE_EQUIRECTANGULAR_MODE = 7;\r\n /** Equirectangular Fixed coordinates mode */\r\n Engine.TEXTURE_FIXED_EQUIRECTANGULAR_MODE = 8;\r\n /** Equirectangular Fixed Mirrored coordinates mode */\r\n Engine.TEXTURE_FIXED_EQUIRECTANGULAR_MIRRORED_MODE = 9;\r\n // Texture rescaling mode\r\n /** Defines that texture rescaling will use a floor to find the closer power of 2 size */\r\n Engine.SCALEMODE_FLOOR = 1;\r\n /** Defines that texture rescaling will look for the nearest power of 2 size */\r\n Engine.SCALEMODE_NEAREST = 2;\r\n /** Defines that texture rescaling will use a ceil to find the closer power of 2 size */\r\n Engine.SCALEMODE_CEILING = 3;\r\n /**\r\n * Method called to create the default rescale post process on each engine.\r\n */\r\n Engine._RescalePostProcessFactory = null;\r\n return Engine;\r\n}(ThinEngine));\r\nexport { Engine };\r\n//# sourceMappingURL=engine.js.map","import { __assign, __decorate } from \"tslib\";\r\nimport { serialize, SerializationHelper } from \"../Misc/decorators\";\r\nimport { Tools } from \"../Misc/tools\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { EngineStore } from \"../Engines/engineStore\";\r\nimport { BaseSubMesh } from \"../Meshes/subMesh\";\r\nimport { UniformBuffer } from \"./uniformBuffer\";\r\nimport { Logger } from \"../Misc/logger\";\r\nimport { Plane } from '../Maths/math.plane';\r\n/**\r\n * Base class for the main features of a material in Babylon.js\r\n */\r\nvar Material = /** @class */ (function () {\r\n /**\r\n * Creates a material instance\r\n * @param name defines the name of the material\r\n * @param scene defines the scene to reference\r\n * @param doNotAdd specifies if the material should be added to the scene\r\n */\r\n function Material(name, scene, doNotAdd) {\r\n /**\r\n * Gets or sets user defined metadata\r\n */\r\n this.metadata = null;\r\n /**\r\n * For internal use only. Please do not use.\r\n */\r\n this.reservedDataStore = null;\r\n /**\r\n * Specifies if the ready state should be checked on each call\r\n */\r\n this.checkReadyOnEveryCall = false;\r\n /**\r\n * Specifies if the ready state should be checked once\r\n */\r\n this.checkReadyOnlyOnce = false;\r\n /**\r\n * The state of the material\r\n */\r\n this.state = \"\";\r\n /**\r\n * The alpha value of the material\r\n */\r\n this._alpha = 1.0;\r\n /**\r\n * Specifies if back face culling is enabled\r\n */\r\n this._backFaceCulling = true;\r\n /**\r\n * Callback triggered when the material is compiled\r\n */\r\n this.onCompiled = null;\r\n /**\r\n * Callback triggered when an error occurs\r\n */\r\n this.onError = null;\r\n /**\r\n * Callback triggered to get the render target textures\r\n */\r\n this.getRenderTargetTextures = null;\r\n /**\r\n * Specifies if the material should be serialized\r\n */\r\n this.doNotSerialize = false;\r\n /**\r\n * @hidden\r\n */\r\n this._storeEffectOnSubMeshes = false;\r\n /**\r\n * Stores the animations for the material\r\n */\r\n this.animations = null;\r\n /**\r\n * An event triggered when the material is disposed\r\n */\r\n this.onDisposeObservable = new Observable();\r\n /**\r\n * An observer which watches for dispose events\r\n */\r\n this._onDisposeObserver = null;\r\n this._onUnBindObservable = null;\r\n /**\r\n * An observer which watches for bind events\r\n */\r\n this._onBindObserver = null;\r\n /**\r\n * Stores the value of the alpha mode\r\n */\r\n this._alphaMode = 2;\r\n /**\r\n * Stores the state of the need depth pre-pass value\r\n */\r\n this._needDepthPrePass = false;\r\n /**\r\n * Specifies if depth writing should be disabled\r\n */\r\n this.disableDepthWrite = false;\r\n /**\r\n * Specifies if depth writing should be forced\r\n */\r\n this.forceDepthWrite = false;\r\n /**\r\n * Specifies the depth function that should be used. 0 means the default engine function\r\n */\r\n this.depthFunction = 0;\r\n /**\r\n * Specifies if there should be a separate pass for culling\r\n */\r\n this.separateCullingPass = false;\r\n /**\r\n * Stores the state specifing if fog should be enabled\r\n */\r\n this._fogEnabled = true;\r\n /**\r\n * Stores the size of points\r\n */\r\n this.pointSize = 1.0;\r\n /**\r\n * Stores the z offset value\r\n */\r\n this.zOffset = 0;\r\n /**\r\n * @hidden\r\n * Stores the effects for the material\r\n */\r\n this._effect = null;\r\n /**\r\n * Specifies if uniform buffers should be used\r\n */\r\n this._useUBO = false;\r\n /**\r\n * Stores the fill mode state\r\n */\r\n this._fillMode = Material.TriangleFillMode;\r\n /**\r\n * Specifies if the depth write state should be cached\r\n */\r\n this._cachedDepthWriteState = false;\r\n /**\r\n * Specifies if the depth function state should be cached\r\n */\r\n this._cachedDepthFunctionState = 0;\r\n /** @hidden */\r\n this._indexInSceneMaterialArray = -1;\r\n /** @hidden */\r\n this.meshMap = null;\r\n this.name = name;\r\n this.id = name || Tools.RandomId();\r\n this._scene = scene || EngineStore.LastCreatedScene;\r\n this.uniqueId = this._scene.getUniqueId();\r\n if (this._scene.useRightHandedSystem) {\r\n this.sideOrientation = Material.ClockWiseSideOrientation;\r\n }\r\n else {\r\n this.sideOrientation = Material.CounterClockWiseSideOrientation;\r\n }\r\n this._uniformBuffer = new UniformBuffer(this._scene.getEngine());\r\n this._useUBO = this.getScene().getEngine().supportsUniformBuffers;\r\n if (!doNotAdd) {\r\n this._scene.addMaterial(this);\r\n }\r\n if (this._scene.useMaterialMeshMap) {\r\n this.meshMap = {};\r\n }\r\n }\r\n Object.defineProperty(Material.prototype, \"alpha\", {\r\n /**\r\n * Gets the alpha value of the material\r\n */\r\n get: function () {\r\n return this._alpha;\r\n },\r\n /**\r\n * Sets the alpha value of the material\r\n */\r\n set: function (value) {\r\n if (this._alpha === value) {\r\n return;\r\n }\r\n this._alpha = value;\r\n this.markAsDirty(Material.MiscDirtyFlag);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"backFaceCulling\", {\r\n /**\r\n * Gets the back-face culling state\r\n */\r\n get: function () {\r\n return this._backFaceCulling;\r\n },\r\n /**\r\n * Sets the back-face culling state\r\n */\r\n set: function (value) {\r\n if (this._backFaceCulling === value) {\r\n return;\r\n }\r\n this._backFaceCulling = value;\r\n this.markAsDirty(Material.TextureDirtyFlag);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"hasRenderTargetTextures\", {\r\n /**\r\n * Gets a boolean indicating that current material needs to register RTT\r\n */\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"onDispose\", {\r\n /**\r\n * Called during a dispose event\r\n */\r\n set: function (callback) {\r\n if (this._onDisposeObserver) {\r\n this.onDisposeObservable.remove(this._onDisposeObserver);\r\n }\r\n this._onDisposeObserver = this.onDisposeObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"onBindObservable\", {\r\n /**\r\n * An event triggered when the material is bound\r\n */\r\n get: function () {\r\n if (!this._onBindObservable) {\r\n this._onBindObservable = new Observable();\r\n }\r\n return this._onBindObservable;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"onBind\", {\r\n /**\r\n * Called during a bind event\r\n */\r\n set: function (callback) {\r\n if (this._onBindObserver) {\r\n this.onBindObservable.remove(this._onBindObserver);\r\n }\r\n this._onBindObserver = this.onBindObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"onUnBindObservable\", {\r\n /**\r\n * An event triggered when the material is unbound\r\n */\r\n get: function () {\r\n if (!this._onUnBindObservable) {\r\n this._onUnBindObservable = new Observable();\r\n }\r\n return this._onUnBindObservable;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"alphaMode\", {\r\n /**\r\n * Gets the value of the alpha mode\r\n */\r\n get: function () {\r\n return this._alphaMode;\r\n },\r\n /**\r\n * Sets the value of the alpha mode.\r\n *\r\n * | Value | Type | Description |\r\n * | --- | --- | --- |\r\n * | 0 | ALPHA_DISABLE | |\r\n * | 1 | ALPHA_ADD | |\r\n * | 2 | ALPHA_COMBINE | |\r\n * | 3 | ALPHA_SUBTRACT | |\r\n * | 4 | ALPHA_MULTIPLY | |\r\n * | 5 | ALPHA_MAXIMIZED | |\r\n * | 6 | ALPHA_ONEONE | |\r\n * | 7 | ALPHA_PREMULTIPLIED | |\r\n * | 8 | ALPHA_PREMULTIPLIED_PORTERDUFF | |\r\n * | 9 | ALPHA_INTERPOLATE | |\r\n * | 10 | ALPHA_SCREENMODE | |\r\n *\r\n */\r\n set: function (value) {\r\n if (this._alphaMode === value) {\r\n return;\r\n }\r\n this._alphaMode = value;\r\n this.markAsDirty(Material.TextureDirtyFlag);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"needDepthPrePass\", {\r\n /**\r\n * Gets the depth pre-pass value\r\n */\r\n get: function () {\r\n return this._needDepthPrePass;\r\n },\r\n /**\r\n * Sets the need depth pre-pass value\r\n */\r\n set: function (value) {\r\n if (this._needDepthPrePass === value) {\r\n return;\r\n }\r\n this._needDepthPrePass = value;\r\n if (this._needDepthPrePass) {\r\n this.checkReadyOnEveryCall = true;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"fogEnabled\", {\r\n /**\r\n * Gets the value of the fog enabled state\r\n */\r\n get: function () {\r\n return this._fogEnabled;\r\n },\r\n /**\r\n * Sets the state for enabling fog\r\n */\r\n set: function (value) {\r\n if (this._fogEnabled === value) {\r\n return;\r\n }\r\n this._fogEnabled = value;\r\n this.markAsDirty(Material.MiscDirtyFlag);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"wireframe\", {\r\n /**\r\n * Gets a value specifying if wireframe mode is enabled\r\n */\r\n get: function () {\r\n switch (this._fillMode) {\r\n case Material.WireFrameFillMode:\r\n case Material.LineListDrawMode:\r\n case Material.LineLoopDrawMode:\r\n case Material.LineStripDrawMode:\r\n return true;\r\n }\r\n return this._scene.forceWireframe;\r\n },\r\n /**\r\n * Sets the state of wireframe mode\r\n */\r\n set: function (value) {\r\n this.fillMode = (value ? Material.WireFrameFillMode : Material.TriangleFillMode);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"pointsCloud\", {\r\n /**\r\n * Gets the value specifying if point clouds are enabled\r\n */\r\n get: function () {\r\n switch (this._fillMode) {\r\n case Material.PointFillMode:\r\n case Material.PointListDrawMode:\r\n return true;\r\n }\r\n return this._scene.forcePointsCloud;\r\n },\r\n /**\r\n * Sets the state of point cloud mode\r\n */\r\n set: function (value) {\r\n this.fillMode = (value ? Material.PointFillMode : Material.TriangleFillMode);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"fillMode\", {\r\n /**\r\n * Gets the material fill mode\r\n */\r\n get: function () {\r\n return this._fillMode;\r\n },\r\n /**\r\n * Sets the material fill mode\r\n */\r\n set: function (value) {\r\n if (this._fillMode === value) {\r\n return;\r\n }\r\n this._fillMode = value;\r\n this.markAsDirty(Material.MiscDirtyFlag);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Returns a string representation of the current material\r\n * @param fullDetails defines a boolean indicating which levels of logging is desired\r\n * @returns a string with material information\r\n */\r\n Material.prototype.toString = function (fullDetails) {\r\n var ret = \"Name: \" + this.name;\r\n if (fullDetails) {\r\n }\r\n return ret;\r\n };\r\n /**\r\n * Gets the class name of the material\r\n * @returns a string with the class name of the material\r\n */\r\n Material.prototype.getClassName = function () {\r\n return \"Material\";\r\n };\r\n Object.defineProperty(Material.prototype, \"isFrozen\", {\r\n /**\r\n * Specifies if updates for the material been locked\r\n */\r\n get: function () {\r\n return this.checkReadyOnlyOnce;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Locks updates for the material\r\n */\r\n Material.prototype.freeze = function () {\r\n this.markDirty();\r\n this.checkReadyOnlyOnce = true;\r\n };\r\n /**\r\n * Unlocks updates for the material\r\n */\r\n Material.prototype.unfreeze = function () {\r\n this.markDirty();\r\n this.checkReadyOnlyOnce = false;\r\n };\r\n /**\r\n * Specifies if the material is ready to be used\r\n * @param mesh defines the mesh to check\r\n * @param useInstances specifies if instances should be used\r\n * @returns a boolean indicating if the material is ready to be used\r\n */\r\n Material.prototype.isReady = function (mesh, useInstances) {\r\n return true;\r\n };\r\n /**\r\n * Specifies that the submesh is ready to be used\r\n * @param mesh defines the mesh to check\r\n * @param subMesh defines which submesh to check\r\n * @param useInstances specifies that instances should be used\r\n * @returns a boolean indicating that the submesh is ready or not\r\n */\r\n Material.prototype.isReadyForSubMesh = function (mesh, subMesh, useInstances) {\r\n return false;\r\n };\r\n /**\r\n * Returns the material effect\r\n * @returns the effect associated with the material\r\n */\r\n Material.prototype.getEffect = function () {\r\n return this._effect;\r\n };\r\n /**\r\n * Returns the current scene\r\n * @returns a Scene\r\n */\r\n Material.prototype.getScene = function () {\r\n return this._scene;\r\n };\r\n /**\r\n * Specifies if the material will require alpha blending\r\n * @returns a boolean specifying if alpha blending is needed\r\n */\r\n Material.prototype.needAlphaBlending = function () {\r\n return (this.alpha < 1.0);\r\n };\r\n /**\r\n * Specifies if the mesh will require alpha blending\r\n * @param mesh defines the mesh to check\r\n * @returns a boolean specifying if alpha blending is needed for the mesh\r\n */\r\n Material.prototype.needAlphaBlendingForMesh = function (mesh) {\r\n return this.needAlphaBlending() || (mesh.visibility < 1.0) || mesh.hasVertexAlpha;\r\n };\r\n /**\r\n * Specifies if this material should be rendered in alpha test mode\r\n * @returns a boolean specifying if an alpha test is needed.\r\n */\r\n Material.prototype.needAlphaTesting = function () {\r\n return false;\r\n };\r\n /**\r\n * Gets the texture used for the alpha test\r\n * @returns the texture to use for alpha testing\r\n */\r\n Material.prototype.getAlphaTestTexture = function () {\r\n return null;\r\n };\r\n /**\r\n * Marks the material to indicate that it needs to be re-calculated\r\n */\r\n Material.prototype.markDirty = function () {\r\n var meshes = this.getScene().meshes;\r\n for (var _i = 0, meshes_1 = meshes; _i < meshes_1.length; _i++) {\r\n var mesh = meshes_1[_i];\r\n if (!mesh.subMeshes) {\r\n continue;\r\n }\r\n for (var _a = 0, _b = mesh.subMeshes; _a < _b.length; _a++) {\r\n var subMesh = _b[_a];\r\n if (subMesh.getMaterial() !== this) {\r\n continue;\r\n }\r\n if (!subMesh.effect) {\r\n continue;\r\n }\r\n subMesh.effect._wasPreviouslyReady = false;\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n Material.prototype._preBind = function (effect, overrideOrientation) {\r\n if (overrideOrientation === void 0) { overrideOrientation = null; }\r\n var engine = this._scene.getEngine();\r\n var orientation = (overrideOrientation == null) ? this.sideOrientation : overrideOrientation;\r\n var reverse = orientation === Material.ClockWiseSideOrientation;\r\n engine.enableEffect(effect ? effect : this._effect);\r\n engine.setState(this.backFaceCulling, this.zOffset, false, reverse);\r\n return reverse;\r\n };\r\n /**\r\n * Binds the material to the mesh\r\n * @param world defines the world transformation matrix\r\n * @param mesh defines the mesh to bind the material to\r\n */\r\n Material.prototype.bind = function (world, mesh) {\r\n };\r\n /**\r\n * Binds the submesh to the material\r\n * @param world defines the world transformation matrix\r\n * @param mesh defines the mesh containing the submesh\r\n * @param subMesh defines the submesh to bind the material to\r\n */\r\n Material.prototype.bindForSubMesh = function (world, mesh, subMesh) {\r\n };\r\n /**\r\n * Binds the world matrix to the material\r\n * @param world defines the world transformation matrix\r\n */\r\n Material.prototype.bindOnlyWorldMatrix = function (world) {\r\n };\r\n /**\r\n * Binds the scene's uniform buffer to the effect.\r\n * @param effect defines the effect to bind to the scene uniform buffer\r\n * @param sceneUbo defines the uniform buffer storing scene data\r\n */\r\n Material.prototype.bindSceneUniformBuffer = function (effect, sceneUbo) {\r\n sceneUbo.bindToEffect(effect, \"Scene\");\r\n };\r\n /**\r\n * Binds the view matrix to the effect\r\n * @param effect defines the effect to bind the view matrix to\r\n */\r\n Material.prototype.bindView = function (effect) {\r\n if (!this._useUBO) {\r\n effect.setMatrix(\"view\", this.getScene().getViewMatrix());\r\n }\r\n else {\r\n this.bindSceneUniformBuffer(effect, this.getScene().getSceneUniformBuffer());\r\n }\r\n };\r\n /**\r\n * Binds the view projection matrix to the effect\r\n * @param effect defines the effect to bind the view projection matrix to\r\n */\r\n Material.prototype.bindViewProjection = function (effect) {\r\n if (!this._useUBO) {\r\n effect.setMatrix(\"viewProjection\", this.getScene().getTransformMatrix());\r\n }\r\n else {\r\n this.bindSceneUniformBuffer(effect, this.getScene().getSceneUniformBuffer());\r\n }\r\n };\r\n /**\r\n * Specifies if material alpha testing should be turned on for the mesh\r\n * @param mesh defines the mesh to check\r\n */\r\n Material.prototype._shouldTurnAlphaTestOn = function (mesh) {\r\n return (!this.needAlphaBlendingForMesh(mesh) && this.needAlphaTesting());\r\n };\r\n /**\r\n * Processes to execute after binding the material to a mesh\r\n * @param mesh defines the rendered mesh\r\n */\r\n Material.prototype._afterBind = function (mesh) {\r\n this._scene._cachedMaterial = this;\r\n if (mesh) {\r\n this._scene._cachedVisibility = mesh.visibility;\r\n }\r\n else {\r\n this._scene._cachedVisibility = 1;\r\n }\r\n if (this._onBindObservable && mesh) {\r\n this._onBindObservable.notifyObservers(mesh);\r\n }\r\n if (this.disableDepthWrite) {\r\n var engine = this._scene.getEngine();\r\n this._cachedDepthWriteState = engine.getDepthWrite();\r\n engine.setDepthWrite(false);\r\n }\r\n if (this.depthFunction !== 0) {\r\n var engine = this._scene.getEngine();\r\n this._cachedDepthFunctionState = engine.getDepthFunction() || 0;\r\n engine.setDepthFunction(this.depthFunction);\r\n }\r\n };\r\n /**\r\n * Unbinds the material from the mesh\r\n */\r\n Material.prototype.unbind = function () {\r\n if (this._onUnBindObservable) {\r\n this._onUnBindObservable.notifyObservers(this);\r\n }\r\n if (this.depthFunction !== 0) {\r\n var engine = this._scene.getEngine();\r\n engine.setDepthFunction(this._cachedDepthFunctionState);\r\n }\r\n if (this.disableDepthWrite) {\r\n var engine = this._scene.getEngine();\r\n engine.setDepthWrite(this._cachedDepthWriteState);\r\n }\r\n };\r\n /**\r\n * Gets the active textures from the material\r\n * @returns an array of textures\r\n */\r\n Material.prototype.getActiveTextures = function () {\r\n return [];\r\n };\r\n /**\r\n * Specifies if the material uses a texture\r\n * @param texture defines the texture to check against the material\r\n * @returns a boolean specifying if the material uses the texture\r\n */\r\n Material.prototype.hasTexture = function (texture) {\r\n return false;\r\n };\r\n /**\r\n * Makes a duplicate of the material, and gives it a new name\r\n * @param name defines the new name for the duplicated material\r\n * @returns the cloned material\r\n */\r\n Material.prototype.clone = function (name) {\r\n return null;\r\n };\r\n /**\r\n * Gets the meshes bound to the material\r\n * @returns an array of meshes bound to the material\r\n */\r\n Material.prototype.getBindedMeshes = function () {\r\n var _this = this;\r\n if (this.meshMap) {\r\n var result = new Array();\r\n for (var meshId in this.meshMap) {\r\n var mesh = this.meshMap[meshId];\r\n if (mesh) {\r\n result.push(mesh);\r\n }\r\n }\r\n return result;\r\n }\r\n else {\r\n var meshes = this._scene.meshes;\r\n return meshes.filter(function (mesh) { return mesh.material === _this; });\r\n }\r\n };\r\n /**\r\n * Force shader compilation\r\n * @param mesh defines the mesh associated with this material\r\n * @param onCompiled defines a function to execute once the material is compiled\r\n * @param options defines the options to configure the compilation\r\n * @param onError defines a function to execute if the material fails compiling\r\n */\r\n Material.prototype.forceCompilation = function (mesh, onCompiled, options, onError) {\r\n var _this = this;\r\n var localOptions = __assign({ clipPlane: false, useInstances: false }, options);\r\n var subMesh = new BaseSubMesh();\r\n var scene = this.getScene();\r\n var checkReady = function () {\r\n if (!_this._scene || !_this._scene.getEngine()) {\r\n return;\r\n }\r\n if (subMesh._materialDefines) {\r\n subMesh._materialDefines._renderId = -1;\r\n }\r\n var clipPlaneState = scene.clipPlane;\r\n if (localOptions.clipPlane) {\r\n scene.clipPlane = new Plane(0, 0, 0, 1);\r\n }\r\n if (_this._storeEffectOnSubMeshes) {\r\n if (_this.isReadyForSubMesh(mesh, subMesh, localOptions.useInstances)) {\r\n if (onCompiled) {\r\n onCompiled(_this);\r\n }\r\n }\r\n else {\r\n if (subMesh.effect && subMesh.effect.getCompilationError() && subMesh.effect.allFallbacksProcessed()) {\r\n if (onError) {\r\n onError(subMesh.effect.getCompilationError());\r\n }\r\n }\r\n else {\r\n setTimeout(checkReady, 16);\r\n }\r\n }\r\n }\r\n else {\r\n if (_this.isReady()) {\r\n if (onCompiled) {\r\n onCompiled(_this);\r\n }\r\n }\r\n else {\r\n setTimeout(checkReady, 16);\r\n }\r\n }\r\n if (localOptions.clipPlane) {\r\n scene.clipPlane = clipPlaneState;\r\n }\r\n };\r\n checkReady();\r\n };\r\n /**\r\n * Force shader compilation\r\n * @param mesh defines the mesh that will use this material\r\n * @param options defines additional options for compiling the shaders\r\n * @returns a promise that resolves when the compilation completes\r\n */\r\n Material.prototype.forceCompilationAsync = function (mesh, options) {\r\n var _this = this;\r\n return new Promise(function (resolve, reject) {\r\n _this.forceCompilation(mesh, function () {\r\n resolve();\r\n }, options, function (reason) {\r\n reject(reason);\r\n });\r\n });\r\n };\r\n /**\r\n * Marks a define in the material to indicate that it needs to be re-computed\r\n * @param flag defines a flag used to determine which parts of the material have to be marked as dirty\r\n */\r\n Material.prototype.markAsDirty = function (flag) {\r\n if (this.getScene().blockMaterialDirtyMechanism) {\r\n return;\r\n }\r\n Material._DirtyCallbackArray.length = 0;\r\n if (flag & Material.TextureDirtyFlag) {\r\n Material._DirtyCallbackArray.push(Material._TextureDirtyCallBack);\r\n }\r\n if (flag & Material.LightDirtyFlag) {\r\n Material._DirtyCallbackArray.push(Material._LightsDirtyCallBack);\r\n }\r\n if (flag & Material.FresnelDirtyFlag) {\r\n Material._DirtyCallbackArray.push(Material._FresnelDirtyCallBack);\r\n }\r\n if (flag & Material.AttributesDirtyFlag) {\r\n Material._DirtyCallbackArray.push(Material._AttributeDirtyCallBack);\r\n }\r\n if (flag & Material.MiscDirtyFlag) {\r\n Material._DirtyCallbackArray.push(Material._MiscDirtyCallBack);\r\n }\r\n if (Material._DirtyCallbackArray.length) {\r\n this._markAllSubMeshesAsDirty(Material._RunDirtyCallBacks);\r\n }\r\n this.getScene().resetCachedMaterial();\r\n };\r\n /**\r\n * Marks all submeshes of a material to indicate that their material defines need to be re-calculated\r\n * @param func defines a function which checks material defines against the submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsDirty = function (func) {\r\n if (this.getScene().blockMaterialDirtyMechanism) {\r\n return;\r\n }\r\n var meshes = this.getScene().meshes;\r\n for (var _i = 0, meshes_2 = meshes; _i < meshes_2.length; _i++) {\r\n var mesh = meshes_2[_i];\r\n if (!mesh.subMeshes) {\r\n continue;\r\n }\r\n for (var _a = 0, _b = mesh.subMeshes; _a < _b.length; _a++) {\r\n var subMesh = _b[_a];\r\n if (subMesh.getMaterial() !== this) {\r\n continue;\r\n }\r\n if (!subMesh._materialDefines) {\r\n continue;\r\n }\r\n func(subMesh._materialDefines);\r\n }\r\n }\r\n };\r\n /**\r\n * Indicates that we need to re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsAllDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._AllDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that image processing needs to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsImageProcessingDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._ImageProcessingDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that textures need to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsTexturesDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._TextureDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that fresnel needs to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsFresnelDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._FresnelDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that fresnel and misc need to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsFresnelAndMiscDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._FresnelAndMiscDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that lights need to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsLightsDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._LightsDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that attributes need to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsAttributesDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._AttributeDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that misc needs to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsMiscDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._MiscDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that textures and misc need to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsTexturesAndMiscDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._TextureAndMiscDirtyCallBack);\r\n };\r\n /**\r\n * Disposes the material\r\n * @param forceDisposeEffect specifies if effects should be forcefully disposed\r\n * @param forceDisposeTextures specifies if textures should be forcefully disposed\r\n * @param notBoundToMesh specifies if the material that is being disposed is known to be not bound to any mesh\r\n */\r\n Material.prototype.dispose = function (forceDisposeEffect, forceDisposeTextures, notBoundToMesh) {\r\n var scene = this.getScene();\r\n // Animations\r\n scene.stopAnimation(this);\r\n scene.freeProcessedMaterials();\r\n // Remove from scene\r\n scene.removeMaterial(this);\r\n if (notBoundToMesh !== true) {\r\n // Remove from meshes\r\n if (this.meshMap) {\r\n for (var meshId in this.meshMap) {\r\n var mesh = this.meshMap[meshId];\r\n if (mesh) {\r\n mesh.material = null; // will set the entry in the map to undefined\r\n this.releaseVertexArrayObject(mesh, forceDisposeEffect);\r\n }\r\n }\r\n }\r\n else {\r\n var meshes = scene.meshes;\r\n for (var _i = 0, meshes_3 = meshes; _i < meshes_3.length; _i++) {\r\n var mesh = meshes_3[_i];\r\n if (mesh.material === this && !mesh.sourceMesh) {\r\n mesh.material = null;\r\n this.releaseVertexArrayObject(mesh, forceDisposeEffect);\r\n }\r\n }\r\n }\r\n }\r\n this._uniformBuffer.dispose();\r\n // Shader are kept in cache for further use but we can get rid of this by using forceDisposeEffect\r\n if (forceDisposeEffect && this._effect) {\r\n if (!this._storeEffectOnSubMeshes) {\r\n this._effect.dispose();\r\n }\r\n this._effect = null;\r\n }\r\n // Callback\r\n this.onDisposeObservable.notifyObservers(this);\r\n this.onDisposeObservable.clear();\r\n if (this._onBindObservable) {\r\n this._onBindObservable.clear();\r\n }\r\n if (this._onUnBindObservable) {\r\n this._onUnBindObservable.clear();\r\n }\r\n };\r\n /** @hidden */\r\n Material.prototype.releaseVertexArrayObject = function (mesh, forceDisposeEffect) {\r\n if (mesh.geometry) {\r\n var geometry = (mesh.geometry);\r\n if (this._storeEffectOnSubMeshes) {\r\n for (var _i = 0, _a = mesh.subMeshes; _i < _a.length; _i++) {\r\n var subMesh = _a[_i];\r\n geometry._releaseVertexArrayObject(subMesh._materialEffect);\r\n if (forceDisposeEffect && subMesh._materialEffect) {\r\n subMesh._materialEffect.dispose();\r\n }\r\n }\r\n }\r\n else {\r\n geometry._releaseVertexArrayObject(this._effect);\r\n }\r\n }\r\n };\r\n /**\r\n * Serializes this material\r\n * @returns the serialized material object\r\n */\r\n Material.prototype.serialize = function () {\r\n return SerializationHelper.Serialize(this);\r\n };\r\n /**\r\n * Creates a material from parsed material data\r\n * @param parsedMaterial defines parsed material data\r\n * @param scene defines the hosting scene\r\n * @param rootUrl defines the root URL to use to load textures\r\n * @returns a new material\r\n */\r\n Material.Parse = function (parsedMaterial, scene, rootUrl) {\r\n if (!parsedMaterial.customType) {\r\n parsedMaterial.customType = \"BABYLON.StandardMaterial\";\r\n }\r\n else if (parsedMaterial.customType === \"BABYLON.PBRMaterial\" && parsedMaterial.overloadedAlbedo) {\r\n parsedMaterial.customType = \"BABYLON.LegacyPBRMaterial\";\r\n if (!BABYLON.LegacyPBRMaterial) {\r\n Logger.Error(\"Your scene is trying to load a legacy version of the PBRMaterial, please, include it from the materials library.\");\r\n return null;\r\n }\r\n }\r\n var materialType = Tools.Instantiate(parsedMaterial.customType);\r\n return materialType.Parse(parsedMaterial, scene, rootUrl);\r\n };\r\n /**\r\n * Returns the triangle fill mode\r\n */\r\n Material.TriangleFillMode = 0;\r\n /**\r\n * Returns the wireframe mode\r\n */\r\n Material.WireFrameFillMode = 1;\r\n /**\r\n * Returns the point fill mode\r\n */\r\n Material.PointFillMode = 2;\r\n /**\r\n * Returns the point list draw mode\r\n */\r\n Material.PointListDrawMode = 3;\r\n /**\r\n * Returns the line list draw mode\r\n */\r\n Material.LineListDrawMode = 4;\r\n /**\r\n * Returns the line loop draw mode\r\n */\r\n Material.LineLoopDrawMode = 5;\r\n /**\r\n * Returns the line strip draw mode\r\n */\r\n Material.LineStripDrawMode = 6;\r\n /**\r\n * Returns the triangle strip draw mode\r\n */\r\n Material.TriangleStripDrawMode = 7;\r\n /**\r\n * Returns the triangle fan draw mode\r\n */\r\n Material.TriangleFanDrawMode = 8;\r\n /**\r\n * Stores the clock-wise side orientation\r\n */\r\n Material.ClockWiseSideOrientation = 0;\r\n /**\r\n * Stores the counter clock-wise side orientation\r\n */\r\n Material.CounterClockWiseSideOrientation = 1;\r\n /**\r\n * The dirty texture flag value\r\n */\r\n Material.TextureDirtyFlag = 1;\r\n /**\r\n * The dirty light flag value\r\n */\r\n Material.LightDirtyFlag = 2;\r\n /**\r\n * The dirty fresnel flag value\r\n */\r\n Material.FresnelDirtyFlag = 4;\r\n /**\r\n * The dirty attribute flag value\r\n */\r\n Material.AttributesDirtyFlag = 8;\r\n /**\r\n * The dirty misc flag value\r\n */\r\n Material.MiscDirtyFlag = 16;\r\n /**\r\n * The all dirty flag value\r\n */\r\n Material.AllDirtyFlag = 31;\r\n Material._AllDirtyCallBack = function (defines) { return defines.markAllAsDirty(); };\r\n Material._ImageProcessingDirtyCallBack = function (defines) { return defines.markAsImageProcessingDirty(); };\r\n Material._TextureDirtyCallBack = function (defines) { return defines.markAsTexturesDirty(); };\r\n Material._FresnelDirtyCallBack = function (defines) { return defines.markAsFresnelDirty(); };\r\n Material._MiscDirtyCallBack = function (defines) { return defines.markAsMiscDirty(); };\r\n Material._LightsDirtyCallBack = function (defines) { return defines.markAsLightDirty(); };\r\n Material._AttributeDirtyCallBack = function (defines) { return defines.markAsAttributesDirty(); };\r\n Material._FresnelAndMiscDirtyCallBack = function (defines) {\r\n Material._FresnelDirtyCallBack(defines);\r\n Material._MiscDirtyCallBack(defines);\r\n };\r\n Material._TextureAndMiscDirtyCallBack = function (defines) {\r\n Material._TextureDirtyCallBack(defines);\r\n Material._MiscDirtyCallBack(defines);\r\n };\r\n Material._DirtyCallbackArray = [];\r\n Material._RunDirtyCallBacks = function (defines) {\r\n for (var _i = 0, _a = Material._DirtyCallbackArray; _i < _a.length; _i++) {\r\n var cb = _a[_i];\r\n cb(defines);\r\n }\r\n };\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"id\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"uniqueId\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"name\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"checkReadyOnEveryCall\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"checkReadyOnlyOnce\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"state\", void 0);\r\n __decorate([\r\n serialize(\"alpha\")\r\n ], Material.prototype, \"_alpha\", void 0);\r\n __decorate([\r\n serialize(\"backFaceCulling\")\r\n ], Material.prototype, \"_backFaceCulling\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"sideOrientation\", void 0);\r\n __decorate([\r\n serialize(\"alphaMode\")\r\n ], Material.prototype, \"_alphaMode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"_needDepthPrePass\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"disableDepthWrite\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"forceDepthWrite\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"depthFunction\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"separateCullingPass\", void 0);\r\n __decorate([\r\n serialize(\"fogEnabled\")\r\n ], Material.prototype, \"_fogEnabled\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"pointSize\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"zOffset\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"wireframe\", null);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"pointsCloud\", null);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"fillMode\", null);\r\n return Material;\r\n}());\r\nexport { Material };\r\n//# sourceMappingURL=material.js.map","import { __extends } from \"tslib\";\r\n/**\r\n * Defines an GC Friendly array where the backfield array do not shrink to prevent over allocations.\r\n */\r\nvar SmartArray = /** @class */ (function () {\r\n /**\r\n * Instantiates a Smart Array.\r\n * @param capacity defines the default capacity of the array.\r\n */\r\n function SmartArray(capacity) {\r\n /**\r\n * The active length of the array.\r\n */\r\n this.length = 0;\r\n this.data = new Array(capacity);\r\n this._id = SmartArray._GlobalId++;\r\n }\r\n /**\r\n * Pushes a value at the end of the active data.\r\n * @param value defines the object to push in the array.\r\n */\r\n SmartArray.prototype.push = function (value) {\r\n this.data[this.length++] = value;\r\n if (this.length > this.data.length) {\r\n this.data.length *= 2;\r\n }\r\n };\r\n /**\r\n * Iterates over the active data and apply the lambda to them.\r\n * @param func defines the action to apply on each value.\r\n */\r\n SmartArray.prototype.forEach = function (func) {\r\n for (var index = 0; index < this.length; index++) {\r\n func(this.data[index]);\r\n }\r\n };\r\n /**\r\n * Sorts the full sets of data.\r\n * @param compareFn defines the comparison function to apply.\r\n */\r\n SmartArray.prototype.sort = function (compareFn) {\r\n this.data.sort(compareFn);\r\n };\r\n /**\r\n * Resets the active data to an empty array.\r\n */\r\n SmartArray.prototype.reset = function () {\r\n this.length = 0;\r\n };\r\n /**\r\n * Releases all the data from the array as well as the array.\r\n */\r\n SmartArray.prototype.dispose = function () {\r\n this.reset();\r\n if (this.data) {\r\n this.data.length = 0;\r\n this.data = [];\r\n }\r\n };\r\n /**\r\n * Concats the active data with a given array.\r\n * @param array defines the data to concatenate with.\r\n */\r\n SmartArray.prototype.concat = function (array) {\r\n if (array.length === 0) {\r\n return;\r\n }\r\n if (this.length + array.length > this.data.length) {\r\n this.data.length = (this.length + array.length) * 2;\r\n }\r\n for (var index = 0; index < array.length; index++) {\r\n this.data[this.length++] = (array.data || array)[index];\r\n }\r\n };\r\n /**\r\n * Returns the position of a value in the active data.\r\n * @param value defines the value to find the index for\r\n * @returns the index if found in the active data otherwise -1\r\n */\r\n SmartArray.prototype.indexOf = function (value) {\r\n var position = this.data.indexOf(value);\r\n if (position >= this.length) {\r\n return -1;\r\n }\r\n return position;\r\n };\r\n /**\r\n * Returns whether an element is part of the active data.\r\n * @param value defines the value to look for\r\n * @returns true if found in the active data otherwise false\r\n */\r\n SmartArray.prototype.contains = function (value) {\r\n return this.indexOf(value) !== -1;\r\n };\r\n // Statics\r\n SmartArray._GlobalId = 0;\r\n return SmartArray;\r\n}());\r\nexport { SmartArray };\r\n/**\r\n * Defines an GC Friendly array where the backfield array do not shrink to prevent over allocations.\r\n * The data in this array can only be present once\r\n */\r\nvar SmartArrayNoDuplicate = /** @class */ (function (_super) {\r\n __extends(SmartArrayNoDuplicate, _super);\r\n function SmartArrayNoDuplicate() {\r\n var _this = _super !== null && _super.apply(this, arguments) || this;\r\n _this._duplicateId = 0;\r\n return _this;\r\n }\r\n /**\r\n * Pushes a value at the end of the active data.\r\n * THIS DOES NOT PREVENT DUPPLICATE DATA\r\n * @param value defines the object to push in the array.\r\n */\r\n SmartArrayNoDuplicate.prototype.push = function (value) {\r\n _super.prototype.push.call(this, value);\r\n if (!value.__smartArrayFlags) {\r\n value.__smartArrayFlags = {};\r\n }\r\n value.__smartArrayFlags[this._id] = this._duplicateId;\r\n };\r\n /**\r\n * Pushes a value at the end of the active data.\r\n * If the data is already present, it won t be added again\r\n * @param value defines the object to push in the array.\r\n * @returns true if added false if it was already present\r\n */\r\n SmartArrayNoDuplicate.prototype.pushNoDuplicate = function (value) {\r\n if (value.__smartArrayFlags && value.__smartArrayFlags[this._id] === this._duplicateId) {\r\n return false;\r\n }\r\n this.push(value);\r\n return true;\r\n };\r\n /**\r\n * Resets the active data to an empty array.\r\n */\r\n SmartArrayNoDuplicate.prototype.reset = function () {\r\n _super.prototype.reset.call(this);\r\n this._duplicateId++;\r\n };\r\n /**\r\n * Concats the active data with a given array.\r\n * This ensures no dupplicate will be present in the result.\r\n * @param array defines the data to concatenate with.\r\n */\r\n SmartArrayNoDuplicate.prototype.concatWithNoDuplicate = function (array) {\r\n if (array.length === 0) {\r\n return;\r\n }\r\n if (this.length + array.length > this.data.length) {\r\n this.data.length = (this.length + array.length) * 2;\r\n }\r\n for (var index = 0; index < array.length; index++) {\r\n var item = (array.data || array)[index];\r\n this.pushNoDuplicate(item);\r\n }\r\n };\r\n return SmartArrayNoDuplicate;\r\n}(SmartArray));\r\nexport { SmartArrayNoDuplicate };\r\n//# sourceMappingURL=smartArray.js.map","import { Vector2 } from \"@babylonjs/core/Maths/math.vector\";\r\nvar tmpRect = [\r\n new Vector2(0, 0),\r\n new Vector2(0, 0),\r\n new Vector2(0, 0),\r\n new Vector2(0, 0),\r\n];\r\nvar tmpRect2 = [\r\n new Vector2(0, 0),\r\n new Vector2(0, 0),\r\n new Vector2(0, 0),\r\n new Vector2(0, 0),\r\n];\r\nvar tmpV1 = new Vector2(0, 0);\r\nvar tmpV2 = new Vector2(0, 0);\r\n/**\r\n * Class used to store 2D control sizes\r\n */\r\nvar Measure = /** @class */ (function () {\r\n /**\r\n * Creates a new measure\r\n * @param left defines left coordinate\r\n * @param top defines top coordinate\r\n * @param width defines width dimension\r\n * @param height defines height dimension\r\n */\r\n function Measure(\r\n /** defines left coordinate */\r\n left, \r\n /** defines top coordinate */\r\n top, \r\n /** defines width dimension */\r\n width, \r\n /** defines height dimension */\r\n height) {\r\n this.left = left;\r\n this.top = top;\r\n this.width = width;\r\n this.height = height;\r\n }\r\n /**\r\n * Copy from another measure\r\n * @param other defines the other measure to copy from\r\n */\r\n Measure.prototype.copyFrom = function (other) {\r\n this.left = other.left;\r\n this.top = other.top;\r\n this.width = other.width;\r\n this.height = other.height;\r\n };\r\n /**\r\n * Copy from a group of 4 floats\r\n * @param left defines left coordinate\r\n * @param top defines top coordinate\r\n * @param width defines width dimension\r\n * @param height defines height dimension\r\n */\r\n Measure.prototype.copyFromFloats = function (left, top, width, height) {\r\n this.left = left;\r\n this.top = top;\r\n this.width = width;\r\n this.height = height;\r\n };\r\n /**\r\n * Computes the axis aligned bounding box measure for two given measures\r\n * @param a Input measure\r\n * @param b Input measure\r\n * @param result the resulting bounding measure\r\n */\r\n Measure.CombineToRef = function (a, b, result) {\r\n var left = Math.min(a.left, b.left);\r\n var top = Math.min(a.top, b.top);\r\n var right = Math.max(a.left + a.width, b.left + b.width);\r\n var bottom = Math.max(a.top + a.height, b.top + b.height);\r\n result.left = left;\r\n result.top = top;\r\n result.width = right - left;\r\n result.height = bottom - top;\r\n };\r\n /**\r\n * Computes the axis aligned bounding box of the measure after it is modified by a given transform\r\n * @param transform the matrix to transform the measure before computing the AABB\r\n * @param result the resulting AABB\r\n */\r\n Measure.prototype.transformToRef = function (transform, result) {\r\n tmpRect[0].copyFromFloats(this.left, this.top);\r\n tmpRect[1].copyFromFloats(this.left + this.width, this.top);\r\n tmpRect[2].copyFromFloats(this.left + this.width, this.top + this.height);\r\n tmpRect[3].copyFromFloats(this.left, this.top + this.height);\r\n tmpV1.copyFromFloats(Number.MAX_VALUE, Number.MAX_VALUE);\r\n tmpV2.copyFromFloats(0, 0);\r\n for (var i = 0; i < 4; i++) {\r\n transform.transformCoordinates(tmpRect[i].x, tmpRect[i].y, tmpRect2[i]);\r\n tmpV1.x = Math.floor(Math.min(tmpV1.x, tmpRect2[i].x));\r\n tmpV1.y = Math.floor(Math.min(tmpV1.y, tmpRect2[i].y));\r\n tmpV2.x = Math.ceil(Math.max(tmpV2.x, tmpRect2[i].x));\r\n tmpV2.y = Math.ceil(Math.max(tmpV2.y, tmpRect2[i].y));\r\n }\r\n result.left = tmpV1.x;\r\n result.top = tmpV1.y;\r\n result.width = tmpV2.x - tmpV1.x;\r\n result.height = tmpV2.y - tmpV1.y;\r\n };\r\n /**\r\n * Check equality between this measure and another one\r\n * @param other defines the other measures\r\n * @returns true if both measures are equals\r\n */\r\n Measure.prototype.isEqualsTo = function (other) {\r\n if (this.left !== other.left) {\r\n return false;\r\n }\r\n if (this.top !== other.top) {\r\n return false;\r\n }\r\n if (this.width !== other.width) {\r\n return false;\r\n }\r\n if (this.height !== other.height) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n /**\r\n * Creates an empty measure\r\n * @returns a new measure\r\n */\r\n Measure.Empty = function () {\r\n return new Measure(0, 0, 0, 0);\r\n };\r\n return Measure;\r\n}());\r\nexport { Measure };\r\n//# sourceMappingURL=measure.js.map","/**\r\n * Class containing a set of static utilities functions for arrays.\r\n */\r\nvar ArrayTools = /** @class */ (function () {\r\n function ArrayTools() {\r\n }\r\n /**\r\n * Returns an array of the given size filled with element built from the given constructor and the paramters\r\n * @param size the number of element to construct and put in the array\r\n * @param itemBuilder a callback responsible for creating new instance of item. Called once per array entry.\r\n * @returns a new array filled with new objects\r\n */\r\n ArrayTools.BuildArray = function (size, itemBuilder) {\r\n var a = [];\r\n for (var i = 0; i < size; ++i) {\r\n a.push(itemBuilder());\r\n }\r\n return a;\r\n };\r\n return ArrayTools;\r\n}());\r\nexport { ArrayTools };\r\n//# sourceMappingURL=arrayTools.js.map","/**\r\n * This class implement a typical dictionary using a string as key and the generic type T as value.\r\n * The underlying implementation relies on an associative array to ensure the best performances.\r\n * The value can be anything including 'null' but except 'undefined'\r\n */\r\nvar StringDictionary = /** @class */ (function () {\r\n function StringDictionary() {\r\n this._count = 0;\r\n this._data = {};\r\n }\r\n /**\r\n * This will clear this dictionary and copy the content from the 'source' one.\r\n * If the T value is a custom object, it won't be copied/cloned, the same object will be used\r\n * @param source the dictionary to take the content from and copy to this dictionary\r\n */\r\n StringDictionary.prototype.copyFrom = function (source) {\r\n var _this = this;\r\n this.clear();\r\n source.forEach(function (t, v) { return _this.add(t, v); });\r\n };\r\n /**\r\n * Get a value based from its key\r\n * @param key the given key to get the matching value from\r\n * @return the value if found, otherwise undefined is returned\r\n */\r\n StringDictionary.prototype.get = function (key) {\r\n var val = this._data[key];\r\n if (val !== undefined) {\r\n return val;\r\n }\r\n return undefined;\r\n };\r\n /**\r\n * Get a value from its key or add it if it doesn't exist.\r\n * This method will ensure you that a given key/data will be present in the dictionary.\r\n * @param key the given key to get the matching value from\r\n * @param factory the factory that will create the value if the key is not present in the dictionary.\r\n * The factory will only be invoked if there's no data for the given key.\r\n * @return the value corresponding to the key.\r\n */\r\n StringDictionary.prototype.getOrAddWithFactory = function (key, factory) {\r\n var val = this.get(key);\r\n if (val !== undefined) {\r\n return val;\r\n }\r\n val = factory(key);\r\n if (val) {\r\n this.add(key, val);\r\n }\r\n return val;\r\n };\r\n /**\r\n * Get a value from its key if present in the dictionary otherwise add it\r\n * @param key the key to get the value from\r\n * @param val if there's no such key/value pair in the dictionary add it with this value\r\n * @return the value corresponding to the key\r\n */\r\n StringDictionary.prototype.getOrAdd = function (key, val) {\r\n var curVal = this.get(key);\r\n if (curVal !== undefined) {\r\n return curVal;\r\n }\r\n this.add(key, val);\r\n return val;\r\n };\r\n /**\r\n * Check if there's a given key in the dictionary\r\n * @param key the key to check for\r\n * @return true if the key is present, false otherwise\r\n */\r\n StringDictionary.prototype.contains = function (key) {\r\n return this._data[key] !== undefined;\r\n };\r\n /**\r\n * Add a new key and its corresponding value\r\n * @param key the key to add\r\n * @param value the value corresponding to the key\r\n * @return true if the operation completed successfully, false if we couldn't insert the key/value because there was already this key in the dictionary\r\n */\r\n StringDictionary.prototype.add = function (key, value) {\r\n if (this._data[key] !== undefined) {\r\n return false;\r\n }\r\n this._data[key] = value;\r\n ++this._count;\r\n return true;\r\n };\r\n /**\r\n * Update a specific value associated to a key\r\n * @param key defines the key to use\r\n * @param value defines the value to store\r\n * @returns true if the value was updated (or false if the key was not found)\r\n */\r\n StringDictionary.prototype.set = function (key, value) {\r\n if (this._data[key] === undefined) {\r\n return false;\r\n }\r\n this._data[key] = value;\r\n return true;\r\n };\r\n /**\r\n * Get the element of the given key and remove it from the dictionary\r\n * @param key defines the key to search\r\n * @returns the value associated with the key or null if not found\r\n */\r\n StringDictionary.prototype.getAndRemove = function (key) {\r\n var val = this.get(key);\r\n if (val !== undefined) {\r\n delete this._data[key];\r\n --this._count;\r\n return val;\r\n }\r\n return null;\r\n };\r\n /**\r\n * Remove a key/value from the dictionary.\r\n * @param key the key to remove\r\n * @return true if the item was successfully deleted, false if no item with such key exist in the dictionary\r\n */\r\n StringDictionary.prototype.remove = function (key) {\r\n if (this.contains(key)) {\r\n delete this._data[key];\r\n --this._count;\r\n return true;\r\n }\r\n return false;\r\n };\r\n /**\r\n * Clear the whole content of the dictionary\r\n */\r\n StringDictionary.prototype.clear = function () {\r\n this._data = {};\r\n this._count = 0;\r\n };\r\n Object.defineProperty(StringDictionary.prototype, \"count\", {\r\n /**\r\n * Gets the current count\r\n */\r\n get: function () {\r\n return this._count;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Execute a callback on each key/val of the dictionary.\r\n * Note that you can remove any element in this dictionary in the callback implementation\r\n * @param callback the callback to execute on a given key/value pair\r\n */\r\n StringDictionary.prototype.forEach = function (callback) {\r\n for (var cur in this._data) {\r\n var val = this._data[cur];\r\n callback(cur, val);\r\n }\r\n };\r\n /**\r\n * Execute a callback on every occurrence of the dictionary until it returns a valid TRes object.\r\n * If the callback returns null or undefined the method will iterate to the next key/value pair\r\n * Note that you can remove any element in this dictionary in the callback implementation\r\n * @param callback the callback to execute, if it return a valid T instanced object the enumeration will stop and the object will be returned\r\n * @returns the first item\r\n */\r\n StringDictionary.prototype.first = function (callback) {\r\n for (var cur in this._data) {\r\n var val = this._data[cur];\r\n var res = callback(cur, val);\r\n if (res) {\r\n return res;\r\n }\r\n }\r\n return null;\r\n };\r\n return StringDictionary;\r\n}());\r\nexport { StringDictionary };\r\n//# sourceMappingURL=stringDictionary.js.map","/**\r\n * Base class of the scene acting as a container for the different elements composing a scene.\r\n * This class is dynamically extended by the different components of the scene increasing\r\n * flexibility and reducing coupling\r\n */\r\nvar AbstractScene = /** @class */ (function () {\r\n function AbstractScene() {\r\n /**\r\n * Gets the list of root nodes (ie. nodes with no parent)\r\n */\r\n this.rootNodes = new Array();\r\n /** All of the cameras added to this scene\r\n * @see http://doc.babylonjs.com/babylon101/cameras\r\n */\r\n this.cameras = new Array();\r\n /**\r\n * All of the lights added to this scene\r\n * @see http://doc.babylonjs.com/babylon101/lights\r\n */\r\n this.lights = new Array();\r\n /**\r\n * All of the (abstract) meshes added to this scene\r\n */\r\n this.meshes = new Array();\r\n /**\r\n * The list of skeletons added to the scene\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_bones_and_skeletons\r\n */\r\n this.skeletons = new Array();\r\n /**\r\n * All of the particle systems added to this scene\r\n * @see http://doc.babylonjs.com/babylon101/particles\r\n */\r\n this.particleSystems = new Array();\r\n /**\r\n * Gets a list of Animations associated with the scene\r\n */\r\n this.animations = [];\r\n /**\r\n * All of the animation groups added to this scene\r\n * @see http://doc.babylonjs.com/how_to/group\r\n */\r\n this.animationGroups = new Array();\r\n /**\r\n * All of the multi-materials added to this scene\r\n * @see http://doc.babylonjs.com/how_to/multi_materials\r\n */\r\n this.multiMaterials = new Array();\r\n /**\r\n * All of the materials added to this scene\r\n * In the context of a Scene, it is not supposed to be modified manually.\r\n * Any addition or removal should be done using the addMaterial and removeMaterial Scene methods.\r\n * Note also that the order of the Material within the array is not significant and might change.\r\n * @see http://doc.babylonjs.com/babylon101/materials\r\n */\r\n this.materials = new Array();\r\n /**\r\n * The list of morph target managers added to the scene\r\n * @see http://doc.babylonjs.com/how_to/how_to_dynamically_morph_a_mesh\r\n */\r\n this.morphTargetManagers = new Array();\r\n /**\r\n * The list of geometries used in the scene.\r\n */\r\n this.geometries = new Array();\r\n /**\r\n * All of the tranform nodes added to this scene\r\n * In the context of a Scene, it is not supposed to be modified manually.\r\n * Any addition or removal should be done using the addTransformNode and removeTransformNode Scene methods.\r\n * Note also that the order of the TransformNode wihin the array is not significant and might change.\r\n * @see http://doc.babylonjs.com/how_to/transformnode\r\n */\r\n this.transformNodes = new Array();\r\n /**\r\n * ActionManagers available on the scene.\r\n */\r\n this.actionManagers = new Array();\r\n /**\r\n * Textures to keep.\r\n */\r\n this.textures = new Array();\r\n /**\r\n * Environment texture for the scene\r\n */\r\n this.environmentTexture = null;\r\n }\r\n /**\r\n * Adds a parser in the list of available ones\r\n * @param name Defines the name of the parser\r\n * @param parser Defines the parser to add\r\n */\r\n AbstractScene.AddParser = function (name, parser) {\r\n this._BabylonFileParsers[name] = parser;\r\n };\r\n /**\r\n * Gets a general parser from the list of avaialble ones\r\n * @param name Defines the name of the parser\r\n * @returns the requested parser or null\r\n */\r\n AbstractScene.GetParser = function (name) {\r\n if (this._BabylonFileParsers[name]) {\r\n return this._BabylonFileParsers[name];\r\n }\r\n return null;\r\n };\r\n /**\r\n * Adds n individual parser in the list of available ones\r\n * @param name Defines the name of the parser\r\n * @param parser Defines the parser to add\r\n */\r\n AbstractScene.AddIndividualParser = function (name, parser) {\r\n this._IndividualBabylonFileParsers[name] = parser;\r\n };\r\n /**\r\n * Gets an individual parser from the list of avaialble ones\r\n * @param name Defines the name of the parser\r\n * @returns the requested parser or null\r\n */\r\n AbstractScene.GetIndividualParser = function (name) {\r\n if (this._IndividualBabylonFileParsers[name]) {\r\n return this._IndividualBabylonFileParsers[name];\r\n }\r\n return null;\r\n };\r\n /**\r\n * Parser json data and populate both a scene and its associated container object\r\n * @param jsonData Defines the data to parse\r\n * @param scene Defines the scene to parse the data for\r\n * @param container Defines the container attached to the parsing sequence\r\n * @param rootUrl Defines the root url of the data\r\n */\r\n AbstractScene.Parse = function (jsonData, scene, container, rootUrl) {\r\n for (var parserName in this._BabylonFileParsers) {\r\n if (this._BabylonFileParsers.hasOwnProperty(parserName)) {\r\n this._BabylonFileParsers[parserName](jsonData, scene, container, rootUrl);\r\n }\r\n }\r\n };\r\n /**\r\n * @returns all meshes, lights, cameras, transformNodes and bones\r\n */\r\n AbstractScene.prototype.getNodes = function () {\r\n var nodes = new Array();\r\n nodes = nodes.concat(this.meshes);\r\n nodes = nodes.concat(this.lights);\r\n nodes = nodes.concat(this.cameras);\r\n nodes = nodes.concat(this.transformNodes); // dummies\r\n this.skeletons.forEach(function (skeleton) { return nodes = nodes.concat(skeleton.bones); });\r\n return nodes;\r\n };\r\n /**\r\n * Stores the list of available parsers in the application.\r\n */\r\n AbstractScene._BabylonFileParsers = {};\r\n /**\r\n * Stores the list of available individual parsers in the application.\r\n */\r\n AbstractScene._IndividualBabylonFileParsers = {};\r\n return AbstractScene;\r\n}());\r\nexport { AbstractScene };\r\n//# sourceMappingURL=abstractScene.js.map","/**\r\n * ActionEvent is the event being sent when an action is triggered.\r\n */\r\nvar ActionEvent = /** @class */ (function () {\r\n /**\r\n * Creates a new ActionEvent\r\n * @param source The mesh or sprite that triggered the action\r\n * @param pointerX The X mouse cursor position at the time of the event\r\n * @param pointerY The Y mouse cursor position at the time of the event\r\n * @param meshUnderPointer The mesh that is currently pointed at (can be null)\r\n * @param sourceEvent the original (browser) event that triggered the ActionEvent\r\n * @param additionalData additional data for the event\r\n */\r\n function ActionEvent(\r\n /** The mesh or sprite that triggered the action */\r\n source, \r\n /** The X mouse cursor position at the time of the event */\r\n pointerX, \r\n /** The Y mouse cursor position at the time of the event */\r\n pointerY, \r\n /** The mesh that is currently pointed at (can be null) */\r\n meshUnderPointer, \r\n /** the original (browser) event that triggered the ActionEvent */\r\n sourceEvent, \r\n /** additional data for the event */\r\n additionalData) {\r\n this.source = source;\r\n this.pointerX = pointerX;\r\n this.pointerY = pointerY;\r\n this.meshUnderPointer = meshUnderPointer;\r\n this.sourceEvent = sourceEvent;\r\n this.additionalData = additionalData;\r\n }\r\n /**\r\n * Helper function to auto-create an ActionEvent from a source mesh.\r\n * @param source The source mesh that triggered the event\r\n * @param evt The original (browser) event\r\n * @param additionalData additional data for the event\r\n * @returns the new ActionEvent\r\n */\r\n ActionEvent.CreateNew = function (source, evt, additionalData) {\r\n var scene = source.getScene();\r\n return new ActionEvent(source, scene.pointerX, scene.pointerY, scene.meshUnderPointer || source, evt, additionalData);\r\n };\r\n /**\r\n * Helper function to auto-create an ActionEvent from a source sprite\r\n * @param source The source sprite that triggered the event\r\n * @param scene Scene associated with the sprite\r\n * @param evt The original (browser) event\r\n * @param additionalData additional data for the event\r\n * @returns the new ActionEvent\r\n */\r\n ActionEvent.CreateNewFromSprite = function (source, scene, evt, additionalData) {\r\n return new ActionEvent(source, scene.pointerX, scene.pointerY, scene.meshUnderPointer, evt, additionalData);\r\n };\r\n /**\r\n * Helper function to auto-create an ActionEvent from a scene. If triggered by a mesh use ActionEvent.CreateNew\r\n * @param scene the scene where the event occurred\r\n * @param evt The original (browser) event\r\n * @returns the new ActionEvent\r\n */\r\n ActionEvent.CreateNewFromScene = function (scene, evt) {\r\n return new ActionEvent(null, scene.pointerX, scene.pointerY, scene.meshUnderPointer, evt);\r\n };\r\n /**\r\n * Helper function to auto-create an ActionEvent from a primitive\r\n * @param prim defines the target primitive\r\n * @param pointerPos defines the pointer position\r\n * @param evt The original (browser) event\r\n * @param additionalData additional data for the event\r\n * @returns the new ActionEvent\r\n */\r\n ActionEvent.CreateNewFromPrimitive = function (prim, pointerPos, evt, additionalData) {\r\n return new ActionEvent(prim, pointerPos.x, pointerPos.y, null, evt, additionalData);\r\n };\r\n return ActionEvent;\r\n}());\r\nexport { ActionEvent };\r\n//# sourceMappingURL=actionEvent.js.map","/**\r\n * Abstract class used to decouple action Manager from scene and meshes.\r\n * Do not instantiate.\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions\r\n */\r\nvar AbstractActionManager = /** @class */ (function () {\r\n function AbstractActionManager() {\r\n /** Gets the cursor to use when hovering items */\r\n this.hoverCursor = '';\r\n /** Gets the list of actions */\r\n this.actions = new Array();\r\n /**\r\n * Gets or sets a boolean indicating that the manager is recursive meaning that it can trigger action from children\r\n */\r\n this.isRecursive = false;\r\n }\r\n Object.defineProperty(AbstractActionManager, \"HasTriggers\", {\r\n /**\r\n * Does exist one action manager with at least one trigger\r\n **/\r\n get: function () {\r\n for (var t in AbstractActionManager.Triggers) {\r\n if (AbstractActionManager.Triggers.hasOwnProperty(t)) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractActionManager, \"HasPickTriggers\", {\r\n /**\r\n * Does exist one action manager with at least one pick trigger\r\n **/\r\n get: function () {\r\n for (var t in AbstractActionManager.Triggers) {\r\n if (AbstractActionManager.Triggers.hasOwnProperty(t)) {\r\n var t_int = parseInt(t);\r\n if (t_int >= 1 && t_int <= 7) {\r\n return true;\r\n }\r\n }\r\n }\r\n return false;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Does exist one action manager that handles actions of a given trigger\r\n * @param trigger defines the trigger to be tested\r\n * @return a boolean indicating whether the trigger is handeled by at least one action manager\r\n **/\r\n AbstractActionManager.HasSpecificTrigger = function (trigger) {\r\n for (var t in AbstractActionManager.Triggers) {\r\n if (AbstractActionManager.Triggers.hasOwnProperty(t)) {\r\n var t_int = parseInt(t);\r\n if (t_int === trigger) {\r\n return true;\r\n }\r\n }\r\n }\r\n return false;\r\n };\r\n /** Gets the list of active triggers */\r\n AbstractActionManager.Triggers = {};\r\n return AbstractActionManager;\r\n}());\r\nexport { AbstractActionManager };\r\n//# sourceMappingURL=abstractActionManager.js.map","import { PointerInfoPre, PointerInfo, PointerEventTypes } from '../Events/pointerEvents';\r\nimport { AbstractActionManager } from '../Actions/abstractActionManager';\r\nimport { Vector2, Matrix } from '../Maths/math.vector';\r\nimport { ActionEvent } from '../Actions/actionEvent';\r\nimport { Tools } from '../Misc/tools';\r\nimport { KeyboardEventTypes, KeyboardInfoPre, KeyboardInfo } from '../Events/keyboardEvents';\r\n/** @hidden */\r\nvar _ClickInfo = /** @class */ (function () {\r\n function _ClickInfo() {\r\n this._singleClick = false;\r\n this._doubleClick = false;\r\n this._hasSwiped = false;\r\n this._ignore = false;\r\n }\r\n Object.defineProperty(_ClickInfo.prototype, \"singleClick\", {\r\n get: function () {\r\n return this._singleClick;\r\n },\r\n set: function (b) {\r\n this._singleClick = b;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(_ClickInfo.prototype, \"doubleClick\", {\r\n get: function () {\r\n return this._doubleClick;\r\n },\r\n set: function (b) {\r\n this._doubleClick = b;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(_ClickInfo.prototype, \"hasSwiped\", {\r\n get: function () {\r\n return this._hasSwiped;\r\n },\r\n set: function (b) {\r\n this._hasSwiped = b;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(_ClickInfo.prototype, \"ignore\", {\r\n get: function () {\r\n return this._ignore;\r\n },\r\n set: function (b) {\r\n this._ignore = b;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n return _ClickInfo;\r\n}());\r\n/**\r\n * Class used to manage all inputs for the scene.\r\n */\r\nvar InputManager = /** @class */ (function () {\r\n /**\r\n * Creates a new InputManager\r\n * @param scene defines the hosting scene\r\n */\r\n function InputManager(scene) {\r\n // Pointers\r\n this._wheelEventName = \"\";\r\n this._meshPickProceed = false;\r\n this._currentPickResult = null;\r\n this._previousPickResult = null;\r\n this._totalPointersPressed = 0;\r\n this._doubleClickOccured = false;\r\n this._pointerX = 0;\r\n this._pointerY = 0;\r\n this._startingPointerPosition = new Vector2(0, 0);\r\n this._previousStartingPointerPosition = new Vector2(0, 0);\r\n this._startingPointerTime = 0;\r\n this._previousStartingPointerTime = 0;\r\n this._pointerCaptures = {};\r\n this._scene = scene;\r\n }\r\n Object.defineProperty(InputManager.prototype, \"meshUnderPointer\", {\r\n /**\r\n * Gets the mesh that is currently under the pointer\r\n */\r\n get: function () {\r\n return this._pointerOverMesh;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputManager.prototype, \"unTranslatedPointer\", {\r\n /**\r\n * Gets the pointer coordinates in 2D without any translation (ie. straight out of the pointer event)\r\n */\r\n get: function () {\r\n return new Vector2(this._unTranslatedPointerX, this._unTranslatedPointerY);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputManager.prototype, \"pointerX\", {\r\n /**\r\n * Gets or sets the current on-screen X position of the pointer\r\n */\r\n get: function () {\r\n return this._pointerX;\r\n },\r\n set: function (value) {\r\n this._pointerX = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputManager.prototype, \"pointerY\", {\r\n /**\r\n * Gets or sets the current on-screen Y position of the pointer\r\n */\r\n get: function () {\r\n return this._pointerY;\r\n },\r\n set: function (value) {\r\n this._pointerY = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n InputManager.prototype._updatePointerPosition = function (evt) {\r\n var canvasRect = this._scene.getEngine().getInputElementClientRect();\r\n if (!canvasRect) {\r\n return;\r\n }\r\n this._pointerX = evt.clientX - canvasRect.left;\r\n this._pointerY = evt.clientY - canvasRect.top;\r\n this._unTranslatedPointerX = this._pointerX;\r\n this._unTranslatedPointerY = this._pointerY;\r\n };\r\n InputManager.prototype._processPointerMove = function (pickResult, evt) {\r\n var scene = this._scene;\r\n var engine = scene.getEngine();\r\n var canvas = engine.getInputElement();\r\n if (!canvas) {\r\n return;\r\n }\r\n canvas.tabIndex = engine.canvasTabIndex;\r\n // Restore pointer\r\n if (!scene.doNotHandleCursors) {\r\n canvas.style.cursor = scene.defaultCursor;\r\n }\r\n var isMeshPicked = (pickResult && pickResult.hit && pickResult.pickedMesh) ? true : false;\r\n if (isMeshPicked) {\r\n scene.setPointerOverMesh(pickResult.pickedMesh);\r\n if (this._pointerOverMesh && this._pointerOverMesh.actionManager && this._pointerOverMesh.actionManager.hasPointerTriggers) {\r\n if (!scene.doNotHandleCursors) {\r\n if (this._pointerOverMesh.actionManager.hoverCursor) {\r\n canvas.style.cursor = this._pointerOverMesh.actionManager.hoverCursor;\r\n }\r\n else {\r\n canvas.style.cursor = scene.hoverCursor;\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n scene.setPointerOverMesh(null);\r\n }\r\n for (var _i = 0, _a = scene._pointerMoveStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n pickResult = step.action(this._unTranslatedPointerX, this._unTranslatedPointerY, pickResult, isMeshPicked, canvas);\r\n }\r\n if (pickResult) {\r\n var type = evt.type === this._wheelEventName ? PointerEventTypes.POINTERWHEEL : PointerEventTypes.POINTERMOVE;\r\n if (scene.onPointerMove) {\r\n scene.onPointerMove(evt, pickResult, type);\r\n }\r\n if (scene.onPointerObservable.hasObservers()) {\r\n var pi = new PointerInfo(type, evt, pickResult);\r\n this._setRayOnPointerInfo(pi);\r\n scene.onPointerObservable.notifyObservers(pi, type);\r\n }\r\n }\r\n };\r\n // Pointers handling\r\n InputManager.prototype._setRayOnPointerInfo = function (pointerInfo) {\r\n var scene = this._scene;\r\n if (pointerInfo.pickInfo && !pointerInfo.pickInfo._pickingUnavailable) {\r\n if (!pointerInfo.pickInfo.ray) {\r\n pointerInfo.pickInfo.ray = scene.createPickingRay(pointerInfo.event.offsetX, pointerInfo.event.offsetY, Matrix.Identity(), scene.activeCamera);\r\n }\r\n }\r\n };\r\n InputManager.prototype._checkPrePointerObservable = function (pickResult, evt, type) {\r\n var scene = this._scene;\r\n var pi = new PointerInfoPre(type, evt, this._unTranslatedPointerX, this._unTranslatedPointerY);\r\n if (pickResult) {\r\n pi.ray = pickResult.ray;\r\n }\r\n scene.onPrePointerObservable.notifyObservers(pi, type);\r\n if (pi.skipOnPointerObservable) {\r\n return true;\r\n }\r\n else {\r\n return false;\r\n }\r\n };\r\n /**\r\n * Use this method to simulate a pointer move on a mesh\r\n * The pickResult parameter can be obtained from a scene.pick or scene.pickWithRay\r\n * @param pickResult pickingInfo of the object wished to simulate pointer event on\r\n * @param pointerEventInit pointer event state to be used when simulating the pointer event (eg. pointer id for multitouch)\r\n */\r\n InputManager.prototype.simulatePointerMove = function (pickResult, pointerEventInit) {\r\n var evt = new PointerEvent(\"pointermove\", pointerEventInit);\r\n if (this._checkPrePointerObservable(pickResult, evt, PointerEventTypes.POINTERMOVE)) {\r\n return;\r\n }\r\n this._processPointerMove(pickResult, evt);\r\n };\r\n /**\r\n * Use this method to simulate a pointer down on a mesh\r\n * The pickResult parameter can be obtained from a scene.pick or scene.pickWithRay\r\n * @param pickResult pickingInfo of the object wished to simulate pointer event on\r\n * @param pointerEventInit pointer event state to be used when simulating the pointer event (eg. pointer id for multitouch)\r\n */\r\n InputManager.prototype.simulatePointerDown = function (pickResult, pointerEventInit) {\r\n var evt = new PointerEvent(\"pointerdown\", pointerEventInit);\r\n if (this._checkPrePointerObservable(pickResult, evt, PointerEventTypes.POINTERDOWN)) {\r\n return;\r\n }\r\n this._processPointerDown(pickResult, evt);\r\n };\r\n InputManager.prototype._processPointerDown = function (pickResult, evt) {\r\n var _this = this;\r\n var scene = this._scene;\r\n if (pickResult && pickResult.hit && pickResult.pickedMesh) {\r\n this._pickedDownMesh = pickResult.pickedMesh;\r\n var actionManager = pickResult.pickedMesh._getActionManagerForTrigger();\r\n if (actionManager) {\r\n if (actionManager.hasPickTriggers) {\r\n actionManager.processTrigger(5, ActionEvent.CreateNew(pickResult.pickedMesh, evt));\r\n switch (evt.button) {\r\n case 0:\r\n actionManager.processTrigger(2, ActionEvent.CreateNew(pickResult.pickedMesh, evt));\r\n break;\r\n case 1:\r\n actionManager.processTrigger(4, ActionEvent.CreateNew(pickResult.pickedMesh, evt));\r\n break;\r\n case 2:\r\n actionManager.processTrigger(3, ActionEvent.CreateNew(pickResult.pickedMesh, evt));\r\n break;\r\n }\r\n }\r\n if (actionManager.hasSpecificTrigger(8)) {\r\n window.setTimeout(function () {\r\n var pickResult = scene.pick(_this._unTranslatedPointerX, _this._unTranslatedPointerY, function (mesh) { return (mesh.isPickable && mesh.isVisible && mesh.isReady() && mesh.actionManager && mesh.actionManager.hasSpecificTrigger(8) && mesh == _this._pickedDownMesh); }, false, scene.cameraToUseForPointers);\r\n if (pickResult && pickResult.hit && pickResult.pickedMesh && actionManager) {\r\n if (_this._totalPointersPressed !== 0 &&\r\n ((Date.now() - _this._startingPointerTime) > InputManager.LongPressDelay) &&\r\n !_this._isPointerSwiping()) {\r\n _this._startingPointerTime = 0;\r\n actionManager.processTrigger(8, ActionEvent.CreateNew(pickResult.pickedMesh, evt));\r\n }\r\n }\r\n }, InputManager.LongPressDelay);\r\n }\r\n }\r\n }\r\n else {\r\n for (var _i = 0, _a = scene._pointerDownStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n pickResult = step.action(this._unTranslatedPointerX, this._unTranslatedPointerY, pickResult, evt);\r\n }\r\n }\r\n if (pickResult) {\r\n var type = PointerEventTypes.POINTERDOWN;\r\n if (scene.onPointerDown) {\r\n scene.onPointerDown(evt, pickResult, type);\r\n }\r\n if (scene.onPointerObservable.hasObservers()) {\r\n var pi = new PointerInfo(type, evt, pickResult);\r\n this._setRayOnPointerInfo(pi);\r\n scene.onPointerObservable.notifyObservers(pi, type);\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n InputManager.prototype._isPointerSwiping = function () {\r\n return Math.abs(this._startingPointerPosition.x - this._pointerX) > InputManager.DragMovementThreshold ||\r\n Math.abs(this._startingPointerPosition.y - this._pointerY) > InputManager.DragMovementThreshold;\r\n };\r\n /**\r\n * Use this method to simulate a pointer up on a mesh\r\n * The pickResult parameter can be obtained from a scene.pick or scene.pickWithRay\r\n * @param pickResult pickingInfo of the object wished to simulate pointer event on\r\n * @param pointerEventInit pointer event state to be used when simulating the pointer event (eg. pointer id for multitouch)\r\n * @param doubleTap indicates that the pointer up event should be considered as part of a double click (false by default)\r\n */\r\n InputManager.prototype.simulatePointerUp = function (pickResult, pointerEventInit, doubleTap) {\r\n var evt = new PointerEvent(\"pointerup\", pointerEventInit);\r\n var clickInfo = new _ClickInfo();\r\n if (doubleTap) {\r\n clickInfo.doubleClick = true;\r\n }\r\n else {\r\n clickInfo.singleClick = true;\r\n }\r\n if (this._checkPrePointerObservable(pickResult, evt, PointerEventTypes.POINTERUP)) {\r\n return;\r\n }\r\n this._processPointerUp(pickResult, evt, clickInfo);\r\n };\r\n InputManager.prototype._processPointerUp = function (pickResult, evt, clickInfo) {\r\n var scene = this._scene;\r\n if (pickResult && pickResult && pickResult.pickedMesh) {\r\n this._pickedUpMesh = pickResult.pickedMesh;\r\n if (this._pickedDownMesh === this._pickedUpMesh) {\r\n if (scene.onPointerPick) {\r\n scene.onPointerPick(evt, pickResult);\r\n }\r\n if (clickInfo.singleClick && !clickInfo.ignore && scene.onPointerObservable.hasObservers()) {\r\n var type_1 = PointerEventTypes.POINTERPICK;\r\n var pi = new PointerInfo(type_1, evt, pickResult);\r\n this._setRayOnPointerInfo(pi);\r\n scene.onPointerObservable.notifyObservers(pi, type_1);\r\n }\r\n }\r\n var actionManager = pickResult.pickedMesh._getActionManagerForTrigger();\r\n if (actionManager && !clickInfo.ignore) {\r\n actionManager.processTrigger(7, ActionEvent.CreateNew(pickResult.pickedMesh, evt));\r\n if (!clickInfo.hasSwiped && clickInfo.singleClick) {\r\n actionManager.processTrigger(1, ActionEvent.CreateNew(pickResult.pickedMesh, evt));\r\n }\r\n var doubleClickActionManager = pickResult.pickedMesh._getActionManagerForTrigger(6);\r\n if (clickInfo.doubleClick && doubleClickActionManager) {\r\n doubleClickActionManager.processTrigger(6, ActionEvent.CreateNew(pickResult.pickedMesh, evt));\r\n }\r\n }\r\n }\r\n else {\r\n if (!clickInfo.ignore) {\r\n for (var _i = 0, _a = scene._pointerUpStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n pickResult = step.action(this._unTranslatedPointerX, this._unTranslatedPointerY, pickResult, evt);\r\n }\r\n }\r\n }\r\n if (this._pickedDownMesh && this._pickedDownMesh !== this._pickedUpMesh) {\r\n var pickedDownActionManager = this._pickedDownMesh._getActionManagerForTrigger(16);\r\n if (pickedDownActionManager) {\r\n pickedDownActionManager.processTrigger(16, ActionEvent.CreateNew(this._pickedDownMesh, evt));\r\n }\r\n }\r\n var type = 0;\r\n if (scene.onPointerObservable.hasObservers()) {\r\n if (!clickInfo.ignore && !clickInfo.hasSwiped) {\r\n if (clickInfo.singleClick && scene.onPointerObservable.hasSpecificMask(PointerEventTypes.POINTERTAP)) {\r\n type = PointerEventTypes.POINTERTAP;\r\n }\r\n else if (clickInfo.doubleClick && scene.onPointerObservable.hasSpecificMask(PointerEventTypes.POINTERDOUBLETAP)) {\r\n type = PointerEventTypes.POINTERDOUBLETAP;\r\n }\r\n if (type) {\r\n var pi = new PointerInfo(type, evt, pickResult);\r\n this._setRayOnPointerInfo(pi);\r\n scene.onPointerObservable.notifyObservers(pi, type);\r\n }\r\n }\r\n if (!clickInfo.ignore) {\r\n type = PointerEventTypes.POINTERUP;\r\n var pi = new PointerInfo(type, evt, pickResult);\r\n this._setRayOnPointerInfo(pi);\r\n scene.onPointerObservable.notifyObservers(pi, type);\r\n }\r\n }\r\n if (scene.onPointerUp && !clickInfo.ignore) {\r\n scene.onPointerUp(evt, pickResult, type);\r\n }\r\n };\r\n /**\r\n * Gets a boolean indicating if the current pointer event is captured (meaning that the scene has already handled the pointer down)\r\n * @param pointerId defines the pointer id to use in a multi-touch scenario (0 by default)\r\n * @returns true if the pointer was captured\r\n */\r\n InputManager.prototype.isPointerCaptured = function (pointerId) {\r\n if (pointerId === void 0) { pointerId = 0; }\r\n return this._pointerCaptures[pointerId];\r\n };\r\n /**\r\n * Attach events to the canvas (To handle actionManagers triggers and raise onPointerMove, onPointerDown and onPointerUp\r\n * @param attachUp defines if you want to attach events to pointerup\r\n * @param attachDown defines if you want to attach events to pointerdown\r\n * @param attachMove defines if you want to attach events to pointermove\r\n * @param elementToAttachTo defines the target DOM element to attach to (will use the canvas by default)\r\n */\r\n InputManager.prototype.attachControl = function (attachUp, attachDown, attachMove, elementToAttachTo) {\r\n var _this = this;\r\n if (attachUp === void 0) { attachUp = true; }\r\n if (attachDown === void 0) { attachDown = true; }\r\n if (attachMove === void 0) { attachMove = true; }\r\n if (elementToAttachTo === void 0) { elementToAttachTo = null; }\r\n var scene = this._scene;\r\n if (!elementToAttachTo) {\r\n elementToAttachTo = scene.getEngine().getInputElement();\r\n }\r\n if (!elementToAttachTo) {\r\n return;\r\n }\r\n var engine = scene.getEngine();\r\n this._initActionManager = function (act, clickInfo) {\r\n if (!_this._meshPickProceed) {\r\n var pickResult = scene.pick(_this._unTranslatedPointerX, _this._unTranslatedPointerY, scene.pointerDownPredicate, false, scene.cameraToUseForPointers);\r\n _this._currentPickResult = pickResult;\r\n if (pickResult) {\r\n act = (pickResult.hit && pickResult.pickedMesh) ? pickResult.pickedMesh._getActionManagerForTrigger() : null;\r\n }\r\n _this._meshPickProceed = true;\r\n }\r\n return act;\r\n };\r\n this._delayedSimpleClick = function (btn, clickInfo, cb) {\r\n // double click delay is over and that no double click has been raised since, or the 2 consecutive keys pressed are different\r\n if ((Date.now() - _this._previousStartingPointerTime > InputManager.DoubleClickDelay && !_this._doubleClickOccured) ||\r\n btn !== _this._previousButtonPressed) {\r\n _this._doubleClickOccured = false;\r\n clickInfo.singleClick = true;\r\n clickInfo.ignore = false;\r\n cb(clickInfo, _this._currentPickResult);\r\n }\r\n };\r\n this._initClickEvent = function (obs1, obs2, evt, cb) {\r\n var clickInfo = new _ClickInfo();\r\n _this._currentPickResult = null;\r\n var act = null;\r\n var checkPicking = obs1.hasSpecificMask(PointerEventTypes.POINTERPICK) || obs2.hasSpecificMask(PointerEventTypes.POINTERPICK)\r\n || obs1.hasSpecificMask(PointerEventTypes.POINTERTAP) || obs2.hasSpecificMask(PointerEventTypes.POINTERTAP)\r\n || obs1.hasSpecificMask(PointerEventTypes.POINTERDOUBLETAP) || obs2.hasSpecificMask(PointerEventTypes.POINTERDOUBLETAP);\r\n if (!checkPicking && AbstractActionManager) {\r\n act = _this._initActionManager(act, clickInfo);\r\n if (act) {\r\n checkPicking = act.hasPickTriggers;\r\n }\r\n }\r\n var needToIgnoreNext = false;\r\n if (checkPicking) {\r\n var btn = evt.button;\r\n clickInfo.hasSwiped = _this._isPointerSwiping();\r\n if (!clickInfo.hasSwiped) {\r\n var checkSingleClickImmediately = !InputManager.ExclusiveDoubleClickMode;\r\n if (!checkSingleClickImmediately) {\r\n checkSingleClickImmediately = !obs1.hasSpecificMask(PointerEventTypes.POINTERDOUBLETAP) &&\r\n !obs2.hasSpecificMask(PointerEventTypes.POINTERDOUBLETAP);\r\n if (checkSingleClickImmediately && !AbstractActionManager.HasSpecificTrigger(6)) {\r\n act = _this._initActionManager(act, clickInfo);\r\n if (act) {\r\n checkSingleClickImmediately = !act.hasSpecificTrigger(6);\r\n }\r\n }\r\n }\r\n if (checkSingleClickImmediately) {\r\n // single click detected if double click delay is over or two different successive keys pressed without exclusive double click or no double click required\r\n if (Date.now() - _this._previousStartingPointerTime > InputManager.DoubleClickDelay ||\r\n btn !== _this._previousButtonPressed) {\r\n clickInfo.singleClick = true;\r\n cb(clickInfo, _this._currentPickResult);\r\n needToIgnoreNext = true;\r\n }\r\n }\r\n // at least one double click is required to be check and exclusive double click is enabled\r\n else {\r\n // wait that no double click has been raised during the double click delay\r\n _this._previousDelayedSimpleClickTimeout = _this._delayedSimpleClickTimeout;\r\n _this._delayedSimpleClickTimeout = window.setTimeout(_this._delayedSimpleClick.bind(_this, btn, clickInfo, cb), InputManager.DoubleClickDelay);\r\n }\r\n var checkDoubleClick = obs1.hasSpecificMask(PointerEventTypes.POINTERDOUBLETAP) ||\r\n obs2.hasSpecificMask(PointerEventTypes.POINTERDOUBLETAP);\r\n if (!checkDoubleClick && AbstractActionManager.HasSpecificTrigger(6)) {\r\n act = _this._initActionManager(act, clickInfo);\r\n if (act) {\r\n checkDoubleClick = act.hasSpecificTrigger(6);\r\n }\r\n }\r\n if (checkDoubleClick) {\r\n // two successive keys pressed are equal, double click delay is not over and double click has not just occurred\r\n if (btn === _this._previousButtonPressed &&\r\n Date.now() - _this._previousStartingPointerTime < InputManager.DoubleClickDelay &&\r\n !_this._doubleClickOccured) {\r\n // pointer has not moved for 2 clicks, it's a double click\r\n if (!clickInfo.hasSwiped &&\r\n !_this._isPointerSwiping()) {\r\n _this._previousStartingPointerTime = 0;\r\n _this._doubleClickOccured = true;\r\n clickInfo.doubleClick = true;\r\n clickInfo.ignore = false;\r\n if (InputManager.ExclusiveDoubleClickMode && _this._previousDelayedSimpleClickTimeout) {\r\n clearTimeout(_this._previousDelayedSimpleClickTimeout);\r\n }\r\n _this._previousDelayedSimpleClickTimeout = _this._delayedSimpleClickTimeout;\r\n cb(clickInfo, _this._currentPickResult);\r\n }\r\n // if the two successive clicks are too far, it's just two simple clicks\r\n else {\r\n _this._doubleClickOccured = false;\r\n _this._previousStartingPointerTime = _this._startingPointerTime;\r\n _this._previousStartingPointerPosition.x = _this._startingPointerPosition.x;\r\n _this._previousStartingPointerPosition.y = _this._startingPointerPosition.y;\r\n _this._previousButtonPressed = btn;\r\n if (InputManager.ExclusiveDoubleClickMode) {\r\n if (_this._previousDelayedSimpleClickTimeout) {\r\n clearTimeout(_this._previousDelayedSimpleClickTimeout);\r\n }\r\n _this._previousDelayedSimpleClickTimeout = _this._delayedSimpleClickTimeout;\r\n cb(clickInfo, _this._previousPickResult);\r\n }\r\n else {\r\n cb(clickInfo, _this._currentPickResult);\r\n }\r\n }\r\n needToIgnoreNext = true;\r\n }\r\n // just the first click of the double has been raised\r\n else {\r\n _this._doubleClickOccured = false;\r\n _this._previousStartingPointerTime = _this._startingPointerTime;\r\n _this._previousStartingPointerPosition.x = _this._startingPointerPosition.x;\r\n _this._previousStartingPointerPosition.y = _this._startingPointerPosition.y;\r\n _this._previousButtonPressed = btn;\r\n }\r\n }\r\n }\r\n }\r\n if (!needToIgnoreNext) {\r\n cb(clickInfo, _this._currentPickResult);\r\n }\r\n };\r\n this._onPointerMove = function (evt) {\r\n _this._updatePointerPosition(evt);\r\n // PreObservable support\r\n if (_this._checkPrePointerObservable(null, evt, evt.type === _this._wheelEventName ? PointerEventTypes.POINTERWHEEL : PointerEventTypes.POINTERMOVE)) {\r\n return;\r\n }\r\n if (!scene.cameraToUseForPointers && !scene.activeCamera) {\r\n return;\r\n }\r\n if (!scene.pointerMovePredicate) {\r\n scene.pointerMovePredicate = function (mesh) { return (mesh.isPickable && mesh.isVisible && mesh.isReady() && mesh.isEnabled() && (mesh.enablePointerMoveEvents || scene.constantlyUpdateMeshUnderPointer || (mesh._getActionManagerForTrigger() != null)) && (!scene.cameraToUseForPointers || (scene.cameraToUseForPointers.layerMask & mesh.layerMask) !== 0)); };\r\n }\r\n // Meshes\r\n var pickResult = scene.pick(_this._unTranslatedPointerX, _this._unTranslatedPointerY, scene.pointerMovePredicate, false, scene.cameraToUseForPointers);\r\n _this._processPointerMove(pickResult, evt);\r\n };\r\n this._onPointerDown = function (evt) {\r\n _this._totalPointersPressed++;\r\n _this._pickedDownMesh = null;\r\n _this._meshPickProceed = false;\r\n _this._updatePointerPosition(evt);\r\n if (scene.preventDefaultOnPointerDown && elementToAttachTo) {\r\n evt.preventDefault();\r\n elementToAttachTo.focus();\r\n }\r\n _this._startingPointerPosition.x = _this._pointerX;\r\n _this._startingPointerPosition.y = _this._pointerY;\r\n _this._startingPointerTime = Date.now();\r\n // PreObservable support\r\n if (_this._checkPrePointerObservable(null, evt, PointerEventTypes.POINTERDOWN)) {\r\n return;\r\n }\r\n if (!scene.cameraToUseForPointers && !scene.activeCamera) {\r\n return;\r\n }\r\n _this._pointerCaptures[evt.pointerId] = true;\r\n if (!scene.pointerDownPredicate) {\r\n scene.pointerDownPredicate = function (mesh) {\r\n return mesh.isPickable && mesh.isVisible && mesh.isReady() && mesh.isEnabled() && (!scene.cameraToUseForPointers || (scene.cameraToUseForPointers.layerMask & mesh.layerMask) !== 0);\r\n };\r\n }\r\n // Meshes\r\n _this._pickedDownMesh = null;\r\n var pickResult = scene.pick(_this._unTranslatedPointerX, _this._unTranslatedPointerY, scene.pointerDownPredicate, false, scene.cameraToUseForPointers);\r\n _this._processPointerDown(pickResult, evt);\r\n };\r\n this._onPointerUp = function (evt) {\r\n if (_this._totalPointersPressed === 0) { // We are attaching the pointer up to windows because of a bug in FF\r\n return; // So we need to test it the pointer down was pressed before.\r\n }\r\n _this._totalPointersPressed--;\r\n _this._pickedUpMesh = null;\r\n _this._meshPickProceed = false;\r\n _this._updatePointerPosition(evt);\r\n if (scene.preventDefaultOnPointerUp && elementToAttachTo) {\r\n evt.preventDefault();\r\n elementToAttachTo.focus();\r\n }\r\n _this._initClickEvent(scene.onPrePointerObservable, scene.onPointerObservable, evt, function (clickInfo, pickResult) {\r\n // PreObservable support\r\n if (scene.onPrePointerObservable.hasObservers()) {\r\n if (!clickInfo.ignore) {\r\n if (!clickInfo.hasSwiped) {\r\n if (clickInfo.singleClick && scene.onPrePointerObservable.hasSpecificMask(PointerEventTypes.POINTERTAP)) {\r\n if (_this._checkPrePointerObservable(null, evt, PointerEventTypes.POINTERTAP)) {\r\n return;\r\n }\r\n }\r\n if (clickInfo.doubleClick && scene.onPrePointerObservable.hasSpecificMask(PointerEventTypes.POINTERDOUBLETAP)) {\r\n if (_this._checkPrePointerObservable(null, evt, PointerEventTypes.POINTERDOUBLETAP)) {\r\n return;\r\n }\r\n }\r\n }\r\n if (_this._checkPrePointerObservable(null, evt, PointerEventTypes.POINTERUP)) {\r\n return;\r\n }\r\n }\r\n }\r\n if (!_this._pointerCaptures[evt.pointerId]) {\r\n return;\r\n }\r\n _this._pointerCaptures[evt.pointerId] = false;\r\n if (!scene.cameraToUseForPointers && !scene.activeCamera) {\r\n return;\r\n }\r\n if (!scene.pointerUpPredicate) {\r\n scene.pointerUpPredicate = function (mesh) {\r\n return mesh.isPickable && mesh.isVisible && mesh.isReady() && mesh.isEnabled() && (!scene.cameraToUseForPointers || (scene.cameraToUseForPointers.layerMask & mesh.layerMask) !== 0);\r\n };\r\n }\r\n // Meshes\r\n if (!_this._meshPickProceed && (AbstractActionManager && AbstractActionManager.HasTriggers || scene.onPointerObservable.hasObservers())) {\r\n _this._initActionManager(null, clickInfo);\r\n }\r\n if (!pickResult) {\r\n pickResult = _this._currentPickResult;\r\n }\r\n _this._processPointerUp(pickResult, evt, clickInfo);\r\n _this._previousPickResult = _this._currentPickResult;\r\n });\r\n };\r\n this._onKeyDown = function (evt) {\r\n var type = KeyboardEventTypes.KEYDOWN;\r\n if (scene.onPreKeyboardObservable.hasObservers()) {\r\n var pi = new KeyboardInfoPre(type, evt);\r\n scene.onPreKeyboardObservable.notifyObservers(pi, type);\r\n if (pi.skipOnPointerObservable) {\r\n return;\r\n }\r\n }\r\n if (scene.onKeyboardObservable.hasObservers()) {\r\n var pi = new KeyboardInfo(type, evt);\r\n scene.onKeyboardObservable.notifyObservers(pi, type);\r\n }\r\n if (scene.actionManager) {\r\n scene.actionManager.processTrigger(14, ActionEvent.CreateNewFromScene(scene, evt));\r\n }\r\n };\r\n this._onKeyUp = function (evt) {\r\n var type = KeyboardEventTypes.KEYUP;\r\n if (scene.onPreKeyboardObservable.hasObservers()) {\r\n var pi = new KeyboardInfoPre(type, evt);\r\n scene.onPreKeyboardObservable.notifyObservers(pi, type);\r\n if (pi.skipOnPointerObservable) {\r\n return;\r\n }\r\n }\r\n if (scene.onKeyboardObservable.hasObservers()) {\r\n var pi = new KeyboardInfo(type, evt);\r\n scene.onKeyboardObservable.notifyObservers(pi, type);\r\n }\r\n if (scene.actionManager) {\r\n scene.actionManager.processTrigger(15, ActionEvent.CreateNewFromScene(scene, evt));\r\n }\r\n };\r\n // Keyboard events\r\n this._onCanvasFocusObserver = engine.onCanvasFocusObservable.add((function () {\r\n var fn = function () {\r\n if (!elementToAttachTo) {\r\n return;\r\n }\r\n elementToAttachTo.addEventListener(\"keydown\", _this._onKeyDown, false);\r\n elementToAttachTo.addEventListener(\"keyup\", _this._onKeyUp, false);\r\n };\r\n if (document.activeElement === elementToAttachTo) {\r\n fn();\r\n }\r\n return fn;\r\n })());\r\n this._onCanvasBlurObserver = engine.onCanvasBlurObservable.add(function () {\r\n if (!elementToAttachTo) {\r\n return;\r\n }\r\n elementToAttachTo.removeEventListener(\"keydown\", _this._onKeyDown);\r\n elementToAttachTo.removeEventListener(\"keyup\", _this._onKeyUp);\r\n });\r\n // Pointer events\r\n var eventPrefix = Tools.GetPointerPrefix();\r\n if (attachMove) {\r\n elementToAttachTo.addEventListener(eventPrefix + \"move\", this._onPointerMove, false);\r\n // Wheel\r\n this._wheelEventName = \"onwheel\" in document.createElement(\"div\") ? \"wheel\" : // Modern browsers support \"wheel\"\r\n document.onmousewheel !== undefined ? \"mousewheel\" : // Webkit and IE support at least \"mousewheel\"\r\n \"DOMMouseScroll\"; // let's assume that remaining browsers are older Firefox\r\n elementToAttachTo.addEventListener(this._wheelEventName, this._onPointerMove, false);\r\n }\r\n if (attachDown) {\r\n elementToAttachTo.addEventListener(eventPrefix + \"down\", this._onPointerDown, false);\r\n }\r\n if (attachUp) {\r\n var hostWindow = scene.getEngine().getHostWindow();\r\n if (hostWindow) {\r\n hostWindow.addEventListener(eventPrefix + \"up\", this._onPointerUp, false);\r\n }\r\n }\r\n };\r\n /**\r\n * Detaches all event handlers\r\n */\r\n InputManager.prototype.detachControl = function () {\r\n var eventPrefix = Tools.GetPointerPrefix();\r\n var canvas = this._scene.getEngine().getInputElement();\r\n var engine = this._scene.getEngine();\r\n if (!canvas) {\r\n return;\r\n }\r\n // Pointer\r\n canvas.removeEventListener(eventPrefix + \"move\", this._onPointerMove);\r\n canvas.removeEventListener(this._wheelEventName, this._onPointerMove);\r\n canvas.removeEventListener(eventPrefix + \"down\", this._onPointerDown);\r\n window.removeEventListener(eventPrefix + \"up\", this._onPointerUp);\r\n // Blur / Focus\r\n if (this._onCanvasBlurObserver) {\r\n engine.onCanvasBlurObservable.remove(this._onCanvasBlurObserver);\r\n }\r\n if (this._onCanvasFocusObserver) {\r\n engine.onCanvasFocusObservable.remove(this._onCanvasFocusObserver);\r\n }\r\n // Keyboard\r\n canvas.removeEventListener(\"keydown\", this._onKeyDown);\r\n canvas.removeEventListener(\"keyup\", this._onKeyUp);\r\n // Cursor\r\n if (!this._scene.doNotHandleCursors) {\r\n canvas.style.cursor = this._scene.defaultCursor;\r\n }\r\n };\r\n /**\r\n * Force the value of meshUnderPointer\r\n * @param mesh defines the mesh to use\r\n */\r\n InputManager.prototype.setPointerOverMesh = function (mesh) {\r\n if (this._pointerOverMesh === mesh) {\r\n return;\r\n }\r\n var actionManager;\r\n if (this._pointerOverMesh) {\r\n actionManager = this._pointerOverMesh._getActionManagerForTrigger(10);\r\n if (actionManager) {\r\n actionManager.processTrigger(10, ActionEvent.CreateNew(this._pointerOverMesh));\r\n }\r\n }\r\n this._pointerOverMesh = mesh;\r\n if (this._pointerOverMesh) {\r\n actionManager = this._pointerOverMesh._getActionManagerForTrigger(9);\r\n if (actionManager) {\r\n actionManager.processTrigger(9, ActionEvent.CreateNew(this._pointerOverMesh));\r\n }\r\n }\r\n };\r\n /**\r\n * Gets the mesh under the pointer\r\n * @returns a Mesh or null if no mesh is under the pointer\r\n */\r\n InputManager.prototype.getPointerOverMesh = function () {\r\n return this._pointerOverMesh;\r\n };\r\n /** The distance in pixel that you have to move to prevent some events */\r\n InputManager.DragMovementThreshold = 10; // in pixels\r\n /** Time in milliseconds to wait to raise long press events if button is still pressed */\r\n InputManager.LongPressDelay = 500; // in milliseconds\r\n /** Time in milliseconds with two consecutive clicks will be considered as a double click */\r\n InputManager.DoubleClickDelay = 300; // in milliseconds\r\n /** If you need to check double click without raising a single click at first click, enable this flag */\r\n InputManager.ExclusiveDoubleClickMode = false;\r\n return InputManager;\r\n}());\r\nexport { InputManager };\r\n//# sourceMappingURL=scene.inputManager.js.map","/**\r\n * Helper class used to generate session unique ID\r\n */\r\nvar UniqueIdGenerator = /** @class */ (function () {\r\n function UniqueIdGenerator() {\r\n }\r\n Object.defineProperty(UniqueIdGenerator, \"UniqueId\", {\r\n /**\r\n * Gets an unique (relatively to the current scene) Id\r\n */\r\n get: function () {\r\n var result = this._UniqueIdCounter;\r\n this._UniqueIdCounter++;\r\n return result;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n // Statics\r\n UniqueIdGenerator._UniqueIdCounter = 0;\r\n return UniqueIdGenerator;\r\n}());\r\nexport { UniqueIdGenerator };\r\n//# sourceMappingURL=uniqueIdGenerator.js.map","import { __assign, __extends } from \"tslib\";\r\nimport { Tools } from \"./Misc/tools\";\r\nimport { PrecisionDate } from \"./Misc/precisionDate\";\r\nimport { Observable } from \"./Misc/observable\";\r\nimport { SmartArrayNoDuplicate, SmartArray } from \"./Misc/smartArray\";\r\nimport { StringDictionary } from \"./Misc/stringDictionary\";\r\nimport { Tags } from \"./Misc/tags\";\r\nimport { Vector3, Matrix } from \"./Maths/math.vector\";\r\nimport { TransformNode } from \"./Meshes/transformNode\";\r\nimport { AbstractMesh } from \"./Meshes/abstractMesh\";\r\nimport { Camera } from \"./Cameras/camera\";\r\nimport { AbstractScene } from \"./abstractScene\";\r\nimport { ImageProcessingConfiguration } from \"./Materials/imageProcessingConfiguration\";\r\nimport { UniformBuffer } from \"./Materials/uniformBuffer\";\r\nimport { Light } from \"./Lights/light\";\r\nimport { PickingInfo } from \"./Collisions/pickingInfo\";\r\nimport { ActionEvent } from \"./Actions/actionEvent\";\r\nimport { PostProcessManager } from \"./PostProcesses/postProcessManager\";\r\nimport { RenderingManager } from \"./Rendering/renderingManager\";\r\nimport { Stage } from \"./sceneComponent\";\r\nimport { DomManagement } from \"./Misc/domManagement\";\r\nimport { Logger } from \"./Misc/logger\";\r\nimport { EngineStore } from \"./Engines/engineStore\";\r\nimport { _DevTools } from './Misc/devTools';\r\nimport { InputManager } from './Inputs/scene.inputManager';\r\nimport { PerfCounter } from './Misc/perfCounter';\r\nimport { Color4, Color3 } from './Maths/math.color';\r\nimport { Frustum } from './Maths/math.frustum';\r\nimport { UniqueIdGenerator } from './Misc/uniqueIdGenerator';\r\nimport { FileTools } from './Misc/fileTools';\r\n/**\r\n * Represents a scene to be rendered by the engine.\r\n * @see http://doc.babylonjs.com/features/scene\r\n */\r\nvar Scene = /** @class */ (function (_super) {\r\n __extends(Scene, _super);\r\n /**\r\n * Creates a new Scene\r\n * @param engine defines the engine to use to render this scene\r\n * @param options defines the scene options\r\n */\r\n function Scene(engine, options) {\r\n var _this = _super.call(this) || this;\r\n // Members\r\n /** @hidden */\r\n _this._inputManager = new InputManager(_this);\r\n /** Define this parameter if you are using multiple cameras and you want to specify which one should be used for pointer position */\r\n _this.cameraToUseForPointers = null;\r\n /** @hidden */\r\n _this._isScene = true;\r\n /** @hidden */\r\n _this._blockEntityCollection = false;\r\n /**\r\n * Gets or sets a boolean that indicates if the scene must clear the render buffer before rendering a frame\r\n */\r\n _this.autoClear = true;\r\n /**\r\n * Gets or sets a boolean that indicates if the scene must clear the depth and stencil buffers before rendering a frame\r\n */\r\n _this.autoClearDepthAndStencil = true;\r\n /**\r\n * Defines the color used to clear the render buffer (Default is (0.2, 0.2, 0.3, 1.0))\r\n */\r\n _this.clearColor = new Color4(0.2, 0.2, 0.3, 1.0);\r\n /**\r\n * Defines the color used to simulate the ambient color (Default is (0, 0, 0))\r\n */\r\n _this.ambientColor = new Color3(0, 0, 0);\r\n /** @hidden */\r\n _this._environmentIntensity = 1;\r\n _this._forceWireframe = false;\r\n _this._skipFrustumClipping = false;\r\n _this._forcePointsCloud = false;\r\n /**\r\n * Gets or sets a boolean indicating if animations are enabled\r\n */\r\n _this.animationsEnabled = true;\r\n _this._animationPropertiesOverride = null;\r\n /**\r\n * Gets or sets a boolean indicating if a constant deltatime has to be used\r\n * This is mostly useful for testing purposes when you do not want the animations to scale with the framerate\r\n */\r\n _this.useConstantAnimationDeltaTime = false;\r\n /**\r\n * Gets or sets a boolean indicating if the scene must keep the meshUnderPointer property updated\r\n * Please note that it requires to run a ray cast through the scene on every frame\r\n */\r\n _this.constantlyUpdateMeshUnderPointer = false;\r\n /**\r\n * Defines the HTML cursor to use when hovering over interactive elements\r\n */\r\n _this.hoverCursor = \"pointer\";\r\n /**\r\n * Defines the HTML default cursor to use (empty by default)\r\n */\r\n _this.defaultCursor = \"\";\r\n /**\r\n * Defines whether cursors are handled by the scene.\r\n */\r\n _this.doNotHandleCursors = false;\r\n /**\r\n * This is used to call preventDefault() on pointer down\r\n * in order to block unwanted artifacts like system double clicks\r\n */\r\n _this.preventDefaultOnPointerDown = true;\r\n /**\r\n * This is used to call preventDefault() on pointer up\r\n * in order to block unwanted artifacts like system double clicks\r\n */\r\n _this.preventDefaultOnPointerUp = true;\r\n // Metadata\r\n /**\r\n * Gets or sets user defined metadata\r\n */\r\n _this.metadata = null;\r\n /**\r\n * For internal use only. Please do not use.\r\n */\r\n _this.reservedDataStore = null;\r\n /**\r\n * Use this array to add regular expressions used to disable offline support for specific urls\r\n */\r\n _this.disableOfflineSupportExceptionRules = new Array();\r\n /**\r\n * An event triggered when the scene is disposed.\r\n */\r\n _this.onDisposeObservable = new Observable();\r\n _this._onDisposeObserver = null;\r\n /**\r\n * An event triggered before rendering the scene (right after animations and physics)\r\n */\r\n _this.onBeforeRenderObservable = new Observable();\r\n _this._onBeforeRenderObserver = null;\r\n /**\r\n * An event triggered after rendering the scene\r\n */\r\n _this.onAfterRenderObservable = new Observable();\r\n /**\r\n * An event triggered after rendering the scene for an active camera (When scene.render is called this will be called after each camera)\r\n */\r\n _this.onAfterRenderCameraObservable = new Observable();\r\n _this._onAfterRenderObserver = null;\r\n /**\r\n * An event triggered before animating the scene\r\n */\r\n _this.onBeforeAnimationsObservable = new Observable();\r\n /**\r\n * An event triggered after animations processing\r\n */\r\n _this.onAfterAnimationsObservable = new Observable();\r\n /**\r\n * An event triggered before draw calls are ready to be sent\r\n */\r\n _this.onBeforeDrawPhaseObservable = new Observable();\r\n /**\r\n * An event triggered after draw calls have been sent\r\n */\r\n _this.onAfterDrawPhaseObservable = new Observable();\r\n /**\r\n * An event triggered when the scene is ready\r\n */\r\n _this.onReadyObservable = new Observable();\r\n /**\r\n * An event triggered before rendering a camera\r\n */\r\n _this.onBeforeCameraRenderObservable = new Observable();\r\n _this._onBeforeCameraRenderObserver = null;\r\n /**\r\n * An event triggered after rendering a camera\r\n */\r\n _this.onAfterCameraRenderObservable = new Observable();\r\n _this._onAfterCameraRenderObserver = null;\r\n /**\r\n * An event triggered when active meshes evaluation is about to start\r\n */\r\n _this.onBeforeActiveMeshesEvaluationObservable = new Observable();\r\n /**\r\n * An event triggered when active meshes evaluation is done\r\n */\r\n _this.onAfterActiveMeshesEvaluationObservable = new Observable();\r\n /**\r\n * An event triggered when particles rendering is about to start\r\n * Note: This event can be trigger more than once per frame (because particles can be rendered by render target textures as well)\r\n */\r\n _this.onBeforeParticlesRenderingObservable = new Observable();\r\n /**\r\n * An event triggered when particles rendering is done\r\n * Note: This event can be trigger more than once per frame (because particles can be rendered by render target textures as well)\r\n */\r\n _this.onAfterParticlesRenderingObservable = new Observable();\r\n /**\r\n * An event triggered when SceneLoader.Append or SceneLoader.Load or SceneLoader.ImportMesh were successfully executed\r\n */\r\n _this.onDataLoadedObservable = new Observable();\r\n /**\r\n * An event triggered when a camera is created\r\n */\r\n _this.onNewCameraAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a camera is removed\r\n */\r\n _this.onCameraRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when a light is created\r\n */\r\n _this.onNewLightAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a light is removed\r\n */\r\n _this.onLightRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when a geometry is created\r\n */\r\n _this.onNewGeometryAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a geometry is removed\r\n */\r\n _this.onGeometryRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when a transform node is created\r\n */\r\n _this.onNewTransformNodeAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a transform node is removed\r\n */\r\n _this.onTransformNodeRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when a mesh is created\r\n */\r\n _this.onNewMeshAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a mesh is removed\r\n */\r\n _this.onMeshRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when a skeleton is created\r\n */\r\n _this.onNewSkeletonAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a skeleton is removed\r\n */\r\n _this.onSkeletonRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when a material is created\r\n */\r\n _this.onNewMaterialAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a material is removed\r\n */\r\n _this.onMaterialRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when a texture is created\r\n */\r\n _this.onNewTextureAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a texture is removed\r\n */\r\n _this.onTextureRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when render targets are about to be rendered\r\n * Can happen multiple times per frame.\r\n */\r\n _this.onBeforeRenderTargetsRenderObservable = new Observable();\r\n /**\r\n * An event triggered when render targets were rendered.\r\n * Can happen multiple times per frame.\r\n */\r\n _this.onAfterRenderTargetsRenderObservable = new Observable();\r\n /**\r\n * An event triggered before calculating deterministic simulation step\r\n */\r\n _this.onBeforeStepObservable = new Observable();\r\n /**\r\n * An event triggered after calculating deterministic simulation step\r\n */\r\n _this.onAfterStepObservable = new Observable();\r\n /**\r\n * An event triggered when the activeCamera property is updated\r\n */\r\n _this.onActiveCameraChanged = new Observable();\r\n /**\r\n * This Observable will be triggered before rendering each renderingGroup of each rendered camera.\r\n * The RenderinGroupInfo class contains all the information about the context in which the observable is called\r\n * If you wish to register an Observer only for a given set of renderingGroup, use the mask with a combination of the renderingGroup index elevated to the power of two (1 for renderingGroup 0, 2 for renderingrOup1, 4 for 2 and 8 for 3)\r\n */\r\n _this.onBeforeRenderingGroupObservable = new Observable();\r\n /**\r\n * This Observable will be triggered after rendering each renderingGroup of each rendered camera.\r\n * The RenderinGroupInfo class contains all the information about the context in which the observable is called\r\n * If you wish to register an Observer only for a given set of renderingGroup, use the mask with a combination of the renderingGroup index elevated to the power of two (1 for renderingGroup 0, 2 for renderingrOup1, 4 for 2 and 8 for 3)\r\n */\r\n _this.onAfterRenderingGroupObservable = new Observable();\r\n /**\r\n * This Observable will when a mesh has been imported into the scene.\r\n */\r\n _this.onMeshImportedObservable = new Observable();\r\n /**\r\n * This Observable will when an animation file has been imported into the scene.\r\n */\r\n _this.onAnimationFileImportedObservable = new Observable();\r\n // Animations\r\n /** @hidden */\r\n _this._registeredForLateAnimationBindings = new SmartArrayNoDuplicate(256);\r\n /**\r\n * This observable event is triggered when any ponter event is triggered. It is registered during Scene.attachControl() and it is called BEFORE the 3D engine process anything (mesh/sprite picking for instance).\r\n * You have the possibility to skip the process and the call to onPointerObservable by setting PointerInfoPre.skipOnPointerObservable to true\r\n */\r\n _this.onPrePointerObservable = new Observable();\r\n /**\r\n * Observable event triggered each time an input event is received from the rendering canvas\r\n */\r\n _this.onPointerObservable = new Observable();\r\n // Keyboard\r\n /**\r\n * This observable event is triggered when any keyboard event si raised and registered during Scene.attachControl()\r\n * You have the possibility to skip the process and the call to onKeyboardObservable by setting KeyboardInfoPre.skipOnPointerObservable to true\r\n */\r\n _this.onPreKeyboardObservable = new Observable();\r\n /**\r\n * Observable event triggered each time an keyboard event is received from the hosting window\r\n */\r\n _this.onKeyboardObservable = new Observable();\r\n // Coordinates system\r\n _this._useRightHandedSystem = false;\r\n // Deterministic lockstep\r\n _this._timeAccumulator = 0;\r\n _this._currentStepId = 0;\r\n _this._currentInternalStep = 0;\r\n // Fog\r\n _this._fogEnabled = true;\r\n _this._fogMode = Scene.FOGMODE_NONE;\r\n /**\r\n * Gets or sets the fog color to use\r\n * @see http://doc.babylonjs.com/babylon101/environment#fog\r\n * (Default is Color3(0.2, 0.2, 0.3))\r\n */\r\n _this.fogColor = new Color3(0.2, 0.2, 0.3);\r\n /**\r\n * Gets or sets the fog density to use\r\n * @see http://doc.babylonjs.com/babylon101/environment#fog\r\n * (Default is 0.1)\r\n */\r\n _this.fogDensity = 0.1;\r\n /**\r\n * Gets or sets the fog start distance to use\r\n * @see http://doc.babylonjs.com/babylon101/environment#fog\r\n * (Default is 0)\r\n */\r\n _this.fogStart = 0;\r\n /**\r\n * Gets or sets the fog end distance to use\r\n * @see http://doc.babylonjs.com/babylon101/environment#fog\r\n * (Default is 1000)\r\n */\r\n _this.fogEnd = 1000.0;\r\n // Lights\r\n _this._shadowsEnabled = true;\r\n _this._lightsEnabled = true;\r\n /** All of the active cameras added to this scene. */\r\n _this.activeCameras = new Array();\r\n // Textures\r\n _this._texturesEnabled = true;\r\n // Particles\r\n /**\r\n * Gets or sets a boolean indicating if particles are enabled on this scene\r\n */\r\n _this.particlesEnabled = true;\r\n // Sprites\r\n /**\r\n * Gets or sets a boolean indicating if sprites are enabled on this scene\r\n */\r\n _this.spritesEnabled = true;\r\n // Skeletons\r\n _this._skeletonsEnabled = true;\r\n // Lens flares\r\n /**\r\n * Gets or sets a boolean indicating if lens flares are enabled on this scene\r\n */\r\n _this.lensFlaresEnabled = true;\r\n // Collisions\r\n /**\r\n * Gets or sets a boolean indicating if collisions are enabled on this scene\r\n * @see http://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity\r\n */\r\n _this.collisionsEnabled = true;\r\n /**\r\n * Defines the gravity applied to this scene (used only for collisions)\r\n * @see http://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity\r\n */\r\n _this.gravity = new Vector3(0, -9.807, 0);\r\n // Postprocesses\r\n /**\r\n * Gets or sets a boolean indicating if postprocesses are enabled on this scene\r\n */\r\n _this.postProcessesEnabled = true;\r\n /**\r\n * The list of postprocesses added to the scene\r\n */\r\n _this.postProcesses = new Array();\r\n // Customs render targets\r\n /**\r\n * Gets or sets a boolean indicating if render targets are enabled on this scene\r\n */\r\n _this.renderTargetsEnabled = true;\r\n /**\r\n * Gets or sets a boolean indicating if next render targets must be dumped as image for debugging purposes\r\n * We recommend not using it and instead rely on Spector.js: http://spector.babylonjs.com\r\n */\r\n _this.dumpNextRenderTargets = false;\r\n /**\r\n * The list of user defined render targets added to the scene\r\n */\r\n _this.customRenderTargets = new Array();\r\n /**\r\n * Gets the list of meshes imported to the scene through SceneLoader\r\n */\r\n _this.importedMeshesFiles = new Array();\r\n // Probes\r\n /**\r\n * Gets or sets a boolean indicating if probes are enabled on this scene\r\n */\r\n _this.probesEnabled = true;\r\n _this._meshesForIntersections = new SmartArrayNoDuplicate(256);\r\n // Procedural textures\r\n /**\r\n * Gets or sets a boolean indicating if procedural textures are enabled on this scene\r\n */\r\n _this.proceduralTexturesEnabled = true;\r\n // Performance counters\r\n _this._totalVertices = new PerfCounter();\r\n /** @hidden */\r\n _this._activeIndices = new PerfCounter();\r\n /** @hidden */\r\n _this._activeParticles = new PerfCounter();\r\n /** @hidden */\r\n _this._activeBones = new PerfCounter();\r\n /** @hidden */\r\n _this._animationTime = 0;\r\n /**\r\n * Gets or sets a general scale for animation speed\r\n * @see https://www.babylonjs-playground.com/#IBU2W7#3\r\n */\r\n _this.animationTimeScale = 1;\r\n _this._renderId = 0;\r\n _this._frameId = 0;\r\n _this._executeWhenReadyTimeoutId = -1;\r\n _this._intermediateRendering = false;\r\n _this._viewUpdateFlag = -1;\r\n _this._projectionUpdateFlag = -1;\r\n /** @hidden */\r\n _this._toBeDisposed = new Array(256);\r\n _this._activeRequests = new Array();\r\n /** @hidden */\r\n _this._pendingData = new Array();\r\n _this._isDisposed = false;\r\n /**\r\n * Gets or sets a boolean indicating that all submeshes of active meshes must be rendered\r\n * Use this boolean to avoid computing frustum clipping on submeshes (This could help when you are CPU bound)\r\n */\r\n _this.dispatchAllSubMeshesOfActiveMeshes = false;\r\n _this._activeMeshes = new SmartArray(256);\r\n _this._processedMaterials = new SmartArray(256);\r\n _this._renderTargets = new SmartArrayNoDuplicate(256);\r\n /** @hidden */\r\n _this._activeParticleSystems = new SmartArray(256);\r\n _this._activeSkeletons = new SmartArrayNoDuplicate(32);\r\n _this._softwareSkinnedMeshes = new SmartArrayNoDuplicate(32);\r\n /** @hidden */\r\n _this._activeAnimatables = new Array();\r\n _this._transformMatrix = Matrix.Zero();\r\n /**\r\n * Gets or sets a boolean indicating if lights must be sorted by priority (off by default)\r\n * This is useful if there are more lights that the maximum simulteanous authorized\r\n */\r\n _this.requireLightSorting = false;\r\n /**\r\n * @hidden\r\n * Backing store of defined scene components.\r\n */\r\n _this._components = [];\r\n /**\r\n * @hidden\r\n * Backing store of defined scene components.\r\n */\r\n _this._serializableComponents = [];\r\n /**\r\n * List of components to register on the next registration step.\r\n */\r\n _this._transientComponents = [];\r\n /**\r\n * @hidden\r\n * Defines the actions happening before camera updates.\r\n */\r\n _this._beforeCameraUpdateStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening before clear the canvas.\r\n */\r\n _this._beforeClearStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions when collecting render targets for the frame.\r\n */\r\n _this._gatherRenderTargetsStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening for one camera in the frame.\r\n */\r\n _this._gatherActiveCameraRenderTargetsStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening during the per mesh ready checks.\r\n */\r\n _this._isReadyForMeshStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening before evaluate active mesh checks.\r\n */\r\n _this._beforeEvaluateActiveMeshStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening during the evaluate sub mesh checks.\r\n */\r\n _this._evaluateSubMeshStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening during the active mesh stage.\r\n */\r\n _this._activeMeshStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening during the per camera render target step.\r\n */\r\n _this._cameraDrawRenderTargetStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just before the active camera is drawing.\r\n */\r\n _this._beforeCameraDrawStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just before a render target is drawing.\r\n */\r\n _this._beforeRenderTargetDrawStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just before a rendering group is drawing.\r\n */\r\n _this._beforeRenderingGroupDrawStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just before a mesh is drawing.\r\n */\r\n _this._beforeRenderingMeshStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just after a mesh has been drawn.\r\n */\r\n _this._afterRenderingMeshStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just after a rendering group has been drawn.\r\n */\r\n _this._afterRenderingGroupDrawStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just after the active camera has been drawn.\r\n */\r\n _this._afterCameraDrawStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just after a render target has been drawn.\r\n */\r\n _this._afterRenderTargetDrawStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just after rendering all cameras and computing intersections.\r\n */\r\n _this._afterRenderStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening when a pointer move event happens.\r\n */\r\n _this._pointerMoveStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening when a pointer down event happens.\r\n */\r\n _this._pointerDownStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening when a pointer up event happens.\r\n */\r\n _this._pointerUpStage = Stage.Create();\r\n /**\r\n * an optional map from Geometry Id to Geometry index in the 'geometries' array\r\n */\r\n _this.geometriesByUniqueId = null;\r\n _this._defaultMeshCandidates = {\r\n data: [],\r\n length: 0\r\n };\r\n _this._defaultSubMeshCandidates = {\r\n data: [],\r\n length: 0\r\n };\r\n _this._preventFreeActiveMeshesAndRenderingGroups = false;\r\n _this._activeMeshesFrozen = false;\r\n _this._skipEvaluateActiveMeshesCompletely = false;\r\n /** @hidden */\r\n _this._allowPostProcessClearColor = true;\r\n /**\r\n * User updatable function that will return a deterministic frame time when engine is in deterministic lock step mode\r\n */\r\n _this.getDeterministicFrameTime = function () {\r\n return _this._engine.getTimeStep();\r\n };\r\n _this._blockMaterialDirtyMechanism = false;\r\n var fullOptions = __assign({ useGeometryUniqueIdsMap: true, useMaterialMeshMap: true, useClonedMeshMap: true, virtual: false }, options);\r\n _this._engine = engine || EngineStore.LastCreatedEngine;\r\n if (!fullOptions.virtual) {\r\n EngineStore._LastCreatedScene = _this;\r\n _this._engine.scenes.push(_this);\r\n }\r\n _this._uid = null;\r\n _this._renderingManager = new RenderingManager(_this);\r\n if (PostProcessManager) {\r\n _this.postProcessManager = new PostProcessManager(_this);\r\n }\r\n if (DomManagement.IsWindowObjectExist()) {\r\n _this.attachControl();\r\n }\r\n // Uniform Buffer\r\n _this._createUbo();\r\n // Default Image processing definition\r\n if (ImageProcessingConfiguration) {\r\n _this._imageProcessingConfiguration = new ImageProcessingConfiguration();\r\n }\r\n _this.setDefaultCandidateProviders();\r\n if (fullOptions.useGeometryUniqueIdsMap) {\r\n _this.geometriesByUniqueId = {};\r\n }\r\n _this.useMaterialMeshMap = fullOptions.useMaterialMeshMap;\r\n _this.useClonedMeshMap = fullOptions.useClonedMeshMap;\r\n if (!options || !options.virtual) {\r\n _this._engine.onNewSceneAddedObservable.notifyObservers(_this);\r\n }\r\n return _this;\r\n }\r\n /**\r\n * Factory used to create the default material.\r\n * @param name The name of the material to create\r\n * @param scene The scene to create the material for\r\n * @returns The default material\r\n */\r\n Scene.DefaultMaterialFactory = function (scene) {\r\n throw _DevTools.WarnImport(\"StandardMaterial\");\r\n };\r\n /**\r\n * Factory used to create the a collision coordinator.\r\n * @returns The collision coordinator\r\n */\r\n Scene.CollisionCoordinatorFactory = function () {\r\n throw _DevTools.WarnImport(\"DefaultCollisionCoordinator\");\r\n };\r\n Object.defineProperty(Scene.prototype, \"environmentTexture\", {\r\n /**\r\n * Texture used in all pbr material as the reflection texture.\r\n * As in the majority of the scene they are the same (exception for multi room and so on),\r\n * this is easier to reference from here than from all the materials.\r\n */\r\n get: function () {\r\n return this._environmentTexture;\r\n },\r\n /**\r\n * Texture used in all pbr material as the reflection texture.\r\n * As in the majority of the scene they are the same (exception for multi room and so on),\r\n * this is easier to set here than in all the materials.\r\n */\r\n set: function (value) {\r\n if (this._environmentTexture === value) {\r\n return;\r\n }\r\n this._environmentTexture = value;\r\n this.markAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"environmentIntensity\", {\r\n /**\r\n * Intensity of the environment in all pbr material.\r\n * This dims or reinforces the IBL lighting overall (reflection and diffuse).\r\n * As in the majority of the scene they are the same (exception for multi room and so on),\r\n * this is easier to reference from here than from all the materials.\r\n */\r\n get: function () {\r\n return this._environmentIntensity;\r\n },\r\n /**\r\n * Intensity of the environment in all pbr material.\r\n * This dims or reinforces the IBL lighting overall (reflection and diffuse).\r\n * As in the majority of the scene they are the same (exception for multi room and so on),\r\n * this is easier to set here than in all the materials.\r\n */\r\n set: function (value) {\r\n if (this._environmentIntensity === value) {\r\n return;\r\n }\r\n this._environmentIntensity = value;\r\n this.markAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"imageProcessingConfiguration\", {\r\n /**\r\n * Default image processing configuration used either in the rendering\r\n * Forward main pass or through the imageProcessingPostProcess if present.\r\n * As in the majority of the scene they are the same (exception for multi camera),\r\n * this is easier to reference from here than from all the materials and post process.\r\n *\r\n * No setter as we it is a shared configuration, you can set the values instead.\r\n */\r\n get: function () {\r\n return this._imageProcessingConfiguration;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"forceWireframe\", {\r\n get: function () {\r\n return this._forceWireframe;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if all rendering must be done in wireframe\r\n */\r\n set: function (value) {\r\n if (this._forceWireframe === value) {\r\n return;\r\n }\r\n this._forceWireframe = value;\r\n this.markAllMaterialsAsDirty(16);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"skipFrustumClipping\", {\r\n get: function () {\r\n return this._skipFrustumClipping;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if we should skip the frustum clipping part of the active meshes selection\r\n */\r\n set: function (value) {\r\n if (this._skipFrustumClipping === value) {\r\n return;\r\n }\r\n this._skipFrustumClipping = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"forcePointsCloud\", {\r\n get: function () {\r\n return this._forcePointsCloud;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if all rendering must be done in point cloud\r\n */\r\n set: function (value) {\r\n if (this._forcePointsCloud === value) {\r\n return;\r\n }\r\n this._forcePointsCloud = value;\r\n this.markAllMaterialsAsDirty(16);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"animationPropertiesOverride\", {\r\n /**\r\n * Gets or sets the animation properties override\r\n */\r\n get: function () {\r\n return this._animationPropertiesOverride;\r\n },\r\n set: function (value) {\r\n this._animationPropertiesOverride = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"onDispose\", {\r\n /** Sets a function to be executed when this scene is disposed. */\r\n set: function (callback) {\r\n if (this._onDisposeObserver) {\r\n this.onDisposeObservable.remove(this._onDisposeObserver);\r\n }\r\n this._onDisposeObserver = this.onDisposeObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"beforeRender\", {\r\n /** Sets a function to be executed before rendering this scene */\r\n set: function (callback) {\r\n if (this._onBeforeRenderObserver) {\r\n this.onBeforeRenderObservable.remove(this._onBeforeRenderObserver);\r\n }\r\n if (callback) {\r\n this._onBeforeRenderObserver = this.onBeforeRenderObservable.add(callback);\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"afterRender\", {\r\n /** Sets a function to be executed after rendering this scene */\r\n set: function (callback) {\r\n if (this._onAfterRenderObserver) {\r\n this.onAfterRenderObservable.remove(this._onAfterRenderObserver);\r\n }\r\n if (callback) {\r\n this._onAfterRenderObserver = this.onAfterRenderObservable.add(callback);\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"beforeCameraRender\", {\r\n /** Sets a function to be executed before rendering a camera*/\r\n set: function (callback) {\r\n if (this._onBeforeCameraRenderObserver) {\r\n this.onBeforeCameraRenderObservable.remove(this._onBeforeCameraRenderObserver);\r\n }\r\n this._onBeforeCameraRenderObserver = this.onBeforeCameraRenderObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"afterCameraRender\", {\r\n /** Sets a function to be executed after rendering a camera*/\r\n set: function (callback) {\r\n if (this._onAfterCameraRenderObserver) {\r\n this.onAfterCameraRenderObservable.remove(this._onAfterCameraRenderObserver);\r\n }\r\n this._onAfterCameraRenderObserver = this.onAfterCameraRenderObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"unTranslatedPointer\", {\r\n /**\r\n * Gets the pointer coordinates without any translation (ie. straight out of the pointer event)\r\n */\r\n get: function () {\r\n return this._inputManager.unTranslatedPointer;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene, \"DragMovementThreshold\", {\r\n /**\r\n * Gets or sets the distance in pixel that you have to move to prevent some events. Default is 10 pixels\r\n */\r\n get: function () {\r\n return InputManager.DragMovementThreshold;\r\n },\r\n set: function (value) {\r\n InputManager.DragMovementThreshold = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene, \"LongPressDelay\", {\r\n /**\r\n * Time in milliseconds to wait to raise long press events if button is still pressed. Default is 500 ms\r\n */\r\n get: function () {\r\n return InputManager.LongPressDelay;\r\n },\r\n set: function (value) {\r\n InputManager.LongPressDelay = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene, \"DoubleClickDelay\", {\r\n /**\r\n * Time in milliseconds to wait to raise long press events if button is still pressed. Default is 300 ms\r\n */\r\n get: function () {\r\n return InputManager.DoubleClickDelay;\r\n },\r\n set: function (value) {\r\n InputManager.DoubleClickDelay = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene, \"ExclusiveDoubleClickMode\", {\r\n /** If you need to check double click without raising a single click at first click, enable this flag */\r\n get: function () {\r\n return InputManager.ExclusiveDoubleClickMode;\r\n },\r\n set: function (value) {\r\n InputManager.ExclusiveDoubleClickMode = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"useRightHandedSystem\", {\r\n get: function () {\r\n return this._useRightHandedSystem;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if the scene must use right-handed coordinates system\r\n */\r\n set: function (value) {\r\n if (this._useRightHandedSystem === value) {\r\n return;\r\n }\r\n this._useRightHandedSystem = value;\r\n this.markAllMaterialsAsDirty(16);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Sets the step Id used by deterministic lock step\r\n * @see http://doc.babylonjs.com/babylon101/animations#deterministic-lockstep\r\n * @param newStepId defines the step Id\r\n */\r\n Scene.prototype.setStepId = function (newStepId) {\r\n this._currentStepId = newStepId;\r\n };\r\n /**\r\n * Gets the step Id used by deterministic lock step\r\n * @see http://doc.babylonjs.com/babylon101/animations#deterministic-lockstep\r\n * @returns the step Id\r\n */\r\n Scene.prototype.getStepId = function () {\r\n return this._currentStepId;\r\n };\r\n /**\r\n * Gets the internal step used by deterministic lock step\r\n * @see http://doc.babylonjs.com/babylon101/animations#deterministic-lockstep\r\n * @returns the internal step\r\n */\r\n Scene.prototype.getInternalStep = function () {\r\n return this._currentInternalStep;\r\n };\r\n Object.defineProperty(Scene.prototype, \"fogEnabled\", {\r\n get: function () {\r\n return this._fogEnabled;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if fog is enabled on this scene\r\n * @see http://doc.babylonjs.com/babylon101/environment#fog\r\n * (Default is true)\r\n */\r\n set: function (value) {\r\n if (this._fogEnabled === value) {\r\n return;\r\n }\r\n this._fogEnabled = value;\r\n this.markAllMaterialsAsDirty(16);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"fogMode\", {\r\n get: function () {\r\n return this._fogMode;\r\n },\r\n /**\r\n * Gets or sets the fog mode to use\r\n * @see http://doc.babylonjs.com/babylon101/environment#fog\r\n * | mode | value |\r\n * | --- | --- |\r\n * | FOGMODE_NONE | 0 |\r\n * | FOGMODE_EXP | 1 |\r\n * | FOGMODE_EXP2 | 2 |\r\n * | FOGMODE_LINEAR | 3 |\r\n */\r\n set: function (value) {\r\n if (this._fogMode === value) {\r\n return;\r\n }\r\n this._fogMode = value;\r\n this.markAllMaterialsAsDirty(16);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"shadowsEnabled\", {\r\n get: function () {\r\n return this._shadowsEnabled;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if shadows are enabled on this scene\r\n */\r\n set: function (value) {\r\n if (this._shadowsEnabled === value) {\r\n return;\r\n }\r\n this._shadowsEnabled = value;\r\n this.markAllMaterialsAsDirty(2);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"lightsEnabled\", {\r\n get: function () {\r\n return this._lightsEnabled;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if lights are enabled on this scene\r\n */\r\n set: function (value) {\r\n if (this._lightsEnabled === value) {\r\n return;\r\n }\r\n this._lightsEnabled = value;\r\n this.markAllMaterialsAsDirty(2);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"activeCamera\", {\r\n /** Gets or sets the current active camera */\r\n get: function () {\r\n return this._activeCamera;\r\n },\r\n set: function (value) {\r\n if (value === this._activeCamera) {\r\n return;\r\n }\r\n this._activeCamera = value;\r\n this.onActiveCameraChanged.notifyObservers(this);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"defaultMaterial\", {\r\n /** The default material used on meshes when no material is affected */\r\n get: function () {\r\n if (!this._defaultMaterial) {\r\n this._defaultMaterial = Scene.DefaultMaterialFactory(this);\r\n }\r\n return this._defaultMaterial;\r\n },\r\n /** The default material used on meshes when no material is affected */\r\n set: function (value) {\r\n this._defaultMaterial = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"texturesEnabled\", {\r\n get: function () {\r\n return this._texturesEnabled;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if textures are enabled on this scene\r\n */\r\n set: function (value) {\r\n if (this._texturesEnabled === value) {\r\n return;\r\n }\r\n this._texturesEnabled = value;\r\n this.markAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"skeletonsEnabled\", {\r\n get: function () {\r\n return this._skeletonsEnabled;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if skeletons are enabled on this scene\r\n */\r\n set: function (value) {\r\n if (this._skeletonsEnabled === value) {\r\n return;\r\n }\r\n this._skeletonsEnabled = value;\r\n this.markAllMaterialsAsDirty(8);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"collisionCoordinator\", {\r\n /** @hidden */\r\n get: function () {\r\n if (!this._collisionCoordinator) {\r\n this._collisionCoordinator = Scene.CollisionCoordinatorFactory();\r\n this._collisionCoordinator.init(this);\r\n }\r\n return this._collisionCoordinator;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"frustumPlanes\", {\r\n /**\r\n * Gets the list of frustum planes (built from the active camera)\r\n */\r\n get: function () {\r\n return this._frustumPlanes;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Registers the transient components if needed.\r\n */\r\n Scene.prototype._registerTransientComponents = function () {\r\n // Register components that have been associated lately to the scene.\r\n if (this._transientComponents.length > 0) {\r\n for (var _i = 0, _a = this._transientComponents; _i < _a.length; _i++) {\r\n var component = _a[_i];\r\n component.register();\r\n }\r\n this._transientComponents = [];\r\n }\r\n };\r\n /**\r\n * @hidden\r\n * Add a component to the scene.\r\n * Note that the ccomponent could be registered on th next frame if this is called after\r\n * the register component stage.\r\n * @param component Defines the component to add to the scene\r\n */\r\n Scene.prototype._addComponent = function (component) {\r\n this._components.push(component);\r\n this._transientComponents.push(component);\r\n var serializableComponent = component;\r\n if (serializableComponent.addFromContainer && serializableComponent.serialize) {\r\n this._serializableComponents.push(serializableComponent);\r\n }\r\n };\r\n /**\r\n * @hidden\r\n * Gets a component from the scene.\r\n * @param name defines the name of the component to retrieve\r\n * @returns the component or null if not present\r\n */\r\n Scene.prototype._getComponent = function (name) {\r\n for (var _i = 0, _a = this._components; _i < _a.length; _i++) {\r\n var component = _a[_i];\r\n if (component.name === name) {\r\n return component;\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a string idenfifying the name of the class\r\n * @returns \"Scene\" string\r\n */\r\n Scene.prototype.getClassName = function () {\r\n return \"Scene\";\r\n };\r\n /**\r\n * @hidden\r\n */\r\n Scene.prototype._getDefaultMeshCandidates = function () {\r\n this._defaultMeshCandidates.data = this.meshes;\r\n this._defaultMeshCandidates.length = this.meshes.length;\r\n return this._defaultMeshCandidates;\r\n };\r\n /**\r\n * @hidden\r\n */\r\n Scene.prototype._getDefaultSubMeshCandidates = function (mesh) {\r\n this._defaultSubMeshCandidates.data = mesh.subMeshes;\r\n this._defaultSubMeshCandidates.length = mesh.subMeshes.length;\r\n return this._defaultSubMeshCandidates;\r\n };\r\n /**\r\n * Sets the default candidate providers for the scene.\r\n * This sets the getActiveMeshCandidates, getActiveSubMeshCandidates, getIntersectingSubMeshCandidates\r\n * and getCollidingSubMeshCandidates to their default function\r\n */\r\n Scene.prototype.setDefaultCandidateProviders = function () {\r\n this.getActiveMeshCandidates = this._getDefaultMeshCandidates.bind(this);\r\n this.getActiveSubMeshCandidates = this._getDefaultSubMeshCandidates.bind(this);\r\n this.getIntersectingSubMeshCandidates = this._getDefaultSubMeshCandidates.bind(this);\r\n this.getCollidingSubMeshCandidates = this._getDefaultSubMeshCandidates.bind(this);\r\n };\r\n Object.defineProperty(Scene.prototype, \"meshUnderPointer\", {\r\n /**\r\n * Gets the mesh that is currently under the pointer\r\n */\r\n get: function () {\r\n return this._inputManager.meshUnderPointer;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"pointerX\", {\r\n /**\r\n * Gets or sets the current on-screen X position of the pointer\r\n */\r\n get: function () {\r\n return this._inputManager.pointerX;\r\n },\r\n set: function (value) {\r\n this._inputManager.pointerX = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"pointerY\", {\r\n /**\r\n * Gets or sets the current on-screen Y position of the pointer\r\n */\r\n get: function () {\r\n return this._inputManager.pointerY;\r\n },\r\n set: function (value) {\r\n this._inputManager.pointerY = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the cached material (ie. the latest rendered one)\r\n * @returns the cached material\r\n */\r\n Scene.prototype.getCachedMaterial = function () {\r\n return this._cachedMaterial;\r\n };\r\n /**\r\n * Gets the cached effect (ie. the latest rendered one)\r\n * @returns the cached effect\r\n */\r\n Scene.prototype.getCachedEffect = function () {\r\n return this._cachedEffect;\r\n };\r\n /**\r\n * Gets the cached visibility state (ie. the latest rendered one)\r\n * @returns the cached visibility state\r\n */\r\n Scene.prototype.getCachedVisibility = function () {\r\n return this._cachedVisibility;\r\n };\r\n /**\r\n * Gets a boolean indicating if the current material / effect / visibility must be bind again\r\n * @param material defines the current material\r\n * @param effect defines the current effect\r\n * @param visibility defines the current visibility state\r\n * @returns true if one parameter is not cached\r\n */\r\n Scene.prototype.isCachedMaterialInvalid = function (material, effect, visibility) {\r\n if (visibility === void 0) { visibility = 1; }\r\n return this._cachedEffect !== effect || this._cachedMaterial !== material || this._cachedVisibility !== visibility;\r\n };\r\n /**\r\n * Gets the engine associated with the scene\r\n * @returns an Engine\r\n */\r\n Scene.prototype.getEngine = function () {\r\n return this._engine;\r\n };\r\n /**\r\n * Gets the total number of vertices rendered per frame\r\n * @returns the total number of vertices rendered per frame\r\n */\r\n Scene.prototype.getTotalVertices = function () {\r\n return this._totalVertices.current;\r\n };\r\n Object.defineProperty(Scene.prototype, \"totalVerticesPerfCounter\", {\r\n /**\r\n * Gets the performance counter for total vertices\r\n * @see http://doc.babylonjs.com/how_to/optimizing_your_scene#instrumentation\r\n */\r\n get: function () {\r\n return this._totalVertices;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the total number of active indices rendered per frame (You can deduce the number of rendered triangles by dividing this number by 3)\r\n * @returns the total number of active indices rendered per frame\r\n */\r\n Scene.prototype.getActiveIndices = function () {\r\n return this._activeIndices.current;\r\n };\r\n Object.defineProperty(Scene.prototype, \"totalActiveIndicesPerfCounter\", {\r\n /**\r\n * Gets the performance counter for active indices\r\n * @see http://doc.babylonjs.com/how_to/optimizing_your_scene#instrumentation\r\n */\r\n get: function () {\r\n return this._activeIndices;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the total number of active particles rendered per frame\r\n * @returns the total number of active particles rendered per frame\r\n */\r\n Scene.prototype.getActiveParticles = function () {\r\n return this._activeParticles.current;\r\n };\r\n Object.defineProperty(Scene.prototype, \"activeParticlesPerfCounter\", {\r\n /**\r\n * Gets the performance counter for active particles\r\n * @see http://doc.babylonjs.com/how_to/optimizing_your_scene#instrumentation\r\n */\r\n get: function () {\r\n return this._activeParticles;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the total number of active bones rendered per frame\r\n * @returns the total number of active bones rendered per frame\r\n */\r\n Scene.prototype.getActiveBones = function () {\r\n return this._activeBones.current;\r\n };\r\n Object.defineProperty(Scene.prototype, \"activeBonesPerfCounter\", {\r\n /**\r\n * Gets the performance counter for active bones\r\n * @see http://doc.babylonjs.com/how_to/optimizing_your_scene#instrumentation\r\n */\r\n get: function () {\r\n return this._activeBones;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the array of active meshes\r\n * @returns an array of AbstractMesh\r\n */\r\n Scene.prototype.getActiveMeshes = function () {\r\n return this._activeMeshes;\r\n };\r\n /**\r\n * Gets the animation ratio (which is 1.0 is the scene renders at 60fps and 2 if the scene renders at 30fps, etc.)\r\n * @returns a number\r\n */\r\n Scene.prototype.getAnimationRatio = function () {\r\n return this._animationRatio !== undefined ? this._animationRatio : 1;\r\n };\r\n /**\r\n * Gets an unique Id for the current render phase\r\n * @returns a number\r\n */\r\n Scene.prototype.getRenderId = function () {\r\n return this._renderId;\r\n };\r\n /**\r\n * Gets an unique Id for the current frame\r\n * @returns a number\r\n */\r\n Scene.prototype.getFrameId = function () {\r\n return this._frameId;\r\n };\r\n /** Call this function if you want to manually increment the render Id*/\r\n Scene.prototype.incrementRenderId = function () {\r\n this._renderId++;\r\n };\r\n Scene.prototype._createUbo = function () {\r\n this._sceneUbo = new UniformBuffer(this._engine, undefined, true);\r\n this._sceneUbo.addUniform(\"viewProjection\", 16);\r\n this._sceneUbo.addUniform(\"view\", 16);\r\n };\r\n /**\r\n * Use this method to simulate a pointer move on a mesh\r\n * The pickResult parameter can be obtained from a scene.pick or scene.pickWithRay\r\n * @param pickResult pickingInfo of the object wished to simulate pointer event on\r\n * @param pointerEventInit pointer event state to be used when simulating the pointer event (eg. pointer id for multitouch)\r\n * @returns the current scene\r\n */\r\n Scene.prototype.simulatePointerMove = function (pickResult, pointerEventInit) {\r\n this._inputManager.simulatePointerMove(pickResult, pointerEventInit);\r\n return this;\r\n };\r\n /**\r\n * Use this method to simulate a pointer down on a mesh\r\n * The pickResult parameter can be obtained from a scene.pick or scene.pickWithRay\r\n * @param pickResult pickingInfo of the object wished to simulate pointer event on\r\n * @param pointerEventInit pointer event state to be used when simulating the pointer event (eg. pointer id for multitouch)\r\n * @returns the current scene\r\n */\r\n Scene.prototype.simulatePointerDown = function (pickResult, pointerEventInit) {\r\n this._inputManager.simulatePointerDown(pickResult, pointerEventInit);\r\n return this;\r\n };\r\n /**\r\n * Use this method to simulate a pointer up on a mesh\r\n * The pickResult parameter can be obtained from a scene.pick or scene.pickWithRay\r\n * @param pickResult pickingInfo of the object wished to simulate pointer event on\r\n * @param pointerEventInit pointer event state to be used when simulating the pointer event (eg. pointer id for multitouch)\r\n * @param doubleTap indicates that the pointer up event should be considered as part of a double click (false by default)\r\n * @returns the current scene\r\n */\r\n Scene.prototype.simulatePointerUp = function (pickResult, pointerEventInit, doubleTap) {\r\n this._inputManager.simulatePointerUp(pickResult, pointerEventInit, doubleTap);\r\n return this;\r\n };\r\n /**\r\n * Gets a boolean indicating if the current pointer event is captured (meaning that the scene has already handled the pointer down)\r\n * @param pointerId defines the pointer id to use in a multi-touch scenario (0 by default)\r\n * @returns true if the pointer was captured\r\n */\r\n Scene.prototype.isPointerCaptured = function (pointerId) {\r\n if (pointerId === void 0) { pointerId = 0; }\r\n return this._inputManager.isPointerCaptured(pointerId);\r\n };\r\n /**\r\n * Attach events to the canvas (To handle actionManagers triggers and raise onPointerMove, onPointerDown and onPointerUp\r\n * @param attachUp defines if you want to attach events to pointerup\r\n * @param attachDown defines if you want to attach events to pointerdown\r\n * @param attachMove defines if you want to attach events to pointermove\r\n */\r\n Scene.prototype.attachControl = function (attachUp, attachDown, attachMove) {\r\n if (attachUp === void 0) { attachUp = true; }\r\n if (attachDown === void 0) { attachDown = true; }\r\n if (attachMove === void 0) { attachMove = true; }\r\n this._inputManager.attachControl(attachUp, attachDown, attachMove);\r\n };\r\n /** Detaches all event handlers*/\r\n Scene.prototype.detachControl = function () {\r\n this._inputManager.detachControl();\r\n };\r\n /**\r\n * This function will check if the scene can be rendered (textures are loaded, shaders are compiled)\r\n * Delay loaded resources are not taking in account\r\n * @return true if all required resources are ready\r\n */\r\n Scene.prototype.isReady = function () {\r\n if (this._isDisposed) {\r\n return false;\r\n }\r\n var index;\r\n var engine = this.getEngine();\r\n // Effects\r\n if (!engine.areAllEffectsReady()) {\r\n return false;\r\n }\r\n // Pending data\r\n if (this._pendingData.length > 0) {\r\n return false;\r\n }\r\n // Meshes\r\n for (index = 0; index < this.meshes.length; index++) {\r\n var mesh = this.meshes[index];\r\n if (!mesh.isEnabled()) {\r\n continue;\r\n }\r\n if (!mesh.subMeshes || mesh.subMeshes.length === 0) {\r\n continue;\r\n }\r\n if (!mesh.isReady(true)) {\r\n return false;\r\n }\r\n var hardwareInstancedRendering = mesh.getClassName() === \"InstancedMesh\" || mesh.getClassName() === \"InstancedLinesMesh\" || engine.getCaps().instancedArrays && mesh.instances.length > 0;\r\n // Is Ready For Mesh\r\n for (var _i = 0, _a = this._isReadyForMeshStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n if (!step.action(mesh, hardwareInstancedRendering)) {\r\n return false;\r\n }\r\n }\r\n }\r\n // Geometries\r\n for (index = 0; index < this.geometries.length; index++) {\r\n var geometry = this.geometries[index];\r\n if (geometry.delayLoadState === 2) {\r\n return false;\r\n }\r\n }\r\n // Post-processes\r\n if (this.activeCameras && this.activeCameras.length > 0) {\r\n for (var _b = 0, _c = this.activeCameras; _b < _c.length; _b++) {\r\n var camera = _c[_b];\r\n if (!camera.isReady(true)) {\r\n return false;\r\n }\r\n }\r\n }\r\n else if (this.activeCamera) {\r\n if (!this.activeCamera.isReady(true)) {\r\n return false;\r\n }\r\n }\r\n // Particles\r\n for (var _d = 0, _e = this.particleSystems; _d < _e.length; _d++) {\r\n var particleSystem = _e[_d];\r\n if (!particleSystem.isReady()) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n /** Resets all cached information relative to material (including effect and visibility) */\r\n Scene.prototype.resetCachedMaterial = function () {\r\n this._cachedMaterial = null;\r\n this._cachedEffect = null;\r\n this._cachedVisibility = null;\r\n };\r\n /**\r\n * Registers a function to be called before every frame render\r\n * @param func defines the function to register\r\n */\r\n Scene.prototype.registerBeforeRender = function (func) {\r\n this.onBeforeRenderObservable.add(func);\r\n };\r\n /**\r\n * Unregisters a function called before every frame render\r\n * @param func defines the function to unregister\r\n */\r\n Scene.prototype.unregisterBeforeRender = function (func) {\r\n this.onBeforeRenderObservable.removeCallback(func);\r\n };\r\n /**\r\n * Registers a function to be called after every frame render\r\n * @param func defines the function to register\r\n */\r\n Scene.prototype.registerAfterRender = function (func) {\r\n this.onAfterRenderObservable.add(func);\r\n };\r\n /**\r\n * Unregisters a function called after every frame render\r\n * @param func defines the function to unregister\r\n */\r\n Scene.prototype.unregisterAfterRender = function (func) {\r\n this.onAfterRenderObservable.removeCallback(func);\r\n };\r\n Scene.prototype._executeOnceBeforeRender = function (func) {\r\n var _this = this;\r\n var execFunc = function () {\r\n func();\r\n setTimeout(function () {\r\n _this.unregisterBeforeRender(execFunc);\r\n });\r\n };\r\n this.registerBeforeRender(execFunc);\r\n };\r\n /**\r\n * The provided function will run before render once and will be disposed afterwards.\r\n * A timeout delay can be provided so that the function will be executed in N ms.\r\n * The timeout is using the browser's native setTimeout so time percision cannot be guaranteed.\r\n * @param func The function to be executed.\r\n * @param timeout optional delay in ms\r\n */\r\n Scene.prototype.executeOnceBeforeRender = function (func, timeout) {\r\n var _this = this;\r\n if (timeout !== undefined) {\r\n setTimeout(function () {\r\n _this._executeOnceBeforeRender(func);\r\n }, timeout);\r\n }\r\n else {\r\n this._executeOnceBeforeRender(func);\r\n }\r\n };\r\n /** @hidden */\r\n Scene.prototype._addPendingData = function (data) {\r\n this._pendingData.push(data);\r\n };\r\n /** @hidden */\r\n Scene.prototype._removePendingData = function (data) {\r\n var wasLoading = this.isLoading;\r\n var index = this._pendingData.indexOf(data);\r\n if (index !== -1) {\r\n this._pendingData.splice(index, 1);\r\n }\r\n if (wasLoading && !this.isLoading) {\r\n this.onDataLoadedObservable.notifyObservers(this);\r\n }\r\n };\r\n /**\r\n * Returns the number of items waiting to be loaded\r\n * @returns the number of items waiting to be loaded\r\n */\r\n Scene.prototype.getWaitingItemsCount = function () {\r\n return this._pendingData.length;\r\n };\r\n Object.defineProperty(Scene.prototype, \"isLoading\", {\r\n /**\r\n * Returns a boolean indicating if the scene is still loading data\r\n */\r\n get: function () {\r\n return this._pendingData.length > 0;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Registers a function to be executed when the scene is ready\r\n * @param {Function} func - the function to be executed\r\n */\r\n Scene.prototype.executeWhenReady = function (func) {\r\n var _this = this;\r\n this.onReadyObservable.add(func);\r\n if (this._executeWhenReadyTimeoutId !== -1) {\r\n return;\r\n }\r\n this._executeWhenReadyTimeoutId = setTimeout(function () {\r\n _this._checkIsReady();\r\n }, 150);\r\n };\r\n /**\r\n * Returns a promise that resolves when the scene is ready\r\n * @returns A promise that resolves when the scene is ready\r\n */\r\n Scene.prototype.whenReadyAsync = function () {\r\n var _this = this;\r\n return new Promise(function (resolve) {\r\n _this.executeWhenReady(function () {\r\n resolve();\r\n });\r\n });\r\n };\r\n /** @hidden */\r\n Scene.prototype._checkIsReady = function () {\r\n var _this = this;\r\n this._registerTransientComponents();\r\n if (this.isReady()) {\r\n this.onReadyObservable.notifyObservers(this);\r\n this.onReadyObservable.clear();\r\n this._executeWhenReadyTimeoutId = -1;\r\n return;\r\n }\r\n if (this._isDisposed) {\r\n this.onReadyObservable.clear();\r\n this._executeWhenReadyTimeoutId = -1;\r\n return;\r\n }\r\n this._executeWhenReadyTimeoutId = setTimeout(function () {\r\n _this._checkIsReady();\r\n }, 150);\r\n };\r\n Object.defineProperty(Scene.prototype, \"animatables\", {\r\n /**\r\n * Gets all animatable attached to the scene\r\n */\r\n get: function () {\r\n return this._activeAnimatables;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Resets the last animation time frame.\r\n * Useful to override when animations start running when loading a scene for the first time.\r\n */\r\n Scene.prototype.resetLastAnimationTimeFrame = function () {\r\n this._animationTimeLast = PrecisionDate.Now;\r\n };\r\n // Matrix\r\n /**\r\n * Gets the current view matrix\r\n * @returns a Matrix\r\n */\r\n Scene.prototype.getViewMatrix = function () {\r\n return this._viewMatrix;\r\n };\r\n /**\r\n * Gets the current projection matrix\r\n * @returns a Matrix\r\n */\r\n Scene.prototype.getProjectionMatrix = function () {\r\n return this._projectionMatrix;\r\n };\r\n /**\r\n * Gets the current transform matrix\r\n * @returns a Matrix made of View * Projection\r\n */\r\n Scene.prototype.getTransformMatrix = function () {\r\n return this._transformMatrix;\r\n };\r\n /**\r\n * Sets the current transform matrix\r\n * @param viewL defines the View matrix to use\r\n * @param projectionL defines the Projection matrix to use\r\n * @param viewR defines the right View matrix to use (if provided)\r\n * @param projectionR defines the right Projection matrix to use (if provided)\r\n */\r\n Scene.prototype.setTransformMatrix = function (viewL, projectionL, viewR, projectionR) {\r\n if (this._viewUpdateFlag === viewL.updateFlag && this._projectionUpdateFlag === projectionL.updateFlag) {\r\n return;\r\n }\r\n this._viewUpdateFlag = viewL.updateFlag;\r\n this._projectionUpdateFlag = projectionL.updateFlag;\r\n this._viewMatrix = viewL;\r\n this._projectionMatrix = projectionL;\r\n this._viewMatrix.multiplyToRef(this._projectionMatrix, this._transformMatrix);\r\n // Update frustum\r\n if (!this._frustumPlanes) {\r\n this._frustumPlanes = Frustum.GetPlanes(this._transformMatrix);\r\n }\r\n else {\r\n Frustum.GetPlanesToRef(this._transformMatrix, this._frustumPlanes);\r\n }\r\n if (this._multiviewSceneUbo && this._multiviewSceneUbo.useUbo) {\r\n this._updateMultiviewUbo(viewR, projectionR);\r\n }\r\n else if (this._sceneUbo.useUbo) {\r\n this._sceneUbo.updateMatrix(\"viewProjection\", this._transformMatrix);\r\n this._sceneUbo.updateMatrix(\"view\", this._viewMatrix);\r\n this._sceneUbo.update();\r\n }\r\n };\r\n /**\r\n * Gets the uniform buffer used to store scene data\r\n * @returns a UniformBuffer\r\n */\r\n Scene.prototype.getSceneUniformBuffer = function () {\r\n return this._multiviewSceneUbo ? this._multiviewSceneUbo : this._sceneUbo;\r\n };\r\n /**\r\n * Gets an unique (relatively to the current scene) Id\r\n * @returns an unique number for the scene\r\n */\r\n Scene.prototype.getUniqueId = function () {\r\n return UniqueIdGenerator.UniqueId;\r\n };\r\n /**\r\n * Add a mesh to the list of scene's meshes\r\n * @param newMesh defines the mesh to add\r\n * @param recursive if all child meshes should also be added to the scene\r\n */\r\n Scene.prototype.addMesh = function (newMesh, recursive) {\r\n var _this = this;\r\n if (recursive === void 0) { recursive = false; }\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.meshes.push(newMesh);\r\n newMesh._resyncLightSources();\r\n if (!newMesh.parent) {\r\n newMesh._addToSceneRootNodes();\r\n }\r\n this.onNewMeshAddedObservable.notifyObservers(newMesh);\r\n if (recursive) {\r\n newMesh.getChildMeshes().forEach(function (m) {\r\n _this.addMesh(m);\r\n });\r\n }\r\n };\r\n /**\r\n * Remove a mesh for the list of scene's meshes\r\n * @param toRemove defines the mesh to remove\r\n * @param recursive if all child meshes should also be removed from the scene\r\n * @returns the index where the mesh was in the mesh list\r\n */\r\n Scene.prototype.removeMesh = function (toRemove, recursive) {\r\n var _this = this;\r\n if (recursive === void 0) { recursive = false; }\r\n var index = this.meshes.indexOf(toRemove);\r\n if (index !== -1) {\r\n // Remove from the scene if mesh found\r\n this.meshes[index] = this.meshes[this.meshes.length - 1];\r\n this.meshes.pop();\r\n if (!toRemove.parent) {\r\n toRemove._removeFromSceneRootNodes();\r\n }\r\n }\r\n this.onMeshRemovedObservable.notifyObservers(toRemove);\r\n if (recursive) {\r\n toRemove.getChildMeshes().forEach(function (m) {\r\n _this.removeMesh(m);\r\n });\r\n }\r\n return index;\r\n };\r\n /**\r\n * Add a transform node to the list of scene's transform nodes\r\n * @param newTransformNode defines the transform node to add\r\n */\r\n Scene.prototype.addTransformNode = function (newTransformNode) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n newTransformNode._indexInSceneTransformNodesArray = this.transformNodes.length;\r\n this.transformNodes.push(newTransformNode);\r\n if (!newTransformNode.parent) {\r\n newTransformNode._addToSceneRootNodes();\r\n }\r\n this.onNewTransformNodeAddedObservable.notifyObservers(newTransformNode);\r\n };\r\n /**\r\n * Remove a transform node for the list of scene's transform nodes\r\n * @param toRemove defines the transform node to remove\r\n * @returns the index where the transform node was in the transform node list\r\n */\r\n Scene.prototype.removeTransformNode = function (toRemove) {\r\n var index = toRemove._indexInSceneTransformNodesArray;\r\n if (index !== -1) {\r\n if (index !== this.transformNodes.length - 1) {\r\n var lastNode = this.transformNodes[this.transformNodes.length - 1];\r\n this.transformNodes[index] = lastNode;\r\n lastNode._indexInSceneTransformNodesArray = index;\r\n }\r\n toRemove._indexInSceneTransformNodesArray = -1;\r\n this.transformNodes.pop();\r\n if (!toRemove.parent) {\r\n toRemove._removeFromSceneRootNodes();\r\n }\r\n }\r\n this.onTransformNodeRemovedObservable.notifyObservers(toRemove);\r\n return index;\r\n };\r\n /**\r\n * Remove a skeleton for the list of scene's skeletons\r\n * @param toRemove defines the skeleton to remove\r\n * @returns the index where the skeleton was in the skeleton list\r\n */\r\n Scene.prototype.removeSkeleton = function (toRemove) {\r\n var index = this.skeletons.indexOf(toRemove);\r\n if (index !== -1) {\r\n // Remove from the scene if found\r\n this.skeletons.splice(index, 1);\r\n this.onSkeletonRemovedObservable.notifyObservers(toRemove);\r\n }\r\n return index;\r\n };\r\n /**\r\n * Remove a morph target for the list of scene's morph targets\r\n * @param toRemove defines the morph target to remove\r\n * @returns the index where the morph target was in the morph target list\r\n */\r\n Scene.prototype.removeMorphTargetManager = function (toRemove) {\r\n var index = this.morphTargetManagers.indexOf(toRemove);\r\n if (index !== -1) {\r\n // Remove from the scene if found\r\n this.morphTargetManagers.splice(index, 1);\r\n }\r\n return index;\r\n };\r\n /**\r\n * Remove a light for the list of scene's lights\r\n * @param toRemove defines the light to remove\r\n * @returns the index where the light was in the light list\r\n */\r\n Scene.prototype.removeLight = function (toRemove) {\r\n var index = this.lights.indexOf(toRemove);\r\n if (index !== -1) {\r\n // Remove from meshes\r\n for (var _i = 0, _a = this.meshes; _i < _a.length; _i++) {\r\n var mesh = _a[_i];\r\n mesh._removeLightSource(toRemove, false);\r\n }\r\n // Remove from the scene if mesh found\r\n this.lights.splice(index, 1);\r\n this.sortLightsByPriority();\r\n if (!toRemove.parent) {\r\n toRemove._removeFromSceneRootNodes();\r\n }\r\n }\r\n this.onLightRemovedObservable.notifyObservers(toRemove);\r\n return index;\r\n };\r\n /**\r\n * Remove a camera for the list of scene's cameras\r\n * @param toRemove defines the camera to remove\r\n * @returns the index where the camera was in the camera list\r\n */\r\n Scene.prototype.removeCamera = function (toRemove) {\r\n var index = this.cameras.indexOf(toRemove);\r\n if (index !== -1) {\r\n // Remove from the scene if mesh found\r\n this.cameras.splice(index, 1);\r\n if (!toRemove.parent) {\r\n toRemove._removeFromSceneRootNodes();\r\n }\r\n }\r\n // Remove from activeCameras\r\n var index2 = this.activeCameras.indexOf(toRemove);\r\n if (index2 !== -1) {\r\n // Remove from the scene if mesh found\r\n this.activeCameras.splice(index2, 1);\r\n }\r\n // Reset the activeCamera\r\n if (this.activeCamera === toRemove) {\r\n if (this.cameras.length > 0) {\r\n this.activeCamera = this.cameras[0];\r\n }\r\n else {\r\n this.activeCamera = null;\r\n }\r\n }\r\n this.onCameraRemovedObservable.notifyObservers(toRemove);\r\n return index;\r\n };\r\n /**\r\n * Remove a particle system for the list of scene's particle systems\r\n * @param toRemove defines the particle system to remove\r\n * @returns the index where the particle system was in the particle system list\r\n */\r\n Scene.prototype.removeParticleSystem = function (toRemove) {\r\n var index = this.particleSystems.indexOf(toRemove);\r\n if (index !== -1) {\r\n this.particleSystems.splice(index, 1);\r\n }\r\n return index;\r\n };\r\n /**\r\n * Remove a animation for the list of scene's animations\r\n * @param toRemove defines the animation to remove\r\n * @returns the index where the animation was in the animation list\r\n */\r\n Scene.prototype.removeAnimation = function (toRemove) {\r\n var index = this.animations.indexOf(toRemove);\r\n if (index !== -1) {\r\n this.animations.splice(index, 1);\r\n }\r\n return index;\r\n };\r\n /**\r\n * Will stop the animation of the given target\r\n * @param target - the target\r\n * @param animationName - the name of the animation to stop (all animations will be stopped if both this and targetMask are empty)\r\n * @param targetMask - a function that determines if the animation should be stopped based on its target (all animations will be stopped if both this and animationName are empty)\r\n */\r\n Scene.prototype.stopAnimation = function (target, animationName, targetMask) {\r\n // Do nothing as code will be provided by animation component\r\n };\r\n /**\r\n * Removes the given animation group from this scene.\r\n * @param toRemove The animation group to remove\r\n * @returns The index of the removed animation group\r\n */\r\n Scene.prototype.removeAnimationGroup = function (toRemove) {\r\n var index = this.animationGroups.indexOf(toRemove);\r\n if (index !== -1) {\r\n this.animationGroups.splice(index, 1);\r\n }\r\n return index;\r\n };\r\n /**\r\n * Removes the given multi-material from this scene.\r\n * @param toRemove The multi-material to remove\r\n * @returns The index of the removed multi-material\r\n */\r\n Scene.prototype.removeMultiMaterial = function (toRemove) {\r\n var index = this.multiMaterials.indexOf(toRemove);\r\n if (index !== -1) {\r\n this.multiMaterials.splice(index, 1);\r\n }\r\n return index;\r\n };\r\n /**\r\n * Removes the given material from this scene.\r\n * @param toRemove The material to remove\r\n * @returns The index of the removed material\r\n */\r\n Scene.prototype.removeMaterial = function (toRemove) {\r\n var index = toRemove._indexInSceneMaterialArray;\r\n if (index !== -1 && index < this.materials.length) {\r\n if (index !== this.materials.length - 1) {\r\n var lastMaterial = this.materials[this.materials.length - 1];\r\n this.materials[index] = lastMaterial;\r\n lastMaterial._indexInSceneMaterialArray = index;\r\n }\r\n toRemove._indexInSceneMaterialArray = -1;\r\n this.materials.pop();\r\n }\r\n this.onMaterialRemovedObservable.notifyObservers(toRemove);\r\n return index;\r\n };\r\n /**\r\n * Removes the given action manager from this scene.\r\n * @param toRemove The action manager to remove\r\n * @returns The index of the removed action manager\r\n */\r\n Scene.prototype.removeActionManager = function (toRemove) {\r\n var index = this.actionManagers.indexOf(toRemove);\r\n if (index !== -1) {\r\n this.actionManagers.splice(index, 1);\r\n }\r\n return index;\r\n };\r\n /**\r\n * Removes the given texture from this scene.\r\n * @param toRemove The texture to remove\r\n * @returns The index of the removed texture\r\n */\r\n Scene.prototype.removeTexture = function (toRemove) {\r\n var index = this.textures.indexOf(toRemove);\r\n if (index !== -1) {\r\n this.textures.splice(index, 1);\r\n }\r\n this.onTextureRemovedObservable.notifyObservers(toRemove);\r\n return index;\r\n };\r\n /**\r\n * Adds the given light to this scene\r\n * @param newLight The light to add\r\n */\r\n Scene.prototype.addLight = function (newLight) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.lights.push(newLight);\r\n this.sortLightsByPriority();\r\n if (!newLight.parent) {\r\n newLight._addToSceneRootNodes();\r\n }\r\n // Add light to all meshes (To support if the light is removed and then re-added)\r\n for (var _i = 0, _a = this.meshes; _i < _a.length; _i++) {\r\n var mesh = _a[_i];\r\n if (mesh.lightSources.indexOf(newLight) === -1) {\r\n mesh.lightSources.push(newLight);\r\n mesh._resyncLightSources();\r\n }\r\n }\r\n this.onNewLightAddedObservable.notifyObservers(newLight);\r\n };\r\n /**\r\n * Sorts the list list based on light priorities\r\n */\r\n Scene.prototype.sortLightsByPriority = function () {\r\n if (this.requireLightSorting) {\r\n this.lights.sort(Light.CompareLightsPriority);\r\n }\r\n };\r\n /**\r\n * Adds the given camera to this scene\r\n * @param newCamera The camera to add\r\n */\r\n Scene.prototype.addCamera = function (newCamera) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.cameras.push(newCamera);\r\n this.onNewCameraAddedObservable.notifyObservers(newCamera);\r\n if (!newCamera.parent) {\r\n newCamera._addToSceneRootNodes();\r\n }\r\n };\r\n /**\r\n * Adds the given skeleton to this scene\r\n * @param newSkeleton The skeleton to add\r\n */\r\n Scene.prototype.addSkeleton = function (newSkeleton) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.skeletons.push(newSkeleton);\r\n this.onNewSkeletonAddedObservable.notifyObservers(newSkeleton);\r\n };\r\n /**\r\n * Adds the given particle system to this scene\r\n * @param newParticleSystem The particle system to add\r\n */\r\n Scene.prototype.addParticleSystem = function (newParticleSystem) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.particleSystems.push(newParticleSystem);\r\n };\r\n /**\r\n * Adds the given animation to this scene\r\n * @param newAnimation The animation to add\r\n */\r\n Scene.prototype.addAnimation = function (newAnimation) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.animations.push(newAnimation);\r\n };\r\n /**\r\n * Adds the given animation group to this scene.\r\n * @param newAnimationGroup The animation group to add\r\n */\r\n Scene.prototype.addAnimationGroup = function (newAnimationGroup) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.animationGroups.push(newAnimationGroup);\r\n };\r\n /**\r\n * Adds the given multi-material to this scene\r\n * @param newMultiMaterial The multi-material to add\r\n */\r\n Scene.prototype.addMultiMaterial = function (newMultiMaterial) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.multiMaterials.push(newMultiMaterial);\r\n };\r\n /**\r\n * Adds the given material to this scene\r\n * @param newMaterial The material to add\r\n */\r\n Scene.prototype.addMaterial = function (newMaterial) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n newMaterial._indexInSceneMaterialArray = this.materials.length;\r\n this.materials.push(newMaterial);\r\n this.onNewMaterialAddedObservable.notifyObservers(newMaterial);\r\n };\r\n /**\r\n * Adds the given morph target to this scene\r\n * @param newMorphTargetManager The morph target to add\r\n */\r\n Scene.prototype.addMorphTargetManager = function (newMorphTargetManager) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.morphTargetManagers.push(newMorphTargetManager);\r\n };\r\n /**\r\n * Adds the given geometry to this scene\r\n * @param newGeometry The geometry to add\r\n */\r\n Scene.prototype.addGeometry = function (newGeometry) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n if (this.geometriesByUniqueId) {\r\n this.geometriesByUniqueId[newGeometry.uniqueId] = this.geometries.length;\r\n }\r\n this.geometries.push(newGeometry);\r\n };\r\n /**\r\n * Adds the given action manager to this scene\r\n * @param newActionManager The action manager to add\r\n */\r\n Scene.prototype.addActionManager = function (newActionManager) {\r\n this.actionManagers.push(newActionManager);\r\n };\r\n /**\r\n * Adds the given texture to this scene.\r\n * @param newTexture The texture to add\r\n */\r\n Scene.prototype.addTexture = function (newTexture) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.textures.push(newTexture);\r\n this.onNewTextureAddedObservable.notifyObservers(newTexture);\r\n };\r\n /**\r\n * Switch active camera\r\n * @param newCamera defines the new active camera\r\n * @param attachControl defines if attachControl must be called for the new active camera (default: true)\r\n */\r\n Scene.prototype.switchActiveCamera = function (newCamera, attachControl) {\r\n if (attachControl === void 0) { attachControl = true; }\r\n var canvas = this._engine.getInputElement();\r\n if (!canvas) {\r\n return;\r\n }\r\n if (this.activeCamera) {\r\n this.activeCamera.detachControl(canvas);\r\n }\r\n this.activeCamera = newCamera;\r\n if (attachControl) {\r\n newCamera.attachControl(canvas);\r\n }\r\n };\r\n /**\r\n * sets the active camera of the scene using its ID\r\n * @param id defines the camera's ID\r\n * @return the new active camera or null if none found.\r\n */\r\n Scene.prototype.setActiveCameraByID = function (id) {\r\n var camera = this.getCameraByID(id);\r\n if (camera) {\r\n this.activeCamera = camera;\r\n return camera;\r\n }\r\n return null;\r\n };\r\n /**\r\n * sets the active camera of the scene using its name\r\n * @param name defines the camera's name\r\n * @returns the new active camera or null if none found.\r\n */\r\n Scene.prototype.setActiveCameraByName = function (name) {\r\n var camera = this.getCameraByName(name);\r\n if (camera) {\r\n this.activeCamera = camera;\r\n return camera;\r\n }\r\n return null;\r\n };\r\n /**\r\n * get an animation group using its name\r\n * @param name defines the material's name\r\n * @return the animation group or null if none found.\r\n */\r\n Scene.prototype.getAnimationGroupByName = function (name) {\r\n for (var index = 0; index < this.animationGroups.length; index++) {\r\n if (this.animationGroups[index].name === name) {\r\n return this.animationGroups[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Get a material using its unique id\r\n * @param uniqueId defines the material's unique id\r\n * @return the material or null if none found.\r\n */\r\n Scene.prototype.getMaterialByUniqueID = function (uniqueId) {\r\n for (var index = 0; index < this.materials.length; index++) {\r\n if (this.materials[index].uniqueId === uniqueId) {\r\n return this.materials[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * get a material using its id\r\n * @param id defines the material's ID\r\n * @return the material or null if none found.\r\n */\r\n Scene.prototype.getMaterialByID = function (id) {\r\n for (var index = 0; index < this.materials.length; index++) {\r\n if (this.materials[index].id === id) {\r\n return this.materials[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a the last added material using a given id\r\n * @param id defines the material's ID\r\n * @return the last material with the given id or null if none found.\r\n */\r\n Scene.prototype.getLastMaterialByID = function (id) {\r\n for (var index = this.materials.length - 1; index >= 0; index--) {\r\n if (this.materials[index].id === id) {\r\n return this.materials[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a material using its name\r\n * @param name defines the material's name\r\n * @return the material or null if none found.\r\n */\r\n Scene.prototype.getMaterialByName = function (name) {\r\n for (var index = 0; index < this.materials.length; index++) {\r\n if (this.materials[index].name === name) {\r\n return this.materials[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Get a texture using its unique id\r\n * @param uniqueId defines the texture's unique id\r\n * @return the texture or null if none found.\r\n */\r\n Scene.prototype.getTextureByUniqueID = function (uniqueId) {\r\n for (var index = 0; index < this.textures.length; index++) {\r\n if (this.textures[index].uniqueId === uniqueId) {\r\n return this.textures[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a camera using its id\r\n * @param id defines the id to look for\r\n * @returns the camera or null if not found\r\n */\r\n Scene.prototype.getCameraByID = function (id) {\r\n for (var index = 0; index < this.cameras.length; index++) {\r\n if (this.cameras[index].id === id) {\r\n return this.cameras[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a camera using its unique id\r\n * @param uniqueId defines the unique id to look for\r\n * @returns the camera or null if not found\r\n */\r\n Scene.prototype.getCameraByUniqueID = function (uniqueId) {\r\n for (var index = 0; index < this.cameras.length; index++) {\r\n if (this.cameras[index].uniqueId === uniqueId) {\r\n return this.cameras[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a camera using its name\r\n * @param name defines the camera's name\r\n * @return the camera or null if none found.\r\n */\r\n Scene.prototype.getCameraByName = function (name) {\r\n for (var index = 0; index < this.cameras.length; index++) {\r\n if (this.cameras[index].name === name) {\r\n return this.cameras[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a bone using its id\r\n * @param id defines the bone's id\r\n * @return the bone or null if not found\r\n */\r\n Scene.prototype.getBoneByID = function (id) {\r\n for (var skeletonIndex = 0; skeletonIndex < this.skeletons.length; skeletonIndex++) {\r\n var skeleton = this.skeletons[skeletonIndex];\r\n for (var boneIndex = 0; boneIndex < skeleton.bones.length; boneIndex++) {\r\n if (skeleton.bones[boneIndex].id === id) {\r\n return skeleton.bones[boneIndex];\r\n }\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a bone using its id\r\n * @param name defines the bone's name\r\n * @return the bone or null if not found\r\n */\r\n Scene.prototype.getBoneByName = function (name) {\r\n for (var skeletonIndex = 0; skeletonIndex < this.skeletons.length; skeletonIndex++) {\r\n var skeleton = this.skeletons[skeletonIndex];\r\n for (var boneIndex = 0; boneIndex < skeleton.bones.length; boneIndex++) {\r\n if (skeleton.bones[boneIndex].name === name) {\r\n return skeleton.bones[boneIndex];\r\n }\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a light node using its name\r\n * @param name defines the the light's name\r\n * @return the light or null if none found.\r\n */\r\n Scene.prototype.getLightByName = function (name) {\r\n for (var index = 0; index < this.lights.length; index++) {\r\n if (this.lights[index].name === name) {\r\n return this.lights[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a light node using its id\r\n * @param id defines the light's id\r\n * @return the light or null if none found.\r\n */\r\n Scene.prototype.getLightByID = function (id) {\r\n for (var index = 0; index < this.lights.length; index++) {\r\n if (this.lights[index].id === id) {\r\n return this.lights[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a light node using its scene-generated unique ID\r\n * @param uniqueId defines the light's unique id\r\n * @return the light or null if none found.\r\n */\r\n Scene.prototype.getLightByUniqueID = function (uniqueId) {\r\n for (var index = 0; index < this.lights.length; index++) {\r\n if (this.lights[index].uniqueId === uniqueId) {\r\n return this.lights[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a particle system by id\r\n * @param id defines the particle system id\r\n * @return the corresponding system or null if none found\r\n */\r\n Scene.prototype.getParticleSystemByID = function (id) {\r\n for (var index = 0; index < this.particleSystems.length; index++) {\r\n if (this.particleSystems[index].id === id) {\r\n return this.particleSystems[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a geometry using its ID\r\n * @param id defines the geometry's id\r\n * @return the geometry or null if none found.\r\n */\r\n Scene.prototype.getGeometryByID = function (id) {\r\n for (var index = 0; index < this.geometries.length; index++) {\r\n if (this.geometries[index].id === id) {\r\n return this.geometries[index];\r\n }\r\n }\r\n return null;\r\n };\r\n Scene.prototype._getGeometryByUniqueID = function (uniqueId) {\r\n if (this.geometriesByUniqueId) {\r\n var index_1 = this.geometriesByUniqueId[uniqueId];\r\n if (index_1 !== undefined) {\r\n return this.geometries[index_1];\r\n }\r\n }\r\n else {\r\n for (var index = 0; index < this.geometries.length; index++) {\r\n if (this.geometries[index].uniqueId === uniqueId) {\r\n return this.geometries[index];\r\n }\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Add a new geometry to this scene\r\n * @param geometry defines the geometry to be added to the scene.\r\n * @param force defines if the geometry must be pushed even if a geometry with this id already exists\r\n * @return a boolean defining if the geometry was added or not\r\n */\r\n Scene.prototype.pushGeometry = function (geometry, force) {\r\n if (!force && this._getGeometryByUniqueID(geometry.uniqueId)) {\r\n return false;\r\n }\r\n this.addGeometry(geometry);\r\n this.onNewGeometryAddedObservable.notifyObservers(geometry);\r\n return true;\r\n };\r\n /**\r\n * Removes an existing geometry\r\n * @param geometry defines the geometry to be removed from the scene\r\n * @return a boolean defining if the geometry was removed or not\r\n */\r\n Scene.prototype.removeGeometry = function (geometry) {\r\n var index;\r\n if (this.geometriesByUniqueId) {\r\n index = this.geometriesByUniqueId[geometry.uniqueId];\r\n if (index === undefined) {\r\n return false;\r\n }\r\n }\r\n else {\r\n index = this.geometries.indexOf(geometry);\r\n if (index < 0) {\r\n return false;\r\n }\r\n }\r\n if (index !== this.geometries.length - 1) {\r\n var lastGeometry = this.geometries[this.geometries.length - 1];\r\n this.geometries[index] = lastGeometry;\r\n if (this.geometriesByUniqueId) {\r\n this.geometriesByUniqueId[lastGeometry.uniqueId] = index;\r\n this.geometriesByUniqueId[geometry.uniqueId] = undefined;\r\n }\r\n }\r\n this.geometries.pop();\r\n this.onGeometryRemovedObservable.notifyObservers(geometry);\r\n return true;\r\n };\r\n /**\r\n * Gets the list of geometries attached to the scene\r\n * @returns an array of Geometry\r\n */\r\n Scene.prototype.getGeometries = function () {\r\n return this.geometries;\r\n };\r\n /**\r\n * Gets the first added mesh found of a given ID\r\n * @param id defines the id to search for\r\n * @return the mesh found or null if not found at all\r\n */\r\n Scene.prototype.getMeshByID = function (id) {\r\n for (var index = 0; index < this.meshes.length; index++) {\r\n if (this.meshes[index].id === id) {\r\n return this.meshes[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a list of meshes using their id\r\n * @param id defines the id to search for\r\n * @returns a list of meshes\r\n */\r\n Scene.prototype.getMeshesByID = function (id) {\r\n return this.meshes.filter(function (m) {\r\n return m.id === id;\r\n });\r\n };\r\n /**\r\n * Gets the first added transform node found of a given ID\r\n * @param id defines the id to search for\r\n * @return the found transform node or null if not found at all.\r\n */\r\n Scene.prototype.getTransformNodeByID = function (id) {\r\n for (var index = 0; index < this.transformNodes.length; index++) {\r\n if (this.transformNodes[index].id === id) {\r\n return this.transformNodes[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a transform node with its auto-generated unique id\r\n * @param uniqueId efines the unique id to search for\r\n * @return the found transform node or null if not found at all.\r\n */\r\n Scene.prototype.getTransformNodeByUniqueID = function (uniqueId) {\r\n for (var index = 0; index < this.transformNodes.length; index++) {\r\n if (this.transformNodes[index].uniqueId === uniqueId) {\r\n return this.transformNodes[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a list of transform nodes using their id\r\n * @param id defines the id to search for\r\n * @returns a list of transform nodes\r\n */\r\n Scene.prototype.getTransformNodesByID = function (id) {\r\n return this.transformNodes.filter(function (m) {\r\n return m.id === id;\r\n });\r\n };\r\n /**\r\n * Gets a mesh with its auto-generated unique id\r\n * @param uniqueId defines the unique id to search for\r\n * @return the found mesh or null if not found at all.\r\n */\r\n Scene.prototype.getMeshByUniqueID = function (uniqueId) {\r\n for (var index = 0; index < this.meshes.length; index++) {\r\n if (this.meshes[index].uniqueId === uniqueId) {\r\n return this.meshes[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a the last added mesh using a given id\r\n * @param id defines the id to search for\r\n * @return the found mesh or null if not found at all.\r\n */\r\n Scene.prototype.getLastMeshByID = function (id) {\r\n for (var index = this.meshes.length - 1; index >= 0; index--) {\r\n if (this.meshes[index].id === id) {\r\n return this.meshes[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a the last added node (Mesh, Camera, Light) using a given id\r\n * @param id defines the id to search for\r\n * @return the found node or null if not found at all\r\n */\r\n Scene.prototype.getLastEntryByID = function (id) {\r\n var index;\r\n for (index = this.meshes.length - 1; index >= 0; index--) {\r\n if (this.meshes[index].id === id) {\r\n return this.meshes[index];\r\n }\r\n }\r\n for (index = this.transformNodes.length - 1; index >= 0; index--) {\r\n if (this.transformNodes[index].id === id) {\r\n return this.transformNodes[index];\r\n }\r\n }\r\n for (index = this.cameras.length - 1; index >= 0; index--) {\r\n if (this.cameras[index].id === id) {\r\n return this.cameras[index];\r\n }\r\n }\r\n for (index = this.lights.length - 1; index >= 0; index--) {\r\n if (this.lights[index].id === id) {\r\n return this.lights[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a node (Mesh, Camera, Light) using a given id\r\n * @param id defines the id to search for\r\n * @return the found node or null if not found at all\r\n */\r\n Scene.prototype.getNodeByID = function (id) {\r\n var mesh = this.getMeshByID(id);\r\n if (mesh) {\r\n return mesh;\r\n }\r\n var transformNode = this.getTransformNodeByID(id);\r\n if (transformNode) {\r\n return transformNode;\r\n }\r\n var light = this.getLightByID(id);\r\n if (light) {\r\n return light;\r\n }\r\n var camera = this.getCameraByID(id);\r\n if (camera) {\r\n return camera;\r\n }\r\n var bone = this.getBoneByID(id);\r\n if (bone) {\r\n return bone;\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a node (Mesh, Camera, Light) using a given name\r\n * @param name defines the name to search for\r\n * @return the found node or null if not found at all.\r\n */\r\n Scene.prototype.getNodeByName = function (name) {\r\n var mesh = this.getMeshByName(name);\r\n if (mesh) {\r\n return mesh;\r\n }\r\n var transformNode = this.getTransformNodeByName(name);\r\n if (transformNode) {\r\n return transformNode;\r\n }\r\n var light = this.getLightByName(name);\r\n if (light) {\r\n return light;\r\n }\r\n var camera = this.getCameraByName(name);\r\n if (camera) {\r\n return camera;\r\n }\r\n var bone = this.getBoneByName(name);\r\n if (bone) {\r\n return bone;\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a mesh using a given name\r\n * @param name defines the name to search for\r\n * @return the found mesh or null if not found at all.\r\n */\r\n Scene.prototype.getMeshByName = function (name) {\r\n for (var index = 0; index < this.meshes.length; index++) {\r\n if (this.meshes[index].name === name) {\r\n return this.meshes[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a transform node using a given name\r\n * @param name defines the name to search for\r\n * @return the found transform node or null if not found at all.\r\n */\r\n Scene.prototype.getTransformNodeByName = function (name) {\r\n for (var index = 0; index < this.transformNodes.length; index++) {\r\n if (this.transformNodes[index].name === name) {\r\n return this.transformNodes[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a skeleton using a given id (if many are found, this function will pick the last one)\r\n * @param id defines the id to search for\r\n * @return the found skeleton or null if not found at all.\r\n */\r\n Scene.prototype.getLastSkeletonByID = function (id) {\r\n for (var index = this.skeletons.length - 1; index >= 0; index--) {\r\n if (this.skeletons[index].id === id) {\r\n return this.skeletons[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a skeleton using a given auto generated unique id\r\n * @param uniqueId defines the unique id to search for\r\n * @return the found skeleton or null if not found at all.\r\n */\r\n Scene.prototype.getSkeletonByUniqueId = function (uniqueId) {\r\n for (var index = 0; index < this.skeletons.length; index++) {\r\n if (this.skeletons[index].uniqueId === uniqueId) {\r\n return this.skeletons[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a skeleton using a given id (if many are found, this function will pick the first one)\r\n * @param id defines the id to search for\r\n * @return the found skeleton or null if not found at all.\r\n */\r\n Scene.prototype.getSkeletonById = function (id) {\r\n for (var index = 0; index < this.skeletons.length; index++) {\r\n if (this.skeletons[index].id === id) {\r\n return this.skeletons[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a skeleton using a given name\r\n * @param name defines the name to search for\r\n * @return the found skeleton or null if not found at all.\r\n */\r\n Scene.prototype.getSkeletonByName = function (name) {\r\n for (var index = 0; index < this.skeletons.length; index++) {\r\n if (this.skeletons[index].name === name) {\r\n return this.skeletons[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a morph target manager using a given id (if many are found, this function will pick the last one)\r\n * @param id defines the id to search for\r\n * @return the found morph target manager or null if not found at all.\r\n */\r\n Scene.prototype.getMorphTargetManagerById = function (id) {\r\n for (var index = 0; index < this.morphTargetManagers.length; index++) {\r\n if (this.morphTargetManagers[index].uniqueId === id) {\r\n return this.morphTargetManagers[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a morph target using a given id (if many are found, this function will pick the first one)\r\n * @param id defines the id to search for\r\n * @return the found morph target or null if not found at all.\r\n */\r\n Scene.prototype.getMorphTargetById = function (id) {\r\n for (var managerIndex = 0; managerIndex < this.morphTargetManagers.length; ++managerIndex) {\r\n var morphTargetManager = this.morphTargetManagers[managerIndex];\r\n for (var index = 0; index < morphTargetManager.numTargets; ++index) {\r\n var target = morphTargetManager.getTarget(index);\r\n if (target.id === id) {\r\n return target;\r\n }\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a boolean indicating if the given mesh is active\r\n * @param mesh defines the mesh to look for\r\n * @returns true if the mesh is in the active list\r\n */\r\n Scene.prototype.isActiveMesh = function (mesh) {\r\n return (this._activeMeshes.indexOf(mesh) !== -1);\r\n };\r\n Object.defineProperty(Scene.prototype, \"uid\", {\r\n /**\r\n * Return a unique id as a string which can serve as an identifier for the scene\r\n */\r\n get: function () {\r\n if (!this._uid) {\r\n this._uid = Tools.RandomId();\r\n }\r\n return this._uid;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Add an externaly attached data from its key.\r\n * This method call will fail and return false, if such key already exists.\r\n * If you don't care and just want to get the data no matter what, use the more convenient getOrAddExternalDataWithFactory() method.\r\n * @param key the unique key that identifies the data\r\n * @param data the data object to associate to the key for this Engine instance\r\n * @return true if no such key were already present and the data was added successfully, false otherwise\r\n */\r\n Scene.prototype.addExternalData = function (key, data) {\r\n if (!this._externalData) {\r\n this._externalData = new StringDictionary();\r\n }\r\n return this._externalData.add(key, data);\r\n };\r\n /**\r\n * Get an externaly attached data from its key\r\n * @param key the unique key that identifies the data\r\n * @return the associated data, if present (can be null), or undefined if not present\r\n */\r\n Scene.prototype.getExternalData = function (key) {\r\n if (!this._externalData) {\r\n return null;\r\n }\r\n return this._externalData.get(key);\r\n };\r\n /**\r\n * Get an externaly attached data from its key, create it using a factory if it's not already present\r\n * @param key the unique key that identifies the data\r\n * @param factory the factory that will be called to create the instance if and only if it doesn't exists\r\n * @return the associated data, can be null if the factory returned null.\r\n */\r\n Scene.prototype.getOrAddExternalDataWithFactory = function (key, factory) {\r\n if (!this._externalData) {\r\n this._externalData = new StringDictionary();\r\n }\r\n return this._externalData.getOrAddWithFactory(key, factory);\r\n };\r\n /**\r\n * Remove an externaly attached data from the Engine instance\r\n * @param key the unique key that identifies the data\r\n * @return true if the data was successfully removed, false if it doesn't exist\r\n */\r\n Scene.prototype.removeExternalData = function (key) {\r\n return this._externalData.remove(key);\r\n };\r\n Scene.prototype._evaluateSubMesh = function (subMesh, mesh, initialMesh) {\r\n if (initialMesh.hasInstances || initialMesh.isAnInstance || this.dispatchAllSubMeshesOfActiveMeshes || this._skipFrustumClipping || mesh.alwaysSelectAsActiveMesh || mesh.subMeshes.length === 1 || subMesh.isInFrustum(this._frustumPlanes)) {\r\n for (var _i = 0, _a = this._evaluateSubMeshStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n step.action(mesh, subMesh);\r\n }\r\n var material = subMesh.getMaterial();\r\n if (material !== null && material !== undefined) {\r\n // Render targets\r\n if (material.hasRenderTargetTextures && material.getRenderTargetTextures != null) {\r\n if (this._processedMaterials.indexOf(material) === -1) {\r\n this._processedMaterials.push(material);\r\n this._renderTargets.concatWithNoDuplicate(material.getRenderTargetTextures());\r\n }\r\n }\r\n // Dispatch\r\n this._renderingManager.dispatch(subMesh, mesh, material);\r\n }\r\n }\r\n };\r\n /**\r\n * Clear the processed materials smart array preventing retention point in material dispose.\r\n */\r\n Scene.prototype.freeProcessedMaterials = function () {\r\n this._processedMaterials.dispose();\r\n };\r\n Object.defineProperty(Scene.prototype, \"blockfreeActiveMeshesAndRenderingGroups\", {\r\n /** Gets or sets a boolean blocking all the calls to freeActiveMeshes and freeRenderingGroups\r\n * It can be used in order to prevent going through methods freeRenderingGroups and freeActiveMeshes several times to improve performance\r\n * when disposing several meshes in a row or a hierarchy of meshes.\r\n * When used, it is the responsability of the user to blockfreeActiveMeshesAndRenderingGroups back to false.\r\n */\r\n get: function () {\r\n return this._preventFreeActiveMeshesAndRenderingGroups;\r\n },\r\n set: function (value) {\r\n if (this._preventFreeActiveMeshesAndRenderingGroups === value) {\r\n return;\r\n }\r\n if (value) {\r\n this.freeActiveMeshes();\r\n this.freeRenderingGroups();\r\n }\r\n this._preventFreeActiveMeshesAndRenderingGroups = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Clear the active meshes smart array preventing retention point in mesh dispose.\r\n */\r\n Scene.prototype.freeActiveMeshes = function () {\r\n if (this.blockfreeActiveMeshesAndRenderingGroups) {\r\n return;\r\n }\r\n this._activeMeshes.dispose();\r\n if (this.activeCamera && this.activeCamera._activeMeshes) {\r\n this.activeCamera._activeMeshes.dispose();\r\n }\r\n if (this.activeCameras) {\r\n for (var i = 0; i < this.activeCameras.length; i++) {\r\n var activeCamera = this.activeCameras[i];\r\n if (activeCamera && activeCamera._activeMeshes) {\r\n activeCamera._activeMeshes.dispose();\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Clear the info related to rendering groups preventing retention points during dispose.\r\n */\r\n Scene.prototype.freeRenderingGroups = function () {\r\n if (this.blockfreeActiveMeshesAndRenderingGroups) {\r\n return;\r\n }\r\n if (this._renderingManager) {\r\n this._renderingManager.freeRenderingGroups();\r\n }\r\n if (this.textures) {\r\n for (var i = 0; i < this.textures.length; i++) {\r\n var texture = this.textures[i];\r\n if (texture && texture.renderList) {\r\n texture.freeRenderingGroups();\r\n }\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n Scene.prototype._isInIntermediateRendering = function () {\r\n return this._intermediateRendering;\r\n };\r\n /**\r\n * Use this function to stop evaluating active meshes. The current list will be keep alive between frames\r\n * @param skipEvaluateActiveMeshes defines an optional boolean indicating that the evaluate active meshes step must be completely skipped\r\n * @returns the current scene\r\n */\r\n Scene.prototype.freezeActiveMeshes = function (skipEvaluateActiveMeshes) {\r\n var _this = this;\r\n if (skipEvaluateActiveMeshes === void 0) { skipEvaluateActiveMeshes = false; }\r\n this.executeWhenReady(function () {\r\n if (!_this.activeCamera) {\r\n return;\r\n }\r\n if (!_this._frustumPlanes) {\r\n _this.setTransformMatrix(_this.activeCamera.getViewMatrix(), _this.activeCamera.getProjectionMatrix());\r\n }\r\n _this._evaluateActiveMeshes();\r\n _this._activeMeshesFrozen = true;\r\n _this._skipEvaluateActiveMeshesCompletely = skipEvaluateActiveMeshes;\r\n for (var index = 0; index < _this._activeMeshes.length; index++) {\r\n _this._activeMeshes.data[index]._freeze();\r\n }\r\n });\r\n return this;\r\n };\r\n /**\r\n * Use this function to restart evaluating active meshes on every frame\r\n * @returns the current scene\r\n */\r\n Scene.prototype.unfreezeActiveMeshes = function () {\r\n for (var index = 0; index < this.meshes.length; index++) {\r\n var mesh = this.meshes[index];\r\n if (mesh._internalAbstractMeshDataInfo) {\r\n mesh._internalAbstractMeshDataInfo._isActive = false;\r\n }\r\n }\r\n for (var index = 0; index < this._activeMeshes.length; index++) {\r\n this._activeMeshes.data[index]._unFreeze();\r\n }\r\n this._activeMeshesFrozen = false;\r\n return this;\r\n };\r\n Scene.prototype._evaluateActiveMeshes = function () {\r\n if (this._activeMeshesFrozen && this._activeMeshes.length) {\r\n if (!this._skipEvaluateActiveMeshesCompletely) {\r\n var len_1 = this._activeMeshes.length;\r\n for (var i = 0; i < len_1; i++) {\r\n var mesh = this._activeMeshes.data[i];\r\n mesh.computeWorldMatrix();\r\n }\r\n }\r\n return;\r\n }\r\n if (!this.activeCamera) {\r\n return;\r\n }\r\n this.onBeforeActiveMeshesEvaluationObservable.notifyObservers(this);\r\n this.activeCamera._activeMeshes.reset();\r\n this._activeMeshes.reset();\r\n this._renderingManager.reset();\r\n this._processedMaterials.reset();\r\n this._activeParticleSystems.reset();\r\n this._activeSkeletons.reset();\r\n this._softwareSkinnedMeshes.reset();\r\n for (var _i = 0, _a = this._beforeEvaluateActiveMeshStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n step.action();\r\n }\r\n // Determine mesh candidates\r\n var meshes = this.getActiveMeshCandidates();\r\n // Check each mesh\r\n var len = meshes.length;\r\n for (var i = 0; i < len; i++) {\r\n var mesh = meshes.data[i];\r\n if (mesh.isBlocked) {\r\n continue;\r\n }\r\n this._totalVertices.addCount(mesh.getTotalVertices(), false);\r\n if (!mesh.isReady() || !mesh.isEnabled() || mesh.scaling.lengthSquared() === 0) {\r\n continue;\r\n }\r\n mesh.computeWorldMatrix();\r\n // Intersections\r\n if (mesh.actionManager && mesh.actionManager.hasSpecificTriggers2(12, 13)) {\r\n this._meshesForIntersections.pushNoDuplicate(mesh);\r\n }\r\n // Switch to current LOD\r\n var meshToRender = this.customLODSelector ? this.customLODSelector(mesh, this.activeCamera) : mesh.getLOD(this.activeCamera);\r\n if (meshToRender === undefined || meshToRender === null) {\r\n continue;\r\n }\r\n // Compute world matrix if LOD is billboard\r\n if (meshToRender !== mesh && meshToRender.billboardMode !== TransformNode.BILLBOARDMODE_NONE) {\r\n meshToRender.computeWorldMatrix();\r\n }\r\n mesh._preActivate();\r\n if (mesh.isVisible && mesh.visibility > 0 && ((mesh.layerMask & this.activeCamera.layerMask) !== 0) && (this._skipFrustumClipping || mesh.alwaysSelectAsActiveMesh || mesh.isInFrustum(this._frustumPlanes))) {\r\n this._activeMeshes.push(mesh);\r\n this.activeCamera._activeMeshes.push(mesh);\r\n if (meshToRender !== mesh) {\r\n meshToRender._activate(this._renderId, false);\r\n }\r\n if (mesh._activate(this._renderId, false)) {\r\n if (!mesh.isAnInstance) {\r\n meshToRender._internalAbstractMeshDataInfo._onlyForInstances = false;\r\n }\r\n else {\r\n if (mesh._internalAbstractMeshDataInfo._actAsRegularMesh) {\r\n meshToRender = mesh;\r\n }\r\n }\r\n meshToRender._internalAbstractMeshDataInfo._isActive = true;\r\n this._activeMesh(mesh, meshToRender);\r\n }\r\n mesh._postActivate();\r\n }\r\n }\r\n this.onAfterActiveMeshesEvaluationObservable.notifyObservers(this);\r\n // Particle systems\r\n if (this.particlesEnabled) {\r\n this.onBeforeParticlesRenderingObservable.notifyObservers(this);\r\n for (var particleIndex = 0; particleIndex < this.particleSystems.length; particleIndex++) {\r\n var particleSystem = this.particleSystems[particleIndex];\r\n if (!particleSystem.isStarted() || !particleSystem.emitter) {\r\n continue;\r\n }\r\n var emitter = particleSystem.emitter;\r\n if (!emitter.position || emitter.isEnabled()) {\r\n this._activeParticleSystems.push(particleSystem);\r\n particleSystem.animate();\r\n this._renderingManager.dispatchParticles(particleSystem);\r\n }\r\n }\r\n this.onAfterParticlesRenderingObservable.notifyObservers(this);\r\n }\r\n };\r\n Scene.prototype._activeMesh = function (sourceMesh, mesh) {\r\n if (this._skeletonsEnabled && mesh.skeleton !== null && mesh.skeleton !== undefined) {\r\n if (this._activeSkeletons.pushNoDuplicate(mesh.skeleton)) {\r\n mesh.skeleton.prepare();\r\n }\r\n if (!mesh.computeBonesUsingShaders) {\r\n this._softwareSkinnedMeshes.pushNoDuplicate(mesh);\r\n }\r\n }\r\n for (var _i = 0, _a = this._activeMeshStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n step.action(sourceMesh, mesh);\r\n }\r\n if (mesh !== undefined && mesh !== null\r\n && mesh.subMeshes !== undefined && mesh.subMeshes !== null && mesh.subMeshes.length > 0) {\r\n var subMeshes = this.getActiveSubMeshCandidates(mesh);\r\n var len = subMeshes.length;\r\n for (var i = 0; i < len; i++) {\r\n var subMesh = subMeshes.data[i];\r\n this._evaluateSubMesh(subMesh, mesh, sourceMesh);\r\n }\r\n }\r\n };\r\n /**\r\n * Update the transform matrix to update from the current active camera\r\n * @param force defines a boolean used to force the update even if cache is up to date\r\n */\r\n Scene.prototype.updateTransformMatrix = function (force) {\r\n if (!this.activeCamera) {\r\n return;\r\n }\r\n this.setTransformMatrix(this.activeCamera.getViewMatrix(), this.activeCamera.getProjectionMatrix(force));\r\n };\r\n Scene.prototype._bindFrameBuffer = function () {\r\n if (this.activeCamera && this.activeCamera._multiviewTexture) {\r\n this.activeCamera._multiviewTexture._bindFrameBuffer();\r\n }\r\n else if (this.activeCamera && this.activeCamera.outputRenderTarget) {\r\n var useMultiview = this.getEngine().getCaps().multiview && this.activeCamera.outputRenderTarget && this.activeCamera.outputRenderTarget.getViewCount() > 1;\r\n if (useMultiview) {\r\n this.activeCamera.outputRenderTarget._bindFrameBuffer();\r\n }\r\n else {\r\n var internalTexture = this.activeCamera.outputRenderTarget.getInternalTexture();\r\n if (internalTexture) {\r\n this.getEngine().bindFramebuffer(internalTexture);\r\n }\r\n else {\r\n Logger.Error(\"Camera contains invalid customDefaultRenderTarget\");\r\n }\r\n }\r\n }\r\n else {\r\n this.getEngine().restoreDefaultFramebuffer(); // Restore back buffer if needed\r\n }\r\n };\r\n /** @hidden */\r\n Scene.prototype._renderForCamera = function (camera, rigParent) {\r\n if (camera && camera._skipRendering) {\r\n return;\r\n }\r\n var engine = this._engine;\r\n // Use _activeCamera instead of activeCamera to avoid onActiveCameraChanged\r\n this._activeCamera = camera;\r\n if (!this.activeCamera) {\r\n throw new Error(\"Active camera not set\");\r\n }\r\n // Viewport\r\n engine.setViewport(this.activeCamera.viewport);\r\n // Camera\r\n this.resetCachedMaterial();\r\n this._renderId++;\r\n var useMultiview = this.getEngine().getCaps().multiview && camera.outputRenderTarget && camera.outputRenderTarget.getViewCount() > 1;\r\n if (useMultiview) {\r\n this.setTransformMatrix(camera._rigCameras[0].getViewMatrix(), camera._rigCameras[0].getProjectionMatrix(), camera._rigCameras[1].getViewMatrix(), camera._rigCameras[1].getProjectionMatrix());\r\n }\r\n else {\r\n this.updateTransformMatrix();\r\n }\r\n this.onBeforeCameraRenderObservable.notifyObservers(this.activeCamera);\r\n // Meshes\r\n this._evaluateActiveMeshes();\r\n // Software skinning\r\n for (var softwareSkinnedMeshIndex = 0; softwareSkinnedMeshIndex < this._softwareSkinnedMeshes.length; softwareSkinnedMeshIndex++) {\r\n var mesh = this._softwareSkinnedMeshes.data[softwareSkinnedMeshIndex];\r\n mesh.applySkeleton(mesh.skeleton);\r\n }\r\n // Render targets\r\n this.onBeforeRenderTargetsRenderObservable.notifyObservers(this);\r\n if (camera.customRenderTargets && camera.customRenderTargets.length > 0) {\r\n this._renderTargets.concatWithNoDuplicate(camera.customRenderTargets);\r\n }\r\n if (rigParent && rigParent.customRenderTargets && rigParent.customRenderTargets.length > 0) {\r\n this._renderTargets.concatWithNoDuplicate(rigParent.customRenderTargets);\r\n }\r\n // Collects render targets from external components.\r\n for (var _i = 0, _a = this._gatherActiveCameraRenderTargetsStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n step.action(this._renderTargets);\r\n }\r\n if (this.renderTargetsEnabled) {\r\n this._intermediateRendering = true;\r\n var needRebind = false;\r\n if (this._renderTargets.length > 0) {\r\n Tools.StartPerformanceCounter(\"Render targets\", this._renderTargets.length > 0);\r\n for (var renderIndex = 0; renderIndex < this._renderTargets.length; renderIndex++) {\r\n var renderTarget = this._renderTargets.data[renderIndex];\r\n if (renderTarget._shouldRender()) {\r\n this._renderId++;\r\n var hasSpecialRenderTargetCamera = renderTarget.activeCamera && renderTarget.activeCamera !== this.activeCamera;\r\n renderTarget.render(hasSpecialRenderTargetCamera, this.dumpNextRenderTargets);\r\n needRebind = true;\r\n }\r\n }\r\n Tools.EndPerformanceCounter(\"Render targets\", this._renderTargets.length > 0);\r\n this._renderId++;\r\n }\r\n for (var _b = 0, _c = this._cameraDrawRenderTargetStage; _b < _c.length; _b++) {\r\n var step = _c[_b];\r\n needRebind = step.action(this.activeCamera) || needRebind;\r\n }\r\n this._intermediateRendering = false;\r\n // Need to bind if sub-camera has an outputRenderTarget eg. for webXR\r\n if (this.activeCamera && this.activeCamera.outputRenderTarget) {\r\n needRebind = true;\r\n }\r\n // Restore framebuffer after rendering to targets\r\n if (needRebind) {\r\n this._bindFrameBuffer();\r\n }\r\n }\r\n this.onAfterRenderTargetsRenderObservable.notifyObservers(this);\r\n // Prepare Frame\r\n if (this.postProcessManager && !camera._multiviewTexture) {\r\n this.postProcessManager._prepareFrame();\r\n }\r\n // Before Camera Draw\r\n for (var _d = 0, _e = this._beforeCameraDrawStage; _d < _e.length; _d++) {\r\n var step = _e[_d];\r\n step.action(this.activeCamera);\r\n }\r\n // Render\r\n this.onBeforeDrawPhaseObservable.notifyObservers(this);\r\n this._renderingManager.render(null, null, true, true);\r\n this.onAfterDrawPhaseObservable.notifyObservers(this);\r\n // After Camera Draw\r\n for (var _f = 0, _g = this._afterCameraDrawStage; _f < _g.length; _f++) {\r\n var step = _g[_f];\r\n step.action(this.activeCamera);\r\n }\r\n // Finalize frame\r\n if (this.postProcessManager && !camera._multiviewTexture) {\r\n this.postProcessManager._finalizeFrame(camera.isIntermediate);\r\n }\r\n // Reset some special arrays\r\n this._renderTargets.reset();\r\n this.onAfterCameraRenderObservable.notifyObservers(this.activeCamera);\r\n };\r\n Scene.prototype._processSubCameras = function (camera) {\r\n if (camera.cameraRigMode === Camera.RIG_MODE_NONE || (camera.outputRenderTarget && camera.outputRenderTarget.getViewCount() > 1 && this.getEngine().getCaps().multiview)) {\r\n this._renderForCamera(camera);\r\n this.onAfterRenderCameraObservable.notifyObservers(camera);\r\n return;\r\n }\r\n if (camera._useMultiviewToSingleView) {\r\n this._renderMultiviewToSingleView(camera);\r\n }\r\n else {\r\n // rig cameras\r\n for (var index = 0; index < camera._rigCameras.length; index++) {\r\n this._renderForCamera(camera._rigCameras[index], camera);\r\n }\r\n }\r\n // Use _activeCamera instead of activeCamera to avoid onActiveCameraChanged\r\n this._activeCamera = camera;\r\n this.setTransformMatrix(this._activeCamera.getViewMatrix(), this._activeCamera.getProjectionMatrix());\r\n this.onAfterRenderCameraObservable.notifyObservers(camera);\r\n };\r\n Scene.prototype._checkIntersections = function () {\r\n for (var index = 0; index < this._meshesForIntersections.length; index++) {\r\n var sourceMesh = this._meshesForIntersections.data[index];\r\n if (!sourceMesh.actionManager) {\r\n continue;\r\n }\r\n for (var actionIndex = 0; sourceMesh.actionManager && actionIndex < sourceMesh.actionManager.actions.length; actionIndex++) {\r\n var action = sourceMesh.actionManager.actions[actionIndex];\r\n if (action.trigger === 12 || action.trigger === 13) {\r\n var parameters = action.getTriggerParameter();\r\n var otherMesh = parameters instanceof AbstractMesh ? parameters : parameters.mesh;\r\n var areIntersecting = otherMesh.intersectsMesh(sourceMesh, parameters.usePreciseIntersection);\r\n var currentIntersectionInProgress = sourceMesh._intersectionsInProgress.indexOf(otherMesh);\r\n if (areIntersecting && currentIntersectionInProgress === -1) {\r\n if (action.trigger === 12) {\r\n action._executeCurrent(ActionEvent.CreateNew(sourceMesh, undefined, otherMesh));\r\n sourceMesh._intersectionsInProgress.push(otherMesh);\r\n }\r\n else if (action.trigger === 13) {\r\n sourceMesh._intersectionsInProgress.push(otherMesh);\r\n }\r\n }\r\n else if (!areIntersecting && currentIntersectionInProgress > -1) {\r\n //They intersected, and now they don't.\r\n //is this trigger an exit trigger? execute an event.\r\n if (action.trigger === 13) {\r\n action._executeCurrent(ActionEvent.CreateNew(sourceMesh, undefined, otherMesh));\r\n }\r\n //if this is an exit trigger, or no exit trigger exists, remove the id from the intersection in progress array.\r\n if (!sourceMesh.actionManager.hasSpecificTrigger(13, function (parameter) {\r\n var parameterMesh = parameter instanceof AbstractMesh ? parameter : parameter.mesh;\r\n return otherMesh === parameterMesh;\r\n }) || action.trigger === 13) {\r\n sourceMesh._intersectionsInProgress.splice(currentIntersectionInProgress, 1);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n Scene.prototype._advancePhysicsEngineStep = function (step) {\r\n // Do nothing. Code will be replaced if physics engine component is referenced\r\n };\r\n /** @hidden */\r\n Scene.prototype._animate = function () {\r\n // Nothing to do as long as Animatable have not been imported.\r\n };\r\n /** Execute all animations (for a frame) */\r\n Scene.prototype.animate = function () {\r\n if (this._engine.isDeterministicLockStep()) {\r\n var deltaTime = Math.max(Scene.MinDeltaTime, Math.min(this._engine.getDeltaTime(), Scene.MaxDeltaTime)) + this._timeAccumulator;\r\n var defaultFrameTime = this._engine.getTimeStep();\r\n var defaultFPS = (1000.0 / defaultFrameTime) / 1000.0;\r\n var stepsTaken = 0;\r\n var maxSubSteps = this._engine.getLockstepMaxSteps();\r\n var internalSteps = Math.floor(deltaTime / defaultFrameTime);\r\n internalSteps = Math.min(internalSteps, maxSubSteps);\r\n while (deltaTime > 0 && stepsTaken < internalSteps) {\r\n this.onBeforeStepObservable.notifyObservers(this);\r\n // Animations\r\n this._animationRatio = defaultFrameTime * defaultFPS;\r\n this._animate();\r\n this.onAfterAnimationsObservable.notifyObservers(this);\r\n // Physics\r\n this._advancePhysicsEngineStep(defaultFrameTime);\r\n this.onAfterStepObservable.notifyObservers(this);\r\n this._currentStepId++;\r\n stepsTaken++;\r\n deltaTime -= defaultFrameTime;\r\n }\r\n this._timeAccumulator = deltaTime < 0 ? 0 : deltaTime;\r\n }\r\n else {\r\n // Animations\r\n var deltaTime = this.useConstantAnimationDeltaTime ? 16 : Math.max(Scene.MinDeltaTime, Math.min(this._engine.getDeltaTime(), Scene.MaxDeltaTime));\r\n this._animationRatio = deltaTime * (60.0 / 1000.0);\r\n this._animate();\r\n this.onAfterAnimationsObservable.notifyObservers(this);\r\n // Physics\r\n this._advancePhysicsEngineStep(deltaTime);\r\n }\r\n };\r\n /**\r\n * Render the scene\r\n * @param updateCameras defines a boolean indicating if cameras must update according to their inputs (true by default)\r\n * @param ignoreAnimations defines a boolean indicating if animations should not be executed (false by default)\r\n */\r\n Scene.prototype.render = function (updateCameras, ignoreAnimations) {\r\n if (updateCameras === void 0) { updateCameras = true; }\r\n if (ignoreAnimations === void 0) { ignoreAnimations = false; }\r\n if (this.isDisposed) {\r\n return;\r\n }\r\n this._frameId++;\r\n // Register components that have been associated lately to the scene.\r\n this._registerTransientComponents();\r\n this._activeParticles.fetchNewFrame();\r\n this._totalVertices.fetchNewFrame();\r\n this._activeIndices.fetchNewFrame();\r\n this._activeBones.fetchNewFrame();\r\n this._meshesForIntersections.reset();\r\n this.resetCachedMaterial();\r\n this.onBeforeAnimationsObservable.notifyObservers(this);\r\n // Actions\r\n if (this.actionManager) {\r\n this.actionManager.processTrigger(11);\r\n }\r\n // Animations\r\n if (!ignoreAnimations) {\r\n this.animate();\r\n }\r\n // Before camera update steps\r\n for (var _i = 0, _a = this._beforeCameraUpdateStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n step.action();\r\n }\r\n // Update Cameras\r\n if (updateCameras) {\r\n if (this.activeCameras.length > 0) {\r\n for (var cameraIndex = 0; cameraIndex < this.activeCameras.length; cameraIndex++) {\r\n var camera = this.activeCameras[cameraIndex];\r\n camera.update();\r\n if (camera.cameraRigMode !== Camera.RIG_MODE_NONE) {\r\n // rig cameras\r\n for (var index = 0; index < camera._rigCameras.length; index++) {\r\n camera._rigCameras[index].update();\r\n }\r\n }\r\n }\r\n }\r\n else if (this.activeCamera) {\r\n this.activeCamera.update();\r\n if (this.activeCamera.cameraRigMode !== Camera.RIG_MODE_NONE) {\r\n // rig cameras\r\n for (var index = 0; index < this.activeCamera._rigCameras.length; index++) {\r\n this.activeCamera._rigCameras[index].update();\r\n }\r\n }\r\n }\r\n }\r\n // Before render\r\n this.onBeforeRenderObservable.notifyObservers(this);\r\n // Customs render targets\r\n this.onBeforeRenderTargetsRenderObservable.notifyObservers(this);\r\n var engine = this.getEngine();\r\n var currentActiveCamera = this.activeCamera;\r\n if (this.renderTargetsEnabled) {\r\n Tools.StartPerformanceCounter(\"Custom render targets\", this.customRenderTargets.length > 0);\r\n this._intermediateRendering = true;\r\n for (var customIndex = 0; customIndex < this.customRenderTargets.length; customIndex++) {\r\n var renderTarget = this.customRenderTargets[customIndex];\r\n if (renderTarget._shouldRender()) {\r\n this._renderId++;\r\n this.activeCamera = renderTarget.activeCamera || this.activeCamera;\r\n if (!this.activeCamera) {\r\n throw new Error(\"Active camera not set\");\r\n }\r\n // Viewport\r\n engine.setViewport(this.activeCamera.viewport);\r\n // Camera\r\n this.updateTransformMatrix();\r\n renderTarget.render(currentActiveCamera !== this.activeCamera, this.dumpNextRenderTargets);\r\n }\r\n }\r\n Tools.EndPerformanceCounter(\"Custom render targets\", this.customRenderTargets.length > 0);\r\n this._intermediateRendering = false;\r\n this._renderId++;\r\n }\r\n // Restore back buffer\r\n this.activeCamera = currentActiveCamera;\r\n this._bindFrameBuffer();\r\n this.onAfterRenderTargetsRenderObservable.notifyObservers(this);\r\n for (var _b = 0, _c = this._beforeClearStage; _b < _c.length; _b++) {\r\n var step = _c[_b];\r\n step.action();\r\n }\r\n // Clear\r\n if (this.autoClearDepthAndStencil || this.autoClear) {\r\n this._engine.clear(this.clearColor, this.autoClear || this.forceWireframe || this.forcePointsCloud, this.autoClearDepthAndStencil, this.autoClearDepthAndStencil);\r\n }\r\n // Collects render targets from external components.\r\n for (var _d = 0, _e = this._gatherRenderTargetsStage; _d < _e.length; _d++) {\r\n var step = _e[_d];\r\n step.action(this._renderTargets);\r\n }\r\n // Multi-cameras?\r\n if (this.activeCameras.length > 0) {\r\n for (var cameraIndex = 0; cameraIndex < this.activeCameras.length; cameraIndex++) {\r\n if (cameraIndex > 0) {\r\n this._engine.clear(null, false, true, true);\r\n }\r\n this._processSubCameras(this.activeCameras[cameraIndex]);\r\n }\r\n }\r\n else {\r\n if (!this.activeCamera) {\r\n throw new Error(\"No camera defined\");\r\n }\r\n this._processSubCameras(this.activeCamera);\r\n }\r\n // Intersection checks\r\n this._checkIntersections();\r\n // Executes the after render stage actions.\r\n for (var _f = 0, _g = this._afterRenderStage; _f < _g.length; _f++) {\r\n var step = _g[_f];\r\n step.action();\r\n }\r\n // After render\r\n if (this.afterRender) {\r\n this.afterRender();\r\n }\r\n this.onAfterRenderObservable.notifyObservers(this);\r\n // Cleaning\r\n if (this._toBeDisposed.length) {\r\n for (var index = 0; index < this._toBeDisposed.length; index++) {\r\n var data = this._toBeDisposed[index];\r\n if (data) {\r\n data.dispose();\r\n }\r\n }\r\n this._toBeDisposed = [];\r\n }\r\n if (this.dumpNextRenderTargets) {\r\n this.dumpNextRenderTargets = false;\r\n }\r\n this._activeBones.addCount(0, true);\r\n this._activeIndices.addCount(0, true);\r\n this._activeParticles.addCount(0, true);\r\n };\r\n /**\r\n * Freeze all materials\r\n * A frozen material will not be updatable but should be faster to render\r\n */\r\n Scene.prototype.freezeMaterials = function () {\r\n for (var i = 0; i < this.materials.length; i++) {\r\n this.materials[i].freeze();\r\n }\r\n };\r\n /**\r\n * Unfreeze all materials\r\n * A frozen material will not be updatable but should be faster to render\r\n */\r\n Scene.prototype.unfreezeMaterials = function () {\r\n for (var i = 0; i < this.materials.length; i++) {\r\n this.materials[i].unfreeze();\r\n }\r\n };\r\n /**\r\n * Releases all held ressources\r\n */\r\n Scene.prototype.dispose = function () {\r\n this.beforeRender = null;\r\n this.afterRender = null;\r\n if (EngineStore._LastCreatedScene === this) {\r\n EngineStore._LastCreatedScene = null;\r\n }\r\n this.skeletons = [];\r\n this.morphTargetManagers = [];\r\n this._transientComponents = [];\r\n this._isReadyForMeshStage.clear();\r\n this._beforeEvaluateActiveMeshStage.clear();\r\n this._evaluateSubMeshStage.clear();\r\n this._activeMeshStage.clear();\r\n this._cameraDrawRenderTargetStage.clear();\r\n this._beforeCameraDrawStage.clear();\r\n this._beforeRenderTargetDrawStage.clear();\r\n this._beforeRenderingGroupDrawStage.clear();\r\n this._beforeRenderingMeshStage.clear();\r\n this._afterRenderingMeshStage.clear();\r\n this._afterRenderingGroupDrawStage.clear();\r\n this._afterCameraDrawStage.clear();\r\n this._afterRenderTargetDrawStage.clear();\r\n this._afterRenderStage.clear();\r\n this._beforeCameraUpdateStage.clear();\r\n this._beforeClearStage.clear();\r\n this._gatherRenderTargetsStage.clear();\r\n this._gatherActiveCameraRenderTargetsStage.clear();\r\n this._pointerMoveStage.clear();\r\n this._pointerDownStage.clear();\r\n this._pointerUpStage.clear();\r\n for (var _i = 0, _a = this._components; _i < _a.length; _i++) {\r\n var component = _a[_i];\r\n component.dispose();\r\n }\r\n this.importedMeshesFiles = new Array();\r\n if (this.stopAllAnimations) {\r\n this.stopAllAnimations();\r\n }\r\n this.resetCachedMaterial();\r\n // Smart arrays\r\n if (this.activeCamera) {\r\n this.activeCamera._activeMeshes.dispose();\r\n this.activeCamera = null;\r\n }\r\n this._activeMeshes.dispose();\r\n this._renderingManager.dispose();\r\n this._processedMaterials.dispose();\r\n this._activeParticleSystems.dispose();\r\n this._activeSkeletons.dispose();\r\n this._softwareSkinnedMeshes.dispose();\r\n this._renderTargets.dispose();\r\n this._registeredForLateAnimationBindings.dispose();\r\n this._meshesForIntersections.dispose();\r\n this._toBeDisposed = [];\r\n // Abort active requests\r\n for (var _b = 0, _c = this._activeRequests; _b < _c.length; _b++) {\r\n var request = _c[_b];\r\n request.abort();\r\n }\r\n // Events\r\n this.onDisposeObservable.notifyObservers(this);\r\n this.onDisposeObservable.clear();\r\n this.onBeforeRenderObservable.clear();\r\n this.onAfterRenderObservable.clear();\r\n this.onBeforeRenderTargetsRenderObservable.clear();\r\n this.onAfterRenderTargetsRenderObservable.clear();\r\n this.onAfterStepObservable.clear();\r\n this.onBeforeStepObservable.clear();\r\n this.onBeforeActiveMeshesEvaluationObservable.clear();\r\n this.onAfterActiveMeshesEvaluationObservable.clear();\r\n this.onBeforeParticlesRenderingObservable.clear();\r\n this.onAfterParticlesRenderingObservable.clear();\r\n this.onBeforeDrawPhaseObservable.clear();\r\n this.onAfterDrawPhaseObservable.clear();\r\n this.onBeforeAnimationsObservable.clear();\r\n this.onAfterAnimationsObservable.clear();\r\n this.onDataLoadedObservable.clear();\r\n this.onBeforeRenderingGroupObservable.clear();\r\n this.onAfterRenderingGroupObservable.clear();\r\n this.onMeshImportedObservable.clear();\r\n this.onBeforeCameraRenderObservable.clear();\r\n this.onAfterCameraRenderObservable.clear();\r\n this.onReadyObservable.clear();\r\n this.onNewCameraAddedObservable.clear();\r\n this.onCameraRemovedObservable.clear();\r\n this.onNewLightAddedObservable.clear();\r\n this.onLightRemovedObservable.clear();\r\n this.onNewGeometryAddedObservable.clear();\r\n this.onGeometryRemovedObservable.clear();\r\n this.onNewTransformNodeAddedObservable.clear();\r\n this.onTransformNodeRemovedObservable.clear();\r\n this.onNewMeshAddedObservable.clear();\r\n this.onMeshRemovedObservable.clear();\r\n this.onNewSkeletonAddedObservable.clear();\r\n this.onSkeletonRemovedObservable.clear();\r\n this.onNewMaterialAddedObservable.clear();\r\n this.onMaterialRemovedObservable.clear();\r\n this.onNewTextureAddedObservable.clear();\r\n this.onTextureRemovedObservable.clear();\r\n this.onPrePointerObservable.clear();\r\n this.onPointerObservable.clear();\r\n this.onPreKeyboardObservable.clear();\r\n this.onKeyboardObservable.clear();\r\n this.onActiveCameraChanged.clear();\r\n this.detachControl();\r\n // Detach cameras\r\n var canvas = this._engine.getInputElement();\r\n if (canvas) {\r\n var index;\r\n for (index = 0; index < this.cameras.length; index++) {\r\n this.cameras[index].detachControl(canvas);\r\n }\r\n }\r\n // Release animation groups\r\n while (this.animationGroups.length) {\r\n this.animationGroups[0].dispose();\r\n }\r\n // Release lights\r\n while (this.lights.length) {\r\n this.lights[0].dispose();\r\n }\r\n // Release meshes\r\n while (this.meshes.length) {\r\n this.meshes[0].dispose(true);\r\n }\r\n while (this.transformNodes.length) {\r\n this.transformNodes[0].dispose(true);\r\n }\r\n // Release cameras\r\n while (this.cameras.length) {\r\n this.cameras[0].dispose();\r\n }\r\n // Release materials\r\n if (this._defaultMaterial) {\r\n this._defaultMaterial.dispose();\r\n }\r\n while (this.multiMaterials.length) {\r\n this.multiMaterials[0].dispose();\r\n }\r\n while (this.materials.length) {\r\n this.materials[0].dispose();\r\n }\r\n // Release particles\r\n while (this.particleSystems.length) {\r\n this.particleSystems[0].dispose();\r\n }\r\n // Release postProcesses\r\n while (this.postProcesses.length) {\r\n this.postProcesses[0].dispose();\r\n }\r\n // Release textures\r\n while (this.textures.length) {\r\n this.textures[0].dispose();\r\n }\r\n // Release UBO\r\n this._sceneUbo.dispose();\r\n if (this._multiviewSceneUbo) {\r\n this._multiviewSceneUbo.dispose();\r\n }\r\n // Post-processes\r\n this.postProcessManager.dispose();\r\n // Remove from engine\r\n index = this._engine.scenes.indexOf(this);\r\n if (index > -1) {\r\n this._engine.scenes.splice(index, 1);\r\n }\r\n this._engine.wipeCaches(true);\r\n this._isDisposed = true;\r\n };\r\n Object.defineProperty(Scene.prototype, \"isDisposed\", {\r\n /**\r\n * Gets if the scene is already disposed\r\n */\r\n get: function () {\r\n return this._isDisposed;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Call this function to reduce memory footprint of the scene.\r\n * Vertex buffers will not store CPU data anymore (this will prevent picking, collisions or physics to work correctly)\r\n */\r\n Scene.prototype.clearCachedVertexData = function () {\r\n for (var meshIndex = 0; meshIndex < this.meshes.length; meshIndex++) {\r\n var mesh = this.meshes[meshIndex];\r\n var geometry = mesh.geometry;\r\n if (geometry) {\r\n geometry._indices = [];\r\n for (var vbName in geometry._vertexBuffers) {\r\n if (!geometry._vertexBuffers.hasOwnProperty(vbName)) {\r\n continue;\r\n }\r\n geometry._vertexBuffers[vbName]._buffer._data = null;\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * This function will remove the local cached buffer data from texture.\r\n * It will save memory but will prevent the texture from being rebuilt\r\n */\r\n Scene.prototype.cleanCachedTextureBuffer = function () {\r\n for (var _i = 0, _a = this.textures; _i < _a.length; _i++) {\r\n var baseTexture = _a[_i];\r\n var buffer = baseTexture._buffer;\r\n if (buffer) {\r\n baseTexture._buffer = null;\r\n }\r\n }\r\n };\r\n /**\r\n * Get the world extend vectors with an optional filter\r\n *\r\n * @param filterPredicate the predicate - which meshes should be included when calculating the world size\r\n * @returns {{ min: Vector3; max: Vector3 }} min and max vectors\r\n */\r\n Scene.prototype.getWorldExtends = function (filterPredicate) {\r\n var min = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n var max = new Vector3(-Number.MAX_VALUE, -Number.MAX_VALUE, -Number.MAX_VALUE);\r\n filterPredicate = filterPredicate || (function () { return true; });\r\n this.meshes.filter(filterPredicate).forEach(function (mesh) {\r\n mesh.computeWorldMatrix(true);\r\n if (!mesh.subMeshes || mesh.subMeshes.length === 0 || mesh.infiniteDistance) {\r\n return;\r\n }\r\n var boundingInfo = mesh.getBoundingInfo();\r\n var minBox = boundingInfo.boundingBox.minimumWorld;\r\n var maxBox = boundingInfo.boundingBox.maximumWorld;\r\n Vector3.CheckExtends(minBox, min, max);\r\n Vector3.CheckExtends(maxBox, min, max);\r\n });\r\n return {\r\n min: min,\r\n max: max\r\n };\r\n };\r\n // Picking\r\n /**\r\n * Creates a ray that can be used to pick in the scene\r\n * @param x defines the x coordinate of the origin (on-screen)\r\n * @param y defines the y coordinate of the origin (on-screen)\r\n * @param world defines the world matrix to use if you want to pick in object space (instead of world space)\r\n * @param camera defines the camera to use for the picking\r\n * @param cameraViewSpace defines if picking will be done in view space (false by default)\r\n * @returns a Ray\r\n */\r\n Scene.prototype.createPickingRay = function (x, y, world, camera, cameraViewSpace) {\r\n if (cameraViewSpace === void 0) { cameraViewSpace = false; }\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /**\r\n * Creates a ray that can be used to pick in the scene\r\n * @param x defines the x coordinate of the origin (on-screen)\r\n * @param y defines the y coordinate of the origin (on-screen)\r\n * @param world defines the world matrix to use if you want to pick in object space (instead of world space)\r\n * @param result defines the ray where to store the picking ray\r\n * @param camera defines the camera to use for the picking\r\n * @param cameraViewSpace defines if picking will be done in view space (false by default)\r\n * @returns the current scene\r\n */\r\n Scene.prototype.createPickingRayToRef = function (x, y, world, result, camera, cameraViewSpace) {\r\n if (cameraViewSpace === void 0) { cameraViewSpace = false; }\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /**\r\n * Creates a ray that can be used to pick in the scene\r\n * @param x defines the x coordinate of the origin (on-screen)\r\n * @param y defines the y coordinate of the origin (on-screen)\r\n * @param camera defines the camera to use for the picking\r\n * @returns a Ray\r\n */\r\n Scene.prototype.createPickingRayInCameraSpace = function (x, y, camera) {\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /**\r\n * Creates a ray that can be used to pick in the scene\r\n * @param x defines the x coordinate of the origin (on-screen)\r\n * @param y defines the y coordinate of the origin (on-screen)\r\n * @param result defines the ray where to store the picking ray\r\n * @param camera defines the camera to use for the picking\r\n * @returns the current scene\r\n */\r\n Scene.prototype.createPickingRayInCameraSpaceToRef = function (x, y, result, camera) {\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /** Launch a ray to try to pick a mesh in the scene\r\n * @param x position on screen\r\n * @param y position on screen\r\n * @param predicate Predicate function used to determine eligible meshes. Can be set to null. In this case, a mesh must be enabled, visible and with isPickable set to true\r\n * @param fastCheck Launch a fast check only using the bounding boxes. Can be set to null.\r\n * @param camera to use for computing the picking ray. Can be set to null. In this case, the scene.activeCamera will be used\r\n * @param trianglePredicate defines an optional predicate used to select faces when a mesh intersection is detected\r\n * @returns a PickingInfo\r\n */\r\n Scene.prototype.pick = function (x, y, predicate, fastCheck, camera, trianglePredicate) {\r\n // Dummy info if picking as not been imported\r\n var pi = new PickingInfo();\r\n pi._pickingUnavailable = true;\r\n return pi;\r\n };\r\n /** Use the given ray to pick a mesh in the scene\r\n * @param ray The ray to use to pick meshes\r\n * @param predicate Predicate function used to determine eligible meshes. Can be set to null. In this case, a mesh must have isPickable set to true\r\n * @param fastCheck Launch a fast check only using the bounding boxes. Can be set to null\r\n * @param trianglePredicate defines an optional predicate used to select faces when a mesh intersection is detected\r\n * @returns a PickingInfo\r\n */\r\n Scene.prototype.pickWithRay = function (ray, predicate, fastCheck, trianglePredicate) {\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /**\r\n * Launch a ray to try to pick a mesh in the scene\r\n * @param x X position on screen\r\n * @param y Y position on screen\r\n * @param predicate Predicate function used to determine eligible meshes. Can be set to null. In this case, a mesh must be enabled, visible and with isPickable set to true\r\n * @param camera camera to use for computing the picking ray. Can be set to null. In this case, the scene.activeCamera will be used\r\n * @param trianglePredicate defines an optional predicate used to select faces when a mesh intersection is detected\r\n * @returns an array of PickingInfo\r\n */\r\n Scene.prototype.multiPick = function (x, y, predicate, camera, trianglePredicate) {\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /**\r\n * Launch a ray to try to pick a mesh in the scene\r\n * @param ray Ray to use\r\n * @param predicate Predicate function used to determine eligible meshes. Can be set to null. In this case, a mesh must be enabled, visible and with isPickable set to true\r\n * @param trianglePredicate defines an optional predicate used to select faces when a mesh intersection is detected\r\n * @returns an array of PickingInfo\r\n */\r\n Scene.prototype.multiPickWithRay = function (ray, predicate, trianglePredicate) {\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /**\r\n * Force the value of meshUnderPointer\r\n * @param mesh defines the mesh to use\r\n */\r\n Scene.prototype.setPointerOverMesh = function (mesh) {\r\n this._inputManager.setPointerOverMesh(mesh);\r\n };\r\n /**\r\n * Gets the mesh under the pointer\r\n * @returns a Mesh or null if no mesh is under the pointer\r\n */\r\n Scene.prototype.getPointerOverMesh = function () {\r\n return this._inputManager.getPointerOverMesh();\r\n };\r\n // Misc.\r\n /** @hidden */\r\n Scene.prototype._rebuildGeometries = function () {\r\n for (var _i = 0, _a = this.geometries; _i < _a.length; _i++) {\r\n var geometry = _a[_i];\r\n geometry._rebuild();\r\n }\r\n for (var _b = 0, _c = this.meshes; _b < _c.length; _b++) {\r\n var mesh = _c[_b];\r\n mesh._rebuild();\r\n }\r\n if (this.postProcessManager) {\r\n this.postProcessManager._rebuild();\r\n }\r\n for (var _d = 0, _e = this._components; _d < _e.length; _d++) {\r\n var component = _e[_d];\r\n component.rebuild();\r\n }\r\n for (var _f = 0, _g = this.particleSystems; _f < _g.length; _f++) {\r\n var system = _g[_f];\r\n system.rebuild();\r\n }\r\n };\r\n /** @hidden */\r\n Scene.prototype._rebuildTextures = function () {\r\n for (var _i = 0, _a = this.textures; _i < _a.length; _i++) {\r\n var texture = _a[_i];\r\n texture._rebuild();\r\n }\r\n this.markAllMaterialsAsDirty(1);\r\n };\r\n // Tags\r\n Scene.prototype._getByTags = function (list, tagsQuery, forEach) {\r\n if (tagsQuery === undefined) {\r\n // returns the complete list (could be done with Tags.MatchesQuery but no need to have a for-loop here)\r\n return list;\r\n }\r\n var listByTags = [];\r\n forEach = forEach || (function (item) { return; });\r\n for (var i in list) {\r\n var item = list[i];\r\n if (Tags && Tags.MatchesQuery(item, tagsQuery)) {\r\n listByTags.push(item);\r\n forEach(item);\r\n }\r\n }\r\n return listByTags;\r\n };\r\n /**\r\n * Get a list of meshes by tags\r\n * @param tagsQuery defines the tags query to use\r\n * @param forEach defines a predicate used to filter results\r\n * @returns an array of Mesh\r\n */\r\n Scene.prototype.getMeshesByTags = function (tagsQuery, forEach) {\r\n return this._getByTags(this.meshes, tagsQuery, forEach);\r\n };\r\n /**\r\n * Get a list of cameras by tags\r\n * @param tagsQuery defines the tags query to use\r\n * @param forEach defines a predicate used to filter results\r\n * @returns an array of Camera\r\n */\r\n Scene.prototype.getCamerasByTags = function (tagsQuery, forEach) {\r\n return this._getByTags(this.cameras, tagsQuery, forEach);\r\n };\r\n /**\r\n * Get a list of lights by tags\r\n * @param tagsQuery defines the tags query to use\r\n * @param forEach defines a predicate used to filter results\r\n * @returns an array of Light\r\n */\r\n Scene.prototype.getLightsByTags = function (tagsQuery, forEach) {\r\n return this._getByTags(this.lights, tagsQuery, forEach);\r\n };\r\n /**\r\n * Get a list of materials by tags\r\n * @param tagsQuery defines the tags query to use\r\n * @param forEach defines a predicate used to filter results\r\n * @returns an array of Material\r\n */\r\n Scene.prototype.getMaterialByTags = function (tagsQuery, forEach) {\r\n return this._getByTags(this.materials, tagsQuery, forEach).concat(this._getByTags(this.multiMaterials, tagsQuery, forEach));\r\n };\r\n /**\r\n * Overrides the default sort function applied in the renderging group to prepare the meshes.\r\n * This allowed control for front to back rendering or reversly depending of the special needs.\r\n *\r\n * @param renderingGroupId The rendering group id corresponding to its index\r\n * @param opaqueSortCompareFn The opaque queue comparison function use to sort.\r\n * @param alphaTestSortCompareFn The alpha test queue comparison function use to sort.\r\n * @param transparentSortCompareFn The transparent queue comparison function use to sort.\r\n */\r\n Scene.prototype.setRenderingOrder = function (renderingGroupId, opaqueSortCompareFn, alphaTestSortCompareFn, transparentSortCompareFn) {\r\n if (opaqueSortCompareFn === void 0) { opaqueSortCompareFn = null; }\r\n if (alphaTestSortCompareFn === void 0) { alphaTestSortCompareFn = null; }\r\n if (transparentSortCompareFn === void 0) { transparentSortCompareFn = null; }\r\n this._renderingManager.setRenderingOrder(renderingGroupId, opaqueSortCompareFn, alphaTestSortCompareFn, transparentSortCompareFn);\r\n };\r\n /**\r\n * Specifies whether or not the stencil and depth buffer are cleared between two rendering groups.\r\n *\r\n * @param renderingGroupId The rendering group id corresponding to its index\r\n * @param autoClearDepthStencil Automatically clears depth and stencil between groups if true.\r\n * @param depth Automatically clears depth between groups if true and autoClear is true.\r\n * @param stencil Automatically clears stencil between groups if true and autoClear is true.\r\n */\r\n Scene.prototype.setRenderingAutoClearDepthStencil = function (renderingGroupId, autoClearDepthStencil, depth, stencil) {\r\n if (depth === void 0) { depth = true; }\r\n if (stencil === void 0) { stencil = true; }\r\n this._renderingManager.setRenderingAutoClearDepthStencil(renderingGroupId, autoClearDepthStencil, depth, stencil);\r\n };\r\n /**\r\n * Gets the current auto clear configuration for one rendering group of the rendering\r\n * manager.\r\n * @param index the rendering group index to get the information for\r\n * @returns The auto clear setup for the requested rendering group\r\n */\r\n Scene.prototype.getAutoClearDepthStencilSetup = function (index) {\r\n return this._renderingManager.getAutoClearDepthStencilSetup(index);\r\n };\r\n Object.defineProperty(Scene.prototype, \"blockMaterialDirtyMechanism\", {\r\n /** Gets or sets a boolean blocking all the calls to markAllMaterialsAsDirty (ie. the materials won't be updated if they are out of sync) */\r\n get: function () {\r\n return this._blockMaterialDirtyMechanism;\r\n },\r\n set: function (value) {\r\n if (this._blockMaterialDirtyMechanism === value) {\r\n return;\r\n }\r\n this._blockMaterialDirtyMechanism = value;\r\n if (!value) { // Do a complete update\r\n this.markAllMaterialsAsDirty(31);\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Will flag all materials as dirty to trigger new shader compilation\r\n * @param flag defines the flag used to specify which material part must be marked as dirty\r\n * @param predicate If not null, it will be used to specifiy if a material has to be marked as dirty\r\n */\r\n Scene.prototype.markAllMaterialsAsDirty = function (flag, predicate) {\r\n if (this._blockMaterialDirtyMechanism) {\r\n return;\r\n }\r\n for (var _i = 0, _a = this.materials; _i < _a.length; _i++) {\r\n var material = _a[_i];\r\n if (predicate && !predicate(material)) {\r\n continue;\r\n }\r\n material.markAsDirty(flag);\r\n }\r\n };\r\n /** @hidden */\r\n Scene.prototype._loadFile = function (url, onSuccess, onProgress, useOfflineSupport, useArrayBuffer, onError) {\r\n var _this = this;\r\n var request = FileTools.LoadFile(url, onSuccess, onProgress, useOfflineSupport ? this.offlineProvider : undefined, useArrayBuffer, onError);\r\n this._activeRequests.push(request);\r\n request.onCompleteObservable.add(function (request) {\r\n _this._activeRequests.splice(_this._activeRequests.indexOf(request), 1);\r\n });\r\n return request;\r\n };\r\n /** @hidden */\r\n Scene.prototype._loadFileAsync = function (url, onProgress, useOfflineSupport, useArrayBuffer) {\r\n var _this = this;\r\n return new Promise(function (resolve, reject) {\r\n _this._loadFile(url, function (data) {\r\n resolve(data);\r\n }, onProgress, useOfflineSupport, useArrayBuffer, function (request, exception) {\r\n reject(exception);\r\n });\r\n });\r\n };\r\n /** @hidden */\r\n Scene.prototype._requestFile = function (url, onSuccess, onProgress, useOfflineSupport, useArrayBuffer, onError, onOpened) {\r\n var _this = this;\r\n var request = FileTools.RequestFile(url, onSuccess, onProgress, useOfflineSupport ? this.offlineProvider : undefined, useArrayBuffer, onError, onOpened);\r\n this._activeRequests.push(request);\r\n request.onCompleteObservable.add(function (request) {\r\n _this._activeRequests.splice(_this._activeRequests.indexOf(request), 1);\r\n });\r\n return request;\r\n };\r\n /** @hidden */\r\n Scene.prototype._requestFileAsync = function (url, onProgress, useOfflineSupport, useArrayBuffer, onOpened) {\r\n var _this = this;\r\n return new Promise(function (resolve, reject) {\r\n _this._requestFile(url, function (data) {\r\n resolve(data);\r\n }, onProgress, useOfflineSupport, useArrayBuffer, function (error) {\r\n reject(error);\r\n }, onOpened);\r\n });\r\n };\r\n /** @hidden */\r\n Scene.prototype._readFile = function (file, onSuccess, onProgress, useArrayBuffer, onError) {\r\n var _this = this;\r\n var request = FileTools.ReadFile(file, onSuccess, onProgress, useArrayBuffer, onError);\r\n this._activeRequests.push(request);\r\n request.onCompleteObservable.add(function (request) {\r\n _this._activeRequests.splice(_this._activeRequests.indexOf(request), 1);\r\n });\r\n return request;\r\n };\r\n /** @hidden */\r\n Scene.prototype._readFileAsync = function (file, onProgress, useArrayBuffer) {\r\n var _this = this;\r\n return new Promise(function (resolve, reject) {\r\n _this._readFile(file, function (data) {\r\n resolve(data);\r\n }, onProgress, useArrayBuffer, function (error) {\r\n reject(error);\r\n });\r\n });\r\n };\r\n /** The fog is deactivated */\r\n Scene.FOGMODE_NONE = 0;\r\n /** The fog density is following an exponential function */\r\n Scene.FOGMODE_EXP = 1;\r\n /** The fog density is following an exponential function faster than FOGMODE_EXP */\r\n Scene.FOGMODE_EXP2 = 2;\r\n /** The fog density is following a linear function. */\r\n Scene.FOGMODE_LINEAR = 3;\r\n /**\r\n * Gets or sets the minimum deltatime when deterministic lock step is enabled\r\n * @see http://doc.babylonjs.com/babylon101/animations#deterministic-lockstep\r\n */\r\n Scene.MinDeltaTime = 1.0;\r\n /**\r\n * Gets or sets the maximum deltatime when deterministic lock step is enabled\r\n * @see http://doc.babylonjs.com/babylon101/animations#deterministic-lockstep\r\n */\r\n Scene.MaxDeltaTime = 1000.0;\r\n return Scene;\r\n}(AbstractScene));\r\nexport { Scene };\r\n//# sourceMappingURL=scene.js.map","import { __extends } from \"tslib\";\r\nimport { Logger } from \"@babylonjs/core/Misc/logger\";\r\nimport { Control } from \"./control\";\r\nimport { Measure } from \"../measure\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Root class for 2D containers\r\n * @see http://doc.babylonjs.com/how_to/gui#containers\r\n */\r\nvar Container = /** @class */ (function (_super) {\r\n __extends(Container, _super);\r\n /**\r\n * Creates a new Container\r\n * @param name defines the name of the container\r\n */\r\n function Container(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n /** @hidden */\r\n _this._children = new Array();\r\n /** @hidden */\r\n _this._measureForChildren = Measure.Empty();\r\n /** @hidden */\r\n _this._background = \"\";\r\n /** @hidden */\r\n _this._adaptWidthToChildren = false;\r\n /** @hidden */\r\n _this._adaptHeightToChildren = false;\r\n /**\r\n * Gets or sets a boolean indicating that layout cycle errors should be displayed on the console\r\n */\r\n _this.logLayoutCycleErrors = false;\r\n /**\r\n * Gets or sets the number of layout cycles (a change involved by a control while evaluating the layout) allowed\r\n */\r\n _this.maxLayoutCycle = 3;\r\n return _this;\r\n }\r\n Object.defineProperty(Container.prototype, \"adaptHeightToChildren\", {\r\n /** Gets or sets a boolean indicating if the container should try to adapt to its children height */\r\n get: function () {\r\n return this._adaptHeightToChildren;\r\n },\r\n set: function (value) {\r\n if (this._adaptHeightToChildren === value) {\r\n return;\r\n }\r\n this._adaptHeightToChildren = value;\r\n if (value) {\r\n this.height = \"100%\";\r\n }\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Container.prototype, \"adaptWidthToChildren\", {\r\n /** Gets or sets a boolean indicating if the container should try to adapt to its children width */\r\n get: function () {\r\n return this._adaptWidthToChildren;\r\n },\r\n set: function (value) {\r\n if (this._adaptWidthToChildren === value) {\r\n return;\r\n }\r\n this._adaptWidthToChildren = value;\r\n if (value) {\r\n this.width = \"100%\";\r\n }\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Container.prototype, \"background\", {\r\n /** Gets or sets background color */\r\n get: function () {\r\n return this._background;\r\n },\r\n set: function (value) {\r\n if (this._background === value) {\r\n return;\r\n }\r\n this._background = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Container.prototype, \"children\", {\r\n /** Gets the list of children */\r\n get: function () {\r\n return this._children;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Container.prototype._getTypeName = function () {\r\n return \"Container\";\r\n };\r\n Container.prototype._flagDescendantsAsMatrixDirty = function () {\r\n for (var _i = 0, _a = this.children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child._markMatrixAsDirty();\r\n }\r\n };\r\n /**\r\n * Gets a child using its name\r\n * @param name defines the child name to look for\r\n * @returns the child control if found\r\n */\r\n Container.prototype.getChildByName = function (name) {\r\n for (var _i = 0, _a = this.children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (child.name === name) {\r\n return child;\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a child using its type and its name\r\n * @param name defines the child name to look for\r\n * @param type defines the child type to look for\r\n * @returns the child control if found\r\n */\r\n Container.prototype.getChildByType = function (name, type) {\r\n for (var _i = 0, _a = this.children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (child.typeName === type) {\r\n return child;\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Search for a specific control in children\r\n * @param control defines the control to look for\r\n * @returns true if the control is in child list\r\n */\r\n Container.prototype.containsControl = function (control) {\r\n return this.children.indexOf(control) !== -1;\r\n };\r\n /**\r\n * Adds a new control to the current container\r\n * @param control defines the control to add\r\n * @returns the current container\r\n */\r\n Container.prototype.addControl = function (control) {\r\n if (!control) {\r\n return this;\r\n }\r\n var index = this._children.indexOf(control);\r\n if (index !== -1) {\r\n return this;\r\n }\r\n control._link(this._host);\r\n control._markAllAsDirty();\r\n this._reOrderControl(control);\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /**\r\n * Removes all controls from the current container\r\n * @returns the current container\r\n */\r\n Container.prototype.clearControls = function () {\r\n var children = this.children.slice();\r\n for (var _i = 0, children_1 = children; _i < children_1.length; _i++) {\r\n var child = children_1[_i];\r\n this.removeControl(child);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Removes a control from the current container\r\n * @param control defines the control to remove\r\n * @returns the current container\r\n */\r\n Container.prototype.removeControl = function (control) {\r\n var index = this._children.indexOf(control);\r\n if (index !== -1) {\r\n this._children.splice(index, 1);\r\n control.parent = null;\r\n }\r\n control.linkWithMesh(null);\r\n if (this._host) {\r\n this._host._cleanControlAfterRemoval(control);\r\n }\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /** @hidden */\r\n Container.prototype._reOrderControl = function (control) {\r\n this.removeControl(control);\r\n var wasAdded = false;\r\n for (var index = 0; index < this._children.length; index++) {\r\n if (this._children[index].zIndex > control.zIndex) {\r\n this._children.splice(index, 0, control);\r\n wasAdded = true;\r\n break;\r\n }\r\n }\r\n if (!wasAdded) {\r\n this._children.push(control);\r\n }\r\n control.parent = this;\r\n this._markAsDirty();\r\n };\r\n /** @hidden */\r\n Container.prototype._offsetLeft = function (offset) {\r\n _super.prototype._offsetLeft.call(this, offset);\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child._offsetLeft(offset);\r\n }\r\n };\r\n /** @hidden */\r\n Container.prototype._offsetTop = function (offset) {\r\n _super.prototype._offsetTop.call(this, offset);\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child._offsetTop(offset);\r\n }\r\n };\r\n /** @hidden */\r\n Container.prototype._markAllAsDirty = function () {\r\n _super.prototype._markAllAsDirty.call(this);\r\n for (var index = 0; index < this._children.length; index++) {\r\n this._children[index]._markAllAsDirty();\r\n }\r\n };\r\n /** @hidden */\r\n Container.prototype._localDraw = function (context) {\r\n if (this._background) {\r\n context.save();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n context.fillStyle = this._background;\r\n context.fillRect(this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n context.restore();\r\n }\r\n };\r\n /** @hidden */\r\n Container.prototype._link = function (host) {\r\n _super.prototype._link.call(this, host);\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child._link(host);\r\n }\r\n };\r\n /** @hidden */\r\n Container.prototype._beforeLayout = function () {\r\n // Do nothing\r\n };\r\n /** @hidden */\r\n Container.prototype._processMeasures = function (parentMeasure, context) {\r\n if (this._isDirty || !this._cachedParentMeasure.isEqualsTo(parentMeasure)) {\r\n _super.prototype._processMeasures.call(this, parentMeasure, context);\r\n this._evaluateClippingState(parentMeasure);\r\n }\r\n };\r\n /** @hidden */\r\n Container.prototype._layout = function (parentMeasure, context) {\r\n if (!this.isDirty && (!this.isVisible || this.notRenderable)) {\r\n return false;\r\n }\r\n this.host._numLayoutCalls++;\r\n if (this._isDirty) {\r\n this._currentMeasure.transformToRef(this._transformMatrix, this._prevCurrentMeasureTransformedIntoGlobalSpace);\r\n }\r\n var rebuildCount = 0;\r\n context.save();\r\n this._applyStates(context);\r\n this._beforeLayout();\r\n do {\r\n var computedWidth = -1;\r\n var computedHeight = -1;\r\n this._rebuildLayout = false;\r\n this._processMeasures(parentMeasure, context);\r\n if (!this._isClipped) {\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child._tempParentMeasure.copyFrom(this._measureForChildren);\r\n if (child._layout(this._measureForChildren, context)) {\r\n if (this.adaptWidthToChildren && child._width.isPixel) {\r\n computedWidth = Math.max(computedWidth, child._currentMeasure.width);\r\n }\r\n if (this.adaptHeightToChildren && child._height.isPixel) {\r\n computedHeight = Math.max(computedHeight, child._currentMeasure.height);\r\n }\r\n }\r\n }\r\n if (this.adaptWidthToChildren && computedWidth >= 0) {\r\n if (this.width !== computedWidth + \"px\") {\r\n this.width = computedWidth + \"px\";\r\n this._rebuildLayout = true;\r\n }\r\n }\r\n if (this.adaptHeightToChildren && computedHeight >= 0) {\r\n if (this.height !== computedHeight + \"px\") {\r\n this.height = computedHeight + \"px\";\r\n this._rebuildLayout = true;\r\n }\r\n }\r\n this._postMeasure();\r\n }\r\n rebuildCount++;\r\n } while (this._rebuildLayout && rebuildCount < this.maxLayoutCycle);\r\n if (rebuildCount >= 3 && this.logLayoutCycleErrors) {\r\n Logger.Error(\"Layout cycle detected in GUI (Container name=\" + this.name + \", uniqueId=\" + this.uniqueId + \")\");\r\n }\r\n context.restore();\r\n if (this._isDirty) {\r\n this.invalidateRect();\r\n this._isDirty = false;\r\n }\r\n return true;\r\n };\r\n Container.prototype._postMeasure = function () {\r\n // Do nothing by default\r\n };\r\n /** @hidden */\r\n Container.prototype._draw = function (context, invalidatedRectangle) {\r\n this._localDraw(context);\r\n if (this.clipChildren) {\r\n this._clipForChildren(context);\r\n }\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n // Only redraw parts of the screen that are invalidated\r\n if (invalidatedRectangle) {\r\n if (!child._intersectsRect(invalidatedRectangle)) {\r\n continue;\r\n }\r\n }\r\n child._render(context, invalidatedRectangle);\r\n }\r\n };\r\n Container.prototype.getDescendantsToRef = function (results, directDescendantsOnly, predicate) {\r\n if (directDescendantsOnly === void 0) { directDescendantsOnly = false; }\r\n if (!this.children) {\r\n return;\r\n }\r\n for (var index = 0; index < this.children.length; index++) {\r\n var item = this.children[index];\r\n if (!predicate || predicate(item)) {\r\n results.push(item);\r\n }\r\n if (!directDescendantsOnly) {\r\n item.getDescendantsToRef(results, false, predicate);\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n Container.prototype._processPicking = function (x, y, type, pointerId, buttonIndex, deltaX, deltaY) {\r\n if (!this._isEnabled || !this.isVisible || this.notRenderable) {\r\n return false;\r\n }\r\n if (!_super.prototype.contains.call(this, x, y)) {\r\n return false;\r\n }\r\n // Checking backwards to pick closest first\r\n for (var index = this._children.length - 1; index >= 0; index--) {\r\n var child = this._children[index];\r\n if (child._processPicking(x, y, type, pointerId, buttonIndex, deltaX, deltaY)) {\r\n if (child.hoverCursor) {\r\n this._host._changeCursor(child.hoverCursor);\r\n }\r\n return true;\r\n }\r\n }\r\n if (!this.isHitTestVisible) {\r\n return false;\r\n }\r\n return this._processObservables(type, x, y, pointerId, buttonIndex, deltaX, deltaY);\r\n };\r\n /** @hidden */\r\n Container.prototype._additionalProcessing = function (parentMeasure, context) {\r\n _super.prototype._additionalProcessing.call(this, parentMeasure, context);\r\n this._measureForChildren.copyFrom(this._currentMeasure);\r\n };\r\n /** Releases associated resources */\r\n Container.prototype.dispose = function () {\r\n _super.prototype.dispose.call(this);\r\n for (var index = this.children.length - 1; index >= 0; index--) {\r\n this.children[index].dispose();\r\n }\r\n };\r\n return Container;\r\n}(Control));\r\nexport { Container };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Container\"] = Container;\r\n//# sourceMappingURL=container.js.map","import { ArrayTools } from \"../Misc/arrayTools\";\r\nimport { Matrix, Vector3 } from \"../Maths/math.vector\";\r\nimport { Epsilon } from '../Maths/math.constants';\r\n/**\r\n * Class used to store bounding box information\r\n */\r\nvar BoundingBox = /** @class */ (function () {\r\n /**\r\n * Creates a new bounding box\r\n * @param min defines the minimum vector (in local space)\r\n * @param max defines the maximum vector (in local space)\r\n * @param worldMatrix defines the new world matrix\r\n */\r\n function BoundingBox(min, max, worldMatrix) {\r\n /**\r\n * Gets the 8 vectors representing the bounding box in local space\r\n */\r\n this.vectors = ArrayTools.BuildArray(8, Vector3.Zero);\r\n /**\r\n * Gets the center of the bounding box in local space\r\n */\r\n this.center = Vector3.Zero();\r\n /**\r\n * Gets the center of the bounding box in world space\r\n */\r\n this.centerWorld = Vector3.Zero();\r\n /**\r\n * Gets the extend size in local space\r\n */\r\n this.extendSize = Vector3.Zero();\r\n /**\r\n * Gets the extend size in world space\r\n */\r\n this.extendSizeWorld = Vector3.Zero();\r\n /**\r\n * Gets the OBB (object bounding box) directions\r\n */\r\n this.directions = ArrayTools.BuildArray(3, Vector3.Zero);\r\n /**\r\n * Gets the 8 vectors representing the bounding box in world space\r\n */\r\n this.vectorsWorld = ArrayTools.BuildArray(8, Vector3.Zero);\r\n /**\r\n * Gets the minimum vector in world space\r\n */\r\n this.minimumWorld = Vector3.Zero();\r\n /**\r\n * Gets the maximum vector in world space\r\n */\r\n this.maximumWorld = Vector3.Zero();\r\n /**\r\n * Gets the minimum vector in local space\r\n */\r\n this.minimum = Vector3.Zero();\r\n /**\r\n * Gets the maximum vector in local space\r\n */\r\n this.maximum = Vector3.Zero();\r\n this.reConstruct(min, max, worldMatrix);\r\n }\r\n // Methods\r\n /**\r\n * Recreates the entire bounding box from scratch as if we call the constructor in place\r\n * @param min defines the new minimum vector (in local space)\r\n * @param max defines the new maximum vector (in local space)\r\n * @param worldMatrix defines the new world matrix\r\n */\r\n BoundingBox.prototype.reConstruct = function (min, max, worldMatrix) {\r\n var minX = min.x, minY = min.y, minZ = min.z, maxX = max.x, maxY = max.y, maxZ = max.z;\r\n var vectors = this.vectors;\r\n this.minimum.copyFromFloats(minX, minY, minZ);\r\n this.maximum.copyFromFloats(maxX, maxY, maxZ);\r\n vectors[0].copyFromFloats(minX, minY, minZ);\r\n vectors[1].copyFromFloats(maxX, maxY, maxZ);\r\n vectors[2].copyFromFloats(maxX, minY, minZ);\r\n vectors[3].copyFromFloats(minX, maxY, minZ);\r\n vectors[4].copyFromFloats(minX, minY, maxZ);\r\n vectors[5].copyFromFloats(maxX, maxY, minZ);\r\n vectors[6].copyFromFloats(minX, maxY, maxZ);\r\n vectors[7].copyFromFloats(maxX, minY, maxZ);\r\n // OBB\r\n max.addToRef(min, this.center).scaleInPlace(0.5);\r\n max.subtractToRef(min, this.extendSize).scaleInPlace(0.5);\r\n this._worldMatrix = worldMatrix || Matrix.IdentityReadOnly;\r\n this._update(this._worldMatrix);\r\n };\r\n /**\r\n * Scale the current bounding box by applying a scale factor\r\n * @param factor defines the scale factor to apply\r\n * @returns the current bounding box\r\n */\r\n BoundingBox.prototype.scale = function (factor) {\r\n var tmpVectors = BoundingBox.TmpVector3;\r\n var diff = this.maximum.subtractToRef(this.minimum, tmpVectors[0]);\r\n var len = diff.length();\r\n diff.normalizeFromLength(len);\r\n var distance = len * factor;\r\n var newRadius = diff.scaleInPlace(distance * 0.5);\r\n var min = this.center.subtractToRef(newRadius, tmpVectors[1]);\r\n var max = this.center.addToRef(newRadius, tmpVectors[2]);\r\n this.reConstruct(min, max, this._worldMatrix);\r\n return this;\r\n };\r\n /**\r\n * Gets the world matrix of the bounding box\r\n * @returns a matrix\r\n */\r\n BoundingBox.prototype.getWorldMatrix = function () {\r\n return this._worldMatrix;\r\n };\r\n /** @hidden */\r\n BoundingBox.prototype._update = function (world) {\r\n var minWorld = this.minimumWorld;\r\n var maxWorld = this.maximumWorld;\r\n var directions = this.directions;\r\n var vectorsWorld = this.vectorsWorld;\r\n var vectors = this.vectors;\r\n if (!world.isIdentity()) {\r\n minWorld.setAll(Number.MAX_VALUE);\r\n maxWorld.setAll(-Number.MAX_VALUE);\r\n for (var index = 0; index < 8; ++index) {\r\n var v = vectorsWorld[index];\r\n Vector3.TransformCoordinatesToRef(vectors[index], world, v);\r\n minWorld.minimizeInPlace(v);\r\n maxWorld.maximizeInPlace(v);\r\n }\r\n // Extend\r\n maxWorld.subtractToRef(minWorld, this.extendSizeWorld).scaleInPlace(0.5);\r\n maxWorld.addToRef(minWorld, this.centerWorld).scaleInPlace(0.5);\r\n }\r\n else {\r\n minWorld.copyFrom(this.minimum);\r\n maxWorld.copyFrom(this.maximum);\r\n for (var index = 0; index < 8; ++index) {\r\n vectorsWorld[index].copyFrom(vectors[index]);\r\n }\r\n // Extend\r\n this.extendSizeWorld.copyFrom(this.extendSize);\r\n this.centerWorld.copyFrom(this.center);\r\n }\r\n Vector3.FromArrayToRef(world.m, 0, directions[0]);\r\n Vector3.FromArrayToRef(world.m, 4, directions[1]);\r\n Vector3.FromArrayToRef(world.m, 8, directions[2]);\r\n this._worldMatrix = world;\r\n };\r\n /**\r\n * Tests if the bounding box is intersecting the frustum planes\r\n * @param frustumPlanes defines the frustum planes to test\r\n * @returns true if there is an intersection\r\n */\r\n BoundingBox.prototype.isInFrustum = function (frustumPlanes) {\r\n return BoundingBox.IsInFrustum(this.vectorsWorld, frustumPlanes);\r\n };\r\n /**\r\n * Tests if the bounding box is entirely inside the frustum planes\r\n * @param frustumPlanes defines the frustum planes to test\r\n * @returns true if there is an inclusion\r\n */\r\n BoundingBox.prototype.isCompletelyInFrustum = function (frustumPlanes) {\r\n return BoundingBox.IsCompletelyInFrustum(this.vectorsWorld, frustumPlanes);\r\n };\r\n /**\r\n * Tests if a point is inside the bounding box\r\n * @param point defines the point to test\r\n * @returns true if the point is inside the bounding box\r\n */\r\n BoundingBox.prototype.intersectsPoint = function (point) {\r\n var min = this.minimumWorld;\r\n var max = this.maximumWorld;\r\n var minX = min.x, minY = min.y, minZ = min.z, maxX = max.x, maxY = max.y, maxZ = max.z;\r\n var pointX = point.x, pointY = point.y, pointZ = point.z;\r\n var delta = -Epsilon;\r\n if (maxX - pointX < delta || delta > pointX - minX) {\r\n return false;\r\n }\r\n if (maxY - pointY < delta || delta > pointY - minY) {\r\n return false;\r\n }\r\n if (maxZ - pointZ < delta || delta > pointZ - minZ) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n /**\r\n * Tests if the bounding box intersects with a bounding sphere\r\n * @param sphere defines the sphere to test\r\n * @returns true if there is an intersection\r\n */\r\n BoundingBox.prototype.intersectsSphere = function (sphere) {\r\n return BoundingBox.IntersectsSphere(this.minimumWorld, this.maximumWorld, sphere.centerWorld, sphere.radiusWorld);\r\n };\r\n /**\r\n * Tests if the bounding box intersects with a box defined by a min and max vectors\r\n * @param min defines the min vector to use\r\n * @param max defines the max vector to use\r\n * @returns true if there is an intersection\r\n */\r\n BoundingBox.prototype.intersectsMinMax = function (min, max) {\r\n var myMin = this.minimumWorld;\r\n var myMax = this.maximumWorld;\r\n var myMinX = myMin.x, myMinY = myMin.y, myMinZ = myMin.z, myMaxX = myMax.x, myMaxY = myMax.y, myMaxZ = myMax.z;\r\n var minX = min.x, minY = min.y, minZ = min.z, maxX = max.x, maxY = max.y, maxZ = max.z;\r\n if (myMaxX < minX || myMinX > maxX) {\r\n return false;\r\n }\r\n if (myMaxY < minY || myMinY > maxY) {\r\n return false;\r\n }\r\n if (myMaxZ < minZ || myMinZ > maxZ) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n // Statics\r\n /**\r\n * Tests if two bounding boxes are intersections\r\n * @param box0 defines the first box to test\r\n * @param box1 defines the second box to test\r\n * @returns true if there is an intersection\r\n */\r\n BoundingBox.Intersects = function (box0, box1) {\r\n return box0.intersectsMinMax(box1.minimumWorld, box1.maximumWorld);\r\n };\r\n /**\r\n * Tests if a bounding box defines by a min/max vectors intersects a sphere\r\n * @param minPoint defines the minimum vector of the bounding box\r\n * @param maxPoint defines the maximum vector of the bounding box\r\n * @param sphereCenter defines the sphere center\r\n * @param sphereRadius defines the sphere radius\r\n * @returns true if there is an intersection\r\n */\r\n BoundingBox.IntersectsSphere = function (minPoint, maxPoint, sphereCenter, sphereRadius) {\r\n var vector = BoundingBox.TmpVector3[0];\r\n Vector3.ClampToRef(sphereCenter, minPoint, maxPoint, vector);\r\n var num = Vector3.DistanceSquared(sphereCenter, vector);\r\n return (num <= (sphereRadius * sphereRadius));\r\n };\r\n /**\r\n * Tests if a bounding box defined with 8 vectors is entirely inside frustum planes\r\n * @param boundingVectors defines an array of 8 vectors representing a bounding box\r\n * @param frustumPlanes defines the frustum planes to test\r\n * @return true if there is an inclusion\r\n */\r\n BoundingBox.IsCompletelyInFrustum = function (boundingVectors, frustumPlanes) {\r\n for (var p = 0; p < 6; ++p) {\r\n var frustumPlane = frustumPlanes[p];\r\n for (var i = 0; i < 8; ++i) {\r\n if (frustumPlane.dotCoordinate(boundingVectors[i]) < 0) {\r\n return false;\r\n }\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Tests if a bounding box defined with 8 vectors intersects frustum planes\r\n * @param boundingVectors defines an array of 8 vectors representing a bounding box\r\n * @param frustumPlanes defines the frustum planes to test\r\n * @return true if there is an intersection\r\n */\r\n BoundingBox.IsInFrustum = function (boundingVectors, frustumPlanes) {\r\n for (var p = 0; p < 6; ++p) {\r\n var canReturnFalse = true;\r\n var frustumPlane = frustumPlanes[p];\r\n for (var i = 0; i < 8; ++i) {\r\n if (frustumPlane.dotCoordinate(boundingVectors[i]) >= 0) {\r\n canReturnFalse = false;\r\n break;\r\n }\r\n }\r\n if (canReturnFalse) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n BoundingBox.TmpVector3 = ArrayTools.BuildArray(3, Vector3.Zero);\r\n return BoundingBox;\r\n}());\r\nexport { BoundingBox };\r\n//# sourceMappingURL=boundingBox.js.map","import { ArrayTools } from \"../Misc/arrayTools\";\r\nimport { Vector3 } from \"../Maths/math.vector\";\r\nimport { BoundingBox } from \"./boundingBox\";\r\nimport { BoundingSphere } from \"./boundingSphere\";\r\nvar _result0 = { min: 0, max: 0 };\r\nvar _result1 = { min: 0, max: 0 };\r\nvar computeBoxExtents = function (axis, box, result) {\r\n var p = Vector3.Dot(box.centerWorld, axis);\r\n var r0 = Math.abs(Vector3.Dot(box.directions[0], axis)) * box.extendSize.x;\r\n var r1 = Math.abs(Vector3.Dot(box.directions[1], axis)) * box.extendSize.y;\r\n var r2 = Math.abs(Vector3.Dot(box.directions[2], axis)) * box.extendSize.z;\r\n var r = r0 + r1 + r2;\r\n result.min = p - r;\r\n result.max = p + r;\r\n};\r\nvar axisOverlap = function (axis, box0, box1) {\r\n computeBoxExtents(axis, box0, _result0);\r\n computeBoxExtents(axis, box1, _result1);\r\n return !(_result0.min > _result1.max || _result1.min > _result0.max);\r\n};\r\n/**\r\n * Info for a bounding data of a mesh\r\n */\r\nvar BoundingInfo = /** @class */ (function () {\r\n /**\r\n * Constructs bounding info\r\n * @param minimum min vector of the bounding box/sphere\r\n * @param maximum max vector of the bounding box/sphere\r\n * @param worldMatrix defines the new world matrix\r\n */\r\n function BoundingInfo(minimum, maximum, worldMatrix) {\r\n this._isLocked = false;\r\n this.boundingBox = new BoundingBox(minimum, maximum, worldMatrix);\r\n this.boundingSphere = new BoundingSphere(minimum, maximum, worldMatrix);\r\n }\r\n /**\r\n * Recreates the entire bounding info from scratch as if we call the constructor in place\r\n * @param min defines the new minimum vector (in local space)\r\n * @param max defines the new maximum vector (in local space)\r\n * @param worldMatrix defines the new world matrix\r\n */\r\n BoundingInfo.prototype.reConstruct = function (min, max, worldMatrix) {\r\n this.boundingBox.reConstruct(min, max, worldMatrix);\r\n this.boundingSphere.reConstruct(min, max, worldMatrix);\r\n };\r\n Object.defineProperty(BoundingInfo.prototype, \"minimum\", {\r\n /**\r\n * min vector of the bounding box/sphere\r\n */\r\n get: function () {\r\n return this.boundingBox.minimum;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BoundingInfo.prototype, \"maximum\", {\r\n /**\r\n * max vector of the bounding box/sphere\r\n */\r\n get: function () {\r\n return this.boundingBox.maximum;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BoundingInfo.prototype, \"isLocked\", {\r\n /**\r\n * If the info is locked and won't be updated to avoid perf overhead\r\n */\r\n get: function () {\r\n return this._isLocked;\r\n },\r\n set: function (value) {\r\n this._isLocked = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n // Methods\r\n /**\r\n * Updates the bounding sphere and box\r\n * @param world world matrix to be used to update\r\n */\r\n BoundingInfo.prototype.update = function (world) {\r\n if (this._isLocked) {\r\n return;\r\n }\r\n this.boundingBox._update(world);\r\n this.boundingSphere._update(world);\r\n };\r\n /**\r\n * Recreate the bounding info to be centered around a specific point given a specific extend.\r\n * @param center New center of the bounding info\r\n * @param extend New extend of the bounding info\r\n * @returns the current bounding info\r\n */\r\n BoundingInfo.prototype.centerOn = function (center, extend) {\r\n var minimum = BoundingInfo.TmpVector3[0].copyFrom(center).subtractInPlace(extend);\r\n var maximum = BoundingInfo.TmpVector3[1].copyFrom(center).addInPlace(extend);\r\n this.boundingBox.reConstruct(minimum, maximum, this.boundingBox.getWorldMatrix());\r\n this.boundingSphere.reConstruct(minimum, maximum, this.boundingBox.getWorldMatrix());\r\n return this;\r\n };\r\n /**\r\n * Scale the current bounding info by applying a scale factor\r\n * @param factor defines the scale factor to apply\r\n * @returns the current bounding info\r\n */\r\n BoundingInfo.prototype.scale = function (factor) {\r\n this.boundingBox.scale(factor);\r\n this.boundingSphere.scale(factor);\r\n return this;\r\n };\r\n /**\r\n * Returns `true` if the bounding info is within the frustum defined by the passed array of planes.\r\n * @param frustumPlanes defines the frustum to test\r\n * @param strategy defines the strategy to use for the culling (default is BABYLON.AbstractMesh.CULLINGSTRATEGY_STANDARD)\r\n * @returns true if the bounding info is in the frustum planes\r\n */\r\n BoundingInfo.prototype.isInFrustum = function (frustumPlanes, strategy) {\r\n if (strategy === void 0) { strategy = 0; }\r\n var inclusionTest = (strategy === 2 || strategy === 3);\r\n if (inclusionTest) {\r\n if (this.boundingSphere.isCenterInFrustum(frustumPlanes)) {\r\n return true;\r\n }\r\n }\r\n if (!this.boundingSphere.isInFrustum(frustumPlanes)) {\r\n return false;\r\n }\r\n var bSphereOnlyTest = (strategy === 1 || strategy === 3);\r\n if (bSphereOnlyTest) {\r\n return true;\r\n }\r\n return this.boundingBox.isInFrustum(frustumPlanes);\r\n };\r\n Object.defineProperty(BoundingInfo.prototype, \"diagonalLength\", {\r\n /**\r\n * Gets the world distance between the min and max points of the bounding box\r\n */\r\n get: function () {\r\n var boundingBox = this.boundingBox;\r\n var diag = boundingBox.maximumWorld.subtractToRef(boundingBox.minimumWorld, BoundingInfo.TmpVector3[0]);\r\n return diag.length();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Checks if a cullable object (mesh...) is in the camera frustum\r\n * Unlike isInFrustum this cheks the full bounding box\r\n * @param frustumPlanes Camera near/planes\r\n * @returns true if the object is in frustum otherwise false\r\n */\r\n BoundingInfo.prototype.isCompletelyInFrustum = function (frustumPlanes) {\r\n return this.boundingBox.isCompletelyInFrustum(frustumPlanes);\r\n };\r\n /** @hidden */\r\n BoundingInfo.prototype._checkCollision = function (collider) {\r\n return collider._canDoCollision(this.boundingSphere.centerWorld, this.boundingSphere.radiusWorld, this.boundingBox.minimumWorld, this.boundingBox.maximumWorld);\r\n };\r\n /**\r\n * Checks if a point is inside the bounding box and bounding sphere or the mesh\r\n * @see https://doc.babylonjs.com/babylon101/intersect_collisions_-_mesh\r\n * @param point the point to check intersection with\r\n * @returns if the point intersects\r\n */\r\n BoundingInfo.prototype.intersectsPoint = function (point) {\r\n if (!this.boundingSphere.centerWorld) {\r\n return false;\r\n }\r\n if (!this.boundingSphere.intersectsPoint(point)) {\r\n return false;\r\n }\r\n if (!this.boundingBox.intersectsPoint(point)) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n /**\r\n * Checks if another bounding info intersects the bounding box and bounding sphere or the mesh\r\n * @see https://doc.babylonjs.com/babylon101/intersect_collisions_-_mesh\r\n * @param boundingInfo the bounding info to check intersection with\r\n * @param precise if the intersection should be done using OBB\r\n * @returns if the bounding info intersects\r\n */\r\n BoundingInfo.prototype.intersects = function (boundingInfo, precise) {\r\n if (!BoundingSphere.Intersects(this.boundingSphere, boundingInfo.boundingSphere)) {\r\n return false;\r\n }\r\n if (!BoundingBox.Intersects(this.boundingBox, boundingInfo.boundingBox)) {\r\n return false;\r\n }\r\n if (!precise) {\r\n return true;\r\n }\r\n var box0 = this.boundingBox;\r\n var box1 = boundingInfo.boundingBox;\r\n if (!axisOverlap(box0.directions[0], box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(box0.directions[1], box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(box0.directions[2], box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(box1.directions[0], box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(box1.directions[1], box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(box1.directions[2], box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[0], box1.directions[0]), box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[0], box1.directions[1]), box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[0], box1.directions[2]), box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[1], box1.directions[0]), box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[1], box1.directions[1]), box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[1], box1.directions[2]), box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[2], box1.directions[0]), box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[2], box1.directions[1]), box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[2], box1.directions[2]), box0, box1)) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n BoundingInfo.TmpVector3 = ArrayTools.BuildArray(2, Vector3.Zero);\r\n return BoundingInfo;\r\n}());\r\nexport { BoundingInfo };\r\n//# sourceMappingURL=boundingInfo.js.map","import { __decorate } from \"tslib\";\r\nimport { Matrix, Vector3 } from \"./Maths/math.vector\";\r\nimport { serialize } from \"./Misc/decorators\";\r\nimport { Observable } from \"./Misc/observable\";\r\nimport { EngineStore } from \"./Engines/engineStore\";\r\nimport { _DevTools } from './Misc/devTools';\r\n/**\r\n * Node is the basic class for all scene objects (Mesh, Light, Camera.)\r\n */\r\nvar Node = /** @class */ (function () {\r\n /**\r\n * Creates a new Node\r\n * @param name the name and id to be given to this node\r\n * @param scene the scene this node will be added to\r\n */\r\n function Node(name, scene) {\r\n if (scene === void 0) { scene = null; }\r\n /**\r\n * Gets or sets a string used to store user defined state for the node\r\n */\r\n this.state = \"\";\r\n /**\r\n * Gets or sets an object used to store user defined information for the node\r\n */\r\n this.metadata = null;\r\n /**\r\n * For internal use only. Please do not use.\r\n */\r\n this.reservedDataStore = null;\r\n this._doNotSerialize = false;\r\n /** @hidden */\r\n this._isDisposed = false;\r\n /**\r\n * Gets a list of Animations associated with the node\r\n */\r\n this.animations = new Array();\r\n this._ranges = {};\r\n /**\r\n * Callback raised when the node is ready to be used\r\n */\r\n this.onReady = null;\r\n this._isEnabled = true;\r\n this._isParentEnabled = true;\r\n this._isReady = true;\r\n /** @hidden */\r\n this._currentRenderId = -1;\r\n this._parentUpdateId = -1;\r\n /** @hidden */\r\n this._childUpdateId = -1;\r\n /** @hidden */\r\n this._waitingParentId = null;\r\n /** @hidden */\r\n this._cache = {};\r\n this._parentNode = null;\r\n this._children = null;\r\n /** @hidden */\r\n this._worldMatrix = Matrix.Identity();\r\n /** @hidden */\r\n this._worldMatrixDeterminant = 0;\r\n /** @hidden */\r\n this._worldMatrixDeterminantIsDirty = true;\r\n /** @hidden */\r\n this._sceneRootNodesIndex = -1;\r\n this._animationPropertiesOverride = null;\r\n /** @hidden */\r\n this._isNode = true;\r\n /**\r\n * An event triggered when the mesh is disposed\r\n */\r\n this.onDisposeObservable = new Observable();\r\n this._onDisposeObserver = null;\r\n // Behaviors\r\n this._behaviors = new Array();\r\n this.name = name;\r\n this.id = name;\r\n this._scene = (scene || EngineStore.LastCreatedScene);\r\n this.uniqueId = this._scene.getUniqueId();\r\n this._initCache();\r\n }\r\n /**\r\n * Add a new node constructor\r\n * @param type defines the type name of the node to construct\r\n * @param constructorFunc defines the constructor function\r\n */\r\n Node.AddNodeConstructor = function (type, constructorFunc) {\r\n this._NodeConstructors[type] = constructorFunc;\r\n };\r\n /**\r\n * Returns a node constructor based on type name\r\n * @param type defines the type name\r\n * @param name defines the new node name\r\n * @param scene defines the hosting scene\r\n * @param options defines optional options to transmit to constructors\r\n * @returns the new constructor or null\r\n */\r\n Node.Construct = function (type, name, scene, options) {\r\n var constructorFunc = this._NodeConstructors[type];\r\n if (!constructorFunc) {\r\n return null;\r\n }\r\n return constructorFunc(name, scene, options);\r\n };\r\n Object.defineProperty(Node.prototype, \"doNotSerialize\", {\r\n /**\r\n * Gets or sets a boolean used to define if the node must be serialized\r\n */\r\n get: function () {\r\n if (this._doNotSerialize) {\r\n return true;\r\n }\r\n if (this._parentNode) {\r\n return this._parentNode.doNotSerialize;\r\n }\r\n return false;\r\n },\r\n set: function (value) {\r\n this._doNotSerialize = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets a boolean indicating if the node has been disposed\r\n * @returns true if the node was disposed\r\n */\r\n Node.prototype.isDisposed = function () {\r\n return this._isDisposed;\r\n };\r\n Object.defineProperty(Node.prototype, \"parent\", {\r\n get: function () {\r\n return this._parentNode;\r\n },\r\n /**\r\n * Gets or sets the parent of the node (without keeping the current position in the scene)\r\n * @see https://doc.babylonjs.com/how_to/parenting\r\n */\r\n set: function (parent) {\r\n if (this._parentNode === parent) {\r\n return;\r\n }\r\n var previousParentNode = this._parentNode;\r\n // Remove self from list of children of parent\r\n if (this._parentNode && this._parentNode._children !== undefined && this._parentNode._children !== null) {\r\n var index = this._parentNode._children.indexOf(this);\r\n if (index !== -1) {\r\n this._parentNode._children.splice(index, 1);\r\n }\r\n if (!parent && !this._isDisposed) {\r\n this._addToSceneRootNodes();\r\n }\r\n }\r\n // Store new parent\r\n this._parentNode = parent;\r\n // Add as child to new parent\r\n if (this._parentNode) {\r\n if (this._parentNode._children === undefined || this._parentNode._children === null) {\r\n this._parentNode._children = new Array();\r\n }\r\n this._parentNode._children.push(this);\r\n if (!previousParentNode) {\r\n this._removeFromSceneRootNodes();\r\n }\r\n }\r\n // Enabled state\r\n this._syncParentEnabledState();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n Node.prototype._addToSceneRootNodes = function () {\r\n if (this._sceneRootNodesIndex === -1) {\r\n this._sceneRootNodesIndex = this._scene.rootNodes.length;\r\n this._scene.rootNodes.push(this);\r\n }\r\n };\r\n /** @hidden */\r\n Node.prototype._removeFromSceneRootNodes = function () {\r\n if (this._sceneRootNodesIndex !== -1) {\r\n var rootNodes = this._scene.rootNodes;\r\n var lastIdx = rootNodes.length - 1;\r\n rootNodes[this._sceneRootNodesIndex] = rootNodes[lastIdx];\r\n rootNodes[this._sceneRootNodesIndex]._sceneRootNodesIndex = this._sceneRootNodesIndex;\r\n this._scene.rootNodes.pop();\r\n this._sceneRootNodesIndex = -1;\r\n }\r\n };\r\n Object.defineProperty(Node.prototype, \"animationPropertiesOverride\", {\r\n /**\r\n * Gets or sets the animation properties override\r\n */\r\n get: function () {\r\n if (!this._animationPropertiesOverride) {\r\n return this._scene.animationPropertiesOverride;\r\n }\r\n return this._animationPropertiesOverride;\r\n },\r\n set: function (value) {\r\n this._animationPropertiesOverride = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets a string idenfifying the name of the class\r\n * @returns \"Node\" string\r\n */\r\n Node.prototype.getClassName = function () {\r\n return \"Node\";\r\n };\r\n Object.defineProperty(Node.prototype, \"onDispose\", {\r\n /**\r\n * Sets a callback that will be raised when the node will be disposed\r\n */\r\n set: function (callback) {\r\n if (this._onDisposeObserver) {\r\n this.onDisposeObservable.remove(this._onDisposeObserver);\r\n }\r\n this._onDisposeObserver = this.onDisposeObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the scene of the node\r\n * @returns a scene\r\n */\r\n Node.prototype.getScene = function () {\r\n return this._scene;\r\n };\r\n /**\r\n * Gets the engine of the node\r\n * @returns a Engine\r\n */\r\n Node.prototype.getEngine = function () {\r\n return this._scene.getEngine();\r\n };\r\n /**\r\n * Attach a behavior to the node\r\n * @see http://doc.babylonjs.com/features/behaviour\r\n * @param behavior defines the behavior to attach\r\n * @param attachImmediately defines that the behavior must be attached even if the scene is still loading\r\n * @returns the current Node\r\n */\r\n Node.prototype.addBehavior = function (behavior, attachImmediately) {\r\n var _this = this;\r\n if (attachImmediately === void 0) { attachImmediately = false; }\r\n var index = this._behaviors.indexOf(behavior);\r\n if (index !== -1) {\r\n return this;\r\n }\r\n behavior.init();\r\n if (this._scene.isLoading && !attachImmediately) {\r\n // We defer the attach when the scene will be loaded\r\n this._scene.onDataLoadedObservable.addOnce(function () {\r\n behavior.attach(_this);\r\n });\r\n }\r\n else {\r\n behavior.attach(this);\r\n }\r\n this._behaviors.push(behavior);\r\n return this;\r\n };\r\n /**\r\n * Remove an attached behavior\r\n * @see http://doc.babylonjs.com/features/behaviour\r\n * @param behavior defines the behavior to attach\r\n * @returns the current Node\r\n */\r\n Node.prototype.removeBehavior = function (behavior) {\r\n var index = this._behaviors.indexOf(behavior);\r\n if (index === -1) {\r\n return this;\r\n }\r\n this._behaviors[index].detach();\r\n this._behaviors.splice(index, 1);\r\n return this;\r\n };\r\n Object.defineProperty(Node.prototype, \"behaviors\", {\r\n /**\r\n * Gets the list of attached behaviors\r\n * @see http://doc.babylonjs.com/features/behaviour\r\n */\r\n get: function () {\r\n return this._behaviors;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets an attached behavior by name\r\n * @param name defines the name of the behavior to look for\r\n * @see http://doc.babylonjs.com/features/behaviour\r\n * @returns null if behavior was not found else the requested behavior\r\n */\r\n Node.prototype.getBehaviorByName = function (name) {\r\n for (var _i = 0, _a = this._behaviors; _i < _a.length; _i++) {\r\n var behavior = _a[_i];\r\n if (behavior.name === name) {\r\n return behavior;\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Returns the latest update of the World matrix\r\n * @returns a Matrix\r\n */\r\n Node.prototype.getWorldMatrix = function () {\r\n if (this._currentRenderId !== this._scene.getRenderId()) {\r\n this.computeWorldMatrix();\r\n }\r\n return this._worldMatrix;\r\n };\r\n /** @hidden */\r\n Node.prototype._getWorldMatrixDeterminant = function () {\r\n if (this._worldMatrixDeterminantIsDirty) {\r\n this._worldMatrixDeterminantIsDirty = false;\r\n this._worldMatrixDeterminant = this._worldMatrix.determinant();\r\n }\r\n return this._worldMatrixDeterminant;\r\n };\r\n Object.defineProperty(Node.prototype, \"worldMatrixFromCache\", {\r\n /**\r\n * Returns directly the latest state of the mesh World matrix.\r\n * A Matrix is returned.\r\n */\r\n get: function () {\r\n return this._worldMatrix;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n // override it in derived class if you add new variables to the cache\r\n // and call the parent class method\r\n /** @hidden */\r\n Node.prototype._initCache = function () {\r\n this._cache = {};\r\n this._cache.parent = undefined;\r\n };\r\n /** @hidden */\r\n Node.prototype.updateCache = function (force) {\r\n if (!force && this.isSynchronized()) {\r\n return;\r\n }\r\n this._cache.parent = this.parent;\r\n this._updateCache();\r\n };\r\n /** @hidden */\r\n Node.prototype._getActionManagerForTrigger = function (trigger, initialCall) {\r\n if (initialCall === void 0) { initialCall = true; }\r\n if (!this.parent) {\r\n return null;\r\n }\r\n return this.parent._getActionManagerForTrigger(trigger, false);\r\n };\r\n // override it in derived class if you add new variables to the cache\r\n // and call the parent class method if !ignoreParentClass\r\n /** @hidden */\r\n Node.prototype._updateCache = function (ignoreParentClass) {\r\n };\r\n // override it in derived class if you add new variables to the cache\r\n /** @hidden */\r\n Node.prototype._isSynchronized = function () {\r\n return true;\r\n };\r\n /** @hidden */\r\n Node.prototype._markSyncedWithParent = function () {\r\n if (this._parentNode) {\r\n this._parentUpdateId = this._parentNode._childUpdateId;\r\n }\r\n };\r\n /** @hidden */\r\n Node.prototype.isSynchronizedWithParent = function () {\r\n if (!this._parentNode) {\r\n return true;\r\n }\r\n if (this._parentUpdateId !== this._parentNode._childUpdateId) {\r\n return false;\r\n }\r\n return this._parentNode.isSynchronized();\r\n };\r\n /** @hidden */\r\n Node.prototype.isSynchronized = function () {\r\n if (this._cache.parent != this._parentNode) {\r\n this._cache.parent = this._parentNode;\r\n return false;\r\n }\r\n if (this._parentNode && !this.isSynchronizedWithParent()) {\r\n return false;\r\n }\r\n return this._isSynchronized();\r\n };\r\n /**\r\n * Is this node ready to be used/rendered\r\n * @param completeCheck defines if a complete check (including materials and lights) has to be done (false by default)\r\n * @return true if the node is ready\r\n */\r\n Node.prototype.isReady = function (completeCheck) {\r\n if (completeCheck === void 0) { completeCheck = false; }\r\n return this._isReady;\r\n };\r\n /**\r\n * Is this node enabled?\r\n * If the node has a parent, all ancestors will be checked and false will be returned if any are false (not enabled), otherwise will return true\r\n * @param checkAncestors indicates if this method should check the ancestors. The default is to check the ancestors. If set to false, the method will return the value of this node without checking ancestors\r\n * @return whether this node (and its parent) is enabled\r\n */\r\n Node.prototype.isEnabled = function (checkAncestors) {\r\n if (checkAncestors === void 0) { checkAncestors = true; }\r\n if (checkAncestors === false) {\r\n return this._isEnabled;\r\n }\r\n if (!this._isEnabled) {\r\n return false;\r\n }\r\n return this._isParentEnabled;\r\n };\r\n /** @hidden */\r\n Node.prototype._syncParentEnabledState = function () {\r\n this._isParentEnabled = this._parentNode ? this._parentNode.isEnabled() : true;\r\n if (this._children) {\r\n this._children.forEach(function (c) {\r\n c._syncParentEnabledState(); // Force children to update accordingly\r\n });\r\n }\r\n };\r\n /**\r\n * Set the enabled state of this node\r\n * @param value defines the new enabled state\r\n */\r\n Node.prototype.setEnabled = function (value) {\r\n this._isEnabled = value;\r\n this._syncParentEnabledState();\r\n };\r\n /**\r\n * Is this node a descendant of the given node?\r\n * The function will iterate up the hierarchy until the ancestor was found or no more parents defined\r\n * @param ancestor defines the parent node to inspect\r\n * @returns a boolean indicating if this node is a descendant of the given node\r\n */\r\n Node.prototype.isDescendantOf = function (ancestor) {\r\n if (this.parent) {\r\n if (this.parent === ancestor) {\r\n return true;\r\n }\r\n return this.parent.isDescendantOf(ancestor);\r\n }\r\n return false;\r\n };\r\n /** @hidden */\r\n Node.prototype._getDescendants = function (results, directDescendantsOnly, predicate) {\r\n if (directDescendantsOnly === void 0) { directDescendantsOnly = false; }\r\n if (!this._children) {\r\n return;\r\n }\r\n for (var index = 0; index < this._children.length; index++) {\r\n var item = this._children[index];\r\n if (!predicate || predicate(item)) {\r\n results.push(item);\r\n }\r\n if (!directDescendantsOnly) {\r\n item._getDescendants(results, false, predicate);\r\n }\r\n }\r\n };\r\n /**\r\n * Will return all nodes that have this node as ascendant\r\n * @param directDescendantsOnly defines if true only direct descendants of 'this' will be considered, if false direct and also indirect (children of children, an so on in a recursive manner) descendants of 'this' will be considered\r\n * @param predicate defines an optional predicate that will be called on every evaluated child, the predicate must return true for a given child to be part of the result, otherwise it will be ignored\r\n * @return all children nodes of all types\r\n */\r\n Node.prototype.getDescendants = function (directDescendantsOnly, predicate) {\r\n var results = new Array();\r\n this._getDescendants(results, directDescendantsOnly, predicate);\r\n return results;\r\n };\r\n /**\r\n * Get all child-meshes of this node\r\n * @param directDescendantsOnly defines if true only direct descendants of 'this' will be considered, if false direct and also indirect (children of children, an so on in a recursive manner) descendants of 'this' will be considered (Default: false)\r\n * @param predicate defines an optional predicate that will be called on every evaluated child, the predicate must return true for a given child to be part of the result, otherwise it will be ignored\r\n * @returns an array of AbstractMesh\r\n */\r\n Node.prototype.getChildMeshes = function (directDescendantsOnly, predicate) {\r\n var results = [];\r\n this._getDescendants(results, directDescendantsOnly, function (node) {\r\n return ((!predicate || predicate(node)) && (node.cullingStrategy !== undefined));\r\n });\r\n return results;\r\n };\r\n /**\r\n * Get all direct children of this node\r\n * @param predicate defines an optional predicate that will be called on every evaluated child, the predicate must return true for a given child to be part of the result, otherwise it will be ignored\r\n * @param directDescendantsOnly defines if true only direct descendants of 'this' will be considered, if false direct and also indirect (children of children, an so on in a recursive manner) descendants of 'this' will be considered (Default: true)\r\n * @returns an array of Node\r\n */\r\n Node.prototype.getChildren = function (predicate, directDescendantsOnly) {\r\n if (directDescendantsOnly === void 0) { directDescendantsOnly = true; }\r\n return this.getDescendants(directDescendantsOnly, predicate);\r\n };\r\n /** @hidden */\r\n Node.prototype._setReady = function (state) {\r\n if (state === this._isReady) {\r\n return;\r\n }\r\n if (!state) {\r\n this._isReady = false;\r\n return;\r\n }\r\n if (this.onReady) {\r\n this.onReady(this);\r\n }\r\n this._isReady = true;\r\n };\r\n /**\r\n * Get an animation by name\r\n * @param name defines the name of the animation to look for\r\n * @returns null if not found else the requested animation\r\n */\r\n Node.prototype.getAnimationByName = function (name) {\r\n for (var i = 0; i < this.animations.length; i++) {\r\n var animation = this.animations[i];\r\n if (animation.name === name) {\r\n return animation;\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Creates an animation range for this node\r\n * @param name defines the name of the range\r\n * @param from defines the starting key\r\n * @param to defines the end key\r\n */\r\n Node.prototype.createAnimationRange = function (name, from, to) {\r\n // check name not already in use\r\n if (!this._ranges[name]) {\r\n this._ranges[name] = Node._AnimationRangeFactory(name, from, to);\r\n for (var i = 0, nAnimations = this.animations.length; i < nAnimations; i++) {\r\n if (this.animations[i]) {\r\n this.animations[i].createRange(name, from, to);\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Delete a specific animation range\r\n * @param name defines the name of the range to delete\r\n * @param deleteFrames defines if animation frames from the range must be deleted as well\r\n */\r\n Node.prototype.deleteAnimationRange = function (name, deleteFrames) {\r\n if (deleteFrames === void 0) { deleteFrames = true; }\r\n for (var i = 0, nAnimations = this.animations.length; i < nAnimations; i++) {\r\n if (this.animations[i]) {\r\n this.animations[i].deleteRange(name, deleteFrames);\r\n }\r\n }\r\n this._ranges[name] = null; // said much faster than 'delete this._range[name]'\r\n };\r\n /**\r\n * Get an animation range by name\r\n * @param name defines the name of the animation range to look for\r\n * @returns null if not found else the requested animation range\r\n */\r\n Node.prototype.getAnimationRange = function (name) {\r\n return this._ranges[name];\r\n };\r\n /**\r\n * Gets the list of all animation ranges defined on this node\r\n * @returns an array\r\n */\r\n Node.prototype.getAnimationRanges = function () {\r\n var animationRanges = [];\r\n var name;\r\n for (name in this._ranges) {\r\n animationRanges.push(this._ranges[name]);\r\n }\r\n return animationRanges;\r\n };\r\n /**\r\n * Will start the animation sequence\r\n * @param name defines the range frames for animation sequence\r\n * @param loop defines if the animation should loop (false by default)\r\n * @param speedRatio defines the speed factor in which to run the animation (1 by default)\r\n * @param onAnimationEnd defines a function to be executed when the animation ended (undefined by default)\r\n * @returns the object created for this animation. If range does not exist, it will return null\r\n */\r\n Node.prototype.beginAnimation = function (name, loop, speedRatio, onAnimationEnd) {\r\n var range = this.getAnimationRange(name);\r\n if (!range) {\r\n return null;\r\n }\r\n return this._scene.beginAnimation(this, range.from, range.to, loop, speedRatio, onAnimationEnd);\r\n };\r\n /**\r\n * Serialize animation ranges into a JSON compatible object\r\n * @returns serialization object\r\n */\r\n Node.prototype.serializeAnimationRanges = function () {\r\n var serializationRanges = [];\r\n for (var name in this._ranges) {\r\n var localRange = this._ranges[name];\r\n if (!localRange) {\r\n continue;\r\n }\r\n var range = {};\r\n range.name = name;\r\n range.from = localRange.from;\r\n range.to = localRange.to;\r\n serializationRanges.push(range);\r\n }\r\n return serializationRanges;\r\n };\r\n /**\r\n * Computes the world matrix of the node\r\n * @param force defines if the cache version should be invalidated forcing the world matrix to be created from scratch\r\n * @returns the world matrix\r\n */\r\n Node.prototype.computeWorldMatrix = function (force) {\r\n if (!this._worldMatrix) {\r\n this._worldMatrix = Matrix.Identity();\r\n }\r\n return this._worldMatrix;\r\n };\r\n /**\r\n * Releases resources associated with this node.\r\n * @param doNotRecurse Set to true to not recurse into each children (recurse into each children by default)\r\n * @param disposeMaterialAndTextures Set to true to also dispose referenced materials and textures (false by default)\r\n */\r\n Node.prototype.dispose = function (doNotRecurse, disposeMaterialAndTextures) {\r\n if (disposeMaterialAndTextures === void 0) { disposeMaterialAndTextures = false; }\r\n this._isDisposed = true;\r\n if (!doNotRecurse) {\r\n var nodes = this.getDescendants(true);\r\n for (var _i = 0, nodes_1 = nodes; _i < nodes_1.length; _i++) {\r\n var node = nodes_1[_i];\r\n node.dispose(doNotRecurse, disposeMaterialAndTextures);\r\n }\r\n }\r\n if (!this.parent) {\r\n this._removeFromSceneRootNodes();\r\n }\r\n else {\r\n this.parent = null;\r\n }\r\n // Callback\r\n this.onDisposeObservable.notifyObservers(this);\r\n this.onDisposeObservable.clear();\r\n // Behaviors\r\n for (var _a = 0, _b = this._behaviors; _a < _b.length; _a++) {\r\n var behavior = _b[_a];\r\n behavior.detach();\r\n }\r\n this._behaviors = [];\r\n };\r\n /**\r\n * Parse animation range data from a serialization object and store them into a given node\r\n * @param node defines where to store the animation ranges\r\n * @param parsedNode defines the serialization object to read data from\r\n * @param scene defines the hosting scene\r\n */\r\n Node.ParseAnimationRanges = function (node, parsedNode, scene) {\r\n if (parsedNode.ranges) {\r\n for (var index = 0; index < parsedNode.ranges.length; index++) {\r\n var data = parsedNode.ranges[index];\r\n node.createAnimationRange(data.name, data.from, data.to);\r\n }\r\n }\r\n };\r\n /**\r\n * Return the minimum and maximum world vectors of the entire hierarchy under current node\r\n * @param includeDescendants Include bounding info from descendants as well (true by default)\r\n * @param predicate defines a callback function that can be customize to filter what meshes should be included in the list used to compute the bounding vectors\r\n * @returns the new bounding vectors\r\n */\r\n Node.prototype.getHierarchyBoundingVectors = function (includeDescendants, predicate) {\r\n if (includeDescendants === void 0) { includeDescendants = true; }\r\n if (predicate === void 0) { predicate = null; }\r\n // Ensures that all world matrix will be recomputed.\r\n this.getScene().incrementRenderId();\r\n this.computeWorldMatrix(true);\r\n var min;\r\n var max;\r\n var thisAbstractMesh = this;\r\n if (thisAbstractMesh.getBoundingInfo && thisAbstractMesh.subMeshes) {\r\n // If this is an abstract mesh get its bounding info\r\n var boundingInfo = thisAbstractMesh.getBoundingInfo();\r\n min = boundingInfo.boundingBox.minimumWorld.clone();\r\n max = boundingInfo.boundingBox.maximumWorld.clone();\r\n }\r\n else {\r\n min = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n max = new Vector3(-Number.MAX_VALUE, -Number.MAX_VALUE, -Number.MAX_VALUE);\r\n }\r\n if (includeDescendants) {\r\n var descendants = this.getDescendants(false);\r\n for (var _i = 0, descendants_1 = descendants; _i < descendants_1.length; _i++) {\r\n var descendant = descendants_1[_i];\r\n var childMesh = descendant;\r\n childMesh.computeWorldMatrix(true);\r\n // Filters meshes based on custom predicate function.\r\n if (predicate && !predicate(childMesh)) {\r\n continue;\r\n }\r\n //make sure we have the needed params to get mix and max\r\n if (!childMesh.getBoundingInfo || childMesh.getTotalVertices() === 0) {\r\n continue;\r\n }\r\n var childBoundingInfo = childMesh.getBoundingInfo();\r\n var boundingBox = childBoundingInfo.boundingBox;\r\n var minBox = boundingBox.minimumWorld;\r\n var maxBox = boundingBox.maximumWorld;\r\n Vector3.CheckExtends(minBox, min, max);\r\n Vector3.CheckExtends(maxBox, min, max);\r\n }\r\n }\r\n return {\r\n min: min,\r\n max: max\r\n };\r\n };\r\n /** @hidden */\r\n Node._AnimationRangeFactory = function (name, from, to) {\r\n throw _DevTools.WarnImport(\"AnimationRange\");\r\n };\r\n Node._NodeConstructors = {};\r\n __decorate([\r\n serialize()\r\n ], Node.prototype, \"name\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Node.prototype, \"id\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Node.prototype, \"uniqueId\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Node.prototype, \"state\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Node.prototype, \"metadata\", void 0);\r\n return Node;\r\n}());\r\nexport { Node };\r\n//# sourceMappingURL=node.js.map","import { Vector3 } from './math.vector';\r\n/** Defines supported spaces */\r\nexport var Space;\r\n(function (Space) {\r\n /** Local (object) space */\r\n Space[Space[\"LOCAL\"] = 0] = \"LOCAL\";\r\n /** World space */\r\n Space[Space[\"WORLD\"] = 1] = \"WORLD\";\r\n /** Bone space */\r\n Space[Space[\"BONE\"] = 2] = \"BONE\";\r\n})(Space || (Space = {}));\r\n/** Defines the 3 main axes */\r\nvar Axis = /** @class */ (function () {\r\n function Axis() {\r\n }\r\n /** X axis */\r\n Axis.X = new Vector3(1.0, 0.0, 0.0);\r\n /** Y axis */\r\n Axis.Y = new Vector3(0.0, 1.0, 0.0);\r\n /** Z axis */\r\n Axis.Z = new Vector3(0.0, 0.0, 1.0);\r\n return Axis;\r\n}());\r\nexport { Axis };\r\n//# sourceMappingURL=math.axis.js.map","/**\r\n * Class used to help managing file picking and drag'n'drop\r\n * File Storage\r\n */\r\nvar FilesInputStore = /** @class */ (function () {\r\n function FilesInputStore() {\r\n }\r\n /**\r\n * List of files ready to be loaded\r\n */\r\n FilesInputStore.FilesToLoad = {};\r\n return FilesInputStore;\r\n}());\r\nexport { FilesInputStore };\r\n//# sourceMappingURL=filesInputStore.js.map","/**\r\n * Class used to define a retry strategy when error happens while loading assets\r\n */\r\nvar RetryStrategy = /** @class */ (function () {\r\n function RetryStrategy() {\r\n }\r\n /**\r\n * Function used to defines an exponential back off strategy\r\n * @param maxRetries defines the maximum number of retries (3 by default)\r\n * @param baseInterval defines the interval between retries\r\n * @returns the strategy function to use\r\n */\r\n RetryStrategy.ExponentialBackoff = function (maxRetries, baseInterval) {\r\n if (maxRetries === void 0) { maxRetries = 3; }\r\n if (baseInterval === void 0) { baseInterval = 500; }\r\n return function (url, request, retryIndex) {\r\n if (request.status !== 0 || retryIndex >= maxRetries || url.indexOf(\"file:\") !== -1) {\r\n return -1;\r\n }\r\n return Math.pow(2, retryIndex) * baseInterval;\r\n };\r\n };\r\n return RetryStrategy;\r\n}());\r\nexport { RetryStrategy };\r\n//# sourceMappingURL=retryStrategy.js.map","import { __extends } from \"tslib\";\r\n/**\r\n * @ignore\r\n * Application error to support additional information when loading a file\r\n */\r\nvar BaseError = /** @class */ (function (_super) {\r\n __extends(BaseError, _super);\r\n function BaseError() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n // See https://stackoverflow.com/questions/12915412/how-do-i-extend-a-host-object-e-g-error-in-typescript\r\n // and https://github.com/Microsoft/TypeScript/wiki/Breaking-Changes#extending-built-ins-like-error-array-and-map-may-no-longer-work\r\n // Polyfill for Object.setPrototypeOf if necessary.\r\n BaseError._setPrototypeOf = Object.setPrototypeOf || (function (o, proto) { o.__proto__ = proto; return o; });\r\n return BaseError;\r\n}(Error));\r\nexport { BaseError };\r\n//# sourceMappingURL=baseError.js.map","import { __extends } from \"tslib\";\r\nimport { WebRequest } from './webRequest';\r\nimport { DomManagement } from './domManagement';\r\nimport { Observable } from './observable';\r\nimport { FilesInputStore } from './filesInputStore';\r\nimport { RetryStrategy } from './retryStrategy';\r\nimport { BaseError } from './baseError';\r\nimport { StringTools } from './stringTools';\r\nimport { ThinEngine } from '../Engines/thinEngine';\r\nimport { ShaderProcessor } from '../Engines/Processors/shaderProcessor';\r\n/** @ignore */\r\nvar LoadFileError = /** @class */ (function (_super) {\r\n __extends(LoadFileError, _super);\r\n /**\r\n * Creates a new LoadFileError\r\n * @param message defines the message of the error\r\n * @param request defines the optional web request\r\n * @param file defines the optional file\r\n */\r\n function LoadFileError(message, object) {\r\n var _this = _super.call(this, message) || this;\r\n _this.name = \"LoadFileError\";\r\n BaseError._setPrototypeOf(_this, LoadFileError.prototype);\r\n if (object instanceof WebRequest) {\r\n _this.request = object;\r\n }\r\n else {\r\n _this.file = object;\r\n }\r\n return _this;\r\n }\r\n return LoadFileError;\r\n}(BaseError));\r\nexport { LoadFileError };\r\n/** @ignore */\r\nvar RequestFileError = /** @class */ (function (_super) {\r\n __extends(RequestFileError, _super);\r\n /**\r\n * Creates a new LoadFileError\r\n * @param message defines the message of the error\r\n * @param request defines the optional web request\r\n */\r\n function RequestFileError(message, request) {\r\n var _this = _super.call(this, message) || this;\r\n _this.request = request;\r\n _this.name = \"RequestFileError\";\r\n BaseError._setPrototypeOf(_this, RequestFileError.prototype);\r\n return _this;\r\n }\r\n return RequestFileError;\r\n}(BaseError));\r\nexport { RequestFileError };\r\n/** @ignore */\r\nvar ReadFileError = /** @class */ (function (_super) {\r\n __extends(ReadFileError, _super);\r\n /**\r\n * Creates a new ReadFileError\r\n * @param message defines the message of the error\r\n * @param file defines the optional file\r\n */\r\n function ReadFileError(message, file) {\r\n var _this = _super.call(this, message) || this;\r\n _this.file = file;\r\n _this.name = \"ReadFileError\";\r\n BaseError._setPrototypeOf(_this, ReadFileError.prototype);\r\n return _this;\r\n }\r\n return ReadFileError;\r\n}(BaseError));\r\nexport { ReadFileError };\r\n/**\r\n * @hidden\r\n */\r\nvar FileTools = /** @class */ (function () {\r\n function FileTools() {\r\n }\r\n /**\r\n * Removes unwanted characters from an url\r\n * @param url defines the url to clean\r\n * @returns the cleaned url\r\n */\r\n FileTools._CleanUrl = function (url) {\r\n url = url.replace(/#/mg, \"%23\");\r\n return url;\r\n };\r\n /**\r\n * Sets the cors behavior on a dom element. This will add the required Tools.CorsBehavior to the element.\r\n * @param url define the url we are trying\r\n * @param element define the dom element where to configure the cors policy\r\n */\r\n FileTools.SetCorsBehavior = function (url, element) {\r\n if (url && url.indexOf(\"data:\") === 0) {\r\n return;\r\n }\r\n if (FileTools.CorsBehavior) {\r\n if (typeof (FileTools.CorsBehavior) === 'string' || this.CorsBehavior instanceof String) {\r\n element.crossOrigin = FileTools.CorsBehavior;\r\n }\r\n else {\r\n var result = FileTools.CorsBehavior(url);\r\n if (result) {\r\n element.crossOrigin = result;\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Loads an image as an HTMLImageElement.\r\n * @param input url string, ArrayBuffer, or Blob to load\r\n * @param onLoad callback called when the image successfully loads\r\n * @param onError callback called when the image fails to load\r\n * @param offlineProvider offline provider for caching\r\n * @param mimeType optional mime type\r\n * @returns the HTMLImageElement of the loaded image\r\n */\r\n FileTools.LoadImage = function (input, onLoad, onError, offlineProvider, mimeType) {\r\n if (mimeType === void 0) { mimeType = \"\"; }\r\n var url;\r\n var usingObjectURL = false;\r\n if (input instanceof ArrayBuffer || ArrayBuffer.isView(input)) {\r\n if (typeof Blob !== 'undefined') {\r\n url = URL.createObjectURL(new Blob([input], { type: mimeType }));\r\n usingObjectURL = true;\r\n }\r\n else {\r\n url = \"data:\" + mimeType + \";base64,\" + StringTools.EncodeArrayBufferToBase64(input);\r\n }\r\n }\r\n else if (input instanceof Blob) {\r\n url = URL.createObjectURL(input);\r\n usingObjectURL = true;\r\n }\r\n else {\r\n url = FileTools._CleanUrl(input);\r\n url = FileTools.PreprocessUrl(input);\r\n }\r\n if (typeof Image === \"undefined\") {\r\n FileTools.LoadFile(url, function (data) {\r\n createImageBitmap(new Blob([data], { type: mimeType })).then(function (imgBmp) {\r\n onLoad(imgBmp);\r\n if (usingObjectURL) {\r\n URL.revokeObjectURL(url);\r\n }\r\n }).catch(function (reason) {\r\n if (onError) {\r\n onError(\"Error while trying to load image: \" + input, reason);\r\n }\r\n });\r\n }, undefined, offlineProvider || undefined, true, function (request, exception) {\r\n if (onError) {\r\n onError(\"Error while trying to load image: \" + input, exception);\r\n }\r\n });\r\n return null;\r\n }\r\n var img = new Image();\r\n FileTools.SetCorsBehavior(url, img);\r\n var loadHandler = function () {\r\n img.removeEventListener(\"load\", loadHandler);\r\n img.removeEventListener(\"error\", errorHandler);\r\n onLoad(img);\r\n // Must revoke the URL after calling onLoad to avoid security exceptions in\r\n // certain scenarios (e.g. when hosted in vscode).\r\n if (usingObjectURL && img.src) {\r\n URL.revokeObjectURL(img.src);\r\n }\r\n };\r\n var errorHandler = function (err) {\r\n img.removeEventListener(\"load\", loadHandler);\r\n img.removeEventListener(\"error\", errorHandler);\r\n if (onError) {\r\n onError(\"Error while trying to load image: \" + input, err);\r\n }\r\n if (usingObjectURL && img.src) {\r\n URL.revokeObjectURL(img.src);\r\n }\r\n };\r\n img.addEventListener(\"load\", loadHandler);\r\n img.addEventListener(\"error\", errorHandler);\r\n var noOfflineSupport = function () {\r\n img.src = url;\r\n };\r\n var loadFromOfflineSupport = function () {\r\n if (offlineProvider) {\r\n offlineProvider.loadImage(url, img);\r\n }\r\n };\r\n if (url.substr(0, 5) !== \"data:\" && offlineProvider && offlineProvider.enableTexturesOffline) {\r\n offlineProvider.open(loadFromOfflineSupport, noOfflineSupport);\r\n }\r\n else {\r\n if (url.indexOf(\"file:\") !== -1) {\r\n var textureName = decodeURIComponent(url.substring(5).toLowerCase());\r\n if (FilesInputStore.FilesToLoad[textureName]) {\r\n try {\r\n var blobURL;\r\n try {\r\n blobURL = URL.createObjectURL(FilesInputStore.FilesToLoad[textureName]);\r\n }\r\n catch (ex) {\r\n // Chrome doesn't support oneTimeOnly parameter\r\n blobURL = URL.createObjectURL(FilesInputStore.FilesToLoad[textureName]);\r\n }\r\n img.src = blobURL;\r\n usingObjectURL = true;\r\n }\r\n catch (e) {\r\n img.src = \"\";\r\n }\r\n return img;\r\n }\r\n }\r\n noOfflineSupport();\r\n }\r\n return img;\r\n };\r\n /**\r\n * Reads a file from a File object\r\n * @param file defines the file to load\r\n * @param onSuccess defines the callback to call when data is loaded\r\n * @param onProgress defines the callback to call during loading process\r\n * @param useArrayBuffer defines a boolean indicating that data must be returned as an ArrayBuffer\r\n * @param onError defines the callback to call when an error occurs\r\n * @returns a file request object\r\n */\r\n FileTools.ReadFile = function (file, onSuccess, onProgress, useArrayBuffer, onError) {\r\n var reader = new FileReader();\r\n var request = {\r\n onCompleteObservable: new Observable(),\r\n abort: function () { return reader.abort(); },\r\n };\r\n reader.onloadend = function (e) { return request.onCompleteObservable.notifyObservers(request); };\r\n if (onError) {\r\n reader.onerror = function (e) {\r\n onError(new ReadFileError(\"Unable to read \" + file.name, file));\r\n };\r\n }\r\n reader.onload = function (e) {\r\n //target doesn't have result from ts 1.3\r\n onSuccess(e.target['result']);\r\n };\r\n if (onProgress) {\r\n reader.onprogress = onProgress;\r\n }\r\n if (!useArrayBuffer) {\r\n // Asynchronous read\r\n reader.readAsText(file);\r\n }\r\n else {\r\n reader.readAsArrayBuffer(file);\r\n }\r\n return request;\r\n };\r\n /**\r\n * Loads a file from a url\r\n * @param url url to load\r\n * @param onSuccess callback called when the file successfully loads\r\n * @param onProgress callback called while file is loading (if the server supports this mode)\r\n * @param offlineProvider defines the offline provider for caching\r\n * @param useArrayBuffer defines a boolean indicating that date must be returned as ArrayBuffer\r\n * @param onError callback called when the file fails to load\r\n * @returns a file request object\r\n */\r\n FileTools.LoadFile = function (url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError) {\r\n // If file and file input are set\r\n if (url.indexOf(\"file:\") !== -1) {\r\n var fileName = decodeURIComponent(url.substring(5).toLowerCase());\r\n if (fileName.indexOf('./') === 0) {\r\n fileName = fileName.substring(2);\r\n }\r\n var file = FilesInputStore.FilesToLoad[fileName];\r\n if (file) {\r\n return FileTools.ReadFile(file, onSuccess, onProgress, useArrayBuffer, onError ? function (error) { return onError(undefined, new LoadFileError(error.message, error.file)); } : undefined);\r\n }\r\n }\r\n return FileTools.RequestFile(url, function (data, request) {\r\n onSuccess(data, request ? request.responseURL : undefined);\r\n }, onProgress, offlineProvider, useArrayBuffer, onError ? function (error) {\r\n onError(error.request, new LoadFileError(error.message, error.request));\r\n } : undefined);\r\n };\r\n /**\r\n * Loads a file\r\n * @param url url to load\r\n * @param onSuccess callback called when the file successfully loads\r\n * @param onProgress callback called while file is loading (if the server supports this mode)\r\n * @param useArrayBuffer defines a boolean indicating that date must be returned as ArrayBuffer\r\n * @param onError callback called when the file fails to load\r\n * @param onOpened callback called when the web request is opened\r\n * @returns a file request object\r\n */\r\n FileTools.RequestFile = function (url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError, onOpened) {\r\n url = FileTools._CleanUrl(url);\r\n url = FileTools.PreprocessUrl(url);\r\n var loadUrl = FileTools.BaseUrl + url;\r\n var aborted = false;\r\n var fileRequest = {\r\n onCompleteObservable: new Observable(),\r\n abort: function () { return aborted = true; },\r\n };\r\n var requestFile = function () {\r\n var request = new WebRequest();\r\n var retryHandle = null;\r\n fileRequest.abort = function () {\r\n aborted = true;\r\n if (request.readyState !== (XMLHttpRequest.DONE || 4)) {\r\n request.abort();\r\n }\r\n if (retryHandle !== null) {\r\n clearTimeout(retryHandle);\r\n retryHandle = null;\r\n }\r\n };\r\n var retryLoop = function (retryIndex) {\r\n request.open('GET', loadUrl);\r\n if (onOpened) {\r\n onOpened(request);\r\n }\r\n if (useArrayBuffer) {\r\n request.responseType = \"arraybuffer\";\r\n }\r\n if (onProgress) {\r\n request.addEventListener(\"progress\", onProgress);\r\n }\r\n var onLoadEnd = function () {\r\n request.removeEventListener(\"loadend\", onLoadEnd);\r\n fileRequest.onCompleteObservable.notifyObservers(fileRequest);\r\n fileRequest.onCompleteObservable.clear();\r\n };\r\n request.addEventListener(\"loadend\", onLoadEnd);\r\n var onReadyStateChange = function () {\r\n if (aborted) {\r\n return;\r\n }\r\n // In case of undefined state in some browsers.\r\n if (request.readyState === (XMLHttpRequest.DONE || 4)) {\r\n // Some browsers have issues where onreadystatechange can be called multiple times with the same value.\r\n request.removeEventListener(\"readystatechange\", onReadyStateChange);\r\n if ((request.status >= 200 && request.status < 300) || (request.status === 0 && (!DomManagement.IsWindowObjectExist() || FileTools.IsFileURL()))) {\r\n onSuccess(useArrayBuffer ? request.response : request.responseText, request);\r\n return;\r\n }\r\n var retryStrategy = FileTools.DefaultRetryStrategy;\r\n if (retryStrategy) {\r\n var waitTime = retryStrategy(loadUrl, request, retryIndex);\r\n if (waitTime !== -1) {\r\n // Prevent the request from completing for retry.\r\n request.removeEventListener(\"loadend\", onLoadEnd);\r\n request = new WebRequest();\r\n retryHandle = setTimeout(function () { return retryLoop(retryIndex + 1); }, waitTime);\r\n return;\r\n }\r\n }\r\n var error = new RequestFileError(\"Error status: \" + request.status + \" \" + request.statusText + \" - Unable to load \" + loadUrl, request);\r\n if (onError) {\r\n onError(error);\r\n }\r\n }\r\n };\r\n request.addEventListener(\"readystatechange\", onReadyStateChange);\r\n request.send();\r\n };\r\n retryLoop(0);\r\n };\r\n // Caching all files\r\n if (offlineProvider && offlineProvider.enableSceneOffline) {\r\n var noOfflineSupport_1 = function (request) {\r\n if (request && request.status > 400) {\r\n if (onError) {\r\n onError(request);\r\n }\r\n }\r\n else {\r\n requestFile();\r\n }\r\n };\r\n var loadFromOfflineSupport = function () {\r\n // TODO: database needs to support aborting and should return a IFileRequest\r\n if (offlineProvider) {\r\n offlineProvider.loadFile(FileTools.BaseUrl + url, function (data) {\r\n if (!aborted) {\r\n onSuccess(data);\r\n }\r\n fileRequest.onCompleteObservable.notifyObservers(fileRequest);\r\n }, onProgress ? function (event) {\r\n if (!aborted) {\r\n onProgress(event);\r\n }\r\n } : undefined, noOfflineSupport_1, useArrayBuffer);\r\n }\r\n };\r\n offlineProvider.open(loadFromOfflineSupport, noOfflineSupport_1);\r\n }\r\n else {\r\n requestFile();\r\n }\r\n return fileRequest;\r\n };\r\n /**\r\n * Checks if the loaded document was accessed via `file:`-Protocol.\r\n * @returns boolean\r\n */\r\n FileTools.IsFileURL = function () {\r\n return location.protocol === \"file:\";\r\n };\r\n /**\r\n * Gets or sets the retry strategy to apply when an error happens while loading an asset\r\n */\r\n FileTools.DefaultRetryStrategy = RetryStrategy.ExponentialBackoff();\r\n /**\r\n * Gets or sets the base URL to use to load assets\r\n */\r\n FileTools.BaseUrl = \"\";\r\n /**\r\n * Default behaviour for cors in the application.\r\n * It can be a string if the expected behavior is identical in the entire app.\r\n * Or a callback to be able to set it per url or on a group of them (in case of Video source for instance)\r\n */\r\n FileTools.CorsBehavior = \"anonymous\";\r\n /**\r\n * Gets or sets a function used to pre-process url before using them to load assets\r\n */\r\n FileTools.PreprocessUrl = function (url) {\r\n return url;\r\n };\r\n return FileTools;\r\n}());\r\nexport { FileTools };\r\nThinEngine._FileToolsLoadImage = FileTools.LoadImage.bind(FileTools);\r\nThinEngine._FileToolsLoadFile = FileTools.LoadFile.bind(FileTools);\r\nShaderProcessor._FileToolsLoadFile = FileTools.LoadFile.bind(FileTools);\r\n//# sourceMappingURL=fileTools.js.map","import { DomManagement } from './domManagement';\r\n/**\r\n * Class containing a set of static utilities functions for precision date\r\n */\r\nvar PrecisionDate = /** @class */ (function () {\r\n function PrecisionDate() {\r\n }\r\n Object.defineProperty(PrecisionDate, \"Now\", {\r\n /**\r\n * Gets either window.performance.now() if supported or Date.now() else\r\n */\r\n get: function () {\r\n if (DomManagement.IsWindowObjectExist() && window.performance && window.performance.now) {\r\n return window.performance.now();\r\n }\r\n return Date.now();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n return PrecisionDate;\r\n}());\r\nexport { PrecisionDate };\r\n//# sourceMappingURL=precisionDate.js.map","import { Observable } from \"../../Misc/observable\";\r\nimport { RenderTargetCreationOptions } from \"../../Materials/Textures/renderTargetCreationOptions\";\r\nimport { _DevTools } from '../../Misc/devTools';\r\n/**\r\n * Defines the source of the internal texture\r\n */\r\nexport var InternalTextureSource;\r\n(function (InternalTextureSource) {\r\n /**\r\n * The source of the texture data is unknown\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Unknown\"] = 0] = \"Unknown\";\r\n /**\r\n * Texture data comes from an URL\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Url\"] = 1] = \"Url\";\r\n /**\r\n * Texture data is only used for temporary storage\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Temp\"] = 2] = \"Temp\";\r\n /**\r\n * Texture data comes from raw data (ArrayBuffer)\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Raw\"] = 3] = \"Raw\";\r\n /**\r\n * Texture content is dynamic (video or dynamic texture)\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Dynamic\"] = 4] = \"Dynamic\";\r\n /**\r\n * Texture content is generated by rendering to it\r\n */\r\n InternalTextureSource[InternalTextureSource[\"RenderTarget\"] = 5] = \"RenderTarget\";\r\n /**\r\n * Texture content is part of a multi render target process\r\n */\r\n InternalTextureSource[InternalTextureSource[\"MultiRenderTarget\"] = 6] = \"MultiRenderTarget\";\r\n /**\r\n * Texture data comes from a cube data file\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Cube\"] = 7] = \"Cube\";\r\n /**\r\n * Texture data comes from a raw cube data\r\n */\r\n InternalTextureSource[InternalTextureSource[\"CubeRaw\"] = 8] = \"CubeRaw\";\r\n /**\r\n * Texture data come from a prefiltered cube data file\r\n */\r\n InternalTextureSource[InternalTextureSource[\"CubePrefiltered\"] = 9] = \"CubePrefiltered\";\r\n /**\r\n * Texture content is raw 3D data\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Raw3D\"] = 10] = \"Raw3D\";\r\n /**\r\n * Texture content is raw 2D array data\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Raw2DArray\"] = 11] = \"Raw2DArray\";\r\n /**\r\n * Texture content is a depth texture\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Depth\"] = 12] = \"Depth\";\r\n /**\r\n * Texture data comes from a raw cube data encoded with RGBD\r\n */\r\n InternalTextureSource[InternalTextureSource[\"CubeRawRGBD\"] = 13] = \"CubeRawRGBD\";\r\n})(InternalTextureSource || (InternalTextureSource = {}));\r\n/**\r\n * Class used to store data associated with WebGL texture data for the engine\r\n * This class should not be used directly\r\n */\r\nvar InternalTexture = /** @class */ (function () {\r\n /**\r\n * Creates a new InternalTexture\r\n * @param engine defines the engine to use\r\n * @param source defines the type of data that will be used\r\n * @param delayAllocation if the texture allocation should be delayed (default: false)\r\n */\r\n function InternalTexture(engine, source, delayAllocation) {\r\n if (delayAllocation === void 0) { delayAllocation = false; }\r\n /**\r\n * Defines if the texture is ready\r\n */\r\n this.isReady = false;\r\n /**\r\n * Defines if the texture is a cube texture\r\n */\r\n this.isCube = false;\r\n /**\r\n * Defines if the texture contains 3D data\r\n */\r\n this.is3D = false;\r\n /**\r\n * Defines if the texture contains 2D array data\r\n */\r\n this.is2DArray = false;\r\n /**\r\n * Defines if the texture contains multiview data\r\n */\r\n this.isMultiview = false;\r\n /**\r\n * Gets the URL used to load this texture\r\n */\r\n this.url = \"\";\r\n /**\r\n * Gets the sampling mode of the texture\r\n */\r\n this.samplingMode = -1;\r\n /**\r\n * Gets a boolean indicating if the texture needs mipmaps generation\r\n */\r\n this.generateMipMaps = false;\r\n /**\r\n * Gets the number of samples used by the texture (WebGL2+ only)\r\n */\r\n this.samples = 0;\r\n /**\r\n * Gets the type of the texture (int, float...)\r\n */\r\n this.type = -1;\r\n /**\r\n * Gets the format of the texture (RGB, RGBA...)\r\n */\r\n this.format = -1;\r\n /**\r\n * Observable called when the texture is loaded\r\n */\r\n this.onLoadedObservable = new Observable();\r\n /**\r\n * Gets the width of the texture\r\n */\r\n this.width = 0;\r\n /**\r\n * Gets the height of the texture\r\n */\r\n this.height = 0;\r\n /**\r\n * Gets the depth of the texture\r\n */\r\n this.depth = 0;\r\n /**\r\n * Gets the initial width of the texture (It could be rescaled if the current system does not support non power of two textures)\r\n */\r\n this.baseWidth = 0;\r\n /**\r\n * Gets the initial height of the texture (It could be rescaled if the current system does not support non power of two textures)\r\n */\r\n this.baseHeight = 0;\r\n /**\r\n * Gets the initial depth of the texture (It could be rescaled if the current system does not support non power of two textures)\r\n */\r\n this.baseDepth = 0;\r\n /**\r\n * Gets a boolean indicating if the texture is inverted on Y axis\r\n */\r\n this.invertY = false;\r\n // Private\r\n /** @hidden */\r\n this._invertVScale = false;\r\n /** @hidden */\r\n this._associatedChannel = -1;\r\n /** @hidden */\r\n this._source = InternalTextureSource.Unknown;\r\n /** @hidden */\r\n this._buffer = null;\r\n /** @hidden */\r\n this._bufferView = null;\r\n /** @hidden */\r\n this._bufferViewArray = null;\r\n /** @hidden */\r\n this._bufferViewArrayArray = null;\r\n /** @hidden */\r\n this._size = 0;\r\n /** @hidden */\r\n this._extension = \"\";\r\n /** @hidden */\r\n this._files = null;\r\n /** @hidden */\r\n this._workingCanvas = null;\r\n /** @hidden */\r\n this._workingContext = null;\r\n /** @hidden */\r\n this._framebuffer = null;\r\n /** @hidden */\r\n this._depthStencilBuffer = null;\r\n /** @hidden */\r\n this._MSAAFramebuffer = null;\r\n /** @hidden */\r\n this._MSAARenderBuffer = null;\r\n /** @hidden */\r\n this._attachments = null;\r\n /** @hidden */\r\n this._cachedCoordinatesMode = null;\r\n /** @hidden */\r\n this._cachedWrapU = null;\r\n /** @hidden */\r\n this._cachedWrapV = null;\r\n /** @hidden */\r\n this._cachedWrapR = null;\r\n /** @hidden */\r\n this._cachedAnisotropicFilteringLevel = null;\r\n /** @hidden */\r\n this._isDisabled = false;\r\n /** @hidden */\r\n this._compression = null;\r\n /** @hidden */\r\n this._generateStencilBuffer = false;\r\n /** @hidden */\r\n this._generateDepthBuffer = false;\r\n /** @hidden */\r\n this._comparisonFunction = 0;\r\n /** @hidden */\r\n this._sphericalPolynomial = null;\r\n /** @hidden */\r\n this._lodGenerationScale = 0;\r\n /** @hidden */\r\n this._lodGenerationOffset = 0;\r\n // Multiview\r\n /** @hidden */\r\n this._colorTextureArray = null;\r\n /** @hidden */\r\n this._depthStencilTextureArray = null;\r\n // The following three fields helps sharing generated fixed LODs for texture filtering\r\n // In environment not supporting the textureLOD extension like EDGE. They are for internal use only.\r\n // They are at the level of the gl texture to benefit from the cache.\r\n /** @hidden */\r\n this._lodTextureHigh = null;\r\n /** @hidden */\r\n this._lodTextureMid = null;\r\n /** @hidden */\r\n this._lodTextureLow = null;\r\n /** @hidden */\r\n this._isRGBD = false;\r\n /** @hidden */\r\n this._linearSpecularLOD = false;\r\n /** @hidden */\r\n this._irradianceTexture = null;\r\n /** @hidden */\r\n this._webGLTexture = null;\r\n /** @hidden */\r\n this._references = 1;\r\n this._engine = engine;\r\n this._source = source;\r\n if (!delayAllocation) {\r\n this._webGLTexture = engine._createTexture();\r\n }\r\n }\r\n /**\r\n * Gets the Engine the texture belongs to.\r\n * @returns The babylon engine\r\n */\r\n InternalTexture.prototype.getEngine = function () {\r\n return this._engine;\r\n };\r\n Object.defineProperty(InternalTexture.prototype, \"source\", {\r\n /**\r\n * Gets the data source type of the texture\r\n */\r\n get: function () {\r\n return this._source;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Increments the number of references (ie. the number of Texture that point to it)\r\n */\r\n InternalTexture.prototype.incrementReferences = function () {\r\n this._references++;\r\n };\r\n /**\r\n * Change the size of the texture (not the size of the content)\r\n * @param width defines the new width\r\n * @param height defines the new height\r\n * @param depth defines the new depth (1 by default)\r\n */\r\n InternalTexture.prototype.updateSize = function (width, height, depth) {\r\n if (depth === void 0) { depth = 1; }\r\n this.width = width;\r\n this.height = height;\r\n this.depth = depth;\r\n this.baseWidth = width;\r\n this.baseHeight = height;\r\n this.baseDepth = depth;\r\n this._size = width * height * depth;\r\n };\r\n /** @hidden */\r\n InternalTexture.prototype._rebuild = function () {\r\n var _this = this;\r\n var proxy;\r\n this.isReady = false;\r\n this._cachedCoordinatesMode = null;\r\n this._cachedWrapU = null;\r\n this._cachedWrapV = null;\r\n this._cachedAnisotropicFilteringLevel = null;\r\n switch (this.source) {\r\n case InternalTextureSource.Temp:\r\n return;\r\n case InternalTextureSource.Url:\r\n proxy = this._engine.createTexture(this.url, !this.generateMipMaps, this.invertY, null, this.samplingMode, function () {\r\n proxy._swapAndDie(_this);\r\n _this.isReady = true;\r\n }, null, this._buffer, undefined, this.format);\r\n return;\r\n case InternalTextureSource.Raw:\r\n proxy = this._engine.createRawTexture(this._bufferView, this.baseWidth, this.baseHeight, this.format, this.generateMipMaps, this.invertY, this.samplingMode, this._compression);\r\n proxy._swapAndDie(this);\r\n this.isReady = true;\r\n return;\r\n case InternalTextureSource.Raw3D:\r\n proxy = this._engine.createRawTexture3D(this._bufferView, this.baseWidth, this.baseHeight, this.baseDepth, this.format, this.generateMipMaps, this.invertY, this.samplingMode, this._compression);\r\n proxy._swapAndDie(this);\r\n this.isReady = true;\r\n return;\r\n case InternalTextureSource.Raw2DArray:\r\n proxy = this._engine.createRawTexture2DArray(this._bufferView, this.baseWidth, this.baseHeight, this.baseDepth, this.format, this.generateMipMaps, this.invertY, this.samplingMode, this._compression);\r\n proxy._swapAndDie(this);\r\n this.isReady = true;\r\n return;\r\n case InternalTextureSource.Dynamic:\r\n proxy = this._engine.createDynamicTexture(this.baseWidth, this.baseHeight, this.generateMipMaps, this.samplingMode);\r\n proxy._swapAndDie(this);\r\n this._engine.updateDynamicTexture(this, this._engine.getRenderingCanvas(), this.invertY, undefined, undefined, true);\r\n // The engine will make sure to update content so no need to flag it as isReady = true\r\n return;\r\n case InternalTextureSource.RenderTarget:\r\n var options = new RenderTargetCreationOptions();\r\n options.generateDepthBuffer = this._generateDepthBuffer;\r\n options.generateMipMaps = this.generateMipMaps;\r\n options.generateStencilBuffer = this._generateStencilBuffer;\r\n options.samplingMode = this.samplingMode;\r\n options.type = this.type;\r\n if (this.isCube) {\r\n proxy = this._engine.createRenderTargetCubeTexture(this.width, options);\r\n }\r\n else {\r\n var size_1 = {\r\n width: this.width,\r\n height: this.height,\r\n layers: this.is2DArray ? this.depth : undefined\r\n };\r\n proxy = this._engine.createRenderTargetTexture(size_1, options);\r\n }\r\n proxy._swapAndDie(this);\r\n this.isReady = true;\r\n return;\r\n case InternalTextureSource.Depth:\r\n var depthTextureOptions = {\r\n bilinearFiltering: this.samplingMode !== 2,\r\n comparisonFunction: this._comparisonFunction,\r\n generateStencil: this._generateStencilBuffer,\r\n isCube: this.isCube\r\n };\r\n var size = {\r\n width: this.width,\r\n height: this.height,\r\n layers: this.is2DArray ? this.depth : undefined\r\n };\r\n proxy = this._engine.createDepthStencilTexture(size, depthTextureOptions);\r\n proxy._swapAndDie(this);\r\n this.isReady = true;\r\n return;\r\n case InternalTextureSource.Cube:\r\n proxy = this._engine.createCubeTexture(this.url, null, this._files, !this.generateMipMaps, function () {\r\n proxy._swapAndDie(_this);\r\n _this.isReady = true;\r\n }, null, this.format, this._extension);\r\n return;\r\n case InternalTextureSource.CubeRaw:\r\n proxy = this._engine.createRawCubeTexture(this._bufferViewArray, this.width, this.format, this.type, this.generateMipMaps, this.invertY, this.samplingMode, this._compression);\r\n proxy._swapAndDie(this);\r\n this.isReady = true;\r\n return;\r\n case InternalTextureSource.CubeRawRGBD:\r\n proxy = this._engine.createRawCubeTexture(null, this.width, this.format, this.type, this.generateMipMaps, this.invertY, this.samplingMode, this._compression);\r\n InternalTexture._UpdateRGBDAsync(proxy, this._bufferViewArrayArray, this._sphericalPolynomial, this._lodGenerationScale, this._lodGenerationOffset).then(function () {\r\n proxy._swapAndDie(_this);\r\n _this.isReady = true;\r\n });\r\n return;\r\n case InternalTextureSource.CubePrefiltered:\r\n proxy = this._engine.createPrefilteredCubeTexture(this.url, null, this._lodGenerationScale, this._lodGenerationOffset, function (proxy) {\r\n if (proxy) {\r\n proxy._swapAndDie(_this);\r\n }\r\n _this.isReady = true;\r\n }, null, this.format, this._extension);\r\n proxy._sphericalPolynomial = this._sphericalPolynomial;\r\n return;\r\n }\r\n };\r\n /** @hidden */\r\n InternalTexture.prototype._swapAndDie = function (target) {\r\n target._webGLTexture = this._webGLTexture;\r\n target._isRGBD = this._isRGBD;\r\n if (this._framebuffer) {\r\n target._framebuffer = this._framebuffer;\r\n }\r\n if (this._depthStencilBuffer) {\r\n target._depthStencilBuffer = this._depthStencilBuffer;\r\n }\r\n target._depthStencilTexture = this._depthStencilTexture;\r\n if (this._lodTextureHigh) {\r\n if (target._lodTextureHigh) {\r\n target._lodTextureHigh.dispose();\r\n }\r\n target._lodTextureHigh = this._lodTextureHigh;\r\n }\r\n if (this._lodTextureMid) {\r\n if (target._lodTextureMid) {\r\n target._lodTextureMid.dispose();\r\n }\r\n target._lodTextureMid = this._lodTextureMid;\r\n }\r\n if (this._lodTextureLow) {\r\n if (target._lodTextureLow) {\r\n target._lodTextureLow.dispose();\r\n }\r\n target._lodTextureLow = this._lodTextureLow;\r\n }\r\n if (this._irradianceTexture) {\r\n if (target._irradianceTexture) {\r\n target._irradianceTexture.dispose();\r\n }\r\n target._irradianceTexture = this._irradianceTexture;\r\n }\r\n var cache = this._engine.getLoadedTexturesCache();\r\n var index = cache.indexOf(this);\r\n if (index !== -1) {\r\n cache.splice(index, 1);\r\n }\r\n var index = cache.indexOf(target);\r\n if (index === -1) {\r\n cache.push(target);\r\n }\r\n };\r\n /**\r\n * Dispose the current allocated resources\r\n */\r\n InternalTexture.prototype.dispose = function () {\r\n if (!this._webGLTexture) {\r\n return;\r\n }\r\n this._references--;\r\n if (this._references === 0) {\r\n this._engine._releaseTexture(this);\r\n this._webGLTexture = null;\r\n }\r\n };\r\n /** @hidden */\r\n InternalTexture._UpdateRGBDAsync = function (internalTexture, data, sphericalPolynomial, lodScale, lodOffset) {\r\n throw _DevTools.WarnImport(\"environmentTextureTools\");\r\n };\r\n return InternalTexture;\r\n}());\r\nexport { InternalTexture };\r\n//# sourceMappingURL=internalTexture.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, serializeAsVector3, serializeAsQuaternion, SerializationHelper } from \"../Misc/decorators\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { Quaternion, Matrix, Vector3, TmpVectors } from \"../Maths/math.vector\";\r\nimport { Node } from \"../node\";\r\nimport { Space } from '../Maths/math.axis';\r\n/**\r\n * A TransformNode is an object that is not rendered but can be used as a center of transformation. This can decrease memory usage and increase rendering speed compared to using an empty mesh as a parent and is less complicated than using a pivot matrix.\r\n * @see https://doc.babylonjs.com/how_to/transformnode\r\n */\r\nvar TransformNode = /** @class */ (function (_super) {\r\n __extends(TransformNode, _super);\r\n function TransformNode(name, scene, isPure) {\r\n if (scene === void 0) { scene = null; }\r\n if (isPure === void 0) { isPure = true; }\r\n var _this = _super.call(this, name, scene) || this;\r\n _this._forward = new Vector3(0, 0, 1);\r\n _this._forwardInverted = new Vector3(0, 0, -1);\r\n _this._up = new Vector3(0, 1, 0);\r\n _this._right = new Vector3(1, 0, 0);\r\n _this._rightInverted = new Vector3(-1, 0, 0);\r\n // Properties\r\n _this._position = Vector3.Zero();\r\n _this._rotation = Vector3.Zero();\r\n _this._rotationQuaternion = null;\r\n _this._scaling = Vector3.One();\r\n _this._isDirty = false;\r\n _this._transformToBoneReferal = null;\r\n _this._isAbsoluteSynced = false;\r\n _this._billboardMode = TransformNode.BILLBOARDMODE_NONE;\r\n _this._preserveParentRotationForBillboard = false;\r\n /**\r\n * Multiplication factor on scale x/y/z when computing the world matrix. Eg. for a 1x1x1 cube setting this to 2 will make it a 2x2x2 cube\r\n */\r\n _this.scalingDeterminant = 1;\r\n _this._infiniteDistance = false;\r\n /**\r\n * Gets or sets a boolean indicating that non uniform scaling (when at least one component is different from others) should be ignored.\r\n * By default the system will update normals to compensate\r\n */\r\n _this.ignoreNonUniformScaling = false;\r\n /**\r\n * Gets or sets a boolean indicating that even if rotationQuaternion is defined, you can keep updating rotation property and Babylon.js will just mix both\r\n */\r\n _this.reIntegrateRotationIntoRotationQuaternion = false;\r\n // Cache\r\n /** @hidden */\r\n _this._poseMatrix = null;\r\n /** @hidden */\r\n _this._localMatrix = Matrix.Zero();\r\n _this._usePivotMatrix = false;\r\n _this._absolutePosition = Vector3.Zero();\r\n _this._absoluteScaling = Vector3.Zero();\r\n _this._absoluteRotationQuaternion = Quaternion.Identity();\r\n _this._pivotMatrix = Matrix.Identity();\r\n _this._postMultiplyPivotMatrix = false;\r\n _this._isWorldMatrixFrozen = false;\r\n /** @hidden */\r\n _this._indexInSceneTransformNodesArray = -1;\r\n /**\r\n * An event triggered after the world matrix is updated\r\n */\r\n _this.onAfterWorldMatrixUpdateObservable = new Observable();\r\n _this._nonUniformScaling = false;\r\n if (isPure) {\r\n _this.getScene().addTransformNode(_this);\r\n }\r\n return _this;\r\n }\r\n Object.defineProperty(TransformNode.prototype, \"billboardMode\", {\r\n /**\r\n * Gets or sets the billboard mode. Default is 0.\r\n *\r\n * | Value | Type | Description |\r\n * | --- | --- | --- |\r\n * | 0 | BILLBOARDMODE_NONE | |\r\n * | 1 | BILLBOARDMODE_X | |\r\n * | 2 | BILLBOARDMODE_Y | |\r\n * | 4 | BILLBOARDMODE_Z | |\r\n * | 7 | BILLBOARDMODE_ALL | |\r\n *\r\n */\r\n get: function () {\r\n return this._billboardMode;\r\n },\r\n set: function (value) {\r\n if (this._billboardMode === value) {\r\n return;\r\n }\r\n this._billboardMode = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"preserveParentRotationForBillboard\", {\r\n /**\r\n * Gets or sets a boolean indicating that parent rotation should be preserved when using billboards.\r\n * This could be useful for glTF objects where parent rotation helps converting from right handed to left handed\r\n */\r\n get: function () {\r\n return this._preserveParentRotationForBillboard;\r\n },\r\n set: function (value) {\r\n if (value === this._preserveParentRotationForBillboard) {\r\n return;\r\n }\r\n this._preserveParentRotationForBillboard = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"infiniteDistance\", {\r\n /**\r\n * Gets or sets the distance of the object to max, often used by skybox\r\n */\r\n get: function () {\r\n return this._infiniteDistance;\r\n },\r\n set: function (value) {\r\n if (this._infiniteDistance === value) {\r\n return;\r\n }\r\n this._infiniteDistance = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets a string identifying the name of the class\r\n * @returns \"TransformNode\" string\r\n */\r\n TransformNode.prototype.getClassName = function () {\r\n return \"TransformNode\";\r\n };\r\n Object.defineProperty(TransformNode.prototype, \"position\", {\r\n /**\r\n * Gets or set the node position (default is (0.0, 0.0, 0.0))\r\n */\r\n get: function () {\r\n return this._position;\r\n },\r\n set: function (newPosition) {\r\n this._position = newPosition;\r\n this._isDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"rotation\", {\r\n /**\r\n * Gets or sets the rotation property : a Vector3 defining the rotation value in radians around each local axis X, Y, Z (default is (0.0, 0.0, 0.0)).\r\n * If rotation quaternion is set, this Vector3 will be ignored and copy from the quaternion\r\n */\r\n get: function () {\r\n return this._rotation;\r\n },\r\n set: function (newRotation) {\r\n this._rotation = newRotation;\r\n this._rotationQuaternion = null;\r\n this._isDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"scaling\", {\r\n /**\r\n * Gets or sets the scaling property : a Vector3 defining the node scaling along each local axis X, Y, Z (default is (0.0, 0.0, 0.0)).\r\n */\r\n get: function () {\r\n return this._scaling;\r\n },\r\n set: function (newScaling) {\r\n this._scaling = newScaling;\r\n this._isDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"rotationQuaternion\", {\r\n /**\r\n * Gets or sets the rotation Quaternion property : this a Quaternion object defining the node rotation by using a unit quaternion (undefined by default, but can be null).\r\n * If set, only the rotationQuaternion is then used to compute the node rotation (ie. node.rotation will be ignored)\r\n */\r\n get: function () {\r\n return this._rotationQuaternion;\r\n },\r\n set: function (quaternion) {\r\n this._rotationQuaternion = quaternion;\r\n //reset the rotation vector.\r\n if (quaternion) {\r\n this._rotation.setAll(0.0);\r\n }\r\n this._isDirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"forward\", {\r\n /**\r\n * The forward direction of that transform in world space.\r\n */\r\n get: function () {\r\n return Vector3.Normalize(Vector3.TransformNormal(this.getScene().useRightHandedSystem ? this._forwardInverted : this._forward, this.getWorldMatrix()));\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"up\", {\r\n /**\r\n * The up direction of that transform in world space.\r\n */\r\n get: function () {\r\n return Vector3.Normalize(Vector3.TransformNormal(this._up, this.getWorldMatrix()));\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"right\", {\r\n /**\r\n * The right direction of that transform in world space.\r\n */\r\n get: function () {\r\n return Vector3.Normalize(Vector3.TransformNormal(this.getScene().useRightHandedSystem ? this._rightInverted : this._right, this.getWorldMatrix()));\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Copies the parameter passed Matrix into the mesh Pose matrix.\r\n * @param matrix the matrix to copy the pose from\r\n * @returns this TransformNode.\r\n */\r\n TransformNode.prototype.updatePoseMatrix = function (matrix) {\r\n if (!this._poseMatrix) {\r\n this._poseMatrix = matrix.clone();\r\n return this;\r\n }\r\n this._poseMatrix.copyFrom(matrix);\r\n return this;\r\n };\r\n /**\r\n * Returns the mesh Pose matrix.\r\n * @returns the pose matrix\r\n */\r\n TransformNode.prototype.getPoseMatrix = function () {\r\n if (!this._poseMatrix) {\r\n this._poseMatrix = Matrix.Identity();\r\n }\r\n return this._poseMatrix;\r\n };\r\n /** @hidden */\r\n TransformNode.prototype._isSynchronized = function () {\r\n var cache = this._cache;\r\n if (this.billboardMode !== cache.billboardMode || this.billboardMode !== TransformNode.BILLBOARDMODE_NONE) {\r\n return false;\r\n }\r\n if (cache.pivotMatrixUpdated) {\r\n return false;\r\n }\r\n if (this.infiniteDistance) {\r\n return false;\r\n }\r\n if (!cache.position.equals(this._position)) {\r\n return false;\r\n }\r\n if (this._rotationQuaternion) {\r\n if (!cache.rotationQuaternion.equals(this._rotationQuaternion)) {\r\n return false;\r\n }\r\n }\r\n else if (!cache.rotation.equals(this._rotation)) {\r\n return false;\r\n }\r\n if (!cache.scaling.equals(this._scaling)) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n /** @hidden */\r\n TransformNode.prototype._initCache = function () {\r\n _super.prototype._initCache.call(this);\r\n var cache = this._cache;\r\n cache.localMatrixUpdated = false;\r\n cache.position = Vector3.Zero();\r\n cache.scaling = Vector3.Zero();\r\n cache.rotation = Vector3.Zero();\r\n cache.rotationQuaternion = new Quaternion(0, 0, 0, 0);\r\n cache.billboardMode = -1;\r\n cache.infiniteDistance = false;\r\n };\r\n /**\r\n * Flag the transform node as dirty (Forcing it to update everything)\r\n * @param property if set to \"rotation\" the objects rotationQuaternion will be set to null\r\n * @returns this transform node\r\n */\r\n TransformNode.prototype.markAsDirty = function (property) {\r\n this._currentRenderId = Number.MAX_VALUE;\r\n this._isDirty = true;\r\n return this;\r\n };\r\n Object.defineProperty(TransformNode.prototype, \"absolutePosition\", {\r\n /**\r\n * Returns the current mesh absolute position.\r\n * Returns a Vector3.\r\n */\r\n get: function () {\r\n return this._absolutePosition;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"absoluteScaling\", {\r\n /**\r\n * Returns the current mesh absolute scaling.\r\n * Returns a Vector3.\r\n */\r\n get: function () {\r\n this._syncAbsoluteScalingAndRotation();\r\n return this._absoluteScaling;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"absoluteRotationQuaternion\", {\r\n /**\r\n * Returns the current mesh absolute rotation.\r\n * Returns a Quaternion.\r\n */\r\n get: function () {\r\n this._syncAbsoluteScalingAndRotation();\r\n return this._absoluteRotationQuaternion;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Sets a new matrix to apply before all other transformation\r\n * @param matrix defines the transform matrix\r\n * @returns the current TransformNode\r\n */\r\n TransformNode.prototype.setPreTransformMatrix = function (matrix) {\r\n return this.setPivotMatrix(matrix, false);\r\n };\r\n /**\r\n * Sets a new pivot matrix to the current node\r\n * @param matrix defines the new pivot matrix to use\r\n * @param postMultiplyPivotMatrix defines if the pivot matrix must be cancelled in the world matrix. When this parameter is set to true (default), the inverse of the pivot matrix is also applied at the end to cancel the transformation effect\r\n * @returns the current TransformNode\r\n */\r\n TransformNode.prototype.setPivotMatrix = function (matrix, postMultiplyPivotMatrix) {\r\n if (postMultiplyPivotMatrix === void 0) { postMultiplyPivotMatrix = true; }\r\n this._pivotMatrix.copyFrom(matrix);\r\n this._usePivotMatrix = !this._pivotMatrix.isIdentity();\r\n this._cache.pivotMatrixUpdated = true;\r\n this._postMultiplyPivotMatrix = postMultiplyPivotMatrix;\r\n if (this._postMultiplyPivotMatrix) {\r\n if (!this._pivotMatrixInverse) {\r\n this._pivotMatrixInverse = Matrix.Invert(this._pivotMatrix);\r\n }\r\n else {\r\n this._pivotMatrix.invertToRef(this._pivotMatrixInverse);\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Returns the mesh pivot matrix.\r\n * Default : Identity.\r\n * @returns the matrix\r\n */\r\n TransformNode.prototype.getPivotMatrix = function () {\r\n return this._pivotMatrix;\r\n };\r\n /**\r\n * Instantiate (when possible) or clone that node with its hierarchy\r\n * @param newParent defines the new parent to use for the instance (or clone)\r\n * @param options defines options to configure how copy is done\r\n * @param onNewNodeCreated defines an option callback to call when a clone or an instance is created\r\n * @returns an instance (or a clone) of the current node with its hiearchy\r\n */\r\n TransformNode.prototype.instantiateHierarchy = function (newParent, options, onNewNodeCreated) {\r\n if (newParent === void 0) { newParent = null; }\r\n var clone = this.clone(\"Clone of \" + (this.name || this.id), newParent || this.parent, true);\r\n if (clone) {\r\n if (onNewNodeCreated) {\r\n onNewNodeCreated(this, clone);\r\n }\r\n }\r\n for (var _i = 0, _a = this.getChildTransformNodes(true); _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child.instantiateHierarchy(clone, options, onNewNodeCreated);\r\n }\r\n return clone;\r\n };\r\n /**\r\n * Prevents the World matrix to be computed any longer\r\n * @param newWorldMatrix defines an optional matrix to use as world matrix\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.freezeWorldMatrix = function (newWorldMatrix) {\r\n if (newWorldMatrix === void 0) { newWorldMatrix = null; }\r\n if (newWorldMatrix) {\r\n this._worldMatrix = newWorldMatrix;\r\n }\r\n else {\r\n this._isWorldMatrixFrozen = false; // no guarantee world is not already frozen, switch off temporarily\r\n this.computeWorldMatrix(true);\r\n }\r\n this._isDirty = false;\r\n this._isWorldMatrixFrozen = true;\r\n return this;\r\n };\r\n /**\r\n * Allows back the World matrix computation.\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.unfreezeWorldMatrix = function () {\r\n this._isWorldMatrixFrozen = false;\r\n this.computeWorldMatrix(true);\r\n return this;\r\n };\r\n Object.defineProperty(TransformNode.prototype, \"isWorldMatrixFrozen\", {\r\n /**\r\n * True if the World matrix has been frozen.\r\n */\r\n get: function () {\r\n return this._isWorldMatrixFrozen;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Retuns the mesh absolute position in the World.\r\n * @returns a Vector3.\r\n */\r\n TransformNode.prototype.getAbsolutePosition = function () {\r\n this.computeWorldMatrix();\r\n return this._absolutePosition;\r\n };\r\n /**\r\n * Sets the mesh absolute position in the World from a Vector3 or an Array(3).\r\n * @param absolutePosition the absolute position to set\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.setAbsolutePosition = function (absolutePosition) {\r\n if (!absolutePosition) {\r\n return this;\r\n }\r\n var absolutePositionX;\r\n var absolutePositionY;\r\n var absolutePositionZ;\r\n if (absolutePosition.x === undefined) {\r\n if (arguments.length < 3) {\r\n return this;\r\n }\r\n absolutePositionX = arguments[0];\r\n absolutePositionY = arguments[1];\r\n absolutePositionZ = arguments[2];\r\n }\r\n else {\r\n absolutePositionX = absolutePosition.x;\r\n absolutePositionY = absolutePosition.y;\r\n absolutePositionZ = absolutePosition.z;\r\n }\r\n if (this.parent) {\r\n var invertParentWorldMatrix = TmpVectors.Matrix[0];\r\n this.parent.getWorldMatrix().invertToRef(invertParentWorldMatrix);\r\n Vector3.TransformCoordinatesFromFloatsToRef(absolutePositionX, absolutePositionY, absolutePositionZ, invertParentWorldMatrix, this.position);\r\n }\r\n else {\r\n this.position.x = absolutePositionX;\r\n this.position.y = absolutePositionY;\r\n this.position.z = absolutePositionZ;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets the mesh position in its local space.\r\n * @param vector3 the position to set in localspace\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.setPositionWithLocalVector = function (vector3) {\r\n this.computeWorldMatrix();\r\n this.position = Vector3.TransformNormal(vector3, this._localMatrix);\r\n return this;\r\n };\r\n /**\r\n * Returns the mesh position in the local space from the current World matrix values.\r\n * @returns a new Vector3.\r\n */\r\n TransformNode.prototype.getPositionExpressedInLocalSpace = function () {\r\n this.computeWorldMatrix();\r\n var invLocalWorldMatrix = TmpVectors.Matrix[0];\r\n this._localMatrix.invertToRef(invLocalWorldMatrix);\r\n return Vector3.TransformNormal(this.position, invLocalWorldMatrix);\r\n };\r\n /**\r\n * Translates the mesh along the passed Vector3 in its local space.\r\n * @param vector3 the distance to translate in localspace\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.locallyTranslate = function (vector3) {\r\n this.computeWorldMatrix(true);\r\n this.position = Vector3.TransformCoordinates(vector3, this._localMatrix);\r\n return this;\r\n };\r\n /**\r\n * Orients a mesh towards a target point. Mesh must be drawn facing user.\r\n * @param targetPoint the position (must be in same space as current mesh) to look at\r\n * @param yawCor optional yaw (y-axis) correction in radians\r\n * @param pitchCor optional pitch (x-axis) correction in radians\r\n * @param rollCor optional roll (z-axis) correction in radians\r\n * @param space the choosen space of the target\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.lookAt = function (targetPoint, yawCor, pitchCor, rollCor, space) {\r\n if (yawCor === void 0) { yawCor = 0; }\r\n if (pitchCor === void 0) { pitchCor = 0; }\r\n if (rollCor === void 0) { rollCor = 0; }\r\n if (space === void 0) { space = Space.LOCAL; }\r\n var dv = TransformNode._lookAtVectorCache;\r\n var pos = space === Space.LOCAL ? this.position : this.getAbsolutePosition();\r\n targetPoint.subtractToRef(pos, dv);\r\n this.setDirection(dv, yawCor, pitchCor, rollCor);\r\n // Correct for parent's rotation offset\r\n if (space === Space.WORLD && this.parent) {\r\n if (this.rotationQuaternion) {\r\n // Get local rotation matrix of the looking object\r\n var rotationMatrix = TmpVectors.Matrix[0];\r\n this.rotationQuaternion.toRotationMatrix(rotationMatrix);\r\n // Offset rotation by parent's inverted rotation matrix to correct in world space\r\n var parentRotationMatrix = TmpVectors.Matrix[1];\r\n this.parent.getWorldMatrix().getRotationMatrixToRef(parentRotationMatrix);\r\n parentRotationMatrix.invert();\r\n rotationMatrix.multiplyToRef(parentRotationMatrix, rotationMatrix);\r\n this.rotationQuaternion.fromRotationMatrix(rotationMatrix);\r\n }\r\n else {\r\n // Get local rotation matrix of the looking object\r\n var quaternionRotation = TmpVectors.Quaternion[0];\r\n Quaternion.FromEulerVectorToRef(this.rotation, quaternionRotation);\r\n var rotationMatrix = TmpVectors.Matrix[0];\r\n quaternionRotation.toRotationMatrix(rotationMatrix);\r\n // Offset rotation by parent's inverted rotation matrix to correct in world space\r\n var parentRotationMatrix = TmpVectors.Matrix[1];\r\n this.parent.getWorldMatrix().getRotationMatrixToRef(parentRotationMatrix);\r\n parentRotationMatrix.invert();\r\n rotationMatrix.multiplyToRef(parentRotationMatrix, rotationMatrix);\r\n quaternionRotation.fromRotationMatrix(rotationMatrix);\r\n quaternionRotation.toEulerAnglesToRef(this.rotation);\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector3 that is the localAxis, expressed in the mesh local space, rotated like the mesh.\r\n * This Vector3 is expressed in the World space.\r\n * @param localAxis axis to rotate\r\n * @returns a new Vector3 that is the localAxis, expressed in the mesh local space, rotated like the mesh.\r\n */\r\n TransformNode.prototype.getDirection = function (localAxis) {\r\n var result = Vector3.Zero();\r\n this.getDirectionToRef(localAxis, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the Vector3 \"result\" as the rotated Vector3 \"localAxis\" in the same rotation than the mesh.\r\n * localAxis is expressed in the mesh local space.\r\n * result is computed in the Wordl space from the mesh World matrix.\r\n * @param localAxis axis to rotate\r\n * @param result the resulting transformnode\r\n * @returns this TransformNode.\r\n */\r\n TransformNode.prototype.getDirectionToRef = function (localAxis, result) {\r\n Vector3.TransformNormalToRef(localAxis, this.getWorldMatrix(), result);\r\n return this;\r\n };\r\n /**\r\n * Sets this transform node rotation to the given local axis.\r\n * @param localAxis the axis in local space\r\n * @param yawCor optional yaw (y-axis) correction in radians\r\n * @param pitchCor optional pitch (x-axis) correction in radians\r\n * @param rollCor optional roll (z-axis) correction in radians\r\n * @returns this TransformNode\r\n */\r\n TransformNode.prototype.setDirection = function (localAxis, yawCor, pitchCor, rollCor) {\r\n if (yawCor === void 0) { yawCor = 0; }\r\n if (pitchCor === void 0) { pitchCor = 0; }\r\n if (rollCor === void 0) { rollCor = 0; }\r\n var yaw = -Math.atan2(localAxis.z, localAxis.x) + Math.PI / 2;\r\n var len = Math.sqrt(localAxis.x * localAxis.x + localAxis.z * localAxis.z);\r\n var pitch = -Math.atan2(localAxis.y, len);\r\n if (this.rotationQuaternion) {\r\n Quaternion.RotationYawPitchRollToRef(yaw + yawCor, pitch + pitchCor, rollCor, this.rotationQuaternion);\r\n }\r\n else {\r\n this.rotation.x = pitch + pitchCor;\r\n this.rotation.y = yaw + yawCor;\r\n this.rotation.z = rollCor;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a new pivot point to the current node\r\n * @param point defines the new pivot point to use\r\n * @param space defines if the point is in world or local space (local by default)\r\n * @returns the current TransformNode\r\n */\r\n TransformNode.prototype.setPivotPoint = function (point, space) {\r\n if (space === void 0) { space = Space.LOCAL; }\r\n if (this.getScene().getRenderId() == 0) {\r\n this.computeWorldMatrix(true);\r\n }\r\n var wm = this.getWorldMatrix();\r\n if (space == Space.WORLD) {\r\n var tmat = TmpVectors.Matrix[0];\r\n wm.invertToRef(tmat);\r\n point = Vector3.TransformCoordinates(point, tmat);\r\n }\r\n return this.setPivotMatrix(Matrix.Translation(-point.x, -point.y, -point.z), true);\r\n };\r\n /**\r\n * Returns a new Vector3 set with the mesh pivot point coordinates in the local space.\r\n * @returns the pivot point\r\n */\r\n TransformNode.prototype.getPivotPoint = function () {\r\n var point = Vector3.Zero();\r\n this.getPivotPointToRef(point);\r\n return point;\r\n };\r\n /**\r\n * Sets the passed Vector3 \"result\" with the coordinates of the mesh pivot point in the local space.\r\n * @param result the vector3 to store the result\r\n * @returns this TransformNode.\r\n */\r\n TransformNode.prototype.getPivotPointToRef = function (result) {\r\n result.x = -this._pivotMatrix.m[12];\r\n result.y = -this._pivotMatrix.m[13];\r\n result.z = -this._pivotMatrix.m[14];\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector3 set with the mesh pivot point World coordinates.\r\n * @returns a new Vector3 set with the mesh pivot point World coordinates.\r\n */\r\n TransformNode.prototype.getAbsolutePivotPoint = function () {\r\n var point = Vector3.Zero();\r\n this.getAbsolutePivotPointToRef(point);\r\n return point;\r\n };\r\n /**\r\n * Sets the Vector3 \"result\" coordinates with the mesh pivot point World coordinates.\r\n * @param result vector3 to store the result\r\n * @returns this TransformNode.\r\n */\r\n TransformNode.prototype.getAbsolutePivotPointToRef = function (result) {\r\n result.x = this._pivotMatrix.m[12];\r\n result.y = this._pivotMatrix.m[13];\r\n result.z = this._pivotMatrix.m[14];\r\n this.getPivotPointToRef(result);\r\n Vector3.TransformCoordinatesToRef(result, this.getWorldMatrix(), result);\r\n return this;\r\n };\r\n /**\r\n * Defines the passed node as the parent of the current node.\r\n * The node will remain exactly where it is and its position / rotation will be updated accordingly\r\n * @see https://doc.babylonjs.com/how_to/parenting\r\n * @param node the node ot set as the parent\r\n * @returns this TransformNode.\r\n */\r\n TransformNode.prototype.setParent = function (node) {\r\n if (!node && !this.parent) {\r\n return this;\r\n }\r\n var quatRotation = TmpVectors.Quaternion[0];\r\n var position = TmpVectors.Vector3[0];\r\n var scale = TmpVectors.Vector3[1];\r\n if (!node) {\r\n this.computeWorldMatrix(true);\r\n this.getWorldMatrix().decompose(scale, quatRotation, position);\r\n }\r\n else {\r\n var diffMatrix = TmpVectors.Matrix[0];\r\n var invParentMatrix = TmpVectors.Matrix[1];\r\n this.computeWorldMatrix(true);\r\n node.computeWorldMatrix(true);\r\n node.getWorldMatrix().invertToRef(invParentMatrix);\r\n this.getWorldMatrix().multiplyToRef(invParentMatrix, diffMatrix);\r\n diffMatrix.decompose(scale, quatRotation, position);\r\n }\r\n if (this.rotationQuaternion) {\r\n this.rotationQuaternion.copyFrom(quatRotation);\r\n }\r\n else {\r\n quatRotation.toEulerAnglesToRef(this.rotation);\r\n }\r\n this.scaling.copyFrom(scale);\r\n this.position.copyFrom(position);\r\n this.parent = node;\r\n return this;\r\n };\r\n Object.defineProperty(TransformNode.prototype, \"nonUniformScaling\", {\r\n /**\r\n * True if the scaling property of this object is non uniform eg. (1,2,1)\r\n */\r\n get: function () {\r\n return this._nonUniformScaling;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n TransformNode.prototype._updateNonUniformScalingState = function (value) {\r\n if (this._nonUniformScaling === value) {\r\n return false;\r\n }\r\n this._nonUniformScaling = value;\r\n return true;\r\n };\r\n /**\r\n * Attach the current TransformNode to another TransformNode associated with a bone\r\n * @param bone Bone affecting the TransformNode\r\n * @param affectedTransformNode TransformNode associated with the bone\r\n * @returns this object\r\n */\r\n TransformNode.prototype.attachToBone = function (bone, affectedTransformNode) {\r\n this._transformToBoneReferal = affectedTransformNode;\r\n this.parent = bone;\r\n if (bone.getWorldMatrix().determinant() < 0) {\r\n this.scalingDeterminant *= -1;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Detach the transform node if its associated with a bone\r\n * @returns this object\r\n */\r\n TransformNode.prototype.detachFromBone = function () {\r\n if (!this.parent) {\r\n return this;\r\n }\r\n if (this.parent.getWorldMatrix().determinant() < 0) {\r\n this.scalingDeterminant *= -1;\r\n }\r\n this._transformToBoneReferal = null;\r\n this.parent = null;\r\n return this;\r\n };\r\n /**\r\n * Rotates the mesh around the axis vector for the passed angle (amount) expressed in radians, in the given space.\r\n * space (default LOCAL) can be either Space.LOCAL, either Space.WORLD.\r\n * Note that the property `rotationQuaternion` is then automatically updated and the property `rotation` is set to (0,0,0) and no longer used.\r\n * The passed axis is also normalized.\r\n * @param axis the axis to rotate around\r\n * @param amount the amount to rotate in radians\r\n * @param space Space to rotate in (Default: local)\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.rotate = function (axis, amount, space) {\r\n axis.normalize();\r\n if (!this.rotationQuaternion) {\r\n this.rotationQuaternion = this.rotation.toQuaternion();\r\n this.rotation.setAll(0);\r\n }\r\n var rotationQuaternion;\r\n if (!space || space === Space.LOCAL) {\r\n rotationQuaternion = Quaternion.RotationAxisToRef(axis, amount, TransformNode._rotationAxisCache);\r\n this.rotationQuaternion.multiplyToRef(rotationQuaternion, this.rotationQuaternion);\r\n }\r\n else {\r\n if (this.parent) {\r\n var invertParentWorldMatrix = TmpVectors.Matrix[0];\r\n this.parent.getWorldMatrix().invertToRef(invertParentWorldMatrix);\r\n axis = Vector3.TransformNormal(axis, invertParentWorldMatrix);\r\n }\r\n rotationQuaternion = Quaternion.RotationAxisToRef(axis, amount, TransformNode._rotationAxisCache);\r\n rotationQuaternion.multiplyToRef(this.rotationQuaternion, this.rotationQuaternion);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Rotates the mesh around the axis vector for the passed angle (amount) expressed in radians, in world space.\r\n * Note that the property `rotationQuaternion` is then automatically updated and the property `rotation` is set to (0,0,0) and no longer used.\r\n * The passed axis is also normalized. .\r\n * Method is based on http://www.euclideanspace.com/maths/geometry/affine/aroundPoint/index.htm\r\n * @param point the point to rotate around\r\n * @param axis the axis to rotate around\r\n * @param amount the amount to rotate in radians\r\n * @returns the TransformNode\r\n */\r\n TransformNode.prototype.rotateAround = function (point, axis, amount) {\r\n axis.normalize();\r\n if (!this.rotationQuaternion) {\r\n this.rotationQuaternion = Quaternion.RotationYawPitchRoll(this.rotation.y, this.rotation.x, this.rotation.z);\r\n this.rotation.setAll(0);\r\n }\r\n var tmpVector = TmpVectors.Vector3[0];\r\n var finalScale = TmpVectors.Vector3[1];\r\n var finalTranslation = TmpVectors.Vector3[2];\r\n var finalRotation = TmpVectors.Quaternion[0];\r\n var translationMatrix = TmpVectors.Matrix[0]; // T\r\n var translationMatrixInv = TmpVectors.Matrix[1]; // T'\r\n var rotationMatrix = TmpVectors.Matrix[2]; // R\r\n var finalMatrix = TmpVectors.Matrix[3]; // T' x R x T\r\n point.subtractToRef(this.position, tmpVector);\r\n Matrix.TranslationToRef(tmpVector.x, tmpVector.y, tmpVector.z, translationMatrix); // T\r\n Matrix.TranslationToRef(-tmpVector.x, -tmpVector.y, -tmpVector.z, translationMatrixInv); // T'\r\n Matrix.RotationAxisToRef(axis, amount, rotationMatrix); // R\r\n translationMatrixInv.multiplyToRef(rotationMatrix, finalMatrix); // T' x R\r\n finalMatrix.multiplyToRef(translationMatrix, finalMatrix); // T' x R x T\r\n finalMatrix.decompose(finalScale, finalRotation, finalTranslation);\r\n this.position.addInPlace(finalTranslation);\r\n finalRotation.multiplyToRef(this.rotationQuaternion, this.rotationQuaternion);\r\n return this;\r\n };\r\n /**\r\n * Translates the mesh along the axis vector for the passed distance in the given space.\r\n * space (default LOCAL) can be either Space.LOCAL, either Space.WORLD.\r\n * @param axis the axis to translate in\r\n * @param distance the distance to translate\r\n * @param space Space to rotate in (Default: local)\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.translate = function (axis, distance, space) {\r\n var displacementVector = axis.scale(distance);\r\n if (!space || space === Space.LOCAL) {\r\n var tempV3 = this.getPositionExpressedInLocalSpace().add(displacementVector);\r\n this.setPositionWithLocalVector(tempV3);\r\n }\r\n else {\r\n this.setAbsolutePosition(this.getAbsolutePosition().add(displacementVector));\r\n }\r\n return this;\r\n };\r\n /**\r\n * Adds a rotation step to the mesh current rotation.\r\n * x, y, z are Euler angles expressed in radians.\r\n * This methods updates the current mesh rotation, either mesh.rotation, either mesh.rotationQuaternion if it's set.\r\n * This means this rotation is made in the mesh local space only.\r\n * It's useful to set a custom rotation order different from the BJS standard one YXZ.\r\n * Example : this rotates the mesh first around its local X axis, then around its local Z axis, finally around its local Y axis.\r\n * ```javascript\r\n * mesh.addRotation(x1, 0, 0).addRotation(0, 0, z2).addRotation(0, 0, y3);\r\n * ```\r\n * Note that `addRotation()` accumulates the passed rotation values to the current ones and computes the .rotation or .rotationQuaternion updated values.\r\n * Under the hood, only quaternions are used. So it's a little faster is you use .rotationQuaternion because it doesn't need to translate them back to Euler angles.\r\n * @param x Rotation to add\r\n * @param y Rotation to add\r\n * @param z Rotation to add\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.addRotation = function (x, y, z) {\r\n var rotationQuaternion;\r\n if (this.rotationQuaternion) {\r\n rotationQuaternion = this.rotationQuaternion;\r\n }\r\n else {\r\n rotationQuaternion = TmpVectors.Quaternion[1];\r\n Quaternion.RotationYawPitchRollToRef(this.rotation.y, this.rotation.x, this.rotation.z, rotationQuaternion);\r\n }\r\n var accumulation = TmpVectors.Quaternion[0];\r\n Quaternion.RotationYawPitchRollToRef(y, x, z, accumulation);\r\n rotationQuaternion.multiplyInPlace(accumulation);\r\n if (!this.rotationQuaternion) {\r\n rotationQuaternion.toEulerAnglesToRef(this.rotation);\r\n }\r\n return this;\r\n };\r\n /**\r\n * @hidden\r\n */\r\n TransformNode.prototype._getEffectiveParent = function () {\r\n return this.parent;\r\n };\r\n /**\r\n * Computes the world matrix of the node\r\n * @param force defines if the cache version should be invalidated forcing the world matrix to be created from scratch\r\n * @returns the world matrix\r\n */\r\n TransformNode.prototype.computeWorldMatrix = function (force) {\r\n if (this._isWorldMatrixFrozen && !this._isDirty) {\r\n return this._worldMatrix;\r\n }\r\n var currentRenderId = this.getScene().getRenderId();\r\n if (!this._isDirty && !force && this.isSynchronized()) {\r\n this._currentRenderId = currentRenderId;\r\n return this._worldMatrix;\r\n }\r\n var camera = this.getScene().activeCamera;\r\n var useBillboardPosition = (this._billboardMode & TransformNode.BILLBOARDMODE_USE_POSITION) !== 0;\r\n var useBillboardPath = this._billboardMode !== TransformNode.BILLBOARDMODE_NONE && !this.preserveParentRotationForBillboard;\r\n // Billboarding based on camera position\r\n if (useBillboardPath && camera && useBillboardPosition) {\r\n this.lookAt(camera.position);\r\n if ((this.billboardMode & TransformNode.BILLBOARDMODE_X) !== TransformNode.BILLBOARDMODE_X) {\r\n this.rotation.x = 0;\r\n }\r\n if ((this.billboardMode & TransformNode.BILLBOARDMODE_Y) !== TransformNode.BILLBOARDMODE_Y) {\r\n this.rotation.y = 0;\r\n }\r\n if ((this.billboardMode & TransformNode.BILLBOARDMODE_Z) !== TransformNode.BILLBOARDMODE_Z) {\r\n this.rotation.z = 0;\r\n }\r\n }\r\n this._updateCache();\r\n var cache = this._cache;\r\n cache.pivotMatrixUpdated = false;\r\n cache.billboardMode = this.billboardMode;\r\n cache.infiniteDistance = this.infiniteDistance;\r\n this._currentRenderId = currentRenderId;\r\n this._childUpdateId++;\r\n this._isDirty = false;\r\n var parent = this._getEffectiveParent();\r\n // Scaling\r\n var scaling = cache.scaling;\r\n var translation = cache.position;\r\n // Translation\r\n if (this._infiniteDistance) {\r\n if (!this.parent && camera) {\r\n var cameraWorldMatrix = camera.getWorldMatrix();\r\n var cameraGlobalPosition = new Vector3(cameraWorldMatrix.m[12], cameraWorldMatrix.m[13], cameraWorldMatrix.m[14]);\r\n translation.copyFromFloats(this._position.x + cameraGlobalPosition.x, this._position.y + cameraGlobalPosition.y, this._position.z + cameraGlobalPosition.z);\r\n }\r\n else {\r\n translation.copyFrom(this._position);\r\n }\r\n }\r\n else {\r\n translation.copyFrom(this._position);\r\n }\r\n // Scaling\r\n scaling.copyFromFloats(this._scaling.x * this.scalingDeterminant, this._scaling.y * this.scalingDeterminant, this._scaling.z * this.scalingDeterminant);\r\n // Rotation\r\n var rotation = cache.rotationQuaternion;\r\n if (this._rotationQuaternion) {\r\n if (this.reIntegrateRotationIntoRotationQuaternion) {\r\n var len = this.rotation.lengthSquared();\r\n if (len) {\r\n this._rotationQuaternion.multiplyInPlace(Quaternion.RotationYawPitchRoll(this._rotation.y, this._rotation.x, this._rotation.z));\r\n this._rotation.copyFromFloats(0, 0, 0);\r\n }\r\n }\r\n rotation.copyFrom(this._rotationQuaternion);\r\n }\r\n else {\r\n Quaternion.RotationYawPitchRollToRef(this._rotation.y, this._rotation.x, this._rotation.z, rotation);\r\n cache.rotation.copyFrom(this._rotation);\r\n }\r\n // Compose\r\n if (this._usePivotMatrix) {\r\n var scaleMatrix = TmpVectors.Matrix[1];\r\n Matrix.ScalingToRef(scaling.x, scaling.y, scaling.z, scaleMatrix);\r\n // Rotation\r\n var rotationMatrix = TmpVectors.Matrix[0];\r\n rotation.toRotationMatrix(rotationMatrix);\r\n // Composing transformations\r\n this._pivotMatrix.multiplyToRef(scaleMatrix, TmpVectors.Matrix[4]);\r\n TmpVectors.Matrix[4].multiplyToRef(rotationMatrix, this._localMatrix);\r\n // Post multiply inverse of pivotMatrix\r\n if (this._postMultiplyPivotMatrix) {\r\n this._localMatrix.multiplyToRef(this._pivotMatrixInverse, this._localMatrix);\r\n }\r\n this._localMatrix.addTranslationFromFloats(translation.x, translation.y, translation.z);\r\n }\r\n else {\r\n Matrix.ComposeToRef(scaling, rotation, translation, this._localMatrix);\r\n }\r\n // Parent\r\n if (parent && parent.getWorldMatrix) {\r\n if (force) {\r\n parent.computeWorldMatrix();\r\n }\r\n if (useBillboardPath) {\r\n if (this._transformToBoneReferal) {\r\n parent.getWorldMatrix().multiplyToRef(this._transformToBoneReferal.getWorldMatrix(), TmpVectors.Matrix[7]);\r\n }\r\n else {\r\n TmpVectors.Matrix[7].copyFrom(parent.getWorldMatrix());\r\n }\r\n // Extract scaling and translation from parent\r\n var translation_1 = TmpVectors.Vector3[5];\r\n var scale = TmpVectors.Vector3[6];\r\n TmpVectors.Matrix[7].decompose(scale, undefined, translation_1);\r\n Matrix.ScalingToRef(scale.x, scale.y, scale.z, TmpVectors.Matrix[7]);\r\n TmpVectors.Matrix[7].setTranslation(translation_1);\r\n this._localMatrix.multiplyToRef(TmpVectors.Matrix[7], this._worldMatrix);\r\n }\r\n else {\r\n if (this._transformToBoneReferal) {\r\n this._localMatrix.multiplyToRef(parent.getWorldMatrix(), TmpVectors.Matrix[6]);\r\n TmpVectors.Matrix[6].multiplyToRef(this._transformToBoneReferal.getWorldMatrix(), this._worldMatrix);\r\n }\r\n else {\r\n this._localMatrix.multiplyToRef(parent.getWorldMatrix(), this._worldMatrix);\r\n }\r\n }\r\n this._markSyncedWithParent();\r\n }\r\n else {\r\n this._worldMatrix.copyFrom(this._localMatrix);\r\n }\r\n // Billboarding based on camera orientation (testing PG:http://www.babylonjs-playground.com/#UJEIL#13)\r\n if (useBillboardPath && camera && this.billboardMode && !useBillboardPosition) {\r\n var storedTranslation = TmpVectors.Vector3[0];\r\n this._worldMatrix.getTranslationToRef(storedTranslation); // Save translation\r\n // Cancel camera rotation\r\n TmpVectors.Matrix[1].copyFrom(camera.getViewMatrix());\r\n TmpVectors.Matrix[1].setTranslationFromFloats(0, 0, 0);\r\n TmpVectors.Matrix[1].invertToRef(TmpVectors.Matrix[0]);\r\n if ((this.billboardMode & TransformNode.BILLBOARDMODE_ALL) !== TransformNode.BILLBOARDMODE_ALL) {\r\n TmpVectors.Matrix[0].decompose(undefined, TmpVectors.Quaternion[0], undefined);\r\n var eulerAngles = TmpVectors.Vector3[1];\r\n TmpVectors.Quaternion[0].toEulerAnglesToRef(eulerAngles);\r\n if ((this.billboardMode & TransformNode.BILLBOARDMODE_X) !== TransformNode.BILLBOARDMODE_X) {\r\n eulerAngles.x = 0;\r\n }\r\n if ((this.billboardMode & TransformNode.BILLBOARDMODE_Y) !== TransformNode.BILLBOARDMODE_Y) {\r\n eulerAngles.y = 0;\r\n }\r\n if ((this.billboardMode & TransformNode.BILLBOARDMODE_Z) !== TransformNode.BILLBOARDMODE_Z) {\r\n eulerAngles.z = 0;\r\n }\r\n Matrix.RotationYawPitchRollToRef(eulerAngles.y, eulerAngles.x, eulerAngles.z, TmpVectors.Matrix[0]);\r\n }\r\n this._worldMatrix.setTranslationFromFloats(0, 0, 0);\r\n this._worldMatrix.multiplyToRef(TmpVectors.Matrix[0], this._worldMatrix);\r\n // Restore translation\r\n this._worldMatrix.setTranslation(TmpVectors.Vector3[0]);\r\n }\r\n // Normal matrix\r\n if (!this.ignoreNonUniformScaling) {\r\n if (this._scaling.isNonUniform) {\r\n this._updateNonUniformScalingState(true);\r\n }\r\n else if (parent && parent._nonUniformScaling) {\r\n this._updateNonUniformScalingState(parent._nonUniformScaling);\r\n }\r\n else {\r\n this._updateNonUniformScalingState(false);\r\n }\r\n }\r\n else {\r\n this._updateNonUniformScalingState(false);\r\n }\r\n this._afterComputeWorldMatrix();\r\n // Absolute position\r\n this._absolutePosition.copyFromFloats(this._worldMatrix.m[12], this._worldMatrix.m[13], this._worldMatrix.m[14]);\r\n this._isAbsoluteSynced = false;\r\n // Callbacks\r\n this.onAfterWorldMatrixUpdateObservable.notifyObservers(this);\r\n if (!this._poseMatrix) {\r\n this._poseMatrix = Matrix.Invert(this._worldMatrix);\r\n }\r\n // Cache the determinant\r\n this._worldMatrixDeterminantIsDirty = true;\r\n return this._worldMatrix;\r\n };\r\n /**\r\n * Resets this nodeTransform's local matrix to Matrix.Identity().\r\n * @param independentOfChildren indicates if all child nodeTransform's world-space transform should be preserved.\r\n */\r\n TransformNode.prototype.resetLocalMatrix = function (independentOfChildren) {\r\n if (independentOfChildren === void 0) { independentOfChildren = true; }\r\n this.computeWorldMatrix();\r\n if (independentOfChildren) {\r\n var children = this.getChildren();\r\n for (var i = 0; i < children.length; ++i) {\r\n var child = children[i];\r\n if (child) {\r\n child.computeWorldMatrix();\r\n var bakedMatrix = TmpVectors.Matrix[0];\r\n child._localMatrix.multiplyToRef(this._localMatrix, bakedMatrix);\r\n var tmpRotationQuaternion = TmpVectors.Quaternion[0];\r\n bakedMatrix.decompose(child.scaling, tmpRotationQuaternion, child.position);\r\n if (child.rotationQuaternion) {\r\n child.rotationQuaternion = tmpRotationQuaternion;\r\n }\r\n else {\r\n tmpRotationQuaternion.toEulerAnglesToRef(child.rotation);\r\n }\r\n }\r\n }\r\n }\r\n this.scaling.copyFromFloats(1, 1, 1);\r\n this.position.copyFromFloats(0, 0, 0);\r\n this.rotation.copyFromFloats(0, 0, 0);\r\n //only if quaternion is already set\r\n if (this.rotationQuaternion) {\r\n this.rotationQuaternion = Quaternion.Identity();\r\n }\r\n this._worldMatrix = Matrix.Identity();\r\n };\r\n TransformNode.prototype._afterComputeWorldMatrix = function () {\r\n };\r\n /**\r\n * If you'd like to be called back after the mesh position, rotation or scaling has been updated.\r\n * @param func callback function to add\r\n *\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.registerAfterWorldMatrixUpdate = function (func) {\r\n this.onAfterWorldMatrixUpdateObservable.add(func);\r\n return this;\r\n };\r\n /**\r\n * Removes a registered callback function.\r\n * @param func callback function to remove\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.unregisterAfterWorldMatrixUpdate = function (func) {\r\n this.onAfterWorldMatrixUpdateObservable.removeCallback(func);\r\n return this;\r\n };\r\n /**\r\n * Gets the position of the current mesh in camera space\r\n * @param camera defines the camera to use\r\n * @returns a position\r\n */\r\n TransformNode.prototype.getPositionInCameraSpace = function (camera) {\r\n if (camera === void 0) { camera = null; }\r\n if (!camera) {\r\n camera = this.getScene().activeCamera;\r\n }\r\n return Vector3.TransformCoordinates(this.absolutePosition, camera.getViewMatrix());\r\n };\r\n /**\r\n * Returns the distance from the mesh to the active camera\r\n * @param camera defines the camera to use\r\n * @returns the distance\r\n */\r\n TransformNode.prototype.getDistanceToCamera = function (camera) {\r\n if (camera === void 0) { camera = null; }\r\n if (!camera) {\r\n camera = this.getScene().activeCamera;\r\n }\r\n return this.absolutePosition.subtract(camera.globalPosition).length();\r\n };\r\n /**\r\n * Clone the current transform node\r\n * @param name Name of the new clone\r\n * @param newParent New parent for the clone\r\n * @param doNotCloneChildren Do not clone children hierarchy\r\n * @returns the new transform node\r\n */\r\n TransformNode.prototype.clone = function (name, newParent, doNotCloneChildren) {\r\n var _this = this;\r\n var result = SerializationHelper.Clone(function () { return new TransformNode(name, _this.getScene()); }, this);\r\n result.name = name;\r\n result.id = name;\r\n if (newParent) {\r\n result.parent = newParent;\r\n }\r\n if (!doNotCloneChildren) {\r\n // Children\r\n var directDescendants = this.getDescendants(true);\r\n for (var index = 0; index < directDescendants.length; index++) {\r\n var child = directDescendants[index];\r\n if (child.clone) {\r\n child.clone(name + \".\" + child.name, result);\r\n }\r\n }\r\n }\r\n return result;\r\n };\r\n /**\r\n * Serializes the objects information.\r\n * @param currentSerializationObject defines the object to serialize in\r\n * @returns the serialized object\r\n */\r\n TransformNode.prototype.serialize = function (currentSerializationObject) {\r\n var serializationObject = SerializationHelper.Serialize(this, currentSerializationObject);\r\n serializationObject.type = this.getClassName();\r\n // Parent\r\n if (this.parent) {\r\n serializationObject.parentId = this.parent.id;\r\n }\r\n serializationObject.localMatrix = this.getPivotMatrix().asArray();\r\n serializationObject.isEnabled = this.isEnabled();\r\n // Parent\r\n if (this.parent) {\r\n serializationObject.parentId = this.parent.id;\r\n }\r\n return serializationObject;\r\n };\r\n // Statics\r\n /**\r\n * Returns a new TransformNode object parsed from the source provided.\r\n * @param parsedTransformNode is the source.\r\n * @param scene the scne the object belongs to\r\n * @param rootUrl is a string, it's the root URL to prefix the `delayLoadingFile` property with\r\n * @returns a new TransformNode object parsed from the source provided.\r\n */\r\n TransformNode.Parse = function (parsedTransformNode, scene, rootUrl) {\r\n var transformNode = SerializationHelper.Parse(function () { return new TransformNode(parsedTransformNode.name, scene); }, parsedTransformNode, scene, rootUrl);\r\n if (parsedTransformNode.localMatrix) {\r\n transformNode.setPreTransformMatrix(Matrix.FromArray(parsedTransformNode.localMatrix));\r\n }\r\n else if (parsedTransformNode.pivotMatrix) {\r\n transformNode.setPivotMatrix(Matrix.FromArray(parsedTransformNode.pivotMatrix));\r\n }\r\n transformNode.setEnabled(parsedTransformNode.isEnabled);\r\n // Parent\r\n if (parsedTransformNode.parentId) {\r\n transformNode._waitingParentId = parsedTransformNode.parentId;\r\n }\r\n return transformNode;\r\n };\r\n /**\r\n * Get all child-transformNodes of this node\r\n * @param directDescendantsOnly defines if true only direct descendants of 'this' will be considered, if false direct and also indirect (children of children, an so on in a recursive manner) descendants of 'this' will be considered\r\n * @param predicate defines an optional predicate that will be called on every evaluated child, the predicate must return true for a given child to be part of the result, otherwise it will be ignored\r\n * @returns an array of TransformNode\r\n */\r\n TransformNode.prototype.getChildTransformNodes = function (directDescendantsOnly, predicate) {\r\n var results = [];\r\n this._getDescendants(results, directDescendantsOnly, function (node) {\r\n return ((!predicate || predicate(node)) && (node instanceof TransformNode));\r\n });\r\n return results;\r\n };\r\n /**\r\n * Releases resources associated with this transform node.\r\n * @param doNotRecurse Set to true to not recurse into each children (recurse into each children by default)\r\n * @param disposeMaterialAndTextures Set to true to also dispose referenced materials and textures (false by default)\r\n */\r\n TransformNode.prototype.dispose = function (doNotRecurse, disposeMaterialAndTextures) {\r\n if (disposeMaterialAndTextures === void 0) { disposeMaterialAndTextures = false; }\r\n // Animations\r\n this.getScene().stopAnimation(this);\r\n // Remove from scene\r\n this.getScene().removeTransformNode(this);\r\n this.onAfterWorldMatrixUpdateObservable.clear();\r\n if (doNotRecurse) {\r\n var transformNodes = this.getChildTransformNodes(true);\r\n for (var _i = 0, transformNodes_1 = transformNodes; _i < transformNodes_1.length; _i++) {\r\n var transformNode = transformNodes_1[_i];\r\n transformNode.parent = null;\r\n transformNode.computeWorldMatrix(true);\r\n }\r\n }\r\n _super.prototype.dispose.call(this, doNotRecurse, disposeMaterialAndTextures);\r\n };\r\n /**\r\n * Uniformly scales the mesh to fit inside of a unit cube (1 X 1 X 1 units)\r\n * @param includeDescendants Use the hierarchy's bounding box instead of the mesh's bounding box. Default is false\r\n * @param ignoreRotation ignore rotation when computing the scale (ie. object will be axis aligned). Default is false\r\n * @param predicate predicate that is passed in to getHierarchyBoundingVectors when selecting which object should be included when scaling\r\n * @returns the current mesh\r\n */\r\n TransformNode.prototype.normalizeToUnitCube = function (includeDescendants, ignoreRotation, predicate) {\r\n if (includeDescendants === void 0) { includeDescendants = true; }\r\n if (ignoreRotation === void 0) { ignoreRotation = false; }\r\n var storedRotation = null;\r\n var storedRotationQuaternion = null;\r\n if (ignoreRotation) {\r\n if (this.rotationQuaternion) {\r\n storedRotationQuaternion = this.rotationQuaternion.clone();\r\n this.rotationQuaternion.copyFromFloats(0, 0, 0, 1);\r\n }\r\n else if (this.rotation) {\r\n storedRotation = this.rotation.clone();\r\n this.rotation.copyFromFloats(0, 0, 0);\r\n }\r\n }\r\n var boundingVectors = this.getHierarchyBoundingVectors(includeDescendants, predicate);\r\n var sizeVec = boundingVectors.max.subtract(boundingVectors.min);\r\n var maxDimension = Math.max(sizeVec.x, sizeVec.y, sizeVec.z);\r\n if (maxDimension === 0) {\r\n return this;\r\n }\r\n var scale = 1 / maxDimension;\r\n this.scaling.scaleInPlace(scale);\r\n if (ignoreRotation) {\r\n if (this.rotationQuaternion && storedRotationQuaternion) {\r\n this.rotationQuaternion.copyFrom(storedRotationQuaternion);\r\n }\r\n else if (this.rotation && storedRotation) {\r\n this.rotation.copyFrom(storedRotation);\r\n }\r\n }\r\n return this;\r\n };\r\n TransformNode.prototype._syncAbsoluteScalingAndRotation = function () {\r\n if (!this._isAbsoluteSynced) {\r\n this._worldMatrix.decompose(this._absoluteScaling, this._absoluteRotationQuaternion);\r\n this._isAbsoluteSynced = true;\r\n }\r\n };\r\n // Statics\r\n /**\r\n * Object will not rotate to face the camera\r\n */\r\n TransformNode.BILLBOARDMODE_NONE = 0;\r\n /**\r\n * Object will rotate to face the camera but only on the x axis\r\n */\r\n TransformNode.BILLBOARDMODE_X = 1;\r\n /**\r\n * Object will rotate to face the camera but only on the y axis\r\n */\r\n TransformNode.BILLBOARDMODE_Y = 2;\r\n /**\r\n * Object will rotate to face the camera but only on the z axis\r\n */\r\n TransformNode.BILLBOARDMODE_Z = 4;\r\n /**\r\n * Object will rotate to face the camera\r\n */\r\n TransformNode.BILLBOARDMODE_ALL = 7;\r\n /**\r\n * Object will rotate to face the camera's position instead of orientation\r\n */\r\n TransformNode.BILLBOARDMODE_USE_POSITION = 128;\r\n TransformNode._lookAtVectorCache = new Vector3(0, 0, 0);\r\n TransformNode._rotationAxisCache = new Quaternion();\r\n __decorate([\r\n serializeAsVector3(\"position\")\r\n ], TransformNode.prototype, \"_position\", void 0);\r\n __decorate([\r\n serializeAsVector3(\"rotation\")\r\n ], TransformNode.prototype, \"_rotation\", void 0);\r\n __decorate([\r\n serializeAsQuaternion(\"rotationQuaternion\")\r\n ], TransformNode.prototype, \"_rotationQuaternion\", void 0);\r\n __decorate([\r\n serializeAsVector3(\"scaling\")\r\n ], TransformNode.prototype, \"_scaling\", void 0);\r\n __decorate([\r\n serialize(\"billboardMode\")\r\n ], TransformNode.prototype, \"_billboardMode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], TransformNode.prototype, \"scalingDeterminant\", void 0);\r\n __decorate([\r\n serialize(\"infiniteDistance\")\r\n ], TransformNode.prototype, \"_infiniteDistance\", void 0);\r\n __decorate([\r\n serialize()\r\n ], TransformNode.prototype, \"ignoreNonUniformScaling\", void 0);\r\n __decorate([\r\n serialize()\r\n ], TransformNode.prototype, \"reIntegrateRotationIntoRotationQuaternion\", void 0);\r\n return TransformNode;\r\n}(Node));\r\nexport { TransformNode };\r\n//# sourceMappingURL=transformNode.js.map","'use strict';\n\nvar bind = require('./helpers/bind');\n\n/*global toString:true*/\n\n// utils is a library of generic helper functions non-specific to axios\n\nvar toString = Object.prototype.toString;\n\n/**\n * Determine if a value is an Array\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Array, otherwise false\n */\nfunction isArray(val) {\n return toString.call(val) === '[object Array]';\n}\n\n/**\n * Determine if a value is undefined\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if the value is undefined, otherwise false\n */\nfunction isUndefined(val) {\n return typeof val === 'undefined';\n}\n\n/**\n * Determine if a value is a Buffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Buffer, otherwise false\n */\nfunction isBuffer(val) {\n return val !== null && !isUndefined(val) && val.constructor !== null && !isUndefined(val.constructor)\n && typeof val.constructor.isBuffer === 'function' && val.constructor.isBuffer(val);\n}\n\n/**\n * Determine if a value is an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an ArrayBuffer, otherwise false\n */\nfunction isArrayBuffer(val) {\n return toString.call(val) === '[object ArrayBuffer]';\n}\n\n/**\n * Determine if a value is a FormData\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an FormData, otherwise false\n */\nfunction isFormData(val) {\n return (typeof FormData !== 'undefined') && (val instanceof FormData);\n}\n\n/**\n * Determine if a value is a view on an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a view on an ArrayBuffer, otherwise false\n */\nfunction isArrayBufferView(val) {\n var result;\n if ((typeof ArrayBuffer !== 'undefined') && (ArrayBuffer.isView)) {\n result = ArrayBuffer.isView(val);\n } else {\n result = (val) && (val.buffer) && (val.buffer instanceof ArrayBuffer);\n }\n return result;\n}\n\n/**\n * Determine if a value is a String\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a String, otherwise false\n */\nfunction isString(val) {\n return typeof val === 'string';\n}\n\n/**\n * Determine if a value is a Number\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Number, otherwise false\n */\nfunction isNumber(val) {\n return typeof val === 'number';\n}\n\n/**\n * Determine if a value is an Object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Object, otherwise false\n */\nfunction isObject(val) {\n return val !== null && typeof val === 'object';\n}\n\n/**\n * Determine if a value is a plain Object\n *\n * @param {Object} val The value to test\n * @return {boolean} True if value is a plain Object, otherwise false\n */\nfunction isPlainObject(val) {\n if (toString.call(val) !== '[object Object]') {\n return false;\n }\n\n var prototype = Object.getPrototypeOf(val);\n return prototype === null || prototype === Object.prototype;\n}\n\n/**\n * Determine if a value is a Date\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Date, otherwise false\n */\nfunction isDate(val) {\n return toString.call(val) === '[object Date]';\n}\n\n/**\n * Determine if a value is a File\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a File, otherwise false\n */\nfunction isFile(val) {\n return toString.call(val) === '[object File]';\n}\n\n/**\n * Determine if a value is a Blob\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Blob, otherwise false\n */\nfunction isBlob(val) {\n return toString.call(val) === '[object Blob]';\n}\n\n/**\n * Determine if a value is a Function\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Function, otherwise false\n */\nfunction isFunction(val) {\n return toString.call(val) === '[object Function]';\n}\n\n/**\n * Determine if a value is a Stream\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Stream, otherwise false\n */\nfunction isStream(val) {\n return isObject(val) && isFunction(val.pipe);\n}\n\n/**\n * Determine if a value is a URLSearchParams object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a URLSearchParams object, otherwise false\n */\nfunction isURLSearchParams(val) {\n return typeof URLSearchParams !== 'undefined' && val instanceof URLSearchParams;\n}\n\n/**\n * Trim excess whitespace off the beginning and end of a string\n *\n * @param {String} str The String to trim\n * @returns {String} The String freed of excess whitespace\n */\nfunction trim(str) {\n return str.replace(/^\\s*/, '').replace(/\\s*$/, '');\n}\n\n/**\n * Determine if we're running in a standard browser environment\n *\n * This allows axios to run in a web worker, and react-native.\n * Both environments support XMLHttpRequest, but not fully standard globals.\n *\n * web workers:\n * typeof window -> undefined\n * typeof document -> undefined\n *\n * react-native:\n * navigator.product -> 'ReactNative'\n * nativescript\n * navigator.product -> 'NativeScript' or 'NS'\n */\nfunction isStandardBrowserEnv() {\n if (typeof navigator !== 'undefined' && (navigator.product === 'ReactNative' ||\n navigator.product === 'NativeScript' ||\n navigator.product === 'NS')) {\n return false;\n }\n return (\n typeof window !== 'undefined' &&\n typeof document !== 'undefined'\n );\n}\n\n/**\n * Iterate over an Array or an Object invoking a function for each item.\n *\n * If `obj` is an Array callback will be called passing\n * the value, index, and complete array for each item.\n *\n * If 'obj' is an Object callback will be called passing\n * the value, key, and complete object for each property.\n *\n * @param {Object|Array} obj The object to iterate\n * @param {Function} fn The callback to invoke for each item\n */\nfunction forEach(obj, fn) {\n // Don't bother if no value provided\n if (obj === null || typeof obj === 'undefined') {\n return;\n }\n\n // Force an array if not already something iterable\n if (typeof obj !== 'object') {\n /*eslint no-param-reassign:0*/\n obj = [obj];\n }\n\n if (isArray(obj)) {\n // Iterate over array values\n for (var i = 0, l = obj.length; i < l; i++) {\n fn.call(null, obj[i], i, obj);\n }\n } else {\n // Iterate over object keys\n for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) {\n fn.call(null, obj[key], key, obj);\n }\n }\n }\n}\n\n/**\n * Accepts varargs expecting each argument to be an object, then\n * immutably merges the properties of each object and returns result.\n *\n * When multiple objects contain the same key the later object in\n * the arguments list will take precedence.\n *\n * Example:\n *\n * ```js\n * var result = merge({foo: 123}, {foo: 456});\n * console.log(result.foo); // outputs 456\n * ```\n *\n * @param {Object} obj1 Object to merge\n * @returns {Object} Result of all merge properties\n */\nfunction merge(/* obj1, obj2, obj3, ... */) {\n var result = {};\n function assignValue(val, key) {\n if (isPlainObject(result[key]) && isPlainObject(val)) {\n result[key] = merge(result[key], val);\n } else if (isPlainObject(val)) {\n result[key] = merge({}, val);\n } else if (isArray(val)) {\n result[key] = val.slice();\n } else {\n result[key] = val;\n }\n }\n\n for (var i = 0, l = arguments.length; i < l; i++) {\n forEach(arguments[i], assignValue);\n }\n return result;\n}\n\n/**\n * Extends object a by mutably adding to it the properties of object b.\n *\n * @param {Object} a The object to be extended\n * @param {Object} b The object to copy properties from\n * @param {Object} thisArg The object to bind function to\n * @return {Object} The resulting value of object a\n */\nfunction extend(a, b, thisArg) {\n forEach(b, function assignValue(val, key) {\n if (thisArg && typeof val === 'function') {\n a[key] = bind(val, thisArg);\n } else {\n a[key] = val;\n }\n });\n return a;\n}\n\n/**\n * Remove byte order marker. This catches EF BB BF (the UTF-8 BOM)\n *\n * @param {string} content with BOM\n * @return {string} content value without BOM\n */\nfunction stripBOM(content) {\n if (content.charCodeAt(0) === 0xFEFF) {\n content = content.slice(1);\n }\n return content;\n}\n\nmodule.exports = {\n isArray: isArray,\n isArrayBuffer: isArrayBuffer,\n isBuffer: isBuffer,\n isFormData: isFormData,\n isArrayBufferView: isArrayBufferView,\n isString: isString,\n isNumber: isNumber,\n isObject: isObject,\n isPlainObject: isPlainObject,\n isUndefined: isUndefined,\n isDate: isDate,\n isFile: isFile,\n isBlob: isBlob,\n isFunction: isFunction,\n isStream: isStream,\n isURLSearchParams: isURLSearchParams,\n isStandardBrowserEnv: isStandardBrowserEnv,\n forEach: forEach,\n merge: merge,\n extend: extend,\n trim: trim,\n stripBOM: stripBOM\n};\n","/**\r\n * Helper to manipulate strings\r\n */\r\nvar StringTools = /** @class */ (function () {\r\n function StringTools() {\r\n }\r\n /**\r\n * Checks for a matching suffix at the end of a string (for ES5 and lower)\r\n * @param str Source string\r\n * @param suffix Suffix to search for in the source string\r\n * @returns Boolean indicating whether the suffix was found (true) or not (false)\r\n */\r\n StringTools.EndsWith = function (str, suffix) {\r\n return str.indexOf(suffix, str.length - suffix.length) !== -1;\r\n };\r\n /**\r\n * Checks for a matching suffix at the beginning of a string (for ES5 and lower)\r\n * @param str Source string\r\n * @param suffix Suffix to search for in the source string\r\n * @returns Boolean indicating whether the suffix was found (true) or not (false)\r\n */\r\n StringTools.StartsWith = function (str, suffix) {\r\n return str.indexOf(suffix) === 0;\r\n };\r\n /**\r\n * Decodes a buffer into a string\r\n * @param buffer The buffer to decode\r\n * @returns The decoded string\r\n */\r\n StringTools.Decode = function (buffer) {\r\n if (typeof TextDecoder !== \"undefined\") {\r\n return new TextDecoder().decode(buffer);\r\n }\r\n var result = \"\";\r\n for (var i = 0; i < buffer.byteLength; i++) {\r\n result += String.fromCharCode(buffer[i]);\r\n }\r\n return result;\r\n };\r\n /**\r\n * Encode a buffer to a base64 string\r\n * @param buffer defines the buffer to encode\r\n * @returns the encoded string\r\n */\r\n StringTools.EncodeArrayBufferToBase64 = function (buffer) {\r\n var keyStr = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\";\r\n var output = \"\";\r\n var chr1, chr2, chr3, enc1, enc2, enc3, enc4;\r\n var i = 0;\r\n var bytes = ArrayBuffer.isView(buffer) ? new Uint8Array(buffer.buffer, buffer.byteOffset, buffer.byteLength) : new Uint8Array(buffer);\r\n while (i < bytes.length) {\r\n chr1 = bytes[i++];\r\n chr2 = i < bytes.length ? bytes[i++] : Number.NaN;\r\n chr3 = i < bytes.length ? bytes[i++] : Number.NaN;\r\n enc1 = chr1 >> 2;\r\n enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);\r\n enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);\r\n enc4 = chr3 & 63;\r\n if (isNaN(chr2)) {\r\n enc3 = enc4 = 64;\r\n }\r\n else if (isNaN(chr3)) {\r\n enc4 = 64;\r\n }\r\n output += keyStr.charAt(enc1) + keyStr.charAt(enc2) +\r\n keyStr.charAt(enc3) + keyStr.charAt(enc4);\r\n }\r\n return output;\r\n };\r\n return StringTools;\r\n}());\r\nexport { StringTools };\r\n//# sourceMappingURL=stringTools.js.map","import { __extends } from \"tslib\";\r\nimport { VertexBuffer } from \"./buffer\";\r\nimport { IntersectionInfo } from \"../Collisions/intersectionInfo\";\r\nimport { BoundingInfo } from \"../Culling/boundingInfo\";\r\nimport { extractMinAndMaxIndexed } from '../Maths/math.functions';\r\n/**\r\n * Base class for submeshes\r\n */\r\nvar BaseSubMesh = /** @class */ (function () {\r\n function BaseSubMesh() {\r\n /** @hidden */\r\n this._materialDefines = null;\r\n /** @hidden */\r\n this._materialEffect = null;\r\n }\r\n Object.defineProperty(BaseSubMesh.prototype, \"materialDefines\", {\r\n /**\r\n * Gets material defines used by the effect associated to the sub mesh\r\n */\r\n get: function () {\r\n return this._materialDefines;\r\n },\r\n /**\r\n * Sets material defines used by the effect associated to the sub mesh\r\n */\r\n set: function (defines) {\r\n this._materialDefines = defines;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSubMesh.prototype, \"effect\", {\r\n /**\r\n * Gets associated effect\r\n */\r\n get: function () {\r\n return this._materialEffect;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Sets associated effect (effect used to render this submesh)\r\n * @param effect defines the effect to associate with\r\n * @param defines defines the set of defines used to compile this effect\r\n */\r\n BaseSubMesh.prototype.setEffect = function (effect, defines) {\r\n if (defines === void 0) { defines = null; }\r\n if (this._materialEffect === effect) {\r\n if (!effect) {\r\n this._materialDefines = null;\r\n }\r\n return;\r\n }\r\n this._materialDefines = defines;\r\n this._materialEffect = effect;\r\n };\r\n return BaseSubMesh;\r\n}());\r\nexport { BaseSubMesh };\r\n/**\r\n * Defines a subdivision inside a mesh\r\n */\r\nvar SubMesh = /** @class */ (function (_super) {\r\n __extends(SubMesh, _super);\r\n /**\r\n * Creates a new submesh\r\n * @param materialIndex defines the material index to use\r\n * @param verticesStart defines vertex index start\r\n * @param verticesCount defines vertices count\r\n * @param indexStart defines index start\r\n * @param indexCount defines indices count\r\n * @param mesh defines the parent mesh\r\n * @param renderingMesh defines an optional rendering mesh\r\n * @param createBoundingBox defines if bounding box should be created for this submesh\r\n */\r\n function SubMesh(\r\n /** the material index to use */\r\n materialIndex, \r\n /** vertex index start */\r\n verticesStart, \r\n /** vertices count */\r\n verticesCount, \r\n /** index start */\r\n indexStart, \r\n /** indices count */\r\n indexCount, mesh, renderingMesh, createBoundingBox) {\r\n if (createBoundingBox === void 0) { createBoundingBox = true; }\r\n var _this = _super.call(this) || this;\r\n _this.materialIndex = materialIndex;\r\n _this.verticesStart = verticesStart;\r\n _this.verticesCount = verticesCount;\r\n _this.indexStart = indexStart;\r\n _this.indexCount = indexCount;\r\n /** @hidden */\r\n _this._linesIndexCount = 0;\r\n _this._linesIndexBuffer = null;\r\n /** @hidden */\r\n _this._lastColliderWorldVertices = null;\r\n /** @hidden */\r\n _this._lastColliderTransformMatrix = null;\r\n /** @hidden */\r\n _this._renderId = 0;\r\n /** @hidden */\r\n _this._alphaIndex = 0;\r\n /** @hidden */\r\n _this._distanceToCamera = 0;\r\n _this._currentMaterial = null;\r\n _this._mesh = mesh;\r\n _this._renderingMesh = renderingMesh || mesh;\r\n mesh.subMeshes.push(_this);\r\n _this._trianglePlanes = [];\r\n _this._id = mesh.subMeshes.length - 1;\r\n if (createBoundingBox) {\r\n _this.refreshBoundingInfo();\r\n mesh.computeWorldMatrix(true);\r\n }\r\n return _this;\r\n }\r\n /**\r\n * Add a new submesh to a mesh\r\n * @param materialIndex defines the material index to use\r\n * @param verticesStart defines vertex index start\r\n * @param verticesCount defines vertices count\r\n * @param indexStart defines index start\r\n * @param indexCount defines indices count\r\n * @param mesh defines the parent mesh\r\n * @param renderingMesh defines an optional rendering mesh\r\n * @param createBoundingBox defines if bounding box should be created for this submesh\r\n * @returns the new submesh\r\n */\r\n SubMesh.AddToMesh = function (materialIndex, verticesStart, verticesCount, indexStart, indexCount, mesh, renderingMesh, createBoundingBox) {\r\n if (createBoundingBox === void 0) { createBoundingBox = true; }\r\n return new SubMesh(materialIndex, verticesStart, verticesCount, indexStart, indexCount, mesh, renderingMesh, createBoundingBox);\r\n };\r\n Object.defineProperty(SubMesh.prototype, \"IsGlobal\", {\r\n /**\r\n * Returns true if this submesh covers the entire parent mesh\r\n * @ignorenaming\r\n */\r\n get: function () {\r\n return (this.verticesStart === 0 && this.verticesCount === this._mesh.getTotalVertices());\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Returns the submesh BoudingInfo object\r\n * @returns current bounding info (or mesh's one if the submesh is global)\r\n */\r\n SubMesh.prototype.getBoundingInfo = function () {\r\n if (this.IsGlobal) {\r\n return this._mesh.getBoundingInfo();\r\n }\r\n return this._boundingInfo;\r\n };\r\n /**\r\n * Sets the submesh BoundingInfo\r\n * @param boundingInfo defines the new bounding info to use\r\n * @returns the SubMesh\r\n */\r\n SubMesh.prototype.setBoundingInfo = function (boundingInfo) {\r\n this._boundingInfo = boundingInfo;\r\n return this;\r\n };\r\n /**\r\n * Returns the mesh of the current submesh\r\n * @return the parent mesh\r\n */\r\n SubMesh.prototype.getMesh = function () {\r\n return this._mesh;\r\n };\r\n /**\r\n * Returns the rendering mesh of the submesh\r\n * @returns the rendering mesh (could be different from parent mesh)\r\n */\r\n SubMesh.prototype.getRenderingMesh = function () {\r\n return this._renderingMesh;\r\n };\r\n /**\r\n * Returns the submesh material\r\n * @returns null or the current material\r\n */\r\n SubMesh.prototype.getMaterial = function () {\r\n var rootMaterial = this._renderingMesh.material;\r\n if (rootMaterial === null || rootMaterial === undefined) {\r\n return this._mesh.getScene().defaultMaterial;\r\n }\r\n else if (rootMaterial.getSubMaterial) {\r\n var multiMaterial = rootMaterial;\r\n var effectiveMaterial = multiMaterial.getSubMaterial(this.materialIndex);\r\n if (this._currentMaterial !== effectiveMaterial) {\r\n this._currentMaterial = effectiveMaterial;\r\n this._materialDefines = null;\r\n }\r\n return effectiveMaterial;\r\n }\r\n return rootMaterial;\r\n };\r\n // Methods\r\n /**\r\n * Sets a new updated BoundingInfo object to the submesh\r\n * @param data defines an optional position array to use to determine the bounding info\r\n * @returns the SubMesh\r\n */\r\n SubMesh.prototype.refreshBoundingInfo = function (data) {\r\n if (data === void 0) { data = null; }\r\n this._lastColliderWorldVertices = null;\r\n if (this.IsGlobal || !this._renderingMesh || !this._renderingMesh.geometry) {\r\n return this;\r\n }\r\n if (!data) {\r\n data = this._renderingMesh.getVerticesData(VertexBuffer.PositionKind);\r\n }\r\n if (!data) {\r\n this._boundingInfo = this._mesh.getBoundingInfo();\r\n return this;\r\n }\r\n var indices = this._renderingMesh.getIndices();\r\n var extend;\r\n //is this the only submesh?\r\n if (this.indexStart === 0 && this.indexCount === indices.length) {\r\n var boundingInfo = this._renderingMesh.getBoundingInfo();\r\n //the rendering mesh's bounding info can be used, it is the standard submesh for all indices.\r\n extend = { minimum: boundingInfo.minimum.clone(), maximum: boundingInfo.maximum.clone() };\r\n }\r\n else {\r\n extend = extractMinAndMaxIndexed(data, indices, this.indexStart, this.indexCount, this._renderingMesh.geometry.boundingBias);\r\n }\r\n if (this._boundingInfo) {\r\n this._boundingInfo.reConstruct(extend.minimum, extend.maximum);\r\n }\r\n else {\r\n this._boundingInfo = new BoundingInfo(extend.minimum, extend.maximum);\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n SubMesh.prototype._checkCollision = function (collider) {\r\n var boundingInfo = this.getBoundingInfo();\r\n return boundingInfo._checkCollision(collider);\r\n };\r\n /**\r\n * Updates the submesh BoundingInfo\r\n * @param world defines the world matrix to use to update the bounding info\r\n * @returns the submesh\r\n */\r\n SubMesh.prototype.updateBoundingInfo = function (world) {\r\n var boundingInfo = this.getBoundingInfo();\r\n if (!boundingInfo) {\r\n this.refreshBoundingInfo();\r\n boundingInfo = this.getBoundingInfo();\r\n }\r\n if (boundingInfo) {\r\n boundingInfo.update(world);\r\n }\r\n return this;\r\n };\r\n /**\r\n * True is the submesh bounding box intersects the frustum defined by the passed array of planes.\r\n * @param frustumPlanes defines the frustum planes\r\n * @returns true if the submesh is intersecting with the frustum\r\n */\r\n SubMesh.prototype.isInFrustum = function (frustumPlanes) {\r\n var boundingInfo = this.getBoundingInfo();\r\n if (!boundingInfo) {\r\n return false;\r\n }\r\n return boundingInfo.isInFrustum(frustumPlanes, this._mesh.cullingStrategy);\r\n };\r\n /**\r\n * True is the submesh bounding box is completely inside the frustum defined by the passed array of planes\r\n * @param frustumPlanes defines the frustum planes\r\n * @returns true if the submesh is inside the frustum\r\n */\r\n SubMesh.prototype.isCompletelyInFrustum = function (frustumPlanes) {\r\n var boundingInfo = this.getBoundingInfo();\r\n if (!boundingInfo) {\r\n return false;\r\n }\r\n return boundingInfo.isCompletelyInFrustum(frustumPlanes);\r\n };\r\n /**\r\n * Renders the submesh\r\n * @param enableAlphaMode defines if alpha needs to be used\r\n * @returns the submesh\r\n */\r\n SubMesh.prototype.render = function (enableAlphaMode) {\r\n this._renderingMesh.render(this, enableAlphaMode, this._mesh._internalAbstractMeshDataInfo._actAsRegularMesh ? this._mesh : undefined);\r\n return this;\r\n };\r\n /**\r\n * @hidden\r\n */\r\n SubMesh.prototype._getLinesIndexBuffer = function (indices, engine) {\r\n if (!this._linesIndexBuffer) {\r\n var linesIndices = [];\r\n for (var index = this.indexStart; index < this.indexStart + this.indexCount; index += 3) {\r\n linesIndices.push(indices[index], indices[index + 1], indices[index + 1], indices[index + 2], indices[index + 2], indices[index]);\r\n }\r\n this._linesIndexBuffer = engine.createIndexBuffer(linesIndices);\r\n this._linesIndexCount = linesIndices.length;\r\n }\r\n return this._linesIndexBuffer;\r\n };\r\n /**\r\n * Checks if the submesh intersects with a ray\r\n * @param ray defines the ray to test\r\n * @returns true is the passed ray intersects the submesh bounding box\r\n */\r\n SubMesh.prototype.canIntersects = function (ray) {\r\n var boundingInfo = this.getBoundingInfo();\r\n if (!boundingInfo) {\r\n return false;\r\n }\r\n return ray.intersectsBox(boundingInfo.boundingBox);\r\n };\r\n /**\r\n * Intersects current submesh with a ray\r\n * @param ray defines the ray to test\r\n * @param positions defines mesh's positions array\r\n * @param indices defines mesh's indices array\r\n * @param fastCheck defines if only bounding info should be used\r\n * @param trianglePredicate defines an optional predicate used to select faces when a mesh intersection is detected\r\n * @returns intersection info or null if no intersection\r\n */\r\n SubMesh.prototype.intersects = function (ray, positions, indices, fastCheck, trianglePredicate) {\r\n var material = this.getMaterial();\r\n if (!material) {\r\n return null;\r\n }\r\n var step = 3;\r\n var checkStopper = false;\r\n switch (material.fillMode) {\r\n case 3:\r\n case 4:\r\n case 5:\r\n case 6:\r\n case 8:\r\n return null;\r\n case 7:\r\n step = 1;\r\n checkStopper = true;\r\n break;\r\n default:\r\n break;\r\n }\r\n // LineMesh first as it's also a Mesh...\r\n if (this._mesh.getClassName() === \"InstancedLinesMesh\" || this._mesh.getClassName() === \"LinesMesh\") {\r\n // Check if mesh is unindexed\r\n if (!indices.length) {\r\n return this._intersectUnIndexedLines(ray, positions, indices, this._mesh.intersectionThreshold, fastCheck);\r\n }\r\n return this._intersectLines(ray, positions, indices, this._mesh.intersectionThreshold, fastCheck);\r\n }\r\n else {\r\n // Check if mesh is unindexed\r\n if (!indices.length && this._mesh._unIndexed) {\r\n return this._intersectUnIndexedTriangles(ray, positions, indices, fastCheck, trianglePredicate);\r\n }\r\n return this._intersectTriangles(ray, positions, indices, step, checkStopper, fastCheck, trianglePredicate);\r\n }\r\n };\r\n /** @hidden */\r\n SubMesh.prototype._intersectLines = function (ray, positions, indices, intersectionThreshold, fastCheck) {\r\n var intersectInfo = null;\r\n // Line test\r\n for (var index = this.indexStart; index < this.indexStart + this.indexCount; index += 2) {\r\n var p0 = positions[indices[index]];\r\n var p1 = positions[indices[index + 1]];\r\n var length = ray.intersectionSegment(p0, p1, intersectionThreshold);\r\n if (length < 0) {\r\n continue;\r\n }\r\n if (fastCheck || !intersectInfo || length < intersectInfo.distance) {\r\n intersectInfo = new IntersectionInfo(null, null, length);\r\n intersectInfo.faceId = index / 2;\r\n if (fastCheck) {\r\n break;\r\n }\r\n }\r\n }\r\n return intersectInfo;\r\n };\r\n /** @hidden */\r\n SubMesh.prototype._intersectUnIndexedLines = function (ray, positions, indices, intersectionThreshold, fastCheck) {\r\n var intersectInfo = null;\r\n // Line test\r\n for (var index = this.verticesStart; index < this.verticesStart + this.verticesCount; index += 2) {\r\n var p0 = positions[index];\r\n var p1 = positions[index + 1];\r\n var length = ray.intersectionSegment(p0, p1, intersectionThreshold);\r\n if (length < 0) {\r\n continue;\r\n }\r\n if (fastCheck || !intersectInfo || length < intersectInfo.distance) {\r\n intersectInfo = new IntersectionInfo(null, null, length);\r\n intersectInfo.faceId = index / 2;\r\n if (fastCheck) {\r\n break;\r\n }\r\n }\r\n }\r\n return intersectInfo;\r\n };\r\n /** @hidden */\r\n SubMesh.prototype._intersectTriangles = function (ray, positions, indices, step, checkStopper, fastCheck, trianglePredicate) {\r\n var intersectInfo = null;\r\n // Triangles test\r\n var faceID = -1;\r\n for (var index = this.indexStart; index < this.indexStart + this.indexCount; index += step) {\r\n faceID++;\r\n var indexA = indices[index];\r\n var indexB = indices[index + 1];\r\n var indexC = indices[index + 2];\r\n if (checkStopper && indexC === 0xFFFFFFFF) {\r\n index += 2;\r\n continue;\r\n }\r\n var p0 = positions[indexA];\r\n var p1 = positions[indexB];\r\n var p2 = positions[indexC];\r\n if (trianglePredicate && !trianglePredicate(p0, p1, p2, ray)) {\r\n continue;\r\n }\r\n var currentIntersectInfo = ray.intersectsTriangle(p0, p1, p2);\r\n if (currentIntersectInfo) {\r\n if (currentIntersectInfo.distance < 0) {\r\n continue;\r\n }\r\n if (fastCheck || !intersectInfo || currentIntersectInfo.distance < intersectInfo.distance) {\r\n intersectInfo = currentIntersectInfo;\r\n intersectInfo.faceId = faceID;\r\n if (fastCheck) {\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n return intersectInfo;\r\n };\r\n /** @hidden */\r\n SubMesh.prototype._intersectUnIndexedTriangles = function (ray, positions, indices, fastCheck, trianglePredicate) {\r\n var intersectInfo = null;\r\n // Triangles test\r\n for (var index = this.verticesStart; index < this.verticesStart + this.verticesCount; index += 3) {\r\n var p0 = positions[index];\r\n var p1 = positions[index + 1];\r\n var p2 = positions[index + 2];\r\n if (trianglePredicate && !trianglePredicate(p0, p1, p2, ray)) {\r\n continue;\r\n }\r\n var currentIntersectInfo = ray.intersectsTriangle(p0, p1, p2);\r\n if (currentIntersectInfo) {\r\n if (currentIntersectInfo.distance < 0) {\r\n continue;\r\n }\r\n if (fastCheck || !intersectInfo || currentIntersectInfo.distance < intersectInfo.distance) {\r\n intersectInfo = currentIntersectInfo;\r\n intersectInfo.faceId = index / 3;\r\n if (fastCheck) {\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n return intersectInfo;\r\n };\r\n /** @hidden */\r\n SubMesh.prototype._rebuild = function () {\r\n if (this._linesIndexBuffer) {\r\n this._linesIndexBuffer = null;\r\n }\r\n };\r\n // Clone\r\n /**\r\n * Creates a new submesh from the passed mesh\r\n * @param newMesh defines the new hosting mesh\r\n * @param newRenderingMesh defines an optional rendering mesh\r\n * @returns the new submesh\r\n */\r\n SubMesh.prototype.clone = function (newMesh, newRenderingMesh) {\r\n var result = new SubMesh(this.materialIndex, this.verticesStart, this.verticesCount, this.indexStart, this.indexCount, newMesh, newRenderingMesh, false);\r\n if (!this.IsGlobal) {\r\n var boundingInfo = this.getBoundingInfo();\r\n if (!boundingInfo) {\r\n return result;\r\n }\r\n result._boundingInfo = new BoundingInfo(boundingInfo.minimum, boundingInfo.maximum);\r\n }\r\n return result;\r\n };\r\n // Dispose\r\n /**\r\n * Release associated resources\r\n */\r\n SubMesh.prototype.dispose = function () {\r\n if (this._linesIndexBuffer) {\r\n this._mesh.getScene().getEngine()._releaseBuffer(this._linesIndexBuffer);\r\n this._linesIndexBuffer = null;\r\n }\r\n // Remove from mesh\r\n var index = this._mesh.subMeshes.indexOf(this);\r\n this._mesh.subMeshes.splice(index, 1);\r\n };\r\n /**\r\n * Gets the class name\r\n * @returns the string \"SubMesh\".\r\n */\r\n SubMesh.prototype.getClassName = function () {\r\n return \"SubMesh\";\r\n };\r\n // Statics\r\n /**\r\n * Creates a new submesh from indices data\r\n * @param materialIndex the index of the main mesh material\r\n * @param startIndex the index where to start the copy in the mesh indices array\r\n * @param indexCount the number of indices to copy then from the startIndex\r\n * @param mesh the main mesh to create the submesh from\r\n * @param renderingMesh the optional rendering mesh\r\n * @returns a new submesh\r\n */\r\n SubMesh.CreateFromIndices = function (materialIndex, startIndex, indexCount, mesh, renderingMesh) {\r\n var minVertexIndex = Number.MAX_VALUE;\r\n var maxVertexIndex = -Number.MAX_VALUE;\r\n var whatWillRender = (renderingMesh || mesh);\r\n var indices = whatWillRender.getIndices();\r\n for (var index = startIndex; index < startIndex + indexCount; index++) {\r\n var vertexIndex = indices[index];\r\n if (vertexIndex < minVertexIndex) {\r\n minVertexIndex = vertexIndex;\r\n }\r\n if (vertexIndex > maxVertexIndex) {\r\n maxVertexIndex = vertexIndex;\r\n }\r\n }\r\n return new SubMesh(materialIndex, minVertexIndex, maxVertexIndex - minVertexIndex + 1, startIndex, indexCount, mesh, renderingMesh);\r\n };\r\n return SubMesh;\r\n}(BaseSubMesh));\r\nexport { SubMesh };\r\n//# sourceMappingURL=subMesh.js.map","import { Vector3 } from '../Maths/math.vector';\r\n/**\r\n * @hidden\r\n */\r\nvar _MeshCollisionData = /** @class */ (function () {\r\n function _MeshCollisionData() {\r\n this._checkCollisions = false;\r\n this._collisionMask = -1;\r\n this._collisionGroup = -1;\r\n this._collider = null;\r\n this._oldPositionForCollisions = new Vector3(0, 0, 0);\r\n this._diffPositionForCollisions = new Vector3(0, 0, 0);\r\n }\r\n return _MeshCollisionData;\r\n}());\r\nexport { _MeshCollisionData };\r\n//# sourceMappingURL=meshCollisionData.js.map","import { __extends } from \"tslib\";\r\nimport { Tools } from \"../Misc/tools\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { Quaternion, Matrix, Vector3, TmpVectors } from \"../Maths/math.vector\";\r\nimport { Engine } from \"../Engines/engine\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { VertexData } from \"../Meshes/mesh.vertexData\";\r\nimport { TransformNode } from \"../Meshes/transformNode\";\r\nimport { PickingInfo } from \"../Collisions/pickingInfo\";\r\nimport { BoundingInfo } from \"../Culling/boundingInfo\";\r\nimport { _MeshCollisionData } from '../Collisions/meshCollisionData';\r\nimport { _DevTools } from '../Misc/devTools';\r\nimport { extractMinAndMax } from '../Maths/math.functions';\r\nimport { Color3, Color4 } from '../Maths/math.color';\r\nimport { Epsilon } from '../Maths/math.constants';\r\nimport { Axis } from '../Maths/math.axis';\r\n/** @hidden */\r\nvar _FacetDataStorage = /** @class */ (function () {\r\n function _FacetDataStorage() {\r\n this.facetNb = 0; // facet number\r\n this.partitioningSubdivisions = 10; // number of subdivisions per axis in the partioning space\r\n this.partitioningBBoxRatio = 1.01; // the partioning array space is by default 1% bigger than the bounding box\r\n this.facetDataEnabled = false; // is the facet data feature enabled on this mesh ?\r\n this.facetParameters = {}; // keep a reference to the object parameters to avoid memory re-allocation\r\n this.bbSize = Vector3.Zero(); // bbox size approximated for facet data\r\n this.subDiv = {\r\n max: 1,\r\n X: 1,\r\n Y: 1,\r\n Z: 1\r\n };\r\n this.facetDepthSort = false; // is the facet depth sort to be computed\r\n this.facetDepthSortEnabled = false; // is the facet depth sort initialized\r\n }\r\n return _FacetDataStorage;\r\n}());\r\n/**\r\n * @hidden\r\n **/\r\nvar _InternalAbstractMeshDataInfo = /** @class */ (function () {\r\n function _InternalAbstractMeshDataInfo() {\r\n this._hasVertexAlpha = false;\r\n this._useVertexColors = true;\r\n this._numBoneInfluencers = 4;\r\n this._applyFog = true;\r\n this._receiveShadows = false;\r\n this._facetData = new _FacetDataStorage();\r\n this._visibility = 1.0;\r\n this._skeleton = null;\r\n this._layerMask = 0x0FFFFFFF;\r\n this._computeBonesUsingShaders = true;\r\n this._isActive = false;\r\n this._onlyForInstances = false;\r\n this._isActiveIntermediate = false;\r\n this._onlyForInstancesIntermediate = false;\r\n this._actAsRegularMesh = false;\r\n }\r\n return _InternalAbstractMeshDataInfo;\r\n}());\r\n/**\r\n * Class used to store all common mesh properties\r\n */\r\nvar AbstractMesh = /** @class */ (function (_super) {\r\n __extends(AbstractMesh, _super);\r\n // Constructor\r\n /**\r\n * Creates a new AbstractMesh\r\n * @param name defines the name of the mesh\r\n * @param scene defines the hosting scene\r\n */\r\n function AbstractMesh(name, scene) {\r\n if (scene === void 0) { scene = null; }\r\n var _this = _super.call(this, name, scene, false) || this;\r\n // Internal data\r\n /** @hidden */\r\n _this._internalAbstractMeshDataInfo = new _InternalAbstractMeshDataInfo();\r\n /**\r\n * The culling strategy to use to check whether the mesh must be rendered or not.\r\n * This value can be changed at any time and will be used on the next render mesh selection.\r\n * The possible values are :\r\n * - AbstractMesh.CULLINGSTRATEGY_STANDARD\r\n * - AbstractMesh.CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY\r\n * - AbstractMesh.CULLINGSTRATEGY_OPTIMISTIC_INCLUSION\r\n * - AbstractMesh.CULLINGSTRATEGY_OPTIMISTIC_INCLUSION_THEN_BSPHERE_ONLY\r\n * Please read each static variable documentation to get details about the culling process.\r\n * */\r\n _this.cullingStrategy = AbstractMesh.CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY;\r\n // Events\r\n /**\r\n * An event triggered when this mesh collides with another one\r\n */\r\n _this.onCollideObservable = new Observable();\r\n /**\r\n * An event triggered when the collision's position changes\r\n */\r\n _this.onCollisionPositionChangeObservable = new Observable();\r\n /**\r\n * An event triggered when material is changed\r\n */\r\n _this.onMaterialChangedObservable = new Observable();\r\n // Properties\r\n /**\r\n * Gets or sets the orientation for POV movement & rotation\r\n */\r\n _this.definedFacingForward = true;\r\n /** @hidden */\r\n _this._occlusionQuery = null;\r\n /** @hidden */\r\n _this._renderingGroup = null;\r\n /** Gets or sets the alpha index used to sort transparent meshes\r\n * @see http://doc.babylonjs.com/resources/transparency_and_how_meshes_are_rendered#alpha-index\r\n */\r\n _this.alphaIndex = Number.MAX_VALUE;\r\n /**\r\n * Gets or sets a boolean indicating if the mesh is visible (renderable). Default is true\r\n */\r\n _this.isVisible = true;\r\n /**\r\n * Gets or sets a boolean indicating if the mesh can be picked (by scene.pick for instance or through actions). Default is true\r\n */\r\n _this.isPickable = true;\r\n /** Gets or sets a boolean indicating that bounding boxes of subMeshes must be rendered as well (false by default) */\r\n _this.showSubMeshesBoundingBox = false;\r\n /** Gets or sets a boolean indicating if the mesh must be considered as a ray blocker for lens flares (false by default)\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_lens_flares\r\n */\r\n _this.isBlocker = false;\r\n /**\r\n * Gets or sets a boolean indicating that pointer move events must be supported on this mesh (false by default)\r\n */\r\n _this.enablePointerMoveEvents = false;\r\n /**\r\n * Specifies the rendering group id for this mesh (0 by default)\r\n * @see http://doc.babylonjs.com/resources/transparency_and_how_meshes_are_rendered#rendering-groups\r\n */\r\n _this.renderingGroupId = 0;\r\n _this._material = null;\r\n /** Defines color to use when rendering outline */\r\n _this.outlineColor = Color3.Red();\r\n /** Define width to use when rendering outline */\r\n _this.outlineWidth = 0.02;\r\n /** Defines color to use when rendering overlay */\r\n _this.overlayColor = Color3.Red();\r\n /** Defines alpha to use when rendering overlay */\r\n _this.overlayAlpha = 0.5;\r\n /** Gets or sets a boolean indicating that internal octree (if available) can be used to boost submeshes selection (true by default) */\r\n _this.useOctreeForRenderingSelection = true;\r\n /** Gets or sets a boolean indicating that internal octree (if available) can be used to boost submeshes picking (true by default) */\r\n _this.useOctreeForPicking = true;\r\n /** Gets or sets a boolean indicating that internal octree (if available) can be used to boost submeshes collision (true by default) */\r\n _this.useOctreeForCollisions = true;\r\n /**\r\n * True if the mesh must be rendered in any case (this will shortcut the frustum clipping phase)\r\n */\r\n _this.alwaysSelectAsActiveMesh = false;\r\n /**\r\n * Gets or sets a boolean indicating that the bounding info does not need to be kept in sync (for performance reason)\r\n */\r\n _this.doNotSyncBoundingInfo = false;\r\n /**\r\n * Gets or sets the current action manager\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions\r\n */\r\n _this.actionManager = null;\r\n // Collisions\r\n _this._meshCollisionData = new _MeshCollisionData();\r\n /**\r\n * Gets or sets the ellipsoid used to impersonate this mesh when using collision engine (default is (0.5, 1, 0.5))\r\n * @see http://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity\r\n */\r\n _this.ellipsoid = new Vector3(0.5, 1, 0.5);\r\n /**\r\n * Gets or sets the ellipsoid offset used to impersonate this mesh when using collision engine (default is (0, 0, 0))\r\n * @see http://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity\r\n */\r\n _this.ellipsoidOffset = new Vector3(0, 0, 0);\r\n // Edges\r\n /**\r\n * Defines edge width used when edgesRenderer is enabled\r\n * @see https://www.babylonjs-playground.com/#10OJSG#13\r\n */\r\n _this.edgesWidth = 1;\r\n /**\r\n * Defines edge color used when edgesRenderer is enabled\r\n * @see https://www.babylonjs-playground.com/#10OJSG#13\r\n */\r\n _this.edgesColor = new Color4(1, 0, 0, 1);\r\n /** @hidden */\r\n _this._edgesRenderer = null;\r\n /** @hidden */\r\n _this._masterMesh = null;\r\n /** @hidden */\r\n _this._boundingInfo = null;\r\n /** @hidden */\r\n _this._renderId = 0;\r\n /** @hidden */\r\n _this._intersectionsInProgress = new Array();\r\n /** @hidden */\r\n _this._unIndexed = false;\r\n /** @hidden */\r\n _this._lightSources = new Array();\r\n // Loading properties\r\n /** @hidden */\r\n _this._waitingData = {\r\n lods: null,\r\n actions: null,\r\n freezeWorldMatrix: null\r\n };\r\n /** @hidden */\r\n _this._bonesTransformMatrices = null;\r\n /** @hidden */\r\n _this._transformMatrixTexture = null;\r\n /**\r\n * An event triggered when the mesh is rebuilt.\r\n */\r\n _this.onRebuildObservable = new Observable();\r\n _this._onCollisionPositionChange = function (collisionId, newPosition, collidedMesh) {\r\n if (collidedMesh === void 0) { collidedMesh = null; }\r\n newPosition.subtractToRef(_this._meshCollisionData._oldPositionForCollisions, _this._meshCollisionData._diffPositionForCollisions);\r\n if (_this._meshCollisionData._diffPositionForCollisions.length() > Engine.CollisionsEpsilon) {\r\n _this.position.addInPlace(_this._meshCollisionData._diffPositionForCollisions);\r\n }\r\n if (collidedMesh) {\r\n _this.onCollideObservable.notifyObservers(collidedMesh);\r\n }\r\n _this.onCollisionPositionChangeObservable.notifyObservers(_this.position);\r\n };\r\n _this.getScene().addMesh(_this);\r\n _this._resyncLightSources();\r\n return _this;\r\n }\r\n Object.defineProperty(AbstractMesh, \"BILLBOARDMODE_NONE\", {\r\n /**\r\n * No billboard\r\n */\r\n get: function () {\r\n return TransformNode.BILLBOARDMODE_NONE;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh, \"BILLBOARDMODE_X\", {\r\n /** Billboard on X axis */\r\n get: function () {\r\n return TransformNode.BILLBOARDMODE_X;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh, \"BILLBOARDMODE_Y\", {\r\n /** Billboard on Y axis */\r\n get: function () {\r\n return TransformNode.BILLBOARDMODE_Y;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh, \"BILLBOARDMODE_Z\", {\r\n /** Billboard on Z axis */\r\n get: function () {\r\n return TransformNode.BILLBOARDMODE_Z;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh, \"BILLBOARDMODE_ALL\", {\r\n /** Billboard on all axes */\r\n get: function () {\r\n return TransformNode.BILLBOARDMODE_ALL;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh, \"BILLBOARDMODE_USE_POSITION\", {\r\n /** Billboard on using position instead of orientation */\r\n get: function () {\r\n return TransformNode.BILLBOARDMODE_USE_POSITION;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"facetNb\", {\r\n /**\r\n * Gets the number of facets in the mesh\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata#what-is-a-mesh-facet\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._facetData.facetNb;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"partitioningSubdivisions\", {\r\n /**\r\n * Gets or set the number (integer) of subdivisions per axis in the partioning space\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata#tweaking-the-partitioning\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._facetData.partitioningSubdivisions;\r\n },\r\n set: function (nb) {\r\n this._internalAbstractMeshDataInfo._facetData.partitioningSubdivisions = nb;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"partitioningBBoxRatio\", {\r\n /**\r\n * The ratio (float) to apply to the bouding box size to set to the partioning space.\r\n * Ex : 1.01 (default) the partioning space is 1% bigger than the bounding box\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata#tweaking-the-partitioning\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._facetData.partitioningBBoxRatio;\r\n },\r\n set: function (ratio) {\r\n this._internalAbstractMeshDataInfo._facetData.partitioningBBoxRatio = ratio;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"mustDepthSortFacets\", {\r\n /**\r\n * Gets or sets a boolean indicating that the facets must be depth sorted on next call to `updateFacetData()`.\r\n * Works only for updatable meshes.\r\n * Doesn't work with multi-materials\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata#facet-depth-sort\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._facetData.facetDepthSort;\r\n },\r\n set: function (sort) {\r\n this._internalAbstractMeshDataInfo._facetData.facetDepthSort = sort;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"facetDepthSortFrom\", {\r\n /**\r\n * The location (Vector3) where the facet depth sort must be computed from.\r\n * By default, the active camera position.\r\n * Used only when facet depth sort is enabled\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata#facet-depth-sort\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._facetData.facetDepthSortFrom;\r\n },\r\n set: function (location) {\r\n this._internalAbstractMeshDataInfo._facetData.facetDepthSortFrom = location;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"isFacetDataEnabled\", {\r\n /**\r\n * gets a boolean indicating if facetData is enabled\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata#what-is-a-mesh-facet\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._facetData.facetDataEnabled;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n AbstractMesh.prototype._updateNonUniformScalingState = function (value) {\r\n if (!_super.prototype._updateNonUniformScalingState.call(this, value)) {\r\n return false;\r\n }\r\n this._markSubMeshesAsMiscDirty();\r\n return true;\r\n };\r\n Object.defineProperty(AbstractMesh.prototype, \"onCollide\", {\r\n /** Set a function to call when this mesh collides with another one */\r\n set: function (callback) {\r\n if (this._meshCollisionData._onCollideObserver) {\r\n this.onCollideObservable.remove(this._meshCollisionData._onCollideObserver);\r\n }\r\n this._meshCollisionData._onCollideObserver = this.onCollideObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"onCollisionPositionChange\", {\r\n /** Set a function to call when the collision's position changes */\r\n set: function (callback) {\r\n if (this._meshCollisionData._onCollisionPositionChangeObserver) {\r\n this.onCollisionPositionChangeObservable.remove(this._meshCollisionData._onCollisionPositionChangeObserver);\r\n }\r\n this._meshCollisionData._onCollisionPositionChangeObserver = this.onCollisionPositionChangeObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"visibility\", {\r\n /**\r\n * Gets or sets mesh visibility between 0 and 1 (default is 1)\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._visibility;\r\n },\r\n /**\r\n * Gets or sets mesh visibility between 0 and 1 (default is 1)\r\n */\r\n set: function (value) {\r\n if (this._internalAbstractMeshDataInfo._visibility === value) {\r\n return;\r\n }\r\n this._internalAbstractMeshDataInfo._visibility = value;\r\n this._markSubMeshesAsMiscDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"material\", {\r\n /** Gets or sets current material */\r\n get: function () {\r\n return this._material;\r\n },\r\n set: function (value) {\r\n if (this._material === value) {\r\n return;\r\n }\r\n // remove from material mesh map id needed\r\n if (this._material && this._material.meshMap) {\r\n this._material.meshMap[this.uniqueId] = undefined;\r\n }\r\n this._material = value;\r\n if (value && value.meshMap) {\r\n value.meshMap[this.uniqueId] = this;\r\n }\r\n if (this.onMaterialChangedObservable.hasObservers()) {\r\n this.onMaterialChangedObservable.notifyObservers(this);\r\n }\r\n if (!this.subMeshes) {\r\n return;\r\n }\r\n this._unBindEffect();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"receiveShadows\", {\r\n /**\r\n * Gets or sets a boolean indicating that this mesh can receive realtime shadows\r\n * @see http://doc.babylonjs.com/babylon101/shadows\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._receiveShadows;\r\n },\r\n set: function (value) {\r\n if (this._internalAbstractMeshDataInfo._receiveShadows === value) {\r\n return;\r\n }\r\n this._internalAbstractMeshDataInfo._receiveShadows = value;\r\n this._markSubMeshesAsLightDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"hasVertexAlpha\", {\r\n /** Gets or sets a boolean indicating that this mesh contains vertex color data with alpha values */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._hasVertexAlpha;\r\n },\r\n set: function (value) {\r\n if (this._internalAbstractMeshDataInfo._hasVertexAlpha === value) {\r\n return;\r\n }\r\n this._internalAbstractMeshDataInfo._hasVertexAlpha = value;\r\n this._markSubMeshesAsAttributesDirty();\r\n this._markSubMeshesAsMiscDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"useVertexColors\", {\r\n /** Gets or sets a boolean indicating that this mesh needs to use vertex color data to render (if this kind of vertex data is available in the geometry) */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._useVertexColors;\r\n },\r\n set: function (value) {\r\n if (this._internalAbstractMeshDataInfo._useVertexColors === value) {\r\n return;\r\n }\r\n this._internalAbstractMeshDataInfo._useVertexColors = value;\r\n this._markSubMeshesAsAttributesDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"computeBonesUsingShaders\", {\r\n /**\r\n * Gets or sets a boolean indicating that bone animations must be computed by the CPU (false by default)\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._computeBonesUsingShaders;\r\n },\r\n set: function (value) {\r\n if (this._internalAbstractMeshDataInfo._computeBonesUsingShaders === value) {\r\n return;\r\n }\r\n this._internalAbstractMeshDataInfo._computeBonesUsingShaders = value;\r\n this._markSubMeshesAsAttributesDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"numBoneInfluencers\", {\r\n /** Gets or sets the number of allowed bone influences per vertex (4 by default) */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._numBoneInfluencers;\r\n },\r\n set: function (value) {\r\n if (this._internalAbstractMeshDataInfo._numBoneInfluencers === value) {\r\n return;\r\n }\r\n this._internalAbstractMeshDataInfo._numBoneInfluencers = value;\r\n this._markSubMeshesAsAttributesDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"applyFog\", {\r\n /** Gets or sets a boolean indicating that this mesh will allow fog to be rendered on it (true by default) */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._applyFog;\r\n },\r\n set: function (value) {\r\n if (this._internalAbstractMeshDataInfo._applyFog === value) {\r\n return;\r\n }\r\n this._internalAbstractMeshDataInfo._applyFog = value;\r\n this._markSubMeshesAsMiscDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"layerMask\", {\r\n /**\r\n * Gets or sets the current layer mask (default is 0x0FFFFFFF)\r\n * @see http://doc.babylonjs.com/how_to/layermasks_and_multi-cam_textures\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._layerMask;\r\n },\r\n set: function (value) {\r\n if (value === this._internalAbstractMeshDataInfo._layerMask) {\r\n return;\r\n }\r\n this._internalAbstractMeshDataInfo._layerMask = value;\r\n this._resyncLightSources();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"collisionMask\", {\r\n /**\r\n * Gets or sets a collision mask used to mask collisions (default is -1).\r\n * A collision between A and B will happen if A.collisionGroup & b.collisionMask !== 0\r\n */\r\n get: function () {\r\n return this._meshCollisionData._collisionMask;\r\n },\r\n set: function (mask) {\r\n this._meshCollisionData._collisionMask = !isNaN(mask) ? mask : -1;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"collisionGroup\", {\r\n /**\r\n * Gets or sets the current collision group mask (-1 by default).\r\n * A collision between A and B will happen if A.collisionGroup & b.collisionMask !== 0\r\n */\r\n get: function () {\r\n return this._meshCollisionData._collisionGroup;\r\n },\r\n set: function (mask) {\r\n this._meshCollisionData._collisionGroup = !isNaN(mask) ? mask : -1;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"lightSources\", {\r\n /** Gets the list of lights affecting that mesh */\r\n get: function () {\r\n return this._lightSources;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"_positions\", {\r\n /** @hidden */\r\n get: function () {\r\n return null;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"skeleton\", {\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._skeleton;\r\n },\r\n /**\r\n * Gets or sets a skeleton to apply skining transformations\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_bones_and_skeletons\r\n */\r\n set: function (value) {\r\n var skeleton = this._internalAbstractMeshDataInfo._skeleton;\r\n if (skeleton && skeleton.needInitialSkinMatrix) {\r\n skeleton._unregisterMeshWithPoseMatrix(this);\r\n }\r\n if (value && value.needInitialSkinMatrix) {\r\n value._registerMeshWithPoseMatrix(this);\r\n }\r\n this._internalAbstractMeshDataInfo._skeleton = value;\r\n if (!this._internalAbstractMeshDataInfo._skeleton) {\r\n this._bonesTransformMatrices = null;\r\n }\r\n this._markSubMeshesAsAttributesDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Returns the string \"AbstractMesh\"\r\n * @returns \"AbstractMesh\"\r\n */\r\n AbstractMesh.prototype.getClassName = function () {\r\n return \"AbstractMesh\";\r\n };\r\n /**\r\n * Gets a string representation of the current mesh\r\n * @param fullDetails defines a boolean indicating if full details must be included\r\n * @returns a string representation of the current mesh\r\n */\r\n AbstractMesh.prototype.toString = function (fullDetails) {\r\n var ret = \"Name: \" + this.name + \", isInstance: \" + (this.getClassName() !== \"InstancedMesh\" ? \"YES\" : \"NO\");\r\n ret += \", # of submeshes: \" + (this.subMeshes ? this.subMeshes.length : 0);\r\n var skeleton = this._internalAbstractMeshDataInfo._skeleton;\r\n if (skeleton) {\r\n ret += \", skeleton: \" + skeleton.name;\r\n }\r\n if (fullDetails) {\r\n ret += \", billboard mode: \" + ([\"NONE\", \"X\", \"Y\", null, \"Z\", null, null, \"ALL\"])[this.billboardMode];\r\n ret += \", freeze wrld mat: \" + (this._isWorldMatrixFrozen || this._waitingData.freezeWorldMatrix ? \"YES\" : \"NO\");\r\n }\r\n return ret;\r\n };\r\n /**\r\n * @hidden\r\n */\r\n AbstractMesh.prototype._getEffectiveParent = function () {\r\n if (this._masterMesh && this.billboardMode !== TransformNode.BILLBOARDMODE_NONE) {\r\n return this._masterMesh;\r\n }\r\n return _super.prototype._getEffectiveParent.call(this);\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._getActionManagerForTrigger = function (trigger, initialCall) {\r\n if (initialCall === void 0) { initialCall = true; }\r\n if (this.actionManager && (initialCall || this.actionManager.isRecursive)) {\r\n if (trigger) {\r\n if (this.actionManager.hasSpecificTrigger(trigger)) {\r\n return this.actionManager;\r\n }\r\n }\r\n else {\r\n return this.actionManager;\r\n }\r\n }\r\n if (!this.parent) {\r\n return null;\r\n }\r\n return this.parent._getActionManagerForTrigger(trigger, false);\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._rebuild = function () {\r\n this.onRebuildObservable.notifyObservers(this);\r\n if (this._occlusionQuery) {\r\n this._occlusionQuery = null;\r\n }\r\n if (!this.subMeshes) {\r\n return;\r\n }\r\n for (var _i = 0, _a = this.subMeshes; _i < _a.length; _i++) {\r\n var subMesh = _a[_i];\r\n subMesh._rebuild();\r\n }\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._resyncLightSources = function () {\r\n this._lightSources.length = 0;\r\n for (var _i = 0, _a = this.getScene().lights; _i < _a.length; _i++) {\r\n var light = _a[_i];\r\n if (!light.isEnabled()) {\r\n continue;\r\n }\r\n if (light.canAffectMesh(this)) {\r\n this._lightSources.push(light);\r\n }\r\n }\r\n this._markSubMeshesAsLightDirty();\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._resyncLightSource = function (light) {\r\n var isIn = light.isEnabled() && light.canAffectMesh(this);\r\n var index = this._lightSources.indexOf(light);\r\n if (index === -1) {\r\n if (!isIn) {\r\n return;\r\n }\r\n this._lightSources.push(light);\r\n }\r\n else {\r\n if (isIn) {\r\n return;\r\n }\r\n this._lightSources.splice(index, 1);\r\n }\r\n this._markSubMeshesAsLightDirty();\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._unBindEffect = function () {\r\n for (var _i = 0, _a = this.subMeshes; _i < _a.length; _i++) {\r\n var subMesh = _a[_i];\r\n subMesh.setEffect(null);\r\n }\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._removeLightSource = function (light, dispose) {\r\n var index = this._lightSources.indexOf(light);\r\n if (index === -1) {\r\n return;\r\n }\r\n this._lightSources.splice(index, 1);\r\n this._markSubMeshesAsLightDirty(dispose);\r\n };\r\n AbstractMesh.prototype._markSubMeshesAsDirty = function (func) {\r\n if (!this.subMeshes) {\r\n return;\r\n }\r\n for (var _i = 0, _a = this.subMeshes; _i < _a.length; _i++) {\r\n var subMesh = _a[_i];\r\n if (subMesh._materialDefines) {\r\n func(subMesh._materialDefines);\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._markSubMeshesAsLightDirty = function (dispose) {\r\n if (dispose === void 0) { dispose = false; }\r\n this._markSubMeshesAsDirty(function (defines) { return defines.markAsLightDirty(dispose); });\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._markSubMeshesAsAttributesDirty = function () {\r\n this._markSubMeshesAsDirty(function (defines) { return defines.markAsAttributesDirty(); });\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._markSubMeshesAsMiscDirty = function () {\r\n if (!this.subMeshes) {\r\n return;\r\n }\r\n for (var _i = 0, _a = this.subMeshes; _i < _a.length; _i++) {\r\n var subMesh = _a[_i];\r\n var material = subMesh.getMaterial();\r\n if (material) {\r\n material.markAsDirty(16);\r\n }\r\n }\r\n };\r\n Object.defineProperty(AbstractMesh.prototype, \"scaling\", {\r\n /**\r\n * Gets or sets a Vector3 depicting the mesh scaling along each local axis X, Y, Z. Default is (1.0, 1.0, 1.0)\r\n */\r\n get: function () {\r\n return this._scaling;\r\n },\r\n set: function (newScaling) {\r\n this._scaling = newScaling;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"isBlocked\", {\r\n // Methods\r\n /**\r\n * Returns true if the mesh is blocked. Implemented by child classes\r\n */\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Returns the mesh itself by default. Implemented by child classes\r\n * @param camera defines the camera to use to pick the right LOD level\r\n * @returns the currentAbstractMesh\r\n */\r\n AbstractMesh.prototype.getLOD = function (camera) {\r\n return this;\r\n };\r\n /**\r\n * Returns 0 by default. Implemented by child classes\r\n * @returns an integer\r\n */\r\n AbstractMesh.prototype.getTotalVertices = function () {\r\n return 0;\r\n };\r\n /**\r\n * Returns a positive integer : the total number of indices in this mesh geometry.\r\n * @returns the numner of indices or zero if the mesh has no geometry.\r\n */\r\n AbstractMesh.prototype.getTotalIndices = function () {\r\n return 0;\r\n };\r\n /**\r\n * Returns null by default. Implemented by child classes\r\n * @returns null\r\n */\r\n AbstractMesh.prototype.getIndices = function () {\r\n return null;\r\n };\r\n /**\r\n * Returns the array of the requested vertex data kind. Implemented by child classes\r\n * @param kind defines the vertex data kind to use\r\n * @returns null\r\n */\r\n AbstractMesh.prototype.getVerticesData = function (kind) {\r\n return null;\r\n };\r\n /**\r\n * Sets the vertex data of the mesh geometry for the requested `kind`.\r\n * If the mesh has no geometry, a new Geometry object is set to the mesh and then passed this vertex data.\r\n * Note that a new underlying VertexBuffer object is created each call.\r\n * If the `kind` is the `PositionKind`, the mesh BoundingInfo is renewed, so the bounding box and sphere, and the mesh World Matrix is recomputed.\r\n * @param kind defines vertex data kind:\r\n * * VertexBuffer.PositionKind\r\n * * VertexBuffer.UVKind\r\n * * VertexBuffer.UV2Kind\r\n * * VertexBuffer.UV3Kind\r\n * * VertexBuffer.UV4Kind\r\n * * VertexBuffer.UV5Kind\r\n * * VertexBuffer.UV6Kind\r\n * * VertexBuffer.ColorKind\r\n * * VertexBuffer.MatricesIndicesKind\r\n * * VertexBuffer.MatricesIndicesExtraKind\r\n * * VertexBuffer.MatricesWeightsKind\r\n * * VertexBuffer.MatricesWeightsExtraKind\r\n * @param data defines the data source\r\n * @param updatable defines if the data must be flagged as updatable (or static)\r\n * @param stride defines the vertex stride (size of an entire vertex). Can be null and in this case will be deduced from vertex data kind\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.setVerticesData = function (kind, data, updatable, stride) {\r\n return this;\r\n };\r\n /**\r\n * Updates the existing vertex data of the mesh geometry for the requested `kind`.\r\n * If the mesh has no geometry, it is simply returned as it is.\r\n * @param kind defines vertex data kind:\r\n * * VertexBuffer.PositionKind\r\n * * VertexBuffer.UVKind\r\n * * VertexBuffer.UV2Kind\r\n * * VertexBuffer.UV3Kind\r\n * * VertexBuffer.UV4Kind\r\n * * VertexBuffer.UV5Kind\r\n * * VertexBuffer.UV6Kind\r\n * * VertexBuffer.ColorKind\r\n * * VertexBuffer.MatricesIndicesKind\r\n * * VertexBuffer.MatricesIndicesExtraKind\r\n * * VertexBuffer.MatricesWeightsKind\r\n * * VertexBuffer.MatricesWeightsExtraKind\r\n * @param data defines the data source\r\n * @param updateExtends If `kind` is `PositionKind` and if `updateExtends` is true, the mesh BoundingInfo is renewed, so the bounding box and sphere, and the mesh World Matrix is recomputed\r\n * @param makeItUnique If true, a new global geometry is created from this data and is set to the mesh\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.updateVerticesData = function (kind, data, updateExtends, makeItUnique) {\r\n return this;\r\n };\r\n /**\r\n * Sets the mesh indices,\r\n * If the mesh has no geometry, a new Geometry object is created and set to the mesh.\r\n * @param indices Expects an array populated with integers or a typed array (Int32Array, Uint32Array, Uint16Array)\r\n * @param totalVertices Defines the total number of vertices\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.setIndices = function (indices, totalVertices) {\r\n return this;\r\n };\r\n /**\r\n * Gets a boolean indicating if specific vertex data is present\r\n * @param kind defines the vertex data kind to use\r\n * @returns true is data kind is present\r\n */\r\n AbstractMesh.prototype.isVerticesDataPresent = function (kind) {\r\n return false;\r\n };\r\n /**\r\n * Returns the mesh BoundingInfo object or creates a new one and returns if it was undefined.\r\n * Note that it returns a shallow bounding of the mesh (i.e. it does not include children).\r\n * To get the full bounding of all children, call `getHierarchyBoundingVectors` instead.\r\n * @returns a BoundingInfo\r\n */\r\n AbstractMesh.prototype.getBoundingInfo = function () {\r\n if (this._masterMesh) {\r\n return this._masterMesh.getBoundingInfo();\r\n }\r\n if (!this._boundingInfo) {\r\n // this._boundingInfo is being created here\r\n this._updateBoundingInfo();\r\n }\r\n // cannot be null.\r\n return this._boundingInfo;\r\n };\r\n /**\r\n * Uniformly scales the mesh to fit inside of a unit cube (1 X 1 X 1 units)\r\n * @param includeDescendants Use the hierarchy's bounding box instead of the mesh's bounding box. Default is false\r\n * @param ignoreRotation ignore rotation when computing the scale (ie. object will be axis aligned). Default is false\r\n * @param predicate predicate that is passed in to getHierarchyBoundingVectors when selecting which object should be included when scaling\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.normalizeToUnitCube = function (includeDescendants, ignoreRotation, predicate) {\r\n if (includeDescendants === void 0) { includeDescendants = true; }\r\n if (ignoreRotation === void 0) { ignoreRotation = false; }\r\n return _super.prototype.normalizeToUnitCube.call(this, includeDescendants, ignoreRotation, predicate);\r\n };\r\n /**\r\n * Overwrite the current bounding info\r\n * @param boundingInfo defines the new bounding info\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.setBoundingInfo = function (boundingInfo) {\r\n this._boundingInfo = boundingInfo;\r\n return this;\r\n };\r\n Object.defineProperty(AbstractMesh.prototype, \"useBones\", {\r\n /** Gets a boolean indicating if this mesh has skinning data and an attached skeleton */\r\n get: function () {\r\n return (this.skeleton && this.getScene().skeletonsEnabled && this.isVerticesDataPresent(VertexBuffer.MatricesIndicesKind) && this.isVerticesDataPresent(VertexBuffer.MatricesWeightsKind));\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n AbstractMesh.prototype._preActivate = function () {\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._preActivateForIntermediateRendering = function (renderId) {\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._activate = function (renderId, intermediateRendering) {\r\n this._renderId = renderId;\r\n return true;\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._postActivate = function () {\r\n // Do nothing\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._freeze = function () {\r\n // Do nothing\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._unFreeze = function () {\r\n // Do nothing\r\n };\r\n /**\r\n * Gets the current world matrix\r\n * @returns a Matrix\r\n */\r\n AbstractMesh.prototype.getWorldMatrix = function () {\r\n if (this._masterMesh && this.billboardMode === TransformNode.BILLBOARDMODE_NONE) {\r\n return this._masterMesh.getWorldMatrix();\r\n }\r\n return _super.prototype.getWorldMatrix.call(this);\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._getWorldMatrixDeterminant = function () {\r\n if (this._masterMesh) {\r\n return this._masterMesh._getWorldMatrixDeterminant();\r\n }\r\n return _super.prototype._getWorldMatrixDeterminant.call(this);\r\n };\r\n Object.defineProperty(AbstractMesh.prototype, \"isAnInstance\", {\r\n /**\r\n * Gets a boolean indicating if this mesh is an instance or a regular mesh\r\n */\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"hasInstances\", {\r\n /**\r\n * Gets a boolean indicating if this mesh has instances\r\n */\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n // ================================== Point of View Movement =================================\r\n /**\r\n * Perform relative position change from the point of view of behind the front of the mesh.\r\n * This is performed taking into account the meshes current rotation, so you do not have to care.\r\n * Supports definition of mesh facing forward or backward\r\n * @param amountRight defines the distance on the right axis\r\n * @param amountUp defines the distance on the up axis\r\n * @param amountForward defines the distance on the forward axis\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.movePOV = function (amountRight, amountUp, amountForward) {\r\n this.position.addInPlace(this.calcMovePOV(amountRight, amountUp, amountForward));\r\n return this;\r\n };\r\n /**\r\n * Calculate relative position change from the point of view of behind the front of the mesh.\r\n * This is performed taking into account the meshes current rotation, so you do not have to care.\r\n * Supports definition of mesh facing forward or backward\r\n * @param amountRight defines the distance on the right axis\r\n * @param amountUp defines the distance on the up axis\r\n * @param amountForward defines the distance on the forward axis\r\n * @returns the new displacement vector\r\n */\r\n AbstractMesh.prototype.calcMovePOV = function (amountRight, amountUp, amountForward) {\r\n var rotMatrix = new Matrix();\r\n var rotQuaternion = (this.rotationQuaternion) ? this.rotationQuaternion : Quaternion.RotationYawPitchRoll(this.rotation.y, this.rotation.x, this.rotation.z);\r\n rotQuaternion.toRotationMatrix(rotMatrix);\r\n var translationDelta = Vector3.Zero();\r\n var defForwardMult = this.definedFacingForward ? -1 : 1;\r\n Vector3.TransformCoordinatesFromFloatsToRef(amountRight * defForwardMult, amountUp, amountForward * defForwardMult, rotMatrix, translationDelta);\r\n return translationDelta;\r\n };\r\n // ================================== Point of View Rotation =================================\r\n /**\r\n * Perform relative rotation change from the point of view of behind the front of the mesh.\r\n * Supports definition of mesh facing forward or backward\r\n * @param flipBack defines the flip\r\n * @param twirlClockwise defines the twirl\r\n * @param tiltRight defines the tilt\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.rotatePOV = function (flipBack, twirlClockwise, tiltRight) {\r\n this.rotation.addInPlace(this.calcRotatePOV(flipBack, twirlClockwise, tiltRight));\r\n return this;\r\n };\r\n /**\r\n * Calculate relative rotation change from the point of view of behind the front of the mesh.\r\n * Supports definition of mesh facing forward or backward.\r\n * @param flipBack defines the flip\r\n * @param twirlClockwise defines the twirl\r\n * @param tiltRight defines the tilt\r\n * @returns the new rotation vector\r\n */\r\n AbstractMesh.prototype.calcRotatePOV = function (flipBack, twirlClockwise, tiltRight) {\r\n var defForwardMult = this.definedFacingForward ? 1 : -1;\r\n return new Vector3(flipBack * defForwardMult, twirlClockwise, tiltRight * defForwardMult);\r\n };\r\n /**\r\n * This method recomputes and sets a new BoundingInfo to the mesh unless it is locked.\r\n * This means the mesh underlying bounding box and sphere are recomputed.\r\n * @param applySkeleton defines whether to apply the skeleton before computing the bounding info\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.refreshBoundingInfo = function (applySkeleton) {\r\n if (applySkeleton === void 0) { applySkeleton = false; }\r\n if (this._boundingInfo && this._boundingInfo.isLocked) {\r\n return this;\r\n }\r\n this._refreshBoundingInfo(this._getPositionData(applySkeleton), null);\r\n return this;\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._refreshBoundingInfo = function (data, bias) {\r\n if (data) {\r\n var extend = extractMinAndMax(data, 0, this.getTotalVertices(), bias);\r\n if (this._boundingInfo) {\r\n this._boundingInfo.reConstruct(extend.minimum, extend.maximum);\r\n }\r\n else {\r\n this._boundingInfo = new BoundingInfo(extend.minimum, extend.maximum);\r\n }\r\n }\r\n if (this.subMeshes) {\r\n for (var index = 0; index < this.subMeshes.length; index++) {\r\n this.subMeshes[index].refreshBoundingInfo(data);\r\n }\r\n }\r\n this._updateBoundingInfo();\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._getPositionData = function (applySkeleton) {\r\n var data = this.getVerticesData(VertexBuffer.PositionKind);\r\n if (data && applySkeleton && this.skeleton) {\r\n data = Tools.Slice(data);\r\n this._generatePointsArray();\r\n var matricesIndicesData = this.getVerticesData(VertexBuffer.MatricesIndicesKind);\r\n var matricesWeightsData = this.getVerticesData(VertexBuffer.MatricesWeightsKind);\r\n if (matricesWeightsData && matricesIndicesData) {\r\n var needExtras = this.numBoneInfluencers > 4;\r\n var matricesIndicesExtraData = needExtras ? this.getVerticesData(VertexBuffer.MatricesIndicesExtraKind) : null;\r\n var matricesWeightsExtraData = needExtras ? this.getVerticesData(VertexBuffer.MatricesWeightsExtraKind) : null;\r\n this.skeleton.prepare();\r\n var skeletonMatrices = this.skeleton.getTransformMatrices(this);\r\n var tempVector = TmpVectors.Vector3[0];\r\n var finalMatrix = TmpVectors.Matrix[0];\r\n var tempMatrix = TmpVectors.Matrix[1];\r\n var matWeightIdx = 0;\r\n for (var index = 0; index < data.length; index += 3, matWeightIdx += 4) {\r\n finalMatrix.reset();\r\n var inf;\r\n var weight;\r\n for (inf = 0; inf < 4; inf++) {\r\n weight = matricesWeightsData[matWeightIdx + inf];\r\n if (weight > 0) {\r\n Matrix.FromFloat32ArrayToRefScaled(skeletonMatrices, Math.floor(matricesIndicesData[matWeightIdx + inf] * 16), weight, tempMatrix);\r\n finalMatrix.addToSelf(tempMatrix);\r\n }\r\n }\r\n if (needExtras) {\r\n for (inf = 0; inf < 4; inf++) {\r\n weight = matricesWeightsExtraData[matWeightIdx + inf];\r\n if (weight > 0) {\r\n Matrix.FromFloat32ArrayToRefScaled(skeletonMatrices, Math.floor(matricesIndicesExtraData[matWeightIdx + inf] * 16), weight, tempMatrix);\r\n finalMatrix.addToSelf(tempMatrix);\r\n }\r\n }\r\n }\r\n Vector3.TransformCoordinatesFromFloatsToRef(data[index], data[index + 1], data[index + 2], finalMatrix, tempVector);\r\n tempVector.toArray(data, index);\r\n if (this._positions) {\r\n this._positions[index / 3].copyFrom(tempVector);\r\n }\r\n }\r\n }\r\n }\r\n return data;\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._updateBoundingInfo = function () {\r\n var effectiveMesh = this._effectiveMesh;\r\n if (this._boundingInfo) {\r\n this._boundingInfo.update(effectiveMesh.worldMatrixFromCache);\r\n }\r\n else {\r\n this._boundingInfo = new BoundingInfo(this.absolutePosition, this.absolutePosition, effectiveMesh.worldMatrixFromCache);\r\n }\r\n this._updateSubMeshesBoundingInfo(effectiveMesh.worldMatrixFromCache);\r\n return this;\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._updateSubMeshesBoundingInfo = function (matrix) {\r\n if (!this.subMeshes) {\r\n return this;\r\n }\r\n var count = this.subMeshes.length;\r\n for (var subIndex = 0; subIndex < count; subIndex++) {\r\n var subMesh = this.subMeshes[subIndex];\r\n if (count > 1 || !subMesh.IsGlobal) {\r\n subMesh.updateBoundingInfo(matrix);\r\n }\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._afterComputeWorldMatrix = function () {\r\n if (this.doNotSyncBoundingInfo) {\r\n return;\r\n }\r\n // Bounding info\r\n this._updateBoundingInfo();\r\n };\r\n Object.defineProperty(AbstractMesh.prototype, \"_effectiveMesh\", {\r\n /** @hidden */\r\n get: function () {\r\n return (this.skeleton && this.skeleton.overrideMesh) || this;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Returns `true` if the mesh is within the frustum defined by the passed array of planes.\r\n * A mesh is in the frustum if its bounding box intersects the frustum\r\n * @param frustumPlanes defines the frustum to test\r\n * @returns true if the mesh is in the frustum planes\r\n */\r\n AbstractMesh.prototype.isInFrustum = function (frustumPlanes) {\r\n return this._boundingInfo !== null && this._boundingInfo.isInFrustum(frustumPlanes, this.cullingStrategy);\r\n };\r\n /**\r\n * Returns `true` if the mesh is completely in the frustum defined be the passed array of planes.\r\n * A mesh is completely in the frustum if its bounding box it completely inside the frustum.\r\n * @param frustumPlanes defines the frustum to test\r\n * @returns true if the mesh is completely in the frustum planes\r\n */\r\n AbstractMesh.prototype.isCompletelyInFrustum = function (frustumPlanes) {\r\n return this._boundingInfo !== null && this._boundingInfo.isCompletelyInFrustum(frustumPlanes);\r\n };\r\n /**\r\n * True if the mesh intersects another mesh or a SolidParticle object\r\n * @param mesh defines a target mesh or SolidParticle to test\r\n * @param precise Unless the parameter `precise` is set to `true` the intersection is computed according to Axis Aligned Bounding Boxes (AABB), else according to OBB (Oriented BBoxes)\r\n * @param includeDescendants Can be set to true to test if the mesh defined in parameters intersects with the current mesh or any child meshes\r\n * @returns true if there is an intersection\r\n */\r\n AbstractMesh.prototype.intersectsMesh = function (mesh, precise, includeDescendants) {\r\n if (precise === void 0) { precise = false; }\r\n if (!this._boundingInfo || !mesh._boundingInfo) {\r\n return false;\r\n }\r\n if (this._boundingInfo.intersects(mesh._boundingInfo, precise)) {\r\n return true;\r\n }\r\n if (includeDescendants) {\r\n for (var _i = 0, _a = this.getChildMeshes(); _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (child.intersectsMesh(mesh, precise, true)) {\r\n return true;\r\n }\r\n }\r\n }\r\n return false;\r\n };\r\n /**\r\n * Returns true if the passed point (Vector3) is inside the mesh bounding box\r\n * @param point defines the point to test\r\n * @returns true if there is an intersection\r\n */\r\n AbstractMesh.prototype.intersectsPoint = function (point) {\r\n if (!this._boundingInfo) {\r\n return false;\r\n }\r\n return this._boundingInfo.intersectsPoint(point);\r\n };\r\n Object.defineProperty(AbstractMesh.prototype, \"checkCollisions\", {\r\n // Collisions\r\n /**\r\n * Gets or sets a boolean indicating that this mesh can be used in the collision engine\r\n * @see http://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity\r\n */\r\n get: function () {\r\n return this._meshCollisionData._checkCollisions;\r\n },\r\n set: function (collisionEnabled) {\r\n this._meshCollisionData._checkCollisions = collisionEnabled;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"collider\", {\r\n /**\r\n * Gets Collider object used to compute collisions (not physics)\r\n * @see http://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity\r\n */\r\n get: function () {\r\n return this._meshCollisionData._collider;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Move the mesh using collision engine\r\n * @see http://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity\r\n * @param displacement defines the requested displacement vector\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.moveWithCollisions = function (displacement) {\r\n var globalPosition = this.getAbsolutePosition();\r\n globalPosition.addToRef(this.ellipsoidOffset, this._meshCollisionData._oldPositionForCollisions);\r\n var coordinator = this.getScene().collisionCoordinator;\r\n if (!this._meshCollisionData._collider) {\r\n this._meshCollisionData._collider = coordinator.createCollider();\r\n }\r\n this._meshCollisionData._collider._radius = this.ellipsoid;\r\n coordinator.getNewPosition(this._meshCollisionData._oldPositionForCollisions, displacement, this._meshCollisionData._collider, 3, this, this._onCollisionPositionChange, this.uniqueId);\r\n return this;\r\n };\r\n // Collisions\r\n /** @hidden */\r\n AbstractMesh.prototype._collideForSubMesh = function (subMesh, transformMatrix, collider) {\r\n this._generatePointsArray();\r\n if (!this._positions) {\r\n return this;\r\n }\r\n // Transformation\r\n if (!subMesh._lastColliderWorldVertices || !subMesh._lastColliderTransformMatrix.equals(transformMatrix)) {\r\n subMesh._lastColliderTransformMatrix = transformMatrix.clone();\r\n subMesh._lastColliderWorldVertices = [];\r\n subMesh._trianglePlanes = [];\r\n var start = subMesh.verticesStart;\r\n var end = (subMesh.verticesStart + subMesh.verticesCount);\r\n for (var i = start; i < end; i++) {\r\n subMesh._lastColliderWorldVertices.push(Vector3.TransformCoordinates(this._positions[i], transformMatrix));\r\n }\r\n }\r\n // Collide\r\n collider._collide(subMesh._trianglePlanes, subMesh._lastColliderWorldVertices, this.getIndices(), subMesh.indexStart, subMesh.indexStart + subMesh.indexCount, subMesh.verticesStart, !!subMesh.getMaterial(), this);\r\n return this;\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._processCollisionsForSubMeshes = function (collider, transformMatrix) {\r\n var subMeshes = this._scene.getCollidingSubMeshCandidates(this, collider);\r\n var len = subMeshes.length;\r\n for (var index = 0; index < len; index++) {\r\n var subMesh = subMeshes.data[index];\r\n // Bounding test\r\n if (len > 1 && !subMesh._checkCollision(collider)) {\r\n continue;\r\n }\r\n this._collideForSubMesh(subMesh, transformMatrix, collider);\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._checkCollision = function (collider) {\r\n // Bounding box test\r\n if (!this._boundingInfo || !this._boundingInfo._checkCollision(collider)) {\r\n return this;\r\n }\r\n // Transformation matrix\r\n var collisionsScalingMatrix = TmpVectors.Matrix[0];\r\n var collisionsTransformMatrix = TmpVectors.Matrix[1];\r\n Matrix.ScalingToRef(1.0 / collider._radius.x, 1.0 / collider._radius.y, 1.0 / collider._radius.z, collisionsScalingMatrix);\r\n this.worldMatrixFromCache.multiplyToRef(collisionsScalingMatrix, collisionsTransformMatrix);\r\n this._processCollisionsForSubMeshes(collider, collisionsTransformMatrix);\r\n return this;\r\n };\r\n // Picking\r\n /** @hidden */\r\n AbstractMesh.prototype._generatePointsArray = function () {\r\n return false;\r\n };\r\n /**\r\n * Checks if the passed Ray intersects with the mesh\r\n * @param ray defines the ray to use\r\n * @param fastCheck defines if fast mode (but less precise) must be used (false by default)\r\n * @param trianglePredicate defines an optional predicate used to select faces when a mesh intersection is detected\r\n * @returns the picking info\r\n * @see http://doc.babylonjs.com/babylon101/intersect_collisions_-_mesh\r\n */\r\n AbstractMesh.prototype.intersects = function (ray, fastCheck, trianglePredicate) {\r\n var pickingInfo = new PickingInfo();\r\n var intersectionThreshold = this.getClassName() === \"InstancedLinesMesh\" || this.getClassName() === \"LinesMesh\" ? this.intersectionThreshold : 0;\r\n var boundingInfo = this._boundingInfo;\r\n if (!this.subMeshes || !boundingInfo || !ray.intersectsSphere(boundingInfo.boundingSphere, intersectionThreshold) || !ray.intersectsBox(boundingInfo.boundingBox, intersectionThreshold)) {\r\n return pickingInfo;\r\n }\r\n if (!this._generatePointsArray()) {\r\n return pickingInfo;\r\n }\r\n var intersectInfo = null;\r\n var subMeshes = this._scene.getIntersectingSubMeshCandidates(this, ray);\r\n var len = subMeshes.length;\r\n for (var index = 0; index < len; index++) {\r\n var subMesh = subMeshes.data[index];\r\n // Bounding test\r\n if (len > 1 && !subMesh.canIntersects(ray)) {\r\n continue;\r\n }\r\n var currentIntersectInfo = subMesh.intersects(ray, this._positions, this.getIndices(), fastCheck, trianglePredicate);\r\n if (currentIntersectInfo) {\r\n if (fastCheck || !intersectInfo || currentIntersectInfo.distance < intersectInfo.distance) {\r\n intersectInfo = currentIntersectInfo;\r\n intersectInfo.subMeshId = index;\r\n if (fastCheck) {\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n if (intersectInfo) {\r\n // Get picked point\r\n var world = this.getWorldMatrix();\r\n var worldOrigin = TmpVectors.Vector3[0];\r\n var direction = TmpVectors.Vector3[1];\r\n Vector3.TransformCoordinatesToRef(ray.origin, world, worldOrigin);\r\n ray.direction.scaleToRef(intersectInfo.distance, direction);\r\n var worldDirection = Vector3.TransformNormal(direction, world);\r\n var pickedPoint = worldDirection.addInPlace(worldOrigin);\r\n // Return result\r\n pickingInfo.hit = true;\r\n pickingInfo.distance = Vector3.Distance(worldOrigin, pickedPoint);\r\n pickingInfo.pickedPoint = pickedPoint;\r\n pickingInfo.pickedMesh = this;\r\n pickingInfo.bu = intersectInfo.bu || 0;\r\n pickingInfo.bv = intersectInfo.bv || 0;\r\n pickingInfo.faceId = intersectInfo.faceId;\r\n pickingInfo.subMeshId = intersectInfo.subMeshId;\r\n return pickingInfo;\r\n }\r\n return pickingInfo;\r\n };\r\n /**\r\n * Clones the current mesh\r\n * @param name defines the mesh name\r\n * @param newParent defines the new mesh parent\r\n * @param doNotCloneChildren defines a boolean indicating that children must not be cloned (false by default)\r\n * @returns the new mesh\r\n */\r\n AbstractMesh.prototype.clone = function (name, newParent, doNotCloneChildren) {\r\n return null;\r\n };\r\n /**\r\n * Disposes all the submeshes of the current meshnp\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.releaseSubMeshes = function () {\r\n if (this.subMeshes) {\r\n while (this.subMeshes.length) {\r\n this.subMeshes[0].dispose();\r\n }\r\n }\r\n else {\r\n this.subMeshes = new Array();\r\n }\r\n return this;\r\n };\r\n /**\r\n * Releases resources associated with this abstract mesh.\r\n * @param doNotRecurse Set to true to not recurse into each children (recurse into each children by default)\r\n * @param disposeMaterialAndTextures Set to true to also dispose referenced materials and textures (false by default)\r\n */\r\n AbstractMesh.prototype.dispose = function (doNotRecurse, disposeMaterialAndTextures) {\r\n var _this = this;\r\n if (disposeMaterialAndTextures === void 0) { disposeMaterialAndTextures = false; }\r\n var index;\r\n // mesh map release.\r\n if (this._scene.useMaterialMeshMap) {\r\n // remove from material mesh map id needed\r\n if (this._material && this._material.meshMap) {\r\n this._material.meshMap[this.uniqueId] = undefined;\r\n }\r\n }\r\n // Smart Array Retainers.\r\n this.getScene().freeActiveMeshes();\r\n this.getScene().freeRenderingGroups();\r\n // Action manager\r\n if (this.actionManager !== undefined && this.actionManager !== null) {\r\n this.actionManager.dispose();\r\n this.actionManager = null;\r\n }\r\n // Skeleton\r\n this._internalAbstractMeshDataInfo._skeleton = null;\r\n if (this._transformMatrixTexture) {\r\n this._transformMatrixTexture.dispose();\r\n this._transformMatrixTexture = null;\r\n }\r\n // Intersections in progress\r\n for (index = 0; index < this._intersectionsInProgress.length; index++) {\r\n var other = this._intersectionsInProgress[index];\r\n var pos = other._intersectionsInProgress.indexOf(this);\r\n other._intersectionsInProgress.splice(pos, 1);\r\n }\r\n this._intersectionsInProgress = [];\r\n // Lights\r\n var lights = this.getScene().lights;\r\n lights.forEach(function (light) {\r\n var meshIndex = light.includedOnlyMeshes.indexOf(_this);\r\n if (meshIndex !== -1) {\r\n light.includedOnlyMeshes.splice(meshIndex, 1);\r\n }\r\n meshIndex = light.excludedMeshes.indexOf(_this);\r\n if (meshIndex !== -1) {\r\n light.excludedMeshes.splice(meshIndex, 1);\r\n }\r\n // Shadow generators\r\n var generator = light.getShadowGenerator();\r\n if (generator) {\r\n var shadowMap = generator.getShadowMap();\r\n if (shadowMap && shadowMap.renderList) {\r\n meshIndex = shadowMap.renderList.indexOf(_this);\r\n if (meshIndex !== -1) {\r\n shadowMap.renderList.splice(meshIndex, 1);\r\n }\r\n }\r\n }\r\n });\r\n // SubMeshes\r\n if (this.getClassName() !== \"InstancedMesh\" || this.getClassName() !== \"InstancedLinesMesh\") {\r\n this.releaseSubMeshes();\r\n }\r\n // Query\r\n var engine = this.getScene().getEngine();\r\n if (this._occlusionQuery) {\r\n this.isOcclusionQueryInProgress = false;\r\n engine.deleteQuery(this._occlusionQuery);\r\n this._occlusionQuery = null;\r\n }\r\n // Engine\r\n engine.wipeCaches();\r\n // Remove from scene\r\n this.getScene().removeMesh(this);\r\n if (disposeMaterialAndTextures) {\r\n if (this.material) {\r\n if (this.material.getClassName() === \"MultiMaterial\") {\r\n this.material.dispose(false, true, true);\r\n }\r\n else {\r\n this.material.dispose(false, true);\r\n }\r\n }\r\n }\r\n if (!doNotRecurse) {\r\n // Particles\r\n for (index = 0; index < this.getScene().particleSystems.length; index++) {\r\n if (this.getScene().particleSystems[index].emitter === this) {\r\n this.getScene().particleSystems[index].dispose();\r\n index--;\r\n }\r\n }\r\n }\r\n // facet data\r\n if (this._internalAbstractMeshDataInfo._facetData.facetDataEnabled) {\r\n this.disableFacetData();\r\n }\r\n this.onAfterWorldMatrixUpdateObservable.clear();\r\n this.onCollideObservable.clear();\r\n this.onCollisionPositionChangeObservable.clear();\r\n this.onRebuildObservable.clear();\r\n _super.prototype.dispose.call(this, doNotRecurse, disposeMaterialAndTextures);\r\n };\r\n /**\r\n * Adds the passed mesh as a child to the current mesh\r\n * @param mesh defines the child mesh\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.addChild = function (mesh) {\r\n mesh.setParent(this);\r\n return this;\r\n };\r\n /**\r\n * Removes the passed mesh from the current mesh children list\r\n * @param mesh defines the child mesh\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.removeChild = function (mesh) {\r\n mesh.setParent(null);\r\n return this;\r\n };\r\n // Facet data\r\n /** @hidden */\r\n AbstractMesh.prototype._initFacetData = function () {\r\n var data = this._internalAbstractMeshDataInfo._facetData;\r\n if (!data.facetNormals) {\r\n data.facetNormals = new Array();\r\n }\r\n if (!data.facetPositions) {\r\n data.facetPositions = new Array();\r\n }\r\n if (!data.facetPartitioning) {\r\n data.facetPartitioning = new Array();\r\n }\r\n data.facetNb = (this.getIndices().length / 3) | 0;\r\n data.partitioningSubdivisions = (data.partitioningSubdivisions) ? data.partitioningSubdivisions : 10; // default nb of partitioning subdivisions = 10\r\n data.partitioningBBoxRatio = (data.partitioningBBoxRatio) ? data.partitioningBBoxRatio : 1.01; // default ratio 1.01 = the partitioning is 1% bigger than the bounding box\r\n for (var f = 0; f < data.facetNb; f++) {\r\n data.facetNormals[f] = Vector3.Zero();\r\n data.facetPositions[f] = Vector3.Zero();\r\n }\r\n data.facetDataEnabled = true;\r\n return this;\r\n };\r\n /**\r\n * Updates the mesh facetData arrays and the internal partitioning when the mesh is morphed or updated.\r\n * This method can be called within the render loop.\r\n * You don't need to call this method by yourself in the render loop when you update/morph a mesh with the methods CreateXXX() as they automatically manage this computation\r\n * @returns the current mesh\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.updateFacetData = function () {\r\n var data = this._internalAbstractMeshDataInfo._facetData;\r\n if (!data.facetDataEnabled) {\r\n this._initFacetData();\r\n }\r\n var positions = this.getVerticesData(VertexBuffer.PositionKind);\r\n var indices = this.getIndices();\r\n var normals = this.getVerticesData(VertexBuffer.NormalKind);\r\n var bInfo = this.getBoundingInfo();\r\n if (data.facetDepthSort && !data.facetDepthSortEnabled) {\r\n // init arrays, matrix and sort function on first call\r\n data.facetDepthSortEnabled = true;\r\n if (indices instanceof Uint16Array) {\r\n data.depthSortedIndices = new Uint16Array(indices);\r\n }\r\n else if (indices instanceof Uint32Array) {\r\n data.depthSortedIndices = new Uint32Array(indices);\r\n }\r\n else {\r\n var needs32bits = false;\r\n for (var i = 0; i < indices.length; i++) {\r\n if (indices[i] > 65535) {\r\n needs32bits = true;\r\n break;\r\n }\r\n }\r\n if (needs32bits) {\r\n data.depthSortedIndices = new Uint32Array(indices);\r\n }\r\n else {\r\n data.depthSortedIndices = new Uint16Array(indices);\r\n }\r\n }\r\n data.facetDepthSortFunction = function (f1, f2) {\r\n return (f2.sqDistance - f1.sqDistance);\r\n };\r\n if (!data.facetDepthSortFrom) {\r\n var camera = this.getScene().activeCamera;\r\n data.facetDepthSortFrom = (camera) ? camera.position : Vector3.Zero();\r\n }\r\n data.depthSortedFacets = [];\r\n for (var f = 0; f < data.facetNb; f++) {\r\n var depthSortedFacet = { ind: f * 3, sqDistance: 0.0 };\r\n data.depthSortedFacets.push(depthSortedFacet);\r\n }\r\n data.invertedMatrix = Matrix.Identity();\r\n data.facetDepthSortOrigin = Vector3.Zero();\r\n }\r\n data.bbSize.x = (bInfo.maximum.x - bInfo.minimum.x > Epsilon) ? bInfo.maximum.x - bInfo.minimum.x : Epsilon;\r\n data.bbSize.y = (bInfo.maximum.y - bInfo.minimum.y > Epsilon) ? bInfo.maximum.y - bInfo.minimum.y : Epsilon;\r\n data.bbSize.z = (bInfo.maximum.z - bInfo.minimum.z > Epsilon) ? bInfo.maximum.z - bInfo.minimum.z : Epsilon;\r\n var bbSizeMax = (data.bbSize.x > data.bbSize.y) ? data.bbSize.x : data.bbSize.y;\r\n bbSizeMax = (bbSizeMax > data.bbSize.z) ? bbSizeMax : data.bbSize.z;\r\n data.subDiv.max = data.partitioningSubdivisions;\r\n data.subDiv.X = Math.floor(data.subDiv.max * data.bbSize.x / bbSizeMax); // adjust the number of subdivisions per axis\r\n data.subDiv.Y = Math.floor(data.subDiv.max * data.bbSize.y / bbSizeMax); // according to each bbox size per axis\r\n data.subDiv.Z = Math.floor(data.subDiv.max * data.bbSize.z / bbSizeMax);\r\n data.subDiv.X = data.subDiv.X < 1 ? 1 : data.subDiv.X; // at least one subdivision\r\n data.subDiv.Y = data.subDiv.Y < 1 ? 1 : data.subDiv.Y;\r\n data.subDiv.Z = data.subDiv.Z < 1 ? 1 : data.subDiv.Z;\r\n // set the parameters for ComputeNormals()\r\n data.facetParameters.facetNormals = this.getFacetLocalNormals();\r\n data.facetParameters.facetPositions = this.getFacetLocalPositions();\r\n data.facetParameters.facetPartitioning = this.getFacetLocalPartitioning();\r\n data.facetParameters.bInfo = bInfo;\r\n data.facetParameters.bbSize = data.bbSize;\r\n data.facetParameters.subDiv = data.subDiv;\r\n data.facetParameters.ratio = this.partitioningBBoxRatio;\r\n data.facetParameters.depthSort = data.facetDepthSort;\r\n if (data.facetDepthSort && data.facetDepthSortEnabled) {\r\n this.computeWorldMatrix(true);\r\n this._worldMatrix.invertToRef(data.invertedMatrix);\r\n Vector3.TransformCoordinatesToRef(data.facetDepthSortFrom, data.invertedMatrix, data.facetDepthSortOrigin);\r\n data.facetParameters.distanceTo = data.facetDepthSortOrigin;\r\n }\r\n data.facetParameters.depthSortedFacets = data.depthSortedFacets;\r\n VertexData.ComputeNormals(positions, indices, normals, data.facetParameters);\r\n if (data.facetDepthSort && data.facetDepthSortEnabled) {\r\n data.depthSortedFacets.sort(data.facetDepthSortFunction);\r\n var l = (data.depthSortedIndices.length / 3) | 0;\r\n for (var f = 0; f < l; f++) {\r\n var sind = data.depthSortedFacets[f].ind;\r\n data.depthSortedIndices[f * 3] = indices[sind];\r\n data.depthSortedIndices[f * 3 + 1] = indices[sind + 1];\r\n data.depthSortedIndices[f * 3 + 2] = indices[sind + 2];\r\n }\r\n this.updateIndices(data.depthSortedIndices, undefined, true);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Returns the facetLocalNormals array.\r\n * The normals are expressed in the mesh local spac\r\n * @returns an array of Vector3\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetLocalNormals = function () {\r\n var facetData = this._internalAbstractMeshDataInfo._facetData;\r\n if (!facetData.facetNormals) {\r\n this.updateFacetData();\r\n }\r\n return facetData.facetNormals;\r\n };\r\n /**\r\n * Returns the facetLocalPositions array.\r\n * The facet positions are expressed in the mesh local space\r\n * @returns an array of Vector3\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetLocalPositions = function () {\r\n var facetData = this._internalAbstractMeshDataInfo._facetData;\r\n if (!facetData.facetPositions) {\r\n this.updateFacetData();\r\n }\r\n return facetData.facetPositions;\r\n };\r\n /**\r\n * Returns the facetLocalPartioning array\r\n * @returns an array of array of numbers\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetLocalPartitioning = function () {\r\n var facetData = this._internalAbstractMeshDataInfo._facetData;\r\n if (!facetData.facetPartitioning) {\r\n this.updateFacetData();\r\n }\r\n return facetData.facetPartitioning;\r\n };\r\n /**\r\n * Returns the i-th facet position in the world system.\r\n * This method allocates a new Vector3 per call\r\n * @param i defines the facet index\r\n * @returns a new Vector3\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetPosition = function (i) {\r\n var pos = Vector3.Zero();\r\n this.getFacetPositionToRef(i, pos);\r\n return pos;\r\n };\r\n /**\r\n * Sets the reference Vector3 with the i-th facet position in the world system\r\n * @param i defines the facet index\r\n * @param ref defines the target vector\r\n * @returns the current mesh\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetPositionToRef = function (i, ref) {\r\n var localPos = (this.getFacetLocalPositions())[i];\r\n var world = this.getWorldMatrix();\r\n Vector3.TransformCoordinatesToRef(localPos, world, ref);\r\n return this;\r\n };\r\n /**\r\n * Returns the i-th facet normal in the world system.\r\n * This method allocates a new Vector3 per call\r\n * @param i defines the facet index\r\n * @returns a new Vector3\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetNormal = function (i) {\r\n var norm = Vector3.Zero();\r\n this.getFacetNormalToRef(i, norm);\r\n return norm;\r\n };\r\n /**\r\n * Sets the reference Vector3 with the i-th facet normal in the world system\r\n * @param i defines the facet index\r\n * @param ref defines the target vector\r\n * @returns the current mesh\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetNormalToRef = function (i, ref) {\r\n var localNorm = (this.getFacetLocalNormals())[i];\r\n Vector3.TransformNormalToRef(localNorm, this.getWorldMatrix(), ref);\r\n return this;\r\n };\r\n /**\r\n * Returns the facets (in an array) in the same partitioning block than the one the passed coordinates are located (expressed in the mesh local system)\r\n * @param x defines x coordinate\r\n * @param y defines y coordinate\r\n * @param z defines z coordinate\r\n * @returns the array of facet indexes\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetsAtLocalCoordinates = function (x, y, z) {\r\n var bInfo = this.getBoundingInfo();\r\n var data = this._internalAbstractMeshDataInfo._facetData;\r\n var ox = Math.floor((x - bInfo.minimum.x * data.partitioningBBoxRatio) * data.subDiv.X * data.partitioningBBoxRatio / data.bbSize.x);\r\n var oy = Math.floor((y - bInfo.minimum.y * data.partitioningBBoxRatio) * data.subDiv.Y * data.partitioningBBoxRatio / data.bbSize.y);\r\n var oz = Math.floor((z - bInfo.minimum.z * data.partitioningBBoxRatio) * data.subDiv.Z * data.partitioningBBoxRatio / data.bbSize.z);\r\n if (ox < 0 || ox > data.subDiv.max || oy < 0 || oy > data.subDiv.max || oz < 0 || oz > data.subDiv.max) {\r\n return null;\r\n }\r\n return data.facetPartitioning[ox + data.subDiv.max * oy + data.subDiv.max * data.subDiv.max * oz];\r\n };\r\n /**\r\n * Returns the closest mesh facet index at (x,y,z) World coordinates, null if not found\r\n * @param projected sets as the (x,y,z) world projection on the facet\r\n * @param checkFace if true (default false), only the facet \"facing\" to (x,y,z) or only the ones \"turning their backs\", according to the parameter \"facing\" are returned\r\n * @param facing if facing and checkFace are true, only the facet \"facing\" to (x, y, z) are returned : positive dot (x, y, z) * facet position. If facing si false and checkFace is true, only the facet \"turning their backs\" to (x, y, z) are returned : negative dot (x, y, z) * facet position\r\n * @param x defines x coordinate\r\n * @param y defines y coordinate\r\n * @param z defines z coordinate\r\n * @returns the face index if found (or null instead)\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getClosestFacetAtCoordinates = function (x, y, z, projected, checkFace, facing) {\r\n if (checkFace === void 0) { checkFace = false; }\r\n if (facing === void 0) { facing = true; }\r\n var world = this.getWorldMatrix();\r\n var invMat = TmpVectors.Matrix[5];\r\n world.invertToRef(invMat);\r\n var invVect = TmpVectors.Vector3[8];\r\n Vector3.TransformCoordinatesFromFloatsToRef(x, y, z, invMat, invVect); // transform (x,y,z) to coordinates in the mesh local space\r\n var closest = this.getClosestFacetAtLocalCoordinates(invVect.x, invVect.y, invVect.z, projected, checkFace, facing);\r\n if (projected) {\r\n // tranform the local computed projected vector to world coordinates\r\n Vector3.TransformCoordinatesFromFloatsToRef(projected.x, projected.y, projected.z, world, projected);\r\n }\r\n return closest;\r\n };\r\n /**\r\n * Returns the closest mesh facet index at (x,y,z) local coordinates, null if not found\r\n * @param projected sets as the (x,y,z) local projection on the facet\r\n * @param checkFace if true (default false), only the facet \"facing\" to (x,y,z) or only the ones \"turning their backs\", according to the parameter \"facing\" are returned\r\n * @param facing if facing and checkFace are true, only the facet \"facing\" to (x, y, z) are returned : positive dot (x, y, z) * facet position. If facing si false and checkFace is true, only the facet \"turning their backs\" to (x, y, z) are returned : negative dot (x, y, z) * facet position\r\n * @param x defines x coordinate\r\n * @param y defines y coordinate\r\n * @param z defines z coordinate\r\n * @returns the face index if found (or null instead)\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getClosestFacetAtLocalCoordinates = function (x, y, z, projected, checkFace, facing) {\r\n if (checkFace === void 0) { checkFace = false; }\r\n if (facing === void 0) { facing = true; }\r\n var closest = null;\r\n var tmpx = 0.0;\r\n var tmpy = 0.0;\r\n var tmpz = 0.0;\r\n var d = 0.0; // tmp dot facet normal * facet position\r\n var t0 = 0.0;\r\n var projx = 0.0;\r\n var projy = 0.0;\r\n var projz = 0.0;\r\n // Get all the facets in the same partitioning block than (x, y, z)\r\n var facetPositions = this.getFacetLocalPositions();\r\n var facetNormals = this.getFacetLocalNormals();\r\n var facetsInBlock = this.getFacetsAtLocalCoordinates(x, y, z);\r\n if (!facetsInBlock) {\r\n return null;\r\n }\r\n // Get the closest facet to (x, y, z)\r\n var shortest = Number.MAX_VALUE; // init distance vars\r\n var tmpDistance = shortest;\r\n var fib; // current facet in the block\r\n var norm; // current facet normal\r\n var p0; // current facet barycenter position\r\n // loop on all the facets in the current partitioning block\r\n for (var idx = 0; idx < facetsInBlock.length; idx++) {\r\n fib = facetsInBlock[idx];\r\n norm = facetNormals[fib];\r\n p0 = facetPositions[fib];\r\n d = (x - p0.x) * norm.x + (y - p0.y) * norm.y + (z - p0.z) * norm.z;\r\n if (!checkFace || (checkFace && facing && d >= 0.0) || (checkFace && !facing && d <= 0.0)) {\r\n // compute (x,y,z) projection on the facet = (projx, projy, projz)\r\n d = norm.x * p0.x + norm.y * p0.y + norm.z * p0.z;\r\n t0 = -(norm.x * x + norm.y * y + norm.z * z - d) / (norm.x * norm.x + norm.y * norm.y + norm.z * norm.z);\r\n projx = x + norm.x * t0;\r\n projy = y + norm.y * t0;\r\n projz = z + norm.z * t0;\r\n tmpx = projx - x;\r\n tmpy = projy - y;\r\n tmpz = projz - z;\r\n tmpDistance = tmpx * tmpx + tmpy * tmpy + tmpz * tmpz; // compute length between (x, y, z) and its projection on the facet\r\n if (tmpDistance < shortest) { // just keep the closest facet to (x, y, z)\r\n shortest = tmpDistance;\r\n closest = fib;\r\n if (projected) {\r\n projected.x = projx;\r\n projected.y = projy;\r\n projected.z = projz;\r\n }\r\n }\r\n }\r\n }\r\n return closest;\r\n };\r\n /**\r\n * Returns the object \"parameter\" set with all the expected parameters for facetData computation by ComputeNormals()\r\n * @returns the parameters\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetDataParameters = function () {\r\n return this._internalAbstractMeshDataInfo._facetData.facetParameters;\r\n };\r\n /**\r\n * Disables the feature FacetData and frees the related memory\r\n * @returns the current mesh\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.disableFacetData = function () {\r\n var facetData = this._internalAbstractMeshDataInfo._facetData;\r\n if (facetData.facetDataEnabled) {\r\n facetData.facetDataEnabled = false;\r\n facetData.facetPositions = new Array();\r\n facetData.facetNormals = new Array();\r\n facetData.facetPartitioning = new Array();\r\n facetData.facetParameters = null;\r\n facetData.depthSortedIndices = new Uint32Array(0);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Updates the AbstractMesh indices array\r\n * @param indices defines the data source\r\n * @param offset defines the offset in the index buffer where to store the new data (can be null)\r\n * @param gpuMemoryOnly defines a boolean indicating that only the GPU memory must be updated leaving the CPU version of the indices unchanged (false by default)\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.updateIndices = function (indices, offset, gpuMemoryOnly) {\r\n if (gpuMemoryOnly === void 0) { gpuMemoryOnly = false; }\r\n return this;\r\n };\r\n /**\r\n * Creates new normals data for the mesh\r\n * @param updatable defines if the normal vertex buffer must be flagged as updatable\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.createNormals = function (updatable) {\r\n var positions = this.getVerticesData(VertexBuffer.PositionKind);\r\n var indices = this.getIndices();\r\n var normals;\r\n if (this.isVerticesDataPresent(VertexBuffer.NormalKind)) {\r\n normals = this.getVerticesData(VertexBuffer.NormalKind);\r\n }\r\n else {\r\n normals = [];\r\n }\r\n VertexData.ComputeNormals(positions, indices, normals, { useRightHandedSystem: this.getScene().useRightHandedSystem });\r\n this.setVerticesData(VertexBuffer.NormalKind, normals, updatable);\r\n return this;\r\n };\r\n /**\r\n * Align the mesh with a normal\r\n * @param normal defines the normal to use\r\n * @param upDirection can be used to redefined the up vector to use (will use the (0, 1, 0) by default)\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.alignWithNormal = function (normal, upDirection) {\r\n if (!upDirection) {\r\n upDirection = Axis.Y;\r\n }\r\n var axisX = TmpVectors.Vector3[0];\r\n var axisZ = TmpVectors.Vector3[1];\r\n Vector3.CrossToRef(upDirection, normal, axisZ);\r\n Vector3.CrossToRef(normal, axisZ, axisX);\r\n if (this.rotationQuaternion) {\r\n Quaternion.RotationQuaternionFromAxisToRef(axisX, normal, axisZ, this.rotationQuaternion);\r\n }\r\n else {\r\n Vector3.RotationFromAxisToRef(axisX, normal, axisZ, this.rotation);\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._checkOcclusionQuery = function () {\r\n return false;\r\n };\r\n /**\r\n * Disables the mesh edge rendering mode\r\n * @returns the currentAbstractMesh\r\n */\r\n AbstractMesh.prototype.disableEdgesRendering = function () {\r\n throw _DevTools.WarnImport(\"EdgesRenderer\");\r\n };\r\n /**\r\n * Enables the edge rendering mode on the mesh.\r\n * This mode makes the mesh edges visible\r\n * @param epsilon defines the maximal distance between two angles to detect a face\r\n * @param checkVerticesInsteadOfIndices indicates that we should check vertex list directly instead of faces\r\n * @returns the currentAbstractMesh\r\n * @see https://www.babylonjs-playground.com/#19O9TU#0\r\n */\r\n AbstractMesh.prototype.enableEdgesRendering = function (epsilon, checkVerticesInsteadOfIndices) {\r\n throw _DevTools.WarnImport(\"EdgesRenderer\");\r\n };\r\n /** No occlusion */\r\n AbstractMesh.OCCLUSION_TYPE_NONE = 0;\r\n /** Occlusion set to optimisitic */\r\n AbstractMesh.OCCLUSION_TYPE_OPTIMISTIC = 1;\r\n /** Occlusion set to strict */\r\n AbstractMesh.OCCLUSION_TYPE_STRICT = 2;\r\n /** Use an accurante occlusion algorithm */\r\n AbstractMesh.OCCLUSION_ALGORITHM_TYPE_ACCURATE = 0;\r\n /** Use a conservative occlusion algorithm */\r\n AbstractMesh.OCCLUSION_ALGORITHM_TYPE_CONSERVATIVE = 1;\r\n /** Default culling strategy : this is an exclusion test and it's the more accurate.\r\n * Test order :\r\n * Is the bounding sphere outside the frustum ?\r\n * If not, are the bounding box vertices outside the frustum ?\r\n * It not, then the cullable object is in the frustum.\r\n */\r\n AbstractMesh.CULLINGSTRATEGY_STANDARD = 0;\r\n /** Culling strategy : Bounding Sphere Only.\r\n * This is an exclusion test. It's faster than the standard strategy because the bounding box is not tested.\r\n * It's also less accurate than the standard because some not visible objects can still be selected.\r\n * Test : is the bounding sphere outside the frustum ?\r\n * If not, then the cullable object is in the frustum.\r\n */\r\n AbstractMesh.CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY = 1;\r\n /** Culling strategy : Optimistic Inclusion.\r\n * This in an inclusion test first, then the standard exclusion test.\r\n * This can be faster when a cullable object is expected to be almost always in the camera frustum.\r\n * This could also be a little slower than the standard test when the tested object center is not the frustum but one of its bounding box vertex is still inside.\r\n * Anyway, it's as accurate as the standard strategy.\r\n * Test :\r\n * Is the cullable object bounding sphere center in the frustum ?\r\n * If not, apply the default culling strategy.\r\n */\r\n AbstractMesh.CULLINGSTRATEGY_OPTIMISTIC_INCLUSION = 2;\r\n /** Culling strategy : Optimistic Inclusion then Bounding Sphere Only.\r\n * This in an inclusion test first, then the bounding sphere only exclusion test.\r\n * This can be the fastest test when a cullable object is expected to be almost always in the camera frustum.\r\n * This could also be a little slower than the BoundingSphereOnly strategy when the tested object center is not in the frustum but its bounding sphere still intersects it.\r\n * It's less accurate than the standard strategy and as accurate as the BoundingSphereOnly strategy.\r\n * Test :\r\n * Is the cullable object bounding sphere center in the frustum ?\r\n * If not, apply the Bounding Sphere Only strategy. No Bounding Box is tested here.\r\n */\r\n AbstractMesh.CULLINGSTRATEGY_OPTIMISTIC_INCLUSION_THEN_BSPHERE_ONLY = 3;\r\n return AbstractMesh;\r\n}(TransformNode));\r\nexport { AbstractMesh };\r\n//# sourceMappingURL=abstractMesh.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, SerializationHelper, serializeAsColor3, expandToProperty } from \"../Misc/decorators\";\r\nimport { Vector3 } from \"../Maths/math.vector\";\r\nimport { Color3, TmpColors } from \"../Maths/math.color\";\r\nimport { Node } from \"../node\";\r\nimport { UniformBuffer } from \"../Materials/uniformBuffer\";\r\nimport { _TypeStore } from '../Misc/typeStore';\r\n/**\r\n * Base class of all the lights in Babylon. It groups all the generic information about lights.\r\n * Lights are used, as you would expect, to affect how meshes are seen, in terms of both illumination and colour.\r\n * All meshes allow light to pass through them unless shadow generation is activated. The default number of lights allowed is four but this can be increased.\r\n */\r\nvar Light = /** @class */ (function (_super) {\r\n __extends(Light, _super);\r\n /**\r\n * Creates a Light object in the scene.\r\n * Documentation : https://doc.babylonjs.com/babylon101/lights\r\n * @param name The firendly name of the light\r\n * @param scene The scene the light belongs too\r\n */\r\n function Light(name, scene) {\r\n var _this = _super.call(this, name, scene) || this;\r\n /**\r\n * Diffuse gives the basic color to an object.\r\n */\r\n _this.diffuse = new Color3(1.0, 1.0, 1.0);\r\n /**\r\n * Specular produces a highlight color on an object.\r\n * Note: This is note affecting PBR materials.\r\n */\r\n _this.specular = new Color3(1.0, 1.0, 1.0);\r\n /**\r\n * Defines the falloff type for this light. This lets overrriding how punctual light are\r\n * falling off base on range or angle.\r\n * This can be set to any values in Light.FALLOFF_x.\r\n *\r\n * Note: This is only useful for PBR Materials at the moment. This could be extended if required to\r\n * other types of materials.\r\n */\r\n _this.falloffType = Light.FALLOFF_DEFAULT;\r\n /**\r\n * Strength of the light.\r\n * Note: By default it is define in the framework own unit.\r\n * Note: In PBR materials the intensityMode can be use to chose what unit the intensity is defined in.\r\n */\r\n _this.intensity = 1.0;\r\n _this._range = Number.MAX_VALUE;\r\n _this._inverseSquaredRange = 0;\r\n /**\r\n * Cached photometric scale default to 1.0 as the automatic intensity mode defaults to 1.0 for every type\r\n * of light.\r\n */\r\n _this._photometricScale = 1.0;\r\n _this._intensityMode = Light.INTENSITYMODE_AUTOMATIC;\r\n _this._radius = 0.00001;\r\n /**\r\n * Defines the rendering priority of the lights. It can help in case of fallback or number of lights\r\n * exceeding the number allowed of the materials.\r\n */\r\n _this.renderPriority = 0;\r\n _this._shadowEnabled = true;\r\n _this._excludeWithLayerMask = 0;\r\n _this._includeOnlyWithLayerMask = 0;\r\n _this._lightmapMode = 0;\r\n /**\r\n * @hidden Internal use only.\r\n */\r\n _this._excludedMeshesIds = new Array();\r\n /**\r\n * @hidden Internal use only.\r\n */\r\n _this._includedOnlyMeshesIds = new Array();\r\n /** @hidden */\r\n _this._isLight = true;\r\n _this.getScene().addLight(_this);\r\n _this._uniformBuffer = new UniformBuffer(_this.getScene().getEngine());\r\n _this._buildUniformLayout();\r\n _this.includedOnlyMeshes = new Array();\r\n _this.excludedMeshes = new Array();\r\n _this._resyncMeshes();\r\n return _this;\r\n }\r\n Object.defineProperty(Light.prototype, \"range\", {\r\n /**\r\n * Defines how far from the source the light is impacting in scene units.\r\n * Note: Unused in PBR material as the distance light falloff is defined following the inverse squared falloff.\r\n */\r\n get: function () {\r\n return this._range;\r\n },\r\n /**\r\n * Defines how far from the source the light is impacting in scene units.\r\n * Note: Unused in PBR material as the distance light falloff is defined following the inverse squared falloff.\r\n */\r\n set: function (value) {\r\n this._range = value;\r\n this._inverseSquaredRange = 1.0 / (this.range * this.range);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Light.prototype, \"intensityMode\", {\r\n /**\r\n * Gets the photometric scale used to interpret the intensity.\r\n * This is only relevant with PBR Materials where the light intensity can be defined in a physical way.\r\n */\r\n get: function () {\r\n return this._intensityMode;\r\n },\r\n /**\r\n * Sets the photometric scale used to interpret the intensity.\r\n * This is only relevant with PBR Materials where the light intensity can be defined in a physical way.\r\n */\r\n set: function (value) {\r\n this._intensityMode = value;\r\n this._computePhotometricScale();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Light.prototype, \"radius\", {\r\n /**\r\n * Gets the light radius used by PBR Materials to simulate soft area lights.\r\n */\r\n get: function () {\r\n return this._radius;\r\n },\r\n /**\r\n * sets the light radius used by PBR Materials to simulate soft area lights.\r\n */\r\n set: function (value) {\r\n this._radius = value;\r\n this._computePhotometricScale();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Light.prototype, \"shadowEnabled\", {\r\n /**\r\n * Gets wether or not the shadows are enabled for this light. This can help turning off/on shadow without detaching\r\n * the current shadow generator.\r\n */\r\n get: function () {\r\n return this._shadowEnabled;\r\n },\r\n /**\r\n * Sets wether or not the shadows are enabled for this light. This can help turning off/on shadow without detaching\r\n * the current shadow generator.\r\n */\r\n set: function (value) {\r\n if (this._shadowEnabled === value) {\r\n return;\r\n }\r\n this._shadowEnabled = value;\r\n this._markMeshesAsLightDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Light.prototype, \"includedOnlyMeshes\", {\r\n /**\r\n * Gets the only meshes impacted by this light.\r\n */\r\n get: function () {\r\n return this._includedOnlyMeshes;\r\n },\r\n /**\r\n * Sets the only meshes impacted by this light.\r\n */\r\n set: function (value) {\r\n this._includedOnlyMeshes = value;\r\n this._hookArrayForIncludedOnly(value);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Light.prototype, \"excludedMeshes\", {\r\n /**\r\n * Gets the meshes not impacted by this light.\r\n */\r\n get: function () {\r\n return this._excludedMeshes;\r\n },\r\n /**\r\n * Sets the meshes not impacted by this light.\r\n */\r\n set: function (value) {\r\n this._excludedMeshes = value;\r\n this._hookArrayForExcluded(value);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Light.prototype, \"excludeWithLayerMask\", {\r\n /**\r\n * Gets the layer id use to find what meshes are not impacted by the light.\r\n * Inactive if 0\r\n */\r\n get: function () {\r\n return this._excludeWithLayerMask;\r\n },\r\n /**\r\n * Sets the layer id use to find what meshes are not impacted by the light.\r\n * Inactive if 0\r\n */\r\n set: function (value) {\r\n this._excludeWithLayerMask = value;\r\n this._resyncMeshes();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Light.prototype, \"includeOnlyWithLayerMask\", {\r\n /**\r\n * Gets the layer id use to find what meshes are impacted by the light.\r\n * Inactive if 0\r\n */\r\n get: function () {\r\n return this._includeOnlyWithLayerMask;\r\n },\r\n /**\r\n * Sets the layer id use to find what meshes are impacted by the light.\r\n * Inactive if 0\r\n */\r\n set: function (value) {\r\n this._includeOnlyWithLayerMask = value;\r\n this._resyncMeshes();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Light.prototype, \"lightmapMode\", {\r\n /**\r\n * Gets the lightmap mode of this light (should be one of the constants defined by Light.LIGHTMAP_x)\r\n */\r\n get: function () {\r\n return this._lightmapMode;\r\n },\r\n /**\r\n * Sets the lightmap mode of this light (should be one of the constants defined by Light.LIGHTMAP_x)\r\n */\r\n set: function (value) {\r\n if (this._lightmapMode === value) {\r\n return;\r\n }\r\n this._lightmapMode = value;\r\n this._markMeshesAsLightDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Sets the passed Effect \"effect\" with the Light textures.\r\n * @param effect The effect to update\r\n * @param lightIndex The index of the light in the effect to update\r\n * @returns The light\r\n */\r\n Light.prototype.transferTexturesToEffect = function (effect, lightIndex) {\r\n // Do nothing by default.\r\n return this;\r\n };\r\n /**\r\n * Binds the lights information from the scene to the effect for the given mesh.\r\n * @param lightIndex Light index\r\n * @param scene The scene where the light belongs to\r\n * @param effect The effect we are binding the data to\r\n * @param useSpecular Defines if specular is supported\r\n * @param rebuildInParallel Specifies whether the shader is rebuilding in parallel\r\n */\r\n Light.prototype._bindLight = function (lightIndex, scene, effect, useSpecular, rebuildInParallel) {\r\n if (rebuildInParallel === void 0) { rebuildInParallel = false; }\r\n var iAsString = lightIndex.toString();\r\n var needUpdate = false;\r\n if (rebuildInParallel && this._uniformBuffer._alreadyBound) {\r\n return;\r\n }\r\n this._uniformBuffer.bindToEffect(effect, \"Light\" + iAsString);\r\n if (this._renderId !== scene.getRenderId() || !this._uniformBuffer.useUbo) {\r\n this._renderId = scene.getRenderId();\r\n var scaledIntensity = this.getScaledIntensity();\r\n this.transferToEffect(effect, iAsString);\r\n this.diffuse.scaleToRef(scaledIntensity, TmpColors.Color3[0]);\r\n this._uniformBuffer.updateColor4(\"vLightDiffuse\", TmpColors.Color3[0], this.range, iAsString);\r\n if (useSpecular) {\r\n this.specular.scaleToRef(scaledIntensity, TmpColors.Color3[1]);\r\n this._uniformBuffer.updateColor4(\"vLightSpecular\", TmpColors.Color3[1], this.radius, iAsString);\r\n }\r\n needUpdate = true;\r\n }\r\n // Textures might still need to be rebound.\r\n this.transferTexturesToEffect(effect, iAsString);\r\n // Shadows\r\n if (scene.shadowsEnabled && this.shadowEnabled) {\r\n var shadowGenerator = this.getShadowGenerator();\r\n if (shadowGenerator) {\r\n shadowGenerator.bindShadowLight(iAsString, effect);\r\n needUpdate = true;\r\n }\r\n }\r\n if (needUpdate) {\r\n this._uniformBuffer.update();\r\n }\r\n };\r\n /**\r\n * Returns the string \"Light\".\r\n * @returns the class name\r\n */\r\n Light.prototype.getClassName = function () {\r\n return \"Light\";\r\n };\r\n /**\r\n * Converts the light information to a readable string for debug purpose.\r\n * @param fullDetails Supports for multiple levels of logging within scene loading\r\n * @returns the human readable light info\r\n */\r\n Light.prototype.toString = function (fullDetails) {\r\n var ret = \"Name: \" + this.name;\r\n ret += \", type: \" + ([\"Point\", \"Directional\", \"Spot\", \"Hemispheric\"])[this.getTypeID()];\r\n if (this.animations) {\r\n for (var i = 0; i < this.animations.length; i++) {\r\n ret += \", animation[0]: \" + this.animations[i].toString(fullDetails);\r\n }\r\n }\r\n if (fullDetails) {\r\n }\r\n return ret;\r\n };\r\n /** @hidden */\r\n Light.prototype._syncParentEnabledState = function () {\r\n _super.prototype._syncParentEnabledState.call(this);\r\n if (!this.isDisposed()) {\r\n this._resyncMeshes();\r\n }\r\n };\r\n /**\r\n * Set the enabled state of this node.\r\n * @param value - the new enabled state\r\n */\r\n Light.prototype.setEnabled = function (value) {\r\n _super.prototype.setEnabled.call(this, value);\r\n this._resyncMeshes();\r\n };\r\n /**\r\n * Returns the Light associated shadow generator if any.\r\n * @return the associated shadow generator.\r\n */\r\n Light.prototype.getShadowGenerator = function () {\r\n return this._shadowGenerator;\r\n };\r\n /**\r\n * Returns a Vector3, the absolute light position in the World.\r\n * @returns the world space position of the light\r\n */\r\n Light.prototype.getAbsolutePosition = function () {\r\n return Vector3.Zero();\r\n };\r\n /**\r\n * Specifies if the light will affect the passed mesh.\r\n * @param mesh The mesh to test against the light\r\n * @return true the mesh is affected otherwise, false.\r\n */\r\n Light.prototype.canAffectMesh = function (mesh) {\r\n if (!mesh) {\r\n return true;\r\n }\r\n if (this.includedOnlyMeshes && this.includedOnlyMeshes.length > 0 && this.includedOnlyMeshes.indexOf(mesh) === -1) {\r\n return false;\r\n }\r\n if (this.excludedMeshes && this.excludedMeshes.length > 0 && this.excludedMeshes.indexOf(mesh) !== -1) {\r\n return false;\r\n }\r\n if (this.includeOnlyWithLayerMask !== 0 && (this.includeOnlyWithLayerMask & mesh.layerMask) === 0) {\r\n return false;\r\n }\r\n if (this.excludeWithLayerMask !== 0 && this.excludeWithLayerMask & mesh.layerMask) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n /**\r\n * Sort function to order lights for rendering.\r\n * @param a First Light object to compare to second.\r\n * @param b Second Light object to compare first.\r\n * @return -1 to reduce's a's index relative to be, 0 for no change, 1 to increase a's index relative to b.\r\n */\r\n Light.CompareLightsPriority = function (a, b) {\r\n //shadow-casting lights have priority over non-shadow-casting lights\r\n //the renderPrioirty is a secondary sort criterion\r\n if (a.shadowEnabled !== b.shadowEnabled) {\r\n return (b.shadowEnabled ? 1 : 0) - (a.shadowEnabled ? 1 : 0);\r\n }\r\n return b.renderPriority - a.renderPriority;\r\n };\r\n /**\r\n * Releases resources associated with this node.\r\n * @param doNotRecurse Set to true to not recurse into each children (recurse into each children by default)\r\n * @param disposeMaterialAndTextures Set to true to also dispose referenced materials and textures (false by default)\r\n */\r\n Light.prototype.dispose = function (doNotRecurse, disposeMaterialAndTextures) {\r\n if (disposeMaterialAndTextures === void 0) { disposeMaterialAndTextures = false; }\r\n if (this._shadowGenerator) {\r\n this._shadowGenerator.dispose();\r\n this._shadowGenerator = null;\r\n }\r\n // Animations\r\n this.getScene().stopAnimation(this);\r\n // Remove from meshes\r\n for (var _i = 0, _a = this.getScene().meshes; _i < _a.length; _i++) {\r\n var mesh = _a[_i];\r\n mesh._removeLightSource(this, true);\r\n }\r\n this._uniformBuffer.dispose();\r\n // Remove from scene\r\n this.getScene().removeLight(this);\r\n _super.prototype.dispose.call(this, doNotRecurse, disposeMaterialAndTextures);\r\n };\r\n /**\r\n * Returns the light type ID (integer).\r\n * @returns The light Type id as a constant defines in Light.LIGHTTYPEID_x\r\n */\r\n Light.prototype.getTypeID = function () {\r\n return 0;\r\n };\r\n /**\r\n * Returns the intensity scaled by the Photometric Scale according to the light type and intensity mode.\r\n * @returns the scaled intensity in intensity mode unit\r\n */\r\n Light.prototype.getScaledIntensity = function () {\r\n return this._photometricScale * this.intensity;\r\n };\r\n /**\r\n * Returns a new Light object, named \"name\", from the current one.\r\n * @param name The name of the cloned light\r\n * @returns the new created light\r\n */\r\n Light.prototype.clone = function (name) {\r\n var constructor = Light.GetConstructorFromName(this.getTypeID(), name, this.getScene());\r\n if (!constructor) {\r\n return null;\r\n }\r\n return SerializationHelper.Clone(constructor, this);\r\n };\r\n /**\r\n * Serializes the current light into a Serialization object.\r\n * @returns the serialized object.\r\n */\r\n Light.prototype.serialize = function () {\r\n var serializationObject = SerializationHelper.Serialize(this);\r\n // Type\r\n serializationObject.type = this.getTypeID();\r\n // Parent\r\n if (this.parent) {\r\n serializationObject.parentId = this.parent.id;\r\n }\r\n // Inclusion / exclusions\r\n if (this.excludedMeshes.length > 0) {\r\n serializationObject.excludedMeshesIds = [];\r\n this.excludedMeshes.forEach(function (mesh) {\r\n serializationObject.excludedMeshesIds.push(mesh.id);\r\n });\r\n }\r\n if (this.includedOnlyMeshes.length > 0) {\r\n serializationObject.includedOnlyMeshesIds = [];\r\n this.includedOnlyMeshes.forEach(function (mesh) {\r\n serializationObject.includedOnlyMeshesIds.push(mesh.id);\r\n });\r\n }\r\n // Animations\r\n SerializationHelper.AppendSerializedAnimations(this, serializationObject);\r\n serializationObject.ranges = this.serializeAnimationRanges();\r\n return serializationObject;\r\n };\r\n /**\r\n * Creates a new typed light from the passed type (integer) : point light = 0, directional light = 1, spot light = 2, hemispheric light = 3.\r\n * This new light is named \"name\" and added to the passed scene.\r\n * @param type Type according to the types available in Light.LIGHTTYPEID_x\r\n * @param name The friendly name of the light\r\n * @param scene The scene the new light will belong to\r\n * @returns the constructor function\r\n */\r\n Light.GetConstructorFromName = function (type, name, scene) {\r\n var constructorFunc = Node.Construct(\"Light_Type_\" + type, name, scene);\r\n if (constructorFunc) {\r\n return constructorFunc;\r\n }\r\n // Default to no light for none present once.\r\n return null;\r\n };\r\n /**\r\n * Parses the passed \"parsedLight\" and returns a new instanced Light from this parsing.\r\n * @param parsedLight The JSON representation of the light\r\n * @param scene The scene to create the parsed light in\r\n * @returns the created light after parsing\r\n */\r\n Light.Parse = function (parsedLight, scene) {\r\n var constructor = Light.GetConstructorFromName(parsedLight.type, parsedLight.name, scene);\r\n if (!constructor) {\r\n return null;\r\n }\r\n var light = SerializationHelper.Parse(constructor, parsedLight, scene);\r\n // Inclusion / exclusions\r\n if (parsedLight.excludedMeshesIds) {\r\n light._excludedMeshesIds = parsedLight.excludedMeshesIds;\r\n }\r\n if (parsedLight.includedOnlyMeshesIds) {\r\n light._includedOnlyMeshesIds = parsedLight.includedOnlyMeshesIds;\r\n }\r\n // Parent\r\n if (parsedLight.parentId) {\r\n light._waitingParentId = parsedLight.parentId;\r\n }\r\n // Falloff\r\n if (parsedLight.falloffType !== undefined) {\r\n light.falloffType = parsedLight.falloffType;\r\n }\r\n // Lightmaps\r\n if (parsedLight.lightmapMode !== undefined) {\r\n light.lightmapMode = parsedLight.lightmapMode;\r\n }\r\n // Animations\r\n if (parsedLight.animations) {\r\n for (var animationIndex = 0; animationIndex < parsedLight.animations.length; animationIndex++) {\r\n var parsedAnimation = parsedLight.animations[animationIndex];\r\n var internalClass = _TypeStore.GetClass(\"BABYLON.Animation\");\r\n if (internalClass) {\r\n light.animations.push(internalClass.Parse(parsedAnimation));\r\n }\r\n }\r\n Node.ParseAnimationRanges(light, parsedLight, scene);\r\n }\r\n if (parsedLight.autoAnimate) {\r\n scene.beginAnimation(light, parsedLight.autoAnimateFrom, parsedLight.autoAnimateTo, parsedLight.autoAnimateLoop, parsedLight.autoAnimateSpeed || 1.0);\r\n }\r\n return light;\r\n };\r\n Light.prototype._hookArrayForExcluded = function (array) {\r\n var _this = this;\r\n var oldPush = array.push;\r\n array.push = function () {\r\n var items = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n items[_i] = arguments[_i];\r\n }\r\n var result = oldPush.apply(array, items);\r\n for (var _a = 0, items_1 = items; _a < items_1.length; _a++) {\r\n var item = items_1[_a];\r\n item._resyncLightSource(_this);\r\n }\r\n return result;\r\n };\r\n var oldSplice = array.splice;\r\n array.splice = function (index, deleteCount) {\r\n var deleted = oldSplice.apply(array, [index, deleteCount]);\r\n for (var _i = 0, deleted_1 = deleted; _i < deleted_1.length; _i++) {\r\n var item = deleted_1[_i];\r\n item._resyncLightSource(_this);\r\n }\r\n return deleted;\r\n };\r\n for (var _i = 0, array_1 = array; _i < array_1.length; _i++) {\r\n var item = array_1[_i];\r\n item._resyncLightSource(this);\r\n }\r\n };\r\n Light.prototype._hookArrayForIncludedOnly = function (array) {\r\n var _this = this;\r\n var oldPush = array.push;\r\n array.push = function () {\r\n var items = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n items[_i] = arguments[_i];\r\n }\r\n var result = oldPush.apply(array, items);\r\n _this._resyncMeshes();\r\n return result;\r\n };\r\n var oldSplice = array.splice;\r\n array.splice = function (index, deleteCount) {\r\n var deleted = oldSplice.apply(array, [index, deleteCount]);\r\n _this._resyncMeshes();\r\n return deleted;\r\n };\r\n this._resyncMeshes();\r\n };\r\n Light.prototype._resyncMeshes = function () {\r\n for (var _i = 0, _a = this.getScene().meshes; _i < _a.length; _i++) {\r\n var mesh = _a[_i];\r\n mesh._resyncLightSource(this);\r\n }\r\n };\r\n /**\r\n * Forces the meshes to update their light related information in their rendering used effects\r\n * @hidden Internal Use Only\r\n */\r\n Light.prototype._markMeshesAsLightDirty = function () {\r\n for (var _i = 0, _a = this.getScene().meshes; _i < _a.length; _i++) {\r\n var mesh = _a[_i];\r\n if (mesh.lightSources.indexOf(this) !== -1) {\r\n mesh._markSubMeshesAsLightDirty();\r\n }\r\n }\r\n };\r\n /**\r\n * Recomputes the cached photometric scale if needed.\r\n */\r\n Light.prototype._computePhotometricScale = function () {\r\n this._photometricScale = this._getPhotometricScale();\r\n this.getScene().resetCachedMaterial();\r\n };\r\n /**\r\n * Returns the Photometric Scale according to the light type and intensity mode.\r\n */\r\n Light.prototype._getPhotometricScale = function () {\r\n var photometricScale = 0.0;\r\n var lightTypeID = this.getTypeID();\r\n //get photometric mode\r\n var photometricMode = this.intensityMode;\r\n if (photometricMode === Light.INTENSITYMODE_AUTOMATIC) {\r\n if (lightTypeID === Light.LIGHTTYPEID_DIRECTIONALLIGHT) {\r\n photometricMode = Light.INTENSITYMODE_ILLUMINANCE;\r\n }\r\n else {\r\n photometricMode = Light.INTENSITYMODE_LUMINOUSINTENSITY;\r\n }\r\n }\r\n //compute photometric scale\r\n switch (lightTypeID) {\r\n case Light.LIGHTTYPEID_POINTLIGHT:\r\n case Light.LIGHTTYPEID_SPOTLIGHT:\r\n switch (photometricMode) {\r\n case Light.INTENSITYMODE_LUMINOUSPOWER:\r\n photometricScale = 1.0 / (4.0 * Math.PI);\r\n break;\r\n case Light.INTENSITYMODE_LUMINOUSINTENSITY:\r\n photometricScale = 1.0;\r\n break;\r\n case Light.INTENSITYMODE_LUMINANCE:\r\n photometricScale = this.radius * this.radius;\r\n break;\r\n }\r\n break;\r\n case Light.LIGHTTYPEID_DIRECTIONALLIGHT:\r\n switch (photometricMode) {\r\n case Light.INTENSITYMODE_ILLUMINANCE:\r\n photometricScale = 1.0;\r\n break;\r\n case Light.INTENSITYMODE_LUMINANCE:\r\n // When radius (and therefore solid angle) is non-zero a directional lights brightness can be specified via central (peak) luminance.\r\n // For a directional light the 'radius' defines the angular radius (in radians) rather than world-space radius (e.g. in metres).\r\n var apexAngleRadians = this.radius;\r\n // Impose a minimum light angular size to avoid the light becoming an infinitely small angular light source (i.e. a dirac delta function).\r\n apexAngleRadians = Math.max(apexAngleRadians, 0.001);\r\n var solidAngle = 2.0 * Math.PI * (1.0 - Math.cos(apexAngleRadians));\r\n photometricScale = solidAngle;\r\n break;\r\n }\r\n break;\r\n case Light.LIGHTTYPEID_HEMISPHERICLIGHT:\r\n // No fall off in hemisperic light.\r\n photometricScale = 1.0;\r\n break;\r\n }\r\n return photometricScale;\r\n };\r\n /**\r\n * Reorder the light in the scene according to their defined priority.\r\n * @hidden Internal Use Only\r\n */\r\n Light.prototype._reorderLightsInScene = function () {\r\n var scene = this.getScene();\r\n if (this._renderPriority != 0) {\r\n scene.requireLightSorting = true;\r\n }\r\n this.getScene().sortLightsByPriority();\r\n };\r\n /**\r\n * Falloff Default: light is falling off following the material specification:\r\n * standard material is using standard falloff whereas pbr material can request special falloff per materials.\r\n */\r\n Light.FALLOFF_DEFAULT = 0;\r\n /**\r\n * Falloff Physical: light is falling off following the inverse squared distance law.\r\n */\r\n Light.FALLOFF_PHYSICAL = 1;\r\n /**\r\n * Falloff gltf: light is falling off as described in the gltf moving to PBR document\r\n * to enhance interoperability with other engines.\r\n */\r\n Light.FALLOFF_GLTF = 2;\r\n /**\r\n * Falloff Standard: light is falling off like in the standard material\r\n * to enhance interoperability with other materials.\r\n */\r\n Light.FALLOFF_STANDARD = 3;\r\n //lightmapMode Consts\r\n /**\r\n * If every light affecting the material is in this lightmapMode,\r\n * material.lightmapTexture adds or multiplies\r\n * (depends on material.useLightmapAsShadowmap)\r\n * after every other light calculations.\r\n */\r\n Light.LIGHTMAP_DEFAULT = 0;\r\n /**\r\n * material.lightmapTexture as only diffuse lighting from this light\r\n * adds only specular lighting from this light\r\n * adds dynamic shadows\r\n */\r\n Light.LIGHTMAP_SPECULAR = 1;\r\n /**\r\n * material.lightmapTexture as only lighting\r\n * no light calculation from this light\r\n * only adds dynamic shadows from this light\r\n */\r\n Light.LIGHTMAP_SHADOWSONLY = 2;\r\n // Intensity Mode Consts\r\n /**\r\n * Each light type uses the default quantity according to its type:\r\n * point/spot lights use luminous intensity\r\n * directional lights use illuminance\r\n */\r\n Light.INTENSITYMODE_AUTOMATIC = 0;\r\n /**\r\n * lumen (lm)\r\n */\r\n Light.INTENSITYMODE_LUMINOUSPOWER = 1;\r\n /**\r\n * candela (lm/sr)\r\n */\r\n Light.INTENSITYMODE_LUMINOUSINTENSITY = 2;\r\n /**\r\n * lux (lm/m^2)\r\n */\r\n Light.INTENSITYMODE_ILLUMINANCE = 3;\r\n /**\r\n * nit (cd/m^2)\r\n */\r\n Light.INTENSITYMODE_LUMINANCE = 4;\r\n // Light types ids const.\r\n /**\r\n * Light type const id of the point light.\r\n */\r\n Light.LIGHTTYPEID_POINTLIGHT = 0;\r\n /**\r\n * Light type const id of the directional light.\r\n */\r\n Light.LIGHTTYPEID_DIRECTIONALLIGHT = 1;\r\n /**\r\n * Light type const id of the spot light.\r\n */\r\n Light.LIGHTTYPEID_SPOTLIGHT = 2;\r\n /**\r\n * Light type const id of the hemispheric light.\r\n */\r\n Light.LIGHTTYPEID_HEMISPHERICLIGHT = 3;\r\n __decorate([\r\n serializeAsColor3()\r\n ], Light.prototype, \"diffuse\", void 0);\r\n __decorate([\r\n serializeAsColor3()\r\n ], Light.prototype, \"specular\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Light.prototype, \"falloffType\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Light.prototype, \"intensity\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Light.prototype, \"range\", null);\r\n __decorate([\r\n serialize()\r\n ], Light.prototype, \"intensityMode\", null);\r\n __decorate([\r\n serialize()\r\n ], Light.prototype, \"radius\", null);\r\n __decorate([\r\n serialize()\r\n ], Light.prototype, \"_renderPriority\", void 0);\r\n __decorate([\r\n expandToProperty(\"_reorderLightsInScene\")\r\n ], Light.prototype, \"renderPriority\", void 0);\r\n __decorate([\r\n serialize(\"shadowEnabled\")\r\n ], Light.prototype, \"_shadowEnabled\", void 0);\r\n __decorate([\r\n serialize(\"excludeWithLayerMask\")\r\n ], Light.prototype, \"_excludeWithLayerMask\", void 0);\r\n __decorate([\r\n serialize(\"includeOnlyWithLayerMask\")\r\n ], Light.prototype, \"_includeOnlyWithLayerMask\", void 0);\r\n __decorate([\r\n serialize(\"lightmapMode\")\r\n ], Light.prototype, \"_lightmapMode\", void 0);\r\n return Light;\r\n}(Node));\r\nexport { Light };\r\n//# sourceMappingURL=light.js.map","import { __extends } from \"tslib\";\r\n/**\r\n * Gather the list of keyboard event types as constants.\r\n */\r\nvar KeyboardEventTypes = /** @class */ (function () {\r\n function KeyboardEventTypes() {\r\n }\r\n /**\r\n * The keydown event is fired when a key becomes active (pressed).\r\n */\r\n KeyboardEventTypes.KEYDOWN = 0x01;\r\n /**\r\n * The keyup event is fired when a key has been released.\r\n */\r\n KeyboardEventTypes.KEYUP = 0x02;\r\n return KeyboardEventTypes;\r\n}());\r\nexport { KeyboardEventTypes };\r\n/**\r\n * This class is used to store keyboard related info for the onKeyboardObservable event.\r\n */\r\nvar KeyboardInfo = /** @class */ (function () {\r\n /**\r\n * Instantiates a new keyboard info.\r\n * This class is used to store keyboard related info for the onKeyboardObservable event.\r\n * @param type Defines the type of event (KeyboardEventTypes)\r\n * @param event Defines the related dom event\r\n */\r\n function KeyboardInfo(\r\n /**\r\n * Defines the type of event (KeyboardEventTypes)\r\n */\r\n type, \r\n /**\r\n * Defines the related dom event\r\n */\r\n event) {\r\n this.type = type;\r\n this.event = event;\r\n }\r\n return KeyboardInfo;\r\n}());\r\nexport { KeyboardInfo };\r\n/**\r\n * This class is used to store keyboard related info for the onPreKeyboardObservable event.\r\n * Set the skipOnKeyboardObservable property to true if you want the engine to stop any process after this event is triggered, even not calling onKeyboardObservable\r\n */\r\nvar KeyboardInfoPre = /** @class */ (function (_super) {\r\n __extends(KeyboardInfoPre, _super);\r\n /**\r\n * Instantiates a new keyboard pre info.\r\n * This class is used to store keyboard related info for the onPreKeyboardObservable event.\r\n * @param type Defines the type of event (KeyboardEventTypes)\r\n * @param event Defines the related dom event\r\n */\r\n function KeyboardInfoPre(\r\n /**\r\n * Defines the type of event (KeyboardEventTypes)\r\n */\r\n type, \r\n /**\r\n * Defines the related dom event\r\n */\r\n event) {\r\n var _this = _super.call(this, type, event) || this;\r\n _this.type = type;\r\n _this.event = event;\r\n _this.skipOnPointerObservable = false;\r\n return _this;\r\n }\r\n return KeyboardInfoPre;\r\n}(KeyboardInfo));\r\nexport { KeyboardInfoPre };\r\n//# sourceMappingURL=keyboardEvents.js.map","/**\r\n * Gather the list of clipboard event types as constants.\r\n */\r\nvar ClipboardEventTypes = /** @class */ (function () {\r\n function ClipboardEventTypes() {\r\n }\r\n /**\r\n * The clipboard event is fired when a copy command is active (pressed).\r\n */\r\n ClipboardEventTypes.COPY = 0x01; //\r\n /**\r\n * The clipboard event is fired when a cut command is active (pressed).\r\n */\r\n ClipboardEventTypes.CUT = 0x02;\r\n /**\r\n * The clipboard event is fired when a paste command is active (pressed).\r\n */\r\n ClipboardEventTypes.PASTE = 0x03;\r\n return ClipboardEventTypes;\r\n}());\r\nexport { ClipboardEventTypes };\r\n/**\r\n * This class is used to store clipboard related info for the onClipboardObservable event.\r\n */\r\nvar ClipboardInfo = /** @class */ (function () {\r\n /**\r\n *Creates an instance of ClipboardInfo.\r\n * @param type Defines the type of event (BABYLON.ClipboardEventTypes)\r\n * @param event Defines the related dom event\r\n */\r\n function ClipboardInfo(\r\n /**\r\n * Defines the type of event (BABYLON.ClipboardEventTypes)\r\n */\r\n type, \r\n /**\r\n * Defines the related dom event\r\n */\r\n event) {\r\n this.type = type;\r\n this.event = event;\r\n }\r\n /**\r\n * Get the clipboard event's type from the keycode.\r\n * @param keyCode Defines the keyCode for the current keyboard event.\r\n * @return {number}\r\n */\r\n ClipboardInfo.GetTypeFromCharacter = function (keyCode) {\r\n var charCode = keyCode;\r\n //TODO: add codes for extended ASCII\r\n switch (charCode) {\r\n case 67: return ClipboardEventTypes.COPY;\r\n case 86: return ClipboardEventTypes.PASTE;\r\n case 88: return ClipboardEventTypes.CUT;\r\n default: return -1;\r\n }\r\n };\r\n return ClipboardInfo;\r\n}());\r\nexport { ClipboardInfo };\r\n//# sourceMappingURL=clipboardEvents.js.map","/**\r\n * Size containing widht and height\r\n */\r\nvar Size = /** @class */ (function () {\r\n /**\r\n * Creates a Size object from the given width and height (floats).\r\n * @param width width of the new size\r\n * @param height height of the new size\r\n */\r\n function Size(width, height) {\r\n this.width = width;\r\n this.height = height;\r\n }\r\n /**\r\n * Returns a string with the Size width and height\r\n * @returns a string with the Size width and height\r\n */\r\n Size.prototype.toString = function () {\r\n return \"{W: \" + this.width + \", H: \" + this.height + \"}\";\r\n };\r\n /**\r\n * \"Size\"\r\n * @returns the string \"Size\"\r\n */\r\n Size.prototype.getClassName = function () {\r\n return \"Size\";\r\n };\r\n /**\r\n * Returns the Size hash code.\r\n * @returns a hash code for a unique width and height\r\n */\r\n Size.prototype.getHashCode = function () {\r\n var hash = this.width | 0;\r\n hash = (hash * 397) ^ (this.height | 0);\r\n return hash;\r\n };\r\n /**\r\n * Updates the current size from the given one.\r\n * @param src the given size\r\n */\r\n Size.prototype.copyFrom = function (src) {\r\n this.width = src.width;\r\n this.height = src.height;\r\n };\r\n /**\r\n * Updates in place the current Size from the given floats.\r\n * @param width width of the new size\r\n * @param height height of the new size\r\n * @returns the updated Size.\r\n */\r\n Size.prototype.copyFromFloats = function (width, height) {\r\n this.width = width;\r\n this.height = height;\r\n return this;\r\n };\r\n /**\r\n * Updates in place the current Size from the given floats.\r\n * @param width width to set\r\n * @param height height to set\r\n * @returns the updated Size.\r\n */\r\n Size.prototype.set = function (width, height) {\r\n return this.copyFromFloats(width, height);\r\n };\r\n /**\r\n * Multiplies the width and height by numbers\r\n * @param w factor to multiple the width by\r\n * @param h factor to multiple the height by\r\n * @returns a new Size set with the multiplication result of the current Size and the given floats.\r\n */\r\n Size.prototype.multiplyByFloats = function (w, h) {\r\n return new Size(this.width * w, this.height * h);\r\n };\r\n /**\r\n * Clones the size\r\n * @returns a new Size copied from the given one.\r\n */\r\n Size.prototype.clone = function () {\r\n return new Size(this.width, this.height);\r\n };\r\n /**\r\n * True if the current Size and the given one width and height are strictly equal.\r\n * @param other the other size to compare against\r\n * @returns True if the current Size and the given one width and height are strictly equal.\r\n */\r\n Size.prototype.equals = function (other) {\r\n if (!other) {\r\n return false;\r\n }\r\n return (this.width === other.width) && (this.height === other.height);\r\n };\r\n Object.defineProperty(Size.prototype, \"surface\", {\r\n /**\r\n * The surface of the Size : width * height (float).\r\n */\r\n get: function () {\r\n return this.width * this.height;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Create a new size of zero\r\n * @returns a new Size set to (0.0, 0.0)\r\n */\r\n Size.Zero = function () {\r\n return new Size(0.0, 0.0);\r\n };\r\n /**\r\n * Sums the width and height of two sizes\r\n * @param otherSize size to add to this size\r\n * @returns a new Size set as the addition result of the current Size and the given one.\r\n */\r\n Size.prototype.add = function (otherSize) {\r\n var r = new Size(this.width + otherSize.width, this.height + otherSize.height);\r\n return r;\r\n };\r\n /**\r\n * Subtracts the width and height of two\r\n * @param otherSize size to subtract to this size\r\n * @returns a new Size set as the subtraction result of the given one from the current Size.\r\n */\r\n Size.prototype.subtract = function (otherSize) {\r\n var r = new Size(this.width - otherSize.width, this.height - otherSize.height);\r\n return r;\r\n };\r\n /**\r\n * Creates a new Size set at the linear interpolation \"amount\" between \"start\" and \"end\"\r\n * @param start starting size to lerp between\r\n * @param end end size to lerp between\r\n * @param amount amount to lerp between the start and end values\r\n * @returns a new Size set at the linear interpolation \"amount\" between \"start\" and \"end\"\r\n */\r\n Size.Lerp = function (start, end, amount) {\r\n var w = start.width + ((end.width - start.width) * amount);\r\n var h = start.height + ((end.height - start.height) * amount);\r\n return new Size(w, h);\r\n };\r\n return Size;\r\n}());\r\nexport { Size };\r\n//# sourceMappingURL=math.size.js.map","import { Vector3, Vector2, TmpVectors } from \"../Maths/math.vector\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\n/**\r\n * Information about the result of picking within a scene\r\n * @see https://doc.babylonjs.com/babylon101/picking_collisions\r\n */\r\nvar PickingInfo = /** @class */ (function () {\r\n function PickingInfo() {\r\n /** @hidden */\r\n this._pickingUnavailable = false;\r\n /**\r\n * If the pick collided with an object\r\n */\r\n this.hit = false;\r\n /**\r\n * Distance away where the pick collided\r\n */\r\n this.distance = 0;\r\n /**\r\n * The location of pick collision\r\n */\r\n this.pickedPoint = null;\r\n /**\r\n * The mesh corresponding the the pick collision\r\n */\r\n this.pickedMesh = null;\r\n /** (See getTextureCoordinates) The barycentric U coordinate that is used when calculating the texture coordinates of the collision.*/\r\n this.bu = 0;\r\n /** (See getTextureCoordinates) The barycentric V coordinate that is used when calculating the texture coordinates of the collision.*/\r\n this.bv = 0;\r\n /** The index of the face on the mesh that was picked, or the index of the Line if the picked Mesh is a LinesMesh */\r\n this.faceId = -1;\r\n /** Id of the the submesh that was picked */\r\n this.subMeshId = 0;\r\n /** If a sprite was picked, this will be the sprite the pick collided with */\r\n this.pickedSprite = null;\r\n /**\r\n * If a mesh was used to do the picking (eg. 6dof controller) this will be populated.\r\n */\r\n this.originMesh = null;\r\n /**\r\n * The ray that was used to perform the picking.\r\n */\r\n this.ray = null;\r\n }\r\n /**\r\n * Gets the normal correspodning to the face the pick collided with\r\n * @param useWorldCoordinates If the resulting normal should be relative to the world (default: false)\r\n * @param useVerticesNormals If the vertices normals should be used to calculate the normal instead of the normal map\r\n * @returns The normal correspodning to the face the pick collided with\r\n */\r\n PickingInfo.prototype.getNormal = function (useWorldCoordinates, useVerticesNormals) {\r\n if (useWorldCoordinates === void 0) { useWorldCoordinates = false; }\r\n if (useVerticesNormals === void 0) { useVerticesNormals = true; }\r\n if (!this.pickedMesh || !this.pickedMesh.isVerticesDataPresent(VertexBuffer.NormalKind)) {\r\n return null;\r\n }\r\n var indices = this.pickedMesh.getIndices();\r\n if (!indices) {\r\n return null;\r\n }\r\n var result;\r\n if (useVerticesNormals) {\r\n var normals = this.pickedMesh.getVerticesData(VertexBuffer.NormalKind);\r\n var normal0 = Vector3.FromArray(normals, indices[this.faceId * 3] * 3);\r\n var normal1 = Vector3.FromArray(normals, indices[this.faceId * 3 + 1] * 3);\r\n var normal2 = Vector3.FromArray(normals, indices[this.faceId * 3 + 2] * 3);\r\n normal0 = normal0.scale(this.bu);\r\n normal1 = normal1.scale(this.bv);\r\n normal2 = normal2.scale(1.0 - this.bu - this.bv);\r\n result = new Vector3(normal0.x + normal1.x + normal2.x, normal0.y + normal1.y + normal2.y, normal0.z + normal1.z + normal2.z);\r\n }\r\n else {\r\n var positions = this.pickedMesh.getVerticesData(VertexBuffer.PositionKind);\r\n var vertex1 = Vector3.FromArray(positions, indices[this.faceId * 3] * 3);\r\n var vertex2 = Vector3.FromArray(positions, indices[this.faceId * 3 + 1] * 3);\r\n var vertex3 = Vector3.FromArray(positions, indices[this.faceId * 3 + 2] * 3);\r\n var p1p2 = vertex1.subtract(vertex2);\r\n var p3p2 = vertex3.subtract(vertex2);\r\n result = Vector3.Cross(p1p2, p3p2);\r\n }\r\n if (useWorldCoordinates) {\r\n var wm = this.pickedMesh.getWorldMatrix();\r\n if (this.pickedMesh.nonUniformScaling) {\r\n TmpVectors.Matrix[0].copyFrom(wm);\r\n wm = TmpVectors.Matrix[0];\r\n wm.setTranslationFromFloats(0, 0, 0);\r\n wm.invert();\r\n wm.transposeToRef(TmpVectors.Matrix[1]);\r\n wm = TmpVectors.Matrix[1];\r\n }\r\n result = Vector3.TransformNormal(result, wm);\r\n }\r\n result.normalize();\r\n return result;\r\n };\r\n /**\r\n * Gets the texture coordinates of where the pick occured\r\n * @returns the vector containing the coordnates of the texture\r\n */\r\n PickingInfo.prototype.getTextureCoordinates = function () {\r\n if (!this.pickedMesh || !this.pickedMesh.isVerticesDataPresent(VertexBuffer.UVKind)) {\r\n return null;\r\n }\r\n var indices = this.pickedMesh.getIndices();\r\n if (!indices) {\r\n return null;\r\n }\r\n var uvs = this.pickedMesh.getVerticesData(VertexBuffer.UVKind);\r\n if (!uvs) {\r\n return null;\r\n }\r\n var uv0 = Vector2.FromArray(uvs, indices[this.faceId * 3] * 2);\r\n var uv1 = Vector2.FromArray(uvs, indices[this.faceId * 3 + 1] * 2);\r\n var uv2 = Vector2.FromArray(uvs, indices[this.faceId * 3 + 2] * 2);\r\n uv0 = uv0.scale(this.bu);\r\n uv1 = uv1.scale(this.bv);\r\n uv2 = uv2.scale(1.0 - this.bu - this.bv);\r\n return new Vector2(uv0.x + uv1.x + uv2.x, uv0.y + uv1.y + uv2.y);\r\n };\r\n return PickingInfo;\r\n}());\r\nexport { PickingInfo };\r\n//# sourceMappingURL=pickingInfo.js.map","import { __extends } from \"tslib\";\r\nimport { Matrix } from \"../Maths/math.vector\";\r\nimport { Material } from \"../Materials/material\";\r\n/**\r\n * Base class of materials working in push mode in babylon JS\r\n * @hidden\r\n */\r\nvar PushMaterial = /** @class */ (function (_super) {\r\n __extends(PushMaterial, _super);\r\n function PushMaterial(name, scene) {\r\n var _this = _super.call(this, name, scene) || this;\r\n _this._normalMatrix = new Matrix();\r\n /**\r\n * Gets or sets a boolean indicating that the material is allowed to do shader hot swapping.\r\n * This means that the material can keep using a previous shader while a new one is being compiled.\r\n * This is mostly used when shader parallel compilation is supported (true by default)\r\n */\r\n _this.allowShaderHotSwapping = true;\r\n _this._storeEffectOnSubMeshes = true;\r\n return _this;\r\n }\r\n PushMaterial.prototype.getEffect = function () {\r\n return this._activeEffect;\r\n };\r\n PushMaterial.prototype.isReady = function (mesh, useInstances) {\r\n if (!mesh) {\r\n return false;\r\n }\r\n if (!mesh.subMeshes || mesh.subMeshes.length === 0) {\r\n return true;\r\n }\r\n return this.isReadyForSubMesh(mesh, mesh.subMeshes[0], useInstances);\r\n };\r\n /**\r\n * Binds the given world matrix to the active effect\r\n *\r\n * @param world the matrix to bind\r\n */\r\n PushMaterial.prototype.bindOnlyWorldMatrix = function (world) {\r\n this._activeEffect.setMatrix(\"world\", world);\r\n };\r\n /**\r\n * Binds the given normal matrix to the active effect\r\n *\r\n * @param normalMatrix the matrix to bind\r\n */\r\n PushMaterial.prototype.bindOnlyNormalMatrix = function (normalMatrix) {\r\n this._activeEffect.setMatrix(\"normalMatrix\", normalMatrix);\r\n };\r\n PushMaterial.prototype.bind = function (world, mesh) {\r\n if (!mesh) {\r\n return;\r\n }\r\n this.bindForSubMesh(world, mesh, mesh.subMeshes[0]);\r\n };\r\n PushMaterial.prototype._afterBind = function (mesh, effect) {\r\n if (effect === void 0) { effect = null; }\r\n _super.prototype._afterBind.call(this, mesh);\r\n this.getScene()._cachedEffect = effect;\r\n };\r\n PushMaterial.prototype._mustRebind = function (scene, effect, visibility) {\r\n if (visibility === void 0) { visibility = 1; }\r\n return scene.isCachedMaterialInvalid(this, effect, visibility);\r\n };\r\n return PushMaterial;\r\n}(Material));\r\nexport { PushMaterial };\r\n//# sourceMappingURL=pushMaterial.js.map","import { Engine } from \"../Engines/engine\";\r\n/**\r\n * This groups all the flags used to control the materials channel.\r\n */\r\nvar MaterialFlags = /** @class */ (function () {\r\n function MaterialFlags() {\r\n }\r\n Object.defineProperty(MaterialFlags, \"DiffuseTextureEnabled\", {\r\n /**\r\n * Are diffuse textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._DiffuseTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._DiffuseTextureEnabled === value) {\r\n return;\r\n }\r\n this._DiffuseTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"AmbientTextureEnabled\", {\r\n /**\r\n * Are ambient textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._AmbientTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._AmbientTextureEnabled === value) {\r\n return;\r\n }\r\n this._AmbientTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"OpacityTextureEnabled\", {\r\n /**\r\n * Are opacity textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._OpacityTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._OpacityTextureEnabled === value) {\r\n return;\r\n }\r\n this._OpacityTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"ReflectionTextureEnabled\", {\r\n /**\r\n * Are reflection textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._ReflectionTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._ReflectionTextureEnabled === value) {\r\n return;\r\n }\r\n this._ReflectionTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"EmissiveTextureEnabled\", {\r\n /**\r\n * Are emissive textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._EmissiveTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._EmissiveTextureEnabled === value) {\r\n return;\r\n }\r\n this._EmissiveTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"SpecularTextureEnabled\", {\r\n /**\r\n * Are specular textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._SpecularTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._SpecularTextureEnabled === value) {\r\n return;\r\n }\r\n this._SpecularTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"BumpTextureEnabled\", {\r\n /**\r\n * Are bump textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._BumpTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._BumpTextureEnabled === value) {\r\n return;\r\n }\r\n this._BumpTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"LightmapTextureEnabled\", {\r\n /**\r\n * Are lightmap textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._LightmapTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._LightmapTextureEnabled === value) {\r\n return;\r\n }\r\n this._LightmapTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"RefractionTextureEnabled\", {\r\n /**\r\n * Are refraction textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._RefractionTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._RefractionTextureEnabled === value) {\r\n return;\r\n }\r\n this._RefractionTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"ColorGradingTextureEnabled\", {\r\n /**\r\n * Are color grading textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._ColorGradingTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._ColorGradingTextureEnabled === value) {\r\n return;\r\n }\r\n this._ColorGradingTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"FresnelEnabled\", {\r\n /**\r\n * Are fresnels enabled in the application.\r\n */\r\n get: function () {\r\n return this._FresnelEnabled;\r\n },\r\n set: function (value) {\r\n if (this._FresnelEnabled === value) {\r\n return;\r\n }\r\n this._FresnelEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(4);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"ClearCoatTextureEnabled\", {\r\n /**\r\n * Are clear coat textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._ClearCoatTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._ClearCoatTextureEnabled === value) {\r\n return;\r\n }\r\n this._ClearCoatTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"ClearCoatBumpTextureEnabled\", {\r\n /**\r\n * Are clear coat bump textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._ClearCoatBumpTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._ClearCoatBumpTextureEnabled === value) {\r\n return;\r\n }\r\n this._ClearCoatBumpTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"ClearCoatTintTextureEnabled\", {\r\n /**\r\n * Are clear coat tint textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._ClearCoatTintTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._ClearCoatTintTextureEnabled === value) {\r\n return;\r\n }\r\n this._ClearCoatTintTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"SheenTextureEnabled\", {\r\n /**\r\n * Are sheen textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._SheenTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._SheenTextureEnabled === value) {\r\n return;\r\n }\r\n this._SheenTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"AnisotropicTextureEnabled\", {\r\n /**\r\n * Are anisotropic textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._AnisotropicTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._AnisotropicTextureEnabled === value) {\r\n return;\r\n }\r\n this._AnisotropicTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"ThicknessTextureEnabled\", {\r\n /**\r\n * Are thickness textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._ThicknessTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._ThicknessTextureEnabled === value) {\r\n return;\r\n }\r\n this._ThicknessTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n // Flags used to enable or disable a type of texture for all Standard Materials\r\n MaterialFlags._DiffuseTextureEnabled = true;\r\n MaterialFlags._AmbientTextureEnabled = true;\r\n MaterialFlags._OpacityTextureEnabled = true;\r\n MaterialFlags._ReflectionTextureEnabled = true;\r\n MaterialFlags._EmissiveTextureEnabled = true;\r\n MaterialFlags._SpecularTextureEnabled = true;\r\n MaterialFlags._BumpTextureEnabled = true;\r\n MaterialFlags._LightmapTextureEnabled = true;\r\n MaterialFlags._RefractionTextureEnabled = true;\r\n MaterialFlags._ColorGradingTextureEnabled = true;\r\n MaterialFlags._FresnelEnabled = true;\r\n MaterialFlags._ClearCoatTextureEnabled = true;\r\n MaterialFlags._ClearCoatBumpTextureEnabled = true;\r\n MaterialFlags._ClearCoatTintTextureEnabled = true;\r\n MaterialFlags._SheenTextureEnabled = true;\r\n MaterialFlags._AnisotropicTextureEnabled = true;\r\n MaterialFlags._ThicknessTextureEnabled = true;\r\n return MaterialFlags;\r\n}());\r\nexport { MaterialFlags };\r\n//# sourceMappingURL=materialFlags.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'defaultFragmentDeclaration';\r\nvar shader = \"uniform vec4 vDiffuseColor;\\n#ifdef SPECULARTERM\\nuniform vec4 vSpecularColor;\\n#endif\\nuniform vec3 vEmissiveColor;\\nuniform float visibility;\\n\\n#ifdef DIFFUSE\\nuniform vec2 vDiffuseInfos;\\n#endif\\n#ifdef AMBIENT\\nuniform vec2 vAmbientInfos;\\n#endif\\n#ifdef OPACITY\\nuniform vec2 vOpacityInfos;\\n#endif\\n#ifdef EMISSIVE\\nuniform vec2 vEmissiveInfos;\\n#endif\\n#ifdef LIGHTMAP\\nuniform vec2 vLightmapInfos;\\n#endif\\n#ifdef BUMP\\nuniform vec3 vBumpInfos;\\nuniform vec2 vTangentSpaceParams;\\n#endif\\n#if defined(REFLECTIONMAP_SPHERICAL) || defined(REFLECTIONMAP_PROJECTION) || defined(REFRACTION)\\nuniform mat4 view;\\n#endif\\n#ifdef REFRACTION\\nuniform vec4 vRefractionInfos;\\n#ifndef REFRACTIONMAP_3D\\nuniform mat4 refractionMatrix;\\n#endif\\n#ifdef REFRACTIONFRESNEL\\nuniform vec4 refractionLeftColor;\\nuniform vec4 refractionRightColor;\\n#endif\\n#endif\\n#if defined(SPECULAR) && defined(SPECULARTERM)\\nuniform vec2 vSpecularInfos;\\n#endif\\n#ifdef DIFFUSEFRESNEL\\nuniform vec4 diffuseLeftColor;\\nuniform vec4 diffuseRightColor;\\n#endif\\n#ifdef OPACITYFRESNEL\\nuniform vec4 opacityParts;\\n#endif\\n#ifdef EMISSIVEFRESNEL\\nuniform vec4 emissiveLeftColor;\\nuniform vec4 emissiveRightColor;\\n#endif\\n\\n#ifdef REFLECTION\\nuniform vec2 vReflectionInfos;\\n#if defined(REFLECTIONMAP_PLANAR) || defined(REFLECTIONMAP_CUBIC) || defined(REFLECTIONMAP_PROJECTION) || defined(REFLECTIONMAP_EQUIRECTANGULAR) || defined(REFLECTIONMAP_SPHERICAL) || defined(REFLECTIONMAP_SKYBOX)\\nuniform mat4 reflectionMatrix;\\n#endif\\n#ifndef REFLECTIONMAP_SKYBOX\\n#if defined(USE_LOCAL_REFLECTIONMAP_CUBIC) && defined(REFLECTIONMAP_CUBIC)\\nuniform vec3 vReflectionPosition;\\nuniform vec3 vReflectionSize;\\n#endif\\n#endif\\n#ifdef REFLECTIONFRESNEL\\nuniform vec4 reflectionLeftColor;\\nuniform vec4 reflectionRightColor;\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var defaultFragmentDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=defaultFragmentDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'defaultUboDeclaration';\r\nvar shader = \"layout(std140,column_major) uniform;\\nuniform Material\\n{\\nvec4 diffuseLeftColor;\\nvec4 diffuseRightColor;\\nvec4 opacityParts;\\nvec4 reflectionLeftColor;\\nvec4 reflectionRightColor;\\nvec4 refractionLeftColor;\\nvec4 refractionRightColor;\\nvec4 emissiveLeftColor;\\nvec4 emissiveRightColor;\\nvec2 vDiffuseInfos;\\nvec2 vAmbientInfos;\\nvec2 vOpacityInfos;\\nvec2 vReflectionInfos;\\nvec3 vReflectionPosition;\\nvec3 vReflectionSize;\\nvec2 vEmissiveInfos;\\nvec2 vLightmapInfos;\\nvec2 vSpecularInfos;\\nvec3 vBumpInfos;\\nmat4 diffuseMatrix;\\nmat4 ambientMatrix;\\nmat4 opacityMatrix;\\nmat4 reflectionMatrix;\\nmat4 emissiveMatrix;\\nmat4 lightmapMatrix;\\nmat4 specularMatrix;\\nmat4 bumpMatrix;\\nvec2 vTangentSpaceParams;\\nfloat pointSize;\\nmat4 refractionMatrix;\\nvec4 vRefractionInfos;\\nvec4 vSpecularColor;\\nvec3 vEmissiveColor;\\nfloat visibility;\\nvec4 vDiffuseColor;\\n};\\nuniform Scene {\\nmat4 viewProjection;\\n#ifdef MULTIVIEW\\nmat4 viewProjectionR;\\n#endif\\nmat4 view;\\n};\\n\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var defaultUboDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=defaultUboDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'lightFragmentDeclaration';\r\nvar shader = \"#ifdef LIGHT{X}\\nuniform vec4 vLightData{X};\\nuniform vec4 vLightDiffuse{X};\\n#ifdef SPECULARTERM\\nuniform vec4 vLightSpecular{X};\\n#else\\nvec4 vLightSpecular{X}=vec4(0.);\\n#endif\\n#ifdef SHADOW{X}\\n#ifdef SHADOWCSM{X}\\nuniform mat4 lightMatrix{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float viewFrustumZ{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float frustumLengths{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float cascadeBlendFactor{X};\\nvarying vec4 vPositionFromLight{X}[SHADOWCSMNUM_CASCADES{X}];\\nvarying float vDepthMetric{X}[SHADOWCSMNUM_CASCADES{X}];\\nvarying vec4 vPositionFromCamera{X};\\n#if defined(SHADOWPCSS{X})\\nuniform highp sampler2DArrayShadow shadowSampler{X};\\nuniform highp sampler2DArray depthSampler{X};\\nuniform vec2 lightSizeUVCorrection{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float depthCorrection{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float penumbraDarkness{X};\\n#elif defined(SHADOWPCF{X})\\nuniform highp sampler2DArrayShadow shadowSampler{X};\\n#else\\nuniform highp sampler2DArray shadowSampler{X};\\n#endif\\n#ifdef SHADOWCSMDEBUG{X}\\nconst vec3 vCascadeColorsMultiplier{X}[8]=vec3[8]\\n(\\nvec3 ( 1.5,0.0,0.0 ),\\nvec3 ( 0.0,1.5,0.0 ),\\nvec3 ( 0.0,0.0,5.5 ),\\nvec3 ( 1.5,0.0,5.5 ),\\nvec3 ( 1.5,1.5,0.0 ),\\nvec3 ( 1.0,1.0,1.0 ),\\nvec3 ( 0.0,1.0,5.5 ),\\nvec3 ( 0.5,3.5,0.75 )\\n);\\nvec3 shadowDebug{X};\\n#endif\\n#ifdef SHADOWCSMUSESHADOWMAXZ{X}\\nint index{X}=-1;\\n#else\\nint index{X}=SHADOWCSMNUM_CASCADES{X}-1;\\n#endif\\nfloat diff{X}=0.;\\n#elif defined(SHADOWCUBE{X})\\nuniform samplerCube shadowSampler{X};\\n#else\\nvarying vec4 vPositionFromLight{X};\\nvarying float vDepthMetric{X};\\n#if defined(SHADOWPCSS{X})\\nuniform highp sampler2DShadow shadowSampler{X};\\nuniform highp sampler2D depthSampler{X};\\n#elif defined(SHADOWPCF{X})\\nuniform highp sampler2DShadow shadowSampler{X};\\n#else\\nuniform sampler2D shadowSampler{X};\\n#endif\\nuniform mat4 lightMatrix{X};\\n#endif\\nuniform vec4 shadowsInfo{X};\\nuniform vec2 depthValues{X};\\n#endif\\n#ifdef SPOTLIGHT{X}\\nuniform vec4 vLightDirection{X};\\nuniform vec4 vLightFalloff{X};\\n#elif defined(POINTLIGHT{X})\\nuniform vec4 vLightFalloff{X};\\n#elif defined(HEMILIGHT{X})\\nuniform vec3 vLightGround{X};\\n#endif\\n#ifdef PROJECTEDLIGHTTEXTURE{X}\\nuniform mat4 textureProjectionMatrix{X};\\nuniform sampler2D projectionLightSampler{X};\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var lightFragmentDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=lightFragmentDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'lightUboDeclaration';\r\nvar shader = \"#ifdef LIGHT{X}\\nuniform Light{X}\\n{\\nvec4 vLightData;\\nvec4 vLightDiffuse;\\nvec4 vLightSpecular;\\n#ifdef SPOTLIGHT{X}\\nvec4 vLightDirection;\\nvec4 vLightFalloff;\\n#elif defined(POINTLIGHT{X})\\nvec4 vLightFalloff;\\n#elif defined(HEMILIGHT{X})\\nvec3 vLightGround;\\n#endif\\nvec4 shadowsInfo;\\nvec2 depthValues;\\n} light{X};\\n#ifdef PROJECTEDLIGHTTEXTURE{X}\\nuniform mat4 textureProjectionMatrix{X};\\nuniform sampler2D projectionLightSampler{X};\\n#endif\\n#ifdef SHADOW{X}\\n#ifdef SHADOWCSM{X}\\nuniform mat4 lightMatrix{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float viewFrustumZ{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float frustumLengths{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float cascadeBlendFactor{X};\\nvarying vec4 vPositionFromLight{X}[SHADOWCSMNUM_CASCADES{X}];\\nvarying float vDepthMetric{X}[SHADOWCSMNUM_CASCADES{X}];\\nvarying vec4 vPositionFromCamera{X};\\n#if defined(SHADOWPCSS{X})\\nuniform highp sampler2DArrayShadow shadowSampler{X};\\nuniform highp sampler2DArray depthSampler{X};\\nuniform vec2 lightSizeUVCorrection{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float depthCorrection{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float penumbraDarkness{X};\\n#elif defined(SHADOWPCF{X})\\nuniform highp sampler2DArrayShadow shadowSampler{X};\\n#else\\nuniform highp sampler2DArray shadowSampler{X};\\n#endif\\n#ifdef SHADOWCSMDEBUG{X}\\nconst vec3 vCascadeColorsMultiplier{X}[8]=vec3[8]\\n(\\nvec3 ( 1.5,0.0,0.0 ),\\nvec3 ( 0.0,1.5,0.0 ),\\nvec3 ( 0.0,0.0,5.5 ),\\nvec3 ( 1.5,0.0,5.5 ),\\nvec3 ( 1.5,1.5,0.0 ),\\nvec3 ( 1.0,1.0,1.0 ),\\nvec3 ( 0.0,1.0,5.5 ),\\nvec3 ( 0.5,3.5,0.75 )\\n);\\nvec3 shadowDebug{X};\\n#endif\\n#ifdef SHADOWCSMUSESHADOWMAXZ{X}\\nint index{X}=-1;\\n#else\\nint index{X}=SHADOWCSMNUM_CASCADES{X}-1;\\n#endif\\nfloat diff{X}=0.;\\n#elif defined(SHADOWCUBE{X})\\nuniform samplerCube shadowSampler{X};\\n#else\\nvarying vec4 vPositionFromLight{X};\\nvarying float vDepthMetric{X};\\n#if defined(SHADOWPCSS{X})\\nuniform highp sampler2DShadow shadowSampler{X};\\nuniform highp sampler2D depthSampler{X};\\n#elif defined(SHADOWPCF{X})\\nuniform highp sampler2DShadow shadowSampler{X};\\n#else\\nuniform sampler2D shadowSampler{X};\\n#endif\\nuniform mat4 lightMatrix{X};\\n#endif\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var lightUboDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=lightUboDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'lightsFragmentFunctions';\r\nvar shader = \"\\nstruct lightingInfo\\n{\\nvec3 diffuse;\\n#ifdef SPECULARTERM\\nvec3 specular;\\n#endif\\n#ifdef NDOTL\\nfloat ndl;\\n#endif\\n};\\nlightingInfo computeLighting(vec3 viewDirectionW,vec3 vNormal,vec4 lightData,vec3 diffuseColor,vec3 specularColor,float range,float glossiness) {\\nlightingInfo result;\\nvec3 lightVectorW;\\nfloat attenuation=1.0;\\nif (lightData.w == 0.)\\n{\\nvec3 direction=lightData.xyz-vPositionW;\\nattenuation=max(0.,1.0-length(direction)/range);\\nlightVectorW=normalize(direction);\\n}\\nelse\\n{\\nlightVectorW=normalize(-lightData.xyz);\\n}\\n\\nfloat ndl=max(0.,dot(vNormal,lightVectorW));\\n#ifdef NDOTL\\nresult.ndl=ndl;\\n#endif\\nresult.diffuse=ndl*diffuseColor*attenuation;\\n#ifdef SPECULARTERM\\n\\nvec3 angleW=normalize(viewDirectionW+lightVectorW);\\nfloat specComp=max(0.,dot(vNormal,angleW));\\nspecComp=pow(specComp,max(1.,glossiness));\\nresult.specular=specComp*specularColor*attenuation;\\n#endif\\nreturn result;\\n}\\nlightingInfo computeSpotLighting(vec3 viewDirectionW,vec3 vNormal,vec4 lightData,vec4 lightDirection,vec3 diffuseColor,vec3 specularColor,float range,float glossiness) {\\nlightingInfo result;\\nvec3 direction=lightData.xyz-vPositionW;\\nvec3 lightVectorW=normalize(direction);\\nfloat attenuation=max(0.,1.0-length(direction)/range);\\n\\nfloat cosAngle=max(0.,dot(lightDirection.xyz,-lightVectorW));\\nif (cosAngle>=lightDirection.w)\\n{\\ncosAngle=max(0.,pow(cosAngle,lightData.w));\\nattenuation*=cosAngle;\\n\\nfloat ndl=max(0.,dot(vNormal,lightVectorW));\\n#ifdef NDOTL\\nresult.ndl=ndl;\\n#endif\\nresult.diffuse=ndl*diffuseColor*attenuation;\\n#ifdef SPECULARTERM\\n\\nvec3 angleW=normalize(viewDirectionW+lightVectorW);\\nfloat specComp=max(0.,dot(vNormal,angleW));\\nspecComp=pow(specComp,max(1.,glossiness));\\nresult.specular=specComp*specularColor*attenuation;\\n#endif\\nreturn result;\\n}\\nresult.diffuse=vec3(0.);\\n#ifdef SPECULARTERM\\nresult.specular=vec3(0.);\\n#endif\\n#ifdef NDOTL\\nresult.ndl=0.;\\n#endif\\nreturn result;\\n}\\nlightingInfo computeHemisphericLighting(vec3 viewDirectionW,vec3 vNormal,vec4 lightData,vec3 diffuseColor,vec3 specularColor,vec3 groundColor,float glossiness) {\\nlightingInfo result;\\n\\nfloat ndl=dot(vNormal,lightData.xyz)*0.5+0.5;\\n#ifdef NDOTL\\nresult.ndl=ndl;\\n#endif\\nresult.diffuse=mix(groundColor,diffuseColor,ndl);\\n#ifdef SPECULARTERM\\n\\nvec3 angleW=normalize(viewDirectionW+lightData.xyz);\\nfloat specComp=max(0.,dot(vNormal,angleW));\\nspecComp=pow(specComp,max(1.,glossiness));\\nresult.specular=specComp*specularColor;\\n#endif\\nreturn result;\\n}\\nvec3 computeProjectionTextureDiffuseLighting(sampler2D projectionLightSampler,mat4 textureProjectionMatrix){\\nvec4 strq=textureProjectionMatrix*vec4(vPositionW,1.0);\\nstrq/=strq.w;\\nvec3 textureColor=texture2D(projectionLightSampler,strq.xy).rgb;\\nreturn textureColor;\\n}\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var lightsFragmentFunctions = { name: name, shader: shader };\r\n//# sourceMappingURL=lightsFragmentFunctions.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'shadowsFragmentFunctions';\r\nvar shader = \"#ifdef SHADOWS\\n#ifndef SHADOWFLOAT\\n\\nfloat unpack(vec4 color)\\n{\\nconst vec4 bit_shift=vec4(1.0/(255.0*255.0*255.0),1.0/(255.0*255.0),1.0/255.0,1.0);\\nreturn dot(color,bit_shift);\\n}\\n#endif\\nfloat computeFallOff(float value,vec2 clipSpace,float frustumEdgeFalloff)\\n{\\nfloat mask=smoothstep(1.0-frustumEdgeFalloff,1.00000012,clamp(dot(clipSpace,clipSpace),0.,1.));\\nreturn mix(value,1.0,mask);\\n}\\nfloat computeShadowCube(vec3 lightPosition,samplerCube shadowSampler,float darkness,vec2 depthValues)\\n{\\nvec3 directionToLight=vPositionW-lightPosition;\\nfloat depth=length(directionToLight);\\ndepth=(depth+depthValues.x)/(depthValues.y);\\ndepth=clamp(depth,0.,1.0);\\ndirectionToLight=normalize(directionToLight);\\ndirectionToLight.y=-directionToLight.y;\\n#ifndef SHADOWFLOAT\\nfloat shadow=unpack(textureCube(shadowSampler,directionToLight));\\n#else\\nfloat shadow=textureCube(shadowSampler,directionToLight).x;\\n#endif\\nif (depth>shadow)\\n{\\nreturn darkness;\\n}\\nreturn 1.0;\\n}\\nfloat computeShadowWithPoissonSamplingCube(vec3 lightPosition,samplerCube shadowSampler,float mapSize,float darkness,vec2 depthValues)\\n{\\nvec3 directionToLight=vPositionW-lightPosition;\\nfloat depth=length(directionToLight);\\ndepth=(depth+depthValues.x)/(depthValues.y);\\ndepth=clamp(depth,0.,1.0);\\ndirectionToLight=normalize(directionToLight);\\ndirectionToLight.y=-directionToLight.y;\\nfloat visibility=1.;\\nvec3 poissonDisk[4];\\npoissonDisk[0]=vec3(-1.0,1.0,-1.0);\\npoissonDisk[1]=vec3(1.0,-1.0,-1.0);\\npoissonDisk[2]=vec3(-1.0,-1.0,-1.0);\\npoissonDisk[3]=vec3(1.0,-1.0,1.0);\\n\\n#ifndef SHADOWFLOAT\\nif (unpack(textureCube(shadowSampler,directionToLight+poissonDisk[0]*mapSize))shadow)\\n{\\nreturn computeFallOff(darkness,clipSpace.xy,frustumEdgeFalloff);\\n}\\nreturn 1.;\\n}\\n#endif\\nfloat computeShadow(vec4 vPositionFromLight,float depthMetric,sampler2D shadowSampler,float darkness,float frustumEdgeFalloff)\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec2 uv=0.5*clipSpace.xy+vec2(0.5);\\nif (uv.x<0. || uv.x>1.0 || uv.y<0. || uv.y>1.0)\\n{\\nreturn 1.0;\\n}\\nfloat shadowPixelDepth=clamp(depthMetric,0.,1.0);\\n#ifndef SHADOWFLOAT\\nfloat shadow=unpack(texture2D(shadowSampler,uv));\\n#else\\nfloat shadow=texture2D(shadowSampler,uv).x;\\n#endif\\nif (shadowPixelDepth>shadow)\\n{\\nreturn computeFallOff(darkness,clipSpace.xy,frustumEdgeFalloff);\\n}\\nreturn 1.;\\n}\\nfloat computeShadowWithPoissonSampling(vec4 vPositionFromLight,float depthMetric,sampler2D shadowSampler,float mapSize,float darkness,float frustumEdgeFalloff)\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec2 uv=0.5*clipSpace.xy+vec2(0.5);\\nif (uv.x<0. || uv.x>1.0 || uv.y<0. || uv.y>1.0)\\n{\\nreturn 1.0;\\n}\\nfloat shadowPixelDepth=clamp(depthMetric,0.,1.0);\\nfloat visibility=1.;\\nvec2 poissonDisk[4];\\npoissonDisk[0]=vec2(-0.94201624,-0.39906216);\\npoissonDisk[1]=vec2(0.94558609,-0.76890725);\\npoissonDisk[2]=vec2(-0.094184101,-0.92938870);\\npoissonDisk[3]=vec2(0.34495938,0.29387760);\\n\\n#ifndef SHADOWFLOAT\\nif (unpack(texture2D(shadowSampler,uv+poissonDisk[0]*mapSize))1.0 || uv.y<0. || uv.y>1.0)\\n{\\nreturn 1.0;\\n}\\nfloat shadowPixelDepth=clamp(depthMetric,0.,1.0);\\n#ifndef SHADOWFLOAT\\nfloat shadowMapSample=unpack(texture2D(shadowSampler,uv));\\n#else\\nfloat shadowMapSample=texture2D(shadowSampler,uv).x;\\n#endif\\nfloat esm=1.0-clamp(exp(min(87.,depthScale*shadowPixelDepth))*shadowMapSample,0.,1.-darkness);\\nreturn computeFallOff(esm,clipSpace.xy,frustumEdgeFalloff);\\n}\\nfloat computeShadowWithCloseESM(vec4 vPositionFromLight,float depthMetric,sampler2D shadowSampler,float darkness,float depthScale,float frustumEdgeFalloff)\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec2 uv=0.5*clipSpace.xy+vec2(0.5);\\nif (uv.x<0. || uv.x>1.0 || uv.y<0. || uv.y>1.0)\\n{\\nreturn 1.0;\\n}\\nfloat shadowPixelDepth=clamp(depthMetric,0.,1.0);\\n#ifndef SHADOWFLOAT\\nfloat shadowMapSample=unpack(texture2D(shadowSampler,uv));\\n#else\\nfloat shadowMapSample=texture2D(shadowSampler,uv).x;\\n#endif\\nfloat esm=clamp(exp(min(87.,-depthScale*(shadowPixelDepth-shadowMapSample))),darkness,1.);\\nreturn computeFallOff(esm,clipSpace.xy,frustumEdgeFalloff);\\n}\\n#ifdef WEBGL2\\n#define GREATEST_LESS_THAN_ONE 0.99999994\\n\\nfloat computeShadowWithCSMPCF1(float layer,vec4 vPositionFromLight,float depthMetric,highp sampler2DArrayShadow shadowSampler,float darkness,float frustumEdgeFalloff)\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec3 uvDepth=vec3(0.5*clipSpace.xyz+vec3(0.5));\\nuvDepth.z=clamp(uvDepth.z,0.,GREATEST_LESS_THAN_ONE);\\nvec4 uvDepthLayer=vec4(uvDepth.x,uvDepth.y,layer,uvDepth.z);\\nfloat shadow=texture(shadowSampler,uvDepthLayer);\\nshadow=mix(darkness,1.,shadow);\\nreturn computeFallOff(shadow,clipSpace.xy,frustumEdgeFalloff);\\n}\\n\\n\\n\\nfloat computeShadowWithCSMPCF3(float layer,vec4 vPositionFromLight,float depthMetric,highp sampler2DArrayShadow shadowSampler,vec2 shadowMapSizeAndInverse,float darkness,float frustumEdgeFalloff)\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec3 uvDepth=vec3(0.5*clipSpace.xyz+vec3(0.5));\\nuvDepth.z=clamp(uvDepth.z,0.,GREATEST_LESS_THAN_ONE);\\nvec2 uv=uvDepth.xy*shadowMapSizeAndInverse.x;\\nuv+=0.5;\\nvec2 st=fract(uv);\\nvec2 base_uv=floor(uv)-0.5;\\nbase_uv*=shadowMapSizeAndInverse.y;\\n\\n\\n\\n\\nvec2 uvw0=3.-2.*st;\\nvec2 uvw1=1.+2.*st;\\nvec2 u=vec2((2.-st.x)/uvw0.x-1.,st.x/uvw1.x+1.)*shadowMapSizeAndInverse.y;\\nvec2 v=vec2((2.-st.y)/uvw0.y-1.,st.y/uvw1.y+1.)*shadowMapSizeAndInverse.y;\\nfloat shadow=0.;\\nshadow+=uvw0.x*uvw0.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[0],v[0]),layer,uvDepth.z));\\nshadow+=uvw1.x*uvw0.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[1],v[0]),layer,uvDepth.z));\\nshadow+=uvw0.x*uvw1.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[0],v[1]),layer,uvDepth.z));\\nshadow+=uvw1.x*uvw1.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[1],v[1]),layer,uvDepth.z));\\nshadow=shadow/16.;\\nshadow=mix(darkness,1.,shadow);\\nreturn computeFallOff(shadow,clipSpace.xy,frustumEdgeFalloff);\\n}\\n\\n\\n\\nfloat computeShadowWithCSMPCF5(float layer,vec4 vPositionFromLight,float depthMetric,highp sampler2DArrayShadow shadowSampler,vec2 shadowMapSizeAndInverse,float darkness,float frustumEdgeFalloff)\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec3 uvDepth=vec3(0.5*clipSpace.xyz+vec3(0.5));\\nuvDepth.z=clamp(uvDepth.z,0.,GREATEST_LESS_THAN_ONE);\\nvec2 uv=uvDepth.xy*shadowMapSizeAndInverse.x;\\nuv+=0.5;\\nvec2 st=fract(uv);\\nvec2 base_uv=floor(uv)-0.5;\\nbase_uv*=shadowMapSizeAndInverse.y;\\n\\n\\nvec2 uvw0=4.-3.*st;\\nvec2 uvw1=vec2(7.);\\nvec2 uvw2=1.+3.*st;\\nvec3 u=vec3((3.-2.*st.x)/uvw0.x-2.,(3.+st.x)/uvw1.x,st.x/uvw2.x+2.)*shadowMapSizeAndInverse.y;\\nvec3 v=vec3((3.-2.*st.y)/uvw0.y-2.,(3.+st.y)/uvw1.y,st.y/uvw2.y+2.)*shadowMapSizeAndInverse.y;\\nfloat shadow=0.;\\nshadow+=uvw0.x*uvw0.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[0],v[0]),layer,uvDepth.z));\\nshadow+=uvw1.x*uvw0.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[1],v[0]),layer,uvDepth.z));\\nshadow+=uvw2.x*uvw0.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[2],v[0]),layer,uvDepth.z));\\nshadow+=uvw0.x*uvw1.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[0],v[1]),layer,uvDepth.z));\\nshadow+=uvw1.x*uvw1.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[1],v[1]),layer,uvDepth.z));\\nshadow+=uvw2.x*uvw1.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[2],v[1]),layer,uvDepth.z));\\nshadow+=uvw0.x*uvw2.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[0],v[2]),layer,uvDepth.z));\\nshadow+=uvw1.x*uvw2.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[1],v[2]),layer,uvDepth.z));\\nshadow+=uvw2.x*uvw2.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[2],v[2]),layer,uvDepth.z));\\nshadow=shadow/144.;\\nshadow=mix(darkness,1.,shadow);\\nreturn computeFallOff(shadow,clipSpace.xy,frustumEdgeFalloff);\\n}\\n\\nfloat computeShadowWithPCF1(vec4 vPositionFromLight,float depthMetric,sampler2DShadow shadowSampler,float darkness,float frustumEdgeFalloff)\\n{\\nif (depthMetric>1.0 || depthMetric<0.0) {\\nreturn 1.0;\\n}\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec3 uvDepth=vec3(0.5*clipSpace.xyz+vec3(0.5));\\nfloat shadow=texture2D(shadowSampler,uvDepth);\\nshadow=mix(darkness,1.,shadow);\\nreturn computeFallOff(shadow,clipSpace.xy,frustumEdgeFalloff);\\n}\\n\\n\\n\\nfloat computeShadowWithPCF3(vec4 vPositionFromLight,float depthMetric,sampler2DShadow shadowSampler,vec2 shadowMapSizeAndInverse,float darkness,float frustumEdgeFalloff)\\n{\\nif (depthMetric>1.0 || depthMetric<0.0) {\\nreturn 1.0;\\n}\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec3 uvDepth=vec3(0.5*clipSpace.xyz+vec3(0.5));\\nvec2 uv=uvDepth.xy*shadowMapSizeAndInverse.x;\\nuv+=0.5;\\nvec2 st=fract(uv);\\nvec2 base_uv=floor(uv)-0.5;\\nbase_uv*=shadowMapSizeAndInverse.y;\\n\\n\\n\\n\\nvec2 uvw0=3.-2.*st;\\nvec2 uvw1=1.+2.*st;\\nvec2 u=vec2((2.-st.x)/uvw0.x-1.,st.x/uvw1.x+1.)*shadowMapSizeAndInverse.y;\\nvec2 v=vec2((2.-st.y)/uvw0.y-1.,st.y/uvw1.y+1.)*shadowMapSizeAndInverse.y;\\nfloat shadow=0.;\\nshadow+=uvw0.x*uvw0.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[0],v[0]),uvDepth.z));\\nshadow+=uvw1.x*uvw0.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[1],v[0]),uvDepth.z));\\nshadow+=uvw0.x*uvw1.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[0],v[1]),uvDepth.z));\\nshadow+=uvw1.x*uvw1.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[1],v[1]),uvDepth.z));\\nshadow=shadow/16.;\\nshadow=mix(darkness,1.,shadow);\\nreturn computeFallOff(shadow,clipSpace.xy,frustumEdgeFalloff);\\n}\\n\\n\\n\\nfloat computeShadowWithPCF5(vec4 vPositionFromLight,float depthMetric,sampler2DShadow shadowSampler,vec2 shadowMapSizeAndInverse,float darkness,float frustumEdgeFalloff)\\n{\\nif (depthMetric>1.0 || depthMetric<0.0) {\\nreturn 1.0;\\n}\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec3 uvDepth=vec3(0.5*clipSpace.xyz+vec3(0.5));\\nvec2 uv=uvDepth.xy*shadowMapSizeAndInverse.x;\\nuv+=0.5;\\nvec2 st=fract(uv);\\nvec2 base_uv=floor(uv)-0.5;\\nbase_uv*=shadowMapSizeAndInverse.y;\\n\\n\\nvec2 uvw0=4.-3.*st;\\nvec2 uvw1=vec2(7.);\\nvec2 uvw2=1.+3.*st;\\nvec3 u=vec3((3.-2.*st.x)/uvw0.x-2.,(3.+st.x)/uvw1.x,st.x/uvw2.x+2.)*shadowMapSizeAndInverse.y;\\nvec3 v=vec3((3.-2.*st.y)/uvw0.y-2.,(3.+st.y)/uvw1.y,st.y/uvw2.y+2.)*shadowMapSizeAndInverse.y;\\nfloat shadow=0.;\\nshadow+=uvw0.x*uvw0.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[0],v[0]),uvDepth.z));\\nshadow+=uvw1.x*uvw0.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[1],v[0]),uvDepth.z));\\nshadow+=uvw2.x*uvw0.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[2],v[0]),uvDepth.z));\\nshadow+=uvw0.x*uvw1.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[0],v[1]),uvDepth.z));\\nshadow+=uvw1.x*uvw1.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[1],v[1]),uvDepth.z));\\nshadow+=uvw2.x*uvw1.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[2],v[1]),uvDepth.z));\\nshadow+=uvw0.x*uvw2.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[0],v[2]),uvDepth.z));\\nshadow+=uvw1.x*uvw2.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[1],v[2]),uvDepth.z));\\nshadow+=uvw2.x*uvw2.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[2],v[2]),uvDepth.z));\\nshadow=shadow/144.;\\nshadow=mix(darkness,1.,shadow);\\nreturn computeFallOff(shadow,clipSpace.xy,frustumEdgeFalloff);\\n}\\nconst vec3 PoissonSamplers32[64]=vec3[64](\\nvec3(0.06407013,0.05409927,0.),\\nvec3(0.7366577,0.5789394,0.),\\nvec3(-0.6270542,-0.5320278,0.),\\nvec3(-0.4096107,0.8411095,0.),\\nvec3(0.6849564,-0.4990818,0.),\\nvec3(-0.874181,-0.04579735,0.),\\nvec3(0.9989998,0.0009880066,0.),\\nvec3(-0.004920578,-0.9151649,0.),\\nvec3(0.1805763,0.9747483,0.),\\nvec3(-0.2138451,0.2635818,0.),\\nvec3(0.109845,0.3884785,0.),\\nvec3(0.06876755,-0.3581074,0.),\\nvec3(0.374073,-0.7661266,0.),\\nvec3(0.3079132,-0.1216763,0.),\\nvec3(-0.3794335,-0.8271583,0.),\\nvec3(-0.203878,-0.07715034,0.),\\nvec3(0.5912697,0.1469799,0.),\\nvec3(-0.88069,0.3031784,0.),\\nvec3(0.5040108,0.8283722,0.),\\nvec3(-0.5844124,0.5494877,0.),\\nvec3(0.6017799,-0.1726654,0.),\\nvec3(-0.5554981,0.1559997,0.),\\nvec3(-0.3016369,-0.3900928,0.),\\nvec3(-0.5550632,-0.1723762,0.),\\nvec3(0.925029,0.2995041,0.),\\nvec3(-0.2473137,0.5538505,0.),\\nvec3(0.9183037,-0.2862392,0.),\\nvec3(0.2469421,0.6718712,0.),\\nvec3(0.3916397,-0.4328209,0.),\\nvec3(-0.03576927,-0.6220032,0.),\\nvec3(-0.04661255,0.7995201,0.),\\nvec3(0.4402924,0.3640312,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.)\\n);\\nconst vec3 PoissonSamplers64[64]=vec3[64](\\nvec3(-0.613392,0.617481,0.),\\nvec3(0.170019,-0.040254,0.),\\nvec3(-0.299417,0.791925,0.),\\nvec3(0.645680,0.493210,0.),\\nvec3(-0.651784,0.717887,0.),\\nvec3(0.421003,0.027070,0.),\\nvec3(-0.817194,-0.271096,0.),\\nvec3(-0.705374,-0.668203,0.),\\nvec3(0.977050,-0.108615,0.),\\nvec3(0.063326,0.142369,0.),\\nvec3(0.203528,0.214331,0.),\\nvec3(-0.667531,0.326090,0.),\\nvec3(-0.098422,-0.295755,0.),\\nvec3(-0.885922,0.215369,0.),\\nvec3(0.566637,0.605213,0.),\\nvec3(0.039766,-0.396100,0.),\\nvec3(0.751946,0.453352,0.),\\nvec3(0.078707,-0.715323,0.),\\nvec3(-0.075838,-0.529344,0.),\\nvec3(0.724479,-0.580798,0.),\\nvec3(0.222999,-0.215125,0.),\\nvec3(-0.467574,-0.405438,0.),\\nvec3(-0.248268,-0.814753,0.),\\nvec3(0.354411,-0.887570,0.),\\nvec3(0.175817,0.382366,0.),\\nvec3(0.487472,-0.063082,0.),\\nvec3(-0.084078,0.898312,0.),\\nvec3(0.488876,-0.783441,0.),\\nvec3(0.470016,0.217933,0.),\\nvec3(-0.696890,-0.549791,0.),\\nvec3(-0.149693,0.605762,0.),\\nvec3(0.034211,0.979980,0.),\\nvec3(0.503098,-0.308878,0.),\\nvec3(-0.016205,-0.872921,0.),\\nvec3(0.385784,-0.393902,0.),\\nvec3(-0.146886,-0.859249,0.),\\nvec3(0.643361,0.164098,0.),\\nvec3(0.634388,-0.049471,0.),\\nvec3(-0.688894,0.007843,0.),\\nvec3(0.464034,-0.188818,0.),\\nvec3(-0.440840,0.137486,0.),\\nvec3(0.364483,0.511704,0.),\\nvec3(0.034028,0.325968,0.),\\nvec3(0.099094,-0.308023,0.),\\nvec3(0.693960,-0.366253,0.),\\nvec3(0.678884,-0.204688,0.),\\nvec3(0.001801,0.780328,0.),\\nvec3(0.145177,-0.898984,0.),\\nvec3(0.062655,-0.611866,0.),\\nvec3(0.315226,-0.604297,0.),\\nvec3(-0.780145,0.486251,0.),\\nvec3(-0.371868,0.882138,0.),\\nvec3(0.200476,0.494430,0.),\\nvec3(-0.494552,-0.711051,0.),\\nvec3(0.612476,0.705252,0.),\\nvec3(-0.578845,-0.768792,0.),\\nvec3(-0.772454,-0.090976,0.),\\nvec3(0.504440,0.372295,0.),\\nvec3(0.155736,0.065157,0.),\\nvec3(0.391522,0.849605,0.),\\nvec3(-0.620106,-0.328104,0.),\\nvec3(0.789239,-0.419965,0.),\\nvec3(-0.545396,0.538133,0.),\\nvec3(-0.178564,-0.596057,0.)\\n);\\n\\n\\n\\n\\n\\nfloat computeShadowWithCSMPCSS(float layer,vec4 vPositionFromLight,float depthMetric,highp sampler2DArray depthSampler,highp sampler2DArrayShadow shadowSampler,float shadowMapSizeInverse,float lightSizeUV,float darkness,float frustumEdgeFalloff,int searchTapCount,int pcfTapCount,vec3[64] poissonSamplers,vec2 lightSizeUVCorrection,float depthCorrection,float penumbraDarkness)\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec3 uvDepth=vec3(0.5*clipSpace.xyz+vec3(0.5));\\nuvDepth.z=clamp(uvDepth.z,0.,GREATEST_LESS_THAN_ONE);\\nvec4 uvDepthLayer=vec4(uvDepth.x,uvDepth.y,layer,uvDepth.z);\\nfloat blockerDepth=0.0;\\nfloat sumBlockerDepth=0.0;\\nfloat numBlocker=0.0;\\nfor (int i=0; i1.0 || depthMetric<0.0) {\\nreturn 1.0;\\n}\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec3 uvDepth=vec3(0.5*clipSpace.xyz+vec3(0.5));\\nfloat blockerDepth=0.0;\\nfloat sumBlockerDepth=0.0;\\nfloat numBlocker=0.0;\\nfor (int i=0; icurrRayHeight)\\n{\\nfloat delta1=currSampledHeight-currRayHeight;\\nfloat delta2=(currRayHeight+stepSize)-lastSampledHeight;\\nfloat ratio=delta1/(delta1+delta2);\\nvCurrOffset=(ratio)* vLastOffset+(1.0-ratio)*vCurrOffset;\\n\\nbreak;\\n}\\nelse\\n{\\ncurrRayHeight-=stepSize;\\nvLastOffset=vCurrOffset;\\nvCurrOffset+=stepSize*vMaxOffset;\\nlastSampledHeight=currSampledHeight;\\n}\\n}\\nreturn vCurrOffset;\\n}\\nvec2 parallaxOffset(vec3 viewDir,float heightScale)\\n{\\n\\nfloat height=texture2D(bumpSampler,vBumpUV).w;\\nvec2 texCoordOffset=heightScale*viewDir.xy*height;\\nreturn -texCoordOffset;\\n}\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var bumpFragmentFunctions = { name: name, shader: shader };\r\n//# sourceMappingURL=bumpFragmentFunctions.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'logDepthDeclaration';\r\nvar shader = \"#ifdef LOGARITHMICDEPTH\\nuniform float logarithmicDepthConstant;\\nvarying float vFragmentDepth;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var logDepthDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=logDepthDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'fogFragmentDeclaration';\r\nvar shader = \"#ifdef FOG\\n#define FOGMODE_NONE 0.\\n#define FOGMODE_EXP 1.\\n#define FOGMODE_EXP2 2.\\n#define FOGMODE_LINEAR 3.\\n#define E 2.71828\\nuniform vec4 vFogInfos;\\nuniform vec3 vFogColor;\\nvarying vec3 vFogDistance;\\nfloat CalcFogFactor()\\n{\\nfloat fogCoeff=1.0;\\nfloat fogStart=vFogInfos.y;\\nfloat fogEnd=vFogInfos.z;\\nfloat fogDensity=vFogInfos.w;\\nfloat fogDistance=length(vFogDistance);\\nif (FOGMODE_LINEAR == vFogInfos.x)\\n{\\nfogCoeff=(fogEnd-fogDistance)/(fogEnd-fogStart);\\n}\\nelse if (FOGMODE_EXP == vFogInfos.x)\\n{\\nfogCoeff=1.0/pow(E,fogDistance*fogDensity);\\n}\\nelse if (FOGMODE_EXP2 == vFogInfos.x)\\n{\\nfogCoeff=1.0/pow(E,fogDistance*fogDistance*fogDensity*fogDensity);\\n}\\nreturn clamp(fogCoeff,0.0,1.0);\\n}\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var fogFragmentDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=fogFragmentDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'bumpFragment';\r\nvar shader = \"vec2 uvOffset=vec2(0.0,0.0);\\n#if defined(BUMP) || defined(PARALLAX)\\n#ifdef NORMALXYSCALE\\nfloat normalScale=1.0;\\n#else\\nfloat normalScale=vBumpInfos.y;\\n#endif\\n#if defined(TANGENT) && defined(NORMAL)\\nmat3 TBN=vTBN;\\n#else\\nmat3 TBN=cotangent_frame(normalW*normalScale,vPositionW,vBumpUV);\\n#endif\\n#elif defined(ANISOTROPIC)\\n#if defined(TANGENT) && defined(NORMAL)\\nmat3 TBN=vTBN;\\n#else\\nmat3 TBN=cotangent_frame(normalW,vPositionW,vMainUV1,vec2(1.,1.));\\n#endif\\n#endif\\n#ifdef PARALLAX\\nmat3 invTBN=transposeMat3(TBN);\\n#ifdef PARALLAXOCCLUSION\\nuvOffset=parallaxOcclusion(invTBN*-viewDirectionW,invTBN*normalW,vBumpUV,vBumpInfos.z);\\n#else\\nuvOffset=parallaxOffset(invTBN*viewDirectionW,vBumpInfos.z);\\n#endif\\n#endif\\n#ifdef BUMP\\n#ifdef OBJECTSPACE_NORMALMAP\\nnormalW=normalize(texture2D(bumpSampler,vBumpUV).xyz*2.0-1.0);\\nnormalW=normalize(mat3(normalMatrix)*normalW);\\n#else\\nnormalW=perturbNormal(TBN,vBumpUV+uvOffset);\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var bumpFragment = { name: name, shader: shader };\r\n//# sourceMappingURL=bumpFragment.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'depthPrePass';\r\nvar shader = \"#ifdef DEPTHPREPASS\\ngl_FragColor=vec4(0.,0.,0.,1.0);\\nreturn;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var depthPrePass = { name: name, shader: shader };\r\n//# sourceMappingURL=depthPrePass.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'lightFragment';\r\nvar shader = \"#ifdef LIGHT{X}\\n#if defined(SHADOWONLY) || defined(LIGHTMAP) && defined(LIGHTMAPEXCLUDED{X}) && defined(LIGHTMAPNOSPECULAR{X})\\n\\n#else\\n#ifdef PBR\\n\\n#ifdef SPOTLIGHT{X}\\npreInfo=computePointAndSpotPreLightingInfo(light{X}.vLightData,viewDirectionW,normalW);\\n#elif defined(POINTLIGHT{X})\\npreInfo=computePointAndSpotPreLightingInfo(light{X}.vLightData,viewDirectionW,normalW);\\n#elif defined(HEMILIGHT{X})\\npreInfo=computeHemisphericPreLightingInfo(light{X}.vLightData,viewDirectionW,normalW);\\n#elif defined(DIRLIGHT{X})\\npreInfo=computeDirectionalPreLightingInfo(light{X}.vLightData,viewDirectionW,normalW);\\n#endif\\npreInfo.NdotV=NdotV;\\n\\n#ifdef SPOTLIGHT{X}\\n#ifdef LIGHT_FALLOFF_GLTF{X}\\npreInfo.attenuation=computeDistanceLightFalloff_GLTF(preInfo.lightDistanceSquared,light{X}.vLightFalloff.y);\\npreInfo.attenuation*=computeDirectionalLightFalloff_GLTF(light{X}.vLightDirection.xyz,preInfo.L,light{X}.vLightFalloff.z,light{X}.vLightFalloff.w);\\n#elif defined(LIGHT_FALLOFF_PHYSICAL{X})\\npreInfo.attenuation=computeDistanceLightFalloff_Physical(preInfo.lightDistanceSquared);\\npreInfo.attenuation*=computeDirectionalLightFalloff_Physical(light{X}.vLightDirection.xyz,preInfo.L,light{X}.vLightDirection.w);\\n#elif defined(LIGHT_FALLOFF_STANDARD{X})\\npreInfo.attenuation=computeDistanceLightFalloff_Standard(preInfo.lightOffset,light{X}.vLightFalloff.x);\\npreInfo.attenuation*=computeDirectionalLightFalloff_Standard(light{X}.vLightDirection.xyz,preInfo.L,light{X}.vLightDirection.w,light{X}.vLightData.w);\\n#else\\npreInfo.attenuation=computeDistanceLightFalloff(preInfo.lightOffset,preInfo.lightDistanceSquared,light{X}.vLightFalloff.x,light{X}.vLightFalloff.y);\\npreInfo.attenuation*=computeDirectionalLightFalloff(light{X}.vLightDirection.xyz,preInfo.L,light{X}.vLightDirection.w,light{X}.vLightData.w,light{X}.vLightFalloff.z,light{X}.vLightFalloff.w);\\n#endif\\n#elif defined(POINTLIGHT{X})\\n#ifdef LIGHT_FALLOFF_GLTF{X}\\npreInfo.attenuation=computeDistanceLightFalloff_GLTF(preInfo.lightDistanceSquared,light{X}.vLightFalloff.y);\\n#elif defined(LIGHT_FALLOFF_PHYSICAL{X})\\npreInfo.attenuation=computeDistanceLightFalloff_Physical(preInfo.lightDistanceSquared);\\n#elif defined(LIGHT_FALLOFF_STANDARD{X})\\npreInfo.attenuation=computeDistanceLightFalloff_Standard(preInfo.lightOffset,light{X}.vLightFalloff.x);\\n#else\\npreInfo.attenuation=computeDistanceLightFalloff(preInfo.lightOffset,preInfo.lightDistanceSquared,light{X}.vLightFalloff.x,light{X}.vLightFalloff.y);\\n#endif\\n#else\\npreInfo.attenuation=1.0;\\n#endif\\n\\n\\n#ifdef HEMILIGHT{X}\\npreInfo.roughness=roughness;\\n#else\\npreInfo.roughness=adjustRoughnessFromLightProperties(roughness,light{X}.vLightSpecular.a,preInfo.lightDistance);\\n#endif\\n\\n#ifdef HEMILIGHT{X}\\ninfo.diffuse=computeHemisphericDiffuseLighting(preInfo,light{X}.vLightDiffuse.rgb,light{X}.vLightGround);\\n#elif defined(SS_TRANSLUCENCY)\\ninfo.diffuse=computeDiffuseAndTransmittedLighting(preInfo,light{X}.vLightDiffuse.rgb,transmittance);\\n#else\\ninfo.diffuse=computeDiffuseLighting(preInfo,light{X}.vLightDiffuse.rgb);\\n#endif\\n\\n#ifdef SPECULARTERM\\n#ifdef ANISOTROPIC\\ninfo.specular=computeAnisotropicSpecularLighting(preInfo,viewDirectionW,normalW,anisotropicTangent,anisotropicBitangent,anisotropy,specularEnvironmentR0,specularEnvironmentR90,AARoughnessFactors.x,light{X}.vLightDiffuse.rgb);\\n#else\\ninfo.specular=computeSpecularLighting(preInfo,normalW,specularEnvironmentR0,specularEnvironmentR90,AARoughnessFactors.x,light{X}.vLightDiffuse.rgb);\\n#endif\\n#endif\\n\\n#ifdef SHEEN\\n#ifdef SHEEN_LINKWITHALBEDO\\n\\npreInfo.roughness=sheenIntensity;\\n#endif\\ninfo.sheen=computeSheenLighting(preInfo,normalW,sheenColor,specularEnvironmentR90,AARoughnessFactors.x,light{X}.vLightDiffuse.rgb);\\n#endif\\n\\n#ifdef CLEARCOAT\\n\\n#ifdef HEMILIGHT{X}\\npreInfo.roughness=clearCoatRoughness;\\n#else\\npreInfo.roughness=adjustRoughnessFromLightProperties(clearCoatRoughness,light{X}.vLightSpecular.a,preInfo.lightDistance);\\n#endif\\ninfo.clearCoat=computeClearCoatLighting(preInfo,clearCoatNormalW,clearCoatAARoughnessFactors.x,clearCoatIntensity,light{X}.vLightDiffuse.rgb);\\n#ifdef CLEARCOAT_TINT\\n\\nabsorption=computeClearCoatLightingAbsorption(clearCoatNdotVRefract,preInfo.L,clearCoatNormalW,clearCoatColor,clearCoatThickness,clearCoatIntensity);\\ninfo.diffuse*=absorption;\\n#ifdef SPECULARTERM\\ninfo.specular*=absorption;\\n#endif\\n#endif\\n\\ninfo.diffuse*=info.clearCoat.w;\\n#ifdef SPECULARTERM\\ninfo.specular*=info.clearCoat.w;\\n#endif\\n#ifdef SHEEN\\ninfo.sheen*=info.clearCoat.w;\\n#endif\\n#endif\\n#else\\n#ifdef SPOTLIGHT{X}\\ninfo=computeSpotLighting(viewDirectionW,normalW,light{X}.vLightData,light{X}.vLightDirection,light{X}.vLightDiffuse.rgb,light{X}.vLightSpecular.rgb,light{X}.vLightDiffuse.a,glossiness);\\n#elif defined(HEMILIGHT{X})\\ninfo=computeHemisphericLighting(viewDirectionW,normalW,light{X}.vLightData,light{X}.vLightDiffuse.rgb,light{X}.vLightSpecular.rgb,light{X}.vLightGround,glossiness);\\n#elif defined(POINTLIGHT{X}) || defined(DIRLIGHT{X})\\ninfo=computeLighting(viewDirectionW,normalW,light{X}.vLightData,light{X}.vLightDiffuse.rgb,light{X}.vLightSpecular.rgb,light{X}.vLightDiffuse.a,glossiness);\\n#endif\\n#endif\\n#ifdef PROJECTEDLIGHTTEXTURE{X}\\ninfo.diffuse*=computeProjectionTextureDiffuseLighting(projectionLightSampler{X},textureProjectionMatrix{X});\\n#endif\\n#endif\\n#ifdef SHADOW{X}\\n#ifdef SHADOWCSM{X}\\nfor (int i=0; i=0.) {\\nindex{X}=i;\\nbreak;\\n}\\n}\\n#ifdef SHADOWCSMUSESHADOWMAXZ{X}\\nif (index{X}>=0)\\n#endif\\n{\\n#if defined(SHADOWPCF{X})\\n#if defined(SHADOWLOWQUALITY{X})\\nshadow=computeShadowWithCSMPCF1(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#elif defined(SHADOWMEDIUMQUALITY{X})\\nshadow=computeShadowWithCSMPCF3(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],shadowSampler{X},light{X}.shadowsInfo.yz,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#else\\nshadow=computeShadowWithCSMPCF5(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],shadowSampler{X},light{X}.shadowsInfo.yz,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#endif\\n#elif defined(SHADOWPCSS{X})\\n#if defined(SHADOWLOWQUALITY{X})\\nshadow=computeShadowWithCSMPCSS16(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w,lightSizeUVCorrection{X}[index{X}],depthCorrection{X}[index{X}],penumbraDarkness{X});\\n#elif defined(SHADOWMEDIUMQUALITY{X})\\nshadow=computeShadowWithCSMPCSS32(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w,lightSizeUVCorrection{X}[index{X}],depthCorrection{X}[index{X}],penumbraDarkness{X});\\n#else\\nshadow=computeShadowWithCSMPCSS64(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w,lightSizeUVCorrection{X}[index{X}],depthCorrection{X}[index{X}],penumbraDarkness{X});\\n#endif\\n#else\\nshadow=computeShadowCSM(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#endif\\n#ifdef SHADOWCSMDEBUG{X}\\nshadowDebug{X}=vec3(shadow)*vCascadeColorsMultiplier{X}[index{X}];\\n#endif\\n#ifndef SHADOWCSMNOBLEND{X}\\nfloat frustumLength=frustumLengths{X}[index{X}];\\nfloat diffRatio=clamp(diff{X}/frustumLength,0.,1.)*cascadeBlendFactor{X};\\nif (index{X}<(SHADOWCSMNUM_CASCADES{X}-1) && diffRatio<1.)\\n{\\nindex{X}+=1;\\nfloat nextShadow=0.;\\n#if defined(SHADOWPCF{X})\\n#if defined(SHADOWLOWQUALITY{X})\\nnextShadow=computeShadowWithCSMPCF1(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#elif defined(SHADOWMEDIUMQUALITY{X})\\nnextShadow=computeShadowWithCSMPCF3(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],shadowSampler{X},light{X}.shadowsInfo.yz,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#else\\nnextShadow=computeShadowWithCSMPCF5(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],shadowSampler{X},light{X}.shadowsInfo.yz,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#endif\\n#elif defined(SHADOWPCSS{X})\\n#if defined(SHADOWLOWQUALITY{X})\\nnextShadow=computeShadowWithCSMPCSS16(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w,lightSizeUVCorrection{X}[index{X}],depthCorrection{X}[index{X}],penumbraDarkness{X});\\n#elif defined(SHADOWMEDIUMQUALITY{X})\\nnextShadow=computeShadowWithCSMPCSS32(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w,lightSizeUVCorrection{X}[index{X}],depthCorrection{X}[index{X}],penumbraDarkness{X});\\n#else\\nnextShadow=computeShadowWithCSMPCSS64(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w,lightSizeUVCorrection{X}[index{X}],depthCorrection{X}[index{X}],penumbraDarkness{X});\\n#endif\\n#else\\nnextShadow=computeShadowCSM(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#endif\\nshadow=mix(nextShadow,shadow,diffRatio);\\n#ifdef SHADOWCSMDEBUG{X}\\nshadowDebug{X}=mix(vec3(nextShadow)*vCascadeColorsMultiplier{X}[index{X}],shadowDebug{X},diffRatio);\\n#endif\\n}\\n#endif\\n}\\n#elif defined(SHADOWCLOSEESM{X})\\n#if defined(SHADOWCUBE{X})\\nshadow=computeShadowWithCloseESMCube(light{X}.vLightData.xyz,shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.z,light{X}.depthValues);\\n#else\\nshadow=computeShadowWithCloseESM(vPositionFromLight{X},vDepthMetric{X},shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.z,light{X}.shadowsInfo.w);\\n#endif\\n#elif defined(SHADOWESM{X})\\n#if defined(SHADOWCUBE{X})\\nshadow=computeShadowWithESMCube(light{X}.vLightData.xyz,shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.z,light{X}.depthValues);\\n#else\\nshadow=computeShadowWithESM(vPositionFromLight{X},vDepthMetric{X},shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.z,light{X}.shadowsInfo.w);\\n#endif\\n#elif defined(SHADOWPOISSON{X})\\n#if defined(SHADOWCUBE{X})\\nshadow=computeShadowWithPoissonSamplingCube(light{X}.vLightData.xyz,shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.x,light{X}.depthValues);\\n#else\\nshadow=computeShadowWithPoissonSampling(vPositionFromLight{X},vDepthMetric{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#endif\\n#elif defined(SHADOWPCF{X})\\n#if defined(SHADOWLOWQUALITY{X})\\nshadow=computeShadowWithPCF1(vPositionFromLight{X},vDepthMetric{X},shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#elif defined(SHADOWMEDIUMQUALITY{X})\\nshadow=computeShadowWithPCF3(vPositionFromLight{X},vDepthMetric{X},shadowSampler{X},light{X}.shadowsInfo.yz,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#else\\nshadow=computeShadowWithPCF5(vPositionFromLight{X},vDepthMetric{X},shadowSampler{X},light{X}.shadowsInfo.yz,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#endif\\n#elif defined(SHADOWPCSS{X})\\n#if defined(SHADOWLOWQUALITY{X})\\nshadow=computeShadowWithPCSS16(vPositionFromLight{X},vDepthMetric{X},depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#elif defined(SHADOWMEDIUMQUALITY{X})\\nshadow=computeShadowWithPCSS32(vPositionFromLight{X},vDepthMetric{X},depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#else\\nshadow=computeShadowWithPCSS64(vPositionFromLight{X},vDepthMetric{X},depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#endif\\n#else\\n#if defined(SHADOWCUBE{X})\\nshadow=computeShadowCube(light{X}.vLightData.xyz,shadowSampler{X},light{X}.shadowsInfo.x,light{X}.depthValues);\\n#else\\nshadow=computeShadow(vPositionFromLight{X},vDepthMetric{X},shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#endif\\n#endif\\n#ifdef SHADOWONLY\\n#ifndef SHADOWINUSE\\n#define SHADOWINUSE\\n#endif\\nglobalShadow+=shadow;\\nshadowLightCount+=1.0;\\n#endif\\n#else\\nshadow=1.;\\n#endif\\n#ifndef SHADOWONLY\\n#ifdef CUSTOMUSERLIGHTING\\ndiffuseBase+=computeCustomDiffuseLighting(info,diffuseBase,shadow);\\n#ifdef SPECULARTERM\\nspecularBase+=computeCustomSpecularLighting(info,specularBase,shadow);\\n#endif\\n#elif defined(LIGHTMAP) && defined(LIGHTMAPEXCLUDED{X})\\ndiffuseBase+=lightmapColor.rgb*shadow;\\n#ifdef SPECULARTERM\\n#ifndef LIGHTMAPNOSPECULAR{X}\\nspecularBase+=info.specular*shadow*lightmapColor.rgb;\\n#endif\\n#endif\\n#ifdef CLEARCOAT\\n#ifndef LIGHTMAPNOSPECULAR{X}\\nclearCoatBase+=info.clearCoat.rgb*shadow*lightmapColor.rgb;\\n#endif\\n#endif\\n#ifdef SHEEN\\n#ifndef LIGHTMAPNOSPECULAR{X}\\nsheenBase+=info.sheen.rgb*shadow;\\n#endif\\n#endif\\n#else\\n#ifdef SHADOWCSMDEBUG{X}\\ndiffuseBase+=info.diffuse*shadowDebug{X};\\n#else\\ndiffuseBase+=info.diffuse*shadow;\\n#endif\\n#ifdef SPECULARTERM\\nspecularBase+=info.specular*shadow;\\n#endif\\n#ifdef CLEARCOAT\\nclearCoatBase+=info.clearCoat.rgb*shadow;\\n#endif\\n#ifdef SHEEN\\nsheenBase+=info.sheen.rgb*shadow;\\n#endif\\n#endif\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var lightFragment = { name: name, shader: shader };\r\n//# sourceMappingURL=lightFragment.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'logDepthFragment';\r\nvar shader = \"#ifdef LOGARITHMICDEPTH\\ngl_FragDepthEXT=log2(vFragmentDepth)*logarithmicDepthConstant*0.5;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var logDepthFragment = { name: name, shader: shader };\r\n//# sourceMappingURL=logDepthFragment.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'fogFragment';\r\nvar shader = \"#ifdef FOG\\nfloat fog=CalcFogFactor();\\ncolor.rgb=fog*color.rgb+(1.0-fog)*vFogColor;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var fogFragment = { name: name, shader: shader };\r\n//# sourceMappingURL=fogFragment.js.map","import { Effect } from \"../Materials/effect\";\r\nimport \"./ShadersInclude/defaultFragmentDeclaration\";\r\nimport \"./ShadersInclude/defaultUboDeclaration\";\r\nimport \"./ShadersInclude/helperFunctions\";\r\nimport \"./ShadersInclude/lightFragmentDeclaration\";\r\nimport \"./ShadersInclude/lightUboDeclaration\";\r\nimport \"./ShadersInclude/lightsFragmentFunctions\";\r\nimport \"./ShadersInclude/shadowsFragmentFunctions\";\r\nimport \"./ShadersInclude/fresnelFunction\";\r\nimport \"./ShadersInclude/reflectionFunction\";\r\nimport \"./ShadersInclude/imageProcessingDeclaration\";\r\nimport \"./ShadersInclude/imageProcessingFunctions\";\r\nimport \"./ShadersInclude/bumpFragmentFunctions\";\r\nimport \"./ShadersInclude/clipPlaneFragmentDeclaration\";\r\nimport \"./ShadersInclude/logDepthDeclaration\";\r\nimport \"./ShadersInclude/fogFragmentDeclaration\";\r\nimport \"./ShadersInclude/clipPlaneFragment\";\r\nimport \"./ShadersInclude/bumpFragment\";\r\nimport \"./ShadersInclude/depthPrePass\";\r\nimport \"./ShadersInclude/lightFragment\";\r\nimport \"./ShadersInclude/logDepthFragment\";\r\nimport \"./ShadersInclude/fogFragment\";\r\nvar name = 'defaultPixelShader';\r\nvar shader = \"#include<__decl__defaultFragment>\\n#if defined(BUMP) || !defined(NORMAL)\\n#extension GL_OES_standard_derivatives : enable\\n#endif\\n#define CUSTOM_FRAGMENT_BEGIN\\n#ifdef LOGARITHMICDEPTH\\n#extension GL_EXT_frag_depth : enable\\n#endif\\n\\n#define RECIPROCAL_PI2 0.15915494\\nuniform vec3 vEyePosition;\\nuniform vec3 vAmbientColor;\\n\\nvarying vec3 vPositionW;\\n#ifdef NORMAL\\nvarying vec3 vNormalW;\\n#endif\\n#ifdef VERTEXCOLOR\\nvarying vec4 vColor;\\n#endif\\n#ifdef MAINUV1\\nvarying vec2 vMainUV1;\\n#endif\\n#ifdef MAINUV2\\nvarying vec2 vMainUV2;\\n#endif\\n\\n#include\\n\\n#include<__decl__lightFragment>[0..maxSimultaneousLights]\\n#include\\n#include\\n\\n#ifdef DIFFUSE\\n#if DIFFUSEDIRECTUV == 1\\n#define vDiffuseUV vMainUV1\\n#elif DIFFUSEDIRECTUV == 2\\n#define vDiffuseUV vMainUV2\\n#else\\nvarying vec2 vDiffuseUV;\\n#endif\\nuniform sampler2D diffuseSampler;\\n#endif\\n#ifdef AMBIENT\\n#if AMBIENTDIRECTUV == 1\\n#define vAmbientUV vMainUV1\\n#elif AMBIENTDIRECTUV == 2\\n#define vAmbientUV vMainUV2\\n#else\\nvarying vec2 vAmbientUV;\\n#endif\\nuniform sampler2D ambientSampler;\\n#endif\\n#ifdef OPACITY\\n#if OPACITYDIRECTUV == 1\\n#define vOpacityUV vMainUV1\\n#elif OPACITYDIRECTUV == 2\\n#define vOpacityUV vMainUV2\\n#else\\nvarying vec2 vOpacityUV;\\n#endif\\nuniform sampler2D opacitySampler;\\n#endif\\n#ifdef EMISSIVE\\n#if EMISSIVEDIRECTUV == 1\\n#define vEmissiveUV vMainUV1\\n#elif EMISSIVEDIRECTUV == 2\\n#define vEmissiveUV vMainUV2\\n#else\\nvarying vec2 vEmissiveUV;\\n#endif\\nuniform sampler2D emissiveSampler;\\n#endif\\n#ifdef LIGHTMAP\\n#if LIGHTMAPDIRECTUV == 1\\n#define vLightmapUV vMainUV1\\n#elif LIGHTMAPDIRECTUV == 2\\n#define vLightmapUV vMainUV2\\n#else\\nvarying vec2 vLightmapUV;\\n#endif\\nuniform sampler2D lightmapSampler;\\n#endif\\n#ifdef REFRACTION\\n#ifdef REFRACTIONMAP_3D\\nuniform samplerCube refractionCubeSampler;\\n#else\\nuniform sampler2D refraction2DSampler;\\n#endif\\n#endif\\n#if defined(SPECULAR) && defined(SPECULARTERM)\\n#if SPECULARDIRECTUV == 1\\n#define vSpecularUV vMainUV1\\n#elif SPECULARDIRECTUV == 2\\n#define vSpecularUV vMainUV2\\n#else\\nvarying vec2 vSpecularUV;\\n#endif\\nuniform sampler2D specularSampler;\\n#endif\\n#ifdef ALPHATEST\\nuniform float alphaCutOff;\\n#endif\\n\\n#include\\n\\n#ifdef REFLECTION\\n#ifdef REFLECTIONMAP_3D\\nuniform samplerCube reflectionCubeSampler;\\n#else\\nuniform sampler2D reflection2DSampler;\\n#endif\\n#ifdef REFLECTIONMAP_SKYBOX\\nvarying vec3 vPositionUVW;\\n#else\\n#if defined(REFLECTIONMAP_EQUIRECTANGULAR_FIXED) || defined(REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED)\\nvarying vec3 vDirectionW;\\n#endif\\n#endif\\n#include\\n#endif\\n#include\\n#include\\n#include\\n#include\\n#include\\n#include\\n#define CUSTOM_FRAGMENT_DEFINITIONS\\nvoid main(void) {\\n#define CUSTOM_FRAGMENT_MAIN_BEGIN\\n#include\\nvec3 viewDirectionW=normalize(vEyePosition-vPositionW);\\n\\nvec4 baseColor=vec4(1.,1.,1.,1.);\\nvec3 diffuseColor=vDiffuseColor.rgb;\\n\\nfloat alpha=vDiffuseColor.a;\\n\\n#ifdef NORMAL\\nvec3 normalW=normalize(vNormalW);\\n#else\\nvec3 normalW=normalize(-cross(dFdx(vPositionW),dFdy(vPositionW)));\\n#endif\\n#include\\n#ifdef TWOSIDEDLIGHTING\\nnormalW=gl_FrontFacing ? normalW : -normalW;\\n#endif\\n#ifdef DIFFUSE\\nbaseColor=texture2D(diffuseSampler,vDiffuseUV+uvOffset);\\n#ifdef ALPHATEST\\nif (baseColor.a\\n#ifdef VERTEXCOLOR\\nbaseColor.rgb*=vColor.rgb;\\n#endif\\n#define CUSTOM_FRAGMENT_UPDATE_DIFFUSE\\n\\nvec3 baseAmbientColor=vec3(1.,1.,1.);\\n#ifdef AMBIENT\\nbaseAmbientColor=texture2D(ambientSampler,vAmbientUV+uvOffset).rgb*vAmbientInfos.y;\\n#endif\\n#define CUSTOM_FRAGMENT_BEFORE_LIGHTS\\n\\n#ifdef SPECULARTERM\\nfloat glossiness=vSpecularColor.a;\\nvec3 specularColor=vSpecularColor.rgb;\\n#ifdef SPECULAR\\nvec4 specularMapColor=texture2D(specularSampler,vSpecularUV+uvOffset);\\nspecularColor=specularMapColor.rgb;\\n#ifdef GLOSSINESS\\nglossiness=glossiness*specularMapColor.a;\\n#endif\\n#endif\\n#else\\nfloat glossiness=0.;\\n#endif\\n\\nvec3 diffuseBase=vec3(0.,0.,0.);\\nlightingInfo info;\\n#ifdef SPECULARTERM\\nvec3 specularBase=vec3(0.,0.,0.);\\n#endif\\nfloat shadow=1.;\\n#ifdef LIGHTMAP\\nvec3 lightmapColor=texture2D(lightmapSampler,vLightmapUV+uvOffset).rgb*vLightmapInfos.y;\\n#endif\\n#include[0..maxSimultaneousLights]\\n\\nvec3 refractionColor=vec3(0.,0.,0.);\\n#ifdef REFRACTION\\nvec3 refractionVector=normalize(refract(-viewDirectionW,normalW,vRefractionInfos.y));\\n#ifdef REFRACTIONMAP_3D\\nrefractionVector.y=refractionVector.y*vRefractionInfos.w;\\nif (dot(refractionVector,viewDirectionW)<1.0) {\\nrefractionColor=textureCube(refractionCubeSampler,refractionVector).rgb;\\n}\\n#else\\nvec3 vRefractionUVW=vec3(refractionMatrix*(view*vec4(vPositionW+refractionVector*vRefractionInfos.z,1.0)));\\nvec2 refractionCoords=vRefractionUVW.xy/vRefractionUVW.z;\\nrefractionCoords.y=1.0-refractionCoords.y;\\nrefractionColor=texture2D(refraction2DSampler,refractionCoords).rgb;\\n#endif\\n#ifdef IS_REFRACTION_LINEAR\\nrefractionColor=toGammaSpace(refractionColor);\\n#endif\\nrefractionColor*=vRefractionInfos.x;\\n#endif\\n\\nvec3 reflectionColor=vec3(0.,0.,0.);\\n#ifdef REFLECTION\\nvec3 vReflectionUVW=computeReflectionCoords(vec4(vPositionW,1.0),normalW);\\n#ifdef REFLECTIONMAP_3D\\n#ifdef ROUGHNESS\\nfloat bias=vReflectionInfos.y;\\n#ifdef SPECULARTERM\\n#ifdef SPECULAR\\n#ifdef GLOSSINESS\\nbias*=(1.0-specularMapColor.a);\\n#endif\\n#endif\\n#endif\\nreflectionColor=textureCube(reflectionCubeSampler,vReflectionUVW,bias).rgb;\\n#else\\nreflectionColor=textureCube(reflectionCubeSampler,vReflectionUVW).rgb;\\n#endif\\n#else\\nvec2 coords=vReflectionUVW.xy;\\n#ifdef REFLECTIONMAP_PROJECTION\\ncoords/=vReflectionUVW.z;\\n#endif\\ncoords.y=1.0-coords.y;\\nreflectionColor=texture2D(reflection2DSampler,coords).rgb;\\n#endif\\n#ifdef IS_REFLECTION_LINEAR\\nreflectionColor=toGammaSpace(reflectionColor);\\n#endif\\nreflectionColor*=vReflectionInfos.x;\\n#ifdef REFLECTIONFRESNEL\\nfloat reflectionFresnelTerm=computeFresnelTerm(viewDirectionW,normalW,reflectionRightColor.a,reflectionLeftColor.a);\\n#ifdef REFLECTIONFRESNELFROMSPECULAR\\n#ifdef SPECULARTERM\\nreflectionColor*=specularColor.rgb*(1.0-reflectionFresnelTerm)+reflectionFresnelTerm*reflectionRightColor.rgb;\\n#else\\nreflectionColor*=reflectionLeftColor.rgb*(1.0-reflectionFresnelTerm)+reflectionFresnelTerm*reflectionRightColor.rgb;\\n#endif\\n#else\\nreflectionColor*=reflectionLeftColor.rgb*(1.0-reflectionFresnelTerm)+reflectionFresnelTerm*reflectionRightColor.rgb;\\n#endif\\n#endif\\n#endif\\n#ifdef REFRACTIONFRESNEL\\nfloat refractionFresnelTerm=computeFresnelTerm(viewDirectionW,normalW,refractionRightColor.a,refractionLeftColor.a);\\nrefractionColor*=refractionLeftColor.rgb*(1.0-refractionFresnelTerm)+refractionFresnelTerm*refractionRightColor.rgb;\\n#endif\\n#ifdef OPACITY\\nvec4 opacityMap=texture2D(opacitySampler,vOpacityUV+uvOffset);\\n#ifdef OPACITYRGB\\nopacityMap.rgb=opacityMap.rgb*vec3(0.3,0.59,0.11);\\nalpha*=(opacityMap.x+opacityMap.y+opacityMap.z)* vOpacityInfos.y;\\n#else\\nalpha*=opacityMap.a*vOpacityInfos.y;\\n#endif\\n#endif\\n#ifdef VERTEXALPHA\\nalpha*=vColor.a;\\n#endif\\n#ifdef OPACITYFRESNEL\\nfloat opacityFresnelTerm=computeFresnelTerm(viewDirectionW,normalW,opacityParts.z,opacityParts.w);\\nalpha+=opacityParts.x*(1.0-opacityFresnelTerm)+opacityFresnelTerm*opacityParts.y;\\n#endif\\n\\nvec3 emissiveColor=vEmissiveColor;\\n#ifdef EMISSIVE\\nemissiveColor+=texture2D(emissiveSampler,vEmissiveUV+uvOffset).rgb*vEmissiveInfos.y;\\n#endif\\n#ifdef EMISSIVEFRESNEL\\nfloat emissiveFresnelTerm=computeFresnelTerm(viewDirectionW,normalW,emissiveRightColor.a,emissiveLeftColor.a);\\nemissiveColor*=emissiveLeftColor.rgb*(1.0-emissiveFresnelTerm)+emissiveFresnelTerm*emissiveRightColor.rgb;\\n#endif\\n\\n#ifdef DIFFUSEFRESNEL\\nfloat diffuseFresnelTerm=computeFresnelTerm(viewDirectionW,normalW,diffuseRightColor.a,diffuseLeftColor.a);\\ndiffuseBase*=diffuseLeftColor.rgb*(1.0-diffuseFresnelTerm)+diffuseFresnelTerm*diffuseRightColor.rgb;\\n#endif\\n\\n#ifdef EMISSIVEASILLUMINATION\\nvec3 finalDiffuse=clamp(diffuseBase*diffuseColor+vAmbientColor,0.0,1.0)*baseColor.rgb;\\n#else\\n#ifdef LINKEMISSIVEWITHDIFFUSE\\nvec3 finalDiffuse=clamp((diffuseBase+emissiveColor)*diffuseColor+vAmbientColor,0.0,1.0)*baseColor.rgb;\\n#else\\nvec3 finalDiffuse=clamp(diffuseBase*diffuseColor+emissiveColor+vAmbientColor,0.0,1.0)*baseColor.rgb;\\n#endif\\n#endif\\n#ifdef SPECULARTERM\\nvec3 finalSpecular=specularBase*specularColor;\\n#ifdef SPECULAROVERALPHA\\nalpha=clamp(alpha+dot(finalSpecular,vec3(0.3,0.59,0.11)),0.,1.);\\n#endif\\n#else\\nvec3 finalSpecular=vec3(0.0);\\n#endif\\n#ifdef REFLECTIONOVERALPHA\\nalpha=clamp(alpha+dot(reflectionColor,vec3(0.3,0.59,0.11)),0.,1.);\\n#endif\\n\\n#ifdef EMISSIVEASILLUMINATION\\nvec4 color=vec4(clamp(finalDiffuse*baseAmbientColor+finalSpecular+reflectionColor+emissiveColor+refractionColor,0.0,1.0),alpha);\\n#else\\nvec4 color=vec4(finalDiffuse*baseAmbientColor+finalSpecular+reflectionColor+refractionColor,alpha);\\n#endif\\n\\n#ifdef LIGHTMAP\\n#ifndef LIGHTMAPEXCLUDED\\n#ifdef USELIGHTMAPASSHADOWMAP\\ncolor.rgb*=lightmapColor;\\n#else\\ncolor.rgb+=lightmapColor;\\n#endif\\n#endif\\n#endif\\n#define CUSTOM_FRAGMENT_BEFORE_FOG\\ncolor.rgb=max(color.rgb,0.);\\n#include\\n#include\\n\\n\\n#ifdef IMAGEPROCESSINGPOSTPROCESS\\ncolor.rgb=toLinearSpace(color.rgb);\\n#else\\n#ifdef IMAGEPROCESSING\\ncolor.rgb=toLinearSpace(color.rgb);\\ncolor=applyImageProcessing(color);\\n#endif\\n#endif\\ncolor.a*=visibility;\\n#ifdef PREMULTIPLYALPHA\\n\\ncolor.rgb*=color.a;\\n#endif\\n#define CUSTOM_FRAGMENT_BEFORE_FRAGCOLOR\\ngl_FragColor=color;\\n}\\n\";\r\nEffect.ShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var defaultPixelShader = { name: name, shader: shader };\r\n//# sourceMappingURL=default.fragment.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'defaultVertexDeclaration';\r\nvar shader = \"\\nuniform mat4 viewProjection;\\nuniform mat4 view;\\n#ifdef DIFFUSE\\nuniform mat4 diffuseMatrix;\\nuniform vec2 vDiffuseInfos;\\n#endif\\n#ifdef AMBIENT\\nuniform mat4 ambientMatrix;\\nuniform vec2 vAmbientInfos;\\n#endif\\n#ifdef OPACITY\\nuniform mat4 opacityMatrix;\\nuniform vec2 vOpacityInfos;\\n#endif\\n#ifdef EMISSIVE\\nuniform vec2 vEmissiveInfos;\\nuniform mat4 emissiveMatrix;\\n#endif\\n#ifdef LIGHTMAP\\nuniform vec2 vLightmapInfos;\\nuniform mat4 lightmapMatrix;\\n#endif\\n#if defined(SPECULAR) && defined(SPECULARTERM)\\nuniform vec2 vSpecularInfos;\\nuniform mat4 specularMatrix;\\n#endif\\n#ifdef BUMP\\nuniform vec3 vBumpInfos;\\nuniform mat4 bumpMatrix;\\n#endif\\n#ifdef REFLECTION\\nuniform mat4 reflectionMatrix;\\n#endif\\n#ifdef POINTSIZE\\nuniform float pointSize;\\n#endif\\n\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var defaultVertexDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=defaultVertexDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'bumpVertexDeclaration';\r\nvar shader = \"#if defined(BUMP) || defined(PARALLAX) || defined(CLEARCOAT_BUMP)\\n#if defined(TANGENT) && defined(NORMAL)\\nvarying mat3 vTBN;\\n#endif\\n#endif\\n\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var bumpVertexDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=bumpVertexDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'fogVertexDeclaration';\r\nvar shader = \"#ifdef FOG\\nvarying vec3 vFogDistance;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var fogVertexDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=fogVertexDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'morphTargetsVertexGlobalDeclaration';\r\nvar shader = \"#ifdef MORPHTARGETS\\nuniform float morphTargetInfluences[NUM_MORPH_INFLUENCERS];\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var morphTargetsVertexGlobalDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=morphTargetsVertexGlobalDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'morphTargetsVertexDeclaration';\r\nvar shader = \"#ifdef MORPHTARGETS\\nattribute vec3 position{X};\\n#ifdef MORPHTARGETS_NORMAL\\nattribute vec3 normal{X};\\n#endif\\n#ifdef MORPHTARGETS_TANGENT\\nattribute vec3 tangent{X};\\n#endif\\n#ifdef MORPHTARGETS_UV\\nattribute vec2 uv_{X};\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var morphTargetsVertexDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=morphTargetsVertexDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'morphTargetsVertex';\r\nvar shader = \"#ifdef MORPHTARGETS\\npositionUpdated+=(position{X}-position)*morphTargetInfluences[{X}];\\n#ifdef MORPHTARGETS_NORMAL\\nnormalUpdated+=(normal{X}-normal)*morphTargetInfluences[{X}];\\n#endif\\n#ifdef MORPHTARGETS_TANGENT\\ntangentUpdated.xyz+=(tangent{X}-tangent.xyz)*morphTargetInfluences[{X}];\\n#endif\\n#ifdef MORPHTARGETS_UV\\nuvUpdated+=(uv_{X}-uv)*morphTargetInfluences[{X}];\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var morphTargetsVertex = { name: name, shader: shader };\r\n//# sourceMappingURL=morphTargetsVertex.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'bumpVertex';\r\nvar shader = \"#if defined(BUMP) || defined(PARALLAX) || defined(CLEARCOAT_BUMP)\\n#if defined(TANGENT) && defined(NORMAL)\\nvec3 tbnNormal=normalize(normalUpdated);\\nvec3 tbnTangent=normalize(tangentUpdated.xyz);\\nvec3 tbnBitangent=cross(tbnNormal,tbnTangent)*tangentUpdated.w;\\nvTBN=mat3(finalWorld)*mat3(tbnTangent,tbnBitangent,tbnNormal);\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var bumpVertex = { name: name, shader: shader };\r\n//# sourceMappingURL=bumpVertex.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'fogVertex';\r\nvar shader = \"#ifdef FOG\\nvFogDistance=(view*worldPos).xyz;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var fogVertex = { name: name, shader: shader };\r\n//# sourceMappingURL=fogVertex.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'shadowsVertex';\r\nvar shader = \"#ifdef SHADOWS\\n#if defined(SHADOWCSM{X})\\nvPositionFromCamera{X}=view*worldPos;\\nfor (int i=0; i\\n\\n#define CUSTOM_VERTEX_BEGIN\\nattribute vec3 position;\\n#ifdef NORMAL\\nattribute vec3 normal;\\n#endif\\n#ifdef TANGENT\\nattribute vec4 tangent;\\n#endif\\n#ifdef UV1\\nattribute vec2 uv;\\n#endif\\n#ifdef UV2\\nattribute vec2 uv2;\\n#endif\\n#ifdef VERTEXCOLOR\\nattribute vec4 color;\\n#endif\\n#include\\n#include\\n\\n#include\\n#ifdef MAINUV1\\nvarying vec2 vMainUV1;\\n#endif\\n#ifdef MAINUV2\\nvarying vec2 vMainUV2;\\n#endif\\n#if defined(DIFFUSE) && DIFFUSEDIRECTUV == 0\\nvarying vec2 vDiffuseUV;\\n#endif\\n#if defined(AMBIENT) && AMBIENTDIRECTUV == 0\\nvarying vec2 vAmbientUV;\\n#endif\\n#if defined(OPACITY) && OPACITYDIRECTUV == 0\\nvarying vec2 vOpacityUV;\\n#endif\\n#if defined(EMISSIVE) && EMISSIVEDIRECTUV == 0\\nvarying vec2 vEmissiveUV;\\n#endif\\n#if defined(LIGHTMAP) && LIGHTMAPDIRECTUV == 0\\nvarying vec2 vLightmapUV;\\n#endif\\n#if defined(SPECULAR) && defined(SPECULARTERM) && SPECULARDIRECTUV == 0\\nvarying vec2 vSpecularUV;\\n#endif\\n#if defined(BUMP) && BUMPDIRECTUV == 0\\nvarying vec2 vBumpUV;\\n#endif\\n\\nvarying vec3 vPositionW;\\n#ifdef NORMAL\\nvarying vec3 vNormalW;\\n#endif\\n#ifdef VERTEXCOLOR\\nvarying vec4 vColor;\\n#endif\\n#include\\n#include\\n#include\\n#include<__decl__lightFragment>[0..maxSimultaneousLights]\\n#include\\n#include[0..maxSimultaneousMorphTargets]\\n#ifdef REFLECTIONMAP_SKYBOX\\nvarying vec3 vPositionUVW;\\n#endif\\n#if defined(REFLECTIONMAP_EQUIRECTANGULAR_FIXED) || defined(REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED)\\nvarying vec3 vDirectionW;\\n#endif\\n#include\\n#define CUSTOM_VERTEX_DEFINITIONS\\nvoid main(void) {\\n#define CUSTOM_VERTEX_MAIN_BEGIN\\nvec3 positionUpdated=position;\\n#ifdef NORMAL\\nvec3 normalUpdated=normal;\\n#endif\\n#ifdef TANGENT\\nvec4 tangentUpdated=tangent;\\n#endif\\n#ifdef UV1\\nvec2 uvUpdated=uv;\\n#endif\\n#include[0..maxSimultaneousMorphTargets]\\n#ifdef REFLECTIONMAP_SKYBOX\\nvPositionUVW=positionUpdated;\\n#endif\\n#define CUSTOM_VERTEX_UPDATE_POSITION\\n#define CUSTOM_VERTEX_UPDATE_NORMAL\\n#include\\n#include\\nvec4 worldPos=finalWorld*vec4(positionUpdated,1.0);\\n#ifdef MULTIVIEW\\nif (gl_ViewID_OVR == 0u) {\\ngl_Position=viewProjection*worldPos;\\n} else {\\ngl_Position=viewProjectionR*worldPos;\\n}\\n#else\\ngl_Position=viewProjection*worldPos;\\n#endif\\nvPositionW=vec3(worldPos);\\n#ifdef NORMAL\\nmat3 normalWorld=mat3(finalWorld);\\n#ifdef NONUNIFORMSCALING\\nnormalWorld=transposeMat3(inverseMat3(normalWorld));\\n#endif\\nvNormalW=normalize(normalWorld*normalUpdated);\\n#endif\\n#if defined(REFLECTIONMAP_EQUIRECTANGULAR_FIXED) || defined(REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED)\\nvDirectionW=normalize(vec3(finalWorld*vec4(positionUpdated,0.0)));\\n#endif\\n\\n#ifndef UV1\\nvec2 uvUpdated=vec2(0.,0.);\\n#endif\\n#ifndef UV2\\nvec2 uv2=vec2(0.,0.);\\n#endif\\n#ifdef MAINUV1\\nvMainUV1=uvUpdated;\\n#endif\\n#ifdef MAINUV2\\nvMainUV2=uv2;\\n#endif\\n#if defined(DIFFUSE) && DIFFUSEDIRECTUV == 0\\nif (vDiffuseInfos.x == 0.)\\n{\\nvDiffuseUV=vec2(diffuseMatrix*vec4(uvUpdated,1.0,0.0));\\n}\\nelse\\n{\\nvDiffuseUV=vec2(diffuseMatrix*vec4(uv2,1.0,0.0));\\n}\\n#endif\\n#if defined(AMBIENT) && AMBIENTDIRECTUV == 0\\nif (vAmbientInfos.x == 0.)\\n{\\nvAmbientUV=vec2(ambientMatrix*vec4(uvUpdated,1.0,0.0));\\n}\\nelse\\n{\\nvAmbientUV=vec2(ambientMatrix*vec4(uv2,1.0,0.0));\\n}\\n#endif\\n#if defined(OPACITY) && OPACITYDIRECTUV == 0\\nif (vOpacityInfos.x == 0.)\\n{\\nvOpacityUV=vec2(opacityMatrix*vec4(uvUpdated,1.0,0.0));\\n}\\nelse\\n{\\nvOpacityUV=vec2(opacityMatrix*vec4(uv2,1.0,0.0));\\n}\\n#endif\\n#if defined(EMISSIVE) && EMISSIVEDIRECTUV == 0\\nif (vEmissiveInfos.x == 0.)\\n{\\nvEmissiveUV=vec2(emissiveMatrix*vec4(uvUpdated,1.0,0.0));\\n}\\nelse\\n{\\nvEmissiveUV=vec2(emissiveMatrix*vec4(uv2,1.0,0.0));\\n}\\n#endif\\n#if defined(LIGHTMAP) && LIGHTMAPDIRECTUV == 0\\nif (vLightmapInfos.x == 0.)\\n{\\nvLightmapUV=vec2(lightmapMatrix*vec4(uvUpdated,1.0,0.0));\\n}\\nelse\\n{\\nvLightmapUV=vec2(lightmapMatrix*vec4(uv2,1.0,0.0));\\n}\\n#endif\\n#if defined(SPECULAR) && defined(SPECULARTERM) && SPECULARDIRECTUV == 0\\nif (vSpecularInfos.x == 0.)\\n{\\nvSpecularUV=vec2(specularMatrix*vec4(uvUpdated,1.0,0.0));\\n}\\nelse\\n{\\nvSpecularUV=vec2(specularMatrix*vec4(uv2,1.0,0.0));\\n}\\n#endif\\n#if defined(BUMP) && BUMPDIRECTUV == 0\\nif (vBumpInfos.x == 0.)\\n{\\nvBumpUV=vec2(bumpMatrix*vec4(uvUpdated,1.0,0.0));\\n}\\nelse\\n{\\nvBumpUV=vec2(bumpMatrix*vec4(uv2,1.0,0.0));\\n}\\n#endif\\n#include\\n#include\\n#include\\n#include[0..maxSimultaneousLights]\\n#ifdef VERTEXCOLOR\\n\\nvColor=color;\\n#endif\\n#include\\n#include\\n#define CUSTOM_VERTEX_MAIN_END\\n}\\n\";\r\nEffect.ShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var defaultVertexShader = { name: name, shader: shader };\r\n//# sourceMappingURL=default.vertex.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, SerializationHelper, serializeAsColor3, expandToProperty, serializeAsFresnelParameters, serializeAsTexture } from \"../Misc/decorators\";\r\nimport { SmartArray } from \"../Misc/smartArray\";\r\nimport { Scene } from \"../scene\";\r\nimport { Matrix } from \"../Maths/math.vector\";\r\nimport { Color3 } from '../Maths/math.color';\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { ImageProcessingConfiguration } from \"./imageProcessingConfiguration\";\r\nimport { MaterialDefines } from \"../Materials/materialDefines\";\r\nimport { PushMaterial } from \"./pushMaterial\";\r\nimport { MaterialHelper } from \"./materialHelper\";\r\nimport { Texture } from \"../Materials/Textures/texture\";\r\nimport { _TypeStore } from \"../Misc/typeStore\";\r\nimport { MaterialFlags } from \"./materialFlags\";\r\nimport \"../Shaders/default.fragment\";\r\nimport \"../Shaders/default.vertex\";\r\nimport { EffectFallbacks } from './effectFallbacks';\r\n/** @hidden */\r\nvar StandardMaterialDefines = /** @class */ (function (_super) {\r\n __extends(StandardMaterialDefines, _super);\r\n function StandardMaterialDefines() {\r\n var _this = _super.call(this) || this;\r\n _this.MAINUV1 = false;\r\n _this.MAINUV2 = false;\r\n _this.DIFFUSE = false;\r\n _this.DIFFUSEDIRECTUV = 0;\r\n _this.AMBIENT = false;\r\n _this.AMBIENTDIRECTUV = 0;\r\n _this.OPACITY = false;\r\n _this.OPACITYDIRECTUV = 0;\r\n _this.OPACITYRGB = false;\r\n _this.REFLECTION = false;\r\n _this.EMISSIVE = false;\r\n _this.EMISSIVEDIRECTUV = 0;\r\n _this.SPECULAR = false;\r\n _this.SPECULARDIRECTUV = 0;\r\n _this.BUMP = false;\r\n _this.BUMPDIRECTUV = 0;\r\n _this.PARALLAX = false;\r\n _this.PARALLAXOCCLUSION = false;\r\n _this.SPECULAROVERALPHA = false;\r\n _this.CLIPPLANE = false;\r\n _this.CLIPPLANE2 = false;\r\n _this.CLIPPLANE3 = false;\r\n _this.CLIPPLANE4 = false;\r\n _this.CLIPPLANE5 = false;\r\n _this.CLIPPLANE6 = false;\r\n _this.ALPHATEST = false;\r\n _this.DEPTHPREPASS = false;\r\n _this.ALPHAFROMDIFFUSE = false;\r\n _this.POINTSIZE = false;\r\n _this.FOG = false;\r\n _this.SPECULARTERM = false;\r\n _this.DIFFUSEFRESNEL = false;\r\n _this.OPACITYFRESNEL = false;\r\n _this.REFLECTIONFRESNEL = false;\r\n _this.REFRACTIONFRESNEL = false;\r\n _this.EMISSIVEFRESNEL = false;\r\n _this.FRESNEL = false;\r\n _this.NORMAL = false;\r\n _this.UV1 = false;\r\n _this.UV2 = false;\r\n _this.VERTEXCOLOR = false;\r\n _this.VERTEXALPHA = false;\r\n _this.NUM_BONE_INFLUENCERS = 0;\r\n _this.BonesPerMesh = 0;\r\n _this.BONETEXTURE = false;\r\n _this.INSTANCES = false;\r\n _this.GLOSSINESS = false;\r\n _this.ROUGHNESS = false;\r\n _this.EMISSIVEASILLUMINATION = false;\r\n _this.LINKEMISSIVEWITHDIFFUSE = false;\r\n _this.REFLECTIONFRESNELFROMSPECULAR = false;\r\n _this.LIGHTMAP = false;\r\n _this.LIGHTMAPDIRECTUV = 0;\r\n _this.OBJECTSPACE_NORMALMAP = false;\r\n _this.USELIGHTMAPASSHADOWMAP = false;\r\n _this.REFLECTIONMAP_3D = false;\r\n _this.REFLECTIONMAP_SPHERICAL = false;\r\n _this.REFLECTIONMAP_PLANAR = false;\r\n _this.REFLECTIONMAP_CUBIC = false;\r\n _this.USE_LOCAL_REFLECTIONMAP_CUBIC = false;\r\n _this.REFLECTIONMAP_PROJECTION = false;\r\n _this.REFLECTIONMAP_SKYBOX = false;\r\n _this.REFLECTIONMAP_EXPLICIT = false;\r\n _this.REFLECTIONMAP_EQUIRECTANGULAR = false;\r\n _this.REFLECTIONMAP_EQUIRECTANGULAR_FIXED = false;\r\n _this.REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED = false;\r\n _this.INVERTCUBICMAP = false;\r\n _this.LOGARITHMICDEPTH = false;\r\n _this.REFRACTION = false;\r\n _this.REFRACTIONMAP_3D = false;\r\n _this.REFLECTIONOVERALPHA = false;\r\n _this.TWOSIDEDLIGHTING = false;\r\n _this.SHADOWFLOAT = false;\r\n _this.MORPHTARGETS = false;\r\n _this.MORPHTARGETS_NORMAL = false;\r\n _this.MORPHTARGETS_TANGENT = false;\r\n _this.MORPHTARGETS_UV = false;\r\n _this.NUM_MORPH_INFLUENCERS = 0;\r\n _this.NONUNIFORMSCALING = false; // https://playground.babylonjs.com#V6DWIH\r\n _this.PREMULTIPLYALPHA = false; // https://playground.babylonjs.com#LNVJJ7\r\n _this.IMAGEPROCESSING = false;\r\n _this.VIGNETTE = false;\r\n _this.VIGNETTEBLENDMODEMULTIPLY = false;\r\n _this.VIGNETTEBLENDMODEOPAQUE = false;\r\n _this.TONEMAPPING = false;\r\n _this.TONEMAPPING_ACES = false;\r\n _this.CONTRAST = false;\r\n _this.COLORCURVES = false;\r\n _this.COLORGRADING = false;\r\n _this.COLORGRADING3D = false;\r\n _this.SAMPLER3DGREENDEPTH = false;\r\n _this.SAMPLER3DBGRMAP = false;\r\n _this.IMAGEPROCESSINGPOSTPROCESS = false;\r\n _this.MULTIVIEW = false;\r\n /**\r\n * If the reflection texture on this material is in linear color space\r\n * @hidden\r\n */\r\n _this.IS_REFLECTION_LINEAR = false;\r\n /**\r\n * If the refraction texture on this material is in linear color space\r\n * @hidden\r\n */\r\n _this.IS_REFRACTION_LINEAR = false;\r\n _this.EXPOSURE = false;\r\n _this.rebuild();\r\n return _this;\r\n }\r\n StandardMaterialDefines.prototype.setReflectionMode = function (modeToEnable) {\r\n var modes = [\r\n \"REFLECTIONMAP_CUBIC\", \"REFLECTIONMAP_EXPLICIT\", \"REFLECTIONMAP_PLANAR\",\r\n \"REFLECTIONMAP_PROJECTION\", \"REFLECTIONMAP_PROJECTION\", \"REFLECTIONMAP_SKYBOX\",\r\n \"REFLECTIONMAP_SPHERICAL\", \"REFLECTIONMAP_EQUIRECTANGULAR\", \"REFLECTIONMAP_EQUIRECTANGULAR_FIXED\",\r\n \"REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED\"\r\n ];\r\n for (var _i = 0, modes_1 = modes; _i < modes_1.length; _i++) {\r\n var mode = modes_1[_i];\r\n this[mode] = (mode === modeToEnable);\r\n }\r\n };\r\n return StandardMaterialDefines;\r\n}(MaterialDefines));\r\nexport { StandardMaterialDefines };\r\n/**\r\n * This is the default material used in Babylon. It is the best trade off between quality\r\n * and performances.\r\n * @see http://doc.babylonjs.com/babylon101/materials\r\n */\r\nvar StandardMaterial = /** @class */ (function (_super) {\r\n __extends(StandardMaterial, _super);\r\n /**\r\n * Instantiates a new standard material.\r\n * This is the default material used in Babylon. It is the best trade off between quality\r\n * and performances.\r\n * @see http://doc.babylonjs.com/babylon101/materials\r\n * @param name Define the name of the material in the scene\r\n * @param scene Define the scene the material belong to\r\n */\r\n function StandardMaterial(name, scene) {\r\n var _this = _super.call(this, name, scene) || this;\r\n _this._diffuseTexture = null;\r\n _this._ambientTexture = null;\r\n _this._opacityTexture = null;\r\n _this._reflectionTexture = null;\r\n _this._emissiveTexture = null;\r\n _this._specularTexture = null;\r\n _this._bumpTexture = null;\r\n _this._lightmapTexture = null;\r\n _this._refractionTexture = null;\r\n /**\r\n * The color of the material lit by the environmental background lighting.\r\n * @see http://doc.babylonjs.com/babylon101/materials#ambient-color-example\r\n */\r\n _this.ambientColor = new Color3(0, 0, 0);\r\n /**\r\n * The basic color of the material as viewed under a light.\r\n */\r\n _this.diffuseColor = new Color3(1, 1, 1);\r\n /**\r\n * Define how the color and intensity of the highlight given by the light in the material.\r\n */\r\n _this.specularColor = new Color3(1, 1, 1);\r\n /**\r\n * Define the color of the material as if self lit.\r\n * This will be mixed in the final result even in the absence of light.\r\n */\r\n _this.emissiveColor = new Color3(0, 0, 0);\r\n /**\r\n * Defines how sharp are the highlights in the material.\r\n * The bigger the value the sharper giving a more glossy feeling to the result.\r\n * Reversely, the smaller the value the blurrier giving a more rough feeling to the result.\r\n */\r\n _this.specularPower = 64;\r\n _this._useAlphaFromDiffuseTexture = false;\r\n _this._useEmissiveAsIllumination = false;\r\n _this._linkEmissiveWithDiffuse = false;\r\n _this._useSpecularOverAlpha = false;\r\n _this._useReflectionOverAlpha = false;\r\n _this._disableLighting = false;\r\n _this._useObjectSpaceNormalMap = false;\r\n _this._useParallax = false;\r\n _this._useParallaxOcclusion = false;\r\n /**\r\n * Apply a scaling factor that determine which \"depth\" the height map should reprensent. A value between 0.05 and 0.1 is reasonnable in Parallax, you can reach 0.2 using Parallax Occlusion.\r\n */\r\n _this.parallaxScaleBias = 0.05;\r\n _this._roughness = 0;\r\n /**\r\n * In case of refraction, define the value of the index of refraction.\r\n * @see http://doc.babylonjs.com/how_to/reflect#how-to-obtain-reflections-and-refractions\r\n */\r\n _this.indexOfRefraction = 0.98;\r\n /**\r\n * Invert the refraction texture alongside the y axis.\r\n * It can be useful with procedural textures or probe for instance.\r\n * @see http://doc.babylonjs.com/how_to/reflect#how-to-obtain-reflections-and-refractions\r\n */\r\n _this.invertRefractionY = true;\r\n /**\r\n * Defines the alpha limits in alpha test mode.\r\n */\r\n _this.alphaCutOff = 0.4;\r\n _this._useLightmapAsShadowmap = false;\r\n _this._useReflectionFresnelFromSpecular = false;\r\n _this._useGlossinessFromSpecularMapAlpha = false;\r\n _this._maxSimultaneousLights = 4;\r\n _this._invertNormalMapX = false;\r\n _this._invertNormalMapY = false;\r\n _this._twoSidedLighting = false;\r\n _this._renderTargets = new SmartArray(16);\r\n _this._worldViewProjectionMatrix = Matrix.Zero();\r\n _this._globalAmbientColor = new Color3(0, 0, 0);\r\n _this._rebuildInParallel = false;\r\n // Setup the default processing configuration to the scene.\r\n _this._attachImageProcessingConfiguration(null);\r\n _this.getRenderTargetTextures = function () {\r\n _this._renderTargets.reset();\r\n if (StandardMaterial.ReflectionTextureEnabled && _this._reflectionTexture && _this._reflectionTexture.isRenderTarget) {\r\n _this._renderTargets.push(_this._reflectionTexture);\r\n }\r\n if (StandardMaterial.RefractionTextureEnabled && _this._refractionTexture && _this._refractionTexture.isRenderTarget) {\r\n _this._renderTargets.push(_this._refractionTexture);\r\n }\r\n return _this._renderTargets;\r\n };\r\n return _this;\r\n }\r\n Object.defineProperty(StandardMaterial.prototype, \"imageProcessingConfiguration\", {\r\n /**\r\n * Gets the image processing configuration used either in this material.\r\n */\r\n get: function () {\r\n return this._imageProcessingConfiguration;\r\n },\r\n /**\r\n * Sets the Default image processing configuration used either in the this material.\r\n *\r\n * If sets to null, the scene one is in use.\r\n */\r\n set: function (value) {\r\n this._attachImageProcessingConfiguration(value);\r\n // Ensure the effect will be rebuilt.\r\n this._markAllSubMeshesAsTexturesDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Attaches a new image processing configuration to the Standard Material.\r\n * @param configuration\r\n */\r\n StandardMaterial.prototype._attachImageProcessingConfiguration = function (configuration) {\r\n var _this = this;\r\n if (configuration === this._imageProcessingConfiguration) {\r\n return;\r\n }\r\n // Detaches observer\r\n if (this._imageProcessingConfiguration && this._imageProcessingObserver) {\r\n this._imageProcessingConfiguration.onUpdateParameters.remove(this._imageProcessingObserver);\r\n }\r\n // Pick the scene configuration if needed\r\n if (!configuration) {\r\n this._imageProcessingConfiguration = this.getScene().imageProcessingConfiguration;\r\n }\r\n else {\r\n this._imageProcessingConfiguration = configuration;\r\n }\r\n // Attaches observer\r\n if (this._imageProcessingConfiguration) {\r\n this._imageProcessingObserver = this._imageProcessingConfiguration.onUpdateParameters.add(function () {\r\n _this._markAllSubMeshesAsImageProcessingDirty();\r\n });\r\n }\r\n };\r\n Object.defineProperty(StandardMaterial.prototype, \"cameraColorCurvesEnabled\", {\r\n /**\r\n * Gets wether the color curves effect is enabled.\r\n */\r\n get: function () {\r\n return this.imageProcessingConfiguration.colorCurvesEnabled;\r\n },\r\n /**\r\n * Sets wether the color curves effect is enabled.\r\n */\r\n set: function (value) {\r\n this.imageProcessingConfiguration.colorCurvesEnabled = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial.prototype, \"cameraColorGradingEnabled\", {\r\n /**\r\n * Gets wether the color grading effect is enabled.\r\n */\r\n get: function () {\r\n return this.imageProcessingConfiguration.colorGradingEnabled;\r\n },\r\n /**\r\n * Gets wether the color grading effect is enabled.\r\n */\r\n set: function (value) {\r\n this.imageProcessingConfiguration.colorGradingEnabled = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial.prototype, \"cameraToneMappingEnabled\", {\r\n /**\r\n * Gets wether tonemapping is enabled or not.\r\n */\r\n get: function () {\r\n return this._imageProcessingConfiguration.toneMappingEnabled;\r\n },\r\n /**\r\n * Sets wether tonemapping is enabled or not\r\n */\r\n set: function (value) {\r\n this._imageProcessingConfiguration.toneMappingEnabled = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial.prototype, \"cameraExposure\", {\r\n /**\r\n * The camera exposure used on this material.\r\n * This property is here and not in the camera to allow controlling exposure without full screen post process.\r\n * This corresponds to a photographic exposure.\r\n */\r\n get: function () {\r\n return this._imageProcessingConfiguration.exposure;\r\n },\r\n /**\r\n * The camera exposure used on this material.\r\n * This property is here and not in the camera to allow controlling exposure without full screen post process.\r\n * This corresponds to a photographic exposure.\r\n */\r\n set: function (value) {\r\n this._imageProcessingConfiguration.exposure = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial.prototype, \"cameraContrast\", {\r\n /**\r\n * Gets The camera contrast used on this material.\r\n */\r\n get: function () {\r\n return this._imageProcessingConfiguration.contrast;\r\n },\r\n /**\r\n * Sets The camera contrast used on this material.\r\n */\r\n set: function (value) {\r\n this._imageProcessingConfiguration.contrast = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial.prototype, \"cameraColorGradingTexture\", {\r\n /**\r\n * Gets the Color Grading 2D Lookup Texture.\r\n */\r\n get: function () {\r\n return this._imageProcessingConfiguration.colorGradingTexture;\r\n },\r\n /**\r\n * Sets the Color Grading 2D Lookup Texture.\r\n */\r\n set: function (value) {\r\n this._imageProcessingConfiguration.colorGradingTexture = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial.prototype, \"cameraColorCurves\", {\r\n /**\r\n * The color grading curves provide additional color adjustmnent that is applied after any color grading transform (3D LUT).\r\n * They allow basic adjustment of saturation and small exposure adjustments, along with color filter tinting to provide white balance adjustment or more stylistic effects.\r\n * These are similar to controls found in many professional imaging or colorist software. The global controls are applied to the entire image. For advanced tuning, extra controls are provided to adjust the shadow, midtone and highlight areas of the image;\r\n * corresponding to low luminance, medium luminance, and high luminance areas respectively.\r\n */\r\n get: function () {\r\n return this._imageProcessingConfiguration.colorCurves;\r\n },\r\n /**\r\n * The color grading curves provide additional color adjustmnent that is applied after any color grading transform (3D LUT).\r\n * They allow basic adjustment of saturation and small exposure adjustments, along with color filter tinting to provide white balance adjustment or more stylistic effects.\r\n * These are similar to controls found in many professional imaging or colorist software. The global controls are applied to the entire image. For advanced tuning, extra controls are provided to adjust the shadow, midtone and highlight areas of the image;\r\n * corresponding to low luminance, medium luminance, and high luminance areas respectively.\r\n */\r\n set: function (value) {\r\n this._imageProcessingConfiguration.colorCurves = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial.prototype, \"hasRenderTargetTextures\", {\r\n /**\r\n * Gets a boolean indicating that current material needs to register RTT\r\n */\r\n get: function () {\r\n if (StandardMaterial.ReflectionTextureEnabled && this._reflectionTexture && this._reflectionTexture.isRenderTarget) {\r\n return true;\r\n }\r\n if (StandardMaterial.RefractionTextureEnabled && this._refractionTexture && this._refractionTexture.isRenderTarget) {\r\n return true;\r\n }\r\n return false;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the current class name of the material e.g. \"StandardMaterial\"\r\n * Mainly use in serialization.\r\n * @returns the class name\r\n */\r\n StandardMaterial.prototype.getClassName = function () {\r\n return \"StandardMaterial\";\r\n };\r\n Object.defineProperty(StandardMaterial.prototype, \"useLogarithmicDepth\", {\r\n /**\r\n * In case the depth buffer does not allow enough depth precision for your scene (might be the case in large scenes)\r\n * You can try switching to logarithmic depth.\r\n * @see http://doc.babylonjs.com/how_to/using_logarithmic_depth_buffer\r\n */\r\n get: function () {\r\n return this._useLogarithmicDepth;\r\n },\r\n set: function (value) {\r\n this._useLogarithmicDepth = value && this.getScene().getEngine().getCaps().fragmentDepthSupported;\r\n this._markAllSubMeshesAsMiscDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Specifies if the material will require alpha blending\r\n * @returns a boolean specifying if alpha blending is needed\r\n */\r\n StandardMaterial.prototype.needAlphaBlending = function () {\r\n return (this.alpha < 1.0) || (this._opacityTexture != null) || this._shouldUseAlphaFromDiffuseTexture() || this._opacityFresnelParameters && this._opacityFresnelParameters.isEnabled;\r\n };\r\n /**\r\n * Specifies if this material should be rendered in alpha test mode\r\n * @returns a boolean specifying if an alpha test is needed.\r\n */\r\n StandardMaterial.prototype.needAlphaTesting = function () {\r\n return this._diffuseTexture != null && this._diffuseTexture.hasAlpha;\r\n };\r\n StandardMaterial.prototype._shouldUseAlphaFromDiffuseTexture = function () {\r\n return this._diffuseTexture != null && this._diffuseTexture.hasAlpha && this._useAlphaFromDiffuseTexture;\r\n };\r\n /**\r\n * Get the texture used for alpha test purpose.\r\n * @returns the diffuse texture in case of the standard material.\r\n */\r\n StandardMaterial.prototype.getAlphaTestTexture = function () {\r\n return this._diffuseTexture;\r\n };\r\n /**\r\n * Get if the submesh is ready to be used and all its information available.\r\n * Child classes can use it to update shaders\r\n * @param mesh defines the mesh to check\r\n * @param subMesh defines which submesh to check\r\n * @param useInstances specifies that instances should be used\r\n * @returns a boolean indicating that the submesh is ready or not\r\n */\r\n StandardMaterial.prototype.isReadyForSubMesh = function (mesh, subMesh, useInstances) {\r\n if (useInstances === void 0) { useInstances = false; }\r\n if (subMesh.effect && this.isFrozen) {\r\n if (subMesh.effect._wasPreviouslyReady) {\r\n return true;\r\n }\r\n }\r\n if (!subMesh._materialDefines) {\r\n subMesh._materialDefines = new StandardMaterialDefines();\r\n }\r\n var scene = this.getScene();\r\n var defines = subMesh._materialDefines;\r\n if (!this.checkReadyOnEveryCall && subMesh.effect) {\r\n if (defines._renderId === scene.getRenderId()) {\r\n return true;\r\n }\r\n }\r\n var engine = scene.getEngine();\r\n // Lights\r\n defines._needNormals = MaterialHelper.PrepareDefinesForLights(scene, mesh, defines, true, this._maxSimultaneousLights, this._disableLighting);\r\n // Multiview\r\n MaterialHelper.PrepareDefinesForMultiview(scene, defines);\r\n // Textures\r\n if (defines._areTexturesDirty) {\r\n defines._needUVs = false;\r\n defines.MAINUV1 = false;\r\n defines.MAINUV2 = false;\r\n if (scene.texturesEnabled) {\r\n if (this._diffuseTexture && StandardMaterial.DiffuseTextureEnabled) {\r\n if (!this._diffuseTexture.isReadyOrNotBlocking()) {\r\n return false;\r\n }\r\n else {\r\n MaterialHelper.PrepareDefinesForMergedUV(this._diffuseTexture, defines, \"DIFFUSE\");\r\n }\r\n }\r\n else {\r\n defines.DIFFUSE = false;\r\n }\r\n if (this._ambientTexture && StandardMaterial.AmbientTextureEnabled) {\r\n if (!this._ambientTexture.isReadyOrNotBlocking()) {\r\n return false;\r\n }\r\n else {\r\n MaterialHelper.PrepareDefinesForMergedUV(this._ambientTexture, defines, \"AMBIENT\");\r\n }\r\n }\r\n else {\r\n defines.AMBIENT = false;\r\n }\r\n if (this._opacityTexture && StandardMaterial.OpacityTextureEnabled) {\r\n if (!this._opacityTexture.isReadyOrNotBlocking()) {\r\n return false;\r\n }\r\n else {\r\n MaterialHelper.PrepareDefinesForMergedUV(this._opacityTexture, defines, \"OPACITY\");\r\n defines.OPACITYRGB = this._opacityTexture.getAlphaFromRGB;\r\n }\r\n }\r\n else {\r\n defines.OPACITY = false;\r\n }\r\n if (this._reflectionTexture && StandardMaterial.ReflectionTextureEnabled) {\r\n if (!this._reflectionTexture.isReadyOrNotBlocking()) {\r\n return false;\r\n }\r\n else {\r\n defines._needNormals = true;\r\n defines.REFLECTION = true;\r\n defines.ROUGHNESS = (this._roughness > 0);\r\n defines.REFLECTIONOVERALPHA = this._useReflectionOverAlpha;\r\n defines.INVERTCUBICMAP = (this._reflectionTexture.coordinatesMode === Texture.INVCUBIC_MODE);\r\n defines.REFLECTIONMAP_3D = this._reflectionTexture.isCube;\r\n switch (this._reflectionTexture.coordinatesMode) {\r\n case Texture.EXPLICIT_MODE:\r\n defines.setReflectionMode(\"REFLECTIONMAP_EXPLICIT\");\r\n break;\r\n case Texture.PLANAR_MODE:\r\n defines.setReflectionMode(\"REFLECTIONMAP_PLANAR\");\r\n break;\r\n case Texture.PROJECTION_MODE:\r\n defines.setReflectionMode(\"REFLECTIONMAP_PROJECTION\");\r\n break;\r\n case Texture.SKYBOX_MODE:\r\n defines.setReflectionMode(\"REFLECTIONMAP_SKYBOX\");\r\n break;\r\n case Texture.SPHERICAL_MODE:\r\n defines.setReflectionMode(\"REFLECTIONMAP_SPHERICAL\");\r\n break;\r\n case Texture.EQUIRECTANGULAR_MODE:\r\n defines.setReflectionMode(\"REFLECTIONMAP_EQUIRECTANGULAR\");\r\n break;\r\n case Texture.FIXED_EQUIRECTANGULAR_MODE:\r\n defines.setReflectionMode(\"REFLECTIONMAP_EQUIRECTANGULAR_FIXED\");\r\n break;\r\n case Texture.FIXED_EQUIRECTANGULAR_MIRRORED_MODE:\r\n defines.setReflectionMode(\"REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED\");\r\n break;\r\n case Texture.CUBIC_MODE:\r\n case Texture.INVCUBIC_MODE:\r\n default:\r\n defines.setReflectionMode(\"REFLECTIONMAP_CUBIC\");\r\n break;\r\n }\r\n defines.USE_LOCAL_REFLECTIONMAP_CUBIC = this._reflectionTexture.boundingBoxSize ? true : false;\r\n }\r\n }\r\n else {\r\n defines.REFLECTION = false;\r\n }\r\n if (this._emissiveTexture && StandardMaterial.EmissiveTextureEnabled) {\r\n if (!this._emissiveTexture.isReadyOrNotBlocking()) {\r\n return false;\r\n }\r\n else {\r\n MaterialHelper.PrepareDefinesForMergedUV(this._emissiveTexture, defines, \"EMISSIVE\");\r\n }\r\n }\r\n else {\r\n defines.EMISSIVE = false;\r\n }\r\n if (this._lightmapTexture && StandardMaterial.LightmapTextureEnabled) {\r\n if (!this._lightmapTexture.isReadyOrNotBlocking()) {\r\n return false;\r\n }\r\n else {\r\n MaterialHelper.PrepareDefinesForMergedUV(this._lightmapTexture, defines, \"LIGHTMAP\");\r\n defines.USELIGHTMAPASSHADOWMAP = this._useLightmapAsShadowmap;\r\n }\r\n }\r\n else {\r\n defines.LIGHTMAP = false;\r\n }\r\n if (this._specularTexture && StandardMaterial.SpecularTextureEnabled) {\r\n if (!this._specularTexture.isReadyOrNotBlocking()) {\r\n return false;\r\n }\r\n else {\r\n MaterialHelper.PrepareDefinesForMergedUV(this._specularTexture, defines, \"SPECULAR\");\r\n defines.GLOSSINESS = this._useGlossinessFromSpecularMapAlpha;\r\n }\r\n }\r\n else {\r\n defines.SPECULAR = false;\r\n }\r\n if (scene.getEngine().getCaps().standardDerivatives && this._bumpTexture && StandardMaterial.BumpTextureEnabled) {\r\n // Bump texure can not be not blocking.\r\n if (!this._bumpTexture.isReady()) {\r\n return false;\r\n }\r\n else {\r\n MaterialHelper.PrepareDefinesForMergedUV(this._bumpTexture, defines, \"BUMP\");\r\n defines.PARALLAX = this._useParallax;\r\n defines.PARALLAXOCCLUSION = this._useParallaxOcclusion;\r\n }\r\n defines.OBJECTSPACE_NORMALMAP = this._useObjectSpaceNormalMap;\r\n }\r\n else {\r\n defines.BUMP = false;\r\n }\r\n if (this._refractionTexture && StandardMaterial.RefractionTextureEnabled) {\r\n if (!this._refractionTexture.isReadyOrNotBlocking()) {\r\n return false;\r\n }\r\n else {\r\n defines._needUVs = true;\r\n defines.REFRACTION = true;\r\n defines.REFRACTIONMAP_3D = this._refractionTexture.isCube;\r\n }\r\n }\r\n else {\r\n defines.REFRACTION = false;\r\n }\r\n defines.TWOSIDEDLIGHTING = !this._backFaceCulling && this._twoSidedLighting;\r\n }\r\n else {\r\n defines.DIFFUSE = false;\r\n defines.AMBIENT = false;\r\n defines.OPACITY = false;\r\n defines.REFLECTION = false;\r\n defines.EMISSIVE = false;\r\n defines.LIGHTMAP = false;\r\n defines.BUMP = false;\r\n defines.REFRACTION = false;\r\n }\r\n defines.ALPHAFROMDIFFUSE = this._shouldUseAlphaFromDiffuseTexture();\r\n defines.EMISSIVEASILLUMINATION = this._useEmissiveAsIllumination;\r\n defines.LINKEMISSIVEWITHDIFFUSE = this._linkEmissiveWithDiffuse;\r\n defines.SPECULAROVERALPHA = this._useSpecularOverAlpha;\r\n defines.PREMULTIPLYALPHA = (this.alphaMode === 7 || this.alphaMode === 8);\r\n }\r\n if (defines._areImageProcessingDirty && this._imageProcessingConfiguration) {\r\n if (!this._imageProcessingConfiguration.isReady()) {\r\n return false;\r\n }\r\n this._imageProcessingConfiguration.prepareDefines(defines);\r\n defines.IS_REFLECTION_LINEAR = (this.reflectionTexture != null && !this.reflectionTexture.gammaSpace);\r\n defines.IS_REFRACTION_LINEAR = (this.refractionTexture != null && !this.refractionTexture.gammaSpace);\r\n }\r\n if (defines._areFresnelDirty) {\r\n if (StandardMaterial.FresnelEnabled) {\r\n // Fresnel\r\n if (this._diffuseFresnelParameters || this._opacityFresnelParameters ||\r\n this._emissiveFresnelParameters || this._refractionFresnelParameters ||\r\n this._reflectionFresnelParameters) {\r\n defines.DIFFUSEFRESNEL = (this._diffuseFresnelParameters && this._diffuseFresnelParameters.isEnabled);\r\n defines.OPACITYFRESNEL = (this._opacityFresnelParameters && this._opacityFresnelParameters.isEnabled);\r\n defines.REFLECTIONFRESNEL = (this._reflectionFresnelParameters && this._reflectionFresnelParameters.isEnabled);\r\n defines.REFLECTIONFRESNELFROMSPECULAR = this._useReflectionFresnelFromSpecular;\r\n defines.REFRACTIONFRESNEL = (this._refractionFresnelParameters && this._refractionFresnelParameters.isEnabled);\r\n defines.EMISSIVEFRESNEL = (this._emissiveFresnelParameters && this._emissiveFresnelParameters.isEnabled);\r\n defines._needNormals = true;\r\n defines.FRESNEL = true;\r\n }\r\n }\r\n else {\r\n defines.FRESNEL = false;\r\n }\r\n }\r\n // Misc.\r\n MaterialHelper.PrepareDefinesForMisc(mesh, scene, this._useLogarithmicDepth, this.pointsCloud, this.fogEnabled, this._shouldTurnAlphaTestOn(mesh), defines);\r\n // Attribs\r\n MaterialHelper.PrepareDefinesForAttributes(mesh, defines, true, true, true);\r\n // Values that need to be evaluated on every frame\r\n MaterialHelper.PrepareDefinesForFrameBoundValues(scene, engine, defines, useInstances);\r\n // Get correct effect\r\n if (defines.isDirty) {\r\n var lightDisposed = defines._areLightsDisposed;\r\n defines.markAsProcessed();\r\n // Fallbacks\r\n var fallbacks = new EffectFallbacks();\r\n if (defines.REFLECTION) {\r\n fallbacks.addFallback(0, \"REFLECTION\");\r\n }\r\n if (defines.SPECULAR) {\r\n fallbacks.addFallback(0, \"SPECULAR\");\r\n }\r\n if (defines.BUMP) {\r\n fallbacks.addFallback(0, \"BUMP\");\r\n }\r\n if (defines.PARALLAX) {\r\n fallbacks.addFallback(1, \"PARALLAX\");\r\n }\r\n if (defines.PARALLAXOCCLUSION) {\r\n fallbacks.addFallback(0, \"PARALLAXOCCLUSION\");\r\n }\r\n if (defines.SPECULAROVERALPHA) {\r\n fallbacks.addFallback(0, \"SPECULAROVERALPHA\");\r\n }\r\n if (defines.FOG) {\r\n fallbacks.addFallback(1, \"FOG\");\r\n }\r\n if (defines.POINTSIZE) {\r\n fallbacks.addFallback(0, \"POINTSIZE\");\r\n }\r\n if (defines.LOGARITHMICDEPTH) {\r\n fallbacks.addFallback(0, \"LOGARITHMICDEPTH\");\r\n }\r\n MaterialHelper.HandleFallbacksForShadows(defines, fallbacks, this._maxSimultaneousLights);\r\n if (defines.SPECULARTERM) {\r\n fallbacks.addFallback(0, \"SPECULARTERM\");\r\n }\r\n if (defines.DIFFUSEFRESNEL) {\r\n fallbacks.addFallback(1, \"DIFFUSEFRESNEL\");\r\n }\r\n if (defines.OPACITYFRESNEL) {\r\n fallbacks.addFallback(2, \"OPACITYFRESNEL\");\r\n }\r\n if (defines.REFLECTIONFRESNEL) {\r\n fallbacks.addFallback(3, \"REFLECTIONFRESNEL\");\r\n }\r\n if (defines.EMISSIVEFRESNEL) {\r\n fallbacks.addFallback(4, \"EMISSIVEFRESNEL\");\r\n }\r\n if (defines.FRESNEL) {\r\n fallbacks.addFallback(4, \"FRESNEL\");\r\n }\r\n if (defines.MULTIVIEW) {\r\n fallbacks.addFallback(0, \"MULTIVIEW\");\r\n }\r\n //Attributes\r\n var attribs = [VertexBuffer.PositionKind];\r\n if (defines.NORMAL) {\r\n attribs.push(VertexBuffer.NormalKind);\r\n }\r\n if (defines.UV1) {\r\n attribs.push(VertexBuffer.UVKind);\r\n }\r\n if (defines.UV2) {\r\n attribs.push(VertexBuffer.UV2Kind);\r\n }\r\n if (defines.VERTEXCOLOR) {\r\n attribs.push(VertexBuffer.ColorKind);\r\n }\r\n MaterialHelper.PrepareAttributesForBones(attribs, mesh, defines, fallbacks);\r\n MaterialHelper.PrepareAttributesForInstances(attribs, defines);\r\n MaterialHelper.PrepareAttributesForMorphTargets(attribs, mesh, defines);\r\n var shaderName = \"default\";\r\n var uniforms = [\"world\", \"view\", \"viewProjection\", \"vEyePosition\", \"vLightsType\", \"vAmbientColor\", \"vDiffuseColor\", \"vSpecularColor\", \"vEmissiveColor\", \"visibility\",\r\n \"vFogInfos\", \"vFogColor\", \"pointSize\",\r\n \"vDiffuseInfos\", \"vAmbientInfos\", \"vOpacityInfos\", \"vReflectionInfos\", \"vEmissiveInfos\", \"vSpecularInfos\", \"vBumpInfos\", \"vLightmapInfos\", \"vRefractionInfos\",\r\n \"mBones\",\r\n \"vClipPlane\", \"vClipPlane2\", \"vClipPlane3\", \"vClipPlane4\", \"vClipPlane5\", \"vClipPlane6\", \"diffuseMatrix\", \"ambientMatrix\", \"opacityMatrix\", \"reflectionMatrix\", \"emissiveMatrix\", \"specularMatrix\", \"bumpMatrix\", \"normalMatrix\", \"lightmapMatrix\", \"refractionMatrix\",\r\n \"diffuseLeftColor\", \"diffuseRightColor\", \"opacityParts\", \"reflectionLeftColor\", \"reflectionRightColor\", \"emissiveLeftColor\", \"emissiveRightColor\", \"refractionLeftColor\", \"refractionRightColor\",\r\n \"vReflectionPosition\", \"vReflectionSize\",\r\n \"logarithmicDepthConstant\", \"vTangentSpaceParams\", \"alphaCutOff\", \"boneTextureWidth\"\r\n ];\r\n var samplers = [\"diffuseSampler\", \"ambientSampler\", \"opacitySampler\", \"reflectionCubeSampler\",\r\n \"reflection2DSampler\", \"emissiveSampler\", \"specularSampler\", \"bumpSampler\", \"lightmapSampler\",\r\n \"refractionCubeSampler\", \"refraction2DSampler\", \"boneSampler\"];\r\n var uniformBuffers = [\"Material\", \"Scene\"];\r\n if (ImageProcessingConfiguration) {\r\n ImageProcessingConfiguration.PrepareUniforms(uniforms, defines);\r\n ImageProcessingConfiguration.PrepareSamplers(samplers, defines);\r\n }\r\n MaterialHelper.PrepareUniformsAndSamplersList({\r\n uniformsNames: uniforms,\r\n uniformBuffersNames: uniformBuffers,\r\n samplers: samplers,\r\n defines: defines,\r\n maxSimultaneousLights: this._maxSimultaneousLights\r\n });\r\n if (this.customShaderNameResolve) {\r\n shaderName = this.customShaderNameResolve(shaderName, uniforms, uniformBuffers, samplers, defines);\r\n }\r\n var join = defines.toString();\r\n var previousEffect = subMesh.effect;\r\n var effect = scene.getEngine().createEffect(shaderName, {\r\n attributes: attribs,\r\n uniformsNames: uniforms,\r\n uniformBuffersNames: uniformBuffers,\r\n samplers: samplers,\r\n defines: join,\r\n fallbacks: fallbacks,\r\n onCompiled: this.onCompiled,\r\n onError: this.onError,\r\n indexParameters: { maxSimultaneousLights: this._maxSimultaneousLights, maxSimultaneousMorphTargets: defines.NUM_MORPH_INFLUENCERS }\r\n }, engine);\r\n if (effect) {\r\n // Use previous effect while new one is compiling\r\n if (this.allowShaderHotSwapping && previousEffect && !effect.isReady()) {\r\n effect = previousEffect;\r\n this._rebuildInParallel = true;\r\n defines.markAsUnprocessed();\r\n if (lightDisposed) {\r\n // re register in case it takes more than one frame.\r\n defines._areLightsDisposed = true;\r\n return false;\r\n }\r\n }\r\n else {\r\n this._rebuildInParallel = false;\r\n scene.resetCachedMaterial();\r\n subMesh.setEffect(effect, defines);\r\n this.buildUniformLayout();\r\n }\r\n }\r\n }\r\n if (!subMesh.effect || !subMesh.effect.isReady()) {\r\n return false;\r\n }\r\n defines._renderId = scene.getRenderId();\r\n subMesh.effect._wasPreviouslyReady = true;\r\n return true;\r\n };\r\n /**\r\n * Builds the material UBO layouts.\r\n * Used internally during the effect preparation.\r\n */\r\n StandardMaterial.prototype.buildUniformLayout = function () {\r\n // Order is important !\r\n var ubo = this._uniformBuffer;\r\n ubo.addUniform(\"diffuseLeftColor\", 4);\r\n ubo.addUniform(\"diffuseRightColor\", 4);\r\n ubo.addUniform(\"opacityParts\", 4);\r\n ubo.addUniform(\"reflectionLeftColor\", 4);\r\n ubo.addUniform(\"reflectionRightColor\", 4);\r\n ubo.addUniform(\"refractionLeftColor\", 4);\r\n ubo.addUniform(\"refractionRightColor\", 4);\r\n ubo.addUniform(\"emissiveLeftColor\", 4);\r\n ubo.addUniform(\"emissiveRightColor\", 4);\r\n ubo.addUniform(\"vDiffuseInfos\", 2);\r\n ubo.addUniform(\"vAmbientInfos\", 2);\r\n ubo.addUniform(\"vOpacityInfos\", 2);\r\n ubo.addUniform(\"vReflectionInfos\", 2);\r\n ubo.addUniform(\"vReflectionPosition\", 3);\r\n ubo.addUniform(\"vReflectionSize\", 3);\r\n ubo.addUniform(\"vEmissiveInfos\", 2);\r\n ubo.addUniform(\"vLightmapInfos\", 2);\r\n ubo.addUniform(\"vSpecularInfos\", 2);\r\n ubo.addUniform(\"vBumpInfos\", 3);\r\n ubo.addUniform(\"diffuseMatrix\", 16);\r\n ubo.addUniform(\"ambientMatrix\", 16);\r\n ubo.addUniform(\"opacityMatrix\", 16);\r\n ubo.addUniform(\"reflectionMatrix\", 16);\r\n ubo.addUniform(\"emissiveMatrix\", 16);\r\n ubo.addUniform(\"lightmapMatrix\", 16);\r\n ubo.addUniform(\"specularMatrix\", 16);\r\n ubo.addUniform(\"bumpMatrix\", 16);\r\n ubo.addUniform(\"vTangentSpaceParams\", 2);\r\n ubo.addUniform(\"pointSize\", 1);\r\n ubo.addUniform(\"refractionMatrix\", 16);\r\n ubo.addUniform(\"vRefractionInfos\", 4);\r\n ubo.addUniform(\"vSpecularColor\", 4);\r\n ubo.addUniform(\"vEmissiveColor\", 3);\r\n ubo.addUniform(\"visibility\", 1);\r\n ubo.addUniform(\"vDiffuseColor\", 4);\r\n ubo.create();\r\n };\r\n /**\r\n * Unbinds the material from the mesh\r\n */\r\n StandardMaterial.prototype.unbind = function () {\r\n if (this._activeEffect) {\r\n var needFlag = false;\r\n if (this._reflectionTexture && this._reflectionTexture.isRenderTarget) {\r\n this._activeEffect.setTexture(\"reflection2DSampler\", null);\r\n needFlag = true;\r\n }\r\n if (this._refractionTexture && this._refractionTexture.isRenderTarget) {\r\n this._activeEffect.setTexture(\"refraction2DSampler\", null);\r\n needFlag = true;\r\n }\r\n if (needFlag) {\r\n this._markAllSubMeshesAsTexturesDirty();\r\n }\r\n }\r\n _super.prototype.unbind.call(this);\r\n };\r\n /**\r\n * Binds the submesh to this material by preparing the effect and shader to draw\r\n * @param world defines the world transformation matrix\r\n * @param mesh defines the mesh containing the submesh\r\n * @param subMesh defines the submesh to bind the material to\r\n */\r\n StandardMaterial.prototype.bindForSubMesh = function (world, mesh, subMesh) {\r\n var scene = this.getScene();\r\n var defines = subMesh._materialDefines;\r\n if (!defines) {\r\n return;\r\n }\r\n var effect = subMesh.effect;\r\n if (!effect) {\r\n return;\r\n }\r\n this._activeEffect = effect;\r\n // Matrices\r\n if (!defines.INSTANCES) {\r\n this.bindOnlyWorldMatrix(world);\r\n }\r\n // Normal Matrix\r\n if (defines.OBJECTSPACE_NORMALMAP) {\r\n world.toNormalMatrix(this._normalMatrix);\r\n this.bindOnlyNormalMatrix(this._normalMatrix);\r\n }\r\n var mustRebind = this._mustRebind(scene, effect, mesh.visibility);\r\n // Bones\r\n MaterialHelper.BindBonesParameters(mesh, effect);\r\n var ubo = this._uniformBuffer;\r\n if (mustRebind) {\r\n ubo.bindToEffect(effect, \"Material\");\r\n this.bindViewProjection(effect);\r\n if (!ubo.useUbo || !this.isFrozen || !ubo.isSync) {\r\n if (StandardMaterial.FresnelEnabled && defines.FRESNEL) {\r\n // Fresnel\r\n if (this.diffuseFresnelParameters && this.diffuseFresnelParameters.isEnabled) {\r\n ubo.updateColor4(\"diffuseLeftColor\", this.diffuseFresnelParameters.leftColor, this.diffuseFresnelParameters.power);\r\n ubo.updateColor4(\"diffuseRightColor\", this.diffuseFresnelParameters.rightColor, this.diffuseFresnelParameters.bias);\r\n }\r\n if (this.opacityFresnelParameters && this.opacityFresnelParameters.isEnabled) {\r\n ubo.updateColor4(\"opacityParts\", new Color3(this.opacityFresnelParameters.leftColor.toLuminance(), this.opacityFresnelParameters.rightColor.toLuminance(), this.opacityFresnelParameters.bias), this.opacityFresnelParameters.power);\r\n }\r\n if (this.reflectionFresnelParameters && this.reflectionFresnelParameters.isEnabled) {\r\n ubo.updateColor4(\"reflectionLeftColor\", this.reflectionFresnelParameters.leftColor, this.reflectionFresnelParameters.power);\r\n ubo.updateColor4(\"reflectionRightColor\", this.reflectionFresnelParameters.rightColor, this.reflectionFresnelParameters.bias);\r\n }\r\n if (this.refractionFresnelParameters && this.refractionFresnelParameters.isEnabled) {\r\n ubo.updateColor4(\"refractionLeftColor\", this.refractionFresnelParameters.leftColor, this.refractionFresnelParameters.power);\r\n ubo.updateColor4(\"refractionRightColor\", this.refractionFresnelParameters.rightColor, this.refractionFresnelParameters.bias);\r\n }\r\n if (this.emissiveFresnelParameters && this.emissiveFresnelParameters.isEnabled) {\r\n ubo.updateColor4(\"emissiveLeftColor\", this.emissiveFresnelParameters.leftColor, this.emissiveFresnelParameters.power);\r\n ubo.updateColor4(\"emissiveRightColor\", this.emissiveFresnelParameters.rightColor, this.emissiveFresnelParameters.bias);\r\n }\r\n }\r\n // Textures\r\n if (scene.texturesEnabled) {\r\n if (this._diffuseTexture && StandardMaterial.DiffuseTextureEnabled) {\r\n ubo.updateFloat2(\"vDiffuseInfos\", this._diffuseTexture.coordinatesIndex, this._diffuseTexture.level);\r\n MaterialHelper.BindTextureMatrix(this._diffuseTexture, ubo, \"diffuse\");\r\n if (this._diffuseTexture.hasAlpha) {\r\n effect.setFloat(\"alphaCutOff\", this.alphaCutOff);\r\n }\r\n }\r\n if (this._ambientTexture && StandardMaterial.AmbientTextureEnabled) {\r\n ubo.updateFloat2(\"vAmbientInfos\", this._ambientTexture.coordinatesIndex, this._ambientTexture.level);\r\n MaterialHelper.BindTextureMatrix(this._ambientTexture, ubo, \"ambient\");\r\n }\r\n if (this._opacityTexture && StandardMaterial.OpacityTextureEnabled) {\r\n ubo.updateFloat2(\"vOpacityInfos\", this._opacityTexture.coordinatesIndex, this._opacityTexture.level);\r\n MaterialHelper.BindTextureMatrix(this._opacityTexture, ubo, \"opacity\");\r\n }\r\n if (this._reflectionTexture && StandardMaterial.ReflectionTextureEnabled) {\r\n ubo.updateFloat2(\"vReflectionInfos\", this._reflectionTexture.level, this.roughness);\r\n ubo.updateMatrix(\"reflectionMatrix\", this._reflectionTexture.getReflectionTextureMatrix());\r\n if (this._reflectionTexture.boundingBoxSize) {\r\n var cubeTexture = this._reflectionTexture;\r\n ubo.updateVector3(\"vReflectionPosition\", cubeTexture.boundingBoxPosition);\r\n ubo.updateVector3(\"vReflectionSize\", cubeTexture.boundingBoxSize);\r\n }\r\n }\r\n if (this._emissiveTexture && StandardMaterial.EmissiveTextureEnabled) {\r\n ubo.updateFloat2(\"vEmissiveInfos\", this._emissiveTexture.coordinatesIndex, this._emissiveTexture.level);\r\n MaterialHelper.BindTextureMatrix(this._emissiveTexture, ubo, \"emissive\");\r\n }\r\n if (this._lightmapTexture && StandardMaterial.LightmapTextureEnabled) {\r\n ubo.updateFloat2(\"vLightmapInfos\", this._lightmapTexture.coordinatesIndex, this._lightmapTexture.level);\r\n MaterialHelper.BindTextureMatrix(this._lightmapTexture, ubo, \"lightmap\");\r\n }\r\n if (this._specularTexture && StandardMaterial.SpecularTextureEnabled) {\r\n ubo.updateFloat2(\"vSpecularInfos\", this._specularTexture.coordinatesIndex, this._specularTexture.level);\r\n MaterialHelper.BindTextureMatrix(this._specularTexture, ubo, \"specular\");\r\n }\r\n if (this._bumpTexture && scene.getEngine().getCaps().standardDerivatives && StandardMaterial.BumpTextureEnabled) {\r\n ubo.updateFloat3(\"vBumpInfos\", this._bumpTexture.coordinatesIndex, 1.0 / this._bumpTexture.level, this.parallaxScaleBias);\r\n MaterialHelper.BindTextureMatrix(this._bumpTexture, ubo, \"bump\");\r\n if (scene._mirroredCameraPosition) {\r\n ubo.updateFloat2(\"vTangentSpaceParams\", this._invertNormalMapX ? 1.0 : -1.0, this._invertNormalMapY ? 1.0 : -1.0);\r\n }\r\n else {\r\n ubo.updateFloat2(\"vTangentSpaceParams\", this._invertNormalMapX ? -1.0 : 1.0, this._invertNormalMapY ? -1.0 : 1.0);\r\n }\r\n }\r\n if (this._refractionTexture && StandardMaterial.RefractionTextureEnabled) {\r\n var depth = 1.0;\r\n if (!this._refractionTexture.isCube) {\r\n ubo.updateMatrix(\"refractionMatrix\", this._refractionTexture.getReflectionTextureMatrix());\r\n if (this._refractionTexture.depth) {\r\n depth = this._refractionTexture.depth;\r\n }\r\n }\r\n ubo.updateFloat4(\"vRefractionInfos\", this._refractionTexture.level, this.indexOfRefraction, depth, this.invertRefractionY ? -1 : 1);\r\n }\r\n }\r\n // Point size\r\n if (this.pointsCloud) {\r\n ubo.updateFloat(\"pointSize\", this.pointSize);\r\n }\r\n if (defines.SPECULARTERM) {\r\n ubo.updateColor4(\"vSpecularColor\", this.specularColor, this.specularPower);\r\n }\r\n ubo.updateColor3(\"vEmissiveColor\", StandardMaterial.EmissiveTextureEnabled ? this.emissiveColor : Color3.BlackReadOnly);\r\n // Visibility\r\n ubo.updateFloat(\"visibility\", mesh.visibility);\r\n // Diffuse\r\n ubo.updateColor4(\"vDiffuseColor\", this.diffuseColor, this.alpha);\r\n }\r\n // Textures\r\n if (scene.texturesEnabled) {\r\n if (this._diffuseTexture && StandardMaterial.DiffuseTextureEnabled) {\r\n effect.setTexture(\"diffuseSampler\", this._diffuseTexture);\r\n }\r\n if (this._ambientTexture && StandardMaterial.AmbientTextureEnabled) {\r\n effect.setTexture(\"ambientSampler\", this._ambientTexture);\r\n }\r\n if (this._opacityTexture && StandardMaterial.OpacityTextureEnabled) {\r\n effect.setTexture(\"opacitySampler\", this._opacityTexture);\r\n }\r\n if (this._reflectionTexture && StandardMaterial.ReflectionTextureEnabled) {\r\n if (this._reflectionTexture.isCube) {\r\n effect.setTexture(\"reflectionCubeSampler\", this._reflectionTexture);\r\n }\r\n else {\r\n effect.setTexture(\"reflection2DSampler\", this._reflectionTexture);\r\n }\r\n }\r\n if (this._emissiveTexture && StandardMaterial.EmissiveTextureEnabled) {\r\n effect.setTexture(\"emissiveSampler\", this._emissiveTexture);\r\n }\r\n if (this._lightmapTexture && StandardMaterial.LightmapTextureEnabled) {\r\n effect.setTexture(\"lightmapSampler\", this._lightmapTexture);\r\n }\r\n if (this._specularTexture && StandardMaterial.SpecularTextureEnabled) {\r\n effect.setTexture(\"specularSampler\", this._specularTexture);\r\n }\r\n if (this._bumpTexture && scene.getEngine().getCaps().standardDerivatives && StandardMaterial.BumpTextureEnabled) {\r\n effect.setTexture(\"bumpSampler\", this._bumpTexture);\r\n }\r\n if (this._refractionTexture && StandardMaterial.RefractionTextureEnabled) {\r\n var depth = 1.0;\r\n if (this._refractionTexture.isCube) {\r\n effect.setTexture(\"refractionCubeSampler\", this._refractionTexture);\r\n }\r\n else {\r\n effect.setTexture(\"refraction2DSampler\", this._refractionTexture);\r\n }\r\n }\r\n }\r\n // Clip plane\r\n MaterialHelper.BindClipPlane(effect, scene);\r\n // Colors\r\n scene.ambientColor.multiplyToRef(this.ambientColor, this._globalAmbientColor);\r\n MaterialHelper.BindEyePosition(effect, scene);\r\n effect.setColor3(\"vAmbientColor\", this._globalAmbientColor);\r\n }\r\n if (mustRebind || !this.isFrozen) {\r\n // Lights\r\n if (scene.lightsEnabled && !this._disableLighting) {\r\n MaterialHelper.BindLights(scene, mesh, effect, defines, this._maxSimultaneousLights, this._rebuildInParallel);\r\n }\r\n // View\r\n if (scene.fogEnabled && mesh.applyFog && scene.fogMode !== Scene.FOGMODE_NONE || this._reflectionTexture || this._refractionTexture) {\r\n this.bindView(effect);\r\n }\r\n // Fog\r\n MaterialHelper.BindFogParameters(scene, mesh, effect);\r\n // Morph targets\r\n if (defines.NUM_MORPH_INFLUENCERS) {\r\n MaterialHelper.BindMorphTargetParameters(mesh, effect);\r\n }\r\n // Log. depth\r\n if (this.useLogarithmicDepth) {\r\n MaterialHelper.BindLogDepth(defines, effect, scene);\r\n }\r\n // image processing\r\n if (this._imageProcessingConfiguration && !this._imageProcessingConfiguration.applyByPostProcess) {\r\n this._imageProcessingConfiguration.bind(this._activeEffect);\r\n }\r\n }\r\n ubo.update();\r\n this._afterBind(mesh, this._activeEffect);\r\n };\r\n /**\r\n * Get the list of animatables in the material.\r\n * @returns the list of animatables object used in the material\r\n */\r\n StandardMaterial.prototype.getAnimatables = function () {\r\n var results = [];\r\n if (this._diffuseTexture && this._diffuseTexture.animations && this._diffuseTexture.animations.length > 0) {\r\n results.push(this._diffuseTexture);\r\n }\r\n if (this._ambientTexture && this._ambientTexture.animations && this._ambientTexture.animations.length > 0) {\r\n results.push(this._ambientTexture);\r\n }\r\n if (this._opacityTexture && this._opacityTexture.animations && this._opacityTexture.animations.length > 0) {\r\n results.push(this._opacityTexture);\r\n }\r\n if (this._reflectionTexture && this._reflectionTexture.animations && this._reflectionTexture.animations.length > 0) {\r\n results.push(this._reflectionTexture);\r\n }\r\n if (this._emissiveTexture && this._emissiveTexture.animations && this._emissiveTexture.animations.length > 0) {\r\n results.push(this._emissiveTexture);\r\n }\r\n if (this._specularTexture && this._specularTexture.animations && this._specularTexture.animations.length > 0) {\r\n results.push(this._specularTexture);\r\n }\r\n if (this._bumpTexture && this._bumpTexture.animations && this._bumpTexture.animations.length > 0) {\r\n results.push(this._bumpTexture);\r\n }\r\n if (this._lightmapTexture && this._lightmapTexture.animations && this._lightmapTexture.animations.length > 0) {\r\n results.push(this._lightmapTexture);\r\n }\r\n if (this._refractionTexture && this._refractionTexture.animations && this._refractionTexture.animations.length > 0) {\r\n results.push(this._refractionTexture);\r\n }\r\n return results;\r\n };\r\n /**\r\n * Gets the active textures from the material\r\n * @returns an array of textures\r\n */\r\n StandardMaterial.prototype.getActiveTextures = function () {\r\n var activeTextures = _super.prototype.getActiveTextures.call(this);\r\n if (this._diffuseTexture) {\r\n activeTextures.push(this._diffuseTexture);\r\n }\r\n if (this._ambientTexture) {\r\n activeTextures.push(this._ambientTexture);\r\n }\r\n if (this._opacityTexture) {\r\n activeTextures.push(this._opacityTexture);\r\n }\r\n if (this._reflectionTexture) {\r\n activeTextures.push(this._reflectionTexture);\r\n }\r\n if (this._emissiveTexture) {\r\n activeTextures.push(this._emissiveTexture);\r\n }\r\n if (this._specularTexture) {\r\n activeTextures.push(this._specularTexture);\r\n }\r\n if (this._bumpTexture) {\r\n activeTextures.push(this._bumpTexture);\r\n }\r\n if (this._lightmapTexture) {\r\n activeTextures.push(this._lightmapTexture);\r\n }\r\n if (this._refractionTexture) {\r\n activeTextures.push(this._refractionTexture);\r\n }\r\n return activeTextures;\r\n };\r\n /**\r\n * Specifies if the material uses a texture\r\n * @param texture defines the texture to check against the material\r\n * @returns a boolean specifying if the material uses the texture\r\n */\r\n StandardMaterial.prototype.hasTexture = function (texture) {\r\n if (_super.prototype.hasTexture.call(this, texture)) {\r\n return true;\r\n }\r\n if (this._diffuseTexture === texture) {\r\n return true;\r\n }\r\n if (this._ambientTexture === texture) {\r\n return true;\r\n }\r\n if (this._opacityTexture === texture) {\r\n return true;\r\n }\r\n if (this._reflectionTexture === texture) {\r\n return true;\r\n }\r\n if (this._emissiveTexture === texture) {\r\n return true;\r\n }\r\n if (this._specularTexture === texture) {\r\n return true;\r\n }\r\n if (this._bumpTexture === texture) {\r\n return true;\r\n }\r\n if (this._lightmapTexture === texture) {\r\n return true;\r\n }\r\n if (this._refractionTexture === texture) {\r\n return true;\r\n }\r\n return false;\r\n };\r\n /**\r\n * Disposes the material\r\n * @param forceDisposeEffect specifies if effects should be forcefully disposed\r\n * @param forceDisposeTextures specifies if textures should be forcefully disposed\r\n */\r\n StandardMaterial.prototype.dispose = function (forceDisposeEffect, forceDisposeTextures) {\r\n if (forceDisposeTextures) {\r\n if (this._diffuseTexture) {\r\n this._diffuseTexture.dispose();\r\n }\r\n if (this._ambientTexture) {\r\n this._ambientTexture.dispose();\r\n }\r\n if (this._opacityTexture) {\r\n this._opacityTexture.dispose();\r\n }\r\n if (this._reflectionTexture) {\r\n this._reflectionTexture.dispose();\r\n }\r\n if (this._emissiveTexture) {\r\n this._emissiveTexture.dispose();\r\n }\r\n if (this._specularTexture) {\r\n this._specularTexture.dispose();\r\n }\r\n if (this._bumpTexture) {\r\n this._bumpTexture.dispose();\r\n }\r\n if (this._lightmapTexture) {\r\n this._lightmapTexture.dispose();\r\n }\r\n if (this._refractionTexture) {\r\n this._refractionTexture.dispose();\r\n }\r\n }\r\n if (this._imageProcessingConfiguration && this._imageProcessingObserver) {\r\n this._imageProcessingConfiguration.onUpdateParameters.remove(this._imageProcessingObserver);\r\n }\r\n _super.prototype.dispose.call(this, forceDisposeEffect, forceDisposeTextures);\r\n };\r\n /**\r\n * Makes a duplicate of the material, and gives it a new name\r\n * @param name defines the new name for the duplicated material\r\n * @returns the cloned material\r\n */\r\n StandardMaterial.prototype.clone = function (name) {\r\n var _this = this;\r\n var result = SerializationHelper.Clone(function () { return new StandardMaterial(name, _this.getScene()); }, this);\r\n result.name = name;\r\n result.id = name;\r\n return result;\r\n };\r\n /**\r\n * Serializes this material in a JSON representation\r\n * @returns the serialized material object\r\n */\r\n StandardMaterial.prototype.serialize = function () {\r\n return SerializationHelper.Serialize(this);\r\n };\r\n /**\r\n * Creates a standard material from parsed material data\r\n * @param source defines the JSON representation of the material\r\n * @param scene defines the hosting scene\r\n * @param rootUrl defines the root URL to use to load textures and relative dependencies\r\n * @returns a new standard material\r\n */\r\n StandardMaterial.Parse = function (source, scene, rootUrl) {\r\n return SerializationHelper.Parse(function () { return new StandardMaterial(source.name, scene); }, source, scene, rootUrl);\r\n };\r\n Object.defineProperty(StandardMaterial, \"DiffuseTextureEnabled\", {\r\n // Flags used to enable or disable a type of texture for all Standard Materials\r\n /**\r\n * Are diffuse textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.DiffuseTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.DiffuseTextureEnabled = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"AmbientTextureEnabled\", {\r\n /**\r\n * Are ambient textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.AmbientTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.AmbientTextureEnabled = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"OpacityTextureEnabled\", {\r\n /**\r\n * Are opacity textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.OpacityTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.OpacityTextureEnabled = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"ReflectionTextureEnabled\", {\r\n /**\r\n * Are reflection textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.ReflectionTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.ReflectionTextureEnabled = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"EmissiveTextureEnabled\", {\r\n /**\r\n * Are emissive textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.EmissiveTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.EmissiveTextureEnabled = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"SpecularTextureEnabled\", {\r\n /**\r\n * Are specular textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.SpecularTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.SpecularTextureEnabled = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"BumpTextureEnabled\", {\r\n /**\r\n * Are bump textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.BumpTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.BumpTextureEnabled = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"LightmapTextureEnabled\", {\r\n /**\r\n * Are lightmap textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.LightmapTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.LightmapTextureEnabled = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"RefractionTextureEnabled\", {\r\n /**\r\n * Are refraction textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.RefractionTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.RefractionTextureEnabled = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"ColorGradingTextureEnabled\", {\r\n /**\r\n * Are color grading textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.ColorGradingTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.ColorGradingTextureEnabled = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"FresnelEnabled\", {\r\n /**\r\n * Are fresnels enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.FresnelEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.FresnelEnabled = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n __decorate([\r\n serializeAsTexture(\"diffuseTexture\")\r\n ], StandardMaterial.prototype, \"_diffuseTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesAndMiscDirty\")\r\n ], StandardMaterial.prototype, \"diffuseTexture\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"ambientTexture\")\r\n ], StandardMaterial.prototype, \"_ambientTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"ambientTexture\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"opacityTexture\")\r\n ], StandardMaterial.prototype, \"_opacityTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesAndMiscDirty\")\r\n ], StandardMaterial.prototype, \"opacityTexture\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"reflectionTexture\")\r\n ], StandardMaterial.prototype, \"_reflectionTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"reflectionTexture\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"emissiveTexture\")\r\n ], StandardMaterial.prototype, \"_emissiveTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"emissiveTexture\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"specularTexture\")\r\n ], StandardMaterial.prototype, \"_specularTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"specularTexture\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"bumpTexture\")\r\n ], StandardMaterial.prototype, \"_bumpTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"bumpTexture\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"lightmapTexture\")\r\n ], StandardMaterial.prototype, \"_lightmapTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"lightmapTexture\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"refractionTexture\")\r\n ], StandardMaterial.prototype, \"_refractionTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"refractionTexture\", void 0);\r\n __decorate([\r\n serializeAsColor3(\"ambient\")\r\n ], StandardMaterial.prototype, \"ambientColor\", void 0);\r\n __decorate([\r\n serializeAsColor3(\"diffuse\")\r\n ], StandardMaterial.prototype, \"diffuseColor\", void 0);\r\n __decorate([\r\n serializeAsColor3(\"specular\")\r\n ], StandardMaterial.prototype, \"specularColor\", void 0);\r\n __decorate([\r\n serializeAsColor3(\"emissive\")\r\n ], StandardMaterial.prototype, \"emissiveColor\", void 0);\r\n __decorate([\r\n serialize()\r\n ], StandardMaterial.prototype, \"specularPower\", void 0);\r\n __decorate([\r\n serialize(\"useAlphaFromDiffuseTexture\")\r\n ], StandardMaterial.prototype, \"_useAlphaFromDiffuseTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useAlphaFromDiffuseTexture\", void 0);\r\n __decorate([\r\n serialize(\"useEmissiveAsIllumination\")\r\n ], StandardMaterial.prototype, \"_useEmissiveAsIllumination\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useEmissiveAsIllumination\", void 0);\r\n __decorate([\r\n serialize(\"linkEmissiveWithDiffuse\")\r\n ], StandardMaterial.prototype, \"_linkEmissiveWithDiffuse\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"linkEmissiveWithDiffuse\", void 0);\r\n __decorate([\r\n serialize(\"useSpecularOverAlpha\")\r\n ], StandardMaterial.prototype, \"_useSpecularOverAlpha\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useSpecularOverAlpha\", void 0);\r\n __decorate([\r\n serialize(\"useReflectionOverAlpha\")\r\n ], StandardMaterial.prototype, \"_useReflectionOverAlpha\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useReflectionOverAlpha\", void 0);\r\n __decorate([\r\n serialize(\"disableLighting\")\r\n ], StandardMaterial.prototype, \"_disableLighting\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsLightsDirty\")\r\n ], StandardMaterial.prototype, \"disableLighting\", void 0);\r\n __decorate([\r\n serialize(\"useObjectSpaceNormalMap\")\r\n ], StandardMaterial.prototype, \"_useObjectSpaceNormalMap\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useObjectSpaceNormalMap\", void 0);\r\n __decorate([\r\n serialize(\"useParallax\")\r\n ], StandardMaterial.prototype, \"_useParallax\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useParallax\", void 0);\r\n __decorate([\r\n serialize(\"useParallaxOcclusion\")\r\n ], StandardMaterial.prototype, \"_useParallaxOcclusion\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useParallaxOcclusion\", void 0);\r\n __decorate([\r\n serialize()\r\n ], StandardMaterial.prototype, \"parallaxScaleBias\", void 0);\r\n __decorate([\r\n serialize(\"roughness\")\r\n ], StandardMaterial.prototype, \"_roughness\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"roughness\", void 0);\r\n __decorate([\r\n serialize()\r\n ], StandardMaterial.prototype, \"indexOfRefraction\", void 0);\r\n __decorate([\r\n serialize()\r\n ], StandardMaterial.prototype, \"invertRefractionY\", void 0);\r\n __decorate([\r\n serialize()\r\n ], StandardMaterial.prototype, \"alphaCutOff\", void 0);\r\n __decorate([\r\n serialize(\"useLightmapAsShadowmap\")\r\n ], StandardMaterial.prototype, \"_useLightmapAsShadowmap\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useLightmapAsShadowmap\", void 0);\r\n __decorate([\r\n serializeAsFresnelParameters(\"diffuseFresnelParameters\")\r\n ], StandardMaterial.prototype, \"_diffuseFresnelParameters\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsFresnelDirty\")\r\n ], StandardMaterial.prototype, \"diffuseFresnelParameters\", void 0);\r\n __decorate([\r\n serializeAsFresnelParameters(\"opacityFresnelParameters\")\r\n ], StandardMaterial.prototype, \"_opacityFresnelParameters\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsFresnelAndMiscDirty\")\r\n ], StandardMaterial.prototype, \"opacityFresnelParameters\", void 0);\r\n __decorate([\r\n serializeAsFresnelParameters(\"reflectionFresnelParameters\")\r\n ], StandardMaterial.prototype, \"_reflectionFresnelParameters\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsFresnelDirty\")\r\n ], StandardMaterial.prototype, \"reflectionFresnelParameters\", void 0);\r\n __decorate([\r\n serializeAsFresnelParameters(\"refractionFresnelParameters\")\r\n ], StandardMaterial.prototype, \"_refractionFresnelParameters\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsFresnelDirty\")\r\n ], StandardMaterial.prototype, \"refractionFresnelParameters\", void 0);\r\n __decorate([\r\n serializeAsFresnelParameters(\"emissiveFresnelParameters\")\r\n ], StandardMaterial.prototype, \"_emissiveFresnelParameters\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsFresnelDirty\")\r\n ], StandardMaterial.prototype, \"emissiveFresnelParameters\", void 0);\r\n __decorate([\r\n serialize(\"useReflectionFresnelFromSpecular\")\r\n ], StandardMaterial.prototype, \"_useReflectionFresnelFromSpecular\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsFresnelDirty\")\r\n ], StandardMaterial.prototype, \"useReflectionFresnelFromSpecular\", void 0);\r\n __decorate([\r\n serialize(\"useGlossinessFromSpecularMapAlpha\")\r\n ], StandardMaterial.prototype, \"_useGlossinessFromSpecularMapAlpha\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useGlossinessFromSpecularMapAlpha\", void 0);\r\n __decorate([\r\n serialize(\"maxSimultaneousLights\")\r\n ], StandardMaterial.prototype, \"_maxSimultaneousLights\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsLightsDirty\")\r\n ], StandardMaterial.prototype, \"maxSimultaneousLights\", void 0);\r\n __decorate([\r\n serialize(\"invertNormalMapX\")\r\n ], StandardMaterial.prototype, \"_invertNormalMapX\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"invertNormalMapX\", void 0);\r\n __decorate([\r\n serialize(\"invertNormalMapY\")\r\n ], StandardMaterial.prototype, \"_invertNormalMapY\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"invertNormalMapY\", void 0);\r\n __decorate([\r\n serialize(\"twoSidedLighting\")\r\n ], StandardMaterial.prototype, \"_twoSidedLighting\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"twoSidedLighting\", void 0);\r\n __decorate([\r\n serialize()\r\n ], StandardMaterial.prototype, \"useLogarithmicDepth\", null);\r\n return StandardMaterial;\r\n}(PushMaterial));\r\nexport { StandardMaterial };\r\n_TypeStore.RegisteredTypes[\"BABYLON.StandardMaterial\"] = StandardMaterial;\r\nScene.DefaultMaterialFactory = function (scene) {\r\n return new StandardMaterial(\"default material\", scene);\r\n};\r\n//# sourceMappingURL=standardMaterial.js.map","import { Vector3, Matrix } from './math.vector';\r\n/**\r\n * Represens a plane by the equation ax + by + cz + d = 0\r\n */\r\nvar Plane = /** @class */ (function () {\r\n /**\r\n * Creates a Plane object according to the given floats a, b, c, d and the plane equation : ax + by + cz + d = 0\r\n * @param a a component of the plane\r\n * @param b b component of the plane\r\n * @param c c component of the plane\r\n * @param d d component of the plane\r\n */\r\n function Plane(a, b, c, d) {\r\n this.normal = new Vector3(a, b, c);\r\n this.d = d;\r\n }\r\n /**\r\n * @returns the plane coordinates as a new array of 4 elements [a, b, c, d].\r\n */\r\n Plane.prototype.asArray = function () {\r\n return [this.normal.x, this.normal.y, this.normal.z, this.d];\r\n };\r\n // Methods\r\n /**\r\n * @returns a new plane copied from the current Plane.\r\n */\r\n Plane.prototype.clone = function () {\r\n return new Plane(this.normal.x, this.normal.y, this.normal.z, this.d);\r\n };\r\n /**\r\n * @returns the string \"Plane\".\r\n */\r\n Plane.prototype.getClassName = function () {\r\n return \"Plane\";\r\n };\r\n /**\r\n * @returns the Plane hash code.\r\n */\r\n Plane.prototype.getHashCode = function () {\r\n var hash = this.normal.getHashCode();\r\n hash = (hash * 397) ^ (this.d | 0);\r\n return hash;\r\n };\r\n /**\r\n * Normalize the current Plane in place.\r\n * @returns the updated Plane.\r\n */\r\n Plane.prototype.normalize = function () {\r\n var norm = (Math.sqrt((this.normal.x * this.normal.x) + (this.normal.y * this.normal.y) + (this.normal.z * this.normal.z)));\r\n var magnitude = 0.0;\r\n if (norm !== 0) {\r\n magnitude = 1.0 / norm;\r\n }\r\n this.normal.x *= magnitude;\r\n this.normal.y *= magnitude;\r\n this.normal.z *= magnitude;\r\n this.d *= magnitude;\r\n return this;\r\n };\r\n /**\r\n * Applies a transformation the plane and returns the result\r\n * @param transformation the transformation matrix to be applied to the plane\r\n * @returns a new Plane as the result of the transformation of the current Plane by the given matrix.\r\n */\r\n Plane.prototype.transform = function (transformation) {\r\n var transposedMatrix = Plane._TmpMatrix;\r\n Matrix.TransposeToRef(transformation, transposedMatrix);\r\n var m = transposedMatrix.m;\r\n var x = this.normal.x;\r\n var y = this.normal.y;\r\n var z = this.normal.z;\r\n var d = this.d;\r\n var normalX = x * m[0] + y * m[1] + z * m[2] + d * m[3];\r\n var normalY = x * m[4] + y * m[5] + z * m[6] + d * m[7];\r\n var normalZ = x * m[8] + y * m[9] + z * m[10] + d * m[11];\r\n var finalD = x * m[12] + y * m[13] + z * m[14] + d * m[15];\r\n return new Plane(normalX, normalY, normalZ, finalD);\r\n };\r\n /**\r\n * Calcualtte the dot product between the point and the plane normal\r\n * @param point point to calculate the dot product with\r\n * @returns the dot product (float) of the point coordinates and the plane normal.\r\n */\r\n Plane.prototype.dotCoordinate = function (point) {\r\n return ((((this.normal.x * point.x) + (this.normal.y * point.y)) + (this.normal.z * point.z)) + this.d);\r\n };\r\n /**\r\n * Updates the current Plane from the plane defined by the three given points.\r\n * @param point1 one of the points used to contruct the plane\r\n * @param point2 one of the points used to contruct the plane\r\n * @param point3 one of the points used to contruct the plane\r\n * @returns the updated Plane.\r\n */\r\n Plane.prototype.copyFromPoints = function (point1, point2, point3) {\r\n var x1 = point2.x - point1.x;\r\n var y1 = point2.y - point1.y;\r\n var z1 = point2.z - point1.z;\r\n var x2 = point3.x - point1.x;\r\n var y2 = point3.y - point1.y;\r\n var z2 = point3.z - point1.z;\r\n var yz = (y1 * z2) - (z1 * y2);\r\n var xz = (z1 * x2) - (x1 * z2);\r\n var xy = (x1 * y2) - (y1 * x2);\r\n var pyth = (Math.sqrt((yz * yz) + (xz * xz) + (xy * xy)));\r\n var invPyth;\r\n if (pyth !== 0) {\r\n invPyth = 1.0 / pyth;\r\n }\r\n else {\r\n invPyth = 0.0;\r\n }\r\n this.normal.x = yz * invPyth;\r\n this.normal.y = xz * invPyth;\r\n this.normal.z = xy * invPyth;\r\n this.d = -((this.normal.x * point1.x) + (this.normal.y * point1.y) + (this.normal.z * point1.z));\r\n return this;\r\n };\r\n /**\r\n * Checks if the plane is facing a given direction\r\n * @param direction the direction to check if the plane is facing\r\n * @param epsilon value the dot product is compared against (returns true if dot <= epsilon)\r\n * @returns True is the vector \"direction\" is the same side than the plane normal.\r\n */\r\n Plane.prototype.isFrontFacingTo = function (direction, epsilon) {\r\n var dot = Vector3.Dot(this.normal, direction);\r\n return (dot <= epsilon);\r\n };\r\n /**\r\n * Calculates the distance to a point\r\n * @param point point to calculate distance to\r\n * @returns the signed distance (float) from the given point to the Plane.\r\n */\r\n Plane.prototype.signedDistanceTo = function (point) {\r\n return Vector3.Dot(point, this.normal) + this.d;\r\n };\r\n // Statics\r\n /**\r\n * Creates a plane from an array\r\n * @param array the array to create a plane from\r\n * @returns a new Plane from the given array.\r\n */\r\n Plane.FromArray = function (array) {\r\n return new Plane(array[0], array[1], array[2], array[3]);\r\n };\r\n /**\r\n * Creates a plane from three points\r\n * @param point1 point used to create the plane\r\n * @param point2 point used to create the plane\r\n * @param point3 point used to create the plane\r\n * @returns a new Plane defined by the three given points.\r\n */\r\n Plane.FromPoints = function (point1, point2, point3) {\r\n var result = new Plane(0.0, 0.0, 0.0, 0.0);\r\n result.copyFromPoints(point1, point2, point3);\r\n return result;\r\n };\r\n /**\r\n * Creates a plane from an origin point and a normal\r\n * @param origin origin of the plane to be constructed\r\n * @param normal normal of the plane to be constructed\r\n * @returns a new Plane the normal vector to this plane at the given origin point.\r\n * Note : the vector \"normal\" is updated because normalized.\r\n */\r\n Plane.FromPositionAndNormal = function (origin, normal) {\r\n var result = new Plane(0.0, 0.0, 0.0, 0.0);\r\n normal.normalize();\r\n result.normal = normal;\r\n result.d = -(normal.x * origin.x + normal.y * origin.y + normal.z * origin.z);\r\n return result;\r\n };\r\n /**\r\n * Calculates the distance from a plane and a point\r\n * @param origin origin of the plane to be constructed\r\n * @param normal normal of the plane to be constructed\r\n * @param point point to calculate distance to\r\n * @returns the signed distance between the plane defined by the normal vector at the \"origin\"\" point and the given other point.\r\n */\r\n Plane.SignedDistanceToPlaneFromPositionAndNormal = function (origin, normal, point) {\r\n var d = -(normal.x * origin.x + normal.y * origin.y + normal.z * origin.z);\r\n return Vector3.Dot(point, normal) + d;\r\n };\r\n Plane._TmpMatrix = Matrix.Identity();\r\n return Plane;\r\n}());\r\nexport { Plane };\r\n//# sourceMappingURL=math.plane.js.map","import { Plane } from './math.plane';\r\n/**\r\n * Represents a camera frustum\r\n */\r\nvar Frustum = /** @class */ (function () {\r\n function Frustum() {\r\n }\r\n /**\r\n * Gets the planes representing the frustum\r\n * @param transform matrix to be applied to the returned planes\r\n * @returns a new array of 6 Frustum planes computed by the given transformation matrix.\r\n */\r\n Frustum.GetPlanes = function (transform) {\r\n var frustumPlanes = [];\r\n for (var index = 0; index < 6; index++) {\r\n frustumPlanes.push(new Plane(0.0, 0.0, 0.0, 0.0));\r\n }\r\n Frustum.GetPlanesToRef(transform, frustumPlanes);\r\n return frustumPlanes;\r\n };\r\n /**\r\n * Gets the near frustum plane transformed by the transform matrix\r\n * @param transform transformation matrix to be applied to the resulting frustum plane\r\n * @param frustumPlane the resuling frustum plane\r\n */\r\n Frustum.GetNearPlaneToRef = function (transform, frustumPlane) {\r\n var m = transform.m;\r\n frustumPlane.normal.x = m[3] + m[2];\r\n frustumPlane.normal.y = m[7] + m[6];\r\n frustumPlane.normal.z = m[11] + m[10];\r\n frustumPlane.d = m[15] + m[14];\r\n frustumPlane.normalize();\r\n };\r\n /**\r\n * Gets the far frustum plane transformed by the transform matrix\r\n * @param transform transformation matrix to be applied to the resulting frustum plane\r\n * @param frustumPlane the resuling frustum plane\r\n */\r\n Frustum.GetFarPlaneToRef = function (transform, frustumPlane) {\r\n var m = transform.m;\r\n frustumPlane.normal.x = m[3] - m[2];\r\n frustumPlane.normal.y = m[7] - m[6];\r\n frustumPlane.normal.z = m[11] - m[10];\r\n frustumPlane.d = m[15] - m[14];\r\n frustumPlane.normalize();\r\n };\r\n /**\r\n * Gets the left frustum plane transformed by the transform matrix\r\n * @param transform transformation matrix to be applied to the resulting frustum plane\r\n * @param frustumPlane the resuling frustum plane\r\n */\r\n Frustum.GetLeftPlaneToRef = function (transform, frustumPlane) {\r\n var m = transform.m;\r\n frustumPlane.normal.x = m[3] + m[0];\r\n frustumPlane.normal.y = m[7] + m[4];\r\n frustumPlane.normal.z = m[11] + m[8];\r\n frustumPlane.d = m[15] + m[12];\r\n frustumPlane.normalize();\r\n };\r\n /**\r\n * Gets the right frustum plane transformed by the transform matrix\r\n * @param transform transformation matrix to be applied to the resulting frustum plane\r\n * @param frustumPlane the resuling frustum plane\r\n */\r\n Frustum.GetRightPlaneToRef = function (transform, frustumPlane) {\r\n var m = transform.m;\r\n frustumPlane.normal.x = m[3] - m[0];\r\n frustumPlane.normal.y = m[7] - m[4];\r\n frustumPlane.normal.z = m[11] - m[8];\r\n frustumPlane.d = m[15] - m[12];\r\n frustumPlane.normalize();\r\n };\r\n /**\r\n * Gets the top frustum plane transformed by the transform matrix\r\n * @param transform transformation matrix to be applied to the resulting frustum plane\r\n * @param frustumPlane the resuling frustum plane\r\n */\r\n Frustum.GetTopPlaneToRef = function (transform, frustumPlane) {\r\n var m = transform.m;\r\n frustumPlane.normal.x = m[3] - m[1];\r\n frustumPlane.normal.y = m[7] - m[5];\r\n frustumPlane.normal.z = m[11] - m[9];\r\n frustumPlane.d = m[15] - m[13];\r\n frustumPlane.normalize();\r\n };\r\n /**\r\n * Gets the bottom frustum plane transformed by the transform matrix\r\n * @param transform transformation matrix to be applied to the resulting frustum plane\r\n * @param frustumPlane the resuling frustum plane\r\n */\r\n Frustum.GetBottomPlaneToRef = function (transform, frustumPlane) {\r\n var m = transform.m;\r\n frustumPlane.normal.x = m[3] + m[1];\r\n frustumPlane.normal.y = m[7] + m[5];\r\n frustumPlane.normal.z = m[11] + m[9];\r\n frustumPlane.d = m[15] + m[13];\r\n frustumPlane.normalize();\r\n };\r\n /**\r\n * Sets the given array \"frustumPlanes\" with the 6 Frustum planes computed by the given transformation matrix.\r\n * @param transform transformation matrix to be applied to the resulting frustum planes\r\n * @param frustumPlanes the resuling frustum planes\r\n */\r\n Frustum.GetPlanesToRef = function (transform, frustumPlanes) {\r\n // Near\r\n Frustum.GetNearPlaneToRef(transform, frustumPlanes[0]);\r\n // Far\r\n Frustum.GetFarPlaneToRef(transform, frustumPlanes[1]);\r\n // Left\r\n Frustum.GetLeftPlaneToRef(transform, frustumPlanes[2]);\r\n // Right\r\n Frustum.GetRightPlaneToRef(transform, frustumPlanes[3]);\r\n // Top\r\n Frustum.GetTopPlaneToRef(transform, frustumPlanes[4]);\r\n // Bottom\r\n Frustum.GetBottomPlaneToRef(transform, frustumPlanes[5]);\r\n };\r\n return Frustum;\r\n}());\r\nexport { Frustum };\r\n//# sourceMappingURL=math.frustum.js.map","import { __extends } from \"tslib\";\r\nimport { DataBuffer } from '../dataBuffer';\r\n/** @hidden */\r\nvar WebGLDataBuffer = /** @class */ (function (_super) {\r\n __extends(WebGLDataBuffer, _super);\r\n function WebGLDataBuffer(resource) {\r\n var _this = _super.call(this) || this;\r\n _this._buffer = resource;\r\n return _this;\r\n }\r\n Object.defineProperty(WebGLDataBuffer.prototype, \"underlyingResource\", {\r\n get: function () {\r\n return this._buffer;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n return WebGLDataBuffer;\r\n}(DataBuffer));\r\nexport { WebGLDataBuffer };\r\n//# sourceMappingURL=webGLDataBuffer.js.map","/**\r\n * Class used to store gfx data (like WebGLBuffer)\r\n */\r\nvar DataBuffer = /** @class */ (function () {\r\n function DataBuffer() {\r\n /**\r\n * Gets or sets the number of objects referencing this buffer\r\n */\r\n this.references = 0;\r\n /** Gets or sets the size of the underlying buffer */\r\n this.capacity = 0;\r\n /**\r\n * Gets or sets a boolean indicating if the buffer contains 32bits indices\r\n */\r\n this.is32Bits = false;\r\n }\r\n Object.defineProperty(DataBuffer.prototype, \"underlyingResource\", {\r\n /**\r\n * Gets the underlying buffer\r\n */\r\n get: function () {\r\n return null;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n return DataBuffer;\r\n}());\r\nexport { DataBuffer };\r\n//# sourceMappingURL=dataBuffer.js.map","/**\r\n * Class used to represent a viewport on screen\r\n */\r\nvar Viewport = /** @class */ (function () {\r\n /**\r\n * Creates a Viewport object located at (x, y) and sized (width, height)\r\n * @param x defines viewport left coordinate\r\n * @param y defines viewport top coordinate\r\n * @param width defines the viewport width\r\n * @param height defines the viewport height\r\n */\r\n function Viewport(\r\n /** viewport left coordinate */\r\n x, \r\n /** viewport top coordinate */\r\n y, \r\n /**viewport width */\r\n width, \r\n /** viewport height */\r\n height) {\r\n this.x = x;\r\n this.y = y;\r\n this.width = width;\r\n this.height = height;\r\n }\r\n /**\r\n * Creates a new viewport using absolute sizing (from 0-> width, 0-> height instead of 0->1)\r\n * @param renderWidth defines the rendering width\r\n * @param renderHeight defines the rendering height\r\n * @returns a new Viewport\r\n */\r\n Viewport.prototype.toGlobal = function (renderWidth, renderHeight) {\r\n return new Viewport(this.x * renderWidth, this.y * renderHeight, this.width * renderWidth, this.height * renderHeight);\r\n };\r\n /**\r\n * Stores absolute viewport value into a target viewport (from 0-> width, 0-> height instead of 0->1)\r\n * @param renderWidth defines the rendering width\r\n * @param renderHeight defines the rendering height\r\n * @param ref defines the target viewport\r\n * @returns the current viewport\r\n */\r\n Viewport.prototype.toGlobalToRef = function (renderWidth, renderHeight, ref) {\r\n ref.x = this.x * renderWidth;\r\n ref.y = this.y * renderHeight;\r\n ref.width = this.width * renderWidth;\r\n ref.height = this.height * renderHeight;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Viewport copied from the current one\r\n * @returns a new Viewport\r\n */\r\n Viewport.prototype.clone = function () {\r\n return new Viewport(this.x, this.y, this.width, this.height);\r\n };\r\n return Viewport;\r\n}());\r\nexport { Viewport };\r\n//# sourceMappingURL=math.viewport.js.map","/**\r\n * Helper class used to generate a canvas to manipulate images\r\n */\r\nvar CanvasGenerator = /** @class */ (function () {\r\n function CanvasGenerator() {\r\n }\r\n /**\r\n * Create a new canvas (or offscreen canvas depending on the context)\r\n * @param width defines the expected width\r\n * @param height defines the expected height\r\n * @return a new canvas or offscreen canvas\r\n */\r\n CanvasGenerator.CreateCanvas = function (width, height) {\r\n if (typeof document === \"undefined\") {\r\n return new OffscreenCanvas(width, height);\r\n }\r\n var canvas = document.createElement(\"canvas\");\r\n canvas.width = width;\r\n canvas.height = height;\r\n return canvas;\r\n };\r\n return CanvasGenerator;\r\n}());\r\nexport { CanvasGenerator };\r\n//# sourceMappingURL=canvasGenerator.js.map","import { PrecisionDate } from './precisionDate';\r\n/**\r\n * This class is used to track a performance counter which is number based.\r\n * The user has access to many properties which give statistics of different nature.\r\n *\r\n * The implementer can track two kinds of Performance Counter: time and count.\r\n * For time you can optionally call fetchNewFrame() to notify the start of a new frame to monitor, then call beginMonitoring() to start and endMonitoring() to record the lapsed time. endMonitoring takes a newFrame parameter for you to specify if the monitored time should be set for a new frame or accumulated to the current frame being monitored.\r\n * For count you first have to call fetchNewFrame() to notify the start of a new frame to monitor, then call addCount() how many time required to increment the count value you monitor.\r\n */\r\nvar PerfCounter = /** @class */ (function () {\r\n /**\r\n * Creates a new counter\r\n */\r\n function PerfCounter() {\r\n this._startMonitoringTime = 0;\r\n this._min = 0;\r\n this._max = 0;\r\n this._average = 0;\r\n this._lastSecAverage = 0;\r\n this._current = 0;\r\n this._totalValueCount = 0;\r\n this._totalAccumulated = 0;\r\n this._lastSecAccumulated = 0;\r\n this._lastSecTime = 0;\r\n this._lastSecValueCount = 0;\r\n }\r\n Object.defineProperty(PerfCounter.prototype, \"min\", {\r\n /**\r\n * Returns the smallest value ever\r\n */\r\n get: function () {\r\n return this._min;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerfCounter.prototype, \"max\", {\r\n /**\r\n * Returns the biggest value ever\r\n */\r\n get: function () {\r\n return this._max;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerfCounter.prototype, \"average\", {\r\n /**\r\n * Returns the average value since the performance counter is running\r\n */\r\n get: function () {\r\n return this._average;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerfCounter.prototype, \"lastSecAverage\", {\r\n /**\r\n * Returns the average value of the last second the counter was monitored\r\n */\r\n get: function () {\r\n return this._lastSecAverage;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerfCounter.prototype, \"current\", {\r\n /**\r\n * Returns the current value\r\n */\r\n get: function () {\r\n return this._current;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerfCounter.prototype, \"total\", {\r\n /**\r\n * Gets the accumulated total\r\n */\r\n get: function () {\r\n return this._totalAccumulated;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerfCounter.prototype, \"count\", {\r\n /**\r\n * Gets the total value count\r\n */\r\n get: function () {\r\n return this._totalValueCount;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Call this method to start monitoring a new frame.\r\n * This scenario is typically used when you accumulate monitoring time many times for a single frame, you call this method at the start of the frame, then beginMonitoring to start recording and endMonitoring(false) to accumulated the recorded time to the PerfCounter or addCount() to accumulate a monitored count.\r\n */\r\n PerfCounter.prototype.fetchNewFrame = function () {\r\n this._totalValueCount++;\r\n this._current = 0;\r\n this._lastSecValueCount++;\r\n };\r\n /**\r\n * Call this method to monitor a count of something (e.g. mesh drawn in viewport count)\r\n * @param newCount the count value to add to the monitored count\r\n * @param fetchResult true when it's the last time in the frame you add to the counter and you wish to update the statistics properties (min/max/average), false if you only want to update statistics.\r\n */\r\n PerfCounter.prototype.addCount = function (newCount, fetchResult) {\r\n if (!PerfCounter.Enabled) {\r\n return;\r\n }\r\n this._current += newCount;\r\n if (fetchResult) {\r\n this._fetchResult();\r\n }\r\n };\r\n /**\r\n * Start monitoring this performance counter\r\n */\r\n PerfCounter.prototype.beginMonitoring = function () {\r\n if (!PerfCounter.Enabled) {\r\n return;\r\n }\r\n this._startMonitoringTime = PrecisionDate.Now;\r\n };\r\n /**\r\n * Compute the time lapsed since the previous beginMonitoring() call.\r\n * @param newFrame true by default to fetch the result and monitor a new frame, if false the time monitored will be added to the current frame counter\r\n */\r\n PerfCounter.prototype.endMonitoring = function (newFrame) {\r\n if (newFrame === void 0) { newFrame = true; }\r\n if (!PerfCounter.Enabled) {\r\n return;\r\n }\r\n if (newFrame) {\r\n this.fetchNewFrame();\r\n }\r\n var currentTime = PrecisionDate.Now;\r\n this._current = currentTime - this._startMonitoringTime;\r\n if (newFrame) {\r\n this._fetchResult();\r\n }\r\n };\r\n PerfCounter.prototype._fetchResult = function () {\r\n this._totalAccumulated += this._current;\r\n this._lastSecAccumulated += this._current;\r\n // Min/Max update\r\n this._min = Math.min(this._min, this._current);\r\n this._max = Math.max(this._max, this._current);\r\n this._average = this._totalAccumulated / this._totalValueCount;\r\n // Reset last sec?\r\n var now = PrecisionDate.Now;\r\n if ((now - this._lastSecTime) > 1000) {\r\n this._lastSecAverage = this._lastSecAccumulated / this._lastSecValueCount;\r\n this._lastSecTime = now;\r\n this._lastSecAccumulated = 0;\r\n this._lastSecValueCount = 0;\r\n }\r\n };\r\n /**\r\n * Gets or sets a global boolean to turn on and off all the counters\r\n */\r\n PerfCounter.Enabled = true;\r\n return PerfCounter;\r\n}());\r\nexport { PerfCounter };\r\n//# sourceMappingURL=perfCounter.js.map","import { __decorate } from \"tslib\";\r\nimport { SerializationHelper, serialize } from \"../Misc/decorators\";\r\nimport { Color4 } from '../Maths/math.color';\r\n/**\r\n * The color grading curves provide additional color adjustmnent that is applied after any color grading transform (3D LUT).\r\n * They allow basic adjustment of saturation and small exposure adjustments, along with color filter tinting to provide white balance adjustment or more stylistic effects.\r\n * These are similar to controls found in many professional imaging or colorist software. The global controls are applied to the entire image. For advanced tuning, extra controls are provided to adjust the shadow, midtone and highlight areas of the image;\r\n * corresponding to low luminance, medium luminance, and high luminance areas respectively.\r\n */\r\nvar ColorCurves = /** @class */ (function () {\r\n function ColorCurves() {\r\n this._dirty = true;\r\n this._tempColor = new Color4(0, 0, 0, 0);\r\n this._globalCurve = new Color4(0, 0, 0, 0);\r\n this._highlightsCurve = new Color4(0, 0, 0, 0);\r\n this._midtonesCurve = new Color4(0, 0, 0, 0);\r\n this._shadowsCurve = new Color4(0, 0, 0, 0);\r\n this._positiveCurve = new Color4(0, 0, 0, 0);\r\n this._negativeCurve = new Color4(0, 0, 0, 0);\r\n this._globalHue = 30;\r\n this._globalDensity = 0;\r\n this._globalSaturation = 0;\r\n this._globalExposure = 0;\r\n this._highlightsHue = 30;\r\n this._highlightsDensity = 0;\r\n this._highlightsSaturation = 0;\r\n this._highlightsExposure = 0;\r\n this._midtonesHue = 30;\r\n this._midtonesDensity = 0;\r\n this._midtonesSaturation = 0;\r\n this._midtonesExposure = 0;\r\n this._shadowsHue = 30;\r\n this._shadowsDensity = 0;\r\n this._shadowsSaturation = 0;\r\n this._shadowsExposure = 0;\r\n }\r\n Object.defineProperty(ColorCurves.prototype, \"globalHue\", {\r\n /**\r\n * Gets the global Hue value.\r\n * The hue value is a standard HSB hue in the range [0,360] where 0=red, 120=green and 240=blue. The default value is 30 degrees (orange).\r\n */\r\n get: function () {\r\n return this._globalHue;\r\n },\r\n /**\r\n * Sets the global Hue value.\r\n * The hue value is a standard HSB hue in the range [0,360] where 0=red, 120=green and 240=blue. The default value is 30 degrees (orange).\r\n */\r\n set: function (value) {\r\n this._globalHue = value;\r\n this._dirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"globalDensity\", {\r\n /**\r\n * Gets the global Density value.\r\n * The density value is in range [-100,+100] where 0 means the color filter has no effect and +100 means the color filter has maximum effect.\r\n * Values less than zero provide a filter of opposite hue.\r\n */\r\n get: function () {\r\n return this._globalDensity;\r\n },\r\n /**\r\n * Sets the global Density value.\r\n * The density value is in range [-100,+100] where 0 means the color filter has no effect and +100 means the color filter has maximum effect.\r\n * Values less than zero provide a filter of opposite hue.\r\n */\r\n set: function (value) {\r\n this._globalDensity = value;\r\n this._dirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"globalSaturation\", {\r\n /**\r\n * Gets the global Saturation value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase saturation and negative values decrease saturation.\r\n */\r\n get: function () {\r\n return this._globalSaturation;\r\n },\r\n /**\r\n * Sets the global Saturation value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase saturation and negative values decrease saturation.\r\n */\r\n set: function (value) {\r\n this._globalSaturation = value;\r\n this._dirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"globalExposure\", {\r\n /**\r\n * Gets the global Exposure value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase exposure and negative values decrease exposure.\r\n */\r\n get: function () {\r\n return this._globalExposure;\r\n },\r\n /**\r\n * Sets the global Exposure value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase exposure and negative values decrease exposure.\r\n */\r\n set: function (value) {\r\n this._globalExposure = value;\r\n this._dirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"highlightsHue\", {\r\n /**\r\n * Gets the highlights Hue value.\r\n * The hue value is a standard HSB hue in the range [0,360] where 0=red, 120=green and 240=blue. The default value is 30 degrees (orange).\r\n */\r\n get: function () {\r\n return this._highlightsHue;\r\n },\r\n /**\r\n * Sets the highlights Hue value.\r\n * The hue value is a standard HSB hue in the range [0,360] where 0=red, 120=green and 240=blue. The default value is 30 degrees (orange).\r\n */\r\n set: function (value) {\r\n this._highlightsHue = value;\r\n this._dirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"highlightsDensity\", {\r\n /**\r\n * Gets the highlights Density value.\r\n * The density value is in range [-100,+100] where 0 means the color filter has no effect and +100 means the color filter has maximum effect.\r\n * Values less than zero provide a filter of opposite hue.\r\n */\r\n get: function () {\r\n return this._highlightsDensity;\r\n },\r\n /**\r\n * Sets the highlights Density value.\r\n * The density value is in range [-100,+100] where 0 means the color filter has no effect and +100 means the color filter has maximum effect.\r\n * Values less than zero provide a filter of opposite hue.\r\n */\r\n set: function (value) {\r\n this._highlightsDensity = value;\r\n this._dirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"highlightsSaturation\", {\r\n /**\r\n * Gets the highlights Saturation value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase saturation and negative values decrease saturation.\r\n */\r\n get: function () {\r\n return this._highlightsSaturation;\r\n },\r\n /**\r\n * Sets the highlights Saturation value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase saturation and negative values decrease saturation.\r\n */\r\n set: function (value) {\r\n this._highlightsSaturation = value;\r\n this._dirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"highlightsExposure\", {\r\n /**\r\n * Gets the highlights Exposure value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase exposure and negative values decrease exposure.\r\n */\r\n get: function () {\r\n return this._highlightsExposure;\r\n },\r\n /**\r\n * Sets the highlights Exposure value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase exposure and negative values decrease exposure.\r\n */\r\n set: function (value) {\r\n this._highlightsExposure = value;\r\n this._dirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"midtonesHue\", {\r\n /**\r\n * Gets the midtones Hue value.\r\n * The hue value is a standard HSB hue in the range [0,360] where 0=red, 120=green and 240=blue. The default value is 30 degrees (orange).\r\n */\r\n get: function () {\r\n return this._midtonesHue;\r\n },\r\n /**\r\n * Sets the midtones Hue value.\r\n * The hue value is a standard HSB hue in the range [0,360] where 0=red, 120=green and 240=blue. The default value is 30 degrees (orange).\r\n */\r\n set: function (value) {\r\n this._midtonesHue = value;\r\n this._dirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"midtonesDensity\", {\r\n /**\r\n * Gets the midtones Density value.\r\n * The density value is in range [-100,+100] where 0 means the color filter has no effect and +100 means the color filter has maximum effect.\r\n * Values less than zero provide a filter of opposite hue.\r\n */\r\n get: function () {\r\n return this._midtonesDensity;\r\n },\r\n /**\r\n * Sets the midtones Density value.\r\n * The density value is in range [-100,+100] where 0 means the color filter has no effect and +100 means the color filter has maximum effect.\r\n * Values less than zero provide a filter of opposite hue.\r\n */\r\n set: function (value) {\r\n this._midtonesDensity = value;\r\n this._dirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"midtonesSaturation\", {\r\n /**\r\n * Gets the midtones Saturation value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase saturation and negative values decrease saturation.\r\n */\r\n get: function () {\r\n return this._midtonesSaturation;\r\n },\r\n /**\r\n * Sets the midtones Saturation value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase saturation and negative values decrease saturation.\r\n */\r\n set: function (value) {\r\n this._midtonesSaturation = value;\r\n this._dirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"midtonesExposure\", {\r\n /**\r\n * Gets the midtones Exposure value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase exposure and negative values decrease exposure.\r\n */\r\n get: function () {\r\n return this._midtonesExposure;\r\n },\r\n /**\r\n * Sets the midtones Exposure value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase exposure and negative values decrease exposure.\r\n */\r\n set: function (value) {\r\n this._midtonesExposure = value;\r\n this._dirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"shadowsHue\", {\r\n /**\r\n * Gets the shadows Hue value.\r\n * The hue value is a standard HSB hue in the range [0,360] where 0=red, 120=green and 240=blue. The default value is 30 degrees (orange).\r\n */\r\n get: function () {\r\n return this._shadowsHue;\r\n },\r\n /**\r\n * Sets the shadows Hue value.\r\n * The hue value is a standard HSB hue in the range [0,360] where 0=red, 120=green and 240=blue. The default value is 30 degrees (orange).\r\n */\r\n set: function (value) {\r\n this._shadowsHue = value;\r\n this._dirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"shadowsDensity\", {\r\n /**\r\n * Gets the shadows Density value.\r\n * The density value is in range [-100,+100] where 0 means the color filter has no effect and +100 means the color filter has maximum effect.\r\n * Values less than zero provide a filter of opposite hue.\r\n */\r\n get: function () {\r\n return this._shadowsDensity;\r\n },\r\n /**\r\n * Sets the shadows Density value.\r\n * The density value is in range [-100,+100] where 0 means the color filter has no effect and +100 means the color filter has maximum effect.\r\n * Values less than zero provide a filter of opposite hue.\r\n */\r\n set: function (value) {\r\n this._shadowsDensity = value;\r\n this._dirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"shadowsSaturation\", {\r\n /**\r\n * Gets the shadows Saturation value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase saturation and negative values decrease saturation.\r\n */\r\n get: function () {\r\n return this._shadowsSaturation;\r\n },\r\n /**\r\n * Sets the shadows Saturation value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase saturation and negative values decrease saturation.\r\n */\r\n set: function (value) {\r\n this._shadowsSaturation = value;\r\n this._dirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"shadowsExposure\", {\r\n /**\r\n * Gets the shadows Exposure value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase exposure and negative values decrease exposure.\r\n */\r\n get: function () {\r\n return this._shadowsExposure;\r\n },\r\n /**\r\n * Sets the shadows Exposure value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase exposure and negative values decrease exposure.\r\n */\r\n set: function (value) {\r\n this._shadowsExposure = value;\r\n this._dirty = true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Returns the class name\r\n * @returns The class name\r\n */\r\n ColorCurves.prototype.getClassName = function () {\r\n return \"ColorCurves\";\r\n };\r\n /**\r\n * Binds the color curves to the shader.\r\n * @param colorCurves The color curve to bind\r\n * @param effect The effect to bind to\r\n * @param positiveUniform The positive uniform shader parameter\r\n * @param neutralUniform The neutral uniform shader parameter\r\n * @param negativeUniform The negative uniform shader parameter\r\n */\r\n ColorCurves.Bind = function (colorCurves, effect, positiveUniform, neutralUniform, negativeUniform) {\r\n if (positiveUniform === void 0) { positiveUniform = \"vCameraColorCurvePositive\"; }\r\n if (neutralUniform === void 0) { neutralUniform = \"vCameraColorCurveNeutral\"; }\r\n if (negativeUniform === void 0) { negativeUniform = \"vCameraColorCurveNegative\"; }\r\n if (colorCurves._dirty) {\r\n colorCurves._dirty = false;\r\n // Fill in global info.\r\n colorCurves.getColorGradingDataToRef(colorCurves._globalHue, colorCurves._globalDensity, colorCurves._globalSaturation, colorCurves._globalExposure, colorCurves._globalCurve);\r\n // Compute highlights info.\r\n colorCurves.getColorGradingDataToRef(colorCurves._highlightsHue, colorCurves._highlightsDensity, colorCurves._highlightsSaturation, colorCurves._highlightsExposure, colorCurves._tempColor);\r\n colorCurves._tempColor.multiplyToRef(colorCurves._globalCurve, colorCurves._highlightsCurve);\r\n // Compute midtones info.\r\n colorCurves.getColorGradingDataToRef(colorCurves._midtonesHue, colorCurves._midtonesDensity, colorCurves._midtonesSaturation, colorCurves._midtonesExposure, colorCurves._tempColor);\r\n colorCurves._tempColor.multiplyToRef(colorCurves._globalCurve, colorCurves._midtonesCurve);\r\n // Compute shadows info.\r\n colorCurves.getColorGradingDataToRef(colorCurves._shadowsHue, colorCurves._shadowsDensity, colorCurves._shadowsSaturation, colorCurves._shadowsExposure, colorCurves._tempColor);\r\n colorCurves._tempColor.multiplyToRef(colorCurves._globalCurve, colorCurves._shadowsCurve);\r\n // Compute deltas (neutral is midtones).\r\n colorCurves._highlightsCurve.subtractToRef(colorCurves._midtonesCurve, colorCurves._positiveCurve);\r\n colorCurves._midtonesCurve.subtractToRef(colorCurves._shadowsCurve, colorCurves._negativeCurve);\r\n }\r\n if (effect) {\r\n effect.setFloat4(positiveUniform, colorCurves._positiveCurve.r, colorCurves._positiveCurve.g, colorCurves._positiveCurve.b, colorCurves._positiveCurve.a);\r\n effect.setFloat4(neutralUniform, colorCurves._midtonesCurve.r, colorCurves._midtonesCurve.g, colorCurves._midtonesCurve.b, colorCurves._midtonesCurve.a);\r\n effect.setFloat4(negativeUniform, colorCurves._negativeCurve.r, colorCurves._negativeCurve.g, colorCurves._negativeCurve.b, colorCurves._negativeCurve.a);\r\n }\r\n };\r\n /**\r\n * Prepare the list of uniforms associated with the ColorCurves effects.\r\n * @param uniformsList The list of uniforms used in the effect\r\n */\r\n ColorCurves.PrepareUniforms = function (uniformsList) {\r\n uniformsList.push(\"vCameraColorCurveNeutral\", \"vCameraColorCurvePositive\", \"vCameraColorCurveNegative\");\r\n };\r\n /**\r\n * Returns color grading data based on a hue, density, saturation and exposure value.\r\n * @param filterHue The hue of the color filter.\r\n * @param filterDensity The density of the color filter.\r\n * @param saturation The saturation.\r\n * @param exposure The exposure.\r\n * @param result The result data container.\r\n */\r\n ColorCurves.prototype.getColorGradingDataToRef = function (hue, density, saturation, exposure, result) {\r\n if (hue == null) {\r\n return;\r\n }\r\n hue = ColorCurves.clamp(hue, 0, 360);\r\n density = ColorCurves.clamp(density, -100, 100);\r\n saturation = ColorCurves.clamp(saturation, -100, 100);\r\n exposure = ColorCurves.clamp(exposure, -100, 100);\r\n // Remap the slider/config filter density with non-linear mapping and also scale by half\r\n // so that the maximum filter density is only 50% control. This provides fine control\r\n // for small values and reasonable range.\r\n density = ColorCurves.applyColorGradingSliderNonlinear(density);\r\n density *= 0.5;\r\n exposure = ColorCurves.applyColorGradingSliderNonlinear(exposure);\r\n if (density < 0) {\r\n density *= -1;\r\n hue = (hue + 180) % 360;\r\n }\r\n ColorCurves.fromHSBToRef(hue, density, 50 + 0.25 * exposure, result);\r\n result.scaleToRef(2, result);\r\n result.a = 1 + 0.01 * saturation;\r\n };\r\n /**\r\n * Takes an input slider value and returns an adjusted value that provides extra control near the centre.\r\n * @param value The input slider value in range [-100,100].\r\n * @returns Adjusted value.\r\n */\r\n ColorCurves.applyColorGradingSliderNonlinear = function (value) {\r\n value /= 100;\r\n var x = Math.abs(value);\r\n x = Math.pow(x, 2);\r\n if (value < 0) {\r\n x *= -1;\r\n }\r\n x *= 100;\r\n return x;\r\n };\r\n /**\r\n * Returns an RGBA Color4 based on Hue, Saturation and Brightness (also referred to as value, HSV).\r\n * @param hue The hue (H) input.\r\n * @param saturation The saturation (S) input.\r\n * @param brightness The brightness (B) input.\r\n * @result An RGBA color represented as Vector4.\r\n */\r\n ColorCurves.fromHSBToRef = function (hue, saturation, brightness, result) {\r\n var h = ColorCurves.clamp(hue, 0, 360);\r\n var s = ColorCurves.clamp(saturation / 100, 0, 1);\r\n var v = ColorCurves.clamp(brightness / 100, 0, 1);\r\n if (s === 0) {\r\n result.r = v;\r\n result.g = v;\r\n result.b = v;\r\n }\r\n else {\r\n // sector 0 to 5\r\n h /= 60;\r\n var i = Math.floor(h);\r\n // fractional part of h\r\n var f = h - i;\r\n var p = v * (1 - s);\r\n var q = v * (1 - s * f);\r\n var t = v * (1 - s * (1 - f));\r\n switch (i) {\r\n case 0:\r\n result.r = v;\r\n result.g = t;\r\n result.b = p;\r\n break;\r\n case 1:\r\n result.r = q;\r\n result.g = v;\r\n result.b = p;\r\n break;\r\n case 2:\r\n result.r = p;\r\n result.g = v;\r\n result.b = t;\r\n break;\r\n case 3:\r\n result.r = p;\r\n result.g = q;\r\n result.b = v;\r\n break;\r\n case 4:\r\n result.r = t;\r\n result.g = p;\r\n result.b = v;\r\n break;\r\n default: // case 5:\r\n result.r = v;\r\n result.g = p;\r\n result.b = q;\r\n break;\r\n }\r\n }\r\n result.a = 1;\r\n };\r\n /**\r\n * Returns a value clamped between min and max\r\n * @param value The value to clamp\r\n * @param min The minimum of value\r\n * @param max The maximum of value\r\n * @returns The clamped value.\r\n */\r\n ColorCurves.clamp = function (value, min, max) {\r\n return Math.min(Math.max(value, min), max);\r\n };\r\n /**\r\n * Clones the current color curve instance.\r\n * @return The cloned curves\r\n */\r\n ColorCurves.prototype.clone = function () {\r\n return SerializationHelper.Clone(function () { return new ColorCurves(); }, this);\r\n };\r\n /**\r\n * Serializes the current color curve instance to a json representation.\r\n * @return a JSON representation\r\n */\r\n ColorCurves.prototype.serialize = function () {\r\n return SerializationHelper.Serialize(this);\r\n };\r\n /**\r\n * Parses the color curve from a json representation.\r\n * @param source the JSON source to parse\r\n * @return The parsed curves\r\n */\r\n ColorCurves.Parse = function (source) {\r\n return SerializationHelper.Parse(function () { return new ColorCurves(); }, source, null, null);\r\n };\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_globalHue\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_globalDensity\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_globalSaturation\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_globalExposure\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_highlightsHue\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_highlightsDensity\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_highlightsSaturation\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_highlightsExposure\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_midtonesHue\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_midtonesDensity\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_midtonesSaturation\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_midtonesExposure\", void 0);\r\n return ColorCurves;\r\n}());\r\nexport { ColorCurves };\r\n// References the dependencies.\r\nSerializationHelper._ColorCurvesParser = ColorCurves.Parse;\r\n//# sourceMappingURL=colorCurves.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, SerializationHelper, serializeAsTexture, serializeAsColorCurves, serializeAsColor4 } from \"../Misc/decorators\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { Tools } from \"../Misc/tools\";\r\nimport { Color4 } from \"../Maths/math.color\";\r\nimport { MaterialDefines } from \"../Materials/materialDefines\";\r\nimport { ColorCurves } from \"../Materials/colorCurves\";\r\n/**\r\n * @hidden\r\n */\r\nvar ImageProcessingConfigurationDefines = /** @class */ (function (_super) {\r\n __extends(ImageProcessingConfigurationDefines, _super);\r\n function ImageProcessingConfigurationDefines() {\r\n var _this = _super.call(this) || this;\r\n _this.IMAGEPROCESSING = false;\r\n _this.VIGNETTE = false;\r\n _this.VIGNETTEBLENDMODEMULTIPLY = false;\r\n _this.VIGNETTEBLENDMODEOPAQUE = false;\r\n _this.TONEMAPPING = false;\r\n _this.TONEMAPPING_ACES = false;\r\n _this.CONTRAST = false;\r\n _this.COLORCURVES = false;\r\n _this.COLORGRADING = false;\r\n _this.COLORGRADING3D = false;\r\n _this.SAMPLER3DGREENDEPTH = false;\r\n _this.SAMPLER3DBGRMAP = false;\r\n _this.IMAGEPROCESSINGPOSTPROCESS = false;\r\n _this.EXPOSURE = false;\r\n _this.rebuild();\r\n return _this;\r\n }\r\n return ImageProcessingConfigurationDefines;\r\n}(MaterialDefines));\r\nexport { ImageProcessingConfigurationDefines };\r\n/**\r\n * This groups together the common properties used for image processing either in direct forward pass\r\n * or through post processing effect depending on the use of the image processing pipeline in your scene\r\n * or not.\r\n */\r\nvar ImageProcessingConfiguration = /** @class */ (function () {\r\n function ImageProcessingConfiguration() {\r\n /**\r\n * Color curves setup used in the effect if colorCurvesEnabled is set to true\r\n */\r\n this.colorCurves = new ColorCurves();\r\n this._colorCurvesEnabled = false;\r\n this._colorGradingEnabled = false;\r\n this._colorGradingWithGreenDepth = true;\r\n this._colorGradingBGR = true;\r\n /** @hidden */\r\n this._exposure = 1.0;\r\n this._toneMappingEnabled = false;\r\n this._toneMappingType = ImageProcessingConfiguration.TONEMAPPING_STANDARD;\r\n this._contrast = 1.0;\r\n /**\r\n * Vignette stretch size.\r\n */\r\n this.vignetteStretch = 0;\r\n /**\r\n * Vignette centre X Offset.\r\n */\r\n this.vignetteCentreX = 0;\r\n /**\r\n * Vignette centre Y Offset.\r\n */\r\n this.vignetteCentreY = 0;\r\n /**\r\n * Vignette weight or intensity of the vignette effect.\r\n */\r\n this.vignetteWeight = 1.5;\r\n /**\r\n * Color of the vignette applied on the screen through the chosen blend mode (vignetteBlendMode)\r\n * if vignetteEnabled is set to true.\r\n */\r\n this.vignetteColor = new Color4(0, 0, 0, 0);\r\n /**\r\n * Camera field of view used by the Vignette effect.\r\n */\r\n this.vignetteCameraFov = 0.5;\r\n this._vignetteBlendMode = ImageProcessingConfiguration.VIGNETTEMODE_MULTIPLY;\r\n this._vignetteEnabled = false;\r\n this._applyByPostProcess = false;\r\n this._isEnabled = true;\r\n /**\r\n * An event triggered when the configuration changes and requires Shader to Update some parameters.\r\n */\r\n this.onUpdateParameters = new Observable();\r\n }\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"colorCurvesEnabled\", {\r\n /**\r\n * Gets wether the color curves effect is enabled.\r\n */\r\n get: function () {\r\n return this._colorCurvesEnabled;\r\n },\r\n /**\r\n * Sets wether the color curves effect is enabled.\r\n */\r\n set: function (value) {\r\n if (this._colorCurvesEnabled === value) {\r\n return;\r\n }\r\n this._colorCurvesEnabled = value;\r\n this._updateParameters();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"colorGradingTexture\", {\r\n /**\r\n * Color grading LUT texture used in the effect if colorGradingEnabled is set to true\r\n */\r\n get: function () {\r\n return this._colorGradingTexture;\r\n },\r\n /**\r\n * Color grading LUT texture used in the effect if colorGradingEnabled is set to true\r\n */\r\n set: function (value) {\r\n if (this._colorGradingTexture === value) {\r\n return;\r\n }\r\n this._colorGradingTexture = value;\r\n this._updateParameters();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"colorGradingEnabled\", {\r\n /**\r\n * Gets wether the color grading effect is enabled.\r\n */\r\n get: function () {\r\n return this._colorGradingEnabled;\r\n },\r\n /**\r\n * Sets wether the color grading effect is enabled.\r\n */\r\n set: function (value) {\r\n if (this._colorGradingEnabled === value) {\r\n return;\r\n }\r\n this._colorGradingEnabled = value;\r\n this._updateParameters();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"colorGradingWithGreenDepth\", {\r\n /**\r\n * Gets wether the color grading effect is using a green depth for the 3d Texture.\r\n */\r\n get: function () {\r\n return this._colorGradingWithGreenDepth;\r\n },\r\n /**\r\n * Sets wether the color grading effect is using a green depth for the 3d Texture.\r\n */\r\n set: function (value) {\r\n if (this._colorGradingWithGreenDepth === value) {\r\n return;\r\n }\r\n this._colorGradingWithGreenDepth = value;\r\n this._updateParameters();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"colorGradingBGR\", {\r\n /**\r\n * Gets wether the color grading texture contains BGR values.\r\n */\r\n get: function () {\r\n return this._colorGradingBGR;\r\n },\r\n /**\r\n * Sets wether the color grading texture contains BGR values.\r\n */\r\n set: function (value) {\r\n if (this._colorGradingBGR === value) {\r\n return;\r\n }\r\n this._colorGradingBGR = value;\r\n this._updateParameters();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"exposure\", {\r\n /**\r\n * Gets the Exposure used in the effect.\r\n */\r\n get: function () {\r\n return this._exposure;\r\n },\r\n /**\r\n * Sets the Exposure used in the effect.\r\n */\r\n set: function (value) {\r\n if (this._exposure === value) {\r\n return;\r\n }\r\n this._exposure = value;\r\n this._updateParameters();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"toneMappingEnabled\", {\r\n /**\r\n * Gets wether the tone mapping effect is enabled.\r\n */\r\n get: function () {\r\n return this._toneMappingEnabled;\r\n },\r\n /**\r\n * Sets wether the tone mapping effect is enabled.\r\n */\r\n set: function (value) {\r\n if (this._toneMappingEnabled === value) {\r\n return;\r\n }\r\n this._toneMappingEnabled = value;\r\n this._updateParameters();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"toneMappingType\", {\r\n /**\r\n * Gets the type of tone mapping effect.\r\n */\r\n get: function () {\r\n return this._toneMappingType;\r\n },\r\n /**\r\n * Sets the type of tone mapping effect used in BabylonJS.\r\n */\r\n set: function (value) {\r\n if (this._toneMappingType === value) {\r\n return;\r\n }\r\n this._toneMappingType = value;\r\n this._updateParameters();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"contrast\", {\r\n /**\r\n * Gets the contrast used in the effect.\r\n */\r\n get: function () {\r\n return this._contrast;\r\n },\r\n /**\r\n * Sets the contrast used in the effect.\r\n */\r\n set: function (value) {\r\n if (this._contrast === value) {\r\n return;\r\n }\r\n this._contrast = value;\r\n this._updateParameters();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"vignetteBlendMode\", {\r\n /**\r\n * Gets the vignette blend mode allowing different kind of effect.\r\n */\r\n get: function () {\r\n return this._vignetteBlendMode;\r\n },\r\n /**\r\n * Sets the vignette blend mode allowing different kind of effect.\r\n */\r\n set: function (value) {\r\n if (this._vignetteBlendMode === value) {\r\n return;\r\n }\r\n this._vignetteBlendMode = value;\r\n this._updateParameters();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"vignetteEnabled\", {\r\n /**\r\n * Gets wether the vignette effect is enabled.\r\n */\r\n get: function () {\r\n return this._vignetteEnabled;\r\n },\r\n /**\r\n * Sets wether the vignette effect is enabled.\r\n */\r\n set: function (value) {\r\n if (this._vignetteEnabled === value) {\r\n return;\r\n }\r\n this._vignetteEnabled = value;\r\n this._updateParameters();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"applyByPostProcess\", {\r\n /**\r\n * Gets wether the image processing is applied through a post process or not.\r\n */\r\n get: function () {\r\n return this._applyByPostProcess;\r\n },\r\n /**\r\n * Sets wether the image processing is applied through a post process or not.\r\n */\r\n set: function (value) {\r\n if (this._applyByPostProcess === value) {\r\n return;\r\n }\r\n this._applyByPostProcess = value;\r\n this._updateParameters();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"isEnabled\", {\r\n /**\r\n * Gets wether the image processing is enabled or not.\r\n */\r\n get: function () {\r\n return this._isEnabled;\r\n },\r\n /**\r\n * Sets wether the image processing is enabled or not.\r\n */\r\n set: function (value) {\r\n if (this._isEnabled === value) {\r\n return;\r\n }\r\n this._isEnabled = value;\r\n this._updateParameters();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Method called each time the image processing information changes requires to recompile the effect.\r\n */\r\n ImageProcessingConfiguration.prototype._updateParameters = function () {\r\n this.onUpdateParameters.notifyObservers(this);\r\n };\r\n /**\r\n * Gets the current class name.\r\n * @return \"ImageProcessingConfiguration\"\r\n */\r\n ImageProcessingConfiguration.prototype.getClassName = function () {\r\n return \"ImageProcessingConfiguration\";\r\n };\r\n /**\r\n * Prepare the list of uniforms associated with the Image Processing effects.\r\n * @param uniforms The list of uniforms used in the effect\r\n * @param defines the list of defines currently in use\r\n */\r\n ImageProcessingConfiguration.PrepareUniforms = function (uniforms, defines) {\r\n if (defines.EXPOSURE) {\r\n uniforms.push(\"exposureLinear\");\r\n }\r\n if (defines.CONTRAST) {\r\n uniforms.push(\"contrast\");\r\n }\r\n if (defines.COLORGRADING) {\r\n uniforms.push(\"colorTransformSettings\");\r\n }\r\n if (defines.VIGNETTE) {\r\n uniforms.push(\"vInverseScreenSize\");\r\n uniforms.push(\"vignetteSettings1\");\r\n uniforms.push(\"vignetteSettings2\");\r\n }\r\n if (defines.COLORCURVES) {\r\n ColorCurves.PrepareUniforms(uniforms);\r\n }\r\n };\r\n /**\r\n * Prepare the list of samplers associated with the Image Processing effects.\r\n * @param samplersList The list of uniforms used in the effect\r\n * @param defines the list of defines currently in use\r\n */\r\n ImageProcessingConfiguration.PrepareSamplers = function (samplersList, defines) {\r\n if (defines.COLORGRADING) {\r\n samplersList.push(\"txColorTransform\");\r\n }\r\n };\r\n /**\r\n * Prepare the list of defines associated to the shader.\r\n * @param defines the list of defines to complete\r\n * @param forPostProcess Define if we are currently in post process mode or not\r\n */\r\n ImageProcessingConfiguration.prototype.prepareDefines = function (defines, forPostProcess) {\r\n if (forPostProcess === void 0) { forPostProcess = false; }\r\n if (forPostProcess !== this.applyByPostProcess || !this._isEnabled) {\r\n defines.VIGNETTE = false;\r\n defines.TONEMAPPING = false;\r\n defines.TONEMAPPING_ACES = false;\r\n defines.CONTRAST = false;\r\n defines.EXPOSURE = false;\r\n defines.COLORCURVES = false;\r\n defines.COLORGRADING = false;\r\n defines.COLORGRADING3D = false;\r\n defines.IMAGEPROCESSING = false;\r\n defines.IMAGEPROCESSINGPOSTPROCESS = this.applyByPostProcess && this._isEnabled;\r\n return;\r\n }\r\n defines.VIGNETTE = this.vignetteEnabled;\r\n defines.VIGNETTEBLENDMODEMULTIPLY = (this.vignetteBlendMode === ImageProcessingConfiguration._VIGNETTEMODE_MULTIPLY);\r\n defines.VIGNETTEBLENDMODEOPAQUE = !defines.VIGNETTEBLENDMODEMULTIPLY;\r\n defines.TONEMAPPING = this.toneMappingEnabled;\r\n switch (this._toneMappingType) {\r\n case ImageProcessingConfiguration.TONEMAPPING_ACES:\r\n defines.TONEMAPPING_ACES = true;\r\n break;\r\n default:\r\n defines.TONEMAPPING_ACES = false;\r\n break;\r\n }\r\n defines.CONTRAST = (this.contrast !== 1.0);\r\n defines.EXPOSURE = (this.exposure !== 1.0);\r\n defines.COLORCURVES = (this.colorCurvesEnabled && !!this.colorCurves);\r\n defines.COLORGRADING = (this.colorGradingEnabled && !!this.colorGradingTexture);\r\n if (defines.COLORGRADING) {\r\n defines.COLORGRADING3D = this.colorGradingTexture.is3D;\r\n }\r\n else {\r\n defines.COLORGRADING3D = false;\r\n }\r\n defines.SAMPLER3DGREENDEPTH = this.colorGradingWithGreenDepth;\r\n defines.SAMPLER3DBGRMAP = this.colorGradingBGR;\r\n defines.IMAGEPROCESSINGPOSTPROCESS = this.applyByPostProcess;\r\n defines.IMAGEPROCESSING = defines.VIGNETTE || defines.TONEMAPPING || defines.CONTRAST || defines.EXPOSURE || defines.COLORCURVES || defines.COLORGRADING;\r\n };\r\n /**\r\n * Returns true if all the image processing information are ready.\r\n * @returns True if ready, otherwise, false\r\n */\r\n ImageProcessingConfiguration.prototype.isReady = function () {\r\n // Color Grading texure can not be none blocking.\r\n return !this.colorGradingEnabled || !this.colorGradingTexture || this.colorGradingTexture.isReady();\r\n };\r\n /**\r\n * Binds the image processing to the shader.\r\n * @param effect The effect to bind to\r\n * @param overrideAspectRatio Override the aspect ratio of the effect\r\n */\r\n ImageProcessingConfiguration.prototype.bind = function (effect, overrideAspectRatio) {\r\n // Color Curves\r\n if (this._colorCurvesEnabled && this.colorCurves) {\r\n ColorCurves.Bind(this.colorCurves, effect);\r\n }\r\n // Vignette\r\n if (this._vignetteEnabled) {\r\n var inverseWidth = 1 / effect.getEngine().getRenderWidth();\r\n var inverseHeight = 1 / effect.getEngine().getRenderHeight();\r\n effect.setFloat2(\"vInverseScreenSize\", inverseWidth, inverseHeight);\r\n var aspectRatio = overrideAspectRatio != null ? overrideAspectRatio : (inverseHeight / inverseWidth);\r\n var vignetteScaleY = Math.tan(this.vignetteCameraFov * 0.5);\r\n var vignetteScaleX = vignetteScaleY * aspectRatio;\r\n var vignetteScaleGeometricMean = Math.sqrt(vignetteScaleX * vignetteScaleY);\r\n vignetteScaleX = Tools.Mix(vignetteScaleX, vignetteScaleGeometricMean, this.vignetteStretch);\r\n vignetteScaleY = Tools.Mix(vignetteScaleY, vignetteScaleGeometricMean, this.vignetteStretch);\r\n effect.setFloat4(\"vignetteSettings1\", vignetteScaleX, vignetteScaleY, -vignetteScaleX * this.vignetteCentreX, -vignetteScaleY * this.vignetteCentreY);\r\n var vignettePower = -2.0 * this.vignetteWeight;\r\n effect.setFloat4(\"vignetteSettings2\", this.vignetteColor.r, this.vignetteColor.g, this.vignetteColor.b, vignettePower);\r\n }\r\n // Exposure\r\n effect.setFloat(\"exposureLinear\", this.exposure);\r\n // Contrast\r\n effect.setFloat(\"contrast\", this.contrast);\r\n // Color transform settings\r\n if (this.colorGradingTexture) {\r\n effect.setTexture(\"txColorTransform\", this.colorGradingTexture);\r\n var textureSize = this.colorGradingTexture.getSize().height;\r\n effect.setFloat4(\"colorTransformSettings\", (textureSize - 1) / textureSize, // textureScale\r\n 0.5 / textureSize, // textureOffset\r\n textureSize, // textureSize\r\n this.colorGradingTexture.level // weight\r\n );\r\n }\r\n };\r\n /**\r\n * Clones the current image processing instance.\r\n * @return The cloned image processing\r\n */\r\n ImageProcessingConfiguration.prototype.clone = function () {\r\n return SerializationHelper.Clone(function () { return new ImageProcessingConfiguration(); }, this);\r\n };\r\n /**\r\n * Serializes the current image processing instance to a json representation.\r\n * @return a JSON representation\r\n */\r\n ImageProcessingConfiguration.prototype.serialize = function () {\r\n return SerializationHelper.Serialize(this);\r\n };\r\n /**\r\n * Parses the image processing from a json representation.\r\n * @param source the JSON source to parse\r\n * @return The parsed image processing\r\n */\r\n ImageProcessingConfiguration.Parse = function (source) {\r\n return SerializationHelper.Parse(function () { return new ImageProcessingConfiguration(); }, source, null, null);\r\n };\r\n Object.defineProperty(ImageProcessingConfiguration, \"VIGNETTEMODE_MULTIPLY\", {\r\n /**\r\n * Used to apply the vignette as a mix with the pixel color.\r\n */\r\n get: function () {\r\n return this._VIGNETTEMODE_MULTIPLY;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration, \"VIGNETTEMODE_OPAQUE\", {\r\n /**\r\n * Used to apply the vignette as a replacement of the pixel color.\r\n */\r\n get: function () {\r\n return this._VIGNETTEMODE_OPAQUE;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Default tone mapping applied in BabylonJS.\r\n */\r\n ImageProcessingConfiguration.TONEMAPPING_STANDARD = 0;\r\n /**\r\n * ACES Tone mapping (used by default in unreal and unity). This can help getting closer\r\n * to other engines rendering to increase portability.\r\n */\r\n ImageProcessingConfiguration.TONEMAPPING_ACES = 1;\r\n // Static constants associated to the image processing.\r\n ImageProcessingConfiguration._VIGNETTEMODE_MULTIPLY = 0;\r\n ImageProcessingConfiguration._VIGNETTEMODE_OPAQUE = 1;\r\n __decorate([\r\n serializeAsColorCurves()\r\n ], ImageProcessingConfiguration.prototype, \"colorCurves\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_colorCurvesEnabled\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"colorGradingTexture\")\r\n ], ImageProcessingConfiguration.prototype, \"_colorGradingTexture\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_colorGradingEnabled\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_colorGradingWithGreenDepth\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_colorGradingBGR\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_exposure\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_toneMappingEnabled\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_toneMappingType\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_contrast\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"vignetteStretch\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"vignetteCentreX\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"vignetteCentreY\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"vignetteWeight\", void 0);\r\n __decorate([\r\n serializeAsColor4()\r\n ], ImageProcessingConfiguration.prototype, \"vignetteColor\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"vignetteCameraFov\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_vignetteBlendMode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_vignetteEnabled\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_applyByPostProcess\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_isEnabled\", void 0);\r\n return ImageProcessingConfiguration;\r\n}());\r\nexport { ImageProcessingConfiguration };\r\n// References the dependencies.\r\nSerializationHelper._ImageProcessingConfigurationParser = ImageProcessingConfiguration.Parse;\r\n//# sourceMappingURL=imageProcessingConfiguration.js.map","import { Vector3, Vector2 } from './math.vector';\r\n/**\r\n * Contains position and normal vectors for a vertex\r\n */\r\nvar PositionNormalVertex = /** @class */ (function () {\r\n /**\r\n * Creates a PositionNormalVertex\r\n * @param position the position of the vertex (defaut: 0,0,0)\r\n * @param normal the normal of the vertex (defaut: 0,1,0)\r\n */\r\n function PositionNormalVertex(\r\n /** the position of the vertex (defaut: 0,0,0) */\r\n position, \r\n /** the normal of the vertex (defaut: 0,1,0) */\r\n normal) {\r\n if (position === void 0) { position = Vector3.Zero(); }\r\n if (normal === void 0) { normal = Vector3.Up(); }\r\n this.position = position;\r\n this.normal = normal;\r\n }\r\n /**\r\n * Clones the PositionNormalVertex\r\n * @returns the cloned PositionNormalVertex\r\n */\r\n PositionNormalVertex.prototype.clone = function () {\r\n return new PositionNormalVertex(this.position.clone(), this.normal.clone());\r\n };\r\n return PositionNormalVertex;\r\n}());\r\nexport { PositionNormalVertex };\r\n/**\r\n * Contains position, normal and uv vectors for a vertex\r\n */\r\nvar PositionNormalTextureVertex = /** @class */ (function () {\r\n /**\r\n * Creates a PositionNormalTextureVertex\r\n * @param position the position of the vertex (defaut: 0,0,0)\r\n * @param normal the normal of the vertex (defaut: 0,1,0)\r\n * @param uv the uv of the vertex (default: 0,0)\r\n */\r\n function PositionNormalTextureVertex(\r\n /** the position of the vertex (defaut: 0,0,0) */\r\n position, \r\n /** the normal of the vertex (defaut: 0,1,0) */\r\n normal, \r\n /** the uv of the vertex (default: 0,0) */\r\n uv) {\r\n if (position === void 0) { position = Vector3.Zero(); }\r\n if (normal === void 0) { normal = Vector3.Up(); }\r\n if (uv === void 0) { uv = Vector2.Zero(); }\r\n this.position = position;\r\n this.normal = normal;\r\n this.uv = uv;\r\n }\r\n /**\r\n * Clones the PositionNormalTextureVertex\r\n * @returns the cloned PositionNormalTextureVertex\r\n */\r\n PositionNormalTextureVertex.prototype.clone = function () {\r\n return new PositionNormalTextureVertex(this.position.clone(), this.normal.clone(), this.uv.clone());\r\n };\r\n return PositionNormalTextureVertex;\r\n}());\r\nexport { PositionNormalTextureVertex };\r\n//# sourceMappingURL=math.vertexFormat.js.map","import { StringTools } from './stringTools';\r\nvar cloneValue = function (source, destinationObject) {\r\n if (!source) {\r\n return null;\r\n }\r\n if (source.getClassName && source.getClassName() === \"Mesh\") {\r\n return null;\r\n }\r\n if (source.getClassName && source.getClassName() === \"SubMesh\") {\r\n return source.clone(destinationObject);\r\n }\r\n else if (source.clone) {\r\n return source.clone();\r\n }\r\n return null;\r\n};\r\n/**\r\n * Class containing a set of static utilities functions for deep copy.\r\n */\r\nvar DeepCopier = /** @class */ (function () {\r\n function DeepCopier() {\r\n }\r\n /**\r\n * Tries to copy an object by duplicating every property\r\n * @param source defines the source object\r\n * @param destination defines the target object\r\n * @param doNotCopyList defines a list of properties to avoid\r\n * @param mustCopyList defines a list of properties to copy (even if they start with _)\r\n */\r\n DeepCopier.DeepCopy = function (source, destination, doNotCopyList, mustCopyList) {\r\n for (var prop in source) {\r\n if (prop[0] === \"_\" && (!mustCopyList || mustCopyList.indexOf(prop) === -1)) {\r\n continue;\r\n }\r\n if (StringTools.EndsWith(prop, \"Observable\")) {\r\n continue;\r\n }\r\n if (doNotCopyList && doNotCopyList.indexOf(prop) !== -1) {\r\n continue;\r\n }\r\n var sourceValue = source[prop];\r\n var typeOfSourceValue = typeof sourceValue;\r\n if (typeOfSourceValue === \"function\") {\r\n continue;\r\n }\r\n try {\r\n if (typeOfSourceValue === \"object\") {\r\n if (sourceValue instanceof Array) {\r\n destination[prop] = [];\r\n if (sourceValue.length > 0) {\r\n if (typeof sourceValue[0] == \"object\") {\r\n for (var index = 0; index < sourceValue.length; index++) {\r\n var clonedValue = cloneValue(sourceValue[index], destination);\r\n if (destination[prop].indexOf(clonedValue) === -1) { // Test if auto inject was not done\r\n destination[prop].push(clonedValue);\r\n }\r\n }\r\n }\r\n else {\r\n destination[prop] = sourceValue.slice(0);\r\n }\r\n }\r\n }\r\n else {\r\n destination[prop] = cloneValue(sourceValue, destination);\r\n }\r\n }\r\n else {\r\n destination[prop] = sourceValue;\r\n }\r\n }\r\n catch (e) {\r\n // Just ignore error (it could be because of a read-only property)\r\n }\r\n }\r\n };\r\n return DeepCopier;\r\n}());\r\nexport { DeepCopier };\r\n//# sourceMappingURL=deepCopier.js.map","import { Vector3 } from './math.vector';\r\n/**\r\n * Extracts minimum and maximum values from a list of indexed positions\r\n * @param positions defines the positions to use\r\n * @param indices defines the indices to the positions\r\n * @param indexStart defines the start index\r\n * @param indexCount defines the end index\r\n * @param bias defines bias value to add to the result\r\n * @return minimum and maximum values\r\n */\r\nexport function extractMinAndMaxIndexed(positions, indices, indexStart, indexCount, bias) {\r\n if (bias === void 0) { bias = null; }\r\n var minimum = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n var maximum = new Vector3(-Number.MAX_VALUE, -Number.MAX_VALUE, -Number.MAX_VALUE);\r\n for (var index = indexStart; index < indexStart + indexCount; index++) {\r\n var offset = indices[index] * 3;\r\n var x = positions[offset];\r\n var y = positions[offset + 1];\r\n var z = positions[offset + 2];\r\n minimum.minimizeInPlaceFromFloats(x, y, z);\r\n maximum.maximizeInPlaceFromFloats(x, y, z);\r\n }\r\n if (bias) {\r\n minimum.x -= minimum.x * bias.x + bias.y;\r\n minimum.y -= minimum.y * bias.x + bias.y;\r\n minimum.z -= minimum.z * bias.x + bias.y;\r\n maximum.x += maximum.x * bias.x + bias.y;\r\n maximum.y += maximum.y * bias.x + bias.y;\r\n maximum.z += maximum.z * bias.x + bias.y;\r\n }\r\n return {\r\n minimum: minimum,\r\n maximum: maximum\r\n };\r\n}\r\n/**\r\n * Extracts minimum and maximum values from a list of positions\r\n * @param positions defines the positions to use\r\n * @param start defines the start index in the positions array\r\n * @param count defines the number of positions to handle\r\n * @param bias defines bias value to add to the result\r\n * @param stride defines the stride size to use (distance between two positions in the positions array)\r\n * @return minimum and maximum values\r\n */\r\nexport function extractMinAndMax(positions, start, count, bias, stride) {\r\n if (bias === void 0) { bias = null; }\r\n var minimum = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n var maximum = new Vector3(-Number.MAX_VALUE, -Number.MAX_VALUE, -Number.MAX_VALUE);\r\n if (!stride) {\r\n stride = 3;\r\n }\r\n for (var index = start, offset = start * stride; index < start + count; index++, offset += stride) {\r\n var x = positions[offset];\r\n var y = positions[offset + 1];\r\n var z = positions[offset + 2];\r\n minimum.minimizeInPlaceFromFloats(x, y, z);\r\n maximum.maximizeInPlaceFromFloats(x, y, z);\r\n }\r\n if (bias) {\r\n minimum.x -= minimum.x * bias.x + bias.y;\r\n minimum.y -= minimum.y * bias.x + bias.y;\r\n minimum.z -= minimum.z * bias.x + bias.y;\r\n maximum.x += maximum.x * bias.x + bias.y;\r\n maximum.y += maximum.y * bias.x + bias.y;\r\n maximum.z += maximum.z * bias.x + bias.y;\r\n }\r\n return {\r\n minimum: minimum,\r\n maximum: maximum\r\n };\r\n}\r\n//# sourceMappingURL=math.functions.js.map","import { ThinEngine } from \"../../Engines/thinEngine\";\r\nimport { WebGLDataBuffer } from '../../Meshes/WebGL/webGLDataBuffer';\r\nThinEngine.prototype.createUniformBuffer = function (elements) {\r\n var ubo = this._gl.createBuffer();\r\n if (!ubo) {\r\n throw new Error(\"Unable to create uniform buffer\");\r\n }\r\n var result = new WebGLDataBuffer(ubo);\r\n this.bindUniformBuffer(result);\r\n if (elements instanceof Float32Array) {\r\n this._gl.bufferData(this._gl.UNIFORM_BUFFER, elements, this._gl.STATIC_DRAW);\r\n }\r\n else {\r\n this._gl.bufferData(this._gl.UNIFORM_BUFFER, new Float32Array(elements), this._gl.STATIC_DRAW);\r\n }\r\n this.bindUniformBuffer(null);\r\n result.references = 1;\r\n return result;\r\n};\r\nThinEngine.prototype.createDynamicUniformBuffer = function (elements) {\r\n var ubo = this._gl.createBuffer();\r\n if (!ubo) {\r\n throw new Error(\"Unable to create dynamic uniform buffer\");\r\n }\r\n var result = new WebGLDataBuffer(ubo);\r\n this.bindUniformBuffer(result);\r\n if (elements instanceof Float32Array) {\r\n this._gl.bufferData(this._gl.UNIFORM_BUFFER, elements, this._gl.DYNAMIC_DRAW);\r\n }\r\n else {\r\n this._gl.bufferData(this._gl.UNIFORM_BUFFER, new Float32Array(elements), this._gl.DYNAMIC_DRAW);\r\n }\r\n this.bindUniformBuffer(null);\r\n result.references = 1;\r\n return result;\r\n};\r\nThinEngine.prototype.updateUniformBuffer = function (uniformBuffer, elements, offset, count) {\r\n this.bindUniformBuffer(uniformBuffer);\r\n if (offset === undefined) {\r\n offset = 0;\r\n }\r\n if (count === undefined) {\r\n if (elements instanceof Float32Array) {\r\n this._gl.bufferSubData(this._gl.UNIFORM_BUFFER, offset, elements);\r\n }\r\n else {\r\n this._gl.bufferSubData(this._gl.UNIFORM_BUFFER, offset, new Float32Array(elements));\r\n }\r\n }\r\n else {\r\n if (elements instanceof Float32Array) {\r\n this._gl.bufferSubData(this._gl.UNIFORM_BUFFER, 0, elements.subarray(offset, offset + count));\r\n }\r\n else {\r\n this._gl.bufferSubData(this._gl.UNIFORM_BUFFER, 0, new Float32Array(elements).subarray(offset, offset + count));\r\n }\r\n }\r\n this.bindUniformBuffer(null);\r\n};\r\nThinEngine.prototype.bindUniformBuffer = function (buffer) {\r\n this._gl.bindBuffer(this._gl.UNIFORM_BUFFER, buffer ? buffer.underlyingResource : null);\r\n};\r\nThinEngine.prototype.bindUniformBufferBase = function (buffer, location) {\r\n this._gl.bindBufferBase(this._gl.UNIFORM_BUFFER, location, buffer ? buffer.underlyingResource : null);\r\n};\r\nThinEngine.prototype.bindUniformBlock = function (pipelineContext, blockName, index) {\r\n var program = pipelineContext.program;\r\n var uniformLocation = this._gl.getUniformBlockIndex(program, blockName);\r\n this._gl.uniformBlockBinding(program, uniformLocation, index);\r\n};\r\n//# sourceMappingURL=engine.uniformBuffer.js.map","import { Logger } from \"../Misc/logger\";\r\nimport \"../Engines/Extensions/engine.uniformBuffer\";\r\n/**\r\n * Uniform buffer objects.\r\n *\r\n * Handles blocks of uniform on the GPU.\r\n *\r\n * If WebGL 2 is not available, this class falls back on traditionnal setUniformXXX calls.\r\n *\r\n * For more information, please refer to :\r\n * https://www.khronos.org/opengl/wiki/Uniform_Buffer_Object\r\n */\r\nvar UniformBuffer = /** @class */ (function () {\r\n /**\r\n * Instantiates a new Uniform buffer objects.\r\n *\r\n * Handles blocks of uniform on the GPU.\r\n *\r\n * If WebGL 2 is not available, this class falls back on traditionnal setUniformXXX calls.\r\n *\r\n * For more information, please refer to :\r\n * @see https://www.khronos.org/opengl/wiki/Uniform_Buffer_Object\r\n * @param engine Define the engine the buffer is associated with\r\n * @param data Define the data contained in the buffer\r\n * @param dynamic Define if the buffer is updatable\r\n */\r\n function UniformBuffer(engine, data, dynamic) {\r\n /** @hidden */\r\n this._alreadyBound = false;\r\n // Matrix cache\r\n this._valueCache = {};\r\n this._engine = engine;\r\n this._noUBO = !engine.supportsUniformBuffers;\r\n this._dynamic = dynamic;\r\n this._data = data || [];\r\n this._uniformLocations = {};\r\n this._uniformSizes = {};\r\n this._uniformLocationPointer = 0;\r\n this._needSync = false;\r\n if (this._noUBO) {\r\n this.updateMatrix3x3 = this._updateMatrix3x3ForEffect;\r\n this.updateMatrix2x2 = this._updateMatrix2x2ForEffect;\r\n this.updateFloat = this._updateFloatForEffect;\r\n this.updateFloat2 = this._updateFloat2ForEffect;\r\n this.updateFloat3 = this._updateFloat3ForEffect;\r\n this.updateFloat4 = this._updateFloat4ForEffect;\r\n this.updateMatrix = this._updateMatrixForEffect;\r\n this.updateVector3 = this._updateVector3ForEffect;\r\n this.updateVector4 = this._updateVector4ForEffect;\r\n this.updateColor3 = this._updateColor3ForEffect;\r\n this.updateColor4 = this._updateColor4ForEffect;\r\n }\r\n else {\r\n this._engine._uniformBuffers.push(this);\r\n this.updateMatrix3x3 = this._updateMatrix3x3ForUniform;\r\n this.updateMatrix2x2 = this._updateMatrix2x2ForUniform;\r\n this.updateFloat = this._updateFloatForUniform;\r\n this.updateFloat2 = this._updateFloat2ForUniform;\r\n this.updateFloat3 = this._updateFloat3ForUniform;\r\n this.updateFloat4 = this._updateFloat4ForUniform;\r\n this.updateMatrix = this._updateMatrixForUniform;\r\n this.updateVector3 = this._updateVector3ForUniform;\r\n this.updateVector4 = this._updateVector4ForUniform;\r\n this.updateColor3 = this._updateColor3ForUniform;\r\n this.updateColor4 = this._updateColor4ForUniform;\r\n }\r\n }\r\n Object.defineProperty(UniformBuffer.prototype, \"useUbo\", {\r\n /**\r\n * Indicates if the buffer is using the WebGL2 UBO implementation,\r\n * or just falling back on setUniformXXX calls.\r\n */\r\n get: function () {\r\n return !this._noUBO;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(UniformBuffer.prototype, \"isSync\", {\r\n /**\r\n * Indicates if the WebGL underlying uniform buffer is in sync\r\n * with the javascript cache data.\r\n */\r\n get: function () {\r\n return !this._needSync;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Indicates if the WebGL underlying uniform buffer is dynamic.\r\n * Also, a dynamic UniformBuffer will disable cache verification and always\r\n * update the underlying WebGL uniform buffer to the GPU.\r\n * @returns if Dynamic, otherwise false\r\n */\r\n UniformBuffer.prototype.isDynamic = function () {\r\n return this._dynamic !== undefined;\r\n };\r\n /**\r\n * The data cache on JS side.\r\n * @returns the underlying data as a float array\r\n */\r\n UniformBuffer.prototype.getData = function () {\r\n return this._bufferData;\r\n };\r\n /**\r\n * The underlying WebGL Uniform buffer.\r\n * @returns the webgl buffer\r\n */\r\n UniformBuffer.prototype.getBuffer = function () {\r\n return this._buffer;\r\n };\r\n /**\r\n * std140 layout specifies how to align data within an UBO structure.\r\n * See https://khronos.org/registry/OpenGL/specs/gl/glspec45.core.pdf#page=159\r\n * for specs.\r\n */\r\n UniformBuffer.prototype._fillAlignment = function (size) {\r\n // This code has been simplified because we only use floats, vectors of 1, 2, 3, 4 components\r\n // and 4x4 matrices\r\n // TODO : change if other types are used\r\n var alignment;\r\n if (size <= 2) {\r\n alignment = size;\r\n }\r\n else {\r\n alignment = 4;\r\n }\r\n if ((this._uniformLocationPointer % alignment) !== 0) {\r\n var oldPointer = this._uniformLocationPointer;\r\n this._uniformLocationPointer += alignment - (this._uniformLocationPointer % alignment);\r\n var diff = this._uniformLocationPointer - oldPointer;\r\n for (var i = 0; i < diff; i++) {\r\n this._data.push(0);\r\n }\r\n }\r\n };\r\n /**\r\n * Adds an uniform in the buffer.\r\n * Warning : the subsequents calls of this function must be in the same order as declared in the shader\r\n * for the layout to be correct !\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n * @param size Data size, or data directly.\r\n */\r\n UniformBuffer.prototype.addUniform = function (name, size) {\r\n if (this._noUBO) {\r\n return;\r\n }\r\n if (this._uniformLocations[name] !== undefined) {\r\n // Already existing uniform\r\n return;\r\n }\r\n // This function must be called in the order of the shader layout !\r\n // size can be the size of the uniform, or data directly\r\n var data;\r\n if (size instanceof Array) {\r\n data = size;\r\n size = data.length;\r\n }\r\n else {\r\n size = size;\r\n data = [];\r\n // Fill with zeros\r\n for (var i = 0; i < size; i++) {\r\n data.push(0);\r\n }\r\n }\r\n this._fillAlignment(size);\r\n this._uniformSizes[name] = size;\r\n this._uniformLocations[name] = this._uniformLocationPointer;\r\n this._uniformLocationPointer += size;\r\n for (var i = 0; i < size; i++) {\r\n this._data.push(data[i]);\r\n }\r\n this._needSync = true;\r\n };\r\n /**\r\n * Adds a Matrix 4x4 to the uniform buffer.\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n * @param mat A 4x4 matrix.\r\n */\r\n UniformBuffer.prototype.addMatrix = function (name, mat) {\r\n this.addUniform(name, Array.prototype.slice.call(mat.toArray()));\r\n };\r\n /**\r\n * Adds a vec2 to the uniform buffer.\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n * @param x Define the x component value of the vec2\r\n * @param y Define the y component value of the vec2\r\n */\r\n UniformBuffer.prototype.addFloat2 = function (name, x, y) {\r\n var temp = [x, y];\r\n this.addUniform(name, temp);\r\n };\r\n /**\r\n * Adds a vec3 to the uniform buffer.\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n * @param x Define the x component value of the vec3\r\n * @param y Define the y component value of the vec3\r\n * @param z Define the z component value of the vec3\r\n */\r\n UniformBuffer.prototype.addFloat3 = function (name, x, y, z) {\r\n var temp = [x, y, z];\r\n this.addUniform(name, temp);\r\n };\r\n /**\r\n * Adds a vec3 to the uniform buffer.\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n * @param color Define the vec3 from a Color\r\n */\r\n UniformBuffer.prototype.addColor3 = function (name, color) {\r\n var temp = new Array();\r\n color.toArray(temp);\r\n this.addUniform(name, temp);\r\n };\r\n /**\r\n * Adds a vec4 to the uniform buffer.\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n * @param color Define the rgb components from a Color\r\n * @param alpha Define the a component of the vec4\r\n */\r\n UniformBuffer.prototype.addColor4 = function (name, color, alpha) {\r\n var temp = new Array();\r\n color.toArray(temp);\r\n temp.push(alpha);\r\n this.addUniform(name, temp);\r\n };\r\n /**\r\n * Adds a vec3 to the uniform buffer.\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n * @param vector Define the vec3 components from a Vector\r\n */\r\n UniformBuffer.prototype.addVector3 = function (name, vector) {\r\n var temp = new Array();\r\n vector.toArray(temp);\r\n this.addUniform(name, temp);\r\n };\r\n /**\r\n * Adds a Matrix 3x3 to the uniform buffer.\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n */\r\n UniformBuffer.prototype.addMatrix3x3 = function (name) {\r\n this.addUniform(name, 12);\r\n };\r\n /**\r\n * Adds a Matrix 2x2 to the uniform buffer.\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n */\r\n UniformBuffer.prototype.addMatrix2x2 = function (name) {\r\n this.addUniform(name, 8);\r\n };\r\n /**\r\n * Effectively creates the WebGL Uniform Buffer, once layout is completed with `addUniform`.\r\n */\r\n UniformBuffer.prototype.create = function () {\r\n if (this._noUBO) {\r\n return;\r\n }\r\n if (this._buffer) {\r\n return; // nothing to do\r\n }\r\n // See spec, alignment must be filled as a vec4\r\n this._fillAlignment(4);\r\n this._bufferData = new Float32Array(this._data);\r\n this._rebuild();\r\n this._needSync = true;\r\n };\r\n /** @hidden */\r\n UniformBuffer.prototype._rebuild = function () {\r\n if (this._noUBO || !this._bufferData) {\r\n return;\r\n }\r\n if (this._dynamic) {\r\n this._buffer = this._engine.createDynamicUniformBuffer(this._bufferData);\r\n }\r\n else {\r\n this._buffer = this._engine.createUniformBuffer(this._bufferData);\r\n }\r\n };\r\n /**\r\n * Updates the WebGL Uniform Buffer on the GPU.\r\n * If the `dynamic` flag is set to true, no cache comparison is done.\r\n * Otherwise, the buffer will be updated only if the cache differs.\r\n */\r\n UniformBuffer.prototype.update = function () {\r\n if (!this._buffer) {\r\n this.create();\r\n return;\r\n }\r\n if (!this._dynamic && !this._needSync) {\r\n return;\r\n }\r\n this._engine.updateUniformBuffer(this._buffer, this._bufferData);\r\n this._needSync = false;\r\n };\r\n /**\r\n * Updates the value of an uniform. The `update` method must be called afterwards to make it effective in the GPU.\r\n * @param uniformName Define the name of the uniform, as used in the uniform block in the shader.\r\n * @param data Define the flattened data\r\n * @param size Define the size of the data.\r\n */\r\n UniformBuffer.prototype.updateUniform = function (uniformName, data, size) {\r\n var location = this._uniformLocations[uniformName];\r\n if (location === undefined) {\r\n if (this._buffer) {\r\n // Cannot add an uniform if the buffer is already created\r\n Logger.Error(\"Cannot add an uniform after UBO has been created.\");\r\n return;\r\n }\r\n this.addUniform(uniformName, size);\r\n location = this._uniformLocations[uniformName];\r\n }\r\n if (!this._buffer) {\r\n this.create();\r\n }\r\n if (!this._dynamic) {\r\n // Cache for static uniform buffers\r\n var changed = false;\r\n for (var i = 0; i < size; i++) {\r\n if (size === 16 || this._bufferData[location + i] !== data[i]) {\r\n changed = true;\r\n this._bufferData[location + i] = data[i];\r\n }\r\n }\r\n this._needSync = this._needSync || changed;\r\n }\r\n else {\r\n // No cache for dynamic\r\n for (var i = 0; i < size; i++) {\r\n this._bufferData[location + i] = data[i];\r\n }\r\n }\r\n };\r\n UniformBuffer.prototype._cacheMatrix = function (name, matrix) {\r\n var cache = this._valueCache[name];\r\n var flag = matrix.updateFlag;\r\n if (cache !== undefined && cache === flag) {\r\n return false;\r\n }\r\n this._valueCache[name] = flag;\r\n return true;\r\n };\r\n // Update methods\r\n UniformBuffer.prototype._updateMatrix3x3ForUniform = function (name, matrix) {\r\n // To match std140, matrix must be realigned\r\n for (var i = 0; i < 3; i++) {\r\n UniformBuffer._tempBuffer[i * 4] = matrix[i * 3];\r\n UniformBuffer._tempBuffer[i * 4 + 1] = matrix[i * 3 + 1];\r\n UniformBuffer._tempBuffer[i * 4 + 2] = matrix[i * 3 + 2];\r\n UniformBuffer._tempBuffer[i * 4 + 3] = 0.0;\r\n }\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 12);\r\n };\r\n UniformBuffer.prototype._updateMatrix3x3ForEffect = function (name, matrix) {\r\n this._currentEffect.setMatrix3x3(name, matrix);\r\n };\r\n UniformBuffer.prototype._updateMatrix2x2ForEffect = function (name, matrix) {\r\n this._currentEffect.setMatrix2x2(name, matrix);\r\n };\r\n UniformBuffer.prototype._updateMatrix2x2ForUniform = function (name, matrix) {\r\n // To match std140, matrix must be realigned\r\n for (var i = 0; i < 2; i++) {\r\n UniformBuffer._tempBuffer[i * 4] = matrix[i * 2];\r\n UniformBuffer._tempBuffer[i * 4 + 1] = matrix[i * 2 + 1];\r\n UniformBuffer._tempBuffer[i * 4 + 2] = 0.0;\r\n UniformBuffer._tempBuffer[i * 4 + 3] = 0.0;\r\n }\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 8);\r\n };\r\n UniformBuffer.prototype._updateFloatForEffect = function (name, x) {\r\n this._currentEffect.setFloat(name, x);\r\n };\r\n UniformBuffer.prototype._updateFloatForUniform = function (name, x) {\r\n UniformBuffer._tempBuffer[0] = x;\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 1);\r\n };\r\n UniformBuffer.prototype._updateFloat2ForEffect = function (name, x, y, suffix) {\r\n if (suffix === void 0) { suffix = \"\"; }\r\n this._currentEffect.setFloat2(name + suffix, x, y);\r\n };\r\n UniformBuffer.prototype._updateFloat2ForUniform = function (name, x, y) {\r\n UniformBuffer._tempBuffer[0] = x;\r\n UniformBuffer._tempBuffer[1] = y;\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 2);\r\n };\r\n UniformBuffer.prototype._updateFloat3ForEffect = function (name, x, y, z, suffix) {\r\n if (suffix === void 0) { suffix = \"\"; }\r\n this._currentEffect.setFloat3(name + suffix, x, y, z);\r\n };\r\n UniformBuffer.prototype._updateFloat3ForUniform = function (name, x, y, z) {\r\n UniformBuffer._tempBuffer[0] = x;\r\n UniformBuffer._tempBuffer[1] = y;\r\n UniformBuffer._tempBuffer[2] = z;\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 3);\r\n };\r\n UniformBuffer.prototype._updateFloat4ForEffect = function (name, x, y, z, w, suffix) {\r\n if (suffix === void 0) { suffix = \"\"; }\r\n this._currentEffect.setFloat4(name + suffix, x, y, z, w);\r\n };\r\n UniformBuffer.prototype._updateFloat4ForUniform = function (name, x, y, z, w) {\r\n UniformBuffer._tempBuffer[0] = x;\r\n UniformBuffer._tempBuffer[1] = y;\r\n UniformBuffer._tempBuffer[2] = z;\r\n UniformBuffer._tempBuffer[3] = w;\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 4);\r\n };\r\n UniformBuffer.prototype._updateMatrixForEffect = function (name, mat) {\r\n this._currentEffect.setMatrix(name, mat);\r\n };\r\n UniformBuffer.prototype._updateMatrixForUniform = function (name, mat) {\r\n if (this._cacheMatrix(name, mat)) {\r\n this.updateUniform(name, mat.toArray(), 16);\r\n }\r\n };\r\n UniformBuffer.prototype._updateVector3ForEffect = function (name, vector) {\r\n this._currentEffect.setVector3(name, vector);\r\n };\r\n UniformBuffer.prototype._updateVector3ForUniform = function (name, vector) {\r\n vector.toArray(UniformBuffer._tempBuffer);\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 3);\r\n };\r\n UniformBuffer.prototype._updateVector4ForEffect = function (name, vector) {\r\n this._currentEffect.setVector4(name, vector);\r\n };\r\n UniformBuffer.prototype._updateVector4ForUniform = function (name, vector) {\r\n vector.toArray(UniformBuffer._tempBuffer);\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 4);\r\n };\r\n UniformBuffer.prototype._updateColor3ForEffect = function (name, color, suffix) {\r\n if (suffix === void 0) { suffix = \"\"; }\r\n this._currentEffect.setColor3(name + suffix, color);\r\n };\r\n UniformBuffer.prototype._updateColor3ForUniform = function (name, color) {\r\n color.toArray(UniformBuffer._tempBuffer);\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 3);\r\n };\r\n UniformBuffer.prototype._updateColor4ForEffect = function (name, color, alpha, suffix) {\r\n if (suffix === void 0) { suffix = \"\"; }\r\n this._currentEffect.setColor4(name + suffix, color, alpha);\r\n };\r\n UniformBuffer.prototype._updateColor4ForUniform = function (name, color, alpha) {\r\n color.toArray(UniformBuffer._tempBuffer);\r\n UniformBuffer._tempBuffer[3] = alpha;\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 4);\r\n };\r\n /**\r\n * Sets a sampler uniform on the effect.\r\n * @param name Define the name of the sampler.\r\n * @param texture Define the texture to set in the sampler\r\n */\r\n UniformBuffer.prototype.setTexture = function (name, texture) {\r\n this._currentEffect.setTexture(name, texture);\r\n };\r\n /**\r\n * Directly updates the value of the uniform in the cache AND on the GPU.\r\n * @param uniformName Define the name of the uniform, as used in the uniform block in the shader.\r\n * @param data Define the flattened data\r\n */\r\n UniformBuffer.prototype.updateUniformDirectly = function (uniformName, data) {\r\n this.updateUniform(uniformName, data, data.length);\r\n this.update();\r\n };\r\n /**\r\n * Binds this uniform buffer to an effect.\r\n * @param effect Define the effect to bind the buffer to\r\n * @param name Name of the uniform block in the shader.\r\n */\r\n UniformBuffer.prototype.bindToEffect = function (effect, name) {\r\n this._currentEffect = effect;\r\n if (this._noUBO || !this._buffer) {\r\n return;\r\n }\r\n this._alreadyBound = true;\r\n effect.bindUniformBuffer(this._buffer, name);\r\n };\r\n /**\r\n * Disposes the uniform buffer.\r\n */\r\n UniformBuffer.prototype.dispose = function () {\r\n if (this._noUBO) {\r\n return;\r\n }\r\n var uniformBuffers = this._engine._uniformBuffers;\r\n var index = uniformBuffers.indexOf(this);\r\n if (index !== -1) {\r\n uniformBuffers[index] = uniformBuffers[uniformBuffers.length - 1];\r\n uniformBuffers.pop();\r\n }\r\n if (!this._buffer) {\r\n return;\r\n }\r\n if (this._engine._releaseBuffer(this._buffer)) {\r\n this._buffer = null;\r\n }\r\n };\r\n // Pool for avoiding memory leaks\r\n UniformBuffer._MAX_UNIFORM_SIZE = 256;\r\n UniformBuffer._tempBuffer = new Float32Array(UniformBuffer._MAX_UNIFORM_SIZE);\r\n return UniformBuffer;\r\n}());\r\nexport { UniformBuffer };\r\n//# sourceMappingURL=uniformBuffer.js.map","/**\r\n * Extended version of XMLHttpRequest with support for customizations (headers, ...)\r\n */\r\nvar WebRequest = /** @class */ (function () {\r\n function WebRequest() {\r\n this._xhr = new XMLHttpRequest();\r\n }\r\n WebRequest.prototype._injectCustomRequestHeaders = function () {\r\n for (var key in WebRequest.CustomRequestHeaders) {\r\n var val = WebRequest.CustomRequestHeaders[key];\r\n if (val) {\r\n this._xhr.setRequestHeader(key, val);\r\n }\r\n }\r\n };\r\n Object.defineProperty(WebRequest.prototype, \"onprogress\", {\r\n /**\r\n * Gets or sets a function to be called when loading progress changes\r\n */\r\n get: function () {\r\n return this._xhr.onprogress;\r\n },\r\n set: function (value) {\r\n this._xhr.onprogress = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(WebRequest.prototype, \"readyState\", {\r\n /**\r\n * Returns client's state\r\n */\r\n get: function () {\r\n return this._xhr.readyState;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(WebRequest.prototype, \"status\", {\r\n /**\r\n * Returns client's status\r\n */\r\n get: function () {\r\n return this._xhr.status;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(WebRequest.prototype, \"statusText\", {\r\n /**\r\n * Returns client's status as a text\r\n */\r\n get: function () {\r\n return this._xhr.statusText;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(WebRequest.prototype, \"response\", {\r\n /**\r\n * Returns client's response\r\n */\r\n get: function () {\r\n return this._xhr.response;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(WebRequest.prototype, \"responseURL\", {\r\n /**\r\n * Returns client's response url\r\n */\r\n get: function () {\r\n return this._xhr.responseURL;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(WebRequest.prototype, \"responseText\", {\r\n /**\r\n * Returns client's response as text\r\n */\r\n get: function () {\r\n return this._xhr.responseText;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(WebRequest.prototype, \"responseType\", {\r\n /**\r\n * Gets or sets the expected response type\r\n */\r\n get: function () {\r\n return this._xhr.responseType;\r\n },\r\n set: function (value) {\r\n this._xhr.responseType = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n WebRequest.prototype.addEventListener = function (type, listener, options) {\r\n this._xhr.addEventListener(type, listener, options);\r\n };\r\n WebRequest.prototype.removeEventListener = function (type, listener, options) {\r\n this._xhr.removeEventListener(type, listener, options);\r\n };\r\n /**\r\n * Cancels any network activity\r\n */\r\n WebRequest.prototype.abort = function () {\r\n this._xhr.abort();\r\n };\r\n /**\r\n * Initiates the request. The optional argument provides the request body. The argument is ignored if request method is GET or HEAD\r\n * @param body defines an optional request body\r\n */\r\n WebRequest.prototype.send = function (body) {\r\n if (WebRequest.CustomRequestHeaders) {\r\n this._injectCustomRequestHeaders();\r\n }\r\n this._xhr.send(body);\r\n };\r\n /**\r\n * Sets the request method, request URL\r\n * @param method defines the method to use (GET, POST, etc..)\r\n * @param url defines the url to connect with\r\n */\r\n WebRequest.prototype.open = function (method, url) {\r\n for (var _i = 0, _a = WebRequest.CustomRequestModifiers; _i < _a.length; _i++) {\r\n var update = _a[_i];\r\n update(this._xhr, url);\r\n }\r\n // Clean url\r\n url = url.replace(\"file:http:\", \"http:\");\r\n url = url.replace(\"file:https:\", \"https:\");\r\n return this._xhr.open(method, url, true);\r\n };\r\n /**\r\n * Sets the value of a request header.\r\n * @param name The name of the header whose value is to be set\r\n * @param value The value to set as the body of the header\r\n */\r\n WebRequest.prototype.setRequestHeader = function (name, value) {\r\n this._xhr.setRequestHeader(name, value);\r\n };\r\n /**\r\n * Get the string containing the text of a particular header's value.\r\n * @param name The name of the header\r\n * @returns The string containing the text of the given header name\r\n */\r\n WebRequest.prototype.getResponseHeader = function (name) {\r\n return this._xhr.getResponseHeader(name);\r\n };\r\n /**\r\n * Custom HTTP Request Headers to be sent with XMLHttpRequests\r\n * i.e. when loading files, where the server/service expects an Authorization header\r\n */\r\n WebRequest.CustomRequestHeaders = {};\r\n /**\r\n * Add callback functions in this array to update all the requests before they get sent to the network\r\n */\r\n WebRequest.CustomRequestModifiers = new Array();\r\n return WebRequest;\r\n}());\r\nexport { WebRequest };\r\n//# sourceMappingURL=webRequest.js.map","import { Logger } from './logger';\r\nimport { _TypeStore } from './typeStore';\r\n/**\r\n * Class used to enable instatition of objects by class name\r\n */\r\nvar InstantiationTools = /** @class */ (function () {\r\n function InstantiationTools() {\r\n }\r\n /**\r\n * Tries to instantiate a new object from a given class name\r\n * @param className defines the class name to instantiate\r\n * @returns the new object or null if the system was not able to do the instantiation\r\n */\r\n InstantiationTools.Instantiate = function (className) {\r\n if (this.RegisteredExternalClasses && this.RegisteredExternalClasses[className]) {\r\n return this.RegisteredExternalClasses[className];\r\n }\r\n var internalClass = _TypeStore.GetClass(className);\r\n if (internalClass) {\r\n return internalClass;\r\n }\r\n Logger.Warn(className + \" not found, you may have missed an import.\");\r\n var arr = className.split(\".\");\r\n var fn = (window || this);\r\n for (var i = 0, len = arr.length; i < len; i++) {\r\n fn = fn[arr[i]];\r\n }\r\n if (typeof fn !== \"function\") {\r\n return null;\r\n }\r\n return fn;\r\n };\r\n /**\r\n * Use this object to register external classes like custom textures or material\r\n * to allow the laoders to instantiate them\r\n */\r\n InstantiationTools.RegisteredExternalClasses = {};\r\n return InstantiationTools;\r\n}());\r\nexport { InstantiationTools };\r\n//# sourceMappingURL=instantiationTools.js.map","import { __extends } from \"tslib\";\r\nimport { Material } from \"../Materials/material\";\r\nimport { Tags } from \"../Misc/tags\";\r\nimport { _TypeStore } from '../Misc/typeStore';\r\n/**\r\n * A multi-material is used to apply different materials to different parts of the same object without the need of\r\n * separate meshes. This can be use to improve performances.\r\n * @see http://doc.babylonjs.com/how_to/multi_materials\r\n */\r\nvar MultiMaterial = /** @class */ (function (_super) {\r\n __extends(MultiMaterial, _super);\r\n /**\r\n * Instantiates a new Multi Material\r\n * A multi-material is used to apply different materials to different parts of the same object without the need of\r\n * separate meshes. This can be use to improve performances.\r\n * @see http://doc.babylonjs.com/how_to/multi_materials\r\n * @param name Define the name in the scene\r\n * @param scene Define the scene the material belongs to\r\n */\r\n function MultiMaterial(name, scene) {\r\n var _this = _super.call(this, name, scene, true) || this;\r\n scene.multiMaterials.push(_this);\r\n _this.subMaterials = new Array();\r\n _this._storeEffectOnSubMeshes = true; // multimaterial is considered like a push material\r\n return _this;\r\n }\r\n Object.defineProperty(MultiMaterial.prototype, \"subMaterials\", {\r\n /**\r\n * Gets or Sets the list of Materials used within the multi material.\r\n * They need to be ordered according to the submeshes order in the associated mesh\r\n */\r\n get: function () {\r\n return this._subMaterials;\r\n },\r\n set: function (value) {\r\n this._subMaterials = value;\r\n this._hookArray(value);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Function used to align with Node.getChildren()\r\n * @returns the list of Materials used within the multi material\r\n */\r\n MultiMaterial.prototype.getChildren = function () {\r\n return this.subMaterials;\r\n };\r\n MultiMaterial.prototype._hookArray = function (array) {\r\n var _this = this;\r\n var oldPush = array.push;\r\n array.push = function () {\r\n var items = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n items[_i] = arguments[_i];\r\n }\r\n var result = oldPush.apply(array, items);\r\n _this._markAllSubMeshesAsTexturesDirty();\r\n return result;\r\n };\r\n var oldSplice = array.splice;\r\n array.splice = function (index, deleteCount) {\r\n var deleted = oldSplice.apply(array, [index, deleteCount]);\r\n _this._markAllSubMeshesAsTexturesDirty();\r\n return deleted;\r\n };\r\n };\r\n /**\r\n * Get one of the submaterial by its index in the submaterials array\r\n * @param index The index to look the sub material at\r\n * @returns The Material if the index has been defined\r\n */\r\n MultiMaterial.prototype.getSubMaterial = function (index) {\r\n if (index < 0 || index >= this.subMaterials.length) {\r\n return this.getScene().defaultMaterial;\r\n }\r\n return this.subMaterials[index];\r\n };\r\n /**\r\n * Get the list of active textures for the whole sub materials list.\r\n * @returns All the textures that will be used during the rendering\r\n */\r\n MultiMaterial.prototype.getActiveTextures = function () {\r\n var _a;\r\n return (_a = _super.prototype.getActiveTextures.call(this)).concat.apply(_a, this.subMaterials.map(function (subMaterial) {\r\n if (subMaterial) {\r\n return subMaterial.getActiveTextures();\r\n }\r\n else {\r\n return [];\r\n }\r\n }));\r\n };\r\n /**\r\n * Gets the current class name of the material e.g. \"MultiMaterial\"\r\n * Mainly use in serialization.\r\n * @returns the class name\r\n */\r\n MultiMaterial.prototype.getClassName = function () {\r\n return \"MultiMaterial\";\r\n };\r\n /**\r\n * Checks if the material is ready to render the requested sub mesh\r\n * @param mesh Define the mesh the submesh belongs to\r\n * @param subMesh Define the sub mesh to look readyness for\r\n * @param useInstances Define whether or not the material is used with instances\r\n * @returns true if ready, otherwise false\r\n */\r\n MultiMaterial.prototype.isReadyForSubMesh = function (mesh, subMesh, useInstances) {\r\n for (var index = 0; index < this.subMaterials.length; index++) {\r\n var subMaterial = this.subMaterials[index];\r\n if (subMaterial) {\r\n if (subMaterial._storeEffectOnSubMeshes) {\r\n if (!subMaterial.isReadyForSubMesh(mesh, subMesh, useInstances)) {\r\n return false;\r\n }\r\n continue;\r\n }\r\n if (!subMaterial.isReady(mesh)) {\r\n return false;\r\n }\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Clones the current material and its related sub materials\r\n * @param name Define the name of the newly cloned material\r\n * @param cloneChildren Define if submaterial will be cloned or shared with the parent instance\r\n * @returns the cloned material\r\n */\r\n MultiMaterial.prototype.clone = function (name, cloneChildren) {\r\n var newMultiMaterial = new MultiMaterial(name, this.getScene());\r\n for (var index = 0; index < this.subMaterials.length; index++) {\r\n var subMaterial = null;\r\n var current = this.subMaterials[index];\r\n if (cloneChildren && current) {\r\n subMaterial = current.clone(name + \"-\" + current.name);\r\n }\r\n else {\r\n subMaterial = this.subMaterials[index];\r\n }\r\n newMultiMaterial.subMaterials.push(subMaterial);\r\n }\r\n return newMultiMaterial;\r\n };\r\n /**\r\n * Serializes the materials into a JSON representation.\r\n * @returns the JSON representation\r\n */\r\n MultiMaterial.prototype.serialize = function () {\r\n var serializationObject = {};\r\n serializationObject.name = this.name;\r\n serializationObject.id = this.id;\r\n if (Tags) {\r\n serializationObject.tags = Tags.GetTags(this);\r\n }\r\n serializationObject.materials = [];\r\n for (var matIndex = 0; matIndex < this.subMaterials.length; matIndex++) {\r\n var subMat = this.subMaterials[matIndex];\r\n if (subMat) {\r\n serializationObject.materials.push(subMat.id);\r\n }\r\n else {\r\n serializationObject.materials.push(null);\r\n }\r\n }\r\n return serializationObject;\r\n };\r\n /**\r\n * Dispose the material and release its associated resources\r\n * @param forceDisposeEffect Define if we want to force disposing the associated effect (if false the shader is not released and could be reuse later on)\r\n * @param forceDisposeTextures Define if we want to force disposing the associated textures (if false, they will not be disposed and can still be use elsewhere in the app)\r\n * @param forceDisposeChildren Define if we want to force disposing the associated submaterials (if false, they will not be disposed and can still be use elsewhere in the app)\r\n */\r\n MultiMaterial.prototype.dispose = function (forceDisposeEffect, forceDisposeTextures, forceDisposeChildren) {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n if (forceDisposeChildren) {\r\n for (var index = 0; index < this.subMaterials.length; index++) {\r\n var subMaterial = this.subMaterials[index];\r\n if (subMaterial) {\r\n subMaterial.dispose(forceDisposeEffect, forceDisposeTextures);\r\n }\r\n }\r\n }\r\n var index = scene.multiMaterials.indexOf(this);\r\n if (index >= 0) {\r\n scene.multiMaterials.splice(index, 1);\r\n }\r\n _super.prototype.dispose.call(this, forceDisposeEffect, forceDisposeTextures);\r\n };\r\n /**\r\n * Creates a MultiMaterial from parsed MultiMaterial data.\r\n * @param parsedMultiMaterial defines parsed MultiMaterial data.\r\n * @param scene defines the hosting scene\r\n * @returns a new MultiMaterial\r\n */\r\n MultiMaterial.ParseMultiMaterial = function (parsedMultiMaterial, scene) {\r\n var multiMaterial = new MultiMaterial(parsedMultiMaterial.name, scene);\r\n multiMaterial.id = parsedMultiMaterial.id;\r\n if (Tags) {\r\n Tags.AddTagsTo(multiMaterial, parsedMultiMaterial.tags);\r\n }\r\n for (var matIndex = 0; matIndex < parsedMultiMaterial.materials.length; matIndex++) {\r\n var subMatId = parsedMultiMaterial.materials[matIndex];\r\n if (subMatId) {\r\n // If the same multimaterial is loaded twice, the 2nd multimaterial needs to reference the latest material by that id which\r\n // is why this lookup should use getLastMaterialByID instead of getMaterialByID\r\n multiMaterial.subMaterials.push(scene.getLastMaterialByID(subMatId));\r\n }\r\n else {\r\n multiMaterial.subMaterials.push(null);\r\n }\r\n }\r\n return multiMaterial;\r\n };\r\n return MultiMaterial;\r\n}(Material));\r\nexport { MultiMaterial };\r\n_TypeStore.RegisteredTypes[\"BABYLON.MultiMaterial\"] = MultiMaterial;\r\n//# sourceMappingURL=multiMaterial.js.map","/*!\r\n * babyplots - Easy, fast, interactive 3D visualizations\r\n *\r\n * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved.\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n * \r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n * \r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n * \r\n * ---------------------------------------------\r\n * \r\n * babyplots includes CCapture.js, released under the following license:\r\n * \r\n * CCapture - A library to capture canvas-based animations\r\n * \r\n * The MIT License\r\n * \r\n * Copyright (c) 2012 Jaume Sanchez Elias\r\n * \r\n * Permission is hereby granted, free of charge, to any person obtaining a copy\r\n * of this software and associated documentation files (the \"Software\"), to deal\r\n * in the Software without restriction, including without limitation the rights\r\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\r\n * copies of the Software, and to permit persons to whom the Software is\r\n * furnished to do so, subject to the following conditions:\r\n * \r\n * The above copyright notice and this permission notice shall be included in\r\n * all copies or substantial portions of the Software.\r\n * \r\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\r\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\r\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\r\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\r\n * THE SOFTWARE.\r\n * \r\n * ---------------------------------------------\r\n * \r\n * babyplots includes axios, released under the following license:\r\n * \r\n * Copyright (c) 2014-present Matt Zabriskie\r\n * \r\n * Permission is hereby granted, free of charge, to any person obtaining a copy\r\n * of this software and associated documentation files (the \"Software\"), to deal\r\n * in the Software without restriction, including without limitation the rights\r\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\r\n * copies of the Software, and to permit persons to whom the Software is\r\n * furnished to do so, subject to the following conditions:\r\n * \r\n * The above copyright notice and this permission notice shall be included in\r\n * all copies or substantial portions of the Software.\r\n * \r\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\r\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\r\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\r\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\r\n * THE SOFTWARE.\r\n * \r\n * ---------------------------------------------\r\n * \r\n * babyplots includes uuid, released under the following license:\r\n * \r\n * The MIT License (MIT)\r\n * \r\n * Copyright (c) 2010-2020 Robert Kieffer and other contributors\r\n * \r\n * Permission is hereby granted, free of charge, to any person obtaining a copy\r\n * of this software and associated documentation files (the \"Software\"), to deal\r\n * in the Software without restriction, including without limitation the rights\r\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\r\n * copies of the Software, and to permit persons to whom the Software is furnished\r\n * to do so, subject to the following conditions:\r\n * \r\n * The above copyright notice and this permission notice shall be included in all\r\n * copies or substantial portions of the Software.\r\n * \r\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\r\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\r\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\r\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\r\n * THE SOFTWARE.\r\n * \r\n */\r\n\r\nimport { Scene } from \"@babylonjs/core/scene\";\r\nimport { Engine } from \"@babylonjs/core/Engines/engine\";\r\nimport { Mesh } from \"@babylonjs/core/Meshes/mesh\";\r\nimport { ArcRotateCamera } from \"@babylonjs/core/Cameras/arcRotateCamera\";\r\nimport { HemisphericLight } from \"@babylonjs/core/Lights/hemisphericLight\";\r\nimport { Vector3, Color4, Color3 } from \"@babylonjs/core/Maths/math\";\r\nimport { BoxBuilder } from \"@babylonjs/core/Meshes/Builders/boxBuilder\";\r\nimport { AdvancedDynamicTexture } from \"@babylonjs/gui/2D/advancedDynamicTexture\";\r\nimport { Rectangle, TextBlock, Grid, Control } from \"@babylonjs/gui/2D/controls\";\r\nimport { ScreenshotTools } from \"@babylonjs/core/Misc/screenshotTools\";\r\nimport chroma from \"chroma-js\";\r\nimport download from \"downloadjs\";\r\nimport { v4 as uuidv4 } from \"uuid\";\r\n\r\nconst axios = require('axios').default;\r\n\r\nimport { AnnotationManager } from \"./Label\";\r\n\r\n/**\r\n * Interface for object containing information about axis setup.\r\n */\r\nexport interface AxisData {\r\n showAxes: boolean[];\r\n static: boolean;\r\n axisLabels: string[];\r\n range: number[][];\r\n color: string[];\r\n scale: number[];\r\n tickBreaks: number[];\r\n showTickLines: boolean[][];\r\n tickLineColor: string[][];\r\n showPlanes: boolean[];\r\n planeColor: string[];\r\n plotType: string;\r\n colnames: string[];\r\n rownames: string[];\r\n}\r\n\r\nimport { Axes } from \"./Axes\";\r\n\r\nexport const buttonSVGs = {\r\n logo: '',\r\n toJson: '',\r\n labels: '',\r\n publish: '',\r\n replay: '',\r\n record: ''\r\n}\r\n\r\nexport const styleText = [\r\n \".bbp.button-bar { position: absolute; z-index: 2; overflow: hidden; padding: 0 10px 4px 0; }\",\r\n \".bbp.button-bar > .button { float: right; width: 75px; height: 30px; cursor: pointer; border-radius: 2px; background-color: #f0f0f0; margin: 0 4px 0 0; }\",\r\n \".bbp.button-bar > .button:hover { background-color: #ddd; }\",\r\n \".bbp.button-bar > .button > svg { width: 75px; height: 30px; }\",\r\n \".bbp.label-control { position: absolute; z-index: 3; font-family: sans-serif; width: 200px; background-color: #f0f0f0; padding: 5px; border-radius: 2px; }\",\r\n \".bbp.label-control > label { font-size: 11pt; }\",\r\n \".bbp.label-control > .edit-container { overflow: auto; }\",\r\n \".bbp.label-control > .edit-container > .label-form { margin-top: 5px; padding-top: 20px; border-top: solid thin #ccc; }\",\r\n \".bbp.label-control .label-form > input { width: 100%; box-sizing: border-box; }\",\r\n \".bbp.label-control .label-form > button { border: none; font-weight: bold; background-color: white; padding: 5px 10px; margin: 5px 0 2px 0; width: 100%; cursor: pointer; }\",\r\n \".bbp.label-control .label-form > button:hover { background-color: #ddd; }\",\r\n \".bbp.overlay { position: absolute; z-index: 3; overflow: hidden; top: 0; left: 0; right: 0; bottom: 0; width: 100%; height: 100%; background-color: #fff5; display: flex; justify-content: center; align-items: center;}\",\r\n \".bbp.overlay > h5.loading-message { color: #000; font-family: Verdana, sans-serif;}\",\r\n \".bbp.publish-form > label { display: block; text-align: left; font-family: Verdana, sans-serif; }\",\r\n \".bbp.publish-form > input { width: 100%; margin-bottom: 15px; box-sizing: border-box; }\",\r\n \".bbp.publish-form > .publish-btn { border: none; font-weight: bold; background-color: #e95420; color: white; padding: 5px 10px; margin: 5px 0 2px 0; width: 100%; cursor: pointer; }\",\r\n \".bbp.publish-form > .publish-btn:hover { background-color: #ca491a }\",\r\n \".bbp.publish-form > .close-btn, .bbp.publish-form > .cancel-btn { border: none; font-weight: bold; background-color: white; padding: 5px 10px; margin: 5px 0 2px 0; width: 100%; cursor: pointer; }\",\r\n \".bbp.publish-form > .close-btn:hover, .bbp.publish-form > .cancel-btn:hover { background-color: #ddd }\",\r\n \".bbp.publish-form > p.form-info { font-size: 8pt; font-family: Verdana, sans-serif; }\",\r\n \".bbp.publish-form > p.message { font-size: 10pt; font-family: Verdana, sans-serif; }\",\r\n \".bbp.publish-form > p.message.warning { color: red; margin-top: 0px; }\",\r\n \".bbp.publish-form > p.message.success { color: green; }\",\r\n].join(\" \");\r\n\r\nexport interface LegendData {\r\n showLegend: boolean;\r\n discrete: boolean;\r\n breaks: string[];\r\n colorScale: string;\r\n inverted: boolean;\r\n position: string;\r\n customColorScale?: string[];\r\n fontSize?: number;\r\n fontColor?: string;\r\n legendTitle?: string;\r\n legendTitleFontSize?: number;\r\n}\r\n\r\nexport abstract class Plot {\r\n protected _coords: number[][];\r\n protected _coordColors: string[];\r\n protected _groups: string[];\r\n protected _groupNames: string[];\r\n protected _size: number = 1;\r\n protected _scene: Scene;\r\n\r\n mesh: Mesh;\r\n meshes: Mesh[];\r\n selection: number[]; // contains indices of cells in selection cube\r\n legendData: LegendData;\r\n xScale: number;\r\n yScale: number;\r\n zScale: number;\r\n\r\n constructor(\r\n scene: Scene,\r\n coordinates: number[][],\r\n colorVar: string[],\r\n size: number,\r\n legendData: LegendData,\r\n xScale: number = 1,\r\n yScale: number = 1,\r\n zScale: number = 1\r\n ) {\r\n this._scene = scene;\r\n this._coords = coordinates;\r\n this._coordColors = colorVar;\r\n this._size = size;\r\n this.legendData = legendData;\r\n this.xScale = xScale\r\n this.yScale = yScale\r\n this.zScale = zScale\r\n }\r\n\r\n updateSize(): void { }\r\n update(): boolean { return false }\r\n resetAnimation(): void { }\r\n}\r\n\r\n\r\ndeclare global {\r\n interface Array {\r\n min(): number;\r\n max(): number;\r\n }\r\n}\r\n\r\nArray.prototype.min = function (): number {\r\n if (this.length > 65536) {\r\n let r = this[0];\r\n this.forEach(function (v: number, _i: any, _a: any) { if (v < r) r = v; });\r\n return r;\r\n } else {\r\n return Math.min.apply(null, this);\r\n }\r\n}\r\n\r\nArray.prototype.max = function (): number {\r\n if (this.length > 65536) {\r\n let r = this[0];\r\n this.forEach(function (v: number, _i: any, _a: any) { if (v > r) r = v; });\r\n return r;\r\n } else {\r\n return Math.max.apply(null, this);\r\n }\r\n}\r\n\r\nexport function matrixMax(matrix: number[][]): number {\r\n let maxRow = matrix.map(function (row) { return row.max(); });\r\n let max = maxRow.max();\r\n return max\r\n}\r\n\r\nexport function matrixMin(matrix: number[][]): number {\r\n let minRow = matrix.map(function (row) { return row.min(); });\r\n let min = minRow.min();\r\n return min\r\n}\r\n\r\nexport function getUniqueVals(source: string[]): string[] {\r\n let length = source.length;\r\n let result: string[] = [];\r\n let seen = new Set();\r\n\r\n outer:\r\n for (let index = 0; index < length; index++) {\r\n let value = source[index];\r\n if (seen.has(value)) continue outer;\r\n seen.add(value);\r\n result.push(value);\r\n }\r\n\r\n return result;\r\n}\r\n\r\nimport { ImgStack } from \"./ImgStack\";\r\nimport { PointCloud } from \"./PointCloud\";\r\nimport { Surface } from \"./Surface\";\r\nimport { HeatMap } from \"./HeatMap\";\r\n\r\nexport const PLOTTYPES = {\r\n 'pointCloud': ['coordinates', 'colorBy', 'colorVar'],\r\n 'surface': ['coordinates', 'colorBy', 'colorVar'],\r\n 'heatMap': ['coordinates', 'colorBy', 'colorVar'],\r\n 'imageStack': ['values', 'indices', 'attributes']\r\n}\r\n\r\n/**\r\n * Takes a reasonable guess if a plot can be created from the provided object\r\n * @param plotData Object containing data to be checked for valid plot information\r\n */\r\nexport function isValidPlot(plotData: {}): boolean {\r\n for (let plotIdx = 0; plotIdx < plotData[\"plots\"].length; plotIdx++) {\r\n const plot = plotData[\"plots\"][plotIdx];\r\n let pltType = plot[\"plotType\"]\r\n if (PLOTTYPES.hasOwnProperty(pltType)) {\r\n for (let i = 0; i < PLOTTYPES[pltType].length; i++) {\r\n const prop = PLOTTYPES[pltType][i];\r\n if (plot[prop] === undefined) {\r\n console.log('Plot ' + plotIdx + ' is missing property:' + prop);\r\n return false;\r\n }\r\n }\r\n } else {\r\n console.log('Unrecognized plot type')\r\n return false;\r\n }\r\n }\r\n return true;\r\n}\r\n\r\nexport class Plots {\r\n private _engine: Engine;\r\n private _hl1: HemisphericLight;\r\n private _hl2: HemisphericLight;\r\n protected _legend: AdvancedDynamicTexture;\r\n protected _showLegend: boolean = true;\r\n private _hasAnim: boolean = false;\r\n private _axes: Axes[] = [];\r\n private _downloadObj: {} = {};\r\n private _buttonBar: HTMLDivElement;\r\n private _annotationManager: AnnotationManager;\r\n private _backgroundColor: string;\r\n private _recording: boolean = false;\r\n private _turned: number = 0;\r\n private _capturer: CCapture;\r\n private _wasTurning: boolean = false;\r\n private _xScale: number = 1;\r\n private _yScale: number = 1;\r\n private _zScale: number = 1;\r\n private _publishFormOverlay: HTMLDivElement;\r\n private _uniqID: string;\r\n\r\n canvas: HTMLCanvasElement;\r\n scene: Scene;\r\n camera: ArcRotateCamera;\r\n plots: Plot[] = [];\r\n turntable: boolean;\r\n rotationRate: number;\r\n fixedSize = false;\r\n ymax: number = 0;\r\n R: boolean = false;\r\n\r\n /**\r\n * Initialize the 3d visualization\r\n * @param canvasElement ID of the canvas element in the dom\r\n * @param backgroundColor Background color of the plot\r\n */\r\n constructor(canvasElement: string, options = {}) {\r\n // create unique id, needed if multiple babyplots canvases are on the same page.\r\n this._uniqID = uuidv4();\r\n\r\n // apply options\r\n // default settings\r\n let opts = {\r\n backgroundColor: \"#ffffffff\",\r\n xScale: 1,\r\n yScale: 1,\r\n zScale: 1,\r\n turntable: false,\r\n rotationRate: 0.01\r\n }\r\n Object.assign(opts, options);\r\n\r\n this.turntable = opts.turntable;\r\n this.rotationRate = opts.rotationRate;\r\n\r\n // setup enginge and scene\r\n this._backgroundColor = opts.backgroundColor;\r\n this.canvas = document.getElementById(canvasElement) as HTMLCanvasElement;\r\n this._engine = new Engine(this.canvas, true, { preserveDrawingBuffer: true, stencil: true });\r\n this.scene = new Scene(this._engine);\r\n\r\n // camera\r\n this.camera = new ArcRotateCamera(\"Camera\", 0, 0, 10, Vector3.Zero(), this.scene);\r\n this.camera.attachControl(this.canvas, true);\r\n this.scene.activeCamera = this.camera;\r\n this.camera.inputs.attached.keyboard.detachControl(this.canvas);\r\n this.camera.wheelPrecision = 50;\r\n\r\n // background color\r\n this.scene.clearColor = Color4.FromHexString(opts.backgroundColor);\r\n\r\n // Axis scales\r\n this._xScale = opts.xScale;\r\n this._yScale = opts.yScale;\r\n this._zScale = opts.zScale;\r\n\r\n // two lights to illuminate the cells uniformly (top and bottom)\r\n this._hl1 = new HemisphericLight(\"HemiLight\", new Vector3(0, 1, 0), this.scene);\r\n this._hl1.diffuse = new Color3(1, 1, 1);\r\n this._hl1.specular = new Color3(0, 0, 0);\r\n // bottom light slightly weaker for better depth perception and orientation\r\n this._hl2 = new HemisphericLight(\"HemiLight\", new Vector3(0, -1, 0), this.scene);\r\n this._hl2.diffuse = new Color3(0.8, 0.8, 0.8);\r\n this._hl2.specular = new Color3(0, 0, 0);\r\n\r\n this._annotationManager = new AnnotationManager(this.canvas, this.scene, this.ymax, this.camera);\r\n\r\n this.scene.registerBeforeRender(this._prepRender.bind(this));\r\n\r\n this.scene.registerAfterRender(this._afterRender.bind(this));\r\n\r\n // create container for buttons\r\n // create css style\r\n let styleElem = document.createElement(\"style\");\r\n styleElem.appendChild(document.createTextNode(styleText));\r\n document.getElementsByTagName('head')[0].appendChild(styleElem);\r\n // create ui elements\r\n let buttonBar = document.createElement(\"div\");\r\n buttonBar.className = \"bbp button-bar\"\r\n buttonBar.style.top = this.canvas.clientTop + 5 + \"px\";\r\n buttonBar.style.left = this.canvas.clientLeft + 5 + \"px\";\r\n this.canvas.parentNode.appendChild(buttonBar);\r\n this._buttonBar = buttonBar;\r\n // prepare download object\r\n this._downloadObj = {\r\n plots: []\r\n };\r\n }\r\n\r\n fromJSON(plotData: {}): void {\r\n if (plotData[\"turntable\"] !== undefined) {\r\n this.turntable = plotData[\"turntable\"];\r\n }\r\n if (plotData[\"rotationRate\"] !== undefined) {\r\n this.rotationRate = plotData[\"rotationRate\"];\r\n }\r\n if (plotData[\"backgroundColor\"]) {\r\n this._backgroundColor = plotData[\"backgroundColor\"];\r\n this.scene.clearColor = Color4.FromHexString(this._backgroundColor);\r\n }\r\n if (plotData[\"xScale\"] !== undefined) {\r\n this._xScale = plotData[\"xScale\"];\r\n }\r\n if (plotData[\"yScale\"] !== undefined) {\r\n this._yScale = plotData[\"yScale\"];\r\n }\r\n if (plotData[\"zScale\"] !== undefined) {\r\n this._zScale = plotData[\"zScale\"];\r\n }\r\n for (let plotIdx = 0; plotIdx < plotData[\"plots\"].length; plotIdx++) {\r\n const plot = plotData[\"plots\"][plotIdx];\r\n if (plot[\"plotType\"] === \"imageStack\") {\r\n this.addImgStack(\r\n plot[\"values\"],\r\n plot[\"indices\"],\r\n plot[\"attributes\"],\r\n {\r\n size: plot[\"size\"],\r\n colorScale: plot[\"colorScale\"],\r\n showLegend: plot[\"showLegend\"],\r\n fontSize: plot[\"fontSize\"],\r\n fontColor: plot[\"fontColor\"],\r\n legendTitle: plot[\"legendTitle\"],\r\n legendTitleFontSize: plot[\"legendTitleFontSize\"],\r\n legendPosition: plot[\"legendPosition\"],\r\n showAxes: plot[\"showAxes\"],\r\n axisLabels: plot[\"axisLabels\"],\r\n axisColors: plot[\"axisColors\"],\r\n tickBreaks: plot[\"tickBreaks\"],\r\n showTickLines: plot[\"showTickLines\"],\r\n tickLineColors: plot[\"tickLineColors\"],\r\n intensityMode: plot[\"intensityMode\"]\r\n }\r\n )\r\n } else if ([\"pointCloud\", \"heatMap\", \"surface\"].indexOf(plot[\"plotType\"]) !== -1) {\r\n this.addPlot(\r\n plot[\"coordinates\"],\r\n plot[\"plotType\"],\r\n plot[\"colorBy\"],\r\n plot[\"colorVar\"],\r\n {\r\n size: plot[\"size\"],\r\n colorScale: plot[\"colorScale\"],\r\n customColorScale: plot[\"customColorScale\"],\r\n colorScaleInverted: plot[\"colorScaleInverted\"],\r\n sortedCategories: plot[\"sortedCategories\"],\r\n showLegend: plot[\"showLegend\"],\r\n fontSize: plot[\"fontSize\"],\r\n fontColor: plot[\"fontColor\"],\r\n legendTitle: plot[\"legendTitle\"],\r\n legendTitleFontSize: plot[\"legendTitleFontSize\"],\r\n legendPosition: plot[\"legendPosition\"],\r\n showAxes: plot[\"showAxes\"],\r\n axisLabels: plot[\"axisLabels\"],\r\n axisColors: plot[\"axisColors\"],\r\n tickBreaks: plot[\"tickBreaks\"],\r\n showTickLines: plot[\"showTickLines\"],\r\n tickLineColors: plot[\"tickLineColors\"],\r\n folded: plot[\"folded\"],\r\n foldedEmbedding: plot[\"foldedEmbedding\"],\r\n foldAnimDelay: plot[\"foldAnimDelay\"],\r\n foldAnimDuration: plot[\"foldAnimDuration\"],\r\n colnames: plot[\"colnames\"],\r\n rownames: plot[\"rownames\"]\r\n }\r\n )\r\n }\r\n }\r\n if (plotData[\"labels\"]) {\r\n this._annotationManager.fixedLabels = true;\r\n let labelData = plotData[\"labels\"];\r\n if (labelData.length > 0) {\r\n if (Array.isArray(labelData[0])) {\r\n this._annotationManager.addLabels(labelData);\r\n } else {\r\n // legacy label saving\r\n for (let i = 0; i < labelData.length; i++) {\r\n const label = labelData[i];\r\n if (label[\"text\"] && label[\"position\"]) {\r\n this._annotationManager.addLabel(label[\"text\"], label[\"position\"]);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n if (plotData[\"cameraAlpha\"] !== undefined) {\r\n this.camera.alpha = plotData[\"cameraAlpha\"];\r\n }\r\n if (plotData[\"cameraBeta\"] !== undefined) {\r\n this.camera.beta = plotData[\"cameraBeta\"];\r\n }\r\n if (plotData[\"cameraRadius\"] !== undefined) {\r\n this.camera.radius = plotData[\"cameraRadius\"];\r\n }\r\n }\r\n\r\n createButtons(whichBtns = [\"json\", \"label\", \"publish\", \"record\"]): void {\r\n if (whichBtns.indexOf(\"json\") !== -1) {\r\n let jsonBtn = document.createElement(\"div\");\r\n jsonBtn.className = \"button\";\r\n jsonBtn.onclick = this._downloadJson.bind(this);\r\n jsonBtn.innerHTML = buttonSVGs.toJson;\r\n this._buttonBar.appendChild(jsonBtn);\r\n }\r\n if (whichBtns.indexOf(\"label\") !== -1) {\r\n let labelBtn = document.createElement(\"div\");\r\n labelBtn.className = \"button\";\r\n labelBtn.onclick = this._annotationManager.toggleLabelControl.bind(this._annotationManager);\r\n labelBtn.innerHTML = buttonSVGs.labels;\r\n this._buttonBar.appendChild(labelBtn);\r\n }\r\n if (whichBtns.indexOf(\"record\") !== -1) {\r\n let recordBtn = document.createElement(\"div\");\r\n recordBtn.className = \"button\";\r\n recordBtn.onclick = this._startRecording.bind(this);\r\n recordBtn.innerHTML = buttonSVGs.record;\r\n this._buttonBar.appendChild(recordBtn);\r\n }\r\n if (whichBtns.indexOf(\"publish\") !== -1) {\r\n let publishBtn = document.createElement(\"div\");\r\n publishBtn.className = \"button\";\r\n publishBtn.onclick = this._createPublishForm.bind(this);\r\n publishBtn.innerHTML = buttonSVGs.publish;\r\n this._buttonBar.appendChild(publishBtn);\r\n }\r\n }\r\n\r\n private _prepDownloadObj() {\r\n this._downloadObj[\"turntable\"] = this.turntable;\r\n this._downloadObj[\"rotationRate\"] = this.rotationRate;\r\n this._downloadObj[\"backgroundColor\"] = this._backgroundColor;\r\n this._downloadObj[\"xScale\"] = this._xScale;\r\n this._downloadObj[\"yScale\"] = this._yScale;\r\n this._downloadObj[\"zScale\"] = this._zScale;\r\n this._downloadObj[\"cameraAlpha\"] = this.camera.alpha;\r\n this._downloadObj[\"cameraBeta\"] = this.camera.beta;\r\n this._downloadObj[\"cameraRadius\"] = this.camera.radius;\r\n this._downloadObj[\"labels\"] = this._annotationManager.exportLabels();\r\n this._downloadObj[\"cameraAlpha\"] = this.camera.alpha;\r\n this._downloadObj[\"cameraBeta\"] = this.camera.beta;\r\n this._downloadObj[\"cameraRadius\"] = this.camera.radius;\r\n }\r\n\r\n private _downloadJson() {\r\n let dlElement = document.createElement(\"a\");\r\n this._prepDownloadObj();\r\n let dlContent = encodeURIComponent(JSON.stringify(this._downloadObj));\r\n dlElement.setAttribute(\"href\", \"data:text/plain;charset=utf-8,\" + dlContent);\r\n dlElement.setAttribute(\"download\", \"babyplots_export.json\");\r\n dlElement.style.display = \"none\";\r\n document.body.appendChild(dlElement);\r\n dlElement.click();\r\n document.body.removeChild(dlElement);\r\n }\r\n\r\n private _createPublishForm() {\r\n\r\n if (this._publishFormOverlay !== undefined) {\r\n return\r\n }\r\n\r\n let formOverlay = document.createElement(\"div\");\r\n\r\n formOverlay.id = \"publishOverlay_\" + this._uniqID;\r\n formOverlay.style.position = \"absolute\";\r\n let r = this.canvas.getBoundingClientRect();\r\n formOverlay.style.top = r.y + \"px\";\r\n formOverlay.style.left = r.x + \"px\";\r\n formOverlay.style.width = r.width + \"px\";\r\n formOverlay.style.height = r.height + \"px\";\r\n formOverlay.style.backgroundColor = \"#ffffff66\";\r\n let formBox = document.createElement(\"div\");\r\n formBox.style.width = \"180px\";\r\n formBox.style.margin = \"42px auto\";\r\n formBox.style.backgroundColor = \"white\";\r\n formBox.style.padding = \"15px 30px\";\r\n formBox.style.borderRadius = \"10px\";\r\n formBox.style.boxShadow = \"0 0 10px #0003\";\r\n formBox.className = \"bbp publish-form\"\r\n formOverlay.appendChild(formBox);\r\n // Upload description text\r\n let formInfo = document.createElement(\"p\");\r\n formInfo.innerText = \"Upload the plot to your account on https://bp.bleb.li. Only you will be able to see it. You can change the access settings in your account.\";\r\n formInfo.className = \"form-info\";\r\n formBox.appendChild(formInfo);\r\n // Inputs and their labels\r\n let usernameLabel = document.createElement(\"label\");\r\n usernameLabel.id = \"publishUsernameLabel_\" + this._uniqID;\r\n usernameLabel.innerText = \"Username:\";\r\n let usernameInput = document.createElement(\"input\");\r\n usernameInput.type = \"text\";\r\n usernameInput.id = \"publishUsername_\" + this._uniqID;\r\n let passwordLabel = document.createElement(\"label\");\r\n passwordLabel.id = \"publishPasswordLabel_\" + this._uniqID;\r\n passwordLabel.innerText = \"Password:\"\r\n let passwordInput = document.createElement(\"input\");\r\n passwordInput.type = \"password\";\r\n passwordInput.id = \"publishPassword_\" + this._uniqID;\r\n let titleLabel = document.createElement(\"label\");\r\n titleLabel.id = \"publishTitleLabel_\" + this._uniqID;\r\n titleLabel.innerText = \"Plot title:\";\r\n let titleInput = document.createElement(\"input\");\r\n titleInput.type = \"text\";\r\n titleInput.id = \"publishTitle_\" + this._uniqID;\r\n // message placeholder\r\n let msg = document.createElement(\"p\");\r\n msg.id = \"publishMessage_\" + this._uniqID;\r\n // Buttons\r\n let publishBtn = document.createElement(\"button\");\r\n publishBtn.className = \"publish-btn\";\r\n publishBtn.id = \"publishBtn_\" + this._uniqID;\r\n publishBtn.onclick = this._tryPublish.bind(this);\r\n publishBtn.innerText = \"Login and publish\";\r\n let cancelBtn = document.createElement(\"button\");\r\n cancelBtn.className = \"cancel-btn\";\r\n cancelBtn.id = \"cancelBtn_\" + this._uniqID;\r\n cancelBtn.onclick = this._cancelPublish.bind(this);\r\n cancelBtn.innerText = \"Cancel\";\r\n let closeBtn = document.createElement(\"button\");\r\n closeBtn.className = \"close-btn\";\r\n closeBtn.id = \"closeBtn_\" + this._uniqID;\r\n closeBtn.onclick = this._cancelPublish.bind(this);\r\n closeBtn.innerText = \"Close\";\r\n closeBtn.style.display = \"none\";\r\n \r\n // Add all form elements to the form\r\n formBox.appendChild(usernameLabel);\r\n formBox.appendChild(usernameInput);\r\n formBox.appendChild(passwordLabel);\r\n formBox.appendChild(passwordInput);\r\n formBox.appendChild(titleLabel);\r\n formBox.appendChild(titleInput);\r\n formBox.appendChild(msg);\r\n formBox.appendChild(publishBtn);\r\n formBox.appendChild(cancelBtn);\r\n formBox.appendChild(closeBtn);\r\n this._publishFormOverlay = formOverlay;\r\n this.canvas.parentNode.appendChild(formOverlay);\r\n }\r\n\r\n private _resizePublishOverlay() {\r\n if (this._publishFormOverlay === undefined) {\r\n return\r\n }\r\n let r = this.canvas.getBoundingClientRect();\r\n this._publishFormOverlay.style.left = r.x + \"px\";\r\n this._publishFormOverlay.style.top = r.y + \"px\";\r\n this._publishFormOverlay.style.width = r.width + \"px\";\r\n this._publishFormOverlay.style.height = r.height + \"px\";\r\n }\r\n\r\n private _tryPublish() {\r\n this.thumbnail(80, (function (thumb_data) {\r\n this._prepDownloadObj();\r\n axios({\r\n method: 'post',\r\n url: 'https://bp.bleb.li/api/publish',\r\n headers: {\r\n 'Content-Type': \"application/json;charset=UTF-8\"\r\n },\r\n data: {\r\n username: (document.getElementById(\"publishUsername_\" + this._uniqID) as HTMLInputElement).value,\r\n password: (document.getElementById(\"publishPassword_\" + this._uniqID) as HTMLInputElement).value,\r\n plotData: JSON.stringify(this._downloadObj),\r\n plotName: (document.getElementById(\"publishTitle_\" + this._uniqID) as HTMLInputElement).value,\r\n thumb: thumb_data\r\n },\r\n\r\n })\r\n .then((function (response) {\r\n let msg = document.getElementById(\"publishMessage_\" + this._uniqID);\r\n msg.innerText = \"Successfully published plot!\";\r\n msg.className = \"message success\";\r\n document.getElementById(\"publishUsername_\" + this._uniqID).style.display = \"none\";\r\n document.getElementById(\"publishUsernameLabel_\" + this._uniqID).style.display = \"none\";\r\n document.getElementById(\"publishPassword_\" + this._uniqID).style.display = \"none\";\r\n document.getElementById(\"publishPasswordLabel_\" + this._uniqID).style.display = \"none\";\r\n document.getElementById(\"publishTitle_\" + this._uniqID).style.display = \"none\";\r\n document.getElementById(\"publishTitleLabel_\" + this._uniqID).style.display = \"none\";\r\n document.getElementById(\"publishBtn_\" + this._uniqID).style.display = \"none\";\r\n document.getElementById(\"cancelBtn_\" + this._uniqID).style.display = \"none\";\r\n document.getElementById(\"closeBtn_\" + this._uniqID).style.display = \"block\";\r\n\r\n }).bind(this))\r\n .catch((function (response) {\r\n if (response.response.data[\"status\"] === \"not authorized\") {\r\n console.log(\"wrong credentials\");\r\n let msg = document.getElementById(\"publishMessage_\" + this._uniqID);\r\n msg.innerText = \"Invalid username or password.\";\r\n msg.className = \"message warning\";\r\n }\r\n console.log(response);\r\n }).bind(this))\r\n }).bind(this));\r\n }\r\n\r\n private _cancelPublish() {\r\n this._publishFormOverlay.remove();\r\n this._publishFormOverlay = undefined;\r\n }\r\n\r\n private _resetAnimation() {\r\n this._hasAnim = true;\r\n this.plots[0].resetAnimation();\r\n let boundingBox = this.plots[0].mesh.getBoundingInfo().boundingBox;\r\n let rangeX = [\r\n boundingBox.minimumWorld.x,\r\n boundingBox.maximumWorld.x\r\n ]\r\n let rangeY = [\r\n boundingBox.minimumWorld.y,\r\n boundingBox.maximumWorld.y\r\n ]\r\n let rangeZ = [\r\n boundingBox.minimumWorld.z,\r\n boundingBox.maximumWorld.z\r\n ]\r\n this._axes[0].axisData.range = [rangeX, rangeY, rangeZ]\r\n this._axes[0].update(this.camera, true);\r\n }\r\n\r\n private _startRecording() {\r\n this._recording = true;\r\n }\r\n\r\n /**\r\n * Register before render\r\n */\r\n private _prepRender(): void {\r\n // rotate camera around plot if turntable is true\r\n if (this.turntable) {\r\n this.camera.alpha += this.rotationRate;\r\n }\r\n // update plots with animations\r\n if (this._hasAnim) {\r\n this._hasAnim = this.plots[0].update();\r\n if (!this._hasAnim) {\r\n let boundingBox = this.plots[0].mesh.getBoundingInfo().boundingBox;\r\n let rangeX = [\r\n boundingBox.minimumWorld.x,\r\n boundingBox.maximumWorld.x\r\n ]\r\n let rangeY = [\r\n boundingBox.minimumWorld.y,\r\n boundingBox.maximumWorld.y\r\n ]\r\n let rangeZ = [\r\n boundingBox.minimumWorld.z,\r\n boundingBox.maximumWorld.z\r\n ]\r\n this._axes[0].axisData.range = [rangeX, rangeY, rangeZ]\r\n this._axes[0].update(this.camera, true);\r\n }\r\n }\r\n // update axis drawing\r\n if (this._axes) {\r\n for (let i = 0; i < this._axes.length; i++) {\r\n this._axes[i].update(this.camera);\r\n }\r\n }\r\n\r\n // update labels\r\n this._annotationManager.update();\r\n\r\n // for (let pltIdx = 0; pltIdx < this.plots.length; pltIdx++) {\r\n // const plot = this.plots[pltIdx];\r\n // plot.update(); \r\n // }\r\n // if (this._mouseOverCheck) {\r\n // const pickResult = this._scene.pick(this._scene.pointerX, this._scene.pointerY);\r\n // const faceId = pickResult.faceId;\r\n // if (faceId == -1) {\r\n // return;\r\n // }\r\n // const idx = this._SPS.pickedParticles[faceId].idx;\r\n // this._mouseOverCallback(idx);\r\n // }\r\n }\r\n\r\n\r\n private _afterRender(): void {\r\n if (this._recording) {\r\n // start recording:\r\n if (this._turned === 0) {\r\n let worker = \"./\";\r\n if (this.R) {\r\n worker = \"lib/babyplots-1/\";\r\n }\r\n this._capturer = new CCapture({\r\n format: \"gif\",\r\n framerate: 30,\r\n verbose: false,\r\n display: false,\r\n quality: 50,\r\n workersPath: worker\r\n });\r\n // create capturer, enable turning\r\n this._capturer.start();\r\n this.rotationRate = 0.02;\r\n // to return turntable option to its initial state after recording\r\n if (this.turntable) {\r\n this._wasTurning = true;\r\n } else {\r\n this.turntable = true;\r\n }\r\n let loadingOverlay = document.createElement(\"div\");\r\n loadingOverlay.className = \"bbp overlay\";\r\n loadingOverlay.id = \"GIFloadingOverlay_\" + this._uniqID;\r\n let loadingText = document.createElement(\"h5\");\r\n loadingText.className = \".loading-message\";\r\n loadingText.innerText = \"Recording GIF...\";\r\n loadingText.id = \"GIFloadingText_\" + this._uniqID;\r\n loadingOverlay.appendChild(loadingText);\r\n this.canvas.parentNode.appendChild(loadingOverlay);\r\n }\r\n // recording in progress:\r\n if (this._turned < 2 * Math.PI) {\r\n // while recording, count rotation and capture screenshots\r\n this._turned += this.rotationRate;\r\n this._capturer.capture(this.canvas);\r\n } else {\r\n // after capturing 360°, stop capturing and save gif\r\n this._recording = false;\r\n this._capturer.stop();\r\n let loadingText = document.getElementById(\"GIFloadingText_\" + this._uniqID);\r\n loadingText.innerText = \"Saving GIF...\";\r\n this._capturer.save(function (blob) {\r\n download(blob, \"babyplots.gif\", 'image/gif');\r\n document.getElementById(\"GIFloadingText_\" + this._uniqID).remove();\r\n document.getElementById(\"GIFloadingOverlay_\" + this._uniqID).remove();\r\n });\r\n this._turned = 0;\r\n this.rotationRate = 0.01;\r\n this._hl2.diffuse = new Color3(0.8, 0.8, 0.8);\r\n if (!this._wasTurning) {\r\n this.turntable = false;\r\n }\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Zoom camera to fit the complete SPS into the field of view\r\n */\r\n private _cameraFitPlot(xRange: number[], yRange: number[], zRange: number[]): void {\r\n let xSize = xRange[1] - xRange[0];\r\n let ySize = yRange[1] - yRange[0];\r\n let zSize = zRange[1] - zRange[0];\r\n let box = BoxBuilder.CreateBox('bdbx', {\r\n width: xSize, height: ySize, depth: zSize\r\n }, this.scene);\r\n let xCenter = xRange[1] - xSize / 2;\r\n let yCenter = yRange[1] - ySize / 2;\r\n let zCenter = zRange[1] - zSize / 2;\r\n box.position = new Vector3(xCenter, yCenter, zCenter);\r\n this.camera.position = new Vector3(xCenter, ySize, zCenter);\r\n this.camera.target = new Vector3(xCenter, yCenter, zCenter);\r\n let radius = box.getBoundingInfo().boundingSphere.radiusWorld;\r\n let aspectRatio = this._engine.getAspectRatio(this.camera);\r\n let halfMinFov = this.camera.fov / 2;\r\n if (aspectRatio < 1) {\r\n halfMinFov = Math.atan(aspectRatio * Math.tan(this.camera.fov / 2));\r\n }\r\n let viewRadius = Math.abs(radius / Math.sin(halfMinFov));\r\n this.camera.radius = viewRadius;\r\n box.dispose();\r\n this.camera.alpha = 0;\r\n this.camera.beta = 1; // 0 is top view, Pi is bottom\r\n this.ymax = yRange[1];\r\n }\r\n\r\n addImgStack(\r\n values: number[],\r\n indices: number[],\r\n attributes: { dim: number[] },\r\n options: {}\r\n ) {\r\n // default options\r\n let opts = {\r\n size: 1,\r\n colorScale: null,\r\n showLegend: false,\r\n fontSize: 11,\r\n fontColor: \"black\",\r\n legendTitle: null,\r\n legendTitleFontSize: 16,\r\n legendPosition: null,\r\n showAxes: [false, false, false],\r\n axisLabels: [\"X\", \"Y\", \"Z\"],\r\n axisColors: [\"#666666\", \"#666666\", \"#666666\"],\r\n tickBreaks: [2, 2, 2],\r\n showTickLines: [[false, false], [false, false], [false, false]],\r\n tickLineColors: [[\"#aaaaaa\", \"#aaaaaa\"], [\"#aaaaaa\", \"#aaaaaa\"], [\"#aaaaaa\", \"#aaaaaa\"]],\r\n intensityMode: \"alpha\"\r\n }\r\n // apply user options\r\n Object.assign(opts, options);\r\n // prepare object for download as json button\r\n this._downloadObj[\"plots\"].push({\r\n plotType: \"imageStack\",\r\n values: values,\r\n indices: indices,\r\n attributes: attributes,\r\n size: opts.size,\r\n colorScale: opts.colorScale,\r\n showLegend: opts.showLegend,\r\n fontSize: opts.fontSize,\r\n fontColor: opts.fontColor,\r\n legendTitle: opts.legendTitle,\r\n legendTitleFontSize: opts.legendTitleFontSize,\r\n legendPosition: opts.legendPosition,\r\n showAxes: opts.showAxes,\r\n axisLabels: opts.axisLabels,\r\n axisColors: opts.axisColors,\r\n tickBreaks: opts.tickBreaks,\r\n showTickLines: opts.showTickLines,\r\n tickLineColors: opts.tickLineColors,\r\n intensityMode: opts.intensityMode\r\n })\r\n let legendData: LegendData = {\r\n showLegend: false,\r\n discrete: false,\r\n breaks: [],\r\n colorScale: \"\",\r\n inverted: false,\r\n position: opts.legendPosition\r\n }\r\n legendData.fontSize = opts.fontSize;\r\n legendData.fontColor = opts.fontColor;\r\n legendData.legendTitle = opts.legendTitle;\r\n legendData.legendTitleFontSize = opts.legendTitleFontSize;\r\n\r\n let plot = new ImgStack(\r\n this.scene,\r\n values,\r\n indices,\r\n attributes,\r\n legendData,\r\n opts.size,\r\n this._backgroundColor,\r\n opts.intensityMode,\r\n this._xScale,\r\n this._yScale,\r\n this._zScale\r\n );\r\n this.plots.push(plot);\r\n this._updateLegend();\r\n this._cameraFitPlot([0, attributes.dim[2]], [0, attributes.dim[0]], [0, attributes.dim[1]]);\r\n this.camera.wheelPrecision = 1;\r\n return this;\r\n }\r\n\r\n addPlot(\r\n coordinates: number[][],\r\n plotType: string,\r\n colorBy: string,\r\n colorVar: string[] | number[],\r\n options = {}\r\n ): Plots {\r\n // default options\r\n let opts = {\r\n size: 1,\r\n xScale: 1,\r\n yScale: 1,\r\n zScale: 1,\r\n colorScale: \"Oranges\",\r\n customColorScale: [],\r\n colorScaleInverted: false,\r\n sortedCategories: [],\r\n showLegend: false,\r\n fontSize: 11,\r\n fontColor: \"black\",\r\n legendTitle: null,\r\n legendTitleFontSize: 16,\r\n legendPosition: null,\r\n showAxes: [false, false, false],\r\n axisLabels: [\"X\", \"Y\", \"Z\"],\r\n axisColors: [\"#666666\", \"#666666\", \"#666666\"],\r\n tickBreaks: [2, 2, 2],\r\n showTickLines: [[false, false], [false, false], [false, false]],\r\n tickLineColors: [[\"#aaaaaa\", \"#aaaaaa\"], [\"#aaaaaa\", \"#aaaaaa\"], [\"#aaaaaa\", \"#aaaaaa\"]],\r\n folded: false,\r\n foldedEmbedding: null,\r\n foldAnimDelay: null,\r\n foldAnimDuration: null,\r\n colnames: null,\r\n rownames: null\r\n }\r\n // apply user options\r\n Object.assign(opts, options);\r\n // create plot data object for download as json button\r\n this._downloadObj[\"plots\"].push({\r\n plotType: plotType,\r\n coordinates: coordinates,\r\n colorBy: colorBy,\r\n colorVar: colorVar,\r\n size: opts.size,\r\n colorScale: opts.colorScale,\r\n customColorScale: opts.customColorScale,\r\n colorScaleInverted: opts.colorScaleInverted,\r\n sortedCategories: opts.sortedCategories,\r\n showLegend: opts.showLegend,\r\n fontSize: opts.fontSize,\r\n fontColor: opts.fontColor,\r\n legendTitle: opts.legendTitle,\r\n legendTitleFontSize: opts.legendTitleFontSize,\r\n legendPosition: opts.legendPosition,\r\n showAxes: opts.showAxes,\r\n axisLabels: opts.axisLabels,\r\n axisColors: opts.axisColors,\r\n tickBreaks: opts.tickBreaks,\r\n showTickLines: opts.showTickLines,\r\n tickLineColors: opts.tickLineColors,\r\n folded: opts.folded,\r\n foldedEmbedding: opts.foldedEmbedding,\r\n foldAnimDelay: opts.foldAnimDelay,\r\n foldAnimDuration: opts.foldAnimDuration,\r\n colnames: opts.colnames,\r\n rownames: opts.rownames\r\n })\r\n\r\n let coordColors: string[] = [];\r\n var legendData: LegendData;\r\n let rangeX: number[];\r\n let rangeY: number[];\r\n let rangeZ: number[];\r\n this._hasAnim = opts.folded;\r\n if (opts.folded) {\r\n let replayBtn = document.createElement(\"div\");\r\n replayBtn.className = \"button\"\r\n replayBtn.innerHTML = buttonSVGs.replay;\r\n replayBtn.onclick = this._resetAnimation.bind(this);\r\n this._buttonBar.appendChild(replayBtn);\r\n }\r\n\r\n switch (colorBy) {\r\n case \"categories\":\r\n // color plot by discrete categories\r\n let groups = colorVar as string[];\r\n let uniqueGroups = getUniqueVals(groups);\r\n // sortedCategories can contain an array of category names to order the groups for coloring.\r\n // sortedCategories must be of same length as unique groups in colorVar.\r\n // if no custom ordering is performed through sortedCategories, groups will be sorted alphabetically.\r\n uniqueGroups.sort();\r\n if (opts.sortedCategories) {\r\n if (uniqueGroups.length === opts.sortedCategories.length) {\r\n // sortedCategories must contain the same category names as those present in colorVar.\r\n if (JSON.stringify(uniqueGroups) === JSON.stringify(opts.sortedCategories.slice(0).sort())) {\r\n uniqueGroups = opts.sortedCategories;\r\n }\r\n }\r\n }\r\n let nColors = uniqueGroups.length;\r\n // Paired is default color scale for discrete variable coloring\r\n let colors = chroma.scale(chroma.brewer.Paired).mode('lch').colors(nColors);\r\n // check if color scale should be custom\r\n if (opts.colorScale === \"custom\") {\r\n if (opts.customColorScale !== undefined && opts.customColorScale.length !== 0) {\r\n if (opts.colorScaleInverted) {\r\n colors = chroma.scale(opts.customColorScale).domain([1, 0]).mode('lch').colors(nColors);\r\n } else {\r\n colors = chroma.scale(opts.customColorScale).mode('lch').colors(nColors);\r\n }\r\n } else {\r\n // set colorScale variable to default for legend if custom color scale is invalid\r\n opts.colorScale = \"Paired\";\r\n }\r\n } else {\r\n // check if user selected color scale is a valid chromajs color brewer name\r\n if (opts.colorScale && chroma.brewer.hasOwnProperty(opts.colorScale)) {\r\n if (opts.colorScaleInverted) {\r\n colors = chroma.scale(chroma.brewer[opts.colorScale]).domain([1, 0]).mode('lch').colors(nColors);\r\n } else {\r\n colors = chroma.scale(chroma.brewer[opts.colorScale]).mode('lch').colors(nColors);\r\n }\r\n } else {\r\n // set colorScale variable to default for legend if user selected is not valid\r\n opts.colorScale = \"Paired\";\r\n }\r\n }\r\n for (let i = 0; i < nColors; i++) {\r\n colors[i] += \"ff\";\r\n }\r\n // apply colors to plot points\r\n for (let i = 0; i < colorVar.length; i++) {\r\n let colorIndex = uniqueGroups.indexOf(groups[i]);\r\n coordColors.push(colors[colorIndex]);\r\n }\r\n // prepare object for legend drawing\r\n legendData = {\r\n showLegend: opts.showLegend,\r\n discrete: true,\r\n breaks: uniqueGroups,\r\n colorScale: opts.colorScale,\r\n customColorScale: opts.customColorScale,\r\n inverted: false,\r\n position: opts.legendPosition\r\n }\r\n break;\r\n case \"values\":\r\n // color by a continuous variable\r\n let min = colorVar.min();\r\n let max = colorVar.max();\r\n // Oranges is default color scale for continuous variable coloring\r\n let colorfunc = chroma.scale(chroma.brewer.Oranges).mode('lch');\r\n // check if color scale should be custom\r\n if (opts.colorScale === \"custom\") {\r\n // check if custom color scale is valid\r\n if (opts.customColorScale !== undefined && opts.customColorScale.length !== 0) {\r\n if (opts.colorScaleInverted) {\r\n colorfunc = chroma.scale(opts.customColorScale).domain([1, 0]).mode('lch');\r\n } else {\r\n colorfunc = chroma.scale(opts.customColorScale).mode('lch');\r\n }\r\n } else {\r\n // set colorScale variable to default for legend if custom color scale is invalid\r\n opts.colorScale = \"Oranges\";\r\n }\r\n } else {\r\n // check if user selected color scale is a valid chromajs color brewer name\r\n if (opts.colorScale && chroma.brewer.hasOwnProperty(opts.colorScale)) {\r\n if (opts.colorScaleInverted) {\r\n colorfunc = chroma.scale(chroma.brewer[opts.colorScale]).domain([1, 0]).mode('lch');\r\n } else {\r\n colorfunc = chroma.scale(chroma.brewer[opts.colorScale]).mode('lch');\r\n }\r\n } else {\r\n // set colorScale variable to default for legend if user selected is not valid\r\n opts.colorScale = \"Oranges\";\r\n }\r\n }\r\n // normalize the values to 0-1 range\r\n let norm = (colorVar as number[]).slice().map(v => (v - min) / (max - min));\r\n // apply colors to plot points\r\n coordColors = norm.map(v => colorfunc(v).alpha(1).hex(\"rgba\"));\r\n // prepare object for legend drawing\r\n legendData = {\r\n showLegend: opts.showLegend,\r\n discrete: false,\r\n breaks: [min.toString(), max.toString()],\r\n colorScale: opts.colorScale,\r\n customColorScale: opts.customColorScale,\r\n inverted: opts.colorScaleInverted,\r\n position: opts.legendPosition\r\n }\r\n break;\r\n case \"direct\":\r\n // color by color hex strings in colorVar\r\n for (let i = 0; i < colorVar.length; i++) {\r\n let cl = colorVar[i];\r\n cl = chroma(cl).hex();\r\n if (cl.length == 7) {\r\n cl += \"ff\";\r\n }\r\n coordColors.push(cl);\r\n }\r\n // prepare object for legend drawing\r\n legendData = {\r\n showLegend: false,\r\n discrete: false,\r\n breaks: [],\r\n colorScale: \"\",\r\n customColorScale: opts.customColorScale,\r\n inverted: false,\r\n position: opts.legendPosition\r\n }\r\n break;\r\n }\r\n // add remaining properties to legend object\r\n legendData.fontSize = opts.fontSize;\r\n legendData.fontColor = opts.fontColor;\r\n legendData.legendTitle = opts.legendTitle;\r\n legendData.legendTitleFontSize = opts.legendTitleFontSize;\r\n\r\n let plot: Plot;\r\n let scale: number[];\r\n switch (plotType) {\r\n case \"pointCloud\":\r\n plot = new PointCloud(\r\n this.scene,\r\n coordinates,\r\n coordColors,\r\n opts.size,\r\n legendData,\r\n opts.folded,\r\n opts.foldedEmbedding,\r\n opts.foldAnimDelay,\r\n opts.foldAnimDuration,\r\n this._xScale,\r\n this._yScale,\r\n this._zScale\r\n );\r\n let boundingBox = plot.mesh.getBoundingInfo().boundingBox;\r\n rangeX = [\r\n boundingBox.minimumWorld.x,\r\n boundingBox.maximumWorld.x\r\n ]\r\n rangeY = [\r\n boundingBox.minimumWorld.y,\r\n boundingBox.maximumWorld.y\r\n ]\r\n rangeZ = [\r\n boundingBox.minimumWorld.z,\r\n boundingBox.maximumWorld.z\r\n ]\r\n scale = [\r\n this._xScale,\r\n this._yScale,\r\n this._zScale,\r\n ]\r\n break;\r\n case \"surface\":\r\n plot = new Surface(\r\n this.scene,\r\n coordinates,\r\n coordColors,\r\n opts.size,\r\n legendData,\r\n this._xScale,\r\n this._yScale,\r\n this._zScale\r\n );\r\n rangeX = [0, coordinates.length * this._xScale];\r\n rangeZ = [0, coordinates[0].length * this._zScale];\r\n rangeY = [\r\n matrixMin(coordinates) * this._yScale,\r\n matrixMax(coordinates) * this._yScale\r\n ];\r\n scale = [\r\n this._xScale,\r\n this._yScale,\r\n this._zScale,\r\n ]\r\n break\r\n case \"heatMap\":\r\n plot = new HeatMap(\r\n this.scene,\r\n coordinates,\r\n coordColors,\r\n opts.size,\r\n legendData,\r\n this._xScale,\r\n this._yScale,\r\n this._zScale\r\n );\r\n rangeX = [0, coordinates.length * this._xScale];\r\n rangeZ = [0, coordinates[0].length * this._zScale];\r\n rangeY = [\r\n matrixMin(coordinates) * this._yScale,\r\n matrixMax(coordinates) * this._yScale\r\n ];\r\n scale = [\r\n this._xScale,\r\n this._yScale,\r\n this._zScale,\r\n ]\r\n break\r\n }\r\n\r\n this.plots.push(plot);\r\n this._updateLegend();\r\n let axisData: AxisData = {\r\n showAxes: opts.showAxes,\r\n static: true,\r\n axisLabels: opts.axisLabels,\r\n range: [rangeX, rangeY, rangeZ],\r\n color: opts.axisColors,\r\n scale: scale,\r\n tickBreaks: opts.tickBreaks,\r\n showTickLines: opts.showTickLines,\r\n tickLineColor: opts.tickLineColors,\r\n showPlanes: [false, false, false],\r\n planeColor: [\"#cccccc88\", \"#cccccc88\", \"#cccccc88\"],\r\n plotType: plotType,\r\n colnames: opts.colnames,\r\n rownames: opts.rownames\r\n }\r\n this._axes.push(new Axes(axisData, this.scene, plotType == \"heatMap\"));\r\n this._cameraFitPlot(rangeX, rangeY, rangeZ);\r\n return this\r\n }\r\n\r\n /**\r\n * Creates a color legend for the plots\r\n */\r\n private _updateLegend(): void {\r\n if (this._legend) { this._legend.dispose(); }\r\n\r\n // create fullscreen GUI texture\r\n let uiLayer = AdvancedDynamicTexture.CreateFullscreenUI(\"UI\");\r\n\r\n let rightFree = true;\r\n let leftFree = true;\r\n for (let i = 0; i < this.plots.length; i++) {\r\n const plot = this.plots[i];\r\n let legendData = plot.legendData;\r\n if ([\"right\", \"left\"].indexOf(legendData.position) === -1) {\r\n legendData.position = null;\r\n }\r\n if (legendData.showLegend) {\r\n if (legendData.position === null) {\r\n if (rightFree) {\r\n legendData.position = \"right\";\r\n rightFree = false;\r\n } else if (leftFree) {\r\n legendData.position = \"left\";\r\n leftFree = false;\r\n } else {\r\n legendData.showLegend = false;\r\n }\r\n } else {\r\n if (legendData.position === \"right\") {\r\n rightFree = false;\r\n } else {\r\n leftFree = false;\r\n }\r\n }\r\n uiLayer = this._createPlotLegend(legendData, uiLayer);\r\n }\r\n }\r\n this._legend = uiLayer;\r\n }\r\n\r\n private _createPlotLegend(legendData: LegendData, uiLayer: AdvancedDynamicTexture): AdvancedDynamicTexture {\r\n if (!legendData.showLegend) {\r\n return uiLayer;\r\n }\r\n let n: number;\r\n let breakN = 20;\r\n // create grid for placing legend in correct position\r\n let grid = new Grid();\r\n uiLayer.addControl(grid);\r\n\r\n // main position of legend (right middle)\r\n let legendWidth = 0.2;\r\n\r\n if (legendData.discrete) {\r\n // number of clusters\r\n n = legendData.breaks.length;\r\n\r\n if (n > breakN * 2) {\r\n legendWidth = 0.4;\r\n }\r\n else if (n > breakN) {\r\n legendWidth = 0.3;\r\n }\r\n }\r\n\r\n let legendColumn = 1;\r\n if (legendData.position === \"right\") {\r\n grid.addColumnDefinition(1 - legendWidth);\r\n grid.addColumnDefinition(legendWidth);\r\n } else {\r\n grid.addColumnDefinition(legendWidth);\r\n grid.addColumnDefinition(1 - legendWidth);\r\n legendColumn = 0;\r\n }\r\n if (legendData.legendTitle && legendData.legendTitle !== \"\") {\r\n grid.addRowDefinition(0.1);\r\n grid.addRowDefinition(0.85);\r\n grid.addRowDefinition(0.05);\r\n }\r\n else {\r\n grid.addRowDefinition(0.05);\r\n grid.addRowDefinition(0.9);\r\n grid.addRowDefinition(0.05);\r\n }\r\n\r\n if (legendData.legendTitle) {\r\n let legendTitle = new TextBlock();\r\n legendTitle.text = legendData.legendTitle;\r\n legendTitle.color = legendData.fontColor;\r\n legendTitle.fontWeight = \"bold\";\r\n if (legendData.legendTitleFontSize) {\r\n legendTitle.fontSize = legendData.legendTitleFontSize + \"px\";\r\n }\r\n else {\r\n legendTitle.fontSize = \"20px\";\r\n }\r\n legendTitle.verticalAlignment = Control.VERTICAL_ALIGNMENT_BOTTOM;\r\n legendTitle.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n grid.addControl(legendTitle, 0, legendColumn);\r\n }\r\n\r\n // for continuous measures display color bar and max and min values.\r\n if (!legendData.discrete) {\r\n\r\n let innerGrid = new Grid();\r\n innerGrid.addColumnDefinition(0.2);\r\n innerGrid.addColumnDefinition(0.8);\r\n grid.addControl(innerGrid, 1, legendColumn);\r\n\r\n let nBreaks = 115;\r\n let labelSpace = 0.15;\r\n if (this.canvas.height < 70) {\r\n nBreaks = 10;\r\n labelSpace = 0.45;\r\n innerGrid.addRowDefinition(1);\r\n }\r\n else if (this.canvas.height < 130) {\r\n nBreaks = 50;\r\n labelSpace = 0.3;\r\n innerGrid.addRowDefinition(1);\r\n }\r\n else {\r\n let padding = (this.canvas.height - 115) / 2;\r\n innerGrid.addRowDefinition(padding, true);\r\n innerGrid.addRowDefinition(115, true);\r\n innerGrid.addRowDefinition(padding, true);\r\n }\r\n // color bar\r\n let colors: string[];\r\n if (legendData.colorScale === \"custom\") {\r\n colors = chroma.scale(legendData.customColorScale).mode('lch').colors(nBreaks);\r\n }\r\n else {\r\n colors = chroma.scale(chroma.brewer[legendData.colorScale]).mode('lch').colors(nBreaks);\r\n }\r\n let scaleGrid = new Grid();\r\n for (let i = 0; i < nBreaks; i++) {\r\n scaleGrid.addRowDefinition(1 / nBreaks);\r\n let legendColor = new Rectangle();\r\n if (legendData.inverted) {\r\n legendColor.background = colors[i];\r\n }\r\n else {\r\n legendColor.background = colors[colors.length - i - 1];\r\n }\r\n legendColor.thickness = 0;\r\n legendColor.width = 0.5;\r\n legendColor.height = 1;\r\n scaleGrid.addControl(legendColor, i, 0);\r\n }\r\n\r\n // label text\r\n let labelGrid = new Grid();\r\n labelGrid.addColumnDefinition(1);\r\n labelGrid.addRowDefinition(labelSpace);\r\n labelGrid.addRowDefinition(1 - labelSpace * 2);\r\n labelGrid.addRowDefinition(labelSpace);\r\n\r\n if (this.canvas.height < 130) {\r\n innerGrid.addControl(scaleGrid, 0, 0);\r\n innerGrid.addControl(labelGrid, 0, 1);\r\n }\r\n else {\r\n innerGrid.addControl(scaleGrid, 1, 0);\r\n innerGrid.addControl(labelGrid, 1, 1);\r\n }\r\n\r\n let minText = new TextBlock();\r\n minText.text = parseFloat(legendData.breaks[0]).toFixed(2);\r\n minText.color = legendData.fontColor;\r\n minText.fontSize = legendData.fontSize + \"px\";\r\n minText.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n labelGrid.addControl(minText, 2, 0);\r\n\r\n let maxText = new TextBlock();\r\n maxText.text = parseFloat(legendData.breaks[1]).toFixed(2);\r\n maxText.color = legendData.fontColor;\r\n maxText.fontSize = legendData.fontSize + \"px\";\r\n maxText.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n labelGrid.addControl(maxText, 0, 0);\r\n }\r\n else {\r\n // inner Grid contains legend rows and columns for color and text\r\n var innerGrid = new Grid();\r\n // two legend columns when more than 15 colors\r\n if (n > breakN * 2) {\r\n innerGrid.addColumnDefinition(0.1);\r\n innerGrid.addColumnDefinition(0.4);\r\n innerGrid.addColumnDefinition(0.1);\r\n innerGrid.addColumnDefinition(0.4);\r\n innerGrid.addColumnDefinition(0.1);\r\n innerGrid.addColumnDefinition(0.4);\r\n }\r\n else if (n > breakN) {\r\n innerGrid.addColumnDefinition(0.1);\r\n innerGrid.addColumnDefinition(0.4);\r\n innerGrid.addColumnDefinition(0.1);\r\n innerGrid.addColumnDefinition(0.4);\r\n }\r\n else {\r\n innerGrid.addColumnDefinition(0.2);\r\n innerGrid.addColumnDefinition(0.8);\r\n }\r\n for (let i = 0; i < n && i < breakN; i++) {\r\n if (n > breakN) {\r\n innerGrid.addRowDefinition(1 / breakN);\r\n }\r\n else {\r\n innerGrid.addRowDefinition(1 / n);\r\n }\r\n }\r\n grid.addControl(innerGrid, 1, legendColumn);\r\n\r\n let colors: string[];\r\n if (legendData.colorScale === \"custom\") {\r\n colors = chroma.scale(legendData.customColorScale).mode('lch').colors(n);\r\n }\r\n else {\r\n colors = chroma.scale(chroma.brewer[legendData.colorScale]).mode('lch').colors(n);\r\n }\r\n\r\n // add color box and legend text\r\n for (let i = 0; i < n; i++) {\r\n // color\r\n var legendColor = new Rectangle();\r\n legendColor.background = colors[i];\r\n legendColor.thickness = 0;\r\n legendColor.width = legendData.fontSize + \"px\";\r\n legendColor.height = legendData.fontSize + \"px\";\r\n // use second column for many entries\r\n if (i > breakN * 2 - 1) {\r\n innerGrid.addControl(legendColor, i - breakN * 2, 4);\r\n }\r\n else if (i > breakN - 1) {\r\n innerGrid.addControl(legendColor, i - breakN, 2);\r\n }\r\n else {\r\n innerGrid.addControl(legendColor, i, 0);\r\n }\r\n // text\r\n var legendText = new TextBlock();\r\n legendText.text = legendData.breaks[i].toString();\r\n legendText.color = legendData.fontColor;\r\n legendText.fontSize = legendData.fontSize + \"px\";\r\n legendText.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n // use second column for many entries\r\n if (i > breakN * 2 - 1) {\r\n innerGrid.addControl(legendText, i - breakN * 2, 5);\r\n }\r\n if (i > breakN - 1) {\r\n innerGrid.addControl(legendText, i - breakN, 3);\r\n }\r\n else {\r\n innerGrid.addControl(legendText, i, 1);\r\n }\r\n }\r\n }\r\n return uiLayer;\r\n }\r\n\r\n /**\r\n * Start rendering the scene\r\n */\r\n doRender(): Plots {\r\n this._engine.runRenderLoop(() => {\r\n this.scene.render();\r\n });\r\n return this;\r\n }\r\n\r\n resize(width?: number, height?: number): Plots {\r\n if (width !== undefined && height !== undefined) {\r\n if (this.R) {\r\n let pad = parseInt(document.body.style.padding.substring(0, document.body.style.padding.length - 2));\r\n this.canvas.width = width - 2 * pad;\r\n this.canvas.height = height - 2 * pad;\r\n } else {\r\n this.canvas.width = width;\r\n this.canvas.height = height;\r\n }\r\n }\r\n this._updateLegend();\r\n this._resizePublishOverlay();\r\n this._engine.resize();\r\n return this\r\n }\r\n\r\n thumbnail(size: number, saveCallback: (data: string) => void): void {\r\n ScreenshotTools.CreateScreenshot(this._engine, this.camera, size, saveCallback);\r\n }\r\n\r\n dispose(): void {\r\n this.scene.dispose();\r\n this._engine.dispose();\r\n }\r\n\r\n /**\r\n * Add labels from a list of labels.\r\n * \r\n * @param labelList List of lists with the first three elements of the inner lists being the x, y and z coordinates, and the fourth the label text.\r\n */\r\n addLabels(labelList: [[number, number, number, string]]): void {\r\n this._annotationManager.addLabels(labelList);\r\n }\r\n\r\n}\r\n","import { DomManagement } from './domManagement';\r\n/**\r\n * Class used to provide helper for timing\r\n */\r\nvar TimingTools = /** @class */ (function () {\r\n function TimingTools() {\r\n }\r\n /**\r\n * Polyfill for setImmediate\r\n * @param action defines the action to execute after the current execution block\r\n */\r\n TimingTools.SetImmediate = function (action) {\r\n if (DomManagement.IsWindowObjectExist() && window.setImmediate) {\r\n window.setImmediate(action);\r\n }\r\n else {\r\n setTimeout(action, 1);\r\n }\r\n };\r\n return TimingTools;\r\n}());\r\nexport { TimingTools };\r\n//# sourceMappingURL=timingTools.js.map","import { ArrayTools } from \"../Misc/arrayTools\";\r\nimport { Matrix, Vector3 } from \"../Maths/math.vector\";\r\n/**\r\n * Class used to store bounding sphere information\r\n */\r\nvar BoundingSphere = /** @class */ (function () {\r\n /**\r\n * Creates a new bounding sphere\r\n * @param min defines the minimum vector (in local space)\r\n * @param max defines the maximum vector (in local space)\r\n * @param worldMatrix defines the new world matrix\r\n */\r\n function BoundingSphere(min, max, worldMatrix) {\r\n /**\r\n * Gets the center of the bounding sphere in local space\r\n */\r\n this.center = Vector3.Zero();\r\n /**\r\n * Gets the center of the bounding sphere in world space\r\n */\r\n this.centerWorld = Vector3.Zero();\r\n /**\r\n * Gets the minimum vector in local space\r\n */\r\n this.minimum = Vector3.Zero();\r\n /**\r\n * Gets the maximum vector in local space\r\n */\r\n this.maximum = Vector3.Zero();\r\n this.reConstruct(min, max, worldMatrix);\r\n }\r\n /**\r\n * Recreates the entire bounding sphere from scratch as if we call the constructor in place\r\n * @param min defines the new minimum vector (in local space)\r\n * @param max defines the new maximum vector (in local space)\r\n * @param worldMatrix defines the new world matrix\r\n */\r\n BoundingSphere.prototype.reConstruct = function (min, max, worldMatrix) {\r\n this.minimum.copyFrom(min);\r\n this.maximum.copyFrom(max);\r\n var distance = Vector3.Distance(min, max);\r\n max.addToRef(min, this.center).scaleInPlace(0.5);\r\n this.radius = distance * 0.5;\r\n this._update(worldMatrix || Matrix.IdentityReadOnly);\r\n };\r\n /**\r\n * Scale the current bounding sphere by applying a scale factor\r\n * @param factor defines the scale factor to apply\r\n * @returns the current bounding box\r\n */\r\n BoundingSphere.prototype.scale = function (factor) {\r\n var newRadius = this.radius * factor;\r\n var tmpVectors = BoundingSphere.TmpVector3;\r\n var tempRadiusVector = tmpVectors[0].setAll(newRadius);\r\n var min = this.center.subtractToRef(tempRadiusVector, tmpVectors[1]);\r\n var max = this.center.addToRef(tempRadiusVector, tmpVectors[2]);\r\n this.reConstruct(min, max, this._worldMatrix);\r\n return this;\r\n };\r\n /**\r\n * Gets the world matrix of the bounding box\r\n * @returns a matrix\r\n */\r\n BoundingSphere.prototype.getWorldMatrix = function () {\r\n return this._worldMatrix;\r\n };\r\n // Methods\r\n /** @hidden */\r\n BoundingSphere.prototype._update = function (worldMatrix) {\r\n if (!worldMatrix.isIdentity()) {\r\n Vector3.TransformCoordinatesToRef(this.center, worldMatrix, this.centerWorld);\r\n var tempVector = BoundingSphere.TmpVector3[0];\r\n Vector3.TransformNormalFromFloatsToRef(1.0, 1.0, 1.0, worldMatrix, tempVector);\r\n this.radiusWorld = Math.max(Math.abs(tempVector.x), Math.abs(tempVector.y), Math.abs(tempVector.z)) * this.radius;\r\n }\r\n else {\r\n this.centerWorld.copyFrom(this.center);\r\n this.radiusWorld = this.radius;\r\n }\r\n };\r\n /**\r\n * Tests if the bounding sphere is intersecting the frustum planes\r\n * @param frustumPlanes defines the frustum planes to test\r\n * @returns true if there is an intersection\r\n */\r\n BoundingSphere.prototype.isInFrustum = function (frustumPlanes) {\r\n var center = this.centerWorld;\r\n var radius = this.radiusWorld;\r\n for (var i = 0; i < 6; i++) {\r\n if (frustumPlanes[i].dotCoordinate(center) <= -radius) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Tests if the bounding sphere center is in between the frustum planes.\r\n * Used for optimistic fast inclusion.\r\n * @param frustumPlanes defines the frustum planes to test\r\n * @returns true if the sphere center is in between the frustum planes\r\n */\r\n BoundingSphere.prototype.isCenterInFrustum = function (frustumPlanes) {\r\n var center = this.centerWorld;\r\n for (var i = 0; i < 6; i++) {\r\n if (frustumPlanes[i].dotCoordinate(center) < 0) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Tests if a point is inside the bounding sphere\r\n * @param point defines the point to test\r\n * @returns true if the point is inside the bounding sphere\r\n */\r\n BoundingSphere.prototype.intersectsPoint = function (point) {\r\n var squareDistance = Vector3.DistanceSquared(this.centerWorld, point);\r\n if (this.radiusWorld * this.radiusWorld < squareDistance) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n // Statics\r\n /**\r\n * Checks if two sphere intersct\r\n * @param sphere0 sphere 0\r\n * @param sphere1 sphere 1\r\n * @returns true if the speres intersect\r\n */\r\n BoundingSphere.Intersects = function (sphere0, sphere1) {\r\n var squareDistance = Vector3.DistanceSquared(sphere0.centerWorld, sphere1.centerWorld);\r\n var radiusSum = sphere0.radiusWorld + sphere1.radiusWorld;\r\n if (radiusSum * radiusSum < squareDistance) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n BoundingSphere.TmpVector3 = ArrayTools.BuildArray(3, Vector3.Zero);\r\n return BoundingSphere;\r\n}());\r\nexport { BoundingSphere };\r\n//# sourceMappingURL=boundingSphere.js.map","import { Material } from \"../Materials/material\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\n/**\r\n * PostProcessManager is used to manage one or more post processes or post process pipelines\r\n * See https://doc.babylonjs.com/how_to/how_to_use_postprocesses\r\n */\r\nvar PostProcessManager = /** @class */ (function () {\r\n /**\r\n * Creates a new instance PostProcess\r\n * @param scene The scene that the post process is associated with.\r\n */\r\n function PostProcessManager(scene) {\r\n this._vertexBuffers = {};\r\n this._scene = scene;\r\n }\r\n PostProcessManager.prototype._prepareBuffers = function () {\r\n if (this._vertexBuffers[VertexBuffer.PositionKind]) {\r\n return;\r\n }\r\n // VBO\r\n var vertices = [];\r\n vertices.push(1, 1);\r\n vertices.push(-1, 1);\r\n vertices.push(-1, -1);\r\n vertices.push(1, -1);\r\n this._vertexBuffers[VertexBuffer.PositionKind] = new VertexBuffer(this._scene.getEngine(), vertices, VertexBuffer.PositionKind, false, false, 2);\r\n this._buildIndexBuffer();\r\n };\r\n PostProcessManager.prototype._buildIndexBuffer = function () {\r\n // Indices\r\n var indices = [];\r\n indices.push(0);\r\n indices.push(1);\r\n indices.push(2);\r\n indices.push(0);\r\n indices.push(2);\r\n indices.push(3);\r\n this._indexBuffer = this._scene.getEngine().createIndexBuffer(indices);\r\n };\r\n /**\r\n * Rebuilds the vertex buffers of the manager.\r\n * @hidden\r\n */\r\n PostProcessManager.prototype._rebuild = function () {\r\n var vb = this._vertexBuffers[VertexBuffer.PositionKind];\r\n if (!vb) {\r\n return;\r\n }\r\n vb._rebuild();\r\n this._buildIndexBuffer();\r\n };\r\n // Methods\r\n /**\r\n * Prepares a frame to be run through a post process.\r\n * @param sourceTexture The input texture to the post procesess. (default: null)\r\n * @param postProcesses An array of post processes to be run. (default: null)\r\n * @returns True if the post processes were able to be run.\r\n * @hidden\r\n */\r\n PostProcessManager.prototype._prepareFrame = function (sourceTexture, postProcesses) {\r\n if (sourceTexture === void 0) { sourceTexture = null; }\r\n if (postProcesses === void 0) { postProcesses = null; }\r\n var camera = this._scene.activeCamera;\r\n if (!camera) {\r\n return false;\r\n }\r\n postProcesses = postProcesses || camera._postProcesses.filter(function (pp) { return pp != null; });\r\n if (!postProcesses || postProcesses.length === 0 || !this._scene.postProcessesEnabled) {\r\n return false;\r\n }\r\n postProcesses[0].activate(camera, sourceTexture, postProcesses !== null && postProcesses !== undefined);\r\n return true;\r\n };\r\n /**\r\n * Manually render a set of post processes to a texture.\r\n * @param postProcesses An array of post processes to be run.\r\n * @param targetTexture The target texture to render to.\r\n * @param forceFullscreenViewport force gl.viewport to be full screen eg. 0,0,textureWidth,textureHeight\r\n * @param faceIndex defines the face to render to if a cubemap is defined as the target\r\n * @param lodLevel defines which lod of the texture to render to\r\n */\r\n PostProcessManager.prototype.directRender = function (postProcesses, targetTexture, forceFullscreenViewport, faceIndex, lodLevel) {\r\n if (targetTexture === void 0) { targetTexture = null; }\r\n if (forceFullscreenViewport === void 0) { forceFullscreenViewport = false; }\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (lodLevel === void 0) { lodLevel = 0; }\r\n var engine = this._scene.getEngine();\r\n for (var index = 0; index < postProcesses.length; index++) {\r\n if (index < postProcesses.length - 1) {\r\n postProcesses[index + 1].activate(this._scene.activeCamera, targetTexture);\r\n }\r\n else {\r\n if (targetTexture) {\r\n engine.bindFramebuffer(targetTexture, faceIndex, undefined, undefined, forceFullscreenViewport, lodLevel);\r\n }\r\n else {\r\n engine.restoreDefaultFramebuffer();\r\n }\r\n }\r\n var pp = postProcesses[index];\r\n var effect = pp.apply();\r\n if (effect) {\r\n pp.onBeforeRenderObservable.notifyObservers(effect);\r\n // VBOs\r\n this._prepareBuffers();\r\n engine.bindBuffers(this._vertexBuffers, this._indexBuffer, effect);\r\n // Draw order\r\n engine.drawElementsType(Material.TriangleFillMode, 0, 6);\r\n pp.onAfterRenderObservable.notifyObservers(effect);\r\n }\r\n }\r\n // Restore depth buffer\r\n engine.setDepthBuffer(true);\r\n engine.setDepthWrite(true);\r\n };\r\n /**\r\n * Finalize the result of the output of the postprocesses.\r\n * @param doNotPresent If true the result will not be displayed to the screen.\r\n * @param targetTexture The target texture to render to.\r\n * @param faceIndex The index of the face to bind the target texture to.\r\n * @param postProcesses The array of post processes to render.\r\n * @param forceFullscreenViewport force gl.viewport to be full screen eg. 0,0,textureWidth,textureHeight (default: false)\r\n * @hidden\r\n */\r\n PostProcessManager.prototype._finalizeFrame = function (doNotPresent, targetTexture, faceIndex, postProcesses, forceFullscreenViewport) {\r\n if (forceFullscreenViewport === void 0) { forceFullscreenViewport = false; }\r\n var camera = this._scene.activeCamera;\r\n if (!camera) {\r\n return;\r\n }\r\n postProcesses = postProcesses || camera._postProcesses.filter(function (pp) { return pp != null; });\r\n if (postProcesses.length === 0 || !this._scene.postProcessesEnabled) {\r\n return;\r\n }\r\n var engine = this._scene.getEngine();\r\n for (var index = 0, len = postProcesses.length; index < len; index++) {\r\n var pp = postProcesses[index];\r\n if (index < len - 1) {\r\n pp._outputTexture = postProcesses[index + 1].activate(camera, targetTexture);\r\n }\r\n else {\r\n if (targetTexture) {\r\n engine.bindFramebuffer(targetTexture, faceIndex, undefined, undefined, forceFullscreenViewport);\r\n pp._outputTexture = targetTexture;\r\n }\r\n else {\r\n engine.restoreDefaultFramebuffer();\r\n pp._outputTexture = null;\r\n }\r\n }\r\n if (doNotPresent) {\r\n break;\r\n }\r\n var effect = pp.apply();\r\n if (effect) {\r\n pp.onBeforeRenderObservable.notifyObservers(effect);\r\n // VBOs\r\n this._prepareBuffers();\r\n engine.bindBuffers(this._vertexBuffers, this._indexBuffer, effect);\r\n // Draw order\r\n engine.drawElementsType(Material.TriangleFillMode, 0, 6);\r\n pp.onAfterRenderObservable.notifyObservers(effect);\r\n }\r\n }\r\n // Restore states\r\n engine.setDepthBuffer(true);\r\n engine.setDepthWrite(true);\r\n engine.setAlphaMode(0);\r\n };\r\n /**\r\n * Disposes of the post process manager.\r\n */\r\n PostProcessManager.prototype.dispose = function () {\r\n var buffer = this._vertexBuffers[VertexBuffer.PositionKind];\r\n if (buffer) {\r\n buffer.dispose();\r\n this._vertexBuffers[VertexBuffer.PositionKind] = null;\r\n }\r\n if (this._indexBuffer) {\r\n this._scene.getEngine()._releaseBuffer(this._indexBuffer);\r\n this._indexBuffer = null;\r\n }\r\n };\r\n return PostProcessManager;\r\n}());\r\nexport { PostProcessManager };\r\n//# sourceMappingURL=postProcessManager.js.map","/**\r\n * @hidden\r\n */\r\nvar IntersectionInfo = /** @class */ (function () {\r\n function IntersectionInfo(bu, bv, distance) {\r\n this.bu = bu;\r\n this.bv = bv;\r\n this.distance = distance;\r\n this.faceId = 0;\r\n this.subMeshId = 0;\r\n }\r\n return IntersectionInfo;\r\n}());\r\nexport { IntersectionInfo };\r\n//# sourceMappingURL=intersectionInfo.js.map","import { StringTools } from '../../Misc/stringTools';\r\n/** @hidden */\r\nvar ShaderCodeNode = /** @class */ (function () {\r\n function ShaderCodeNode() {\r\n this.children = [];\r\n }\r\n ShaderCodeNode.prototype.isValid = function (preprocessors) {\r\n return true;\r\n };\r\n ShaderCodeNode.prototype.process = function (preprocessors, options) {\r\n var result = \"\";\r\n if (this.line) {\r\n var value = this.line;\r\n var processor = options.processor;\r\n if (processor) {\r\n // This must be done before other replacements to avoid mistakenly changing something that was already changed.\r\n if (processor.lineProcessor) {\r\n value = processor.lineProcessor(value, options.isFragment);\r\n }\r\n if (processor.attributeProcessor && StringTools.StartsWith(this.line, \"attribute\")) {\r\n value = processor.attributeProcessor(this.line);\r\n }\r\n else if (processor.varyingProcessor && StringTools.StartsWith(this.line, \"varying\")) {\r\n value = processor.varyingProcessor(this.line, options.isFragment);\r\n }\r\n else if ((processor.uniformProcessor || processor.uniformBufferProcessor) && StringTools.StartsWith(this.line, \"uniform\")) {\r\n var regex = /uniform (.+) (.+)/;\r\n if (regex.test(this.line)) { // uniform\r\n if (processor.uniformProcessor) {\r\n value = processor.uniformProcessor(this.line, options.isFragment);\r\n }\r\n }\r\n else { // Uniform buffer\r\n if (processor.uniformBufferProcessor) {\r\n value = processor.uniformBufferProcessor(this.line, options.isFragment);\r\n options.lookForClosingBracketForUniformBuffer = true;\r\n }\r\n }\r\n }\r\n if (processor.endOfUniformBufferProcessor) {\r\n if (options.lookForClosingBracketForUniformBuffer && this.line.indexOf(\"}\") !== -1) {\r\n options.lookForClosingBracketForUniformBuffer = false;\r\n value = processor.endOfUniformBufferProcessor(this.line, options.isFragment);\r\n }\r\n }\r\n }\r\n result += value + \"\\r\\n\";\r\n }\r\n this.children.forEach(function (child) {\r\n result += child.process(preprocessors, options);\r\n });\r\n if (this.additionalDefineKey) {\r\n preprocessors[this.additionalDefineKey] = this.additionalDefineValue || \"true\";\r\n }\r\n return result;\r\n };\r\n return ShaderCodeNode;\r\n}());\r\nexport { ShaderCodeNode };\r\n//# sourceMappingURL=shaderCodeNode.js.map","/** @hidden */\r\nvar ShaderCodeCursor = /** @class */ (function () {\r\n function ShaderCodeCursor() {\r\n }\r\n Object.defineProperty(ShaderCodeCursor.prototype, \"currentLine\", {\r\n get: function () {\r\n return this._lines[this.lineIndex];\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ShaderCodeCursor.prototype, \"canRead\", {\r\n get: function () {\r\n return this.lineIndex < this._lines.length - 1;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ShaderCodeCursor.prototype, \"lines\", {\r\n set: function (value) {\r\n this._lines = [];\r\n for (var _i = 0, value_1 = value; _i < value_1.length; _i++) {\r\n var line = value_1[_i];\r\n // Prevent removing line break in macros.\r\n if (line[0] === \"#\") {\r\n this._lines.push(line);\r\n continue;\r\n }\r\n var split = line.split(\";\");\r\n for (var index = 0; index < split.length; index++) {\r\n var subLine = split[index];\r\n subLine = subLine.trim();\r\n if (!subLine) {\r\n continue;\r\n }\r\n this._lines.push(subLine + (index !== split.length - 1 ? \";\" : \"\"));\r\n }\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n return ShaderCodeCursor;\r\n}());\r\nexport { ShaderCodeCursor };\r\n//# sourceMappingURL=shaderCodeCursor.js.map","import { __extends } from \"tslib\";\r\nimport { ShaderCodeNode } from './shaderCodeNode';\r\n/** @hidden */\r\nvar ShaderCodeConditionNode = /** @class */ (function (_super) {\r\n __extends(ShaderCodeConditionNode, _super);\r\n function ShaderCodeConditionNode() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n ShaderCodeConditionNode.prototype.process = function (preprocessors, options) {\r\n for (var index = 0; index < this.children.length; index++) {\r\n var node = this.children[index];\r\n if (node.isValid(preprocessors)) {\r\n return node.process(preprocessors, options);\r\n }\r\n }\r\n return \"\";\r\n };\r\n return ShaderCodeConditionNode;\r\n}(ShaderCodeNode));\r\nexport { ShaderCodeConditionNode };\r\n//# sourceMappingURL=shaderCodeConditionNode.js.map","import { __extends } from \"tslib\";\r\nimport { ShaderCodeNode } from './shaderCodeNode';\r\n/** @hidden */\r\nvar ShaderCodeTestNode = /** @class */ (function (_super) {\r\n __extends(ShaderCodeTestNode, _super);\r\n function ShaderCodeTestNode() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n ShaderCodeTestNode.prototype.isValid = function (preprocessors) {\r\n return this.testExpression.isTrue(preprocessors);\r\n };\r\n return ShaderCodeTestNode;\r\n}(ShaderCodeNode));\r\nexport { ShaderCodeTestNode };\r\n//# sourceMappingURL=shaderCodeTestNode.js.map","/** @hidden */\r\nvar ShaderDefineExpression = /** @class */ (function () {\r\n function ShaderDefineExpression() {\r\n }\r\n ShaderDefineExpression.prototype.isTrue = function (preprocessors) {\r\n return true;\r\n };\r\n return ShaderDefineExpression;\r\n}());\r\nexport { ShaderDefineExpression };\r\n//# sourceMappingURL=shaderDefineExpression.js.map","import { __extends } from \"tslib\";\r\nimport { ShaderDefineExpression } from \"../shaderDefineExpression\";\r\n/** @hidden */\r\nvar ShaderDefineIsDefinedOperator = /** @class */ (function (_super) {\r\n __extends(ShaderDefineIsDefinedOperator, _super);\r\n function ShaderDefineIsDefinedOperator(define, not) {\r\n if (not === void 0) { not = false; }\r\n var _this = _super.call(this) || this;\r\n _this.define = define;\r\n _this.not = not;\r\n return _this;\r\n }\r\n ShaderDefineIsDefinedOperator.prototype.isTrue = function (preprocessors) {\r\n var condition = preprocessors[this.define] !== undefined;\r\n if (this.not) {\r\n condition = !condition;\r\n }\r\n return condition;\r\n };\r\n return ShaderDefineIsDefinedOperator;\r\n}(ShaderDefineExpression));\r\nexport { ShaderDefineIsDefinedOperator };\r\n//# sourceMappingURL=shaderDefineIsDefinedOperator.js.map","import { __extends } from \"tslib\";\r\nimport { ShaderDefineExpression } from '../shaderDefineExpression';\r\n/** @hidden */\r\nvar ShaderDefineOrOperator = /** @class */ (function (_super) {\r\n __extends(ShaderDefineOrOperator, _super);\r\n function ShaderDefineOrOperator() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n ShaderDefineOrOperator.prototype.isTrue = function (preprocessors) {\r\n return this.leftOperand.isTrue(preprocessors) || this.rightOperand.isTrue(preprocessors);\r\n };\r\n return ShaderDefineOrOperator;\r\n}(ShaderDefineExpression));\r\nexport { ShaderDefineOrOperator };\r\n//# sourceMappingURL=shaderDefineOrOperator.js.map","import { __extends } from \"tslib\";\r\nimport { ShaderDefineExpression } from '../shaderDefineExpression';\r\n/** @hidden */\r\nvar ShaderDefineAndOperator = /** @class */ (function (_super) {\r\n __extends(ShaderDefineAndOperator, _super);\r\n function ShaderDefineAndOperator() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n ShaderDefineAndOperator.prototype.isTrue = function (preprocessors) {\r\n return this.leftOperand.isTrue(preprocessors) && this.rightOperand.isTrue(preprocessors);\r\n };\r\n return ShaderDefineAndOperator;\r\n}(ShaderDefineExpression));\r\nexport { ShaderDefineAndOperator };\r\n//# sourceMappingURL=shaderDefineAndOperator.js.map","import { __extends } from \"tslib\";\r\nimport { ShaderDefineExpression } from '../shaderDefineExpression';\r\n/** @hidden */\r\nvar ShaderDefineArithmeticOperator = /** @class */ (function (_super) {\r\n __extends(ShaderDefineArithmeticOperator, _super);\r\n function ShaderDefineArithmeticOperator(define, operand, testValue) {\r\n var _this = _super.call(this) || this;\r\n _this.define = define;\r\n _this.operand = operand;\r\n _this.testValue = testValue;\r\n return _this;\r\n }\r\n ShaderDefineArithmeticOperator.prototype.isTrue = function (preprocessors) {\r\n var value = preprocessors[this.define];\r\n if (value === undefined) {\r\n value = this.define;\r\n }\r\n var condition = false;\r\n var left = parseInt(value);\r\n var right = parseInt(this.testValue);\r\n switch (this.operand) {\r\n case \">\":\r\n condition = left > right;\r\n break;\r\n case \"<\":\r\n condition = left < right;\r\n break;\r\n case \"<=\":\r\n condition = left <= right;\r\n break;\r\n case \">=\":\r\n condition = left >= right;\r\n break;\r\n case \"==\":\r\n condition = left === right;\r\n break;\r\n }\r\n return condition;\r\n };\r\n return ShaderDefineArithmeticOperator;\r\n}(ShaderDefineExpression));\r\nexport { ShaderDefineArithmeticOperator };\r\n//# sourceMappingURL=shaderDefineArithmeticOperator.js.map","import { ShaderCodeNode } from './shaderCodeNode';\r\nimport { ShaderCodeCursor } from './shaderCodeCursor';\r\nimport { ShaderCodeConditionNode } from './shaderCodeConditionNode';\r\nimport { ShaderCodeTestNode } from './shaderCodeTestNode';\r\nimport { ShaderDefineIsDefinedOperator } from './Expressions/Operators/shaderDefineIsDefinedOperator';\r\nimport { ShaderDefineOrOperator } from './Expressions/Operators/shaderDefineOrOperator';\r\nimport { ShaderDefineAndOperator } from './Expressions/Operators/shaderDefineAndOperator';\r\nimport { ShaderDefineArithmeticOperator } from './Expressions/Operators/shaderDefineArithmeticOperator';\r\nimport { _DevTools } from '../../Misc/devTools';\r\n/** @hidden */\r\nvar ShaderProcessor = /** @class */ (function () {\r\n function ShaderProcessor() {\r\n }\r\n ShaderProcessor.Process = function (sourceCode, options, callback) {\r\n var _this = this;\r\n this._ProcessIncludes(sourceCode, options, function (codeWithIncludes) {\r\n var migratedCode = _this._ProcessShaderConversion(codeWithIncludes, options);\r\n callback(migratedCode);\r\n });\r\n };\r\n ShaderProcessor._ProcessPrecision = function (source, options) {\r\n var shouldUseHighPrecisionShader = options.shouldUseHighPrecisionShader;\r\n if (source.indexOf(\"precision highp float\") === -1) {\r\n if (!shouldUseHighPrecisionShader) {\r\n source = \"precision mediump float;\\n\" + source;\r\n }\r\n else {\r\n source = \"precision highp float;\\n\" + source;\r\n }\r\n }\r\n else {\r\n if (!shouldUseHighPrecisionShader) { // Moving highp to mediump\r\n source = source.replace(\"precision highp float\", \"precision mediump float\");\r\n }\r\n }\r\n return source;\r\n };\r\n ShaderProcessor._ExtractOperation = function (expression) {\r\n var regex = /defined\\((.+)\\)/;\r\n var match = regex.exec(expression);\r\n if (match && match.length) {\r\n return new ShaderDefineIsDefinedOperator(match[1].trim(), expression[0] === \"!\");\r\n }\r\n var operators = [\"==\", \">=\", \"<=\", \"<\", \">\"];\r\n var operator = \"\";\r\n var indexOperator = 0;\r\n for (var _i = 0, operators_1 = operators; _i < operators_1.length; _i++) {\r\n operator = operators_1[_i];\r\n indexOperator = expression.indexOf(operator);\r\n if (indexOperator > -1) {\r\n break;\r\n }\r\n }\r\n if (indexOperator === -1) {\r\n return new ShaderDefineIsDefinedOperator(expression);\r\n }\r\n var define = expression.substring(0, indexOperator).trim();\r\n var value = expression.substring(indexOperator + operator.length).trim();\r\n return new ShaderDefineArithmeticOperator(define, operator, value);\r\n };\r\n ShaderProcessor._BuildSubExpression = function (expression) {\r\n var indexOr = expression.indexOf(\"||\");\r\n if (indexOr === -1) {\r\n var indexAnd = expression.indexOf(\"&&\");\r\n if (indexAnd > -1) {\r\n var andOperator = new ShaderDefineAndOperator();\r\n var leftPart = expression.substring(0, indexAnd).trim();\r\n var rightPart = expression.substring(indexAnd + 2).trim();\r\n andOperator.leftOperand = this._BuildSubExpression(leftPart);\r\n andOperator.rightOperand = this._BuildSubExpression(rightPart);\r\n return andOperator;\r\n }\r\n else {\r\n return this._ExtractOperation(expression);\r\n }\r\n }\r\n else {\r\n var orOperator = new ShaderDefineOrOperator();\r\n var leftPart = expression.substring(0, indexOr).trim();\r\n var rightPart = expression.substring(indexOr + 2).trim();\r\n orOperator.leftOperand = this._BuildSubExpression(leftPart);\r\n orOperator.rightOperand = this._BuildSubExpression(rightPart);\r\n return orOperator;\r\n }\r\n };\r\n ShaderProcessor._BuildExpression = function (line, start) {\r\n var node = new ShaderCodeTestNode();\r\n var command = line.substring(0, start);\r\n var expression = line.substring(start).trim();\r\n if (command === \"#ifdef\") {\r\n node.testExpression = new ShaderDefineIsDefinedOperator(expression);\r\n }\r\n else if (command === \"#ifndef\") {\r\n node.testExpression = new ShaderDefineIsDefinedOperator(expression, true);\r\n }\r\n else {\r\n node.testExpression = this._BuildSubExpression(expression);\r\n }\r\n return node;\r\n };\r\n ShaderProcessor._MoveCursorWithinIf = function (cursor, rootNode, ifNode) {\r\n var line = cursor.currentLine;\r\n while (this._MoveCursor(cursor, ifNode)) {\r\n line = cursor.currentLine;\r\n var first5 = line.substring(0, 5).toLowerCase();\r\n if (first5 === \"#else\") {\r\n var elseNode = new ShaderCodeNode();\r\n rootNode.children.push(elseNode);\r\n this._MoveCursor(cursor, elseNode);\r\n return;\r\n }\r\n else if (first5 === \"#elif\") {\r\n var elifNode = this._BuildExpression(line, 5);\r\n rootNode.children.push(elifNode);\r\n ifNode = elifNode;\r\n }\r\n }\r\n };\r\n ShaderProcessor._MoveCursor = function (cursor, rootNode) {\r\n while (cursor.canRead) {\r\n cursor.lineIndex++;\r\n var line = cursor.currentLine;\r\n var keywords = /(#ifdef)|(#else)|(#elif)|(#endif)|(#ifndef)|(#if)/;\r\n var matches = keywords.exec(line);\r\n if (matches && matches.length) {\r\n var keyword = matches[0];\r\n switch (keyword) {\r\n case \"#ifdef\": {\r\n var newRootNode = new ShaderCodeConditionNode();\r\n rootNode.children.push(newRootNode);\r\n var ifNode = this._BuildExpression(line, 6);\r\n newRootNode.children.push(ifNode);\r\n this._MoveCursorWithinIf(cursor, newRootNode, ifNode);\r\n break;\r\n }\r\n case \"#else\":\r\n case \"#elif\":\r\n return true;\r\n case \"#endif\":\r\n return false;\r\n case \"#ifndef\": {\r\n var newRootNode = new ShaderCodeConditionNode();\r\n rootNode.children.push(newRootNode);\r\n var ifNode = this._BuildExpression(line, 7);\r\n newRootNode.children.push(ifNode);\r\n this._MoveCursorWithinIf(cursor, newRootNode, ifNode);\r\n break;\r\n }\r\n case \"#if\": {\r\n var newRootNode = new ShaderCodeConditionNode();\r\n var ifNode = this._BuildExpression(line, 3);\r\n rootNode.children.push(newRootNode);\r\n newRootNode.children.push(ifNode);\r\n this._MoveCursorWithinIf(cursor, newRootNode, ifNode);\r\n break;\r\n }\r\n }\r\n }\r\n else {\r\n var newNode = new ShaderCodeNode();\r\n newNode.line = line;\r\n rootNode.children.push(newNode);\r\n // Detect additional defines\r\n if (line[0] === \"#\" && line[1] === \"d\") {\r\n var split = line.replace(\";\", \"\").split(\" \");\r\n newNode.additionalDefineKey = split[1];\r\n if (split.length === 3) {\r\n newNode.additionalDefineValue = split[2];\r\n }\r\n }\r\n }\r\n }\r\n return false;\r\n };\r\n ShaderProcessor._EvaluatePreProcessors = function (sourceCode, preprocessors, options) {\r\n var rootNode = new ShaderCodeNode();\r\n var cursor = new ShaderCodeCursor();\r\n cursor.lineIndex = -1;\r\n cursor.lines = sourceCode.split(\"\\n\");\r\n // Decompose (We keep it in 2 steps so it is easier to maintain and perf hit is insignificant)\r\n this._MoveCursor(cursor, rootNode);\r\n // Recompose\r\n return rootNode.process(preprocessors, options);\r\n };\r\n ShaderProcessor._PreparePreProcessors = function (options) {\r\n var defines = options.defines;\r\n var preprocessors = {};\r\n for (var _i = 0, defines_1 = defines; _i < defines_1.length; _i++) {\r\n var define = defines_1[_i];\r\n var keyValue = define.replace(\"#define\", \"\").replace(\";\", \"\").trim();\r\n var split = keyValue.split(\" \");\r\n preprocessors[split[0]] = split.length > 1 ? split[1] : \"\";\r\n }\r\n preprocessors[\"GL_ES\"] = \"true\";\r\n preprocessors[\"__VERSION__\"] = options.version;\r\n preprocessors[options.platformName] = \"true\";\r\n return preprocessors;\r\n };\r\n ShaderProcessor._ProcessShaderConversion = function (sourceCode, options) {\r\n var preparedSourceCode = this._ProcessPrecision(sourceCode, options);\r\n if (!options.processor) {\r\n return preparedSourceCode;\r\n }\r\n // Already converted\r\n if (preparedSourceCode.indexOf(\"#version 3\") !== -1) {\r\n return preparedSourceCode.replace(\"#version 300 es\", \"\");\r\n }\r\n var defines = options.defines;\r\n var preprocessors = this._PreparePreProcessors(options);\r\n // General pre processing\r\n if (options.processor.preProcessor) {\r\n preparedSourceCode = options.processor.preProcessor(preparedSourceCode, defines, options.isFragment);\r\n }\r\n preparedSourceCode = this._EvaluatePreProcessors(preparedSourceCode, preprocessors, options);\r\n // Post processing\r\n if (options.processor.postProcessor) {\r\n preparedSourceCode = options.processor.postProcessor(preparedSourceCode, defines, options.isFragment);\r\n }\r\n return preparedSourceCode;\r\n };\r\n ShaderProcessor._ProcessIncludes = function (sourceCode, options, callback) {\r\n var _this = this;\r\n var regex = /#include<(.+)>(\\((.*)\\))*(\\[(.*)\\])*/g;\r\n var match = regex.exec(sourceCode);\r\n var returnValue = new String(sourceCode);\r\n while (match != null) {\r\n var includeFile = match[1];\r\n // Uniform declaration\r\n if (includeFile.indexOf(\"__decl__\") !== -1) {\r\n includeFile = includeFile.replace(/__decl__/, \"\");\r\n if (options.supportsUniformBuffers) {\r\n includeFile = includeFile.replace(/Vertex/, \"Ubo\");\r\n includeFile = includeFile.replace(/Fragment/, \"Ubo\");\r\n }\r\n includeFile = includeFile + \"Declaration\";\r\n }\r\n if (options.includesShadersStore[includeFile]) {\r\n // Substitution\r\n var includeContent = options.includesShadersStore[includeFile];\r\n if (match[2]) {\r\n var splits = match[3].split(\",\");\r\n for (var index = 0; index < splits.length; index += 2) {\r\n var source = new RegExp(splits[index], \"g\");\r\n var dest = splits[index + 1];\r\n includeContent = includeContent.replace(source, dest);\r\n }\r\n }\r\n if (match[4]) {\r\n var indexString = match[5];\r\n if (indexString.indexOf(\"..\") !== -1) {\r\n var indexSplits = indexString.split(\"..\");\r\n var minIndex = parseInt(indexSplits[0]);\r\n var maxIndex = parseInt(indexSplits[1]);\r\n var sourceIncludeContent = includeContent.slice(0);\r\n includeContent = \"\";\r\n if (isNaN(maxIndex)) {\r\n maxIndex = options.indexParameters[indexSplits[1]];\r\n }\r\n for (var i = minIndex; i < maxIndex; i++) {\r\n if (!options.supportsUniformBuffers) {\r\n // Ubo replacement\r\n sourceIncludeContent = sourceIncludeContent.replace(/light\\{X\\}.(\\w*)/g, function (str, p1) {\r\n return p1 + \"{X}\";\r\n });\r\n }\r\n includeContent += sourceIncludeContent.replace(/\\{X\\}/g, i.toString()) + \"\\n\";\r\n }\r\n }\r\n else {\r\n if (!options.supportsUniformBuffers) {\r\n // Ubo replacement\r\n includeContent = includeContent.replace(/light\\{X\\}.(\\w*)/g, function (str, p1) {\r\n return p1 + \"{X}\";\r\n });\r\n }\r\n includeContent = includeContent.replace(/\\{X\\}/g, indexString);\r\n }\r\n }\r\n // Replace\r\n returnValue = returnValue.replace(match[0], includeContent);\r\n }\r\n else {\r\n var includeShaderUrl = options.shadersRepository + \"ShadersInclude/\" + includeFile + \".fx\";\r\n ShaderProcessor._FileToolsLoadFile(includeShaderUrl, function (fileContent) {\r\n options.includesShadersStore[includeFile] = fileContent;\r\n _this._ProcessIncludes(returnValue, options, callback);\r\n });\r\n return;\r\n }\r\n match = regex.exec(sourceCode);\r\n }\r\n callback(returnValue);\r\n };\r\n /**\r\n * Loads a file from a url\r\n * @param url url to load\r\n * @param onSuccess callback called when the file successfully loads\r\n * @param onProgress callback called while file is loading (if the server supports this mode)\r\n * @param offlineProvider defines the offline provider for caching\r\n * @param useArrayBuffer defines a boolean indicating that date must be returned as ArrayBuffer\r\n * @param onError callback called when the file fails to load\r\n * @returns a file request object\r\n * @hidden\r\n */\r\n ShaderProcessor._FileToolsLoadFile = function (url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError) {\r\n throw _DevTools.WarnImport(\"FileTools\");\r\n };\r\n return ShaderProcessor;\r\n}());\r\nexport { ShaderProcessor };\r\n//# sourceMappingURL=shaderProcessor.js.map","import { Scalar } from './math.scalar';\r\nimport { Vector2, Vector3, Quaternion, Matrix } from './math.vector';\r\nimport { Epsilon } from './math.constants';\r\n/**\r\n * Defines potential orientation for back face culling\r\n */\r\nexport var Orientation;\r\n(function (Orientation) {\r\n /**\r\n * Clockwise\r\n */\r\n Orientation[Orientation[\"CW\"] = 0] = \"CW\";\r\n /** Counter clockwise */\r\n Orientation[Orientation[\"CCW\"] = 1] = \"CCW\";\r\n})(Orientation || (Orientation = {}));\r\n/** Class used to represent a Bezier curve */\r\nvar BezierCurve = /** @class */ (function () {\r\n function BezierCurve() {\r\n }\r\n /**\r\n * Returns the cubic Bezier interpolated value (float) at \"t\" (float) from the given x1, y1, x2, y2 floats\r\n * @param t defines the time\r\n * @param x1 defines the left coordinate on X axis\r\n * @param y1 defines the left coordinate on Y axis\r\n * @param x2 defines the right coordinate on X axis\r\n * @param y2 defines the right coordinate on Y axis\r\n * @returns the interpolated value\r\n */\r\n BezierCurve.Interpolate = function (t, x1, y1, x2, y2) {\r\n // Extract X (which is equal to time here)\r\n var f0 = 1 - 3 * x2 + 3 * x1;\r\n var f1 = 3 * x2 - 6 * x1;\r\n var f2 = 3 * x1;\r\n var refinedT = t;\r\n for (var i = 0; i < 5; i++) {\r\n var refinedT2 = refinedT * refinedT;\r\n var refinedT3 = refinedT2 * refinedT;\r\n var x = f0 * refinedT3 + f1 * refinedT2 + f2 * refinedT;\r\n var slope = 1.0 / (3.0 * f0 * refinedT2 + 2.0 * f1 * refinedT + f2);\r\n refinedT -= (x - t) * slope;\r\n refinedT = Math.min(1, Math.max(0, refinedT));\r\n }\r\n // Resolve cubic bezier for the given x\r\n return 3 * Math.pow(1 - refinedT, 2) * refinedT * y1 +\r\n 3 * (1 - refinedT) * Math.pow(refinedT, 2) * y2 +\r\n Math.pow(refinedT, 3);\r\n };\r\n return BezierCurve;\r\n}());\r\nexport { BezierCurve };\r\n/**\r\n * Defines angle representation\r\n */\r\nvar Angle = /** @class */ (function () {\r\n /**\r\n * Creates an Angle object of \"radians\" radians (float).\r\n * @param radians the angle in radians\r\n */\r\n function Angle(radians) {\r\n this._radians = radians;\r\n if (this._radians < 0.0) {\r\n this._radians += (2.0 * Math.PI);\r\n }\r\n }\r\n /**\r\n * Get value in degrees\r\n * @returns the Angle value in degrees (float)\r\n */\r\n Angle.prototype.degrees = function () {\r\n return this._radians * 180.0 / Math.PI;\r\n };\r\n /**\r\n * Get value in radians\r\n * @returns the Angle value in radians (float)\r\n */\r\n Angle.prototype.radians = function () {\r\n return this._radians;\r\n };\r\n /**\r\n * Gets a new Angle object valued with the angle value in radians between the two given vectors\r\n * @param a defines first vector\r\n * @param b defines second vector\r\n * @returns a new Angle\r\n */\r\n Angle.BetweenTwoPoints = function (a, b) {\r\n var delta = b.subtract(a);\r\n var theta = Math.atan2(delta.y, delta.x);\r\n return new Angle(theta);\r\n };\r\n /**\r\n * Gets a new Angle object from the given float in radians\r\n * @param radians defines the angle value in radians\r\n * @returns a new Angle\r\n */\r\n Angle.FromRadians = function (radians) {\r\n return new Angle(radians);\r\n };\r\n /**\r\n * Gets a new Angle object from the given float in degrees\r\n * @param degrees defines the angle value in degrees\r\n * @returns a new Angle\r\n */\r\n Angle.FromDegrees = function (degrees) {\r\n return new Angle(degrees * Math.PI / 180.0);\r\n };\r\n return Angle;\r\n}());\r\nexport { Angle };\r\n/**\r\n * This represents an arc in a 2d space.\r\n */\r\nvar Arc2 = /** @class */ (function () {\r\n /**\r\n * Creates an Arc object from the three given points : start, middle and end.\r\n * @param startPoint Defines the start point of the arc\r\n * @param midPoint Defines the midlle point of the arc\r\n * @param endPoint Defines the end point of the arc\r\n */\r\n function Arc2(\r\n /** Defines the start point of the arc */\r\n startPoint, \r\n /** Defines the mid point of the arc */\r\n midPoint, \r\n /** Defines the end point of the arc */\r\n endPoint) {\r\n this.startPoint = startPoint;\r\n this.midPoint = midPoint;\r\n this.endPoint = endPoint;\r\n var temp = Math.pow(midPoint.x, 2) + Math.pow(midPoint.y, 2);\r\n var startToMid = (Math.pow(startPoint.x, 2) + Math.pow(startPoint.y, 2) - temp) / 2.;\r\n var midToEnd = (temp - Math.pow(endPoint.x, 2) - Math.pow(endPoint.y, 2)) / 2.;\r\n var det = (startPoint.x - midPoint.x) * (midPoint.y - endPoint.y) - (midPoint.x - endPoint.x) * (startPoint.y - midPoint.y);\r\n this.centerPoint = new Vector2((startToMid * (midPoint.y - endPoint.y) - midToEnd * (startPoint.y - midPoint.y)) / det, ((startPoint.x - midPoint.x) * midToEnd - (midPoint.x - endPoint.x) * startToMid) / det);\r\n this.radius = this.centerPoint.subtract(this.startPoint).length();\r\n this.startAngle = Angle.BetweenTwoPoints(this.centerPoint, this.startPoint);\r\n var a1 = this.startAngle.degrees();\r\n var a2 = Angle.BetweenTwoPoints(this.centerPoint, this.midPoint).degrees();\r\n var a3 = Angle.BetweenTwoPoints(this.centerPoint, this.endPoint).degrees();\r\n // angles correction\r\n if (a2 - a1 > +180.0) {\r\n a2 -= 360.0;\r\n }\r\n if (a2 - a1 < -180.0) {\r\n a2 += 360.0;\r\n }\r\n if (a3 - a2 > +180.0) {\r\n a3 -= 360.0;\r\n }\r\n if (a3 - a2 < -180.0) {\r\n a3 += 360.0;\r\n }\r\n this.orientation = (a2 - a1) < 0 ? Orientation.CW : Orientation.CCW;\r\n this.angle = Angle.FromDegrees(this.orientation === Orientation.CW ? a1 - a3 : a3 - a1);\r\n }\r\n return Arc2;\r\n}());\r\nexport { Arc2 };\r\n/**\r\n * Represents a 2D path made up of multiple 2D points\r\n */\r\nvar Path2 = /** @class */ (function () {\r\n /**\r\n * Creates a Path2 object from the starting 2D coordinates x and y.\r\n * @param x the starting points x value\r\n * @param y the starting points y value\r\n */\r\n function Path2(x, y) {\r\n this._points = new Array();\r\n this._length = 0.0;\r\n /**\r\n * If the path start and end point are the same\r\n */\r\n this.closed = false;\r\n this._points.push(new Vector2(x, y));\r\n }\r\n /**\r\n * Adds a new segment until the given coordinates (x, y) to the current Path2.\r\n * @param x the added points x value\r\n * @param y the added points y value\r\n * @returns the updated Path2.\r\n */\r\n Path2.prototype.addLineTo = function (x, y) {\r\n if (this.closed) {\r\n return this;\r\n }\r\n var newPoint = new Vector2(x, y);\r\n var previousPoint = this._points[this._points.length - 1];\r\n this._points.push(newPoint);\r\n this._length += newPoint.subtract(previousPoint).length();\r\n return this;\r\n };\r\n /**\r\n * Adds _numberOfSegments_ segments according to the arc definition (middle point coordinates, end point coordinates, the arc start point being the current Path2 last point) to the current Path2.\r\n * @param midX middle point x value\r\n * @param midY middle point y value\r\n * @param endX end point x value\r\n * @param endY end point y value\r\n * @param numberOfSegments (default: 36)\r\n * @returns the updated Path2.\r\n */\r\n Path2.prototype.addArcTo = function (midX, midY, endX, endY, numberOfSegments) {\r\n if (numberOfSegments === void 0) { numberOfSegments = 36; }\r\n if (this.closed) {\r\n return this;\r\n }\r\n var startPoint = this._points[this._points.length - 1];\r\n var midPoint = new Vector2(midX, midY);\r\n var endPoint = new Vector2(endX, endY);\r\n var arc = new Arc2(startPoint, midPoint, endPoint);\r\n var increment = arc.angle.radians() / numberOfSegments;\r\n if (arc.orientation === Orientation.CW) {\r\n increment *= -1;\r\n }\r\n var currentAngle = arc.startAngle.radians() + increment;\r\n for (var i = 0; i < numberOfSegments; i++) {\r\n var x = Math.cos(currentAngle) * arc.radius + arc.centerPoint.x;\r\n var y = Math.sin(currentAngle) * arc.radius + arc.centerPoint.y;\r\n this.addLineTo(x, y);\r\n currentAngle += increment;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Closes the Path2.\r\n * @returns the Path2.\r\n */\r\n Path2.prototype.close = function () {\r\n this.closed = true;\r\n return this;\r\n };\r\n /**\r\n * Gets the sum of the distance between each sequential point in the path\r\n * @returns the Path2 total length (float).\r\n */\r\n Path2.prototype.length = function () {\r\n var result = this._length;\r\n if (this.closed) {\r\n var lastPoint = this._points[this._points.length - 1];\r\n var firstPoint = this._points[0];\r\n result += (firstPoint.subtract(lastPoint).length());\r\n }\r\n return result;\r\n };\r\n /**\r\n * Gets the points which construct the path\r\n * @returns the Path2 internal array of points.\r\n */\r\n Path2.prototype.getPoints = function () {\r\n return this._points;\r\n };\r\n /**\r\n * Retreives the point at the distance aways from the starting point\r\n * @param normalizedLengthPosition the length along the path to retreive the point from\r\n * @returns a new Vector2 located at a percentage of the Path2 total length on this path.\r\n */\r\n Path2.prototype.getPointAtLengthPosition = function (normalizedLengthPosition) {\r\n if (normalizedLengthPosition < 0 || normalizedLengthPosition > 1) {\r\n return Vector2.Zero();\r\n }\r\n var lengthPosition = normalizedLengthPosition * this.length();\r\n var previousOffset = 0;\r\n for (var i = 0; i < this._points.length; i++) {\r\n var j = (i + 1) % this._points.length;\r\n var a = this._points[i];\r\n var b = this._points[j];\r\n var bToA = b.subtract(a);\r\n var nextOffset = (bToA.length() + previousOffset);\r\n if (lengthPosition >= previousOffset && lengthPosition <= nextOffset) {\r\n var dir = bToA.normalize();\r\n var localOffset = lengthPosition - previousOffset;\r\n return new Vector2(a.x + (dir.x * localOffset), a.y + (dir.y * localOffset));\r\n }\r\n previousOffset = nextOffset;\r\n }\r\n return Vector2.Zero();\r\n };\r\n /**\r\n * Creates a new path starting from an x and y position\r\n * @param x starting x value\r\n * @param y starting y value\r\n * @returns a new Path2 starting at the coordinates (x, y).\r\n */\r\n Path2.StartingAt = function (x, y) {\r\n return new Path2(x, y);\r\n };\r\n return Path2;\r\n}());\r\nexport { Path2 };\r\n/**\r\n * Represents a 3D path made up of multiple 3D points\r\n */\r\nvar Path3D = /** @class */ (function () {\r\n /**\r\n * new Path3D(path, normal, raw)\r\n * Creates a Path3D. A Path3D is a logical math object, so not a mesh.\r\n * please read the description in the tutorial : https://doc.babylonjs.com/how_to/how_to_use_path3d\r\n * @param path an array of Vector3, the curve axis of the Path3D\r\n * @param firstNormal (options) Vector3, the first wanted normal to the curve. Ex (0, 1, 0) for a vertical normal.\r\n * @param raw (optional, default false) : boolean, if true the returned Path3D isn't normalized. Useful to depict path acceleration or speed.\r\n * @param alignTangentsWithPath (optional, default false) : boolean, if true the tangents will be aligned with the path.\r\n */\r\n function Path3D(\r\n /**\r\n * an array of Vector3, the curve axis of the Path3D\r\n */\r\n path, firstNormal, raw, alignTangentsWithPath) {\r\n if (firstNormal === void 0) { firstNormal = null; }\r\n if (alignTangentsWithPath === void 0) { alignTangentsWithPath = false; }\r\n this.path = path;\r\n this._curve = new Array();\r\n this._distances = new Array();\r\n this._tangents = new Array();\r\n this._normals = new Array();\r\n this._binormals = new Array();\r\n // holds interpolated point data\r\n this._pointAtData = {\r\n id: 0,\r\n point: Vector3.Zero(),\r\n previousPointArrayIndex: 0,\r\n position: 0,\r\n subPosition: 0,\r\n interpolateReady: false,\r\n interpolationMatrix: Matrix.Identity(),\r\n };\r\n for (var p = 0; p < path.length; p++) {\r\n this._curve[p] = path[p].clone(); // hard copy\r\n }\r\n this._raw = raw || false;\r\n this._alignTangentsWithPath = alignTangentsWithPath;\r\n this._compute(firstNormal, alignTangentsWithPath);\r\n }\r\n /**\r\n * Returns the Path3D array of successive Vector3 designing its curve.\r\n * @returns the Path3D array of successive Vector3 designing its curve.\r\n */\r\n Path3D.prototype.getCurve = function () {\r\n return this._curve;\r\n };\r\n /**\r\n * Returns the Path3D array of successive Vector3 designing its curve.\r\n * @returns the Path3D array of successive Vector3 designing its curve.\r\n */\r\n Path3D.prototype.getPoints = function () {\r\n return this._curve;\r\n };\r\n /**\r\n * @returns the computed length (float) of the path.\r\n */\r\n Path3D.prototype.length = function () {\r\n return this._distances[this._distances.length - 1];\r\n };\r\n /**\r\n * Returns an array populated with tangent vectors on each Path3D curve point.\r\n * @returns an array populated with tangent vectors on each Path3D curve point.\r\n */\r\n Path3D.prototype.getTangents = function () {\r\n return this._tangents;\r\n };\r\n /**\r\n * Returns an array populated with normal vectors on each Path3D curve point.\r\n * @returns an array populated with normal vectors on each Path3D curve point.\r\n */\r\n Path3D.prototype.getNormals = function () {\r\n return this._normals;\r\n };\r\n /**\r\n * Returns an array populated with binormal vectors on each Path3D curve point.\r\n * @returns an array populated with binormal vectors on each Path3D curve point.\r\n */\r\n Path3D.prototype.getBinormals = function () {\r\n return this._binormals;\r\n };\r\n /**\r\n * Returns an array populated with distances (float) of the i-th point from the first curve point.\r\n * @returns an array populated with distances (float) of the i-th point from the first curve point.\r\n */\r\n Path3D.prototype.getDistances = function () {\r\n return this._distances;\r\n };\r\n /**\r\n * Returns an interpolated point along this path\r\n * @param position the position of the point along this path, from 0.0 to 1.0\r\n * @returns a new Vector3 as the point\r\n */\r\n Path3D.prototype.getPointAt = function (position) {\r\n return this._updatePointAtData(position).point;\r\n };\r\n /**\r\n * Returns the tangent vector of an interpolated Path3D curve point at the specified position along this path.\r\n * @param position the position of the point along this path, from 0.0 to 1.0\r\n * @param interpolated (optional, default false) : boolean, if true returns an interpolated tangent instead of the tangent of the previous path point.\r\n * @returns a tangent vector corresponding to the interpolated Path3D curve point, if not interpolated, the tangent is taken from the precomputed tangents array.\r\n */\r\n Path3D.prototype.getTangentAt = function (position, interpolated) {\r\n if (interpolated === void 0) { interpolated = false; }\r\n this._updatePointAtData(position, interpolated);\r\n return interpolated ? Vector3.TransformCoordinates(Vector3.Forward(), this._pointAtData.interpolationMatrix) : this._tangents[this._pointAtData.previousPointArrayIndex];\r\n };\r\n /**\r\n * Returns the tangent vector of an interpolated Path3D curve point at the specified position along this path.\r\n * @param position the position of the point along this path, from 0.0 to 1.0\r\n * @param interpolated (optional, default false) : boolean, if true returns an interpolated normal instead of the normal of the previous path point.\r\n * @returns a normal vector corresponding to the interpolated Path3D curve point, if not interpolated, the normal is taken from the precomputed normals array.\r\n */\r\n Path3D.prototype.getNormalAt = function (position, interpolated) {\r\n if (interpolated === void 0) { interpolated = false; }\r\n this._updatePointAtData(position, interpolated);\r\n return interpolated ? Vector3.TransformCoordinates(Vector3.Right(), this._pointAtData.interpolationMatrix) : this._normals[this._pointAtData.previousPointArrayIndex];\r\n };\r\n /**\r\n * Returns the binormal vector of an interpolated Path3D curve point at the specified position along this path.\r\n * @param position the position of the point along this path, from 0.0 to 1.0\r\n * @param interpolated (optional, default false) : boolean, if true returns an interpolated binormal instead of the binormal of the previous path point.\r\n * @returns a binormal vector corresponding to the interpolated Path3D curve point, if not interpolated, the binormal is taken from the precomputed binormals array.\r\n */\r\n Path3D.prototype.getBinormalAt = function (position, interpolated) {\r\n if (interpolated === void 0) { interpolated = false; }\r\n this._updatePointAtData(position, interpolated);\r\n return interpolated ? Vector3.TransformCoordinates(Vector3.UpReadOnly, this._pointAtData.interpolationMatrix) : this._binormals[this._pointAtData.previousPointArrayIndex];\r\n };\r\n /**\r\n * Returns the distance (float) of an interpolated Path3D curve point at the specified position along this path.\r\n * @param position the position of the point along this path, from 0.0 to 1.0\r\n * @returns the distance of the interpolated Path3D curve point at the specified position along this path.\r\n */\r\n Path3D.prototype.getDistanceAt = function (position) {\r\n return this.length() * position;\r\n };\r\n /**\r\n * Returns the array index of the previous point of an interpolated point along this path\r\n * @param position the position of the point to interpolate along this path, from 0.0 to 1.0\r\n * @returns the array index\r\n */\r\n Path3D.prototype.getPreviousPointIndexAt = function (position) {\r\n this._updatePointAtData(position);\r\n return this._pointAtData.previousPointArrayIndex;\r\n };\r\n /**\r\n * Returns the position of an interpolated point relative to the two path points it lies between, from 0.0 (point A) to 1.0 (point B)\r\n * @param position the position of the point to interpolate along this path, from 0.0 to 1.0\r\n * @returns the sub position\r\n */\r\n Path3D.prototype.getSubPositionAt = function (position) {\r\n this._updatePointAtData(position);\r\n return this._pointAtData.subPosition;\r\n };\r\n /**\r\n * Returns the position of the closest virtual point on this path to an arbitrary Vector3, from 0.0 to 1.0\r\n * @param target the vector of which to get the closest position to\r\n * @returns the position of the closest virtual point on this path to the target vector\r\n */\r\n Path3D.prototype.getClosestPositionTo = function (target) {\r\n var smallestDistance = Number.MAX_VALUE;\r\n var closestPosition = 0.0;\r\n for (var i = 0; i < this._curve.length - 1; i++) {\r\n var point = this._curve[i + 0];\r\n var tangent = this._curve[i + 1].subtract(point).normalize();\r\n var subLength = this._distances[i + 1] - this._distances[i + 0];\r\n var subPosition = Math.min(Math.max(Vector3.Dot(tangent, target.subtract(point).normalize()), 0.0) * Vector3.Distance(point, target) / subLength, 1.0);\r\n var distance = Vector3.Distance(point.add(tangent.scale(subPosition * subLength)), target);\r\n if (distance < smallestDistance) {\r\n smallestDistance = distance;\r\n closestPosition = (this._distances[i + 0] + subLength * subPosition) / this.length();\r\n }\r\n }\r\n return closestPosition;\r\n };\r\n /**\r\n * Returns a sub path (slice) of this path\r\n * @param start the position of the fist path point, from 0.0 to 1.0, or a negative value, which will get wrapped around from the end of the path to 0.0 to 1.0 values\r\n * @param end the position of the last path point, from 0.0 to 1.0, or a negative value, which will get wrapped around from the end of the path to 0.0 to 1.0 values\r\n * @returns a sub path (slice) of this path\r\n */\r\n Path3D.prototype.slice = function (start, end) {\r\n if (start === void 0) { start = 0.0; }\r\n if (end === void 0) { end = 1.0; }\r\n if (start < 0.0) {\r\n start = 1 - (start * -1.0) % 1.0;\r\n }\r\n if (end < 0.0) {\r\n end = 1 - (end * -1.0) % 1.0;\r\n }\r\n if (start > end) {\r\n var _start = start;\r\n start = end;\r\n end = _start;\r\n }\r\n var curvePoints = this.getCurve();\r\n var startPoint = this.getPointAt(start);\r\n var startIndex = this.getPreviousPointIndexAt(start);\r\n var endPoint = this.getPointAt(end);\r\n var endIndex = this.getPreviousPointIndexAt(end) + 1;\r\n var slicePoints = [];\r\n if (start !== 0.0) {\r\n startIndex++;\r\n slicePoints.push(startPoint);\r\n }\r\n slicePoints.push.apply(slicePoints, curvePoints.slice(startIndex, endIndex));\r\n if (end !== 1.0 || start === 1.0) {\r\n slicePoints.push(endPoint);\r\n }\r\n return new Path3D(slicePoints, this.getNormalAt(start), this._raw, this._alignTangentsWithPath);\r\n };\r\n /**\r\n * Forces the Path3D tangent, normal, binormal and distance recomputation.\r\n * @param path path which all values are copied into the curves points\r\n * @param firstNormal which should be projected onto the curve\r\n * @param alignTangentsWithPath (optional, default false) : boolean, if true the tangents will be aligned with the path\r\n * @returns the same object updated.\r\n */\r\n Path3D.prototype.update = function (path, firstNormal, alignTangentsWithPath) {\r\n if (firstNormal === void 0) { firstNormal = null; }\r\n if (alignTangentsWithPath === void 0) { alignTangentsWithPath = false; }\r\n for (var p = 0; p < path.length; p++) {\r\n this._curve[p].x = path[p].x;\r\n this._curve[p].y = path[p].y;\r\n this._curve[p].z = path[p].z;\r\n }\r\n this._compute(firstNormal, alignTangentsWithPath);\r\n return this;\r\n };\r\n // private function compute() : computes tangents, normals and binormals\r\n Path3D.prototype._compute = function (firstNormal, alignTangentsWithPath) {\r\n if (alignTangentsWithPath === void 0) { alignTangentsWithPath = false; }\r\n var l = this._curve.length;\r\n // first and last tangents\r\n this._tangents[0] = this._getFirstNonNullVector(0);\r\n if (!this._raw) {\r\n this._tangents[0].normalize();\r\n }\r\n this._tangents[l - 1] = this._curve[l - 1].subtract(this._curve[l - 2]);\r\n if (!this._raw) {\r\n this._tangents[l - 1].normalize();\r\n }\r\n // normals and binormals at first point : arbitrary vector with _normalVector()\r\n var tg0 = this._tangents[0];\r\n var pp0 = this._normalVector(tg0, firstNormal);\r\n this._normals[0] = pp0;\r\n if (!this._raw) {\r\n this._normals[0].normalize();\r\n }\r\n this._binormals[0] = Vector3.Cross(tg0, this._normals[0]);\r\n if (!this._raw) {\r\n this._binormals[0].normalize();\r\n }\r\n this._distances[0] = 0.0;\r\n // normals and binormals : next points\r\n var prev; // previous vector (segment)\r\n var cur; // current vector (segment)\r\n var curTang; // current tangent\r\n // previous normal\r\n var prevNor; // previous normal\r\n var prevBinor; // previous binormal\r\n for (var i = 1; i < l; i++) {\r\n // tangents\r\n prev = this._getLastNonNullVector(i);\r\n if (i < l - 1) {\r\n cur = this._getFirstNonNullVector(i);\r\n this._tangents[i] = alignTangentsWithPath ? cur : prev.add(cur);\r\n this._tangents[i].normalize();\r\n }\r\n this._distances[i] = this._distances[i - 1] + prev.length();\r\n // normals and binormals\r\n // http://www.cs.cmu.edu/afs/andrew/scs/cs/15-462/web/old/asst2camera.html\r\n curTang = this._tangents[i];\r\n prevBinor = this._binormals[i - 1];\r\n this._normals[i] = Vector3.Cross(prevBinor, curTang);\r\n if (!this._raw) {\r\n if (this._normals[i].length() === 0) {\r\n prevNor = this._normals[i - 1];\r\n this._normals[i] = prevNor.clone();\r\n }\r\n else {\r\n this._normals[i].normalize();\r\n }\r\n }\r\n this._binormals[i] = Vector3.Cross(curTang, this._normals[i]);\r\n if (!this._raw) {\r\n this._binormals[i].normalize();\r\n }\r\n }\r\n this._pointAtData.id = NaN;\r\n };\r\n // private function getFirstNonNullVector(index)\r\n // returns the first non null vector from index : curve[index + N].subtract(curve[index])\r\n Path3D.prototype._getFirstNonNullVector = function (index) {\r\n var i = 1;\r\n var nNVector = this._curve[index + i].subtract(this._curve[index]);\r\n while (nNVector.length() === 0 && index + i + 1 < this._curve.length) {\r\n i++;\r\n nNVector = this._curve[index + i].subtract(this._curve[index]);\r\n }\r\n return nNVector;\r\n };\r\n // private function getLastNonNullVector(index)\r\n // returns the last non null vector from index : curve[index].subtract(curve[index - N])\r\n Path3D.prototype._getLastNonNullVector = function (index) {\r\n var i = 1;\r\n var nLVector = this._curve[index].subtract(this._curve[index - i]);\r\n while (nLVector.length() === 0 && index > i + 1) {\r\n i++;\r\n nLVector = this._curve[index].subtract(this._curve[index - i]);\r\n }\r\n return nLVector;\r\n };\r\n // private function normalVector(v0, vt, va) :\r\n // returns an arbitrary point in the plane defined by the point v0 and the vector vt orthogonal to this plane\r\n // if va is passed, it returns the va projection on the plane orthogonal to vt at the point v0\r\n Path3D.prototype._normalVector = function (vt, va) {\r\n var normal0;\r\n var tgl = vt.length();\r\n if (tgl === 0.0) {\r\n tgl = 1.0;\r\n }\r\n if (va === undefined || va === null) {\r\n var point;\r\n if (!Scalar.WithinEpsilon(Math.abs(vt.y) / tgl, 1.0, Epsilon)) { // search for a point in the plane\r\n point = new Vector3(0.0, -1.0, 0.0);\r\n }\r\n else if (!Scalar.WithinEpsilon(Math.abs(vt.x) / tgl, 1.0, Epsilon)) {\r\n point = new Vector3(1.0, 0.0, 0.0);\r\n }\r\n else if (!Scalar.WithinEpsilon(Math.abs(vt.z) / tgl, 1.0, Epsilon)) {\r\n point = new Vector3(0.0, 0.0, 1.0);\r\n }\r\n else {\r\n point = Vector3.Zero();\r\n }\r\n normal0 = Vector3.Cross(vt, point);\r\n }\r\n else {\r\n normal0 = Vector3.Cross(vt, va);\r\n Vector3.CrossToRef(normal0, vt, normal0);\r\n }\r\n normal0.normalize();\r\n return normal0;\r\n };\r\n /**\r\n * Updates the point at data for an interpolated point along this curve\r\n * @param position the position of the point along this curve, from 0.0 to 1.0\r\n * @interpolateTNB wether to compute the interpolated tangent, normal and binormal\r\n * @returns the (updated) point at data\r\n */\r\n Path3D.prototype._updatePointAtData = function (position, interpolateTNB) {\r\n if (interpolateTNB === void 0) { interpolateTNB = false; }\r\n // set an id for caching the result\r\n if (this._pointAtData.id === position) {\r\n if (!this._pointAtData.interpolateReady) {\r\n this._updateInterpolationMatrix();\r\n }\r\n return this._pointAtData;\r\n }\r\n else {\r\n this._pointAtData.id = position;\r\n }\r\n var curvePoints = this.getPoints();\r\n // clamp position between 0.0 and 1.0\r\n if (position <= 0.0) {\r\n return this._setPointAtData(0.0, 0.0, curvePoints[0], 0, interpolateTNB);\r\n }\r\n else if (position >= 1.0) {\r\n return this._setPointAtData(1.0, 1.0, curvePoints[curvePoints.length - 1], curvePoints.length - 1, interpolateTNB);\r\n }\r\n var previousPoint = curvePoints[0];\r\n var currentPoint;\r\n var currentLength = 0.0;\r\n var targetLength = position * this.length();\r\n for (var i = 1; i < curvePoints.length; i++) {\r\n currentPoint = curvePoints[i];\r\n var distance = Vector3.Distance(previousPoint, currentPoint);\r\n currentLength += distance;\r\n if (currentLength === targetLength) {\r\n return this._setPointAtData(position, 1.0, currentPoint, i, interpolateTNB);\r\n }\r\n else if (currentLength > targetLength) {\r\n var toLength = currentLength - targetLength;\r\n var diff = toLength / distance;\r\n var dir = previousPoint.subtract(currentPoint);\r\n var point = currentPoint.add(dir.scaleInPlace(diff));\r\n return this._setPointAtData(position, 1 - diff, point, i - 1, interpolateTNB);\r\n }\r\n previousPoint = currentPoint;\r\n }\r\n return this._pointAtData;\r\n };\r\n /**\r\n * Updates the point at data from the specified parameters\r\n * @param position where along the path the interpolated point is, from 0.0 to 1.0\r\n * @param point the interpolated point\r\n * @param parentIndex the index of an existing curve point that is on, or else positionally the first behind, the interpolated point\r\n */\r\n Path3D.prototype._setPointAtData = function (position, subPosition, point, parentIndex, interpolateTNB) {\r\n this._pointAtData.point = point;\r\n this._pointAtData.position = position;\r\n this._pointAtData.subPosition = subPosition;\r\n this._pointAtData.previousPointArrayIndex = parentIndex;\r\n this._pointAtData.interpolateReady = interpolateTNB;\r\n if (interpolateTNB) {\r\n this._updateInterpolationMatrix();\r\n }\r\n return this._pointAtData;\r\n };\r\n /**\r\n * Updates the point at interpolation matrix for the tangents, normals and binormals\r\n */\r\n Path3D.prototype._updateInterpolationMatrix = function () {\r\n this._pointAtData.interpolationMatrix = Matrix.Identity();\r\n var parentIndex = this._pointAtData.previousPointArrayIndex;\r\n if (parentIndex !== this._tangents.length - 1) {\r\n var index = parentIndex + 1;\r\n var tangentFrom = this._tangents[parentIndex].clone();\r\n var normalFrom = this._normals[parentIndex].clone();\r\n var binormalFrom = this._binormals[parentIndex].clone();\r\n var tangentTo = this._tangents[index].clone();\r\n var normalTo = this._normals[index].clone();\r\n var binormalTo = this._binormals[index].clone();\r\n var quatFrom = Quaternion.RotationQuaternionFromAxis(normalFrom, binormalFrom, tangentFrom);\r\n var quatTo = Quaternion.RotationQuaternionFromAxis(normalTo, binormalTo, tangentTo);\r\n var quatAt = Quaternion.Slerp(quatFrom, quatTo, this._pointAtData.subPosition);\r\n quatAt.toRotationMatrix(this._pointAtData.interpolationMatrix);\r\n }\r\n };\r\n return Path3D;\r\n}());\r\nexport { Path3D };\r\n/**\r\n * A Curve3 object is a logical object, so not a mesh, to handle curves in the 3D geometric space.\r\n * A Curve3 is designed from a series of successive Vector3.\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_curve3\r\n */\r\nvar Curve3 = /** @class */ (function () {\r\n /**\r\n * A Curve3 object is a logical object, so not a mesh, to handle curves in the 3D geometric space.\r\n * A Curve3 is designed from a series of successive Vector3.\r\n * Tuto : https://doc.babylonjs.com/how_to/how_to_use_curve3#curve3-object\r\n * @param points points which make up the curve\r\n */\r\n function Curve3(points) {\r\n this._length = 0.0;\r\n this._points = points;\r\n this._length = this._computeLength(points);\r\n }\r\n /**\r\n * Returns a Curve3 object along a Quadratic Bezier curve : https://doc.babylonjs.com/how_to/how_to_use_curve3#quadratic-bezier-curve\r\n * @param v0 (Vector3) the origin point of the Quadratic Bezier\r\n * @param v1 (Vector3) the control point\r\n * @param v2 (Vector3) the end point of the Quadratic Bezier\r\n * @param nbPoints (integer) the wanted number of points in the curve\r\n * @returns the created Curve3\r\n */\r\n Curve3.CreateQuadraticBezier = function (v0, v1, v2, nbPoints) {\r\n nbPoints = nbPoints > 2 ? nbPoints : 3;\r\n var bez = new Array();\r\n var equation = function (t, val0, val1, val2) {\r\n var res = (1.0 - t) * (1.0 - t) * val0 + 2.0 * t * (1.0 - t) * val1 + t * t * val2;\r\n return res;\r\n };\r\n for (var i = 0; i <= nbPoints; i++) {\r\n bez.push(new Vector3(equation(i / nbPoints, v0.x, v1.x, v2.x), equation(i / nbPoints, v0.y, v1.y, v2.y), equation(i / nbPoints, v0.z, v1.z, v2.z)));\r\n }\r\n return new Curve3(bez);\r\n };\r\n /**\r\n * Returns a Curve3 object along a Cubic Bezier curve : https://doc.babylonjs.com/how_to/how_to_use_curve3#cubic-bezier-curve\r\n * @param v0 (Vector3) the origin point of the Cubic Bezier\r\n * @param v1 (Vector3) the first control point\r\n * @param v2 (Vector3) the second control point\r\n * @param v3 (Vector3) the end point of the Cubic Bezier\r\n * @param nbPoints (integer) the wanted number of points in the curve\r\n * @returns the created Curve3\r\n */\r\n Curve3.CreateCubicBezier = function (v0, v1, v2, v3, nbPoints) {\r\n nbPoints = nbPoints > 3 ? nbPoints : 4;\r\n var bez = new Array();\r\n var equation = function (t, val0, val1, val2, val3) {\r\n var res = (1.0 - t) * (1.0 - t) * (1.0 - t) * val0 + 3.0 * t * (1.0 - t) * (1.0 - t) * val1 + 3.0 * t * t * (1.0 - t) * val2 + t * t * t * val3;\r\n return res;\r\n };\r\n for (var i = 0; i <= nbPoints; i++) {\r\n bez.push(new Vector3(equation(i / nbPoints, v0.x, v1.x, v2.x, v3.x), equation(i / nbPoints, v0.y, v1.y, v2.y, v3.y), equation(i / nbPoints, v0.z, v1.z, v2.z, v3.z)));\r\n }\r\n return new Curve3(bez);\r\n };\r\n /**\r\n * Returns a Curve3 object along a Hermite Spline curve : https://doc.babylonjs.com/how_to/how_to_use_curve3#hermite-spline\r\n * @param p1 (Vector3) the origin point of the Hermite Spline\r\n * @param t1 (Vector3) the tangent vector at the origin point\r\n * @param p2 (Vector3) the end point of the Hermite Spline\r\n * @param t2 (Vector3) the tangent vector at the end point\r\n * @param nbPoints (integer) the wanted number of points in the curve\r\n * @returns the created Curve3\r\n */\r\n Curve3.CreateHermiteSpline = function (p1, t1, p2, t2, nbPoints) {\r\n var hermite = new Array();\r\n var step = 1.0 / nbPoints;\r\n for (var i = 0; i <= nbPoints; i++) {\r\n hermite.push(Vector3.Hermite(p1, t1, p2, t2, i * step));\r\n }\r\n return new Curve3(hermite);\r\n };\r\n /**\r\n * Returns a Curve3 object along a CatmullRom Spline curve :\r\n * @param points (array of Vector3) the points the spline must pass through. At least, four points required\r\n * @param nbPoints (integer) the wanted number of points between each curve control points\r\n * @param closed (boolean) optional with default false, when true forms a closed loop from the points\r\n * @returns the created Curve3\r\n */\r\n Curve3.CreateCatmullRomSpline = function (points, nbPoints, closed) {\r\n var catmullRom = new Array();\r\n var step = 1.0 / nbPoints;\r\n var amount = 0.0;\r\n if (closed) {\r\n var pointsCount = points.length;\r\n for (var i = 0; i < pointsCount; i++) {\r\n amount = 0;\r\n for (var c = 0; c < nbPoints; c++) {\r\n catmullRom.push(Vector3.CatmullRom(points[i % pointsCount], points[(i + 1) % pointsCount], points[(i + 2) % pointsCount], points[(i + 3) % pointsCount], amount));\r\n amount += step;\r\n }\r\n }\r\n catmullRom.push(catmullRom[0]);\r\n }\r\n else {\r\n var totalPoints = new Array();\r\n totalPoints.push(points[0].clone());\r\n Array.prototype.push.apply(totalPoints, points);\r\n totalPoints.push(points[points.length - 1].clone());\r\n for (var i = 0; i < totalPoints.length - 3; i++) {\r\n amount = 0;\r\n for (var c = 0; c < nbPoints; c++) {\r\n catmullRom.push(Vector3.CatmullRom(totalPoints[i], totalPoints[i + 1], totalPoints[i + 2], totalPoints[i + 3], amount));\r\n amount += step;\r\n }\r\n }\r\n i--;\r\n catmullRom.push(Vector3.CatmullRom(totalPoints[i], totalPoints[i + 1], totalPoints[i + 2], totalPoints[i + 3], amount));\r\n }\r\n return new Curve3(catmullRom);\r\n };\r\n /**\r\n * @returns the Curve3 stored array of successive Vector3\r\n */\r\n Curve3.prototype.getPoints = function () {\r\n return this._points;\r\n };\r\n /**\r\n * @returns the computed length (float) of the curve.\r\n */\r\n Curve3.prototype.length = function () {\r\n return this._length;\r\n };\r\n /**\r\n * Returns a new instance of Curve3 object : var curve = curveA.continue(curveB);\r\n * This new Curve3 is built by translating and sticking the curveB at the end of the curveA.\r\n * curveA and curveB keep unchanged.\r\n * @param curve the curve to continue from this curve\r\n * @returns the newly constructed curve\r\n */\r\n Curve3.prototype.continue = function (curve) {\r\n var lastPoint = this._points[this._points.length - 1];\r\n var continuedPoints = this._points.slice();\r\n var curvePoints = curve.getPoints();\r\n for (var i = 1; i < curvePoints.length; i++) {\r\n continuedPoints.push(curvePoints[i].subtract(curvePoints[0]).add(lastPoint));\r\n }\r\n var continuedCurve = new Curve3(continuedPoints);\r\n return continuedCurve;\r\n };\r\n Curve3.prototype._computeLength = function (path) {\r\n var l = 0;\r\n for (var i = 1; i < path.length; i++) {\r\n l += (path[i].subtract(path[i - 1])).length();\r\n }\r\n return l;\r\n };\r\n return Curve3;\r\n}());\r\nexport { Curve3 };\r\n//# sourceMappingURL=math.path.js.map","/**\r\n * Define options used to create a render target texture\r\n */\r\nvar RenderTargetCreationOptions = /** @class */ (function () {\r\n function RenderTargetCreationOptions() {\r\n }\r\n return RenderTargetCreationOptions;\r\n}());\r\nexport { RenderTargetCreationOptions };\r\n//# sourceMappingURL=renderTargetCreationOptions.js.map","/**\r\n * Class used to manipulate GUIDs\r\n */\r\nvar GUID = /** @class */ (function () {\r\n function GUID() {\r\n }\r\n /**\r\n * Implementation from http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/2117523#answer-2117523\r\n * Be aware Math.random() could cause collisions, but:\r\n * \"All but 6 of the 128 bits of the ID are randomly generated, which means that for any two ids, there's a 1 in 2^^122 (or 5.3x10^^36) chance they'll collide\"\r\n * @returns a pseudo random id\r\n */\r\n GUID.RandomId = function () {\r\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {\r\n var r = Math.random() * 16 | 0, v = c === 'x' ? r : (r & 0x3 | 0x8);\r\n return v.toString(16);\r\n });\r\n };\r\n return GUID;\r\n}());\r\nexport { GUID };\r\n//# sourceMappingURL=guid.js.map","/**\r\n * Manages the defines for the Material\r\n */\r\nvar MaterialDefines = /** @class */ (function () {\r\n function MaterialDefines() {\r\n this._isDirty = true;\r\n /** @hidden */\r\n this._areLightsDirty = true;\r\n /** @hidden */\r\n this._areLightsDisposed = false;\r\n /** @hidden */\r\n this._areAttributesDirty = true;\r\n /** @hidden */\r\n this._areTexturesDirty = true;\r\n /** @hidden */\r\n this._areFresnelDirty = true;\r\n /** @hidden */\r\n this._areMiscDirty = true;\r\n /** @hidden */\r\n this._areImageProcessingDirty = true;\r\n /** @hidden */\r\n this._normals = false;\r\n /** @hidden */\r\n this._uvs = false;\r\n /** @hidden */\r\n this._needNormals = false;\r\n /** @hidden */\r\n this._needUVs = false;\r\n }\r\n Object.defineProperty(MaterialDefines.prototype, \"isDirty\", {\r\n /**\r\n * Specifies if the material needs to be re-calculated\r\n */\r\n get: function () {\r\n return this._isDirty;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Marks the material to indicate that it has been re-calculated\r\n */\r\n MaterialDefines.prototype.markAsProcessed = function () {\r\n this._isDirty = false;\r\n this._areAttributesDirty = false;\r\n this._areTexturesDirty = false;\r\n this._areFresnelDirty = false;\r\n this._areLightsDirty = false;\r\n this._areLightsDisposed = false;\r\n this._areMiscDirty = false;\r\n this._areImageProcessingDirty = false;\r\n };\r\n /**\r\n * Marks the material to indicate that it needs to be re-calculated\r\n */\r\n MaterialDefines.prototype.markAsUnprocessed = function () {\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Marks the material to indicate all of its defines need to be re-calculated\r\n */\r\n MaterialDefines.prototype.markAllAsDirty = function () {\r\n this._areTexturesDirty = true;\r\n this._areAttributesDirty = true;\r\n this._areLightsDirty = true;\r\n this._areFresnelDirty = true;\r\n this._areMiscDirty = true;\r\n this._areImageProcessingDirty = true;\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Marks the material to indicate that image processing needs to be re-calculated\r\n */\r\n MaterialDefines.prototype.markAsImageProcessingDirty = function () {\r\n this._areImageProcessingDirty = true;\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Marks the material to indicate the lights need to be re-calculated\r\n * @param disposed Defines whether the light is dirty due to dispose or not\r\n */\r\n MaterialDefines.prototype.markAsLightDirty = function (disposed) {\r\n if (disposed === void 0) { disposed = false; }\r\n this._areLightsDirty = true;\r\n this._areLightsDisposed = this._areLightsDisposed || disposed;\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Marks the attribute state as changed\r\n */\r\n MaterialDefines.prototype.markAsAttributesDirty = function () {\r\n this._areAttributesDirty = true;\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Marks the texture state as changed\r\n */\r\n MaterialDefines.prototype.markAsTexturesDirty = function () {\r\n this._areTexturesDirty = true;\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Marks the fresnel state as changed\r\n */\r\n MaterialDefines.prototype.markAsFresnelDirty = function () {\r\n this._areFresnelDirty = true;\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Marks the misc state as changed\r\n */\r\n MaterialDefines.prototype.markAsMiscDirty = function () {\r\n this._areMiscDirty = true;\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Rebuilds the material defines\r\n */\r\n MaterialDefines.prototype.rebuild = function () {\r\n if (this._keys) {\r\n delete this._keys;\r\n }\r\n this._keys = [];\r\n for (var _i = 0, _a = Object.keys(this); _i < _a.length; _i++) {\r\n var key = _a[_i];\r\n if (key[0] === \"_\") {\r\n continue;\r\n }\r\n this._keys.push(key);\r\n }\r\n };\r\n /**\r\n * Specifies if two material defines are equal\r\n * @param other - A material define instance to compare to\r\n * @returns - Boolean indicating if the material defines are equal (true) or not (false)\r\n */\r\n MaterialDefines.prototype.isEqual = function (other) {\r\n if (this._keys.length !== other._keys.length) {\r\n return false;\r\n }\r\n for (var index = 0; index < this._keys.length; index++) {\r\n var prop = this._keys[index];\r\n if (this[prop] !== other[prop]) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Clones this instance's defines to another instance\r\n * @param other - material defines to clone values to\r\n */\r\n MaterialDefines.prototype.cloneTo = function (other) {\r\n if (this._keys.length !== other._keys.length) {\r\n other._keys = this._keys.slice(0);\r\n }\r\n for (var index = 0; index < this._keys.length; index++) {\r\n var prop = this._keys[index];\r\n other[prop] = this[prop];\r\n }\r\n };\r\n /**\r\n * Resets the material define values\r\n */\r\n MaterialDefines.prototype.reset = function () {\r\n for (var index = 0; index < this._keys.length; index++) {\r\n var prop = this._keys[index];\r\n var type = typeof this[prop];\r\n switch (type) {\r\n case \"number\":\r\n this[prop] = 0;\r\n break;\r\n case \"string\":\r\n this[prop] = \"\";\r\n break;\r\n default:\r\n this[prop] = false;\r\n break;\r\n }\r\n }\r\n };\r\n /**\r\n * Converts the material define values to a string\r\n * @returns - String of material define information\r\n */\r\n MaterialDefines.prototype.toString = function () {\r\n var result = \"\";\r\n for (var index = 0; index < this._keys.length; index++) {\r\n var prop = this._keys[index];\r\n var value = this[prop];\r\n var type = typeof value;\r\n switch (type) {\r\n case \"number\":\r\n case \"string\":\r\n result += \"#define \" + prop + \" \" + value + \"\\n\";\r\n break;\r\n default:\r\n if (value) {\r\n result += \"#define \" + prop + \"\\n\";\r\n }\r\n break;\r\n }\r\n }\r\n return result;\r\n };\r\n return MaterialDefines;\r\n}());\r\nexport { MaterialDefines };\r\n//# sourceMappingURL=materialDefines.js.map","/**\r\n * EffectFallbacks can be used to add fallbacks (properties to disable) to certain properties when desired to improve performance.\r\n * (Eg. Start at high quality with reflection and fog, if fps is low, remove reflection, if still low remove fog)\r\n */\r\nvar EffectFallbacks = /** @class */ (function () {\r\n function EffectFallbacks() {\r\n this._defines = {};\r\n this._currentRank = 32;\r\n this._maxRank = -1;\r\n this._mesh = null;\r\n }\r\n /**\r\n * Removes the fallback from the bound mesh.\r\n */\r\n EffectFallbacks.prototype.unBindMesh = function () {\r\n this._mesh = null;\r\n };\r\n /**\r\n * Adds a fallback on the specified property.\r\n * @param rank The rank of the fallback (Lower ranks will be fallbacked to first)\r\n * @param define The name of the define in the shader\r\n */\r\n EffectFallbacks.prototype.addFallback = function (rank, define) {\r\n if (!this._defines[rank]) {\r\n if (rank < this._currentRank) {\r\n this._currentRank = rank;\r\n }\r\n if (rank > this._maxRank) {\r\n this._maxRank = rank;\r\n }\r\n this._defines[rank] = new Array();\r\n }\r\n this._defines[rank].push(define);\r\n };\r\n /**\r\n * Sets the mesh to use CPU skinning when needing to fallback.\r\n * @param rank The rank of the fallback (Lower ranks will be fallbacked to first)\r\n * @param mesh The mesh to use the fallbacks.\r\n */\r\n EffectFallbacks.prototype.addCPUSkinningFallback = function (rank, mesh) {\r\n this._mesh = mesh;\r\n if (rank < this._currentRank) {\r\n this._currentRank = rank;\r\n }\r\n if (rank > this._maxRank) {\r\n this._maxRank = rank;\r\n }\r\n };\r\n Object.defineProperty(EffectFallbacks.prototype, \"hasMoreFallbacks\", {\r\n /**\r\n * Checks to see if more fallbacks are still availible.\r\n */\r\n get: function () {\r\n return this._currentRank <= this._maxRank;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Removes the defines that should be removed when falling back.\r\n * @param currentDefines defines the current define statements for the shader.\r\n * @param effect defines the current effect we try to compile\r\n * @returns The resulting defines with defines of the current rank removed.\r\n */\r\n EffectFallbacks.prototype.reduce = function (currentDefines, effect) {\r\n // First we try to switch to CPU skinning\r\n if (this._mesh && this._mesh.computeBonesUsingShaders && this._mesh.numBoneInfluencers > 0) {\r\n this._mesh.computeBonesUsingShaders = false;\r\n currentDefines = currentDefines.replace(\"#define NUM_BONE_INFLUENCERS \" + this._mesh.numBoneInfluencers, \"#define NUM_BONE_INFLUENCERS 0\");\r\n effect._bonesComputationForcedToCPU = true;\r\n var scene = this._mesh.getScene();\r\n for (var index = 0; index < scene.meshes.length; index++) {\r\n var otherMesh = scene.meshes[index];\r\n if (!otherMesh.material) {\r\n if (!this._mesh.material && otherMesh.computeBonesUsingShaders && otherMesh.numBoneInfluencers > 0) {\r\n otherMesh.computeBonesUsingShaders = false;\r\n }\r\n continue;\r\n }\r\n if (!otherMesh.computeBonesUsingShaders || otherMesh.numBoneInfluencers === 0) {\r\n continue;\r\n }\r\n if (otherMesh.material.getEffect() === effect) {\r\n otherMesh.computeBonesUsingShaders = false;\r\n }\r\n else if (otherMesh.subMeshes) {\r\n for (var _i = 0, _a = otherMesh.subMeshes; _i < _a.length; _i++) {\r\n var subMesh = _a[_i];\r\n var subMeshEffect = subMesh.effect;\r\n if (subMeshEffect === effect) {\r\n otherMesh.computeBonesUsingShaders = false;\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n var currentFallbacks = this._defines[this._currentRank];\r\n if (currentFallbacks) {\r\n for (var index = 0; index < currentFallbacks.length; index++) {\r\n currentDefines = currentDefines.replace(\"#define \" + currentFallbacks[index], \"\");\r\n }\r\n }\r\n this._currentRank++;\r\n }\r\n return currentDefines;\r\n };\r\n return EffectFallbacks;\r\n}());\r\nexport { EffectFallbacks };\r\n//# sourceMappingURL=effectFallbacks.js.map","import { SmartArray } from \"../Misc/smartArray\";\r\nimport { Vector3 } from \"../Maths/math.vector\";\r\n/**\r\n * This represents the object necessary to create a rendering group.\r\n * This is exclusively used and created by the rendering manager.\r\n * To modify the behavior, you use the available helpers in your scene or meshes.\r\n * @hidden\r\n */\r\nvar RenderingGroup = /** @class */ (function () {\r\n /**\r\n * Creates a new rendering group.\r\n * @param index The rendering group index\r\n * @param opaqueSortCompareFn The opaque sort comparison function. If null no order is applied\r\n * @param alphaTestSortCompareFn The alpha test sort comparison function. If null no order is applied\r\n * @param transparentSortCompareFn The transparent sort comparison function. If null back to front + alpha index sort is applied\r\n */\r\n function RenderingGroup(index, scene, opaqueSortCompareFn, alphaTestSortCompareFn, transparentSortCompareFn) {\r\n if (opaqueSortCompareFn === void 0) { opaqueSortCompareFn = null; }\r\n if (alphaTestSortCompareFn === void 0) { alphaTestSortCompareFn = null; }\r\n if (transparentSortCompareFn === void 0) { transparentSortCompareFn = null; }\r\n this.index = index;\r\n this._opaqueSubMeshes = new SmartArray(256);\r\n this._transparentSubMeshes = new SmartArray(256);\r\n this._alphaTestSubMeshes = new SmartArray(256);\r\n this._depthOnlySubMeshes = new SmartArray(256);\r\n this._particleSystems = new SmartArray(256);\r\n this._spriteManagers = new SmartArray(256);\r\n /** @hidden */\r\n this._edgesRenderers = new SmartArray(16);\r\n this._scene = scene;\r\n this.opaqueSortCompareFn = opaqueSortCompareFn;\r\n this.alphaTestSortCompareFn = alphaTestSortCompareFn;\r\n this.transparentSortCompareFn = transparentSortCompareFn;\r\n }\r\n Object.defineProperty(RenderingGroup.prototype, \"opaqueSortCompareFn\", {\r\n /**\r\n * Set the opaque sort comparison function.\r\n * If null the sub meshes will be render in the order they were created\r\n */\r\n set: function (value) {\r\n this._opaqueSortCompareFn = value;\r\n if (value) {\r\n this._renderOpaque = this.renderOpaqueSorted;\r\n }\r\n else {\r\n this._renderOpaque = RenderingGroup.renderUnsorted;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(RenderingGroup.prototype, \"alphaTestSortCompareFn\", {\r\n /**\r\n * Set the alpha test sort comparison function.\r\n * If null the sub meshes will be render in the order they were created\r\n */\r\n set: function (value) {\r\n this._alphaTestSortCompareFn = value;\r\n if (value) {\r\n this._renderAlphaTest = this.renderAlphaTestSorted;\r\n }\r\n else {\r\n this._renderAlphaTest = RenderingGroup.renderUnsorted;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(RenderingGroup.prototype, \"transparentSortCompareFn\", {\r\n /**\r\n * Set the transparent sort comparison function.\r\n * If null the sub meshes will be render in the order they were created\r\n */\r\n set: function (value) {\r\n if (value) {\r\n this._transparentSortCompareFn = value;\r\n }\r\n else {\r\n this._transparentSortCompareFn = RenderingGroup.defaultTransparentSortCompare;\r\n }\r\n this._renderTransparent = this.renderTransparentSorted;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Render all the sub meshes contained in the group.\r\n * @param customRenderFunction Used to override the default render behaviour of the group.\r\n * @returns true if rendered some submeshes.\r\n */\r\n RenderingGroup.prototype.render = function (customRenderFunction, renderSprites, renderParticles, activeMeshes) {\r\n if (customRenderFunction) {\r\n customRenderFunction(this._opaqueSubMeshes, this._alphaTestSubMeshes, this._transparentSubMeshes, this._depthOnlySubMeshes);\r\n return;\r\n }\r\n var engine = this._scene.getEngine();\r\n // Depth only\r\n if (this._depthOnlySubMeshes.length !== 0) {\r\n engine.setColorWrite(false);\r\n this._renderAlphaTest(this._depthOnlySubMeshes);\r\n engine.setColorWrite(true);\r\n }\r\n // Opaque\r\n if (this._opaqueSubMeshes.length !== 0) {\r\n this._renderOpaque(this._opaqueSubMeshes);\r\n }\r\n // Alpha test\r\n if (this._alphaTestSubMeshes.length !== 0) {\r\n this._renderAlphaTest(this._alphaTestSubMeshes);\r\n }\r\n var stencilState = engine.getStencilBuffer();\r\n engine.setStencilBuffer(false);\r\n // Sprites\r\n if (renderSprites) {\r\n this._renderSprites();\r\n }\r\n // Particles\r\n if (renderParticles) {\r\n this._renderParticles(activeMeshes);\r\n }\r\n if (this.onBeforeTransparentRendering) {\r\n this.onBeforeTransparentRendering();\r\n }\r\n // Transparent\r\n if (this._transparentSubMeshes.length !== 0) {\r\n this._renderTransparent(this._transparentSubMeshes);\r\n engine.setAlphaMode(0);\r\n }\r\n // Set back stencil to false in case it changes before the edge renderer.\r\n engine.setStencilBuffer(false);\r\n // Edges\r\n if (this._edgesRenderers.length) {\r\n for (var edgesRendererIndex = 0; edgesRendererIndex < this._edgesRenderers.length; edgesRendererIndex++) {\r\n this._edgesRenderers.data[edgesRendererIndex].render();\r\n }\r\n engine.setAlphaMode(0);\r\n }\r\n // Restore Stencil state.\r\n engine.setStencilBuffer(stencilState);\r\n };\r\n /**\r\n * Renders the opaque submeshes in the order from the opaqueSortCompareFn.\r\n * @param subMeshes The submeshes to render\r\n */\r\n RenderingGroup.prototype.renderOpaqueSorted = function (subMeshes) {\r\n return RenderingGroup.renderSorted(subMeshes, this._opaqueSortCompareFn, this._scene.activeCamera, false);\r\n };\r\n /**\r\n * Renders the opaque submeshes in the order from the alphatestSortCompareFn.\r\n * @param subMeshes The submeshes to render\r\n */\r\n RenderingGroup.prototype.renderAlphaTestSorted = function (subMeshes) {\r\n return RenderingGroup.renderSorted(subMeshes, this._alphaTestSortCompareFn, this._scene.activeCamera, false);\r\n };\r\n /**\r\n * Renders the opaque submeshes in the order from the transparentSortCompareFn.\r\n * @param subMeshes The submeshes to render\r\n */\r\n RenderingGroup.prototype.renderTransparentSorted = function (subMeshes) {\r\n return RenderingGroup.renderSorted(subMeshes, this._transparentSortCompareFn, this._scene.activeCamera, true);\r\n };\r\n /**\r\n * Renders the submeshes in a specified order.\r\n * @param subMeshes The submeshes to sort before render\r\n * @param sortCompareFn The comparison function use to sort\r\n * @param cameraPosition The camera position use to preprocess the submeshes to help sorting\r\n * @param transparent Specifies to activate blending if true\r\n */\r\n RenderingGroup.renderSorted = function (subMeshes, sortCompareFn, camera, transparent) {\r\n var subIndex = 0;\r\n var subMesh;\r\n var cameraPosition = camera ? camera.globalPosition : RenderingGroup._zeroVector;\r\n for (; subIndex < subMeshes.length; subIndex++) {\r\n subMesh = subMeshes.data[subIndex];\r\n subMesh._alphaIndex = subMesh.getMesh().alphaIndex;\r\n subMesh._distanceToCamera = Vector3.Distance(subMesh.getBoundingInfo().boundingSphere.centerWorld, cameraPosition);\r\n }\r\n var sortedArray = subMeshes.data.slice(0, subMeshes.length);\r\n if (sortCompareFn) {\r\n sortedArray.sort(sortCompareFn);\r\n }\r\n for (subIndex = 0; subIndex < sortedArray.length; subIndex++) {\r\n subMesh = sortedArray[subIndex];\r\n if (transparent) {\r\n var material = subMesh.getMaterial();\r\n if (material && material.needDepthPrePass) {\r\n var engine = material.getScene().getEngine();\r\n engine.setColorWrite(false);\r\n engine.setAlphaMode(0);\r\n subMesh.render(false);\r\n engine.setColorWrite(true);\r\n }\r\n }\r\n subMesh.render(transparent);\r\n }\r\n };\r\n /**\r\n * Renders the submeshes in the order they were dispatched (no sort applied).\r\n * @param subMeshes The submeshes to render\r\n */\r\n RenderingGroup.renderUnsorted = function (subMeshes) {\r\n for (var subIndex = 0; subIndex < subMeshes.length; subIndex++) {\r\n var submesh = subMeshes.data[subIndex];\r\n submesh.render(false);\r\n }\r\n };\r\n /**\r\n * Build in function which can be applied to ensure meshes of a special queue (opaque, alpha test, transparent)\r\n * are rendered back to front if in the same alpha index.\r\n *\r\n * @param a The first submesh\r\n * @param b The second submesh\r\n * @returns The result of the comparison\r\n */\r\n RenderingGroup.defaultTransparentSortCompare = function (a, b) {\r\n // Alpha index first\r\n if (a._alphaIndex > b._alphaIndex) {\r\n return 1;\r\n }\r\n if (a._alphaIndex < b._alphaIndex) {\r\n return -1;\r\n }\r\n // Then distance to camera\r\n return RenderingGroup.backToFrontSortCompare(a, b);\r\n };\r\n /**\r\n * Build in function which can be applied to ensure meshes of a special queue (opaque, alpha test, transparent)\r\n * are rendered back to front.\r\n *\r\n * @param a The first submesh\r\n * @param b The second submesh\r\n * @returns The result of the comparison\r\n */\r\n RenderingGroup.backToFrontSortCompare = function (a, b) {\r\n // Then distance to camera\r\n if (a._distanceToCamera < b._distanceToCamera) {\r\n return 1;\r\n }\r\n if (a._distanceToCamera > b._distanceToCamera) {\r\n return -1;\r\n }\r\n return 0;\r\n };\r\n /**\r\n * Build in function which can be applied to ensure meshes of a special queue (opaque, alpha test, transparent)\r\n * are rendered front to back (prevent overdraw).\r\n *\r\n * @param a The first submesh\r\n * @param b The second submesh\r\n * @returns The result of the comparison\r\n */\r\n RenderingGroup.frontToBackSortCompare = function (a, b) {\r\n // Then distance to camera\r\n if (a._distanceToCamera < b._distanceToCamera) {\r\n return -1;\r\n }\r\n if (a._distanceToCamera > b._distanceToCamera) {\r\n return 1;\r\n }\r\n return 0;\r\n };\r\n /**\r\n * Resets the different lists of submeshes to prepare a new frame.\r\n */\r\n RenderingGroup.prototype.prepare = function () {\r\n this._opaqueSubMeshes.reset();\r\n this._transparentSubMeshes.reset();\r\n this._alphaTestSubMeshes.reset();\r\n this._depthOnlySubMeshes.reset();\r\n this._particleSystems.reset();\r\n this._spriteManagers.reset();\r\n this._edgesRenderers.reset();\r\n };\r\n RenderingGroup.prototype.dispose = function () {\r\n this._opaqueSubMeshes.dispose();\r\n this._transparentSubMeshes.dispose();\r\n this._alphaTestSubMeshes.dispose();\r\n this._depthOnlySubMeshes.dispose();\r\n this._particleSystems.dispose();\r\n this._spriteManagers.dispose();\r\n this._edgesRenderers.dispose();\r\n };\r\n /**\r\n * Inserts the submesh in its correct queue depending on its material.\r\n * @param subMesh The submesh to dispatch\r\n * @param [mesh] Optional reference to the submeshes's mesh. Provide if you have an exiting reference to improve performance.\r\n * @param [material] Optional reference to the submeshes's material. Provide if you have an exiting reference to improve performance.\r\n */\r\n RenderingGroup.prototype.dispatch = function (subMesh, mesh, material) {\r\n // Get mesh and materials if not provided\r\n if (mesh === undefined) {\r\n mesh = subMesh.getMesh();\r\n }\r\n if (material === undefined) {\r\n material = subMesh.getMaterial();\r\n }\r\n if (material === null || material === undefined) {\r\n return;\r\n }\r\n if (material.needAlphaBlendingForMesh(mesh)) { // Transparent\r\n this._transparentSubMeshes.push(subMesh);\r\n }\r\n else if (material.needAlphaTesting()) { // Alpha test\r\n if (material.needDepthPrePass) {\r\n this._depthOnlySubMeshes.push(subMesh);\r\n }\r\n this._alphaTestSubMeshes.push(subMesh);\r\n }\r\n else {\r\n if (material.needDepthPrePass) {\r\n this._depthOnlySubMeshes.push(subMesh);\r\n }\r\n this._opaqueSubMeshes.push(subMesh); // Opaque\r\n }\r\n mesh._renderingGroup = this;\r\n if (mesh._edgesRenderer && mesh._edgesRenderer.isEnabled) {\r\n this._edgesRenderers.push(mesh._edgesRenderer);\r\n }\r\n };\r\n RenderingGroup.prototype.dispatchSprites = function (spriteManager) {\r\n this._spriteManagers.push(spriteManager);\r\n };\r\n RenderingGroup.prototype.dispatchParticles = function (particleSystem) {\r\n this._particleSystems.push(particleSystem);\r\n };\r\n RenderingGroup.prototype._renderParticles = function (activeMeshes) {\r\n if (this._particleSystems.length === 0) {\r\n return;\r\n }\r\n // Particles\r\n var activeCamera = this._scene.activeCamera;\r\n this._scene.onBeforeParticlesRenderingObservable.notifyObservers(this._scene);\r\n for (var particleIndex = 0; particleIndex < this._particleSystems.length; particleIndex++) {\r\n var particleSystem = this._particleSystems.data[particleIndex];\r\n if ((activeCamera && activeCamera.layerMask & particleSystem.layerMask) === 0) {\r\n continue;\r\n }\r\n var emitter = particleSystem.emitter;\r\n if (!emitter.position || !activeMeshes || activeMeshes.indexOf(emitter) !== -1) {\r\n this._scene._activeParticles.addCount(particleSystem.render(), false);\r\n }\r\n }\r\n this._scene.onAfterParticlesRenderingObservable.notifyObservers(this._scene);\r\n };\r\n RenderingGroup.prototype._renderSprites = function () {\r\n if (!this._scene.spritesEnabled || this._spriteManagers.length === 0) {\r\n return;\r\n }\r\n // Sprites\r\n var activeCamera = this._scene.activeCamera;\r\n this._scene.onBeforeSpritesRenderingObservable.notifyObservers(this._scene);\r\n for (var id = 0; id < this._spriteManagers.length; id++) {\r\n var spriteManager = this._spriteManagers.data[id];\r\n if (((activeCamera && activeCamera.layerMask & spriteManager.layerMask) !== 0)) {\r\n spriteManager.render();\r\n }\r\n }\r\n this._scene.onAfterSpritesRenderingObservable.notifyObservers(this._scene);\r\n };\r\n RenderingGroup._zeroVector = Vector3.Zero();\r\n return RenderingGroup;\r\n}());\r\nexport { RenderingGroup };\r\n//# sourceMappingURL=renderingGroup.js.map","import { RenderingGroup } from \"./renderingGroup\";\r\n/**\r\n * This class is used by the onRenderingGroupObservable\r\n */\r\nvar RenderingGroupInfo = /** @class */ (function () {\r\n function RenderingGroupInfo() {\r\n }\r\n return RenderingGroupInfo;\r\n}());\r\nexport { RenderingGroupInfo };\r\n/**\r\n * This is the manager responsible of all the rendering for meshes sprites and particles.\r\n * It is enable to manage the different groups as well as the different necessary sort functions.\r\n * This should not be used directly aside of the few static configurations\r\n */\r\nvar RenderingManager = /** @class */ (function () {\r\n /**\r\n * Instantiates a new rendering group for a particular scene\r\n * @param scene Defines the scene the groups belongs to\r\n */\r\n function RenderingManager(scene) {\r\n /**\r\n * @hidden\r\n */\r\n this._useSceneAutoClearSetup = false;\r\n this._renderingGroups = new Array();\r\n this._autoClearDepthStencil = {};\r\n this._customOpaqueSortCompareFn = {};\r\n this._customAlphaTestSortCompareFn = {};\r\n this._customTransparentSortCompareFn = {};\r\n this._renderingGroupInfo = new RenderingGroupInfo();\r\n this._scene = scene;\r\n for (var i = RenderingManager.MIN_RENDERINGGROUPS; i < RenderingManager.MAX_RENDERINGGROUPS; i++) {\r\n this._autoClearDepthStencil[i] = { autoClear: true, depth: true, stencil: true };\r\n }\r\n }\r\n RenderingManager.prototype._clearDepthStencilBuffer = function (depth, stencil) {\r\n if (depth === void 0) { depth = true; }\r\n if (stencil === void 0) { stencil = true; }\r\n if (this._depthStencilBufferAlreadyCleaned) {\r\n return;\r\n }\r\n this._scene.getEngine().clear(null, false, depth, stencil);\r\n this._depthStencilBufferAlreadyCleaned = true;\r\n };\r\n /**\r\n * Renders the entire managed groups. This is used by the scene or the different rennder targets.\r\n * @hidden\r\n */\r\n RenderingManager.prototype.render = function (customRenderFunction, activeMeshes, renderParticles, renderSprites) {\r\n // Update the observable context (not null as it only goes away on dispose)\r\n var info = this._renderingGroupInfo;\r\n info.scene = this._scene;\r\n info.camera = this._scene.activeCamera;\r\n // Dispatch sprites\r\n if (this._scene.spriteManagers && renderSprites) {\r\n for (var index = 0; index < this._scene.spriteManagers.length; index++) {\r\n var manager = this._scene.spriteManagers[index];\r\n this.dispatchSprites(manager);\r\n }\r\n }\r\n // Render\r\n for (var index = RenderingManager.MIN_RENDERINGGROUPS; index < RenderingManager.MAX_RENDERINGGROUPS; index++) {\r\n this._depthStencilBufferAlreadyCleaned = index === RenderingManager.MIN_RENDERINGGROUPS;\r\n var renderingGroup = this._renderingGroups[index];\r\n if (!renderingGroup) {\r\n continue;\r\n }\r\n var renderingGroupMask = Math.pow(2, index);\r\n info.renderingGroupId = index;\r\n // Before Observable\r\n this._scene.onBeforeRenderingGroupObservable.notifyObservers(info, renderingGroupMask);\r\n // Clear depth/stencil if needed\r\n if (RenderingManager.AUTOCLEAR) {\r\n var autoClear = this._useSceneAutoClearSetup ?\r\n this._scene.getAutoClearDepthStencilSetup(index) :\r\n this._autoClearDepthStencil[index];\r\n if (autoClear && autoClear.autoClear) {\r\n this._clearDepthStencilBuffer(autoClear.depth, autoClear.stencil);\r\n }\r\n }\r\n // Render\r\n for (var _i = 0, _a = this._scene._beforeRenderingGroupDrawStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n step.action(index);\r\n }\r\n renderingGroup.render(customRenderFunction, renderSprites, renderParticles, activeMeshes);\r\n for (var _b = 0, _c = this._scene._afterRenderingGroupDrawStage; _b < _c.length; _b++) {\r\n var step = _c[_b];\r\n step.action(index);\r\n }\r\n // After Observable\r\n this._scene.onAfterRenderingGroupObservable.notifyObservers(info, renderingGroupMask);\r\n }\r\n };\r\n /**\r\n * Resets the different information of the group to prepare a new frame\r\n * @hidden\r\n */\r\n RenderingManager.prototype.reset = function () {\r\n for (var index = RenderingManager.MIN_RENDERINGGROUPS; index < RenderingManager.MAX_RENDERINGGROUPS; index++) {\r\n var renderingGroup = this._renderingGroups[index];\r\n if (renderingGroup) {\r\n renderingGroup.prepare();\r\n }\r\n }\r\n };\r\n /**\r\n * Dispose and release the group and its associated resources.\r\n * @hidden\r\n */\r\n RenderingManager.prototype.dispose = function () {\r\n this.freeRenderingGroups();\r\n this._renderingGroups.length = 0;\r\n this._renderingGroupInfo = null;\r\n };\r\n /**\r\n * Clear the info related to rendering groups preventing retention points during dispose.\r\n */\r\n RenderingManager.prototype.freeRenderingGroups = function () {\r\n for (var index = RenderingManager.MIN_RENDERINGGROUPS; index < RenderingManager.MAX_RENDERINGGROUPS; index++) {\r\n var renderingGroup = this._renderingGroups[index];\r\n if (renderingGroup) {\r\n renderingGroup.dispose();\r\n }\r\n }\r\n };\r\n RenderingManager.prototype._prepareRenderingGroup = function (renderingGroupId) {\r\n if (this._renderingGroups[renderingGroupId] === undefined) {\r\n this._renderingGroups[renderingGroupId] = new RenderingGroup(renderingGroupId, this._scene, this._customOpaqueSortCompareFn[renderingGroupId], this._customAlphaTestSortCompareFn[renderingGroupId], this._customTransparentSortCompareFn[renderingGroupId]);\r\n }\r\n };\r\n /**\r\n * Add a sprite manager to the rendering manager in order to render it this frame.\r\n * @param spriteManager Define the sprite manager to render\r\n */\r\n RenderingManager.prototype.dispatchSprites = function (spriteManager) {\r\n var renderingGroupId = spriteManager.renderingGroupId || 0;\r\n this._prepareRenderingGroup(renderingGroupId);\r\n this._renderingGroups[renderingGroupId].dispatchSprites(spriteManager);\r\n };\r\n /**\r\n * Add a particle system to the rendering manager in order to render it this frame.\r\n * @param particleSystem Define the particle system to render\r\n */\r\n RenderingManager.prototype.dispatchParticles = function (particleSystem) {\r\n var renderingGroupId = particleSystem.renderingGroupId || 0;\r\n this._prepareRenderingGroup(renderingGroupId);\r\n this._renderingGroups[renderingGroupId].dispatchParticles(particleSystem);\r\n };\r\n /**\r\n * Add a submesh to the manager in order to render it this frame\r\n * @param subMesh The submesh to dispatch\r\n * @param mesh Optional reference to the submeshes's mesh. Provide if you have an exiting reference to improve performance.\r\n * @param material Optional reference to the submeshes's material. Provide if you have an exiting reference to improve performance.\r\n */\r\n RenderingManager.prototype.dispatch = function (subMesh, mesh, material) {\r\n if (mesh === undefined) {\r\n mesh = subMesh.getMesh();\r\n }\r\n var renderingGroupId = mesh.renderingGroupId || 0;\r\n this._prepareRenderingGroup(renderingGroupId);\r\n this._renderingGroups[renderingGroupId].dispatch(subMesh, mesh, material);\r\n };\r\n /**\r\n * Overrides the default sort function applied in the renderging group to prepare the meshes.\r\n * This allowed control for front to back rendering or reversly depending of the special needs.\r\n *\r\n * @param renderingGroupId The rendering group id corresponding to its index\r\n * @param opaqueSortCompareFn The opaque queue comparison function use to sort.\r\n * @param alphaTestSortCompareFn The alpha test queue comparison function use to sort.\r\n * @param transparentSortCompareFn The transparent queue comparison function use to sort.\r\n */\r\n RenderingManager.prototype.setRenderingOrder = function (renderingGroupId, opaqueSortCompareFn, alphaTestSortCompareFn, transparentSortCompareFn) {\r\n if (opaqueSortCompareFn === void 0) { opaqueSortCompareFn = null; }\r\n if (alphaTestSortCompareFn === void 0) { alphaTestSortCompareFn = null; }\r\n if (transparentSortCompareFn === void 0) { transparentSortCompareFn = null; }\r\n this._customOpaqueSortCompareFn[renderingGroupId] = opaqueSortCompareFn;\r\n this._customAlphaTestSortCompareFn[renderingGroupId] = alphaTestSortCompareFn;\r\n this._customTransparentSortCompareFn[renderingGroupId] = transparentSortCompareFn;\r\n if (this._renderingGroups[renderingGroupId]) {\r\n var group = this._renderingGroups[renderingGroupId];\r\n group.opaqueSortCompareFn = this._customOpaqueSortCompareFn[renderingGroupId];\r\n group.alphaTestSortCompareFn = this._customAlphaTestSortCompareFn[renderingGroupId];\r\n group.transparentSortCompareFn = this._customTransparentSortCompareFn[renderingGroupId];\r\n }\r\n };\r\n /**\r\n * Specifies whether or not the stencil and depth buffer are cleared between two rendering groups.\r\n *\r\n * @param renderingGroupId The rendering group id corresponding to its index\r\n * @param autoClearDepthStencil Automatically clears depth and stencil between groups if true.\r\n * @param depth Automatically clears depth between groups if true and autoClear is true.\r\n * @param stencil Automatically clears stencil between groups if true and autoClear is true.\r\n */\r\n RenderingManager.prototype.setRenderingAutoClearDepthStencil = function (renderingGroupId, autoClearDepthStencil, depth, stencil) {\r\n if (depth === void 0) { depth = true; }\r\n if (stencil === void 0) { stencil = true; }\r\n this._autoClearDepthStencil[renderingGroupId] = {\r\n autoClear: autoClearDepthStencil,\r\n depth: depth,\r\n stencil: stencil\r\n };\r\n };\r\n /**\r\n * Gets the current auto clear configuration for one rendering group of the rendering\r\n * manager.\r\n * @param index the rendering group index to get the information for\r\n * @returns The auto clear setup for the requested rendering group\r\n */\r\n RenderingManager.prototype.getAutoClearDepthStencilSetup = function (index) {\r\n return this._autoClearDepthStencil[index];\r\n };\r\n /**\r\n * The max id used for rendering groups (not included)\r\n */\r\n RenderingManager.MAX_RENDERINGGROUPS = 4;\r\n /**\r\n * The min id used for rendering groups (included)\r\n */\r\n RenderingManager.MIN_RENDERINGGROUPS = 0;\r\n /**\r\n * Used to globally prevent autoclearing scenes.\r\n */\r\n RenderingManager.AUTOCLEAR = true;\r\n return RenderingManager;\r\n}());\r\nexport { RenderingManager };\r\n//# sourceMappingURL=renderingManager.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'helperFunctions';\r\nvar shader = \"const float PI=3.1415926535897932384626433832795;\\nconst float LinearEncodePowerApprox=2.2;\\nconst float GammaEncodePowerApprox=1.0/LinearEncodePowerApprox;\\nconst vec3 LuminanceEncodeApprox=vec3(0.2126,0.7152,0.0722);\\nconst float Epsilon=0.0000001;\\n#define saturate(x) clamp(x,0.0,1.0)\\n#define absEps(x) abs(x)+Epsilon\\n#define maxEps(x) max(x,Epsilon)\\n#define saturateEps(x) clamp(x,Epsilon,1.0)\\nmat3 transposeMat3(mat3 inMatrix) {\\nvec3 i0=inMatrix[0];\\nvec3 i1=inMatrix[1];\\nvec3 i2=inMatrix[2];\\nmat3 outMatrix=mat3(\\nvec3(i0.x,i1.x,i2.x),\\nvec3(i0.y,i1.y,i2.y),\\nvec3(i0.z,i1.z,i2.z)\\n);\\nreturn outMatrix;\\n}\\n\\nmat3 inverseMat3(mat3 inMatrix) {\\nfloat a00=inMatrix[0][0],a01=inMatrix[0][1],a02=inMatrix[0][2];\\nfloat a10=inMatrix[1][0],a11=inMatrix[1][1],a12=inMatrix[1][2];\\nfloat a20=inMatrix[2][0],a21=inMatrix[2][1],a22=inMatrix[2][2];\\nfloat b01=a22*a11-a12*a21;\\nfloat b11=-a22*a10+a12*a20;\\nfloat b21=a21*a10-a11*a20;\\nfloat det=a00*b01+a01*b11+a02*b21;\\nreturn mat3(b01,(-a22*a01+a02*a21),(a12*a01-a02*a11),\\nb11,(a22*a00-a02*a20),(-a12*a00+a02*a10),\\nb21,(-a21*a00+a01*a20),(a11*a00-a01*a10))/det;\\n}\\nvec3 toLinearSpace(vec3 color)\\n{\\nreturn pow(color,vec3(LinearEncodePowerApprox));\\n}\\nvec3 toGammaSpace(vec3 color)\\n{\\nreturn pow(color,vec3(GammaEncodePowerApprox));\\n}\\nfloat toGammaSpace(float color)\\n{\\nreturn pow(color,GammaEncodePowerApprox);\\n}\\nfloat square(float value)\\n{\\nreturn value*value;\\n}\\nfloat pow5(float value) {\\nfloat sq=value*value;\\nreturn sq*sq*value;\\n}\\nfloat getLuminance(vec3 color)\\n{\\nreturn clamp(dot(color,LuminanceEncodeApprox),0.,1.);\\n}\\n\\nfloat getRand(vec2 seed) {\\nreturn fract(sin(dot(seed.xy ,vec2(12.9898,78.233)))*43758.5453);\\n}\\nfloat dither(vec2 seed,float varianceAmount) {\\nfloat rand=getRand(seed);\\nfloat dither=mix(-varianceAmount/255.0,varianceAmount/255.0,rand);\\nreturn dither;\\n}\\n\\nconst float rgbdMaxRange=255.0;\\nvec4 toRGBD(vec3 color) {\\nfloat maxRGB=maxEps(max(color.r,max(color.g,color.b)));\\nfloat D=max(rgbdMaxRange/maxRGB,1.);\\nD=clamp(floor(D)/255.0,0.,1.);\\n\\nvec3 rgb=color.rgb*D;\\n\\nrgb=toGammaSpace(rgb);\\nreturn vec4(rgb,D);\\n}\\nvec3 fromRGBD(vec4 rgbd) {\\n\\nrgbd.rgb=toLinearSpace(rgbd.rgb);\\n\\nreturn rgbd.rgb/rgbd.a;\\n}\\n\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var helperFunctions = { name: name, shader: shader };\r\n//# sourceMappingURL=helperFunctions.js.map","/**\n * chroma.js - JavaScript library for color conversions\n *\n * Copyright (c) 2011-2019, Gregor Aisch\n * All rights reserved.\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n *\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the documentation\n * and/or other materials provided with the distribution.\n *\n * 3. The name Gregor Aisch may not be used to endorse or promote products\n * derived from this software without specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\n * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL GREGOR AISCH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,\n * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,\n * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,\n * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY\n * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n *\n * -------------------------------------------------------\n *\n * chroma.js includes colors from colorbrewer2.org, which are released under\n * the following license:\n *\n * Copyright (c) 2002 Cynthia Brewer, Mark Harrower,\n * and The Pennsylvania State University.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing,\n * software distributed under the License is distributed on an\n * \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,\n * either express or implied. See the License for the specific\n * language governing permissions and limitations under the License.\n *\n * ------------------------------------------------------\n *\n * Named colors are taken from X11 Color Names.\n * http://www.w3.org/TR/css3-color/#svg-color\n *\n * @preserve\n */\n\n(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (global.chroma = factory());\n}(this, (function () { 'use strict';\n\n var limit = function (x, min, max) {\n if ( min === void 0 ) min=0;\n if ( max === void 0 ) max=1;\n\n return x < min ? min : x > max ? max : x;\n };\n\n var clip_rgb = function (rgb) {\n rgb._clipped = false;\n rgb._unclipped = rgb.slice(0);\n for (var i=0; i<=3; i++) {\n if (i < 3) {\n if (rgb[i] < 0 || rgb[i] > 255) { rgb._clipped = true; }\n rgb[i] = limit(rgb[i], 0, 255);\n } else if (i === 3) {\n rgb[i] = limit(rgb[i], 0, 1);\n }\n }\n return rgb;\n };\n\n // ported from jQuery's $.type\n var classToType = {};\n for (var i = 0, list = ['Boolean', 'Number', 'String', 'Function', 'Array', 'Date', 'RegExp', 'Undefined', 'Null']; i < list.length; i += 1) {\n var name = list[i];\n\n classToType[(\"[object \" + name + \"]\")] = name.toLowerCase();\n }\n var type = function(obj) {\n return classToType[Object.prototype.toString.call(obj)] || \"object\";\n };\n\n var unpack = function (args, keyOrder) {\n if ( keyOrder === void 0 ) keyOrder=null;\n\n \t// if called with more than 3 arguments, we return the arguments\n if (args.length >= 3) { return Array.prototype.slice.call(args); }\n // with less than 3 args we check if first arg is object\n // and use the keyOrder string to extract and sort properties\n \tif (type(args[0]) == 'object' && keyOrder) {\n \t\treturn keyOrder.split('')\n \t\t\t.filter(function (k) { return args[0][k] !== undefined; })\n \t\t\t.map(function (k) { return args[0][k]; });\n \t}\n \t// otherwise we just return the first argument\n \t// (which we suppose is an array of args)\n return args[0];\n };\n\n var last = function (args) {\n if (args.length < 2) { return null; }\n var l = args.length-1;\n if (type(args[l]) == 'string') { return args[l].toLowerCase(); }\n return null;\n };\n\n var PI = Math.PI;\n\n var utils = {\n \tclip_rgb: clip_rgb,\n \tlimit: limit,\n \ttype: type,\n \tunpack: unpack,\n \tlast: last,\n \tPI: PI,\n \tTWOPI: PI*2,\n \tPITHIRD: PI/3,\n \tDEG2RAD: PI / 180,\n \tRAD2DEG: 180 / PI\n };\n\n var input = {\n \tformat: {},\n \tautodetect: []\n };\n\n var last$1 = utils.last;\n var clip_rgb$1 = utils.clip_rgb;\n var type$1 = utils.type;\n\n\n var Color = function Color() {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var me = this;\n if (type$1(args[0]) === 'object' &&\n args[0].constructor &&\n args[0].constructor === this.constructor) {\n // the argument is already a Color instance\n return args[0];\n }\n\n // last argument could be the mode\n var mode = last$1(args);\n var autodetect = false;\n\n if (!mode) {\n autodetect = true;\n if (!input.sorted) {\n input.autodetect = input.autodetect.sort(function (a,b) { return b.p - a.p; });\n input.sorted = true;\n }\n // auto-detect format\n for (var i = 0, list = input.autodetect; i < list.length; i += 1) {\n var chk = list[i];\n\n mode = chk.test.apply(chk, args);\n if (mode) { break; }\n }\n }\n\n if (input.format[mode]) {\n var rgb = input.format[mode].apply(null, autodetect ? args : args.slice(0,-1));\n me._rgb = clip_rgb$1(rgb);\n } else {\n throw new Error('unknown format: '+args);\n }\n\n // add alpha channel\n if (me._rgb.length === 3) { me._rgb.push(1); }\n };\n\n Color.prototype.toString = function toString () {\n if (type$1(this.hex) == 'function') { return this.hex(); }\n return (\"[\" + (this._rgb.join(',')) + \"]\");\n };\n\n var Color_1 = Color;\n\n var chroma = function () {\n \tvar args = [], len = arguments.length;\n \twhile ( len-- ) args[ len ] = arguments[ len ];\n\n \treturn new (Function.prototype.bind.apply( chroma.Color, [ null ].concat( args) ));\n };\n\n chroma.Color = Color_1;\n chroma.version = '2.1.0';\n\n var chroma_1 = chroma;\n\n var unpack$1 = utils.unpack;\n var max = Math.max;\n\n var rgb2cmyk = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$1(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n r = r / 255;\n g = g / 255;\n b = b / 255;\n var k = 1 - max(r,max(g,b));\n var f = k < 1 ? 1 / (1-k) : 0;\n var c = (1-r-k) * f;\n var m = (1-g-k) * f;\n var y = (1-b-k) * f;\n return [c,m,y,k];\n };\n\n var rgb2cmyk_1 = rgb2cmyk;\n\n var unpack$2 = utils.unpack;\n\n var cmyk2rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$2(args, 'cmyk');\n var c = args[0];\n var m = args[1];\n var y = args[2];\n var k = args[3];\n var alpha = args.length > 4 ? args[4] : 1;\n if (k === 1) { return [0,0,0,alpha]; }\n return [\n c >= 1 ? 0 : 255 * (1-c) * (1-k), // r\n m >= 1 ? 0 : 255 * (1-m) * (1-k), // g\n y >= 1 ? 0 : 255 * (1-y) * (1-k), // b\n alpha\n ];\n };\n\n var cmyk2rgb_1 = cmyk2rgb;\n\n var unpack$3 = utils.unpack;\n var type$2 = utils.type;\n\n\n\n Color_1.prototype.cmyk = function() {\n return rgb2cmyk_1(this._rgb);\n };\n\n chroma_1.cmyk = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['cmyk']) ));\n };\n\n input.format.cmyk = cmyk2rgb_1;\n\n input.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$3(args, 'cmyk');\n if (type$2(args) === 'array' && args.length === 4) {\n return 'cmyk';\n }\n }\n });\n\n var unpack$4 = utils.unpack;\n var last$2 = utils.last;\n var rnd = function (a) { return Math.round(a*100)/100; };\n\n /*\n * supported arguments:\n * - hsl2css(h,s,l)\n * - hsl2css(h,s,l,a)\n * - hsl2css([h,s,l], mode)\n * - hsl2css([h,s,l,a], mode)\n * - hsl2css({h,s,l,a}, mode)\n */\n var hsl2css = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var hsla = unpack$4(args, 'hsla');\n var mode = last$2(args) || 'lsa';\n hsla[0] = rnd(hsla[0] || 0);\n hsla[1] = rnd(hsla[1]*100) + '%';\n hsla[2] = rnd(hsla[2]*100) + '%';\n if (mode === 'hsla' || (hsla.length > 3 && hsla[3]<1)) {\n hsla[3] = hsla.length > 3 ? hsla[3] : 1;\n mode = 'hsla';\n } else {\n hsla.length = 3;\n }\n return (mode + \"(\" + (hsla.join(',')) + \")\");\n };\n\n var hsl2css_1 = hsl2css;\n\n var unpack$5 = utils.unpack;\n\n /*\n * supported arguments:\n * - rgb2hsl(r,g,b)\n * - rgb2hsl(r,g,b,a)\n * - rgb2hsl([r,g,b])\n * - rgb2hsl([r,g,b,a])\n * - rgb2hsl({r,g,b,a})\n */\n var rgb2hsl = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$5(args, 'rgba');\n var r = args[0];\n var g = args[1];\n var b = args[2];\n\n r /= 255;\n g /= 255;\n b /= 255;\n\n var min = Math.min(r, g, b);\n var max = Math.max(r, g, b);\n\n var l = (max + min) / 2;\n var s, h;\n\n if (max === min){\n s = 0;\n h = Number.NaN;\n } else {\n s = l < 0.5 ? (max - min) / (max + min) : (max - min) / (2 - max - min);\n }\n\n if (r == max) { h = (g - b) / (max - min); }\n else if (g == max) { h = 2 + (b - r) / (max - min); }\n else if (b == max) { h = 4 + (r - g) / (max - min); }\n\n h *= 60;\n if (h < 0) { h += 360; }\n if (args.length>3 && args[3]!==undefined) { return [h,s,l,args[3]]; }\n return [h,s,l];\n };\n\n var rgb2hsl_1 = rgb2hsl;\n\n var unpack$6 = utils.unpack;\n var last$3 = utils.last;\n\n\n var round = Math.round;\n\n /*\n * supported arguments:\n * - rgb2css(r,g,b)\n * - rgb2css(r,g,b,a)\n * - rgb2css([r,g,b], mode)\n * - rgb2css([r,g,b,a], mode)\n * - rgb2css({r,g,b,a}, mode)\n */\n var rgb2css = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var rgba = unpack$6(args, 'rgba');\n var mode = last$3(args) || 'rgb';\n if (mode.substr(0,3) == 'hsl') {\n return hsl2css_1(rgb2hsl_1(rgba), mode);\n }\n rgba[0] = round(rgba[0]);\n rgba[1] = round(rgba[1]);\n rgba[2] = round(rgba[2]);\n if (mode === 'rgba' || (rgba.length > 3 && rgba[3]<1)) {\n rgba[3] = rgba.length > 3 ? rgba[3] : 1;\n mode = 'rgba';\n }\n return (mode + \"(\" + (rgba.slice(0,mode==='rgb'?3:4).join(',')) + \")\");\n };\n\n var rgb2css_1 = rgb2css;\n\n var unpack$7 = utils.unpack;\n var round$1 = Math.round;\n\n var hsl2rgb = function () {\n var assign;\n\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n args = unpack$7(args, 'hsl');\n var h = args[0];\n var s = args[1];\n var l = args[2];\n var r,g,b;\n if (s === 0) {\n r = g = b = l*255;\n } else {\n var t3 = [0,0,0];\n var c = [0,0,0];\n var t2 = l < 0.5 ? l * (1+s) : l+s-l*s;\n var t1 = 2 * l - t2;\n var h_ = h / 360;\n t3[0] = h_ + 1/3;\n t3[1] = h_;\n t3[2] = h_ - 1/3;\n for (var i=0; i<3; i++) {\n if (t3[i] < 0) { t3[i] += 1; }\n if (t3[i] > 1) { t3[i] -= 1; }\n if (6 * t3[i] < 1)\n { c[i] = t1 + (t2 - t1) * 6 * t3[i]; }\n else if (2 * t3[i] < 1)\n { c[i] = t2; }\n else if (3 * t3[i] < 2)\n { c[i] = t1 + (t2 - t1) * ((2 / 3) - t3[i]) * 6; }\n else\n { c[i] = t1; }\n }\n (assign = [round$1(c[0]*255),round$1(c[1]*255),round$1(c[2]*255)], r = assign[0], g = assign[1], b = assign[2]);\n }\n if (args.length > 3) {\n // keep alpha channel\n return [r,g,b,args[3]];\n }\n return [r,g,b,1];\n };\n\n var hsl2rgb_1 = hsl2rgb;\n\n var RE_RGB = /^rgb\\(\\s*(-?\\d+),\\s*(-?\\d+)\\s*,\\s*(-?\\d+)\\s*\\)$/;\n var RE_RGBA = /^rgba\\(\\s*(-?\\d+),\\s*(-?\\d+)\\s*,\\s*(-?\\d+)\\s*,\\s*([01]|[01]?\\.\\d+)\\)$/;\n var RE_RGB_PCT = /^rgb\\(\\s*(-?\\d+(?:\\.\\d+)?)%,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*\\)$/;\n var RE_RGBA_PCT = /^rgba\\(\\s*(-?\\d+(?:\\.\\d+)?)%,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*([01]|[01]?\\.\\d+)\\)$/;\n var RE_HSL = /^hsl\\(\\s*(-?\\d+(?:\\.\\d+)?),\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*\\)$/;\n var RE_HSLA = /^hsla\\(\\s*(-?\\d+(?:\\.\\d+)?),\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*([01]|[01]?\\.\\d+)\\)$/;\n\n var round$2 = Math.round;\n\n var css2rgb = function (css) {\n css = css.toLowerCase().trim();\n var m;\n\n if (input.format.named) {\n try {\n return input.format.named(css);\n } catch (e) {\n // eslint-disable-next-line\n }\n }\n\n // rgb(250,20,0)\n if ((m = css.match(RE_RGB))) {\n var rgb = m.slice(1,4);\n for (var i=0; i<3; i++) {\n rgb[i] = +rgb[i];\n }\n rgb[3] = 1; // default alpha\n return rgb;\n }\n\n // rgba(250,20,0,0.4)\n if ((m = css.match(RE_RGBA))) {\n var rgb$1 = m.slice(1,5);\n for (var i$1=0; i$1<4; i$1++) {\n rgb$1[i$1] = +rgb$1[i$1];\n }\n return rgb$1;\n }\n\n // rgb(100%,0%,0%)\n if ((m = css.match(RE_RGB_PCT))) {\n var rgb$2 = m.slice(1,4);\n for (var i$2=0; i$2<3; i$2++) {\n rgb$2[i$2] = round$2(rgb$2[i$2] * 2.55);\n }\n rgb$2[3] = 1; // default alpha\n return rgb$2;\n }\n\n // rgba(100%,0%,0%,0.4)\n if ((m = css.match(RE_RGBA_PCT))) {\n var rgb$3 = m.slice(1,5);\n for (var i$3=0; i$3<3; i$3++) {\n rgb$3[i$3] = round$2(rgb$3[i$3] * 2.55);\n }\n rgb$3[3] = +rgb$3[3];\n return rgb$3;\n }\n\n // hsl(0,100%,50%)\n if ((m = css.match(RE_HSL))) {\n var hsl = m.slice(1,4);\n hsl[1] *= 0.01;\n hsl[2] *= 0.01;\n var rgb$4 = hsl2rgb_1(hsl);\n rgb$4[3] = 1;\n return rgb$4;\n }\n\n // hsla(0,100%,50%,0.5)\n if ((m = css.match(RE_HSLA))) {\n var hsl$1 = m.slice(1,4);\n hsl$1[1] *= 0.01;\n hsl$1[2] *= 0.01;\n var rgb$5 = hsl2rgb_1(hsl$1);\n rgb$5[3] = +m[4]; // default alpha = 1\n return rgb$5;\n }\n };\n\n css2rgb.test = function (s) {\n return RE_RGB.test(s) ||\n RE_RGBA.test(s) ||\n RE_RGB_PCT.test(s) ||\n RE_RGBA_PCT.test(s) ||\n RE_HSL.test(s) ||\n RE_HSLA.test(s);\n };\n\n var css2rgb_1 = css2rgb;\n\n var type$3 = utils.type;\n\n\n\n\n Color_1.prototype.css = function(mode) {\n return rgb2css_1(this._rgb, mode);\n };\n\n chroma_1.css = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['css']) ));\n };\n\n input.format.css = css2rgb_1;\n\n input.autodetect.push({\n p: 5,\n test: function (h) {\n var rest = [], len = arguments.length - 1;\n while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];\n\n if (!rest.length && type$3(h) === 'string' && css2rgb_1.test(h)) {\n return 'css';\n }\n }\n });\n\n var unpack$8 = utils.unpack;\n\n input.format.gl = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var rgb = unpack$8(args, 'rgba');\n rgb[0] *= 255;\n rgb[1] *= 255;\n rgb[2] *= 255;\n return rgb;\n };\n\n chroma_1.gl = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['gl']) ));\n };\n\n Color_1.prototype.gl = function() {\n var rgb = this._rgb;\n return [rgb[0]/255, rgb[1]/255, rgb[2]/255, rgb[3]];\n };\n\n var unpack$9 = utils.unpack;\n\n var rgb2hcg = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$9(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n var min = Math.min(r, g, b);\n var max = Math.max(r, g, b);\n var delta = max - min;\n var c = delta * 100 / 255;\n var _g = min / (255 - delta) * 100;\n var h;\n if (delta === 0) {\n h = Number.NaN;\n } else {\n if (r === max) { h = (g - b) / delta; }\n if (g === max) { h = 2+(b - r) / delta; }\n if (b === max) { h = 4+(r - g) / delta; }\n h *= 60;\n if (h < 0) { h += 360; }\n }\n return [h, c, _g];\n };\n\n var rgb2hcg_1 = rgb2hcg;\n\n var unpack$a = utils.unpack;\n var floor = Math.floor;\n\n /*\n * this is basically just HSV with some minor tweaks\n *\n * hue.. [0..360]\n * chroma .. [0..1]\n * grayness .. [0..1]\n */\n\n var hcg2rgb = function () {\n var assign, assign$1, assign$2, assign$3, assign$4, assign$5;\n\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n args = unpack$a(args, 'hcg');\n var h = args[0];\n var c = args[1];\n var _g = args[2];\n var r,g,b;\n _g = _g * 255;\n var _c = c * 255;\n if (c === 0) {\n r = g = b = _g;\n } else {\n if (h === 360) { h = 0; }\n if (h > 360) { h -= 360; }\n if (h < 0) { h += 360; }\n h /= 60;\n var i = floor(h);\n var f = h - i;\n var p = _g * (1 - c);\n var q = p + _c * (1 - f);\n var t = p + _c * f;\n var v = p + _c;\n switch (i) {\n case 0: (assign = [v, t, p], r = assign[0], g = assign[1], b = assign[2]); break\n case 1: (assign$1 = [q, v, p], r = assign$1[0], g = assign$1[1], b = assign$1[2]); break\n case 2: (assign$2 = [p, v, t], r = assign$2[0], g = assign$2[1], b = assign$2[2]); break\n case 3: (assign$3 = [p, q, v], r = assign$3[0], g = assign$3[1], b = assign$3[2]); break\n case 4: (assign$4 = [t, p, v], r = assign$4[0], g = assign$4[1], b = assign$4[2]); break\n case 5: (assign$5 = [v, p, q], r = assign$5[0], g = assign$5[1], b = assign$5[2]); break\n }\n }\n return [r, g, b, args.length > 3 ? args[3] : 1];\n };\n\n var hcg2rgb_1 = hcg2rgb;\n\n var unpack$b = utils.unpack;\n var type$4 = utils.type;\n\n\n\n\n\n\n Color_1.prototype.hcg = function() {\n return rgb2hcg_1(this._rgb);\n };\n\n chroma_1.hcg = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hcg']) ));\n };\n\n input.format.hcg = hcg2rgb_1;\n\n input.autodetect.push({\n p: 1,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$b(args, 'hcg');\n if (type$4(args) === 'array' && args.length === 3) {\n return 'hcg';\n }\n }\n });\n\n var unpack$c = utils.unpack;\n var last$4 = utils.last;\n var round$3 = Math.round;\n\n var rgb2hex = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$c(args, 'rgba');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n var a = ref[3];\n var mode = last$4(args) || 'auto';\n if (a === undefined) { a = 1; }\n if (mode === 'auto') {\n mode = a < 1 ? 'rgba' : 'rgb';\n }\n r = round$3(r);\n g = round$3(g);\n b = round$3(b);\n var u = r << 16 | g << 8 | b;\n var str = \"000000\" + u.toString(16); //#.toUpperCase();\n str = str.substr(str.length - 6);\n var hxa = '0' + round$3(a * 255).toString(16);\n hxa = hxa.substr(hxa.length - 2);\n switch (mode.toLowerCase()) {\n case 'rgba': return (\"#\" + str + hxa);\n case 'argb': return (\"#\" + hxa + str);\n default: return (\"#\" + str);\n }\n };\n\n var rgb2hex_1 = rgb2hex;\n\n var RE_HEX = /^#?([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/;\n var RE_HEXA = /^#?([A-Fa-f0-9]{8}|[A-Fa-f0-9]{4})$/;\n\n var hex2rgb = function (hex) {\n if (hex.match(RE_HEX)) {\n // remove optional leading #\n if (hex.length === 4 || hex.length === 7) {\n hex = hex.substr(1);\n }\n // expand short-notation to full six-digit\n if (hex.length === 3) {\n hex = hex.split('');\n hex = hex[0]+hex[0]+hex[1]+hex[1]+hex[2]+hex[2];\n }\n var u = parseInt(hex, 16);\n var r = u >> 16;\n var g = u >> 8 & 0xFF;\n var b = u & 0xFF;\n return [r,g,b,1];\n }\n\n // match rgba hex format, eg #FF000077\n if (hex.match(RE_HEXA)) {\n if (hex.length === 5 || hex.length === 9) {\n // remove optional leading #\n hex = hex.substr(1);\n }\n // expand short-notation to full eight-digit\n if (hex.length === 4) {\n hex = hex.split('');\n hex = hex[0]+hex[0]+hex[1]+hex[1]+hex[2]+hex[2]+hex[3]+hex[3];\n }\n var u$1 = parseInt(hex, 16);\n var r$1 = u$1 >> 24 & 0xFF;\n var g$1 = u$1 >> 16 & 0xFF;\n var b$1 = u$1 >> 8 & 0xFF;\n var a = Math.round((u$1 & 0xFF) / 0xFF * 100) / 100;\n return [r$1,g$1,b$1,a];\n }\n\n // we used to check for css colors here\n // if _input.css? and rgb = _input.css hex\n // return rgb\n\n throw new Error((\"unknown hex color: \" + hex));\n };\n\n var hex2rgb_1 = hex2rgb;\n\n var type$5 = utils.type;\n\n\n\n\n Color_1.prototype.hex = function(mode) {\n return rgb2hex_1(this._rgb, mode);\n };\n\n chroma_1.hex = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hex']) ));\n };\n\n input.format.hex = hex2rgb_1;\n input.autodetect.push({\n p: 4,\n test: function (h) {\n var rest = [], len = arguments.length - 1;\n while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];\n\n if (!rest.length && type$5(h) === 'string' && [3,4,5,6,7,8,9].indexOf(h.length) >= 0) {\n return 'hex';\n }\n }\n });\n\n var unpack$d = utils.unpack;\n var TWOPI = utils.TWOPI;\n var min = Math.min;\n var sqrt = Math.sqrt;\n var acos = Math.acos;\n\n var rgb2hsi = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n /*\n borrowed from here:\n http://hummer.stanford.edu/museinfo/doc/examples/humdrum/keyscape2/rgb2hsi.cpp\n */\n var ref = unpack$d(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n r /= 255;\n g /= 255;\n b /= 255;\n var h;\n var min_ = min(r,g,b);\n var i = (r+g+b) / 3;\n var s = i > 0 ? 1 - min_/i : 0;\n if (s === 0) {\n h = NaN;\n } else {\n h = ((r-g)+(r-b)) / 2;\n h /= sqrt((r-g)*(r-g) + (r-b)*(g-b));\n h = acos(h);\n if (b > g) {\n h = TWOPI - h;\n }\n h /= TWOPI;\n }\n return [h*360,s,i];\n };\n\n var rgb2hsi_1 = rgb2hsi;\n\n var unpack$e = utils.unpack;\n var limit$1 = utils.limit;\n var TWOPI$1 = utils.TWOPI;\n var PITHIRD = utils.PITHIRD;\n var cos = Math.cos;\n\n /*\n * hue [0..360]\n * saturation [0..1]\n * intensity [0..1]\n */\n var hsi2rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n /*\n borrowed from here:\n http://hummer.stanford.edu/museinfo/doc/examples/humdrum/keyscape2/hsi2rgb.cpp\n */\n args = unpack$e(args, 'hsi');\n var h = args[0];\n var s = args[1];\n var i = args[2];\n var r,g,b;\n\n if (isNaN(h)) { h = 0; }\n if (isNaN(s)) { s = 0; }\n // normalize hue\n if (h > 360) { h -= 360; }\n if (h < 0) { h += 360; }\n h /= 360;\n if (h < 1/3) {\n b = (1-s)/3;\n r = (1+s*cos(TWOPI$1*h)/cos(PITHIRD-TWOPI$1*h))/3;\n g = 1 - (b+r);\n } else if (h < 2/3) {\n h -= 1/3;\n r = (1-s)/3;\n g = (1+s*cos(TWOPI$1*h)/cos(PITHIRD-TWOPI$1*h))/3;\n b = 1 - (r+g);\n } else {\n h -= 2/3;\n g = (1-s)/3;\n b = (1+s*cos(TWOPI$1*h)/cos(PITHIRD-TWOPI$1*h))/3;\n r = 1 - (g+b);\n }\n r = limit$1(i*r*3);\n g = limit$1(i*g*3);\n b = limit$1(i*b*3);\n return [r*255, g*255, b*255, args.length > 3 ? args[3] : 1];\n };\n\n var hsi2rgb_1 = hsi2rgb;\n\n var unpack$f = utils.unpack;\n var type$6 = utils.type;\n\n\n\n\n\n\n Color_1.prototype.hsi = function() {\n return rgb2hsi_1(this._rgb);\n };\n\n chroma_1.hsi = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hsi']) ));\n };\n\n input.format.hsi = hsi2rgb_1;\n\n input.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$f(args, 'hsi');\n if (type$6(args) === 'array' && args.length === 3) {\n return 'hsi';\n }\n }\n });\n\n var unpack$g = utils.unpack;\n var type$7 = utils.type;\n\n\n\n\n\n\n Color_1.prototype.hsl = function() {\n return rgb2hsl_1(this._rgb);\n };\n\n chroma_1.hsl = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hsl']) ));\n };\n\n input.format.hsl = hsl2rgb_1;\n\n input.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$g(args, 'hsl');\n if (type$7(args) === 'array' && args.length === 3) {\n return 'hsl';\n }\n }\n });\n\n var unpack$h = utils.unpack;\n var min$1 = Math.min;\n var max$1 = Math.max;\n\n /*\n * supported arguments:\n * - rgb2hsv(r,g,b)\n * - rgb2hsv([r,g,b])\n * - rgb2hsv({r,g,b})\n */\n var rgb2hsl$1 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$h(args, 'rgb');\n var r = args[0];\n var g = args[1];\n var b = args[2];\n var min_ = min$1(r, g, b);\n var max_ = max$1(r, g, b);\n var delta = max_ - min_;\n var h,s,v;\n v = max_ / 255.0;\n if (max_ === 0) {\n h = Number.NaN;\n s = 0;\n } else {\n s = delta / max_;\n if (r === max_) { h = (g - b) / delta; }\n if (g === max_) { h = 2+(b - r) / delta; }\n if (b === max_) { h = 4+(r - g) / delta; }\n h *= 60;\n if (h < 0) { h += 360; }\n }\n return [h, s, v]\n };\n\n var rgb2hsv = rgb2hsl$1;\n\n var unpack$i = utils.unpack;\n var floor$1 = Math.floor;\n\n var hsv2rgb = function () {\n var assign, assign$1, assign$2, assign$3, assign$4, assign$5;\n\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n args = unpack$i(args, 'hsv');\n var h = args[0];\n var s = args[1];\n var v = args[2];\n var r,g,b;\n v *= 255;\n if (s === 0) {\n r = g = b = v;\n } else {\n if (h === 360) { h = 0; }\n if (h > 360) { h -= 360; }\n if (h < 0) { h += 360; }\n h /= 60;\n\n var i = floor$1(h);\n var f = h - i;\n var p = v * (1 - s);\n var q = v * (1 - s * f);\n var t = v * (1 - s * (1 - f));\n\n switch (i) {\n case 0: (assign = [v, t, p], r = assign[0], g = assign[1], b = assign[2]); break\n case 1: (assign$1 = [q, v, p], r = assign$1[0], g = assign$1[1], b = assign$1[2]); break\n case 2: (assign$2 = [p, v, t], r = assign$2[0], g = assign$2[1], b = assign$2[2]); break\n case 3: (assign$3 = [p, q, v], r = assign$3[0], g = assign$3[1], b = assign$3[2]); break\n case 4: (assign$4 = [t, p, v], r = assign$4[0], g = assign$4[1], b = assign$4[2]); break\n case 5: (assign$5 = [v, p, q], r = assign$5[0], g = assign$5[1], b = assign$5[2]); break\n }\n }\n return [r,g,b,args.length > 3?args[3]:1];\n };\n\n var hsv2rgb_1 = hsv2rgb;\n\n var unpack$j = utils.unpack;\n var type$8 = utils.type;\n\n\n\n\n\n\n Color_1.prototype.hsv = function() {\n return rgb2hsv(this._rgb);\n };\n\n chroma_1.hsv = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hsv']) ));\n };\n\n input.format.hsv = hsv2rgb_1;\n\n input.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$j(args, 'hsv');\n if (type$8(args) === 'array' && args.length === 3) {\n return 'hsv';\n }\n }\n });\n\n var labConstants = {\n // Corresponds roughly to RGB brighter/darker\n Kn: 18,\n\n // D65 standard referent\n Xn: 0.950470,\n Yn: 1,\n Zn: 1.088830,\n\n t0: 0.137931034, // 4 / 29\n t1: 0.206896552, // 6 / 29\n t2: 0.12841855, // 3 * t1 * t1\n t3: 0.008856452, // t1 * t1 * t1\n };\n\n var unpack$k = utils.unpack;\n var pow = Math.pow;\n\n var rgb2lab = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$k(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n var ref$1 = rgb2xyz(r,g,b);\n var x = ref$1[0];\n var y = ref$1[1];\n var z = ref$1[2];\n var l = 116 * y - 16;\n return [l < 0 ? 0 : l, 500 * (x - y), 200 * (y - z)];\n };\n\n var rgb_xyz = function (r) {\n if ((r /= 255) <= 0.04045) { return r / 12.92; }\n return pow((r + 0.055) / 1.055, 2.4);\n };\n\n var xyz_lab = function (t) {\n if (t > labConstants.t3) { return pow(t, 1 / 3); }\n return t / labConstants.t2 + labConstants.t0;\n };\n\n var rgb2xyz = function (r,g,b) {\n r = rgb_xyz(r);\n g = rgb_xyz(g);\n b = rgb_xyz(b);\n var x = xyz_lab((0.4124564 * r + 0.3575761 * g + 0.1804375 * b) / labConstants.Xn);\n var y = xyz_lab((0.2126729 * r + 0.7151522 * g + 0.0721750 * b) / labConstants.Yn);\n var z = xyz_lab((0.0193339 * r + 0.1191920 * g + 0.9503041 * b) / labConstants.Zn);\n return [x,y,z];\n };\n\n var rgb2lab_1 = rgb2lab;\n\n var unpack$l = utils.unpack;\n var pow$1 = Math.pow;\n\n /*\n * L* [0..100]\n * a [-100..100]\n * b [-100..100]\n */\n var lab2rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$l(args, 'lab');\n var l = args[0];\n var a = args[1];\n var b = args[2];\n var x,y,z, r,g,b_;\n\n y = (l + 16) / 116;\n x = isNaN(a) ? y : y + a / 500;\n z = isNaN(b) ? y : y - b / 200;\n\n y = labConstants.Yn * lab_xyz(y);\n x = labConstants.Xn * lab_xyz(x);\n z = labConstants.Zn * lab_xyz(z);\n\n r = xyz_rgb(3.2404542 * x - 1.5371385 * y - 0.4985314 * z); // D65 -> sRGB\n g = xyz_rgb(-0.9692660 * x + 1.8760108 * y + 0.0415560 * z);\n b_ = xyz_rgb(0.0556434 * x - 0.2040259 * y + 1.0572252 * z);\n\n return [r,g,b_,args.length > 3 ? args[3] : 1];\n };\n\n var xyz_rgb = function (r) {\n return 255 * (r <= 0.00304 ? 12.92 * r : 1.055 * pow$1(r, 1 / 2.4) - 0.055)\n };\n\n var lab_xyz = function (t) {\n return t > labConstants.t1 ? t * t * t : labConstants.t2 * (t - labConstants.t0)\n };\n\n var lab2rgb_1 = lab2rgb;\n\n var unpack$m = utils.unpack;\n var type$9 = utils.type;\n\n\n\n\n\n\n Color_1.prototype.lab = function() {\n return rgb2lab_1(this._rgb);\n };\n\n chroma_1.lab = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['lab']) ));\n };\n\n input.format.lab = lab2rgb_1;\n\n input.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$m(args, 'lab');\n if (type$9(args) === 'array' && args.length === 3) {\n return 'lab';\n }\n }\n });\n\n var unpack$n = utils.unpack;\n var RAD2DEG = utils.RAD2DEG;\n var sqrt$1 = Math.sqrt;\n var atan2 = Math.atan2;\n var round$4 = Math.round;\n\n var lab2lch = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$n(args, 'lab');\n var l = ref[0];\n var a = ref[1];\n var b = ref[2];\n var c = sqrt$1(a * a + b * b);\n var h = (atan2(b, a) * RAD2DEG + 360) % 360;\n if (round$4(c*10000) === 0) { h = Number.NaN; }\n return [l, c, h];\n };\n\n var lab2lch_1 = lab2lch;\n\n var unpack$o = utils.unpack;\n\n\n\n var rgb2lch = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$o(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n var ref$1 = rgb2lab_1(r,g,b);\n var l = ref$1[0];\n var a = ref$1[1];\n var b_ = ref$1[2];\n return lab2lch_1(l,a,b_);\n };\n\n var rgb2lch_1 = rgb2lch;\n\n var unpack$p = utils.unpack;\n var DEG2RAD = utils.DEG2RAD;\n var sin = Math.sin;\n var cos$1 = Math.cos;\n\n var lch2lab = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n /*\n Convert from a qualitative parameter h and a quantitative parameter l to a 24-bit pixel.\n These formulas were invented by David Dalrymple to obtain maximum contrast without going\n out of gamut if the parameters are in the range 0-1.\n\n A saturation multiplier was added by Gregor Aisch\n */\n var ref = unpack$p(args, 'lch');\n var l = ref[0];\n var c = ref[1];\n var h = ref[2];\n if (isNaN(h)) { h = 0; }\n h = h * DEG2RAD;\n return [l, cos$1(h) * c, sin(h) * c]\n };\n\n var lch2lab_1 = lch2lab;\n\n var unpack$q = utils.unpack;\n\n\n\n var lch2rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$q(args, 'lch');\n var l = args[0];\n var c = args[1];\n var h = args[2];\n var ref = lch2lab_1 (l,c,h);\n var L = ref[0];\n var a = ref[1];\n var b_ = ref[2];\n var ref$1 = lab2rgb_1 (L,a,b_);\n var r = ref$1[0];\n var g = ref$1[1];\n var b = ref$1[2];\n return [r, g, b, args.length > 3 ? args[3] : 1];\n };\n\n var lch2rgb_1 = lch2rgb;\n\n var unpack$r = utils.unpack;\n\n\n var hcl2rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var hcl = unpack$r(args, 'hcl').reverse();\n return lch2rgb_1.apply(void 0, hcl);\n };\n\n var hcl2rgb_1 = hcl2rgb;\n\n var unpack$s = utils.unpack;\n var type$a = utils.type;\n\n\n\n\n\n\n Color_1.prototype.lch = function() { return rgb2lch_1(this._rgb); };\n Color_1.prototype.hcl = function() { return rgb2lch_1(this._rgb).reverse(); };\n\n chroma_1.lch = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['lch']) ));\n };\n chroma_1.hcl = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hcl']) ));\n };\n\n input.format.lch = lch2rgb_1;\n input.format.hcl = hcl2rgb_1;\n\n ['lch','hcl'].forEach(function (m) { return input.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$s(args, m);\n if (type$a(args) === 'array' && args.length === 3) {\n return m;\n }\n }\n }); });\n\n /**\n \tX11 color names\n\n \thttp://www.w3.org/TR/css3-color/#svg-color\n */\n\n var w3cx11 = {\n aliceblue: '#f0f8ff',\n antiquewhite: '#faebd7',\n aqua: '#00ffff',\n aquamarine: '#7fffd4',\n azure: '#f0ffff',\n beige: '#f5f5dc',\n bisque: '#ffe4c4',\n black: '#000000',\n blanchedalmond: '#ffebcd',\n blue: '#0000ff',\n blueviolet: '#8a2be2',\n brown: '#a52a2a',\n burlywood: '#deb887',\n cadetblue: '#5f9ea0',\n chartreuse: '#7fff00',\n chocolate: '#d2691e',\n coral: '#ff7f50',\n cornflower: '#6495ed',\n cornflowerblue: '#6495ed',\n cornsilk: '#fff8dc',\n crimson: '#dc143c',\n cyan: '#00ffff',\n darkblue: '#00008b',\n darkcyan: '#008b8b',\n darkgoldenrod: '#b8860b',\n darkgray: '#a9a9a9',\n darkgreen: '#006400',\n darkgrey: '#a9a9a9',\n darkkhaki: '#bdb76b',\n darkmagenta: '#8b008b',\n darkolivegreen: '#556b2f',\n darkorange: '#ff8c00',\n darkorchid: '#9932cc',\n darkred: '#8b0000',\n darksalmon: '#e9967a',\n darkseagreen: '#8fbc8f',\n darkslateblue: '#483d8b',\n darkslategray: '#2f4f4f',\n darkslategrey: '#2f4f4f',\n darkturquoise: '#00ced1',\n darkviolet: '#9400d3',\n deeppink: '#ff1493',\n deepskyblue: '#00bfff',\n dimgray: '#696969',\n dimgrey: '#696969',\n dodgerblue: '#1e90ff',\n firebrick: '#b22222',\n floralwhite: '#fffaf0',\n forestgreen: '#228b22',\n fuchsia: '#ff00ff',\n gainsboro: '#dcdcdc',\n ghostwhite: '#f8f8ff',\n gold: '#ffd700',\n goldenrod: '#daa520',\n gray: '#808080',\n green: '#008000',\n greenyellow: '#adff2f',\n grey: '#808080',\n honeydew: '#f0fff0',\n hotpink: '#ff69b4',\n indianred: '#cd5c5c',\n indigo: '#4b0082',\n ivory: '#fffff0',\n khaki: '#f0e68c',\n laserlemon: '#ffff54',\n lavender: '#e6e6fa',\n lavenderblush: '#fff0f5',\n lawngreen: '#7cfc00',\n lemonchiffon: '#fffacd',\n lightblue: '#add8e6',\n lightcoral: '#f08080',\n lightcyan: '#e0ffff',\n lightgoldenrod: '#fafad2',\n lightgoldenrodyellow: '#fafad2',\n lightgray: '#d3d3d3',\n lightgreen: '#90ee90',\n lightgrey: '#d3d3d3',\n lightpink: '#ffb6c1',\n lightsalmon: '#ffa07a',\n lightseagreen: '#20b2aa',\n lightskyblue: '#87cefa',\n lightslategray: '#778899',\n lightslategrey: '#778899',\n lightsteelblue: '#b0c4de',\n lightyellow: '#ffffe0',\n lime: '#00ff00',\n limegreen: '#32cd32',\n linen: '#faf0e6',\n magenta: '#ff00ff',\n maroon: '#800000',\n maroon2: '#7f0000',\n maroon3: '#b03060',\n mediumaquamarine: '#66cdaa',\n mediumblue: '#0000cd',\n mediumorchid: '#ba55d3',\n mediumpurple: '#9370db',\n mediumseagreen: '#3cb371',\n mediumslateblue: '#7b68ee',\n mediumspringgreen: '#00fa9a',\n mediumturquoise: '#48d1cc',\n mediumvioletred: '#c71585',\n midnightblue: '#191970',\n mintcream: '#f5fffa',\n mistyrose: '#ffe4e1',\n moccasin: '#ffe4b5',\n navajowhite: '#ffdead',\n navy: '#000080',\n oldlace: '#fdf5e6',\n olive: '#808000',\n olivedrab: '#6b8e23',\n orange: '#ffa500',\n orangered: '#ff4500',\n orchid: '#da70d6',\n palegoldenrod: '#eee8aa',\n palegreen: '#98fb98',\n paleturquoise: '#afeeee',\n palevioletred: '#db7093',\n papayawhip: '#ffefd5',\n peachpuff: '#ffdab9',\n peru: '#cd853f',\n pink: '#ffc0cb',\n plum: '#dda0dd',\n powderblue: '#b0e0e6',\n purple: '#800080',\n purple2: '#7f007f',\n purple3: '#a020f0',\n rebeccapurple: '#663399',\n red: '#ff0000',\n rosybrown: '#bc8f8f',\n royalblue: '#4169e1',\n saddlebrown: '#8b4513',\n salmon: '#fa8072',\n sandybrown: '#f4a460',\n seagreen: '#2e8b57',\n seashell: '#fff5ee',\n sienna: '#a0522d',\n silver: '#c0c0c0',\n skyblue: '#87ceeb',\n slateblue: '#6a5acd',\n slategray: '#708090',\n slategrey: '#708090',\n snow: '#fffafa',\n springgreen: '#00ff7f',\n steelblue: '#4682b4',\n tan: '#d2b48c',\n teal: '#008080',\n thistle: '#d8bfd8',\n tomato: '#ff6347',\n turquoise: '#40e0d0',\n violet: '#ee82ee',\n wheat: '#f5deb3',\n white: '#ffffff',\n whitesmoke: '#f5f5f5',\n yellow: '#ffff00',\n yellowgreen: '#9acd32'\n };\n\n var w3cx11_1 = w3cx11;\n\n var type$b = utils.type;\n\n\n\n\n\n Color_1.prototype.name = function() {\n var hex = rgb2hex_1(this._rgb, 'rgb');\n for (var i = 0, list = Object.keys(w3cx11_1); i < list.length; i += 1) {\n var n = list[i];\n\n if (w3cx11_1[n] === hex) { return n.toLowerCase(); }\n }\n return hex;\n };\n\n input.format.named = function (name) {\n name = name.toLowerCase();\n if (w3cx11_1[name]) { return hex2rgb_1(w3cx11_1[name]); }\n throw new Error('unknown color name: '+name);\n };\n\n input.autodetect.push({\n p: 5,\n test: function (h) {\n var rest = [], len = arguments.length - 1;\n while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];\n\n if (!rest.length && type$b(h) === 'string' && w3cx11_1[h.toLowerCase()]) {\n return 'named';\n }\n }\n });\n\n var unpack$t = utils.unpack;\n\n var rgb2num = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$t(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n return (r << 16) + (g << 8) + b;\n };\n\n var rgb2num_1 = rgb2num;\n\n var type$c = utils.type;\n\n var num2rgb = function (num) {\n if (type$c(num) == \"number\" && num >= 0 && num <= 0xFFFFFF) {\n var r = num >> 16;\n var g = (num >> 8) & 0xFF;\n var b = num & 0xFF;\n return [r,g,b,1];\n }\n throw new Error(\"unknown num color: \"+num);\n };\n\n var num2rgb_1 = num2rgb;\n\n var type$d = utils.type;\n\n\n\n Color_1.prototype.num = function() {\n return rgb2num_1(this._rgb);\n };\n\n chroma_1.num = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['num']) ));\n };\n\n input.format.num = num2rgb_1;\n\n input.autodetect.push({\n p: 5,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n if (args.length === 1 && type$d(args[0]) === 'number' && args[0] >= 0 && args[0] <= 0xFFFFFF) {\n return 'num';\n }\n }\n });\n\n var unpack$u = utils.unpack;\n var type$e = utils.type;\n var round$5 = Math.round;\n\n Color_1.prototype.rgb = function(rnd) {\n if ( rnd === void 0 ) rnd=true;\n\n if (rnd === false) { return this._rgb.slice(0,3); }\n return this._rgb.slice(0,3).map(round$5);\n };\n\n Color_1.prototype.rgba = function(rnd) {\n if ( rnd === void 0 ) rnd=true;\n\n return this._rgb.slice(0,4).map(function (v,i) {\n return i<3 ? (rnd === false ? v : round$5(v)) : v;\n });\n };\n\n chroma_1.rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['rgb']) ));\n };\n\n input.format.rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var rgba = unpack$u(args, 'rgba');\n if (rgba[3] === undefined) { rgba[3] = 1; }\n return rgba;\n };\n\n input.autodetect.push({\n p: 3,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$u(args, 'rgba');\n if (type$e(args) === 'array' && (args.length === 3 ||\n args.length === 4 && type$e(args[3]) == 'number' && args[3] >= 0 && args[3] <= 1)) {\n return 'rgb';\n }\n }\n });\n\n /*\n * Based on implementation by Neil Bartlett\n * https://github.com/neilbartlett/color-temperature\n */\n\n var log = Math.log;\n\n var temperature2rgb = function (kelvin) {\n var temp = kelvin / 100;\n var r,g,b;\n if (temp < 66) {\n r = 255;\n g = -155.25485562709179 - 0.44596950469579133 * (g = temp-2) + 104.49216199393888 * log(g);\n b = temp < 20 ? 0 : -254.76935184120902 + 0.8274096064007395 * (b = temp-10) + 115.67994401066147 * log(b);\n } else {\n r = 351.97690566805693 + 0.114206453784165 * (r = temp-55) - 40.25366309332127 * log(r);\n g = 325.4494125711974 + 0.07943456536662342 * (g = temp-50) - 28.0852963507957 * log(g);\n b = 255;\n }\n return [r,g,b,1];\n };\n\n var temperature2rgb_1 = temperature2rgb;\n\n /*\n * Based on implementation by Neil Bartlett\n * https://github.com/neilbartlett/color-temperature\n **/\n\n\n var unpack$v = utils.unpack;\n var round$6 = Math.round;\n\n var rgb2temperature = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var rgb = unpack$v(args, 'rgb');\n var r = rgb[0], b = rgb[2];\n var minTemp = 1000;\n var maxTemp = 40000;\n var eps = 0.4;\n var temp;\n while (maxTemp - minTemp > eps) {\n temp = (maxTemp + minTemp) * 0.5;\n var rgb$1 = temperature2rgb_1(temp);\n if ((rgb$1[2] / rgb$1[0]) >= (b / r)) {\n maxTemp = temp;\n } else {\n minTemp = temp;\n }\n }\n return round$6(temp);\n };\n\n var rgb2temperature_1 = rgb2temperature;\n\n Color_1.prototype.temp =\n Color_1.prototype.kelvin =\n Color_1.prototype.temperature = function() {\n return rgb2temperature_1(this._rgb);\n };\n\n chroma_1.temp =\n chroma_1.kelvin =\n chroma_1.temperature = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['temp']) ));\n };\n\n input.format.temp =\n input.format.kelvin =\n input.format.temperature = temperature2rgb_1;\n\n var type$f = utils.type;\n\n Color_1.prototype.alpha = function(a, mutate) {\n if ( mutate === void 0 ) mutate=false;\n\n if (a !== undefined && type$f(a) === 'number') {\n if (mutate) {\n this._rgb[3] = a;\n return this;\n }\n return new Color_1([this._rgb[0], this._rgb[1], this._rgb[2], a], 'rgb');\n }\n return this._rgb[3];\n };\n\n Color_1.prototype.clipped = function() {\n return this._rgb._clipped || false;\n };\n\n Color_1.prototype.darken = function(amount) {\n \tif ( amount === void 0 ) amount=1;\n\n \tvar me = this;\n \tvar lab = me.lab();\n \tlab[0] -= labConstants.Kn * amount;\n \treturn new Color_1(lab, 'lab').alpha(me.alpha(), true);\n };\n\n Color_1.prototype.brighten = function(amount) {\n \tif ( amount === void 0 ) amount=1;\n\n \treturn this.darken(-amount);\n };\n\n Color_1.prototype.darker = Color_1.prototype.darken;\n Color_1.prototype.brighter = Color_1.prototype.brighten;\n\n Color_1.prototype.get = function(mc) {\n var ref = mc.split('.');\n var mode = ref[0];\n var channel = ref[1];\n var src = this[mode]();\n if (channel) {\n var i = mode.indexOf(channel);\n if (i > -1) { return src[i]; }\n throw new Error((\"unknown channel \" + channel + \" in mode \" + mode));\n } else {\n return src;\n }\n };\n\n var type$g = utils.type;\n var pow$2 = Math.pow;\n\n var EPS = 1e-7;\n var MAX_ITER = 20;\n\n Color_1.prototype.luminance = function(lum) {\n if (lum !== undefined && type$g(lum) === 'number') {\n if (lum === 0) {\n // return pure black\n return new Color_1([0,0,0,this._rgb[3]], 'rgb');\n }\n if (lum === 1) {\n // return pure white\n return new Color_1([255,255,255,this._rgb[3]], 'rgb');\n }\n // compute new color using...\n var cur_lum = this.luminance();\n var mode = 'rgb';\n var max_iter = MAX_ITER;\n\n var test = function (low, high) {\n var mid = low.interpolate(high, 0.5, mode);\n var lm = mid.luminance();\n if (Math.abs(lum - lm) < EPS || !max_iter--) {\n // close enough\n return mid;\n }\n return lm > lum ? test(low, mid) : test(mid, high);\n };\n\n var rgb = (cur_lum > lum ? test(new Color_1([0,0,0]), this) : test(this, new Color_1([255,255,255]))).rgb();\n return new Color_1(rgb.concat( [this._rgb[3]]));\n }\n return rgb2luminance.apply(void 0, (this._rgb).slice(0,3));\n };\n\n\n var rgb2luminance = function (r,g,b) {\n // relative luminance\n // see http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef\n r = luminance_x(r);\n g = luminance_x(g);\n b = luminance_x(b);\n return 0.2126 * r + 0.7152 * g + 0.0722 * b;\n };\n\n var luminance_x = function (x) {\n x /= 255;\n return x <= 0.03928 ? x/12.92 : pow$2((x+0.055)/1.055, 2.4);\n };\n\n var interpolator = {};\n\n var type$h = utils.type;\n\n\n var mix = function (col1, col2, f) {\n if ( f === void 0 ) f=0.5;\n var rest = [], len = arguments.length - 3;\n while ( len-- > 0 ) rest[ len ] = arguments[ len + 3 ];\n\n var mode = rest[0] || 'lrgb';\n if (!interpolator[mode] && !rest.length) {\n // fall back to the first supported mode\n mode = Object.keys(interpolator)[0];\n }\n if (!interpolator[mode]) {\n throw new Error((\"interpolation mode \" + mode + \" is not defined\"));\n }\n if (type$h(col1) !== 'object') { col1 = new Color_1(col1); }\n if (type$h(col2) !== 'object') { col2 = new Color_1(col2); }\n return interpolator[mode](col1, col2, f)\n .alpha(col1.alpha() + f * (col2.alpha() - col1.alpha()));\n };\n\n Color_1.prototype.mix =\n Color_1.prototype.interpolate = function(col2, f) {\n \tif ( f === void 0 ) f=0.5;\n \tvar rest = [], len = arguments.length - 2;\n \twhile ( len-- > 0 ) rest[ len ] = arguments[ len + 2 ];\n\n \treturn mix.apply(void 0, [ this, col2, f ].concat( rest ));\n };\n\n Color_1.prototype.premultiply = function(mutate) {\n \tif ( mutate === void 0 ) mutate=false;\n\n \tvar rgb = this._rgb;\n \tvar a = rgb[3];\n \tif (mutate) {\n \t\tthis._rgb = [rgb[0]*a, rgb[1]*a, rgb[2]*a, a];\n \t\treturn this;\n \t} else {\n \t\treturn new Color_1([rgb[0]*a, rgb[1]*a, rgb[2]*a, a], 'rgb');\n \t}\n };\n\n Color_1.prototype.saturate = function(amount) {\n \tif ( amount === void 0 ) amount=1;\n\n \tvar me = this;\n \tvar lch = me.lch();\n \tlch[1] += labConstants.Kn * amount;\n \tif (lch[1] < 0) { lch[1] = 0; }\n \treturn new Color_1(lch, 'lch').alpha(me.alpha(), true);\n };\n\n Color_1.prototype.desaturate = function(amount) {\n \tif ( amount === void 0 ) amount=1;\n\n \treturn this.saturate(-amount);\n };\n\n var type$i = utils.type;\n\n Color_1.prototype.set = function(mc, value, mutate) {\n if ( mutate === void 0 ) mutate=false;\n\n var ref = mc.split('.');\n var mode = ref[0];\n var channel = ref[1];\n var src = this[mode]();\n if (channel) {\n var i = mode.indexOf(channel);\n if (i > -1) {\n if (type$i(value) == 'string') {\n switch(value.charAt(0)) {\n case '+': src[i] += +value; break;\n case '-': src[i] += +value; break;\n case '*': src[i] *= +(value.substr(1)); break;\n case '/': src[i] /= +(value.substr(1)); break;\n default: src[i] = +value;\n }\n } else if (type$i(value) === 'number') {\n src[i] = value;\n } else {\n throw new Error(\"unsupported value for Color.set\");\n }\n var out = new Color_1(src, mode);\n if (mutate) {\n this._rgb = out._rgb;\n return this;\n }\n return out;\n }\n throw new Error((\"unknown channel \" + channel + \" in mode \" + mode));\n } else {\n return src;\n }\n };\n\n var rgb$1 = function (col1, col2, f) {\n var xyz0 = col1._rgb;\n var xyz1 = col2._rgb;\n return new Color_1(\n xyz0[0] + f * (xyz1[0]-xyz0[0]),\n xyz0[1] + f * (xyz1[1]-xyz0[1]),\n xyz0[2] + f * (xyz1[2]-xyz0[2]),\n 'rgb'\n )\n };\n\n // register interpolator\n interpolator.rgb = rgb$1;\n\n var sqrt$2 = Math.sqrt;\n var pow$3 = Math.pow;\n\n var lrgb = function (col1, col2, f) {\n var ref = col1._rgb;\n var x1 = ref[0];\n var y1 = ref[1];\n var z1 = ref[2];\n var ref$1 = col2._rgb;\n var x2 = ref$1[0];\n var y2 = ref$1[1];\n var z2 = ref$1[2];\n return new Color_1(\n sqrt$2(pow$3(x1,2) * (1-f) + pow$3(x2,2) * f),\n sqrt$2(pow$3(y1,2) * (1-f) + pow$3(y2,2) * f),\n sqrt$2(pow$3(z1,2) * (1-f) + pow$3(z2,2) * f),\n 'rgb'\n )\n };\n\n // register interpolator\n interpolator.lrgb = lrgb;\n\n var lab$1 = function (col1, col2, f) {\n var xyz0 = col1.lab();\n var xyz1 = col2.lab();\n return new Color_1(\n xyz0[0] + f * (xyz1[0]-xyz0[0]),\n xyz0[1] + f * (xyz1[1]-xyz0[1]),\n xyz0[2] + f * (xyz1[2]-xyz0[2]),\n 'lab'\n )\n };\n\n // register interpolator\n interpolator.lab = lab$1;\n\n var _hsx = function (col1, col2, f, m) {\n var assign, assign$1;\n\n var xyz0, xyz1;\n if (m === 'hsl') {\n xyz0 = col1.hsl();\n xyz1 = col2.hsl();\n } else if (m === 'hsv') {\n xyz0 = col1.hsv();\n xyz1 = col2.hsv();\n } else if (m === 'hcg') {\n xyz0 = col1.hcg();\n xyz1 = col2.hcg();\n } else if (m === 'hsi') {\n xyz0 = col1.hsi();\n xyz1 = col2.hsi();\n } else if (m === 'lch' || m === 'hcl') {\n m = 'hcl';\n xyz0 = col1.hcl();\n xyz1 = col2.hcl();\n }\n\n var hue0, hue1, sat0, sat1, lbv0, lbv1;\n if (m.substr(0, 1) === 'h') {\n (assign = xyz0, hue0 = assign[0], sat0 = assign[1], lbv0 = assign[2]);\n (assign$1 = xyz1, hue1 = assign$1[0], sat1 = assign$1[1], lbv1 = assign$1[2]);\n }\n\n var sat, hue, lbv, dh;\n\n if (!isNaN(hue0) && !isNaN(hue1)) {\n // both colors have hue\n if (hue1 > hue0 && hue1 - hue0 > 180) {\n dh = hue1-(hue0+360);\n } else if (hue1 < hue0 && hue0 - hue1 > 180) {\n dh = hue1+360-hue0;\n } else{\n dh = hue1 - hue0;\n }\n hue = hue0 + f * dh;\n } else if (!isNaN(hue0)) {\n hue = hue0;\n if ((lbv1 == 1 || lbv1 == 0) && m != 'hsv') { sat = sat0; }\n } else if (!isNaN(hue1)) {\n hue = hue1;\n if ((lbv0 == 1 || lbv0 == 0) && m != 'hsv') { sat = sat1; }\n } else {\n hue = Number.NaN;\n }\n\n if (sat === undefined) { sat = sat0 + f * (sat1 - sat0); }\n lbv = lbv0 + f * (lbv1-lbv0);\n return new Color_1([hue, sat, lbv], m);\n };\n\n var lch$1 = function (col1, col2, f) {\n \treturn _hsx(col1, col2, f, 'lch');\n };\n\n // register interpolator\n interpolator.lch = lch$1;\n interpolator.hcl = lch$1;\n\n var num$1 = function (col1, col2, f) {\n var c1 = col1.num();\n var c2 = col2.num();\n return new Color_1(c1 + f * (c2-c1), 'num')\n };\n\n // register interpolator\n interpolator.num = num$1;\n\n var hcg$1 = function (col1, col2, f) {\n \treturn _hsx(col1, col2, f, 'hcg');\n };\n\n // register interpolator\n interpolator.hcg = hcg$1;\n\n var hsi$1 = function (col1, col2, f) {\n \treturn _hsx(col1, col2, f, 'hsi');\n };\n\n // register interpolator\n interpolator.hsi = hsi$1;\n\n var hsl$1 = function (col1, col2, f) {\n \treturn _hsx(col1, col2, f, 'hsl');\n };\n\n // register interpolator\n interpolator.hsl = hsl$1;\n\n var hsv$1 = function (col1, col2, f) {\n \treturn _hsx(col1, col2, f, 'hsv');\n };\n\n // register interpolator\n interpolator.hsv = hsv$1;\n\n var clip_rgb$2 = utils.clip_rgb;\n var pow$4 = Math.pow;\n var sqrt$3 = Math.sqrt;\n var PI$1 = Math.PI;\n var cos$2 = Math.cos;\n var sin$1 = Math.sin;\n var atan2$1 = Math.atan2;\n\n var average = function (colors, mode, weights) {\n if ( mode === void 0 ) mode='lrgb';\n if ( weights === void 0 ) weights=null;\n\n var l = colors.length;\n if (!weights) { weights = Array.from(new Array(l)).map(function () { return 1; }); }\n // normalize weights\n var k = l / weights.reduce(function(a, b) { return a + b; });\n weights.forEach(function (w,i) { weights[i] *= k; });\n // convert colors to Color objects\n colors = colors.map(function (c) { return new Color_1(c); });\n if (mode === 'lrgb') {\n return _average_lrgb(colors, weights)\n }\n var first = colors.shift();\n var xyz = first.get(mode);\n var cnt = [];\n var dx = 0;\n var dy = 0;\n // initial color\n for (var i=0; i= 360) { A$1 -= 360; }\n xyz[i$1] = A$1;\n } else {\n xyz[i$1] = xyz[i$1]/cnt[i$1];\n }\n }\n alpha /= l;\n return (new Color_1(xyz, mode)).alpha(alpha > 0.99999 ? 1 : alpha, true);\n };\n\n\n var _average_lrgb = function (colors, weights) {\n var l = colors.length;\n var xyz = [0,0,0,0];\n for (var i=0; i < colors.length; i++) {\n var col = colors[i];\n var f = weights[i] / l;\n var rgb = col._rgb;\n xyz[0] += pow$4(rgb[0],2) * f;\n xyz[1] += pow$4(rgb[1],2) * f;\n xyz[2] += pow$4(rgb[2],2) * f;\n xyz[3] += rgb[3] * f;\n }\n xyz[0] = sqrt$3(xyz[0]);\n xyz[1] = sqrt$3(xyz[1]);\n xyz[2] = sqrt$3(xyz[2]);\n if (xyz[3] > 0.9999999) { xyz[3] = 1; }\n return new Color_1(clip_rgb$2(xyz));\n };\n\n // minimal multi-purpose interface\n\n // @requires utils color analyze\n\n\n var type$j = utils.type;\n\n var pow$5 = Math.pow;\n\n var scale = function(colors) {\n\n // constructor\n var _mode = 'rgb';\n var _nacol = chroma_1('#ccc');\n var _spread = 0;\n // const _fixed = false;\n var _domain = [0, 1];\n var _pos = [];\n var _padding = [0,0];\n var _classes = false;\n var _colors = [];\n var _out = false;\n var _min = 0;\n var _max = 1;\n var _correctLightness = false;\n var _colorCache = {};\n var _useCache = true;\n var _gamma = 1;\n\n // private methods\n\n var setColors = function(colors) {\n colors = colors || ['#fff', '#000'];\n if (colors && type$j(colors) === 'string' && chroma_1.brewer &&\n chroma_1.brewer[colors.toLowerCase()]) {\n colors = chroma_1.brewer[colors.toLowerCase()];\n }\n if (type$j(colors) === 'array') {\n // handle single color\n if (colors.length === 1) {\n colors = [colors[0], colors[0]];\n }\n // make a copy of the colors\n colors = colors.slice(0);\n // convert to chroma classes\n for (var c=0; c= _classes[i]) {\n i++;\n }\n return i-1;\n }\n return 0;\n };\n\n var tMapLightness = function (t) { return t; };\n var tMapDomain = function (t) { return t; };\n\n // const classifyValue = function(value) {\n // let val = value;\n // if (_classes.length > 2) {\n // const n = _classes.length-1;\n // const i = getClass(value);\n // const minc = _classes[0] + ((_classes[1]-_classes[0]) * (0 + (_spread * 0.5))); // center of 1st class\n // const maxc = _classes[n-1] + ((_classes[n]-_classes[n-1]) * (1 - (_spread * 0.5))); // center of last class\n // val = _min + ((((_classes[i] + ((_classes[i+1] - _classes[i]) * 0.5)) - minc) / (maxc-minc)) * (_max - _min));\n // }\n // return val;\n // };\n\n var getColor = function(val, bypassMap) {\n var col, t;\n if (bypassMap == null) { bypassMap = false; }\n if (isNaN(val) || (val === null)) { return _nacol; }\n if (!bypassMap) {\n if (_classes && (_classes.length > 2)) {\n // find the class\n var c = getClass(val);\n t = c / (_classes.length-2);\n } else if (_max !== _min) {\n // just interpolate between min/max\n t = (val - _min) / (_max - _min);\n } else {\n t = 1;\n }\n } else {\n t = val;\n }\n\n // domain map\n t = tMapDomain(t);\n\n if (!bypassMap) {\n t = tMapLightness(t); // lightness correction\n }\n\n if (_gamma !== 1) { t = pow$5(t, _gamma); }\n\n t = _padding[0] + (t * (1 - _padding[0] - _padding[1]));\n\n t = Math.min(1, Math.max(0, t));\n\n var k = Math.floor(t * 10000);\n\n if (_useCache && _colorCache[k]) {\n col = _colorCache[k];\n } else {\n if (type$j(_colors) === 'array') {\n //for i in [0.._pos.length-1]\n for (var i=0; i<_pos.length; i++) {\n var p = _pos[i];\n if (t <= p) {\n col = _colors[i];\n break;\n }\n if ((t >= p) && (i === (_pos.length-1))) {\n col = _colors[i];\n break;\n }\n if (t > p && t < _pos[i+1]) {\n t = (t-p)/(_pos[i+1]-p);\n col = chroma_1.interpolate(_colors[i], _colors[i+1], t, _mode);\n break;\n }\n }\n } else if (type$j(_colors) === 'function') {\n col = _colors(t);\n }\n if (_useCache) { _colorCache[k] = col; }\n }\n return col;\n };\n\n var resetCache = function () { return _colorCache = {}; };\n\n setColors(colors);\n\n // public interface\n\n var f = function(v) {\n var c = chroma_1(getColor(v));\n if (_out && c[_out]) { return c[_out](); } else { return c; }\n };\n\n f.classes = function(classes) {\n if (classes != null) {\n if (type$j(classes) === 'array') {\n _classes = classes;\n _domain = [classes[0], classes[classes.length-1]];\n } else {\n var d = chroma_1.analyze(_domain);\n if (classes === 0) {\n _classes = [d.min, d.max];\n } else {\n _classes = chroma_1.limits(d, 'e', classes);\n }\n }\n return f;\n }\n return _classes;\n };\n\n\n f.domain = function(domain) {\n if (!arguments.length) {\n return _domain;\n }\n _min = domain[0];\n _max = domain[domain.length-1];\n _pos = [];\n var k = _colors.length;\n if ((domain.length === k) && (_min !== _max)) {\n // update positions\n for (var i = 0, list = Array.from(domain); i < list.length; i += 1) {\n var d = list[i];\n\n _pos.push((d-_min) / (_max-_min));\n }\n } else {\n for (var c=0; c 2) {\n // set domain map\n var tOut = domain.map(function (d,i) { return i/(domain.length-1); });\n var tBreaks = domain.map(function (d) { return (d - _min) / (_max - _min); });\n if (!tBreaks.every(function (val, i) { return tOut[i] === val; })) {\n tMapDomain = function (t) {\n if (t <= 0 || t >= 1) { return t; }\n var i = 0;\n while (t >= tBreaks[i+1]) { i++; }\n var f = (t - tBreaks[i]) / (tBreaks[i+1] - tBreaks[i]);\n var out = tOut[i] + f * (tOut[i+1] - tOut[i]);\n return out;\n };\n }\n\n }\n }\n _domain = [_min, _max];\n return f;\n };\n\n f.mode = function(_m) {\n if (!arguments.length) {\n return _mode;\n }\n _mode = _m;\n resetCache();\n return f;\n };\n\n f.range = function(colors, _pos) {\n setColors(colors, _pos);\n return f;\n };\n\n f.out = function(_o) {\n _out = _o;\n return f;\n };\n\n f.spread = function(val) {\n if (!arguments.length) {\n return _spread;\n }\n _spread = val;\n return f;\n };\n\n f.correctLightness = function(v) {\n if (v == null) { v = true; }\n _correctLightness = v;\n resetCache();\n if (_correctLightness) {\n tMapLightness = function(t) {\n var L0 = getColor(0, true).lab()[0];\n var L1 = getColor(1, true).lab()[0];\n var pol = L0 > L1;\n var L_actual = getColor(t, true).lab()[0];\n var L_ideal = L0 + ((L1 - L0) * t);\n var L_diff = L_actual - L_ideal;\n var t0 = 0;\n var t1 = 1;\n var max_iter = 20;\n while ((Math.abs(L_diff) > 1e-2) && (max_iter-- > 0)) {\n (function() {\n if (pol) { L_diff *= -1; }\n if (L_diff < 0) {\n t0 = t;\n t += (t1 - t) * 0.5;\n } else {\n t1 = t;\n t += (t0 - t) * 0.5;\n }\n L_actual = getColor(t, true).lab()[0];\n return L_diff = L_actual - L_ideal;\n })();\n }\n return t;\n };\n } else {\n tMapLightness = function (t) { return t; };\n }\n return f;\n };\n\n f.padding = function(p) {\n if (p != null) {\n if (type$j(p) === 'number') {\n p = [p,p];\n }\n _padding = p;\n return f;\n } else {\n return _padding;\n }\n };\n\n f.colors = function(numColors, out) {\n // If no arguments are given, return the original colors that were provided\n if (arguments.length < 2) { out = 'hex'; }\n var result = [];\n\n if (arguments.length === 0) {\n result = _colors.slice(0);\n\n } else if (numColors === 1) {\n result = [f(0.5)];\n\n } else if (numColors > 1) {\n var dm = _domain[0];\n var dd = _domain[1] - dm;\n result = __range__(0, numColors, false).map(function (i) { return f( dm + ((i/(numColors-1)) * dd) ); });\n\n } else { // returns all colors based on the defined classes\n colors = [];\n var samples = [];\n if (_classes && (_classes.length > 2)) {\n for (var i = 1, end = _classes.length, asc = 1 <= end; asc ? i < end : i > end; asc ? i++ : i--) {\n samples.push((_classes[i-1]+_classes[i])*0.5);\n }\n } else {\n samples = _domain;\n }\n result = samples.map(function (v) { return f(v); });\n }\n\n if (chroma_1[out]) {\n result = result.map(function (c) { return c[out](); });\n }\n return result;\n };\n\n f.cache = function(c) {\n if (c != null) {\n _useCache = c;\n return f;\n } else {\n return _useCache;\n }\n };\n\n f.gamma = function(g) {\n if (g != null) {\n _gamma = g;\n return f;\n } else {\n return _gamma;\n }\n };\n\n f.nodata = function(d) {\n if (d != null) {\n _nacol = chroma_1(d);\n return f;\n } else {\n return _nacol;\n }\n };\n\n return f;\n };\n\n function __range__(left, right, inclusive) {\n var range = [];\n var ascending = left < right;\n var end = !inclusive ? right : ascending ? right + 1 : right - 1;\n for (var i = left; ascending ? i < end : i > end; ascending ? i++ : i--) {\n range.push(i);\n }\n return range;\n }\n\n //\n // interpolates between a set of colors uzing a bezier spline\n //\n\n // @requires utils lab\n\n\n\n\n var bezier = function(colors) {\n var assign, assign$1, assign$2;\n\n var I, lab0, lab1, lab2;\n colors = colors.map(function (c) { return new Color_1(c); });\n if (colors.length === 2) {\n // linear interpolation\n (assign = colors.map(function (c) { return c.lab(); }), lab0 = assign[0], lab1 = assign[1]);\n I = function(t) {\n var lab = ([0, 1, 2].map(function (i) { return lab0[i] + (t * (lab1[i] - lab0[i])); }));\n return new Color_1(lab, 'lab');\n };\n } else if (colors.length === 3) {\n // quadratic bezier interpolation\n (assign$1 = colors.map(function (c) { return c.lab(); }), lab0 = assign$1[0], lab1 = assign$1[1], lab2 = assign$1[2]);\n I = function(t) {\n var lab = ([0, 1, 2].map(function (i) { return ((1-t)*(1-t) * lab0[i]) + (2 * (1-t) * t * lab1[i]) + (t * t * lab2[i]); }));\n return new Color_1(lab, 'lab');\n };\n } else if (colors.length === 4) {\n // cubic bezier interpolation\n var lab3;\n (assign$2 = colors.map(function (c) { return c.lab(); }), lab0 = assign$2[0], lab1 = assign$2[1], lab2 = assign$2[2], lab3 = assign$2[3]);\n I = function(t) {\n var lab = ([0, 1, 2].map(function (i) { return ((1-t)*(1-t)*(1-t) * lab0[i]) + (3 * (1-t) * (1-t) * t * lab1[i]) + (3 * (1-t) * t * t * lab2[i]) + (t*t*t * lab3[i]); }));\n return new Color_1(lab, 'lab');\n };\n } else if (colors.length === 5) {\n var I0 = bezier(colors.slice(0, 3));\n var I1 = bezier(colors.slice(2, 5));\n I = function(t) {\n if (t < 0.5) {\n return I0(t*2);\n } else {\n return I1((t-0.5)*2);\n }\n };\n }\n return I;\n };\n\n var bezier_1 = function (colors) {\n var f = bezier(colors);\n f.scale = function () { return scale(f); };\n return f;\n };\n\n /*\n * interpolates between a set of colors uzing a bezier spline\n * blend mode formulas taken from http://www.venture-ware.com/kevin/coding/lets-learn-math-photoshop-blend-modes/\n */\n\n\n\n\n var blend = function (bottom, top, mode) {\n if (!blend[mode]) {\n throw new Error('unknown blend mode ' + mode);\n }\n return blend[mode](bottom, top);\n };\n\n var blend_f = function (f) { return function (bottom,top) {\n var c0 = chroma_1(top).rgb();\n var c1 = chroma_1(bottom).rgb();\n return chroma_1.rgb(f(c0, c1));\n }; };\n\n var each = function (f) { return function (c0, c1) {\n var out = [];\n out[0] = f(c0[0], c1[0]);\n out[1] = f(c0[1], c1[1]);\n out[2] = f(c0[2], c1[2]);\n return out;\n }; };\n\n var normal = function (a) { return a; };\n var multiply = function (a,b) { return a * b / 255; };\n var darken$1 = function (a,b) { return a > b ? b : a; };\n var lighten = function (a,b) { return a > b ? a : b; };\n var screen = function (a,b) { return 255 * (1 - (1-a/255) * (1-b/255)); };\n var overlay = function (a,b) { return b < 128 ? 2 * a * b / 255 : 255 * (1 - 2 * (1 - a / 255 ) * ( 1 - b / 255 )); };\n var burn = function (a,b) { return 255 * (1 - (1 - b / 255) / (a/255)); };\n var dodge = function (a,b) {\n if (a === 255) { return 255; }\n a = 255 * (b / 255) / (1 - a / 255);\n return a > 255 ? 255 : a\n };\n\n // # add = (a,b) ->\n // # if (a + b > 255) then 255 else a + b\n\n blend.normal = blend_f(each(normal));\n blend.multiply = blend_f(each(multiply));\n blend.screen = blend_f(each(screen));\n blend.overlay = blend_f(each(overlay));\n blend.darken = blend_f(each(darken$1));\n blend.lighten = blend_f(each(lighten));\n blend.dodge = blend_f(each(dodge));\n blend.burn = blend_f(each(burn));\n // blend.add = blend_f(each(add));\n\n var blend_1 = blend;\n\n // cubehelix interpolation\n // based on D.A. Green \"A colour scheme for the display of astronomical intensity images\"\n // http://astron-soc.in/bulletin/11June/289392011.pdf\n\n var type$k = utils.type;\n var clip_rgb$3 = utils.clip_rgb;\n var TWOPI$2 = utils.TWOPI;\n var pow$6 = Math.pow;\n var sin$2 = Math.sin;\n var cos$3 = Math.cos;\n\n\n var cubehelix = function(start, rotations, hue, gamma, lightness) {\n if ( start === void 0 ) start=300;\n if ( rotations === void 0 ) rotations=-1.5;\n if ( hue === void 0 ) hue=1;\n if ( gamma === void 0 ) gamma=1;\n if ( lightness === void 0 ) lightness=[0,1];\n\n var dh = 0, dl;\n if (type$k(lightness) === 'array') {\n dl = lightness[1] - lightness[0];\n } else {\n dl = 0;\n lightness = [lightness, lightness];\n }\n\n var f = function(fract) {\n var a = TWOPI$2 * (((start+120)/360) + (rotations * fract));\n var l = pow$6(lightness[0] + (dl * fract), gamma);\n var h = dh !== 0 ? hue[0] + (fract * dh) : hue;\n var amp = (h * l * (1-l)) / 2;\n var cos_a = cos$3(a);\n var sin_a = sin$2(a);\n var r = l + (amp * ((-0.14861 * cos_a) + (1.78277* sin_a)));\n var g = l + (amp * ((-0.29227 * cos_a) - (0.90649* sin_a)));\n var b = l + (amp * (+1.97294 * cos_a));\n return chroma_1(clip_rgb$3([r*255,g*255,b*255,1]));\n };\n\n f.start = function(s) {\n if ((s == null)) { return start; }\n start = s;\n return f;\n };\n\n f.rotations = function(r) {\n if ((r == null)) { return rotations; }\n rotations = r;\n return f;\n };\n\n f.gamma = function(g) {\n if ((g == null)) { return gamma; }\n gamma = g;\n return f;\n };\n\n f.hue = function(h) {\n if ((h == null)) { return hue; }\n hue = h;\n if (type$k(hue) === 'array') {\n dh = hue[1] - hue[0];\n if (dh === 0) { hue = hue[1]; }\n } else {\n dh = 0;\n }\n return f;\n };\n\n f.lightness = function(h) {\n if ((h == null)) { return lightness; }\n if (type$k(h) === 'array') {\n lightness = h;\n dl = h[1] - h[0];\n } else {\n lightness = [h,h];\n dl = 0;\n }\n return f;\n };\n\n f.scale = function () { return chroma_1.scale(f); };\n\n f.hue(hue);\n\n return f;\n };\n\n var digits = '0123456789abcdef';\n\n var floor$2 = Math.floor;\n var random = Math.random;\n\n var random_1 = function () {\n var code = '#';\n for (var i=0; i<6; i++) {\n code += digits.charAt(floor$2(random() * 16));\n }\n return new Color_1(code, 'hex');\n };\n\n var log$1 = Math.log;\n var pow$7 = Math.pow;\n var floor$3 = Math.floor;\n var abs = Math.abs;\n\n\n var analyze = function (data, key) {\n if ( key === void 0 ) key=null;\n\n var r = {\n min: Number.MAX_VALUE,\n max: Number.MAX_VALUE*-1,\n sum: 0,\n values: [],\n count: 0\n };\n if (type(data) === 'object') {\n data = Object.values(data);\n }\n data.forEach(function (val) {\n if (key && type(val) === 'object') { val = val[key]; }\n if (val !== undefined && val !== null && !isNaN(val)) {\n r.values.push(val);\n r.sum += val;\n if (val < r.min) { r.min = val; }\n if (val > r.max) { r.max = val; }\n r.count += 1;\n }\n });\n\n r.domain = [r.min, r.max];\n\n r.limits = function (mode, num) { return limits(r, mode, num); };\n\n return r;\n };\n\n\n var limits = function (data, mode, num) {\n if ( mode === void 0 ) mode='equal';\n if ( num === void 0 ) num=7;\n\n if (type(data) == 'array') {\n data = analyze(data);\n }\n var min = data.min;\n var max = data.max;\n var values = data.values.sort(function (a,b) { return a-b; });\n\n if (num === 1) { return [min,max]; }\n\n var limits = [];\n\n if (mode.substr(0,1) === 'c') { // continuous\n limits.push(min);\n limits.push(max);\n }\n\n if (mode.substr(0,1) === 'e') { // equal interval\n limits.push(min);\n for (var i=1; i 0');\n }\n var min_log = Math.LOG10E * log$1(min);\n var max_log = Math.LOG10E * log$1(max);\n limits.push(min);\n for (var i$1=1; i$1 pb\n var pr = p - pb;\n limits.push((values[pb]*(1-pr)) + (values[pb+1]*pr));\n }\n }\n limits.push(max);\n\n }\n\n else if (mode.substr(0,1) === 'k') { // k-means clustering\n /*\n implementation based on\n http://code.google.com/p/figue/source/browse/trunk/figue.js#336\n simplified for 1-d input values\n */\n var cluster;\n var n = values.length;\n var assignments = new Array(n);\n var clusterSizes = new Array(num);\n var repeat = true;\n var nb_iters = 0;\n var centroids = null;\n\n // get seed values\n centroids = [];\n centroids.push(min);\n for (var i$3=1; i$3 200) {\n repeat = false;\n }\n }\n\n // finished k-means clustering\n // the next part is borrowed from gabrielflor.it\n var kClusters = {};\n for (var j$5=0; j$5 l2 ? (l1 + 0.05) / (l2 + 0.05) : (l2 + 0.05) / (l1 + 0.05);\n };\n\n var sqrt$4 = Math.sqrt;\n var atan2$2 = Math.atan2;\n var abs$1 = Math.abs;\n var cos$4 = Math.cos;\n var PI$2 = Math.PI;\n\n var deltaE = function(a, b, L, C) {\n if ( L === void 0 ) L=1;\n if ( C === void 0 ) C=1;\n\n // Delta E (CMC)\n // see http://www.brucelindbloom.com/index.html?Eqn_DeltaE_CMC.html\n a = new Color_1(a);\n b = new Color_1(b);\n var ref = Array.from(a.lab());\n var L1 = ref[0];\n var a1 = ref[1];\n var b1 = ref[2];\n var ref$1 = Array.from(b.lab());\n var L2 = ref$1[0];\n var a2 = ref$1[1];\n var b2 = ref$1[2];\n var c1 = sqrt$4((a1 * a1) + (b1 * b1));\n var c2 = sqrt$4((a2 * a2) + (b2 * b2));\n var sl = L1 < 16.0 ? 0.511 : (0.040975 * L1) / (1.0 + (0.01765 * L1));\n var sc = ((0.0638 * c1) / (1.0 + (0.0131 * c1))) + 0.638;\n var h1 = c1 < 0.000001 ? 0.0 : (atan2$2(b1, a1) * 180.0) / PI$2;\n while (h1 < 0) { h1 += 360; }\n while (h1 >= 360) { h1 -= 360; }\n var t = (h1 >= 164.0) && (h1 <= 345.0) ? (0.56 + abs$1(0.2 * cos$4((PI$2 * (h1 + 168.0)) / 180.0))) : (0.36 + abs$1(0.4 * cos$4((PI$2 * (h1 + 35.0)) / 180.0)));\n var c4 = c1 * c1 * c1 * c1;\n var f = sqrt$4(c4 / (c4 + 1900.0));\n var sh = sc * (((f * t) + 1.0) - f);\n var delL = L1 - L2;\n var delC = c1 - c2;\n var delA = a1 - a2;\n var delB = b1 - b2;\n var dH2 = ((delA * delA) + (delB * delB)) - (delC * delC);\n var v1 = delL / (L * sl);\n var v2 = delC / (C * sc);\n var v3 = sh;\n return sqrt$4((v1 * v1) + (v2 * v2) + (dH2 / (v3 * v3)));\n };\n\n // simple Euclidean distance\n var distance = function(a, b, mode) {\n if ( mode === void 0 ) mode='lab';\n\n // Delta E (CIE 1976)\n // see http://www.brucelindbloom.com/index.html?Equations.html\n a = new Color_1(a);\n b = new Color_1(b);\n var l1 = a.get(mode);\n var l2 = b.get(mode);\n var sum_sq = 0;\n for (var i in l1) {\n var d = (l1[i] || 0) - (l2[i] || 0);\n sum_sq += d*d;\n }\n return Math.sqrt(sum_sq);\n };\n\n var valid = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n try {\n new (Function.prototype.bind.apply( Color_1, [ null ].concat( args) ));\n return true;\n } catch (e) {\n return false;\n }\n };\n\n // some pre-defined color scales:\n\n\n\n\n var scales = {\n \tcool: function cool() { return scale([chroma_1.hsl(180,1,.9), chroma_1.hsl(250,.7,.4)]) },\n \thot: function hot() { return scale(['#000','#f00','#ff0','#fff'], [0,.25,.75,1]).mode('rgb') }\n };\n\n /**\n ColorBrewer colors for chroma.js\n\n Copyright (c) 2002 Cynthia Brewer, Mark Harrower, and The\n Pennsylvania State University.\n\n Licensed under the Apache License, Version 2.0 (the \"License\");\n you may not use this file except in compliance with the License.\n You may obtain a copy of the License at\n http://www.apache.org/licenses/LICENSE-2.0\n\n Unless required by applicable law or agreed to in writing, software distributed\n under the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR\n CONDITIONS OF ANY KIND, either express or implied. See the License for the\n specific language governing permissions and limitations under the License.\n */\n\n var colorbrewer = {\n // sequential\n OrRd: ['#fff7ec', '#fee8c8', '#fdd49e', '#fdbb84', '#fc8d59', '#ef6548', '#d7301f', '#b30000', '#7f0000'],\n PuBu: ['#fff7fb', '#ece7f2', '#d0d1e6', '#a6bddb', '#74a9cf', '#3690c0', '#0570b0', '#045a8d', '#023858'],\n BuPu: ['#f7fcfd', '#e0ecf4', '#bfd3e6', '#9ebcda', '#8c96c6', '#8c6bb1', '#88419d', '#810f7c', '#4d004b'],\n Oranges: ['#fff5eb', '#fee6ce', '#fdd0a2', '#fdae6b', '#fd8d3c', '#f16913', '#d94801', '#a63603', '#7f2704'],\n BuGn: ['#f7fcfd', '#e5f5f9', '#ccece6', '#99d8c9', '#66c2a4', '#41ae76', '#238b45', '#006d2c', '#00441b'],\n YlOrBr: ['#ffffe5', '#fff7bc', '#fee391', '#fec44f', '#fe9929', '#ec7014', '#cc4c02', '#993404', '#662506'],\n YlGn: ['#ffffe5', '#f7fcb9', '#d9f0a3', '#addd8e', '#78c679', '#41ab5d', '#238443', '#006837', '#004529'],\n Reds: ['#fff5f0', '#fee0d2', '#fcbba1', '#fc9272', '#fb6a4a', '#ef3b2c', '#cb181d', '#a50f15', '#67000d'],\n RdPu: ['#fff7f3', '#fde0dd', '#fcc5c0', '#fa9fb5', '#f768a1', '#dd3497', '#ae017e', '#7a0177', '#49006a'],\n Greens: ['#f7fcf5', '#e5f5e0', '#c7e9c0', '#a1d99b', '#74c476', '#41ab5d', '#238b45', '#006d2c', '#00441b'],\n YlGnBu: ['#ffffd9', '#edf8b1', '#c7e9b4', '#7fcdbb', '#41b6c4', '#1d91c0', '#225ea8', '#253494', '#081d58'],\n Purples: ['#fcfbfd', '#efedf5', '#dadaeb', '#bcbddc', '#9e9ac8', '#807dba', '#6a51a3', '#54278f', '#3f007d'],\n GnBu: ['#f7fcf0', '#e0f3db', '#ccebc5', '#a8ddb5', '#7bccc4', '#4eb3d3', '#2b8cbe', '#0868ac', '#084081'],\n Greys: ['#ffffff', '#f0f0f0', '#d9d9d9', '#bdbdbd', '#969696', '#737373', '#525252', '#252525', '#000000'],\n YlOrRd: ['#ffffcc', '#ffeda0', '#fed976', '#feb24c', '#fd8d3c', '#fc4e2a', '#e31a1c', '#bd0026', '#800026'],\n PuRd: ['#f7f4f9', '#e7e1ef', '#d4b9da', '#c994c7', '#df65b0', '#e7298a', '#ce1256', '#980043', '#67001f'],\n Blues: ['#f7fbff', '#deebf7', '#c6dbef', '#9ecae1', '#6baed6', '#4292c6', '#2171b5', '#08519c', '#08306b'],\n PuBuGn: ['#fff7fb', '#ece2f0', '#d0d1e6', '#a6bddb', '#67a9cf', '#3690c0', '#02818a', '#016c59', '#014636'],\n Viridis: ['#440154', '#482777', '#3f4a8a', '#31678e', '#26838f', '#1f9d8a', '#6cce5a', '#b6de2b', '#fee825'],\n\n // diverging\n\n Spectral: ['#9e0142', '#d53e4f', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#e6f598', '#abdda4', '#66c2a5', '#3288bd', '#5e4fa2'],\n RdYlGn: ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#d9ef8b', '#a6d96a', '#66bd63', '#1a9850', '#006837'],\n RdBu: ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#f7f7f7', '#d1e5f0', '#92c5de', '#4393c3', '#2166ac', '#053061'],\n PiYG: ['#8e0152', '#c51b7d', '#de77ae', '#f1b6da', '#fde0ef', '#f7f7f7', '#e6f5d0', '#b8e186', '#7fbc41', '#4d9221', '#276419'],\n PRGn: ['#40004b', '#762a83', '#9970ab', '#c2a5cf', '#e7d4e8', '#f7f7f7', '#d9f0d3', '#a6dba0', '#5aae61', '#1b7837', '#00441b'],\n RdYlBu: ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee090', '#ffffbf', '#e0f3f8', '#abd9e9', '#74add1', '#4575b4', '#313695'],\n BrBG: ['#543005', '#8c510a', '#bf812d', '#dfc27d', '#f6e8c3', '#f5f5f5', '#c7eae5', '#80cdc1', '#35978f', '#01665e', '#003c30'],\n RdGy: ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#ffffff', '#e0e0e0', '#bababa', '#878787', '#4d4d4d', '#1a1a1a'],\n PuOr: ['#7f3b08', '#b35806', '#e08214', '#fdb863', '#fee0b6', '#f7f7f7', '#d8daeb', '#b2abd2', '#8073ac', '#542788', '#2d004b'],\n\n // qualitative\n\n Set2: ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3', '#a6d854', '#ffd92f', '#e5c494', '#b3b3b3'],\n Accent: ['#7fc97f', '#beaed4', '#fdc086', '#ffff99', '#386cb0', '#f0027f', '#bf5b17', '#666666'],\n Set1: ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00', '#ffff33', '#a65628', '#f781bf', '#999999'],\n Set3: ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5', '#d9d9d9', '#bc80bd', '#ccebc5', '#ffed6f'],\n Dark2: ['#1b9e77', '#d95f02', '#7570b3', '#e7298a', '#66a61e', '#e6ab02', '#a6761d', '#666666'],\n Paired: ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00', '#cab2d6', '#6a3d9a', '#ffff99', '#b15928'],\n Pastel2: ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4', '#e6f5c9', '#fff2ae', '#f1e2cc', '#cccccc'],\n Pastel1: ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6', '#ffffcc', '#e5d8bd', '#fddaec', '#f2f2f2'],\n };\n\n // add lowercase aliases for case-insensitive matches\n for (var i$1 = 0, list$1 = Object.keys(colorbrewer); i$1 < list$1.length; i$1 += 1) {\n var key = list$1[i$1];\n\n colorbrewer[key.toLowerCase()] = colorbrewer[key];\n }\n\n var colorbrewer_1 = colorbrewer;\n\n // feel free to comment out anything to rollup\n // a smaller chroma.js built\n\n // io --> convert colors\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n // operators --> modify existing Colors\n\n\n\n\n\n\n\n\n\n\n // interpolators\n\n\n\n\n\n\n\n\n\n\n // generators -- > create new colors\n chroma_1.average = average;\n chroma_1.bezier = bezier_1;\n chroma_1.blend = blend_1;\n chroma_1.cubehelix = cubehelix;\n chroma_1.mix = chroma_1.interpolate = mix;\n chroma_1.random = random_1;\n chroma_1.scale = scale;\n\n // other utility methods\n chroma_1.analyze = analyze_1.analyze;\n chroma_1.contrast = contrast;\n chroma_1.deltaE = deltaE;\n chroma_1.distance = distance;\n chroma_1.limits = analyze_1.limits;\n chroma_1.valid = valid;\n\n // scale\n chroma_1.scales = scales;\n\n // colors\n chroma_1.colors = w3cx11_1;\n chroma_1.brewer = colorbrewer_1;\n\n var chroma_js = chroma_1;\n\n return chroma_js;\n\n})));\n","import { Mesh } from \"../mesh\";\r\nimport { VertexData } from \"../mesh.vertexData\";\r\nVertexData.CreatePlane = function (options) {\r\n var indices = [];\r\n var positions = [];\r\n var normals = [];\r\n var uvs = [];\r\n var width = options.width || options.size || 1;\r\n var height = options.height || options.size || 1;\r\n var sideOrientation = (options.sideOrientation === 0) ? 0 : options.sideOrientation || VertexData.DEFAULTSIDE;\r\n // Vertices\r\n var halfWidth = width / 2.0;\r\n var halfHeight = height / 2.0;\r\n positions.push(-halfWidth, -halfHeight, 0);\r\n normals.push(0, 0, -1.0);\r\n uvs.push(0.0, 0.0);\r\n positions.push(halfWidth, -halfHeight, 0);\r\n normals.push(0, 0, -1.0);\r\n uvs.push(1.0, 0.0);\r\n positions.push(halfWidth, halfHeight, 0);\r\n normals.push(0, 0, -1.0);\r\n uvs.push(1.0, 1.0);\r\n positions.push(-halfWidth, halfHeight, 0);\r\n normals.push(0, 0, -1.0);\r\n uvs.push(0.0, 1.0);\r\n // Indices\r\n indices.push(0);\r\n indices.push(1);\r\n indices.push(2);\r\n indices.push(0);\r\n indices.push(2);\r\n indices.push(3);\r\n // Sides\r\n VertexData._ComputeSides(sideOrientation, positions, indices, normals, uvs, options.frontUVs, options.backUVs);\r\n // Result\r\n var vertexData = new VertexData();\r\n vertexData.indices = indices;\r\n vertexData.positions = positions;\r\n vertexData.normals = normals;\r\n vertexData.uvs = uvs;\r\n return vertexData;\r\n};\r\nMesh.CreatePlane = function (name, size, scene, updatable, sideOrientation) {\r\n var options = {\r\n size: size,\r\n width: size,\r\n height: size,\r\n sideOrientation: sideOrientation,\r\n updatable: updatable\r\n };\r\n return PlaneBuilder.CreatePlane(name, options, scene);\r\n};\r\n/**\r\n * Class containing static functions to help procedurally build meshes\r\n */\r\nvar PlaneBuilder = /** @class */ (function () {\r\n function PlaneBuilder() {\r\n }\r\n /**\r\n * Creates a plane mesh\r\n * * The parameter `size` sets the size (float) of both sides of the plane at once (default 1)\r\n * * You can set some different plane dimensions by using the parameters `width` and `height` (both by default have the same value of `size`)\r\n * * The parameter `sourcePlane` is a Plane instance. It builds a mesh plane from a Math plane\r\n * * You can also set the mesh side orientation with the values : BABYLON.Mesh.FRONTSIDE (default), BABYLON.Mesh.BACKSIDE or BABYLON.Mesh.DOUBLESIDE\r\n * * If you create a double-sided mesh, you can choose what parts of the texture image to crop and stick respectively on the front and the back sides with the parameters `frontUVs` and `backUVs` (Vector4). Detail here : https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @param name defines the name of the mesh\r\n * @param options defines the options used to create the mesh\r\n * @param scene defines the hosting scene\r\n * @returns the plane mesh\r\n * @see https://doc.babylonjs.com/how_to/set_shapes#plane\r\n */\r\n PlaneBuilder.CreatePlane = function (name, options, scene) {\r\n if (scene === void 0) { scene = null; }\r\n var plane = new Mesh(name, scene);\r\n options.sideOrientation = Mesh._GetDefaultSideOrientation(options.sideOrientation);\r\n plane._originalBuilderSideOrientation = options.sideOrientation;\r\n var vertexData = VertexData.CreatePlane(options);\r\n vertexData.applyToMesh(plane, options.updatable);\r\n if (options.sourcePlane) {\r\n plane.translate(options.sourcePlane.normal, -options.sourcePlane.d);\r\n plane.setDirection(options.sourcePlane.normal.scale(-1));\r\n }\r\n return plane;\r\n };\r\n return PlaneBuilder;\r\n}());\r\nexport { PlaneBuilder };\r\n//# sourceMappingURL=planeBuilder.js.map","import { ThinEngine } from \"../../Engines/thinEngine\";\r\nimport { InternalTexture, InternalTextureSource } from '../../Materials/Textures/internalTexture';\r\nThinEngine.prototype.createDynamicTexture = function (width, height, generateMipMaps, samplingMode) {\r\n var texture = new InternalTexture(this, InternalTextureSource.Dynamic);\r\n texture.baseWidth = width;\r\n texture.baseHeight = height;\r\n if (generateMipMaps) {\r\n width = this.needPOTTextures ? ThinEngine.GetExponentOfTwo(width, this._caps.maxTextureSize) : width;\r\n height = this.needPOTTextures ? ThinEngine.GetExponentOfTwo(height, this._caps.maxTextureSize) : height;\r\n }\r\n // this.resetTextureCache();\r\n texture.width = width;\r\n texture.height = height;\r\n texture.isReady = false;\r\n texture.generateMipMaps = generateMipMaps;\r\n texture.samplingMode = samplingMode;\r\n this.updateTextureSamplingMode(samplingMode, texture);\r\n this._internalTexturesCache.push(texture);\r\n return texture;\r\n};\r\nThinEngine.prototype.updateDynamicTexture = function (texture, canvas, invertY, premulAlpha, format, forceBindTexture) {\r\n if (premulAlpha === void 0) { premulAlpha = false; }\r\n if (forceBindTexture === void 0) { forceBindTexture = false; }\r\n if (!texture) {\r\n return;\r\n }\r\n this._bindTextureDirectly(this._gl.TEXTURE_2D, texture, true, forceBindTexture);\r\n this._unpackFlipY(invertY);\r\n if (premulAlpha) {\r\n this._gl.pixelStorei(this._gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, 1);\r\n }\r\n var internalFormat = format ? this._getInternalFormat(format) : this._gl.RGBA;\r\n this._gl.texImage2D(this._gl.TEXTURE_2D, 0, internalFormat, internalFormat, this._gl.UNSIGNED_BYTE, canvas);\r\n if (texture.generateMipMaps) {\r\n this._gl.generateMipmap(this._gl.TEXTURE_2D);\r\n }\r\n this._bindTextureDirectly(this._gl.TEXTURE_2D, null);\r\n if (premulAlpha) {\r\n this._gl.pixelStorei(this._gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, 0);\r\n }\r\n texture.isReady = true;\r\n};\r\n//# sourceMappingURL=engine.dynamicTexture.js.map","import { __extends } from \"tslib\";\r\nimport { Logger } from \"../../Misc/logger\";\r\nimport { Texture } from \"../../Materials/Textures/texture\";\r\nimport \"../../Engines/Extensions/engine.dynamicTexture\";\r\nimport { CanvasGenerator } from '../../Misc/canvasGenerator';\r\n/**\r\n * A class extending Texture allowing drawing on a texture\r\n * @see http://doc.babylonjs.com/how_to/dynamictexture\r\n */\r\nvar DynamicTexture = /** @class */ (function (_super) {\r\n __extends(DynamicTexture, _super);\r\n /**\r\n * Creates a DynamicTexture\r\n * @param name defines the name of the texture\r\n * @param options provides 3 alternatives for width and height of texture, a canvas, object with width and height properties, number for both width and height\r\n * @param scene defines the scene where you want the texture\r\n * @param generateMipMaps defines the use of MinMaps or not (default is false)\r\n * @param samplingMode defines the sampling mode to use (default is Texture.TRILINEAR_SAMPLINGMODE)\r\n * @param format defines the texture format to use (default is Engine.TEXTUREFORMAT_RGBA)\r\n */\r\n function DynamicTexture(name, options, scene, generateMipMaps, samplingMode, format) {\r\n if (scene === void 0) { scene = null; }\r\n if (samplingMode === void 0) { samplingMode = 3; }\r\n if (format === void 0) { format = 5; }\r\n var _this = _super.call(this, null, scene, !generateMipMaps, undefined, samplingMode, undefined, undefined, undefined, undefined, format) || this;\r\n _this.name = name;\r\n _this._engine = _this.getScene().getEngine();\r\n _this.wrapU = Texture.CLAMP_ADDRESSMODE;\r\n _this.wrapV = Texture.CLAMP_ADDRESSMODE;\r\n _this._generateMipMaps = generateMipMaps;\r\n if (options.getContext) {\r\n _this._canvas = options;\r\n _this._texture = _this._engine.createDynamicTexture(options.width, options.height, generateMipMaps, samplingMode);\r\n }\r\n else {\r\n _this._canvas = CanvasGenerator.CreateCanvas(1, 1);\r\n if (options.width || options.width === 0) {\r\n _this._texture = _this._engine.createDynamicTexture(options.width, options.height, generateMipMaps, samplingMode);\r\n }\r\n else {\r\n _this._texture = _this._engine.createDynamicTexture(options, options, generateMipMaps, samplingMode);\r\n }\r\n }\r\n var textureSize = _this.getSize();\r\n _this._canvas.width = textureSize.width;\r\n _this._canvas.height = textureSize.height;\r\n _this._context = _this._canvas.getContext(\"2d\");\r\n return _this;\r\n }\r\n /**\r\n * Get the current class name of the texture useful for serialization or dynamic coding.\r\n * @returns \"DynamicTexture\"\r\n */\r\n DynamicTexture.prototype.getClassName = function () {\r\n return \"DynamicTexture\";\r\n };\r\n Object.defineProperty(DynamicTexture.prototype, \"canRescale\", {\r\n /**\r\n * Gets the current state of canRescale\r\n */\r\n get: function () {\r\n return true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n DynamicTexture.prototype._recreate = function (textureSize) {\r\n this._canvas.width = textureSize.width;\r\n this._canvas.height = textureSize.height;\r\n this.releaseInternalTexture();\r\n this._texture = this._engine.createDynamicTexture(textureSize.width, textureSize.height, this._generateMipMaps, this.samplingMode);\r\n };\r\n /**\r\n * Scales the texture\r\n * @param ratio the scale factor to apply to both width and height\r\n */\r\n DynamicTexture.prototype.scale = function (ratio) {\r\n var textureSize = this.getSize();\r\n textureSize.width *= ratio;\r\n textureSize.height *= ratio;\r\n this._recreate(textureSize);\r\n };\r\n /**\r\n * Resizes the texture\r\n * @param width the new width\r\n * @param height the new height\r\n */\r\n DynamicTexture.prototype.scaleTo = function (width, height) {\r\n var textureSize = this.getSize();\r\n textureSize.width = width;\r\n textureSize.height = height;\r\n this._recreate(textureSize);\r\n };\r\n /**\r\n * Gets the context of the canvas used by the texture\r\n * @returns the canvas context of the dynamic texture\r\n */\r\n DynamicTexture.prototype.getContext = function () {\r\n return this._context;\r\n };\r\n /**\r\n * Clears the texture\r\n */\r\n DynamicTexture.prototype.clear = function () {\r\n var size = this.getSize();\r\n this._context.fillRect(0, 0, size.width, size.height);\r\n };\r\n /**\r\n * Updates the texture\r\n * @param invertY defines the direction for the Y axis (default is true - y increases downwards)\r\n * @param premulAlpha defines if alpha is stored as premultiplied (default is false)\r\n */\r\n DynamicTexture.prototype.update = function (invertY, premulAlpha) {\r\n if (premulAlpha === void 0) { premulAlpha = false; }\r\n this._engine.updateDynamicTexture(this._texture, this._canvas, invertY === undefined ? true : invertY, premulAlpha, this._format || undefined);\r\n };\r\n /**\r\n * Draws text onto the texture\r\n * @param text defines the text to be drawn\r\n * @param x defines the placement of the text from the left\r\n * @param y defines the placement of the text from the top when invertY is true and from the bottom when false\r\n * @param font defines the font to be used with font-style, font-size, font-name\r\n * @param color defines the color used for the text\r\n * @param clearColor defines the color for the canvas, use null to not overwrite canvas\r\n * @param invertY defines the direction for the Y axis (default is true - y increases downwards)\r\n * @param update defines whether texture is immediately update (default is true)\r\n */\r\n DynamicTexture.prototype.drawText = function (text, x, y, font, color, clearColor, invertY, update) {\r\n if (update === void 0) { update = true; }\r\n var size = this.getSize();\r\n if (clearColor) {\r\n this._context.fillStyle = clearColor;\r\n this._context.fillRect(0, 0, size.width, size.height);\r\n }\r\n this._context.font = font;\r\n if (x === null || x === undefined) {\r\n var textSize = this._context.measureText(text);\r\n x = (size.width - textSize.width) / 2;\r\n }\r\n if (y === null || y === undefined) {\r\n var fontSize = parseInt((font.replace(/\\D/g, '')));\r\n y = (size.height / 2) + (fontSize / 3.65);\r\n }\r\n this._context.fillStyle = color;\r\n this._context.fillText(text, x, y);\r\n if (update) {\r\n this.update(invertY);\r\n }\r\n };\r\n /**\r\n * Clones the texture\r\n * @returns the clone of the texture.\r\n */\r\n DynamicTexture.prototype.clone = function () {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return this;\r\n }\r\n var textureSize = this.getSize();\r\n var newTexture = new DynamicTexture(this.name, textureSize, scene, this._generateMipMaps);\r\n // Base texture\r\n newTexture.hasAlpha = this.hasAlpha;\r\n newTexture.level = this.level;\r\n // Dynamic Texture\r\n newTexture.wrapU = this.wrapU;\r\n newTexture.wrapV = this.wrapV;\r\n return newTexture;\r\n };\r\n /**\r\n * Serializes the dynamic texture. The scene should be ready before the dynamic texture is serialized\r\n * @returns a serialized dynamic texture object\r\n */\r\n DynamicTexture.prototype.serialize = function () {\r\n var scene = this.getScene();\r\n if (scene && !scene.isReady()) {\r\n Logger.Warn(\"The scene must be ready before serializing the dynamic texture\");\r\n }\r\n var serializationObject = _super.prototype.serialize.call(this);\r\n if (this._canvas.toDataURL) {\r\n serializationObject.base64String = this._canvas.toDataURL();\r\n }\r\n serializationObject.invertY = this._invertY;\r\n serializationObject.samplingMode = this.samplingMode;\r\n return serializationObject;\r\n };\r\n /** @hidden */\r\n DynamicTexture.prototype._rebuild = function () {\r\n this.update();\r\n };\r\n return DynamicTexture;\r\n}(Texture));\r\nexport { DynamicTexture };\r\n//# sourceMappingURL=dynamicTexture.js.map","import { Vector4 } from \"../../Maths/math.vector\";\r\nimport { Color4 } from '../../Maths/math.color';\r\nimport { Mesh } from \"../mesh\";\r\nimport { VertexData } from \"../mesh.vertexData\";\r\nVertexData.CreateBox = function (options) {\r\n var nbFaces = 6;\r\n var indices = [0, 1, 2, 0, 2, 3, 4, 5, 6, 4, 6, 7, 8, 9, 10, 8, 10, 11, 12, 13, 14, 12, 14, 15, 16, 17, 18, 16, 18, 19, 20, 21, 22, 20, 22, 23];\r\n var normals = [0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0];\r\n var uvs = [];\r\n var positions = [];\r\n var width = options.width || options.size || 1;\r\n var height = options.height || options.size || 1;\r\n var depth = options.depth || options.size || 1;\r\n var wrap = options.wrap || false;\r\n var topBaseAt = (options.topBaseAt === void 0) ? 1 : options.topBaseAt;\r\n var bottomBaseAt = (options.bottomBaseAt === void 0) ? 0 : options.bottomBaseAt;\r\n topBaseAt = (topBaseAt + 4) % 4; // places values as 0 to 3\r\n bottomBaseAt = (bottomBaseAt + 4) % 4; // places values as 0 to 3\r\n var topOrder = [2, 0, 3, 1];\r\n var bottomOrder = [2, 0, 1, 3];\r\n var topIndex = topOrder[topBaseAt];\r\n var bottomIndex = bottomOrder[bottomBaseAt];\r\n var basePositions = [1, -1, 1, -1, -1, 1, -1, 1, 1, 1, 1, 1, 1, 1, -1, -1, 1, -1, -1, -1, -1, 1, -1, -1, 1, 1, -1, 1, -1, -1, 1, -1, 1, 1, 1, 1, -1, 1, 1, -1, -1, 1, -1, -1, -1, -1, 1, -1, -1, 1, 1, -1, 1, -1, 1, 1, -1, 1, 1, 1, 1, -1, 1, 1, -1, -1, -1, -1, -1, -1, -1, 1];\r\n if (wrap) {\r\n indices = [2, 3, 0, 2, 0, 1, 4, 5, 6, 4, 6, 7, 9, 10, 11, 9, 11, 8, 12, 14, 15, 12, 13, 14];\r\n basePositions = [-1, 1, 1, 1, 1, 1, 1, -1, 1, -1, -1, 1, 1, 1, -1, -1, 1, -1, -1, -1, -1, 1, -1, -1, 1, 1, 1, 1, 1, -1, 1, -1, -1, 1, -1, 1, -1, 1, -1, -1, 1, 1, -1, -1, 1, -1, -1, -1];\r\n var topFaceBase = [[1, 1, 1], [-1, 1, 1], [-1, 1, -1], [1, 1, -1]];\r\n var bottomFaceBase = [[-1, -1, 1], [1, -1, 1], [1, -1, -1], [-1, -1, -1]];\r\n var topFaceOrder = [17, 18, 19, 16];\r\n var bottomFaceOrder = [22, 23, 20, 21];\r\n while (topIndex > 0) {\r\n topFaceBase.unshift(topFaceBase.pop());\r\n topFaceOrder.unshift(topFaceOrder.pop());\r\n topIndex--;\r\n }\r\n while (bottomIndex > 0) {\r\n bottomFaceBase.unshift(bottomFaceBase.pop());\r\n bottomFaceOrder.unshift(bottomFaceOrder.pop());\r\n bottomIndex--;\r\n }\r\n topFaceBase = topFaceBase.flat();\r\n bottomFaceBase = bottomFaceBase.flat();\r\n basePositions = basePositions.concat(topFaceBase).concat(bottomFaceBase);\r\n indices.push(topFaceOrder[0], topFaceOrder[2], topFaceOrder[3], topFaceOrder[0], topFaceOrder[1], topFaceOrder[2]);\r\n indices.push(bottomFaceOrder[0], bottomFaceOrder[2], bottomFaceOrder[3], bottomFaceOrder[0], bottomFaceOrder[1], bottomFaceOrder[2]);\r\n }\r\n var scaleArray = [width / 2, height / 2, depth / 2];\r\n positions = basePositions.reduce(function (accumulator, currentValue, currentIndex) { return accumulator.concat(currentValue * scaleArray[currentIndex % 3]); }, []);\r\n var sideOrientation = (options.sideOrientation === 0) ? 0 : options.sideOrientation || VertexData.DEFAULTSIDE;\r\n var faceUV = options.faceUV || new Array(6);\r\n var faceColors = options.faceColors;\r\n var colors = [];\r\n // default face colors and UV if undefined\r\n for (var f = 0; f < 6; f++) {\r\n if (faceUV[f] === undefined) {\r\n faceUV[f] = new Vector4(0, 0, 1, 1);\r\n }\r\n if (faceColors && faceColors[f] === undefined) {\r\n faceColors[f] = new Color4(1, 1, 1, 1);\r\n }\r\n }\r\n // Create each face in turn.\r\n for (var index = 0; index < nbFaces; index++) {\r\n uvs.push(faceUV[index].z, faceUV[index].w);\r\n uvs.push(faceUV[index].x, faceUV[index].w);\r\n uvs.push(faceUV[index].x, faceUV[index].y);\r\n uvs.push(faceUV[index].z, faceUV[index].y);\r\n if (faceColors) {\r\n for (var c = 0; c < 4; c++) {\r\n colors.push(faceColors[index].r, faceColors[index].g, faceColors[index].b, faceColors[index].a);\r\n }\r\n }\r\n }\r\n // sides\r\n VertexData._ComputeSides(sideOrientation, positions, indices, normals, uvs, options.frontUVs, options.backUVs);\r\n // Result\r\n var vertexData = new VertexData();\r\n vertexData.indices = indices;\r\n vertexData.positions = positions;\r\n vertexData.normals = normals;\r\n vertexData.uvs = uvs;\r\n if (faceColors) {\r\n var totalColors = (sideOrientation === VertexData.DOUBLESIDE) ? colors.concat(colors) : colors;\r\n vertexData.colors = totalColors;\r\n }\r\n return vertexData;\r\n};\r\nMesh.CreateBox = function (name, size, scene, updatable, sideOrientation) {\r\n if (scene === void 0) { scene = null; }\r\n var options = {\r\n size: size,\r\n sideOrientation: sideOrientation,\r\n updatable: updatable\r\n };\r\n return BoxBuilder.CreateBox(name, options, scene);\r\n};\r\n/**\r\n * Class containing static functions to help procedurally build meshes\r\n */\r\nvar BoxBuilder = /** @class */ (function () {\r\n function BoxBuilder() {\r\n }\r\n /**\r\n * Creates a box mesh\r\n * * The parameter `size` sets the size (float) of each box side (default 1)\r\n * * You can set some different box dimensions by using the parameters `width`, `height` and `depth` (all by default have the same value of `size`)\r\n * * You can set different colors and different images to each box side by using the parameters `faceColors` (an array of 6 Color3 elements) and `faceUV` (an array of 6 Vector4 elements)\r\n * * Please read this tutorial : https://doc.babylonjs.com/how_to/createbox_per_face_textures_and_colors\r\n * * You can also set the mesh side orientation with the values : BABYLON.Mesh.FRONTSIDE (default), BABYLON.Mesh.BACKSIDE or BABYLON.Mesh.DOUBLESIDE\r\n * * If you create a double-sided mesh, you can choose what parts of the texture image to crop and stick respectively on the front and the back sides with the parameters `frontUVs` and `backUVs` (Vector4). Detail here : https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @see https://doc.babylonjs.com/how_to/set_shapes#box\r\n * @param name defines the name of the mesh\r\n * @param options defines the options used to create the mesh\r\n * @param scene defines the hosting scene\r\n * @returns the box mesh\r\n */\r\n BoxBuilder.CreateBox = function (name, options, scene) {\r\n if (scene === void 0) { scene = null; }\r\n var box = new Mesh(name, scene);\r\n options.sideOrientation = Mesh._GetDefaultSideOrientation(options.sideOrientation);\r\n box._originalBuilderSideOrientation = options.sideOrientation;\r\n var vertexData = VertexData.CreateBox(options);\r\n vertexData.applyToMesh(box, options.updatable);\r\n return box;\r\n };\r\n return BoxBuilder;\r\n}());\r\nexport { BoxBuilder };\r\n//# sourceMappingURL=boxBuilder.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'clipPlaneFragmentDeclaration';\r\nvar shader = \"#ifdef CLIPPLANE\\nvarying float fClipDistance;\\n#endif\\n#ifdef CLIPPLANE2\\nvarying float fClipDistance2;\\n#endif\\n#ifdef CLIPPLANE3\\nvarying float fClipDistance3;\\n#endif\\n#ifdef CLIPPLANE4\\nvarying float fClipDistance4;\\n#endif\\n#ifdef CLIPPLANE5\\nvarying float fClipDistance5;\\n#endif\\n#ifdef CLIPPLANE6\\nvarying float fClipDistance6;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var clipPlaneFragmentDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=clipPlaneFragmentDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'clipPlaneFragment';\r\nvar shader = \"#ifdef CLIPPLANE\\nif (fClipDistance>0.0)\\n{\\ndiscard;\\n}\\n#endif\\n#ifdef CLIPPLANE2\\nif (fClipDistance2>0.0)\\n{\\ndiscard;\\n}\\n#endif\\n#ifdef CLIPPLANE3\\nif (fClipDistance3>0.0)\\n{\\ndiscard;\\n}\\n#endif\\n#ifdef CLIPPLANE4\\nif (fClipDistance4>0.0)\\n{\\ndiscard;\\n}\\n#endif\\n#ifdef CLIPPLANE5\\nif (fClipDistance5>0.0)\\n{\\ndiscard;\\n}\\n#endif\\n#ifdef CLIPPLANE6\\nif (fClipDistance6>0.0)\\n{\\ndiscard;\\n}\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var clipPlaneFragment = { name: name, shader: shader };\r\n//# sourceMappingURL=clipPlaneFragment.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'bonesDeclaration';\r\nvar shader = \"#if NUM_BONE_INFLUENCERS>0\\n#ifdef BONETEXTURE\\nuniform sampler2D boneSampler;\\nuniform float boneTextureWidth;\\n#else\\nuniform mat4 mBones[BonesPerMesh];\\n#endif\\nattribute vec4 matricesIndices;\\nattribute vec4 matricesWeights;\\n#if NUM_BONE_INFLUENCERS>4\\nattribute vec4 matricesIndicesExtra;\\nattribute vec4 matricesWeightsExtra;\\n#endif\\n#ifdef BONETEXTURE\\nmat4 readMatrixFromRawSampler(sampler2D smp,float index)\\n{\\nfloat offset=index*4.0;\\nfloat dx=1.0/boneTextureWidth;\\nvec4 m0=texture2D(smp,vec2(dx*(offset+0.5),0.));\\nvec4 m1=texture2D(smp,vec2(dx*(offset+1.5),0.));\\nvec4 m2=texture2D(smp,vec2(dx*(offset+2.5),0.));\\nvec4 m3=texture2D(smp,vec2(dx*(offset+3.5),0.));\\nreturn mat4(m0,m1,m2,m3);\\n}\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var bonesDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=bonesDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'instancesDeclaration';\r\nvar shader = \"#ifdef INSTANCES\\nattribute vec4 world0;\\nattribute vec4 world1;\\nattribute vec4 world2;\\nattribute vec4 world3;\\n#else\\nuniform mat4 world;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var instancesDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=instancesDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'clipPlaneVertexDeclaration';\r\nvar shader = \"#ifdef CLIPPLANE\\nuniform vec4 vClipPlane;\\nvarying float fClipDistance;\\n#endif\\n#ifdef CLIPPLANE2\\nuniform vec4 vClipPlane2;\\nvarying float fClipDistance2;\\n#endif\\n#ifdef CLIPPLANE3\\nuniform vec4 vClipPlane3;\\nvarying float fClipDistance3;\\n#endif\\n#ifdef CLIPPLANE4\\nuniform vec4 vClipPlane4;\\nvarying float fClipDistance4;\\n#endif\\n#ifdef CLIPPLANE5\\nuniform vec4 vClipPlane5;\\nvarying float fClipDistance5;\\n#endif\\n#ifdef CLIPPLANE6\\nuniform vec4 vClipPlane6;\\nvarying float fClipDistance6;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var clipPlaneVertexDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=clipPlaneVertexDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'instancesVertex';\r\nvar shader = \"#ifdef INSTANCES\\nmat4 finalWorld=mat4(world0,world1,world2,world3);\\n#else\\nmat4 finalWorld=world;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var instancesVertex = { name: name, shader: shader };\r\n//# sourceMappingURL=instancesVertex.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'bonesVertex';\r\nvar shader = \"#if NUM_BONE_INFLUENCERS>0\\nmat4 influence;\\n#ifdef BONETEXTURE\\ninfluence=readMatrixFromRawSampler(boneSampler,matricesIndices[0])*matricesWeights[0];\\n#if NUM_BONE_INFLUENCERS>1\\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndices[1])*matricesWeights[1];\\n#endif\\n#if NUM_BONE_INFLUENCERS>2\\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndices[2])*matricesWeights[2];\\n#endif\\n#if NUM_BONE_INFLUENCERS>3\\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndices[3])*matricesWeights[3];\\n#endif\\n#if NUM_BONE_INFLUENCERS>4\\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndicesExtra[0])*matricesWeightsExtra[0];\\n#endif\\n#if NUM_BONE_INFLUENCERS>5\\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndicesExtra[1])*matricesWeightsExtra[1];\\n#endif\\n#if NUM_BONE_INFLUENCERS>6\\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndicesExtra[2])*matricesWeightsExtra[2];\\n#endif\\n#if NUM_BONE_INFLUENCERS>7\\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndicesExtra[3])*matricesWeightsExtra[3];\\n#endif\\n#else\\ninfluence=mBones[int(matricesIndices[0])]*matricesWeights[0];\\n#if NUM_BONE_INFLUENCERS>1\\ninfluence+=mBones[int(matricesIndices[1])]*matricesWeights[1];\\n#endif\\n#if NUM_BONE_INFLUENCERS>2\\ninfluence+=mBones[int(matricesIndices[2])]*matricesWeights[2];\\n#endif\\n#if NUM_BONE_INFLUENCERS>3\\ninfluence+=mBones[int(matricesIndices[3])]*matricesWeights[3];\\n#endif\\n#if NUM_BONE_INFLUENCERS>4\\ninfluence+=mBones[int(matricesIndicesExtra[0])]*matricesWeightsExtra[0];\\n#endif\\n#if NUM_BONE_INFLUENCERS>5\\ninfluence+=mBones[int(matricesIndicesExtra[1])]*matricesWeightsExtra[1];\\n#endif\\n#if NUM_BONE_INFLUENCERS>6\\ninfluence+=mBones[int(matricesIndicesExtra[2])]*matricesWeightsExtra[2];\\n#endif\\n#if NUM_BONE_INFLUENCERS>7\\ninfluence+=mBones[int(matricesIndicesExtra[3])]*matricesWeightsExtra[3];\\n#endif\\n#endif\\nfinalWorld=finalWorld*influence;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var bonesVertex = { name: name, shader: shader };\r\n//# sourceMappingURL=bonesVertex.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'clipPlaneVertex';\r\nvar shader = \"#ifdef CLIPPLANE\\nfClipDistance=dot(worldPos,vClipPlane);\\n#endif\\n#ifdef CLIPPLANE2\\nfClipDistance2=dot(worldPos,vClipPlane2);\\n#endif\\n#ifdef CLIPPLANE3\\nfClipDistance3=dot(worldPos,vClipPlane3);\\n#endif\\n#ifdef CLIPPLANE4\\nfClipDistance4=dot(worldPos,vClipPlane4);\\n#endif\\n#ifdef CLIPPLANE5\\nfClipDistance5=dot(worldPos,vClipPlane5);\\n#endif\\n#ifdef CLIPPLANE6\\nfClipDistance6=dot(worldPos,vClipPlane6);\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var clipPlaneVertex = { name: name, shader: shader };\r\n//# sourceMappingURL=clipPlaneVertex.js.map","'use strict';\n\nmodule.exports = function bind(fn, thisArg) {\n return function wrap() {\n var args = new Array(arguments.length);\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i];\n }\n return fn.apply(thisArg, args);\n };\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nfunction encode(val) {\n return encodeURIComponent(val).\n replace(/%3A/gi, ':').\n replace(/%24/g, '$').\n replace(/%2C/gi, ',').\n replace(/%20/g, '+').\n replace(/%5B/gi, '[').\n replace(/%5D/gi, ']');\n}\n\n/**\n * Build a URL by appending params to the end\n *\n * @param {string} url The base of the url (e.g., http://www.google.com)\n * @param {object} [params] The params to be appended\n * @returns {string} The formatted url\n */\nmodule.exports = function buildURL(url, params, paramsSerializer) {\n /*eslint no-param-reassign:0*/\n if (!params) {\n return url;\n }\n\n var serializedParams;\n if (paramsSerializer) {\n serializedParams = paramsSerializer(params);\n } else if (utils.isURLSearchParams(params)) {\n serializedParams = params.toString();\n } else {\n var parts = [];\n\n utils.forEach(params, function serialize(val, key) {\n if (val === null || typeof val === 'undefined') {\n return;\n }\n\n if (utils.isArray(val)) {\n key = key + '[]';\n } else {\n val = [val];\n }\n\n utils.forEach(val, function parseValue(v) {\n if (utils.isDate(v)) {\n v = v.toISOString();\n } else if (utils.isObject(v)) {\n v = JSON.stringify(v);\n }\n parts.push(encode(key) + '=' + encode(v));\n });\n });\n\n serializedParams = parts.join('&');\n }\n\n if (serializedParams) {\n var hashmarkIndex = url.indexOf('#');\n if (hashmarkIndex !== -1) {\n url = url.slice(0, hashmarkIndex);\n }\n\n url += (url.indexOf('?') === -1 ? '?' : '&') + serializedParams;\n }\n\n return url;\n};\n","'use strict';\n\nmodule.exports = function isCancel(value) {\n return !!(value && value.__CANCEL__);\n};\n","'use strict';\n\nvar utils = require('./utils');\nvar normalizeHeaderName = require('./helpers/normalizeHeaderName');\n\nvar DEFAULT_CONTENT_TYPE = {\n 'Content-Type': 'application/x-www-form-urlencoded'\n};\n\nfunction setContentTypeIfUnset(headers, value) {\n if (!utils.isUndefined(headers) && utils.isUndefined(headers['Content-Type'])) {\n headers['Content-Type'] = value;\n }\n}\n\nfunction getDefaultAdapter() {\n var adapter;\n if (typeof XMLHttpRequest !== 'undefined') {\n // For browsers use XHR adapter\n adapter = require('./adapters/xhr');\n } else if (typeof process !== 'undefined' && Object.prototype.toString.call(process) === '[object process]') {\n // For node use HTTP adapter\n adapter = require('./adapters/http');\n }\n return adapter;\n}\n\nvar defaults = {\n adapter: getDefaultAdapter(),\n\n transformRequest: [function transformRequest(data, headers) {\n normalizeHeaderName(headers, 'Accept');\n normalizeHeaderName(headers, 'Content-Type');\n if (utils.isFormData(data) ||\n utils.isArrayBuffer(data) ||\n utils.isBuffer(data) ||\n utils.isStream(data) ||\n utils.isFile(data) ||\n utils.isBlob(data)\n ) {\n return data;\n }\n if (utils.isArrayBufferView(data)) {\n return data.buffer;\n }\n if (utils.isURLSearchParams(data)) {\n setContentTypeIfUnset(headers, 'application/x-www-form-urlencoded;charset=utf-8');\n return data.toString();\n }\n if (utils.isObject(data)) {\n setContentTypeIfUnset(headers, 'application/json;charset=utf-8');\n return JSON.stringify(data);\n }\n return data;\n }],\n\n transformResponse: [function transformResponse(data) {\n /*eslint no-param-reassign:0*/\n if (typeof data === 'string') {\n try {\n data = JSON.parse(data);\n } catch (e) { /* Ignore */ }\n }\n return data;\n }],\n\n /**\n * A timeout in milliseconds to abort a request. If set to 0 (default) a\n * timeout is not created.\n */\n timeout: 0,\n\n xsrfCookieName: 'XSRF-TOKEN',\n xsrfHeaderName: 'X-XSRF-TOKEN',\n\n maxContentLength: -1,\n maxBodyLength: -1,\n\n validateStatus: function validateStatus(status) {\n return status >= 200 && status < 300;\n }\n};\n\ndefaults.headers = {\n common: {\n 'Accept': 'application/json, text/plain, */*'\n }\n};\n\nutils.forEach(['delete', 'get', 'head'], function forEachMethodNoData(method) {\n defaults.headers[method] = {};\n});\n\nutils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n defaults.headers[method] = utils.merge(DEFAULT_CONTENT_TYPE);\n});\n\nmodule.exports = defaults;\n","'use strict';\n\nvar utils = require('./../utils');\nvar settle = require('./../core/settle');\nvar cookies = require('./../helpers/cookies');\nvar buildURL = require('./../helpers/buildURL');\nvar buildFullPath = require('../core/buildFullPath');\nvar parseHeaders = require('./../helpers/parseHeaders');\nvar isURLSameOrigin = require('./../helpers/isURLSameOrigin');\nvar createError = require('../core/createError');\n\nmodule.exports = function xhrAdapter(config) {\n return new Promise(function dispatchXhrRequest(resolve, reject) {\n var requestData = config.data;\n var requestHeaders = config.headers;\n\n if (utils.isFormData(requestData)) {\n delete requestHeaders['Content-Type']; // Let the browser set it\n }\n\n var request = new XMLHttpRequest();\n\n // HTTP basic authentication\n if (config.auth) {\n var username = config.auth.username || '';\n var password = config.auth.password ? unescape(encodeURIComponent(config.auth.password)) : '';\n requestHeaders.Authorization = 'Basic ' + btoa(username + ':' + password);\n }\n\n var fullPath = buildFullPath(config.baseURL, config.url);\n request.open(config.method.toUpperCase(), buildURL(fullPath, config.params, config.paramsSerializer), true);\n\n // Set the request timeout in MS\n request.timeout = config.timeout;\n\n // Listen for ready state\n request.onreadystatechange = function handleLoad() {\n if (!request || request.readyState !== 4) {\n return;\n }\n\n // The request errored out and we didn't get a response, this will be\n // handled by onerror instead\n // With one exception: request that using file: protocol, most browsers\n // will return status as 0 even though it's a successful request\n if (request.status === 0 && !(request.responseURL && request.responseURL.indexOf('file:') === 0)) {\n return;\n }\n\n // Prepare the response\n var responseHeaders = 'getAllResponseHeaders' in request ? parseHeaders(request.getAllResponseHeaders()) : null;\n var responseData = !config.responseType || config.responseType === 'text' ? request.responseText : request.response;\n var response = {\n data: responseData,\n status: request.status,\n statusText: request.statusText,\n headers: responseHeaders,\n config: config,\n request: request\n };\n\n settle(resolve, reject, response);\n\n // Clean up request\n request = null;\n };\n\n // Handle browser request cancellation (as opposed to a manual cancellation)\n request.onabort = function handleAbort() {\n if (!request) {\n return;\n }\n\n reject(createError('Request aborted', config, 'ECONNABORTED', request));\n\n // Clean up request\n request = null;\n };\n\n // Handle low level network errors\n request.onerror = function handleError() {\n // Real errors are hidden from us by the browser\n // onerror should only fire if it's a network error\n reject(createError('Network Error', config, null, request));\n\n // Clean up request\n request = null;\n };\n\n // Handle timeout\n request.ontimeout = function handleTimeout() {\n var timeoutErrorMessage = 'timeout of ' + config.timeout + 'ms exceeded';\n if (config.timeoutErrorMessage) {\n timeoutErrorMessage = config.timeoutErrorMessage;\n }\n reject(createError(timeoutErrorMessage, config, 'ECONNABORTED',\n request));\n\n // Clean up request\n request = null;\n };\n\n // Add xsrf header\n // This is only done if running in a standard browser environment.\n // Specifically not if we're in a web worker, or react-native.\n if (utils.isStandardBrowserEnv()) {\n // Add xsrf header\n var xsrfValue = (config.withCredentials || isURLSameOrigin(fullPath)) && config.xsrfCookieName ?\n cookies.read(config.xsrfCookieName) :\n undefined;\n\n if (xsrfValue) {\n requestHeaders[config.xsrfHeaderName] = xsrfValue;\n }\n }\n\n // Add headers to the request\n if ('setRequestHeader' in request) {\n utils.forEach(requestHeaders, function setRequestHeader(val, key) {\n if (typeof requestData === 'undefined' && key.toLowerCase() === 'content-type') {\n // Remove Content-Type if data is undefined\n delete requestHeaders[key];\n } else {\n // Otherwise add header to the request\n request.setRequestHeader(key, val);\n }\n });\n }\n\n // Add withCredentials to request if needed\n if (!utils.isUndefined(config.withCredentials)) {\n request.withCredentials = !!config.withCredentials;\n }\n\n // Add responseType to request if needed\n if (config.responseType) {\n try {\n request.responseType = config.responseType;\n } catch (e) {\n // Expected DOMException thrown by browsers not compatible XMLHttpRequest Level 2.\n // But, this can be suppressed for 'json' type as it can be parsed by default 'transformResponse' function.\n if (config.responseType !== 'json') {\n throw e;\n }\n }\n }\n\n // Handle progress if needed\n if (typeof config.onDownloadProgress === 'function') {\n request.addEventListener('progress', config.onDownloadProgress);\n }\n\n // Not all browsers support upload events\n if (typeof config.onUploadProgress === 'function' && request.upload) {\n request.upload.addEventListener('progress', config.onUploadProgress);\n }\n\n if (config.cancelToken) {\n // Handle cancellation\n config.cancelToken.promise.then(function onCanceled(cancel) {\n if (!request) {\n return;\n }\n\n request.abort();\n reject(cancel);\n // Clean up request\n request = null;\n });\n }\n\n if (!requestData) {\n requestData = null;\n }\n\n // Send the request\n request.send(requestData);\n });\n};\n","'use strict';\n\nvar enhanceError = require('./enhanceError');\n\n/**\n * Create an Error with the specified message, config, error code, request and response.\n *\n * @param {string} message The error message.\n * @param {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The created error.\n */\nmodule.exports = function createError(message, config, code, request, response) {\n var error = new Error(message);\n return enhanceError(error, config, code, request, response);\n};\n","'use strict';\n\nvar utils = require('../utils');\n\n/**\n * Config-specific merge-function which creates a new config-object\n * by merging two configuration objects together.\n *\n * @param {Object} config1\n * @param {Object} config2\n * @returns {Object} New object resulting from merging config2 to config1\n */\nmodule.exports = function mergeConfig(config1, config2) {\n // eslint-disable-next-line no-param-reassign\n config2 = config2 || {};\n var config = {};\n\n var valueFromConfig2Keys = ['url', 'method', 'data'];\n var mergeDeepPropertiesKeys = ['headers', 'auth', 'proxy', 'params'];\n var defaultToConfig2Keys = [\n 'baseURL', 'transformRequest', 'transformResponse', 'paramsSerializer',\n 'timeout', 'timeoutMessage', 'withCredentials', 'adapter', 'responseType', 'xsrfCookieName',\n 'xsrfHeaderName', 'onUploadProgress', 'onDownloadProgress', 'decompress',\n 'maxContentLength', 'maxBodyLength', 'maxRedirects', 'transport', 'httpAgent',\n 'httpsAgent', 'cancelToken', 'socketPath', 'responseEncoding'\n ];\n var directMergeKeys = ['validateStatus'];\n\n function getMergedValue(target, source) {\n if (utils.isPlainObject(target) && utils.isPlainObject(source)) {\n return utils.merge(target, source);\n } else if (utils.isPlainObject(source)) {\n return utils.merge({}, source);\n } else if (utils.isArray(source)) {\n return source.slice();\n }\n return source;\n }\n\n function mergeDeepProperties(prop) {\n if (!utils.isUndefined(config2[prop])) {\n config[prop] = getMergedValue(config1[prop], config2[prop]);\n } else if (!utils.isUndefined(config1[prop])) {\n config[prop] = getMergedValue(undefined, config1[prop]);\n }\n }\n\n utils.forEach(valueFromConfig2Keys, function valueFromConfig2(prop) {\n if (!utils.isUndefined(config2[prop])) {\n config[prop] = getMergedValue(undefined, config2[prop]);\n }\n });\n\n utils.forEach(mergeDeepPropertiesKeys, mergeDeepProperties);\n\n utils.forEach(defaultToConfig2Keys, function defaultToConfig2(prop) {\n if (!utils.isUndefined(config2[prop])) {\n config[prop] = getMergedValue(undefined, config2[prop]);\n } else if (!utils.isUndefined(config1[prop])) {\n config[prop] = getMergedValue(undefined, config1[prop]);\n }\n });\n\n utils.forEach(directMergeKeys, function merge(prop) {\n if (prop in config2) {\n config[prop] = getMergedValue(config1[prop], config2[prop]);\n } else if (prop in config1) {\n config[prop] = getMergedValue(undefined, config1[prop]);\n }\n });\n\n var axiosKeys = valueFromConfig2Keys\n .concat(mergeDeepPropertiesKeys)\n .concat(defaultToConfig2Keys)\n .concat(directMergeKeys);\n\n var otherKeys = Object\n .keys(config1)\n .concat(Object.keys(config2))\n .filter(function filterAxiosKeys(key) {\n return axiosKeys.indexOf(key) === -1;\n });\n\n utils.forEach(otherKeys, mergeDeepProperties);\n\n return config;\n};\n","'use strict';\n\n/**\n * A `Cancel` is an object that is thrown when an operation is canceled.\n *\n * @class\n * @param {string=} message The message.\n */\nfunction Cancel(message) {\n this.message = message;\n}\n\nCancel.prototype.toString = function toString() {\n return 'Cancel' + (this.message ? ': ' + this.message : '');\n};\n\nCancel.prototype.__CANCEL__ = true;\n\nmodule.exports = Cancel;\n","import { __extends } from \"tslib\";\r\nimport { Container } from \"./container\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/** Class used to create rectangle container */\r\nvar Rectangle = /** @class */ (function (_super) {\r\n __extends(Rectangle, _super);\r\n /**\r\n * Creates a new Rectangle\r\n * @param name defines the control name\r\n */\r\n function Rectangle(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._thickness = 1;\r\n _this._cornerRadius = 0;\r\n return _this;\r\n }\r\n Object.defineProperty(Rectangle.prototype, \"thickness\", {\r\n /** Gets or sets border thickness */\r\n get: function () {\r\n return this._thickness;\r\n },\r\n set: function (value) {\r\n if (this._thickness === value) {\r\n return;\r\n }\r\n this._thickness = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Rectangle.prototype, \"cornerRadius\", {\r\n /** Gets or sets the corner radius angle */\r\n get: function () {\r\n return this._cornerRadius;\r\n },\r\n set: function (value) {\r\n if (value < 0) {\r\n value = 0;\r\n }\r\n if (this._cornerRadius === value) {\r\n return;\r\n }\r\n this._cornerRadius = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Rectangle.prototype._getTypeName = function () {\r\n return \"Rectangle\";\r\n };\r\n Rectangle.prototype._localDraw = function (context) {\r\n context.save();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n if (this._background) {\r\n context.fillStyle = this._background;\r\n if (this._cornerRadius) {\r\n this._drawRoundedRect(context, this._thickness / 2);\r\n context.fill();\r\n }\r\n else {\r\n context.fillRect(this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n }\r\n }\r\n if (this._thickness) {\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n if (this.color) {\r\n context.strokeStyle = this.color;\r\n }\r\n context.lineWidth = this._thickness;\r\n if (this._cornerRadius) {\r\n this._drawRoundedRect(context, this._thickness / 2);\r\n context.stroke();\r\n }\r\n else {\r\n context.strokeRect(this._currentMeasure.left + this._thickness / 2, this._currentMeasure.top + this._thickness / 2, this._currentMeasure.width - this._thickness, this._currentMeasure.height - this._thickness);\r\n }\r\n }\r\n context.restore();\r\n };\r\n Rectangle.prototype._additionalProcessing = function (parentMeasure, context) {\r\n _super.prototype._additionalProcessing.call(this, parentMeasure, context);\r\n this._measureForChildren.width -= 2 * this._thickness;\r\n this._measureForChildren.height -= 2 * this._thickness;\r\n this._measureForChildren.left += this._thickness;\r\n this._measureForChildren.top += this._thickness;\r\n };\r\n Rectangle.prototype._drawRoundedRect = function (context, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n var x = this._currentMeasure.left + offset;\r\n var y = this._currentMeasure.top + offset;\r\n var width = this._currentMeasure.width - offset * 2;\r\n var height = this._currentMeasure.height - offset * 2;\r\n var radius = Math.min(height / 2 - 2, Math.min(width / 2 - 2, this._cornerRadius));\r\n context.beginPath();\r\n context.moveTo(x + radius, y);\r\n context.lineTo(x + width - radius, y);\r\n context.quadraticCurveTo(x + width, y, x + width, y + radius);\r\n context.lineTo(x + width, y + height - radius);\r\n context.quadraticCurveTo(x + width, y + height, x + width - radius, y + height);\r\n context.lineTo(x + radius, y + height);\r\n context.quadraticCurveTo(x, y + height, x, y + height - radius);\r\n context.lineTo(x, y + radius);\r\n context.quadraticCurveTo(x, y, x + radius, y);\r\n context.closePath();\r\n };\r\n Rectangle.prototype._clipForChildren = function (context) {\r\n if (this._cornerRadius) {\r\n this._drawRoundedRect(context, this._thickness);\r\n context.clip();\r\n }\r\n };\r\n return Rectangle;\r\n}(Container));\r\nexport { Rectangle };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Rectangle\"] = Rectangle;\r\n//# sourceMappingURL=rectangle.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { ValueAndUnit } from \"../valueAndUnit\";\r\nimport { Control } from \"./control\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Enum that determines the text-wrapping mode to use.\r\n */\r\nexport var TextWrapping;\r\n(function (TextWrapping) {\r\n /**\r\n * Clip the text when it's larger than Control.width; this is the default mode.\r\n */\r\n TextWrapping[TextWrapping[\"Clip\"] = 0] = \"Clip\";\r\n /**\r\n * Wrap the text word-wise, i.e. try to add line-breaks at word boundary to fit within Control.width.\r\n */\r\n TextWrapping[TextWrapping[\"WordWrap\"] = 1] = \"WordWrap\";\r\n /**\r\n * Ellipsize the text, i.e. shrink with trailing … when text is larger than Control.width.\r\n */\r\n TextWrapping[TextWrapping[\"Ellipsis\"] = 2] = \"Ellipsis\";\r\n})(TextWrapping || (TextWrapping = {}));\r\n/**\r\n * Class used to create text block control\r\n */\r\nvar TextBlock = /** @class */ (function (_super) {\r\n __extends(TextBlock, _super);\r\n /**\r\n * Creates a new TextBlock object\r\n * @param name defines the name of the control\r\n * @param text defines the text to display (emptry string by default)\r\n */\r\n function TextBlock(\r\n /**\r\n * Defines the name of the control\r\n */\r\n name, text) {\r\n if (text === void 0) { text = \"\"; }\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._text = \"\";\r\n _this._textWrapping = TextWrapping.Clip;\r\n _this._textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_CENTER;\r\n _this._textVerticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n _this._resizeToFit = false;\r\n _this._lineSpacing = new ValueAndUnit(0);\r\n _this._outlineWidth = 0;\r\n _this._outlineColor = \"white\";\r\n /**\r\n * An event triggered after the text is changed\r\n */\r\n _this.onTextChangedObservable = new Observable();\r\n /**\r\n * An event triggered after the text was broken up into lines\r\n */\r\n _this.onLinesReadyObservable = new Observable();\r\n _this.text = text;\r\n return _this;\r\n }\r\n Object.defineProperty(TextBlock.prototype, \"lines\", {\r\n /**\r\n * Return the line list (you may need to use the onLinesReadyObservable to make sure the list is ready)\r\n */\r\n get: function () {\r\n return this._lines;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"resizeToFit\", {\r\n /**\r\n * Gets or sets an boolean indicating that the TextBlock will be resized to fit container\r\n */\r\n get: function () {\r\n return this._resizeToFit;\r\n },\r\n /**\r\n * Gets or sets an boolean indicating that the TextBlock will be resized to fit container\r\n */\r\n set: function (value) {\r\n if (this._resizeToFit === value) {\r\n return;\r\n }\r\n this._resizeToFit = value;\r\n if (this._resizeToFit) {\r\n this._width.ignoreAdaptiveScaling = true;\r\n this._height.ignoreAdaptiveScaling = true;\r\n }\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"textWrapping\", {\r\n /**\r\n * Gets or sets a boolean indicating if text must be wrapped\r\n */\r\n get: function () {\r\n return this._textWrapping;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if text must be wrapped\r\n */\r\n set: function (value) {\r\n if (this._textWrapping === value) {\r\n return;\r\n }\r\n this._textWrapping = +value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"text\", {\r\n /**\r\n * Gets or sets text to display\r\n */\r\n get: function () {\r\n return this._text;\r\n },\r\n /**\r\n * Gets or sets text to display\r\n */\r\n set: function (value) {\r\n if (this._text === value) {\r\n return;\r\n }\r\n this._text = value;\r\n this._markAsDirty();\r\n this.onTextChangedObservable.notifyObservers(this);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"textHorizontalAlignment\", {\r\n /**\r\n * Gets or sets text horizontal alignment (BABYLON.GUI.Control.HORIZONTAL_ALIGNMENT_CENTER by default)\r\n */\r\n get: function () {\r\n return this._textHorizontalAlignment;\r\n },\r\n /**\r\n * Gets or sets text horizontal alignment (BABYLON.GUI.Control.HORIZONTAL_ALIGNMENT_CENTER by default)\r\n */\r\n set: function (value) {\r\n if (this._textHorizontalAlignment === value) {\r\n return;\r\n }\r\n this._textHorizontalAlignment = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"textVerticalAlignment\", {\r\n /**\r\n * Gets or sets text vertical alignment (BABYLON.GUI.Control.VERTICAL_ALIGNMENT_CENTER by default)\r\n */\r\n get: function () {\r\n return this._textVerticalAlignment;\r\n },\r\n /**\r\n * Gets or sets text vertical alignment (BABYLON.GUI.Control.VERTICAL_ALIGNMENT_CENTER by default)\r\n */\r\n set: function (value) {\r\n if (this._textVerticalAlignment === value) {\r\n return;\r\n }\r\n this._textVerticalAlignment = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"lineSpacing\", {\r\n /**\r\n * Gets or sets line spacing value\r\n */\r\n get: function () {\r\n return this._lineSpacing.toString(this._host);\r\n },\r\n /**\r\n * Gets or sets line spacing value\r\n */\r\n set: function (value) {\r\n if (this._lineSpacing.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"outlineWidth\", {\r\n /**\r\n * Gets or sets outlineWidth of the text to display\r\n */\r\n get: function () {\r\n return this._outlineWidth;\r\n },\r\n /**\r\n * Gets or sets outlineWidth of the text to display\r\n */\r\n set: function (value) {\r\n if (this._outlineWidth === value) {\r\n return;\r\n }\r\n this._outlineWidth = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"outlineColor\", {\r\n /**\r\n * Gets or sets outlineColor of the text to display\r\n */\r\n get: function () {\r\n return this._outlineColor;\r\n },\r\n /**\r\n * Gets or sets outlineColor of the text to display\r\n */\r\n set: function (value) {\r\n if (this._outlineColor === value) {\r\n return;\r\n }\r\n this._outlineColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n TextBlock.prototype._getTypeName = function () {\r\n return \"TextBlock\";\r\n };\r\n TextBlock.prototype._processMeasures = function (parentMeasure, context) {\r\n if (!this._fontOffset) {\r\n this._fontOffset = Control._GetFontOffset(context.font);\r\n }\r\n _super.prototype._processMeasures.call(this, parentMeasure, context);\r\n // Prepare lines\r\n this._lines = this._breakLines(this._currentMeasure.width, context);\r\n this.onLinesReadyObservable.notifyObservers(this);\r\n var maxLineWidth = 0;\r\n for (var i = 0; i < this._lines.length; i++) {\r\n var line = this._lines[i];\r\n if (line.width > maxLineWidth) {\r\n maxLineWidth = line.width;\r\n }\r\n }\r\n if (this._resizeToFit) {\r\n if (this._textWrapping === TextWrapping.Clip) {\r\n var newWidth = this.paddingLeftInPixels + this.paddingRightInPixels + maxLineWidth;\r\n if (newWidth !== this._width.internalValue) {\r\n this._width.updateInPlace(newWidth, ValueAndUnit.UNITMODE_PIXEL);\r\n this._rebuildLayout = true;\r\n }\r\n }\r\n var newHeight = this.paddingTopInPixels + this.paddingBottomInPixels + this._fontOffset.height * this._lines.length;\r\n if (this._lines.length > 0 && this._lineSpacing.internalValue !== 0) {\r\n var lineSpacing = 0;\r\n if (this._lineSpacing.isPixel) {\r\n lineSpacing = this._lineSpacing.getValue(this._host);\r\n }\r\n else {\r\n lineSpacing = (this._lineSpacing.getValue(this._host) * this._height.getValueInPixel(this._host, this._cachedParentMeasure.height));\r\n }\r\n newHeight += (this._lines.length - 1) * lineSpacing;\r\n }\r\n if (newHeight !== this._height.internalValue) {\r\n this._height.updateInPlace(newHeight, ValueAndUnit.UNITMODE_PIXEL);\r\n this._rebuildLayout = true;\r\n }\r\n }\r\n };\r\n TextBlock.prototype._drawText = function (text, textWidth, y, context) {\r\n var width = this._currentMeasure.width;\r\n var x = 0;\r\n switch (this._textHorizontalAlignment) {\r\n case Control.HORIZONTAL_ALIGNMENT_LEFT:\r\n x = 0;\r\n break;\r\n case Control.HORIZONTAL_ALIGNMENT_RIGHT:\r\n x = width - textWidth;\r\n break;\r\n case Control.HORIZONTAL_ALIGNMENT_CENTER:\r\n x = (width - textWidth) / 2;\r\n break;\r\n }\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n if (this.outlineWidth) {\r\n context.strokeText(text, this._currentMeasure.left + x, y);\r\n }\r\n context.fillText(text, this._currentMeasure.left + x, y);\r\n };\r\n /** @hidden */\r\n TextBlock.prototype._draw = function (context, invalidatedRectangle) {\r\n context.save();\r\n this._applyStates(context);\r\n // Render lines\r\n this._renderLines(context);\r\n context.restore();\r\n };\r\n TextBlock.prototype._applyStates = function (context) {\r\n _super.prototype._applyStates.call(this, context);\r\n if (this.outlineWidth) {\r\n context.lineWidth = this.outlineWidth;\r\n context.strokeStyle = this.outlineColor;\r\n }\r\n };\r\n TextBlock.prototype._breakLines = function (refWidth, context) {\r\n var lines = [];\r\n var _lines = this.text.split(\"\\n\");\r\n if (this._textWrapping === TextWrapping.Ellipsis) {\r\n for (var _i = 0, _lines_1 = _lines; _i < _lines_1.length; _i++) {\r\n var _line = _lines_1[_i];\r\n lines.push(this._parseLineEllipsis(_line, refWidth, context));\r\n }\r\n }\r\n else if (this._textWrapping === TextWrapping.WordWrap) {\r\n for (var _a = 0, _lines_2 = _lines; _a < _lines_2.length; _a++) {\r\n var _line = _lines_2[_a];\r\n lines.push.apply(lines, this._parseLineWordWrap(_line, refWidth, context));\r\n }\r\n }\r\n else {\r\n for (var _b = 0, _lines_3 = _lines; _b < _lines_3.length; _b++) {\r\n var _line = _lines_3[_b];\r\n lines.push(this._parseLine(_line, context));\r\n }\r\n }\r\n return lines;\r\n };\r\n TextBlock.prototype._parseLine = function (line, context) {\r\n if (line === void 0) { line = ''; }\r\n return { text: line, width: context.measureText(line).width };\r\n };\r\n TextBlock.prototype._parseLineEllipsis = function (line, width, context) {\r\n if (line === void 0) { line = ''; }\r\n var lineWidth = context.measureText(line).width;\r\n if (lineWidth > width) {\r\n line += '…';\r\n }\r\n while (line.length > 2 && lineWidth > width) {\r\n line = line.slice(0, -2) + '…';\r\n lineWidth = context.measureText(line).width;\r\n }\r\n return { text: line, width: lineWidth };\r\n };\r\n TextBlock.prototype._parseLineWordWrap = function (line, width, context) {\r\n if (line === void 0) { line = ''; }\r\n var lines = [];\r\n var words = line.split(' ');\r\n var lineWidth = 0;\r\n for (var n = 0; n < words.length; n++) {\r\n var testLine = n > 0 ? line + \" \" + words[n] : words[0];\r\n var metrics = context.measureText(testLine);\r\n var testWidth = metrics.width;\r\n if (testWidth > width && n > 0) {\r\n lines.push({ text: line, width: lineWidth });\r\n line = words[n];\r\n lineWidth = context.measureText(line).width;\r\n }\r\n else {\r\n lineWidth = testWidth;\r\n line = testLine;\r\n }\r\n }\r\n lines.push({ text: line, width: lineWidth });\r\n return lines;\r\n };\r\n TextBlock.prototype._renderLines = function (context) {\r\n var height = this._currentMeasure.height;\r\n var rootY = 0;\r\n switch (this._textVerticalAlignment) {\r\n case Control.VERTICAL_ALIGNMENT_TOP:\r\n rootY = this._fontOffset.ascent;\r\n break;\r\n case Control.VERTICAL_ALIGNMENT_BOTTOM:\r\n rootY = height - this._fontOffset.height * (this._lines.length - 1) - this._fontOffset.descent;\r\n break;\r\n case Control.VERTICAL_ALIGNMENT_CENTER:\r\n rootY = this._fontOffset.ascent + (height - this._fontOffset.height * this._lines.length) / 2;\r\n break;\r\n }\r\n rootY += this._currentMeasure.top;\r\n for (var i = 0; i < this._lines.length; i++) {\r\n var line = this._lines[i];\r\n if (i !== 0 && this._lineSpacing.internalValue !== 0) {\r\n if (this._lineSpacing.isPixel) {\r\n rootY += this._lineSpacing.getValue(this._host);\r\n }\r\n else {\r\n rootY = rootY + (this._lineSpacing.getValue(this._host) * this._height.getValueInPixel(this._host, this._cachedParentMeasure.height));\r\n }\r\n }\r\n this._drawText(line.text, line.width, rootY, context);\r\n rootY += this._fontOffset.height;\r\n }\r\n };\r\n /**\r\n * Given a width constraint applied on the text block, find the expected height\r\n * @returns expected height\r\n */\r\n TextBlock.prototype.computeExpectedHeight = function () {\r\n if (this.text && this.widthInPixels) {\r\n var context_1 = document.createElement('canvas').getContext('2d');\r\n if (context_1) {\r\n this._applyStates(context_1);\r\n if (!this._fontOffset) {\r\n this._fontOffset = Control._GetFontOffset(context_1.font);\r\n }\r\n var lines = this._lines ? this._lines : this._breakLines(this.widthInPixels - this.paddingLeftInPixels - this.paddingRightInPixels, context_1);\r\n var newHeight = this.paddingTopInPixels + this.paddingBottomInPixels + this._fontOffset.height * lines.length;\r\n if (lines.length > 0 && this._lineSpacing.internalValue !== 0) {\r\n var lineSpacing = 0;\r\n if (this._lineSpacing.isPixel) {\r\n lineSpacing = this._lineSpacing.getValue(this._host);\r\n }\r\n else {\r\n lineSpacing = (this._lineSpacing.getValue(this._host) * this._height.getValueInPixel(this._host, this._cachedParentMeasure.height));\r\n }\r\n newHeight += (lines.length - 1) * lineSpacing;\r\n }\r\n return newHeight;\r\n }\r\n }\r\n return 0;\r\n };\r\n TextBlock.prototype.dispose = function () {\r\n _super.prototype.dispose.call(this);\r\n this.onTextChangedObservable.clear();\r\n };\r\n return TextBlock;\r\n}(Control));\r\nexport { TextBlock };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.TextBlock\"] = TextBlock;\r\n//# sourceMappingURL=textBlock.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { Tools } from \"@babylonjs/core/Misc/tools\";\r\nimport { Control } from \"./control\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create 2D images\r\n */\r\nvar Image = /** @class */ (function (_super) {\r\n __extends(Image, _super);\r\n /**\r\n * Creates a new Image\r\n * @param name defines the control name\r\n * @param url defines the image url\r\n */\r\n function Image(name, url) {\r\n if (url === void 0) { url = null; }\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._workingCanvas = null;\r\n _this._loaded = false;\r\n _this._stretch = Image.STRETCH_FILL;\r\n _this._autoScale = false;\r\n _this._sourceLeft = 0;\r\n _this._sourceTop = 0;\r\n _this._sourceWidth = 0;\r\n _this._sourceHeight = 0;\r\n _this._svgAttributesComputationCompleted = false;\r\n _this._isSVG = false;\r\n _this._cellWidth = 0;\r\n _this._cellHeight = 0;\r\n _this._cellId = -1;\r\n _this._populateNinePatchSlicesFromImage = false;\r\n /**\r\n * Observable notified when the content is loaded\r\n */\r\n _this.onImageLoadedObservable = new Observable();\r\n /**\r\n * Observable notified when _sourceLeft, _sourceTop, _sourceWidth and _sourceHeight are computed\r\n */\r\n _this.onSVGAttributesComputedObservable = new Observable();\r\n _this.source = url;\r\n return _this;\r\n }\r\n Object.defineProperty(Image.prototype, \"isLoaded\", {\r\n /**\r\n * Gets a boolean indicating that the content is loaded\r\n */\r\n get: function () {\r\n return this._loaded;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"populateNinePatchSlicesFromImage\", {\r\n /**\r\n * Gets or sets a boolean indicating if nine patch slices (left, top, right, bottom) should be read from image data\r\n */\r\n get: function () {\r\n return this._populateNinePatchSlicesFromImage;\r\n },\r\n set: function (value) {\r\n if (this._populateNinePatchSlicesFromImage === value) {\r\n return;\r\n }\r\n this._populateNinePatchSlicesFromImage = value;\r\n if (this._populateNinePatchSlicesFromImage && this._loaded) {\r\n this._extractNinePatchSliceDataFromImage();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"detectPointerOnOpaqueOnly\", {\r\n /**\r\n * Gets or sets a boolean indicating if pointers should only be validated on pixels with alpha > 0.\r\n * Beware using this as this will comsume more memory as the image has to be stored twice\r\n */\r\n get: function () {\r\n return this._detectPointerOnOpaqueOnly;\r\n },\r\n set: function (value) {\r\n if (this._detectPointerOnOpaqueOnly === value) {\r\n return;\r\n }\r\n this._detectPointerOnOpaqueOnly = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"sliceLeft\", {\r\n /**\r\n * Gets or sets the left value for slicing (9-patch)\r\n */\r\n get: function () {\r\n return this._sliceLeft;\r\n },\r\n set: function (value) {\r\n if (this._sliceLeft === value) {\r\n return;\r\n }\r\n this._sliceLeft = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"sliceRight\", {\r\n /**\r\n * Gets or sets the right value for slicing (9-patch)\r\n */\r\n get: function () {\r\n return this._sliceRight;\r\n },\r\n set: function (value) {\r\n if (this._sliceRight === value) {\r\n return;\r\n }\r\n this._sliceRight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"sliceTop\", {\r\n /**\r\n * Gets or sets the top value for slicing (9-patch)\r\n */\r\n get: function () {\r\n return this._sliceTop;\r\n },\r\n set: function (value) {\r\n if (this._sliceTop === value) {\r\n return;\r\n }\r\n this._sliceTop = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"sliceBottom\", {\r\n /**\r\n * Gets or sets the bottom value for slicing (9-patch)\r\n */\r\n get: function () {\r\n return this._sliceBottom;\r\n },\r\n set: function (value) {\r\n if (this._sliceBottom === value) {\r\n return;\r\n }\r\n this._sliceBottom = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"sourceLeft\", {\r\n /**\r\n * Gets or sets the left coordinate in the source image\r\n */\r\n get: function () {\r\n return this._sourceLeft;\r\n },\r\n set: function (value) {\r\n if (this._sourceLeft === value) {\r\n return;\r\n }\r\n this._sourceLeft = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"sourceTop\", {\r\n /**\r\n * Gets or sets the top coordinate in the source image\r\n */\r\n get: function () {\r\n return this._sourceTop;\r\n },\r\n set: function (value) {\r\n if (this._sourceTop === value) {\r\n return;\r\n }\r\n this._sourceTop = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"sourceWidth\", {\r\n /**\r\n * Gets or sets the width to capture in the source image\r\n */\r\n get: function () {\r\n return this._sourceWidth;\r\n },\r\n set: function (value) {\r\n if (this._sourceWidth === value) {\r\n return;\r\n }\r\n this._sourceWidth = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"sourceHeight\", {\r\n /**\r\n * Gets or sets the height to capture in the source image\r\n */\r\n get: function () {\r\n return this._sourceHeight;\r\n },\r\n set: function (value) {\r\n if (this._sourceHeight === value) {\r\n return;\r\n }\r\n this._sourceHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"isSVG\", {\r\n /** Indicates if the format of the image is SVG */\r\n get: function () {\r\n return this._isSVG;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"svgAttributesComputationCompleted\", {\r\n /** Gets the status of the SVG attributes computation (sourceLeft, sourceTop, sourceWidth, sourceHeight) */\r\n get: function () {\r\n return this._svgAttributesComputationCompleted;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"autoScale\", {\r\n /**\r\n * Gets or sets a boolean indicating if the image can force its container to adapt its size\r\n * @see http://doc.babylonjs.com/how_to/gui#image\r\n */\r\n get: function () {\r\n return this._autoScale;\r\n },\r\n set: function (value) {\r\n if (this._autoScale === value) {\r\n return;\r\n }\r\n this._autoScale = value;\r\n if (value && this._loaded) {\r\n this.synchronizeSizeWithContent();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"stretch\", {\r\n /** Gets or sets the streching mode used by the image */\r\n get: function () {\r\n return this._stretch;\r\n },\r\n set: function (value) {\r\n if (this._stretch === value) {\r\n return;\r\n }\r\n this._stretch = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n Image.prototype._rotate90 = function (n, preserveProperties) {\r\n if (preserveProperties === void 0) { preserveProperties = false; }\r\n var canvas = document.createElement('canvas');\r\n var context = canvas.getContext('2d');\r\n var width = this._domImage.width;\r\n var height = this._domImage.height;\r\n canvas.width = height;\r\n canvas.height = width;\r\n context.translate(canvas.width / 2, canvas.height / 2);\r\n context.rotate(n * Math.PI / 2);\r\n context.drawImage(this._domImage, 0, 0, width, height, -width / 2, -height / 2, width, height);\r\n var dataUrl = canvas.toDataURL(\"image/jpg\");\r\n var rotatedImage = new Image(this.name + \"rotated\", dataUrl);\r\n if (preserveProperties) {\r\n rotatedImage._stretch = this._stretch;\r\n rotatedImage._autoScale = this._autoScale;\r\n rotatedImage._cellId = this._cellId;\r\n rotatedImage._cellWidth = n % 1 ? this._cellHeight : this._cellWidth;\r\n rotatedImage._cellHeight = n % 1 ? this._cellWidth : this._cellHeight;\r\n }\r\n this._handleRotationForSVGImage(this, rotatedImage, n);\r\n return rotatedImage;\r\n };\r\n Image.prototype._handleRotationForSVGImage = function (srcImage, dstImage, n) {\r\n var _this = this;\r\n if (!srcImage._isSVG) {\r\n return;\r\n }\r\n if (srcImage._svgAttributesComputationCompleted) {\r\n this._rotate90SourceProperties(srcImage, dstImage, n);\r\n this._markAsDirty();\r\n }\r\n else {\r\n srcImage.onSVGAttributesComputedObservable.addOnce(function () {\r\n _this._rotate90SourceProperties(srcImage, dstImage, n);\r\n _this._markAsDirty();\r\n });\r\n }\r\n };\r\n Image.prototype._rotate90SourceProperties = function (srcImage, dstImage, n) {\r\n var _a, _b;\r\n var srcLeft = srcImage.sourceLeft, srcTop = srcImage.sourceTop, srcWidth = srcImage.domImage.width, srcHeight = srcImage.domImage.height;\r\n var dstLeft = srcLeft, dstTop = srcTop, dstWidth = srcImage.sourceWidth, dstHeight = srcImage.sourceHeight;\r\n if (n != 0) {\r\n var mult = n < 0 ? -1 : 1;\r\n n = n % 4;\r\n for (var i = 0; i < Math.abs(n); ++i) {\r\n dstLeft = -(srcTop - srcHeight / 2) * mult + srcHeight / 2;\r\n dstTop = (srcLeft - srcWidth / 2) * mult + srcWidth / 2;\r\n _a = [dstHeight, dstWidth], dstWidth = _a[0], dstHeight = _a[1];\r\n if (n < 0) {\r\n dstTop -= dstHeight;\r\n }\r\n else {\r\n dstLeft -= dstWidth;\r\n }\r\n srcLeft = dstLeft;\r\n srcTop = dstTop;\r\n _b = [srcHeight, srcWidth], srcWidth = _b[0], srcHeight = _b[1];\r\n }\r\n }\r\n dstImage.sourceLeft = dstLeft;\r\n dstImage.sourceTop = dstTop;\r\n dstImage.sourceWidth = dstWidth;\r\n dstImage.sourceHeight = dstHeight;\r\n };\r\n Object.defineProperty(Image.prototype, \"domImage\", {\r\n get: function () {\r\n return this._domImage;\r\n },\r\n /**\r\n * Gets or sets the internal DOM image used to render the control\r\n */\r\n set: function (value) {\r\n var _this = this;\r\n this._domImage = value;\r\n this._loaded = false;\r\n if (this._domImage.width) {\r\n this._onImageLoaded();\r\n }\r\n else {\r\n this._domImage.onload = function () {\r\n _this._onImageLoaded();\r\n };\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Image.prototype._onImageLoaded = function () {\r\n this._imageWidth = this._domImage.width;\r\n this._imageHeight = this._domImage.height;\r\n this._loaded = true;\r\n if (this._populateNinePatchSlicesFromImage) {\r\n this._extractNinePatchSliceDataFromImage();\r\n }\r\n if (this._autoScale) {\r\n this.synchronizeSizeWithContent();\r\n }\r\n this.onImageLoadedObservable.notifyObservers(this);\r\n this._markAsDirty();\r\n };\r\n Image.prototype._extractNinePatchSliceDataFromImage = function () {\r\n if (!this._workingCanvas) {\r\n this._workingCanvas = document.createElement('canvas');\r\n }\r\n var canvas = this._workingCanvas;\r\n var context = canvas.getContext('2d');\r\n var width = this._domImage.width;\r\n var height = this._domImage.height;\r\n canvas.width = width;\r\n canvas.height = height;\r\n context.drawImage(this._domImage, 0, 0, width, height);\r\n var imageData = context.getImageData(0, 0, width, height);\r\n // Left and right\r\n this._sliceLeft = -1;\r\n this._sliceRight = -1;\r\n for (var x = 0; x < width; x++) {\r\n var alpha = imageData.data[x * 4 + 3];\r\n if (alpha > 127 && this._sliceLeft === -1) {\r\n this._sliceLeft = x;\r\n continue;\r\n }\r\n if (alpha < 127 && this._sliceLeft > -1) {\r\n this._sliceRight = x;\r\n break;\r\n }\r\n }\r\n // top and bottom\r\n this._sliceTop = -1;\r\n this._sliceBottom = -1;\r\n for (var y = 0; y < height; y++) {\r\n var alpha = imageData.data[y * width * 4 + 3];\r\n if (alpha > 127 && this._sliceTop === -1) {\r\n this._sliceTop = y;\r\n continue;\r\n }\r\n if (alpha < 127 && this._sliceTop > -1) {\r\n this._sliceBottom = y;\r\n break;\r\n }\r\n }\r\n };\r\n Object.defineProperty(Image.prototype, \"source\", {\r\n /**\r\n * Gets or sets image source url\r\n */\r\n set: function (value) {\r\n var _this = this;\r\n if (this._source === value) {\r\n return;\r\n }\r\n this._loaded = false;\r\n this._source = value;\r\n if (value) {\r\n value = this._svgCheck(value);\r\n }\r\n this._domImage = document.createElement(\"img\");\r\n this._domImage.onload = function () {\r\n _this._onImageLoaded();\r\n };\r\n if (value) {\r\n Tools.SetCorsBehavior(value, this._domImage);\r\n this._domImage.src = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Checks for svg document with icon id present\r\n */\r\n Image.prototype._svgCheck = function (value) {\r\n var _this = this;\r\n if (window.SVGSVGElement && (value.search(/.svg#/gi) !== -1) && (value.indexOf(\"#\") === value.lastIndexOf(\"#\"))) {\r\n this._isSVG = true;\r\n var svgsrc = value.split('#')[0];\r\n var elemid = value.split('#')[1];\r\n // check if object alr exist in document\r\n var svgExist = document.body.querySelector('object[data=\"' + svgsrc + '\"]');\r\n if (svgExist) {\r\n var svgDoc = svgExist.contentDocument;\r\n // get viewbox width and height, get svg document width and height in px\r\n if (svgDoc && svgDoc.documentElement) {\r\n var vb = svgDoc.documentElement.getAttribute(\"viewBox\");\r\n var docwidth = Number(svgDoc.documentElement.getAttribute(\"width\"));\r\n var docheight = Number(svgDoc.documentElement.getAttribute(\"height\"));\r\n var elem = svgDoc.getElementById(elemid);\r\n if (elem && vb && docwidth && docheight) {\r\n this._getSVGAttribs(svgExist, elemid);\r\n return value;\r\n }\r\n }\r\n // wait for object to load\r\n svgExist.addEventListener(\"load\", function () {\r\n _this._getSVGAttribs(svgExist, elemid);\r\n });\r\n }\r\n else {\r\n // create document object\r\n var svgImage = document.createElement(\"object\");\r\n svgImage.data = svgsrc;\r\n svgImage.type = \"image/svg+xml\";\r\n svgImage.width = \"0%\";\r\n svgImage.height = \"0%\";\r\n document.body.appendChild(svgImage);\r\n // when the object has loaded, get the element attribs\r\n svgImage.onload = function () {\r\n var svgobj = document.body.querySelector('object[data=\"' + svgsrc + '\"]');\r\n if (svgobj) {\r\n _this._getSVGAttribs(svgobj, elemid);\r\n }\r\n };\r\n }\r\n return svgsrc;\r\n }\r\n else {\r\n return value;\r\n }\r\n };\r\n /**\r\n * Sets sourceLeft, sourceTop, sourceWidth, sourceHeight automatically\r\n * given external svg file and icon id\r\n */\r\n Image.prototype._getSVGAttribs = function (svgsrc, elemid) {\r\n var svgDoc = svgsrc.contentDocument;\r\n // get viewbox width and height, get svg document width and height in px\r\n if (svgDoc && svgDoc.documentElement) {\r\n var vb = svgDoc.documentElement.getAttribute(\"viewBox\");\r\n var docwidth = Number(svgDoc.documentElement.getAttribute(\"width\"));\r\n var docheight = Number(svgDoc.documentElement.getAttribute(\"height\"));\r\n // get element bbox and matrix transform\r\n var elem = svgDoc.getElementById(elemid);\r\n if (vb && docwidth && docheight && elem) {\r\n var vb_width = Number(vb.split(\" \")[2]);\r\n var vb_height = Number(vb.split(\" \")[3]);\r\n var elem_bbox = elem.getBBox();\r\n var elem_matrix_a = 1;\r\n var elem_matrix_d = 1;\r\n var elem_matrix_e = 0;\r\n var elem_matrix_f = 0;\r\n if (elem.transform && elem.transform.baseVal.consolidate()) {\r\n elem_matrix_a = elem.transform.baseVal.consolidate().matrix.a;\r\n elem_matrix_d = elem.transform.baseVal.consolidate().matrix.d;\r\n elem_matrix_e = elem.transform.baseVal.consolidate().matrix.e;\r\n elem_matrix_f = elem.transform.baseVal.consolidate().matrix.f;\r\n }\r\n // compute source coordinates and dimensions\r\n this.sourceLeft = ((elem_matrix_a * elem_bbox.x + elem_matrix_e) * docwidth) / vb_width;\r\n this.sourceTop = ((elem_matrix_d * elem_bbox.y + elem_matrix_f) * docheight) / vb_height;\r\n this.sourceWidth = (elem_bbox.width * elem_matrix_a) * (docwidth / vb_width);\r\n this.sourceHeight = (elem_bbox.height * elem_matrix_d) * (docheight / vb_height);\r\n this._svgAttributesComputationCompleted = true;\r\n this.onSVGAttributesComputedObservable.notifyObservers(this);\r\n }\r\n }\r\n };\r\n Object.defineProperty(Image.prototype, \"cellWidth\", {\r\n /**\r\n * Gets or sets the cell width to use when animation sheet is enabled\r\n * @see http://doc.babylonjs.com/how_to/gui#image\r\n */\r\n get: function () {\r\n return this._cellWidth;\r\n },\r\n set: function (value) {\r\n if (this._cellWidth === value) {\r\n return;\r\n }\r\n this._cellWidth = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"cellHeight\", {\r\n /**\r\n * Gets or sets the cell height to use when animation sheet is enabled\r\n * @see http://doc.babylonjs.com/how_to/gui#image\r\n */\r\n get: function () {\r\n return this._cellHeight;\r\n },\r\n set: function (value) {\r\n if (this._cellHeight === value) {\r\n return;\r\n }\r\n this._cellHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"cellId\", {\r\n /**\r\n * Gets or sets the cell id to use (this will turn on the animation sheet mode)\r\n * @see http://doc.babylonjs.com/how_to/gui#image\r\n */\r\n get: function () {\r\n return this._cellId;\r\n },\r\n set: function (value) {\r\n if (this._cellId === value) {\r\n return;\r\n }\r\n this._cellId = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Tests if a given coordinates belong to the current control\r\n * @param x defines x coordinate to test\r\n * @param y defines y coordinate to test\r\n * @returns true if the coordinates are inside the control\r\n */\r\n Image.prototype.contains = function (x, y) {\r\n if (!_super.prototype.contains.call(this, x, y)) {\r\n return false;\r\n }\r\n if (!this._detectPointerOnOpaqueOnly || !this._workingCanvas) {\r\n return true;\r\n }\r\n var canvas = this._workingCanvas;\r\n var context = canvas.getContext(\"2d\");\r\n var width = this._currentMeasure.width | 0;\r\n var height = this._currentMeasure.height | 0;\r\n var imageData = context.getImageData(0, 0, width, height).data;\r\n x = (x - this._currentMeasure.left) | 0;\r\n y = (y - this._currentMeasure.top) | 0;\r\n var pickedPixel = imageData[(x + y * this._currentMeasure.width) * 4 + 3];\r\n return pickedPixel > 0;\r\n };\r\n Image.prototype._getTypeName = function () {\r\n return \"Image\";\r\n };\r\n /** Force the control to synchronize with its content */\r\n Image.prototype.synchronizeSizeWithContent = function () {\r\n if (!this._loaded) {\r\n return;\r\n }\r\n this.width = this._domImage.width + \"px\";\r\n this.height = this._domImage.height + \"px\";\r\n };\r\n Image.prototype._processMeasures = function (parentMeasure, context) {\r\n if (this._loaded) {\r\n switch (this._stretch) {\r\n case Image.STRETCH_NONE:\r\n break;\r\n case Image.STRETCH_FILL:\r\n break;\r\n case Image.STRETCH_UNIFORM:\r\n break;\r\n case Image.STRETCH_NINE_PATCH:\r\n break;\r\n case Image.STRETCH_EXTEND:\r\n if (this._autoScale) {\r\n this.synchronizeSizeWithContent();\r\n }\r\n if (this.parent && this.parent.parent) { // Will update root size if root is not the top root\r\n this.parent.adaptWidthToChildren = true;\r\n this.parent.adaptHeightToChildren = true;\r\n }\r\n break;\r\n }\r\n }\r\n _super.prototype._processMeasures.call(this, parentMeasure, context);\r\n };\r\n Image.prototype._prepareWorkingCanvasForOpaqueDetection = function () {\r\n if (!this._detectPointerOnOpaqueOnly) {\r\n return;\r\n }\r\n if (!this._workingCanvas) {\r\n this._workingCanvas = document.createElement('canvas');\r\n }\r\n var canvas = this._workingCanvas;\r\n var width = this._currentMeasure.width;\r\n var height = this._currentMeasure.height;\r\n var context = canvas.getContext(\"2d\");\r\n canvas.width = width;\r\n canvas.height = height;\r\n context.clearRect(0, 0, width, height);\r\n };\r\n Image.prototype._drawImage = function (context, sx, sy, sw, sh, tx, ty, tw, th) {\r\n context.drawImage(this._domImage, sx, sy, sw, sh, tx, ty, tw, th);\r\n if (!this._detectPointerOnOpaqueOnly) {\r\n return;\r\n }\r\n var canvas = this._workingCanvas;\r\n context = canvas.getContext(\"2d\");\r\n context.drawImage(this._domImage, sx, sy, sw, sh, tx - this._currentMeasure.left, ty - this._currentMeasure.top, tw, th);\r\n };\r\n Image.prototype._draw = function (context) {\r\n context.save();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n var x, y, width, height;\r\n if (this.cellId == -1) {\r\n x = this._sourceLeft;\r\n y = this._sourceTop;\r\n width = this._sourceWidth ? this._sourceWidth : this._imageWidth;\r\n height = this._sourceHeight ? this._sourceHeight : this._imageHeight;\r\n }\r\n else {\r\n var rowCount = this._domImage.naturalWidth / this.cellWidth;\r\n var column = (this.cellId / rowCount) >> 0;\r\n var row = this.cellId % rowCount;\r\n x = this.cellWidth * row;\r\n y = this.cellHeight * column;\r\n width = this.cellWidth;\r\n height = this.cellHeight;\r\n }\r\n this._prepareWorkingCanvasForOpaqueDetection();\r\n this._applyStates(context);\r\n if (this._loaded) {\r\n switch (this._stretch) {\r\n case Image.STRETCH_NONE:\r\n this._drawImage(context, x, y, width, height, this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n break;\r\n case Image.STRETCH_FILL:\r\n this._drawImage(context, x, y, width, height, this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n break;\r\n case Image.STRETCH_UNIFORM:\r\n var hRatio = this._currentMeasure.width / width;\r\n var vRatio = this._currentMeasure.height / height;\r\n var ratio = Math.min(hRatio, vRatio);\r\n var centerX = (this._currentMeasure.width - width * ratio) / 2;\r\n var centerY = (this._currentMeasure.height - height * ratio) / 2;\r\n this._drawImage(context, x, y, width, height, this._currentMeasure.left + centerX, this._currentMeasure.top + centerY, width * ratio, height * ratio);\r\n break;\r\n case Image.STRETCH_EXTEND:\r\n this._drawImage(context, x, y, width, height, this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n break;\r\n case Image.STRETCH_NINE_PATCH:\r\n this._renderNinePatch(context);\r\n break;\r\n }\r\n }\r\n context.restore();\r\n };\r\n Image.prototype._renderCornerPatch = function (context, x, y, width, height, targetX, targetY) {\r\n this._drawImage(context, x, y, width, height, this._currentMeasure.left + targetX, this._currentMeasure.top + targetY, width, height);\r\n };\r\n Image.prototype._renderNinePatch = function (context) {\r\n var height = this._imageHeight;\r\n var leftWidth = this._sliceLeft;\r\n var topHeight = this._sliceTop;\r\n var bottomHeight = this._imageHeight - this._sliceBottom;\r\n var rightWidth = this._imageWidth - this._sliceRight;\r\n var left = 0;\r\n var top = 0;\r\n if (this._populateNinePatchSlicesFromImage) {\r\n left = 1;\r\n top = 1;\r\n height -= 2;\r\n leftWidth -= 1;\r\n topHeight -= 1;\r\n bottomHeight -= 1;\r\n rightWidth -= 1;\r\n }\r\n var centerWidth = this._sliceRight - this._sliceLeft;\r\n var targetCenterWidth = this._currentMeasure.width - rightWidth - this.sliceLeft;\r\n var targetTopHeight = this._currentMeasure.height - height + this._sliceBottom;\r\n // Corners\r\n this._renderCornerPatch(context, left, top, leftWidth, topHeight, 0, 0);\r\n this._renderCornerPatch(context, left, this._sliceBottom, leftWidth, height - this._sliceBottom, 0, targetTopHeight);\r\n this._renderCornerPatch(context, this._sliceRight, top, rightWidth, topHeight, this._currentMeasure.width - rightWidth, 0);\r\n this._renderCornerPatch(context, this._sliceRight, this._sliceBottom, rightWidth, height - this._sliceBottom, this._currentMeasure.width - rightWidth, targetTopHeight);\r\n // Center\r\n this._drawImage(context, this._sliceLeft, this._sliceTop, centerWidth, this._sliceBottom - this._sliceTop, this._currentMeasure.left + leftWidth, this._currentMeasure.top + topHeight, targetCenterWidth, targetTopHeight - topHeight);\r\n // Borders\r\n this._drawImage(context, left, this._sliceTop, leftWidth, this._sliceBottom - this._sliceTop, this._currentMeasure.left, this._currentMeasure.top + topHeight, leftWidth, targetTopHeight - topHeight);\r\n this._drawImage(context, this._sliceRight, this._sliceTop, leftWidth, this._sliceBottom - this._sliceTop, this._currentMeasure.left + this._currentMeasure.width - rightWidth, this._currentMeasure.top + topHeight, leftWidth, targetTopHeight - topHeight);\r\n this._drawImage(context, this._sliceLeft, top, centerWidth, topHeight, this._currentMeasure.left + leftWidth, this._currentMeasure.top, targetCenterWidth, topHeight);\r\n this._drawImage(context, this._sliceLeft, this._sliceBottom, centerWidth, bottomHeight, this._currentMeasure.left + leftWidth, this._currentMeasure.top + targetTopHeight, targetCenterWidth, bottomHeight);\r\n };\r\n Image.prototype.dispose = function () {\r\n _super.prototype.dispose.call(this);\r\n this.onImageLoadedObservable.clear();\r\n this.onSVGAttributesComputedObservable.clear();\r\n };\r\n // Static\r\n /** STRETCH_NONE */\r\n Image.STRETCH_NONE = 0;\r\n /** STRETCH_FILL */\r\n Image.STRETCH_FILL = 1;\r\n /** STRETCH_UNIFORM */\r\n Image.STRETCH_UNIFORM = 2;\r\n /** STRETCH_EXTEND */\r\n Image.STRETCH_EXTEND = 3;\r\n /** NINE_PATCH */\r\n Image.STRETCH_NINE_PATCH = 4;\r\n return Image;\r\n}(Control));\r\nexport { Image };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Image\"] = Image;\r\n//# sourceMappingURL=image.js.map","import { __extends } from \"tslib\";\r\nimport { Rectangle } from \"./rectangle\";\r\nimport { Control } from \"./control\";\r\nimport { TextBlock } from \"./textBlock\";\r\nimport { Image } from \"./image\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create 2D buttons\r\n */\r\nvar Button = /** @class */ (function (_super) {\r\n __extends(Button, _super);\r\n /**\r\n * Creates a new Button\r\n * @param name defines the name of the button\r\n */\r\n function Button(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n /**\r\n * Gets or sets a boolean indicating that the button will let internal controls handle picking instead of doing it directly using its bounding info\r\n */\r\n _this.delegatePickingToChildren = false;\r\n _this.thickness = 1;\r\n _this.isPointerBlocker = true;\r\n var alphaStore = null;\r\n _this.pointerEnterAnimation = function () {\r\n alphaStore = _this.alpha;\r\n _this.alpha -= 0.1;\r\n };\r\n _this.pointerOutAnimation = function () {\r\n if (alphaStore !== null) {\r\n _this.alpha = alphaStore;\r\n }\r\n };\r\n _this.pointerDownAnimation = function () {\r\n _this.scaleX -= 0.05;\r\n _this.scaleY -= 0.05;\r\n };\r\n _this.pointerUpAnimation = function () {\r\n _this.scaleX += 0.05;\r\n _this.scaleY += 0.05;\r\n };\r\n return _this;\r\n }\r\n Object.defineProperty(Button.prototype, \"image\", {\r\n /**\r\n * Returns the image part of the button (if any)\r\n */\r\n get: function () {\r\n return this._image;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Button.prototype, \"textBlock\", {\r\n /**\r\n * Returns the image part of the button (if any)\r\n */\r\n get: function () {\r\n return this._textBlock;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Button.prototype._getTypeName = function () {\r\n return \"Button\";\r\n };\r\n // While being a container, the button behaves like a control.\r\n /** @hidden */\r\n Button.prototype._processPicking = function (x, y, type, pointerId, buttonIndex, deltaX, deltaY) {\r\n if (!this._isEnabled || !this.isHitTestVisible || !this.isVisible || this.notRenderable) {\r\n return false;\r\n }\r\n if (!_super.prototype.contains.call(this, x, y)) {\r\n return false;\r\n }\r\n if (this.delegatePickingToChildren) {\r\n var contains = false;\r\n for (var index = this._children.length - 1; index >= 0; index--) {\r\n var child = this._children[index];\r\n if (child.isEnabled && child.isHitTestVisible && child.isVisible && !child.notRenderable && child.contains(x, y)) {\r\n contains = true;\r\n break;\r\n }\r\n }\r\n if (!contains) {\r\n return false;\r\n }\r\n }\r\n this._processObservables(type, x, y, pointerId, buttonIndex, deltaX, deltaY);\r\n return true;\r\n };\r\n /** @hidden */\r\n Button.prototype._onPointerEnter = function (target) {\r\n if (!_super.prototype._onPointerEnter.call(this, target)) {\r\n return false;\r\n }\r\n if (this.pointerEnterAnimation) {\r\n this.pointerEnterAnimation();\r\n }\r\n return true;\r\n };\r\n /** @hidden */\r\n Button.prototype._onPointerOut = function (target, force) {\r\n if (force === void 0) { force = false; }\r\n if (this.pointerOutAnimation) {\r\n this.pointerOutAnimation();\r\n }\r\n _super.prototype._onPointerOut.call(this, target, force);\r\n };\r\n /** @hidden */\r\n Button.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex) {\r\n if (!_super.prototype._onPointerDown.call(this, target, coordinates, pointerId, buttonIndex)) {\r\n return false;\r\n }\r\n if (this.pointerDownAnimation) {\r\n this.pointerDownAnimation();\r\n }\r\n return true;\r\n };\r\n /** @hidden */\r\n Button.prototype._onPointerUp = function (target, coordinates, pointerId, buttonIndex, notifyClick) {\r\n if (this.pointerUpAnimation) {\r\n this.pointerUpAnimation();\r\n }\r\n _super.prototype._onPointerUp.call(this, target, coordinates, pointerId, buttonIndex, notifyClick);\r\n };\r\n // Statics\r\n /**\r\n * Creates a new button made with an image and a text\r\n * @param name defines the name of the button\r\n * @param text defines the text of the button\r\n * @param imageUrl defines the url of the image\r\n * @returns a new Button\r\n */\r\n Button.CreateImageButton = function (name, text, imageUrl) {\r\n var result = new Button(name);\r\n // Adding text\r\n var textBlock = new TextBlock(name + \"_button\", text);\r\n textBlock.textWrapping = true;\r\n textBlock.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_CENTER;\r\n textBlock.paddingLeft = \"20%\";\r\n result.addControl(textBlock);\r\n // Adding image\r\n var iconImage = new Image(name + \"_icon\", imageUrl);\r\n iconImage.width = \"20%\";\r\n iconImage.stretch = Image.STRETCH_UNIFORM;\r\n iconImage.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n result.addControl(iconImage);\r\n // Store\r\n result._image = iconImage;\r\n result._textBlock = textBlock;\r\n return result;\r\n };\r\n /**\r\n * Creates a new button made with an image\r\n * @param name defines the name of the button\r\n * @param imageUrl defines the url of the image\r\n * @returns a new Button\r\n */\r\n Button.CreateImageOnlyButton = function (name, imageUrl) {\r\n var result = new Button(name);\r\n // Adding image\r\n var iconImage = new Image(name + \"_icon\", imageUrl);\r\n iconImage.stretch = Image.STRETCH_FILL;\r\n iconImage.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n result.addControl(iconImage);\r\n // Store\r\n result._image = iconImage;\r\n return result;\r\n };\r\n /**\r\n * Creates a new button made with a text\r\n * @param name defines the name of the button\r\n * @param text defines the text of the button\r\n * @returns a new Button\r\n */\r\n Button.CreateSimpleButton = function (name, text) {\r\n var result = new Button(name);\r\n // Adding text\r\n var textBlock = new TextBlock(name + \"_button\", text);\r\n textBlock.textWrapping = true;\r\n textBlock.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_CENTER;\r\n result.addControl(textBlock);\r\n // Store\r\n result._textBlock = textBlock;\r\n return result;\r\n };\r\n /**\r\n * Creates a new button made with an image and a centered text\r\n * @param name defines the name of the button\r\n * @param text defines the text of the button\r\n * @param imageUrl defines the url of the image\r\n * @returns a new Button\r\n */\r\n Button.CreateImageWithCenterTextButton = function (name, text, imageUrl) {\r\n var result = new Button(name);\r\n // Adding image\r\n var iconImage = new Image(name + \"_icon\", imageUrl);\r\n iconImage.stretch = Image.STRETCH_FILL;\r\n result.addControl(iconImage);\r\n // Adding text\r\n var textBlock = new TextBlock(name + \"_button\", text);\r\n textBlock.textWrapping = true;\r\n textBlock.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_CENTER;\r\n result.addControl(textBlock);\r\n // Store\r\n result._image = iconImage;\r\n result._textBlock = textBlock;\r\n return result;\r\n };\r\n return Button;\r\n}(Rectangle));\r\nexport { Button };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Button\"] = Button;\r\n//# sourceMappingURL=button.js.map","import { __extends } from \"tslib\";\r\nimport { Tools } from \"@babylonjs/core/Misc/tools\";\r\nimport { Container } from \"./container\";\r\nimport { Control } from \"./control\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create a 2D stack panel container\r\n */\r\nvar StackPanel = /** @class */ (function (_super) {\r\n __extends(StackPanel, _super);\r\n /**\r\n * Creates a new StackPanel\r\n * @param name defines control name\r\n */\r\n function StackPanel(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._isVertical = true;\r\n _this._manualWidth = false;\r\n _this._manualHeight = false;\r\n _this._doNotTrackManualChanges = false;\r\n /**\r\n * Gets or sets a boolean indicating that layou warnings should be ignored\r\n */\r\n _this.ignoreLayoutWarnings = false;\r\n return _this;\r\n }\r\n Object.defineProperty(StackPanel.prototype, \"isVertical\", {\r\n /** Gets or sets a boolean indicating if the stack panel is vertical or horizontal*/\r\n get: function () {\r\n return this._isVertical;\r\n },\r\n set: function (value) {\r\n if (this._isVertical === value) {\r\n return;\r\n }\r\n this._isVertical = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StackPanel.prototype, \"width\", {\r\n get: function () {\r\n return this._width.toString(this._host);\r\n },\r\n /**\r\n * Gets or sets panel width.\r\n * This value should not be set when in horizontal mode as it will be computed automatically\r\n */\r\n set: function (value) {\r\n if (!this._doNotTrackManualChanges) {\r\n this._manualWidth = true;\r\n }\r\n if (this._width.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._width.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(StackPanel.prototype, \"height\", {\r\n get: function () {\r\n return this._height.toString(this._host);\r\n },\r\n /**\r\n * Gets or sets panel height.\r\n * This value should not be set when in vertical mode as it will be computed automatically\r\n */\r\n set: function (value) {\r\n if (!this._doNotTrackManualChanges) {\r\n this._manualHeight = true;\r\n }\r\n if (this._height.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._height.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n StackPanel.prototype._getTypeName = function () {\r\n return \"StackPanel\";\r\n };\r\n /** @hidden */\r\n StackPanel.prototype._preMeasure = function (parentMeasure, context) {\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (this._isVertical) {\r\n child.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n }\r\n else {\r\n child.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n }\r\n }\r\n _super.prototype._preMeasure.call(this, parentMeasure, context);\r\n };\r\n StackPanel.prototype._additionalProcessing = function (parentMeasure, context) {\r\n _super.prototype._additionalProcessing.call(this, parentMeasure, context);\r\n this._measureForChildren.copyFrom(parentMeasure);\r\n this._measureForChildren.left = this._currentMeasure.left;\r\n this._measureForChildren.top = this._currentMeasure.top;\r\n if (!this.isVertical || this._manualWidth) {\r\n this._measureForChildren.width = this._currentMeasure.width;\r\n }\r\n if (this.isVertical || this._manualHeight) {\r\n this._measureForChildren.height = this._currentMeasure.height;\r\n }\r\n };\r\n StackPanel.prototype._postMeasure = function () {\r\n var stackWidth = 0;\r\n var stackHeight = 0;\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (!child.isVisible || child.notRenderable) {\r\n continue;\r\n }\r\n if (this._isVertical) {\r\n if (child.top !== stackHeight + \"px\") {\r\n child.top = stackHeight + \"px\";\r\n this._rebuildLayout = true;\r\n child._top.ignoreAdaptiveScaling = true;\r\n }\r\n if (child._height.isPercentage && !child._automaticSize) {\r\n if (!this.ignoreLayoutWarnings) {\r\n Tools.Warn(\"Control (Name:\" + child.name + \", UniqueId:\" + child.uniqueId + \") is using height in percentage mode inside a vertical StackPanel\");\r\n }\r\n }\r\n else {\r\n stackHeight += child._currentMeasure.height + child.paddingTopInPixels + child.paddingBottomInPixels;\r\n }\r\n }\r\n else {\r\n if (child.left !== stackWidth + \"px\") {\r\n child.left = stackWidth + \"px\";\r\n this._rebuildLayout = true;\r\n child._left.ignoreAdaptiveScaling = true;\r\n }\r\n if (child._width.isPercentage && !child._automaticSize) {\r\n if (!this.ignoreLayoutWarnings) {\r\n Tools.Warn(\"Control (Name:\" + child.name + \", UniqueId:\" + child.uniqueId + \") is using width in percentage mode inside a horizontal StackPanel\");\r\n }\r\n }\r\n else {\r\n stackWidth += child._currentMeasure.width + child.paddingLeftInPixels + child.paddingRightInPixels;\r\n }\r\n }\r\n }\r\n this._doNotTrackManualChanges = true;\r\n // Let stack panel width or height default to stackHeight and stackWidth if dimensions are not specified.\r\n // User can now define their own height and width for stack panel.\r\n var panelWidthChanged = false;\r\n var panelHeightChanged = false;\r\n if (!this._manualHeight && this._isVertical) { // do not specify height if strictly defined by user\r\n var previousHeight = this.height;\r\n this.height = stackHeight + \"px\";\r\n panelHeightChanged = previousHeight !== this.height || !this._height.ignoreAdaptiveScaling;\r\n }\r\n if (!this._manualWidth && !this._isVertical) { // do not specify width if strictly defined by user\r\n var previousWidth = this.width;\r\n this.width = stackWidth + \"px\";\r\n panelWidthChanged = previousWidth !== this.width || !this._width.ignoreAdaptiveScaling;\r\n }\r\n if (panelHeightChanged) {\r\n this._height.ignoreAdaptiveScaling = true;\r\n }\r\n if (panelWidthChanged) {\r\n this._width.ignoreAdaptiveScaling = true;\r\n }\r\n this._doNotTrackManualChanges = false;\r\n if (panelWidthChanged || panelHeightChanged) {\r\n this._rebuildLayout = true;\r\n }\r\n _super.prototype._postMeasure.call(this);\r\n };\r\n return StackPanel;\r\n}(Container));\r\nexport { StackPanel };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.StackPanel\"] = StackPanel;\r\n//# sourceMappingURL=stackPanel.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { Control } from \"./control\";\r\nimport { StackPanel } from \"./stackPanel\";\r\nimport { TextBlock } from \"./textBlock\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to represent a 2D checkbox\r\n */\r\nvar Checkbox = /** @class */ (function (_super) {\r\n __extends(Checkbox, _super);\r\n /**\r\n * Creates a new CheckBox\r\n * @param name defines the control name\r\n */\r\n function Checkbox(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._isChecked = false;\r\n _this._background = \"black\";\r\n _this._checkSizeRatio = 0.8;\r\n _this._thickness = 1;\r\n /**\r\n * Observable raised when isChecked property changes\r\n */\r\n _this.onIsCheckedChangedObservable = new Observable();\r\n _this.isPointerBlocker = true;\r\n return _this;\r\n }\r\n Object.defineProperty(Checkbox.prototype, \"thickness\", {\r\n /** Gets or sets border thickness */\r\n get: function () {\r\n return this._thickness;\r\n },\r\n set: function (value) {\r\n if (this._thickness === value) {\r\n return;\r\n }\r\n this._thickness = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Checkbox.prototype, \"checkSizeRatio\", {\r\n /** Gets or sets a value indicating the ratio between overall size and check size */\r\n get: function () {\r\n return this._checkSizeRatio;\r\n },\r\n set: function (value) {\r\n value = Math.max(Math.min(1, value), 0);\r\n if (this._checkSizeRatio === value) {\r\n return;\r\n }\r\n this._checkSizeRatio = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Checkbox.prototype, \"background\", {\r\n /** Gets or sets background color */\r\n get: function () {\r\n return this._background;\r\n },\r\n set: function (value) {\r\n if (this._background === value) {\r\n return;\r\n }\r\n this._background = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Checkbox.prototype, \"isChecked\", {\r\n /** Gets or sets a boolean indicating if the checkbox is checked or not */\r\n get: function () {\r\n return this._isChecked;\r\n },\r\n set: function (value) {\r\n if (this._isChecked === value) {\r\n return;\r\n }\r\n this._isChecked = value;\r\n this._markAsDirty();\r\n this.onIsCheckedChangedObservable.notifyObservers(value);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Checkbox.prototype._getTypeName = function () {\r\n return \"Checkbox\";\r\n };\r\n /** @hidden */\r\n Checkbox.prototype._draw = function (context, invalidatedRectangle) {\r\n context.save();\r\n this._applyStates(context);\r\n var actualWidth = this._currentMeasure.width - this._thickness;\r\n var actualHeight = this._currentMeasure.height - this._thickness;\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n context.fillStyle = this._isEnabled ? this._background : this._disabledColor;\r\n context.fillRect(this._currentMeasure.left + this._thickness / 2, this._currentMeasure.top + this._thickness / 2, actualWidth, actualHeight);\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n if (this._isChecked) {\r\n context.fillStyle = this._isEnabled ? this.color : this._disabledColorItem;\r\n var offsetWidth = actualWidth * this._checkSizeRatio;\r\n var offseHeight = actualHeight * this._checkSizeRatio;\r\n context.fillRect(this._currentMeasure.left + this._thickness / 2 + (actualWidth - offsetWidth) / 2, this._currentMeasure.top + this._thickness / 2 + (actualHeight - offseHeight) / 2, offsetWidth, offseHeight);\r\n }\r\n context.strokeStyle = this.color;\r\n context.lineWidth = this._thickness;\r\n context.strokeRect(this._currentMeasure.left + this._thickness / 2, this._currentMeasure.top + this._thickness / 2, actualWidth, actualHeight);\r\n context.restore();\r\n };\r\n // Events\r\n /** @hidden */\r\n Checkbox.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex) {\r\n if (!_super.prototype._onPointerDown.call(this, target, coordinates, pointerId, buttonIndex)) {\r\n return false;\r\n }\r\n this.isChecked = !this.isChecked;\r\n return true;\r\n };\r\n /**\r\n * Utility function to easily create a checkbox with a header\r\n * @param title defines the label to use for the header\r\n * @param onValueChanged defines the callback to call when value changes\r\n * @returns a StackPanel containing the checkbox and a textBlock\r\n */\r\n Checkbox.AddCheckBoxWithHeader = function (title, onValueChanged) {\r\n var panel = new StackPanel();\r\n panel.isVertical = false;\r\n panel.height = \"30px\";\r\n var checkbox = new Checkbox();\r\n checkbox.width = \"20px\";\r\n checkbox.height = \"20px\";\r\n checkbox.isChecked = true;\r\n checkbox.color = \"green\";\r\n checkbox.onIsCheckedChangedObservable.add(onValueChanged);\r\n panel.addControl(checkbox);\r\n var header = new TextBlock();\r\n header.text = title;\r\n header.width = \"180px\";\r\n header.paddingLeft = \"5px\";\r\n header.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n header.color = \"white\";\r\n panel.addControl(header);\r\n return panel;\r\n };\r\n return Checkbox;\r\n}(Control));\r\nexport { Checkbox };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Checkbox\"] = Checkbox;\r\n//# sourceMappingURL=checkbox.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { ClipboardEventTypes } from \"@babylonjs/core/Events/clipboardEvents\";\r\nimport { PointerEventTypes } from '@babylonjs/core/Events/pointerEvents';\r\nimport { Control } from \"./control\";\r\nimport { ValueAndUnit } from \"../valueAndUnit\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create input text control\r\n */\r\nvar InputText = /** @class */ (function (_super) {\r\n __extends(InputText, _super);\r\n /**\r\n * Creates a new InputText\r\n * @param name defines the control name\r\n * @param text defines the text of the control\r\n */\r\n function InputText(name, text) {\r\n if (text === void 0) { text = \"\"; }\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._text = \"\";\r\n _this._placeholderText = \"\";\r\n _this._background = \"#222222\";\r\n _this._focusedBackground = \"#000000\";\r\n _this._focusedColor = \"white\";\r\n _this._placeholderColor = \"gray\";\r\n _this._thickness = 1;\r\n _this._margin = new ValueAndUnit(10, ValueAndUnit.UNITMODE_PIXEL);\r\n _this._autoStretchWidth = true;\r\n _this._maxWidth = new ValueAndUnit(1, ValueAndUnit.UNITMODE_PERCENTAGE, false);\r\n _this._isFocused = false;\r\n _this._blinkIsEven = false;\r\n _this._cursorOffset = 0;\r\n _this._deadKey = false;\r\n _this._addKey = true;\r\n _this._currentKey = \"\";\r\n _this._isTextHighlightOn = false;\r\n _this._textHighlightColor = \"#d5e0ff\";\r\n _this._highligherOpacity = 0.4;\r\n _this._highlightedText = \"\";\r\n _this._startHighlightIndex = 0;\r\n _this._endHighlightIndex = 0;\r\n _this._cursorIndex = -1;\r\n _this._onFocusSelectAll = false;\r\n _this._isPointerDown = false;\r\n /** Gets or sets a string representing the message displayed on mobile when the control gets the focus */\r\n _this.promptMessage = \"Please enter text:\";\r\n /** Force disable prompt on mobile device */\r\n _this.disableMobilePrompt = false;\r\n /** Observable raised when the text changes */\r\n _this.onTextChangedObservable = new Observable();\r\n /** Observable raised just before an entered character is to be added */\r\n _this.onBeforeKeyAddObservable = new Observable();\r\n /** Observable raised when the control gets the focus */\r\n _this.onFocusObservable = new Observable();\r\n /** Observable raised when the control loses the focus */\r\n _this.onBlurObservable = new Observable();\r\n /**Observable raised when the text is highlighted */\r\n _this.onTextHighlightObservable = new Observable();\r\n /**Observable raised when copy event is triggered */\r\n _this.onTextCopyObservable = new Observable();\r\n /** Observable raised when cut event is triggered */\r\n _this.onTextCutObservable = new Observable();\r\n /** Observable raised when paste event is triggered */\r\n _this.onTextPasteObservable = new Observable();\r\n /** Observable raised when a key event was processed */\r\n _this.onKeyboardEventProcessedObservable = new Observable();\r\n _this.text = text;\r\n _this.isPointerBlocker = true;\r\n return _this;\r\n }\r\n Object.defineProperty(InputText.prototype, \"maxWidth\", {\r\n /** Gets or sets the maximum width allowed by the control */\r\n get: function () {\r\n return this._maxWidth.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._maxWidth.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._maxWidth.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"maxWidthInPixels\", {\r\n /** Gets the maximum width allowed by the control in pixels */\r\n get: function () {\r\n return this._maxWidth.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"highligherOpacity\", {\r\n /** Gets or sets the text highlighter transparency; default: 0.4 */\r\n get: function () {\r\n return this._highligherOpacity;\r\n },\r\n set: function (value) {\r\n if (this._highligherOpacity === value) {\r\n return;\r\n }\r\n this._highligherOpacity = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"onFocusSelectAll\", {\r\n /** Gets or sets a boolean indicating whether to select complete text by default on input focus */\r\n get: function () {\r\n return this._onFocusSelectAll;\r\n },\r\n set: function (value) {\r\n if (this._onFocusSelectAll === value) {\r\n return;\r\n }\r\n this._onFocusSelectAll = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"textHighlightColor\", {\r\n /** Gets or sets the text hightlight color */\r\n get: function () {\r\n return this._textHighlightColor;\r\n },\r\n set: function (value) {\r\n if (this._textHighlightColor === value) {\r\n return;\r\n }\r\n this._textHighlightColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"margin\", {\r\n /** Gets or sets control margin */\r\n get: function () {\r\n return this._margin.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._margin.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._margin.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"marginInPixels\", {\r\n /** Gets control margin in pixels */\r\n get: function () {\r\n return this._margin.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"autoStretchWidth\", {\r\n /** Gets or sets a boolean indicating if the control can auto stretch its width to adapt to the text */\r\n get: function () {\r\n return this._autoStretchWidth;\r\n },\r\n set: function (value) {\r\n if (this._autoStretchWidth === value) {\r\n return;\r\n }\r\n this._autoStretchWidth = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"thickness\", {\r\n /** Gets or sets border thickness */\r\n get: function () {\r\n return this._thickness;\r\n },\r\n set: function (value) {\r\n if (this._thickness === value) {\r\n return;\r\n }\r\n this._thickness = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"focusedBackground\", {\r\n /** Gets or sets the background color when focused */\r\n get: function () {\r\n return this._focusedBackground;\r\n },\r\n set: function (value) {\r\n if (this._focusedBackground === value) {\r\n return;\r\n }\r\n this._focusedBackground = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"focusedColor\", {\r\n /** Gets or sets the background color when focused */\r\n get: function () {\r\n return this._focusedColor;\r\n },\r\n set: function (value) {\r\n if (this._focusedColor === value) {\r\n return;\r\n }\r\n this._focusedColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"background\", {\r\n /** Gets or sets the background color */\r\n get: function () {\r\n return this._background;\r\n },\r\n set: function (value) {\r\n if (this._background === value) {\r\n return;\r\n }\r\n this._background = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"placeholderColor\", {\r\n /** Gets or sets the placeholder color */\r\n get: function () {\r\n return this._placeholderColor;\r\n },\r\n set: function (value) {\r\n if (this._placeholderColor === value) {\r\n return;\r\n }\r\n this._placeholderColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"placeholderText\", {\r\n /** Gets or sets the text displayed when the control is empty */\r\n get: function () {\r\n return this._placeholderText;\r\n },\r\n set: function (value) {\r\n if (this._placeholderText === value) {\r\n return;\r\n }\r\n this._placeholderText = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"deadKey\", {\r\n /** Gets or sets the dead key flag */\r\n get: function () {\r\n return this._deadKey;\r\n },\r\n set: function (flag) {\r\n this._deadKey = flag;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"highlightedText\", {\r\n /** Gets or sets the highlight text */\r\n get: function () {\r\n return this._highlightedText;\r\n },\r\n set: function (text) {\r\n if (this._highlightedText === text) {\r\n return;\r\n }\r\n this._highlightedText = text;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"addKey\", {\r\n /** Gets or sets if the current key should be added */\r\n get: function () {\r\n return this._addKey;\r\n },\r\n set: function (flag) {\r\n this._addKey = flag;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"currentKey\", {\r\n /** Gets or sets the value of the current key being entered */\r\n get: function () {\r\n return this._currentKey;\r\n },\r\n set: function (key) {\r\n this._currentKey = key;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"text\", {\r\n /** Gets or sets the text displayed in the control */\r\n get: function () {\r\n return this._text;\r\n },\r\n set: function (value) {\r\n var valueAsString = value.toString(); // Forcing convertion\r\n if (this._text === valueAsString) {\r\n return;\r\n }\r\n this._text = valueAsString;\r\n this._markAsDirty();\r\n this.onTextChangedObservable.notifyObservers(this);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"width\", {\r\n /** Gets or sets control width */\r\n get: function () {\r\n return this._width.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._width.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._width.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n this.autoStretchWidth = false;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n InputText.prototype.onBlur = function () {\r\n this._isFocused = false;\r\n this._scrollLeft = null;\r\n this._cursorOffset = 0;\r\n clearTimeout(this._blinkTimeout);\r\n this._markAsDirty();\r\n this.onBlurObservable.notifyObservers(this);\r\n this._host.unRegisterClipboardEvents();\r\n if (this._onClipboardObserver) {\r\n this._host.onClipboardObservable.remove(this._onClipboardObserver);\r\n }\r\n var scene = this._host.getScene();\r\n if (this._onPointerDblTapObserver && scene) {\r\n scene.onPointerObservable.remove(this._onPointerDblTapObserver);\r\n }\r\n };\r\n /** @hidden */\r\n InputText.prototype.onFocus = function () {\r\n var _this = this;\r\n if (!this._isEnabled) {\r\n return;\r\n }\r\n this._scrollLeft = null;\r\n this._isFocused = true;\r\n this._blinkIsEven = false;\r\n this._cursorOffset = 0;\r\n this._markAsDirty();\r\n this.onFocusObservable.notifyObservers(this);\r\n if (navigator.userAgent.indexOf(\"Mobile\") !== -1 && !this.disableMobilePrompt) {\r\n var value = prompt(this.promptMessage);\r\n if (value !== null) {\r\n this.text = value;\r\n }\r\n this._host.focusedControl = null;\r\n return;\r\n }\r\n this._host.registerClipboardEvents();\r\n this._onClipboardObserver = this._host.onClipboardObservable.add(function (clipboardInfo) {\r\n // process clipboard event, can be configured.\r\n switch (clipboardInfo.type) {\r\n case ClipboardEventTypes.COPY:\r\n _this._onCopyText(clipboardInfo.event);\r\n _this.onTextCopyObservable.notifyObservers(_this);\r\n break;\r\n case ClipboardEventTypes.CUT:\r\n _this._onCutText(clipboardInfo.event);\r\n _this.onTextCutObservable.notifyObservers(_this);\r\n break;\r\n case ClipboardEventTypes.PASTE:\r\n _this._onPasteText(clipboardInfo.event);\r\n _this.onTextPasteObservable.notifyObservers(_this);\r\n break;\r\n default: return;\r\n }\r\n });\r\n var scene = this._host.getScene();\r\n if (scene) {\r\n //register the pointer double tap event\r\n this._onPointerDblTapObserver = scene.onPointerObservable.add(function (pointerInfo) {\r\n if (!_this._isFocused) {\r\n return;\r\n }\r\n if (pointerInfo.type === PointerEventTypes.POINTERDOUBLETAP) {\r\n _this._processDblClick(pointerInfo);\r\n }\r\n });\r\n }\r\n if (this._onFocusSelectAll) {\r\n this._selectAllText();\r\n }\r\n };\r\n InputText.prototype._getTypeName = function () {\r\n return \"InputText\";\r\n };\r\n /**\r\n * Function called to get the list of controls that should not steal the focus from this control\r\n * @returns an array of controls\r\n */\r\n InputText.prototype.keepsFocusWith = function () {\r\n if (!this._connectedVirtualKeyboard) {\r\n return null;\r\n }\r\n return [this._connectedVirtualKeyboard];\r\n };\r\n /** @hidden */\r\n InputText.prototype.processKey = function (keyCode, key, evt) {\r\n //return if clipboard event keys (i.e -ctr/cmd + c,v,x)\r\n if (evt && (evt.ctrlKey || evt.metaKey) && (keyCode === 67 || keyCode === 86 || keyCode === 88)) {\r\n return;\r\n }\r\n //select all\r\n if (evt && (evt.ctrlKey || evt.metaKey) && keyCode === 65) {\r\n this._selectAllText();\r\n evt.preventDefault();\r\n return;\r\n }\r\n // Specific cases\r\n switch (keyCode) {\r\n case 32: //SPACE\r\n key = \" \"; //ie11 key for space is \"Spacebar\"\r\n break;\r\n case 191: //SLASH\r\n if (evt) {\r\n evt.preventDefault();\r\n }\r\n break;\r\n case 8: // BACKSPACE\r\n if (this._text && this._text.length > 0) {\r\n //delete the highlighted text\r\n if (this._isTextHighlightOn) {\r\n this.text = this._text.slice(0, this._startHighlightIndex) + this._text.slice(this._endHighlightIndex);\r\n this._isTextHighlightOn = false;\r\n this._cursorOffset = this.text.length - this._startHighlightIndex;\r\n this._blinkIsEven = false;\r\n if (evt) {\r\n evt.preventDefault();\r\n }\r\n return;\r\n }\r\n //delete single character\r\n if (this._cursorOffset === 0) {\r\n this.text = this._text.substr(0, this._text.length - 1);\r\n }\r\n else {\r\n var deletePosition = this._text.length - this._cursorOffset;\r\n if (deletePosition > 0) {\r\n this.text = this._text.slice(0, deletePosition - 1) + this._text.slice(deletePosition);\r\n }\r\n }\r\n }\r\n if (evt) {\r\n evt.preventDefault();\r\n }\r\n return;\r\n case 46: // DELETE\r\n if (this._isTextHighlightOn) {\r\n this.text = this._text.slice(0, this._startHighlightIndex) + this._text.slice(this._endHighlightIndex);\r\n var decrementor = (this._endHighlightIndex - this._startHighlightIndex);\r\n while (decrementor > 0 && this._cursorOffset > 0) {\r\n this._cursorOffset--;\r\n }\r\n this._isTextHighlightOn = false;\r\n this._cursorOffset = this.text.length - this._startHighlightIndex;\r\n if (evt) {\r\n evt.preventDefault();\r\n }\r\n return;\r\n }\r\n if (this._text && this._text.length > 0 && this._cursorOffset > 0) {\r\n var deletePosition = this._text.length - this._cursorOffset;\r\n this.text = this._text.slice(0, deletePosition) + this._text.slice(deletePosition + 1);\r\n this._cursorOffset--;\r\n }\r\n if (evt) {\r\n evt.preventDefault();\r\n }\r\n return;\r\n case 13: // RETURN\r\n this._host.focusedControl = null;\r\n this._isTextHighlightOn = false;\r\n return;\r\n case 35: // END\r\n this._cursorOffset = 0;\r\n this._blinkIsEven = false;\r\n this._isTextHighlightOn = false;\r\n this._markAsDirty();\r\n return;\r\n case 36: // HOME\r\n this._cursorOffset = this._text.length;\r\n this._blinkIsEven = false;\r\n this._isTextHighlightOn = false;\r\n this._markAsDirty();\r\n return;\r\n case 37: // LEFT\r\n this._cursorOffset++;\r\n if (this._cursorOffset > this._text.length) {\r\n this._cursorOffset = this._text.length;\r\n }\r\n if (evt && evt.shiftKey) {\r\n // update the cursor\r\n this._blinkIsEven = false;\r\n // shift + ctrl/cmd + <-\r\n if (evt.ctrlKey || evt.metaKey) {\r\n if (!this._isTextHighlightOn) {\r\n if (this._text.length === this._cursorOffset) {\r\n return;\r\n }\r\n else {\r\n this._endHighlightIndex = this._text.length - this._cursorOffset + 1;\r\n }\r\n }\r\n this._startHighlightIndex = 0;\r\n this._cursorIndex = this._text.length - this._endHighlightIndex;\r\n this._cursorOffset = this._text.length;\r\n this._isTextHighlightOn = true;\r\n this._markAsDirty();\r\n return;\r\n }\r\n //store the starting point\r\n if (!this._isTextHighlightOn) {\r\n this._isTextHighlightOn = true;\r\n this._cursorIndex = (this._cursorOffset >= this._text.length) ? this._text.length : this._cursorOffset - 1;\r\n }\r\n //if text is already highlighted\r\n else if (this._cursorIndex === -1) {\r\n this._cursorIndex = this._text.length - this._endHighlightIndex;\r\n this._cursorOffset = (this._startHighlightIndex === 0) ? this._text.length : this._text.length - this._startHighlightIndex + 1;\r\n }\r\n //set the highlight indexes\r\n if (this._cursorIndex < this._cursorOffset) {\r\n this._endHighlightIndex = this._text.length - this._cursorIndex;\r\n this._startHighlightIndex = this._text.length - this._cursorOffset;\r\n }\r\n else if (this._cursorIndex > this._cursorOffset) {\r\n this._endHighlightIndex = this._text.length - this._cursorOffset;\r\n this._startHighlightIndex = this._text.length - this._cursorIndex;\r\n }\r\n else {\r\n this._isTextHighlightOn = false;\r\n }\r\n this._markAsDirty();\r\n return;\r\n }\r\n if (this._isTextHighlightOn) {\r\n this._cursorOffset = this._text.length - this._startHighlightIndex;\r\n this._isTextHighlightOn = false;\r\n }\r\n if (evt && (evt.ctrlKey || evt.metaKey)) {\r\n this._cursorOffset = this.text.length;\r\n evt.preventDefault();\r\n }\r\n this._blinkIsEven = false;\r\n this._isTextHighlightOn = false;\r\n this._cursorIndex = -1;\r\n this._markAsDirty();\r\n return;\r\n case 39: // RIGHT\r\n this._cursorOffset--;\r\n if (this._cursorOffset < 0) {\r\n this._cursorOffset = 0;\r\n }\r\n if (evt && evt.shiftKey) {\r\n //update the cursor\r\n this._blinkIsEven = false;\r\n //shift + ctrl/cmd + ->\r\n if (evt.ctrlKey || evt.metaKey) {\r\n if (!this._isTextHighlightOn) {\r\n if (this._cursorOffset === 0) {\r\n return;\r\n }\r\n else {\r\n this._startHighlightIndex = this._text.length - this._cursorOffset - 1;\r\n }\r\n }\r\n this._endHighlightIndex = this._text.length;\r\n this._isTextHighlightOn = true;\r\n this._cursorIndex = this._text.length - this._startHighlightIndex;\r\n this._cursorOffset = 0;\r\n this._markAsDirty();\r\n return;\r\n }\r\n if (!this._isTextHighlightOn) {\r\n this._isTextHighlightOn = true;\r\n this._cursorIndex = (this._cursorOffset <= 0) ? 0 : this._cursorOffset + 1;\r\n }\r\n //if text is already highlighted\r\n else if (this._cursorIndex === -1) {\r\n this._cursorIndex = this._text.length - this._startHighlightIndex;\r\n this._cursorOffset = (this._text.length === this._endHighlightIndex) ? 0 : this._text.length - this._endHighlightIndex - 1;\r\n }\r\n //set the highlight indexes\r\n if (this._cursorIndex < this._cursorOffset) {\r\n this._endHighlightIndex = this._text.length - this._cursorIndex;\r\n this._startHighlightIndex = this._text.length - this._cursorOffset;\r\n }\r\n else if (this._cursorIndex > this._cursorOffset) {\r\n this._endHighlightIndex = this._text.length - this._cursorOffset;\r\n this._startHighlightIndex = this._text.length - this._cursorIndex;\r\n }\r\n else {\r\n this._isTextHighlightOn = false;\r\n }\r\n this._markAsDirty();\r\n return;\r\n }\r\n if (this._isTextHighlightOn) {\r\n this._cursorOffset = this._text.length - this._endHighlightIndex;\r\n this._isTextHighlightOn = false;\r\n }\r\n //ctr + ->\r\n if (evt && (evt.ctrlKey || evt.metaKey)) {\r\n this._cursorOffset = 0;\r\n evt.preventDefault();\r\n }\r\n this._blinkIsEven = false;\r\n this._isTextHighlightOn = false;\r\n this._cursorIndex = -1;\r\n this._markAsDirty();\r\n return;\r\n case 222: // Dead\r\n if (evt) {\r\n evt.preventDefault();\r\n }\r\n this._cursorIndex = -1;\r\n this.deadKey = true;\r\n break;\r\n }\r\n // Printable characters\r\n if (key &&\r\n ((keyCode === -1) || // Direct access\r\n (keyCode === 32) || // Space\r\n (keyCode > 47 && keyCode < 64) || // Numbers\r\n (keyCode > 64 && keyCode < 91) || // Letters\r\n (keyCode > 159 && keyCode < 193) || // Special characters\r\n (keyCode > 218 && keyCode < 223) || // Special characters\r\n (keyCode > 95 && keyCode < 112))) { // Numpad\r\n this._currentKey = key;\r\n this.onBeforeKeyAddObservable.notifyObservers(this);\r\n key = this._currentKey;\r\n if (this._addKey) {\r\n if (this._isTextHighlightOn) {\r\n this.text = this._text.slice(0, this._startHighlightIndex) + key + this._text.slice(this._endHighlightIndex);\r\n this._cursorOffset = this.text.length - (this._startHighlightIndex + 1);\r\n this._isTextHighlightOn = false;\r\n this._blinkIsEven = false;\r\n this._markAsDirty();\r\n }\r\n else if (this._cursorOffset === 0) {\r\n this.text += key;\r\n }\r\n else {\r\n var insertPosition = this._text.length - this._cursorOffset;\r\n this.text = this._text.slice(0, insertPosition) + key + this._text.slice(insertPosition);\r\n }\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n InputText.prototype._updateValueFromCursorIndex = function (offset) {\r\n //update the cursor\r\n this._blinkIsEven = false;\r\n if (this._cursorIndex === -1) {\r\n this._cursorIndex = offset;\r\n }\r\n else {\r\n if (this._cursorIndex < this._cursorOffset) {\r\n this._endHighlightIndex = this._text.length - this._cursorIndex;\r\n this._startHighlightIndex = this._text.length - this._cursorOffset;\r\n }\r\n else if (this._cursorIndex > this._cursorOffset) {\r\n this._endHighlightIndex = this._text.length - this._cursorOffset;\r\n this._startHighlightIndex = this._text.length - this._cursorIndex;\r\n }\r\n else {\r\n this._isTextHighlightOn = false;\r\n this._markAsDirty();\r\n return;\r\n }\r\n }\r\n this._isTextHighlightOn = true;\r\n this._markAsDirty();\r\n };\r\n /** @hidden */\r\n InputText.prototype._processDblClick = function (evt) {\r\n //pre-find the start and end index of the word under cursor, speeds up the rendering\r\n this._startHighlightIndex = this._text.length - this._cursorOffset;\r\n this._endHighlightIndex = this._startHighlightIndex;\r\n var rWord = /\\w+/g, moveLeft, moveRight;\r\n do {\r\n moveRight = this._endHighlightIndex < this._text.length && (this._text[this._endHighlightIndex].search(rWord) !== -1) ? ++this._endHighlightIndex : 0;\r\n moveLeft = this._startHighlightIndex > 0 && (this._text[this._startHighlightIndex - 1].search(rWord) !== -1) ? --this._startHighlightIndex : 0;\r\n } while (moveLeft || moveRight);\r\n this._cursorOffset = this.text.length - this._startHighlightIndex;\r\n this.onTextHighlightObservable.notifyObservers(this);\r\n this._isTextHighlightOn = true;\r\n this._clickedCoordinate = null;\r\n this._blinkIsEven = true;\r\n this._cursorIndex = -1;\r\n this._markAsDirty();\r\n };\r\n /** @hidden */\r\n InputText.prototype._selectAllText = function () {\r\n this._blinkIsEven = true;\r\n this._isTextHighlightOn = true;\r\n this._startHighlightIndex = 0;\r\n this._endHighlightIndex = this._text.length;\r\n this._cursorOffset = this._text.length;\r\n this._cursorIndex = -1;\r\n this._markAsDirty();\r\n };\r\n /**\r\n * Handles the keyboard event\r\n * @param evt Defines the KeyboardEvent\r\n */\r\n InputText.prototype.processKeyboard = function (evt) {\r\n // process pressed key\r\n this.processKey(evt.keyCode, evt.key, evt);\r\n this.onKeyboardEventProcessedObservable.notifyObservers(evt);\r\n };\r\n /** @hidden */\r\n InputText.prototype._onCopyText = function (ev) {\r\n this._isTextHighlightOn = false;\r\n //when write permission to clipbaord data is denied\r\n try {\r\n ev.clipboardData && ev.clipboardData.setData(\"text/plain\", this._highlightedText);\r\n }\r\n catch (_a) { } //pass\r\n this._host.clipboardData = this._highlightedText;\r\n };\r\n /** @hidden */\r\n InputText.prototype._onCutText = function (ev) {\r\n if (!this._highlightedText) {\r\n return;\r\n }\r\n this.text = this._text.slice(0, this._startHighlightIndex) + this._text.slice(this._endHighlightIndex);\r\n this._isTextHighlightOn = false;\r\n this._cursorOffset = this.text.length - this._startHighlightIndex;\r\n //when write permission to clipbaord data is denied\r\n try {\r\n ev.clipboardData && ev.clipboardData.setData(\"text/plain\", this._highlightedText);\r\n }\r\n catch (_a) { } //pass\r\n this._host.clipboardData = this._highlightedText;\r\n this._highlightedText = \"\";\r\n };\r\n /** @hidden */\r\n InputText.prototype._onPasteText = function (ev) {\r\n var data = \"\";\r\n if (ev.clipboardData && ev.clipboardData.types.indexOf(\"text/plain\") !== -1) {\r\n data = ev.clipboardData.getData(\"text/plain\");\r\n }\r\n else {\r\n //get the cached data; returns blank string by default\r\n data = this._host.clipboardData;\r\n }\r\n var insertPosition = this._text.length - this._cursorOffset;\r\n this.text = this._text.slice(0, insertPosition) + data + this._text.slice(insertPosition);\r\n };\r\n InputText.prototype._draw = function (context, invalidatedRectangle) {\r\n var _this = this;\r\n context.save();\r\n this._applyStates(context);\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n // Background\r\n if (this._isFocused) {\r\n if (this._focusedBackground) {\r\n context.fillStyle = this._isEnabled ? this._focusedBackground : this._disabledColor;\r\n context.fillRect(this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n }\r\n }\r\n else if (this._background) {\r\n context.fillStyle = this._isEnabled ? this._background : this._disabledColor;\r\n context.fillRect(this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n }\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n if (!this._fontOffset) {\r\n this._fontOffset = Control._GetFontOffset(context.font);\r\n }\r\n // Text\r\n var clipTextLeft = this._currentMeasure.left + this._margin.getValueInPixel(this._host, this._tempParentMeasure.width);\r\n if (this.color) {\r\n context.fillStyle = this.color;\r\n }\r\n var text = this._beforeRenderText(this._text);\r\n if (!this._isFocused && !this._text && this._placeholderText) {\r\n text = this._placeholderText;\r\n if (this._placeholderColor) {\r\n context.fillStyle = this._placeholderColor;\r\n }\r\n }\r\n this._textWidth = context.measureText(text).width;\r\n var marginWidth = this._margin.getValueInPixel(this._host, this._tempParentMeasure.width) * 2;\r\n if (this._autoStretchWidth) {\r\n this.width = Math.min(this._maxWidth.getValueInPixel(this._host, this._tempParentMeasure.width), this._textWidth + marginWidth) + \"px\";\r\n }\r\n var rootY = this._fontOffset.ascent + (this._currentMeasure.height - this._fontOffset.height) / 2;\r\n var availableWidth = this._width.getValueInPixel(this._host, this._tempParentMeasure.width) - marginWidth;\r\n context.save();\r\n context.beginPath();\r\n context.rect(clipTextLeft, this._currentMeasure.top + (this._currentMeasure.height - this._fontOffset.height) / 2, availableWidth + 2, this._currentMeasure.height);\r\n context.clip();\r\n if (this._isFocused && this._textWidth > availableWidth) {\r\n var textLeft = clipTextLeft - this._textWidth + availableWidth;\r\n if (!this._scrollLeft) {\r\n this._scrollLeft = textLeft;\r\n }\r\n }\r\n else {\r\n this._scrollLeft = clipTextLeft;\r\n }\r\n context.fillText(text, this._scrollLeft, this._currentMeasure.top + rootY);\r\n // Cursor\r\n if (this._isFocused) {\r\n // Need to move cursor\r\n if (this._clickedCoordinate) {\r\n var rightPosition = this._scrollLeft + this._textWidth;\r\n var absoluteCursorPosition = rightPosition - this._clickedCoordinate;\r\n var currentSize = 0;\r\n this._cursorOffset = 0;\r\n var previousDist = 0;\r\n do {\r\n if (this._cursorOffset) {\r\n previousDist = Math.abs(absoluteCursorPosition - currentSize);\r\n }\r\n this._cursorOffset++;\r\n currentSize = context.measureText(text.substr(text.length - this._cursorOffset, this._cursorOffset)).width;\r\n } while (currentSize < absoluteCursorPosition && (text.length >= this._cursorOffset));\r\n // Find closest move\r\n if (Math.abs(absoluteCursorPosition - currentSize) > previousDist) {\r\n this._cursorOffset--;\r\n }\r\n this._blinkIsEven = false;\r\n this._clickedCoordinate = null;\r\n }\r\n // Render cursor\r\n if (!this._blinkIsEven) {\r\n var cursorOffsetText = this.text.substr(this._text.length - this._cursorOffset);\r\n var cursorOffsetWidth = context.measureText(cursorOffsetText).width;\r\n var cursorLeft = this._scrollLeft + this._textWidth - cursorOffsetWidth;\r\n if (cursorLeft < clipTextLeft) {\r\n this._scrollLeft += (clipTextLeft - cursorLeft);\r\n cursorLeft = clipTextLeft;\r\n this._markAsDirty();\r\n }\r\n else if (cursorLeft > clipTextLeft + availableWidth) {\r\n this._scrollLeft += (clipTextLeft + availableWidth - cursorLeft);\r\n cursorLeft = clipTextLeft + availableWidth;\r\n this._markAsDirty();\r\n }\r\n if (!this._isTextHighlightOn) {\r\n context.fillRect(cursorLeft, this._currentMeasure.top + (this._currentMeasure.height - this._fontOffset.height) / 2, 2, this._fontOffset.height);\r\n }\r\n }\r\n clearTimeout(this._blinkTimeout);\r\n this._blinkTimeout = setTimeout(function () {\r\n _this._blinkIsEven = !_this._blinkIsEven;\r\n _this._markAsDirty();\r\n }, 500);\r\n //show the highlighted text\r\n if (this._isTextHighlightOn) {\r\n clearTimeout(this._blinkTimeout);\r\n var highlightCursorOffsetWidth = context.measureText(this.text.substring(this._startHighlightIndex)).width;\r\n var highlightCursorLeft = this._scrollLeft + this._textWidth - highlightCursorOffsetWidth;\r\n this._highlightedText = this.text.substring(this._startHighlightIndex, this._endHighlightIndex);\r\n var width = context.measureText(this.text.substring(this._startHighlightIndex, this._endHighlightIndex)).width;\r\n if (highlightCursorLeft < clipTextLeft) {\r\n width = width - (clipTextLeft - highlightCursorLeft);\r\n if (!width) {\r\n // when using left arrow on text.length > availableWidth;\r\n // assigns the width of the first letter after clipTextLeft\r\n width = context.measureText(this.text.charAt(this.text.length - this._cursorOffset)).width;\r\n }\r\n highlightCursorLeft = clipTextLeft;\r\n }\r\n //for transparancy\r\n context.globalAlpha = this._highligherOpacity;\r\n context.fillStyle = this._textHighlightColor;\r\n context.fillRect(highlightCursorLeft, this._currentMeasure.top + (this._currentMeasure.height - this._fontOffset.height) / 2, width, this._fontOffset.height);\r\n context.globalAlpha = 1.0;\r\n }\r\n }\r\n context.restore();\r\n // Border\r\n if (this._thickness) {\r\n if (this._isFocused) {\r\n if (this.focusedColor) {\r\n context.strokeStyle = this.focusedColor;\r\n }\r\n }\r\n else {\r\n if (this.color) {\r\n context.strokeStyle = this.color;\r\n }\r\n }\r\n context.lineWidth = this._thickness;\r\n context.strokeRect(this._currentMeasure.left + this._thickness / 2, this._currentMeasure.top + this._thickness / 2, this._currentMeasure.width - this._thickness, this._currentMeasure.height - this._thickness);\r\n }\r\n context.restore();\r\n };\r\n InputText.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex) {\r\n if (!_super.prototype._onPointerDown.call(this, target, coordinates, pointerId, buttonIndex)) {\r\n return false;\r\n }\r\n this._clickedCoordinate = coordinates.x;\r\n this._isTextHighlightOn = false;\r\n this._highlightedText = \"\";\r\n this._cursorIndex = -1;\r\n this._isPointerDown = true;\r\n this._host._capturingControl[pointerId] = this;\r\n if (this._host.focusedControl === this) {\r\n // Move cursor\r\n clearTimeout(this._blinkTimeout);\r\n this._markAsDirty();\r\n return true;\r\n }\r\n if (!this._isEnabled) {\r\n return false;\r\n }\r\n this._host.focusedControl = this;\r\n return true;\r\n };\r\n InputText.prototype._onPointerMove = function (target, coordinates, pointerId) {\r\n if (this._host.focusedControl === this && this._isPointerDown) {\r\n this._clickedCoordinate = coordinates.x;\r\n this._markAsDirty();\r\n this._updateValueFromCursorIndex(this._cursorOffset);\r\n }\r\n _super.prototype._onPointerMove.call(this, target, coordinates, pointerId);\r\n };\r\n InputText.prototype._onPointerUp = function (target, coordinates, pointerId, buttonIndex, notifyClick) {\r\n this._isPointerDown = false;\r\n delete this._host._capturingControl[pointerId];\r\n _super.prototype._onPointerUp.call(this, target, coordinates, pointerId, buttonIndex, notifyClick);\r\n };\r\n InputText.prototype._beforeRenderText = function (text) {\r\n return text;\r\n };\r\n InputText.prototype.dispose = function () {\r\n _super.prototype.dispose.call(this);\r\n this.onBlurObservable.clear();\r\n this.onFocusObservable.clear();\r\n this.onTextChangedObservable.clear();\r\n this.onTextCopyObservable.clear();\r\n this.onTextCutObservable.clear();\r\n this.onTextPasteObservable.clear();\r\n this.onTextHighlightObservable.clear();\r\n this.onKeyboardEventProcessedObservable.clear();\r\n };\r\n return InputText;\r\n}(Control));\r\nexport { InputText };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.InputText\"] = InputText;\r\n//# sourceMappingURL=inputText.js.map","import { __extends } from \"tslib\";\r\nimport { Container } from \"./container\";\r\nimport { ValueAndUnit } from \"../valueAndUnit\";\r\nimport { Control } from \"./control\";\r\nimport { Tools } from '@babylonjs/core/Misc/tools';\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create a 2D grid container\r\n */\r\nvar Grid = /** @class */ (function (_super) {\r\n __extends(Grid, _super);\r\n /**\r\n * Creates a new Grid\r\n * @param name defines control name\r\n */\r\n function Grid(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._rowDefinitions = new Array();\r\n _this._columnDefinitions = new Array();\r\n _this._cells = {};\r\n _this._childControls = new Array();\r\n return _this;\r\n }\r\n Object.defineProperty(Grid.prototype, \"columnCount\", {\r\n /**\r\n * Gets the number of columns\r\n */\r\n get: function () {\r\n return this._columnDefinitions.length;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Grid.prototype, \"rowCount\", {\r\n /**\r\n * Gets the number of rows\r\n */\r\n get: function () {\r\n return this._rowDefinitions.length;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Grid.prototype, \"children\", {\r\n /** Gets the list of children */\r\n get: function () {\r\n return this._childControls;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Grid.prototype, \"cells\", {\r\n /** Gets the list of cells (e.g. the containers) */\r\n get: function () {\r\n return this._cells;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the definition of a specific row\r\n * @param index defines the index of the row\r\n * @returns the row definition\r\n */\r\n Grid.prototype.getRowDefinition = function (index) {\r\n if (index < 0 || index >= this._rowDefinitions.length) {\r\n return null;\r\n }\r\n return this._rowDefinitions[index];\r\n };\r\n /**\r\n * Gets the definition of a specific column\r\n * @param index defines the index of the column\r\n * @returns the column definition\r\n */\r\n Grid.prototype.getColumnDefinition = function (index) {\r\n if (index < 0 || index >= this._columnDefinitions.length) {\r\n return null;\r\n }\r\n return this._columnDefinitions[index];\r\n };\r\n /**\r\n * Adds a new row to the grid\r\n * @param height defines the height of the row (either in pixel or a value between 0 and 1)\r\n * @param isPixel defines if the height is expressed in pixel (or in percentage)\r\n * @returns the current grid\r\n */\r\n Grid.prototype.addRowDefinition = function (height, isPixel) {\r\n if (isPixel === void 0) { isPixel = false; }\r\n this._rowDefinitions.push(new ValueAndUnit(height, isPixel ? ValueAndUnit.UNITMODE_PIXEL : ValueAndUnit.UNITMODE_PERCENTAGE));\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /**\r\n * Adds a new column to the grid\r\n * @param width defines the width of the column (either in pixel or a value between 0 and 1)\r\n * @param isPixel defines if the width is expressed in pixel (or in percentage)\r\n * @returns the current grid\r\n */\r\n Grid.prototype.addColumnDefinition = function (width, isPixel) {\r\n if (isPixel === void 0) { isPixel = false; }\r\n this._columnDefinitions.push(new ValueAndUnit(width, isPixel ? ValueAndUnit.UNITMODE_PIXEL : ValueAndUnit.UNITMODE_PERCENTAGE));\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /**\r\n * Update a row definition\r\n * @param index defines the index of the row to update\r\n * @param height defines the height of the row (either in pixel or a value between 0 and 1)\r\n * @param isPixel defines if the weight is expressed in pixel (or in percentage)\r\n * @returns the current grid\r\n */\r\n Grid.prototype.setRowDefinition = function (index, height, isPixel) {\r\n if (isPixel === void 0) { isPixel = false; }\r\n if (index < 0 || index >= this._rowDefinitions.length) {\r\n return this;\r\n }\r\n var current = this._rowDefinitions[index];\r\n if (current && current.isPixel === isPixel && current.internalValue === height) {\r\n return this;\r\n }\r\n this._rowDefinitions[index] = new ValueAndUnit(height, isPixel ? ValueAndUnit.UNITMODE_PIXEL : ValueAndUnit.UNITMODE_PERCENTAGE);\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /**\r\n * Update a column definition\r\n * @param index defines the index of the column to update\r\n * @param width defines the width of the column (either in pixel or a value between 0 and 1)\r\n * @param isPixel defines if the width is expressed in pixel (or in percentage)\r\n * @returns the current grid\r\n */\r\n Grid.prototype.setColumnDefinition = function (index, width, isPixel) {\r\n if (isPixel === void 0) { isPixel = false; }\r\n if (index < 0 || index >= this._columnDefinitions.length) {\r\n return this;\r\n }\r\n var current = this._columnDefinitions[index];\r\n if (current && current.isPixel === isPixel && current.internalValue === width) {\r\n return this;\r\n }\r\n this._columnDefinitions[index] = new ValueAndUnit(width, isPixel ? ValueAndUnit.UNITMODE_PIXEL : ValueAndUnit.UNITMODE_PERCENTAGE);\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /**\r\n * Gets the list of children stored in a specific cell\r\n * @param row defines the row to check\r\n * @param column defines the column to check\r\n * @returns the list of controls\r\n */\r\n Grid.prototype.getChildrenAt = function (row, column) {\r\n var cell = this._cells[row + \":\" + column];\r\n if (!cell) {\r\n return null;\r\n }\r\n return cell.children;\r\n };\r\n /**\r\n * Gets a string representing the child cell info (row x column)\r\n * @param child defines the control to get info from\r\n * @returns a string containing the child cell info (row x column)\r\n */\r\n Grid.prototype.getChildCellInfo = function (child) {\r\n return child._tag;\r\n };\r\n Grid.prototype._removeCell = function (cell, key) {\r\n if (!cell) {\r\n return;\r\n }\r\n _super.prototype.removeControl.call(this, cell);\r\n for (var _i = 0, _a = cell.children; _i < _a.length; _i++) {\r\n var control = _a[_i];\r\n var childIndex = this._childControls.indexOf(control);\r\n if (childIndex !== -1) {\r\n this._childControls.splice(childIndex, 1);\r\n }\r\n }\r\n delete this._cells[key];\r\n };\r\n Grid.prototype._offsetCell = function (previousKey, key) {\r\n if (!this._cells[key]) {\r\n return;\r\n }\r\n this._cells[previousKey] = this._cells[key];\r\n for (var _i = 0, _a = this._cells[previousKey].children; _i < _a.length; _i++) {\r\n var control = _a[_i];\r\n control._tag = previousKey;\r\n }\r\n delete this._cells[key];\r\n };\r\n /**\r\n * Remove a column definition at specified index\r\n * @param index defines the index of the column to remove\r\n * @returns the current grid\r\n */\r\n Grid.prototype.removeColumnDefinition = function (index) {\r\n if (index < 0 || index >= this._columnDefinitions.length) {\r\n return this;\r\n }\r\n for (var x = 0; x < this._rowDefinitions.length; x++) {\r\n var key = x + \":\" + index;\r\n var cell = this._cells[key];\r\n this._removeCell(cell, key);\r\n }\r\n for (var x = 0; x < this._rowDefinitions.length; x++) {\r\n for (var y = index + 1; y < this._columnDefinitions.length; y++) {\r\n var previousKey = x + \":\" + (y - 1);\r\n var key = x + \":\" + y;\r\n this._offsetCell(previousKey, key);\r\n }\r\n }\r\n this._columnDefinitions.splice(index, 1);\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /**\r\n * Remove a row definition at specified index\r\n * @param index defines the index of the row to remove\r\n * @returns the current grid\r\n */\r\n Grid.prototype.removeRowDefinition = function (index) {\r\n if (index < 0 || index >= this._rowDefinitions.length) {\r\n return this;\r\n }\r\n for (var y = 0; y < this._columnDefinitions.length; y++) {\r\n var key = index + \":\" + y;\r\n var cell = this._cells[key];\r\n this._removeCell(cell, key);\r\n }\r\n for (var y = 0; y < this._columnDefinitions.length; y++) {\r\n for (var x = index + 1; x < this._rowDefinitions.length; x++) {\r\n var previousKey = x - 1 + \":\" + y;\r\n var key = x + \":\" + y;\r\n this._offsetCell(previousKey, key);\r\n }\r\n }\r\n this._rowDefinitions.splice(index, 1);\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /**\r\n * Adds a new control to the current grid\r\n * @param control defines the control to add\r\n * @param row defines the row where to add the control (0 by default)\r\n * @param column defines the column where to add the control (0 by default)\r\n * @returns the current grid\r\n */\r\n Grid.prototype.addControl = function (control, row, column) {\r\n if (row === void 0) { row = 0; }\r\n if (column === void 0) { column = 0; }\r\n if (this._rowDefinitions.length === 0) {\r\n // Add default row definition\r\n this.addRowDefinition(1, false);\r\n }\r\n if (this._columnDefinitions.length === 0) {\r\n // Add default column definition\r\n this.addColumnDefinition(1, false);\r\n }\r\n if (this._childControls.indexOf(control) !== -1) {\r\n Tools.Warn(\"Control (Name:\" + control.name + \", UniqueId:\" + control.uniqueId + \") is already associated with this grid. You must remove it before reattaching it\");\r\n return this;\r\n }\r\n var x = Math.min(row, this._rowDefinitions.length - 1);\r\n var y = Math.min(column, this._columnDefinitions.length - 1);\r\n var key = x + \":\" + y;\r\n var goodContainer = this._cells[key];\r\n if (!goodContainer) {\r\n goodContainer = new Container(key);\r\n this._cells[key] = goodContainer;\r\n goodContainer.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n goodContainer.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n _super.prototype.addControl.call(this, goodContainer);\r\n }\r\n goodContainer.addControl(control);\r\n this._childControls.push(control);\r\n control._tag = key;\r\n control.parent = this;\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /**\r\n * Removes a control from the current container\r\n * @param control defines the control to remove\r\n * @returns the current container\r\n */\r\n Grid.prototype.removeControl = function (control) {\r\n var index = this._childControls.indexOf(control);\r\n if (index !== -1) {\r\n this._childControls.splice(index, 1);\r\n }\r\n var cell = this._cells[control._tag];\r\n if (cell) {\r\n cell.removeControl(control);\r\n control._tag = null;\r\n }\r\n this._markAsDirty();\r\n return this;\r\n };\r\n Grid.prototype._getTypeName = function () {\r\n return \"Grid\";\r\n };\r\n Grid.prototype._getGridDefinitions = function (definitionCallback) {\r\n var widths = [];\r\n var heights = [];\r\n var lefts = [];\r\n var tops = [];\r\n var availableWidth = this._currentMeasure.width;\r\n var globalWidthPercentage = 0;\r\n var availableHeight = this._currentMeasure.height;\r\n var globalHeightPercentage = 0;\r\n // Heights\r\n var index = 0;\r\n for (var _i = 0, _a = this._rowDefinitions; _i < _a.length; _i++) {\r\n var value = _a[_i];\r\n if (value.isPixel) {\r\n var height = value.getValue(this._host);\r\n availableHeight -= height;\r\n heights[index] = height;\r\n }\r\n else {\r\n globalHeightPercentage += value.internalValue;\r\n }\r\n index++;\r\n }\r\n var top = 0;\r\n index = 0;\r\n for (var _b = 0, _c = this._rowDefinitions; _b < _c.length; _b++) {\r\n var value = _c[_b];\r\n tops.push(top);\r\n if (!value.isPixel) {\r\n var height = (value.internalValue / globalHeightPercentage) * availableHeight;\r\n top += height;\r\n heights[index] = height;\r\n }\r\n else {\r\n top += value.getValue(this._host);\r\n }\r\n index++;\r\n }\r\n // Widths\r\n index = 0;\r\n for (var _d = 0, _e = this._columnDefinitions; _d < _e.length; _d++) {\r\n var value = _e[_d];\r\n if (value.isPixel) {\r\n var width = value.getValue(this._host);\r\n availableWidth -= width;\r\n widths[index] = width;\r\n }\r\n else {\r\n globalWidthPercentage += value.internalValue;\r\n }\r\n index++;\r\n }\r\n var left = 0;\r\n index = 0;\r\n for (var _f = 0, _g = this._columnDefinitions; _f < _g.length; _f++) {\r\n var value = _g[_f];\r\n lefts.push(left);\r\n if (!value.isPixel) {\r\n var width = (value.internalValue / globalWidthPercentage) * availableWidth;\r\n left += width;\r\n widths[index] = width;\r\n }\r\n else {\r\n left += value.getValue(this._host);\r\n }\r\n index++;\r\n }\r\n definitionCallback(lefts, tops, widths, heights);\r\n };\r\n Grid.prototype._additionalProcessing = function (parentMeasure, context) {\r\n var _this = this;\r\n this._getGridDefinitions(function (lefts, tops, widths, heights) {\r\n // Setting child sizes\r\n for (var key in _this._cells) {\r\n if (!_this._cells.hasOwnProperty(key)) {\r\n continue;\r\n }\r\n var split = key.split(\":\");\r\n var x = parseInt(split[0]);\r\n var y = parseInt(split[1]);\r\n var cell = _this._cells[key];\r\n cell.left = lefts[y] + \"px\";\r\n cell.top = tops[x] + \"px\";\r\n cell.width = widths[y] + \"px\";\r\n cell.height = heights[x] + \"px\";\r\n cell._left.ignoreAdaptiveScaling = true;\r\n cell._top.ignoreAdaptiveScaling = true;\r\n cell._width.ignoreAdaptiveScaling = true;\r\n cell._height.ignoreAdaptiveScaling = true;\r\n }\r\n });\r\n _super.prototype._additionalProcessing.call(this, parentMeasure, context);\r\n };\r\n Grid.prototype._flagDescendantsAsMatrixDirty = function () {\r\n for (var key in this._cells) {\r\n if (!this._cells.hasOwnProperty(key)) {\r\n continue;\r\n }\r\n var child = this._cells[key];\r\n child._markMatrixAsDirty();\r\n }\r\n };\r\n Grid.prototype._renderHighlightSpecific = function (context) {\r\n var _this = this;\r\n _super.prototype._renderHighlightSpecific.call(this, context);\r\n this._getGridDefinitions(function (lefts, tops, widths, heights) {\r\n // Columns\r\n for (var index = 0; index < lefts.length; index++) {\r\n var left = _this._currentMeasure.left + lefts[index] + widths[index];\r\n context.beginPath();\r\n context.moveTo(left, _this._currentMeasure.top);\r\n context.lineTo(left, _this._currentMeasure.top + _this._currentMeasure.height);\r\n context.stroke();\r\n }\r\n // Rows\r\n for (var index = 0; index < tops.length; index++) {\r\n var top_1 = _this._currentMeasure.top + tops[index] + heights[index];\r\n context.beginPath();\r\n context.moveTo(_this._currentMeasure.left, top_1);\r\n context.lineTo(_this._currentMeasure.left + _this._currentMeasure.width, top_1);\r\n context.stroke();\r\n }\r\n });\r\n context.restore();\r\n };\r\n /** Releases associated resources */\r\n Grid.prototype.dispose = function () {\r\n _super.prototype.dispose.call(this);\r\n for (var _i = 0, _a = this._childControls; _i < _a.length; _i++) {\r\n var control = _a[_i];\r\n control.dispose();\r\n }\r\n this._childControls = [];\r\n };\r\n return Grid;\r\n}(Container));\r\nexport { Grid };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Grid\"] = Grid;\r\n//# sourceMappingURL=grid.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { Control } from \"./control\";\r\nimport { InputText } from \"./inputText\";\r\nimport { Rectangle } from \"./rectangle\";\r\nimport { Button } from \"./button\";\r\nimport { Grid } from \"./grid\";\r\nimport { TextBlock } from \"../controls/textBlock\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\nimport { Color3 } from '@babylonjs/core/Maths/math.color';\r\n/** Class used to create color pickers */\r\nvar ColorPicker = /** @class */ (function (_super) {\r\n __extends(ColorPicker, _super);\r\n /**\r\n * Creates a new ColorPicker\r\n * @param name defines the control name\r\n */\r\n function ColorPicker(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._value = Color3.Red();\r\n _this._tmpColor = new Color3();\r\n _this._pointerStartedOnSquare = false;\r\n _this._pointerStartedOnWheel = false;\r\n _this._squareLeft = 0;\r\n _this._squareTop = 0;\r\n _this._squareSize = 0;\r\n _this._h = 360;\r\n _this._s = 1;\r\n _this._v = 1;\r\n _this._lastPointerDownID = -1;\r\n /**\r\n * Observable raised when the value changes\r\n */\r\n _this.onValueChangedObservable = new Observable();\r\n // Events\r\n _this._pointerIsDown = false;\r\n _this.value = new Color3(.88, .1, .1);\r\n _this.size = \"200px\";\r\n _this.isPointerBlocker = true;\r\n return _this;\r\n }\r\n Object.defineProperty(ColorPicker.prototype, \"value\", {\r\n /** Gets or sets the color of the color picker */\r\n get: function () {\r\n return this._value;\r\n },\r\n set: function (value) {\r\n if (this._value.equals(value)) {\r\n return;\r\n }\r\n this._value.copyFrom(value);\r\n this._value.toHSVToRef(this._tmpColor);\r\n this._h = this._tmpColor.r;\r\n this._s = Math.max(this._tmpColor.g, 0.00001);\r\n this._v = Math.max(this._tmpColor.b, 0.00001);\r\n this._markAsDirty();\r\n if (this._value.r <= ColorPicker._Epsilon) {\r\n this._value.r = 0;\r\n }\r\n if (this._value.g <= ColorPicker._Epsilon) {\r\n this._value.g = 0;\r\n }\r\n if (this._value.b <= ColorPicker._Epsilon) {\r\n this._value.b = 0;\r\n }\r\n if (this._value.r >= 1.0 - ColorPicker._Epsilon) {\r\n this._value.r = 1.0;\r\n }\r\n if (this._value.g >= 1.0 - ColorPicker._Epsilon) {\r\n this._value.g = 1.0;\r\n }\r\n if (this._value.b >= 1.0 - ColorPicker._Epsilon) {\r\n this._value.b = 1.0;\r\n }\r\n this.onValueChangedObservable.notifyObservers(this._value);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorPicker.prototype, \"width\", {\r\n /**\r\n * Gets or sets control width\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._width.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._width.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._width.fromString(value)) {\r\n this._height.fromString(value);\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorPicker.prototype, \"height\", {\r\n /**\r\n * Gets or sets control height\r\n * @see http://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._height.toString(this._host);\r\n },\r\n /** Gets or sets control height */\r\n set: function (value) {\r\n if (this._height.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._height.fromString(value)) {\r\n this._width.fromString(value);\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorPicker.prototype, \"size\", {\r\n /** Gets or sets control size */\r\n get: function () {\r\n return this.width;\r\n },\r\n set: function (value) {\r\n this.width = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n ColorPicker.prototype._getTypeName = function () {\r\n return \"ColorPicker\";\r\n };\r\n /** @hidden */\r\n ColorPicker.prototype._preMeasure = function (parentMeasure, context) {\r\n if (parentMeasure.width < parentMeasure.height) {\r\n this._currentMeasure.height = parentMeasure.width;\r\n }\r\n else {\r\n this._currentMeasure.width = parentMeasure.height;\r\n }\r\n };\r\n ColorPicker.prototype._updateSquareProps = function () {\r\n var radius = Math.min(this._currentMeasure.width, this._currentMeasure.height) * .5;\r\n var wheelThickness = radius * .2;\r\n var innerDiameter = (radius - wheelThickness) * 2;\r\n var squareSize = innerDiameter / (Math.sqrt(2));\r\n var offset = radius - squareSize * .5;\r\n this._squareLeft = this._currentMeasure.left + offset;\r\n this._squareTop = this._currentMeasure.top + offset;\r\n this._squareSize = squareSize;\r\n };\r\n ColorPicker.prototype._drawGradientSquare = function (hueValue, left, top, width, height, context) {\r\n var lgh = context.createLinearGradient(left, top, width + left, top);\r\n lgh.addColorStop(0, '#fff');\r\n lgh.addColorStop(1, 'hsl(' + hueValue + ', 100%, 50%)');\r\n context.fillStyle = lgh;\r\n context.fillRect(left, top, width, height);\r\n var lgv = context.createLinearGradient(left, top, left, height + top);\r\n lgv.addColorStop(0, 'rgba(0,0,0,0)');\r\n lgv.addColorStop(1, '#000');\r\n context.fillStyle = lgv;\r\n context.fillRect(left, top, width, height);\r\n };\r\n ColorPicker.prototype._drawCircle = function (centerX, centerY, radius, context) {\r\n context.beginPath();\r\n context.arc(centerX, centerY, radius + 1, 0, 2 * Math.PI, false);\r\n context.lineWidth = 3;\r\n context.strokeStyle = '#333333';\r\n context.stroke();\r\n context.beginPath();\r\n context.arc(centerX, centerY, radius, 0, 2 * Math.PI, false);\r\n context.lineWidth = 3;\r\n context.strokeStyle = '#ffffff';\r\n context.stroke();\r\n };\r\n ColorPicker.prototype._createColorWheelCanvas = function (radius, thickness) {\r\n var canvas = document.createElement(\"canvas\");\r\n canvas.width = radius * 2;\r\n canvas.height = radius * 2;\r\n var context = canvas.getContext(\"2d\");\r\n var image = context.getImageData(0, 0, radius * 2, radius * 2);\r\n var data = image.data;\r\n var color = this._tmpColor;\r\n var maxDistSq = radius * radius;\r\n var innerRadius = radius - thickness;\r\n var minDistSq = innerRadius * innerRadius;\r\n for (var x = -radius; x < radius; x++) {\r\n for (var y = -radius; y < radius; y++) {\r\n var distSq = x * x + y * y;\r\n if (distSq > maxDistSq || distSq < minDistSq) {\r\n continue;\r\n }\r\n var dist = Math.sqrt(distSq);\r\n var ang = Math.atan2(y, x);\r\n Color3.HSVtoRGBToRef(ang * 180 / Math.PI + 180, dist / radius, 1, color);\r\n var index = ((x + radius) + ((y + radius) * 2 * radius)) * 4;\r\n data[index] = color.r * 255;\r\n data[index + 1] = color.g * 255;\r\n data[index + 2] = color.b * 255;\r\n var alphaRatio = (dist - innerRadius) / (radius - innerRadius);\r\n //apply less alpha to bigger color pickers\r\n var alphaAmount = .2;\r\n var maxAlpha = .2;\r\n var minAlpha = .04;\r\n var lowerRadius = 50;\r\n var upperRadius = 150;\r\n if (radius < lowerRadius) {\r\n alphaAmount = maxAlpha;\r\n }\r\n else if (radius > upperRadius) {\r\n alphaAmount = minAlpha;\r\n }\r\n else {\r\n alphaAmount = (minAlpha - maxAlpha) * (radius - lowerRadius) / (upperRadius - lowerRadius) + maxAlpha;\r\n }\r\n var alphaRatio = (dist - innerRadius) / (radius - innerRadius);\r\n if (alphaRatio < alphaAmount) {\r\n data[index + 3] = 255 * (alphaRatio / alphaAmount);\r\n }\r\n else if (alphaRatio > 1 - alphaAmount) {\r\n data[index + 3] = 255 * (1.0 - ((alphaRatio - (1 - alphaAmount)) / alphaAmount));\r\n }\r\n else {\r\n data[index + 3] = 255;\r\n }\r\n }\r\n }\r\n context.putImageData(image, 0, 0);\r\n return canvas;\r\n };\r\n /** @hidden */\r\n ColorPicker.prototype._draw = function (context) {\r\n context.save();\r\n this._applyStates(context);\r\n var radius = Math.min(this._currentMeasure.width, this._currentMeasure.height) * .5;\r\n var wheelThickness = radius * .2;\r\n var left = this._currentMeasure.left;\r\n var top = this._currentMeasure.top;\r\n if (!this._colorWheelCanvas || this._colorWheelCanvas.width != radius * 2) {\r\n this._colorWheelCanvas = this._createColorWheelCanvas(radius, wheelThickness);\r\n }\r\n this._updateSquareProps();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n context.fillRect(this._squareLeft, this._squareTop, this._squareSize, this._squareSize);\r\n }\r\n context.drawImage(this._colorWheelCanvas, left, top);\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n this._drawGradientSquare(this._h, this._squareLeft, this._squareTop, this._squareSize, this._squareSize, context);\r\n var cx = this._squareLeft + this._squareSize * this._s;\r\n var cy = this._squareTop + this._squareSize * (1 - this._v);\r\n this._drawCircle(cx, cy, radius * .04, context);\r\n var dist = radius - wheelThickness * .5;\r\n cx = left + radius + Math.cos((this._h - 180) * Math.PI / 180) * dist;\r\n cy = top + radius + Math.sin((this._h - 180) * Math.PI / 180) * dist;\r\n this._drawCircle(cx, cy, wheelThickness * .35, context);\r\n context.restore();\r\n };\r\n ColorPicker.prototype._updateValueFromPointer = function (x, y) {\r\n if (this._pointerStartedOnWheel) {\r\n var radius = Math.min(this._currentMeasure.width, this._currentMeasure.height) * .5;\r\n var centerX = radius + this._currentMeasure.left;\r\n var centerY = radius + this._currentMeasure.top;\r\n this._h = Math.atan2(y - centerY, x - centerX) * 180 / Math.PI + 180;\r\n }\r\n else if (this._pointerStartedOnSquare) {\r\n this._updateSquareProps();\r\n this._s = (x - this._squareLeft) / this._squareSize;\r\n this._v = 1 - (y - this._squareTop) / this._squareSize;\r\n this._s = Math.min(this._s, 1);\r\n this._s = Math.max(this._s, ColorPicker._Epsilon);\r\n this._v = Math.min(this._v, 1);\r\n this._v = Math.max(this._v, ColorPicker._Epsilon);\r\n }\r\n Color3.HSVtoRGBToRef(this._h, this._s, this._v, this._tmpColor);\r\n this.value = this._tmpColor;\r\n };\r\n ColorPicker.prototype._isPointOnSquare = function (x, y) {\r\n this._updateSquareProps();\r\n var left = this._squareLeft;\r\n var top = this._squareTop;\r\n var size = this._squareSize;\r\n if (x >= left && x <= left + size &&\r\n y >= top && y <= top + size) {\r\n return true;\r\n }\r\n return false;\r\n };\r\n ColorPicker.prototype._isPointOnWheel = function (x, y) {\r\n var radius = Math.min(this._currentMeasure.width, this._currentMeasure.height) * .5;\r\n var centerX = radius + this._currentMeasure.left;\r\n var centerY = radius + this._currentMeasure.top;\r\n var wheelThickness = radius * .2;\r\n var innerRadius = radius - wheelThickness;\r\n var radiusSq = radius * radius;\r\n var innerRadiusSq = innerRadius * innerRadius;\r\n var dx = x - centerX;\r\n var dy = y - centerY;\r\n var distSq = dx * dx + dy * dy;\r\n if (distSq <= radiusSq && distSq >= innerRadiusSq) {\r\n return true;\r\n }\r\n return false;\r\n };\r\n ColorPicker.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex) {\r\n if (!_super.prototype._onPointerDown.call(this, target, coordinates, pointerId, buttonIndex)) {\r\n return false;\r\n }\r\n this._pointerIsDown = true;\r\n this._pointerStartedOnSquare = false;\r\n this._pointerStartedOnWheel = false;\r\n // Invert transform\r\n this._invertTransformMatrix.transformCoordinates(coordinates.x, coordinates.y, this._transformedPosition);\r\n var x = this._transformedPosition.x;\r\n var y = this._transformedPosition.y;\r\n if (this._isPointOnSquare(x, y)) {\r\n this._pointerStartedOnSquare = true;\r\n }\r\n else if (this._isPointOnWheel(x, y)) {\r\n this._pointerStartedOnWheel = true;\r\n }\r\n this._updateValueFromPointer(x, y);\r\n this._host._capturingControl[pointerId] = this;\r\n this._lastPointerDownID = pointerId;\r\n return true;\r\n };\r\n ColorPicker.prototype._onPointerMove = function (target, coordinates, pointerId) {\r\n // Only listen to pointer move events coming from the last pointer to click on the element (To support dual vr controller interaction)\r\n if (pointerId != this._lastPointerDownID) {\r\n return;\r\n }\r\n // Invert transform\r\n this._invertTransformMatrix.transformCoordinates(coordinates.x, coordinates.y, this._transformedPosition);\r\n var x = this._transformedPosition.x;\r\n var y = this._transformedPosition.y;\r\n if (this._pointerIsDown) {\r\n this._updateValueFromPointer(x, y);\r\n }\r\n _super.prototype._onPointerMove.call(this, target, coordinates, pointerId);\r\n };\r\n ColorPicker.prototype._onPointerUp = function (target, coordinates, pointerId, buttonIndex, notifyClick) {\r\n this._pointerIsDown = false;\r\n delete this._host._capturingControl[pointerId];\r\n _super.prototype._onPointerUp.call(this, target, coordinates, pointerId, buttonIndex, notifyClick);\r\n };\r\n /**\r\n * This function expands the color picker by creating a color picker dialog with manual\r\n * color value input and the ability to save colors into an array to be used later in\r\n * subsequent launches of the dialogue.\r\n * @param advancedTexture defines the AdvancedDynamicTexture the dialog is assigned to\r\n * @param options defines size for dialog and options for saved colors. Also accepts last color picked as hex string and saved colors array as hex strings.\r\n * @returns picked color as a hex string and the saved colors array as hex strings.\r\n */\r\n ColorPicker.ShowPickerDialogAsync = function (advancedTexture, options) {\r\n return new Promise(function (resolve, reject) {\r\n // Default options\r\n options.pickerWidth = options.pickerWidth || \"640px\";\r\n options.pickerHeight = options.pickerHeight || \"400px\";\r\n options.headerHeight = options.headerHeight || \"35px\";\r\n options.lastColor = options.lastColor || \"#000000\";\r\n options.swatchLimit = options.swatchLimit || 20;\r\n options.numSwatchesPerLine = options.numSwatchesPerLine || 10;\r\n // Window size settings\r\n var drawerMaxRows = options.swatchLimit / options.numSwatchesPerLine;\r\n var rawSwatchSize = parseFloat(options.pickerWidth) / options.numSwatchesPerLine;\r\n var gutterSize = Math.floor(rawSwatchSize * 0.25);\r\n var colGutters = gutterSize * (options.numSwatchesPerLine + 1);\r\n var swatchSize = Math.floor((parseFloat(options.pickerWidth) - colGutters) / options.numSwatchesPerLine);\r\n var drawerMaxSize = (swatchSize * drawerMaxRows) + (gutterSize * (drawerMaxRows + 1));\r\n var containerSize = (parseInt(options.pickerHeight) + drawerMaxSize + Math.floor(swatchSize * 0.25)).toString() + \"px\";\r\n // Button Colors\r\n var buttonColor = \"#c0c0c0\";\r\n var buttonBackgroundColor = \"#535353\";\r\n var buttonBackgroundHoverColor = \"#414141\";\r\n var buttonBackgroundClickColor = \"515151\";\r\n var buttonDisabledColor = \"#555555\";\r\n var buttonDisabledBackgroundColor = \"#454545\";\r\n var currentSwatchesOutlineColor = \"#404040\";\r\n var luminanceLimitColor = Color3.FromHexString(\"#dddddd\");\r\n var luminanceLimit = luminanceLimitColor.r + luminanceLimitColor.g + luminanceLimitColor.b;\r\n var iconColorDark = \"#aaaaaa\";\r\n var iconColorLight = \"#ffffff\";\r\n var closeIconColor;\r\n // Button settings\r\n var buttonFontSize;\r\n var butEdit;\r\n var buttonWidth;\r\n var buttonHeight;\r\n // Input Text Colors\r\n var inputFieldLabels = [\"R\", \"G\", \"B\"];\r\n var inputTextBackgroundColor = \"#454545\";\r\n var inputTextColor = \"#f0f0f0\";\r\n // This is the current color as set by either the picker or by entering a value\r\n var currentColor;\r\n // This int is used for naming swatches and serves as the index for calling them from the list\r\n var swatchNumber;\r\n // Menu Panel options. We need to know if the swatchDrawer exists so we can create it if needed.\r\n var swatchDrawer;\r\n var editSwatchMode = false;\r\n // Color InputText fields that will be updated upon value change\r\n var picker;\r\n var rValInt;\r\n var gValInt;\r\n var bValInt;\r\n var rValDec;\r\n var gValDec;\r\n var bValDec;\r\n var hexVal;\r\n var newSwatch;\r\n var lastVal;\r\n var activeField;\r\n /**\r\n * Will update all values for InputText and ColorPicker controls based on the BABYLON.Color3 passed to this function.\r\n * Each InputText control and the ColorPicker control will be tested to see if they are the activeField and if they\r\n * are will receive no update. This is to prevent the input from the user being overwritten.\r\n */\r\n function updateValues(value, inputField) {\r\n activeField = inputField;\r\n var pickedColor = value.toHexString();\r\n newSwatch.background = pickedColor;\r\n if (rValInt.name != activeField) {\r\n rValInt.text = Math.floor(value.r * 255).toString();\r\n }\r\n if (gValInt.name != activeField) {\r\n gValInt.text = Math.floor(value.g * 255).toString();\r\n }\r\n if (bValInt.name != activeField) {\r\n bValInt.text = Math.floor(value.b * 255).toString();\r\n }\r\n if (rValDec.name != activeField) {\r\n rValDec.text = value.r.toString();\r\n }\r\n if (gValDec.name != activeField) {\r\n gValDec.text = value.g.toString();\r\n }\r\n if (bValDec.name != activeField) {\r\n bValDec.text = value.b.toString();\r\n }\r\n if (hexVal.name != activeField) {\r\n var minusPound = pickedColor.split(\"#\");\r\n hexVal.text = minusPound[1];\r\n }\r\n if (picker.name != activeField) {\r\n picker.value = value;\r\n }\r\n }\r\n // When the user enters an integer for R, G, or B we check to make sure it is a valid number and replace if not.\r\n function updateInt(field, channel) {\r\n var newValue = field.text;\r\n var checkVal = /[^0-9]/g.test(newValue);\r\n if (checkVal) {\r\n field.text = lastVal;\r\n return;\r\n }\r\n else {\r\n if (newValue != \"\") {\r\n if (Math.floor(parseInt(newValue)) < 0) {\r\n newValue = \"0\";\r\n }\r\n else if (Math.floor(parseInt(newValue)) > 255) {\r\n newValue = \"255\";\r\n }\r\n else if (isNaN(parseInt(newValue))) {\r\n newValue = \"0\";\r\n }\r\n }\r\n if (activeField == field.name) {\r\n lastVal = newValue;\r\n }\r\n }\r\n if (newValue != \"\") {\r\n newValue = parseInt(newValue).toString();\r\n field.text = newValue;\r\n var newSwatchRGB = Color3.FromHexString(newSwatch.background);\r\n if (activeField == field.name) {\r\n if (channel == \"r\") {\r\n updateValues(new Color3((parseInt(newValue)) / 255, newSwatchRGB.g, newSwatchRGB.b), field.name);\r\n }\r\n else if (channel == \"g\") {\r\n updateValues(new Color3(newSwatchRGB.r, (parseInt(newValue)) / 255, newSwatchRGB.b), field.name);\r\n }\r\n else {\r\n updateValues(new Color3(newSwatchRGB.r, newSwatchRGB.g, (parseInt(newValue)) / 255), field.name);\r\n }\r\n }\r\n }\r\n }\r\n // When the user enters a float for R, G, or B we check to make sure it is a valid number and replace if not.\r\n function updateFloat(field, channel) {\r\n var newValue = field.text;\r\n var checkVal = /[^0-9\\.]/g.test(newValue);\r\n if (checkVal) {\r\n field.text = lastVal;\r\n return;\r\n }\r\n else {\r\n if (newValue != \"\" && newValue != \".\" && parseFloat(newValue) != 0) {\r\n if (parseFloat(newValue) < 0.0) {\r\n newValue = \"0.0\";\r\n }\r\n else if (parseFloat(newValue) > 1.0) {\r\n newValue = \"1.0\";\r\n }\r\n else if (isNaN(parseFloat(newValue))) {\r\n newValue = \"0.0\";\r\n }\r\n }\r\n if (activeField == field.name) {\r\n lastVal = newValue;\r\n }\r\n }\r\n if (newValue != \"\" && newValue != \".\" && parseFloat(newValue) != 0) {\r\n newValue = parseFloat(newValue).toString();\r\n field.text = newValue;\r\n }\r\n else {\r\n newValue = \"0.0\";\r\n }\r\n var newSwatchRGB = Color3.FromHexString(newSwatch.background);\r\n if (activeField == field.name) {\r\n if (channel == \"r\") {\r\n updateValues(new Color3(parseFloat(newValue), newSwatchRGB.g, newSwatchRGB.b), field.name);\r\n }\r\n else if (channel == \"g\") {\r\n updateValues(new Color3(newSwatchRGB.r, parseFloat(newValue), newSwatchRGB.b), field.name);\r\n }\r\n else {\r\n updateValues(new Color3(newSwatchRGB.r, newSwatchRGB.g, parseFloat(newValue)), field.name);\r\n }\r\n }\r\n }\r\n // Removes the current index from the savedColors array. Drawer can then be regenerated.\r\n function deleteSwatch(index) {\r\n if (options.savedColors) {\r\n options.savedColors.splice(index, 1);\r\n }\r\n if (options.savedColors && options.savedColors.length == 0) {\r\n setEditButtonVisibility(false);\r\n editSwatchMode = false;\r\n }\r\n }\r\n // Creates and styles an individual swatch when updateSwatches is called.\r\n function createSwatch() {\r\n if (options.savedColors && options.savedColors[swatchNumber]) {\r\n if (editSwatchMode) {\r\n var icon = \"b\";\r\n }\r\n else {\r\n var icon = \"\";\r\n }\r\n var swatch = Button.CreateSimpleButton(\"Swatch_\" + swatchNumber, icon);\r\n swatch.fontFamily = \"BabylonJSglyphs\";\r\n var swatchColor = Color3.FromHexString(options.savedColors[swatchNumber]);\r\n var swatchLuminence = swatchColor.r + swatchColor.g + swatchColor.b;\r\n // Set color of outline and textBlock based on luminance of the color swatch so feedback always visible\r\n if (swatchLuminence > luminanceLimit) {\r\n swatch.color = iconColorDark;\r\n }\r\n else {\r\n swatch.color = iconColorLight;\r\n }\r\n swatch.fontSize = Math.floor(swatchSize * 0.7);\r\n swatch.textBlock.verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n swatch.height = swatch.width = (swatchSize).toString() + \"px\";\r\n swatch.background = options.savedColors[swatchNumber];\r\n swatch.thickness = 2;\r\n var metadata_1 = swatchNumber;\r\n swatch.pointerDownAnimation = function () {\r\n swatch.thickness = 4;\r\n };\r\n swatch.pointerUpAnimation = function () {\r\n swatch.thickness = 3;\r\n };\r\n swatch.pointerEnterAnimation = function () {\r\n swatch.thickness = 3;\r\n };\r\n swatch.pointerOutAnimation = function () {\r\n swatch.thickness = 2;\r\n };\r\n swatch.onPointerClickObservable.add(function () {\r\n if (!editSwatchMode) {\r\n if (options.savedColors) {\r\n updateValues(Color3.FromHexString(options.savedColors[metadata_1]), swatch.name);\r\n }\r\n }\r\n else {\r\n deleteSwatch(metadata_1);\r\n updateSwatches(\"\", butSave);\r\n }\r\n });\r\n return swatch;\r\n }\r\n else {\r\n return null;\r\n }\r\n }\r\n // Mode switch to render button text and close symbols on swatch controls\r\n function editSwatches(mode) {\r\n if (mode !== undefined) {\r\n editSwatchMode = mode;\r\n }\r\n if (editSwatchMode) {\r\n for (var i = 0; i < swatchDrawer.children.length; i++) {\r\n var thisButton = swatchDrawer.children[i];\r\n thisButton.textBlock.text = \"b\";\r\n }\r\n if (butEdit !== undefined) {\r\n butEdit.textBlock.text = \"Done\";\r\n }\r\n }\r\n else {\r\n for (var i = 0; i < swatchDrawer.children.length; i++) {\r\n var thisButton = swatchDrawer.children[i];\r\n thisButton.textBlock.text = \"\";\r\n }\r\n if (butEdit !== undefined) {\r\n butEdit.textBlock.text = \"Edit\";\r\n }\r\n }\r\n }\r\n /**\r\n * When Save Color button is pressed this function will first create a swatch drawer if one is not already\r\n * made. Then all controls are removed from the drawer and we step through the savedColors array and\r\n * creates one swatch per color. It will also set the height of the drawer control based on how many\r\n * saved colors there are and how many can be stored per row.\r\n */\r\n function updateSwatches(color, button) {\r\n if (options.savedColors) {\r\n if (color != \"\") {\r\n options.savedColors.push(color);\r\n }\r\n swatchNumber = 0;\r\n swatchDrawer.clearControls();\r\n var rowCount = Math.ceil(options.savedColors.length / options.numSwatchesPerLine);\r\n if (rowCount == 0) {\r\n var gutterCount = 0;\r\n }\r\n else {\r\n var gutterCount = rowCount + 1;\r\n }\r\n if (swatchDrawer.rowCount != rowCount + gutterCount) {\r\n var currentRows = swatchDrawer.rowCount;\r\n for (var i = 0; i < currentRows; i++) {\r\n swatchDrawer.removeRowDefinition(0);\r\n }\r\n for (var i = 0; i < rowCount + gutterCount; i++) {\r\n if (i % 2) {\r\n swatchDrawer.addRowDefinition(swatchSize, true);\r\n }\r\n else {\r\n swatchDrawer.addRowDefinition(gutterSize, true);\r\n }\r\n }\r\n }\r\n swatchDrawer.height = ((swatchSize * rowCount) + (gutterCount * gutterSize)).toString() + \"px\";\r\n for (var y = 1, thisRow = 1; y < rowCount + gutterCount; y += 2, thisRow++) {\r\n // Determine number of buttons to create per row based on the button limit per row and number of saved colors\r\n if (options.savedColors.length > thisRow * options.numSwatchesPerLine) {\r\n var totalButtonsThisRow = options.numSwatchesPerLine;\r\n }\r\n else {\r\n var totalButtonsThisRow = options.savedColors.length - ((thisRow - 1) * options.numSwatchesPerLine);\r\n }\r\n var buttonIterations = (Math.min(Math.max(totalButtonsThisRow, 0), options.numSwatchesPerLine));\r\n for (var x = 0, w = 1; x < buttonIterations; x++) {\r\n if (x > options.numSwatchesPerLine) {\r\n continue;\r\n }\r\n var swatch = createSwatch();\r\n if (swatch != null) {\r\n swatchDrawer.addControl(swatch, y, w);\r\n w += 2;\r\n swatchNumber++;\r\n }\r\n else {\r\n continue;\r\n }\r\n }\r\n }\r\n if (options.savedColors.length >= options.swatchLimit) {\r\n disableButton(button, true);\r\n }\r\n else {\r\n disableButton(button, false);\r\n }\r\n }\r\n }\r\n // Shows or hides edit swatches button depending on if there are saved swatches\r\n function setEditButtonVisibility(enableButton) {\r\n if (enableButton) {\r\n butEdit = Button.CreateSimpleButton(\"butEdit\", \"Edit\");\r\n butEdit.width = buttonWidth;\r\n butEdit.height = buttonHeight;\r\n butEdit.left = (Math.floor(parseInt(buttonWidth) * 0.1)).toString() + \"px\";\r\n butEdit.top = (parseFloat(butEdit.left) * -1).toString() + \"px\";\r\n butEdit.verticalAlignment = Control.VERTICAL_ALIGNMENT_BOTTOM;\r\n butEdit.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n butEdit.thickness = 2;\r\n butEdit.color = buttonColor;\r\n butEdit.fontSize = buttonFontSize;\r\n butEdit.background = buttonBackgroundColor;\r\n butEdit.onPointerEnterObservable.add(function () {\r\n butEdit.background = buttonBackgroundHoverColor;\r\n });\r\n butEdit.onPointerOutObservable.add(function () {\r\n butEdit.background = buttonBackgroundColor;\r\n });\r\n butEdit.pointerDownAnimation = function () {\r\n butEdit.background = buttonBackgroundClickColor;\r\n };\r\n butEdit.pointerUpAnimation = function () {\r\n butEdit.background = buttonBackgroundHoverColor;\r\n };\r\n butEdit.onPointerClickObservable.add(function () {\r\n if (editSwatchMode) {\r\n editSwatchMode = false;\r\n }\r\n else {\r\n editSwatchMode = true;\r\n }\r\n editSwatches();\r\n });\r\n pickerGrid.addControl(butEdit, 1, 0);\r\n }\r\n else {\r\n pickerGrid.removeControl(butEdit);\r\n }\r\n }\r\n // Called when the user hits the limit of saved colors in the drawer.\r\n function disableButton(button, disabled) {\r\n if (disabled) {\r\n button.color = buttonDisabledColor;\r\n button.background = buttonDisabledBackgroundColor;\r\n }\r\n else {\r\n button.color = buttonColor;\r\n button.background = buttonBackgroundColor;\r\n }\r\n }\r\n // Passes last chosen color back to scene and kills dialog by removing from AdvancedDynamicTexture\r\n function closePicker(color) {\r\n if (options.savedColors && options.savedColors.length > 0) {\r\n resolve({\r\n savedColors: options.savedColors,\r\n pickedColor: color\r\n });\r\n }\r\n else {\r\n resolve({\r\n pickedColor: color\r\n });\r\n }\r\n advancedTexture.removeControl(dialogContainer);\r\n }\r\n // Dialogue menu container which will contain both the main dialogue window and the swatch drawer which opens once a color is saved.\r\n var dialogContainer = new Grid();\r\n dialogContainer.name = \"Dialog Container\";\r\n dialogContainer.width = options.pickerWidth;\r\n if (options.savedColors) {\r\n dialogContainer.height = containerSize;\r\n var topRow = parseInt(options.pickerHeight) / parseInt(containerSize);\r\n dialogContainer.addRowDefinition(topRow, false);\r\n dialogContainer.addRowDefinition(1.0 - topRow, false);\r\n }\r\n else {\r\n dialogContainer.height = options.pickerHeight;\r\n dialogContainer.addRowDefinition(1.0, false);\r\n }\r\n advancedTexture.addControl(dialogContainer);\r\n // Swatch drawer which contains all saved color buttons\r\n if (options.savedColors) {\r\n swatchDrawer = new Grid();\r\n swatchDrawer.name = \"Swatch Drawer\";\r\n swatchDrawer.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n swatchDrawer.background = buttonBackgroundColor;\r\n swatchDrawer.width = options.pickerWidth;\r\n var initialRows = options.savedColors.length / options.numSwatchesPerLine;\r\n if (initialRows == 0) {\r\n var gutterCount = 0;\r\n }\r\n else {\r\n var gutterCount = initialRows + 1;\r\n }\r\n swatchDrawer.height = ((swatchSize * initialRows) + (gutterCount * gutterSize)).toString() + \"px\";\r\n swatchDrawer.top = Math.floor(swatchSize * 0.25).toString() + \"px\";\r\n for (var i = 0; i < (Math.ceil(options.savedColors.length / options.numSwatchesPerLine) * 2) + 1; i++) {\r\n if (i % 2 != 0) {\r\n swatchDrawer.addRowDefinition(swatchSize, true);\r\n }\r\n else {\r\n swatchDrawer.addRowDefinition(gutterSize, true);\r\n }\r\n }\r\n for (var i = 0; i < options.numSwatchesPerLine * 2 + 1; i++) {\r\n if (i % 2 != 0) {\r\n swatchDrawer.addColumnDefinition(swatchSize, true);\r\n }\r\n else {\r\n swatchDrawer.addColumnDefinition(gutterSize, true);\r\n }\r\n }\r\n dialogContainer.addControl(swatchDrawer, 1, 0);\r\n }\r\n // Picker container\r\n var pickerPanel = new Grid();\r\n pickerPanel.name = \"Picker Panel\";\r\n pickerPanel.height = options.pickerHeight;\r\n var panelHead = parseInt(options.headerHeight) / parseInt(options.pickerHeight);\r\n var pickerPanelRows = [panelHead, 1.0 - panelHead];\r\n pickerPanel.addRowDefinition(pickerPanelRows[0], false);\r\n pickerPanel.addRowDefinition(pickerPanelRows[1], false);\r\n dialogContainer.addControl(pickerPanel, 0, 0);\r\n // Picker container header\r\n var header = new Rectangle();\r\n header.name = \"Dialogue Header Bar\";\r\n header.background = \"#cccccc\";\r\n header.thickness = 0;\r\n pickerPanel.addControl(header, 0, 0);\r\n // Header close button\r\n var closeButton = Button.CreateSimpleButton(\"closeButton\", \"a\");\r\n closeButton.fontFamily = \"BabylonJSglyphs\";\r\n var headerColor3 = Color3.FromHexString(header.background);\r\n closeIconColor = new Color3(1.0 - headerColor3.r, 1.0 - headerColor3.g, 1.0 - headerColor3.b);\r\n closeButton.color = closeIconColor.toHexString();\r\n closeButton.fontSize = Math.floor(parseInt(options.headerHeight) * 0.6);\r\n closeButton.textBlock.textVerticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n closeButton.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_RIGHT;\r\n closeButton.height = closeButton.width = options.headerHeight;\r\n closeButton.background = header.background;\r\n closeButton.thickness = 0;\r\n closeButton.pointerDownAnimation = function () {\r\n };\r\n closeButton.pointerUpAnimation = function () {\r\n closeButton.background = header.background;\r\n };\r\n closeButton.pointerEnterAnimation = function () {\r\n closeButton.color = header.background;\r\n closeButton.background = \"red\";\r\n };\r\n closeButton.pointerOutAnimation = function () {\r\n closeButton.color = closeIconColor.toHexString();\r\n closeButton.background = header.background;\r\n };\r\n closeButton.onPointerClickObservable.add(function () {\r\n closePicker(currentSwatch.background);\r\n });\r\n pickerPanel.addControl(closeButton, 0, 0);\r\n // Dialog container body\r\n var dialogBody = new Grid();\r\n dialogBody.name = \"Dialogue Body\";\r\n dialogBody.background = buttonBackgroundColor;\r\n var dialogBodyCols = [0.4375, 0.5625];\r\n dialogBody.addRowDefinition(1.0, false);\r\n dialogBody.addColumnDefinition(dialogBodyCols[0], false);\r\n dialogBody.addColumnDefinition(dialogBodyCols[1], false);\r\n pickerPanel.addControl(dialogBody, 1, 0);\r\n // Picker grid\r\n var pickerGrid = new Grid();\r\n pickerGrid.name = \"Picker Grid\";\r\n pickerGrid.addRowDefinition(0.85, false);\r\n pickerGrid.addRowDefinition(0.15, false);\r\n dialogBody.addControl(pickerGrid, 0, 0);\r\n // Picker control\r\n picker = new ColorPicker();\r\n picker.name = \"GUI Color Picker\";\r\n if (options.pickerHeight < options.pickerWidth) {\r\n picker.width = 0.89;\r\n }\r\n else {\r\n picker.height = 0.89;\r\n }\r\n picker.value = Color3.FromHexString(options.lastColor);\r\n picker.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_CENTER;\r\n picker.verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n picker.onPointerDownObservable.add(function () {\r\n activeField = picker.name;\r\n lastVal = \"\";\r\n editSwatches(false);\r\n });\r\n picker.onValueChangedObservable.add(function (value) {\r\n if (activeField == picker.name) {\r\n updateValues(value, picker.name);\r\n }\r\n });\r\n pickerGrid.addControl(picker, 0, 0);\r\n // Picker body right quarant\r\n var pickerBodyRight = new Grid();\r\n pickerBodyRight.name = \"Dialogue Right Half\";\r\n pickerBodyRight.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n var pickerBodyRightRows = [0.514, 0.486];\r\n pickerBodyRight.addRowDefinition(pickerBodyRightRows[0], false);\r\n pickerBodyRight.addRowDefinition(pickerBodyRightRows[1], false);\r\n dialogBody.addControl(pickerBodyRight, 1, 1);\r\n // Picker container swatches and buttons\r\n var pickerSwatchesButtons = new Grid();\r\n pickerSwatchesButtons.name = \"Swatches and Buttons\";\r\n var pickerButtonsCol = [0.417, 0.583];\r\n pickerSwatchesButtons.addRowDefinition(1.0, false);\r\n pickerSwatchesButtons.addColumnDefinition(pickerButtonsCol[0], false);\r\n pickerSwatchesButtons.addColumnDefinition(pickerButtonsCol[1], false);\r\n pickerBodyRight.addControl(pickerSwatchesButtons, 0, 0);\r\n // Picker Swatches quadrant\r\n var pickerSwatches = new Grid();\r\n pickerSwatches.name = \"New and Current Swatches\";\r\n var pickeSwatchesRows = [0.04, 0.16, 0.64, 0.16];\r\n pickerSwatches.addRowDefinition(pickeSwatchesRows[0], false);\r\n pickerSwatches.addRowDefinition(pickeSwatchesRows[1], false);\r\n pickerSwatches.addRowDefinition(pickeSwatchesRows[2], false);\r\n pickerSwatches.addRowDefinition(pickeSwatchesRows[3], false);\r\n pickerSwatchesButtons.addControl(pickerSwatches, 0, 0);\r\n // Active swatches\r\n var activeSwatches = new Grid();\r\n activeSwatches.name = \"Active Swatches\";\r\n activeSwatches.width = 0.67;\r\n activeSwatches.addRowDefinition(0.5, false);\r\n activeSwatches.addRowDefinition(0.5, false);\r\n pickerSwatches.addControl(activeSwatches, 2, 0);\r\n var labelWidth = (Math.floor(parseInt(options.pickerWidth) * dialogBodyCols[1] * pickerButtonsCol[0] * 0.11));\r\n var labelHeight = (Math.floor(parseInt(options.pickerHeight) * pickerPanelRows[1] * pickerBodyRightRows[0] * pickeSwatchesRows[1] * 0.5));\r\n if (options.pickerWidth > options.pickerHeight) {\r\n var labelTextSize = labelHeight;\r\n }\r\n else {\r\n var labelTextSize = labelWidth;\r\n }\r\n // New color swatch and previous color button\r\n var newText = new TextBlock();\r\n newText.text = \"new\";\r\n newText.name = \"New Color Label\";\r\n newText.color = buttonColor;\r\n newText.fontSize = labelTextSize;\r\n pickerSwatches.addControl(newText, 1, 0);\r\n newSwatch = new Rectangle();\r\n newSwatch.name = \"New Color Swatch\";\r\n newSwatch.background = options.lastColor;\r\n newSwatch.thickness = 0;\r\n activeSwatches.addControl(newSwatch, 0, 0);\r\n var currentSwatch = Button.CreateSimpleButton(\"currentSwatch\", \"\");\r\n currentSwatch.background = options.lastColor;\r\n currentSwatch.thickness = 0;\r\n currentSwatch.onPointerClickObservable.add(function () {\r\n var revertColor = Color3.FromHexString(currentSwatch.background);\r\n updateValues(revertColor, currentSwatch.name);\r\n editSwatches(false);\r\n });\r\n currentSwatch.pointerDownAnimation = function () { };\r\n currentSwatch.pointerUpAnimation = function () { };\r\n currentSwatch.pointerEnterAnimation = function () { };\r\n currentSwatch.pointerOutAnimation = function () { };\r\n activeSwatches.addControl(currentSwatch, 1, 0);\r\n var swatchOutline = new Rectangle();\r\n swatchOutline.name = \"Swatch Outline\";\r\n swatchOutline.width = 0.67;\r\n swatchOutline.thickness = 2;\r\n swatchOutline.color = currentSwatchesOutlineColor;\r\n swatchOutline.isHitTestVisible = false;\r\n pickerSwatches.addControl(swatchOutline, 2, 0);\r\n var currentText = new TextBlock();\r\n currentText.name = \"Current Color Label\";\r\n currentText.text = \"current\";\r\n currentText.color = buttonColor;\r\n currentText.fontSize = labelTextSize;\r\n pickerSwatches.addControl(currentText, 3, 0);\r\n // Buttons grid\r\n var buttonGrid = new Grid();\r\n buttonGrid.name = \"Button Grid\";\r\n buttonGrid.height = 0.8;\r\n var buttonGridRows = 1 / 3;\r\n buttonGrid.addRowDefinition(buttonGridRows, false);\r\n buttonGrid.addRowDefinition(buttonGridRows, false);\r\n buttonGrid.addRowDefinition(buttonGridRows, false);\r\n pickerSwatchesButtons.addControl(buttonGrid, 0, 1);\r\n // Determine pixel width and height for all buttons from overall panel dimensions\r\n buttonWidth = (Math.floor(parseInt(options.pickerWidth) * dialogBodyCols[1] * pickerButtonsCol[1] * 0.67)).toString() + \"px\";\r\n buttonHeight = (Math.floor(parseInt(options.pickerHeight) * pickerPanelRows[1] * pickerBodyRightRows[0] * (parseFloat(buttonGrid.height.toString()) / 100) * buttonGridRows * 0.7)).toString() + \"px\";\r\n // Determine button type size\r\n if (parseFloat(buttonWidth) > parseFloat(buttonHeight)) {\r\n buttonFontSize = Math.floor(parseFloat(buttonHeight) * 0.45);\r\n }\r\n else {\r\n buttonFontSize = Math.floor(parseFloat(buttonWidth) * 0.11);\r\n }\r\n // Panel Buttons\r\n var butOK = Button.CreateSimpleButton(\"butOK\", \"OK\");\r\n butOK.width = buttonWidth;\r\n butOK.height = buttonHeight;\r\n butOK.verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n butOK.thickness = 2;\r\n butOK.color = buttonColor;\r\n butOK.fontSize = buttonFontSize;\r\n butOK.background = buttonBackgroundColor;\r\n butOK.onPointerEnterObservable.add(function () { butOK.background = buttonBackgroundHoverColor; });\r\n butOK.onPointerOutObservable.add(function () { butOK.background = buttonBackgroundColor; });\r\n butOK.pointerDownAnimation = function () {\r\n butOK.background = buttonBackgroundClickColor;\r\n };\r\n butOK.pointerUpAnimation = function () {\r\n butOK.background = buttonBackgroundHoverColor;\r\n };\r\n butOK.onPointerClickObservable.add(function () {\r\n editSwatches(false);\r\n closePicker(newSwatch.background);\r\n });\r\n buttonGrid.addControl(butOK, 0, 0);\r\n var butCancel = Button.CreateSimpleButton(\"butCancel\", \"Cancel\");\r\n butCancel.width = buttonWidth;\r\n butCancel.height = buttonHeight;\r\n butCancel.verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n butCancel.thickness = 2;\r\n butCancel.color = buttonColor;\r\n butCancel.fontSize = buttonFontSize;\r\n butCancel.background = buttonBackgroundColor;\r\n butCancel.onPointerEnterObservable.add(function () { butCancel.background = buttonBackgroundHoverColor; });\r\n butCancel.onPointerOutObservable.add(function () { butCancel.background = buttonBackgroundColor; });\r\n butCancel.pointerDownAnimation = function () {\r\n butCancel.background = buttonBackgroundClickColor;\r\n };\r\n butCancel.pointerUpAnimation = function () {\r\n butCancel.background = buttonBackgroundHoverColor;\r\n };\r\n butCancel.onPointerClickObservable.add(function () {\r\n editSwatches(false);\r\n closePicker(currentSwatch.background);\r\n });\r\n buttonGrid.addControl(butCancel, 1, 0);\r\n if (options.savedColors) {\r\n var butSave = Button.CreateSimpleButton(\"butSave\", \"Save\");\r\n butSave.width = buttonWidth;\r\n butSave.height = buttonHeight;\r\n butSave.verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n butSave.thickness = 2;\r\n butSave.fontSize = buttonFontSize;\r\n if (options.savedColors.length < options.swatchLimit) {\r\n butSave.color = buttonColor;\r\n butSave.background = buttonBackgroundColor;\r\n }\r\n else {\r\n disableButton(butSave, true);\r\n }\r\n butSave.onPointerEnterObservable.add(function () {\r\n if (options.savedColors) {\r\n if (options.savedColors.length < options.swatchLimit) {\r\n butSave.background = buttonBackgroundHoverColor;\r\n }\r\n }\r\n });\r\n butSave.onPointerOutObservable.add(function () {\r\n if (options.savedColors) {\r\n if (options.savedColors.length < options.swatchLimit) {\r\n butSave.background = buttonBackgroundColor;\r\n }\r\n }\r\n });\r\n butSave.pointerDownAnimation = function () {\r\n if (options.savedColors) {\r\n if (options.savedColors.length < options.swatchLimit) {\r\n butSave.background = buttonBackgroundClickColor;\r\n }\r\n }\r\n };\r\n butSave.pointerUpAnimation = function () {\r\n if (options.savedColors) {\r\n if (options.savedColors.length < options.swatchLimit) {\r\n butSave.background = buttonBackgroundHoverColor;\r\n }\r\n }\r\n };\r\n butSave.onPointerClickObservable.add(function () {\r\n if (options.savedColors) {\r\n if (options.savedColors.length == 0) {\r\n setEditButtonVisibility(true);\r\n }\r\n if (options.savedColors.length < options.swatchLimit) {\r\n updateSwatches(newSwatch.background, butSave);\r\n }\r\n editSwatches(false);\r\n }\r\n });\r\n if (options.savedColors.length > 0) {\r\n setEditButtonVisibility(true);\r\n }\r\n buttonGrid.addControl(butSave, 2, 0);\r\n }\r\n // Picker color values input\r\n var pickerColorValues = new Grid();\r\n pickerColorValues.name = \"Dialog Lower Right\";\r\n pickerColorValues.addRowDefinition(0.02, false);\r\n pickerColorValues.addRowDefinition(0.63, false);\r\n pickerColorValues.addRowDefinition(0.21, false);\r\n pickerColorValues.addRowDefinition(0.14, false);\r\n pickerBodyRight.addControl(pickerColorValues, 1, 0);\r\n // RGB values text boxes\r\n currentColor = Color3.FromHexString(options.lastColor);\r\n var rgbValuesQuadrant = new Grid();\r\n rgbValuesQuadrant.name = \"RGB Values\";\r\n rgbValuesQuadrant.width = 0.82;\r\n rgbValuesQuadrant.verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n rgbValuesQuadrant.addRowDefinition(1 / 3, false);\r\n rgbValuesQuadrant.addRowDefinition(1 / 3, false);\r\n rgbValuesQuadrant.addRowDefinition(1 / 3, false);\r\n rgbValuesQuadrant.addColumnDefinition(0.1, false);\r\n rgbValuesQuadrant.addColumnDefinition(0.2, false);\r\n rgbValuesQuadrant.addColumnDefinition(0.7, false);\r\n pickerColorValues.addControl(rgbValuesQuadrant, 1, 0);\r\n for (var i = 0; i < inputFieldLabels.length; i++) {\r\n var labelText = new TextBlock();\r\n labelText.text = inputFieldLabels[i];\r\n labelText.color = buttonColor;\r\n labelText.fontSize = buttonFontSize;\r\n rgbValuesQuadrant.addControl(labelText, i, 0);\r\n }\r\n // Input fields for RGB values\r\n rValInt = new InputText();\r\n rValInt.width = 0.83;\r\n rValInt.height = 0.72;\r\n rValInt.name = \"rIntField\";\r\n rValInt.fontSize = buttonFontSize;\r\n rValInt.text = (currentColor.r * 255).toString();\r\n rValInt.color = inputTextColor;\r\n rValInt.background = inputTextBackgroundColor;\r\n rValInt.onFocusObservable.add(function () {\r\n activeField = rValInt.name;\r\n lastVal = rValInt.text;\r\n editSwatches(false);\r\n });\r\n rValInt.onBlurObservable.add(function () {\r\n if (rValInt.text == \"\") {\r\n rValInt.text = \"0\";\r\n }\r\n updateInt(rValInt, \"r\");\r\n if (activeField == rValInt.name) {\r\n activeField = \"\";\r\n }\r\n });\r\n rValInt.onTextChangedObservable.add(function () {\r\n if (activeField == rValInt.name) {\r\n updateInt(rValInt, \"r\");\r\n }\r\n });\r\n rgbValuesQuadrant.addControl(rValInt, 0, 1);\r\n gValInt = new InputText();\r\n gValInt.width = 0.83;\r\n gValInt.height = 0.72;\r\n gValInt.name = \"gIntField\";\r\n gValInt.fontSize = buttonFontSize;\r\n gValInt.text = (currentColor.g * 255).toString();\r\n gValInt.color = inputTextColor;\r\n gValInt.background = inputTextBackgroundColor;\r\n gValInt.onFocusObservable.add(function () {\r\n activeField = gValInt.name;\r\n lastVal = gValInt.text;\r\n editSwatches(false);\r\n });\r\n gValInt.onBlurObservable.add(function () {\r\n if (gValInt.text == \"\") {\r\n gValInt.text = \"0\";\r\n }\r\n updateInt(gValInt, \"g\");\r\n if (activeField == gValInt.name) {\r\n activeField = \"\";\r\n }\r\n });\r\n gValInt.onTextChangedObservable.add(function () {\r\n if (activeField == gValInt.name) {\r\n updateInt(gValInt, \"g\");\r\n }\r\n });\r\n rgbValuesQuadrant.addControl(gValInt, 1, 1);\r\n bValInt = new InputText();\r\n bValInt.width = 0.83;\r\n bValInt.height = 0.72;\r\n bValInt.name = \"bIntField\";\r\n bValInt.fontSize = buttonFontSize;\r\n bValInt.text = (currentColor.b * 255).toString();\r\n bValInt.color = inputTextColor;\r\n bValInt.background = inputTextBackgroundColor;\r\n bValInt.onFocusObservable.add(function () {\r\n activeField = bValInt.name;\r\n lastVal = bValInt.text;\r\n editSwatches(false);\r\n });\r\n bValInt.onBlurObservable.add(function () {\r\n if (bValInt.text == \"\") {\r\n bValInt.text = \"0\";\r\n }\r\n updateInt(bValInt, \"b\");\r\n if (activeField == bValInt.name) {\r\n activeField = \"\";\r\n }\r\n });\r\n bValInt.onTextChangedObservable.add(function () {\r\n if (activeField == bValInt.name) {\r\n updateInt(bValInt, \"b\");\r\n }\r\n });\r\n rgbValuesQuadrant.addControl(bValInt, 2, 1);\r\n rValDec = new InputText();\r\n rValDec.width = 0.95;\r\n rValDec.height = 0.72;\r\n rValDec.name = \"rDecField\";\r\n rValDec.fontSize = buttonFontSize;\r\n rValDec.text = currentColor.r.toString();\r\n rValDec.color = inputTextColor;\r\n rValDec.background = inputTextBackgroundColor;\r\n rValDec.onFocusObservable.add(function () {\r\n activeField = rValDec.name;\r\n lastVal = rValDec.text;\r\n editSwatches(false);\r\n });\r\n rValDec.onBlurObservable.add(function () {\r\n if (parseFloat(rValDec.text) == 0 || rValDec.text == \"\") {\r\n rValDec.text = \"0\";\r\n updateFloat(rValDec, \"r\");\r\n }\r\n if (activeField == rValDec.name) {\r\n activeField = \"\";\r\n }\r\n });\r\n rValDec.onTextChangedObservable.add(function () {\r\n if (activeField == rValDec.name) {\r\n updateFloat(rValDec, \"r\");\r\n }\r\n });\r\n rgbValuesQuadrant.addControl(rValDec, 0, 2);\r\n gValDec = new InputText();\r\n gValDec.width = 0.95;\r\n gValDec.height = 0.72;\r\n gValDec.name = \"gDecField\";\r\n gValDec.fontSize = buttonFontSize;\r\n gValDec.text = currentColor.g.toString();\r\n gValDec.color = inputTextColor;\r\n gValDec.background = inputTextBackgroundColor;\r\n gValDec.onFocusObservable.add(function () {\r\n activeField = gValDec.name;\r\n lastVal = gValDec.text;\r\n editSwatches(false);\r\n });\r\n gValDec.onBlurObservable.add(function () {\r\n if (parseFloat(gValDec.text) == 0 || gValDec.text == \"\") {\r\n gValDec.text = \"0\";\r\n updateFloat(gValDec, \"g\");\r\n }\r\n if (activeField == gValDec.name) {\r\n activeField = \"\";\r\n }\r\n });\r\n gValDec.onTextChangedObservable.add(function () {\r\n if (activeField == gValDec.name) {\r\n updateFloat(gValDec, \"g\");\r\n }\r\n });\r\n rgbValuesQuadrant.addControl(gValDec, 1, 2);\r\n bValDec = new InputText();\r\n bValDec.width = 0.95;\r\n bValDec.height = 0.72;\r\n bValDec.name = \"bDecField\";\r\n bValDec.fontSize = buttonFontSize;\r\n bValDec.text = currentColor.b.toString();\r\n bValDec.color = inputTextColor;\r\n bValDec.background = inputTextBackgroundColor;\r\n bValDec.onFocusObservable.add(function () {\r\n activeField = bValDec.name;\r\n lastVal = bValDec.text;\r\n editSwatches(false);\r\n });\r\n bValDec.onBlurObservable.add(function () {\r\n if (parseFloat(bValDec.text) == 0 || bValDec.text == \"\") {\r\n bValDec.text = \"0\";\r\n updateFloat(bValDec, \"b\");\r\n }\r\n if (activeField == bValDec.name) {\r\n activeField = \"\";\r\n }\r\n });\r\n bValDec.onTextChangedObservable.add(function () {\r\n if (activeField == bValDec.name) {\r\n updateFloat(bValDec, \"b\");\r\n }\r\n });\r\n rgbValuesQuadrant.addControl(bValDec, 2, 2);\r\n // Hex value input\r\n var hexValueQuadrant = new Grid();\r\n hexValueQuadrant.name = \"Hex Value\";\r\n hexValueQuadrant.width = 0.82;\r\n hexValueQuadrant.addRowDefinition(1.0, false);\r\n hexValueQuadrant.addColumnDefinition(0.1, false);\r\n hexValueQuadrant.addColumnDefinition(0.9, false);\r\n pickerColorValues.addControl(hexValueQuadrant, 2, 0);\r\n var labelText = new TextBlock();\r\n labelText.text = \"#\";\r\n labelText.color = buttonColor;\r\n labelText.fontSize = buttonFontSize;\r\n hexValueQuadrant.addControl(labelText, 0, 0);\r\n hexVal = new InputText();\r\n hexVal.width = 0.96;\r\n hexVal.height = 0.72;\r\n hexVal.name = \"hexField\";\r\n hexVal.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_CENTER;\r\n hexVal.fontSize = buttonFontSize;\r\n var minusPound = options.lastColor.split(\"#\");\r\n hexVal.text = minusPound[1];\r\n hexVal.color = inputTextColor;\r\n hexVal.background = inputTextBackgroundColor;\r\n hexVal.onFocusObservable.add(function () {\r\n activeField = hexVal.name;\r\n lastVal = hexVal.text;\r\n editSwatches(false);\r\n });\r\n hexVal.onBlurObservable.add(function () {\r\n if (hexVal.text.length == 3) {\r\n var val = hexVal.text.split(\"\");\r\n hexVal.text = val[0] + val[0] + val[1] + val[1] + val[2] + val[2];\r\n }\r\n if (hexVal.text == \"\") {\r\n hexVal.text = \"000000\";\r\n updateValues(Color3.FromHexString(hexVal.text), \"b\");\r\n }\r\n if (activeField == hexVal.name) {\r\n activeField = \"\";\r\n }\r\n });\r\n hexVal.onTextChangedObservable.add(function () {\r\n var newHexValue = hexVal.text;\r\n var checkHex = /[^0-9A-F]/i.test(newHexValue);\r\n if ((hexVal.text.length > 6 || checkHex) && activeField == hexVal.name) {\r\n hexVal.text = lastVal;\r\n }\r\n else {\r\n if (hexVal.text.length < 6) {\r\n var leadingZero = 6 - hexVal.text.length;\r\n for (var i = 0; i < leadingZero; i++) {\r\n newHexValue = \"0\" + newHexValue;\r\n }\r\n }\r\n if (hexVal.text.length == 3) {\r\n var val = hexVal.text.split(\"\");\r\n newHexValue = val[0] + val[0] + val[1] + val[1] + val[2] + val[2];\r\n }\r\n newHexValue = \"#\" + newHexValue;\r\n if (activeField == hexVal.name) {\r\n lastVal = hexVal.text;\r\n updateValues(Color3.FromHexString(newHexValue), hexVal.name);\r\n }\r\n }\r\n });\r\n hexValueQuadrant.addControl(hexVal, 0, 1);\r\n if (options.savedColors && options.savedColors.length > 0) {\r\n updateSwatches(\"\", butSave);\r\n }\r\n });\r\n };\r\n ColorPicker._Epsilon = 0.000001;\r\n return ColorPicker;\r\n}(Control));\r\nexport { ColorPicker };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.ColorPicker\"] = ColorPicker;\r\n//# sourceMappingURL=colorpicker.js.map","import { __extends } from \"tslib\";\r\nimport { Container } from \"./container\";\r\nimport { Control } from \"./control\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/** Class used to create 2D ellipse containers */\r\nvar Ellipse = /** @class */ (function (_super) {\r\n __extends(Ellipse, _super);\r\n /**\r\n * Creates a new Ellipse\r\n * @param name defines the control name\r\n */\r\n function Ellipse(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._thickness = 1;\r\n return _this;\r\n }\r\n Object.defineProperty(Ellipse.prototype, \"thickness\", {\r\n /** Gets or sets border thickness */\r\n get: function () {\r\n return this._thickness;\r\n },\r\n set: function (value) {\r\n if (this._thickness === value) {\r\n return;\r\n }\r\n this._thickness = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Ellipse.prototype._getTypeName = function () {\r\n return \"Ellipse\";\r\n };\r\n Ellipse.prototype._localDraw = function (context) {\r\n context.save();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n Control.drawEllipse(this._currentMeasure.left + this._currentMeasure.width / 2, this._currentMeasure.top + this._currentMeasure.height / 2, this._currentMeasure.width / 2 - this._thickness / 2, this._currentMeasure.height / 2 - this._thickness / 2, context);\r\n if (this._background) {\r\n context.fillStyle = this._background;\r\n context.fill();\r\n }\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n if (this._thickness) {\r\n if (this.color) {\r\n context.strokeStyle = this.color;\r\n }\r\n context.lineWidth = this._thickness;\r\n context.stroke();\r\n }\r\n context.restore();\r\n };\r\n Ellipse.prototype._additionalProcessing = function (parentMeasure, context) {\r\n _super.prototype._additionalProcessing.call(this, parentMeasure, context);\r\n this._measureForChildren.width -= 2 * this._thickness;\r\n this._measureForChildren.height -= 2 * this._thickness;\r\n this._measureForChildren.left += this._thickness;\r\n this._measureForChildren.top += this._thickness;\r\n };\r\n Ellipse.prototype._clipForChildren = function (context) {\r\n Control.drawEllipse(this._currentMeasure.left + this._currentMeasure.width / 2, this._currentMeasure.top + this._currentMeasure.height / 2, this._currentMeasure.width / 2, this._currentMeasure.height / 2, context);\r\n context.clip();\r\n };\r\n return Ellipse;\r\n}(Container));\r\nexport { Ellipse };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Ellipse\"] = Ellipse;\r\n//# sourceMappingURL=ellipse.js.map","import { __extends } from \"tslib\";\r\nimport { InputText } from \"./inputText\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create a password control\r\n */\r\nvar InputPassword = /** @class */ (function (_super) {\r\n __extends(InputPassword, _super);\r\n function InputPassword() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n InputPassword.prototype._beforeRenderText = function (text) {\r\n var txt = \"\";\r\n for (var i = 0; i < text.length; i++) {\r\n txt += \"\\u2022\";\r\n }\r\n return txt;\r\n };\r\n return InputPassword;\r\n}(InputText));\r\nexport { InputPassword };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.InputPassword\"] = InputPassword;\r\n//# sourceMappingURL=inputPassword.js.map","import { __extends } from \"tslib\";\r\nimport { Vector3, Matrix } from \"@babylonjs/core/Maths/math.vector\";\r\nimport { Tools } from \"@babylonjs/core/Misc/tools\";\r\nimport { Control } from \"./control\";\r\nimport { ValueAndUnit } from \"../valueAndUnit\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/** Class used to render 2D lines */\r\nvar Line = /** @class */ (function (_super) {\r\n __extends(Line, _super);\r\n /**\r\n * Creates a new Line\r\n * @param name defines the control name\r\n */\r\n function Line(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._lineWidth = 1;\r\n _this._x1 = new ValueAndUnit(0);\r\n _this._y1 = new ValueAndUnit(0);\r\n _this._x2 = new ValueAndUnit(0);\r\n _this._y2 = new ValueAndUnit(0);\r\n _this._dash = new Array();\r\n _this._automaticSize = true;\r\n _this.isHitTestVisible = false;\r\n _this._horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _this._verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n return _this;\r\n }\r\n Object.defineProperty(Line.prototype, \"dash\", {\r\n /** Gets or sets the dash pattern */\r\n get: function () {\r\n return this._dash;\r\n },\r\n set: function (value) {\r\n if (this._dash === value) {\r\n return;\r\n }\r\n this._dash = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"connectedControl\", {\r\n /** Gets or sets the control connected with the line end */\r\n get: function () {\r\n return this._connectedControl;\r\n },\r\n set: function (value) {\r\n var _this = this;\r\n if (this._connectedControl === value) {\r\n return;\r\n }\r\n if (this._connectedControlDirtyObserver && this._connectedControl) {\r\n this._connectedControl.onDirtyObservable.remove(this._connectedControlDirtyObserver);\r\n this._connectedControlDirtyObserver = null;\r\n }\r\n if (value) {\r\n this._connectedControlDirtyObserver = value.onDirtyObservable.add(function () { return _this._markAsDirty(); });\r\n }\r\n this._connectedControl = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"x1\", {\r\n /** Gets or sets start coordinates on X axis */\r\n get: function () {\r\n return this._x1.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._x1.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._x1.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"y1\", {\r\n /** Gets or sets start coordinates on Y axis */\r\n get: function () {\r\n return this._y1.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._y1.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._y1.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"x2\", {\r\n /** Gets or sets end coordinates on X axis */\r\n get: function () {\r\n return this._x2.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._x2.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._x2.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"y2\", {\r\n /** Gets or sets end coordinates on Y axis */\r\n get: function () {\r\n return this._y2.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._y2.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._y2.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"lineWidth\", {\r\n /** Gets or sets line width */\r\n get: function () {\r\n return this._lineWidth;\r\n },\r\n set: function (value) {\r\n if (this._lineWidth === value) {\r\n return;\r\n }\r\n this._lineWidth = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"horizontalAlignment\", {\r\n /** Gets or sets horizontal alignment */\r\n set: function (value) {\r\n return;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"verticalAlignment\", {\r\n /** Gets or sets vertical alignment */\r\n set: function (value) {\r\n return;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"_effectiveX2\", {\r\n get: function () {\r\n return (this._connectedControl ? this._connectedControl.centerX : 0) + this._x2.getValue(this._host);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"_effectiveY2\", {\r\n get: function () {\r\n return (this._connectedControl ? this._connectedControl.centerY : 0) + this._y2.getValue(this._host);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Line.prototype._getTypeName = function () {\r\n return \"Line\";\r\n };\r\n Line.prototype._draw = function (context) {\r\n context.save();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n this._applyStates(context);\r\n context.strokeStyle = this.color;\r\n context.lineWidth = this._lineWidth;\r\n context.setLineDash(this._dash);\r\n context.beginPath();\r\n context.moveTo(this._cachedParentMeasure.left + this._x1.getValue(this._host), this._cachedParentMeasure.top + this._y1.getValue(this._host));\r\n context.lineTo(this._cachedParentMeasure.left + this._effectiveX2, this._cachedParentMeasure.top + this._effectiveY2);\r\n context.stroke();\r\n context.restore();\r\n };\r\n Line.prototype._measure = function () {\r\n // Width / Height\r\n this._currentMeasure.width = Math.abs(this._x1.getValue(this._host) - this._effectiveX2) + this._lineWidth;\r\n this._currentMeasure.height = Math.abs(this._y1.getValue(this._host) - this._effectiveY2) + this._lineWidth;\r\n };\r\n Line.prototype._computeAlignment = function (parentMeasure, context) {\r\n this._currentMeasure.left = parentMeasure.left + Math.min(this._x1.getValue(this._host), this._effectiveX2) - this._lineWidth / 2;\r\n this._currentMeasure.top = parentMeasure.top + Math.min(this._y1.getValue(this._host), this._effectiveY2) - this._lineWidth / 2;\r\n };\r\n /**\r\n * Move one end of the line given 3D cartesian coordinates.\r\n * @param position Targeted world position\r\n * @param scene Scene\r\n * @param end (opt) Set to true to assign x2 and y2 coordinates of the line. Default assign to x1 and y1.\r\n */\r\n Line.prototype.moveToVector3 = function (position, scene, end) {\r\n if (end === void 0) { end = false; }\r\n if (!this._host || this.parent !== this._host._rootContainer) {\r\n Tools.Error(\"Cannot move a control to a vector3 if the control is not at root level\");\r\n return;\r\n }\r\n var globalViewport = this._host._getGlobalViewport(scene);\r\n var projectedPosition = Vector3.Project(position, Matrix.Identity(), scene.getTransformMatrix(), globalViewport);\r\n this._moveToProjectedPosition(projectedPosition, end);\r\n if (projectedPosition.z < 0 || projectedPosition.z > 1) {\r\n this.notRenderable = true;\r\n return;\r\n }\r\n this.notRenderable = false;\r\n };\r\n /**\r\n * Move one end of the line to a position in screen absolute space.\r\n * @param projectedPosition Position in screen absolute space (X, Y)\r\n * @param end (opt) Set to true to assign x2 and y2 coordinates of the line. Default assign to x1 and y1.\r\n */\r\n Line.prototype._moveToProjectedPosition = function (projectedPosition, end) {\r\n if (end === void 0) { end = false; }\r\n var x = (projectedPosition.x + this._linkOffsetX.getValue(this._host)) + \"px\";\r\n var y = (projectedPosition.y + this._linkOffsetY.getValue(this._host)) + \"px\";\r\n if (end) {\r\n this.x2 = x;\r\n this.y2 = y;\r\n this._x2.ignoreAdaptiveScaling = true;\r\n this._y2.ignoreAdaptiveScaling = true;\r\n }\r\n else {\r\n this.x1 = x;\r\n this.y1 = y;\r\n this._x1.ignoreAdaptiveScaling = true;\r\n this._y1.ignoreAdaptiveScaling = true;\r\n }\r\n };\r\n return Line;\r\n}(Control));\r\nexport { Line };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Line\"] = Line;\r\n//# sourceMappingURL=line.js.map","import { Vector2 } from \"@babylonjs/core/Maths/math.vector\";\r\nimport { ValueAndUnit } from \"./valueAndUnit\";\r\n/**\r\n * Class used to store a point for a MultiLine object.\r\n * The point can be pure 2D coordinates, a mesh or a control\r\n */\r\nvar MultiLinePoint = /** @class */ (function () {\r\n /**\r\n * Creates a new MultiLinePoint\r\n * @param multiLine defines the source MultiLine object\r\n */\r\n function MultiLinePoint(multiLine) {\r\n this._multiLine = multiLine;\r\n this._x = new ValueAndUnit(0);\r\n this._y = new ValueAndUnit(0);\r\n this._point = new Vector2(0, 0);\r\n }\r\n Object.defineProperty(MultiLinePoint.prototype, \"x\", {\r\n /** Gets or sets x coordinate */\r\n get: function () {\r\n return this._x.toString(this._multiLine._host);\r\n },\r\n set: function (value) {\r\n if (this._x.toString(this._multiLine._host) === value) {\r\n return;\r\n }\r\n if (this._x.fromString(value)) {\r\n this._multiLine._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MultiLinePoint.prototype, \"y\", {\r\n /** Gets or sets y coordinate */\r\n get: function () {\r\n return this._y.toString(this._multiLine._host);\r\n },\r\n set: function (value) {\r\n if (this._y.toString(this._multiLine._host) === value) {\r\n return;\r\n }\r\n if (this._y.fromString(value)) {\r\n this._multiLine._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MultiLinePoint.prototype, \"control\", {\r\n /** Gets or sets the control associated with this point */\r\n get: function () {\r\n return this._control;\r\n },\r\n set: function (value) {\r\n if (this._control === value) {\r\n return;\r\n }\r\n if (this._control && this._controlObserver) {\r\n this._control.onDirtyObservable.remove(this._controlObserver);\r\n this._controlObserver = null;\r\n }\r\n this._control = value;\r\n if (this._control) {\r\n this._controlObserver = this._control.onDirtyObservable.add(this._multiLine.onPointUpdate);\r\n }\r\n this._multiLine._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MultiLinePoint.prototype, \"mesh\", {\r\n /** Gets or sets the mesh associated with this point */\r\n get: function () {\r\n return this._mesh;\r\n },\r\n set: function (value) {\r\n if (this._mesh === value) {\r\n return;\r\n }\r\n if (this._mesh && this._meshObserver) {\r\n this._mesh.getScene().onAfterCameraRenderObservable.remove(this._meshObserver);\r\n }\r\n this._mesh = value;\r\n if (this._mesh) {\r\n this._meshObserver = this._mesh.getScene().onAfterCameraRenderObservable.add(this._multiLine.onPointUpdate);\r\n }\r\n this._multiLine._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** Resets links */\r\n MultiLinePoint.prototype.resetLinks = function () {\r\n this.control = null;\r\n this.mesh = null;\r\n };\r\n /**\r\n * Gets a translation vector\r\n * @returns the translation vector\r\n */\r\n MultiLinePoint.prototype.translate = function () {\r\n this._point = this._translatePoint();\r\n return this._point;\r\n };\r\n MultiLinePoint.prototype._translatePoint = function () {\r\n if (this._mesh != null) {\r\n return this._multiLine._host.getProjectedPosition(this._mesh.getBoundingInfo().boundingSphere.center, this._mesh.getWorldMatrix());\r\n }\r\n else if (this._control != null) {\r\n return new Vector2(this._control.centerX, this._control.centerY);\r\n }\r\n else {\r\n var host = this._multiLine._host;\r\n var xValue = this._x.getValueInPixel(host, Number(host._canvas.width));\r\n var yValue = this._y.getValueInPixel(host, Number(host._canvas.height));\r\n return new Vector2(xValue, yValue);\r\n }\r\n };\r\n /** Release associated resources */\r\n MultiLinePoint.prototype.dispose = function () {\r\n this.resetLinks();\r\n };\r\n return MultiLinePoint;\r\n}());\r\nexport { MultiLinePoint };\r\n//# sourceMappingURL=multiLinePoint.js.map","import { __extends } from \"tslib\";\r\nimport { AbstractMesh } from \"@babylonjs/core/Meshes/abstractMesh\";\r\nimport { Control } from \"./control\";\r\nimport { MultiLinePoint } from \"../multiLinePoint\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create multi line control\r\n */\r\nvar MultiLine = /** @class */ (function (_super) {\r\n __extends(MultiLine, _super);\r\n /**\r\n * Creates a new MultiLine\r\n * @param name defines the control name\r\n */\r\n function MultiLine(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._lineWidth = 1;\r\n /** Function called when a point is updated */\r\n _this.onPointUpdate = function () {\r\n _this._markAsDirty();\r\n };\r\n _this._automaticSize = true;\r\n _this.isHitTestVisible = false;\r\n _this._horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _this._verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n _this._dash = [];\r\n _this._points = [];\r\n return _this;\r\n }\r\n Object.defineProperty(MultiLine.prototype, \"dash\", {\r\n /** Gets or sets dash pattern */\r\n get: function () {\r\n return this._dash;\r\n },\r\n set: function (value) {\r\n if (this._dash === value) {\r\n return;\r\n }\r\n this._dash = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets point stored at specified index\r\n * @param index defines the index to look for\r\n * @returns the requested point if found\r\n */\r\n MultiLine.prototype.getAt = function (index) {\r\n if (!this._points[index]) {\r\n this._points[index] = new MultiLinePoint(this);\r\n }\r\n return this._points[index];\r\n };\r\n /**\r\n * Adds new points to the point collection\r\n * @param items defines the list of items (mesh, control or 2d coordiantes) to add\r\n * @returns the list of created MultiLinePoint\r\n */\r\n MultiLine.prototype.add = function () {\r\n var _this = this;\r\n var items = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n items[_i] = arguments[_i];\r\n }\r\n return items.map(function (item) { return _this.push(item); });\r\n };\r\n /**\r\n * Adds a new point to the point collection\r\n * @param item defines the item (mesh, control or 2d coordiantes) to add\r\n * @returns the created MultiLinePoint\r\n */\r\n MultiLine.prototype.push = function (item) {\r\n var point = this.getAt(this._points.length);\r\n if (item == null) {\r\n return point;\r\n }\r\n if (item instanceof AbstractMesh) {\r\n point.mesh = item;\r\n }\r\n else if (item instanceof Control) {\r\n point.control = item;\r\n }\r\n else if (item.x != null && item.y != null) {\r\n point.x = item.x;\r\n point.y = item.y;\r\n }\r\n return point;\r\n };\r\n /**\r\n * Remove a specific value or point from the active point collection\r\n * @param value defines the value or point to remove\r\n */\r\n MultiLine.prototype.remove = function (value) {\r\n var index;\r\n if (value instanceof MultiLinePoint) {\r\n index = this._points.indexOf(value);\r\n if (index === -1) {\r\n return;\r\n }\r\n }\r\n else {\r\n index = value;\r\n }\r\n var point = this._points[index];\r\n if (!point) {\r\n return;\r\n }\r\n point.dispose();\r\n this._points.splice(index, 1);\r\n };\r\n /**\r\n * Resets this object to initial state (no point)\r\n */\r\n MultiLine.prototype.reset = function () {\r\n while (this._points.length > 0) {\r\n this.remove(this._points.length - 1);\r\n }\r\n };\r\n /**\r\n * Resets all links\r\n */\r\n MultiLine.prototype.resetLinks = function () {\r\n this._points.forEach(function (point) {\r\n if (point != null) {\r\n point.resetLinks();\r\n }\r\n });\r\n };\r\n Object.defineProperty(MultiLine.prototype, \"lineWidth\", {\r\n /** Gets or sets line width */\r\n get: function () {\r\n return this._lineWidth;\r\n },\r\n set: function (value) {\r\n if (this._lineWidth === value) {\r\n return;\r\n }\r\n this._lineWidth = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MultiLine.prototype, \"horizontalAlignment\", {\r\n set: function (value) {\r\n return;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(MultiLine.prototype, \"verticalAlignment\", {\r\n set: function (value) {\r\n return;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n MultiLine.prototype._getTypeName = function () {\r\n return \"MultiLine\";\r\n };\r\n MultiLine.prototype._draw = function (context, invalidatedRectangle) {\r\n context.save();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n this._applyStates(context);\r\n context.strokeStyle = this.color;\r\n context.lineWidth = this._lineWidth;\r\n context.setLineDash(this._dash);\r\n context.beginPath();\r\n var first = true; //first index is not necessarily 0\r\n this._points.forEach(function (point) {\r\n if (!point) {\r\n return;\r\n }\r\n if (first) {\r\n context.moveTo(point._point.x, point._point.y);\r\n first = false;\r\n }\r\n else {\r\n context.lineTo(point._point.x, point._point.y);\r\n }\r\n });\r\n context.stroke();\r\n context.restore();\r\n };\r\n MultiLine.prototype._additionalProcessing = function (parentMeasure, context) {\r\n var _this = this;\r\n this._minX = null;\r\n this._minY = null;\r\n this._maxX = null;\r\n this._maxY = null;\r\n this._points.forEach(function (point, index) {\r\n if (!point) {\r\n return;\r\n }\r\n point.translate();\r\n if (_this._minX == null || point._point.x < _this._minX) {\r\n _this._minX = point._point.x;\r\n }\r\n if (_this._minY == null || point._point.y < _this._minY) {\r\n _this._minY = point._point.y;\r\n }\r\n if (_this._maxX == null || point._point.x > _this._maxX) {\r\n _this._maxX = point._point.x;\r\n }\r\n if (_this._maxY == null || point._point.y > _this._maxY) {\r\n _this._maxY = point._point.y;\r\n }\r\n });\r\n if (this._minX == null) {\r\n this._minX = 0;\r\n }\r\n if (this._minY == null) {\r\n this._minY = 0;\r\n }\r\n if (this._maxX == null) {\r\n this._maxX = 0;\r\n }\r\n if (this._maxY == null) {\r\n this._maxY = 0;\r\n }\r\n };\r\n MultiLine.prototype._measure = function () {\r\n if (this._minX == null || this._maxX == null || this._minY == null || this._maxY == null) {\r\n return;\r\n }\r\n this._currentMeasure.width = Math.abs(this._maxX - this._minX) + this._lineWidth;\r\n this._currentMeasure.height = Math.abs(this._maxY - this._minY) + this._lineWidth;\r\n };\r\n MultiLine.prototype._computeAlignment = function (parentMeasure, context) {\r\n if (this._minX == null || this._minY == null) {\r\n return;\r\n }\r\n this._currentMeasure.left = this._minX - this._lineWidth / 2;\r\n this._currentMeasure.top = this._minY - this._lineWidth / 2;\r\n };\r\n MultiLine.prototype.dispose = function () {\r\n this.reset();\r\n _super.prototype.dispose.call(this);\r\n };\r\n return MultiLine;\r\n}(Control));\r\nexport { MultiLine };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.MultiLine\"] = MultiLine;\r\n//# sourceMappingURL=multiLine.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { Control } from \"./control\";\r\nimport { StackPanel } from \"./stackPanel\";\r\nimport { TextBlock } from \"./textBlock\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create radio button controls\r\n */\r\nvar RadioButton = /** @class */ (function (_super) {\r\n __extends(RadioButton, _super);\r\n /**\r\n * Creates a new RadioButton\r\n * @param name defines the control name\r\n */\r\n function RadioButton(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._isChecked = false;\r\n _this._background = \"black\";\r\n _this._checkSizeRatio = 0.8;\r\n _this._thickness = 1;\r\n /** Gets or sets group name */\r\n _this.group = \"\";\r\n /** Observable raised when isChecked is changed */\r\n _this.onIsCheckedChangedObservable = new Observable();\r\n _this.isPointerBlocker = true;\r\n return _this;\r\n }\r\n Object.defineProperty(RadioButton.prototype, \"thickness\", {\r\n /** Gets or sets border thickness */\r\n get: function () {\r\n return this._thickness;\r\n },\r\n set: function (value) {\r\n if (this._thickness === value) {\r\n return;\r\n }\r\n this._thickness = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(RadioButton.prototype, \"checkSizeRatio\", {\r\n /** Gets or sets a value indicating the ratio between overall size and check size */\r\n get: function () {\r\n return this._checkSizeRatio;\r\n },\r\n set: function (value) {\r\n value = Math.max(Math.min(1, value), 0);\r\n if (this._checkSizeRatio === value) {\r\n return;\r\n }\r\n this._checkSizeRatio = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(RadioButton.prototype, \"background\", {\r\n /** Gets or sets background color */\r\n get: function () {\r\n return this._background;\r\n },\r\n set: function (value) {\r\n if (this._background === value) {\r\n return;\r\n }\r\n this._background = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(RadioButton.prototype, \"isChecked\", {\r\n /** Gets or sets a boolean indicating if the checkbox is checked or not */\r\n get: function () {\r\n return this._isChecked;\r\n },\r\n set: function (value) {\r\n var _this = this;\r\n if (this._isChecked === value) {\r\n return;\r\n }\r\n this._isChecked = value;\r\n this._markAsDirty();\r\n this.onIsCheckedChangedObservable.notifyObservers(value);\r\n if (this._isChecked && this._host) {\r\n // Update all controls from same group\r\n this._host.executeOnAllControls(function (control) {\r\n if (control === _this) {\r\n return;\r\n }\r\n if (control.group === undefined) {\r\n return;\r\n }\r\n var childRadio = control;\r\n if (childRadio.group === _this.group) {\r\n childRadio.isChecked = false;\r\n }\r\n });\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n RadioButton.prototype._getTypeName = function () {\r\n return \"RadioButton\";\r\n };\r\n RadioButton.prototype._draw = function (context) {\r\n context.save();\r\n this._applyStates(context);\r\n var actualWidth = this._currentMeasure.width - this._thickness;\r\n var actualHeight = this._currentMeasure.height - this._thickness;\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n // Outer\r\n Control.drawEllipse(this._currentMeasure.left + this._currentMeasure.width / 2, this._currentMeasure.top + this._currentMeasure.height / 2, this._currentMeasure.width / 2 - this._thickness / 2, this._currentMeasure.height / 2 - this._thickness / 2, context);\r\n context.fillStyle = this._isEnabled ? this._background : this._disabledColor;\r\n context.fill();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n context.strokeStyle = this.color;\r\n context.lineWidth = this._thickness;\r\n context.stroke();\r\n // Inner\r\n if (this._isChecked) {\r\n context.fillStyle = this._isEnabled ? this.color : this._disabledColor;\r\n var offsetWidth = actualWidth * this._checkSizeRatio;\r\n var offseHeight = actualHeight * this._checkSizeRatio;\r\n Control.drawEllipse(this._currentMeasure.left + this._currentMeasure.width / 2, this._currentMeasure.top + this._currentMeasure.height / 2, offsetWidth / 2 - this._thickness / 2, offseHeight / 2 - this._thickness / 2, context);\r\n context.fill();\r\n }\r\n context.restore();\r\n };\r\n // Events\r\n RadioButton.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex) {\r\n if (!_super.prototype._onPointerDown.call(this, target, coordinates, pointerId, buttonIndex)) {\r\n return false;\r\n }\r\n if (!this.isChecked) {\r\n this.isChecked = true;\r\n }\r\n return true;\r\n };\r\n /**\r\n * Utility function to easily create a radio button with a header\r\n * @param title defines the label to use for the header\r\n * @param group defines the group to use for the radio button\r\n * @param isChecked defines the initial state of the radio button\r\n * @param onValueChanged defines the callback to call when value changes\r\n * @returns a StackPanel containing the radio button and a textBlock\r\n */\r\n RadioButton.AddRadioButtonWithHeader = function (title, group, isChecked, onValueChanged) {\r\n var panel = new StackPanel();\r\n panel.isVertical = false;\r\n panel.height = \"30px\";\r\n var radio = new RadioButton();\r\n radio.width = \"20px\";\r\n radio.height = \"20px\";\r\n radio.isChecked = isChecked;\r\n radio.color = \"green\";\r\n radio.group = group;\r\n radio.onIsCheckedChangedObservable.add(function (value) { return onValueChanged(radio, value); });\r\n panel.addControl(radio);\r\n var header = new TextBlock();\r\n header.text = title;\r\n header.width = \"180px\";\r\n header.paddingLeft = \"5px\";\r\n header.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n header.color = \"white\";\r\n panel.addControl(header);\r\n return panel;\r\n };\r\n return RadioButton;\r\n}(Control));\r\nexport { RadioButton };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.RadioButton\"] = RadioButton;\r\n//# sourceMappingURL=radioButton.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { Control } from \"../control\";\r\nimport { ValueAndUnit } from \"../../valueAndUnit\";\r\n/**\r\n * Class used to create slider controls\r\n */\r\nvar BaseSlider = /** @class */ (function (_super) {\r\n __extends(BaseSlider, _super);\r\n /**\r\n * Creates a new BaseSlider\r\n * @param name defines the control name\r\n */\r\n function BaseSlider(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._thumbWidth = new ValueAndUnit(20, ValueAndUnit.UNITMODE_PIXEL, false);\r\n _this._minimum = 0;\r\n _this._maximum = 100;\r\n _this._value = 50;\r\n _this._isVertical = false;\r\n _this._barOffset = new ValueAndUnit(5, ValueAndUnit.UNITMODE_PIXEL, false);\r\n _this._isThumbClamped = false;\r\n _this._displayThumb = true;\r\n _this._step = 0;\r\n _this._lastPointerDownID = -1;\r\n // Shared rendering info\r\n _this._effectiveBarOffset = 0;\r\n /** Observable raised when the sldier value changes */\r\n _this.onValueChangedObservable = new Observable();\r\n // Events\r\n _this._pointerIsDown = false;\r\n _this.isPointerBlocker = true;\r\n return _this;\r\n }\r\n Object.defineProperty(BaseSlider.prototype, \"displayThumb\", {\r\n /** Gets or sets a boolean indicating if the thumb must be rendered */\r\n get: function () {\r\n return this._displayThumb;\r\n },\r\n set: function (value) {\r\n if (this._displayThumb === value) {\r\n return;\r\n }\r\n this._displayThumb = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"step\", {\r\n /** Gets or sets a step to apply to values (0 by default) */\r\n get: function () {\r\n return this._step;\r\n },\r\n set: function (value) {\r\n if (this._step === value) {\r\n return;\r\n }\r\n this._step = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"barOffset\", {\r\n /** Gets or sets main bar offset (ie. the margin applied to the value bar) */\r\n get: function () {\r\n return this._barOffset.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._barOffset.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._barOffset.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"barOffsetInPixels\", {\r\n /** Gets main bar offset in pixels*/\r\n get: function () {\r\n return this._barOffset.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"thumbWidth\", {\r\n /** Gets or sets thumb width */\r\n get: function () {\r\n return this._thumbWidth.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._thumbWidth.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._thumbWidth.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"thumbWidthInPixels\", {\r\n /** Gets thumb width in pixels */\r\n get: function () {\r\n return this._thumbWidth.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"minimum\", {\r\n /** Gets or sets minimum value */\r\n get: function () {\r\n return this._minimum;\r\n },\r\n set: function (value) {\r\n if (this._minimum === value) {\r\n return;\r\n }\r\n this._minimum = value;\r\n this._markAsDirty();\r\n this.value = Math.max(Math.min(this.value, this._maximum), this._minimum);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"maximum\", {\r\n /** Gets or sets maximum value */\r\n get: function () {\r\n return this._maximum;\r\n },\r\n set: function (value) {\r\n if (this._maximum === value) {\r\n return;\r\n }\r\n this._maximum = value;\r\n this._markAsDirty();\r\n this.value = Math.max(Math.min(this.value, this._maximum), this._minimum);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"value\", {\r\n /** Gets or sets current value */\r\n get: function () {\r\n return this._value;\r\n },\r\n set: function (value) {\r\n value = Math.max(Math.min(value, this._maximum), this._minimum);\r\n if (this._value === value) {\r\n return;\r\n }\r\n this._value = value;\r\n this._markAsDirty();\r\n this.onValueChangedObservable.notifyObservers(this._value);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"isVertical\", {\r\n /**Gets or sets a boolean indicating if the slider should be vertical or horizontal */\r\n get: function () {\r\n return this._isVertical;\r\n },\r\n set: function (value) {\r\n if (this._isVertical === value) {\r\n return;\r\n }\r\n this._isVertical = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"isThumbClamped\", {\r\n /** Gets or sets a value indicating if the thumb can go over main bar extends */\r\n get: function () {\r\n return this._isThumbClamped;\r\n },\r\n set: function (value) {\r\n if (this._isThumbClamped === value) {\r\n return;\r\n }\r\n this._isThumbClamped = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n BaseSlider.prototype._getTypeName = function () {\r\n return \"BaseSlider\";\r\n };\r\n BaseSlider.prototype._getThumbPosition = function () {\r\n if (this.isVertical) {\r\n return ((this.maximum - this.value) / (this.maximum - this.minimum)) * this._backgroundBoxLength;\r\n }\r\n return ((this.value - this.minimum) / (this.maximum - this.minimum)) * this._backgroundBoxLength;\r\n };\r\n BaseSlider.prototype._getThumbThickness = function (type) {\r\n var thumbThickness = 0;\r\n switch (type) {\r\n case \"circle\":\r\n if (this._thumbWidth.isPixel) {\r\n thumbThickness = Math.max(this._thumbWidth.getValue(this._host), this._backgroundBoxThickness);\r\n }\r\n else {\r\n thumbThickness = this._backgroundBoxThickness * this._thumbWidth.getValue(this._host);\r\n }\r\n break;\r\n case \"rectangle\":\r\n if (this._thumbWidth.isPixel) {\r\n thumbThickness = Math.min(this._thumbWidth.getValue(this._host), this._backgroundBoxThickness);\r\n }\r\n else {\r\n thumbThickness = this._backgroundBoxThickness * this._thumbWidth.getValue(this._host);\r\n }\r\n }\r\n return thumbThickness;\r\n };\r\n BaseSlider.prototype._prepareRenderingData = function (type) {\r\n // Main bar\r\n this._effectiveBarOffset = 0;\r\n this._renderLeft = this._currentMeasure.left;\r\n this._renderTop = this._currentMeasure.top;\r\n this._renderWidth = this._currentMeasure.width;\r\n this._renderHeight = this._currentMeasure.height;\r\n this._backgroundBoxLength = Math.max(this._currentMeasure.width, this._currentMeasure.height);\r\n this._backgroundBoxThickness = Math.min(this._currentMeasure.width, this._currentMeasure.height);\r\n this._effectiveThumbThickness = this._getThumbThickness(type);\r\n if (this.displayThumb) {\r\n this._backgroundBoxLength -= this._effectiveThumbThickness;\r\n }\r\n //throw error when height is less than width for vertical slider\r\n if ((this.isVertical && this._currentMeasure.height < this._currentMeasure.width)) {\r\n console.error(\"Height should be greater than width\");\r\n return;\r\n }\r\n if (this._barOffset.isPixel) {\r\n this._effectiveBarOffset = Math.min(this._barOffset.getValue(this._host), this._backgroundBoxThickness);\r\n }\r\n else {\r\n this._effectiveBarOffset = this._backgroundBoxThickness * this._barOffset.getValue(this._host);\r\n }\r\n this._backgroundBoxThickness -= (this._effectiveBarOffset * 2);\r\n if (this.isVertical) {\r\n this._renderLeft += this._effectiveBarOffset;\r\n if (!this.isThumbClamped && this.displayThumb) {\r\n this._renderTop += (this._effectiveThumbThickness / 2);\r\n }\r\n this._renderHeight = this._backgroundBoxLength;\r\n this._renderWidth = this._backgroundBoxThickness;\r\n }\r\n else {\r\n this._renderTop += this._effectiveBarOffset;\r\n if (!this.isThumbClamped && this.displayThumb) {\r\n this._renderLeft += (this._effectiveThumbThickness / 2);\r\n }\r\n this._renderHeight = this._backgroundBoxThickness;\r\n this._renderWidth = this._backgroundBoxLength;\r\n }\r\n };\r\n /** @hidden */\r\n BaseSlider.prototype._updateValueFromPointer = function (x, y) {\r\n if (this.rotation != 0) {\r\n this._invertTransformMatrix.transformCoordinates(x, y, this._transformedPosition);\r\n x = this._transformedPosition.x;\r\n y = this._transformedPosition.y;\r\n }\r\n var value;\r\n if (this._isVertical) {\r\n value = this._minimum + (1 - ((y - this._currentMeasure.top) / this._currentMeasure.height)) * (this._maximum - this._minimum);\r\n }\r\n else {\r\n value = this._minimum + ((x - this._currentMeasure.left) / this._currentMeasure.width) * (this._maximum - this._minimum);\r\n }\r\n var mult = (1 / this._step) | 0;\r\n this.value = this._step ? ((value * mult) | 0) / mult : value;\r\n };\r\n BaseSlider.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex) {\r\n if (!_super.prototype._onPointerDown.call(this, target, coordinates, pointerId, buttonIndex)) {\r\n return false;\r\n }\r\n this._pointerIsDown = true;\r\n this._updateValueFromPointer(coordinates.x, coordinates.y);\r\n this._host._capturingControl[pointerId] = this;\r\n this._lastPointerDownID = pointerId;\r\n return true;\r\n };\r\n BaseSlider.prototype._onPointerMove = function (target, coordinates, pointerId) {\r\n // Only listen to pointer move events coming from the last pointer to click on the element (To support dual vr controller interaction)\r\n if (pointerId != this._lastPointerDownID) {\r\n return;\r\n }\r\n if (this._pointerIsDown) {\r\n this._updateValueFromPointer(coordinates.x, coordinates.y);\r\n }\r\n _super.prototype._onPointerMove.call(this, target, coordinates, pointerId);\r\n };\r\n BaseSlider.prototype._onPointerUp = function (target, coordinates, pointerId, buttonIndex, notifyClick) {\r\n this._pointerIsDown = false;\r\n delete this._host._capturingControl[pointerId];\r\n _super.prototype._onPointerUp.call(this, target, coordinates, pointerId, buttonIndex, notifyClick);\r\n };\r\n return BaseSlider;\r\n}(Control));\r\nexport { BaseSlider };\r\n//# sourceMappingURL=baseSlider.js.map","import { __extends } from \"tslib\";\r\nimport { BaseSlider } from \"./baseSlider\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create slider controls\r\n */\r\nvar Slider = /** @class */ (function (_super) {\r\n __extends(Slider, _super);\r\n /**\r\n * Creates a new Slider\r\n * @param name defines the control name\r\n */\r\n function Slider(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._background = \"black\";\r\n _this._borderColor = \"white\";\r\n _this._isThumbCircle = false;\r\n _this._displayValueBar = true;\r\n return _this;\r\n }\r\n Object.defineProperty(Slider.prototype, \"displayValueBar\", {\r\n /** Gets or sets a boolean indicating if the value bar must be rendered */\r\n get: function () {\r\n return this._displayValueBar;\r\n },\r\n set: function (value) {\r\n if (this._displayValueBar === value) {\r\n return;\r\n }\r\n this._displayValueBar = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Slider.prototype, \"borderColor\", {\r\n /** Gets or sets border color */\r\n get: function () {\r\n return this._borderColor;\r\n },\r\n set: function (value) {\r\n if (this._borderColor === value) {\r\n return;\r\n }\r\n this._borderColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Slider.prototype, \"background\", {\r\n /** Gets or sets background color */\r\n get: function () {\r\n return this._background;\r\n },\r\n set: function (value) {\r\n if (this._background === value) {\r\n return;\r\n }\r\n this._background = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Slider.prototype, \"isThumbCircle\", {\r\n /** Gets or sets a boolean indicating if the thumb should be round or square */\r\n get: function () {\r\n return this._isThumbCircle;\r\n },\r\n set: function (value) {\r\n if (this._isThumbCircle === value) {\r\n return;\r\n }\r\n this._isThumbCircle = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Slider.prototype._getTypeName = function () {\r\n return \"Slider\";\r\n };\r\n Slider.prototype._draw = function (context, invalidatedRectangle) {\r\n context.save();\r\n this._applyStates(context);\r\n this._prepareRenderingData(this.isThumbCircle ? \"circle\" : \"rectangle\");\r\n var left = this._renderLeft;\r\n var top = this._renderTop;\r\n var width = this._renderWidth;\r\n var height = this._renderHeight;\r\n var radius = 0;\r\n if (this.isThumbClamped && this.isThumbCircle) {\r\n if (this.isVertical) {\r\n top += (this._effectiveThumbThickness / 2);\r\n }\r\n else {\r\n left += (this._effectiveThumbThickness / 2);\r\n }\r\n radius = this._backgroundBoxThickness / 2;\r\n }\r\n else {\r\n radius = (this._effectiveThumbThickness - this._effectiveBarOffset) / 2;\r\n }\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n var thumbPosition = this._getThumbPosition();\r\n context.fillStyle = this._background;\r\n if (this.isVertical) {\r\n if (this.isThumbClamped) {\r\n if (this.isThumbCircle) {\r\n context.beginPath();\r\n context.arc(left + this._backgroundBoxThickness / 2, top, radius, Math.PI, 2 * Math.PI);\r\n context.fill();\r\n context.fillRect(left, top, width, height);\r\n }\r\n else {\r\n context.fillRect(left, top, width, height + this._effectiveThumbThickness);\r\n }\r\n }\r\n else {\r\n context.fillRect(left, top, width, height);\r\n }\r\n }\r\n else {\r\n if (this.isThumbClamped) {\r\n if (this.isThumbCircle) {\r\n context.beginPath();\r\n context.arc(left + this._backgroundBoxLength, top + (this._backgroundBoxThickness / 2), radius, 0, 2 * Math.PI);\r\n context.fill();\r\n context.fillRect(left, top, width, height);\r\n }\r\n else {\r\n context.fillRect(left, top, width + this._effectiveThumbThickness, height);\r\n }\r\n }\r\n else {\r\n context.fillRect(left, top, width, height);\r\n }\r\n }\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n // Value bar\r\n context.fillStyle = this.color;\r\n if (this._displayValueBar) {\r\n if (this.isVertical) {\r\n if (this.isThumbClamped) {\r\n if (this.isThumbCircle) {\r\n context.beginPath();\r\n context.arc(left + this._backgroundBoxThickness / 2, top + this._backgroundBoxLength, radius, 0, 2 * Math.PI);\r\n context.fill();\r\n context.fillRect(left, top + thumbPosition, width, height - thumbPosition);\r\n }\r\n else {\r\n context.fillRect(left, top + thumbPosition, width, height - thumbPosition + this._effectiveThumbThickness);\r\n }\r\n }\r\n else {\r\n context.fillRect(left, top + thumbPosition, width, height - thumbPosition);\r\n }\r\n }\r\n else {\r\n if (this.isThumbClamped) {\r\n if (this.isThumbCircle) {\r\n context.beginPath();\r\n context.arc(left, top + this._backgroundBoxThickness / 2, radius, 0, 2 * Math.PI);\r\n context.fill();\r\n context.fillRect(left, top, thumbPosition, height);\r\n }\r\n else {\r\n context.fillRect(left, top, thumbPosition, height);\r\n }\r\n }\r\n else {\r\n context.fillRect(left, top, thumbPosition, height);\r\n }\r\n }\r\n }\r\n // Thumb\r\n if (this.displayThumb) {\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n if (this._isThumbCircle) {\r\n context.beginPath();\r\n if (this.isVertical) {\r\n context.arc(left + this._backgroundBoxThickness / 2, top + thumbPosition, radius, 0, 2 * Math.PI);\r\n }\r\n else {\r\n context.arc(left + thumbPosition, top + (this._backgroundBoxThickness / 2), radius, 0, 2 * Math.PI);\r\n }\r\n context.fill();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n context.strokeStyle = this._borderColor;\r\n context.stroke();\r\n }\r\n else {\r\n if (this.isVertical) {\r\n context.fillRect(left - this._effectiveBarOffset, this._currentMeasure.top + thumbPosition, this._currentMeasure.width, this._effectiveThumbThickness);\r\n }\r\n else {\r\n context.fillRect(this._currentMeasure.left + thumbPosition, this._currentMeasure.top, this._effectiveThumbThickness, this._currentMeasure.height);\r\n }\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n context.strokeStyle = this._borderColor;\r\n if (this.isVertical) {\r\n context.strokeRect(left - this._effectiveBarOffset, this._currentMeasure.top + thumbPosition, this._currentMeasure.width, this._effectiveThumbThickness);\r\n }\r\n else {\r\n context.strokeRect(this._currentMeasure.left + thumbPosition, this._currentMeasure.top, this._effectiveThumbThickness, this._currentMeasure.height);\r\n }\r\n }\r\n }\r\n context.restore();\r\n };\r\n return Slider;\r\n}(BaseSlider));\r\nexport { Slider };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Slider\"] = Slider;\r\n//# sourceMappingURL=slider.js.map","import { __extends } from \"tslib\";\r\nimport { Rectangle } from \"./rectangle\";\r\nimport { StackPanel } from \"./stackPanel\";\r\nimport { Control } from \"./control\";\r\nimport { TextBlock } from \"./textBlock\";\r\nimport { Checkbox } from \"./checkbox\";\r\nimport { RadioButton } from \"./radioButton\";\r\nimport { Slider } from \"./sliders/slider\";\r\nimport { Container } from \"./container\";\r\n/** Class used to create a RadioGroup\r\n * which contains groups of radio buttons\r\n*/\r\nvar SelectorGroup = /** @class */ (function () {\r\n /**\r\n * Creates a new SelectorGroup\r\n * @param name of group, used as a group heading\r\n */\r\n function SelectorGroup(\r\n /** name of SelectorGroup */\r\n name) {\r\n this.name = name;\r\n this._groupPanel = new StackPanel();\r\n this._selectors = new Array();\r\n this._groupPanel.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n this._groupPanel.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n this._groupHeader = this._addGroupHeader(name);\r\n }\r\n Object.defineProperty(SelectorGroup.prototype, \"groupPanel\", {\r\n /** Gets the groupPanel of the SelectorGroup */\r\n get: function () {\r\n return this._groupPanel;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SelectorGroup.prototype, \"selectors\", {\r\n /** Gets the selectors array */\r\n get: function () {\r\n return this._selectors;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SelectorGroup.prototype, \"header\", {\r\n /** Gets and sets the group header */\r\n get: function () {\r\n return this._groupHeader.text;\r\n },\r\n set: function (label) {\r\n if (this._groupHeader.text === \"label\") {\r\n return;\r\n }\r\n this._groupHeader.text = label;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n SelectorGroup.prototype._addGroupHeader = function (text) {\r\n var groupHeading = new TextBlock(\"groupHead\", text);\r\n groupHeading.width = 0.9;\r\n groupHeading.height = \"30px\";\r\n groupHeading.textWrapping = true;\r\n groupHeading.color = \"black\";\r\n groupHeading.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n groupHeading.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n groupHeading.left = \"2px\";\r\n this._groupPanel.addControl(groupHeading);\r\n return groupHeading;\r\n };\r\n /** @hidden*/\r\n SelectorGroup.prototype._getSelector = function (selectorNb) {\r\n if (selectorNb < 0 || selectorNb >= this._selectors.length) {\r\n return;\r\n }\r\n return this._selectors[selectorNb];\r\n };\r\n /** Removes the selector at the given position\r\n * @param selectorNb the position of the selector within the group\r\n */\r\n SelectorGroup.prototype.removeSelector = function (selectorNb) {\r\n if (selectorNb < 0 || selectorNb >= this._selectors.length) {\r\n return;\r\n }\r\n this._groupPanel.removeControl(this._selectors[selectorNb]);\r\n this._selectors.splice(selectorNb, 1);\r\n };\r\n return SelectorGroup;\r\n}());\r\nexport { SelectorGroup };\r\n/** Class used to create a CheckboxGroup\r\n * which contains groups of checkbox buttons\r\n*/\r\nvar CheckboxGroup = /** @class */ (function (_super) {\r\n __extends(CheckboxGroup, _super);\r\n function CheckboxGroup() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n /** Adds a checkbox as a control\r\n * @param text is the label for the selector\r\n * @param func is the function called when the Selector is checked\r\n * @param checked is true when Selector is checked\r\n */\r\n CheckboxGroup.prototype.addCheckbox = function (text, func, checked) {\r\n if (func === void 0) { func = function (s) { }; }\r\n if (checked === void 0) { checked = false; }\r\n var checked = checked || false;\r\n var button = new Checkbox();\r\n button.width = \"20px\";\r\n button.height = \"20px\";\r\n button.color = \"#364249\";\r\n button.background = \"#CCCCCC\";\r\n button.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n button.onIsCheckedChangedObservable.add(function (state) {\r\n func(state);\r\n });\r\n var _selector = Control.AddHeader(button, text, \"200px\", { isHorizontal: true, controlFirst: true });\r\n _selector.height = \"30px\";\r\n _selector.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _selector.left = \"4px\";\r\n this.groupPanel.addControl(_selector);\r\n this.selectors.push(_selector);\r\n button.isChecked = checked;\r\n if (this.groupPanel.parent && this.groupPanel.parent.parent) {\r\n button.color = this.groupPanel.parent.parent.buttonColor;\r\n button.background = this.groupPanel.parent.parent.buttonBackground;\r\n }\r\n };\r\n /** @hidden */\r\n CheckboxGroup.prototype._setSelectorLabel = function (selectorNb, label) {\r\n this.selectors[selectorNb].children[1].text = label;\r\n };\r\n /** @hidden */\r\n CheckboxGroup.prototype._setSelectorLabelColor = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[1].color = color;\r\n };\r\n /** @hidden */\r\n CheckboxGroup.prototype._setSelectorButtonColor = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[0].color = color;\r\n };\r\n /** @hidden */\r\n CheckboxGroup.prototype._setSelectorButtonBackground = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[0].background = color;\r\n };\r\n return CheckboxGroup;\r\n}(SelectorGroup));\r\nexport { CheckboxGroup };\r\n/** Class used to create a RadioGroup\r\n * which contains groups of radio buttons\r\n*/\r\nvar RadioGroup = /** @class */ (function (_super) {\r\n __extends(RadioGroup, _super);\r\n function RadioGroup() {\r\n var _this = _super !== null && _super.apply(this, arguments) || this;\r\n _this._selectNb = 0;\r\n return _this;\r\n }\r\n /** Adds a radio button as a control\r\n * @param label is the label for the selector\r\n * @param func is the function called when the Selector is checked\r\n * @param checked is true when Selector is checked\r\n */\r\n RadioGroup.prototype.addRadio = function (label, func, checked) {\r\n if (func === void 0) { func = function (n) { }; }\r\n if (checked === void 0) { checked = false; }\r\n var nb = this._selectNb++;\r\n var button = new RadioButton();\r\n button.name = label;\r\n button.width = \"20px\";\r\n button.height = \"20px\";\r\n button.color = \"#364249\";\r\n button.background = \"#CCCCCC\";\r\n button.group = this.name;\r\n button.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n button.onIsCheckedChangedObservable.add(function (state) {\r\n if (state) {\r\n func(nb);\r\n }\r\n });\r\n var _selector = Control.AddHeader(button, label, \"200px\", { isHorizontal: true, controlFirst: true });\r\n _selector.height = \"30px\";\r\n _selector.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _selector.left = \"4px\";\r\n this.groupPanel.addControl(_selector);\r\n this.selectors.push(_selector);\r\n button.isChecked = checked;\r\n if (this.groupPanel.parent && this.groupPanel.parent.parent) {\r\n button.color = this.groupPanel.parent.parent.buttonColor;\r\n button.background = this.groupPanel.parent.parent.buttonBackground;\r\n }\r\n };\r\n /** @hidden */\r\n RadioGroup.prototype._setSelectorLabel = function (selectorNb, label) {\r\n this.selectors[selectorNb].children[1].text = label;\r\n };\r\n /** @hidden */\r\n RadioGroup.prototype._setSelectorLabelColor = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[1].color = color;\r\n };\r\n /** @hidden */\r\n RadioGroup.prototype._setSelectorButtonColor = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[0].color = color;\r\n };\r\n /** @hidden */\r\n RadioGroup.prototype._setSelectorButtonBackground = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[0].background = color;\r\n };\r\n return RadioGroup;\r\n}(SelectorGroup));\r\nexport { RadioGroup };\r\n/** Class used to create a SliderGroup\r\n * which contains groups of slider buttons\r\n*/\r\nvar SliderGroup = /** @class */ (function (_super) {\r\n __extends(SliderGroup, _super);\r\n function SliderGroup() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n /**\r\n * Adds a slider to the SelectorGroup\r\n * @param label is the label for the SliderBar\r\n * @param func is the function called when the Slider moves\r\n * @param unit is a string describing the units used, eg degrees or metres\r\n * @param min is the minimum value for the Slider\r\n * @param max is the maximum value for the Slider\r\n * @param value is the start value for the Slider between min and max\r\n * @param onValueChange is the function used to format the value displayed, eg radians to degrees\r\n */\r\n SliderGroup.prototype.addSlider = function (label, func, unit, min, max, value, onValueChange) {\r\n if (func === void 0) { func = function (v) { }; }\r\n if (unit === void 0) { unit = \"Units\"; }\r\n if (min === void 0) { min = 0; }\r\n if (max === void 0) { max = 0; }\r\n if (value === void 0) { value = 0; }\r\n if (onValueChange === void 0) { onValueChange = function (v) { return v | 0; }; }\r\n var button = new Slider();\r\n button.name = unit;\r\n button.value = value;\r\n button.minimum = min;\r\n button.maximum = max;\r\n button.width = 0.9;\r\n button.height = \"20px\";\r\n button.color = \"#364249\";\r\n button.background = \"#CCCCCC\";\r\n button.borderColor = \"black\";\r\n button.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n button.left = \"4px\";\r\n button.paddingBottom = \"4px\";\r\n button.onValueChangedObservable.add(function (value) {\r\n button.parent.children[0].text = button.parent.children[0].name + \": \" + onValueChange(value) + \" \" + button.name;\r\n func(value);\r\n });\r\n var _selector = Control.AddHeader(button, label + \": \" + onValueChange(value) + \" \" + unit, \"30px\", { isHorizontal: false, controlFirst: false });\r\n _selector.height = \"60px\";\r\n _selector.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _selector.left = \"4px\";\r\n _selector.children[0].name = label;\r\n this.groupPanel.addControl(_selector);\r\n this.selectors.push(_selector);\r\n if (this.groupPanel.parent && this.groupPanel.parent.parent) {\r\n button.color = this.groupPanel.parent.parent.buttonColor;\r\n button.background = this.groupPanel.parent.parent.buttonBackground;\r\n }\r\n };\r\n /** @hidden */\r\n SliderGroup.prototype._setSelectorLabel = function (selectorNb, label) {\r\n this.selectors[selectorNb].children[0].name = label;\r\n this.selectors[selectorNb].children[0].text = label + \": \" + this.selectors[selectorNb].children[1].value + \" \" + this.selectors[selectorNb].children[1].name;\r\n };\r\n /** @hidden */\r\n SliderGroup.prototype._setSelectorLabelColor = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[0].color = color;\r\n };\r\n /** @hidden */\r\n SliderGroup.prototype._setSelectorButtonColor = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[1].color = color;\r\n };\r\n /** @hidden */\r\n SliderGroup.prototype._setSelectorButtonBackground = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[1].background = color;\r\n };\r\n return SliderGroup;\r\n}(SelectorGroup));\r\nexport { SliderGroup };\r\n/** Class used to hold the controls for the checkboxes, radio buttons and sliders\r\n * @see http://doc.babylonjs.com/how_to/selector\r\n*/\r\nvar SelectionPanel = /** @class */ (function (_super) {\r\n __extends(SelectionPanel, _super);\r\n /**\r\n * Creates a new SelectionPanel\r\n * @param name of SelectionPanel\r\n * @param groups is an array of SelectionGroups\r\n */\r\n function SelectionPanel(\r\n /** name of SelectionPanel */\r\n name, \r\n /** an array of SelectionGroups */\r\n groups) {\r\n if (groups === void 0) { groups = []; }\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this.groups = groups;\r\n _this._buttonColor = \"#364249\";\r\n _this._buttonBackground = \"#CCCCCC\";\r\n _this._headerColor = \"black\";\r\n _this._barColor = \"white\";\r\n _this._barHeight = \"2px\";\r\n _this._spacerHeight = \"20px\";\r\n _this._bars = new Array();\r\n _this._groups = groups;\r\n _this.thickness = 2;\r\n _this._panel = new StackPanel();\r\n _this._panel.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n _this._panel.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _this._panel.top = 5;\r\n _this._panel.left = 5;\r\n _this._panel.width = 0.95;\r\n if (groups.length > 0) {\r\n for (var i = 0; i < groups.length - 1; i++) {\r\n _this._panel.addControl(groups[i].groupPanel);\r\n _this._addSpacer();\r\n }\r\n _this._panel.addControl(groups[groups.length - 1].groupPanel);\r\n }\r\n _this.addControl(_this._panel);\r\n return _this;\r\n }\r\n SelectionPanel.prototype._getTypeName = function () {\r\n return \"SelectionPanel\";\r\n };\r\n Object.defineProperty(SelectionPanel.prototype, \"headerColor\", {\r\n /** Gets or sets the headerColor */\r\n get: function () {\r\n return this._headerColor;\r\n },\r\n set: function (color) {\r\n if (this._headerColor === color) {\r\n return;\r\n }\r\n this._headerColor = color;\r\n this._setHeaderColor();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n SelectionPanel.prototype._setHeaderColor = function () {\r\n for (var i = 0; i < this._groups.length; i++) {\r\n this._groups[i].groupPanel.children[0].color = this._headerColor;\r\n }\r\n };\r\n Object.defineProperty(SelectionPanel.prototype, \"buttonColor\", {\r\n /** Gets or sets the button color */\r\n get: function () {\r\n return this._buttonColor;\r\n },\r\n set: function (color) {\r\n if (this._buttonColor === color) {\r\n return;\r\n }\r\n this._buttonColor = color;\r\n this._setbuttonColor();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n SelectionPanel.prototype._setbuttonColor = function () {\r\n for (var i = 0; i < this._groups.length; i++) {\r\n for (var j = 0; j < this._groups[i].selectors.length; j++) {\r\n this._groups[i]._setSelectorButtonColor(j, this._buttonColor);\r\n }\r\n }\r\n };\r\n Object.defineProperty(SelectionPanel.prototype, \"labelColor\", {\r\n /** Gets or sets the label color */\r\n get: function () {\r\n return this._labelColor;\r\n },\r\n set: function (color) {\r\n if (this._labelColor === color) {\r\n return;\r\n }\r\n this._labelColor = color;\r\n this._setLabelColor();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n SelectionPanel.prototype._setLabelColor = function () {\r\n for (var i = 0; i < this._groups.length; i++) {\r\n for (var j = 0; j < this._groups[i].selectors.length; j++) {\r\n this._groups[i]._setSelectorLabelColor(j, this._labelColor);\r\n }\r\n }\r\n };\r\n Object.defineProperty(SelectionPanel.prototype, \"buttonBackground\", {\r\n /** Gets or sets the button background */\r\n get: function () {\r\n return this._buttonBackground;\r\n },\r\n set: function (color) {\r\n if (this._buttonBackground === color) {\r\n return;\r\n }\r\n this._buttonBackground = color;\r\n this._setButtonBackground();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n SelectionPanel.prototype._setButtonBackground = function () {\r\n for (var i = 0; i < this._groups.length; i++) {\r\n for (var j = 0; j < this._groups[i].selectors.length; j++) {\r\n this._groups[i]._setSelectorButtonBackground(j, this._buttonBackground);\r\n }\r\n }\r\n };\r\n Object.defineProperty(SelectionPanel.prototype, \"barColor\", {\r\n /** Gets or sets the color of separator bar */\r\n get: function () {\r\n return this._barColor;\r\n },\r\n set: function (color) {\r\n if (this._barColor === color) {\r\n return;\r\n }\r\n this._barColor = color;\r\n this._setBarColor();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n SelectionPanel.prototype._setBarColor = function () {\r\n for (var i = 0; i < this._bars.length; i++) {\r\n this._bars[i].children[0].background = this._barColor;\r\n }\r\n };\r\n Object.defineProperty(SelectionPanel.prototype, \"barHeight\", {\r\n /** Gets or sets the height of separator bar */\r\n get: function () {\r\n return this._barHeight;\r\n },\r\n set: function (value) {\r\n if (this._barHeight === value) {\r\n return;\r\n }\r\n this._barHeight = value;\r\n this._setBarHeight();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n SelectionPanel.prototype._setBarHeight = function () {\r\n for (var i = 0; i < this._bars.length; i++) {\r\n this._bars[i].children[0].height = this._barHeight;\r\n }\r\n };\r\n Object.defineProperty(SelectionPanel.prototype, \"spacerHeight\", {\r\n /** Gets or sets the height of spacers*/\r\n get: function () {\r\n return this._spacerHeight;\r\n },\r\n set: function (value) {\r\n if (this._spacerHeight === value) {\r\n return;\r\n }\r\n this._spacerHeight = value;\r\n this._setSpacerHeight();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n SelectionPanel.prototype._setSpacerHeight = function () {\r\n for (var i = 0; i < this._bars.length; i++) {\r\n this._bars[i].height = this._spacerHeight;\r\n }\r\n };\r\n /** Adds a bar between groups */\r\n SelectionPanel.prototype._addSpacer = function () {\r\n var separator = new Container();\r\n separator.width = 1;\r\n separator.height = this._spacerHeight;\r\n separator.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n var bar = new Rectangle();\r\n bar.width = 1;\r\n bar.height = this._barHeight;\r\n bar.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n bar.verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n bar.background = this._barColor;\r\n bar.color = \"transparent\";\r\n separator.addControl(bar);\r\n this._panel.addControl(separator);\r\n this._bars.push(separator);\r\n };\r\n /** Add a group to the selection panel\r\n * @param group is the selector group to add\r\n */\r\n SelectionPanel.prototype.addGroup = function (group) {\r\n if (this._groups.length > 0) {\r\n this._addSpacer();\r\n }\r\n this._panel.addControl(group.groupPanel);\r\n this._groups.push(group);\r\n group.groupPanel.children[0].color = this._headerColor;\r\n for (var j = 0; j < group.selectors.length; j++) {\r\n group._setSelectorButtonColor(j, this._buttonColor);\r\n group._setSelectorButtonBackground(j, this._buttonBackground);\r\n }\r\n };\r\n /** Remove the group from the given position\r\n * @param groupNb is the position of the group in the list\r\n */\r\n SelectionPanel.prototype.removeGroup = function (groupNb) {\r\n if (groupNb < 0 || groupNb >= this._groups.length) {\r\n return;\r\n }\r\n var group = this._groups[groupNb];\r\n this._panel.removeControl(group.groupPanel);\r\n this._groups.splice(groupNb, 1);\r\n if (groupNb < this._bars.length) {\r\n this._panel.removeControl(this._bars[groupNb]);\r\n this._bars.splice(groupNb, 1);\r\n }\r\n };\r\n /** Change a group header label\r\n * @param label is the new group header label\r\n * @param groupNb is the number of the group to relabel\r\n * */\r\n SelectionPanel.prototype.setHeaderName = function (label, groupNb) {\r\n if (groupNb < 0 || groupNb >= this._groups.length) {\r\n return;\r\n }\r\n var group = this._groups[groupNb];\r\n group.groupPanel.children[0].text = label;\r\n };\r\n /** Change selector label to the one given\r\n * @param label is the new selector label\r\n * @param groupNb is the number of the groupcontaining the selector\r\n * @param selectorNb is the number of the selector within a group to relabel\r\n * */\r\n SelectionPanel.prototype.relabel = function (label, groupNb, selectorNb) {\r\n if (groupNb < 0 || groupNb >= this._groups.length) {\r\n return;\r\n }\r\n var group = this._groups[groupNb];\r\n if (selectorNb < 0 || selectorNb >= group.selectors.length) {\r\n return;\r\n }\r\n group._setSelectorLabel(selectorNb, label);\r\n };\r\n /** For a given group position remove the selector at the given position\r\n * @param groupNb is the number of the group to remove the selector from\r\n * @param selectorNb is the number of the selector within the group\r\n */\r\n SelectionPanel.prototype.removeFromGroupSelector = function (groupNb, selectorNb) {\r\n if (groupNb < 0 || groupNb >= this._groups.length) {\r\n return;\r\n }\r\n var group = this._groups[groupNb];\r\n if (selectorNb < 0 || selectorNb >= group.selectors.length) {\r\n return;\r\n }\r\n group.removeSelector(selectorNb);\r\n };\r\n /** For a given group position of correct type add a checkbox button\r\n * @param groupNb is the number of the group to remove the selector from\r\n * @param label is the label for the selector\r\n * @param func is the function called when the Selector is checked\r\n * @param checked is true when Selector is checked\r\n */\r\n SelectionPanel.prototype.addToGroupCheckbox = function (groupNb, label, func, checked) {\r\n if (func === void 0) { func = function () { }; }\r\n if (checked === void 0) { checked = false; }\r\n if (groupNb < 0 || groupNb >= this._groups.length) {\r\n return;\r\n }\r\n var group = this._groups[groupNb];\r\n group.addCheckbox(label, func, checked);\r\n };\r\n /** For a given group position of correct type add a radio button\r\n * @param groupNb is the number of the group to remove the selector from\r\n * @param label is the label for the selector\r\n * @param func is the function called when the Selector is checked\r\n * @param checked is true when Selector is checked\r\n */\r\n SelectionPanel.prototype.addToGroupRadio = function (groupNb, label, func, checked) {\r\n if (func === void 0) { func = function () { }; }\r\n if (checked === void 0) { checked = false; }\r\n if (groupNb < 0 || groupNb >= this._groups.length) {\r\n return;\r\n }\r\n var group = this._groups[groupNb];\r\n group.addRadio(label, func, checked);\r\n };\r\n /**\r\n * For a given slider group add a slider\r\n * @param groupNb is the number of the group to add the slider to\r\n * @param label is the label for the Slider\r\n * @param func is the function called when the Slider moves\r\n * @param unit is a string describing the units used, eg degrees or metres\r\n * @param min is the minimum value for the Slider\r\n * @param max is the maximum value for the Slider\r\n * @param value is the start value for the Slider between min and max\r\n * @param onVal is the function used to format the value displayed, eg radians to degrees\r\n */\r\n SelectionPanel.prototype.addToGroupSlider = function (groupNb, label, func, unit, min, max, value, onVal) {\r\n if (func === void 0) { func = function () { }; }\r\n if (unit === void 0) { unit = \"Units\"; }\r\n if (min === void 0) { min = 0; }\r\n if (max === void 0) { max = 0; }\r\n if (value === void 0) { value = 0; }\r\n if (onVal === void 0) { onVal = function (v) { return v | 0; }; }\r\n if (groupNb < 0 || groupNb >= this._groups.length) {\r\n return;\r\n }\r\n var group = this._groups[groupNb];\r\n group.addSlider(label, func, unit, min, max, value, onVal);\r\n };\r\n return SelectionPanel;\r\n}(Rectangle));\r\nexport { SelectionPanel };\r\n//# sourceMappingURL=selector.js.map","import { __extends } from \"tslib\";\r\nimport { Measure } from \"../../measure\";\r\nimport { Container } from \"../container\";\r\nimport { ValueAndUnit } from \"../../valueAndUnit\";\r\nimport { Control } from \"../control\";\r\n/**\r\n * Class used to hold a the container for ScrollViewer\r\n * @hidden\r\n*/\r\nvar _ScrollViewerWindow = /** @class */ (function (_super) {\r\n __extends(_ScrollViewerWindow, _super);\r\n /**\r\n * Creates a new ScrollViewerWindow\r\n * @param name of ScrollViewerWindow\r\n */\r\n function _ScrollViewerWindow(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this._freezeControls = false;\r\n _this._bucketWidth = 0;\r\n _this._bucketHeight = 0;\r\n _this._buckets = {};\r\n return _this;\r\n }\r\n Object.defineProperty(_ScrollViewerWindow.prototype, \"freezeControls\", {\r\n get: function () {\r\n return this._freezeControls;\r\n },\r\n set: function (value) {\r\n if (this._freezeControls === value) {\r\n return;\r\n }\r\n // trigger a full normal layout calculation to be sure all children have their measures up to date\r\n this._freezeControls = false;\r\n var textureSize = this.host.getSize();\r\n var renderWidth = textureSize.width;\r\n var renderHeight = textureSize.height;\r\n var context = this.host.getContext();\r\n var measure = new Measure(0, 0, renderWidth, renderHeight);\r\n this.host._numLayoutCalls = 0;\r\n this.host._rootContainer._layout(measure, context);\r\n // in freeze mode, prepare children measures accordingly\r\n if (value) {\r\n this._updateMeasures();\r\n if (this._useBuckets()) {\r\n this._makeBuckets();\r\n }\r\n }\r\n this._freezeControls = value;\r\n this.host.markAsDirty(); // redraw with the (new) current settings\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(_ScrollViewerWindow.prototype, \"bucketWidth\", {\r\n get: function () {\r\n return this._bucketWidth;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(_ScrollViewerWindow.prototype, \"bucketHeight\", {\r\n get: function () {\r\n return this._bucketHeight;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n _ScrollViewerWindow.prototype.setBucketSizes = function (width, height) {\r\n this._bucketWidth = width;\r\n this._bucketHeight = height;\r\n if (this._useBuckets()) {\r\n if (this._freezeControls) {\r\n this._makeBuckets();\r\n }\r\n }\r\n else {\r\n this._buckets = {};\r\n }\r\n };\r\n _ScrollViewerWindow.prototype._useBuckets = function () {\r\n return this._bucketWidth > 0 && this._bucketHeight > 0;\r\n };\r\n _ScrollViewerWindow.prototype._makeBuckets = function () {\r\n this._buckets = {};\r\n this._bucketLen = Math.ceil(this.widthInPixels / this._bucketWidth);\r\n this._dispatchInBuckets(this._children);\r\n };\r\n _ScrollViewerWindow.prototype._dispatchInBuckets = function (children) {\r\n for (var i = 0; i < children.length; ++i) {\r\n var child = children[i];\r\n var bStartX = Math.max(0, Math.floor((child._currentMeasure.left - this._currentMeasure.left) / this._bucketWidth)), bEndX = Math.floor((child._currentMeasure.left - this._currentMeasure.left + child._currentMeasure.width - 1) / this._bucketWidth), bStartY = Math.max(0, Math.floor((child._currentMeasure.top - this._currentMeasure.top) / this._bucketHeight)), bEndY = Math.floor((child._currentMeasure.top - this._currentMeasure.top + child._currentMeasure.height - 1) / this._bucketHeight);\r\n while (bStartY <= bEndY) {\r\n for (var x = bStartX; x <= bEndX; ++x) {\r\n var bucket = bStartY * this._bucketLen + x, lstc = this._buckets[bucket];\r\n if (!lstc) {\r\n lstc = [];\r\n this._buckets[bucket] = lstc;\r\n }\r\n lstc.push(child);\r\n }\r\n bStartY++;\r\n }\r\n if (child instanceof Container && child._children.length > 0) {\r\n this._dispatchInBuckets(child._children);\r\n }\r\n }\r\n };\r\n // reset left and top measures for the window and all its children\r\n _ScrollViewerWindow.prototype._updateMeasures = function () {\r\n var left = this.leftInPixels | 0, top = this.topInPixels | 0;\r\n this._measureForChildren.left -= left;\r\n this._measureForChildren.top -= top;\r\n this._currentMeasure.left -= left;\r\n this._currentMeasure.top -= top;\r\n this._updateChildrenMeasures(this._children, left, top);\r\n };\r\n _ScrollViewerWindow.prototype._updateChildrenMeasures = function (children, left, top) {\r\n for (var i = 0; i < children.length; ++i) {\r\n var child = children[i];\r\n child._currentMeasure.left -= left;\r\n child._currentMeasure.top -= top;\r\n child._customData._origLeft = child._currentMeasure.left; // save the original left and top values for each child\r\n child._customData._origTop = child._currentMeasure.top;\r\n if (child instanceof Container && child._children.length > 0) {\r\n this._updateChildrenMeasures(child._children, left, top);\r\n }\r\n }\r\n };\r\n _ScrollViewerWindow.prototype._getTypeName = function () {\r\n return \"ScrollViewerWindow\";\r\n };\r\n /** @hidden */\r\n _ScrollViewerWindow.prototype._additionalProcessing = function (parentMeasure, context) {\r\n _super.prototype._additionalProcessing.call(this, parentMeasure, context);\r\n this._parentMeasure = parentMeasure;\r\n this._measureForChildren.left = this._currentMeasure.left;\r\n this._measureForChildren.top = this._currentMeasure.top;\r\n this._measureForChildren.width = parentMeasure.width;\r\n this._measureForChildren.height = parentMeasure.height;\r\n };\r\n /** @hidden */\r\n _ScrollViewerWindow.prototype._layout = function (parentMeasure, context) {\r\n if (this._freezeControls) {\r\n this.invalidateRect(); // will trigger a redraw of the window\r\n return false;\r\n }\r\n return _super.prototype._layout.call(this, parentMeasure, context);\r\n };\r\n _ScrollViewerWindow.prototype._scrollChildren = function (children, left, top) {\r\n for (var i = 0; i < children.length; ++i) {\r\n var child = children[i];\r\n child._currentMeasure.left = child._customData._origLeft + left;\r\n child._currentMeasure.top = child._customData._origTop + top;\r\n child._isClipped = false; // clipping will be handled by _draw and the call to _intersectsRect()\r\n if (child instanceof Container && child._children.length > 0) {\r\n this._scrollChildren(child._children, left, top);\r\n }\r\n }\r\n };\r\n _ScrollViewerWindow.prototype._scrollChildrenWithBuckets = function (left, top, scrollLeft, scrollTop) {\r\n var bStartX = Math.max(0, Math.floor(-left / this._bucketWidth)), bEndX = Math.floor((-left + this._parentMeasure.width - 1) / this._bucketWidth), bStartY = Math.max(0, Math.floor(-top / this._bucketHeight)), bEndY = Math.floor((-top + this._parentMeasure.height - 1) / this._bucketHeight);\r\n while (bStartY <= bEndY) {\r\n for (var x = bStartX; x <= bEndX; ++x) {\r\n var bucket = bStartY * this._bucketLen + x, lstc = this._buckets[bucket];\r\n if (lstc) {\r\n for (var i = 0; i < lstc.length; ++i) {\r\n var child = lstc[i];\r\n child._currentMeasure.left = child._customData._origLeft + scrollLeft;\r\n child._currentMeasure.top = child._customData._origTop + scrollTop;\r\n child._isClipped = false; // clipping will be handled by _draw and the call to _intersectsRect()\r\n }\r\n }\r\n }\r\n bStartY++;\r\n }\r\n };\r\n /** @hidden */\r\n _ScrollViewerWindow.prototype._draw = function (context, invalidatedRectangle) {\r\n if (!this._freezeControls) {\r\n _super.prototype._draw.call(this, context, invalidatedRectangle);\r\n return;\r\n }\r\n this._localDraw(context);\r\n if (this.clipChildren) {\r\n this._clipForChildren(context);\r\n }\r\n var left = this.leftInPixels, top = this.topInPixels;\r\n if (this._useBuckets()) {\r\n this._scrollChildrenWithBuckets(this._oldLeft, this._oldTop, left, top);\r\n this._scrollChildrenWithBuckets(left, top, left, top);\r\n }\r\n else {\r\n this._scrollChildren(this._children, left, top);\r\n }\r\n this._oldLeft = left;\r\n this._oldTop = top;\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (!child._intersectsRect(this._parentMeasure)) {\r\n continue;\r\n }\r\n child._render(context, this._parentMeasure);\r\n }\r\n };\r\n _ScrollViewerWindow.prototype._postMeasure = function () {\r\n if (this._freezeControls) {\r\n _super.prototype._postMeasure.call(this);\r\n return;\r\n }\r\n var maxWidth = this.parentClientWidth;\r\n var maxHeight = this.parentClientHeight;\r\n for (var _i = 0, _a = this.children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (!child.isVisible || child.notRenderable) {\r\n continue;\r\n }\r\n if (child.horizontalAlignment === Control.HORIZONTAL_ALIGNMENT_CENTER) {\r\n child._offsetLeft(this._currentMeasure.left - child._currentMeasure.left);\r\n }\r\n if (child.verticalAlignment === Control.VERTICAL_ALIGNMENT_CENTER) {\r\n child._offsetTop(this._currentMeasure.top - child._currentMeasure.top);\r\n }\r\n maxWidth = Math.max(maxWidth, child._currentMeasure.left - this._currentMeasure.left + child._currentMeasure.width);\r\n maxHeight = Math.max(maxHeight, child._currentMeasure.top - this._currentMeasure.top + child._currentMeasure.height);\r\n }\r\n if (this._currentMeasure.width !== maxWidth) {\r\n this._width.updateInPlace(maxWidth, ValueAndUnit.UNITMODE_PIXEL);\r\n this._currentMeasure.width = maxWidth;\r\n this._rebuildLayout = true;\r\n this._isDirty = true;\r\n }\r\n if (this._currentMeasure.height !== maxHeight) {\r\n this._height.updateInPlace(maxHeight, ValueAndUnit.UNITMODE_PIXEL);\r\n this._currentMeasure.height = maxHeight;\r\n this._rebuildLayout = true;\r\n this._isDirty = true;\r\n }\r\n _super.prototype._postMeasure.call(this);\r\n };\r\n return _ScrollViewerWindow;\r\n}(Container));\r\nexport { _ScrollViewerWindow };\r\n//# sourceMappingURL=scrollViewerWindow.js.map","import { __extends } from \"tslib\";\r\nimport { BaseSlider } from \"./baseSlider\";\r\nimport { Measure } from \"../../measure\";\r\n/**\r\n * Class used to create slider controls\r\n */\r\nvar ScrollBar = /** @class */ (function (_super) {\r\n __extends(ScrollBar, _super);\r\n /**\r\n * Creates a new Slider\r\n * @param name defines the control name\r\n */\r\n function ScrollBar(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._background = \"black\";\r\n _this._borderColor = \"white\";\r\n _this._tempMeasure = new Measure(0, 0, 0, 0);\r\n return _this;\r\n }\r\n Object.defineProperty(ScrollBar.prototype, \"borderColor\", {\r\n /** Gets or sets border color */\r\n get: function () {\r\n return this._borderColor;\r\n },\r\n set: function (value) {\r\n if (this._borderColor === value) {\r\n return;\r\n }\r\n this._borderColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollBar.prototype, \"background\", {\r\n /** Gets or sets background color */\r\n get: function () {\r\n return this._background;\r\n },\r\n set: function (value) {\r\n if (this._background === value) {\r\n return;\r\n }\r\n this._background = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n ScrollBar.prototype._getTypeName = function () {\r\n return \"Scrollbar\";\r\n };\r\n ScrollBar.prototype._getThumbThickness = function () {\r\n var thumbThickness = 0;\r\n if (this._thumbWidth.isPixel) {\r\n thumbThickness = this._thumbWidth.getValue(this._host);\r\n }\r\n else {\r\n thumbThickness = this._backgroundBoxThickness * this._thumbWidth.getValue(this._host);\r\n }\r\n return thumbThickness;\r\n };\r\n ScrollBar.prototype._draw = function (context) {\r\n context.save();\r\n this._applyStates(context);\r\n this._prepareRenderingData(\"rectangle\");\r\n var left = this._renderLeft;\r\n var thumbPosition = this._getThumbPosition();\r\n context.fillStyle = this._background;\r\n context.fillRect(this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n // Value bar\r\n context.fillStyle = this.color;\r\n // Thumb\r\n if (this.isVertical) {\r\n this._tempMeasure.left = left - this._effectiveBarOffset;\r\n this._tempMeasure.top = this._currentMeasure.top + thumbPosition;\r\n this._tempMeasure.width = this._currentMeasure.width;\r\n this._tempMeasure.height = this._effectiveThumbThickness;\r\n }\r\n else {\r\n this._tempMeasure.left = this._currentMeasure.left + thumbPosition;\r\n this._tempMeasure.top = this._currentMeasure.top;\r\n this._tempMeasure.width = this._effectiveThumbThickness;\r\n this._tempMeasure.height = this._currentMeasure.height;\r\n }\r\n context.fillRect(this._tempMeasure.left, this._tempMeasure.top, this._tempMeasure.width, this._tempMeasure.height);\r\n context.restore();\r\n };\r\n /** @hidden */\r\n ScrollBar.prototype._updateValueFromPointer = function (x, y) {\r\n if (this.rotation != 0) {\r\n this._invertTransformMatrix.transformCoordinates(x, y, this._transformedPosition);\r\n x = this._transformedPosition.x;\r\n y = this._transformedPosition.y;\r\n }\r\n if (this._first) {\r\n this._first = false;\r\n this._originX = x;\r\n this._originY = y;\r\n // Check if move is required\r\n if (x < this._tempMeasure.left || x > this._tempMeasure.left + this._tempMeasure.width || y < this._tempMeasure.top || y > this._tempMeasure.top + this._tempMeasure.height) {\r\n if (this.isVertical) {\r\n this.value = this.minimum + (1 - ((y - this._currentMeasure.top) / this._currentMeasure.height)) * (this.maximum - this.minimum);\r\n }\r\n else {\r\n this.value = this.minimum + ((x - this._currentMeasure.left) / this._currentMeasure.width) * (this.maximum - this.minimum);\r\n }\r\n }\r\n }\r\n // Delta mode\r\n var delta = 0;\r\n if (this.isVertical) {\r\n delta = -((y - this._originY) / (this._currentMeasure.height - this._effectiveThumbThickness));\r\n }\r\n else {\r\n delta = (x - this._originX) / (this._currentMeasure.width - this._effectiveThumbThickness);\r\n }\r\n this.value += delta * (this.maximum - this.minimum);\r\n this._originX = x;\r\n this._originY = y;\r\n };\r\n ScrollBar.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex) {\r\n this._first = true;\r\n return _super.prototype._onPointerDown.call(this, target, coordinates, pointerId, buttonIndex);\r\n };\r\n return ScrollBar;\r\n}(BaseSlider));\r\nexport { ScrollBar };\r\n//# sourceMappingURL=scrollBar.js.map","import { __extends } from \"tslib\";\r\nimport { BaseSlider } from \"./baseSlider\";\r\nimport { Measure } from \"../../measure\";\r\n/**\r\n * Class used to create slider controls\r\n */\r\nvar ImageScrollBar = /** @class */ (function (_super) {\r\n __extends(ImageScrollBar, _super);\r\n /**\r\n * Creates a new ImageScrollBar\r\n * @param name defines the control name\r\n */\r\n function ImageScrollBar(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._thumbLength = 0.5;\r\n _this._thumbHeight = 1;\r\n _this._barImageHeight = 1;\r\n _this._tempMeasure = new Measure(0, 0, 0, 0);\r\n /** Number of 90° rotation to apply on the images when in vertical mode */\r\n _this.num90RotationInVerticalMode = 1;\r\n return _this;\r\n }\r\n Object.defineProperty(ImageScrollBar.prototype, \"backgroundImage\", {\r\n /**\r\n * Gets or sets the image used to render the background for horizontal bar\r\n */\r\n get: function () {\r\n return this._backgroundBaseImage;\r\n },\r\n set: function (value) {\r\n var _this = this;\r\n if (this._backgroundBaseImage === value) {\r\n return;\r\n }\r\n this._backgroundBaseImage = value;\r\n if (this.isVertical && this.num90RotationInVerticalMode !== 0) {\r\n if (!value.isLoaded) {\r\n value.onImageLoadedObservable.addOnce(function () {\r\n var rotatedValue = value._rotate90(_this.num90RotationInVerticalMode, true);\r\n _this._backgroundImage = rotatedValue;\r\n if (!rotatedValue.isLoaded) {\r\n rotatedValue.onImageLoadedObservable.addOnce(function () {\r\n _this._markAsDirty();\r\n });\r\n }\r\n _this._markAsDirty();\r\n });\r\n }\r\n else {\r\n this._backgroundImage = value._rotate90(this.num90RotationInVerticalMode, true);\r\n this._markAsDirty();\r\n }\r\n }\r\n else {\r\n this._backgroundImage = value;\r\n if (value && !value.isLoaded) {\r\n value.onImageLoadedObservable.addOnce(function () {\r\n _this._markAsDirty();\r\n });\r\n }\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageScrollBar.prototype, \"thumbImage\", {\r\n /**\r\n * Gets or sets the image used to render the thumb\r\n */\r\n get: function () {\r\n return this._thumbBaseImage;\r\n },\r\n set: function (value) {\r\n var _this = this;\r\n if (this._thumbBaseImage === value) {\r\n return;\r\n }\r\n this._thumbBaseImage = value;\r\n if (this.isVertical && this.num90RotationInVerticalMode !== 0) {\r\n if (!value.isLoaded) {\r\n value.onImageLoadedObservable.addOnce(function () {\r\n var rotatedValue = value._rotate90(-_this.num90RotationInVerticalMode, true);\r\n _this._thumbImage = rotatedValue;\r\n if (!rotatedValue.isLoaded) {\r\n rotatedValue.onImageLoadedObservable.addOnce(function () {\r\n _this._markAsDirty();\r\n });\r\n }\r\n _this._markAsDirty();\r\n });\r\n }\r\n else {\r\n this._thumbImage = value._rotate90(-this.num90RotationInVerticalMode, true);\r\n this._markAsDirty();\r\n }\r\n }\r\n else {\r\n this._thumbImage = value;\r\n if (value && !value.isLoaded) {\r\n value.onImageLoadedObservable.addOnce(function () {\r\n _this._markAsDirty();\r\n });\r\n }\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageScrollBar.prototype, \"thumbLength\", {\r\n /**\r\n * Gets or sets the length of the thumb\r\n */\r\n get: function () {\r\n return this._thumbLength;\r\n },\r\n set: function (value) {\r\n if (this._thumbLength === value) {\r\n return;\r\n }\r\n this._thumbLength = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageScrollBar.prototype, \"thumbHeight\", {\r\n /**\r\n * Gets or sets the height of the thumb\r\n */\r\n get: function () {\r\n return this._thumbHeight;\r\n },\r\n set: function (value) {\r\n if (this._thumbLength === value) {\r\n return;\r\n }\r\n this._thumbHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageScrollBar.prototype, \"barImageHeight\", {\r\n /**\r\n * Gets or sets the height of the bar image\r\n */\r\n get: function () {\r\n return this._barImageHeight;\r\n },\r\n set: function (value) {\r\n if (this._barImageHeight === value) {\r\n return;\r\n }\r\n this._barImageHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n ImageScrollBar.prototype._getTypeName = function () {\r\n return \"ImageScrollBar\";\r\n };\r\n ImageScrollBar.prototype._getThumbThickness = function () {\r\n var thumbThickness = 0;\r\n if (this._thumbWidth.isPixel) {\r\n thumbThickness = this._thumbWidth.getValue(this._host);\r\n }\r\n else {\r\n thumbThickness = this._backgroundBoxThickness * this._thumbWidth.getValue(this._host);\r\n }\r\n return thumbThickness;\r\n };\r\n ImageScrollBar.prototype._draw = function (context) {\r\n context.save();\r\n this._applyStates(context);\r\n this._prepareRenderingData(\"rectangle\");\r\n var thumbPosition = this._getThumbPosition();\r\n var left = this._renderLeft;\r\n var top = this._renderTop;\r\n var width = this._renderWidth;\r\n var height = this._renderHeight;\r\n // Background\r\n if (this._backgroundImage) {\r\n this._tempMeasure.copyFromFloats(left, top, width, height);\r\n if (this.isVertical) {\r\n this._tempMeasure.copyFromFloats(left + width * (1 - this._barImageHeight) * 0.5, this._currentMeasure.top, width * this._barImageHeight, height);\r\n this._tempMeasure.height += this._effectiveThumbThickness;\r\n this._backgroundImage._currentMeasure.copyFrom(this._tempMeasure);\r\n }\r\n else {\r\n this._tempMeasure.copyFromFloats(this._currentMeasure.left, top + height * (1 - this._barImageHeight) * 0.5, width, height * this._barImageHeight);\r\n this._tempMeasure.width += this._effectiveThumbThickness;\r\n this._backgroundImage._currentMeasure.copyFrom(this._tempMeasure);\r\n }\r\n this._backgroundImage._draw(context);\r\n }\r\n // Thumb\r\n if (this.isVertical) {\r\n this._tempMeasure.copyFromFloats(left - this._effectiveBarOffset + this._currentMeasure.width * (1 - this._thumbHeight) * 0.5, this._currentMeasure.top + thumbPosition, this._currentMeasure.width * this._thumbHeight, this._effectiveThumbThickness);\r\n }\r\n else {\r\n this._tempMeasure.copyFromFloats(this._currentMeasure.left + thumbPosition, this._currentMeasure.top + this._currentMeasure.height * (1 - this._thumbHeight) * 0.5, this._effectiveThumbThickness, this._currentMeasure.height * this._thumbHeight);\r\n }\r\n if (this._thumbImage) {\r\n this._thumbImage._currentMeasure.copyFrom(this._tempMeasure);\r\n this._thumbImage._draw(context);\r\n }\r\n context.restore();\r\n };\r\n /** @hidden */\r\n ImageScrollBar.prototype._updateValueFromPointer = function (x, y) {\r\n if (this.rotation != 0) {\r\n this._invertTransformMatrix.transformCoordinates(x, y, this._transformedPosition);\r\n x = this._transformedPosition.x;\r\n y = this._transformedPosition.y;\r\n }\r\n if (this._first) {\r\n this._first = false;\r\n this._originX = x;\r\n this._originY = y;\r\n // Check if move is required\r\n if (x < this._tempMeasure.left || x > this._tempMeasure.left + this._tempMeasure.width || y < this._tempMeasure.top || y > this._tempMeasure.top + this._tempMeasure.height) {\r\n if (this.isVertical) {\r\n this.value = this.minimum + (1 - ((y - this._currentMeasure.top) / this._currentMeasure.height)) * (this.maximum - this.minimum);\r\n }\r\n else {\r\n this.value = this.minimum + ((x - this._currentMeasure.left) / this._currentMeasure.width) * (this.maximum - this.minimum);\r\n }\r\n }\r\n }\r\n // Delta mode\r\n var delta = 0;\r\n if (this.isVertical) {\r\n delta = -((y - this._originY) / (this._currentMeasure.height - this._effectiveThumbThickness));\r\n }\r\n else {\r\n delta = (x - this._originX) / (this._currentMeasure.width - this._effectiveThumbThickness);\r\n }\r\n this.value += delta * (this.maximum - this.minimum);\r\n this._originX = x;\r\n this._originY = y;\r\n };\r\n ImageScrollBar.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex) {\r\n this._first = true;\r\n return _super.prototype._onPointerDown.call(this, target, coordinates, pointerId, buttonIndex);\r\n };\r\n return ImageScrollBar;\r\n}(BaseSlider));\r\nexport { ImageScrollBar };\r\n//# sourceMappingURL=imageScrollBar.js.map","import { __extends } from \"tslib\";\r\nimport { Rectangle } from \"../rectangle\";\r\nimport { Grid } from \"../grid\";\r\nimport { Control } from \"../control\";\r\nimport { _ScrollViewerWindow } from \"./scrollViewerWindow\";\r\nimport { ScrollBar } from \"../sliders/scrollBar\";\r\nimport { ImageScrollBar } from \"../sliders/imageScrollBar\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to hold a viewer window and sliders in a grid\r\n*/\r\nvar ScrollViewer = /** @class */ (function (_super) {\r\n __extends(ScrollViewer, _super);\r\n /**\r\n * Creates a new ScrollViewer\r\n * @param name of ScrollViewer\r\n */\r\n function ScrollViewer(name, isImageBased) {\r\n var _this = _super.call(this, name) || this;\r\n _this._barSize = 20;\r\n _this._pointerIsOver = false;\r\n _this._wheelPrecision = 0.05;\r\n _this._thumbLength = 0.5;\r\n _this._thumbHeight = 1;\r\n _this._barImageHeight = 1;\r\n _this._horizontalBarImageHeight = 1;\r\n _this._verticalBarImageHeight = 1;\r\n _this._forceHorizontalBar = false;\r\n _this._forceVerticalBar = false;\r\n _this._useImageBar = isImageBased ? isImageBased : false;\r\n _this.onDirtyObservable.add(function () {\r\n _this._horizontalBarSpace.color = _this.color;\r\n _this._verticalBarSpace.color = _this.color;\r\n _this._dragSpace.color = _this.color;\r\n });\r\n _this.onPointerEnterObservable.add(function () {\r\n _this._pointerIsOver = true;\r\n });\r\n _this.onPointerOutObservable.add(function () {\r\n _this._pointerIsOver = false;\r\n });\r\n _this._grid = new Grid();\r\n if (_this._useImageBar) {\r\n _this._horizontalBar = new ImageScrollBar();\r\n _this._verticalBar = new ImageScrollBar();\r\n }\r\n else {\r\n _this._horizontalBar = new ScrollBar();\r\n _this._verticalBar = new ScrollBar();\r\n }\r\n _this._window = new _ScrollViewerWindow(\"scrollViewer_window\");\r\n _this._window.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _this._window.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n _this._grid.addColumnDefinition(1);\r\n _this._grid.addColumnDefinition(0, true);\r\n _this._grid.addRowDefinition(1);\r\n _this._grid.addRowDefinition(0, true);\r\n _super.prototype.addControl.call(_this, _this._grid);\r\n _this._grid.addControl(_this._window, 0, 0);\r\n _this._verticalBarSpace = new Rectangle();\r\n _this._verticalBarSpace.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _this._verticalBarSpace.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n _this._verticalBarSpace.thickness = 1;\r\n _this._grid.addControl(_this._verticalBarSpace, 0, 1);\r\n _this._addBar(_this._verticalBar, _this._verticalBarSpace, true, Math.PI);\r\n _this._horizontalBarSpace = new Rectangle();\r\n _this._horizontalBarSpace.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _this._horizontalBarSpace.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n _this._horizontalBarSpace.thickness = 1;\r\n _this._grid.addControl(_this._horizontalBarSpace, 1, 0);\r\n _this._addBar(_this._horizontalBar, _this._horizontalBarSpace, false, 0);\r\n _this._dragSpace = new Rectangle();\r\n _this._dragSpace.thickness = 1;\r\n _this._grid.addControl(_this._dragSpace, 1, 1);\r\n // Colors\r\n if (!_this._useImageBar) {\r\n _this.barColor = \"grey\";\r\n _this.barBackground = \"transparent\";\r\n }\r\n return _this;\r\n }\r\n Object.defineProperty(ScrollViewer.prototype, \"horizontalBar\", {\r\n /**\r\n * Gets the horizontal scrollbar\r\n */\r\n get: function () {\r\n return this._horizontalBar;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"verticalBar\", {\r\n /**\r\n * Gets the vertical scrollbar\r\n */\r\n get: function () {\r\n return this._verticalBar;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Adds a new control to the current container\r\n * @param control defines the control to add\r\n * @returns the current container\r\n */\r\n ScrollViewer.prototype.addControl = function (control) {\r\n if (!control) {\r\n return this;\r\n }\r\n this._window.addControl(control);\r\n return this;\r\n };\r\n /**\r\n * Removes a control from the current container\r\n * @param control defines the control to remove\r\n * @returns the current container\r\n */\r\n ScrollViewer.prototype.removeControl = function (control) {\r\n this._window.removeControl(control);\r\n return this;\r\n };\r\n Object.defineProperty(ScrollViewer.prototype, \"children\", {\r\n /** Gets the list of children */\r\n get: function () {\r\n return this._window.children;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n ScrollViewer.prototype._flagDescendantsAsMatrixDirty = function () {\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child._markMatrixAsDirty();\r\n }\r\n };\r\n Object.defineProperty(ScrollViewer.prototype, \"freezeControls\", {\r\n /**\r\n * Freezes or unfreezes the controls in the window.\r\n * When controls are frozen, the scroll viewer can render a lot more quickly but updates to positions/sizes of controls\r\n * are not taken into account. If you want to change positions/sizes, unfreeze, perform the changes then freeze again\r\n */\r\n get: function () {\r\n return this._window.freezeControls;\r\n },\r\n set: function (value) {\r\n this._window.freezeControls = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"bucketWidth\", {\r\n /** Gets the bucket width */\r\n get: function () {\r\n return this._window.bucketWidth;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"bucketHeight\", {\r\n /** Gets the bucket height */\r\n get: function () {\r\n return this._window.bucketHeight;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Sets the bucket sizes.\r\n * When freezeControls is true, setting a non-zero bucket size will improve performances by updating only\r\n * controls that are visible. The bucket sizes is used to subdivide (internally) the window area to smaller areas into which\r\n * controls are dispatched. So, the size should be roughly equals to the mean size of all the controls of\r\n * the window. To disable the usage of buckets, sets either width or height (or both) to 0.\r\n * Please note that using this option will raise the memory usage (the higher the bucket sizes, the less memory\r\n * used), that's why it is not enabled by default.\r\n * @param width width of the bucket\r\n * @param height height of the bucket\r\n */\r\n ScrollViewer.prototype.setBucketSizes = function (width, height) {\r\n this._window.setBucketSizes(width, height);\r\n };\r\n Object.defineProperty(ScrollViewer.prototype, \"forceHorizontalBar\", {\r\n /**\r\n * Forces the horizontal scroll bar to be displayed\r\n */\r\n get: function () {\r\n return this._forceHorizontalBar;\r\n },\r\n set: function (value) {\r\n this._grid.setRowDefinition(1, value ? this._barSize : 0, true);\r\n this._horizontalBar.isVisible = value;\r\n this._forceHorizontalBar = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"forceVerticalBar\", {\r\n /**\r\n * Forces the vertical scroll bar to be displayed\r\n */\r\n get: function () {\r\n return this._forceVerticalBar;\r\n },\r\n set: function (value) {\r\n this._grid.setColumnDefinition(1, value ? this._barSize : 0, true);\r\n this._verticalBar.isVisible = value;\r\n this._forceVerticalBar = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** Reset the scroll viewer window to initial size */\r\n ScrollViewer.prototype.resetWindow = function () {\r\n this._window.width = \"100%\";\r\n this._window.height = \"100%\";\r\n };\r\n ScrollViewer.prototype._getTypeName = function () {\r\n return \"ScrollViewer\";\r\n };\r\n ScrollViewer.prototype._buildClientSizes = function () {\r\n var ratio = this.host.idealRatio;\r\n this._window.parentClientWidth = this._currentMeasure.width - (this._verticalBar.isVisible || this.forceVerticalBar ? this._barSize * ratio : 0) - 2 * this.thickness;\r\n this._window.parentClientHeight = this._currentMeasure.height - (this._horizontalBar.isVisible || this.forceHorizontalBar ? this._barSize * ratio : 0) - 2 * this.thickness;\r\n this._clientWidth = this._window.parentClientWidth;\r\n this._clientHeight = this._window.parentClientHeight;\r\n };\r\n ScrollViewer.prototype._additionalProcessing = function (parentMeasure, context) {\r\n _super.prototype._additionalProcessing.call(this, parentMeasure, context);\r\n this._buildClientSizes();\r\n };\r\n ScrollViewer.prototype._postMeasure = function () {\r\n _super.prototype._postMeasure.call(this);\r\n this._updateScroller();\r\n };\r\n Object.defineProperty(ScrollViewer.prototype, \"wheelPrecision\", {\r\n /**\r\n * Gets or sets the mouse wheel precision\r\n * from 0 to 1 with a default value of 0.05\r\n * */\r\n get: function () {\r\n return this._wheelPrecision;\r\n },\r\n set: function (value) {\r\n if (this._wheelPrecision === value) {\r\n return;\r\n }\r\n if (value < 0) {\r\n value = 0;\r\n }\r\n if (value > 1) {\r\n value = 1;\r\n }\r\n this._wheelPrecision = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"scrollBackground\", {\r\n /** Gets or sets the scroll bar container background color */\r\n get: function () {\r\n return this._horizontalBarSpace.background;\r\n },\r\n set: function (color) {\r\n if (this._horizontalBarSpace.background === color) {\r\n return;\r\n }\r\n this._horizontalBarSpace.background = color;\r\n this._verticalBarSpace.background = color;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"barColor\", {\r\n /** Gets or sets the bar color */\r\n get: function () {\r\n return this._barColor;\r\n },\r\n set: function (color) {\r\n if (this._barColor === color) {\r\n return;\r\n }\r\n this._barColor = color;\r\n this._horizontalBar.color = color;\r\n this._verticalBar.color = color;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"thumbImage\", {\r\n /** Gets or sets the bar image */\r\n get: function () {\r\n return this._barImage;\r\n },\r\n set: function (value) {\r\n if (this._barImage === value) {\r\n return;\r\n }\r\n this._barImage = value;\r\n var hb = this._horizontalBar;\r\n var vb = this._verticalBar;\r\n hb.thumbImage = value;\r\n vb.thumbImage = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"horizontalThumbImage\", {\r\n /** Gets or sets the horizontal bar image */\r\n get: function () {\r\n return this._horizontalBarImage;\r\n },\r\n set: function (value) {\r\n if (this._horizontalBarImage === value) {\r\n return;\r\n }\r\n this._horizontalBarImage = value;\r\n var hb = this._horizontalBar;\r\n hb.thumbImage = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"verticalThumbImage\", {\r\n /** Gets or sets the vertical bar image */\r\n get: function () {\r\n return this._verticalBarImage;\r\n },\r\n set: function (value) {\r\n if (this._verticalBarImage === value) {\r\n return;\r\n }\r\n this._verticalBarImage = value;\r\n var vb = this._verticalBar;\r\n vb.thumbImage = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"barSize\", {\r\n /** Gets or sets the size of the bar */\r\n get: function () {\r\n return this._barSize;\r\n },\r\n set: function (value) {\r\n if (this._barSize === value) {\r\n return;\r\n }\r\n this._barSize = value;\r\n this._markAsDirty();\r\n if (this._horizontalBar.isVisible) {\r\n this._grid.setRowDefinition(1, this._barSize, true);\r\n }\r\n if (this._verticalBar.isVisible) {\r\n this._grid.setColumnDefinition(1, this._barSize, true);\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"thumbLength\", {\r\n /** Gets or sets the length of the thumb */\r\n get: function () {\r\n return this._thumbLength;\r\n },\r\n set: function (value) {\r\n if (this._thumbLength === value) {\r\n return;\r\n }\r\n if (value <= 0) {\r\n value = 0.1;\r\n }\r\n if (value > 1) {\r\n value = 1;\r\n }\r\n this._thumbLength = value;\r\n var hb = this._horizontalBar;\r\n var vb = this._verticalBar;\r\n hb.thumbLength = value;\r\n vb.thumbLength = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"thumbHeight\", {\r\n /** Gets or sets the height of the thumb */\r\n get: function () {\r\n return this._thumbHeight;\r\n },\r\n set: function (value) {\r\n if (this._thumbHeight === value) {\r\n return;\r\n }\r\n if (value <= 0) {\r\n value = 0.1;\r\n }\r\n if (value > 1) {\r\n value = 1;\r\n }\r\n this._thumbHeight = value;\r\n var hb = this._horizontalBar;\r\n var vb = this._verticalBar;\r\n hb.thumbHeight = value;\r\n vb.thumbHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"barImageHeight\", {\r\n /** Gets or sets the height of the bar image */\r\n get: function () {\r\n return this._barImageHeight;\r\n },\r\n set: function (value) {\r\n if (this._barImageHeight === value) {\r\n return;\r\n }\r\n if (value <= 0) {\r\n value = 0.1;\r\n }\r\n if (value > 1) {\r\n value = 1;\r\n }\r\n this._barImageHeight = value;\r\n var hb = this._horizontalBar;\r\n var vb = this._verticalBar;\r\n hb.barImageHeight = value;\r\n vb.barImageHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"horizontalBarImageHeight\", {\r\n /** Gets or sets the height of the horizontal bar image */\r\n get: function () {\r\n return this._horizontalBarImageHeight;\r\n },\r\n set: function (value) {\r\n if (this._horizontalBarImageHeight === value) {\r\n return;\r\n }\r\n if (value <= 0) {\r\n value = 0.1;\r\n }\r\n if (value > 1) {\r\n value = 1;\r\n }\r\n this._horizontalBarImageHeight = value;\r\n var hb = this._horizontalBar;\r\n hb.barImageHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"verticalBarImageHeight\", {\r\n /** Gets or sets the height of the vertical bar image */\r\n get: function () {\r\n return this._verticalBarImageHeight;\r\n },\r\n set: function (value) {\r\n if (this._verticalBarImageHeight === value) {\r\n return;\r\n }\r\n if (value <= 0) {\r\n value = 0.1;\r\n }\r\n if (value > 1) {\r\n value = 1;\r\n }\r\n this._verticalBarImageHeight = value;\r\n var vb = this._verticalBar;\r\n vb.barImageHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"barBackground\", {\r\n /** Gets or sets the bar background */\r\n get: function () {\r\n return this._barBackground;\r\n },\r\n set: function (color) {\r\n if (this._barBackground === color) {\r\n return;\r\n }\r\n this._barBackground = color;\r\n var hb = this._horizontalBar;\r\n var vb = this._verticalBar;\r\n hb.background = color;\r\n vb.background = color;\r\n this._dragSpace.background = color;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"barImage\", {\r\n /** Gets or sets the bar background image */\r\n get: function () {\r\n return this._barBackgroundImage;\r\n },\r\n set: function (value) {\r\n if (this._barBackgroundImage === value) {\r\n }\r\n this._barBackgroundImage = value;\r\n var hb = this._horizontalBar;\r\n var vb = this._verticalBar;\r\n hb.backgroundImage = value;\r\n vb.backgroundImage = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"horizontalBarImage\", {\r\n /** Gets or sets the horizontal bar background image */\r\n get: function () {\r\n return this._horizontalBarBackgroundImage;\r\n },\r\n set: function (value) {\r\n if (this._horizontalBarBackgroundImage === value) {\r\n }\r\n this._horizontalBarBackgroundImage = value;\r\n var hb = this._horizontalBar;\r\n hb.backgroundImage = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"verticalBarImage\", {\r\n /** Gets or sets the vertical bar background image */\r\n get: function () {\r\n return this._verticalBarBackgroundImage;\r\n },\r\n set: function (value) {\r\n if (this._verticalBarBackgroundImage === value) {\r\n }\r\n this._verticalBarBackgroundImage = value;\r\n var vb = this._verticalBar;\r\n vb.backgroundImage = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n ScrollViewer.prototype._setWindowPosition = function () {\r\n var ratio = this.host.idealRatio;\r\n var windowContentsWidth = this._window._currentMeasure.width;\r\n var windowContentsHeight = this._window._currentMeasure.height;\r\n var _endLeft = this._clientWidth - windowContentsWidth;\r\n var _endTop = this._clientHeight - windowContentsHeight;\r\n var newLeft = (this._horizontalBar.value / ratio) * _endLeft + \"px\";\r\n var newTop = (this._verticalBar.value / ratio) * _endTop + \"px\";\r\n if (newLeft !== this._window.left) {\r\n this._window.left = newLeft;\r\n if (!this.freezeControls) {\r\n this._rebuildLayout = true;\r\n }\r\n }\r\n if (newTop !== this._window.top) {\r\n this._window.top = newTop;\r\n if (!this.freezeControls) {\r\n this._rebuildLayout = true;\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n ScrollViewer.prototype._updateScroller = function () {\r\n var windowContentsWidth = this._window._currentMeasure.width;\r\n var windowContentsHeight = this._window._currentMeasure.height;\r\n if (this._horizontalBar.isVisible && windowContentsWidth <= this._clientWidth && !this.forceHorizontalBar) {\r\n this._grid.setRowDefinition(1, 0, true);\r\n this._horizontalBar.isVisible = false;\r\n this._horizontalBar.value = 0;\r\n this._rebuildLayout = true;\r\n }\r\n else if (!this._horizontalBar.isVisible && (windowContentsWidth > this._clientWidth || this.forceHorizontalBar)) {\r\n this._grid.setRowDefinition(1, this._barSize, true);\r\n this._horizontalBar.isVisible = true;\r\n this._rebuildLayout = true;\r\n }\r\n if (this._verticalBar.isVisible && windowContentsHeight <= this._clientHeight && !this.forceVerticalBar) {\r\n this._grid.setColumnDefinition(1, 0, true);\r\n this._verticalBar.isVisible = false;\r\n this._verticalBar.value = 0;\r\n this._rebuildLayout = true;\r\n }\r\n else if (!this._verticalBar.isVisible && (windowContentsHeight > this._clientHeight || this.forceVerticalBar)) {\r\n this._grid.setColumnDefinition(1, this._barSize, true);\r\n this._verticalBar.isVisible = true;\r\n this._rebuildLayout = true;\r\n }\r\n this._buildClientSizes();\r\n var ratio = this.host.idealRatio;\r\n this._horizontalBar.thumbWidth = this._thumbLength * 0.9 * (this._clientWidth / ratio) + \"px\";\r\n this._verticalBar.thumbWidth = this._thumbLength * 0.9 * (this._clientHeight / ratio) + \"px\";\r\n };\r\n ScrollViewer.prototype._link = function (host) {\r\n _super.prototype._link.call(this, host);\r\n this._attachWheel();\r\n };\r\n /** @hidden */\r\n ScrollViewer.prototype._addBar = function (barControl, barContainer, isVertical, rotation) {\r\n var _this = this;\r\n barControl.paddingLeft = 0;\r\n barControl.width = \"100%\";\r\n barControl.height = \"100%\";\r\n barControl.barOffset = 0;\r\n barControl.value = 0;\r\n barControl.maximum = 1;\r\n barControl.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_CENTER;\r\n barControl.verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n barControl.isVertical = isVertical;\r\n barControl.rotation = rotation;\r\n barControl.isVisible = false;\r\n barContainer.addControl(barControl);\r\n barControl.onValueChangedObservable.add(function (value) {\r\n _this._setWindowPosition();\r\n });\r\n };\r\n /** @hidden */\r\n ScrollViewer.prototype._attachWheel = function () {\r\n var _this = this;\r\n if (!this._host || this._onWheelObserver) {\r\n return;\r\n }\r\n this._onWheelObserver = this.onWheelObservable.add(function (pi) {\r\n if (!_this._pointerIsOver) {\r\n return;\r\n }\r\n if (_this._verticalBar.isVisible == true) {\r\n if (pi.y < 0 && _this._verticalBar.value > 0) {\r\n _this._verticalBar.value -= _this._wheelPrecision;\r\n }\r\n else if (pi.y > 0 && _this._verticalBar.value < _this._verticalBar.maximum) {\r\n _this._verticalBar.value += _this._wheelPrecision;\r\n }\r\n }\r\n if (_this._horizontalBar.isVisible == true) {\r\n if (pi.x < 0 && _this._horizontalBar.value < _this._horizontalBar.maximum) {\r\n _this._horizontalBar.value += _this._wheelPrecision;\r\n }\r\n else if (pi.x > 0 && _this._horizontalBar.value > 0) {\r\n _this._horizontalBar.value -= _this._wheelPrecision;\r\n }\r\n }\r\n });\r\n };\r\n ScrollViewer.prototype._renderHighlightSpecific = function (context) {\r\n if (!this.isHighlighted) {\r\n return;\r\n }\r\n _super.prototype._renderHighlightSpecific.call(this, context);\r\n this._grid._renderHighlightSpecific(context);\r\n context.restore();\r\n };\r\n /** Releases associated resources */\r\n ScrollViewer.prototype.dispose = function () {\r\n this.onWheelObservable.remove(this._onWheelObserver);\r\n this._onWheelObserver = null;\r\n _super.prototype.dispose.call(this);\r\n };\r\n return ScrollViewer;\r\n}(Rectangle));\r\nexport { ScrollViewer };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.ScrollViewer\"] = ScrollViewer;\r\n//# sourceMappingURL=scrollViewer.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { StackPanel } from \"./stackPanel\";\r\nimport { Button } from \"./button\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to store key control properties\r\n */\r\nvar KeyPropertySet = /** @class */ (function () {\r\n function KeyPropertySet() {\r\n }\r\n return KeyPropertySet;\r\n}());\r\nexport { KeyPropertySet };\r\n/**\r\n * Class used to create virtual keyboard\r\n */\r\nvar VirtualKeyboard = /** @class */ (function (_super) {\r\n __extends(VirtualKeyboard, _super);\r\n function VirtualKeyboard() {\r\n var _this = _super !== null && _super.apply(this, arguments) || this;\r\n /** Observable raised when a key is pressed */\r\n _this.onKeyPressObservable = new Observable();\r\n /** Gets or sets default key button width */\r\n _this.defaultButtonWidth = \"40px\";\r\n /** Gets or sets default key button height */\r\n _this.defaultButtonHeight = \"40px\";\r\n /** Gets or sets default key button left padding */\r\n _this.defaultButtonPaddingLeft = \"2px\";\r\n /** Gets or sets default key button right padding */\r\n _this.defaultButtonPaddingRight = \"2px\";\r\n /** Gets or sets default key button top padding */\r\n _this.defaultButtonPaddingTop = \"2px\";\r\n /** Gets or sets default key button bottom padding */\r\n _this.defaultButtonPaddingBottom = \"2px\";\r\n /** Gets or sets default key button foreground color */\r\n _this.defaultButtonColor = \"#DDD\";\r\n /** Gets or sets default key button background color */\r\n _this.defaultButtonBackground = \"#070707\";\r\n /** Gets or sets shift button foreground color */\r\n _this.shiftButtonColor = \"#7799FF\";\r\n /** Gets or sets shift button thickness*/\r\n _this.selectedShiftThickness = 1;\r\n /** Gets shift key state */\r\n _this.shiftState = 0;\r\n _this._currentlyConnectedInputText = null;\r\n _this._connectedInputTexts = [];\r\n _this._onKeyPressObserver = null;\r\n return _this;\r\n }\r\n VirtualKeyboard.prototype._getTypeName = function () {\r\n return \"VirtualKeyboard\";\r\n };\r\n VirtualKeyboard.prototype._createKey = function (key, propertySet) {\r\n var _this = this;\r\n var button = Button.CreateSimpleButton(key, key);\r\n button.width = propertySet && propertySet.width ? propertySet.width : this.defaultButtonWidth;\r\n button.height = propertySet && propertySet.height ? propertySet.height : this.defaultButtonHeight;\r\n button.color = propertySet && propertySet.color ? propertySet.color : this.defaultButtonColor;\r\n button.background = propertySet && propertySet.background ? propertySet.background : this.defaultButtonBackground;\r\n button.paddingLeft = propertySet && propertySet.paddingLeft ? propertySet.paddingLeft : this.defaultButtonPaddingLeft;\r\n button.paddingRight = propertySet && propertySet.paddingRight ? propertySet.paddingRight : this.defaultButtonPaddingRight;\r\n button.paddingTop = propertySet && propertySet.paddingTop ? propertySet.paddingTop : this.defaultButtonPaddingTop;\r\n button.paddingBottom = propertySet && propertySet.paddingBottom ? propertySet.paddingBottom : this.defaultButtonPaddingBottom;\r\n button.thickness = 0;\r\n button.isFocusInvisible = true;\r\n button.shadowColor = this.shadowColor;\r\n button.shadowBlur = this.shadowBlur;\r\n button.shadowOffsetX = this.shadowOffsetX;\r\n button.shadowOffsetY = this.shadowOffsetY;\r\n button.onPointerUpObservable.add(function () {\r\n _this.onKeyPressObservable.notifyObservers(key);\r\n });\r\n return button;\r\n };\r\n /**\r\n * Adds a new row of keys\r\n * @param keys defines the list of keys to add\r\n * @param propertySets defines the associated property sets\r\n */\r\n VirtualKeyboard.prototype.addKeysRow = function (keys, propertySets) {\r\n var panel = new StackPanel();\r\n panel.isVertical = false;\r\n panel.isFocusInvisible = true;\r\n var maxKey = null;\r\n for (var i = 0; i < keys.length; i++) {\r\n var properties = null;\r\n if (propertySets && propertySets.length === keys.length) {\r\n properties = propertySets[i];\r\n }\r\n var key = this._createKey(keys[i], properties);\r\n if (!maxKey || key.heightInPixels > maxKey.heightInPixels) {\r\n maxKey = key;\r\n }\r\n panel.addControl(key);\r\n }\r\n panel.height = maxKey ? maxKey.height : this.defaultButtonHeight;\r\n this.addControl(panel);\r\n };\r\n /**\r\n * Set the shift key to a specific state\r\n * @param shiftState defines the new shift state\r\n */\r\n VirtualKeyboard.prototype.applyShiftState = function (shiftState) {\r\n if (!this.children) {\r\n return;\r\n }\r\n for (var i = 0; i < this.children.length; i++) {\r\n var row = this.children[i];\r\n if (!row || !row.children) {\r\n continue;\r\n }\r\n var rowContainer = row;\r\n for (var j = 0; j < rowContainer.children.length; j++) {\r\n var button = rowContainer.children[j];\r\n if (!button || !button.children[0]) {\r\n continue;\r\n }\r\n var button_tblock = button.children[0];\r\n if (button_tblock.text === \"\\u21E7\") {\r\n button.color = (shiftState ? this.shiftButtonColor : this.defaultButtonColor);\r\n button.thickness = (shiftState > 1 ? this.selectedShiftThickness : 0);\r\n }\r\n button_tblock.text = (shiftState > 0 ? button_tblock.text.toUpperCase() : button_tblock.text.toLowerCase());\r\n }\r\n }\r\n };\r\n Object.defineProperty(VirtualKeyboard.prototype, \"connectedInputText\", {\r\n /** Gets the input text control currently attached to the keyboard */\r\n get: function () {\r\n return this._currentlyConnectedInputText;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Connects the keyboard with an input text control\r\n *\r\n * @param input defines the target control\r\n */\r\n VirtualKeyboard.prototype.connect = function (input) {\r\n var _this = this;\r\n var inputTextAlreadyConnected = this._connectedInputTexts.some(function (a) { return a.input === input; });\r\n if (inputTextAlreadyConnected) {\r\n return;\r\n }\r\n if (this._onKeyPressObserver === null) {\r\n this._onKeyPressObserver = this.onKeyPressObservable.add(function (key) {\r\n if (!_this._currentlyConnectedInputText) {\r\n return;\r\n }\r\n _this._currentlyConnectedInputText._host.focusedControl = _this._currentlyConnectedInputText;\r\n switch (key) {\r\n case \"\\u21E7\":\r\n _this.shiftState++;\r\n if (_this.shiftState > 2) {\r\n _this.shiftState = 0;\r\n }\r\n _this.applyShiftState(_this.shiftState);\r\n return;\r\n case \"\\u2190\":\r\n _this._currentlyConnectedInputText.processKey(8);\r\n return;\r\n case \"\\u21B5\":\r\n _this._currentlyConnectedInputText.processKey(13);\r\n return;\r\n }\r\n _this._currentlyConnectedInputText.processKey(-1, (_this.shiftState ? key.toUpperCase() : key));\r\n if (_this.shiftState === 1) {\r\n _this.shiftState = 0;\r\n _this.applyShiftState(_this.shiftState);\r\n }\r\n });\r\n }\r\n this.isVisible = false;\r\n this._currentlyConnectedInputText = input;\r\n input._connectedVirtualKeyboard = this;\r\n // Events hooking\r\n var onFocusObserver = input.onFocusObservable.add(function () {\r\n _this._currentlyConnectedInputText = input;\r\n input._connectedVirtualKeyboard = _this;\r\n _this.isVisible = true;\r\n });\r\n var onBlurObserver = input.onBlurObservable.add(function () {\r\n input._connectedVirtualKeyboard = null;\r\n _this._currentlyConnectedInputText = null;\r\n _this.isVisible = false;\r\n });\r\n this._connectedInputTexts.push({\r\n input: input,\r\n onBlurObserver: onBlurObserver,\r\n onFocusObserver: onFocusObserver\r\n });\r\n };\r\n /**\r\n * Disconnects the keyboard from connected InputText controls\r\n *\r\n * @param input optionally defines a target control, otherwise all are disconnected\r\n */\r\n VirtualKeyboard.prototype.disconnect = function (input) {\r\n var _this = this;\r\n if (input) {\r\n // .find not available on IE\r\n var filtered = this._connectedInputTexts.filter(function (a) { return a.input === input; });\r\n if (filtered.length === 1) {\r\n this._removeConnectedInputObservables(filtered[0]);\r\n this._connectedInputTexts = this._connectedInputTexts.filter(function (a) { return a.input !== input; });\r\n if (this._currentlyConnectedInputText === input) {\r\n this._currentlyConnectedInputText = null;\r\n }\r\n }\r\n }\r\n else {\r\n this._connectedInputTexts.forEach(function (connectedInputText) {\r\n _this._removeConnectedInputObservables(connectedInputText);\r\n });\r\n this._connectedInputTexts = [];\r\n }\r\n if (this._connectedInputTexts.length === 0) {\r\n this._currentlyConnectedInputText = null;\r\n this.onKeyPressObservable.remove(this._onKeyPressObserver);\r\n this._onKeyPressObserver = null;\r\n }\r\n };\r\n VirtualKeyboard.prototype._removeConnectedInputObservables = function (connectedInputText) {\r\n connectedInputText.input._connectedVirtualKeyboard = null;\r\n connectedInputText.input.onFocusObservable.remove(connectedInputText.onFocusObserver);\r\n connectedInputText.input.onBlurObservable.remove(connectedInputText.onBlurObserver);\r\n };\r\n /**\r\n * Release all resources\r\n */\r\n VirtualKeyboard.prototype.dispose = function () {\r\n _super.prototype.dispose.call(this);\r\n this.disconnect();\r\n };\r\n // Statics\r\n /**\r\n * Creates a new keyboard using a default layout\r\n *\r\n * @param name defines control name\r\n * @returns a new VirtualKeyboard\r\n */\r\n VirtualKeyboard.CreateDefaultLayout = function (name) {\r\n var returnValue = new VirtualKeyboard(name);\r\n returnValue.addKeysRow([\"1\", \"2\", \"3\", \"4\", \"5\", \"6\", \"7\", \"8\", \"9\", \"0\", \"\\u2190\"]);\r\n returnValue.addKeysRow([\"q\", \"w\", \"e\", \"r\", \"t\", \"y\", \"u\", \"i\", \"o\", \"p\"]);\r\n returnValue.addKeysRow([\"a\", \"s\", \"d\", \"f\", \"g\", \"h\", \"j\", \"k\", \"l\", \";\", \"'\", \"\\u21B5\"]);\r\n returnValue.addKeysRow([\"\\u21E7\", \"z\", \"x\", \"c\", \"v\", \"b\", \"n\", \"m\", \",\", \".\", \"/\"]);\r\n returnValue.addKeysRow([\" \"], [{ width: \"200px\" }]);\r\n return returnValue;\r\n };\r\n return VirtualKeyboard;\r\n}(StackPanel));\r\nexport { VirtualKeyboard };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.VirtualKeyboard\"] = VirtualKeyboard;\r\n//# sourceMappingURL=virtualKeyboard.js.map","import { __extends } from \"tslib\";\r\nimport { Control } from \"./control\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/** Class used to render a grid */\r\nvar DisplayGrid = /** @class */ (function (_super) {\r\n __extends(DisplayGrid, _super);\r\n /**\r\n * Creates a new GridDisplayRectangle\r\n * @param name defines the control name\r\n */\r\n function DisplayGrid(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._cellWidth = 20;\r\n _this._cellHeight = 20;\r\n _this._minorLineTickness = 1;\r\n _this._minorLineColor = \"DarkGray\";\r\n _this._majorLineTickness = 2;\r\n _this._majorLineColor = \"White\";\r\n _this._majorLineFrequency = 5;\r\n _this._background = \"Black\";\r\n _this._displayMajorLines = true;\r\n _this._displayMinorLines = true;\r\n return _this;\r\n }\r\n Object.defineProperty(DisplayGrid.prototype, \"displayMinorLines\", {\r\n /** Gets or sets a boolean indicating if minor lines must be rendered (true by default)) */\r\n get: function () {\r\n return this._displayMinorLines;\r\n },\r\n set: function (value) {\r\n if (this._displayMinorLines === value) {\r\n return;\r\n }\r\n this._displayMinorLines = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"displayMajorLines\", {\r\n /** Gets or sets a boolean indicating if major lines must be rendered (true by default)) */\r\n get: function () {\r\n return this._displayMajorLines;\r\n },\r\n set: function (value) {\r\n if (this._displayMajorLines === value) {\r\n return;\r\n }\r\n this._displayMajorLines = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"background\", {\r\n /** Gets or sets background color (Black by default) */\r\n get: function () {\r\n return this._background;\r\n },\r\n set: function (value) {\r\n if (this._background === value) {\r\n return;\r\n }\r\n this._background = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"cellWidth\", {\r\n /** Gets or sets the width of each cell (20 by default) */\r\n get: function () {\r\n return this._cellWidth;\r\n },\r\n set: function (value) {\r\n this._cellWidth = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"cellHeight\", {\r\n /** Gets or sets the height of each cell (20 by default) */\r\n get: function () {\r\n return this._cellHeight;\r\n },\r\n set: function (value) {\r\n this._cellHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"minorLineTickness\", {\r\n /** Gets or sets the tickness of minor lines (1 by default) */\r\n get: function () {\r\n return this._minorLineTickness;\r\n },\r\n set: function (value) {\r\n this._minorLineTickness = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"minorLineColor\", {\r\n /** Gets or sets the color of minor lines (DarkGray by default) */\r\n get: function () {\r\n return this._minorLineColor;\r\n },\r\n set: function (value) {\r\n this._minorLineColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"majorLineTickness\", {\r\n /** Gets or sets the tickness of major lines (2 by default) */\r\n get: function () {\r\n return this._majorLineTickness;\r\n },\r\n set: function (value) {\r\n this._majorLineTickness = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"majorLineColor\", {\r\n /** Gets or sets the color of major lines (White by default) */\r\n get: function () {\r\n return this._majorLineColor;\r\n },\r\n set: function (value) {\r\n this._majorLineColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"majorLineFrequency\", {\r\n /** Gets or sets the frequency of major lines (default is 1 every 5 minor lines)*/\r\n get: function () {\r\n return this._majorLineFrequency;\r\n },\r\n set: function (value) {\r\n this._majorLineFrequency = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n DisplayGrid.prototype._draw = function (context, invalidatedRectangle) {\r\n context.save();\r\n this._applyStates(context);\r\n if (this._isEnabled) {\r\n if (this._background) {\r\n context.fillStyle = this._background;\r\n context.fillRect(this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n }\r\n var cellCountX = this._currentMeasure.width / this._cellWidth;\r\n var cellCountY = this._currentMeasure.height / this._cellHeight;\r\n // Minor lines\r\n var left = this._currentMeasure.left + this._currentMeasure.width / 2;\r\n var top_1 = this._currentMeasure.top + this._currentMeasure.height / 2;\r\n if (this._displayMinorLines) {\r\n context.strokeStyle = this._minorLineColor;\r\n context.lineWidth = this._minorLineTickness;\r\n for (var x = -cellCountX / 2; x < cellCountX / 2; x++) {\r\n var cellX = left + x * this.cellWidth;\r\n context.beginPath();\r\n context.moveTo(cellX, this._currentMeasure.top);\r\n context.lineTo(cellX, this._currentMeasure.top + this._currentMeasure.height);\r\n context.stroke();\r\n }\r\n for (var y = -cellCountY / 2; y < cellCountY / 2; y++) {\r\n var cellY = top_1 + y * this.cellHeight;\r\n context.beginPath();\r\n context.moveTo(this._currentMeasure.left, cellY);\r\n context.lineTo(this._currentMeasure.left + this._currentMeasure.width, cellY);\r\n context.stroke();\r\n }\r\n }\r\n // Major lines\r\n if (this._displayMajorLines) {\r\n context.strokeStyle = this._majorLineColor;\r\n context.lineWidth = this._majorLineTickness;\r\n for (var x = -cellCountX / 2 + this._majorLineFrequency; x < cellCountX / 2; x += this._majorLineFrequency) {\r\n var cellX = left + x * this.cellWidth;\r\n context.beginPath();\r\n context.moveTo(cellX, this._currentMeasure.top);\r\n context.lineTo(cellX, this._currentMeasure.top + this._currentMeasure.height);\r\n context.stroke();\r\n }\r\n for (var y = -cellCountY / 2 + this._majorLineFrequency; y < cellCountY / 2; y += this._majorLineFrequency) {\r\n var cellY = top_1 + y * this.cellHeight;\r\n context.moveTo(this._currentMeasure.left, cellY);\r\n context.lineTo(this._currentMeasure.left + this._currentMeasure.width, cellY);\r\n context.closePath();\r\n context.stroke();\r\n }\r\n }\r\n }\r\n context.restore();\r\n };\r\n DisplayGrid.prototype._getTypeName = function () {\r\n return \"DisplayGrid\";\r\n };\r\n return DisplayGrid;\r\n}(Control));\r\nexport { DisplayGrid };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.DisplayGrid\"] = DisplayGrid;\r\n//# sourceMappingURL=displayGrid.js.map","import { __extends } from \"tslib\";\r\nimport { BaseSlider } from \"./baseSlider\";\r\nimport { Measure } from \"../../measure\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create slider controls based on images\r\n */\r\nvar ImageBasedSlider = /** @class */ (function (_super) {\r\n __extends(ImageBasedSlider, _super);\r\n /**\r\n * Creates a new ImageBasedSlider\r\n * @param name defines the control name\r\n */\r\n function ImageBasedSlider(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._tempMeasure = new Measure(0, 0, 0, 0);\r\n return _this;\r\n }\r\n Object.defineProperty(ImageBasedSlider.prototype, \"displayThumb\", {\r\n get: function () {\r\n return this._displayThumb && this.thumbImage != null;\r\n },\r\n set: function (value) {\r\n if (this._displayThumb === value) {\r\n return;\r\n }\r\n this._displayThumb = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageBasedSlider.prototype, \"backgroundImage\", {\r\n /**\r\n * Gets or sets the image used to render the background\r\n */\r\n get: function () {\r\n return this._backgroundImage;\r\n },\r\n set: function (value) {\r\n var _this = this;\r\n if (this._backgroundImage === value) {\r\n return;\r\n }\r\n this._backgroundImage = value;\r\n if (value && !value.isLoaded) {\r\n value.onImageLoadedObservable.addOnce(function () { return _this._markAsDirty(); });\r\n }\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageBasedSlider.prototype, \"valueBarImage\", {\r\n /**\r\n * Gets or sets the image used to render the value bar\r\n */\r\n get: function () {\r\n return this._valueBarImage;\r\n },\r\n set: function (value) {\r\n var _this = this;\r\n if (this._valueBarImage === value) {\r\n return;\r\n }\r\n this._valueBarImage = value;\r\n if (value && !value.isLoaded) {\r\n value.onImageLoadedObservable.addOnce(function () { return _this._markAsDirty(); });\r\n }\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageBasedSlider.prototype, \"thumbImage\", {\r\n /**\r\n * Gets or sets the image used to render the thumb\r\n */\r\n get: function () {\r\n return this._thumbImage;\r\n },\r\n set: function (value) {\r\n var _this = this;\r\n if (this._thumbImage === value) {\r\n return;\r\n }\r\n this._thumbImage = value;\r\n if (value && !value.isLoaded) {\r\n value.onImageLoadedObservable.addOnce(function () { return _this._markAsDirty(); });\r\n }\r\n this._markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n ImageBasedSlider.prototype._getTypeName = function () {\r\n return \"ImageBasedSlider\";\r\n };\r\n ImageBasedSlider.prototype._draw = function (context, invalidatedRectangle) {\r\n context.save();\r\n this._applyStates(context);\r\n this._prepareRenderingData(\"rectangle\");\r\n var thumbPosition = this._getThumbPosition();\r\n var left = this._renderLeft;\r\n var top = this._renderTop;\r\n var width = this._renderWidth;\r\n var height = this._renderHeight;\r\n // Background\r\n if (this._backgroundImage) {\r\n this._tempMeasure.copyFromFloats(left, top, width, height);\r\n if (this.isThumbClamped && this.displayThumb) {\r\n if (this.isVertical) {\r\n this._tempMeasure.height += this._effectiveThumbThickness;\r\n }\r\n else {\r\n this._tempMeasure.width += this._effectiveThumbThickness;\r\n }\r\n }\r\n this._backgroundImage._currentMeasure.copyFrom(this._tempMeasure);\r\n this._backgroundImage._draw(context);\r\n }\r\n // Bar\r\n if (this._valueBarImage) {\r\n if (this.isVertical) {\r\n if (this.isThumbClamped && this.displayThumb) {\r\n this._tempMeasure.copyFromFloats(left, top + thumbPosition, width, height - thumbPosition + this._effectiveThumbThickness);\r\n }\r\n else {\r\n this._tempMeasure.copyFromFloats(left, top + thumbPosition, width, height - thumbPosition);\r\n }\r\n }\r\n else {\r\n if (this.isThumbClamped && this.displayThumb) {\r\n this._tempMeasure.copyFromFloats(left, top, thumbPosition + this._effectiveThumbThickness / 2, height);\r\n }\r\n else {\r\n this._tempMeasure.copyFromFloats(left, top, thumbPosition, height);\r\n }\r\n }\r\n this._valueBarImage._currentMeasure.copyFrom(this._tempMeasure);\r\n this._valueBarImage._draw(context);\r\n }\r\n // Thumb\r\n if (this.displayThumb) {\r\n if (this.isVertical) {\r\n this._tempMeasure.copyFromFloats(left - this._effectiveBarOffset, this._currentMeasure.top + thumbPosition, this._currentMeasure.width, this._effectiveThumbThickness);\r\n }\r\n else {\r\n this._tempMeasure.copyFromFloats(this._currentMeasure.left + thumbPosition, this._currentMeasure.top, this._effectiveThumbThickness, this._currentMeasure.height);\r\n }\r\n this._thumbImage._currentMeasure.copyFrom(this._tempMeasure);\r\n this._thumbImage._draw(context);\r\n }\r\n context.restore();\r\n };\r\n return ImageBasedSlider;\r\n}(BaseSlider));\r\nexport { ImageBasedSlider };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.ImageBasedSlider\"] = ImageBasedSlider;\r\n//# sourceMappingURL=imageBasedSlider.js.map","import { Control } from \"./control\";\r\nimport { StackPanel } from \"./stackPanel\";\r\nimport { TextBlock } from \"./textBlock\";\r\n/**\r\n * Forcing an export so that this code will execute\r\n * @hidden\r\n */\r\nvar name = \"Statics\";\r\nexport { name };\r\n/**\r\n * Creates a stack panel that can be used to render headers\r\n * @param control defines the control to associate with the header\r\n * @param text defines the text of the header\r\n * @param size defines the size of the header\r\n * @param options defines options used to configure the header\r\n * @returns a new StackPanel\r\n */\r\nControl.AddHeader = function (control, text, size, options) {\r\n var panel = new StackPanel(\"panel\");\r\n var isHorizontal = options ? options.isHorizontal : true;\r\n var controlFirst = options ? options.controlFirst : true;\r\n panel.isVertical = !isHorizontal;\r\n var header = new TextBlock(\"header\");\r\n header.text = text;\r\n header.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n if (isHorizontal) {\r\n header.width = size;\r\n }\r\n else {\r\n header.height = size;\r\n }\r\n if (controlFirst) {\r\n panel.addControl(control);\r\n panel.addControl(header);\r\n header.paddingLeft = \"5px\";\r\n }\r\n else {\r\n panel.addControl(header);\r\n panel.addControl(control);\r\n header.paddingRight = \"5px\";\r\n }\r\n header.shadowBlur = control.shadowBlur;\r\n header.shadowColor = control.shadowColor;\r\n header.shadowOffsetX = control.shadowOffsetX;\r\n header.shadowOffsetY = control.shadowOffsetY;\r\n return panel;\r\n};\r\n//# sourceMappingURL=statics.js.map","import { SceneComponentConstants } from \"../sceneComponent\";\r\n/**\r\n * Defines the layer scene component responsible to manage any layers\r\n * in a given scene.\r\n */\r\nvar LayerSceneComponent = /** @class */ (function () {\r\n /**\r\n * Creates a new instance of the component for the given scene\r\n * @param scene Defines the scene to register the component in\r\n */\r\n function LayerSceneComponent(scene) {\r\n /**\r\n * The component name helpfull to identify the component in the list of scene components.\r\n */\r\n this.name = SceneComponentConstants.NAME_LAYER;\r\n this.scene = scene;\r\n this._engine = scene.getEngine();\r\n scene.layers = new Array();\r\n }\r\n /**\r\n * Registers the component in a given scene\r\n */\r\n LayerSceneComponent.prototype.register = function () {\r\n this.scene._beforeCameraDrawStage.registerStep(SceneComponentConstants.STEP_BEFORECAMERADRAW_LAYER, this, this._drawCameraBackground);\r\n this.scene._afterCameraDrawStage.registerStep(SceneComponentConstants.STEP_AFTERCAMERADRAW_LAYER, this, this._drawCameraForeground);\r\n this.scene._beforeRenderTargetDrawStage.registerStep(SceneComponentConstants.STEP_BEFORERENDERTARGETDRAW_LAYER, this, this._drawRenderTargetBackground);\r\n this.scene._afterRenderTargetDrawStage.registerStep(SceneComponentConstants.STEP_AFTERRENDERTARGETDRAW_LAYER, this, this._drawRenderTargetForeground);\r\n };\r\n /**\r\n * Rebuilds the elements related to this component in case of\r\n * context lost for instance.\r\n */\r\n LayerSceneComponent.prototype.rebuild = function () {\r\n var layers = this.scene.layers;\r\n for (var _i = 0, layers_1 = layers; _i < layers_1.length; _i++) {\r\n var layer = layers_1[_i];\r\n layer._rebuild();\r\n }\r\n };\r\n /**\r\n * Disposes the component and the associated ressources.\r\n */\r\n LayerSceneComponent.prototype.dispose = function () {\r\n var layers = this.scene.layers;\r\n while (layers.length) {\r\n layers[0].dispose();\r\n }\r\n };\r\n LayerSceneComponent.prototype._draw = function (predicate) {\r\n var layers = this.scene.layers;\r\n if (layers.length) {\r\n this._engine.setDepthBuffer(false);\r\n for (var _i = 0, layers_2 = layers; _i < layers_2.length; _i++) {\r\n var layer = layers_2[_i];\r\n if (predicate(layer)) {\r\n layer.render();\r\n }\r\n }\r\n this._engine.setDepthBuffer(true);\r\n }\r\n };\r\n LayerSceneComponent.prototype._drawCameraPredicate = function (layer, isBackground, cameraLayerMask) {\r\n return !layer.renderOnlyInRenderTargetTextures &&\r\n layer.isBackground === isBackground &&\r\n ((layer.layerMask & cameraLayerMask) !== 0);\r\n };\r\n LayerSceneComponent.prototype._drawCameraBackground = function (camera) {\r\n var _this = this;\r\n this._draw(function (layer) {\r\n return _this._drawCameraPredicate(layer, true, camera.layerMask);\r\n });\r\n };\r\n LayerSceneComponent.prototype._drawCameraForeground = function (camera) {\r\n var _this = this;\r\n this._draw(function (layer) {\r\n return _this._drawCameraPredicate(layer, false, camera.layerMask);\r\n });\r\n };\r\n LayerSceneComponent.prototype._drawRenderTargetPredicate = function (layer, isBackground, cameraLayerMask, renderTargetTexture) {\r\n return (layer.renderTargetTextures.length > 0) &&\r\n layer.isBackground === isBackground &&\r\n (layer.renderTargetTextures.indexOf(renderTargetTexture) > -1) &&\r\n ((layer.layerMask & cameraLayerMask) !== 0);\r\n };\r\n LayerSceneComponent.prototype._drawRenderTargetBackground = function (renderTarget) {\r\n var _this = this;\r\n this._draw(function (layer) {\r\n return _this._drawRenderTargetPredicate(layer, true, _this.scene.activeCamera.layerMask, renderTarget);\r\n });\r\n };\r\n LayerSceneComponent.prototype._drawRenderTargetForeground = function (renderTarget) {\r\n var _this = this;\r\n this._draw(function (layer) {\r\n return _this._drawRenderTargetPredicate(layer, false, _this.scene.activeCamera.layerMask, renderTarget);\r\n });\r\n };\r\n /**\r\n * Adds all the elements from the container to the scene\r\n * @param container the container holding the elements\r\n */\r\n LayerSceneComponent.prototype.addFromContainer = function (container) {\r\n var _this = this;\r\n if (!container.layers) {\r\n return;\r\n }\r\n container.layers.forEach(function (layer) {\r\n _this.scene.layers.push(layer);\r\n });\r\n };\r\n /**\r\n * Removes all the elements in the container from the scene\r\n * @param container contains the elements to remove\r\n * @param dispose if the removed element should be disposed (default: false)\r\n */\r\n LayerSceneComponent.prototype.removeFromContainer = function (container, dispose) {\r\n var _this = this;\r\n if (dispose === void 0) { dispose = false; }\r\n if (!container.layers) {\r\n return;\r\n }\r\n container.layers.forEach(function (layer) {\r\n var index = _this.scene.layers.indexOf(layer);\r\n if (index !== -1) {\r\n _this.scene.layers.splice(index, 1);\r\n }\r\n if (dispose) {\r\n layer.dispose();\r\n }\r\n });\r\n };\r\n return LayerSceneComponent;\r\n}());\r\nexport { LayerSceneComponent };\r\n//# sourceMappingURL=layerSceneComponent.js.map","import { Effect } from \"../Materials/effect\";\r\nimport \"./ShadersInclude/helperFunctions\";\r\nvar name = 'layerPixelShader';\r\nvar shader = \"\\nvarying vec2 vUV;\\nuniform sampler2D textureSampler;\\n\\nuniform vec4 color;\\n\\n#include\\nvoid main(void) {\\nvec4 baseColor=texture2D(textureSampler,vUV);\\n#ifdef LINEAR\\nbaseColor.rgb=toGammaSpace(baseColor.rgb);\\n#endif\\n#ifdef ALPHATEST\\nif (baseColor.a<0.4)\\ndiscard;\\n#endif\\ngl_FragColor=baseColor*color;\\n}\";\r\nEffect.ShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var layerPixelShader = { name: name, shader: shader };\r\n//# sourceMappingURL=layer.fragment.js.map","import { Effect } from \"../Materials/effect\";\r\nvar name = 'layerVertexShader';\r\nvar shader = \"\\nattribute vec2 position;\\n\\nuniform vec2 scale;\\nuniform vec2 offset;\\nuniform mat4 textureMatrix;\\n\\nvarying vec2 vUV;\\nconst vec2 madd=vec2(0.5,0.5);\\nvoid main(void) {\\nvec2 shiftedPosition=position*scale+offset;\\nvUV=vec2(textureMatrix*vec4(shiftedPosition*madd+madd,1.0,0.0));\\ngl_Position=vec4(shiftedPosition,0.0,1.0);\\n}\";\r\nEffect.ShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var layerVertexShader = { name: name, shader: shader };\r\n//# sourceMappingURL=layer.vertex.js.map","import { Observable } from \"../Misc/observable\";\r\nimport { Vector2 } from \"../Maths/math.vector\";\r\nimport { Color4 } from '../Maths/math.color';\r\nimport { EngineStore } from \"../Engines/engineStore\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { Material } from \"../Materials/material\";\r\nimport { Texture } from \"../Materials/Textures/texture\";\r\nimport { SceneComponentConstants } from \"../sceneComponent\";\r\nimport { LayerSceneComponent } from \"./layerSceneComponent\";\r\nimport \"../Shaders/layer.fragment\";\r\nimport \"../Shaders/layer.vertex\";\r\n/**\r\n * This represents a full screen 2d layer.\r\n * This can be useful to display a picture in the background of your scene for instance.\r\n * @see https://www.babylonjs-playground.com/#08A2BS#1\r\n */\r\nvar Layer = /** @class */ (function () {\r\n /**\r\n * Instantiates a new layer.\r\n * This represents a full screen 2d layer.\r\n * This can be useful to display a picture in the background of your scene for instance.\r\n * @see https://www.babylonjs-playground.com/#08A2BS#1\r\n * @param name Define the name of the layer in the scene\r\n * @param imgUrl Define the url of the texture to display in the layer\r\n * @param scene Define the scene the layer belongs to\r\n * @param isBackground Defines whether the layer is displayed in front or behind the scene\r\n * @param color Defines a color for the layer\r\n */\r\n function Layer(\r\n /**\r\n * Define the name of the layer.\r\n */\r\n name, imgUrl, scene, isBackground, color) {\r\n this.name = name;\r\n /**\r\n * Define the scale of the layer in order to zoom in out of the texture.\r\n */\r\n this.scale = new Vector2(1, 1);\r\n /**\r\n * Define an offset for the layer in order to shift the texture.\r\n */\r\n this.offset = new Vector2(0, 0);\r\n /**\r\n * Define the alpha blending mode used in the layer in case the texture or color has an alpha.\r\n */\r\n this.alphaBlendingMode = 2;\r\n /**\r\n * Define a mask to restrict the layer to only some of the scene cameras.\r\n */\r\n this.layerMask = 0x0FFFFFFF;\r\n /**\r\n * Define the list of render target the layer is visible into.\r\n */\r\n this.renderTargetTextures = [];\r\n /**\r\n * Define if the layer is only used in renderTarget or if it also\r\n * renders in the main frame buffer of the canvas.\r\n */\r\n this.renderOnlyInRenderTargetTextures = false;\r\n this._vertexBuffers = {};\r\n /**\r\n * An event triggered when the layer is disposed.\r\n */\r\n this.onDisposeObservable = new Observable();\r\n /**\r\n * An event triggered before rendering the scene\r\n */\r\n this.onBeforeRenderObservable = new Observable();\r\n /**\r\n * An event triggered after rendering the scene\r\n */\r\n this.onAfterRenderObservable = new Observable();\r\n this.texture = imgUrl ? new Texture(imgUrl, scene, true) : null;\r\n this.isBackground = isBackground === undefined ? true : isBackground;\r\n this.color = color === undefined ? new Color4(1, 1, 1, 1) : color;\r\n this._scene = (scene || EngineStore.LastCreatedScene);\r\n var layerComponent = this._scene._getComponent(SceneComponentConstants.NAME_LAYER);\r\n if (!layerComponent) {\r\n layerComponent = new LayerSceneComponent(this._scene);\r\n this._scene._addComponent(layerComponent);\r\n }\r\n this._scene.layers.push(this);\r\n var engine = this._scene.getEngine();\r\n // VBO\r\n var vertices = [];\r\n vertices.push(1, 1);\r\n vertices.push(-1, 1);\r\n vertices.push(-1, -1);\r\n vertices.push(1, -1);\r\n var vertexBuffer = new VertexBuffer(engine, vertices, VertexBuffer.PositionKind, false, false, 2);\r\n this._vertexBuffers[VertexBuffer.PositionKind] = vertexBuffer;\r\n this._createIndexBuffer();\r\n }\r\n Object.defineProperty(Layer.prototype, \"onDispose\", {\r\n /**\r\n * Back compatibility with callback before the onDisposeObservable existed.\r\n * The set callback will be triggered when the layer has been disposed.\r\n */\r\n set: function (callback) {\r\n if (this._onDisposeObserver) {\r\n this.onDisposeObservable.remove(this._onDisposeObserver);\r\n }\r\n this._onDisposeObserver = this.onDisposeObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Layer.prototype, \"onBeforeRender\", {\r\n /**\r\n * Back compatibility with callback before the onBeforeRenderObservable existed.\r\n * The set callback will be triggered just before rendering the layer.\r\n */\r\n set: function (callback) {\r\n if (this._onBeforeRenderObserver) {\r\n this.onBeforeRenderObservable.remove(this._onBeforeRenderObserver);\r\n }\r\n this._onBeforeRenderObserver = this.onBeforeRenderObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Layer.prototype, \"onAfterRender\", {\r\n /**\r\n * Back compatibility with callback before the onAfterRenderObservable existed.\r\n * The set callback will be triggered just after rendering the layer.\r\n */\r\n set: function (callback) {\r\n if (this._onAfterRenderObserver) {\r\n this.onAfterRenderObservable.remove(this._onAfterRenderObserver);\r\n }\r\n this._onAfterRenderObserver = this.onAfterRenderObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Layer.prototype._createIndexBuffer = function () {\r\n var engine = this._scene.getEngine();\r\n // Indices\r\n var indices = [];\r\n indices.push(0);\r\n indices.push(1);\r\n indices.push(2);\r\n indices.push(0);\r\n indices.push(2);\r\n indices.push(3);\r\n this._indexBuffer = engine.createIndexBuffer(indices);\r\n };\r\n /** @hidden */\r\n Layer.prototype._rebuild = function () {\r\n var vb = this._vertexBuffers[VertexBuffer.PositionKind];\r\n if (vb) {\r\n vb._rebuild();\r\n }\r\n this._createIndexBuffer();\r\n };\r\n /**\r\n * Renders the layer in the scene.\r\n */\r\n Layer.prototype.render = function () {\r\n var engine = this._scene.getEngine();\r\n var defines = \"\";\r\n if (this.alphaTest) {\r\n defines = \"#define ALPHATEST\";\r\n }\r\n if (this.texture && !this.texture.gammaSpace) {\r\n defines += \"\\r\\n#define LINEAR\";\r\n }\r\n if (this._previousDefines !== defines) {\r\n this._previousDefines = defines;\r\n this._effect = engine.createEffect(\"layer\", [VertexBuffer.PositionKind], [\"textureMatrix\", \"color\", \"scale\", \"offset\"], [\"textureSampler\"], defines);\r\n }\r\n var currentEffect = this._effect;\r\n // Check\r\n if (!currentEffect || !currentEffect.isReady() || !this.texture || !this.texture.isReady()) {\r\n return;\r\n }\r\n var engine = this._scene.getEngine();\r\n this.onBeforeRenderObservable.notifyObservers(this);\r\n // Render\r\n engine.enableEffect(currentEffect);\r\n engine.setState(false);\r\n // Texture\r\n currentEffect.setTexture(\"textureSampler\", this.texture);\r\n currentEffect.setMatrix(\"textureMatrix\", this.texture.getTextureMatrix());\r\n // Color\r\n currentEffect.setFloat4(\"color\", this.color.r, this.color.g, this.color.b, this.color.a);\r\n // Scale / offset\r\n currentEffect.setVector2(\"offset\", this.offset);\r\n currentEffect.setVector2(\"scale\", this.scale);\r\n // VBOs\r\n engine.bindBuffers(this._vertexBuffers, this._indexBuffer, currentEffect);\r\n // Draw order\r\n if (!this.alphaTest) {\r\n engine.setAlphaMode(this.alphaBlendingMode);\r\n engine.drawElementsType(Material.TriangleFillMode, 0, 6);\r\n engine.setAlphaMode(0);\r\n }\r\n else {\r\n engine.drawElementsType(Material.TriangleFillMode, 0, 6);\r\n }\r\n this.onAfterRenderObservable.notifyObservers(this);\r\n };\r\n /**\r\n * Disposes and releases the associated ressources.\r\n */\r\n Layer.prototype.dispose = function () {\r\n var vertexBuffer = this._vertexBuffers[VertexBuffer.PositionKind];\r\n if (vertexBuffer) {\r\n vertexBuffer.dispose();\r\n this._vertexBuffers[VertexBuffer.PositionKind] = null;\r\n }\r\n if (this._indexBuffer) {\r\n this._scene.getEngine()._releaseBuffer(this._indexBuffer);\r\n this._indexBuffer = null;\r\n }\r\n if (this.texture) {\r\n this.texture.dispose();\r\n this.texture = null;\r\n }\r\n // Clean RTT list\r\n this.renderTargetTextures = [];\r\n // Remove from scene\r\n var index = this._scene.layers.indexOf(this);\r\n this._scene.layers.splice(index, 1);\r\n // Callback\r\n this.onDisposeObservable.notifyObservers(this);\r\n this.onDisposeObservable.clear();\r\n this.onAfterRenderObservable.clear();\r\n this.onBeforeRenderObservable.clear();\r\n };\r\n return Layer;\r\n}());\r\nexport { Layer };\r\n//# sourceMappingURL=layer.js.map","import { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { ValueAndUnit } from \"./valueAndUnit\";\r\n/**\r\n * Define a style used by control to automatically setup properties based on a template.\r\n * Only support font related properties so far\r\n */\r\nvar Style = /** @class */ (function () {\r\n /**\r\n * Creates a new style object\r\n * @param host defines the AdvancedDynamicTexture which hosts this style\r\n */\r\n function Style(host) {\r\n this._fontFamily = \"Arial\";\r\n this._fontStyle = \"\";\r\n this._fontWeight = \"\";\r\n /** @hidden */\r\n this._fontSize = new ValueAndUnit(18, ValueAndUnit.UNITMODE_PIXEL, false);\r\n /**\r\n * Observable raised when the style values are changed\r\n */\r\n this.onChangedObservable = new Observable();\r\n this._host = host;\r\n }\r\n Object.defineProperty(Style.prototype, \"fontSize\", {\r\n /**\r\n * Gets or sets the font size\r\n */\r\n get: function () {\r\n return this._fontSize.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._fontSize.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._fontSize.fromString(value)) {\r\n this.onChangedObservable.notifyObservers(this);\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Style.prototype, \"fontFamily\", {\r\n /**\r\n * Gets or sets the font family\r\n */\r\n get: function () {\r\n return this._fontFamily;\r\n },\r\n set: function (value) {\r\n if (this._fontFamily === value) {\r\n return;\r\n }\r\n this._fontFamily = value;\r\n this.onChangedObservable.notifyObservers(this);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Style.prototype, \"fontStyle\", {\r\n /**\r\n * Gets or sets the font style\r\n */\r\n get: function () {\r\n return this._fontStyle;\r\n },\r\n set: function (value) {\r\n if (this._fontStyle === value) {\r\n return;\r\n }\r\n this._fontStyle = value;\r\n this.onChangedObservable.notifyObservers(this);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Style.prototype, \"fontWeight\", {\r\n /** Gets or sets font weight */\r\n get: function () {\r\n return this._fontWeight;\r\n },\r\n set: function (value) {\r\n if (this._fontWeight === value) {\r\n return;\r\n }\r\n this._fontWeight = value;\r\n this.onChangedObservable.notifyObservers(this);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** Dispose all associated resources */\r\n Style.prototype.dispose = function () {\r\n this.onChangedObservable.clear();\r\n };\r\n return Style;\r\n}());\r\nexport { Style };\r\n//# sourceMappingURL=style.js.map","/** Defines the cross module used constants to avoid circular dependncies */\r\nvar Constants = /** @class */ (function () {\r\n function Constants() {\r\n }\r\n /** Defines that alpha blending is disabled */\r\n Constants.ALPHA_DISABLE = 0;\r\n /** Defines that alpha blending is SRC ALPHA * SRC + DEST */\r\n Constants.ALPHA_ADD = 1;\r\n /** Defines that alpha blending is SRC ALPHA * SRC + (1 - SRC ALPHA) * DEST */\r\n Constants.ALPHA_COMBINE = 2;\r\n /** Defines that alpha blending is DEST - SRC * DEST */\r\n Constants.ALPHA_SUBTRACT = 3;\r\n /** Defines that alpha blending is SRC * DEST */\r\n Constants.ALPHA_MULTIPLY = 4;\r\n /** Defines that alpha blending is SRC ALPHA * SRC + (1 - SRC) * DEST */\r\n Constants.ALPHA_MAXIMIZED = 5;\r\n /** Defines that alpha blending is SRC + DEST */\r\n Constants.ALPHA_ONEONE = 6;\r\n /** Defines that alpha blending is SRC + (1 - SRC ALPHA) * DEST */\r\n Constants.ALPHA_PREMULTIPLIED = 7;\r\n /**\r\n * Defines that alpha blending is SRC + (1 - SRC ALPHA) * DEST\r\n * Alpha will be set to (1 - SRC ALPHA) * DEST ALPHA\r\n */\r\n Constants.ALPHA_PREMULTIPLIED_PORTERDUFF = 8;\r\n /** Defines that alpha blending is CST * SRC + (1 - CST) * DEST */\r\n Constants.ALPHA_INTERPOLATE = 9;\r\n /**\r\n * Defines that alpha blending is SRC + (1 - SRC) * DEST\r\n * Alpha will be set to SRC ALPHA + (1 - SRC ALPHA) * DEST ALPHA\r\n */\r\n Constants.ALPHA_SCREENMODE = 10;\r\n /**\r\n * Defines that alpha blending is SRC + DST\r\n * Alpha will be set to SRC ALPHA + DST ALPHA\r\n */\r\n Constants.ALPHA_ONEONE_ONEONE = 11;\r\n /**\r\n * Defines that alpha blending is SRC * DST ALPHA + DST\r\n * Alpha will be set to 0\r\n */\r\n Constants.ALPHA_ALPHATOCOLOR = 12;\r\n /**\r\n * Defines that alpha blending is SRC * (1 - DST) + DST * (1 - SRC)\r\n */\r\n Constants.ALPHA_REVERSEONEMINUS = 13;\r\n /**\r\n * Defines that alpha blending is SRC + DST * (1 - SRC ALPHA)\r\n * Alpha will be set to SRC ALPHA + DST ALPHA * (1 - SRC ALPHA)\r\n */\r\n Constants.ALPHA_SRC_DSTONEMINUSSRCALPHA = 14;\r\n /**\r\n * Defines that alpha blending is SRC + DST\r\n * Alpha will be set to SRC ALPHA\r\n */\r\n Constants.ALPHA_ONEONE_ONEZERO = 15;\r\n /**\r\n * Defines that alpha blending is SRC * (1 - DST) + DST * (1 - SRC)\r\n * Alpha will be set to DST ALPHA\r\n */\r\n Constants.ALPHA_EXCLUSION = 16;\r\n /** Defines that alpha blending equation a SUM */\r\n Constants.ALPHA_EQUATION_ADD = 0;\r\n /** Defines that alpha blending equation a SUBSTRACTION */\r\n Constants.ALPHA_EQUATION_SUBSTRACT = 1;\r\n /** Defines that alpha blending equation a REVERSE SUBSTRACTION */\r\n Constants.ALPHA_EQUATION_REVERSE_SUBTRACT = 2;\r\n /** Defines that alpha blending equation a MAX operation */\r\n Constants.ALPHA_EQUATION_MAX = 3;\r\n /** Defines that alpha blending equation a MIN operation */\r\n Constants.ALPHA_EQUATION_MIN = 4;\r\n /**\r\n * Defines that alpha blending equation a DARKEN operation:\r\n * It takes the min of the src and sums the alpha channels.\r\n */\r\n Constants.ALPHA_EQUATION_DARKEN = 5;\r\n /** Defines that the ressource is not delayed*/\r\n Constants.DELAYLOADSTATE_NONE = 0;\r\n /** Defines that the ressource was successfully delay loaded */\r\n Constants.DELAYLOADSTATE_LOADED = 1;\r\n /** Defines that the ressource is currently delay loading */\r\n Constants.DELAYLOADSTATE_LOADING = 2;\r\n /** Defines that the ressource is delayed and has not started loading */\r\n Constants.DELAYLOADSTATE_NOTLOADED = 4;\r\n // Depht or Stencil test Constants.\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will never pass. i.e. Nothing will be drawn */\r\n Constants.NEVER = 0x0200;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will always pass. i.e. Pixels will be drawn in the order they are drawn */\r\n Constants.ALWAYS = 0x0207;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is less than the stored value */\r\n Constants.LESS = 0x0201;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is equals to the stored value */\r\n Constants.EQUAL = 0x0202;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is less than or equal to the stored value */\r\n Constants.LEQUAL = 0x0203;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is greater than the stored value */\r\n Constants.GREATER = 0x0204;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is greater than or equal to the stored value */\r\n Constants.GEQUAL = 0x0206;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is not equal to the stored value */\r\n Constants.NOTEQUAL = 0x0205;\r\n // Stencil Actions Constants.\r\n /** Passed to stencilOperation to specify that stencil value must be kept */\r\n Constants.KEEP = 0x1E00;\r\n /** Passed to stencilOperation to specify that stencil value must be replaced */\r\n Constants.REPLACE = 0x1E01;\r\n /** Passed to stencilOperation to specify that stencil value must be incremented */\r\n Constants.INCR = 0x1E02;\r\n /** Passed to stencilOperation to specify that stencil value must be decremented */\r\n Constants.DECR = 0x1E03;\r\n /** Passed to stencilOperation to specify that stencil value must be inverted */\r\n Constants.INVERT = 0x150A;\r\n /** Passed to stencilOperation to specify that stencil value must be incremented with wrapping */\r\n Constants.INCR_WRAP = 0x8507;\r\n /** Passed to stencilOperation to specify that stencil value must be decremented with wrapping */\r\n Constants.DECR_WRAP = 0x8508;\r\n /** Texture is not repeating outside of 0..1 UVs */\r\n Constants.TEXTURE_CLAMP_ADDRESSMODE = 0;\r\n /** Texture is repeating outside of 0..1 UVs */\r\n Constants.TEXTURE_WRAP_ADDRESSMODE = 1;\r\n /** Texture is repeating and mirrored */\r\n Constants.TEXTURE_MIRROR_ADDRESSMODE = 2;\r\n /** ALPHA */\r\n Constants.TEXTUREFORMAT_ALPHA = 0;\r\n /** LUMINANCE */\r\n Constants.TEXTUREFORMAT_LUMINANCE = 1;\r\n /** LUMINANCE_ALPHA */\r\n Constants.TEXTUREFORMAT_LUMINANCE_ALPHA = 2;\r\n /** RGB */\r\n Constants.TEXTUREFORMAT_RGB = 4;\r\n /** RGBA */\r\n Constants.TEXTUREFORMAT_RGBA = 5;\r\n /** RED */\r\n Constants.TEXTUREFORMAT_RED = 6;\r\n /** RED (2nd reference) */\r\n Constants.TEXTUREFORMAT_R = 6;\r\n /** RG */\r\n Constants.TEXTUREFORMAT_RG = 7;\r\n /** RED_INTEGER */\r\n Constants.TEXTUREFORMAT_RED_INTEGER = 8;\r\n /** RED_INTEGER (2nd reference) */\r\n Constants.TEXTUREFORMAT_R_INTEGER = 8;\r\n /** RG_INTEGER */\r\n Constants.TEXTUREFORMAT_RG_INTEGER = 9;\r\n /** RGB_INTEGER */\r\n Constants.TEXTUREFORMAT_RGB_INTEGER = 10;\r\n /** RGBA_INTEGER */\r\n Constants.TEXTUREFORMAT_RGBA_INTEGER = 11;\r\n /** UNSIGNED_BYTE */\r\n Constants.TEXTURETYPE_UNSIGNED_BYTE = 0;\r\n /** UNSIGNED_BYTE (2nd reference) */\r\n Constants.TEXTURETYPE_UNSIGNED_INT = 0;\r\n /** FLOAT */\r\n Constants.TEXTURETYPE_FLOAT = 1;\r\n /** HALF_FLOAT */\r\n Constants.TEXTURETYPE_HALF_FLOAT = 2;\r\n /** BYTE */\r\n Constants.TEXTURETYPE_BYTE = 3;\r\n /** SHORT */\r\n Constants.TEXTURETYPE_SHORT = 4;\r\n /** UNSIGNED_SHORT */\r\n Constants.TEXTURETYPE_UNSIGNED_SHORT = 5;\r\n /** INT */\r\n Constants.TEXTURETYPE_INT = 6;\r\n /** UNSIGNED_INT */\r\n Constants.TEXTURETYPE_UNSIGNED_INTEGER = 7;\r\n /** UNSIGNED_SHORT_4_4_4_4 */\r\n Constants.TEXTURETYPE_UNSIGNED_SHORT_4_4_4_4 = 8;\r\n /** UNSIGNED_SHORT_5_5_5_1 */\r\n Constants.TEXTURETYPE_UNSIGNED_SHORT_5_5_5_1 = 9;\r\n /** UNSIGNED_SHORT_5_6_5 */\r\n Constants.TEXTURETYPE_UNSIGNED_SHORT_5_6_5 = 10;\r\n /** UNSIGNED_INT_2_10_10_10_REV */\r\n Constants.TEXTURETYPE_UNSIGNED_INT_2_10_10_10_REV = 11;\r\n /** UNSIGNED_INT_24_8 */\r\n Constants.TEXTURETYPE_UNSIGNED_INT_24_8 = 12;\r\n /** UNSIGNED_INT_10F_11F_11F_REV */\r\n Constants.TEXTURETYPE_UNSIGNED_INT_10F_11F_11F_REV = 13;\r\n /** UNSIGNED_INT_5_9_9_9_REV */\r\n Constants.TEXTURETYPE_UNSIGNED_INT_5_9_9_9_REV = 14;\r\n /** FLOAT_32_UNSIGNED_INT_24_8_REV */\r\n Constants.TEXTURETYPE_FLOAT_32_UNSIGNED_INT_24_8_REV = 15;\r\n /** nearest is mag = nearest and min = nearest and no mip */\r\n Constants.TEXTURE_NEAREST_SAMPLINGMODE = 1;\r\n /** mag = nearest and min = nearest and mip = none */\r\n Constants.TEXTURE_NEAREST_NEAREST = 1;\r\n /** Bilinear is mag = linear and min = linear and no mip */\r\n Constants.TEXTURE_BILINEAR_SAMPLINGMODE = 2;\r\n /** mag = linear and min = linear and mip = none */\r\n Constants.TEXTURE_LINEAR_LINEAR = 2;\r\n /** Trilinear is mag = linear and min = linear and mip = linear */\r\n Constants.TEXTURE_TRILINEAR_SAMPLINGMODE = 3;\r\n /** Trilinear is mag = linear and min = linear and mip = linear */\r\n Constants.TEXTURE_LINEAR_LINEAR_MIPLINEAR = 3;\r\n /** mag = nearest and min = nearest and mip = nearest */\r\n Constants.TEXTURE_NEAREST_NEAREST_MIPNEAREST = 4;\r\n /** mag = nearest and min = linear and mip = nearest */\r\n Constants.TEXTURE_NEAREST_LINEAR_MIPNEAREST = 5;\r\n /** mag = nearest and min = linear and mip = linear */\r\n Constants.TEXTURE_NEAREST_LINEAR_MIPLINEAR = 6;\r\n /** mag = nearest and min = linear and mip = none */\r\n Constants.TEXTURE_NEAREST_LINEAR = 7;\r\n /** nearest is mag = nearest and min = nearest and mip = linear */\r\n Constants.TEXTURE_NEAREST_NEAREST_MIPLINEAR = 8;\r\n /** mag = linear and min = nearest and mip = nearest */\r\n Constants.TEXTURE_LINEAR_NEAREST_MIPNEAREST = 9;\r\n /** mag = linear and min = nearest and mip = linear */\r\n Constants.TEXTURE_LINEAR_NEAREST_MIPLINEAR = 10;\r\n /** Bilinear is mag = linear and min = linear and mip = nearest */\r\n Constants.TEXTURE_LINEAR_LINEAR_MIPNEAREST = 11;\r\n /** mag = linear and min = nearest and mip = none */\r\n Constants.TEXTURE_LINEAR_NEAREST = 12;\r\n /** Explicit coordinates mode */\r\n Constants.TEXTURE_EXPLICIT_MODE = 0;\r\n /** Spherical coordinates mode */\r\n Constants.TEXTURE_SPHERICAL_MODE = 1;\r\n /** Planar coordinates mode */\r\n Constants.TEXTURE_PLANAR_MODE = 2;\r\n /** Cubic coordinates mode */\r\n Constants.TEXTURE_CUBIC_MODE = 3;\r\n /** Projection coordinates mode */\r\n Constants.TEXTURE_PROJECTION_MODE = 4;\r\n /** Skybox coordinates mode */\r\n Constants.TEXTURE_SKYBOX_MODE = 5;\r\n /** Inverse Cubic coordinates mode */\r\n Constants.TEXTURE_INVCUBIC_MODE = 6;\r\n /** Equirectangular coordinates mode */\r\n Constants.TEXTURE_EQUIRECTANGULAR_MODE = 7;\r\n /** Equirectangular Fixed coordinates mode */\r\n Constants.TEXTURE_FIXED_EQUIRECTANGULAR_MODE = 8;\r\n /** Equirectangular Fixed Mirrored coordinates mode */\r\n Constants.TEXTURE_FIXED_EQUIRECTANGULAR_MIRRORED_MODE = 9;\r\n // Texture rescaling mode\r\n /** Defines that texture rescaling will use a floor to find the closer power of 2 size */\r\n Constants.SCALEMODE_FLOOR = 1;\r\n /** Defines that texture rescaling will look for the nearest power of 2 size */\r\n Constants.SCALEMODE_NEAREST = 2;\r\n /** Defines that texture rescaling will use a ceil to find the closer power of 2 size */\r\n Constants.SCALEMODE_CEILING = 3;\r\n /**\r\n * The dirty texture flag value\r\n */\r\n Constants.MATERIAL_TextureDirtyFlag = 1;\r\n /**\r\n * The dirty light flag value\r\n */\r\n Constants.MATERIAL_LightDirtyFlag = 2;\r\n /**\r\n * The dirty fresnel flag value\r\n */\r\n Constants.MATERIAL_FresnelDirtyFlag = 4;\r\n /**\r\n * The dirty attribute flag value\r\n */\r\n Constants.MATERIAL_AttributesDirtyFlag = 8;\r\n /**\r\n * The dirty misc flag value\r\n */\r\n Constants.MATERIAL_MiscDirtyFlag = 16;\r\n /**\r\n * The all dirty flag value\r\n */\r\n Constants.MATERIAL_AllDirtyFlag = 31;\r\n /**\r\n * Returns the triangle fill mode\r\n */\r\n Constants.MATERIAL_TriangleFillMode = 0;\r\n /**\r\n * Returns the wireframe mode\r\n */\r\n Constants.MATERIAL_WireFrameFillMode = 1;\r\n /**\r\n * Returns the point fill mode\r\n */\r\n Constants.MATERIAL_PointFillMode = 2;\r\n /**\r\n * Returns the point list draw mode\r\n */\r\n Constants.MATERIAL_PointListDrawMode = 3;\r\n /**\r\n * Returns the line list draw mode\r\n */\r\n Constants.MATERIAL_LineListDrawMode = 4;\r\n /**\r\n * Returns the line loop draw mode\r\n */\r\n Constants.MATERIAL_LineLoopDrawMode = 5;\r\n /**\r\n * Returns the line strip draw mode\r\n */\r\n Constants.MATERIAL_LineStripDrawMode = 6;\r\n /**\r\n * Returns the triangle strip draw mode\r\n */\r\n Constants.MATERIAL_TriangleStripDrawMode = 7;\r\n /**\r\n * Returns the triangle fan draw mode\r\n */\r\n Constants.MATERIAL_TriangleFanDrawMode = 8;\r\n /**\r\n * Stores the clock-wise side orientation\r\n */\r\n Constants.MATERIAL_ClockWiseSideOrientation = 0;\r\n /**\r\n * Stores the counter clock-wise side orientation\r\n */\r\n Constants.MATERIAL_CounterClockWiseSideOrientation = 1;\r\n /**\r\n * Nothing\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_NothingTrigger = 0;\r\n /**\r\n * On pick\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnPickTrigger = 1;\r\n /**\r\n * On left pick\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnLeftPickTrigger = 2;\r\n /**\r\n * On right pick\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnRightPickTrigger = 3;\r\n /**\r\n * On center pick\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnCenterPickTrigger = 4;\r\n /**\r\n * On pick down\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnPickDownTrigger = 5;\r\n /**\r\n * On double pick\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnDoublePickTrigger = 6;\r\n /**\r\n * On pick up\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnPickUpTrigger = 7;\r\n /**\r\n * On pick out.\r\n * This trigger will only be raised if you also declared a OnPickDown\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnPickOutTrigger = 16;\r\n /**\r\n * On long press\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnLongPressTrigger = 8;\r\n /**\r\n * On pointer over\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnPointerOverTrigger = 9;\r\n /**\r\n * On pointer out\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnPointerOutTrigger = 10;\r\n /**\r\n * On every frame\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnEveryFrameTrigger = 11;\r\n /**\r\n * On intersection enter\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnIntersectionEnterTrigger = 12;\r\n /**\r\n * On intersection exit\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnIntersectionExitTrigger = 13;\r\n /**\r\n * On key down\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnKeyDownTrigger = 14;\r\n /**\r\n * On key up\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnKeyUpTrigger = 15;\r\n /**\r\n * Billboard mode will only apply to Y axis\r\n */\r\n Constants.PARTICLES_BILLBOARDMODE_Y = 2;\r\n /**\r\n * Billboard mode will apply to all axes\r\n */\r\n Constants.PARTICLES_BILLBOARDMODE_ALL = 7;\r\n /**\r\n * Special billboard mode where the particle will be biilboard to the camera but rotated to align with direction\r\n */\r\n Constants.PARTICLES_BILLBOARDMODE_STRETCHED = 8;\r\n /** Default culling strategy : this is an exclusion test and it's the more accurate.\r\n * Test order :\r\n * Is the bounding sphere outside the frustum ?\r\n * If not, are the bounding box vertices outside the frustum ?\r\n * It not, then the cullable object is in the frustum.\r\n */\r\n Constants.MESHES_CULLINGSTRATEGY_STANDARD = 0;\r\n /** Culling strategy : Bounding Sphere Only.\r\n * This is an exclusion test. It's faster than the standard strategy because the bounding box is not tested.\r\n * It's also less accurate than the standard because some not visible objects can still be selected.\r\n * Test : is the bounding sphere outside the frustum ?\r\n * If not, then the cullable object is in the frustum.\r\n */\r\n Constants.MESHES_CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY = 1;\r\n /** Culling strategy : Optimistic Inclusion.\r\n * This in an inclusion test first, then the standard exclusion test.\r\n * This can be faster when a cullable object is expected to be almost always in the camera frustum.\r\n * This could also be a little slower than the standard test when the tested object center is not the frustum but one of its bounding box vertex is still inside.\r\n * Anyway, it's as accurate as the standard strategy.\r\n * Test :\r\n * Is the cullable object bounding sphere center in the frustum ?\r\n * If not, apply the default culling strategy.\r\n */\r\n Constants.MESHES_CULLINGSTRATEGY_OPTIMISTIC_INCLUSION = 2;\r\n /** Culling strategy : Optimistic Inclusion then Bounding Sphere Only.\r\n * This in an inclusion test first, then the bounding sphere only exclusion test.\r\n * This can be the fastest test when a cullable object is expected to be almost always in the camera frustum.\r\n * This could also be a little slower than the BoundingSphereOnly strategy when the tested object center is not in the frustum but its bounding sphere still intersects it.\r\n * It's less accurate than the standard strategy and as accurate as the BoundingSphereOnly strategy.\r\n * Test :\r\n * Is the cullable object bounding sphere center in the frustum ?\r\n * If not, apply the Bounding Sphere Only strategy. No Bounding Box is tested here.\r\n */\r\n Constants.MESHES_CULLINGSTRATEGY_OPTIMISTIC_INCLUSION_THEN_BSPHERE_ONLY = 3;\r\n /**\r\n * No logging while loading\r\n */\r\n Constants.SCENELOADER_NO_LOGGING = 0;\r\n /**\r\n * Minimal logging while loading\r\n */\r\n Constants.SCENELOADER_MINIMAL_LOGGING = 1;\r\n /**\r\n * Summary logging while loading\r\n */\r\n Constants.SCENELOADER_SUMMARY_LOGGING = 2;\r\n /**\r\n * Detailled logging while loading\r\n */\r\n Constants.SCENELOADER_DETAILED_LOGGING = 3;\r\n return Constants;\r\n}());\r\nexport { Constants };\r\n//# sourceMappingURL=constants.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { Vector2, Vector3 } from \"@babylonjs/core/Maths/math.vector\";\r\nimport { Tools } from \"@babylonjs/core/Misc/tools\";\r\nimport { PointerEventTypes } from '@babylonjs/core/Events/pointerEvents';\r\nimport { ClipboardEventTypes, ClipboardInfo } from \"@babylonjs/core/Events/clipboardEvents\";\r\nimport { KeyboardEventTypes } from \"@babylonjs/core/Events/keyboardEvents\";\r\nimport { StandardMaterial } from \"@babylonjs/core/Materials/standardMaterial\";\r\nimport { Texture } from \"@babylonjs/core/Materials/Textures/texture\";\r\nimport { DynamicTexture } from \"@babylonjs/core/Materials/Textures/dynamicTexture\";\r\nimport { Layer } from \"@babylonjs/core/Layers/layer\";\r\nimport { Container } from \"./controls/container\";\r\nimport { Style } from \"./style\";\r\nimport { Measure } from \"./measure\";\r\nimport { Constants } from '@babylonjs/core/Engines/constants';\r\nimport { Viewport } from '@babylonjs/core/Maths/math.viewport';\r\nimport { Color3 } from '@babylonjs/core/Maths/math.color';\r\n/**\r\n* Class used to create texture to support 2D GUI elements\r\n* @see http://doc.babylonjs.com/how_to/gui\r\n*/\r\nvar AdvancedDynamicTexture = /** @class */ (function (_super) {\r\n __extends(AdvancedDynamicTexture, _super);\r\n /**\r\n * Creates a new AdvancedDynamicTexture\r\n * @param name defines the name of the texture\r\n * @param width defines the width of the texture\r\n * @param height defines the height of the texture\r\n * @param scene defines the hosting scene\r\n * @param generateMipMaps defines a boolean indicating if mipmaps must be generated (false by default)\r\n * @param samplingMode defines the texture sampling mode (Texture.NEAREST_SAMPLINGMODE by default)\r\n */\r\n function AdvancedDynamicTexture(name, width, height, scene, generateMipMaps, samplingMode) {\r\n if (width === void 0) { width = 0; }\r\n if (height === void 0) { height = 0; }\r\n if (generateMipMaps === void 0) { generateMipMaps = false; }\r\n if (samplingMode === void 0) { samplingMode = Texture.NEAREST_SAMPLINGMODE; }\r\n var _this = _super.call(this, name, { width: width, height: height }, scene, generateMipMaps, samplingMode, Constants.TEXTUREFORMAT_RGBA) || this;\r\n _this._isDirty = false;\r\n /** @hidden */\r\n _this._rootContainer = new Container(\"root\");\r\n /** @hidden */\r\n _this._lastControlOver = {};\r\n /** @hidden */\r\n _this._lastControlDown = {};\r\n /** @hidden */\r\n _this._capturingControl = {};\r\n /** @hidden */\r\n _this._linkedControls = new Array();\r\n _this._isFullscreen = false;\r\n _this._fullscreenViewport = new Viewport(0, 0, 1, 1);\r\n _this._idealWidth = 0;\r\n _this._idealHeight = 0;\r\n _this._useSmallestIdeal = false;\r\n _this._renderAtIdealSize = false;\r\n _this._blockNextFocusCheck = false;\r\n _this._renderScale = 1;\r\n _this._cursorChanged = false;\r\n _this._defaultMousePointerId = 0;\r\n /** @hidden */\r\n _this._numLayoutCalls = 0;\r\n /** @hidden */\r\n _this._numRenderCalls = 0;\r\n /**\r\n * Define type to string to ensure compatibility across browsers\r\n * Safari doesn't support DataTransfer constructor\r\n */\r\n _this._clipboardData = \"\";\r\n /**\r\n * Observable event triggered each time an clipboard event is received from the rendering canvas\r\n */\r\n _this.onClipboardObservable = new Observable();\r\n /**\r\n * Observable event triggered each time a pointer down is intercepted by a control\r\n */\r\n _this.onControlPickedObservable = new Observable();\r\n /**\r\n * Observable event triggered before layout is evaluated\r\n */\r\n _this.onBeginLayoutObservable = new Observable();\r\n /**\r\n * Observable event triggered after the layout was evaluated\r\n */\r\n _this.onEndLayoutObservable = new Observable();\r\n /**\r\n * Observable event triggered before the texture is rendered\r\n */\r\n _this.onBeginRenderObservable = new Observable();\r\n /**\r\n * Observable event triggered after the texture was rendered\r\n */\r\n _this.onEndRenderObservable = new Observable();\r\n /**\r\n * Gets or sets a boolean defining if alpha is stored as premultiplied\r\n */\r\n _this.premulAlpha = false;\r\n _this._useInvalidateRectOptimization = true;\r\n // Invalidated rectangle which is the combination of all invalidated controls after they have been rotated into absolute position\r\n _this._invalidatedRectangle = null;\r\n _this._clearMeasure = new Measure(0, 0, 0, 0);\r\n /** @hidden */\r\n _this.onClipboardCopy = function (rawEvt) {\r\n var evt = rawEvt;\r\n var ev = new ClipboardInfo(ClipboardEventTypes.COPY, evt);\r\n _this.onClipboardObservable.notifyObservers(ev);\r\n evt.preventDefault();\r\n };\r\n /** @hidden */\r\n _this.onClipboardCut = function (rawEvt) {\r\n var evt = rawEvt;\r\n var ev = new ClipboardInfo(ClipboardEventTypes.CUT, evt);\r\n _this.onClipboardObservable.notifyObservers(ev);\r\n evt.preventDefault();\r\n };\r\n /** @hidden */\r\n _this.onClipboardPaste = function (rawEvt) {\r\n var evt = rawEvt;\r\n var ev = new ClipboardInfo(ClipboardEventTypes.PASTE, evt);\r\n _this.onClipboardObservable.notifyObservers(ev);\r\n evt.preventDefault();\r\n };\r\n scene = _this.getScene();\r\n if (!scene || !_this._texture) {\r\n return _this;\r\n }\r\n _this._rootElement = scene.getEngine().getInputElement();\r\n _this._renderObserver = scene.onBeforeCameraRenderObservable.add(function (camera) { return _this._checkUpdate(camera); });\r\n _this._preKeyboardObserver = scene.onPreKeyboardObservable.add(function (info) {\r\n if (!_this._focusedControl) {\r\n return;\r\n }\r\n if (info.type === KeyboardEventTypes.KEYDOWN) {\r\n _this._focusedControl.processKeyboard(info.event);\r\n }\r\n info.skipOnPointerObservable = true;\r\n });\r\n _this._rootContainer._link(_this);\r\n _this.hasAlpha = true;\r\n if (!width || !height) {\r\n _this._resizeObserver = scene.getEngine().onResizeObservable.add(function () { return _this._onResize(); });\r\n _this._onResize();\r\n }\r\n _this._texture.isReady = true;\r\n return _this;\r\n }\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"numLayoutCalls\", {\r\n /** Gets the number of layout calls made the last time the ADT has been rendered */\r\n get: function () {\r\n return this._numLayoutCalls;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"numRenderCalls\", {\r\n /** Gets the number of render calls made the last time the ADT has been rendered */\r\n get: function () {\r\n return this._numRenderCalls;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"renderScale\", {\r\n /**\r\n * Gets or sets a number used to scale rendering size (2 means that the texture will be twice bigger).\r\n * Useful when you want more antialiasing\r\n */\r\n get: function () {\r\n return this._renderScale;\r\n },\r\n set: function (value) {\r\n if (value === this._renderScale) {\r\n return;\r\n }\r\n this._renderScale = value;\r\n this._onResize();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"background\", {\r\n /** Gets or sets the background color */\r\n get: function () {\r\n return this._background;\r\n },\r\n set: function (value) {\r\n if (this._background === value) {\r\n return;\r\n }\r\n this._background = value;\r\n this.markAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"idealWidth\", {\r\n /**\r\n * Gets or sets the ideal width used to design controls.\r\n * The GUI will then rescale everything accordingly\r\n * @see http://doc.babylonjs.com/how_to/gui#adaptive-scaling\r\n */\r\n get: function () {\r\n return this._idealWidth;\r\n },\r\n set: function (value) {\r\n if (this._idealWidth === value) {\r\n return;\r\n }\r\n this._idealWidth = value;\r\n this.markAsDirty();\r\n this._rootContainer._markAllAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"idealHeight\", {\r\n /**\r\n * Gets or sets the ideal height used to design controls.\r\n * The GUI will then rescale everything accordingly\r\n * @see http://doc.babylonjs.com/how_to/gui#adaptive-scaling\r\n */\r\n get: function () {\r\n return this._idealHeight;\r\n },\r\n set: function (value) {\r\n if (this._idealHeight === value) {\r\n return;\r\n }\r\n this._idealHeight = value;\r\n this.markAsDirty();\r\n this._rootContainer._markAllAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"useSmallestIdeal\", {\r\n /**\r\n * Gets or sets a boolean indicating if the smallest ideal value must be used if idealWidth and idealHeight are both set\r\n * @see http://doc.babylonjs.com/how_to/gui#adaptive-scaling\r\n */\r\n get: function () {\r\n return this._useSmallestIdeal;\r\n },\r\n set: function (value) {\r\n if (this._useSmallestIdeal === value) {\r\n return;\r\n }\r\n this._useSmallestIdeal = value;\r\n this.markAsDirty();\r\n this._rootContainer._markAllAsDirty();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"renderAtIdealSize\", {\r\n /**\r\n * Gets or sets a boolean indicating if adaptive scaling must be used\r\n * @see http://doc.babylonjs.com/how_to/gui#adaptive-scaling\r\n */\r\n get: function () {\r\n return this._renderAtIdealSize;\r\n },\r\n set: function (value) {\r\n if (this._renderAtIdealSize === value) {\r\n return;\r\n }\r\n this._renderAtIdealSize = value;\r\n this._onResize();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"idealRatio\", {\r\n /**\r\n * Gets the ratio used when in \"ideal mode\"\r\n * @see http://doc.babylonjs.com/how_to/gui#adaptive-scaling\r\n * */\r\n get: function () {\r\n var rwidth = 0;\r\n var rheight = 0;\r\n if (this._idealWidth) {\r\n rwidth = (this.getSize().width) / this._idealWidth;\r\n }\r\n if (this._idealHeight) {\r\n rheight = (this.getSize().height) / this._idealHeight;\r\n }\r\n if (this._useSmallestIdeal && this._idealWidth && this._idealHeight) {\r\n return window.innerWidth < window.innerHeight ? rwidth : rheight;\r\n }\r\n if (this._idealWidth) { // horizontal\r\n return rwidth;\r\n }\r\n if (this._idealHeight) { // vertical\r\n return rheight;\r\n }\r\n return 1;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"layer\", {\r\n /**\r\n * Gets the underlying layer used to render the texture when in fullscreen mode\r\n */\r\n get: function () {\r\n return this._layerToDispose;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"rootContainer\", {\r\n /**\r\n * Gets the root container control\r\n */\r\n get: function () {\r\n return this._rootContainer;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Returns an array containing the root container.\r\n * This is mostly used to let the Inspector introspects the ADT\r\n * @returns an array containing the rootContainer\r\n */\r\n AdvancedDynamicTexture.prototype.getChildren = function () {\r\n return [this._rootContainer];\r\n };\r\n /**\r\n * Will return all controls that are inside this texture\r\n * @param directDescendantsOnly defines if true only direct descendants of 'this' will be considered, if false direct and also indirect (children of children, an so on in a recursive manner) descendants of 'this' will be considered\r\n * @param predicate defines an optional predicate that will be called on every evaluated child, the predicate must return true for a given child to be part of the result, otherwise it will be ignored\r\n * @return all child controls\r\n */\r\n AdvancedDynamicTexture.prototype.getDescendants = function (directDescendantsOnly, predicate) {\r\n return this._rootContainer.getDescendants(directDescendantsOnly, predicate);\r\n };\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"focusedControl\", {\r\n /**\r\n * Gets or sets the current focused control\r\n */\r\n get: function () {\r\n return this._focusedControl;\r\n },\r\n set: function (control) {\r\n if (this._focusedControl == control) {\r\n return;\r\n }\r\n if (this._focusedControl) {\r\n this._focusedControl.onBlur();\r\n }\r\n if (control) {\r\n control.onFocus();\r\n }\r\n this._focusedControl = control;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"isForeground\", {\r\n /**\r\n * Gets or sets a boolean indicating if the texture must be rendered in background or foreground when in fullscreen mode\r\n */\r\n get: function () {\r\n if (!this.layer) {\r\n return true;\r\n }\r\n return (!this.layer.isBackground);\r\n },\r\n set: function (value) {\r\n if (!this.layer) {\r\n return;\r\n }\r\n if (this.layer.isBackground === !value) {\r\n return;\r\n }\r\n this.layer.isBackground = !value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"clipboardData\", {\r\n /**\r\n * Gets or set information about clipboardData\r\n */\r\n get: function () {\r\n return this._clipboardData;\r\n },\r\n set: function (value) {\r\n this._clipboardData = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Get the current class name of the texture useful for serialization or dynamic coding.\r\n * @returns \"AdvancedDynamicTexture\"\r\n */\r\n AdvancedDynamicTexture.prototype.getClassName = function () {\r\n return \"AdvancedDynamicTexture\";\r\n };\r\n /**\r\n * Function used to execute a function on all controls\r\n * @param func defines the function to execute\r\n * @param container defines the container where controls belong. If null the root container will be used\r\n */\r\n AdvancedDynamicTexture.prototype.executeOnAllControls = function (func, container) {\r\n if (!container) {\r\n container = this._rootContainer;\r\n }\r\n func(container);\r\n for (var _i = 0, _a = container.children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (child.children) {\r\n this.executeOnAllControls(func, child);\r\n continue;\r\n }\r\n func(child);\r\n }\r\n };\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"useInvalidateRectOptimization\", {\r\n /**\r\n * Gets or sets a boolean indicating if the InvalidateRect optimization should be turned on\r\n */\r\n get: function () {\r\n return this._useInvalidateRectOptimization;\r\n },\r\n set: function (value) {\r\n this._useInvalidateRectOptimization = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Invalidates a rectangle area on the gui texture\r\n * @param invalidMinX left most position of the rectangle to invalidate in the texture\r\n * @param invalidMinY top most position of the rectangle to invalidate in the texture\r\n * @param invalidMaxX right most position of the rectangle to invalidate in the texture\r\n * @param invalidMaxY bottom most position of the rectangle to invalidate in the texture\r\n */\r\n AdvancedDynamicTexture.prototype.invalidateRect = function (invalidMinX, invalidMinY, invalidMaxX, invalidMaxY) {\r\n if (!this._useInvalidateRectOptimization) {\r\n return;\r\n }\r\n if (!this._invalidatedRectangle) {\r\n this._invalidatedRectangle = new Measure(invalidMinX, invalidMinY, invalidMaxX - invalidMinX + 1, invalidMaxY - invalidMinY + 1);\r\n }\r\n else {\r\n // Compute intersection\r\n var maxX = Math.ceil(Math.max(this._invalidatedRectangle.left + this._invalidatedRectangle.width - 1, invalidMaxX));\r\n var maxY = Math.ceil(Math.max(this._invalidatedRectangle.top + this._invalidatedRectangle.height - 1, invalidMaxY));\r\n this._invalidatedRectangle.left = Math.floor(Math.min(this._invalidatedRectangle.left, invalidMinX));\r\n this._invalidatedRectangle.top = Math.floor(Math.min(this._invalidatedRectangle.top, invalidMinY));\r\n this._invalidatedRectangle.width = maxX - this._invalidatedRectangle.left + 1;\r\n this._invalidatedRectangle.height = maxY - this._invalidatedRectangle.top + 1;\r\n }\r\n };\r\n /**\r\n * Marks the texture as dirty forcing a complete update\r\n */\r\n AdvancedDynamicTexture.prototype.markAsDirty = function () {\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Helper function used to create a new style\r\n * @returns a new style\r\n * @see http://doc.babylonjs.com/how_to/gui#styles\r\n */\r\n AdvancedDynamicTexture.prototype.createStyle = function () {\r\n return new Style(this);\r\n };\r\n /**\r\n * Adds a new control to the root container\r\n * @param control defines the control to add\r\n * @returns the current texture\r\n */\r\n AdvancedDynamicTexture.prototype.addControl = function (control) {\r\n this._rootContainer.addControl(control);\r\n return this;\r\n };\r\n /**\r\n * Removes a control from the root container\r\n * @param control defines the control to remove\r\n * @returns the current texture\r\n */\r\n AdvancedDynamicTexture.prototype.removeControl = function (control) {\r\n this._rootContainer.removeControl(control);\r\n return this;\r\n };\r\n /**\r\n * Release all resources\r\n */\r\n AdvancedDynamicTexture.prototype.dispose = function () {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n this._rootElement = null;\r\n scene.onBeforeCameraRenderObservable.remove(this._renderObserver);\r\n if (this._resizeObserver) {\r\n scene.getEngine().onResizeObservable.remove(this._resizeObserver);\r\n }\r\n if (this._pointerMoveObserver) {\r\n scene.onPrePointerObservable.remove(this._pointerMoveObserver);\r\n }\r\n if (this._pointerObserver) {\r\n scene.onPointerObservable.remove(this._pointerObserver);\r\n }\r\n if (this._preKeyboardObserver) {\r\n scene.onPreKeyboardObservable.remove(this._preKeyboardObserver);\r\n }\r\n if (this._canvasPointerOutObserver) {\r\n scene.getEngine().onCanvasPointerOutObservable.remove(this._canvasPointerOutObserver);\r\n }\r\n if (this._layerToDispose) {\r\n this._layerToDispose.texture = null;\r\n this._layerToDispose.dispose();\r\n this._layerToDispose = null;\r\n }\r\n this._rootContainer.dispose();\r\n this.onClipboardObservable.clear();\r\n this.onControlPickedObservable.clear();\r\n this.onBeginRenderObservable.clear();\r\n this.onEndRenderObservable.clear();\r\n this.onBeginLayoutObservable.clear();\r\n this.onEndLayoutObservable.clear();\r\n _super.prototype.dispose.call(this);\r\n };\r\n AdvancedDynamicTexture.prototype._onResize = function () {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n // Check size\r\n var engine = scene.getEngine();\r\n var textureSize = this.getSize();\r\n var renderWidth = engine.getRenderWidth() * this._renderScale;\r\n var renderHeight = engine.getRenderHeight() * this._renderScale;\r\n if (this._renderAtIdealSize) {\r\n if (this._idealWidth) {\r\n renderHeight = (renderHeight * this._idealWidth) / renderWidth;\r\n renderWidth = this._idealWidth;\r\n }\r\n else if (this._idealHeight) {\r\n renderWidth = (renderWidth * this._idealHeight) / renderHeight;\r\n renderHeight = this._idealHeight;\r\n }\r\n }\r\n if (textureSize.width !== renderWidth || textureSize.height !== renderHeight) {\r\n this.scaleTo(renderWidth, renderHeight);\r\n this.markAsDirty();\r\n if (this._idealWidth || this._idealHeight) {\r\n this._rootContainer._markAllAsDirty();\r\n }\r\n }\r\n this.invalidateRect(0, 0, textureSize.width - 1, textureSize.height - 1);\r\n };\r\n /** @hidden */\r\n AdvancedDynamicTexture.prototype._getGlobalViewport = function (scene) {\r\n var engine = scene.getEngine();\r\n return this._fullscreenViewport.toGlobal(engine.getRenderWidth(), engine.getRenderHeight());\r\n };\r\n /**\r\n * Get screen coordinates for a vector3\r\n * @param position defines the position to project\r\n * @param worldMatrix defines the world matrix to use\r\n * @returns the projected position\r\n */\r\n AdvancedDynamicTexture.prototype.getProjectedPosition = function (position, worldMatrix) {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return Vector2.Zero();\r\n }\r\n var globalViewport = this._getGlobalViewport(scene);\r\n var projectedPosition = Vector3.Project(position, worldMatrix, scene.getTransformMatrix(), globalViewport);\r\n projectedPosition.scaleInPlace(this.renderScale);\r\n return new Vector2(projectedPosition.x, projectedPosition.y);\r\n };\r\n AdvancedDynamicTexture.prototype._checkUpdate = function (camera) {\r\n if (this._layerToDispose) {\r\n if ((camera.layerMask & this._layerToDispose.layerMask) === 0) {\r\n return;\r\n }\r\n }\r\n if (this._isFullscreen && this._linkedControls.length) {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n var globalViewport = this._getGlobalViewport(scene);\r\n for (var _i = 0, _a = this._linkedControls; _i < _a.length; _i++) {\r\n var control = _a[_i];\r\n if (!control.isVisible) {\r\n continue;\r\n }\r\n var mesh = control._linkedMesh;\r\n if (!mesh || mesh.isDisposed()) {\r\n Tools.SetImmediate(function () {\r\n control.linkWithMesh(null);\r\n });\r\n continue;\r\n }\r\n var position = mesh.getBoundingInfo ? mesh.getBoundingInfo().boundingSphere.center : Vector3.ZeroReadOnly;\r\n var projectedPosition = Vector3.Project(position, mesh.getWorldMatrix(), scene.getTransformMatrix(), globalViewport);\r\n if (projectedPosition.z < 0 || projectedPosition.z > 1) {\r\n control.notRenderable = true;\r\n continue;\r\n }\r\n control.notRenderable = false;\r\n // Account for RenderScale.\r\n projectedPosition.scaleInPlace(this.renderScale);\r\n control._moveToProjectedPosition(projectedPosition);\r\n }\r\n }\r\n if (!this._isDirty && !this._rootContainer.isDirty) {\r\n return;\r\n }\r\n this._isDirty = false;\r\n this._render();\r\n this.update(true, this.premulAlpha);\r\n };\r\n AdvancedDynamicTexture.prototype._render = function () {\r\n var textureSize = this.getSize();\r\n var renderWidth = textureSize.width;\r\n var renderHeight = textureSize.height;\r\n var context = this.getContext();\r\n context.font = \"18px Arial\";\r\n context.strokeStyle = \"white\";\r\n // Layout\r\n this.onBeginLayoutObservable.notifyObservers(this);\r\n var measure = new Measure(0, 0, renderWidth, renderHeight);\r\n this._numLayoutCalls = 0;\r\n this._rootContainer._layout(measure, context);\r\n this.onEndLayoutObservable.notifyObservers(this);\r\n this._isDirty = false; // Restoring the dirty state that could have been set by controls during layout processing\r\n // Clear\r\n if (this._invalidatedRectangle) {\r\n this._clearMeasure.copyFrom(this._invalidatedRectangle);\r\n }\r\n else {\r\n this._clearMeasure.copyFromFloats(0, 0, renderWidth, renderHeight);\r\n }\r\n context.clearRect(this._clearMeasure.left, this._clearMeasure.top, this._clearMeasure.width, this._clearMeasure.height);\r\n if (this._background) {\r\n context.save();\r\n context.fillStyle = this._background;\r\n context.fillRect(this._clearMeasure.left, this._clearMeasure.top, this._clearMeasure.width, this._clearMeasure.height);\r\n context.restore();\r\n }\r\n // Render\r\n this.onBeginRenderObservable.notifyObservers(this);\r\n this._numRenderCalls = 0;\r\n this._rootContainer._render(context, this._invalidatedRectangle);\r\n this.onEndRenderObservable.notifyObservers(this);\r\n this._invalidatedRectangle = null;\r\n };\r\n /** @hidden */\r\n AdvancedDynamicTexture.prototype._changeCursor = function (cursor) {\r\n if (this._rootElement) {\r\n this._rootElement.style.cursor = cursor;\r\n this._cursorChanged = true;\r\n }\r\n };\r\n /** @hidden */\r\n AdvancedDynamicTexture.prototype._registerLastControlDown = function (control, pointerId) {\r\n this._lastControlDown[pointerId] = control;\r\n this.onControlPickedObservable.notifyObservers(control);\r\n };\r\n AdvancedDynamicTexture.prototype._doPicking = function (x, y, type, pointerId, buttonIndex, deltaX, deltaY) {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n var engine = scene.getEngine();\r\n var textureSize = this.getSize();\r\n if (this._isFullscreen) {\r\n var camera = scene.cameraToUseForPointers || scene.activeCamera;\r\n var viewport = camera.viewport;\r\n x = x * (textureSize.width / (engine.getRenderWidth() * viewport.width));\r\n y = y * (textureSize.height / (engine.getRenderHeight() * viewport.height));\r\n }\r\n if (this._capturingControl[pointerId]) {\r\n this._capturingControl[pointerId]._processObservables(type, x, y, pointerId, buttonIndex);\r\n return;\r\n }\r\n this._cursorChanged = false;\r\n if (!this._rootContainer._processPicking(x, y, type, pointerId, buttonIndex, deltaX, deltaY)) {\r\n this._changeCursor(\"\");\r\n if (type === PointerEventTypes.POINTERMOVE) {\r\n if (this._lastControlOver[pointerId]) {\r\n this._lastControlOver[pointerId]._onPointerOut(this._lastControlOver[pointerId]);\r\n delete this._lastControlOver[pointerId];\r\n }\r\n }\r\n }\r\n if (!this._cursorChanged) {\r\n this._changeCursor(\"\");\r\n }\r\n this._manageFocus();\r\n };\r\n /** @hidden */\r\n AdvancedDynamicTexture.prototype._cleanControlAfterRemovalFromList = function (list, control) {\r\n for (var pointerId in list) {\r\n if (!list.hasOwnProperty(pointerId)) {\r\n continue;\r\n }\r\n var lastControlOver = list[pointerId];\r\n if (lastControlOver === control) {\r\n delete list[pointerId];\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n AdvancedDynamicTexture.prototype._cleanControlAfterRemoval = function (control) {\r\n this._cleanControlAfterRemovalFromList(this._lastControlDown, control);\r\n this._cleanControlAfterRemovalFromList(this._lastControlOver, control);\r\n };\r\n /** Attach to all scene events required to support pointer events */\r\n AdvancedDynamicTexture.prototype.attach = function () {\r\n var _this = this;\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n var tempViewport = new Viewport(0, 0, 0, 0);\r\n this._pointerMoveObserver = scene.onPrePointerObservable.add(function (pi, state) {\r\n if (scene.isPointerCaptured((pi.event).pointerId)) {\r\n return;\r\n }\r\n if (pi.type !== PointerEventTypes.POINTERMOVE\r\n && pi.type !== PointerEventTypes.POINTERUP\r\n && pi.type !== PointerEventTypes.POINTERDOWN\r\n && pi.type !== PointerEventTypes.POINTERWHEEL) {\r\n return;\r\n }\r\n if (!scene) {\r\n return;\r\n }\r\n if (pi.type === PointerEventTypes.POINTERMOVE && pi.event.pointerId) {\r\n _this._defaultMousePointerId = pi.event.pointerId; // This is required to make sure we have the correct pointer ID for wheel\r\n }\r\n var camera = scene.cameraToUseForPointers || scene.activeCamera;\r\n var engine = scene.getEngine();\r\n if (!camera) {\r\n tempViewport.x = 0;\r\n tempViewport.y = 0;\r\n tempViewport.width = engine.getRenderWidth();\r\n tempViewport.height = engine.getRenderHeight();\r\n }\r\n else {\r\n camera.viewport.toGlobalToRef(engine.getRenderWidth(), engine.getRenderHeight(), tempViewport);\r\n }\r\n var x = scene.pointerX / engine.getHardwareScalingLevel() - tempViewport.x;\r\n var y = scene.pointerY / engine.getHardwareScalingLevel() - (engine.getRenderHeight() - tempViewport.y - tempViewport.height);\r\n _this._shouldBlockPointer = false;\r\n // Do picking modifies _shouldBlockPointer\r\n var pointerId = pi.event.pointerId || _this._defaultMousePointerId;\r\n _this._doPicking(x, y, pi.type, pointerId, pi.event.button, pi.event.deltaX, pi.event.deltaY);\r\n // Avoid overwriting a true skipOnPointerObservable to false\r\n if (_this._shouldBlockPointer) {\r\n pi.skipOnPointerObservable = _this._shouldBlockPointer;\r\n }\r\n });\r\n this._attachToOnPointerOut(scene);\r\n };\r\n /**\r\n * Register the clipboard Events onto the canvas\r\n */\r\n AdvancedDynamicTexture.prototype.registerClipboardEvents = function () {\r\n self.addEventListener(\"copy\", this.onClipboardCopy, false);\r\n self.addEventListener(\"cut\", this.onClipboardCut, false);\r\n self.addEventListener(\"paste\", this.onClipboardPaste, false);\r\n };\r\n /**\r\n * Unregister the clipboard Events from the canvas\r\n */\r\n AdvancedDynamicTexture.prototype.unRegisterClipboardEvents = function () {\r\n self.removeEventListener(\"copy\", this.onClipboardCopy);\r\n self.removeEventListener(\"cut\", this.onClipboardCut);\r\n self.removeEventListener(\"paste\", this.onClipboardPaste);\r\n };\r\n /**\r\n * Connect the texture to a hosting mesh to enable interactions\r\n * @param mesh defines the mesh to attach to\r\n * @param supportPointerMove defines a boolean indicating if pointer move events must be catched as well\r\n */\r\n AdvancedDynamicTexture.prototype.attachToMesh = function (mesh, supportPointerMove) {\r\n var _this = this;\r\n if (supportPointerMove === void 0) { supportPointerMove = true; }\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n this._pointerObserver = scene.onPointerObservable.add(function (pi, state) {\r\n if (pi.type !== PointerEventTypes.POINTERMOVE\r\n && pi.type !== PointerEventTypes.POINTERUP\r\n && pi.type !== PointerEventTypes.POINTERDOWN) {\r\n return;\r\n }\r\n var pointerId = pi.event.pointerId || _this._defaultMousePointerId;\r\n if (pi.pickInfo && pi.pickInfo.hit && pi.pickInfo.pickedMesh === mesh) {\r\n var uv = pi.pickInfo.getTextureCoordinates();\r\n if (uv) {\r\n var size = _this.getSize();\r\n _this._doPicking(uv.x * size.width, (1.0 - uv.y) * size.height, pi.type, pointerId, pi.event.button);\r\n }\r\n }\r\n else if (pi.type === PointerEventTypes.POINTERUP) {\r\n if (_this._lastControlDown[pointerId]) {\r\n _this._lastControlDown[pointerId]._forcePointerUp(pointerId);\r\n }\r\n delete _this._lastControlDown[pointerId];\r\n if (_this.focusedControl) {\r\n var friendlyControls = _this.focusedControl.keepsFocusWith();\r\n var canMoveFocus = true;\r\n if (friendlyControls) {\r\n for (var _i = 0, friendlyControls_1 = friendlyControls; _i < friendlyControls_1.length; _i++) {\r\n var control = friendlyControls_1[_i];\r\n // Same host, no need to keep the focus\r\n if (_this === control._host) {\r\n continue;\r\n }\r\n // Different hosts\r\n var otherHost = control._host;\r\n if (otherHost._lastControlOver[pointerId] && otherHost._lastControlOver[pointerId].isAscendant(control)) {\r\n canMoveFocus = false;\r\n break;\r\n }\r\n }\r\n }\r\n if (canMoveFocus) {\r\n _this.focusedControl = null;\r\n }\r\n }\r\n }\r\n else if (pi.type === PointerEventTypes.POINTERMOVE) {\r\n if (_this._lastControlOver[pointerId]) {\r\n _this._lastControlOver[pointerId]._onPointerOut(_this._lastControlOver[pointerId], true);\r\n }\r\n delete _this._lastControlOver[pointerId];\r\n }\r\n });\r\n mesh.enablePointerMoveEvents = supportPointerMove;\r\n this._attachToOnPointerOut(scene);\r\n };\r\n /**\r\n * Move the focus to a specific control\r\n * @param control defines the control which will receive the focus\r\n */\r\n AdvancedDynamicTexture.prototype.moveFocusToControl = function (control) {\r\n this.focusedControl = control;\r\n this._lastPickedControl = control;\r\n this._blockNextFocusCheck = true;\r\n };\r\n AdvancedDynamicTexture.prototype._manageFocus = function () {\r\n if (this._blockNextFocusCheck) {\r\n this._blockNextFocusCheck = false;\r\n this._lastPickedControl = this._focusedControl;\r\n return;\r\n }\r\n // Focus management\r\n if (this._focusedControl) {\r\n if (this._focusedControl !== this._lastPickedControl) {\r\n if (this._lastPickedControl.isFocusInvisible) {\r\n return;\r\n }\r\n this.focusedControl = null;\r\n }\r\n }\r\n };\r\n AdvancedDynamicTexture.prototype._attachToOnPointerOut = function (scene) {\r\n var _this = this;\r\n this._canvasPointerOutObserver = scene.getEngine().onCanvasPointerOutObservable.add(function (pointerEvent) {\r\n if (_this._lastControlOver[pointerEvent.pointerId]) {\r\n _this._lastControlOver[pointerEvent.pointerId]._onPointerOut(_this._lastControlOver[pointerEvent.pointerId]);\r\n }\r\n delete _this._lastControlOver[pointerEvent.pointerId];\r\n if (_this._lastControlDown[pointerEvent.pointerId] && _this._lastControlDown[pointerEvent.pointerId] !== _this._capturingControl[pointerEvent.pointerId]) {\r\n _this._lastControlDown[pointerEvent.pointerId]._forcePointerUp();\r\n delete _this._lastControlDown[pointerEvent.pointerId];\r\n }\r\n });\r\n };\r\n // Statics\r\n /**\r\n * Creates a new AdvancedDynamicTexture in projected mode (ie. attached to a mesh)\r\n * @param mesh defines the mesh which will receive the texture\r\n * @param width defines the texture width (1024 by default)\r\n * @param height defines the texture height (1024 by default)\r\n * @param supportPointerMove defines a boolean indicating if the texture must capture move events (true by default)\r\n * @param onlyAlphaTesting defines a boolean indicating that alpha blending will not be used (only alpha testing) (false by default)\r\n * @returns a new AdvancedDynamicTexture\r\n */\r\n AdvancedDynamicTexture.CreateForMesh = function (mesh, width, height, supportPointerMove, onlyAlphaTesting) {\r\n if (width === void 0) { width = 1024; }\r\n if (height === void 0) { height = 1024; }\r\n if (supportPointerMove === void 0) { supportPointerMove = true; }\r\n if (onlyAlphaTesting === void 0) { onlyAlphaTesting = false; }\r\n var result = new AdvancedDynamicTexture(mesh.name + \" AdvancedDynamicTexture\", width, height, mesh.getScene(), true, Texture.TRILINEAR_SAMPLINGMODE);\r\n var material = new StandardMaterial(\"AdvancedDynamicTextureMaterial\", mesh.getScene());\r\n material.backFaceCulling = false;\r\n material.diffuseColor = Color3.Black();\r\n material.specularColor = Color3.Black();\r\n if (onlyAlphaTesting) {\r\n material.diffuseTexture = result;\r\n material.emissiveTexture = result;\r\n result.hasAlpha = true;\r\n }\r\n else {\r\n material.emissiveTexture = result;\r\n material.opacityTexture = result;\r\n }\r\n mesh.material = material;\r\n result.attachToMesh(mesh, supportPointerMove);\r\n return result;\r\n };\r\n /**\r\n * Creates a new AdvancedDynamicTexture in fullscreen mode.\r\n * In this mode the texture will rely on a layer for its rendering.\r\n * This allows it to be treated like any other layer.\r\n * As such, if you have a multi camera setup, you can set the layerMask on the GUI as well.\r\n * LayerMask is set through advancedTexture.layer.layerMask\r\n * @param name defines name for the texture\r\n * @param foreground defines a boolean indicating if the texture must be rendered in foreground (default is true)\r\n * @param scene defines the hsoting scene\r\n * @param sampling defines the texture sampling mode (Texture.BILINEAR_SAMPLINGMODE by default)\r\n * @returns a new AdvancedDynamicTexture\r\n */\r\n AdvancedDynamicTexture.CreateFullscreenUI = function (name, foreground, scene, sampling) {\r\n if (foreground === void 0) { foreground = true; }\r\n if (scene === void 0) { scene = null; }\r\n if (sampling === void 0) { sampling = Texture.BILINEAR_SAMPLINGMODE; }\r\n var result = new AdvancedDynamicTexture(name, 0, 0, scene, false, sampling);\r\n // Display\r\n var layer = new Layer(name + \"_layer\", null, scene, !foreground);\r\n layer.texture = result;\r\n result._layerToDispose = layer;\r\n result._isFullscreen = true;\r\n // Attach\r\n result.attach();\r\n return result;\r\n };\r\n return AdvancedDynamicTexture;\r\n}(DynamicTexture));\r\nexport { AdvancedDynamicTexture };\r\n//# sourceMappingURL=advancedDynamicTexture.js.map","import { __extends } from \"tslib\";\r\nimport { TmpVectors } from \"../Maths/math.vector\";\r\nimport { Logger } from \"../Misc/logger\";\r\nimport { AbstractMesh } from \"../Meshes/abstractMesh\";\r\nimport { Mesh } from \"../Meshes/mesh\";\r\nimport { DeepCopier } from \"../Misc/deepCopier\";\r\nimport { TransformNode } from './transformNode';\r\nimport { VertexBuffer } from './buffer';\r\nMesh._instancedMeshFactory = function (name, mesh) {\r\n var instance = new InstancedMesh(name, mesh);\r\n if (mesh.instancedBuffers) {\r\n instance.instancedBuffers = {};\r\n for (var key in mesh.instancedBuffers) {\r\n instance.instancedBuffers[key] = mesh.instancedBuffers[key];\r\n }\r\n }\r\n return instance;\r\n};\r\n/**\r\n * Creates an instance based on a source mesh.\r\n */\r\nvar InstancedMesh = /** @class */ (function (_super) {\r\n __extends(InstancedMesh, _super);\r\n function InstancedMesh(name, source) {\r\n var _this = _super.call(this, name, source.getScene()) || this;\r\n /** @hidden */\r\n _this._indexInSourceMeshInstanceArray = -1;\r\n source.addInstance(_this);\r\n _this._sourceMesh = source;\r\n _this._unIndexed = source._unIndexed;\r\n _this.position.copyFrom(source.position);\r\n _this.rotation.copyFrom(source.rotation);\r\n _this.scaling.copyFrom(source.scaling);\r\n if (source.rotationQuaternion) {\r\n _this.rotationQuaternion = source.rotationQuaternion.clone();\r\n }\r\n _this.animations = source.animations;\r\n for (var _i = 0, _a = source.getAnimationRanges(); _i < _a.length; _i++) {\r\n var range = _a[_i];\r\n if (range != null) {\r\n _this.createAnimationRange(range.name, range.from, range.to);\r\n }\r\n }\r\n _this.infiniteDistance = source.infiniteDistance;\r\n _this.setPivotMatrix(source.getPivotMatrix());\r\n _this.refreshBoundingInfo();\r\n _this._syncSubMeshes();\r\n return _this;\r\n }\r\n /**\r\n * Returns the string \"InstancedMesh\".\r\n */\r\n InstancedMesh.prototype.getClassName = function () {\r\n return \"InstancedMesh\";\r\n };\r\n Object.defineProperty(InstancedMesh.prototype, \"lightSources\", {\r\n /** Gets the list of lights affecting that mesh */\r\n get: function () {\r\n return this._sourceMesh._lightSources;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n InstancedMesh.prototype._resyncLightSources = function () {\r\n // Do nothing as all the work will be done by source mesh\r\n };\r\n InstancedMesh.prototype._resyncLightSource = function (light) {\r\n // Do nothing as all the work will be done by source mesh\r\n };\r\n InstancedMesh.prototype._removeLightSource = function (light, dispose) {\r\n // Do nothing as all the work will be done by source mesh\r\n };\r\n Object.defineProperty(InstancedMesh.prototype, \"receiveShadows\", {\r\n // Methods\r\n /**\r\n * If the source mesh receives shadows\r\n */\r\n get: function () {\r\n return this._sourceMesh.receiveShadows;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InstancedMesh.prototype, \"material\", {\r\n /**\r\n * The material of the source mesh\r\n */\r\n get: function () {\r\n return this._sourceMesh.material;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InstancedMesh.prototype, \"visibility\", {\r\n /**\r\n * Visibility of the source mesh\r\n */\r\n get: function () {\r\n return this._sourceMesh.visibility;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InstancedMesh.prototype, \"skeleton\", {\r\n /**\r\n * Skeleton of the source mesh\r\n */\r\n get: function () {\r\n return this._sourceMesh.skeleton;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(InstancedMesh.prototype, \"renderingGroupId\", {\r\n /**\r\n * Rendering ground id of the source mesh\r\n */\r\n get: function () {\r\n return this._sourceMesh.renderingGroupId;\r\n },\r\n set: function (value) {\r\n if (!this._sourceMesh || value === this._sourceMesh.renderingGroupId) {\r\n return;\r\n }\r\n //no-op with warning\r\n Logger.Warn(\"Note - setting renderingGroupId of an instanced mesh has no effect on the scene\");\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Returns the total number of vertices (integer).\r\n */\r\n InstancedMesh.prototype.getTotalVertices = function () {\r\n return this._sourceMesh ? this._sourceMesh.getTotalVertices() : 0;\r\n };\r\n /**\r\n * Returns a positive integer : the total number of indices in this mesh geometry.\r\n * @returns the numner of indices or zero if the mesh has no geometry.\r\n */\r\n InstancedMesh.prototype.getTotalIndices = function () {\r\n return this._sourceMesh.getTotalIndices();\r\n };\r\n Object.defineProperty(InstancedMesh.prototype, \"sourceMesh\", {\r\n /**\r\n * The source mesh of the instance\r\n */\r\n get: function () {\r\n return this._sourceMesh;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Is this node ready to be used/rendered\r\n * @param completeCheck defines if a complete check (including materials and lights) has to be done (false by default)\r\n * @return {boolean} is it ready\r\n */\r\n InstancedMesh.prototype.isReady = function (completeCheck) {\r\n if (completeCheck === void 0) { completeCheck = false; }\r\n return this._sourceMesh.isReady(completeCheck, true);\r\n };\r\n /**\r\n * Returns an array of integers or a typed array (Int32Array, Uint32Array, Uint16Array) populated with the mesh indices.\r\n * @param kind kind of verticies to retreive (eg. positons, normals, uvs, etc.)\r\n * @param copyWhenShared If true (default false) and and if the mesh geometry is shared among some other meshes, the returned array is a copy of the internal one.\r\n * @returns a float array or a Float32Array of the requested kind of data : positons, normals, uvs, etc.\r\n */\r\n InstancedMesh.prototype.getVerticesData = function (kind, copyWhenShared) {\r\n return this._sourceMesh.getVerticesData(kind, copyWhenShared);\r\n };\r\n /**\r\n * Sets the vertex data of the mesh geometry for the requested `kind`.\r\n * If the mesh has no geometry, a new Geometry object is set to the mesh and then passed this vertex data.\r\n * The `data` are either a numeric array either a Float32Array.\r\n * The parameter `updatable` is passed as is to the underlying Geometry object constructor (if initianilly none) or updater.\r\n * The parameter `stride` is an optional positive integer, it is usually automatically deducted from the `kind` (3 for positions or normals, 2 for UV, etc).\r\n * Note that a new underlying VertexBuffer object is created each call.\r\n * If the `kind` is the `PositionKind`, the mesh BoundingInfo is renewed, so the bounding box and sphere, and the mesh World Matrix is recomputed.\r\n *\r\n * Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n *\r\n * Returns the Mesh.\r\n */\r\n InstancedMesh.prototype.setVerticesData = function (kind, data, updatable, stride) {\r\n if (this.sourceMesh) {\r\n this.sourceMesh.setVerticesData(kind, data, updatable, stride);\r\n }\r\n return this.sourceMesh;\r\n };\r\n /**\r\n * Updates the existing vertex data of the mesh geometry for the requested `kind`.\r\n * If the mesh has no geometry, it is simply returned as it is.\r\n * The `data` are either a numeric array either a Float32Array.\r\n * No new underlying VertexBuffer object is created.\r\n * If the `kind` is the `PositionKind` and if `updateExtends` is true, the mesh BoundingInfo is renewed, so the bounding box and sphere, and the mesh World Matrix is recomputed.\r\n * If the parameter `makeItUnique` is true, a new global geometry is created from this positions and is set to the mesh.\r\n *\r\n * Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n *\r\n * Returns the Mesh.\r\n */\r\n InstancedMesh.prototype.updateVerticesData = function (kind, data, updateExtends, makeItUnique) {\r\n if (this.sourceMesh) {\r\n this.sourceMesh.updateVerticesData(kind, data, updateExtends, makeItUnique);\r\n }\r\n return this.sourceMesh;\r\n };\r\n /**\r\n * Sets the mesh indices.\r\n * Expects an array populated with integers or a typed array (Int32Array, Uint32Array, Uint16Array).\r\n * If the mesh has no geometry, a new Geometry object is created and set to the mesh.\r\n * This method creates a new index buffer each call.\r\n * Returns the Mesh.\r\n */\r\n InstancedMesh.prototype.setIndices = function (indices, totalVertices) {\r\n if (totalVertices === void 0) { totalVertices = null; }\r\n if (this.sourceMesh) {\r\n this.sourceMesh.setIndices(indices, totalVertices);\r\n }\r\n return this.sourceMesh;\r\n };\r\n /**\r\n * Boolean : True if the mesh owns the requested kind of data.\r\n */\r\n InstancedMesh.prototype.isVerticesDataPresent = function (kind) {\r\n return this._sourceMesh.isVerticesDataPresent(kind);\r\n };\r\n /**\r\n * Returns an array of indices (IndicesArray).\r\n */\r\n InstancedMesh.prototype.getIndices = function () {\r\n return this._sourceMesh.getIndices();\r\n };\r\n Object.defineProperty(InstancedMesh.prototype, \"_positions\", {\r\n get: function () {\r\n return this._sourceMesh._positions;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * This method recomputes and sets a new BoundingInfo to the mesh unless it is locked.\r\n * This means the mesh underlying bounding box and sphere are recomputed.\r\n * @param applySkeleton defines whether to apply the skeleton before computing the bounding info\r\n * @returns the current mesh\r\n */\r\n InstancedMesh.prototype.refreshBoundingInfo = function (applySkeleton) {\r\n if (applySkeleton === void 0) { applySkeleton = false; }\r\n if (this._boundingInfo && this._boundingInfo.isLocked) {\r\n return this;\r\n }\r\n var bias = this._sourceMesh.geometry ? this._sourceMesh.geometry.boundingBias : null;\r\n this._refreshBoundingInfo(this._sourceMesh._getPositionData(applySkeleton), bias);\r\n return this;\r\n };\r\n /** @hidden */\r\n InstancedMesh.prototype._preActivate = function () {\r\n if (this._currentLOD) {\r\n this._currentLOD._preActivate();\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n InstancedMesh.prototype._activate = function (renderId, intermediateRendering) {\r\n if (!this._sourceMesh.subMeshes) {\r\n Logger.Warn(\"Instances should only be created for meshes with geometry.\");\r\n }\r\n if (this._currentLOD) {\r\n var differentSign = (this._currentLOD._getWorldMatrixDeterminant() > 0) !== (this._getWorldMatrixDeterminant() > 0);\r\n if (differentSign) {\r\n this._internalAbstractMeshDataInfo._actAsRegularMesh = true;\r\n return true;\r\n }\r\n this._internalAbstractMeshDataInfo._actAsRegularMesh = false;\r\n this._currentLOD._registerInstanceForRenderId(this, renderId);\r\n if (intermediateRendering) {\r\n if (!this._currentLOD._internalAbstractMeshDataInfo._isActiveIntermediate) {\r\n this._currentLOD._internalAbstractMeshDataInfo._onlyForInstancesIntermediate = true;\r\n return true;\r\n }\r\n }\r\n else {\r\n if (!this._currentLOD._internalAbstractMeshDataInfo._isActive) {\r\n this._currentLOD._internalAbstractMeshDataInfo._onlyForInstances = true;\r\n return true;\r\n }\r\n }\r\n }\r\n return false;\r\n };\r\n /** @hidden */\r\n InstancedMesh.prototype._postActivate = function () {\r\n if (this._edgesRenderer && this._edgesRenderer.isEnabled && this._sourceMesh._renderingGroup) {\r\n this._sourceMesh._renderingGroup._edgesRenderers.push(this._edgesRenderer);\r\n }\r\n };\r\n InstancedMesh.prototype.getWorldMatrix = function () {\r\n if (this._currentLOD && this._currentLOD.billboardMode !== TransformNode.BILLBOARDMODE_NONE && this._currentLOD._masterMesh !== this) {\r\n var tempMaster = this._currentLOD._masterMesh;\r\n this._currentLOD._masterMesh = this;\r\n TmpVectors.Vector3[7].copyFrom(this._currentLOD.position);\r\n this._currentLOD.position.set(0, 0, 0);\r\n TmpVectors.Matrix[0].copyFrom(this._currentLOD.computeWorldMatrix(true));\r\n this._currentLOD.position.copyFrom(TmpVectors.Vector3[7]);\r\n this._currentLOD._masterMesh = tempMaster;\r\n return TmpVectors.Matrix[0];\r\n }\r\n return _super.prototype.getWorldMatrix.call(this);\r\n };\r\n Object.defineProperty(InstancedMesh.prototype, \"isAnInstance\", {\r\n get: function () {\r\n return true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Returns the current associated LOD AbstractMesh.\r\n */\r\n InstancedMesh.prototype.getLOD = function (camera) {\r\n if (!camera) {\r\n return this;\r\n }\r\n var boundingInfo = this.getBoundingInfo();\r\n this._currentLOD = this.sourceMesh.getLOD(camera, boundingInfo.boundingSphere);\r\n if (this._currentLOD === this.sourceMesh) {\r\n return this.sourceMesh;\r\n }\r\n return this._currentLOD;\r\n };\r\n /** @hidden */\r\n InstancedMesh.prototype._preActivateForIntermediateRendering = function (renderId) {\r\n return this.sourceMesh._preActivateForIntermediateRendering(renderId);\r\n };\r\n /** @hidden */\r\n InstancedMesh.prototype._syncSubMeshes = function () {\r\n this.releaseSubMeshes();\r\n if (this._sourceMesh.subMeshes) {\r\n for (var index = 0; index < this._sourceMesh.subMeshes.length; index++) {\r\n this._sourceMesh.subMeshes[index].clone(this, this._sourceMesh);\r\n }\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n InstancedMesh.prototype._generatePointsArray = function () {\r\n return this._sourceMesh._generatePointsArray();\r\n };\r\n /**\r\n * Creates a new InstancedMesh from the current mesh.\r\n * - name (string) : the cloned mesh name\r\n * - newParent (optional Node) : the optional Node to parent the clone to.\r\n * - doNotCloneChildren (optional boolean, default `false`) : if `true` the model children aren't cloned.\r\n *\r\n * Returns the clone.\r\n */\r\n InstancedMesh.prototype.clone = function (name, newParent, doNotCloneChildren) {\r\n if (newParent === void 0) { newParent = null; }\r\n var result = this._sourceMesh.createInstance(name);\r\n // Deep copy\r\n DeepCopier.DeepCopy(this, result, [\"name\", \"subMeshes\", \"uniqueId\", \"parent\"], []);\r\n // Bounding info\r\n this.refreshBoundingInfo();\r\n // Parent\r\n if (newParent) {\r\n result.parent = newParent;\r\n }\r\n if (!doNotCloneChildren) {\r\n // Children\r\n for (var index = 0; index < this.getScene().meshes.length; index++) {\r\n var mesh = this.getScene().meshes[index];\r\n if (mesh.parent === this) {\r\n mesh.clone(mesh.name, result);\r\n }\r\n }\r\n }\r\n result.computeWorldMatrix(true);\r\n return result;\r\n };\r\n /**\r\n * Disposes the InstancedMesh.\r\n * Returns nothing.\r\n */\r\n InstancedMesh.prototype.dispose = function (doNotRecurse, disposeMaterialAndTextures) {\r\n if (disposeMaterialAndTextures === void 0) { disposeMaterialAndTextures = false; }\r\n // Remove from mesh\r\n this._sourceMesh.removeInstance(this);\r\n _super.prototype.dispose.call(this, doNotRecurse, disposeMaterialAndTextures);\r\n };\r\n return InstancedMesh;\r\n}(AbstractMesh));\r\nexport { InstancedMesh };\r\nMesh.prototype.registerInstancedBuffer = function (kind, stride) {\r\n // Remove existing one\r\n this.removeVerticesData(kind);\r\n // Creates the instancedBuffer field if not present\r\n if (!this.instancedBuffers) {\r\n this.instancedBuffers = {};\r\n for (var _i = 0, _a = this.instances; _i < _a.length; _i++) {\r\n var instance = _a[_i];\r\n instance.instancedBuffers = {};\r\n }\r\n this._userInstancedBuffersStorage = {\r\n data: {},\r\n vertexBuffers: {},\r\n strides: {},\r\n sizes: {}\r\n };\r\n }\r\n // Creates an empty property for this kind\r\n this.instancedBuffers[kind] = null;\r\n this._userInstancedBuffersStorage.strides[kind] = stride;\r\n this._userInstancedBuffersStorage.sizes[kind] = stride * 32; // Initial size\r\n this._userInstancedBuffersStorage.data[kind] = new Float32Array(this._userInstancedBuffersStorage.sizes[kind]);\r\n this._userInstancedBuffersStorage.vertexBuffers[kind] = new VertexBuffer(this.getEngine(), this._userInstancedBuffersStorage.data[kind], kind, true, false, stride, true);\r\n this.setVerticesBuffer(this._userInstancedBuffersStorage.vertexBuffers[kind]);\r\n for (var _b = 0, _c = this.instances; _b < _c.length; _b++) {\r\n var instance = _c[_b];\r\n instance.instancedBuffers[kind] = null;\r\n }\r\n};\r\nMesh.prototype._processInstancedBuffers = function (visibleInstances, renderSelf) {\r\n var instanceCount = visibleInstances.length;\r\n for (var kind in this.instancedBuffers) {\r\n var size = this._userInstancedBuffersStorage.sizes[kind];\r\n var stride = this._userInstancedBuffersStorage.strides[kind];\r\n // Resize if required\r\n var expectedSize = (instanceCount + 1) * stride;\r\n while (size < expectedSize) {\r\n size *= 2;\r\n }\r\n if (this._userInstancedBuffersStorage.data[kind].length != size) {\r\n this._userInstancedBuffersStorage.data[kind] = new Float32Array(size);\r\n this._userInstancedBuffersStorage.sizes[kind] = size;\r\n if (this._userInstancedBuffersStorage.vertexBuffers[kind]) {\r\n this._userInstancedBuffersStorage.vertexBuffers[kind].dispose();\r\n this._userInstancedBuffersStorage.vertexBuffers[kind] = null;\r\n }\r\n }\r\n var data = this._userInstancedBuffersStorage.data[kind];\r\n // Update data buffer\r\n var offset = 0;\r\n if (renderSelf) {\r\n offset += stride;\r\n var value = this.instancedBuffers[kind];\r\n if (value.toArray) {\r\n value.toArray(data, offset);\r\n }\r\n else {\r\n value.copyToArray(data, offset);\r\n }\r\n }\r\n for (var instanceIndex = 0; instanceIndex < instanceCount; instanceIndex++) {\r\n var instance = visibleInstances[instanceIndex];\r\n var value = instance.instancedBuffers[kind];\r\n if (value.toArray) {\r\n value.toArray(data, offset);\r\n }\r\n else {\r\n value.copyToArray(data, offset);\r\n }\r\n offset += stride;\r\n }\r\n // Update vertex buffer\r\n if (!this._userInstancedBuffersStorage.vertexBuffers[kind]) {\r\n this._userInstancedBuffersStorage.vertexBuffers[kind] = new VertexBuffer(this.getEngine(), this._userInstancedBuffersStorage.data[kind], kind, true, false, stride, true);\r\n this.setVerticesBuffer(this._userInstancedBuffersStorage.vertexBuffers[kind]);\r\n }\r\n else {\r\n this._userInstancedBuffersStorage.vertexBuffers[kind].updateDirectly(data, 0);\r\n }\r\n }\r\n};\r\nMesh.prototype._disposeInstanceSpecificData = function () {\r\n if (this._instanceDataStorage.instancesBuffer) {\r\n this._instanceDataStorage.instancesBuffer.dispose();\r\n this._instanceDataStorage.instancesBuffer = null;\r\n }\r\n while (this.instances.length) {\r\n this.instances[0].dispose();\r\n }\r\n for (var kind in this.instancedBuffers) {\r\n if (this._userInstancedBuffersStorage.vertexBuffers[kind]) {\r\n this._userInstancedBuffersStorage.vertexBuffers[kind].dispose();\r\n }\r\n }\r\n this.instancedBuffers = {};\r\n};\r\n//# sourceMappingURL=instancedMesh.js.map","import { __assign, __extends } from \"tslib\";\r\nimport { SerializationHelper } from \"../Misc/decorators\";\r\nimport { Matrix, Vector3, Vector2, Vector4 } from \"../Maths/math.vector\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { Texture } from \"../Materials/Textures/texture\";\r\nimport { MaterialHelper } from \"./materialHelper\";\r\nimport { Material } from \"./material\";\r\nimport { _TypeStore } from '../Misc/typeStore';\r\nimport { Color3, Color4 } from '../Maths/math.color';\r\nimport { EffectFallbacks } from './effectFallbacks';\r\n/**\r\n * The ShaderMaterial object has the necessary methods to pass data from your scene to the Vertex and Fragment Shaders and returns a material that can be applied to any mesh.\r\n *\r\n * This returned material effects how the mesh will look based on the code in the shaders.\r\n *\r\n * @see http://doc.babylonjs.com/how_to/shader_material\r\n */\r\nvar ShaderMaterial = /** @class */ (function (_super) {\r\n __extends(ShaderMaterial, _super);\r\n /**\r\n * Instantiate a new shader material.\r\n * The ShaderMaterial object has the necessary methods to pass data from your scene to the Vertex and Fragment Shaders and returns a material that can be applied to any mesh.\r\n * This returned material effects how the mesh will look based on the code in the shaders.\r\n * @see http://doc.babylonjs.com/how_to/shader_material\r\n * @param name Define the name of the material in the scene\r\n * @param scene Define the scene the material belongs to\r\n * @param shaderPath Defines the route to the shader code in one of three ways:\r\n * * object: { vertex: \"custom\", fragment: \"custom\" }, used with Effect.ShadersStore[\"customVertexShader\"] and Effect.ShadersStore[\"customFragmentShader\"]\r\n * * object: { vertexElement: \"vertexShaderCode\", fragmentElement: \"fragmentShaderCode\" }, used with shader code in script tags\r\n * * object: { vertexSource: \"vertex shader code string\", fragmentSource: \"fragment shader code string\" } using with strings containing the shaders code\r\n * * string: \"./COMMON_NAME\", used with external files COMMON_NAME.vertex.fx and COMMON_NAME.fragment.fx in index.html folder.\r\n * @param options Define the options used to create the shader\r\n */\r\n function ShaderMaterial(name, scene, shaderPath, options) {\r\n if (options === void 0) { options = {}; }\r\n var _this = _super.call(this, name, scene) || this;\r\n _this._textures = {};\r\n _this._textureArrays = {};\r\n _this._floats = {};\r\n _this._ints = {};\r\n _this._floatsArrays = {};\r\n _this._colors3 = {};\r\n _this._colors3Arrays = {};\r\n _this._colors4 = {};\r\n _this._colors4Arrays = {};\r\n _this._vectors2 = {};\r\n _this._vectors3 = {};\r\n _this._vectors4 = {};\r\n _this._matrices = {};\r\n _this._matrixArrays = {};\r\n _this._matrices3x3 = {};\r\n _this._matrices2x2 = {};\r\n _this._vectors2Arrays = {};\r\n _this._vectors3Arrays = {};\r\n _this._vectors4Arrays = {};\r\n _this._cachedWorldViewMatrix = new Matrix();\r\n _this._cachedWorldViewProjectionMatrix = new Matrix();\r\n _this._multiview = false;\r\n _this._shaderPath = shaderPath;\r\n _this._options = __assign({ needAlphaBlending: false, needAlphaTesting: false, attributes: [\"position\", \"normal\", \"uv\"], uniforms: [\"worldViewProjection\"], uniformBuffers: [], samplers: [], defines: [] }, options);\r\n return _this;\r\n }\r\n Object.defineProperty(ShaderMaterial.prototype, \"shaderPath\", {\r\n /**\r\n * Gets the shader path used to define the shader code\r\n * It can be modified to trigger a new compilation\r\n */\r\n get: function () {\r\n return this._shaderPath;\r\n },\r\n /**\r\n * Sets the shader path used to define the shader code\r\n * It can be modified to trigger a new compilation\r\n */\r\n set: function (shaderPath) {\r\n this._shaderPath = shaderPath;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ShaderMaterial.prototype, \"options\", {\r\n /**\r\n * Gets the options used to compile the shader.\r\n * They can be modified to trigger a new compilation\r\n */\r\n get: function () {\r\n return this._options;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the current class name of the material e.g. \"ShaderMaterial\"\r\n * Mainly use in serialization.\r\n * @returns the class name\r\n */\r\n ShaderMaterial.prototype.getClassName = function () {\r\n return \"ShaderMaterial\";\r\n };\r\n /**\r\n * Specifies if the material will require alpha blending\r\n * @returns a boolean specifying if alpha blending is needed\r\n */\r\n ShaderMaterial.prototype.needAlphaBlending = function () {\r\n return (this.alpha < 1.0) || this._options.needAlphaBlending;\r\n };\r\n /**\r\n * Specifies if this material should be rendered in alpha test mode\r\n * @returns a boolean specifying if an alpha test is needed.\r\n */\r\n ShaderMaterial.prototype.needAlphaTesting = function () {\r\n return this._options.needAlphaTesting;\r\n };\r\n ShaderMaterial.prototype._checkUniform = function (uniformName) {\r\n if (this._options.uniforms.indexOf(uniformName) === -1) {\r\n this._options.uniforms.push(uniformName);\r\n }\r\n };\r\n /**\r\n * Set a texture in the shader.\r\n * @param name Define the name of the uniform samplers as defined in the shader\r\n * @param texture Define the texture to bind to this sampler\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setTexture = function (name, texture) {\r\n if (this._options.samplers.indexOf(name) === -1) {\r\n this._options.samplers.push(name);\r\n }\r\n this._textures[name] = texture;\r\n return this;\r\n };\r\n /**\r\n * Set a texture array in the shader.\r\n * @param name Define the name of the uniform sampler array as defined in the shader\r\n * @param textures Define the list of textures to bind to this sampler\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setTextureArray = function (name, textures) {\r\n if (this._options.samplers.indexOf(name) === -1) {\r\n this._options.samplers.push(name);\r\n }\r\n this._checkUniform(name);\r\n this._textureArrays[name] = textures;\r\n return this;\r\n };\r\n /**\r\n * Set a float in the shader.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setFloat = function (name, value) {\r\n this._checkUniform(name);\r\n this._floats[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a int in the shader.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setInt = function (name, value) {\r\n this._checkUniform(name);\r\n this._ints[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set an array of floats in the shader.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setFloats = function (name, value) {\r\n this._checkUniform(name);\r\n this._floatsArrays[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a vec3 in the shader from a Color3.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setColor3 = function (name, value) {\r\n this._checkUniform(name);\r\n this._colors3[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a vec3 array in the shader from a Color3 array.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setColor3Array = function (name, value) {\r\n this._checkUniform(name);\r\n this._colors3Arrays[name] = value.reduce(function (arr, color) {\r\n color.toArray(arr, arr.length);\r\n return arr;\r\n }, []);\r\n return this;\r\n };\r\n /**\r\n * Set a vec4 in the shader from a Color4.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setColor4 = function (name, value) {\r\n this._checkUniform(name);\r\n this._colors4[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a vec4 array in the shader from a Color4 array.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setColor4Array = function (name, value) {\r\n this._checkUniform(name);\r\n this._colors4Arrays[name] = value.reduce(function (arr, color) {\r\n color.toArray(arr, arr.length);\r\n return arr;\r\n }, []);\r\n return this;\r\n };\r\n /**\r\n * Set a vec2 in the shader from a Vector2.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setVector2 = function (name, value) {\r\n this._checkUniform(name);\r\n this._vectors2[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a vec3 in the shader from a Vector3.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setVector3 = function (name, value) {\r\n this._checkUniform(name);\r\n this._vectors3[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a vec4 in the shader from a Vector4.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setVector4 = function (name, value) {\r\n this._checkUniform(name);\r\n this._vectors4[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a mat4 in the shader from a Matrix.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setMatrix = function (name, value) {\r\n this._checkUniform(name);\r\n this._matrices[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a float32Array in the shader from a matrix array.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setMatrices = function (name, value) {\r\n this._checkUniform(name);\r\n var float32Array = new Float32Array(value.length * 16);\r\n for (var index = 0; index < value.length; index++) {\r\n var matrix = value[index];\r\n matrix.copyToArray(float32Array, index * 16);\r\n }\r\n this._matrixArrays[name] = float32Array;\r\n return this;\r\n };\r\n /**\r\n * Set a mat3 in the shader from a Float32Array.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setMatrix3x3 = function (name, value) {\r\n this._checkUniform(name);\r\n this._matrices3x3[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a mat2 in the shader from a Float32Array.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setMatrix2x2 = function (name, value) {\r\n this._checkUniform(name);\r\n this._matrices2x2[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a vec2 array in the shader from a number array.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setArray2 = function (name, value) {\r\n this._checkUniform(name);\r\n this._vectors2Arrays[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a vec3 array in the shader from a number array.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setArray3 = function (name, value) {\r\n this._checkUniform(name);\r\n this._vectors3Arrays[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a vec4 array in the shader from a number array.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setArray4 = function (name, value) {\r\n this._checkUniform(name);\r\n this._vectors4Arrays[name] = value;\r\n return this;\r\n };\r\n ShaderMaterial.prototype._checkCache = function (mesh, useInstances) {\r\n if (!mesh) {\r\n return true;\r\n }\r\n if (this._effect && (this._effect.defines.indexOf(\"#define INSTANCES\") !== -1) !== useInstances) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n /**\r\n * Specifies that the submesh is ready to be used\r\n * @param mesh defines the mesh to check\r\n * @param subMesh defines which submesh to check\r\n * @param useInstances specifies that instances should be used\r\n * @returns a boolean indicating that the submesh is ready or not\r\n */\r\n ShaderMaterial.prototype.isReadyForSubMesh = function (mesh, subMesh, useInstances) {\r\n return this.isReady(mesh, useInstances);\r\n };\r\n /**\r\n * Checks if the material is ready to render the requested mesh\r\n * @param mesh Define the mesh to render\r\n * @param useInstances Define whether or not the material is used with instances\r\n * @returns true if ready, otherwise false\r\n */\r\n ShaderMaterial.prototype.isReady = function (mesh, useInstances) {\r\n if (this._effect && this.isFrozen) {\r\n if (this._effect._wasPreviouslyReady) {\r\n return true;\r\n }\r\n }\r\n var scene = this.getScene();\r\n var engine = scene.getEngine();\r\n if (!this.checkReadyOnEveryCall) {\r\n if (this._renderId === scene.getRenderId()) {\r\n if (this._checkCache(mesh, useInstances)) {\r\n return true;\r\n }\r\n }\r\n }\r\n // Instances\r\n var defines = [];\r\n var attribs = [];\r\n var fallbacks = new EffectFallbacks();\r\n // global multiview\r\n if (engine.getCaps().multiview &&\r\n scene.activeCamera &&\r\n scene.activeCamera.outputRenderTarget &&\r\n scene.activeCamera.outputRenderTarget.getViewCount() > 1) {\r\n this._multiview = true;\r\n defines.push(\"#define MULTIVIEW\");\r\n if (this._options.uniforms.indexOf(\"viewProjection\") !== -1 &&\r\n this._options.uniforms.push(\"viewProjectionR\") === -1) {\r\n this._options.uniforms.push(\"viewProjectionR\");\r\n }\r\n }\r\n for (var index = 0; index < this._options.defines.length; index++) {\r\n defines.push(this._options.defines[index]);\r\n }\r\n for (var index = 0; index < this._options.attributes.length; index++) {\r\n attribs.push(this._options.attributes[index]);\r\n }\r\n if (mesh && mesh.isVerticesDataPresent(VertexBuffer.ColorKind)) {\r\n attribs.push(VertexBuffer.ColorKind);\r\n defines.push(\"#define VERTEXCOLOR\");\r\n }\r\n if (useInstances) {\r\n defines.push(\"#define INSTANCES\");\r\n MaterialHelper.PushAttributesForInstances(attribs);\r\n }\r\n // Bones\r\n if (mesh && mesh.useBones && mesh.computeBonesUsingShaders && mesh.skeleton) {\r\n attribs.push(VertexBuffer.MatricesIndicesKind);\r\n attribs.push(VertexBuffer.MatricesWeightsKind);\r\n if (mesh.numBoneInfluencers > 4) {\r\n attribs.push(VertexBuffer.MatricesIndicesExtraKind);\r\n attribs.push(VertexBuffer.MatricesWeightsExtraKind);\r\n }\r\n var skeleton = mesh.skeleton;\r\n defines.push(\"#define NUM_BONE_INFLUENCERS \" + mesh.numBoneInfluencers);\r\n fallbacks.addCPUSkinningFallback(0, mesh);\r\n if (skeleton.isUsingTextureForMatrices) {\r\n defines.push(\"#define BONETEXTURE\");\r\n if (this._options.uniforms.indexOf(\"boneTextureWidth\") === -1) {\r\n this._options.uniforms.push(\"boneTextureWidth\");\r\n }\r\n if (this._options.samplers.indexOf(\"boneSampler\") === -1) {\r\n this._options.samplers.push(\"boneSampler\");\r\n }\r\n }\r\n else {\r\n defines.push(\"#define BonesPerMesh \" + (skeleton.bones.length + 1));\r\n if (this._options.uniforms.indexOf(\"mBones\") === -1) {\r\n this._options.uniforms.push(\"mBones\");\r\n }\r\n }\r\n }\r\n else {\r\n defines.push(\"#define NUM_BONE_INFLUENCERS 0\");\r\n }\r\n // Textures\r\n for (var name in this._textures) {\r\n if (!this._textures[name].isReady()) {\r\n return false;\r\n }\r\n }\r\n // Alpha test\r\n if (mesh && this._shouldTurnAlphaTestOn(mesh)) {\r\n defines.push(\"#define ALPHATEST\");\r\n }\r\n var previousEffect = this._effect;\r\n var join = defines.join(\"\\n\");\r\n this._effect = engine.createEffect(this._shaderPath, {\r\n attributes: attribs,\r\n uniformsNames: this._options.uniforms,\r\n uniformBuffersNames: this._options.uniformBuffers,\r\n samplers: this._options.samplers,\r\n defines: join,\r\n fallbacks: fallbacks,\r\n onCompiled: this.onCompiled,\r\n onError: this.onError\r\n }, engine);\r\n if (!this._effect.isReady()) {\r\n return false;\r\n }\r\n if (previousEffect !== this._effect) {\r\n scene.resetCachedMaterial();\r\n }\r\n this._renderId = scene.getRenderId();\r\n this._effect._wasPreviouslyReady = true;\r\n return true;\r\n };\r\n /**\r\n * Binds the world matrix to the material\r\n * @param world defines the world transformation matrix\r\n */\r\n ShaderMaterial.prototype.bindOnlyWorldMatrix = function (world) {\r\n var scene = this.getScene();\r\n if (!this._effect) {\r\n return;\r\n }\r\n if (this._options.uniforms.indexOf(\"world\") !== -1) {\r\n this._effect.setMatrix(\"world\", world);\r\n }\r\n if (this._options.uniforms.indexOf(\"worldView\") !== -1) {\r\n world.multiplyToRef(scene.getViewMatrix(), this._cachedWorldViewMatrix);\r\n this._effect.setMatrix(\"worldView\", this._cachedWorldViewMatrix);\r\n }\r\n if (this._options.uniforms.indexOf(\"worldViewProjection\") !== -1) {\r\n world.multiplyToRef(scene.getTransformMatrix(), this._cachedWorldViewProjectionMatrix);\r\n this._effect.setMatrix(\"worldViewProjection\", this._cachedWorldViewProjectionMatrix);\r\n }\r\n };\r\n /**\r\n * Binds the material to the mesh\r\n * @param world defines the world transformation matrix\r\n * @param mesh defines the mesh to bind the material to\r\n */\r\n ShaderMaterial.prototype.bind = function (world, mesh) {\r\n // Std values\r\n this.bindOnlyWorldMatrix(world);\r\n if (this._effect && this.getScene().getCachedMaterial() !== this) {\r\n if (this._options.uniforms.indexOf(\"view\") !== -1) {\r\n this._effect.setMatrix(\"view\", this.getScene().getViewMatrix());\r\n }\r\n if (this._options.uniforms.indexOf(\"projection\") !== -1) {\r\n this._effect.setMatrix(\"projection\", this.getScene().getProjectionMatrix());\r\n }\r\n if (this._options.uniforms.indexOf(\"viewProjection\") !== -1) {\r\n this._effect.setMatrix(\"viewProjection\", this.getScene().getTransformMatrix());\r\n if (this._multiview) {\r\n this._effect.setMatrix(\"viewProjectionR\", this.getScene()._transformMatrixR);\r\n }\r\n }\r\n if (this.getScene().activeCamera && this._options.uniforms.indexOf(\"cameraPosition\") !== -1) {\r\n this._effect.setVector3(\"cameraPosition\", this.getScene().activeCamera.globalPosition);\r\n }\r\n // Bones\r\n MaterialHelper.BindBonesParameters(mesh, this._effect);\r\n var name;\r\n // Texture\r\n for (name in this._textures) {\r\n this._effect.setTexture(name, this._textures[name]);\r\n }\r\n // Texture arrays\r\n for (name in this._textureArrays) {\r\n this._effect.setTextureArray(name, this._textureArrays[name]);\r\n }\r\n // Int\r\n for (name in this._ints) {\r\n this._effect.setInt(name, this._ints[name]);\r\n }\r\n // Float\r\n for (name in this._floats) {\r\n this._effect.setFloat(name, this._floats[name]);\r\n }\r\n // Floats\r\n for (name in this._floatsArrays) {\r\n this._effect.setArray(name, this._floatsArrays[name]);\r\n }\r\n // Color3\r\n for (name in this._colors3) {\r\n this._effect.setColor3(name, this._colors3[name]);\r\n }\r\n // Color3Array\r\n for (name in this._colors3Arrays) {\r\n this._effect.setArray3(name, this._colors3Arrays[name]);\r\n }\r\n // Color4\r\n for (name in this._colors4) {\r\n var color = this._colors4[name];\r\n this._effect.setFloat4(name, color.r, color.g, color.b, color.a);\r\n }\r\n // Color4Array\r\n for (name in this._colors4Arrays) {\r\n this._effect.setArray4(name, this._colors4Arrays[name]);\r\n }\r\n // Vector2\r\n for (name in this._vectors2) {\r\n this._effect.setVector2(name, this._vectors2[name]);\r\n }\r\n // Vector3\r\n for (name in this._vectors3) {\r\n this._effect.setVector3(name, this._vectors3[name]);\r\n }\r\n // Vector4\r\n for (name in this._vectors4) {\r\n this._effect.setVector4(name, this._vectors4[name]);\r\n }\r\n // Matrix\r\n for (name in this._matrices) {\r\n this._effect.setMatrix(name, this._matrices[name]);\r\n }\r\n // MatrixArray\r\n for (name in this._matrixArrays) {\r\n this._effect.setMatrices(name, this._matrixArrays[name]);\r\n }\r\n // Matrix 3x3\r\n for (name in this._matrices3x3) {\r\n this._effect.setMatrix3x3(name, this._matrices3x3[name]);\r\n }\r\n // Matrix 2x2\r\n for (name in this._matrices2x2) {\r\n this._effect.setMatrix2x2(name, this._matrices2x2[name]);\r\n }\r\n // Vector2Array\r\n for (name in this._vectors2Arrays) {\r\n this._effect.setArray2(name, this._vectors2Arrays[name]);\r\n }\r\n // Vector3Array\r\n for (name in this._vectors3Arrays) {\r\n this._effect.setArray3(name, this._vectors3Arrays[name]);\r\n }\r\n // Vector4Array\r\n for (name in this._vectors4Arrays) {\r\n this._effect.setArray4(name, this._vectors4Arrays[name]);\r\n }\r\n }\r\n this._afterBind(mesh);\r\n };\r\n /**\r\n * Gets the active textures from the material\r\n * @returns an array of textures\r\n */\r\n ShaderMaterial.prototype.getActiveTextures = function () {\r\n var activeTextures = _super.prototype.getActiveTextures.call(this);\r\n for (var name in this._textures) {\r\n activeTextures.push(this._textures[name]);\r\n }\r\n for (var name in this._textureArrays) {\r\n var array = this._textureArrays[name];\r\n for (var index = 0; index < array.length; index++) {\r\n activeTextures.push(array[index]);\r\n }\r\n }\r\n return activeTextures;\r\n };\r\n /**\r\n * Specifies if the material uses a texture\r\n * @param texture defines the texture to check against the material\r\n * @returns a boolean specifying if the material uses the texture\r\n */\r\n ShaderMaterial.prototype.hasTexture = function (texture) {\r\n if (_super.prototype.hasTexture.call(this, texture)) {\r\n return true;\r\n }\r\n for (var name in this._textures) {\r\n if (this._textures[name] === texture) {\r\n return true;\r\n }\r\n }\r\n for (var name in this._textureArrays) {\r\n var array = this._textureArrays[name];\r\n for (var index = 0; index < array.length; index++) {\r\n if (array[index] === texture) {\r\n return true;\r\n }\r\n }\r\n }\r\n return false;\r\n };\r\n /**\r\n * Makes a duplicate of the material, and gives it a new name\r\n * @param name defines the new name for the duplicated material\r\n * @returns the cloned material\r\n */\r\n ShaderMaterial.prototype.clone = function (name) {\r\n var _this = this;\r\n var result = SerializationHelper.Clone(function () { return new ShaderMaterial(name, _this.getScene(), _this._shaderPath, _this._options); }, this);\r\n result.name = name;\r\n result.id = name;\r\n // Shader code path\r\n if (typeof result._shaderPath === 'object') {\r\n result._shaderPath = __assign({}, result._shaderPath);\r\n }\r\n // Options\r\n this._options = __assign({}, this._options);\r\n Object.keys(this._options).forEach(function (propName) {\r\n var propValue = _this._options[propName];\r\n if (Array.isArray(propValue)) {\r\n _this._options[propName] = propValue.slice(0);\r\n }\r\n });\r\n // Texture\r\n for (var key in this._textures) {\r\n result.setTexture(key, this._textures[key]);\r\n }\r\n // Float\r\n for (var key in this._floats) {\r\n result.setFloat(key, this._floats[key]);\r\n }\r\n // Floats\r\n for (var key in this._floatsArrays) {\r\n result.setFloats(key, this._floatsArrays[key]);\r\n }\r\n // Color3\r\n for (var key in this._colors3) {\r\n result.setColor3(key, this._colors3[key]);\r\n }\r\n // Color4\r\n for (var key in this._colors4) {\r\n result.setColor4(key, this._colors4[key]);\r\n }\r\n // Vector2\r\n for (var key in this._vectors2) {\r\n result.setVector2(key, this._vectors2[key]);\r\n }\r\n // Vector3\r\n for (var key in this._vectors3) {\r\n result.setVector3(key, this._vectors3[key]);\r\n }\r\n // Vector4\r\n for (var key in this._vectors4) {\r\n result.setVector4(key, this._vectors4[key]);\r\n }\r\n // Matrix\r\n for (var key in this._matrices) {\r\n result.setMatrix(key, this._matrices[key]);\r\n }\r\n // Matrix 3x3\r\n for (var key in this._matrices3x3) {\r\n result.setMatrix3x3(key, this._matrices3x3[key]);\r\n }\r\n // Matrix 2x2\r\n for (var key in this._matrices2x2) {\r\n result.setMatrix2x2(key, this._matrices2x2[key]);\r\n }\r\n return result;\r\n };\r\n /**\r\n * Disposes the material\r\n * @param forceDisposeEffect specifies if effects should be forcefully disposed\r\n * @param forceDisposeTextures specifies if textures should be forcefully disposed\r\n * @param notBoundToMesh specifies if the material that is being disposed is known to be not bound to any mesh\r\n */\r\n ShaderMaterial.prototype.dispose = function (forceDisposeEffect, forceDisposeTextures, notBoundToMesh) {\r\n if (forceDisposeTextures) {\r\n var name;\r\n for (name in this._textures) {\r\n this._textures[name].dispose();\r\n }\r\n for (name in this._textureArrays) {\r\n var array = this._textureArrays[name];\r\n for (var index = 0; index < array.length; index++) {\r\n array[index].dispose();\r\n }\r\n }\r\n }\r\n this._textures = {};\r\n _super.prototype.dispose.call(this, forceDisposeEffect, forceDisposeTextures, notBoundToMesh);\r\n };\r\n /**\r\n * Serializes this material in a JSON representation\r\n * @returns the serialized material object\r\n */\r\n ShaderMaterial.prototype.serialize = function () {\r\n var serializationObject = SerializationHelper.Serialize(this);\r\n serializationObject.customType = \"BABYLON.ShaderMaterial\";\r\n serializationObject.options = this._options;\r\n serializationObject.shaderPath = this._shaderPath;\r\n var name;\r\n // Texture\r\n serializationObject.textures = {};\r\n for (name in this._textures) {\r\n serializationObject.textures[name] = this._textures[name].serialize();\r\n }\r\n // Texture arrays\r\n serializationObject.textureArrays = {};\r\n for (name in this._textureArrays) {\r\n serializationObject.textureArrays[name] = [];\r\n var array = this._textureArrays[name];\r\n for (var index = 0; index < array.length; index++) {\r\n serializationObject.textureArrays[name].push(array[index].serialize());\r\n }\r\n }\r\n // Float\r\n serializationObject.floats = {};\r\n for (name in this._floats) {\r\n serializationObject.floats[name] = this._floats[name];\r\n }\r\n // Floats\r\n serializationObject.FloatArrays = {};\r\n for (name in this._floatsArrays) {\r\n serializationObject.FloatArrays[name] = this._floatsArrays[name];\r\n }\r\n // Color3\r\n serializationObject.colors3 = {};\r\n for (name in this._colors3) {\r\n serializationObject.colors3[name] = this._colors3[name].asArray();\r\n }\r\n // Color3 array\r\n serializationObject.colors3Arrays = {};\r\n for (name in this._colors3Arrays) {\r\n serializationObject.colors3Arrays[name] = this._colors3Arrays[name];\r\n }\r\n // Color4\r\n serializationObject.colors4 = {};\r\n for (name in this._colors4) {\r\n serializationObject.colors4[name] = this._colors4[name].asArray();\r\n }\r\n // Color4 array\r\n serializationObject.colors4Arrays = {};\r\n for (name in this._colors4Arrays) {\r\n serializationObject.colors4Arrays[name] = this._colors4Arrays[name];\r\n }\r\n // Vector2\r\n serializationObject.vectors2 = {};\r\n for (name in this._vectors2) {\r\n serializationObject.vectors2[name] = this._vectors2[name].asArray();\r\n }\r\n // Vector3\r\n serializationObject.vectors3 = {};\r\n for (name in this._vectors3) {\r\n serializationObject.vectors3[name] = this._vectors3[name].asArray();\r\n }\r\n // Vector4\r\n serializationObject.vectors4 = {};\r\n for (name in this._vectors4) {\r\n serializationObject.vectors4[name] = this._vectors4[name].asArray();\r\n }\r\n // Matrix\r\n serializationObject.matrices = {};\r\n for (name in this._matrices) {\r\n serializationObject.matrices[name] = this._matrices[name].asArray();\r\n }\r\n // MatrixArray\r\n serializationObject.matrixArray = {};\r\n for (name in this._matrixArrays) {\r\n serializationObject.matrixArray[name] = this._matrixArrays[name];\r\n }\r\n // Matrix 3x3\r\n serializationObject.matrices3x3 = {};\r\n for (name in this._matrices3x3) {\r\n serializationObject.matrices3x3[name] = this._matrices3x3[name];\r\n }\r\n // Matrix 2x2\r\n serializationObject.matrices2x2 = {};\r\n for (name in this._matrices2x2) {\r\n serializationObject.matrices2x2[name] = this._matrices2x2[name];\r\n }\r\n // Vector2Array\r\n serializationObject.vectors2Arrays = {};\r\n for (name in this._vectors2Arrays) {\r\n serializationObject.vectors2Arrays[name] = this._vectors2Arrays[name];\r\n }\r\n // Vector3Array\r\n serializationObject.vectors3Arrays = {};\r\n for (name in this._vectors3Arrays) {\r\n serializationObject.vectors3Arrays[name] = this._vectors3Arrays[name];\r\n }\r\n // Vector4Array\r\n serializationObject.vectors4Arrays = {};\r\n for (name in this._vectors4Arrays) {\r\n serializationObject.vectors4Arrays[name] = this._vectors4Arrays[name];\r\n }\r\n return serializationObject;\r\n };\r\n /**\r\n * Creates a shader material from parsed shader material data\r\n * @param source defines the JSON represnetation of the material\r\n * @param scene defines the hosting scene\r\n * @param rootUrl defines the root URL to use to load textures and relative dependencies\r\n * @returns a new material\r\n */\r\n ShaderMaterial.Parse = function (source, scene, rootUrl) {\r\n var material = SerializationHelper.Parse(function () { return new ShaderMaterial(source.name, scene, source.shaderPath, source.options); }, source, scene, rootUrl);\r\n var name;\r\n // Texture\r\n for (name in source.textures) {\r\n material.setTexture(name, Texture.Parse(source.textures[name], scene, rootUrl));\r\n }\r\n // Texture arrays\r\n for (name in source.textureArrays) {\r\n var array = source.textureArrays[name];\r\n var textureArray = new Array();\r\n for (var index = 0; index < array.length; index++) {\r\n textureArray.push(Texture.Parse(array[index], scene, rootUrl));\r\n }\r\n material.setTextureArray(name, textureArray);\r\n }\r\n // Float\r\n for (name in source.floats) {\r\n material.setFloat(name, source.floats[name]);\r\n }\r\n // Float s\r\n for (name in source.floatsArrays) {\r\n material.setFloats(name, source.floatsArrays[name]);\r\n }\r\n // Color3\r\n for (name in source.colors3) {\r\n material.setColor3(name, Color3.FromArray(source.colors3[name]));\r\n }\r\n // Color3 arrays\r\n for (name in source.colors3Arrays) {\r\n var colors = source.colors3Arrays[name].reduce(function (arr, num, i) {\r\n if (i % 3 === 0) {\r\n arr.push([num]);\r\n }\r\n else {\r\n arr[arr.length - 1].push(num);\r\n }\r\n return arr;\r\n }, []).map(function (color) { return Color3.FromArray(color); });\r\n material.setColor3Array(name, colors);\r\n }\r\n // Color4\r\n for (name in source.colors4) {\r\n material.setColor4(name, Color4.FromArray(source.colors4[name]));\r\n }\r\n // Color4 arrays\r\n for (name in source.colors4Arrays) {\r\n var colors = source.colors4Arrays[name].reduce(function (arr, num, i) {\r\n if (i % 4 === 0) {\r\n arr.push([num]);\r\n }\r\n else {\r\n arr[arr.length - 1].push(num);\r\n }\r\n return arr;\r\n }, []).map(function (color) { return Color4.FromArray(color); });\r\n material.setColor4Array(name, colors);\r\n }\r\n // Vector2\r\n for (name in source.vectors2) {\r\n material.setVector2(name, Vector2.FromArray(source.vectors2[name]));\r\n }\r\n // Vector3\r\n for (name in source.vectors3) {\r\n material.setVector3(name, Vector3.FromArray(source.vectors3[name]));\r\n }\r\n // Vector4\r\n for (name in source.vectors4) {\r\n material.setVector4(name, Vector4.FromArray(source.vectors4[name]));\r\n }\r\n // Matrix\r\n for (name in source.matrices) {\r\n material.setMatrix(name, Matrix.FromArray(source.matrices[name]));\r\n }\r\n // MatrixArray\r\n for (name in source.matrixArray) {\r\n material._matrixArrays[name] = new Float32Array(source.matrixArray[name]);\r\n }\r\n // Matrix 3x3\r\n for (name in source.matrices3x3) {\r\n material.setMatrix3x3(name, source.matrices3x3[name]);\r\n }\r\n // Matrix 2x2\r\n for (name in source.matrices2x2) {\r\n material.setMatrix2x2(name, source.matrices2x2[name]);\r\n }\r\n // Vector2Array\r\n for (name in source.vectors2Arrays) {\r\n material.setArray2(name, source.vectors2Arrays[name]);\r\n }\r\n // Vector3Array\r\n for (name in source.vectors3Arrays) {\r\n material.setArray3(name, source.vectors3Arrays[name]);\r\n }\r\n // Vector4Array\r\n for (name in source.vectors4Arrays) {\r\n material.setArray4(name, source.vectors4Arrays[name]);\r\n }\r\n return material;\r\n };\r\n return ShaderMaterial;\r\n}(Material));\r\nexport { ShaderMaterial };\r\n_TypeStore.RegisteredTypes[\"BABYLON.ShaderMaterial\"] = ShaderMaterial;\r\n//# sourceMappingURL=shaderMaterial.js.map","import { Effect } from \"../Materials/effect\";\r\nimport \"./ShadersInclude/clipPlaneFragmentDeclaration\";\r\nimport \"./ShadersInclude/clipPlaneFragment\";\r\nvar name = 'colorPixelShader';\r\nvar shader = \"#ifdef VERTEXCOLOR\\nvarying vec4 vColor;\\n#else\\nuniform vec4 color;\\n#endif\\n#include\\nvoid main(void) {\\n#include\\n#ifdef VERTEXCOLOR\\ngl_FragColor=vColor;\\n#else\\ngl_FragColor=color;\\n#endif\\n}\";\r\nEffect.ShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var colorPixelShader = { name: name, shader: shader };\r\n//# sourceMappingURL=color.fragment.js.map","import { Effect } from \"../Materials/effect\";\r\nimport \"./ShadersInclude/bonesDeclaration\";\r\nimport \"./ShadersInclude/clipPlaneVertexDeclaration\";\r\nimport \"./ShadersInclude/instancesDeclaration\";\r\nimport \"./ShadersInclude/instancesVertex\";\r\nimport \"./ShadersInclude/bonesVertex\";\r\nimport \"./ShadersInclude/clipPlaneVertex\";\r\nvar name = 'colorVertexShader';\r\nvar shader = \"\\nattribute vec3 position;\\n#ifdef VERTEXCOLOR\\nattribute vec4 color;\\n#endif\\n#include\\n#include\\n\\n#include\\nuniform mat4 viewProjection;\\n#ifdef MULTIVIEW\\nuniform mat4 viewProjectionR;\\n#endif\\n\\n#ifdef VERTEXCOLOR\\nvarying vec4 vColor;\\n#endif\\nvoid main(void) {\\n#include\\n#include\\nvec4 worldPos=finalWorld*vec4(position,1.0);\\n#ifdef MULTIVIEW\\nif (gl_ViewID_OVR == 0u) {\\ngl_Position=viewProjection*worldPos;\\n} else {\\ngl_Position=viewProjectionR*worldPos;\\n}\\n#else\\ngl_Position=viewProjection*worldPos;\\n#endif\\n#include\\n#ifdef VERTEXCOLOR\\n\\nvColor=color;\\n#endif\\n}\";\r\nEffect.ShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var colorVertexShader = { name: name, shader: shader };\r\n//# sourceMappingURL=color.vertex.js.map","import { __extends } from \"tslib\";\r\nimport { Color3, Color4 } from \"../Maths/math.color\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { Mesh } from \"../Meshes/mesh\";\r\nimport { InstancedMesh } from \"../Meshes/instancedMesh\";\r\nimport { Material } from \"../Materials/material\";\r\nimport { ShaderMaterial } from \"../Materials/shaderMaterial\";\r\nimport { MaterialHelper } from '../Materials/materialHelper';\r\nimport \"../Shaders/color.fragment\";\r\nimport \"../Shaders/color.vertex\";\r\n/**\r\n * Line mesh\r\n * @see https://doc.babylonjs.com/babylon101/parametric_shapes\r\n */\r\nvar LinesMesh = /** @class */ (function (_super) {\r\n __extends(LinesMesh, _super);\r\n /**\r\n * Creates a new LinesMesh\r\n * @param name defines the name\r\n * @param scene defines the hosting scene\r\n * @param parent defines the parent mesh if any\r\n * @param source defines the optional source LinesMesh used to clone data from\r\n * @param doNotCloneChildren When cloning, skip cloning child meshes of source, default False.\r\n * When false, achieved by calling a clone(), also passing False.\r\n * This will make creation of children, recursive.\r\n * @param useVertexColor defines if this LinesMesh supports vertex color\r\n * @param useVertexAlpha defines if this LinesMesh supports vertex alpha\r\n */\r\n function LinesMesh(name, scene, parent, source, doNotCloneChildren, \r\n /**\r\n * If vertex color should be applied to the mesh\r\n */\r\n useVertexColor, \r\n /**\r\n * If vertex alpha should be applied to the mesh\r\n */\r\n useVertexAlpha) {\r\n if (scene === void 0) { scene = null; }\r\n if (parent === void 0) { parent = null; }\r\n if (source === void 0) { source = null; }\r\n var _this = _super.call(this, name, scene, parent, source, doNotCloneChildren) || this;\r\n _this.useVertexColor = useVertexColor;\r\n _this.useVertexAlpha = useVertexAlpha;\r\n /**\r\n * Color of the line (Default: White)\r\n */\r\n _this.color = new Color3(1, 1, 1);\r\n /**\r\n * Alpha of the line (Default: 1)\r\n */\r\n _this.alpha = 1;\r\n if (source) {\r\n _this.color = source.color.clone();\r\n _this.alpha = source.alpha;\r\n _this.useVertexColor = source.useVertexColor;\r\n _this.useVertexAlpha = source.useVertexAlpha;\r\n }\r\n _this.intersectionThreshold = 0.1;\r\n var defines = [];\r\n var options = {\r\n attributes: [VertexBuffer.PositionKind, \"world0\", \"world1\", \"world2\", \"world3\"],\r\n uniforms: [\"vClipPlane\", \"vClipPlane2\", \"vClipPlane3\", \"vClipPlane4\", \"vClipPlane5\", \"vClipPlane6\", \"world\", \"viewProjection\"],\r\n needAlphaBlending: true,\r\n defines: defines\r\n };\r\n if (useVertexAlpha === false) {\r\n options.needAlphaBlending = false;\r\n }\r\n if (!useVertexColor) {\r\n options.uniforms.push(\"color\");\r\n _this.color4 = new Color4();\r\n }\r\n else {\r\n options.defines.push(\"#define VERTEXCOLOR\");\r\n options.attributes.push(VertexBuffer.ColorKind);\r\n }\r\n _this._colorShader = new ShaderMaterial(\"colorShader\", _this.getScene(), \"color\", options);\r\n return _this;\r\n }\r\n LinesMesh.prototype._addClipPlaneDefine = function (label) {\r\n var define = \"#define \" + label;\r\n var index = this._colorShader.options.defines.indexOf(define);\r\n if (index !== -1) {\r\n return;\r\n }\r\n this._colorShader.options.defines.push(define);\r\n };\r\n LinesMesh.prototype._removeClipPlaneDefine = function (label) {\r\n var define = \"#define \" + label;\r\n var index = this._colorShader.options.defines.indexOf(define);\r\n if (index === -1) {\r\n return;\r\n }\r\n this._colorShader.options.defines.splice(index, 1);\r\n };\r\n LinesMesh.prototype.isReady = function () {\r\n var scene = this.getScene();\r\n // Clip planes\r\n scene.clipPlane ? this._addClipPlaneDefine(\"CLIPPLANE\") : this._removeClipPlaneDefine(\"CLIPPLANE\");\r\n scene.clipPlane2 ? this._addClipPlaneDefine(\"CLIPPLANE2\") : this._removeClipPlaneDefine(\"CLIPPLANE2\");\r\n scene.clipPlane3 ? this._addClipPlaneDefine(\"CLIPPLANE3\") : this._removeClipPlaneDefine(\"CLIPPLANE3\");\r\n scene.clipPlane4 ? this._addClipPlaneDefine(\"CLIPPLANE4\") : this._removeClipPlaneDefine(\"CLIPPLANE4\");\r\n scene.clipPlane5 ? this._addClipPlaneDefine(\"CLIPPLANE5\") : this._removeClipPlaneDefine(\"CLIPPLANE5\");\r\n scene.clipPlane6 ? this._addClipPlaneDefine(\"CLIPPLANE6\") : this._removeClipPlaneDefine(\"CLIPPLANE6\");\r\n if (!this._colorShader.isReady()) {\r\n return false;\r\n }\r\n return _super.prototype.isReady.call(this);\r\n };\r\n /**\r\n * Returns the string \"LineMesh\"\r\n */\r\n LinesMesh.prototype.getClassName = function () {\r\n return \"LinesMesh\";\r\n };\r\n Object.defineProperty(LinesMesh.prototype, \"material\", {\r\n /**\r\n * @hidden\r\n */\r\n get: function () {\r\n return this._colorShader;\r\n },\r\n /**\r\n * @hidden\r\n */\r\n set: function (value) {\r\n // Do nothing\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(LinesMesh.prototype, \"checkCollisions\", {\r\n /**\r\n * @hidden\r\n */\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n LinesMesh.prototype._bind = function (subMesh, effect, fillMode) {\r\n if (!this._geometry) {\r\n return this;\r\n }\r\n var colorEffect = this._colorShader.getEffect();\r\n // VBOs\r\n var indexToBind = this.isUnIndexed ? null : this._geometry.getIndexBuffer();\r\n this._geometry._bind(colorEffect, indexToBind);\r\n // Color\r\n if (!this.useVertexColor) {\r\n var _a = this.color, r = _a.r, g = _a.g, b = _a.b;\r\n this.color4.set(r, g, b, this.alpha);\r\n this._colorShader.setColor4(\"color\", this.color4);\r\n }\r\n // Clip planes\r\n MaterialHelper.BindClipPlane(colorEffect, this.getScene());\r\n return this;\r\n };\r\n /** @hidden */\r\n LinesMesh.prototype._draw = function (subMesh, fillMode, instancesCount) {\r\n if (!this._geometry || !this._geometry.getVertexBuffers() || (!this._unIndexed && !this._geometry.getIndexBuffer())) {\r\n return this;\r\n }\r\n var engine = this.getScene().getEngine();\r\n // Draw order\r\n if (this._unIndexed) {\r\n engine.drawArraysType(Material.LineListDrawMode, subMesh.verticesStart, subMesh.verticesCount, instancesCount);\r\n }\r\n else {\r\n engine.drawElementsType(Material.LineListDrawMode, subMesh.indexStart, subMesh.indexCount, instancesCount);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Disposes of the line mesh\r\n * @param doNotRecurse If children should be disposed\r\n */\r\n LinesMesh.prototype.dispose = function (doNotRecurse) {\r\n this._colorShader.dispose(false, false, true);\r\n _super.prototype.dispose.call(this, doNotRecurse);\r\n };\r\n /**\r\n * Returns a new LineMesh object cloned from the current one.\r\n */\r\n LinesMesh.prototype.clone = function (name, newParent, doNotCloneChildren) {\r\n if (newParent === void 0) { newParent = null; }\r\n return new LinesMesh(name, this.getScene(), newParent, this, doNotCloneChildren);\r\n };\r\n /**\r\n * Creates a new InstancedLinesMesh object from the mesh model.\r\n * @see http://doc.babylonjs.com/how_to/how_to_use_instances\r\n * @param name defines the name of the new instance\r\n * @returns a new InstancedLinesMesh\r\n */\r\n LinesMesh.prototype.createInstance = function (name) {\r\n return new InstancedLinesMesh(name, this);\r\n };\r\n return LinesMesh;\r\n}(Mesh));\r\nexport { LinesMesh };\r\n/**\r\n * Creates an instance based on a source LinesMesh\r\n */\r\nvar InstancedLinesMesh = /** @class */ (function (_super) {\r\n __extends(InstancedLinesMesh, _super);\r\n function InstancedLinesMesh(name, source) {\r\n var _this = _super.call(this, name, source) || this;\r\n _this.intersectionThreshold = source.intersectionThreshold;\r\n return _this;\r\n }\r\n /**\r\n * Returns the string \"InstancedLinesMesh\".\r\n */\r\n InstancedLinesMesh.prototype.getClassName = function () {\r\n return \"InstancedLinesMesh\";\r\n };\r\n return InstancedLinesMesh;\r\n}(InstancedMesh));\r\nexport { InstancedLinesMesh };\r\n//# sourceMappingURL=linesMesh.js.map","import { Vector3 } from \"../../Maths/math.vector\";\r\nimport { _CreationDataStorage, Mesh } from \"../mesh\";\r\nimport { VertexData } from \"../mesh.vertexData\";\r\nimport { LinesMesh } from \"../../Meshes/linesMesh\";\r\nimport { VertexBuffer } from \"../../Meshes/buffer\";\r\nVertexData.CreateLineSystem = function (options) {\r\n var indices = [];\r\n var positions = [];\r\n var lines = options.lines;\r\n var colors = options.colors;\r\n var vertexColors = [];\r\n var idx = 0;\r\n for (var l = 0; l < lines.length; l++) {\r\n var points = lines[l];\r\n for (var index = 0; index < points.length; index++) {\r\n positions.push(points[index].x, points[index].y, points[index].z);\r\n if (colors) {\r\n var color = colors[l];\r\n vertexColors.push(color[index].r, color[index].g, color[index].b, color[index].a);\r\n }\r\n if (index > 0) {\r\n indices.push(idx - 1);\r\n indices.push(idx);\r\n }\r\n idx++;\r\n }\r\n }\r\n var vertexData = new VertexData();\r\n vertexData.indices = indices;\r\n vertexData.positions = positions;\r\n if (colors) {\r\n vertexData.colors = vertexColors;\r\n }\r\n return vertexData;\r\n};\r\nVertexData.CreateDashedLines = function (options) {\r\n var dashSize = options.dashSize || 3;\r\n var gapSize = options.gapSize || 1;\r\n var dashNb = options.dashNb || 200;\r\n var points = options.points;\r\n var positions = new Array();\r\n var indices = new Array();\r\n var curvect = Vector3.Zero();\r\n var lg = 0;\r\n var nb = 0;\r\n var shft = 0;\r\n var dashshft = 0;\r\n var curshft = 0;\r\n var idx = 0;\r\n var i = 0;\r\n for (i = 0; i < points.length - 1; i++) {\r\n points[i + 1].subtractToRef(points[i], curvect);\r\n lg += curvect.length();\r\n }\r\n shft = lg / dashNb;\r\n dashshft = dashSize * shft / (dashSize + gapSize);\r\n for (i = 0; i < points.length - 1; i++) {\r\n points[i + 1].subtractToRef(points[i], curvect);\r\n nb = Math.floor(curvect.length() / shft);\r\n curvect.normalize();\r\n for (var j = 0; j < nb; j++) {\r\n curshft = shft * j;\r\n positions.push(points[i].x + curshft * curvect.x, points[i].y + curshft * curvect.y, points[i].z + curshft * curvect.z);\r\n positions.push(points[i].x + (curshft + dashshft) * curvect.x, points[i].y + (curshft + dashshft) * curvect.y, points[i].z + (curshft + dashshft) * curvect.z);\r\n indices.push(idx, idx + 1);\r\n idx += 2;\r\n }\r\n }\r\n // Result\r\n var vertexData = new VertexData();\r\n vertexData.positions = positions;\r\n vertexData.indices = indices;\r\n return vertexData;\r\n};\r\nMesh.CreateLines = function (name, points, scene, updatable, instance) {\r\n if (scene === void 0) { scene = null; }\r\n if (updatable === void 0) { updatable = false; }\r\n if (instance === void 0) { instance = null; }\r\n var options = {\r\n points: points,\r\n updatable: updatable,\r\n instance: instance\r\n };\r\n return LinesBuilder.CreateLines(name, options, scene);\r\n};\r\nMesh.CreateDashedLines = function (name, points, dashSize, gapSize, dashNb, scene, updatable, instance) {\r\n if (scene === void 0) { scene = null; }\r\n var options = {\r\n points: points,\r\n dashSize: dashSize,\r\n gapSize: gapSize,\r\n dashNb: dashNb,\r\n updatable: updatable,\r\n instance: instance\r\n };\r\n return LinesBuilder.CreateDashedLines(name, options, scene);\r\n};\r\n/**\r\n * Class containing static functions to help procedurally build meshes\r\n */\r\nvar LinesBuilder = /** @class */ (function () {\r\n function LinesBuilder() {\r\n }\r\n /**\r\n * Creates a line system mesh. A line system is a pool of many lines gathered in a single mesh\r\n * * A line system mesh is considered as a parametric shape since it has no predefined original shape. Its shape is determined by the passed array of lines as an input parameter\r\n * * Like every other parametric shape, it is dynamically updatable by passing an existing instance of LineSystem to this static function\r\n * * The parameter `lines` is an array of lines, each line being an array of successive Vector3\r\n * * The optional parameter `instance` is an instance of an existing LineSystem object to be updated with the passed `lines` parameter\r\n * * The optional parameter `colors` is an array of line colors, each line colors being an array of successive Color4, one per line point\r\n * * The optional parameter `useVertexAlpha` is to be set to `false` (default `true`) when you don't need the alpha blending (faster)\r\n * * Updating a simple Line mesh, you just need to update every line in the `lines` array : https://doc.babylonjs.com/how_to/how_to_dynamically_morph_a_mesh#lines-and-dashedlines\r\n * * When updating an instance, remember that only line point positions can change, not the number of points, neither the number of lines\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @see https://doc.babylonjs.com/how_to/parametric_shapes#line-system\r\n * @param name defines the name of the new line system\r\n * @param options defines the options used to create the line system\r\n * @param scene defines the hosting scene\r\n * @returns a new line system mesh\r\n */\r\n LinesBuilder.CreateLineSystem = function (name, options, scene) {\r\n var instance = options.instance;\r\n var lines = options.lines;\r\n var colors = options.colors;\r\n if (instance) { // lines update\r\n var positions = instance.getVerticesData(VertexBuffer.PositionKind);\r\n var vertexColor;\r\n var lineColors;\r\n if (colors) {\r\n vertexColor = instance.getVerticesData(VertexBuffer.ColorKind);\r\n }\r\n var i = 0;\r\n var c = 0;\r\n for (var l = 0; l < lines.length; l++) {\r\n var points = lines[l];\r\n for (var p = 0; p < points.length; p++) {\r\n positions[i] = points[p].x;\r\n positions[i + 1] = points[p].y;\r\n positions[i + 2] = points[p].z;\r\n if (colors && vertexColor) {\r\n lineColors = colors[l];\r\n vertexColor[c] = lineColors[p].r;\r\n vertexColor[c + 1] = lineColors[p].g;\r\n vertexColor[c + 2] = lineColors[p].b;\r\n vertexColor[c + 3] = lineColors[p].a;\r\n c += 4;\r\n }\r\n i += 3;\r\n }\r\n }\r\n instance.updateVerticesData(VertexBuffer.PositionKind, positions, false, false);\r\n if (colors && vertexColor) {\r\n instance.updateVerticesData(VertexBuffer.ColorKind, vertexColor, false, false);\r\n }\r\n return instance;\r\n }\r\n // line system creation\r\n var useVertexColor = (colors) ? true : false;\r\n var lineSystem = new LinesMesh(name, scene, null, undefined, undefined, useVertexColor, options.useVertexAlpha);\r\n var vertexData = VertexData.CreateLineSystem(options);\r\n vertexData.applyToMesh(lineSystem, options.updatable);\r\n return lineSystem;\r\n };\r\n /**\r\n * Creates a line mesh\r\n * A line mesh is considered as a parametric shape since it has no predefined original shape. Its shape is determined by the passed array of points as an input parameter\r\n * * Like every other parametric shape, it is dynamically updatable by passing an existing instance of LineMesh to this static function\r\n * * The parameter `points` is an array successive Vector3\r\n * * The optional parameter `instance` is an instance of an existing LineMesh object to be updated with the passed `points` parameter : https://doc.babylonjs.com/how_to/how_to_dynamically_morph_a_mesh#lines-and-dashedlines\r\n * * The optional parameter `colors` is an array of successive Color4, one per line point\r\n * * The optional parameter `useVertexAlpha` is to be set to `false` (default `true`) when you don't need alpha blending (faster)\r\n * * When updating an instance, remember that only point positions can change, not the number of points\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @see https://doc.babylonjs.com/how_to/parametric_shapes#lines\r\n * @param name defines the name of the new line system\r\n * @param options defines the options used to create the line system\r\n * @param scene defines the hosting scene\r\n * @returns a new line mesh\r\n */\r\n LinesBuilder.CreateLines = function (name, options, scene) {\r\n if (scene === void 0) { scene = null; }\r\n var colors = (options.colors) ? [options.colors] : null;\r\n var lines = LinesBuilder.CreateLineSystem(name, { lines: [options.points], updatable: options.updatable, instance: options.instance, colors: colors, useVertexAlpha: options.useVertexAlpha }, scene);\r\n return lines;\r\n };\r\n /**\r\n * Creates a dashed line mesh\r\n * * A dashed line mesh is considered as a parametric shape since it has no predefined original shape. Its shape is determined by the passed array of points as an input parameter\r\n * * Like every other parametric shape, it is dynamically updatable by passing an existing instance of LineMesh to this static function\r\n * * The parameter `points` is an array successive Vector3\r\n * * The parameter `dashNb` is the intended total number of dashes (positive integer, default 200)\r\n * * The parameter `dashSize` is the size of the dashes relatively the dash number (positive float, default 3)\r\n * * The parameter `gapSize` is the size of the gap between two successive dashes relatively the dash number (positive float, default 1)\r\n * * The optional parameter `instance` is an instance of an existing LineMesh object to be updated with the passed `points` parameter : https://doc.babylonjs.com/how_to/how_to_dynamically_morph_a_mesh#lines-and-dashedlines\r\n * * The optional parameter `useVertexAlpha` is to be set to `false` (default `true`) when you don't need the alpha blending (faster)\r\n * * When updating an instance, remember that only point positions can change, not the number of points\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @param name defines the name of the mesh\r\n * @param options defines the options used to create the mesh\r\n * @param scene defines the hosting scene\r\n * @returns the dashed line mesh\r\n * @see https://doc.babylonjs.com/how_to/parametric_shapes#dashed-lines\r\n */\r\n LinesBuilder.CreateDashedLines = function (name, options, scene) {\r\n if (scene === void 0) { scene = null; }\r\n var points = options.points;\r\n var instance = options.instance;\r\n var gapSize = options.gapSize || 1;\r\n var dashSize = options.dashSize || 3;\r\n if (instance) { // dashed lines update\r\n var positionFunction = function (positions) {\r\n var curvect = Vector3.Zero();\r\n var nbSeg = positions.length / 6;\r\n var lg = 0;\r\n var nb = 0;\r\n var shft = 0;\r\n var dashshft = 0;\r\n var curshft = 0;\r\n var p = 0;\r\n var i = 0;\r\n var j = 0;\r\n for (i = 0; i < points.length - 1; i++) {\r\n points[i + 1].subtractToRef(points[i], curvect);\r\n lg += curvect.length();\r\n }\r\n shft = lg / nbSeg;\r\n var dashSize = instance._creationDataStorage.dashSize;\r\n var gapSize = instance._creationDataStorage.gapSize;\r\n dashshft = dashSize * shft / (dashSize + gapSize);\r\n for (i = 0; i < points.length - 1; i++) {\r\n points[i + 1].subtractToRef(points[i], curvect);\r\n nb = Math.floor(curvect.length() / shft);\r\n curvect.normalize();\r\n j = 0;\r\n while (j < nb && p < positions.length) {\r\n curshft = shft * j;\r\n positions[p] = points[i].x + curshft * curvect.x;\r\n positions[p + 1] = points[i].y + curshft * curvect.y;\r\n positions[p + 2] = points[i].z + curshft * curvect.z;\r\n positions[p + 3] = points[i].x + (curshft + dashshft) * curvect.x;\r\n positions[p + 4] = points[i].y + (curshft + dashshft) * curvect.y;\r\n positions[p + 5] = points[i].z + (curshft + dashshft) * curvect.z;\r\n p += 6;\r\n j++;\r\n }\r\n }\r\n while (p < positions.length) {\r\n positions[p] = points[i].x;\r\n positions[p + 1] = points[i].y;\r\n positions[p + 2] = points[i].z;\r\n p += 3;\r\n }\r\n };\r\n instance.updateMeshPositions(positionFunction, false);\r\n return instance;\r\n }\r\n // dashed lines creation\r\n var dashedLines = new LinesMesh(name, scene, null, undefined, undefined, undefined, options.useVertexAlpha);\r\n var vertexData = VertexData.CreateDashedLines(options);\r\n vertexData.applyToMesh(dashedLines, options.updatable);\r\n dashedLines._creationDataStorage = new _CreationDataStorage();\r\n dashedLines._creationDataStorage.dashSize = dashSize;\r\n dashedLines._creationDataStorage.gapSize = gapSize;\r\n return dashedLines;\r\n };\r\n return LinesBuilder;\r\n}());\r\nexport { LinesBuilder };\r\n//# sourceMappingURL=linesBuilder.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serializeAsColor3, serializeAsVector3 } from \"../Misc/decorators\";\r\nimport { Matrix, Vector3 } from \"../Maths/math.vector\";\r\nimport { Color3 } from \"../Maths/math.color\";\r\nimport { Node } from \"../node\";\r\nimport { Light } from \"./light\";\r\nNode.AddNodeConstructor(\"Light_Type_3\", function (name, scene) {\r\n return function () { return new HemisphericLight(name, Vector3.Zero(), scene); };\r\n});\r\n/**\r\n * The HemisphericLight simulates the ambient environment light,\r\n * so the passed direction is the light reflection direction, not the incoming direction.\r\n */\r\nvar HemisphericLight = /** @class */ (function (_super) {\r\n __extends(HemisphericLight, _super);\r\n /**\r\n * Creates a HemisphericLight object in the scene according to the passed direction (Vector3).\r\n * The HemisphericLight simulates the ambient environment light, so the passed direction is the light reflection direction, not the incoming direction.\r\n * The HemisphericLight can't cast shadows.\r\n * Documentation : https://doc.babylonjs.com/babylon101/lights\r\n * @param name The friendly name of the light\r\n * @param direction The direction of the light reflection\r\n * @param scene The scene the light belongs to\r\n */\r\n function HemisphericLight(name, direction, scene) {\r\n var _this = _super.call(this, name, scene) || this;\r\n /**\r\n * The groundColor is the light in the opposite direction to the one specified during creation.\r\n * You can think of the diffuse and specular light as coming from the centre of the object in the given direction and the groundColor light in the opposite direction.\r\n */\r\n _this.groundColor = new Color3(0.0, 0.0, 0.0);\r\n _this.direction = direction || Vector3.Up();\r\n return _this;\r\n }\r\n HemisphericLight.prototype._buildUniformLayout = function () {\r\n this._uniformBuffer.addUniform(\"vLightData\", 4);\r\n this._uniformBuffer.addUniform(\"vLightDiffuse\", 4);\r\n this._uniformBuffer.addUniform(\"vLightSpecular\", 4);\r\n this._uniformBuffer.addUniform(\"vLightGround\", 3);\r\n this._uniformBuffer.addUniform(\"shadowsInfo\", 3);\r\n this._uniformBuffer.addUniform(\"depthValues\", 2);\r\n this._uniformBuffer.create();\r\n };\r\n /**\r\n * Returns the string \"HemisphericLight\".\r\n * @return The class name\r\n */\r\n HemisphericLight.prototype.getClassName = function () {\r\n return \"HemisphericLight\";\r\n };\r\n /**\r\n * Sets the HemisphericLight direction towards the passed target (Vector3).\r\n * Returns the updated direction.\r\n * @param target The target the direction should point to\r\n * @return The computed direction\r\n */\r\n HemisphericLight.prototype.setDirectionToTarget = function (target) {\r\n this.direction = Vector3.Normalize(target.subtract(Vector3.Zero()));\r\n return this.direction;\r\n };\r\n /**\r\n * Returns the shadow generator associated to the light.\r\n * @returns Always null for hemispheric lights because it does not support shadows.\r\n */\r\n HemisphericLight.prototype.getShadowGenerator = function () {\r\n return null;\r\n };\r\n /**\r\n * Sets the passed Effect object with the HemisphericLight normalized direction and color and the passed name (string).\r\n * @param effect The effect to update\r\n * @param lightIndex The index of the light in the effect to update\r\n * @returns The hemispheric light\r\n */\r\n HemisphericLight.prototype.transferToEffect = function (effect, lightIndex) {\r\n var normalizeDirection = Vector3.Normalize(this.direction);\r\n this._uniformBuffer.updateFloat4(\"vLightData\", normalizeDirection.x, normalizeDirection.y, normalizeDirection.z, 0.0, lightIndex);\r\n this._uniformBuffer.updateColor3(\"vLightGround\", this.groundColor.scale(this.intensity), lightIndex);\r\n return this;\r\n };\r\n HemisphericLight.prototype.transferToNodeMaterialEffect = function (effect, lightDataUniformName) {\r\n var normalizeDirection = Vector3.Normalize(this.direction);\r\n effect.setFloat3(lightDataUniformName, normalizeDirection.x, normalizeDirection.y, normalizeDirection.z);\r\n return this;\r\n };\r\n /**\r\n * Computes the world matrix of the node\r\n * @param force defines if the cache version should be invalidated forcing the world matrix to be created from scratch\r\n * @param useWasUpdatedFlag defines a reserved property\r\n * @returns the world matrix\r\n */\r\n HemisphericLight.prototype.computeWorldMatrix = function () {\r\n if (!this._worldMatrix) {\r\n this._worldMatrix = Matrix.Identity();\r\n }\r\n return this._worldMatrix;\r\n };\r\n /**\r\n * Returns the integer 3.\r\n * @return The light Type id as a constant defines in Light.LIGHTTYPEID_x\r\n */\r\n HemisphericLight.prototype.getTypeID = function () {\r\n return Light.LIGHTTYPEID_HEMISPHERICLIGHT;\r\n };\r\n /**\r\n * Prepares the list of defines specific to the light type.\r\n * @param defines the list of defines\r\n * @param lightIndex defines the index of the light for the effect\r\n */\r\n HemisphericLight.prototype.prepareLightSpecificDefines = function (defines, lightIndex) {\r\n defines[\"HEMILIGHT\" + lightIndex] = true;\r\n };\r\n __decorate([\r\n serializeAsColor3()\r\n ], HemisphericLight.prototype, \"groundColor\", void 0);\r\n __decorate([\r\n serializeAsVector3()\r\n ], HemisphericLight.prototype, \"direction\", void 0);\r\n return HemisphericLight;\r\n}(Light));\r\nexport { HemisphericLight };\r\n//# sourceMappingURL=hemisphericLight.js.map","//download.js v4.2, by dandavis; 2008-2016. [MIT] see http://danml.com/download.html for tests/usage\n// v1 landed a FF+Chrome compat way of downloading strings to local un-named files, upgraded to use a hidden frame and optional mime\n// v2 added named files via a[download], msSaveBlob, IE (10+) support, and window.URL support for larger+faster saves than dataURLs\n// v3 added dataURL and Blob Input, bind-toggle arity, and legacy dataURL fallback was improved with force-download mime and base64 support. 3.1 improved safari handling.\n// v4 adds AMD/UMD, commonJS, and plain browser support\n// v4.1 adds url download capability via solo URL argument (same domain/CORS only)\n// v4.2 adds semantic variable names, long (over 2MB) dataURL support, and hidden by default temp anchors\n// https://github.com/rndme/download\n\n(function (root, factory) {\n\tif (typeof define === 'function' && define.amd) {\n\t\t// AMD. Register as an anonymous module.\n\t\tdefine([], factory);\n\t} else if (typeof exports === 'object') {\n\t\t// Node. Does not work with strict CommonJS, but\n\t\t// only CommonJS-like environments that support module.exports,\n\t\t// like Node.\n\t\tmodule.exports = factory();\n\t} else {\n\t\t// Browser globals (root is window)\n\t\troot.download = factory();\n }\n}(this, function () {\n\n\treturn function download(data, strFileName, strMimeType) {\n\n\t\tvar self = window, // this script is only for browsers anyway...\n\t\t\tdefaultMime = \"application/octet-stream\", // this default mime also triggers iframe downloads\n\t\t\tmimeType = strMimeType || defaultMime,\n\t\t\tpayload = data,\n\t\t\turl = !strFileName && !strMimeType && payload,\n\t\t\tanchor = document.createElement(\"a\"),\n\t\t\ttoString = function(a){return String(a);},\n\t\t\tmyBlob = (self.Blob || self.MozBlob || self.WebKitBlob || toString),\n\t\t\tfileName = strFileName || \"download\",\n\t\t\tblob,\n\t\t\treader;\n\t\t\tmyBlob= myBlob.call ? myBlob.bind(self) : Blob ;\n\t \n\t\tif(String(this)===\"true\"){ //reverse arguments, allowing download.bind(true, \"text/xml\", \"export.xml\") to act as a callback\n\t\t\tpayload=[payload, mimeType];\n\t\t\tmimeType=payload[0];\n\t\t\tpayload=payload[1];\n\t\t}\n\n\n\t\tif(url && url.length< 2048){ // if no filename and no mime, assume a url was passed as the only argument\n\t\t\tfileName = url.split(\"/\").pop().split(\"?\")[0];\n\t\t\tanchor.href = url; // assign href prop to temp anchor\n\t\t \tif(anchor.href.indexOf(url) !== -1){ // if the browser determines that it's a potentially valid url path:\n \t\tvar ajax=new XMLHttpRequest();\n \t\tajax.open( \"GET\", url, true);\n \t\tajax.responseType = 'blob';\n \t\tajax.onload= function(e){ \n\t\t\t\t download(e.target.response, fileName, defaultMime);\n\t\t\t\t};\n \t\tsetTimeout(function(){ ajax.send();}, 0); // allows setting custom ajax headers using the return:\n\t\t\t return ajax;\n\t\t\t} // end if valid url?\n\t\t} // end if url?\n\n\n\t\t//go ahead and download dataURLs right away\n\t\tif(/^data:([\\w+-]+\\/[\\w+.-]+)?[,;]/.test(payload)){\n\t\t\n\t\t\tif(payload.length > (1024*1024*1.999) && myBlob !== toString ){\n\t\t\t\tpayload=dataUrlToBlob(payload);\n\t\t\t\tmimeType=payload.type || defaultMime;\n\t\t\t}else{\t\t\t\n\t\t\t\treturn navigator.msSaveBlob ? // IE10 can't do a[download], only Blobs:\n\t\t\t\t\tnavigator.msSaveBlob(dataUrlToBlob(payload), fileName) :\n\t\t\t\t\tsaver(payload) ; // everyone else can save dataURLs un-processed\n\t\t\t}\n\t\t\t\n\t\t}else{//not data url, is it a string with special needs?\n\t\t\tif(/([\\x80-\\xff])/.test(payload)){\t\t\t \n\t\t\t\tvar i=0, tempUiArr= new Uint8Array(payload.length), mx=tempUiArr.length;\n\t\t\t\tfor(i;i 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","'use strict';\n\nvar utils = require('../utils');\n\nmodule.exports = function normalizeHeaderName(headers, normalizedName) {\n utils.forEach(headers, function processHeader(value, name) {\n if (name !== normalizedName && name.toUpperCase() === normalizedName.toUpperCase()) {\n headers[normalizedName] = value;\n delete headers[name];\n }\n });\n};\n","'use strict';\n\nvar createError = require('./createError');\n\n/**\n * Resolve or reject a Promise based on response status.\n *\n * @param {Function} resolve A function that resolves the promise.\n * @param {Function} reject A function that rejects the promise.\n * @param {object} response The response.\n */\nmodule.exports = function settle(resolve, reject, response) {\n var validateStatus = response.config.validateStatus;\n if (!response.status || !validateStatus || validateStatus(response.status)) {\n resolve(response);\n } else {\n reject(createError(\n 'Request failed with status code ' + response.status,\n response.config,\n null,\n response.request,\n response\n ));\n }\n};\n","'use strict';\n\n/**\n * Update an Error with the specified config, error code, and response.\n *\n * @param {Error} error The error to update.\n * @param {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The error.\n */\nmodule.exports = function enhanceError(error, config, code, request, response) {\n error.config = config;\n if (code) {\n error.code = code;\n }\n\n error.request = request;\n error.response = response;\n error.isAxiosError = true;\n\n error.toJSON = function toJSON() {\n return {\n // Standard\n message: this.message,\n name: this.name,\n // Microsoft\n description: this.description,\n number: this.number,\n // Mozilla\n fileName: this.fileName,\n lineNumber: this.lineNumber,\n columnNumber: this.columnNumber,\n stack: this.stack,\n // Axios\n config: this.config,\n code: this.code\n };\n };\n return error;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nmodule.exports = (\n utils.isStandardBrowserEnv() ?\n\n // Standard browser envs support document.cookie\n (function standardBrowserEnv() {\n return {\n write: function write(name, value, expires, path, domain, secure) {\n var cookie = [];\n cookie.push(name + '=' + encodeURIComponent(value));\n\n if (utils.isNumber(expires)) {\n cookie.push('expires=' + new Date(expires).toGMTString());\n }\n\n if (utils.isString(path)) {\n cookie.push('path=' + path);\n }\n\n if (utils.isString(domain)) {\n cookie.push('domain=' + domain);\n }\n\n if (secure === true) {\n cookie.push('secure');\n }\n\n document.cookie = cookie.join('; ');\n },\n\n read: function read(name) {\n var match = document.cookie.match(new RegExp('(^|;\\\\s*)(' + name + ')=([^;]*)'));\n return (match ? decodeURIComponent(match[3]) : null);\n },\n\n remove: function remove(name) {\n this.write(name, '', Date.now() - 86400000);\n }\n };\n })() :\n\n // Non standard browser env (web workers, react-native) lack needed support.\n (function nonStandardBrowserEnv() {\n return {\n write: function write() {},\n read: function read() { return null; },\n remove: function remove() {}\n };\n })()\n);\n","'use strict';\n\nvar isAbsoluteURL = require('../helpers/isAbsoluteURL');\nvar combineURLs = require('../helpers/combineURLs');\n\n/**\n * Creates a new URL by combining the baseURL with the requestedURL,\n * only when the requestedURL is not already an absolute URL.\n * If the requestURL is absolute, this function returns the requestedURL untouched.\n *\n * @param {string} baseURL The base URL\n * @param {string} requestedURL Absolute or relative URL to combine\n * @returns {string} The combined full path\n */\nmodule.exports = function buildFullPath(baseURL, requestedURL) {\n if (baseURL && !isAbsoluteURL(requestedURL)) {\n return combineURLs(baseURL, requestedURL);\n }\n return requestedURL;\n};\n","'use strict';\n\n/**\n * Determines whether the specified URL is absolute\n *\n * @param {string} url The URL to test\n * @returns {boolean} True if the specified URL is absolute, otherwise false\n */\nmodule.exports = function isAbsoluteURL(url) {\n // A URL is considered absolute if it begins with \"://\" or \"//\" (protocol-relative URL).\n // RFC 3986 defines scheme name as a sequence of characters beginning with a letter and followed\n // by any combination of letters, digits, plus, period, or hyphen.\n return /^([a-z][a-z\\d\\+\\-\\.]*:)?\\/\\//i.test(url);\n};\n","'use strict';\n\n/**\n * Creates a new URL by combining the specified URLs\n *\n * @param {string} baseURL The base URL\n * @param {string} relativeURL The relative URL\n * @returns {string} The combined URL\n */\nmodule.exports = function combineURLs(baseURL, relativeURL) {\n return relativeURL\n ? baseURL.replace(/\\/+$/, '') + '/' + relativeURL.replace(/^\\/+/, '')\n : baseURL;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\n// Headers whose duplicates are ignored by node\n// c.f. https://nodejs.org/api/http.html#http_message_headers\nvar ignoreDuplicateOf = [\n 'age', 'authorization', 'content-length', 'content-type', 'etag',\n 'expires', 'from', 'host', 'if-modified-since', 'if-unmodified-since',\n 'last-modified', 'location', 'max-forwards', 'proxy-authorization',\n 'referer', 'retry-after', 'user-agent'\n];\n\n/**\n * Parse headers into an object\n *\n * ```\n * Date: Wed, 27 Aug 2014 08:58:49 GMT\n * Content-Type: application/json\n * Connection: keep-alive\n * Transfer-Encoding: chunked\n * ```\n *\n * @param {String} headers Headers needing to be parsed\n * @returns {Object} Headers parsed into an object\n */\nmodule.exports = function parseHeaders(headers) {\n var parsed = {};\n var key;\n var val;\n var i;\n\n if (!headers) { return parsed; }\n\n utils.forEach(headers.split('\\n'), function parser(line) {\n i = line.indexOf(':');\n key = utils.trim(line.substr(0, i)).toLowerCase();\n val = utils.trim(line.substr(i + 1));\n\n if (key) {\n if (parsed[key] && ignoreDuplicateOf.indexOf(key) >= 0) {\n return;\n }\n if (key === 'set-cookie') {\n parsed[key] = (parsed[key] ? parsed[key] : []).concat([val]);\n } else {\n parsed[key] = parsed[key] ? parsed[key] + ', ' + val : val;\n }\n }\n });\n\n return parsed;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nmodule.exports = (\n utils.isStandardBrowserEnv() ?\n\n // Standard browser envs have full support of the APIs needed to test\n // whether the request URL is of the same origin as current location.\n (function standardBrowserEnv() {\n var msie = /(msie|trident)/i.test(navigator.userAgent);\n var urlParsingNode = document.createElement('a');\n var originURL;\n\n /**\n * Parse a URL to discover it's components\n *\n * @param {String} url The URL to be parsed\n * @returns {Object}\n */\n function resolveURL(url) {\n var href = url;\n\n if (msie) {\n // IE needs attribute set twice to normalize properties\n urlParsingNode.setAttribute('href', href);\n href = urlParsingNode.href;\n }\n\n urlParsingNode.setAttribute('href', href);\n\n // urlParsingNode provides the UrlUtils interface - http://url.spec.whatwg.org/#urlutils\n return {\n href: urlParsingNode.href,\n protocol: urlParsingNode.protocol ? urlParsingNode.protocol.replace(/:$/, '') : '',\n host: urlParsingNode.host,\n search: urlParsingNode.search ? urlParsingNode.search.replace(/^\\?/, '') : '',\n hash: urlParsingNode.hash ? urlParsingNode.hash.replace(/^#/, '') : '',\n hostname: urlParsingNode.hostname,\n port: urlParsingNode.port,\n pathname: (urlParsingNode.pathname.charAt(0) === '/') ?\n urlParsingNode.pathname :\n '/' + urlParsingNode.pathname\n };\n }\n\n originURL = resolveURL(window.location.href);\n\n /**\n * Determine if a URL shares the same origin as the current location\n *\n * @param {String} requestURL The URL to test\n * @returns {boolean} True if URL shares the same origin, otherwise false\n */\n return function isURLSameOrigin(requestURL) {\n var parsed = (utils.isString(requestURL)) ? resolveURL(requestURL) : requestURL;\n return (parsed.protocol === originURL.protocol &&\n parsed.host === originURL.host);\n };\n })() :\n\n // Non standard browser envs (web workers, react-native) lack needed support.\n (function nonStandardBrowserEnv() {\n return function isURLSameOrigin() {\n return true;\n };\n })()\n);\n","'use strict';\n\nvar Cancel = require('./Cancel');\n\n/**\n * A `CancelToken` is an object that can be used to request cancellation of an operation.\n *\n * @class\n * @param {Function} executor The executor function.\n */\nfunction CancelToken(executor) {\n if (typeof executor !== 'function') {\n throw new TypeError('executor must be a function.');\n }\n\n var resolvePromise;\n this.promise = new Promise(function promiseExecutor(resolve) {\n resolvePromise = resolve;\n });\n\n var token = this;\n executor(function cancel(message) {\n if (token.reason) {\n // Cancellation has already been requested\n return;\n }\n\n token.reason = new Cancel(message);\n resolvePromise(token.reason);\n });\n}\n\n/**\n * Throws a `Cancel` if cancellation has been requested.\n */\nCancelToken.prototype.throwIfRequested = function throwIfRequested() {\n if (this.reason) {\n throw this.reason;\n }\n};\n\n/**\n * Returns an object that contains a new `CancelToken` and a function that, when called,\n * cancels the `CancelToken`.\n */\nCancelToken.source = function source() {\n var cancel;\n var token = new CancelToken(function executor(c) {\n cancel = c;\n });\n return {\n token: token,\n cancel: cancel\n };\n};\n\nmodule.exports = CancelToken;\n","'use strict';\n\n/**\n * Syntactic sugar for invoking a function and expanding an array for arguments.\n *\n * Common use case would be to use `Function.prototype.apply`.\n *\n * ```js\n * function f(x, y, z) {}\n * var args = [1, 2, 3];\n * f.apply(null, args);\n * ```\n *\n * With `spread` this example can be re-written.\n *\n * ```js\n * spread(function(x, y, z) {})([1, 2, 3]);\n * ```\n *\n * @param {Function} callback\n * @returns {Function}\n */\nmodule.exports = function spread(callback) {\n return function wrap(arr) {\n return callback.apply(null, arr);\n };\n};\n","/**\r\n * Babyplots - Easy, fast, interactive 3D visualizations\r\n *\r\n * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved.\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n * \r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n * \r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n * \r\n */\r\n\r\nimport { Scene } from \"@babylonjs/core/scene\";\r\nimport { ArcRotateCamera } from \"@babylonjs/core/Cameras/arcRotateCamera\";\r\nimport { Mesh } from \"@babylonjs/core/Meshes/mesh\";\r\nimport { Vector3, Axis, Color3 } from \"@babylonjs/core/Maths/math\";\r\nimport { PlaneBuilder } from \"@babylonjs/core/Meshes/Builders/planeBuilder\";\r\nimport { PointerDragBehavior } from \"@babylonjs/core/Behaviors/Meshes/pointerDragBehavior\";\r\nimport { AdvancedDynamicTexture } from \"@babylonjs/gui/2D/advancedDynamicTexture\";\r\nimport { Rectangle, TextBlock } from \"@babylonjs/gui/2D/controls\";\r\nimport { LinesBuilder } from \"@babylonjs/core/Meshes/Builders/linesBuilder\";\r\nimport { LinesMesh } from \"@babylonjs/core/Meshes/linesMesh\";\r\nimport { CylinderBuilder } from \"@babylonjs/core/Meshes/Builders/cylinderBuilder\";\r\n\r\nclass Arrow {\r\n private _lines: LinesMesh;\r\n private _tip: Mesh;\r\n\r\n size: number = 1;\r\n\r\n constructor(from: Vector3, to: Vector3, scene: Scene, color?: string) {\r\n let lines = LinesBuilder.CreateLineSystem('ls', {\r\n lines: [[from, to]],\r\n updatable: true\r\n }, scene);\r\n\r\n lines.color = new Color3(0, 0, 0);\r\n if (color !== undefined) {\r\n lines.color = Color3.FromHexString(color);\r\n }\r\n this._lines = lines;\r\n let tip = CylinderBuilder.CreateCylinder(\"tip\", {\r\n diameterTop: 0,\r\n diameterBottom: this.size,\r\n tessellation: 36\r\n }, scene);\r\n tip.position = to;\r\n\r\n }\r\n}\r\n\r\nclass Label {\r\n private _label: Mesh;\r\n private _background: Rectangle;\r\n private _text: TextBlock;\r\n\r\n size: number = 100;\r\n color: string = \"black\";\r\n fixed: boolean = false;\r\n\r\n constructor(text: string, position: Vector3, scene: Scene, color?: string) {\r\n let plane = PlaneBuilder.CreatePlane('label', {\r\n width: 5,\r\n height: 5\r\n }, scene);\r\n\r\n if (color !== undefined) {\r\n this.color = color;\r\n }\r\n\r\n plane.position = position;\r\n\r\n let advancedTexture = AdvancedDynamicTexture.CreateForMesh(plane);\r\n\r\n let background = new Rectangle();\r\n background.color = \"red\";\r\n background.alpha = 0\r\n advancedTexture.addControl(background);\r\n this._background = background;\r\n\r\n let textBlock = new TextBlock();\r\n textBlock.text = text;\r\n textBlock.color = this.color;\r\n textBlock.fontSize = this.size;\r\n advancedTexture.addControl(textBlock);\r\n this._text = textBlock;\r\n\r\n if (!this.fixed) {\r\n makeDraggable(plane);\r\n }\r\n\r\n this._label = plane;\r\n }\r\n\r\n setText(text: string) {\r\n this._text.text = text;\r\n }\r\n\r\n update(camera: ArcRotateCamera, scene: Scene) {\r\n // draw 3d labels in plot\r\n let axis1 = Vector3.Cross(camera.position, Axis.Y);\r\n let axis2 = Vector3.Cross(axis1, camera.position);\r\n let axis3 = Vector3.Cross(axis1, axis2);\r\n this._label.rotation = Vector3.RotationFromAxis(axis1, axis2, axis3);\r\n\r\n if (!this.fixed) {\r\n // highlighting label under mouse cursor\r\n const meshUnderPointer = scene.meshUnderPointer as Mesh;\r\n if (this._label === meshUnderPointer) {\r\n this._background.alpha = 1;\r\n } else {\r\n this._background.alpha = 0;\r\n }\r\n }\r\n }\r\n\r\n fix() {\r\n this._label.removeBehavior(this._label.getBehaviorByName(\"PointerDrag\"));\r\n this.fixed = true;\r\n }\r\n\r\n unfix() {\r\n makeDraggable(this._label);\r\n this.fixed = false;\r\n }\r\n\r\n dispose() {\r\n this._text.dispose();\r\n this._background.dispose();\r\n this._label.dispose();\r\n }\r\n\r\n export(): [number, number, number, string] {\r\n return [\r\n this._label.position.x,\r\n this._label.position.y,\r\n this._label.position.z,\r\n this._text.text\r\n ]\r\n }\r\n}\r\n\r\nexport class AnnotationManager {\r\n private _canvas: HTMLCanvasElement;\r\n private _scene: Scene;\r\n private _ymax: number;\r\n private _camera: ArcRotateCamera;\r\n private _labelControlBox: HTMLDivElement;\r\n private _editLabelContainer: HTMLDivElement;\r\n private _editLabelForms: HTMLDivElement[] = [];\r\n private _addLabelTextInput: HTMLInputElement;\r\n private _showLabels: boolean = false;\r\n private _arrows: Arrow[] = [];\r\n private _showArrows: boolean = false;\r\n\r\n labels: Label[] = [];\r\n fixedLabels: boolean = false;\r\n fixedArrows: boolean = false;\r\n\r\n constructor(canvas: HTMLCanvasElement, scene: Scene, ymax: number, camera: ArcRotateCamera) {\r\n this._canvas = canvas;\r\n this._scene = scene;\r\n this._ymax = ymax;\r\n this._camera = camera;\r\n this._createLabelForms();\r\n }\r\n\r\n private _createLabelForms() {\r\n let labelBox = document.createElement(\"div\");\r\n labelBox.className = \"bbp label-control\";\r\n labelBox.style.display = \"none\";\r\n labelBox.style.top = this._canvas.clientTop + 40 + \"px\";\r\n labelBox.style.left = this._canvas.clientTop + 5 + \"px\";\r\n let addLabelForm = document.createElement(\"div\");\r\n addLabelForm.className = \"label-form\";\r\n let addLabelLabel = document.createElement(\"label\");\r\n addLabelLabel.innerText = \"Label Text:\";\r\n addLabelLabel.htmlFor = \"addLabelInput\";\r\n let addLabelInput = document.createElement(\"input\");\r\n addLabelInput.name = \"addLabelInput\";\r\n addLabelInput.type = \"text\";\r\n this._addLabelTextInput = addLabelInput;\r\n let addLabelBtn = document.createElement(\"button\");\r\n addLabelBtn.innerText = \"Add Label\";\r\n addLabelBtn.onclick = this._addLabelBtnClick.bind(this);\r\n addLabelForm.appendChild(addLabelLabel);\r\n addLabelForm.appendChild(addLabelInput);\r\n addLabelForm.appendChild(addLabelBtn);\r\n labelBox.appendChild(addLabelForm);\r\n let editLabelContainer = document.createElement(\"div\");\r\n editLabelContainer.className = \"edit-container\";\r\n editLabelContainer.style.maxHeight = (this._canvas.height - 100).toString() + \"px\";\r\n labelBox.appendChild(editLabelContainer);\r\n this._editLabelContainer = editLabelContainer;\r\n this._labelControlBox = labelBox;\r\n this._canvas.parentNode.appendChild(labelBox);\r\n }\r\n\r\n update() {\r\n if (this._showArrows) {\r\n\r\n }\r\n if (this._showLabels) {\r\n for (let i = 0; i < this.labels.length; i++) {\r\n const label = this.labels[i];\r\n label.update(this._camera, this._scene);\r\n }\r\n }\r\n }\r\n\r\n toggleLabelControl() {\r\n if (this._labelControlBox.style.display == \"none\") {\r\n this._labelControlBox.style.display = \"block\";\r\n this.unfixLabels();\r\n } else {\r\n this._labelControlBox.style.display = \"none\";\r\n this.fixLabels();\r\n }\r\n }\r\n\r\n private _addLabelBtnClick(event: Event) {\r\n event.preventDefault();\r\n this.addLabel(this._addLabelTextInput.value);\r\n }\r\n\r\n addArrow(from: number[], to: number[]) {\r\n this._arrows.push(new Arrow(\r\n Vector3.FromArray(from),\r\n Vector3.FromArray(to),\r\n this._scene\r\n ));\r\n }\r\n\r\n /**\r\n * Add a 3d label to the plot\r\n * @param text Label title\r\n * @param [moveCallback] On dragging of label in 3d plot, the final position will be passed to this function\r\n */\r\n addLabel(text: string, position?: number[]): number {\r\n this._addLabelTextInput.value = \"\";\r\n let labelIdx = this.labels.length;\r\n\r\n let pos: Vector3;\r\n if (position) {\r\n pos = Vector3.FromArray(position)\r\n } else {\r\n pos = new Vector3(0, this._ymax + 2, 0);\r\n }\r\n\r\n let newLabel = new Label(text, pos, this._scene);\r\n\r\n this.labels.push(newLabel);\r\n\r\n let editLabelForm = document.createElement(\"div\");\r\n editLabelForm.className = \"label-form\";\r\n let editLabelLabel = document.createElement(\"label\");\r\n editLabelLabel.innerText = \"Edit Label Text:\";\r\n editLabelLabel.htmlFor = \"editLabelInput\";\r\n editLabelForm.appendChild(editLabelLabel);\r\n let editLabelInput = document.createElement(\"input\");\r\n editLabelInput.name = \"editLabelInput\";\r\n editLabelInput.type = \"text\";\r\n editLabelInput.value = text;\r\n editLabelInput.dataset.labelnum = labelIdx.toString();\r\n editLabelInput.onkeyup = this._editLabelText.bind(this);\r\n editLabelForm.appendChild(editLabelInput);\r\n let rmvLabelBtn = document.createElement(\"button\");\r\n rmvLabelBtn.innerText = \"Remove Label\"\r\n rmvLabelBtn.onclick = this._removeLabel.bind(this);\r\n rmvLabelBtn.dataset.labelnum = labelIdx.toString();\r\n editLabelForm.appendChild(rmvLabelBtn);\r\n editLabelForm.dataset.labelnum = labelIdx.toString();\r\n this._editLabelForms.push(editLabelForm);\r\n this._editLabelContainer.appendChild(editLabelForm);\r\n\r\n this._showLabels = true;\r\n return labelIdx;\r\n }\r\n\r\n /**\r\n * Add multiple labels from a list of labels.\r\n * \r\n * @param labelList List of lists with the first three elements of the inner lists being the x, y and z coordinates, and the fourth the label text.\r\n */\r\n addLabels(labelList: [[number, number, number, string]]): void {\r\n for (let i = 0; i < labelList.length; i++) {\r\n const label = labelList[i];\r\n let text = label[3];\r\n let position = label.slice(0, 3) as number[];\r\n this.addLabel(text, position);\r\n }\r\n }\r\n\r\n private _editLabelText(ev: Event): void {\r\n let inputElem = ev.target as HTMLInputElement;\r\n this.labels[parseInt(inputElem.dataset.labelnum)].setText(inputElem.value);\r\n }\r\n\r\n private _removeLabel(ev: Event) {\r\n let btn = ev.target as HTMLButtonElement;\r\n let labelNum = parseInt(btn.dataset.labelnum);\r\n this.labels[labelNum].dispose();\r\n this.labels.splice(labelNum, 1);\r\n let thisForm: HTMLDivElement;\r\n this._editLabelForms.forEach(eLabelForm => {\r\n if (parseInt(eLabelForm.dataset.labelnum) == labelNum) {\r\n thisForm = eLabelForm;\r\n } else if (parseInt(eLabelForm.dataset.labelnum) > labelNum) {\r\n let oldNum = parseInt(eLabelForm.dataset.labelnum)\r\n let newNum = (oldNum - 1).toString()\r\n eLabelForm.dataset.labelnum = newNum;\r\n let oInput = eLabelForm.querySelector('input[data-labelnum=\"' + oldNum + '\"]') as HTMLInputElement;\r\n oInput.dataset.labelnum = newNum;\r\n let oBtn = eLabelForm.querySelector('button[data-labelnum=\"' + oldNum + '\"]') as HTMLButtonElement;\r\n oBtn.dataset.labelnum = newNum;\r\n }\r\n });\r\n thisForm.parentNode.removeChild(thisForm);\r\n }\r\n\r\n exportLabels(): any[] {\r\n let labels = [];\r\n for (let i = 0; i < this.labels.length; i++) {\r\n labels.push(this.labels[i].export());\r\n }\r\n return labels;\r\n }\r\n\r\n fixLabels() {\r\n for (let i = 0; i < this.labels.length; i++) {\r\n this.labels[i].fix();\r\n }\r\n this.fixedLabels = true;\r\n }\r\n\r\n unfixLabels() {\r\n for (let i = 0; i < this.labels.length; i++) {\r\n this.labels[i].unfix();\r\n }\r\n this.fixedLabels = false;\r\n }\r\n}\r\n\r\nfunction makeDraggable(label: Mesh) {\r\n let labelDragBehavior = new PointerDragBehavior();\r\n label.addBehavior(labelDragBehavior);\r\n}","import { Vector4, Vector3, Vector2 } from \"../../Maths/math.vector\";\r\nimport { Color4 } from '../../Maths/math.color';\r\nimport { Mesh } from \"../mesh\";\r\nimport { VertexData } from \"../mesh.vertexData\";\r\nimport { Scene } from \"../../scene\";\r\nimport { Axis } from '../../Maths/math.axis';\r\nVertexData.CreateCylinder = function (options) {\r\n var height = options.height || 2;\r\n var diameterTop = (options.diameterTop === 0) ? 0 : options.diameterTop || options.diameter || 1;\r\n var diameterBottom = (options.diameterBottom === 0) ? 0 : options.diameterBottom || options.diameter || 1;\r\n diameterTop = diameterTop || 0.00001; // Prevent broken normals\r\n diameterBottom = diameterBottom || 0.00001; // Prevent broken normals\r\n var tessellation = options.tessellation || 24;\r\n var subdivisions = options.subdivisions || 1;\r\n var hasRings = options.hasRings ? true : false;\r\n var enclose = options.enclose ? true : false;\r\n var cap = (options.cap === 0) ? 0 : options.cap || Mesh.CAP_ALL;\r\n var arc = options.arc && (options.arc <= 0 || options.arc > 1) ? 1.0 : options.arc || 1.0;\r\n var sideOrientation = (options.sideOrientation === 0) ? 0 : options.sideOrientation || VertexData.DEFAULTSIDE;\r\n var faceUV = options.faceUV || new Array(3);\r\n var faceColors = options.faceColors;\r\n // default face colors and UV if undefined\r\n var quadNb = (arc !== 1 && enclose) ? 2 : 0;\r\n var ringNb = (hasRings) ? subdivisions : 1;\r\n var surfaceNb = 2 + (1 + quadNb) * ringNb;\r\n var f;\r\n for (f = 0; f < surfaceNb; f++) {\r\n if (faceColors && faceColors[f] === undefined) {\r\n faceColors[f] = new Color4(1, 1, 1, 1);\r\n }\r\n }\r\n for (f = 0; f < surfaceNb; f++) {\r\n if (faceUV && faceUV[f] === undefined) {\r\n faceUV[f] = new Vector4(0, 0, 1, 1);\r\n }\r\n }\r\n var indices = new Array();\r\n var positions = new Array();\r\n var normals = new Array();\r\n var uvs = new Array();\r\n var colors = new Array();\r\n var angle_step = Math.PI * 2 * arc / tessellation;\r\n var angle;\r\n var h;\r\n var radius;\r\n var tan = (diameterBottom - diameterTop) / 2 / height;\r\n var ringVertex = Vector3.Zero();\r\n var ringNormal = Vector3.Zero();\r\n var ringFirstVertex = Vector3.Zero();\r\n var ringFirstNormal = Vector3.Zero();\r\n var quadNormal = Vector3.Zero();\r\n var Y = Axis.Y;\r\n // positions, normals, uvs\r\n var i;\r\n var j;\r\n var r;\r\n var ringIdx = 1;\r\n var s = 1; // surface index\r\n var cs = 0;\r\n var v = 0;\r\n for (i = 0; i <= subdivisions; i++) {\r\n h = i / subdivisions;\r\n radius = (h * (diameterTop - diameterBottom) + diameterBottom) / 2;\r\n ringIdx = (hasRings && i !== 0 && i !== subdivisions) ? 2 : 1;\r\n for (r = 0; r < ringIdx; r++) {\r\n if (hasRings) {\r\n s += r;\r\n }\r\n if (enclose) {\r\n s += 2 * r;\r\n }\r\n for (j = 0; j <= tessellation; j++) {\r\n angle = j * angle_step;\r\n // position\r\n ringVertex.x = Math.cos(-angle) * radius;\r\n ringVertex.y = -height / 2 + h * height;\r\n ringVertex.z = Math.sin(-angle) * radius;\r\n // normal\r\n if (diameterTop === 0 && i === subdivisions) {\r\n // if no top cap, reuse former normals\r\n ringNormal.x = normals[normals.length - (tessellation + 1) * 3];\r\n ringNormal.y = normals[normals.length - (tessellation + 1) * 3 + 1];\r\n ringNormal.z = normals[normals.length - (tessellation + 1) * 3 + 2];\r\n }\r\n else {\r\n ringNormal.x = ringVertex.x;\r\n ringNormal.z = ringVertex.z;\r\n ringNormal.y = Math.sqrt(ringNormal.x * ringNormal.x + ringNormal.z * ringNormal.z) * tan;\r\n ringNormal.normalize();\r\n }\r\n // keep first ring vertex values for enclose\r\n if (j === 0) {\r\n ringFirstVertex.copyFrom(ringVertex);\r\n ringFirstNormal.copyFrom(ringNormal);\r\n }\r\n positions.push(ringVertex.x, ringVertex.y, ringVertex.z);\r\n normals.push(ringNormal.x, ringNormal.y, ringNormal.z);\r\n if (hasRings) {\r\n v = (cs !== s) ? faceUV[s].y : faceUV[s].w;\r\n }\r\n else {\r\n v = faceUV[s].y + (faceUV[s].w - faceUV[s].y) * h;\r\n }\r\n uvs.push(faceUV[s].x + (faceUV[s].z - faceUV[s].x) * j / tessellation, v);\r\n if (faceColors) {\r\n colors.push(faceColors[s].r, faceColors[s].g, faceColors[s].b, faceColors[s].a);\r\n }\r\n }\r\n // if enclose, add four vertices and their dedicated normals\r\n if (arc !== 1 && enclose) {\r\n positions.push(ringVertex.x, ringVertex.y, ringVertex.z);\r\n positions.push(0, ringVertex.y, 0);\r\n positions.push(0, ringVertex.y, 0);\r\n positions.push(ringFirstVertex.x, ringFirstVertex.y, ringFirstVertex.z);\r\n Vector3.CrossToRef(Y, ringNormal, quadNormal);\r\n quadNormal.normalize();\r\n normals.push(quadNormal.x, quadNormal.y, quadNormal.z, quadNormal.x, quadNormal.y, quadNormal.z);\r\n Vector3.CrossToRef(ringFirstNormal, Y, quadNormal);\r\n quadNormal.normalize();\r\n normals.push(quadNormal.x, quadNormal.y, quadNormal.z, quadNormal.x, quadNormal.y, quadNormal.z);\r\n if (hasRings) {\r\n v = (cs !== s) ? faceUV[s + 1].y : faceUV[s + 1].w;\r\n }\r\n else {\r\n v = faceUV[s + 1].y + (faceUV[s + 1].w - faceUV[s + 1].y) * h;\r\n }\r\n uvs.push(faceUV[s + 1].x, v);\r\n uvs.push(faceUV[s + 1].z, v);\r\n if (hasRings) {\r\n v = (cs !== s) ? faceUV[s + 2].y : faceUV[s + 2].w;\r\n }\r\n else {\r\n v = faceUV[s + 2].y + (faceUV[s + 2].w - faceUV[s + 2].y) * h;\r\n }\r\n uvs.push(faceUV[s + 2].x, v);\r\n uvs.push(faceUV[s + 2].z, v);\r\n if (faceColors) {\r\n colors.push(faceColors[s + 1].r, faceColors[s + 1].g, faceColors[s + 1].b, faceColors[s + 1].a);\r\n colors.push(faceColors[s + 1].r, faceColors[s + 1].g, faceColors[s + 1].b, faceColors[s + 1].a);\r\n colors.push(faceColors[s + 2].r, faceColors[s + 2].g, faceColors[s + 2].b, faceColors[s + 2].a);\r\n colors.push(faceColors[s + 2].r, faceColors[s + 2].g, faceColors[s + 2].b, faceColors[s + 2].a);\r\n }\r\n }\r\n if (cs !== s) {\r\n cs = s;\r\n }\r\n }\r\n }\r\n // indices\r\n var e = (arc !== 1 && enclose) ? tessellation + 4 : tessellation; // correction of number of iteration if enclose\r\n var s;\r\n i = 0;\r\n for (s = 0; s < subdivisions; s++) {\r\n var i0 = 0;\r\n var i1 = 0;\r\n var i2 = 0;\r\n var i3 = 0;\r\n for (j = 0; j < tessellation; j++) {\r\n i0 = i * (e + 1) + j;\r\n i1 = (i + 1) * (e + 1) + j;\r\n i2 = i * (e + 1) + (j + 1);\r\n i3 = (i + 1) * (e + 1) + (j + 1);\r\n indices.push(i0, i1, i2);\r\n indices.push(i3, i2, i1);\r\n }\r\n if (arc !== 1 && enclose) { // if enclose, add two quads\r\n indices.push(i0 + 2, i1 + 2, i2 + 2);\r\n indices.push(i3 + 2, i2 + 2, i1 + 2);\r\n indices.push(i0 + 4, i1 + 4, i2 + 4);\r\n indices.push(i3 + 4, i2 + 4, i1 + 4);\r\n }\r\n i = (hasRings) ? (i + 2) : (i + 1);\r\n }\r\n // Caps\r\n var createCylinderCap = function (isTop) {\r\n var radius = isTop ? diameterTop / 2 : diameterBottom / 2;\r\n if (radius === 0) {\r\n return;\r\n }\r\n // Cap positions, normals & uvs\r\n var angle;\r\n var circleVector;\r\n var i;\r\n var u = (isTop) ? faceUV[surfaceNb - 1] : faceUV[0];\r\n var c = null;\r\n if (faceColors) {\r\n c = (isTop) ? faceColors[surfaceNb - 1] : faceColors[0];\r\n }\r\n // cap center\r\n var vbase = positions.length / 3;\r\n var offset = isTop ? height / 2 : -height / 2;\r\n var center = new Vector3(0, offset, 0);\r\n positions.push(center.x, center.y, center.z);\r\n normals.push(0, isTop ? 1 : -1, 0);\r\n uvs.push(u.x + (u.z - u.x) * 0.5, u.y + (u.w - u.y) * 0.5);\r\n if (c) {\r\n colors.push(c.r, c.g, c.b, c.a);\r\n }\r\n var textureScale = new Vector2(0.5, 0.5);\r\n for (i = 0; i <= tessellation; i++) {\r\n angle = Math.PI * 2 * i * arc / tessellation;\r\n var cos = Math.cos(-angle);\r\n var sin = Math.sin(-angle);\r\n circleVector = new Vector3(cos * radius, offset, sin * radius);\r\n var textureCoordinate = new Vector2(cos * textureScale.x + 0.5, sin * textureScale.y + 0.5);\r\n positions.push(circleVector.x, circleVector.y, circleVector.z);\r\n normals.push(0, isTop ? 1 : -1, 0);\r\n uvs.push(u.x + (u.z - u.x) * textureCoordinate.x, u.y + (u.w - u.y) * textureCoordinate.y);\r\n if (c) {\r\n colors.push(c.r, c.g, c.b, c.a);\r\n }\r\n }\r\n // Cap indices\r\n for (i = 0; i < tessellation; i++) {\r\n if (!isTop) {\r\n indices.push(vbase);\r\n indices.push(vbase + (i + 1));\r\n indices.push(vbase + (i + 2));\r\n }\r\n else {\r\n indices.push(vbase);\r\n indices.push(vbase + (i + 2));\r\n indices.push(vbase + (i + 1));\r\n }\r\n }\r\n };\r\n // add caps to geometry based on cap parameter\r\n if ((cap === Mesh.CAP_START)\r\n || (cap === Mesh.CAP_ALL)) {\r\n createCylinderCap(false);\r\n }\r\n if ((cap === Mesh.CAP_END)\r\n || (cap === Mesh.CAP_ALL)) {\r\n createCylinderCap(true);\r\n }\r\n // Sides\r\n VertexData._ComputeSides(sideOrientation, positions, indices, normals, uvs, options.frontUVs, options.backUVs);\r\n var vertexData = new VertexData();\r\n vertexData.indices = indices;\r\n vertexData.positions = positions;\r\n vertexData.normals = normals;\r\n vertexData.uvs = uvs;\r\n if (faceColors) {\r\n vertexData.colors = colors;\r\n }\r\n return vertexData;\r\n};\r\nMesh.CreateCylinder = function (name, height, diameterTop, diameterBottom, tessellation, subdivisions, scene, updatable, sideOrientation) {\r\n if (scene === undefined || !(scene instanceof Scene)) {\r\n if (scene !== undefined) {\r\n sideOrientation = updatable || Mesh.DEFAULTSIDE;\r\n updatable = scene;\r\n }\r\n scene = subdivisions;\r\n subdivisions = 1;\r\n }\r\n var options = {\r\n height: height,\r\n diameterTop: diameterTop,\r\n diameterBottom: diameterBottom,\r\n tessellation: tessellation,\r\n subdivisions: subdivisions,\r\n sideOrientation: sideOrientation,\r\n updatable: updatable\r\n };\r\n return CylinderBuilder.CreateCylinder(name, options, scene);\r\n};\r\n/**\r\n * Class containing static functions to help procedurally build meshes\r\n */\r\nvar CylinderBuilder = /** @class */ (function () {\r\n function CylinderBuilder() {\r\n }\r\n /**\r\n * Creates a cylinder or a cone mesh\r\n * * The parameter `height` sets the height size (float) of the cylinder/cone (float, default 2).\r\n * * The parameter `diameter` sets the diameter of the top and bottom cap at once (float, default 1).\r\n * * The parameters `diameterTop` and `diameterBottom` overwrite the parameter `diameter` and set respectively the top cap and bottom cap diameter (floats, default 1). The parameter \"diameterBottom\" can't be zero.\r\n * * The parameter `tessellation` sets the number of cylinder sides (positive integer, default 24). Set it to 3 to get a prism for instance.\r\n * * The parameter `subdivisions` sets the number of rings along the cylinder height (positive integer, default 1).\r\n * * The parameter `hasRings` (boolean, default false) makes the subdivisions independent from each other, so they become different faces.\r\n * * The parameter `enclose` (boolean, default false) adds two extra faces per subdivision to a sliced cylinder to close it around its height axis.\r\n * * The parameter `cap` sets the way the cylinder is capped. Possible values : BABYLON.Mesh.NO_CAP, BABYLON.Mesh.CAP_START, BABYLON.Mesh.CAP_END, BABYLON.Mesh.CAP_ALL (default).\r\n * * The parameter `arc` (float, default 1) is the ratio (max 1) to apply to the circumference to slice the cylinder.\r\n * * You can set different colors and different images to each box side by using the parameters `faceColors` (an array of n Color3 elements) and `faceUV` (an array of n Vector4 elements).\r\n * * The value of n is the number of cylinder faces. If the cylinder has only 1 subdivisions, n equals : top face + cylinder surface + bottom face = 3\r\n * * Now, if the cylinder has 5 independent subdivisions (hasRings = true), n equals : top face + 5 stripe surfaces + bottom face = 2 + 5 = 7\r\n * * Finally, if the cylinder has 5 independent subdivisions and is enclose, n equals : top face + 5 x (stripe surface + 2 closing faces) + bottom face = 2 + 5 * 3 = 17\r\n * * Each array (color or UVs) is always ordered the same way : the first element is the bottom cap, the last element is the top cap. The other elements are each a ring surface.\r\n * * If `enclose` is false, a ring surface is one element.\r\n * * If `enclose` is true, a ring surface is 3 successive elements in the array : the tubular surface, then the two closing faces.\r\n * * Example how to set colors and textures on a sliced cylinder : https://www.html5gamedevs.com/topic/17945-creating-a-closed-slice-of-a-cylinder/#comment-106379\r\n * * You can also set the mesh side orientation with the values : BABYLON.Mesh.FRONTSIDE (default), BABYLON.Mesh.BACKSIDE or BABYLON.Mesh.DOUBLESIDE\r\n * * If you create a double-sided mesh, you can choose what parts of the texture image to crop and stick respectively on the front and the back sides with the parameters `frontUVs` and `backUVs` (Vector4). Detail here : https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created.\r\n * @param name defines the name of the mesh\r\n * @param options defines the options used to create the mesh\r\n * @param scene defines the hosting scene\r\n * @returns the cylinder mesh\r\n * @see https://doc.babylonjs.com/how_to/set_shapes#cylinder-or-cone\r\n */\r\n CylinderBuilder.CreateCylinder = function (name, options, scene) {\r\n var cylinder = new Mesh(name, scene);\r\n options.sideOrientation = Mesh._GetDefaultSideOrientation(options.sideOrientation);\r\n cylinder._originalBuilderSideOrientation = options.sideOrientation;\r\n var vertexData = VertexData.CreateCylinder(options);\r\n vertexData.applyToMesh(cylinder, options.updatable);\r\n return cylinder;\r\n };\r\n return CylinderBuilder;\r\n}());\r\nexport { CylinderBuilder };\r\n//# sourceMappingURL=cylinderBuilder.js.map","/**\r\n * Babyplots - Easy, fast, interactive 3D visualizations\r\n *\r\n * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved.\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n * \r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n * \r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n * \r\n */\r\n\r\nimport { Scene } from \"@babylonjs/core/scene\";\r\nimport { ArcRotateCamera } from \"@babylonjs/core/Cameras/arcRotateCamera\";\r\nimport { Mesh } from \"@babylonjs/core/Meshes/mesh\";\r\nimport { LinesBuilder } from \"@babylonjs/core/Meshes/Builders/linesBuilder\";\r\nimport { LinesMesh } from \"@babylonjs/core/Meshes/linesMesh\";\r\nimport { Vector3, Axis, Color3} from \"@babylonjs/core/Maths/math\";\r\nimport { DynamicTexture } from \"@babylonjs/core/Materials/Textures/dynamicTexture\";\r\nimport { StandardMaterial } from \"@babylonjs/core/Materials/standardMaterial\";\r\nimport { AxisData } from \"./babyplots\";\r\n\r\n/**\r\n * Class to store and update plot axes.\r\n */\r\nexport class Axes {\r\n private _axes: LinesMesh[] = [];\r\n private _axisLabels: Mesh[] = [];\r\n private _ticks: LinesMesh[] = [];\r\n private _tickLabels: Mesh[] = [];\r\n private _tickLines: LinesMesh[] = [];\r\n private _scene: Scene;\r\n axisData: AxisData;\r\n /**\r\n * Create axes for plot.\r\n * @param axisData object containing all information about axis setup.\r\n * @param scene BABYLON scene.\r\n */\r\n constructor(axisData: AxisData, scene: Scene, heatmap: boolean = false) {\r\n this.axisData = axisData;\r\n this._scene = scene;\r\n this._createAxes(heatmap);\r\n }\r\n private _roundTicks(num: number, scale: number = 2): number {\r\n if (!(\"\" + num).includes(\"e\")) {\r\n return +(Math.round(parseFloat(num.toString() + \"e+\" + scale.toString())) + \"e-\" + scale);\r\n }\r\n else {\r\n var arr = (\"\" + num).split(\"e\");\r\n var sig = \"\";\r\n if (+arr[1] + scale > 0) {\r\n sig = \"+\";\r\n }\r\n return +(Math.round(parseFloat(+arr[0].toString() + \"e\" + sig.toString() + (+arr[1].toString() + scale.toString()))) + \"e-\" + scale);\r\n }\r\n }\r\n private _createAxes(heatmap: boolean = false): void {\r\n if (heatmap) {\r\n // Tick breaks for heat map on x and z coordinates have to match columns and rows\r\n this.axisData.tickBreaks[0] = 1;\r\n this.axisData.tickBreaks[2] = 1;\r\n }\r\n // Apply scaling factor to tick break interval to get distance between ticks\r\n let xtickBreaks = this.axisData.tickBreaks[0] * this.axisData.scale[0];\r\n let ytickBreaks = this.axisData.tickBreaks[1] * this.axisData.scale[1];\r\n let ztickBreaks = this.axisData.tickBreaks[2] * this.axisData.scale[2];\r\n // Find minima and maxima of the axes as a multiple of the tick interval distance\r\n let xmin = Math.floor(this.axisData.range[0][0] / xtickBreaks) * xtickBreaks;\r\n let ymin = Math.floor(this.axisData.range[1][0] / ytickBreaks) * ytickBreaks;\r\n let zmin = Math.floor(this.axisData.range[2][0] / ztickBreaks) * ztickBreaks;\r\n let xmax = Math.ceil(this.axisData.range[0][1] / xtickBreaks) * xtickBreaks;\r\n let ymax = Math.ceil(this.axisData.range[1][1] / ytickBreaks) * ytickBreaks;\r\n let zmax = Math.ceil(this.axisData.range[2][1] / ztickBreaks) * ztickBreaks;\r\n // Create X axis\r\n if (this.axisData.showAxes[0]) {\r\n // Create axis line\r\n let axisX = LinesBuilder.CreateLines(\"axisX\", {\r\n points: [\r\n new Vector3(xmin, ymin, zmin),\r\n new Vector3(xmax, ymin, zmin)\r\n ]\r\n }, this._scene);\r\n // Apply axis color\r\n axisX.color = Color3.FromHexString(this.axisData.color[0]);\r\n this._axes.push(axisX);\r\n // Create axis label\r\n let xChar = this._makeTextPlane(this.axisData.axisLabels[0], 1, this.axisData.color[0]);\r\n // Place label near end of the axis\r\n xChar.position = new Vector3(xmax / 2, ymin - 0.5 * ymax, zmin);\r\n this._axisLabels.push(xChar);\r\n // Create ticks and tick lines\r\n let xTicks = [];\r\n // Find x coordinates for ticks\r\n // Negative ticks\r\n for (let i = 0; i < -Math.ceil(this.axisData.range[0][0] / xtickBreaks); i++) {\r\n xTicks.push(-(i + 1) * xtickBreaks);\r\n }\r\n // Positive ticks\r\n for (let i = 0; i <= Math.ceil(this.axisData.range[0][1] / xtickBreaks); i++) {\r\n xTicks.push(i * xtickBreaks);\r\n }\r\n // Usually ticks start with 0, heat map starts with 1\r\n let startTick = 0;\r\n if (heatmap) {\r\n startTick = 1;\r\n }\r\n // Create all ticks\r\n for (let i = startTick; i < xTicks.length; i++) {\r\n let tickPos = xTicks[i];\r\n if (heatmap) {\r\n tickPos = tickPos - 0.5 * this.axisData.scale[0];\r\n }\r\n let tick = LinesBuilder.CreateLines(\"xTicks\", {\r\n points: [\r\n new Vector3(tickPos, ymin, zmin + 0.05 * xmax),\r\n new Vector3(tickPos, ymin, zmin),\r\n new Vector3(tickPos, ymin + 0.05 * ymax, zmin)\r\n ]\r\n }, this._scene);\r\n tick.color = Color3.FromHexString(this.axisData.color[0]);\r\n this._ticks.push(tick);\r\n let tickLabel = this._roundTicks(tickPos / this.axisData.scale[0]).toString();\r\n if (heatmap) {\r\n tickLabel = this.axisData.colnames[i - 1];\r\n }\r\n if (tickLabel === undefined) {\r\n continue;\r\n }\r\n let tickChar = this._makeTextPlane(tickLabel, 0.6, this.axisData.color[0]);\r\n tickChar.position = new Vector3(tickPos, ymin - 0.1 * ymax, zmin);\r\n this._tickLabels.push(tickChar);\r\n if (this.axisData.showTickLines[0][0]) {\r\n let tickLine = LinesBuilder.CreateLines(\"xTickLines\", {\r\n points: [\r\n new Vector3(tickPos, ymax, zmin),\r\n new Vector3(tickPos, ymin, zmin)\r\n ]\r\n }, this._scene);\r\n tickLine.color = Color3.FromHexString(this.axisData.tickLineColor[0][0]);\r\n this._tickLines.push(tickLine);\r\n }\r\n if (this.axisData.showTickLines[0][1]) {\r\n let tickLine = LinesBuilder.CreateLines(\"xTickLines\", {\r\n points: [\r\n new Vector3(tickPos, ymin, zmax),\r\n new Vector3(tickPos, ymin, zmin)\r\n ]\r\n }, this._scene);\r\n tickLine.color = Color3.FromHexString(this.axisData.tickLineColor[0][1]);\r\n this._tickLines.push(tickLine);\r\n }\r\n }\r\n }\r\n // create Y axis\r\n if (this.axisData.showAxes[1]) {\r\n // axis\r\n let axisY = LinesBuilder.CreateLines(\"axisY\", {\r\n points: [\r\n new Vector3(xmin, ymin, zmin),\r\n new Vector3(xmin, ymax, zmin)\r\n ]\r\n }, this._scene);\r\n axisY.color = Color3.FromHexString(this.axisData.color[1]);\r\n this._axes.push(axisY);\r\n // label\r\n let yChar = this._makeTextPlane(this.axisData.axisLabels[1], 1, this.axisData.color[1]);\r\n yChar.position = new Vector3(xmin, ymax / 2, zmin - 0.5 * ymax);\r\n this._axisLabels.push(yChar);\r\n // y ticks and tick lines\r\n let yTicks = [];\r\n for (let i = 0; i < -Math.ceil(this.axisData.range[1][0] / ytickBreaks); i++) {\r\n yTicks.push(-(i + 1) * ytickBreaks);\r\n }\r\n for (let i = 0; i <= Math.ceil(this.axisData.range[1][1] / ytickBreaks); i++) {\r\n yTicks.push(i * ytickBreaks);\r\n }\r\n for (let i = 0; i < yTicks.length; i++) {\r\n let tickPos = yTicks[i];\r\n let tick = LinesBuilder.CreateLines(\"yTicks\", {\r\n points: [\r\n new Vector3(xmin, tickPos, zmin + 0.05 * zmax),\r\n new Vector3(xmin, tickPos, zmin),\r\n new Vector3(xmin + 0.05 * xmax, tickPos, zmin)\r\n ]\r\n }, this._scene);\r\n tick.color = Color3.FromHexString(this.axisData.color[1]);\r\n this._ticks.push(tick);\r\n let tickLabel = this._roundTicks(tickPos / this.axisData.scale[1]);\r\n let tickChar = this._makeTextPlane(tickLabel.toString(), 0.6, this.axisData.color[1]);\r\n tickChar.position = new Vector3(xmin, tickPos, zmin - 0.05 * ymax);\r\n this._tickLabels.push(tickChar);\r\n // tick lines\r\n if (this.axisData.showTickLines[1][0]) {\r\n let tickLine = LinesBuilder.CreateLines(\"yTicksLines\", {\r\n points: [\r\n new Vector3(xmax, tickPos, zmin),\r\n new Vector3(xmin, tickPos, zmin)\r\n ]\r\n }, this._scene);\r\n tickLine.color = Color3.FromHexString(this.axisData.tickLineColor[1][0]);\r\n this._tickLines.push(tickLine);\r\n }\r\n if (this.axisData.showTickLines[1][1]) {\r\n let tickLine = LinesBuilder.CreateLines(\"yTickLines\", {\r\n points: [\r\n new Vector3(xmin, tickPos, zmax),\r\n new Vector3(xmin, tickPos, zmin)\r\n ]\r\n }, this._scene);\r\n tickLine.color = Color3.FromHexString(this.axisData.tickLineColor[1][1]);\r\n this._tickLines.push(tickLine);\r\n }\r\n }\r\n }\r\n // create Z axis\r\n if (this.axisData.showAxes[2]) {\r\n // axis\r\n let axisZ = LinesBuilder.CreateLines(\"axisZ\", {\r\n points: [\r\n new Vector3(xmin, ymin, zmin),\r\n new Vector3(xmin, ymin, zmax)\r\n ]\r\n }, this._scene);\r\n axisZ.color = Color3.FromHexString(this.axisData.color[2]);\r\n this._axes.push(axisZ);\r\n // label\r\n let zChar = this._makeTextPlane(this.axisData.axisLabels[2], 1, this.axisData.color[2]);\r\n zChar.position = new Vector3(xmin, ymin - 0.5 * ymax, zmax / 2);\r\n this._axisLabels.push(zChar);\r\n // z ticks and tick lines\r\n let zTicks = [];\r\n for (let i = 0; i < -Math.ceil(this.axisData.range[2][0] / ztickBreaks); i++) {\r\n zTicks.push(-(i + 1) * ztickBreaks);\r\n }\r\n for (let i = 0; i <= Math.ceil(this.axisData.range[2][1] / ztickBreaks); i++) {\r\n zTicks.push(i * ztickBreaks);\r\n }\r\n let startTick = 0;\r\n if (heatmap) {\r\n startTick = 1;\r\n }\r\n for (let i = startTick; i < zTicks.length; i++) {\r\n let tickPos = zTicks[i];\r\n if (heatmap) {\r\n tickPos = tickPos - 0.5 * this.axisData.scale[2];\r\n }\r\n let tick = LinesBuilder.CreateLines(\"zTicks\", {\r\n points: [\r\n new Vector3(xmin + 0.05 * xmax, ymin, tickPos),\r\n new Vector3(xmin, ymin, tickPos),\r\n new Vector3(xmin, ymin + 0.05 * ymax, tickPos)\r\n ]\r\n }, this._scene);\r\n tick.color = Color3.FromHexString(this.axisData.color[2]);\r\n this._ticks.push(tick);\r\n let tickLabel = this._roundTicks(tickPos / this.axisData.scale[2]).toString();\r\n if (heatmap) {\r\n tickLabel = this.axisData.rownames[i - 1];\r\n }\r\n if (tickLabel === undefined) {\r\n continue;\r\n }\r\n let tickChar = this._makeTextPlane(tickLabel, 0.6, this.axisData.color[2]);\r\n tickChar.position = new Vector3(xmin, ymin - 0.1 * ymax, tickPos);\r\n this._tickLabels.push(tickChar);\r\n // tick lines\r\n if (this.axisData.showTickLines[2][0]) {\r\n let tickLine = LinesBuilder.CreateLines(\"zTickLines\", {\r\n points: [\r\n new Vector3(xmax, ymin, tickPos),\r\n new Vector3(xmin, ymin, tickPos)\r\n ]\r\n }, this._scene);\r\n tickLine.color = Color3.FromHexString(this.axisData.tickLineColor[2][0]);\r\n this._tickLines.push(tickLine);\r\n }\r\n if (this.axisData.showTickLines[2][1]) {\r\n let tickLine = LinesBuilder.CreateLines(\"zTickLines\", {\r\n points: [\r\n new Vector3(xmin, ymax, tickPos),\r\n new Vector3(xmin, ymin, tickPos)\r\n ]\r\n }, this._scene);\r\n tickLine.color = Color3.FromHexString(this.axisData.tickLineColor[2][1]);\r\n this._tickLines.push(tickLine);\r\n }\r\n }\r\n }\r\n }\r\n private _makeTextPlane(text: string, size: number, color: string): Mesh {\r\n var dynamicTexture = new DynamicTexture(\"DynamicTexture\", 75, this._scene, true);\r\n dynamicTexture.hasAlpha = true;\r\n dynamicTexture.drawText(text, 5, 40, (40 - text.length * 4) + \"px Arial\", color, \"transparent\", true);\r\n var plane = Mesh.CreatePlane(\"TextPlane\", size, this._scene, true);\r\n var material = new StandardMaterial(\"TextPlaneMaterial\", this._scene);\r\n material.backFaceCulling = false;\r\n material.specularColor = new Color3(0, 0, 0);\r\n material.diffuseTexture = dynamicTexture;\r\n plane.material = material;\r\n return plane;\r\n }\r\n update(camera: ArcRotateCamera, updateAxisData?: boolean): void {\r\n if (updateAxisData) {\r\n for (let i = 0; i < this._axes.length; i++) {\r\n this._axes[i].dispose();\r\n }\r\n for (let i = 0; i < this._axisLabels.length; i++) {\r\n this._axisLabels[i].dispose();\r\n }\r\n for (let i = 0; i < this._ticks.length; i++) {\r\n this._ticks[i].dispose();\r\n }\r\n for (let i = 0; i < this._tickLabels.length; i++) {\r\n this._tickLabels[i].dispose();\r\n }\r\n for (let i = 0; i < this._tickLines.length; i++) {\r\n this._tickLines[i].dispose();\r\n }\r\n this._createAxes();\r\n }\r\n if (this.axisData.showAxes) {\r\n let axis1 = Vector3.Cross(camera.position, Axis.Y);\r\n let axis2 = Vector3.Cross(axis1, camera.position);\r\n let axis3 = Vector3.Cross(axis1, axis2);\r\n for (let i = 0; i < this._axisLabels.length; i++) {\r\n this._axisLabels[i].rotation = Vector3.RotationFromAxis(axis1, axis2, axis3);\r\n }\r\n for (let i = 0; i < this._tickLabels.length; i++) {\r\n this._tickLabels[i].rotation = Vector3.RotationFromAxis(axis1, axis2, axis3);\r\n }\r\n }\r\n }\r\n}\r\n","/**\r\n * Babyplots - Easy, fast, interactive 3D visualizations\r\n *\r\n * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved.\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n * \r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n * \r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n * \r\n */\r\n\r\nimport { Scene } from \"@babylonjs/core/scene\";\r\nimport { Mesh } from \"@babylonjs/core/Meshes/mesh\";\r\nimport { Color3 } from \"@babylonjs/core/Maths/math\";\r\nimport { VertexData } from \"@babylonjs/core/Meshes/mesh.vertexData\";\r\nimport { StandardMaterial } from \"@babylonjs/core/Materials/standardMaterial\";\r\nimport { Plot, LegendData } from \"./babyplots\";\r\nimport chroma from \"chroma-js\";\r\n\r\n\r\n\r\nexport class ImgStack extends Plot {\r\n private _backgroundColor: string;\r\n private _intensityMode: string;\r\n private _channelCoords: number[][][];\r\n private _channelCoordIntensities: number[][];\r\n constructor(\r\n scene: Scene,\r\n values: number[],\r\n indices: number[],\r\n attributes: { dim: number[] },\r\n legendData: LegendData,\r\n size: number,\r\n backgroundColor: string,\r\n intensityMode: string,\r\n xScale: number = 1,\r\n yScale: number = 1,\r\n zScale: number = 1\r\n ) {\r\n let colSize = attributes.dim[0];\r\n let rowSize = attributes.dim[1];\r\n let channels = attributes.dim[2];\r\n let slices = attributes.dim[3];\r\n let channelSize = colSize * rowSize;\r\n let sliceSize = channelSize * channels;\r\n let coords = [];\r\n let Intensities = [];\r\n for (let i = 0; i < channels; i++) {\r\n coords.push([]);\r\n Intensities.push([]);\r\n }\r\n for (let i = 0; i < indices.length; i++) {\r\n const index = indices[i];\r\n let slice = Math.floor(index / sliceSize);\r\n let sliceIndex = index - sliceSize * slice;\r\n let channel = Math.floor(sliceIndex / channelSize);\r\n let channelIndex = sliceIndex - channelSize * channel;\r\n let row = Math.floor(channelIndex / colSize);\r\n let col = channelIndex % colSize;\r\n coords[channel].push([\r\n col * xScale,\r\n row * yScale,\r\n slice * zScale\r\n ]);\r\n Intensities[channel].push(values[i]);\r\n }\r\n super(scene, [], [], size, legendData, xScale, yScale, zScale);\r\n this._channelCoords = coords;\r\n this._channelCoordIntensities = Intensities;\r\n this._backgroundColor = backgroundColor;\r\n this._intensityMode = intensityMode;\r\n this.meshes = [];\r\n this._createImgStack();\r\n }\r\n\r\n private _createImgStack(): void {\r\n let positions = [];\r\n let colors = [];\r\n for (let c = 0; c < this._channelCoords.length; c++) {\r\n const channelIntensities = this._channelCoordIntensities[c];\r\n if (channelIntensities.length === 0) {\r\n continue;\r\n }\r\n const channelCoords = this._channelCoords[c];\r\n let channelColor: string;\r\n if (c == 0) {\r\n channelColor = \"#ff0000\";\r\n } else if (c == 1) {\r\n channelColor = \"#00ff00\";\r\n } else {\r\n channelColor = \"#0000ff\";\r\n }\r\n let channelColorRGB = chroma(channelColor).rgb();\r\n channelColorRGB[0] = channelColorRGB[0] / 255;\r\n channelColorRGB[1] = channelColorRGB[1] / 255;\r\n channelColorRGB[2] = channelColorRGB[2] / 255;\r\n if (this._intensityMode === \"alpha\") {\r\n let alphaLevels = 10;\r\n let minIntensity = channelIntensities.min();\r\n let alphaPositions: number[][] = [];\r\n let alphaColors: number[][] = [];\r\n let alphaIntensities: number[] = [];\r\n for (let i = 0; i < alphaLevels; i++) {\r\n alphaPositions.push([]);\r\n alphaColors.push([]);\r\n alphaIntensities.push((i + 1) * (1 / alphaLevels));\r\n }\r\n\r\n for (let p = 0; p < channelCoords.length; p++) {\r\n for (let intens = 0; intens < alphaIntensities.length; intens++) {\r\n const testIntensity = alphaIntensities[intens];\r\n if ((channelIntensities[p] - minIntensity) / (1 - minIntensity) <= testIntensity) {\r\n alphaPositions[intens].push(\r\n channelCoords[p][2],\r\n channelCoords[p][0],\r\n channelCoords[p][1]\r\n );\r\n alphaColors[intens].push(\r\n channelColorRGB[0],\r\n channelColorRGB[1],\r\n channelColorRGB[2],\r\n 1\r\n );\r\n break;\r\n }\r\n }\r\n }\r\n\r\n for (let intensIdx = 0; intensIdx < alphaIntensities.length; intensIdx++) {\r\n if (alphaColors[intensIdx].length <= 4) {\r\n continue;\r\n }\r\n let customMesh = new Mesh(`custom-${c}_${intensIdx}`, this._scene);\r\n const intensity = alphaIntensities[intensIdx];\r\n let vertexData = new VertexData();\r\n vertexData.positions = alphaPositions[intensIdx];\r\n vertexData.colors = alphaColors[intensIdx];\r\n vertexData.applyToMesh(customMesh, true);\r\n let mat = new StandardMaterial(`mat-${c}_${intensIdx}`, this._scene);\r\n mat.emissiveColor = new Color3(1, 1, 1);\r\n mat.disableLighting = true;\r\n mat.pointsCloud = true;\r\n mat.pointSize = this._size;\r\n mat.alpha = intensity;\r\n customMesh.material = mat;\r\n this.meshes.push(customMesh);\r\n }\r\n\r\n } else {\r\n for (let p = 0; p < channelCoords.length; p++) {\r\n positions.push(channelCoords[p][2], channelCoords[p][0], channelCoords[p][1]);\r\n if (this._intensityMode === \"mix\") {\r\n let colormix = chroma.mix(this._backgroundColor, channelColor, channelIntensities[p]).rgb();\r\n colors.push(colormix[0] / 255, colormix[1] / 255, colormix[2] / 255, 1);\r\n } else {\r\n colors.push(channelColorRGB[0], channelColorRGB[1], channelColorRGB[2], 1);\r\n }\r\n }\r\n let customMesh = new Mesh(`custom-${c}`, this._scene);\r\n let vertexData = new VertexData();\r\n vertexData.positions = positions;\r\n vertexData.colors = colors;\r\n vertexData.applyToMesh(customMesh, true);\r\n let mat = new StandardMaterial(`mat-${c}`, this._scene);\r\n mat.emissiveColor = new Color3(1, 1, 1);\r\n mat.disableLighting = true;\r\n mat.pointsCloud = true;\r\n mat.pointSize = this._size;\r\n customMesh.material = mat;\r\n this.meshes.push(customMesh);\r\n }\r\n }\r\n }\r\n}","/**\r\n * Babyplots - Easy, fast, interactive 3D visualizations\r\n *\r\n * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved.\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n * \r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n * \r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n * \r\n */\r\n\r\nimport { Scene } from \"@babylonjs/core/scene\";\r\nimport { Mesh } from \"@babylonjs/core/Meshes/mesh\";\r\nimport { SphereBuilder } from \"@babylonjs/core/Meshes/Builders/sphereBuilder\";\r\nimport { Vector3, Color4, Color3 } from \"@babylonjs/core/Maths/math\";\r\nimport { SolidParticleSystem } from \"@babylonjs/core/Particles/solidParticleSystem\";\r\nimport { VertexData } from \"@babylonjs/core/Meshes/mesh.vertexData\";\r\nimport { StandardMaterial } from \"@babylonjs/core/Materials/standardMaterial\";\r\nimport { FloatArray } from \"@babylonjs/core/types\";\r\nimport { PickingInfo } from \"@babylonjs/core/Collisions/pickingInfo\";\r\nimport { Plot, LegendData } from \"./babyplots\";\r\n\r\nexport class PointCloud extends Plot {\r\n private _SPS: SolidParticleSystem;\r\n private _pointPicking: boolean = false;\r\n private _selectionCallback = function (selection: number[]) { return false; };\r\n private _folded: boolean;\r\n private _foldedEmbedding: number[][];\r\n private _foldVectors: Vector3[] = [];\r\n private _foldCounter: number = 0;\r\n private _foldAnimFrames: number = 200;\r\n private _foldVectorFract: Vector3[] = [];\r\n private _foldDelay: number = 100;\r\n constructor(\r\n scene: Scene,\r\n coordinates: number[][],\r\n colorVar: string[],\r\n size: number,\r\n legendData: LegendData,\r\n folded?: boolean,\r\n foldedEmbedding?: number[][],\r\n foldAnimDelay?: number,\r\n foldAnimDuration?: number,\r\n xScale: number = 1,\r\n yScale: number = 1,\r\n zScale: number = 1\r\n ) {\r\n super(scene, coordinates, colorVar, size, legendData, xScale, yScale, zScale);\r\n this._folded = folded;\r\n if (foldAnimDelay) {\r\n this._foldDelay = foldAnimDelay;\r\n }\r\n if (foldAnimDuration) {\r\n this._foldAnimFrames = foldAnimDuration;\r\n }\r\n if (folded) {\r\n if (foldedEmbedding) {\r\n for (let i = 0; i < foldedEmbedding.length; i++) {\r\n if (foldedEmbedding[i].length == 2) {\r\n foldedEmbedding[i].push(0);\r\n }\r\n let fv = new Vector3(\r\n coordinates[i][0] * this.xScale,\r\n coordinates[i][2] * this.zScale,\r\n coordinates[i][1] * this.yScale\r\n ).subtractFromFloats(\r\n foldedEmbedding[i][0] * this.xScale,\r\n 0,\r\n foldedEmbedding[i][1] * this.yScale,\r\n );\r\n this._foldVectors.push(fv);\r\n this._foldVectorFract.push(fv.divide(new Vector3(this._foldAnimFrames, this._foldAnimFrames, this._foldAnimFrames)));\r\n }\r\n this._foldedEmbedding = foldedEmbedding;\r\n } else {\r\n foldedEmbedding = JSON.parse(JSON.stringify(coordinates));\r\n for (let i = 0; i < foldedEmbedding.length; i++) {\r\n foldedEmbedding[i][2] = 0;\r\n let fv = new Vector3(\r\n coordinates[i][0] * this.xScale,\r\n coordinates[i][2] * this.zScale,\r\n coordinates[i][1] * this.yScale\r\n ).subtractFromFloats(\r\n foldedEmbedding[i][0] * this.xScale,\r\n 0,\r\n foldedEmbedding[i][1] * this.yScale\r\n );\r\n this._foldVectors.push(fv);\r\n this._foldVectorFract.push(fv.divide(new Vector3(this._foldAnimFrames, this._foldAnimFrames, this._foldAnimFrames)));\r\n }\r\n this._foldedEmbedding = foldedEmbedding;\r\n }\r\n }\r\n this._createPointCloud();\r\n }\r\n /**\r\n * Positions spheres according to coordinates in a SPS\r\n */\r\n private _createPointCloud(): void {\r\n // prototype cell\r\n if (this._coords.length > 10000) {\r\n let customMesh = new Mesh(\"custom\", this._scene);\r\n // Set arrays for positions and indices\r\n let positions = [];\r\n let colors = [];\r\n if (this._folded) {\r\n for (let p = 0; p < this._coords.length; p++) {\r\n positions.push(\r\n this._foldedEmbedding[p][0] * this.xScale,\r\n this._foldedEmbedding[p][2] * this.zScale,\r\n this._foldedEmbedding[p][1] * this.yScale\r\n );\r\n let col = Color4.FromHexString(this._coordColors[p]);\r\n colors.push(col.r, col.g, col.b, col.a);\r\n }\r\n } else {\r\n for (let p = 0; p < this._coords.length; p++) {\r\n positions.push(\r\n this._coords[p][0] * this.xScale,\r\n this._coords[p][2] * this.zScale,\r\n this._coords[p][1] * this.yScale\r\n );\r\n let col = Color4.FromHexString(this._coordColors[p]);\r\n colors.push(col.r, col.g, col.b, col.a);\r\n }\r\n }\r\n var vertexData = new VertexData();\r\n // Assign positions\r\n vertexData.positions = positions;\r\n vertexData.colors = colors;\r\n // Apply vertexData to custom mesh\r\n vertexData.applyToMesh(customMesh, true);\r\n var mat = new StandardMaterial(\"mat\", this._scene);\r\n mat.emissiveColor = new Color3(1, 1, 1);\r\n mat.disableLighting = true;\r\n mat.pointsCloud = true;\r\n mat.pointSize = this._size;\r\n customMesh.material = mat;\r\n this.mesh = customMesh;\r\n }\r\n else {\r\n let cell = SphereBuilder.CreateSphere(\"sphere\", { segments: 2, diameter: this._size * 0.1 }, this._scene);\r\n // let cell = MeshBuilder.CreateDisc(\"disc\", {tessellation: 6, radius: this._size}, this._scene);\r\n // particle system\r\n let SPS = new SolidParticleSystem('SPS', this._scene, {\r\n updatable: true,\r\n isPickable: true\r\n });\r\n // add all cells to SPS\r\n SPS.addShape(cell, this._coords.length);\r\n // position and color cells\r\n if (this._folded) {\r\n for (let i = 0; i < SPS.nbParticles; i++) {\r\n SPS.particles[i].position.x = this._foldedEmbedding[i][0] * this.xScale;\r\n SPS.particles[i].position.z = this._foldedEmbedding[i][1] * this.zScale;\r\n SPS.particles[i].position.y = this._foldedEmbedding[i][2] * this.yScale;\r\n SPS.particles[i].color = Color4.FromHexString(this._coordColors[i]);\r\n }\r\n } else {\r\n for (let i = 0; i < SPS.nbParticles; i++) {\r\n SPS.particles[i].position.x = this._coords[i][0] * this.xScale;\r\n SPS.particles[i].position.z = this._coords[i][1] * this.zScale;\r\n SPS.particles[i].position.y = this._coords[i][2] * this.yScale;\r\n SPS.particles[i].color = Color4.FromHexString(this._coordColors[i]);\r\n }\r\n }\r\n SPS.buildMesh();\r\n // scale bounding box to actual size of the SPS particles\r\n SPS.computeBoundingBox = true;\r\n // remove prototype cell\r\n cell.dispose();\r\n // calculate SPS particles\r\n SPS.setParticles();\r\n // SPS.billboard = true;\r\n SPS.computeBoundingBox = true;\r\n this._SPS = SPS;\r\n this.mesh = SPS.mesh;\r\n var mat = new StandardMaterial(\"pointMat\", this._scene);\r\n mat.alpha = 1;\r\n this.mesh.material = mat;\r\n }\r\n Object.defineProperty(this, \"alpha\", {\r\n set(newAlpha) {\r\n this.mesh.material.alpha = newAlpha;\r\n }\r\n });\r\n }\r\n\r\n resetAnimation(): void {\r\n this._folded = true;\r\n if (this._SPS) {\r\n for (let i = 0; i < this._SPS.particles.length; i++) {\r\n this._SPS.particles[i].position = new Vector3(\r\n this._foldedEmbedding[i][0] * this.xScale,\r\n this._foldedEmbedding[i][2] * this.zScale,\r\n this._foldedEmbedding[i][1] * this.yScale\r\n );\r\n }\r\n this._SPS.setParticles();\r\n } else {\r\n let positionFunction = function (positions: FloatArray) {\r\n let numberOfVertices = positions.length / 3;\r\n for (let i = 0; i < numberOfVertices; i++) {\r\n positions[i * 3] = this._foldedEmbedding[i][0] * this.xScale;\r\n positions[i * 3 + 1] = this._foldedEmbedding[i][2] * this.zScale;\r\n positions[i * 3 + 2] = this._foldedEmbedding[i][1] * this.yScale;\r\n }\r\n }\r\n this.mesh.updateMeshPositions(positionFunction.bind(this), true);\r\n }\r\n this.mesh.refreshBoundingInfo();\r\n this._foldCounter = 0;\r\n }\r\n\r\n update(): boolean {\r\n if (this._SPS && this._folded) {\r\n if (this._foldCounter < this._foldDelay) {\r\n this._foldCounter += 1;\r\n } else if (this._foldCounter < this._foldAnimFrames + this._foldDelay) {\r\n for (let i = 0; i < this._SPS.particles.length; i++) {\r\n this._SPS.particles[i].position.addInPlace(this._foldVectorFract[i]);\r\n }\r\n this._foldCounter += 1;\r\n this._SPS.setParticles();\r\n } else {\r\n this._folded = false;\r\n for (let i = 0; i < this._SPS.particles.length; i++) {\r\n this._SPS.particles[i].position = new Vector3(\r\n this._coords[i][0] * this.xScale,\r\n this._coords[i][2] * this.zScale,\r\n this._coords[i][1] * this.yScale\r\n );\r\n }\r\n this._SPS.setParticles();\r\n this.mesh.refreshBoundingInfo();\r\n }\r\n } else if (this.mesh && this._folded) {\r\n if (this._foldCounter < this._foldDelay) {\r\n this._foldCounter += 1;\r\n } else if (this._foldCounter < this._foldAnimFrames + this._foldDelay) {\r\n let positionFunction = function (positions: FloatArray) {\r\n let numberOfVertices = positions.length / 3;\r\n for (let i = 0; i < numberOfVertices; i++) {\r\n let posVector = new Vector3(\r\n positions[i * 3],\r\n positions[i * 3 + 1],\r\n positions[i * 3 + 2]\r\n ).addInPlace(this._foldVectorFract[i]);\r\n positions[i * 3] = posVector.x;\r\n positions[i * 3 + 1] = posVector.y;\r\n positions[i * 3 + 2] = posVector.z;\r\n }\r\n }\r\n this.mesh.updateMeshPositions(positionFunction.bind(this), true);\r\n this._foldCounter += 1;\r\n } else {\r\n this._folded = false;\r\n let positionFunction = function (positions: FloatArray) {\r\n let numberOfVertices = positions.length / 3;\r\n for (let i = 0; i < numberOfVertices; i++) {\r\n positions[i * 3] = this._coords[i][0] * this.xScale;\r\n positions[i * 3 + 1] = this._coords[i][2] * this.zScale;\r\n positions[i * 3 + 2] = this._coords[i][1] * this.yScale;\r\n }\r\n }\r\n this.mesh.updateMeshPositions(positionFunction.bind(this), true);\r\n this.mesh.refreshBoundingInfo();\r\n }\r\n }\r\n return this._folded;\r\n }\r\n private _pointPicker(_evt: PointerEvent, pickResult: PickingInfo) {\r\n if (this._pointPicking) {\r\n const faceId = pickResult.faceId;\r\n if (faceId == -1) {\r\n return;\r\n }\r\n const idx = this._SPS.pickedParticles[faceId].idx;\r\n for (let i = 0; i < this._SPS.nbParticles; i++) {\r\n this._SPS.particles[i].color = new Color4(0.3, 0.3, 0.8, 1);\r\n }\r\n let p = this._SPS.particles[idx];\r\n p.color = new Color4(1, 0, 0, 1);\r\n this._SPS.setParticles();\r\n this.selection = [idx];\r\n this._selectionCallback(this.selection);\r\n }\r\n }\r\n updateSize(): void {\r\n for (let i = 0; i < this._SPS.nbParticles; i++) {\r\n this._SPS.particles[i].scale.x = this._size;\r\n this._SPS.particles[i].scale.y = this._size;\r\n this._SPS.particles[i].scale.z = this._size;\r\n }\r\n this._SPS.setParticles();\r\n super.updateSize();\r\n }\r\n}\r\n","import { Vector3, Matrix } from \"../../Maths/math.vector\";\r\nimport { Mesh } from \"../mesh\";\r\nimport { VertexData } from \"../mesh.vertexData\";\r\nVertexData.CreateSphere = function (options) {\r\n var segments = options.segments || 32;\r\n var diameterX = options.diameterX || options.diameter || 1;\r\n var diameterY = options.diameterY || options.diameter || 1;\r\n var diameterZ = options.diameterZ || options.diameter || 1;\r\n var arc = options.arc && (options.arc <= 0 || options.arc > 1) ? 1.0 : options.arc || 1.0;\r\n var slice = options.slice && (options.slice <= 0) ? 1.0 : options.slice || 1.0;\r\n var sideOrientation = (options.sideOrientation === 0) ? 0 : options.sideOrientation || VertexData.DEFAULTSIDE;\r\n var radius = new Vector3(diameterX / 2, diameterY / 2, diameterZ / 2);\r\n var totalZRotationSteps = 2 + segments;\r\n var totalYRotationSteps = 2 * totalZRotationSteps;\r\n var indices = [];\r\n var positions = [];\r\n var normals = [];\r\n var uvs = [];\r\n for (var zRotationStep = 0; zRotationStep <= totalZRotationSteps; zRotationStep++) {\r\n var normalizedZ = zRotationStep / totalZRotationSteps;\r\n var angleZ = normalizedZ * Math.PI * slice;\r\n for (var yRotationStep = 0; yRotationStep <= totalYRotationSteps; yRotationStep++) {\r\n var normalizedY = yRotationStep / totalYRotationSteps;\r\n var angleY = normalizedY * Math.PI * 2 * arc;\r\n var rotationZ = Matrix.RotationZ(-angleZ);\r\n var rotationY = Matrix.RotationY(angleY);\r\n var afterRotZ = Vector3.TransformCoordinates(Vector3.Up(), rotationZ);\r\n var complete = Vector3.TransformCoordinates(afterRotZ, rotationY);\r\n var vertex = complete.multiply(radius);\r\n var normal = complete.divide(radius).normalize();\r\n positions.push(vertex.x, vertex.y, vertex.z);\r\n normals.push(normal.x, normal.y, normal.z);\r\n uvs.push(normalizedY, normalizedZ);\r\n }\r\n if (zRotationStep > 0) {\r\n var verticesCount = positions.length / 3;\r\n for (var firstIndex = verticesCount - 2 * (totalYRotationSteps + 1); (firstIndex + totalYRotationSteps + 2) < verticesCount; firstIndex++) {\r\n indices.push((firstIndex));\r\n indices.push((firstIndex + 1));\r\n indices.push(firstIndex + totalYRotationSteps + 1);\r\n indices.push((firstIndex + totalYRotationSteps + 1));\r\n indices.push((firstIndex + 1));\r\n indices.push((firstIndex + totalYRotationSteps + 2));\r\n }\r\n }\r\n }\r\n // Sides\r\n VertexData._ComputeSides(sideOrientation, positions, indices, normals, uvs, options.frontUVs, options.backUVs);\r\n // Result\r\n var vertexData = new VertexData();\r\n vertexData.indices = indices;\r\n vertexData.positions = positions;\r\n vertexData.normals = normals;\r\n vertexData.uvs = uvs;\r\n return vertexData;\r\n};\r\nMesh.CreateSphere = function (name, segments, diameter, scene, updatable, sideOrientation) {\r\n var options = {\r\n segments: segments,\r\n diameterX: diameter,\r\n diameterY: diameter,\r\n diameterZ: diameter,\r\n sideOrientation: sideOrientation,\r\n updatable: updatable\r\n };\r\n return SphereBuilder.CreateSphere(name, options, scene);\r\n};\r\n/**\r\n * Class containing static functions to help procedurally build meshes\r\n */\r\nvar SphereBuilder = /** @class */ (function () {\r\n function SphereBuilder() {\r\n }\r\n /**\r\n * Creates a sphere mesh\r\n * * The parameter `diameter` sets the diameter size (float) of the sphere (default 1)\r\n * * You can set some different sphere dimensions, for instance to build an ellipsoid, by using the parameters `diameterX`, `diameterY` and `diameterZ` (all by default have the same value of `diameter`)\r\n * * The parameter `segments` sets the sphere number of horizontal stripes (positive integer, default 32)\r\n * * You can create an unclosed sphere with the parameter `arc` (positive float, default 1), valued between 0 and 1, what is the ratio of the circumference (latitude) : 2 x PI x ratio\r\n * * You can create an unclosed sphere on its height with the parameter `slice` (positive float, default1), valued between 0 and 1, what is the height ratio (longitude)\r\n * * You can also set the mesh side orientation with the values : BABYLON.Mesh.FRONTSIDE (default), BABYLON.Mesh.BACKSIDE or BABYLON.Mesh.DOUBLESIDE\r\n * * If you create a double-sided mesh, you can choose what parts of the texture image to crop and stick respectively on the front and the back sides with the parameters `frontUVs` and `backUVs` (Vector4). Detail here : https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @param name defines the name of the mesh\r\n * @param options defines the options used to create the mesh\r\n * @param scene defines the hosting scene\r\n * @returns the sphere mesh\r\n * @see https://doc.babylonjs.com/how_to/set_shapes#sphere\r\n */\r\n SphereBuilder.CreateSphere = function (name, options, scene) {\r\n if (scene === void 0) { scene = null; }\r\n var sphere = new Mesh(name, scene);\r\n options.sideOrientation = Mesh._GetDefaultSideOrientation(options.sideOrientation);\r\n sphere._originalBuilderSideOrientation = options.sideOrientation;\r\n var vertexData = VertexData.CreateSphere(options);\r\n vertexData.applyToMesh(sphere, options.updatable);\r\n return sphere;\r\n };\r\n return SphereBuilder;\r\n}());\r\nexport { SphereBuilder };\r\n//# sourceMappingURL=sphereBuilder.js.map","/**\r\n * Babyplots - Easy, fast, interactive 3D visualizations\r\n *\r\n * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved.\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n * \r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n * \r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n * \r\n */\r\n\r\nimport { Scene } from \"@babylonjs/core/scene\";\r\nimport { Mesh } from \"@babylonjs/core/Meshes/mesh\";\r\nimport { VertexData } from \"@babylonjs/core/Meshes/mesh.vertexData\";\r\nimport { StandardMaterial } from \"@babylonjs/core/Materials/standardMaterial\";\r\nimport { Plot, LegendData, matrixMax } from \"./babyplots\";\r\nimport chroma from \"chroma-js\";\r\n\r\n\r\nexport class Surface extends Plot {\r\n constructor(\r\n scene: Scene,\r\n coordinates: number[][],\r\n colorVar: string[],\r\n size: number,\r\n legendData: LegendData,\r\n xScale: number = 1,\r\n yScale: number = 1,\r\n zScale: number = 1\r\n ) {\r\n super(scene, coordinates, colorVar, size, legendData, xScale, yScale, zScale);\r\n this._createSurface();\r\n }\r\n private _createSurface(): void {\r\n var surface = new Mesh(\"surface\", this._scene);\r\n var positions = [];\r\n var indices = [];\r\n for (let row = 0; row < this._coords.length; row++) {\r\n const rowCoords = this._coords[row];\r\n for (let column = 0; column < rowCoords.length; column++) {\r\n const coord = rowCoords[column];\r\n positions.push(\r\n column * this.xScale,\r\n coord * this.yScale,\r\n row * this.zScale\r\n );\r\n if (row < this._coords.length - 1 && column < rowCoords.length - 1) {\r\n indices.push(\r\n column + row * rowCoords.length,\r\n rowCoords.length + row * rowCoords.length + column,\r\n column + row * rowCoords.length + 1,\r\n column + row * rowCoords.length + 1,\r\n rowCoords.length + row * rowCoords.length + column,\r\n rowCoords.length + row * rowCoords.length + column + 1\r\n );\r\n }\r\n }\r\n }\r\n var colors = [];\r\n for (let i = 0; i < this._coordColors.length; i++) {\r\n const hex = this._coordColors[i];\r\n let rgba = chroma(hex).rgba();\r\n colors.push(rgba[0] / 255, rgba[1] / 255, rgba[2] / 255, rgba[3]);\r\n }\r\n var normals = [];\r\n var vertexData = new VertexData();\r\n VertexData.ComputeNormals(positions, indices, normals);\r\n vertexData.positions = positions;\r\n vertexData.indices = indices;\r\n vertexData.colors = colors;\r\n vertexData.normals = normals;\r\n vertexData.applyToMesh(surface);\r\n var mat = new StandardMaterial(\"surfaceMat\", this._scene);\r\n mat.backFaceCulling = false;\r\n mat.alpha = 1;\r\n surface.material = mat;\r\n this.mesh = surface;\r\n Object.defineProperty(this, \"alpha\", {\r\n set(newAlpha) {\r\n this.mesh.material.alpha = newAlpha;\r\n }\r\n });\r\n }\r\n}\r\n","/**\r\n * Babyplots - Easy, fast, interactive 3D visualizations\r\n *\r\n * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved.\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n * \r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n * \r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n * \r\n */\r\n\r\nimport { Scene } from \"@babylonjs/core/scene\";\r\nimport { Mesh } from \"@babylonjs/core/Meshes/mesh\";\r\nimport { Color3, Vector3 } from \"@babylonjs/core/Maths/math\";\r\nimport { BoxBuilder } from \"@babylonjs/core/Meshes/Builders/boxBuilder\";\r\nimport { PlaneBuilder } from \"@babylonjs/core/Meshes/Builders/planeBuilder\";\r\nimport { StandardMaterial } from \"@babylonjs/core/Materials/standardMaterial\";\r\nimport { Plot, LegendData, matrixMax } from \"./babyplots\";\r\n\r\nexport class HeatMap extends Plot {\r\n constructor(\r\n scene: Scene,\r\n coordinates: number[][],\r\n colorVar: string[],\r\n size: number,\r\n legendData: LegendData,\r\n xScale: number = 1,\r\n yScale: number = 1,\r\n zScale: number = 1\r\n ) {\r\n super(scene, coordinates, colorVar, size, legendData, xScale, yScale, zScale);\r\n this._createHeatMap();\r\n }\r\n private _createHeatMap(): void {\r\n let boxes = [];\r\n for (let row = 0; row < this._coords.length; row++) {\r\n const rowCoords = this._coords[row];\r\n for (let column = 0; column < rowCoords.length; column++) {\r\n const coord = rowCoords[column];\r\n if (coord > 0) {\r\n let height = coord * this.yScale;\r\n let box = BoxBuilder.CreateBox(\"box_\" + row + \"-\" + column, {\r\n height: height,\r\n width: this.xScale * this._size,\r\n depth: this.zScale * this._size\r\n }, this._scene);\r\n box.position = new Vector3(\r\n row * this.xScale + 0.5 * this.xScale,\r\n height / 2,\r\n column * this.zScale + 0.5 * this.zScale\r\n );\r\n let mat = new StandardMaterial(\"box_\" + row + \"-\" + column + \"_color\", this._scene);\r\n mat.alpha = 1;\r\n mat.diffuseColor = Color3.FromHexString(\r\n this._coordColors[column + row * rowCoords.length].substring(0, 7)\r\n );\r\n box.material = mat;\r\n boxes.push(box);\r\n }\r\n else {\r\n let box = PlaneBuilder.CreatePlane(\r\n \"box_\" + row + \"-\" + column,\r\n {\r\n width: this.xScale * this._size,\r\n height: this.zScale * this._size\r\n }, this._scene);\r\n box.position = new Vector3(\r\n row * this.xScale + 0.5 * this.xScale,\r\n 0,\r\n column * this.zScale + 0.5 * this.zScale\r\n );\r\n box.rotation.x = Math.PI / 2;\r\n let mat = new StandardMaterial(\"box_\" + row + \"-\" + column + \"_color\", this._scene);\r\n mat.alpha = 1;\r\n mat.diffuseColor = Color3.FromHexString(\r\n this._coordColors[column + row * rowCoords.length].substring(0, 7)\r\n );\r\n mat.backFaceCulling = false;\r\n box.material = mat;\r\n boxes.push(box);\r\n }\r\n }\r\n }\r\n this.meshes = boxes;\r\n Object.defineProperty(this, \"alpha\", {\r\n set(newAlpha) {\r\n for (let i = 0; i < this.meshes.length; i++) {\r\n const box = this.meshes[i] as Mesh;\r\n box.material.alpha = newAlpha;\r\n }\r\n }\r\n });\r\n }\r\n}\r\n","/**\r\n * Enum for the animation key frame interpolation type\r\n */\r\nexport var AnimationKeyInterpolation;\r\n(function (AnimationKeyInterpolation) {\r\n /**\r\n * Do not interpolate between keys and use the start key value only. Tangents are ignored\r\n */\r\n AnimationKeyInterpolation[AnimationKeyInterpolation[\"STEP\"] = 1] = \"STEP\";\r\n})(AnimationKeyInterpolation || (AnimationKeyInterpolation = {}));\r\n//# sourceMappingURL=animationKey.js.map","import { PointerEventTypes } from \"../../Events/pointerEvents\";\r\nimport { PrecisionDate } from \"../../Misc/precisionDate\";\r\n/**\r\n * The autoRotation behavior (AutoRotationBehavior) is designed to create a smooth rotation of an ArcRotateCamera when there is no user interaction.\r\n * @see http://doc.babylonjs.com/how_to/camera_behaviors#autorotation-behavior\r\n */\r\nvar AutoRotationBehavior = /** @class */ (function () {\r\n function AutoRotationBehavior() {\r\n this._zoomStopsAnimation = false;\r\n this._idleRotationSpeed = 0.05;\r\n this._idleRotationWaitTime = 2000;\r\n this._idleRotationSpinupTime = 2000;\r\n this._isPointerDown = false;\r\n this._lastFrameTime = null;\r\n this._lastInteractionTime = -Infinity;\r\n this._cameraRotationSpeed = 0;\r\n this._lastFrameRadius = 0;\r\n }\r\n Object.defineProperty(AutoRotationBehavior.prototype, \"name\", {\r\n /**\r\n * Gets the name of the behavior.\r\n */\r\n get: function () {\r\n return \"AutoRotation\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AutoRotationBehavior.prototype, \"zoomStopsAnimation\", {\r\n /**\r\n * Gets the flag that indicates if user zooming should stop animation.\r\n */\r\n get: function () {\r\n return this._zoomStopsAnimation;\r\n },\r\n /**\r\n * Sets the flag that indicates if user zooming should stop animation.\r\n */\r\n set: function (flag) {\r\n this._zoomStopsAnimation = flag;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AutoRotationBehavior.prototype, \"idleRotationSpeed\", {\r\n /**\r\n * Gets the default speed at which the camera rotates around the model.\r\n */\r\n get: function () {\r\n return this._idleRotationSpeed;\r\n },\r\n /**\r\n * Sets the default speed at which the camera rotates around the model.\r\n */\r\n set: function (speed) {\r\n this._idleRotationSpeed = speed;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AutoRotationBehavior.prototype, \"idleRotationWaitTime\", {\r\n /**\r\n * Gets the time (milliseconds) to wait after user interaction before the camera starts rotating.\r\n */\r\n get: function () {\r\n return this._idleRotationWaitTime;\r\n },\r\n /**\r\n * Sets the time (in milliseconds) to wait after user interaction before the camera starts rotating.\r\n */\r\n set: function (time) {\r\n this._idleRotationWaitTime = time;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AutoRotationBehavior.prototype, \"idleRotationSpinupTime\", {\r\n /**\r\n * Gets the time (milliseconds) to take to spin up to the full idle rotation speed.\r\n */\r\n get: function () {\r\n return this._idleRotationSpinupTime;\r\n },\r\n /**\r\n * Sets the time (milliseconds) to take to spin up to the full idle rotation speed.\r\n */\r\n set: function (time) {\r\n this._idleRotationSpinupTime = time;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(AutoRotationBehavior.prototype, \"rotationInProgress\", {\r\n /**\r\n * Gets a value indicating if the camera is currently rotating because of this behavior\r\n */\r\n get: function () {\r\n return Math.abs(this._cameraRotationSpeed) > 0;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Initializes the behavior.\r\n */\r\n AutoRotationBehavior.prototype.init = function () {\r\n // Do notihng\r\n };\r\n /**\r\n * Attaches the behavior to its arc rotate camera.\r\n * @param camera Defines the camera to attach the behavior to\r\n */\r\n AutoRotationBehavior.prototype.attach = function (camera) {\r\n var _this = this;\r\n this._attachedCamera = camera;\r\n var scene = this._attachedCamera.getScene();\r\n this._onPrePointerObservableObserver = scene.onPrePointerObservable.add(function (pointerInfoPre) {\r\n if (pointerInfoPre.type === PointerEventTypes.POINTERDOWN) {\r\n _this._isPointerDown = true;\r\n return;\r\n }\r\n if (pointerInfoPre.type === PointerEventTypes.POINTERUP) {\r\n _this._isPointerDown = false;\r\n }\r\n });\r\n this._onAfterCheckInputsObserver = camera.onAfterCheckInputsObservable.add(function () {\r\n var now = PrecisionDate.Now;\r\n var dt = 0;\r\n if (_this._lastFrameTime != null) {\r\n dt = now - _this._lastFrameTime;\r\n }\r\n _this._lastFrameTime = now;\r\n // Stop the animation if there is user interaction and the animation should stop for this interaction\r\n _this._applyUserInteraction();\r\n var timeToRotation = now - _this._lastInteractionTime - _this._idleRotationWaitTime;\r\n var scale = Math.max(Math.min(timeToRotation / (_this._idleRotationSpinupTime), 1), 0);\r\n _this._cameraRotationSpeed = _this._idleRotationSpeed * scale;\r\n // Step camera rotation by rotation speed\r\n if (_this._attachedCamera) {\r\n _this._attachedCamera.alpha -= _this._cameraRotationSpeed * (dt / 1000);\r\n }\r\n });\r\n };\r\n /**\r\n * Detaches the behavior from its current arc rotate camera.\r\n */\r\n AutoRotationBehavior.prototype.detach = function () {\r\n if (!this._attachedCamera) {\r\n return;\r\n }\r\n var scene = this._attachedCamera.getScene();\r\n if (this._onPrePointerObservableObserver) {\r\n scene.onPrePointerObservable.remove(this._onPrePointerObservableObserver);\r\n }\r\n this._attachedCamera.onAfterCheckInputsObservable.remove(this._onAfterCheckInputsObserver);\r\n this._attachedCamera = null;\r\n };\r\n /**\r\n * Returns true if user is scrolling.\r\n * @return true if user is scrolling.\r\n */\r\n AutoRotationBehavior.prototype._userIsZooming = function () {\r\n if (!this._attachedCamera) {\r\n return false;\r\n }\r\n return this._attachedCamera.inertialRadiusOffset !== 0;\r\n };\r\n AutoRotationBehavior.prototype._shouldAnimationStopForInteraction = function () {\r\n if (!this._attachedCamera) {\r\n return false;\r\n }\r\n var zoomHasHitLimit = false;\r\n if (this._lastFrameRadius === this._attachedCamera.radius && this._attachedCamera.inertialRadiusOffset !== 0) {\r\n zoomHasHitLimit = true;\r\n }\r\n // Update the record of previous radius - works as an approx. indicator of hitting radius limits\r\n this._lastFrameRadius = this._attachedCamera.radius;\r\n return this._zoomStopsAnimation ? zoomHasHitLimit : this._userIsZooming();\r\n };\r\n /**\r\n * Applies any current user interaction to the camera. Takes into account maximum alpha rotation.\r\n */\r\n AutoRotationBehavior.prototype._applyUserInteraction = function () {\r\n if (this._userIsMoving() && !this._shouldAnimationStopForInteraction()) {\r\n this._lastInteractionTime = PrecisionDate.Now;\r\n }\r\n };\r\n // Tools\r\n AutoRotationBehavior.prototype._userIsMoving = function () {\r\n if (!this._attachedCamera) {\r\n return false;\r\n }\r\n return this._attachedCamera.inertialAlphaOffset !== 0 ||\r\n this._attachedCamera.inertialBetaOffset !== 0 ||\r\n this._attachedCamera.inertialRadiusOffset !== 0 ||\r\n this._attachedCamera.inertialPanningX !== 0 ||\r\n this._attachedCamera.inertialPanningY !== 0 ||\r\n this._isPointerDown;\r\n };\r\n return AutoRotationBehavior;\r\n}());\r\nexport { AutoRotationBehavior };\r\n//# sourceMappingURL=autoRotationBehavior.js.map","import { __extends } from \"tslib\";\r\nimport { BezierCurve } from \"../Maths/math.path\";\r\n/**\r\n * Base class used for every default easing function.\r\n * @see http://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar EasingFunction = /** @class */ (function () {\r\n function EasingFunction() {\r\n this._easingMode = EasingFunction.EASINGMODE_EASEIN;\r\n }\r\n /**\r\n * Sets the easing mode of the current function.\r\n * @param easingMode Defines the willing mode (EASINGMODE_EASEIN, EASINGMODE_EASEOUT or EASINGMODE_EASEINOUT)\r\n */\r\n EasingFunction.prototype.setEasingMode = function (easingMode) {\r\n var n = Math.min(Math.max(easingMode, 0), 2);\r\n this._easingMode = n;\r\n };\r\n /**\r\n * Gets the current easing mode.\r\n * @returns the easing mode\r\n */\r\n EasingFunction.prototype.getEasingMode = function () {\r\n return this._easingMode;\r\n };\r\n /**\r\n * @hidden\r\n */\r\n EasingFunction.prototype.easeInCore = function (gradient) {\r\n throw new Error('You must implement this method');\r\n };\r\n /**\r\n * Given an input gradient between 0 and 1, this returns the corresponding value\r\n * of the easing function.\r\n * @param gradient Defines the value between 0 and 1 we want the easing value for\r\n * @returns the corresponding value on the curve defined by the easing function\r\n */\r\n EasingFunction.prototype.ease = function (gradient) {\r\n switch (this._easingMode) {\r\n case EasingFunction.EASINGMODE_EASEIN:\r\n return this.easeInCore(gradient);\r\n case EasingFunction.EASINGMODE_EASEOUT:\r\n return (1 - this.easeInCore(1 - gradient));\r\n }\r\n if (gradient >= 0.5) {\r\n return (((1 - this.easeInCore((1 - gradient) * 2)) * 0.5) + 0.5);\r\n }\r\n return (this.easeInCore(gradient * 2) * 0.5);\r\n };\r\n /**\r\n * Interpolation follows the mathematical formula associated with the easing function.\r\n */\r\n EasingFunction.EASINGMODE_EASEIN = 0;\r\n /**\r\n * Interpolation follows 100% interpolation minus the output of the formula associated with the easing function.\r\n */\r\n EasingFunction.EASINGMODE_EASEOUT = 1;\r\n /**\r\n * Interpolation uses EaseIn for the first half of the animation and EaseOut for the second half.\r\n */\r\n EasingFunction.EASINGMODE_EASEINOUT = 2;\r\n return EasingFunction;\r\n}());\r\nexport { EasingFunction };\r\n/**\r\n * Easing function with a circle shape (see link below).\r\n * @see https://easings.net/#easeInCirc\r\n * @see http://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar CircleEase = /** @class */ (function (_super) {\r\n __extends(CircleEase, _super);\r\n function CircleEase() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n /** @hidden */\r\n CircleEase.prototype.easeInCore = function (gradient) {\r\n gradient = Math.max(0, Math.min(1, gradient));\r\n return (1.0 - Math.sqrt(1.0 - (gradient * gradient)));\r\n };\r\n return CircleEase;\r\n}(EasingFunction));\r\nexport { CircleEase };\r\n/**\r\n * Easing function with a ease back shape (see link below).\r\n * @see https://easings.net/#easeInBack\r\n * @see http://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar BackEase = /** @class */ (function (_super) {\r\n __extends(BackEase, _super);\r\n /**\r\n * Instantiates a back ease easing\r\n * @see https://easings.net/#easeInBack\r\n * @param amplitude Defines the amplitude of the function\r\n */\r\n function BackEase(\r\n /** Defines the amplitude of the function */\r\n amplitude) {\r\n if (amplitude === void 0) { amplitude = 1; }\r\n var _this = _super.call(this) || this;\r\n _this.amplitude = amplitude;\r\n return _this;\r\n }\r\n /** @hidden */\r\n BackEase.prototype.easeInCore = function (gradient) {\r\n var num = Math.max(0, this.amplitude);\r\n return (Math.pow(gradient, 3.0) - ((gradient * num) * Math.sin(3.1415926535897931 * gradient)));\r\n };\r\n return BackEase;\r\n}(EasingFunction));\r\nexport { BackEase };\r\n/**\r\n * Easing function with a bouncing shape (see link below).\r\n * @see https://easings.net/#easeInBounce\r\n * @see http://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar BounceEase = /** @class */ (function (_super) {\r\n __extends(BounceEase, _super);\r\n /**\r\n * Instantiates a bounce easing\r\n * @see https://easings.net/#easeInBounce\r\n * @param bounces Defines the number of bounces\r\n * @param bounciness Defines the amplitude of the bounce\r\n */\r\n function BounceEase(\r\n /** Defines the number of bounces */\r\n bounces, \r\n /** Defines the amplitude of the bounce */\r\n bounciness) {\r\n if (bounces === void 0) { bounces = 3; }\r\n if (bounciness === void 0) { bounciness = 2; }\r\n var _this = _super.call(this) || this;\r\n _this.bounces = bounces;\r\n _this.bounciness = bounciness;\r\n return _this;\r\n }\r\n /** @hidden */\r\n BounceEase.prototype.easeInCore = function (gradient) {\r\n var y = Math.max(0.0, this.bounces);\r\n var bounciness = this.bounciness;\r\n if (bounciness <= 1.0) {\r\n bounciness = 1.001;\r\n }\r\n var num9 = Math.pow(bounciness, y);\r\n var num5 = 1.0 - bounciness;\r\n var num4 = ((1.0 - num9) / num5) + (num9 * 0.5);\r\n var num15 = gradient * num4;\r\n var num65 = Math.log((-num15 * (1.0 - bounciness)) + 1.0) / Math.log(bounciness);\r\n var num3 = Math.floor(num65);\r\n var num13 = num3 + 1.0;\r\n var num8 = (1.0 - Math.pow(bounciness, num3)) / (num5 * num4);\r\n var num12 = (1.0 - Math.pow(bounciness, num13)) / (num5 * num4);\r\n var num7 = (num8 + num12) * 0.5;\r\n var num6 = gradient - num7;\r\n var num2 = num7 - num8;\r\n return (((-Math.pow(1.0 / bounciness, y - num3) / (num2 * num2)) * (num6 - num2)) * (num6 + num2));\r\n };\r\n return BounceEase;\r\n}(EasingFunction));\r\nexport { BounceEase };\r\n/**\r\n * Easing function with a power of 3 shape (see link below).\r\n * @see https://easings.net/#easeInCubic\r\n * @see http://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar CubicEase = /** @class */ (function (_super) {\r\n __extends(CubicEase, _super);\r\n function CubicEase() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n /** @hidden */\r\n CubicEase.prototype.easeInCore = function (gradient) {\r\n return (gradient * gradient * gradient);\r\n };\r\n return CubicEase;\r\n}(EasingFunction));\r\nexport { CubicEase };\r\n/**\r\n * Easing function with an elastic shape (see link below).\r\n * @see https://easings.net/#easeInElastic\r\n * @see http://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar ElasticEase = /** @class */ (function (_super) {\r\n __extends(ElasticEase, _super);\r\n /**\r\n * Instantiates an elastic easing function\r\n * @see https://easings.net/#easeInElastic\r\n * @param oscillations Defines the number of oscillations\r\n * @param springiness Defines the amplitude of the oscillations\r\n */\r\n function ElasticEase(\r\n /** Defines the number of oscillations*/\r\n oscillations, \r\n /** Defines the amplitude of the oscillations*/\r\n springiness) {\r\n if (oscillations === void 0) { oscillations = 3; }\r\n if (springiness === void 0) { springiness = 3; }\r\n var _this = _super.call(this) || this;\r\n _this.oscillations = oscillations;\r\n _this.springiness = springiness;\r\n return _this;\r\n }\r\n /** @hidden */\r\n ElasticEase.prototype.easeInCore = function (gradient) {\r\n var num2;\r\n var num3 = Math.max(0.0, this.oscillations);\r\n var num = Math.max(0.0, this.springiness);\r\n if (num == 0) {\r\n num2 = gradient;\r\n }\r\n else {\r\n num2 = (Math.exp(num * gradient) - 1.0) / (Math.exp(num) - 1.0);\r\n }\r\n return (num2 * Math.sin(((6.2831853071795862 * num3) + 1.5707963267948966) * gradient));\r\n };\r\n return ElasticEase;\r\n}(EasingFunction));\r\nexport { ElasticEase };\r\n/**\r\n * Easing function with an exponential shape (see link below).\r\n * @see https://easings.net/#easeInExpo\r\n * @see http://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar ExponentialEase = /** @class */ (function (_super) {\r\n __extends(ExponentialEase, _super);\r\n /**\r\n * Instantiates an exponential easing function\r\n * @see https://easings.net/#easeInExpo\r\n * @param exponent Defines the exponent of the function\r\n */\r\n function ExponentialEase(\r\n /** Defines the exponent of the function */\r\n exponent) {\r\n if (exponent === void 0) { exponent = 2; }\r\n var _this = _super.call(this) || this;\r\n _this.exponent = exponent;\r\n return _this;\r\n }\r\n /** @hidden */\r\n ExponentialEase.prototype.easeInCore = function (gradient) {\r\n if (this.exponent <= 0) {\r\n return gradient;\r\n }\r\n return ((Math.exp(this.exponent * gradient) - 1.0) / (Math.exp(this.exponent) - 1.0));\r\n };\r\n return ExponentialEase;\r\n}(EasingFunction));\r\nexport { ExponentialEase };\r\n/**\r\n * Easing function with a power shape (see link below).\r\n * @see https://easings.net/#easeInQuad\r\n * @see http://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar PowerEase = /** @class */ (function (_super) {\r\n __extends(PowerEase, _super);\r\n /**\r\n * Instantiates an power base easing function\r\n * @see https://easings.net/#easeInQuad\r\n * @param power Defines the power of the function\r\n */\r\n function PowerEase(\r\n /** Defines the power of the function */\r\n power) {\r\n if (power === void 0) { power = 2; }\r\n var _this = _super.call(this) || this;\r\n _this.power = power;\r\n return _this;\r\n }\r\n /** @hidden */\r\n PowerEase.prototype.easeInCore = function (gradient) {\r\n var y = Math.max(0.0, this.power);\r\n return Math.pow(gradient, y);\r\n };\r\n return PowerEase;\r\n}(EasingFunction));\r\nexport { PowerEase };\r\n/**\r\n * Easing function with a power of 2 shape (see link below).\r\n * @see https://easings.net/#easeInQuad\r\n * @see http://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar QuadraticEase = /** @class */ (function (_super) {\r\n __extends(QuadraticEase, _super);\r\n function QuadraticEase() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n /** @hidden */\r\n QuadraticEase.prototype.easeInCore = function (gradient) {\r\n return (gradient * gradient);\r\n };\r\n return QuadraticEase;\r\n}(EasingFunction));\r\nexport { QuadraticEase };\r\n/**\r\n * Easing function with a power of 4 shape (see link below).\r\n * @see https://easings.net/#easeInQuart\r\n * @see http://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar QuarticEase = /** @class */ (function (_super) {\r\n __extends(QuarticEase, _super);\r\n function QuarticEase() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n /** @hidden */\r\n QuarticEase.prototype.easeInCore = function (gradient) {\r\n return (gradient * gradient * gradient * gradient);\r\n };\r\n return QuarticEase;\r\n}(EasingFunction));\r\nexport { QuarticEase };\r\n/**\r\n * Easing function with a power of 5 shape (see link below).\r\n * @see https://easings.net/#easeInQuint\r\n * @see http://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar QuinticEase = /** @class */ (function (_super) {\r\n __extends(QuinticEase, _super);\r\n function QuinticEase() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n /** @hidden */\r\n QuinticEase.prototype.easeInCore = function (gradient) {\r\n return (gradient * gradient * gradient * gradient * gradient);\r\n };\r\n return QuinticEase;\r\n}(EasingFunction));\r\nexport { QuinticEase };\r\n/**\r\n * Easing function with a sin shape (see link below).\r\n * @see https://easings.net/#easeInSine\r\n * @see http://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar SineEase = /** @class */ (function (_super) {\r\n __extends(SineEase, _super);\r\n function SineEase() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n /** @hidden */\r\n SineEase.prototype.easeInCore = function (gradient) {\r\n return (1.0 - Math.sin(1.5707963267948966 * (1.0 - gradient)));\r\n };\r\n return SineEase;\r\n}(EasingFunction));\r\nexport { SineEase };\r\n/**\r\n * Easing function with a bezier shape (see link below).\r\n * @see http://cubic-bezier.com/#.17,.67,.83,.67\r\n * @see http://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar BezierCurveEase = /** @class */ (function (_super) {\r\n __extends(BezierCurveEase, _super);\r\n /**\r\n * Instantiates a bezier function\r\n * @see http://cubic-bezier.com/#.17,.67,.83,.67\r\n * @param x1 Defines the x component of the start tangent in the bezier curve\r\n * @param y1 Defines the y component of the start tangent in the bezier curve\r\n * @param x2 Defines the x component of the end tangent in the bezier curve\r\n * @param y2 Defines the y component of the end tangent in the bezier curve\r\n */\r\n function BezierCurveEase(\r\n /** Defines the x component of the start tangent in the bezier curve */\r\n x1, \r\n /** Defines the y component of the start tangent in the bezier curve */\r\n y1, \r\n /** Defines the x component of the end tangent in the bezier curve */\r\n x2, \r\n /** Defines the y component of the end tangent in the bezier curve */\r\n y2) {\r\n if (x1 === void 0) { x1 = 0; }\r\n if (y1 === void 0) { y1 = 0; }\r\n if (x2 === void 0) { x2 = 1; }\r\n if (y2 === void 0) { y2 = 1; }\r\n var _this = _super.call(this) || this;\r\n _this.x1 = x1;\r\n _this.y1 = y1;\r\n _this.x2 = x2;\r\n _this.y2 = y2;\r\n return _this;\r\n }\r\n /** @hidden */\r\n BezierCurveEase.prototype.easeInCore = function (gradient) {\r\n return BezierCurve.Interpolate(gradient, this.x1, this.y1, this.x2, this.y2);\r\n };\r\n return BezierCurveEase;\r\n}(EasingFunction));\r\nexport { BezierCurveEase };\r\n//# sourceMappingURL=easing.js.map","/**\r\n * Represents the range of an animation\r\n */\r\nvar AnimationRange = /** @class */ (function () {\r\n /**\r\n * Initializes the range of an animation\r\n * @param name The name of the animation range\r\n * @param from The starting frame of the animation\r\n * @param to The ending frame of the animation\r\n */\r\n function AnimationRange(\r\n /**The name of the animation range**/\r\n name, \r\n /**The starting frame of the animation */\r\n from, \r\n /**The ending frame of the animation*/\r\n to) {\r\n this.name = name;\r\n this.from = from;\r\n this.to = to;\r\n }\r\n /**\r\n * Makes a copy of the animation range\r\n * @returns A copy of the animation range\r\n */\r\n AnimationRange.prototype.clone = function () {\r\n return new AnimationRange(this.name, this.from, this.to);\r\n };\r\n return AnimationRange;\r\n}());\r\nexport { AnimationRange };\r\n//# sourceMappingURL=animationRange.js.map","import { Vector3, Quaternion, Vector2, Matrix } from \"../Maths/math.vector\";\r\nimport { Color3, Color4 } from '../Maths/math.color';\r\nimport { Scalar } from \"../Maths/math.scalar\";\r\nimport { SerializationHelper } from \"../Misc/decorators\";\r\nimport { _TypeStore } from '../Misc/typeStore';\r\nimport { AnimationKeyInterpolation } from './animationKey';\r\nimport { AnimationRange } from './animationRange';\r\nimport { Node } from \"../node\";\r\nimport { Size } from '../Maths/math.size';\r\n/**\r\n * @hidden\r\n */\r\nvar _IAnimationState = /** @class */ (function () {\r\n function _IAnimationState() {\r\n }\r\n return _IAnimationState;\r\n}());\r\nexport { _IAnimationState };\r\n/**\r\n * Class used to store any kind of animation\r\n */\r\nvar Animation = /** @class */ (function () {\r\n /**\r\n * Initializes the animation\r\n * @param name Name of the animation\r\n * @param targetProperty Property to animate\r\n * @param framePerSecond The frames per second of the animation\r\n * @param dataType The data type of the animation\r\n * @param loopMode The loop mode of the animation\r\n * @param enableBlending Specifies if blending should be enabled\r\n */\r\n function Animation(\r\n /**Name of the animation */\r\n name, \r\n /**Property to animate */\r\n targetProperty, \r\n /**The frames per second of the animation */\r\n framePerSecond, \r\n /**The data type of the animation */\r\n dataType, \r\n /**The loop mode of the animation */\r\n loopMode, \r\n /**Specifies if blending should be enabled */\r\n enableBlending) {\r\n this.name = name;\r\n this.targetProperty = targetProperty;\r\n this.framePerSecond = framePerSecond;\r\n this.dataType = dataType;\r\n this.loopMode = loopMode;\r\n this.enableBlending = enableBlending;\r\n /**\r\n * @hidden Internal use only\r\n */\r\n this._runtimeAnimations = new Array();\r\n /**\r\n * The set of event that will be linked to this animation\r\n */\r\n this._events = new Array();\r\n /**\r\n * Stores the blending speed of the animation\r\n */\r\n this.blendingSpeed = 0.01;\r\n /**\r\n * Stores the animation ranges for the animation\r\n */\r\n this._ranges = {};\r\n this.targetPropertyPath = targetProperty.split(\".\");\r\n this.dataType = dataType;\r\n this.loopMode = loopMode === undefined ? Animation.ANIMATIONLOOPMODE_CYCLE : loopMode;\r\n }\r\n /**\r\n * @hidden Internal use\r\n */\r\n Animation._PrepareAnimation = function (name, targetProperty, framePerSecond, totalFrame, from, to, loopMode, easingFunction) {\r\n var dataType = undefined;\r\n if (!isNaN(parseFloat(from)) && isFinite(from)) {\r\n dataType = Animation.ANIMATIONTYPE_FLOAT;\r\n }\r\n else if (from instanceof Quaternion) {\r\n dataType = Animation.ANIMATIONTYPE_QUATERNION;\r\n }\r\n else if (from instanceof Vector3) {\r\n dataType = Animation.ANIMATIONTYPE_VECTOR3;\r\n }\r\n else if (from instanceof Vector2) {\r\n dataType = Animation.ANIMATIONTYPE_VECTOR2;\r\n }\r\n else if (from instanceof Color3) {\r\n dataType = Animation.ANIMATIONTYPE_COLOR3;\r\n }\r\n else if (from instanceof Color4) {\r\n dataType = Animation.ANIMATIONTYPE_COLOR4;\r\n }\r\n else if (from instanceof Size) {\r\n dataType = Animation.ANIMATIONTYPE_SIZE;\r\n }\r\n if (dataType == undefined) {\r\n return null;\r\n }\r\n var animation = new Animation(name, targetProperty, framePerSecond, dataType, loopMode);\r\n var keys = [{ frame: 0, value: from }, { frame: totalFrame, value: to }];\r\n animation.setKeys(keys);\r\n if (easingFunction !== undefined) {\r\n animation.setEasingFunction(easingFunction);\r\n }\r\n return animation;\r\n };\r\n /**\r\n * Sets up an animation\r\n * @param property The property to animate\r\n * @param animationType The animation type to apply\r\n * @param framePerSecond The frames per second of the animation\r\n * @param easingFunction The easing function used in the animation\r\n * @returns The created animation\r\n */\r\n Animation.CreateAnimation = function (property, animationType, framePerSecond, easingFunction) {\r\n var animation = new Animation(property + \"Animation\", property, framePerSecond, animationType, Animation.ANIMATIONLOOPMODE_CONSTANT);\r\n animation.setEasingFunction(easingFunction);\r\n return animation;\r\n };\r\n /**\r\n * Create and start an animation on a node\r\n * @param name defines the name of the global animation that will be run on all nodes\r\n * @param node defines the root node where the animation will take place\r\n * @param targetProperty defines property to animate\r\n * @param framePerSecond defines the number of frame per second yo use\r\n * @param totalFrame defines the number of frames in total\r\n * @param from defines the initial value\r\n * @param to defines the final value\r\n * @param loopMode defines which loop mode you want to use (off by default)\r\n * @param easingFunction defines the easing function to use (linear by default)\r\n * @param onAnimationEnd defines the callback to call when animation end\r\n * @returns the animatable created for this animation\r\n */\r\n Animation.CreateAndStartAnimation = function (name, node, targetProperty, framePerSecond, totalFrame, from, to, loopMode, easingFunction, onAnimationEnd) {\r\n var animation = Animation._PrepareAnimation(name, targetProperty, framePerSecond, totalFrame, from, to, loopMode, easingFunction);\r\n if (!animation) {\r\n return null;\r\n }\r\n return node.getScene().beginDirectAnimation(node, [animation], 0, totalFrame, (animation.loopMode === 1), 1.0, onAnimationEnd);\r\n };\r\n /**\r\n * Create and start an animation on a node and its descendants\r\n * @param name defines the name of the global animation that will be run on all nodes\r\n * @param node defines the root node where the animation will take place\r\n * @param directDescendantsOnly if true only direct descendants will be used, if false direct and also indirect (children of children, an so on in a recursive manner) descendants will be used\r\n * @param targetProperty defines property to animate\r\n * @param framePerSecond defines the number of frame per second to use\r\n * @param totalFrame defines the number of frames in total\r\n * @param from defines the initial value\r\n * @param to defines the final value\r\n * @param loopMode defines which loop mode you want to use (off by default)\r\n * @param easingFunction defines the easing function to use (linear by default)\r\n * @param onAnimationEnd defines the callback to call when an animation ends (will be called once per node)\r\n * @returns the list of animatables created for all nodes\r\n * @example https://www.babylonjs-playground.com/#MH0VLI\r\n */\r\n Animation.CreateAndStartHierarchyAnimation = function (name, node, directDescendantsOnly, targetProperty, framePerSecond, totalFrame, from, to, loopMode, easingFunction, onAnimationEnd) {\r\n var animation = Animation._PrepareAnimation(name, targetProperty, framePerSecond, totalFrame, from, to, loopMode, easingFunction);\r\n if (!animation) {\r\n return null;\r\n }\r\n var scene = node.getScene();\r\n return scene.beginDirectHierarchyAnimation(node, directDescendantsOnly, [animation], 0, totalFrame, (animation.loopMode === 1), 1.0, onAnimationEnd);\r\n };\r\n /**\r\n * Creates a new animation, merges it with the existing animations and starts it\r\n * @param name Name of the animation\r\n * @param node Node which contains the scene that begins the animations\r\n * @param targetProperty Specifies which property to animate\r\n * @param framePerSecond The frames per second of the animation\r\n * @param totalFrame The total number of frames\r\n * @param from The frame at the beginning of the animation\r\n * @param to The frame at the end of the animation\r\n * @param loopMode Specifies the loop mode of the animation\r\n * @param easingFunction (Optional) The easing function of the animation, which allow custom mathematical formulas for animations\r\n * @param onAnimationEnd Callback to run once the animation is complete\r\n * @returns Nullable animation\r\n */\r\n Animation.CreateMergeAndStartAnimation = function (name, node, targetProperty, framePerSecond, totalFrame, from, to, loopMode, easingFunction, onAnimationEnd) {\r\n var animation = Animation._PrepareAnimation(name, targetProperty, framePerSecond, totalFrame, from, to, loopMode, easingFunction);\r\n if (!animation) {\r\n return null;\r\n }\r\n node.animations.push(animation);\r\n return node.getScene().beginAnimation(node, 0, totalFrame, (animation.loopMode === 1), 1.0, onAnimationEnd);\r\n };\r\n /**\r\n * Transition property of an host to the target Value\r\n * @param property The property to transition\r\n * @param targetValue The target Value of the property\r\n * @param host The object where the property to animate belongs\r\n * @param scene Scene used to run the animation\r\n * @param frameRate Framerate (in frame/s) to use\r\n * @param transition The transition type we want to use\r\n * @param duration The duration of the animation, in milliseconds\r\n * @param onAnimationEnd Callback trigger at the end of the animation\r\n * @returns Nullable animation\r\n */\r\n Animation.TransitionTo = function (property, targetValue, host, scene, frameRate, transition, duration, onAnimationEnd) {\r\n if (onAnimationEnd === void 0) { onAnimationEnd = null; }\r\n if (duration <= 0) {\r\n host[property] = targetValue;\r\n if (onAnimationEnd) {\r\n onAnimationEnd();\r\n }\r\n return null;\r\n }\r\n var endFrame = frameRate * (duration / 1000);\r\n transition.setKeys([{\r\n frame: 0,\r\n value: host[property].clone ? host[property].clone() : host[property]\r\n },\r\n {\r\n frame: endFrame,\r\n value: targetValue\r\n }]);\r\n if (!host.animations) {\r\n host.animations = [];\r\n }\r\n host.animations.push(transition);\r\n var animation = scene.beginAnimation(host, 0, endFrame, false);\r\n animation.onAnimationEnd = onAnimationEnd;\r\n return animation;\r\n };\r\n Object.defineProperty(Animation.prototype, \"runtimeAnimations\", {\r\n /**\r\n * Return the array of runtime animations currently using this animation\r\n */\r\n get: function () {\r\n return this._runtimeAnimations;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Animation.prototype, \"hasRunningRuntimeAnimations\", {\r\n /**\r\n * Specifies if any of the runtime animations are currently running\r\n */\r\n get: function () {\r\n for (var _i = 0, _a = this._runtimeAnimations; _i < _a.length; _i++) {\r\n var runtimeAnimation = _a[_i];\r\n if (!runtimeAnimation.isStopped) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n // Methods\r\n /**\r\n * Converts the animation to a string\r\n * @param fullDetails support for multiple levels of logging within scene loading\r\n * @returns String form of the animation\r\n */\r\n Animation.prototype.toString = function (fullDetails) {\r\n var ret = \"Name: \" + this.name + \", property: \" + this.targetProperty;\r\n ret += \", datatype: \" + ([\"Float\", \"Vector3\", \"Quaternion\", \"Matrix\", \"Color3\", \"Vector2\"])[this.dataType];\r\n ret += \", nKeys: \" + (this._keys ? this._keys.length : \"none\");\r\n ret += \", nRanges: \" + (this._ranges ? Object.keys(this._ranges).length : \"none\");\r\n if (fullDetails) {\r\n ret += \", Ranges: {\";\r\n var first = true;\r\n for (var name in this._ranges) {\r\n if (first) {\r\n ret += \", \";\r\n first = false;\r\n }\r\n ret += name;\r\n }\r\n ret += \"}\";\r\n }\r\n return ret;\r\n };\r\n /**\r\n * Add an event to this animation\r\n * @param event Event to add\r\n */\r\n Animation.prototype.addEvent = function (event) {\r\n this._events.push(event);\r\n };\r\n /**\r\n * Remove all events found at the given frame\r\n * @param frame The frame to remove events from\r\n */\r\n Animation.prototype.removeEvents = function (frame) {\r\n for (var index = 0; index < this._events.length; index++) {\r\n if (this._events[index].frame === frame) {\r\n this._events.splice(index, 1);\r\n index--;\r\n }\r\n }\r\n };\r\n /**\r\n * Retrieves all the events from the animation\r\n * @returns Events from the animation\r\n */\r\n Animation.prototype.getEvents = function () {\r\n return this._events;\r\n };\r\n /**\r\n * Creates an animation range\r\n * @param name Name of the animation range\r\n * @param from Starting frame of the animation range\r\n * @param to Ending frame of the animation\r\n */\r\n Animation.prototype.createRange = function (name, from, to) {\r\n // check name not already in use; could happen for bones after serialized\r\n if (!this._ranges[name]) {\r\n this._ranges[name] = new AnimationRange(name, from, to);\r\n }\r\n };\r\n /**\r\n * Deletes an animation range by name\r\n * @param name Name of the animation range to delete\r\n * @param deleteFrames Specifies if the key frames for the range should also be deleted (true) or not (false)\r\n */\r\n Animation.prototype.deleteRange = function (name, deleteFrames) {\r\n if (deleteFrames === void 0) { deleteFrames = true; }\r\n var range = this._ranges[name];\r\n if (!range) {\r\n return;\r\n }\r\n if (deleteFrames) {\r\n var from = range.from;\r\n var to = range.to;\r\n // this loop MUST go high to low for multiple splices to work\r\n for (var key = this._keys.length - 1; key >= 0; key--) {\r\n if (this._keys[key].frame >= from && this._keys[key].frame <= to) {\r\n this._keys.splice(key, 1);\r\n }\r\n }\r\n }\r\n this._ranges[name] = null; // said much faster than 'delete this._range[name]'\r\n };\r\n /**\r\n * Gets the animation range by name, or null if not defined\r\n * @param name Name of the animation range\r\n * @returns Nullable animation range\r\n */\r\n Animation.prototype.getRange = function (name) {\r\n return this._ranges[name];\r\n };\r\n /**\r\n * Gets the key frames from the animation\r\n * @returns The key frames of the animation\r\n */\r\n Animation.prototype.getKeys = function () {\r\n return this._keys;\r\n };\r\n /**\r\n * Gets the highest frame rate of the animation\r\n * @returns Highest frame rate of the animation\r\n */\r\n Animation.prototype.getHighestFrame = function () {\r\n var ret = 0;\r\n for (var key = 0, nKeys = this._keys.length; key < nKeys; key++) {\r\n if (ret < this._keys[key].frame) {\r\n ret = this._keys[key].frame;\r\n }\r\n }\r\n return ret;\r\n };\r\n /**\r\n * Gets the easing function of the animation\r\n * @returns Easing function of the animation\r\n */\r\n Animation.prototype.getEasingFunction = function () {\r\n return this._easingFunction;\r\n };\r\n /**\r\n * Sets the easing function of the animation\r\n * @param easingFunction A custom mathematical formula for animation\r\n */\r\n Animation.prototype.setEasingFunction = function (easingFunction) {\r\n this._easingFunction = easingFunction;\r\n };\r\n /**\r\n * Interpolates a scalar linearly\r\n * @param startValue Start value of the animation curve\r\n * @param endValue End value of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated scalar value\r\n */\r\n Animation.prototype.floatInterpolateFunction = function (startValue, endValue, gradient) {\r\n return Scalar.Lerp(startValue, endValue, gradient);\r\n };\r\n /**\r\n * Interpolates a scalar cubically\r\n * @param startValue Start value of the animation curve\r\n * @param outTangent End tangent of the animation\r\n * @param endValue End value of the animation curve\r\n * @param inTangent Start tangent of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated scalar value\r\n */\r\n Animation.prototype.floatInterpolateFunctionWithTangents = function (startValue, outTangent, endValue, inTangent, gradient) {\r\n return Scalar.Hermite(startValue, outTangent, endValue, inTangent, gradient);\r\n };\r\n /**\r\n * Interpolates a quaternion using a spherical linear interpolation\r\n * @param startValue Start value of the animation curve\r\n * @param endValue End value of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated quaternion value\r\n */\r\n Animation.prototype.quaternionInterpolateFunction = function (startValue, endValue, gradient) {\r\n return Quaternion.Slerp(startValue, endValue, gradient);\r\n };\r\n /**\r\n * Interpolates a quaternion cubically\r\n * @param startValue Start value of the animation curve\r\n * @param outTangent End tangent of the animation curve\r\n * @param endValue End value of the animation curve\r\n * @param inTangent Start tangent of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated quaternion value\r\n */\r\n Animation.prototype.quaternionInterpolateFunctionWithTangents = function (startValue, outTangent, endValue, inTangent, gradient) {\r\n return Quaternion.Hermite(startValue, outTangent, endValue, inTangent, gradient).normalize();\r\n };\r\n /**\r\n * Interpolates a Vector3 linearl\r\n * @param startValue Start value of the animation curve\r\n * @param endValue End value of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated scalar value\r\n */\r\n Animation.prototype.vector3InterpolateFunction = function (startValue, endValue, gradient) {\r\n return Vector3.Lerp(startValue, endValue, gradient);\r\n };\r\n /**\r\n * Interpolates a Vector3 cubically\r\n * @param startValue Start value of the animation curve\r\n * @param outTangent End tangent of the animation\r\n * @param endValue End value of the animation curve\r\n * @param inTangent Start tangent of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns InterpolatedVector3 value\r\n */\r\n Animation.prototype.vector3InterpolateFunctionWithTangents = function (startValue, outTangent, endValue, inTangent, gradient) {\r\n return Vector3.Hermite(startValue, outTangent, endValue, inTangent, gradient);\r\n };\r\n /**\r\n * Interpolates a Vector2 linearly\r\n * @param startValue Start value of the animation curve\r\n * @param endValue End value of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated Vector2 value\r\n */\r\n Animation.prototype.vector2InterpolateFunction = function (startValue, endValue, gradient) {\r\n return Vector2.Lerp(startValue, endValue, gradient);\r\n };\r\n /**\r\n * Interpolates a Vector2 cubically\r\n * @param startValue Start value of the animation curve\r\n * @param outTangent End tangent of the animation\r\n * @param endValue End value of the animation curve\r\n * @param inTangent Start tangent of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated Vector2 value\r\n */\r\n Animation.prototype.vector2InterpolateFunctionWithTangents = function (startValue, outTangent, endValue, inTangent, gradient) {\r\n return Vector2.Hermite(startValue, outTangent, endValue, inTangent, gradient);\r\n };\r\n /**\r\n * Interpolates a size linearly\r\n * @param startValue Start value of the animation curve\r\n * @param endValue End value of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated Size value\r\n */\r\n Animation.prototype.sizeInterpolateFunction = function (startValue, endValue, gradient) {\r\n return Size.Lerp(startValue, endValue, gradient);\r\n };\r\n /**\r\n * Interpolates a Color3 linearly\r\n * @param startValue Start value of the animation curve\r\n * @param endValue End value of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated Color3 value\r\n */\r\n Animation.prototype.color3InterpolateFunction = function (startValue, endValue, gradient) {\r\n return Color3.Lerp(startValue, endValue, gradient);\r\n };\r\n /**\r\n * Interpolates a Color4 linearly\r\n * @param startValue Start value of the animation curve\r\n * @param endValue End value of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated Color3 value\r\n */\r\n Animation.prototype.color4InterpolateFunction = function (startValue, endValue, gradient) {\r\n return Color4.Lerp(startValue, endValue, gradient);\r\n };\r\n /**\r\n * @hidden Internal use only\r\n */\r\n Animation.prototype._getKeyValue = function (value) {\r\n if (typeof value === \"function\") {\r\n return value();\r\n }\r\n return value;\r\n };\r\n /**\r\n * @hidden Internal use only\r\n */\r\n Animation.prototype._interpolate = function (currentFrame, state) {\r\n if (state.loopMode === Animation.ANIMATIONLOOPMODE_CONSTANT && state.repeatCount > 0) {\r\n return state.highLimitValue.clone ? state.highLimitValue.clone() : state.highLimitValue;\r\n }\r\n var keys = this._keys;\r\n if (keys.length === 1) {\r\n return this._getKeyValue(keys[0].value);\r\n }\r\n var startKeyIndex = state.key;\r\n if (keys[startKeyIndex].frame >= currentFrame) {\r\n while (startKeyIndex - 1 >= 0 && keys[startKeyIndex].frame >= currentFrame) {\r\n startKeyIndex--;\r\n }\r\n }\r\n for (var key = startKeyIndex; key < keys.length; key++) {\r\n var endKey = keys[key + 1];\r\n if (endKey.frame >= currentFrame) {\r\n state.key = key;\r\n var startKey = keys[key];\r\n var startValue = this._getKeyValue(startKey.value);\r\n if (startKey.interpolation === AnimationKeyInterpolation.STEP) {\r\n return startValue;\r\n }\r\n var endValue = this._getKeyValue(endKey.value);\r\n var useTangent = startKey.outTangent !== undefined && endKey.inTangent !== undefined;\r\n var frameDelta = endKey.frame - startKey.frame;\r\n // gradient : percent of currentFrame between the frame inf and the frame sup\r\n var gradient = (currentFrame - startKey.frame) / frameDelta;\r\n // check for easingFunction and correction of gradient\r\n var easingFunction = this.getEasingFunction();\r\n if (easingFunction != null) {\r\n gradient = easingFunction.ease(gradient);\r\n }\r\n switch (this.dataType) {\r\n // Float\r\n case Animation.ANIMATIONTYPE_FLOAT:\r\n var floatValue = useTangent ? this.floatInterpolateFunctionWithTangents(startValue, startKey.outTangent * frameDelta, endValue, endKey.inTangent * frameDelta, gradient) : this.floatInterpolateFunction(startValue, endValue, gradient);\r\n switch (state.loopMode) {\r\n case Animation.ANIMATIONLOOPMODE_CYCLE:\r\n case Animation.ANIMATIONLOOPMODE_CONSTANT:\r\n return floatValue;\r\n case Animation.ANIMATIONLOOPMODE_RELATIVE:\r\n return state.offsetValue * state.repeatCount + floatValue;\r\n }\r\n break;\r\n // Quaternion\r\n case Animation.ANIMATIONTYPE_QUATERNION:\r\n var quatValue = useTangent ? this.quaternionInterpolateFunctionWithTangents(startValue, startKey.outTangent.scale(frameDelta), endValue, endKey.inTangent.scale(frameDelta), gradient) : this.quaternionInterpolateFunction(startValue, endValue, gradient);\r\n switch (state.loopMode) {\r\n case Animation.ANIMATIONLOOPMODE_CYCLE:\r\n case Animation.ANIMATIONLOOPMODE_CONSTANT:\r\n return quatValue;\r\n case Animation.ANIMATIONLOOPMODE_RELATIVE:\r\n return quatValue.addInPlace(state.offsetValue.scale(state.repeatCount));\r\n }\r\n return quatValue;\r\n // Vector3\r\n case Animation.ANIMATIONTYPE_VECTOR3:\r\n var vec3Value = useTangent ? this.vector3InterpolateFunctionWithTangents(startValue, startKey.outTangent.scale(frameDelta), endValue, endKey.inTangent.scale(frameDelta), gradient) : this.vector3InterpolateFunction(startValue, endValue, gradient);\r\n switch (state.loopMode) {\r\n case Animation.ANIMATIONLOOPMODE_CYCLE:\r\n case Animation.ANIMATIONLOOPMODE_CONSTANT:\r\n return vec3Value;\r\n case Animation.ANIMATIONLOOPMODE_RELATIVE:\r\n return vec3Value.add(state.offsetValue.scale(state.repeatCount));\r\n }\r\n // Vector2\r\n case Animation.ANIMATIONTYPE_VECTOR2:\r\n var vec2Value = useTangent ? this.vector2InterpolateFunctionWithTangents(startValue, startKey.outTangent.scale(frameDelta), endValue, endKey.inTangent.scale(frameDelta), gradient) : this.vector2InterpolateFunction(startValue, endValue, gradient);\r\n switch (state.loopMode) {\r\n case Animation.ANIMATIONLOOPMODE_CYCLE:\r\n case Animation.ANIMATIONLOOPMODE_CONSTANT:\r\n return vec2Value;\r\n case Animation.ANIMATIONLOOPMODE_RELATIVE:\r\n return vec2Value.add(state.offsetValue.scale(state.repeatCount));\r\n }\r\n // Size\r\n case Animation.ANIMATIONTYPE_SIZE:\r\n switch (state.loopMode) {\r\n case Animation.ANIMATIONLOOPMODE_CYCLE:\r\n case Animation.ANIMATIONLOOPMODE_CONSTANT:\r\n return this.sizeInterpolateFunction(startValue, endValue, gradient);\r\n case Animation.ANIMATIONLOOPMODE_RELATIVE:\r\n return this.sizeInterpolateFunction(startValue, endValue, gradient).add(state.offsetValue.scale(state.repeatCount));\r\n }\r\n // Color3\r\n case Animation.ANIMATIONTYPE_COLOR3:\r\n switch (state.loopMode) {\r\n case Animation.ANIMATIONLOOPMODE_CYCLE:\r\n case Animation.ANIMATIONLOOPMODE_CONSTANT:\r\n return this.color3InterpolateFunction(startValue, endValue, gradient);\r\n case Animation.ANIMATIONLOOPMODE_RELATIVE:\r\n return this.color3InterpolateFunction(startValue, endValue, gradient).add(state.offsetValue.scale(state.repeatCount));\r\n }\r\n // Color4\r\n case Animation.ANIMATIONTYPE_COLOR4:\r\n switch (state.loopMode) {\r\n case Animation.ANIMATIONLOOPMODE_CYCLE:\r\n case Animation.ANIMATIONLOOPMODE_CONSTANT:\r\n return this.color4InterpolateFunction(startValue, endValue, gradient);\r\n case Animation.ANIMATIONLOOPMODE_RELATIVE:\r\n return this.color4InterpolateFunction(startValue, endValue, gradient).add(state.offsetValue.scale(state.repeatCount));\r\n }\r\n // Matrix\r\n case Animation.ANIMATIONTYPE_MATRIX:\r\n switch (state.loopMode) {\r\n case Animation.ANIMATIONLOOPMODE_CYCLE:\r\n case Animation.ANIMATIONLOOPMODE_CONSTANT:\r\n if (Animation.AllowMatricesInterpolation) {\r\n return this.matrixInterpolateFunction(startValue, endValue, gradient, state.workValue);\r\n }\r\n case Animation.ANIMATIONLOOPMODE_RELATIVE:\r\n return startValue;\r\n }\r\n default:\r\n break;\r\n }\r\n break;\r\n }\r\n }\r\n return this._getKeyValue(keys[keys.length - 1].value);\r\n };\r\n /**\r\n * Defines the function to use to interpolate matrices\r\n * @param startValue defines the start matrix\r\n * @param endValue defines the end matrix\r\n * @param gradient defines the gradient between both matrices\r\n * @param result defines an optional target matrix where to store the interpolation\r\n * @returns the interpolated matrix\r\n */\r\n Animation.prototype.matrixInterpolateFunction = function (startValue, endValue, gradient, result) {\r\n if (Animation.AllowMatrixDecomposeForInterpolation) {\r\n if (result) {\r\n Matrix.DecomposeLerpToRef(startValue, endValue, gradient, result);\r\n return result;\r\n }\r\n return Matrix.DecomposeLerp(startValue, endValue, gradient);\r\n }\r\n if (result) {\r\n Matrix.LerpToRef(startValue, endValue, gradient, result);\r\n return result;\r\n }\r\n return Matrix.Lerp(startValue, endValue, gradient);\r\n };\r\n /**\r\n * Makes a copy of the animation\r\n * @returns Cloned animation\r\n */\r\n Animation.prototype.clone = function () {\r\n var clone = new Animation(this.name, this.targetPropertyPath.join(\".\"), this.framePerSecond, this.dataType, this.loopMode);\r\n clone.enableBlending = this.enableBlending;\r\n clone.blendingSpeed = this.blendingSpeed;\r\n if (this._keys) {\r\n clone.setKeys(this._keys);\r\n }\r\n if (this._ranges) {\r\n clone._ranges = {};\r\n for (var name in this._ranges) {\r\n var range = this._ranges[name];\r\n if (!range) {\r\n continue;\r\n }\r\n clone._ranges[name] = range.clone();\r\n }\r\n }\r\n return clone;\r\n };\r\n /**\r\n * Sets the key frames of the animation\r\n * @param values The animation key frames to set\r\n */\r\n Animation.prototype.setKeys = function (values) {\r\n this._keys = values.slice(0);\r\n };\r\n /**\r\n * Serializes the animation to an object\r\n * @returns Serialized object\r\n */\r\n Animation.prototype.serialize = function () {\r\n var serializationObject = {};\r\n serializationObject.name = this.name;\r\n serializationObject.property = this.targetProperty;\r\n serializationObject.framePerSecond = this.framePerSecond;\r\n serializationObject.dataType = this.dataType;\r\n serializationObject.loopBehavior = this.loopMode;\r\n serializationObject.enableBlending = this.enableBlending;\r\n serializationObject.blendingSpeed = this.blendingSpeed;\r\n var dataType = this.dataType;\r\n serializationObject.keys = [];\r\n var keys = this.getKeys();\r\n for (var index = 0; index < keys.length; index++) {\r\n var animationKey = keys[index];\r\n var key = {};\r\n key.frame = animationKey.frame;\r\n switch (dataType) {\r\n case Animation.ANIMATIONTYPE_FLOAT:\r\n key.values = [animationKey.value];\r\n break;\r\n case Animation.ANIMATIONTYPE_QUATERNION:\r\n case Animation.ANIMATIONTYPE_MATRIX:\r\n case Animation.ANIMATIONTYPE_VECTOR3:\r\n case Animation.ANIMATIONTYPE_COLOR3:\r\n case Animation.ANIMATIONTYPE_COLOR4:\r\n key.values = animationKey.value.asArray();\r\n break;\r\n }\r\n serializationObject.keys.push(key);\r\n }\r\n serializationObject.ranges = [];\r\n for (var name in this._ranges) {\r\n var source = this._ranges[name];\r\n if (!source) {\r\n continue;\r\n }\r\n var range = {};\r\n range.name = name;\r\n range.from = source.from;\r\n range.to = source.to;\r\n serializationObject.ranges.push(range);\r\n }\r\n return serializationObject;\r\n };\r\n /** @hidden */\r\n Animation._UniversalLerp = function (left, right, amount) {\r\n var constructor = left.constructor;\r\n if (constructor.Lerp) { // Lerp supported\r\n return constructor.Lerp(left, right, amount);\r\n }\r\n else if (constructor.Slerp) { // Slerp supported\r\n return constructor.Slerp(left, right, amount);\r\n }\r\n else if (left.toFixed) { // Number\r\n return left * (1.0 - amount) + amount * right;\r\n }\r\n else { // Blending not supported\r\n return right;\r\n }\r\n };\r\n /**\r\n * Parses an animation object and creates an animation\r\n * @param parsedAnimation Parsed animation object\r\n * @returns Animation object\r\n */\r\n Animation.Parse = function (parsedAnimation) {\r\n var animation = new Animation(parsedAnimation.name, parsedAnimation.property, parsedAnimation.framePerSecond, parsedAnimation.dataType, parsedAnimation.loopBehavior);\r\n var dataType = parsedAnimation.dataType;\r\n var keys = [];\r\n var data;\r\n var index;\r\n if (parsedAnimation.enableBlending) {\r\n animation.enableBlending = parsedAnimation.enableBlending;\r\n }\r\n if (parsedAnimation.blendingSpeed) {\r\n animation.blendingSpeed = parsedAnimation.blendingSpeed;\r\n }\r\n for (index = 0; index < parsedAnimation.keys.length; index++) {\r\n var key = parsedAnimation.keys[index];\r\n var inTangent;\r\n var outTangent;\r\n switch (dataType) {\r\n case Animation.ANIMATIONTYPE_FLOAT:\r\n data = key.values[0];\r\n if (key.values.length >= 1) {\r\n inTangent = key.values[1];\r\n }\r\n if (key.values.length >= 2) {\r\n outTangent = key.values[2];\r\n }\r\n break;\r\n case Animation.ANIMATIONTYPE_QUATERNION:\r\n data = Quaternion.FromArray(key.values);\r\n if (key.values.length >= 8) {\r\n var _inTangent = Quaternion.FromArray(key.values.slice(4, 8));\r\n if (!_inTangent.equals(Quaternion.Zero())) {\r\n inTangent = _inTangent;\r\n }\r\n }\r\n if (key.values.length >= 12) {\r\n var _outTangent = Quaternion.FromArray(key.values.slice(8, 12));\r\n if (!_outTangent.equals(Quaternion.Zero())) {\r\n outTangent = _outTangent;\r\n }\r\n }\r\n break;\r\n case Animation.ANIMATIONTYPE_MATRIX:\r\n data = Matrix.FromArray(key.values);\r\n break;\r\n case Animation.ANIMATIONTYPE_COLOR3:\r\n data = Color3.FromArray(key.values);\r\n break;\r\n case Animation.ANIMATIONTYPE_COLOR4:\r\n data = Color4.FromArray(key.values);\r\n break;\r\n case Animation.ANIMATIONTYPE_VECTOR3:\r\n default:\r\n data = Vector3.FromArray(key.values);\r\n break;\r\n }\r\n var keyData = {};\r\n keyData.frame = key.frame;\r\n keyData.value = data;\r\n if (inTangent != undefined) {\r\n keyData.inTangent = inTangent;\r\n }\r\n if (outTangent != undefined) {\r\n keyData.outTangent = outTangent;\r\n }\r\n keys.push(keyData);\r\n }\r\n animation.setKeys(keys);\r\n if (parsedAnimation.ranges) {\r\n for (index = 0; index < parsedAnimation.ranges.length; index++) {\r\n data = parsedAnimation.ranges[index];\r\n animation.createRange(data.name, data.from, data.to);\r\n }\r\n }\r\n return animation;\r\n };\r\n /**\r\n * Appends the serialized animations from the source animations\r\n * @param source Source containing the animations\r\n * @param destination Target to store the animations\r\n */\r\n Animation.AppendSerializedAnimations = function (source, destination) {\r\n SerializationHelper.AppendSerializedAnimations(source, destination);\r\n };\r\n /**\r\n * Use matrix interpolation instead of using direct key value when animating matrices\r\n */\r\n Animation.AllowMatricesInterpolation = false;\r\n /**\r\n * When matrix interpolation is enabled, this boolean forces the system to use Matrix.DecomposeLerp instead of Matrix.Lerp. Interpolation is more precise but slower\r\n */\r\n Animation.AllowMatrixDecomposeForInterpolation = true;\r\n // Statics\r\n /**\r\n * Float animation type\r\n */\r\n Animation.ANIMATIONTYPE_FLOAT = 0;\r\n /**\r\n * Vector3 animation type\r\n */\r\n Animation.ANIMATIONTYPE_VECTOR3 = 1;\r\n /**\r\n * Quaternion animation type\r\n */\r\n Animation.ANIMATIONTYPE_QUATERNION = 2;\r\n /**\r\n * Matrix animation type\r\n */\r\n Animation.ANIMATIONTYPE_MATRIX = 3;\r\n /**\r\n * Color3 animation type\r\n */\r\n Animation.ANIMATIONTYPE_COLOR3 = 4;\r\n /**\r\n * Color3 animation type\r\n */\r\n Animation.ANIMATIONTYPE_COLOR4 = 7;\r\n /**\r\n * Vector2 animation type\r\n */\r\n Animation.ANIMATIONTYPE_VECTOR2 = 5;\r\n /**\r\n * Size animation type\r\n */\r\n Animation.ANIMATIONTYPE_SIZE = 6;\r\n /**\r\n * Relative Loop Mode\r\n */\r\n Animation.ANIMATIONLOOPMODE_RELATIVE = 0;\r\n /**\r\n * Cycle Loop Mode\r\n */\r\n Animation.ANIMATIONLOOPMODE_CYCLE = 1;\r\n /**\r\n * Constant Loop Mode\r\n */\r\n Animation.ANIMATIONLOOPMODE_CONSTANT = 2;\r\n return Animation;\r\n}());\r\nexport { Animation };\r\n_TypeStore.RegisteredTypes[\"BABYLON.Animation\"] = Animation;\r\nNode._AnimationRangeFactory = function (name, from, to) { return new AnimationRange(name, from, to); };\r\n//# sourceMappingURL=animation.js.map","import { BackEase, EasingFunction } from \"../../Animations/easing\";\r\nimport { Animation } from \"../../Animations/animation\";\r\n/**\r\n * Add a bouncing effect to an ArcRotateCamera when reaching a specified minimum and maximum radius\r\n * @see http://doc.babylonjs.com/how_to/camera_behaviors#bouncing-behavior\r\n */\r\nvar BouncingBehavior = /** @class */ (function () {\r\n function BouncingBehavior() {\r\n /**\r\n * The duration of the animation, in milliseconds\r\n */\r\n this.transitionDuration = 450;\r\n /**\r\n * Length of the distance animated by the transition when lower radius is reached\r\n */\r\n this.lowerRadiusTransitionRange = 2;\r\n /**\r\n * Length of the distance animated by the transition when upper radius is reached\r\n */\r\n this.upperRadiusTransitionRange = -2;\r\n this._autoTransitionRange = false;\r\n // Animations\r\n this._radiusIsAnimating = false;\r\n this._radiusBounceTransition = null;\r\n this._animatables = new Array();\r\n }\r\n Object.defineProperty(BouncingBehavior.prototype, \"name\", {\r\n /**\r\n * Gets the name of the behavior.\r\n */\r\n get: function () {\r\n return \"Bouncing\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(BouncingBehavior.prototype, \"autoTransitionRange\", {\r\n /**\r\n * Gets a value indicating if the lowerRadiusTransitionRange and upperRadiusTransitionRange are defined automatically\r\n */\r\n get: function () {\r\n return this._autoTransitionRange;\r\n },\r\n /**\r\n * Sets a value indicating if the lowerRadiusTransitionRange and upperRadiusTransitionRange are defined automatically\r\n * Transition ranges will be set to 5% of the bounding box diagonal in world space\r\n */\r\n set: function (value) {\r\n var _this = this;\r\n if (this._autoTransitionRange === value) {\r\n return;\r\n }\r\n this._autoTransitionRange = value;\r\n var camera = this._attachedCamera;\r\n if (!camera) {\r\n return;\r\n }\r\n if (value) {\r\n this._onMeshTargetChangedObserver = camera.onMeshTargetChangedObservable.add(function (mesh) {\r\n if (!mesh) {\r\n return;\r\n }\r\n mesh.computeWorldMatrix(true);\r\n var diagonal = mesh.getBoundingInfo().diagonalLength;\r\n _this.lowerRadiusTransitionRange = diagonal * 0.05;\r\n _this.upperRadiusTransitionRange = diagonal * 0.05;\r\n });\r\n }\r\n else if (this._onMeshTargetChangedObserver) {\r\n camera.onMeshTargetChangedObservable.remove(this._onMeshTargetChangedObserver);\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Initializes the behavior.\r\n */\r\n BouncingBehavior.prototype.init = function () {\r\n // Do notihng\r\n };\r\n /**\r\n * Attaches the behavior to its arc rotate camera.\r\n * @param camera Defines the camera to attach the behavior to\r\n */\r\n BouncingBehavior.prototype.attach = function (camera) {\r\n var _this = this;\r\n this._attachedCamera = camera;\r\n this._onAfterCheckInputsObserver = camera.onAfterCheckInputsObservable.add(function () {\r\n if (!_this._attachedCamera) {\r\n return;\r\n }\r\n // Add the bounce animation to the lower radius limit\r\n if (_this._isRadiusAtLimit(_this._attachedCamera.lowerRadiusLimit)) {\r\n _this._applyBoundRadiusAnimation(_this.lowerRadiusTransitionRange);\r\n }\r\n // Add the bounce animation to the upper radius limit\r\n if (_this._isRadiusAtLimit(_this._attachedCamera.upperRadiusLimit)) {\r\n _this._applyBoundRadiusAnimation(_this.upperRadiusTransitionRange);\r\n }\r\n });\r\n };\r\n /**\r\n * Detaches the behavior from its current arc rotate camera.\r\n */\r\n BouncingBehavior.prototype.detach = function () {\r\n if (!this._attachedCamera) {\r\n return;\r\n }\r\n if (this._onAfterCheckInputsObserver) {\r\n this._attachedCamera.onAfterCheckInputsObservable.remove(this._onAfterCheckInputsObserver);\r\n }\r\n if (this._onMeshTargetChangedObserver) {\r\n this._attachedCamera.onMeshTargetChangedObservable.remove(this._onMeshTargetChangedObserver);\r\n }\r\n this._attachedCamera = null;\r\n };\r\n /**\r\n * Checks if the camera radius is at the specified limit. Takes into account animation locks.\r\n * @param radiusLimit The limit to check against.\r\n * @return Bool to indicate if at limit.\r\n */\r\n BouncingBehavior.prototype._isRadiusAtLimit = function (radiusLimit) {\r\n if (!this._attachedCamera) {\r\n return false;\r\n }\r\n if (this._attachedCamera.radius === radiusLimit && !this._radiusIsAnimating) {\r\n return true;\r\n }\r\n return false;\r\n };\r\n /**\r\n * Applies an animation to the radius of the camera, extending by the radiusDelta.\r\n * @param radiusDelta The delta by which to animate to. Can be negative.\r\n */\r\n BouncingBehavior.prototype._applyBoundRadiusAnimation = function (radiusDelta) {\r\n var _this = this;\r\n if (!this._attachedCamera) {\r\n return;\r\n }\r\n if (!this._radiusBounceTransition) {\r\n BouncingBehavior.EasingFunction.setEasingMode(BouncingBehavior.EasingMode);\r\n this._radiusBounceTransition = Animation.CreateAnimation(\"radius\", Animation.ANIMATIONTYPE_FLOAT, 60, BouncingBehavior.EasingFunction);\r\n }\r\n // Prevent zoom until bounce has completed\r\n this._cachedWheelPrecision = this._attachedCamera.wheelPrecision;\r\n this._attachedCamera.wheelPrecision = Infinity;\r\n this._attachedCamera.inertialRadiusOffset = 0;\r\n // Animate to the radius limit\r\n this.stopAllAnimations();\r\n this._radiusIsAnimating = true;\r\n var animatable = Animation.TransitionTo(\"radius\", this._attachedCamera.radius + radiusDelta, this._attachedCamera, this._attachedCamera.getScene(), 60, this._radiusBounceTransition, this.transitionDuration, function () { return _this._clearAnimationLocks(); });\r\n if (animatable) {\r\n this._animatables.push(animatable);\r\n }\r\n };\r\n /**\r\n * Removes all animation locks. Allows new animations to be added to any of the camera properties.\r\n */\r\n BouncingBehavior.prototype._clearAnimationLocks = function () {\r\n this._radiusIsAnimating = false;\r\n if (this._attachedCamera) {\r\n this._attachedCamera.wheelPrecision = this._cachedWheelPrecision;\r\n }\r\n };\r\n /**\r\n * Stops and removes all animations that have been applied to the camera\r\n */\r\n BouncingBehavior.prototype.stopAllAnimations = function () {\r\n if (this._attachedCamera) {\r\n this._attachedCamera.animations = [];\r\n }\r\n while (this._animatables.length) {\r\n this._animatables[0].onAnimationEnd = null;\r\n this._animatables[0].stop();\r\n this._animatables.shift();\r\n }\r\n };\r\n /**\r\n * The easing function used by animations\r\n */\r\n BouncingBehavior.EasingFunction = new BackEase(0.3);\r\n /**\r\n * The easing mode used by animations\r\n */\r\n BouncingBehavior.EasingMode = EasingFunction.EASINGMODE_EASEOUT;\r\n return BouncingBehavior;\r\n}());\r\nexport { BouncingBehavior };\r\n//# sourceMappingURL=bouncingBehavior.js.map","import { ExponentialEase, EasingFunction } from \"../../Animations/easing\";\r\nimport { PointerEventTypes } from \"../../Events/pointerEvents\";\r\nimport { PrecisionDate } from \"../../Misc/precisionDate\";\r\nimport { Vector3, Vector2 } from \"../../Maths/math.vector\";\r\nimport { Animation } from \"../../Animations/animation\";\r\n/**\r\n * The framing behavior (FramingBehavior) is designed to automatically position an ArcRotateCamera when its target is set to a mesh. It is also useful if you want to prevent the camera to go under a virtual horizontal plane.\r\n * @see http://doc.babylonjs.com/how_to/camera_behaviors#framing-behavior\r\n */\r\nvar FramingBehavior = /** @class */ (function () {\r\n function FramingBehavior() {\r\n this._mode = FramingBehavior.FitFrustumSidesMode;\r\n this._radiusScale = 1.0;\r\n this._positionScale = 0.5;\r\n this._defaultElevation = 0.3;\r\n this._elevationReturnTime = 1500;\r\n this._elevationReturnWaitTime = 1000;\r\n this._zoomStopsAnimation = false;\r\n this._framingTime = 1500;\r\n /**\r\n * Define if the behavior should automatically change the configured\r\n * camera limits and sensibilities.\r\n */\r\n this.autoCorrectCameraLimitsAndSensibility = true;\r\n this._isPointerDown = false;\r\n this._lastInteractionTime = -Infinity;\r\n // Framing control\r\n this._animatables = new Array();\r\n this._betaIsAnimating = false;\r\n }\r\n Object.defineProperty(FramingBehavior.prototype, \"name\", {\r\n /**\r\n * Gets the name of the behavior.\r\n */\r\n get: function () {\r\n return \"Framing\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(FramingBehavior.prototype, \"mode\", {\r\n /**\r\n * Gets current mode used by the behavior.\r\n */\r\n get: function () {\r\n return this._mode;\r\n },\r\n /**\r\n * Sets the current mode used by the behavior\r\n */\r\n set: function (mode) {\r\n this._mode = mode;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(FramingBehavior.prototype, \"radiusScale\", {\r\n /**\r\n * Gets the scale applied to the radius\r\n */\r\n get: function () {\r\n return this._radiusScale;\r\n },\r\n /**\r\n * Sets the scale applied to the radius (1 by default)\r\n */\r\n set: function (radius) {\r\n this._radiusScale = radius;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(FramingBehavior.prototype, \"positionScale\", {\r\n /**\r\n * Gets the scale to apply on Y axis to position camera focus. 0.5 by default which means the center of the bounding box.\r\n */\r\n get: function () {\r\n return this._positionScale;\r\n },\r\n /**\r\n * Sets the scale to apply on Y axis to position camera focus. 0.5 by default which means the center of the bounding box.\r\n */\r\n set: function (scale) {\r\n this._positionScale = scale;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(FramingBehavior.prototype, \"defaultElevation\", {\r\n /**\r\n * Gets the angle above/below the horizontal plane to return to when the return to default elevation idle\r\n * behaviour is triggered, in radians.\r\n */\r\n get: function () {\r\n return this._defaultElevation;\r\n },\r\n /**\r\n * Sets the angle above/below the horizontal plane to return to when the return to default elevation idle\r\n * behaviour is triggered, in radians.\r\n */\r\n set: function (elevation) {\r\n this._defaultElevation = elevation;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(FramingBehavior.prototype, \"elevationReturnTime\", {\r\n /**\r\n * Gets the time (in milliseconds) taken to return to the default beta position.\r\n * Negative value indicates camera should not return to default.\r\n */\r\n get: function () {\r\n return this._elevationReturnTime;\r\n },\r\n /**\r\n * Sets the time (in milliseconds) taken to return to the default beta position.\r\n * Negative value indicates camera should not return to default.\r\n */\r\n set: function (speed) {\r\n this._elevationReturnTime = speed;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(FramingBehavior.prototype, \"elevationReturnWaitTime\", {\r\n /**\r\n * Gets the delay (in milliseconds) taken before the camera returns to the default beta position.\r\n */\r\n get: function () {\r\n return this._elevationReturnWaitTime;\r\n },\r\n /**\r\n * Sets the delay (in milliseconds) taken before the camera returns to the default beta position.\r\n */\r\n set: function (time) {\r\n this._elevationReturnWaitTime = time;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(FramingBehavior.prototype, \"zoomStopsAnimation\", {\r\n /**\r\n * Gets the flag that indicates if user zooming should stop animation.\r\n */\r\n get: function () {\r\n return this._zoomStopsAnimation;\r\n },\r\n /**\r\n * Sets the flag that indicates if user zooming should stop animation.\r\n */\r\n set: function (flag) {\r\n this._zoomStopsAnimation = flag;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(FramingBehavior.prototype, \"framingTime\", {\r\n /**\r\n * Gets the transition time when framing the mesh, in milliseconds\r\n */\r\n get: function () {\r\n return this._framingTime;\r\n },\r\n /**\r\n * Sets the transition time when framing the mesh, in milliseconds\r\n */\r\n set: function (time) {\r\n this._framingTime = time;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Initializes the behavior.\r\n */\r\n FramingBehavior.prototype.init = function () {\r\n // Do notihng\r\n };\r\n /**\r\n * Attaches the behavior to its arc rotate camera.\r\n * @param camera Defines the camera to attach the behavior to\r\n */\r\n FramingBehavior.prototype.attach = function (camera) {\r\n var _this = this;\r\n this._attachedCamera = camera;\r\n var scene = this._attachedCamera.getScene();\r\n FramingBehavior.EasingFunction.setEasingMode(FramingBehavior.EasingMode);\r\n this._onPrePointerObservableObserver = scene.onPrePointerObservable.add(function (pointerInfoPre) {\r\n if (pointerInfoPre.type === PointerEventTypes.POINTERDOWN) {\r\n _this._isPointerDown = true;\r\n return;\r\n }\r\n if (pointerInfoPre.type === PointerEventTypes.POINTERUP) {\r\n _this._isPointerDown = false;\r\n }\r\n });\r\n this._onMeshTargetChangedObserver = camera.onMeshTargetChangedObservable.add(function (mesh) {\r\n if (mesh) {\r\n _this.zoomOnMesh(mesh);\r\n }\r\n });\r\n this._onAfterCheckInputsObserver = camera.onAfterCheckInputsObservable.add(function () {\r\n // Stop the animation if there is user interaction and the animation should stop for this interaction\r\n _this._applyUserInteraction();\r\n // Maintain the camera above the ground. If the user pulls the camera beneath the ground plane, lift it\r\n // back to the default position after a given timeout\r\n _this._maintainCameraAboveGround();\r\n });\r\n };\r\n /**\r\n * Detaches the behavior from its current arc rotate camera.\r\n */\r\n FramingBehavior.prototype.detach = function () {\r\n if (!this._attachedCamera) {\r\n return;\r\n }\r\n var scene = this._attachedCamera.getScene();\r\n if (this._onPrePointerObservableObserver) {\r\n scene.onPrePointerObservable.remove(this._onPrePointerObservableObserver);\r\n }\r\n if (this._onAfterCheckInputsObserver) {\r\n this._attachedCamera.onAfterCheckInputsObservable.remove(this._onAfterCheckInputsObserver);\r\n }\r\n if (this._onMeshTargetChangedObserver) {\r\n this._attachedCamera.onMeshTargetChangedObservable.remove(this._onMeshTargetChangedObserver);\r\n }\r\n this._attachedCamera = null;\r\n };\r\n /**\r\n * Targets the given mesh and updates zoom level accordingly.\r\n * @param mesh The mesh to target.\r\n * @param focusOnOriginXZ Determines if the camera should focus on 0 in the X and Z axis instead of the mesh\r\n * @param onAnimationEnd Callback triggered at the end of the framing animation\r\n */\r\n FramingBehavior.prototype.zoomOnMesh = function (mesh, focusOnOriginXZ, onAnimationEnd) {\r\n if (focusOnOriginXZ === void 0) { focusOnOriginXZ = false; }\r\n if (onAnimationEnd === void 0) { onAnimationEnd = null; }\r\n mesh.computeWorldMatrix(true);\r\n var boundingBox = mesh.getBoundingInfo().boundingBox;\r\n this.zoomOnBoundingInfo(boundingBox.minimumWorld, boundingBox.maximumWorld, focusOnOriginXZ, onAnimationEnd);\r\n };\r\n /**\r\n * Targets the given mesh with its children and updates zoom level accordingly.\r\n * @param mesh The mesh to target.\r\n * @param focusOnOriginXZ Determines if the camera should focus on 0 in the X and Z axis instead of the mesh\r\n * @param onAnimationEnd Callback triggered at the end of the framing animation\r\n */\r\n FramingBehavior.prototype.zoomOnMeshHierarchy = function (mesh, focusOnOriginXZ, onAnimationEnd) {\r\n if (focusOnOriginXZ === void 0) { focusOnOriginXZ = false; }\r\n if (onAnimationEnd === void 0) { onAnimationEnd = null; }\r\n mesh.computeWorldMatrix(true);\r\n var boundingBox = mesh.getHierarchyBoundingVectors(true);\r\n this.zoomOnBoundingInfo(boundingBox.min, boundingBox.max, focusOnOriginXZ, onAnimationEnd);\r\n };\r\n /**\r\n * Targets the given meshes with their children and updates zoom level accordingly.\r\n * @param meshes The mesh to target.\r\n * @param focusOnOriginXZ Determines if the camera should focus on 0 in the X and Z axis instead of the mesh\r\n * @param onAnimationEnd Callback triggered at the end of the framing animation\r\n */\r\n FramingBehavior.prototype.zoomOnMeshesHierarchy = function (meshes, focusOnOriginXZ, onAnimationEnd) {\r\n if (focusOnOriginXZ === void 0) { focusOnOriginXZ = false; }\r\n if (onAnimationEnd === void 0) { onAnimationEnd = null; }\r\n var min = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n var max = new Vector3(-Number.MAX_VALUE, -Number.MAX_VALUE, -Number.MAX_VALUE);\r\n for (var i = 0; i < meshes.length; i++) {\r\n var boundingInfo = meshes[i].getHierarchyBoundingVectors(true);\r\n Vector3.CheckExtends(boundingInfo.min, min, max);\r\n Vector3.CheckExtends(boundingInfo.max, min, max);\r\n }\r\n this.zoomOnBoundingInfo(min, max, focusOnOriginXZ, onAnimationEnd);\r\n };\r\n /**\r\n * Targets the bounding box info defined by its extends and updates zoom level accordingly.\r\n * @param minimumWorld Determines the smaller position of the bounding box extend\r\n * @param maximumWorld Determines the bigger position of the bounding box extend\r\n * @param focusOnOriginXZ Determines if the camera should focus on 0 in the X and Z axis instead of the mesh\r\n * @param onAnimationEnd Callback triggered at the end of the framing animation\r\n */\r\n FramingBehavior.prototype.zoomOnBoundingInfo = function (minimumWorld, maximumWorld, focusOnOriginXZ, onAnimationEnd) {\r\n var _this = this;\r\n if (focusOnOriginXZ === void 0) { focusOnOriginXZ = false; }\r\n if (onAnimationEnd === void 0) { onAnimationEnd = null; }\r\n var zoomTarget;\r\n if (!this._attachedCamera) {\r\n return;\r\n }\r\n // Find target by interpolating from bottom of bounding box in world-space to top via framingPositionY\r\n var bottom = minimumWorld.y;\r\n var top = maximumWorld.y;\r\n var zoomTargetY = bottom + (top - bottom) * this._positionScale;\r\n var radiusWorld = maximumWorld.subtract(minimumWorld).scale(0.5);\r\n if (focusOnOriginXZ) {\r\n zoomTarget = new Vector3(0, zoomTargetY, 0);\r\n }\r\n else {\r\n var centerWorld = minimumWorld.add(radiusWorld);\r\n zoomTarget = new Vector3(centerWorld.x, zoomTargetY, centerWorld.z);\r\n }\r\n if (!this._vectorTransition) {\r\n this._vectorTransition = Animation.CreateAnimation(\"target\", Animation.ANIMATIONTYPE_VECTOR3, 60, FramingBehavior.EasingFunction);\r\n }\r\n this._betaIsAnimating = true;\r\n var animatable = Animation.TransitionTo(\"target\", zoomTarget, this._attachedCamera, this._attachedCamera.getScene(), 60, this._vectorTransition, this._framingTime);\r\n if (animatable) {\r\n this._animatables.push(animatable);\r\n }\r\n // sets the radius and lower radius bounds\r\n // Small delta ensures camera is not always at lower zoom limit.\r\n var radius = 0;\r\n if (this._mode === FramingBehavior.FitFrustumSidesMode) {\r\n var position = this._calculateLowerRadiusFromModelBoundingSphere(minimumWorld, maximumWorld);\r\n if (this.autoCorrectCameraLimitsAndSensibility) {\r\n this._attachedCamera.lowerRadiusLimit = radiusWorld.length() + this._attachedCamera.minZ;\r\n }\r\n radius = position;\r\n }\r\n else if (this._mode === FramingBehavior.IgnoreBoundsSizeMode) {\r\n radius = this._calculateLowerRadiusFromModelBoundingSphere(minimumWorld, maximumWorld);\r\n if (this.autoCorrectCameraLimitsAndSensibility && this._attachedCamera.lowerRadiusLimit === null) {\r\n this._attachedCamera.lowerRadiusLimit = this._attachedCamera.minZ;\r\n }\r\n }\r\n // Set sensibilities\r\n if (this.autoCorrectCameraLimitsAndSensibility) {\r\n var extend = maximumWorld.subtract(minimumWorld).length();\r\n this._attachedCamera.panningSensibility = 5000 / extend;\r\n this._attachedCamera.wheelPrecision = 100 / radius;\r\n }\r\n // transition to new radius\r\n if (!this._radiusTransition) {\r\n this._radiusTransition = Animation.CreateAnimation(\"radius\", Animation.ANIMATIONTYPE_FLOAT, 60, FramingBehavior.EasingFunction);\r\n }\r\n animatable = Animation.TransitionTo(\"radius\", radius, this._attachedCamera, this._attachedCamera.getScene(), 60, this._radiusTransition, this._framingTime, function () {\r\n _this.stopAllAnimations();\r\n if (onAnimationEnd) {\r\n onAnimationEnd();\r\n }\r\n if (_this._attachedCamera && _this._attachedCamera.useInputToRestoreState) {\r\n _this._attachedCamera.storeState();\r\n }\r\n });\r\n if (animatable) {\r\n this._animatables.push(animatable);\r\n }\r\n };\r\n /**\r\n * Calculates the lowest radius for the camera based on the bounding box of the mesh.\r\n * @param mesh The mesh on which to base the calculation. mesh boundingInfo used to estimate necessary\r\n *\t\t\t frustum width.\r\n * @return The minimum distance from the primary mesh's center point at which the camera must be kept in order\r\n *\t\t to fully enclose the mesh in the viewing frustum.\r\n */\r\n FramingBehavior.prototype._calculateLowerRadiusFromModelBoundingSphere = function (minimumWorld, maximumWorld) {\r\n var size = maximumWorld.subtract(minimumWorld);\r\n var boxVectorGlobalDiagonal = size.length();\r\n var frustumSlope = this._getFrustumSlope();\r\n // Formula for setting distance\r\n // (Good explanation: http://stackoverflow.com/questions/2866350/move-camera-to-fit-3d-scene)\r\n var radiusWithoutFraming = boxVectorGlobalDiagonal * 0.5;\r\n // Horizon distance\r\n var radius = radiusWithoutFraming * this._radiusScale;\r\n var distanceForHorizontalFrustum = radius * Math.sqrt(1.0 + 1.0 / (frustumSlope.x * frustumSlope.x));\r\n var distanceForVerticalFrustum = radius * Math.sqrt(1.0 + 1.0 / (frustumSlope.y * frustumSlope.y));\r\n var distance = Math.max(distanceForHorizontalFrustum, distanceForVerticalFrustum);\r\n var camera = this._attachedCamera;\r\n if (!camera) {\r\n return 0;\r\n }\r\n if (camera.lowerRadiusLimit && this._mode === FramingBehavior.IgnoreBoundsSizeMode) {\r\n // Don't exceed the requested limit\r\n distance = distance < camera.lowerRadiusLimit ? camera.lowerRadiusLimit : distance;\r\n }\r\n // Don't exceed the upper radius limit\r\n if (camera.upperRadiusLimit) {\r\n distance = distance > camera.upperRadiusLimit ? camera.upperRadiusLimit : distance;\r\n }\r\n return distance;\r\n };\r\n /**\r\n * Keeps the camera above the ground plane. If the user pulls the camera below the ground plane, the camera\r\n * is automatically returned to its default position (expected to be above ground plane).\r\n */\r\n FramingBehavior.prototype._maintainCameraAboveGround = function () {\r\n var _this = this;\r\n if (this._elevationReturnTime < 0) {\r\n return;\r\n }\r\n var timeSinceInteraction = PrecisionDate.Now - this._lastInteractionTime;\r\n var defaultBeta = Math.PI * 0.5 - this._defaultElevation;\r\n var limitBeta = Math.PI * 0.5;\r\n // Bring the camera back up if below the ground plane\r\n if (this._attachedCamera && !this._betaIsAnimating && this._attachedCamera.beta > limitBeta && timeSinceInteraction >= this._elevationReturnWaitTime) {\r\n this._betaIsAnimating = true;\r\n //Transition to new position\r\n this.stopAllAnimations();\r\n if (!this._betaTransition) {\r\n this._betaTransition = Animation.CreateAnimation(\"beta\", Animation.ANIMATIONTYPE_FLOAT, 60, FramingBehavior.EasingFunction);\r\n }\r\n var animatabe = Animation.TransitionTo(\"beta\", defaultBeta, this._attachedCamera, this._attachedCamera.getScene(), 60, this._betaTransition, this._elevationReturnTime, function () {\r\n _this._clearAnimationLocks();\r\n _this.stopAllAnimations();\r\n });\r\n if (animatabe) {\r\n this._animatables.push(animatabe);\r\n }\r\n }\r\n };\r\n /**\r\n * Returns the frustum slope based on the canvas ratio and camera FOV\r\n * @returns The frustum slope represented as a Vector2 with X and Y slopes\r\n */\r\n FramingBehavior.prototype._getFrustumSlope = function () {\r\n // Calculate the viewport ratio\r\n // Aspect Ratio is Height/Width.\r\n var camera = this._attachedCamera;\r\n if (!camera) {\r\n return Vector2.Zero();\r\n }\r\n var engine = camera.getScene().getEngine();\r\n var aspectRatio = engine.getAspectRatio(camera);\r\n // Camera FOV is the vertical field of view (top-bottom) in radians.\r\n // Slope of the frustum top/bottom planes in view space, relative to the forward vector.\r\n var frustumSlopeY = Math.tan(camera.fov / 2);\r\n // Slope of the frustum left/right planes in view space, relative to the forward vector.\r\n // Provides the amount that one side (e.g. left) of the frustum gets wider for every unit\r\n // along the forward vector.\r\n var frustumSlopeX = frustumSlopeY * aspectRatio;\r\n return new Vector2(frustumSlopeX, frustumSlopeY);\r\n };\r\n /**\r\n * Removes all animation locks. Allows new animations to be added to any of the arcCamera properties.\r\n */\r\n FramingBehavior.prototype._clearAnimationLocks = function () {\r\n this._betaIsAnimating = false;\r\n };\r\n /**\r\n * Applies any current user interaction to the camera. Takes into account maximum alpha rotation.\r\n */\r\n FramingBehavior.prototype._applyUserInteraction = function () {\r\n if (this.isUserIsMoving) {\r\n this._lastInteractionTime = PrecisionDate.Now;\r\n this.stopAllAnimations();\r\n this._clearAnimationLocks();\r\n }\r\n };\r\n /**\r\n * Stops and removes all animations that have been applied to the camera\r\n */\r\n FramingBehavior.prototype.stopAllAnimations = function () {\r\n if (this._attachedCamera) {\r\n this._attachedCamera.animations = [];\r\n }\r\n while (this._animatables.length) {\r\n if (this._animatables[0]) {\r\n this._animatables[0].onAnimationEnd = null;\r\n this._animatables[0].stop();\r\n }\r\n this._animatables.shift();\r\n }\r\n };\r\n Object.defineProperty(FramingBehavior.prototype, \"isUserIsMoving\", {\r\n /**\r\n * Gets a value indicating if the user is moving the camera\r\n */\r\n get: function () {\r\n if (!this._attachedCamera) {\r\n return false;\r\n }\r\n return this._attachedCamera.inertialAlphaOffset !== 0 ||\r\n this._attachedCamera.inertialBetaOffset !== 0 ||\r\n this._attachedCamera.inertialRadiusOffset !== 0 ||\r\n this._attachedCamera.inertialPanningX !== 0 ||\r\n this._attachedCamera.inertialPanningY !== 0 ||\r\n this._isPointerDown;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * The easing function used by animations\r\n */\r\n FramingBehavior.EasingFunction = new ExponentialEase();\r\n /**\r\n * The easing mode used by animations\r\n */\r\n FramingBehavior.EasingMode = EasingFunction.EASINGMODE_EASEINOUT;\r\n // Statics\r\n /**\r\n * The camera can move all the way towards the mesh.\r\n */\r\n FramingBehavior.IgnoreBoundsSizeMode = 0;\r\n /**\r\n * The camera is not allowed to zoom closer to the mesh than the point at which the adjusted bounding sphere touches the frustum sides\r\n */\r\n FramingBehavior.FitFrustumSidesMode = 1;\r\n return FramingBehavior;\r\n}());\r\nexport { FramingBehavior };\r\n//# sourceMappingURL=framingBehavior.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, serializeAsVector3, serializeAsMeshReference } from \"../Misc/decorators\";\r\nimport { Camera } from \"./camera\";\r\nimport { Quaternion, Matrix, Vector3, Vector2, TmpVectors } from \"../Maths/math.vector\";\r\nimport { Epsilon } from '../Maths/math.constants';\r\nimport { Axis } from '../Maths/math.axis';\r\n/**\r\n * A target camera takes a mesh or position as a target and continues to look at it while it moves.\r\n * This is the base of the follow, arc rotate cameras and Free camera\r\n * @see http://doc.babylonjs.com/features/cameras\r\n */\r\nvar TargetCamera = /** @class */ (function (_super) {\r\n __extends(TargetCamera, _super);\r\n /**\r\n * Instantiates a target camera that takes a mesh or position as a target and continues to look at it while it moves.\r\n * This is the base of the follow, arc rotate cameras and Free camera\r\n * @see http://doc.babylonjs.com/features/cameras\r\n * @param name Defines the name of the camera in the scene\r\n * @param position Defines the start position of the camera in the scene\r\n * @param scene Defines the scene the camera belongs to\r\n * @param setActiveOnSceneIfNoneActive Defines wheter the camera should be marked as active if not other active cameras have been defined\r\n */\r\n function TargetCamera(name, position, scene, setActiveOnSceneIfNoneActive) {\r\n if (setActiveOnSceneIfNoneActive === void 0) { setActiveOnSceneIfNoneActive = true; }\r\n var _this = _super.call(this, name, position, scene, setActiveOnSceneIfNoneActive) || this;\r\n /**\r\n * Define the current direction the camera is moving to\r\n */\r\n _this.cameraDirection = new Vector3(0, 0, 0);\r\n /**\r\n * Define the current rotation the camera is rotating to\r\n */\r\n _this.cameraRotation = new Vector2(0, 0);\r\n /**\r\n * When set, the up vector of the camera will be updated by the rotation of the camera\r\n */\r\n _this.updateUpVectorFromRotation = false;\r\n _this._tmpQuaternion = new Quaternion();\r\n /**\r\n * Define the current rotation of the camera\r\n */\r\n _this.rotation = new Vector3(0, 0, 0);\r\n /**\r\n * Define the current speed of the camera\r\n */\r\n _this.speed = 2.0;\r\n /**\r\n * Add constraint to the camera to prevent it to move freely in all directions and\r\n * around all axis.\r\n */\r\n _this.noRotationConstraint = false;\r\n /**\r\n * Define the current target of the camera as an object or a position.\r\n */\r\n _this.lockedTarget = null;\r\n /** @hidden */\r\n _this._currentTarget = Vector3.Zero();\r\n /** @hidden */\r\n _this._initialFocalDistance = 1;\r\n /** @hidden */\r\n _this._viewMatrix = Matrix.Zero();\r\n /** @hidden */\r\n _this._camMatrix = Matrix.Zero();\r\n /** @hidden */\r\n _this._cameraTransformMatrix = Matrix.Zero();\r\n /** @hidden */\r\n _this._cameraRotationMatrix = Matrix.Zero();\r\n /** @hidden */\r\n _this._referencePoint = new Vector3(0, 0, 1);\r\n /** @hidden */\r\n _this._transformedReferencePoint = Vector3.Zero();\r\n _this._globalCurrentTarget = Vector3.Zero();\r\n _this._globalCurrentUpVector = Vector3.Zero();\r\n _this._defaultUp = Vector3.Up();\r\n _this._cachedRotationZ = 0;\r\n _this._cachedQuaternionRotationZ = 0;\r\n return _this;\r\n }\r\n /**\r\n * Gets the position in front of the camera at a given distance.\r\n * @param distance The distance from the camera we want the position to be\r\n * @returns the position\r\n */\r\n TargetCamera.prototype.getFrontPosition = function (distance) {\r\n this.getWorldMatrix();\r\n var direction = this.getTarget().subtract(this.position);\r\n direction.normalize();\r\n direction.scaleInPlace(distance);\r\n return this.globalPosition.add(direction);\r\n };\r\n /** @hidden */\r\n TargetCamera.prototype._getLockedTargetPosition = function () {\r\n if (!this.lockedTarget) {\r\n return null;\r\n }\r\n if (this.lockedTarget.absolutePosition) {\r\n this.lockedTarget.computeWorldMatrix();\r\n }\r\n return this.lockedTarget.absolutePosition || this.lockedTarget;\r\n };\r\n /**\r\n * Store current camera state of the camera (fov, position, rotation, etc..)\r\n * @returns the camera\r\n */\r\n TargetCamera.prototype.storeState = function () {\r\n this._storedPosition = this.position.clone();\r\n this._storedRotation = this.rotation.clone();\r\n if (this.rotationQuaternion) {\r\n this._storedRotationQuaternion = this.rotationQuaternion.clone();\r\n }\r\n return _super.prototype.storeState.call(this);\r\n };\r\n /**\r\n * Restored camera state. You must call storeState() first\r\n * @returns whether it was successful or not\r\n * @hidden\r\n */\r\n TargetCamera.prototype._restoreStateValues = function () {\r\n if (!_super.prototype._restoreStateValues.call(this)) {\r\n return false;\r\n }\r\n this.position = this._storedPosition.clone();\r\n this.rotation = this._storedRotation.clone();\r\n if (this.rotationQuaternion) {\r\n this.rotationQuaternion = this._storedRotationQuaternion.clone();\r\n }\r\n this.cameraDirection.copyFromFloats(0, 0, 0);\r\n this.cameraRotation.copyFromFloats(0, 0);\r\n return true;\r\n };\r\n /** @hidden */\r\n TargetCamera.prototype._initCache = function () {\r\n _super.prototype._initCache.call(this);\r\n this._cache.lockedTarget = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n this._cache.rotation = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n this._cache.rotationQuaternion = new Quaternion(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n };\r\n /** @hidden */\r\n TargetCamera.prototype._updateCache = function (ignoreParentClass) {\r\n if (!ignoreParentClass) {\r\n _super.prototype._updateCache.call(this);\r\n }\r\n var lockedTargetPosition = this._getLockedTargetPosition();\r\n if (!lockedTargetPosition) {\r\n this._cache.lockedTarget = null;\r\n }\r\n else {\r\n if (!this._cache.lockedTarget) {\r\n this._cache.lockedTarget = lockedTargetPosition.clone();\r\n }\r\n else {\r\n this._cache.lockedTarget.copyFrom(lockedTargetPosition);\r\n }\r\n }\r\n this._cache.rotation.copyFrom(this.rotation);\r\n if (this.rotationQuaternion) {\r\n this._cache.rotationQuaternion.copyFrom(this.rotationQuaternion);\r\n }\r\n };\r\n // Synchronized\r\n /** @hidden */\r\n TargetCamera.prototype._isSynchronizedViewMatrix = function () {\r\n if (!_super.prototype._isSynchronizedViewMatrix.call(this)) {\r\n return false;\r\n }\r\n var lockedTargetPosition = this._getLockedTargetPosition();\r\n return (this._cache.lockedTarget ? this._cache.lockedTarget.equals(lockedTargetPosition) : !lockedTargetPosition)\r\n && (this.rotationQuaternion ? this.rotationQuaternion.equals(this._cache.rotationQuaternion) : this._cache.rotation.equals(this.rotation));\r\n };\r\n // Methods\r\n /** @hidden */\r\n TargetCamera.prototype._computeLocalCameraSpeed = function () {\r\n var engine = this.getEngine();\r\n return this.speed * Math.sqrt((engine.getDeltaTime() / (engine.getFps() * 100.0)));\r\n };\r\n // Target\r\n /**\r\n * Defines the target the camera should look at.\r\n * @param target Defines the new target as a Vector or a mesh\r\n */\r\n TargetCamera.prototype.setTarget = function (target) {\r\n this.upVector.normalize();\r\n this._initialFocalDistance = target.subtract(this.position).length();\r\n if (this.position.z === target.z) {\r\n this.position.z += Epsilon;\r\n }\r\n Matrix.LookAtLHToRef(this.position, target, this._defaultUp, this._camMatrix);\r\n this._camMatrix.invert();\r\n this.rotation.x = Math.atan(this._camMatrix.m[6] / this._camMatrix.m[10]);\r\n var vDir = target.subtract(this.position);\r\n if (vDir.x >= 0.0) {\r\n this.rotation.y = (-Math.atan(vDir.z / vDir.x) + Math.PI / 2.0);\r\n }\r\n else {\r\n this.rotation.y = (-Math.atan(vDir.z / vDir.x) - Math.PI / 2.0);\r\n }\r\n this.rotation.z = 0;\r\n if (isNaN(this.rotation.x)) {\r\n this.rotation.x = 0;\r\n }\r\n if (isNaN(this.rotation.y)) {\r\n this.rotation.y = 0;\r\n }\r\n if (isNaN(this.rotation.z)) {\r\n this.rotation.z = 0;\r\n }\r\n if (this.rotationQuaternion) {\r\n Quaternion.RotationYawPitchRollToRef(this.rotation.y, this.rotation.x, this.rotation.z, this.rotationQuaternion);\r\n }\r\n };\r\n /**\r\n * Return the current target position of the camera. This value is expressed in local space.\r\n * @returns the target position\r\n */\r\n TargetCamera.prototype.getTarget = function () {\r\n return this._currentTarget;\r\n };\r\n /** @hidden */\r\n TargetCamera.prototype._decideIfNeedsToMove = function () {\r\n return Math.abs(this.cameraDirection.x) > 0 || Math.abs(this.cameraDirection.y) > 0 || Math.abs(this.cameraDirection.z) > 0;\r\n };\r\n /** @hidden */\r\n TargetCamera.prototype._updatePosition = function () {\r\n if (this.parent) {\r\n this.parent.getWorldMatrix().invertToRef(TmpVectors.Matrix[0]);\r\n Vector3.TransformNormalToRef(this.cameraDirection, TmpVectors.Matrix[0], TmpVectors.Vector3[0]);\r\n this.position.addInPlace(TmpVectors.Vector3[0]);\r\n return;\r\n }\r\n this.position.addInPlace(this.cameraDirection);\r\n };\r\n /** @hidden */\r\n TargetCamera.prototype._checkInputs = function () {\r\n var needToMove = this._decideIfNeedsToMove();\r\n var needToRotate = Math.abs(this.cameraRotation.x) > 0 || Math.abs(this.cameraRotation.y) > 0;\r\n // Move\r\n if (needToMove) {\r\n this._updatePosition();\r\n }\r\n // Rotate\r\n if (needToRotate) {\r\n this.rotation.x += this.cameraRotation.x;\r\n this.rotation.y += this.cameraRotation.y;\r\n //rotate, if quaternion is set and rotation was used\r\n if (this.rotationQuaternion) {\r\n var len = this.rotation.lengthSquared();\r\n if (len) {\r\n Quaternion.RotationYawPitchRollToRef(this.rotation.y, this.rotation.x, this.rotation.z, this.rotationQuaternion);\r\n }\r\n }\r\n if (!this.noRotationConstraint) {\r\n var limit = 1.570796;\r\n if (this.rotation.x > limit) {\r\n this.rotation.x = limit;\r\n }\r\n if (this.rotation.x < -limit) {\r\n this.rotation.x = -limit;\r\n }\r\n }\r\n }\r\n // Inertia\r\n if (needToMove) {\r\n if (Math.abs(this.cameraDirection.x) < this.speed * Epsilon) {\r\n this.cameraDirection.x = 0;\r\n }\r\n if (Math.abs(this.cameraDirection.y) < this.speed * Epsilon) {\r\n this.cameraDirection.y = 0;\r\n }\r\n if (Math.abs(this.cameraDirection.z) < this.speed * Epsilon) {\r\n this.cameraDirection.z = 0;\r\n }\r\n this.cameraDirection.scaleInPlace(this.inertia);\r\n }\r\n if (needToRotate) {\r\n if (Math.abs(this.cameraRotation.x) < this.speed * Epsilon) {\r\n this.cameraRotation.x = 0;\r\n }\r\n if (Math.abs(this.cameraRotation.y) < this.speed * Epsilon) {\r\n this.cameraRotation.y = 0;\r\n }\r\n this.cameraRotation.scaleInPlace(this.inertia);\r\n }\r\n _super.prototype._checkInputs.call(this);\r\n };\r\n TargetCamera.prototype._updateCameraRotationMatrix = function () {\r\n if (this.rotationQuaternion) {\r\n this.rotationQuaternion.toRotationMatrix(this._cameraRotationMatrix);\r\n }\r\n else {\r\n Matrix.RotationYawPitchRollToRef(this.rotation.y, this.rotation.x, this.rotation.z, this._cameraRotationMatrix);\r\n }\r\n };\r\n /**\r\n * Update the up vector to apply the rotation of the camera (So if you changed the camera rotation.z this will let you update the up vector as well)\r\n * @returns the current camera\r\n */\r\n TargetCamera.prototype._rotateUpVectorWithCameraRotationMatrix = function () {\r\n Vector3.TransformNormalToRef(this._defaultUp, this._cameraRotationMatrix, this.upVector);\r\n return this;\r\n };\r\n /** @hidden */\r\n TargetCamera.prototype._getViewMatrix = function () {\r\n if (this.lockedTarget) {\r\n this.setTarget(this._getLockedTargetPosition());\r\n }\r\n // Compute\r\n this._updateCameraRotationMatrix();\r\n // Apply the changed rotation to the upVector\r\n if (this.rotationQuaternion && this._cachedQuaternionRotationZ != this.rotationQuaternion.z) {\r\n this._rotateUpVectorWithCameraRotationMatrix();\r\n this._cachedQuaternionRotationZ = this.rotationQuaternion.z;\r\n }\r\n else if (this._cachedRotationZ != this.rotation.z) {\r\n this._rotateUpVectorWithCameraRotationMatrix();\r\n this._cachedRotationZ = this.rotation.z;\r\n }\r\n Vector3.TransformCoordinatesToRef(this._referencePoint, this._cameraRotationMatrix, this._transformedReferencePoint);\r\n // Computing target and final matrix\r\n this.position.addToRef(this._transformedReferencePoint, this._currentTarget);\r\n if (this.updateUpVectorFromRotation) {\r\n if (this.rotationQuaternion) {\r\n Axis.Y.rotateByQuaternionToRef(this.rotationQuaternion, this.upVector);\r\n }\r\n else {\r\n Quaternion.FromEulerVectorToRef(this.rotation, this._tmpQuaternion);\r\n Axis.Y.rotateByQuaternionToRef(this._tmpQuaternion, this.upVector);\r\n }\r\n }\r\n this._computeViewMatrix(this.position, this._currentTarget, this.upVector);\r\n return this._viewMatrix;\r\n };\r\n TargetCamera.prototype._computeViewMatrix = function (position, target, up) {\r\n if (this.parent) {\r\n var parentWorldMatrix = this.parent.getWorldMatrix();\r\n Vector3.TransformCoordinatesToRef(position, parentWorldMatrix, this._globalPosition);\r\n Vector3.TransformCoordinatesToRef(target, parentWorldMatrix, this._globalCurrentTarget);\r\n Vector3.TransformNormalToRef(up, parentWorldMatrix, this._globalCurrentUpVector);\r\n this._markSyncedWithParent();\r\n }\r\n else {\r\n this._globalPosition.copyFrom(position);\r\n this._globalCurrentTarget.copyFrom(target);\r\n this._globalCurrentUpVector.copyFrom(up);\r\n }\r\n if (this.getScene().useRightHandedSystem) {\r\n Matrix.LookAtRHToRef(this._globalPosition, this._globalCurrentTarget, this._globalCurrentUpVector, this._viewMatrix);\r\n }\r\n else {\r\n Matrix.LookAtLHToRef(this._globalPosition, this._globalCurrentTarget, this._globalCurrentUpVector, this._viewMatrix);\r\n }\r\n };\r\n /**\r\n * @hidden\r\n */\r\n TargetCamera.prototype.createRigCamera = function (name, cameraIndex) {\r\n if (this.cameraRigMode !== Camera.RIG_MODE_NONE) {\r\n var rigCamera = new TargetCamera(name, this.position.clone(), this.getScene());\r\n rigCamera.isRigCamera = true;\r\n rigCamera.rigParent = this;\r\n if (this.cameraRigMode === Camera.RIG_MODE_VR || this.cameraRigMode === Camera.RIG_MODE_WEBVR) {\r\n if (!this.rotationQuaternion) {\r\n this.rotationQuaternion = new Quaternion();\r\n }\r\n rigCamera._cameraRigParams = {};\r\n rigCamera.rotationQuaternion = new Quaternion();\r\n }\r\n return rigCamera;\r\n }\r\n return null;\r\n };\r\n /**\r\n * @hidden\r\n */\r\n TargetCamera.prototype._updateRigCameras = function () {\r\n var camLeft = this._rigCameras[0];\r\n var camRight = this._rigCameras[1];\r\n this.computeWorldMatrix();\r\n switch (this.cameraRigMode) {\r\n case Camera.RIG_MODE_STEREOSCOPIC_ANAGLYPH:\r\n case Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL:\r\n case Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED:\r\n case Camera.RIG_MODE_STEREOSCOPIC_OVERUNDER:\r\n case Camera.RIG_MODE_STEREOSCOPIC_INTERLACED:\r\n //provisionnaly using _cameraRigParams.stereoHalfAngle instead of calculations based on _cameraRigParams.interaxialDistance:\r\n var leftSign = (this.cameraRigMode === Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED) ? 1 : -1;\r\n var rightSign = (this.cameraRigMode === Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED) ? -1 : 1;\r\n this._getRigCamPositionAndTarget(this._cameraRigParams.stereoHalfAngle * leftSign, camLeft);\r\n this._getRigCamPositionAndTarget(this._cameraRigParams.stereoHalfAngle * rightSign, camRight);\r\n break;\r\n case Camera.RIG_MODE_VR:\r\n if (camLeft.rotationQuaternion) {\r\n camLeft.rotationQuaternion.copyFrom(this.rotationQuaternion);\r\n camRight.rotationQuaternion.copyFrom(this.rotationQuaternion);\r\n }\r\n else {\r\n camLeft.rotation.copyFrom(this.rotation);\r\n camRight.rotation.copyFrom(this.rotation);\r\n }\r\n camLeft.position.copyFrom(this.position);\r\n camRight.position.copyFrom(this.position);\r\n break;\r\n }\r\n _super.prototype._updateRigCameras.call(this);\r\n };\r\n TargetCamera.prototype._getRigCamPositionAndTarget = function (halfSpace, rigCamera) {\r\n var target = this.getTarget();\r\n target.subtractToRef(this.position, TargetCamera._TargetFocalPoint);\r\n TargetCamera._TargetFocalPoint.normalize().scaleInPlace(this._initialFocalDistance);\r\n var newFocalTarget = TargetCamera._TargetFocalPoint.addInPlace(this.position);\r\n Matrix.TranslationToRef(-newFocalTarget.x, -newFocalTarget.y, -newFocalTarget.z, TargetCamera._TargetTransformMatrix);\r\n TargetCamera._TargetTransformMatrix.multiplyToRef(Matrix.RotationY(halfSpace), TargetCamera._RigCamTransformMatrix);\r\n Matrix.TranslationToRef(newFocalTarget.x, newFocalTarget.y, newFocalTarget.z, TargetCamera._TargetTransformMatrix);\r\n TargetCamera._RigCamTransformMatrix.multiplyToRef(TargetCamera._TargetTransformMatrix, TargetCamera._RigCamTransformMatrix);\r\n Vector3.TransformCoordinatesToRef(this.position, TargetCamera._RigCamTransformMatrix, rigCamera.position);\r\n rigCamera.setTarget(newFocalTarget);\r\n };\r\n /**\r\n * Gets the current object class name.\r\n * @return the class name\r\n */\r\n TargetCamera.prototype.getClassName = function () {\r\n return \"TargetCamera\";\r\n };\r\n TargetCamera._RigCamTransformMatrix = new Matrix();\r\n TargetCamera._TargetTransformMatrix = new Matrix();\r\n TargetCamera._TargetFocalPoint = new Vector3();\r\n __decorate([\r\n serializeAsVector3()\r\n ], TargetCamera.prototype, \"rotation\", void 0);\r\n __decorate([\r\n serialize()\r\n ], TargetCamera.prototype, \"speed\", void 0);\r\n __decorate([\r\n serializeAsMeshReference(\"lockedTargetId\")\r\n ], TargetCamera.prototype, \"lockedTarget\", void 0);\r\n return TargetCamera;\r\n}(Camera));\r\nexport { TargetCamera };\r\n//# sourceMappingURL=targetCamera.js.map","import { Logger } from \"../Misc/logger\";\r\nimport { SerializationHelper } from \"../Misc/decorators\";\r\nimport { Camera } from \"./camera\";\r\n/**\r\n * @ignore\r\n * This is a list of all the different input types that are available in the application.\r\n * Fo instance: ArcRotateCameraGamepadInput...\r\n */\r\nexport var CameraInputTypes = {};\r\n/**\r\n * This represents the input manager used within a camera.\r\n * It helps dealing with all the different kind of input attached to a camera.\r\n * @see http://doc.babylonjs.com/how_to/customizing_camera_inputs\r\n */\r\nvar CameraInputsManager = /** @class */ (function () {\r\n /**\r\n * Instantiate a new Camera Input Manager.\r\n * @param camera Defines the camera the input manager blongs to\r\n */\r\n function CameraInputsManager(camera) {\r\n this.attached = {};\r\n this.camera = camera;\r\n this.checkInputs = function () { };\r\n }\r\n /**\r\n * Add an input method to a camera\r\n * @see http://doc.babylonjs.com/how_to/customizing_camera_inputs\r\n * @param input camera input method\r\n */\r\n CameraInputsManager.prototype.add = function (input) {\r\n var type = input.getSimpleName();\r\n if (this.attached[type]) {\r\n Logger.Warn(\"camera input of type \" + type + \" already exists on camera\");\r\n return;\r\n }\r\n this.attached[type] = input;\r\n input.camera = this.camera;\r\n //for checkInputs, we are dynamically creating a function\r\n //the goal is to avoid the performance penalty of looping for inputs in the render loop\r\n if (input.checkInputs) {\r\n this.checkInputs = this._addCheckInputs(input.checkInputs.bind(input));\r\n }\r\n if (this.attachedElement) {\r\n input.attachControl(this.attachedElement);\r\n }\r\n };\r\n /**\r\n * Remove a specific input method from a camera\r\n * example: camera.inputs.remove(camera.inputs.attached.mouse);\r\n * @param inputToRemove camera input method\r\n */\r\n CameraInputsManager.prototype.remove = function (inputToRemove) {\r\n for (var cam in this.attached) {\r\n var input = this.attached[cam];\r\n if (input === inputToRemove) {\r\n input.detachControl(this.attachedElement);\r\n input.camera = null;\r\n delete this.attached[cam];\r\n this.rebuildInputCheck();\r\n }\r\n }\r\n };\r\n /**\r\n * Remove a specific input type from a camera\r\n * example: camera.inputs.remove(\"ArcRotateCameraGamepadInput\");\r\n * @param inputType the type of the input to remove\r\n */\r\n CameraInputsManager.prototype.removeByType = function (inputType) {\r\n for (var cam in this.attached) {\r\n var input = this.attached[cam];\r\n if (input.getClassName() === inputType) {\r\n input.detachControl(this.attachedElement);\r\n input.camera = null;\r\n delete this.attached[cam];\r\n this.rebuildInputCheck();\r\n }\r\n }\r\n };\r\n CameraInputsManager.prototype._addCheckInputs = function (fn) {\r\n var current = this.checkInputs;\r\n return function () {\r\n current();\r\n fn();\r\n };\r\n };\r\n /**\r\n * Attach the input controls to the currently attached dom element to listen the events from.\r\n * @param input Defines the input to attach\r\n */\r\n CameraInputsManager.prototype.attachInput = function (input) {\r\n if (this.attachedElement) {\r\n input.attachControl(this.attachedElement, this.noPreventDefault);\r\n }\r\n };\r\n /**\r\n * Attach the current manager inputs controls to a specific dom element to listen the events from.\r\n * @param element Defines the dom element to collect the events from\r\n * @param noPreventDefault Defines whether event caught by the controls should call preventdefault() (https://developer.mozilla.org/en-US/docs/Web/API/Event/preventDefault)\r\n */\r\n CameraInputsManager.prototype.attachElement = function (element, noPreventDefault) {\r\n if (noPreventDefault === void 0) { noPreventDefault = false; }\r\n if (this.attachedElement) {\r\n return;\r\n }\r\n noPreventDefault = Camera.ForceAttachControlToAlwaysPreventDefault ? false : noPreventDefault;\r\n this.attachedElement = element;\r\n this.noPreventDefault = noPreventDefault;\r\n for (var cam in this.attached) {\r\n this.attached[cam].attachControl(element, noPreventDefault);\r\n }\r\n };\r\n /**\r\n * Detach the current manager inputs controls from a specific dom element.\r\n * @param element Defines the dom element to collect the events from\r\n * @param disconnect Defines whether the input should be removed from the current list of attached inputs\r\n */\r\n CameraInputsManager.prototype.detachElement = function (element, disconnect) {\r\n if (disconnect === void 0) { disconnect = false; }\r\n if (this.attachedElement !== element) {\r\n return;\r\n }\r\n for (var cam in this.attached) {\r\n this.attached[cam].detachControl(element);\r\n if (disconnect) {\r\n this.attached[cam].camera = null;\r\n }\r\n }\r\n this.attachedElement = null;\r\n };\r\n /**\r\n * Rebuild the dynamic inputCheck function from the current list of\r\n * defined inputs in the manager.\r\n */\r\n CameraInputsManager.prototype.rebuildInputCheck = function () {\r\n this.checkInputs = function () { };\r\n for (var cam in this.attached) {\r\n var input = this.attached[cam];\r\n if (input.checkInputs) {\r\n this.checkInputs = this._addCheckInputs(input.checkInputs.bind(input));\r\n }\r\n }\r\n };\r\n /**\r\n * Remove all attached input methods from a camera\r\n */\r\n CameraInputsManager.prototype.clear = function () {\r\n if (this.attachedElement) {\r\n this.detachElement(this.attachedElement, true);\r\n }\r\n this.attached = {};\r\n this.attachedElement = null;\r\n this.checkInputs = function () { };\r\n };\r\n /**\r\n * Serialize the current input manager attached to a camera.\r\n * This ensures than once parsed,\r\n * the input associated to the camera will be identical to the current ones\r\n * @param serializedCamera Defines the camera serialization JSON the input serialization should write to\r\n */\r\n CameraInputsManager.prototype.serialize = function (serializedCamera) {\r\n var inputs = {};\r\n for (var cam in this.attached) {\r\n var input = this.attached[cam];\r\n var res = SerializationHelper.Serialize(input);\r\n inputs[input.getClassName()] = res;\r\n }\r\n serializedCamera.inputsmgr = inputs;\r\n };\r\n /**\r\n * Parses an input manager serialized JSON to restore the previous list of inputs\r\n * and states associated to a camera.\r\n * @param parsedCamera Defines the JSON to parse\r\n */\r\n CameraInputsManager.prototype.parse = function (parsedCamera) {\r\n var parsedInputs = parsedCamera.inputsmgr;\r\n if (parsedInputs) {\r\n this.clear();\r\n for (var n in parsedInputs) {\r\n var construct = CameraInputTypes[n];\r\n if (construct) {\r\n var parsedinput = parsedInputs[n];\r\n var input = SerializationHelper.Parse(function () { return new construct(); }, parsedinput, null);\r\n this.add(input);\r\n }\r\n }\r\n }\r\n else {\r\n //2016-03-08 this part is for managing backward compatibility\r\n for (var n in this.attached) {\r\n var construct = CameraInputTypes[this.attached[n].getClassName()];\r\n if (construct) {\r\n var input = SerializationHelper.Parse(function () { return new construct(); }, parsedCamera, null);\r\n this.remove(this.attached[n]);\r\n this.add(input);\r\n }\r\n }\r\n }\r\n };\r\n return CameraInputsManager;\r\n}());\r\nexport { CameraInputsManager };\r\n//# sourceMappingURL=cameraInputsManager.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize } from \"../../Misc/decorators\";\r\nimport { CameraInputTypes } from \"../../Cameras/cameraInputsManager\";\r\nimport { BaseCameraPointersInput } from \"../../Cameras/Inputs/BaseCameraPointersInput\";\r\n/**\r\n * Manage the pointers inputs to control an arc rotate camera.\r\n * @see http://doc.babylonjs.com/how_to/customizing_camera_inputs\r\n */\r\nvar ArcRotateCameraPointersInput = /** @class */ (function (_super) {\r\n __extends(ArcRotateCameraPointersInput, _super);\r\n function ArcRotateCameraPointersInput() {\r\n var _this = _super !== null && _super.apply(this, arguments) || this;\r\n /**\r\n * Defines the buttons associated with the input to handle camera move.\r\n */\r\n _this.buttons = [0, 1, 2];\r\n /**\r\n * Defines the pointer angular sensibility along the X axis or how fast is\r\n * the camera rotating.\r\n */\r\n _this.angularSensibilityX = 1000.0;\r\n /**\r\n * Defines the pointer angular sensibility along the Y axis or how fast is\r\n * the camera rotating.\r\n */\r\n _this.angularSensibilityY = 1000.0;\r\n /**\r\n * Defines the pointer pinch precision or how fast is the camera zooming.\r\n */\r\n _this.pinchPrecision = 12.0;\r\n /**\r\n * pinchDeltaPercentage will be used instead of pinchPrecision if different\r\n * from 0.\r\n * It defines the percentage of current camera.radius to use as delta when\r\n * pinch zoom is used.\r\n */\r\n _this.pinchDeltaPercentage = 0;\r\n /**\r\n * When useNaturalPinchZoom is true, multi touch zoom will zoom in such\r\n * that any object in the plane at the camera's target point will scale\r\n * perfectly with finger motion.\r\n * Overrides pinchDeltaPercentage and pinchPrecision.\r\n */\r\n _this.useNaturalPinchZoom = false;\r\n /**\r\n * Defines the pointer panning sensibility or how fast is the camera moving.\r\n */\r\n _this.panningSensibility = 1000.0;\r\n /**\r\n * Defines whether panning (2 fingers swipe) is enabled through multitouch.\r\n */\r\n _this.multiTouchPanning = true;\r\n /**\r\n * Defines whether panning is enabled for both pan (2 fingers swipe) and\r\n * zoom (pinch) through multitouch.\r\n */\r\n _this.multiTouchPanAndZoom = true;\r\n /**\r\n * Revers pinch action direction.\r\n */\r\n _this.pinchInwards = true;\r\n _this._isPanClick = false;\r\n _this._twoFingerActivityCount = 0;\r\n _this._isPinching = false;\r\n return _this;\r\n }\r\n /**\r\n * Gets the class name of the current input.\r\n * @returns the class name\r\n */\r\n ArcRotateCameraPointersInput.prototype.getClassName = function () {\r\n return \"ArcRotateCameraPointersInput\";\r\n };\r\n /**\r\n * Called on pointer POINTERMOVE event if only a single touch is active.\r\n */\r\n ArcRotateCameraPointersInput.prototype.onTouch = function (point, offsetX, offsetY) {\r\n if (this.panningSensibility !== 0 &&\r\n ((this._ctrlKey && this.camera._useCtrlForPanning) || this._isPanClick)) {\r\n this.camera.inertialPanningX += -offsetX / this.panningSensibility;\r\n this.camera.inertialPanningY += offsetY / this.panningSensibility;\r\n }\r\n else {\r\n this.camera.inertialAlphaOffset -= offsetX / this.angularSensibilityX;\r\n this.camera.inertialBetaOffset -= offsetY / this.angularSensibilityY;\r\n }\r\n };\r\n /**\r\n * Called on pointer POINTERDOUBLETAP event.\r\n */\r\n ArcRotateCameraPointersInput.prototype.onDoubleTap = function (type) {\r\n if (this.camera.useInputToRestoreState) {\r\n this.camera.restoreState();\r\n }\r\n };\r\n /**\r\n * Called on pointer POINTERMOVE event if multiple touches are active.\r\n */\r\n ArcRotateCameraPointersInput.prototype.onMultiTouch = function (pointA, pointB, previousPinchSquaredDistance, pinchSquaredDistance, previousMultiTouchPanPosition, multiTouchPanPosition) {\r\n if (previousPinchSquaredDistance === 0 && previousMultiTouchPanPosition === null) {\r\n // First time this method is called for new pinch.\r\n // Next time this is called there will be a\r\n // previousPinchSquaredDistance and pinchSquaredDistance to compare.\r\n return;\r\n }\r\n if (pinchSquaredDistance === 0 && multiTouchPanPosition === null) {\r\n // Last time this method is called at the end of a pinch.\r\n return;\r\n }\r\n var direction = this.pinchInwards ? 1 : -1;\r\n if (this.multiTouchPanAndZoom) {\r\n if (this.useNaturalPinchZoom) {\r\n this.camera.radius = this.camera.radius *\r\n Math.sqrt(previousPinchSquaredDistance) / Math.sqrt(pinchSquaredDistance);\r\n }\r\n else if (this.pinchDeltaPercentage) {\r\n this.camera.inertialRadiusOffset +=\r\n (pinchSquaredDistance - previousPinchSquaredDistance) * 0.001 *\r\n this.camera.radius * this.pinchDeltaPercentage;\r\n }\r\n else {\r\n this.camera.inertialRadiusOffset +=\r\n (pinchSquaredDistance - previousPinchSquaredDistance) /\r\n (this.pinchPrecision * direction *\r\n (this.angularSensibilityX + this.angularSensibilityY) / 2);\r\n }\r\n if (this.panningSensibility !== 0 &&\r\n previousMultiTouchPanPosition && multiTouchPanPosition) {\r\n var moveDeltaX = multiTouchPanPosition.x - previousMultiTouchPanPosition.x;\r\n var moveDeltaY = multiTouchPanPosition.y - previousMultiTouchPanPosition.y;\r\n this.camera.inertialPanningX += -moveDeltaX / this.panningSensibility;\r\n this.camera.inertialPanningY += moveDeltaY / this.panningSensibility;\r\n }\r\n }\r\n else {\r\n this._twoFingerActivityCount++;\r\n var previousPinchDistance = Math.sqrt(previousPinchSquaredDistance);\r\n var pinchDistance = Math.sqrt(pinchSquaredDistance);\r\n if (this._isPinching ||\r\n (this._twoFingerActivityCount < 20 &&\r\n Math.abs(pinchDistance - previousPinchDistance) >\r\n this.camera.pinchToPanMaxDistance)) {\r\n // Since pinch has not been active long, assume we intend to zoom.\r\n if (this.pinchDeltaPercentage) {\r\n this.camera.inertialRadiusOffset +=\r\n (pinchSquaredDistance - previousPinchSquaredDistance) * 0.001 *\r\n this.camera.radius * this.pinchDeltaPercentage;\r\n }\r\n else {\r\n this.camera.inertialRadiusOffset +=\r\n (pinchSquaredDistance - previousPinchSquaredDistance) /\r\n (this.pinchPrecision * direction *\r\n (this.angularSensibilityX + this.angularSensibilityY) / 2);\r\n }\r\n // Since we are pinching, remain pinching on next iteration.\r\n this._isPinching = true;\r\n }\r\n else {\r\n // Pause between pinch starting and moving implies not a zoom event.\r\n // Pan instead.\r\n if (this.panningSensibility !== 0 && this.multiTouchPanning &&\r\n multiTouchPanPosition && previousMultiTouchPanPosition) {\r\n var moveDeltaX = multiTouchPanPosition.x - previousMultiTouchPanPosition.x;\r\n var moveDeltaY = multiTouchPanPosition.y - previousMultiTouchPanPosition.y;\r\n this.camera.inertialPanningX += -moveDeltaX / this.panningSensibility;\r\n this.camera.inertialPanningY += moveDeltaY / this.panningSensibility;\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Called each time a new POINTERDOWN event occurs. Ie, for each button\r\n * press.\r\n */\r\n ArcRotateCameraPointersInput.prototype.onButtonDown = function (evt) {\r\n this._isPanClick = evt.button === this.camera._panningMouseButton;\r\n };\r\n /**\r\n * Called each time a new POINTERUP event occurs. Ie, for each button\r\n * release.\r\n */\r\n ArcRotateCameraPointersInput.prototype.onButtonUp = function (evt) {\r\n this._twoFingerActivityCount = 0;\r\n this._isPinching = false;\r\n };\r\n /**\r\n * Called when window becomes inactive.\r\n */\r\n ArcRotateCameraPointersInput.prototype.onLostFocus = function () {\r\n this._isPanClick = false;\r\n this._twoFingerActivityCount = 0;\r\n this._isPinching = false;\r\n };\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"buttons\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"angularSensibilityX\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"angularSensibilityY\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"pinchPrecision\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"pinchDeltaPercentage\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"useNaturalPinchZoom\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"panningSensibility\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"multiTouchPanning\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"multiTouchPanAndZoom\", void 0);\r\n return ArcRotateCameraPointersInput;\r\n}(BaseCameraPointersInput));\r\nexport { ArcRotateCameraPointersInput };\r\nCameraInputTypes[\"ArcRotateCameraPointersInput\"] =\r\n ArcRotateCameraPointersInput;\r\n//# sourceMappingURL=arcRotateCameraPointersInput.js.map","import { __decorate } from \"tslib\";\r\nimport { serialize } from \"../../Misc/decorators\";\r\nimport { Tools } from \"../../Misc/tools\";\r\nimport { PointerEventTypes } from \"../../Events/pointerEvents\";\r\n/**\r\n * Base class for Camera Pointer Inputs.\r\n * See FollowCameraPointersInput in src/Cameras/Inputs/followCameraPointersInput.ts\r\n * for example usage.\r\n */\r\nvar BaseCameraPointersInput = /** @class */ (function () {\r\n function BaseCameraPointersInput() {\r\n /**\r\n * Defines the buttons associated with the input to handle camera move.\r\n */\r\n this.buttons = [0, 1, 2];\r\n }\r\n /**\r\n * Attach the input controls to a specific dom element to get the input from.\r\n * @param element Defines the element the controls should be listened from\r\n * @param noPreventDefault Defines whether event caught by the controls should call preventdefault() (https://developer.mozilla.org/en-US/docs/Web/API/Event/preventDefault)\r\n */\r\n BaseCameraPointersInput.prototype.attachControl = function (element, noPreventDefault) {\r\n var _this = this;\r\n var engine = this.camera.getEngine();\r\n var previousPinchSquaredDistance = 0;\r\n var previousMultiTouchPanPosition = null;\r\n this.pointA = null;\r\n this.pointB = null;\r\n this._altKey = false;\r\n this._ctrlKey = false;\r\n this._metaKey = false;\r\n this._shiftKey = false;\r\n this._buttonsPressed = 0;\r\n this._pointerInput = function (p, s) {\r\n var evt = p.event;\r\n var isTouch = evt.pointerType === \"touch\";\r\n if (engine.isInVRExclusivePointerMode) {\r\n return;\r\n }\r\n if (p.type !== PointerEventTypes.POINTERMOVE &&\r\n _this.buttons.indexOf(evt.button) === -1) {\r\n return;\r\n }\r\n var srcElement = (evt.srcElement || evt.target);\r\n _this._altKey = evt.altKey;\r\n _this._ctrlKey = evt.ctrlKey;\r\n _this._metaKey = evt.metaKey;\r\n _this._shiftKey = evt.shiftKey;\r\n _this._buttonsPressed = evt.buttons;\r\n if (engine.isPointerLock) {\r\n var offsetX = evt.movementX ||\r\n evt.mozMovementX ||\r\n evt.webkitMovementX ||\r\n evt.msMovementX ||\r\n 0;\r\n var offsetY = evt.movementY ||\r\n evt.mozMovementY ||\r\n evt.webkitMovementY ||\r\n evt.msMovementY ||\r\n 0;\r\n _this.onTouch(null, offsetX, offsetY);\r\n _this.pointA = null;\r\n _this.pointB = null;\r\n }\r\n else if (p.type === PointerEventTypes.POINTERDOWN && srcElement) {\r\n try {\r\n srcElement.setPointerCapture(evt.pointerId);\r\n }\r\n catch (e) {\r\n //Nothing to do with the error. Execution will continue.\r\n }\r\n if (_this.pointA === null) {\r\n _this.pointA = { x: evt.clientX,\r\n y: evt.clientY,\r\n pointerId: evt.pointerId,\r\n type: evt.pointerType };\r\n }\r\n else if (_this.pointB === null) {\r\n _this.pointB = { x: evt.clientX,\r\n y: evt.clientY,\r\n pointerId: evt.pointerId,\r\n type: evt.pointerType };\r\n }\r\n _this.onButtonDown(evt);\r\n if (!noPreventDefault) {\r\n evt.preventDefault();\r\n element.focus();\r\n }\r\n }\r\n else if (p.type === PointerEventTypes.POINTERDOUBLETAP) {\r\n _this.onDoubleTap(evt.pointerType);\r\n }\r\n else if (p.type === PointerEventTypes.POINTERUP && srcElement) {\r\n try {\r\n srcElement.releasePointerCapture(evt.pointerId);\r\n }\r\n catch (e) {\r\n //Nothing to do with the error.\r\n }\r\n if (!isTouch) {\r\n _this.pointB = null; // Mouse and pen are mono pointer\r\n }\r\n //would be better to use pointers.remove(evt.pointerId) for multitouch gestures,\r\n //but emptying completely pointers collection is required to fix a bug on iPhone :\r\n //when changing orientation while pinching camera,\r\n //one pointer stay pressed forever if we don't release all pointers\r\n //will be ok to put back pointers.remove(evt.pointerId); when iPhone bug corrected\r\n if (engine._badOS) {\r\n _this.pointA = _this.pointB = null;\r\n }\r\n else {\r\n //only remove the impacted pointer in case of multitouch allowing on most\r\n //platforms switching from rotate to zoom and pan seamlessly.\r\n if (_this.pointB && _this.pointA && _this.pointA.pointerId == evt.pointerId) {\r\n _this.pointA = _this.pointB;\r\n _this.pointB = null;\r\n }\r\n else if (_this.pointA && _this.pointB &&\r\n _this.pointB.pointerId == evt.pointerId) {\r\n _this.pointB = null;\r\n }\r\n else {\r\n _this.pointA = _this.pointB = null;\r\n }\r\n }\r\n if (previousPinchSquaredDistance !== 0 || previousMultiTouchPanPosition) {\r\n // Previous pinch data is populated but a button has been lifted\r\n // so pinch has ended.\r\n _this.onMultiTouch(_this.pointA, _this.pointB, previousPinchSquaredDistance, 0, // pinchSquaredDistance\r\n previousMultiTouchPanPosition, null // multiTouchPanPosition\r\n );\r\n previousPinchSquaredDistance = 0;\r\n previousMultiTouchPanPosition = null;\r\n }\r\n _this.onButtonUp(evt);\r\n if (!noPreventDefault) {\r\n evt.preventDefault();\r\n }\r\n }\r\n else if (p.type === PointerEventTypes.POINTERMOVE) {\r\n if (!noPreventDefault) {\r\n evt.preventDefault();\r\n }\r\n // One button down\r\n if (_this.pointA && _this.pointB === null) {\r\n var offsetX = evt.clientX - _this.pointA.x;\r\n var offsetY = evt.clientY - _this.pointA.y;\r\n _this.onTouch(_this.pointA, offsetX, offsetY);\r\n _this.pointA.x = evt.clientX;\r\n _this.pointA.y = evt.clientY;\r\n }\r\n // Two buttons down: pinch\r\n else if (_this.pointA && _this.pointB) {\r\n var ed = (_this.pointA.pointerId === evt.pointerId) ?\r\n _this.pointA : _this.pointB;\r\n ed.x = evt.clientX;\r\n ed.y = evt.clientY;\r\n var distX = _this.pointA.x - _this.pointB.x;\r\n var distY = _this.pointA.y - _this.pointB.y;\r\n var pinchSquaredDistance = (distX * distX) + (distY * distY);\r\n var multiTouchPanPosition = { x: (_this.pointA.x + _this.pointB.x) / 2,\r\n y: (_this.pointA.y + _this.pointB.y) / 2,\r\n pointerId: evt.pointerId,\r\n type: p.type };\r\n _this.onMultiTouch(_this.pointA, _this.pointB, previousPinchSquaredDistance, pinchSquaredDistance, previousMultiTouchPanPosition, multiTouchPanPosition);\r\n previousMultiTouchPanPosition = multiTouchPanPosition;\r\n previousPinchSquaredDistance = pinchSquaredDistance;\r\n }\r\n }\r\n };\r\n this._observer = this.camera.getScene().onPointerObservable.add(this._pointerInput, PointerEventTypes.POINTERDOWN | PointerEventTypes.POINTERUP |\r\n PointerEventTypes.POINTERMOVE);\r\n this._onLostFocus = function () {\r\n _this.pointA = _this.pointB = null;\r\n previousPinchSquaredDistance = 0;\r\n previousMultiTouchPanPosition = null;\r\n _this.onLostFocus();\r\n };\r\n element.addEventListener(\"contextmenu\", this.onContextMenu.bind(this), false);\r\n var hostWindow = this.camera.getScene().getEngine().getHostWindow();\r\n if (hostWindow) {\r\n Tools.RegisterTopRootEvents(hostWindow, [\r\n { name: \"blur\", handler: this._onLostFocus }\r\n ]);\r\n }\r\n };\r\n /**\r\n * Detach the current controls from the specified dom element.\r\n * @param element Defines the element to stop listening the inputs from\r\n */\r\n BaseCameraPointersInput.prototype.detachControl = function (element) {\r\n if (this._onLostFocus) {\r\n var hostWindow = this.camera.getScene().getEngine().getHostWindow();\r\n if (hostWindow) {\r\n Tools.UnregisterTopRootEvents(hostWindow, [\r\n { name: \"blur\", handler: this._onLostFocus }\r\n ]);\r\n }\r\n }\r\n if (element && this._observer) {\r\n this.camera.getScene().onPointerObservable.remove(this._observer);\r\n this._observer = null;\r\n if (this.onContextMenu) {\r\n element.removeEventListener(\"contextmenu\", this.onContextMenu);\r\n }\r\n this._onLostFocus = null;\r\n }\r\n this._altKey = false;\r\n this._ctrlKey = false;\r\n this._metaKey = false;\r\n this._shiftKey = false;\r\n this._buttonsPressed = 0;\r\n };\r\n /**\r\n * Gets the class name of the current input.\r\n * @returns the class name\r\n */\r\n BaseCameraPointersInput.prototype.getClassName = function () {\r\n return \"BaseCameraPointersInput\";\r\n };\r\n /**\r\n * Get the friendly name associated with the input class.\r\n * @returns the input friendly name\r\n */\r\n BaseCameraPointersInput.prototype.getSimpleName = function () {\r\n return \"pointers\";\r\n };\r\n /**\r\n * Called on pointer POINTERDOUBLETAP event.\r\n * Override this method to provide functionality on POINTERDOUBLETAP event.\r\n */\r\n BaseCameraPointersInput.prototype.onDoubleTap = function (type) {\r\n };\r\n /**\r\n * Called on pointer POINTERMOVE event if only a single touch is active.\r\n * Override this method to provide functionality.\r\n */\r\n BaseCameraPointersInput.prototype.onTouch = function (point, offsetX, offsetY) {\r\n };\r\n /**\r\n * Called on pointer POINTERMOVE event if multiple touches are active.\r\n * Override this method to provide functionality.\r\n */\r\n BaseCameraPointersInput.prototype.onMultiTouch = function (pointA, pointB, previousPinchSquaredDistance, pinchSquaredDistance, previousMultiTouchPanPosition, multiTouchPanPosition) {\r\n };\r\n /**\r\n * Called on JS contextmenu event.\r\n * Override this method to provide functionality.\r\n */\r\n BaseCameraPointersInput.prototype.onContextMenu = function (evt) {\r\n evt.preventDefault();\r\n };\r\n /**\r\n * Called each time a new POINTERDOWN event occurs. Ie, for each button\r\n * press.\r\n * Override this method to provide functionality.\r\n */\r\n BaseCameraPointersInput.prototype.onButtonDown = function (evt) {\r\n };\r\n /**\r\n * Called each time a new POINTERUP event occurs. Ie, for each button\r\n * release.\r\n * Override this method to provide functionality.\r\n */\r\n BaseCameraPointersInput.prototype.onButtonUp = function (evt) {\r\n };\r\n /**\r\n * Called when window becomes inactive.\r\n * Override this method to provide functionality.\r\n */\r\n BaseCameraPointersInput.prototype.onLostFocus = function () {\r\n };\r\n __decorate([\r\n serialize()\r\n ], BaseCameraPointersInput.prototype, \"buttons\", void 0);\r\n return BaseCameraPointersInput;\r\n}());\r\nexport { BaseCameraPointersInput };\r\n//# sourceMappingURL=BaseCameraPointersInput.js.map","import { __decorate } from \"tslib\";\r\nimport { serialize } from \"../../Misc/decorators\";\r\nimport { CameraInputTypes } from \"../../Cameras/cameraInputsManager\";\r\nimport { KeyboardEventTypes } from \"../../Events/keyboardEvents\";\r\n/**\r\n * Manage the keyboard inputs to control the movement of an arc rotate camera.\r\n * @see http://doc.babylonjs.com/how_to/customizing_camera_inputs\r\n */\r\nvar ArcRotateCameraKeyboardMoveInput = /** @class */ (function () {\r\n function ArcRotateCameraKeyboardMoveInput() {\r\n /**\r\n * Defines the list of key codes associated with the up action (increase alpha)\r\n */\r\n this.keysUp = [38];\r\n /**\r\n * Defines the list of key codes associated with the down action (decrease alpha)\r\n */\r\n this.keysDown = [40];\r\n /**\r\n * Defines the list of key codes associated with the left action (increase beta)\r\n */\r\n this.keysLeft = [37];\r\n /**\r\n * Defines the list of key codes associated with the right action (decrease beta)\r\n */\r\n this.keysRight = [39];\r\n /**\r\n * Defines the list of key codes associated with the reset action.\r\n * Those keys reset the camera to its last stored state (with the method camera.storeState())\r\n */\r\n this.keysReset = [220];\r\n /**\r\n * Defines the panning sensibility of the inputs.\r\n * (How fast is the camera panning)\r\n */\r\n this.panningSensibility = 50.0;\r\n /**\r\n * Defines the zooming sensibility of the inputs.\r\n * (How fast is the camera zooming)\r\n */\r\n this.zoomingSensibility = 25.0;\r\n /**\r\n * Defines whether maintaining the alt key down switch the movement mode from\r\n * orientation to zoom.\r\n */\r\n this.useAltToZoom = true;\r\n /**\r\n * Rotation speed of the camera\r\n */\r\n this.angularSpeed = 0.01;\r\n this._keys = new Array();\r\n }\r\n /**\r\n * Attach the input controls to a specific dom element to get the input from.\r\n * @param element Defines the element the controls should be listened from\r\n * @param noPreventDefault Defines whether event caught by the controls should call preventdefault() (https://developer.mozilla.org/en-US/docs/Web/API/Event/preventDefault)\r\n */\r\n ArcRotateCameraKeyboardMoveInput.prototype.attachControl = function (element, noPreventDefault) {\r\n var _this = this;\r\n if (this._onCanvasBlurObserver) {\r\n return;\r\n }\r\n this._scene = this.camera.getScene();\r\n this._engine = this._scene.getEngine();\r\n this._onCanvasBlurObserver = this._engine.onCanvasBlurObservable.add(function () {\r\n _this._keys = [];\r\n });\r\n this._onKeyboardObserver = this._scene.onKeyboardObservable.add(function (info) {\r\n var evt = info.event;\r\n if (!evt.metaKey) {\r\n if (info.type === KeyboardEventTypes.KEYDOWN) {\r\n _this._ctrlPressed = evt.ctrlKey;\r\n _this._altPressed = evt.altKey;\r\n if (_this.keysUp.indexOf(evt.keyCode) !== -1 ||\r\n _this.keysDown.indexOf(evt.keyCode) !== -1 ||\r\n _this.keysLeft.indexOf(evt.keyCode) !== -1 ||\r\n _this.keysRight.indexOf(evt.keyCode) !== -1 ||\r\n _this.keysReset.indexOf(evt.keyCode) !== -1) {\r\n var index = _this._keys.indexOf(evt.keyCode);\r\n if (index === -1) {\r\n _this._keys.push(evt.keyCode);\r\n }\r\n if (evt.preventDefault) {\r\n if (!noPreventDefault) {\r\n evt.preventDefault();\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n if (_this.keysUp.indexOf(evt.keyCode) !== -1 ||\r\n _this.keysDown.indexOf(evt.keyCode) !== -1 ||\r\n _this.keysLeft.indexOf(evt.keyCode) !== -1 ||\r\n _this.keysRight.indexOf(evt.keyCode) !== -1 ||\r\n _this.keysReset.indexOf(evt.keyCode) !== -1) {\r\n var index = _this._keys.indexOf(evt.keyCode);\r\n if (index >= 0) {\r\n _this._keys.splice(index, 1);\r\n }\r\n if (evt.preventDefault) {\r\n if (!noPreventDefault) {\r\n evt.preventDefault();\r\n }\r\n }\r\n }\r\n }\r\n }\r\n });\r\n };\r\n /**\r\n * Detach the current controls from the specified dom element.\r\n * @param element Defines the element to stop listening the inputs from\r\n */\r\n ArcRotateCameraKeyboardMoveInput.prototype.detachControl = function (element) {\r\n if (this._scene) {\r\n if (this._onKeyboardObserver) {\r\n this._scene.onKeyboardObservable.remove(this._onKeyboardObserver);\r\n }\r\n if (this._onCanvasBlurObserver) {\r\n this._engine.onCanvasBlurObservable.remove(this._onCanvasBlurObserver);\r\n }\r\n this._onKeyboardObserver = null;\r\n this._onCanvasBlurObserver = null;\r\n }\r\n this._keys = [];\r\n };\r\n /**\r\n * Update the current camera state depending on the inputs that have been used this frame.\r\n * This is a dynamically created lambda to avoid the performance penalty of looping for inputs in the render loop.\r\n */\r\n ArcRotateCameraKeyboardMoveInput.prototype.checkInputs = function () {\r\n if (this._onKeyboardObserver) {\r\n var camera = this.camera;\r\n for (var index = 0; index < this._keys.length; index++) {\r\n var keyCode = this._keys[index];\r\n if (this.keysLeft.indexOf(keyCode) !== -1) {\r\n if (this._ctrlPressed && this.camera._useCtrlForPanning) {\r\n camera.inertialPanningX -= 1 / this.panningSensibility;\r\n }\r\n else {\r\n camera.inertialAlphaOffset -= this.angularSpeed;\r\n }\r\n }\r\n else if (this.keysUp.indexOf(keyCode) !== -1) {\r\n if (this._ctrlPressed && this.camera._useCtrlForPanning) {\r\n camera.inertialPanningY += 1 / this.panningSensibility;\r\n }\r\n else if (this._altPressed && this.useAltToZoom) {\r\n camera.inertialRadiusOffset += 1 / this.zoomingSensibility;\r\n }\r\n else {\r\n camera.inertialBetaOffset -= this.angularSpeed;\r\n }\r\n }\r\n else if (this.keysRight.indexOf(keyCode) !== -1) {\r\n if (this._ctrlPressed && this.camera._useCtrlForPanning) {\r\n camera.inertialPanningX += 1 / this.panningSensibility;\r\n }\r\n else {\r\n camera.inertialAlphaOffset += this.angularSpeed;\r\n }\r\n }\r\n else if (this.keysDown.indexOf(keyCode) !== -1) {\r\n if (this._ctrlPressed && this.camera._useCtrlForPanning) {\r\n camera.inertialPanningY -= 1 / this.panningSensibility;\r\n }\r\n else if (this._altPressed && this.useAltToZoom) {\r\n camera.inertialRadiusOffset -= 1 / this.zoomingSensibility;\r\n }\r\n else {\r\n camera.inertialBetaOffset += this.angularSpeed;\r\n }\r\n }\r\n else if (this.keysReset.indexOf(keyCode) !== -1) {\r\n if (camera.useInputToRestoreState) {\r\n camera.restoreState();\r\n }\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Gets the class name of the current intput.\r\n * @returns the class name\r\n */\r\n ArcRotateCameraKeyboardMoveInput.prototype.getClassName = function () {\r\n return \"ArcRotateCameraKeyboardMoveInput\";\r\n };\r\n /**\r\n * Get the friendly name associated with the input class.\r\n * @returns the input friendly name\r\n */\r\n ArcRotateCameraKeyboardMoveInput.prototype.getSimpleName = function () {\r\n return \"keyboard\";\r\n };\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"keysUp\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"keysDown\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"keysLeft\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"keysRight\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"keysReset\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"panningSensibility\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"zoomingSensibility\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"useAltToZoom\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"angularSpeed\", void 0);\r\n return ArcRotateCameraKeyboardMoveInput;\r\n}());\r\nexport { ArcRotateCameraKeyboardMoveInput };\r\nCameraInputTypes[\"ArcRotateCameraKeyboardMoveInput\"] = ArcRotateCameraKeyboardMoveInput;\r\n//# sourceMappingURL=arcRotateCameraKeyboardMoveInput.js.map","import { __decorate } from \"tslib\";\r\nimport { serialize } from \"../../Misc/decorators\";\r\nimport { CameraInputTypes } from \"../../Cameras/cameraInputsManager\";\r\nimport { PointerEventTypes } from \"../../Events/pointerEvents\";\r\nimport { Scalar } from '../../Maths/math.scalar';\r\n/**\r\n * Manage the mouse wheel inputs to control an arc rotate camera.\r\n * @see http://doc.babylonjs.com/how_to/customizing_camera_inputs\r\n */\r\nvar ArcRotateCameraMouseWheelInput = /** @class */ (function () {\r\n function ArcRotateCameraMouseWheelInput() {\r\n /**\r\n * Gets or Set the mouse wheel precision or how fast is the camera zooming.\r\n */\r\n this.wheelPrecision = 3.0;\r\n /**\r\n * wheelDeltaPercentage will be used instead of wheelPrecision if different from 0.\r\n * It defines the percentage of current camera.radius to use as delta when wheel is used.\r\n */\r\n this.wheelDeltaPercentage = 0;\r\n }\r\n ArcRotateCameraMouseWheelInput.prototype.computeDeltaFromMouseWheelLegacyEvent = function (mouseWheelDelta, radius) {\r\n var delta = 0;\r\n var wheelDelta = (mouseWheelDelta * 0.01 * this.wheelDeltaPercentage) * radius;\r\n if (mouseWheelDelta > 0) {\r\n delta = wheelDelta / (1.0 + this.wheelDeltaPercentage);\r\n }\r\n else {\r\n delta = wheelDelta * (1.0 + this.wheelDeltaPercentage);\r\n }\r\n return delta;\r\n };\r\n /**\r\n * Attach the input controls to a specific dom element to get the input from.\r\n * @param element Defines the element the controls should be listened from\r\n * @param noPreventDefault Defines whether event caught by the controls should call preventdefault() (https://developer.mozilla.org/en-US/docs/Web/API/Event/preventDefault)\r\n */\r\n ArcRotateCameraMouseWheelInput.prototype.attachControl = function (element, noPreventDefault) {\r\n var _this = this;\r\n this._wheel = function (p, s) {\r\n //sanity check - this should be a PointerWheel event.\r\n if (p.type !== PointerEventTypes.POINTERWHEEL) {\r\n return;\r\n }\r\n var event = p.event;\r\n var delta = 0;\r\n var mouseWheelLegacyEvent = event;\r\n var wheelDelta = 0;\r\n if (mouseWheelLegacyEvent.wheelDelta) {\r\n wheelDelta = mouseWheelLegacyEvent.wheelDelta;\r\n }\r\n else {\r\n wheelDelta = -(event.deltaY || event.detail) * 60;\r\n }\r\n if (_this.wheelDeltaPercentage) {\r\n delta = _this.computeDeltaFromMouseWheelLegacyEvent(wheelDelta, _this.camera.radius);\r\n // If zooming in, estimate the target radius and use that to compute the delta for inertia\r\n // this will stop multiple scroll events zooming in from adding too much inertia\r\n if (delta > 0) {\r\n var estimatedTargetRadius = _this.camera.radius;\r\n var targetInertia = _this.camera.inertialRadiusOffset + delta;\r\n for (var i = 0; i < 20 && Math.abs(targetInertia) > 0.001; i++) {\r\n estimatedTargetRadius -= targetInertia;\r\n targetInertia *= _this.camera.inertia;\r\n }\r\n estimatedTargetRadius = Scalar.Clamp(estimatedTargetRadius, 0, Number.MAX_VALUE);\r\n delta = _this.computeDeltaFromMouseWheelLegacyEvent(wheelDelta, estimatedTargetRadius);\r\n }\r\n }\r\n else {\r\n delta = wheelDelta / (_this.wheelPrecision * 40);\r\n }\r\n if (delta) {\r\n _this.camera.inertialRadiusOffset += delta;\r\n }\r\n if (event.preventDefault) {\r\n if (!noPreventDefault) {\r\n event.preventDefault();\r\n }\r\n }\r\n };\r\n this._observer = this.camera.getScene().onPointerObservable.add(this._wheel, PointerEventTypes.POINTERWHEEL);\r\n };\r\n /**\r\n * Detach the current controls from the specified dom element.\r\n * @param element Defines the element to stop listening the inputs from\r\n */\r\n ArcRotateCameraMouseWheelInput.prototype.detachControl = function (element) {\r\n if (this._observer && element) {\r\n this.camera.getScene().onPointerObservable.remove(this._observer);\r\n this._observer = null;\r\n this._wheel = null;\r\n }\r\n };\r\n /**\r\n * Gets the class name of the current intput.\r\n * @returns the class name\r\n */\r\n ArcRotateCameraMouseWheelInput.prototype.getClassName = function () {\r\n return \"ArcRotateCameraMouseWheelInput\";\r\n };\r\n /**\r\n * Get the friendly name associated with the input class.\r\n * @returns the input friendly name\r\n */\r\n ArcRotateCameraMouseWheelInput.prototype.getSimpleName = function () {\r\n return \"mousewheel\";\r\n };\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraMouseWheelInput.prototype, \"wheelPrecision\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraMouseWheelInput.prototype, \"wheelDeltaPercentage\", void 0);\r\n return ArcRotateCameraMouseWheelInput;\r\n}());\r\nexport { ArcRotateCameraMouseWheelInput };\r\nCameraInputTypes[\"ArcRotateCameraMouseWheelInput\"] = ArcRotateCameraMouseWheelInput;\r\n//# sourceMappingURL=arcRotateCameraMouseWheelInput.js.map","import { __extends } from \"tslib\";\r\nimport { ArcRotateCameraPointersInput } from \"../Cameras/Inputs/arcRotateCameraPointersInput\";\r\nimport { ArcRotateCameraKeyboardMoveInput } from \"../Cameras/Inputs/arcRotateCameraKeyboardMoveInput\";\r\nimport { ArcRotateCameraMouseWheelInput } from \"../Cameras/Inputs/arcRotateCameraMouseWheelInput\";\r\nimport { CameraInputsManager } from \"../Cameras/cameraInputsManager\";\r\n/**\r\n * Default Inputs manager for the ArcRotateCamera.\r\n * It groups all the default supported inputs for ease of use.\r\n * @see http://doc.babylonjs.com/how_to/customizing_camera_inputs\r\n */\r\nvar ArcRotateCameraInputsManager = /** @class */ (function (_super) {\r\n __extends(ArcRotateCameraInputsManager, _super);\r\n /**\r\n * Instantiates a new ArcRotateCameraInputsManager.\r\n * @param camera Defines the camera the inputs belong to\r\n */\r\n function ArcRotateCameraInputsManager(camera) {\r\n return _super.call(this, camera) || this;\r\n }\r\n /**\r\n * Add mouse wheel input support to the input manager.\r\n * @returns the current input manager\r\n */\r\n ArcRotateCameraInputsManager.prototype.addMouseWheel = function () {\r\n this.add(new ArcRotateCameraMouseWheelInput());\r\n return this;\r\n };\r\n /**\r\n * Add pointers input support to the input manager.\r\n * @returns the current input manager\r\n */\r\n ArcRotateCameraInputsManager.prototype.addPointers = function () {\r\n this.add(new ArcRotateCameraPointersInput());\r\n return this;\r\n };\r\n /**\r\n * Add keyboard input support to the input manager.\r\n * @returns the current input manager\r\n */\r\n ArcRotateCameraInputsManager.prototype.addKeyboard = function () {\r\n this.add(new ArcRotateCameraKeyboardMoveInput());\r\n return this;\r\n };\r\n return ArcRotateCameraInputsManager;\r\n}(CameraInputsManager));\r\nexport { ArcRotateCameraInputsManager };\r\n//# sourceMappingURL=arcRotateCameraInputsManager.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, serializeAsVector3 } from \"../Misc/decorators\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { Matrix, Vector3, Vector2 } from \"../Maths/math.vector\";\r\nimport { Node } from \"../node\";\r\nimport { Mesh } from \"../Meshes/mesh\";\r\nimport { AutoRotationBehavior } from \"../Behaviors/Cameras/autoRotationBehavior\";\r\nimport { BouncingBehavior } from \"../Behaviors/Cameras/bouncingBehavior\";\r\nimport { FramingBehavior } from \"../Behaviors/Cameras/framingBehavior\";\r\nimport { Camera } from \"./camera\";\r\nimport { TargetCamera } from \"./targetCamera\";\r\nimport { ArcRotateCameraInputsManager } from \"../Cameras/arcRotateCameraInputsManager\";\r\nimport { Epsilon } from '../Maths/math.constants';\r\nNode.AddNodeConstructor(\"ArcRotateCamera\", function (name, scene) {\r\n return function () { return new ArcRotateCamera(name, 0, 0, 1.0, Vector3.Zero(), scene); };\r\n});\r\n/**\r\n * This represents an orbital type of camera.\r\n *\r\n * This camera always points towards a given target position and can be rotated around that target with the target as the centre of rotation. It can be controlled with cursors and mouse, or with touch events.\r\n * Think of this camera as one orbiting its target position, or more imaginatively as a spy satellite orbiting the earth. Its position relative to the target (earth) can be set by three parameters, alpha (radians) the longitudinal rotation, beta (radians) the latitudinal rotation and radius the distance from the target position.\r\n * @see http://doc.babylonjs.com/babylon101/cameras#arc-rotate-camera\r\n */\r\nvar ArcRotateCamera = /** @class */ (function (_super) {\r\n __extends(ArcRotateCamera, _super);\r\n /**\r\n * Instantiates a new ArcRotateCamera in a given scene\r\n * @param name Defines the name of the camera\r\n * @param alpha Defines the camera rotation along the logitudinal axis\r\n * @param beta Defines the camera rotation along the latitudinal axis\r\n * @param radius Defines the camera distance from its target\r\n * @param target Defines the camera target\r\n * @param scene Defines the scene the camera belongs to\r\n * @param setActiveOnSceneIfNoneActive Defines wheter the camera should be marked as active if not other active cameras have been defined\r\n */\r\n function ArcRotateCamera(name, alpha, beta, radius, target, scene, setActiveOnSceneIfNoneActive) {\r\n if (setActiveOnSceneIfNoneActive === void 0) { setActiveOnSceneIfNoneActive = true; }\r\n var _this = _super.call(this, name, Vector3.Zero(), scene, setActiveOnSceneIfNoneActive) || this;\r\n _this._upVector = Vector3.Up();\r\n /**\r\n * Current inertia value on the longitudinal axis.\r\n * The bigger this number the longer it will take for the camera to stop.\r\n */\r\n _this.inertialAlphaOffset = 0;\r\n /**\r\n * Current inertia value on the latitudinal axis.\r\n * The bigger this number the longer it will take for the camera to stop.\r\n */\r\n _this.inertialBetaOffset = 0;\r\n /**\r\n * Current inertia value on the radius axis.\r\n * The bigger this number the longer it will take for the camera to stop.\r\n */\r\n _this.inertialRadiusOffset = 0;\r\n /**\r\n * Minimum allowed angle on the longitudinal axis.\r\n * This can help limiting how the Camera is able to move in the scene.\r\n */\r\n _this.lowerAlphaLimit = null;\r\n /**\r\n * Maximum allowed angle on the longitudinal axis.\r\n * This can help limiting how the Camera is able to move in the scene.\r\n */\r\n _this.upperAlphaLimit = null;\r\n /**\r\n * Minimum allowed angle on the latitudinal axis.\r\n * This can help limiting how the Camera is able to move in the scene.\r\n */\r\n _this.lowerBetaLimit = 0.01;\r\n /**\r\n * Maximum allowed angle on the latitudinal axis.\r\n * This can help limiting how the Camera is able to move in the scene.\r\n */\r\n _this.upperBetaLimit = Math.PI - 0.01;\r\n /**\r\n * Minimum allowed distance of the camera to the target (The camera can not get closer).\r\n * This can help limiting how the Camera is able to move in the scene.\r\n */\r\n _this.lowerRadiusLimit = null;\r\n /**\r\n * Maximum allowed distance of the camera to the target (The camera can not get further).\r\n * This can help limiting how the Camera is able to move in the scene.\r\n */\r\n _this.upperRadiusLimit = null;\r\n /**\r\n * Defines the current inertia value used during panning of the camera along the X axis.\r\n */\r\n _this.inertialPanningX = 0;\r\n /**\r\n * Defines the current inertia value used during panning of the camera along the Y axis.\r\n */\r\n _this.inertialPanningY = 0;\r\n /**\r\n * Defines the distance used to consider the camera in pan mode vs pinch/zoom.\r\n * Basically if your fingers moves away from more than this distance you will be considered\r\n * in pinch mode.\r\n */\r\n _this.pinchToPanMaxDistance = 20;\r\n /**\r\n * Defines the maximum distance the camera can pan.\r\n * This could help keeping the cammera always in your scene.\r\n */\r\n _this.panningDistanceLimit = null;\r\n /**\r\n * Defines the target of the camera before paning.\r\n */\r\n _this.panningOriginTarget = Vector3.Zero();\r\n /**\r\n * Defines the value of the inertia used during panning.\r\n * 0 would mean stop inertia and one would mean no decelleration at all.\r\n */\r\n _this.panningInertia = 0.9;\r\n //-- end properties for backward compatibility for inputs\r\n /**\r\n * Defines how much the radius should be scaled while zomming on a particular mesh (through the zoomOn function)\r\n */\r\n _this.zoomOnFactor = 1;\r\n /**\r\n * Defines a screen offset for the camera position.\r\n */\r\n _this.targetScreenOffset = Vector2.Zero();\r\n /**\r\n * Allows the camera to be completely reversed.\r\n * If false the camera can not arrive upside down.\r\n */\r\n _this.allowUpsideDown = true;\r\n /**\r\n * Define if double tap/click is used to restore the previously saved state of the camera.\r\n */\r\n _this.useInputToRestoreState = true;\r\n /** @hidden */\r\n _this._viewMatrix = new Matrix();\r\n /**\r\n * Defines the allowed panning axis.\r\n */\r\n _this.panningAxis = new Vector3(1, 1, 0);\r\n /**\r\n * Observable triggered when the mesh target has been changed on the camera.\r\n */\r\n _this.onMeshTargetChangedObservable = new Observable();\r\n /**\r\n * Defines whether the camera should check collision with the objects oh the scene.\r\n * @see http://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity#how-can-i-do-this\r\n */\r\n _this.checkCollisions = false;\r\n /**\r\n * Defines the collision radius of the camera.\r\n * This simulates a sphere around the camera.\r\n * @see http://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity#arcrotatecamera\r\n */\r\n _this.collisionRadius = new Vector3(0.5, 0.5, 0.5);\r\n _this._previousPosition = Vector3.Zero();\r\n _this._collisionVelocity = Vector3.Zero();\r\n _this._newPosition = Vector3.Zero();\r\n _this._computationVector = Vector3.Zero();\r\n _this._onCollisionPositionChange = function (collisionId, newPosition, collidedMesh) {\r\n if (collidedMesh === void 0) { collidedMesh = null; }\r\n if (!collidedMesh) {\r\n _this._previousPosition.copyFrom(_this._position);\r\n }\r\n else {\r\n _this.setPosition(newPosition);\r\n if (_this.onCollide) {\r\n _this.onCollide(collidedMesh);\r\n }\r\n }\r\n // Recompute because of constraints\r\n var cosa = Math.cos(_this.alpha);\r\n var sina = Math.sin(_this.alpha);\r\n var cosb = Math.cos(_this.beta);\r\n var sinb = Math.sin(_this.beta);\r\n if (sinb === 0) {\r\n sinb = 0.0001;\r\n }\r\n var target = _this._getTargetPosition();\r\n _this._computationVector.copyFromFloats(_this.radius * cosa * sinb, _this.radius * cosb, _this.radius * sina * sinb);\r\n target.addToRef(_this._computationVector, _this._newPosition);\r\n _this._position.copyFrom(_this._newPosition);\r\n var up = _this.upVector;\r\n if (_this.allowUpsideDown && _this.beta < 0) {\r\n up = up.clone();\r\n up = up.negate();\r\n }\r\n _this._computeViewMatrix(_this._position, target, up);\r\n _this._viewMatrix.addAtIndex(12, _this.targetScreenOffset.x);\r\n _this._viewMatrix.addAtIndex(13, _this.targetScreenOffset.y);\r\n _this._collisionTriggered = false;\r\n };\r\n _this._target = Vector3.Zero();\r\n if (target) {\r\n _this.setTarget(target);\r\n }\r\n _this.alpha = alpha;\r\n _this.beta = beta;\r\n _this.radius = radius;\r\n _this.getViewMatrix();\r\n _this.inputs = new ArcRotateCameraInputsManager(_this);\r\n _this.inputs.addKeyboard().addMouseWheel().addPointers();\r\n return _this;\r\n }\r\n Object.defineProperty(ArcRotateCamera.prototype, \"target\", {\r\n /**\r\n * Defines the target point of the camera.\r\n * The camera looks towards it form the radius distance.\r\n */\r\n get: function () {\r\n return this._target;\r\n },\r\n set: function (value) {\r\n this.setTarget(value);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"position\", {\r\n /**\r\n * Define the current local position of the camera in the scene\r\n */\r\n get: function () {\r\n return this._position;\r\n },\r\n set: function (newPosition) {\r\n this.setPosition(newPosition);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"upVector\", {\r\n get: function () {\r\n return this._upVector;\r\n },\r\n /**\r\n * The vector the camera should consider as up. (default is Vector3(0, 1, 0) as returned by Vector3.Up())\r\n * Setting this will copy the given vector to the camera's upVector, and set rotation matrices to and from Y up.\r\n * DO NOT set the up vector using copyFrom or copyFromFloats, as this bypasses setting the above matrices.\r\n */\r\n set: function (vec) {\r\n if (!this._upToYMatrix) {\r\n this._YToUpMatrix = new Matrix();\r\n this._upToYMatrix = new Matrix();\r\n this._upVector = Vector3.Zero();\r\n }\r\n vec.normalize();\r\n this._upVector.copyFrom(vec);\r\n this.setMatUp();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Sets the Y-up to camera up-vector rotation matrix, and the up-vector to Y-up rotation matrix.\r\n */\r\n ArcRotateCamera.prototype.setMatUp = function () {\r\n // from y-up to custom-up (used in _getViewMatrix)\r\n Matrix.RotationAlignToRef(Vector3.UpReadOnly, this._upVector, this._YToUpMatrix);\r\n // from custom-up to y-up (used in rebuildAnglesAndRadius)\r\n Matrix.RotationAlignToRef(this._upVector, Vector3.UpReadOnly, this._upToYMatrix);\r\n };\r\n Object.defineProperty(ArcRotateCamera.prototype, \"angularSensibilityX\", {\r\n //-- begin properties for backward compatibility for inputs\r\n /**\r\n * Gets or Set the pointer angular sensibility along the X axis or how fast is the camera rotating.\r\n */\r\n get: function () {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n return pointers.angularSensibilityX;\r\n }\r\n return 0;\r\n },\r\n set: function (value) {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n pointers.angularSensibilityX = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"angularSensibilityY\", {\r\n /**\r\n * Gets or Set the pointer angular sensibility along the Y axis or how fast is the camera rotating.\r\n */\r\n get: function () {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n return pointers.angularSensibilityY;\r\n }\r\n return 0;\r\n },\r\n set: function (value) {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n pointers.angularSensibilityY = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"pinchPrecision\", {\r\n /**\r\n * Gets or Set the pointer pinch precision or how fast is the camera zooming.\r\n */\r\n get: function () {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n return pointers.pinchPrecision;\r\n }\r\n return 0;\r\n },\r\n set: function (value) {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n pointers.pinchPrecision = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"pinchDeltaPercentage\", {\r\n /**\r\n * Gets or Set the pointer pinch delta percentage or how fast is the camera zooming.\r\n * It will be used instead of pinchDeltaPrecision if different from 0.\r\n * It defines the percentage of current camera.radius to use as delta when pinch zoom is used.\r\n */\r\n get: function () {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n return pointers.pinchDeltaPercentage;\r\n }\r\n return 0;\r\n },\r\n set: function (value) {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n pointers.pinchDeltaPercentage = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"useNaturalPinchZoom\", {\r\n /**\r\n * Gets or Set the pointer use natural pinch zoom to override the pinch precision\r\n * and pinch delta percentage.\r\n * When useNaturalPinchZoom is true, multi touch zoom will zoom in such\r\n * that any object in the plane at the camera's target point will scale\r\n * perfectly with finger motion.\r\n */\r\n get: function () {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n return pointers.useNaturalPinchZoom;\r\n }\r\n return false;\r\n },\r\n set: function (value) {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n pointers.useNaturalPinchZoom = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"panningSensibility\", {\r\n /**\r\n * Gets or Set the pointer panning sensibility or how fast is the camera moving.\r\n */\r\n get: function () {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n return pointers.panningSensibility;\r\n }\r\n return 0;\r\n },\r\n set: function (value) {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n pointers.panningSensibility = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"keysUp\", {\r\n /**\r\n * Gets or Set the list of keyboard keys used to control beta angle in a positive direction.\r\n */\r\n get: function () {\r\n var keyboard = this.inputs.attached[\"keyboard\"];\r\n if (keyboard) {\r\n return keyboard.keysUp;\r\n }\r\n return [];\r\n },\r\n set: function (value) {\r\n var keyboard = this.inputs.attached[\"keyboard\"];\r\n if (keyboard) {\r\n keyboard.keysUp = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"keysDown\", {\r\n /**\r\n * Gets or Set the list of keyboard keys used to control beta angle in a negative direction.\r\n */\r\n get: function () {\r\n var keyboard = this.inputs.attached[\"keyboard\"];\r\n if (keyboard) {\r\n return keyboard.keysDown;\r\n }\r\n return [];\r\n },\r\n set: function (value) {\r\n var keyboard = this.inputs.attached[\"keyboard\"];\r\n if (keyboard) {\r\n keyboard.keysDown = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"keysLeft\", {\r\n /**\r\n * Gets or Set the list of keyboard keys used to control alpha angle in a negative direction.\r\n */\r\n get: function () {\r\n var keyboard = this.inputs.attached[\"keyboard\"];\r\n if (keyboard) {\r\n return keyboard.keysLeft;\r\n }\r\n return [];\r\n },\r\n set: function (value) {\r\n var keyboard = this.inputs.attached[\"keyboard\"];\r\n if (keyboard) {\r\n keyboard.keysLeft = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"keysRight\", {\r\n /**\r\n * Gets or Set the list of keyboard keys used to control alpha angle in a positive direction.\r\n */\r\n get: function () {\r\n var keyboard = this.inputs.attached[\"keyboard\"];\r\n if (keyboard) {\r\n return keyboard.keysRight;\r\n }\r\n return [];\r\n },\r\n set: function (value) {\r\n var keyboard = this.inputs.attached[\"keyboard\"];\r\n if (keyboard) {\r\n keyboard.keysRight = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"wheelPrecision\", {\r\n /**\r\n * Gets or Set the mouse wheel precision or how fast is the camera zooming.\r\n */\r\n get: function () {\r\n var mousewheel = this.inputs.attached[\"mousewheel\"];\r\n if (mousewheel) {\r\n return mousewheel.wheelPrecision;\r\n }\r\n return 0;\r\n },\r\n set: function (value) {\r\n var mousewheel = this.inputs.attached[\"mousewheel\"];\r\n if (mousewheel) {\r\n mousewheel.wheelPrecision = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"wheelDeltaPercentage\", {\r\n /**\r\n * Gets or Set the mouse wheel delta percentage or how fast is the camera zooming.\r\n * It will be used instead of pinchDeltaPrecision if different from 0.\r\n * It defines the percentage of current camera.radius to use as delta when pinch zoom is used.\r\n */\r\n get: function () {\r\n var mousewheel = this.inputs.attached[\"mousewheel\"];\r\n if (mousewheel) {\r\n return mousewheel.wheelDeltaPercentage;\r\n }\r\n return 0;\r\n },\r\n set: function (value) {\r\n var mousewheel = this.inputs.attached[\"mousewheel\"];\r\n if (mousewheel) {\r\n mousewheel.wheelDeltaPercentage = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"bouncingBehavior\", {\r\n /**\r\n * Gets the bouncing behavior of the camera if it has been enabled.\r\n * @see http://doc.babylonjs.com/how_to/camera_behaviors#bouncing-behavior\r\n */\r\n get: function () {\r\n return this._bouncingBehavior;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"useBouncingBehavior\", {\r\n /**\r\n * Defines if the bouncing behavior of the camera is enabled on the camera.\r\n * @see http://doc.babylonjs.com/how_to/camera_behaviors#bouncing-behavior\r\n */\r\n get: function () {\r\n return this._bouncingBehavior != null;\r\n },\r\n set: function (value) {\r\n if (value === this.useBouncingBehavior) {\r\n return;\r\n }\r\n if (value) {\r\n this._bouncingBehavior = new BouncingBehavior();\r\n this.addBehavior(this._bouncingBehavior);\r\n }\r\n else if (this._bouncingBehavior) {\r\n this.removeBehavior(this._bouncingBehavior);\r\n this._bouncingBehavior = null;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"framingBehavior\", {\r\n /**\r\n * Gets the framing behavior of the camera if it has been enabled.\r\n * @see http://doc.babylonjs.com/how_to/camera_behaviors#framing-behavior\r\n */\r\n get: function () {\r\n return this._framingBehavior;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"useFramingBehavior\", {\r\n /**\r\n * Defines if the framing behavior of the camera is enabled on the camera.\r\n * @see http://doc.babylonjs.com/how_to/camera_behaviors#framing-behavior\r\n */\r\n get: function () {\r\n return this._framingBehavior != null;\r\n },\r\n set: function (value) {\r\n if (value === this.useFramingBehavior) {\r\n return;\r\n }\r\n if (value) {\r\n this._framingBehavior = new FramingBehavior();\r\n this.addBehavior(this._framingBehavior);\r\n }\r\n else if (this._framingBehavior) {\r\n this.removeBehavior(this._framingBehavior);\r\n this._framingBehavior = null;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"autoRotationBehavior\", {\r\n /**\r\n * Gets the auto rotation behavior of the camera if it has been enabled.\r\n * @see http://doc.babylonjs.com/how_to/camera_behaviors#autorotation-behavior\r\n */\r\n get: function () {\r\n return this._autoRotationBehavior;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"useAutoRotationBehavior\", {\r\n /**\r\n * Defines if the auto rotation behavior of the camera is enabled on the camera.\r\n * @see http://doc.babylonjs.com/how_to/camera_behaviors#autorotation-behavior\r\n */\r\n get: function () {\r\n return this._autoRotationBehavior != null;\r\n },\r\n set: function (value) {\r\n if (value === this.useAutoRotationBehavior) {\r\n return;\r\n }\r\n if (value) {\r\n this._autoRotationBehavior = new AutoRotationBehavior();\r\n this.addBehavior(this._autoRotationBehavior);\r\n }\r\n else if (this._autoRotationBehavior) {\r\n this.removeBehavior(this._autoRotationBehavior);\r\n this._autoRotationBehavior = null;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n // Cache\r\n /** @hidden */\r\n ArcRotateCamera.prototype._initCache = function () {\r\n _super.prototype._initCache.call(this);\r\n this._cache._target = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n this._cache.alpha = undefined;\r\n this._cache.beta = undefined;\r\n this._cache.radius = undefined;\r\n this._cache.targetScreenOffset = Vector2.Zero();\r\n };\r\n /** @hidden */\r\n ArcRotateCamera.prototype._updateCache = function (ignoreParentClass) {\r\n if (!ignoreParentClass) {\r\n _super.prototype._updateCache.call(this);\r\n }\r\n this._cache._target.copyFrom(this._getTargetPosition());\r\n this._cache.alpha = this.alpha;\r\n this._cache.beta = this.beta;\r\n this._cache.radius = this.radius;\r\n this._cache.targetScreenOffset.copyFrom(this.targetScreenOffset);\r\n };\r\n ArcRotateCamera.prototype._getTargetPosition = function () {\r\n if (this._targetHost && this._targetHost.getAbsolutePosition) {\r\n var pos = this._targetHost.absolutePosition;\r\n if (this._targetBoundingCenter) {\r\n pos.addToRef(this._targetBoundingCenter, this._target);\r\n }\r\n else {\r\n this._target.copyFrom(pos);\r\n }\r\n }\r\n var lockedTargetPosition = this._getLockedTargetPosition();\r\n if (lockedTargetPosition) {\r\n return lockedTargetPosition;\r\n }\r\n return this._target;\r\n };\r\n /**\r\n * Stores the current state of the camera (alpha, beta, radius and target)\r\n * @returns the camera itself\r\n */\r\n ArcRotateCamera.prototype.storeState = function () {\r\n this._storedAlpha = this.alpha;\r\n this._storedBeta = this.beta;\r\n this._storedRadius = this.radius;\r\n this._storedTarget = this._getTargetPosition().clone();\r\n this._storedTargetScreenOffset = this.targetScreenOffset.clone();\r\n return _super.prototype.storeState.call(this);\r\n };\r\n /**\r\n * @hidden\r\n * Restored camera state. You must call storeState() first\r\n */\r\n ArcRotateCamera.prototype._restoreStateValues = function () {\r\n if (!_super.prototype._restoreStateValues.call(this)) {\r\n return false;\r\n }\r\n this.setTarget(this._storedTarget.clone());\r\n this.alpha = this._storedAlpha;\r\n this.beta = this._storedBeta;\r\n this.radius = this._storedRadius;\r\n this.targetScreenOffset = this._storedTargetScreenOffset.clone();\r\n this.inertialAlphaOffset = 0;\r\n this.inertialBetaOffset = 0;\r\n this.inertialRadiusOffset = 0;\r\n this.inertialPanningX = 0;\r\n this.inertialPanningY = 0;\r\n return true;\r\n };\r\n // Synchronized\r\n /** @hidden */\r\n ArcRotateCamera.prototype._isSynchronizedViewMatrix = function () {\r\n if (!_super.prototype._isSynchronizedViewMatrix.call(this)) {\r\n return false;\r\n }\r\n return this._cache._target.equals(this._getTargetPosition())\r\n && this._cache.alpha === this.alpha\r\n && this._cache.beta === this.beta\r\n && this._cache.radius === this.radius\r\n && this._cache.targetScreenOffset.equals(this.targetScreenOffset);\r\n };\r\n /**\r\n * Attached controls to the current camera.\r\n * @param element Defines the element the controls should be listened from\r\n * @param noPreventDefault Defines whether event caught by the controls should call preventdefault() (https://developer.mozilla.org/en-US/docs/Web/API/Event/preventDefault)\r\n * @param useCtrlForPanning Defines whether ctrl is used for paning within the controls\r\n * @param panningMouseButton Defines whether panning is allowed through mouse click button\r\n */\r\n ArcRotateCamera.prototype.attachControl = function (element, noPreventDefault, useCtrlForPanning, panningMouseButton) {\r\n var _this = this;\r\n if (useCtrlForPanning === void 0) { useCtrlForPanning = true; }\r\n if (panningMouseButton === void 0) { panningMouseButton = 2; }\r\n this._useCtrlForPanning = useCtrlForPanning;\r\n this._panningMouseButton = panningMouseButton;\r\n this.inputs.attachElement(element, noPreventDefault);\r\n this._reset = function () {\r\n _this.inertialAlphaOffset = 0;\r\n _this.inertialBetaOffset = 0;\r\n _this.inertialRadiusOffset = 0;\r\n _this.inertialPanningX = 0;\r\n _this.inertialPanningY = 0;\r\n };\r\n };\r\n /**\r\n * Detach the current controls from the camera.\r\n * The camera will stop reacting to inputs.\r\n * @param element Defines the element to stop listening the inputs from\r\n */\r\n ArcRotateCamera.prototype.detachControl = function (element) {\r\n this.inputs.detachElement(element);\r\n if (this._reset) {\r\n this._reset();\r\n }\r\n };\r\n /** @hidden */\r\n ArcRotateCamera.prototype._checkInputs = function () {\r\n //if (async) collision inspection was triggered, don't update the camera's position - until the collision callback was called.\r\n if (this._collisionTriggered) {\r\n return;\r\n }\r\n this.inputs.checkInputs();\r\n // Inertia\r\n if (this.inertialAlphaOffset !== 0 || this.inertialBetaOffset !== 0 || this.inertialRadiusOffset !== 0) {\r\n var inertialAlphaOffset = this.inertialAlphaOffset;\r\n if (this.beta <= 0) {\r\n inertialAlphaOffset *= -1;\r\n }\r\n if (this.getScene().useRightHandedSystem) {\r\n inertialAlphaOffset *= -1;\r\n }\r\n if (this.parent && this.parent._getWorldMatrixDeterminant() < 0) {\r\n inertialAlphaOffset *= -1;\r\n }\r\n this.alpha += inertialAlphaOffset;\r\n this.beta += this.inertialBetaOffset;\r\n this.radius -= this.inertialRadiusOffset;\r\n this.inertialAlphaOffset *= this.inertia;\r\n this.inertialBetaOffset *= this.inertia;\r\n this.inertialRadiusOffset *= this.inertia;\r\n if (Math.abs(this.inertialAlphaOffset) < Epsilon) {\r\n this.inertialAlphaOffset = 0;\r\n }\r\n if (Math.abs(this.inertialBetaOffset) < Epsilon) {\r\n this.inertialBetaOffset = 0;\r\n }\r\n if (Math.abs(this.inertialRadiusOffset) < this.speed * Epsilon) {\r\n this.inertialRadiusOffset = 0;\r\n }\r\n }\r\n // Panning inertia\r\n if (this.inertialPanningX !== 0 || this.inertialPanningY !== 0) {\r\n if (!this._localDirection) {\r\n this._localDirection = Vector3.Zero();\r\n this._transformedDirection = Vector3.Zero();\r\n }\r\n this._localDirection.copyFromFloats(this.inertialPanningX, this.inertialPanningY, this.inertialPanningY);\r\n this._localDirection.multiplyInPlace(this.panningAxis);\r\n this._viewMatrix.invertToRef(this._cameraTransformMatrix);\r\n Vector3.TransformNormalToRef(this._localDirection, this._cameraTransformMatrix, this._transformedDirection);\r\n //Eliminate y if map panning is enabled (panningAxis == 1,0,1)\r\n if (!this.panningAxis.y) {\r\n this._transformedDirection.y = 0;\r\n }\r\n if (!this._targetHost) {\r\n if (this.panningDistanceLimit) {\r\n this._transformedDirection.addInPlace(this._target);\r\n var distanceSquared = Vector3.DistanceSquared(this._transformedDirection, this.panningOriginTarget);\r\n if (distanceSquared <= (this.panningDistanceLimit * this.panningDistanceLimit)) {\r\n this._target.copyFrom(this._transformedDirection);\r\n }\r\n }\r\n else {\r\n this._target.addInPlace(this._transformedDirection);\r\n }\r\n }\r\n this.inertialPanningX *= this.panningInertia;\r\n this.inertialPanningY *= this.panningInertia;\r\n if (Math.abs(this.inertialPanningX) < this.speed * Epsilon) {\r\n this.inertialPanningX = 0;\r\n }\r\n if (Math.abs(this.inertialPanningY) < this.speed * Epsilon) {\r\n this.inertialPanningY = 0;\r\n }\r\n }\r\n // Limits\r\n this._checkLimits();\r\n _super.prototype._checkInputs.call(this);\r\n };\r\n ArcRotateCamera.prototype._checkLimits = function () {\r\n if (this.lowerBetaLimit === null || this.lowerBetaLimit === undefined) {\r\n if (this.allowUpsideDown && this.beta > Math.PI) {\r\n this.beta = this.beta - (2 * Math.PI);\r\n }\r\n }\r\n else {\r\n if (this.beta < this.lowerBetaLimit) {\r\n this.beta = this.lowerBetaLimit;\r\n }\r\n }\r\n if (this.upperBetaLimit === null || this.upperBetaLimit === undefined) {\r\n if (this.allowUpsideDown && this.beta < -Math.PI) {\r\n this.beta = this.beta + (2 * Math.PI);\r\n }\r\n }\r\n else {\r\n if (this.beta > this.upperBetaLimit) {\r\n this.beta = this.upperBetaLimit;\r\n }\r\n }\r\n if (this.lowerAlphaLimit !== null && this.alpha < this.lowerAlphaLimit) {\r\n this.alpha = this.lowerAlphaLimit;\r\n }\r\n if (this.upperAlphaLimit !== null && this.alpha > this.upperAlphaLimit) {\r\n this.alpha = this.upperAlphaLimit;\r\n }\r\n if (this.lowerRadiusLimit !== null && this.radius < this.lowerRadiusLimit) {\r\n this.radius = this.lowerRadiusLimit;\r\n this.inertialRadiusOffset = 0;\r\n }\r\n if (this.upperRadiusLimit !== null && this.radius > this.upperRadiusLimit) {\r\n this.radius = this.upperRadiusLimit;\r\n this.inertialRadiusOffset = 0;\r\n }\r\n };\r\n /**\r\n * Rebuilds angles (alpha, beta) and radius from the give position and target\r\n */\r\n ArcRotateCamera.prototype.rebuildAnglesAndRadius = function () {\r\n this._position.subtractToRef(this._getTargetPosition(), this._computationVector);\r\n // need to rotate to Y up equivalent if up vector not Axis.Y\r\n if (this._upVector.x !== 0 || this._upVector.y !== 1.0 || this._upVector.z !== 0) {\r\n Vector3.TransformCoordinatesToRef(this._computationVector, this._upToYMatrix, this._computationVector);\r\n }\r\n this.radius = this._computationVector.length();\r\n if (this.radius === 0) {\r\n this.radius = 0.0001; // Just to avoid division by zero\r\n }\r\n // Alpha\r\n if (this._computationVector.x === 0 && this._computationVector.z === 0) {\r\n this.alpha = Math.PI / 2; // avoid division by zero when looking along up axis, and set to acos(0)\r\n }\r\n else {\r\n this.alpha = Math.acos(this._computationVector.x / Math.sqrt(Math.pow(this._computationVector.x, 2) + Math.pow(this._computationVector.z, 2)));\r\n }\r\n if (this._computationVector.z < 0) {\r\n this.alpha = 2 * Math.PI - this.alpha;\r\n }\r\n // Beta\r\n this.beta = Math.acos(this._computationVector.y / this.radius);\r\n this._checkLimits();\r\n };\r\n /**\r\n * Use a position to define the current camera related information like alpha, beta and radius\r\n * @param position Defines the position to set the camera at\r\n */\r\n ArcRotateCamera.prototype.setPosition = function (position) {\r\n if (this._position.equals(position)) {\r\n return;\r\n }\r\n this._position.copyFrom(position);\r\n this.rebuildAnglesAndRadius();\r\n };\r\n /**\r\n * Defines the target the camera should look at.\r\n * This will automatically adapt alpha beta and radius to fit within the new target.\r\n * @param target Defines the new target as a Vector or a mesh\r\n * @param toBoundingCenter In case of a mesh target, defines whether to target the mesh position or its bounding information center\r\n * @param allowSamePosition If false, prevents reapplying the new computed position if it is identical to the current one (optim)\r\n */\r\n ArcRotateCamera.prototype.setTarget = function (target, toBoundingCenter, allowSamePosition) {\r\n if (toBoundingCenter === void 0) { toBoundingCenter = false; }\r\n if (allowSamePosition === void 0) { allowSamePosition = false; }\r\n if (target.getBoundingInfo) {\r\n if (toBoundingCenter) {\r\n this._targetBoundingCenter = target.getBoundingInfo().boundingBox.centerWorld.clone();\r\n }\r\n else {\r\n this._targetBoundingCenter = null;\r\n }\r\n target.computeWorldMatrix();\r\n this._targetHost = target;\r\n this._target = this._getTargetPosition();\r\n this.onMeshTargetChangedObservable.notifyObservers(this._targetHost);\r\n }\r\n else {\r\n var newTarget = target;\r\n var currentTarget = this._getTargetPosition();\r\n if (currentTarget && !allowSamePosition && currentTarget.equals(newTarget)) {\r\n return;\r\n }\r\n this._targetHost = null;\r\n this._target = newTarget;\r\n this._targetBoundingCenter = null;\r\n this.onMeshTargetChangedObservable.notifyObservers(null);\r\n }\r\n this.rebuildAnglesAndRadius();\r\n };\r\n /** @hidden */\r\n ArcRotateCamera.prototype._getViewMatrix = function () {\r\n // Compute\r\n var cosa = Math.cos(this.alpha);\r\n var sina = Math.sin(this.alpha);\r\n var cosb = Math.cos(this.beta);\r\n var sinb = Math.sin(this.beta);\r\n if (sinb === 0) {\r\n sinb = 0.0001;\r\n }\r\n var target = this._getTargetPosition();\r\n this._computationVector.copyFromFloats(this.radius * cosa * sinb, this.radius * cosb, this.radius * sina * sinb);\r\n // Rotate according to up vector\r\n if (this._upVector.x !== 0 || this._upVector.y !== 1.0 || this._upVector.z !== 0) {\r\n Vector3.TransformCoordinatesToRef(this._computationVector, this._YToUpMatrix, this._computationVector);\r\n }\r\n target.addToRef(this._computationVector, this._newPosition);\r\n if (this.getScene().collisionsEnabled && this.checkCollisions) {\r\n var coordinator = this.getScene().collisionCoordinator;\r\n if (!this._collider) {\r\n this._collider = coordinator.createCollider();\r\n }\r\n this._collider._radius = this.collisionRadius;\r\n this._newPosition.subtractToRef(this._position, this._collisionVelocity);\r\n this._collisionTriggered = true;\r\n coordinator.getNewPosition(this._position, this._collisionVelocity, this._collider, 3, null, this._onCollisionPositionChange, this.uniqueId);\r\n }\r\n else {\r\n this._position.copyFrom(this._newPosition);\r\n var up = this.upVector;\r\n if (this.allowUpsideDown && sinb < 0) {\r\n up = up.negate();\r\n }\r\n this._computeViewMatrix(this._position, target, up);\r\n this._viewMatrix.addAtIndex(12, this.targetScreenOffset.x);\r\n this._viewMatrix.addAtIndex(13, this.targetScreenOffset.y);\r\n }\r\n this._currentTarget = target;\r\n return this._viewMatrix;\r\n };\r\n /**\r\n * Zooms on a mesh to be at the min distance where we could see it fully in the current viewport.\r\n * @param meshes Defines the mesh to zoom on\r\n * @param doNotUpdateMaxZ Defines whether or not maxZ should be updated whilst zooming on the mesh (this can happen if the mesh is big and the maxradius pretty small for instance)\r\n */\r\n ArcRotateCamera.prototype.zoomOn = function (meshes, doNotUpdateMaxZ) {\r\n if (doNotUpdateMaxZ === void 0) { doNotUpdateMaxZ = false; }\r\n meshes = meshes || this.getScene().meshes;\r\n var minMaxVector = Mesh.MinMax(meshes);\r\n var distance = Vector3.Distance(minMaxVector.min, minMaxVector.max);\r\n this.radius = distance * this.zoomOnFactor;\r\n this.focusOn({ min: minMaxVector.min, max: minMaxVector.max, distance: distance }, doNotUpdateMaxZ);\r\n };\r\n /**\r\n * Focus on a mesh or a bounding box. This adapts the target and maxRadius if necessary but does not update the current radius.\r\n * The target will be changed but the radius\r\n * @param meshesOrMinMaxVectorAndDistance Defines the mesh or bounding info to focus on\r\n * @param doNotUpdateMaxZ Defines whether or not maxZ should be updated whilst zooming on the mesh (this can happen if the mesh is big and the maxradius pretty small for instance)\r\n */\r\n ArcRotateCamera.prototype.focusOn = function (meshesOrMinMaxVectorAndDistance, doNotUpdateMaxZ) {\r\n if (doNotUpdateMaxZ === void 0) { doNotUpdateMaxZ = false; }\r\n var meshesOrMinMaxVector;\r\n var distance;\r\n if (meshesOrMinMaxVectorAndDistance.min === undefined) { // meshes\r\n var meshes = meshesOrMinMaxVectorAndDistance || this.getScene().meshes;\r\n meshesOrMinMaxVector = Mesh.MinMax(meshes);\r\n distance = Vector3.Distance(meshesOrMinMaxVector.min, meshesOrMinMaxVector.max);\r\n }\r\n else { //minMaxVector and distance\r\n var minMaxVectorAndDistance = meshesOrMinMaxVectorAndDistance;\r\n meshesOrMinMaxVector = minMaxVectorAndDistance;\r\n distance = minMaxVectorAndDistance.distance;\r\n }\r\n this._target = Mesh.Center(meshesOrMinMaxVector);\r\n if (!doNotUpdateMaxZ) {\r\n this.maxZ = distance * 2;\r\n }\r\n };\r\n /**\r\n * @override\r\n * Override Camera.createRigCamera\r\n */\r\n ArcRotateCamera.prototype.createRigCamera = function (name, cameraIndex) {\r\n var alphaShift = 0;\r\n switch (this.cameraRigMode) {\r\n case Camera.RIG_MODE_STEREOSCOPIC_ANAGLYPH:\r\n case Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL:\r\n case Camera.RIG_MODE_STEREOSCOPIC_OVERUNDER:\r\n case Camera.RIG_MODE_STEREOSCOPIC_INTERLACED:\r\n case Camera.RIG_MODE_VR:\r\n alphaShift = this._cameraRigParams.stereoHalfAngle * (cameraIndex === 0 ? 1 : -1);\r\n break;\r\n case Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED:\r\n alphaShift = this._cameraRigParams.stereoHalfAngle * (cameraIndex === 0 ? -1 : 1);\r\n break;\r\n }\r\n var rigCam = new ArcRotateCamera(name, this.alpha + alphaShift, this.beta, this.radius, this._target, this.getScene());\r\n rigCam._cameraRigParams = {};\r\n rigCam.isRigCamera = true;\r\n rigCam.rigParent = this;\r\n return rigCam;\r\n };\r\n /**\r\n * @hidden\r\n * @override\r\n * Override Camera._updateRigCameras\r\n */\r\n ArcRotateCamera.prototype._updateRigCameras = function () {\r\n var camLeft = this._rigCameras[0];\r\n var camRight = this._rigCameras[1];\r\n camLeft.beta = camRight.beta = this.beta;\r\n switch (this.cameraRigMode) {\r\n case Camera.RIG_MODE_STEREOSCOPIC_ANAGLYPH:\r\n case Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL:\r\n case Camera.RIG_MODE_STEREOSCOPIC_OVERUNDER:\r\n case Camera.RIG_MODE_STEREOSCOPIC_INTERLACED:\r\n case Camera.RIG_MODE_VR:\r\n camLeft.alpha = this.alpha - this._cameraRigParams.stereoHalfAngle;\r\n camRight.alpha = this.alpha + this._cameraRigParams.stereoHalfAngle;\r\n break;\r\n case Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED:\r\n camLeft.alpha = this.alpha + this._cameraRigParams.stereoHalfAngle;\r\n camRight.alpha = this.alpha - this._cameraRigParams.stereoHalfAngle;\r\n break;\r\n }\r\n _super.prototype._updateRigCameras.call(this);\r\n };\r\n /**\r\n * Destroy the camera and release the current resources hold by it.\r\n */\r\n ArcRotateCamera.prototype.dispose = function () {\r\n this.inputs.clear();\r\n _super.prototype.dispose.call(this);\r\n };\r\n /**\r\n * Gets the current object class name.\r\n * @return the class name\r\n */\r\n ArcRotateCamera.prototype.getClassName = function () {\r\n return \"ArcRotateCamera\";\r\n };\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"alpha\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"beta\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"radius\", void 0);\r\n __decorate([\r\n serializeAsVector3(\"target\")\r\n ], ArcRotateCamera.prototype, \"_target\", void 0);\r\n __decorate([\r\n serializeAsVector3(\"upVector\")\r\n ], ArcRotateCamera.prototype, \"_upVector\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"inertialAlphaOffset\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"inertialBetaOffset\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"inertialRadiusOffset\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"lowerAlphaLimit\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"upperAlphaLimit\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"lowerBetaLimit\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"upperBetaLimit\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"lowerRadiusLimit\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"upperRadiusLimit\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"inertialPanningX\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"inertialPanningY\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"pinchToPanMaxDistance\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"panningDistanceLimit\", void 0);\r\n __decorate([\r\n serializeAsVector3()\r\n ], ArcRotateCamera.prototype, \"panningOriginTarget\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"panningInertia\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"zoomOnFactor\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"targetScreenOffset\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"allowUpsideDown\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"useInputToRestoreState\", void 0);\r\n return ArcRotateCamera;\r\n}(TargetCamera));\r\nexport { ArcRotateCamera };\r\n//# sourceMappingURL=arcRotateCamera.js.map","// Unique ID creation requires a high quality random # generator. In the browser we therefore\n// require the crypto API and do not support built-in fallback to lower quality random number\n// generators (like Math.random()).\n// getRandomValues needs to be invoked in a context where \"this\" is a Crypto implementation. Also,\n// find the complete implementation of crypto (msCrypto) on IE11.\nvar getRandomValues = typeof crypto !== 'undefined' && crypto.getRandomValues && crypto.getRandomValues.bind(crypto) || typeof msCrypto !== 'undefined' && typeof msCrypto.getRandomValues === 'function' && msCrypto.getRandomValues.bind(msCrypto);\nvar rnds8 = new Uint8Array(16);\nexport default function rng() {\n if (!getRandomValues) {\n throw new Error('crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported');\n }\n\n return getRandomValues(rnds8);\n}","export default /^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;","import validate from './validate.js';\n/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\n\nvar byteToHex = [];\n\nfor (var i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).substr(1));\n}\n\nfunction stringify(arr) {\n var offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n // Note: Be careful editing this code! It's been tuned for performance\n // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434\n var uuid = (byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]).toLowerCase(); // Consistency check for valid UUID. If this throws, it's likely due to one\n // of the following:\n // - One or more input array values don't map to a hex octet (leading to\n // \"undefined\" in the uuid)\n // - Invalid input values for the RFC `version` or `variant` fields\n\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n\n return uuid;\n}\n\nexport default stringify;","import REGEX from './regex.js';\n\nfunction validate(uuid) {\n return typeof uuid === 'string' && REGEX.test(uuid);\n}\n\nexport default validate;","import rng from './rng.js';\nimport stringify from './stringify.js'; // **`v1()` - Generate time-based UUID**\n//\n// Inspired by https://github.com/LiosK/UUID.js\n// and http://docs.python.org/library/uuid.html\n\nvar _nodeId;\n\nvar _clockseq; // Previous uuid creation time\n\n\nvar _lastMSecs = 0;\nvar _lastNSecs = 0; // See https://github.com/uuidjs/uuid for API details\n\nfunction v1(options, buf, offset) {\n var i = buf && offset || 0;\n var b = buf || new Array(16);\n options = options || {};\n var node = options.node || _nodeId;\n var clockseq = options.clockseq !== undefined ? options.clockseq : _clockseq; // node and clockseq need to be initialized to random values if they're not\n // specified. We do this lazily to minimize issues related to insufficient\n // system entropy. See #189\n\n if (node == null || clockseq == null) {\n var seedBytes = options.random || (options.rng || rng)();\n\n if (node == null) {\n // Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1)\n node = _nodeId = [seedBytes[0] | 0x01, seedBytes[1], seedBytes[2], seedBytes[3], seedBytes[4], seedBytes[5]];\n }\n\n if (clockseq == null) {\n // Per 4.2.2, randomize (14 bit) clockseq\n clockseq = _clockseq = (seedBytes[6] << 8 | seedBytes[7]) & 0x3fff;\n }\n } // UUID timestamps are 100 nano-second units since the Gregorian epoch,\n // (1582-10-15 00:00). JSNumbers aren't precise enough for this, so\n // time is handled internally as 'msecs' (integer milliseconds) and 'nsecs'\n // (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00.\n\n\n var msecs = options.msecs !== undefined ? options.msecs : Date.now(); // Per 4.2.1.2, use count of uuid's generated during the current clock\n // cycle to simulate higher resolution clock\n\n var nsecs = options.nsecs !== undefined ? options.nsecs : _lastNSecs + 1; // Time since last uuid creation (in msecs)\n\n var dt = msecs - _lastMSecs + (nsecs - _lastNSecs) / 10000; // Per 4.2.1.2, Bump clockseq on clock regression\n\n if (dt < 0 && options.clockseq === undefined) {\n clockseq = clockseq + 1 & 0x3fff;\n } // Reset nsecs if clock regresses (new clockseq) or we've moved onto a new\n // time interval\n\n\n if ((dt < 0 || msecs > _lastMSecs) && options.nsecs === undefined) {\n nsecs = 0;\n } // Per 4.2.1.2 Throw error if too many uuids are requested\n\n\n if (nsecs >= 10000) {\n throw new Error(\"uuid.v1(): Can't create more than 10M uuids/sec\");\n }\n\n _lastMSecs = msecs;\n _lastNSecs = nsecs;\n _clockseq = clockseq; // Per 4.1.4 - Convert from unix epoch to Gregorian epoch\n\n msecs += 12219292800000; // `time_low`\n\n var tl = ((msecs & 0xfffffff) * 10000 + nsecs) % 0x100000000;\n b[i++] = tl >>> 24 & 0xff;\n b[i++] = tl >>> 16 & 0xff;\n b[i++] = tl >>> 8 & 0xff;\n b[i++] = tl & 0xff; // `time_mid`\n\n var tmh = msecs / 0x100000000 * 10000 & 0xfffffff;\n b[i++] = tmh >>> 8 & 0xff;\n b[i++] = tmh & 0xff; // `time_high_and_version`\n\n b[i++] = tmh >>> 24 & 0xf | 0x10; // include version\n\n b[i++] = tmh >>> 16 & 0xff; // `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant)\n\n b[i++] = clockseq >>> 8 | 0x80; // `clock_seq_low`\n\n b[i++] = clockseq & 0xff; // `node`\n\n for (var n = 0; n < 6; ++n) {\n b[i + n] = node[n];\n }\n\n return buf || stringify(b);\n}\n\nexport default v1;","import validate from './validate.js';\n\nfunction parse(uuid) {\n if (!validate(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n var v;\n var arr = new Uint8Array(16); // Parse ########-....-....-....-............\n\n arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;\n arr[1] = v >>> 16 & 0xff;\n arr[2] = v >>> 8 & 0xff;\n arr[3] = v & 0xff; // Parse ........-####-....-....-............\n\n arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;\n arr[5] = v & 0xff; // Parse ........-....-####-....-............\n\n arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;\n arr[7] = v & 0xff; // Parse ........-....-....-####-............\n\n arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;\n arr[9] = v & 0xff; // Parse ........-....-....-....-############\n // (Use \"/\" to avoid 32-bit truncation when bit-shifting high-order bytes)\n\n arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;\n arr[11] = v / 0x100000000 & 0xff;\n arr[12] = v >>> 24 & 0xff;\n arr[13] = v >>> 16 & 0xff;\n arr[14] = v >>> 8 & 0xff;\n arr[15] = v & 0xff;\n return arr;\n}\n\nexport default parse;","import stringify from './stringify.js';\nimport parse from './parse.js';\n\nfunction stringToBytes(str) {\n str = unescape(encodeURIComponent(str)); // UTF8 escape\n\n var bytes = [];\n\n for (var i = 0; i < str.length; ++i) {\n bytes.push(str.charCodeAt(i));\n }\n\n return bytes;\n}\n\nexport var DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';\nexport var URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';\nexport default function (name, version, hashfunc) {\n function generateUUID(value, namespace, buf, offset) {\n if (typeof value === 'string') {\n value = stringToBytes(value);\n }\n\n if (typeof namespace === 'string') {\n namespace = parse(namespace);\n }\n\n if (namespace.length !== 16) {\n throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');\n } // Compute hash of namespace and value, Per 4.3\n // Future: Use spread syntax when supported on all platforms, e.g. `bytes =\n // hashfunc([...namespace, ... value])`\n\n\n var bytes = new Uint8Array(16 + value.length);\n bytes.set(namespace);\n bytes.set(value, namespace.length);\n bytes = hashfunc(bytes);\n bytes[6] = bytes[6] & 0x0f | version;\n bytes[8] = bytes[8] & 0x3f | 0x80;\n\n if (buf) {\n offset = offset || 0;\n\n for (var i = 0; i < 16; ++i) {\n buf[offset + i] = bytes[i];\n }\n\n return buf;\n }\n\n return stringify(bytes);\n } // Function#name is not settable on some platforms (#270)\n\n\n try {\n generateUUID.name = name; // eslint-disable-next-line no-empty\n } catch (err) {} // For CommonJS default export support\n\n\n generateUUID.DNS = DNS;\n generateUUID.URL = URL;\n return generateUUID;\n}","/*\n * Browser-compatible JavaScript MD5\n *\n * Modification of JavaScript MD5\n * https://github.com/blueimp/JavaScript-MD5\n *\n * Copyright 2011, Sebastian Tschan\n * https://blueimp.net\n *\n * Licensed under the MIT license:\n * https://opensource.org/licenses/MIT\n *\n * Based on\n * A JavaScript implementation of the RSA Data Security, Inc. MD5 Message\n * Digest Algorithm, as defined in RFC 1321.\n * Version 2.2 Copyright (C) Paul Johnston 1999 - 2009\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n * Distributed under the BSD License\n * See http://pajhome.org.uk/crypt/md5 for more info.\n */\nfunction md5(bytes) {\n if (typeof bytes === 'string') {\n var msg = unescape(encodeURIComponent(bytes)); // UTF8 escape\n\n bytes = new Uint8Array(msg.length);\n\n for (var i = 0; i < msg.length; ++i) {\n bytes[i] = msg.charCodeAt(i);\n }\n }\n\n return md5ToHexEncodedArray(wordsToMd5(bytesToWords(bytes), bytes.length * 8));\n}\n/*\n * Convert an array of little-endian words to an array of bytes\n */\n\n\nfunction md5ToHexEncodedArray(input) {\n var output = [];\n var length32 = input.length * 32;\n var hexTab = '0123456789abcdef';\n\n for (var i = 0; i < length32; i += 8) {\n var x = input[i >> 5] >>> i % 32 & 0xff;\n var hex = parseInt(hexTab.charAt(x >>> 4 & 0x0f) + hexTab.charAt(x & 0x0f), 16);\n output.push(hex);\n }\n\n return output;\n}\n/**\n * Calculate output length with padding and bit length\n */\n\n\nfunction getOutputLength(inputLength8) {\n return (inputLength8 + 64 >>> 9 << 4) + 14 + 1;\n}\n/*\n * Calculate the MD5 of an array of little-endian words, and a bit length.\n */\n\n\nfunction wordsToMd5(x, len) {\n /* append padding */\n x[len >> 5] |= 0x80 << len % 32;\n x[getOutputLength(len) - 1] = len;\n var a = 1732584193;\n var b = -271733879;\n var c = -1732584194;\n var d = 271733878;\n\n for (var i = 0; i < x.length; i += 16) {\n var olda = a;\n var oldb = b;\n var oldc = c;\n var oldd = d;\n a = md5ff(a, b, c, d, x[i], 7, -680876936);\n d = md5ff(d, a, b, c, x[i + 1], 12, -389564586);\n c = md5ff(c, d, a, b, x[i + 2], 17, 606105819);\n b = md5ff(b, c, d, a, x[i + 3], 22, -1044525330);\n a = md5ff(a, b, c, d, x[i + 4], 7, -176418897);\n d = md5ff(d, a, b, c, x[i + 5], 12, 1200080426);\n c = md5ff(c, d, a, b, x[i + 6], 17, -1473231341);\n b = md5ff(b, c, d, a, x[i + 7], 22, -45705983);\n a = md5ff(a, b, c, d, x[i + 8], 7, 1770035416);\n d = md5ff(d, a, b, c, x[i + 9], 12, -1958414417);\n c = md5ff(c, d, a, b, x[i + 10], 17, -42063);\n b = md5ff(b, c, d, a, x[i + 11], 22, -1990404162);\n a = md5ff(a, b, c, d, x[i + 12], 7, 1804603682);\n d = md5ff(d, a, b, c, x[i + 13], 12, -40341101);\n c = md5ff(c, d, a, b, x[i + 14], 17, -1502002290);\n b = md5ff(b, c, d, a, x[i + 15], 22, 1236535329);\n a = md5gg(a, b, c, d, x[i + 1], 5, -165796510);\n d = md5gg(d, a, b, c, x[i + 6], 9, -1069501632);\n c = md5gg(c, d, a, b, x[i + 11], 14, 643717713);\n b = md5gg(b, c, d, a, x[i], 20, -373897302);\n a = md5gg(a, b, c, d, x[i + 5], 5, -701558691);\n d = md5gg(d, a, b, c, x[i + 10], 9, 38016083);\n c = md5gg(c, d, a, b, x[i + 15], 14, -660478335);\n b = md5gg(b, c, d, a, x[i + 4], 20, -405537848);\n a = md5gg(a, b, c, d, x[i + 9], 5, 568446438);\n d = md5gg(d, a, b, c, x[i + 14], 9, -1019803690);\n c = md5gg(c, d, a, b, x[i + 3], 14, -187363961);\n b = md5gg(b, c, d, a, x[i + 8], 20, 1163531501);\n a = md5gg(a, b, c, d, x[i + 13], 5, -1444681467);\n d = md5gg(d, a, b, c, x[i + 2], 9, -51403784);\n c = md5gg(c, d, a, b, x[i + 7], 14, 1735328473);\n b = md5gg(b, c, d, a, x[i + 12], 20, -1926607734);\n a = md5hh(a, b, c, d, x[i + 5], 4, -378558);\n d = md5hh(d, a, b, c, x[i + 8], 11, -2022574463);\n c = md5hh(c, d, a, b, x[i + 11], 16, 1839030562);\n b = md5hh(b, c, d, a, x[i + 14], 23, -35309556);\n a = md5hh(a, b, c, d, x[i + 1], 4, -1530992060);\n d = md5hh(d, a, b, c, x[i + 4], 11, 1272893353);\n c = md5hh(c, d, a, b, x[i + 7], 16, -155497632);\n b = md5hh(b, c, d, a, x[i + 10], 23, -1094730640);\n a = md5hh(a, b, c, d, x[i + 13], 4, 681279174);\n d = md5hh(d, a, b, c, x[i], 11, -358537222);\n c = md5hh(c, d, a, b, x[i + 3], 16, -722521979);\n b = md5hh(b, c, d, a, x[i + 6], 23, 76029189);\n a = md5hh(a, b, c, d, x[i + 9], 4, -640364487);\n d = md5hh(d, a, b, c, x[i + 12], 11, -421815835);\n c = md5hh(c, d, a, b, x[i + 15], 16, 530742520);\n b = md5hh(b, c, d, a, x[i + 2], 23, -995338651);\n a = md5ii(a, b, c, d, x[i], 6, -198630844);\n d = md5ii(d, a, b, c, x[i + 7], 10, 1126891415);\n c = md5ii(c, d, a, b, x[i + 14], 15, -1416354905);\n b = md5ii(b, c, d, a, x[i + 5], 21, -57434055);\n a = md5ii(a, b, c, d, x[i + 12], 6, 1700485571);\n d = md5ii(d, a, b, c, x[i + 3], 10, -1894986606);\n c = md5ii(c, d, a, b, x[i + 10], 15, -1051523);\n b = md5ii(b, c, d, a, x[i + 1], 21, -2054922799);\n a = md5ii(a, b, c, d, x[i + 8], 6, 1873313359);\n d = md5ii(d, a, b, c, x[i + 15], 10, -30611744);\n c = md5ii(c, d, a, b, x[i + 6], 15, -1560198380);\n b = md5ii(b, c, d, a, x[i + 13], 21, 1309151649);\n a = md5ii(a, b, c, d, x[i + 4], 6, -145523070);\n d = md5ii(d, a, b, c, x[i + 11], 10, -1120210379);\n c = md5ii(c, d, a, b, x[i + 2], 15, 718787259);\n b = md5ii(b, c, d, a, x[i + 9], 21, -343485551);\n a = safeAdd(a, olda);\n b = safeAdd(b, oldb);\n c = safeAdd(c, oldc);\n d = safeAdd(d, oldd);\n }\n\n return [a, b, c, d];\n}\n/*\n * Convert an array bytes to an array of little-endian words\n * Characters >255 have their high-byte silently ignored.\n */\n\n\nfunction bytesToWords(input) {\n if (input.length === 0) {\n return [];\n }\n\n var length8 = input.length * 8;\n var output = new Uint32Array(getOutputLength(length8));\n\n for (var i = 0; i < length8; i += 8) {\n output[i >> 5] |= (input[i / 8] & 0xff) << i % 32;\n }\n\n return output;\n}\n/*\n * Add integers, wrapping at 2^32. This uses 16-bit operations internally\n * to work around bugs in some JS interpreters.\n */\n\n\nfunction safeAdd(x, y) {\n var lsw = (x & 0xffff) + (y & 0xffff);\n var msw = (x >> 16) + (y >> 16) + (lsw >> 16);\n return msw << 16 | lsw & 0xffff;\n}\n/*\n * Bitwise rotate a 32-bit number to the left.\n */\n\n\nfunction bitRotateLeft(num, cnt) {\n return num << cnt | num >>> 32 - cnt;\n}\n/*\n * These functions implement the four basic operations the algorithm uses.\n */\n\n\nfunction md5cmn(q, a, b, x, s, t) {\n return safeAdd(bitRotateLeft(safeAdd(safeAdd(a, q), safeAdd(x, t)), s), b);\n}\n\nfunction md5ff(a, b, c, d, x, s, t) {\n return md5cmn(b & c | ~b & d, a, b, x, s, t);\n}\n\nfunction md5gg(a, b, c, d, x, s, t) {\n return md5cmn(b & d | c & ~d, a, b, x, s, t);\n}\n\nfunction md5hh(a, b, c, d, x, s, t) {\n return md5cmn(b ^ c ^ d, a, b, x, s, t);\n}\n\nfunction md5ii(a, b, c, d, x, s, t) {\n return md5cmn(c ^ (b | ~d), a, b, x, s, t);\n}\n\nexport default md5;","import v35 from './v35.js';\nimport md5 from './md5.js';\nvar v3 = v35('v3', 0x30, md5);\nexport default v3;","import rng from './rng.js';\nimport stringify from './stringify.js';\n\nfunction v4(options, buf, offset) {\n options = options || {};\n var rnds = options.random || (options.rng || rng)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n\n rnds[6] = rnds[6] & 0x0f | 0x40;\n rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided\n\n if (buf) {\n offset = offset || 0;\n\n for (var i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n\n return buf;\n }\n\n return stringify(rnds);\n}\n\nexport default v4;","// Adapted from Chris Veness' SHA1 code at\n// http://www.movable-type.co.uk/scripts/sha1.html\nfunction f(s, x, y, z) {\n switch (s) {\n case 0:\n return x & y ^ ~x & z;\n\n case 1:\n return x ^ y ^ z;\n\n case 2:\n return x & y ^ x & z ^ y & z;\n\n case 3:\n return x ^ y ^ z;\n }\n}\n\nfunction ROTL(x, n) {\n return x << n | x >>> 32 - n;\n}\n\nfunction sha1(bytes) {\n var K = [0x5a827999, 0x6ed9eba1, 0x8f1bbcdc, 0xca62c1d6];\n var H = [0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0];\n\n if (typeof bytes === 'string') {\n var msg = unescape(encodeURIComponent(bytes)); // UTF8 escape\n\n bytes = [];\n\n for (var i = 0; i < msg.length; ++i) {\n bytes.push(msg.charCodeAt(i));\n }\n } else if (!Array.isArray(bytes)) {\n // Convert Array-like to Array\n bytes = Array.prototype.slice.call(bytes);\n }\n\n bytes.push(0x80);\n var l = bytes.length / 4 + 2;\n var N = Math.ceil(l / 16);\n var M = new Array(N);\n\n for (var _i = 0; _i < N; ++_i) {\n var arr = new Uint32Array(16);\n\n for (var j = 0; j < 16; ++j) {\n arr[j] = bytes[_i * 64 + j * 4] << 24 | bytes[_i * 64 + j * 4 + 1] << 16 | bytes[_i * 64 + j * 4 + 2] << 8 | bytes[_i * 64 + j * 4 + 3];\n }\n\n M[_i] = arr;\n }\n\n M[N - 1][14] = (bytes.length - 1) * 8 / Math.pow(2, 32);\n M[N - 1][14] = Math.floor(M[N - 1][14]);\n M[N - 1][15] = (bytes.length - 1) * 8 & 0xffffffff;\n\n for (var _i2 = 0; _i2 < N; ++_i2) {\n var W = new Uint32Array(80);\n\n for (var t = 0; t < 16; ++t) {\n W[t] = M[_i2][t];\n }\n\n for (var _t = 16; _t < 80; ++_t) {\n W[_t] = ROTL(W[_t - 3] ^ W[_t - 8] ^ W[_t - 14] ^ W[_t - 16], 1);\n }\n\n var a = H[0];\n var b = H[1];\n var c = H[2];\n var d = H[3];\n var e = H[4];\n\n for (var _t2 = 0; _t2 < 80; ++_t2) {\n var s = Math.floor(_t2 / 20);\n var T = ROTL(a, 5) + f(s, b, c, d) + e + K[s] + W[_t2] >>> 0;\n e = d;\n d = c;\n c = ROTL(b, 30) >>> 0;\n b = a;\n a = T;\n }\n\n H[0] = H[0] + a >>> 0;\n H[1] = H[1] + b >>> 0;\n H[2] = H[2] + c >>> 0;\n H[3] = H[3] + d >>> 0;\n H[4] = H[4] + e >>> 0;\n }\n\n return [H[0] >> 24 & 0xff, H[0] >> 16 & 0xff, H[0] >> 8 & 0xff, H[0] & 0xff, H[1] >> 24 & 0xff, H[1] >> 16 & 0xff, H[1] >> 8 & 0xff, H[1] & 0xff, H[2] >> 24 & 0xff, H[2] >> 16 & 0xff, H[2] >> 8 & 0xff, H[2] & 0xff, H[3] >> 24 & 0xff, H[3] >> 16 & 0xff, H[3] >> 8 & 0xff, H[3] & 0xff, H[4] >> 24 & 0xff, H[4] >> 16 & 0xff, H[4] >> 8 & 0xff, H[4] & 0xff];\n}\n\nexport default sha1;","import v35 from './v35.js';\nimport sha1 from './sha1.js';\nvar v5 = v35('v5', 0x50, sha1);\nexport default v5;","export default '00000000-0000-0000-0000-000000000000';","import validate from './validate.js';\n\nfunction version(uuid) {\n if (!validate(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n return parseInt(uuid.substr(14, 1), 16);\n}\n\nexport default version;","import { __assign } from \"tslib\";\r\nimport { InternalTexture, InternalTextureSource } from '../../Materials/Textures/internalTexture';\r\nimport { Logger } from '../../Misc/logger';\r\nimport { RenderTargetCreationOptions } from '../../Materials/Textures/renderTargetCreationOptions';\r\nimport { ThinEngine } from '../thinEngine';\r\nThinEngine.prototype.createRenderTargetTexture = function (size, options) {\r\n var fullOptions = new RenderTargetCreationOptions();\r\n if (options !== undefined && typeof options === \"object\") {\r\n fullOptions.generateMipMaps = options.generateMipMaps;\r\n fullOptions.generateDepthBuffer = !!options.generateDepthBuffer;\r\n fullOptions.generateStencilBuffer = !!options.generateStencilBuffer;\r\n fullOptions.type = options.type === undefined ? 0 : options.type;\r\n fullOptions.samplingMode = options.samplingMode === undefined ? 3 : options.samplingMode;\r\n fullOptions.format = options.format === undefined ? 5 : options.format;\r\n }\r\n else {\r\n fullOptions.generateMipMaps = options;\r\n fullOptions.generateDepthBuffer = true;\r\n fullOptions.generateStencilBuffer = false;\r\n fullOptions.type = 0;\r\n fullOptions.samplingMode = 3;\r\n fullOptions.format = 5;\r\n }\r\n if (fullOptions.type === 1 && !this._caps.textureFloatLinearFiltering) {\r\n // if floating point linear (gl.FLOAT) then force to NEAREST_SAMPLINGMODE\r\n fullOptions.samplingMode = 1;\r\n }\r\n else if (fullOptions.type === 2 && !this._caps.textureHalfFloatLinearFiltering) {\r\n // if floating point linear (HALF_FLOAT) then force to NEAREST_SAMPLINGMODE\r\n fullOptions.samplingMode = 1;\r\n }\r\n if (fullOptions.type === 1 && !this._caps.textureFloat) {\r\n fullOptions.type = 0;\r\n Logger.Warn(\"Float textures are not supported. Render target forced to TEXTURETYPE_UNSIGNED_BYTE type\");\r\n }\r\n var gl = this._gl;\r\n var texture = new InternalTexture(this, InternalTextureSource.RenderTarget);\r\n var width = size.width || size;\r\n var height = size.height || size;\r\n var layers = size.layers || 0;\r\n var filters = this._getSamplingParameters(fullOptions.samplingMode, fullOptions.generateMipMaps ? true : false);\r\n var target = layers !== 0 ? gl.TEXTURE_2D_ARRAY : gl.TEXTURE_2D;\r\n var sizedFormat = this._getRGBABufferInternalSizedFormat(fullOptions.type, fullOptions.format);\r\n var internalFormat = this._getInternalFormat(fullOptions.format);\r\n var type = this._getWebGLTextureType(fullOptions.type);\r\n // Bind\r\n this._bindTextureDirectly(target, texture);\r\n if (layers !== 0) {\r\n texture.is2DArray = true;\r\n gl.texImage3D(target, 0, sizedFormat, width, height, layers, 0, internalFormat, type, null);\r\n }\r\n else {\r\n gl.texImage2D(target, 0, sizedFormat, width, height, 0, internalFormat, type, null);\r\n }\r\n gl.texParameteri(target, gl.TEXTURE_MAG_FILTER, filters.mag);\r\n gl.texParameteri(target, gl.TEXTURE_MIN_FILTER, filters.min);\r\n gl.texParameteri(target, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\r\n gl.texParameteri(target, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\r\n // MipMaps\r\n if (fullOptions.generateMipMaps) {\r\n this._gl.generateMipmap(target);\r\n }\r\n this._bindTextureDirectly(target, null);\r\n // Create the framebuffer\r\n var framebuffer = gl.createFramebuffer();\r\n this._bindUnboundFramebuffer(framebuffer);\r\n texture._depthStencilBuffer = this._setupFramebufferDepthAttachments(fullOptions.generateStencilBuffer ? true : false, fullOptions.generateDepthBuffer, width, height);\r\n // No need to rebind on every frame\r\n if (!texture.is2DArray) {\r\n gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture._webGLTexture, 0);\r\n }\r\n this._bindUnboundFramebuffer(null);\r\n texture._framebuffer = framebuffer;\r\n texture.baseWidth = width;\r\n texture.baseHeight = height;\r\n texture.width = width;\r\n texture.height = height;\r\n texture.depth = layers;\r\n texture.isReady = true;\r\n texture.samples = 1;\r\n texture.generateMipMaps = fullOptions.generateMipMaps ? true : false;\r\n texture.samplingMode = fullOptions.samplingMode;\r\n texture.type = fullOptions.type;\r\n texture.format = fullOptions.format;\r\n texture._generateDepthBuffer = fullOptions.generateDepthBuffer;\r\n texture._generateStencilBuffer = fullOptions.generateStencilBuffer ? true : false;\r\n this._internalTexturesCache.push(texture);\r\n return texture;\r\n};\r\nThinEngine.prototype.createDepthStencilTexture = function (size, options) {\r\n if (options.isCube) {\r\n var width = size.width || size;\r\n return this._createDepthStencilCubeTexture(width, options);\r\n }\r\n else {\r\n return this._createDepthStencilTexture(size, options);\r\n }\r\n};\r\nThinEngine.prototype._createDepthStencilTexture = function (size, options) {\r\n var gl = this._gl;\r\n var layers = size.layers || 0;\r\n var target = layers !== 0 ? gl.TEXTURE_2D_ARRAY : gl.TEXTURE_2D;\r\n var internalTexture = new InternalTexture(this, InternalTextureSource.Depth);\r\n if (!this._caps.depthTextureExtension) {\r\n Logger.Error(\"Depth texture is not supported by your browser or hardware.\");\r\n return internalTexture;\r\n }\r\n var internalOptions = __assign({ bilinearFiltering: false, comparisonFunction: 0, generateStencil: false }, options);\r\n this._bindTextureDirectly(target, internalTexture, true);\r\n this._setupDepthStencilTexture(internalTexture, size, internalOptions.generateStencil, internalOptions.bilinearFiltering, internalOptions.comparisonFunction);\r\n var type = internalOptions.generateStencil ? gl.UNSIGNED_INT_24_8 : gl.UNSIGNED_INT;\r\n var internalFormat = internalOptions.generateStencil ? gl.DEPTH_STENCIL : gl.DEPTH_COMPONENT;\r\n var sizedFormat = internalFormat;\r\n if (this.webGLVersion > 1) {\r\n sizedFormat = internalOptions.generateStencil ? gl.DEPTH24_STENCIL8 : gl.DEPTH_COMPONENT24;\r\n }\r\n if (internalTexture.is2DArray) {\r\n gl.texImage3D(target, 0, sizedFormat, internalTexture.width, internalTexture.height, layers, 0, internalFormat, type, null);\r\n }\r\n else {\r\n gl.texImage2D(target, 0, sizedFormat, internalTexture.width, internalTexture.height, 0, internalFormat, type, null);\r\n }\r\n this._bindTextureDirectly(target, null);\r\n return internalTexture;\r\n};\r\n//# sourceMappingURL=engine.renderTarget.js.map","import { __assign } from \"tslib\";\r\nimport { InternalTexture, InternalTextureSource } from '../../Materials/Textures/internalTexture';\r\nimport { Logger } from '../../Misc/logger';\r\nimport { ThinEngine } from '../thinEngine';\r\nThinEngine.prototype.createRenderTargetCubeTexture = function (size, options) {\r\n var fullOptions = __assign({ generateMipMaps: true, generateDepthBuffer: true, generateStencilBuffer: false, type: 0, samplingMode: 3, format: 5 }, options);\r\n fullOptions.generateStencilBuffer = fullOptions.generateDepthBuffer && fullOptions.generateStencilBuffer;\r\n if (fullOptions.type === 1 && !this._caps.textureFloatLinearFiltering) {\r\n // if floating point linear (gl.FLOAT) then force to NEAREST_SAMPLINGMODE\r\n fullOptions.samplingMode = 1;\r\n }\r\n else if (fullOptions.type === 2 && !this._caps.textureHalfFloatLinearFiltering) {\r\n // if floating point linear (HALF_FLOAT) then force to NEAREST_SAMPLINGMODE\r\n fullOptions.samplingMode = 1;\r\n }\r\n var gl = this._gl;\r\n var texture = new InternalTexture(this, InternalTextureSource.RenderTarget);\r\n this._bindTextureDirectly(gl.TEXTURE_CUBE_MAP, texture, true);\r\n var filters = this._getSamplingParameters(fullOptions.samplingMode, fullOptions.generateMipMaps);\r\n if (fullOptions.type === 1 && !this._caps.textureFloat) {\r\n fullOptions.type = 0;\r\n Logger.Warn(\"Float textures are not supported. Cube render target forced to TEXTURETYPE_UNESIGNED_BYTE type\");\r\n }\r\n gl.texParameteri(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_MAG_FILTER, filters.mag);\r\n gl.texParameteri(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_MIN_FILTER, filters.min);\r\n gl.texParameteri(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\r\n gl.texParameteri(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\r\n for (var face = 0; face < 6; face++) {\r\n gl.texImage2D((gl.TEXTURE_CUBE_MAP_POSITIVE_X + face), 0, this._getRGBABufferInternalSizedFormat(fullOptions.type, fullOptions.format), size, size, 0, this._getInternalFormat(fullOptions.format), this._getWebGLTextureType(fullOptions.type), null);\r\n }\r\n // Create the framebuffer\r\n var framebuffer = gl.createFramebuffer();\r\n this._bindUnboundFramebuffer(framebuffer);\r\n texture._depthStencilBuffer = this._setupFramebufferDepthAttachments(fullOptions.generateStencilBuffer, fullOptions.generateDepthBuffer, size, size);\r\n // MipMaps\r\n if (fullOptions.generateMipMaps) {\r\n gl.generateMipmap(gl.TEXTURE_CUBE_MAP);\r\n }\r\n // Unbind\r\n this._bindTextureDirectly(gl.TEXTURE_CUBE_MAP, null);\r\n this._bindUnboundFramebuffer(null);\r\n texture._framebuffer = framebuffer;\r\n texture.width = size;\r\n texture.height = size;\r\n texture.isReady = true;\r\n texture.isCube = true;\r\n texture.samples = 1;\r\n texture.generateMipMaps = fullOptions.generateMipMaps;\r\n texture.samplingMode = fullOptions.samplingMode;\r\n texture.type = fullOptions.type;\r\n texture.format = fullOptions.format;\r\n texture._generateDepthBuffer = fullOptions.generateDepthBuffer;\r\n texture._generateStencilBuffer = fullOptions.generateStencilBuffer;\r\n this._internalTexturesCache.push(texture);\r\n return texture;\r\n};\r\n//# sourceMappingURL=engine.renderTargetCube.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"../../Misc/observable\";\r\nimport { Tools } from \"../../Misc/tools\";\r\nimport { Matrix, Vector3 } from \"../../Maths/math.vector\";\r\nimport { Texture } from \"../../Materials/Textures/texture\";\r\nimport { PostProcessManager } from \"../../PostProcesses/postProcessManager\";\r\nimport { RenderingManager } from \"../../Rendering/renderingManager\";\r\nimport \"../../Engines/Extensions/engine.renderTarget\";\r\nimport \"../../Engines/Extensions/engine.renderTargetCube\";\r\nimport { Engine } from '../../Engines/engine';\r\n/**\r\n * This Helps creating a texture that will be created from a camera in your scene.\r\n * It is basically a dynamic texture that could be used to create special effects for instance.\r\n * Actually, It is the base of lot of effects in the framework like post process, shadows, effect layers and rendering pipelines...\r\n */\r\nvar RenderTargetTexture = /** @class */ (function (_super) {\r\n __extends(RenderTargetTexture, _super);\r\n /**\r\n * Instantiate a render target texture. This is mainly used to render of screen the scene to for instance apply post processse\r\n * or used a shadow, depth texture...\r\n * @param name The friendly name of the texture\r\n * @param size The size of the RTT (number if square, or {width: number, height:number} or {ratio:} to define a ratio from the main scene)\r\n * @param scene The scene the RTT belongs to. The latest created scene will be used if not precised.\r\n * @param generateMipMaps True if mip maps need to be generated after render.\r\n * @param doNotChangeAspectRatio True to not change the aspect ratio of the scene in the RTT\r\n * @param type The type of the buffer in the RTT (int, half float, float...)\r\n * @param isCube True if a cube texture needs to be created\r\n * @param samplingMode The sampling mode to be usedwith the render target (Linear, Nearest...)\r\n * @param generateDepthBuffer True to generate a depth buffer\r\n * @param generateStencilBuffer True to generate a stencil buffer\r\n * @param isMulti True if multiple textures need to be created (Draw Buffers)\r\n * @param format The internal format of the buffer in the RTT (RED, RG, RGB, RGBA, ALPHA...)\r\n * @param delayAllocation if the texture allocation should be delayed (default: false)\r\n */\r\n function RenderTargetTexture(name, size, scene, generateMipMaps, doNotChangeAspectRatio, type, isCube, samplingMode, generateDepthBuffer, generateStencilBuffer, isMulti, format, delayAllocation) {\r\n if (doNotChangeAspectRatio === void 0) { doNotChangeAspectRatio = true; }\r\n if (type === void 0) { type = 0; }\r\n if (isCube === void 0) { isCube = false; }\r\n if (samplingMode === void 0) { samplingMode = Texture.TRILINEAR_SAMPLINGMODE; }\r\n if (generateDepthBuffer === void 0) { generateDepthBuffer = true; }\r\n if (generateStencilBuffer === void 0) { generateStencilBuffer = false; }\r\n if (isMulti === void 0) { isMulti = false; }\r\n if (format === void 0) { format = 5; }\r\n if (delayAllocation === void 0) { delayAllocation = false; }\r\n var _this = _super.call(this, null, scene, !generateMipMaps) || this;\r\n _this.isCube = isCube;\r\n /**\r\n * Define if particles should be rendered in your texture.\r\n */\r\n _this.renderParticles = true;\r\n /**\r\n * Define if sprites should be rendered in your texture.\r\n */\r\n _this.renderSprites = false;\r\n /**\r\n * Override the default coordinates mode to projection for RTT as it is the most common case for rendered textures.\r\n */\r\n _this.coordinatesMode = Texture.PROJECTION_MODE;\r\n /**\r\n * Define if the camera viewport should be respected while rendering the texture or if the render should be done to the entire texture.\r\n */\r\n _this.ignoreCameraViewport = false;\r\n /**\r\n * An event triggered when the texture is unbind.\r\n */\r\n _this.onBeforeBindObservable = new Observable();\r\n /**\r\n * An event triggered when the texture is unbind.\r\n */\r\n _this.onAfterUnbindObservable = new Observable();\r\n /**\r\n * An event triggered before rendering the texture\r\n */\r\n _this.onBeforeRenderObservable = new Observable();\r\n /**\r\n * An event triggered after rendering the texture\r\n */\r\n _this.onAfterRenderObservable = new Observable();\r\n /**\r\n * An event triggered after the texture clear\r\n */\r\n _this.onClearObservable = new Observable();\r\n /**\r\n * An event triggered when the texture is resized.\r\n */\r\n _this.onResizeObservable = new Observable();\r\n _this._currentRefreshId = -1;\r\n _this._refreshRate = 1;\r\n _this._samples = 1;\r\n /**\r\n * Gets or sets the center of the bounding box associated with the texture (when in cube mode)\r\n * It must define where the camera used to render the texture is set\r\n */\r\n _this.boundingBoxPosition = Vector3.Zero();\r\n scene = _this.getScene();\r\n if (!scene) {\r\n return _this;\r\n }\r\n _this.renderList = new Array();\r\n _this._engine = scene.getEngine();\r\n _this.name = name;\r\n _this.isRenderTarget = true;\r\n _this._initialSizeParameter = size;\r\n _this._processSizeParameter(size);\r\n _this._resizeObserver = _this.getScene().getEngine().onResizeObservable.add(function () {\r\n });\r\n _this._generateMipMaps = generateMipMaps ? true : false;\r\n _this._doNotChangeAspectRatio = doNotChangeAspectRatio;\r\n // Rendering groups\r\n _this._renderingManager = new RenderingManager(scene);\r\n _this._renderingManager._useSceneAutoClearSetup = true;\r\n if (isMulti) {\r\n return _this;\r\n }\r\n _this._renderTargetOptions = {\r\n generateMipMaps: generateMipMaps,\r\n type: type,\r\n format: format,\r\n samplingMode: samplingMode,\r\n generateDepthBuffer: generateDepthBuffer,\r\n generateStencilBuffer: generateStencilBuffer\r\n };\r\n if (samplingMode === Texture.NEAREST_SAMPLINGMODE) {\r\n _this.wrapU = Texture.CLAMP_ADDRESSMODE;\r\n _this.wrapV = Texture.CLAMP_ADDRESSMODE;\r\n }\r\n if (!delayAllocation) {\r\n if (isCube) {\r\n _this._texture = scene.getEngine().createRenderTargetCubeTexture(_this.getRenderSize(), _this._renderTargetOptions);\r\n _this.coordinatesMode = Texture.INVCUBIC_MODE;\r\n _this._textureMatrix = Matrix.Identity();\r\n }\r\n else {\r\n _this._texture = scene.getEngine().createRenderTargetTexture(_this._size, _this._renderTargetOptions);\r\n }\r\n }\r\n return _this;\r\n }\r\n Object.defineProperty(RenderTargetTexture.prototype, \"renderList\", {\r\n /**\r\n * Use this list to define the list of mesh you want to render.\r\n */\r\n get: function () {\r\n return this._renderList;\r\n },\r\n set: function (value) {\r\n this._renderList = value;\r\n if (this._renderList) {\r\n this._hookArray(this._renderList);\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n RenderTargetTexture.prototype._hookArray = function (array) {\r\n var _this = this;\r\n var oldPush = array.push;\r\n array.push = function () {\r\n var items = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n items[_i] = arguments[_i];\r\n }\r\n var wasEmpty = array.length === 0;\r\n var result = oldPush.apply(array, items);\r\n if (wasEmpty) {\r\n _this.getScene().meshes.forEach(function (mesh) {\r\n mesh._markSubMeshesAsLightDirty();\r\n });\r\n }\r\n return result;\r\n };\r\n var oldSplice = array.splice;\r\n array.splice = function (index, deleteCount) {\r\n var deleted = oldSplice.apply(array, [index, deleteCount]);\r\n if (array.length === 0) {\r\n _this.getScene().meshes.forEach(function (mesh) {\r\n mesh._markSubMeshesAsLightDirty();\r\n });\r\n }\r\n return deleted;\r\n };\r\n };\r\n Object.defineProperty(RenderTargetTexture.prototype, \"onAfterUnbind\", {\r\n /**\r\n * Set a after unbind callback in the texture.\r\n * This has been kept for backward compatibility and use of onAfterUnbindObservable is recommended.\r\n */\r\n set: function (callback) {\r\n if (this._onAfterUnbindObserver) {\r\n this.onAfterUnbindObservable.remove(this._onAfterUnbindObserver);\r\n }\r\n this._onAfterUnbindObserver = this.onAfterUnbindObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(RenderTargetTexture.prototype, \"onBeforeRender\", {\r\n /**\r\n * Set a before render callback in the texture.\r\n * This has been kept for backward compatibility and use of onBeforeRenderObservable is recommended.\r\n */\r\n set: function (callback) {\r\n if (this._onBeforeRenderObserver) {\r\n this.onBeforeRenderObservable.remove(this._onBeforeRenderObserver);\r\n }\r\n this._onBeforeRenderObserver = this.onBeforeRenderObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(RenderTargetTexture.prototype, \"onAfterRender\", {\r\n /**\r\n * Set a after render callback in the texture.\r\n * This has been kept for backward compatibility and use of onAfterRenderObservable is recommended.\r\n */\r\n set: function (callback) {\r\n if (this._onAfterRenderObserver) {\r\n this.onAfterRenderObservable.remove(this._onAfterRenderObserver);\r\n }\r\n this._onAfterRenderObserver = this.onAfterRenderObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(RenderTargetTexture.prototype, \"onClear\", {\r\n /**\r\n * Set a clear callback in the texture.\r\n * This has been kept for backward compatibility and use of onClearObservable is recommended.\r\n */\r\n set: function (callback) {\r\n if (this._onClearObserver) {\r\n this.onClearObservable.remove(this._onClearObserver);\r\n }\r\n this._onClearObserver = this.onClearObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(RenderTargetTexture.prototype, \"renderTargetOptions\", {\r\n /**\r\n * Gets render target creation options that were used.\r\n */\r\n get: function () {\r\n return this._renderTargetOptions;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n RenderTargetTexture.prototype._onRatioRescale = function () {\r\n if (this._sizeRatio) {\r\n this.resize(this._initialSizeParameter);\r\n }\r\n };\r\n Object.defineProperty(RenderTargetTexture.prototype, \"boundingBoxSize\", {\r\n get: function () {\r\n return this._boundingBoxSize;\r\n },\r\n /**\r\n * Gets or sets the size of the bounding box associated with the texture (when in cube mode)\r\n * When defined, the cubemap will switch to local mode\r\n * @see https://community.arm.com/graphics/b/blog/posts/reflections-based-on-local-cubemaps-in-unity\r\n * @example https://www.babylonjs-playground.com/#RNASML\r\n */\r\n set: function (value) {\r\n if (this._boundingBoxSize && this._boundingBoxSize.equals(value)) {\r\n return;\r\n }\r\n this._boundingBoxSize = value;\r\n var scene = this.getScene();\r\n if (scene) {\r\n scene.markAllMaterialsAsDirty(1);\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(RenderTargetTexture.prototype, \"depthStencilTexture\", {\r\n /**\r\n * In case the RTT has been created with a depth texture, get the associated\r\n * depth texture.\r\n * Otherwise, return null.\r\n */\r\n get: function () {\r\n var _a;\r\n return ((_a = this.getInternalTexture()) === null || _a === void 0 ? void 0 : _a._depthStencilTexture) || null;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Creates a depth stencil texture.\r\n * This is only available in WebGL 2 or with the depth texture extension available.\r\n * @param comparisonFunction Specifies the comparison function to set on the texture. If 0 or undefined, the texture is not in comparison mode\r\n * @param bilinearFiltering Specifies whether or not bilinear filtering is enable on the texture\r\n * @param generateStencil Specifies whether or not a stencil should be allocated in the texture\r\n */\r\n RenderTargetTexture.prototype.createDepthStencilTexture = function (comparisonFunction, bilinearFiltering, generateStencil) {\r\n if (comparisonFunction === void 0) { comparisonFunction = 0; }\r\n if (bilinearFiltering === void 0) { bilinearFiltering = true; }\r\n if (generateStencil === void 0) { generateStencil = false; }\r\n var internalTexture = this.getInternalTexture();\r\n if (!this.getScene() || !internalTexture) {\r\n return;\r\n }\r\n var engine = this.getScene().getEngine();\r\n internalTexture._depthStencilTexture = engine.createDepthStencilTexture(this._size, {\r\n bilinearFiltering: bilinearFiltering,\r\n comparisonFunction: comparisonFunction,\r\n generateStencil: generateStencil,\r\n isCube: this.isCube\r\n });\r\n };\r\n RenderTargetTexture.prototype._processSizeParameter = function (size) {\r\n if (size.ratio) {\r\n this._sizeRatio = size.ratio;\r\n this._size = {\r\n width: this._bestReflectionRenderTargetDimension(this._engine.getRenderWidth(), this._sizeRatio),\r\n height: this._bestReflectionRenderTargetDimension(this._engine.getRenderHeight(), this._sizeRatio)\r\n };\r\n }\r\n else {\r\n this._size = size;\r\n }\r\n };\r\n Object.defineProperty(RenderTargetTexture.prototype, \"samples\", {\r\n /**\r\n * Define the number of samples to use in case of MSAA.\r\n * It defaults to one meaning no MSAA has been enabled.\r\n */\r\n get: function () {\r\n return this._samples;\r\n },\r\n set: function (value) {\r\n if (this._samples === value) {\r\n return;\r\n }\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n this._samples = scene.getEngine().updateRenderTargetTextureSampleCount(this._texture, value);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Resets the refresh counter of the texture and start bak from scratch.\r\n * Could be useful to regenerate the texture if it is setup to render only once.\r\n */\r\n RenderTargetTexture.prototype.resetRefreshCounter = function () {\r\n this._currentRefreshId = -1;\r\n };\r\n Object.defineProperty(RenderTargetTexture.prototype, \"refreshRate\", {\r\n /**\r\n * Define the refresh rate of the texture or the rendering frequency.\r\n * Use 0 to render just once, 1 to render on every frame, 2 to render every two frames and so on...\r\n */\r\n get: function () {\r\n return this._refreshRate;\r\n },\r\n set: function (value) {\r\n this._refreshRate = value;\r\n this.resetRefreshCounter();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Adds a post process to the render target rendering passes.\r\n * @param postProcess define the post process to add\r\n */\r\n RenderTargetTexture.prototype.addPostProcess = function (postProcess) {\r\n if (!this._postProcessManager) {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n this._postProcessManager = new PostProcessManager(scene);\r\n this._postProcesses = new Array();\r\n }\r\n this._postProcesses.push(postProcess);\r\n this._postProcesses[0].autoClear = false;\r\n };\r\n /**\r\n * Clear all the post processes attached to the render target\r\n * @param dispose define if the cleared post processesshould also be disposed (false by default)\r\n */\r\n RenderTargetTexture.prototype.clearPostProcesses = function (dispose) {\r\n if (dispose === void 0) { dispose = false; }\r\n if (!this._postProcesses) {\r\n return;\r\n }\r\n if (dispose) {\r\n for (var _i = 0, _a = this._postProcesses; _i < _a.length; _i++) {\r\n var postProcess = _a[_i];\r\n postProcess.dispose();\r\n }\r\n }\r\n this._postProcesses = [];\r\n };\r\n /**\r\n * Remove one of the post process from the list of attached post processes to the texture\r\n * @param postProcess define the post process to remove from the list\r\n */\r\n RenderTargetTexture.prototype.removePostProcess = function (postProcess) {\r\n if (!this._postProcesses) {\r\n return;\r\n }\r\n var index = this._postProcesses.indexOf(postProcess);\r\n if (index === -1) {\r\n return;\r\n }\r\n this._postProcesses.splice(index, 1);\r\n if (this._postProcesses.length > 0) {\r\n this._postProcesses[0].autoClear = false;\r\n }\r\n };\r\n /** @hidden */\r\n RenderTargetTexture.prototype._shouldRender = function () {\r\n if (this._currentRefreshId === -1) { // At least render once\r\n this._currentRefreshId = 1;\r\n return true;\r\n }\r\n if (this.refreshRate === this._currentRefreshId) {\r\n this._currentRefreshId = 1;\r\n return true;\r\n }\r\n this._currentRefreshId++;\r\n return false;\r\n };\r\n /**\r\n * Gets the actual render size of the texture.\r\n * @returns the width of the render size\r\n */\r\n RenderTargetTexture.prototype.getRenderSize = function () {\r\n return this.getRenderWidth();\r\n };\r\n /**\r\n * Gets the actual render width of the texture.\r\n * @returns the width of the render size\r\n */\r\n RenderTargetTexture.prototype.getRenderWidth = function () {\r\n if (this._size.width) {\r\n return this._size.width;\r\n }\r\n return this._size;\r\n };\r\n /**\r\n * Gets the actual render height of the texture.\r\n * @returns the height of the render size\r\n */\r\n RenderTargetTexture.prototype.getRenderHeight = function () {\r\n if (this._size.width) {\r\n return this._size.height;\r\n }\r\n return this._size;\r\n };\r\n /**\r\n * Gets the actual number of layers of the texture.\r\n * @returns the number of layers\r\n */\r\n RenderTargetTexture.prototype.getRenderLayers = function () {\r\n var layers = this._size.layers;\r\n if (layers) {\r\n return layers;\r\n }\r\n return 0;\r\n };\r\n Object.defineProperty(RenderTargetTexture.prototype, \"canRescale\", {\r\n /**\r\n * Get if the texture can be rescaled or not.\r\n */\r\n get: function () {\r\n return true;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Resize the texture using a ratio.\r\n * @param ratio the ratio to apply to the texture size in order to compute the new target size\r\n */\r\n RenderTargetTexture.prototype.scale = function (ratio) {\r\n var newSize = Math.max(1, this.getRenderSize() * ratio);\r\n this.resize(newSize);\r\n };\r\n /**\r\n * Get the texture reflection matrix used to rotate/transform the reflection.\r\n * @returns the reflection matrix\r\n */\r\n RenderTargetTexture.prototype.getReflectionTextureMatrix = function () {\r\n if (this.isCube) {\r\n return this._textureMatrix;\r\n }\r\n return _super.prototype.getReflectionTextureMatrix.call(this);\r\n };\r\n /**\r\n * Resize the texture to a new desired size.\r\n * Be carrefull as it will recreate all the data in the new texture.\r\n * @param size Define the new size. It can be:\r\n * - a number for squared texture,\r\n * - an object containing { width: number, height: number }\r\n * - or an object containing a ratio { ratio: number }\r\n */\r\n RenderTargetTexture.prototype.resize = function (size) {\r\n var wasCube = this.isCube;\r\n this.releaseInternalTexture();\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n this._processSizeParameter(size);\r\n if (wasCube) {\r\n this._texture = scene.getEngine().createRenderTargetCubeTexture(this.getRenderSize(), this._renderTargetOptions);\r\n }\r\n else {\r\n this._texture = scene.getEngine().createRenderTargetTexture(this._size, this._renderTargetOptions);\r\n }\r\n if (this.onResizeObservable.hasObservers()) {\r\n this.onResizeObservable.notifyObservers(this);\r\n }\r\n };\r\n /**\r\n * Renders all the objects from the render list into the texture.\r\n * @param useCameraPostProcess Define if camera post processes should be used during the rendering\r\n * @param dumpForDebug Define if the rendering result should be dumped (copied) for debugging purpose\r\n */\r\n RenderTargetTexture.prototype.render = function (useCameraPostProcess, dumpForDebug) {\r\n if (useCameraPostProcess === void 0) { useCameraPostProcess = false; }\r\n if (dumpForDebug === void 0) { dumpForDebug = false; }\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n var engine = scene.getEngine();\r\n if (this.useCameraPostProcesses !== undefined) {\r\n useCameraPostProcess = this.useCameraPostProcesses;\r\n }\r\n if (this._waitingRenderList) {\r\n this.renderList = [];\r\n for (var index = 0; index < this._waitingRenderList.length; index++) {\r\n var id = this._waitingRenderList[index];\r\n var mesh_1 = scene.getMeshByID(id);\r\n if (mesh_1) {\r\n this.renderList.push(mesh_1);\r\n }\r\n }\r\n delete this._waitingRenderList;\r\n }\r\n // Is predicate defined?\r\n if (this.renderListPredicate) {\r\n if (this.renderList) {\r\n this.renderList.length = 0; // Clear previous renderList\r\n }\r\n else {\r\n this.renderList = [];\r\n }\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n var sceneMeshes = scene.meshes;\r\n for (var index = 0; index < sceneMeshes.length; index++) {\r\n var mesh = sceneMeshes[index];\r\n if (this.renderListPredicate(mesh)) {\r\n this.renderList.push(mesh);\r\n }\r\n }\r\n }\r\n this.onBeforeBindObservable.notifyObservers(this);\r\n // Set custom projection.\r\n // Needs to be before binding to prevent changing the aspect ratio.\r\n var camera;\r\n if (this.activeCamera) {\r\n camera = this.activeCamera;\r\n engine.setViewport(this.activeCamera.viewport, this.getRenderWidth(), this.getRenderHeight());\r\n if (this.activeCamera !== scene.activeCamera) {\r\n scene.setTransformMatrix(this.activeCamera.getViewMatrix(), this.activeCamera.getProjectionMatrix(true));\r\n }\r\n }\r\n else {\r\n camera = scene.activeCamera;\r\n if (camera) {\r\n engine.setViewport(camera.viewport, this.getRenderWidth(), this.getRenderHeight());\r\n }\r\n }\r\n this._defaultRenderListPrepared = false;\r\n if (this.is2DArray) {\r\n for (var layer = 0; layer < this.getRenderLayers(); layer++) {\r\n this.renderToTarget(0, useCameraPostProcess, dumpForDebug, layer, camera);\r\n scene.incrementRenderId();\r\n scene.resetCachedMaterial();\r\n }\r\n }\r\n else if (this.isCube) {\r\n for (var face = 0; face < 6; face++) {\r\n this.renderToTarget(face, useCameraPostProcess, dumpForDebug, undefined, camera);\r\n scene.incrementRenderId();\r\n scene.resetCachedMaterial();\r\n }\r\n }\r\n else {\r\n this.renderToTarget(0, useCameraPostProcess, dumpForDebug, undefined, camera);\r\n }\r\n this.onAfterUnbindObservable.notifyObservers(this);\r\n if (scene.activeCamera) {\r\n // Do not avoid setting uniforms when multiple scenes are active as another camera may have overwrite these\r\n if (scene.getEngine().scenes.length > 1 || (this.activeCamera && this.activeCamera !== scene.activeCamera)) {\r\n scene.setTransformMatrix(scene.activeCamera.getViewMatrix(), scene.activeCamera.getProjectionMatrix(true));\r\n }\r\n engine.setViewport(scene.activeCamera.viewport);\r\n }\r\n scene.resetCachedMaterial();\r\n };\r\n RenderTargetTexture.prototype._bestReflectionRenderTargetDimension = function (renderDimension, scale) {\r\n var minimum = 128;\r\n var x = renderDimension * scale;\r\n var curved = Engine.NearestPOT(x + (minimum * minimum / (minimum + x)));\r\n // Ensure we don't exceed the render dimension (while staying POT)\r\n return Math.min(Engine.FloorPOT(renderDimension), curved);\r\n };\r\n RenderTargetTexture.prototype._prepareRenderingManager = function (currentRenderList, currentRenderListLength, camera, checkLayerMask) {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n this._renderingManager.reset();\r\n var sceneRenderId = scene.getRenderId();\r\n for (var meshIndex = 0; meshIndex < currentRenderListLength; meshIndex++) {\r\n var mesh = currentRenderList[meshIndex];\r\n if (mesh) {\r\n if (!mesh.isReady(this.refreshRate === 0)) {\r\n this.resetRefreshCounter();\r\n continue;\r\n }\r\n mesh._preActivateForIntermediateRendering(sceneRenderId);\r\n var isMasked = void 0;\r\n if (checkLayerMask && camera) {\r\n isMasked = ((mesh.layerMask & camera.layerMask) === 0);\r\n }\r\n else {\r\n isMasked = false;\r\n }\r\n if (mesh.isEnabled() && mesh.isVisible && mesh.subMeshes && !isMasked) {\r\n if (mesh._activate(sceneRenderId, true) && mesh.subMeshes.length) {\r\n if (!mesh.isAnInstance) {\r\n mesh._internalAbstractMeshDataInfo._onlyForInstancesIntermediate = false;\r\n }\r\n else {\r\n mesh = mesh.sourceMesh;\r\n }\r\n mesh._internalAbstractMeshDataInfo._isActiveIntermediate = true;\r\n for (var subIndex = 0; subIndex < mesh.subMeshes.length; subIndex++) {\r\n var subMesh = mesh.subMeshes[subIndex];\r\n this._renderingManager.dispatch(subMesh, mesh);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n for (var particleIndex = 0; particleIndex < scene.particleSystems.length; particleIndex++) {\r\n var particleSystem = scene.particleSystems[particleIndex];\r\n var emitter = particleSystem.emitter;\r\n if (!particleSystem.isStarted() || !emitter || !emitter.position || !emitter.isEnabled()) {\r\n continue;\r\n }\r\n if (currentRenderList.indexOf(emitter) >= 0) {\r\n this._renderingManager.dispatchParticles(particleSystem);\r\n }\r\n }\r\n };\r\n /**\r\n * @hidden\r\n * @param faceIndex face index to bind to if this is a cubetexture\r\n * @param layer defines the index of the texture to bind in the array\r\n */\r\n RenderTargetTexture.prototype._bindFrameBuffer = function (faceIndex, layer) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (layer === void 0) { layer = 0; }\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n var engine = scene.getEngine();\r\n if (this._texture) {\r\n engine.bindFramebuffer(this._texture, this.isCube ? faceIndex : undefined, undefined, undefined, this.ignoreCameraViewport, 0, layer);\r\n }\r\n };\r\n RenderTargetTexture.prototype.unbindFrameBuffer = function (engine, faceIndex) {\r\n var _this = this;\r\n if (!this._texture) {\r\n return;\r\n }\r\n engine.unBindFramebuffer(this._texture, this.isCube, function () {\r\n _this.onAfterRenderObservable.notifyObservers(faceIndex);\r\n });\r\n };\r\n RenderTargetTexture.prototype.renderToTarget = function (faceIndex, useCameraPostProcess, dumpForDebug, layer, camera) {\r\n if (layer === void 0) { layer = 0; }\r\n if (camera === void 0) { camera = null; }\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n var engine = scene.getEngine();\r\n if (!this._texture) {\r\n return;\r\n }\r\n // Bind\r\n if (this._postProcessManager) {\r\n this._postProcessManager._prepareFrame(this._texture, this._postProcesses);\r\n }\r\n else if (!useCameraPostProcess || !scene.postProcessManager._prepareFrame(this._texture)) {\r\n this._bindFrameBuffer(faceIndex, layer);\r\n }\r\n if (this.is2DArray) {\r\n this.onBeforeRenderObservable.notifyObservers(layer);\r\n }\r\n else {\r\n this.onBeforeRenderObservable.notifyObservers(faceIndex);\r\n }\r\n // Get the list of meshes to render\r\n var currentRenderList = null;\r\n var defaultRenderList = this.renderList ? this.renderList : scene.getActiveMeshes().data;\r\n var defaultRenderListLength = this.renderList ? this.renderList.length : scene.getActiveMeshes().length;\r\n if (this.getCustomRenderList) {\r\n currentRenderList = this.getCustomRenderList(this.is2DArray ? layer : faceIndex, defaultRenderList, defaultRenderListLength);\r\n }\r\n if (!currentRenderList) {\r\n // No custom render list provided, we prepare the rendering for the default list, but check\r\n // first if we did not already performed the preparation before so as to avoid re-doing it several times\r\n if (!this._defaultRenderListPrepared) {\r\n this._prepareRenderingManager(defaultRenderList, defaultRenderListLength, camera, !this.renderList);\r\n this._defaultRenderListPrepared = true;\r\n }\r\n currentRenderList = defaultRenderList;\r\n }\r\n else {\r\n // Prepare the rendering for the custom render list provided\r\n this._prepareRenderingManager(currentRenderList, currentRenderList.length, camera, false);\r\n }\r\n // Clear\r\n if (this.onClearObservable.hasObservers()) {\r\n this.onClearObservable.notifyObservers(engine);\r\n }\r\n else {\r\n engine.clear(this.clearColor || scene.clearColor, true, true, true);\r\n }\r\n if (!this._doNotChangeAspectRatio) {\r\n scene.updateTransformMatrix(true);\r\n }\r\n // Before Camera Draw\r\n for (var _i = 0, _a = scene._beforeRenderTargetDrawStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n step.action(this);\r\n }\r\n // Render\r\n this._renderingManager.render(this.customRenderFunction, currentRenderList, this.renderParticles, this.renderSprites);\r\n // After Camera Draw\r\n for (var _b = 0, _c = scene._afterRenderTargetDrawStage; _b < _c.length; _b++) {\r\n var step = _c[_b];\r\n step.action(this);\r\n }\r\n if (this._postProcessManager) {\r\n this._postProcessManager._finalizeFrame(false, this._texture, faceIndex, this._postProcesses, this.ignoreCameraViewport);\r\n }\r\n else if (useCameraPostProcess) {\r\n scene.postProcessManager._finalizeFrame(false, this._texture, faceIndex);\r\n }\r\n if (!this._doNotChangeAspectRatio) {\r\n scene.updateTransformMatrix(true);\r\n }\r\n // Dump ?\r\n if (dumpForDebug) {\r\n Tools.DumpFramebuffer(this.getRenderWidth(), this.getRenderHeight(), engine);\r\n }\r\n // Unbind\r\n if (!this.isCube || faceIndex === 5) {\r\n if (this.isCube) {\r\n if (faceIndex === 5) {\r\n engine.generateMipMapsForCubemap(this._texture);\r\n }\r\n }\r\n this.unbindFrameBuffer(engine, faceIndex);\r\n }\r\n else {\r\n this.onAfterRenderObservable.notifyObservers(faceIndex);\r\n }\r\n };\r\n /**\r\n * Overrides the default sort function applied in the renderging group to prepare the meshes.\r\n * This allowed control for front to back rendering or reversly depending of the special needs.\r\n *\r\n * @param renderingGroupId The rendering group id corresponding to its index\r\n * @param opaqueSortCompareFn The opaque queue comparison function use to sort.\r\n * @param alphaTestSortCompareFn The alpha test queue comparison function use to sort.\r\n * @param transparentSortCompareFn The transparent queue comparison function use to sort.\r\n */\r\n RenderTargetTexture.prototype.setRenderingOrder = function (renderingGroupId, opaqueSortCompareFn, alphaTestSortCompareFn, transparentSortCompareFn) {\r\n if (opaqueSortCompareFn === void 0) { opaqueSortCompareFn = null; }\r\n if (alphaTestSortCompareFn === void 0) { alphaTestSortCompareFn = null; }\r\n if (transparentSortCompareFn === void 0) { transparentSortCompareFn = null; }\r\n this._renderingManager.setRenderingOrder(renderingGroupId, opaqueSortCompareFn, alphaTestSortCompareFn, transparentSortCompareFn);\r\n };\r\n /**\r\n * Specifies whether or not the stencil and depth buffer are cleared between two rendering groups.\r\n *\r\n * @param renderingGroupId The rendering group id corresponding to its index\r\n * @param autoClearDepthStencil Automatically clears depth and stencil between groups if true.\r\n */\r\n RenderTargetTexture.prototype.setRenderingAutoClearDepthStencil = function (renderingGroupId, autoClearDepthStencil) {\r\n this._renderingManager.setRenderingAutoClearDepthStencil(renderingGroupId, autoClearDepthStencil);\r\n this._renderingManager._useSceneAutoClearSetup = false;\r\n };\r\n /**\r\n * Clones the texture.\r\n * @returns the cloned texture\r\n */\r\n RenderTargetTexture.prototype.clone = function () {\r\n var textureSize = this.getSize();\r\n var newTexture = new RenderTargetTexture(this.name, textureSize, this.getScene(), this._renderTargetOptions.generateMipMaps, this._doNotChangeAspectRatio, this._renderTargetOptions.type, this.isCube, this._renderTargetOptions.samplingMode, this._renderTargetOptions.generateDepthBuffer, this._renderTargetOptions.generateStencilBuffer);\r\n // Base texture\r\n newTexture.hasAlpha = this.hasAlpha;\r\n newTexture.level = this.level;\r\n // RenderTarget Texture\r\n newTexture.coordinatesMode = this.coordinatesMode;\r\n if (this.renderList) {\r\n newTexture.renderList = this.renderList.slice(0);\r\n }\r\n return newTexture;\r\n };\r\n /**\r\n * Serialize the texture to a JSON representation we can easily use in the resepective Parse function.\r\n * @returns The JSON representation of the texture\r\n */\r\n RenderTargetTexture.prototype.serialize = function () {\r\n if (!this.name) {\r\n return null;\r\n }\r\n var serializationObject = _super.prototype.serialize.call(this);\r\n serializationObject.renderTargetSize = this.getRenderSize();\r\n serializationObject.renderList = [];\r\n if (this.renderList) {\r\n for (var index = 0; index < this.renderList.length; index++) {\r\n serializationObject.renderList.push(this.renderList[index].id);\r\n }\r\n }\r\n return serializationObject;\r\n };\r\n /**\r\n * This will remove the attached framebuffer objects. The texture will not be able to be used as render target anymore\r\n */\r\n RenderTargetTexture.prototype.disposeFramebufferObjects = function () {\r\n var objBuffer = this.getInternalTexture();\r\n var scene = this.getScene();\r\n if (objBuffer && scene) {\r\n scene.getEngine()._releaseFramebufferObjects(objBuffer);\r\n }\r\n };\r\n /**\r\n * Dispose the texture and release its associated resources.\r\n */\r\n RenderTargetTexture.prototype.dispose = function () {\r\n this.onResizeObservable.clear();\r\n this.onClearObservable.clear();\r\n this.onAfterRenderObservable.clear();\r\n this.onAfterUnbindObservable.clear();\r\n this.onBeforeBindObservable.clear();\r\n this.onBeforeRenderObservable.clear();\r\n if (this._postProcessManager) {\r\n this._postProcessManager.dispose();\r\n this._postProcessManager = null;\r\n }\r\n this.clearPostProcesses(true);\r\n if (this._resizeObserver) {\r\n this.getScene().getEngine().onResizeObservable.remove(this._resizeObserver);\r\n this._resizeObserver = null;\r\n }\r\n this.renderList = null;\r\n // Remove from custom render targets\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n var index = scene.customRenderTargets.indexOf(this);\r\n if (index >= 0) {\r\n scene.customRenderTargets.splice(index, 1);\r\n }\r\n for (var _i = 0, _a = scene.cameras; _i < _a.length; _i++) {\r\n var camera = _a[_i];\r\n index = camera.customRenderTargets.indexOf(this);\r\n if (index >= 0) {\r\n camera.customRenderTargets.splice(index, 1);\r\n }\r\n }\r\n if (this.depthStencilTexture) {\r\n this.getScene().getEngine()._releaseTexture(this.depthStencilTexture);\r\n }\r\n _super.prototype.dispose.call(this);\r\n };\r\n /** @hidden */\r\n RenderTargetTexture.prototype._rebuild = function () {\r\n if (this.refreshRate === RenderTargetTexture.REFRESHRATE_RENDER_ONCE) {\r\n this.refreshRate = RenderTargetTexture.REFRESHRATE_RENDER_ONCE;\r\n }\r\n if (this._postProcessManager) {\r\n this._postProcessManager._rebuild();\r\n }\r\n };\r\n /**\r\n * Clear the info related to rendering groups preventing retention point in material dispose.\r\n */\r\n RenderTargetTexture.prototype.freeRenderingGroups = function () {\r\n if (this._renderingManager) {\r\n this._renderingManager.freeRenderingGroups();\r\n }\r\n };\r\n /**\r\n * Gets the number of views the corresponding to the texture (eg. a MultiviewRenderTarget will have > 1)\r\n * @returns the view count\r\n */\r\n RenderTargetTexture.prototype.getViewCount = function () {\r\n return 1;\r\n };\r\n /**\r\n * The texture will only be rendered once which can be useful to improve performance if everything in your render is static for instance.\r\n */\r\n RenderTargetTexture.REFRESHRATE_RENDER_ONCE = 0;\r\n /**\r\n * The texture will only be rendered rendered every frame and is recomended for dynamic contents.\r\n */\r\n RenderTargetTexture.REFRESHRATE_RENDER_ONEVERYFRAME = 1;\r\n /**\r\n * The texture will be rendered every 2 frames which could be enough if your dynamic objects are not\r\n * the central point of your effect and can save a lot of performances.\r\n */\r\n RenderTargetTexture.REFRESHRATE_RENDER_ONEVERYTWOFRAMES = 2;\r\n return RenderTargetTexture;\r\n}(Texture));\r\nexport { RenderTargetTexture };\r\nTexture._CreateRenderTargetTexture = function (name, renderTargetSize, scene, generateMipMaps) {\r\n return new RenderTargetTexture(name, renderTargetSize, scene, generateMipMaps);\r\n};\r\n//# sourceMappingURL=renderTargetTexture.js.map","import { Effect } from \"../Materials/effect\";\r\nvar name = 'postprocessVertexShader';\r\nvar shader = \"\\nattribute vec2 position;\\nuniform vec2 scale;\\n\\nvarying vec2 vUV;\\nconst vec2 madd=vec2(0.5,0.5);\\nvoid main(void) {\\nvUV=(position*madd+madd)*scale;\\ngl_Position=vec4(position,0.0,1.0);\\n}\";\r\nEffect.ShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var postprocessVertexShader = { name: name, shader: shader };\r\n//# sourceMappingURL=postprocess.vertex.js.map","import { SmartArray } from \"../Misc/smartArray\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { Vector2 } from \"../Maths/math.vector\";\r\nimport \"../Shaders/postprocess.vertex\";\r\nimport { Engine } from '../Engines/engine';\r\nimport \"../Engines/Extensions/engine.renderTarget\";\r\n/**\r\n * PostProcess can be used to apply a shader to a texture after it has been rendered\r\n * See https://doc.babylonjs.com/how_to/how_to_use_postprocesses\r\n */\r\nvar PostProcess = /** @class */ (function () {\r\n /**\r\n * Creates a new instance PostProcess\r\n * @param name The name of the PostProcess.\r\n * @param fragmentUrl The url of the fragment shader to be used.\r\n * @param parameters Array of the names of uniform non-sampler2D variables that will be passed to the shader.\r\n * @param samplers Array of the names of uniform sampler2D variables that will be passed to the shader.\r\n * @param options The required width/height ratio to downsize to before computing the render pass. (Use 1.0 for full size)\r\n * @param camera The camera to apply the render pass to.\r\n * @param samplingMode The sampling mode to be used when computing the pass. (default: 0)\r\n * @param engine The engine which the post process will be applied. (default: current engine)\r\n * @param reusable If the post process can be reused on the same frame. (default: false)\r\n * @param defines String of defines that will be set when running the fragment shader. (default: null)\r\n * @param textureType Type of textures used when performing the post process. (default: 0)\r\n * @param vertexUrl The url of the vertex shader to be used. (default: \"postprocess\")\r\n * @param indexParameters The index parameters to be used for babylons include syntax \"#include[0..varyingCount]\". (default: undefined) See usage in babylon.blurPostProcess.ts and kernelBlur.vertex.fx\r\n * @param blockCompilation If the shader should not be compiled imediatly. (default: false)\r\n * @param textureFormat Format of textures used when performing the post process. (default: TEXTUREFORMAT_RGBA)\r\n */\r\n function PostProcess(\r\n /** Name of the PostProcess. */\r\n name, fragmentUrl, parameters, samplers, options, camera, samplingMode, engine, reusable, defines, textureType, vertexUrl, indexParameters, blockCompilation, textureFormat) {\r\n if (samplingMode === void 0) { samplingMode = 1; }\r\n if (defines === void 0) { defines = null; }\r\n if (textureType === void 0) { textureType = 0; }\r\n if (vertexUrl === void 0) { vertexUrl = \"postprocess\"; }\r\n if (blockCompilation === void 0) { blockCompilation = false; }\r\n if (textureFormat === void 0) { textureFormat = 5; }\r\n this.name = name;\r\n /**\r\n * Width of the texture to apply the post process on\r\n */\r\n this.width = -1;\r\n /**\r\n * Height of the texture to apply the post process on\r\n */\r\n this.height = -1;\r\n /**\r\n * Internal, reference to the location where this postprocess was output to. (Typically the texture on the next postprocess in the chain)\r\n * @hidden\r\n */\r\n this._outputTexture = null;\r\n /**\r\n * If the buffer needs to be cleared before applying the post process. (default: true)\r\n * Should be set to false if shader will overwrite all previous pixels.\r\n */\r\n this.autoClear = true;\r\n /**\r\n * Type of alpha mode to use when performing the post process (default: Engine.ALPHA_DISABLE)\r\n */\r\n this.alphaMode = 0;\r\n /**\r\n * Animations to be used for the post processing\r\n */\r\n this.animations = new Array();\r\n /**\r\n * Enable Pixel Perfect mode where texture is not scaled to be power of 2.\r\n * Can only be used on a single postprocess or on the last one of a chain. (default: false)\r\n */\r\n this.enablePixelPerfectMode = false;\r\n /**\r\n * Force the postprocess to be applied without taking in account viewport\r\n */\r\n this.forceFullscreenViewport = true;\r\n /**\r\n * Scale mode for the post process (default: Engine.SCALEMODE_FLOOR)\r\n *\r\n * | Value | Type | Description |\r\n * | ----- | ----------------------------------- | ----------- |\r\n * | 1 | SCALEMODE_FLOOR | [engine.scalemode_floor](http://doc.babylonjs.com/api/classes/babylon.engine#scalemode_floor) |\r\n * | 2 | SCALEMODE_NEAREST | [engine.scalemode_nearest](http://doc.babylonjs.com/api/classes/babylon.engine#scalemode_nearest) |\r\n * | 3 | SCALEMODE_CEILING | [engine.scalemode_ceiling](http://doc.babylonjs.com/api/classes/babylon.engine#scalemode_ceiling) |\r\n *\r\n */\r\n this.scaleMode = 1;\r\n /**\r\n * Force textures to be a power of two (default: false)\r\n */\r\n this.alwaysForcePOT = false;\r\n this._samples = 1;\r\n /**\r\n * Modify the scale of the post process to be the same as the viewport (default: false)\r\n */\r\n this.adaptScaleToCurrentViewport = false;\r\n this._reusable = false;\r\n /**\r\n * Smart array of input and output textures for the post process.\r\n * @hidden\r\n */\r\n this._textures = new SmartArray(2);\r\n /**\r\n * The index in _textures that corresponds to the output texture.\r\n * @hidden\r\n */\r\n this._currentRenderTextureInd = 0;\r\n this._scaleRatio = new Vector2(1, 1);\r\n this._texelSize = Vector2.Zero();\r\n // Events\r\n /**\r\n * An event triggered when the postprocess is activated.\r\n */\r\n this.onActivateObservable = new Observable();\r\n /**\r\n * An event triggered when the postprocess changes its size.\r\n */\r\n this.onSizeChangedObservable = new Observable();\r\n /**\r\n * An event triggered when the postprocess applies its effect.\r\n */\r\n this.onApplyObservable = new Observable();\r\n /**\r\n * An event triggered before rendering the postprocess\r\n */\r\n this.onBeforeRenderObservable = new Observable();\r\n /**\r\n * An event triggered after rendering the postprocess\r\n */\r\n this.onAfterRenderObservable = new Observable();\r\n if (camera != null) {\r\n this._camera = camera;\r\n this._scene = camera.getScene();\r\n camera.attachPostProcess(this);\r\n this._engine = this._scene.getEngine();\r\n this._scene.postProcesses.push(this);\r\n this.uniqueId = this._scene.getUniqueId();\r\n }\r\n else if (engine) {\r\n this._engine = engine;\r\n this._engine.postProcesses.push(this);\r\n }\r\n this._options = options;\r\n this.renderTargetSamplingMode = samplingMode ? samplingMode : 1;\r\n this._reusable = reusable || false;\r\n this._textureType = textureType;\r\n this._textureFormat = textureFormat;\r\n this._samplers = samplers || [];\r\n this._samplers.push(\"textureSampler\");\r\n this._fragmentUrl = fragmentUrl;\r\n this._vertexUrl = vertexUrl;\r\n this._parameters = parameters || [];\r\n this._parameters.push(\"scale\");\r\n this._indexParameters = indexParameters;\r\n if (!blockCompilation) {\r\n this.updateEffect(defines);\r\n }\r\n }\r\n Object.defineProperty(PostProcess.prototype, \"samples\", {\r\n /**\r\n * Number of sample textures (default: 1)\r\n */\r\n get: function () {\r\n return this._samples;\r\n },\r\n set: function (n) {\r\n var _this = this;\r\n this._samples = Math.min(n, this._engine.getCaps().maxMSAASamples);\r\n this._textures.forEach(function (texture) {\r\n if (texture.samples !== _this._samples) {\r\n _this._engine.updateRenderTargetTextureSampleCount(texture, _this._samples);\r\n }\r\n });\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Returns the fragment url or shader name used in the post process.\r\n * @returns the fragment url or name in the shader store.\r\n */\r\n PostProcess.prototype.getEffectName = function () {\r\n return this._fragmentUrl;\r\n };\r\n Object.defineProperty(PostProcess.prototype, \"onActivate\", {\r\n /**\r\n * A function that is added to the onActivateObservable\r\n */\r\n set: function (callback) {\r\n if (this._onActivateObserver) {\r\n this.onActivateObservable.remove(this._onActivateObserver);\r\n }\r\n if (callback) {\r\n this._onActivateObserver = this.onActivateObservable.add(callback);\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PostProcess.prototype, \"onSizeChanged\", {\r\n /**\r\n * A function that is added to the onSizeChangedObservable\r\n */\r\n set: function (callback) {\r\n if (this._onSizeChangedObserver) {\r\n this.onSizeChangedObservable.remove(this._onSizeChangedObserver);\r\n }\r\n this._onSizeChangedObserver = this.onSizeChangedObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PostProcess.prototype, \"onApply\", {\r\n /**\r\n * A function that is added to the onApplyObservable\r\n */\r\n set: function (callback) {\r\n if (this._onApplyObserver) {\r\n this.onApplyObservable.remove(this._onApplyObserver);\r\n }\r\n this._onApplyObserver = this.onApplyObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PostProcess.prototype, \"onBeforeRender\", {\r\n /**\r\n * A function that is added to the onBeforeRenderObservable\r\n */\r\n set: function (callback) {\r\n if (this._onBeforeRenderObserver) {\r\n this.onBeforeRenderObservable.remove(this._onBeforeRenderObserver);\r\n }\r\n this._onBeforeRenderObserver = this.onBeforeRenderObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PostProcess.prototype, \"onAfterRender\", {\r\n /**\r\n * A function that is added to the onAfterRenderObservable\r\n */\r\n set: function (callback) {\r\n if (this._onAfterRenderObserver) {\r\n this.onAfterRenderObservable.remove(this._onAfterRenderObserver);\r\n }\r\n this._onAfterRenderObserver = this.onAfterRenderObservable.add(callback);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PostProcess.prototype, \"inputTexture\", {\r\n /**\r\n * The input texture for this post process and the output texture of the previous post process. When added to a pipeline the previous post process will\r\n * render it's output into this texture and this texture will be used as textureSampler in the fragment shader of this post process.\r\n */\r\n get: function () {\r\n return this._textures.data[this._currentRenderTextureInd];\r\n },\r\n set: function (value) {\r\n this._forcedOutputTexture = value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the camera which post process is applied to.\r\n * @returns The camera the post process is applied to.\r\n */\r\n PostProcess.prototype.getCamera = function () {\r\n return this._camera;\r\n };\r\n Object.defineProperty(PostProcess.prototype, \"texelSize\", {\r\n /**\r\n * Gets the texel size of the postprocess.\r\n * See https://en.wikipedia.org/wiki/Texel_(graphics)\r\n */\r\n get: function () {\r\n if (this._shareOutputWithPostProcess) {\r\n return this._shareOutputWithPostProcess.texelSize;\r\n }\r\n if (this._forcedOutputTexture) {\r\n this._texelSize.copyFromFloats(1.0 / this._forcedOutputTexture.width, 1.0 / this._forcedOutputTexture.height);\r\n }\r\n return this._texelSize;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Gets a string idenfifying the name of the class\r\n * @returns \"PostProcess\" string\r\n */\r\n PostProcess.prototype.getClassName = function () {\r\n return \"PostProcess\";\r\n };\r\n /**\r\n * Gets the engine which this post process belongs to.\r\n * @returns The engine the post process was enabled with.\r\n */\r\n PostProcess.prototype.getEngine = function () {\r\n return this._engine;\r\n };\r\n /**\r\n * The effect that is created when initializing the post process.\r\n * @returns The created effect corresponding the the postprocess.\r\n */\r\n PostProcess.prototype.getEffect = function () {\r\n return this._effect;\r\n };\r\n /**\r\n * To avoid multiple redundant textures for multiple post process, the output the output texture for this post process can be shared with another.\r\n * @param postProcess The post process to share the output with.\r\n * @returns This post process.\r\n */\r\n PostProcess.prototype.shareOutputWith = function (postProcess) {\r\n this._disposeTextures();\r\n this._shareOutputWithPostProcess = postProcess;\r\n return this;\r\n };\r\n /**\r\n * Reverses the effect of calling shareOutputWith and returns the post process back to its original state.\r\n * This should be called if the post process that shares output with this post process is disabled/disposed.\r\n */\r\n PostProcess.prototype.useOwnOutput = function () {\r\n if (this._textures.length == 0) {\r\n this._textures = new SmartArray(2);\r\n }\r\n this._shareOutputWithPostProcess = null;\r\n };\r\n /**\r\n * Updates the effect with the current post process compile time values and recompiles the shader.\r\n * @param defines Define statements that should be added at the beginning of the shader. (default: null)\r\n * @param uniforms Set of uniform variables that will be passed to the shader. (default: null)\r\n * @param samplers Set of Texture2D variables that will be passed to the shader. (default: null)\r\n * @param indexParameters The index parameters to be used for babylons include syntax \"#include[0..varyingCount]\". (default: undefined) See usage in babylon.blurPostProcess.ts and kernelBlur.vertex.fx\r\n * @param onCompiled Called when the shader has been compiled.\r\n * @param onError Called if there is an error when compiling a shader.\r\n */\r\n PostProcess.prototype.updateEffect = function (defines, uniforms, samplers, indexParameters, onCompiled, onError) {\r\n if (defines === void 0) { defines = null; }\r\n if (uniforms === void 0) { uniforms = null; }\r\n if (samplers === void 0) { samplers = null; }\r\n this._effect = this._engine.createEffect({ vertex: this._vertexUrl, fragment: this._fragmentUrl }, [\"position\"], uniforms || this._parameters, samplers || this._samplers, defines !== null ? defines : \"\", undefined, onCompiled, onError, indexParameters || this._indexParameters);\r\n };\r\n /**\r\n * The post process is reusable if it can be used multiple times within one frame.\r\n * @returns If the post process is reusable\r\n */\r\n PostProcess.prototype.isReusable = function () {\r\n return this._reusable;\r\n };\r\n /** invalidate frameBuffer to hint the postprocess to create a depth buffer */\r\n PostProcess.prototype.markTextureDirty = function () {\r\n this.width = -1;\r\n };\r\n /**\r\n * Activates the post process by intializing the textures to be used when executed. Notifies onActivateObservable.\r\n * When this post process is used in a pipeline, this is call will bind the input texture of this post process to the output of the previous.\r\n * @param camera The camera that will be used in the post process. This camera will be used when calling onActivateObservable.\r\n * @param sourceTexture The source texture to be inspected to get the width and height if not specified in the post process constructor. (default: null)\r\n * @param forceDepthStencil If true, a depth and stencil buffer will be generated. (default: false)\r\n * @returns The target texture that was bound to be written to.\r\n */\r\n PostProcess.prototype.activate = function (camera, sourceTexture, forceDepthStencil) {\r\n var _this = this;\r\n if (sourceTexture === void 0) { sourceTexture = null; }\r\n camera = camera || this._camera;\r\n var scene = camera.getScene();\r\n var engine = scene.getEngine();\r\n var maxSize = engine.getCaps().maxTextureSize;\r\n var requiredWidth = ((sourceTexture ? sourceTexture.width : this._engine.getRenderWidth(true)) * this._options) | 0;\r\n var requiredHeight = ((sourceTexture ? sourceTexture.height : this._engine.getRenderHeight(true)) * this._options) | 0;\r\n // If rendering to a webvr camera's left or right eye only half the width should be used to avoid resize when rendered to screen\r\n var webVRCamera = camera.parent;\r\n if (webVRCamera && (webVRCamera.leftCamera == camera || webVRCamera.rightCamera == camera)) {\r\n requiredWidth /= 2;\r\n }\r\n var desiredWidth = (this._options.width || requiredWidth);\r\n var desiredHeight = this._options.height || requiredHeight;\r\n var needMipMaps = this.renderTargetSamplingMode !== 7 &&\r\n this.renderTargetSamplingMode !== 1 &&\r\n this.renderTargetSamplingMode !== 2;\r\n if (!this._shareOutputWithPostProcess && !this._forcedOutputTexture) {\r\n if (this.adaptScaleToCurrentViewport) {\r\n var currentViewport = engine.currentViewport;\r\n if (currentViewport) {\r\n desiredWidth *= currentViewport.width;\r\n desiredHeight *= currentViewport.height;\r\n }\r\n }\r\n if (needMipMaps || this.alwaysForcePOT) {\r\n if (!this._options.width) {\r\n desiredWidth = engine.needPOTTextures ? Engine.GetExponentOfTwo(desiredWidth, maxSize, this.scaleMode) : desiredWidth;\r\n }\r\n if (!this._options.height) {\r\n desiredHeight = engine.needPOTTextures ? Engine.GetExponentOfTwo(desiredHeight, maxSize, this.scaleMode) : desiredHeight;\r\n }\r\n }\r\n if (this.width !== desiredWidth || this.height !== desiredHeight) {\r\n if (this._textures.length > 0) {\r\n for (var i = 0; i < this._textures.length; i++) {\r\n this._engine._releaseTexture(this._textures.data[i]);\r\n }\r\n this._textures.reset();\r\n }\r\n this.width = desiredWidth;\r\n this.height = desiredHeight;\r\n var textureSize = { width: this.width, height: this.height };\r\n var textureOptions = {\r\n generateMipMaps: needMipMaps,\r\n generateDepthBuffer: forceDepthStencil || camera._postProcesses.indexOf(this) === 0,\r\n generateStencilBuffer: (forceDepthStencil || camera._postProcesses.indexOf(this) === 0) && this._engine.isStencilEnable,\r\n samplingMode: this.renderTargetSamplingMode,\r\n type: this._textureType,\r\n format: this._textureFormat\r\n };\r\n this._textures.push(this._engine.createRenderTargetTexture(textureSize, textureOptions));\r\n if (this._reusable) {\r\n this._textures.push(this._engine.createRenderTargetTexture(textureSize, textureOptions));\r\n }\r\n this._texelSize.copyFromFloats(1.0 / this.width, 1.0 / this.height);\r\n this.onSizeChangedObservable.notifyObservers(this);\r\n }\r\n this._textures.forEach(function (texture) {\r\n if (texture.samples !== _this.samples) {\r\n _this._engine.updateRenderTargetTextureSampleCount(texture, _this.samples);\r\n }\r\n });\r\n }\r\n var target;\r\n if (this._shareOutputWithPostProcess) {\r\n target = this._shareOutputWithPostProcess.inputTexture;\r\n }\r\n else if (this._forcedOutputTexture) {\r\n target = this._forcedOutputTexture;\r\n this.width = this._forcedOutputTexture.width;\r\n this.height = this._forcedOutputTexture.height;\r\n }\r\n else {\r\n target = this.inputTexture;\r\n }\r\n // Bind the input of this post process to be used as the output of the previous post process.\r\n if (this.enablePixelPerfectMode) {\r\n this._scaleRatio.copyFromFloats(requiredWidth / desiredWidth, requiredHeight / desiredHeight);\r\n this._engine.bindFramebuffer(target, 0, requiredWidth, requiredHeight, this.forceFullscreenViewport);\r\n }\r\n else {\r\n this._scaleRatio.copyFromFloats(1, 1);\r\n this._engine.bindFramebuffer(target, 0, undefined, undefined, this.forceFullscreenViewport);\r\n }\r\n this.onActivateObservable.notifyObservers(camera);\r\n // Clear\r\n if (this.autoClear && this.alphaMode === 0) {\r\n this._engine.clear(this.clearColor ? this.clearColor : scene.clearColor, scene._allowPostProcessClearColor, true, true);\r\n }\r\n if (this._reusable) {\r\n this._currentRenderTextureInd = (this._currentRenderTextureInd + 1) % 2;\r\n }\r\n return target;\r\n };\r\n Object.defineProperty(PostProcess.prototype, \"isSupported\", {\r\n /**\r\n * If the post process is supported.\r\n */\r\n get: function () {\r\n return this._effect.isSupported;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PostProcess.prototype, \"aspectRatio\", {\r\n /**\r\n * The aspect ratio of the output texture.\r\n */\r\n get: function () {\r\n if (this._shareOutputWithPostProcess) {\r\n return this._shareOutputWithPostProcess.aspectRatio;\r\n }\r\n if (this._forcedOutputTexture) {\r\n return this._forcedOutputTexture.width / this._forcedOutputTexture.height;\r\n }\r\n return this.width / this.height;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Get a value indicating if the post-process is ready to be used\r\n * @returns true if the post-process is ready (shader is compiled)\r\n */\r\n PostProcess.prototype.isReady = function () {\r\n return this._effect && this._effect.isReady();\r\n };\r\n /**\r\n * Binds all textures and uniforms to the shader, this will be run on every pass.\r\n * @returns the effect corresponding to this post process. Null if not compiled or not ready.\r\n */\r\n PostProcess.prototype.apply = function () {\r\n // Check\r\n if (!this._effect || !this._effect.isReady()) {\r\n return null;\r\n }\r\n // States\r\n this._engine.enableEffect(this._effect);\r\n this._engine.setState(false);\r\n this._engine.setDepthBuffer(false);\r\n this._engine.setDepthWrite(false);\r\n // Alpha\r\n this._engine.setAlphaMode(this.alphaMode);\r\n if (this.alphaConstants) {\r\n this.getEngine().setAlphaConstants(this.alphaConstants.r, this.alphaConstants.g, this.alphaConstants.b, this.alphaConstants.a);\r\n }\r\n // Bind the output texture of the preivous post process as the input to this post process.\r\n var source;\r\n if (this._shareOutputWithPostProcess) {\r\n source = this._shareOutputWithPostProcess.inputTexture;\r\n }\r\n else if (this._forcedOutputTexture) {\r\n source = this._forcedOutputTexture;\r\n }\r\n else {\r\n source = this.inputTexture;\r\n }\r\n this._effect._bindTexture(\"textureSampler\", source);\r\n // Parameters\r\n this._effect.setVector2(\"scale\", this._scaleRatio);\r\n this.onApplyObservable.notifyObservers(this._effect);\r\n return this._effect;\r\n };\r\n PostProcess.prototype._disposeTextures = function () {\r\n if (this._shareOutputWithPostProcess || this._forcedOutputTexture) {\r\n return;\r\n }\r\n if (this._textures.length > 0) {\r\n for (var i = 0; i < this._textures.length; i++) {\r\n this._engine._releaseTexture(this._textures.data[i]);\r\n }\r\n }\r\n this._textures.dispose();\r\n };\r\n /**\r\n * Disposes the post process.\r\n * @param camera The camera to dispose the post process on.\r\n */\r\n PostProcess.prototype.dispose = function (camera) {\r\n camera = camera || this._camera;\r\n this._disposeTextures();\r\n if (this._scene) {\r\n var index_1 = this._scene.postProcesses.indexOf(this);\r\n if (index_1 !== -1) {\r\n this._scene.postProcesses.splice(index_1, 1);\r\n }\r\n }\r\n else {\r\n var index_2 = this._engine.postProcesses.indexOf(this);\r\n if (index_2 !== -1) {\r\n this._engine.postProcesses.splice(index_2, 1);\r\n }\r\n }\r\n if (!camera) {\r\n return;\r\n }\r\n camera.detachPostProcess(this);\r\n var index = camera._postProcesses.indexOf(this);\r\n if (index === 0 && camera._postProcesses.length > 0) {\r\n var firstPostProcess = this._camera._getFirstPostProcess();\r\n if (firstPostProcess) {\r\n firstPostProcess.markTextureDirty();\r\n }\r\n }\r\n this.onActivateObservable.clear();\r\n this.onAfterRenderObservable.clear();\r\n this.onApplyObservable.clear();\r\n this.onBeforeRenderObservable.clear();\r\n this.onSizeChangedObservable.clear();\r\n };\r\n return PostProcess;\r\n}());\r\nexport { PostProcess };\r\n//# sourceMappingURL=postProcess.js.map","import { Effect } from \"../Materials/effect\";\r\nvar name = 'fxaaPixelShader';\r\nvar shader = \"uniform sampler2D textureSampler;\\nuniform vec2 texelSize;\\nvarying vec2 vUV;\\nvarying vec2 sampleCoordS;\\nvarying vec2 sampleCoordE;\\nvarying vec2 sampleCoordN;\\nvarying vec2 sampleCoordW;\\nvarying vec2 sampleCoordNW;\\nvarying vec2 sampleCoordSE;\\nvarying vec2 sampleCoordNE;\\nvarying vec2 sampleCoordSW;\\nconst float fxaaQualitySubpix=1.0;\\nconst float fxaaQualityEdgeThreshold=0.166;\\nconst float fxaaQualityEdgeThresholdMin=0.0833;\\nconst vec3 kLumaCoefficients=vec3(0.2126,0.7152,0.0722);\\n#define FxaaLuma(rgba) dot(rgba.rgb,kLumaCoefficients)\\nvoid main(){\\nvec2 posM;\\nposM.x=vUV.x;\\nposM.y=vUV.y;\\nvec4 rgbyM=texture2D(textureSampler,vUV,0.0);\\nfloat lumaM=FxaaLuma(rgbyM);\\nfloat lumaS=FxaaLuma(texture2D(textureSampler,sampleCoordS,0.0));\\nfloat lumaE=FxaaLuma(texture2D(textureSampler,sampleCoordE,0.0));\\nfloat lumaN=FxaaLuma(texture2D(textureSampler,sampleCoordN,0.0));\\nfloat lumaW=FxaaLuma(texture2D(textureSampler,sampleCoordW,0.0));\\nfloat maxSM=max(lumaS,lumaM);\\nfloat minSM=min(lumaS,lumaM);\\nfloat maxESM=max(lumaE,maxSM);\\nfloat minESM=min(lumaE,minSM);\\nfloat maxWN=max(lumaN,lumaW);\\nfloat minWN=min(lumaN,lumaW);\\nfloat rangeMax=max(maxWN,maxESM);\\nfloat rangeMin=min(minWN,minESM);\\nfloat rangeMaxScaled=rangeMax*fxaaQualityEdgeThreshold;\\nfloat range=rangeMax-rangeMin;\\nfloat rangeMaxClamped=max(fxaaQualityEdgeThresholdMin,rangeMaxScaled);\\n#ifndef MALI\\nif(range=edgeVert;\\nfloat subpixA=subpixNSWE*2.0+subpixNWSWNESE;\\nif (!horzSpan)\\n{\\nlumaN=lumaW;\\n}\\nif (!horzSpan)\\n{\\nlumaS=lumaE;\\n}\\nif (horzSpan)\\n{\\nlengthSign=texelSize.y;\\n}\\nfloat subpixB=(subpixA*(1.0/12.0))-lumaM;\\nfloat gradientN=lumaN-lumaM;\\nfloat gradientS=lumaS-lumaM;\\nfloat lumaNN=lumaN+lumaM;\\nfloat lumaSS=lumaS+lumaM;\\nbool pairN=abs(gradientN)>=abs(gradientS);\\nfloat gradient=max(abs(gradientN),abs(gradientS));\\nif (pairN)\\n{\\nlengthSign=-lengthSign;\\n}\\nfloat subpixC=clamp(abs(subpixB)*subpixRcpRange,0.0,1.0);\\nvec2 posB;\\nposB.x=posM.x;\\nposB.y=posM.y;\\nvec2 offNP;\\noffNP.x=(!horzSpan) ? 0.0 : texelSize.x;\\noffNP.y=(horzSpan) ? 0.0 : texelSize.y;\\nif (!horzSpan)\\n{\\nposB.x+=lengthSign*0.5;\\n}\\nif (horzSpan)\\n{\\nposB.y+=lengthSign*0.5;\\n}\\nvec2 posN;\\nposN.x=posB.x-offNP.x*1.5;\\nposN.y=posB.y-offNP.y*1.5;\\nvec2 posP;\\nposP.x=posB.x+offNP.x*1.5;\\nposP.y=posB.y+offNP.y*1.5;\\nfloat subpixD=((-2.0)*subpixC)+3.0;\\nfloat lumaEndN=FxaaLuma(texture2D(textureSampler,posN,0.0));\\nfloat subpixE=subpixC*subpixC;\\nfloat lumaEndP=FxaaLuma(texture2D(textureSampler,posP,0.0));\\nif (!pairN)\\n{\\nlumaNN=lumaSS;\\n}\\nfloat gradientScaled=gradient*1.0/4.0;\\nfloat lumaMM=lumaM-lumaNN*0.5;\\nfloat subpixF=subpixD*subpixE;\\nbool lumaMLTZero=lumaMM<0.0;\\nlumaEndN-=lumaNN*0.5;\\nlumaEndP-=lumaNN*0.5;\\nbool doneN=abs(lumaEndN)>=gradientScaled;\\nbool doneP=abs(lumaEndP)>=gradientScaled;\\nif (!doneN)\\n{\\nposN.x-=offNP.x*3.0;\\n}\\nif (!doneN)\\n{\\nposN.y-=offNP.y*3.0;\\n}\\nbool doneNP=(!doneN) || (!doneP);\\nif (!doneP)\\n{\\nposP.x+=offNP.x*3.0;\\n}\\nif (!doneP)\\n{\\nposP.y+=offNP.y*3.0;\\n}\\nif (doneNP)\\n{\\nif (!doneN) lumaEndN=FxaaLuma(texture2D(textureSampler,posN.xy,0.0));\\nif (!doneP) lumaEndP=FxaaLuma(texture2D(textureSampler,posP.xy,0.0));\\nif (!doneN) lumaEndN=lumaEndN-lumaNN*0.5;\\nif (!doneP) lumaEndP=lumaEndP-lumaNN*0.5;\\ndoneN=abs(lumaEndN)>=gradientScaled;\\ndoneP=abs(lumaEndP)>=gradientScaled;\\nif (!doneN) posN.x-=offNP.x*12.0;\\nif (!doneN) posN.y-=offNP.y*12.0;\\ndoneNP=(!doneN) || (!doneP);\\nif (!doneP) posP.x+=offNP.x*12.0;\\nif (!doneP) posP.y+=offNP.y*12.0;\\n}\\nfloat dstN=posM.x-posN.x;\\nfloat dstP=posP.x-posM.x;\\nif (!horzSpan)\\n{\\ndstN=posM.y-posN.y;\\n}\\nif (!horzSpan)\\n{\\ndstP=posP.y-posM.y;\\n}\\nbool goodSpanN=(lumaEndN<0.0) != lumaMLTZero;\\nfloat spanLength=(dstP+dstN);\\nbool goodSpanP=(lumaEndP<0.0) != lumaMLTZero;\\nfloat spanLengthRcp=1.0/spanLength;\\nbool directionN=dstN -1) {\r\n return \"#define MALI 1\\n\";\r\n }\r\n return null;\r\n };\r\n return FxaaPostProcess;\r\n}(PostProcess));\r\nexport { FxaaPostProcess };\r\n//# sourceMappingURL=fxaaPostProcess.js.map","import { Texture } from \"../Materials/Textures/texture\";\r\nimport { RenderTargetTexture } from \"../Materials/Textures/renderTargetTexture\";\r\nimport { FxaaPostProcess } from \"../PostProcesses/fxaaPostProcess\";\r\nimport { Logger } from \"./logger\";\r\nimport { Tools } from \"./tools\";\r\n/**\r\n * Class containing a set of static utilities functions for screenshots\r\n */\r\nvar ScreenshotTools = /** @class */ (function () {\r\n function ScreenshotTools() {\r\n }\r\n /**\r\n * Captures a screenshot of the current rendering\r\n * @see http://doc.babylonjs.com/how_to/render_scene_on_a_png\r\n * @param engine defines the rendering engine\r\n * @param camera defines the source camera\r\n * @param size This parameter can be set to a single number or to an object with the\r\n * following (optional) properties: precision, width, height. If a single number is passed,\r\n * it will be used for both width and height. If an object is passed, the screenshot size\r\n * will be derived from the parameters. The precision property is a multiplier allowing\r\n * rendering at a higher or lower resolution\r\n * @param successCallback defines the callback receives a single parameter which contains the\r\n * screenshot as a string of base64-encoded characters. This string can be assigned to the\r\n * src parameter of an to display it\r\n * @param mimeType defines the MIME type of the screenshot image (default: image/png).\r\n * Check your browser for supported MIME types\r\n */\r\n ScreenshotTools.CreateScreenshot = function (engine, camera, size, successCallback, mimeType) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n var _a = ScreenshotTools._getScreenshotSize(engine, camera, size), height = _a.height, width = _a.width;\r\n if (!(height && width)) {\r\n Logger.Error(\"Invalid 'size' parameter !\");\r\n return;\r\n }\r\n if (!Tools._ScreenshotCanvas) {\r\n Tools._ScreenshotCanvas = document.createElement('canvas');\r\n }\r\n Tools._ScreenshotCanvas.width = width;\r\n Tools._ScreenshotCanvas.height = height;\r\n var renderContext = Tools._ScreenshotCanvas.getContext(\"2d\");\r\n var ratio = engine.getRenderWidth() / engine.getRenderHeight();\r\n var newWidth = width;\r\n var newHeight = newWidth / ratio;\r\n if (newHeight > height) {\r\n newHeight = height;\r\n newWidth = newHeight * ratio;\r\n }\r\n var offsetX = Math.max(0, width - newWidth) / 2;\r\n var offsetY = Math.max(0, height - newHeight) / 2;\r\n var renderingCanvas = engine.getRenderingCanvas();\r\n if (renderContext && renderingCanvas) {\r\n renderContext.drawImage(renderingCanvas, offsetX, offsetY, newWidth, newHeight);\r\n }\r\n Tools.EncodeScreenshotCanvasData(successCallback, mimeType);\r\n };\r\n /**\r\n * Captures a screenshot of the current rendering\r\n * @see http://doc.babylonjs.com/how_to/render_scene_on_a_png\r\n * @param engine defines the rendering engine\r\n * @param camera defines the source camera\r\n * @param size This parameter can be set to a single number or to an object with the\r\n * following (optional) properties: precision, width, height. If a single number is passed,\r\n * it will be used for both width and height. If an object is passed, the screenshot size\r\n * will be derived from the parameters. The precision property is a multiplier allowing\r\n * rendering at a higher or lower resolution\r\n * @param mimeType defines the MIME type of the screenshot image (default: image/png).\r\n * Check your browser for supported MIME types\r\n * @returns screenshot as a string of base64-encoded characters. This string can be assigned\r\n * to the src parameter of an to display it\r\n */\r\n ScreenshotTools.CreateScreenshotAsync = function (engine, camera, size, mimeType) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n return new Promise(function (resolve, reject) {\r\n ScreenshotTools.CreateScreenshot(engine, camera, size, function (data) {\r\n if (typeof (data) !== \"undefined\") {\r\n resolve(data);\r\n }\r\n else {\r\n reject(new Error(\"Data is undefined\"));\r\n }\r\n }, mimeType);\r\n });\r\n };\r\n /**\r\n * Generates an image screenshot from the specified camera.\r\n * @see http://doc.babylonjs.com/how_to/render_scene_on_a_png\r\n * @param engine The engine to use for rendering\r\n * @param camera The camera to use for rendering\r\n * @param size This parameter can be set to a single number or to an object with the\r\n * following (optional) properties: precision, width, height. If a single number is passed,\r\n * it will be used for both width and height. If an object is passed, the screenshot size\r\n * will be derived from the parameters. The precision property is a multiplier allowing\r\n * rendering at a higher or lower resolution\r\n * @param successCallback The callback receives a single parameter which contains the\r\n * screenshot as a string of base64-encoded characters. This string can be assigned to the\r\n * src parameter of an to display it\r\n * @param mimeType The MIME type of the screenshot image (default: image/png).\r\n * Check your browser for supported MIME types\r\n * @param samples Texture samples (default: 1)\r\n * @param antialiasing Whether antialiasing should be turned on or not (default: false)\r\n * @param fileName A name for for the downloaded file.\r\n * @param renderSprites Whether the sprites should be rendered or not (default: false)\r\n */\r\n ScreenshotTools.CreateScreenshotUsingRenderTarget = function (engine, camera, size, successCallback, mimeType, samples, antialiasing, fileName, renderSprites) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n if (samples === void 0) { samples = 1; }\r\n if (antialiasing === void 0) { antialiasing = false; }\r\n if (renderSprites === void 0) { renderSprites = false; }\r\n var _a = ScreenshotTools._getScreenshotSize(engine, camera, size), height = _a.height, width = _a.width;\r\n var targetTextureSize = { width: width, height: height };\r\n if (!(height && width)) {\r\n Logger.Error(\"Invalid 'size' parameter !\");\r\n return;\r\n }\r\n var scene = camera.getScene();\r\n var previousCamera = null;\r\n if (scene.activeCamera !== camera) {\r\n previousCamera = scene.activeCamera;\r\n scene.activeCamera = camera;\r\n }\r\n var renderCanvas = engine.getRenderingCanvas();\r\n if (!renderCanvas) {\r\n Logger.Error(\"No rendering canvas found !\");\r\n return;\r\n }\r\n var originalSize = { width: renderCanvas.width, height: renderCanvas.height };\r\n engine.setSize(width, height);\r\n scene.render();\r\n // At this point size can be a number, or an object (according to engine.prototype.createRenderTargetTexture method)\r\n var texture = new RenderTargetTexture(\"screenShot\", targetTextureSize, scene, false, false, 0, false, Texture.NEAREST_SAMPLINGMODE);\r\n texture.renderList = null;\r\n texture.samples = samples;\r\n texture.renderSprites = renderSprites;\r\n texture.onAfterRenderObservable.add(function () {\r\n Tools.DumpFramebuffer(width, height, engine, successCallback, mimeType, fileName);\r\n });\r\n var renderToTexture = function () {\r\n scene.incrementRenderId();\r\n scene.resetCachedMaterial();\r\n texture.render(true);\r\n texture.dispose();\r\n if (previousCamera) {\r\n scene.activeCamera = previousCamera;\r\n }\r\n engine.setSize(originalSize.width, originalSize.height);\r\n camera.getProjectionMatrix(true); // Force cache refresh;\r\n };\r\n if (antialiasing) {\r\n var fxaaPostProcess = new FxaaPostProcess('antialiasing', 1.0, scene.activeCamera);\r\n texture.addPostProcess(fxaaPostProcess);\r\n // Async Shader Compilation can lead to none ready effects in synchronous code\r\n if (!fxaaPostProcess.getEffect().isReady()) {\r\n fxaaPostProcess.getEffect().onCompiled = function () {\r\n renderToTexture();\r\n };\r\n }\r\n // The effect is ready we can render\r\n else {\r\n renderToTexture();\r\n }\r\n }\r\n else {\r\n // No need to wait for extra resources to be ready\r\n renderToTexture();\r\n }\r\n };\r\n /**\r\n * Generates an image screenshot from the specified camera.\r\n * @see http://doc.babylonjs.com/how_to/render_scene_on_a_png\r\n * @param engine The engine to use for rendering\r\n * @param camera The camera to use for rendering\r\n * @param size This parameter can be set to a single number or to an object with the\r\n * following (optional) properties: precision, width, height. If a single number is passed,\r\n * it will be used for both width and height. If an object is passed, the screenshot size\r\n * will be derived from the parameters. The precision property is a multiplier allowing\r\n * rendering at a higher or lower resolution\r\n * @param mimeType The MIME type of the screenshot image (default: image/png).\r\n * Check your browser for supported MIME types\r\n * @param samples Texture samples (default: 1)\r\n * @param antialiasing Whether antialiasing should be turned on or not (default: false)\r\n * @param fileName A name for for the downloaded file.\r\n * @param renderSprites Whether the sprites should be rendered or not (default: false)\r\n * @returns screenshot as a string of base64-encoded characters. This string can be assigned\r\n * to the src parameter of an to display it\r\n */\r\n ScreenshotTools.CreateScreenshotUsingRenderTargetAsync = function (engine, camera, size, mimeType, samples, antialiasing, fileName, renderSprites) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n if (samples === void 0) { samples = 1; }\r\n if (antialiasing === void 0) { antialiasing = false; }\r\n if (renderSprites === void 0) { renderSprites = false; }\r\n return new Promise(function (resolve, reject) {\r\n ScreenshotTools.CreateScreenshotUsingRenderTarget(engine, camera, size, function (data) {\r\n if (typeof (data) !== \"undefined\") {\r\n resolve(data);\r\n }\r\n else {\r\n reject(new Error(\"Data is undefined\"));\r\n }\r\n }, mimeType, samples, antialiasing, fileName, renderSprites);\r\n });\r\n };\r\n /**\r\n * Gets height and width for screenshot size\r\n * @private\r\n */\r\n ScreenshotTools._getScreenshotSize = function (engine, camera, size) {\r\n var height = 0;\r\n var width = 0;\r\n //If a size value defined as object\r\n if (typeof (size) === 'object') {\r\n var precision = size.precision\r\n ? Math.abs(size.precision) // prevent GL_INVALID_VALUE : glViewport: negative width/height\r\n : 1;\r\n //If a width and height values is specified\r\n if (size.width && size.height) {\r\n height = size.height * precision;\r\n width = size.width * precision;\r\n }\r\n //If passing only width, computing height to keep display canvas ratio.\r\n else if (size.width && !size.height) {\r\n width = size.width * precision;\r\n height = Math.round(width / engine.getAspectRatio(camera));\r\n }\r\n //If passing only height, computing width to keep display canvas ratio.\r\n else if (size.height && !size.width) {\r\n height = size.height * precision;\r\n width = Math.round(height * engine.getAspectRatio(camera));\r\n }\r\n else {\r\n width = Math.round(engine.getRenderWidth() * precision);\r\n height = Math.round(width / engine.getAspectRatio(camera));\r\n }\r\n }\r\n //Assuming here that \"size\" parameter is a number\r\n else if (!isNaN(size)) {\r\n height = size;\r\n width = size;\r\n }\r\n // When creating the image data from the CanvasRenderingContext2D, the width and height is clamped to the size of the _gl context\r\n // On certain GPUs, it seems as if the _gl context truncates to an integer automatically. Therefore, if a user tries to pass the width of their canvas element\r\n // and it happens to be a float (1000.5 x 600.5 px), the engine.readPixels will return a different size array than context.createImageData\r\n // to resolve this, we truncate the floats here to ensure the same size\r\n if (width) {\r\n width = Math.floor(width);\r\n }\r\n if (height) {\r\n height = Math.floor(height);\r\n }\r\n return { height: height | 0, width: width | 0 };\r\n };\r\n return ScreenshotTools;\r\n}());\r\nexport { ScreenshotTools };\r\nTools.CreateScreenshot = ScreenshotTools.CreateScreenshot;\r\nTools.CreateScreenshotAsync = ScreenshotTools.CreateScreenshotAsync;\r\nTools.CreateScreenshotUsingRenderTarget = ScreenshotTools.CreateScreenshotUsingRenderTarget;\r\nTools.CreateScreenshotUsingRenderTargetAsync = ScreenshotTools.CreateScreenshotUsingRenderTargetAsync;\r\n//# sourceMappingURL=screenshotTools.js.map","import { ArrayTools } from \"../Misc/arrayTools\";\r\nimport { Matrix, Vector3, TmpVectors } from \"../Maths/math.vector\";\r\nimport { PickingInfo } from \"../Collisions/pickingInfo\";\r\nimport { IntersectionInfo } from \"../Collisions/intersectionInfo\";\r\nimport { Scene } from '../scene';\r\nimport { Camera } from '../Cameras/camera';\r\n/**\r\n * Class representing a ray with position and direction\r\n */\r\nvar Ray = /** @class */ (function () {\r\n /**\r\n * Creates a new ray\r\n * @param origin origin point\r\n * @param direction direction\r\n * @param length length of the ray\r\n */\r\n function Ray(\r\n /** origin point */\r\n origin, \r\n /** direction */\r\n direction, \r\n /** length of the ray */\r\n length) {\r\n if (length === void 0) { length = Number.MAX_VALUE; }\r\n this.origin = origin;\r\n this.direction = direction;\r\n this.length = length;\r\n }\r\n // Methods\r\n /**\r\n * Checks if the ray intersects a box\r\n * @param minimum bound of the box\r\n * @param maximum bound of the box\r\n * @param intersectionTreshold extra extend to be added to the box in all direction\r\n * @returns if the box was hit\r\n */\r\n Ray.prototype.intersectsBoxMinMax = function (minimum, maximum, intersectionTreshold) {\r\n if (intersectionTreshold === void 0) { intersectionTreshold = 0; }\r\n var newMinimum = Ray.TmpVector3[0].copyFromFloats(minimum.x - intersectionTreshold, minimum.y - intersectionTreshold, minimum.z - intersectionTreshold);\r\n var newMaximum = Ray.TmpVector3[1].copyFromFloats(maximum.x + intersectionTreshold, maximum.y + intersectionTreshold, maximum.z + intersectionTreshold);\r\n var d = 0.0;\r\n var maxValue = Number.MAX_VALUE;\r\n var inv;\r\n var min;\r\n var max;\r\n var temp;\r\n if (Math.abs(this.direction.x) < 0.0000001) {\r\n if (this.origin.x < newMinimum.x || this.origin.x > newMaximum.x) {\r\n return false;\r\n }\r\n }\r\n else {\r\n inv = 1.0 / this.direction.x;\r\n min = (newMinimum.x - this.origin.x) * inv;\r\n max = (newMaximum.x - this.origin.x) * inv;\r\n if (max === -Infinity) {\r\n max = Infinity;\r\n }\r\n if (min > max) {\r\n temp = min;\r\n min = max;\r\n max = temp;\r\n }\r\n d = Math.max(min, d);\r\n maxValue = Math.min(max, maxValue);\r\n if (d > maxValue) {\r\n return false;\r\n }\r\n }\r\n if (Math.abs(this.direction.y) < 0.0000001) {\r\n if (this.origin.y < newMinimum.y || this.origin.y > newMaximum.y) {\r\n return false;\r\n }\r\n }\r\n else {\r\n inv = 1.0 / this.direction.y;\r\n min = (newMinimum.y - this.origin.y) * inv;\r\n max = (newMaximum.y - this.origin.y) * inv;\r\n if (max === -Infinity) {\r\n max = Infinity;\r\n }\r\n if (min > max) {\r\n temp = min;\r\n min = max;\r\n max = temp;\r\n }\r\n d = Math.max(min, d);\r\n maxValue = Math.min(max, maxValue);\r\n if (d > maxValue) {\r\n return false;\r\n }\r\n }\r\n if (Math.abs(this.direction.z) < 0.0000001) {\r\n if (this.origin.z < newMinimum.z || this.origin.z > newMaximum.z) {\r\n return false;\r\n }\r\n }\r\n else {\r\n inv = 1.0 / this.direction.z;\r\n min = (newMinimum.z - this.origin.z) * inv;\r\n max = (newMaximum.z - this.origin.z) * inv;\r\n if (max === -Infinity) {\r\n max = Infinity;\r\n }\r\n if (min > max) {\r\n temp = min;\r\n min = max;\r\n max = temp;\r\n }\r\n d = Math.max(min, d);\r\n maxValue = Math.min(max, maxValue);\r\n if (d > maxValue) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Checks if the ray intersects a box\r\n * @param box the bounding box to check\r\n * @param intersectionTreshold extra extend to be added to the BoundingBox in all direction\r\n * @returns if the box was hit\r\n */\r\n Ray.prototype.intersectsBox = function (box, intersectionTreshold) {\r\n if (intersectionTreshold === void 0) { intersectionTreshold = 0; }\r\n return this.intersectsBoxMinMax(box.minimum, box.maximum, intersectionTreshold);\r\n };\r\n /**\r\n * If the ray hits a sphere\r\n * @param sphere the bounding sphere to check\r\n * @param intersectionTreshold extra extend to be added to the BoundingSphere in all direction\r\n * @returns true if it hits the sphere\r\n */\r\n Ray.prototype.intersectsSphere = function (sphere, intersectionTreshold) {\r\n if (intersectionTreshold === void 0) { intersectionTreshold = 0; }\r\n var x = sphere.center.x - this.origin.x;\r\n var y = sphere.center.y - this.origin.y;\r\n var z = sphere.center.z - this.origin.z;\r\n var pyth = (x * x) + (y * y) + (z * z);\r\n var radius = sphere.radius + intersectionTreshold;\r\n var rr = radius * radius;\r\n if (pyth <= rr) {\r\n return true;\r\n }\r\n var dot = (x * this.direction.x) + (y * this.direction.y) + (z * this.direction.z);\r\n if (dot < 0.0) {\r\n return false;\r\n }\r\n var temp = pyth - (dot * dot);\r\n return temp <= rr;\r\n };\r\n /**\r\n * If the ray hits a triange\r\n * @param vertex0 triangle vertex\r\n * @param vertex1 triangle vertex\r\n * @param vertex2 triangle vertex\r\n * @returns intersection information if hit\r\n */\r\n Ray.prototype.intersectsTriangle = function (vertex0, vertex1, vertex2) {\r\n var edge1 = Ray.TmpVector3[0];\r\n var edge2 = Ray.TmpVector3[1];\r\n var pvec = Ray.TmpVector3[2];\r\n var tvec = Ray.TmpVector3[3];\r\n var qvec = Ray.TmpVector3[4];\r\n vertex1.subtractToRef(vertex0, edge1);\r\n vertex2.subtractToRef(vertex0, edge2);\r\n Vector3.CrossToRef(this.direction, edge2, pvec);\r\n var det = Vector3.Dot(edge1, pvec);\r\n if (det === 0) {\r\n return null;\r\n }\r\n var invdet = 1 / det;\r\n this.origin.subtractToRef(vertex0, tvec);\r\n var bv = Vector3.Dot(tvec, pvec) * invdet;\r\n if (bv < 0 || bv > 1.0) {\r\n return null;\r\n }\r\n Vector3.CrossToRef(tvec, edge1, qvec);\r\n var bw = Vector3.Dot(this.direction, qvec) * invdet;\r\n if (bw < 0 || bv + bw > 1.0) {\r\n return null;\r\n }\r\n //check if the distance is longer than the predefined length.\r\n var distance = Vector3.Dot(edge2, qvec) * invdet;\r\n if (distance > this.length) {\r\n return null;\r\n }\r\n return new IntersectionInfo(1 - bv - bw, bv, distance);\r\n };\r\n /**\r\n * Checks if ray intersects a plane\r\n * @param plane the plane to check\r\n * @returns the distance away it was hit\r\n */\r\n Ray.prototype.intersectsPlane = function (plane) {\r\n var distance;\r\n var result1 = Vector3.Dot(plane.normal, this.direction);\r\n if (Math.abs(result1) < 9.99999997475243E-07) {\r\n return null;\r\n }\r\n else {\r\n var result2 = Vector3.Dot(plane.normal, this.origin);\r\n distance = (-plane.d - result2) / result1;\r\n if (distance < 0.0) {\r\n if (distance < -9.99999997475243E-07) {\r\n return null;\r\n }\r\n else {\r\n return 0;\r\n }\r\n }\r\n return distance;\r\n }\r\n };\r\n /**\r\n * Calculate the intercept of a ray on a given axis\r\n * @param axis to check 'x' | 'y' | 'z'\r\n * @param offset from axis interception (i.e. an offset of 1y is intercepted above ground)\r\n * @returns a vector containing the coordinates where 'axis' is equal to zero (else offset), or null if there is no intercept.\r\n */\r\n Ray.prototype.intersectsAxis = function (axis, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n switch (axis) {\r\n case 'y':\r\n var t = (this.origin.y - offset) / this.direction.y;\r\n if (t > 0) {\r\n return null;\r\n }\r\n return new Vector3(this.origin.x + (this.direction.x * -t), offset, this.origin.z + (this.direction.z * -t));\r\n case 'x':\r\n var t = (this.origin.x - offset) / this.direction.x;\r\n if (t > 0) {\r\n return null;\r\n }\r\n return new Vector3(offset, this.origin.y + (this.direction.y * -t), this.origin.z + (this.direction.z * -t));\r\n case 'z':\r\n var t = (this.origin.z - offset) / this.direction.z;\r\n if (t > 0) {\r\n return null;\r\n }\r\n return new Vector3(this.origin.x + (this.direction.x * -t), this.origin.y + (this.direction.y * -t), offset);\r\n default:\r\n return null;\r\n }\r\n };\r\n /**\r\n * Checks if ray intersects a mesh\r\n * @param mesh the mesh to check\r\n * @param fastCheck if only the bounding box should checked\r\n * @returns picking info of the intersecton\r\n */\r\n Ray.prototype.intersectsMesh = function (mesh, fastCheck) {\r\n var tm = TmpVectors.Matrix[0];\r\n mesh.getWorldMatrix().invertToRef(tm);\r\n if (this._tmpRay) {\r\n Ray.TransformToRef(this, tm, this._tmpRay);\r\n }\r\n else {\r\n this._tmpRay = Ray.Transform(this, tm);\r\n }\r\n return mesh.intersects(this._tmpRay, fastCheck);\r\n };\r\n /**\r\n * Checks if ray intersects a mesh\r\n * @param meshes the meshes to check\r\n * @param fastCheck if only the bounding box should checked\r\n * @param results array to store result in\r\n * @returns Array of picking infos\r\n */\r\n Ray.prototype.intersectsMeshes = function (meshes, fastCheck, results) {\r\n if (results) {\r\n results.length = 0;\r\n }\r\n else {\r\n results = [];\r\n }\r\n for (var i = 0; i < meshes.length; i++) {\r\n var pickInfo = this.intersectsMesh(meshes[i], fastCheck);\r\n if (pickInfo.hit) {\r\n results.push(pickInfo);\r\n }\r\n }\r\n results.sort(this._comparePickingInfo);\r\n return results;\r\n };\r\n Ray.prototype._comparePickingInfo = function (pickingInfoA, pickingInfoB) {\r\n if (pickingInfoA.distance < pickingInfoB.distance) {\r\n return -1;\r\n }\r\n else if (pickingInfoA.distance > pickingInfoB.distance) {\r\n return 1;\r\n }\r\n else {\r\n return 0;\r\n }\r\n };\r\n /**\r\n * Intersection test between the ray and a given segment whithin a given tolerance (threshold)\r\n * @param sega the first point of the segment to test the intersection against\r\n * @param segb the second point of the segment to test the intersection against\r\n * @param threshold the tolerance margin, if the ray doesn't intersect the segment but is close to the given threshold, the intersection is successful\r\n * @return the distance from the ray origin to the intersection point if there's intersection, or -1 if there's no intersection\r\n */\r\n Ray.prototype.intersectionSegment = function (sega, segb, threshold) {\r\n var o = this.origin;\r\n var u = TmpVectors.Vector3[0];\r\n var rsegb = TmpVectors.Vector3[1];\r\n var v = TmpVectors.Vector3[2];\r\n var w = TmpVectors.Vector3[3];\r\n segb.subtractToRef(sega, u);\r\n this.direction.scaleToRef(Ray.rayl, v);\r\n o.addToRef(v, rsegb);\r\n sega.subtractToRef(o, w);\r\n var a = Vector3.Dot(u, u); // always >= 0\r\n var b = Vector3.Dot(u, v);\r\n var c = Vector3.Dot(v, v); // always >= 0\r\n var d = Vector3.Dot(u, w);\r\n var e = Vector3.Dot(v, w);\r\n var D = a * c - b * b; // always >= 0\r\n var sc, sN, sD = D; // sc = sN / sD, default sD = D >= 0\r\n var tc, tN, tD = D; // tc = tN / tD, default tD = D >= 0\r\n // compute the line parameters of the two closest points\r\n if (D < Ray.smallnum) { // the lines are almost parallel\r\n sN = 0.0; // force using point P0 on segment S1\r\n sD = 1.0; // to prevent possible division by 0.0 later\r\n tN = e;\r\n tD = c;\r\n }\r\n else { // get the closest points on the infinite lines\r\n sN = (b * e - c * d);\r\n tN = (a * e - b * d);\r\n if (sN < 0.0) { // sc < 0 => the s=0 edge is visible\r\n sN = 0.0;\r\n tN = e;\r\n tD = c;\r\n }\r\n else if (sN > sD) { // sc > 1 => the s=1 edge is visible\r\n sN = sD;\r\n tN = e + b;\r\n tD = c;\r\n }\r\n }\r\n if (tN < 0.0) { // tc < 0 => the t=0 edge is visible\r\n tN = 0.0;\r\n // recompute sc for this edge\r\n if (-d < 0.0) {\r\n sN = 0.0;\r\n }\r\n else if (-d > a) {\r\n sN = sD;\r\n }\r\n else {\r\n sN = -d;\r\n sD = a;\r\n }\r\n }\r\n else if (tN > tD) { // tc > 1 => the t=1 edge is visible\r\n tN = tD;\r\n // recompute sc for this edge\r\n if ((-d + b) < 0.0) {\r\n sN = 0;\r\n }\r\n else if ((-d + b) > a) {\r\n sN = sD;\r\n }\r\n else {\r\n sN = (-d + b);\r\n sD = a;\r\n }\r\n }\r\n // finally do the division to get sc and tc\r\n sc = (Math.abs(sN) < Ray.smallnum ? 0.0 : sN / sD);\r\n tc = (Math.abs(tN) < Ray.smallnum ? 0.0 : tN / tD);\r\n // get the difference of the two closest points\r\n var qtc = TmpVectors.Vector3[4];\r\n v.scaleToRef(tc, qtc);\r\n var qsc = TmpVectors.Vector3[5];\r\n u.scaleToRef(sc, qsc);\r\n qsc.addInPlace(w);\r\n var dP = TmpVectors.Vector3[6];\r\n qsc.subtractToRef(qtc, dP); // = S1(sc) - S2(tc)\r\n var isIntersected = (tc > 0) && (tc <= this.length) && (dP.lengthSquared() < (threshold * threshold)); // return intersection result\r\n if (isIntersected) {\r\n return qsc.length();\r\n }\r\n return -1;\r\n };\r\n /**\r\n * Update the ray from viewport position\r\n * @param x position\r\n * @param y y position\r\n * @param viewportWidth viewport width\r\n * @param viewportHeight viewport height\r\n * @param world world matrix\r\n * @param view view matrix\r\n * @param projection projection matrix\r\n * @returns this ray updated\r\n */\r\n Ray.prototype.update = function (x, y, viewportWidth, viewportHeight, world, view, projection) {\r\n this.unprojectRayToRef(x, y, viewportWidth, viewportHeight, world, view, projection);\r\n return this;\r\n };\r\n // Statics\r\n /**\r\n * Creates a ray with origin and direction of 0,0,0\r\n * @returns the new ray\r\n */\r\n Ray.Zero = function () {\r\n return new Ray(Vector3.Zero(), Vector3.Zero());\r\n };\r\n /**\r\n * Creates a new ray from screen space and viewport\r\n * @param x position\r\n * @param y y position\r\n * @param viewportWidth viewport width\r\n * @param viewportHeight viewport height\r\n * @param world world matrix\r\n * @param view view matrix\r\n * @param projection projection matrix\r\n * @returns new ray\r\n */\r\n Ray.CreateNew = function (x, y, viewportWidth, viewportHeight, world, view, projection) {\r\n var result = Ray.Zero();\r\n return result.update(x, y, viewportWidth, viewportHeight, world, view, projection);\r\n };\r\n /**\r\n * Function will create a new transformed ray starting from origin and ending at the end point. Ray's length will be set, and ray will be\r\n * transformed to the given world matrix.\r\n * @param origin The origin point\r\n * @param end The end point\r\n * @param world a matrix to transform the ray to. Default is the identity matrix.\r\n * @returns the new ray\r\n */\r\n Ray.CreateNewFromTo = function (origin, end, world) {\r\n if (world === void 0) { world = Matrix.IdentityReadOnly; }\r\n var direction = end.subtract(origin);\r\n var length = Math.sqrt((direction.x * direction.x) + (direction.y * direction.y) + (direction.z * direction.z));\r\n direction.normalize();\r\n return Ray.Transform(new Ray(origin, direction, length), world);\r\n };\r\n /**\r\n * Transforms a ray by a matrix\r\n * @param ray ray to transform\r\n * @param matrix matrix to apply\r\n * @returns the resulting new ray\r\n */\r\n Ray.Transform = function (ray, matrix) {\r\n var result = new Ray(new Vector3(0, 0, 0), new Vector3(0, 0, 0));\r\n Ray.TransformToRef(ray, matrix, result);\r\n return result;\r\n };\r\n /**\r\n * Transforms a ray by a matrix\r\n * @param ray ray to transform\r\n * @param matrix matrix to apply\r\n * @param result ray to store result in\r\n */\r\n Ray.TransformToRef = function (ray, matrix, result) {\r\n Vector3.TransformCoordinatesToRef(ray.origin, matrix, result.origin);\r\n Vector3.TransformNormalToRef(ray.direction, matrix, result.direction);\r\n result.length = ray.length;\r\n var dir = result.direction;\r\n var len = dir.length();\r\n if (!(len === 0 || len === 1)) {\r\n var num = 1.0 / len;\r\n dir.x *= num;\r\n dir.y *= num;\r\n dir.z *= num;\r\n result.length *= len;\r\n }\r\n };\r\n /**\r\n * Unproject a ray from screen space to object space\r\n * @param sourceX defines the screen space x coordinate to use\r\n * @param sourceY defines the screen space y coordinate to use\r\n * @param viewportWidth defines the current width of the viewport\r\n * @param viewportHeight defines the current height of the viewport\r\n * @param world defines the world matrix to use (can be set to Identity to go to world space)\r\n * @param view defines the view matrix to use\r\n * @param projection defines the projection matrix to use\r\n */\r\n Ray.prototype.unprojectRayToRef = function (sourceX, sourceY, viewportWidth, viewportHeight, world, view, projection) {\r\n var matrix = TmpVectors.Matrix[0];\r\n world.multiplyToRef(view, matrix);\r\n matrix.multiplyToRef(projection, matrix);\r\n matrix.invert();\r\n var nearScreenSource = TmpVectors.Vector3[0];\r\n nearScreenSource.x = sourceX / viewportWidth * 2 - 1;\r\n nearScreenSource.y = -(sourceY / viewportHeight * 2 - 1);\r\n nearScreenSource.z = -1.0;\r\n var farScreenSource = TmpVectors.Vector3[1].copyFromFloats(nearScreenSource.x, nearScreenSource.y, 1.0);\r\n var nearVec3 = TmpVectors.Vector3[2];\r\n var farVec3 = TmpVectors.Vector3[3];\r\n Vector3._UnprojectFromInvertedMatrixToRef(nearScreenSource, matrix, nearVec3);\r\n Vector3._UnprojectFromInvertedMatrixToRef(farScreenSource, matrix, farVec3);\r\n this.origin.copyFrom(nearVec3);\r\n farVec3.subtractToRef(nearVec3, this.direction);\r\n this.direction.normalize();\r\n };\r\n Ray.TmpVector3 = ArrayTools.BuildArray(6, Vector3.Zero);\r\n Ray.smallnum = 0.00000001;\r\n Ray.rayl = 10e8;\r\n return Ray;\r\n}());\r\nexport { Ray };\r\nScene.prototype.createPickingRay = function (x, y, world, camera, cameraViewSpace) {\r\n if (cameraViewSpace === void 0) { cameraViewSpace = false; }\r\n var result = Ray.Zero();\r\n this.createPickingRayToRef(x, y, world, result, camera, cameraViewSpace);\r\n return result;\r\n};\r\nScene.prototype.createPickingRayToRef = function (x, y, world, result, camera, cameraViewSpace) {\r\n if (cameraViewSpace === void 0) { cameraViewSpace = false; }\r\n var engine = this.getEngine();\r\n if (!camera) {\r\n if (!this.activeCamera) {\r\n return this;\r\n }\r\n camera = this.activeCamera;\r\n }\r\n var cameraViewport = camera.viewport;\r\n var viewport = cameraViewport.toGlobal(engine.getRenderWidth(), engine.getRenderHeight());\r\n // Moving coordinates to local viewport world\r\n x = x / engine.getHardwareScalingLevel() - viewport.x;\r\n y = y / engine.getHardwareScalingLevel() - (engine.getRenderHeight() - viewport.y - viewport.height);\r\n result.update(x, y, viewport.width, viewport.height, world ? world : Matrix.IdentityReadOnly, cameraViewSpace ? Matrix.IdentityReadOnly : camera.getViewMatrix(), camera.getProjectionMatrix());\r\n return this;\r\n};\r\nScene.prototype.createPickingRayInCameraSpace = function (x, y, camera) {\r\n var result = Ray.Zero();\r\n this.createPickingRayInCameraSpaceToRef(x, y, result, camera);\r\n return result;\r\n};\r\nScene.prototype.createPickingRayInCameraSpaceToRef = function (x, y, result, camera) {\r\n if (!PickingInfo) {\r\n return this;\r\n }\r\n var engine = this.getEngine();\r\n if (!camera) {\r\n if (!this.activeCamera) {\r\n throw new Error(\"Active camera not set\");\r\n }\r\n camera = this.activeCamera;\r\n }\r\n var cameraViewport = camera.viewport;\r\n var viewport = cameraViewport.toGlobal(engine.getRenderWidth(), engine.getRenderHeight());\r\n var identity = Matrix.Identity();\r\n // Moving coordinates to local viewport world\r\n x = x / engine.getHardwareScalingLevel() - viewport.x;\r\n y = y / engine.getHardwareScalingLevel() - (engine.getRenderHeight() - viewport.y - viewport.height);\r\n result.update(x, y, viewport.width, viewport.height, identity, identity, camera.getProjectionMatrix());\r\n return this;\r\n};\r\nScene.prototype._internalPick = function (rayFunction, predicate, fastCheck, trianglePredicate) {\r\n if (!PickingInfo) {\r\n return null;\r\n }\r\n var pickingInfo = null;\r\n for (var meshIndex = 0; meshIndex < this.meshes.length; meshIndex++) {\r\n var mesh = this.meshes[meshIndex];\r\n if (predicate) {\r\n if (!predicate(mesh)) {\r\n continue;\r\n }\r\n }\r\n else if (!mesh.isEnabled() || !mesh.isVisible || !mesh.isPickable) {\r\n continue;\r\n }\r\n var world = mesh.getWorldMatrix();\r\n var ray = rayFunction(world);\r\n var result = mesh.intersects(ray, fastCheck, trianglePredicate);\r\n if (!result || !result.hit) {\r\n continue;\r\n }\r\n if (!fastCheck && pickingInfo != null && result.distance >= pickingInfo.distance) {\r\n continue;\r\n }\r\n pickingInfo = result;\r\n if (fastCheck) {\r\n break;\r\n }\r\n }\r\n return pickingInfo || new PickingInfo();\r\n};\r\nScene.prototype._internalMultiPick = function (rayFunction, predicate, trianglePredicate) {\r\n if (!PickingInfo) {\r\n return null;\r\n }\r\n var pickingInfos = new Array();\r\n for (var meshIndex = 0; meshIndex < this.meshes.length; meshIndex++) {\r\n var mesh = this.meshes[meshIndex];\r\n if (predicate) {\r\n if (!predicate(mesh)) {\r\n continue;\r\n }\r\n }\r\n else if (!mesh.isEnabled() || !mesh.isVisible || !mesh.isPickable) {\r\n continue;\r\n }\r\n var world = mesh.getWorldMatrix();\r\n var ray = rayFunction(world);\r\n var result = mesh.intersects(ray, false, trianglePredicate);\r\n if (!result || !result.hit) {\r\n continue;\r\n }\r\n pickingInfos.push(result);\r\n }\r\n return pickingInfos;\r\n};\r\nScene.prototype.pick = function (x, y, predicate, fastCheck, camera, trianglePredicate) {\r\n var _this = this;\r\n if (!PickingInfo) {\r\n return null;\r\n }\r\n var result = this._internalPick(function (world) {\r\n if (!_this._tempPickingRay) {\r\n _this._tempPickingRay = Ray.Zero();\r\n }\r\n _this.createPickingRayToRef(x, y, world, _this._tempPickingRay, camera || null);\r\n return _this._tempPickingRay;\r\n }, predicate, fastCheck, trianglePredicate);\r\n if (result) {\r\n result.ray = this.createPickingRay(x, y, Matrix.Identity(), camera || null);\r\n }\r\n return result;\r\n};\r\nScene.prototype.pickWithRay = function (ray, predicate, fastCheck, trianglePredicate) {\r\n var _this = this;\r\n var result = this._internalPick(function (world) {\r\n if (!_this._pickWithRayInverseMatrix) {\r\n _this._pickWithRayInverseMatrix = Matrix.Identity();\r\n }\r\n world.invertToRef(_this._pickWithRayInverseMatrix);\r\n if (!_this._cachedRayForTransform) {\r\n _this._cachedRayForTransform = Ray.Zero();\r\n }\r\n Ray.TransformToRef(ray, _this._pickWithRayInverseMatrix, _this._cachedRayForTransform);\r\n return _this._cachedRayForTransform;\r\n }, predicate, fastCheck, trianglePredicate);\r\n if (result) {\r\n result.ray = ray;\r\n }\r\n return result;\r\n};\r\nScene.prototype.multiPick = function (x, y, predicate, camera, trianglePredicate) {\r\n var _this = this;\r\n return this._internalMultiPick(function (world) { return _this.createPickingRay(x, y, world, camera || null); }, predicate, trianglePredicate);\r\n};\r\nScene.prototype.multiPickWithRay = function (ray, predicate, trianglePredicate) {\r\n var _this = this;\r\n return this._internalMultiPick(function (world) {\r\n if (!_this._pickWithRayInverseMatrix) {\r\n _this._pickWithRayInverseMatrix = Matrix.Identity();\r\n }\r\n world.invertToRef(_this._pickWithRayInverseMatrix);\r\n if (!_this._cachedRayForTransform) {\r\n _this._cachedRayForTransform = Ray.Zero();\r\n }\r\n Ray.TransformToRef(ray, _this._pickWithRayInverseMatrix, _this._cachedRayForTransform);\r\n return _this._cachedRayForTransform;\r\n }, predicate, trianglePredicate);\r\n};\r\nCamera.prototype.getForwardRay = function (length, transform, origin) {\r\n if (length === void 0) { length = 100; }\r\n if (!transform) {\r\n transform = this.getWorldMatrix();\r\n }\r\n if (!origin) {\r\n origin = this.position;\r\n }\r\n var forward = this._scene.useRightHandedSystem ? new Vector3(0, 0, -1) : new Vector3(0, 0, 1);\r\n var forwardWorld = Vector3.TransformNormal(forward, transform);\r\n var direction = Vector3.Normalize(forwardWorld);\r\n return new Ray(origin, direction, length);\r\n};\r\n//# sourceMappingURL=ray.js.map","import { Vector3, Matrix } from '../Maths/math.vector';\r\n/**\r\n * Class containing a set of static utilities functions for managing Pivots\r\n * @hidden\r\n */\r\nvar PivotTools = /** @class */ (function () {\r\n function PivotTools() {\r\n }\r\n /** @hidden */\r\n PivotTools._RemoveAndStorePivotPoint = function (mesh) {\r\n if (mesh && PivotTools._PivotCached === 0) {\r\n // Save old pivot and set pivot to 0,0,0\r\n mesh.getPivotPointToRef(PivotTools._OldPivotPoint);\r\n if (!PivotTools._OldPivotPoint.equalsToFloats(0, 0, 0)) {\r\n mesh.setPivotMatrix(Matrix.IdentityReadOnly);\r\n PivotTools._OldPivotPoint.subtractToRef(mesh.getPivotPoint(), PivotTools._PivotTranslation);\r\n PivotTools._PivotTmpVector.copyFromFloats(1, 1, 1);\r\n PivotTools._PivotTmpVector.subtractInPlace(mesh.scaling);\r\n PivotTools._PivotTmpVector.multiplyInPlace(PivotTools._PivotTranslation);\r\n mesh.position.addInPlace(PivotTools._PivotTmpVector);\r\n }\r\n }\r\n PivotTools._PivotCached++;\r\n };\r\n /** @hidden */\r\n PivotTools._RestorePivotPoint = function (mesh) {\r\n if (mesh && !PivotTools._OldPivotPoint.equalsToFloats(0, 0, 0) && PivotTools._PivotCached === 1) {\r\n mesh.setPivotPoint(PivotTools._OldPivotPoint);\r\n PivotTools._PivotTmpVector.copyFromFloats(1, 1, 1);\r\n PivotTools._PivotTmpVector.subtractInPlace(mesh.scaling);\r\n PivotTools._PivotTmpVector.multiplyInPlace(PivotTools._PivotTranslation);\r\n mesh.position.subtractInPlace(PivotTools._PivotTmpVector);\r\n }\r\n this._PivotCached--;\r\n };\r\n // Stores the state of the pivot cache (_oldPivotPoint, _pivotTranslation)\r\n // store/remove pivot point should only be applied during their outermost calls\r\n PivotTools._PivotCached = 0;\r\n PivotTools._OldPivotPoint = new Vector3();\r\n PivotTools._PivotTranslation = new Vector3();\r\n PivotTools._PivotTmpVector = new Vector3();\r\n return PivotTools;\r\n}());\r\nexport { PivotTools };\r\n//# sourceMappingURL=pivotTools.js.map","import { Mesh } from \"../../Meshes/mesh\";\r\nimport { Scene } from \"../../scene\";\r\nimport { Observable } from \"../../Misc/observable\";\r\nimport { Vector3 } from \"../../Maths/math.vector\";\r\nimport { PointerEventTypes } from \"../../Events/pointerEvents\";\r\nimport { Ray } from \"../../Culling/ray\";\r\nimport { PivotTools } from '../../Misc/pivotTools';\r\nimport \"../../Meshes/Builders/planeBuilder\";\r\n/**\r\n * A behavior that when attached to a mesh will allow the mesh to be dragged around the screen based on pointer events\r\n */\r\nvar PointerDragBehavior = /** @class */ (function () {\r\n /**\r\n * Creates a pointer drag behavior that can be attached to a mesh\r\n * @param options The drag axis or normal of the plane that will be dragged across. If no options are specified the drag plane will always face the ray's origin (eg. camera)\r\n */\r\n function PointerDragBehavior(options) {\r\n this._useAlternatePickedPointAboveMaxDragAngleDragSpeed = -1.1;\r\n /**\r\n * The maximum tolerated angle between the drag plane and dragging pointer rays to trigger pointer events. Set to 0 to allow any angle (default: 0)\r\n */\r\n this.maxDragAngle = 0;\r\n /**\r\n * @hidden\r\n */\r\n this._useAlternatePickedPointAboveMaxDragAngle = false;\r\n /**\r\n * The id of the pointer that is currently interacting with the behavior (-1 when no pointer is active)\r\n */\r\n this.currentDraggingPointerID = -1;\r\n /**\r\n * If the behavior is currently in a dragging state\r\n */\r\n this.dragging = false;\r\n /**\r\n * The distance towards the target drag position to move each frame. This can be useful to avoid jitter. Set this to 1 for no delay. (Default: 0.2)\r\n */\r\n this.dragDeltaRatio = 0.2;\r\n /**\r\n * If the drag plane orientation should be updated during the dragging (Default: true)\r\n */\r\n this.updateDragPlane = true;\r\n // Debug mode will display drag planes to help visualize behavior\r\n this._debugMode = false;\r\n this._moving = false;\r\n /**\r\n * Fires each time the attached mesh is dragged with the pointer\r\n * * delta between last drag position and current drag position in world space\r\n * * dragDistance along the drag axis\r\n * * dragPlaneNormal normal of the current drag plane used during the drag\r\n * * dragPlanePoint in world space where the drag intersects the drag plane\r\n */\r\n this.onDragObservable = new Observable();\r\n /**\r\n * Fires each time a drag begins (eg. mouse down on mesh)\r\n */\r\n this.onDragStartObservable = new Observable();\r\n /**\r\n * Fires each time a drag ends (eg. mouse release after drag)\r\n */\r\n this.onDragEndObservable = new Observable();\r\n /**\r\n * If the attached mesh should be moved when dragged\r\n */\r\n this.moveAttached = true;\r\n /**\r\n * If the drag behavior will react to drag events (Default: true)\r\n */\r\n this.enabled = true;\r\n /**\r\n * If pointer events should start and release the drag (Default: true)\r\n */\r\n this.startAndReleaseDragOnPointerEvents = true;\r\n /**\r\n * If camera controls should be detached during the drag\r\n */\r\n this.detachCameraControls = true;\r\n /**\r\n * If set, the drag plane/axis will be rotated based on the attached mesh's world rotation (Default: true)\r\n */\r\n this.useObjectOrientationForDragging = true;\r\n /**\r\n * Predicate to determine if it is valid to move the object to a new position when it is moved\r\n */\r\n this.validateDrag = function (targetPosition) { return true; };\r\n this._tmpVector = new Vector3(0, 0, 0);\r\n this._alternatePickedPoint = new Vector3(0, 0, 0);\r\n this._worldDragAxis = new Vector3(0, 0, 0);\r\n this._targetPosition = new Vector3(0, 0, 0);\r\n this._attachedElement = null;\r\n this._startDragRay = new Ray(new Vector3(), new Vector3());\r\n this._lastPointerRay = {};\r\n this._dragDelta = new Vector3();\r\n // Variables to avoid instantiation in the below method\r\n this._pointA = new Vector3(0, 0, 0);\r\n this._pointB = new Vector3(0, 0, 0);\r\n this._pointC = new Vector3(0, 0, 0);\r\n this._lineA = new Vector3(0, 0, 0);\r\n this._lineB = new Vector3(0, 0, 0);\r\n this._localAxis = new Vector3(0, 0, 0);\r\n this._lookAt = new Vector3(0, 0, 0);\r\n this._options = options ? options : {};\r\n var optionCount = 0;\r\n if (this._options.dragAxis) {\r\n optionCount++;\r\n }\r\n if (this._options.dragPlaneNormal) {\r\n optionCount++;\r\n }\r\n if (optionCount > 1) {\r\n throw \"Multiple drag modes specified in dragBehavior options. Only one expected\";\r\n }\r\n }\r\n Object.defineProperty(PointerDragBehavior.prototype, \"options\", {\r\n /**\r\n * Gets the options used by the behavior\r\n */\r\n get: function () {\r\n return this._options;\r\n },\r\n /**\r\n * Sets the options used by the behavior\r\n */\r\n set: function (options) {\r\n this._options = options;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(PointerDragBehavior.prototype, \"name\", {\r\n /**\r\n * The name of the behavior\r\n */\r\n get: function () {\r\n return \"PointerDrag\";\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Initializes the behavior\r\n */\r\n PointerDragBehavior.prototype.init = function () { };\r\n /**\r\n * Attaches the drag behavior the passed in mesh\r\n * @param ownerNode The mesh that will be dragged around once attached\r\n * @param predicate Predicate to use for pick filtering\r\n */\r\n PointerDragBehavior.prototype.attach = function (ownerNode, predicate) {\r\n var _this = this;\r\n this._scene = ownerNode.getScene();\r\n this.attachedNode = ownerNode;\r\n // Initialize drag plane to not interfere with existing scene\r\n if (!PointerDragBehavior._planeScene) {\r\n if (this._debugMode) {\r\n PointerDragBehavior._planeScene = this._scene;\r\n }\r\n else {\r\n PointerDragBehavior._planeScene = new Scene(this._scene.getEngine(), { virtual: true });\r\n PointerDragBehavior._planeScene.detachControl();\r\n this._scene.onDisposeObservable.addOnce(function () {\r\n PointerDragBehavior._planeScene.dispose();\r\n PointerDragBehavior._planeScene = null;\r\n });\r\n }\r\n }\r\n this._dragPlane = Mesh.CreatePlane(\"pointerDragPlane\", this._debugMode ? 1 : 10000, PointerDragBehavior._planeScene, false, Mesh.DOUBLESIDE);\r\n // State of the drag\r\n this.lastDragPosition = new Vector3(0, 0, 0);\r\n var pickPredicate = !!predicate ? predicate : function (m) {\r\n return _this.attachedNode == m || m.isDescendantOf(_this.attachedNode);\r\n };\r\n this._pointerObserver = this._scene.onPointerObservable.add(function (pointerInfo, eventState) {\r\n if (!_this.enabled) {\r\n return;\r\n }\r\n if (pointerInfo.type == PointerEventTypes.POINTERDOWN) {\r\n if (_this.startAndReleaseDragOnPointerEvents && !_this.dragging && pointerInfo.pickInfo && pointerInfo.pickInfo.hit && pointerInfo.pickInfo.pickedMesh && pointerInfo.pickInfo.pickedPoint && pointerInfo.pickInfo.ray && pickPredicate(pointerInfo.pickInfo.pickedMesh)) {\r\n _this._startDrag(pointerInfo.event.pointerId, pointerInfo.pickInfo.ray, pointerInfo.pickInfo.pickedPoint);\r\n }\r\n }\r\n else if (pointerInfo.type == PointerEventTypes.POINTERUP) {\r\n if (_this.startAndReleaseDragOnPointerEvents && _this.currentDraggingPointerID == pointerInfo.event.pointerId) {\r\n _this.releaseDrag();\r\n }\r\n }\r\n else if (pointerInfo.type == PointerEventTypes.POINTERMOVE) {\r\n var pointerId = pointerInfo.event.pointerId;\r\n // If drag was started with anyMouseID specified, set pointerID to the next mouse that moved\r\n if (_this.currentDraggingPointerID === PointerDragBehavior._AnyMouseID && pointerId !== PointerDragBehavior._AnyMouseID && pointerInfo.event.pointerType == \"mouse\") {\r\n if (_this._lastPointerRay[_this.currentDraggingPointerID]) {\r\n _this._lastPointerRay[pointerId] = _this._lastPointerRay[_this.currentDraggingPointerID];\r\n delete _this._lastPointerRay[_this.currentDraggingPointerID];\r\n }\r\n _this.currentDraggingPointerID = pointerId;\r\n }\r\n // Keep track of last pointer ray, this is used simulating the start of a drag in startDrag()\r\n if (!_this._lastPointerRay[pointerId]) {\r\n _this._lastPointerRay[pointerId] = new Ray(new Vector3(), new Vector3());\r\n }\r\n if (pointerInfo.pickInfo && pointerInfo.pickInfo.ray) {\r\n _this._lastPointerRay[pointerId].origin.copyFrom(pointerInfo.pickInfo.ray.origin);\r\n _this._lastPointerRay[pointerId].direction.copyFrom(pointerInfo.pickInfo.ray.direction);\r\n if (_this.currentDraggingPointerID == pointerId && _this.dragging) {\r\n _this._moveDrag(pointerInfo.pickInfo.ray);\r\n }\r\n }\r\n }\r\n });\r\n this._beforeRenderObserver = this._scene.onBeforeRenderObservable.add(function () {\r\n if (_this._moving && _this.moveAttached) {\r\n PivotTools._RemoveAndStorePivotPoint(_this.attachedNode);\r\n // Slowly move mesh to avoid jitter\r\n _this._targetPosition.subtractToRef((_this.attachedNode).absolutePosition, _this._tmpVector);\r\n _this._tmpVector.scaleInPlace(_this.dragDeltaRatio);\r\n (_this.attachedNode).getAbsolutePosition().addToRef(_this._tmpVector, _this._tmpVector);\r\n if (_this.validateDrag(_this._tmpVector)) {\r\n (_this.attachedNode).setAbsolutePosition(_this._tmpVector);\r\n }\r\n PivotTools._RestorePivotPoint(_this.attachedNode);\r\n }\r\n });\r\n };\r\n /**\r\n * Force relase the drag action by code.\r\n */\r\n PointerDragBehavior.prototype.releaseDrag = function () {\r\n if (this.dragging) {\r\n this.onDragEndObservable.notifyObservers({ dragPlanePoint: this.lastDragPosition, pointerId: this.currentDraggingPointerID });\r\n this.dragging = false;\r\n }\r\n this.currentDraggingPointerID = -1;\r\n this._moving = false;\r\n // Reattach camera controls\r\n if (this.detachCameraControls && this._attachedElement && this._scene.activeCamera && !this._scene.activeCamera.leftCamera) {\r\n this._scene.activeCamera.attachControl(this._attachedElement, this._scene.activeCamera.inputs ? this._scene.activeCamera.inputs.noPreventDefault : true);\r\n }\r\n };\r\n /**\r\n * Simulates the start of a pointer drag event on the behavior\r\n * @param pointerId pointerID of the pointer that should be simulated (Default: Any mouse pointer ID)\r\n * @param fromRay initial ray of the pointer to be simulated (Default: Ray from camera to attached mesh)\r\n * @param startPickedPoint picked point of the pointer to be simulated (Default: attached mesh position)\r\n */\r\n PointerDragBehavior.prototype.startDrag = function (pointerId, fromRay, startPickedPoint) {\r\n if (pointerId === void 0) { pointerId = PointerDragBehavior._AnyMouseID; }\r\n this._startDrag(pointerId, fromRay, startPickedPoint);\r\n var lastRay = this._lastPointerRay[pointerId];\r\n if (pointerId === PointerDragBehavior._AnyMouseID) {\r\n lastRay = this._lastPointerRay[Object.keys(this._lastPointerRay)[0]];\r\n }\r\n if (lastRay) {\r\n // if there was a last pointer ray drag the object there\r\n this._moveDrag(lastRay);\r\n }\r\n };\r\n PointerDragBehavior.prototype._startDrag = function (pointerId, fromRay, startPickedPoint) {\r\n if (!this._scene.activeCamera || this.dragging || !this.attachedNode) {\r\n return;\r\n }\r\n PivotTools._RemoveAndStorePivotPoint(this.attachedNode);\r\n // Create start ray from the camera to the object\r\n if (fromRay) {\r\n this._startDragRay.direction.copyFrom(fromRay.direction);\r\n this._startDragRay.origin.copyFrom(fromRay.origin);\r\n }\r\n else {\r\n this._startDragRay.origin.copyFrom(this._scene.activeCamera.position);\r\n this.attachedNode.getWorldMatrix().getTranslationToRef(this._tmpVector);\r\n this._tmpVector.subtractToRef(this._scene.activeCamera.position, this._startDragRay.direction);\r\n }\r\n this._updateDragPlanePosition(this._startDragRay, startPickedPoint ? startPickedPoint : this._tmpVector);\r\n var pickedPoint = this._pickWithRayOnDragPlane(this._startDragRay);\r\n if (pickedPoint) {\r\n this.dragging = true;\r\n this.currentDraggingPointerID = pointerId;\r\n this.lastDragPosition.copyFrom(pickedPoint);\r\n this.onDragStartObservable.notifyObservers({ dragPlanePoint: pickedPoint, pointerId: this.currentDraggingPointerID });\r\n this._targetPosition.copyFrom((this.attachedNode).absolutePosition);\r\n // Detatch camera controls\r\n if (this.detachCameraControls && this._scene.activeCamera && this._scene.activeCamera.inputs && !this._scene.activeCamera.leftCamera) {\r\n if (this._scene.activeCamera.inputs.attachedElement) {\r\n this._attachedElement = this._scene.activeCamera.inputs.attachedElement;\r\n this._scene.activeCamera.detachControl(this._scene.activeCamera.inputs.attachedElement);\r\n }\r\n else {\r\n this._attachedElement = null;\r\n }\r\n }\r\n }\r\n PivotTools._RestorePivotPoint(this.attachedNode);\r\n };\r\n PointerDragBehavior.prototype._moveDrag = function (ray) {\r\n this._moving = true;\r\n var pickedPoint = this._pickWithRayOnDragPlane(ray);\r\n if (pickedPoint) {\r\n if (this.updateDragPlane) {\r\n this._updateDragPlanePosition(ray, pickedPoint);\r\n }\r\n var dragLength = 0;\r\n // depending on the drag mode option drag accordingly\r\n if (this._options.dragAxis) {\r\n // Convert local drag axis to world if useObjectOrientationForDragging\r\n this.useObjectOrientationForDragging ? Vector3.TransformCoordinatesToRef(this._options.dragAxis, this.attachedNode.getWorldMatrix().getRotationMatrix(), this._worldDragAxis) : this._worldDragAxis.copyFrom(this._options.dragAxis);\r\n // Project delta drag from the drag plane onto the drag axis\r\n pickedPoint.subtractToRef(this.lastDragPosition, this._tmpVector);\r\n dragLength = Vector3.Dot(this._tmpVector, this._worldDragAxis);\r\n this._worldDragAxis.scaleToRef(dragLength, this._dragDelta);\r\n }\r\n else {\r\n dragLength = this._dragDelta.length();\r\n pickedPoint.subtractToRef(this.lastDragPosition, this._dragDelta);\r\n }\r\n this._targetPosition.addInPlace(this._dragDelta);\r\n this.onDragObservable.notifyObservers({ dragDistance: dragLength, delta: this._dragDelta, dragPlanePoint: pickedPoint, dragPlaneNormal: this._dragPlane.forward, pointerId: this.currentDraggingPointerID });\r\n this.lastDragPosition.copyFrom(pickedPoint);\r\n }\r\n };\r\n PointerDragBehavior.prototype._pickWithRayOnDragPlane = function (ray) {\r\n var _this = this;\r\n if (!ray) {\r\n return null;\r\n }\r\n // Calculate angle between plane normal and ray\r\n var angle = Math.acos(Vector3.Dot(this._dragPlane.forward, ray.direction));\r\n // Correct if ray is casted from oposite side\r\n if (angle > Math.PI / 2) {\r\n angle = Math.PI - angle;\r\n }\r\n // If the angle is too perpendicular to the plane pick another point on the plane where it is looking\r\n if (this.maxDragAngle > 0 && angle > this.maxDragAngle) {\r\n if (this._useAlternatePickedPointAboveMaxDragAngle) {\r\n // Invert ray direction along the towards object axis\r\n this._tmpVector.copyFrom(ray.direction);\r\n (this.attachedNode).absolutePosition.subtractToRef(ray.origin, this._alternatePickedPoint);\r\n this._alternatePickedPoint.normalize();\r\n this._alternatePickedPoint.scaleInPlace(this._useAlternatePickedPointAboveMaxDragAngleDragSpeed * Vector3.Dot(this._alternatePickedPoint, this._tmpVector));\r\n this._tmpVector.addInPlace(this._alternatePickedPoint);\r\n // Project resulting vector onto the drag plane and add it to the attached nodes absolute position to get a picked point\r\n var dot = Vector3.Dot(this._dragPlane.forward, this._tmpVector);\r\n this._dragPlane.forward.scaleToRef(-dot, this._alternatePickedPoint);\r\n this._alternatePickedPoint.addInPlace(this._tmpVector);\r\n this._alternatePickedPoint.addInPlace((this.attachedNode).absolutePosition);\r\n return this._alternatePickedPoint;\r\n }\r\n else {\r\n return null;\r\n }\r\n }\r\n var pickResult = PointerDragBehavior._planeScene.pickWithRay(ray, function (m) { return m == _this._dragPlane; });\r\n if (pickResult && pickResult.hit && pickResult.pickedMesh && pickResult.pickedPoint) {\r\n return pickResult.pickedPoint;\r\n }\r\n else {\r\n return null;\r\n }\r\n };\r\n // Position the drag plane based on the attached mesh position, for single axis rotate the plane along the axis to face the camera\r\n PointerDragBehavior.prototype._updateDragPlanePosition = function (ray, dragPlanePosition) {\r\n this._pointA.copyFrom(dragPlanePosition);\r\n if (this._options.dragAxis) {\r\n this.useObjectOrientationForDragging ? Vector3.TransformCoordinatesToRef(this._options.dragAxis, this.attachedNode.getWorldMatrix().getRotationMatrix(), this._localAxis) : this._localAxis.copyFrom(this._options.dragAxis);\r\n // Calculate plane normal in direction of camera but perpendicular to drag axis\r\n this._pointA.addToRef(this._localAxis, this._pointB); // towards drag axis\r\n ray.origin.subtractToRef(this._pointA, this._pointC);\r\n this._pointA.addToRef(this._pointC.normalize(), this._pointC); // towards camera\r\n // Get perpendicular line from direction to camera and drag axis\r\n this._pointB.subtractToRef(this._pointA, this._lineA);\r\n this._pointC.subtractToRef(this._pointA, this._lineB);\r\n Vector3.CrossToRef(this._lineA, this._lineB, this._lookAt);\r\n // Get perpendicular line from previous result and drag axis to adjust lineB to be perpendiculat to camera\r\n Vector3.CrossToRef(this._lineA, this._lookAt, this._lookAt);\r\n this._lookAt.normalize();\r\n this._dragPlane.position.copyFrom(this._pointA);\r\n this._pointA.addToRef(this._lookAt, this._lookAt);\r\n this._dragPlane.lookAt(this._lookAt);\r\n }\r\n else if (this._options.dragPlaneNormal) {\r\n this.useObjectOrientationForDragging ? Vector3.TransformCoordinatesToRef(this._options.dragPlaneNormal, this.attachedNode.getWorldMatrix().getRotationMatrix(), this._localAxis) : this._localAxis.copyFrom(this._options.dragPlaneNormal);\r\n this._dragPlane.position.copyFrom(this._pointA);\r\n this._pointA.addToRef(this._localAxis, this._lookAt);\r\n this._dragPlane.lookAt(this._lookAt);\r\n }\r\n else {\r\n this._dragPlane.position.copyFrom(this._pointA);\r\n this._dragPlane.lookAt(ray.origin);\r\n }\r\n // Update the position of the drag plane so it doesn't get out of sync with the node (eg. when moving back and forth quickly)\r\n this._dragPlane.position.copyFrom(this.attachedNode.absolutePosition);\r\n this._dragPlane.computeWorldMatrix(true);\r\n };\r\n /**\r\n * Detaches the behavior from the mesh\r\n */\r\n PointerDragBehavior.prototype.detach = function () {\r\n if (this._pointerObserver) {\r\n this._scene.onPointerObservable.remove(this._pointerObserver);\r\n }\r\n if (this._beforeRenderObserver) {\r\n this._scene.onBeforeRenderObservable.remove(this._beforeRenderObserver);\r\n }\r\n this.releaseDrag();\r\n };\r\n PointerDragBehavior._AnyMouseID = -2;\r\n return PointerDragBehavior;\r\n}());\r\nexport { PointerDragBehavior };\r\n//# sourceMappingURL=pointerDragBehavior.js.map","import { Mesh } from \"../mesh\";\r\nimport { VertexData } from \"../mesh.vertexData\";\r\nVertexData.CreateDisc = function (options) {\r\n var positions = new Array();\r\n var indices = new Array();\r\n var normals = new Array();\r\n var uvs = new Array();\r\n var radius = options.radius || 0.5;\r\n var tessellation = options.tessellation || 64;\r\n var arc = options.arc && (options.arc <= 0 || options.arc > 1) ? 1.0 : options.arc || 1.0;\r\n var sideOrientation = (options.sideOrientation === 0) ? 0 : options.sideOrientation || VertexData.DEFAULTSIDE;\r\n // positions and uvs\r\n positions.push(0, 0, 0); // disc center first\r\n uvs.push(0.5, 0.5);\r\n var theta = Math.PI * 2 * arc;\r\n var step = theta / tessellation;\r\n for (var a = 0; a < theta; a += step) {\r\n var x = Math.cos(a);\r\n var y = Math.sin(a);\r\n var u = (x + 1) / 2;\r\n var v = (1 - y) / 2;\r\n positions.push(radius * x, radius * y, 0);\r\n uvs.push(u, v);\r\n }\r\n if (arc === 1) {\r\n positions.push(positions[3], positions[4], positions[5]); // close the circle\r\n uvs.push(uvs[2], uvs[3]);\r\n }\r\n //indices\r\n var vertexNb = positions.length / 3;\r\n for (var i = 1; i < vertexNb - 1; i++) {\r\n indices.push(i + 1, 0, i);\r\n }\r\n // result\r\n VertexData.ComputeNormals(positions, indices, normals);\r\n VertexData._ComputeSides(sideOrientation, positions, indices, normals, uvs, options.frontUVs, options.backUVs);\r\n var vertexData = new VertexData();\r\n vertexData.indices = indices;\r\n vertexData.positions = positions;\r\n vertexData.normals = normals;\r\n vertexData.uvs = uvs;\r\n return vertexData;\r\n};\r\nMesh.CreateDisc = function (name, radius, tessellation, scene, updatable, sideOrientation) {\r\n if (scene === void 0) { scene = null; }\r\n var options = {\r\n radius: radius,\r\n tessellation: tessellation,\r\n sideOrientation: sideOrientation,\r\n updatable: updatable\r\n };\r\n return DiscBuilder.CreateDisc(name, options, scene);\r\n};\r\n/**\r\n * Class containing static functions to help procedurally build meshes\r\n */\r\nvar DiscBuilder = /** @class */ (function () {\r\n function DiscBuilder() {\r\n }\r\n /**\r\n * Creates a plane polygonal mesh. By default, this is a disc\r\n * * The parameter `radius` sets the radius size (float) of the polygon (default 0.5)\r\n * * The parameter `tessellation` sets the number of polygon sides (positive integer, default 64). So a tessellation valued to 3 will build a triangle, to 4 a square, etc\r\n * * You can create an unclosed polygon with the parameter `arc` (positive float, default 1), valued between 0 and 1, what is the ratio of the circumference : 2 x PI x ratio\r\n * * You can also set the mesh side orientation with the values : BABYLON.Mesh.FRONTSIDE (default), BABYLON.Mesh.BACKSIDE or BABYLON.Mesh.DOUBLESIDE\r\n * * If you create a double-sided mesh, you can choose what parts of the texture image to crop and stick respectively on the front and the back sides with the parameters `frontUVs` and `backUVs` (Vector4). Detail here : https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @param name defines the name of the mesh\r\n * @param options defines the options used to create the mesh\r\n * @param scene defines the hosting scene\r\n * @returns the plane polygonal mesh\r\n * @see https://doc.babylonjs.com/how_to/set_shapes#disc-or-regular-polygon\r\n */\r\n DiscBuilder.CreateDisc = function (name, options, scene) {\r\n if (scene === void 0) { scene = null; }\r\n var disc = new Mesh(name, scene);\r\n options.sideOrientation = Mesh._GetDefaultSideOrientation(options.sideOrientation);\r\n disc._originalBuilderSideOrientation = options.sideOrientation;\r\n var vertexData = VertexData.CreateDisc(options);\r\n vertexData.applyToMesh(disc, options.updatable);\r\n return disc;\r\n };\r\n return DiscBuilder;\r\n}());\r\nexport { DiscBuilder };\r\n//# sourceMappingURL=discBuilder.js.map","import { Vector3, TmpVectors, Quaternion, Vector4 } from \"../Maths/math.vector\";\r\nimport { Color4 } from '../Maths/math.color';\r\nimport { BoundingInfo } from \"../Culling/boundingInfo\";\r\nimport { BoundingSphere } from \"../Culling/boundingSphere\";\r\nimport { AbstractMesh } from '../Meshes/abstractMesh';\r\n/**\r\n * Represents one particle of a solid particle system.\r\n */\r\nvar SolidParticle = /** @class */ (function () {\r\n /**\r\n * Creates a Solid Particle object.\r\n * Don't create particles manually, use instead the Solid Particle System internal tools like _addParticle()\r\n * @param particleIndex (integer) is the particle index in the Solid Particle System pool.\r\n * @param particleId (integer) is the particle identifier. Unless some particles are removed from the SPS, it's the same value than the particle idx.\r\n * @param positionIndex (integer) is the starting index of the particle vertices in the SPS \"positions\" array.\r\n * @param indiceIndex (integer) is the starting index of the particle indices in the SPS \"indices\" array.\r\n * @param model (ModelShape) is a reference to the model shape on what the particle is designed.\r\n * @param shapeId (integer) is the model shape identifier in the SPS.\r\n * @param idxInShape (integer) is the index of the particle in the current model (ex: the 10th box of addShape(box, 30))\r\n * @param sps defines the sps it is associated to\r\n * @param modelBoundingInfo is the reference to the model BoundingInfo used for intersection computations.\r\n * @param materialIndex is the particle material identifier (integer) when the MultiMaterials are enabled in the SPS.\r\n */\r\n function SolidParticle(particleIndex, particleId, positionIndex, indiceIndex, model, shapeId, idxInShape, sps, modelBoundingInfo, materialIndex) {\r\n if (modelBoundingInfo === void 0) { modelBoundingInfo = null; }\r\n if (materialIndex === void 0) { materialIndex = null; }\r\n /**\r\n * particle global index\r\n */\r\n this.idx = 0;\r\n /**\r\n * particle identifier\r\n */\r\n this.id = 0;\r\n /**\r\n * The color of the particle\r\n */\r\n this.color = new Color4(1.0, 1.0, 1.0, 1.0);\r\n /**\r\n * The world space position of the particle.\r\n */\r\n this.position = Vector3.Zero();\r\n /**\r\n * The world space rotation of the particle. (Not use if rotationQuaternion is set)\r\n */\r\n this.rotation = Vector3.Zero();\r\n /**\r\n * The scaling of the particle.\r\n */\r\n this.scaling = Vector3.One();\r\n /**\r\n * The uvs of the particle.\r\n */\r\n this.uvs = new Vector4(0.0, 0.0, 1.0, 1.0);\r\n /**\r\n * The current speed of the particle.\r\n */\r\n this.velocity = Vector3.Zero();\r\n /**\r\n * The pivot point in the particle local space.\r\n */\r\n this.pivot = Vector3.Zero();\r\n /**\r\n * Must the particle be translated from its pivot point in its local space ?\r\n * In this case, the pivot point is set at the origin of the particle local space and the particle is translated.\r\n * Default : false\r\n */\r\n this.translateFromPivot = false;\r\n /**\r\n * Is the particle active or not ?\r\n */\r\n this.alive = true;\r\n /**\r\n * Is the particle visible or not ?\r\n */\r\n this.isVisible = true;\r\n /**\r\n * Index of this particle in the global \"positions\" array (Internal use)\r\n * @hidden\r\n */\r\n this._pos = 0;\r\n /**\r\n * @hidden Index of this particle in the global \"indices\" array (Internal use)\r\n */\r\n this._ind = 0;\r\n /**\r\n * ModelShape id of this particle\r\n */\r\n this.shapeId = 0;\r\n /**\r\n * Index of the particle in its shape id\r\n */\r\n this.idxInShape = 0;\r\n /**\r\n * @hidden Still set as invisible in order to skip useless computations (Internal use)\r\n */\r\n this._stillInvisible = false;\r\n /**\r\n * @hidden Last computed particle rotation matrix\r\n */\r\n this._rotationMatrix = [1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0];\r\n /**\r\n * Parent particle Id, if any.\r\n * Default null.\r\n */\r\n this.parentId = null;\r\n /**\r\n * The particle material identifier (integer) when MultiMaterials are enabled in the SPS.\r\n */\r\n this.materialIndex = null;\r\n /**\r\n * The culling strategy to use to check whether the solid particle must be culled or not when using isInFrustum().\r\n * The possible values are :\r\n * - AbstractMesh.CULLINGSTRATEGY_STANDARD\r\n * - AbstractMesh.CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY\r\n * - AbstractMesh.CULLINGSTRATEGY_OPTIMISTIC_INCLUSION\r\n * - AbstractMesh.CULLINGSTRATEGY_OPTIMISTIC_INCLUSION_THEN_BSPHERE_ONLY\r\n * The default value for solid particles is AbstractMesh.CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY\r\n * Please read each static variable documentation in the class AbstractMesh to get details about the culling process.\r\n * */\r\n this.cullingStrategy = AbstractMesh.CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY;\r\n /**\r\n * @hidden Internal global position in the SPS.\r\n */\r\n this._globalPosition = Vector3.Zero();\r\n this.idx = particleIndex;\r\n this.id = particleId;\r\n this._pos = positionIndex;\r\n this._ind = indiceIndex;\r\n this._model = model;\r\n this.shapeId = shapeId;\r\n this.idxInShape = idxInShape;\r\n this._sps = sps;\r\n if (modelBoundingInfo) {\r\n this._modelBoundingInfo = modelBoundingInfo;\r\n this._boundingInfo = new BoundingInfo(modelBoundingInfo.minimum, modelBoundingInfo.maximum);\r\n }\r\n if (materialIndex !== null) {\r\n this.materialIndex = materialIndex;\r\n }\r\n }\r\n /**\r\n * Copies the particle property values into the existing target : position, rotation, scaling, uvs, colors, pivot, parent, visibility, alive\r\n * @param target the particle target\r\n * @returns the current particle\r\n */\r\n SolidParticle.prototype.copyToRef = function (target) {\r\n target.position.copyFrom(this.position);\r\n target.rotation.copyFrom(this.rotation);\r\n if (this.rotationQuaternion) {\r\n if (target.rotationQuaternion) {\r\n target.rotationQuaternion.copyFrom(this.rotationQuaternion);\r\n }\r\n else {\r\n target.rotationQuaternion = this.rotationQuaternion.clone();\r\n }\r\n }\r\n target.scaling.copyFrom(this.scaling);\r\n if (this.color) {\r\n if (target.color) {\r\n target.color.copyFrom(this.color);\r\n }\r\n else {\r\n target.color = this.color.clone();\r\n }\r\n }\r\n target.uvs.copyFrom(this.uvs);\r\n target.velocity.copyFrom(this.velocity);\r\n target.pivot.copyFrom(this.pivot);\r\n target.translateFromPivot = this.translateFromPivot;\r\n target.alive = this.alive;\r\n target.isVisible = this.isVisible;\r\n target.parentId = this.parentId;\r\n target.cullingStrategy = this.cullingStrategy;\r\n if (this.materialIndex !== null) {\r\n target.materialIndex = this.materialIndex;\r\n }\r\n return this;\r\n };\r\n Object.defineProperty(SolidParticle.prototype, \"scale\", {\r\n /**\r\n * Legacy support, changed scale to scaling\r\n */\r\n get: function () {\r\n return this.scaling;\r\n },\r\n /**\r\n * Legacy support, changed scale to scaling\r\n */\r\n set: function (scale) {\r\n this.scaling = scale;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SolidParticle.prototype, \"quaternion\", {\r\n /**\r\n * Legacy support, changed quaternion to rotationQuaternion\r\n */\r\n get: function () {\r\n return this.rotationQuaternion;\r\n },\r\n /**\r\n * Legacy support, changed quaternion to rotationQuaternion\r\n */\r\n set: function (q) {\r\n this.rotationQuaternion = q;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Returns a boolean. True if the particle intersects another particle or another mesh, else false.\r\n * The intersection is computed on the particle bounding sphere and Axis Aligned Bounding Box (AABB)\r\n * @param target is the object (solid particle or mesh) what the intersection is computed against.\r\n * @returns true if it intersects\r\n */\r\n SolidParticle.prototype.intersectsMesh = function (target) {\r\n if (!this._boundingInfo || !target._boundingInfo) {\r\n return false;\r\n }\r\n if (this._sps._bSphereOnly) {\r\n return BoundingSphere.Intersects(this._boundingInfo.boundingSphere, target._boundingInfo.boundingSphere);\r\n }\r\n return this._boundingInfo.intersects(target._boundingInfo, false);\r\n };\r\n /**\r\n * Returns `true` if the solid particle is within the frustum defined by the passed array of planes.\r\n * A particle is in the frustum if its bounding box intersects the frustum\r\n * @param frustumPlanes defines the frustum to test\r\n * @returns true if the particle is in the frustum planes\r\n */\r\n SolidParticle.prototype.isInFrustum = function (frustumPlanes) {\r\n return this._boundingInfo !== null && this._boundingInfo.isInFrustum(frustumPlanes, this.cullingStrategy);\r\n };\r\n /**\r\n * get the rotation matrix of the particle\r\n * @hidden\r\n */\r\n SolidParticle.prototype.getRotationMatrix = function (m) {\r\n var quaternion;\r\n if (this.rotationQuaternion) {\r\n quaternion = this.rotationQuaternion;\r\n }\r\n else {\r\n quaternion = TmpVectors.Quaternion[0];\r\n var rotation = this.rotation;\r\n Quaternion.RotationYawPitchRollToRef(rotation.y, rotation.x, rotation.z, quaternion);\r\n }\r\n quaternion.toRotationMatrix(m);\r\n };\r\n return SolidParticle;\r\n}());\r\nexport { SolidParticle };\r\n/**\r\n * Represents the shape of the model used by one particle of a solid particle system.\r\n * SPS internal tool, don't use it manually.\r\n */\r\nvar ModelShape = /** @class */ (function () {\r\n /**\r\n * Creates a ModelShape object. This is an internal simplified reference to a mesh used as for a model to replicate particles from by the SPS.\r\n * SPS internal tool, don't use it manually.\r\n * @hidden\r\n */\r\n function ModelShape(id, shape, indices, normals, colors, shapeUV, posFunction, vtxFunction, material) {\r\n /**\r\n * length of the shape in the model indices array (internal use)\r\n * @hidden\r\n */\r\n this._indicesLength = 0;\r\n this.shapeID = id;\r\n this._shape = shape;\r\n this._indices = indices;\r\n this._indicesLength = indices.length;\r\n this._shapeUV = shapeUV;\r\n this._shapeColors = colors;\r\n this._normals = normals;\r\n this._positionFunction = posFunction;\r\n this._vertexFunction = vtxFunction;\r\n this._material = material;\r\n }\r\n return ModelShape;\r\n}());\r\nexport { ModelShape };\r\n/**\r\n * Represents a Depth Sorted Particle in the solid particle system.\r\n * @hidden\r\n */\r\nvar DepthSortedParticle = /** @class */ (function () {\r\n /**\r\n * Creates a new sorted particle\r\n * @param materialIndex\r\n */\r\n function DepthSortedParticle(ind, indLength, materialIndex) {\r\n /**\r\n * Index of the particle in the \"indices\" array\r\n */\r\n this.ind = 0;\r\n /**\r\n * Length of the particle shape in the \"indices\" array\r\n */\r\n this.indicesLength = 0;\r\n /**\r\n * Squared distance from the particle to the camera\r\n */\r\n this.sqDistance = 0.0;\r\n /**\r\n * Material index when used with MultiMaterials\r\n */\r\n this.materialIndex = 0;\r\n this.ind = ind;\r\n this.indicesLength = indLength;\r\n this.materialIndex = materialIndex;\r\n }\r\n return DepthSortedParticle;\r\n}());\r\nexport { DepthSortedParticle };\r\n//# sourceMappingURL=solidParticle.js.map","import { Vector3, Matrix, TmpVectors, Quaternion } from \"../Maths/math.vector\";\r\nimport { Color4 } from '../Maths/math.color';\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { VertexData } from \"../Meshes/mesh.vertexData\";\r\nimport { Mesh } from \"../Meshes/mesh\";\r\nimport { DiscBuilder } from \"../Meshes/Builders/discBuilder\";\r\nimport { EngineStore } from \"../Engines/engineStore\";\r\nimport { DepthSortedParticle, SolidParticle, ModelShape } from \"./solidParticle\";\r\nimport { BoundingInfo } from \"../Culling/boundingInfo\";\r\nimport { Axis } from '../Maths/math.axis';\r\nimport { SubMesh } from '../Meshes/subMesh';\r\nimport { StandardMaterial } from '../Materials/standardMaterial';\r\nimport { MultiMaterial } from '../Materials/multiMaterial';\r\n/**\r\n * The SPS is a single updatable mesh. The solid particles are simply separate parts or faces fo this big mesh.\r\n *As it is just a mesh, the SPS has all the same properties than any other BJS mesh : not more, not less. It can be scaled, rotated, translated, enlighted, textured, moved, etc.\r\n\r\n * The SPS is also a particle system. It provides some methods to manage the particles.\r\n * However it is behavior agnostic. This means it has no emitter, no particle physics, no particle recycler. You have to implement your own behavior.\r\n *\r\n * Full documentation here : http://doc.babylonjs.com/how_to/Solid_Particle_System\r\n */\r\nvar SolidParticleSystem = /** @class */ (function () {\r\n /**\r\n * Creates a SPS (Solid Particle System) object.\r\n * @param name (String) is the SPS name, this will be the underlying mesh name.\r\n * @param scene (Scene) is the scene in which the SPS is added.\r\n * @param options defines the options of the sps e.g.\r\n * * updatable (optional boolean, default true) : if the SPS must be updatable or immutable.\r\n * * isPickable (optional boolean, default false) : if the solid particles must be pickable.\r\n * * enableDepthSort (optional boolean, default false) : if the solid particles must be sorted in the geometry according to their distance to the camera.\r\n * * useModelMaterial (optional boolean, defaut false) : if the model materials must be used to create the SPS multimaterial. This enables the multimaterial supports of the SPS.\r\n * * enableMultiMaterial (optional boolean, default false) : if the solid particles can be given different materials.\r\n * * expandable (optional boolean, default false) : if particles can still be added after the initial SPS mesh creation.\r\n * * particleIntersection (optional boolean, default false) : if the solid particle intersections must be computed.\r\n * * boundingSphereOnly (optional boolean, default false) : if the particle intersection must be computed only with the bounding sphere (no bounding box computation, so faster).\r\n * * bSphereRadiusFactor (optional float, default 1.0) : a number to multiply the boundind sphere radius by in order to reduce it for instance.\r\n * @example bSphereRadiusFactor = 1.0 / Math.sqrt(3.0) => the bounding sphere exactly matches a spherical mesh.\r\n */\r\n function SolidParticleSystem(name, scene, options) {\r\n /**\r\n * The SPS array of Solid Particle objects. Just access each particle as with any classic array.\r\n * Example : var p = SPS.particles[i];\r\n */\r\n this.particles = new Array();\r\n /**\r\n * The SPS total number of particles. Read only. Use SPS.counter instead if you need to set your own value.\r\n */\r\n this.nbParticles = 0;\r\n /**\r\n * If the particles must ever face the camera (default false). Useful for planar particles.\r\n */\r\n this.billboard = false;\r\n /**\r\n * Recompute normals when adding a shape\r\n */\r\n this.recomputeNormals = false;\r\n /**\r\n * This a counter ofr your own usage. It's not set by any SPS functions.\r\n */\r\n this.counter = 0;\r\n /**\r\n * This empty object is intended to store some SPS specific or temporary values in order to lower the Garbage Collector activity.\r\n * Please read : http://doc.babylonjs.com/how_to/Solid_Particle_System#garbage-collector-concerns\r\n */\r\n this.vars = {};\r\n /**\r\n * If the particle intersection must be computed only with the bounding sphere (no bounding box computation, so faster). (Internal use only)\r\n * @hidden\r\n */\r\n this._bSphereOnly = false;\r\n /**\r\n * A number to multiply the boundind sphere radius by in order to reduce it for instance. (Internal use only)\r\n * @hidden\r\n */\r\n this._bSphereRadiusFactor = 1.0;\r\n this._positions = new Array();\r\n this._indices = new Array();\r\n this._normals = new Array();\r\n this._colors = new Array();\r\n this._uvs = new Array();\r\n this._index = 0; // indices index\r\n this._updatable = true;\r\n this._pickable = false;\r\n this._isVisibilityBoxLocked = false;\r\n this._alwaysVisible = false;\r\n this._depthSort = false;\r\n this._expandable = false;\r\n this._shapeCounter = 0;\r\n this._copy = new SolidParticle(0, 0, 0, 0, null, 0, 0, this);\r\n this._color = new Color4(0, 0, 0, 0);\r\n this._computeParticleColor = true;\r\n this._computeParticleTexture = true;\r\n this._computeParticleRotation = true;\r\n this._computeParticleVertex = false;\r\n this._computeBoundingBox = false;\r\n this._depthSortParticles = true;\r\n this._mustUnrotateFixedNormals = false;\r\n this._particlesIntersect = false;\r\n this._needs32Bits = false;\r\n this._isNotBuilt = true;\r\n this._lastParticleId = 0;\r\n this._idxOfId = []; // array : key = particle.id / value = particle.idx\r\n this._multimaterialEnabled = false;\r\n this._useModelMaterial = false;\r\n this._depthSortFunction = function (p1, p2) { return p2.sqDistance - p1.sqDistance; };\r\n this._materialSortFunction = function (p1, p2) { return p1.materialIndex - p2.materialIndex; };\r\n this._autoUpdateSubMeshes = false;\r\n this.name = name;\r\n this._scene = scene || EngineStore.LastCreatedScene;\r\n this._camera = scene.activeCamera;\r\n this._pickable = options ? options.isPickable : false;\r\n this._depthSort = options ? options.enableDepthSort : false;\r\n this._multimaterialEnabled = options ? options.enableMultiMaterial : false;\r\n this._useModelMaterial = options ? options.useModelMaterial : false;\r\n this._multimaterialEnabled = (this._useModelMaterial) ? true : this._multimaterialEnabled;\r\n this._expandable = options ? options.expandable : false;\r\n this._particlesIntersect = options ? options.particleIntersection : false;\r\n this._bSphereOnly = options ? options.boundingSphereOnly : false;\r\n this._bSphereRadiusFactor = (options && options.bSphereRadiusFactor) ? options.bSphereRadiusFactor : 1.0;\r\n if (options && options.updatable !== undefined) {\r\n this._updatable = options.updatable;\r\n }\r\n else {\r\n this._updatable = true;\r\n }\r\n if (this._pickable) {\r\n this.pickedParticles = [];\r\n }\r\n if (this._depthSort || this._multimaterialEnabled) {\r\n this.depthSortedParticles = [];\r\n }\r\n if (this._multimaterialEnabled) {\r\n this._multimaterial = new MultiMaterial(this.name + \"MultiMaterial\", this._scene);\r\n this._materials = [];\r\n this._materialIndexesById = {};\r\n }\r\n }\r\n /**\r\n * Builds the SPS underlying mesh. Returns a standard Mesh.\r\n * If no model shape was added to the SPS, the returned mesh is just a single triangular plane.\r\n * @returns the created mesh\r\n */\r\n SolidParticleSystem.prototype.buildMesh = function () {\r\n if (!this._isNotBuilt && this.mesh) {\r\n return this.mesh;\r\n }\r\n if (this.nbParticles === 0 && !this.mesh) {\r\n var triangle = DiscBuilder.CreateDisc(\"\", { radius: 1, tessellation: 3 }, this._scene);\r\n this.addShape(triangle, 1);\r\n triangle.dispose();\r\n }\r\n this._indices32 = (this._needs32Bits) ? new Uint32Array(this._indices) : new Uint16Array(this._indices);\r\n this._positions32 = new Float32Array(this._positions);\r\n this._uvs32 = new Float32Array(this._uvs);\r\n this._colors32 = new Float32Array(this._colors);\r\n if (!this.mesh) { // in case it's already expanded\r\n var mesh = new Mesh(this.name, this._scene);\r\n this.mesh = mesh;\r\n }\r\n if (!this._updatable && this._multimaterialEnabled) {\r\n this._sortParticlesByMaterial(); // this may reorder the indices32\r\n }\r\n if (this.recomputeNormals) {\r\n VertexData.ComputeNormals(this._positions32, this._indices32, this._normals);\r\n }\r\n this._normals32 = new Float32Array(this._normals);\r\n this._fixedNormal32 = new Float32Array(this._normals);\r\n if (this._mustUnrotateFixedNormals) { // the particles could be created already rotated in the mesh with a positionFunction\r\n this._unrotateFixedNormals();\r\n }\r\n var vertexData = new VertexData();\r\n vertexData.indices = (this._depthSort) ? this._indices : this._indices32;\r\n vertexData.set(this._positions32, VertexBuffer.PositionKind);\r\n vertexData.set(this._normals32, VertexBuffer.NormalKind);\r\n if (this._uvs32.length > 0) {\r\n vertexData.set(this._uvs32, VertexBuffer.UVKind);\r\n }\r\n if (this._colors32.length > 0) {\r\n vertexData.set(this._colors32, VertexBuffer.ColorKind);\r\n }\r\n vertexData.applyToMesh(this.mesh, this._updatable);\r\n this.mesh.isPickable = this._pickable;\r\n if (this._multimaterialEnabled) {\r\n this.setMultiMaterial(this._materials);\r\n }\r\n if (!this._expandable) {\r\n // free memory\r\n if (!this._depthSort && !this._multimaterialEnabled) {\r\n this._indices = null;\r\n }\r\n this._positions = null;\r\n this._normals = null;\r\n this._uvs = null;\r\n this._colors = null;\r\n if (!this._updatable) {\r\n this.particles.length = 0;\r\n }\r\n }\r\n this._isNotBuilt = false;\r\n this.recomputeNormals = false;\r\n return this.mesh;\r\n };\r\n /**\r\n * Digests the mesh and generates as many solid particles in the system as wanted. Returns the SPS.\r\n * These particles will have the same geometry than the mesh parts and will be positioned at the same localisation than the mesh original places.\r\n * Thus the particles generated from `digest()` have their property `position` set yet.\r\n * @param mesh ( Mesh ) is the mesh to be digested\r\n * @param options {facetNb} (optional integer, default 1) is the number of mesh facets per particle, this parameter is overriden by the parameter `number` if any\r\n * {delta} (optional integer, default 0) is the random extra number of facets per particle , each particle will have between `facetNb` and `facetNb + delta` facets\r\n * {number} (optional positive integer) is the wanted number of particles : each particle is built with `mesh_total_facets / number` facets\r\n * {storage} (optional existing array) is an array where the particles will be stored for a further use instead of being inserted in the SPS.\r\n * @returns the current SPS\r\n */\r\n SolidParticleSystem.prototype.digest = function (mesh, options) {\r\n var size = (options && options.facetNb) || 1;\r\n var number = (options && options.number) || 0;\r\n var delta = (options && options.delta) || 0;\r\n var meshPos = mesh.getVerticesData(VertexBuffer.PositionKind);\r\n var meshInd = mesh.getIndices();\r\n var meshUV = mesh.getVerticesData(VertexBuffer.UVKind);\r\n var meshCol = mesh.getVerticesData(VertexBuffer.ColorKind);\r\n var meshNor = mesh.getVerticesData(VertexBuffer.NormalKind);\r\n var storage = (options && options.storage) ? options.storage : null;\r\n var f = 0; // facet counter\r\n var totalFacets = meshInd.length / 3; // a facet is a triangle, so 3 indices\r\n // compute size from number\r\n if (number) {\r\n number = (number > totalFacets) ? totalFacets : number;\r\n size = Math.round(totalFacets / number);\r\n delta = 0;\r\n }\r\n else {\r\n size = (size > totalFacets) ? totalFacets : size;\r\n }\r\n var facetPos = []; // submesh positions\r\n var facetNor = [];\r\n var facetInd = []; // submesh indices\r\n var facetUV = []; // submesh UV\r\n var facetCol = []; // submesh colors\r\n var barycenter = Vector3.Zero();\r\n var sizeO = size;\r\n while (f < totalFacets) {\r\n size = sizeO + Math.floor((1 + delta) * Math.random());\r\n if (f > totalFacets - size) {\r\n size = totalFacets - f;\r\n }\r\n // reset temp arrays\r\n facetPos.length = 0;\r\n facetNor.length = 0;\r\n facetInd.length = 0;\r\n facetUV.length = 0;\r\n facetCol.length = 0;\r\n // iterate over \"size\" facets\r\n var fi = 0;\r\n for (var j = f * 3; j < (f + size) * 3; j++) {\r\n facetInd.push(fi);\r\n var i = meshInd[j];\r\n var i3 = i * 3;\r\n facetPos.push(meshPos[i3], meshPos[i3 + 1], meshPos[i3 + 2]);\r\n facetNor.push(meshNor[i3], meshNor[i3 + 1], meshNor[i3 + 2]);\r\n if (meshUV) {\r\n var i2 = i * 2;\r\n facetUV.push(meshUV[i2], meshUV[i2 + 1]);\r\n }\r\n if (meshCol) {\r\n var i4 = i * 4;\r\n facetCol.push(meshCol[i4], meshCol[i4 + 1], meshCol[i4 + 2], meshCol[i4 + 3]);\r\n }\r\n fi++;\r\n }\r\n // create a model shape for each single particle\r\n var idx = this.nbParticles;\r\n var shape = this._posToShape(facetPos);\r\n var shapeUV = this._uvsToShapeUV(facetUV);\r\n var shapeInd = Array.from(facetInd);\r\n var shapeCol = Array.from(facetCol);\r\n var shapeNor = Array.from(facetNor);\r\n // compute the barycenter of the shape\r\n barycenter.copyFromFloats(0, 0, 0);\r\n var v;\r\n for (v = 0; v < shape.length; v++) {\r\n barycenter.addInPlace(shape[v]);\r\n }\r\n barycenter.scaleInPlace(1 / shape.length);\r\n // shift the shape from its barycenter to the origin\r\n // and compute the BBox required for intersection.\r\n var minimum = new Vector3(Infinity, Infinity, Infinity);\r\n var maximum = new Vector3(-Infinity, -Infinity, -Infinity);\r\n for (v = 0; v < shape.length; v++) {\r\n shape[v].subtractInPlace(barycenter);\r\n minimum.minimizeInPlaceFromFloats(shape[v].x, shape[v].y, shape[v].z);\r\n maximum.maximizeInPlaceFromFloats(shape[v].x, shape[v].y, shape[v].z);\r\n }\r\n var bInfo;\r\n if (this._particlesIntersect) {\r\n bInfo = new BoundingInfo(minimum, maximum);\r\n }\r\n var material = null;\r\n if (this._useModelMaterial) {\r\n material = (mesh.material) ? mesh.material : this._setDefaultMaterial();\r\n }\r\n var modelShape = new ModelShape(this._shapeCounter, shape, shapeInd, shapeNor, shapeCol, shapeUV, null, null, material);\r\n // add the particle in the SPS\r\n var currentPos = this._positions.length;\r\n var currentInd = this._indices.length;\r\n this._meshBuilder(this._index, currentInd, shape, this._positions, shapeInd, this._indices, facetUV, this._uvs, shapeCol, this._colors, shapeNor, this._normals, idx, 0, null, modelShape);\r\n this._addParticle(idx, this._lastParticleId, currentPos, currentInd, modelShape, this._shapeCounter, 0, bInfo, storage);\r\n // initialize the particle position\r\n this.particles[this.nbParticles].position.addInPlace(barycenter);\r\n if (!storage) {\r\n this._index += shape.length;\r\n idx++;\r\n this.nbParticles++;\r\n this._lastParticleId++;\r\n }\r\n this._shapeCounter++;\r\n f += size;\r\n }\r\n this._isNotBuilt = true; // buildMesh() is now expected for setParticles() to work\r\n return this;\r\n };\r\n /**\r\n * Unrotate the fixed normals in case the mesh was built with pre-rotated particles, ex : use of positionFunction in addShape()\r\n * @hidden\r\n */\r\n SolidParticleSystem.prototype._unrotateFixedNormals = function () {\r\n var index = 0;\r\n var idx = 0;\r\n var tmpNormal = TmpVectors.Vector3[0];\r\n var quaternion = TmpVectors.Quaternion[0];\r\n var invertedRotMatrix = TmpVectors.Matrix[0];\r\n for (var p = 0; p < this.particles.length; p++) {\r\n var particle = this.particles[p];\r\n var shape = particle._model._shape;\r\n // computing the inverse of the rotation matrix from the quaternion\r\n // is equivalent to computing the matrix of the inverse quaternion, i.e of the conjugate quaternion\r\n if (particle.rotationQuaternion) {\r\n particle.rotationQuaternion.conjugateToRef(quaternion);\r\n }\r\n else {\r\n var rotation = particle.rotation;\r\n Quaternion.RotationYawPitchRollToRef(rotation.y, rotation.x, rotation.z, quaternion);\r\n quaternion.conjugateInPlace();\r\n }\r\n quaternion.toRotationMatrix(invertedRotMatrix);\r\n for (var pt = 0; pt < shape.length; pt++) {\r\n idx = index + pt * 3;\r\n Vector3.TransformNormalFromFloatsToRef(this._normals32[idx], this._normals32[idx + 1], this._normals32[idx + 2], invertedRotMatrix, tmpNormal);\r\n tmpNormal.toArray(this._fixedNormal32, idx);\r\n }\r\n index = idx + 3;\r\n }\r\n };\r\n /**\r\n * Resets the temporary working copy particle\r\n * @hidden\r\n */\r\n SolidParticleSystem.prototype._resetCopy = function () {\r\n var copy = this._copy;\r\n copy.position.setAll(0);\r\n copy.rotation.setAll(0);\r\n copy.rotationQuaternion = null;\r\n copy.scaling.setAll(1);\r\n copy.uvs.copyFromFloats(0.0, 0.0, 1.0, 1.0);\r\n copy.color = null;\r\n copy.translateFromPivot = false;\r\n copy.materialIndex = null;\r\n };\r\n /**\r\n * Inserts the shape model geometry in the global SPS mesh by updating the positions, indices, normals, colors, uvs arrays\r\n * @param p the current index in the positions array to be updated\r\n * @param ind the current index in the indices array\r\n * @param shape a Vector3 array, the shape geometry\r\n * @param positions the positions array to be updated\r\n * @param meshInd the shape indices array\r\n * @param indices the indices array to be updated\r\n * @param meshUV the shape uv array\r\n * @param uvs the uv array to be updated\r\n * @param meshCol the shape color array\r\n * @param colors the color array to be updated\r\n * @param meshNor the shape normals array\r\n * @param normals the normals array to be updated\r\n * @param idx the particle index\r\n * @param idxInShape the particle index in its shape\r\n * @param options the addShape() method passed options\r\n * @model the particle model\r\n * @hidden\r\n */\r\n SolidParticleSystem.prototype._meshBuilder = function (p, ind, shape, positions, meshInd, indices, meshUV, uvs, meshCol, colors, meshNor, normals, idx, idxInShape, options, model) {\r\n var i;\r\n var u = 0;\r\n var c = 0;\r\n var n = 0;\r\n this._resetCopy();\r\n var copy = this._copy;\r\n var storeApart = (options && options.storage) ? true : false;\r\n copy.idx = idx;\r\n copy.idxInShape = idxInShape;\r\n if (this._useModelMaterial) {\r\n var materialId = model._material.uniqueId;\r\n var materialIndexesById = this._materialIndexesById;\r\n if (!materialIndexesById.hasOwnProperty(materialId)) {\r\n materialIndexesById[materialId] = this._materials.length;\r\n this._materials.push(model._material);\r\n }\r\n var matIdx = materialIndexesById[materialId];\r\n copy.materialIndex = matIdx;\r\n }\r\n if (options && options.positionFunction) { // call to custom positionFunction\r\n options.positionFunction(copy, idx, idxInShape);\r\n this._mustUnrotateFixedNormals = true;\r\n }\r\n // in case the particle geometry must NOT be inserted in the SPS mesh geometry\r\n if (storeApart) {\r\n return copy;\r\n }\r\n var rotMatrix = TmpVectors.Matrix[0];\r\n var tmpVertex = TmpVectors.Vector3[0];\r\n var tmpRotated = TmpVectors.Vector3[1];\r\n var pivotBackTranslation = TmpVectors.Vector3[2];\r\n var scaledPivot = TmpVectors.Vector3[3];\r\n Matrix.IdentityToRef(rotMatrix);\r\n copy.getRotationMatrix(rotMatrix);\r\n copy.pivot.multiplyToRef(copy.scaling, scaledPivot);\r\n if (copy.translateFromPivot) {\r\n pivotBackTranslation.setAll(0.0);\r\n }\r\n else {\r\n pivotBackTranslation.copyFrom(scaledPivot);\r\n }\r\n var someVertexFunction = (options && options.vertexFunction);\r\n for (i = 0; i < shape.length; i++) {\r\n tmpVertex.copyFrom(shape[i]);\r\n if (someVertexFunction) {\r\n options.vertexFunction(copy, tmpVertex, i);\r\n }\r\n tmpVertex.multiplyInPlace(copy.scaling).subtractInPlace(scaledPivot);\r\n Vector3.TransformCoordinatesToRef(tmpVertex, rotMatrix, tmpRotated);\r\n tmpRotated.addInPlace(pivotBackTranslation).addInPlace(copy.position);\r\n positions.push(tmpRotated.x, tmpRotated.y, tmpRotated.z);\r\n if (meshUV) {\r\n var copyUvs = copy.uvs;\r\n uvs.push((copyUvs.z - copyUvs.x) * meshUV[u] + copyUvs.x, (copyUvs.w - copyUvs.y) * meshUV[u + 1] + copyUvs.y);\r\n u += 2;\r\n }\r\n if (copy.color) {\r\n this._color = copy.color;\r\n }\r\n else {\r\n var color = this._color;\r\n if (meshCol && meshCol[c] !== undefined) {\r\n color.r = meshCol[c];\r\n color.g = meshCol[c + 1];\r\n color.b = meshCol[c + 2];\r\n color.a = meshCol[c + 3];\r\n }\r\n else {\r\n color.r = 1.0;\r\n color.g = 1.0;\r\n color.b = 1.0;\r\n color.a = 1.0;\r\n }\r\n }\r\n colors.push(this._color.r, this._color.g, this._color.b, this._color.a);\r\n c += 4;\r\n if (!this.recomputeNormals && meshNor) {\r\n Vector3.TransformNormalFromFloatsToRef(meshNor[n], meshNor[n + 1], meshNor[n + 2], rotMatrix, tmpVertex);\r\n normals.push(tmpVertex.x, tmpVertex.y, tmpVertex.z);\r\n n += 3;\r\n }\r\n }\r\n for (i = 0; i < meshInd.length; i++) {\r\n var current_ind = p + meshInd[i];\r\n indices.push(current_ind);\r\n if (current_ind > 65535) {\r\n this._needs32Bits = true;\r\n }\r\n }\r\n if (this._pickable) {\r\n var nbfaces = meshInd.length / 3;\r\n for (i = 0; i < nbfaces; i++) {\r\n this.pickedParticles.push({ idx: idx, faceId: i });\r\n }\r\n }\r\n if (this._depthSort || this._multimaterialEnabled) {\r\n var matIndex = (copy.materialIndex !== null) ? copy.materialIndex : 0;\r\n this.depthSortedParticles.push(new DepthSortedParticle(ind, meshInd.length, matIndex));\r\n }\r\n return copy;\r\n };\r\n /**\r\n * Returns a shape Vector3 array from positions float array\r\n * @param positions float array\r\n * @returns a vector3 array\r\n * @hidden\r\n */\r\n SolidParticleSystem.prototype._posToShape = function (positions) {\r\n var shape = [];\r\n for (var i = 0; i < positions.length; i += 3) {\r\n shape.push(Vector3.FromArray(positions, i));\r\n }\r\n return shape;\r\n };\r\n /**\r\n * Returns a shapeUV array from a float uvs (array deep copy)\r\n * @param uvs as a float array\r\n * @returns a shapeUV array\r\n * @hidden\r\n */\r\n SolidParticleSystem.prototype._uvsToShapeUV = function (uvs) {\r\n var shapeUV = [];\r\n if (uvs) {\r\n for (var i = 0; i < uvs.length; i++) {\r\n shapeUV.push(uvs[i]);\r\n }\r\n }\r\n return shapeUV;\r\n };\r\n /**\r\n * Adds a new particle object in the particles array\r\n * @param idx particle index in particles array\r\n * @param id particle id\r\n * @param idxpos positionIndex : the starting index of the particle vertices in the SPS \"positions\" array\r\n * @param idxind indiceIndex : he starting index of the particle indices in the SPS \"indices\" array\r\n * @param model particle ModelShape object\r\n * @param shapeId model shape identifier\r\n * @param idxInShape index of the particle in the current model\r\n * @param bInfo model bounding info object\r\n * @param storage target storage array, if any\r\n * @hidden\r\n */\r\n SolidParticleSystem.prototype._addParticle = function (idx, id, idxpos, idxind, model, shapeId, idxInShape, bInfo, storage) {\r\n if (bInfo === void 0) { bInfo = null; }\r\n if (storage === void 0) { storage = null; }\r\n var sp = new SolidParticle(idx, id, idxpos, idxind, model, shapeId, idxInShape, this, bInfo);\r\n var target = (storage) ? storage : this.particles;\r\n target.push(sp);\r\n return sp;\r\n };\r\n /**\r\n * Adds some particles to the SPS from the model shape. Returns the shape id.\r\n * Please read the doc : http://doc.babylonjs.com/how_to/Solid_Particle_System#create-an-immutable-sps\r\n * @param mesh is any Mesh object that will be used as a model for the solid particles.\r\n * @param nb (positive integer) the number of particles to be created from this model\r\n * @param options {positionFunction} is an optional javascript function to called for each particle on SPS creation.\r\n * {vertexFunction} is an optional javascript function to called for each vertex of each particle on SPS creation\r\n * {storage} (optional existing array) is an array where the particles will be stored for a further use instead of being inserted in the SPS.\r\n * @returns the number of shapes in the system\r\n */\r\n SolidParticleSystem.prototype.addShape = function (mesh, nb, options) {\r\n var meshPos = mesh.getVerticesData(VertexBuffer.PositionKind);\r\n var meshInd = mesh.getIndices();\r\n var meshUV = mesh.getVerticesData(VertexBuffer.UVKind);\r\n var meshCol = mesh.getVerticesData(VertexBuffer.ColorKind);\r\n var meshNor = mesh.getVerticesData(VertexBuffer.NormalKind);\r\n this.recomputeNormals = (meshNor) ? false : true;\r\n var indices = Array.from(meshInd);\r\n var shapeNormals = Array.from(meshNor);\r\n var shapeColors = (meshCol) ? Array.from(meshCol) : [];\r\n var storage = (options && options.storage) ? options.storage : null;\r\n var bbInfo = null;\r\n if (this._particlesIntersect) {\r\n bbInfo = mesh.getBoundingInfo();\r\n }\r\n var shape = this._posToShape(meshPos);\r\n var shapeUV = this._uvsToShapeUV(meshUV);\r\n var posfunc = options ? options.positionFunction : null;\r\n var vtxfunc = options ? options.vertexFunction : null;\r\n var material = null;\r\n if (this._useModelMaterial) {\r\n material = (mesh.material) ? mesh.material : this._setDefaultMaterial();\r\n }\r\n var modelShape = new ModelShape(this._shapeCounter, shape, indices, shapeNormals, shapeColors, shapeUV, posfunc, vtxfunc, material);\r\n // particles\r\n for (var i = 0; i < nb; i++) {\r\n this._insertNewParticle(this.nbParticles, i, modelShape, shape, meshInd, meshUV, meshCol, meshNor, bbInfo, storage, options);\r\n }\r\n this._shapeCounter++;\r\n this._isNotBuilt = true; // buildMesh() call is now expected for setParticles() to work\r\n return this._shapeCounter - 1;\r\n };\r\n /**\r\n * Rebuilds a particle back to its just built status : if needed, recomputes the custom positions and vertices\r\n * @hidden\r\n */\r\n SolidParticleSystem.prototype._rebuildParticle = function (particle, reset) {\r\n if (reset === void 0) { reset = false; }\r\n this._resetCopy();\r\n var copy = this._copy;\r\n if (particle._model._positionFunction) { // recall to stored custom positionFunction\r\n particle._model._positionFunction(copy, particle.idx, particle.idxInShape);\r\n }\r\n var rotMatrix = TmpVectors.Matrix[0];\r\n var tmpVertex = TmpVectors.Vector3[0];\r\n var tmpRotated = TmpVectors.Vector3[1];\r\n var pivotBackTranslation = TmpVectors.Vector3[2];\r\n var scaledPivot = TmpVectors.Vector3[3];\r\n copy.getRotationMatrix(rotMatrix);\r\n particle.pivot.multiplyToRef(particle.scaling, scaledPivot);\r\n if (copy.translateFromPivot) {\r\n pivotBackTranslation.copyFromFloats(0.0, 0.0, 0.0);\r\n }\r\n else {\r\n pivotBackTranslation.copyFrom(scaledPivot);\r\n }\r\n var shape = particle._model._shape;\r\n for (var pt = 0; pt < shape.length; pt++) {\r\n tmpVertex.copyFrom(shape[pt]);\r\n if (particle._model._vertexFunction) {\r\n particle._model._vertexFunction(copy, tmpVertex, pt); // recall to stored vertexFunction\r\n }\r\n tmpVertex.multiplyInPlace(copy.scaling).subtractInPlace(scaledPivot);\r\n Vector3.TransformCoordinatesToRef(tmpVertex, rotMatrix, tmpRotated);\r\n tmpRotated.addInPlace(pivotBackTranslation).addInPlace(copy.position).toArray(this._positions32, particle._pos + pt * 3);\r\n }\r\n if (reset) {\r\n particle.position.setAll(0.0);\r\n particle.rotation.setAll(0.0);\r\n particle.rotationQuaternion = null;\r\n particle.scaling.setAll(1.0);\r\n particle.uvs.setAll(0.0);\r\n particle.pivot.setAll(0.0);\r\n particle.translateFromPivot = false;\r\n particle.parentId = null;\r\n }\r\n };\r\n /**\r\n * Rebuilds the whole mesh and updates the VBO : custom positions and vertices are recomputed if needed.\r\n * @param reset boolean, default false : if the particles must be reset at position and rotation zero, scaling 1, color white, initial UVs and not parented.\r\n * @returns the SPS.\r\n */\r\n SolidParticleSystem.prototype.rebuildMesh = function (reset) {\r\n if (reset === void 0) { reset = false; }\r\n for (var p = 0; p < this.particles.length; p++) {\r\n this._rebuildParticle(this.particles[p], reset);\r\n }\r\n this.mesh.updateVerticesData(VertexBuffer.PositionKind, this._positions32, false, false);\r\n return this;\r\n };\r\n /** Removes the particles from the start-th to the end-th included from an expandable SPS (required).\r\n * Returns an array with the removed particles.\r\n * If the number of particles to remove is lower than zero or greater than the global remaining particle number, then an empty array is returned.\r\n * The SPS can't be empty so at least one particle needs to remain in place.\r\n * Under the hood, the VertexData array, so the VBO buffer, is recreated each call.\r\n * @param start index of the first particle to remove\r\n * @param end index of the last particle to remove (included)\r\n * @returns an array populated with the removed particles\r\n */\r\n SolidParticleSystem.prototype.removeParticles = function (start, end) {\r\n var nb = end - start + 1;\r\n if (!this._expandable || nb <= 0 || nb >= this.nbParticles || !this._updatable) {\r\n return [];\r\n }\r\n var particles = this.particles;\r\n var currentNb = this.nbParticles;\r\n if (end < currentNb - 1) { // update the particle indexes in the positions array in case they're remaining particles after the last removed\r\n var firstRemaining = end + 1;\r\n var shiftPos = particles[firstRemaining]._pos - particles[start]._pos;\r\n var shifInd = particles[firstRemaining]._ind - particles[start]._ind;\r\n for (var i = firstRemaining; i < currentNb; i++) {\r\n var part = particles[i];\r\n part._pos -= shiftPos;\r\n part._ind -= shifInd;\r\n }\r\n }\r\n var removed = particles.splice(start, nb);\r\n this._positions.length = 0;\r\n this._indices.length = 0;\r\n this._colors.length = 0;\r\n this._uvs.length = 0;\r\n this._normals.length = 0;\r\n this._index = 0;\r\n this._idxOfId.length = 0;\r\n if (this._depthSort || this._multimaterialEnabled) {\r\n this.depthSortedParticles = [];\r\n }\r\n var ind = 0;\r\n var particlesLength = particles.length;\r\n for (var p = 0; p < particlesLength; p++) {\r\n var particle = particles[p];\r\n var model = particle._model;\r\n var shape = model._shape;\r\n var modelIndices = model._indices;\r\n var modelNormals = model._normals;\r\n var modelColors = model._shapeColors;\r\n var modelUVs = model._shapeUV;\r\n particle.idx = p;\r\n this._idxOfId[particle.id] = p;\r\n this._meshBuilder(this._index, ind, shape, this._positions, modelIndices, this._indices, modelUVs, this._uvs, modelColors, this._colors, modelNormals, this._normals, particle.idx, particle.idxInShape, null, model);\r\n this._index += shape.length;\r\n ind += modelIndices.length;\r\n }\r\n this.nbParticles -= nb;\r\n this._isNotBuilt = true; // buildMesh() call is now expected for setParticles() to work\r\n return removed;\r\n };\r\n /**\r\n * Inserts some pre-created particles in the solid particle system so that they can be managed by setParticles().\r\n * @param solidParticleArray an array populated with Solid Particles objects\r\n * @returns the SPS\r\n */\r\n SolidParticleSystem.prototype.insertParticlesFromArray = function (solidParticleArray) {\r\n if (!this._expandable) {\r\n return this;\r\n }\r\n var idxInShape = 0;\r\n var currentShapeId = solidParticleArray[0].shapeId;\r\n var nb = solidParticleArray.length;\r\n for (var i = 0; i < nb; i++) {\r\n var sp = solidParticleArray[i];\r\n var model = sp._model;\r\n var shape = model._shape;\r\n var meshInd = model._indices;\r\n var meshUV = model._shapeUV;\r\n var meshCol = model._shapeColors;\r\n var meshNor = model._normals;\r\n var noNor = (meshNor) ? false : true;\r\n this.recomputeNormals = (noNor || this.recomputeNormals);\r\n var bbInfo = sp._boundingInfo;\r\n var newPart = this._insertNewParticle(this.nbParticles, idxInShape, model, shape, meshInd, meshUV, meshCol, meshNor, bbInfo, null, null);\r\n sp.copyToRef(newPart);\r\n idxInShape++;\r\n if (currentShapeId != sp.shapeId) {\r\n currentShapeId = sp.shapeId;\r\n idxInShape = 0;\r\n }\r\n }\r\n this._isNotBuilt = true; // buildMesh() call is now expected for setParticles() to work\r\n return this;\r\n };\r\n /**\r\n * Creates a new particle and modifies the SPS mesh geometry :\r\n * - calls _meshBuilder() to increase the SPS mesh geometry step by step\r\n * - calls _addParticle() to populate the particle array\r\n * factorized code from addShape() and insertParticlesFromArray()\r\n * @param idx particle index in the particles array\r\n * @param i particle index in its shape\r\n * @param modelShape particle ModelShape object\r\n * @param shape shape vertex array\r\n * @param meshInd shape indices array\r\n * @param meshUV shape uv array\r\n * @param meshCol shape color array\r\n * @param meshNor shape normals array\r\n * @param bbInfo shape bounding info\r\n * @param storage target particle storage\r\n * @options addShape() passed options\r\n * @hidden\r\n */\r\n SolidParticleSystem.prototype._insertNewParticle = function (idx, i, modelShape, shape, meshInd, meshUV, meshCol, meshNor, bbInfo, storage, options) {\r\n var currentPos = this._positions.length;\r\n var currentInd = this._indices.length;\r\n var currentCopy = this._meshBuilder(this._index, currentInd, shape, this._positions, meshInd, this._indices, meshUV, this._uvs, meshCol, this._colors, meshNor, this._normals, idx, i, options, modelShape);\r\n var sp = null;\r\n if (this._updatable) {\r\n sp = this._addParticle(this.nbParticles, this._lastParticleId, currentPos, currentInd, modelShape, this._shapeCounter, i, bbInfo, storage);\r\n sp.position.copyFrom(currentCopy.position);\r\n sp.rotation.copyFrom(currentCopy.rotation);\r\n if (currentCopy.rotationQuaternion) {\r\n if (sp.rotationQuaternion) {\r\n sp.rotationQuaternion.copyFrom(currentCopy.rotationQuaternion);\r\n }\r\n else {\r\n sp.rotationQuaternion = currentCopy.rotationQuaternion.clone();\r\n }\r\n }\r\n if (currentCopy.color) {\r\n if (sp.color) {\r\n sp.color.copyFrom(currentCopy.color);\r\n }\r\n else {\r\n sp.color = currentCopy.color.clone();\r\n }\r\n }\r\n sp.scaling.copyFrom(currentCopy.scaling);\r\n sp.uvs.copyFrom(currentCopy.uvs);\r\n if (currentCopy.materialIndex !== null) {\r\n sp.materialIndex = currentCopy.materialIndex;\r\n }\r\n if (this.expandable) {\r\n this._idxOfId[sp.id] = sp.idx;\r\n }\r\n }\r\n if (!storage) {\r\n this._index += shape.length;\r\n this.nbParticles++;\r\n this._lastParticleId++;\r\n }\r\n return sp;\r\n };\r\n /**\r\n * Sets all the particles : this method actually really updates the mesh according to the particle positions, rotations, colors, textures, etc.\r\n * This method calls `updateParticle()` for each particle of the SPS.\r\n * For an animated SPS, it is usually called within the render loop.\r\n * This methods does nothing if called on a non updatable or not yet built SPS. Example : buildMesh() not called after having added or removed particles from an expandable SPS.\r\n * @param start The particle index in the particle array where to start to compute the particle property values _(default 0)_\r\n * @param end The particle index in the particle array where to stop to compute the particle property values _(default nbParticle - 1)_\r\n * @param update If the mesh must be finally updated on this call after all the particle computations _(default true)_\r\n * @returns the SPS.\r\n */\r\n SolidParticleSystem.prototype.setParticles = function (start, end, update) {\r\n if (start === void 0) { start = 0; }\r\n if (end === void 0) { end = this.nbParticles - 1; }\r\n if (update === void 0) { update = true; }\r\n if (!this._updatable || this._isNotBuilt) {\r\n return this;\r\n }\r\n // custom beforeUpdate\r\n this.beforeUpdateParticles(start, end, update);\r\n var rotMatrix = TmpVectors.Matrix[0];\r\n var invertedMatrix = TmpVectors.Matrix[1];\r\n var mesh = this.mesh;\r\n var colors32 = this._colors32;\r\n var positions32 = this._positions32;\r\n var normals32 = this._normals32;\r\n var uvs32 = this._uvs32;\r\n var indices32 = this._indices32;\r\n var indices = this._indices;\r\n var fixedNormal32 = this._fixedNormal32;\r\n var tempVectors = TmpVectors.Vector3;\r\n var camAxisX = tempVectors[5].copyFromFloats(1.0, 0.0, 0.0);\r\n var camAxisY = tempVectors[6].copyFromFloats(0.0, 1.0, 0.0);\r\n var camAxisZ = tempVectors[7].copyFromFloats(0.0, 0.0, 1.0);\r\n var minimum = tempVectors[8].setAll(Number.MAX_VALUE);\r\n var maximum = tempVectors[9].setAll(-Number.MAX_VALUE);\r\n var camInvertedPosition = tempVectors[10].setAll(0);\r\n // cases when the World Matrix is to be computed first\r\n if (this.billboard || this._depthSort) {\r\n this.mesh.computeWorldMatrix(true);\r\n this.mesh._worldMatrix.invertToRef(invertedMatrix);\r\n }\r\n // if the particles will always face the camera\r\n if (this.billboard) {\r\n // compute the camera position and un-rotate it by the current mesh rotation\r\n var tmpVertex = tempVectors[0];\r\n this._camera.getDirectionToRef(Axis.Z, tmpVertex);\r\n Vector3.TransformNormalToRef(tmpVertex, invertedMatrix, camAxisZ);\r\n camAxisZ.normalize();\r\n // same for camera up vector extracted from the cam view matrix\r\n var view = this._camera.getViewMatrix(true);\r\n Vector3.TransformNormalFromFloatsToRef(view.m[1], view.m[5], view.m[9], invertedMatrix, camAxisY);\r\n Vector3.CrossToRef(camAxisY, camAxisZ, camAxisX);\r\n camAxisY.normalize();\r\n camAxisX.normalize();\r\n }\r\n // if depthSort, compute the camera global position in the mesh local system\r\n if (this._depthSort) {\r\n Vector3.TransformCoordinatesToRef(this._camera.globalPosition, invertedMatrix, camInvertedPosition); // then un-rotate the camera\r\n }\r\n Matrix.IdentityToRef(rotMatrix);\r\n var idx = 0; // current position index in the global array positions32\r\n var index = 0; // position start index in the global array positions32 of the current particle\r\n var colidx = 0; // current color index in the global array colors32\r\n var colorIndex = 0; // color start index in the global array colors32 of the current particle\r\n var uvidx = 0; // current uv index in the global array uvs32\r\n var uvIndex = 0; // uv start index in the global array uvs32 of the current particle\r\n var pt = 0; // current index in the particle model shape\r\n if (this.mesh.isFacetDataEnabled) {\r\n this._computeBoundingBox = true;\r\n }\r\n end = (end >= this.nbParticles) ? this.nbParticles - 1 : end;\r\n if (this._computeBoundingBox) {\r\n if (start != 0 || end != this.nbParticles - 1) { // only some particles are updated, then use the current existing BBox basis. Note : it can only increase.\r\n var boundingInfo = this.mesh._boundingInfo;\r\n if (boundingInfo) {\r\n minimum.copyFrom(boundingInfo.minimum);\r\n maximum.copyFrom(boundingInfo.maximum);\r\n }\r\n }\r\n }\r\n // particle loop\r\n index = this.particles[start]._pos;\r\n var vpos = (index / 3) | 0;\r\n colorIndex = vpos * 4;\r\n uvIndex = vpos * 2;\r\n for (var p = start; p <= end; p++) {\r\n var particle = this.particles[p];\r\n // call to custom user function to update the particle properties\r\n this.updateParticle(particle);\r\n var shape = particle._model._shape;\r\n var shapeUV = particle._model._shapeUV;\r\n var particleRotationMatrix = particle._rotationMatrix;\r\n var particlePosition = particle.position;\r\n var particleRotation = particle.rotation;\r\n var particleScaling = particle.scaling;\r\n var particleGlobalPosition = particle._globalPosition;\r\n // camera-particle distance for depth sorting\r\n if (this._depthSort && this._depthSortParticles) {\r\n var dsp = this.depthSortedParticles[p];\r\n dsp.ind = particle._ind;\r\n dsp.indicesLength = particle._model._indicesLength;\r\n dsp.sqDistance = Vector3.DistanceSquared(particle.position, camInvertedPosition);\r\n }\r\n // skip the computations for inactive or already invisible particles\r\n if (!particle.alive || (particle._stillInvisible && !particle.isVisible)) {\r\n // increment indexes for the next particle\r\n pt = shape.length;\r\n index += pt * 3;\r\n colorIndex += pt * 4;\r\n uvIndex += pt * 2;\r\n continue;\r\n }\r\n if (particle.isVisible) {\r\n particle._stillInvisible = false; // un-mark permanent invisibility\r\n var scaledPivot = tempVectors[12];\r\n particle.pivot.multiplyToRef(particleScaling, scaledPivot);\r\n // particle rotation matrix\r\n if (this.billboard) {\r\n particleRotation.x = 0.0;\r\n particleRotation.y = 0.0;\r\n }\r\n if (this._computeParticleRotation || this.billboard) {\r\n particle.getRotationMatrix(rotMatrix);\r\n }\r\n var particleHasParent = (particle.parentId !== null);\r\n if (particleHasParent) {\r\n var parent_1 = this.getParticleById(particle.parentId);\r\n if (parent_1) {\r\n var parentRotationMatrix = parent_1._rotationMatrix;\r\n var parentGlobalPosition = parent_1._globalPosition;\r\n var rotatedY = particlePosition.x * parentRotationMatrix[1] + particlePosition.y * parentRotationMatrix[4] + particlePosition.z * parentRotationMatrix[7];\r\n var rotatedX = particlePosition.x * parentRotationMatrix[0] + particlePosition.y * parentRotationMatrix[3] + particlePosition.z * parentRotationMatrix[6];\r\n var rotatedZ = particlePosition.x * parentRotationMatrix[2] + particlePosition.y * parentRotationMatrix[5] + particlePosition.z * parentRotationMatrix[8];\r\n particleGlobalPosition.x = parentGlobalPosition.x + rotatedX;\r\n particleGlobalPosition.y = parentGlobalPosition.y + rotatedY;\r\n particleGlobalPosition.z = parentGlobalPosition.z + rotatedZ;\r\n if (this._computeParticleRotation || this.billboard) {\r\n var rotMatrixValues = rotMatrix.m;\r\n particleRotationMatrix[0] = rotMatrixValues[0] * parentRotationMatrix[0] + rotMatrixValues[1] * parentRotationMatrix[3] + rotMatrixValues[2] * parentRotationMatrix[6];\r\n particleRotationMatrix[1] = rotMatrixValues[0] * parentRotationMatrix[1] + rotMatrixValues[1] * parentRotationMatrix[4] + rotMatrixValues[2] * parentRotationMatrix[7];\r\n particleRotationMatrix[2] = rotMatrixValues[0] * parentRotationMatrix[2] + rotMatrixValues[1] * parentRotationMatrix[5] + rotMatrixValues[2] * parentRotationMatrix[8];\r\n particleRotationMatrix[3] = rotMatrixValues[4] * parentRotationMatrix[0] + rotMatrixValues[5] * parentRotationMatrix[3] + rotMatrixValues[6] * parentRotationMatrix[6];\r\n particleRotationMatrix[4] = rotMatrixValues[4] * parentRotationMatrix[1] + rotMatrixValues[5] * parentRotationMatrix[4] + rotMatrixValues[6] * parentRotationMatrix[7];\r\n particleRotationMatrix[5] = rotMatrixValues[4] * parentRotationMatrix[2] + rotMatrixValues[5] * parentRotationMatrix[5] + rotMatrixValues[6] * parentRotationMatrix[8];\r\n particleRotationMatrix[6] = rotMatrixValues[8] * parentRotationMatrix[0] + rotMatrixValues[9] * parentRotationMatrix[3] + rotMatrixValues[10] * parentRotationMatrix[6];\r\n particleRotationMatrix[7] = rotMatrixValues[8] * parentRotationMatrix[1] + rotMatrixValues[9] * parentRotationMatrix[4] + rotMatrixValues[10] * parentRotationMatrix[7];\r\n particleRotationMatrix[8] = rotMatrixValues[8] * parentRotationMatrix[2] + rotMatrixValues[9] * parentRotationMatrix[5] + rotMatrixValues[10] * parentRotationMatrix[8];\r\n }\r\n }\r\n else { // in case the parent were removed at some moment\r\n particle.parentId = null;\r\n }\r\n }\r\n else {\r\n particleGlobalPosition.x = particlePosition.x;\r\n particleGlobalPosition.y = particlePosition.y;\r\n particleGlobalPosition.z = particlePosition.z;\r\n if (this._computeParticleRotation || this.billboard) {\r\n var rotMatrixValues = rotMatrix.m;\r\n particleRotationMatrix[0] = rotMatrixValues[0];\r\n particleRotationMatrix[1] = rotMatrixValues[1];\r\n particleRotationMatrix[2] = rotMatrixValues[2];\r\n particleRotationMatrix[3] = rotMatrixValues[4];\r\n particleRotationMatrix[4] = rotMatrixValues[5];\r\n particleRotationMatrix[5] = rotMatrixValues[6];\r\n particleRotationMatrix[6] = rotMatrixValues[8];\r\n particleRotationMatrix[7] = rotMatrixValues[9];\r\n particleRotationMatrix[8] = rotMatrixValues[10];\r\n }\r\n }\r\n var pivotBackTranslation = tempVectors[11];\r\n if (particle.translateFromPivot) {\r\n pivotBackTranslation.setAll(0.0);\r\n }\r\n else {\r\n pivotBackTranslation.copyFrom(scaledPivot);\r\n }\r\n // particle vertex loop\r\n for (pt = 0; pt < shape.length; pt++) {\r\n idx = index + pt * 3;\r\n colidx = colorIndex + pt * 4;\r\n uvidx = uvIndex + pt * 2;\r\n var tmpVertex = tempVectors[0];\r\n tmpVertex.copyFrom(shape[pt]);\r\n if (this._computeParticleVertex) {\r\n this.updateParticleVertex(particle, tmpVertex, pt);\r\n }\r\n // positions\r\n var vertexX = tmpVertex.x * particleScaling.x - scaledPivot.x;\r\n var vertexY = tmpVertex.y * particleScaling.y - scaledPivot.y;\r\n var vertexZ = tmpVertex.z * particleScaling.z - scaledPivot.z;\r\n var rotatedX = vertexX * particleRotationMatrix[0] + vertexY * particleRotationMatrix[3] + vertexZ * particleRotationMatrix[6];\r\n var rotatedY = vertexX * particleRotationMatrix[1] + vertexY * particleRotationMatrix[4] + vertexZ * particleRotationMatrix[7];\r\n var rotatedZ = vertexX * particleRotationMatrix[2] + vertexY * particleRotationMatrix[5] + vertexZ * particleRotationMatrix[8];\r\n rotatedX += pivotBackTranslation.x;\r\n rotatedY += pivotBackTranslation.y;\r\n rotatedZ += pivotBackTranslation.z;\r\n var px = positions32[idx] = particleGlobalPosition.x + camAxisX.x * rotatedX + camAxisY.x * rotatedY + camAxisZ.x * rotatedZ;\r\n var py = positions32[idx + 1] = particleGlobalPosition.y + camAxisX.y * rotatedX + camAxisY.y * rotatedY + camAxisZ.y * rotatedZ;\r\n var pz = positions32[idx + 2] = particleGlobalPosition.z + camAxisX.z * rotatedX + camAxisY.z * rotatedY + camAxisZ.z * rotatedZ;\r\n if (this._computeBoundingBox) {\r\n minimum.minimizeInPlaceFromFloats(px, py, pz);\r\n maximum.maximizeInPlaceFromFloats(px, py, pz);\r\n }\r\n // normals : if the particles can't be morphed then just rotate the normals, what is much more faster than ComputeNormals()\r\n if (!this._computeParticleVertex) {\r\n var normalx = fixedNormal32[idx];\r\n var normaly = fixedNormal32[idx + 1];\r\n var normalz = fixedNormal32[idx + 2];\r\n var rotatedx = normalx * particleRotationMatrix[0] + normaly * particleRotationMatrix[3] + normalz * particleRotationMatrix[6];\r\n var rotatedy = normalx * particleRotationMatrix[1] + normaly * particleRotationMatrix[4] + normalz * particleRotationMatrix[7];\r\n var rotatedz = normalx * particleRotationMatrix[2] + normaly * particleRotationMatrix[5] + normalz * particleRotationMatrix[8];\r\n normals32[idx] = camAxisX.x * rotatedx + camAxisY.x * rotatedy + camAxisZ.x * rotatedz;\r\n normals32[idx + 1] = camAxisX.y * rotatedx + camAxisY.y * rotatedy + camAxisZ.y * rotatedz;\r\n normals32[idx + 2] = camAxisX.z * rotatedx + camAxisY.z * rotatedy + camAxisZ.z * rotatedz;\r\n }\r\n if (this._computeParticleColor && particle.color) {\r\n var color = particle.color;\r\n var colors32_1 = this._colors32;\r\n colors32_1[colidx] = color.r;\r\n colors32_1[colidx + 1] = color.g;\r\n colors32_1[colidx + 2] = color.b;\r\n colors32_1[colidx + 3] = color.a;\r\n }\r\n if (this._computeParticleTexture) {\r\n var uvs = particle.uvs;\r\n uvs32[uvidx] = shapeUV[pt * 2] * (uvs.z - uvs.x) + uvs.x;\r\n uvs32[uvidx + 1] = shapeUV[pt * 2 + 1] * (uvs.w - uvs.y) + uvs.y;\r\n }\r\n }\r\n }\r\n // particle just set invisible : scaled to zero and positioned at the origin\r\n else {\r\n particle._stillInvisible = true; // mark the particle as invisible\r\n for (pt = 0; pt < shape.length; pt++) {\r\n idx = index + pt * 3;\r\n colidx = colorIndex + pt * 4;\r\n uvidx = uvIndex + pt * 2;\r\n positions32[idx] = positions32[idx + 1] = positions32[idx + 2] = 0;\r\n normals32[idx] = normals32[idx + 1] = normals32[idx + 2] = 0;\r\n if (this._computeParticleColor && particle.color) {\r\n var color = particle.color;\r\n colors32[colidx] = color.r;\r\n colors32[colidx + 1] = color.g;\r\n colors32[colidx + 2] = color.b;\r\n colors32[colidx + 3] = color.a;\r\n }\r\n if (this._computeParticleTexture) {\r\n var uvs = particle.uvs;\r\n uvs32[uvidx] = shapeUV[pt * 2] * (uvs.z - uvs.x) + uvs.x;\r\n uvs32[uvidx + 1] = shapeUV[pt * 2 + 1] * (uvs.w - uvs.y) + uvs.y;\r\n }\r\n }\r\n }\r\n // if the particle intersections must be computed : update the bbInfo\r\n if (this._particlesIntersect) {\r\n var bInfo = particle._boundingInfo;\r\n var bBox = bInfo.boundingBox;\r\n var bSphere = bInfo.boundingSphere;\r\n var modelBoundingInfo = particle._modelBoundingInfo;\r\n if (!this._bSphereOnly) {\r\n // place, scale and rotate the particle bbox within the SPS local system, then update it\r\n var modelBoundingInfoVectors = modelBoundingInfo.boundingBox.vectors;\r\n var tempMin = tempVectors[1];\r\n var tempMax = tempVectors[2];\r\n tempMin.setAll(Number.MAX_VALUE);\r\n tempMax.setAll(-Number.MAX_VALUE);\r\n for (var b = 0; b < 8; b++) {\r\n var scaledX = modelBoundingInfoVectors[b].x * particleScaling.x;\r\n var scaledY = modelBoundingInfoVectors[b].y * particleScaling.y;\r\n var scaledZ = modelBoundingInfoVectors[b].z * particleScaling.z;\r\n var rotatedX = scaledX * particleRotationMatrix[0] + scaledY * particleRotationMatrix[3] + scaledZ * particleRotationMatrix[6];\r\n var rotatedY = scaledX * particleRotationMatrix[1] + scaledY * particleRotationMatrix[4] + scaledZ * particleRotationMatrix[7];\r\n var rotatedZ = scaledX * particleRotationMatrix[2] + scaledY * particleRotationMatrix[5] + scaledZ * particleRotationMatrix[8];\r\n var x = particlePosition.x + camAxisX.x * rotatedX + camAxisY.x * rotatedY + camAxisZ.x * rotatedZ;\r\n var y = particlePosition.y + camAxisX.y * rotatedX + camAxisY.y * rotatedY + camAxisZ.y * rotatedZ;\r\n var z = particlePosition.z + camAxisX.z * rotatedX + camAxisY.z * rotatedY + camAxisZ.z * rotatedZ;\r\n tempMin.minimizeInPlaceFromFloats(x, y, z);\r\n tempMax.maximizeInPlaceFromFloats(x, y, z);\r\n }\r\n bBox.reConstruct(tempMin, tempMax, mesh._worldMatrix);\r\n }\r\n // place and scale the particle bouding sphere in the SPS local system, then update it\r\n var minBbox = modelBoundingInfo.minimum.multiplyToRef(particleScaling, tempVectors[1]);\r\n var maxBbox = modelBoundingInfo.maximum.multiplyToRef(particleScaling, tempVectors[2]);\r\n var bSphereCenter = maxBbox.addToRef(minBbox, tempVectors[3]).scaleInPlace(0.5).addInPlace(particleGlobalPosition);\r\n var halfDiag = maxBbox.subtractToRef(minBbox, tempVectors[4]).scaleInPlace(0.5 * this._bSphereRadiusFactor);\r\n var bSphereMinBbox = bSphereCenter.subtractToRef(halfDiag, tempVectors[1]);\r\n var bSphereMaxBbox = bSphereCenter.addToRef(halfDiag, tempVectors[2]);\r\n bSphere.reConstruct(bSphereMinBbox, bSphereMaxBbox, mesh._worldMatrix);\r\n }\r\n // increment indexes for the next particle\r\n index = idx + 3;\r\n colorIndex = colidx + 4;\r\n uvIndex = uvidx + 2;\r\n }\r\n // if the VBO must be updated\r\n if (update) {\r\n if (this._computeParticleColor) {\r\n mesh.updateVerticesData(VertexBuffer.ColorKind, colors32, false, false);\r\n }\r\n if (this._computeParticleTexture) {\r\n mesh.updateVerticesData(VertexBuffer.UVKind, uvs32, false, false);\r\n }\r\n mesh.updateVerticesData(VertexBuffer.PositionKind, positions32, false, false);\r\n if (!mesh.areNormalsFrozen || mesh.isFacetDataEnabled) {\r\n if (this._computeParticleVertex || mesh.isFacetDataEnabled) {\r\n // recompute the normals only if the particles can be morphed, update then also the normal reference array _fixedNormal32[]\r\n var params = mesh.isFacetDataEnabled ? mesh.getFacetDataParameters() : null;\r\n VertexData.ComputeNormals(positions32, indices32, normals32, params);\r\n for (var i = 0; i < normals32.length; i++) {\r\n fixedNormal32[i] = normals32[i];\r\n }\r\n }\r\n if (!mesh.areNormalsFrozen) {\r\n mesh.updateVerticesData(VertexBuffer.NormalKind, normals32, false, false);\r\n }\r\n }\r\n if (this._depthSort && this._depthSortParticles) {\r\n var depthSortedParticles = this.depthSortedParticles;\r\n depthSortedParticles.sort(this._depthSortFunction);\r\n var dspl = depthSortedParticles.length;\r\n var sid = 0;\r\n for (var sorted = 0; sorted < dspl; sorted++) {\r\n var lind = depthSortedParticles[sorted].indicesLength;\r\n var sind = depthSortedParticles[sorted].ind;\r\n for (var i = 0; i < lind; i++) {\r\n indices32[sid] = indices[sind + i];\r\n sid++;\r\n }\r\n }\r\n mesh.updateIndices(indices32);\r\n }\r\n }\r\n if (this._computeBoundingBox) {\r\n if (mesh._boundingInfo) {\r\n mesh._boundingInfo.reConstruct(minimum, maximum, mesh._worldMatrix);\r\n }\r\n else {\r\n mesh._boundingInfo = new BoundingInfo(minimum, maximum, mesh._worldMatrix);\r\n }\r\n }\r\n if (this._autoUpdateSubMeshes) {\r\n this.computeSubMeshes();\r\n }\r\n this.afterUpdateParticles(start, end, update);\r\n return this;\r\n };\r\n /**\r\n * Disposes the SPS.\r\n */\r\n SolidParticleSystem.prototype.dispose = function () {\r\n this.mesh.dispose();\r\n this.vars = null;\r\n // drop references to internal big arrays for the GC\r\n this._positions = null;\r\n this._indices = null;\r\n this._normals = null;\r\n this._uvs = null;\r\n this._colors = null;\r\n this._indices32 = null;\r\n this._positions32 = null;\r\n this._normals32 = null;\r\n this._fixedNormal32 = null;\r\n this._uvs32 = null;\r\n this._colors32 = null;\r\n this.pickedParticles = null;\r\n };\r\n /**\r\n * Returns a SolidParticle object from its identifier : particle.id\r\n * @param id (integer) the particle Id\r\n * @returns the searched particle or null if not found in the SPS.\r\n */\r\n SolidParticleSystem.prototype.getParticleById = function (id) {\r\n var p = this.particles[id];\r\n if (p && p.id == id) {\r\n return p;\r\n }\r\n var particles = this.particles;\r\n var idx = this._idxOfId[id];\r\n if (idx !== undefined) {\r\n return particles[idx];\r\n }\r\n var i = 0;\r\n var nb = this.nbParticles;\r\n while (i < nb) {\r\n var particle = particles[i];\r\n if (particle.id == id) {\r\n return particle;\r\n }\r\n i++;\r\n }\r\n return null;\r\n };\r\n /**\r\n * Returns a new array populated with the particles having the passed shapeId.\r\n * @param shapeId (integer) the shape identifier\r\n * @returns a new solid particle array\r\n */\r\n SolidParticleSystem.prototype.getParticlesByShapeId = function (shapeId) {\r\n var ref = [];\r\n this.getParticlesByShapeIdToRef(shapeId, ref);\r\n return ref;\r\n };\r\n /**\r\n * Populates the passed array \"ref\" with the particles having the passed shapeId.\r\n * @param shapeId the shape identifier\r\n * @returns the SPS\r\n * @param ref\r\n */\r\n SolidParticleSystem.prototype.getParticlesByShapeIdToRef = function (shapeId, ref) {\r\n ref.length = 0;\r\n for (var i = 0; i < this.nbParticles; i++) {\r\n var p = this.particles[i];\r\n if (p.shapeId == shapeId) {\r\n ref.push(p);\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Computes the required SubMeshes according the materials assigned to the particles.\r\n * @returns the solid particle system.\r\n * Does nothing if called before the SPS mesh is built.\r\n */\r\n SolidParticleSystem.prototype.computeSubMeshes = function () {\r\n if (!this.mesh || !this._multimaterialEnabled) {\r\n return this;\r\n }\r\n var depthSortedParticles = this.depthSortedParticles;\r\n if (this.particles.length > 0) {\r\n for (var p = 0; p < this.particles.length; p++) {\r\n var part = this.particles[p];\r\n if (!part.materialIndex) {\r\n part.materialIndex = 0;\r\n }\r\n var sortedPart = depthSortedParticles[p];\r\n sortedPart.materialIndex = part.materialIndex;\r\n sortedPart.ind = part._ind;\r\n sortedPart.indicesLength = part._model._indicesLength;\r\n }\r\n }\r\n this._sortParticlesByMaterial();\r\n var indicesByMaterial = this._indicesByMaterial;\r\n var materialIndexes = this._materialIndexes;\r\n var mesh = this.mesh;\r\n mesh.subMeshes = [];\r\n var vcount = mesh.getTotalVertices();\r\n for (var m = 0; m < materialIndexes.length; m++) {\r\n var start = indicesByMaterial[m];\r\n var count = indicesByMaterial[m + 1] - start;\r\n var matIndex = materialIndexes[m];\r\n new SubMesh(matIndex, 0, vcount, start, count, mesh);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sorts the solid particles by material when MultiMaterial is enabled.\r\n * Updates the indices32 array.\r\n * Updates the indicesByMaterial array.\r\n * Updates the mesh indices array.\r\n * @returns the SPS\r\n * @hidden\r\n */\r\n SolidParticleSystem.prototype._sortParticlesByMaterial = function () {\r\n var indicesByMaterial = [0];\r\n this._indicesByMaterial = indicesByMaterial;\r\n var materialIndexes = [];\r\n this._materialIndexes = materialIndexes;\r\n var depthSortedParticles = this.depthSortedParticles;\r\n depthSortedParticles.sort(this._materialSortFunction);\r\n var length = depthSortedParticles.length;\r\n var indices32 = this._indices32;\r\n var indices = this._indices;\r\n var sid = 0;\r\n var lastMatIndex = depthSortedParticles[0].materialIndex;\r\n materialIndexes.push(lastMatIndex);\r\n for (var sorted = 0; sorted < length; sorted++) {\r\n var sortedPart = depthSortedParticles[sorted];\r\n var lind = sortedPart.indicesLength;\r\n var sind = sortedPart.ind;\r\n if (sortedPart.materialIndex !== lastMatIndex) {\r\n lastMatIndex = sortedPart.materialIndex;\r\n indicesByMaterial.push(sid);\r\n materialIndexes.push(lastMatIndex);\r\n }\r\n for (var i = 0; i < lind; i++) {\r\n indices32[sid] = indices[sind + i];\r\n sid++;\r\n }\r\n }\r\n indicesByMaterial.push(indices32.length); // add the last number to ease the indices start/count values for subMeshes creation\r\n if (this._updatable) {\r\n this.mesh.updateIndices(indices32);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets the material indexes by id materialIndexesById[id] = materialIndex\r\n * @hidden\r\n */\r\n SolidParticleSystem.prototype._setMaterialIndexesById = function () {\r\n this._materialIndexesById = {};\r\n for (var i = 0; i < this._materials.length; i++) {\r\n var id = this._materials[i].uniqueId;\r\n this._materialIndexesById[id] = i;\r\n }\r\n };\r\n /**\r\n * Returns an array with unique values of Materials from the passed array\r\n * @param array the material array to be checked and filtered\r\n * @hidden\r\n */\r\n SolidParticleSystem.prototype._filterUniqueMaterialId = function (array) {\r\n var filtered = array.filter(function (value, index, self) {\r\n return self.indexOf(value) === index;\r\n });\r\n return filtered;\r\n };\r\n /**\r\n * Sets a new Standard Material as _defaultMaterial if not already set.\r\n * @hidden\r\n */\r\n SolidParticleSystem.prototype._setDefaultMaterial = function () {\r\n if (!this._defaultMaterial) {\r\n this._defaultMaterial = new StandardMaterial(this.name + \"DefaultMaterial\", this._scene);\r\n }\r\n return this._defaultMaterial;\r\n };\r\n /**\r\n * Visibilty helper : Recomputes the visible size according to the mesh bounding box\r\n * doc : http://doc.babylonjs.com/how_to/Solid_Particle_System#sps-visibility\r\n * @returns the SPS.\r\n */\r\n SolidParticleSystem.prototype.refreshVisibleSize = function () {\r\n if (!this._isVisibilityBoxLocked) {\r\n this.mesh.refreshBoundingInfo();\r\n }\r\n return this;\r\n };\r\n /**\r\n * Visibility helper : Sets the size of a visibility box, this sets the underlying mesh bounding box.\r\n * @param size the size (float) of the visibility box\r\n * note : this doesn't lock the SPS mesh bounding box.\r\n * doc : http://doc.babylonjs.com/how_to/Solid_Particle_System#sps-visibility\r\n */\r\n SolidParticleSystem.prototype.setVisibilityBox = function (size) {\r\n var vis = size / 2;\r\n this.mesh._boundingInfo = new BoundingInfo(new Vector3(-vis, -vis, -vis), new Vector3(vis, vis, vis));\r\n };\r\n Object.defineProperty(SolidParticleSystem.prototype, \"isAlwaysVisible\", {\r\n /**\r\n * Gets whether the SPS as always visible or not\r\n * doc : http://doc.babylonjs.com/how_to/Solid_Particle_System#sps-visibility\r\n */\r\n get: function () {\r\n return this._alwaysVisible;\r\n },\r\n /**\r\n * Sets the SPS as always visible or not\r\n * doc : http://doc.babylonjs.com/how_to/Solid_Particle_System#sps-visibility\r\n */\r\n set: function (val) {\r\n this._alwaysVisible = val;\r\n this.mesh.alwaysSelectAsActiveMesh = val;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SolidParticleSystem.prototype, \"isVisibilityBoxLocked\", {\r\n /**\r\n * Gets if the SPS visibility box as locked or not. This enables/disables the underlying mesh bounding box updates.\r\n * doc : http://doc.babylonjs.com/how_to/Solid_Particle_System#sps-visibility\r\n */\r\n get: function () {\r\n return this._isVisibilityBoxLocked;\r\n },\r\n /**\r\n * Sets the SPS visibility box as locked or not. This enables/disables the underlying mesh bounding box updates.\r\n * doc : http://doc.babylonjs.com/how_to/Solid_Particle_System#sps-visibility\r\n */\r\n set: function (val) {\r\n this._isVisibilityBoxLocked = val;\r\n var boundingInfo = this.mesh.getBoundingInfo();\r\n boundingInfo.isLocked = val;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SolidParticleSystem.prototype, \"computeParticleRotation\", {\r\n /**\r\n * Gets if `setParticles()` computes the particle rotations or not.\r\n * Default value : true. The SPS is faster when it's set to false.\r\n * Note : the particle rotations aren't stored values, so setting `computeParticleRotation` to false will prevents the particle to rotate.\r\n */\r\n get: function () {\r\n return this._computeParticleRotation;\r\n },\r\n /**\r\n * Tells to `setParticles()` to compute the particle rotations or not.\r\n * Default value : true. The SPS is faster when it's set to false.\r\n * Note : the particle rotations aren't stored values, so setting `computeParticleRotation` to false will prevents the particle to rotate.\r\n */\r\n set: function (val) {\r\n this._computeParticleRotation = val;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SolidParticleSystem.prototype, \"computeParticleColor\", {\r\n /**\r\n * Gets if `setParticles()` computes the particle colors or not.\r\n * Default value : true. The SPS is faster when it's set to false.\r\n * Note : the particle colors are stored values, so setting `computeParticleColor` to false will keep yet the last colors set.\r\n */\r\n get: function () {\r\n return this._computeParticleColor;\r\n },\r\n /**\r\n * Tells to `setParticles()` to compute the particle colors or not.\r\n * Default value : true. The SPS is faster when it's set to false.\r\n * Note : the particle colors are stored values, so setting `computeParticleColor` to false will keep yet the last colors set.\r\n */\r\n set: function (val) {\r\n this._computeParticleColor = val;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SolidParticleSystem.prototype, \"computeParticleTexture\", {\r\n /**\r\n * Gets if `setParticles()` computes the particle textures or not.\r\n * Default value : true. The SPS is faster when it's set to false.\r\n * Note : the particle textures are stored values, so setting `computeParticleTexture` to false will keep yet the last colors set.\r\n */\r\n get: function () {\r\n return this._computeParticleTexture;\r\n },\r\n set: function (val) {\r\n this._computeParticleTexture = val;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SolidParticleSystem.prototype, \"computeParticleVertex\", {\r\n /**\r\n * Gets if `setParticles()` calls the vertex function for each vertex of each particle, or not.\r\n * Default value : false. The SPS is faster when it's set to false.\r\n * Note : the particle custom vertex positions aren't stored values.\r\n */\r\n get: function () {\r\n return this._computeParticleVertex;\r\n },\r\n /**\r\n * Tells to `setParticles()` to call the vertex function for each vertex of each particle, or not.\r\n * Default value : false. The SPS is faster when it's set to false.\r\n * Note : the particle custom vertex positions aren't stored values.\r\n */\r\n set: function (val) {\r\n this._computeParticleVertex = val;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SolidParticleSystem.prototype, \"computeBoundingBox\", {\r\n /**\r\n * Gets if `setParticles()` computes or not the mesh bounding box when computing the particle positions.\r\n */\r\n get: function () {\r\n return this._computeBoundingBox;\r\n },\r\n /**\r\n * Tells to `setParticles()` to compute or not the mesh bounding box when computing the particle positions.\r\n */\r\n set: function (val) {\r\n this._computeBoundingBox = val;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SolidParticleSystem.prototype, \"depthSortParticles\", {\r\n /**\r\n * Gets if `setParticles()` sorts or not the distance between each particle and the camera.\r\n * Skipped when `enableDepthSort` is set to `false` (default) at construction time.\r\n * Default : `true`\r\n */\r\n get: function () {\r\n return this._depthSortParticles;\r\n },\r\n /**\r\n * Tells to `setParticles()` to sort or not the distance between each particle and the camera.\r\n * Skipped when `enableDepthSort` is set to `false` (default) at construction time.\r\n * Default : `true`\r\n */\r\n set: function (val) {\r\n this._depthSortParticles = val;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SolidParticleSystem.prototype, \"expandable\", {\r\n /**\r\n * Gets if the SPS is created as expandable at construction time.\r\n * Default : `false`\r\n */\r\n get: function () {\r\n return this._expandable;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SolidParticleSystem.prototype, \"multimaterialEnabled\", {\r\n /**\r\n * Gets if the SPS supports the Multi Materials\r\n */\r\n get: function () {\r\n return this._multimaterialEnabled;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SolidParticleSystem.prototype, \"useModelMaterial\", {\r\n /**\r\n * Gets if the SPS uses the model materials for its own multimaterial.\r\n */\r\n get: function () {\r\n return this._useModelMaterial;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SolidParticleSystem.prototype, \"materials\", {\r\n /**\r\n * The SPS used material array.\r\n */\r\n get: function () {\r\n return this._materials;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Sets the SPS MultiMaterial from the passed materials.\r\n * Note : the passed array is internally copied and not used then by reference.\r\n * @param materials an array of material objects. This array indexes are the materialIndex values of the particles.\r\n */\r\n SolidParticleSystem.prototype.setMultiMaterial = function (materials) {\r\n this._materials = this._filterUniqueMaterialId(materials);\r\n this._setMaterialIndexesById();\r\n if (this._multimaterial) {\r\n this._multimaterial.dispose();\r\n }\r\n this._multimaterial = new MultiMaterial(this.name + \"MultiMaterial\", this._scene);\r\n for (var m = 0; m < this._materials.length; m++) {\r\n this._multimaterial.subMaterials.push(this._materials[m]);\r\n }\r\n this.computeSubMeshes();\r\n this.mesh.material = this._multimaterial;\r\n };\r\n Object.defineProperty(SolidParticleSystem.prototype, \"multimaterial\", {\r\n /**\r\n * The SPS computed multimaterial object\r\n */\r\n get: function () {\r\n return this._multimaterial;\r\n },\r\n set: function (mm) {\r\n this._multimaterial = mm;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(SolidParticleSystem.prototype, \"autoUpdateSubMeshes\", {\r\n /**\r\n * If the subMeshes must be updated on the next call to setParticles()\r\n */\r\n get: function () {\r\n return this._autoUpdateSubMeshes;\r\n },\r\n set: function (val) {\r\n this._autoUpdateSubMeshes = val;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n // =======================================================================\r\n // Particle behavior logic\r\n // these following methods may be overwritten by the user to fit his needs\r\n /**\r\n * This function does nothing. It may be overwritten to set all the particle first values.\r\n * The SPS doesn't call this function, you may have to call it by your own.\r\n * doc : http://doc.babylonjs.com/how_to/Solid_Particle_System#particle-management\r\n */\r\n SolidParticleSystem.prototype.initParticles = function () {\r\n };\r\n /**\r\n * This function does nothing. It may be overwritten to recycle a particle.\r\n * The SPS doesn't call this function, you may have to call it by your own.\r\n * doc : http://doc.babylonjs.com/how_to/Solid_Particle_System#particle-management\r\n * @param particle The particle to recycle\r\n * @returns the recycled particle\r\n */\r\n SolidParticleSystem.prototype.recycleParticle = function (particle) {\r\n return particle;\r\n };\r\n /**\r\n * Updates a particle : this function should be overwritten by the user.\r\n * It is called on each particle by `setParticles()`. This is the place to code each particle behavior.\r\n * doc : http://doc.babylonjs.com/how_to/Solid_Particle_System#particle-management\r\n * @example : just set a particle position or velocity and recycle conditions\r\n * @param particle The particle to update\r\n * @returns the updated particle\r\n */\r\n SolidParticleSystem.prototype.updateParticle = function (particle) {\r\n return particle;\r\n };\r\n /**\r\n * Updates a vertex of a particle : it can be overwritten by the user.\r\n * This will be called on each vertex particle by `setParticles()` if `computeParticleVertex` is set to true only.\r\n * @param particle the current particle\r\n * @param vertex the current index of the current particle\r\n * @param pt the index of the current vertex in the particle shape\r\n * doc : http://doc.babylonjs.com/how_to/Solid_Particle_System#update-each-particle-shape\r\n * @example : just set a vertex particle position\r\n * @returns the updated vertex\r\n */\r\n SolidParticleSystem.prototype.updateParticleVertex = function (particle, vertex, pt) {\r\n return vertex;\r\n };\r\n /**\r\n * This will be called before any other treatment by `setParticles()` and will be passed three parameters.\r\n * This does nothing and may be overwritten by the user.\r\n * @param start the particle index in the particle array where to stop to iterate, same than the value passed to setParticle()\r\n * @param stop the particle index in the particle array where to stop to iterate, same than the value passed to setParticle()\r\n * @param update the boolean update value actually passed to setParticles()\r\n */\r\n SolidParticleSystem.prototype.beforeUpdateParticles = function (start, stop, update) {\r\n };\r\n /**\r\n * This will be called by `setParticles()` after all the other treatments and just before the actual mesh update.\r\n * This will be passed three parameters.\r\n * This does nothing and may be overwritten by the user.\r\n * @param start the particle index in the particle array where to stop to iterate, same than the value passed to setParticle()\r\n * @param stop the particle index in the particle array where to stop to iterate, same than the value passed to setParticle()\r\n * @param update the boolean update value actually passed to setParticles()\r\n */\r\n SolidParticleSystem.prototype.afterUpdateParticles = function (start, stop, update) {\r\n };\r\n return SolidParticleSystem;\r\n}());\r\nexport { SolidParticleSystem };\r\n//# sourceMappingURL=solidParticleSystem.js.map"],"sourceRoot":""} \ No newline at end of file +{"version":3,"sources":["webpack://Baby/webpack/bootstrap","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.vector.js","webpack://Baby/./node_modules/tslib/tslib.es6.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/buffer.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/decorators.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/observable.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/effect.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/math2D.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/control.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.color.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/devTools.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/typeStore.js","webpack://Baby/./node_modules/@babylonjs/core/Events/pointerEvents.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/logger.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/promise.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/tools.js","webpack://Baby/./node_modules/@babylonjs/core/Loading/sceneLoaderFlags.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/geometry.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/multiMaterial.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/meshLODLevel.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/mesh.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/mesh.vertexData.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/valueAndUnit.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.constants.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.scalar.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/thinMaterialHelper.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/materialHelper.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/Textures/baseTexture.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/Textures/thinTexture.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/copyTools.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/Textures/texture.js","webpack://Baby/./node_modules/@babylonjs/core/States/depthCullingState.js","webpack://Baby/./node_modules/@babylonjs/core/States/stencilState.js","webpack://Baby/./node_modules/@babylonjs/core/States/alphaCullingState.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/WebGL/webGLShaderProcessors.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/WebGL/webGL2ShaderProcessors.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/WebGL/webGLPipelineContext.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/thinEngine.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/camera.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/andOrNotEvaluator.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/tags.js","webpack://Baby/./node_modules/@babylonjs/core/sceneComponent.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/material.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/performanceMonitor.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Extensions/engine.alpha.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Extensions/engine.readTexture.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Extensions/engine.dynamicBuffer.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/engine.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/engineStore.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/domManagement.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/stringDictionary.js","webpack://Baby/./node_modules/@babylonjs/core/abstractScene.js","webpack://Baby/./node_modules/@babylonjs/core/Actions/actionEvent.js","webpack://Baby/./node_modules/@babylonjs/core/Actions/abstractActionManager.js","webpack://Baby/./node_modules/@babylonjs/core/Inputs/scene.inputManager.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/uniqueIdGenerator.js","webpack://Baby/./node_modules/@babylonjs/core/scene.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/smartArray.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/measure.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/arrayTools.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/container.js","webpack://Baby/./node_modules/@babylonjs/core/node.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/filesInputStore.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/retryStrategy.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/baseError.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/fileTools.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.axis.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/precisionDate.js","webpack://Baby/./node_modules/@babylonjs/core/Culling/boundingBox.js","webpack://Baby/./node_modules/@babylonjs/core/Culling/boundingSphere.js","webpack://Baby/./node_modules/@babylonjs/core/Culling/boundingInfo.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/Textures/internalTexture.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/stringTools.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/transformNode.js","webpack://Baby/./node_modules/axios/lib/utils.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/webRequest.js","webpack://Baby/./node_modules/@babylonjs/core/Collisions/pickingInfo.js","webpack://Baby/./node_modules/@babylonjs/core/Lights/light.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/subMesh.js","webpack://Baby/./node_modules/@babylonjs/core/Events/keyboardEvents.js","webpack://Baby/./node_modules/@babylonjs/core/Events/clipboardEvents.js","webpack://Baby/./node_modules/@babylonjs/core/Collisions/meshCollisionData.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/abstractMesh.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/performanceConfigurator.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/prePassConfiguration.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/pushMaterial.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/materialFlags.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/defaultFragmentDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/defaultUboDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/prePassDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/lightFragmentDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/lightUboDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/lightsFragmentFunctions.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/shadowsFragmentFunctions.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/fresnelFunction.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/reflectionFunction.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/imageProcessingDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/imageProcessingFunctions.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/bumpFragmentMainFunctions.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/bumpFragmentFunctions.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/logDepthDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/fogFragmentDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/bumpFragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/depthPrePass.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/lightFragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/logDepthFragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/fogFragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/default.fragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/defaultVertexDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/prePassVertexDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/bumpVertexDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/fogVertexDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/morphTargetsVertexGlobalDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/morphTargetsVertexDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/morphTargetsVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/prePassVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/bumpVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/fogVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/shadowsVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/pointCloudVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/logDepthVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/default.vertex.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/material.detailMapConfiguration.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/standardMaterial.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.plane.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.frustum.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.size.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/canvasGenerator.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/WebGL/webGLDataBuffer.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/dataBuffer.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.vertexFormat.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.viewport.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/perfCounter.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/colorCurves.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/imageProcessingConfiguration.js","webpack://Baby/./babyplots.ts","webpack://Baby/./node_modules/@babylonjs/core/Misc/deepCopier.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.functions.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Extensions/engine.uniformBuffer.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/uniformBuffer.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/instantiationTools.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/timingTools.js","webpack://Baby/./node_modules/@babylonjs/core/PostProcesses/postProcessManager.js","webpack://Baby/./node_modules/@babylonjs/core/Collisions/intersectionInfo.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/shaderCodeNode.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/shaderCodeCursor.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/shaderCodeConditionNode.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/shaderCodeTestNode.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/Expressions/shaderDefineExpression.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/Expressions/Operators/shaderDefineIsDefinedOperator.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/Expressions/Operators/shaderDefineOrOperator.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/Expressions/Operators/shaderDefineAndOperator.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/Expressions/Operators/shaderDefineArithmeticOperator.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Processors/shaderProcessor.js","webpack://Baby/./node_modules/@babylonjs/core/Maths/math.path.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/Textures/renderTargetCreationOptions.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/guid.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/materialDefines.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/effectFallbacks.js","webpack://Baby/./node_modules/@babylonjs/core/Rendering/renderingGroup.js","webpack://Baby/./node_modules/@babylonjs/core/Rendering/renderingManager.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/Builders/boxBuilder.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/helperFunctions.js","webpack://Baby/./node_modules/chroma-js/chroma.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/Builders/planeBuilder.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Extensions/engine.dynamicTexture.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/Textures/dynamicTexture.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/clipPlaneFragmentDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/clipPlaneFragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/bonesDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/instancesDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/clipPlaneVertexDeclaration.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/instancesVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/bonesVertex.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/ShadersInclude/clipPlaneVertex.js","webpack://Baby/./node_modules/axios/lib/helpers/bind.js","webpack://Baby/./node_modules/axios/lib/helpers/buildURL.js","webpack://Baby/./node_modules/axios/lib/cancel/isCancel.js","webpack://Baby/./node_modules/axios/lib/defaults.js","webpack://Baby/./node_modules/axios/lib/adapters/xhr.js","webpack://Baby/./node_modules/axios/lib/core/createError.js","webpack://Baby/./node_modules/axios/lib/core/mergeConfig.js","webpack://Baby/./node_modules/axios/lib/cancel/Cancel.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/Builders/cylinderBuilder.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/rectangle.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/textBlock.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/image.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/button.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/stackPanel.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/checkbox.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/textWrapper.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/inputText.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/grid.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/colorpicker.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/ellipse.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/inputPassword.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/line.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/multiLinePoint.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/multiLine.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/radioButton.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/sliders/baseSlider.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/sliders/slider.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/selector.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/scrollViewers/scrollViewerWindow.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/sliders/scrollBar.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/sliders/imageScrollBar.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/scrollViewers/scrollViewer.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/virtualKeyboard.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/displayGrid.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/sliders/imageBasedSlider.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/controls/statics.js","webpack://Baby/./node_modules/@babylonjs/core/Layers/layerSceneComponent.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/layer.fragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/layer.vertex.js","webpack://Baby/./node_modules/@babylonjs/core/Layers/layer.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/style.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/constants.js","webpack://Baby/./node_modules/@babylonjs/gui/2D/advancedDynamicTexture.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/instancedMesh.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/shaderMaterial.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/color.fragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/color.vertex.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/linesMesh.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/Builders/linesBuilder.js","webpack://Baby/./node_modules/@babylonjs/core/Lights/hemisphericLight.js","webpack://Baby/./node_modules/downloadjs/download.js","webpack://Baby/./node_modules/axios/index.js","webpack://Baby/./node_modules/axios/lib/axios.js","webpack://Baby/./node_modules/axios/lib/core/Axios.js","webpack://Baby/./node_modules/axios/lib/core/InterceptorManager.js","webpack://Baby/./node_modules/axios/lib/core/dispatchRequest.js","webpack://Baby/./node_modules/axios/lib/core/transformData.js","webpack://Baby/./node_modules/process/browser.js","webpack://Baby/./node_modules/axios/lib/helpers/normalizeHeaderName.js","webpack://Baby/./node_modules/axios/lib/core/settle.js","webpack://Baby/./node_modules/axios/lib/core/enhanceError.js","webpack://Baby/./node_modules/axios/lib/helpers/cookies.js","webpack://Baby/./node_modules/axios/lib/core/buildFullPath.js","webpack://Baby/./node_modules/axios/lib/helpers/isAbsoluteURL.js","webpack://Baby/./node_modules/axios/lib/helpers/combineURLs.js","webpack://Baby/./node_modules/axios/lib/helpers/parseHeaders.js","webpack://Baby/./node_modules/axios/lib/helpers/isURLSameOrigin.js","webpack://Baby/./node_modules/axios/lib/cancel/CancelToken.js","webpack://Baby/./node_modules/axios/lib/helpers/spread.js","webpack://Baby/./Label.ts","webpack://Baby/./Axes.ts","webpack://Baby/./ImgStack.ts","webpack://Baby/./ShapeCloud.ts","webpack://Baby/./node_modules/@babylonjs/core/Meshes/thinInstanceMesh.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/Builders/sphereBuilder.js","webpack://Baby/./node_modules/@babylonjs/core/Meshes/Builders/torusBuilder.js","webpack://Baby/./PointCloud.ts","webpack://Baby/./Surface.ts","webpack://Baby/./HeatMap.ts","webpack://Baby/./node_modules/@babylonjs/core/Animations/animationKey.js","webpack://Baby/./node_modules/@babylonjs/core/Behaviors/Cameras/autoRotationBehavior.js","webpack://Baby/./node_modules/@babylonjs/core/Animations/easing.js","webpack://Baby/./node_modules/@babylonjs/core/Animations/animationRange.js","webpack://Baby/./node_modules/@babylonjs/core/Animations/animation.js","webpack://Baby/./node_modules/@babylonjs/core/Behaviors/Cameras/bouncingBehavior.js","webpack://Baby/./node_modules/@babylonjs/core/Behaviors/Cameras/framingBehavior.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/targetCamera.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/cameraInputsManager.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/Inputs/arcRotateCameraPointersInput.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/Inputs/BaseCameraPointersInput.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/Inputs/arcRotateCameraKeyboardMoveInput.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/Inputs/arcRotateCameraMouseWheelInput.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/arcRotateCameraInputsManager.js","webpack://Baby/./node_modules/@babylonjs/core/Cameras/arcRotateCamera.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/rng.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/regex.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/stringify.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/validate.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/v1.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/parse.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/v35.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/md5.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/v3.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/v4.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/sha1.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/v5.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/nil.js","webpack://Baby/./node_modules/uuid/dist/esm-browser/version.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Extensions/engine.renderTarget.js","webpack://Baby/./node_modules/@babylonjs/core/Engines/Extensions/engine.renderTargetCube.js","webpack://Baby/./node_modules/@babylonjs/core/Materials/Textures/renderTargetTexture.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/postprocess.vertex.js","webpack://Baby/./node_modules/@babylonjs/core/PostProcesses/postProcess.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/fxaa.fragment.js","webpack://Baby/./node_modules/@babylonjs/core/Shaders/fxaa.vertex.js","webpack://Baby/./node_modules/@babylonjs/core/PostProcesses/fxaaPostProcess.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/screenshotTools.js","webpack://Baby/./node_modules/@babylonjs/core/Culling/ray.js","webpack://Baby/./node_modules/@babylonjs/core/Misc/pivotTools.js","webpack://Baby/./node_modules/@babylonjs/core/Behaviors/Meshes/pointerDragBehavior.js"],"names":["installedModules","__webpack_require__","moduleId","exports","module","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","Vector2","x","y","this","toString","getClassName","getHashCode","hash","toArray","array","index","fromArray","FromArrayToRef","asArray","result","Array","copyFrom","source","copyFromFloats","set","add","otherVector","addToRef","addInPlace","addVector3","subtract","subtractToRef","subtractInPlace","multiplyInPlace","multiply","multiplyToRef","multiplyByFloats","divide","divideToRef","divideInPlace","negate","negateInPlace","negateToRef","scaleInPlace","scale","scaleToRef","scaleAndAddToRef","equals","equalsWithEpsilon","epsilon","WithinEpsilon","floor","Math","fract","length","sqrt","lengthSquared","normalize","len","clone","Zero","One","FromArray","offset","CatmullRom","value1","value2","value3","value4","amount","squared","cubed","Clamp","min","max","Hermite","tangent1","tangent2","part1","part2","part3","part4","Lerp","start","end","Dot","left","right","Normalize","vector","newVector","Minimize","Maximize","Transform","transformation","TransformToRef","PointInTriangle","p0","p1","p2","a","sign","Distance","DistanceSquared","Center","center","DistanceOfPointFromSegment","segA","segB","l2","v","proj","Vector3","z","_isDirty","_x","_y","_z","configurable","toQuaternion","Quaternion","RotationYawPitchRoll","addInPlaceFromFloats","subtractFromFloatsToRef","subtractFromFloats","projectOnPlane","plane","origin","projectOnPlaneToRef","normal","V","MathTmp","denom","scaledV","equalsToFloats","minimizeInPlace","other","minimizeInPlaceFromFloats","maximizeInPlace","maximizeInPlaceFromFloats","isNonUniformWithinEpsilon","absX","abs","absY","absZ","normalizeFromLength","reorderInPlace","order","_this","toLowerCase","forEach","val","rotateByQuaternionToRef","quaternion","toRotationMatrix","Matrix","TransformCoordinatesToRef","rotateByQuaternionAroundPointToRef","point","cross","Cross","normalizeToNew","normalized","normalizeToRef","reference","setAll","GetClipFactor","vector0","vector1","axis","size","d0","GetAngleBetweenVectors","v0","v1","dot","CrossToRef","acos","FromFloatArray","FromFloatArrayToRef","FromFloatsToRef","Up","_UpReadOnly","_ZeroReadOnly","Down","Forward","rightHandedSystem","Backward","Right","Left","TransformCoordinates","TransformCoordinatesFromFloatsToRef","rx","ry","rz","rw","TransformNormal","TransformNormalToRef","TransformNormalFromFloatsToRef","ClampToRef","CheckExtends","LerpToRef","NormalizeToRef","Project","world","transform","viewport","ProjectToRef","cw","width","ch","height","cx","cy","viewportMatrix","FromValuesToRef","matrix","_UnprojectFromInvertedMatrixToRef","num","UnprojectFromTransform","viewportWidth","viewportHeight","invert","Unproject","view","projection","UnprojectToRef","UnprojectFloatsToRef","sourceX","sourceY","sourceZ","screenSource","RotationFromAxis","axis1","axis2","axis3","rotation","RotationFromAxisToRef","ref","quat","RotationQuaternionFromAxisToRef","toEulerAnglesToRef","Vector4","w","undefined","toVector3","FromVector3","_w","otherQuaternion","q1","conjugateToRef","conjugateInPlace","conjugate","inv","toEulerAngles","qz","qx","qy","qw","sqw","sqz","sqx","sqy","zAxisY","limit","atan2","PI","asin","FromQuaternionToRef","fromRotationMatrix","FromRotationMatrixToRef","FromRotationMatrix","data","m11","m12","m13","m21","m22","m23","m31","m32","m33","trace","AreClose","quat0","quat1","Inverse","q","InverseToRef","Identity","IsIdentity","RotationAxis","angle","RotationAxisToRef","sin","cos","FromEulerAngles","RotationYawPitchRollToRef","FromEulerAnglesToRef","FromEulerVector","vec","FromEulerVectorToRef","yaw","pitch","roll","halfRoll","halfPitch","halfYaw","sinRoll","cosRoll","sinPitch","cosPitch","sinYaw","cosYaw","RotationAlphaBetaGamma","alpha","beta","gamma","RotationAlphaBetaGammaToRef","halfGammaPlusAlpha","halfGammaMinusAlpha","halfBeta","RotationQuaternionFromAxis","rotMat","FromXYZAxesToRef","Slerp","SlerpToRef","num2","num3","num4","flag","num5","num6","_isIdentity","_isIdentityDirty","_isIdentity3x2","_isIdentity3x2Dirty","updateFlag","MatrixTrackPrecisionChange","MatrixTrackedMatrices","push","_m","MatrixCurrentType","_updateIdentityStatus","MatrixUse64Bits","_markAsUpdated","_updateFlagSeed","isIdentity","isIdentityDirty","isIdentity3x2","isIdentity3x2Dirty","isIdentityAs3x2","determinant","m00","m01","m02","m03","m10","m20","m30","det_22_33","det_21_33","det_21_32","det_20_33","det_20_32","det_20_31","invertToRef","reset","resultM","otherM","addToSelf","IdentityToRef","cofact_00","cofact_01","cofact_02","cofact_03","det","detInv","det_12_33","det_11_33","det_11_32","det_10_33","det_10_32","det_10_31","det_12_23","det_11_23","det_11_22","det_10_23","det_10_22","det_10_21","cofact_10","cofact_11","cofact_12","cofact_13","cofact_20","cofact_21","cofact_22","cofact_23","cofact_30","cofact_31","cofact_32","cofact_33","addAtIndex","multiplyAtIndex","setTranslationFromFloats","addTranslationFromFloats","setTranslation","vector3","getTranslation","getTranslationToRef","removeRotationAndScaling","copyToArray","multiplyToArray","tm0","tm1","tm2","tm3","tm4","tm5","tm6","tm7","tm8","tm9","tm10","tm11","tm12","tm13","tm14","tm15","om0","om1","om2","om3","om4","om5","om6","om7","om8","om9","om10","om11","om12","om13","om14","om15","om","decompose","translation","sx","sy","sz","getRow","setRow","row","setRowFromFloats","transpose","Transpose","transposeToRef","TransposeToRef","toNormalMatrix","tmp","getRotationMatrix","getRotationMatrixToRef","toggleModelMatrixHandInPlace","toggleProjectionMatrixHandInPlace","FromFloat32ArrayToRefScaled","_identityReadOnly","initialM11","initialM12","initialM13","initialM14","initialM21","initialM22","initialM23","initialM24","initialM31","initialM32","initialM33","initialM34","initialM41","initialM42","initialM43","initialM44","FromValues","Compose","ComposeToRef","x2","y2","z2","xx","xy","xz","yy","yz","zz","wx","wy","wz","identity","zero","RotationX","RotationXToRef","Invert","RotationY","RotationYToRef","RotationZ","RotationZToRef","c1","RotationAlignToRef","from","to","k","Scaling","ScalingToRef","Translation","TranslationToRef","startValue","endValue","gradient","startM","endM","DecomposeLerp","DecomposeLerpToRef","startScale","startRotation","startTranslation","endScale","endRotation","endTranslation","resultScale","resultRotation","resultTranslation","LookAtLH","eye","target","up","LookAtLHToRef","xAxis","yAxis","zAxis","xSquareLength","ex","ey","ez","LookAtRH","LookAtRHToRef","OrthoLH","znear","zfar","OrthoLHToRef","b","OrthoOffCenterLH","bottom","top","OrthoOffCenterLHToRef","i0","i1","OrthoOffCenterRH","OrthoOffCenterRHToRef","PerspectiveLH","PerspectiveFovLH","fov","aspect","PerspectiveFovLHToRef","isVerticalFovFixed","f","tan","PerspectiveFovReverseLHToRef","PerspectiveFovRH","PerspectiveFovRHToRef","PerspectiveFovReverseRHToRef","PerspectiveFovWebVRToRef","rightHanded","rightHandedFactor","upTan","upDegrees","downTan","downDegrees","leftTan","leftDegrees","rightTan","rightDegrees","xScale","yScale","GetFinalMatrix","zmin","zmax","GetAsMatrix2x2","arr","Float32Array","GetAsMatrix3x3","rm","mm","Reflection","ReflectionToRef","temp","temp2","temp3","xaxis","yaxis","zaxis","zw","zx","yw","xw","BuildArray","TmpVectors","RegisteredTypes","extendStatics","setPrototypeOf","__proto__","__extends","__","constructor","__assign","assign","arguments","apply","__decorate","decorators","desc","getOwnPropertyDescriptor","Reflect","decorate","__spreadArrays","il","j","jl","Buffer","engine","updatable","stride","postponeInternalCreation","instanced","useBytes","divisor","_isAlreadyOwned","getScene","_engine","getEngine","_updatable","_instanced","_divisor","_data","byteStride","BYTES_PER_ELEMENT","createVertexBuffer","kind","byteOffset","VertexBuffer","isUpdatable","getData","getBuffer","_buffer","getStrideSize","updateDynamicVertexBuffer","createDynamicVertexBuffer","_rebuild","update","updateDirectly","vertexCount","_increaseReferences","references","dispose","_releaseBuffer","type","takeBufferOwnership","_ownsBuffer","_kind","data_1","FLOAT","Int8Array","BYTE","Uint8Array","UNSIGNED_BYTE","Int16Array","SHORT","Uint16Array","UNSIGNED_SHORT","Int32Array","INT","Uint32Array","UNSIGNED_INT","typeByteLength","GetTypeByteLength","_size","DeduceStride","_instanceDivisor","getKind","getOffset","getSize","getIsInstanced","getInstanceDivisor","count","callback","ForEach","UVKind","UV2Kind","UV3Kind","UV4Kind","UV5Kind","UV6Kind","NormalKind","PositionKind","ColorKind","MatricesIndicesKind","MatricesIndicesExtraKind","MatricesWeightsKind","MatricesWeightsExtraKind","TangentKind","Error","componentCount","componentType","componentIndex","dataView","ArrayBuffer","DataView","buffer","byteLength","componentByteLength","componentByteOffset","_GetFloatValue","getInt8","getUint8","getInt16","getUint16","getInt32","getUint32","getFloat32","__decoratorInitialStore","__mergedStore","_copySource","creationFunction","instanciate","destination","AddTagsTo","tags","classStore","getMergedStore","propertyDescriptor","sourceProperty","propertyType","isRenderTarget","classKey","store","currentTarget","currentKey","initialStore","parent_1","done","getPrototypeOf","generateSerializableMember","sourceName","propertyKey","getDirectStore","expandToProperty","targetKey","setCallback","generateExpandMember","serialize","serializeAsTexture","serializeAsColor3","serializeAsFresnelParameters","serializeAsVector3","serializeAsMeshReference","serializeAsColorCurves","serializeAsColor4","serializeAsQuaternion","SerializationHelper","AppendSerializedAnimations","animations","animationIndex","animation","Serialize","entity","serializationObject","GetTags","serializedProperties","targetPropertyName","id","Parse","scene","rootUrl","dest","_TextureParser","_FresnelParametersParser","getLastMeshByID","_ColorCurvesParser","_ImageProcessingConfigurationParser","getCameraByID","Clone","Instanciate","WarnImport","EventState","mask","skipNextObservers","initalize","Observer","scope","_willBeUnregistered","unregisterOnNextCall","Observable","MultiObserver","_observers","_observables","remove","Watch","observables","_i","observables_1","observer","onObserverAdded","_eventState","_onObserverAdded","insertFirst","unregisterOnFirstCall","unshift","addOnce","indexOf","_deferUnregister","removeCallback","setTimeout","_remove","splice","makeObserverTopPriority","makeObserverBottomPriority","notifyObservers","eventData","userInfo","state","lastReturnValue","_a","obs","notifyObserversWithPromise","Promise","resolve","then","lastReturnedValue","notifyObserver","hasObservers","clear","slice","hasSpecificMask","Effect","baseName","attributesNamesOrOptions","uniformsNamesOrEngine","samplers","defines","fallbacks","onCompiled","onError","indexParameters","onBind","uniqueId","onCompileObservable","onErrorObservable","_onBindObservable","_wasPreviouslyReady","_bonesComputationForcedToCPU","_multiTarget","_uniformBuffersNames","_samplers","_isReady","_compilationError","_allFallbacksProcessed","_uniforms","_key","_fallbacks","_vertexSourceCode","_fragmentSourceCode","_vertexSourceCodeOverride","_fragmentSourceCodeOverride","_transformFeedbackVaryings","_rawVertexSourceCode","_rawFragmentSourceCode","_pipelineContext","_valueCache","vertexSource","fragmentSource","processFinalCode","attributes","options","_attributesNames","_uniformsNames","uniformsNames","concat","_samplerList","_indexParameters","transformFeedbackVaryings","multiTarget","uniformBuffersNames","_uniformBuffersNamesList","_attributeLocationByName","_uniqueIdSeed","hostDocument","IsWindowObjectExist","getHostDocument","vertexElement","getElementById","vertex","fragmentElement","fragment","processorOptions","split","isFragment","shouldUseHighPrecisionShader","_shouldUseHighPrecisionShader","processor","_shaderProcessor","supportsUniformBuffers","shadersRepository","ShadersRepository","includesShadersStore","IncludesShadersStore","version","webGLVersion","platformName","_loadShader","vertexCode","fragmentCode","Process","migratedVertexCode","migratedFragmentCode","_useFinalCode","spectorName","_prepareEffect","isReady","_isReadyInternal","getPipelineContext","getAttributesNames","getAttributeLocation","_attributes","getAttributeLocationByName","getAttributesCount","getUniformIndex","uniformName","getUniform","getSamplers","getUniformNames","getUniformBuffersNames","getIndexParameters","getCompilationError","allFallbacksProcessed","executeWhenCompiled","func","effect","isAsync","_checkIsReady","previousPipelineContext","e","_processCompilationErrors","shader","optionalKey","shaderUrl","HTMLElement","GetDOMTextContent","substr","ShadersStore","_loadFile","window","atob","_rebuildProgram","vertexSourceCode","fragmentSourceCode","error","scenes","markAllMaterialsAsDirty","_handlesSpectorRebuildCallback","attributesNames","engine_1","createPipelineContext","rebuildRebind","_preparePipelineContext","_executeWhenRenderingStateIsCompiled","bindUniformBlock","getUniforms","uniform","getAttributes","name_1","bindSamplers","unBindMesh","_deletePipelineContext","_getShaderCodeAndErrorLine","code","regexp","errorLine","res","match","lineNumber","parseInt","lines","_b","_c","_d","_e","message","map","attribute","LogShaderCodeOnCompilationError","lineErrorVertex","lineErrorFragment","_getVertexShaderCode","_getFragmentShaderCode","hasMoreFallbacks","reduce","_bindTexture","channel","texture","setTexture","setDepthStencilTexture","setTextureArray","textures","exName","initialPos","currentExName","channelIndex","setTextureFromPostProcess","postProcess","setTextureFromPostProcessOutput","_cacheMatrix","cache","_cacheFloat2","changed","_cacheFloat3","_cacheFloat4","bindUniformBuffer","bufferName","_baseCache","bindUniformBufferBase","blockName","setInt","setIntArray","setIntArray2","setIntArray3","setIntArray4","setFloatArray","setArray","setFloatArray2","setArray2","setFloatArray3","setArray3","setFloatArray4","setArray4","setMatrices","matrices","setMatrix","setMatrix3x3","setMatrix2x2","setFloat","setBool","bool","setVector2","vector2","setFloat2","setVector3","setFloat3","setVector4","vector4","setFloat4","setColor3","color3","g","setColor4","setDirectColor4","color4","_releaseEffect","RegisterShader","pixelShader","vertexShader","ResetCache","_super","Vector2WithInfo","buttonIndex","Matrix2D","fromValues","l0","l1","l3","l4","l5","detDiv","det4","det5","r0","r1","r2","r3","r4","r5","transformCoordinates","RotationToRef","tx","ty","scaleX","scaleY","parentMatrix","_TempPreTranslationMatrix","_TempScalingMatrix","_TempRotationMatrix","_TempPostTranslationMatrix","_TempCompose0","_TempCompose1","_TempCompose2","Control","_alpha","_alphaSet","_zIndex","_currentMeasure","Empty","_fontFamily","_fontStyle","_fontWeight","_fontSize","UNITMODE_PIXEL","_width","UNITMODE_PERCENTAGE","_height","_color","_style","_horizontalAlignment","HORIZONTAL_ALIGNMENT_CENTER","_verticalAlignment","VERTICAL_ALIGNMENT_CENTER","_wasDirty","_tempParentMeasure","_prevCurrentMeasureTransformedIntoGlobalSpace","_cachedParentMeasure","_paddingLeft","_paddingRight","_paddingTop","_paddingBottom","_left","_top","_scaleX","_scaleY","_rotation","_transformCenterX","_transformCenterY","_transformMatrix","_invertTransformMatrix","_transformedPosition","_isMatrixDirty","_isVisible","_isHighlighted","_fontSet","_dummyVector2","_downCount","_enterCount","_doNotRender","_downPointerIds","_isEnabled","_disabledColor","_disabledColorItem","_rebuildLayout","_customData","_isClipped","_automaticSize","metadata","isHitTestVisible","isPointerBlocker","isFocusInvisible","clipChildren","clipContent","useBitmapCache","_shadowOffsetX","_shadowOffsetY","_shadowBlur","_shadowColor","hoverCursor","_linkOffsetX","_linkOffsetY","onWheelObservable","onPointerMoveObservable","onPointerOutObservable","onPointerDownObservable","onPointerUpObservable","onPointerClickObservable","onPointerEnterObservable","onDirtyObservable","onBeforeDrawObservable","onAfterDrawObservable","onDisposeObservable","fixedRatio","_fixedRatioMasterIsWidth","_tmpMeasureA","_markAsDirty","_getTypeName","_host","_fontOffset","_markMatrixAsDirty","fromString","getValueInPixel","isNaN","_resetFontCache","onChangedObservable","_styleObserver","isPercentage","fontSizeToUse","isPixel","getValue","fontSize","zIndex","parent","_reOrderControl","_linkedMesh","paddingLeft","paddingRight","paddingTop","paddingBottom","linkOffsetX","linkOffsetY","getAscendantOfClass","className","isAscendant","container","getLocalCoordinates","globalCoordinates","getLocalCoordinatesToRef","getParentLocalCoordinates","moveToVector3","position","_rootContainer","horizontalAlignment","HORIZONTAL_ALIGNMENT_LEFT","verticalAlignment","VERTICAL_ALIGNMENT_TOP","globalViewport","_getGlobalViewport","projectedPosition","getTransformMatrix","_moveToProjectedPosition","notRenderable","getDescendantsToRef","results","directDescendantsOnly","predicate","getDescendants","linkWithMesh","mesh","_linkedControls","oldLeft","oldTop","newLeft","newTop","ignoreAdaptiveScaling","_offsetLeft","_offsetTop","_flagDescendantsAsMatrixDirty","_intersectsRect","rect","transformToRef","invalidateRect","_transform","host","useInvalidateRectOptimization","CombineToRef","shadowBlur","shadowOffsetX","shadowOffsetY","leftShadowOffset","rightShadowOffset","topShadowOffset","bottomShadowOffset","ceil","force","markAsDirty","_markAllAsDirty","_font","_prepareFont","_link","getUniqueId","context","offsetX","offsetY","translate","rotate","_cachedOffsetX","_cachedOffsetY","_renderHighlight","isHighlighted","save","strokeStyle","lineWidth","_renderHighlightSpecific","restore","strokeRect","_applyStates","_isFontSizeInPercentage","font","fillStyle","AllowAlphaInheritance","globalAlpha","_layout","parentMeasure","isDirty","isVisible","isEqualsTo","_numLayoutCalls","addAndTransformToRef","paddingLeftInPixels","paddingTopInPixels","paddingRightInPixels","paddingBottomInPixels","rebuildCount","_processMeasures","_evaluateClippingState","_preMeasure","_measure","_computeAlignment","_additionalProcessing","parentWidth","parentHeight","HORIZONTAL_ALIGNMENT_RIGHT","VERTICAL_ALIGNMENT_BOTTOM","_clipForChildren","_clip","invalidatedRectangle","beginPath","_ClipMeasure","intersection","clip","_render","_numRenderCalls","_cacheData","putImageData","_draw","getImageData","contains","_shouldBlockPointer","_processPicking","pi","pointerId","deltaX","deltaY","_processObservables","_onPointerMove","coordinates","_onPointerEnter","_onPointerOut","canNotify","_onPointerDown","_onPointerUp","notifyClick","canNotifyClick","_forcePointerUp","_onWheelScroll","_onCanvasBlur","POINTERMOVE","previousControlOver","_lastControlOver","POINTERDOWN","_registerLastControlDown","_lastPickedControl","POINTERUP","_lastControlDown","POINTERWHEEL","fontStyle","fontWeight","fontSizeInPixels","fontFamily","_GetFontOffset","removeControl","_HORIZONTAL_ALIGNMENT_LEFT","_HORIZONTAL_ALIGNMENT_RIGHT","_HORIZONTAL_ALIGNMENT_CENTER","_VERTICAL_ALIGNMENT_TOP","_VERTICAL_ALIGNMENT_BOTTOM","_VERTICAL_ALIGNMENT_CENTER","_FontHeightSizes","text","document","createElement","innerHTML","style","block","display","verticalAlign","div","whiteSpace","appendChild","body","fontAscent","fontHeight","getBoundingClientRect","removeChild","ascent","descent","drawEllipse","arc","closePath","AddHeader","Color3","toColor4","Color4","toLuminance","otherColor","equalsFloats","clampToRef","toHexString","intR","intG","intB","ToHex","toLinearSpace","convertedColor","toLinearSpaceToRef","toHSV","toHSVToRef","h","dm","pow","toGammaSpace","toGammaSpaceToRef","HSVtoRGBToRef","hue","saturation","chroma","FromHexString","hex","substring","FromInts","Red","Green","Blue","Black","_BlackReadOnly","White","Purple","Magenta","Yellow","Gray","Teal","Random","random","color","returnAsColor3","intA","FromColor3","CheckColors4","colors","colors4","newIndex","TmpColors","_DevTools","_TypeStore","GetClass","fqdn","PointerEventTypes","POINTERPICK","POINTERTAP","POINTERDOUBLETAP","PointerInfoBase","event","PointerInfoPre","localX","localY","ray","skipOnPointerObservable","localPosition","PointerInfo","pickInfo","Logger","_AddLogEntry","entry","_LogCache","OnNewCacheEntry","_FormatMessage","padStr","date","Date","getHours","getMinutes","getSeconds","_LogDisabled","_LogEnabled","formattedMessage","console","log","_WarnDisabled","_WarnEnabled","warn","_ErrorDisabled","_ErrorEnabled","errorsCount","ClearLogCache","level","MessageLogLevel","Log","WarningLogLevel","Warn","ErrorLogLevel","NoneLogLevel","AllLogLevel","PromiseStates","FulFillmentAgregator","InternalPromise","resolver","_state","Pending","_children","_rejectWasConsumed","_resolve","reason","_reject","_resultValue","_parent","_result","catch","onRejected","onFulfilled","newPromise","_onFulfilled","_onRejected","Fulfilled","returnedValue","returnedPromise","_reason","_moveChildren","children","child","Rejected","onLocalThrow","_RegisterForFulfillment","promise","agregator","rootPromise","all","promises","race","promises_1","PromisePolyfill","Apply","Tools","BaseUrl","DefaultRetryStrategy","strategy","CorsBehavior","UseFallbackTexture","RegisteredExternalClasses","classes","FallbackTexture","FetchToRef","u","pixels","Mix","Instantiate","Slice","SliceToArray","isArray","SetImmediate","action","IsExponentOfTwo","FloatRound","fround","_tmpFloatArray","GetFilename","path","lastIndexOf","GetFolderPath","uri","returnUnchangedIfNoSlash","ToDegrees","ToRadians","MakeArray","obj","allowsNullUndefined","GetPointerPrefix","eventPrefix","PointerEvent","IsNavigatorAvailable","navigator","pointerEnabled","_badDesktopOS","_badOS","SetCorsBehavior","url","element","CleanUrl","replace","PreprocessUrl","LoadImage","input","onLoad","offlineProvider","mimeType","LoadFile","onSuccess","onProgress","useArrayBuffer","LoadFileAsync","reject","request","exception","LoadScript","scriptUrl","scriptId","head","getElementsByTagName","script","setAttribute","onload","onerror","LoadScriptAsync","ReadFileAsDataURL","fileToLoad","progressCallback","reader","FileReader","onCompleteObservable","abort","onloadend","onprogress","readAsDataURL","ReadFile","file","FileAsURL","content","fileBlob","Blob","URL","webkitURL","createObjectURL","Format","decimals","toFixed","DeepCopy","doNotCopyList","mustCopyList","IsEmpty","RegisterTopRootEvents","windowElement","events","addEventListener","handler","UnregisterTopRootEvents","removeEventListener","DumpFramebuffer","successCallback","fileName","numberOfChannelsByLine","halfHeight","readPixels","currentCell","targetCell","_ScreenshotCanvas","getContext","imageData","createImageData","EncodeScreenshotCanvasData","ToBlob","canvas","toBlob","quality","binStr","toDataURL","charCodeAt","blob","stringDate","getFullYear","getMonth","getDate","Download","newWindow","open","img","revokeObjectURL","src","msSaveBlob","href","download","parentElement","click","BackCompatCameraNoPreventDefault","args","CreateScreenshot","camera","CreateScreenshotAsync","CreateScreenshotUsingRenderTarget","samples","antialiasing","CreateScreenshotUsingRenderTargetAsync","RandomId","IsBase64","DecodeBase64","decodedString","bufferLength","bufferView","GetAbsoluteUrl","LogCache","LogLevels","PerformanceUserMarkLogLevel","StartPerformanceCounter","_StartUserMark","EndPerformanceCounter","_EndUserMark","PerformanceConsoleLogLevel","_StartPerformanceConsole","_EndPerformanceConsole","_StartPerformanceCounterDisabled","_EndPerformanceCounterDisabled","counterName","condition","_performance","performance","mark","measure","time","timeEnd","Now","GetClassName","isType","First","array_1","el","getFullClassName","moduleName","classObj","DelayAsync","delay","IsSafari","test","userAgent","UseCustomRequestHeaders","CustomRequestHeaders","PerformanceNoneLogLevel","AsyncLoop","iterations","_done","_fn","_successCallback","executeNext","breakLoop","Run","fn","loop","SyncAsyncForLoop","syncedIterations","breakFunction","timeout","iteration","SceneLoaderFlags","_ForceFullSceneLoadingForIncremental","_ShowLoadingScreen","_loggingLevel","_CleanBoneMatrixWeights","Geometry","vertexData","delayLoadState","_totalVertices","_isDisposed","_indexBufferIsUpdatable","_positionsCache","useBoundingInfoFromGeometry","_meshes","_scene","_vertexBuffers","_indices","setAllVerticesData","getCaps","vertexArrayObject","_vertexArrayObjects","applyToMesh","computeWorldMatrix","_boundingBias","_updateBoundingInfo","CreateGeometryForMesh","geometry","_extend","doNotSerialize","_indexBuffer","createIndexBuffer","applyToGeometry","notifyUpdate","setVerticesData","setVerticesBuffer","removeVerticesData","totalVertices","_updateExtend","_resetPointsArrayCache","meshes","numOfMeshes","_boundingInfo","minimum","maximum","_createGlobalSubMesh","_disposeVertexArrayObjects","updateVerticesDataDirectly","vertexBuffer","getVertexBuffer","updateVerticesData","updateExtends","meshes_1","reConstruct","subMeshes_1","subMeshes","refreshBoundingInfo","_bind","indexToBind","vbs","getVertexBuffers","recordVertexArrayObject","bindVertexArrayObject","bindBuffers","getTotalVertices","getVerticesData","copyWhenShared","forceCopy","tightlyPackedByteStride","copy_1","remainder","isVertexBufferUpdatable","vb","isVerticesDataPresent","_delayInfo","getVerticesDataKinds","updateIndices","indices","gpuMemoryOnly","needToUpdateSubMeshes","updateDynamicIndexBuffer","setIndices","getTotalIndices","getIndices","orig","copy","getIndexBuffer","_releaseVertexArrayObject","releaseVertexArrayObject","releaseForMesh","shouldDispose","_geometry","previousGeometry","pushGeometry","_applyToMesh","boundingBias","_syncGeometryWithMorphTargetManager","synchronizeInstances","onGeometryUpdated","_markSubMeshesAsAttributesDirty","load","onLoaded","_queueLoad","delayLoadingFile","_addPendingData","_delayLoadingFunction","JSON","parse","_removePendingData","toLeftHanded","tIndices","tTemp","tPositions","tNormals","_positions","_generatePointsArray","arrayIdx","isDisposed","removeGeometry","stopChecking","HasTags","toNumberArray","serializeVerticeData","positions","normals","tangets","uvs","uv2s","uv3s","uv4s","uv5s","uv6s","matricesIndices","_isExpanded","matricesWeights","ExtractFromMesh","_ImportGeometry","parsedGeometry","geometryId","getGeometryByID","binaryInfo","_binaryInfo","positionsAttrDesc","positionsData","normalsAttrDesc","normalsData","tangetsAttrDesc","tangentsData","uvsAttrDesc","uvsData","uvs2AttrDesc","uvs2Data","uvs3AttrDesc","uvs3Data","uvs4AttrDesc","uvs4Data","uvs5AttrDesc","uvs5Data","uvs6AttrDesc","uvs6Data","colorsAttrDesc","colorsData","matricesIndicesAttrDesc","matricesIndicesData","floatIndices","matricesIndicesExtraAttrDesc","matricesWeightsAttrDesc","matricesWeightsData","indicesAttrDesc","indicesData","subMeshesAttrDesc","subMeshesData","materialIndex","verticesStart","verticesCount","indexStart","indexCount","AddToMesh","tangents","uvs2","uvs3","uvs4","uvs5","uvs6","matricesIndex","matricesIndicesExtra","_CleanMatricesWeights","matricesWeightsExtra","subIndex","parsedSubMesh","_shouldGenerateFlatShading","convertToFlatShadedMesh","onMeshImportedObservable","CleanBoneMatrixWeights","noInfluenceBoneIndex","skeletonId","skeleton","getLastSkeletonByID","bones","influencers","numBoneInfluencer","weight","firstZeroWeight","mweight","parsedVertexData","boundingBoxMinimum","boundingBoxMaximum","hasUVs","hasUVs2","hasUVs3","hasUVs4","hasUVs5","hasUVs6","hasColors","hasMatricesIndices","hasMatricesWeights","ImportVertexData","MultiMaterial","multiMaterials","subMaterials","_storeEffectOnSubMeshes","_subMaterials","_hookArray","getChildren","oldPush","items","_markAllSubMeshesAsTexturesDirty","oldSplice","deleteCount","deleted","getSubMaterial","defaultMaterial","getActiveTextures","subMaterial","hasTexture","isReadyForSubMesh","subMesh","useInstances","cloneChildren","newMultiMaterial","current","materials","matIndex","subMat","forceDisposeEffect","forceDisposeTextures","forceDisposeChildren","ParseMultiMaterial","parsedMultiMaterial","multiMaterial","subMatId","getLastMaterialByID","MeshLODLevel","distance","_CreationDataStorage","_InstanceDataStorage","visibleInstances","batchCache","_InstancesBatch","instancesBufferSize","mustReturn","renderSelf","hardwareInstancedRendering","_ThinInstanceDataStorage","instancesCount","matrixBuffer","matrixBufferSize","boundingVectors","worldMatrices","_InternalMeshDataInfo","_areNormalsFrozen","_source","meshMap","_preActivateId","_LODLevels","_morphTargetManager","Mesh","doNotCloneChildren","clonePhysicsImpostor","_internalMeshDataInfo","instances","_creationDataStorage","_instanceDataStorage","_thinInstanceDataStorage","_effectiveMaterial","_originalBuilderSideOrientation","DEFAULTSIDE","overrideMaterialSideOrientation","useClonedMeshMap","_ranges","ranges","createAnimationRange","setEnabled","isEnabled","setPivotMatrix","getPivotMatrix","material","directDescendants","index_1","morphTargetManager","getPhysicsEngine","physicsEngine","impostor","getImpostorForPhysicsObject","physicsImpostor","particleSystems","system","emitter","instancedArrays","_GetDefaultSideOrientation","orientation","FRONTSIDE","_internalAbstractMeshDataInfo","_computeBonesUsingShaders","_sourcePositions","_sourceNormals","_onBeforeRenderObservable","_onBeforeBindObservable","_onAfterRenderObservable","_onBeforeDrawObservable","_onBeforeDrawObserver","_unIndexed","instancesData","manualUpdate","instantiateHierarchy","newParent","onNewNodeCreated","instance","doNotInstantiate","createInstance","scaling","rotationQuaternion","getChildTransformNodes","fullDetails","ret","_waitingParentId","ib","_unBindEffect","getLODLevels","_sortLODLevels","sort","addLODLevel","_masterMesh","getLODLevelAtDistance","internalDataInfo","removeLODLevel","getLOD","boundingSphere","bSphere","getBoundingInfo","distanceToCamera","centerWorld","globalPosition","onLODLevelSelection","_checkDelayState","_preActivate","_updateSubMeshesBoundingInfo","worldMatrixFromCache","completeCheck","forceInstanceSupport","_f","hasThinInstances","mat","_g","effectiveMaterial","getMaterial","_h","_j","lightSources","generator","getShadowGenerator","getShadowMap","renderList","_k","_l","needAlphaBlendingForMesh","_o","lod","freezeNormals","unfreezeNormals","overridenInstanceCount","sceneRenderId","getRenderId","_preActivateForIntermediateRendering","renderId","intermediateDefaultRenderId","_registerInstanceForRenderId","defaultRenderId","selfDefaultRenderId","_renderId","previousRenderId","isFrozen","_afterComputeWorldMatrix","doNotSyncBoundingInfo","thinInstanceRefreshBoundingInfo","_postActivate","edgesShareWithInstances","edgesRenderer","_renderingGroup","_edgesRenderers","pushNoDuplicate","customInstances","getWorldMatrix","applySkeleton","isLocked","bias","_refreshBoundingInfo","_getPositionData","totalIndices","needToRecreate","submesh","releaseSubMeshes","subdivide","subdivisionSize","CreateFromIndices","markVerticesDataAsUpdatable","makeItUnique","makeGeometryUnique","updateMeshPositions","positionFunction","computeNormals","ComputeNormals","oldGeometry","fillMode","PointFillMode","WireFrameFillMode","_getLinesIndexBuffer","TriangleFillMode","drawArraysType","drawElementsType","_linesIndexCount","registerBeforeRender","onBeforeRenderObservable","unregisterBeforeRender","registerAfterRender","onAfterRenderObservable","unregisterAfterRender","_getInstancesRenderList","subMeshId","isReplacementMode","previousBatch","isInIntermediateRendering","_isInIntermediateRendering","onlyForInstances","_onlyForInstancesIntermediate","_onlyForInstances","currentRenderId","_renderWithInstances","batch","_id","instanceStorage","currentInstancesBufferSize","instancesBuffer","bufferSize","needUpdateBuffer","_effectiveMesh","instanceIndex","_processInstancedBuffers","_activeIndices","addCount","unbindInstanceAttributes","_renderWithThinInstances","_processRendering","renderingMesh","onBeforeDraw","getRenderingMesh","instanceCount","visibleInstancesForSubMesh","visibleInstanceCount","_freeze","_unFreeze","render","enableAlphaMode","effectiveMeshReplacement","_isActiveIntermediate","_isActive","_checkOcclusionQuery","instanceDataStorage","setAlphaMode","alphaMode","getEffect","_beforeRenderingMeshStage","sideOrientation","effectiveMesh","backFaceCulling","mainDeterminant","_getWorldMatrixDeterminant","ClockWiseSideOrientation","CounterClockWiseSideOrientation","reverse","_preBind","forceDepthWrite","setDepthWrite","forcePointsCloud","forceWireframe","bindForSubMesh","separateCullingPass","setState","zOffset","_onBeforeDraw","unbind","_afterRenderingMeshStage","isInstance","bindOnlyWorldMatrix","cleanMatrixWeights","normalizeSkinWeightsAndExtra","normalizeSkinFourWeights","numWeights","recip","validateSkinning","skinned","valid","report","numberNotSorted","missingWeights","maxUsedWeights","numberNotNormalized","numInfluences","usedWeightCounts","lastWeight","usedWeights","tolerance","numBones","numBadBoneIndices","getBinaryData","_syncSubMeshes","isInFrustum","frustumPlanes","setMaterialByID","getAnimatables","bakeTransformIntoVertices","submeshes","flipFaces","bakeCurrentTransformIntoVertices","bakeIndependenlyOfChildren","resetLocalMatrix","doNotRecurse","disposeMaterialAndTextures","_disposeInstanceSpecificData","_disposeThinInstanceSpecificData","applyDisplacementMap","minHeight","maxHeight","uvOffset","uvScale","forceUpdate","heightMapWidth","heightMapHeight","CreateCanvas","drawImage","applyDisplacementMapFromBuffer","uv","pos","kindIndex","kinds","newdata","updatableNormals","previousSubmeshes","vertexIndex","p3","p1p2","p3p2","localIndex","submeshIndex","previousOne","convertToUnIndexedMesh","flipNormals","vertex_data","increaseVertices","numberPerEdge","currentIndices","segments","tempIndices","deltaPosition","deltaNormal","deltaUV","side","positionPtr","uvPtr","idx","forceSharedVertices","currentUVs","currentPositions","currentColors","ptr","facet","pstring","indexPtr","uniquePositions","_instancedMeshFactory","_PhysicsImpostorParser","physicObject","jsonObject","others_1","optimizeIndices","vectorPositions","dupes","realPos","testedPosition","againstPosition","originalSubMeshes","_postMultiplyPivotMatrix","pivotMatrix","localMatrix","infiniteDistance","pickable","isPickable","receiveShadows","billboardMode","visibility","checkCollisions","isBlocker","parentId","isUnIndexed","materialId","morphTargetManagerId","numBoneInfluencers","_getComponent","NAME_PHYSICSENGINE","getPhysicsImpostor","physicsMass","getParam","physicsFriction","physicsRestitution","serializationInstance","serializeAnimationRanges","matrixData","thinInstances","_userThinInstanceBuffersStorage","userThinInstance","sizes","strides","layerMask","alphaIndex","hasVertexAlpha","overlayAlpha","overlayColor","renderOverlay","applyFog","actionManager","actions","numInfluencers","morphTarget","getActiveTarget","getPositions","getNormals","getTangents","getUVs","parsedMesh","_GroundMeshParser","setPreTransformMatrix","showBoundingBox","showSubMeshesBoundingBox","useFlatShading","freezeWorldMatrix","_waitingData","ForceFullSceneLoadingForIncremental","getMorphTargetManagerById","parsedAnimation","internalClass","ParseAnimationRanges","autoAnimate","beginAnimation","autoAnimateFrom","autoAnimateTo","autoAnimateLoop","autoAnimateSpeed","lodMeshIds","lods","ids","distances","lodDistances","coverages","lodCoverages","parsedInstance","thinInstanceSetBuffer","CreateRibbon","pathArray","closeArray","CreateDisc","radius","tessellation","CreateBox","CreateSphere","diameter","CreateHemisphere","CreateCylinder","diameterTop","diameterBottom","subdivisions","CreateTorus","thickness","CreateTorusKnot","tube","radialSegments","tubularSegments","CreateLines","points","CreateDashedLines","dashSize","gapSize","dashNb","CreatePolygon","shape","holes","earcutInjection","earcut","ExtrudePolygon","depth","ExtrudeShape","cap","ExtrudeShapeCustom","scaleFunction","rotationFunction","ribbonCloseArray","ribbonClosePath","CreateLathe","CreatePlane","CreateGround","CreateTiledGround","xmin","xmax","precision","CreateGroundFromHeightMap","onReady","alphaFilter","CreateTube","radiusFunction","CreatePolyhedron","CreateIcoSphere","CreateDecal","sourceMesh","CreateCapsule","setPositionsForCPUSkinning","setNormalsForCPUSkinning","_softwareSkinningFrameId","getFrameId","hasNormals","inf","needExtras","matricesIndicesExtraData","matricesWeightsExtraData","skeletonMatrices","getTransformMatrices","tempVector3","finalMatrix","tempMatrix","matWeightIdx","MinMax","minVector","maxVector","boundingBox","minimumWorld","maximumWorld","meshesOrMinMaxVector","minMaxVector","MergeMeshes","disposeSource","allow32BitsIndices","meshSubclass","subdivideWithSubMeshes","multiMultiMaterials","otherVertexData","materialArray","materialIndexArray","indiceArray","isAnInstance","wm","merge","addInstance","_indexInSourceMeshInstanceArray","removeInstance","last","pop","BACKSIDE","DOUBLESIDE","NO_CAP","CAP_START","CAP_END","CAP_ALL","NO_FLIP","FLIP_TILE","ROTATE_TILE","FLIP_ROW","ROTATE_ROW","FLIP_N_ROTATE_TILE","FLIP_N_ROTATE_ROW","CENTER","LEFT","RIGHT","TOP","BOTTOM","VertexData","_applyTo","updateMesh","_update","updateGeometry","meshOrGeometry","flip","transformed","tangent","tangentTransformed","use32BitsIndices","_validate","decal","_mergeElement","isSrcTypedArray","isOthTypedArray","ret32","getElementCount","values","positionsElementCount","validateElementCount","elementCount","_ExtractFrom","ExtractFromGeometry","CreateTiledBox","CreateTiledPlane","CreateLineSystem","polygon","fUV","fColors","frontUVs","backUVs","wrap","capSubdivisions","p1p2x","p1p2y","p1p2z","p3p2x","p3p2y","p3p2z","faceNormalx","faceNormaly","faceNormalz","v1x","v1y","v1z","v2x","v2y","v2z","v3x","v3y","v3z","computeFacetNormals","computeFacetPositions","computeFacetPartitioning","computeDepthSort","faceNormalSign","ratio","distanceTo","useRightHandedSystem","depthSortedFacets","xSubRatio","ySubRatio","zSubRatio","subSq","bbSize","ox","oy","oz","b1x","b1y","b1z","b2x","b2y","b2z","b3x","b3y","b3z","block_idx_o","block_idx_v1","block_idx_v2","block_idx_v3","bbSizeMax","subDiv","X","Y","Z","facetPartitioning","nbFaces","facetNormals","facetPositions","bInfo","dsf","ind","sqDistance","_ComputeSides","li","ln","lp","lu","ValueAndUnit","unit","negativeValueAllowed","_value","_originalUnit","refValue","updateInPlace","idealWidth","idealHeight","useSmallestIdeal","innerWidth","innerHeight","percentage","_Regex","exec","sourceValue","parseFloat","sourceUnit","_UNITMODE_PERCENTAGE","_UNITMODE_PIXEL","ToGammaSpace","ToLinearSpace","Epsilon","Scalar","str","toUpperCase","Sign","Log2","LOG2E","Repeat","Denormalize","DeltaAngle","PingPong","SmoothStep","MoveTowards","maxDelta","MoveTowardsAngle","LerpAngle","InverseLerp","RandomRange","RangeToPercent","number","PercentToRange","percent","NormalizeRadians","TwoPi","ThinMaterialHelper","BindClipPlane","holder","clipPlane","clipPlane2","clipPlane3","clipPlane4","clipPlane5","clipPlane6","MaterialHelper","BindEyePosition","variableName","_forcedViewPosition","activeCamera","devicePosition","_mirroredCameraPosition","PrepareDefinesForMergedUV","_needUVs","getTextureMatrix","coordinatesIndex","BindTextureMatrix","uniformBuffer","updateMatrix","GetFogState","fogEnabled","fogMode","FOGMODE_NONE","PrepareDefinesForMisc","useLogarithmicDepth","pointsCloud","alphaTest","_areMiscDirty","nonUniformScaling","PrepareDefinesForFrameBoundValues","useClipPlane","useThinInstances","useClipPlane1","useClipPlane2","useClipPlane3","useClipPlane4","useClipPlane5","useClipPlane6","getColorWrite","markAsUnprocessed","PrepareDefinesForBones","useBones","computeBonesUsingShaders","materialSupportsBoneTexture","isUsingTextureForMatrices","prePassRenderer","enabled","nonExcluded","excludedSkinnedMesh","PrepareDefinesForMorphTargets","manager","supportsUVs","supportsTangents","supportsNormals","PrepareDefinesForAttributes","useVertexColor","useMorphTargets","useVertexAlpha","_areAttributesDirty","_needNormals","_normals","_uvs","hasVertexColors","useVertexColors","PrepareDefinesForMultiview","previousMultiview","MULTIVIEW","outputRenderTarget","getViewCount","PrepareDefinesForPrePass","canRenderToMRT","previousPrePass","PREPASS","_arePrePassDirty","texturesList","define","SCENE_MRT_COUNT","mrtCount","getIndex","markAsImageProcessingDirty","PrepareDefinesForLight","light","lightIndex","specularSupported","needNormals","needRebuild","prepareLightSpecificDefines","falloffType","FALLOFF_GLTF","FALLOFF_PHYSICAL","FALLOFF_STANDARD","specular","specularEnabled","shadowsEnabled","shadowEnabled","shadowGenerator","shadowMap","prepareDefines","lightmapMode","LIGHTMAP_DEFAULT","LIGHTMAP_SHADOWSONLY","PrepareDefinesForLights","maxSimultaneousLights","disableLighting","_areLightsDirty","lightsEnabled","caps","textureFloatRender","textureFloatLinearFiltering","textureHalfFloatRender","textureHalfFloatLinearFiltering","rebuild","PrepareUniformsAndSamplersForLight","uniformsList","samplersList","projectedLightTexture","uniformBuffersList","updateOnlyBuffersList","PrepareUniformsAndSamplersList","uniformsListOrOptions","HandleFallbacksForShadows","rank","lightFallbackRank","addFallback","PrepareAttributesForMorphTargetsInfluencers","attribs","_TmpMorphInfluencers","NUM_MORPH_INFLUENCERS","PrepareAttributesForMorphTargets","LastCreatedEngine","maxAttributesCount","maxVertexAttribs","PrepareAttributesForBones","addCPUSkinningFallback","PrepareAttributesForInstances","PushAttributesForInstances","BindLightProperties","transferToEffect","BindLight","useSpecular","rebuildInParallel","_bindLight","BindLights","BindFogParameters","linearSpace","fogStart","fogEnd","fogDensity","fogColor","_tempFogColor","BindBonesParameters","prePassConfiguration","boneTexture","getTransformMatrixTexture","previousBones","_CopyBonesTransformationMatrices","BindMorphTargetParameters","abstractMesh","influences","BindLogDepth","maxZ","LN2","BaseTexture","sceneOrEngine","reservedDataStore","_hasAlpha","getAlphaFromRGB","_coordinatesMode","wrapR","anisotropicFilteringLevel","DEFAULT_ANISOTROPIC_FILTERING_LEVEL","_isCube","_gammaSpace","invertZ","lodLevelInAlpha","_prefiltered","_onDisposeObserver","_texture","_uid","_isScene","LastCreatedScene","addTexture","_wrapU","_wrapV","isCube","is3D","is2DArray","_isRGBD","_lodGenerationOffset","_lodGenerationScale","_linearSpecularLOD","_irradianceTexture","_getEngine","checkTransformsAreIdentical","IdentityReadOnly","getReflectionTextureMatrix","isReadyOrNotBlocking","isBlocking","_getFromCache","noMipmap","sampling","invertY","texturesCache","getLoadedTexturesCache","texturesCacheEntry","generateMipMaps","samplingMode","incrementReferences","format","faceIndex","round","_readTexturePixels","_lodTextureHigh","_lodTextureMid","_lodTextureLow","stopAnimation","onTextureRemovedObservable","WhenAllReady","numRemaining","onLoadObservable","ThinTexture","internalTexture","_cachedSize","_cachedBaseSize","delayLoad","getInternalTexture","getBaseSize","baseWidth","baseHeight","updateSamplingMode","updateTextureSamplingMode","releaseInternalTexture","CopyTools","GenerateBase64StringFromTexture","npixels","ctx","canvas2","ctx2","Texture","deleteBuffer","loaderOptions","TRILINEAR_SAMPLINGMODE","uOffset","vOffset","uScale","vScale","uAng","vAng","wAng","uRotationCenter","vRotationCenter","wRotationCenter","homogeneousRotationInUVTransform","inspectableCustomProperties","_noMipmap","_invertY","_rowGenerationMatrix","_cachedTextureMatrix","_projectionModeMatrix","_t0","_t1","_t2","_cachedUOffset","_cachedVOffset","_cachedUScale","_cachedVScale","_cachedUAng","_cachedVAng","_cachedWAng","_cachedProjectionMatrixId","_cachedURotationCenter","_cachedVRotationCenter","_cachedWRotationCenter","_cachedHomogeneousRotationInUVTransform","_cachedCoordinatesMode","_initialSamplingMode","BILINEAR_SAMPLINGMODE","_deleteBuffer","_format","_delayedOnLoad","_delayedOnError","_isBlocking","_mimeType","_loaderOptions","onBeforeTextureInitObservable","_invertVScale","_cachedWrapU","wrapU","_cachedWrapV","wrapV","_cachedWrapR","resetCachedMaterial","onLoadedObservable","useDelayedTextureLoading","createTexture","updateURL","StartsWith","_prepareRowForTextureGeneration","uBase","coordinatesMode","PROJECTION_MODE","getProjectionMatrix","PLANAR_MODE","projectionMatrix","savedName","SerializeBuffers","ForceSerializeBuffers","base64String","EncodeArrayBufferToBase64","parsedTexture","customType","parsedCustomTexture","_samplingMode","_CubeTextureParser","mirrorPlane","mirrorTexture","_CreateMirror","renderTargetSize","_waitingRenderList","renderTargetTexture","reflectionProbes","probe","cubeTexture","_CreateRenderTargetTexture","CreateFromBase64String","UseSerializedUrlIfAny","LoadFromDataString","jsonTexture","NEAREST_SAMPLINGMODE","NEAREST_NEAREST_MIPLINEAR","LINEAR_LINEAR_MIPNEAREST","LINEAR_LINEAR_MIPLINEAR","NEAREST_NEAREST_MIPNEAREST","NEAREST_LINEAR_MIPNEAREST","NEAREST_LINEAR_MIPLINEAR","NEAREST_LINEAR","NEAREST_NEAREST","LINEAR_NEAREST_MIPNEAREST","LINEAR_NEAREST_MIPLINEAR","LINEAR_LINEAR","LINEAR_NEAREST","EXPLICIT_MODE","SPHERICAL_MODE","CUBIC_MODE","SKYBOX_MODE","INVCUBIC_MODE","EQUIRECTANGULAR_MODE","FIXED_EQUIRECTANGULAR_MODE","FIXED_EQUIRECTANGULAR_MIRRORED_MODE","CLAMP_ADDRESSMODE","WRAP_ADDRESSMODE","MIRROR_ADDRESSMODE","DepthCullingState","_isDepthTestDirty","_isDepthMaskDirty","_isDepthFuncDirty","_isCullFaceDirty","_isCullDirty","_isZOffsetDirty","_isFrontFaceDirty","_zOffset","_cullFace","_cull","_depthFunc","_depthMask","_depthTest","_frontFace","gl","cull","enable","CULL_FACE","disable","cullFace","depthMask","depthTest","DEPTH_TEST","depthFunc","POLYGON_OFFSET_FILL","polygonOffset","frontFace","StencilState","_isStencilTestDirty","_isStencilMaskDirty","_isStencilFuncDirty","_isStencilOpDirty","_stencilFunc","_stencilFuncRef","_stencilFuncMask","_stencilOpStencilFail","_stencilOpDepthFail","_stencilOpStencilDepthPass","_stencilMask","_stencilTest","ALWAYS","KEEP","REPLACE","stencilTest","STENCIL_TEST","stencilMask","stencilFunc","stencilFuncRef","stencilFuncMask","stencilOp","stencilOpStencilFail","stencilOpDepthFail","stencilOpStencilDepthPass","AlphaState","_isAlphaBlendDirty","_isBlendFunctionParametersDirty","_isBlendEquationParametersDirty","_isBlendConstantsDirty","_alphaBlend","_blendFunctionParameters","_blendEquationParameters","_blendConstants","setAlphaBlendConstants","setAlphaBlendFunctionParameters","value0","setAlphaEquationParameters","rgb","BLEND","blendFuncSeparate","blendEquationSeparate","blendColor","WebGLShaderProcessor","postProcessor","drawBuffersExtension","WebGL2ShaderProcessor","attributeProcessor","varyingProcessor","varying","hasDrawBuffersExtension","search","WebGLPipelineContext","vertexCompilationError","fragmentCompilationError","programLinkError","programValidationError","isParallelCompiled","program","_isRenderingStateCompiled","_getShaderSource","fragmentShader","BufferPointer","ThinEngine","canvasOrContext","antialias","adaptToDeviceRatio","forcePOTTextures","isFullscreen","cullBackFaces","renderEvenInBackground","preventCacheWipeBetweenFrames","validateShaderPrograms","useReverseDepthBuffer","disableUniformBuffers","_uniformBuffers","_webGLVersion","_windowIsBackground","_highPrecisionShadersAllowed","_renderingQueueLaunched","_activeRenderLoops","onContextLostObservable","onContextRestoredObservable","_contextWasLost","_doNotHandleContextLost","disableVertexArrayObjects","_colorWrite","_colorWriteChanged","_depthCullingState","_stencilState","_alphaState","_alphaMode","_alphaEquation","_internalTexturesCache","_activeChannel","_currentTextureChannel","_boundTexturesCache","_compiledEffects","_vertexAttribArraysEnabled","_uintIndicesCurrentlySet","_currentBoundBuffer","_currentFramebuffer","_dummyFramebuffer","_currentBufferPointers","_currentInstanceLocations","_currentInstanceBuffers","_vaoRecordInProgress","_mustWipeVertexAttributes","_nextFreeTextureSlots","_maxSimultaneousTextures","_activeRequests","_transformTextureUrl","hostInformation","isMobile","premultipliedAlpha","_viewportCached","_unpackFlipYCached","enableUnpackFlipYCached","_getDepthStencilBuffer","internalFormat","msInternalFormat","attachment","_gl","depthStencilBuffer","createRenderbuffer","bindRenderbuffer","RENDERBUFFER","renderbufferStorageMultisample","renderbufferStorage","framebufferRenderbuffer","FRAMEBUFFER","_boundUniforms","SetMatrixPrecision","useHighPrecisionMatrix","_renderingCanvas","deterministicLockstep","lockstepMaxSteps","timeStep","preserveDrawingBuffer","audioEngine","stencil","xrCompatible","doNotHandleContextLost","ua","ExceptionList","targets","RegExp","capture","captureConstraint","constraint","matches","targets_1","_onContextLost","evt","preventDefault","_onContextRestored","_initGLContext","_rebuildEffects","_rebuildInternalTextures","_rebuildBuffers","wipeCaches","powerPreference","disableWebGL2Support","deleteQuery","getContextAttributes","pixelStorei","UNPACK_COLORSPACE_CONVERSION_WEBGL","NONE","useHighPrecisionFloats","devicePixelRatio","limitDeviceRatio","_hardwareScalingLevel","resize","_isStencilEnable","_caps","_creationOptions","Version","description","parallelShaderCompile","highPrecisionShaderSupported","dimensions","_framebufferDimensionsObject","_cachedViewport","_emptyTexture","createRawTexture","_emptyTexture3D","createRawTexture3D","_emptyTexture2DArray","createRawTexture2DArray","_emptyCubeTexture","faceData","cubeData","createRawCubeTexture","currentState_1","areAllEffectsReady","maxTexturesImageUnits","getParameter","MAX_TEXTURE_IMAGE_UNITS","maxCombinedTexturesImageUnits","MAX_COMBINED_TEXTURE_IMAGE_UNITS","maxVertexTextureImageUnits","MAX_VERTEX_TEXTURE_IMAGE_UNITS","maxTextureSize","MAX_TEXTURE_SIZE","maxSamples","MAX_SAMPLES","maxCubemapTextureSize","MAX_CUBE_MAP_TEXTURE_SIZE","maxRenderTextureSize","MAX_RENDERBUFFER_SIZE","MAX_VERTEX_ATTRIBS","maxVaryingVectors","MAX_VARYING_VECTORS","maxFragmentUniformVectors","MAX_FRAGMENT_UNIFORM_VECTORS","maxVertexUniformVectors","MAX_VERTEX_UNIFORM_VECTORS","getExtension","standardDerivatives","maxAnisotropy","astc","bptc","s3tc","pvrtc","etc1","etc2","textureAnisotropicFilterExtension","uintIndices","fragmentDepthSupported","timerQuery","canUseTimestampForTimerQuery","maxMSAASamples","colorBufferFloat","textureFloat","textureHalfFloat","textureLOD","blendMinMax","multiview","oculusMultiview","depthTextureExtension","_glVersion","VERSION","rendererInfo","_glRenderer","UNMASKED_RENDERER_WEBGL","_glVendor","UNMASKED_VENDOR_WEBGL","HALF_FLOAT_OES","RGBA16F","RGBA32F","DEPTH24_STENCIL8","getQuery","getQueryEXT","TIMESTAMP_EXT","QUERY_COUNTER_BITS_EXT","MAX_TEXTURE_MAX_ANISOTROPY_EXT","_canRenderToFloatFramebuffer","_canRenderToHalfFloatFramebuffer","drawBuffers","drawBuffersWEBGL","DRAW_FRAMEBUFFER","UNSIGNED_INT_24_8","UNSIGNED_INT_24_8_WEBGL","vertexArrayObjectExtension","createVertexArray","createVertexArrayOES","bindVertexArray","bindVertexArrayOES","deleteVertexArray","deleteVertexArrayOES","instanceExtension","drawArraysInstanced","drawArraysInstancedANGLE","drawElementsInstanced","drawElementsInstancedANGLE","vertexAttribDivisor","vertexAttribDivisorANGLE","getShaderPrecisionFormat","vertex_highp","VERTEX_SHADER","HIGH_FLOAT","fragment_highp","FRAGMENT_SHADER","blendMinMaxExtension","MAX","MAX_EXT","MIN","MIN_EXT","LEQUAL","slot","_prepareWorkingCanvas","_workingCanvas","_workingContext","resetTextureCache","getGlInfo","vendor","renderer","setHardwareScalingLevel","getHardwareScalingLevel","stopRenderLoop","renderFunction","_renderLoop","shouldRender","beginFrame","endFrame","_frameHandler","_queueNewFrame","_boundRenderFunction","getHostWindow","getRenderingCanvas","ownerDocument","defaultView","getRenderWidth","useScreen","_currentRenderTarget","framebufferWidth","drawingBufferWidth","getRenderHeight","framebufferHeight","drawingBufferHeight","bindedRenderFunction","requester","QueueNewFrame","runRenderLoop","backBuffer","applyStates","clearColor","COLOR_BUFFER_BIT","GREATER","clearDepth","DEPTH_BUFFER_BIT","clearStencil","STENCIL_BUFFER_BIT","_viewport","setViewport","requiredWidth","requiredHeight","flushFramebuffer","clientWidth","clientHeight","setSize","bindFramebuffer","forceFullscreenViewport","lodLevel","layer","unBindFramebuffer","_bindUnboundFramebuffer","_MSAAFramebuffer","_framebuffer","framebufferTextureLayer","COLOR_ATTACHMENT0","_webGLTexture","framebufferTexture2D","TEXTURE_CUBE_MAP_POSITIVE_X","depthStencilTexture","_depthStencilTexture","DEPTH_STENCIL_ATTACHMENT","DEPTH_ATTACHMENT","TEXTURE_2D","framebuffer","disableGenerateMipMaps","onBeforeUnbind","_textureArray","unBindMultiColorAttachmentFramebuffer","READ_FRAMEBUFFER","blitFramebuffer","NEAREST","_bindTextureDirectly","generateMipmap","flush","restoreDefaultFramebuffer","_resetVertexBufferBinding","bindArrayBuffer","_cachedVertexBuffers","_createVertexBuffer","STATIC_DRAW","usage","vbo","createBuffer","dataBuffer","bufferData","ARRAY_BUFFER","DYNAMIC_DRAW","_resetIndexBufferBinding","bindIndexBuffer","_cachedIndexBuffer","_normalizeIndexData","ELEMENT_ARRAY_BUFFER","is32Bits","_unbindVertexArrayObject","bindBuffer","pipelineContext","uniformLocation","getUniformBlockIndex","uniformBlockBinding","underlyingResource","updateArrayBuffer","bufferSubData","_vertexAttribPointer","indx","pointer","active","vertexAttribPointer","_bindIndexBufferWithCache","indexBuffer","_bindVertexBuffersAttributes","vertexBuffers","unbindAllAttributes","enableVertexAttribArray","vao","_cachedVertexArrayObject","bindBuffersDirectly","vertexDeclaration","vertexStrideSize","_cachedEffectForVertexBuffers","attributesCount","boundBuffer","ul","offsetLocation","updateAndBindInstancesBuffer","offsetLocations","bindInstancesBuffer","attributesInfo","computeStride","ai","attributeSize","_currentEffect","attributeName","attributeType","disableInstanceAttributeByName","attributeLocation","disableInstanceAttribute","shouldClean","disableAttributeByIndex","disableVertexAttribArray","draw","useTriangles","drawPointClouds","drawUnIndexed","_reportDrawCall","drawMode","_drawMode","indexFormat","mult","drawElements","drawArrays","TRIANGLES","POINTS","LINES","LINE_LOOP","LINE_STRIP","TRIANGLE_STRIP","TRIANGLE_FAN","webGLPipelineContext","__SPECTOR_rebuildProgram","deleteProgram","createEffect","vertexToken","fragmentToken","compiledEffect","_ConcatenateShader","shaderVersion","_compileShader","_compileRawShader","createShader","shaderSource","compileShader","getShaderSource","createRawShaderProgram","_createShaderProgram","createShaderProgram","shaderProgram","createProgram","attachShader","linkProgram","_finalizePipelineContext","getProgramParameter","LINK_STATUS","getShaderParameter","COMPILE_STATUS","getShaderInfoLog","getProgramInfoLog","validateProgram","VALIDATE_STATUS","deleteShader","createAsRaw","webGLRenderingState","COMPLETION_STATUS_KHR","oldHandler","getUniformLocation","getAttribLocation","enableEffect","uniform1i","uniform1iv","uniform2iv","uniform3iv","uniform4iv","uniform1fv","uniform2fv","uniform3fv","uniform4fv","uniformMatrix4fv","uniformMatrix3fv","uniformMatrix2fv","uniform1f","uniform2f","uniform3f","uniform4f","colorMask","setColorWrite","clearInternalTexturesCache","bruteForce","_currentProgram","UNPACK_PREMULTIPLY_ALPHA_WEBGL","_getSamplingParameters","magFilter","minFilter","LINEAR","LINEAR_MIPMAP_NEAREST","LINEAR_MIPMAP_LINEAR","NEAREST_MIPMAP_LINEAR","NEAREST_MIPMAP_NEAREST","mag","_createTexture","fallback","forcedExtension","fromData","fromBlob","isBase64","Url","originalUrl","_originalUrl","lastDot","extension","loader","_TextureLoaders","availableLoader","canLoad","onLoadObserver","onInternalError","callback_1","loadData","loadMipmap","isCompressed","loadFailed","_prepareWebGLTexture","isView","responseURL","onload_1","potWidth","potHeight","continuationCallback","isPot","_getInternalFormat","RGB","RGBA","texImage2D","_supportsHardwareTextureRescaling","source_1","Temp","_rescaleTexture","_releaseTexture","decoding","close","_FileToolsLoadImage","onComplete","compression","textureType","_unpackFlipY","UNPACK_FLIP_Y_WEBGL","_getUnpackAlignement","UNPACK_ALIGNMENT","_getTextureTarget","TEXTURE_CUBE_MAP","TEXTURE_3D","isMultiview","TEXTURE_2D_ARRAY","filters","_setTextureParameterInteger","TEXTURE_MAG_FILTER","TEXTURE_MIN_FILTER","updateTextureWrappingMode","TEXTURE_WRAP_S","_getTextureWrapMode","TEXTURE_WRAP_T","TEXTURE_WRAP_R","_setupDepthStencilTexture","generateStencil","bilinearFiltering","comparisonFunction","layers","_generateDepthBuffer","_generateStencilBuffer","_comparisonFunction","samplingParameters","texParameteri","CLAMP_TO_EDGE","TEXTURE_COMPARE_FUNC","TEXTURE_COMPARE_MODE","COMPARE_REF_TO_TEXTURE","_uploadCompressedDataToTextureDirectly","compressedTexImage2D","_uploadDataToTextureDirectly","babylonInternalFormat","useTextureWidthAndHeight","_getWebGLTextureType","_getRGBABufferInternalSizedFormat","lodMaxWidth","lodMaxHeight","updateTextureData","xOffset","yOffset","texSubImage2D","_uploadArrayBufferViewToTexture","bindTarget","_prepareWebGLTextureContinuation","processFunction","needPOTTextures","GetExponentOfTwo","_setupFramebufferDepthAttachments","generateStencilBuffer","generateDepthBuffer","DEPTH_STENCIL","depthFormat","DEPTH_COMPONENT16","DEPTH_COMPONENT32F","STENCIL_INDEX8","STENCIL_ATTACHMENT","_releaseFramebufferObjects","deleteFramebuffer","_depthStencilBuffer","deleteRenderbuffer","_MSAARenderBuffer","_deleteTexture","unbindAllTextures","deleteTexture","_setProgram","useProgram","_activateCurrentTexture","activeTexture","TEXTURE0","forTextureDataUpdate","wasPreviouslyBound","isTextureForRendering","_associatedChannel","bindTexture","_colorTextureArray","_bindSamplerUniformToChannel","_setTexture","sourceSlot","_currentState","REPEAT","MIRRORED_REPEAT","isPartOfTextureArray","video","emptyCubeTexture","emptyTexture3D","emptyTexture2DArray","emptyTexture","needToBind","textureWrapMode","_setAnisotropicLevel","_textureUnits","anisotropicFilterExtension","_cachedAnisotropicFilteringLevel","_setTextureParameterFloat","TEXTURE_MAX_ANISOTROPY_EXT","parameter","texParameterf","releaseEffects","attachContextLostEvent","attachContextRestoredEvent","getError","_canRenderToFramebuffer","NO_ERROR","successful","fb","createFramebuffer","status","checkFramebufferStatus","FRAMEBUFFER_COMPLETE","readFormat","readType","UNSIGNED_SHORT_4_4_4_4","UNSIGNED_SHORT_5_5_5_1","UNSIGNED_SHORT_5_6_5","HALF_FLOAT","UNSIGNED_INT_2_10_10_10_REV","UNSIGNED_INT_10F_11F_11F_REV","UNSIGNED_INT_5_9_9_9_REV","FLOAT_32_UNSIGNED_INT_24_8_REV","ALPHA","LUMINANCE","LUMINANCE_ALPHA","RED","RG","RED_INTEGER","RG_INTEGER","RGB_INTEGER","RGBA_INTEGER","R8_SNORM","RG8_SNORM","RGB8_SNORM","R8I","RG8I","RGB8I","RGBA8I","RGBA8_SNORM","R8","RG8","RGB8","RGBA8","R8UI","RG8UI","RGB8UI","RGBA8UI","R16I","RG16I","RGB16I","RGBA16I","R16UI","RG16UI","RGB16UI","RGBA16UI","R32I","RG32I","RGB32I","RGBA32I","R32UI","RG32UI","RGB32UI","RGBA32UI","R32F","RG32F","RGB32F","R16F","RG16F","RGB16F","RGB565","R11F_G11F_B10F","RGB9_E5","RGBA4","RGB5_A1","RGB10_A2","RGB10_A2UI","_getRGBAMultiSampleBufferFormat","_FileToolsLoadFile","hasAlpha","numChannels","isSupported","_HasMajorPerformanceCaveat","_IsSupported","tempcanvas","WebGLRenderingContext","failIfMajorPerformanceCaveat","CeilingPOT","FloorPOT","NearestPOT","pot","requestPostAnimationFrame","requestAnimationFrame","msRequestAnimationFrame","webkitRequestAnimationFrame","mozRequestAnimationFrame","oRequestAnimationFrame","CollisionsEpsilon","Camera","setActiveOnSceneIfNoneActive","_position","_upVector","orthoLeft","orthoRight","orthoBottom","orthoTop","minZ","inertia","PERSPECTIVE_CAMERA","isIntermediate","fovMode","FOVMODE_VERTICAL_FIXED","cameraRigMode","RIG_MODE_NONE","customRenderTargets","onViewMatrixChangedObservable","onProjectionMatrixChangedObservable","onAfterCheckInputsObservable","onRestoreStateObservable","isRigCamera","_rigCameras","_webvrViewMatrix","_skipRendering","_projectionMatrix","_postProcesses","_activeMeshes","_globalPosition","_computedViewMatrix","_doNotComputeProjectionMatrix","_refreshFrustumPlanes","_isCamera","_isLeftCamera","_isRightCamera","addCamera","newPosition","storeState","_stateStored","_storedFov","_restoreStateValues","restoreState","getActiveMeshes","isActiveMesh","pp","_initCache","_cache","Number","MAX_VALUE","upVector","aspectRatio","renderWidth","renderHeight","_updateCache","ignoreParentClass","_isSynchronized","_isSynchronizedViewMatrix","_isSynchronizedProjectionMatrix","isSynchronizedWithParent","check","getAspectRatio","attachControl","ignored","noPreventDefault","detachControl","_checkInputs","_updateRigCameras","_rigPostProcess","_getFirstPostProcess","ppIndex","_cascadePostProcessesToRigCams","firstPostProcess","markTextureDirty","cam","rigPostProcess","getEffectName","attachPostProcess","insertAt","isReusable","detachPostProcess","getViewMatrix","_worldMatrix","_getViewMatrix","updateCache","_currentRenderId","_childUpdateId","_cameraRigParams","vrPreViewMatrix","freezeProjectionMatrix","unfreezeProjectionMatrix","reverseDepth","halfWidth","getTransformationMatrix","_updateFrustumPlanes","_frustumPlanes","GetPlanesToRef","GetPlanes","checkRigCameras","rigCameras","isCompletelyInFrustum","getForwardRay","getForwardRayToRef","refRay","inputs","removeCamera","getLeftTarget","getTarget","getRightTarget","setCameraRigMode","rigParams","interaxialDistance","stereoHalfAngle","leftCamera","createRigCamera","rightCamera","RIG_MODE_STEREOSCOPIC_ANAGLYPH","_setStereoscopicAnaglyphRigMode","RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL","RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED","RIG_MODE_STEREOSCOPIC_OVERUNDER","RIG_MODE_STEREOSCOPIC_INTERLACED","_setStereoscopicRigMode","RIG_MODE_VR","_setVRRigMode","RIG_MODE_WEBVR","_setWebVRRigMode","_getVRProjectionMatrix","vrMetrics","aspectRatioFov","vrWorkMatrix","vrHMatrix","_updateCameraRotationMatrix","_updateWebVRCameraRotationMatrix","_getWebVRProjectionMatrix","_getWebVRViewMatrix","setCameraRigParameter","cameraIndex","_setupInputs","GetConstructorFromName","isStereoscopicSideBySide","getDirection","localAxis","getDirectionToRef","interaxial_distance","constructorFunc","Construct","_createDefaultParsedCamera","parsedCamera","construct","setPosition","setTarget","ORTHOGRAPHIC_CAMERA","FOVMODE_HORIZONTAL_FIXED","RIG_MODE_CUSTOM","ForceAttachControlToAlwaysPreventDefault","AndOrNotEvaluator","Eval","query","evaluateCallback","_HandleParenthesisContent","parenthesisContent","or","ori","_SimplifyNegation","trim","and","andj","booleanString","Tags","EnableFor","_tags","hasTags","addTags","tagsString","removeTags","RemoveTagsFrom","matchesTagsQuery","tagsQuery","MatchesQuery","DisableFor","asString","tagsArray","tag","join","_AddTagTo","_RemoveTagFrom","SceneComponentConstants","NAME_EFFECTLAYER","NAME_LAYER","NAME_LENSFLARESYSTEM","NAME_BOUNDINGBOXRENDERER","NAME_PARTICLESYSTEM","NAME_GAMEPAD","NAME_SIMPLIFICATIONQUEUE","NAME_GEOMETRYBUFFERRENDERER","NAME_PREPASSRENDERER","NAME_DEPTHRENDERER","NAME_POSTPROCESSRENDERPIPELINEMANAGER","NAME_SPRITE","NAME_SUBSURFACE","NAME_OUTLINERENDERER","NAME_PROCEDURALTEXTURE","NAME_SHADOWGENERATOR","NAME_OCTREE","NAME_AUDIO","STEP_ISREADYFORMESH_EFFECTLAYER","STEP_BEFOREEVALUATEACTIVEMESH_BOUNDINGBOXRENDERER","STEP_EVALUATESUBMESH_BOUNDINGBOXRENDERER","STEP_PREACTIVEMESH_BOUNDINGBOXRENDERER","STEP_CAMERADRAWRENDERTARGET_EFFECTLAYER","STEP_BEFORECAMERADRAW_EFFECTLAYER","STEP_BEFORECAMERADRAW_LAYER","STEP_BEFORECAMERADRAW_PREPASS","STEP_BEFORERENDERTARGETDRAW_LAYER","STEP_BEFORERENDERINGMESH_PREPASS","STEP_BEFORERENDERINGMESH_OUTLINE","STEP_AFTERRENDERINGMESH_PREPASS","STEP_AFTERRENDERINGMESH_OUTLINE","STEP_AFTERRENDERINGGROUPDRAW_EFFECTLAYER_DRAW","STEP_AFTERRENDERINGGROUPDRAW_BOUNDINGBOXRENDERER","STEP_BEFORECAMERAUPDATE_SIMPLIFICATIONQUEUE","STEP_BEFORECAMERAUPDATE_GAMEPAD","STEP_BEFORECLEAR_PROCEDURALTEXTURE","STEP_AFTERRENDERTARGETDRAW_LAYER","STEP_AFTERCAMERADRAW_EFFECTLAYER","STEP_AFTERCAMERADRAW_LENSFLARESYSTEM","STEP_AFTERCAMERADRAW_EFFECTLAYER_DRAW","STEP_AFTERCAMERADRAW_LAYER","STEP_AFTERCAMERADRAW_PREPASS","STEP_AFTERRENDER_AUDIO","STEP_GATHERRENDERTARGETS_DEPTHRENDERER","STEP_GATHERRENDERTARGETS_GEOMETRYBUFFERRENDERER","STEP_GATHERRENDERTARGETS_SHADOWGENERATOR","STEP_GATHERRENDERTARGETS_POSTPROCESSRENDERPIPELINEMANAGER","STEP_GATHERACTIVECAMERARENDERTARGETS_DEPTHRENDERER","STEP_BEFORECLEARSTAGE_PREPASS","STEP_POINTERMOVE_SPRITE","STEP_POINTERDOWN_SPRITE","STEP_POINTERUP_SPRITE","Stage","Create","registerStep","component","Material","doNotAdd","shadowDepthWrapper","allowShaderHotSwapping","checkReadyOnEveryCall","checkReadyOnlyOnce","_backFaceCulling","getRenderTargetTextures","_onUnBindObservable","_onBindObserver","_needDepthPrePass","disableDepthWrite","disableColorWrite","depthFunction","_fogEnabled","pointSize","_effect","_useUBO","_fillMode","_cachedDepthWriteState","_cachedColorWriteState","_cachedDepthFunctionState","_indexInSceneMaterialArray","_forceAlphaTest","_transparencyMode","idSubscript","getMaterialByID","_uniformBuffer","addMaterial","useMaterialMeshMap","MiscDirtyFlag","TextureDirtyFlag","onBindObservable","_onEffectCreatedObservable","LineListDrawMode","LineLoopDrawMode","LineStripDrawMode","PointListDrawMode","freeze","markDirty","unfreeze","MATERIAL_ALPHATESTANDBLEND","_markAllSubMeshesAsTexturesAndMiscDirty","MATERIAL_OPAQUE","MATERIAL_ALPHATEST","needAlphaBlending","_disableAlphaBlending","needAlphaTesting","_shouldTurnAlphaTestOn","getAlphaTestTexture","overrideOrientation","bindSceneUniformBuffer","sceneUbo","bindToEffect","bindView","getSceneUniformBuffer","bindViewProjection","_afterBind","_cachedMaterial","_cachedVisibility","getDepthWrite","getDepthFunction","setDepthFunction","getBindedMeshes","meshId","filter","forceCompilation","localOptions","currentHotSwapingState","checkReady","clipPlaneState","allDone","lastError","tempSubMesh","_materialDefines","forceCompilationAsync","blockMaterialDirtyMechanism","_DirtyCallbackArray","_TextureDirtyCallBack","LightDirtyFlag","_LightsDirtyCallBack","FresnelDirtyFlag","_FresnelDirtyCallBack","AttributesDirtyFlag","_AttributeDirtyCallBack","_MiscDirtyCallBack","PrePassDirtyFlag","_PrePassDirtyCallBack","_markAllSubMeshesAsDirty","_RunDirtyCallBacks","meshes_2","_markScenePrePassDirty","enablePrePassRenderer","_markAllSubMeshesAsAllDirty","_AllDirtyCallBack","_markAllSubMeshesAsImageProcessingDirty","_ImageProcessingDirtyCallBack","_markAllSubMeshesAsFresnelDirty","_markAllSubMeshesAsFresnelAndMiscDirty","_FresnelAndMiscDirtyCallBack","_markAllSubMeshesAsLightsDirty","_markAllSubMeshesAsAttributesDirty","_markAllSubMeshesAsMiscDirty","_markAllSubMeshesAsPrePassDirty","_TextureAndMiscDirtyCallBack","setPrePassRenderer","notBoundToMesh","freeProcessedMaterials","removeMaterial","meshes_3","_materialEffect","parsedMaterial","overloadedAlbedo","BABYLON","LegacyPBRMaterial","TriangleStripDrawMode","TriangleFanDrawMode","AllDirtyFlag","MATERIAL_ALPHABLEND","MATERIAL_NORMALBLENDMETHOD_WHITEOUT","MATERIAL_NORMALBLENDMETHOD_RNM","markAllAsDirty","markAsTexturesDirty","markAsFresnelDirty","markAsMiscDirty","markAsPrePassDirty","markAsLightDirty","markAsAttributesDirty","cb","PerformanceMonitor","frameSampleSize","_enabled","_rollingFrameTime","RollingAverage","sampleFrame","timeMs","_lastFrameTimeMs","dt","average","variance","history","isSaturated","_samples","delta","bottomValue","_pos","_sampleCount","_m2","_wrapPosition","setAlphaConstants","noDepthWriteChange","alphaBlend","ONE","ONE_MINUS_SRC_ALPHA","SRC_ALPHA","ZERO","ONE_MINUS_SRC_COLOR","DST_COLOR","CONSTANT_COLOR","ONE_MINUS_CONSTANT_COLOR","CONSTANT_ALPHA","ONE_MINUS_CONSTANT_ALPHA","DST_ALPHA","ONE_MINUS_DST_COLOR","ONE_MINUS_DST_ALPHA","depthCullingState","getAlphaMode","setAlphaEquation","equation","FUNC_ADD","FUNC_SUBTRACT","FUNC_REVERSE_SUBTRACT","getAlphaEquation","dummy","arrayBuffer","dataLength","subarray","Engine","enableOfflineSupport","disableManifestCheck","onNewSceneAddedObservable","postProcesses","isPointerLock","onResizeObservable","onCanvasBlurObservable","onCanvasFocusObservable","onCanvasPointerOutObservable","onBeginFrameObservable","customAnimationFrameRequester","onEndFrameObservable","onBeforeShaderCompilationObservable","onAfterShaderCompilationObservable","_deterministicLockstep","_lockstepMaxSteps","_timeStep","_fps","_deltaTime","_drawCalls","canvasTabIndex","disablePerformanceMonitorInBackground","_performanceMonitor","Instances","canvas_1","_onCanvasFocus","_onBlur","_onFocus","_onCanvasPointerOut","ev","hostWindow","anyDoc_1","_onFullscreenChange","fullscreen","mozFullScreen","webkitIsFullScreen","msIsFullScreen","_pointerLockRequested","_RequestPointerlock","_onPointerLockChange","mozPointerLockElement","webkitPointerLockElement","msPointerLockElement","pointerLockElement","AudioEngineFactory","_connectVREvents","OfflineProviderFactory","doNotHandleTouchAction","_disableTouchAction","_prepareVRComponent","autoEnableWebVR","initWebVR","NpmPackage","MarkAllMaterialsAsDirty","engineIndex","sceneIndex","DefaultLoadingScreenFactory","_RescalePostProcessFactory","getInputElement","viewportOwner","getScreenAspectRatio","getRenderingCanvasClientRect","getInputElementClientRect","isDeterministicLockStep","getLockstepMaxSteps","getTimeStep","generateMipMapsForCubemap","culling","reverseSide","BACK","FRONT","setZOffset","CW","CCW","getZOffset","setDepthBuffer","getStencilBuffer","setStencilBuffer","getStencilMask","setStencilMask","getStencilFunction","getStencilFunctionReference","getStencilFunctionMask","setStencilFunction","setStencilFunctionReference","setStencilFunctionMask","getStencilOperationFail","getStencilOperationDepthFail","getStencilOperationPass","setStencilOperationFail","operation","setStencilOperationDepthFail","setStencilOperationPass","setDitheringState","DITHER","setRasterizerState","RASTERIZER_DISCARD","setDepthFunctionToGreater","setDepthFunctionToGreaterOrEqual","GEQUAL","setDepthFunctionToLess","LESS","setDepthFunctionToLessOrEqual","cacheStencilState","_cachedStencilBuffer","_cachedStencilFunction","_cachedStencilMask","_cachedStencilOperationPass","_cachedStencilOperationFail","_cachedStencilOperationDepthFail","_cachedStencilReference","restoreStencilState","setDirectViewport","currentViewport","scissorClear","enableScissor","disableScissor","SCISSOR_TEST","scissor","_submitVRFrame","disableVR","isVRPresenting","_requestVRFrame","_loadFileAsync","getVertexShaderSource","shaders","getAttachedShaders","getFragmentShaderSource","_textures","_currentRenderTextureInd","_outputTexture","_rebuildGeometries","_rebuildTextures","_renderFrame","_renderViews","requestID","switchFullscreen","requestPointerLock","exitFullscreen","enterFullscreen","_RequestFullscreen","_ExitFullscreen","enterPointerlock","exitPointerlock","_ExitPointerlock","_measureFps","camIndex","cameras","transformFeedback","deleteTransformFeedback","createTransformFeedback","bindTransformFeedback","setTranformFeedbackVaryings","rtt","createRenderTargetTexture","_rescalePostProcess","onApply","hostingScene","postProcessManager","directRender","copyTexImage2D","getFps","getDeltaTime","averageFPS","instantaneousFrameTime","_uploadImageToTexture","image","updateRenderTargetTextureSampleCount","colorRenderbuffer","updateTextureComparisonFunction","createInstancesBuffer","capacity","deleteInstancesBuffer","_clientWaitAsync","sync","flags","interval_ms","clientWaitSync","WAIT_FAILED","TIMEOUT_EXPIRED","_readPixelsAsync","outputBuffer","buf","PIXEL_PACK_BUFFER","STREAM_READ","fenceSync","SYNC_GPU_COMMANDS_COMPLETE","deleteSync","getBufferSubData","hideLoadingUI","IsDocumentAvailable","touchAction","msTouchAction","displayLoadingUI","loadingScreen","_loadingScreen","loadingUIText","loadingUIBackgroundColor","msRequestPointerLock","mozRequestPointerLock","webkitRequestPointerLock","anyDoc","exitPointerLock","msExitPointerLock","mozExitPointerLock","webkitExitPointerLock","requestFunction","requestFullscreen","msRequestFullscreen","webkitRequestFullscreen","mozRequestFullScreen","mozCancelFullScreen","webkitCancelFullScreen","msCancelFullScreen","ALPHA_DISABLE","ALPHA_ADD","ALPHA_COMBINE","ALPHA_SUBTRACT","ALPHA_MULTIPLY","ALPHA_MAXIMIZED","ALPHA_ONEONE","ALPHA_PREMULTIPLIED","ALPHA_PREMULTIPLIED_PORTERDUFF","ALPHA_INTERPOLATE","ALPHA_SCREENMODE","DELAYLOADSTATE_NONE","DELAYLOADSTATE_LOADED","DELAYLOADSTATE_LOADING","DELAYLOADSTATE_NOTLOADED","NEVER","EQUAL","NOTEQUAL","INCR","DECR","INVERT","INCR_WRAP","DECR_WRAP","TEXTURE_CLAMP_ADDRESSMODE","TEXTURE_WRAP_ADDRESSMODE","TEXTURE_MIRROR_ADDRESSMODE","TEXTUREFORMAT_ALPHA","TEXTUREFORMAT_LUMINANCE","TEXTUREFORMAT_LUMINANCE_ALPHA","TEXTUREFORMAT_RGB","TEXTUREFORMAT_RGBA","TEXTUREFORMAT_RED","TEXTUREFORMAT_R","TEXTUREFORMAT_RG","TEXTUREFORMAT_RED_INTEGER","TEXTUREFORMAT_R_INTEGER","TEXTUREFORMAT_RG_INTEGER","TEXTUREFORMAT_RGB_INTEGER","TEXTUREFORMAT_RGBA_INTEGER","TEXTURETYPE_UNSIGNED_BYTE","TEXTURETYPE_UNSIGNED_INT","TEXTURETYPE_FLOAT","TEXTURETYPE_HALF_FLOAT","TEXTURETYPE_BYTE","TEXTURETYPE_SHORT","TEXTURETYPE_UNSIGNED_SHORT","TEXTURETYPE_INT","TEXTURETYPE_UNSIGNED_INTEGER","TEXTURETYPE_UNSIGNED_SHORT_4_4_4_4","TEXTURETYPE_UNSIGNED_SHORT_5_5_5_1","TEXTURETYPE_UNSIGNED_SHORT_5_6_5","TEXTURETYPE_UNSIGNED_INT_2_10_10_10_REV","TEXTURETYPE_UNSIGNED_INT_24_8","TEXTURETYPE_UNSIGNED_INT_10F_11F_11F_REV","TEXTURETYPE_UNSIGNED_INT_5_9_9_9_REV","TEXTURETYPE_FLOAT_32_UNSIGNED_INT_24_8_REV","TEXTURE_NEAREST_SAMPLINGMODE","TEXTURE_BILINEAR_SAMPLINGMODE","TEXTURE_TRILINEAR_SAMPLINGMODE","TEXTURE_NEAREST_NEAREST_MIPLINEAR","TEXTURE_LINEAR_LINEAR_MIPNEAREST","TEXTURE_LINEAR_LINEAR_MIPLINEAR","TEXTURE_NEAREST_NEAREST_MIPNEAREST","TEXTURE_NEAREST_LINEAR_MIPNEAREST","TEXTURE_NEAREST_LINEAR_MIPLINEAR","TEXTURE_NEAREST_LINEAR","TEXTURE_NEAREST_NEAREST","TEXTURE_LINEAR_NEAREST_MIPNEAREST","TEXTURE_LINEAR_NEAREST_MIPLINEAR","TEXTURE_LINEAR_LINEAR","TEXTURE_LINEAR_NEAREST","TEXTURE_EXPLICIT_MODE","TEXTURE_SPHERICAL_MODE","TEXTURE_PLANAR_MODE","TEXTURE_CUBIC_MODE","TEXTURE_PROJECTION_MODE","TEXTURE_SKYBOX_MODE","TEXTURE_INVCUBIC_MODE","TEXTURE_EQUIRECTANGULAR_MODE","TEXTURE_FIXED_EQUIRECTANGULAR_MODE","TEXTURE_FIXED_EQUIRECTANGULAR_MIRRORED_MODE","SCALEMODE_FLOOR","SCALEMODE_NEAREST","SCALEMODE_CEILING","EngineStore","_LastCreatedScene","DomManagement","firstChild","nodeType","textContent","StringDictionary","_count","getOrAddWithFactory","factory","getOrAdd","curVal","getAndRemove","cur","first","AbstractScene","rootNodes","lights","skeletons","animationGroups","morphTargetManagers","geometries","transformNodes","actionManagers","_environmentTexture","AddParser","parser","_BabylonFileParsers","GetParser","AddIndividualParser","_IndividualBabylonFileParsers","GetIndividualParser","jsonData","parserName","getNodes","nodes","ActionEvent","pointerX","pointerY","meshUnderPointer","sourceEvent","additionalData","CreateNew","CreateNewFromSprite","CreateNewFromScene","CreateNewFromPrimitive","prim","pointerPos","AbstractActionManager","isRecursive","Triggers","t_int","HasSpecificTrigger","trigger","_ClickInfo","_singleClick","_doubleClick","_hasSwiped","_ignore","InputManager","_alreadyAttached","_wheelEventName","_meshPickProceed","_currentPickResult","_previousPickResult","_totalPointersPressed","_doubleClickOccured","_pointerX","_pointerY","_startingPointerPosition","_previousStartingPointerPosition","_startingPointerTime","_previousStartingPointerTime","_pointerCaptures","_meshUnderPointerId","_keyboardIsAttached","_pointerOverMesh","getMeshUnderPointerByPointerId","_unTranslatedPointerX","_unTranslatedPointerY","_updatePointerPosition","canvasRect","clientX","clientY","_processPointerMove","pickResult","tabIndex","doNotHandleCursors","cursor","defaultCursor","isMeshPicked","hit","pickedMesh","setPointerOverMesh","hasPointerTriggers","_pointerMoveStage","onPointerMove","onPointerObservable","_setRayOnPointerInfo","pointerInfo","_pickingUnavailable","createPickingRay","_checkPrePointerObservable","onPrePointerObservable","simulatePointerMove","pointerEventInit","simulatePointerDown","_processPointerDown","_pickedDownMesh","_getActionManagerForTrigger","hasPickTriggers","processTrigger","button","hasSpecificTrigger","pick","cameraToUseForPointers","now","LongPressDelay","_isPointerSwiping","_pointerDownStage","onPointerDown","DragMovementThreshold","simulatePointerUp","doubleTap","clickInfo","doubleClick","singleClick","_processPointerUp","_pickedUpMesh","onPointerPick","ignore","type_1","hasSwiped","doubleClickActionManager","_pointerUpStage","pickedDownActionManager","onPointerUp","isPointerCaptured","attachUp","attachDown","attachMove","elementToAttachTo","_alreadyAttachedTo","_initActionManager","act","pointerDownPredicate","_delayedSimpleClick","btn","DoubleClickDelay","_previousButtonPressed","_initClickEvent","obs1","obs2","checkPicking","needToIgnoreNext","checkSingleClickImmediately","ExclusiveDoubleClickMode","_previousDelayedSimpleClickTimeout","_delayedSimpleClickTimeout","checkDoubleClick","clearTimeout","pointerMovePredicate","enablePointerMoveEvents","constantlyUpdateMeshUnderPointer","preventDefaultOnPointerDown","focus","preventDefaultOnPointerUp","pointerUpPredicate","HasTriggers","_onKeyDown","KEYDOWN","onPreKeyboardObservable","onKeyboardObservable","_onKeyUp","KEYUP","attachedFunction","_onCanvasFocusObserver","activeElement","_onCanvasBlurObserver","onmousewheel","underPointerMesh","getPointerOverMesh","UniqueIdGenerator","_UniqueIdCounter","Scene","_inputManager","_blockEntityCollection","autoClear","autoClearDepthAndStencil","ambientColor","_environmentIntensity","_forceWireframe","_skipFrustumClipping","_forcePointsCloud","animationsEnabled","_animationPropertiesOverride","useConstantAnimationDeltaTime","disableOfflineSupportExceptionRules","_onBeforeRenderObserver","onAfterRenderCameraObservable","_onAfterRenderObserver","onBeforeAnimationsObservable","onAfterAnimationsObservable","onBeforeDrawPhaseObservable","onAfterDrawPhaseObservable","onReadyObservable","onBeforeCameraRenderObservable","_onBeforeCameraRenderObserver","onAfterCameraRenderObservable","_onAfterCameraRenderObserver","onBeforeActiveMeshesEvaluationObservable","onAfterActiveMeshesEvaluationObservable","onBeforeParticlesRenderingObservable","onAfterParticlesRenderingObservable","onDataLoadedObservable","onNewCameraAddedObservable","onCameraRemovedObservable","onNewLightAddedObservable","onLightRemovedObservable","onNewGeometryAddedObservable","onGeometryRemovedObservable","onNewTransformNodeAddedObservable","onTransformNodeRemovedObservable","onNewMeshAddedObservable","onMeshRemovedObservable","onNewSkeletonAddedObservable","onSkeletonRemovedObservable","onNewMaterialAddedObservable","onNewMultiMaterialAddedObservable","onMaterialRemovedObservable","onMultiMaterialRemovedObservable","onNewTextureAddedObservable","onBeforeRenderTargetsRenderObservable","onAfterRenderTargetsRenderObservable","onBeforeStepObservable","onAfterStepObservable","onActiveCameraChanged","onBeforeRenderingGroupObservable","onAfterRenderingGroupObservable","onAnimationFileImportedObservable","_registeredForLateAnimationBindings","_useRightHandedSystem","_timeAccumulator","_currentStepId","_currentInternalStep","_fogMode","prePass","_shadowsEnabled","_lightsEnabled","activeCameras","_texturesEnabled","physicsEnabled","particlesEnabled","spritesEnabled","_skeletonsEnabled","lensFlaresEnabled","collisionsEnabled","gravity","postProcessesEnabled","renderTargetsEnabled","dumpNextRenderTargets","importedMeshesFiles","probesEnabled","_meshesForIntersections","proceduralTexturesEnabled","_activeParticles","_activeBones","_animationTime","animationTimeScale","_frameId","_executeWhenReadyTimeoutId","_intermediateRendering","_viewUpdateFlag","_projectionUpdateFlag","_toBeDisposed","_pendingData","dispatchAllSubMeshesOfActiveMeshes","_processedMaterials","_renderTargets","_activeParticleSystems","_activeSkeletons","_softwareSkinnedMeshes","_activeAnimatables","requireLightSorting","_components","_serializableComponents","_transientComponents","_beforeCameraUpdateStage","_beforeClearStage","_gatherRenderTargetsStage","_gatherActiveCameraRenderTargetsStage","_isReadyForMeshStage","_beforeEvaluateActiveMeshStage","_evaluateSubMeshStage","_preActiveMeshStage","_cameraDrawRenderTargetStage","_beforeCameraDrawStage","_beforeRenderTargetDrawStage","_beforeRenderingGroupDrawStage","_afterRenderingGroupDrawStage","_afterCameraDrawStage","_afterRenderTargetDrawStage","_afterRenderStage","geometriesByUniqueId","_defaultMeshCandidates","_defaultSubMeshCandidates","_preventFreeActiveMeshesAndRenderingGroups","_activeMeshesFrozen","_skipEvaluateActiveMeshesCompletely","_allowPostProcessClearColor","getDeterministicFrameTime","_blockMaterialDirtyMechanism","fullOptions","useGeometryUniqueIdsMap","virtual","_renderingManager","_createUbo","_imageProcessingConfiguration","setDefaultCandidateProviders","DefaultMaterialFactory","CollisionCoordinatorFactory","unTranslatedPointer","setStepId","newStepId","getStepId","getInternalStep","_activeCamera","_defaultMaterial","_collisionCoordinator","init","_registerTransientComponents","register","_addComponent","serializableComponent","addFromContainer","_getDefaultMeshCandidates","_getDefaultSubMeshCandidates","getActiveMeshCandidates","getActiveSubMeshCandidates","getIntersectingSubMeshCandidates","getCollidingSubMeshCandidates","getCachedMaterial","getCachedEffect","_cachedEffect","getCachedVisibility","isCachedMaterialInvalid","getActiveIndices","getActiveParticles","getActiveBones","getAnimationRatio","_animationRatio","incrementRenderId","_sceneUbo","addUniform","_executeOnceBeforeRender","execFunc","executeOnceBeforeRender","wasLoading","isLoading","getWaitingItemsCount","executeWhenReady","whenReadyAsync","resetLastAnimationTimeFrame","_animationTimeLast","_viewMatrix","setTransformMatrix","viewL","projectionL","viewR","projectionR","_multiviewSceneUbo","useUbo","_updateMultiviewUbo","UniqueId","addMesh","newMesh","recursive","_resyncLightSources","_addToSceneRootNodes","getChildMeshes","removeMesh","toRemove","_removeFromSceneRootNodes","addTransformNode","newTransformNode","_indexInSceneTransformNodesArray","removeTransformNode","lastNode","removeSkeleton","removeMorphTargetManager","removeLight","_removeLightSource","sortLightsByPriority","index2","removeParticleSystem","removeAnimation","animationName","targetMask","removeAnimationGroup","removeMultiMaterial","lastMaterial","removeActionManager","removeTexture","addLight","newLight","CompareLightsPriority","newCamera","addSkeleton","newSkeleton","addParticleSystem","newParticleSystem","addAnimation","newAnimation","addAnimationGroup","newAnimationGroup","addMultiMaterial","newMaterial","addMorphTargetManager","newMorphTargetManager","addGeometry","newGeometry","addActionManager","newActionManager","newTexture","switchActiveCamera","setActiveCameraByID","setActiveCameraByName","getCameraByName","getAnimationGroupByName","getMaterialByUniqueID","getMaterialByName","getTextureByUniqueID","getCameraByUniqueID","getBoneByID","skeletonIndex","boneIndex","getBoneByName","getLightByName","getLightByID","getLightByUniqueID","getParticleSystemByID","_getGeometryByUniqueID","lastGeometry","getGeometries","getMeshByID","getMeshesByID","getTransformNodeByID","getTransformNodeByUniqueID","getTransformNodesByID","getMeshByUniqueID","getLastEntryByID","getNodeByID","transformNode","bone","getNodeByName","getMeshByName","getTransformNodeByName","getSkeletonByUniqueId","getSkeletonById","getSkeletonByName","getMorphTargetById","managerIndex","numTargets","getMorphTargetByName","getPostProcessByName","postProcessIndex","addExternalData","_externalData","getExternalData","getOrAddExternalDataWithFactory","removeExternalData","_evaluateSubMesh","initialMesh","hasInstances","alwaysSelectAsActiveMesh","hasRenderTargetTextures","concatWithNoDuplicate","dispatch","freeActiveMeshes","freeRenderingGroups","blockfreeActiveMeshesAndRenderingGroups","freezeActiveMeshes","skipEvaluateActiveMeshes","_evaluateActiveMeshes","unfreezeActiveMeshes","len_1","psLength","animate","_currentLODIsUpToDate","isBlocked","hasSpecificTriggers2","meshToRender","customLODSelector","_currentLOD","BILLBOARDMODE_NONE","_activate","_actAsRegularMesh","_activeMesh","particleIndex","particleSystem","isStarted","dispatchParticles","prepare","updateTransformMatrix","_bindFrameBuffer","_multiviewTexture","_renderForCamera","rigParent","softwareSkinnedMeshIndex","needRebind","renderIndex","renderTarget","_shouldRender","hasSpecialRenderTargetCamera","_prepareFrame","_finalizeFrame","_processSubCameras","_useMultiviewToSingleView","_renderMultiviewToSingleView","_checkIntersections","actionIndex","parameters","getTriggerParameter","otherMesh","areIntersecting","intersectsMesh","usePreciseIntersection","currentIntersectionInProgress","_intersectionsInProgress","_executeCurrent","parameterMesh","_advancePhysicsEngineStep","step","_animate","deltaTime","MinDeltaTime","MaxDeltaTime","defaultFrameTime","defaultFPS","stepsTaken","maxSubSteps","internalSteps","updateCameras","ignoreAnimations","fetchNewFrame","currentActiveCamera","customIndex","afterRender","freezeMaterials","unfreezeMaterials","beforeRender","stopAllAnimations","clearCachedVertexData","meshIndex","vbName","cleanCachedTextureBuffer","baseTexture","getWorldExtends","filterPredicate","boundingInfo","minBox","maxBox","cameraViewSpace","createPickingRayToRef","createPickingRayInCameraSpace","createPickingRayInCameraSpaceToRef","fastCheck","trianglePredicate","pickWithBoundingInfo","pickWithRay","multiPick","multiPickWithRay","_getByTags","list","listByTags","item","getMeshesByTags","getCamerasByTags","getLightsByTags","getMaterialByTags","getTransformNodesByTags","setRenderingOrder","renderingGroupId","opaqueSortCompareFn","alphaTestSortCompareFn","transparentSortCompareFn","setRenderingAutoClearDepthStencil","autoClearDepthStencil","getAutoClearDepthStencilSetup","useOfflineSupport","_requestFile","onOpened","RequestFile","_requestFileAsync","_readFile","_readFileAsync","FOGMODE_EXP","FOGMODE_EXP2","FOGMODE_LINEAR","SmartArray","_GlobalId","compareFn","SmartArrayNoDuplicate","_duplicateId","__smartArrayFlags","tmpRect","tmpRect2","tmpV1","tmpV2","Measure","addX","addY","addWidth","addHeight","ArrayTools","itemBuilder","Container","_measureForChildren","_background","_adaptWidthToChildren","_adaptHeightToChildren","logLayoutCycleErrors","maxLayoutCycle","getChildByName","getChildByType","typeName","containsControl","control","addControl","clearControls","children_1","_cleanControlAfterRemoval","wasAdded","_localDraw","shadowColor","fillRect","_beforeLayout","computedWidth","computedHeight","adaptWidthToChildren","adaptHeightToChildren","_postMeasure","_changeCursor","Node","_doNotSerialize","_isParentEnabled","_parentUpdateId","_parentNode","_worldMatrixDeterminant","_worldMatrixDeterminantIsDirty","_sceneRootNodesIndex","_isNode","_behaviors","AddNodeConstructor","_NodeConstructors","previousParentNode","_syncParentEnabledState","lastIdx","animationPropertiesOverride","addBehavior","behavior","attachImmediately","attach","removeBehavior","detach","getBehaviorByName","isSynchronized","initialCall","_markSyncedWithParent","checkAncestors","isDescendantOf","ancestor","_getDescendants","node","cullingStrategy","_setReady","getAnimationByName","_AnimationRangeFactory","nAnimations","createRange","deleteAnimationRange","deleteFrames","deleteRange","getAnimationRange","getAnimationRanges","animationRanges","speedRatio","onAnimationEnd","range","serializationRanges","localRange","nodes_1","parsedNode","getHierarchyBoundingVectors","includeDescendants","thisAbstractMesh","descendants_1","childMesh","FilesInputStore","FilesToLoad","RetryStrategy","ExponentialBackoff","maxRetries","baseInterval","retryIndex","BaseError","_setPrototypeOf","proto","LoadFileError","RequestFileError","ReadFileError","FileTools","_CleanUrl","String","crossOrigin","usingObjectURL","Image","createImageBitmap","imgBmp","loadHandler","errorHandler","err","inputText","noOfflineSupport","enableTexturesOffline","loadImage","textureName","decodeURIComponent","blobURL","readAsArrayBuffer","readAsText","loadUrl","aborted","fileRequest","requestFile","retryHandle","readyState","XMLHttpRequest","DONE","retryLoop","responseType","onLoadEnd","onReadyStateChange","IsFileURL","response","responseText","retryStrategy","waitTime","statusText","send","enableSceneOffline","noOfflineSupport_1","loadFile","location","protocol","Space","Coordinate","Axis","PrecisionDate","BoundingBox","worldMatrix","vectors","extendSize","extendSizeWorld","directions","vectorsWorld","minX","minY","maxX","maxY","factor","tmpVectors","TmpVector3","diff","newRadius","minWorld","maxWorld","IsInFrustum","IsCompletelyInFrustum","intersectsPoint","pointX","pointY","pointZ","intersectsSphere","sphere","IntersectsSphere","radiusWorld","intersectsMinMax","myMin","myMax","myMinX","myMinY","myMinZ","myMaxX","myMaxY","myMaxZ","Intersects","box0","box1","minPoint","maxPoint","sphereCenter","sphereRadius","frustumPlane","dotCoordinate","canReturnFalse","BoundingSphere","tempRadiusVector","tempVector","isCenterInFrustum","squareDistance","sphere0","sphere1","radiusSum","_result0","_result1","computeBoxExtents","box","axisOverlap","BoundingInfo","_isLocked","centerOn","extend","_checkCollision","collider","_canDoCollision","intersects","precise","InternalTextureSource","InternalTexture","delayAllocation","baseDepth","Unknown","_bufferView","_bufferViewArray","_bufferViewArrayArray","_extension","_files","_attachments","_isDisabled","_compression","_sphericalPolynomial","_depthStencilTextureArray","_references","updateSize","proxy","_swapAndDie","Raw","Raw3D","Raw2DArray","Dynamic","createDynamicTexture","updateDynamicTexture","RenderTarget","createRenderTargetCubeTexture","size_1","Depth","depthTextureOptions","createDepthStencilTexture","Cube","createCubeTexture","CubeRaw","CubeRawRGBD","_UpdateRGBDAsync","CubePrefiltered","createPrefilteredCubeTexture","sphericalPolynomial","lodScale","lodOffset","StringTools","EndsWith","suffix","Decode","TextDecoder","decode","fromCharCode","chr1","chr2","chr3","enc1","enc2","enc3","enc4","keyStr","output","bytes","NaN","charAt","PadNumber","TransformNode","isPure","_forward","_forwardInverted","_up","_right","_rightInverted","_rotationQuaternion","_scaling","_transformToBoneReferal","_isAbsoluteSynced","_billboardMode","_preserveParentRotationForBillboard","scalingDeterminant","_infiniteDistance","ignoreNonUniformScaling","reIntegrateRotationIntoRotationQuaternion","_poseMatrix","_localMatrix","_usePivotMatrix","_absolutePosition","_absoluteScaling","_absoluteRotationQuaternion","_pivotMatrix","_isWorldMatrixFrozen","onAfterWorldMatrixUpdateObservable","_nonUniformScaling","newRotation","newScaling","updatePoseMatrix","getPoseMatrix","pivotMatrixUpdated","localMatrixUpdated","_syncAbsoluteScalingAndRotation","postMultiplyPivotMatrix","_pivotMatrixInverse","newWorldMatrix","unfreezeWorldMatrix","getAbsolutePosition","setAbsolutePosition","absolutePosition","absolutePositionX","absolutePositionY","absolutePositionZ","invertParentWorldMatrix","setPositionWithLocalVector","getPositionExpressedInLocalSpace","invLocalWorldMatrix","locallyTranslate","lookAt","targetPoint","yawCor","pitchCor","rollCor","space","LOCAL","dv","_lookAtVectorCache","setDirection","WORLD","rotationMatrix","parentRotationMatrix","quaternionRotation","setPivotPoint","tmat","getPivotPoint","getPivotPointToRef","getAbsolutePivotPoint","getAbsolutePivotPointToRef","setParent","quatRotation","diffMatrix","invParentMatrix","_updateNonUniformScalingState","attachToBone","affectedTransformNode","getSkeleton","detachFromBone","_rotationAxisCache","rotateAround","tmpVector","finalScale","finalTranslation","finalRotation","translationMatrix","translationMatrixInv","displacementVector","tempV3","addRotation","accumulation","_getEffectiveParent","useBillboardPosition","BILLBOARDMODE_USE_POSITION","useBillboardPath","preserveParentRotationForBillboard","BILLBOARDMODE_X","BILLBOARDMODE_Y","BILLBOARDMODE_Z","_TmpScaling","cameraWorldMatrix","cameraGlobalPosition","_TmpTranslation","_TmpRotation","scaleMatrix","translation_1","storedTranslation","BILLBOARDMODE_ALL","eulerAngles","independentOfChildren","bakedMatrix","tmpRotationQuaternion","registerAfterWorldMatrixUpdate","unregisterAfterWorldMatrixUpdate","getPositionInCameraSpace","getDistanceToCamera","currentSerializationObject","parsedTransformNode","transformNodes_1","normalizeToUnitCube","ignoreRotation","storedRotation","storedRotationQuaternion","sizeVec","maxDimension","isUndefined","isObject","isPlainObject","isFunction","isArrayBuffer","isBuffer","isFormData","FormData","isArrayBufferView","isString","isNumber","isDate","isFile","isBlob","isStream","pipe","isURLSearchParams","URLSearchParams","isStandardBrowserEnv","product","assignValue","thisArg","stripBOM","WebRequest","_xhr","_native","_injectCustomRequestHeaders","setRequestHeader","listener","method","CustomRequestModifiers","getResponseHeader","PickingInfo","pickedPoint","bu","bv","faceId","subMeshFaceId","pickedSprite","thinInstanceIndex","originMesh","getNormal","useWorldCoordinates","useVerticesNormals","normal0","normal1","normal2","vertex1","vertex2","vertex3","getTextureCoordinates","uv0","uv1","uv2","Light","diffuse","FALLOFF_DEFAULT","intensity","_range","_inverseSquaredRange","_photometricScale","_intensityMode","INTENSITYMODE_AUTOMATIC","_radius","renderPriority","_shadowEnabled","_excludeWithLayerMask","_includeOnlyWithLayerMask","_lightmapMode","_excludedMeshesIds","_includedOnlyMeshesIds","_isLight","_buildUniformLayout","includedOnlyMeshes","excludedMeshes","_resyncMeshes","_computePhotometricScale","_markMeshesAsLightDirty","_includedOnlyMeshes","_hookArrayForIncludedOnly","_excludedMeshes","_hookArrayForExcluded","transferTexturesToEffect","iAsString","needUpdate","_alreadyBound","scaledIntensity","getScaledIntensity","updateColor4","bindShadowLight","getTypeID","_shadowGenerator","canAffectMesh","includeOnlyWithLayerMask","excludeWithLayerMask","clonedLight","excludedMeshesIds","includedOnlyMeshesIds","parsedLight","items_1","_resyncLightSource","deleted_1","_markSubMeshesAsLightDirty","_getPhotometricScale","photometricScale","lightTypeID","photometricMode","intensityMode","LIGHTTYPEID_DIRECTIONALLIGHT","INTENSITYMODE_ILLUMINANCE","INTENSITYMODE_LUMINOUSINTENSITY","LIGHTTYPEID_POINTLIGHT","LIGHTTYPEID_SPOTLIGHT","INTENSITYMODE_LUMINOUSPOWER","INTENSITYMODE_LUMINANCE","apexAngleRadians","LIGHTTYPEID_HEMISPHERICLIGHT","_reorderLightsInScene","_renderPriority","LIGHTMAP_SPECULAR","SubMesh","createBoundingBox","addToMesh","_effectOverride","_linesIndexBuffer","_lastColliderWorldVertices","_lastColliderTransformMatrix","_alphaIndex","_distanceToCamera","_currentMaterial","_mesh","_renderingMesh","_trianglePlanes","setEffect","IsGlobal","setBoundingInfo","getMesh","getReplacementMesh","getEffectiveMesh","replacementMesh","rootMaterial","_IsMultiMaterial","updateBoundingInfo","linesIndices","canIntersects","intersectsBox","checkStopper","_intersectLines","intersectionThreshold","_intersectUnIndexedLines","_intersectUnIndexedTriangles","_intersectTriangles","intersectInfo","intersectionSegment","faceID","indexA","indexB","indexC","currentIntersectInfo","intersectsTriangle","newRenderingMesh","startIndex","minVertexIndex","maxVertexIndex","KeyboardEventTypes","KeyboardInfo","KeyboardInfoPre","ClipboardEventTypes","COPY","CUT","PASTE","ClipboardInfo","GetTypeFromCharacter","keyCode","_checkCollisions","_collisionMask","_collisionGroup","_surroundingMeshes","_collider","_oldPositionForCollisions","_diffPositionForCollisions","_collisionResponse","facetNb","partitioningSubdivisions","partitioningBBoxRatio","facetDataEnabled","facetParameters","facetDepthSort","facetDepthSortEnabled","_InternalAbstractMeshDataInfo","_hasVertexAlpha","_useVertexColors","_numBoneInfluencers","_applyFog","_receiveShadows","_facetData","_visibility","_skeleton","_layerMask","AbstractMesh","CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY","onCollideObservable","onCollisionPositionChangeObservable","onMaterialChangedObservable","definedFacingForward","_occlusionQuery","_renderingGroupId","_material","outlineColor","outlineWidth","useOctreeForRenderingSelection","useOctreeForPicking","useOctreeForCollisions","_meshCollisionData","ellipsoid","ellipsoidOffset","edgesWidth","edgesColor","_edgesRenderer","_lightSources","_bonesTransformMatrices","_transformMatrixTexture","onRebuildObservable","_onCollisionPositionChange","collisionId","collidedMesh","nb","facetDepthSortFrom","_markSubMeshesAsMiscDirty","_onCollideObserver","_onCollisionPositionChangeObserver","needInitialSkinMatrix","_unregisterMeshWithPoseMatrix","_registerMeshWithPoseMatrix","isIn","removed","_markSubMeshesAsDirty","skeletonsEnabled","intermediateRendering","movePOV","amountRight","amountUp","amountForward","calcMovePOV","rotMatrix","translationDelta","defForwardMult","rotatePOV","flipBack","twirlClockwise","tiltRight","calcRotatePOV","overrideMesh","collisionEnabled","moveWithCollisions","displacement","coordinator","collisionCoordinator","createCollider","getNewPosition","_collideForSubMesh","transformMatrix","_collide","_processCollisionsForSubMeshes","collisionsScalingMatrix","collisionsTransformMatrix","onlyBoundingInfo","worldToUse","skipBoundingInfo","pickingInfo","anySubmeshSupportIntersect","worldOrigin","direction","isOcclusionQueryInProgress","disableFacetData","addChild","_initFacetData","updateFacetData","depthSortedIndices","needs32bits","facetDepthSortFunction","f1","f2","depthSortedFacet","invertedMatrix","facetDepthSortOrigin","getFacetLocalNormals","getFacetLocalPositions","getFacetLocalPartitioning","depthSort","sind","facetData","getFacetPosition","getFacetPositionToRef","localPos","getFacetNormal","norm","getFacetNormalToRef","localNorm","getFacetsAtLocalCoordinates","getClosestFacetAtCoordinates","projected","checkFace","facing","invMat","invVect","closest","getClosestFacetAtLocalCoordinates","tmpx","tmpy","tmpz","t0","projx","projy","projz","facetsInBlock","fib","shortest","tmpDistance","getFacetDataParameters","createNormals","alignWithNormal","upDirection","axisX","axisZ","disableEdgesRendering","enableEdgesRendering","checkVerticesInsteadOfIndices","getConnectedParticleSystems","OCCLUSION_TYPE_NONE","OCCLUSION_TYPE_OPTIMISTIC","OCCLUSION_TYPE_STRICT","OCCLUSION_ALGORITHM_TYPE_ACCURATE","OCCLUSION_ALGORITHM_TYPE_CONSERVATIVE","CULLINGSTRATEGY_STANDARD","CULLINGSTRATEGY_OPTIMISTIC_INCLUSION","CULLINGSTRATEGY_OPTIMISTIC_INCLUSION_THEN_BSPHERE_ONLY","PerformanceConfigurator","use64bits","PrePassConfiguration","previousWorldMatrices","AddUniforms","uniforms","AddSamplers","previousViewProjection","PushMaterial","_normalMatrix","_activeEffect","_isReadyForSubMesh","bindOnlyNormalMatrix","normalMatrix","_mustRebind","MaterialFlags","_DiffuseTextureEnabled","_DetailTextureEnabled","_AmbientTextureEnabled","_OpacityTextureEnabled","_ReflectionTextureEnabled","_EmissiveTextureEnabled","_SpecularTextureEnabled","_BumpTextureEnabled","_LightmapTextureEnabled","_RefractionTextureEnabled","_ColorGradingTextureEnabled","_FresnelEnabled","_ClearCoatTextureEnabled","_ClearCoatBumpTextureEnabled","_ClearCoatTintTextureEnabled","_SheenTextureEnabled","_AnisotropicTextureEnabled","_ThicknessTextureEnabled","DetailMapConfiguration","markAllSubMeshesAsTexturesDirty","diffuseBlendLevel","roughnessBlendLevel","bumpLevel","_normalBlendMethod","_internalMarkAllSubMeshesAsTexturesDirty","_areTexturesDirty","texturesEnabled","DetailTextureEnabled","DETAIL_NORMALBLENDMETHOD","DETAIL","isSync","updateFloat4","activeTextures","animatables","PrepareUniformBuffer","copyTo","detailMap","onCreatedEffectParameters","StandardMaterialDefines","MAINUV1","MAINUV2","DIFFUSE","DIFFUSEDIRECTUV","DETAILDIRECTUV","AMBIENT","AMBIENTDIRECTUV","OPACITY","OPACITYDIRECTUV","OPACITYRGB","REFLECTION","EMISSIVE","EMISSIVEDIRECTUV","SPECULAR","SPECULARDIRECTUV","BUMP","BUMPDIRECTUV","PARALLAX","PARALLAXOCCLUSION","SPECULAROVERALPHA","CLIPPLANE","CLIPPLANE2","CLIPPLANE3","CLIPPLANE4","CLIPPLANE5","CLIPPLANE6","ALPHATEST","DEPTHPREPASS","ALPHAFROMDIFFUSE","POINTSIZE","FOG","SPECULARTERM","DIFFUSEFRESNEL","OPACITYFRESNEL","REFLECTIONFRESNEL","REFRACTIONFRESNEL","EMISSIVEFRESNEL","FRESNEL","NORMAL","UV1","UV2","VERTEXCOLOR","VERTEXALPHA","NUM_BONE_INFLUENCERS","BonesPerMesh","BONETEXTURE","BONES_VELOCITY_ENABLED","INSTANCES","THIN_INSTANCES","GLOSSINESS","ROUGHNESS","EMISSIVEASILLUMINATION","LINKEMISSIVEWITHDIFFUSE","REFLECTIONFRESNELFROMSPECULAR","LIGHTMAP","LIGHTMAPDIRECTUV","OBJECTSPACE_NORMALMAP","USELIGHTMAPASSHADOWMAP","REFLECTIONMAP_3D","REFLECTIONMAP_SPHERICAL","REFLECTIONMAP_PLANAR","REFLECTIONMAP_CUBIC","USE_LOCAL_REFLECTIONMAP_CUBIC","REFLECTIONMAP_PROJECTION","REFLECTIONMAP_SKYBOX","REFLECTIONMAP_EXPLICIT","REFLECTIONMAP_EQUIRECTANGULAR","REFLECTIONMAP_EQUIRECTANGULAR_FIXED","REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED","INVERTCUBICMAP","LOGARITHMICDEPTH","REFRACTION","REFRACTIONMAP_3D","REFLECTIONOVERALPHA","TWOSIDEDLIGHTING","SHADOWFLOAT","MORPHTARGETS","MORPHTARGETS_NORMAL","MORPHTARGETS_TANGENT","MORPHTARGETS_UV","NONUNIFORMSCALING","PREMULTIPLYALPHA","ALPHATEST_AFTERALLALPHACOMPUTATIONS","ALPHABLEND","PREPASS_IRRADIANCE","PREPASS_IRRADIANCE_INDEX","PREPASS_ALBEDO","PREPASS_ALBEDO_INDEX","PREPASS_DEPTHNORMAL","PREPASS_DEPTHNORMAL_INDEX","PREPASS_POSITION","PREPASS_POSITION_INDEX","PREPASS_VELOCITY","PREPASS_VELOCITY_INDEX","PREPASS_REFLECTIVITY","PREPASS_REFLECTIVITY_INDEX","RGBDLIGHTMAP","RGBDREFLECTION","RGBDREFRACTION","IMAGEPROCESSING","VIGNETTE","VIGNETTEBLENDMODEMULTIPLY","VIGNETTEBLENDMODEOPAQUE","TONEMAPPING","TONEMAPPING_ACES","CONTRAST","COLORCURVES","COLORGRADING","COLORGRADING3D","SAMPLER3DGREENDEPTH","SAMPLER3DBGRMAP","IMAGEPROCESSINGPOSTPROCESS","IS_REFLECTION_LINEAR","IS_REFRACTION_LINEAR","EXPOSURE","setReflectionMode","modeToEnable","modes_1","StandardMaterial","_diffuseTexture","_ambientTexture","_opacityTexture","_reflectionTexture","_emissiveTexture","_specularTexture","_bumpTexture","_lightmapTexture","_refractionTexture","diffuseColor","specularColor","emissiveColor","specularPower","_useAlphaFromDiffuseTexture","_useEmissiveAsIllumination","_linkEmissiveWithDiffuse","_useSpecularOverAlpha","_useReflectionOverAlpha","_disableLighting","_useObjectSpaceNormalMap","_useParallax","_useParallaxOcclusion","parallaxScaleBias","_roughness","indexOfRefraction","invertRefractionY","alphaCutOff","_useLightmapAsShadowmap","_useReflectionFresnelFromSpecular","_useGlossinessFromSpecularMapAlpha","_maxSimultaneousLights","_invertNormalMapX","_invertNormalMapY","_twoSidedLighting","_worldViewProjectionMatrix","_globalAmbientColor","_rebuildInParallel","_attachImageProcessingConfiguration","ReflectionTextureEnabled","RefractionTextureEnabled","configuration","_imageProcessingObserver","onUpdateParameters","imageProcessingConfiguration","colorCurvesEnabled","colorGradingEnabled","toneMappingEnabled","exposure","contrast","colorGradingTexture","colorCurves","_useLogarithmicDepth","_shouldUseAlphaFromDiffuseTexture","_opacityFresnelParameters","_hasAlphaChannel","DiffuseTextureEnabled","AmbientTextureEnabled","OpacityTextureEnabled","isRGBD","boundingBoxSize","EmissiveTextureEnabled","LightmapTextureEnabled","SpecularTextureEnabled","BumpTextureEnabled","transparencyMode","_areImageProcessingDirty","reflectionTexture","gammaSpace","refractionTexture","_areFresnelDirty","FresnelEnabled","_diffuseFresnelParameters","_emissiveFresnelParameters","_refractionFresnelParameters","_reflectionFresnelParameters","lightDisposed","_areLightsDisposed","markAsProcessed","shaderName","uniformBuffers","PrepareUniforms","PrepareSamplers","csnrOptions","customShaderNameResolve","previousEffect","maxSimultaneousMorphTargets","buildUniformLayout","ubo","needFlag","mustRebind","diffuseFresnelParameters","leftColor","power","rightColor","opacityFresnelParameters","reflectionFresnelParameters","refractionFresnelParameters","emissiveFresnelParameters","updateFloat2","roughness","updateVector3","boundingBoxPosition","updateFloat3","updateFloat","updateColor3","BlackReadOnly","applyByPostProcess","ColorGradingTextureEnabled","Plane","magnitude","_TmpMatrix","copyFromPoints","point1","point2","point3","invPyth","x1","y1","z1","pyth","isFrontFacingTo","signedDistanceTo","FromPoints","FromPositionAndNormal","SignedDistanceToPlaneFromPositionAndNormal","Frustum","GetNearPlaneToRef","GetFarPlaneToRef","GetLeftPlaneToRef","GetRightPlaneToRef","GetTopPlaneToRef","GetBottomPlaneToRef","Size","otherSize","CanvasGenerator","OffscreenCanvas","WebGLDataBuffer","resource","DataBuffer","PositionNormalVertex","PositionNormalTextureVertex","Viewport","toGlobal","toGlobalToRef","PerfCounter","_startMonitoringTime","_min","_max","_average","_lastSecAverage","_current","_totalValueCount","_totalAccumulated","_lastSecAccumulated","_lastSecTime","_lastSecValueCount","newCount","fetchResult","Enabled","_fetchResult","beginMonitoring","endMonitoring","newFrame","currentTime","ColorCurves","_dirty","_tempColor","_globalCurve","_highlightsCurve","_midtonesCurve","_shadowsCurve","_positiveCurve","_negativeCurve","_globalHue","_globalDensity","_globalSaturation","_globalExposure","_highlightsHue","_highlightsDensity","_highlightsSaturation","_highlightsExposure","_midtonesHue","_midtonesDensity","_midtonesSaturation","_midtonesExposure","_shadowsHue","_shadowsDensity","_shadowsSaturation","_shadowsExposure","Bind","positiveUniform","neutralUniform","negativeUniform","getColorGradingDataToRef","density","clamp","applyColorGradingSliderNonlinear","fromHSBToRef","brightness","ImageProcessingConfigurationDefines","ImageProcessingConfiguration","_colorCurvesEnabled","_colorGradingEnabled","_colorGradingWithGreenDepth","_colorGradingBGR","_exposure","_toneMappingEnabled","_toneMappingType","TONEMAPPING_STANDARD","_contrast","vignetteStretch","vignetteCentreX","vignetteCentreY","vignetteWeight","vignetteColor","vignetteCameraFov","_vignetteBlendMode","VIGNETTEMODE_MULTIPLY","_vignetteEnabled","_applyByPostProcess","_updateParameters","_colorGradingTexture","forPostProcess","vignetteEnabled","vignetteBlendMode","_VIGNETTEMODE_MULTIPLY","colorGradingWithGreenDepth","colorGradingBGR","overrideAspectRatio","inverseWidth","inverseHeight","vignetteScaleY","vignetteScaleX","vignetteScaleGeometricMean","vignettePower","textureSize","_VIGNETTEMODE_OPAQUE","axios","default","buttonSVGs","logo","toJson","labels","publish","replay","record","styleText","colorVar","legendData","zScale","_coords","_coordColors","resetAnimation","matrixMax","matrixMin","getUniqueVals","seen","Set","has","Plot","PLOTTYPES","plotData","plotIdx","plot","pltType","prop","canvasElement","_showLegend","_hasAnim","_axes","_downloadObj","_recording","_turned","_wasTurning","_xScale","_yScale","_zScale","plots","fixedSize","ymax","R","_uniqID","opts","backgroundColor","turntable","rotationRate","_backgroundColor","ArcRotateCamera","attached","keyboard","wheelPrecision","_hl1","HemisphericLight","_hl2","_annotationManager","AnnotationManager","_prepRender","_afterRender","styleElem","createTextNode","buttonBar","clientTop","clientLeft","parentNode","_buttonBar","fromJSON","addImgStack","colorScale","showLegend","fontColor","legendTitle","legendTitleFontSize","legendPosition","showAxes","axisLabels","axisColors","tickBreaks","showTickLines","tickLineColors","addPlot","customColorScale","colorScaleInverted","sortedCategories","folded","foldedEmbedding","foldAnimDelay","foldAnimDuration","colnames","rownames","fixedLabels","labelData","addLabels","label","addLabel","createButtons","whichBtns","jsonBtn","onclick","_downloadJson","labelBtn","toggleLabelControl","recordBtn","_startRecording","publishBtn","_createPublishForm","_prepDownloadObj","exportLabels","dlElement","dlContent","encodeURIComponent","stringify","_publishFormOverlay","formOverlay","formBox","margin","padding","borderRadius","boxShadow","formInfo","innerText","usernameLabel","usernameInput","passwordLabel","passwordInput","titleLabel","titleInput","msg","_tryPublish","cancelBtn","_cancelPublish","closeBtn","_resizePublishOverlay","thumbnail","thumb_data","headers","username","password","plotName","thumb","_resetAnimation","rangeX","rangeY","rangeZ","axisData","worker","_capturer","CCapture","framerate","verbose","workersPath","loadingOverlay","loadingText","stop","_cameraFitPlot","xRange","yRange","zRange","xSize","ySize","zSize","BoxBuilder","xCenter","yCenter","zCenter","halfMinFov","atan","viewRadius","plotType","discrete","breaks","inverted","ImgStack","_updateLegend","dim","colorBy","shading","coordColors","replayBtn","groups","uniqueGroups","nColors","brewer","Paired","domain","colorIndex","Oranges","cl","PointCloud","Surface","ShapeCloud","HeatMap","static","tickLineColor","showPlanes","planeColor","Axes","_legend","uiLayer","AdvancedDynamicTexture","CreateFullscreenUI","rightFree","leftFree","_createPlotLegend","breakN","grid","Grid","legendWidth","legendColumn","addColumnDefinition","addRowDefinition","TextBlock","innerGrid","legendColor","Rectangle","background","legendText","textHorizontalAlignment","nBreaks","labelSpace","scaleGrid","labelGrid","minText","maxText","doRender","pad","saveCallback","ScreenshotTools","labelList","Plots","cloneValue","destinationObject","DeepCopier","proerties_1","props","getOwnPropertyNames","getAllPropertyNames","typeOfSourceValue","clonedValue","extractMinAndMaxIndexed","extractMinAndMax","createUniformBuffer","elements","UNIFORM_BUFFER","createDynamicUniformBuffer","updateUniformBuffer","bindBufferBase","UniformBuffer","dynamic","_noUBO","_dynamic","_uniformLocations","_uniformSizes","_uniformLocationPointer","_needSync","updateMatrix3x3","_updateMatrix3x3ForEffect","updateMatrix2x2","_updateMatrix2x2ForEffect","_updateFloatForEffect","_updateFloat2ForEffect","_updateFloat3ForEffect","_updateFloat4ForEffect","_updateMatrixForEffect","_updateVector3ForEffect","updateVector4","_updateVector4ForEffect","_updateColor3ForEffect","_updateColor4ForEffect","_updateMatrix3x3ForUniform","_updateMatrix2x2ForUniform","_updateFloatForUniform","_updateFloat2ForUniform","_updateFloat3ForUniform","_updateFloat4ForUniform","_updateMatrixForUniform","_updateVector3ForUniform","_updateVector4ForUniform","_updateColor3ForUniform","_updateColor4ForUniform","isDynamic","_bufferData","_fillAlignment","alignment","oldPointer","addMatrix","addFloat2","addFloat3","addColor3","addColor4","addMatrix3x3","addMatrix2x2","updateUniform","_tempBuffer","updateUniformDirectly","_MAX_UNIFORM_SIZE","InstantiationTools","TimingTools","setImmediate","PostProcessManager","_prepareBuffers","vertices","_buildIndexBuffer","sourceTexture","activate","targetTexture","doNotBindFrambuffer","doNotPresent","IntersectionInfo","ShaderCodeNode","isValid","preprocessors","process","line","lineProcessor","uniformProcessor","uniformBufferProcessor","lookForClosingBracketForUniformBuffer","endOfUniformBufferProcessor","additionalDefineKey","additionalDefineValue","ShaderCodeCursor","_lines","lineIndex","value_1","subLine","ShaderCodeConditionNode","ShaderCodeTestNode","testExpression","isTrue","ShaderDefineExpression","postfixToInfix","postfix","stack","postfix_1","_OperatorPriority","v2","infixToPostfix","infix","stackIdx","pushOperand","operand","_Stack","peek","token","ShaderDefineIsDefinedOperator","not","ShaderDefineOrOperator","leftOperand","rightOperand","ShaderDefineAndOperator","ShaderDefineArithmeticOperator","testValue","regexSE","regexSERevert","ShaderProcessor","sourceCode","_ProcessIncludes","codeWithIncludes","migratedCode","_ProcessShaderConversion","_ProcessPrecision","_ExtractOperation","expression","operator","indexOperator","operators_1","_BuildSubExpression","_BuildExpression","command","_MoveCursorWithinIf","rootNode","ifNode","currentLine","_MoveCursor","first5","elseNode","elifNode","canRead","newRootNode","newNode","_EvaluatePreProcessors","_PreparePreProcessors","defines_1","preparedSourceCode","preProcessor","regex","returnValue","keepProcessing","includeFile","includeShaderUrl","fileContent","includeContent","splits","indexString","indexSplits","minIndex","maxIndex","sourceIncludeContent","Orientation","BezierCurve","Interpolate","f0","refinedT","refinedT2","Angle","radians","_radians","degrees","BetweenTwoPoints","FromRadians","FromDegrees","Arc2","startPoint","midPoint","endPoint","startToMid","midToEnd","centerPoint","startAngle","a1","a2","a3","Path2","_points","_length","closed","addLineTo","newPoint","previousPoint","addArcTo","midX","midY","endX","endY","numberOfSegments","increment","currentAngle","lastPoint","getPoints","getPointAtLengthPosition","normalizedLengthPosition","lengthPosition","previousOffset","bToA","nextOffset","dir","localOffset","StartingAt","Path3D","firstNormal","raw","alignTangentsWithPath","_curve","_distances","_tangents","_binormals","_pointAtData","previousPointArrayIndex","subPosition","interpolateReady","interpolationMatrix","_raw","_alignTangentsWithPath","_compute","getCurve","getBinormals","getDistances","getPointAt","_updatePointAtData","getTangentAt","interpolated","getNormalAt","getBinormalAt","UpReadOnly","getDistanceAt","getPreviousPointIndexAt","getSubPositionAt","getClosestPositionTo","smallestDistance","closestPosition","subLength","_start","curvePoints","endIndex","slicePoints","_getFirstNonNullVector","prev","curTang","prevNor","prevBinor","tg0","pp0","_normalVector","_getLastNonNullVector","nNVector","nLVector","vt","va","tgl","interpolateTNB","_updateInterpolationMatrix","_setPointAtData","currentPoint","currentLength","targetLength","parentIndex","tangentFrom","normalFrom","binormalFrom","tangentTo","normalTo","binormalTo","quatFrom","quatTo","Curve3","_computeLength","CreateQuadraticBezier","nbPoints","bez","val0","val1","val2","CreateCubicBezier","v3","val3","CreateHermiteSpline","t1","t2","hermite","CreateCatmullRomSpline","catmullRom","pointsCount","totalPoints","continue","curve","continuedPoints","RenderTargetCreationOptions","GUID","MaterialDefines","disposed","_keys","keys","isEqual","cloneTo","EffectFallbacks","_defines","_currentRank","_maxRank","currentDefines","currentFallbacks","RenderingGroup","_opaqueSubMeshes","_transparentSubMeshes","_alphaTestSubMeshes","_depthOnlySubMeshes","_particleSystems","_spriteManagers","_opaqueSortCompareFn","_renderOpaque","renderOpaqueSorted","renderUnsorted","_alphaTestSortCompareFn","_renderAlphaTest","renderAlphaTestSorted","_transparentSortCompareFn","defaultTransparentSortCompare","_renderTransparent","renderTransparentSorted","customRenderFunction","renderSprites","renderParticles","activeMeshes","stencilState","_renderSprites","_renderParticles","onBeforeTransparentRendering","edgesRendererIndex","renderSorted","sortCompareFn","transparent","cameraPosition","_zeroVector","sortedArray","needDepthPrePass","backToFrontSortCompare","frontToBackSortCompare","dispatchSprites","spriteManager","onBeforeSpritesRenderingObservable","onAfterSpritesRenderingObservable","RenderingGroupInfo","RenderingManager","_useSceneAutoClearSetup","_renderingGroups","_autoClearDepthStencil","_customOpaqueSortCompareFn","_customAlphaTestSortCompareFn","_customTransparentSortCompareFn","_renderingGroupInfo","MIN_RENDERINGGROUPS","MAX_RENDERINGGROUPS","_clearDepthStencilBuffer","_depthStencilBufferAlreadyCleaned","info","spriteManagers","renderingGroup","renderingGroupMask","AUTOCLEAR","_prepareRenderingGroup","group","topBaseAt","bottomBaseAt","topIndex","bottomIndex","basePositions","topFaceBase","bottomFaceBase","topFaceOrder","bottomFaceOrder","flat","scaleArray","accumulator","currentValue","currentIndex","faceUV","faceColors","totalColors","clip_rgb","_clipped","_unclipped","classToType","unpack","keyOrder","utils","TWOPI","PITHIRD","DEG2RAD","RAD2DEG","autodetect","last$1","clip_rgb$1","type$1","Color","me","sorted","chk","_rgb","Color_1","Function","chroma_1","unpack$1","rgb2cmyk_1","unpack$2","cmyk2rgb_1","unpack$3","type$2","cmyk","unpack$4","last$2","rnd","hsl2css_1","hsla","unpack$5","rgb2hsl_1","unpack$6","last$3","rgb2css_1","rgba","unpack$7","round$1","hsl2rgb_1","t3","h_","RE_RGB","RE_RGBA","RE_RGB_PCT","RE_RGBA_PCT","RE_HSL","RE_HSLA","round$2","css2rgb","css","named","rgb$1","i$1","rgb$2","i$2","rgb$3","i$3","hsl","rgb$4","hsl$1","rgb$5","css2rgb_1","type$3","rest","unpack$8","unpack$9","rgb2hcg_1","unpack$a","hcg2rgb_1","assign$1","assign$2","assign$3","assign$4","assign$5","unpack$b","type$4","hcg","unpack$c","last$4","round$3","rgb2hex_1","hxa","RE_HEX","RE_HEXA","hex2rgb_1","u$1","type$5","unpack$d","rgb2hsi_1","min_","unpack$e","limit$1","TWOPI$1","hsi2rgb_1","unpack$f","type$6","hsi","unpack$g","type$7","unpack$h","min$1","max$1","rgb2hsv","max_","unpack$i","floor$1","hsv2rgb_1","unpack$j","type$8","hsv","labConstants","Kn","Xn","Yn","Zn","unpack$k","rgb2lab","ref$1","rgb2xyz","rgb_xyz","xyz_lab","rgb2lab_1","unpack$l","pow$1","lab2rgb","lab_xyz","xyz_rgb","lab2rgb_1","unpack$m","type$9","lab","unpack$n","sqrt$1","round$4","lab2lch_1","unpack$o","rgb2lch_1","b_","unpack$p","cos$1","lch2lab_1","unpack$q","lch2rgb_1","L","unpack$r","hcl2rgb_1","hcl","unpack$s","type$a","lch","w3cx11_1","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflower","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgreen","darkgrey","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","green","greenyellow","grey","honeydew","hotpink","indianred","indigo","ivory","khaki","laserlemon","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrod","lightgoldenrodyellow","lightgray","lightgreen","lightgrey","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","maroon2","maroon3","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","purple2","purple3","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen","type$b","unpack$t","rgb2num_1","type$c","num2rgb_1","type$d","unpack$u","type$e","round$5","temperature2rgb_1","kelvin","unpack$v","round$6","rgb2temperature_1","minTemp","maxTemp","eps","temperature","type$f","mutate","clipped","darken","brighten","darker","brighter","mc","type$g","pow$2","EPS","MAX_ITER","luminance","lum","cur_lum","max_iter","low","high","mid","interpolate","lm","rgb2luminance","luminance_x","interpolator","type$h","mix","col1","col2","premultiply","saturate","desaturate","type$i","out","xyz0","xyz1","sqrt$2","pow$3","lrgb","lab$1","_hsx","hue0","hue1","sat0","sat1","lbv0","lbv1","sat","lch$1","num$1","c2","hcg$1","hsi$1","hsv$1","clip_rgb$2","pow$4","sqrt$3","PI$1","cos$2","sin$1","atan2$1","weights","_average_lrgb","shift","xyz","cnt","dx","dy","A","ci","xyz2","A$1","col","type$j","pow$5","_mode","_nacol","_spread","_domain","_padding","_classes","_colors","_out","_correctLightness","_colorCache","_useCache","_gamma","setColors","c$1","resetCache","getClass","tMapLightness","tMapDomain","getColor","bypassMap","analyze","limits","tOut","tBreaks","every","spread","correctLightness","L0","L1","pol","L_actual","L_ideal","L_diff","numColors","dd","__range__","asc","nodata","inclusive","ascending","bezier","I","lab0","lab1","lab2","lab3","I0","I1","bezier_1","blend","blend_f","c0","each","darken$1","lighten","screen","overlay","burn","dodge","blend_1","type$k","clip_rgb$3","TWOPI$2","pow$6","sin$2","cos$3","cubehelix","rotations","lightness","dl","dh","amp","cos_a","sin_a","digits","floor$2","random_1","log$1","pow$7","floor$3","sum","min_log","LOG10E","max_log","pb","pr","cluster","assignments","clusterSizes","repeat","nb_iters","centroids","i$4","mindist","best","j$1","dist","newCentroids","j$2","i$5","j$3","j$4","kClusters","j$5","i$6","tmpKMeansBreaks","j$6","i$7","analyze_1","sqrt$4","atan2$2","abs$1","cos$4","PI$2","deltaE","C","b1","L2","b2","sl","sc","h1","c4","sh","delC","delA","delB","sum_sq","scales","cool","hot","colorbrewer","OrRd","PuBu","BuPu","BuGn","YlOrBr","YlGn","Reds","RdPu","Greens","YlGnBu","Purples","GnBu","Greys","YlOrRd","PuRd","Blues","PuBuGn","Viridis","Spectral","RdYlGn","RdBu","PiYG","PRGn","RdYlBu","BrBG","RdGy","PuOr","Set2","Accent","Set1","Set3","Dark2","Pastel2","Pastel1","list$1","colorbrewer_1","PlaneBuilder","sourcePlane","premulAlpha","forceBindTexture","glformat","DynamicTexture","_generateMipMaps","_canvas","_context","_recreate","scaleTo","drawText","textSize","measureText","fillText","_IsCanvasElement","encode","params","paramsSerializer","serializedParams","parts","toISOString","hashmarkIndex","__CANCEL__","normalizeHeaderName","DEFAULT_CONTENT_TYPE","setContentTypeIfUnset","adapter","defaults","transformRequest","transformResponse","xsrfCookieName","xsrfHeaderName","maxContentLength","maxBodyLength","validateStatus","common","settle","cookies","buildURL","buildFullPath","parseHeaders","isURLSameOrigin","createError","config","requestData","requestHeaders","auth","unescape","Authorization","btoa","fullPath","baseURL","onreadystatechange","responseHeaders","getAllResponseHeaders","onabort","ontimeout","timeoutErrorMessage","xsrfValue","withCredentials","read","onDownloadProgress","onUploadProgress","upload","cancelToken","cancel","enhanceError","config1","config2","valueFromConfig2Keys","mergeDeepPropertiesKeys","defaultToConfig2Keys","directMergeKeys","getMergedValue","mergeDeepProperties","axiosKeys","otherKeys","Cancel","hasRings","enclose","surfaceNb","angle_step","ringVertex","ringNormal","ringFirstVertex","ringFirstNormal","quadNormal","ringIdx","cs","i2","i3","createCylinderCap","isTop","circleVector","vbase","textureScale","textureCoordinate","CylinderBuilder","cylinder","_thickness","_cornerRadius","_drawRoundedRect","fill","stroke","moveTo","lineTo","quadraticCurveTo","TextWrapping","_text","_textWrapping","Clip","_textHorizontalAlignment","_textVerticalAlignment","_resizeToFit","_lineSpacing","_outlineWidth","_outlineColor","_underline","_lineThrough","onTextChangedObservable","onLinesReadyObservable","_breakLines","maxLineWidth","newWidth","internalValue","newHeight","lineSpacing","_drawText","textWidth","strokeText","_renderLines","lineJoin","miterLimit","refWidth","Ellipsis","_lines_1","_line","_parseLineEllipsis","WordWrap","_lines_2","_parseLineWordWrap","_lines_3","_parseLine","characters","words","wordSplittingFunction","testLine","testWidth","rootY","computeExpectedHeight","widthInPixels","context_1","_loaded","_stretch","STRETCH_FILL","_autoScale","_sourceLeft","_sourceTop","_sourceWidth","_sourceHeight","_svgAttributesComputationCompleted","_isSVG","_cellWidth","_cellHeight","_cellId","_populateNinePatchSlicesFromImage","_imageDataCache","onImageLoadedObservable","onSVGAttributesComputedObservable","_extractNinePatchSliceDataFromImage","_detectPointerOnOpaqueOnly","_sliceLeft","_sliceRight","_sliceTop","_sliceBottom","synchronizeSizeWithContent","_rotate90","preserveProperties","_domImage","dataUrl","rotatedImage","_handleRotationForSVGImage","srcImage","dstImage","_rotate90SourceProperties","srcLeft","sourceLeft","srcTop","sourceTop","srcWidth","domImage","srcHeight","dstLeft","dstTop","dstWidth","sourceWidth","dstHeight","sourceHeight","_onImageLoaded","_imageWidth","_imageHeight","_svgCheck","SVGSVGElement","svgsrc","elemid","svgExist","querySelector","svgDoc","contentDocument","documentElement","getAttribute","docwidth","docheight","_getSVGAttribs","svgImage","svgobj","elem","vb_width","vb_height","elem_bbox","getBBox","elem_matrix_a","elem_matrix_d","elem_matrix_e","elem_matrix_f","baseVal","consolidate","STRETCH_NONE","STRETCH_UNIFORM","STRETCH_NINE_PATCH","STRETCH_EXTEND","_prepareWorkingCanvasForOpaqueDetection","clearRect","_drawImage","sw","tw","th","cellId","rowCount","naturalWidth","cellWidth","column","cellHeight","hRatio","vRatio","centerX","centerY","_renderNinePatch","_renderCornerPatch","targetX","targetY","leftWidth","topHeight","bottomHeight","rightWidth","centerWidth","targetCenterWidth","sliceLeft","targetTopHeight","Button","delegatePickingToChildren","alphaStore","pointerEnterAnimation","pointerOutAnimation","pointerDownAnimation","pointerUpAnimation","_image","_textBlock","CreateImageButton","imageUrl","textBlock","textWrapping","iconImage","stretch","CreateImageOnlyButton","CreateSimpleButton","CreateImageWithCenterTextButton","StackPanel","_isVertical","_manualWidth","_manualHeight","_doNotTrackManualChanges","ignoreLayoutWarnings","isVertical","stackWidth","stackHeight","panelWidthChanged","panelHeightChanged","previousHeight","previousWidth","Checkbox","_isChecked","_checkSizeRatio","onIsCheckedChangedObservable","actualWidth","actualHeight","offsetWidth","offseHeight","isChecked","AddCheckBoxWithHeader","title","onValueChanged","panel","checkbox","header","TextWrapper","_characters","txt","removePart","idxStart","idxEnd","insertTxt","newCharacters","isWord","rWord","InputText","_placeholderText","_focusedBackground","_focusedColor","_placeholderColor","_margin","_autoStretchWidth","_maxWidth","_isFocused","_blinkIsEven","_cursorOffset","_deadKey","_addKey","_currentKey","_isTextHighlightOn","_textHighlightColor","_highligherOpacity","_highlightedText","_startHighlightIndex","_endHighlightIndex","_cursorIndex","_onFocusSelectAll","_isPointerDown","promptMessage","disableMobilePrompt","onBeforeKeyAddObservable","onFocusObservable","onBlurObservable","onTextHighlightObservable","onTextCopyObservable","onTextCutObservable","onTextPasteObservable","onKeyboardEventProcessedObservable","_textWrapper","valueAsString","_textHasChanged","autoStretchWidth","onBlur","_scrollLeft","_blinkTimeout","unRegisterClipboardEvents","_onClipboardObserver","onClipboardObservable","_onPointerDblTapObserver","onFocus","prompt","focusedControl","registerClipboardEvents","clipboardInfo","_onCopyText","_onCutText","_onPasteText","_processDblClick","_selectAllText","keepsFocusWith","_connectedVirtualKeyboard","processKey","ctrlKey","metaKey","deletePosition","shiftKey","deadKey","insertPosition","_updateValueFromCursorIndex","moveLeft","moveRight","_clickedCoordinate","processKeyboard","clipboardData","setData","types","clipTextLeft","_beforeRenderText","_textWidth","marginWidth","availableWidth","textLeft","absoluteCursorPosition","currentSize","previousDist","cursorOffsetText","cursorOffsetWidth","cursorLeft","highlightCursorOffsetWidth","highlightCursorLeft","focusedColor","_capturingControl","textWrapper","_rowDefinitions","_columnDefinitions","_cells","_childControls","getRowDefinition","getColumnDefinition","setRowDefinition","setColumnDefinition","getChildrenAt","cell","getChildCellInfo","_tag","_removeCell","childIndex","_offsetCell","previousKey","removeColumnDefinition","removeRowDefinition","goodContainer","_getGridDefinitions","definitionCallback","widths","heights","lefts","tops","globalWidthPercentage","availableHeight","globalHeightPercentage","top_1","ColorPicker","_tmpColor","_pointerStartedOnSquare","_pointerStartedOnWheel","_squareLeft","_squareTop","_squareSize","_s","_v","_lastPointerDownID","onValueChangedObservable","_pointerIsDown","_Epsilon","_updateSquareProps","squareSize","_drawGradientSquare","hueValue","lgh","createLinearGradient","addColorStop","lgv","_drawCircle","_createColorWheelCanvas","maxDistSq","innerRadius","minDistSq","distSq","ang","alphaAmount","alphaRatio","wheelThickness","_colorWheelCanvas","_updateValueFromPointer","_isPointOnSquare","_isPointOnWheel","ShowPickerDialogAsync","advancedTexture","pickerWidth","pickerHeight","headerHeight","lastColor","swatchLimit","numSwatchesPerLine","closeIconColor","buttonFontSize","butEdit","buttonWidth","buttonHeight","currentColor","swatchNumber","swatchDrawer","picker","rValInt","gValInt","bValInt","rValDec","gValDec","bValDec","hexVal","newSwatch","lastVal","activeField","drawerMaxRows","rawSwatchSize","gutterSize","colGutters","swatchSize","drawerMaxSize","containerSize","buttonColor","buttonBackgroundColor","buttonBackgroundHoverColor","buttonBackgroundClickColor","luminanceLimitColor","luminanceLimit","inputFieldLabels","inputTextBackgroundColor","inputTextColor","editSwatchMode","updateValues","inputField","pickedColor","minusPound","updateInt","field","newValue","newSwatchRGB","createSwatch","savedColors","icon","swatch","swatchColor","swatchLuminence","metadata_1","setEditButtonVisibility","updateSwatches","butSave","editSwatches","gutterCount","currentRows","thisRow","totalButtonsThisRow","buttonIterations","disableButton","enableButton","pickerGrid","disabled","closePicker","dialogContainer","topRow","initialRows","pickerPanel","panelHead","pickerPanelRows","closeButton","headerColor3","textVerticalAlignment","currentSwatch","dialogBody","dialogBodyCols","pickerBodyRight","pickerBodyRightRows","pickerSwatchesButtons","pickerButtonsCol","pickerSwatches","pickeSwatchesRows","activeSwatches","labelWidth","labelHeight","labelTextSize","newText","swatchOutline","currentText","buttonGrid","buttonGridRows","butOK","butCancel","pickerColorValues","rgbValuesQuadrant","labelText","hexValueQuadrant","newHexValue","checkHex","leadingZero","Ellipse","InputPassword","pwdTextWrapper","Line","_lineWidth","_x1","_y1","_x2","_y2","_dash","_connectedControl","_connectedControlDirtyObserver","setLineDash","_effectiveX2","_effectiveY2","MultiLinePoint","multiLine","_multiLine","_point","_control","_controlObserver","onPointUpdate","_meshObserver","resetLinks","_translatePoint","getProjectedPositionWithZ","xValue","yValue","MultiLine","getAt","_minX","_minY","_maxX","_maxY","RadioButton","executeOnAllControls","childRadio","AddRadioButtonWithHeader","radio","BaseSlider","_thumbWidth","_minimum","_maximum","_barOffset","_isThumbClamped","_displayThumb","_step","_effectiveBarOffset","_getThumbPosition","_backgroundBoxLength","_getThumbThickness","thumbThickness","_backgroundBoxThickness","_prepareRenderingData","_renderLeft","_renderTop","_renderWidth","_renderHeight","_effectiveThumbThickness","displayThumb","isThumbClamped","Slider","_borderColor","_thumbColor","_isThumbCircle","_displayValueBar","isThumbCircle","thumbPosition","SelectorGroup","_groupPanel","_selectors","_groupHeader","_addGroupHeader","groupHeading","_getSelector","selectorNb","removeSelector","CheckboxGroup","addCheckbox","checked","_selector","isHorizontal","controlFirst","groupPanel","selectors","buttonBackground","_setSelectorLabel","_setSelectorLabelColor","_setSelectorButtonColor","_setSelectorButtonBackground","RadioGroup","_selectNb","addRadio","SliderGroup","addSlider","onValueChange","borderColor","SelectionPanel","_buttonColor","_buttonBackground","_headerColor","_barColor","_barHeight","_spacerHeight","_bars","_groups","_panel","_addSpacer","_setHeaderColor","_setbuttonColor","_labelColor","_setLabelColor","_setButtonBackground","_setBarColor","_setBarHeight","_setSpacerHeight","separator","bar","addGroup","removeGroup","groupNb","setHeaderName","relabel","removeFromGroupSelector","addToGroupCheckbox","addToGroupRadio","addToGroupSlider","onVal","_ScrollViewerWindow","_freezeControls","_bucketWidth","_bucketHeight","_buckets","_restoreMeasures","_updateMeasures","_useBuckets","_makeBuckets","setBucketSizes","_bucketLen","_dispatchInBuckets","_oldLeft","_oldTop","bStartX","_origLeft","origLeft","bEndX","bStartY","_origTop","origTop","bEndY","bucket","lstc","leftInPixels","topInPixels","origLeftForChildren","origTopForChildren","_updateChildrenMeasures","_parentMeasure","_scrollChildren","_scrollChildrenWithBuckets","scrollLeft","scrollTop","maxWidth","parentClientWidth","parentClientHeight","ScrollBar","_tempMeasure","_first","_originX","_originY","ImageScrollBar","_thumbLength","_thumbHeight","_barImageHeight","num90RotationInVerticalMode","_backgroundBaseImage","isLoaded","_backgroundImage","rotatedValue","_thumbBaseImage","_thumbImage","ScrollViewer","isImageBased","_barSize","_pointerIsOver","_wheelPrecision","_horizontalBarImageHeight","_verticalBarImageHeight","_oldWindowContentsWidth","_oldWindowContentsHeight","_forceHorizontalBar","_forceVerticalBar","_useImageBar","_horizontalBarSpace","_verticalBarSpace","_dragSpace","_grid","_horizontalBar","_verticalBar","_window","_addBar","barColor","barBackground","freezeControls","bucketWidth","bucketHeight","resetWindow","_buildClientSizes","idealRatio","forceVerticalBar","forceHorizontalBar","_clientWidth","_clientHeight","_updateScroller","_setWindowPosition","_barImage","hb","thumbImage","_horizontalBarImage","_verticalBarImage","thumbLength","thumbHeight","barImageHeight","_barBackground","_barBackgroundImage","backgroundImage","_horizontalBarBackgroundImage","_verticalBarBackgroundImage","windowContentsWidth","windowContentsHeight","_endLeft","_endTop","thumbWidth","_attachWheel","barControl","barContainer","barOffset","_onWheelObserver","KeyPropertySet","VirtualKeyboard","onKeyPressObservable","defaultButtonWidth","defaultButtonHeight","defaultButtonPaddingLeft","defaultButtonPaddingRight","defaultButtonPaddingTop","defaultButtonPaddingBottom","defaultButtonColor","defaultButtonBackground","shiftButtonColor","selectedShiftThickness","shiftState","_currentlyConnectedInputText","_connectedInputTexts","_onKeyPressObserver","_createKey","propertySet","addKeysRow","propertySets","maxKey","properties","heightInPixels","applyShiftState","rowContainer","button_tblock","connect","some","onFocusObserver","onBlurObserver","disconnect","filtered","_removeConnectedInputObservables","connectedInputText","CreateDefaultLayout","DisplayGrid","_minorLineTickness","_minorLineColor","_majorLineTickness","_majorLineColor","_majorLineFrequency","_displayMajorLines","_displayMinorLines","cellCountX","cellCountY","cellX","cellY","ImageBasedSlider","_valueBarImage","LayerSceneComponent","_drawCameraBackground","_drawCameraForeground","_drawRenderTargetBackground","_drawRenderTargetForeground","layers_1","layers_2","_drawCameraPredicate","isBackground","cameraLayerMask","renderOnlyInRenderTargetTextures","_drawRenderTargetPredicate","renderTargetTextures","removeFromContainer","Layer","imgUrl","alphaBlendingMode","layerComponent","_createIndexBuffer","_previousDefines","currentEffect","Style","Constants","ALPHA_ONEONE_ONEONE","ALPHA_ALPHATOCOLOR","ALPHA_REVERSEONEMINUS","ALPHA_SRC_DSTONEMINUSSRCALPHA","ALPHA_ONEONE_ONEZERO","ALPHA_EXCLUSION","ALPHA_EQUATION_ADD","ALPHA_EQUATION_SUBSTRACT","ALPHA_EQUATION_REVERSE_SUBTRACT","ALPHA_EQUATION_MAX","ALPHA_EQUATION_MIN","ALPHA_EQUATION_DARKEN","TEXTURE_FILTERING_QUALITY_OFFLINE","TEXTURE_FILTERING_QUALITY_HIGH","TEXTURE_FILTERING_QUALITY_MEDIUM","TEXTURE_FILTERING_QUALITY_LOW","MATERIAL_TextureDirtyFlag","MATERIAL_LightDirtyFlag","MATERIAL_FresnelDirtyFlag","MATERIAL_AttributesDirtyFlag","MATERIAL_MiscDirtyFlag","MATERIAL_PrePassDirtyFlag","MATERIAL_AllDirtyFlag","MATERIAL_TriangleFillMode","MATERIAL_WireFrameFillMode","MATERIAL_PointFillMode","MATERIAL_PointListDrawMode","MATERIAL_LineListDrawMode","MATERIAL_LineLoopDrawMode","MATERIAL_LineStripDrawMode","MATERIAL_TriangleStripDrawMode","MATERIAL_TriangleFanDrawMode","MATERIAL_ClockWiseSideOrientation","MATERIAL_CounterClockWiseSideOrientation","ACTION_NothingTrigger","ACTION_OnPickTrigger","ACTION_OnLeftPickTrigger","ACTION_OnRightPickTrigger","ACTION_OnCenterPickTrigger","ACTION_OnPickDownTrigger","ACTION_OnDoublePickTrigger","ACTION_OnPickUpTrigger","ACTION_OnPickOutTrigger","ACTION_OnLongPressTrigger","ACTION_OnPointerOverTrigger","ACTION_OnPointerOutTrigger","ACTION_OnEveryFrameTrigger","ACTION_OnIntersectionEnterTrigger","ACTION_OnIntersectionExitTrigger","ACTION_OnKeyDownTrigger","ACTION_OnKeyUpTrigger","PARTICLES_BILLBOARDMODE_Y","PARTICLES_BILLBOARDMODE_ALL","PARTICLES_BILLBOARDMODE_STRETCHED","MESHES_CULLINGSTRATEGY_STANDARD","MESHES_CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY","MESHES_CULLINGSTRATEGY_OPTIMISTIC_INCLUSION","MESHES_CULLINGSTRATEGY_OPTIMISTIC_INCLUSION_THEN_BSPHERE_ONLY","SCENELOADER_NO_LOGGING","SCENELOADER_MINIMAL_LOGGING","SCENELOADER_SUMMARY_LOGGING","SCENELOADER_DETAILED_LOGGING","PREPASS_IRRADIANCE_TEXTURE_TYPE","PREPASS_POSITION_TEXTURE_TYPE","PREPASS_VELOCITY_TEXTURE_TYPE","PREPASS_REFLECTIVITY_TEXTURE_TYPE","PREPASS_COLOR_TEXTURE_TYPE","PREPASS_DEPTHNORMAL_TEXTURE_TYPE","PREPASS_ALBEDO_TEXTURE_TYPE","_isFullscreen","_fullscreenViewport","_idealWidth","_idealHeight","_useSmallestIdeal","_renderAtIdealSize","_blockNextFocusCheck","_renderScale","_cursorChanged","_defaultMousePointerId","_clipboardData","onControlPickedObservable","onBeginLayoutObservable","onEndLayoutObservable","onBeginRenderObservable","onEndRenderObservable","applyYInversionOnUpdate","_useInvalidateRectOptimization","_invalidatedRectangle","_clearMeasure","onClipboardCopy","rawEvt","onClipboardCut","onClipboardPaste","_rootElement","_renderObserver","_checkUpdate","_preKeyboardObserver","_focusedControl","_resizeObserver","_onResize","rwidth","rheight","_layerToDispose","invalidMinX","invalidMinY","invalidMaxX","invalidMaxY","createStyle","_pointerMoveObserver","_pointerObserver","_canvasPointerOutObserver","_canvasBlurObserver","getProjectedPosition","renderScale","_loop_1","ZeroReadOnly","this_1","_doPicking","_manageFocus","_cleanControlAfterRemovalFromList","tempViewport","_attachToOnPointerOut","_attachToOnBlur","self","attachToMesh","supportPointerMove","friendlyControls","canMoveFocus","friendlyControls_1","otherHost","moveFocusToControl","pointerEvent","entries","CreateForMesh","onlyAlphaTesting","diffuseTexture","emissiveTexture","opacityTexture","CreateForMeshTexture","foreground","instancedBuffers","InstancedMesh","_sourceMesh","tempMaster","registerInstancedBuffer","_userInstancedBuffersStorage","expectedSize","ShaderMaterial","shaderPath","_textureArrays","_floats","_ints","_floatsArrays","_colors3","_colors3Arrays","_colors4","_colors4Arrays","_vectors2","_vectors3","_vectors4","_matrices","_matrixArrays","_matrices3x3","_matrices2x2","_vectors2Arrays","_vectors3Arrays","_vectors4Arrays","_cachedWorldViewMatrix","_cachedWorldViewProjectionMatrix","_multiview","_shaderPath","_options","_checkUniform","setFloats","setColor3Array","setColor4Array","float32Array","_checkCache","_cachedDefines","effectOverride","_transformMatrixR","seffect","propName","propValue","textureArrays","floats","FloatArrays","colors3","colors3Arrays","colors4Arrays","vectors2","vectors3","vectors4","matrixArray","matrices3x3","matrices2x2","vectors2Arrays","vectors3Arrays","vectors4Arrays","textureArray","floatsArrays","ParseFromFileAsync","CreateFromSnippetAsync","snippetId","snippet","jsonPayload","shaderMaterial","SnippetUrl","LinesMesh","_colorShader","_addClipPlaneDefine","_removeClipPlaneDefine","colorEffect","InstancedLinesMesh","vertexColors","shft","dashshft","curvect","lg","curshft","LinesBuilder","vertexColor","lineColors","lineSystem","nbSeg","dashedLines","groundColor","setDirectionToTarget","normalizeDirection","transferToNodeMaterialEffect","lightDataUniformName","strFileName","strMimeType","defaultMime","payload","anchor","myBlob","MozBlob","WebKitBlob","ajax","dataUrlToBlob","saver","tempUiArr","mx","strUrl","binData","uiArr","winMode","confirm","Axios","mergeConfig","defaultConfig","instanceConfig","CancelToken","isCancel","InterceptorManager","dispatchRequest","interceptors","chain","interceptor","fulfilled","rejected","getUri","handlers","use","eject","transformData","throwIfCancellationRequested","throwIfRequested","fns","cachedSetTimeout","cachedClearTimeout","defaultSetTimout","defaultClearTimeout","runTimeout","fun","currentQueue","queue","draining","queueIndex","cleanUpNextTick","drainQueue","run","marker","runClearTimeout","Item","noop","nextTick","browser","env","argv","versions","on","addListener","once","off","removeListener","removeAllListeners","emit","prependListener","prependOnceListener","listeners","binding","cwd","chdir","umask","normalizedName","isAxiosError","toJSON","columnNumber","write","expires","secure","cookie","toGMTString","isAbsoluteURL","combineURLs","requestedURL","relativeURL","ignoreDuplicateOf","parsed","originURL","msie","urlParsingNode","resolveURL","hostname","port","pathname","requestURL","executor","TypeError","resolvePromise","fixed","makeDraggable","_label","setText","fix","unfix","export","_editLabelForms","_showLabels","_arrows","_showArrows","fixedArrows","_ymax","_camera","_createLabelForms","labelBox","addLabelForm","addLabelLabel","htmlFor","addLabelInput","_addLabelTextInput","addLabelBtn","_addLabelBtnClick","editLabelContainer","_editLabelContainer","_labelControlBox","unfixLabels","fixLabels","addArrow","Arrow","labelIdx","newLabel","Label","editLabelForm","editLabelLabel","editLabelInput","dataset","labelnum","onkeyup","_editLabelText","rmvLabelBtn","_removeLabel","inputElem","thisForm","labelNum","eLabelForm","oldNum","newNum","labelDragBehavior","PointerDragBehavior","heatmap","_axisLabels","_ticks","_tickLabels","_tickLines","_createAxes","_roundTicks","includes","sig","xtickBreaks","ytickBreaks","ztickBreaks","ymin","xChar","_makeTextPlane","xTicks","startTick","tickPos","tick","tickLabel","tickChar","tickLine","axisY","yChar","yTicks","zChar","zTicks","dynamicTexture","updateAxisData","colSize","rowSize","channels","channelSize","sliceSize","coords","Intensities","sliceIndex","_channelCoords","_channelCoordIntensities","_createImgStack","channelIntensities","channelCoords","channelColor","channelColorRGB","minIntensity","alphaPositions","alphaColors","alphaIntensities","intens","testIntensity","intensIdx","customMesh","colormix","_shape","_shading","_createShapeCloud","origMesh","matricesData","colorData","SphereBuilder","TorusBuilder","newAlpha","thinInstanceAdd","refresh","_thinInstanceUpdateBufferSize","thinInstanceSetMatrixAt","thinInstanceAddSelf","thinInstanceRegisterAttribute","_thinInstanceInitializeUserStorage","thinInstanceBufferUpdated","thinInstanceSetAttributeAt","staticBuffer","thinInstancePartialBufferUpdate","thinInstanceGetWorldMatrices","forceRefreshParentInfo","POSITIVE_INFINITY","NEGATIVE_INFINITY","numInstances","kindIsMatrix","newSize","newData","diameterX","diameterY","diameterZ","dedupTopBottomIndices","totalZRotationSteps","totalYRotationSteps","zRotationStep","normalizedZ","angleZ","yRotationStep","normalizedY","angleY","rotationZ","rotationY","afterRotZ","complete","firstIndex","outerAngle","innerAngle","nextI","nextJ","torus","_pointPicking","_selectionCallback","selection","_foldVectors","_foldCounter","_foldAnimFrames","_foldVectorFract","_foldDelay","_folded","fv","_foldedEmbedding","_createPointCloud","numberOfVertices","posVector","_createSurface","surface","rowCoords","coord","_createHeatMap","boxes","AnimationKeyInterpolation","AutoRotationBehavior","_zoomStopsAnimation","_idleRotationSpeed","_idleRotationWaitTime","_idleRotationSpinupTime","_lastFrameTime","_lastInteractionTime","Infinity","_cameraRotationSpeed","_lastFrameRadius","speed","_attachedCamera","_onPrePointerObservableObserver","pointerInfoPre","_onAfterCheckInputsObserver","_applyUserInteraction","timeToRotation","_userIsZooming","inertialRadiusOffset","_shouldAnimationStopForInteraction","zoomHasHitLimit","_userIsMoving","inertialAlphaOffset","inertialBetaOffset","inertialPanningX","inertialPanningY","EasingFunction","_easingMode","EASINGMODE_EASEIN","setEasingMode","easingMode","getEasingMode","easeInCore","ease","EASINGMODE_EASEOUT","EASINGMODE_EASEINOUT","CircleEase","BackEase","amplitude","BounceEase","bounces","bounciness","num9","num15","num65","num13","num8","num7","CubicEase","ElasticEase","oscillations","springiness","exp","ExponentialEase","exponent","PowerEase","QuadraticEase","QuarticEase","QuinticEase","SineEase","BezierCurveEase","AnimationRange","Animation","targetProperty","framePerSecond","dataType","loopMode","enableBlending","_runtimeAnimations","_events","blendingSpeed","targetPropertyPath","ANIMATIONLOOPMODE_CYCLE","_PrepareAnimation","totalFrame","easingFunction","isFinite","ANIMATIONTYPE_FLOAT","ANIMATIONTYPE_QUATERNION","ANIMATIONTYPE_VECTOR3","ANIMATIONTYPE_VECTOR2","ANIMATIONTYPE_COLOR3","ANIMATIONTYPE_COLOR4","ANIMATIONTYPE_SIZE","frame","setKeys","setEasingFunction","CreateAnimation","animationType","ANIMATIONLOOPMODE_CONSTANT","CreateAndStartAnimation","beginDirectAnimation","CreateAndStartHierarchyAnimation","beginDirectHierarchyAnimation","CreateMergeAndStartAnimation","MakeAnimationAdditive","sourceAnimation","referenceFrame","cloneOriginal","clonedName","firstKey","lastKey","valueStore","referenceValue","referencePosition","referenceQuaternion","referenceScaling","keyPosition","keyQuaternion","keyScaling","referenceFound","rangeValue","getRange","fromKeyFound","toKeyFound","_getKeyValue","nextKey","animationState","repeatCount","_interpolate","ANIMATIONTYPE_MATRIX","TransitionTo","targetValue","frameRate","transition","duration","isStopped","addEvent","removeEvents","getEvents","getKeys","getHighestFrame","nKeys","getEasingFunction","_easingFunction","floatInterpolateFunction","floatInterpolateFunctionWithTangents","outTangent","inTangent","quaternionInterpolateFunction","quaternionInterpolateFunctionWithTangents","vector3InterpolateFunction","vector3InterpolateFunctionWithTangents","vector2InterpolateFunction","vector2InterpolateFunctionWithTangents","sizeInterpolateFunction","color3InterpolateFunction","color4InterpolateFunction","currentFrame","highLimitValue","startKeyIndex","endKey","startKey","interpolation","STEP","useTangent","frameDelta","floatValue","ANIMATIONLOOPMODE_RELATIVE","offsetValue","quatValue","vec3Value","vec2Value","AllowMatricesInterpolation","matrixInterpolateFunction","workValue","AllowMatrixDecomposeForInterpolation","loopBehavior","animationKey","_UniversalLerp","_inTangent","_outTangent","keyData","serializationObject_1","serializedAnimation","serializationObject_2","BouncingBehavior","transitionDuration","lowerRadiusTransitionRange","upperRadiusTransitionRange","_autoTransitionRange","_radiusIsAnimating","_radiusBounceTransition","_animatables","_onMeshTargetChangedObserver","onMeshTargetChangedObservable","diagonal","diagonalLength","_isRadiusAtLimit","lowerRadiusLimit","_applyBoundRadiusAnimation","upperRadiusLimit","radiusLimit","radiusDelta","EasingMode","_cachedWheelPrecision","animatable","_clearAnimationLocks","FramingBehavior","FitFrustumSidesMode","_radiusScale","_positionScale","_defaultElevation","_elevationReturnTime","_elevationReturnWaitTime","_framingTime","autoCorrectCameraLimitsAndSensibility","_betaIsAnimating","elevation","zoomOnMesh","_maintainCameraAboveGround","focusOnOriginXZ","zoomOnBoundingInfo","zoomOnMeshHierarchy","zoomOnMeshesHierarchy","zoomTarget","zoomTargetY","_vectorTransition","_calculateLowerRadiusFromModelBoundingSphere","IgnoreBoundsSizeMode","panningSensibility","_radiusTransition","useInputToRestoreState","boxVectorGlobalDiagonal","frustumSlope","_getFrustumSlope","distanceForHorizontalFrustum","distanceForVerticalFrustum","timeSinceInteraction","defaultBeta","limitBeta","_betaTransition","animatabe","frustumSlopeY","frustumSlopeX","isUserIsMoving","TargetCamera","_tmpUpVector","_tmpTargetVector","cameraDirection","cameraRotation","ignoreParentScaling","updateUpVectorFromRotation","_tmpQuaternion","noRotationConstraint","invertRotation","inverseRotationSpeed","lockedTarget","_currentTarget","_initialFocalDistance","_camMatrix","_cameraTransformMatrix","_cameraRotationMatrix","_referencePoint","_transformedReferencePoint","_defaultUp","_cachedRotationZ","_cachedQuaternionRotationZ","getFrontPosition","_getLockedTargetPosition","_storedPosition","_storedRotation","_storedRotationQuaternion","lockedTargetPosition","_computeLocalCameraSpeed","vDir","_decideIfNeedsToMove","_updatePosition","directionMultiplier","needToMove","needToRotate","_rotateUpVectorWithCameraRotationMatrix","_computeViewMatrix","parentWorldMatrix","rigCamera","camLeft","camRight","leftSign","rightSign","_getRigCamPositionAndTarget","halfSpace","_TargetFocalPoint","newFocalTarget","_TargetTransformMatrix","_RigCamTransformMatrix","CameraInputTypes","CameraInputsManager","attachedToElement","checkInputs","getSimpleName","_addCheckInputs","inputToRemove","rebuildInputCheck","removeByType","inputType","attachInput","attachElement","detachElement","serializedCamera","inputsmgr","parsedInputs","parsedinput","ArcRotateCameraPointersInput","buttons","angularSensibilityX","angularSensibilityY","pinchPrecision","pinchDeltaPercentage","useNaturalPinchZoom","multiTouchPanning","multiTouchPanAndZoom","pinchInwards","_isPanClick","_twoFingerActivityCount","_isPinching","onTouch","_ctrlKey","_useCtrlForPanning","onDoubleTap","onMultiTouch","pointA","pointB","previousPinchSquaredDistance","pinchSquaredDistance","previousMultiTouchPanPosition","multiTouchPanPosition","moveDeltaX","moveDeltaY","previousPinchDistance","pinchDistance","pinchToPanMaxDistance","onButtonDown","_panningMouseButton","onButtonUp","onLostFocus","BaseCameraPointersInput","_altKey","_metaKey","_shiftKey","_buttonsPressed","_pointerInput","isTouch","pointerType","isInVRExclusivePointerMode","srcElement","altKey","movementX","mozMovementX","webkitMovementX","msMovementX","movementY","mozMovementY","webkitMovementY","msMovementY","setPointerCapture","releasePointerCapture","ed","distX","distY","_observer","_onLostFocus","onContextMenu","inputElement","ArcRotateCameraKeyboardMoveInput","keysUp","keysDown","keysLeft","keysRight","keysReset","zoomingSensibility","useAltToZoom","angularSpeed","_onKeyboardObserver","_ctrlPressed","_altPressed","ArcRotateCameraMouseWheelInput","wheelDeltaPercentage","computeDeltaFromMouseWheelLegacyEvent","mouseWheelDelta","wheelDelta","_wheel","mouseWheelLegacyEvent","detail","estimatedTargetRadius","targetInertia","ArcRotateCameraInputsManager","addMouseWheel","addPointers","addKeyboard","lowerAlphaLimit","upperAlphaLimit","lowerBetaLimit","upperBetaLimit","panningDistanceLimit","panningOriginTarget","panningInertia","zoomOnFactor","targetScreenOffset","allowUpsideDown","panningAxis","collisionRadius","_previousPosition","_collisionVelocity","_newPosition","_computationVector","onCollide","cosa","sina","cosb","sinb","_getTargetPosition","_collisionTriggered","_target","_upToYMatrix","_YToUpMatrix","setMatUp","pointers","mousewheel","_bouncingBehavior","useBouncingBehavior","_framingBehavior","useFramingBehavior","_autoRotationBehavior","useAutoRotationBehavior","_targetHost","_targetBoundingCenter","_storedAlpha","_storedBeta","_storedRadius","_storedTarget","_storedTargetScreenOffset","useCtrlForPanning","panningMouseButton","_reset","_localDirection","_transformedDirection","_checkLimits","rebuildAnglesAndRadius","previousAlpha","alphaCorrectionTurns","toBoundingCenter","allowSamePosition","newTarget","zoomOn","doNotUpdateMaxZ","focusOn","meshesOrMinMaxVectorAndDistance","alphaShift","rigCam","getRandomValues","crypto","msCrypto","rnds8","rng","uuid","byteToHex","_nodeId","_clockseq","_lastMSecs","_lastNSecs","clockseq","seedBytes","msecs","nsecs","tl","tmh","generateUUID","namespace","stringToBytes","hashfunc","DNS","getOutputLength","inputLength8","safeAdd","lsw","md5cmn","md5ff","md5gg","md5hh","md5ii","v35","length32","hexTab","md5ToHexEncodedArray","olda","oldb","oldc","oldd","wordsToMd5","length8","bytesToWords","rnds","ROTL","K","H","N","M","_i2","W","_t","T","sizedFormat","texImage3D","currentFrameBuffer","_createDepthStencilCubeTexture","_createDepthStencilTexture","internalOptions","DEPTH_COMPONENT","DEPTH_COMPONENT24","face","RenderTargetTexture","doNotChangeAspectRatio","isMulti","ignoreCameraViewport","onBeforeBindObservable","onAfterUnbindObservable","onClearObservable","_currentRefreshId","_refreshRate","_initialSizeParameter","_processSizeParameter","_doNotChangeAspectRatio","_renderTargetOptions","getRenderSize","_textureMatrix","_renderList","wasEmpty","_onAfterUnbindObserver","_onClearObserver","_onRatioRescale","_sizeRatio","_boundingBoxSize","_bestReflectionRenderTargetDimension","resetRefreshCounter","addPostProcess","_postProcessManager","clearPostProcesses","removePostProcess","refreshRate","getRenderLayers","wasCube","useCameraPostProcess","dumpForDebug","useCameraPostProcesses","mesh_1","renderListPredicate","sceneMeshes","_defaultRenderListPrepared","renderToTarget","renderDimension","curved","_prepareRenderingManager","currentRenderList","currentRenderListLength","checkLayerMask","customIsReadyFunction","isMasked","unbindFrameBuffer","defaultRenderList","defaultRenderListLength","getCustomRenderList","disposeFramebufferObjects","objBuffer","REFRESHRATE_RENDER_ONCE","REFRESHRATE_RENDER_ONEVERYFRAME","REFRESHRATE_RENDER_ONEVERYTWOFRAMES","PostProcess","fragmentUrl","reusable","vertexUrl","blockCompilation","textureFormat","nodeMaterialSource","enablePixelPerfectMode","scaleMode","alwaysForcePOT","adaptScaleToCurrentViewport","_reusable","_scaleRatio","_texelSize","onActivateObservable","onSizeChangedObservable","onApplyObservable","renderTargetSamplingMode","_textureType","_textureFormat","_fragmentUrl","_vertexUrl","_parameters","updateEffect","_onActivateObserver","_onSizeChangedObserver","_onApplyObserver","_forcedOutputTexture","restoreDefaultInputTexture","getCamera","_shareOutputWithPostProcess","texelSize","shareOutputWith","_disposeTextures","useOwnOutput","forceDepthStencil","maxSize","webVRCamera","desiredWidth","desiredHeight","needMipMaps","textureOptions","isStencilEnable","inputTexture","alphaConstants","_prePassEffectConfiguration","addEffectConfiguration","cameraId","parsedPostProcess","postProcessType","_Parse","FxaaPostProcess","_getDefines","glInfo","targetCamera","_getScreenshotSize","renderContext","renderingCanvas","enableStencilBuffer","targetTextureSize","renderCanvas","originalSize","previousCamera","previousCameras","renderToTexture","fxaaPostProcess","Ray","intersectsBoxMinMax","intersectionTreshold","newMinimum","_TmpVector3","newMaximum","maxValue","rr","vertex0","edge1","edge2","pvec","tvec","qvec","invdet","bw","intersectsPlane","result1","result2","intersectsAxis","tm","_tmpRay","intersectsMeshes","_comparePickingInfo","pickingInfoA","pickingInfoB","sega","segb","threshold","rsegb","rayl","sN","tc","tN","D","sD","tD","smallnum","qtc","qsc","dP","unprojectRayToRef","CreateNewFromTo","nearScreenSource","farScreenSource","nearVec3","farVec3","_internalPickForMesh","rayFunction","_internalPick","thinInstanceEnablePicking","tmpMatrix","thinMatrices","result_1","_internalMultiPick","pickingInfos","result_2","_tempPickingRay","_pickWithRayInverseMatrix","_cachedRayForTransform","PivotTools","_RemoveAndStorePivotPoint","_PivotCached","_OldPivotPoint","_PivotPostMultiplyPivotMatrix","_PivotTranslation","_PivotTmpVector","_RestorePivotPoint","_useAlternatePickedPointAboveMaxDragAngleDragSpeed","maxDragAngle","_useAlternatePickedPointAboveMaxDragAngle","currentDraggingPointerID","dragging","dragDeltaRatio","updateDragPlane","_debugMode","_moving","onDragObservable","onDragStartObservable","onDragEndObservable","moveAttached","startAndReleaseDragOnPointerEvents","detachCameraControls","useObjectOrientationForDragging","validateDrag","targetPosition","_tmpVector","_alternatePickedPoint","_worldDragAxis","_targetPosition","_attachedToElement","_startDragRay","_lastPointerRay","_dragDelta","_pointA","_pointC","_localAxis","_lookAt","optionCount","dragAxis","dragPlaneNormal","ownerNode","attachedNode","_planeScene","_dragPlane","lastDragPosition","pickPredicate","eventState","_startDrag","releaseDrag","_AnyMouseID","MouseEvent","_moveDrag","_beforeRenderObserver","dragPlanePoint","arcRotateCamera","startDrag","fromRay","startPickedPoint","lastRay","_updateDragPlanePosition","_pickWithRayOnDragPlane","dragLength","dragDistance","forward","dragPlanePosition"],"mappings":"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","file":"babyplots.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 60);\n","import { Scalar } from \"./math.scalar\";\r\nimport { Epsilon } from './math.constants';\r\nimport { ArrayTools } from '../Misc/arrayTools';\r\nimport { _TypeStore } from '../Misc/typeStore';\r\nimport { PerformanceConfigurator } from '../Engines/performanceConfigurator';\r\n/**\r\n * Class representing a vector containing 2 coordinates\r\n */\r\nvar Vector2 = /** @class */ (function () {\r\n /**\r\n * Creates a new Vector2 from the given x and y coordinates\r\n * @param x defines the first coordinate\r\n * @param y defines the second coordinate\r\n */\r\n function Vector2(\r\n /** defines the first coordinate */\r\n x, \r\n /** defines the second coordinate */\r\n y) {\r\n if (x === void 0) { x = 0; }\r\n if (y === void 0) { y = 0; }\r\n this.x = x;\r\n this.y = y;\r\n }\r\n /**\r\n * Gets a string with the Vector2 coordinates\r\n * @returns a string with the Vector2 coordinates\r\n */\r\n Vector2.prototype.toString = function () {\r\n return \"{X: \" + this.x + \" Y: \" + this.y + \"}\";\r\n };\r\n /**\r\n * Gets class name\r\n * @returns the string \"Vector2\"\r\n */\r\n Vector2.prototype.getClassName = function () {\r\n return \"Vector2\";\r\n };\r\n /**\r\n * Gets current vector hash code\r\n * @returns the Vector2 hash code as a number\r\n */\r\n Vector2.prototype.getHashCode = function () {\r\n var hash = this.x | 0;\r\n hash = (hash * 397) ^ (this.y | 0);\r\n return hash;\r\n };\r\n // Operators\r\n /**\r\n * Sets the Vector2 coordinates in the given array or Float32Array from the given index.\r\n * @param array defines the source array\r\n * @param index defines the offset in source array\r\n * @returns the current Vector2\r\n */\r\n Vector2.prototype.toArray = function (array, index) {\r\n if (index === void 0) { index = 0; }\r\n array[index] = this.x;\r\n array[index + 1] = this.y;\r\n return this;\r\n };\r\n /**\r\n * Update the current vector from an array\r\n * @param array defines the destination array\r\n * @param index defines the offset in the destination array\r\n * @returns the current Vector3\r\n */\r\n Vector2.prototype.fromArray = function (array, index) {\r\n if (index === void 0) { index = 0; }\r\n Vector2.FromArrayToRef(array, index, this);\r\n return this;\r\n };\r\n /**\r\n * Copy the current vector to an array\r\n * @returns a new array with 2 elements: the Vector2 coordinates.\r\n */\r\n Vector2.prototype.asArray = function () {\r\n var result = new Array();\r\n this.toArray(result, 0);\r\n return result;\r\n };\r\n /**\r\n * Sets the Vector2 coordinates with the given Vector2 coordinates\r\n * @param source defines the source Vector2\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.copyFrom = function (source) {\r\n this.x = source.x;\r\n this.y = source.y;\r\n return this;\r\n };\r\n /**\r\n * Sets the Vector2 coordinates with the given floats\r\n * @param x defines the first coordinate\r\n * @param y defines the second coordinate\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.copyFromFloats = function (x, y) {\r\n this.x = x;\r\n this.y = y;\r\n return this;\r\n };\r\n /**\r\n * Sets the Vector2 coordinates with the given floats\r\n * @param x defines the first coordinate\r\n * @param y defines the second coordinate\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.set = function (x, y) {\r\n return this.copyFromFloats(x, y);\r\n };\r\n /**\r\n * Add another vector with the current one\r\n * @param otherVector defines the other vector\r\n * @returns a new Vector2 set with the addition of the current Vector2 and the given one coordinates\r\n */\r\n Vector2.prototype.add = function (otherVector) {\r\n return new Vector2(this.x + otherVector.x, this.y + otherVector.y);\r\n };\r\n /**\r\n * Sets the \"result\" coordinates with the addition of the current Vector2 and the given one coordinates\r\n * @param otherVector defines the other vector\r\n * @param result defines the target vector\r\n * @returns the unmodified current Vector2\r\n */\r\n Vector2.prototype.addToRef = function (otherVector, result) {\r\n result.x = this.x + otherVector.x;\r\n result.y = this.y + otherVector.y;\r\n return this;\r\n };\r\n /**\r\n * Set the Vector2 coordinates by adding the given Vector2 coordinates\r\n * @param otherVector defines the other vector\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.addInPlace = function (otherVector) {\r\n this.x += otherVector.x;\r\n this.y += otherVector.y;\r\n return this;\r\n };\r\n /**\r\n * Gets a new Vector2 by adding the current Vector2 coordinates to the given Vector3 x, y coordinates\r\n * @param otherVector defines the other vector\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.addVector3 = function (otherVector) {\r\n return new Vector2(this.x + otherVector.x, this.y + otherVector.y);\r\n };\r\n /**\r\n * Gets a new Vector2 set with the subtracted coordinates of the given one from the current Vector2\r\n * @param otherVector defines the other vector\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.subtract = function (otherVector) {\r\n return new Vector2(this.x - otherVector.x, this.y - otherVector.y);\r\n };\r\n /**\r\n * Sets the \"result\" coordinates with the subtraction of the given one from the current Vector2 coordinates.\r\n * @param otherVector defines the other vector\r\n * @param result defines the target vector\r\n * @returns the unmodified current Vector2\r\n */\r\n Vector2.prototype.subtractToRef = function (otherVector, result) {\r\n result.x = this.x - otherVector.x;\r\n result.y = this.y - otherVector.y;\r\n return this;\r\n };\r\n /**\r\n * Sets the current Vector2 coordinates by subtracting from it the given one coordinates\r\n * @param otherVector defines the other vector\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.subtractInPlace = function (otherVector) {\r\n this.x -= otherVector.x;\r\n this.y -= otherVector.y;\r\n return this;\r\n };\r\n /**\r\n * Multiplies in place the current Vector2 coordinates by the given ones\r\n * @param otherVector defines the other vector\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.multiplyInPlace = function (otherVector) {\r\n this.x *= otherVector.x;\r\n this.y *= otherVector.y;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector2 set with the multiplication of the current Vector2 and the given one coordinates\r\n * @param otherVector defines the other vector\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.multiply = function (otherVector) {\r\n return new Vector2(this.x * otherVector.x, this.y * otherVector.y);\r\n };\r\n /**\r\n * Sets \"result\" coordinates with the multiplication of the current Vector2 and the given one coordinates\r\n * @param otherVector defines the other vector\r\n * @param result defines the target vector\r\n * @returns the unmodified current Vector2\r\n */\r\n Vector2.prototype.multiplyToRef = function (otherVector, result) {\r\n result.x = this.x * otherVector.x;\r\n result.y = this.y * otherVector.y;\r\n return this;\r\n };\r\n /**\r\n * Gets a new Vector2 set with the Vector2 coordinates multiplied by the given floats\r\n * @param x defines the first coordinate\r\n * @param y defines the second coordinate\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.multiplyByFloats = function (x, y) {\r\n return new Vector2(this.x * x, this.y * y);\r\n };\r\n /**\r\n * Returns a new Vector2 set with the Vector2 coordinates divided by the given one coordinates\r\n * @param otherVector defines the other vector\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.divide = function (otherVector) {\r\n return new Vector2(this.x / otherVector.x, this.y / otherVector.y);\r\n };\r\n /**\r\n * Sets the \"result\" coordinates with the Vector2 divided by the given one coordinates\r\n * @param otherVector defines the other vector\r\n * @param result defines the target vector\r\n * @returns the unmodified current Vector2\r\n */\r\n Vector2.prototype.divideToRef = function (otherVector, result) {\r\n result.x = this.x / otherVector.x;\r\n result.y = this.y / otherVector.y;\r\n return this;\r\n };\r\n /**\r\n * Divides the current Vector2 coordinates by the given ones\r\n * @param otherVector defines the other vector\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.divideInPlace = function (otherVector) {\r\n return this.divideToRef(otherVector, this);\r\n };\r\n /**\r\n * Gets a new Vector2 with current Vector2 negated coordinates\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.negate = function () {\r\n return new Vector2(-this.x, -this.y);\r\n };\r\n /**\r\n * Negate this vector in place\r\n * @returns this\r\n */\r\n Vector2.prototype.negateInPlace = function () {\r\n this.x *= -1;\r\n this.y *= -1;\r\n return this;\r\n };\r\n /**\r\n * Negate the current Vector2 and stores the result in the given vector \"result\" coordinates\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector2\r\n */\r\n Vector2.prototype.negateToRef = function (result) {\r\n return result.copyFromFloats(this.x * -1, this.y * -1);\r\n };\r\n /**\r\n * Multiply the Vector2 coordinates by scale\r\n * @param scale defines the scaling factor\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.scaleInPlace = function (scale) {\r\n this.x *= scale;\r\n this.y *= scale;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector2 scaled by \"scale\" from the current Vector2\r\n * @param scale defines the scaling factor\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.scale = function (scale) {\r\n var result = new Vector2(0, 0);\r\n this.scaleToRef(scale, result);\r\n return result;\r\n };\r\n /**\r\n * Scale the current Vector2 values by a factor to a given Vector2\r\n * @param scale defines the scale factor\r\n * @param result defines the Vector2 object where to store the result\r\n * @returns the unmodified current Vector2\r\n */\r\n Vector2.prototype.scaleToRef = function (scale, result) {\r\n result.x = this.x * scale;\r\n result.y = this.y * scale;\r\n return this;\r\n };\r\n /**\r\n * Scale the current Vector2 values by a factor and add the result to a given Vector2\r\n * @param scale defines the scale factor\r\n * @param result defines the Vector2 object where to store the result\r\n * @returns the unmodified current Vector2\r\n */\r\n Vector2.prototype.scaleAndAddToRef = function (scale, result) {\r\n result.x += this.x * scale;\r\n result.y += this.y * scale;\r\n return this;\r\n };\r\n /**\r\n * Gets a boolean if two vectors are equals\r\n * @param otherVector defines the other vector\r\n * @returns true if the given vector coordinates strictly equal the current Vector2 ones\r\n */\r\n Vector2.prototype.equals = function (otherVector) {\r\n return otherVector && this.x === otherVector.x && this.y === otherVector.y;\r\n };\r\n /**\r\n * Gets a boolean if two vectors are equals (using an epsilon value)\r\n * @param otherVector defines the other vector\r\n * @param epsilon defines the minimal distance to consider equality\r\n * @returns true if the given vector coordinates are close to the current ones by a distance of epsilon.\r\n */\r\n Vector2.prototype.equalsWithEpsilon = function (otherVector, epsilon) {\r\n if (epsilon === void 0) { epsilon = Epsilon; }\r\n return otherVector && Scalar.WithinEpsilon(this.x, otherVector.x, epsilon) && Scalar.WithinEpsilon(this.y, otherVector.y, epsilon);\r\n };\r\n /**\r\n * Gets a new Vector2 from current Vector2 floored values\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.floor = function () {\r\n return new Vector2(Math.floor(this.x), Math.floor(this.y));\r\n };\r\n /**\r\n * Gets a new Vector2 from current Vector2 floored values\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.fract = function () {\r\n return new Vector2(this.x - Math.floor(this.x), this.y - Math.floor(this.y));\r\n };\r\n // Properties\r\n /**\r\n * Gets the length of the vector\r\n * @returns the vector length (float)\r\n */\r\n Vector2.prototype.length = function () {\r\n return Math.sqrt(this.x * this.x + this.y * this.y);\r\n };\r\n /**\r\n * Gets the vector squared length\r\n * @returns the vector squared length (float)\r\n */\r\n Vector2.prototype.lengthSquared = function () {\r\n return (this.x * this.x + this.y * this.y);\r\n };\r\n // Methods\r\n /**\r\n * Normalize the vector\r\n * @returns the current updated Vector2\r\n */\r\n Vector2.prototype.normalize = function () {\r\n var len = this.length();\r\n if (len === 0) {\r\n return this;\r\n }\r\n this.x /= len;\r\n this.y /= len;\r\n return this;\r\n };\r\n /**\r\n * Gets a new Vector2 copied from the Vector2\r\n * @returns a new Vector2\r\n */\r\n Vector2.prototype.clone = function () {\r\n return new Vector2(this.x, this.y);\r\n };\r\n // Statics\r\n /**\r\n * Gets a new Vector2(0, 0)\r\n * @returns a new Vector2\r\n */\r\n Vector2.Zero = function () {\r\n return new Vector2(0, 0);\r\n };\r\n /**\r\n * Gets a new Vector2(1, 1)\r\n * @returns a new Vector2\r\n */\r\n Vector2.One = function () {\r\n return new Vector2(1, 1);\r\n };\r\n /**\r\n * Gets a new Vector2 set from the given index element of the given array\r\n * @param array defines the data source\r\n * @param offset defines the offset in the data source\r\n * @returns a new Vector2\r\n */\r\n Vector2.FromArray = function (array, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n return new Vector2(array[offset], array[offset + 1]);\r\n };\r\n /**\r\n * Sets \"result\" from the given index element of the given array\r\n * @param array defines the data source\r\n * @param offset defines the offset in the data source\r\n * @param result defines the target vector\r\n */\r\n Vector2.FromArrayToRef = function (array, offset, result) {\r\n result.x = array[offset];\r\n result.y = array[offset + 1];\r\n };\r\n /**\r\n * Gets a new Vector2 located for \"amount\" (float) on the CatmullRom spline defined by the given four Vector2\r\n * @param value1 defines 1st point of control\r\n * @param value2 defines 2nd point of control\r\n * @param value3 defines 3rd point of control\r\n * @param value4 defines 4th point of control\r\n * @param amount defines the interpolation factor\r\n * @returns a new Vector2\r\n */\r\n Vector2.CatmullRom = function (value1, value2, value3, value4, amount) {\r\n var squared = amount * amount;\r\n var cubed = amount * squared;\r\n var x = 0.5 * ((((2.0 * value2.x) + ((-value1.x + value3.x) * amount)) +\r\n (((((2.0 * value1.x) - (5.0 * value2.x)) + (4.0 * value3.x)) - value4.x) * squared)) +\r\n ((((-value1.x + (3.0 * value2.x)) - (3.0 * value3.x)) + value4.x) * cubed));\r\n var y = 0.5 * ((((2.0 * value2.y) + ((-value1.y + value3.y) * amount)) +\r\n (((((2.0 * value1.y) - (5.0 * value2.y)) + (4.0 * value3.y)) - value4.y) * squared)) +\r\n ((((-value1.y + (3.0 * value2.y)) - (3.0 * value3.y)) + value4.y) * cubed));\r\n return new Vector2(x, y);\r\n };\r\n /**\r\n * Returns a new Vector2 set with same the coordinates than \"value\" ones if the vector \"value\" is in the square defined by \"min\" and \"max\".\r\n * If a coordinate of \"value\" is lower than \"min\" coordinates, the returned Vector2 is given this \"min\" coordinate.\r\n * If a coordinate of \"value\" is greater than \"max\" coordinates, the returned Vector2 is given this \"max\" coordinate\r\n * @param value defines the value to clamp\r\n * @param min defines the lower limit\r\n * @param max defines the upper limit\r\n * @returns a new Vector2\r\n */\r\n Vector2.Clamp = function (value, min, max) {\r\n var x = value.x;\r\n x = (x > max.x) ? max.x : x;\r\n x = (x < min.x) ? min.x : x;\r\n var y = value.y;\r\n y = (y > max.y) ? max.y : y;\r\n y = (y < min.y) ? min.y : y;\r\n return new Vector2(x, y);\r\n };\r\n /**\r\n * Returns a new Vector2 located for \"amount\" (float) on the Hermite spline defined by the vectors \"value1\", \"value3\", \"tangent1\", \"tangent2\"\r\n * @param value1 defines the 1st control point\r\n * @param tangent1 defines the outgoing tangent\r\n * @param value2 defines the 2nd control point\r\n * @param tangent2 defines the incoming tangent\r\n * @param amount defines the interpolation factor\r\n * @returns a new Vector2\r\n */\r\n Vector2.Hermite = function (value1, tangent1, value2, tangent2, amount) {\r\n var squared = amount * amount;\r\n var cubed = amount * squared;\r\n var part1 = ((2.0 * cubed) - (3.0 * squared)) + 1.0;\r\n var part2 = (-2.0 * cubed) + (3.0 * squared);\r\n var part3 = (cubed - (2.0 * squared)) + amount;\r\n var part4 = cubed - squared;\r\n var x = (((value1.x * part1) + (value2.x * part2)) + (tangent1.x * part3)) + (tangent2.x * part4);\r\n var y = (((value1.y * part1) + (value2.y * part2)) + (tangent1.y * part3)) + (tangent2.y * part4);\r\n return new Vector2(x, y);\r\n };\r\n /**\r\n * Returns a new Vector2 located for \"amount\" (float) on the linear interpolation between the vector \"start\" adn the vector \"end\".\r\n * @param start defines the start vector\r\n * @param end defines the end vector\r\n * @param amount defines the interpolation factor\r\n * @returns a new Vector2\r\n */\r\n Vector2.Lerp = function (start, end, amount) {\r\n var x = start.x + ((end.x - start.x) * amount);\r\n var y = start.y + ((end.y - start.y) * amount);\r\n return new Vector2(x, y);\r\n };\r\n /**\r\n * Gets the dot product of the vector \"left\" and the vector \"right\"\r\n * @param left defines first vector\r\n * @param right defines second vector\r\n * @returns the dot product (float)\r\n */\r\n Vector2.Dot = function (left, right) {\r\n return left.x * right.x + left.y * right.y;\r\n };\r\n /**\r\n * Returns a new Vector2 equal to the normalized given vector\r\n * @param vector defines the vector to normalize\r\n * @returns a new Vector2\r\n */\r\n Vector2.Normalize = function (vector) {\r\n var newVector = vector.clone();\r\n newVector.normalize();\r\n return newVector;\r\n };\r\n /**\r\n * Gets a new Vector2 set with the minimal coordinate values from the \"left\" and \"right\" vectors\r\n * @param left defines 1st vector\r\n * @param right defines 2nd vector\r\n * @returns a new Vector2\r\n */\r\n Vector2.Minimize = function (left, right) {\r\n var x = (left.x < right.x) ? left.x : right.x;\r\n var y = (left.y < right.y) ? left.y : right.y;\r\n return new Vector2(x, y);\r\n };\r\n /**\r\n * Gets a new Vecto2 set with the maximal coordinate values from the \"left\" and \"right\" vectors\r\n * @param left defines 1st vector\r\n * @param right defines 2nd vector\r\n * @returns a new Vector2\r\n */\r\n Vector2.Maximize = function (left, right) {\r\n var x = (left.x > right.x) ? left.x : right.x;\r\n var y = (left.y > right.y) ? left.y : right.y;\r\n return new Vector2(x, y);\r\n };\r\n /**\r\n * Gets a new Vector2 set with the transformed coordinates of the given vector by the given transformation matrix\r\n * @param vector defines the vector to transform\r\n * @param transformation defines the matrix to apply\r\n * @returns a new Vector2\r\n */\r\n Vector2.Transform = function (vector, transformation) {\r\n var r = Vector2.Zero();\r\n Vector2.TransformToRef(vector, transformation, r);\r\n return r;\r\n };\r\n /**\r\n * Transforms the given vector coordinates by the given transformation matrix and stores the result in the vector \"result\" coordinates\r\n * @param vector defines the vector to transform\r\n * @param transformation defines the matrix to apply\r\n * @param result defines the target vector\r\n */\r\n Vector2.TransformToRef = function (vector, transformation, result) {\r\n var m = transformation.m;\r\n var x = (vector.x * m[0]) + (vector.y * m[4]) + m[12];\r\n var y = (vector.x * m[1]) + (vector.y * m[5]) + m[13];\r\n result.x = x;\r\n result.y = y;\r\n };\r\n /**\r\n * Determines if a given vector is included in a triangle\r\n * @param p defines the vector to test\r\n * @param p0 defines 1st triangle point\r\n * @param p1 defines 2nd triangle point\r\n * @param p2 defines 3rd triangle point\r\n * @returns true if the point \"p\" is in the triangle defined by the vertors \"p0\", \"p1\", \"p2\"\r\n */\r\n Vector2.PointInTriangle = function (p, p0, p1, p2) {\r\n var a = 1 / 2 * (-p1.y * p2.x + p0.y * (-p1.x + p2.x) + p0.x * (p1.y - p2.y) + p1.x * p2.y);\r\n var sign = a < 0 ? -1 : 1;\r\n var s = (p0.y * p2.x - p0.x * p2.y + (p2.y - p0.y) * p.x + (p0.x - p2.x) * p.y) * sign;\r\n var t = (p0.x * p1.y - p0.y * p1.x + (p0.y - p1.y) * p.x + (p1.x - p0.x) * p.y) * sign;\r\n return s > 0 && t > 0 && (s + t) < 2 * a * sign;\r\n };\r\n /**\r\n * Gets the distance between the vectors \"value1\" and \"value2\"\r\n * @param value1 defines first vector\r\n * @param value2 defines second vector\r\n * @returns the distance between vectors\r\n */\r\n Vector2.Distance = function (value1, value2) {\r\n return Math.sqrt(Vector2.DistanceSquared(value1, value2));\r\n };\r\n /**\r\n * Returns the squared distance between the vectors \"value1\" and \"value2\"\r\n * @param value1 defines first vector\r\n * @param value2 defines second vector\r\n * @returns the squared distance between vectors\r\n */\r\n Vector2.DistanceSquared = function (value1, value2) {\r\n var x = value1.x - value2.x;\r\n var y = value1.y - value2.y;\r\n return (x * x) + (y * y);\r\n };\r\n /**\r\n * Gets a new Vector2 located at the center of the vectors \"value1\" and \"value2\"\r\n * @param value1 defines first vector\r\n * @param value2 defines second vector\r\n * @returns a new Vector2\r\n */\r\n Vector2.Center = function (value1, value2) {\r\n var center = value1.add(value2);\r\n center.scaleInPlace(0.5);\r\n return center;\r\n };\r\n /**\r\n * Gets the shortest distance (float) between the point \"p\" and the segment defined by the two points \"segA\" and \"segB\".\r\n * @param p defines the middle point\r\n * @param segA defines one point of the segment\r\n * @param segB defines the other point of the segment\r\n * @returns the shortest distance\r\n */\r\n Vector2.DistanceOfPointFromSegment = function (p, segA, segB) {\r\n var l2 = Vector2.DistanceSquared(segA, segB);\r\n if (l2 === 0.0) {\r\n return Vector2.Distance(p, segA);\r\n }\r\n var v = segB.subtract(segA);\r\n var t = Math.max(0, Math.min(1, Vector2.Dot(p.subtract(segA), v) / l2));\r\n var proj = segA.add(v.multiplyByFloats(t, t));\r\n return Vector2.Distance(p, proj);\r\n };\r\n return Vector2;\r\n}());\r\nexport { Vector2 };\r\n/**\r\n * Class used to store (x,y,z) vector representation\r\n * A Vector3 is the main object used in 3D geometry\r\n * It can represent etiher the coordinates of a point the space, either a direction\r\n * Reminder: js uses a left handed forward facing system\r\n */\r\nvar Vector3 = /** @class */ (function () {\r\n /**\r\n * Creates a new Vector3 object from the given x, y, z (floats) coordinates.\r\n * @param x defines the first coordinates (on X axis)\r\n * @param y defines the second coordinates (on Y axis)\r\n * @param z defines the third coordinates (on Z axis)\r\n */\r\n function Vector3(x, y, z) {\r\n if (x === void 0) { x = 0; }\r\n if (y === void 0) { y = 0; }\r\n if (z === void 0) { z = 0; }\r\n /** @hidden */\r\n this._isDirty = true;\r\n this._x = x;\r\n this._y = y;\r\n this._z = z;\r\n }\r\n Object.defineProperty(Vector3.prototype, \"x\", {\r\n /** Gets or sets the x coordinate */\r\n get: function () {\r\n return this._x;\r\n },\r\n set: function (value) {\r\n this._x = value;\r\n this._isDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Vector3.prototype, \"y\", {\r\n /** Gets or sets the y coordinate */\r\n get: function () {\r\n return this._y;\r\n },\r\n set: function (value) {\r\n this._y = value;\r\n this._isDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Vector3.prototype, \"z\", {\r\n /** Gets or sets the z coordinate */\r\n get: function () {\r\n return this._z;\r\n },\r\n set: function (value) {\r\n this._z = value;\r\n this._isDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Creates a string representation of the Vector3\r\n * @returns a string with the Vector3 coordinates.\r\n */\r\n Vector3.prototype.toString = function () {\r\n return \"{X: \" + this._x + \" Y:\" + this._y + \" Z:\" + this._z + \"}\";\r\n };\r\n /**\r\n * Gets the class name\r\n * @returns the string \"Vector3\"\r\n */\r\n Vector3.prototype.getClassName = function () {\r\n return \"Vector3\";\r\n };\r\n /**\r\n * Creates the Vector3 hash code\r\n * @returns a number which tends to be unique between Vector3 instances\r\n */\r\n Vector3.prototype.getHashCode = function () {\r\n var hash = this._x | 0;\r\n hash = (hash * 397) ^ (this._y | 0);\r\n hash = (hash * 397) ^ (this._z | 0);\r\n return hash;\r\n };\r\n // Operators\r\n /**\r\n * Creates an array containing three elements : the coordinates of the Vector3\r\n * @returns a new array of numbers\r\n */\r\n Vector3.prototype.asArray = function () {\r\n var result = [];\r\n this.toArray(result, 0);\r\n return result;\r\n };\r\n /**\r\n * Populates the given array or Float32Array from the given index with the successive coordinates of the Vector3\r\n * @param array defines the destination array\r\n * @param index defines the offset in the destination array\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.toArray = function (array, index) {\r\n if (index === void 0) { index = 0; }\r\n array[index] = this._x;\r\n array[index + 1] = this._y;\r\n array[index + 2] = this._z;\r\n return this;\r\n };\r\n /**\r\n * Update the current vector from an array\r\n * @param array defines the destination array\r\n * @param index defines the offset in the destination array\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.fromArray = function (array, index) {\r\n if (index === void 0) { index = 0; }\r\n Vector3.FromArrayToRef(array, index, this);\r\n return this;\r\n };\r\n /**\r\n * Converts the current Vector3 into a quaternion (considering that the Vector3 contains Euler angles representation of a rotation)\r\n * @returns a new Quaternion object, computed from the Vector3 coordinates\r\n */\r\n Vector3.prototype.toQuaternion = function () {\r\n return Quaternion.RotationYawPitchRoll(this._y, this._x, this._z);\r\n };\r\n /**\r\n * Adds the given vector to the current Vector3\r\n * @param otherVector defines the second operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.addInPlace = function (otherVector) {\r\n return this.addInPlaceFromFloats(otherVector._x, otherVector._y, otherVector._z);\r\n };\r\n /**\r\n * Adds the given coordinates to the current Vector3\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.addInPlaceFromFloats = function (x, y, z) {\r\n this.x += x;\r\n this.y += y;\r\n this.z += z;\r\n return this;\r\n };\r\n /**\r\n * Gets a new Vector3, result of the addition the current Vector3 and the given vector\r\n * @param otherVector defines the second operand\r\n * @returns the resulting Vector3\r\n */\r\n Vector3.prototype.add = function (otherVector) {\r\n return new Vector3(this._x + otherVector._x, this._y + otherVector._y, this._z + otherVector._z);\r\n };\r\n /**\r\n * Adds the current Vector3 to the given one and stores the result in the vector \"result\"\r\n * @param otherVector defines the second operand\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.addToRef = function (otherVector, result) {\r\n return result.copyFromFloats(this._x + otherVector._x, this._y + otherVector._y, this._z + otherVector._z);\r\n };\r\n /**\r\n * Subtract the given vector from the current Vector3\r\n * @param otherVector defines the second operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.subtractInPlace = function (otherVector) {\r\n this.x -= otherVector._x;\r\n this.y -= otherVector._y;\r\n this.z -= otherVector._z;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector3, result of the subtraction of the given vector from the current Vector3\r\n * @param otherVector defines the second operand\r\n * @returns the resulting Vector3\r\n */\r\n Vector3.prototype.subtract = function (otherVector) {\r\n return new Vector3(this._x - otherVector._x, this._y - otherVector._y, this._z - otherVector._z);\r\n };\r\n /**\r\n * Subtracts the given vector from the current Vector3 and stores the result in the vector \"result\".\r\n * @param otherVector defines the second operand\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.subtractToRef = function (otherVector, result) {\r\n return this.subtractFromFloatsToRef(otherVector._x, otherVector._y, otherVector._z, result);\r\n };\r\n /**\r\n * Returns a new Vector3 set with the subtraction of the given floats from the current Vector3 coordinates\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @returns the resulting Vector3\r\n */\r\n Vector3.prototype.subtractFromFloats = function (x, y, z) {\r\n return new Vector3(this._x - x, this._y - y, this._z - z);\r\n };\r\n /**\r\n * Subtracts the given floats from the current Vector3 coordinates and set the given vector \"result\" with this result\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.subtractFromFloatsToRef = function (x, y, z, result) {\r\n return result.copyFromFloats(this._x - x, this._y - y, this._z - z);\r\n };\r\n /**\r\n * Gets a new Vector3 set with the current Vector3 negated coordinates\r\n * @returns a new Vector3\r\n */\r\n Vector3.prototype.negate = function () {\r\n return new Vector3(-this._x, -this._y, -this._z);\r\n };\r\n /**\r\n * Negate this vector in place\r\n * @returns this\r\n */\r\n Vector3.prototype.negateInPlace = function () {\r\n this.x *= -1;\r\n this.y *= -1;\r\n this.z *= -1;\r\n return this;\r\n };\r\n /**\r\n * Negate the current Vector3 and stores the result in the given vector \"result\" coordinates\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.negateToRef = function (result) {\r\n return result.copyFromFloats(this._x * -1, this._y * -1, this._z * -1);\r\n };\r\n /**\r\n * Multiplies the Vector3 coordinates by the float \"scale\"\r\n * @param scale defines the multiplier factor\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.scaleInPlace = function (scale) {\r\n this.x *= scale;\r\n this.y *= scale;\r\n this.z *= scale;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector3 set with the current Vector3 coordinates multiplied by the float \"scale\"\r\n * @param scale defines the multiplier factor\r\n * @returns a new Vector3\r\n */\r\n Vector3.prototype.scale = function (scale) {\r\n return new Vector3(this._x * scale, this._y * scale, this._z * scale);\r\n };\r\n /**\r\n * Multiplies the current Vector3 coordinates by the float \"scale\" and stores the result in the given vector \"result\" coordinates\r\n * @param scale defines the multiplier factor\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.scaleToRef = function (scale, result) {\r\n return result.copyFromFloats(this._x * scale, this._y * scale, this._z * scale);\r\n };\r\n /**\r\n * Scale the current Vector3 values by a factor and add the result to a given Vector3\r\n * @param scale defines the scale factor\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the unmodified current Vector3\r\n */\r\n Vector3.prototype.scaleAndAddToRef = function (scale, result) {\r\n return result.addInPlaceFromFloats(this._x * scale, this._y * scale, this._z * scale);\r\n };\r\n /**\r\n * Projects the current vector3 to a plane along a ray starting from a specified origin and directed towards the point.\r\n * @param origin defines the origin of the projection ray\r\n * @param plane defines the plane to project to\r\n * @returns the projected vector3\r\n */\r\n Vector3.prototype.projectOnPlane = function (plane, origin) {\r\n var result = Vector3.Zero();\r\n this.projectOnPlaneToRef(plane, origin, result);\r\n return result;\r\n };\r\n /**\r\n * Projects the current vector3 to a plane along a ray starting from a specified origin and directed towards the point.\r\n * @param origin defines the origin of the projection ray\r\n * @param plane defines the plane to project to\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.prototype.projectOnPlaneToRef = function (plane, origin, result) {\r\n var n = plane.normal;\r\n var d = plane.d;\r\n var V = MathTmp.Vector3[0];\r\n // ray direction\r\n this.subtractToRef(origin, V);\r\n V.normalize();\r\n var denom = Vector3.Dot(V, n);\r\n var t = -(Vector3.Dot(origin, n) + d) / denom;\r\n // P = P0 + t*V\r\n var scaledV = V.scaleInPlace(t);\r\n origin.addToRef(scaledV, result);\r\n };\r\n /**\r\n * Returns true if the current Vector3 and the given vector coordinates are strictly equal\r\n * @param otherVector defines the second operand\r\n * @returns true if both vectors are equals\r\n */\r\n Vector3.prototype.equals = function (otherVector) {\r\n return otherVector && this._x === otherVector._x && this._y === otherVector._y && this._z === otherVector._z;\r\n };\r\n /**\r\n * Returns true if the current Vector3 and the given vector coordinates are distant less than epsilon\r\n * @param otherVector defines the second operand\r\n * @param epsilon defines the minimal distance to define values as equals\r\n * @returns true if both vectors are distant less than epsilon\r\n */\r\n Vector3.prototype.equalsWithEpsilon = function (otherVector, epsilon) {\r\n if (epsilon === void 0) { epsilon = Epsilon; }\r\n return otherVector && Scalar.WithinEpsilon(this._x, otherVector._x, epsilon) && Scalar.WithinEpsilon(this._y, otherVector._y, epsilon) && Scalar.WithinEpsilon(this._z, otherVector._z, epsilon);\r\n };\r\n /**\r\n * Returns true if the current Vector3 coordinates equals the given floats\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @returns true if both vectors are equals\r\n */\r\n Vector3.prototype.equalsToFloats = function (x, y, z) {\r\n return this._x === x && this._y === y && this._z === z;\r\n };\r\n /**\r\n * Multiplies the current Vector3 coordinates by the given ones\r\n * @param otherVector defines the second operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.multiplyInPlace = function (otherVector) {\r\n this.x *= otherVector._x;\r\n this.y *= otherVector._y;\r\n this.z *= otherVector._z;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector3, result of the multiplication of the current Vector3 by the given vector\r\n * @param otherVector defines the second operand\r\n * @returns the new Vector3\r\n */\r\n Vector3.prototype.multiply = function (otherVector) {\r\n return this.multiplyByFloats(otherVector._x, otherVector._y, otherVector._z);\r\n };\r\n /**\r\n * Multiplies the current Vector3 by the given one and stores the result in the given vector \"result\"\r\n * @param otherVector defines the second operand\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.multiplyToRef = function (otherVector, result) {\r\n return result.copyFromFloats(this._x * otherVector._x, this._y * otherVector._y, this._z * otherVector._z);\r\n };\r\n /**\r\n * Returns a new Vector3 set with the result of the mulliplication of the current Vector3 coordinates by the given floats\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @returns the new Vector3\r\n */\r\n Vector3.prototype.multiplyByFloats = function (x, y, z) {\r\n return new Vector3(this._x * x, this._y * y, this._z * z);\r\n };\r\n /**\r\n * Returns a new Vector3 set with the result of the division of the current Vector3 coordinates by the given ones\r\n * @param otherVector defines the second operand\r\n * @returns the new Vector3\r\n */\r\n Vector3.prototype.divide = function (otherVector) {\r\n return new Vector3(this._x / otherVector._x, this._y / otherVector._y, this._z / otherVector._z);\r\n };\r\n /**\r\n * Divides the current Vector3 coordinates by the given ones and stores the result in the given vector \"result\"\r\n * @param otherVector defines the second operand\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector3\r\n */\r\n Vector3.prototype.divideToRef = function (otherVector, result) {\r\n return result.copyFromFloats(this._x / otherVector._x, this._y / otherVector._y, this._z / otherVector._z);\r\n };\r\n /**\r\n * Divides the current Vector3 coordinates by the given ones.\r\n * @param otherVector defines the second operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.divideInPlace = function (otherVector) {\r\n return this.divideToRef(otherVector, this);\r\n };\r\n /**\r\n * Updates the current Vector3 with the minimal coordinate values between its and the given vector ones\r\n * @param other defines the second operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.minimizeInPlace = function (other) {\r\n return this.minimizeInPlaceFromFloats(other._x, other._y, other._z);\r\n };\r\n /**\r\n * Updates the current Vector3 with the maximal coordinate values between its and the given vector ones.\r\n * @param other defines the second operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.maximizeInPlace = function (other) {\r\n return this.maximizeInPlaceFromFloats(other._x, other._y, other._z);\r\n };\r\n /**\r\n * Updates the current Vector3 with the minimal coordinate values between its and the given coordinates\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.minimizeInPlaceFromFloats = function (x, y, z) {\r\n if (x < this._x) {\r\n this.x = x;\r\n }\r\n if (y < this._y) {\r\n this.y = y;\r\n }\r\n if (z < this._z) {\r\n this.z = z;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Updates the current Vector3 with the maximal coordinate values between its and the given coordinates.\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.maximizeInPlaceFromFloats = function (x, y, z) {\r\n if (x > this._x) {\r\n this.x = x;\r\n }\r\n if (y > this._y) {\r\n this.y = y;\r\n }\r\n if (z > this._z) {\r\n this.z = z;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Due to float precision, scale of a mesh could be uniform but float values are off by a small fraction\r\n * Check if is non uniform within a certain amount of decimal places to account for this\r\n * @param epsilon the amount the values can differ\r\n * @returns if the the vector is non uniform to a certain number of decimal places\r\n */\r\n Vector3.prototype.isNonUniformWithinEpsilon = function (epsilon) {\r\n var absX = Math.abs(this._x);\r\n var absY = Math.abs(this._y);\r\n if (!Scalar.WithinEpsilon(absX, absY, epsilon)) {\r\n return true;\r\n }\r\n var absZ = Math.abs(this._z);\r\n if (!Scalar.WithinEpsilon(absX, absZ, epsilon)) {\r\n return true;\r\n }\r\n if (!Scalar.WithinEpsilon(absY, absZ, epsilon)) {\r\n return true;\r\n }\r\n return false;\r\n };\r\n Object.defineProperty(Vector3.prototype, \"isNonUniform\", {\r\n /**\r\n * Gets a boolean indicating that the vector is non uniform meaning x, y or z are not all the same\r\n */\r\n get: function () {\r\n var absX = Math.abs(this._x);\r\n var absY = Math.abs(this._y);\r\n if (absX !== absY) {\r\n return true;\r\n }\r\n var absZ = Math.abs(this._z);\r\n if (absX !== absZ) {\r\n return true;\r\n }\r\n return false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets a new Vector3 from current Vector3 floored values\r\n * @returns a new Vector3\r\n */\r\n Vector3.prototype.floor = function () {\r\n return new Vector3(Math.floor(this._x), Math.floor(this._y), Math.floor(this._z));\r\n };\r\n /**\r\n * Gets a new Vector3 from current Vector3 floored values\r\n * @returns a new Vector3\r\n */\r\n Vector3.prototype.fract = function () {\r\n return new Vector3(this._x - Math.floor(this._x), this._y - Math.floor(this._y), this._z - Math.floor(this._z));\r\n };\r\n // Properties\r\n /**\r\n * Gets the length of the Vector3\r\n * @returns the length of the Vector3\r\n */\r\n Vector3.prototype.length = function () {\r\n return Math.sqrt(this._x * this._x + this._y * this._y + this._z * this._z);\r\n };\r\n /**\r\n * Gets the squared length of the Vector3\r\n * @returns squared length of the Vector3\r\n */\r\n Vector3.prototype.lengthSquared = function () {\r\n return (this._x * this._x + this._y * this._y + this._z * this._z);\r\n };\r\n /**\r\n * Normalize the current Vector3.\r\n * Please note that this is an in place operation.\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.normalize = function () {\r\n return this.normalizeFromLength(this.length());\r\n };\r\n /**\r\n * Reorders the x y z properties of the vector in place\r\n * @param order new ordering of the properties (eg. for vector 1,2,3 with \"ZYX\" will produce 3,2,1)\r\n * @returns the current updated vector\r\n */\r\n Vector3.prototype.reorderInPlace = function (order) {\r\n var _this = this;\r\n order = order.toLowerCase();\r\n if (order === \"xyz\") {\r\n return this;\r\n }\r\n MathTmp.Vector3[0].copyFrom(this);\r\n [\"x\", \"y\", \"z\"].forEach(function (val, i) {\r\n _this[val] = MathTmp.Vector3[0][order[i]];\r\n });\r\n return this;\r\n };\r\n /**\r\n * Rotates the vector around 0,0,0 by a quaternion\r\n * @param quaternion the rotation quaternion\r\n * @param result vector to store the result\r\n * @returns the resulting vector\r\n */\r\n Vector3.prototype.rotateByQuaternionToRef = function (quaternion, result) {\r\n quaternion.toRotationMatrix(MathTmp.Matrix[0]);\r\n Vector3.TransformCoordinatesToRef(this, MathTmp.Matrix[0], result);\r\n return result;\r\n };\r\n /**\r\n * Rotates a vector around a given point\r\n * @param quaternion the rotation quaternion\r\n * @param point the point to rotate around\r\n * @param result vector to store the result\r\n * @returns the resulting vector\r\n */\r\n Vector3.prototype.rotateByQuaternionAroundPointToRef = function (quaternion, point, result) {\r\n this.subtractToRef(point, MathTmp.Vector3[0]);\r\n MathTmp.Vector3[0].rotateByQuaternionToRef(quaternion, MathTmp.Vector3[0]);\r\n point.addToRef(MathTmp.Vector3[0], result);\r\n return result;\r\n };\r\n /**\r\n * Returns a new Vector3 as the cross product of the current vector and the \"other\" one\r\n * The cross product is then orthogonal to both current and \"other\"\r\n * @param other defines the right operand\r\n * @returns the cross product\r\n */\r\n Vector3.prototype.cross = function (other) {\r\n return Vector3.Cross(this, other);\r\n };\r\n /**\r\n * Normalize the current Vector3 with the given input length.\r\n * Please note that this is an in place operation.\r\n * @param len the length of the vector\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.normalizeFromLength = function (len) {\r\n if (len === 0 || len === 1.0) {\r\n return this;\r\n }\r\n return this.scaleInPlace(1.0 / len);\r\n };\r\n /**\r\n * Normalize the current Vector3 to a new vector\r\n * @returns the new Vector3\r\n */\r\n Vector3.prototype.normalizeToNew = function () {\r\n var normalized = new Vector3(0, 0, 0);\r\n this.normalizeToRef(normalized);\r\n return normalized;\r\n };\r\n /**\r\n * Normalize the current Vector3 to the reference\r\n * @param reference define the Vector3 to update\r\n * @returns the updated Vector3\r\n */\r\n Vector3.prototype.normalizeToRef = function (reference) {\r\n var len = this.length();\r\n if (len === 0 || len === 1.0) {\r\n return reference.copyFromFloats(this._x, this._y, this._z);\r\n }\r\n return this.scaleToRef(1.0 / len, reference);\r\n };\r\n /**\r\n * Creates a new Vector3 copied from the current Vector3\r\n * @returns the new Vector3\r\n */\r\n Vector3.prototype.clone = function () {\r\n return new Vector3(this._x, this._y, this._z);\r\n };\r\n /**\r\n * Copies the given vector coordinates to the current Vector3 ones\r\n * @param source defines the source Vector3\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.copyFrom = function (source) {\r\n return this.copyFromFloats(source._x, source._y, source._z);\r\n };\r\n /**\r\n * Copies the given floats to the current Vector3 coordinates\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.copyFromFloats = function (x, y, z) {\r\n this.x = x;\r\n this.y = y;\r\n this.z = z;\r\n return this;\r\n };\r\n /**\r\n * Copies the given floats to the current Vector3 coordinates\r\n * @param x defines the x coordinate of the operand\r\n * @param y defines the y coordinate of the operand\r\n * @param z defines the z coordinate of the operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.set = function (x, y, z) {\r\n return this.copyFromFloats(x, y, z);\r\n };\r\n /**\r\n * Copies the given float to the current Vector3 coordinates\r\n * @param v defines the x, y and z coordinates of the operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector3.prototype.setAll = function (v) {\r\n this.x = this.y = this.z = v;\r\n return this;\r\n };\r\n // Statics\r\n /**\r\n * Get the clip factor between two vectors\r\n * @param vector0 defines the first operand\r\n * @param vector1 defines the second operand\r\n * @param axis defines the axis to use\r\n * @param size defines the size along the axis\r\n * @returns the clip factor\r\n */\r\n Vector3.GetClipFactor = function (vector0, vector1, axis, size) {\r\n var d0 = Vector3.Dot(vector0, axis) - size;\r\n var d1 = Vector3.Dot(vector1, axis) - size;\r\n var s = d0 / (d0 - d1);\r\n return s;\r\n };\r\n /**\r\n * Get angle between two vectors\r\n * @param vector0 angle between vector0 and vector1\r\n * @param vector1 angle between vector0 and vector1\r\n * @param normal direction of the normal\r\n * @return the angle between vector0 and vector1\r\n */\r\n Vector3.GetAngleBetweenVectors = function (vector0, vector1, normal) {\r\n var v0 = vector0.normalizeToRef(MathTmp.Vector3[1]);\r\n var v1 = vector1.normalizeToRef(MathTmp.Vector3[2]);\r\n var dot = Vector3.Dot(v0, v1);\r\n var n = MathTmp.Vector3[3];\r\n Vector3.CrossToRef(v0, v1, n);\r\n if (Vector3.Dot(n, normal) > 0) {\r\n return Math.acos(dot);\r\n }\r\n return -Math.acos(dot);\r\n };\r\n /**\r\n * Returns a new Vector3 set from the index \"offset\" of the given array\r\n * @param array defines the source array\r\n * @param offset defines the offset in the source array\r\n * @returns the new Vector3\r\n */\r\n Vector3.FromArray = function (array, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n return new Vector3(array[offset], array[offset + 1], array[offset + 2]);\r\n };\r\n /**\r\n * Returns a new Vector3 set from the index \"offset\" of the given Float32Array\r\n * @param array defines the source array\r\n * @param offset defines the offset in the source array\r\n * @returns the new Vector3\r\n * @deprecated Please use FromArray instead.\r\n */\r\n Vector3.FromFloatArray = function (array, offset) {\r\n return Vector3.FromArray(array, offset);\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the element values from the index \"offset\" of the given array\r\n * @param array defines the source array\r\n * @param offset defines the offset in the source array\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.FromArrayToRef = function (array, offset, result) {\r\n result.x = array[offset];\r\n result.y = array[offset + 1];\r\n result.z = array[offset + 2];\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the element values from the index \"offset\" of the given Float32Array\r\n * @param array defines the source array\r\n * @param offset defines the offset in the source array\r\n * @param result defines the Vector3 where to store the result\r\n * @deprecated Please use FromArrayToRef instead.\r\n */\r\n Vector3.FromFloatArrayToRef = function (array, offset, result) {\r\n return Vector3.FromArrayToRef(array, offset, result);\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the given floats.\r\n * @param x defines the x coordinate of the source\r\n * @param y defines the y coordinate of the source\r\n * @param z defines the z coordinate of the source\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.FromFloatsToRef = function (x, y, z, result) {\r\n result.copyFromFloats(x, y, z);\r\n };\r\n /**\r\n * Returns a new Vector3 set to (0.0, 0.0, 0.0)\r\n * @returns a new empty Vector3\r\n */\r\n Vector3.Zero = function () {\r\n return new Vector3(0.0, 0.0, 0.0);\r\n };\r\n /**\r\n * Returns a new Vector3 set to (1.0, 1.0, 1.0)\r\n * @returns a new unit Vector3\r\n */\r\n Vector3.One = function () {\r\n return new Vector3(1.0, 1.0, 1.0);\r\n };\r\n /**\r\n * Returns a new Vector3 set to (0.0, 1.0, 0.0)\r\n * @returns a new up Vector3\r\n */\r\n Vector3.Up = function () {\r\n return new Vector3(0.0, 1.0, 0.0);\r\n };\r\n Object.defineProperty(Vector3, \"UpReadOnly\", {\r\n /**\r\n * Gets a up Vector3 that must not be updated\r\n */\r\n get: function () {\r\n return Vector3._UpReadOnly;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Vector3, \"ZeroReadOnly\", {\r\n /**\r\n * Gets a zero Vector3 that must not be updated\r\n */\r\n get: function () {\r\n return Vector3._ZeroReadOnly;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Returns a new Vector3 set to (0.0, -1.0, 0.0)\r\n * @returns a new down Vector3\r\n */\r\n Vector3.Down = function () {\r\n return new Vector3(0.0, -1.0, 0.0);\r\n };\r\n /**\r\n * Returns a new Vector3 set to (0.0, 0.0, 1.0)\r\n * @param rightHandedSystem is the scene right-handed (negative z)\r\n * @returns a new forward Vector3\r\n */\r\n Vector3.Forward = function (rightHandedSystem) {\r\n if (rightHandedSystem === void 0) { rightHandedSystem = false; }\r\n return new Vector3(0.0, 0.0, (rightHandedSystem ? -1.0 : 1.0));\r\n };\r\n /**\r\n * Returns a new Vector3 set to (0.0, 0.0, -1.0)\r\n * @param rightHandedSystem is the scene right-handed (negative-z)\r\n * @returns a new forward Vector3\r\n */\r\n Vector3.Backward = function (rightHandedSystem) {\r\n if (rightHandedSystem === void 0) { rightHandedSystem = false; }\r\n return new Vector3(0.0, 0.0, (rightHandedSystem ? 1.0 : -1.0));\r\n };\r\n /**\r\n * Returns a new Vector3 set to (1.0, 0.0, 0.0)\r\n * @returns a new right Vector3\r\n */\r\n Vector3.Right = function () {\r\n return new Vector3(1.0, 0.0, 0.0);\r\n };\r\n /**\r\n * Returns a new Vector3 set to (-1.0, 0.0, 0.0)\r\n * @returns a new left Vector3\r\n */\r\n Vector3.Left = function () {\r\n return new Vector3(-1.0, 0.0, 0.0);\r\n };\r\n /**\r\n * Returns a new Vector3 set with the result of the transformation by the given matrix of the given vector.\r\n * This method computes tranformed coordinates only, not transformed direction vectors (ie. it takes translation in account)\r\n * @param vector defines the Vector3 to transform\r\n * @param transformation defines the transformation matrix\r\n * @returns the transformed Vector3\r\n */\r\n Vector3.TransformCoordinates = function (vector, transformation) {\r\n var result = Vector3.Zero();\r\n Vector3.TransformCoordinatesToRef(vector, transformation, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given vector \"result\" coordinates with the result of the transformation by the given matrix of the given vector\r\n * This method computes tranformed coordinates only, not transformed direction vectors (ie. it takes translation in account)\r\n * @param vector defines the Vector3 to transform\r\n * @param transformation defines the transformation matrix\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.TransformCoordinatesToRef = function (vector, transformation, result) {\r\n Vector3.TransformCoordinatesFromFloatsToRef(vector._x, vector._y, vector._z, transformation, result);\r\n };\r\n /**\r\n * Sets the given vector \"result\" coordinates with the result of the transformation by the given matrix of the given floats (x, y, z)\r\n * This method computes tranformed coordinates only, not transformed direction vectors\r\n * @param x define the x coordinate of the source vector\r\n * @param y define the y coordinate of the source vector\r\n * @param z define the z coordinate of the source vector\r\n * @param transformation defines the transformation matrix\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.TransformCoordinatesFromFloatsToRef = function (x, y, z, transformation, result) {\r\n var m = transformation.m;\r\n var rx = x * m[0] + y * m[4] + z * m[8] + m[12];\r\n var ry = x * m[1] + y * m[5] + z * m[9] + m[13];\r\n var rz = x * m[2] + y * m[6] + z * m[10] + m[14];\r\n var rw = 1 / (x * m[3] + y * m[7] + z * m[11] + m[15]);\r\n result.x = rx * rw;\r\n result.y = ry * rw;\r\n result.z = rz * rw;\r\n };\r\n /**\r\n * Returns a new Vector3 set with the result of the normal transformation by the given matrix of the given vector\r\n * This methods computes transformed normalized direction vectors only (ie. it does not apply translation)\r\n * @param vector defines the Vector3 to transform\r\n * @param transformation defines the transformation matrix\r\n * @returns the new Vector3\r\n */\r\n Vector3.TransformNormal = function (vector, transformation) {\r\n var result = Vector3.Zero();\r\n Vector3.TransformNormalToRef(vector, transformation, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the result of the normal transformation by the given matrix of the given vector\r\n * This methods computes transformed normalized direction vectors only (ie. it does not apply translation)\r\n * @param vector defines the Vector3 to transform\r\n * @param transformation defines the transformation matrix\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.TransformNormalToRef = function (vector, transformation, result) {\r\n this.TransformNormalFromFloatsToRef(vector._x, vector._y, vector._z, transformation, result);\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the result of the normal transformation by the given matrix of the given floats (x, y, z)\r\n * This methods computes transformed normalized direction vectors only (ie. it does not apply translation)\r\n * @param x define the x coordinate of the source vector\r\n * @param y define the y coordinate of the source vector\r\n * @param z define the z coordinate of the source vector\r\n * @param transformation defines the transformation matrix\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.TransformNormalFromFloatsToRef = function (x, y, z, transformation, result) {\r\n var m = transformation.m;\r\n result.x = x * m[0] + y * m[4] + z * m[8];\r\n result.y = x * m[1] + y * m[5] + z * m[9];\r\n result.z = x * m[2] + y * m[6] + z * m[10];\r\n };\r\n /**\r\n * Returns a new Vector3 located for \"amount\" on the CatmullRom interpolation spline defined by the vectors \"value1\", \"value2\", \"value3\", \"value4\"\r\n * @param value1 defines the first control point\r\n * @param value2 defines the second control point\r\n * @param value3 defines the third control point\r\n * @param value4 defines the fourth control point\r\n * @param amount defines the amount on the spline to use\r\n * @returns the new Vector3\r\n */\r\n Vector3.CatmullRom = function (value1, value2, value3, value4, amount) {\r\n var squared = amount * amount;\r\n var cubed = amount * squared;\r\n var x = 0.5 * ((((2.0 * value2._x) + ((-value1._x + value3._x) * amount)) +\r\n (((((2.0 * value1._x) - (5.0 * value2._x)) + (4.0 * value3._x)) - value4._x) * squared)) +\r\n ((((-value1._x + (3.0 * value2._x)) - (3.0 * value3._x)) + value4._x) * cubed));\r\n var y = 0.5 * ((((2.0 * value2._y) + ((-value1._y + value3._y) * amount)) +\r\n (((((2.0 * value1._y) - (5.0 * value2._y)) + (4.0 * value3._y)) - value4._y) * squared)) +\r\n ((((-value1._y + (3.0 * value2._y)) - (3.0 * value3._y)) + value4._y) * cubed));\r\n var z = 0.5 * ((((2.0 * value2._z) + ((-value1._z + value3._z) * amount)) +\r\n (((((2.0 * value1._z) - (5.0 * value2._z)) + (4.0 * value3._z)) - value4._z) * squared)) +\r\n ((((-value1._z + (3.0 * value2._z)) - (3.0 * value3._z)) + value4._z) * cubed));\r\n return new Vector3(x, y, z);\r\n };\r\n /**\r\n * Returns a new Vector3 set with the coordinates of \"value\", if the vector \"value\" is in the cube defined by the vectors \"min\" and \"max\"\r\n * If a coordinate value of \"value\" is lower than one of the \"min\" coordinate, then this \"value\" coordinate is set with the \"min\" one\r\n * If a coordinate value of \"value\" is greater than one of the \"max\" coordinate, then this \"value\" coordinate is set with the \"max\" one\r\n * @param value defines the current value\r\n * @param min defines the lower range value\r\n * @param max defines the upper range value\r\n * @returns the new Vector3\r\n */\r\n Vector3.Clamp = function (value, min, max) {\r\n var v = new Vector3();\r\n Vector3.ClampToRef(value, min, max, v);\r\n return v;\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the coordinates of \"value\", if the vector \"value\" is in the cube defined by the vectors \"min\" and \"max\"\r\n * If a coordinate value of \"value\" is lower than one of the \"min\" coordinate, then this \"value\" coordinate is set with the \"min\" one\r\n * If a coordinate value of \"value\" is greater than one of the \"max\" coordinate, then this \"value\" coordinate is set with the \"max\" one\r\n * @param value defines the current value\r\n * @param min defines the lower range value\r\n * @param max defines the upper range value\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.ClampToRef = function (value, min, max, result) {\r\n var x = value._x;\r\n x = (x > max._x) ? max._x : x;\r\n x = (x < min._x) ? min._x : x;\r\n var y = value._y;\r\n y = (y > max._y) ? max._y : y;\r\n y = (y < min._y) ? min._y : y;\r\n var z = value._z;\r\n z = (z > max._z) ? max._z : z;\r\n z = (z < min._z) ? min._z : z;\r\n result.copyFromFloats(x, y, z);\r\n };\r\n /**\r\n * Checks if a given vector is inside a specific range\r\n * @param v defines the vector to test\r\n * @param min defines the minimum range\r\n * @param max defines the maximum range\r\n */\r\n Vector3.CheckExtends = function (v, min, max) {\r\n min.minimizeInPlace(v);\r\n max.maximizeInPlace(v);\r\n };\r\n /**\r\n * Returns a new Vector3 located for \"amount\" (float) on the Hermite interpolation spline defined by the vectors \"value1\", \"tangent1\", \"value2\", \"tangent2\"\r\n * @param value1 defines the first control point\r\n * @param tangent1 defines the first tangent vector\r\n * @param value2 defines the second control point\r\n * @param tangent2 defines the second tangent vector\r\n * @param amount defines the amount on the interpolation spline (between 0 and 1)\r\n * @returns the new Vector3\r\n */\r\n Vector3.Hermite = function (value1, tangent1, value2, tangent2, amount) {\r\n var squared = amount * amount;\r\n var cubed = amount * squared;\r\n var part1 = ((2.0 * cubed) - (3.0 * squared)) + 1.0;\r\n var part2 = (-2.0 * cubed) + (3.0 * squared);\r\n var part3 = (cubed - (2.0 * squared)) + amount;\r\n var part4 = cubed - squared;\r\n var x = (((value1._x * part1) + (value2._x * part2)) + (tangent1._x * part3)) + (tangent2._x * part4);\r\n var y = (((value1._y * part1) + (value2._y * part2)) + (tangent1._y * part3)) + (tangent2._y * part4);\r\n var z = (((value1._z * part1) + (value2._z * part2)) + (tangent1._z * part3)) + (tangent2._z * part4);\r\n return new Vector3(x, y, z);\r\n };\r\n /**\r\n * Returns a new Vector3 located for \"amount\" (float) on the linear interpolation between the vectors \"start\" and \"end\"\r\n * @param start defines the start value\r\n * @param end defines the end value\r\n * @param amount max defines amount between both (between 0 and 1)\r\n * @returns the new Vector3\r\n */\r\n Vector3.Lerp = function (start, end, amount) {\r\n var result = new Vector3(0, 0, 0);\r\n Vector3.LerpToRef(start, end, amount, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the result of the linear interpolation from the vector \"start\" for \"amount\" to the vector \"end\"\r\n * @param start defines the start value\r\n * @param end defines the end value\r\n * @param amount max defines amount between both (between 0 and 1)\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.LerpToRef = function (start, end, amount, result) {\r\n result.x = start._x + ((end._x - start._x) * amount);\r\n result.y = start._y + ((end._y - start._y) * amount);\r\n result.z = start._z + ((end._z - start._z) * amount);\r\n };\r\n /**\r\n * Returns the dot product (float) between the vectors \"left\" and \"right\"\r\n * @param left defines the left operand\r\n * @param right defines the right operand\r\n * @returns the dot product\r\n */\r\n Vector3.Dot = function (left, right) {\r\n return (left._x * right._x + left._y * right._y + left._z * right._z);\r\n };\r\n /**\r\n * Returns a new Vector3 as the cross product of the vectors \"left\" and \"right\"\r\n * The cross product is then orthogonal to both \"left\" and \"right\"\r\n * @param left defines the left operand\r\n * @param right defines the right operand\r\n * @returns the cross product\r\n */\r\n Vector3.Cross = function (left, right) {\r\n var result = Vector3.Zero();\r\n Vector3.CrossToRef(left, right, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the cross product of \"left\" and \"right\"\r\n * The cross product is then orthogonal to both \"left\" and \"right\"\r\n * @param left defines the left operand\r\n * @param right defines the right operand\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.CrossToRef = function (left, right, result) {\r\n var x = left._y * right._z - left._z * right._y;\r\n var y = left._z * right._x - left._x * right._z;\r\n var z = left._x * right._y - left._y * right._x;\r\n result.copyFromFloats(x, y, z);\r\n };\r\n /**\r\n * Returns a new Vector3 as the normalization of the given vector\r\n * @param vector defines the Vector3 to normalize\r\n * @returns the new Vector3\r\n */\r\n Vector3.Normalize = function (vector) {\r\n var result = Vector3.Zero();\r\n Vector3.NormalizeToRef(vector, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the normalization of the given first vector\r\n * @param vector defines the Vector3 to normalize\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.NormalizeToRef = function (vector, result) {\r\n vector.normalizeToRef(result);\r\n };\r\n /**\r\n * Project a Vector3 onto screen space\r\n * @param vector defines the Vector3 to project\r\n * @param world defines the world matrix to use\r\n * @param transform defines the transform (view x projection) matrix to use\r\n * @param viewport defines the screen viewport to use\r\n * @returns the new Vector3\r\n */\r\n Vector3.Project = function (vector, world, transform, viewport) {\r\n var result = new Vector3();\r\n Vector3.ProjectToRef(vector, world, transform, viewport, result);\r\n return result;\r\n };\r\n /**\r\n * Project a Vector3 onto screen space to reference\r\n * @param vector defines the Vector3 to project\r\n * @param world defines the world matrix to use\r\n * @param transform defines the transform (view x projection) matrix to use\r\n * @param viewport defines the screen viewport to use\r\n * @param result the vector in which the screen space will be stored\r\n * @returns the new Vector3\r\n */\r\n Vector3.ProjectToRef = function (vector, world, transform, viewport, result) {\r\n var cw = viewport.width;\r\n var ch = viewport.height;\r\n var cx = viewport.x;\r\n var cy = viewport.y;\r\n var viewportMatrix = MathTmp.Matrix[1];\r\n Matrix.FromValuesToRef(cw / 2.0, 0, 0, 0, 0, -ch / 2.0, 0, 0, 0, 0, 0.5, 0, cx + cw / 2.0, ch / 2.0 + cy, 0.5, 1, viewportMatrix);\r\n var matrix = MathTmp.Matrix[0];\r\n world.multiplyToRef(transform, matrix);\r\n matrix.multiplyToRef(viewportMatrix, matrix);\r\n Vector3.TransformCoordinatesToRef(vector, matrix, result);\r\n return result;\r\n };\r\n /** @hidden */\r\n Vector3._UnprojectFromInvertedMatrixToRef = function (source, matrix, result) {\r\n Vector3.TransformCoordinatesToRef(source, matrix, result);\r\n var m = matrix.m;\r\n var num = source._x * m[3] + source._y * m[7] + source._z * m[11] + m[15];\r\n if (Scalar.WithinEpsilon(num, 1.0)) {\r\n result.scaleInPlace(1.0 / num);\r\n }\r\n };\r\n /**\r\n * Unproject from screen space to object space\r\n * @param source defines the screen space Vector3 to use\r\n * @param viewportWidth defines the current width of the viewport\r\n * @param viewportHeight defines the current height of the viewport\r\n * @param world defines the world matrix to use (can be set to Identity to go to world space)\r\n * @param transform defines the transform (view x projection) matrix to use\r\n * @returns the new Vector3\r\n */\r\n Vector3.UnprojectFromTransform = function (source, viewportWidth, viewportHeight, world, transform) {\r\n var matrix = MathTmp.Matrix[0];\r\n world.multiplyToRef(transform, matrix);\r\n matrix.invert();\r\n source.x = source._x / viewportWidth * 2 - 1;\r\n source.y = -(source._y / viewportHeight * 2 - 1);\r\n var vector = new Vector3();\r\n Vector3._UnprojectFromInvertedMatrixToRef(source, matrix, vector);\r\n return vector;\r\n };\r\n /**\r\n * Unproject from screen space to object space\r\n * @param source defines the screen space Vector3 to use\r\n * @param viewportWidth defines the current width of the viewport\r\n * @param viewportHeight defines the current height of the viewport\r\n * @param world defines the world matrix to use (can be set to Identity to go to world space)\r\n * @param view defines the view matrix to use\r\n * @param projection defines the projection matrix to use\r\n * @returns the new Vector3\r\n */\r\n Vector3.Unproject = function (source, viewportWidth, viewportHeight, world, view, projection) {\r\n var result = Vector3.Zero();\r\n Vector3.UnprojectToRef(source, viewportWidth, viewportHeight, world, view, projection, result);\r\n return result;\r\n };\r\n /**\r\n * Unproject from screen space to object space\r\n * @param source defines the screen space Vector3 to use\r\n * @param viewportWidth defines the current width of the viewport\r\n * @param viewportHeight defines the current height of the viewport\r\n * @param world defines the world matrix to use (can be set to Identity to go to world space)\r\n * @param view defines the view matrix to use\r\n * @param projection defines the projection matrix to use\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.UnprojectToRef = function (source, viewportWidth, viewportHeight, world, view, projection, result) {\r\n Vector3.UnprojectFloatsToRef(source._x, source._y, source._z, viewportWidth, viewportHeight, world, view, projection, result);\r\n };\r\n /**\r\n * Unproject from screen space to object space\r\n * @param sourceX defines the screen space x coordinate to use\r\n * @param sourceY defines the screen space y coordinate to use\r\n * @param sourceZ defines the screen space z coordinate to use\r\n * @param viewportWidth defines the current width of the viewport\r\n * @param viewportHeight defines the current height of the viewport\r\n * @param world defines the world matrix to use (can be set to Identity to go to world space)\r\n * @param view defines the view matrix to use\r\n * @param projection defines the projection matrix to use\r\n * @param result defines the Vector3 where to store the result\r\n */\r\n Vector3.UnprojectFloatsToRef = function (sourceX, sourceY, sourceZ, viewportWidth, viewportHeight, world, view, projection, result) {\r\n var matrix = MathTmp.Matrix[0];\r\n world.multiplyToRef(view, matrix);\r\n matrix.multiplyToRef(projection, matrix);\r\n matrix.invert();\r\n var screenSource = MathTmp.Vector3[0];\r\n screenSource.x = sourceX / viewportWidth * 2 - 1;\r\n screenSource.y = -(sourceY / viewportHeight * 2 - 1);\r\n screenSource.z = 2 * sourceZ - 1.0;\r\n Vector3._UnprojectFromInvertedMatrixToRef(screenSource, matrix, result);\r\n };\r\n /**\r\n * Gets the minimal coordinate values between two Vector3\r\n * @param left defines the first operand\r\n * @param right defines the second operand\r\n * @returns the new Vector3\r\n */\r\n Vector3.Minimize = function (left, right) {\r\n var min = left.clone();\r\n min.minimizeInPlace(right);\r\n return min;\r\n };\r\n /**\r\n * Gets the maximal coordinate values between two Vector3\r\n * @param left defines the first operand\r\n * @param right defines the second operand\r\n * @returns the new Vector3\r\n */\r\n Vector3.Maximize = function (left, right) {\r\n var max = left.clone();\r\n max.maximizeInPlace(right);\r\n return max;\r\n };\r\n /**\r\n * Returns the distance between the vectors \"value1\" and \"value2\"\r\n * @param value1 defines the first operand\r\n * @param value2 defines the second operand\r\n * @returns the distance\r\n */\r\n Vector3.Distance = function (value1, value2) {\r\n return Math.sqrt(Vector3.DistanceSquared(value1, value2));\r\n };\r\n /**\r\n * Returns the squared distance between the vectors \"value1\" and \"value2\"\r\n * @param value1 defines the first operand\r\n * @param value2 defines the second operand\r\n * @returns the squared distance\r\n */\r\n Vector3.DistanceSquared = function (value1, value2) {\r\n var x = value1._x - value2._x;\r\n var y = value1._y - value2._y;\r\n var z = value1._z - value2._z;\r\n return (x * x) + (y * y) + (z * z);\r\n };\r\n /**\r\n * Returns a new Vector3 located at the center between \"value1\" and \"value2\"\r\n * @param value1 defines the first operand\r\n * @param value2 defines the second operand\r\n * @returns the new Vector3\r\n */\r\n Vector3.Center = function (value1, value2) {\r\n var center = value1.add(value2);\r\n center.scaleInPlace(0.5);\r\n return center;\r\n };\r\n /**\r\n * Given three orthogonal normalized left-handed oriented Vector3 axis in space (target system),\r\n * RotationFromAxis() returns the rotation Euler angles (ex : rotation.x, rotation.y, rotation.z) to apply\r\n * to something in order to rotate it from its local system to the given target system\r\n * Note: axis1, axis2 and axis3 are normalized during this operation\r\n * @param axis1 defines the first axis\r\n * @param axis2 defines the second axis\r\n * @param axis3 defines the third axis\r\n * @returns a new Vector3\r\n */\r\n Vector3.RotationFromAxis = function (axis1, axis2, axis3) {\r\n var rotation = Vector3.Zero();\r\n Vector3.RotationFromAxisToRef(axis1, axis2, axis3, rotation);\r\n return rotation;\r\n };\r\n /**\r\n * The same than RotationFromAxis but updates the given ref Vector3 parameter instead of returning a new Vector3\r\n * @param axis1 defines the first axis\r\n * @param axis2 defines the second axis\r\n * @param axis3 defines the third axis\r\n * @param ref defines the Vector3 where to store the result\r\n */\r\n Vector3.RotationFromAxisToRef = function (axis1, axis2, axis3, ref) {\r\n var quat = MathTmp.Quaternion[0];\r\n Quaternion.RotationQuaternionFromAxisToRef(axis1, axis2, axis3, quat);\r\n quat.toEulerAnglesToRef(ref);\r\n };\r\n Vector3._UpReadOnly = Vector3.Up();\r\n Vector3._ZeroReadOnly = Vector3.Zero();\r\n return Vector3;\r\n}());\r\nexport { Vector3 };\r\n/**\r\n * Vector4 class created for EulerAngle class conversion to Quaternion\r\n */\r\nvar Vector4 = /** @class */ (function () {\r\n /**\r\n * Creates a Vector4 object from the given floats.\r\n * @param x x value of the vector\r\n * @param y y value of the vector\r\n * @param z z value of the vector\r\n * @param w w value of the vector\r\n */\r\n function Vector4(\r\n /** x value of the vector */\r\n x, \r\n /** y value of the vector */\r\n y, \r\n /** z value of the vector */\r\n z, \r\n /** w value of the vector */\r\n w) {\r\n this.x = x;\r\n this.y = y;\r\n this.z = z;\r\n this.w = w;\r\n }\r\n /**\r\n * Returns the string with the Vector4 coordinates.\r\n * @returns a string containing all the vector values\r\n */\r\n Vector4.prototype.toString = function () {\r\n return \"{X: \" + this.x + \" Y:\" + this.y + \" Z:\" + this.z + \" W:\" + this.w + \"}\";\r\n };\r\n /**\r\n * Returns the string \"Vector4\".\r\n * @returns \"Vector4\"\r\n */\r\n Vector4.prototype.getClassName = function () {\r\n return \"Vector4\";\r\n };\r\n /**\r\n * Returns the Vector4 hash code.\r\n * @returns a unique hash code\r\n */\r\n Vector4.prototype.getHashCode = function () {\r\n var hash = this.x | 0;\r\n hash = (hash * 397) ^ (this.y | 0);\r\n hash = (hash * 397) ^ (this.z | 0);\r\n hash = (hash * 397) ^ (this.w | 0);\r\n return hash;\r\n };\r\n // Operators\r\n /**\r\n * Returns a new array populated with 4 elements : the Vector4 coordinates.\r\n * @returns the resulting array\r\n */\r\n Vector4.prototype.asArray = function () {\r\n var result = new Array();\r\n this.toArray(result, 0);\r\n return result;\r\n };\r\n /**\r\n * Populates the given array from the given index with the Vector4 coordinates.\r\n * @param array array to populate\r\n * @param index index of the array to start at (default: 0)\r\n * @returns the Vector4.\r\n */\r\n Vector4.prototype.toArray = function (array, index) {\r\n if (index === undefined) {\r\n index = 0;\r\n }\r\n array[index] = this.x;\r\n array[index + 1] = this.y;\r\n array[index + 2] = this.z;\r\n array[index + 3] = this.w;\r\n return this;\r\n };\r\n /**\r\n * Update the current vector from an array\r\n * @param array defines the destination array\r\n * @param index defines the offset in the destination array\r\n * @returns the current Vector3\r\n */\r\n Vector4.prototype.fromArray = function (array, index) {\r\n if (index === void 0) { index = 0; }\r\n Vector4.FromArrayToRef(array, index, this);\r\n return this;\r\n };\r\n /**\r\n * Adds the given vector to the current Vector4.\r\n * @param otherVector the vector to add\r\n * @returns the updated Vector4.\r\n */\r\n Vector4.prototype.addInPlace = function (otherVector) {\r\n this.x += otherVector.x;\r\n this.y += otherVector.y;\r\n this.z += otherVector.z;\r\n this.w += otherVector.w;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector4 as the result of the addition of the current Vector4 and the given one.\r\n * @param otherVector the vector to add\r\n * @returns the resulting vector\r\n */\r\n Vector4.prototype.add = function (otherVector) {\r\n return new Vector4(this.x + otherVector.x, this.y + otherVector.y, this.z + otherVector.z, this.w + otherVector.w);\r\n };\r\n /**\r\n * Updates the given vector \"result\" with the result of the addition of the current Vector4 and the given one.\r\n * @param otherVector the vector to add\r\n * @param result the vector to store the result\r\n * @returns the current Vector4.\r\n */\r\n Vector4.prototype.addToRef = function (otherVector, result) {\r\n result.x = this.x + otherVector.x;\r\n result.y = this.y + otherVector.y;\r\n result.z = this.z + otherVector.z;\r\n result.w = this.w + otherVector.w;\r\n return this;\r\n };\r\n /**\r\n * Subtract in place the given vector from the current Vector4.\r\n * @param otherVector the vector to subtract\r\n * @returns the updated Vector4.\r\n */\r\n Vector4.prototype.subtractInPlace = function (otherVector) {\r\n this.x -= otherVector.x;\r\n this.y -= otherVector.y;\r\n this.z -= otherVector.z;\r\n this.w -= otherVector.w;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector4 with the result of the subtraction of the given vector from the current Vector4.\r\n * @param otherVector the vector to add\r\n * @returns the new vector with the result\r\n */\r\n Vector4.prototype.subtract = function (otherVector) {\r\n return new Vector4(this.x - otherVector.x, this.y - otherVector.y, this.z - otherVector.z, this.w - otherVector.w);\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the result of the subtraction of the given vector from the current Vector4.\r\n * @param otherVector the vector to subtract\r\n * @param result the vector to store the result\r\n * @returns the current Vector4.\r\n */\r\n Vector4.prototype.subtractToRef = function (otherVector, result) {\r\n result.x = this.x - otherVector.x;\r\n result.y = this.y - otherVector.y;\r\n result.z = this.z - otherVector.z;\r\n result.w = this.w - otherVector.w;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector4 set with the result of the subtraction of the given floats from the current Vector4 coordinates.\r\n */\r\n /**\r\n * Returns a new Vector4 set with the result of the subtraction of the given floats from the current Vector4 coordinates.\r\n * @param x value to subtract\r\n * @param y value to subtract\r\n * @param z value to subtract\r\n * @param w value to subtract\r\n * @returns new vector containing the result\r\n */\r\n Vector4.prototype.subtractFromFloats = function (x, y, z, w) {\r\n return new Vector4(this.x - x, this.y - y, this.z - z, this.w - w);\r\n };\r\n /**\r\n * Sets the given vector \"result\" set with the result of the subtraction of the given floats from the current Vector4 coordinates.\r\n * @param x value to subtract\r\n * @param y value to subtract\r\n * @param z value to subtract\r\n * @param w value to subtract\r\n * @param result the vector to store the result in\r\n * @returns the current Vector4.\r\n */\r\n Vector4.prototype.subtractFromFloatsToRef = function (x, y, z, w, result) {\r\n result.x = this.x - x;\r\n result.y = this.y - y;\r\n result.z = this.z - z;\r\n result.w = this.w - w;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector4 set with the current Vector4 negated coordinates.\r\n * @returns a new vector with the negated values\r\n */\r\n Vector4.prototype.negate = function () {\r\n return new Vector4(-this.x, -this.y, -this.z, -this.w);\r\n };\r\n /**\r\n * Negate this vector in place\r\n * @returns this\r\n */\r\n Vector4.prototype.negateInPlace = function () {\r\n this.x *= -1;\r\n this.y *= -1;\r\n this.z *= -1;\r\n this.w *= -1;\r\n return this;\r\n };\r\n /**\r\n * Negate the current Vector4 and stores the result in the given vector \"result\" coordinates\r\n * @param result defines the Vector3 object where to store the result\r\n * @returns the current Vector4\r\n */\r\n Vector4.prototype.negateToRef = function (result) {\r\n return result.copyFromFloats(this.x * -1, this.y * -1, this.z * -1, this.w * -1);\r\n };\r\n /**\r\n * Multiplies the current Vector4 coordinates by scale (float).\r\n * @param scale the number to scale with\r\n * @returns the updated Vector4.\r\n */\r\n Vector4.prototype.scaleInPlace = function (scale) {\r\n this.x *= scale;\r\n this.y *= scale;\r\n this.z *= scale;\r\n this.w *= scale;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector4 set with the current Vector4 coordinates multiplied by scale (float).\r\n * @param scale the number to scale with\r\n * @returns a new vector with the result\r\n */\r\n Vector4.prototype.scale = function (scale) {\r\n return new Vector4(this.x * scale, this.y * scale, this.z * scale, this.w * scale);\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the current Vector4 coordinates multiplied by scale (float).\r\n * @param scale the number to scale with\r\n * @param result a vector to store the result in\r\n * @returns the current Vector4.\r\n */\r\n Vector4.prototype.scaleToRef = function (scale, result) {\r\n result.x = this.x * scale;\r\n result.y = this.y * scale;\r\n result.z = this.z * scale;\r\n result.w = this.w * scale;\r\n return this;\r\n };\r\n /**\r\n * Scale the current Vector4 values by a factor and add the result to a given Vector4\r\n * @param scale defines the scale factor\r\n * @param result defines the Vector4 object where to store the result\r\n * @returns the unmodified current Vector4\r\n */\r\n Vector4.prototype.scaleAndAddToRef = function (scale, result) {\r\n result.x += this.x * scale;\r\n result.y += this.y * scale;\r\n result.z += this.z * scale;\r\n result.w += this.w * scale;\r\n return this;\r\n };\r\n /**\r\n * Boolean : True if the current Vector4 coordinates are stricly equal to the given ones.\r\n * @param otherVector the vector to compare against\r\n * @returns true if they are equal\r\n */\r\n Vector4.prototype.equals = function (otherVector) {\r\n return otherVector && this.x === otherVector.x && this.y === otherVector.y && this.z === otherVector.z && this.w === otherVector.w;\r\n };\r\n /**\r\n * Boolean : True if the current Vector4 coordinates are each beneath the distance \"epsilon\" from the given vector ones.\r\n * @param otherVector vector to compare against\r\n * @param epsilon (Default: very small number)\r\n * @returns true if they are equal\r\n */\r\n Vector4.prototype.equalsWithEpsilon = function (otherVector, epsilon) {\r\n if (epsilon === void 0) { epsilon = Epsilon; }\r\n return otherVector\r\n && Scalar.WithinEpsilon(this.x, otherVector.x, epsilon)\r\n && Scalar.WithinEpsilon(this.y, otherVector.y, epsilon)\r\n && Scalar.WithinEpsilon(this.z, otherVector.z, epsilon)\r\n && Scalar.WithinEpsilon(this.w, otherVector.w, epsilon);\r\n };\r\n /**\r\n * Boolean : True if the given floats are strictly equal to the current Vector4 coordinates.\r\n * @param x x value to compare against\r\n * @param y y value to compare against\r\n * @param z z value to compare against\r\n * @param w w value to compare against\r\n * @returns true if equal\r\n */\r\n Vector4.prototype.equalsToFloats = function (x, y, z, w) {\r\n return this.x === x && this.y === y && this.z === z && this.w === w;\r\n };\r\n /**\r\n * Multiplies in place the current Vector4 by the given one.\r\n * @param otherVector vector to multiple with\r\n * @returns the updated Vector4.\r\n */\r\n Vector4.prototype.multiplyInPlace = function (otherVector) {\r\n this.x *= otherVector.x;\r\n this.y *= otherVector.y;\r\n this.z *= otherVector.z;\r\n this.w *= otherVector.w;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector4 set with the multiplication result of the current Vector4 and the given one.\r\n * @param otherVector vector to multiple with\r\n * @returns resulting new vector\r\n */\r\n Vector4.prototype.multiply = function (otherVector) {\r\n return new Vector4(this.x * otherVector.x, this.y * otherVector.y, this.z * otherVector.z, this.w * otherVector.w);\r\n };\r\n /**\r\n * Updates the given vector \"result\" with the multiplication result of the current Vector4 and the given one.\r\n * @param otherVector vector to multiple with\r\n * @param result vector to store the result\r\n * @returns the current Vector4.\r\n */\r\n Vector4.prototype.multiplyToRef = function (otherVector, result) {\r\n result.x = this.x * otherVector.x;\r\n result.y = this.y * otherVector.y;\r\n result.z = this.z * otherVector.z;\r\n result.w = this.w * otherVector.w;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector4 set with the multiplication result of the given floats and the current Vector4 coordinates.\r\n * @param x x value multiply with\r\n * @param y y value multiply with\r\n * @param z z value multiply with\r\n * @param w w value multiply with\r\n * @returns resulting new vector\r\n */\r\n Vector4.prototype.multiplyByFloats = function (x, y, z, w) {\r\n return new Vector4(this.x * x, this.y * y, this.z * z, this.w * w);\r\n };\r\n /**\r\n * Returns a new Vector4 set with the division result of the current Vector4 by the given one.\r\n * @param otherVector vector to devide with\r\n * @returns resulting new vector\r\n */\r\n Vector4.prototype.divide = function (otherVector) {\r\n return new Vector4(this.x / otherVector.x, this.y / otherVector.y, this.z / otherVector.z, this.w / otherVector.w);\r\n };\r\n /**\r\n * Updates the given vector \"result\" with the division result of the current Vector4 by the given one.\r\n * @param otherVector vector to devide with\r\n * @param result vector to store the result\r\n * @returns the current Vector4.\r\n */\r\n Vector4.prototype.divideToRef = function (otherVector, result) {\r\n result.x = this.x / otherVector.x;\r\n result.y = this.y / otherVector.y;\r\n result.z = this.z / otherVector.z;\r\n result.w = this.w / otherVector.w;\r\n return this;\r\n };\r\n /**\r\n * Divides the current Vector3 coordinates by the given ones.\r\n * @param otherVector vector to devide with\r\n * @returns the updated Vector3.\r\n */\r\n Vector4.prototype.divideInPlace = function (otherVector) {\r\n return this.divideToRef(otherVector, this);\r\n };\r\n /**\r\n * Updates the Vector4 coordinates with the minimum values between its own and the given vector ones\r\n * @param other defines the second operand\r\n * @returns the current updated Vector4\r\n */\r\n Vector4.prototype.minimizeInPlace = function (other) {\r\n if (other.x < this.x) {\r\n this.x = other.x;\r\n }\r\n if (other.y < this.y) {\r\n this.y = other.y;\r\n }\r\n if (other.z < this.z) {\r\n this.z = other.z;\r\n }\r\n if (other.w < this.w) {\r\n this.w = other.w;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Updates the Vector4 coordinates with the maximum values between its own and the given vector ones\r\n * @param other defines the second operand\r\n * @returns the current updated Vector4\r\n */\r\n Vector4.prototype.maximizeInPlace = function (other) {\r\n if (other.x > this.x) {\r\n this.x = other.x;\r\n }\r\n if (other.y > this.y) {\r\n this.y = other.y;\r\n }\r\n if (other.z > this.z) {\r\n this.z = other.z;\r\n }\r\n if (other.w > this.w) {\r\n this.w = other.w;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Gets a new Vector4 from current Vector4 floored values\r\n * @returns a new Vector4\r\n */\r\n Vector4.prototype.floor = function () {\r\n return new Vector4(Math.floor(this.x), Math.floor(this.y), Math.floor(this.z), Math.floor(this.w));\r\n };\r\n /**\r\n * Gets a new Vector4 from current Vector3 floored values\r\n * @returns a new Vector4\r\n */\r\n Vector4.prototype.fract = function () {\r\n return new Vector4(this.x - Math.floor(this.x), this.y - Math.floor(this.y), this.z - Math.floor(this.z), this.w - Math.floor(this.w));\r\n };\r\n // Properties\r\n /**\r\n * Returns the Vector4 length (float).\r\n * @returns the length\r\n */\r\n Vector4.prototype.length = function () {\r\n return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w);\r\n };\r\n /**\r\n * Returns the Vector4 squared length (float).\r\n * @returns the length squared\r\n */\r\n Vector4.prototype.lengthSquared = function () {\r\n return (this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w);\r\n };\r\n // Methods\r\n /**\r\n * Normalizes in place the Vector4.\r\n * @returns the updated Vector4.\r\n */\r\n Vector4.prototype.normalize = function () {\r\n var len = this.length();\r\n if (len === 0) {\r\n return this;\r\n }\r\n return this.scaleInPlace(1.0 / len);\r\n };\r\n /**\r\n * Returns a new Vector3 from the Vector4 (x, y, z) coordinates.\r\n * @returns this converted to a new vector3\r\n */\r\n Vector4.prototype.toVector3 = function () {\r\n return new Vector3(this.x, this.y, this.z);\r\n };\r\n /**\r\n * Returns a new Vector4 copied from the current one.\r\n * @returns the new cloned vector\r\n */\r\n Vector4.prototype.clone = function () {\r\n return new Vector4(this.x, this.y, this.z, this.w);\r\n };\r\n /**\r\n * Updates the current Vector4 with the given one coordinates.\r\n * @param source the source vector to copy from\r\n * @returns the updated Vector4.\r\n */\r\n Vector4.prototype.copyFrom = function (source) {\r\n this.x = source.x;\r\n this.y = source.y;\r\n this.z = source.z;\r\n this.w = source.w;\r\n return this;\r\n };\r\n /**\r\n * Updates the current Vector4 coordinates with the given floats.\r\n * @param x float to copy from\r\n * @param y float to copy from\r\n * @param z float to copy from\r\n * @param w float to copy from\r\n * @returns the updated Vector4.\r\n */\r\n Vector4.prototype.copyFromFloats = function (x, y, z, w) {\r\n this.x = x;\r\n this.y = y;\r\n this.z = z;\r\n this.w = w;\r\n return this;\r\n };\r\n /**\r\n * Updates the current Vector4 coordinates with the given floats.\r\n * @param x float to set from\r\n * @param y float to set from\r\n * @param z float to set from\r\n * @param w float to set from\r\n * @returns the updated Vector4.\r\n */\r\n Vector4.prototype.set = function (x, y, z, w) {\r\n return this.copyFromFloats(x, y, z, w);\r\n };\r\n /**\r\n * Copies the given float to the current Vector3 coordinates\r\n * @param v defines the x, y, z and w coordinates of the operand\r\n * @returns the current updated Vector3\r\n */\r\n Vector4.prototype.setAll = function (v) {\r\n this.x = this.y = this.z = this.w = v;\r\n return this;\r\n };\r\n // Statics\r\n /**\r\n * Returns a new Vector4 set from the starting index of the given array.\r\n * @param array the array to pull values from\r\n * @param offset the offset into the array to start at\r\n * @returns the new vector\r\n */\r\n Vector4.FromArray = function (array, offset) {\r\n if (!offset) {\r\n offset = 0;\r\n }\r\n return new Vector4(array[offset], array[offset + 1], array[offset + 2], array[offset + 3]);\r\n };\r\n /**\r\n * Updates the given vector \"result\" from the starting index of the given array.\r\n * @param array the array to pull values from\r\n * @param offset the offset into the array to start at\r\n * @param result the vector to store the result in\r\n */\r\n Vector4.FromArrayToRef = function (array, offset, result) {\r\n result.x = array[offset];\r\n result.y = array[offset + 1];\r\n result.z = array[offset + 2];\r\n result.w = array[offset + 3];\r\n };\r\n /**\r\n * Updates the given vector \"result\" from the starting index of the given Float32Array.\r\n * @param array the array to pull values from\r\n * @param offset the offset into the array to start at\r\n * @param result the vector to store the result in\r\n */\r\n Vector4.FromFloatArrayToRef = function (array, offset, result) {\r\n Vector4.FromArrayToRef(array, offset, result);\r\n };\r\n /**\r\n * Updates the given vector \"result\" coordinates from the given floats.\r\n * @param x float to set from\r\n * @param y float to set from\r\n * @param z float to set from\r\n * @param w float to set from\r\n * @param result the vector to the floats in\r\n */\r\n Vector4.FromFloatsToRef = function (x, y, z, w, result) {\r\n result.x = x;\r\n result.y = y;\r\n result.z = z;\r\n result.w = w;\r\n };\r\n /**\r\n * Returns a new Vector4 set to (0.0, 0.0, 0.0, 0.0)\r\n * @returns the new vector\r\n */\r\n Vector4.Zero = function () {\r\n return new Vector4(0.0, 0.0, 0.0, 0.0);\r\n };\r\n /**\r\n * Returns a new Vector4 set to (1.0, 1.0, 1.0, 1.0)\r\n * @returns the new vector\r\n */\r\n Vector4.One = function () {\r\n return new Vector4(1.0, 1.0, 1.0, 1.0);\r\n };\r\n /**\r\n * Returns a new normalized Vector4 from the given one.\r\n * @param vector the vector to normalize\r\n * @returns the vector\r\n */\r\n Vector4.Normalize = function (vector) {\r\n var result = Vector4.Zero();\r\n Vector4.NormalizeToRef(vector, result);\r\n return result;\r\n };\r\n /**\r\n * Updates the given vector \"result\" from the normalization of the given one.\r\n * @param vector the vector to normalize\r\n * @param result the vector to store the result in\r\n */\r\n Vector4.NormalizeToRef = function (vector, result) {\r\n result.copyFrom(vector);\r\n result.normalize();\r\n };\r\n /**\r\n * Returns a vector with the minimum values from the left and right vectors\r\n * @param left left vector to minimize\r\n * @param right right vector to minimize\r\n * @returns a new vector with the minimum of the left and right vector values\r\n */\r\n Vector4.Minimize = function (left, right) {\r\n var min = left.clone();\r\n min.minimizeInPlace(right);\r\n return min;\r\n };\r\n /**\r\n * Returns a vector with the maximum values from the left and right vectors\r\n * @param left left vector to maximize\r\n * @param right right vector to maximize\r\n * @returns a new vector with the maximum of the left and right vector values\r\n */\r\n Vector4.Maximize = function (left, right) {\r\n var max = left.clone();\r\n max.maximizeInPlace(right);\r\n return max;\r\n };\r\n /**\r\n * Returns the distance (float) between the vectors \"value1\" and \"value2\".\r\n * @param value1 value to calulate the distance between\r\n * @param value2 value to calulate the distance between\r\n * @return the distance between the two vectors\r\n */\r\n Vector4.Distance = function (value1, value2) {\r\n return Math.sqrt(Vector4.DistanceSquared(value1, value2));\r\n };\r\n /**\r\n * Returns the squared distance (float) between the vectors \"value1\" and \"value2\".\r\n * @param value1 value to calulate the distance between\r\n * @param value2 value to calulate the distance between\r\n * @return the distance between the two vectors squared\r\n */\r\n Vector4.DistanceSquared = function (value1, value2) {\r\n var x = value1.x - value2.x;\r\n var y = value1.y - value2.y;\r\n var z = value1.z - value2.z;\r\n var w = value1.w - value2.w;\r\n return (x * x) + (y * y) + (z * z) + (w * w);\r\n };\r\n /**\r\n * Returns a new Vector4 located at the center between the vectors \"value1\" and \"value2\".\r\n * @param value1 value to calulate the center between\r\n * @param value2 value to calulate the center between\r\n * @return the center between the two vectors\r\n */\r\n Vector4.Center = function (value1, value2) {\r\n var center = value1.add(value2);\r\n center.scaleInPlace(0.5);\r\n return center;\r\n };\r\n /**\r\n * Returns a new Vector4 set with the result of the normal transformation by the given matrix of the given vector.\r\n * This methods computes transformed normalized direction vectors only.\r\n * @param vector the vector to transform\r\n * @param transformation the transformation matrix to apply\r\n * @returns the new vector\r\n */\r\n Vector4.TransformNormal = function (vector, transformation) {\r\n var result = Vector4.Zero();\r\n Vector4.TransformNormalToRef(vector, transformation, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the result of the normal transformation by the given matrix of the given vector.\r\n * This methods computes transformed normalized direction vectors only.\r\n * @param vector the vector to transform\r\n * @param transformation the transformation matrix to apply\r\n * @param result the vector to store the result in\r\n */\r\n Vector4.TransformNormalToRef = function (vector, transformation, result) {\r\n var m = transformation.m;\r\n var x = (vector.x * m[0]) + (vector.y * m[4]) + (vector.z * m[8]);\r\n var y = (vector.x * m[1]) + (vector.y * m[5]) + (vector.z * m[9]);\r\n var z = (vector.x * m[2]) + (vector.y * m[6]) + (vector.z * m[10]);\r\n result.x = x;\r\n result.y = y;\r\n result.z = z;\r\n result.w = vector.w;\r\n };\r\n /**\r\n * Sets the given vector \"result\" with the result of the normal transformation by the given matrix of the given floats (x, y, z, w).\r\n * This methods computes transformed normalized direction vectors only.\r\n * @param x value to transform\r\n * @param y value to transform\r\n * @param z value to transform\r\n * @param w value to transform\r\n * @param transformation the transformation matrix to apply\r\n * @param result the vector to store the results in\r\n */\r\n Vector4.TransformNormalFromFloatsToRef = function (x, y, z, w, transformation, result) {\r\n var m = transformation.m;\r\n result.x = (x * m[0]) + (y * m[4]) + (z * m[8]);\r\n result.y = (x * m[1]) + (y * m[5]) + (z * m[9]);\r\n result.z = (x * m[2]) + (y * m[6]) + (z * m[10]);\r\n result.w = w;\r\n };\r\n /**\r\n * Creates a new Vector4 from a Vector3\r\n * @param source defines the source data\r\n * @param w defines the 4th component (default is 0)\r\n * @returns a new Vector4\r\n */\r\n Vector4.FromVector3 = function (source, w) {\r\n if (w === void 0) { w = 0; }\r\n return new Vector4(source._x, source._y, source._z, w);\r\n };\r\n return Vector4;\r\n}());\r\nexport { Vector4 };\r\n/**\r\n * Class used to store quaternion data\r\n * @see https://en.wikipedia.org/wiki/Quaternion\r\n * @see https://doc.babylonjs.com/features/position,_rotation,_scaling\r\n */\r\nvar Quaternion = /** @class */ (function () {\r\n /**\r\n * Creates a new Quaternion from the given floats\r\n * @param x defines the first component (0 by default)\r\n * @param y defines the second component (0 by default)\r\n * @param z defines the third component (0 by default)\r\n * @param w defines the fourth component (1.0 by default)\r\n */\r\n function Quaternion(x, y, z, w) {\r\n if (x === void 0) { x = 0.0; }\r\n if (y === void 0) { y = 0.0; }\r\n if (z === void 0) { z = 0.0; }\r\n if (w === void 0) { w = 1.0; }\r\n /** @hidden */\r\n this._isDirty = true;\r\n this._x = x;\r\n this._y = y;\r\n this._z = z;\r\n this._w = w;\r\n }\r\n Object.defineProperty(Quaternion.prototype, \"x\", {\r\n /** Gets or sets the x coordinate */\r\n get: function () {\r\n return this._x;\r\n },\r\n set: function (value) {\r\n this._x = value;\r\n this._isDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Quaternion.prototype, \"y\", {\r\n /** Gets or sets the y coordinate */\r\n get: function () {\r\n return this._y;\r\n },\r\n set: function (value) {\r\n this._y = value;\r\n this._isDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Quaternion.prototype, \"z\", {\r\n /** Gets or sets the z coordinate */\r\n get: function () {\r\n return this._z;\r\n },\r\n set: function (value) {\r\n this._z = value;\r\n this._isDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Quaternion.prototype, \"w\", {\r\n /** Gets or sets the w coordinate */\r\n get: function () {\r\n return this._w;\r\n },\r\n set: function (value) {\r\n this._w = value;\r\n this._isDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets a string representation for the current quaternion\r\n * @returns a string with the Quaternion coordinates\r\n */\r\n Quaternion.prototype.toString = function () {\r\n return \"{X: \" + this._x + \" Y:\" + this._y + \" Z:\" + this._z + \" W:\" + this._w + \"}\";\r\n };\r\n /**\r\n * Gets the class name of the quaternion\r\n * @returns the string \"Quaternion\"\r\n */\r\n Quaternion.prototype.getClassName = function () {\r\n return \"Quaternion\";\r\n };\r\n /**\r\n * Gets a hash code for this quaternion\r\n * @returns the quaternion hash code\r\n */\r\n Quaternion.prototype.getHashCode = function () {\r\n var hash = this._x | 0;\r\n hash = (hash * 397) ^ (this._y | 0);\r\n hash = (hash * 397) ^ (this._z | 0);\r\n hash = (hash * 397) ^ (this._w | 0);\r\n return hash;\r\n };\r\n /**\r\n * Copy the quaternion to an array\r\n * @returns a new array populated with 4 elements from the quaternion coordinates\r\n */\r\n Quaternion.prototype.asArray = function () {\r\n return [this._x, this._y, this._z, this._w];\r\n };\r\n /**\r\n * Check if two quaternions are equals\r\n * @param otherQuaternion defines the second operand\r\n * @return true if the current quaternion and the given one coordinates are strictly equals\r\n */\r\n Quaternion.prototype.equals = function (otherQuaternion) {\r\n return otherQuaternion && this._x === otherQuaternion._x && this._y === otherQuaternion._y && this._z === otherQuaternion._z && this._w === otherQuaternion._w;\r\n };\r\n /**\r\n * Gets a boolean if two quaternions are equals (using an epsilon value)\r\n * @param otherQuaternion defines the other quaternion\r\n * @param epsilon defines the minimal distance to consider equality\r\n * @returns true if the given quaternion coordinates are close to the current ones by a distance of epsilon.\r\n */\r\n Quaternion.prototype.equalsWithEpsilon = function (otherQuaternion, epsilon) {\r\n if (epsilon === void 0) { epsilon = Epsilon; }\r\n return otherQuaternion\r\n && Scalar.WithinEpsilon(this._x, otherQuaternion._x, epsilon)\r\n && Scalar.WithinEpsilon(this._y, otherQuaternion._y, epsilon)\r\n && Scalar.WithinEpsilon(this._z, otherQuaternion._z, epsilon)\r\n && Scalar.WithinEpsilon(this._w, otherQuaternion._w, epsilon);\r\n };\r\n /**\r\n * Clone the current quaternion\r\n * @returns a new quaternion copied from the current one\r\n */\r\n Quaternion.prototype.clone = function () {\r\n return new Quaternion(this._x, this._y, this._z, this._w);\r\n };\r\n /**\r\n * Copy a quaternion to the current one\r\n * @param other defines the other quaternion\r\n * @returns the updated current quaternion\r\n */\r\n Quaternion.prototype.copyFrom = function (other) {\r\n this.x = other._x;\r\n this.y = other._y;\r\n this.z = other._z;\r\n this.w = other._w;\r\n return this;\r\n };\r\n /**\r\n * Updates the current quaternion with the given float coordinates\r\n * @param x defines the x coordinate\r\n * @param y defines the y coordinate\r\n * @param z defines the z coordinate\r\n * @param w defines the w coordinate\r\n * @returns the updated current quaternion\r\n */\r\n Quaternion.prototype.copyFromFloats = function (x, y, z, w) {\r\n this.x = x;\r\n this.y = y;\r\n this.z = z;\r\n this.w = w;\r\n return this;\r\n };\r\n /**\r\n * Updates the current quaternion from the given float coordinates\r\n * @param x defines the x coordinate\r\n * @param y defines the y coordinate\r\n * @param z defines the z coordinate\r\n * @param w defines the w coordinate\r\n * @returns the updated current quaternion\r\n */\r\n Quaternion.prototype.set = function (x, y, z, w) {\r\n return this.copyFromFloats(x, y, z, w);\r\n };\r\n /**\r\n * Adds two quaternions\r\n * @param other defines the second operand\r\n * @returns a new quaternion as the addition result of the given one and the current quaternion\r\n */\r\n Quaternion.prototype.add = function (other) {\r\n return new Quaternion(this._x + other._x, this._y + other._y, this._z + other._z, this._w + other._w);\r\n };\r\n /**\r\n * Add a quaternion to the current one\r\n * @param other defines the quaternion to add\r\n * @returns the current quaternion\r\n */\r\n Quaternion.prototype.addInPlace = function (other) {\r\n this._x += other._x;\r\n this._y += other._y;\r\n this._z += other._z;\r\n this._w += other._w;\r\n return this;\r\n };\r\n /**\r\n * Subtract two quaternions\r\n * @param other defines the second operand\r\n * @returns a new quaternion as the subtraction result of the given one from the current one\r\n */\r\n Quaternion.prototype.subtract = function (other) {\r\n return new Quaternion(this._x - other._x, this._y - other._y, this._z - other._z, this._w - other._w);\r\n };\r\n /**\r\n * Multiplies the current quaternion by a scale factor\r\n * @param value defines the scale factor\r\n * @returns a new quaternion set by multiplying the current quaternion coordinates by the float \"scale\"\r\n */\r\n Quaternion.prototype.scale = function (value) {\r\n return new Quaternion(this._x * value, this._y * value, this._z * value, this._w * value);\r\n };\r\n /**\r\n * Scale the current quaternion values by a factor and stores the result to a given quaternion\r\n * @param scale defines the scale factor\r\n * @param result defines the Quaternion object where to store the result\r\n * @returns the unmodified current quaternion\r\n */\r\n Quaternion.prototype.scaleToRef = function (scale, result) {\r\n result.x = this._x * scale;\r\n result.y = this._y * scale;\r\n result.z = this._z * scale;\r\n result.w = this._w * scale;\r\n return this;\r\n };\r\n /**\r\n * Multiplies in place the current quaternion by a scale factor\r\n * @param value defines the scale factor\r\n * @returns the current modified quaternion\r\n */\r\n Quaternion.prototype.scaleInPlace = function (value) {\r\n this.x *= value;\r\n this.y *= value;\r\n this.z *= value;\r\n this.w *= value;\r\n return this;\r\n };\r\n /**\r\n * Scale the current quaternion values by a factor and add the result to a given quaternion\r\n * @param scale defines the scale factor\r\n * @param result defines the Quaternion object where to store the result\r\n * @returns the unmodified current quaternion\r\n */\r\n Quaternion.prototype.scaleAndAddToRef = function (scale, result) {\r\n result.x += this._x * scale;\r\n result.y += this._y * scale;\r\n result.z += this._z * scale;\r\n result.w += this._w * scale;\r\n return this;\r\n };\r\n /**\r\n * Multiplies two quaternions\r\n * @param q1 defines the second operand\r\n * @returns a new quaternion set as the multiplication result of the current one with the given one \"q1\"\r\n */\r\n Quaternion.prototype.multiply = function (q1) {\r\n var result = new Quaternion(0, 0, 0, 1.0);\r\n this.multiplyToRef(q1, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given \"result\" as the the multiplication result of the current one with the given one \"q1\"\r\n * @param q1 defines the second operand\r\n * @param result defines the target quaternion\r\n * @returns the current quaternion\r\n */\r\n Quaternion.prototype.multiplyToRef = function (q1, result) {\r\n var x = this._x * q1._w + this._y * q1._z - this._z * q1._y + this._w * q1._x;\r\n var y = -this._x * q1._z + this._y * q1._w + this._z * q1._x + this._w * q1._y;\r\n var z = this._x * q1._y - this._y * q1._x + this._z * q1._w + this._w * q1._z;\r\n var w = -this._x * q1._x - this._y * q1._y - this._z * q1._z + this._w * q1._w;\r\n result.copyFromFloats(x, y, z, w);\r\n return this;\r\n };\r\n /**\r\n * Updates the current quaternion with the multiplication of itself with the given one \"q1\"\r\n * @param q1 defines the second operand\r\n * @returns the currentupdated quaternion\r\n */\r\n Quaternion.prototype.multiplyInPlace = function (q1) {\r\n this.multiplyToRef(q1, this);\r\n return this;\r\n };\r\n /**\r\n * Conjugates (1-q) the current quaternion and stores the result in the given quaternion\r\n * @param ref defines the target quaternion\r\n * @returns the current quaternion\r\n */\r\n Quaternion.prototype.conjugateToRef = function (ref) {\r\n ref.copyFromFloats(-this._x, -this._y, -this._z, this._w);\r\n return this;\r\n };\r\n /**\r\n * Conjugates in place (1-q) the current quaternion\r\n * @returns the current updated quaternion\r\n */\r\n Quaternion.prototype.conjugateInPlace = function () {\r\n this.x *= -1;\r\n this.y *= -1;\r\n this.z *= -1;\r\n return this;\r\n };\r\n /**\r\n * Conjugates in place (1-q) the current quaternion\r\n * @returns a new quaternion\r\n */\r\n Quaternion.prototype.conjugate = function () {\r\n var result = new Quaternion(-this._x, -this._y, -this._z, this._w);\r\n return result;\r\n };\r\n /**\r\n * Gets length of current quaternion\r\n * @returns the quaternion length (float)\r\n */\r\n Quaternion.prototype.length = function () {\r\n return Math.sqrt((this._x * this._x) + (this._y * this._y) + (this._z * this._z) + (this._w * this._w));\r\n };\r\n /**\r\n * Normalize in place the current quaternion\r\n * @returns the current updated quaternion\r\n */\r\n Quaternion.prototype.normalize = function () {\r\n var len = this.length();\r\n if (len === 0) {\r\n return this;\r\n }\r\n var inv = 1.0 / len;\r\n this.x *= inv;\r\n this.y *= inv;\r\n this.z *= inv;\r\n this.w *= inv;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector3 set with the Euler angles translated from the current quaternion\r\n * @param order is a reserved parameter and is ignored for now\r\n * @returns a new Vector3 containing the Euler angles\r\n */\r\n Quaternion.prototype.toEulerAngles = function (order) {\r\n if (order === void 0) { order = \"YZX\"; }\r\n var result = Vector3.Zero();\r\n this.toEulerAnglesToRef(result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given vector3 \"result\" with the Euler angles translated from the current quaternion\r\n * @param result defines the vector which will be filled with the Euler angles\r\n * @returns the current unchanged quaternion\r\n */\r\n Quaternion.prototype.toEulerAnglesToRef = function (result) {\r\n var qz = this._z;\r\n var qx = this._x;\r\n var qy = this._y;\r\n var qw = this._w;\r\n var sqw = qw * qw;\r\n var sqz = qz * qz;\r\n var sqx = qx * qx;\r\n var sqy = qy * qy;\r\n var zAxisY = qy * qz - qx * qw;\r\n var limit = .4999999;\r\n if (zAxisY < -limit) {\r\n result.y = 2 * Math.atan2(qy, qw);\r\n result.x = Math.PI / 2;\r\n result.z = 0;\r\n }\r\n else if (zAxisY > limit) {\r\n result.y = 2 * Math.atan2(qy, qw);\r\n result.x = -Math.PI / 2;\r\n result.z = 0;\r\n }\r\n else {\r\n result.z = Math.atan2(2.0 * (qx * qy + qz * qw), (-sqz - sqx + sqy + sqw));\r\n result.x = Math.asin(-2.0 * (qz * qy - qx * qw));\r\n result.y = Math.atan2(2.0 * (qz * qx + qy * qw), (sqz - sqx - sqy + sqw));\r\n }\r\n return this;\r\n };\r\n /**\r\n * Updates the given rotation matrix with the current quaternion values\r\n * @param result defines the target matrix\r\n * @returns the current unchanged quaternion\r\n */\r\n Quaternion.prototype.toRotationMatrix = function (result) {\r\n Matrix.FromQuaternionToRef(this, result);\r\n return this;\r\n };\r\n /**\r\n * Updates the current quaternion from the given rotation matrix values\r\n * @param matrix defines the source matrix\r\n * @returns the current updated quaternion\r\n */\r\n Quaternion.prototype.fromRotationMatrix = function (matrix) {\r\n Quaternion.FromRotationMatrixToRef(matrix, this);\r\n return this;\r\n };\r\n // Statics\r\n /**\r\n * Creates a new quaternion from a rotation matrix\r\n * @param matrix defines the source matrix\r\n * @returns a new quaternion created from the given rotation matrix values\r\n */\r\n Quaternion.FromRotationMatrix = function (matrix) {\r\n var result = new Quaternion();\r\n Quaternion.FromRotationMatrixToRef(matrix, result);\r\n return result;\r\n };\r\n /**\r\n * Updates the given quaternion with the given rotation matrix values\r\n * @param matrix defines the source matrix\r\n * @param result defines the target quaternion\r\n */\r\n Quaternion.FromRotationMatrixToRef = function (matrix, result) {\r\n var data = matrix.m;\r\n var m11 = data[0], m12 = data[4], m13 = data[8];\r\n var m21 = data[1], m22 = data[5], m23 = data[9];\r\n var m31 = data[2], m32 = data[6], m33 = data[10];\r\n var trace = m11 + m22 + m33;\r\n var s;\r\n if (trace > 0) {\r\n s = 0.5 / Math.sqrt(trace + 1.0);\r\n result.w = 0.25 / s;\r\n result.x = (m32 - m23) * s;\r\n result.y = (m13 - m31) * s;\r\n result.z = (m21 - m12) * s;\r\n }\r\n else if (m11 > m22 && m11 > m33) {\r\n s = 2.0 * Math.sqrt(1.0 + m11 - m22 - m33);\r\n result.w = (m32 - m23) / s;\r\n result.x = 0.25 * s;\r\n result.y = (m12 + m21) / s;\r\n result.z = (m13 + m31) / s;\r\n }\r\n else if (m22 > m33) {\r\n s = 2.0 * Math.sqrt(1.0 + m22 - m11 - m33);\r\n result.w = (m13 - m31) / s;\r\n result.x = (m12 + m21) / s;\r\n result.y = 0.25 * s;\r\n result.z = (m23 + m32) / s;\r\n }\r\n else {\r\n s = 2.0 * Math.sqrt(1.0 + m33 - m11 - m22);\r\n result.w = (m21 - m12) / s;\r\n result.x = (m13 + m31) / s;\r\n result.y = (m23 + m32) / s;\r\n result.z = 0.25 * s;\r\n }\r\n };\r\n /**\r\n * Returns the dot product (float) between the quaternions \"left\" and \"right\"\r\n * @param left defines the left operand\r\n * @param right defines the right operand\r\n * @returns the dot product\r\n */\r\n Quaternion.Dot = function (left, right) {\r\n return (left._x * right._x + left._y * right._y + left._z * right._z + left._w * right._w);\r\n };\r\n /**\r\n * Checks if the two quaternions are close to each other\r\n * @param quat0 defines the first quaternion to check\r\n * @param quat1 defines the second quaternion to check\r\n * @returns true if the two quaternions are close to each other\r\n */\r\n Quaternion.AreClose = function (quat0, quat1) {\r\n var dot = Quaternion.Dot(quat0, quat1);\r\n return dot >= 0;\r\n };\r\n /**\r\n * Creates an empty quaternion\r\n * @returns a new quaternion set to (0.0, 0.0, 0.0)\r\n */\r\n Quaternion.Zero = function () {\r\n return new Quaternion(0.0, 0.0, 0.0, 0.0);\r\n };\r\n /**\r\n * Inverse a given quaternion\r\n * @param q defines the source quaternion\r\n * @returns a new quaternion as the inverted current quaternion\r\n */\r\n Quaternion.Inverse = function (q) {\r\n return new Quaternion(-q._x, -q._y, -q._z, q._w);\r\n };\r\n /**\r\n * Inverse a given quaternion\r\n * @param q defines the source quaternion\r\n * @param result the quaternion the result will be stored in\r\n * @returns the result quaternion\r\n */\r\n Quaternion.InverseToRef = function (q, result) {\r\n result.set(-q._x, -q._y, -q._z, q._w);\r\n return result;\r\n };\r\n /**\r\n * Creates an identity quaternion\r\n * @returns the identity quaternion\r\n */\r\n Quaternion.Identity = function () {\r\n return new Quaternion(0.0, 0.0, 0.0, 1.0);\r\n };\r\n /**\r\n * Gets a boolean indicating if the given quaternion is identity\r\n * @param quaternion defines the quaternion to check\r\n * @returns true if the quaternion is identity\r\n */\r\n Quaternion.IsIdentity = function (quaternion) {\r\n return quaternion && quaternion._x === 0 && quaternion._y === 0 && quaternion._z === 0 && quaternion._w === 1;\r\n };\r\n /**\r\n * Creates a quaternion from a rotation around an axis\r\n * @param axis defines the axis to use\r\n * @param angle defines the angle to use\r\n * @returns a new quaternion created from the given axis (Vector3) and angle in radians (float)\r\n */\r\n Quaternion.RotationAxis = function (axis, angle) {\r\n return Quaternion.RotationAxisToRef(axis, angle, new Quaternion());\r\n };\r\n /**\r\n * Creates a rotation around an axis and stores it into the given quaternion\r\n * @param axis defines the axis to use\r\n * @param angle defines the angle to use\r\n * @param result defines the target quaternion\r\n * @returns the target quaternion\r\n */\r\n Quaternion.RotationAxisToRef = function (axis, angle, result) {\r\n var sin = Math.sin(angle / 2);\r\n axis.normalize();\r\n result.w = Math.cos(angle / 2);\r\n result.x = axis._x * sin;\r\n result.y = axis._y * sin;\r\n result.z = axis._z * sin;\r\n return result;\r\n };\r\n /**\r\n * Creates a new quaternion from data stored into an array\r\n * @param array defines the data source\r\n * @param offset defines the offset in the source array where the data starts\r\n * @returns a new quaternion\r\n */\r\n Quaternion.FromArray = function (array, offset) {\r\n if (!offset) {\r\n offset = 0;\r\n }\r\n return new Quaternion(array[offset], array[offset + 1], array[offset + 2], array[offset + 3]);\r\n };\r\n /**\r\n * Updates the given quaternion \"result\" from the starting index of the given array.\r\n * @param array the array to pull values from\r\n * @param offset the offset into the array to start at\r\n * @param result the quaternion to store the result in\r\n */\r\n Quaternion.FromArrayToRef = function (array, offset, result) {\r\n result.x = array[offset];\r\n result.y = array[offset + 1];\r\n result.z = array[offset + 2];\r\n result.w = array[offset + 3];\r\n };\r\n /**\r\n * Create a quaternion from Euler rotation angles\r\n * @param x Pitch\r\n * @param y Yaw\r\n * @param z Roll\r\n * @returns the new Quaternion\r\n */\r\n Quaternion.FromEulerAngles = function (x, y, z) {\r\n var q = new Quaternion();\r\n Quaternion.RotationYawPitchRollToRef(y, x, z, q);\r\n return q;\r\n };\r\n /**\r\n * Updates a quaternion from Euler rotation angles\r\n * @param x Pitch\r\n * @param y Yaw\r\n * @param z Roll\r\n * @param result the quaternion to store the result\r\n * @returns the updated quaternion\r\n */\r\n Quaternion.FromEulerAnglesToRef = function (x, y, z, result) {\r\n Quaternion.RotationYawPitchRollToRef(y, x, z, result);\r\n return result;\r\n };\r\n /**\r\n * Create a quaternion from Euler rotation vector\r\n * @param vec the Euler vector (x Pitch, y Yaw, z Roll)\r\n * @returns the new Quaternion\r\n */\r\n Quaternion.FromEulerVector = function (vec) {\r\n var q = new Quaternion();\r\n Quaternion.RotationYawPitchRollToRef(vec._y, vec._x, vec._z, q);\r\n return q;\r\n };\r\n /**\r\n * Updates a quaternion from Euler rotation vector\r\n * @param vec the Euler vector (x Pitch, y Yaw, z Roll)\r\n * @param result the quaternion to store the result\r\n * @returns the updated quaternion\r\n */\r\n Quaternion.FromEulerVectorToRef = function (vec, result) {\r\n Quaternion.RotationYawPitchRollToRef(vec._y, vec._x, vec._z, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a new quaternion from the given Euler float angles (y, x, z)\r\n * @param yaw defines the rotation around Y axis\r\n * @param pitch defines the rotation around X axis\r\n * @param roll defines the rotation around Z axis\r\n * @returns the new quaternion\r\n */\r\n Quaternion.RotationYawPitchRoll = function (yaw, pitch, roll) {\r\n var q = new Quaternion();\r\n Quaternion.RotationYawPitchRollToRef(yaw, pitch, roll, q);\r\n return q;\r\n };\r\n /**\r\n * Creates a new rotation from the given Euler float angles (y, x, z) and stores it in the target quaternion\r\n * @param yaw defines the rotation around Y axis\r\n * @param pitch defines the rotation around X axis\r\n * @param roll defines the rotation around Z axis\r\n * @param result defines the target quaternion\r\n */\r\n Quaternion.RotationYawPitchRollToRef = function (yaw, pitch, roll, result) {\r\n // Produces a quaternion from Euler angles in the z-y-x orientation (Tait-Bryan angles)\r\n var halfRoll = roll * 0.5;\r\n var halfPitch = pitch * 0.5;\r\n var halfYaw = yaw * 0.5;\r\n var sinRoll = Math.sin(halfRoll);\r\n var cosRoll = Math.cos(halfRoll);\r\n var sinPitch = Math.sin(halfPitch);\r\n var cosPitch = Math.cos(halfPitch);\r\n var sinYaw = Math.sin(halfYaw);\r\n var cosYaw = Math.cos(halfYaw);\r\n result.x = (cosYaw * sinPitch * cosRoll) + (sinYaw * cosPitch * sinRoll);\r\n result.y = (sinYaw * cosPitch * cosRoll) - (cosYaw * sinPitch * sinRoll);\r\n result.z = (cosYaw * cosPitch * sinRoll) - (sinYaw * sinPitch * cosRoll);\r\n result.w = (cosYaw * cosPitch * cosRoll) + (sinYaw * sinPitch * sinRoll);\r\n };\r\n /**\r\n * Creates a new quaternion from the given Euler float angles expressed in z-x-z orientation\r\n * @param alpha defines the rotation around first axis\r\n * @param beta defines the rotation around second axis\r\n * @param gamma defines the rotation around third axis\r\n * @returns the new quaternion\r\n */\r\n Quaternion.RotationAlphaBetaGamma = function (alpha, beta, gamma) {\r\n var result = new Quaternion();\r\n Quaternion.RotationAlphaBetaGammaToRef(alpha, beta, gamma, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a new quaternion from the given Euler float angles expressed in z-x-z orientation and stores it in the target quaternion\r\n * @param alpha defines the rotation around first axis\r\n * @param beta defines the rotation around second axis\r\n * @param gamma defines the rotation around third axis\r\n * @param result defines the target quaternion\r\n */\r\n Quaternion.RotationAlphaBetaGammaToRef = function (alpha, beta, gamma, result) {\r\n // Produces a quaternion from Euler angles in the z-x-z orientation\r\n var halfGammaPlusAlpha = (gamma + alpha) * 0.5;\r\n var halfGammaMinusAlpha = (gamma - alpha) * 0.5;\r\n var halfBeta = beta * 0.5;\r\n result.x = Math.cos(halfGammaMinusAlpha) * Math.sin(halfBeta);\r\n result.y = Math.sin(halfGammaMinusAlpha) * Math.sin(halfBeta);\r\n result.z = Math.sin(halfGammaPlusAlpha) * Math.cos(halfBeta);\r\n result.w = Math.cos(halfGammaPlusAlpha) * Math.cos(halfBeta);\r\n };\r\n /**\r\n * Creates a new quaternion containing the rotation value to reach the target (axis1, axis2, axis3) orientation as a rotated XYZ system (axis1, axis2 and axis3 are normalized during this operation)\r\n * @param axis1 defines the first axis\r\n * @param axis2 defines the second axis\r\n * @param axis3 defines the third axis\r\n * @returns the new quaternion\r\n */\r\n Quaternion.RotationQuaternionFromAxis = function (axis1, axis2, axis3) {\r\n var quat = new Quaternion(0.0, 0.0, 0.0, 0.0);\r\n Quaternion.RotationQuaternionFromAxisToRef(axis1, axis2, axis3, quat);\r\n return quat;\r\n };\r\n /**\r\n * Creates a rotation value to reach the target (axis1, axis2, axis3) orientation as a rotated XYZ system (axis1, axis2 and axis3 are normalized during this operation) and stores it in the target quaternion\r\n * @param axis1 defines the first axis\r\n * @param axis2 defines the second axis\r\n * @param axis3 defines the third axis\r\n * @param ref defines the target quaternion\r\n */\r\n Quaternion.RotationQuaternionFromAxisToRef = function (axis1, axis2, axis3, ref) {\r\n var rotMat = MathTmp.Matrix[0];\r\n Matrix.FromXYZAxesToRef(axis1.normalize(), axis2.normalize(), axis3.normalize(), rotMat);\r\n Quaternion.FromRotationMatrixToRef(rotMat, ref);\r\n };\r\n /**\r\n * Interpolates between two quaternions\r\n * @param left defines first quaternion\r\n * @param right defines second quaternion\r\n * @param amount defines the gradient to use\r\n * @returns the new interpolated quaternion\r\n */\r\n Quaternion.Slerp = function (left, right, amount) {\r\n var result = Quaternion.Identity();\r\n Quaternion.SlerpToRef(left, right, amount, result);\r\n return result;\r\n };\r\n /**\r\n * Interpolates between two quaternions and stores it into a target quaternion\r\n * @param left defines first quaternion\r\n * @param right defines second quaternion\r\n * @param amount defines the gradient to use\r\n * @param result defines the target quaternion\r\n */\r\n Quaternion.SlerpToRef = function (left, right, amount, result) {\r\n var num2;\r\n var num3;\r\n var num4 = (((left._x * right._x) + (left._y * right._y)) + (left._z * right._z)) + (left._w * right._w);\r\n var flag = false;\r\n if (num4 < 0) {\r\n flag = true;\r\n num4 = -num4;\r\n }\r\n if (num4 > 0.999999) {\r\n num3 = 1 - amount;\r\n num2 = flag ? -amount : amount;\r\n }\r\n else {\r\n var num5 = Math.acos(num4);\r\n var num6 = (1.0 / Math.sin(num5));\r\n num3 = (Math.sin((1.0 - amount) * num5)) * num6;\r\n num2 = flag ? ((-Math.sin(amount * num5)) * num6) : ((Math.sin(amount * num5)) * num6);\r\n }\r\n result.x = (num3 * left._x) + (num2 * right._x);\r\n result.y = (num3 * left._y) + (num2 * right._y);\r\n result.z = (num3 * left._z) + (num2 * right._z);\r\n result.w = (num3 * left._w) + (num2 * right._w);\r\n };\r\n /**\r\n * Interpolate between two quaternions using Hermite interpolation\r\n * @param value1 defines first quaternion\r\n * @param tangent1 defines the incoming tangent\r\n * @param value2 defines second quaternion\r\n * @param tangent2 defines the outgoing tangent\r\n * @param amount defines the target quaternion\r\n * @returns the new interpolated quaternion\r\n */\r\n Quaternion.Hermite = function (value1, tangent1, value2, tangent2, amount) {\r\n var squared = amount * amount;\r\n var cubed = amount * squared;\r\n var part1 = ((2.0 * cubed) - (3.0 * squared)) + 1.0;\r\n var part2 = (-2.0 * cubed) + (3.0 * squared);\r\n var part3 = (cubed - (2.0 * squared)) + amount;\r\n var part4 = cubed - squared;\r\n var x = (((value1._x * part1) + (value2._x * part2)) + (tangent1._x * part3)) + (tangent2._x * part4);\r\n var y = (((value1._y * part1) + (value2._y * part2)) + (tangent1._y * part3)) + (tangent2._y * part4);\r\n var z = (((value1._z * part1) + (value2._z * part2)) + (tangent1._z * part3)) + (tangent2._z * part4);\r\n var w = (((value1._w * part1) + (value2._w * part2)) + (tangent1._w * part3)) + (tangent2._w * part4);\r\n return new Quaternion(x, y, z, w);\r\n };\r\n return Quaternion;\r\n}());\r\nexport { Quaternion };\r\n/**\r\n * Class used to store matrix data (4x4)\r\n */\r\nvar Matrix = /** @class */ (function () {\r\n /**\r\n * Creates an empty matrix (filled with zeros)\r\n */\r\n function Matrix() {\r\n this._isIdentity = false;\r\n this._isIdentityDirty = true;\r\n this._isIdentity3x2 = true;\r\n this._isIdentity3x2Dirty = true;\r\n /**\r\n * Gets the update flag of the matrix which is an unique number for the matrix.\r\n * It will be incremented every time the matrix data change.\r\n * You can use it to speed the comparison between two versions of the same matrix.\r\n */\r\n this.updateFlag = -1;\r\n if (PerformanceConfigurator.MatrixTrackPrecisionChange) {\r\n PerformanceConfigurator.MatrixTrackedMatrices.push(this);\r\n }\r\n this._m = new PerformanceConfigurator.MatrixCurrentType(16);\r\n this._updateIdentityStatus(false);\r\n }\r\n Object.defineProperty(Matrix, \"Use64Bits\", {\r\n /**\r\n * Gets the precision of matrix computations\r\n */\r\n get: function () {\r\n return PerformanceConfigurator.MatrixUse64Bits;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Matrix.prototype, \"m\", {\r\n /**\r\n * Gets the internal data of the matrix\r\n */\r\n get: function () { return this._m; },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n Matrix.prototype._markAsUpdated = function () {\r\n this.updateFlag = Matrix._updateFlagSeed++;\r\n this._isIdentity = false;\r\n this._isIdentity3x2 = false;\r\n this._isIdentityDirty = true;\r\n this._isIdentity3x2Dirty = true;\r\n };\r\n /** @hidden */\r\n Matrix.prototype._updateIdentityStatus = function (isIdentity, isIdentityDirty, isIdentity3x2, isIdentity3x2Dirty) {\r\n if (isIdentityDirty === void 0) { isIdentityDirty = false; }\r\n if (isIdentity3x2 === void 0) { isIdentity3x2 = false; }\r\n if (isIdentity3x2Dirty === void 0) { isIdentity3x2Dirty = true; }\r\n this.updateFlag = Matrix._updateFlagSeed++;\r\n this._isIdentity = isIdentity;\r\n this._isIdentity3x2 = isIdentity || isIdentity3x2;\r\n this._isIdentityDirty = this._isIdentity ? false : isIdentityDirty;\r\n this._isIdentity3x2Dirty = this._isIdentity3x2 ? false : isIdentity3x2Dirty;\r\n };\r\n // Properties\r\n /**\r\n * Check if the current matrix is identity\r\n * @returns true is the matrix is the identity matrix\r\n */\r\n Matrix.prototype.isIdentity = function () {\r\n if (this._isIdentityDirty) {\r\n this._isIdentityDirty = false;\r\n var m = this._m;\r\n this._isIdentity = (m[0] === 1.0 && m[1] === 0.0 && m[2] === 0.0 && m[3] === 0.0 &&\r\n m[4] === 0.0 && m[5] === 1.0 && m[6] === 0.0 && m[7] === 0.0 &&\r\n m[8] === 0.0 && m[9] === 0.0 && m[10] === 1.0 && m[11] === 0.0 &&\r\n m[12] === 0.0 && m[13] === 0.0 && m[14] === 0.0 && m[15] === 1.0);\r\n }\r\n return this._isIdentity;\r\n };\r\n /**\r\n * Check if the current matrix is identity as a texture matrix (3x2 store in 4x4)\r\n * @returns true is the matrix is the identity matrix\r\n */\r\n Matrix.prototype.isIdentityAs3x2 = function () {\r\n if (this._isIdentity3x2Dirty) {\r\n this._isIdentity3x2Dirty = false;\r\n if (this._m[0] !== 1.0 || this._m[5] !== 1.0 || this._m[15] !== 1.0) {\r\n this._isIdentity3x2 = false;\r\n }\r\n else if (this._m[1] !== 0.0 || this._m[2] !== 0.0 || this._m[3] !== 0.0 ||\r\n this._m[4] !== 0.0 || this._m[6] !== 0.0 || this._m[7] !== 0.0 ||\r\n this._m[8] !== 0.0 || this._m[9] !== 0.0 || this._m[10] !== 0.0 || this._m[11] !== 0.0 ||\r\n this._m[12] !== 0.0 || this._m[13] !== 0.0 || this._m[14] !== 0.0) {\r\n this._isIdentity3x2 = false;\r\n }\r\n else {\r\n this._isIdentity3x2 = true;\r\n }\r\n }\r\n return this._isIdentity3x2;\r\n };\r\n /**\r\n * Gets the determinant of the matrix\r\n * @returns the matrix determinant\r\n */\r\n Matrix.prototype.determinant = function () {\r\n if (this._isIdentity === true) {\r\n return 1;\r\n }\r\n var m = this._m;\r\n var m00 = m[0], m01 = m[1], m02 = m[2], m03 = m[3];\r\n var m10 = m[4], m11 = m[5], m12 = m[6], m13 = m[7];\r\n var m20 = m[8], m21 = m[9], m22 = m[10], m23 = m[11];\r\n var m30 = m[12], m31 = m[13], m32 = m[14], m33 = m[15];\r\n // https://en.wikipedia.org/wiki/Laplace_expansion\r\n // to compute the deterrminant of a 4x4 Matrix we compute the cofactors of any row or column,\r\n // then we multiply each Cofactor by its corresponding matrix value and sum them all to get the determinant\r\n // Cofactor(i, j) = sign(i,j) * det(Minor(i, j))\r\n // where\r\n // - sign(i,j) = (i+j) % 2 === 0 ? 1 : -1\r\n // - Minor(i, j) is the 3x3 matrix we get by removing row i and column j from current Matrix\r\n //\r\n // Here we do that for the 1st row.\r\n var det_22_33 = m22 * m33 - m32 * m23;\r\n var det_21_33 = m21 * m33 - m31 * m23;\r\n var det_21_32 = m21 * m32 - m31 * m22;\r\n var det_20_33 = m20 * m33 - m30 * m23;\r\n var det_20_32 = m20 * m32 - m22 * m30;\r\n var det_20_31 = m20 * m31 - m30 * m21;\r\n var cofact_00 = +(m11 * det_22_33 - m12 * det_21_33 + m13 * det_21_32);\r\n var cofact_01 = -(m10 * det_22_33 - m12 * det_20_33 + m13 * det_20_32);\r\n var cofact_02 = +(m10 * det_21_33 - m11 * det_20_33 + m13 * det_20_31);\r\n var cofact_03 = -(m10 * det_21_32 - m11 * det_20_32 + m12 * det_20_31);\r\n return m00 * cofact_00 + m01 * cofact_01 + m02 * cofact_02 + m03 * cofact_03;\r\n };\r\n // Methods\r\n /**\r\n * Returns the matrix as a Float32Array or Array\r\n * @returns the matrix underlying array\r\n */\r\n Matrix.prototype.toArray = function () {\r\n return this._m;\r\n };\r\n /**\r\n * Returns the matrix as a Float32Array or Array\r\n * @returns the matrix underlying array.\r\n */\r\n Matrix.prototype.asArray = function () {\r\n return this._m;\r\n };\r\n /**\r\n * Inverts the current matrix in place\r\n * @returns the current inverted matrix\r\n */\r\n Matrix.prototype.invert = function () {\r\n this.invertToRef(this);\r\n return this;\r\n };\r\n /**\r\n * Sets all the matrix elements to zero\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.reset = function () {\r\n Matrix.FromValuesToRef(0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, this);\r\n this._updateIdentityStatus(false);\r\n return this;\r\n };\r\n /**\r\n * Adds the current matrix with a second one\r\n * @param other defines the matrix to add\r\n * @returns a new matrix as the addition of the current matrix and the given one\r\n */\r\n Matrix.prototype.add = function (other) {\r\n var result = new Matrix();\r\n this.addToRef(other, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given matrix \"result\" to the addition of the current matrix and the given one\r\n * @param other defines the matrix to add\r\n * @param result defines the target matrix\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.addToRef = function (other, result) {\r\n var m = this._m;\r\n var resultM = result._m;\r\n var otherM = other.m;\r\n for (var index = 0; index < 16; index++) {\r\n resultM[index] = m[index] + otherM[index];\r\n }\r\n result._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Adds in place the given matrix to the current matrix\r\n * @param other defines the second operand\r\n * @returns the current updated matrix\r\n */\r\n Matrix.prototype.addToSelf = function (other) {\r\n var m = this._m;\r\n var otherM = other.m;\r\n for (var index = 0; index < 16; index++) {\r\n m[index] += otherM[index];\r\n }\r\n this._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Sets the given matrix to the current inverted Matrix\r\n * @param other defines the target matrix\r\n * @returns the unmodified current matrix\r\n */\r\n Matrix.prototype.invertToRef = function (other) {\r\n if (this._isIdentity === true) {\r\n Matrix.IdentityToRef(other);\r\n return this;\r\n }\r\n // the inverse of a Matrix is the transpose of cofactor matrix divided by the determinant\r\n var m = this._m;\r\n var m00 = m[0], m01 = m[1], m02 = m[2], m03 = m[3];\r\n var m10 = m[4], m11 = m[5], m12 = m[6], m13 = m[7];\r\n var m20 = m[8], m21 = m[9], m22 = m[10], m23 = m[11];\r\n var m30 = m[12], m31 = m[13], m32 = m[14], m33 = m[15];\r\n var det_22_33 = m22 * m33 - m32 * m23;\r\n var det_21_33 = m21 * m33 - m31 * m23;\r\n var det_21_32 = m21 * m32 - m31 * m22;\r\n var det_20_33 = m20 * m33 - m30 * m23;\r\n var det_20_32 = m20 * m32 - m22 * m30;\r\n var det_20_31 = m20 * m31 - m30 * m21;\r\n var cofact_00 = +(m11 * det_22_33 - m12 * det_21_33 + m13 * det_21_32);\r\n var cofact_01 = -(m10 * det_22_33 - m12 * det_20_33 + m13 * det_20_32);\r\n var cofact_02 = +(m10 * det_21_33 - m11 * det_20_33 + m13 * det_20_31);\r\n var cofact_03 = -(m10 * det_21_32 - m11 * det_20_32 + m12 * det_20_31);\r\n var det = m00 * cofact_00 + m01 * cofact_01 + m02 * cofact_02 + m03 * cofact_03;\r\n if (det === 0) {\r\n // not invertible\r\n other.copyFrom(this);\r\n return this;\r\n }\r\n var detInv = 1 / det;\r\n var det_12_33 = m12 * m33 - m32 * m13;\r\n var det_11_33 = m11 * m33 - m31 * m13;\r\n var det_11_32 = m11 * m32 - m31 * m12;\r\n var det_10_33 = m10 * m33 - m30 * m13;\r\n var det_10_32 = m10 * m32 - m30 * m12;\r\n var det_10_31 = m10 * m31 - m30 * m11;\r\n var det_12_23 = m12 * m23 - m22 * m13;\r\n var det_11_23 = m11 * m23 - m21 * m13;\r\n var det_11_22 = m11 * m22 - m21 * m12;\r\n var det_10_23 = m10 * m23 - m20 * m13;\r\n var det_10_22 = m10 * m22 - m20 * m12;\r\n var det_10_21 = m10 * m21 - m20 * m11;\r\n var cofact_10 = -(m01 * det_22_33 - m02 * det_21_33 + m03 * det_21_32);\r\n var cofact_11 = +(m00 * det_22_33 - m02 * det_20_33 + m03 * det_20_32);\r\n var cofact_12 = -(m00 * det_21_33 - m01 * det_20_33 + m03 * det_20_31);\r\n var cofact_13 = +(m00 * det_21_32 - m01 * det_20_32 + m02 * det_20_31);\r\n var cofact_20 = +(m01 * det_12_33 - m02 * det_11_33 + m03 * det_11_32);\r\n var cofact_21 = -(m00 * det_12_33 - m02 * det_10_33 + m03 * det_10_32);\r\n var cofact_22 = +(m00 * det_11_33 - m01 * det_10_33 + m03 * det_10_31);\r\n var cofact_23 = -(m00 * det_11_32 - m01 * det_10_32 + m02 * det_10_31);\r\n var cofact_30 = -(m01 * det_12_23 - m02 * det_11_23 + m03 * det_11_22);\r\n var cofact_31 = +(m00 * det_12_23 - m02 * det_10_23 + m03 * det_10_22);\r\n var cofact_32 = -(m00 * det_11_23 - m01 * det_10_23 + m03 * det_10_21);\r\n var cofact_33 = +(m00 * det_11_22 - m01 * det_10_22 + m02 * det_10_21);\r\n Matrix.FromValuesToRef(cofact_00 * detInv, cofact_10 * detInv, cofact_20 * detInv, cofact_30 * detInv, cofact_01 * detInv, cofact_11 * detInv, cofact_21 * detInv, cofact_31 * detInv, cofact_02 * detInv, cofact_12 * detInv, cofact_22 * detInv, cofact_32 * detInv, cofact_03 * detInv, cofact_13 * detInv, cofact_23 * detInv, cofact_33 * detInv, other);\r\n return this;\r\n };\r\n /**\r\n * add a value at the specified position in the current Matrix\r\n * @param index the index of the value within the matrix. between 0 and 15.\r\n * @param value the value to be added\r\n * @returns the current updated matrix\r\n */\r\n Matrix.prototype.addAtIndex = function (index, value) {\r\n this._m[index] += value;\r\n this._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * mutiply the specified position in the current Matrix by a value\r\n * @param index the index of the value within the matrix. between 0 and 15.\r\n * @param value the value to be added\r\n * @returns the current updated matrix\r\n */\r\n Matrix.prototype.multiplyAtIndex = function (index, value) {\r\n this._m[index] *= value;\r\n this._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Inserts the translation vector (using 3 floats) in the current matrix\r\n * @param x defines the 1st component of the translation\r\n * @param y defines the 2nd component of the translation\r\n * @param z defines the 3rd component of the translation\r\n * @returns the current updated matrix\r\n */\r\n Matrix.prototype.setTranslationFromFloats = function (x, y, z) {\r\n this._m[12] = x;\r\n this._m[13] = y;\r\n this._m[14] = z;\r\n this._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Adds the translation vector (using 3 floats) in the current matrix\r\n * @param x defines the 1st component of the translation\r\n * @param y defines the 2nd component of the translation\r\n * @param z defines the 3rd component of the translation\r\n * @returns the current updated matrix\r\n */\r\n Matrix.prototype.addTranslationFromFloats = function (x, y, z) {\r\n this._m[12] += x;\r\n this._m[13] += y;\r\n this._m[14] += z;\r\n this._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Inserts the translation vector in the current matrix\r\n * @param vector3 defines the translation to insert\r\n * @returns the current updated matrix\r\n */\r\n Matrix.prototype.setTranslation = function (vector3) {\r\n return this.setTranslationFromFloats(vector3._x, vector3._y, vector3._z);\r\n };\r\n /**\r\n * Gets the translation value of the current matrix\r\n * @returns a new Vector3 as the extracted translation from the matrix\r\n */\r\n Matrix.prototype.getTranslation = function () {\r\n return new Vector3(this._m[12], this._m[13], this._m[14]);\r\n };\r\n /**\r\n * Fill a Vector3 with the extracted translation from the matrix\r\n * @param result defines the Vector3 where to store the translation\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.getTranslationToRef = function (result) {\r\n result.x = this._m[12];\r\n result.y = this._m[13];\r\n result.z = this._m[14];\r\n return this;\r\n };\r\n /**\r\n * Remove rotation and scaling part from the matrix\r\n * @returns the updated matrix\r\n */\r\n Matrix.prototype.removeRotationAndScaling = function () {\r\n var m = this.m;\r\n Matrix.FromValuesToRef(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, m[12], m[13], m[14], m[15], this);\r\n this._updateIdentityStatus(m[12] === 0 && m[13] === 0 && m[14] === 0 && m[15] === 1);\r\n return this;\r\n };\r\n /**\r\n * Multiply two matrices\r\n * @param other defines the second operand\r\n * @returns a new matrix set with the multiplication result of the current Matrix and the given one\r\n */\r\n Matrix.prototype.multiply = function (other) {\r\n var result = new Matrix();\r\n this.multiplyToRef(other, result);\r\n return result;\r\n };\r\n /**\r\n * Copy the current matrix from the given one\r\n * @param other defines the source matrix\r\n * @returns the current updated matrix\r\n */\r\n Matrix.prototype.copyFrom = function (other) {\r\n other.copyToArray(this._m);\r\n var o = other;\r\n this._updateIdentityStatus(o._isIdentity, o._isIdentityDirty, o._isIdentity3x2, o._isIdentity3x2Dirty);\r\n return this;\r\n };\r\n /**\r\n * Populates the given array from the starting index with the current matrix values\r\n * @param array defines the target array\r\n * @param offset defines the offset in the target array where to start storing values\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.copyToArray = function (array, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n var source = this._m;\r\n array[offset] = source[0];\r\n array[offset + 1] = source[1];\r\n array[offset + 2] = source[2];\r\n array[offset + 3] = source[3];\r\n array[offset + 4] = source[4];\r\n array[offset + 5] = source[5];\r\n array[offset + 6] = source[6];\r\n array[offset + 7] = source[7];\r\n array[offset + 8] = source[8];\r\n array[offset + 9] = source[9];\r\n array[offset + 10] = source[10];\r\n array[offset + 11] = source[11];\r\n array[offset + 12] = source[12];\r\n array[offset + 13] = source[13];\r\n array[offset + 14] = source[14];\r\n array[offset + 15] = source[15];\r\n return this;\r\n };\r\n /**\r\n * Sets the given matrix \"result\" with the multiplication result of the current Matrix and the given one\r\n * @param other defines the second operand\r\n * @param result defines the matrix where to store the multiplication\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.multiplyToRef = function (other, result) {\r\n if (this._isIdentity) {\r\n result.copyFrom(other);\r\n return this;\r\n }\r\n if (other._isIdentity) {\r\n result.copyFrom(this);\r\n return this;\r\n }\r\n this.multiplyToArray(other, result._m, 0);\r\n result._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Sets the Float32Array \"result\" from the given index \"offset\" with the multiplication of the current matrix and the given one\r\n * @param other defines the second operand\r\n * @param result defines the array where to store the multiplication\r\n * @param offset defines the offset in the target array where to start storing values\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.multiplyToArray = function (other, result, offset) {\r\n var m = this._m;\r\n var otherM = other.m;\r\n var tm0 = m[0], tm1 = m[1], tm2 = m[2], tm3 = m[3];\r\n var tm4 = m[4], tm5 = m[5], tm6 = m[6], tm7 = m[7];\r\n var tm8 = m[8], tm9 = m[9], tm10 = m[10], tm11 = m[11];\r\n var tm12 = m[12], tm13 = m[13], tm14 = m[14], tm15 = m[15];\r\n var om0 = otherM[0], om1 = otherM[1], om2 = otherM[2], om3 = otherM[3];\r\n var om4 = otherM[4], om5 = otherM[5], om6 = otherM[6], om7 = otherM[7];\r\n var om8 = otherM[8], om9 = otherM[9], om10 = otherM[10], om11 = otherM[11];\r\n var om12 = otherM[12], om13 = otherM[13], om14 = otherM[14], om15 = otherM[15];\r\n result[offset] = tm0 * om0 + tm1 * om4 + tm2 * om8 + tm3 * om12;\r\n result[offset + 1] = tm0 * om1 + tm1 * om5 + tm2 * om9 + tm3 * om13;\r\n result[offset + 2] = tm0 * om2 + tm1 * om6 + tm2 * om10 + tm3 * om14;\r\n result[offset + 3] = tm0 * om3 + tm1 * om7 + tm2 * om11 + tm3 * om15;\r\n result[offset + 4] = tm4 * om0 + tm5 * om4 + tm6 * om8 + tm7 * om12;\r\n result[offset + 5] = tm4 * om1 + tm5 * om5 + tm6 * om9 + tm7 * om13;\r\n result[offset + 6] = tm4 * om2 + tm5 * om6 + tm6 * om10 + tm7 * om14;\r\n result[offset + 7] = tm4 * om3 + tm5 * om7 + tm6 * om11 + tm7 * om15;\r\n result[offset + 8] = tm8 * om0 + tm9 * om4 + tm10 * om8 + tm11 * om12;\r\n result[offset + 9] = tm8 * om1 + tm9 * om5 + tm10 * om9 + tm11 * om13;\r\n result[offset + 10] = tm8 * om2 + tm9 * om6 + tm10 * om10 + tm11 * om14;\r\n result[offset + 11] = tm8 * om3 + tm9 * om7 + tm10 * om11 + tm11 * om15;\r\n result[offset + 12] = tm12 * om0 + tm13 * om4 + tm14 * om8 + tm15 * om12;\r\n result[offset + 13] = tm12 * om1 + tm13 * om5 + tm14 * om9 + tm15 * om13;\r\n result[offset + 14] = tm12 * om2 + tm13 * om6 + tm14 * om10 + tm15 * om14;\r\n result[offset + 15] = tm12 * om3 + tm13 * om7 + tm14 * om11 + tm15 * om15;\r\n return this;\r\n };\r\n /**\r\n * Check equality between this matrix and a second one\r\n * @param value defines the second matrix to compare\r\n * @returns true is the current matrix and the given one values are strictly equal\r\n */\r\n Matrix.prototype.equals = function (value) {\r\n var other = value;\r\n if (!other) {\r\n return false;\r\n }\r\n if (this._isIdentity || other._isIdentity) {\r\n if (!this._isIdentityDirty && !other._isIdentityDirty) {\r\n return this._isIdentity && other._isIdentity;\r\n }\r\n }\r\n var m = this.m;\r\n var om = other.m;\r\n return (m[0] === om[0] && m[1] === om[1] && m[2] === om[2] && m[3] === om[3] &&\r\n m[4] === om[4] && m[5] === om[5] && m[6] === om[6] && m[7] === om[7] &&\r\n m[8] === om[8] && m[9] === om[9] && m[10] === om[10] && m[11] === om[11] &&\r\n m[12] === om[12] && m[13] === om[13] && m[14] === om[14] && m[15] === om[15]);\r\n };\r\n /**\r\n * Clone the current matrix\r\n * @returns a new matrix from the current matrix\r\n */\r\n Matrix.prototype.clone = function () {\r\n var matrix = new Matrix();\r\n matrix.copyFrom(this);\r\n return matrix;\r\n };\r\n /**\r\n * Returns the name of the current matrix class\r\n * @returns the string \"Matrix\"\r\n */\r\n Matrix.prototype.getClassName = function () {\r\n return \"Matrix\";\r\n };\r\n /**\r\n * Gets the hash code of the current matrix\r\n * @returns the hash code\r\n */\r\n Matrix.prototype.getHashCode = function () {\r\n var hash = this._m[0] | 0;\r\n for (var i = 1; i < 16; i++) {\r\n hash = (hash * 397) ^ (this._m[i] | 0);\r\n }\r\n return hash;\r\n };\r\n /**\r\n * Decomposes the current Matrix into a translation, rotation and scaling components\r\n * @param scale defines the scale vector3 given as a reference to update\r\n * @param rotation defines the rotation quaternion given as a reference to update\r\n * @param translation defines the translation vector3 given as a reference to update\r\n * @returns true if operation was successful\r\n */\r\n Matrix.prototype.decompose = function (scale, rotation, translation) {\r\n if (this._isIdentity) {\r\n if (translation) {\r\n translation.setAll(0);\r\n }\r\n if (scale) {\r\n scale.setAll(1);\r\n }\r\n if (rotation) {\r\n rotation.copyFromFloats(0, 0, 0, 1);\r\n }\r\n return true;\r\n }\r\n var m = this._m;\r\n if (translation) {\r\n translation.copyFromFloats(m[12], m[13], m[14]);\r\n }\r\n scale = scale || MathTmp.Vector3[0];\r\n scale.x = Math.sqrt(m[0] * m[0] + m[1] * m[1] + m[2] * m[2]);\r\n scale.y = Math.sqrt(m[4] * m[4] + m[5] * m[5] + m[6] * m[6]);\r\n scale.z = Math.sqrt(m[8] * m[8] + m[9] * m[9] + m[10] * m[10]);\r\n if (this.determinant() <= 0) {\r\n scale.y *= -1;\r\n }\r\n if (scale._x === 0 || scale._y === 0 || scale._z === 0) {\r\n if (rotation) {\r\n rotation.copyFromFloats(0.0, 0.0, 0.0, 1.0);\r\n }\r\n return false;\r\n }\r\n if (rotation) {\r\n var sx = 1 / scale._x, sy = 1 / scale._y, sz = 1 / scale._z;\r\n Matrix.FromValuesToRef(m[0] * sx, m[1] * sx, m[2] * sx, 0.0, m[4] * sy, m[5] * sy, m[6] * sy, 0.0, m[8] * sz, m[9] * sz, m[10] * sz, 0.0, 0.0, 0.0, 0.0, 1.0, MathTmp.Matrix[0]);\r\n Quaternion.FromRotationMatrixToRef(MathTmp.Matrix[0], rotation);\r\n }\r\n return true;\r\n };\r\n /**\r\n * Gets specific row of the matrix\r\n * @param index defines the number of the row to get\r\n * @returns the index-th row of the current matrix as a new Vector4\r\n */\r\n Matrix.prototype.getRow = function (index) {\r\n if (index < 0 || index > 3) {\r\n return null;\r\n }\r\n var i = index * 4;\r\n return new Vector4(this._m[i + 0], this._m[i + 1], this._m[i + 2], this._m[i + 3]);\r\n };\r\n /**\r\n * Sets the index-th row of the current matrix to the vector4 values\r\n * @param index defines the number of the row to set\r\n * @param row defines the target vector4\r\n * @returns the updated current matrix\r\n */\r\n Matrix.prototype.setRow = function (index, row) {\r\n return this.setRowFromFloats(index, row.x, row.y, row.z, row.w);\r\n };\r\n /**\r\n * Compute the transpose of the matrix\r\n * @returns the new transposed matrix\r\n */\r\n Matrix.prototype.transpose = function () {\r\n return Matrix.Transpose(this);\r\n };\r\n /**\r\n * Compute the transpose of the matrix and store it in a given matrix\r\n * @param result defines the target matrix\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.transposeToRef = function (result) {\r\n Matrix.TransposeToRef(this, result);\r\n return this;\r\n };\r\n /**\r\n * Sets the index-th row of the current matrix with the given 4 x float values\r\n * @param index defines the row index\r\n * @param x defines the x component to set\r\n * @param y defines the y component to set\r\n * @param z defines the z component to set\r\n * @param w defines the w component to set\r\n * @returns the updated current matrix\r\n */\r\n Matrix.prototype.setRowFromFloats = function (index, x, y, z, w) {\r\n if (index < 0 || index > 3) {\r\n return this;\r\n }\r\n var i = index * 4;\r\n this._m[i + 0] = x;\r\n this._m[i + 1] = y;\r\n this._m[i + 2] = z;\r\n this._m[i + 3] = w;\r\n this._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Compute a new matrix set with the current matrix values multiplied by scale (float)\r\n * @param scale defines the scale factor\r\n * @returns a new matrix\r\n */\r\n Matrix.prototype.scale = function (scale) {\r\n var result = new Matrix();\r\n this.scaleToRef(scale, result);\r\n return result;\r\n };\r\n /**\r\n * Scale the current matrix values by a factor to a given result matrix\r\n * @param scale defines the scale factor\r\n * @param result defines the matrix to store the result\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.scaleToRef = function (scale, result) {\r\n for (var index = 0; index < 16; index++) {\r\n result._m[index] = this._m[index] * scale;\r\n }\r\n result._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Scale the current matrix values by a factor and add the result to a given matrix\r\n * @param scale defines the scale factor\r\n * @param result defines the Matrix to store the result\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.scaleAndAddToRef = function (scale, result) {\r\n for (var index = 0; index < 16; index++) {\r\n result._m[index] += this._m[index] * scale;\r\n }\r\n result._markAsUpdated();\r\n return this;\r\n };\r\n /**\r\n * Writes to the given matrix a normal matrix, computed from this one (using values from identity matrix for fourth row and column).\r\n * @param ref matrix to store the result\r\n */\r\n Matrix.prototype.toNormalMatrix = function (ref) {\r\n var tmp = MathTmp.Matrix[0];\r\n this.invertToRef(tmp);\r\n tmp.transposeToRef(ref);\r\n var m = ref._m;\r\n Matrix.FromValuesToRef(m[0], m[1], m[2], 0.0, m[4], m[5], m[6], 0.0, m[8], m[9], m[10], 0.0, 0.0, 0.0, 0.0, 1.0, ref);\r\n };\r\n /**\r\n * Gets only rotation part of the current matrix\r\n * @returns a new matrix sets to the extracted rotation matrix from the current one\r\n */\r\n Matrix.prototype.getRotationMatrix = function () {\r\n var result = new Matrix();\r\n this.getRotationMatrixToRef(result);\r\n return result;\r\n };\r\n /**\r\n * Extracts the rotation matrix from the current one and sets it as the given \"result\"\r\n * @param result defines the target matrix to store data to\r\n * @returns the current matrix\r\n */\r\n Matrix.prototype.getRotationMatrixToRef = function (result) {\r\n var scale = MathTmp.Vector3[0];\r\n if (!this.decompose(scale)) {\r\n Matrix.IdentityToRef(result);\r\n return this;\r\n }\r\n var m = this._m;\r\n var sx = 1 / scale._x, sy = 1 / scale._y, sz = 1 / scale._z;\r\n Matrix.FromValuesToRef(m[0] * sx, m[1] * sx, m[2] * sx, 0.0, m[4] * sy, m[5] * sy, m[6] * sy, 0.0, m[8] * sz, m[9] * sz, m[10] * sz, 0.0, 0.0, 0.0, 0.0, 1.0, result);\r\n return this;\r\n };\r\n /**\r\n * Toggles model matrix from being right handed to left handed in place and vice versa\r\n */\r\n Matrix.prototype.toggleModelMatrixHandInPlace = function () {\r\n var m = this._m;\r\n m[2] *= -1;\r\n m[6] *= -1;\r\n m[8] *= -1;\r\n m[9] *= -1;\r\n m[14] *= -1;\r\n this._markAsUpdated();\r\n };\r\n /**\r\n * Toggles projection matrix from being right handed to left handed in place and vice versa\r\n */\r\n Matrix.prototype.toggleProjectionMatrixHandInPlace = function () {\r\n var m = this._m;\r\n m[8] *= -1;\r\n m[9] *= -1;\r\n m[10] *= -1;\r\n m[11] *= -1;\r\n this._markAsUpdated();\r\n };\r\n // Statics\r\n /**\r\n * Creates a matrix from an array\r\n * @param array defines the source array\r\n * @param offset defines an offset in the source array\r\n * @returns a new Matrix set from the starting index of the given array\r\n */\r\n Matrix.FromArray = function (array, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n var result = new Matrix();\r\n Matrix.FromArrayToRef(array, offset, result);\r\n return result;\r\n };\r\n /**\r\n * Copy the content of an array into a given matrix\r\n * @param array defines the source array\r\n * @param offset defines an offset in the source array\r\n * @param result defines the target matrix\r\n */\r\n Matrix.FromArrayToRef = function (array, offset, result) {\r\n for (var index = 0; index < 16; index++) {\r\n result._m[index] = array[index + offset];\r\n }\r\n result._markAsUpdated();\r\n };\r\n /**\r\n * Stores an array into a matrix after having multiplied each component by a given factor\r\n * @param array defines the source array\r\n * @param offset defines the offset in the source array\r\n * @param scale defines the scaling factor\r\n * @param result defines the target matrix\r\n */\r\n Matrix.FromFloat32ArrayToRefScaled = function (array, offset, scale, result) {\r\n for (var index = 0; index < 16; index++) {\r\n result._m[index] = array[index + offset] * scale;\r\n }\r\n result._markAsUpdated();\r\n };\r\n Object.defineProperty(Matrix, \"IdentityReadOnly\", {\r\n /**\r\n * Gets an identity matrix that must not be updated\r\n */\r\n get: function () {\r\n return Matrix._identityReadOnly;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Stores a list of values (16) inside a given matrix\r\n * @param initialM11 defines 1st value of 1st row\r\n * @param initialM12 defines 2nd value of 1st row\r\n * @param initialM13 defines 3rd value of 1st row\r\n * @param initialM14 defines 4th value of 1st row\r\n * @param initialM21 defines 1st value of 2nd row\r\n * @param initialM22 defines 2nd value of 2nd row\r\n * @param initialM23 defines 3rd value of 2nd row\r\n * @param initialM24 defines 4th value of 2nd row\r\n * @param initialM31 defines 1st value of 3rd row\r\n * @param initialM32 defines 2nd value of 3rd row\r\n * @param initialM33 defines 3rd value of 3rd row\r\n * @param initialM34 defines 4th value of 3rd row\r\n * @param initialM41 defines 1st value of 4th row\r\n * @param initialM42 defines 2nd value of 4th row\r\n * @param initialM43 defines 3rd value of 4th row\r\n * @param initialM44 defines 4th value of 4th row\r\n * @param result defines the target matrix\r\n */\r\n Matrix.FromValuesToRef = function (initialM11, initialM12, initialM13, initialM14, initialM21, initialM22, initialM23, initialM24, initialM31, initialM32, initialM33, initialM34, initialM41, initialM42, initialM43, initialM44, result) {\r\n var m = result._m;\r\n m[0] = initialM11;\r\n m[1] = initialM12;\r\n m[2] = initialM13;\r\n m[3] = initialM14;\r\n m[4] = initialM21;\r\n m[5] = initialM22;\r\n m[6] = initialM23;\r\n m[7] = initialM24;\r\n m[8] = initialM31;\r\n m[9] = initialM32;\r\n m[10] = initialM33;\r\n m[11] = initialM34;\r\n m[12] = initialM41;\r\n m[13] = initialM42;\r\n m[14] = initialM43;\r\n m[15] = initialM44;\r\n result._markAsUpdated();\r\n };\r\n /**\r\n * Creates new matrix from a list of values (16)\r\n * @param initialM11 defines 1st value of 1st row\r\n * @param initialM12 defines 2nd value of 1st row\r\n * @param initialM13 defines 3rd value of 1st row\r\n * @param initialM14 defines 4th value of 1st row\r\n * @param initialM21 defines 1st value of 2nd row\r\n * @param initialM22 defines 2nd value of 2nd row\r\n * @param initialM23 defines 3rd value of 2nd row\r\n * @param initialM24 defines 4th value of 2nd row\r\n * @param initialM31 defines 1st value of 3rd row\r\n * @param initialM32 defines 2nd value of 3rd row\r\n * @param initialM33 defines 3rd value of 3rd row\r\n * @param initialM34 defines 4th value of 3rd row\r\n * @param initialM41 defines 1st value of 4th row\r\n * @param initialM42 defines 2nd value of 4th row\r\n * @param initialM43 defines 3rd value of 4th row\r\n * @param initialM44 defines 4th value of 4th row\r\n * @returns the new matrix\r\n */\r\n Matrix.FromValues = function (initialM11, initialM12, initialM13, initialM14, initialM21, initialM22, initialM23, initialM24, initialM31, initialM32, initialM33, initialM34, initialM41, initialM42, initialM43, initialM44) {\r\n var result = new Matrix();\r\n var m = result._m;\r\n m[0] = initialM11;\r\n m[1] = initialM12;\r\n m[2] = initialM13;\r\n m[3] = initialM14;\r\n m[4] = initialM21;\r\n m[5] = initialM22;\r\n m[6] = initialM23;\r\n m[7] = initialM24;\r\n m[8] = initialM31;\r\n m[9] = initialM32;\r\n m[10] = initialM33;\r\n m[11] = initialM34;\r\n m[12] = initialM41;\r\n m[13] = initialM42;\r\n m[14] = initialM43;\r\n m[15] = initialM44;\r\n result._markAsUpdated();\r\n return result;\r\n };\r\n /**\r\n * Creates a new matrix composed by merging scale (vector3), rotation (quaternion) and translation (vector3)\r\n * @param scale defines the scale vector3\r\n * @param rotation defines the rotation quaternion\r\n * @param translation defines the translation vector3\r\n * @returns a new matrix\r\n */\r\n Matrix.Compose = function (scale, rotation, translation) {\r\n var result = new Matrix();\r\n Matrix.ComposeToRef(scale, rotation, translation, result);\r\n return result;\r\n };\r\n /**\r\n * Sets a matrix to a value composed by merging scale (vector3), rotation (quaternion) and translation (vector3)\r\n * @param scale defines the scale vector3\r\n * @param rotation defines the rotation quaternion\r\n * @param translation defines the translation vector3\r\n * @param result defines the target matrix\r\n */\r\n Matrix.ComposeToRef = function (scale, rotation, translation, result) {\r\n var m = result._m;\r\n var x = rotation._x, y = rotation._y, z = rotation._z, w = rotation._w;\r\n var x2 = x + x, y2 = y + y, z2 = z + z;\r\n var xx = x * x2, xy = x * y2, xz = x * z2;\r\n var yy = y * y2, yz = y * z2, zz = z * z2;\r\n var wx = w * x2, wy = w * y2, wz = w * z2;\r\n var sx = scale._x, sy = scale._y, sz = scale._z;\r\n m[0] = (1 - (yy + zz)) * sx;\r\n m[1] = (xy + wz) * sx;\r\n m[2] = (xz - wy) * sx;\r\n m[3] = 0;\r\n m[4] = (xy - wz) * sy;\r\n m[5] = (1 - (xx + zz)) * sy;\r\n m[6] = (yz + wx) * sy;\r\n m[7] = 0;\r\n m[8] = (xz + wy) * sz;\r\n m[9] = (yz - wx) * sz;\r\n m[10] = (1 - (xx + yy)) * sz;\r\n m[11] = 0;\r\n m[12] = translation._x;\r\n m[13] = translation._y;\r\n m[14] = translation._z;\r\n m[15] = 1;\r\n result._markAsUpdated();\r\n };\r\n /**\r\n * Creates a new identity matrix\r\n * @returns a new identity matrix\r\n */\r\n Matrix.Identity = function () {\r\n var identity = Matrix.FromValues(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0);\r\n identity._updateIdentityStatus(true);\r\n return identity;\r\n };\r\n /**\r\n * Creates a new identity matrix and stores the result in a given matrix\r\n * @param result defines the target matrix\r\n */\r\n Matrix.IdentityToRef = function (result) {\r\n Matrix.FromValuesToRef(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, result);\r\n result._updateIdentityStatus(true);\r\n };\r\n /**\r\n * Creates a new zero matrix\r\n * @returns a new zero matrix\r\n */\r\n Matrix.Zero = function () {\r\n var zero = Matrix.FromValues(0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0);\r\n zero._updateIdentityStatus(false);\r\n return zero;\r\n };\r\n /**\r\n * Creates a new rotation matrix for \"angle\" radians around the X axis\r\n * @param angle defines the angle (in radians) to use\r\n * @return the new matrix\r\n */\r\n Matrix.RotationX = function (angle) {\r\n var result = new Matrix();\r\n Matrix.RotationXToRef(angle, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a new matrix as the invert of a given matrix\r\n * @param source defines the source matrix\r\n * @returns the new matrix\r\n */\r\n Matrix.Invert = function (source) {\r\n var result = new Matrix();\r\n source.invertToRef(result);\r\n return result;\r\n };\r\n /**\r\n * Creates a new rotation matrix for \"angle\" radians around the X axis and stores it in a given matrix\r\n * @param angle defines the angle (in radians) to use\r\n * @param result defines the target matrix\r\n */\r\n Matrix.RotationXToRef = function (angle, result) {\r\n var s = Math.sin(angle);\r\n var c = Math.cos(angle);\r\n Matrix.FromValuesToRef(1.0, 0.0, 0.0, 0.0, 0.0, c, s, 0.0, 0.0, -s, c, 0.0, 0.0, 0.0, 0.0, 1.0, result);\r\n result._updateIdentityStatus(c === 1 && s === 0);\r\n };\r\n /**\r\n * Creates a new rotation matrix for \"angle\" radians around the Y axis\r\n * @param angle defines the angle (in radians) to use\r\n * @return the new matrix\r\n */\r\n Matrix.RotationY = function (angle) {\r\n var result = new Matrix();\r\n Matrix.RotationYToRef(angle, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a new rotation matrix for \"angle\" radians around the Y axis and stores it in a given matrix\r\n * @param angle defines the angle (in radians) to use\r\n * @param result defines the target matrix\r\n */\r\n Matrix.RotationYToRef = function (angle, result) {\r\n var s = Math.sin(angle);\r\n var c = Math.cos(angle);\r\n Matrix.FromValuesToRef(c, 0.0, -s, 0.0, 0.0, 1.0, 0.0, 0.0, s, 0.0, c, 0.0, 0.0, 0.0, 0.0, 1.0, result);\r\n result._updateIdentityStatus(c === 1 && s === 0);\r\n };\r\n /**\r\n * Creates a new rotation matrix for \"angle\" radians around the Z axis\r\n * @param angle defines the angle (in radians) to use\r\n * @return the new matrix\r\n */\r\n Matrix.RotationZ = function (angle) {\r\n var result = new Matrix();\r\n Matrix.RotationZToRef(angle, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a new rotation matrix for \"angle\" radians around the Z axis and stores it in a given matrix\r\n * @param angle defines the angle (in radians) to use\r\n * @param result defines the target matrix\r\n */\r\n Matrix.RotationZToRef = function (angle, result) {\r\n var s = Math.sin(angle);\r\n var c = Math.cos(angle);\r\n Matrix.FromValuesToRef(c, s, 0.0, 0.0, -s, c, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, result);\r\n result._updateIdentityStatus(c === 1 && s === 0);\r\n };\r\n /**\r\n * Creates a new rotation matrix for \"angle\" radians around the given axis\r\n * @param axis defines the axis to use\r\n * @param angle defines the angle (in radians) to use\r\n * @return the new matrix\r\n */\r\n Matrix.RotationAxis = function (axis, angle) {\r\n var result = new Matrix();\r\n Matrix.RotationAxisToRef(axis, angle, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a new rotation matrix for \"angle\" radians around the given axis and stores it in a given matrix\r\n * @param axis defines the axis to use\r\n * @param angle defines the angle (in radians) to use\r\n * @param result defines the target matrix\r\n */\r\n Matrix.RotationAxisToRef = function (axis, angle, result) {\r\n var s = Math.sin(-angle);\r\n var c = Math.cos(-angle);\r\n var c1 = 1 - c;\r\n axis.normalize();\r\n var m = result._m;\r\n m[0] = (axis._x * axis._x) * c1 + c;\r\n m[1] = (axis._x * axis._y) * c1 - (axis._z * s);\r\n m[2] = (axis._x * axis._z) * c1 + (axis._y * s);\r\n m[3] = 0.0;\r\n m[4] = (axis._y * axis._x) * c1 + (axis._z * s);\r\n m[5] = (axis._y * axis._y) * c1 + c;\r\n m[6] = (axis._y * axis._z) * c1 - (axis._x * s);\r\n m[7] = 0.0;\r\n m[8] = (axis._z * axis._x) * c1 - (axis._y * s);\r\n m[9] = (axis._z * axis._y) * c1 + (axis._x * s);\r\n m[10] = (axis._z * axis._z) * c1 + c;\r\n m[11] = 0.0;\r\n m[12] = 0.0;\r\n m[13] = 0.0;\r\n m[14] = 0.0;\r\n m[15] = 1.0;\r\n result._markAsUpdated();\r\n };\r\n /**\r\n * Takes normalised vectors and returns a rotation matrix to align \"from\" with \"to\".\r\n * Taken from http://www.iquilezles.org/www/articles/noacos/noacos.htm\r\n * @param from defines the vector to align\r\n * @param to defines the vector to align to\r\n * @param result defines the target matrix\r\n */\r\n Matrix.RotationAlignToRef = function (from, to, result) {\r\n var v = Vector3.Cross(to, from);\r\n var c = Vector3.Dot(to, from);\r\n var k = 1 / (1 + c);\r\n var m = result._m;\r\n m[0] = v._x * v._x * k + c;\r\n m[1] = v._y * v._x * k - v._z;\r\n m[2] = v._z * v._x * k + v._y;\r\n m[3] = 0;\r\n m[4] = v._x * v._y * k + v._z;\r\n m[5] = v._y * v._y * k + c;\r\n m[6] = v._z * v._y * k - v._x;\r\n m[7] = 0;\r\n m[8] = v._x * v._z * k - v._y;\r\n m[9] = v._y * v._z * k + v._x;\r\n m[10] = v._z * v._z * k + c;\r\n m[11] = 0;\r\n m[12] = 0;\r\n m[13] = 0;\r\n m[14] = 0;\r\n m[15] = 1;\r\n result._markAsUpdated();\r\n };\r\n /**\r\n * Creates a rotation matrix\r\n * @param yaw defines the yaw angle in radians (Y axis)\r\n * @param pitch defines the pitch angle in radians (X axis)\r\n * @param roll defines the roll angle in radians (Z axis)\r\n * @returns the new rotation matrix\r\n */\r\n Matrix.RotationYawPitchRoll = function (yaw, pitch, roll) {\r\n var result = new Matrix();\r\n Matrix.RotationYawPitchRollToRef(yaw, pitch, roll, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a rotation matrix and stores it in a given matrix\r\n * @param yaw defines the yaw angle in radians (Y axis)\r\n * @param pitch defines the pitch angle in radians (X axis)\r\n * @param roll defines the roll angle in radians (Z axis)\r\n * @param result defines the target matrix\r\n */\r\n Matrix.RotationYawPitchRollToRef = function (yaw, pitch, roll, result) {\r\n Quaternion.RotationYawPitchRollToRef(yaw, pitch, roll, MathTmp.Quaternion[0]);\r\n MathTmp.Quaternion[0].toRotationMatrix(result);\r\n };\r\n /**\r\n * Creates a scaling matrix\r\n * @param x defines the scale factor on X axis\r\n * @param y defines the scale factor on Y axis\r\n * @param z defines the scale factor on Z axis\r\n * @returns the new matrix\r\n */\r\n Matrix.Scaling = function (x, y, z) {\r\n var result = new Matrix();\r\n Matrix.ScalingToRef(x, y, z, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a scaling matrix and stores it in a given matrix\r\n * @param x defines the scale factor on X axis\r\n * @param y defines the scale factor on Y axis\r\n * @param z defines the scale factor on Z axis\r\n * @param result defines the target matrix\r\n */\r\n Matrix.ScalingToRef = function (x, y, z, result) {\r\n Matrix.FromValuesToRef(x, 0.0, 0.0, 0.0, 0.0, y, 0.0, 0.0, 0.0, 0.0, z, 0.0, 0.0, 0.0, 0.0, 1.0, result);\r\n result._updateIdentityStatus(x === 1 && y === 1 && z === 1);\r\n };\r\n /**\r\n * Creates a translation matrix\r\n * @param x defines the translation on X axis\r\n * @param y defines the translation on Y axis\r\n * @param z defines the translationon Z axis\r\n * @returns the new matrix\r\n */\r\n Matrix.Translation = function (x, y, z) {\r\n var result = new Matrix();\r\n Matrix.TranslationToRef(x, y, z, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a translation matrix and stores it in a given matrix\r\n * @param x defines the translation on X axis\r\n * @param y defines the translation on Y axis\r\n * @param z defines the translationon Z axis\r\n * @param result defines the target matrix\r\n */\r\n Matrix.TranslationToRef = function (x, y, z, result) {\r\n Matrix.FromValuesToRef(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, x, y, z, 1.0, result);\r\n result._updateIdentityStatus(x === 0 && y === 0 && z === 0);\r\n };\r\n /**\r\n * Returns a new Matrix whose values are the interpolated values for \"gradient\" (float) between the ones of the matrices \"startValue\" and \"endValue\".\r\n * @param startValue defines the start value\r\n * @param endValue defines the end value\r\n * @param gradient defines the gradient factor\r\n * @returns the new matrix\r\n */\r\n Matrix.Lerp = function (startValue, endValue, gradient) {\r\n var result = new Matrix();\r\n Matrix.LerpToRef(startValue, endValue, gradient, result);\r\n return result;\r\n };\r\n /**\r\n * Set the given matrix \"result\" as the interpolated values for \"gradient\" (float) between the ones of the matrices \"startValue\" and \"endValue\".\r\n * @param startValue defines the start value\r\n * @param endValue defines the end value\r\n * @param gradient defines the gradient factor\r\n * @param result defines the Matrix object where to store data\r\n */\r\n Matrix.LerpToRef = function (startValue, endValue, gradient, result) {\r\n var resultM = result._m;\r\n var startM = startValue.m;\r\n var endM = endValue.m;\r\n for (var index = 0; index < 16; index++) {\r\n resultM[index] = startM[index] * (1.0 - gradient) + endM[index] * gradient;\r\n }\r\n result._markAsUpdated();\r\n };\r\n /**\r\n * Builds a new matrix whose values are computed by:\r\n * * decomposing the the \"startValue\" and \"endValue\" matrices into their respective scale, rotation and translation matrices\r\n * * interpolating for \"gradient\" (float) the values between each of these decomposed matrices between the start and the end\r\n * * recomposing a new matrix from these 3 interpolated scale, rotation and translation matrices\r\n * @param startValue defines the first matrix\r\n * @param endValue defines the second matrix\r\n * @param gradient defines the gradient between the two matrices\r\n * @returns the new matrix\r\n */\r\n Matrix.DecomposeLerp = function (startValue, endValue, gradient) {\r\n var result = new Matrix();\r\n Matrix.DecomposeLerpToRef(startValue, endValue, gradient, result);\r\n return result;\r\n };\r\n /**\r\n * Update a matrix to values which are computed by:\r\n * * decomposing the the \"startValue\" and \"endValue\" matrices into their respective scale, rotation and translation matrices\r\n * * interpolating for \"gradient\" (float) the values between each of these decomposed matrices between the start and the end\r\n * * recomposing a new matrix from these 3 interpolated scale, rotation and translation matrices\r\n * @param startValue defines the first matrix\r\n * @param endValue defines the second matrix\r\n * @param gradient defines the gradient between the two matrices\r\n * @param result defines the target matrix\r\n */\r\n Matrix.DecomposeLerpToRef = function (startValue, endValue, gradient, result) {\r\n var startScale = MathTmp.Vector3[0];\r\n var startRotation = MathTmp.Quaternion[0];\r\n var startTranslation = MathTmp.Vector3[1];\r\n startValue.decompose(startScale, startRotation, startTranslation);\r\n var endScale = MathTmp.Vector3[2];\r\n var endRotation = MathTmp.Quaternion[1];\r\n var endTranslation = MathTmp.Vector3[3];\r\n endValue.decompose(endScale, endRotation, endTranslation);\r\n var resultScale = MathTmp.Vector3[4];\r\n Vector3.LerpToRef(startScale, endScale, gradient, resultScale);\r\n var resultRotation = MathTmp.Quaternion[2];\r\n Quaternion.SlerpToRef(startRotation, endRotation, gradient, resultRotation);\r\n var resultTranslation = MathTmp.Vector3[5];\r\n Vector3.LerpToRef(startTranslation, endTranslation, gradient, resultTranslation);\r\n Matrix.ComposeToRef(resultScale, resultRotation, resultTranslation, result);\r\n };\r\n /**\r\n * Gets a new rotation matrix used to rotate an entity so as it looks at the target vector3, from the eye vector3 position, the up vector3 being oriented like \"up\"\r\n * This function works in left handed mode\r\n * @param eye defines the final position of the entity\r\n * @param target defines where the entity should look at\r\n * @param up defines the up vector for the entity\r\n * @returns the new matrix\r\n */\r\n Matrix.LookAtLH = function (eye, target, up) {\r\n var result = new Matrix();\r\n Matrix.LookAtLHToRef(eye, target, up, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given \"result\" Matrix to a rotation matrix used to rotate an entity so that it looks at the target vector3, from the eye vector3 position, the up vector3 being oriented like \"up\".\r\n * This function works in left handed mode\r\n * @param eye defines the final position of the entity\r\n * @param target defines where the entity should look at\r\n * @param up defines the up vector for the entity\r\n * @param result defines the target matrix\r\n */\r\n Matrix.LookAtLHToRef = function (eye, target, up, result) {\r\n var xAxis = MathTmp.Vector3[0];\r\n var yAxis = MathTmp.Vector3[1];\r\n var zAxis = MathTmp.Vector3[2];\r\n // Z axis\r\n target.subtractToRef(eye, zAxis);\r\n zAxis.normalize();\r\n // X axis\r\n Vector3.CrossToRef(up, zAxis, xAxis);\r\n var xSquareLength = xAxis.lengthSquared();\r\n if (xSquareLength === 0) {\r\n xAxis.x = 1.0;\r\n }\r\n else {\r\n xAxis.normalizeFromLength(Math.sqrt(xSquareLength));\r\n }\r\n // Y axis\r\n Vector3.CrossToRef(zAxis, xAxis, yAxis);\r\n yAxis.normalize();\r\n // Eye angles\r\n var ex = -Vector3.Dot(xAxis, eye);\r\n var ey = -Vector3.Dot(yAxis, eye);\r\n var ez = -Vector3.Dot(zAxis, eye);\r\n Matrix.FromValuesToRef(xAxis._x, yAxis._x, zAxis._x, 0.0, xAxis._y, yAxis._y, zAxis._y, 0.0, xAxis._z, yAxis._z, zAxis._z, 0.0, ex, ey, ez, 1.0, result);\r\n };\r\n /**\r\n * Gets a new rotation matrix used to rotate an entity so as it looks at the target vector3, from the eye vector3 position, the up vector3 being oriented like \"up\"\r\n * This function works in right handed mode\r\n * @param eye defines the final position of the entity\r\n * @param target defines where the entity should look at\r\n * @param up defines the up vector for the entity\r\n * @returns the new matrix\r\n */\r\n Matrix.LookAtRH = function (eye, target, up) {\r\n var result = new Matrix();\r\n Matrix.LookAtRHToRef(eye, target, up, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the given \"result\" Matrix to a rotation matrix used to rotate an entity so that it looks at the target vector3, from the eye vector3 position, the up vector3 being oriented like \"up\".\r\n * This function works in right handed mode\r\n * @param eye defines the final position of the entity\r\n * @param target defines where the entity should look at\r\n * @param up defines the up vector for the entity\r\n * @param result defines the target matrix\r\n */\r\n Matrix.LookAtRHToRef = function (eye, target, up, result) {\r\n var xAxis = MathTmp.Vector3[0];\r\n var yAxis = MathTmp.Vector3[1];\r\n var zAxis = MathTmp.Vector3[2];\r\n // Z axis\r\n eye.subtractToRef(target, zAxis);\r\n zAxis.normalize();\r\n // X axis\r\n Vector3.CrossToRef(up, zAxis, xAxis);\r\n var xSquareLength = xAxis.lengthSquared();\r\n if (xSquareLength === 0) {\r\n xAxis.x = 1.0;\r\n }\r\n else {\r\n xAxis.normalizeFromLength(Math.sqrt(xSquareLength));\r\n }\r\n // Y axis\r\n Vector3.CrossToRef(zAxis, xAxis, yAxis);\r\n yAxis.normalize();\r\n // Eye angles\r\n var ex = -Vector3.Dot(xAxis, eye);\r\n var ey = -Vector3.Dot(yAxis, eye);\r\n var ez = -Vector3.Dot(zAxis, eye);\r\n Matrix.FromValuesToRef(xAxis._x, yAxis._x, zAxis._x, 0.0, xAxis._y, yAxis._y, zAxis._y, 0.0, xAxis._z, yAxis._z, zAxis._z, 0.0, ex, ey, ez, 1.0, result);\r\n };\r\n /**\r\n * Create a left-handed orthographic projection matrix\r\n * @param width defines the viewport width\r\n * @param height defines the viewport height\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @returns a new matrix as a left-handed orthographic projection matrix\r\n */\r\n Matrix.OrthoLH = function (width, height, znear, zfar) {\r\n var matrix = new Matrix();\r\n Matrix.OrthoLHToRef(width, height, znear, zfar, matrix);\r\n return matrix;\r\n };\r\n /**\r\n * Store a left-handed orthographic projection to a given matrix\r\n * @param width defines the viewport width\r\n * @param height defines the viewport height\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @param result defines the target matrix\r\n */\r\n Matrix.OrthoLHToRef = function (width, height, znear, zfar, result) {\r\n var n = znear;\r\n var f = zfar;\r\n var a = 2.0 / width;\r\n var b = 2.0 / height;\r\n var c = 2.0 / (f - n);\r\n var d = -(f + n) / (f - n);\r\n Matrix.FromValuesToRef(a, 0.0, 0.0, 0.0, 0.0, b, 0.0, 0.0, 0.0, 0.0, c, 0.0, 0.0, 0.0, d, 1.0, result);\r\n result._updateIdentityStatus(a === 1 && b === 1 && c === 1 && d === 0);\r\n };\r\n /**\r\n * Create a left-handed orthographic projection matrix\r\n * @param left defines the viewport left coordinate\r\n * @param right defines the viewport right coordinate\r\n * @param bottom defines the viewport bottom coordinate\r\n * @param top defines the viewport top coordinate\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @returns a new matrix as a left-handed orthographic projection matrix\r\n */\r\n Matrix.OrthoOffCenterLH = function (left, right, bottom, top, znear, zfar) {\r\n var matrix = new Matrix();\r\n Matrix.OrthoOffCenterLHToRef(left, right, bottom, top, znear, zfar, matrix);\r\n return matrix;\r\n };\r\n /**\r\n * Stores a left-handed orthographic projection into a given matrix\r\n * @param left defines the viewport left coordinate\r\n * @param right defines the viewport right coordinate\r\n * @param bottom defines the viewport bottom coordinate\r\n * @param top defines the viewport top coordinate\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @param result defines the target matrix\r\n */\r\n Matrix.OrthoOffCenterLHToRef = function (left, right, bottom, top, znear, zfar, result) {\r\n var n = znear;\r\n var f = zfar;\r\n var a = 2.0 / (right - left);\r\n var b = 2.0 / (top - bottom);\r\n var c = 2.0 / (f - n);\r\n var d = -(f + n) / (f - n);\r\n var i0 = (left + right) / (left - right);\r\n var i1 = (top + bottom) / (bottom - top);\r\n Matrix.FromValuesToRef(a, 0.0, 0.0, 0.0, 0.0, b, 0.0, 0.0, 0.0, 0.0, c, 0.0, i0, i1, d, 1.0, result);\r\n result._markAsUpdated();\r\n };\r\n /**\r\n * Creates a right-handed orthographic projection matrix\r\n * @param left defines the viewport left coordinate\r\n * @param right defines the viewport right coordinate\r\n * @param bottom defines the viewport bottom coordinate\r\n * @param top defines the viewport top coordinate\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @returns a new matrix as a right-handed orthographic projection matrix\r\n */\r\n Matrix.OrthoOffCenterRH = function (left, right, bottom, top, znear, zfar) {\r\n var matrix = new Matrix();\r\n Matrix.OrthoOffCenterRHToRef(left, right, bottom, top, znear, zfar, matrix);\r\n return matrix;\r\n };\r\n /**\r\n * Stores a right-handed orthographic projection into a given matrix\r\n * @param left defines the viewport left coordinate\r\n * @param right defines the viewport right coordinate\r\n * @param bottom defines the viewport bottom coordinate\r\n * @param top defines the viewport top coordinate\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @param result defines the target matrix\r\n */\r\n Matrix.OrthoOffCenterRHToRef = function (left, right, bottom, top, znear, zfar, result) {\r\n Matrix.OrthoOffCenterLHToRef(left, right, bottom, top, znear, zfar, result);\r\n result._m[10] *= -1; // No need to call _markAsUpdated as previous function already called it and let _isIdentityDirty to true\r\n };\r\n /**\r\n * Creates a left-handed perspective projection matrix\r\n * @param width defines the viewport width\r\n * @param height defines the viewport height\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @returns a new matrix as a left-handed perspective projection matrix\r\n */\r\n Matrix.PerspectiveLH = function (width, height, znear, zfar) {\r\n var matrix = new Matrix();\r\n var n = znear;\r\n var f = zfar;\r\n var a = 2.0 * n / width;\r\n var b = 2.0 * n / height;\r\n var c = (f + n) / (f - n);\r\n var d = -2.0 * f * n / (f - n);\r\n Matrix.FromValuesToRef(a, 0.0, 0.0, 0.0, 0.0, b, 0.0, 0.0, 0.0, 0.0, c, 1.0, 0.0, 0.0, d, 0.0, matrix);\r\n matrix._updateIdentityStatus(false);\r\n return matrix;\r\n };\r\n /**\r\n * Creates a left-handed perspective projection matrix\r\n * @param fov defines the horizontal field of view\r\n * @param aspect defines the aspect ratio\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @returns a new matrix as a left-handed perspective projection matrix\r\n */\r\n Matrix.PerspectiveFovLH = function (fov, aspect, znear, zfar) {\r\n var matrix = new Matrix();\r\n Matrix.PerspectiveFovLHToRef(fov, aspect, znear, zfar, matrix);\r\n return matrix;\r\n };\r\n /**\r\n * Stores a left-handed perspective projection into a given matrix\r\n * @param fov defines the horizontal field of view\r\n * @param aspect defines the aspect ratio\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @param result defines the target matrix\r\n * @param isVerticalFovFixed defines it the fov is vertically fixed (default) or horizontally\r\n */\r\n Matrix.PerspectiveFovLHToRef = function (fov, aspect, znear, zfar, result, isVerticalFovFixed) {\r\n if (isVerticalFovFixed === void 0) { isVerticalFovFixed = true; }\r\n var n = znear;\r\n var f = zfar;\r\n var t = 1.0 / (Math.tan(fov * 0.5));\r\n var a = isVerticalFovFixed ? (t / aspect) : t;\r\n var b = isVerticalFovFixed ? t : (t * aspect);\r\n var c = (f + n) / (f - n);\r\n var d = -2.0 * f * n / (f - n);\r\n Matrix.FromValuesToRef(a, 0.0, 0.0, 0.0, 0.0, b, 0.0, 0.0, 0.0, 0.0, c, 1.0, 0.0, 0.0, d, 0.0, result);\r\n result._updateIdentityStatus(false);\r\n };\r\n /**\r\n * Stores a left-handed perspective projection into a given matrix with depth reversed\r\n * @param fov defines the horizontal field of view\r\n * @param aspect defines the aspect ratio\r\n * @param znear defines the near clip plane\r\n * @param zfar not used as infinity is used as far clip\r\n * @param result defines the target matrix\r\n * @param isVerticalFovFixed defines it the fov is vertically fixed (default) or horizontally\r\n */\r\n Matrix.PerspectiveFovReverseLHToRef = function (fov, aspect, znear, zfar, result, isVerticalFovFixed) {\r\n if (isVerticalFovFixed === void 0) { isVerticalFovFixed = true; }\r\n var t = 1.0 / (Math.tan(fov * 0.5));\r\n var a = isVerticalFovFixed ? (t / aspect) : t;\r\n var b = isVerticalFovFixed ? t : (t * aspect);\r\n Matrix.FromValuesToRef(a, 0.0, 0.0, 0.0, 0.0, b, 0.0, 0.0, 0.0, 0.0, -znear, 1.0, 0.0, 0.0, 1.0, 0.0, result);\r\n result._updateIdentityStatus(false);\r\n };\r\n /**\r\n * Creates a right-handed perspective projection matrix\r\n * @param fov defines the horizontal field of view\r\n * @param aspect defines the aspect ratio\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @returns a new matrix as a right-handed perspective projection matrix\r\n */\r\n Matrix.PerspectiveFovRH = function (fov, aspect, znear, zfar) {\r\n var matrix = new Matrix();\r\n Matrix.PerspectiveFovRHToRef(fov, aspect, znear, zfar, matrix);\r\n return matrix;\r\n };\r\n /**\r\n * Stores a right-handed perspective projection into a given matrix\r\n * @param fov defines the horizontal field of view\r\n * @param aspect defines the aspect ratio\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @param result defines the target matrix\r\n * @param isVerticalFovFixed defines it the fov is vertically fixed (default) or horizontally\r\n */\r\n Matrix.PerspectiveFovRHToRef = function (fov, aspect, znear, zfar, result, isVerticalFovFixed) {\r\n //alternatively this could be expressed as:\r\n // m = PerspectiveFovLHToRef\r\n // m[10] *= -1.0;\r\n // m[11] *= -1.0;\r\n if (isVerticalFovFixed === void 0) { isVerticalFovFixed = true; }\r\n var n = znear;\r\n var f = zfar;\r\n var t = 1.0 / (Math.tan(fov * 0.5));\r\n var a = isVerticalFovFixed ? (t / aspect) : t;\r\n var b = isVerticalFovFixed ? t : (t * aspect);\r\n var c = -(f + n) / (f - n);\r\n var d = -2 * f * n / (f - n);\r\n Matrix.FromValuesToRef(a, 0.0, 0.0, 0.0, 0.0, b, 0.0, 0.0, 0.0, 0.0, c, -1.0, 0.0, 0.0, d, 0.0, result);\r\n result._updateIdentityStatus(false);\r\n };\r\n /**\r\n * Stores a right-handed perspective projection into a given matrix\r\n * @param fov defines the horizontal field of view\r\n * @param aspect defines the aspect ratio\r\n * @param znear defines the near clip plane\r\n * @param zfar not used as infinity is used as far clip\r\n * @param result defines the target matrix\r\n * @param isVerticalFovFixed defines it the fov is vertically fixed (default) or horizontally\r\n */\r\n Matrix.PerspectiveFovReverseRHToRef = function (fov, aspect, znear, zfar, result, isVerticalFovFixed) {\r\n //alternatively this could be expressed as:\r\n // m = PerspectiveFovLHToRef\r\n // m[10] *= -1.0;\r\n // m[11] *= -1.0;\r\n if (isVerticalFovFixed === void 0) { isVerticalFovFixed = true; }\r\n var t = 1.0 / (Math.tan(fov * 0.5));\r\n var a = isVerticalFovFixed ? (t / aspect) : t;\r\n var b = isVerticalFovFixed ? t : (t * aspect);\r\n Matrix.FromValuesToRef(a, 0.0, 0.0, 0.0, 0.0, b, 0.0, 0.0, 0.0, 0.0, -znear, -1.0, 0.0, 0.0, -1.0, 0.0, result);\r\n result._updateIdentityStatus(false);\r\n };\r\n /**\r\n * Stores a perspective projection for WebVR info a given matrix\r\n * @param fov defines the field of view\r\n * @param znear defines the near clip plane\r\n * @param zfar defines the far clip plane\r\n * @param result defines the target matrix\r\n * @param rightHanded defines if the matrix must be in right-handed mode (false by default)\r\n */\r\n Matrix.PerspectiveFovWebVRToRef = function (fov, znear, zfar, result, rightHanded) {\r\n if (rightHanded === void 0) { rightHanded = false; }\r\n var rightHandedFactor = rightHanded ? -1 : 1;\r\n var upTan = Math.tan(fov.upDegrees * Math.PI / 180.0);\r\n var downTan = Math.tan(fov.downDegrees * Math.PI / 180.0);\r\n var leftTan = Math.tan(fov.leftDegrees * Math.PI / 180.0);\r\n var rightTan = Math.tan(fov.rightDegrees * Math.PI / 180.0);\r\n var xScale = 2.0 / (leftTan + rightTan);\r\n var yScale = 2.0 / (upTan + downTan);\r\n var m = result._m;\r\n m[0] = xScale;\r\n m[1] = m[2] = m[3] = m[4] = 0.0;\r\n m[5] = yScale;\r\n m[6] = m[7] = 0.0;\r\n m[8] = ((leftTan - rightTan) * xScale * 0.5);\r\n m[9] = -((upTan - downTan) * yScale * 0.5);\r\n m[10] = -zfar / (znear - zfar);\r\n m[11] = 1.0 * rightHandedFactor;\r\n m[12] = m[13] = m[15] = 0.0;\r\n m[14] = -(2.0 * zfar * znear) / (zfar - znear);\r\n result._markAsUpdated();\r\n };\r\n /**\r\n * Computes a complete transformation matrix\r\n * @param viewport defines the viewport to use\r\n * @param world defines the world matrix\r\n * @param view defines the view matrix\r\n * @param projection defines the projection matrix\r\n * @param zmin defines the near clip plane\r\n * @param zmax defines the far clip plane\r\n * @returns the transformation matrix\r\n */\r\n Matrix.GetFinalMatrix = function (viewport, world, view, projection, zmin, zmax) {\r\n var cw = viewport.width;\r\n var ch = viewport.height;\r\n var cx = viewport.x;\r\n var cy = viewport.y;\r\n var viewportMatrix = Matrix.FromValues(cw / 2.0, 0.0, 0.0, 0.0, 0.0, -ch / 2.0, 0.0, 0.0, 0.0, 0.0, zmax - zmin, 0.0, cx + cw / 2.0, ch / 2.0 + cy, zmin, 1.0);\r\n var matrix = MathTmp.Matrix[0];\r\n world.multiplyToRef(view, matrix);\r\n matrix.multiplyToRef(projection, matrix);\r\n return matrix.multiply(viewportMatrix);\r\n };\r\n /**\r\n * Extracts a 2x2 matrix from a given matrix and store the result in a Float32Array\r\n * @param matrix defines the matrix to use\r\n * @returns a new Float32Array array with 4 elements : the 2x2 matrix extracted from the given matrix\r\n */\r\n Matrix.GetAsMatrix2x2 = function (matrix) {\r\n var m = matrix.m;\r\n var arr = [m[0], m[1], m[4], m[5]];\r\n return PerformanceConfigurator.MatrixUse64Bits ? arr : new Float32Array(arr);\r\n };\r\n /**\r\n * Extracts a 3x3 matrix from a given matrix and store the result in a Float32Array\r\n * @param matrix defines the matrix to use\r\n * @returns a new Float32Array array with 9 elements : the 3x3 matrix extracted from the given matrix\r\n */\r\n Matrix.GetAsMatrix3x3 = function (matrix) {\r\n var m = matrix.m;\r\n var arr = [\r\n m[0], m[1], m[2],\r\n m[4], m[5], m[6],\r\n m[8], m[9], m[10]\r\n ];\r\n return PerformanceConfigurator.MatrixUse64Bits ? arr : new Float32Array(arr);\r\n };\r\n /**\r\n * Compute the transpose of a given matrix\r\n * @param matrix defines the matrix to transpose\r\n * @returns the new matrix\r\n */\r\n Matrix.Transpose = function (matrix) {\r\n var result = new Matrix();\r\n Matrix.TransposeToRef(matrix, result);\r\n return result;\r\n };\r\n /**\r\n * Compute the transpose of a matrix and store it in a target matrix\r\n * @param matrix defines the matrix to transpose\r\n * @param result defines the target matrix\r\n */\r\n Matrix.TransposeToRef = function (matrix, result) {\r\n var rm = result._m;\r\n var mm = matrix.m;\r\n rm[0] = mm[0];\r\n rm[1] = mm[4];\r\n rm[2] = mm[8];\r\n rm[3] = mm[12];\r\n rm[4] = mm[1];\r\n rm[5] = mm[5];\r\n rm[6] = mm[9];\r\n rm[7] = mm[13];\r\n rm[8] = mm[2];\r\n rm[9] = mm[6];\r\n rm[10] = mm[10];\r\n rm[11] = mm[14];\r\n rm[12] = mm[3];\r\n rm[13] = mm[7];\r\n rm[14] = mm[11];\r\n rm[15] = mm[15];\r\n // identity-ness does not change when transposing\r\n result._updateIdentityStatus(matrix._isIdentity, matrix._isIdentityDirty);\r\n };\r\n /**\r\n * Computes a reflection matrix from a plane\r\n * @param plane defines the reflection plane\r\n * @returns a new matrix\r\n */\r\n Matrix.Reflection = function (plane) {\r\n var matrix = new Matrix();\r\n Matrix.ReflectionToRef(plane, matrix);\r\n return matrix;\r\n };\r\n /**\r\n * Computes a reflection matrix from a plane\r\n * @param plane defines the reflection plane\r\n * @param result defines the target matrix\r\n */\r\n Matrix.ReflectionToRef = function (plane, result) {\r\n plane.normalize();\r\n var x = plane.normal.x;\r\n var y = plane.normal.y;\r\n var z = plane.normal.z;\r\n var temp = -2 * x;\r\n var temp2 = -2 * y;\r\n var temp3 = -2 * z;\r\n Matrix.FromValuesToRef(temp * x + 1, temp2 * x, temp3 * x, 0.0, temp * y, temp2 * y + 1, temp3 * y, 0.0, temp * z, temp2 * z, temp3 * z + 1, 0.0, temp * plane.d, temp2 * plane.d, temp3 * plane.d, 1.0, result);\r\n };\r\n /**\r\n * Sets the given matrix as a rotation matrix composed from the 3 left handed axes\r\n * @param xaxis defines the value of the 1st axis\r\n * @param yaxis defines the value of the 2nd axis\r\n * @param zaxis defines the value of the 3rd axis\r\n * @param result defines the target matrix\r\n */\r\n Matrix.FromXYZAxesToRef = function (xaxis, yaxis, zaxis, result) {\r\n Matrix.FromValuesToRef(xaxis._x, xaxis._y, xaxis._z, 0.0, yaxis._x, yaxis._y, yaxis._z, 0.0, zaxis._x, zaxis._y, zaxis._z, 0.0, 0.0, 0.0, 0.0, 1.0, result);\r\n };\r\n /**\r\n * Creates a rotation matrix from a quaternion and stores it in a target matrix\r\n * @param quat defines the quaternion to use\r\n * @param result defines the target matrix\r\n */\r\n Matrix.FromQuaternionToRef = function (quat, result) {\r\n var xx = quat._x * quat._x;\r\n var yy = quat._y * quat._y;\r\n var zz = quat._z * quat._z;\r\n var xy = quat._x * quat._y;\r\n var zw = quat._z * quat._w;\r\n var zx = quat._z * quat._x;\r\n var yw = quat._y * quat._w;\r\n var yz = quat._y * quat._z;\r\n var xw = quat._x * quat._w;\r\n result._m[0] = 1.0 - (2.0 * (yy + zz));\r\n result._m[1] = 2.0 * (xy + zw);\r\n result._m[2] = 2.0 * (zx - yw);\r\n result._m[3] = 0.0;\r\n result._m[4] = 2.0 * (xy - zw);\r\n result._m[5] = 1.0 - (2.0 * (zz + xx));\r\n result._m[6] = 2.0 * (yz + xw);\r\n result._m[7] = 0.0;\r\n result._m[8] = 2.0 * (zx + yw);\r\n result._m[9] = 2.0 * (yz - xw);\r\n result._m[10] = 1.0 - (2.0 * (yy + xx));\r\n result._m[11] = 0.0;\r\n result._m[12] = 0.0;\r\n result._m[13] = 0.0;\r\n result._m[14] = 0.0;\r\n result._m[15] = 1.0;\r\n result._markAsUpdated();\r\n };\r\n Matrix._updateFlagSeed = 0;\r\n Matrix._identityReadOnly = Matrix.Identity();\r\n return Matrix;\r\n}());\r\nexport { Matrix };\r\n/**\r\n * @hidden\r\n * Same as Tmp but not exported to keep it only for math functions to avoid conflicts\r\n */\r\nvar MathTmp = /** @class */ (function () {\r\n function MathTmp() {\r\n }\r\n MathTmp.Vector3 = ArrayTools.BuildArray(6, Vector3.Zero);\r\n MathTmp.Matrix = ArrayTools.BuildArray(2, Matrix.Identity);\r\n MathTmp.Quaternion = ArrayTools.BuildArray(3, Quaternion.Zero);\r\n return MathTmp;\r\n}());\r\n/**\r\n * @hidden\r\n */\r\nvar TmpVectors = /** @class */ (function () {\r\n function TmpVectors() {\r\n }\r\n TmpVectors.Vector2 = ArrayTools.BuildArray(3, Vector2.Zero); // 3 temp Vector2 at once should be enough\r\n TmpVectors.Vector3 = ArrayTools.BuildArray(13, Vector3.Zero); // 13 temp Vector3 at once should be enough\r\n TmpVectors.Vector4 = ArrayTools.BuildArray(3, Vector4.Zero); // 3 temp Vector4 at once should be enough\r\n TmpVectors.Quaternion = ArrayTools.BuildArray(2, Quaternion.Zero); // 2 temp Quaternion at once should be enough\r\n TmpVectors.Matrix = ArrayTools.BuildArray(8, Matrix.Identity); // 8 temp Matrices at once should be enough\r\n return TmpVectors;\r\n}());\r\nexport { TmpVectors };\r\n_TypeStore.RegisteredTypes[\"BABYLON.Vector2\"] = Vector2;\r\n_TypeStore.RegisteredTypes[\"BABYLON.Vector3\"] = Vector3;\r\n_TypeStore.RegisteredTypes[\"BABYLON.Vector4\"] = Vector4;\r\n_TypeStore.RegisteredTypes[\"BABYLON.Matrix\"] = Matrix;\r\n//# sourceMappingURL=math.vector.js.map","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, privateMap) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to get private field on non-instance\");\r\n }\r\n return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to set private field on non-instance\");\r\n }\r\n privateMap.set(receiver, value);\r\n return value;\r\n}\r\n","/**\r\n * Class used to store data that will be store in GPU memory\r\n */\r\nvar Buffer = /** @class */ (function () {\r\n /**\r\n * Constructor\r\n * @param engine the engine\r\n * @param data the data to use for this buffer\r\n * @param updatable whether the data is updatable\r\n * @param stride the stride (optional)\r\n * @param postponeInternalCreation whether to postpone creating the internal WebGL buffer (optional)\r\n * @param instanced whether the buffer is instanced (optional)\r\n * @param useBytes set to true if the stride in in bytes (optional)\r\n * @param divisor sets an optional divisor for instances (1 by default)\r\n */\r\n function Buffer(engine, data, updatable, stride, postponeInternalCreation, instanced, useBytes, divisor) {\r\n if (stride === void 0) { stride = 0; }\r\n if (postponeInternalCreation === void 0) { postponeInternalCreation = false; }\r\n if (instanced === void 0) { instanced = false; }\r\n if (useBytes === void 0) { useBytes = false; }\r\n this._isAlreadyOwned = false;\r\n if (engine.getScene) { // old versions of VertexBuffer accepted 'mesh' instead of 'engine'\r\n this._engine = engine.getScene().getEngine();\r\n }\r\n else {\r\n this._engine = engine;\r\n }\r\n this._updatable = updatable;\r\n this._instanced = instanced;\r\n this._divisor = divisor || 1;\r\n this._data = data;\r\n this.byteStride = useBytes ? stride : stride * Float32Array.BYTES_PER_ELEMENT;\r\n if (!postponeInternalCreation) { // by default\r\n this.create();\r\n }\r\n }\r\n /**\r\n * Create a new VertexBuffer based on the current buffer\r\n * @param kind defines the vertex buffer kind (position, normal, etc.)\r\n * @param offset defines offset in the buffer (0 by default)\r\n * @param size defines the size in floats of attributes (position is 3 for instance)\r\n * @param stride defines the stride size in floats in the buffer (the offset to apply to reach next value when data is interleaved)\r\n * @param instanced defines if the vertex buffer contains indexed data\r\n * @param useBytes defines if the offset and stride are in bytes *\r\n * @param divisor sets an optional divisor for instances (1 by default)\r\n * @returns the new vertex buffer\r\n */\r\n Buffer.prototype.createVertexBuffer = function (kind, offset, size, stride, instanced, useBytes, divisor) {\r\n if (useBytes === void 0) { useBytes = false; }\r\n var byteOffset = useBytes ? offset : offset * Float32Array.BYTES_PER_ELEMENT;\r\n var byteStride = stride ? (useBytes ? stride : stride * Float32Array.BYTES_PER_ELEMENT) : this.byteStride;\r\n // a lot of these parameters are ignored as they are overriden by the buffer\r\n return new VertexBuffer(this._engine, this, kind, this._updatable, true, byteStride, instanced === undefined ? this._instanced : instanced, byteOffset, size, undefined, undefined, true, this._divisor || divisor);\r\n };\r\n // Properties\r\n /**\r\n * Gets a boolean indicating if the Buffer is updatable?\r\n * @returns true if the buffer is updatable\r\n */\r\n Buffer.prototype.isUpdatable = function () {\r\n return this._updatable;\r\n };\r\n /**\r\n * Gets current buffer's data\r\n * @returns a DataArray or null\r\n */\r\n Buffer.prototype.getData = function () {\r\n return this._data;\r\n };\r\n /**\r\n * Gets underlying native buffer\r\n * @returns underlying native buffer\r\n */\r\n Buffer.prototype.getBuffer = function () {\r\n return this._buffer;\r\n };\r\n /**\r\n * Gets the stride in float32 units (i.e. byte stride / 4).\r\n * May not be an integer if the byte stride is not divisible by 4.\r\n * @returns the stride in float32 units\r\n * @deprecated Please use byteStride instead.\r\n */\r\n Buffer.prototype.getStrideSize = function () {\r\n return this.byteStride / Float32Array.BYTES_PER_ELEMENT;\r\n };\r\n // Methods\r\n /**\r\n * Store data into the buffer. If the buffer was already used it will be either recreated or updated depending on isUpdatable property\r\n * @param data defines the data to store\r\n */\r\n Buffer.prototype.create = function (data) {\r\n if (data === void 0) { data = null; }\r\n if (!data && this._buffer) {\r\n return; // nothing to do\r\n }\r\n data = data || this._data;\r\n if (!data) {\r\n return;\r\n }\r\n if (!this._buffer) { // create buffer\r\n if (this._updatable) {\r\n this._buffer = this._engine.createDynamicVertexBuffer(data);\r\n this._data = data;\r\n }\r\n else {\r\n this._buffer = this._engine.createVertexBuffer(data);\r\n }\r\n }\r\n else if (this._updatable) { // update buffer\r\n this._engine.updateDynamicVertexBuffer(this._buffer, data);\r\n this._data = data;\r\n }\r\n };\r\n /** @hidden */\r\n Buffer.prototype._rebuild = function () {\r\n this._buffer = null;\r\n this.create(this._data);\r\n };\r\n /**\r\n * Update current buffer data\r\n * @param data defines the data to store\r\n */\r\n Buffer.prototype.update = function (data) {\r\n this.create(data);\r\n };\r\n /**\r\n * Updates the data directly.\r\n * @param data the new data\r\n * @param offset the new offset\r\n * @param vertexCount the vertex count (optional)\r\n * @param useBytes set to true if the offset is in bytes\r\n */\r\n Buffer.prototype.updateDirectly = function (data, offset, vertexCount, useBytes) {\r\n if (useBytes === void 0) { useBytes = false; }\r\n if (!this._buffer) {\r\n return;\r\n }\r\n if (this._updatable) { // update buffer\r\n this._engine.updateDynamicVertexBuffer(this._buffer, data, useBytes ? offset : offset * Float32Array.BYTES_PER_ELEMENT, (vertexCount ? vertexCount * this.byteStride : undefined));\r\n this._data = null;\r\n }\r\n };\r\n /** @hidden */\r\n Buffer.prototype._increaseReferences = function () {\r\n if (!this._buffer) {\r\n return;\r\n }\r\n if (!this._isAlreadyOwned) {\r\n this._isAlreadyOwned = true;\r\n return;\r\n }\r\n this._buffer.references++;\r\n };\r\n /**\r\n * Release all resources\r\n */\r\n Buffer.prototype.dispose = function () {\r\n if (!this._buffer) {\r\n return;\r\n }\r\n if (this._engine._releaseBuffer(this._buffer)) {\r\n this._buffer = null;\r\n }\r\n };\r\n return Buffer;\r\n}());\r\nexport { Buffer };\r\n/**\r\n * Specialized buffer used to store vertex data\r\n */\r\nvar VertexBuffer = /** @class */ (function () {\r\n /**\r\n * Constructor\r\n * @param engine the engine\r\n * @param data the data to use for this vertex buffer\r\n * @param kind the vertex buffer kind\r\n * @param updatable whether the data is updatable\r\n * @param postponeInternalCreation whether to postpone creating the internal WebGL buffer (optional)\r\n * @param stride the stride (optional)\r\n * @param instanced whether the buffer is instanced (optional)\r\n * @param offset the offset of the data (optional)\r\n * @param size the number of components (optional)\r\n * @param type the type of the component (optional)\r\n * @param normalized whether the data contains normalized data (optional)\r\n * @param useBytes set to true if stride and offset are in bytes (optional)\r\n * @param divisor defines the instance divisor to use (1 by default)\r\n * @param takeBufferOwnership defines if the buffer should be released when the vertex buffer is disposed\r\n */\r\n function VertexBuffer(engine, data, kind, updatable, postponeInternalCreation, stride, instanced, offset, size, type, normalized, useBytes, divisor, takeBufferOwnership) {\r\n if (normalized === void 0) { normalized = false; }\r\n if (useBytes === void 0) { useBytes = false; }\r\n if (divisor === void 0) { divisor = 1; }\r\n if (takeBufferOwnership === void 0) { takeBufferOwnership = false; }\r\n if (data instanceof Buffer) {\r\n this._buffer = data;\r\n this._ownsBuffer = takeBufferOwnership;\r\n if (takeBufferOwnership) {\r\n this._buffer._increaseReferences();\r\n }\r\n }\r\n else {\r\n this._buffer = new Buffer(engine, data, updatable, stride, postponeInternalCreation, instanced, useBytes);\r\n this._ownsBuffer = true;\r\n }\r\n this._kind = kind;\r\n if (type == undefined) {\r\n var data_1 = this.getData();\r\n this.type = VertexBuffer.FLOAT;\r\n if (data_1 instanceof Int8Array) {\r\n this.type = VertexBuffer.BYTE;\r\n }\r\n else if (data_1 instanceof Uint8Array) {\r\n this.type = VertexBuffer.UNSIGNED_BYTE;\r\n }\r\n else if (data_1 instanceof Int16Array) {\r\n this.type = VertexBuffer.SHORT;\r\n }\r\n else if (data_1 instanceof Uint16Array) {\r\n this.type = VertexBuffer.UNSIGNED_SHORT;\r\n }\r\n else if (data_1 instanceof Int32Array) {\r\n this.type = VertexBuffer.INT;\r\n }\r\n else if (data_1 instanceof Uint32Array) {\r\n this.type = VertexBuffer.UNSIGNED_INT;\r\n }\r\n }\r\n else {\r\n this.type = type;\r\n }\r\n var typeByteLength = VertexBuffer.GetTypeByteLength(this.type);\r\n if (useBytes) {\r\n this._size = size || (stride ? (stride / typeByteLength) : VertexBuffer.DeduceStride(kind));\r\n this.byteStride = stride || this._buffer.byteStride || (this._size * typeByteLength);\r\n this.byteOffset = offset || 0;\r\n }\r\n else {\r\n this._size = size || stride || VertexBuffer.DeduceStride(kind);\r\n this.byteStride = stride ? (stride * typeByteLength) : (this._buffer.byteStride || (this._size * typeByteLength));\r\n this.byteOffset = (offset || 0) * typeByteLength;\r\n }\r\n this.normalized = normalized;\r\n this._instanced = instanced !== undefined ? instanced : false;\r\n this._instanceDivisor = instanced ? divisor : 0;\r\n }\r\n Object.defineProperty(VertexBuffer.prototype, \"instanceDivisor\", {\r\n /**\r\n * Gets or sets the instance divisor when in instanced mode\r\n */\r\n get: function () {\r\n return this._instanceDivisor;\r\n },\r\n set: function (value) {\r\n this._instanceDivisor = value;\r\n if (value == 0) {\r\n this._instanced = false;\r\n }\r\n else {\r\n this._instanced = true;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n VertexBuffer.prototype._rebuild = function () {\r\n if (!this._buffer) {\r\n return;\r\n }\r\n this._buffer._rebuild();\r\n };\r\n /**\r\n * Returns the kind of the VertexBuffer (string)\r\n * @returns a string\r\n */\r\n VertexBuffer.prototype.getKind = function () {\r\n return this._kind;\r\n };\r\n // Properties\r\n /**\r\n * Gets a boolean indicating if the VertexBuffer is updatable?\r\n * @returns true if the buffer is updatable\r\n */\r\n VertexBuffer.prototype.isUpdatable = function () {\r\n return this._buffer.isUpdatable();\r\n };\r\n /**\r\n * Gets current buffer's data\r\n * @returns a DataArray or null\r\n */\r\n VertexBuffer.prototype.getData = function () {\r\n return this._buffer.getData();\r\n };\r\n /**\r\n * Gets underlying native buffer\r\n * @returns underlying native buffer\r\n */\r\n VertexBuffer.prototype.getBuffer = function () {\r\n return this._buffer.getBuffer();\r\n };\r\n /**\r\n * Gets the stride in float32 units (i.e. byte stride / 4).\r\n * May not be an integer if the byte stride is not divisible by 4.\r\n * @returns the stride in float32 units\r\n * @deprecated Please use byteStride instead.\r\n */\r\n VertexBuffer.prototype.getStrideSize = function () {\r\n return this.byteStride / VertexBuffer.GetTypeByteLength(this.type);\r\n };\r\n /**\r\n * Returns the offset as a multiple of the type byte length.\r\n * @returns the offset in bytes\r\n * @deprecated Please use byteOffset instead.\r\n */\r\n VertexBuffer.prototype.getOffset = function () {\r\n return this.byteOffset / VertexBuffer.GetTypeByteLength(this.type);\r\n };\r\n /**\r\n * Returns the number of components per vertex attribute (integer)\r\n * @returns the size in float\r\n */\r\n VertexBuffer.prototype.getSize = function () {\r\n return this._size;\r\n };\r\n /**\r\n * Gets a boolean indicating is the internal buffer of the VertexBuffer is instanced\r\n * @returns true if this buffer is instanced\r\n */\r\n VertexBuffer.prototype.getIsInstanced = function () {\r\n return this._instanced;\r\n };\r\n /**\r\n * Returns the instancing divisor, zero for non-instanced (integer).\r\n * @returns a number\r\n */\r\n VertexBuffer.prototype.getInstanceDivisor = function () {\r\n return this._instanceDivisor;\r\n };\r\n // Methods\r\n /**\r\n * Store data into the buffer. If the buffer was already used it will be either recreated or updated depending on isUpdatable property\r\n * @param data defines the data to store\r\n */\r\n VertexBuffer.prototype.create = function (data) {\r\n this._buffer.create(data);\r\n };\r\n /**\r\n * Updates the underlying buffer according to the passed numeric array or Float32Array.\r\n * This function will create a new buffer if the current one is not updatable\r\n * @param data defines the data to store\r\n */\r\n VertexBuffer.prototype.update = function (data) {\r\n this._buffer.update(data);\r\n };\r\n /**\r\n * Updates directly the underlying WebGLBuffer according to the passed numeric array or Float32Array.\r\n * Returns the directly updated WebGLBuffer.\r\n * @param data the new data\r\n * @param offset the new offset\r\n * @param useBytes set to true if the offset is in bytes\r\n */\r\n VertexBuffer.prototype.updateDirectly = function (data, offset, useBytes) {\r\n if (useBytes === void 0) { useBytes = false; }\r\n this._buffer.updateDirectly(data, offset, undefined, useBytes);\r\n };\r\n /**\r\n * Disposes the VertexBuffer and the underlying WebGLBuffer.\r\n */\r\n VertexBuffer.prototype.dispose = function () {\r\n if (this._ownsBuffer) {\r\n this._buffer.dispose();\r\n }\r\n };\r\n /**\r\n * Enumerates each value of this vertex buffer as numbers.\r\n * @param count the number of values to enumerate\r\n * @param callback the callback function called for each value\r\n */\r\n VertexBuffer.prototype.forEach = function (count, callback) {\r\n VertexBuffer.ForEach(this._buffer.getData(), this.byteOffset, this.byteStride, this._size, this.type, count, this.normalized, callback);\r\n };\r\n /**\r\n * Deduces the stride given a kind.\r\n * @param kind The kind string to deduce\r\n * @returns The deduced stride\r\n */\r\n VertexBuffer.DeduceStride = function (kind) {\r\n switch (kind) {\r\n case VertexBuffer.UVKind:\r\n case VertexBuffer.UV2Kind:\r\n case VertexBuffer.UV3Kind:\r\n case VertexBuffer.UV4Kind:\r\n case VertexBuffer.UV5Kind:\r\n case VertexBuffer.UV6Kind:\r\n return 2;\r\n case VertexBuffer.NormalKind:\r\n case VertexBuffer.PositionKind:\r\n return 3;\r\n case VertexBuffer.ColorKind:\r\n case VertexBuffer.MatricesIndicesKind:\r\n case VertexBuffer.MatricesIndicesExtraKind:\r\n case VertexBuffer.MatricesWeightsKind:\r\n case VertexBuffer.MatricesWeightsExtraKind:\r\n case VertexBuffer.TangentKind:\r\n return 4;\r\n default:\r\n throw new Error(\"Invalid kind '\" + kind + \"'\");\r\n }\r\n };\r\n /**\r\n * Gets the byte length of the given type.\r\n * @param type the type\r\n * @returns the number of bytes\r\n */\r\n VertexBuffer.GetTypeByteLength = function (type) {\r\n switch (type) {\r\n case VertexBuffer.BYTE:\r\n case VertexBuffer.UNSIGNED_BYTE:\r\n return 1;\r\n case VertexBuffer.SHORT:\r\n case VertexBuffer.UNSIGNED_SHORT:\r\n return 2;\r\n case VertexBuffer.INT:\r\n case VertexBuffer.UNSIGNED_INT:\r\n case VertexBuffer.FLOAT:\r\n return 4;\r\n default:\r\n throw new Error(\"Invalid type '\" + type + \"'\");\r\n }\r\n };\r\n /**\r\n * Enumerates each value of the given parameters as numbers.\r\n * @param data the data to enumerate\r\n * @param byteOffset the byte offset of the data\r\n * @param byteStride the byte stride of the data\r\n * @param componentCount the number of components per element\r\n * @param componentType the type of the component\r\n * @param count the number of values to enumerate\r\n * @param normalized whether the data is normalized\r\n * @param callback the callback function called for each value\r\n */\r\n VertexBuffer.ForEach = function (data, byteOffset, byteStride, componentCount, componentType, count, normalized, callback) {\r\n if (data instanceof Array) {\r\n var offset = byteOffset / 4;\r\n var stride = byteStride / 4;\r\n for (var index = 0; index < count; index += componentCount) {\r\n for (var componentIndex = 0; componentIndex < componentCount; componentIndex++) {\r\n callback(data[offset + componentIndex], index + componentIndex);\r\n }\r\n offset += stride;\r\n }\r\n }\r\n else {\r\n var dataView = data instanceof ArrayBuffer ? new DataView(data) : new DataView(data.buffer, data.byteOffset, data.byteLength);\r\n var componentByteLength = VertexBuffer.GetTypeByteLength(componentType);\r\n for (var index = 0; index < count; index += componentCount) {\r\n var componentByteOffset = byteOffset;\r\n for (var componentIndex = 0; componentIndex < componentCount; componentIndex++) {\r\n var value = VertexBuffer._GetFloatValue(dataView, componentType, componentByteOffset, normalized);\r\n callback(value, index + componentIndex);\r\n componentByteOffset += componentByteLength;\r\n }\r\n byteOffset += byteStride;\r\n }\r\n }\r\n };\r\n VertexBuffer._GetFloatValue = function (dataView, type, byteOffset, normalized) {\r\n switch (type) {\r\n case VertexBuffer.BYTE: {\r\n var value = dataView.getInt8(byteOffset);\r\n if (normalized) {\r\n value = Math.max(value / 127, -1);\r\n }\r\n return value;\r\n }\r\n case VertexBuffer.UNSIGNED_BYTE: {\r\n var value = dataView.getUint8(byteOffset);\r\n if (normalized) {\r\n value = value / 255;\r\n }\r\n return value;\r\n }\r\n case VertexBuffer.SHORT: {\r\n var value = dataView.getInt16(byteOffset, true);\r\n if (normalized) {\r\n value = Math.max(value / 32767, -1);\r\n }\r\n return value;\r\n }\r\n case VertexBuffer.UNSIGNED_SHORT: {\r\n var value = dataView.getUint16(byteOffset, true);\r\n if (normalized) {\r\n value = value / 65535;\r\n }\r\n return value;\r\n }\r\n case VertexBuffer.INT: {\r\n return dataView.getInt32(byteOffset, true);\r\n }\r\n case VertexBuffer.UNSIGNED_INT: {\r\n return dataView.getUint32(byteOffset, true);\r\n }\r\n case VertexBuffer.FLOAT: {\r\n return dataView.getFloat32(byteOffset, true);\r\n }\r\n default: {\r\n throw new Error(\"Invalid component type \" + type);\r\n }\r\n }\r\n };\r\n /**\r\n * The byte type.\r\n */\r\n VertexBuffer.BYTE = 5120;\r\n /**\r\n * The unsigned byte type.\r\n */\r\n VertexBuffer.UNSIGNED_BYTE = 5121;\r\n /**\r\n * The short type.\r\n */\r\n VertexBuffer.SHORT = 5122;\r\n /**\r\n * The unsigned short type.\r\n */\r\n VertexBuffer.UNSIGNED_SHORT = 5123;\r\n /**\r\n * The integer type.\r\n */\r\n VertexBuffer.INT = 5124;\r\n /**\r\n * The unsigned integer type.\r\n */\r\n VertexBuffer.UNSIGNED_INT = 5125;\r\n /**\r\n * The float type.\r\n */\r\n VertexBuffer.FLOAT = 5126;\r\n // Enums\r\n /**\r\n * Positions\r\n */\r\n VertexBuffer.PositionKind = \"position\";\r\n /**\r\n * Normals\r\n */\r\n VertexBuffer.NormalKind = \"normal\";\r\n /**\r\n * Tangents\r\n */\r\n VertexBuffer.TangentKind = \"tangent\";\r\n /**\r\n * Texture coordinates\r\n */\r\n VertexBuffer.UVKind = \"uv\";\r\n /**\r\n * Texture coordinates 2\r\n */\r\n VertexBuffer.UV2Kind = \"uv2\";\r\n /**\r\n * Texture coordinates 3\r\n */\r\n VertexBuffer.UV3Kind = \"uv3\";\r\n /**\r\n * Texture coordinates 4\r\n */\r\n VertexBuffer.UV4Kind = \"uv4\";\r\n /**\r\n * Texture coordinates 5\r\n */\r\n VertexBuffer.UV5Kind = \"uv5\";\r\n /**\r\n * Texture coordinates 6\r\n */\r\n VertexBuffer.UV6Kind = \"uv6\";\r\n /**\r\n * Colors\r\n */\r\n VertexBuffer.ColorKind = \"color\";\r\n /**\r\n * Matrix indices (for bones)\r\n */\r\n VertexBuffer.MatricesIndicesKind = \"matricesIndices\";\r\n /**\r\n * Matrix weights (for bones)\r\n */\r\n VertexBuffer.MatricesWeightsKind = \"matricesWeights\";\r\n /**\r\n * Additional matrix indices (for bones)\r\n */\r\n VertexBuffer.MatricesIndicesExtraKind = \"matricesIndicesExtra\";\r\n /**\r\n * Additional matrix weights (for bones)\r\n */\r\n VertexBuffer.MatricesWeightsExtraKind = \"matricesWeightsExtra\";\r\n return VertexBuffer;\r\n}());\r\nexport { VertexBuffer };\r\n//# sourceMappingURL=buffer.js.map","import { Tags } from \"../Misc/tags\";\r\nimport { Quaternion, Vector2, Vector3, Matrix } from \"../Maths/math.vector\";\r\nimport { _DevTools } from './devTools';\r\nimport { Color4, Color3 } from '../Maths/math.color';\r\nvar __decoratorInitialStore = {};\r\nvar __mergedStore = {};\r\nvar _copySource = function (creationFunction, source, instanciate) {\r\n var destination = creationFunction();\r\n // Tags\r\n if (Tags) {\r\n Tags.AddTagsTo(destination, source.tags);\r\n }\r\n var classStore = getMergedStore(destination);\r\n // Properties\r\n for (var property in classStore) {\r\n var propertyDescriptor = classStore[property];\r\n var sourceProperty = source[property];\r\n var propertyType = propertyDescriptor.type;\r\n if (sourceProperty !== undefined && sourceProperty !== null && property !== \"uniqueId\") {\r\n switch (propertyType) {\r\n case 0: // Value\r\n case 6: // Mesh reference\r\n case 11: // Camera reference\r\n destination[property] = sourceProperty;\r\n break;\r\n case 1: // Texture\r\n destination[property] = (instanciate || sourceProperty.isRenderTarget) ? sourceProperty : sourceProperty.clone();\r\n break;\r\n case 2: // Color3\r\n case 3: // FresnelParameters\r\n case 4: // Vector2\r\n case 5: // Vector3\r\n case 7: // Color Curves\r\n case 10: // Quaternion\r\n case 12: // Matrix\r\n destination[property] = instanciate ? sourceProperty : sourceProperty.clone();\r\n break;\r\n }\r\n }\r\n }\r\n return destination;\r\n};\r\nfunction getDirectStore(target) {\r\n var classKey = target.getClassName();\r\n if (!__decoratorInitialStore[classKey]) {\r\n __decoratorInitialStore[classKey] = {};\r\n }\r\n return __decoratorInitialStore[classKey];\r\n}\r\n/**\r\n * Return the list of properties flagged as serializable\r\n * @param target: host object\r\n */\r\nfunction getMergedStore(target) {\r\n var classKey = target.getClassName();\r\n if (__mergedStore[classKey]) {\r\n return __mergedStore[classKey];\r\n }\r\n __mergedStore[classKey] = {};\r\n var store = __mergedStore[classKey];\r\n var currentTarget = target;\r\n var currentKey = classKey;\r\n while (currentKey) {\r\n var initialStore = __decoratorInitialStore[currentKey];\r\n for (var property in initialStore) {\r\n store[property] = initialStore[property];\r\n }\r\n var parent_1 = void 0;\r\n var done = false;\r\n do {\r\n parent_1 = Object.getPrototypeOf(currentTarget);\r\n if (!parent_1.getClassName) {\r\n done = true;\r\n break;\r\n }\r\n if (parent_1.getClassName() !== currentKey) {\r\n break;\r\n }\r\n currentTarget = parent_1;\r\n } while (parent_1);\r\n if (done) {\r\n break;\r\n }\r\n currentKey = parent_1.getClassName();\r\n currentTarget = parent_1;\r\n }\r\n return store;\r\n}\r\nfunction generateSerializableMember(type, sourceName) {\r\n return function (target, propertyKey) {\r\n var classStore = getDirectStore(target);\r\n if (!classStore[propertyKey]) {\r\n classStore[propertyKey] = { type: type, sourceName: sourceName };\r\n }\r\n };\r\n}\r\nfunction generateExpandMember(setCallback, targetKey) {\r\n if (targetKey === void 0) { targetKey = null; }\r\n return function (target, propertyKey) {\r\n var key = targetKey || (\"_\" + propertyKey);\r\n Object.defineProperty(target, propertyKey, {\r\n get: function () {\r\n return this[key];\r\n },\r\n set: function (value) {\r\n if (this[key] === value) {\r\n return;\r\n }\r\n this[key] = value;\r\n target[setCallback].apply(this);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n };\r\n}\r\nexport function expandToProperty(callback, targetKey) {\r\n if (targetKey === void 0) { targetKey = null; }\r\n return generateExpandMember(callback, targetKey);\r\n}\r\nexport function serialize(sourceName) {\r\n return generateSerializableMember(0, sourceName); // value member\r\n}\r\nexport function serializeAsTexture(sourceName) {\r\n return generateSerializableMember(1, sourceName); // texture member\r\n}\r\nexport function serializeAsColor3(sourceName) {\r\n return generateSerializableMember(2, sourceName); // color3 member\r\n}\r\nexport function serializeAsFresnelParameters(sourceName) {\r\n return generateSerializableMember(3, sourceName); // fresnel parameters member\r\n}\r\nexport function serializeAsVector2(sourceName) {\r\n return generateSerializableMember(4, sourceName); // vector2 member\r\n}\r\nexport function serializeAsVector3(sourceName) {\r\n return generateSerializableMember(5, sourceName); // vector3 member\r\n}\r\nexport function serializeAsMeshReference(sourceName) {\r\n return generateSerializableMember(6, sourceName); // mesh reference member\r\n}\r\nexport function serializeAsColorCurves(sourceName) {\r\n return generateSerializableMember(7, sourceName); // color curves\r\n}\r\nexport function serializeAsColor4(sourceName) {\r\n return generateSerializableMember(8, sourceName); // color 4\r\n}\r\nexport function serializeAsImageProcessingConfiguration(sourceName) {\r\n return generateSerializableMember(9, sourceName); // image processing\r\n}\r\nexport function serializeAsQuaternion(sourceName) {\r\n return generateSerializableMember(10, sourceName); // quaternion member\r\n}\r\nexport function serializeAsMatrix(sourceName) {\r\n return generateSerializableMember(12, sourceName); // matrix member\r\n}\r\n/**\r\n * Decorator used to define property that can be serialized as reference to a camera\r\n * @param sourceName defines the name of the property to decorate\r\n */\r\nexport function serializeAsCameraReference(sourceName) {\r\n return generateSerializableMember(11, sourceName); // camera reference member\r\n}\r\n/**\r\n * Class used to help serialization objects\r\n */\r\nvar SerializationHelper = /** @class */ (function () {\r\n function SerializationHelper() {\r\n }\r\n /**\r\n * Appends the serialized animations from the source animations\r\n * @param source Source containing the animations\r\n * @param destination Target to store the animations\r\n */\r\n SerializationHelper.AppendSerializedAnimations = function (source, destination) {\r\n if (source.animations) {\r\n destination.animations = [];\r\n for (var animationIndex = 0; animationIndex < source.animations.length; animationIndex++) {\r\n var animation = source.animations[animationIndex];\r\n destination.animations.push(animation.serialize());\r\n }\r\n }\r\n };\r\n /**\r\n * Static function used to serialized a specific entity\r\n * @param entity defines the entity to serialize\r\n * @param serializationObject defines the optional target obecjt where serialization data will be stored\r\n * @returns a JSON compatible object representing the serialization of the entity\r\n */\r\n SerializationHelper.Serialize = function (entity, serializationObject) {\r\n if (!serializationObject) {\r\n serializationObject = {};\r\n }\r\n // Tags\r\n if (Tags) {\r\n serializationObject.tags = Tags.GetTags(entity);\r\n }\r\n var serializedProperties = getMergedStore(entity);\r\n // Properties\r\n for (var property in serializedProperties) {\r\n var propertyDescriptor = serializedProperties[property];\r\n var targetPropertyName = propertyDescriptor.sourceName || property;\r\n var propertyType = propertyDescriptor.type;\r\n var sourceProperty = entity[property];\r\n if (sourceProperty !== undefined && sourceProperty !== null && property !== \"uniqueId\") {\r\n switch (propertyType) {\r\n case 0: // Value\r\n serializationObject[targetPropertyName] = sourceProperty;\r\n break;\r\n case 1: // Texture\r\n serializationObject[targetPropertyName] = sourceProperty.serialize();\r\n break;\r\n case 2: // Color3\r\n serializationObject[targetPropertyName] = sourceProperty.asArray();\r\n break;\r\n case 3: // FresnelParameters\r\n serializationObject[targetPropertyName] = sourceProperty.serialize();\r\n break;\r\n case 4: // Vector2\r\n serializationObject[targetPropertyName] = sourceProperty.asArray();\r\n break;\r\n case 5: // Vector3\r\n serializationObject[targetPropertyName] = sourceProperty.asArray();\r\n break;\r\n case 6: // Mesh reference\r\n serializationObject[targetPropertyName] = sourceProperty.id;\r\n break;\r\n case 7: // Color Curves\r\n serializationObject[targetPropertyName] = sourceProperty.serialize();\r\n break;\r\n case 8: // Color 4\r\n serializationObject[targetPropertyName] = sourceProperty.asArray();\r\n break;\r\n case 9: // Image Processing\r\n serializationObject[targetPropertyName] = sourceProperty.serialize();\r\n break;\r\n case 10: // Quaternion\r\n serializationObject[targetPropertyName] = sourceProperty.asArray();\r\n break;\r\n case 11: // Camera reference\r\n serializationObject[targetPropertyName] = sourceProperty.id;\r\n case 12: // Matrix\r\n serializationObject[targetPropertyName] = sourceProperty.asArray();\r\n break;\r\n }\r\n }\r\n }\r\n return serializationObject;\r\n };\r\n /**\r\n * Creates a new entity from a serialization data object\r\n * @param creationFunction defines a function used to instanciated the new entity\r\n * @param source defines the source serialization data\r\n * @param scene defines the hosting scene\r\n * @param rootUrl defines the root url for resources\r\n * @returns a new entity\r\n */\r\n SerializationHelper.Parse = function (creationFunction, source, scene, rootUrl) {\r\n if (rootUrl === void 0) { rootUrl = null; }\r\n var destination = creationFunction();\r\n if (!rootUrl) {\r\n rootUrl = \"\";\r\n }\r\n // Tags\r\n if (Tags) {\r\n Tags.AddTagsTo(destination, source.tags);\r\n }\r\n var classStore = getMergedStore(destination);\r\n // Properties\r\n for (var property in classStore) {\r\n var propertyDescriptor = classStore[property];\r\n var sourceProperty = source[propertyDescriptor.sourceName || property];\r\n var propertyType = propertyDescriptor.type;\r\n if (sourceProperty !== undefined && sourceProperty !== null && property !== \"uniqueId\") {\r\n var dest = destination;\r\n switch (propertyType) {\r\n case 0: // Value\r\n dest[property] = sourceProperty;\r\n break;\r\n case 1: // Texture\r\n if (scene) {\r\n dest[property] = SerializationHelper._TextureParser(sourceProperty, scene, rootUrl);\r\n }\r\n break;\r\n case 2: // Color3\r\n dest[property] = Color3.FromArray(sourceProperty);\r\n break;\r\n case 3: // FresnelParameters\r\n dest[property] = SerializationHelper._FresnelParametersParser(sourceProperty);\r\n break;\r\n case 4: // Vector2\r\n dest[property] = Vector2.FromArray(sourceProperty);\r\n break;\r\n case 5: // Vector3\r\n dest[property] = Vector3.FromArray(sourceProperty);\r\n break;\r\n case 6: // Mesh reference\r\n if (scene) {\r\n dest[property] = scene.getLastMeshByID(sourceProperty);\r\n }\r\n break;\r\n case 7: // Color Curves\r\n dest[property] = SerializationHelper._ColorCurvesParser(sourceProperty);\r\n break;\r\n case 8: // Color 4\r\n dest[property] = Color4.FromArray(sourceProperty);\r\n break;\r\n case 9: // Image Processing\r\n dest[property] = SerializationHelper._ImageProcessingConfigurationParser(sourceProperty);\r\n break;\r\n case 10: // Quaternion\r\n dest[property] = Quaternion.FromArray(sourceProperty);\r\n break;\r\n case 11: // Camera reference\r\n if (scene) {\r\n dest[property] = scene.getCameraByID(sourceProperty);\r\n }\r\n case 12: // Matrix\r\n dest[property] = Matrix.FromArray(sourceProperty);\r\n break;\r\n }\r\n }\r\n }\r\n return destination;\r\n };\r\n /**\r\n * Clones an object\r\n * @param creationFunction defines the function used to instanciate the new object\r\n * @param source defines the source object\r\n * @returns the cloned object\r\n */\r\n SerializationHelper.Clone = function (creationFunction, source) {\r\n return _copySource(creationFunction, source, false);\r\n };\r\n /**\r\n * Instanciates a new object based on a source one (some data will be shared between both object)\r\n * @param creationFunction defines the function used to instanciate the new object\r\n * @param source defines the source object\r\n * @returns the new object\r\n */\r\n SerializationHelper.Instanciate = function (creationFunction, source) {\r\n return _copySource(creationFunction, source, true);\r\n };\r\n /** @hidden */\r\n SerializationHelper._ImageProcessingConfigurationParser = function (sourceProperty) {\r\n throw _DevTools.WarnImport(\"ImageProcessingConfiguration\");\r\n };\r\n /** @hidden */\r\n SerializationHelper._FresnelParametersParser = function (sourceProperty) {\r\n throw _DevTools.WarnImport(\"FresnelParameters\");\r\n };\r\n /** @hidden */\r\n SerializationHelper._ColorCurvesParser = function (sourceProperty) {\r\n throw _DevTools.WarnImport(\"ColorCurves\");\r\n };\r\n /** @hidden */\r\n SerializationHelper._TextureParser = function (sourceProperty, scene, rootUrl) {\r\n throw _DevTools.WarnImport(\"Texture\");\r\n };\r\n return SerializationHelper;\r\n}());\r\nexport { SerializationHelper };\r\n//# sourceMappingURL=decorators.js.map","/**\r\n * A class serves as a medium between the observable and its observers\r\n */\r\nvar EventState = /** @class */ (function () {\r\n /**\r\n * Create a new EventState\r\n * @param mask defines the mask associated with this state\r\n * @param skipNextObservers defines a flag which will instruct the observable to skip following observers when set to true\r\n * @param target defines the original target of the state\r\n * @param currentTarget defines the current target of the state\r\n */\r\n function EventState(mask, skipNextObservers, target, currentTarget) {\r\n if (skipNextObservers === void 0) { skipNextObservers = false; }\r\n this.initalize(mask, skipNextObservers, target, currentTarget);\r\n }\r\n /**\r\n * Initialize the current event state\r\n * @param mask defines the mask associated with this state\r\n * @param skipNextObservers defines a flag which will instruct the observable to skip following observers when set to true\r\n * @param target defines the original target of the state\r\n * @param currentTarget defines the current target of the state\r\n * @returns the current event state\r\n */\r\n EventState.prototype.initalize = function (mask, skipNextObservers, target, currentTarget) {\r\n if (skipNextObservers === void 0) { skipNextObservers = false; }\r\n this.mask = mask;\r\n this.skipNextObservers = skipNextObservers;\r\n this.target = target;\r\n this.currentTarget = currentTarget;\r\n return this;\r\n };\r\n return EventState;\r\n}());\r\nexport { EventState };\r\n/**\r\n * Represent an Observer registered to a given Observable object.\r\n */\r\nvar Observer = /** @class */ (function () {\r\n /**\r\n * Creates a new observer\r\n * @param callback defines the callback to call when the observer is notified\r\n * @param mask defines the mask of the observer (used to filter notifications)\r\n * @param scope defines the current scope used to restore the JS context\r\n */\r\n function Observer(\r\n /**\r\n * Defines the callback to call when the observer is notified\r\n */\r\n callback, \r\n /**\r\n * Defines the mask of the observer (used to filter notifications)\r\n */\r\n mask, \r\n /**\r\n * Defines the current scope used to restore the JS context\r\n */\r\n scope) {\r\n if (scope === void 0) { scope = null; }\r\n this.callback = callback;\r\n this.mask = mask;\r\n this.scope = scope;\r\n /** @hidden */\r\n this._willBeUnregistered = false;\r\n /**\r\n * Gets or sets a property defining that the observer as to be unregistered after the next notification\r\n */\r\n this.unregisterOnNextCall = false;\r\n }\r\n return Observer;\r\n}());\r\nexport { Observer };\r\n/**\r\n * Represent a list of observers registered to multiple Observables object.\r\n */\r\nvar MultiObserver = /** @class */ (function () {\r\n function MultiObserver() {\r\n }\r\n /**\r\n * Release associated resources\r\n */\r\n MultiObserver.prototype.dispose = function () {\r\n if (this._observers && this._observables) {\r\n for (var index = 0; index < this._observers.length; index++) {\r\n this._observables[index].remove(this._observers[index]);\r\n }\r\n }\r\n this._observers = null;\r\n this._observables = null;\r\n };\r\n /**\r\n * Raise a callback when one of the observable will notify\r\n * @param observables defines a list of observables to watch\r\n * @param callback defines the callback to call on notification\r\n * @param mask defines the mask used to filter notifications\r\n * @param scope defines the current scope used to restore the JS context\r\n * @returns the new MultiObserver\r\n */\r\n MultiObserver.Watch = function (observables, callback, mask, scope) {\r\n if (mask === void 0) { mask = -1; }\r\n if (scope === void 0) { scope = null; }\r\n var result = new MultiObserver();\r\n result._observers = new Array();\r\n result._observables = observables;\r\n for (var _i = 0, observables_1 = observables; _i < observables_1.length; _i++) {\r\n var observable = observables_1[_i];\r\n var observer = observable.add(callback, mask, false, scope);\r\n if (observer) {\r\n result._observers.push(observer);\r\n }\r\n }\r\n return result;\r\n };\r\n return MultiObserver;\r\n}());\r\nexport { MultiObserver };\r\n/**\r\n * The Observable class is a simple implementation of the Observable pattern.\r\n *\r\n * There's one slight particularity though: a given Observable can notify its observer using a particular mask value, only the Observers registered with this mask value will be notified.\r\n * This enable a more fine grained execution without having to rely on multiple different Observable objects.\r\n * For instance you may have a given Observable that have four different types of notifications: Move (mask = 0x01), Stop (mask = 0x02), Turn Right (mask = 0X04), Turn Left (mask = 0X08).\r\n * A given observer can register itself with only Move and Stop (mask = 0x03), then it will only be notified when one of these two occurs and will never be for Turn Left/Right.\r\n */\r\nvar Observable = /** @class */ (function () {\r\n /**\r\n * Creates a new observable\r\n * @param onObserverAdded defines a callback to call when a new observer is added\r\n */\r\n function Observable(onObserverAdded) {\r\n this._observers = new Array();\r\n this._eventState = new EventState(0);\r\n if (onObserverAdded) {\r\n this._onObserverAdded = onObserverAdded;\r\n }\r\n }\r\n Object.defineProperty(Observable.prototype, \"observers\", {\r\n /**\r\n * Gets the list of observers\r\n */\r\n get: function () {\r\n return this._observers;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Create a new Observer with the specified callback\r\n * @param callback the callback that will be executed for that Observer\r\n * @param mask the mask used to filter observers\r\n * @param insertFirst if true the callback will be inserted at the first position, hence executed before the others ones. If false (default behavior) the callback will be inserted at the last position, executed after all the others already present.\r\n * @param scope optional scope for the callback to be called from\r\n * @param unregisterOnFirstCall defines if the observer as to be unregistered after the next notification\r\n * @returns the new observer created for the callback\r\n */\r\n Observable.prototype.add = function (callback, mask, insertFirst, scope, unregisterOnFirstCall) {\r\n if (mask === void 0) { mask = -1; }\r\n if (insertFirst === void 0) { insertFirst = false; }\r\n if (scope === void 0) { scope = null; }\r\n if (unregisterOnFirstCall === void 0) { unregisterOnFirstCall = false; }\r\n if (!callback) {\r\n return null;\r\n }\r\n var observer = new Observer(callback, mask, scope);\r\n observer.unregisterOnNextCall = unregisterOnFirstCall;\r\n if (insertFirst) {\r\n this._observers.unshift(observer);\r\n }\r\n else {\r\n this._observers.push(observer);\r\n }\r\n if (this._onObserverAdded) {\r\n this._onObserverAdded(observer);\r\n }\r\n return observer;\r\n };\r\n /**\r\n * Create a new Observer with the specified callback and unregisters after the next notification\r\n * @param callback the callback that will be executed for that Observer\r\n * @returns the new observer created for the callback\r\n */\r\n Observable.prototype.addOnce = function (callback) {\r\n return this.add(callback, undefined, undefined, undefined, true);\r\n };\r\n /**\r\n * Remove an Observer from the Observable object\r\n * @param observer the instance of the Observer to remove\r\n * @returns false if it doesn't belong to this Observable\r\n */\r\n Observable.prototype.remove = function (observer) {\r\n if (!observer) {\r\n return false;\r\n }\r\n var index = this._observers.indexOf(observer);\r\n if (index !== -1) {\r\n this._deferUnregister(observer);\r\n return true;\r\n }\r\n return false;\r\n };\r\n /**\r\n * Remove a callback from the Observable object\r\n * @param callback the callback to remove\r\n * @param scope optional scope. If used only the callbacks with this scope will be removed\r\n * @returns false if it doesn't belong to this Observable\r\n */\r\n Observable.prototype.removeCallback = function (callback, scope) {\r\n for (var index = 0; index < this._observers.length; index++) {\r\n var observer = this._observers[index];\r\n if (observer._willBeUnregistered) {\r\n continue;\r\n }\r\n if (observer.callback === callback && (!scope || scope === observer.scope)) {\r\n this._deferUnregister(observer);\r\n return true;\r\n }\r\n }\r\n return false;\r\n };\r\n Observable.prototype._deferUnregister = function (observer) {\r\n var _this = this;\r\n observer.unregisterOnNextCall = false;\r\n observer._willBeUnregistered = true;\r\n setTimeout(function () {\r\n _this._remove(observer);\r\n }, 0);\r\n };\r\n // This should only be called when not iterating over _observers to avoid callback skipping.\r\n // Removes an observer from the _observer Array.\r\n Observable.prototype._remove = function (observer) {\r\n if (!observer) {\r\n return false;\r\n }\r\n var index = this._observers.indexOf(observer);\r\n if (index !== -1) {\r\n this._observers.splice(index, 1);\r\n return true;\r\n }\r\n return false;\r\n };\r\n /**\r\n * Moves the observable to the top of the observer list making it get called first when notified\r\n * @param observer the observer to move\r\n */\r\n Observable.prototype.makeObserverTopPriority = function (observer) {\r\n this._remove(observer);\r\n this._observers.unshift(observer);\r\n };\r\n /**\r\n * Moves the observable to the bottom of the observer list making it get called last when notified\r\n * @param observer the observer to move\r\n */\r\n Observable.prototype.makeObserverBottomPriority = function (observer) {\r\n this._remove(observer);\r\n this._observers.push(observer);\r\n };\r\n /**\r\n * Notify all Observers by calling their respective callback with the given data\r\n * Will return true if all observers were executed, false if an observer set skipNextObservers to true, then prevent the subsequent ones to execute\r\n * @param eventData defines the data to send to all observers\r\n * @param mask defines the mask of the current notification (observers with incompatible mask (ie mask & observer.mask === 0) will not be notified)\r\n * @param target defines the original target of the state\r\n * @param currentTarget defines the current target of the state\r\n * @param userInfo defines any user info to send to observers\r\n * @returns false if the complete observer chain was not processed (because one observer set the skipNextObservers to true)\r\n */\r\n Observable.prototype.notifyObservers = function (eventData, mask, target, currentTarget, userInfo) {\r\n if (mask === void 0) { mask = -1; }\r\n if (!this._observers.length) {\r\n return true;\r\n }\r\n var state = this._eventState;\r\n state.mask = mask;\r\n state.target = target;\r\n state.currentTarget = currentTarget;\r\n state.skipNextObservers = false;\r\n state.lastReturnValue = eventData;\r\n state.userInfo = userInfo;\r\n for (var _i = 0, _a = this._observers; _i < _a.length; _i++) {\r\n var obs = _a[_i];\r\n if (obs._willBeUnregistered) {\r\n continue;\r\n }\r\n if (obs.mask & mask) {\r\n if (obs.scope) {\r\n state.lastReturnValue = obs.callback.apply(obs.scope, [eventData, state]);\r\n }\r\n else {\r\n state.lastReturnValue = obs.callback(eventData, state);\r\n }\r\n if (obs.unregisterOnNextCall) {\r\n this._deferUnregister(obs);\r\n }\r\n }\r\n if (state.skipNextObservers) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Calling this will execute each callback, expecting it to be a promise or return a value.\r\n * If at any point in the chain one function fails, the promise will fail and the execution will not continue.\r\n * This is useful when a chain of events (sometimes async events) is needed to initialize a certain object\r\n * and it is crucial that all callbacks will be executed.\r\n * The order of the callbacks is kept, callbacks are not executed parallel.\r\n *\r\n * @param eventData The data to be sent to each callback\r\n * @param mask is used to filter observers defaults to -1\r\n * @param target defines the callback target (see EventState)\r\n * @param currentTarget defines he current object in the bubbling phase\r\n * @param userInfo defines any user info to send to observers\r\n * @returns {Promise} will return a Promise than resolves when all callbacks executed successfully.\r\n */\r\n Observable.prototype.notifyObserversWithPromise = function (eventData, mask, target, currentTarget, userInfo) {\r\n var _this = this;\r\n if (mask === void 0) { mask = -1; }\r\n // create an empty promise\r\n var p = Promise.resolve(eventData);\r\n // no observers? return this promise.\r\n if (!this._observers.length) {\r\n return p;\r\n }\r\n var state = this._eventState;\r\n state.mask = mask;\r\n state.target = target;\r\n state.currentTarget = currentTarget;\r\n state.skipNextObservers = false;\r\n state.userInfo = userInfo;\r\n // execute one callback after another (not using Promise.all, the order is important)\r\n this._observers.forEach(function (obs) {\r\n if (state.skipNextObservers) {\r\n return;\r\n }\r\n if (obs._willBeUnregistered) {\r\n return;\r\n }\r\n if (obs.mask & mask) {\r\n if (obs.scope) {\r\n p = p.then(function (lastReturnedValue) {\r\n state.lastReturnValue = lastReturnedValue;\r\n return obs.callback.apply(obs.scope, [eventData, state]);\r\n });\r\n }\r\n else {\r\n p = p.then(function (lastReturnedValue) {\r\n state.lastReturnValue = lastReturnedValue;\r\n return obs.callback(eventData, state);\r\n });\r\n }\r\n if (obs.unregisterOnNextCall) {\r\n _this._deferUnregister(obs);\r\n }\r\n }\r\n });\r\n // return the eventData\r\n return p.then(function () { return eventData; });\r\n };\r\n /**\r\n * Notify a specific observer\r\n * @param observer defines the observer to notify\r\n * @param eventData defines the data to be sent to each callback\r\n * @param mask is used to filter observers defaults to -1\r\n */\r\n Observable.prototype.notifyObserver = function (observer, eventData, mask) {\r\n if (mask === void 0) { mask = -1; }\r\n var state = this._eventState;\r\n state.mask = mask;\r\n state.skipNextObservers = false;\r\n observer.callback(eventData, state);\r\n };\r\n /**\r\n * Gets a boolean indicating if the observable has at least one observer\r\n * @returns true is the Observable has at least one Observer registered\r\n */\r\n Observable.prototype.hasObservers = function () {\r\n return this._observers.length > 0;\r\n };\r\n /**\r\n * Clear the list of observers\r\n */\r\n Observable.prototype.clear = function () {\r\n this._observers = new Array();\r\n this._onObserverAdded = null;\r\n };\r\n /**\r\n * Clone the current observable\r\n * @returns a new observable\r\n */\r\n Observable.prototype.clone = function () {\r\n var result = new Observable();\r\n result._observers = this._observers.slice(0);\r\n return result;\r\n };\r\n /**\r\n * Does this observable handles observer registered with a given mask\r\n * @param mask defines the mask to be tested\r\n * @return whether or not one observer registered with the given mask is handeled\r\n **/\r\n Observable.prototype.hasSpecificMask = function (mask) {\r\n if (mask === void 0) { mask = -1; }\r\n for (var _i = 0, _a = this._observers; _i < _a.length; _i++) {\r\n var obs = _a[_i];\r\n if (obs.mask & mask || obs.mask === mask) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n };\r\n return Observable;\r\n}());\r\nexport { Observable };\r\n//# sourceMappingURL=observable.js.map","import { Observable } from \"../Misc/observable\";\r\nimport { DomManagement } from \"../Misc/domManagement\";\r\nimport { Logger } from \"../Misc/logger\";\r\nimport { ShaderProcessor } from '../Engines/Processors/shaderProcessor';\r\n/**\r\n * Effect containing vertex and fragment shader that can be executed on an object.\r\n */\r\nvar Effect = /** @class */ (function () {\r\n /**\r\n * Instantiates an effect.\r\n * An effect can be used to create/manage/execute vertex and fragment shaders.\r\n * @param baseName Name of the effect.\r\n * @param attributesNamesOrOptions List of attribute names that will be passed to the shader or set of all options to create the effect.\r\n * @param uniformsNamesOrEngine List of uniform variable names that will be passed to the shader or the engine that will be used to render effect.\r\n * @param samplers List of sampler variables that will be passed to the shader.\r\n * @param engine Engine to be used to render the effect\r\n * @param defines Define statements to be added to the shader.\r\n * @param fallbacks Possible fallbacks for this effect to improve performance when needed.\r\n * @param onCompiled Callback that will be called when the shader is compiled.\r\n * @param onError Callback that will be called if an error occurs during shader compilation.\r\n * @param indexParameters Parameters to be used with Babylons include syntax to iterate over an array (eg. {lights: 10})\r\n */\r\n function Effect(baseName, attributesNamesOrOptions, uniformsNamesOrEngine, samplers, engine, defines, fallbacks, onCompiled, onError, indexParameters) {\r\n var _this = this;\r\n if (samplers === void 0) { samplers = null; }\r\n if (defines === void 0) { defines = null; }\r\n if (fallbacks === void 0) { fallbacks = null; }\r\n if (onCompiled === void 0) { onCompiled = null; }\r\n if (onError === void 0) { onError = null; }\r\n var _a;\r\n /**\r\n * Name of the effect.\r\n */\r\n this.name = null;\r\n /**\r\n * String container all the define statements that should be set on the shader.\r\n */\r\n this.defines = \"\";\r\n /**\r\n * Callback that will be called when the shader is compiled.\r\n */\r\n this.onCompiled = null;\r\n /**\r\n * Callback that will be called if an error occurs during shader compilation.\r\n */\r\n this.onError = null;\r\n /**\r\n * Callback that will be called when effect is bound.\r\n */\r\n this.onBind = null;\r\n /**\r\n * Unique ID of the effect.\r\n */\r\n this.uniqueId = 0;\r\n /**\r\n * Observable that will be called when the shader is compiled.\r\n * It is recommended to use executeWhenCompile() or to make sure that scene.isReady() is called to get this observable raised.\r\n */\r\n this.onCompileObservable = new Observable();\r\n /**\r\n * Observable that will be called if an error occurs during shader compilation.\r\n */\r\n this.onErrorObservable = new Observable();\r\n /** @hidden */\r\n this._onBindObservable = null;\r\n /**\r\n * @hidden\r\n * Specifies if the effect was previously ready\r\n */\r\n this._wasPreviouslyReady = false;\r\n /** @hidden */\r\n this._bonesComputationForcedToCPU = false;\r\n /** @hidden */\r\n this._multiTarget = false;\r\n this._uniformBuffersNames = {};\r\n this._samplers = {};\r\n this._isReady = false;\r\n this._compilationError = \"\";\r\n this._allFallbacksProcessed = false;\r\n this._uniforms = {};\r\n /**\r\n * Key for the effect.\r\n * @hidden\r\n */\r\n this._key = \"\";\r\n this._fallbacks = null;\r\n this._vertexSourceCode = \"\";\r\n this._fragmentSourceCode = \"\";\r\n this._vertexSourceCodeOverride = \"\";\r\n this._fragmentSourceCodeOverride = \"\";\r\n this._transformFeedbackVaryings = null;\r\n this._rawVertexSourceCode = \"\";\r\n this._rawFragmentSourceCode = \"\";\r\n /**\r\n * Compiled shader to webGL program.\r\n * @hidden\r\n */\r\n this._pipelineContext = null;\r\n this._valueCache = {};\r\n this.name = baseName;\r\n var processFinalCode = null;\r\n if (attributesNamesOrOptions.attributes) {\r\n var options = attributesNamesOrOptions;\r\n this._engine = uniformsNamesOrEngine;\r\n this._attributesNames = options.attributes;\r\n this._uniformsNames = options.uniformsNames.concat(options.samplers);\r\n this._samplerList = options.samplers.slice();\r\n this.defines = options.defines;\r\n this.onError = options.onError;\r\n this.onCompiled = options.onCompiled;\r\n this._fallbacks = options.fallbacks;\r\n this._indexParameters = options.indexParameters;\r\n this._transformFeedbackVaryings = options.transformFeedbackVaryings || null;\r\n this._multiTarget = !!options.multiTarget;\r\n if (options.uniformBuffersNames) {\r\n this._uniformBuffersNamesList = options.uniformBuffersNames.slice();\r\n for (var i = 0; i < options.uniformBuffersNames.length; i++) {\r\n this._uniformBuffersNames[options.uniformBuffersNames[i]] = i;\r\n }\r\n }\r\n processFinalCode = (_a = options.processFinalCode) !== null && _a !== void 0 ? _a : null;\r\n }\r\n else {\r\n this._engine = engine;\r\n this.defines = (defines == null ? \"\" : defines);\r\n this._uniformsNames = uniformsNamesOrEngine.concat(samplers);\r\n this._samplerList = samplers ? samplers.slice() : [];\r\n this._attributesNames = attributesNamesOrOptions;\r\n this._uniformBuffersNamesList = [];\r\n this.onError = onError;\r\n this.onCompiled = onCompiled;\r\n this._indexParameters = indexParameters;\r\n this._fallbacks = fallbacks;\r\n }\r\n this._attributeLocationByName = {};\r\n this.uniqueId = Effect._uniqueIdSeed++;\r\n var vertexSource;\r\n var fragmentSource;\r\n var hostDocument = DomManagement.IsWindowObjectExist() ? this._engine.getHostDocument() : null;\r\n if (baseName.vertexSource) {\r\n vertexSource = \"source:\" + baseName.vertexSource;\r\n }\r\n else if (baseName.vertexElement) {\r\n vertexSource = hostDocument ? hostDocument.getElementById(baseName.vertexElement) : null;\r\n if (!vertexSource) {\r\n vertexSource = baseName.vertexElement;\r\n }\r\n }\r\n else {\r\n vertexSource = baseName.vertex || baseName;\r\n }\r\n if (baseName.fragmentSource) {\r\n fragmentSource = \"source:\" + baseName.fragmentSource;\r\n }\r\n else if (baseName.fragmentElement) {\r\n fragmentSource = hostDocument ? hostDocument.getElementById(baseName.fragmentElement) : null;\r\n if (!fragmentSource) {\r\n fragmentSource = baseName.fragmentElement;\r\n }\r\n }\r\n else {\r\n fragmentSource = baseName.fragment || baseName;\r\n }\r\n var processorOptions = {\r\n defines: this.defines.split(\"\\n\"),\r\n indexParameters: this._indexParameters,\r\n isFragment: false,\r\n shouldUseHighPrecisionShader: this._engine._shouldUseHighPrecisionShader,\r\n processor: this._engine._shaderProcessor,\r\n supportsUniformBuffers: this._engine.supportsUniformBuffers,\r\n shadersRepository: Effect.ShadersRepository,\r\n includesShadersStore: Effect.IncludesShadersStore,\r\n version: (this._engine.webGLVersion * 100).toString(),\r\n platformName: this._engine.webGLVersion >= 2 ? \"WEBGL2\" : \"WEBGL1\"\r\n };\r\n this._loadShader(vertexSource, \"Vertex\", \"\", function (vertexCode) {\r\n _this._rawVertexSourceCode = vertexCode;\r\n _this._loadShader(fragmentSource, \"Fragment\", \"Pixel\", function (fragmentCode) {\r\n _this._rawFragmentSourceCode = fragmentCode;\r\n ShaderProcessor.Process(vertexCode, processorOptions, function (migratedVertexCode) {\r\n if (processFinalCode) {\r\n migratedVertexCode = processFinalCode(\"vertex\", migratedVertexCode);\r\n }\r\n processorOptions.isFragment = true;\r\n ShaderProcessor.Process(fragmentCode, processorOptions, function (migratedFragmentCode) {\r\n if (processFinalCode) {\r\n migratedFragmentCode = processFinalCode(\"fragment\", migratedFragmentCode);\r\n }\r\n _this._useFinalCode(migratedVertexCode, migratedFragmentCode, baseName);\r\n }, _this._engine);\r\n }, _this._engine);\r\n });\r\n });\r\n }\r\n Object.defineProperty(Effect.prototype, \"onBindObservable\", {\r\n /**\r\n * Observable that will be called when effect is bound.\r\n */\r\n get: function () {\r\n if (!this._onBindObservable) {\r\n this._onBindObservable = new Observable();\r\n }\r\n return this._onBindObservable;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Effect.prototype._useFinalCode = function (migratedVertexCode, migratedFragmentCode, baseName) {\r\n if (baseName) {\r\n var vertex = baseName.vertexElement || baseName.vertex || baseName.spectorName || baseName;\r\n var fragment = baseName.fragmentElement || baseName.fragment || baseName.spectorName || baseName;\r\n this._vertexSourceCode = \"#define SHADER_NAME vertex:\" + vertex + \"\\n\" + migratedVertexCode;\r\n this._fragmentSourceCode = \"#define SHADER_NAME fragment:\" + fragment + \"\\n\" + migratedFragmentCode;\r\n }\r\n else {\r\n this._vertexSourceCode = migratedVertexCode;\r\n this._fragmentSourceCode = migratedFragmentCode;\r\n }\r\n this._prepareEffect();\r\n };\r\n Object.defineProperty(Effect.prototype, \"key\", {\r\n /**\r\n * Unique key for this effect\r\n */\r\n get: function () {\r\n return this._key;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * If the effect has been compiled and prepared.\r\n * @returns if the effect is compiled and prepared.\r\n */\r\n Effect.prototype.isReady = function () {\r\n try {\r\n return this._isReadyInternal();\r\n }\r\n catch (_a) {\r\n return false;\r\n }\r\n };\r\n Effect.prototype._isReadyInternal = function () {\r\n if (this._isReady) {\r\n return true;\r\n }\r\n if (this._pipelineContext) {\r\n return this._pipelineContext.isReady;\r\n }\r\n return false;\r\n };\r\n /**\r\n * The engine the effect was initialized with.\r\n * @returns the engine.\r\n */\r\n Effect.prototype.getEngine = function () {\r\n return this._engine;\r\n };\r\n /**\r\n * The pipeline context for this effect\r\n * @returns the associated pipeline context\r\n */\r\n Effect.prototype.getPipelineContext = function () {\r\n return this._pipelineContext;\r\n };\r\n /**\r\n * The set of names of attribute variables for the shader.\r\n * @returns An array of attribute names.\r\n */\r\n Effect.prototype.getAttributesNames = function () {\r\n return this._attributesNames;\r\n };\r\n /**\r\n * Returns the attribute at the given index.\r\n * @param index The index of the attribute.\r\n * @returns The location of the attribute.\r\n */\r\n Effect.prototype.getAttributeLocation = function (index) {\r\n return this._attributes[index];\r\n };\r\n /**\r\n * Returns the attribute based on the name of the variable.\r\n * @param name of the attribute to look up.\r\n * @returns the attribute location.\r\n */\r\n Effect.prototype.getAttributeLocationByName = function (name) {\r\n return this._attributeLocationByName[name];\r\n };\r\n /**\r\n * The number of attributes.\r\n * @returns the numnber of attributes.\r\n */\r\n Effect.prototype.getAttributesCount = function () {\r\n return this._attributes.length;\r\n };\r\n /**\r\n * Gets the index of a uniform variable.\r\n * @param uniformName of the uniform to look up.\r\n * @returns the index.\r\n */\r\n Effect.prototype.getUniformIndex = function (uniformName) {\r\n return this._uniformsNames.indexOf(uniformName);\r\n };\r\n /**\r\n * Returns the attribute based on the name of the variable.\r\n * @param uniformName of the uniform to look up.\r\n * @returns the location of the uniform.\r\n */\r\n Effect.prototype.getUniform = function (uniformName) {\r\n return this._uniforms[uniformName];\r\n };\r\n /**\r\n * Returns an array of sampler variable names\r\n * @returns The array of sampler variable names.\r\n */\r\n Effect.prototype.getSamplers = function () {\r\n return this._samplerList;\r\n };\r\n /**\r\n * Returns an array of uniform variable names\r\n * @returns The array of uniform variable names.\r\n */\r\n Effect.prototype.getUniformNames = function () {\r\n return this._uniformsNames;\r\n };\r\n /**\r\n * Returns an array of uniform buffer variable names\r\n * @returns The array of uniform buffer variable names.\r\n */\r\n Effect.prototype.getUniformBuffersNames = function () {\r\n return this._uniformBuffersNamesList;\r\n };\r\n /**\r\n * Returns the index parameters used to create the effect\r\n * @returns The index parameters object\r\n */\r\n Effect.prototype.getIndexParameters = function () {\r\n return this._indexParameters;\r\n };\r\n /**\r\n * The error from the last compilation.\r\n * @returns the error string.\r\n */\r\n Effect.prototype.getCompilationError = function () {\r\n return this._compilationError;\r\n };\r\n /**\r\n * Gets a boolean indicating that all fallbacks were used during compilation\r\n * @returns true if all fallbacks were used\r\n */\r\n Effect.prototype.allFallbacksProcessed = function () {\r\n return this._allFallbacksProcessed;\r\n };\r\n /**\r\n * Adds a callback to the onCompiled observable and call the callback imediatly if already ready.\r\n * @param func The callback to be used.\r\n */\r\n Effect.prototype.executeWhenCompiled = function (func) {\r\n var _this = this;\r\n if (this.isReady()) {\r\n func(this);\r\n return;\r\n }\r\n this.onCompileObservable.add(function (effect) {\r\n func(effect);\r\n });\r\n if (!this._pipelineContext || this._pipelineContext.isAsync) {\r\n setTimeout(function () {\r\n _this._checkIsReady(null);\r\n }, 16);\r\n }\r\n };\r\n Effect.prototype._checkIsReady = function (previousPipelineContext) {\r\n var _this = this;\r\n try {\r\n if (this._isReadyInternal()) {\r\n return;\r\n }\r\n }\r\n catch (e) {\r\n this._processCompilationErrors(e, previousPipelineContext);\r\n return;\r\n }\r\n setTimeout(function () {\r\n _this._checkIsReady(previousPipelineContext);\r\n }, 16);\r\n };\r\n Effect.prototype._loadShader = function (shader, key, optionalKey, callback) {\r\n if (typeof (HTMLElement) !== \"undefined\") {\r\n // DOM element ?\r\n if (shader instanceof HTMLElement) {\r\n var shaderCode = DomManagement.GetDOMTextContent(shader);\r\n callback(shaderCode);\r\n return;\r\n }\r\n }\r\n // Direct source ?\r\n if (shader.substr(0, 7) === \"source:\") {\r\n callback(shader.substr(7));\r\n return;\r\n }\r\n // Base64 encoded ?\r\n if (shader.substr(0, 7) === \"base64:\") {\r\n var shaderBinary = window.atob(shader.substr(7));\r\n callback(shaderBinary);\r\n return;\r\n }\r\n // Is in local store ?\r\n if (Effect.ShadersStore[shader + key + \"Shader\"]) {\r\n callback(Effect.ShadersStore[shader + key + \"Shader\"]);\r\n return;\r\n }\r\n if (optionalKey && Effect.ShadersStore[shader + optionalKey + \"Shader\"]) {\r\n callback(Effect.ShadersStore[shader + optionalKey + \"Shader\"]);\r\n return;\r\n }\r\n var shaderUrl;\r\n if (shader[0] === \".\" || shader[0] === \"/\" || shader.indexOf(\"http\") > -1) {\r\n shaderUrl = shader;\r\n }\r\n else {\r\n shaderUrl = Effect.ShadersRepository + shader;\r\n }\r\n // Vertex shader\r\n this._engine._loadFile(shaderUrl + \".\" + key.toLowerCase() + \".fx\", callback);\r\n };\r\n Object.defineProperty(Effect.prototype, \"vertexSourceCode\", {\r\n /**\r\n * Gets the vertex shader source code of this effect\r\n */\r\n get: function () {\r\n return this._vertexSourceCodeOverride && this._fragmentSourceCodeOverride ? this._vertexSourceCodeOverride : this._vertexSourceCode;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Effect.prototype, \"fragmentSourceCode\", {\r\n /**\r\n * Gets the fragment shader source code of this effect\r\n */\r\n get: function () {\r\n return this._vertexSourceCodeOverride && this._fragmentSourceCodeOverride ? this._fragmentSourceCodeOverride : this._fragmentSourceCode;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Effect.prototype, \"rawVertexSourceCode\", {\r\n /**\r\n * Gets the vertex shader source code before it has been processed by the preprocessor\r\n */\r\n get: function () {\r\n return this._rawVertexSourceCode;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Effect.prototype, \"rawFragmentSourceCode\", {\r\n /**\r\n * Gets the fragment shader source code before it has been processed by the preprocessor\r\n */\r\n get: function () {\r\n return this._rawFragmentSourceCode;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Recompiles the webGL program\r\n * @param vertexSourceCode The source code for the vertex shader.\r\n * @param fragmentSourceCode The source code for the fragment shader.\r\n * @param onCompiled Callback called when completed.\r\n * @param onError Callback called on error.\r\n * @hidden\r\n */\r\n Effect.prototype._rebuildProgram = function (vertexSourceCode, fragmentSourceCode, onCompiled, onError) {\r\n var _this = this;\r\n this._isReady = false;\r\n this._vertexSourceCodeOverride = vertexSourceCode;\r\n this._fragmentSourceCodeOverride = fragmentSourceCode;\r\n this.onError = function (effect, error) {\r\n if (onError) {\r\n onError(error);\r\n }\r\n };\r\n this.onCompiled = function () {\r\n var scenes = _this.getEngine().scenes;\r\n if (scenes) {\r\n for (var i = 0; i < scenes.length; i++) {\r\n scenes[i].markAllMaterialsAsDirty(63);\r\n }\r\n }\r\n _this._pipelineContext._handlesSpectorRebuildCallback(onCompiled);\r\n };\r\n this._fallbacks = null;\r\n this._prepareEffect();\r\n };\r\n /**\r\n * Prepares the effect\r\n * @hidden\r\n */\r\n Effect.prototype._prepareEffect = function () {\r\n var _this = this;\r\n var attributesNames = this._attributesNames;\r\n var defines = this.defines;\r\n this._valueCache = {};\r\n var previousPipelineContext = this._pipelineContext;\r\n try {\r\n var engine_1 = this._engine;\r\n this._pipelineContext = engine_1.createPipelineContext();\r\n var rebuildRebind = this._rebuildProgram.bind(this);\r\n if (this._vertexSourceCodeOverride && this._fragmentSourceCodeOverride) {\r\n engine_1._preparePipelineContext(this._pipelineContext, this._vertexSourceCodeOverride, this._fragmentSourceCodeOverride, true, rebuildRebind, null, this._transformFeedbackVaryings);\r\n }\r\n else {\r\n engine_1._preparePipelineContext(this._pipelineContext, this._vertexSourceCode, this._fragmentSourceCode, false, rebuildRebind, defines, this._transformFeedbackVaryings);\r\n }\r\n engine_1._executeWhenRenderingStateIsCompiled(this._pipelineContext, function () {\r\n if (engine_1.supportsUniformBuffers) {\r\n for (var name in _this._uniformBuffersNames) {\r\n _this.bindUniformBlock(name, _this._uniformBuffersNames[name]);\r\n }\r\n }\r\n var uniforms = engine_1.getUniforms(_this._pipelineContext, _this._uniformsNames);\r\n uniforms.forEach(function (uniform, index) {\r\n _this._uniforms[_this._uniformsNames[index]] = uniform;\r\n });\r\n _this._attributes = engine_1.getAttributes(_this._pipelineContext, attributesNames);\r\n if (attributesNames) {\r\n for (var i = 0; i < attributesNames.length; i++) {\r\n var name_1 = attributesNames[i];\r\n _this._attributeLocationByName[name_1] = _this._attributes[i];\r\n }\r\n }\r\n var index;\r\n for (index = 0; index < _this._samplerList.length; index++) {\r\n var sampler = _this.getUniform(_this._samplerList[index]);\r\n if (sampler == null) {\r\n _this._samplerList.splice(index, 1);\r\n index--;\r\n }\r\n }\r\n _this._samplerList.forEach(function (name, index) {\r\n _this._samplers[name] = index;\r\n });\r\n engine_1.bindSamplers(_this);\r\n _this._compilationError = \"\";\r\n _this._isReady = true;\r\n if (_this.onCompiled) {\r\n _this.onCompiled(_this);\r\n }\r\n _this.onCompileObservable.notifyObservers(_this);\r\n _this.onCompileObservable.clear();\r\n // Unbind mesh reference in fallbacks\r\n if (_this._fallbacks) {\r\n _this._fallbacks.unBindMesh();\r\n }\r\n if (previousPipelineContext) {\r\n _this.getEngine()._deletePipelineContext(previousPipelineContext);\r\n }\r\n });\r\n if (this._pipelineContext.isAsync) {\r\n this._checkIsReady(previousPipelineContext);\r\n }\r\n }\r\n catch (e) {\r\n this._processCompilationErrors(e, previousPipelineContext);\r\n }\r\n };\r\n Effect.prototype._getShaderCodeAndErrorLine = function (code, error, isFragment) {\r\n var regexp = isFragment ? /FRAGMENT SHADER ERROR: 0:(\\d+?):/ : /VERTEX SHADER ERROR: 0:(\\d+?):/;\r\n var errorLine = null;\r\n if (error && code) {\r\n var res = error.match(regexp);\r\n if (res && res.length === 2) {\r\n var lineNumber = parseInt(res[1]);\r\n var lines = code.split(\"\\n\", -1);\r\n if (lines.length >= lineNumber) {\r\n errorLine = \"Offending line [\" + lineNumber + \"] in \" + (isFragment ? \"fragment\" : \"vertex\") + \" code: \" + lines[lineNumber - 1];\r\n }\r\n }\r\n }\r\n return [code, errorLine];\r\n };\r\n Effect.prototype._processCompilationErrors = function (e, previousPipelineContext) {\r\n var _a, _b;\r\n var _c, _d, _e;\r\n if (previousPipelineContext === void 0) { previousPipelineContext = null; }\r\n this._compilationError = e.message;\r\n var attributesNames = this._attributesNames;\r\n var fallbacks = this._fallbacks;\r\n // Let's go through fallbacks then\r\n Logger.Error(\"Unable to compile effect:\");\r\n Logger.Error(\"Uniforms: \" + this._uniformsNames.map(function (uniform) {\r\n return \" \" + uniform;\r\n }));\r\n Logger.Error(\"Attributes: \" + attributesNames.map(function (attribute) {\r\n return \" \" + attribute;\r\n }));\r\n Logger.Error(\"Defines:\\r\\n\" + this.defines);\r\n if (Effect.LogShaderCodeOnCompilationError) {\r\n var lineErrorVertex = null, lineErrorFragment = null, code = null;\r\n if ((_c = this._pipelineContext) === null || _c === void 0 ? void 0 : _c._getVertexShaderCode()) {\r\n _a = this._getShaderCodeAndErrorLine(this._pipelineContext._getVertexShaderCode(), this._compilationError, false), code = _a[0], lineErrorVertex = _a[1];\r\n if (code) {\r\n Logger.Error(\"Vertex code:\");\r\n Logger.Error(code);\r\n }\r\n }\r\n if ((_d = this._pipelineContext) === null || _d === void 0 ? void 0 : _d._getFragmentShaderCode()) {\r\n _b = this._getShaderCodeAndErrorLine((_e = this._pipelineContext) === null || _e === void 0 ? void 0 : _e._getFragmentShaderCode(), this._compilationError, true), code = _b[0], lineErrorFragment = _b[1];\r\n if (code) {\r\n Logger.Error(\"Fragment code:\");\r\n Logger.Error(code);\r\n }\r\n }\r\n if (lineErrorVertex) {\r\n Logger.Error(lineErrorVertex);\r\n }\r\n if (lineErrorFragment) {\r\n Logger.Error(lineErrorFragment);\r\n }\r\n }\r\n Logger.Error(\"Error: \" + this._compilationError);\r\n if (previousPipelineContext) {\r\n this._pipelineContext = previousPipelineContext;\r\n this._isReady = true;\r\n if (this.onError) {\r\n this.onError(this, this._compilationError);\r\n }\r\n this.onErrorObservable.notifyObservers(this);\r\n }\r\n if (fallbacks) {\r\n this._pipelineContext = null;\r\n if (fallbacks.hasMoreFallbacks) {\r\n this._allFallbacksProcessed = false;\r\n Logger.Error(\"Trying next fallback.\");\r\n this.defines = fallbacks.reduce(this.defines, this);\r\n this._prepareEffect();\r\n }\r\n else { // Sorry we did everything we can\r\n this._allFallbacksProcessed = true;\r\n if (this.onError) {\r\n this.onError(this, this._compilationError);\r\n }\r\n this.onErrorObservable.notifyObservers(this);\r\n this.onErrorObservable.clear();\r\n // Unbind mesh reference in fallbacks\r\n if (this._fallbacks) {\r\n this._fallbacks.unBindMesh();\r\n }\r\n }\r\n }\r\n else {\r\n this._allFallbacksProcessed = true;\r\n }\r\n };\r\n Object.defineProperty(Effect.prototype, \"isSupported\", {\r\n /**\r\n * Checks if the effect is supported. (Must be called after compilation)\r\n */\r\n get: function () {\r\n return this._compilationError === \"\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Binds a texture to the engine to be used as output of the shader.\r\n * @param channel Name of the output variable.\r\n * @param texture Texture to bind.\r\n * @hidden\r\n */\r\n Effect.prototype._bindTexture = function (channel, texture) {\r\n this._engine._bindTexture(this._samplers[channel], texture);\r\n };\r\n /**\r\n * Sets a texture on the engine to be used in the shader.\r\n * @param channel Name of the sampler variable.\r\n * @param texture Texture to set.\r\n */\r\n Effect.prototype.setTexture = function (channel, texture) {\r\n this._engine.setTexture(this._samplers[channel], this._uniforms[channel], texture);\r\n };\r\n /**\r\n * Sets a depth stencil texture from a render target on the engine to be used in the shader.\r\n * @param channel Name of the sampler variable.\r\n * @param texture Texture to set.\r\n */\r\n Effect.prototype.setDepthStencilTexture = function (channel, texture) {\r\n this._engine.setDepthStencilTexture(this._samplers[channel], this._uniforms[channel], texture);\r\n };\r\n /**\r\n * Sets an array of textures on the engine to be used in the shader.\r\n * @param channel Name of the variable.\r\n * @param textures Textures to set.\r\n */\r\n Effect.prototype.setTextureArray = function (channel, textures) {\r\n var exName = channel + \"Ex\";\r\n if (this._samplerList.indexOf(exName + \"0\") === -1) {\r\n var initialPos = this._samplerList.indexOf(channel);\r\n for (var index = 1; index < textures.length; index++) {\r\n var currentExName = exName + (index - 1).toString();\r\n this._samplerList.splice(initialPos + index, 0, currentExName);\r\n }\r\n // Reset every channels\r\n var channelIndex = 0;\r\n for (var _i = 0, _a = this._samplerList; _i < _a.length; _i++) {\r\n var key = _a[_i];\r\n this._samplers[key] = channelIndex;\r\n channelIndex += 1;\r\n }\r\n }\r\n this._engine.setTextureArray(this._samplers[channel], this._uniforms[channel], textures);\r\n };\r\n /**\r\n * Sets a texture to be the input of the specified post process. (To use the output, pass in the next post process in the pipeline)\r\n * @param channel Name of the sampler variable.\r\n * @param postProcess Post process to get the input texture from.\r\n */\r\n Effect.prototype.setTextureFromPostProcess = function (channel, postProcess) {\r\n this._engine.setTextureFromPostProcess(this._samplers[channel], postProcess);\r\n };\r\n /**\r\n * (Warning! setTextureFromPostProcessOutput may be desired instead)\r\n * Sets the input texture of the passed in post process to be input of this effect. (To use the output of the passed in post process use setTextureFromPostProcessOutput)\r\n * @param channel Name of the sampler variable.\r\n * @param postProcess Post process to get the output texture from.\r\n */\r\n Effect.prototype.setTextureFromPostProcessOutput = function (channel, postProcess) {\r\n this._engine.setTextureFromPostProcessOutput(this._samplers[channel], postProcess);\r\n };\r\n /** @hidden */\r\n Effect.prototype._cacheMatrix = function (uniformName, matrix) {\r\n var cache = this._valueCache[uniformName];\r\n var flag = matrix.updateFlag;\r\n if (cache !== undefined && cache === flag) {\r\n return false;\r\n }\r\n this._valueCache[uniformName] = flag;\r\n return true;\r\n };\r\n /** @hidden */\r\n Effect.prototype._cacheFloat2 = function (uniformName, x, y) {\r\n var cache = this._valueCache[uniformName];\r\n if (!cache || cache.length !== 2) {\r\n cache = [x, y];\r\n this._valueCache[uniformName] = cache;\r\n return true;\r\n }\r\n var changed = false;\r\n if (cache[0] !== x) {\r\n cache[0] = x;\r\n changed = true;\r\n }\r\n if (cache[1] !== y) {\r\n cache[1] = y;\r\n changed = true;\r\n }\r\n return changed;\r\n };\r\n /** @hidden */\r\n Effect.prototype._cacheFloat3 = function (uniformName, x, y, z) {\r\n var cache = this._valueCache[uniformName];\r\n if (!cache || cache.length !== 3) {\r\n cache = [x, y, z];\r\n this._valueCache[uniformName] = cache;\r\n return true;\r\n }\r\n var changed = false;\r\n if (cache[0] !== x) {\r\n cache[0] = x;\r\n changed = true;\r\n }\r\n if (cache[1] !== y) {\r\n cache[1] = y;\r\n changed = true;\r\n }\r\n if (cache[2] !== z) {\r\n cache[2] = z;\r\n changed = true;\r\n }\r\n return changed;\r\n };\r\n /** @hidden */\r\n Effect.prototype._cacheFloat4 = function (uniformName, x, y, z, w) {\r\n var cache = this._valueCache[uniformName];\r\n if (!cache || cache.length !== 4) {\r\n cache = [x, y, z, w];\r\n this._valueCache[uniformName] = cache;\r\n return true;\r\n }\r\n var changed = false;\r\n if (cache[0] !== x) {\r\n cache[0] = x;\r\n changed = true;\r\n }\r\n if (cache[1] !== y) {\r\n cache[1] = y;\r\n changed = true;\r\n }\r\n if (cache[2] !== z) {\r\n cache[2] = z;\r\n changed = true;\r\n }\r\n if (cache[3] !== w) {\r\n cache[3] = w;\r\n changed = true;\r\n }\r\n return changed;\r\n };\r\n /**\r\n * Binds a buffer to a uniform.\r\n * @param buffer Buffer to bind.\r\n * @param name Name of the uniform variable to bind to.\r\n */\r\n Effect.prototype.bindUniformBuffer = function (buffer, name) {\r\n var bufferName = this._uniformBuffersNames[name];\r\n if (bufferName === undefined || Effect._baseCache[bufferName] === buffer) {\r\n return;\r\n }\r\n Effect._baseCache[bufferName] = buffer;\r\n this._engine.bindUniformBufferBase(buffer, bufferName);\r\n };\r\n /**\r\n * Binds block to a uniform.\r\n * @param blockName Name of the block to bind.\r\n * @param index Index to bind.\r\n */\r\n Effect.prototype.bindUniformBlock = function (blockName, index) {\r\n this._engine.bindUniformBlock(this._pipelineContext, blockName, index);\r\n };\r\n /**\r\n * Sets an interger value on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param value Value to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setInt = function (uniformName, value) {\r\n var cache = this._valueCache[uniformName];\r\n if (cache !== undefined && cache === value) {\r\n return this;\r\n }\r\n if (this._engine.setInt(this._uniforms[uniformName], value)) {\r\n this._valueCache[uniformName] = value;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets an int array on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setIntArray = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setIntArray(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an int array 2 on a uniform variable. (Array is specified as single array eg. [1,2,3,4] will result in [[1,2],[3,4]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setIntArray2 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setIntArray2(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an int array 3 on a uniform variable. (Array is specified as single array eg. [1,2,3,4,5,6] will result in [[1,2,3],[4,5,6]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setIntArray3 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setIntArray3(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an int array 4 on a uniform variable. (Array is specified as single array eg. [1,2,3,4,5,6,7,8] will result in [[1,2,3,4],[5,6,7,8]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setIntArray4 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setIntArray4(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an float array on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setFloatArray = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setArray(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an float array 2 on a uniform variable. (Array is specified as single array eg. [1,2,3,4] will result in [[1,2],[3,4]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setFloatArray2 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setArray2(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an float array 3 on a uniform variable. (Array is specified as single array eg. [1,2,3,4,5,6] will result in [[1,2,3],[4,5,6]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setFloatArray3 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setArray3(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an float array 4 on a uniform variable. (Array is specified as single array eg. [1,2,3,4,5,6,7,8] will result in [[1,2,3,4],[5,6,7,8]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setFloatArray4 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setArray4(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an array on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setArray = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setArray(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an array 2 on a uniform variable. (Array is specified as single array eg. [1,2,3,4] will result in [[1,2],[3,4]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setArray2 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setArray2(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an array 3 on a uniform variable. (Array is specified as single array eg. [1,2,3,4,5,6] will result in [[1,2,3],[4,5,6]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setArray3 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setArray3(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets an array 4 on a uniform variable. (Array is specified as single array eg. [1,2,3,4,5,6,7,8] will result in [[1,2,3,4],[5,6,7,8]] in the shader)\r\n * @param uniformName Name of the variable.\r\n * @param array array to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setArray4 = function (uniformName, array) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setArray4(this._uniforms[uniformName], array);\r\n return this;\r\n };\r\n /**\r\n * Sets matrices on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param matrices matrices to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setMatrices = function (uniformName, matrices) {\r\n if (!matrices) {\r\n return this;\r\n }\r\n this._valueCache[uniformName] = null;\r\n this._engine.setMatrices(this._uniforms[uniformName], matrices); // the cast is ok because it is gl.uniformMatrix4fv() which is called at the end, and this function accepts Float32Array and Array\r\n return this;\r\n };\r\n /**\r\n * Sets matrix on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param matrix matrix to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setMatrix = function (uniformName, matrix) {\r\n if (this._cacheMatrix(uniformName, matrix)) {\r\n if (!this._engine.setMatrices(this._uniforms[uniformName], matrix.toArray())) {\r\n this._valueCache[uniformName] = null;\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a 3x3 matrix on a uniform variable. (Speicified as [1,2,3,4,5,6,7,8,9] will result in [1,2,3][4,5,6][7,8,9] matrix)\r\n * @param uniformName Name of the variable.\r\n * @param matrix matrix to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setMatrix3x3 = function (uniformName, matrix) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setMatrix3x3(this._uniforms[uniformName], matrix); // the cast is ok because it is gl.uniformMatrix3fv() which is called at the end, and this function accepts Float32Array and Array\r\n return this;\r\n };\r\n /**\r\n * Sets a 2x2 matrix on a uniform variable. (Speicified as [1,2,3,4] will result in [1,2][3,4] matrix)\r\n * @param uniformName Name of the variable.\r\n * @param matrix matrix to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setMatrix2x2 = function (uniformName, matrix) {\r\n this._valueCache[uniformName] = null;\r\n this._engine.setMatrix2x2(this._uniforms[uniformName], matrix); // the cast is ok because it is gl.uniformMatrix2fv() which is called at the end, and this function accepts Float32Array and Array\r\n return this;\r\n };\r\n /**\r\n * Sets a float on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param value value to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setFloat = function (uniformName, value) {\r\n var cache = this._valueCache[uniformName];\r\n if (cache !== undefined && cache === value) {\r\n return this;\r\n }\r\n if (this._engine.setFloat(this._uniforms[uniformName], value)) {\r\n this._valueCache[uniformName] = value;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a boolean on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param bool value to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setBool = function (uniformName, bool) {\r\n var cache = this._valueCache[uniformName];\r\n if (cache !== undefined && cache === bool) {\r\n return this;\r\n }\r\n if (this._engine.setInt(this._uniforms[uniformName], bool ? 1 : 0)) {\r\n this._valueCache[uniformName] = bool;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a Vector2 on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param vector2 vector2 to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setVector2 = function (uniformName, vector2) {\r\n if (this._cacheFloat2(uniformName, vector2.x, vector2.y)) {\r\n if (!this._engine.setFloat2(this._uniforms[uniformName], vector2.x, vector2.y)) {\r\n this._valueCache[uniformName] = null;\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a float2 on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param x First float in float2.\r\n * @param y Second float in float2.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setFloat2 = function (uniformName, x, y) {\r\n if (this._cacheFloat2(uniformName, x, y)) {\r\n if (!this._engine.setFloat2(this._uniforms[uniformName], x, y)) {\r\n this._valueCache[uniformName] = null;\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a Vector3 on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param vector3 Value to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setVector3 = function (uniformName, vector3) {\r\n if (this._cacheFloat3(uniformName, vector3.x, vector3.y, vector3.z)) {\r\n if (!this._engine.setFloat3(this._uniforms[uniformName], vector3.x, vector3.y, vector3.z)) {\r\n this._valueCache[uniformName] = null;\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a float3 on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param x First float in float3.\r\n * @param y Second float in float3.\r\n * @param z Third float in float3.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setFloat3 = function (uniformName, x, y, z) {\r\n if (this._cacheFloat3(uniformName, x, y, z)) {\r\n if (!this._engine.setFloat3(this._uniforms[uniformName], x, y, z)) {\r\n this._valueCache[uniformName] = null;\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a Vector4 on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param vector4 Value to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setVector4 = function (uniformName, vector4) {\r\n if (this._cacheFloat4(uniformName, vector4.x, vector4.y, vector4.z, vector4.w)) {\r\n if (!this._engine.setFloat4(this._uniforms[uniformName], vector4.x, vector4.y, vector4.z, vector4.w)) {\r\n this._valueCache[uniformName] = null;\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a float4 on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param x First float in float4.\r\n * @param y Second float in float4.\r\n * @param z Third float in float4.\r\n * @param w Fourth float in float4.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setFloat4 = function (uniformName, x, y, z, w) {\r\n if (this._cacheFloat4(uniformName, x, y, z, w)) {\r\n if (!this._engine.setFloat4(this._uniforms[uniformName], x, y, z, w)) {\r\n this._valueCache[uniformName] = null;\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a Color3 on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param color3 Value to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setColor3 = function (uniformName, color3) {\r\n if (this._cacheFloat3(uniformName, color3.r, color3.g, color3.b)) {\r\n if (!this._engine.setFloat3(this._uniforms[uniformName], color3.r, color3.g, color3.b)) {\r\n this._valueCache[uniformName] = null;\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a Color4 on a uniform variable.\r\n * @param uniformName Name of the variable.\r\n * @param color3 Value to be set.\r\n * @param alpha Alpha value to be set.\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setColor4 = function (uniformName, color3, alpha) {\r\n if (this._cacheFloat4(uniformName, color3.r, color3.g, color3.b, alpha)) {\r\n if (!this._engine.setFloat4(this._uniforms[uniformName], color3.r, color3.g, color3.b, alpha)) {\r\n this._valueCache[uniformName] = null;\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a Color4 on a uniform variable\r\n * @param uniformName defines the name of the variable\r\n * @param color4 defines the value to be set\r\n * @returns this effect.\r\n */\r\n Effect.prototype.setDirectColor4 = function (uniformName, color4) {\r\n if (this._cacheFloat4(uniformName, color4.r, color4.g, color4.b, color4.a)) {\r\n if (!this._engine.setFloat4(this._uniforms[uniformName], color4.r, color4.g, color4.b, color4.a)) {\r\n this._valueCache[uniformName] = null;\r\n }\r\n }\r\n return this;\r\n };\r\n /** Release all associated resources */\r\n Effect.prototype.dispose = function () {\r\n this._engine._releaseEffect(this);\r\n };\r\n /**\r\n * This function will add a new shader to the shader store\r\n * @param name the name of the shader\r\n * @param pixelShader optional pixel shader content\r\n * @param vertexShader optional vertex shader content\r\n */\r\n Effect.RegisterShader = function (name, pixelShader, vertexShader) {\r\n if (pixelShader) {\r\n Effect.ShadersStore[name + \"PixelShader\"] = pixelShader;\r\n }\r\n if (vertexShader) {\r\n Effect.ShadersStore[name + \"VertexShader\"] = vertexShader;\r\n }\r\n };\r\n /**\r\n * Resets the cache of effects.\r\n */\r\n Effect.ResetCache = function () {\r\n Effect._baseCache = {};\r\n };\r\n /**\r\n * Gets or sets the relative url used to load shaders if using the engine in non-minified mode\r\n */\r\n Effect.ShadersRepository = \"src/Shaders/\";\r\n /**\r\n * Enable logging of the shader code when a compilation error occurs\r\n */\r\n Effect.LogShaderCodeOnCompilationError = true;\r\n Effect._uniqueIdSeed = 0;\r\n Effect._baseCache = {};\r\n /**\r\n * Store of each shader (The can be looked up using effect.key)\r\n */\r\n Effect.ShadersStore = {};\r\n /**\r\n * Store of each included file for a shader (The can be looked up using effect.key)\r\n */\r\n Effect.IncludesShadersStore = {};\r\n return Effect;\r\n}());\r\nexport { Effect };\r\n//# sourceMappingURL=effect.js.map","import { __extends } from \"tslib\";\r\nimport { Vector2 } from \"@babylonjs/core/Maths/math.vector\";\r\nimport { Epsilon } from '@babylonjs/core/Maths/math.constants';\r\n/**\r\n * Class used to transport Vector2 information for pointer events\r\n */\r\nvar Vector2WithInfo = /** @class */ (function (_super) {\r\n __extends(Vector2WithInfo, _super);\r\n /**\r\n * Creates a new Vector2WithInfo\r\n * @param source defines the vector2 data to transport\r\n * @param buttonIndex defines the current mouse button index\r\n */\r\n function Vector2WithInfo(source, \r\n /** defines the current mouse button index */\r\n buttonIndex) {\r\n if (buttonIndex === void 0) { buttonIndex = 0; }\r\n var _this = _super.call(this, source.x, source.y) || this;\r\n _this.buttonIndex = buttonIndex;\r\n return _this;\r\n }\r\n return Vector2WithInfo;\r\n}(Vector2));\r\nexport { Vector2WithInfo };\r\n/** Class used to provide 2D matrix features */\r\nvar Matrix2D = /** @class */ (function () {\r\n /**\r\n * Creates a new matrix\r\n * @param m00 defines value for (0, 0)\r\n * @param m01 defines value for (0, 1)\r\n * @param m10 defines value for (1, 0)\r\n * @param m11 defines value for (1, 1)\r\n * @param m20 defines value for (2, 0)\r\n * @param m21 defines value for (2, 1)\r\n */\r\n function Matrix2D(m00, m01, m10, m11, m20, m21) {\r\n /** Gets the internal array of 6 floats used to store matrix data */\r\n this.m = new Float32Array(6);\r\n this.fromValues(m00, m01, m10, m11, m20, m21);\r\n }\r\n /**\r\n * Fills the matrix from direct values\r\n * @param m00 defines value for (0, 0)\r\n * @param m01 defines value for (0, 1)\r\n * @param m10 defines value for (1, 0)\r\n * @param m11 defines value for (1, 1)\r\n * @param m20 defines value for (2, 0)\r\n * @param m21 defines value for (2, 1)\r\n * @returns the current modified matrix\r\n */\r\n Matrix2D.prototype.fromValues = function (m00, m01, m10, m11, m20, m21) {\r\n this.m[0] = m00;\r\n this.m[1] = m01;\r\n this.m[2] = m10;\r\n this.m[3] = m11;\r\n this.m[4] = m20;\r\n this.m[5] = m21;\r\n return this;\r\n };\r\n /**\r\n * Gets matrix determinant\r\n * @returns the determinant\r\n */\r\n Matrix2D.prototype.determinant = function () {\r\n return this.m[0] * this.m[3] - this.m[1] * this.m[2];\r\n };\r\n /**\r\n * Inverses the matrix and stores it in a target matrix\r\n * @param result defines the target matrix\r\n * @returns the current matrix\r\n */\r\n Matrix2D.prototype.invertToRef = function (result) {\r\n var l0 = this.m[0];\r\n var l1 = this.m[1];\r\n var l2 = this.m[2];\r\n var l3 = this.m[3];\r\n var l4 = this.m[4];\r\n var l5 = this.m[5];\r\n var det = this.determinant();\r\n if (det < (Epsilon * Epsilon)) {\r\n result.m[0] = 0;\r\n result.m[1] = 0;\r\n result.m[2] = 0;\r\n result.m[3] = 0;\r\n result.m[4] = 0;\r\n result.m[5] = 0;\r\n return this;\r\n }\r\n var detDiv = 1 / det;\r\n var det4 = l2 * l5 - l3 * l4;\r\n var det5 = l1 * l4 - l0 * l5;\r\n result.m[0] = l3 * detDiv;\r\n result.m[1] = -l1 * detDiv;\r\n result.m[2] = -l2 * detDiv;\r\n result.m[3] = l0 * detDiv;\r\n result.m[4] = det4 * detDiv;\r\n result.m[5] = det5 * detDiv;\r\n return this;\r\n };\r\n /**\r\n * Multiplies the current matrix with another one\r\n * @param other defines the second operand\r\n * @param result defines the target matrix\r\n * @returns the current matrix\r\n */\r\n Matrix2D.prototype.multiplyToRef = function (other, result) {\r\n var l0 = this.m[0];\r\n var l1 = this.m[1];\r\n var l2 = this.m[2];\r\n var l3 = this.m[3];\r\n var l4 = this.m[4];\r\n var l5 = this.m[5];\r\n var r0 = other.m[0];\r\n var r1 = other.m[1];\r\n var r2 = other.m[2];\r\n var r3 = other.m[3];\r\n var r4 = other.m[4];\r\n var r5 = other.m[5];\r\n result.m[0] = l0 * r0 + l1 * r2;\r\n result.m[1] = l0 * r1 + l1 * r3;\r\n result.m[2] = l2 * r0 + l3 * r2;\r\n result.m[3] = l2 * r1 + l3 * r3;\r\n result.m[4] = l4 * r0 + l5 * r2 + r4;\r\n result.m[5] = l4 * r1 + l5 * r3 + r5;\r\n return this;\r\n };\r\n /**\r\n * Applies the current matrix to a set of 2 floats and stores the result in a vector2\r\n * @param x defines the x coordinate to transform\r\n * @param y defines the x coordinate to transform\r\n * @param result defines the target vector2\r\n * @returns the current matrix\r\n */\r\n Matrix2D.prototype.transformCoordinates = function (x, y, result) {\r\n result.x = x * this.m[0] + y * this.m[2] + this.m[4];\r\n result.y = x * this.m[1] + y * this.m[3] + this.m[5];\r\n return this;\r\n };\r\n // Statics\r\n /**\r\n * Creates an identity matrix\r\n * @returns a new matrix\r\n */\r\n Matrix2D.Identity = function () {\r\n return new Matrix2D(1, 0, 0, 1, 0, 0);\r\n };\r\n /**\r\n * Creates a translation matrix and stores it in a target matrix\r\n * @param x defines the x coordinate of the translation\r\n * @param y defines the y coordinate of the translation\r\n * @param result defines the target matrix\r\n */\r\n Matrix2D.TranslationToRef = function (x, y, result) {\r\n result.fromValues(1, 0, 0, 1, x, y);\r\n };\r\n /**\r\n * Creates a scaling matrix and stores it in a target matrix\r\n * @param x defines the x coordinate of the scaling\r\n * @param y defines the y coordinate of the scaling\r\n * @param result defines the target matrix\r\n */\r\n Matrix2D.ScalingToRef = function (x, y, result) {\r\n result.fromValues(x, 0, 0, y, 0, 0);\r\n };\r\n /**\r\n * Creates a rotation matrix and stores it in a target matrix\r\n * @param angle defines the rotation angle\r\n * @param result defines the target matrix\r\n */\r\n Matrix2D.RotationToRef = function (angle, result) {\r\n var s = Math.sin(angle);\r\n var c = Math.cos(angle);\r\n result.fromValues(c, s, -s, c, 0, 0);\r\n };\r\n /**\r\n * Composes a matrix from translation, rotation, scaling and parent matrix and stores it in a target matrix\r\n * @param tx defines the x coordinate of the translation\r\n * @param ty defines the y coordinate of the translation\r\n * @param angle defines the rotation angle\r\n * @param scaleX defines the x coordinate of the scaling\r\n * @param scaleY defines the y coordinate of the scaling\r\n * @param parentMatrix defines the parent matrix to multiply by (can be null)\r\n * @param result defines the target matrix\r\n */\r\n Matrix2D.ComposeToRef = function (tx, ty, angle, scaleX, scaleY, parentMatrix, result) {\r\n Matrix2D.TranslationToRef(tx, ty, Matrix2D._TempPreTranslationMatrix);\r\n Matrix2D.ScalingToRef(scaleX, scaleY, Matrix2D._TempScalingMatrix);\r\n Matrix2D.RotationToRef(angle, Matrix2D._TempRotationMatrix);\r\n Matrix2D.TranslationToRef(-tx, -ty, Matrix2D._TempPostTranslationMatrix);\r\n Matrix2D._TempPreTranslationMatrix.multiplyToRef(Matrix2D._TempScalingMatrix, Matrix2D._TempCompose0);\r\n Matrix2D._TempCompose0.multiplyToRef(Matrix2D._TempRotationMatrix, Matrix2D._TempCompose1);\r\n if (parentMatrix) {\r\n Matrix2D._TempCompose1.multiplyToRef(Matrix2D._TempPostTranslationMatrix, Matrix2D._TempCompose2);\r\n Matrix2D._TempCompose2.multiplyToRef(parentMatrix, result);\r\n }\r\n else {\r\n Matrix2D._TempCompose1.multiplyToRef(Matrix2D._TempPostTranslationMatrix, result);\r\n }\r\n };\r\n Matrix2D._TempPreTranslationMatrix = Matrix2D.Identity();\r\n Matrix2D._TempPostTranslationMatrix = Matrix2D.Identity();\r\n Matrix2D._TempRotationMatrix = Matrix2D.Identity();\r\n Matrix2D._TempScalingMatrix = Matrix2D.Identity();\r\n Matrix2D._TempCompose0 = Matrix2D.Identity();\r\n Matrix2D._TempCompose1 = Matrix2D.Identity();\r\n Matrix2D._TempCompose2 = Matrix2D.Identity();\r\n return Matrix2D;\r\n}());\r\nexport { Matrix2D };\r\n//# sourceMappingURL=math2D.js.map","import { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { Vector2, Vector3, Matrix } from \"@babylonjs/core/Maths/math.vector\";\r\nimport { PointerEventTypes } from '@babylonjs/core/Events/pointerEvents';\r\nimport { Logger } from \"@babylonjs/core/Misc/logger\";\r\nimport { Tools } from \"@babylonjs/core/Misc/tools\";\r\nimport { ValueAndUnit } from \"../valueAndUnit\";\r\nimport { Measure } from \"../measure\";\r\nimport { Matrix2D, Vector2WithInfo } from \"../math2D\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Root class used for all 2D controls\r\n * @see https://doc.babylonjs.com/how_to/gui#controls\r\n */\r\nvar Control = /** @class */ (function () {\r\n // Functions\r\n /**\r\n * Creates a new control\r\n * @param name defines the name of the control\r\n */\r\n function Control(\r\n /** defines the name of the control */\r\n name) {\r\n this.name = name;\r\n this._alpha = 1;\r\n this._alphaSet = false;\r\n this._zIndex = 0;\r\n /** @hidden */\r\n this._currentMeasure = Measure.Empty();\r\n this._fontFamily = \"Arial\";\r\n this._fontStyle = \"\";\r\n this._fontWeight = \"\";\r\n this._fontSize = new ValueAndUnit(18, ValueAndUnit.UNITMODE_PIXEL, false);\r\n /** @hidden */\r\n this._width = new ValueAndUnit(1, ValueAndUnit.UNITMODE_PERCENTAGE, false);\r\n /** @hidden */\r\n this._height = new ValueAndUnit(1, ValueAndUnit.UNITMODE_PERCENTAGE, false);\r\n this._color = \"\";\r\n this._style = null;\r\n /** @hidden */\r\n this._horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_CENTER;\r\n /** @hidden */\r\n this._verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n /** @hidden */\r\n this._isDirty = true;\r\n /** @hidden */\r\n this._wasDirty = false;\r\n /** @hidden */\r\n this._tempParentMeasure = Measure.Empty();\r\n /** @hidden */\r\n this._prevCurrentMeasureTransformedIntoGlobalSpace = Measure.Empty();\r\n /** @hidden */\r\n this._cachedParentMeasure = Measure.Empty();\r\n this._paddingLeft = new ValueAndUnit(0);\r\n this._paddingRight = new ValueAndUnit(0);\r\n this._paddingTop = new ValueAndUnit(0);\r\n this._paddingBottom = new ValueAndUnit(0);\r\n /** @hidden */\r\n this._left = new ValueAndUnit(0);\r\n /** @hidden */\r\n this._top = new ValueAndUnit(0);\r\n this._scaleX = 1.0;\r\n this._scaleY = 1.0;\r\n this._rotation = 0;\r\n this._transformCenterX = 0.5;\r\n this._transformCenterY = 0.5;\r\n /** @hidden */\r\n this._transformMatrix = Matrix2D.Identity();\r\n /** @hidden */\r\n this._invertTransformMatrix = Matrix2D.Identity();\r\n /** @hidden */\r\n this._transformedPosition = Vector2.Zero();\r\n this._isMatrixDirty = true;\r\n this._isVisible = true;\r\n this._isHighlighted = false;\r\n this._fontSet = false;\r\n this._dummyVector2 = Vector2.Zero();\r\n this._downCount = 0;\r\n this._enterCount = -1;\r\n this._doNotRender = false;\r\n this._downPointerIds = {};\r\n this._isEnabled = true;\r\n this._disabledColor = \"#9a9a9a\";\r\n this._disabledColorItem = \"#6a6a6a\";\r\n /** @hidden */\r\n this._rebuildLayout = false;\r\n /** @hidden */\r\n this._customData = {};\r\n /** @hidden */\r\n this._isClipped = false;\r\n /** @hidden */\r\n this._automaticSize = false;\r\n /**\r\n * Gets or sets an object used to store user defined information for the node\r\n */\r\n this.metadata = null;\r\n /** Gets or sets a boolean indicating if the control can be hit with pointer events */\r\n this.isHitTestVisible = true;\r\n /** Gets or sets a boolean indicating if the control can block pointer events */\r\n this.isPointerBlocker = false;\r\n /** Gets or sets a boolean indicating if the control can be focusable */\r\n this.isFocusInvisible = false;\r\n /**\r\n * Gets or sets a boolean indicating if the children are clipped to the current control bounds.\r\n * Please note that not clipping children may generate issues with adt.useInvalidateRectOptimization so it is recommended to turn this optimization off if you want to use unclipped children\r\n */\r\n this.clipChildren = true;\r\n /**\r\n * Gets or sets a boolean indicating that control content must be clipped\r\n * Please note that not clipping children may generate issues with adt.useInvalidateRectOptimization so it is recommended to turn this optimization off if you want to use unclipped children\r\n */\r\n this.clipContent = true;\r\n /**\r\n * Gets or sets a boolean indicating that the current control should cache its rendering (useful when the control does not change often)\r\n */\r\n this.useBitmapCache = false;\r\n this._shadowOffsetX = 0;\r\n this._shadowOffsetY = 0;\r\n this._shadowBlur = 0;\r\n this._shadowColor = 'black';\r\n /** Gets or sets the cursor to use when the control is hovered */\r\n this.hoverCursor = \"\";\r\n /** @hidden */\r\n this._linkOffsetX = new ValueAndUnit(0);\r\n /** @hidden */\r\n this._linkOffsetY = new ValueAndUnit(0);\r\n /**\r\n * An event triggered when pointer wheel is scrolled\r\n */\r\n this.onWheelObservable = new Observable();\r\n /**\r\n * An event triggered when the pointer move over the control.\r\n */\r\n this.onPointerMoveObservable = new Observable();\r\n /**\r\n * An event triggered when the pointer move out of the control.\r\n */\r\n this.onPointerOutObservable = new Observable();\r\n /**\r\n * An event triggered when the pointer taps the control\r\n */\r\n this.onPointerDownObservable = new Observable();\r\n /**\r\n * An event triggered when pointer up\r\n */\r\n this.onPointerUpObservable = new Observable();\r\n /**\r\n * An event triggered when a control is clicked on\r\n */\r\n this.onPointerClickObservable = new Observable();\r\n /**\r\n * An event triggered when pointer enters the control\r\n */\r\n this.onPointerEnterObservable = new Observable();\r\n /**\r\n * An event triggered when the control is marked as dirty\r\n */\r\n this.onDirtyObservable = new Observable();\r\n /**\r\n * An event triggered before drawing the control\r\n */\r\n this.onBeforeDrawObservable = new Observable();\r\n /**\r\n * An event triggered after the control was drawn\r\n */\r\n this.onAfterDrawObservable = new Observable();\r\n /**\r\n * An event triggered when the control has been disposed\r\n */\r\n this.onDisposeObservable = new Observable();\r\n /**\r\n * Gets or sets a fixed ratio for this control.\r\n * When different from 0, the ratio is used to compute the \"second\" dimension.\r\n * The first dimension used in the computation is the last one set (by setting width / widthInPixels or height / heightInPixels), and the\r\n * second dimension is computed as first dimension * fixedRatio\r\n */\r\n this.fixedRatio = 0;\r\n this._fixedRatioMasterIsWidth = true;\r\n this._tmpMeasureA = new Measure(0, 0, 0, 0);\r\n }\r\n Object.defineProperty(Control.prototype, \"shadowOffsetX\", {\r\n /** Gets or sets a value indicating the offset to apply on X axis to render the shadow */\r\n get: function () {\r\n return this._shadowOffsetX;\r\n },\r\n set: function (value) {\r\n if (this._shadowOffsetX === value) {\r\n return;\r\n }\r\n this._shadowOffsetX = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"shadowOffsetY\", {\r\n /** Gets or sets a value indicating the offset to apply on Y axis to render the shadow */\r\n get: function () {\r\n return this._shadowOffsetY;\r\n },\r\n set: function (value) {\r\n if (this._shadowOffsetY === value) {\r\n return;\r\n }\r\n this._shadowOffsetY = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"shadowBlur\", {\r\n /** Gets or sets a value indicating the amount of blur to use to render the shadow */\r\n get: function () {\r\n return this._shadowBlur;\r\n },\r\n set: function (value) {\r\n if (this._shadowBlur === value) {\r\n return;\r\n }\r\n this._shadowBlur = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"shadowColor\", {\r\n /** Gets or sets a value indicating the color of the shadow (black by default ie. \"#000\") */\r\n get: function () {\r\n return this._shadowColor;\r\n },\r\n set: function (value) {\r\n if (this._shadowColor === value) {\r\n return;\r\n }\r\n this._shadowColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"typeName\", {\r\n // Properties\r\n /** Gets the control type name */\r\n get: function () {\r\n return this._getTypeName();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Get the current class name of the control.\r\n * @returns current class name\r\n */\r\n Control.prototype.getClassName = function () {\r\n return this._getTypeName();\r\n };\r\n Object.defineProperty(Control.prototype, \"host\", {\r\n /**\r\n * Get the hosting AdvancedDynamicTexture\r\n */\r\n get: function () {\r\n return this._host;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"fontOffset\", {\r\n /** Gets or set information about font offsets (used to render and align text) */\r\n get: function () {\r\n return this._fontOffset;\r\n },\r\n set: function (offset) {\r\n this._fontOffset = offset;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"alpha\", {\r\n /** Gets or sets alpha value for the control (1 means opaque and 0 means entirely transparent) */\r\n get: function () {\r\n return this._alpha;\r\n },\r\n set: function (value) {\r\n if (this._alpha === value) {\r\n return;\r\n }\r\n this._alphaSet = true;\r\n this._alpha = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"isHighlighted\", {\r\n /**\r\n * Gets or sets a boolean indicating that we want to highlight the control (mostly for debugging purpose)\r\n */\r\n get: function () {\r\n return this._isHighlighted;\r\n },\r\n set: function (value) {\r\n if (this._isHighlighted === value) {\r\n return;\r\n }\r\n this._isHighlighted = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"scaleX\", {\r\n /** Gets or sets a value indicating the scale factor on X axis (1 by default)\r\n * @see https://doc.babylonjs.com/how_to/gui#rotation-and-scaling\r\n */\r\n get: function () {\r\n return this._scaleX;\r\n },\r\n set: function (value) {\r\n if (this._scaleX === value) {\r\n return;\r\n }\r\n this._scaleX = value;\r\n this._markAsDirty();\r\n this._markMatrixAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"scaleY\", {\r\n /** Gets or sets a value indicating the scale factor on Y axis (1 by default)\r\n * @see https://doc.babylonjs.com/how_to/gui#rotation-and-scaling\r\n */\r\n get: function () {\r\n return this._scaleY;\r\n },\r\n set: function (value) {\r\n if (this._scaleY === value) {\r\n return;\r\n }\r\n this._scaleY = value;\r\n this._markAsDirty();\r\n this._markMatrixAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"rotation\", {\r\n /** Gets or sets the rotation angle (0 by default)\r\n * @see https://doc.babylonjs.com/how_to/gui#rotation-and-scaling\r\n */\r\n get: function () {\r\n return this._rotation;\r\n },\r\n set: function (value) {\r\n if (this._rotation === value) {\r\n return;\r\n }\r\n this._rotation = value;\r\n this._markAsDirty();\r\n this._markMatrixAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"transformCenterY\", {\r\n /** Gets or sets the transformation center on Y axis (0 by default)\r\n * @see https://doc.babylonjs.com/how_to/gui#rotation-and-scaling\r\n */\r\n get: function () {\r\n return this._transformCenterY;\r\n },\r\n set: function (value) {\r\n if (this._transformCenterY === value) {\r\n return;\r\n }\r\n this._transformCenterY = value;\r\n this._markAsDirty();\r\n this._markMatrixAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"transformCenterX\", {\r\n /** Gets or sets the transformation center on X axis (0 by default)\r\n * @see https://doc.babylonjs.com/how_to/gui#rotation-and-scaling\r\n */\r\n get: function () {\r\n return this._transformCenterX;\r\n },\r\n set: function (value) {\r\n if (this._transformCenterX === value) {\r\n return;\r\n }\r\n this._transformCenterX = value;\r\n this._markAsDirty();\r\n this._markMatrixAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"horizontalAlignment\", {\r\n /**\r\n * Gets or sets the horizontal alignment\r\n * @see https://doc.babylonjs.com/how_to/gui#alignments\r\n */\r\n get: function () {\r\n return this._horizontalAlignment;\r\n },\r\n set: function (value) {\r\n if (this._horizontalAlignment === value) {\r\n return;\r\n }\r\n this._horizontalAlignment = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"verticalAlignment\", {\r\n /**\r\n * Gets or sets the vertical alignment\r\n * @see https://doc.babylonjs.com/how_to/gui#alignments\r\n */\r\n get: function () {\r\n return this._verticalAlignment;\r\n },\r\n set: function (value) {\r\n if (this._verticalAlignment === value) {\r\n return;\r\n }\r\n this._verticalAlignment = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"width\", {\r\n /**\r\n * Gets or sets control width\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._width.toString(this._host);\r\n },\r\n set: function (value) {\r\n this._fixedRatioMasterIsWidth = true;\r\n if (this._width.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._width.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"widthInPixels\", {\r\n /**\r\n * Gets or sets the control width in pixel\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._width.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this._fixedRatioMasterIsWidth = true;\r\n this.width = value + \"px\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"height\", {\r\n /**\r\n * Gets or sets control height\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._height.toString(this._host);\r\n },\r\n set: function (value) {\r\n this._fixedRatioMasterIsWidth = false;\r\n if (this._height.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._height.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"heightInPixels\", {\r\n /**\r\n * Gets or sets control height in pixel\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._height.getValueInPixel(this._host, this._cachedParentMeasure.height);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this._fixedRatioMasterIsWidth = false;\r\n this.height = value + \"px\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"fontFamily\", {\r\n /** Gets or set font family */\r\n get: function () {\r\n if (!this._fontSet) {\r\n return \"\";\r\n }\r\n return this._fontFamily;\r\n },\r\n set: function (value) {\r\n if (this._fontFamily === value) {\r\n return;\r\n }\r\n this._fontFamily = value;\r\n this._resetFontCache();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"fontStyle\", {\r\n /** Gets or sets font style */\r\n get: function () {\r\n return this._fontStyle;\r\n },\r\n set: function (value) {\r\n if (this._fontStyle === value) {\r\n return;\r\n }\r\n this._fontStyle = value;\r\n this._resetFontCache();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"fontWeight\", {\r\n /** Gets or sets font weight */\r\n get: function () {\r\n return this._fontWeight;\r\n },\r\n set: function (value) {\r\n if (this._fontWeight === value) {\r\n return;\r\n }\r\n this._fontWeight = value;\r\n this._resetFontCache();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"style\", {\r\n /**\r\n * Gets or sets style\r\n * @see https://doc.babylonjs.com/how_to/gui#styles\r\n */\r\n get: function () {\r\n return this._style;\r\n },\r\n set: function (value) {\r\n var _this = this;\r\n if (this._style) {\r\n this._style.onChangedObservable.remove(this._styleObserver);\r\n this._styleObserver = null;\r\n }\r\n this._style = value;\r\n if (this._style) {\r\n this._styleObserver = this._style.onChangedObservable.add(function () {\r\n _this._markAsDirty();\r\n _this._resetFontCache();\r\n });\r\n }\r\n this._markAsDirty();\r\n this._resetFontCache();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"_isFontSizeInPercentage\", {\r\n /** @hidden */\r\n get: function () {\r\n return this._fontSize.isPercentage;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"fontSizeInPixels\", {\r\n /** Gets or sets font size in pixels */\r\n get: function () {\r\n var fontSizeToUse = this._style ? this._style._fontSize : this._fontSize;\r\n if (fontSizeToUse.isPixel) {\r\n return fontSizeToUse.getValue(this._host);\r\n }\r\n return fontSizeToUse.getValueInPixel(this._host, this._tempParentMeasure.height || this._cachedParentMeasure.height);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.fontSize = value + \"px\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"fontSize\", {\r\n /** Gets or sets font size */\r\n get: function () {\r\n return this._fontSize.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._fontSize.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._fontSize.fromString(value)) {\r\n this._markAsDirty();\r\n this._resetFontCache();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"color\", {\r\n /** Gets or sets foreground color */\r\n get: function () {\r\n return this._color;\r\n },\r\n set: function (value) {\r\n if (this._color === value) {\r\n return;\r\n }\r\n this._color = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"zIndex\", {\r\n /** Gets or sets z index which is used to reorder controls on the z axis */\r\n get: function () {\r\n return this._zIndex;\r\n },\r\n set: function (value) {\r\n if (this.zIndex === value) {\r\n return;\r\n }\r\n this._zIndex = value;\r\n if (this.parent) {\r\n this.parent._reOrderControl(this);\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"notRenderable\", {\r\n /** Gets or sets a boolean indicating if the control can be rendered */\r\n get: function () {\r\n return this._doNotRender;\r\n },\r\n set: function (value) {\r\n if (this._doNotRender === value) {\r\n return;\r\n }\r\n this._doNotRender = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"isVisible\", {\r\n /** Gets or sets a boolean indicating if the control is visible */\r\n get: function () {\r\n return this._isVisible;\r\n },\r\n set: function (value) {\r\n if (this._isVisible === value) {\r\n return;\r\n }\r\n this._isVisible = value;\r\n this._markAsDirty(true);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"isDirty\", {\r\n /** Gets a boolean indicating that the control needs to update its rendering */\r\n get: function () {\r\n return this._isDirty;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"linkedMesh\", {\r\n /**\r\n * Gets the current linked mesh (or null if none)\r\n */\r\n get: function () {\r\n return this._linkedMesh;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"paddingLeft\", {\r\n /**\r\n * Gets or sets a value indicating the padding to use on the left of the control\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._paddingLeft.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._paddingLeft.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"paddingLeftInPixels\", {\r\n /**\r\n * Gets or sets a value indicating the padding in pixels to use on the left of the control\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._paddingLeft.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.paddingLeft = value + \"px\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"paddingRight\", {\r\n /**\r\n * Gets or sets a value indicating the padding to use on the right of the control\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._paddingRight.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._paddingRight.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"paddingRightInPixels\", {\r\n /**\r\n * Gets or sets a value indicating the padding in pixels to use on the right of the control\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._paddingRight.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.paddingRight = value + \"px\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"paddingTop\", {\r\n /**\r\n * Gets or sets a value indicating the padding to use on the top of the control\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._paddingTop.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._paddingTop.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"paddingTopInPixels\", {\r\n /**\r\n * Gets or sets a value indicating the padding in pixels to use on the top of the control\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._paddingTop.getValueInPixel(this._host, this._cachedParentMeasure.height);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.paddingTop = value + \"px\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"paddingBottom\", {\r\n /**\r\n * Gets or sets a value indicating the padding to use on the bottom of the control\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._paddingBottom.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._paddingBottom.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"paddingBottomInPixels\", {\r\n /**\r\n * Gets or sets a value indicating the padding in pixels to use on the bottom of the control\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._paddingBottom.getValueInPixel(this._host, this._cachedParentMeasure.height);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.paddingBottom = value + \"px\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"left\", {\r\n /**\r\n * Gets or sets a value indicating the left coordinate of the control\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._left.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._left.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"leftInPixels\", {\r\n /**\r\n * Gets or sets a value indicating the left coordinate in pixels of the control\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._left.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.left = value + \"px\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"top\", {\r\n /**\r\n * Gets or sets a value indicating the top coordinate of the control\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._top.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._top.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"topInPixels\", {\r\n /**\r\n * Gets or sets a value indicating the top coordinate in pixels of the control\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._top.getValueInPixel(this._host, this._cachedParentMeasure.height);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.top = value + \"px\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"linkOffsetX\", {\r\n /**\r\n * Gets or sets a value indicating the offset on X axis to the linked mesh\r\n * @see https://doc.babylonjs.com/how_to/gui#tracking-positions\r\n */\r\n get: function () {\r\n return this._linkOffsetX.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._linkOffsetX.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"linkOffsetXInPixels\", {\r\n /**\r\n * Gets or sets a value indicating the offset in pixels on X axis to the linked mesh\r\n * @see https://doc.babylonjs.com/how_to/gui#tracking-positions\r\n */\r\n get: function () {\r\n return this._linkOffsetX.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.linkOffsetX = value + \"px\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"linkOffsetY\", {\r\n /**\r\n * Gets or sets a value indicating the offset on Y axis to the linked mesh\r\n * @see https://doc.babylonjs.com/how_to/gui#tracking-positions\r\n */\r\n get: function () {\r\n return this._linkOffsetY.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._linkOffsetY.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"linkOffsetYInPixels\", {\r\n /**\r\n * Gets or sets a value indicating the offset in pixels on Y axis to the linked mesh\r\n * @see https://doc.babylonjs.com/how_to/gui#tracking-positions\r\n */\r\n get: function () {\r\n return this._linkOffsetY.getValueInPixel(this._host, this._cachedParentMeasure.height);\r\n },\r\n set: function (value) {\r\n if (isNaN(value)) {\r\n return;\r\n }\r\n this.linkOffsetY = value + \"px\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"centerX\", {\r\n /** Gets the center coordinate on X axis */\r\n get: function () {\r\n return this._currentMeasure.left + this._currentMeasure.width / 2;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"centerY\", {\r\n /** Gets the center coordinate on Y axis */\r\n get: function () {\r\n return this._currentMeasure.top + this._currentMeasure.height / 2;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"isEnabled\", {\r\n /** Gets or sets if control is Enabled*/\r\n get: function () {\r\n return this._isEnabled;\r\n },\r\n set: function (value) {\r\n if (this._isEnabled === value) {\r\n return;\r\n }\r\n this._isEnabled = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"disabledColor\", {\r\n /** Gets or sets background color of control if it's disabled*/\r\n get: function () {\r\n return this._disabledColor;\r\n },\r\n set: function (value) {\r\n if (this._disabledColor === value) {\r\n return;\r\n }\r\n this._disabledColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control.prototype, \"disabledColorItem\", {\r\n /** Gets or sets front color of control if it's disabled*/\r\n get: function () {\r\n return this._disabledColorItem;\r\n },\r\n set: function (value) {\r\n if (this._disabledColorItem === value) {\r\n return;\r\n }\r\n this._disabledColorItem = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n Control.prototype._getTypeName = function () {\r\n return \"Control\";\r\n };\r\n /**\r\n * Gets the first ascendant in the hierarchy of the given type\r\n * @param className defines the required type\r\n * @returns the ascendant or null if not found\r\n */\r\n Control.prototype.getAscendantOfClass = function (className) {\r\n if (!this.parent) {\r\n return null;\r\n }\r\n if (this.parent.getClassName() === className) {\r\n return this.parent;\r\n }\r\n return this.parent.getAscendantOfClass(className);\r\n };\r\n /** @hidden */\r\n Control.prototype._resetFontCache = function () {\r\n this._fontSet = true;\r\n this._markAsDirty();\r\n };\r\n /**\r\n * Determines if a container is an ascendant of the current control\r\n * @param container defines the container to look for\r\n * @returns true if the container is one of the ascendant of the control\r\n */\r\n Control.prototype.isAscendant = function (container) {\r\n if (!this.parent) {\r\n return false;\r\n }\r\n if (this.parent === container) {\r\n return true;\r\n }\r\n return this.parent.isAscendant(container);\r\n };\r\n /**\r\n * Gets coordinates in local control space\r\n * @param globalCoordinates defines the coordinates to transform\r\n * @returns the new coordinates in local space\r\n */\r\n Control.prototype.getLocalCoordinates = function (globalCoordinates) {\r\n var result = Vector2.Zero();\r\n this.getLocalCoordinatesToRef(globalCoordinates, result);\r\n return result;\r\n };\r\n /**\r\n * Gets coordinates in local control space\r\n * @param globalCoordinates defines the coordinates to transform\r\n * @param result defines the target vector2 where to store the result\r\n * @returns the current control\r\n */\r\n Control.prototype.getLocalCoordinatesToRef = function (globalCoordinates, result) {\r\n result.x = globalCoordinates.x - this._currentMeasure.left;\r\n result.y = globalCoordinates.y - this._currentMeasure.top;\r\n return this;\r\n };\r\n /**\r\n * Gets coordinates in parent local control space\r\n * @param globalCoordinates defines the coordinates to transform\r\n * @returns the new coordinates in parent local space\r\n */\r\n Control.prototype.getParentLocalCoordinates = function (globalCoordinates) {\r\n var result = Vector2.Zero();\r\n result.x = globalCoordinates.x - this._cachedParentMeasure.left;\r\n result.y = globalCoordinates.y - this._cachedParentMeasure.top;\r\n return result;\r\n };\r\n /**\r\n * Move the current control to a vector3 position projected onto the screen.\r\n * @param position defines the target position\r\n * @param scene defines the hosting scene\r\n */\r\n Control.prototype.moveToVector3 = function (position, scene) {\r\n if (!this._host || this.parent !== this._host._rootContainer) {\r\n Tools.Error(\"Cannot move a control to a vector3 if the control is not at root level\");\r\n return;\r\n }\r\n this.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n this.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n var globalViewport = this._host._getGlobalViewport(scene);\r\n var projectedPosition = Vector3.Project(position, Matrix.Identity(), scene.getTransformMatrix(), globalViewport);\r\n this._moveToProjectedPosition(projectedPosition);\r\n if (projectedPosition.z < 0 || projectedPosition.z > 1) {\r\n this.notRenderable = true;\r\n return;\r\n }\r\n this.notRenderable = false;\r\n };\r\n /**\r\n * Will store all controls that have this control as ascendant in a given array\r\n * @param results defines the array where to store the descendants\r\n * @param directDescendantsOnly defines if true only direct descendants of 'this' will be considered, if false direct and also indirect (children of children, an so on in a recursive manner) descendants of 'this' will be considered\r\n * @param predicate defines an optional predicate that will be called on every evaluated child, the predicate must return true for a given child to be part of the result, otherwise it will be ignored\r\n */\r\n Control.prototype.getDescendantsToRef = function (results, directDescendantsOnly, predicate) {\r\n if (directDescendantsOnly === void 0) { directDescendantsOnly = false; }\r\n // Do nothing by default\r\n };\r\n /**\r\n * Will return all controls that have this control as ascendant\r\n * @param directDescendantsOnly defines if true only direct descendants of 'this' will be considered, if false direct and also indirect (children of children, an so on in a recursive manner) descendants of 'this' will be considered\r\n * @param predicate defines an optional predicate that will be called on every evaluated child, the predicate must return true for a given child to be part of the result, otherwise it will be ignored\r\n * @return all child controls\r\n */\r\n Control.prototype.getDescendants = function (directDescendantsOnly, predicate) {\r\n var results = new Array();\r\n this.getDescendantsToRef(results, directDescendantsOnly, predicate);\r\n return results;\r\n };\r\n /**\r\n * Link current control with a target mesh\r\n * @param mesh defines the mesh to link with\r\n * @see https://doc.babylonjs.com/how_to/gui#tracking-positions\r\n */\r\n Control.prototype.linkWithMesh = function (mesh) {\r\n if (!this._host || this.parent && this.parent !== this._host._rootContainer) {\r\n if (mesh) {\r\n Tools.Error(\"Cannot link a control to a mesh if the control is not at root level\");\r\n }\r\n return;\r\n }\r\n var index = this._host._linkedControls.indexOf(this);\r\n if (index !== -1) {\r\n this._linkedMesh = mesh;\r\n if (!mesh) {\r\n this._host._linkedControls.splice(index, 1);\r\n }\r\n return;\r\n }\r\n else if (!mesh) {\r\n return;\r\n }\r\n this.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n this.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n this._linkedMesh = mesh;\r\n this._host._linkedControls.push(this);\r\n };\r\n /** @hidden */\r\n Control.prototype._moveToProjectedPosition = function (projectedPosition) {\r\n var oldLeft = this._left.getValue(this._host);\r\n var oldTop = this._top.getValue(this._host);\r\n var newLeft = ((projectedPosition.x + this._linkOffsetX.getValue(this._host)) - this._currentMeasure.width / 2);\r\n var newTop = ((projectedPosition.y + this._linkOffsetY.getValue(this._host)) - this._currentMeasure.height / 2);\r\n if (this._left.ignoreAdaptiveScaling && this._top.ignoreAdaptiveScaling) {\r\n if (Math.abs(newLeft - oldLeft) < 0.5) {\r\n newLeft = oldLeft;\r\n }\r\n if (Math.abs(newTop - oldTop) < 0.5) {\r\n newTop = oldTop;\r\n }\r\n }\r\n this.left = newLeft + \"px\";\r\n this.top = newTop + \"px\";\r\n this._left.ignoreAdaptiveScaling = true;\r\n this._top.ignoreAdaptiveScaling = true;\r\n this._markAsDirty();\r\n };\r\n /** @hidden */\r\n Control.prototype._offsetLeft = function (offset) {\r\n this._isDirty = true;\r\n this._currentMeasure.left += offset;\r\n };\r\n /** @hidden */\r\n Control.prototype._offsetTop = function (offset) {\r\n this._isDirty = true;\r\n this._currentMeasure.top += offset;\r\n };\r\n /** @hidden */\r\n Control.prototype._markMatrixAsDirty = function () {\r\n this._isMatrixDirty = true;\r\n this._flagDescendantsAsMatrixDirty();\r\n };\r\n /** @hidden */\r\n Control.prototype._flagDescendantsAsMatrixDirty = function () {\r\n // No child\r\n };\r\n /** @hidden */\r\n Control.prototype._intersectsRect = function (rect) {\r\n // Rotate the control's current measure into local space and check if it intersects the passed in rectangle\r\n this._currentMeasure.transformToRef(this._transformMatrix, this._tmpMeasureA);\r\n if (this._tmpMeasureA.left >= rect.left + rect.width) {\r\n return false;\r\n }\r\n if (this._tmpMeasureA.top >= rect.top + rect.height) {\r\n return false;\r\n }\r\n if (this._tmpMeasureA.left + this._tmpMeasureA.width <= rect.left) {\r\n return false;\r\n }\r\n if (this._tmpMeasureA.top + this._tmpMeasureA.height <= rect.top) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n /** @hidden */\r\n Control.prototype.invalidateRect = function () {\r\n this._transform();\r\n if (this.host && this.host.useInvalidateRectOptimization) {\r\n // Rotate by transform to get the measure transformed to global space\r\n this._currentMeasure.transformToRef(this._transformMatrix, this._tmpMeasureA);\r\n // get the boudning box of the current measure and last frames measure in global space and invalidate it\r\n // the previous measure is used to properly clear a control that is scaled down\r\n Measure.CombineToRef(this._tmpMeasureA, this._prevCurrentMeasureTransformedIntoGlobalSpace, this._tmpMeasureA);\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n // Expand rect based on shadows\r\n var shadowOffsetX = this.shadowOffsetX;\r\n var shadowOffsetY = this.shadowOffsetY;\r\n var shadowBlur = this.shadowBlur;\r\n var leftShadowOffset = Math.min(Math.min(shadowOffsetX, 0) - shadowBlur * 2, 0);\r\n var rightShadowOffset = Math.max(Math.max(shadowOffsetX, 0) + shadowBlur * 2, 0);\r\n var topShadowOffset = Math.min(Math.min(shadowOffsetY, 0) - shadowBlur * 2, 0);\r\n var bottomShadowOffset = Math.max(Math.max(shadowOffsetY, 0) + shadowBlur * 2, 0);\r\n this.host.invalidateRect(Math.floor(this._tmpMeasureA.left + leftShadowOffset), Math.floor(this._tmpMeasureA.top + topShadowOffset), Math.ceil(this._tmpMeasureA.left + this._tmpMeasureA.width + rightShadowOffset), Math.ceil(this._tmpMeasureA.top + this._tmpMeasureA.height + bottomShadowOffset));\r\n }\r\n else {\r\n this.host.invalidateRect(Math.floor(this._tmpMeasureA.left), Math.floor(this._tmpMeasureA.top), Math.ceil(this._tmpMeasureA.left + this._tmpMeasureA.width), Math.ceil(this._tmpMeasureA.top + this._tmpMeasureA.height));\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._markAsDirty = function (force) {\r\n if (force === void 0) { force = false; }\r\n if (!this._isVisible && !force) {\r\n return;\r\n }\r\n this._isDirty = true;\r\n // Redraw only this rectangle\r\n if (this._host) {\r\n this._host.markAsDirty();\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._markAllAsDirty = function () {\r\n this._markAsDirty();\r\n if (this._font) {\r\n this._prepareFont();\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._link = function (host) {\r\n this._host = host;\r\n if (this._host) {\r\n this.uniqueId = this._host.getScene().getUniqueId();\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._transform = function (context) {\r\n if (!this._isMatrixDirty && this._scaleX === 1 && this._scaleY === 1 && this._rotation === 0) {\r\n return;\r\n }\r\n // postTranslate\r\n var offsetX = this._currentMeasure.width * this._transformCenterX + this._currentMeasure.left;\r\n var offsetY = this._currentMeasure.height * this._transformCenterY + this._currentMeasure.top;\r\n if (context) {\r\n context.translate(offsetX, offsetY);\r\n // rotate\r\n context.rotate(this._rotation);\r\n // scale\r\n context.scale(this._scaleX, this._scaleY);\r\n // preTranslate\r\n context.translate(-offsetX, -offsetY);\r\n }\r\n // Need to update matrices?\r\n if (this._isMatrixDirty || this._cachedOffsetX !== offsetX || this._cachedOffsetY !== offsetY) {\r\n this._cachedOffsetX = offsetX;\r\n this._cachedOffsetY = offsetY;\r\n this._isMatrixDirty = false;\r\n this._flagDescendantsAsMatrixDirty();\r\n Matrix2D.ComposeToRef(-offsetX, -offsetY, this._rotation, this._scaleX, this._scaleY, this.parent ? this.parent._transformMatrix : null, this._transformMatrix);\r\n this._transformMatrix.invertToRef(this._invertTransformMatrix);\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._renderHighlight = function (context) {\r\n if (!this.isHighlighted) {\r\n return;\r\n }\r\n context.save();\r\n context.strokeStyle = \"#4affff\";\r\n context.lineWidth = 2;\r\n this._renderHighlightSpecific(context);\r\n context.restore();\r\n };\r\n /** @hidden */\r\n Control.prototype._renderHighlightSpecific = function (context) {\r\n context.strokeRect(this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n };\r\n /** @hidden */\r\n Control.prototype._applyStates = function (context) {\r\n if (this._isFontSizeInPercentage) {\r\n this._fontSet = true;\r\n }\r\n if (this._fontSet) {\r\n this._prepareFont();\r\n this._fontSet = false;\r\n }\r\n if (this._font) {\r\n context.font = this._font;\r\n }\r\n if (this._color) {\r\n context.fillStyle = this._color;\r\n }\r\n if (Control.AllowAlphaInheritance) {\r\n context.globalAlpha *= this._alpha;\r\n }\r\n else if (this._alphaSet) {\r\n context.globalAlpha = this.parent ? this.parent.alpha * this._alpha : this._alpha;\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._layout = function (parentMeasure, context) {\r\n if (!this.isDirty && (!this.isVisible || this.notRenderable)) {\r\n return false;\r\n }\r\n if (this._isDirty || !this._cachedParentMeasure.isEqualsTo(parentMeasure)) {\r\n this.host._numLayoutCalls++;\r\n this._currentMeasure.addAndTransformToRef(this._transformMatrix, -this.paddingLeftInPixels | 0, -this.paddingTopInPixels | 0, this.paddingRightInPixels | 0, this.paddingBottomInPixels | 0, this._prevCurrentMeasureTransformedIntoGlobalSpace);\r\n context.save();\r\n this._applyStates(context);\r\n var rebuildCount = 0;\r\n do {\r\n this._rebuildLayout = false;\r\n this._processMeasures(parentMeasure, context);\r\n rebuildCount++;\r\n } while (this._rebuildLayout && rebuildCount < 3);\r\n if (rebuildCount >= 3) {\r\n Logger.Error(\"Layout cycle detected in GUI (Control name=\" + this.name + \", uniqueId=\" + this.uniqueId + \")\");\r\n }\r\n context.restore();\r\n this.invalidateRect();\r\n this._evaluateClippingState(parentMeasure);\r\n }\r\n this._wasDirty = this._isDirty;\r\n this._isDirty = false;\r\n return true;\r\n };\r\n /** @hidden */\r\n Control.prototype._processMeasures = function (parentMeasure, context) {\r\n this._currentMeasure.copyFrom(parentMeasure);\r\n // Let children take some pre-measurement actions\r\n this._preMeasure(parentMeasure, context);\r\n this._measure();\r\n this._computeAlignment(parentMeasure, context);\r\n // Convert to int values\r\n this._currentMeasure.left = this._currentMeasure.left | 0;\r\n this._currentMeasure.top = this._currentMeasure.top | 0;\r\n this._currentMeasure.width = this._currentMeasure.width | 0;\r\n this._currentMeasure.height = this._currentMeasure.height | 0;\r\n // Let children add more features\r\n this._additionalProcessing(parentMeasure, context);\r\n this._cachedParentMeasure.copyFrom(parentMeasure);\r\n if (this.onDirtyObservable.hasObservers()) {\r\n this.onDirtyObservable.notifyObservers(this);\r\n }\r\n };\r\n Control.prototype._evaluateClippingState = function (parentMeasure) {\r\n if (this.parent && this.parent.clipChildren) {\r\n // Early clip\r\n if (this._currentMeasure.left > parentMeasure.left + parentMeasure.width) {\r\n this._isClipped = true;\r\n return;\r\n }\r\n if (this._currentMeasure.left + this._currentMeasure.width < parentMeasure.left) {\r\n this._isClipped = true;\r\n return;\r\n }\r\n if (this._currentMeasure.top > parentMeasure.top + parentMeasure.height) {\r\n this._isClipped = true;\r\n return;\r\n }\r\n if (this._currentMeasure.top + this._currentMeasure.height < parentMeasure.top) {\r\n this._isClipped = true;\r\n return;\r\n }\r\n }\r\n this._isClipped = false;\r\n };\r\n /** @hidden */\r\n Control.prototype._measure = function () {\r\n // Width / Height\r\n if (this._width.isPixel) {\r\n this._currentMeasure.width = this._width.getValue(this._host);\r\n }\r\n else {\r\n this._currentMeasure.width *= this._width.getValue(this._host);\r\n }\r\n if (this._height.isPixel) {\r\n this._currentMeasure.height = this._height.getValue(this._host);\r\n }\r\n else {\r\n this._currentMeasure.height *= this._height.getValue(this._host);\r\n }\r\n if (this.fixedRatio !== 0) {\r\n if (this._fixedRatioMasterIsWidth) {\r\n this._currentMeasure.height = this._currentMeasure.width * this.fixedRatio;\r\n }\r\n else {\r\n this._currentMeasure.width = this._currentMeasure.height * this.fixedRatio;\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._computeAlignment = function (parentMeasure, context) {\r\n var width = this._currentMeasure.width;\r\n var height = this._currentMeasure.height;\r\n var parentWidth = parentMeasure.width;\r\n var parentHeight = parentMeasure.height;\r\n // Left / top\r\n var x = 0;\r\n var y = 0;\r\n switch (this.horizontalAlignment) {\r\n case Control.HORIZONTAL_ALIGNMENT_LEFT:\r\n x = 0;\r\n break;\r\n case Control.HORIZONTAL_ALIGNMENT_RIGHT:\r\n x = parentWidth - width;\r\n break;\r\n case Control.HORIZONTAL_ALIGNMENT_CENTER:\r\n x = (parentWidth - width) / 2;\r\n break;\r\n }\r\n switch (this.verticalAlignment) {\r\n case Control.VERTICAL_ALIGNMENT_TOP:\r\n y = 0;\r\n break;\r\n case Control.VERTICAL_ALIGNMENT_BOTTOM:\r\n y = parentHeight - height;\r\n break;\r\n case Control.VERTICAL_ALIGNMENT_CENTER:\r\n y = (parentHeight - height) / 2;\r\n break;\r\n }\r\n if (this._paddingLeft.isPixel) {\r\n this._currentMeasure.left += this._paddingLeft.getValue(this._host);\r\n this._currentMeasure.width -= this._paddingLeft.getValue(this._host);\r\n }\r\n else {\r\n this._currentMeasure.left += parentWidth * this._paddingLeft.getValue(this._host);\r\n this._currentMeasure.width -= parentWidth * this._paddingLeft.getValue(this._host);\r\n }\r\n if (this._paddingRight.isPixel) {\r\n this._currentMeasure.width -= this._paddingRight.getValue(this._host);\r\n }\r\n else {\r\n this._currentMeasure.width -= parentWidth * this._paddingRight.getValue(this._host);\r\n }\r\n if (this._paddingTop.isPixel) {\r\n this._currentMeasure.top += this._paddingTop.getValue(this._host);\r\n this._currentMeasure.height -= this._paddingTop.getValue(this._host);\r\n }\r\n else {\r\n this._currentMeasure.top += parentHeight * this._paddingTop.getValue(this._host);\r\n this._currentMeasure.height -= parentHeight * this._paddingTop.getValue(this._host);\r\n }\r\n if (this._paddingBottom.isPixel) {\r\n this._currentMeasure.height -= this._paddingBottom.getValue(this._host);\r\n }\r\n else {\r\n this._currentMeasure.height -= parentHeight * this._paddingBottom.getValue(this._host);\r\n }\r\n if (this._left.isPixel) {\r\n this._currentMeasure.left += this._left.getValue(this._host);\r\n }\r\n else {\r\n this._currentMeasure.left += parentWidth * this._left.getValue(this._host);\r\n }\r\n if (this._top.isPixel) {\r\n this._currentMeasure.top += this._top.getValue(this._host);\r\n }\r\n else {\r\n this._currentMeasure.top += parentHeight * this._top.getValue(this._host);\r\n }\r\n this._currentMeasure.left += x;\r\n this._currentMeasure.top += y;\r\n };\r\n /** @hidden */\r\n Control.prototype._preMeasure = function (parentMeasure, context) {\r\n // Do nothing\r\n };\r\n /** @hidden */\r\n Control.prototype._additionalProcessing = function (parentMeasure, context) {\r\n // Do nothing\r\n };\r\n /** @hidden */\r\n Control.prototype._clipForChildren = function (context) {\r\n // DO nothing\r\n };\r\n Control.prototype._clip = function (context, invalidatedRectangle) {\r\n context.beginPath();\r\n Control._ClipMeasure.copyFrom(this._currentMeasure);\r\n if (invalidatedRectangle) {\r\n // Rotate the invalidated rect into the control's space\r\n invalidatedRectangle.transformToRef(this._invertTransformMatrix, this._tmpMeasureA);\r\n // Get the intersection of the rect in context space and the current context\r\n var intersection = new Measure(0, 0, 0, 0);\r\n intersection.left = Math.max(this._tmpMeasureA.left, this._currentMeasure.left);\r\n intersection.top = Math.max(this._tmpMeasureA.top, this._currentMeasure.top);\r\n intersection.width = Math.min(this._tmpMeasureA.left + this._tmpMeasureA.width, this._currentMeasure.left + this._currentMeasure.width) - intersection.left;\r\n intersection.height = Math.min(this._tmpMeasureA.top + this._tmpMeasureA.height, this._currentMeasure.top + this._currentMeasure.height) - intersection.top;\r\n Control._ClipMeasure.copyFrom(intersection);\r\n }\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n var shadowOffsetX = this.shadowOffsetX;\r\n var shadowOffsetY = this.shadowOffsetY;\r\n var shadowBlur = this.shadowBlur;\r\n var leftShadowOffset = Math.min(Math.min(shadowOffsetX, 0) - shadowBlur * 2, 0);\r\n var rightShadowOffset = Math.max(Math.max(shadowOffsetX, 0) + shadowBlur * 2, 0);\r\n var topShadowOffset = Math.min(Math.min(shadowOffsetY, 0) - shadowBlur * 2, 0);\r\n var bottomShadowOffset = Math.max(Math.max(shadowOffsetY, 0) + shadowBlur * 2, 0);\r\n context.rect(Control._ClipMeasure.left + leftShadowOffset, Control._ClipMeasure.top + topShadowOffset, Control._ClipMeasure.width + rightShadowOffset - leftShadowOffset, Control._ClipMeasure.height + bottomShadowOffset - topShadowOffset);\r\n }\r\n else {\r\n context.rect(Control._ClipMeasure.left, Control._ClipMeasure.top, Control._ClipMeasure.width, Control._ClipMeasure.height);\r\n }\r\n context.clip();\r\n };\r\n /** @hidden */\r\n Control.prototype._render = function (context, invalidatedRectangle) {\r\n if (!this.isVisible || this.notRenderable || this._isClipped) {\r\n this._isDirty = false;\r\n return false;\r\n }\r\n this.host._numRenderCalls++;\r\n context.save();\r\n this._applyStates(context);\r\n // Transform\r\n this._transform(context);\r\n // Clip\r\n if (this.clipContent) {\r\n this._clip(context, invalidatedRectangle);\r\n }\r\n if (this.onBeforeDrawObservable.hasObservers()) {\r\n this.onBeforeDrawObservable.notifyObservers(this);\r\n }\r\n if (this.useBitmapCache && !this._wasDirty && this._cacheData) {\r\n context.putImageData(this._cacheData, this._currentMeasure.left, this._currentMeasure.top);\r\n }\r\n else {\r\n this._draw(context, invalidatedRectangle);\r\n }\r\n if (this.useBitmapCache && this._wasDirty) {\r\n this._cacheData = context.getImageData(this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n }\r\n this._renderHighlight(context);\r\n if (this.onAfterDrawObservable.hasObservers()) {\r\n this.onAfterDrawObservable.notifyObservers(this);\r\n }\r\n context.restore();\r\n return true;\r\n };\r\n /** @hidden */\r\n Control.prototype._draw = function (context, invalidatedRectangle) {\r\n // Do nothing\r\n };\r\n /**\r\n * Tests if a given coordinates belong to the current control\r\n * @param x defines x coordinate to test\r\n * @param y defines y coordinate to test\r\n * @returns true if the coordinates are inside the control\r\n */\r\n Control.prototype.contains = function (x, y) {\r\n // Invert transform\r\n this._invertTransformMatrix.transformCoordinates(x, y, this._transformedPosition);\r\n x = this._transformedPosition.x;\r\n y = this._transformedPosition.y;\r\n // Check\r\n if (x < this._currentMeasure.left) {\r\n return false;\r\n }\r\n if (x > this._currentMeasure.left + this._currentMeasure.width) {\r\n return false;\r\n }\r\n if (y < this._currentMeasure.top) {\r\n return false;\r\n }\r\n if (y > this._currentMeasure.top + this._currentMeasure.height) {\r\n return false;\r\n }\r\n if (this.isPointerBlocker) {\r\n this._host._shouldBlockPointer = true;\r\n }\r\n return true;\r\n };\r\n /** @hidden */\r\n Control.prototype._processPicking = function (x, y, pi, type, pointerId, buttonIndex, deltaX, deltaY) {\r\n if (!this._isEnabled) {\r\n return false;\r\n }\r\n if (!this.isHitTestVisible || !this.isVisible || this._doNotRender) {\r\n return false;\r\n }\r\n if (!this.contains(x, y)) {\r\n return false;\r\n }\r\n this._processObservables(type, x, y, pi, pointerId, buttonIndex, deltaX, deltaY);\r\n return true;\r\n };\r\n /** @hidden */\r\n Control.prototype._onPointerMove = function (target, coordinates, pointerId, pi) {\r\n var canNotify = this.onPointerMoveObservable.notifyObservers(coordinates, -1, target, this, pi);\r\n if (canNotify && this.parent != null) {\r\n this.parent._onPointerMove(target, coordinates, pointerId, pi);\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._onPointerEnter = function (target, pi) {\r\n if (!this._isEnabled) {\r\n return false;\r\n }\r\n if (this._enterCount > 0) {\r\n return false;\r\n }\r\n if (this._enterCount === -1) { // -1 is for touch input, we are now sure we are with a mouse or pencil\r\n this._enterCount = 0;\r\n }\r\n this._enterCount++;\r\n var canNotify = this.onPointerEnterObservable.notifyObservers(this, -1, target, this, pi);\r\n if (canNotify && this.parent != null) {\r\n this.parent._onPointerEnter(target, pi);\r\n }\r\n return true;\r\n };\r\n /** @hidden */\r\n Control.prototype._onPointerOut = function (target, pi, force) {\r\n if (force === void 0) { force = false; }\r\n if (!force && (!this._isEnabled || target === this)) {\r\n return;\r\n }\r\n this._enterCount = 0;\r\n var canNotify = true;\r\n if (!target.isAscendant(this)) {\r\n canNotify = this.onPointerOutObservable.notifyObservers(this, -1, target, this, pi);\r\n }\r\n if (canNotify && this.parent != null) {\r\n this.parent._onPointerOut(target, pi, force);\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex, pi) {\r\n // Prevent pointerout to lose control context.\r\n // Event redundancy is checked inside the function.\r\n this._onPointerEnter(this, pi);\r\n if (this._downCount !== 0) {\r\n return false;\r\n }\r\n this._downCount++;\r\n this._downPointerIds[pointerId] = true;\r\n var canNotify = this.onPointerDownObservable.notifyObservers(new Vector2WithInfo(coordinates, buttonIndex), -1, target, this, pi);\r\n if (canNotify && this.parent != null) {\r\n this.parent._onPointerDown(target, coordinates, pointerId, buttonIndex, pi);\r\n }\r\n return true;\r\n };\r\n /** @hidden */\r\n Control.prototype._onPointerUp = function (target, coordinates, pointerId, buttonIndex, notifyClick, pi) {\r\n if (!this._isEnabled) {\r\n return;\r\n }\r\n this._downCount = 0;\r\n delete this._downPointerIds[pointerId];\r\n var canNotifyClick = notifyClick;\r\n if (notifyClick && (this._enterCount > 0 || this._enterCount === -1)) {\r\n canNotifyClick = this.onPointerClickObservable.notifyObservers(new Vector2WithInfo(coordinates, buttonIndex), -1, target, this, pi);\r\n }\r\n var canNotify = this.onPointerUpObservable.notifyObservers(new Vector2WithInfo(coordinates, buttonIndex), -1, target, this, pi);\r\n if (canNotify && this.parent != null) {\r\n this.parent._onPointerUp(target, coordinates, pointerId, buttonIndex, canNotifyClick, pi);\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._forcePointerUp = function (pointerId) {\r\n if (pointerId === void 0) { pointerId = null; }\r\n if (pointerId !== null) {\r\n this._onPointerUp(this, Vector2.Zero(), pointerId, 0, true);\r\n }\r\n else {\r\n for (var key in this._downPointerIds) {\r\n this._onPointerUp(this, Vector2.Zero(), +key, 0, true);\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._onWheelScroll = function (deltaX, deltaY) {\r\n if (!this._isEnabled) {\r\n return;\r\n }\r\n var canNotify = this.onWheelObservable.notifyObservers(new Vector2(deltaX, deltaY));\r\n if (canNotify && this.parent != null) {\r\n this.parent._onWheelScroll(deltaX, deltaY);\r\n }\r\n };\r\n /** @hidden */\r\n Control.prototype._onCanvasBlur = function () { };\r\n /** @hidden */\r\n Control.prototype._processObservables = function (type, x, y, pi, pointerId, buttonIndex, deltaX, deltaY) {\r\n if (!this._isEnabled) {\r\n return false;\r\n }\r\n this._dummyVector2.copyFromFloats(x, y);\r\n if (type === PointerEventTypes.POINTERMOVE) {\r\n this._onPointerMove(this, this._dummyVector2, pointerId, pi);\r\n var previousControlOver = this._host._lastControlOver[pointerId];\r\n if (previousControlOver && previousControlOver !== this) {\r\n previousControlOver._onPointerOut(this, pi);\r\n }\r\n if (previousControlOver !== this) {\r\n this._onPointerEnter(this, pi);\r\n }\r\n this._host._lastControlOver[pointerId] = this;\r\n return true;\r\n }\r\n if (type === PointerEventTypes.POINTERDOWN) {\r\n this._onPointerDown(this, this._dummyVector2, pointerId, buttonIndex, pi);\r\n this._host._registerLastControlDown(this, pointerId);\r\n this._host._lastPickedControl = this;\r\n return true;\r\n }\r\n if (type === PointerEventTypes.POINTERUP) {\r\n if (this._host._lastControlDown[pointerId]) {\r\n this._host._lastControlDown[pointerId]._onPointerUp(this, this._dummyVector2, pointerId, buttonIndex, true, pi);\r\n }\r\n delete this._host._lastControlDown[pointerId];\r\n return true;\r\n }\r\n if (type === PointerEventTypes.POINTERWHEEL) {\r\n if (this._host._lastControlOver[pointerId]) {\r\n this._host._lastControlOver[pointerId]._onWheelScroll(deltaX, deltaY);\r\n return true;\r\n }\r\n }\r\n return false;\r\n };\r\n Control.prototype._prepareFont = function () {\r\n if (!this._font && !this._fontSet) {\r\n return;\r\n }\r\n if (this._style) {\r\n this._font = this._style.fontStyle + \" \" + this._style.fontWeight + \" \" + this.fontSizeInPixels + \"px \" + this._style.fontFamily;\r\n }\r\n else {\r\n this._font = this._fontStyle + \" \" + this._fontWeight + \" \" + this.fontSizeInPixels + \"px \" + this._fontFamily;\r\n }\r\n this._fontOffset = Control._GetFontOffset(this._font);\r\n };\r\n /** Releases associated resources */\r\n Control.prototype.dispose = function () {\r\n this.onDirtyObservable.clear();\r\n this.onBeforeDrawObservable.clear();\r\n this.onAfterDrawObservable.clear();\r\n this.onPointerDownObservable.clear();\r\n this.onPointerEnterObservable.clear();\r\n this.onPointerMoveObservable.clear();\r\n this.onPointerOutObservable.clear();\r\n this.onPointerUpObservable.clear();\r\n this.onPointerClickObservable.clear();\r\n this.onWheelObservable.clear();\r\n if (this._styleObserver && this._style) {\r\n this._style.onChangedObservable.remove(this._styleObserver);\r\n this._styleObserver = null;\r\n }\r\n if (this.parent) {\r\n this.parent.removeControl(this);\r\n this.parent = null;\r\n }\r\n if (this._host) {\r\n var index = this._host._linkedControls.indexOf(this);\r\n if (index > -1) {\r\n this.linkWithMesh(null);\r\n }\r\n }\r\n // Callback\r\n this.onDisposeObservable.notifyObservers(this);\r\n this.onDisposeObservable.clear();\r\n };\r\n Object.defineProperty(Control, \"HORIZONTAL_ALIGNMENT_LEFT\", {\r\n /** HORIZONTAL_ALIGNMENT_LEFT */\r\n get: function () {\r\n return Control._HORIZONTAL_ALIGNMENT_LEFT;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control, \"HORIZONTAL_ALIGNMENT_RIGHT\", {\r\n /** HORIZONTAL_ALIGNMENT_RIGHT */\r\n get: function () {\r\n return Control._HORIZONTAL_ALIGNMENT_RIGHT;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control, \"HORIZONTAL_ALIGNMENT_CENTER\", {\r\n /** HORIZONTAL_ALIGNMENT_CENTER */\r\n get: function () {\r\n return Control._HORIZONTAL_ALIGNMENT_CENTER;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control, \"VERTICAL_ALIGNMENT_TOP\", {\r\n /** VERTICAL_ALIGNMENT_TOP */\r\n get: function () {\r\n return Control._VERTICAL_ALIGNMENT_TOP;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control, \"VERTICAL_ALIGNMENT_BOTTOM\", {\r\n /** VERTICAL_ALIGNMENT_BOTTOM */\r\n get: function () {\r\n return Control._VERTICAL_ALIGNMENT_BOTTOM;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Control, \"VERTICAL_ALIGNMENT_CENTER\", {\r\n /** VERTICAL_ALIGNMENT_CENTER */\r\n get: function () {\r\n return Control._VERTICAL_ALIGNMENT_CENTER;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n Control._GetFontOffset = function (font) {\r\n if (Control._FontHeightSizes[font]) {\r\n return Control._FontHeightSizes[font];\r\n }\r\n var text = document.createElement(\"span\");\r\n text.innerHTML = \"Hg\";\r\n text.style.font = font;\r\n var block = document.createElement(\"div\");\r\n block.style.display = \"inline-block\";\r\n block.style.width = \"1px\";\r\n block.style.height = \"0px\";\r\n block.style.verticalAlign = \"bottom\";\r\n var div = document.createElement(\"div\");\r\n div.style.whiteSpace = \"nowrap\";\r\n div.appendChild(text);\r\n div.appendChild(block);\r\n document.body.appendChild(div);\r\n var fontAscent = 0;\r\n var fontHeight = 0;\r\n try {\r\n fontHeight = block.getBoundingClientRect().top - text.getBoundingClientRect().top;\r\n block.style.verticalAlign = \"baseline\";\r\n fontAscent = block.getBoundingClientRect().top - text.getBoundingClientRect().top;\r\n }\r\n finally {\r\n document.body.removeChild(div);\r\n }\r\n var result = { ascent: fontAscent, height: fontHeight, descent: fontHeight - fontAscent };\r\n Control._FontHeightSizes[font] = result;\r\n return result;\r\n };\r\n /** @hidden */\r\n Control.drawEllipse = function (x, y, width, height, context) {\r\n context.translate(x, y);\r\n context.scale(width, height);\r\n context.beginPath();\r\n context.arc(0, 0, 1, 0, 2 * Math.PI);\r\n context.closePath();\r\n context.scale(1 / width, 1 / height);\r\n context.translate(-x, -y);\r\n };\r\n /**\r\n * Gets or sets a boolean indicating if alpha must be an inherited value (false by default)\r\n */\r\n Control.AllowAlphaInheritance = false;\r\n Control._ClipMeasure = new Measure(0, 0, 0, 0);\r\n // Statics\r\n Control._HORIZONTAL_ALIGNMENT_LEFT = 0;\r\n Control._HORIZONTAL_ALIGNMENT_RIGHT = 1;\r\n Control._HORIZONTAL_ALIGNMENT_CENTER = 2;\r\n Control._VERTICAL_ALIGNMENT_TOP = 0;\r\n Control._VERTICAL_ALIGNMENT_BOTTOM = 1;\r\n Control._VERTICAL_ALIGNMENT_CENTER = 2;\r\n Control._FontHeightSizes = {};\r\n /**\r\n * Creates a stack panel that can be used to render headers\r\n * @param control defines the control to associate with the header\r\n * @param text defines the text of the header\r\n * @param size defines the size of the header\r\n * @param options defines options used to configure the header\r\n * @returns a new StackPanel\r\n * @ignore\r\n * @hidden\r\n */\r\n Control.AddHeader = function () { };\r\n return Control;\r\n}());\r\nexport { Control };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Control\"] = Control;\r\n//# sourceMappingURL=control.js.map","import { Scalar } from './math.scalar';\r\nimport { ToLinearSpace, ToGammaSpace } from './math.constants';\r\nimport { ArrayTools } from '../Misc/arrayTools';\r\nimport { _TypeStore } from '../Misc/typeStore';\r\n/**\r\n * Class used to hold a RBG color\r\n */\r\nvar Color3 = /** @class */ (function () {\r\n /**\r\n * Creates a new Color3 object from red, green, blue values, all between 0 and 1\r\n * @param r defines the red component (between 0 and 1, default is 0)\r\n * @param g defines the green component (between 0 and 1, default is 0)\r\n * @param b defines the blue component (between 0 and 1, default is 0)\r\n */\r\n function Color3(\r\n /**\r\n * Defines the red component (between 0 and 1, default is 0)\r\n */\r\n r, \r\n /**\r\n * Defines the green component (between 0 and 1, default is 0)\r\n */\r\n g, \r\n /**\r\n * Defines the blue component (between 0 and 1, default is 0)\r\n */\r\n b) {\r\n if (r === void 0) { r = 0; }\r\n if (g === void 0) { g = 0; }\r\n if (b === void 0) { b = 0; }\r\n this.r = r;\r\n this.g = g;\r\n this.b = b;\r\n }\r\n /**\r\n * Creates a string with the Color3 current values\r\n * @returns the string representation of the Color3 object\r\n */\r\n Color3.prototype.toString = function () {\r\n return \"{R: \" + this.r + \" G:\" + this.g + \" B:\" + this.b + \"}\";\r\n };\r\n /**\r\n * Returns the string \"Color3\"\r\n * @returns \"Color3\"\r\n */\r\n Color3.prototype.getClassName = function () {\r\n return \"Color3\";\r\n };\r\n /**\r\n * Compute the Color3 hash code\r\n * @returns an unique number that can be used to hash Color3 objects\r\n */\r\n Color3.prototype.getHashCode = function () {\r\n var hash = (this.r * 255) | 0;\r\n hash = (hash * 397) ^ ((this.g * 255) | 0);\r\n hash = (hash * 397) ^ ((this.b * 255) | 0);\r\n return hash;\r\n };\r\n // Operators\r\n /**\r\n * Stores in the given array from the given starting index the red, green, blue values as successive elements\r\n * @param array defines the array where to store the r,g,b components\r\n * @param index defines an optional index in the target array to define where to start storing values\r\n * @returns the current Color3 object\r\n */\r\n Color3.prototype.toArray = function (array, index) {\r\n if (index === void 0) { index = 0; }\r\n array[index] = this.r;\r\n array[index + 1] = this.g;\r\n array[index + 2] = this.b;\r\n return this;\r\n };\r\n /**\r\n * Update the current color with values stored in an array from the starting index of the given array\r\n * @param array defines the source array\r\n * @param offset defines an offset in the source array\r\n * @returns the current Color3 object\r\n */\r\n Color3.prototype.fromArray = function (array, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n Color3.FromArrayToRef(array, offset, this);\r\n return this;\r\n };\r\n /**\r\n * Returns a new Color4 object from the current Color3 and the given alpha\r\n * @param alpha defines the alpha component on the new Color4 object (default is 1)\r\n * @returns a new Color4 object\r\n */\r\n Color3.prototype.toColor4 = function (alpha) {\r\n if (alpha === void 0) { alpha = 1; }\r\n return new Color4(this.r, this.g, this.b, alpha);\r\n };\r\n /**\r\n * Returns a new array populated with 3 numeric elements : red, green and blue values\r\n * @returns the new array\r\n */\r\n Color3.prototype.asArray = function () {\r\n var result = new Array();\r\n this.toArray(result, 0);\r\n return result;\r\n };\r\n /**\r\n * Returns the luminance value\r\n * @returns a float value\r\n */\r\n Color3.prototype.toLuminance = function () {\r\n return this.r * 0.3 + this.g * 0.59 + this.b * 0.11;\r\n };\r\n /**\r\n * Multiply each Color3 rgb values by the given Color3 rgb values in a new Color3 object\r\n * @param otherColor defines the second operand\r\n * @returns the new Color3 object\r\n */\r\n Color3.prototype.multiply = function (otherColor) {\r\n return new Color3(this.r * otherColor.r, this.g * otherColor.g, this.b * otherColor.b);\r\n };\r\n /**\r\n * Multiply the rgb values of the Color3 and the given Color3 and stores the result in the object \"result\"\r\n * @param otherColor defines the second operand\r\n * @param result defines the Color3 object where to store the result\r\n * @returns the current Color3\r\n */\r\n Color3.prototype.multiplyToRef = function (otherColor, result) {\r\n result.r = this.r * otherColor.r;\r\n result.g = this.g * otherColor.g;\r\n result.b = this.b * otherColor.b;\r\n return this;\r\n };\r\n /**\r\n * Determines equality between Color3 objects\r\n * @param otherColor defines the second operand\r\n * @returns true if the rgb values are equal to the given ones\r\n */\r\n Color3.prototype.equals = function (otherColor) {\r\n return otherColor && this.r === otherColor.r && this.g === otherColor.g && this.b === otherColor.b;\r\n };\r\n /**\r\n * Determines equality between the current Color3 object and a set of r,b,g values\r\n * @param r defines the red component to check\r\n * @param g defines the green component to check\r\n * @param b defines the blue component to check\r\n * @returns true if the rgb values are equal to the given ones\r\n */\r\n Color3.prototype.equalsFloats = function (r, g, b) {\r\n return this.r === r && this.g === g && this.b === b;\r\n };\r\n /**\r\n * Multiplies in place each rgb value by scale\r\n * @param scale defines the scaling factor\r\n * @returns the updated Color3\r\n */\r\n Color3.prototype.scale = function (scale) {\r\n return new Color3(this.r * scale, this.g * scale, this.b * scale);\r\n };\r\n /**\r\n * Multiplies the rgb values by scale and stores the result into \"result\"\r\n * @param scale defines the scaling factor\r\n * @param result defines the Color3 object where to store the result\r\n * @returns the unmodified current Color3\r\n */\r\n Color3.prototype.scaleToRef = function (scale, result) {\r\n result.r = this.r * scale;\r\n result.g = this.g * scale;\r\n result.b = this.b * scale;\r\n return this;\r\n };\r\n /**\r\n * Scale the current Color3 values by a factor and add the result to a given Color3\r\n * @param scale defines the scale factor\r\n * @param result defines color to store the result into\r\n * @returns the unmodified current Color3\r\n */\r\n Color3.prototype.scaleAndAddToRef = function (scale, result) {\r\n result.r += this.r * scale;\r\n result.g += this.g * scale;\r\n result.b += this.b * scale;\r\n return this;\r\n };\r\n /**\r\n * Clamps the rgb values by the min and max values and stores the result into \"result\"\r\n * @param min defines minimum clamping value (default is 0)\r\n * @param max defines maximum clamping value (default is 1)\r\n * @param result defines color to store the result into\r\n * @returns the original Color3\r\n */\r\n Color3.prototype.clampToRef = function (min, max, result) {\r\n if (min === void 0) { min = 0; }\r\n if (max === void 0) { max = 1; }\r\n result.r = Scalar.Clamp(this.r, min, max);\r\n result.g = Scalar.Clamp(this.g, min, max);\r\n result.b = Scalar.Clamp(this.b, min, max);\r\n return this;\r\n };\r\n /**\r\n * Creates a new Color3 set with the added values of the current Color3 and of the given one\r\n * @param otherColor defines the second operand\r\n * @returns the new Color3\r\n */\r\n Color3.prototype.add = function (otherColor) {\r\n return new Color3(this.r + otherColor.r, this.g + otherColor.g, this.b + otherColor.b);\r\n };\r\n /**\r\n * Stores the result of the addition of the current Color3 and given one rgb values into \"result\"\r\n * @param otherColor defines the second operand\r\n * @param result defines Color3 object to store the result into\r\n * @returns the unmodified current Color3\r\n */\r\n Color3.prototype.addToRef = function (otherColor, result) {\r\n result.r = this.r + otherColor.r;\r\n result.g = this.g + otherColor.g;\r\n result.b = this.b + otherColor.b;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Color3 set with the subtracted values of the given one from the current Color3\r\n * @param otherColor defines the second operand\r\n * @returns the new Color3\r\n */\r\n Color3.prototype.subtract = function (otherColor) {\r\n return new Color3(this.r - otherColor.r, this.g - otherColor.g, this.b - otherColor.b);\r\n };\r\n /**\r\n * Stores the result of the subtraction of given one from the current Color3 rgb values into \"result\"\r\n * @param otherColor defines the second operand\r\n * @param result defines Color3 object to store the result into\r\n * @returns the unmodified current Color3\r\n */\r\n Color3.prototype.subtractToRef = function (otherColor, result) {\r\n result.r = this.r - otherColor.r;\r\n result.g = this.g - otherColor.g;\r\n result.b = this.b - otherColor.b;\r\n return this;\r\n };\r\n /**\r\n * Copy the current object\r\n * @returns a new Color3 copied the current one\r\n */\r\n Color3.prototype.clone = function () {\r\n return new Color3(this.r, this.g, this.b);\r\n };\r\n /**\r\n * Copies the rgb values from the source in the current Color3\r\n * @param source defines the source Color3 object\r\n * @returns the updated Color3 object\r\n */\r\n Color3.prototype.copyFrom = function (source) {\r\n this.r = source.r;\r\n this.g = source.g;\r\n this.b = source.b;\r\n return this;\r\n };\r\n /**\r\n * Updates the Color3 rgb values from the given floats\r\n * @param r defines the red component to read from\r\n * @param g defines the green component to read from\r\n * @param b defines the blue component to read from\r\n * @returns the current Color3 object\r\n */\r\n Color3.prototype.copyFromFloats = function (r, g, b) {\r\n this.r = r;\r\n this.g = g;\r\n this.b = b;\r\n return this;\r\n };\r\n /**\r\n * Updates the Color3 rgb values from the given floats\r\n * @param r defines the red component to read from\r\n * @param g defines the green component to read from\r\n * @param b defines the blue component to read from\r\n * @returns the current Color3 object\r\n */\r\n Color3.prototype.set = function (r, g, b) {\r\n return this.copyFromFloats(r, g, b);\r\n };\r\n /**\r\n * Compute the Color3 hexadecimal code as a string\r\n * @returns a string containing the hexadecimal representation of the Color3 object\r\n */\r\n Color3.prototype.toHexString = function () {\r\n var intR = (this.r * 255) | 0;\r\n var intG = (this.g * 255) | 0;\r\n var intB = (this.b * 255) | 0;\r\n return \"#\" + Scalar.ToHex(intR) + Scalar.ToHex(intG) + Scalar.ToHex(intB);\r\n };\r\n /**\r\n * Computes a new Color3 converted from the current one to linear space\r\n * @returns a new Color3 object\r\n */\r\n Color3.prototype.toLinearSpace = function () {\r\n var convertedColor = new Color3();\r\n this.toLinearSpaceToRef(convertedColor);\r\n return convertedColor;\r\n };\r\n /**\r\n * Converts current color in rgb space to HSV values\r\n * @returns a new color3 representing the HSV values\r\n */\r\n Color3.prototype.toHSV = function () {\r\n var result = new Color3();\r\n this.toHSVToRef(result);\r\n return result;\r\n };\r\n /**\r\n * Converts current color in rgb space to HSV values\r\n * @param result defines the Color3 where to store the HSV values\r\n */\r\n Color3.prototype.toHSVToRef = function (result) {\r\n var r = this.r;\r\n var g = this.g;\r\n var b = this.b;\r\n var max = Math.max(r, g, b);\r\n var min = Math.min(r, g, b);\r\n var h = 0;\r\n var s = 0;\r\n var v = max;\r\n var dm = max - min;\r\n if (max !== 0) {\r\n s = dm / max;\r\n }\r\n if (max != min) {\r\n if (max == r) {\r\n h = (g - b) / dm;\r\n if (g < b) {\r\n h += 6;\r\n }\r\n }\r\n else if (max == g) {\r\n h = (b - r) / dm + 2;\r\n }\r\n else if (max == b) {\r\n h = (r - g) / dm + 4;\r\n }\r\n h *= 60;\r\n }\r\n result.r = h;\r\n result.g = s;\r\n result.b = v;\r\n };\r\n /**\r\n * Converts the Color3 values to linear space and stores the result in \"convertedColor\"\r\n * @param convertedColor defines the Color3 object where to store the linear space version\r\n * @returns the unmodified Color3\r\n */\r\n Color3.prototype.toLinearSpaceToRef = function (convertedColor) {\r\n convertedColor.r = Math.pow(this.r, ToLinearSpace);\r\n convertedColor.g = Math.pow(this.g, ToLinearSpace);\r\n convertedColor.b = Math.pow(this.b, ToLinearSpace);\r\n return this;\r\n };\r\n /**\r\n * Computes a new Color3 converted from the current one to gamma space\r\n * @returns a new Color3 object\r\n */\r\n Color3.prototype.toGammaSpace = function () {\r\n var convertedColor = new Color3();\r\n this.toGammaSpaceToRef(convertedColor);\r\n return convertedColor;\r\n };\r\n /**\r\n * Converts the Color3 values to gamma space and stores the result in \"convertedColor\"\r\n * @param convertedColor defines the Color3 object where to store the gamma space version\r\n * @returns the unmodified Color3\r\n */\r\n Color3.prototype.toGammaSpaceToRef = function (convertedColor) {\r\n convertedColor.r = Math.pow(this.r, ToGammaSpace);\r\n convertedColor.g = Math.pow(this.g, ToGammaSpace);\r\n convertedColor.b = Math.pow(this.b, ToGammaSpace);\r\n return this;\r\n };\r\n /**\r\n * Convert Hue, saturation and value to a Color3 (RGB)\r\n * @param hue defines the hue\r\n * @param saturation defines the saturation\r\n * @param value defines the value\r\n * @param result defines the Color3 where to store the RGB values\r\n */\r\n Color3.HSVtoRGBToRef = function (hue, saturation, value, result) {\r\n var chroma = value * saturation;\r\n var h = hue / 60;\r\n var x = chroma * (1 - Math.abs((h % 2) - 1));\r\n var r = 0;\r\n var g = 0;\r\n var b = 0;\r\n if (h >= 0 && h <= 1) {\r\n r = chroma;\r\n g = x;\r\n }\r\n else if (h >= 1 && h <= 2) {\r\n r = x;\r\n g = chroma;\r\n }\r\n else if (h >= 2 && h <= 3) {\r\n g = chroma;\r\n b = x;\r\n }\r\n else if (h >= 3 && h <= 4) {\r\n g = x;\r\n b = chroma;\r\n }\r\n else if (h >= 4 && h <= 5) {\r\n r = x;\r\n b = chroma;\r\n }\r\n else if (h >= 5 && h <= 6) {\r\n r = chroma;\r\n b = x;\r\n }\r\n var m = value - chroma;\r\n result.set((r + m), (g + m), (b + m));\r\n };\r\n /**\r\n * Creates a new Color3 from the string containing valid hexadecimal values\r\n * @param hex defines a string containing valid hexadecimal values\r\n * @returns a new Color3 object\r\n */\r\n Color3.FromHexString = function (hex) {\r\n if (hex.substring(0, 1) !== \"#\" || hex.length !== 7) {\r\n return new Color3(0, 0, 0);\r\n }\r\n var r = parseInt(hex.substring(1, 3), 16);\r\n var g = parseInt(hex.substring(3, 5), 16);\r\n var b = parseInt(hex.substring(5, 7), 16);\r\n return Color3.FromInts(r, g, b);\r\n };\r\n /**\r\n * Creates a new Color3 from the starting index of the given array\r\n * @param array defines the source array\r\n * @param offset defines an offset in the source array\r\n * @returns a new Color3 object\r\n */\r\n Color3.FromArray = function (array, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n return new Color3(array[offset], array[offset + 1], array[offset + 2]);\r\n };\r\n /**\r\n * Creates a new Color3 from the starting index element of the given array\r\n * @param array defines the source array to read from\r\n * @param offset defines the offset in the source array\r\n * @param result defines the target Color3 object\r\n */\r\n Color3.FromArrayToRef = function (array, offset, result) {\r\n if (offset === void 0) { offset = 0; }\r\n result.r = array[offset];\r\n result.g = array[offset + 1];\r\n result.b = array[offset + 2];\r\n };\r\n /**\r\n * Creates a new Color3 from integer values (< 256)\r\n * @param r defines the red component to read from (value between 0 and 255)\r\n * @param g defines the green component to read from (value between 0 and 255)\r\n * @param b defines the blue component to read from (value between 0 and 255)\r\n * @returns a new Color3 object\r\n */\r\n Color3.FromInts = function (r, g, b) {\r\n return new Color3(r / 255.0, g / 255.0, b / 255.0);\r\n };\r\n /**\r\n * Creates a new Color3 with values linearly interpolated of \"amount\" between the start Color3 and the end Color3\r\n * @param start defines the start Color3 value\r\n * @param end defines the end Color3 value\r\n * @param amount defines the gradient value between start and end\r\n * @returns a new Color3 object\r\n */\r\n Color3.Lerp = function (start, end, amount) {\r\n var result = new Color3(0.0, 0.0, 0.0);\r\n Color3.LerpToRef(start, end, amount, result);\r\n return result;\r\n };\r\n /**\r\n * Creates a new Color3 with values linearly interpolated of \"amount\" between the start Color3 and the end Color3\r\n * @param left defines the start value\r\n * @param right defines the end value\r\n * @param amount defines the gradient factor\r\n * @param result defines the Color3 object where to store the result\r\n */\r\n Color3.LerpToRef = function (left, right, amount, result) {\r\n result.r = left.r + ((right.r - left.r) * amount);\r\n result.g = left.g + ((right.g - left.g) * amount);\r\n result.b = left.b + ((right.b - left.b) * amount);\r\n };\r\n /**\r\n * Returns a Color3 value containing a red color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Red = function () { return new Color3(1, 0, 0); };\r\n /**\r\n * Returns a Color3 value containing a green color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Green = function () { return new Color3(0, 1, 0); };\r\n /**\r\n * Returns a Color3 value containing a blue color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Blue = function () { return new Color3(0, 0, 1); };\r\n /**\r\n * Returns a Color3 value containing a black color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Black = function () { return new Color3(0, 0, 0); };\r\n Object.defineProperty(Color3, \"BlackReadOnly\", {\r\n /**\r\n * Gets a Color3 value containing a black color that must not be updated\r\n */\r\n get: function () {\r\n return Color3._BlackReadOnly;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Returns a Color3 value containing a white color\r\n * @returns a new Color3 object\r\n */\r\n Color3.White = function () { return new Color3(1, 1, 1); };\r\n /**\r\n * Returns a Color3 value containing a purple color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Purple = function () { return new Color3(0.5, 0, 0.5); };\r\n /**\r\n * Returns a Color3 value containing a magenta color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Magenta = function () { return new Color3(1, 0, 1); };\r\n /**\r\n * Returns a Color3 value containing a yellow color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Yellow = function () { return new Color3(1, 1, 0); };\r\n /**\r\n * Returns a Color3 value containing a gray color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Gray = function () { return new Color3(0.5, 0.5, 0.5); };\r\n /**\r\n * Returns a Color3 value containing a teal color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Teal = function () { return new Color3(0, 1.0, 1.0); };\r\n /**\r\n * Returns a Color3 value containing a random color\r\n * @returns a new Color3 object\r\n */\r\n Color3.Random = function () { return new Color3(Math.random(), Math.random(), Math.random()); };\r\n // Statics\r\n Color3._BlackReadOnly = Color3.Black();\r\n return Color3;\r\n}());\r\nexport { Color3 };\r\n/**\r\n * Class used to hold a RBGA color\r\n */\r\nvar Color4 = /** @class */ (function () {\r\n /**\r\n * Creates a new Color4 object from red, green, blue values, all between 0 and 1\r\n * @param r defines the red component (between 0 and 1, default is 0)\r\n * @param g defines the green component (between 0 and 1, default is 0)\r\n * @param b defines the blue component (between 0 and 1, default is 0)\r\n * @param a defines the alpha component (between 0 and 1, default is 1)\r\n */\r\n function Color4(\r\n /**\r\n * Defines the red component (between 0 and 1, default is 0)\r\n */\r\n r, \r\n /**\r\n * Defines the green component (between 0 and 1, default is 0)\r\n */\r\n g, \r\n /**\r\n * Defines the blue component (between 0 and 1, default is 0)\r\n */\r\n b, \r\n /**\r\n * Defines the alpha component (between 0 and 1, default is 1)\r\n */\r\n a) {\r\n if (r === void 0) { r = 0; }\r\n if (g === void 0) { g = 0; }\r\n if (b === void 0) { b = 0; }\r\n if (a === void 0) { a = 1; }\r\n this.r = r;\r\n this.g = g;\r\n this.b = b;\r\n this.a = a;\r\n }\r\n // Operators\r\n /**\r\n * Adds in place the given Color4 values to the current Color4 object\r\n * @param right defines the second operand\r\n * @returns the current updated Color4 object\r\n */\r\n Color4.prototype.addInPlace = function (right) {\r\n this.r += right.r;\r\n this.g += right.g;\r\n this.b += right.b;\r\n this.a += right.a;\r\n return this;\r\n };\r\n /**\r\n * Creates a new array populated with 4 numeric elements : red, green, blue, alpha values\r\n * @returns the new array\r\n */\r\n Color4.prototype.asArray = function () {\r\n var result = new Array();\r\n this.toArray(result, 0);\r\n return result;\r\n };\r\n /**\r\n * Stores from the starting index in the given array the Color4 successive values\r\n * @param array defines the array where to store the r,g,b components\r\n * @param index defines an optional index in the target array to define where to start storing values\r\n * @returns the current Color4 object\r\n */\r\n Color4.prototype.toArray = function (array, index) {\r\n if (index === void 0) { index = 0; }\r\n array[index] = this.r;\r\n array[index + 1] = this.g;\r\n array[index + 2] = this.b;\r\n array[index + 3] = this.a;\r\n return this;\r\n };\r\n /**\r\n * Update the current color with values stored in an array from the starting index of the given array\r\n * @param array defines the source array\r\n * @param offset defines an offset in the source array\r\n * @returns the current Color4 object\r\n */\r\n Color4.prototype.fromArray = function (array, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n Color4.FromArrayToRef(array, offset, this);\r\n return this;\r\n };\r\n /**\r\n * Determines equality between Color4 objects\r\n * @param otherColor defines the second operand\r\n * @returns true if the rgba values are equal to the given ones\r\n */\r\n Color4.prototype.equals = function (otherColor) {\r\n return otherColor && this.r === otherColor.r && this.g === otherColor.g && this.b === otherColor.b && this.a === otherColor.a;\r\n };\r\n /**\r\n * Creates a new Color4 set with the added values of the current Color4 and of the given one\r\n * @param right defines the second operand\r\n * @returns a new Color4 object\r\n */\r\n Color4.prototype.add = function (right) {\r\n return new Color4(this.r + right.r, this.g + right.g, this.b + right.b, this.a + right.a);\r\n };\r\n /**\r\n * Creates a new Color4 set with the subtracted values of the given one from the current Color4\r\n * @param right defines the second operand\r\n * @returns a new Color4 object\r\n */\r\n Color4.prototype.subtract = function (right) {\r\n return new Color4(this.r - right.r, this.g - right.g, this.b - right.b, this.a - right.a);\r\n };\r\n /**\r\n * Subtracts the given ones from the current Color4 values and stores the results in \"result\"\r\n * @param right defines the second operand\r\n * @param result defines the Color4 object where to store the result\r\n * @returns the current Color4 object\r\n */\r\n Color4.prototype.subtractToRef = function (right, result) {\r\n result.r = this.r - right.r;\r\n result.g = this.g - right.g;\r\n result.b = this.b - right.b;\r\n result.a = this.a - right.a;\r\n return this;\r\n };\r\n /**\r\n * Creates a new Color4 with the current Color4 values multiplied by scale\r\n * @param scale defines the scaling factor to apply\r\n * @returns a new Color4 object\r\n */\r\n Color4.prototype.scale = function (scale) {\r\n return new Color4(this.r * scale, this.g * scale, this.b * scale, this.a * scale);\r\n };\r\n /**\r\n * Multiplies the current Color4 values by scale and stores the result in \"result\"\r\n * @param scale defines the scaling factor to apply\r\n * @param result defines the Color4 object where to store the result\r\n * @returns the current unmodified Color4\r\n */\r\n Color4.prototype.scaleToRef = function (scale, result) {\r\n result.r = this.r * scale;\r\n result.g = this.g * scale;\r\n result.b = this.b * scale;\r\n result.a = this.a * scale;\r\n return this;\r\n };\r\n /**\r\n * Scale the current Color4 values by a factor and add the result to a given Color4\r\n * @param scale defines the scale factor\r\n * @param result defines the Color4 object where to store the result\r\n * @returns the unmodified current Color4\r\n */\r\n Color4.prototype.scaleAndAddToRef = function (scale, result) {\r\n result.r += this.r * scale;\r\n result.g += this.g * scale;\r\n result.b += this.b * scale;\r\n result.a += this.a * scale;\r\n return this;\r\n };\r\n /**\r\n * Clamps the rgb values by the min and max values and stores the result into \"result\"\r\n * @param min defines minimum clamping value (default is 0)\r\n * @param max defines maximum clamping value (default is 1)\r\n * @param result defines color to store the result into.\r\n * @returns the cuurent Color4\r\n */\r\n Color4.prototype.clampToRef = function (min, max, result) {\r\n if (min === void 0) { min = 0; }\r\n if (max === void 0) { max = 1; }\r\n result.r = Scalar.Clamp(this.r, min, max);\r\n result.g = Scalar.Clamp(this.g, min, max);\r\n result.b = Scalar.Clamp(this.b, min, max);\r\n result.a = Scalar.Clamp(this.a, min, max);\r\n return this;\r\n };\r\n /**\r\n * Multipy an Color4 value by another and return a new Color4 object\r\n * @param color defines the Color4 value to multiply by\r\n * @returns a new Color4 object\r\n */\r\n Color4.prototype.multiply = function (color) {\r\n return new Color4(this.r * color.r, this.g * color.g, this.b * color.b, this.a * color.a);\r\n };\r\n /**\r\n * Multipy a Color4 value by another and push the result in a reference value\r\n * @param color defines the Color4 value to multiply by\r\n * @param result defines the Color4 to fill the result in\r\n * @returns the result Color4\r\n */\r\n Color4.prototype.multiplyToRef = function (color, result) {\r\n result.r = this.r * color.r;\r\n result.g = this.g * color.g;\r\n result.b = this.b * color.b;\r\n result.a = this.a * color.a;\r\n return result;\r\n };\r\n /**\r\n * Creates a string with the Color4 current values\r\n * @returns the string representation of the Color4 object\r\n */\r\n Color4.prototype.toString = function () {\r\n return \"{R: \" + this.r + \" G:\" + this.g + \" B:\" + this.b + \" A:\" + this.a + \"}\";\r\n };\r\n /**\r\n * Returns the string \"Color4\"\r\n * @returns \"Color4\"\r\n */\r\n Color4.prototype.getClassName = function () {\r\n return \"Color4\";\r\n };\r\n /**\r\n * Compute the Color4 hash code\r\n * @returns an unique number that can be used to hash Color4 objects\r\n */\r\n Color4.prototype.getHashCode = function () {\r\n var hash = (this.r * 255) | 0;\r\n hash = (hash * 397) ^ ((this.g * 255) | 0);\r\n hash = (hash * 397) ^ ((this.b * 255) | 0);\r\n hash = (hash * 397) ^ ((this.a * 255) | 0);\r\n return hash;\r\n };\r\n /**\r\n * Creates a new Color4 copied from the current one\r\n * @returns a new Color4 object\r\n */\r\n Color4.prototype.clone = function () {\r\n return new Color4(this.r, this.g, this.b, this.a);\r\n };\r\n /**\r\n * Copies the given Color4 values into the current one\r\n * @param source defines the source Color4 object\r\n * @returns the current updated Color4 object\r\n */\r\n Color4.prototype.copyFrom = function (source) {\r\n this.r = source.r;\r\n this.g = source.g;\r\n this.b = source.b;\r\n this.a = source.a;\r\n return this;\r\n };\r\n /**\r\n * Copies the given float values into the current one\r\n * @param r defines the red component to read from\r\n * @param g defines the green component to read from\r\n * @param b defines the blue component to read from\r\n * @param a defines the alpha component to read from\r\n * @returns the current updated Color4 object\r\n */\r\n Color4.prototype.copyFromFloats = function (r, g, b, a) {\r\n this.r = r;\r\n this.g = g;\r\n this.b = b;\r\n this.a = a;\r\n return this;\r\n };\r\n /**\r\n * Copies the given float values into the current one\r\n * @param r defines the red component to read from\r\n * @param g defines the green component to read from\r\n * @param b defines the blue component to read from\r\n * @param a defines the alpha component to read from\r\n * @returns the current updated Color4 object\r\n */\r\n Color4.prototype.set = function (r, g, b, a) {\r\n return this.copyFromFloats(r, g, b, a);\r\n };\r\n /**\r\n * Compute the Color4 hexadecimal code as a string\r\n * @param returnAsColor3 defines if the string should only contains RGB values (off by default)\r\n * @returns a string containing the hexadecimal representation of the Color4 object\r\n */\r\n Color4.prototype.toHexString = function (returnAsColor3) {\r\n if (returnAsColor3 === void 0) { returnAsColor3 = false; }\r\n var intR = (this.r * 255) | 0;\r\n var intG = (this.g * 255) | 0;\r\n var intB = (this.b * 255) | 0;\r\n if (returnAsColor3) {\r\n return \"#\" + Scalar.ToHex(intR) + Scalar.ToHex(intG) + Scalar.ToHex(intB);\r\n }\r\n var intA = (this.a * 255) | 0;\r\n return \"#\" + Scalar.ToHex(intR) + Scalar.ToHex(intG) + Scalar.ToHex(intB) + Scalar.ToHex(intA);\r\n };\r\n /**\r\n * Computes a new Color4 converted from the current one to linear space\r\n * @returns a new Color4 object\r\n */\r\n Color4.prototype.toLinearSpace = function () {\r\n var convertedColor = new Color4();\r\n this.toLinearSpaceToRef(convertedColor);\r\n return convertedColor;\r\n };\r\n /**\r\n * Converts the Color4 values to linear space and stores the result in \"convertedColor\"\r\n * @param convertedColor defines the Color4 object where to store the linear space version\r\n * @returns the unmodified Color4\r\n */\r\n Color4.prototype.toLinearSpaceToRef = function (convertedColor) {\r\n convertedColor.r = Math.pow(this.r, ToLinearSpace);\r\n convertedColor.g = Math.pow(this.g, ToLinearSpace);\r\n convertedColor.b = Math.pow(this.b, ToLinearSpace);\r\n convertedColor.a = this.a;\r\n return this;\r\n };\r\n /**\r\n * Computes a new Color4 converted from the current one to gamma space\r\n * @returns a new Color4 object\r\n */\r\n Color4.prototype.toGammaSpace = function () {\r\n var convertedColor = new Color4();\r\n this.toGammaSpaceToRef(convertedColor);\r\n return convertedColor;\r\n };\r\n /**\r\n * Converts the Color4 values to gamma space and stores the result in \"convertedColor\"\r\n * @param convertedColor defines the Color4 object where to store the gamma space version\r\n * @returns the unmodified Color4\r\n */\r\n Color4.prototype.toGammaSpaceToRef = function (convertedColor) {\r\n convertedColor.r = Math.pow(this.r, ToGammaSpace);\r\n convertedColor.g = Math.pow(this.g, ToGammaSpace);\r\n convertedColor.b = Math.pow(this.b, ToGammaSpace);\r\n convertedColor.a = this.a;\r\n return this;\r\n };\r\n // Statics\r\n /**\r\n * Creates a new Color4 from the string containing valid hexadecimal values\r\n * @param hex defines a string containing valid hexadecimal values\r\n * @returns a new Color4 object\r\n */\r\n Color4.FromHexString = function (hex) {\r\n if (hex.substring(0, 1) !== \"#\" || hex.length !== 9) {\r\n return new Color4(0.0, 0.0, 0.0, 0.0);\r\n }\r\n var r = parseInt(hex.substring(1, 3), 16);\r\n var g = parseInt(hex.substring(3, 5), 16);\r\n var b = parseInt(hex.substring(5, 7), 16);\r\n var a = parseInt(hex.substring(7, 9), 16);\r\n return Color4.FromInts(r, g, b, a);\r\n };\r\n /**\r\n * Creates a new Color4 object set with the linearly interpolated values of \"amount\" between the left Color4 object and the right Color4 object\r\n * @param left defines the start value\r\n * @param right defines the end value\r\n * @param amount defines the gradient factor\r\n * @returns a new Color4 object\r\n */\r\n Color4.Lerp = function (left, right, amount) {\r\n var result = new Color4(0.0, 0.0, 0.0, 0.0);\r\n Color4.LerpToRef(left, right, amount, result);\r\n return result;\r\n };\r\n /**\r\n * Set the given \"result\" with the linearly interpolated values of \"amount\" between the left Color4 object and the right Color4 object\r\n * @param left defines the start value\r\n * @param right defines the end value\r\n * @param amount defines the gradient factor\r\n * @param result defines the Color4 object where to store data\r\n */\r\n Color4.LerpToRef = function (left, right, amount, result) {\r\n result.r = left.r + (right.r - left.r) * amount;\r\n result.g = left.g + (right.g - left.g) * amount;\r\n result.b = left.b + (right.b - left.b) * amount;\r\n result.a = left.a + (right.a - left.a) * amount;\r\n };\r\n /**\r\n * Creates a new Color4 from a Color3 and an alpha value\r\n * @param color3 defines the source Color3 to read from\r\n * @param alpha defines the alpha component (1.0 by default)\r\n * @returns a new Color4 object\r\n */\r\n Color4.FromColor3 = function (color3, alpha) {\r\n if (alpha === void 0) { alpha = 1.0; }\r\n return new Color4(color3.r, color3.g, color3.b, alpha);\r\n };\r\n /**\r\n * Creates a new Color4 from the starting index element of the given array\r\n * @param array defines the source array to read from\r\n * @param offset defines the offset in the source array\r\n * @returns a new Color4 object\r\n */\r\n Color4.FromArray = function (array, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n return new Color4(array[offset], array[offset + 1], array[offset + 2], array[offset + 3]);\r\n };\r\n /**\r\n * Creates a new Color4 from the starting index element of the given array\r\n * @param array defines the source array to read from\r\n * @param offset defines the offset in the source array\r\n * @param result defines the target Color4 object\r\n */\r\n Color4.FromArrayToRef = function (array, offset, result) {\r\n if (offset === void 0) { offset = 0; }\r\n result.r = array[offset];\r\n result.g = array[offset + 1];\r\n result.b = array[offset + 2];\r\n result.a = array[offset + 3];\r\n };\r\n /**\r\n * Creates a new Color3 from integer values (< 256)\r\n * @param r defines the red component to read from (value between 0 and 255)\r\n * @param g defines the green component to read from (value between 0 and 255)\r\n * @param b defines the blue component to read from (value between 0 and 255)\r\n * @param a defines the alpha component to read from (value between 0 and 255)\r\n * @returns a new Color3 object\r\n */\r\n Color4.FromInts = function (r, g, b, a) {\r\n return new Color4(r / 255.0, g / 255.0, b / 255.0, a / 255.0);\r\n };\r\n /**\r\n * Check the content of a given array and convert it to an array containing RGBA data\r\n * If the original array was already containing count * 4 values then it is returned directly\r\n * @param colors defines the array to check\r\n * @param count defines the number of RGBA data to expect\r\n * @returns an array containing count * 4 values (RGBA)\r\n */\r\n Color4.CheckColors4 = function (colors, count) {\r\n // Check if color3 was used\r\n if (colors.length === count * 3) {\r\n var colors4 = [];\r\n for (var index = 0; index < colors.length; index += 3) {\r\n var newIndex = (index / 3) * 4;\r\n colors4[newIndex] = colors[index];\r\n colors4[newIndex + 1] = colors[index + 1];\r\n colors4[newIndex + 2] = colors[index + 2];\r\n colors4[newIndex + 3] = 1.0;\r\n }\r\n return colors4;\r\n }\r\n return colors;\r\n };\r\n return Color4;\r\n}());\r\nexport { Color4 };\r\n/**\r\n * @hidden\r\n */\r\nvar TmpColors = /** @class */ (function () {\r\n function TmpColors() {\r\n }\r\n TmpColors.Color3 = ArrayTools.BuildArray(3, Color3.Black);\r\n TmpColors.Color4 = ArrayTools.BuildArray(3, function () { return new Color4(0, 0, 0, 0); });\r\n return TmpColors;\r\n}());\r\nexport { TmpColors };\r\n_TypeStore.RegisteredTypes[\"BABYLON.Color3\"] = Color3;\r\n_TypeStore.RegisteredTypes[\"BABYLON.Color4\"] = Color4;\r\n//# sourceMappingURL=math.color.js.map","/** @hidden */\r\nvar _DevTools = /** @class */ (function () {\r\n function _DevTools() {\r\n }\r\n _DevTools.WarnImport = function (name) {\r\n return name + \" needs to be imported before as it contains a side-effect required by your code.\";\r\n };\r\n return _DevTools;\r\n}());\r\nexport { _DevTools };\r\n//# sourceMappingURL=devTools.js.map","/** @hidden */\r\nvar _TypeStore = /** @class */ (function () {\r\n function _TypeStore() {\r\n }\r\n /** @hidden */\r\n _TypeStore.GetClass = function (fqdn) {\r\n if (this.RegisteredTypes && this.RegisteredTypes[fqdn]) {\r\n return this.RegisteredTypes[fqdn];\r\n }\r\n return null;\r\n };\r\n /** @hidden */\r\n _TypeStore.RegisteredTypes = {};\r\n return _TypeStore;\r\n}());\r\nexport { _TypeStore };\r\n//# sourceMappingURL=typeStore.js.map","import { __extends } from \"tslib\";\r\nimport { Vector2 } from \"../Maths/math.vector\";\r\n/**\r\n * Gather the list of pointer event types as constants.\r\n */\r\nvar PointerEventTypes = /** @class */ (function () {\r\n function PointerEventTypes() {\r\n }\r\n /**\r\n * The pointerdown event is fired when a pointer becomes active. For mouse, it is fired when the device transitions from no buttons depressed to at least one button depressed. For touch, it is fired when physical contact is made with the digitizer. For pen, it is fired when the stylus makes physical contact with the digitizer.\r\n */\r\n PointerEventTypes.POINTERDOWN = 0x01;\r\n /**\r\n * The pointerup event is fired when a pointer is no longer active.\r\n */\r\n PointerEventTypes.POINTERUP = 0x02;\r\n /**\r\n * The pointermove event is fired when a pointer changes coordinates.\r\n */\r\n PointerEventTypes.POINTERMOVE = 0x04;\r\n /**\r\n * The pointerwheel event is fired when a mouse wheel has been rotated.\r\n */\r\n PointerEventTypes.POINTERWHEEL = 0x08;\r\n /**\r\n * The pointerpick event is fired when a mesh or sprite has been picked by the pointer.\r\n */\r\n PointerEventTypes.POINTERPICK = 0x10;\r\n /**\r\n * The pointertap event is fired when a the object has been touched and released without drag.\r\n */\r\n PointerEventTypes.POINTERTAP = 0x20;\r\n /**\r\n * The pointerdoubletap event is fired when a the object has been touched and released twice without drag.\r\n */\r\n PointerEventTypes.POINTERDOUBLETAP = 0x40;\r\n return PointerEventTypes;\r\n}());\r\nexport { PointerEventTypes };\r\n/**\r\n * Base class of pointer info types.\r\n */\r\nvar PointerInfoBase = /** @class */ (function () {\r\n /**\r\n * Instantiates the base class of pointers info.\r\n * @param type Defines the type of event (PointerEventTypes)\r\n * @param event Defines the related dom event\r\n */\r\n function PointerInfoBase(\r\n /**\r\n * Defines the type of event (PointerEventTypes)\r\n */\r\n type, \r\n /**\r\n * Defines the related dom event\r\n */\r\n event) {\r\n this.type = type;\r\n this.event = event;\r\n }\r\n return PointerInfoBase;\r\n}());\r\nexport { PointerInfoBase };\r\n/**\r\n * This class is used to store pointer related info for the onPrePointerObservable event.\r\n * Set the skipOnPointerObservable property to true if you want the engine to stop any process after this event is triggered, even not calling onPointerObservable\r\n */\r\nvar PointerInfoPre = /** @class */ (function (_super) {\r\n __extends(PointerInfoPre, _super);\r\n /**\r\n * Instantiates a PointerInfoPre to store pointer related info to the onPrePointerObservable event.\r\n * @param type Defines the type of event (PointerEventTypes)\r\n * @param event Defines the related dom event\r\n * @param localX Defines the local x coordinates of the pointer when the event occured\r\n * @param localY Defines the local y coordinates of the pointer when the event occured\r\n */\r\n function PointerInfoPre(type, event, localX, localY) {\r\n var _this = _super.call(this, type, event) || this;\r\n /**\r\n * Ray from a pointer if availible (eg. 6dof controller)\r\n */\r\n _this.ray = null;\r\n _this.skipOnPointerObservable = false;\r\n _this.localPosition = new Vector2(localX, localY);\r\n return _this;\r\n }\r\n return PointerInfoPre;\r\n}(PointerInfoBase));\r\nexport { PointerInfoPre };\r\n/**\r\n * This type contains all the data related to a pointer event in Babylon.js.\r\n * The event member is an instance of PointerEvent for all types except PointerWheel and is of type MouseWheelEvent when type equals PointerWheel. The different event types can be found in the PointerEventTypes class.\r\n */\r\nvar PointerInfo = /** @class */ (function (_super) {\r\n __extends(PointerInfo, _super);\r\n /**\r\n * Instantiates a PointerInfo to store pointer related info to the onPointerObservable event.\r\n * @param type Defines the type of event (PointerEventTypes)\r\n * @param event Defines the related dom event\r\n * @param pickInfo Defines the picking info associated to the info (if any)\\\r\n */\r\n function PointerInfo(type, event, \r\n /**\r\n * Defines the picking info associated to the info (if any)\\\r\n */\r\n pickInfo) {\r\n var _this = _super.call(this, type, event) || this;\r\n _this.pickInfo = pickInfo;\r\n return _this;\r\n }\r\n return PointerInfo;\r\n}(PointerInfoBase));\r\nexport { PointerInfo };\r\n//# sourceMappingURL=pointerEvents.js.map","/**\r\n * Logger used througouht the application to allow configuration of\r\n * the log level required for the messages.\r\n */\r\nvar Logger = /** @class */ (function () {\r\n function Logger() {\r\n }\r\n Logger._AddLogEntry = function (entry) {\r\n Logger._LogCache = entry + Logger._LogCache;\r\n if (Logger.OnNewCacheEntry) {\r\n Logger.OnNewCacheEntry(entry);\r\n }\r\n };\r\n Logger._FormatMessage = function (message) {\r\n var padStr = function (i) { return (i < 10) ? \"0\" + i : \"\" + i; };\r\n var date = new Date();\r\n return \"[\" + padStr(date.getHours()) + \":\" + padStr(date.getMinutes()) + \":\" + padStr(date.getSeconds()) + \"]: \" + message;\r\n };\r\n Logger._LogDisabled = function (message) {\r\n // nothing to do\r\n };\r\n Logger._LogEnabled = function (message) {\r\n var formattedMessage = Logger._FormatMessage(message);\r\n console.log(\"BJS - \" + formattedMessage);\r\n var entry = \"
\" + formattedMessage + \"

\";\r\n Logger._AddLogEntry(entry);\r\n };\r\n Logger._WarnDisabled = function (message) {\r\n // nothing to do\r\n };\r\n Logger._WarnEnabled = function (message) {\r\n var formattedMessage = Logger._FormatMessage(message);\r\n console.warn(\"BJS - \" + formattedMessage);\r\n var entry = \"
\" + formattedMessage + \"

\";\r\n Logger._AddLogEntry(entry);\r\n };\r\n Logger._ErrorDisabled = function (message) {\r\n // nothing to do\r\n };\r\n Logger._ErrorEnabled = function (message) {\r\n Logger.errorsCount++;\r\n var formattedMessage = Logger._FormatMessage(message);\r\n console.error(\"BJS - \" + formattedMessage);\r\n var entry = \"
\" + formattedMessage + \"

\";\r\n Logger._AddLogEntry(entry);\r\n };\r\n Object.defineProperty(Logger, \"LogCache\", {\r\n /**\r\n * Gets current log cache (list of logs)\r\n */\r\n get: function () {\r\n return Logger._LogCache;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Clears the log cache\r\n */\r\n Logger.ClearLogCache = function () {\r\n Logger._LogCache = \"\";\r\n Logger.errorsCount = 0;\r\n };\r\n Object.defineProperty(Logger, \"LogLevels\", {\r\n /**\r\n * Sets the current log level (MessageLogLevel / WarningLogLevel / ErrorLogLevel)\r\n */\r\n set: function (level) {\r\n if ((level & Logger.MessageLogLevel) === Logger.MessageLogLevel) {\r\n Logger.Log = Logger._LogEnabled;\r\n }\r\n else {\r\n Logger.Log = Logger._LogDisabled;\r\n }\r\n if ((level & Logger.WarningLogLevel) === Logger.WarningLogLevel) {\r\n Logger.Warn = Logger._WarnEnabled;\r\n }\r\n else {\r\n Logger.Warn = Logger._WarnDisabled;\r\n }\r\n if ((level & Logger.ErrorLogLevel) === Logger.ErrorLogLevel) {\r\n Logger.Error = Logger._ErrorEnabled;\r\n }\r\n else {\r\n Logger.Error = Logger._ErrorDisabled;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * No log\r\n */\r\n Logger.NoneLogLevel = 0;\r\n /**\r\n * Only message logs\r\n */\r\n Logger.MessageLogLevel = 1;\r\n /**\r\n * Only warning logs\r\n */\r\n Logger.WarningLogLevel = 2;\r\n /**\r\n * Only error logs\r\n */\r\n Logger.ErrorLogLevel = 4;\r\n /**\r\n * All logs\r\n */\r\n Logger.AllLogLevel = 7;\r\n Logger._LogCache = \"\";\r\n /**\r\n * Gets a value indicating the number of loading errors\r\n * @ignorenaming\r\n */\r\n Logger.errorsCount = 0;\r\n /**\r\n * Log a message to the console\r\n */\r\n Logger.Log = Logger._LogEnabled;\r\n /**\r\n * Write a warning message to the console\r\n */\r\n Logger.Warn = Logger._WarnEnabled;\r\n /**\r\n * Write an error message to the console\r\n */\r\n Logger.Error = Logger._ErrorEnabled;\r\n return Logger;\r\n}());\r\nexport { Logger };\r\n//# sourceMappingURL=logger.js.map","var PromiseStates;\r\n(function (PromiseStates) {\r\n PromiseStates[PromiseStates[\"Pending\"] = 0] = \"Pending\";\r\n PromiseStates[PromiseStates[\"Fulfilled\"] = 1] = \"Fulfilled\";\r\n PromiseStates[PromiseStates[\"Rejected\"] = 2] = \"Rejected\";\r\n})(PromiseStates || (PromiseStates = {}));\r\nvar FulFillmentAgregator = /** @class */ (function () {\r\n function FulFillmentAgregator() {\r\n this.count = 0;\r\n this.target = 0;\r\n this.results = [];\r\n }\r\n return FulFillmentAgregator;\r\n}());\r\nvar InternalPromise = /** @class */ (function () {\r\n function InternalPromise(resolver) {\r\n var _this = this;\r\n this._state = PromiseStates.Pending;\r\n this._children = new Array();\r\n this._rejectWasConsumed = false;\r\n if (!resolver) {\r\n return;\r\n }\r\n try {\r\n resolver(function (value) {\r\n _this._resolve(value);\r\n }, function (reason) {\r\n _this._reject(reason);\r\n });\r\n }\r\n catch (e) {\r\n this._reject(e);\r\n }\r\n }\r\n Object.defineProperty(InternalPromise.prototype, \"_result\", {\r\n get: function () {\r\n return this._resultValue;\r\n },\r\n set: function (value) {\r\n this._resultValue = value;\r\n if (this._parent && this._parent._result === undefined) {\r\n this._parent._result = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n InternalPromise.prototype.catch = function (onRejected) {\r\n return this.then(undefined, onRejected);\r\n };\r\n InternalPromise.prototype.then = function (onFulfilled, onRejected) {\r\n var _this = this;\r\n var newPromise = new InternalPromise();\r\n newPromise._onFulfilled = onFulfilled;\r\n newPromise._onRejected = onRejected;\r\n // Composition\r\n this._children.push(newPromise);\r\n newPromise._parent = this;\r\n if (this._state !== PromiseStates.Pending) {\r\n setTimeout(function () {\r\n if (_this._state === PromiseStates.Fulfilled || _this._rejectWasConsumed) {\r\n var returnedValue = newPromise._resolve(_this._result);\r\n if (returnedValue !== undefined && returnedValue !== null) {\r\n if (returnedValue._state !== undefined) {\r\n var returnedPromise = returnedValue;\r\n newPromise._children.push(returnedPromise);\r\n returnedPromise._parent = newPromise;\r\n newPromise = returnedPromise;\r\n }\r\n else {\r\n newPromise._result = returnedValue;\r\n }\r\n }\r\n }\r\n else {\r\n newPromise._reject(_this._reason);\r\n }\r\n });\r\n }\r\n return newPromise;\r\n };\r\n InternalPromise.prototype._moveChildren = function (children) {\r\n var _a;\r\n var _this = this;\r\n (_a = this._children).push.apply(_a, children.splice(0, children.length));\r\n this._children.forEach(function (child) {\r\n child._parent = _this;\r\n });\r\n if (this._state === PromiseStates.Fulfilled) {\r\n for (var _i = 0, _b = this._children; _i < _b.length; _i++) {\r\n var child = _b[_i];\r\n child._resolve(this._result);\r\n }\r\n }\r\n else if (this._state === PromiseStates.Rejected) {\r\n for (var _c = 0, _d = this._children; _c < _d.length; _c++) {\r\n var child = _d[_c];\r\n child._reject(this._reason);\r\n }\r\n }\r\n };\r\n InternalPromise.prototype._resolve = function (value) {\r\n try {\r\n this._state = PromiseStates.Fulfilled;\r\n var returnedValue = null;\r\n if (this._onFulfilled) {\r\n returnedValue = this._onFulfilled(value);\r\n }\r\n if (returnedValue !== undefined && returnedValue !== null) {\r\n if (returnedValue._state !== undefined) {\r\n // Transmit children\r\n var returnedPromise = returnedValue;\r\n returnedPromise._parent = this;\r\n returnedPromise._moveChildren(this._children);\r\n value = returnedPromise._result;\r\n }\r\n else {\r\n value = returnedValue;\r\n }\r\n }\r\n this._result = value;\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child._resolve(value);\r\n }\r\n this._children.length = 0;\r\n delete this._onFulfilled;\r\n delete this._onRejected;\r\n }\r\n catch (e) {\r\n this._reject(e, true);\r\n }\r\n };\r\n InternalPromise.prototype._reject = function (reason, onLocalThrow) {\r\n if (onLocalThrow === void 0) { onLocalThrow = false; }\r\n this._state = PromiseStates.Rejected;\r\n this._reason = reason;\r\n if (this._onRejected && !onLocalThrow) {\r\n try {\r\n this._onRejected(reason);\r\n this._rejectWasConsumed = true;\r\n }\r\n catch (e) {\r\n reason = e;\r\n }\r\n }\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (this._rejectWasConsumed) {\r\n child._resolve(null);\r\n }\r\n else {\r\n child._reject(reason);\r\n }\r\n }\r\n this._children.length = 0;\r\n delete this._onFulfilled;\r\n delete this._onRejected;\r\n };\r\n InternalPromise.resolve = function (value) {\r\n var newPromise = new InternalPromise();\r\n newPromise._resolve(value);\r\n return newPromise;\r\n };\r\n InternalPromise._RegisterForFulfillment = function (promise, agregator, index) {\r\n promise.then(function (value) {\r\n agregator.results[index] = value;\r\n agregator.count++;\r\n if (agregator.count === agregator.target) {\r\n agregator.rootPromise._resolve(agregator.results);\r\n }\r\n return null;\r\n }, function (reason) {\r\n if (agregator.rootPromise._state !== PromiseStates.Rejected) {\r\n agregator.rootPromise._reject(reason);\r\n }\r\n });\r\n };\r\n InternalPromise.all = function (promises) {\r\n var newPromise = new InternalPromise();\r\n var agregator = new FulFillmentAgregator();\r\n agregator.target = promises.length;\r\n agregator.rootPromise = newPromise;\r\n if (promises.length) {\r\n for (var index = 0; index < promises.length; index++) {\r\n InternalPromise._RegisterForFulfillment(promises[index], agregator, index);\r\n }\r\n }\r\n else {\r\n newPromise._resolve([]);\r\n }\r\n return newPromise;\r\n };\r\n InternalPromise.race = function (promises) {\r\n var newPromise = new InternalPromise();\r\n if (promises.length) {\r\n for (var _i = 0, promises_1 = promises; _i < promises_1.length; _i++) {\r\n var promise = promises_1[_i];\r\n promise.then(function (value) {\r\n if (newPromise) {\r\n newPromise._resolve(value);\r\n newPromise = null;\r\n }\r\n return null;\r\n }, function (reason) {\r\n if (newPromise) {\r\n newPromise._reject(reason);\r\n newPromise = null;\r\n }\r\n });\r\n }\r\n }\r\n return newPromise;\r\n };\r\n return InternalPromise;\r\n}());\r\n/**\r\n * Helper class that provides a small promise polyfill\r\n */\r\nvar PromisePolyfill = /** @class */ (function () {\r\n function PromisePolyfill() {\r\n }\r\n /**\r\n * Static function used to check if the polyfill is required\r\n * If this is the case then the function will inject the polyfill to window.Promise\r\n * @param force defines a boolean used to force the injection (mostly for testing purposes)\r\n */\r\n PromisePolyfill.Apply = function (force) {\r\n if (force === void 0) { force = false; }\r\n if (force || typeof Promise === 'undefined') {\r\n var root = window;\r\n root.Promise = InternalPromise;\r\n }\r\n };\r\n return PromisePolyfill;\r\n}());\r\nexport { PromisePolyfill };\r\n//# sourceMappingURL=promise.js.map","import { Observable } from \"./observable\";\r\nimport { DomManagement } from \"./domManagement\";\r\nimport { Logger } from \"./logger\";\r\nimport { DeepCopier } from \"./deepCopier\";\r\nimport { PrecisionDate } from \"./precisionDate\";\r\nimport { _DevTools } from \"./devTools\";\r\nimport { WebRequest } from \"./webRequest\";\r\nimport { EngineStore } from \"../Engines/engineStore\";\r\nimport { FileTools } from \"./fileTools\";\r\nimport { PromisePolyfill } from \"./promise\";\r\nimport { TimingTools } from \"./timingTools\";\r\nimport { InstantiationTools } from \"./instantiationTools\";\r\nimport { GUID } from \"./guid\";\r\n/**\r\n * Class containing a set of static utilities functions\r\n */\r\nvar Tools = /** @class */ (function () {\r\n function Tools() {\r\n }\r\n Object.defineProperty(Tools, \"BaseUrl\", {\r\n /**\r\n * Gets or sets the base URL to use to load assets\r\n */\r\n get: function () {\r\n return FileTools.BaseUrl;\r\n },\r\n set: function (value) {\r\n FileTools.BaseUrl = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Tools, \"DefaultRetryStrategy\", {\r\n /**\r\n * Gets or sets the retry strategy to apply when an error happens while loading an asset\r\n */\r\n get: function () {\r\n return FileTools.DefaultRetryStrategy;\r\n },\r\n set: function (strategy) {\r\n FileTools.DefaultRetryStrategy = strategy;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Tools, \"CorsBehavior\", {\r\n /**\r\n * Default behaviour for cors in the application.\r\n * It can be a string if the expected behavior is identical in the entire app.\r\n * Or a callback to be able to set it per url or on a group of them (in case of Video source for instance)\r\n */\r\n get: function () {\r\n return FileTools.CorsBehavior;\r\n },\r\n set: function (value) {\r\n FileTools.CorsBehavior = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Tools, \"UseFallbackTexture\", {\r\n /**\r\n * Gets or sets a global variable indicating if fallback texture must be used when a texture cannot be loaded\r\n * @ignorenaming\r\n */\r\n get: function () {\r\n return EngineStore.UseFallbackTexture;\r\n },\r\n set: function (value) {\r\n EngineStore.UseFallbackTexture = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Tools, \"RegisteredExternalClasses\", {\r\n /**\r\n * Use this object to register external classes like custom textures or material\r\n * to allow the laoders to instantiate them\r\n */\r\n get: function () {\r\n return InstantiationTools.RegisteredExternalClasses;\r\n },\r\n set: function (classes) {\r\n InstantiationTools.RegisteredExternalClasses = classes;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Tools, \"fallbackTexture\", {\r\n /**\r\n * Texture content used if a texture cannot loaded\r\n * @ignorenaming\r\n */\r\n get: function () {\r\n return EngineStore.FallbackTexture;\r\n },\r\n set: function (value) {\r\n EngineStore.FallbackTexture = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Read the content of a byte array at a specified coordinates (taking in account wrapping)\r\n * @param u defines the coordinate on X axis\r\n * @param v defines the coordinate on Y axis\r\n * @param width defines the width of the source data\r\n * @param height defines the height of the source data\r\n * @param pixels defines the source byte array\r\n * @param color defines the output color\r\n */\r\n Tools.FetchToRef = function (u, v, width, height, pixels, color) {\r\n var wrappedU = (Math.abs(u) * width) % width | 0;\r\n var wrappedV = (Math.abs(v) * height) % height | 0;\r\n var position = (wrappedU + wrappedV * width) * 4;\r\n color.r = pixels[position] / 255;\r\n color.g = pixels[position + 1] / 255;\r\n color.b = pixels[position + 2] / 255;\r\n color.a = pixels[position + 3] / 255;\r\n };\r\n /**\r\n * Interpolates between a and b via alpha\r\n * @param a The lower value (returned when alpha = 0)\r\n * @param b The upper value (returned when alpha = 1)\r\n * @param alpha The interpolation-factor\r\n * @return The mixed value\r\n */\r\n Tools.Mix = function (a, b, alpha) {\r\n return a * (1 - alpha) + b * alpha;\r\n };\r\n /**\r\n * Tries to instantiate a new object from a given class name\r\n * @param className defines the class name to instantiate\r\n * @returns the new object or null if the system was not able to do the instantiation\r\n */\r\n Tools.Instantiate = function (className) {\r\n return InstantiationTools.Instantiate(className);\r\n };\r\n /**\r\n * Provides a slice function that will work even on IE\r\n * @param data defines the array to slice\r\n * @param start defines the start of the data (optional)\r\n * @param end defines the end of the data (optional)\r\n * @returns the new sliced array\r\n */\r\n Tools.Slice = function (data, start, end) {\r\n if (data.slice) {\r\n return data.slice(start, end);\r\n }\r\n return Array.prototype.slice.call(data, start, end);\r\n };\r\n /**\r\n * Provides a slice function that will work even on IE\r\n * The difference between this and Slice is that this will force-convert to array\r\n * @param data defines the array to slice\r\n * @param start defines the start of the data (optional)\r\n * @param end defines the end of the data (optional)\r\n * @returns the new sliced array\r\n */\r\n Tools.SliceToArray = function (data, start, end) {\r\n if (Array.isArray(data)) {\r\n return data.slice(start, end);\r\n }\r\n return Array.prototype.slice.call(data, start, end);\r\n };\r\n /**\r\n * Polyfill for setImmediate\r\n * @param action defines the action to execute after the current execution block\r\n */\r\n Tools.SetImmediate = function (action) {\r\n TimingTools.SetImmediate(action);\r\n };\r\n /**\r\n * Function indicating if a number is an exponent of 2\r\n * @param value defines the value to test\r\n * @returns true if the value is an exponent of 2\r\n */\r\n Tools.IsExponentOfTwo = function (value) {\r\n var count = 1;\r\n do {\r\n count *= 2;\r\n } while (count < value);\r\n return count === value;\r\n };\r\n /**\r\n * Returns the nearest 32-bit single precision float representation of a Number\r\n * @param value A Number. If the parameter is of a different type, it will get converted\r\n * to a number or to NaN if it cannot be converted\r\n * @returns number\r\n */\r\n Tools.FloatRound = function (value) {\r\n if (Math.fround) {\r\n return Math.fround(value);\r\n }\r\n return (Tools._tmpFloatArray[0] = value);\r\n };\r\n /**\r\n * Extracts the filename from a path\r\n * @param path defines the path to use\r\n * @returns the filename\r\n */\r\n Tools.GetFilename = function (path) {\r\n var index = path.lastIndexOf(\"/\");\r\n if (index < 0) {\r\n return path;\r\n }\r\n return path.substring(index + 1);\r\n };\r\n /**\r\n * Extracts the \"folder\" part of a path (everything before the filename).\r\n * @param uri The URI to extract the info from\r\n * @param returnUnchangedIfNoSlash Do not touch the URI if no slashes are present\r\n * @returns The \"folder\" part of the path\r\n */\r\n Tools.GetFolderPath = function (uri, returnUnchangedIfNoSlash) {\r\n if (returnUnchangedIfNoSlash === void 0) { returnUnchangedIfNoSlash = false; }\r\n var index = uri.lastIndexOf(\"/\");\r\n if (index < 0) {\r\n if (returnUnchangedIfNoSlash) {\r\n return uri;\r\n }\r\n return \"\";\r\n }\r\n return uri.substring(0, index + 1);\r\n };\r\n /**\r\n * Convert an angle in radians to degrees\r\n * @param angle defines the angle to convert\r\n * @returns the angle in degrees\r\n */\r\n Tools.ToDegrees = function (angle) {\r\n return (angle * 180) / Math.PI;\r\n };\r\n /**\r\n * Convert an angle in degrees to radians\r\n * @param angle defines the angle to convert\r\n * @returns the angle in radians\r\n */\r\n Tools.ToRadians = function (angle) {\r\n return (angle * Math.PI) / 180;\r\n };\r\n /**\r\n * Returns an array if obj is not an array\r\n * @param obj defines the object to evaluate as an array\r\n * @param allowsNullUndefined defines a boolean indicating if obj is allowed to be null or undefined\r\n * @returns either obj directly if obj is an array or a new array containing obj\r\n */\r\n Tools.MakeArray = function (obj, allowsNullUndefined) {\r\n if (allowsNullUndefined !== true && (obj === undefined || obj == null)) {\r\n return null;\r\n }\r\n return Array.isArray(obj) ? obj : [obj];\r\n };\r\n /**\r\n * Gets the pointer prefix to use\r\n * @param engine defines the engine we are finding the prefix for\r\n * @returns \"pointer\" if touch is enabled. Else returns \"mouse\"\r\n */\r\n Tools.GetPointerPrefix = function (engine) {\r\n var eventPrefix = \"pointer\";\r\n // Check if pointer events are supported\r\n if (DomManagement.IsWindowObjectExist() && !window.PointerEvent && DomManagement.IsNavigatorAvailable() && !navigator.pointerEnabled) {\r\n eventPrefix = \"mouse\";\r\n }\r\n // Special Fallback MacOS Safari...\r\n if (engine._badDesktopOS &&\r\n !engine._badOS &&\r\n // And not ipad pros who claim to be macs...\r\n !(document && \"ontouchend\" in document)) {\r\n eventPrefix = \"mouse\";\r\n }\r\n return eventPrefix;\r\n };\r\n /**\r\n * Sets the cors behavior on a dom element. This will add the required Tools.CorsBehavior to the element.\r\n * @param url define the url we are trying\r\n * @param element define the dom element where to configure the cors policy\r\n */\r\n Tools.SetCorsBehavior = function (url, element) {\r\n FileTools.SetCorsBehavior(url, element);\r\n };\r\n // External files\r\n /**\r\n * Removes unwanted characters from an url\r\n * @param url defines the url to clean\r\n * @returns the cleaned url\r\n */\r\n Tools.CleanUrl = function (url) {\r\n url = url.replace(/#/gm, \"%23\");\r\n return url;\r\n };\r\n Object.defineProperty(Tools, \"PreprocessUrl\", {\r\n /**\r\n * Gets or sets a function used to pre-process url before using them to load assets\r\n */\r\n get: function () {\r\n return FileTools.PreprocessUrl;\r\n },\r\n set: function (processor) {\r\n FileTools.PreprocessUrl = processor;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Loads an image as an HTMLImageElement.\r\n * @param input url string, ArrayBuffer, or Blob to load\r\n * @param onLoad callback called when the image successfully loads\r\n * @param onError callback called when the image fails to load\r\n * @param offlineProvider offline provider for caching\r\n * @param mimeType optional mime type\r\n * @returns the HTMLImageElement of the loaded image\r\n */\r\n Tools.LoadImage = function (input, onLoad, onError, offlineProvider, mimeType) {\r\n return FileTools.LoadImage(input, onLoad, onError, offlineProvider, mimeType);\r\n };\r\n /**\r\n * Loads a file from a url\r\n * @param url url string, ArrayBuffer, or Blob to load\r\n * @param onSuccess callback called when the file successfully loads\r\n * @param onProgress callback called while file is loading (if the server supports this mode)\r\n * @param offlineProvider defines the offline provider for caching\r\n * @param useArrayBuffer defines a boolean indicating that date must be returned as ArrayBuffer\r\n * @param onError callback called when the file fails to load\r\n * @returns a file request object\r\n */\r\n Tools.LoadFile = function (url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError) {\r\n return FileTools.LoadFile(url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError);\r\n };\r\n /**\r\n * Loads a file from a url\r\n * @param url the file url to load\r\n * @param useArrayBuffer defines a boolean indicating that date must be returned as ArrayBuffer\r\n * @returns a promise containing an ArrayBuffer corresponding to the loaded file\r\n */\r\n Tools.LoadFileAsync = function (url, useArrayBuffer) {\r\n if (useArrayBuffer === void 0) { useArrayBuffer = true; }\r\n return new Promise(function (resolve, reject) {\r\n FileTools.LoadFile(url, function (data) {\r\n resolve(data);\r\n }, undefined, undefined, useArrayBuffer, function (request, exception) {\r\n reject(exception);\r\n });\r\n });\r\n };\r\n /**\r\n * Load a script (identified by an url). When the url returns, the\r\n * content of this file is added into a new script element, attached to the DOM (body element)\r\n * @param scriptUrl defines the url of the script to laod\r\n * @param onSuccess defines the callback called when the script is loaded\r\n * @param onError defines the callback to call if an error occurs\r\n * @param scriptId defines the id of the script element\r\n */\r\n Tools.LoadScript = function (scriptUrl, onSuccess, onError, scriptId) {\r\n if (!DomManagement.IsWindowObjectExist()) {\r\n return;\r\n }\r\n var head = document.getElementsByTagName(\"head\")[0];\r\n var script = document.createElement(\"script\");\r\n script.setAttribute(\"type\", \"text/javascript\");\r\n script.setAttribute(\"src\", scriptUrl);\r\n if (scriptId) {\r\n script.id = scriptId;\r\n }\r\n script.onload = function () {\r\n if (onSuccess) {\r\n onSuccess();\r\n }\r\n };\r\n script.onerror = function (e) {\r\n if (onError) {\r\n onError(\"Unable to load script '\" + scriptUrl + \"'\", e);\r\n }\r\n };\r\n head.appendChild(script);\r\n };\r\n /**\r\n * Load an asynchronous script (identified by an url). When the url returns, the\r\n * content of this file is added into a new script element, attached to the DOM (body element)\r\n * @param scriptUrl defines the url of the script to laod\r\n * @param scriptId defines the id of the script element\r\n * @returns a promise request object\r\n */\r\n Tools.LoadScriptAsync = function (scriptUrl, scriptId) {\r\n var _this = this;\r\n return new Promise(function (resolve, reject) {\r\n _this.LoadScript(scriptUrl, function () {\r\n resolve();\r\n }, function (message, exception) {\r\n reject(exception);\r\n });\r\n });\r\n };\r\n /**\r\n * Loads a file from a blob\r\n * @param fileToLoad defines the blob to use\r\n * @param callback defines the callback to call when data is loaded\r\n * @param progressCallback defines the callback to call during loading process\r\n * @returns a file request object\r\n */\r\n Tools.ReadFileAsDataURL = function (fileToLoad, callback, progressCallback) {\r\n var reader = new FileReader();\r\n var request = {\r\n onCompleteObservable: new Observable(),\r\n abort: function () { return reader.abort(); },\r\n };\r\n reader.onloadend = function (e) {\r\n request.onCompleteObservable.notifyObservers(request);\r\n };\r\n reader.onload = function (e) {\r\n //target doesn't have result from ts 1.3\r\n callback(e.target[\"result\"]);\r\n };\r\n reader.onprogress = progressCallback;\r\n reader.readAsDataURL(fileToLoad);\r\n return request;\r\n };\r\n /**\r\n * Reads a file from a File object\r\n * @param file defines the file to load\r\n * @param onSuccess defines the callback to call when data is loaded\r\n * @param onProgress defines the callback to call during loading process\r\n * @param useArrayBuffer defines a boolean indicating that data must be returned as an ArrayBuffer\r\n * @param onError defines the callback to call when an error occurs\r\n * @returns a file request object\r\n */\r\n Tools.ReadFile = function (file, onSuccess, onProgress, useArrayBuffer, onError) {\r\n return FileTools.ReadFile(file, onSuccess, onProgress, useArrayBuffer, onError);\r\n };\r\n /**\r\n * Creates a data url from a given string content\r\n * @param content defines the content to convert\r\n * @returns the new data url link\r\n */\r\n Tools.FileAsURL = function (content) {\r\n var fileBlob = new Blob([content]);\r\n var url = window.URL || window.webkitURL;\r\n var link = url.createObjectURL(fileBlob);\r\n return link;\r\n };\r\n /**\r\n * Format the given number to a specific decimal format\r\n * @param value defines the number to format\r\n * @param decimals defines the number of decimals to use\r\n * @returns the formatted string\r\n */\r\n Tools.Format = function (value, decimals) {\r\n if (decimals === void 0) { decimals = 2; }\r\n return value.toFixed(decimals);\r\n };\r\n /**\r\n * Tries to copy an object by duplicating every property\r\n * @param source defines the source object\r\n * @param destination defines the target object\r\n * @param doNotCopyList defines a list of properties to avoid\r\n * @param mustCopyList defines a list of properties to copy (even if they start with _)\r\n */\r\n Tools.DeepCopy = function (source, destination, doNotCopyList, mustCopyList) {\r\n DeepCopier.DeepCopy(source, destination, doNotCopyList, mustCopyList);\r\n };\r\n /**\r\n * Gets a boolean indicating if the given object has no own property\r\n * @param obj defines the object to test\r\n * @returns true if object has no own property\r\n */\r\n Tools.IsEmpty = function (obj) {\r\n for (var i in obj) {\r\n if (obj.hasOwnProperty(i)) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Function used to register events at window level\r\n * @param windowElement defines the Window object to use\r\n * @param events defines the events to register\r\n */\r\n Tools.RegisterTopRootEvents = function (windowElement, events) {\r\n for (var index = 0; index < events.length; index++) {\r\n var event = events[index];\r\n windowElement.addEventListener(event.name, event.handler, false);\r\n try {\r\n if (window.parent) {\r\n window.parent.addEventListener(event.name, event.handler, false);\r\n }\r\n }\r\n catch (e) {\r\n // Silently fails...\r\n }\r\n }\r\n };\r\n /**\r\n * Function used to unregister events from window level\r\n * @param windowElement defines the Window object to use\r\n * @param events defines the events to unregister\r\n */\r\n Tools.UnregisterTopRootEvents = function (windowElement, events) {\r\n for (var index = 0; index < events.length; index++) {\r\n var event = events[index];\r\n windowElement.removeEventListener(event.name, event.handler);\r\n try {\r\n if (windowElement.parent) {\r\n windowElement.parent.removeEventListener(event.name, event.handler);\r\n }\r\n }\r\n catch (e) {\r\n // Silently fails...\r\n }\r\n }\r\n };\r\n /**\r\n * Dumps the current bound framebuffer\r\n * @param width defines the rendering width\r\n * @param height defines the rendering height\r\n * @param engine defines the hosting engine\r\n * @param successCallback defines the callback triggered once the data are available\r\n * @param mimeType defines the mime type of the result\r\n * @param fileName defines the filename to download. If present, the result will automatically be downloaded\r\n */\r\n Tools.DumpFramebuffer = function (width, height, engine, successCallback, mimeType, fileName) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n // Read the contents of the framebuffer\r\n var numberOfChannelsByLine = width * 4;\r\n var halfHeight = height / 2;\r\n //Reading datas from WebGL\r\n var data = engine.readPixels(0, 0, width, height);\r\n //To flip image on Y axis.\r\n for (var i = 0; i < halfHeight; i++) {\r\n for (var j = 0; j < numberOfChannelsByLine; j++) {\r\n var currentCell = j + i * numberOfChannelsByLine;\r\n var targetLine = height - i - 1;\r\n var targetCell = j + targetLine * numberOfChannelsByLine;\r\n var temp = data[currentCell];\r\n data[currentCell] = data[targetCell];\r\n data[targetCell] = temp;\r\n }\r\n }\r\n // Create a 2D canvas to store the result\r\n if (!Tools._ScreenshotCanvas) {\r\n Tools._ScreenshotCanvas = document.createElement(\"canvas\");\r\n }\r\n Tools._ScreenshotCanvas.width = width;\r\n Tools._ScreenshotCanvas.height = height;\r\n var context = Tools._ScreenshotCanvas.getContext(\"2d\");\r\n if (context) {\r\n // Copy the pixels to a 2D canvas\r\n var imageData = context.createImageData(width, height);\r\n var castData = imageData.data;\r\n castData.set(data);\r\n context.putImageData(imageData, 0, 0);\r\n Tools.EncodeScreenshotCanvasData(successCallback, mimeType, fileName);\r\n }\r\n };\r\n /**\r\n * Converts the canvas data to blob.\r\n * This acts as a polyfill for browsers not supporting the to blob function.\r\n * @param canvas Defines the canvas to extract the data from\r\n * @param successCallback Defines the callback triggered once the data are available\r\n * @param mimeType Defines the mime type of the result\r\n */\r\n Tools.ToBlob = function (canvas, successCallback, mimeType) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n // We need HTMLCanvasElement.toBlob for HD screenshots\r\n if (!canvas.toBlob) {\r\n // low performance polyfill based on toDataURL (https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob)\r\n canvas.toBlob = function (callback, type, quality) {\r\n var _this = this;\r\n setTimeout(function () {\r\n var binStr = atob(_this.toDataURL(type, quality).split(\",\")[1]), len = binStr.length, arr = new Uint8Array(len);\r\n for (var i = 0; i < len; i++) {\r\n arr[i] = binStr.charCodeAt(i);\r\n }\r\n callback(new Blob([arr]));\r\n });\r\n };\r\n }\r\n canvas.toBlob(function (blob) {\r\n successCallback(blob);\r\n }, mimeType);\r\n };\r\n /**\r\n * Encodes the canvas data to base 64 or automatically download the result if filename is defined\r\n * @param successCallback defines the callback triggered once the data are available\r\n * @param mimeType defines the mime type of the result\r\n * @param fileName defines he filename to download. If present, the result will automatically be downloaded\r\n */\r\n Tools.EncodeScreenshotCanvasData = function (successCallback, mimeType, fileName) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n if (successCallback) {\r\n var base64Image = Tools._ScreenshotCanvas.toDataURL(mimeType);\r\n successCallback(base64Image);\r\n }\r\n else {\r\n this.ToBlob(Tools._ScreenshotCanvas, function (blob) {\r\n //Creating a link if the browser have the download attribute on the a tag, to automatically start download generated image.\r\n if (\"download\" in document.createElement(\"a\")) {\r\n if (!fileName) {\r\n var date = new Date();\r\n var stringDate = (date.getFullYear() + \"-\" + (date.getMonth() + 1)).slice(2) + \"-\" + date.getDate() + \"_\" + date.getHours() + \"-\" + (\"0\" + date.getMinutes()).slice(-2);\r\n fileName = \"screenshot_\" + stringDate + \".png\";\r\n }\r\n Tools.Download(blob, fileName);\r\n }\r\n else {\r\n var url = URL.createObjectURL(blob);\r\n var newWindow = window.open(\"\");\r\n if (!newWindow) {\r\n return;\r\n }\r\n var img = newWindow.document.createElement(\"img\");\r\n img.onload = function () {\r\n // no longer need to read the blob so it's revoked\r\n URL.revokeObjectURL(url);\r\n };\r\n img.src = url;\r\n newWindow.document.body.appendChild(img);\r\n }\r\n }, mimeType);\r\n }\r\n };\r\n /**\r\n * Downloads a blob in the browser\r\n * @param blob defines the blob to download\r\n * @param fileName defines the name of the downloaded file\r\n */\r\n Tools.Download = function (blob, fileName) {\r\n if (navigator && navigator.msSaveBlob) {\r\n navigator.msSaveBlob(blob, fileName);\r\n return;\r\n }\r\n var url = window.URL.createObjectURL(blob);\r\n var a = document.createElement(\"a\");\r\n document.body.appendChild(a);\r\n a.style.display = \"none\";\r\n a.href = url;\r\n a.download = fileName;\r\n a.addEventListener(\"click\", function () {\r\n if (a.parentElement) {\r\n a.parentElement.removeChild(a);\r\n }\r\n });\r\n a.click();\r\n window.URL.revokeObjectURL(url);\r\n };\r\n /**\r\n * Will return the right value of the noPreventDefault variable\r\n * Needed to keep backwards compatibility to the old API.\r\n *\r\n * @param args arguments passed to the attachControl function\r\n * @returns the correct value for noPreventDefault\r\n */\r\n Tools.BackCompatCameraNoPreventDefault = function (args) {\r\n // is it used correctly?\r\n if (typeof args[0] === \"boolean\") {\r\n return args[0];\r\n }\r\n else if (typeof args[1] === \"boolean\") {\r\n return args[1];\r\n }\r\n return false;\r\n };\r\n /**\r\n * Captures a screenshot of the current rendering\r\n * @see https://doc.babylonjs.com/how_to/render_scene_on_a_png\r\n * @param engine defines the rendering engine\r\n * @param camera defines the source camera\r\n * @param size This parameter can be set to a single number or to an object with the\r\n * following (optional) properties: precision, width, height. If a single number is passed,\r\n * it will be used for both width and height. If an object is passed, the screenshot size\r\n * will be derived from the parameters. The precision property is a multiplier allowing\r\n * rendering at a higher or lower resolution\r\n * @param successCallback defines the callback receives a single parameter which contains the\r\n * screenshot as a string of base64-encoded characters. This string can be assigned to the\r\n * src parameter of an to display it\r\n * @param mimeType defines the MIME type of the screenshot image (default: image/png).\r\n * Check your browser for supported MIME types\r\n */\r\n Tools.CreateScreenshot = function (engine, camera, size, successCallback, mimeType) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n throw _DevTools.WarnImport(\"ScreenshotTools\");\r\n };\r\n /**\r\n * Captures a screenshot of the current rendering\r\n * @see https://doc.babylonjs.com/how_to/render_scene_on_a_png\r\n * @param engine defines the rendering engine\r\n * @param camera defines the source camera\r\n * @param size This parameter can be set to a single number or to an object with the\r\n * following (optional) properties: precision, width, height. If a single number is passed,\r\n * it will be used for both width and height. If an object is passed, the screenshot size\r\n * will be derived from the parameters. The precision property is a multiplier allowing\r\n * rendering at a higher or lower resolution\r\n * @param mimeType defines the MIME type of the screenshot image (default: image/png).\r\n * Check your browser for supported MIME types\r\n * @returns screenshot as a string of base64-encoded characters. This string can be assigned\r\n * to the src parameter of an to display it\r\n */\r\n Tools.CreateScreenshotAsync = function (engine, camera, size, mimeType) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n throw _DevTools.WarnImport(\"ScreenshotTools\");\r\n };\r\n /**\r\n * Generates an image screenshot from the specified camera.\r\n * @see https://doc.babylonjs.com/how_to/render_scene_on_a_png\r\n * @param engine The engine to use for rendering\r\n * @param camera The camera to use for rendering\r\n * @param size This parameter can be set to a single number or to an object with the\r\n * following (optional) properties: precision, width, height. If a single number is passed,\r\n * it will be used for both width and height. If an object is passed, the screenshot size\r\n * will be derived from the parameters. The precision property is a multiplier allowing\r\n * rendering at a higher or lower resolution\r\n * @param successCallback The callback receives a single parameter which contains the\r\n * screenshot as a string of base64-encoded characters. This string can be assigned to the\r\n * src parameter of an to display it\r\n * @param mimeType The MIME type of the screenshot image (default: image/png).\r\n * Check your browser for supported MIME types\r\n * @param samples Texture samples (default: 1)\r\n * @param antialiasing Whether antialiasing should be turned on or not (default: false)\r\n * @param fileName A name for for the downloaded file.\r\n */\r\n Tools.CreateScreenshotUsingRenderTarget = function (engine, camera, size, successCallback, mimeType, samples, antialiasing, fileName) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n if (samples === void 0) { samples = 1; }\r\n if (antialiasing === void 0) { antialiasing = false; }\r\n throw _DevTools.WarnImport(\"ScreenshotTools\");\r\n };\r\n /**\r\n * Generates an image screenshot from the specified camera.\r\n * @see https://doc.babylonjs.com/how_to/render_scene_on_a_png\r\n * @param engine The engine to use for rendering\r\n * @param camera The camera to use for rendering\r\n * @param size This parameter can be set to a single number or to an object with the\r\n * following (optional) properties: precision, width, height. If a single number is passed,\r\n * it will be used for both width and height. If an object is passed, the screenshot size\r\n * will be derived from the parameters. The precision property is a multiplier allowing\r\n * rendering at a higher or lower resolution\r\n * @param mimeType The MIME type of the screenshot image (default: image/png).\r\n * Check your browser for supported MIME types\r\n * @param samples Texture samples (default: 1)\r\n * @param antialiasing Whether antialiasing should be turned on or not (default: false)\r\n * @param fileName A name for for the downloaded file.\r\n * @returns screenshot as a string of base64-encoded characters. This string can be assigned\r\n * to the src parameter of an to display it\r\n */\r\n Tools.CreateScreenshotUsingRenderTargetAsync = function (engine, camera, size, mimeType, samples, antialiasing, fileName) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n if (samples === void 0) { samples = 1; }\r\n if (antialiasing === void 0) { antialiasing = false; }\r\n throw _DevTools.WarnImport(\"ScreenshotTools\");\r\n };\r\n /**\r\n * Implementation from http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/2117523#answer-2117523\r\n * Be aware Math.random() could cause collisions, but:\r\n * \"All but 6 of the 128 bits of the ID are randomly generated, which means that for any two ids, there's a 1 in 2^^122 (or 5.3x10^^36) chance they'll collide\"\r\n * @returns a pseudo random id\r\n */\r\n Tools.RandomId = function () {\r\n return GUID.RandomId();\r\n };\r\n /**\r\n * Test if the given uri is a base64 string\r\n * @param uri The uri to test\r\n * @return True if the uri is a base64 string or false otherwise\r\n */\r\n Tools.IsBase64 = function (uri) {\r\n return uri.length < 5 ? false : uri.substr(0, 5) === \"data:\";\r\n };\r\n /**\r\n * Decode the given base64 uri.\r\n * @param uri The uri to decode\r\n * @return The decoded base64 data.\r\n */\r\n Tools.DecodeBase64 = function (uri) {\r\n var decodedString = atob(uri.split(\",\")[1]);\r\n var bufferLength = decodedString.length;\r\n var bufferView = new Uint8Array(new ArrayBuffer(bufferLength));\r\n for (var i = 0; i < bufferLength; i++) {\r\n bufferView[i] = decodedString.charCodeAt(i);\r\n }\r\n return bufferView.buffer;\r\n };\r\n /**\r\n * Gets the absolute url.\r\n * @param url the input url\r\n * @return the absolute url\r\n */\r\n Tools.GetAbsoluteUrl = function (url) {\r\n var a = document.createElement(\"a\");\r\n a.href = url;\r\n return a.href;\r\n };\r\n Object.defineProperty(Tools, \"errorsCount\", {\r\n /**\r\n * Gets a value indicating the number of loading errors\r\n * @ignorenaming\r\n */\r\n get: function () {\r\n return Logger.errorsCount;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Log a message to the console\r\n * @param message defines the message to log\r\n */\r\n Tools.Log = function (message) {\r\n Logger.Log(message);\r\n };\r\n /**\r\n * Write a warning message to the console\r\n * @param message defines the message to log\r\n */\r\n Tools.Warn = function (message) {\r\n Logger.Warn(message);\r\n };\r\n /**\r\n * Write an error message to the console\r\n * @param message defines the message to log\r\n */\r\n Tools.Error = function (message) {\r\n Logger.Error(message);\r\n };\r\n Object.defineProperty(Tools, \"LogCache\", {\r\n /**\r\n * Gets current log cache (list of logs)\r\n */\r\n get: function () {\r\n return Logger.LogCache;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Clears the log cache\r\n */\r\n Tools.ClearLogCache = function () {\r\n Logger.ClearLogCache();\r\n };\r\n Object.defineProperty(Tools, \"LogLevels\", {\r\n /**\r\n * Sets the current log level (MessageLogLevel / WarningLogLevel / ErrorLogLevel)\r\n */\r\n set: function (level) {\r\n Logger.LogLevels = level;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Tools, \"PerformanceLogLevel\", {\r\n /**\r\n * Sets the current performance log level\r\n */\r\n set: function (level) {\r\n if ((level & Tools.PerformanceUserMarkLogLevel) === Tools.PerformanceUserMarkLogLevel) {\r\n Tools.StartPerformanceCounter = Tools._StartUserMark;\r\n Tools.EndPerformanceCounter = Tools._EndUserMark;\r\n return;\r\n }\r\n if ((level & Tools.PerformanceConsoleLogLevel) === Tools.PerformanceConsoleLogLevel) {\r\n Tools.StartPerformanceCounter = Tools._StartPerformanceConsole;\r\n Tools.EndPerformanceCounter = Tools._EndPerformanceConsole;\r\n return;\r\n }\r\n Tools.StartPerformanceCounter = Tools._StartPerformanceCounterDisabled;\r\n Tools.EndPerformanceCounter = Tools._EndPerformanceCounterDisabled;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Tools._StartPerformanceCounterDisabled = function (counterName, condition) { };\r\n Tools._EndPerformanceCounterDisabled = function (counterName, condition) { };\r\n Tools._StartUserMark = function (counterName, condition) {\r\n if (condition === void 0) { condition = true; }\r\n if (!Tools._performance) {\r\n if (!DomManagement.IsWindowObjectExist()) {\r\n return;\r\n }\r\n Tools._performance = window.performance;\r\n }\r\n if (!condition || !Tools._performance.mark) {\r\n return;\r\n }\r\n Tools._performance.mark(counterName + \"-Begin\");\r\n };\r\n Tools._EndUserMark = function (counterName, condition) {\r\n if (condition === void 0) { condition = true; }\r\n if (!condition || !Tools._performance.mark) {\r\n return;\r\n }\r\n Tools._performance.mark(counterName + \"-End\");\r\n Tools._performance.measure(counterName, counterName + \"-Begin\", counterName + \"-End\");\r\n };\r\n Tools._StartPerformanceConsole = function (counterName, condition) {\r\n if (condition === void 0) { condition = true; }\r\n if (!condition) {\r\n return;\r\n }\r\n Tools._StartUserMark(counterName, condition);\r\n if (console.time) {\r\n console.time(counterName);\r\n }\r\n };\r\n Tools._EndPerformanceConsole = function (counterName, condition) {\r\n if (condition === void 0) { condition = true; }\r\n if (!condition) {\r\n return;\r\n }\r\n Tools._EndUserMark(counterName, condition);\r\n console.timeEnd(counterName);\r\n };\r\n Object.defineProperty(Tools, \"Now\", {\r\n /**\r\n * Gets either window.performance.now() if supported or Date.now() else\r\n */\r\n get: function () {\r\n return PrecisionDate.Now;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * This method will return the name of the class used to create the instance of the given object.\r\n * It will works only on Javascript basic data types (number, string, ...) and instance of class declared with the @className decorator.\r\n * @param object the object to get the class name from\r\n * @param isType defines if the object is actually a type\r\n * @returns the name of the class, will be \"object\" for a custom data type not using the @className decorator\r\n */\r\n Tools.GetClassName = function (object, isType) {\r\n if (isType === void 0) { isType = false; }\r\n var name = null;\r\n if (!isType && object.getClassName) {\r\n name = object.getClassName();\r\n }\r\n else {\r\n if (object instanceof Object) {\r\n var classObj = isType ? object : Object.getPrototypeOf(object);\r\n name = classObj.constructor[\"__bjsclassName__\"];\r\n }\r\n if (!name) {\r\n name = typeof object;\r\n }\r\n }\r\n return name;\r\n };\r\n /**\r\n * Gets the first element of an array satisfying a given predicate\r\n * @param array defines the array to browse\r\n * @param predicate defines the predicate to use\r\n * @returns null if not found or the element\r\n */\r\n Tools.First = function (array, predicate) {\r\n for (var _i = 0, array_1 = array; _i < array_1.length; _i++) {\r\n var el = array_1[_i];\r\n if (predicate(el)) {\r\n return el;\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * This method will return the name of the full name of the class, including its owning module (if any).\r\n * It will works only on Javascript basic data types (number, string, ...) and instance of class declared with the @className decorator or implementing a method getClassName():string (in which case the module won't be specified).\r\n * @param object the object to get the class name from\r\n * @param isType defines if the object is actually a type\r\n * @return a string that can have two forms: \"moduleName.className\" if module was specified when the class' Name was registered or \"className\" if there was not module specified.\r\n * @ignorenaming\r\n */\r\n Tools.getFullClassName = function (object, isType) {\r\n if (isType === void 0) { isType = false; }\r\n var className = null;\r\n var moduleName = null;\r\n if (!isType && object.getClassName) {\r\n className = object.getClassName();\r\n }\r\n else {\r\n if (object instanceof Object) {\r\n var classObj = isType ? object : Object.getPrototypeOf(object);\r\n className = classObj.constructor[\"__bjsclassName__\"];\r\n moduleName = classObj.constructor[\"__bjsmoduleName__\"];\r\n }\r\n if (!className) {\r\n className = typeof object;\r\n }\r\n }\r\n if (!className) {\r\n return null;\r\n }\r\n return (moduleName != null ? moduleName + \".\" : \"\") + className;\r\n };\r\n /**\r\n * Returns a promise that resolves after the given amount of time.\r\n * @param delay Number of milliseconds to delay\r\n * @returns Promise that resolves after the given amount of time\r\n */\r\n Tools.DelayAsync = function (delay) {\r\n return new Promise(function (resolve) {\r\n setTimeout(function () {\r\n resolve();\r\n }, delay);\r\n });\r\n };\r\n /**\r\n * Utility function to detect if the current user agent is Safari\r\n * @returns whether or not the current user agent is safari\r\n */\r\n Tools.IsSafari = function () {\r\n return /^((?!chrome|android).)*safari/i.test(navigator.userAgent);\r\n };\r\n /**\r\n * Enable/Disable Custom HTTP Request Headers globally.\r\n * default = false\r\n * @see CustomRequestHeaders\r\n */\r\n Tools.UseCustomRequestHeaders = false;\r\n /**\r\n * Custom HTTP Request Headers to be sent with XMLHttpRequests\r\n * i.e. when loading files, where the server/service expects an Authorization header\r\n */\r\n Tools.CustomRequestHeaders = WebRequest.CustomRequestHeaders;\r\n Tools._tmpFloatArray = new Float32Array(1);\r\n /**\r\n * Extracts text content from a DOM element hierarchy\r\n * Back Compat only, please use DomManagement.GetDOMTextContent instead.\r\n */\r\n Tools.GetDOMTextContent = DomManagement.GetDOMTextContent;\r\n // Logs\r\n /**\r\n * No log\r\n */\r\n Tools.NoneLogLevel = Logger.NoneLogLevel;\r\n /**\r\n * Only message logs\r\n */\r\n Tools.MessageLogLevel = Logger.MessageLogLevel;\r\n /**\r\n * Only warning logs\r\n */\r\n Tools.WarningLogLevel = Logger.WarningLogLevel;\r\n /**\r\n * Only error logs\r\n */\r\n Tools.ErrorLogLevel = Logger.ErrorLogLevel;\r\n /**\r\n * All logs\r\n */\r\n Tools.AllLogLevel = Logger.AllLogLevel;\r\n /**\r\n * Checks if the window object exists\r\n * Back Compat only, please use DomManagement.IsWindowObjectExist instead.\r\n */\r\n Tools.IsWindowObjectExist = DomManagement.IsWindowObjectExist;\r\n // Performances\r\n /**\r\n * No performance log\r\n */\r\n Tools.PerformanceNoneLogLevel = 0;\r\n /**\r\n * Use user marks to log performance\r\n */\r\n Tools.PerformanceUserMarkLogLevel = 1;\r\n /**\r\n * Log performance to the console\r\n */\r\n Tools.PerformanceConsoleLogLevel = 2;\r\n /**\r\n * Starts a performance counter\r\n */\r\n Tools.StartPerformanceCounter = Tools._StartPerformanceCounterDisabled;\r\n /**\r\n * Ends a specific performance coutner\r\n */\r\n Tools.EndPerformanceCounter = Tools._EndPerformanceCounterDisabled;\r\n return Tools;\r\n}());\r\nexport { Tools };\r\n/**\r\n * Use this className as a decorator on a given class definition to add it a name and optionally its module.\r\n * You can then use the Tools.getClassName(obj) on an instance to retrieve its class name.\r\n * This method is the only way to get it done in all cases, even if the .js file declaring the class is minified\r\n * @param name The name of the class, case should be preserved\r\n * @param module The name of the Module hosting the class, optional, but strongly recommended to specify if possible. Case should be preserved.\r\n */\r\nexport function className(name, module) {\r\n return function (target) {\r\n target[\"__bjsclassName__\"] = name;\r\n target[\"__bjsmoduleName__\"] = module != null ? module : null;\r\n };\r\n}\r\n/**\r\n * An implementation of a loop for asynchronous functions.\r\n */\r\nvar AsyncLoop = /** @class */ (function () {\r\n /**\r\n * Constructor.\r\n * @param iterations the number of iterations.\r\n * @param func the function to run each iteration\r\n * @param successCallback the callback that will be called upon succesful execution\r\n * @param offset starting offset.\r\n */\r\n function AsyncLoop(\r\n /**\r\n * Defines the number of iterations for the loop\r\n */\r\n iterations, func, successCallback, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n this.iterations = iterations;\r\n this.index = offset - 1;\r\n this._done = false;\r\n this._fn = func;\r\n this._successCallback = successCallback;\r\n }\r\n /**\r\n * Execute the next iteration. Must be called after the last iteration was finished.\r\n */\r\n AsyncLoop.prototype.executeNext = function () {\r\n if (!this._done) {\r\n if (this.index + 1 < this.iterations) {\r\n ++this.index;\r\n this._fn(this);\r\n }\r\n else {\r\n this.breakLoop();\r\n }\r\n }\r\n };\r\n /**\r\n * Break the loop and run the success callback.\r\n */\r\n AsyncLoop.prototype.breakLoop = function () {\r\n this._done = true;\r\n this._successCallback();\r\n };\r\n /**\r\n * Create and run an async loop.\r\n * @param iterations the number of iterations.\r\n * @param fn the function to run each iteration\r\n * @param successCallback the callback that will be called upon succesful execution\r\n * @param offset starting offset.\r\n * @returns the created async loop object\r\n */\r\n AsyncLoop.Run = function (iterations, fn, successCallback, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n var loop = new AsyncLoop(iterations, fn, successCallback, offset);\r\n loop.executeNext();\r\n return loop;\r\n };\r\n /**\r\n * A for-loop that will run a given number of iterations synchronous and the rest async.\r\n * @param iterations total number of iterations\r\n * @param syncedIterations number of synchronous iterations in each async iteration.\r\n * @param fn the function to call each iteration.\r\n * @param callback a success call back that will be called when iterating stops.\r\n * @param breakFunction a break condition (optional)\r\n * @param timeout timeout settings for the setTimeout function. default - 0.\r\n * @returns the created async loop object\r\n */\r\n AsyncLoop.SyncAsyncForLoop = function (iterations, syncedIterations, fn, callback, breakFunction, timeout) {\r\n if (timeout === void 0) { timeout = 0; }\r\n return AsyncLoop.Run(Math.ceil(iterations / syncedIterations), function (loop) {\r\n if (breakFunction && breakFunction()) {\r\n loop.breakLoop();\r\n }\r\n else {\r\n setTimeout(function () {\r\n for (var i = 0; i < syncedIterations; ++i) {\r\n var iteration = loop.index * syncedIterations + i;\r\n if (iteration >= iterations) {\r\n break;\r\n }\r\n fn(iteration);\r\n if (breakFunction && breakFunction()) {\r\n loop.breakLoop();\r\n break;\r\n }\r\n }\r\n loop.executeNext();\r\n }, timeout);\r\n }\r\n }, callback);\r\n };\r\n return AsyncLoop;\r\n}());\r\nexport { AsyncLoop };\r\n// Will only be define if Tools is imported freeing up some space when only engine is required\r\nEngineStore.FallbackTexture =\r\n \"\";\r\n// Register promise fallback for IE\r\nPromisePolyfill.Apply();\r\n//# sourceMappingURL=tools.js.map","/**\r\n * Class used to represent data loading progression\r\n */\r\nvar SceneLoaderFlags = /** @class */ (function () {\r\n function SceneLoaderFlags() {\r\n }\r\n Object.defineProperty(SceneLoaderFlags, \"ForceFullSceneLoadingForIncremental\", {\r\n /**\r\n * Gets or sets a boolean indicating if entire scene must be loaded even if scene contains incremental data\r\n */\r\n get: function () {\r\n return SceneLoaderFlags._ForceFullSceneLoadingForIncremental;\r\n },\r\n set: function (value) {\r\n SceneLoaderFlags._ForceFullSceneLoadingForIncremental = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(SceneLoaderFlags, \"ShowLoadingScreen\", {\r\n /**\r\n * Gets or sets a boolean indicating if loading screen must be displayed while loading a scene\r\n */\r\n get: function () {\r\n return SceneLoaderFlags._ShowLoadingScreen;\r\n },\r\n set: function (value) {\r\n SceneLoaderFlags._ShowLoadingScreen = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(SceneLoaderFlags, \"loggingLevel\", {\r\n /**\r\n * Defines the current logging level (while loading the scene)\r\n * @ignorenaming\r\n */\r\n get: function () {\r\n return SceneLoaderFlags._loggingLevel;\r\n },\r\n set: function (value) {\r\n SceneLoaderFlags._loggingLevel = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(SceneLoaderFlags, \"CleanBoneMatrixWeights\", {\r\n /**\r\n * Gets or set a boolean indicating if matrix weights must be cleaned upon loading\r\n */\r\n get: function () {\r\n return SceneLoaderFlags._CleanBoneMatrixWeights;\r\n },\r\n set: function (value) {\r\n SceneLoaderFlags._CleanBoneMatrixWeights = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n // Flags\r\n SceneLoaderFlags._ForceFullSceneLoadingForIncremental = false;\r\n SceneLoaderFlags._ShowLoadingScreen = true;\r\n SceneLoaderFlags._CleanBoneMatrixWeights = false;\r\n SceneLoaderFlags._loggingLevel = 0;\r\n return SceneLoaderFlags;\r\n}());\r\nexport { SceneLoaderFlags };\r\n//# sourceMappingURL=sceneLoaderFlags.js.map","import { Vector3 } from \"../Maths/math.vector\";\r\nimport { Color4 } from \"../Maths/math.color\";\r\nimport { VertexData } from \"../Meshes/mesh.vertexData\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { SubMesh } from \"../Meshes/subMesh\";\r\nimport { SceneLoaderFlags } from \"../Loading/sceneLoaderFlags\";\r\nimport { BoundingInfo } from \"../Culling/boundingInfo\";\r\nimport { Tools } from \"../Misc/tools\";\r\nimport { Tags } from \"../Misc/tags\";\r\nimport { extractMinAndMax } from \"../Maths/math.functions\";\r\n/**\r\n * Class used to store geometry data (vertex buffers + index buffer)\r\n */\r\nvar Geometry = /** @class */ (function () {\r\n /**\r\n * Creates a new geometry\r\n * @param id defines the unique ID\r\n * @param scene defines the hosting scene\r\n * @param vertexData defines the VertexData used to get geometry data\r\n * @param updatable defines if geometry must be updatable (false by default)\r\n * @param mesh defines the mesh that will be associated with the geometry\r\n */\r\n function Geometry(id, scene, vertexData, updatable, mesh) {\r\n if (updatable === void 0) { updatable = false; }\r\n if (mesh === void 0) { mesh = null; }\r\n /**\r\n * Gets the delay loading state of the geometry (none by default which means not delayed)\r\n */\r\n this.delayLoadState = 0;\r\n this._totalVertices = 0;\r\n this._isDisposed = false;\r\n this._indexBufferIsUpdatable = false;\r\n this._positionsCache = [];\r\n /**\r\n * If set to true (false by defaut), the bounding info applied to the meshes sharing this geometry will be the bounding info defined at the class level\r\n * and won't be computed based on the vertex positions (which is what we get when useBoundingInfoFromGeometry = false)\r\n */\r\n this.useBoundingInfoFromGeometry = false;\r\n this.id = id;\r\n this.uniqueId = scene.getUniqueId();\r\n this._engine = scene.getEngine();\r\n this._meshes = [];\r\n this._scene = scene;\r\n //Init vertex buffer cache\r\n this._vertexBuffers = {};\r\n this._indices = [];\r\n this._updatable = updatable;\r\n // vertexData\r\n if (vertexData) {\r\n this.setAllVerticesData(vertexData, updatable);\r\n }\r\n else {\r\n this._totalVertices = 0;\r\n this._indices = [];\r\n }\r\n if (this._engine.getCaps().vertexArrayObject) {\r\n this._vertexArrayObjects = {};\r\n }\r\n // applyToMesh\r\n if (mesh) {\r\n this.applyToMesh(mesh);\r\n mesh.computeWorldMatrix(true);\r\n }\r\n }\r\n Object.defineProperty(Geometry.prototype, \"boundingBias\", {\r\n /**\r\n * Gets or sets the Bias Vector to apply on the bounding elements (box/sphere), the max extend is computed as v += v * bias.x + bias.y, the min is computed as v -= v * bias.x + bias.y\r\n */\r\n get: function () {\r\n return this._boundingBias;\r\n },\r\n /**\r\n * Gets or sets the Bias Vector to apply on the bounding elements (box/sphere), the max extend is computed as v += v * bias.x + bias.y, the min is computed as v -= v * bias.x + bias.y\r\n */\r\n set: function (value) {\r\n if (this._boundingBias) {\r\n this._boundingBias.copyFrom(value);\r\n }\r\n else {\r\n this._boundingBias = value.clone();\r\n }\r\n this._updateBoundingInfo(true, null);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Static function used to attach a new empty geometry to a mesh\r\n * @param mesh defines the mesh to attach the geometry to\r\n * @returns the new Geometry\r\n */\r\n Geometry.CreateGeometryForMesh = function (mesh) {\r\n var geometry = new Geometry(Geometry.RandomId(), mesh.getScene());\r\n geometry.applyToMesh(mesh);\r\n return geometry;\r\n };\r\n Object.defineProperty(Geometry.prototype, \"meshes\", {\r\n /** Get the list of meshes using this geometry */\r\n get: function () {\r\n return this._meshes;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Geometry.prototype, \"extend\", {\r\n /**\r\n * Gets the current extend of the geometry\r\n */\r\n get: function () {\r\n return this._extend;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the hosting scene\r\n * @returns the hosting Scene\r\n */\r\n Geometry.prototype.getScene = function () {\r\n return this._scene;\r\n };\r\n /**\r\n * Gets the hosting engine\r\n * @returns the hosting Engine\r\n */\r\n Geometry.prototype.getEngine = function () {\r\n return this._engine;\r\n };\r\n /**\r\n * Defines if the geometry is ready to use\r\n * @returns true if the geometry is ready to be used\r\n */\r\n Geometry.prototype.isReady = function () {\r\n return this.delayLoadState === 1 || this.delayLoadState === 0;\r\n };\r\n Object.defineProperty(Geometry.prototype, \"doNotSerialize\", {\r\n /**\r\n * Gets a value indicating that the geometry should not be serialized\r\n */\r\n get: function () {\r\n for (var index = 0; index < this._meshes.length; index++) {\r\n if (!this._meshes[index].doNotSerialize) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n Geometry.prototype._rebuild = function () {\r\n if (this._vertexArrayObjects) {\r\n this._vertexArrayObjects = {};\r\n }\r\n // Index buffer\r\n if (this._meshes.length !== 0 && this._indices) {\r\n this._indexBuffer = this._engine.createIndexBuffer(this._indices);\r\n }\r\n // Vertex buffers\r\n for (var key in this._vertexBuffers) {\r\n var vertexBuffer = this._vertexBuffers[key];\r\n vertexBuffer._rebuild();\r\n }\r\n };\r\n /**\r\n * Affects all geometry data in one call\r\n * @param vertexData defines the geometry data\r\n * @param updatable defines if the geometry must be flagged as updatable (false as default)\r\n */\r\n Geometry.prototype.setAllVerticesData = function (vertexData, updatable) {\r\n vertexData.applyToGeometry(this, updatable);\r\n this.notifyUpdate();\r\n };\r\n /**\r\n * Set specific vertex data\r\n * @param kind defines the data kind (Position, normal, etc...)\r\n * @param data defines the vertex data to use\r\n * @param updatable defines if the vertex must be flagged as updatable (false as default)\r\n * @param stride defines the stride to use (0 by default). This value is deduced from the kind value if not specified\r\n */\r\n Geometry.prototype.setVerticesData = function (kind, data, updatable, stride) {\r\n if (updatable === void 0) { updatable = false; }\r\n if (updatable && Array.isArray(data)) {\r\n // to avoid converting to Float32Array at each draw call in engine.updateDynamicVertexBuffer, we make the conversion a single time here\r\n data = new Float32Array(data);\r\n }\r\n var buffer = new VertexBuffer(this._engine, data, kind, updatable, this._meshes.length === 0, stride);\r\n this.setVerticesBuffer(buffer);\r\n };\r\n /**\r\n * Removes a specific vertex data\r\n * @param kind defines the data kind (Position, normal, etc...)\r\n */\r\n Geometry.prototype.removeVerticesData = function (kind) {\r\n if (this._vertexBuffers[kind]) {\r\n this._vertexBuffers[kind].dispose();\r\n delete this._vertexBuffers[kind];\r\n }\r\n };\r\n /**\r\n * Affect a vertex buffer to the geometry. the vertexBuffer.getKind() function is used to determine where to store the data\r\n * @param buffer defines the vertex buffer to use\r\n * @param totalVertices defines the total number of vertices for position kind (could be null)\r\n */\r\n Geometry.prototype.setVerticesBuffer = function (buffer, totalVertices) {\r\n if (totalVertices === void 0) { totalVertices = null; }\r\n var kind = buffer.getKind();\r\n if (this._vertexBuffers[kind]) {\r\n this._vertexBuffers[kind].dispose();\r\n }\r\n this._vertexBuffers[kind] = buffer;\r\n if (kind === VertexBuffer.PositionKind) {\r\n var data = buffer.getData();\r\n if (totalVertices != null) {\r\n this._totalVertices = totalVertices;\r\n }\r\n else {\r\n if (data != null) {\r\n this._totalVertices = data.length / (buffer.byteStride / 4);\r\n }\r\n }\r\n this._updateExtend(data);\r\n this._resetPointsArrayCache();\r\n var meshes = this._meshes;\r\n var numOfMeshes = meshes.length;\r\n for (var index = 0; index < numOfMeshes; index++) {\r\n var mesh = meshes[index];\r\n mesh._boundingInfo = new BoundingInfo(this._extend.minimum, this._extend.maximum);\r\n mesh._createGlobalSubMesh(false);\r\n mesh.computeWorldMatrix(true);\r\n }\r\n }\r\n this.notifyUpdate(kind);\r\n if (this._vertexArrayObjects) {\r\n this._disposeVertexArrayObjects();\r\n this._vertexArrayObjects = {}; // Will trigger a rebuild of the VAO if supported\r\n }\r\n };\r\n /**\r\n * Update a specific vertex buffer\r\n * This function will directly update the underlying DataBuffer according to the passed numeric array or Float32Array\r\n * It will do nothing if the buffer is not updatable\r\n * @param kind defines the data kind (Position, normal, etc...)\r\n * @param data defines the data to use\r\n * @param offset defines the offset in the target buffer where to store the data\r\n * @param useBytes set to true if the offset is in bytes\r\n */\r\n Geometry.prototype.updateVerticesDataDirectly = function (kind, data, offset, useBytes) {\r\n if (useBytes === void 0) { useBytes = false; }\r\n var vertexBuffer = this.getVertexBuffer(kind);\r\n if (!vertexBuffer) {\r\n return;\r\n }\r\n vertexBuffer.updateDirectly(data, offset, useBytes);\r\n this.notifyUpdate(kind);\r\n };\r\n /**\r\n * Update a specific vertex buffer\r\n * This function will create a new buffer if the current one is not updatable\r\n * @param kind defines the data kind (Position, normal, etc...)\r\n * @param data defines the data to use\r\n * @param updateExtends defines if the geometry extends must be recomputed (false by default)\r\n */\r\n Geometry.prototype.updateVerticesData = function (kind, data, updateExtends) {\r\n if (updateExtends === void 0) { updateExtends = false; }\r\n var vertexBuffer = this.getVertexBuffer(kind);\r\n if (!vertexBuffer) {\r\n return;\r\n }\r\n vertexBuffer.update(data);\r\n if (kind === VertexBuffer.PositionKind) {\r\n this._updateBoundingInfo(updateExtends, data);\r\n }\r\n this.notifyUpdate(kind);\r\n };\r\n Geometry.prototype._updateBoundingInfo = function (updateExtends, data) {\r\n if (updateExtends) {\r\n this._updateExtend(data);\r\n }\r\n this._resetPointsArrayCache();\r\n if (updateExtends) {\r\n var meshes = this._meshes;\r\n for (var _i = 0, meshes_1 = meshes; _i < meshes_1.length; _i++) {\r\n var mesh = meshes_1[_i];\r\n if (mesh._boundingInfo) {\r\n mesh._boundingInfo.reConstruct(this._extend.minimum, this._extend.maximum);\r\n }\r\n else {\r\n mesh._boundingInfo = new BoundingInfo(this._extend.minimum, this._extend.maximum);\r\n }\r\n var subMeshes = mesh.subMeshes;\r\n for (var _a = 0, subMeshes_1 = subMeshes; _a < subMeshes_1.length; _a++) {\r\n var subMesh = subMeshes_1[_a];\r\n subMesh.refreshBoundingInfo();\r\n }\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n Geometry.prototype._bind = function (effect, indexToBind) {\r\n if (!effect) {\r\n return;\r\n }\r\n if (indexToBind === undefined) {\r\n indexToBind = this._indexBuffer;\r\n }\r\n var vbs = this.getVertexBuffers();\r\n if (!vbs) {\r\n return;\r\n }\r\n if (indexToBind != this._indexBuffer || !this._vertexArrayObjects) {\r\n this._engine.bindBuffers(vbs, indexToBind, effect);\r\n return;\r\n }\r\n // Using VAO\r\n if (!this._vertexArrayObjects[effect.key]) {\r\n this._vertexArrayObjects[effect.key] = this._engine.recordVertexArrayObject(vbs, indexToBind, effect);\r\n }\r\n this._engine.bindVertexArrayObject(this._vertexArrayObjects[effect.key], indexToBind);\r\n };\r\n /**\r\n * Gets total number of vertices\r\n * @returns the total number of vertices\r\n */\r\n Geometry.prototype.getTotalVertices = function () {\r\n if (!this.isReady()) {\r\n return 0;\r\n }\r\n return this._totalVertices;\r\n };\r\n /**\r\n * Gets a specific vertex data attached to this geometry. Float data is constructed if the vertex buffer data cannot be returned directly.\r\n * @param kind defines the data kind (Position, normal, etc...)\r\n * @param copyWhenShared defines if the returned array must be cloned upon returning it if the current geometry is shared between multiple meshes\r\n * @param forceCopy defines a boolean indicating that the returned array must be cloned upon returning it\r\n * @returns a float array containing vertex data\r\n */\r\n Geometry.prototype.getVerticesData = function (kind, copyWhenShared, forceCopy) {\r\n var vertexBuffer = this.getVertexBuffer(kind);\r\n if (!vertexBuffer) {\r\n return null;\r\n }\r\n var data = vertexBuffer.getData();\r\n if (!data) {\r\n return null;\r\n }\r\n var tightlyPackedByteStride = vertexBuffer.getSize() * VertexBuffer.GetTypeByteLength(vertexBuffer.type);\r\n var count = this._totalVertices * vertexBuffer.getSize();\r\n if (vertexBuffer.type !== VertexBuffer.FLOAT || vertexBuffer.byteStride !== tightlyPackedByteStride) {\r\n var copy_1 = [];\r\n vertexBuffer.forEach(count, function (value) { return copy_1.push(value); });\r\n return copy_1;\r\n }\r\n if (!(data instanceof Array || data instanceof Float32Array) || vertexBuffer.byteOffset !== 0 || data.length !== count) {\r\n if (data instanceof Array) {\r\n var offset = vertexBuffer.byteOffset / 4;\r\n return Tools.Slice(data, offset, offset + count);\r\n }\r\n else if (data instanceof ArrayBuffer) {\r\n return new Float32Array(data, vertexBuffer.byteOffset, count);\r\n }\r\n else {\r\n var offset = data.byteOffset + vertexBuffer.byteOffset;\r\n if (forceCopy || (copyWhenShared && this._meshes.length !== 1)) {\r\n var result = new Float32Array(count);\r\n var source = new Float32Array(data.buffer, offset, count);\r\n result.set(source);\r\n return result;\r\n }\r\n // Portect against bad data\r\n var remainder = offset % 4;\r\n if (remainder) {\r\n offset = Math.max(0, offset - remainder);\r\n }\r\n return new Float32Array(data.buffer, offset, count);\r\n }\r\n }\r\n if (forceCopy || (copyWhenShared && this._meshes.length !== 1)) {\r\n return Tools.Slice(data);\r\n }\r\n return data;\r\n };\r\n /**\r\n * Returns a boolean defining if the vertex data for the requested `kind` is updatable\r\n * @param kind defines the data kind (Position, normal, etc...)\r\n * @returns true if the vertex buffer with the specified kind is updatable\r\n */\r\n Geometry.prototype.isVertexBufferUpdatable = function (kind) {\r\n var vb = this._vertexBuffers[kind];\r\n if (!vb) {\r\n return false;\r\n }\r\n return vb.isUpdatable();\r\n };\r\n /**\r\n * Gets a specific vertex buffer\r\n * @param kind defines the data kind (Position, normal, etc...)\r\n * @returns a VertexBuffer\r\n */\r\n Geometry.prototype.getVertexBuffer = function (kind) {\r\n if (!this.isReady()) {\r\n return null;\r\n }\r\n return this._vertexBuffers[kind];\r\n };\r\n /**\r\n * Returns all vertex buffers\r\n * @return an object holding all vertex buffers indexed by kind\r\n */\r\n Geometry.prototype.getVertexBuffers = function () {\r\n if (!this.isReady()) {\r\n return null;\r\n }\r\n return this._vertexBuffers;\r\n };\r\n /**\r\n * Gets a boolean indicating if specific vertex buffer is present\r\n * @param kind defines the data kind (Position, normal, etc...)\r\n * @returns true if data is present\r\n */\r\n Geometry.prototype.isVerticesDataPresent = function (kind) {\r\n if (!this._vertexBuffers) {\r\n if (this._delayInfo) {\r\n return this._delayInfo.indexOf(kind) !== -1;\r\n }\r\n return false;\r\n }\r\n return this._vertexBuffers[kind] !== undefined;\r\n };\r\n /**\r\n * Gets a list of all attached data kinds (Position, normal, etc...)\r\n * @returns a list of string containing all kinds\r\n */\r\n Geometry.prototype.getVerticesDataKinds = function () {\r\n var result = [];\r\n var kind;\r\n if (!this._vertexBuffers && this._delayInfo) {\r\n for (kind in this._delayInfo) {\r\n result.push(kind);\r\n }\r\n }\r\n else {\r\n for (kind in this._vertexBuffers) {\r\n result.push(kind);\r\n }\r\n }\r\n return result;\r\n };\r\n /**\r\n * Update index buffer\r\n * @param indices defines the indices to store in the index buffer\r\n * @param offset defines the offset in the target buffer where to store the data\r\n * @param gpuMemoryOnly defines a boolean indicating that only the GPU memory must be updated leaving the CPU version of the indices unchanged (false by default)\r\n */\r\n Geometry.prototype.updateIndices = function (indices, offset, gpuMemoryOnly) {\r\n if (gpuMemoryOnly === void 0) { gpuMemoryOnly = false; }\r\n if (!this._indexBuffer) {\r\n return;\r\n }\r\n if (!this._indexBufferIsUpdatable) {\r\n this.setIndices(indices, null, true);\r\n }\r\n else {\r\n var needToUpdateSubMeshes = indices.length !== this._indices.length;\r\n if (!gpuMemoryOnly) {\r\n this._indices = indices.slice();\r\n }\r\n this._engine.updateDynamicIndexBuffer(this._indexBuffer, indices, offset);\r\n if (needToUpdateSubMeshes) {\r\n for (var _i = 0, _a = this._meshes; _i < _a.length; _i++) {\r\n var mesh = _a[_i];\r\n mesh._createGlobalSubMesh(true);\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Creates a new index buffer\r\n * @param indices defines the indices to store in the index buffer\r\n * @param totalVertices defines the total number of vertices (could be null)\r\n * @param updatable defines if the index buffer must be flagged as updatable (false by default)\r\n */\r\n Geometry.prototype.setIndices = function (indices, totalVertices, updatable) {\r\n if (totalVertices === void 0) { totalVertices = null; }\r\n if (updatable === void 0) { updatable = false; }\r\n if (this._indexBuffer) {\r\n this._engine._releaseBuffer(this._indexBuffer);\r\n }\r\n this._disposeVertexArrayObjects();\r\n this._indices = indices;\r\n this._indexBufferIsUpdatable = updatable;\r\n if (this._meshes.length !== 0 && this._indices) {\r\n this._indexBuffer = this._engine.createIndexBuffer(this._indices, updatable);\r\n }\r\n if (totalVertices != undefined) {\r\n // including null and undefined\r\n this._totalVertices = totalVertices;\r\n }\r\n for (var _i = 0, _a = this._meshes; _i < _a.length; _i++) {\r\n var mesh = _a[_i];\r\n mesh._createGlobalSubMesh(true);\r\n }\r\n this.notifyUpdate();\r\n };\r\n /**\r\n * Return the total number of indices\r\n * @returns the total number of indices\r\n */\r\n Geometry.prototype.getTotalIndices = function () {\r\n if (!this.isReady()) {\r\n return 0;\r\n }\r\n return this._indices.length;\r\n };\r\n /**\r\n * Gets the index buffer array\r\n * @param copyWhenShared defines if the returned array must be cloned upon returning it if the current geometry is shared between multiple meshes\r\n * @param forceCopy defines a boolean indicating that the returned array must be cloned upon returning it\r\n * @returns the index buffer array\r\n */\r\n Geometry.prototype.getIndices = function (copyWhenShared, forceCopy) {\r\n if (!this.isReady()) {\r\n return null;\r\n }\r\n var orig = this._indices;\r\n if (!forceCopy && (!copyWhenShared || this._meshes.length === 1)) {\r\n return orig;\r\n }\r\n else {\r\n var len = orig.length;\r\n var copy = [];\r\n for (var i = 0; i < len; i++) {\r\n copy.push(orig[i]);\r\n }\r\n return copy;\r\n }\r\n };\r\n /**\r\n * Gets the index buffer\r\n * @return the index buffer\r\n */\r\n Geometry.prototype.getIndexBuffer = function () {\r\n if (!this.isReady()) {\r\n return null;\r\n }\r\n return this._indexBuffer;\r\n };\r\n /** @hidden */\r\n Geometry.prototype._releaseVertexArrayObject = function (effect) {\r\n if (effect === void 0) { effect = null; }\r\n if (!effect || !this._vertexArrayObjects) {\r\n return;\r\n }\r\n if (this._vertexArrayObjects[effect.key]) {\r\n this._engine.releaseVertexArrayObject(this._vertexArrayObjects[effect.key]);\r\n delete this._vertexArrayObjects[effect.key];\r\n }\r\n };\r\n /**\r\n * Release the associated resources for a specific mesh\r\n * @param mesh defines the source mesh\r\n * @param shouldDispose defines if the geometry must be disposed if there is no more mesh pointing to it\r\n */\r\n Geometry.prototype.releaseForMesh = function (mesh, shouldDispose) {\r\n var meshes = this._meshes;\r\n var index = meshes.indexOf(mesh);\r\n if (index === -1) {\r\n return;\r\n }\r\n meshes.splice(index, 1);\r\n mesh._geometry = null;\r\n if (meshes.length === 0 && shouldDispose) {\r\n this.dispose();\r\n }\r\n };\r\n /**\r\n * Apply current geometry to a given mesh\r\n * @param mesh defines the mesh to apply geometry to\r\n */\r\n Geometry.prototype.applyToMesh = function (mesh) {\r\n if (mesh._geometry === this) {\r\n return;\r\n }\r\n var previousGeometry = mesh._geometry;\r\n if (previousGeometry) {\r\n previousGeometry.releaseForMesh(mesh);\r\n }\r\n var meshes = this._meshes;\r\n // must be done before setting vertexBuffers because of mesh._createGlobalSubMesh()\r\n mesh._geometry = this;\r\n this._scene.pushGeometry(this);\r\n meshes.push(mesh);\r\n if (this.isReady()) {\r\n this._applyToMesh(mesh);\r\n }\r\n else {\r\n mesh._boundingInfo = this._boundingInfo;\r\n }\r\n };\r\n Geometry.prototype._updateExtend = function (data) {\r\n if (data === void 0) { data = null; }\r\n if (this.useBoundingInfoFromGeometry && this._boundingInfo) {\r\n this._extend = {\r\n minimum: this._boundingInfo.minimum.clone(),\r\n maximum: this._boundingInfo.maximum.clone(),\r\n };\r\n }\r\n else {\r\n if (!data) {\r\n data = this.getVerticesData(VertexBuffer.PositionKind);\r\n }\r\n this._extend = extractMinAndMax(data, 0, this._totalVertices, this.boundingBias, 3);\r\n }\r\n };\r\n Geometry.prototype._applyToMesh = function (mesh) {\r\n var numOfMeshes = this._meshes.length;\r\n // vertexBuffers\r\n for (var kind in this._vertexBuffers) {\r\n if (numOfMeshes === 1) {\r\n this._vertexBuffers[kind].create();\r\n }\r\n var buffer = this._vertexBuffers[kind].getBuffer();\r\n if (buffer) {\r\n buffer.references = numOfMeshes;\r\n }\r\n if (kind === VertexBuffer.PositionKind) {\r\n if (!this._extend) {\r\n this._updateExtend();\r\n }\r\n mesh._boundingInfo = new BoundingInfo(this._extend.minimum, this._extend.maximum);\r\n mesh._createGlobalSubMesh(false);\r\n //bounding info was just created again, world matrix should be applied again.\r\n mesh._updateBoundingInfo();\r\n }\r\n }\r\n // indexBuffer\r\n if (numOfMeshes === 1 && this._indices && this._indices.length > 0) {\r\n this._indexBuffer = this._engine.createIndexBuffer(this._indices);\r\n }\r\n if (this._indexBuffer) {\r\n this._indexBuffer.references = numOfMeshes;\r\n }\r\n // morphTargets\r\n mesh._syncGeometryWithMorphTargetManager();\r\n // instances\r\n mesh.synchronizeInstances();\r\n };\r\n Geometry.prototype.notifyUpdate = function (kind) {\r\n if (this.onGeometryUpdated) {\r\n this.onGeometryUpdated(this, kind);\r\n }\r\n for (var _i = 0, _a = this._meshes; _i < _a.length; _i++) {\r\n var mesh = _a[_i];\r\n mesh._markSubMeshesAsAttributesDirty();\r\n }\r\n };\r\n /**\r\n * Load the geometry if it was flagged as delay loaded\r\n * @param scene defines the hosting scene\r\n * @param onLoaded defines a callback called when the geometry is loaded\r\n */\r\n Geometry.prototype.load = function (scene, onLoaded) {\r\n if (this.delayLoadState === 2) {\r\n return;\r\n }\r\n if (this.isReady()) {\r\n if (onLoaded) {\r\n onLoaded();\r\n }\r\n return;\r\n }\r\n this.delayLoadState = 2;\r\n this._queueLoad(scene, onLoaded);\r\n };\r\n Geometry.prototype._queueLoad = function (scene, onLoaded) {\r\n var _this = this;\r\n if (!this.delayLoadingFile) {\r\n return;\r\n }\r\n scene._addPendingData(this);\r\n scene._loadFile(this.delayLoadingFile, function (data) {\r\n if (!_this._delayLoadingFunction) {\r\n return;\r\n }\r\n _this._delayLoadingFunction(JSON.parse(data), _this);\r\n _this.delayLoadState = 1;\r\n _this._delayInfo = [];\r\n scene._removePendingData(_this);\r\n var meshes = _this._meshes;\r\n var numOfMeshes = meshes.length;\r\n for (var index = 0; index < numOfMeshes; index++) {\r\n _this._applyToMesh(meshes[index]);\r\n }\r\n if (onLoaded) {\r\n onLoaded();\r\n }\r\n }, undefined, true);\r\n };\r\n /**\r\n * Invert the geometry to move from a right handed system to a left handed one.\r\n */\r\n Geometry.prototype.toLeftHanded = function () {\r\n // Flip faces\r\n var tIndices = this.getIndices(false);\r\n if (tIndices != null && tIndices.length > 0) {\r\n for (var i = 0; i < tIndices.length; i += 3) {\r\n var tTemp = tIndices[i + 0];\r\n tIndices[i + 0] = tIndices[i + 2];\r\n tIndices[i + 2] = tTemp;\r\n }\r\n this.setIndices(tIndices);\r\n }\r\n // Negate position.z\r\n var tPositions = this.getVerticesData(VertexBuffer.PositionKind, false);\r\n if (tPositions != null && tPositions.length > 0) {\r\n for (var i = 0; i < tPositions.length; i += 3) {\r\n tPositions[i + 2] = -tPositions[i + 2];\r\n }\r\n this.setVerticesData(VertexBuffer.PositionKind, tPositions, false);\r\n }\r\n // Negate normal.z\r\n var tNormals = this.getVerticesData(VertexBuffer.NormalKind, false);\r\n if (tNormals != null && tNormals.length > 0) {\r\n for (var i = 0; i < tNormals.length; i += 3) {\r\n tNormals[i + 2] = -tNormals[i + 2];\r\n }\r\n this.setVerticesData(VertexBuffer.NormalKind, tNormals, false);\r\n }\r\n };\r\n // Cache\r\n /** @hidden */\r\n Geometry.prototype._resetPointsArrayCache = function () {\r\n this._positions = null;\r\n };\r\n /** @hidden */\r\n Geometry.prototype._generatePointsArray = function () {\r\n if (this._positions) {\r\n return true;\r\n }\r\n var data = this.getVerticesData(VertexBuffer.PositionKind);\r\n if (!data || data.length === 0) {\r\n return false;\r\n }\r\n for (var index = this._positionsCache.length * 3, arrayIdx = this._positionsCache.length; index < data.length; index += 3, ++arrayIdx) {\r\n this._positionsCache[arrayIdx] = Vector3.FromArray(data, index);\r\n }\r\n for (var index = 0, arrayIdx = 0; index < data.length; index += 3, ++arrayIdx) {\r\n this._positionsCache[arrayIdx].set(data[0 + index], data[1 + index], data[2 + index]);\r\n }\r\n // just in case the number of positions was reduced, splice the array\r\n this._positionsCache.length = data.length / 3;\r\n this._positions = this._positionsCache;\r\n return true;\r\n };\r\n /**\r\n * Gets a value indicating if the geometry is disposed\r\n * @returns true if the geometry was disposed\r\n */\r\n Geometry.prototype.isDisposed = function () {\r\n return this._isDisposed;\r\n };\r\n Geometry.prototype._disposeVertexArrayObjects = function () {\r\n if (this._vertexArrayObjects) {\r\n for (var kind in this._vertexArrayObjects) {\r\n this._engine.releaseVertexArrayObject(this._vertexArrayObjects[kind]);\r\n }\r\n this._vertexArrayObjects = {};\r\n }\r\n };\r\n /**\r\n * Free all associated resources\r\n */\r\n Geometry.prototype.dispose = function () {\r\n var meshes = this._meshes;\r\n var numOfMeshes = meshes.length;\r\n var index;\r\n for (index = 0; index < numOfMeshes; index++) {\r\n this.releaseForMesh(meshes[index]);\r\n }\r\n this._meshes = [];\r\n this._disposeVertexArrayObjects();\r\n for (var kind in this._vertexBuffers) {\r\n this._vertexBuffers[kind].dispose();\r\n }\r\n this._vertexBuffers = {};\r\n this._totalVertices = 0;\r\n if (this._indexBuffer) {\r\n this._engine._releaseBuffer(this._indexBuffer);\r\n }\r\n this._indexBuffer = null;\r\n this._indices = [];\r\n this.delayLoadState = 0;\r\n this.delayLoadingFile = null;\r\n this._delayLoadingFunction = null;\r\n this._delayInfo = [];\r\n this._boundingInfo = null;\r\n this._scene.removeGeometry(this);\r\n this._isDisposed = true;\r\n };\r\n /**\r\n * Clone the current geometry into a new geometry\r\n * @param id defines the unique ID of the new geometry\r\n * @returns a new geometry object\r\n */\r\n Geometry.prototype.copy = function (id) {\r\n var vertexData = new VertexData();\r\n vertexData.indices = [];\r\n var indices = this.getIndices();\r\n if (indices) {\r\n for (var index = 0; index < indices.length; index++) {\r\n vertexData.indices.push(indices[index]);\r\n }\r\n }\r\n var updatable = false;\r\n var stopChecking = false;\r\n var kind;\r\n for (kind in this._vertexBuffers) {\r\n // using slice() to make a copy of the array and not just reference it\r\n var data = this.getVerticesData(kind);\r\n if (data) {\r\n if (data instanceof Float32Array) {\r\n vertexData.set(new Float32Array(data), kind);\r\n }\r\n else {\r\n vertexData.set(data.slice(0), kind);\r\n }\r\n if (!stopChecking) {\r\n var vb = this.getVertexBuffer(kind);\r\n if (vb) {\r\n updatable = vb.isUpdatable();\r\n stopChecking = !updatable;\r\n }\r\n }\r\n }\r\n }\r\n var geometry = new Geometry(id, this._scene, vertexData, updatable);\r\n geometry.delayLoadState = this.delayLoadState;\r\n geometry.delayLoadingFile = this.delayLoadingFile;\r\n geometry._delayLoadingFunction = this._delayLoadingFunction;\r\n for (kind in this._delayInfo) {\r\n geometry._delayInfo = geometry._delayInfo || [];\r\n geometry._delayInfo.push(kind);\r\n }\r\n // Bounding info\r\n geometry._boundingInfo = new BoundingInfo(this._extend.minimum, this._extend.maximum);\r\n return geometry;\r\n };\r\n /**\r\n * Serialize the current geometry info (and not the vertices data) into a JSON object\r\n * @return a JSON representation of the current geometry data (without the vertices data)\r\n */\r\n Geometry.prototype.serialize = function () {\r\n var serializationObject = {};\r\n serializationObject.id = this.id;\r\n serializationObject.updatable = this._updatable;\r\n if (Tags && Tags.HasTags(this)) {\r\n serializationObject.tags = Tags.GetTags(this);\r\n }\r\n return serializationObject;\r\n };\r\n Geometry.prototype.toNumberArray = function (origin) {\r\n if (Array.isArray(origin)) {\r\n return origin;\r\n }\r\n else {\r\n return Array.prototype.slice.call(origin);\r\n }\r\n };\r\n /**\r\n * Serialize all vertices data into a JSON oject\r\n * @returns a JSON representation of the current geometry data\r\n */\r\n Geometry.prototype.serializeVerticeData = function () {\r\n var serializationObject = this.serialize();\r\n if (this.isVerticesDataPresent(VertexBuffer.PositionKind)) {\r\n serializationObject.positions = this.toNumberArray(this.getVerticesData(VertexBuffer.PositionKind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.PositionKind)) {\r\n serializationObject.positions._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.NormalKind)) {\r\n serializationObject.normals = this.toNumberArray(this.getVerticesData(VertexBuffer.NormalKind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.NormalKind)) {\r\n serializationObject.normals._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.TangentKind)) {\r\n serializationObject.tangets = this.toNumberArray(this.getVerticesData(VertexBuffer.TangentKind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.TangentKind)) {\r\n serializationObject.tangets._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.UVKind)) {\r\n serializationObject.uvs = this.toNumberArray(this.getVerticesData(VertexBuffer.UVKind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.UVKind)) {\r\n serializationObject.uvs._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.UV2Kind)) {\r\n serializationObject.uv2s = this.toNumberArray(this.getVerticesData(VertexBuffer.UV2Kind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.UV2Kind)) {\r\n serializationObject.uv2s._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.UV3Kind)) {\r\n serializationObject.uv3s = this.toNumberArray(this.getVerticesData(VertexBuffer.UV3Kind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.UV3Kind)) {\r\n serializationObject.uv3s._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.UV4Kind)) {\r\n serializationObject.uv4s = this.toNumberArray(this.getVerticesData(VertexBuffer.UV4Kind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.UV4Kind)) {\r\n serializationObject.uv4s._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.UV5Kind)) {\r\n serializationObject.uv5s = this.toNumberArray(this.getVerticesData(VertexBuffer.UV5Kind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.UV5Kind)) {\r\n serializationObject.uv5s._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.UV6Kind)) {\r\n serializationObject.uv6s = this.toNumberArray(this.getVerticesData(VertexBuffer.UV6Kind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.UV6Kind)) {\r\n serializationObject.uv6s._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.ColorKind)) {\r\n serializationObject.colors = this.toNumberArray(this.getVerticesData(VertexBuffer.ColorKind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.ColorKind)) {\r\n serializationObject.colors._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.MatricesIndicesKind)) {\r\n serializationObject.matricesIndices = this.toNumberArray(this.getVerticesData(VertexBuffer.MatricesIndicesKind));\r\n serializationObject.matricesIndices._isExpanded = true;\r\n if (this.isVertexBufferUpdatable(VertexBuffer.MatricesIndicesKind)) {\r\n serializationObject.matricesIndices._updatable = true;\r\n }\r\n }\r\n if (this.isVerticesDataPresent(VertexBuffer.MatricesWeightsKind)) {\r\n serializationObject.matricesWeights = this.toNumberArray(this.getVerticesData(VertexBuffer.MatricesWeightsKind));\r\n if (this.isVertexBufferUpdatable(VertexBuffer.MatricesWeightsKind)) {\r\n serializationObject.matricesWeights._updatable = true;\r\n }\r\n }\r\n serializationObject.indices = this.toNumberArray(this.getIndices());\r\n return serializationObject;\r\n };\r\n // Statics\r\n /**\r\n * Extracts a clone of a mesh geometry\r\n * @param mesh defines the source mesh\r\n * @param id defines the unique ID of the new geometry object\r\n * @returns the new geometry object\r\n */\r\n Geometry.ExtractFromMesh = function (mesh, id) {\r\n var geometry = mesh._geometry;\r\n if (!geometry) {\r\n return null;\r\n }\r\n return geometry.copy(id);\r\n };\r\n /**\r\n * You should now use Tools.RandomId(), this method is still here for legacy reasons.\r\n * Implementation from http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/2117523#answer-2117523\r\n * Be aware Math.random() could cause collisions, but:\r\n * \"All but 6 of the 128 bits of the ID are randomly generated, which means that for any two ids, there's a 1 in 2^^122 (or 5.3x10^^36) chance they'll collide\"\r\n * @returns a string containing a new GUID\r\n */\r\n Geometry.RandomId = function () {\r\n return Tools.RandomId();\r\n };\r\n /** @hidden */\r\n Geometry._ImportGeometry = function (parsedGeometry, mesh) {\r\n var scene = mesh.getScene();\r\n // Geometry\r\n var geometryId = parsedGeometry.geometryId;\r\n if (geometryId) {\r\n var geometry = scene.getGeometryByID(geometryId);\r\n if (geometry) {\r\n geometry.applyToMesh(mesh);\r\n }\r\n }\r\n else if (parsedGeometry instanceof ArrayBuffer) {\r\n var binaryInfo = mesh._binaryInfo;\r\n if (binaryInfo.positionsAttrDesc && binaryInfo.positionsAttrDesc.count > 0) {\r\n var positionsData = new Float32Array(parsedGeometry, binaryInfo.positionsAttrDesc.offset, binaryInfo.positionsAttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.PositionKind, positionsData, false);\r\n }\r\n if (binaryInfo.normalsAttrDesc && binaryInfo.normalsAttrDesc.count > 0) {\r\n var normalsData = new Float32Array(parsedGeometry, binaryInfo.normalsAttrDesc.offset, binaryInfo.normalsAttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.NormalKind, normalsData, false);\r\n }\r\n if (binaryInfo.tangetsAttrDesc && binaryInfo.tangetsAttrDesc.count > 0) {\r\n var tangentsData = new Float32Array(parsedGeometry, binaryInfo.tangetsAttrDesc.offset, binaryInfo.tangetsAttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.TangentKind, tangentsData, false);\r\n }\r\n if (binaryInfo.uvsAttrDesc && binaryInfo.uvsAttrDesc.count > 0) {\r\n var uvsData = new Float32Array(parsedGeometry, binaryInfo.uvsAttrDesc.offset, binaryInfo.uvsAttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.UVKind, uvsData, false);\r\n }\r\n if (binaryInfo.uvs2AttrDesc && binaryInfo.uvs2AttrDesc.count > 0) {\r\n var uvs2Data = new Float32Array(parsedGeometry, binaryInfo.uvs2AttrDesc.offset, binaryInfo.uvs2AttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.UV2Kind, uvs2Data, false);\r\n }\r\n if (binaryInfo.uvs3AttrDesc && binaryInfo.uvs3AttrDesc.count > 0) {\r\n var uvs3Data = new Float32Array(parsedGeometry, binaryInfo.uvs3AttrDesc.offset, binaryInfo.uvs3AttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.UV3Kind, uvs3Data, false);\r\n }\r\n if (binaryInfo.uvs4AttrDesc && binaryInfo.uvs4AttrDesc.count > 0) {\r\n var uvs4Data = new Float32Array(parsedGeometry, binaryInfo.uvs4AttrDesc.offset, binaryInfo.uvs4AttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.UV4Kind, uvs4Data, false);\r\n }\r\n if (binaryInfo.uvs5AttrDesc && binaryInfo.uvs5AttrDesc.count > 0) {\r\n var uvs5Data = new Float32Array(parsedGeometry, binaryInfo.uvs5AttrDesc.offset, binaryInfo.uvs5AttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.UV5Kind, uvs5Data, false);\r\n }\r\n if (binaryInfo.uvs6AttrDesc && binaryInfo.uvs6AttrDesc.count > 0) {\r\n var uvs6Data = new Float32Array(parsedGeometry, binaryInfo.uvs6AttrDesc.offset, binaryInfo.uvs6AttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.UV6Kind, uvs6Data, false);\r\n }\r\n if (binaryInfo.colorsAttrDesc && binaryInfo.colorsAttrDesc.count > 0) {\r\n var colorsData = new Float32Array(parsedGeometry, binaryInfo.colorsAttrDesc.offset, binaryInfo.colorsAttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.ColorKind, colorsData, false, binaryInfo.colorsAttrDesc.stride);\r\n }\r\n if (binaryInfo.matricesIndicesAttrDesc && binaryInfo.matricesIndicesAttrDesc.count > 0) {\r\n var matricesIndicesData = new Int32Array(parsedGeometry, binaryInfo.matricesIndicesAttrDesc.offset, binaryInfo.matricesIndicesAttrDesc.count);\r\n var floatIndices = [];\r\n for (var i = 0; i < matricesIndicesData.length; i++) {\r\n var index = matricesIndicesData[i];\r\n floatIndices.push(index & 0x000000ff);\r\n floatIndices.push((index & 0x0000ff00) >> 8);\r\n floatIndices.push((index & 0x00ff0000) >> 16);\r\n floatIndices.push((index >> 24) & 0xff); // & 0xFF to convert to v + 256 if v < 0\r\n }\r\n mesh.setVerticesData(VertexBuffer.MatricesIndicesKind, floatIndices, false);\r\n }\r\n if (binaryInfo.matricesIndicesExtraAttrDesc && binaryInfo.matricesIndicesExtraAttrDesc.count > 0) {\r\n var matricesIndicesData = new Int32Array(parsedGeometry, binaryInfo.matricesIndicesExtraAttrDesc.offset, binaryInfo.matricesIndicesExtraAttrDesc.count);\r\n var floatIndices = [];\r\n for (var i = 0; i < matricesIndicesData.length; i++) {\r\n var index = matricesIndicesData[i];\r\n floatIndices.push(index & 0x000000ff);\r\n floatIndices.push((index & 0x0000ff00) >> 8);\r\n floatIndices.push((index & 0x00ff0000) >> 16);\r\n floatIndices.push((index >> 24) & 0xff); // & 0xFF to convert to v + 256 if v < 0\r\n }\r\n mesh.setVerticesData(VertexBuffer.MatricesIndicesExtraKind, floatIndices, false);\r\n }\r\n if (binaryInfo.matricesWeightsAttrDesc && binaryInfo.matricesWeightsAttrDesc.count > 0) {\r\n var matricesWeightsData = new Float32Array(parsedGeometry, binaryInfo.matricesWeightsAttrDesc.offset, binaryInfo.matricesWeightsAttrDesc.count);\r\n mesh.setVerticesData(VertexBuffer.MatricesWeightsKind, matricesWeightsData, false);\r\n }\r\n if (binaryInfo.indicesAttrDesc && binaryInfo.indicesAttrDesc.count > 0) {\r\n var indicesData = new Int32Array(parsedGeometry, binaryInfo.indicesAttrDesc.offset, binaryInfo.indicesAttrDesc.count);\r\n mesh.setIndices(indicesData, null);\r\n }\r\n if (binaryInfo.subMeshesAttrDesc && binaryInfo.subMeshesAttrDesc.count > 0) {\r\n var subMeshesData = new Int32Array(parsedGeometry, binaryInfo.subMeshesAttrDesc.offset, binaryInfo.subMeshesAttrDesc.count * 5);\r\n mesh.subMeshes = [];\r\n for (var i = 0; i < binaryInfo.subMeshesAttrDesc.count; i++) {\r\n var materialIndex = subMeshesData[i * 5 + 0];\r\n var verticesStart = subMeshesData[i * 5 + 1];\r\n var verticesCount = subMeshesData[i * 5 + 2];\r\n var indexStart = subMeshesData[i * 5 + 3];\r\n var indexCount = subMeshesData[i * 5 + 4];\r\n SubMesh.AddToMesh(materialIndex, verticesStart, verticesCount, indexStart, indexCount, mesh);\r\n }\r\n }\r\n }\r\n else if (parsedGeometry.positions && parsedGeometry.normals && parsedGeometry.indices) {\r\n mesh.setVerticesData(VertexBuffer.PositionKind, parsedGeometry.positions, parsedGeometry.positions._updatable);\r\n mesh.setVerticesData(VertexBuffer.NormalKind, parsedGeometry.normals, parsedGeometry.normals._updatable);\r\n if (parsedGeometry.tangents) {\r\n mesh.setVerticesData(VertexBuffer.TangentKind, parsedGeometry.tangents, parsedGeometry.tangents._updatable);\r\n }\r\n if (parsedGeometry.uvs) {\r\n mesh.setVerticesData(VertexBuffer.UVKind, parsedGeometry.uvs, parsedGeometry.uvs._updatable);\r\n }\r\n if (parsedGeometry.uvs2) {\r\n mesh.setVerticesData(VertexBuffer.UV2Kind, parsedGeometry.uvs2, parsedGeometry.uvs2._updatable);\r\n }\r\n if (parsedGeometry.uvs3) {\r\n mesh.setVerticesData(VertexBuffer.UV3Kind, parsedGeometry.uvs3, parsedGeometry.uvs3._updatable);\r\n }\r\n if (parsedGeometry.uvs4) {\r\n mesh.setVerticesData(VertexBuffer.UV4Kind, parsedGeometry.uvs4, parsedGeometry.uvs4._updatable);\r\n }\r\n if (parsedGeometry.uvs5) {\r\n mesh.setVerticesData(VertexBuffer.UV5Kind, parsedGeometry.uvs5, parsedGeometry.uvs5._updatable);\r\n }\r\n if (parsedGeometry.uvs6) {\r\n mesh.setVerticesData(VertexBuffer.UV6Kind, parsedGeometry.uvs6, parsedGeometry.uvs6._updatable);\r\n }\r\n if (parsedGeometry.colors) {\r\n mesh.setVerticesData(VertexBuffer.ColorKind, Color4.CheckColors4(parsedGeometry.colors, parsedGeometry.positions.length / 3), parsedGeometry.colors._updatable);\r\n }\r\n if (parsedGeometry.matricesIndices) {\r\n if (!parsedGeometry.matricesIndices._isExpanded) {\r\n var floatIndices = [];\r\n for (var i = 0; i < parsedGeometry.matricesIndices.length; i++) {\r\n var matricesIndex = parsedGeometry.matricesIndices[i];\r\n floatIndices.push(matricesIndex & 0x000000ff);\r\n floatIndices.push((matricesIndex & 0x0000ff00) >> 8);\r\n floatIndices.push((matricesIndex & 0x00ff0000) >> 16);\r\n floatIndices.push((matricesIndex >> 24) & 0xff); // & 0xFF to convert to v + 256 if v < 0\r\n }\r\n mesh.setVerticesData(VertexBuffer.MatricesIndicesKind, floatIndices, parsedGeometry.matricesIndices._updatable);\r\n }\r\n else {\r\n delete parsedGeometry.matricesIndices._isExpanded;\r\n mesh.setVerticesData(VertexBuffer.MatricesIndicesKind, parsedGeometry.matricesIndices, parsedGeometry.matricesIndices._updatable);\r\n }\r\n }\r\n if (parsedGeometry.matricesIndicesExtra) {\r\n if (!parsedGeometry.matricesIndicesExtra._isExpanded) {\r\n var floatIndices = [];\r\n for (var i = 0; i < parsedGeometry.matricesIndicesExtra.length; i++) {\r\n var matricesIndex = parsedGeometry.matricesIndicesExtra[i];\r\n floatIndices.push(matricesIndex & 0x000000ff);\r\n floatIndices.push((matricesIndex & 0x0000ff00) >> 8);\r\n floatIndices.push((matricesIndex & 0x00ff0000) >> 16);\r\n floatIndices.push((matricesIndex >> 24) & 0xff); // & 0xFF to convert to v + 256 if v < 0\r\n }\r\n mesh.setVerticesData(VertexBuffer.MatricesIndicesExtraKind, floatIndices, parsedGeometry.matricesIndicesExtra._updatable);\r\n }\r\n else {\r\n delete parsedGeometry.matricesIndices._isExpanded;\r\n mesh.setVerticesData(VertexBuffer.MatricesIndicesExtraKind, parsedGeometry.matricesIndicesExtra, parsedGeometry.matricesIndicesExtra._updatable);\r\n }\r\n }\r\n if (parsedGeometry.matricesWeights) {\r\n Geometry._CleanMatricesWeights(parsedGeometry, mesh);\r\n mesh.setVerticesData(VertexBuffer.MatricesWeightsKind, parsedGeometry.matricesWeights, parsedGeometry.matricesWeights._updatable);\r\n }\r\n if (parsedGeometry.matricesWeightsExtra) {\r\n mesh.setVerticesData(VertexBuffer.MatricesWeightsExtraKind, parsedGeometry.matricesWeightsExtra, parsedGeometry.matricesWeights._updatable);\r\n }\r\n mesh.setIndices(parsedGeometry.indices, null);\r\n }\r\n // SubMeshes\r\n if (parsedGeometry.subMeshes) {\r\n mesh.subMeshes = [];\r\n for (var subIndex = 0; subIndex < parsedGeometry.subMeshes.length; subIndex++) {\r\n var parsedSubMesh = parsedGeometry.subMeshes[subIndex];\r\n SubMesh.AddToMesh(parsedSubMesh.materialIndex, parsedSubMesh.verticesStart, parsedSubMesh.verticesCount, parsedSubMesh.indexStart, parsedSubMesh.indexCount, mesh);\r\n }\r\n }\r\n // Flat shading\r\n if (mesh._shouldGenerateFlatShading) {\r\n mesh.convertToFlatShadedMesh();\r\n mesh._shouldGenerateFlatShading = false;\r\n }\r\n // Update\r\n mesh.computeWorldMatrix(true);\r\n scene.onMeshImportedObservable.notifyObservers(mesh);\r\n };\r\n Geometry._CleanMatricesWeights = function (parsedGeometry, mesh) {\r\n var epsilon = 1e-3;\r\n if (!SceneLoaderFlags.CleanBoneMatrixWeights) {\r\n return;\r\n }\r\n var noInfluenceBoneIndex = 0.0;\r\n if (parsedGeometry.skeletonId > -1) {\r\n var skeleton = mesh.getScene().getLastSkeletonByID(parsedGeometry.skeletonId);\r\n if (!skeleton) {\r\n return;\r\n }\r\n noInfluenceBoneIndex = skeleton.bones.length;\r\n }\r\n else {\r\n return;\r\n }\r\n var matricesIndices = mesh.getVerticesData(VertexBuffer.MatricesIndicesKind);\r\n var matricesIndicesExtra = mesh.getVerticesData(VertexBuffer.MatricesIndicesExtraKind);\r\n var matricesWeights = parsedGeometry.matricesWeights;\r\n var matricesWeightsExtra = parsedGeometry.matricesWeightsExtra;\r\n var influencers = parsedGeometry.numBoneInfluencer;\r\n var size = matricesWeights.length;\r\n for (var i = 0; i < size; i += 4) {\r\n var weight = 0.0;\r\n var firstZeroWeight = -1;\r\n for (var j = 0; j < 4; j++) {\r\n var w = matricesWeights[i + j];\r\n weight += w;\r\n if (w < epsilon && firstZeroWeight < 0) {\r\n firstZeroWeight = j;\r\n }\r\n }\r\n if (matricesWeightsExtra) {\r\n for (var j = 0; j < 4; j++) {\r\n var w = matricesWeightsExtra[i + j];\r\n weight += w;\r\n if (w < epsilon && firstZeroWeight < 0) {\r\n firstZeroWeight = j + 4;\r\n }\r\n }\r\n }\r\n if (firstZeroWeight < 0 || firstZeroWeight > influencers - 1) {\r\n firstZeroWeight = influencers - 1;\r\n }\r\n if (weight > epsilon) {\r\n var mweight = 1.0 / weight;\r\n for (var j = 0; j < 4; j++) {\r\n matricesWeights[i + j] *= mweight;\r\n }\r\n if (matricesWeightsExtra) {\r\n for (var j = 0; j < 4; j++) {\r\n matricesWeightsExtra[i + j] *= mweight;\r\n }\r\n }\r\n }\r\n else {\r\n if (firstZeroWeight >= 4) {\r\n matricesWeightsExtra[i + firstZeroWeight - 4] = 1.0 - weight;\r\n matricesIndicesExtra[i + firstZeroWeight - 4] = noInfluenceBoneIndex;\r\n }\r\n else {\r\n matricesWeights[i + firstZeroWeight] = 1.0 - weight;\r\n matricesIndices[i + firstZeroWeight] = noInfluenceBoneIndex;\r\n }\r\n }\r\n }\r\n mesh.setVerticesData(VertexBuffer.MatricesIndicesKind, matricesIndices);\r\n if (parsedGeometry.matricesWeightsExtra) {\r\n mesh.setVerticesData(VertexBuffer.MatricesIndicesExtraKind, matricesIndicesExtra);\r\n }\r\n };\r\n /**\r\n * Create a new geometry from persisted data (Using .babylon file format)\r\n * @param parsedVertexData defines the persisted data\r\n * @param scene defines the hosting scene\r\n * @param rootUrl defines the root url to use to load assets (like delayed data)\r\n * @returns the new geometry object\r\n */\r\n Geometry.Parse = function (parsedVertexData, scene, rootUrl) {\r\n if (scene.getGeometryByID(parsedVertexData.id)) {\r\n return null; // null since geometry could be something else than a box...\r\n }\r\n var geometry = new Geometry(parsedVertexData.id, scene, undefined, parsedVertexData.updatable);\r\n if (Tags) {\r\n Tags.AddTagsTo(geometry, parsedVertexData.tags);\r\n }\r\n if (parsedVertexData.delayLoadingFile) {\r\n geometry.delayLoadState = 4;\r\n geometry.delayLoadingFile = rootUrl + parsedVertexData.delayLoadingFile;\r\n geometry._boundingInfo = new BoundingInfo(Vector3.FromArray(parsedVertexData.boundingBoxMinimum), Vector3.FromArray(parsedVertexData.boundingBoxMaximum));\r\n geometry._delayInfo = [];\r\n if (parsedVertexData.hasUVs) {\r\n geometry._delayInfo.push(VertexBuffer.UVKind);\r\n }\r\n if (parsedVertexData.hasUVs2) {\r\n geometry._delayInfo.push(VertexBuffer.UV2Kind);\r\n }\r\n if (parsedVertexData.hasUVs3) {\r\n geometry._delayInfo.push(VertexBuffer.UV3Kind);\r\n }\r\n if (parsedVertexData.hasUVs4) {\r\n geometry._delayInfo.push(VertexBuffer.UV4Kind);\r\n }\r\n if (parsedVertexData.hasUVs5) {\r\n geometry._delayInfo.push(VertexBuffer.UV5Kind);\r\n }\r\n if (parsedVertexData.hasUVs6) {\r\n geometry._delayInfo.push(VertexBuffer.UV6Kind);\r\n }\r\n if (parsedVertexData.hasColors) {\r\n geometry._delayInfo.push(VertexBuffer.ColorKind);\r\n }\r\n if (parsedVertexData.hasMatricesIndices) {\r\n geometry._delayInfo.push(VertexBuffer.MatricesIndicesKind);\r\n }\r\n if (parsedVertexData.hasMatricesWeights) {\r\n geometry._delayInfo.push(VertexBuffer.MatricesWeightsKind);\r\n }\r\n geometry._delayLoadingFunction = VertexData.ImportVertexData;\r\n }\r\n else {\r\n VertexData.ImportVertexData(parsedVertexData, geometry);\r\n }\r\n scene.pushGeometry(geometry, true);\r\n return geometry;\r\n };\r\n return Geometry;\r\n}());\r\nexport { Geometry };\r\n//# sourceMappingURL=geometry.js.map","import { __extends } from \"tslib\";\r\nimport { Material } from \"../Materials/material\";\r\nimport { Tags } from \"../Misc/tags\";\r\nimport { _TypeStore } from '../Misc/typeStore';\r\n/**\r\n * A multi-material is used to apply different materials to different parts of the same object without the need of\r\n * separate meshes. This can be use to improve performances.\r\n * @see https://doc.babylonjs.com/how_to/multi_materials\r\n */\r\nvar MultiMaterial = /** @class */ (function (_super) {\r\n __extends(MultiMaterial, _super);\r\n /**\r\n * Instantiates a new Multi Material\r\n * A multi-material is used to apply different materials to different parts of the same object without the need of\r\n * separate meshes. This can be use to improve performances.\r\n * @see https://doc.babylonjs.com/how_to/multi_materials\r\n * @param name Define the name in the scene\r\n * @param scene Define the scene the material belongs to\r\n */\r\n function MultiMaterial(name, scene) {\r\n var _this = _super.call(this, name, scene, true) || this;\r\n scene.multiMaterials.push(_this);\r\n _this.subMaterials = new Array();\r\n _this._storeEffectOnSubMeshes = true; // multimaterial is considered like a push material\r\n return _this;\r\n }\r\n Object.defineProperty(MultiMaterial.prototype, \"subMaterials\", {\r\n /**\r\n * Gets or Sets the list of Materials used within the multi material.\r\n * They need to be ordered according to the submeshes order in the associated mesh\r\n */\r\n get: function () {\r\n return this._subMaterials;\r\n },\r\n set: function (value) {\r\n this._subMaterials = value;\r\n this._hookArray(value);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Function used to align with Node.getChildren()\r\n * @returns the list of Materials used within the multi material\r\n */\r\n MultiMaterial.prototype.getChildren = function () {\r\n return this.subMaterials;\r\n };\r\n MultiMaterial.prototype._hookArray = function (array) {\r\n var _this = this;\r\n var oldPush = array.push;\r\n array.push = function () {\r\n var items = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n items[_i] = arguments[_i];\r\n }\r\n var result = oldPush.apply(array, items);\r\n _this._markAllSubMeshesAsTexturesDirty();\r\n return result;\r\n };\r\n var oldSplice = array.splice;\r\n array.splice = function (index, deleteCount) {\r\n var deleted = oldSplice.apply(array, [index, deleteCount]);\r\n _this._markAllSubMeshesAsTexturesDirty();\r\n return deleted;\r\n };\r\n };\r\n /**\r\n * Get one of the submaterial by its index in the submaterials array\r\n * @param index The index to look the sub material at\r\n * @returns The Material if the index has been defined\r\n */\r\n MultiMaterial.prototype.getSubMaterial = function (index) {\r\n if (index < 0 || index >= this.subMaterials.length) {\r\n return this.getScene().defaultMaterial;\r\n }\r\n return this.subMaterials[index];\r\n };\r\n /**\r\n * Get the list of active textures for the whole sub materials list.\r\n * @returns All the textures that will be used during the rendering\r\n */\r\n MultiMaterial.prototype.getActiveTextures = function () {\r\n var _a;\r\n return (_a = _super.prototype.getActiveTextures.call(this)).concat.apply(_a, this.subMaterials.map(function (subMaterial) {\r\n if (subMaterial) {\r\n return subMaterial.getActiveTextures();\r\n }\r\n else {\r\n return [];\r\n }\r\n }));\r\n };\r\n /**\r\n * Specifies if any sub-materials of this multi-material use a given texture.\r\n * @param texture Defines the texture to check against this multi-material's sub-materials.\r\n * @returns A boolean specifying if any sub-material of this multi-material uses the texture.\r\n */\r\n MultiMaterial.prototype.hasTexture = function (texture) {\r\n var _a;\r\n if (_super.prototype.hasTexture.call(this, texture)) {\r\n return true;\r\n }\r\n for (var i = 0; i < this.subMaterials.length; i++) {\r\n if ((_a = this.subMaterials[i]) === null || _a === void 0 ? void 0 : _a.hasTexture(texture)) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n };\r\n /**\r\n * Gets the current class name of the material e.g. \"MultiMaterial\"\r\n * Mainly use in serialization.\r\n * @returns the class name\r\n */\r\n MultiMaterial.prototype.getClassName = function () {\r\n return \"MultiMaterial\";\r\n };\r\n /**\r\n * Checks if the material is ready to render the requested sub mesh\r\n * @param mesh Define the mesh the submesh belongs to\r\n * @param subMesh Define the sub mesh to look readyness for\r\n * @param useInstances Define whether or not the material is used with instances\r\n * @returns true if ready, otherwise false\r\n */\r\n MultiMaterial.prototype.isReadyForSubMesh = function (mesh, subMesh, useInstances) {\r\n for (var index = 0; index < this.subMaterials.length; index++) {\r\n var subMaterial = this.subMaterials[index];\r\n if (subMaterial) {\r\n if (subMaterial._storeEffectOnSubMeshes) {\r\n if (!subMaterial.isReadyForSubMesh(mesh, subMesh, useInstances)) {\r\n return false;\r\n }\r\n continue;\r\n }\r\n if (!subMaterial.isReady(mesh)) {\r\n return false;\r\n }\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Clones the current material and its related sub materials\r\n * @param name Define the name of the newly cloned material\r\n * @param cloneChildren Define if submaterial will be cloned or shared with the parent instance\r\n * @returns the cloned material\r\n */\r\n MultiMaterial.prototype.clone = function (name, cloneChildren) {\r\n var newMultiMaterial = new MultiMaterial(name, this.getScene());\r\n for (var index = 0; index < this.subMaterials.length; index++) {\r\n var subMaterial = null;\r\n var current = this.subMaterials[index];\r\n if (cloneChildren && current) {\r\n subMaterial = current.clone(name + \"-\" + current.name);\r\n }\r\n else {\r\n subMaterial = this.subMaterials[index];\r\n }\r\n newMultiMaterial.subMaterials.push(subMaterial);\r\n }\r\n return newMultiMaterial;\r\n };\r\n /**\r\n * Serializes the materials into a JSON representation.\r\n * @returns the JSON representation\r\n */\r\n MultiMaterial.prototype.serialize = function () {\r\n var serializationObject = {};\r\n serializationObject.name = this.name;\r\n serializationObject.id = this.id;\r\n if (Tags) {\r\n serializationObject.tags = Tags.GetTags(this);\r\n }\r\n serializationObject.materials = [];\r\n for (var matIndex = 0; matIndex < this.subMaterials.length; matIndex++) {\r\n var subMat = this.subMaterials[matIndex];\r\n if (subMat) {\r\n serializationObject.materials.push(subMat.id);\r\n }\r\n else {\r\n serializationObject.materials.push(null);\r\n }\r\n }\r\n return serializationObject;\r\n };\r\n /**\r\n * Dispose the material and release its associated resources\r\n * @param forceDisposeEffect Define if we want to force disposing the associated effect (if false the shader is not released and could be reuse later on)\r\n * @param forceDisposeTextures Define if we want to force disposing the associated textures (if false, they will not be disposed and can still be use elsewhere in the app)\r\n * @param forceDisposeChildren Define if we want to force disposing the associated submaterials (if false, they will not be disposed and can still be use elsewhere in the app)\r\n */\r\n MultiMaterial.prototype.dispose = function (forceDisposeEffect, forceDisposeTextures, forceDisposeChildren) {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n if (forceDisposeChildren) {\r\n for (var index = 0; index < this.subMaterials.length; index++) {\r\n var subMaterial = this.subMaterials[index];\r\n if (subMaterial) {\r\n subMaterial.dispose(forceDisposeEffect, forceDisposeTextures);\r\n }\r\n }\r\n }\r\n var index = scene.multiMaterials.indexOf(this);\r\n if (index >= 0) {\r\n scene.multiMaterials.splice(index, 1);\r\n }\r\n _super.prototype.dispose.call(this, forceDisposeEffect, forceDisposeTextures);\r\n };\r\n /**\r\n * Creates a MultiMaterial from parsed MultiMaterial data.\r\n * @param parsedMultiMaterial defines parsed MultiMaterial data.\r\n * @param scene defines the hosting scene\r\n * @returns a new MultiMaterial\r\n */\r\n MultiMaterial.ParseMultiMaterial = function (parsedMultiMaterial, scene) {\r\n var multiMaterial = new MultiMaterial(parsedMultiMaterial.name, scene);\r\n multiMaterial.id = parsedMultiMaterial.id;\r\n if (Tags) {\r\n Tags.AddTagsTo(multiMaterial, parsedMultiMaterial.tags);\r\n }\r\n for (var matIndex = 0; matIndex < parsedMultiMaterial.materials.length; matIndex++) {\r\n var subMatId = parsedMultiMaterial.materials[matIndex];\r\n if (subMatId) {\r\n // If the same multimaterial is loaded twice, the 2nd multimaterial needs to reference the latest material by that id which\r\n // is why this lookup should use getLastMaterialByID instead of getMaterialByID\r\n multiMaterial.subMaterials.push(scene.getLastMaterialByID(subMatId));\r\n }\r\n else {\r\n multiMaterial.subMaterials.push(null);\r\n }\r\n }\r\n return multiMaterial;\r\n };\r\n return MultiMaterial;\r\n}(Material));\r\nexport { MultiMaterial };\r\n_TypeStore.RegisteredTypes[\"BABYLON.MultiMaterial\"] = MultiMaterial;\r\n//# sourceMappingURL=multiMaterial.js.map","/**\r\n * Class used to represent a specific level of detail of a mesh\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_lod\r\n */\r\nvar MeshLODLevel = /** @class */ (function () {\r\n /**\r\n * Creates a new LOD level\r\n * @param distance defines the distance where this level should star being displayed\r\n * @param mesh defines the mesh to use to render this level\r\n */\r\n function MeshLODLevel(\r\n /** Defines the distance where this level should start being displayed */\r\n distance, \r\n /** Defines the mesh to use to render this level */\r\n mesh) {\r\n this.distance = distance;\r\n this.mesh = mesh;\r\n }\r\n return MeshLODLevel;\r\n}());\r\nexport { MeshLODLevel };\r\n//# sourceMappingURL=meshLODLevel.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { Tools, AsyncLoop } from \"../Misc/tools\";\r\nimport { DeepCopier } from \"../Misc/deepCopier\";\r\nimport { Tags } from \"../Misc/tags\";\r\nimport { Quaternion, Matrix, Vector3, Vector2 } from \"../Maths/math.vector\";\r\nimport { Color3 } from '../Maths/math.color';\r\nimport { Node } from \"../node\";\r\nimport { VertexBuffer } from \"./buffer\";\r\nimport { VertexData } from \"./mesh.vertexData\";\r\nimport { Buffer } from \"./buffer\";\r\nimport { Geometry } from \"./geometry\";\r\nimport { AbstractMesh } from \"./abstractMesh\";\r\nimport { SubMesh } from \"./subMesh\";\r\nimport { BoundingInfo } from \"../Culling/boundingInfo\";\r\nimport { Material } from \"../Materials/material\";\r\nimport { MultiMaterial } from \"../Materials/multiMaterial\";\r\nimport { SceneLoaderFlags } from \"../Loading/sceneLoaderFlags\";\r\nimport { SerializationHelper } from \"../Misc/decorators\";\r\nimport { Logger } from \"../Misc/logger\";\r\nimport { _TypeStore } from '../Misc/typeStore';\r\nimport { _DevTools } from '../Misc/devTools';\r\nimport { SceneComponentConstants } from \"../sceneComponent\";\r\nimport { MeshLODLevel } from './meshLODLevel';\r\nimport { CanvasGenerator } from '../Misc/canvasGenerator';\r\n/**\r\n * @hidden\r\n **/\r\nvar _CreationDataStorage = /** @class */ (function () {\r\n function _CreationDataStorage() {\r\n }\r\n return _CreationDataStorage;\r\n}());\r\nexport { _CreationDataStorage };\r\n/**\r\n * @hidden\r\n **/\r\nvar _InstanceDataStorage = /** @class */ (function () {\r\n function _InstanceDataStorage() {\r\n this.visibleInstances = {};\r\n this.batchCache = new _InstancesBatch();\r\n this.instancesBufferSize = 32 * 16 * 4; // let's start with a maximum of 32 instances\r\n }\r\n return _InstanceDataStorage;\r\n}());\r\n/**\r\n * @hidden\r\n **/\r\nvar _InstancesBatch = /** @class */ (function () {\r\n function _InstancesBatch() {\r\n this.mustReturn = false;\r\n this.visibleInstances = new Array();\r\n this.renderSelf = new Array();\r\n this.hardwareInstancedRendering = new Array();\r\n }\r\n return _InstancesBatch;\r\n}());\r\nexport { _InstancesBatch };\r\n/**\r\n * @hidden\r\n **/\r\nvar _ThinInstanceDataStorage = /** @class */ (function () {\r\n function _ThinInstanceDataStorage() {\r\n this.instancesCount = 0;\r\n this.matrixBuffer = null;\r\n this.matrixBufferSize = 32 * 16; // let's start with a maximum of 32 thin instances\r\n this.boundingVectors = [];\r\n this.worldMatrices = null;\r\n }\r\n return _ThinInstanceDataStorage;\r\n}());\r\n/**\r\n * @hidden\r\n **/\r\nvar _InternalMeshDataInfo = /** @class */ (function () {\r\n function _InternalMeshDataInfo() {\r\n this._areNormalsFrozen = false; // Will be used by ribbons mainly\r\n // Will be used to save a source mesh reference, If any\r\n this._source = null;\r\n // Will be used to for fast cloned mesh lookup\r\n this.meshMap = null;\r\n this._preActivateId = -1;\r\n this._LODLevels = new Array();\r\n // Morph\r\n this._morphTargetManager = null;\r\n }\r\n return _InternalMeshDataInfo;\r\n}());\r\n/**\r\n * Class used to represent renderable models\r\n */\r\nvar Mesh = /** @class */ (function (_super) {\r\n __extends(Mesh, _super);\r\n /**\r\n * @constructor\r\n * @param name The value used by scene.getMeshByName() to do a lookup.\r\n * @param scene The scene to add this mesh to.\r\n * @param parent The parent of this mesh, if it has one\r\n * @param source An optional Mesh from which geometry is shared, cloned.\r\n * @param doNotCloneChildren When cloning, skip cloning child meshes of source, default False.\r\n * When false, achieved by calling a clone(), also passing False.\r\n * This will make creation of children, recursive.\r\n * @param clonePhysicsImpostor When cloning, include cloning mesh physics impostor, default True.\r\n */\r\n function Mesh(name, scene, parent, source, doNotCloneChildren, clonePhysicsImpostor) {\r\n if (scene === void 0) { scene = null; }\r\n if (parent === void 0) { parent = null; }\r\n if (source === void 0) { source = null; }\r\n if (clonePhysicsImpostor === void 0) { clonePhysicsImpostor = true; }\r\n var _this = _super.call(this, name, scene) || this;\r\n // Internal data\r\n _this._internalMeshDataInfo = new _InternalMeshDataInfo();\r\n // Members\r\n /**\r\n * Gets the delay loading state of the mesh (when delay loading is turned on)\r\n * @see https://doc.babylonjs.com/how_to/using_the_incremental_loading_system\r\n */\r\n _this.delayLoadState = 0;\r\n /**\r\n * Gets the list of instances created from this mesh\r\n * it is not supposed to be modified manually.\r\n * Note also that the order of the InstancedMesh wihin the array is not significant and might change.\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_instances\r\n */\r\n _this.instances = new Array();\r\n // Private\r\n /** @hidden */\r\n _this._creationDataStorage = null;\r\n /** @hidden */\r\n _this._geometry = null;\r\n /** @hidden */\r\n _this._instanceDataStorage = new _InstanceDataStorage();\r\n /** @hidden */\r\n _this._thinInstanceDataStorage = new _ThinInstanceDataStorage();\r\n _this._effectiveMaterial = null;\r\n /** @hidden */\r\n _this._shouldGenerateFlatShading = false;\r\n // Use by builder only to know what orientation were the mesh build in.\r\n /** @hidden */\r\n _this._originalBuilderSideOrientation = Mesh.DEFAULTSIDE;\r\n /**\r\n * Use this property to change the original side orientation defined at construction time\r\n */\r\n _this.overrideMaterialSideOrientation = null;\r\n scene = _this.getScene();\r\n if (source) {\r\n // Geometry\r\n if (source._geometry) {\r\n source._geometry.applyToMesh(_this);\r\n }\r\n // Deep copy\r\n DeepCopier.DeepCopy(source, _this, [\r\n \"name\", \"material\", \"skeleton\", \"instances\", \"parent\", \"uniqueId\", \"source\", \"metadata\", \"morphTargetManager\",\r\n \"hasInstances\", \"source\", \"worldMatrixInstancedBuffer\", \"hasLODLevels\", \"geometry\", \"isBlocked\", \"areNormalsFrozen\",\r\n \"facetNb\", \"isFacetDataEnabled\", \"lightSources\", \"useBones\", \"isAnInstance\", \"collider\", \"edgesRenderer\", \"forward\",\r\n \"up\", \"right\", \"absolutePosition\", \"absoluteScaling\", \"absoluteRotationQuaternion\", \"isWorldMatrixFrozen\",\r\n \"nonUniformScaling\", \"behaviors\", \"worldMatrixFromCache\", \"hasThinInstances\", \"cloneMeshMap\"\r\n ], [\"_poseMatrix\"]);\r\n // Source mesh\r\n _this._internalMeshDataInfo._source = source;\r\n if (scene.useClonedMeshMap) {\r\n if (!source._internalMeshDataInfo.meshMap) {\r\n source._internalMeshDataInfo.meshMap = {};\r\n }\r\n source._internalMeshDataInfo.meshMap[_this.uniqueId] = _this;\r\n }\r\n // Construction Params\r\n // Clone parameters allowing mesh to be updated in case of parametric shapes.\r\n _this._originalBuilderSideOrientation = source._originalBuilderSideOrientation;\r\n _this._creationDataStorage = source._creationDataStorage;\r\n // Animation ranges\r\n if (source._ranges) {\r\n var ranges = source._ranges;\r\n for (var name in ranges) {\r\n if (!ranges.hasOwnProperty(name)) {\r\n continue;\r\n }\r\n if (!ranges[name]) {\r\n continue;\r\n }\r\n _this.createAnimationRange(name, ranges[name].from, ranges[name].to);\r\n }\r\n }\r\n // Metadata\r\n if (source.metadata && source.metadata.clone) {\r\n _this.metadata = source.metadata.clone();\r\n }\r\n else {\r\n _this.metadata = source.metadata;\r\n }\r\n // Tags\r\n if (Tags && Tags.HasTags(source)) {\r\n Tags.AddTagsTo(_this, Tags.GetTags(source, true));\r\n }\r\n // Enabled\r\n _this.setEnabled(source.isEnabled());\r\n // Parent\r\n _this.parent = source.parent;\r\n // Pivot\r\n _this.setPivotMatrix(source.getPivotMatrix());\r\n _this.id = name + \".\" + source.id;\r\n // Material\r\n _this.material = source.material;\r\n var index;\r\n if (!doNotCloneChildren) {\r\n // Children\r\n var directDescendants = source.getDescendants(true);\r\n for (var index_1 = 0; index_1 < directDescendants.length; index_1++) {\r\n var child = directDescendants[index_1];\r\n if (child.clone) {\r\n child.clone(name + \".\" + child.name, _this);\r\n }\r\n }\r\n }\r\n // Morphs\r\n if (source.morphTargetManager) {\r\n _this.morphTargetManager = source.morphTargetManager;\r\n }\r\n // Physics clone\r\n if (scene.getPhysicsEngine) {\r\n var physicsEngine = scene.getPhysicsEngine();\r\n if (clonePhysicsImpostor && physicsEngine) {\r\n var impostor = physicsEngine.getImpostorForPhysicsObject(source);\r\n if (impostor) {\r\n _this.physicsImpostor = impostor.clone(_this);\r\n }\r\n }\r\n }\r\n // Particles\r\n for (index = 0; index < scene.particleSystems.length; index++) {\r\n var system = scene.particleSystems[index];\r\n if (system.emitter === source) {\r\n system.clone(system.name, _this);\r\n }\r\n }\r\n _this.refreshBoundingInfo();\r\n _this.computeWorldMatrix(true);\r\n }\r\n // Parent\r\n if (parent !== null) {\r\n _this.parent = parent;\r\n }\r\n _this._instanceDataStorage.hardwareInstancedRendering = _this.getEngine().getCaps().instancedArrays;\r\n return _this;\r\n }\r\n /**\r\n * Gets the default side orientation.\r\n * @param orientation the orientation to value to attempt to get\r\n * @returns the default orientation\r\n * @hidden\r\n */\r\n Mesh._GetDefaultSideOrientation = function (orientation) {\r\n return orientation || Mesh.FRONTSIDE; // works as Mesh.FRONTSIDE is 0\r\n };\r\n Object.defineProperty(Mesh.prototype, \"computeBonesUsingShaders\", {\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._computeBonesUsingShaders;\r\n },\r\n set: function (value) {\r\n if (this._internalAbstractMeshDataInfo._computeBonesUsingShaders === value) {\r\n return;\r\n }\r\n if (value && this._internalMeshDataInfo._sourcePositions) {\r\n // switch from software to GPU computation: we need to reset the vertex and normal buffers that have been updated by the software process\r\n this.setVerticesData(VertexBuffer.PositionKind, this._internalMeshDataInfo._sourcePositions.slice(), true);\r\n if (this._internalMeshDataInfo._sourceNormals) {\r\n this.setVerticesData(VertexBuffer.NormalKind, this._internalMeshDataInfo._sourceNormals.slice(), true);\r\n }\r\n }\r\n this._internalAbstractMeshDataInfo._computeBonesUsingShaders = value;\r\n this._markSubMeshesAsAttributesDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"onBeforeRenderObservable\", {\r\n /**\r\n * An event triggered before rendering the mesh\r\n */\r\n get: function () {\r\n if (!this._internalMeshDataInfo._onBeforeRenderObservable) {\r\n this._internalMeshDataInfo._onBeforeRenderObservable = new Observable();\r\n }\r\n return this._internalMeshDataInfo._onBeforeRenderObservable;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"onBeforeBindObservable\", {\r\n /**\r\n * An event triggered before binding the mesh\r\n */\r\n get: function () {\r\n if (!this._internalMeshDataInfo._onBeforeBindObservable) {\r\n this._internalMeshDataInfo._onBeforeBindObservable = new Observable();\r\n }\r\n return this._internalMeshDataInfo._onBeforeBindObservable;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"onAfterRenderObservable\", {\r\n /**\r\n * An event triggered after rendering the mesh\r\n */\r\n get: function () {\r\n if (!this._internalMeshDataInfo._onAfterRenderObservable) {\r\n this._internalMeshDataInfo._onAfterRenderObservable = new Observable();\r\n }\r\n return this._internalMeshDataInfo._onAfterRenderObservable;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"onBeforeDrawObservable\", {\r\n /**\r\n * An event triggered before drawing the mesh\r\n */\r\n get: function () {\r\n if (!this._internalMeshDataInfo._onBeforeDrawObservable) {\r\n this._internalMeshDataInfo._onBeforeDrawObservable = new Observable();\r\n }\r\n return this._internalMeshDataInfo._onBeforeDrawObservable;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"onBeforeDraw\", {\r\n /**\r\n * Sets a callback to call before drawing the mesh. It is recommended to use onBeforeDrawObservable instead\r\n */\r\n set: function (callback) {\r\n if (this._onBeforeDrawObserver) {\r\n this.onBeforeDrawObservable.remove(this._onBeforeDrawObserver);\r\n }\r\n this._onBeforeDrawObserver = this.onBeforeDrawObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"hasInstances\", {\r\n get: function () {\r\n return this.instances.length > 0;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"hasThinInstances\", {\r\n get: function () {\r\n var _a;\r\n return ((_a = this._thinInstanceDataStorage.instancesCount) !== null && _a !== void 0 ? _a : 0) > 0;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"morphTargetManager\", {\r\n /**\r\n * Gets or sets the morph target manager\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_morphtargets\r\n */\r\n get: function () {\r\n return this._internalMeshDataInfo._morphTargetManager;\r\n },\r\n set: function (value) {\r\n if (this._internalMeshDataInfo._morphTargetManager === value) {\r\n return;\r\n }\r\n this._internalMeshDataInfo._morphTargetManager = value;\r\n this._syncGeometryWithMorphTargetManager();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"source\", {\r\n /**\r\n * Gets the source mesh (the one used to clone this one from)\r\n */\r\n get: function () {\r\n return this._internalMeshDataInfo._source;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"cloneMeshMap\", {\r\n /**\r\n * Gets the list of clones of this mesh\r\n * The scene must have been constructed with useClonedMeshMap=true for this to work!\r\n * Note that useClonedMeshMap=true is the default setting\r\n */\r\n get: function () {\r\n return this._internalMeshDataInfo.meshMap;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"isUnIndexed\", {\r\n /**\r\n * Gets or sets a boolean indicating that this mesh does not use index buffer\r\n */\r\n get: function () {\r\n return this._unIndexed;\r\n },\r\n set: function (value) {\r\n if (this._unIndexed !== value) {\r\n this._unIndexed = value;\r\n this._markSubMeshesAsAttributesDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"worldMatrixInstancedBuffer\", {\r\n /** Gets the array buffer used to store the instanced buffer used for instances' world matrices */\r\n get: function () {\r\n return this._instanceDataStorage.instancesData;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Mesh.prototype, \"manualUpdateOfWorldMatrixInstancedBuffer\", {\r\n /** Gets or sets a boolean indicating that the update of the instance buffer of the world matrices is manual */\r\n get: function () {\r\n return this._instanceDataStorage.manualUpdate;\r\n },\r\n set: function (value) {\r\n this._instanceDataStorage.manualUpdate = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n // Methods\r\n Mesh.prototype.instantiateHierarchy = function (newParent, options, onNewNodeCreated) {\r\n if (newParent === void 0) { newParent = null; }\r\n var instance = (this.getTotalVertices() > 0 && (!options || !options.doNotInstantiate)) ? this.createInstance(\"instance of \" + (this.name || this.id)) : this.clone(\"Clone of \" + (this.name || this.id), newParent || this.parent, true);\r\n if (instance) {\r\n instance.parent = newParent || this.parent;\r\n instance.position = this.position.clone();\r\n instance.scaling = this.scaling.clone();\r\n if (this.rotationQuaternion) {\r\n instance.rotationQuaternion = this.rotationQuaternion.clone();\r\n }\r\n else {\r\n instance.rotation = this.rotation.clone();\r\n }\r\n if (onNewNodeCreated) {\r\n onNewNodeCreated(this, instance);\r\n }\r\n }\r\n for (var _i = 0, _a = this.getChildTransformNodes(true); _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child.instantiateHierarchy(instance, options, onNewNodeCreated);\r\n }\r\n return instance;\r\n };\r\n /**\r\n * Gets the class name\r\n * @returns the string \"Mesh\".\r\n */\r\n Mesh.prototype.getClassName = function () {\r\n return \"Mesh\";\r\n };\r\n Object.defineProperty(Mesh.prototype, \"_isMesh\", {\r\n /** @hidden */\r\n get: function () {\r\n return true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Returns a description of this mesh\r\n * @param fullDetails define if full details about this mesh must be used\r\n * @returns a descriptive string representing this mesh\r\n */\r\n Mesh.prototype.toString = function (fullDetails) {\r\n var ret = _super.prototype.toString.call(this, fullDetails);\r\n ret += \", n vertices: \" + this.getTotalVertices();\r\n ret += \", parent: \" + (this._waitingParentId ? this._waitingParentId : (this.parent ? this.parent.name : \"NONE\"));\r\n if (this.animations) {\r\n for (var i = 0; i < this.animations.length; i++) {\r\n ret += \", animation[0]: \" + this.animations[i].toString(fullDetails);\r\n }\r\n }\r\n if (fullDetails) {\r\n if (this._geometry) {\r\n var ib = this.getIndices();\r\n var vb = this.getVerticesData(VertexBuffer.PositionKind);\r\n if (vb && ib) {\r\n ret += \", flat shading: \" + (vb.length / 3 === ib.length ? \"YES\" : \"NO\");\r\n }\r\n }\r\n else {\r\n ret += \", flat shading: UNKNOWN\";\r\n }\r\n }\r\n return ret;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._unBindEffect = function () {\r\n _super.prototype._unBindEffect.call(this);\r\n for (var _i = 0, _a = this.instances; _i < _a.length; _i++) {\r\n var instance = _a[_i];\r\n instance._unBindEffect();\r\n }\r\n };\r\n Object.defineProperty(Mesh.prototype, \"hasLODLevels\", {\r\n /**\r\n * Gets a boolean indicating if this mesh has LOD\r\n */\r\n get: function () {\r\n return this._internalMeshDataInfo._LODLevels.length > 0;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the list of MeshLODLevel associated with the current mesh\r\n * @returns an array of MeshLODLevel\r\n */\r\n Mesh.prototype.getLODLevels = function () {\r\n return this._internalMeshDataInfo._LODLevels;\r\n };\r\n Mesh.prototype._sortLODLevels = function () {\r\n this._internalMeshDataInfo._LODLevels.sort(function (a, b) {\r\n if (a.distance < b.distance) {\r\n return 1;\r\n }\r\n if (a.distance > b.distance) {\r\n return -1;\r\n }\r\n return 0;\r\n });\r\n };\r\n /**\r\n * Add a mesh as LOD level triggered at the given distance.\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_lod\r\n * @param distance The distance from the center of the object to show this level\r\n * @param mesh The mesh to be added as LOD level (can be null)\r\n * @return This mesh (for chaining)\r\n */\r\n Mesh.prototype.addLODLevel = function (distance, mesh) {\r\n if (mesh && mesh._masterMesh) {\r\n Logger.Warn(\"You cannot use a mesh as LOD level twice\");\r\n return this;\r\n }\r\n var level = new MeshLODLevel(distance, mesh);\r\n this._internalMeshDataInfo._LODLevels.push(level);\r\n if (mesh) {\r\n mesh._masterMesh = this;\r\n }\r\n this._sortLODLevels();\r\n return this;\r\n };\r\n /**\r\n * Returns the LOD level mesh at the passed distance or null if not found.\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_lod\r\n * @param distance The distance from the center of the object to show this level\r\n * @returns a Mesh or `null`\r\n */\r\n Mesh.prototype.getLODLevelAtDistance = function (distance) {\r\n var internalDataInfo = this._internalMeshDataInfo;\r\n for (var index = 0; index < internalDataInfo._LODLevels.length; index++) {\r\n var level = internalDataInfo._LODLevels[index];\r\n if (level.distance === distance) {\r\n return level.mesh;\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Remove a mesh from the LOD array\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_lod\r\n * @param mesh defines the mesh to be removed\r\n * @return This mesh (for chaining)\r\n */\r\n Mesh.prototype.removeLODLevel = function (mesh) {\r\n var internalDataInfo = this._internalMeshDataInfo;\r\n for (var index = 0; index < internalDataInfo._LODLevels.length; index++) {\r\n if (internalDataInfo._LODLevels[index].mesh === mesh) {\r\n internalDataInfo._LODLevels.splice(index, 1);\r\n if (mesh) {\r\n mesh._masterMesh = null;\r\n }\r\n }\r\n }\r\n this._sortLODLevels();\r\n return this;\r\n };\r\n /**\r\n * Returns the registered LOD mesh distant from the parameter `camera` position if any, else returns the current mesh.\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_lod\r\n * @param camera defines the camera to use to compute distance\r\n * @param boundingSphere defines a custom bounding sphere to use instead of the one from this mesh\r\n * @return This mesh (for chaining)\r\n */\r\n Mesh.prototype.getLOD = function (camera, boundingSphere) {\r\n var internalDataInfo = this._internalMeshDataInfo;\r\n if (!internalDataInfo._LODLevels || internalDataInfo._LODLevels.length === 0) {\r\n return this;\r\n }\r\n var bSphere;\r\n if (boundingSphere) {\r\n bSphere = boundingSphere;\r\n }\r\n else {\r\n var boundingInfo = this.getBoundingInfo();\r\n bSphere = boundingInfo.boundingSphere;\r\n }\r\n var distanceToCamera = bSphere.centerWorld.subtract(camera.globalPosition).length();\r\n if (internalDataInfo._LODLevels[internalDataInfo._LODLevels.length - 1].distance > distanceToCamera) {\r\n if (this.onLODLevelSelection) {\r\n this.onLODLevelSelection(distanceToCamera, this, this);\r\n }\r\n return this;\r\n }\r\n for (var index = 0; index < internalDataInfo._LODLevels.length; index++) {\r\n var level = internalDataInfo._LODLevels[index];\r\n if (level.distance < distanceToCamera) {\r\n if (level.mesh) {\r\n if (level.mesh.delayLoadState === 4) {\r\n level.mesh._checkDelayState();\r\n return this;\r\n }\r\n if (level.mesh.delayLoadState === 2) {\r\n return this;\r\n }\r\n level.mesh._preActivate();\r\n level.mesh._updateSubMeshesBoundingInfo(this.worldMatrixFromCache);\r\n }\r\n if (this.onLODLevelSelection) {\r\n this.onLODLevelSelection(distanceToCamera, this, level.mesh);\r\n }\r\n return level.mesh;\r\n }\r\n }\r\n if (this.onLODLevelSelection) {\r\n this.onLODLevelSelection(distanceToCamera, this, this);\r\n }\r\n return this;\r\n };\r\n Object.defineProperty(Mesh.prototype, \"geometry\", {\r\n /**\r\n * Gets the mesh internal Geometry object\r\n */\r\n get: function () {\r\n return this._geometry;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Returns the total number of vertices within the mesh geometry or zero if the mesh has no geometry.\r\n * @returns the total number of vertices\r\n */\r\n Mesh.prototype.getTotalVertices = function () {\r\n if (this._geometry === null || this._geometry === undefined) {\r\n return 0;\r\n }\r\n return this._geometry.getTotalVertices();\r\n };\r\n /**\r\n * Returns the content of an associated vertex buffer\r\n * @param kind defines which buffer to read from (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n * @param copyWhenShared defines a boolean indicating that if the mesh geometry is shared among some other meshes, the returned array is a copy of the internal one\r\n * @param forceCopy defines a boolean forcing the copy of the buffer no matter what the value of copyWhenShared is\r\n * @returns a FloatArray or null if the mesh has no geometry or no vertex buffer for this kind.\r\n */\r\n Mesh.prototype.getVerticesData = function (kind, copyWhenShared, forceCopy) {\r\n if (!this._geometry) {\r\n return null;\r\n }\r\n return this._geometry.getVerticesData(kind, copyWhenShared, forceCopy);\r\n };\r\n /**\r\n * Returns the mesh VertexBuffer object from the requested `kind`\r\n * @param kind defines which buffer to read from (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.NormalKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n * @returns a FloatArray or null if the mesh has no vertex buffer for this kind.\r\n */\r\n Mesh.prototype.getVertexBuffer = function (kind) {\r\n if (!this._geometry) {\r\n return null;\r\n }\r\n return this._geometry.getVertexBuffer(kind);\r\n };\r\n /**\r\n * Tests if a specific vertex buffer is associated with this mesh\r\n * @param kind defines which buffer to check (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.NormalKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n * @returns a boolean\r\n */\r\n Mesh.prototype.isVerticesDataPresent = function (kind) {\r\n if (!this._geometry) {\r\n if (this._delayInfo) {\r\n return this._delayInfo.indexOf(kind) !== -1;\r\n }\r\n return false;\r\n }\r\n return this._geometry.isVerticesDataPresent(kind);\r\n };\r\n /**\r\n * Returns a boolean defining if the vertex data for the requested `kind` is updatable.\r\n * @param kind defines which buffer to check (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n * @returns a boolean\r\n */\r\n Mesh.prototype.isVertexBufferUpdatable = function (kind) {\r\n if (!this._geometry) {\r\n if (this._delayInfo) {\r\n return this._delayInfo.indexOf(kind) !== -1;\r\n }\r\n return false;\r\n }\r\n return this._geometry.isVertexBufferUpdatable(kind);\r\n };\r\n /**\r\n * Returns a string which contains the list of existing `kinds` of Vertex Data associated with this mesh.\r\n * @param kind defines which buffer to read from (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.NormalKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n * @returns an array of strings\r\n */\r\n Mesh.prototype.getVerticesDataKinds = function () {\r\n if (!this._geometry) {\r\n var result = new Array();\r\n if (this._delayInfo) {\r\n this._delayInfo.forEach(function (kind) {\r\n result.push(kind);\r\n });\r\n }\r\n return result;\r\n }\r\n return this._geometry.getVerticesDataKinds();\r\n };\r\n /**\r\n * Returns a positive integer : the total number of indices in this mesh geometry.\r\n * @returns the numner of indices or zero if the mesh has no geometry.\r\n */\r\n Mesh.prototype.getTotalIndices = function () {\r\n if (!this._geometry) {\r\n return 0;\r\n }\r\n return this._geometry.getTotalIndices();\r\n };\r\n /**\r\n * Returns an array of integers or a typed array (Int32Array, Uint32Array, Uint16Array) populated with the mesh indices.\r\n * @param copyWhenShared If true (default false) and and if the mesh geometry is shared among some other meshes, the returned array is a copy of the internal one.\r\n * @param forceCopy defines a boolean indicating that the returned array must be cloned upon returning it\r\n * @returns the indices array or an empty array if the mesh has no geometry\r\n */\r\n Mesh.prototype.getIndices = function (copyWhenShared, forceCopy) {\r\n if (!this._geometry) {\r\n return [];\r\n }\r\n return this._geometry.getIndices(copyWhenShared, forceCopy);\r\n };\r\n Object.defineProperty(Mesh.prototype, \"isBlocked\", {\r\n get: function () {\r\n return this._masterMesh !== null && this._masterMesh !== undefined;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Determine if the current mesh is ready to be rendered\r\n * @param completeCheck defines if a complete check (including materials and lights) has to be done (false by default)\r\n * @param forceInstanceSupport will check if the mesh will be ready when used with instances (false by default)\r\n * @returns true if all associated assets are ready (material, textures, shaders)\r\n */\r\n Mesh.prototype.isReady = function (completeCheck, forceInstanceSupport) {\r\n var _a, _b, _c, _d, _e, _f;\r\n if (completeCheck === void 0) { completeCheck = false; }\r\n if (forceInstanceSupport === void 0) { forceInstanceSupport = false; }\r\n if (this.delayLoadState === 2) {\r\n return false;\r\n }\r\n if (!_super.prototype.isReady.call(this, completeCheck)) {\r\n return false;\r\n }\r\n if (!this.subMeshes || this.subMeshes.length === 0) {\r\n return true;\r\n }\r\n if (!completeCheck) {\r\n return true;\r\n }\r\n var engine = this.getEngine();\r\n var scene = this.getScene();\r\n var hardwareInstancedRendering = forceInstanceSupport || engine.getCaps().instancedArrays && (this.instances.length > 0 || this.hasThinInstances);\r\n this.computeWorldMatrix();\r\n var mat = this.material || scene.defaultMaterial;\r\n if (mat) {\r\n if (mat._storeEffectOnSubMeshes) {\r\n for (var _i = 0, _g = this.subMeshes; _i < _g.length; _i++) {\r\n var subMesh = _g[_i];\r\n var effectiveMaterial = subMesh.getMaterial();\r\n if (effectiveMaterial) {\r\n if (effectiveMaterial._storeEffectOnSubMeshes) {\r\n if (!effectiveMaterial.isReadyForSubMesh(this, subMesh, hardwareInstancedRendering)) {\r\n return false;\r\n }\r\n }\r\n else {\r\n if (!effectiveMaterial.isReady(this, hardwareInstancedRendering)) {\r\n return false;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n if (!mat.isReady(this, hardwareInstancedRendering)) {\r\n return false;\r\n }\r\n }\r\n }\r\n // Shadows\r\n for (var _h = 0, _j = this.lightSources; _h < _j.length; _h++) {\r\n var light = _j[_h];\r\n var generator = light.getShadowGenerator();\r\n if (generator && (!((_a = generator.getShadowMap()) === null || _a === void 0 ? void 0 : _a.renderList) || ((_b = generator.getShadowMap()) === null || _b === void 0 ? void 0 : _b.renderList) && ((_d = (_c = generator.getShadowMap()) === null || _c === void 0 ? void 0 : _c.renderList) === null || _d === void 0 ? void 0 : _d.indexOf(this)) !== -1)) {\r\n for (var _k = 0, _l = this.subMeshes; _k < _l.length; _k++) {\r\n var subMesh = _l[_k];\r\n if (!generator.isReady(subMesh, hardwareInstancedRendering, (_f = (_e = subMesh.getMaterial()) === null || _e === void 0 ? void 0 : _e.needAlphaBlendingForMesh(this)) !== null && _f !== void 0 ? _f : false)) {\r\n return false;\r\n }\r\n }\r\n }\r\n }\r\n // LOD\r\n for (var _m = 0, _o = this._internalMeshDataInfo._LODLevels; _m < _o.length; _m++) {\r\n var lod = _o[_m];\r\n if (lod.mesh && !lod.mesh.isReady(hardwareInstancedRendering)) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n Object.defineProperty(Mesh.prototype, \"areNormalsFrozen\", {\r\n /**\r\n * Gets a boolean indicating if the normals aren't to be recomputed on next mesh `positions` array update. This property is pertinent only for updatable parametric shapes.\r\n */\r\n get: function () {\r\n return this._internalMeshDataInfo._areNormalsFrozen;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * This function affects parametric shapes on vertex position update only : ribbons, tubes, etc. It has no effect at all on other shapes. It prevents the mesh normals from being recomputed on next `positions` array update.\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.freezeNormals = function () {\r\n this._internalMeshDataInfo._areNormalsFrozen = true;\r\n return this;\r\n };\r\n /**\r\n * This function affects parametric shapes on vertex position update only : ribbons, tubes, etc. It has no effect at all on other shapes. It reactivates the mesh normals computation if it was previously frozen\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.unfreezeNormals = function () {\r\n this._internalMeshDataInfo._areNormalsFrozen = false;\r\n return this;\r\n };\r\n Object.defineProperty(Mesh.prototype, \"overridenInstanceCount\", {\r\n /**\r\n * Sets a value overriding the instance count. Only applicable when custom instanced InterleavedVertexBuffer are used rather than InstancedMeshs\r\n */\r\n set: function (count) {\r\n this._instanceDataStorage.overridenInstanceCount = count;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n // Methods\r\n /** @hidden */\r\n Mesh.prototype._preActivate = function () {\r\n var internalDataInfo = this._internalMeshDataInfo;\r\n var sceneRenderId = this.getScene().getRenderId();\r\n if (internalDataInfo._preActivateId === sceneRenderId) {\r\n return this;\r\n }\r\n internalDataInfo._preActivateId = sceneRenderId;\r\n this._instanceDataStorage.visibleInstances = null;\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._preActivateForIntermediateRendering = function (renderId) {\r\n if (this._instanceDataStorage.visibleInstances) {\r\n this._instanceDataStorage.visibleInstances.intermediateDefaultRenderId = renderId;\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._registerInstanceForRenderId = function (instance, renderId) {\r\n if (!this._instanceDataStorage.visibleInstances) {\r\n this._instanceDataStorage.visibleInstances = {\r\n defaultRenderId: renderId,\r\n selfDefaultRenderId: this._renderId\r\n };\r\n }\r\n if (!this._instanceDataStorage.visibleInstances[renderId]) {\r\n if (this._instanceDataStorage.previousRenderId !== undefined && this._instanceDataStorage.isFrozen) {\r\n this._instanceDataStorage.visibleInstances[this._instanceDataStorage.previousRenderId] = null;\r\n }\r\n this._instanceDataStorage.previousRenderId = renderId;\r\n this._instanceDataStorage.visibleInstances[renderId] = new Array();\r\n }\r\n this._instanceDataStorage.visibleInstances[renderId].push(instance);\r\n return this;\r\n };\r\n Mesh.prototype._afterComputeWorldMatrix = function () {\r\n _super.prototype._afterComputeWorldMatrix.call(this);\r\n if (!this.hasThinInstances) {\r\n return;\r\n }\r\n if (!this.doNotSyncBoundingInfo) {\r\n this.thinInstanceRefreshBoundingInfo(false);\r\n }\r\n };\r\n /** @hidden */\r\n Mesh.prototype._postActivate = function () {\r\n if (this.edgesShareWithInstances && this.edgesRenderer && this.edgesRenderer.isEnabled && this._renderingGroup) {\r\n this._renderingGroup._edgesRenderers.pushNoDuplicate(this.edgesRenderer);\r\n this.edgesRenderer.customInstances.push(this.getWorldMatrix());\r\n }\r\n };\r\n /**\r\n * This method recomputes and sets a new BoundingInfo to the mesh unless it is locked.\r\n * This means the mesh underlying bounding box and sphere are recomputed.\r\n * @param applySkeleton defines whether to apply the skeleton before computing the bounding info\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.refreshBoundingInfo = function (applySkeleton) {\r\n if (applySkeleton === void 0) { applySkeleton = false; }\r\n if (this._boundingInfo && this._boundingInfo.isLocked) {\r\n return this;\r\n }\r\n var bias = this.geometry ? this.geometry.boundingBias : null;\r\n this._refreshBoundingInfo(this._getPositionData(applySkeleton), bias);\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._createGlobalSubMesh = function (force) {\r\n var totalVertices = this.getTotalVertices();\r\n if (!totalVertices || !this.getIndices()) {\r\n return null;\r\n }\r\n // Check if we need to recreate the submeshes\r\n if (this.subMeshes && this.subMeshes.length > 0) {\r\n var ib = this.getIndices();\r\n if (!ib) {\r\n return null;\r\n }\r\n var totalIndices = ib.length;\r\n var needToRecreate = false;\r\n if (force) {\r\n needToRecreate = true;\r\n }\r\n else {\r\n for (var _i = 0, _a = this.subMeshes; _i < _a.length; _i++) {\r\n var submesh = _a[_i];\r\n if (submesh.indexStart + submesh.indexCount > totalIndices) {\r\n needToRecreate = true;\r\n break;\r\n }\r\n if (submesh.verticesStart + submesh.verticesCount > totalVertices) {\r\n needToRecreate = true;\r\n break;\r\n }\r\n }\r\n }\r\n if (!needToRecreate) {\r\n return this.subMeshes[0];\r\n }\r\n }\r\n this.releaseSubMeshes();\r\n return new SubMesh(0, 0, totalVertices, 0, this.getTotalIndices(), this);\r\n };\r\n /**\r\n * This function will subdivide the mesh into multiple submeshes\r\n * @param count defines the expected number of submeshes\r\n */\r\n Mesh.prototype.subdivide = function (count) {\r\n if (count < 1) {\r\n return;\r\n }\r\n var totalIndices = this.getTotalIndices();\r\n var subdivisionSize = (totalIndices / count) | 0;\r\n var offset = 0;\r\n // Ensure that subdivisionSize is a multiple of 3\r\n while (subdivisionSize % 3 !== 0) {\r\n subdivisionSize++;\r\n }\r\n this.releaseSubMeshes();\r\n for (var index = 0; index < count; index++) {\r\n if (offset >= totalIndices) {\r\n break;\r\n }\r\n SubMesh.CreateFromIndices(0, offset, index === count - 1 ? totalIndices - offset : subdivisionSize, this);\r\n offset += subdivisionSize;\r\n }\r\n this.synchronizeInstances();\r\n };\r\n /**\r\n * Copy a FloatArray into a specific associated vertex buffer\r\n * @param kind defines which buffer to write to (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n * @param data defines the data source\r\n * @param updatable defines if the updated vertex buffer must be flagged as updatable\r\n * @param stride defines the data stride size (can be null)\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.setVerticesData = function (kind, data, updatable, stride) {\r\n if (updatable === void 0) { updatable = false; }\r\n if (!this._geometry) {\r\n var vertexData = new VertexData();\r\n vertexData.set(data, kind);\r\n var scene = this.getScene();\r\n new Geometry(Geometry.RandomId(), scene, vertexData, updatable, this);\r\n }\r\n else {\r\n this._geometry.setVerticesData(kind, data, updatable, stride);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Delete a vertex buffer associated with this mesh\r\n * @param kind defines which buffer to delete (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n */\r\n Mesh.prototype.removeVerticesData = function (kind) {\r\n if (!this._geometry) {\r\n return;\r\n }\r\n this._geometry.removeVerticesData(kind);\r\n };\r\n /**\r\n * Flags an associated vertex buffer as updatable\r\n * @param kind defines which buffer to use (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n * @param updatable defines if the updated vertex buffer must be flagged as updatable\r\n */\r\n Mesh.prototype.markVerticesDataAsUpdatable = function (kind, updatable) {\r\n if (updatable === void 0) { updatable = true; }\r\n var vb = this.getVertexBuffer(kind);\r\n if (!vb || vb.isUpdatable() === updatable) {\r\n return;\r\n }\r\n this.setVerticesData(kind, this.getVerticesData(kind), updatable);\r\n };\r\n /**\r\n * Sets the mesh global Vertex Buffer\r\n * @param buffer defines the buffer to use\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.setVerticesBuffer = function (buffer) {\r\n if (!this._geometry) {\r\n this._geometry = Geometry.CreateGeometryForMesh(this);\r\n }\r\n this._geometry.setVerticesBuffer(buffer);\r\n return this;\r\n };\r\n /**\r\n * Update a specific associated vertex buffer\r\n * @param kind defines which buffer to write to (positions, indices, normals, etc). Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n * @param data defines the data source\r\n * @param updateExtends defines if extends info of the mesh must be updated (can be null). This is mostly useful for \"position\" kind\r\n * @param makeItUnique defines if the geometry associated with the mesh must be cloned to make the change only for this mesh (and not all meshes associated with the same geometry)\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.updateVerticesData = function (kind, data, updateExtends, makeItUnique) {\r\n if (!this._geometry) {\r\n return this;\r\n }\r\n if (!makeItUnique) {\r\n this._geometry.updateVerticesData(kind, data, updateExtends);\r\n }\r\n else {\r\n this.makeGeometryUnique();\r\n this.updateVerticesData(kind, data, updateExtends, false);\r\n }\r\n return this;\r\n };\r\n /**\r\n * This method updates the vertex positions of an updatable mesh according to the `positionFunction` returned values.\r\n * @see https://doc.babylonjs.com/how_to/how_to_dynamically_morph_a_mesh#other-shapes-updatemeshpositions\r\n * @param positionFunction is a simple JS function what is passed the mesh `positions` array. It doesn't need to return anything\r\n * @param computeNormals is a boolean (default true) to enable/disable the mesh normal recomputation after the vertex position update\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.updateMeshPositions = function (positionFunction, computeNormals) {\r\n if (computeNormals === void 0) { computeNormals = true; }\r\n var positions = this.getVerticesData(VertexBuffer.PositionKind);\r\n if (!positions) {\r\n return this;\r\n }\r\n positionFunction(positions);\r\n this.updateVerticesData(VertexBuffer.PositionKind, positions, false, false);\r\n if (computeNormals) {\r\n var indices = this.getIndices();\r\n var normals = this.getVerticesData(VertexBuffer.NormalKind);\r\n if (!normals) {\r\n return this;\r\n }\r\n VertexData.ComputeNormals(positions, indices, normals);\r\n this.updateVerticesData(VertexBuffer.NormalKind, normals, false, false);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Creates a un-shared specific occurence of the geometry for the mesh.\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.makeGeometryUnique = function () {\r\n if (!this._geometry) {\r\n return this;\r\n }\r\n if (this._geometry.meshes.length === 1) {\r\n return this;\r\n }\r\n var oldGeometry = this._geometry;\r\n var geometry = this._geometry.copy(Geometry.RandomId());\r\n oldGeometry.releaseForMesh(this, true);\r\n geometry.applyToMesh(this);\r\n return this;\r\n };\r\n /**\r\n * Set the index buffer of this mesh\r\n * @param indices defines the source data\r\n * @param totalVertices defines the total number of vertices referenced by this index data (can be null)\r\n * @param updatable defines if the updated index buffer must be flagged as updatable (default is false)\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.setIndices = function (indices, totalVertices, updatable) {\r\n if (totalVertices === void 0) { totalVertices = null; }\r\n if (updatable === void 0) { updatable = false; }\r\n if (!this._geometry) {\r\n var vertexData = new VertexData();\r\n vertexData.indices = indices;\r\n var scene = this.getScene();\r\n new Geometry(Geometry.RandomId(), scene, vertexData, updatable, this);\r\n }\r\n else {\r\n this._geometry.setIndices(indices, totalVertices, updatable);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Update the current index buffer\r\n * @param indices defines the source data\r\n * @param offset defines the offset in the index buffer where to store the new data (can be null)\r\n * @param gpuMemoryOnly defines a boolean indicating that only the GPU memory must be updated leaving the CPU version of the indices unchanged (false by default)\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.updateIndices = function (indices, offset, gpuMemoryOnly) {\r\n if (gpuMemoryOnly === void 0) { gpuMemoryOnly = false; }\r\n if (!this._geometry) {\r\n return this;\r\n }\r\n this._geometry.updateIndices(indices, offset, gpuMemoryOnly);\r\n return this;\r\n };\r\n /**\r\n * Invert the geometry to move from a right handed system to a left handed one.\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.toLeftHanded = function () {\r\n if (!this._geometry) {\r\n return this;\r\n }\r\n this._geometry.toLeftHanded();\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._bind = function (subMesh, effect, fillMode) {\r\n if (!this._geometry) {\r\n return this;\r\n }\r\n var engine = this.getScene().getEngine();\r\n // Wireframe\r\n var indexToBind;\r\n if (this._unIndexed) {\r\n indexToBind = null;\r\n }\r\n else {\r\n switch (fillMode) {\r\n case Material.PointFillMode:\r\n indexToBind = null;\r\n break;\r\n case Material.WireFrameFillMode:\r\n indexToBind = subMesh._getLinesIndexBuffer(this.getIndices(), engine);\r\n break;\r\n default:\r\n case Material.TriangleFillMode:\r\n indexToBind = this._geometry.getIndexBuffer();\r\n break;\r\n }\r\n }\r\n // VBOs\r\n this._geometry._bind(effect, indexToBind);\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._draw = function (subMesh, fillMode, instancesCount) {\r\n if (!this._geometry || !this._geometry.getVertexBuffers() || (!this._unIndexed && !this._geometry.getIndexBuffer())) {\r\n return this;\r\n }\r\n if (this._internalMeshDataInfo._onBeforeDrawObservable) {\r\n this._internalMeshDataInfo._onBeforeDrawObservable.notifyObservers(this);\r\n }\r\n var scene = this.getScene();\r\n var engine = scene.getEngine();\r\n if (this._unIndexed || fillMode == Material.PointFillMode) {\r\n // or triangles as points\r\n engine.drawArraysType(fillMode, subMesh.verticesStart, subMesh.verticesCount, instancesCount);\r\n }\r\n else if (fillMode == Material.WireFrameFillMode) {\r\n // Triangles as wireframe\r\n engine.drawElementsType(fillMode, 0, subMesh._linesIndexCount, instancesCount);\r\n }\r\n else {\r\n engine.drawElementsType(fillMode, subMesh.indexStart, subMesh.indexCount, instancesCount);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Registers for this mesh a javascript function called just before the rendering process\r\n * @param func defines the function to call before rendering this mesh\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.registerBeforeRender = function (func) {\r\n this.onBeforeRenderObservable.add(func);\r\n return this;\r\n };\r\n /**\r\n * Disposes a previously registered javascript function called before the rendering\r\n * @param func defines the function to remove\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.unregisterBeforeRender = function (func) {\r\n this.onBeforeRenderObservable.removeCallback(func);\r\n return this;\r\n };\r\n /**\r\n * Registers for this mesh a javascript function called just after the rendering is complete\r\n * @param func defines the function to call after rendering this mesh\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.registerAfterRender = function (func) {\r\n this.onAfterRenderObservable.add(func);\r\n return this;\r\n };\r\n /**\r\n * Disposes a previously registered javascript function called after the rendering.\r\n * @param func defines the function to remove\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.unregisterAfterRender = function (func) {\r\n this.onAfterRenderObservable.removeCallback(func);\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._getInstancesRenderList = function (subMeshId, isReplacementMode) {\r\n if (isReplacementMode === void 0) { isReplacementMode = false; }\r\n if (this._instanceDataStorage.isFrozen && this._instanceDataStorage.previousBatch) {\r\n return this._instanceDataStorage.previousBatch;\r\n }\r\n var scene = this.getScene();\r\n var isInIntermediateRendering = scene._isInIntermediateRendering();\r\n var onlyForInstances = isInIntermediateRendering ? this._internalAbstractMeshDataInfo._onlyForInstancesIntermediate : this._internalAbstractMeshDataInfo._onlyForInstances;\r\n var batchCache = this._instanceDataStorage.batchCache;\r\n batchCache.mustReturn = false;\r\n batchCache.renderSelf[subMeshId] = isReplacementMode || (!onlyForInstances && this.isEnabled() && this.isVisible);\r\n batchCache.visibleInstances[subMeshId] = null;\r\n if (this._instanceDataStorage.visibleInstances && !isReplacementMode) {\r\n var visibleInstances = this._instanceDataStorage.visibleInstances;\r\n var currentRenderId = scene.getRenderId();\r\n var defaultRenderId = (isInIntermediateRendering ? visibleInstances.intermediateDefaultRenderId : visibleInstances.defaultRenderId);\r\n batchCache.visibleInstances[subMeshId] = visibleInstances[currentRenderId];\r\n if (!batchCache.visibleInstances[subMeshId] && defaultRenderId) {\r\n batchCache.visibleInstances[subMeshId] = visibleInstances[defaultRenderId];\r\n }\r\n }\r\n batchCache.hardwareInstancedRendering[subMeshId] =\r\n !isReplacementMode &&\r\n this._instanceDataStorage.hardwareInstancedRendering\r\n && (batchCache.visibleInstances[subMeshId] !== null)\r\n && (batchCache.visibleInstances[subMeshId] !== undefined);\r\n this._instanceDataStorage.previousBatch = batchCache;\r\n return batchCache;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._renderWithInstances = function (subMesh, fillMode, batch, effect, engine) {\r\n var visibleInstances = batch.visibleInstances[subMesh._id];\r\n if (!visibleInstances) {\r\n return this;\r\n }\r\n var instanceStorage = this._instanceDataStorage;\r\n var currentInstancesBufferSize = instanceStorage.instancesBufferSize;\r\n var instancesBuffer = instanceStorage.instancesBuffer;\r\n var matricesCount = visibleInstances.length + 1;\r\n var bufferSize = matricesCount * 16 * 4;\r\n while (instanceStorage.instancesBufferSize < bufferSize) {\r\n instanceStorage.instancesBufferSize *= 2;\r\n }\r\n if (!instanceStorage.instancesData || currentInstancesBufferSize != instanceStorage.instancesBufferSize) {\r\n instanceStorage.instancesData = new Float32Array(instanceStorage.instancesBufferSize / 4);\r\n }\r\n var offset = 0;\r\n var instancesCount = 0;\r\n var renderSelf = batch.renderSelf[subMesh._id];\r\n var needUpdateBuffer = !instancesBuffer || currentInstancesBufferSize !== instanceStorage.instancesBufferSize;\r\n if (!this._instanceDataStorage.manualUpdate && (!instanceStorage.isFrozen || needUpdateBuffer)) {\r\n var world = this._effectiveMesh.getWorldMatrix();\r\n if (renderSelf) {\r\n world.copyToArray(instanceStorage.instancesData, offset);\r\n offset += 16;\r\n instancesCount++;\r\n }\r\n if (visibleInstances) {\r\n for (var instanceIndex = 0; instanceIndex < visibleInstances.length; instanceIndex++) {\r\n var instance = visibleInstances[instanceIndex];\r\n instance.getWorldMatrix().copyToArray(instanceStorage.instancesData, offset);\r\n offset += 16;\r\n instancesCount++;\r\n }\r\n }\r\n }\r\n else {\r\n instancesCount = (renderSelf ? 1 : 0) + visibleInstances.length;\r\n }\r\n if (needUpdateBuffer) {\r\n if (instancesBuffer) {\r\n instancesBuffer.dispose();\r\n }\r\n instancesBuffer = new Buffer(engine, instanceStorage.instancesData, true, 16, false, true);\r\n instanceStorage.instancesBuffer = instancesBuffer;\r\n this.setVerticesBuffer(instancesBuffer.createVertexBuffer(\"world0\", 0, 4));\r\n this.setVerticesBuffer(instancesBuffer.createVertexBuffer(\"world1\", 4, 4));\r\n this.setVerticesBuffer(instancesBuffer.createVertexBuffer(\"world2\", 8, 4));\r\n this.setVerticesBuffer(instancesBuffer.createVertexBuffer(\"world3\", 12, 4));\r\n }\r\n else {\r\n if (!this._instanceDataStorage.isFrozen) {\r\n instancesBuffer.updateDirectly(instanceStorage.instancesData, 0, instancesCount);\r\n }\r\n }\r\n this._processInstancedBuffers(visibleInstances, renderSelf);\r\n // Stats\r\n this.getScene()._activeIndices.addCount(subMesh.indexCount * instancesCount, false);\r\n // Draw\r\n this._bind(subMesh, effect, fillMode);\r\n this._draw(subMesh, fillMode, instancesCount);\r\n engine.unbindInstanceAttributes();\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._renderWithThinInstances = function (subMesh, fillMode, effect, engine) {\r\n var _a, _b;\r\n // Stats\r\n var instancesCount = (_b = (_a = this._thinInstanceDataStorage) === null || _a === void 0 ? void 0 : _a.instancesCount) !== null && _b !== void 0 ? _b : 0;\r\n this.getScene()._activeIndices.addCount(subMesh.indexCount * instancesCount, false);\r\n // Draw\r\n this._bind(subMesh, effect, fillMode);\r\n this._draw(subMesh, fillMode, instancesCount);\r\n engine.unbindInstanceAttributes();\r\n };\r\n /** @hidden */\r\n Mesh.prototype._processInstancedBuffers = function (visibleInstances, renderSelf) {\r\n // Do nothing\r\n };\r\n /** @hidden */\r\n Mesh.prototype._processRendering = function (renderingMesh, subMesh, effect, fillMode, batch, hardwareInstancedRendering, onBeforeDraw, effectiveMaterial) {\r\n var scene = this.getScene();\r\n var engine = scene.getEngine();\r\n if (hardwareInstancedRendering && subMesh.getRenderingMesh().hasThinInstances) {\r\n this._renderWithThinInstances(subMesh, fillMode, effect, engine);\r\n return this;\r\n }\r\n if (hardwareInstancedRendering) {\r\n this._renderWithInstances(subMesh, fillMode, batch, effect, engine);\r\n }\r\n else {\r\n var instanceCount = 0;\r\n if (batch.renderSelf[subMesh._id]) {\r\n // Draw\r\n if (onBeforeDraw) {\r\n onBeforeDraw(false, renderingMesh._effectiveMesh.getWorldMatrix(), effectiveMaterial);\r\n }\r\n instanceCount++;\r\n this._draw(subMesh, fillMode, this._instanceDataStorage.overridenInstanceCount);\r\n }\r\n var visibleInstancesForSubMesh = batch.visibleInstances[subMesh._id];\r\n if (visibleInstancesForSubMesh) {\r\n var visibleInstanceCount = visibleInstancesForSubMesh.length;\r\n instanceCount += visibleInstanceCount;\r\n // Stats\r\n for (var instanceIndex = 0; instanceIndex < visibleInstanceCount; instanceIndex++) {\r\n var instance = visibleInstancesForSubMesh[instanceIndex];\r\n // World\r\n var world = instance.getWorldMatrix();\r\n if (onBeforeDraw) {\r\n onBeforeDraw(true, world, effectiveMaterial);\r\n }\r\n // Draw\r\n this._draw(subMesh, fillMode);\r\n }\r\n }\r\n // Stats\r\n scene._activeIndices.addCount(subMesh.indexCount * instanceCount, false);\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._rebuild = function () {\r\n if (this._instanceDataStorage.instancesBuffer) {\r\n // Dispose instance buffer to be recreated in _renderWithInstances when rendered\r\n this._instanceDataStorage.instancesBuffer.dispose();\r\n this._instanceDataStorage.instancesBuffer = null;\r\n }\r\n _super.prototype._rebuild.call(this);\r\n };\r\n /** @hidden */\r\n Mesh.prototype._freeze = function () {\r\n if (!this.subMeshes) {\r\n return;\r\n }\r\n // Prepare batches\r\n for (var index = 0; index < this.subMeshes.length; index++) {\r\n this._getInstancesRenderList(index);\r\n }\r\n this._effectiveMaterial = null;\r\n this._instanceDataStorage.isFrozen = true;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._unFreeze = function () {\r\n this._instanceDataStorage.isFrozen = false;\r\n this._instanceDataStorage.previousBatch = null;\r\n };\r\n /**\r\n * Triggers the draw call for the mesh. Usually, you don't need to call this method by your own because the mesh rendering is handled by the scene rendering manager\r\n * @param subMesh defines the subMesh to render\r\n * @param enableAlphaMode defines if alpha mode can be changed\r\n * @param effectiveMeshReplacement defines an optional mesh used to provide info for the rendering\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.render = function (subMesh, enableAlphaMode, effectiveMeshReplacement) {\r\n var scene = this.getScene();\r\n if (this._internalAbstractMeshDataInfo._isActiveIntermediate) {\r\n this._internalAbstractMeshDataInfo._isActiveIntermediate = false;\r\n }\r\n else {\r\n this._internalAbstractMeshDataInfo._isActive = false;\r\n }\r\n if (this._checkOcclusionQuery()) {\r\n return this;\r\n }\r\n // Managing instances\r\n var batch = this._getInstancesRenderList(subMesh._id, !!effectiveMeshReplacement);\r\n if (batch.mustReturn) {\r\n return this;\r\n }\r\n // Checking geometry state\r\n if (!this._geometry || !this._geometry.getVertexBuffers() || (!this._unIndexed && !this._geometry.getIndexBuffer())) {\r\n return this;\r\n }\r\n if (this._internalMeshDataInfo._onBeforeRenderObservable) {\r\n this._internalMeshDataInfo._onBeforeRenderObservable.notifyObservers(this);\r\n }\r\n var engine = scene.getEngine();\r\n var hardwareInstancedRendering = batch.hardwareInstancedRendering[subMesh._id] || subMesh.getRenderingMesh().hasThinInstances;\r\n var instanceDataStorage = this._instanceDataStorage;\r\n var material = subMesh.getMaterial();\r\n if (!material) {\r\n return this;\r\n }\r\n // Material\r\n if (!instanceDataStorage.isFrozen || !this._effectiveMaterial || this._effectiveMaterial !== material) {\r\n if (material._storeEffectOnSubMeshes) {\r\n if (!material.isReadyForSubMesh(this, subMesh, hardwareInstancedRendering)) {\r\n return this;\r\n }\r\n }\r\n else if (!material.isReady(this, hardwareInstancedRendering)) {\r\n return this;\r\n }\r\n this._effectiveMaterial = material;\r\n }\r\n // Alpha mode\r\n if (enableAlphaMode) {\r\n engine.setAlphaMode(this._effectiveMaterial.alphaMode);\r\n }\r\n var effect;\r\n if (this._effectiveMaterial._storeEffectOnSubMeshes) {\r\n effect = subMesh.effect;\r\n }\r\n else {\r\n effect = this._effectiveMaterial.getEffect();\r\n }\r\n for (var _i = 0, _a = scene._beforeRenderingMeshStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n step.action(this, subMesh, batch, effect);\r\n }\r\n if (!effect) {\r\n return this;\r\n }\r\n var effectiveMesh = effectiveMeshReplacement || this._effectiveMesh;\r\n var sideOrientation;\r\n if (!instanceDataStorage.isFrozen &&\r\n (this._effectiveMaterial.backFaceCulling || this.overrideMaterialSideOrientation !== null)) {\r\n var mainDeterminant = effectiveMesh._getWorldMatrixDeterminant();\r\n sideOrientation = this.overrideMaterialSideOrientation;\r\n if (sideOrientation == null) {\r\n sideOrientation = this._effectiveMaterial.sideOrientation;\r\n }\r\n if (mainDeterminant < 0) {\r\n sideOrientation = (sideOrientation === Material.ClockWiseSideOrientation ? Material.CounterClockWiseSideOrientation : Material.ClockWiseSideOrientation);\r\n }\r\n instanceDataStorage.sideOrientation = sideOrientation;\r\n }\r\n else {\r\n sideOrientation = instanceDataStorage.sideOrientation;\r\n }\r\n var reverse = this._effectiveMaterial._preBind(effect, sideOrientation);\r\n if (this._effectiveMaterial.forceDepthWrite) {\r\n engine.setDepthWrite(true);\r\n }\r\n // Bind\r\n var fillMode = scene.forcePointsCloud ? Material.PointFillMode : (scene.forceWireframe ? Material.WireFrameFillMode : this._effectiveMaterial.fillMode);\r\n if (this._internalMeshDataInfo._onBeforeBindObservable) {\r\n this._internalMeshDataInfo._onBeforeBindObservable.notifyObservers(this);\r\n }\r\n if (!hardwareInstancedRendering) { // Binding will be done later because we need to add more info to the VB\r\n this._bind(subMesh, effect, fillMode);\r\n }\r\n var world = effectiveMesh.getWorldMatrix();\r\n if (this._effectiveMaterial._storeEffectOnSubMeshes) {\r\n this._effectiveMaterial.bindForSubMesh(world, this, subMesh);\r\n }\r\n else {\r\n this._effectiveMaterial.bind(world, this);\r\n }\r\n if (!this._effectiveMaterial.backFaceCulling && this._effectiveMaterial.separateCullingPass) {\r\n engine.setState(true, this._effectiveMaterial.zOffset, false, !reverse);\r\n this._processRendering(this, subMesh, effect, fillMode, batch, hardwareInstancedRendering, this._onBeforeDraw, this._effectiveMaterial);\r\n engine.setState(true, this._effectiveMaterial.zOffset, false, reverse);\r\n }\r\n // Draw\r\n this._processRendering(this, subMesh, effect, fillMode, batch, hardwareInstancedRendering, this._onBeforeDraw, this._effectiveMaterial);\r\n // Unbind\r\n this._effectiveMaterial.unbind();\r\n for (var _b = 0, _c = scene._afterRenderingMeshStage; _b < _c.length; _b++) {\r\n var step = _c[_b];\r\n step.action(this, subMesh, batch, effect);\r\n }\r\n if (this._internalMeshDataInfo._onAfterRenderObservable) {\r\n this._internalMeshDataInfo._onAfterRenderObservable.notifyObservers(this);\r\n }\r\n return this;\r\n };\r\n Mesh.prototype._onBeforeDraw = function (isInstance, world, effectiveMaterial) {\r\n if (isInstance && effectiveMaterial) {\r\n effectiveMaterial.bindOnlyWorldMatrix(world);\r\n }\r\n };\r\n /**\r\n * Renormalize the mesh and patch it up if there are no weights\r\n * Similar to normalization by adding the weights compute the reciprocal and multiply all elements, this wil ensure that everything adds to 1.\r\n * However in the case of zero weights then we set just a single influence to 1.\r\n * We check in the function for extra's present and if so we use the normalizeSkinWeightsWithExtras rather than the FourWeights version.\r\n */\r\n Mesh.prototype.cleanMatrixWeights = function () {\r\n if (this.isVerticesDataPresent(VertexBuffer.MatricesWeightsKind)) {\r\n if (this.isVerticesDataPresent(VertexBuffer.MatricesWeightsExtraKind)) {\r\n this.normalizeSkinWeightsAndExtra();\r\n }\r\n else {\r\n this.normalizeSkinFourWeights();\r\n }\r\n }\r\n };\r\n // faster 4 weight version.\r\n Mesh.prototype.normalizeSkinFourWeights = function () {\r\n var matricesWeights = this.getVerticesData(VertexBuffer.MatricesWeightsKind);\r\n var numWeights = matricesWeights.length;\r\n for (var a = 0; a < numWeights; a += 4) {\r\n // accumulate weights\r\n var t = matricesWeights[a] + matricesWeights[a + 1] + matricesWeights[a + 2] + matricesWeights[a + 3];\r\n // check for invalid weight and just set it to 1.\r\n if (t === 0) {\r\n matricesWeights[a] = 1;\r\n }\r\n else {\r\n // renormalize so everything adds to 1 use reciprical\r\n var recip = 1 / t;\r\n matricesWeights[a] *= recip;\r\n matricesWeights[a + 1] *= recip;\r\n matricesWeights[a + 2] *= recip;\r\n matricesWeights[a + 3] *= recip;\r\n }\r\n }\r\n this.setVerticesData(VertexBuffer.MatricesWeightsKind, matricesWeights);\r\n };\r\n // handle special case of extra verts. (in theory gltf can handle 12 influences)\r\n Mesh.prototype.normalizeSkinWeightsAndExtra = function () {\r\n var matricesWeightsExtra = this.getVerticesData(VertexBuffer.MatricesWeightsExtraKind);\r\n var matricesWeights = this.getVerticesData(VertexBuffer.MatricesWeightsKind);\r\n var numWeights = matricesWeights.length;\r\n for (var a = 0; a < numWeights; a += 4) {\r\n // accumulate weights\r\n var t = matricesWeights[a] + matricesWeights[a + 1] + matricesWeights[a + 2] + matricesWeights[a + 3];\r\n t += matricesWeightsExtra[a] + matricesWeightsExtra[a + 1] + matricesWeightsExtra[a + 2] + matricesWeightsExtra[a + 3];\r\n // check for invalid weight and just set it to 1.\r\n if (t === 0) {\r\n matricesWeights[a] = 1;\r\n }\r\n else {\r\n // renormalize so everything adds to 1 use reciprical\r\n var recip = 1 / t;\r\n matricesWeights[a] *= recip;\r\n matricesWeights[a + 1] *= recip;\r\n matricesWeights[a + 2] *= recip;\r\n matricesWeights[a + 3] *= recip;\r\n // same goes for extras\r\n matricesWeightsExtra[a] *= recip;\r\n matricesWeightsExtra[a + 1] *= recip;\r\n matricesWeightsExtra[a + 2] *= recip;\r\n matricesWeightsExtra[a + 3] *= recip;\r\n }\r\n }\r\n this.setVerticesData(VertexBuffer.MatricesWeightsKind, matricesWeights);\r\n this.setVerticesData(VertexBuffer.MatricesWeightsKind, matricesWeightsExtra);\r\n };\r\n /**\r\n * ValidateSkinning is used to determine that a mesh has valid skinning data along with skin metrics, if missing weights,\r\n * or not normalized it is returned as invalid mesh the string can be used for console logs, or on screen messages to let\r\n * the user know there was an issue with importing the mesh\r\n * @returns a validation object with skinned, valid and report string\r\n */\r\n Mesh.prototype.validateSkinning = function () {\r\n var matricesWeightsExtra = this.getVerticesData(VertexBuffer.MatricesWeightsExtraKind);\r\n var matricesWeights = this.getVerticesData(VertexBuffer.MatricesWeightsKind);\r\n if (matricesWeights === null || this.skeleton == null) {\r\n return { skinned: false, valid: true, report: \"not skinned\" };\r\n }\r\n var numWeights = matricesWeights.length;\r\n var numberNotSorted = 0;\r\n var missingWeights = 0;\r\n var maxUsedWeights = 0;\r\n var numberNotNormalized = 0;\r\n var numInfluences = matricesWeightsExtra === null ? 4 : 8;\r\n var usedWeightCounts = new Array();\r\n for (var a = 0; a <= numInfluences; a++) {\r\n usedWeightCounts[a] = 0;\r\n }\r\n var toleranceEpsilon = 0.001;\r\n for (var a = 0; a < numWeights; a += 4) {\r\n var lastWeight = matricesWeights[a];\r\n var t = lastWeight;\r\n var usedWeights = t === 0 ? 0 : 1;\r\n for (var b = 1; b < numInfluences; b++) {\r\n var d = b < 4 ? matricesWeights[a + b] : matricesWeightsExtra[a + b - 4];\r\n if (d > lastWeight) {\r\n numberNotSorted++;\r\n }\r\n if (d !== 0) {\r\n usedWeights++;\r\n }\r\n t += d;\r\n lastWeight = d;\r\n }\r\n // count the buffer weights usage\r\n usedWeightCounts[usedWeights]++;\r\n // max influences\r\n if (usedWeights > maxUsedWeights) {\r\n maxUsedWeights = usedWeights;\r\n }\r\n // check for invalid weight and just set it to 1.\r\n if (t === 0) {\r\n missingWeights++;\r\n }\r\n else {\r\n // renormalize so everything adds to 1 use reciprical\r\n var recip = 1 / t;\r\n var tolerance = 0;\r\n for (b = 0; b < numInfluences; b++) {\r\n if (b < 4) {\r\n tolerance += Math.abs(matricesWeights[a + b] - (matricesWeights[a + b] * recip));\r\n }\r\n else {\r\n tolerance += Math.abs(matricesWeightsExtra[a + b - 4] - (matricesWeightsExtra[a + b - 4] * recip));\r\n }\r\n }\r\n // arbitary epsilon value for dicdating not normalized\r\n if (tolerance > toleranceEpsilon) {\r\n numberNotNormalized++;\r\n }\r\n }\r\n }\r\n // validate bone indices are in range of the skeleton\r\n var numBones = this.skeleton.bones.length;\r\n var matricesIndices = this.getVerticesData(VertexBuffer.MatricesIndicesKind);\r\n var matricesIndicesExtra = this.getVerticesData(VertexBuffer.MatricesIndicesExtraKind);\r\n var numBadBoneIndices = 0;\r\n for (var a = 0; a < numWeights; a += 4) {\r\n for (var b = 0; b < numInfluences; b++) {\r\n var index = b < 4 ? matricesIndices[a + b] : matricesIndicesExtra[a + b - 4];\r\n if (index >= numBones || index < 0) {\r\n numBadBoneIndices++;\r\n }\r\n }\r\n }\r\n // log mesh stats\r\n var output = \"Number of Weights = \" + numWeights / 4 + \"\\nMaximum influences = \" + maxUsedWeights +\r\n \"\\nMissing Weights = \" + missingWeights + \"\\nNot Sorted = \" + numberNotSorted +\r\n \"\\nNot Normalized = \" + numberNotNormalized + \"\\nWeightCounts = [\" + usedWeightCounts + \"]\" +\r\n \"\\nNumber of bones = \" + numBones + \"\\nBad Bone Indices = \" + numBadBoneIndices;\r\n return { skinned: true, valid: missingWeights === 0 && numberNotNormalized === 0 && numBadBoneIndices === 0, report: output };\r\n };\r\n /** @hidden */\r\n Mesh.prototype._checkDelayState = function () {\r\n var scene = this.getScene();\r\n if (this._geometry) {\r\n this._geometry.load(scene);\r\n }\r\n else if (this.delayLoadState === 4) {\r\n this.delayLoadState = 2;\r\n this._queueLoad(scene);\r\n }\r\n return this;\r\n };\r\n Mesh.prototype._queueLoad = function (scene) {\r\n var _this = this;\r\n scene._addPendingData(this);\r\n var getBinaryData = (this.delayLoadingFile.indexOf(\".babylonbinarymeshdata\") !== -1);\r\n Tools.LoadFile(this.delayLoadingFile, function (data) {\r\n if (data instanceof ArrayBuffer) {\r\n _this._delayLoadingFunction(data, _this);\r\n }\r\n else {\r\n _this._delayLoadingFunction(JSON.parse(data), _this);\r\n }\r\n _this.instances.forEach(function (instance) {\r\n instance.refreshBoundingInfo();\r\n instance._syncSubMeshes();\r\n });\r\n _this.delayLoadState = 1;\r\n scene._removePendingData(_this);\r\n }, function () { }, scene.offlineProvider, getBinaryData);\r\n return this;\r\n };\r\n /**\r\n * Returns `true` if the mesh is within the frustum defined by the passed array of planes.\r\n * A mesh is in the frustum if its bounding box intersects the frustum\r\n * @param frustumPlanes defines the frustum to test\r\n * @returns true if the mesh is in the frustum planes\r\n */\r\n Mesh.prototype.isInFrustum = function (frustumPlanes) {\r\n if (this.delayLoadState === 2) {\r\n return false;\r\n }\r\n if (!_super.prototype.isInFrustum.call(this, frustumPlanes)) {\r\n return false;\r\n }\r\n this._checkDelayState();\r\n return true;\r\n };\r\n /**\r\n * Sets the mesh material by the material or multiMaterial `id` property\r\n * @param id is a string identifying the material or the multiMaterial\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.setMaterialByID = function (id) {\r\n var materials = this.getScene().materials;\r\n var index;\r\n for (index = materials.length - 1; index > -1; index--) {\r\n if (materials[index].id === id) {\r\n this.material = materials[index];\r\n return this;\r\n }\r\n }\r\n // Multi\r\n var multiMaterials = this.getScene().multiMaterials;\r\n for (index = multiMaterials.length - 1; index > -1; index--) {\r\n if (multiMaterials[index].id === id) {\r\n this.material = multiMaterials[index];\r\n return this;\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Returns as a new array populated with the mesh material and/or skeleton, if any.\r\n * @returns an array of IAnimatable\r\n */\r\n Mesh.prototype.getAnimatables = function () {\r\n var results = new Array();\r\n if (this.material) {\r\n results.push(this.material);\r\n }\r\n if (this.skeleton) {\r\n results.push(this.skeleton);\r\n }\r\n return results;\r\n };\r\n /**\r\n * Modifies the mesh geometry according to the passed transformation matrix.\r\n * This method returns nothing but it really modifies the mesh even if it's originally not set as updatable.\r\n * The mesh normals are modified using the same transformation.\r\n * Note that, under the hood, this method sets a new VertexBuffer each call.\r\n * @param transform defines the transform matrix to use\r\n * @see https://doc.babylonjs.com/resources/baking_transformations\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.bakeTransformIntoVertices = function (transform) {\r\n // Position\r\n if (!this.isVerticesDataPresent(VertexBuffer.PositionKind)) {\r\n return this;\r\n }\r\n var submeshes = this.subMeshes.splice(0);\r\n this._resetPointsArrayCache();\r\n var data = this.getVerticesData(VertexBuffer.PositionKind);\r\n var temp = new Array();\r\n var index;\r\n for (index = 0; index < data.length; index += 3) {\r\n Vector3.TransformCoordinates(Vector3.FromArray(data, index), transform).toArray(temp, index);\r\n }\r\n this.setVerticesData(VertexBuffer.PositionKind, temp, this.getVertexBuffer(VertexBuffer.PositionKind).isUpdatable());\r\n // Normals\r\n if (this.isVerticesDataPresent(VertexBuffer.NormalKind)) {\r\n data = this.getVerticesData(VertexBuffer.NormalKind);\r\n temp = [];\r\n for (index = 0; index < data.length; index += 3) {\r\n Vector3.TransformNormal(Vector3.FromArray(data, index), transform).normalize().toArray(temp, index);\r\n }\r\n this.setVerticesData(VertexBuffer.NormalKind, temp, this.getVertexBuffer(VertexBuffer.NormalKind).isUpdatable());\r\n }\r\n // flip faces?\r\n if (transform.m[0] * transform.m[5] * transform.m[10] < 0) {\r\n this.flipFaces();\r\n }\r\n // Restore submeshes\r\n this.releaseSubMeshes();\r\n this.subMeshes = submeshes;\r\n return this;\r\n };\r\n /**\r\n * Modifies the mesh geometry according to its own current World Matrix.\r\n * The mesh World Matrix is then reset.\r\n * This method returns nothing but really modifies the mesh even if it's originally not set as updatable.\r\n * Note that, under the hood, this method sets a new VertexBuffer each call.\r\n * @see https://doc.babylonjs.com/resources/baking_transformations\r\n * @param bakeIndependenlyOfChildren indicates whether to preserve all child nodes' World Matrix during baking\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.bakeCurrentTransformIntoVertices = function (bakeIndependenlyOfChildren) {\r\n if (bakeIndependenlyOfChildren === void 0) { bakeIndependenlyOfChildren = true; }\r\n this.bakeTransformIntoVertices(this.computeWorldMatrix(true));\r\n this.resetLocalMatrix(bakeIndependenlyOfChildren);\r\n return this;\r\n };\r\n Object.defineProperty(Mesh.prototype, \"_positions\", {\r\n // Cache\r\n /** @hidden */\r\n get: function () {\r\n if (this._geometry) {\r\n return this._geometry._positions;\r\n }\r\n return null;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n Mesh.prototype._resetPointsArrayCache = function () {\r\n if (this._geometry) {\r\n this._geometry._resetPointsArrayCache();\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n Mesh.prototype._generatePointsArray = function () {\r\n if (this._geometry) {\r\n return this._geometry._generatePointsArray();\r\n }\r\n return false;\r\n };\r\n /**\r\n * Returns a new Mesh object generated from the current mesh properties.\r\n * This method must not get confused with createInstance()\r\n * @param name is a string, the name given to the new mesh\r\n * @param newParent can be any Node object (default `null`)\r\n * @param doNotCloneChildren allows/denies the recursive cloning of the original mesh children if any (default `false`)\r\n * @param clonePhysicsImpostor allows/denies the cloning in the same time of the original mesh `body` used by the physics engine, if any (default `true`)\r\n * @returns a new mesh\r\n */\r\n Mesh.prototype.clone = function (name, newParent, doNotCloneChildren, clonePhysicsImpostor) {\r\n if (name === void 0) { name = \"\"; }\r\n if (newParent === void 0) { newParent = null; }\r\n if (clonePhysicsImpostor === void 0) { clonePhysicsImpostor = true; }\r\n return new Mesh(name, this.getScene(), newParent, this, doNotCloneChildren, clonePhysicsImpostor);\r\n };\r\n /**\r\n * Releases resources associated with this mesh.\r\n * @param doNotRecurse Set to true to not recurse into each children (recurse into each children by default)\r\n * @param disposeMaterialAndTextures Set to true to also dispose referenced materials and textures (false by default)\r\n */\r\n Mesh.prototype.dispose = function (doNotRecurse, disposeMaterialAndTextures) {\r\n if (disposeMaterialAndTextures === void 0) { disposeMaterialAndTextures = false; }\r\n this.morphTargetManager = null;\r\n if (this._geometry) {\r\n this._geometry.releaseForMesh(this, true);\r\n }\r\n var internalDataInfo = this._internalMeshDataInfo;\r\n if (internalDataInfo._onBeforeDrawObservable) {\r\n internalDataInfo._onBeforeDrawObservable.clear();\r\n }\r\n if (internalDataInfo._onBeforeBindObservable) {\r\n internalDataInfo._onBeforeBindObservable.clear();\r\n }\r\n if (internalDataInfo._onBeforeRenderObservable) {\r\n internalDataInfo._onBeforeRenderObservable.clear();\r\n }\r\n if (internalDataInfo._onAfterRenderObservable) {\r\n internalDataInfo._onAfterRenderObservable.clear();\r\n }\r\n // Sources\r\n if (this._scene.useClonedMeshMap) {\r\n if (internalDataInfo.meshMap) {\r\n for (var uniqueId in internalDataInfo.meshMap) {\r\n var mesh = internalDataInfo.meshMap[uniqueId];\r\n if (mesh) {\r\n mesh._internalMeshDataInfo._source = null;\r\n internalDataInfo.meshMap[uniqueId] = undefined;\r\n }\r\n }\r\n }\r\n if (internalDataInfo._source && internalDataInfo._source._internalMeshDataInfo.meshMap) {\r\n internalDataInfo._source._internalMeshDataInfo.meshMap[this.uniqueId] = undefined;\r\n }\r\n }\r\n else {\r\n var meshes = this.getScene().meshes;\r\n for (var _i = 0, meshes_1 = meshes; _i < meshes_1.length; _i++) {\r\n var abstractMesh = meshes_1[_i];\r\n var mesh = abstractMesh;\r\n if (mesh._internalMeshDataInfo && mesh._internalMeshDataInfo._source && mesh._internalMeshDataInfo._source === this) {\r\n mesh._internalMeshDataInfo._source = null;\r\n }\r\n }\r\n }\r\n internalDataInfo._source = null;\r\n // Instances\r\n this._disposeInstanceSpecificData();\r\n // Thin instances\r\n this._disposeThinInstanceSpecificData();\r\n _super.prototype.dispose.call(this, doNotRecurse, disposeMaterialAndTextures);\r\n };\r\n /** @hidden */\r\n Mesh.prototype._disposeInstanceSpecificData = function () {\r\n // Do nothing\r\n };\r\n /** @hidden */\r\n Mesh.prototype._disposeThinInstanceSpecificData = function () {\r\n // Do nothing\r\n };\r\n /**\r\n * Modifies the mesh geometry according to a displacement map.\r\n * A displacement map is a colored image. Each pixel color value (actually a gradient computed from red, green, blue values) will give the displacement to apply to each mesh vertex.\r\n * The mesh must be set as updatable. Its internal geometry is directly modified, no new buffer are allocated.\r\n * @param url is a string, the URL from the image file is to be downloaded.\r\n * @param minHeight is the lower limit of the displacement.\r\n * @param maxHeight is the upper limit of the displacement.\r\n * @param onSuccess is an optional Javascript function to be called just after the mesh is modified. It is passed the modified mesh and must return nothing.\r\n * @param uvOffset is an optional vector2 used to offset UV.\r\n * @param uvScale is an optional vector2 used to scale UV.\r\n * @param forceUpdate defines whether or not to force an update of the generated buffers. This is useful to apply on a deserialized model for instance.\r\n * @returns the Mesh.\r\n */\r\n Mesh.prototype.applyDisplacementMap = function (url, minHeight, maxHeight, onSuccess, uvOffset, uvScale, forceUpdate) {\r\n var _this = this;\r\n if (forceUpdate === void 0) { forceUpdate = false; }\r\n var scene = this.getScene();\r\n var onload = function (img) {\r\n // Getting height map data\r\n var heightMapWidth = img.width;\r\n var heightMapHeight = img.height;\r\n var canvas = CanvasGenerator.CreateCanvas(heightMapWidth, heightMapHeight);\r\n var context = canvas.getContext(\"2d\");\r\n context.drawImage(img, 0, 0);\r\n // Create VertexData from map data\r\n //Cast is due to wrong definition in lib.d.ts from ts 1.3 - https://github.com/Microsoft/TypeScript/issues/949\r\n var buffer = context.getImageData(0, 0, heightMapWidth, heightMapHeight).data;\r\n _this.applyDisplacementMapFromBuffer(buffer, heightMapWidth, heightMapHeight, minHeight, maxHeight, uvOffset, uvScale, forceUpdate);\r\n //execute success callback, if set\r\n if (onSuccess) {\r\n onSuccess(_this);\r\n }\r\n };\r\n Tools.LoadImage(url, onload, function () { }, scene.offlineProvider);\r\n return this;\r\n };\r\n /**\r\n * Modifies the mesh geometry according to a displacementMap buffer.\r\n * A displacement map is a colored image. Each pixel color value (actually a gradient computed from red, green, blue values) will give the displacement to apply to each mesh vertex.\r\n * The mesh must be set as updatable. Its internal geometry is directly modified, no new buffer are allocated.\r\n * @param buffer is a `Uint8Array` buffer containing series of `Uint8` lower than 255, the red, green, blue and alpha values of each successive pixel.\r\n * @param heightMapWidth is the width of the buffer image.\r\n * @param heightMapHeight is the height of the buffer image.\r\n * @param minHeight is the lower limit of the displacement.\r\n * @param maxHeight is the upper limit of the displacement.\r\n * @param onSuccess is an optional Javascript function to be called just after the mesh is modified. It is passed the modified mesh and must return nothing.\r\n * @param uvOffset is an optional vector2 used to offset UV.\r\n * @param uvScale is an optional vector2 used to scale UV.\r\n * @param forceUpdate defines whether or not to force an update of the generated buffers. This is useful to apply on a deserialized model for instance.\r\n * @returns the Mesh.\r\n */\r\n Mesh.prototype.applyDisplacementMapFromBuffer = function (buffer, heightMapWidth, heightMapHeight, minHeight, maxHeight, uvOffset, uvScale, forceUpdate) {\r\n if (forceUpdate === void 0) { forceUpdate = false; }\r\n if (!this.isVerticesDataPresent(VertexBuffer.PositionKind)\r\n || !this.isVerticesDataPresent(VertexBuffer.NormalKind)\r\n || !this.isVerticesDataPresent(VertexBuffer.UVKind)) {\r\n Logger.Warn(\"Cannot call applyDisplacementMap: Given mesh is not complete. Position, Normal or UV are missing\");\r\n return this;\r\n }\r\n var positions = this.getVerticesData(VertexBuffer.PositionKind, true, true);\r\n var normals = this.getVerticesData(VertexBuffer.NormalKind);\r\n var uvs = this.getVerticesData(VertexBuffer.UVKind);\r\n var position = Vector3.Zero();\r\n var normal = Vector3.Zero();\r\n var uv = Vector2.Zero();\r\n uvOffset = uvOffset || Vector2.Zero();\r\n uvScale = uvScale || new Vector2(1, 1);\r\n for (var index = 0; index < positions.length; index += 3) {\r\n Vector3.FromArrayToRef(positions, index, position);\r\n Vector3.FromArrayToRef(normals, index, normal);\r\n Vector2.FromArrayToRef(uvs, (index / 3) * 2, uv);\r\n // Compute height\r\n var u = ((Math.abs(uv.x * uvScale.x + uvOffset.x % 1) * (heightMapWidth - 1)) % heightMapWidth) | 0;\r\n var v = ((Math.abs(uv.y * uvScale.y + uvOffset.y % 1) * (heightMapHeight - 1)) % heightMapHeight) | 0;\r\n var pos = (u + v * heightMapWidth) * 4;\r\n var r = buffer[pos] / 255.0;\r\n var g = buffer[pos + 1] / 255.0;\r\n var b = buffer[pos + 2] / 255.0;\r\n var gradient = r * 0.3 + g * 0.59 + b * 0.11;\r\n normal.normalize();\r\n normal.scaleInPlace(minHeight + (maxHeight - minHeight) * gradient);\r\n position = position.add(normal);\r\n position.toArray(positions, index);\r\n }\r\n VertexData.ComputeNormals(positions, this.getIndices(), normals);\r\n if (forceUpdate) {\r\n this.setVerticesData(VertexBuffer.PositionKind, positions);\r\n this.setVerticesData(VertexBuffer.NormalKind, normals);\r\n }\r\n else {\r\n this.updateVerticesData(VertexBuffer.PositionKind, positions);\r\n this.updateVerticesData(VertexBuffer.NormalKind, normals);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Modify the mesh to get a flat shading rendering.\r\n * This means each mesh facet will then have its own normals. Usually new vertices are added in the mesh geometry to get this result.\r\n * Warning : the mesh is really modified even if not set originally as updatable and, under the hood, a new VertexBuffer is allocated.\r\n * @returns current mesh\r\n */\r\n Mesh.prototype.convertToFlatShadedMesh = function () {\r\n var kinds = this.getVerticesDataKinds();\r\n var vbs = {};\r\n var data = {};\r\n var newdata = {};\r\n var updatableNormals = false;\r\n var kindIndex;\r\n var kind;\r\n for (kindIndex = 0; kindIndex < kinds.length; kindIndex++) {\r\n kind = kinds[kindIndex];\r\n var vertexBuffer = this.getVertexBuffer(kind);\r\n if (kind === VertexBuffer.NormalKind) {\r\n updatableNormals = vertexBuffer.isUpdatable();\r\n kinds.splice(kindIndex, 1);\r\n kindIndex--;\r\n continue;\r\n }\r\n vbs[kind] = vertexBuffer;\r\n data[kind] = vbs[kind].getData();\r\n newdata[kind] = [];\r\n }\r\n // Save previous submeshes\r\n var previousSubmeshes = this.subMeshes.slice(0);\r\n var indices = this.getIndices();\r\n var totalIndices = this.getTotalIndices();\r\n // Generating unique vertices per face\r\n var index;\r\n for (index = 0; index < totalIndices; index++) {\r\n var vertexIndex = indices[index];\r\n for (kindIndex = 0; kindIndex < kinds.length; kindIndex++) {\r\n kind = kinds[kindIndex];\r\n var stride = vbs[kind].getStrideSize();\r\n for (var offset = 0; offset < stride; offset++) {\r\n newdata[kind].push(data[kind][vertexIndex * stride + offset]);\r\n }\r\n }\r\n }\r\n // Updating faces & normal\r\n var normals = [];\r\n var positions = newdata[VertexBuffer.PositionKind];\r\n for (index = 0; index < totalIndices; index += 3) {\r\n indices[index] = index;\r\n indices[index + 1] = index + 1;\r\n indices[index + 2] = index + 2;\r\n var p1 = Vector3.FromArray(positions, index * 3);\r\n var p2 = Vector3.FromArray(positions, (index + 1) * 3);\r\n var p3 = Vector3.FromArray(positions, (index + 2) * 3);\r\n var p1p2 = p1.subtract(p2);\r\n var p3p2 = p3.subtract(p2);\r\n var normal = Vector3.Normalize(Vector3.Cross(p1p2, p3p2));\r\n // Store same normals for every vertex\r\n for (var localIndex = 0; localIndex < 3; localIndex++) {\r\n normals.push(normal.x);\r\n normals.push(normal.y);\r\n normals.push(normal.z);\r\n }\r\n }\r\n this.setIndices(indices);\r\n this.setVerticesData(VertexBuffer.NormalKind, normals, updatableNormals);\r\n // Updating vertex buffers\r\n for (kindIndex = 0; kindIndex < kinds.length; kindIndex++) {\r\n kind = kinds[kindIndex];\r\n this.setVerticesData(kind, newdata[kind], vbs[kind].isUpdatable());\r\n }\r\n // Updating submeshes\r\n this.releaseSubMeshes();\r\n for (var submeshIndex = 0; submeshIndex < previousSubmeshes.length; submeshIndex++) {\r\n var previousOne = previousSubmeshes[submeshIndex];\r\n SubMesh.AddToMesh(previousOne.materialIndex, previousOne.indexStart, previousOne.indexCount, previousOne.indexStart, previousOne.indexCount, this);\r\n }\r\n this.synchronizeInstances();\r\n return this;\r\n };\r\n /**\r\n * This method removes all the mesh indices and add new vertices (duplication) in order to unfold facets into buffers.\r\n * In other words, more vertices, no more indices and a single bigger VBO.\r\n * The mesh is really modified even if not set originally as updatable. Under the hood, a new VertexBuffer is allocated.\r\n * @returns current mesh\r\n */\r\n Mesh.prototype.convertToUnIndexedMesh = function () {\r\n var kinds = this.getVerticesDataKinds();\r\n var vbs = {};\r\n var data = {};\r\n var newdata = {};\r\n var kindIndex;\r\n var kind;\r\n for (kindIndex = 0; kindIndex < kinds.length; kindIndex++) {\r\n kind = kinds[kindIndex];\r\n var vertexBuffer = this.getVertexBuffer(kind);\r\n vbs[kind] = vertexBuffer;\r\n data[kind] = vbs[kind].getData();\r\n newdata[kind] = [];\r\n }\r\n // Save previous submeshes\r\n var previousSubmeshes = this.subMeshes.slice(0);\r\n var indices = this.getIndices();\r\n var totalIndices = this.getTotalIndices();\r\n // Generating unique vertices per face\r\n var index;\r\n for (index = 0; index < totalIndices; index++) {\r\n var vertexIndex = indices[index];\r\n for (kindIndex = 0; kindIndex < kinds.length; kindIndex++) {\r\n kind = kinds[kindIndex];\r\n var stride = vbs[kind].getStrideSize();\r\n for (var offset = 0; offset < stride; offset++) {\r\n newdata[kind].push(data[kind][vertexIndex * stride + offset]);\r\n }\r\n }\r\n }\r\n // Updating indices\r\n for (index = 0; index < totalIndices; index += 3) {\r\n indices[index] = index;\r\n indices[index + 1] = index + 1;\r\n indices[index + 2] = index + 2;\r\n }\r\n this.setIndices(indices);\r\n // Updating vertex buffers\r\n for (kindIndex = 0; kindIndex < kinds.length; kindIndex++) {\r\n kind = kinds[kindIndex];\r\n this.setVerticesData(kind, newdata[kind], vbs[kind].isUpdatable());\r\n }\r\n // Updating submeshes\r\n this.releaseSubMeshes();\r\n for (var submeshIndex = 0; submeshIndex < previousSubmeshes.length; submeshIndex++) {\r\n var previousOne = previousSubmeshes[submeshIndex];\r\n SubMesh.AddToMesh(previousOne.materialIndex, previousOne.indexStart, previousOne.indexCount, previousOne.indexStart, previousOne.indexCount, this);\r\n }\r\n this._unIndexed = true;\r\n this.synchronizeInstances();\r\n return this;\r\n };\r\n /**\r\n * Inverses facet orientations.\r\n * Warning : the mesh is really modified even if not set originally as updatable. A new VertexBuffer is created under the hood each call.\r\n * @param flipNormals will also inverts the normals\r\n * @returns current mesh\r\n */\r\n Mesh.prototype.flipFaces = function (flipNormals) {\r\n if (flipNormals === void 0) { flipNormals = false; }\r\n var vertex_data = VertexData.ExtractFromMesh(this);\r\n var i;\r\n if (flipNormals && this.isVerticesDataPresent(VertexBuffer.NormalKind) && vertex_data.normals) {\r\n for (i = 0; i < vertex_data.normals.length; i++) {\r\n vertex_data.normals[i] *= -1;\r\n }\r\n }\r\n if (vertex_data.indices) {\r\n var temp;\r\n for (i = 0; i < vertex_data.indices.length; i += 3) {\r\n // reassign indices\r\n temp = vertex_data.indices[i + 1];\r\n vertex_data.indices[i + 1] = vertex_data.indices[i + 2];\r\n vertex_data.indices[i + 2] = temp;\r\n }\r\n }\r\n vertex_data.applyToMesh(this, this.isVertexBufferUpdatable(VertexBuffer.PositionKind));\r\n return this;\r\n };\r\n /**\r\n * Increase the number of facets and hence vertices in a mesh\r\n * Vertex normals are interpolated from existing vertex normals\r\n * Warning : the mesh is really modified even if not set originally as updatable. A new VertexBuffer is created under the hood each call.\r\n * @param numberPerEdge the number of new vertices to add to each edge of a facet, optional default 1\r\n */\r\n Mesh.prototype.increaseVertices = function (numberPerEdge) {\r\n var vertex_data = VertexData.ExtractFromMesh(this);\r\n var uvs = vertex_data.uvs;\r\n var currentIndices = vertex_data.indices;\r\n var positions = vertex_data.positions;\r\n var normals = vertex_data.normals;\r\n if (!currentIndices || !positions || !normals || !uvs) {\r\n Logger.Warn(\"VertexData contains null entries\");\r\n }\r\n else {\r\n var segments = numberPerEdge + 1; //segments per current facet edge, become sides of new facets\r\n var tempIndices = new Array();\r\n for (var i = 0; i < segments + 1; i++) {\r\n tempIndices[i] = new Array();\r\n }\r\n var a; //vertex index of one end of a side\r\n var b; //vertex index of other end of the side\r\n var deltaPosition = new Vector3(0, 0, 0);\r\n var deltaNormal = new Vector3(0, 0, 0);\r\n var deltaUV = new Vector2(0, 0);\r\n var indices = new Array();\r\n var vertexIndex = new Array();\r\n var side = new Array();\r\n var len;\r\n var positionPtr = positions.length;\r\n var uvPtr = uvs.length;\r\n for (var i = 0; i < currentIndices.length; i += 3) {\r\n vertexIndex[0] = currentIndices[i];\r\n vertexIndex[1] = currentIndices[i + 1];\r\n vertexIndex[2] = currentIndices[i + 2];\r\n for (var j = 0; j < 3; j++) {\r\n a = vertexIndex[j];\r\n b = vertexIndex[(j + 1) % 3];\r\n if (side[a] === undefined && side[b] === undefined) {\r\n side[a] = new Array();\r\n side[b] = new Array();\r\n }\r\n else {\r\n if (side[a] === undefined) {\r\n side[a] = new Array();\r\n }\r\n if (side[b] === undefined) {\r\n side[b] = new Array();\r\n }\r\n }\r\n if (side[a][b] === undefined && side[b][a] === undefined) {\r\n side[a][b] = [];\r\n deltaPosition.x = (positions[3 * b] - positions[3 * a]) / segments;\r\n deltaPosition.y = (positions[3 * b + 1] - positions[3 * a + 1]) / segments;\r\n deltaPosition.z = (positions[3 * b + 2] - positions[3 * a + 2]) / segments;\r\n deltaNormal.x = (normals[3 * b] - normals[3 * a]) / segments;\r\n deltaNormal.y = (normals[3 * b + 1] - normals[3 * a + 1]) / segments;\r\n deltaNormal.z = (normals[3 * b + 2] - normals[3 * a + 2]) / segments;\r\n deltaUV.x = (uvs[2 * b] - uvs[2 * a]) / segments;\r\n deltaUV.y = (uvs[2 * b + 1] - uvs[2 * a + 1]) / segments;\r\n side[a][b].push(a);\r\n for (var k = 1; k < segments; k++) {\r\n side[a][b].push(positions.length / 3);\r\n positions[positionPtr] = positions[3 * a] + k * deltaPosition.x;\r\n normals[positionPtr++] = normals[3 * a] + k * deltaNormal.x;\r\n positions[positionPtr] = positions[3 * a + 1] + k * deltaPosition.y;\r\n normals[positionPtr++] = normals[3 * a + 1] + k * deltaNormal.y;\r\n positions[positionPtr] = positions[3 * a + 2] + k * deltaPosition.z;\r\n normals[positionPtr++] = normals[3 * a + 2] + k * deltaNormal.z;\r\n uvs[uvPtr++] = uvs[2 * a] + k * deltaUV.x;\r\n uvs[uvPtr++] = uvs[2 * a + 1] + k * deltaUV.y;\r\n }\r\n side[a][b].push(b);\r\n side[b][a] = new Array();\r\n len = side[a][b].length;\r\n for (var idx = 0; idx < len; idx++) {\r\n side[b][a][idx] = side[a][b][len - 1 - idx];\r\n }\r\n }\r\n }\r\n //Calculate positions, normals and uvs of new internal vertices\r\n tempIndices[0][0] = currentIndices[i];\r\n tempIndices[1][0] = side[currentIndices[i]][currentIndices[i + 1]][1];\r\n tempIndices[1][1] = side[currentIndices[i]][currentIndices[i + 2]][1];\r\n for (var k = 2; k < segments; k++) {\r\n tempIndices[k][0] = side[currentIndices[i]][currentIndices[i + 1]][k];\r\n tempIndices[k][k] = side[currentIndices[i]][currentIndices[i + 2]][k];\r\n deltaPosition.x = (positions[3 * tempIndices[k][k]] - positions[3 * tempIndices[k][0]]) / k;\r\n deltaPosition.y = (positions[3 * tempIndices[k][k] + 1] - positions[3 * tempIndices[k][0] + 1]) / k;\r\n deltaPosition.z = (positions[3 * tempIndices[k][k] + 2] - positions[3 * tempIndices[k][0] + 2]) / k;\r\n deltaNormal.x = (normals[3 * tempIndices[k][k]] - normals[3 * tempIndices[k][0]]) / k;\r\n deltaNormal.y = (normals[3 * tempIndices[k][k] + 1] - normals[3 * tempIndices[k][0] + 1]) / k;\r\n deltaNormal.z = (normals[3 * tempIndices[k][k] + 2] - normals[3 * tempIndices[k][0] + 2]) / k;\r\n deltaUV.x = (uvs[2 * tempIndices[k][k]] - uvs[2 * tempIndices[k][0]]) / k;\r\n deltaUV.y = (uvs[2 * tempIndices[k][k] + 1] - uvs[2 * tempIndices[k][0] + 1]) / k;\r\n for (var j = 1; j < k; j++) {\r\n tempIndices[k][j] = positions.length / 3;\r\n positions[positionPtr] = positions[3 * tempIndices[k][0]] + j * deltaPosition.x;\r\n normals[positionPtr++] = normals[3 * tempIndices[k][0]] + j * deltaNormal.x;\r\n positions[positionPtr] = positions[3 * tempIndices[k][0] + 1] + j * deltaPosition.y;\r\n normals[positionPtr++] = normals[3 * tempIndices[k][0] + 1] + j * deltaNormal.y;\r\n positions[positionPtr] = positions[3 * tempIndices[k][0] + 2] + j * deltaPosition.z;\r\n normals[positionPtr++] = normals[3 * tempIndices[k][0] + 2] + j * deltaNormal.z;\r\n uvs[uvPtr++] = uvs[2 * tempIndices[k][0]] + j * deltaUV.x;\r\n uvs[uvPtr++] = uvs[2 * tempIndices[k][0] + 1] + j * deltaUV.y;\r\n }\r\n }\r\n tempIndices[segments] = side[currentIndices[i + 1]][currentIndices[i + 2]];\r\n // reform indices\r\n indices.push(tempIndices[0][0], tempIndices[1][0], tempIndices[1][1]);\r\n for (var k = 1; k < segments; k++) {\r\n for (var j = 0; j < k; j++) {\r\n indices.push(tempIndices[k][j], tempIndices[k + 1][j], tempIndices[k + 1][j + 1]);\r\n indices.push(tempIndices[k][j], tempIndices[k + 1][j + 1], tempIndices[k][j + 1]);\r\n }\r\n indices.push(tempIndices[k][j], tempIndices[k + 1][j], tempIndices[k + 1][j + 1]);\r\n }\r\n }\r\n vertex_data.indices = indices;\r\n vertex_data.applyToMesh(this, this.isVertexBufferUpdatable(VertexBuffer.PositionKind));\r\n }\r\n };\r\n /**\r\n * Force adjacent facets to share vertices and remove any facets that have all vertices in a line\r\n * This will undo any application of covertToFlatShadedMesh\r\n * Warning : the mesh is really modified even if not set originally as updatable. A new VertexBuffer is created under the hood each call.\r\n */\r\n Mesh.prototype.forceSharedVertices = function () {\r\n var vertex_data = VertexData.ExtractFromMesh(this);\r\n var currentUVs = vertex_data.uvs;\r\n var currentIndices = vertex_data.indices;\r\n var currentPositions = vertex_data.positions;\r\n var currentColors = vertex_data.colors;\r\n if (currentIndices === void 0 || currentPositions === void 0 || currentIndices === null || currentPositions === null) {\r\n Logger.Warn(\"VertexData contains empty entries\");\r\n }\r\n else {\r\n var positions = new Array();\r\n var indices = new Array();\r\n var uvs = new Array();\r\n var colors = new Array();\r\n var pstring = new Array(); //lists facet vertex positions (a,b,c) as string \"a|b|c\"\r\n var indexPtr = 0; // pointer to next available index value\r\n var uniquePositions = {}; // unique vertex positions\r\n var ptr; // pointer to element in uniquePositions\r\n var facet;\r\n for (var i = 0; i < currentIndices.length; i += 3) {\r\n facet = [currentIndices[i], currentIndices[i + 1], currentIndices[i + 2]]; //facet vertex indices\r\n pstring = new Array();\r\n for (var j = 0; j < 3; j++) {\r\n pstring[j] = \"\";\r\n for (var k = 0; k < 3; k++) {\r\n //small values make 0\r\n if (Math.abs(currentPositions[3 * facet[j] + k]) < 0.00000001) {\r\n currentPositions[3 * facet[j] + k] = 0;\r\n }\r\n pstring[j] += currentPositions[3 * facet[j] + k] + \"|\";\r\n }\r\n }\r\n //check facet vertices to see that none are repeated\r\n // do not process any facet that has a repeated vertex, ie is a line\r\n if (!(pstring[0] == pstring[1] || pstring[0] == pstring[2] || pstring[1] == pstring[2])) {\r\n //for each facet position check if already listed in uniquePositions\r\n // if not listed add to uniquePositions and set index pointer\r\n // if listed use its index in uniquePositions and new index pointer\r\n for (var j = 0; j < 3; j++) {\r\n ptr = uniquePositions[pstring[j]];\r\n if (ptr === undefined) {\r\n uniquePositions[pstring[j]] = indexPtr;\r\n ptr = indexPtr++;\r\n //not listed so add individual x, y, z coordinates to positions\r\n for (var k = 0; k < 3; k++) {\r\n positions.push(currentPositions[3 * facet[j] + k]);\r\n }\r\n if (currentColors !== null && currentColors !== void 0) {\r\n for (var k = 0; k < 4; k++) {\r\n colors.push(currentColors[4 * facet[j] + k]);\r\n }\r\n }\r\n if (currentUVs !== null && currentUVs !== void 0) {\r\n for (var k = 0; k < 2; k++) {\r\n uvs.push(currentUVs[2 * facet[j] + k]);\r\n }\r\n }\r\n }\r\n // add new index pointer to indices array\r\n indices.push(ptr);\r\n }\r\n }\r\n }\r\n var normals = new Array();\r\n VertexData.ComputeNormals(positions, indices, normals);\r\n //create new vertex data object and update\r\n vertex_data.positions = positions;\r\n vertex_data.indices = indices;\r\n vertex_data.normals = normals;\r\n if (currentUVs !== null && currentUVs !== void 0) {\r\n vertex_data.uvs = uvs;\r\n }\r\n if (currentColors !== null && currentColors !== void 0) {\r\n vertex_data.colors = colors;\r\n }\r\n vertex_data.applyToMesh(this, this.isVertexBufferUpdatable(VertexBuffer.PositionKind));\r\n }\r\n };\r\n // Instances\r\n /** @hidden */\r\n Mesh._instancedMeshFactory = function (name, mesh) {\r\n throw _DevTools.WarnImport(\"InstancedMesh\");\r\n };\r\n /** @hidden */\r\n Mesh._PhysicsImpostorParser = function (scene, physicObject, jsonObject) {\r\n throw _DevTools.WarnImport(\"PhysicsImpostor\");\r\n };\r\n /**\r\n * Creates a new InstancedMesh object from the mesh model.\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_instances\r\n * @param name defines the name of the new instance\r\n * @returns a new InstancedMesh\r\n */\r\n Mesh.prototype.createInstance = function (name) {\r\n var geometry = this.geometry;\r\n if (geometry && geometry.meshes.length > 1) {\r\n var others = geometry.meshes.slice(0);\r\n for (var _i = 0, others_1 = others; _i < others_1.length; _i++) {\r\n var other = others_1[_i];\r\n if (other === this) {\r\n continue;\r\n }\r\n other.makeGeometryUnique();\r\n }\r\n }\r\n return Mesh._instancedMeshFactory(name, this);\r\n };\r\n /**\r\n * Synchronises all the mesh instance submeshes to the current mesh submeshes, if any.\r\n * After this call, all the mesh instances have the same submeshes than the current mesh.\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.synchronizeInstances = function () {\r\n if (this._geometry && this._geometry.meshes.length !== 1 && this.instances.length) {\r\n this.makeGeometryUnique();\r\n }\r\n for (var instanceIndex = 0; instanceIndex < this.instances.length; instanceIndex++) {\r\n var instance = this.instances[instanceIndex];\r\n instance._syncSubMeshes();\r\n }\r\n return this;\r\n };\r\n /**\r\n * Optimization of the mesh's indices, in case a mesh has duplicated vertices.\r\n * The function will only reorder the indices and will not remove unused vertices to avoid problems with submeshes.\r\n * This should be used together with the simplification to avoid disappearing triangles.\r\n * @param successCallback an optional success callback to be called after the optimization finished.\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.optimizeIndices = function (successCallback) {\r\n var _this = this;\r\n var indices = this.getIndices();\r\n var positions = this.getVerticesData(VertexBuffer.PositionKind);\r\n if (!positions || !indices) {\r\n return this;\r\n }\r\n var vectorPositions = new Array();\r\n for (var pos = 0; pos < positions.length; pos = pos + 3) {\r\n vectorPositions.push(Vector3.FromArray(positions, pos));\r\n }\r\n var dupes = new Array();\r\n AsyncLoop.SyncAsyncForLoop(vectorPositions.length, 40, function (iteration) {\r\n var realPos = vectorPositions.length - 1 - iteration;\r\n var testedPosition = vectorPositions[realPos];\r\n for (var j = 0; j < realPos; ++j) {\r\n var againstPosition = vectorPositions[j];\r\n if (testedPosition.equals(againstPosition)) {\r\n dupes[realPos] = j;\r\n break;\r\n }\r\n }\r\n }, function () {\r\n for (var i = 0; i < indices.length; ++i) {\r\n indices[i] = dupes[indices[i]] || indices[i];\r\n }\r\n //indices are now reordered\r\n var originalSubMeshes = _this.subMeshes.slice(0);\r\n _this.setIndices(indices);\r\n _this.subMeshes = originalSubMeshes;\r\n if (successCallback) {\r\n successCallback(_this);\r\n }\r\n });\r\n return this;\r\n };\r\n /**\r\n * Serialize current mesh\r\n * @param serializationObject defines the object which will receive the serialization data\r\n */\r\n Mesh.prototype.serialize = function (serializationObject) {\r\n serializationObject.name = this.name;\r\n serializationObject.id = this.id;\r\n serializationObject.uniqueId = this.uniqueId;\r\n serializationObject.type = this.getClassName();\r\n if (Tags && Tags.HasTags(this)) {\r\n serializationObject.tags = Tags.GetTags(this);\r\n }\r\n serializationObject.position = this.position.asArray();\r\n if (this.rotationQuaternion) {\r\n serializationObject.rotationQuaternion = this.rotationQuaternion.asArray();\r\n }\r\n else if (this.rotation) {\r\n serializationObject.rotation = this.rotation.asArray();\r\n }\r\n serializationObject.scaling = this.scaling.asArray();\r\n if (this._postMultiplyPivotMatrix) {\r\n serializationObject.pivotMatrix = this.getPivotMatrix().asArray();\r\n }\r\n else {\r\n serializationObject.localMatrix = this.getPivotMatrix().asArray();\r\n }\r\n serializationObject.isEnabled = this.isEnabled(false);\r\n serializationObject.isVisible = this.isVisible;\r\n serializationObject.infiniteDistance = this.infiniteDistance;\r\n serializationObject.pickable = this.isPickable;\r\n serializationObject.receiveShadows = this.receiveShadows;\r\n serializationObject.billboardMode = this.billboardMode;\r\n serializationObject.visibility = this.visibility;\r\n serializationObject.checkCollisions = this.checkCollisions;\r\n serializationObject.isBlocker = this.isBlocker;\r\n serializationObject.overrideMaterialSideOrientation = this.overrideMaterialSideOrientation;\r\n // Parent\r\n if (this.parent) {\r\n serializationObject.parentId = this.parent.id;\r\n }\r\n // Geometry\r\n serializationObject.isUnIndexed = this.isUnIndexed;\r\n var geometry = this._geometry;\r\n if (geometry) {\r\n var geometryId = geometry.id;\r\n serializationObject.geometryId = geometryId;\r\n // SubMeshes\r\n serializationObject.subMeshes = [];\r\n for (var subIndex = 0; subIndex < this.subMeshes.length; subIndex++) {\r\n var subMesh = this.subMeshes[subIndex];\r\n serializationObject.subMeshes.push({\r\n materialIndex: subMesh.materialIndex,\r\n verticesStart: subMesh.verticesStart,\r\n verticesCount: subMesh.verticesCount,\r\n indexStart: subMesh.indexStart,\r\n indexCount: subMesh.indexCount\r\n });\r\n }\r\n }\r\n // Material\r\n if (this.material) {\r\n if (!this.material.doNotSerialize) {\r\n serializationObject.materialId = this.material.id;\r\n }\r\n }\r\n else {\r\n this.material = null;\r\n }\r\n // Morph targets\r\n if (this.morphTargetManager) {\r\n serializationObject.morphTargetManagerId = this.morphTargetManager.uniqueId;\r\n }\r\n // Skeleton\r\n if (this.skeleton) {\r\n serializationObject.skeletonId = this.skeleton.id;\r\n serializationObject.numBoneInfluencers = this.numBoneInfluencers;\r\n }\r\n // Physics\r\n //TODO implement correct serialization for physics impostors.\r\n if (this.getScene()._getComponent(SceneComponentConstants.NAME_PHYSICSENGINE)) {\r\n var impostor = this.getPhysicsImpostor();\r\n if (impostor) {\r\n serializationObject.physicsMass = impostor.getParam(\"mass\");\r\n serializationObject.physicsFriction = impostor.getParam(\"friction\");\r\n serializationObject.physicsRestitution = impostor.getParam(\"mass\");\r\n serializationObject.physicsImpostor = impostor.type;\r\n }\r\n }\r\n // Metadata\r\n if (this.metadata) {\r\n serializationObject.metadata = this.metadata;\r\n }\r\n // Instances\r\n serializationObject.instances = [];\r\n for (var index = 0; index < this.instances.length; index++) {\r\n var instance = this.instances[index];\r\n if (instance.doNotSerialize) {\r\n continue;\r\n }\r\n var serializationInstance = {\r\n name: instance.name,\r\n id: instance.id,\r\n isEnabled: instance.isEnabled(false),\r\n isVisible: instance.isVisible,\r\n isPickable: instance.isPickable,\r\n checkCollisions: instance.checkCollisions,\r\n position: instance.position.asArray(),\r\n scaling: instance.scaling.asArray()\r\n };\r\n if (instance.parent) {\r\n serializationInstance.parentId = instance.parent.id;\r\n }\r\n if (instance.rotationQuaternion) {\r\n serializationInstance.rotationQuaternion = instance.rotationQuaternion.asArray();\r\n }\r\n else if (instance.rotation) {\r\n serializationInstance.rotation = instance.rotation.asArray();\r\n }\r\n // Physics\r\n //TODO implement correct serialization for physics impostors.\r\n if (this.getScene()._getComponent(SceneComponentConstants.NAME_PHYSICSENGINE)) {\r\n var impostor = instance.getPhysicsImpostor();\r\n if (impostor) {\r\n serializationInstance.physicsMass = impostor.getParam(\"mass\");\r\n serializationInstance.physicsFriction = impostor.getParam(\"friction\");\r\n serializationInstance.physicsRestitution = impostor.getParam(\"mass\");\r\n serializationInstance.physicsImpostor = impostor.type;\r\n }\r\n }\r\n // Metadata\r\n if (instance.metadata) {\r\n serializationInstance.metadata = instance.metadata;\r\n }\r\n serializationObject.instances.push(serializationInstance);\r\n // Animations\r\n SerializationHelper.AppendSerializedAnimations(instance, serializationInstance);\r\n serializationInstance.ranges = instance.serializeAnimationRanges();\r\n }\r\n // Thin instances\r\n if (this._thinInstanceDataStorage.instancesCount && this._thinInstanceDataStorage.matrixData) {\r\n serializationObject.thinInstances = {\r\n instancesCount: this._thinInstanceDataStorage.instancesCount,\r\n matrixData: Tools.SliceToArray(this._thinInstanceDataStorage.matrixData),\r\n matrixBufferSize: this._thinInstanceDataStorage.matrixBufferSize,\r\n };\r\n if (this._userThinInstanceBuffersStorage) {\r\n var userThinInstance = {\r\n data: {},\r\n sizes: {},\r\n strides: {},\r\n };\r\n for (var kind in this._userThinInstanceBuffersStorage.data) {\r\n userThinInstance.data[kind] = Tools.SliceToArray(this._userThinInstanceBuffersStorage.data[kind]);\r\n userThinInstance.sizes[kind] = this._userThinInstanceBuffersStorage.sizes[kind];\r\n userThinInstance.strides[kind] = this._userThinInstanceBuffersStorage.strides[kind];\r\n }\r\n serializationObject.thinInstances.userThinInstance = userThinInstance;\r\n }\r\n }\r\n // Animations\r\n SerializationHelper.AppendSerializedAnimations(this, serializationObject);\r\n serializationObject.ranges = this.serializeAnimationRanges();\r\n // Layer mask\r\n serializationObject.layerMask = this.layerMask;\r\n // Alpha\r\n serializationObject.alphaIndex = this.alphaIndex;\r\n serializationObject.hasVertexAlpha = this.hasVertexAlpha;\r\n // Overlay\r\n serializationObject.overlayAlpha = this.overlayAlpha;\r\n serializationObject.overlayColor = this.overlayColor.asArray();\r\n serializationObject.renderOverlay = this.renderOverlay;\r\n // Fog\r\n serializationObject.applyFog = this.applyFog;\r\n // Action Manager\r\n if (this.actionManager) {\r\n serializationObject.actions = this.actionManager.serialize(this.name);\r\n }\r\n };\r\n /** @hidden */\r\n Mesh.prototype._syncGeometryWithMorphTargetManager = function () {\r\n if (!this.geometry) {\r\n return;\r\n }\r\n this._markSubMeshesAsAttributesDirty();\r\n var morphTargetManager = this._internalMeshDataInfo._morphTargetManager;\r\n if (morphTargetManager && morphTargetManager.vertexCount) {\r\n if (morphTargetManager.vertexCount !== this.getTotalVertices()) {\r\n Logger.Error(\"Mesh is incompatible with morph targets. Targets and mesh must all have the same vertices count.\");\r\n this.morphTargetManager = null;\r\n return;\r\n }\r\n for (var index = 0; index < morphTargetManager.numInfluencers; index++) {\r\n var morphTarget = morphTargetManager.getActiveTarget(index);\r\n var positions = morphTarget.getPositions();\r\n if (!positions) {\r\n Logger.Error(\"Invalid morph target. Target must have positions.\");\r\n return;\r\n }\r\n this.geometry.setVerticesData(VertexBuffer.PositionKind + index, positions, false, 3);\r\n var normals = morphTarget.getNormals();\r\n if (normals) {\r\n this.geometry.setVerticesData(VertexBuffer.NormalKind + index, normals, false, 3);\r\n }\r\n var tangents = morphTarget.getTangents();\r\n if (tangents) {\r\n this.geometry.setVerticesData(VertexBuffer.TangentKind + index, tangents, false, 3);\r\n }\r\n var uvs = morphTarget.getUVs();\r\n if (uvs) {\r\n this.geometry.setVerticesData(VertexBuffer.UVKind + \"_\" + index, uvs, false, 2);\r\n }\r\n }\r\n }\r\n else {\r\n var index = 0;\r\n // Positions\r\n while (this.geometry.isVerticesDataPresent(VertexBuffer.PositionKind + index)) {\r\n this.geometry.removeVerticesData(VertexBuffer.PositionKind + index);\r\n if (this.geometry.isVerticesDataPresent(VertexBuffer.NormalKind + index)) {\r\n this.geometry.removeVerticesData(VertexBuffer.NormalKind + index);\r\n }\r\n if (this.geometry.isVerticesDataPresent(VertexBuffer.TangentKind + index)) {\r\n this.geometry.removeVerticesData(VertexBuffer.TangentKind + index);\r\n }\r\n if (this.geometry.isVerticesDataPresent(VertexBuffer.UVKind + index)) {\r\n this.geometry.removeVerticesData(VertexBuffer.UVKind + \"_\" + index);\r\n }\r\n index++;\r\n }\r\n }\r\n };\r\n /**\r\n * Returns a new Mesh object parsed from the source provided.\r\n * @param parsedMesh is the source\r\n * @param scene defines the hosting scene\r\n * @param rootUrl is the root URL to prefix the `delayLoadingFile` property with\r\n * @returns a new Mesh\r\n */\r\n Mesh.Parse = function (parsedMesh, scene, rootUrl) {\r\n var mesh;\r\n if (parsedMesh.type && parsedMesh.type === \"GroundMesh\") {\r\n mesh = Mesh._GroundMeshParser(parsedMesh, scene);\r\n }\r\n else {\r\n mesh = new Mesh(parsedMesh.name, scene);\r\n }\r\n mesh.id = parsedMesh.id;\r\n if (Tags) {\r\n Tags.AddTagsTo(mesh, parsedMesh.tags);\r\n }\r\n mesh.position = Vector3.FromArray(parsedMesh.position);\r\n if (parsedMesh.metadata !== undefined) {\r\n mesh.metadata = parsedMesh.metadata;\r\n }\r\n if (parsedMesh.rotationQuaternion) {\r\n mesh.rotationQuaternion = Quaternion.FromArray(parsedMesh.rotationQuaternion);\r\n }\r\n else if (parsedMesh.rotation) {\r\n mesh.rotation = Vector3.FromArray(parsedMesh.rotation);\r\n }\r\n mesh.scaling = Vector3.FromArray(parsedMesh.scaling);\r\n if (parsedMesh.localMatrix) {\r\n mesh.setPreTransformMatrix(Matrix.FromArray(parsedMesh.localMatrix));\r\n }\r\n else if (parsedMesh.pivotMatrix) {\r\n mesh.setPivotMatrix(Matrix.FromArray(parsedMesh.pivotMatrix));\r\n }\r\n mesh.setEnabled(parsedMesh.isEnabled);\r\n mesh.isVisible = parsedMesh.isVisible;\r\n mesh.infiniteDistance = parsedMesh.infiniteDistance;\r\n mesh.showBoundingBox = parsedMesh.showBoundingBox;\r\n mesh.showSubMeshesBoundingBox = parsedMesh.showSubMeshesBoundingBox;\r\n if (parsedMesh.applyFog !== undefined) {\r\n mesh.applyFog = parsedMesh.applyFog;\r\n }\r\n if (parsedMesh.pickable !== undefined) {\r\n mesh.isPickable = parsedMesh.pickable;\r\n }\r\n if (parsedMesh.alphaIndex !== undefined) {\r\n mesh.alphaIndex = parsedMesh.alphaIndex;\r\n }\r\n mesh.receiveShadows = parsedMesh.receiveShadows;\r\n mesh.billboardMode = parsedMesh.billboardMode;\r\n if (parsedMesh.visibility !== undefined) {\r\n mesh.visibility = parsedMesh.visibility;\r\n }\r\n mesh.checkCollisions = parsedMesh.checkCollisions;\r\n mesh.overrideMaterialSideOrientation = parsedMesh.overrideMaterialSideOrientation;\r\n if (parsedMesh.isBlocker !== undefined) {\r\n mesh.isBlocker = parsedMesh.isBlocker;\r\n }\r\n mesh._shouldGenerateFlatShading = parsedMesh.useFlatShading;\r\n // freezeWorldMatrix\r\n if (parsedMesh.freezeWorldMatrix) {\r\n mesh._waitingData.freezeWorldMatrix = parsedMesh.freezeWorldMatrix;\r\n }\r\n // Parent\r\n if (parsedMesh.parentId) {\r\n mesh._waitingParentId = parsedMesh.parentId;\r\n }\r\n // Actions\r\n if (parsedMesh.actions !== undefined) {\r\n mesh._waitingData.actions = parsedMesh.actions;\r\n }\r\n // Overlay\r\n if (parsedMesh.overlayAlpha !== undefined) {\r\n mesh.overlayAlpha = parsedMesh.overlayAlpha;\r\n }\r\n if (parsedMesh.overlayColor !== undefined) {\r\n mesh.overlayColor = Color3.FromArray(parsedMesh.overlayColor);\r\n }\r\n if (parsedMesh.renderOverlay !== undefined) {\r\n mesh.renderOverlay = parsedMesh.renderOverlay;\r\n }\r\n // Geometry\r\n mesh.isUnIndexed = !!parsedMesh.isUnIndexed;\r\n mesh.hasVertexAlpha = parsedMesh.hasVertexAlpha;\r\n if (parsedMesh.delayLoadingFile) {\r\n mesh.delayLoadState = 4;\r\n mesh.delayLoadingFile = rootUrl + parsedMesh.delayLoadingFile;\r\n mesh._boundingInfo = new BoundingInfo(Vector3.FromArray(parsedMesh.boundingBoxMinimum), Vector3.FromArray(parsedMesh.boundingBoxMaximum));\r\n if (parsedMesh._binaryInfo) {\r\n mesh._binaryInfo = parsedMesh._binaryInfo;\r\n }\r\n mesh._delayInfo = [];\r\n if (parsedMesh.hasUVs) {\r\n mesh._delayInfo.push(VertexBuffer.UVKind);\r\n }\r\n if (parsedMesh.hasUVs2) {\r\n mesh._delayInfo.push(VertexBuffer.UV2Kind);\r\n }\r\n if (parsedMesh.hasUVs3) {\r\n mesh._delayInfo.push(VertexBuffer.UV3Kind);\r\n }\r\n if (parsedMesh.hasUVs4) {\r\n mesh._delayInfo.push(VertexBuffer.UV4Kind);\r\n }\r\n if (parsedMesh.hasUVs5) {\r\n mesh._delayInfo.push(VertexBuffer.UV5Kind);\r\n }\r\n if (parsedMesh.hasUVs6) {\r\n mesh._delayInfo.push(VertexBuffer.UV6Kind);\r\n }\r\n if (parsedMesh.hasColors) {\r\n mesh._delayInfo.push(VertexBuffer.ColorKind);\r\n }\r\n if (parsedMesh.hasMatricesIndices) {\r\n mesh._delayInfo.push(VertexBuffer.MatricesIndicesKind);\r\n }\r\n if (parsedMesh.hasMatricesWeights) {\r\n mesh._delayInfo.push(VertexBuffer.MatricesWeightsKind);\r\n }\r\n mesh._delayLoadingFunction = Geometry._ImportGeometry;\r\n if (SceneLoaderFlags.ForceFullSceneLoadingForIncremental) {\r\n mesh._checkDelayState();\r\n }\r\n }\r\n else {\r\n Geometry._ImportGeometry(parsedMesh, mesh);\r\n }\r\n // Material\r\n if (parsedMesh.materialId) {\r\n mesh.setMaterialByID(parsedMesh.materialId);\r\n }\r\n else {\r\n mesh.material = null;\r\n }\r\n // Morph targets\r\n if (parsedMesh.morphTargetManagerId > -1) {\r\n mesh.morphTargetManager = scene.getMorphTargetManagerById(parsedMesh.morphTargetManagerId);\r\n }\r\n // Skeleton\r\n if (parsedMesh.skeletonId !== undefined && parsedMesh.skeletonId !== null) {\r\n mesh.skeleton = scene.getLastSkeletonByID(parsedMesh.skeletonId);\r\n if (parsedMesh.numBoneInfluencers) {\r\n mesh.numBoneInfluencers = parsedMesh.numBoneInfluencers;\r\n }\r\n }\r\n // Animations\r\n if (parsedMesh.animations) {\r\n for (var animationIndex = 0; animationIndex < parsedMesh.animations.length; animationIndex++) {\r\n var parsedAnimation = parsedMesh.animations[animationIndex];\r\n var internalClass = _TypeStore.GetClass(\"BABYLON.Animation\");\r\n if (internalClass) {\r\n mesh.animations.push(internalClass.Parse(parsedAnimation));\r\n }\r\n }\r\n Node.ParseAnimationRanges(mesh, parsedMesh, scene);\r\n }\r\n if (parsedMesh.autoAnimate) {\r\n scene.beginAnimation(mesh, parsedMesh.autoAnimateFrom, parsedMesh.autoAnimateTo, parsedMesh.autoAnimateLoop, parsedMesh.autoAnimateSpeed || 1.0);\r\n }\r\n // Layer Mask\r\n if (parsedMesh.layerMask && (!isNaN(parsedMesh.layerMask))) {\r\n mesh.layerMask = Math.abs(parseInt(parsedMesh.layerMask));\r\n }\r\n else {\r\n mesh.layerMask = 0x0FFFFFFF;\r\n }\r\n // Physics\r\n if (parsedMesh.physicsImpostor) {\r\n Mesh._PhysicsImpostorParser(scene, mesh, parsedMesh);\r\n }\r\n // Levels\r\n if (parsedMesh.lodMeshIds) {\r\n mesh._waitingData.lods = {\r\n ids: parsedMesh.lodMeshIds,\r\n distances: (parsedMesh.lodDistances) ? parsedMesh.lodDistances : null,\r\n coverages: (parsedMesh.lodCoverages) ? parsedMesh.lodCoverages : null\r\n };\r\n }\r\n // Instances\r\n if (parsedMesh.instances) {\r\n for (var index = 0; index < parsedMesh.instances.length; index++) {\r\n var parsedInstance = parsedMesh.instances[index];\r\n var instance = mesh.createInstance(parsedInstance.name);\r\n if (parsedInstance.id) {\r\n instance.id = parsedInstance.id;\r\n }\r\n if (Tags) {\r\n if (parsedInstance.tags) {\r\n Tags.AddTagsTo(instance, parsedInstance.tags);\r\n }\r\n else {\r\n Tags.AddTagsTo(instance, parsedMesh.tags);\r\n }\r\n }\r\n instance.position = Vector3.FromArray(parsedInstance.position);\r\n if (parsedInstance.metadata !== undefined) {\r\n instance.metadata = parsedInstance.metadata;\r\n }\r\n if (parsedInstance.parentId) {\r\n instance._waitingParentId = parsedInstance.parentId;\r\n }\r\n if (parsedInstance.isEnabled !== undefined && parsedInstance.isEnabled !== null) {\r\n instance.setEnabled(parsedInstance.isEnabled);\r\n }\r\n if (parsedInstance.isVisible !== undefined && parsedInstance.isVisible !== null) {\r\n instance.isVisible = parsedInstance.isVisible;\r\n }\r\n if (parsedInstance.isPickable !== undefined && parsedInstance.isPickable !== null) {\r\n instance.isPickable = parsedInstance.isPickable;\r\n }\r\n if (parsedInstance.rotationQuaternion) {\r\n instance.rotationQuaternion = Quaternion.FromArray(parsedInstance.rotationQuaternion);\r\n }\r\n else if (parsedInstance.rotation) {\r\n instance.rotation = Vector3.FromArray(parsedInstance.rotation);\r\n }\r\n instance.scaling = Vector3.FromArray(parsedInstance.scaling);\r\n if (parsedInstance.checkCollisions != undefined && parsedInstance.checkCollisions != null) {\r\n instance.checkCollisions = parsedInstance.checkCollisions;\r\n }\r\n if (parsedInstance.pickable != undefined && parsedInstance.pickable != null) {\r\n instance.isPickable = parsedInstance.pickable;\r\n }\r\n if (parsedInstance.showBoundingBox != undefined && parsedInstance.showBoundingBox != null) {\r\n instance.showBoundingBox = parsedInstance.showBoundingBox;\r\n }\r\n if (parsedInstance.showSubMeshesBoundingBox != undefined && parsedInstance.showSubMeshesBoundingBox != null) {\r\n instance.showSubMeshesBoundingBox = parsedInstance.showSubMeshesBoundingBox;\r\n }\r\n if (parsedInstance.alphaIndex != undefined && parsedInstance.showSubMeshesBoundingBox != null) {\r\n instance.alphaIndex = parsedInstance.alphaIndex;\r\n }\r\n // Physics\r\n if (parsedInstance.physicsImpostor) {\r\n Mesh._PhysicsImpostorParser(scene, instance, parsedInstance);\r\n }\r\n // Animation\r\n if (parsedInstance.animations) {\r\n for (animationIndex = 0; animationIndex < parsedInstance.animations.length; animationIndex++) {\r\n parsedAnimation = parsedInstance.animations[animationIndex];\r\n var internalClass = _TypeStore.GetClass(\"BABYLON.Animation\");\r\n if (internalClass) {\r\n instance.animations.push(internalClass.Parse(parsedAnimation));\r\n }\r\n }\r\n Node.ParseAnimationRanges(instance, parsedInstance, scene);\r\n if (parsedInstance.autoAnimate) {\r\n scene.beginAnimation(instance, parsedInstance.autoAnimateFrom, parsedInstance.autoAnimateTo, parsedInstance.autoAnimateLoop, parsedInstance.autoAnimateSpeed || 1.0);\r\n }\r\n }\r\n }\r\n }\r\n // Thin instances\r\n if (parsedMesh.thinInstances) {\r\n var thinInstances = parsedMesh.thinInstances;\r\n if (thinInstances.matrixData) {\r\n mesh.thinInstanceSetBuffer(\"matrix\", new Float32Array(thinInstances.matrixData), 16, false);\r\n mesh._thinInstanceDataStorage.matrixBufferSize = thinInstances.matrixBufferSize;\r\n mesh._thinInstanceDataStorage.instancesCount = thinInstances.instancesCount;\r\n }\r\n else {\r\n mesh._thinInstanceDataStorage.matrixBufferSize = thinInstances.matrixBufferSize;\r\n }\r\n if (parsedMesh.thinInstances.userThinInstance) {\r\n var userThinInstance = parsedMesh.thinInstances.userThinInstance;\r\n for (var kind in userThinInstance.data) {\r\n mesh.thinInstanceSetBuffer(kind, new Float32Array(userThinInstance.data[kind]), userThinInstance.strides[kind], false);\r\n mesh._userThinInstanceBuffersStorage.sizes[kind] = userThinInstance.sizes[kind];\r\n }\r\n }\r\n }\r\n return mesh;\r\n };\r\n /**\r\n * Creates a ribbon mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @see https://doc.babylonjs.com/how_to/parametric_shapes\r\n * @param name defines the name of the mesh to create\r\n * @param pathArray is a required array of paths, what are each an array of successive Vector3. The pathArray parameter depicts the ribbon geometry.\r\n * @param closeArray creates a seam between the first and the last paths of the path array (default is false)\r\n * @param closePath creates a seam between the first and the last points of each path of the path array\r\n * @param offset is taken in account only if the `pathArray` is containing a single path\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @param instance defines an instance of an existing Ribbon object to be updated with the passed `pathArray` parameter (https://doc.babylonjs.com/how_to/How_to_dynamically_morph_a_mesh#ribbon)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateRibbon = function (name, pathArray, closeArray, closePath, offset, scene, updatable, sideOrientation, instance) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a plane polygonal mesh. By default, this is a disc. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param radius sets the radius size (float) of the polygon (default 0.5)\r\n * @param tessellation sets the number of polygon sides (positive integer, default 64). So a tessellation valued to 3 will build a triangle, to 4 a square, etc\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateDisc = function (name, radius, tessellation, scene, updatable, sideOrientation) {\r\n if (scene === void 0) { scene = null; }\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a box mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param size sets the size (float) of each box side (default 1)\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateBox = function (name, size, scene, updatable, sideOrientation) {\r\n if (scene === void 0) { scene = null; }\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a sphere mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param segments sets the sphere number of horizontal stripes (positive integer, default 32)\r\n * @param diameter sets the diameter size (float) of the sphere (default 1)\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateSphere = function (name, segments, diameter, scene, updatable, sideOrientation) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a hemisphere mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param segments sets the sphere number of horizontal stripes (positive integer, default 32)\r\n * @param diameter sets the diameter size (float) of the sphere (default 1)\r\n * @param scene defines the hosting scene\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateHemisphere = function (name, segments, diameter, scene) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a cylinder or a cone mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param height sets the height size (float) of the cylinder/cone (float, default 2)\r\n * @param diameterTop set the top cap diameter (floats, default 1)\r\n * @param diameterBottom set the bottom cap diameter (floats, default 1). This value can't be zero\r\n * @param tessellation sets the number of cylinder sides (positive integer, default 24). Set it to 3 to get a prism for instance\r\n * @param subdivisions sets the number of rings along the cylinder height (positive integer, default 1)\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateCylinder = function (name, height, diameterTop, diameterBottom, tessellation, subdivisions, scene, updatable, sideOrientation) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n // Torus (Code from SharpDX.org)\r\n /**\r\n * Creates a torus mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param diameter sets the diameter size (float) of the torus (default 1)\r\n * @param thickness sets the diameter size of the tube of the torus (float, default 0.5)\r\n * @param tessellation sets the number of torus sides (postive integer, default 16)\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateTorus = function (name, diameter, thickness, tessellation, scene, updatable, sideOrientation) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a torus knot mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param radius sets the global radius size (float) of the torus knot (default 2)\r\n * @param tube sets the diameter size of the tube of the torus (float, default 0.5)\r\n * @param radialSegments sets the number of sides on each tube segments (positive integer, default 32)\r\n * @param tubularSegments sets the number of tubes to decompose the knot into (positive integer, default 32)\r\n * @param p the number of windings on X axis (positive integers, default 2)\r\n * @param q the number of windings on Y axis (positive integers, default 3)\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateTorusKnot = function (name, radius, tube, radialSegments, tubularSegments, p, q, scene, updatable, sideOrientation) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a line mesh. Please consider using the same method from the MeshBuilder class instead.\r\n * @param name defines the name of the mesh to create\r\n * @param points is an array successive Vector3\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param instance is an instance of an existing LineMesh object to be updated with the passed `points` parameter (https://doc.babylonjs.com/how_to/How_to_dynamically_morph_a_mesh#lines-and-dashedlines).\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateLines = function (name, points, scene, updatable, instance) {\r\n if (scene === void 0) { scene = null; }\r\n if (updatable === void 0) { updatable = false; }\r\n if (instance === void 0) { instance = null; }\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a dashed line mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param points is an array successive Vector3\r\n * @param dashSize is the size of the dashes relatively the dash number (positive float, default 3)\r\n * @param gapSize is the size of the gap between two successive dashes relatively the dash number (positive float, default 1)\r\n * @param dashNb is the intended total number of dashes (positive integer, default 200)\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param instance is an instance of an existing LineMesh object to be updated with the passed `points` parameter (https://doc.babylonjs.com/how_to/How_to_dynamically_morph_a_mesh#lines-and-dashedlines)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateDashedLines = function (name, points, dashSize, gapSize, dashNb, scene, updatable, instance) {\r\n if (scene === void 0) { scene = null; }\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a polygon mesh.Please consider using the same method from the MeshBuilder class instead\r\n * The polygon's shape will depend on the input parameters and is constructed parallel to a ground mesh.\r\n * The parameter `shape` is a required array of successive Vector3 representing the corners of the polygon in th XoZ plane, that is y = 0 for all vectors.\r\n * You can set the mesh side orientation with the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created.\r\n * Remember you can only change the shape positions, not their number when updating a polygon.\r\n * @see https://doc.babylonjs.com/how_to/parametric_shapes#non-regular-polygon\r\n * @param name defines the name of the mesh to create\r\n * @param shape is a required array of successive Vector3 representing the corners of the polygon in th XoZ plane, that is y = 0 for all vectors\r\n * @param scene defines the hosting scene\r\n * @param holes is a required array of arrays of successive Vector3 used to defines holes in the polygon\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @param earcutInjection can be used to inject your own earcut reference\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreatePolygon = function (name, shape, scene, holes, updatable, sideOrientation, earcutInjection) {\r\n if (earcutInjection === void 0) { earcutInjection = earcut; }\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates an extruded polygon mesh, with depth in the Y direction. Please consider using the same method from the MeshBuilder class instead.\r\n * @see https://doc.babylonjs.com/how_to/parametric_shapes#extruded-non-regular-polygon\r\n * @param name defines the name of the mesh to create\r\n * @param shape is a required array of successive Vector3 representing the corners of the polygon in th XoZ plane, that is y = 0 for all vectors\r\n * @param depth defines the height of extrusion\r\n * @param scene defines the hosting scene\r\n * @param holes is a required array of arrays of successive Vector3 used to defines holes in the polygon\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @param earcutInjection can be used to inject your own earcut reference\r\n * @returns a new Mesh\r\n */\r\n Mesh.ExtrudePolygon = function (name, shape, depth, scene, holes, updatable, sideOrientation, earcutInjection) {\r\n if (earcutInjection === void 0) { earcutInjection = earcut; }\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates an extruded shape mesh.\r\n * The extrusion is a parametric shape. It has no predefined shape. Its final shape will depend on the input parameters. Please consider using the same method from the MeshBuilder class instead\r\n * @see https://doc.babylonjs.com/how_to/parametric_shapes\r\n * @see https://doc.babylonjs.com/how_to/parametric_shapes#extruded-shapes\r\n * @param name defines the name of the mesh to create\r\n * @param shape is a required array of successive Vector3. This array depicts the shape to be extruded in its local space : the shape must be designed in the xOy plane and will be extruded along the Z axis\r\n * @param path is a required array of successive Vector3. This is the axis curve the shape is extruded along\r\n * @param scale is the value to scale the shape\r\n * @param rotation is the angle value to rotate the shape each step (each path point), from the former step (so rotation added each step) along the curve\r\n * @param cap sets the way the extruded shape is capped. Possible values : Mesh.NO_CAP (default), Mesh.CAP_START, Mesh.CAP_END, Mesh.CAP_ALL\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @param instance is an instance of an existing ExtrudedShape object to be updated with the passed `shape`, `path`, `scale` or `rotation` parameters (https://doc.babylonjs.com/how_to/How_to_dynamically_morph_a_mesh#extruded-shape)\r\n * @returns a new Mesh\r\n */\r\n Mesh.ExtrudeShape = function (name, shape, path, scale, rotation, cap, scene, updatable, sideOrientation, instance) {\r\n if (scene === void 0) { scene = null; }\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates an custom extruded shape mesh.\r\n * The custom extrusion is a parametric shape.\r\n * It has no predefined shape. Its final shape will depend on the input parameters.\r\n * Please consider using the same method from the MeshBuilder class instead\r\n * @see https://doc.babylonjs.com/how_to/parametric_shapes#extruded-shapes\r\n * @param name defines the name of the mesh to create\r\n * @param shape is a required array of successive Vector3. This array depicts the shape to be extruded in its local space : the shape must be designed in the xOy plane and will be extruded along the Z axis\r\n * @param path is a required array of successive Vector3. This is the axis curve the shape is extruded along\r\n * @param scaleFunction is a custom Javascript function called on each path point\r\n * @param rotationFunction is a custom Javascript function called on each path point\r\n * @param ribbonCloseArray forces the extrusion underlying ribbon to close all the paths in its `pathArray`\r\n * @param ribbonClosePath forces the extrusion underlying ribbon to close its `pathArray`\r\n * @param cap sets the way the extruded shape is capped. Possible values : Mesh.NO_CAP (default), Mesh.CAP_START, Mesh.CAP_END, Mesh.CAP_ALL\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @param instance is an instance of an existing ExtrudedShape object to be updated with the passed `shape`, `path`, `scale` or `rotation` parameters (https://doc.babylonjs.com/how_to/how_to_dynamically_morph_a_mesh#extruded-shape)\r\n * @returns a new Mesh\r\n */\r\n Mesh.ExtrudeShapeCustom = function (name, shape, path, scaleFunction, rotationFunction, ribbonCloseArray, ribbonClosePath, cap, scene, updatable, sideOrientation, instance) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates lathe mesh.\r\n * The lathe is a shape with a symetry axis : a 2D model shape is rotated around this axis to design the lathe.\r\n * Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param shape is a required array of successive Vector3. This array depicts the shape to be rotated in its local space : the shape must be designed in the xOy plane and will be rotated around the Y axis. It's usually a 2D shape, so the Vector3 z coordinates are often set to zero\r\n * @param radius is the radius value of the lathe\r\n * @param tessellation is the side number of the lathe.\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateLathe = function (name, shape, radius, tessellation, scene, updatable, sideOrientation) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a plane mesh. Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param size sets the size (float) of both sides of the plane at once (default 1)\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreatePlane = function (name, size, scene, updatable, sideOrientation) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a ground mesh.\r\n * Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param width set the width of the ground\r\n * @param height set the height of the ground\r\n * @param subdivisions sets the number of subdivisions per side\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateGround = function (name, width, height, subdivisions, scene, updatable) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a tiled ground mesh.\r\n * Please consider using the same method from the MeshBuilder class instead\r\n * @param name defines the name of the mesh to create\r\n * @param xmin set the ground minimum X coordinate\r\n * @param zmin set the ground minimum Y coordinate\r\n * @param xmax set the ground maximum X coordinate\r\n * @param zmax set the ground maximum Z coordinate\r\n * @param subdivisions is an object `{w: positive integer, h: positive integer}` (default `{w: 6, h: 6}`). `w` and `h` are the numbers of subdivisions on the ground width and height. Each subdivision is called a tile\r\n * @param precision is an object `{w: positive integer, h: positive integer}` (default `{w: 2, h: 2}`). `w` and `h` are the numbers of subdivisions on the ground width and height of each tile\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateTiledGround = function (name, xmin, zmin, xmax, zmax, subdivisions, precision, scene, updatable) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a ground mesh from a height map.\r\n * Please consider using the same method from the MeshBuilder class instead\r\n * @see https://doc.babylonjs.com/babylon101/height_map\r\n * @param name defines the name of the mesh to create\r\n * @param url sets the URL of the height map image resource\r\n * @param width set the ground width size\r\n * @param height set the ground height size\r\n * @param subdivisions sets the number of subdivision per side\r\n * @param minHeight is the minimum altitude on the ground\r\n * @param maxHeight is the maximum altitude on the ground\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param onReady is a callback function that will be called once the mesh is built (the height map download can last some time)\r\n * @param alphaFilter will filter any data where the alpha channel is below this value, defaults 0 (all data visible)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateGroundFromHeightMap = function (name, url, width, height, subdivisions, minHeight, maxHeight, scene, updatable, onReady, alphaFilter) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a tube mesh.\r\n * The tube is a parametric shape.\r\n * It has no predefined shape. Its final shape will depend on the input parameters.\r\n * Please consider using the same method from the MeshBuilder class instead\r\n * @see https://doc.babylonjs.com/how_to/parametric_shapes\r\n * @param name defines the name of the mesh to create\r\n * @param path is a required array of successive Vector3. It is the curve used as the axis of the tube\r\n * @param radius sets the tube radius size\r\n * @param tessellation is the number of sides on the tubular surface\r\n * @param radiusFunction is a custom function. If it is not null, it overwrittes the parameter `radius`. This function is called on each point of the tube path and is passed the index `i` of the i-th point and the distance of this point from the first point of the path\r\n * @param cap sets the way the extruded shape is capped. Possible values : Mesh.NO_CAP (default), Mesh.CAP_START, Mesh.CAP_END, Mesh.CAP_ALL\r\n * @param scene defines the hosting scene\r\n * @param updatable defines if the mesh must be flagged as updatable\r\n * @param sideOrientation defines the mesh side orientation (https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation)\r\n * @param instance is an instance of an existing Tube object to be updated with the passed `pathArray` parameter (https://doc.babylonjs.com/how_to/How_to_dynamically_morph_a_mesh#tube)\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateTube = function (name, path, radius, tessellation, radiusFunction, cap, scene, updatable, sideOrientation, instance) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a polyhedron mesh.\r\n * Please consider using the same method from the MeshBuilder class instead.\r\n * * The parameter `type` (positive integer, max 14, default 0) sets the polyhedron type to build among the 15 embbeded types. Please refer to the type sheet in the tutorial to choose the wanted type\r\n * * The parameter `size` (positive float, default 1) sets the polygon size\r\n * * You can overwrite the `size` on each dimension bu using the parameters `sizeX`, `sizeY` or `sizeZ` (positive floats, default to `size` value)\r\n * * You can build other polyhedron types than the 15 embbeded ones by setting the parameter `custom` (`polyhedronObject`, default null). If you set the parameter `custom`, this overwrittes the parameter `type`\r\n * * A `polyhedronObject` is a formatted javascript object. You'll find a full file with pre-set polyhedra here : https://github.com/BabylonJS/Extensions/tree/master/Polyhedron\r\n * * You can set the color and the UV of each side of the polyhedron with the parameters `faceColors` (Color4, default `(1, 1, 1, 1)`) and faceUV (Vector4, default `(0, 0, 1, 1)`)\r\n * * To understand how to set `faceUV` or `faceColors`, please read this by considering the right number of faces of your polyhedron, instead of only 6 for the box : https://doc.babylonjs.com/how_to/createbox_per_face_textures_and_colors\r\n * * The parameter `flat` (boolean, default true). If set to false, it gives the polyhedron a single global face, so less vertices and shared normals. In this case, `faceColors` and `faceUV` are ignored\r\n * * You can also set the mesh side orientation with the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * If you create a double-sided mesh, you can choose what parts of the texture image to crop and stick respectively on the front and the back sides with the parameters `frontUVs` and `backUVs` (Vector4). Detail here : https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @param name defines the name of the mesh to create\r\n * @param options defines the options used to create the mesh\r\n * @param scene defines the hosting scene\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreatePolyhedron = function (name, options, scene) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a sphere based upon an icosahedron with 20 triangular faces which can be subdivided\r\n * * The parameter `radius` sets the radius size (float) of the icosphere (default 1)\r\n * * You can set some different icosphere dimensions, for instance to build an ellipsoid, by using the parameters `radiusX`, `radiusY` and `radiusZ` (all by default have the same value than `radius`)\r\n * * The parameter `subdivisions` sets the number of subdivisions (postive integer, default 4). The more subdivisions, the more faces on the icosphere whatever its size\r\n * * The parameter `flat` (boolean, default true) gives each side its own normals. Set it to false to get a smooth continuous light reflection on the surface\r\n * * You can also set the mesh side orientation with the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * If you create a double-sided mesh, you can choose what parts of the texture image to crop and stick respectively on the front and the back sides with the parameters `frontUVs` and `backUVs` (Vector4). Detail here : https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @param name defines the name of the mesh\r\n * @param options defines the options used to create the mesh\r\n * @param scene defines the hosting scene\r\n * @returns a new Mesh\r\n * @see https://doc.babylonjs.com/how_to/polyhedra_shapes#icosphere\r\n */\r\n Mesh.CreateIcoSphere = function (name, options, scene) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /**\r\n * Creates a decal mesh.\r\n * Please consider using the same method from the MeshBuilder class instead.\r\n * A decal is a mesh usually applied as a model onto the surface of another mesh\r\n * @param name defines the name of the mesh\r\n * @param sourceMesh defines the mesh receiving the decal\r\n * @param position sets the position of the decal in world coordinates\r\n * @param normal sets the normal of the mesh where the decal is applied onto in world coordinates\r\n * @param size sets the decal scaling\r\n * @param angle sets the angle to rotate the decal\r\n * @returns a new Mesh\r\n */\r\n Mesh.CreateDecal = function (name, sourceMesh, position, normal, size, angle) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n /** Creates a Capsule Mesh\r\n * @param name defines the name of the mesh.\r\n * @param options the constructors options used to shape the mesh.\r\n * @param scene defines the scene the mesh is scoped to.\r\n * @returns the capsule mesh\r\n * @see https://doc.babylonjs.com/how_to/capsule_shape\r\n */\r\n Mesh.CreateCapsule = function (name, options, scene) {\r\n throw _DevTools.WarnImport(\"MeshBuilder\");\r\n };\r\n // Skeletons\r\n /**\r\n * Prepare internal position array for software CPU skinning\r\n * @returns original positions used for CPU skinning. Useful for integrating Morphing with skeletons in same mesh\r\n */\r\n Mesh.prototype.setPositionsForCPUSkinning = function () {\r\n var internalDataInfo = this._internalMeshDataInfo;\r\n if (!internalDataInfo._sourcePositions) {\r\n var source = this.getVerticesData(VertexBuffer.PositionKind);\r\n if (!source) {\r\n return internalDataInfo._sourcePositions;\r\n }\r\n internalDataInfo._sourcePositions = new Float32Array(source);\r\n if (!this.isVertexBufferUpdatable(VertexBuffer.PositionKind)) {\r\n this.setVerticesData(VertexBuffer.PositionKind, source, true);\r\n }\r\n }\r\n return internalDataInfo._sourcePositions;\r\n };\r\n /**\r\n * Prepare internal normal array for software CPU skinning\r\n * @returns original normals used for CPU skinning. Useful for integrating Morphing with skeletons in same mesh.\r\n */\r\n Mesh.prototype.setNormalsForCPUSkinning = function () {\r\n var internalDataInfo = this._internalMeshDataInfo;\r\n if (!internalDataInfo._sourceNormals) {\r\n var source = this.getVerticesData(VertexBuffer.NormalKind);\r\n if (!source) {\r\n return internalDataInfo._sourceNormals;\r\n }\r\n internalDataInfo._sourceNormals = new Float32Array(source);\r\n if (!this.isVertexBufferUpdatable(VertexBuffer.NormalKind)) {\r\n this.setVerticesData(VertexBuffer.NormalKind, source, true);\r\n }\r\n }\r\n return internalDataInfo._sourceNormals;\r\n };\r\n /**\r\n * Updates the vertex buffer by applying transformation from the bones\r\n * @param skeleton defines the skeleton to apply to current mesh\r\n * @returns the current mesh\r\n */\r\n Mesh.prototype.applySkeleton = function (skeleton) {\r\n if (!this.geometry) {\r\n return this;\r\n }\r\n if (this.geometry._softwareSkinningFrameId == this.getScene().getFrameId()) {\r\n return this;\r\n }\r\n this.geometry._softwareSkinningFrameId = this.getScene().getFrameId();\r\n if (!this.isVerticesDataPresent(VertexBuffer.PositionKind)) {\r\n return this;\r\n }\r\n if (!this.isVerticesDataPresent(VertexBuffer.MatricesIndicesKind)) {\r\n return this;\r\n }\r\n if (!this.isVerticesDataPresent(VertexBuffer.MatricesWeightsKind)) {\r\n return this;\r\n }\r\n var hasNormals = this.isVerticesDataPresent(VertexBuffer.NormalKind);\r\n var internalDataInfo = this._internalMeshDataInfo;\r\n if (!internalDataInfo._sourcePositions) {\r\n var submeshes = this.subMeshes.slice();\r\n this.setPositionsForCPUSkinning();\r\n this.subMeshes = submeshes;\r\n }\r\n if (hasNormals && !internalDataInfo._sourceNormals) {\r\n this.setNormalsForCPUSkinning();\r\n }\r\n // positionsData checks for not being Float32Array will only pass at most once\r\n var positionsData = this.getVerticesData(VertexBuffer.PositionKind);\r\n if (!positionsData) {\r\n return this;\r\n }\r\n if (!(positionsData instanceof Float32Array)) {\r\n positionsData = new Float32Array(positionsData);\r\n }\r\n // normalsData checks for not being Float32Array will only pass at most once\r\n var normalsData = this.getVerticesData(VertexBuffer.NormalKind);\r\n if (hasNormals) {\r\n if (!normalsData) {\r\n return this;\r\n }\r\n if (!(normalsData instanceof Float32Array)) {\r\n normalsData = new Float32Array(normalsData);\r\n }\r\n }\r\n var matricesIndicesData = this.getVerticesData(VertexBuffer.MatricesIndicesKind);\r\n var matricesWeightsData = this.getVerticesData(VertexBuffer.MatricesWeightsKind);\r\n if (!matricesWeightsData || !matricesIndicesData) {\r\n return this;\r\n }\r\n var needExtras = this.numBoneInfluencers > 4;\r\n var matricesIndicesExtraData = needExtras ? this.getVerticesData(VertexBuffer.MatricesIndicesExtraKind) : null;\r\n var matricesWeightsExtraData = needExtras ? this.getVerticesData(VertexBuffer.MatricesWeightsExtraKind) : null;\r\n var skeletonMatrices = skeleton.getTransformMatrices(this);\r\n var tempVector3 = Vector3.Zero();\r\n var finalMatrix = new Matrix();\r\n var tempMatrix = new Matrix();\r\n var matWeightIdx = 0;\r\n var inf;\r\n for (var index = 0; index < positionsData.length; index += 3, matWeightIdx += 4) {\r\n var weight;\r\n for (inf = 0; inf < 4; inf++) {\r\n weight = matricesWeightsData[matWeightIdx + inf];\r\n if (weight > 0) {\r\n Matrix.FromFloat32ArrayToRefScaled(skeletonMatrices, Math.floor(matricesIndicesData[matWeightIdx + inf] * 16), weight, tempMatrix);\r\n finalMatrix.addToSelf(tempMatrix);\r\n }\r\n }\r\n if (needExtras) {\r\n for (inf = 0; inf < 4; inf++) {\r\n weight = matricesWeightsExtraData[matWeightIdx + inf];\r\n if (weight > 0) {\r\n Matrix.FromFloat32ArrayToRefScaled(skeletonMatrices, Math.floor(matricesIndicesExtraData[matWeightIdx + inf] * 16), weight, tempMatrix);\r\n finalMatrix.addToSelf(tempMatrix);\r\n }\r\n }\r\n }\r\n Vector3.TransformCoordinatesFromFloatsToRef(internalDataInfo._sourcePositions[index], internalDataInfo._sourcePositions[index + 1], internalDataInfo._sourcePositions[index + 2], finalMatrix, tempVector3);\r\n tempVector3.toArray(positionsData, index);\r\n if (hasNormals) {\r\n Vector3.TransformNormalFromFloatsToRef(internalDataInfo._sourceNormals[index], internalDataInfo._sourceNormals[index + 1], internalDataInfo._sourceNormals[index + 2], finalMatrix, tempVector3);\r\n tempVector3.toArray(normalsData, index);\r\n }\r\n finalMatrix.reset();\r\n }\r\n this.updateVerticesData(VertexBuffer.PositionKind, positionsData);\r\n if (hasNormals) {\r\n this.updateVerticesData(VertexBuffer.NormalKind, normalsData);\r\n }\r\n return this;\r\n };\r\n // Tools\r\n /**\r\n * Returns an object containing a min and max Vector3 which are the minimum and maximum vectors of each mesh bounding box from the passed array, in the world coordinates\r\n * @param meshes defines the list of meshes to scan\r\n * @returns an object `{min:` Vector3`, max:` Vector3`}`\r\n */\r\n Mesh.MinMax = function (meshes) {\r\n var minVector = null;\r\n var maxVector = null;\r\n meshes.forEach(function (mesh) {\r\n var boundingInfo = mesh.getBoundingInfo();\r\n var boundingBox = boundingInfo.boundingBox;\r\n if (!minVector || !maxVector) {\r\n minVector = boundingBox.minimumWorld;\r\n maxVector = boundingBox.maximumWorld;\r\n }\r\n else {\r\n minVector.minimizeInPlace(boundingBox.minimumWorld);\r\n maxVector.maximizeInPlace(boundingBox.maximumWorld);\r\n }\r\n });\r\n if (!minVector || !maxVector) {\r\n return {\r\n min: Vector3.Zero(),\r\n max: Vector3.Zero()\r\n };\r\n }\r\n return {\r\n min: minVector,\r\n max: maxVector\r\n };\r\n };\r\n /**\r\n * Returns the center of the `{min:` Vector3`, max:` Vector3`}` or the center of MinMax vector3 computed from a mesh array\r\n * @param meshesOrMinMaxVector could be an array of meshes or a `{min:` Vector3`, max:` Vector3`}` object\r\n * @returns a vector3\r\n */\r\n Mesh.Center = function (meshesOrMinMaxVector) {\r\n var minMaxVector = (meshesOrMinMaxVector instanceof Array) ? Mesh.MinMax(meshesOrMinMaxVector) : meshesOrMinMaxVector;\r\n return Vector3.Center(minMaxVector.min, minMaxVector.max);\r\n };\r\n /**\r\n * Merge the array of meshes into a single mesh for performance reasons.\r\n * @param meshes defines he vertices source. They should all be of the same material. Entries can empty\r\n * @param disposeSource when true (default), dispose of the vertices from the source meshes\r\n * @param allow32BitsIndices when the sum of the vertices > 64k, this must be set to true\r\n * @param meshSubclass when set, vertices inserted into this Mesh. Meshes can then be merged into a Mesh sub-class.\r\n * @param subdivideWithSubMeshes when true (false default), subdivide mesh to his subMesh array with meshes source.\r\n * @param multiMultiMaterials when true (false default), subdivide mesh and accept multiple multi materials, ignores subdivideWithSubMeshes.\r\n * @returns a new mesh\r\n */\r\n Mesh.MergeMeshes = function (meshes, disposeSource, allow32BitsIndices, meshSubclass, subdivideWithSubMeshes, multiMultiMaterials) {\r\n if (disposeSource === void 0) { disposeSource = true; }\r\n var index;\r\n if (!allow32BitsIndices) {\r\n var totalVertices = 0;\r\n // Counting vertices\r\n for (index = 0; index < meshes.length; index++) {\r\n if (meshes[index]) {\r\n totalVertices += meshes[index].getTotalVertices();\r\n if (totalVertices >= 65536) {\r\n Logger.Warn(\"Cannot merge meshes because resulting mesh will have more than 65536 vertices. Please use allow32BitsIndices = true to use 32 bits indices\");\r\n return null;\r\n }\r\n }\r\n }\r\n }\r\n if (multiMultiMaterials) {\r\n var newMultiMaterial = null;\r\n var subIndex;\r\n var matIndex;\r\n subdivideWithSubMeshes = false;\r\n }\r\n var materialArray = new Array();\r\n var materialIndexArray = new Array();\r\n // Merge\r\n var vertexData = null;\r\n var otherVertexData;\r\n var indiceArray = new Array();\r\n var source = null;\r\n for (index = 0; index < meshes.length; index++) {\r\n if (meshes[index]) {\r\n var mesh = meshes[index];\r\n if (mesh.isAnInstance) {\r\n Logger.Warn(\"Cannot merge instance meshes.\");\r\n return null;\r\n }\r\n var wm = mesh.computeWorldMatrix(true);\r\n otherVertexData = VertexData.ExtractFromMesh(mesh, true, true);\r\n otherVertexData.transform(wm);\r\n if (vertexData) {\r\n vertexData.merge(otherVertexData, allow32BitsIndices);\r\n }\r\n else {\r\n vertexData = otherVertexData;\r\n source = mesh;\r\n }\r\n if (subdivideWithSubMeshes) {\r\n indiceArray.push(mesh.getTotalIndices());\r\n }\r\n if (multiMultiMaterials) {\r\n if (mesh.material) {\r\n var material = mesh.material;\r\n if (material instanceof MultiMaterial) {\r\n for (matIndex = 0; matIndex < material.subMaterials.length; matIndex++) {\r\n if (materialArray.indexOf(material.subMaterials[matIndex]) < 0) {\r\n materialArray.push(material.subMaterials[matIndex]);\r\n }\r\n }\r\n for (subIndex = 0; subIndex < mesh.subMeshes.length; subIndex++) {\r\n materialIndexArray.push(materialArray.indexOf(material.subMaterials[mesh.subMeshes[subIndex].materialIndex]));\r\n indiceArray.push(mesh.subMeshes[subIndex].indexCount);\r\n }\r\n }\r\n else {\r\n if (materialArray.indexOf(material) < 0) {\r\n materialArray.push(material);\r\n }\r\n for (subIndex = 0; subIndex < mesh.subMeshes.length; subIndex++) {\r\n materialIndexArray.push(materialArray.indexOf(material));\r\n indiceArray.push(mesh.subMeshes[subIndex].indexCount);\r\n }\r\n }\r\n }\r\n else {\r\n for (subIndex = 0; subIndex < mesh.subMeshes.length; subIndex++) {\r\n materialIndexArray.push(0);\r\n indiceArray.push(mesh.subMeshes[subIndex].indexCount);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n source = source;\r\n if (!meshSubclass) {\r\n meshSubclass = new Mesh(source.name + \"_merged\", source.getScene());\r\n }\r\n vertexData.applyToMesh(meshSubclass);\r\n // Setting properties\r\n meshSubclass.checkCollisions = source.checkCollisions;\r\n meshSubclass.overrideMaterialSideOrientation = source.overrideMaterialSideOrientation;\r\n // Cleaning\r\n if (disposeSource) {\r\n for (index = 0; index < meshes.length; index++) {\r\n if (meshes[index]) {\r\n meshes[index].dispose();\r\n }\r\n }\r\n }\r\n // Subdivide\r\n if (subdivideWithSubMeshes || multiMultiMaterials) {\r\n //-- removal of global submesh\r\n meshSubclass.releaseSubMeshes();\r\n index = 0;\r\n var offset = 0;\r\n //-- apply subdivision according to index table\r\n while (index < indiceArray.length) {\r\n SubMesh.CreateFromIndices(0, offset, indiceArray[index], meshSubclass);\r\n offset += indiceArray[index];\r\n index++;\r\n }\r\n }\r\n if (multiMultiMaterials) {\r\n newMultiMaterial = new MultiMaterial(source.name + \"_merged\", source.getScene());\r\n newMultiMaterial.subMaterials = materialArray;\r\n for (subIndex = 0; subIndex < meshSubclass.subMeshes.length; subIndex++) {\r\n meshSubclass.subMeshes[subIndex].materialIndex = materialIndexArray[subIndex];\r\n }\r\n meshSubclass.material = newMultiMaterial;\r\n }\r\n else {\r\n meshSubclass.material = source.material;\r\n }\r\n return meshSubclass;\r\n };\r\n /** @hidden */\r\n Mesh.prototype.addInstance = function (instance) {\r\n instance._indexInSourceMeshInstanceArray = this.instances.length;\r\n this.instances.push(instance);\r\n };\r\n /** @hidden */\r\n Mesh.prototype.removeInstance = function (instance) {\r\n // Remove from mesh\r\n var index = instance._indexInSourceMeshInstanceArray;\r\n if (index != -1) {\r\n if (index !== this.instances.length - 1) {\r\n var last = this.instances[this.instances.length - 1];\r\n this.instances[index] = last;\r\n last._indexInSourceMeshInstanceArray = index;\r\n }\r\n instance._indexInSourceMeshInstanceArray = -1;\r\n this.instances.pop();\r\n }\r\n };\r\n // Consts\r\n /**\r\n * Mesh side orientation : usually the external or front surface\r\n */\r\n Mesh.FRONTSIDE = VertexData.FRONTSIDE;\r\n /**\r\n * Mesh side orientation : usually the internal or back surface\r\n */\r\n Mesh.BACKSIDE = VertexData.BACKSIDE;\r\n /**\r\n * Mesh side orientation : both internal and external or front and back surfaces\r\n */\r\n Mesh.DOUBLESIDE = VertexData.DOUBLESIDE;\r\n /**\r\n * Mesh side orientation : by default, `FRONTSIDE`\r\n */\r\n Mesh.DEFAULTSIDE = VertexData.DEFAULTSIDE;\r\n /**\r\n * Mesh cap setting : no cap\r\n */\r\n Mesh.NO_CAP = 0;\r\n /**\r\n * Mesh cap setting : one cap at the beginning of the mesh\r\n */\r\n Mesh.CAP_START = 1;\r\n /**\r\n * Mesh cap setting : one cap at the end of the mesh\r\n */\r\n Mesh.CAP_END = 2;\r\n /**\r\n * Mesh cap setting : two caps, one at the beginning and one at the end of the mesh\r\n */\r\n Mesh.CAP_ALL = 3;\r\n /**\r\n * Mesh pattern setting : no flip or rotate\r\n */\r\n Mesh.NO_FLIP = 0;\r\n /**\r\n * Mesh pattern setting : flip (reflect in y axis) alternate tiles on each row or column\r\n */\r\n Mesh.FLIP_TILE = 1;\r\n /**\r\n * Mesh pattern setting : rotate (180degs) alternate tiles on each row or column\r\n */\r\n Mesh.ROTATE_TILE = 2;\r\n /**\r\n * Mesh pattern setting : flip (reflect in y axis) all tiles on alternate rows\r\n */\r\n Mesh.FLIP_ROW = 3;\r\n /**\r\n * Mesh pattern setting : rotate (180degs) all tiles on alternate rows\r\n */\r\n Mesh.ROTATE_ROW = 4;\r\n /**\r\n * Mesh pattern setting : flip and rotate alternate tiles on each row or column\r\n */\r\n Mesh.FLIP_N_ROTATE_TILE = 5;\r\n /**\r\n * Mesh pattern setting : rotate pattern and rotate\r\n */\r\n Mesh.FLIP_N_ROTATE_ROW = 6;\r\n /**\r\n * Mesh tile positioning : part tiles same on left/right or top/bottom\r\n */\r\n Mesh.CENTER = 0;\r\n /**\r\n * Mesh tile positioning : part tiles on left\r\n */\r\n Mesh.LEFT = 1;\r\n /**\r\n * Mesh tile positioning : part tiles on right\r\n */\r\n Mesh.RIGHT = 2;\r\n /**\r\n * Mesh tile positioning : part tiles on top\r\n */\r\n Mesh.TOP = 3;\r\n /**\r\n * Mesh tile positioning : part tiles on bottom\r\n */\r\n Mesh.BOTTOM = 4;\r\n // Statics\r\n /** @hidden */\r\n Mesh._GroundMeshParser = function (parsedMesh, scene) {\r\n throw _DevTools.WarnImport(\"GroundMesh\");\r\n };\r\n return Mesh;\r\n}(AbstractMesh));\r\nexport { Mesh };\r\n_TypeStore.RegisteredTypes[\"BABYLON.Mesh\"] = Mesh;\r\n//# sourceMappingURL=mesh.js.map","import { Vector3, Vector4 } from \"../Maths/math.vector\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { _DevTools } from '../Misc/devTools';\r\nimport { Color4 } from '../Maths/math.color';\r\nimport { Logger } from '../Misc/logger';\r\n/**\r\n * This class contains the various kinds of data on every vertex of a mesh used in determining its shape and appearance\r\n */\r\nvar VertexData = /** @class */ (function () {\r\n function VertexData() {\r\n }\r\n /**\r\n * Uses the passed data array to set the set the values for the specified kind of data\r\n * @param data a linear array of floating numbers\r\n * @param kind the type of data that is being set, eg positions, colors etc\r\n */\r\n VertexData.prototype.set = function (data, kind) {\r\n if (!data.length) {\r\n Logger.Warn(\"Setting vertex data kind '\" + kind + \"' with an empty array\");\r\n }\r\n switch (kind) {\r\n case VertexBuffer.PositionKind:\r\n this.positions = data;\r\n break;\r\n case VertexBuffer.NormalKind:\r\n this.normals = data;\r\n break;\r\n case VertexBuffer.TangentKind:\r\n this.tangents = data;\r\n break;\r\n case VertexBuffer.UVKind:\r\n this.uvs = data;\r\n break;\r\n case VertexBuffer.UV2Kind:\r\n this.uvs2 = data;\r\n break;\r\n case VertexBuffer.UV3Kind:\r\n this.uvs3 = data;\r\n break;\r\n case VertexBuffer.UV4Kind:\r\n this.uvs4 = data;\r\n break;\r\n case VertexBuffer.UV5Kind:\r\n this.uvs5 = data;\r\n break;\r\n case VertexBuffer.UV6Kind:\r\n this.uvs6 = data;\r\n break;\r\n case VertexBuffer.ColorKind:\r\n this.colors = data;\r\n break;\r\n case VertexBuffer.MatricesIndicesKind:\r\n this.matricesIndices = data;\r\n break;\r\n case VertexBuffer.MatricesWeightsKind:\r\n this.matricesWeights = data;\r\n break;\r\n case VertexBuffer.MatricesIndicesExtraKind:\r\n this.matricesIndicesExtra = data;\r\n break;\r\n case VertexBuffer.MatricesWeightsExtraKind:\r\n this.matricesWeightsExtra = data;\r\n break;\r\n }\r\n };\r\n /**\r\n * Associates the vertexData to the passed Mesh.\r\n * Sets it as updatable or not (default `false`)\r\n * @param mesh the mesh the vertexData is applied to\r\n * @param updatable when used and having the value true allows new data to update the vertexData\r\n * @returns the VertexData\r\n */\r\n VertexData.prototype.applyToMesh = function (mesh, updatable) {\r\n this._applyTo(mesh, updatable);\r\n return this;\r\n };\r\n /**\r\n * Associates the vertexData to the passed Geometry.\r\n * Sets it as updatable or not (default `false`)\r\n * @param geometry the geometry the vertexData is applied to\r\n * @param updatable when used and having the value true allows new data to update the vertexData\r\n * @returns VertexData\r\n */\r\n VertexData.prototype.applyToGeometry = function (geometry, updatable) {\r\n this._applyTo(geometry, updatable);\r\n return this;\r\n };\r\n /**\r\n * Updates the associated mesh\r\n * @param mesh the mesh to be updated\r\n * @param updateExtends when true the mesh BoundingInfo will be renewed when and if position kind is updated, optional with default false\r\n * @param makeItUnique when true, and when and if position kind is updated, a new global geometry will be created from these positions and set to the mesh, optional with default false\r\n * @returns VertexData\r\n */\r\n VertexData.prototype.updateMesh = function (mesh) {\r\n this._update(mesh);\r\n return this;\r\n };\r\n /**\r\n * Updates the associated geometry\r\n * @param geometry the geometry to be updated\r\n * @param updateExtends when true BoundingInfo will be renewed when and if position kind is updated, optional with default false\r\n * @param makeItUnique when true, and when and if position kind is updated, a new global geometry will be created from these positions and set to the mesh, optional with default false\r\n * @returns VertexData.\r\n */\r\n VertexData.prototype.updateGeometry = function (geometry) {\r\n this._update(geometry);\r\n return this;\r\n };\r\n VertexData.prototype._applyTo = function (meshOrGeometry, updatable) {\r\n if (updatable === void 0) { updatable = false; }\r\n if (this.positions) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.PositionKind, this.positions, updatable);\r\n }\r\n if (this.normals) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.NormalKind, this.normals, updatable);\r\n }\r\n if (this.tangents) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.TangentKind, this.tangents, updatable);\r\n }\r\n if (this.uvs) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.UVKind, this.uvs, updatable);\r\n }\r\n if (this.uvs2) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.UV2Kind, this.uvs2, updatable);\r\n }\r\n if (this.uvs3) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.UV3Kind, this.uvs3, updatable);\r\n }\r\n if (this.uvs4) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.UV4Kind, this.uvs4, updatable);\r\n }\r\n if (this.uvs5) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.UV5Kind, this.uvs5, updatable);\r\n }\r\n if (this.uvs6) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.UV6Kind, this.uvs6, updatable);\r\n }\r\n if (this.colors) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.ColorKind, this.colors, updatable);\r\n }\r\n if (this.matricesIndices) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.MatricesIndicesKind, this.matricesIndices, updatable);\r\n }\r\n if (this.matricesWeights) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.MatricesWeightsKind, this.matricesWeights, updatable);\r\n }\r\n if (this.matricesIndicesExtra) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.MatricesIndicesExtraKind, this.matricesIndicesExtra, updatable);\r\n }\r\n if (this.matricesWeightsExtra) {\r\n meshOrGeometry.setVerticesData(VertexBuffer.MatricesWeightsExtraKind, this.matricesWeightsExtra, updatable);\r\n }\r\n if (this.indices) {\r\n meshOrGeometry.setIndices(this.indices, null, updatable);\r\n }\r\n else {\r\n meshOrGeometry.setIndices([], null);\r\n }\r\n return this;\r\n };\r\n VertexData.prototype._update = function (meshOrGeometry, updateExtends, makeItUnique) {\r\n if (this.positions) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.PositionKind, this.positions, updateExtends, makeItUnique);\r\n }\r\n if (this.normals) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.NormalKind, this.normals, updateExtends, makeItUnique);\r\n }\r\n if (this.tangents) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.TangentKind, this.tangents, updateExtends, makeItUnique);\r\n }\r\n if (this.uvs) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.UVKind, this.uvs, updateExtends, makeItUnique);\r\n }\r\n if (this.uvs2) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.UV2Kind, this.uvs2, updateExtends, makeItUnique);\r\n }\r\n if (this.uvs3) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.UV3Kind, this.uvs3, updateExtends, makeItUnique);\r\n }\r\n if (this.uvs4) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.UV4Kind, this.uvs4, updateExtends, makeItUnique);\r\n }\r\n if (this.uvs5) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.UV5Kind, this.uvs5, updateExtends, makeItUnique);\r\n }\r\n if (this.uvs6) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.UV6Kind, this.uvs6, updateExtends, makeItUnique);\r\n }\r\n if (this.colors) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.ColorKind, this.colors, updateExtends, makeItUnique);\r\n }\r\n if (this.matricesIndices) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.MatricesIndicesKind, this.matricesIndices, updateExtends, makeItUnique);\r\n }\r\n if (this.matricesWeights) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.MatricesWeightsKind, this.matricesWeights, updateExtends, makeItUnique);\r\n }\r\n if (this.matricesIndicesExtra) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.MatricesIndicesExtraKind, this.matricesIndicesExtra, updateExtends, makeItUnique);\r\n }\r\n if (this.matricesWeightsExtra) {\r\n meshOrGeometry.updateVerticesData(VertexBuffer.MatricesWeightsExtraKind, this.matricesWeightsExtra, updateExtends, makeItUnique);\r\n }\r\n if (this.indices) {\r\n meshOrGeometry.setIndices(this.indices, null);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Transforms each position and each normal of the vertexData according to the passed Matrix\r\n * @param matrix the transforming matrix\r\n * @returns the VertexData\r\n */\r\n VertexData.prototype.transform = function (matrix) {\r\n var flip = matrix.determinant() < 0;\r\n var transformed = Vector3.Zero();\r\n var index;\r\n if (this.positions) {\r\n var position = Vector3.Zero();\r\n for (index = 0; index < this.positions.length; index += 3) {\r\n Vector3.FromArrayToRef(this.positions, index, position);\r\n Vector3.TransformCoordinatesToRef(position, matrix, transformed);\r\n this.positions[index] = transformed.x;\r\n this.positions[index + 1] = transformed.y;\r\n this.positions[index + 2] = transformed.z;\r\n }\r\n }\r\n if (this.normals) {\r\n var normal = Vector3.Zero();\r\n for (index = 0; index < this.normals.length; index += 3) {\r\n Vector3.FromArrayToRef(this.normals, index, normal);\r\n Vector3.TransformNormalToRef(normal, matrix, transformed);\r\n this.normals[index] = transformed.x;\r\n this.normals[index + 1] = transformed.y;\r\n this.normals[index + 2] = transformed.z;\r\n }\r\n }\r\n if (this.tangents) {\r\n var tangent = Vector4.Zero();\r\n var tangentTransformed = Vector4.Zero();\r\n for (index = 0; index < this.tangents.length; index += 4) {\r\n Vector4.FromArrayToRef(this.tangents, index, tangent);\r\n Vector4.TransformNormalToRef(tangent, matrix, tangentTransformed);\r\n this.tangents[index] = tangentTransformed.x;\r\n this.tangents[index + 1] = tangentTransformed.y;\r\n this.tangents[index + 2] = tangentTransformed.z;\r\n this.tangents[index + 3] = tangentTransformed.w;\r\n }\r\n }\r\n if (flip && this.indices) {\r\n for (index = 0; index < this.indices.length; index += 3) {\r\n var tmp = this.indices[index + 1];\r\n this.indices[index + 1] = this.indices[index + 2];\r\n this.indices[index + 2] = tmp;\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Merges the passed VertexData into the current one\r\n * @param other the VertexData to be merged into the current one\r\n * @param use32BitsIndices defines a boolean indicating if indices must be store in a 32 bits array\r\n * @returns the modified VertexData\r\n */\r\n VertexData.prototype.merge = function (other, use32BitsIndices) {\r\n if (use32BitsIndices === void 0) { use32BitsIndices = false; }\r\n this._validate();\r\n other._validate();\r\n if (!this.normals !== !other.normals ||\r\n !this.tangents !== !other.tangents ||\r\n !this.uvs !== !other.uvs ||\r\n !this.uvs2 !== !other.uvs2 ||\r\n !this.uvs3 !== !other.uvs3 ||\r\n !this.uvs4 !== !other.uvs4 ||\r\n !this.uvs5 !== !other.uvs5 ||\r\n !this.uvs6 !== !other.uvs6 ||\r\n !this.colors !== !other.colors ||\r\n !this.matricesIndices !== !other.matricesIndices ||\r\n !this.matricesWeights !== !other.matricesWeights ||\r\n !this.matricesIndicesExtra !== !other.matricesIndicesExtra ||\r\n !this.matricesWeightsExtra !== !other.matricesWeightsExtra) {\r\n throw new Error(\"Cannot merge vertex data that do not have the same set of attributes\");\r\n }\r\n if (other.indices) {\r\n if (!this.indices) {\r\n this.indices = [];\r\n }\r\n var offset = this.positions ? this.positions.length / 3 : 0;\r\n var isSrcTypedArray = this.indices.BYTES_PER_ELEMENT !== undefined;\r\n if (isSrcTypedArray) {\r\n var len = this.indices.length + other.indices.length;\r\n var temp = use32BitsIndices || this.indices instanceof Uint32Array ? new Uint32Array(len) : new Uint16Array(len);\r\n temp.set(this.indices);\r\n var decal = this.indices.length;\r\n for (var index = 0; index < other.indices.length; index++) {\r\n temp[decal + index] = other.indices[index] + offset;\r\n }\r\n this.indices = temp;\r\n }\r\n else {\r\n for (var index = 0; index < other.indices.length; index++) {\r\n this.indices.push(other.indices[index] + offset);\r\n }\r\n }\r\n }\r\n this.positions = this._mergeElement(this.positions, other.positions);\r\n this.normals = this._mergeElement(this.normals, other.normals);\r\n this.tangents = this._mergeElement(this.tangents, other.tangents);\r\n this.uvs = this._mergeElement(this.uvs, other.uvs);\r\n this.uvs2 = this._mergeElement(this.uvs2, other.uvs2);\r\n this.uvs3 = this._mergeElement(this.uvs3, other.uvs3);\r\n this.uvs4 = this._mergeElement(this.uvs4, other.uvs4);\r\n this.uvs5 = this._mergeElement(this.uvs5, other.uvs5);\r\n this.uvs6 = this._mergeElement(this.uvs6, other.uvs6);\r\n this.colors = this._mergeElement(this.colors, other.colors);\r\n this.matricesIndices = this._mergeElement(this.matricesIndices, other.matricesIndices);\r\n this.matricesWeights = this._mergeElement(this.matricesWeights, other.matricesWeights);\r\n this.matricesIndicesExtra = this._mergeElement(this.matricesIndicesExtra, other.matricesIndicesExtra);\r\n this.matricesWeightsExtra = this._mergeElement(this.matricesWeightsExtra, other.matricesWeightsExtra);\r\n return this;\r\n };\r\n VertexData.prototype._mergeElement = function (source, other) {\r\n if (!source) {\r\n return other;\r\n }\r\n if (!other) {\r\n return source;\r\n }\r\n var len = other.length + source.length;\r\n var isSrcTypedArray = source instanceof Float32Array;\r\n var isOthTypedArray = other instanceof Float32Array;\r\n // use non-loop method when the source is Float32Array\r\n if (isSrcTypedArray) {\r\n var ret32 = new Float32Array(len);\r\n ret32.set(source);\r\n ret32.set(other, source.length);\r\n return ret32;\r\n // source is number[], when other is also use concat\r\n }\r\n else if (!isOthTypedArray) {\r\n return source.concat(other);\r\n // source is a number[], but other is a Float32Array, loop required\r\n }\r\n else {\r\n var ret = source.slice(0); // copy source to a separate array\r\n for (var i = 0, len = other.length; i < len; i++) {\r\n ret.push(other[i]);\r\n }\r\n return ret;\r\n }\r\n };\r\n VertexData.prototype._validate = function () {\r\n if (!this.positions) {\r\n throw new Error(\"Positions are required\");\r\n }\r\n var getElementCount = function (kind, values) {\r\n var stride = VertexBuffer.DeduceStride(kind);\r\n if ((values.length % stride) !== 0) {\r\n throw new Error(\"The \" + kind + \"s array count must be a multiple of \" + stride);\r\n }\r\n return values.length / stride;\r\n };\r\n var positionsElementCount = getElementCount(VertexBuffer.PositionKind, this.positions);\r\n var validateElementCount = function (kind, values) {\r\n var elementCount = getElementCount(kind, values);\r\n if (elementCount !== positionsElementCount) {\r\n throw new Error(\"The \" + kind + \"s element count (\" + elementCount + \") does not match the positions count (\" + positionsElementCount + \")\");\r\n }\r\n };\r\n if (this.normals) {\r\n validateElementCount(VertexBuffer.NormalKind, this.normals);\r\n }\r\n if (this.tangents) {\r\n validateElementCount(VertexBuffer.TangentKind, this.tangents);\r\n }\r\n if (this.uvs) {\r\n validateElementCount(VertexBuffer.UVKind, this.uvs);\r\n }\r\n if (this.uvs2) {\r\n validateElementCount(VertexBuffer.UV2Kind, this.uvs2);\r\n }\r\n if (this.uvs3) {\r\n validateElementCount(VertexBuffer.UV3Kind, this.uvs3);\r\n }\r\n if (this.uvs4) {\r\n validateElementCount(VertexBuffer.UV4Kind, this.uvs4);\r\n }\r\n if (this.uvs5) {\r\n validateElementCount(VertexBuffer.UV5Kind, this.uvs5);\r\n }\r\n if (this.uvs6) {\r\n validateElementCount(VertexBuffer.UV6Kind, this.uvs6);\r\n }\r\n if (this.colors) {\r\n validateElementCount(VertexBuffer.ColorKind, this.colors);\r\n }\r\n if (this.matricesIndices) {\r\n validateElementCount(VertexBuffer.MatricesIndicesKind, this.matricesIndices);\r\n }\r\n if (this.matricesWeights) {\r\n validateElementCount(VertexBuffer.MatricesWeightsKind, this.matricesWeights);\r\n }\r\n if (this.matricesIndicesExtra) {\r\n validateElementCount(VertexBuffer.MatricesIndicesExtraKind, this.matricesIndicesExtra);\r\n }\r\n if (this.matricesWeightsExtra) {\r\n validateElementCount(VertexBuffer.MatricesWeightsExtraKind, this.matricesWeightsExtra);\r\n }\r\n };\r\n /**\r\n * Serializes the VertexData\r\n * @returns a serialized object\r\n */\r\n VertexData.prototype.serialize = function () {\r\n var serializationObject = this.serialize();\r\n if (this.positions) {\r\n serializationObject.positions = this.positions;\r\n }\r\n if (this.normals) {\r\n serializationObject.normals = this.normals;\r\n }\r\n if (this.tangents) {\r\n serializationObject.tangents = this.tangents;\r\n }\r\n if (this.uvs) {\r\n serializationObject.uvs = this.uvs;\r\n }\r\n if (this.uvs2) {\r\n serializationObject.uvs2 = this.uvs2;\r\n }\r\n if (this.uvs3) {\r\n serializationObject.uvs3 = this.uvs3;\r\n }\r\n if (this.uvs4) {\r\n serializationObject.uvs4 = this.uvs4;\r\n }\r\n if (this.uvs5) {\r\n serializationObject.uvs5 = this.uvs5;\r\n }\r\n if (this.uvs6) {\r\n serializationObject.uvs6 = this.uvs6;\r\n }\r\n if (this.colors) {\r\n serializationObject.colors = this.colors;\r\n }\r\n if (this.matricesIndices) {\r\n serializationObject.matricesIndices = this.matricesIndices;\r\n serializationObject.matricesIndices._isExpanded = true;\r\n }\r\n if (this.matricesWeights) {\r\n serializationObject.matricesWeights = this.matricesWeights;\r\n }\r\n if (this.matricesIndicesExtra) {\r\n serializationObject.matricesIndicesExtra = this.matricesIndicesExtra;\r\n serializationObject.matricesIndicesExtra._isExpanded = true;\r\n }\r\n if (this.matricesWeightsExtra) {\r\n serializationObject.matricesWeightsExtra = this.matricesWeightsExtra;\r\n }\r\n serializationObject.indices = this.indices;\r\n return serializationObject;\r\n };\r\n // Statics\r\n /**\r\n * Extracts the vertexData from a mesh\r\n * @param mesh the mesh from which to extract the VertexData\r\n * @param copyWhenShared defines if the VertexData must be cloned when shared between multiple meshes, optional, default false\r\n * @param forceCopy indicating that the VertexData must be cloned, optional, default false\r\n * @returns the object VertexData associated to the passed mesh\r\n */\r\n VertexData.ExtractFromMesh = function (mesh, copyWhenShared, forceCopy) {\r\n return VertexData._ExtractFrom(mesh, copyWhenShared, forceCopy);\r\n };\r\n /**\r\n * Extracts the vertexData from the geometry\r\n * @param geometry the geometry from which to extract the VertexData\r\n * @param copyWhenShared defines if the VertexData must be cloned when the geometrty is shared between multiple meshes, optional, default false\r\n * @param forceCopy indicating that the VertexData must be cloned, optional, default false\r\n * @returns the object VertexData associated to the passed mesh\r\n */\r\n VertexData.ExtractFromGeometry = function (geometry, copyWhenShared, forceCopy) {\r\n return VertexData._ExtractFrom(geometry, copyWhenShared, forceCopy);\r\n };\r\n VertexData._ExtractFrom = function (meshOrGeometry, copyWhenShared, forceCopy) {\r\n var result = new VertexData();\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.PositionKind)) {\r\n result.positions = meshOrGeometry.getVerticesData(VertexBuffer.PositionKind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.NormalKind)) {\r\n result.normals = meshOrGeometry.getVerticesData(VertexBuffer.NormalKind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.TangentKind)) {\r\n result.tangents = meshOrGeometry.getVerticesData(VertexBuffer.TangentKind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.UVKind)) {\r\n result.uvs = meshOrGeometry.getVerticesData(VertexBuffer.UVKind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.UV2Kind)) {\r\n result.uvs2 = meshOrGeometry.getVerticesData(VertexBuffer.UV2Kind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.UV3Kind)) {\r\n result.uvs3 = meshOrGeometry.getVerticesData(VertexBuffer.UV3Kind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.UV4Kind)) {\r\n result.uvs4 = meshOrGeometry.getVerticesData(VertexBuffer.UV4Kind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.UV5Kind)) {\r\n result.uvs5 = meshOrGeometry.getVerticesData(VertexBuffer.UV5Kind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.UV6Kind)) {\r\n result.uvs6 = meshOrGeometry.getVerticesData(VertexBuffer.UV6Kind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.ColorKind)) {\r\n result.colors = meshOrGeometry.getVerticesData(VertexBuffer.ColorKind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.MatricesIndicesKind)) {\r\n result.matricesIndices = meshOrGeometry.getVerticesData(VertexBuffer.MatricesIndicesKind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.MatricesWeightsKind)) {\r\n result.matricesWeights = meshOrGeometry.getVerticesData(VertexBuffer.MatricesWeightsKind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.MatricesIndicesExtraKind)) {\r\n result.matricesIndicesExtra = meshOrGeometry.getVerticesData(VertexBuffer.MatricesIndicesExtraKind, copyWhenShared, forceCopy);\r\n }\r\n if (meshOrGeometry.isVerticesDataPresent(VertexBuffer.MatricesWeightsExtraKind)) {\r\n result.matricesWeightsExtra = meshOrGeometry.getVerticesData(VertexBuffer.MatricesWeightsExtraKind, copyWhenShared, forceCopy);\r\n }\r\n result.indices = meshOrGeometry.getIndices(copyWhenShared, forceCopy);\r\n return result;\r\n };\r\n /**\r\n * Creates the VertexData for a Ribbon\r\n * @param options an object used to set the following optional parameters for the ribbon, required but can be empty\r\n * * pathArray array of paths, each of which an array of successive Vector3\r\n * * closeArray creates a seam between the first and the last paths of the pathArray, optional, default false\r\n * * closePath creates a seam between the first and the last points of each path of the path array, optional, default false\r\n * * offset a positive integer, only used when pathArray contains a single path (offset = 10 means the point 1 is joined to the point 11), default rounded half size of the pathArray length\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * * invertUV swaps in the U and V coordinates when applying a texture, optional, default false\r\n * * uvs a linear array, of length 2 * number of vertices, of custom UV values, optional\r\n * * colors a linear array, of length 4 * number of vertices, of custom color values, optional\r\n * @returns the VertexData of the ribbon\r\n */\r\n VertexData.CreateRibbon = function (options) {\r\n throw _DevTools.WarnImport(\"ribbonBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for a box\r\n * @param options an object used to set the following optional parameters for the box, required but can be empty\r\n * * size sets the width, height and depth of the box to the value of size, optional default 1\r\n * * width sets the width (x direction) of the box, overwrites the width set by size, optional, default size\r\n * * height sets the height (y direction) of the box, overwrites the height set by size, optional, default size\r\n * * depth sets the depth (z direction) of the box, overwrites the depth set by size, optional, default size\r\n * * faceUV an array of 6 Vector4 elements used to set different images to each box side\r\n * * faceColors an array of 6 Color3 elements used to set different colors to each box side\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the box\r\n */\r\n VertexData.CreateBox = function (options) {\r\n throw _DevTools.WarnImport(\"boxBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for a tiled box\r\n * @param options an object used to set the following optional parameters for the box, required but can be empty\r\n * * faceTiles sets the pattern, tile size and number of tiles for a face\r\n * * faceUV an array of 6 Vector4 elements used to set different images to each box side\r\n * * faceColors an array of 6 Color3 elements used to set different colors to each box side\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * @returns the VertexData of the box\r\n */\r\n VertexData.CreateTiledBox = function (options) {\r\n throw _DevTools.WarnImport(\"tiledBoxBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for a tiled plane\r\n * @param options an object used to set the following optional parameters for the box, required but can be empty\r\n * * pattern a limited pattern arrangement depending on the number\r\n * * tileSize sets the width, height and depth of the tile to the value of size, optional default 1\r\n * * tileWidth sets the width (x direction) of the tile, overwrites the width set by size, optional, default size\r\n * * tileHeight sets the height (y direction) of the tile, overwrites the height set by size, optional, default size\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the tiled plane\r\n */\r\n VertexData.CreateTiledPlane = function (options) {\r\n throw _DevTools.WarnImport(\"tiledPlaneBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for an ellipsoid, defaults to a sphere\r\n * @param options an object used to set the following optional parameters for the box, required but can be empty\r\n * * segments sets the number of horizontal strips optional, default 32\r\n * * diameter sets the axes dimensions, diameterX, diameterY and diameterZ to the value of diameter, optional default 1\r\n * * diameterX sets the diameterX (x direction) of the ellipsoid, overwrites the diameterX set by diameter, optional, default diameter\r\n * * diameterY sets the diameterY (y direction) of the ellipsoid, overwrites the diameterY set by diameter, optional, default diameter\r\n * * diameterZ sets the diameterZ (z direction) of the ellipsoid, overwrites the diameterZ set by diameter, optional, default diameter\r\n * * arc a number from 0 to 1, to create an unclosed ellipsoid based on the fraction of the circumference (latitude) given by the arc value, optional, default 1\r\n * * slice a number from 0 to 1, to create an unclosed ellipsoid based on the fraction of the height (latitude) given by the arc value, optional, default 1\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the ellipsoid\r\n */\r\n VertexData.CreateSphere = function (options) {\r\n throw _DevTools.WarnImport(\"sphereBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for a cylinder, cone or prism\r\n * @param options an object used to set the following optional parameters for the box, required but can be empty\r\n * * height sets the height (y direction) of the cylinder, optional, default 2\r\n * * diameterTop sets the diameter of the top of the cone, overwrites diameter, optional, default diameter\r\n * * diameterBottom sets the diameter of the bottom of the cone, overwrites diameter, optional, default diameter\r\n * * diameter sets the diameter of the top and bottom of the cone, optional default 1\r\n * * tessellation the number of prism sides, 3 for a triangular prism, optional, default 24\r\n * * subdivisions` the number of rings along the cylinder height, optional, default 1\r\n * * arc a number from 0 to 1, to create an unclosed cylinder based on the fraction of the circumference given by the arc value, optional, default 1\r\n * * faceColors an array of Color3 elements used to set different colors to the top, rings and bottom respectively\r\n * * faceUV an array of Vector4 elements used to set different images to the top, rings and bottom respectively\r\n * * hasRings when true makes each subdivision independantly treated as a face for faceUV and faceColors, optional, default false\r\n * * enclose when true closes an open cylinder by adding extra flat faces between the height axis and vertical edges, think cut cake\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the cylinder, cone or prism\r\n */\r\n VertexData.CreateCylinder = function (options) {\r\n throw _DevTools.WarnImport(\"cylinderBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for a torus\r\n * @param options an object used to set the following optional parameters for the box, required but can be empty\r\n * * diameter the diameter of the torus, optional default 1\r\n * * thickness the diameter of the tube forming the torus, optional default 0.5\r\n * * tessellation the number of prism sides, 3 for a triangular prism, optional, default 24\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the torus\r\n */\r\n VertexData.CreateTorus = function (options) {\r\n throw _DevTools.WarnImport(\"torusBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData of the LineSystem\r\n * @param options an object used to set the following optional parameters for the LineSystem, required but can be empty\r\n * - lines an array of lines, each line being an array of successive Vector3\r\n * - colors an array of line colors, each of the line colors being an array of successive Color4, one per line point\r\n * @returns the VertexData of the LineSystem\r\n */\r\n VertexData.CreateLineSystem = function (options) {\r\n throw _DevTools.WarnImport(\"linesBuilder\");\r\n };\r\n /**\r\n * Create the VertexData for a DashedLines\r\n * @param options an object used to set the following optional parameters for the DashedLines, required but can be empty\r\n * - points an array successive Vector3\r\n * - dashSize the size of the dashes relative to the dash number, optional, default 3\r\n * - gapSize the size of the gap between two successive dashes relative to the dash number, optional, default 1\r\n * - dashNb the intended total number of dashes, optional, default 200\r\n * @returns the VertexData for the DashedLines\r\n */\r\n VertexData.CreateDashedLines = function (options) {\r\n throw _DevTools.WarnImport(\"linesBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for a Ground\r\n * @param options an object used to set the following optional parameters for the Ground, required but can be empty\r\n * - width the width (x direction) of the ground, optional, default 1\r\n * - height the height (z direction) of the ground, optional, default 1\r\n * - subdivisions the number of subdivisions per side, optional, default 1\r\n * @returns the VertexData of the Ground\r\n */\r\n VertexData.CreateGround = function (options) {\r\n throw _DevTools.WarnImport(\"groundBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for a TiledGround by subdividing the ground into tiles\r\n * @param options an object used to set the following optional parameters for the Ground, required but can be empty\r\n * * xmin the ground minimum X coordinate, optional, default -1\r\n * * zmin the ground minimum Z coordinate, optional, default -1\r\n * * xmax the ground maximum X coordinate, optional, default 1\r\n * * zmax the ground maximum Z coordinate, optional, default 1\r\n * * subdivisions a javascript object {w: positive integer, h: positive integer}, `w` and `h` are the numbers of subdivisions on the ground width and height creating 'tiles', default {w: 6, h: 6}\r\n * * precision a javascript object {w: positive integer, h: positive integer}, `w` and `h` are the numbers of subdivisions on the tile width and height, default {w: 2, h: 2}\r\n * @returns the VertexData of the TiledGround\r\n */\r\n VertexData.CreateTiledGround = function (options) {\r\n throw _DevTools.WarnImport(\"groundBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData of the Ground designed from a heightmap\r\n * @param options an object used to set the following parameters for the Ground, required and provided by MeshBuilder.CreateGroundFromHeightMap\r\n * * width the width (x direction) of the ground\r\n * * height the height (z direction) of the ground\r\n * * subdivisions the number of subdivisions per side\r\n * * minHeight the minimum altitude on the ground, optional, default 0\r\n * * maxHeight the maximum altitude on the ground, optional default 1\r\n * * colorFilter the filter to apply to the image pixel colors to compute the height, optional Color3, default (0.3, 0.59, 0.11)\r\n * * buffer the array holding the image color data\r\n * * bufferWidth the width of image\r\n * * bufferHeight the height of image\r\n * * alphaFilter Remove any data where the alpha channel is below this value, defaults 0 (all data visible)\r\n * @returns the VertexData of the Ground designed from a heightmap\r\n */\r\n VertexData.CreateGroundFromHeightMap = function (options) {\r\n throw _DevTools.WarnImport(\"groundBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for a Plane\r\n * @param options an object used to set the following optional parameters for the plane, required but can be empty\r\n * * size sets the width and height of the plane to the value of size, optional default 1\r\n * * width sets the width (x direction) of the plane, overwrites the width set by size, optional, default size\r\n * * height sets the height (y direction) of the plane, overwrites the height set by size, optional, default size\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the box\r\n */\r\n VertexData.CreatePlane = function (options) {\r\n throw _DevTools.WarnImport(\"planeBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData of the Disc or regular Polygon\r\n * @param options an object used to set the following optional parameters for the disc, required but can be empty\r\n * * radius the radius of the disc, optional default 0.5\r\n * * tessellation the number of polygon sides, optional, default 64\r\n * * arc a number from 0 to 1, to create an unclosed polygon based on the fraction of the circumference given by the arc value, optional, default 1\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the box\r\n */\r\n VertexData.CreateDisc = function (options) {\r\n throw _DevTools.WarnImport(\"discBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData for an irregular Polygon in the XoZ plane using a mesh built by polygonTriangulation.build()\r\n * All parameters are provided by MeshBuilder.CreatePolygon as needed\r\n * @param polygon a mesh built from polygonTriangulation.build()\r\n * @param sideOrientation takes the values Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * @param fUV an array of Vector4 elements used to set different images to the top, rings and bottom respectively\r\n * @param fColors an array of Color3 elements used to set different colors to the top, rings and bottom respectively\r\n * @param frontUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * @param backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @param wrap a boolean, default false, when true and fUVs used texture is wrapped around all sides, when false texture is applied side\r\n * @returns the VertexData of the Polygon\r\n */\r\n VertexData.CreatePolygon = function (polygon, sideOrientation, fUV, fColors, frontUVs, backUVs, wrap) {\r\n throw _DevTools.WarnImport(\"polygonBuilder\");\r\n };\r\n /**\r\n * Creates the VertexData of the IcoSphere\r\n * @param options an object used to set the following optional parameters for the IcoSphere, required but can be empty\r\n * * radius the radius of the IcoSphere, optional default 1\r\n * * radiusX allows stretching in the x direction, optional, default radius\r\n * * radiusY allows stretching in the y direction, optional, default radius\r\n * * radiusZ allows stretching in the z direction, optional, default radius\r\n * * flat when true creates a flat shaded mesh, optional, default true\r\n * * subdivisions increasing the subdivisions increases the number of faces, optional, default 4\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the IcoSphere\r\n */\r\n VertexData.CreateIcoSphere = function (options) {\r\n throw _DevTools.WarnImport(\"icoSphereBuilder\");\r\n };\r\n // inspired from // http://stemkoski.github.io/Three.js/Polyhedra.html\r\n /**\r\n * Creates the VertexData for a Polyhedron\r\n * @param options an object used to set the following optional parameters for the polyhedron, required but can be empty\r\n * * type provided types are:\r\n * * 0 : Tetrahedron, 1 : Octahedron, 2 : Dodecahedron, 3 : Icosahedron, 4 : Rhombicuboctahedron, 5 : Triangular Prism, 6 : Pentagonal Prism, 7 : Hexagonal Prism, 8 : Square Pyramid (J1)\r\n * * 9 : Pentagonal Pyramid (J2), 10 : Triangular Dipyramid (J12), 11 : Pentagonal Dipyramid (J13), 12 : Elongated Square Dipyramid (J15), 13 : Elongated Pentagonal Dipyramid (J16), 14 : Elongated Pentagonal Cupola (J20)\r\n * * size the size of the IcoSphere, optional default 1\r\n * * sizeX allows stretching in the x direction, optional, default size\r\n * * sizeY allows stretching in the y direction, optional, default size\r\n * * sizeZ allows stretching in the z direction, optional, default size\r\n * * custom a number that overwrites the type to create from an extended set of polyhedron from https://www.babylonjs-playground.com/#21QRSK#15 with minimised editor\r\n * * faceUV an array of Vector4 elements used to set different images to the top, rings and bottom respectively\r\n * * faceColors an array of Color3 elements used to set different colors to the top, rings and bottom respectively\r\n * * flat when true creates a flat shaded mesh, optional, default true\r\n * * subdivisions increasing the subdivisions increases the number of faces, optional, default 4\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the Polyhedron\r\n */\r\n VertexData.CreatePolyhedron = function (options) {\r\n throw _DevTools.WarnImport(\"polyhedronBuilder\");\r\n };\r\n //\r\n /**\r\n * Creates the VertexData for a Capsule, inspired from https://github.com/maximeq/three-js-capsule-geometry/blob/master/src/CapsuleBufferGeometry.js\r\n * @param options an object used to set the following optional parameters for the capsule, required but can be empty\r\n * @returns the VertexData of the Capsule\r\n */\r\n VertexData.CreateCapsule = function (options) {\r\n if (options === void 0) { options = {\r\n orientation: Vector3.Up(),\r\n subdivisions: 2,\r\n tessellation: 16,\r\n height: 1,\r\n radius: 0.25,\r\n capSubdivisions: 6\r\n }; }\r\n throw _DevTools.WarnImport(\"capsuleBuilder\");\r\n };\r\n // based on http://code.google.com/p/away3d/source/browse/trunk/fp10/Away3D/src/away3d/primitives/TorusKnot.as?spec=svn2473&r=2473\r\n /**\r\n * Creates the VertexData for a TorusKnot\r\n * @param options an object used to set the following optional parameters for the TorusKnot, required but can be empty\r\n * * radius the radius of the torus knot, optional, default 2\r\n * * tube the thickness of the tube, optional, default 0.5\r\n * * radialSegments the number of sides on each tube segments, optional, default 32\r\n * * tubularSegments the number of tubes to decompose the knot into, optional, default 32\r\n * * p the number of windings around the z axis, optional, default 2\r\n * * q the number of windings around the x axis, optional, default 3\r\n * * sideOrientation optional and takes the values : Mesh.FRONTSIDE (default), Mesh.BACKSIDE or Mesh.DOUBLESIDE\r\n * * frontUvs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the front side, optional, default vector4 (0, 0, 1, 1)\r\n * * backUVs only usable when you create a double-sided mesh, used to choose what parts of the texture image to crop and apply on the back side, optional, default vector4 (0, 0, 1, 1)\r\n * @returns the VertexData of the Torus Knot\r\n */\r\n VertexData.CreateTorusKnot = function (options) {\r\n throw _DevTools.WarnImport(\"torusKnotBuilder\");\r\n };\r\n // Tools\r\n /**\r\n * Compute normals for given positions and indices\r\n * @param positions an array of vertex positions, [...., x, y, z, ......]\r\n * @param indices an array of indices in groups of three for each triangular facet, [...., i, j, k, ......]\r\n * @param normals an array of vertex normals, [...., x, y, z, ......]\r\n * @param options an object used to set the following optional parameters for the TorusKnot, optional\r\n * * facetNormals : optional array of facet normals (vector3)\r\n * * facetPositions : optional array of facet positions (vector3)\r\n * * facetPartitioning : optional partitioning array. facetPositions is required for facetPartitioning computation\r\n * * ratio : optional partitioning ratio / bounding box, required for facetPartitioning computation\r\n * * bInfo : optional bounding info, required for facetPartitioning computation\r\n * * bbSize : optional bounding box size data, required for facetPartitioning computation\r\n * * subDiv : optional partitioning data about subdivsions on each axis (int), required for facetPartitioning computation\r\n * * useRightHandedSystem: optional boolean to for right handed system computation\r\n * * depthSort : optional boolean to enable the facet depth sort computation\r\n * * distanceTo : optional Vector3 to compute the facet depth from this location\r\n * * depthSortedFacets : optional array of depthSortedFacets to store the facet distances from the reference location\r\n */\r\n VertexData.ComputeNormals = function (positions, indices, normals, options) {\r\n // temporary scalar variables\r\n var index = 0; // facet index\r\n var p1p2x = 0.0; // p1p2 vector x coordinate\r\n var p1p2y = 0.0; // p1p2 vector y coordinate\r\n var p1p2z = 0.0; // p1p2 vector z coordinate\r\n var p3p2x = 0.0; // p3p2 vector x coordinate\r\n var p3p2y = 0.0; // p3p2 vector y coordinate\r\n var p3p2z = 0.0; // p3p2 vector z coordinate\r\n var faceNormalx = 0.0; // facet normal x coordinate\r\n var faceNormaly = 0.0; // facet normal y coordinate\r\n var faceNormalz = 0.0; // facet normal z coordinate\r\n var length = 0.0; // facet normal length before normalization\r\n var v1x = 0; // vector1 x index in the positions array\r\n var v1y = 0; // vector1 y index in the positions array\r\n var v1z = 0; // vector1 z index in the positions array\r\n var v2x = 0; // vector2 x index in the positions array\r\n var v2y = 0; // vector2 y index in the positions array\r\n var v2z = 0; // vector2 z index in the positions array\r\n var v3x = 0; // vector3 x index in the positions array\r\n var v3y = 0; // vector3 y index in the positions array\r\n var v3z = 0; // vector3 z index in the positions array\r\n var computeFacetNormals = false;\r\n var computeFacetPositions = false;\r\n var computeFacetPartitioning = false;\r\n var computeDepthSort = false;\r\n var faceNormalSign = 1;\r\n var ratio = 0;\r\n var distanceTo = null;\r\n if (options) {\r\n computeFacetNormals = (options.facetNormals) ? true : false;\r\n computeFacetPositions = (options.facetPositions) ? true : false;\r\n computeFacetPartitioning = (options.facetPartitioning) ? true : false;\r\n faceNormalSign = (options.useRightHandedSystem === true) ? -1 : 1;\r\n ratio = options.ratio || 0;\r\n computeDepthSort = (options.depthSort) ? true : false;\r\n distanceTo = (options.distanceTo);\r\n if (computeDepthSort) {\r\n if (distanceTo === undefined) {\r\n distanceTo = Vector3.Zero();\r\n }\r\n var depthSortedFacets = options.depthSortedFacets;\r\n }\r\n }\r\n // facetPartitioning reinit if needed\r\n var xSubRatio = 0;\r\n var ySubRatio = 0;\r\n var zSubRatio = 0;\r\n var subSq = 0;\r\n if (computeFacetPartitioning && options && options.bbSize) {\r\n var ox = 0; // X partitioning index for facet position\r\n var oy = 0; // Y partinioning index for facet position\r\n var oz = 0; // Z partinioning index for facet position\r\n var b1x = 0; // X partitioning index for facet v1 vertex\r\n var b1y = 0; // Y partitioning index for facet v1 vertex\r\n var b1z = 0; // z partitioning index for facet v1 vertex\r\n var b2x = 0; // X partitioning index for facet v2 vertex\r\n var b2y = 0; // Y partitioning index for facet v2 vertex\r\n var b2z = 0; // Z partitioning index for facet v2 vertex\r\n var b3x = 0; // X partitioning index for facet v3 vertex\r\n var b3y = 0; // Y partitioning index for facet v3 vertex\r\n var b3z = 0; // Z partitioning index for facet v3 vertex\r\n var block_idx_o = 0; // facet barycenter block index\r\n var block_idx_v1 = 0; // v1 vertex block index\r\n var block_idx_v2 = 0; // v2 vertex block index\r\n var block_idx_v3 = 0; // v3 vertex block index\r\n var bbSizeMax = (options.bbSize.x > options.bbSize.y) ? options.bbSize.x : options.bbSize.y;\r\n bbSizeMax = (bbSizeMax > options.bbSize.z) ? bbSizeMax : options.bbSize.z;\r\n xSubRatio = options.subDiv.X * ratio / options.bbSize.x;\r\n ySubRatio = options.subDiv.Y * ratio / options.bbSize.y;\r\n zSubRatio = options.subDiv.Z * ratio / options.bbSize.z;\r\n subSq = options.subDiv.max * options.subDiv.max;\r\n options.facetPartitioning.length = 0;\r\n }\r\n // reset the normals\r\n for (index = 0; index < positions.length; index++) {\r\n normals[index] = 0.0;\r\n }\r\n // Loop : 1 indice triplet = 1 facet\r\n var nbFaces = (indices.length / 3) | 0;\r\n for (index = 0; index < nbFaces; index++) {\r\n // get the indexes of the coordinates of each vertex of the facet\r\n v1x = indices[index * 3] * 3;\r\n v1y = v1x + 1;\r\n v1z = v1x + 2;\r\n v2x = indices[index * 3 + 1] * 3;\r\n v2y = v2x + 1;\r\n v2z = v2x + 2;\r\n v3x = indices[index * 3 + 2] * 3;\r\n v3y = v3x + 1;\r\n v3z = v3x + 2;\r\n p1p2x = positions[v1x] - positions[v2x]; // compute two vectors per facet : p1p2 and p3p2\r\n p1p2y = positions[v1y] - positions[v2y];\r\n p1p2z = positions[v1z] - positions[v2z];\r\n p3p2x = positions[v3x] - positions[v2x];\r\n p3p2y = positions[v3y] - positions[v2y];\r\n p3p2z = positions[v3z] - positions[v2z];\r\n // compute the face normal with the cross product\r\n faceNormalx = faceNormalSign * (p1p2y * p3p2z - p1p2z * p3p2y);\r\n faceNormaly = faceNormalSign * (p1p2z * p3p2x - p1p2x * p3p2z);\r\n faceNormalz = faceNormalSign * (p1p2x * p3p2y - p1p2y * p3p2x);\r\n // normalize this normal and store it in the array facetData\r\n length = Math.sqrt(faceNormalx * faceNormalx + faceNormaly * faceNormaly + faceNormalz * faceNormalz);\r\n length = (length === 0) ? 1.0 : length;\r\n faceNormalx /= length;\r\n faceNormaly /= length;\r\n faceNormalz /= length;\r\n if (computeFacetNormals && options) {\r\n options.facetNormals[index].x = faceNormalx;\r\n options.facetNormals[index].y = faceNormaly;\r\n options.facetNormals[index].z = faceNormalz;\r\n }\r\n if (computeFacetPositions && options) {\r\n // compute and the facet barycenter coordinates in the array facetPositions\r\n options.facetPositions[index].x = (positions[v1x] + positions[v2x] + positions[v3x]) / 3.0;\r\n options.facetPositions[index].y = (positions[v1y] + positions[v2y] + positions[v3y]) / 3.0;\r\n options.facetPositions[index].z = (positions[v1z] + positions[v2z] + positions[v3z]) / 3.0;\r\n }\r\n if (computeFacetPartitioning && options) {\r\n // store the facet indexes in arrays in the main facetPartitioning array :\r\n // compute each facet vertex (+ facet barycenter) index in the partiniong array\r\n ox = Math.floor((options.facetPositions[index].x - options.bInfo.minimum.x * ratio) * xSubRatio);\r\n oy = Math.floor((options.facetPositions[index].y - options.bInfo.minimum.y * ratio) * ySubRatio);\r\n oz = Math.floor((options.facetPositions[index].z - options.bInfo.minimum.z * ratio) * zSubRatio);\r\n b1x = Math.floor((positions[v1x] - options.bInfo.minimum.x * ratio) * xSubRatio);\r\n b1y = Math.floor((positions[v1y] - options.bInfo.minimum.y * ratio) * ySubRatio);\r\n b1z = Math.floor((positions[v1z] - options.bInfo.minimum.z * ratio) * zSubRatio);\r\n b2x = Math.floor((positions[v2x] - options.bInfo.minimum.x * ratio) * xSubRatio);\r\n b2y = Math.floor((positions[v2y] - options.bInfo.minimum.y * ratio) * ySubRatio);\r\n b2z = Math.floor((positions[v2z] - options.bInfo.minimum.z * ratio) * zSubRatio);\r\n b3x = Math.floor((positions[v3x] - options.bInfo.minimum.x * ratio) * xSubRatio);\r\n b3y = Math.floor((positions[v3y] - options.bInfo.minimum.y * ratio) * ySubRatio);\r\n b3z = Math.floor((positions[v3z] - options.bInfo.minimum.z * ratio) * zSubRatio);\r\n block_idx_v1 = b1x + options.subDiv.max * b1y + subSq * b1z;\r\n block_idx_v2 = b2x + options.subDiv.max * b2y + subSq * b2z;\r\n block_idx_v3 = b3x + options.subDiv.max * b3y + subSq * b3z;\r\n block_idx_o = ox + options.subDiv.max * oy + subSq * oz;\r\n options.facetPartitioning[block_idx_o] = options.facetPartitioning[block_idx_o] ? options.facetPartitioning[block_idx_o] : new Array();\r\n options.facetPartitioning[block_idx_v1] = options.facetPartitioning[block_idx_v1] ? options.facetPartitioning[block_idx_v1] : new Array();\r\n options.facetPartitioning[block_idx_v2] = options.facetPartitioning[block_idx_v2] ? options.facetPartitioning[block_idx_v2] : new Array();\r\n options.facetPartitioning[block_idx_v3] = options.facetPartitioning[block_idx_v3] ? options.facetPartitioning[block_idx_v3] : new Array();\r\n // push each facet index in each block containing the vertex\r\n options.facetPartitioning[block_idx_v1].push(index);\r\n if (block_idx_v2 != block_idx_v1) {\r\n options.facetPartitioning[block_idx_v2].push(index);\r\n }\r\n if (!(block_idx_v3 == block_idx_v2 || block_idx_v3 == block_idx_v1)) {\r\n options.facetPartitioning[block_idx_v3].push(index);\r\n }\r\n if (!(block_idx_o == block_idx_v1 || block_idx_o == block_idx_v2 || block_idx_o == block_idx_v3)) {\r\n options.facetPartitioning[block_idx_o].push(index);\r\n }\r\n }\r\n if (computeDepthSort && options && options.facetPositions) {\r\n var dsf = depthSortedFacets[index];\r\n dsf.ind = index * 3;\r\n dsf.sqDistance = Vector3.DistanceSquared(options.facetPositions[index], distanceTo);\r\n }\r\n // compute the normals anyway\r\n normals[v1x] += faceNormalx; // accumulate all the normals per face\r\n normals[v1y] += faceNormaly;\r\n normals[v1z] += faceNormalz;\r\n normals[v2x] += faceNormalx;\r\n normals[v2y] += faceNormaly;\r\n normals[v2z] += faceNormalz;\r\n normals[v3x] += faceNormalx;\r\n normals[v3y] += faceNormaly;\r\n normals[v3z] += faceNormalz;\r\n }\r\n // last normalization of each normal\r\n for (index = 0; index < normals.length / 3; index++) {\r\n faceNormalx = normals[index * 3];\r\n faceNormaly = normals[index * 3 + 1];\r\n faceNormalz = normals[index * 3 + 2];\r\n length = Math.sqrt(faceNormalx * faceNormalx + faceNormaly * faceNormaly + faceNormalz * faceNormalz);\r\n length = (length === 0) ? 1.0 : length;\r\n faceNormalx /= length;\r\n faceNormaly /= length;\r\n faceNormalz /= length;\r\n normals[index * 3] = faceNormalx;\r\n normals[index * 3 + 1] = faceNormaly;\r\n normals[index * 3 + 2] = faceNormalz;\r\n }\r\n };\r\n /** @hidden */\r\n VertexData._ComputeSides = function (sideOrientation, positions, indices, normals, uvs, frontUVs, backUVs) {\r\n var li = indices.length;\r\n var ln = normals.length;\r\n var i;\r\n var n;\r\n sideOrientation = sideOrientation || VertexData.DEFAULTSIDE;\r\n switch (sideOrientation) {\r\n case VertexData.FRONTSIDE:\r\n // nothing changed\r\n break;\r\n case VertexData.BACKSIDE:\r\n var tmp;\r\n // indices\r\n for (i = 0; i < li; i += 3) {\r\n tmp = indices[i];\r\n indices[i] = indices[i + 2];\r\n indices[i + 2] = tmp;\r\n }\r\n // normals\r\n for (n = 0; n < ln; n++) {\r\n normals[n] = -normals[n];\r\n }\r\n break;\r\n case VertexData.DOUBLESIDE:\r\n // positions\r\n var lp = positions.length;\r\n var l = lp / 3;\r\n for (var p = 0; p < lp; p++) {\r\n positions[lp + p] = positions[p];\r\n }\r\n // indices\r\n for (i = 0; i < li; i += 3) {\r\n indices[i + li] = indices[i + 2] + l;\r\n indices[i + 1 + li] = indices[i + 1] + l;\r\n indices[i + 2 + li] = indices[i] + l;\r\n }\r\n // normals\r\n for (n = 0; n < ln; n++) {\r\n normals[ln + n] = -normals[n];\r\n }\r\n // uvs\r\n var lu = uvs.length;\r\n var u = 0;\r\n for (u = 0; u < lu; u++) {\r\n uvs[u + lu] = uvs[u];\r\n }\r\n frontUVs = frontUVs ? frontUVs : new Vector4(0.0, 0.0, 1.0, 1.0);\r\n backUVs = backUVs ? backUVs : new Vector4(0.0, 0.0, 1.0, 1.0);\r\n u = 0;\r\n for (i = 0; i < lu / 2; i++) {\r\n uvs[u] = frontUVs.x + (frontUVs.z - frontUVs.x) * uvs[u];\r\n uvs[u + 1] = frontUVs.y + (frontUVs.w - frontUVs.y) * uvs[u + 1];\r\n uvs[u + lu] = backUVs.x + (backUVs.z - backUVs.x) * uvs[u + lu];\r\n uvs[u + lu + 1] = backUVs.y + (backUVs.w - backUVs.y) * uvs[u + lu + 1];\r\n u += 2;\r\n }\r\n break;\r\n }\r\n };\r\n /**\r\n * Applies VertexData created from the imported parameters to the geometry\r\n * @param parsedVertexData the parsed data from an imported file\r\n * @param geometry the geometry to apply the VertexData to\r\n */\r\n VertexData.ImportVertexData = function (parsedVertexData, geometry) {\r\n var vertexData = new VertexData();\r\n // positions\r\n var positions = parsedVertexData.positions;\r\n if (positions) {\r\n vertexData.set(positions, VertexBuffer.PositionKind);\r\n }\r\n // normals\r\n var normals = parsedVertexData.normals;\r\n if (normals) {\r\n vertexData.set(normals, VertexBuffer.NormalKind);\r\n }\r\n // tangents\r\n var tangents = parsedVertexData.tangents;\r\n if (tangents) {\r\n vertexData.set(tangents, VertexBuffer.TangentKind);\r\n }\r\n // uvs\r\n var uvs = parsedVertexData.uvs;\r\n if (uvs) {\r\n vertexData.set(uvs, VertexBuffer.UVKind);\r\n }\r\n // uv2s\r\n var uv2s = parsedVertexData.uv2s;\r\n if (uv2s) {\r\n vertexData.set(uv2s, VertexBuffer.UV2Kind);\r\n }\r\n // uv3s\r\n var uv3s = parsedVertexData.uv3s;\r\n if (uv3s) {\r\n vertexData.set(uv3s, VertexBuffer.UV3Kind);\r\n }\r\n // uv4s\r\n var uv4s = parsedVertexData.uv4s;\r\n if (uv4s) {\r\n vertexData.set(uv4s, VertexBuffer.UV4Kind);\r\n }\r\n // uv5s\r\n var uv5s = parsedVertexData.uv5s;\r\n if (uv5s) {\r\n vertexData.set(uv5s, VertexBuffer.UV5Kind);\r\n }\r\n // uv6s\r\n var uv6s = parsedVertexData.uv6s;\r\n if (uv6s) {\r\n vertexData.set(uv6s, VertexBuffer.UV6Kind);\r\n }\r\n // colors\r\n var colors = parsedVertexData.colors;\r\n if (colors) {\r\n vertexData.set(Color4.CheckColors4(colors, positions.length / 3), VertexBuffer.ColorKind);\r\n }\r\n // matricesIndices\r\n var matricesIndices = parsedVertexData.matricesIndices;\r\n if (matricesIndices) {\r\n vertexData.set(matricesIndices, VertexBuffer.MatricesIndicesKind);\r\n }\r\n // matricesWeights\r\n var matricesWeights = parsedVertexData.matricesWeights;\r\n if (matricesWeights) {\r\n vertexData.set(matricesWeights, VertexBuffer.MatricesWeightsKind);\r\n }\r\n // indices\r\n var indices = parsedVertexData.indices;\r\n if (indices) {\r\n vertexData.indices = indices;\r\n }\r\n geometry.setAllVerticesData(vertexData, parsedVertexData.updatable);\r\n };\r\n /**\r\n * Mesh side orientation : usually the external or front surface\r\n */\r\n VertexData.FRONTSIDE = 0;\r\n /**\r\n * Mesh side orientation : usually the internal or back surface\r\n */\r\n VertexData.BACKSIDE = 1;\r\n /**\r\n * Mesh side orientation : both internal and external or front and back surfaces\r\n */\r\n VertexData.DOUBLESIDE = 2;\r\n /**\r\n * Mesh side orientation : by default, `FRONTSIDE`\r\n */\r\n VertexData.DEFAULTSIDE = 0;\r\n return VertexData;\r\n}());\r\nexport { VertexData };\r\n//# sourceMappingURL=mesh.vertexData.js.map","/**\r\n * Class used to specific a value and its associated unit\r\n */\r\nvar ValueAndUnit = /** @class */ (function () {\r\n /**\r\n * Creates a new ValueAndUnit\r\n * @param value defines the value to store\r\n * @param unit defines the unit to store\r\n * @param negativeValueAllowed defines a boolean indicating if the value can be negative\r\n */\r\n function ValueAndUnit(value, \r\n /** defines the unit to store */\r\n unit, \r\n /** defines a boolean indicating if the value can be negative */\r\n negativeValueAllowed) {\r\n if (unit === void 0) { unit = ValueAndUnit.UNITMODE_PIXEL; }\r\n if (negativeValueAllowed === void 0) { negativeValueAllowed = true; }\r\n this.unit = unit;\r\n this.negativeValueAllowed = negativeValueAllowed;\r\n this._value = 1;\r\n /**\r\n * Gets or sets a value indicating that this value will not scale accordingly with adaptive scaling property\r\n * @see https://doc.babylonjs.com/how_to/gui#adaptive-scaling\r\n */\r\n this.ignoreAdaptiveScaling = false;\r\n this._value = value;\r\n this._originalUnit = unit;\r\n }\r\n Object.defineProperty(ValueAndUnit.prototype, \"isPercentage\", {\r\n /** Gets a boolean indicating if the value is a percentage */\r\n get: function () {\r\n return this.unit === ValueAndUnit.UNITMODE_PERCENTAGE;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ValueAndUnit.prototype, \"isPixel\", {\r\n /** Gets a boolean indicating if the value is store as pixel */\r\n get: function () {\r\n return this.unit === ValueAndUnit.UNITMODE_PIXEL;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ValueAndUnit.prototype, \"internalValue\", {\r\n /** Gets direct internal value */\r\n get: function () {\r\n return this._value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets value as pixel\r\n * @param host defines the root host\r\n * @param refValue defines the reference value for percentages\r\n * @returns the value as pixel\r\n */\r\n ValueAndUnit.prototype.getValueInPixel = function (host, refValue) {\r\n if (this.isPixel) {\r\n return this.getValue(host);\r\n }\r\n return this.getValue(host) * refValue;\r\n };\r\n /**\r\n * Update the current value and unit. This should be done cautiously as the GUi won't be marked as dirty with this function.\r\n * @param value defines the value to store\r\n * @param unit defines the unit to store\r\n * @returns the current ValueAndUnit\r\n */\r\n ValueAndUnit.prototype.updateInPlace = function (value, unit) {\r\n if (unit === void 0) { unit = ValueAndUnit.UNITMODE_PIXEL; }\r\n this._value = value;\r\n this.unit = unit;\r\n return this;\r\n };\r\n /**\r\n * Gets the value accordingly to its unit\r\n * @param host defines the root host\r\n * @returns the value\r\n */\r\n ValueAndUnit.prototype.getValue = function (host) {\r\n if (host && !this.ignoreAdaptiveScaling && this.unit !== ValueAndUnit.UNITMODE_PERCENTAGE) {\r\n var width = 0;\r\n var height = 0;\r\n if (host.idealWidth) {\r\n width = (this._value * host.getSize().width) / host.idealWidth;\r\n }\r\n if (host.idealHeight) {\r\n height = (this._value * host.getSize().height) / host.idealHeight;\r\n }\r\n if (host.useSmallestIdeal && host.idealWidth && host.idealHeight) {\r\n return window.innerWidth < window.innerHeight ? width : height;\r\n }\r\n if (host.idealWidth) { // horizontal\r\n return width;\r\n }\r\n if (host.idealHeight) { // vertical\r\n return height;\r\n }\r\n }\r\n return this._value;\r\n };\r\n /**\r\n * Gets a string representation of the value\r\n * @param host defines the root host\r\n * @param decimals defines an optional number of decimals to display\r\n * @returns a string\r\n */\r\n ValueAndUnit.prototype.toString = function (host, decimals) {\r\n switch (this.unit) {\r\n case ValueAndUnit.UNITMODE_PERCENTAGE:\r\n var percentage = this.getValue(host) * 100;\r\n return (decimals ? percentage.toFixed(decimals) : percentage) + \"%\";\r\n case ValueAndUnit.UNITMODE_PIXEL:\r\n var pixels = this.getValue(host);\r\n return (decimals ? pixels.toFixed(decimals) : pixels) + \"px\";\r\n }\r\n return this.unit.toString();\r\n };\r\n /**\r\n * Store a value parsed from a string\r\n * @param source defines the source string\r\n * @returns true if the value was successfully parsed\r\n */\r\n ValueAndUnit.prototype.fromString = function (source) {\r\n var match = ValueAndUnit._Regex.exec(source.toString());\r\n if (!match || match.length === 0) {\r\n return false;\r\n }\r\n var sourceValue = parseFloat(match[1]);\r\n var sourceUnit = this._originalUnit;\r\n if (!this.negativeValueAllowed) {\r\n if (sourceValue < 0) {\r\n sourceValue = 0;\r\n }\r\n }\r\n if (match.length === 4) {\r\n switch (match[3]) {\r\n case \"px\":\r\n sourceUnit = ValueAndUnit.UNITMODE_PIXEL;\r\n break;\r\n case \"%\":\r\n sourceUnit = ValueAndUnit.UNITMODE_PERCENTAGE;\r\n sourceValue /= 100.0;\r\n break;\r\n }\r\n }\r\n if (sourceValue === this._value && sourceUnit === this.unit) {\r\n return false;\r\n }\r\n this._value = sourceValue;\r\n this.unit = sourceUnit;\r\n return true;\r\n };\r\n Object.defineProperty(ValueAndUnit, \"UNITMODE_PERCENTAGE\", {\r\n /** UNITMODE_PERCENTAGE */\r\n get: function () {\r\n return ValueAndUnit._UNITMODE_PERCENTAGE;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ValueAndUnit, \"UNITMODE_PIXEL\", {\r\n /** UNITMODE_PIXEL */\r\n get: function () {\r\n return ValueAndUnit._UNITMODE_PIXEL;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n // Static\r\n ValueAndUnit._Regex = /(^-?\\d*(\\.\\d+)?)(%|px)?/;\r\n ValueAndUnit._UNITMODE_PERCENTAGE = 0;\r\n ValueAndUnit._UNITMODE_PIXEL = 1;\r\n return ValueAndUnit;\r\n}());\r\nexport { ValueAndUnit };\r\n//# sourceMappingURL=valueAndUnit.js.map","/**\r\n * Constant used to convert a value to gamma space\r\n * @ignorenaming\r\n */\r\nexport var ToGammaSpace = 1 / 2.2;\r\n/**\r\n * Constant used to convert a value to linear space\r\n * @ignorenaming\r\n */\r\nexport var ToLinearSpace = 2.2;\r\n/**\r\n * Constant used to define the minimal number value in Babylon.js\r\n * @ignorenaming\r\n */\r\nvar Epsilon = 0.001;\r\nexport { Epsilon };\r\n//# sourceMappingURL=math.constants.js.map","/**\r\n * Scalar computation library\r\n */\r\nvar Scalar = /** @class */ (function () {\r\n function Scalar() {\r\n }\r\n /**\r\n * Boolean : true if the absolute difference between a and b is lower than epsilon (default = 1.401298E-45)\r\n * @param a number\r\n * @param b number\r\n * @param epsilon (default = 1.401298E-45)\r\n * @returns true if the absolute difference between a and b is lower than epsilon (default = 1.401298E-45)\r\n */\r\n Scalar.WithinEpsilon = function (a, b, epsilon) {\r\n if (epsilon === void 0) { epsilon = 1.401298E-45; }\r\n var num = a - b;\r\n return -epsilon <= num && num <= epsilon;\r\n };\r\n /**\r\n * Returns a string : the upper case translation of the number i to hexadecimal.\r\n * @param i number\r\n * @returns the upper case translation of the number i to hexadecimal.\r\n */\r\n Scalar.ToHex = function (i) {\r\n var str = i.toString(16);\r\n if (i <= 15) {\r\n return (\"0\" + str).toUpperCase();\r\n }\r\n return str.toUpperCase();\r\n };\r\n /**\r\n * Returns -1 if value is negative and +1 is value is positive.\r\n * @param value the value\r\n * @returns the value itself if it's equal to zero.\r\n */\r\n Scalar.Sign = function (value) {\r\n value = +value; // convert to a number\r\n if (value === 0 || isNaN(value)) {\r\n return value;\r\n }\r\n return value > 0 ? 1 : -1;\r\n };\r\n /**\r\n * Returns the value itself if it's between min and max.\r\n * Returns min if the value is lower than min.\r\n * Returns max if the value is greater than max.\r\n * @param value the value to clmap\r\n * @param min the min value to clamp to (default: 0)\r\n * @param max the max value to clamp to (default: 1)\r\n * @returns the clamped value\r\n */\r\n Scalar.Clamp = function (value, min, max) {\r\n if (min === void 0) { min = 0; }\r\n if (max === void 0) { max = 1; }\r\n return Math.min(max, Math.max(min, value));\r\n };\r\n /**\r\n * the log2 of value.\r\n * @param value the value to compute log2 of\r\n * @returns the log2 of value.\r\n */\r\n Scalar.Log2 = function (value) {\r\n return Math.log(value) * Math.LOG2E;\r\n };\r\n /**\r\n * Loops the value, so that it is never larger than length and never smaller than 0.\r\n *\r\n * This is similar to the modulo operator but it works with floating point numbers.\r\n * For example, using 3.0 for t and 2.5 for length, the result would be 0.5.\r\n * With t = 5 and length = 2.5, the result would be 0.0.\r\n * Note, however, that the behaviour is not defined for negative numbers as it is for the modulo operator\r\n * @param value the value\r\n * @param length the length\r\n * @returns the looped value\r\n */\r\n Scalar.Repeat = function (value, length) {\r\n return value - Math.floor(value / length) * length;\r\n };\r\n /**\r\n * Normalize the value between 0.0 and 1.0 using min and max values\r\n * @param value value to normalize\r\n * @param min max to normalize between\r\n * @param max min to normalize between\r\n * @returns the normalized value\r\n */\r\n Scalar.Normalize = function (value, min, max) {\r\n return (value - min) / (max - min);\r\n };\r\n /**\r\n * Denormalize the value from 0.0 and 1.0 using min and max values\r\n * @param normalized value to denormalize\r\n * @param min max to denormalize between\r\n * @param max min to denormalize between\r\n * @returns the denormalized value\r\n */\r\n Scalar.Denormalize = function (normalized, min, max) {\r\n return (normalized * (max - min) + min);\r\n };\r\n /**\r\n * Calculates the shortest difference between two given angles given in degrees.\r\n * @param current current angle in degrees\r\n * @param target target angle in degrees\r\n * @returns the delta\r\n */\r\n Scalar.DeltaAngle = function (current, target) {\r\n var num = Scalar.Repeat(target - current, 360.0);\r\n if (num > 180.0) {\r\n num -= 360.0;\r\n }\r\n return num;\r\n };\r\n /**\r\n * PingPongs the value t, so that it is never larger than length and never smaller than 0.\r\n * @param tx value\r\n * @param length length\r\n * @returns The returned value will move back and forth between 0 and length\r\n */\r\n Scalar.PingPong = function (tx, length) {\r\n var t = Scalar.Repeat(tx, length * 2.0);\r\n return length - Math.abs(t - length);\r\n };\r\n /**\r\n * Interpolates between min and max with smoothing at the limits.\r\n *\r\n * This function interpolates between min and max in a similar way to Lerp. However, the interpolation will gradually speed up\r\n * from the start and slow down toward the end. This is useful for creating natural-looking animation, fading and other transitions.\r\n * @param from from\r\n * @param to to\r\n * @param tx value\r\n * @returns the smooth stepped value\r\n */\r\n Scalar.SmoothStep = function (from, to, tx) {\r\n var t = Scalar.Clamp(tx);\r\n t = -2.0 * t * t * t + 3.0 * t * t;\r\n return to * t + from * (1.0 - t);\r\n };\r\n /**\r\n * Moves a value current towards target.\r\n *\r\n * This is essentially the same as Mathf.Lerp but instead the function will ensure that the speed never exceeds maxDelta.\r\n * Negative values of maxDelta pushes the value away from target.\r\n * @param current current value\r\n * @param target target value\r\n * @param maxDelta max distance to move\r\n * @returns resulting value\r\n */\r\n Scalar.MoveTowards = function (current, target, maxDelta) {\r\n var result = 0;\r\n if (Math.abs(target - current) <= maxDelta) {\r\n result = target;\r\n }\r\n else {\r\n result = current + Scalar.Sign(target - current) * maxDelta;\r\n }\r\n return result;\r\n };\r\n /**\r\n * Same as MoveTowards but makes sure the values interpolate correctly when they wrap around 360 degrees.\r\n *\r\n * Variables current and target are assumed to be in degrees. For optimization reasons, negative values of maxDelta\r\n * are not supported and may cause oscillation. To push current away from a target angle, add 180 to that angle instead.\r\n * @param current current value\r\n * @param target target value\r\n * @param maxDelta max distance to move\r\n * @returns resulting angle\r\n */\r\n Scalar.MoveTowardsAngle = function (current, target, maxDelta) {\r\n var num = Scalar.DeltaAngle(current, target);\r\n var result = 0;\r\n if (-maxDelta < num && num < maxDelta) {\r\n result = target;\r\n }\r\n else {\r\n target = current + num;\r\n result = Scalar.MoveTowards(current, target, maxDelta);\r\n }\r\n return result;\r\n };\r\n /**\r\n * Creates a new scalar with values linearly interpolated of \"amount\" between the start scalar and the end scalar.\r\n * @param start start value\r\n * @param end target value\r\n * @param amount amount to lerp between\r\n * @returns the lerped value\r\n */\r\n Scalar.Lerp = function (start, end, amount) {\r\n return start + ((end - start) * amount);\r\n };\r\n /**\r\n * Same as Lerp but makes sure the values interpolate correctly when they wrap around 360 degrees.\r\n * The parameter t is clamped to the range [0, 1]. Variables a and b are assumed to be in degrees.\r\n * @param start start value\r\n * @param end target value\r\n * @param amount amount to lerp between\r\n * @returns the lerped value\r\n */\r\n Scalar.LerpAngle = function (start, end, amount) {\r\n var num = Scalar.Repeat(end - start, 360.0);\r\n if (num > 180.0) {\r\n num -= 360.0;\r\n }\r\n return start + num * Scalar.Clamp(amount);\r\n };\r\n /**\r\n * Calculates the linear parameter t that produces the interpolant value within the range [a, b].\r\n * @param a start value\r\n * @param b target value\r\n * @param value value between a and b\r\n * @returns the inverseLerp value\r\n */\r\n Scalar.InverseLerp = function (a, b, value) {\r\n var result = 0;\r\n if (a != b) {\r\n result = Scalar.Clamp((value - a) / (b - a));\r\n }\r\n else {\r\n result = 0.0;\r\n }\r\n return result;\r\n };\r\n /**\r\n * Returns a new scalar located for \"amount\" (float) on the Hermite spline defined by the scalars \"value1\", \"value3\", \"tangent1\", \"tangent2\".\r\n * @see http://mathworld.wolfram.com/HermitePolynomial.html\r\n * @param value1 spline value\r\n * @param tangent1 spline value\r\n * @param value2 spline value\r\n * @param tangent2 spline value\r\n * @param amount input value\r\n * @returns hermite result\r\n */\r\n Scalar.Hermite = function (value1, tangent1, value2, tangent2, amount) {\r\n var squared = amount * amount;\r\n var cubed = amount * squared;\r\n var part1 = ((2.0 * cubed) - (3.0 * squared)) + 1.0;\r\n var part2 = (-2.0 * cubed) + (3.0 * squared);\r\n var part3 = (cubed - (2.0 * squared)) + amount;\r\n var part4 = cubed - squared;\r\n return (((value1 * part1) + (value2 * part2)) + (tangent1 * part3)) + (tangent2 * part4);\r\n };\r\n /**\r\n * Returns a random float number between and min and max values\r\n * @param min min value of random\r\n * @param max max value of random\r\n * @returns random value\r\n */\r\n Scalar.RandomRange = function (min, max) {\r\n if (min === max) {\r\n return min;\r\n }\r\n return ((Math.random() * (max - min)) + min);\r\n };\r\n /**\r\n * This function returns percentage of a number in a given range.\r\n *\r\n * RangeToPercent(40,20,60) will return 0.5 (50%)\r\n * RangeToPercent(34,0,100) will return 0.34 (34%)\r\n * @param number to convert to percentage\r\n * @param min min range\r\n * @param max max range\r\n * @returns the percentage\r\n */\r\n Scalar.RangeToPercent = function (number, min, max) {\r\n return ((number - min) / (max - min));\r\n };\r\n /**\r\n * This function returns number that corresponds to the percentage in a given range.\r\n *\r\n * PercentToRange(0.34,0,100) will return 34.\r\n * @param percent to convert to number\r\n * @param min min range\r\n * @param max max range\r\n * @returns the number\r\n */\r\n Scalar.PercentToRange = function (percent, min, max) {\r\n return ((max - min) * percent + min);\r\n };\r\n /**\r\n * Returns the angle converted to equivalent value between -Math.PI and Math.PI radians.\r\n * @param angle The angle to normalize in radian.\r\n * @return The converted angle.\r\n */\r\n Scalar.NormalizeRadians = function (angle) {\r\n // More precise but slower version kept for reference.\r\n // angle = angle % Tools.TwoPi;\r\n // angle = (angle + Tools.TwoPi) % Tools.TwoPi;\r\n //if (angle > Math.PI) {\r\n //\tangle -= Tools.TwoPi;\r\n //}\r\n angle -= (Scalar.TwoPi * Math.floor((angle + Math.PI) / Scalar.TwoPi));\r\n return angle;\r\n };\r\n /**\r\n * Two pi constants convenient for computation.\r\n */\r\n Scalar.TwoPi = Math.PI * 2;\r\n return Scalar;\r\n}());\r\nexport { Scalar };\r\n//# sourceMappingURL=math.scalar.js.map","/**\r\n * \"Static Class\" containing a few commonly used helper while dealing with material for rendering purpose.\r\n *\r\n * It is complementary with MaterialHelper but provides completely independent functions (for tree shaking sake)\r\n *\r\n * This works by convention in BabylonJS but is meant to be use only with shader following the in place naming rules and conventions.\r\n */\r\nvar ThinMaterialHelper = /** @class */ (function () {\r\n function ThinMaterialHelper() {\r\n }\r\n /**\r\n * Binds the clip plane information from the holder to the effect.\r\n * @param effect The effect we are binding the data to\r\n * @param holder The entity containing the clip plane information\r\n */\r\n ThinMaterialHelper.BindClipPlane = function (effect, holder) {\r\n if (holder.clipPlane) {\r\n var clipPlane = holder.clipPlane;\r\n effect.setFloat4(\"vClipPlane\", clipPlane.normal.x, clipPlane.normal.y, clipPlane.normal.z, clipPlane.d);\r\n }\r\n if (holder.clipPlane2) {\r\n var clipPlane = holder.clipPlane2;\r\n effect.setFloat4(\"vClipPlane2\", clipPlane.normal.x, clipPlane.normal.y, clipPlane.normal.z, clipPlane.d);\r\n }\r\n if (holder.clipPlane3) {\r\n var clipPlane = holder.clipPlane3;\r\n effect.setFloat4(\"vClipPlane3\", clipPlane.normal.x, clipPlane.normal.y, clipPlane.normal.z, clipPlane.d);\r\n }\r\n if (holder.clipPlane4) {\r\n var clipPlane = holder.clipPlane4;\r\n effect.setFloat4(\"vClipPlane4\", clipPlane.normal.x, clipPlane.normal.y, clipPlane.normal.z, clipPlane.d);\r\n }\r\n if (holder.clipPlane5) {\r\n var clipPlane = holder.clipPlane5;\r\n effect.setFloat4(\"vClipPlane5\", clipPlane.normal.x, clipPlane.normal.y, clipPlane.normal.z, clipPlane.d);\r\n }\r\n if (holder.clipPlane6) {\r\n var clipPlane = holder.clipPlane6;\r\n effect.setFloat4(\"vClipPlane6\", clipPlane.normal.x, clipPlane.normal.y, clipPlane.normal.z, clipPlane.d);\r\n }\r\n };\r\n return ThinMaterialHelper;\r\n}());\r\nexport { ThinMaterialHelper };\r\n//# sourceMappingURL=thinMaterialHelper.js.map","import { Logger } from \"../Misc/logger\";\r\nimport { Scene } from \"../scene\";\r\nimport { EngineStore } from \"../Engines/engineStore\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { Light } from \"../Lights/light\";\r\nimport { Color3 } from '../Maths/math.color';\r\nimport { ThinMaterialHelper } from './thinMaterialHelper';\r\n/**\r\n * \"Static Class\" containing the most commonly used helper while dealing with material for rendering purpose.\r\n *\r\n * It contains the basic tools to help defining defines, binding uniform for the common part of the materials.\r\n *\r\n * This works by convention in BabylonJS but is meant to be use only with shader following the in place naming rules and conventions.\r\n */\r\nvar MaterialHelper = /** @class */ (function () {\r\n function MaterialHelper() {\r\n }\r\n /**\r\n * Bind the current view position to an effect.\r\n * @param effect The effect to be bound\r\n * @param scene The scene the eyes position is used from\r\n * @param variableName name of the shader variable that will hold the eye position\r\n */\r\n MaterialHelper.BindEyePosition = function (effect, scene, variableName) {\r\n if (variableName === void 0) { variableName = \"vEyePosition\"; }\r\n if (scene._forcedViewPosition) {\r\n effect.setVector3(variableName, scene._forcedViewPosition);\r\n return;\r\n }\r\n var globalPosition = scene.activeCamera.globalPosition;\r\n if (!globalPosition) {\r\n // Use WebVRFreecamera's device position as global position is not it's actual position in babylon space\r\n globalPosition = scene.activeCamera.devicePosition;\r\n }\r\n effect.setVector3(variableName, scene._mirroredCameraPosition ? scene._mirroredCameraPosition : globalPosition);\r\n };\r\n /**\r\n * Helps preparing the defines values about the UVs in used in the effect.\r\n * UVs are shared as much as we can accross channels in the shaders.\r\n * @param texture The texture we are preparing the UVs for\r\n * @param defines The defines to update\r\n * @param key The channel key \"diffuse\", \"specular\"... used in the shader\r\n */\r\n MaterialHelper.PrepareDefinesForMergedUV = function (texture, defines, key) {\r\n defines._needUVs = true;\r\n defines[key] = true;\r\n if (texture.getTextureMatrix().isIdentityAs3x2()) {\r\n defines[key + \"DIRECTUV\"] = texture.coordinatesIndex + 1;\r\n if (texture.coordinatesIndex === 0) {\r\n defines[\"MAINUV1\"] = true;\r\n }\r\n else {\r\n defines[\"MAINUV2\"] = true;\r\n }\r\n }\r\n else {\r\n defines[key + \"DIRECTUV\"] = 0;\r\n }\r\n };\r\n /**\r\n * Binds a texture matrix value to its corrsponding uniform\r\n * @param texture The texture to bind the matrix for\r\n * @param uniformBuffer The uniform buffer receivin the data\r\n * @param key The channel key \"diffuse\", \"specular\"... used in the shader\r\n */\r\n MaterialHelper.BindTextureMatrix = function (texture, uniformBuffer, key) {\r\n var matrix = texture.getTextureMatrix();\r\n uniformBuffer.updateMatrix(key + \"Matrix\", matrix);\r\n };\r\n /**\r\n * Gets the current status of the fog (should it be enabled?)\r\n * @param mesh defines the mesh to evaluate for fog support\r\n * @param scene defines the hosting scene\r\n * @returns true if fog must be enabled\r\n */\r\n MaterialHelper.GetFogState = function (mesh, scene) {\r\n return (scene.fogEnabled && mesh.applyFog && scene.fogMode !== Scene.FOGMODE_NONE);\r\n };\r\n /**\r\n * Helper used to prepare the list of defines associated with misc. values for shader compilation\r\n * @param mesh defines the current mesh\r\n * @param scene defines the current scene\r\n * @param useLogarithmicDepth defines if logarithmic depth has to be turned on\r\n * @param pointsCloud defines if point cloud rendering has to be turned on\r\n * @param fogEnabled defines if fog has to be turned on\r\n * @param alphaTest defines if alpha testing has to be turned on\r\n * @param defines defines the current list of defines\r\n */\r\n MaterialHelper.PrepareDefinesForMisc = function (mesh, scene, useLogarithmicDepth, pointsCloud, fogEnabled, alphaTest, defines) {\r\n if (defines._areMiscDirty) {\r\n defines[\"LOGARITHMICDEPTH\"] = useLogarithmicDepth;\r\n defines[\"POINTSIZE\"] = pointsCloud;\r\n defines[\"FOG\"] = fogEnabled && this.GetFogState(mesh, scene);\r\n defines[\"NONUNIFORMSCALING\"] = mesh.nonUniformScaling;\r\n defines[\"ALPHATEST\"] = alphaTest;\r\n }\r\n };\r\n /**\r\n * Helper used to prepare the list of defines associated with frame values for shader compilation\r\n * @param scene defines the current scene\r\n * @param engine defines the current engine\r\n * @param defines specifies the list of active defines\r\n * @param useInstances defines if instances have to be turned on\r\n * @param useClipPlane defines if clip plane have to be turned on\r\n * @param useInstances defines if instances have to be turned on\r\n * @param useThinInstances defines if thin instances have to be turned on\r\n */\r\n MaterialHelper.PrepareDefinesForFrameBoundValues = function (scene, engine, defines, useInstances, useClipPlane, useThinInstances) {\r\n if (useClipPlane === void 0) { useClipPlane = null; }\r\n if (useThinInstances === void 0) { useThinInstances = false; }\r\n var changed = false;\r\n var useClipPlane1 = false;\r\n var useClipPlane2 = false;\r\n var useClipPlane3 = false;\r\n var useClipPlane4 = false;\r\n var useClipPlane5 = false;\r\n var useClipPlane6 = false;\r\n useClipPlane1 = useClipPlane == null ? (scene.clipPlane !== undefined && scene.clipPlane !== null) : useClipPlane;\r\n useClipPlane2 = useClipPlane == null ? (scene.clipPlane2 !== undefined && scene.clipPlane2 !== null) : useClipPlane;\r\n useClipPlane3 = useClipPlane == null ? (scene.clipPlane3 !== undefined && scene.clipPlane3 !== null) : useClipPlane;\r\n useClipPlane4 = useClipPlane == null ? (scene.clipPlane4 !== undefined && scene.clipPlane4 !== null) : useClipPlane;\r\n useClipPlane5 = useClipPlane == null ? (scene.clipPlane5 !== undefined && scene.clipPlane5 !== null) : useClipPlane;\r\n useClipPlane6 = useClipPlane == null ? (scene.clipPlane6 !== undefined && scene.clipPlane6 !== null) : useClipPlane;\r\n if (defines[\"CLIPPLANE\"] !== useClipPlane1) {\r\n defines[\"CLIPPLANE\"] = useClipPlane1;\r\n changed = true;\r\n }\r\n if (defines[\"CLIPPLANE2\"] !== useClipPlane2) {\r\n defines[\"CLIPPLANE2\"] = useClipPlane2;\r\n changed = true;\r\n }\r\n if (defines[\"CLIPPLANE3\"] !== useClipPlane3) {\r\n defines[\"CLIPPLANE3\"] = useClipPlane3;\r\n changed = true;\r\n }\r\n if (defines[\"CLIPPLANE4\"] !== useClipPlane4) {\r\n defines[\"CLIPPLANE4\"] = useClipPlane4;\r\n changed = true;\r\n }\r\n if (defines[\"CLIPPLANE5\"] !== useClipPlane5) {\r\n defines[\"CLIPPLANE5\"] = useClipPlane5;\r\n changed = true;\r\n }\r\n if (defines[\"CLIPPLANE6\"] !== useClipPlane6) {\r\n defines[\"CLIPPLANE6\"] = useClipPlane6;\r\n changed = true;\r\n }\r\n if (defines[\"DEPTHPREPASS\"] !== !engine.getColorWrite()) {\r\n defines[\"DEPTHPREPASS\"] = !defines[\"DEPTHPREPASS\"];\r\n changed = true;\r\n }\r\n if (defines[\"INSTANCES\"] !== useInstances) {\r\n defines[\"INSTANCES\"] = useInstances;\r\n changed = true;\r\n }\r\n if (defines[\"THIN_INSTANCES\"] !== useThinInstances) {\r\n defines[\"THIN_INSTANCES\"] = useThinInstances;\r\n changed = true;\r\n }\r\n if (changed) {\r\n defines.markAsUnprocessed();\r\n }\r\n };\r\n /**\r\n * Prepares the defines for bones\r\n * @param mesh The mesh containing the geometry data we will draw\r\n * @param defines The defines to update\r\n */\r\n MaterialHelper.PrepareDefinesForBones = function (mesh, defines) {\r\n if (mesh.useBones && mesh.computeBonesUsingShaders && mesh.skeleton) {\r\n defines[\"NUM_BONE_INFLUENCERS\"] = mesh.numBoneInfluencers;\r\n var materialSupportsBoneTexture = defines[\"BONETEXTURE\"] !== undefined;\r\n if (mesh.skeleton.isUsingTextureForMatrices && materialSupportsBoneTexture) {\r\n defines[\"BONETEXTURE\"] = true;\r\n }\r\n else {\r\n defines[\"BonesPerMesh\"] = (mesh.skeleton.bones.length + 1);\r\n defines[\"BONETEXTURE\"] = materialSupportsBoneTexture ? false : undefined;\r\n var prePassRenderer = mesh.getScene().prePassRenderer;\r\n if (prePassRenderer && prePassRenderer.enabled) {\r\n var nonExcluded = prePassRenderer.excludedSkinnedMesh.indexOf(mesh) === -1;\r\n defines[\"BONES_VELOCITY_ENABLED\"] = nonExcluded;\r\n }\r\n }\r\n }\r\n else {\r\n defines[\"NUM_BONE_INFLUENCERS\"] = 0;\r\n defines[\"BonesPerMesh\"] = 0;\r\n }\r\n };\r\n /**\r\n * Prepares the defines for morph targets\r\n * @param mesh The mesh containing the geometry data we will draw\r\n * @param defines The defines to update\r\n */\r\n MaterialHelper.PrepareDefinesForMorphTargets = function (mesh, defines) {\r\n var manager = mesh.morphTargetManager;\r\n if (manager) {\r\n defines[\"MORPHTARGETS_UV\"] = manager.supportsUVs && defines[\"UV1\"];\r\n defines[\"MORPHTARGETS_TANGENT\"] = manager.supportsTangents && defines[\"TANGENT\"];\r\n defines[\"MORPHTARGETS_NORMAL\"] = manager.supportsNormals && defines[\"NORMAL\"];\r\n defines[\"MORPHTARGETS\"] = (manager.numInfluencers > 0);\r\n defines[\"NUM_MORPH_INFLUENCERS\"] = manager.numInfluencers;\r\n }\r\n else {\r\n defines[\"MORPHTARGETS_UV\"] = false;\r\n defines[\"MORPHTARGETS_TANGENT\"] = false;\r\n defines[\"MORPHTARGETS_NORMAL\"] = false;\r\n defines[\"MORPHTARGETS\"] = false;\r\n defines[\"NUM_MORPH_INFLUENCERS\"] = 0;\r\n }\r\n };\r\n /**\r\n * Prepares the defines used in the shader depending on the attributes data available in the mesh\r\n * @param mesh The mesh containing the geometry data we will draw\r\n * @param defines The defines to update\r\n * @param useVertexColor Precise whether vertex colors should be used or not (override mesh info)\r\n * @param useBones Precise whether bones should be used or not (override mesh info)\r\n * @param useMorphTargets Precise whether morph targets should be used or not (override mesh info)\r\n * @param useVertexAlpha Precise whether vertex alpha should be used or not (override mesh info)\r\n * @returns false if defines are considered not dirty and have not been checked\r\n */\r\n MaterialHelper.PrepareDefinesForAttributes = function (mesh, defines, useVertexColor, useBones, useMorphTargets, useVertexAlpha) {\r\n if (useMorphTargets === void 0) { useMorphTargets = false; }\r\n if (useVertexAlpha === void 0) { useVertexAlpha = true; }\r\n if (!defines._areAttributesDirty && defines._needNormals === defines._normals && defines._needUVs === defines._uvs) {\r\n return false;\r\n }\r\n defines._normals = defines._needNormals;\r\n defines._uvs = defines._needUVs;\r\n defines[\"NORMAL\"] = (defines._needNormals && mesh.isVerticesDataPresent(VertexBuffer.NormalKind));\r\n if (defines._needNormals && mesh.isVerticesDataPresent(VertexBuffer.TangentKind)) {\r\n defines[\"TANGENT\"] = true;\r\n }\r\n if (defines._needUVs) {\r\n defines[\"UV1\"] = mesh.isVerticesDataPresent(VertexBuffer.UVKind);\r\n defines[\"UV2\"] = mesh.isVerticesDataPresent(VertexBuffer.UV2Kind);\r\n }\r\n else {\r\n defines[\"UV1\"] = false;\r\n defines[\"UV2\"] = false;\r\n }\r\n if (useVertexColor) {\r\n var hasVertexColors = mesh.useVertexColors && mesh.isVerticesDataPresent(VertexBuffer.ColorKind);\r\n defines[\"VERTEXCOLOR\"] = hasVertexColors;\r\n defines[\"VERTEXALPHA\"] = mesh.hasVertexAlpha && hasVertexColors && useVertexAlpha;\r\n }\r\n if (useBones) {\r\n this.PrepareDefinesForBones(mesh, defines);\r\n }\r\n if (useMorphTargets) {\r\n this.PrepareDefinesForMorphTargets(mesh, defines);\r\n }\r\n return true;\r\n };\r\n /**\r\n * Prepares the defines related to multiview\r\n * @param scene The scene we are intending to draw\r\n * @param defines The defines to update\r\n */\r\n MaterialHelper.PrepareDefinesForMultiview = function (scene, defines) {\r\n if (scene.activeCamera) {\r\n var previousMultiview = defines.MULTIVIEW;\r\n defines.MULTIVIEW = (scene.activeCamera.outputRenderTarget !== null && scene.activeCamera.outputRenderTarget.getViewCount() > 1);\r\n if (defines.MULTIVIEW != previousMultiview) {\r\n defines.markAsUnprocessed();\r\n }\r\n }\r\n };\r\n /**\r\n * Prepares the defines related to the prepass\r\n * @param scene The scene we are intending to draw\r\n * @param defines The defines to update\r\n * @param canRenderToMRT Indicates if this material renders to several textures in the prepass\r\n */\r\n MaterialHelper.PrepareDefinesForPrePass = function (scene, defines, canRenderToMRT) {\r\n var previousPrePass = defines.PREPASS;\r\n if (!defines._arePrePassDirty) {\r\n return;\r\n }\r\n var texturesList = [\r\n {\r\n type: 1,\r\n define: \"PREPASS_POSITION\",\r\n index: \"PREPASS_POSITION_INDEX\",\r\n },\r\n {\r\n type: 2,\r\n define: \"PREPASS_VELOCITY\",\r\n index: \"PREPASS_VELOCITY_INDEX\",\r\n },\r\n {\r\n type: 3,\r\n define: \"PREPASS_REFLECTIVITY\",\r\n index: \"PREPASS_REFLECTIVITY_INDEX\",\r\n },\r\n {\r\n type: 0,\r\n define: \"PREPASS_IRRADIANCE\",\r\n index: \"PREPASS_IRRADIANCE_INDEX\",\r\n },\r\n {\r\n type: 6,\r\n define: \"PREPASS_ALBEDO\",\r\n index: \"PREPASS_ALBEDO_INDEX\",\r\n },\r\n {\r\n type: 5,\r\n define: \"PREPASS_DEPTHNORMAL\",\r\n index: \"PREPASS_DEPTHNORMAL_INDEX\",\r\n }\r\n ];\r\n if (scene.prePassRenderer && scene.prePassRenderer.enabled && canRenderToMRT) {\r\n defines.PREPASS = true;\r\n defines.SCENE_MRT_COUNT = scene.prePassRenderer.mrtCount;\r\n for (var i = 0; i < texturesList.length; i++) {\r\n var index = scene.prePassRenderer.getIndex(texturesList[i].type);\r\n if (index !== -1) {\r\n defines[texturesList[i].define] = true;\r\n defines[texturesList[i].index] = index;\r\n }\r\n else {\r\n defines[texturesList[i].define] = false;\r\n }\r\n }\r\n }\r\n else {\r\n defines.PREPASS = false;\r\n for (var i = 0; i < texturesList.length; i++) {\r\n defines[texturesList[i].define] = false;\r\n }\r\n }\r\n if (defines.PREPASS != previousPrePass) {\r\n defines.markAsUnprocessed();\r\n defines.markAsImageProcessingDirty();\r\n }\r\n };\r\n /**\r\n * Prepares the defines related to the light information passed in parameter\r\n * @param scene The scene we are intending to draw\r\n * @param mesh The mesh the effect is compiling for\r\n * @param light The light the effect is compiling for\r\n * @param lightIndex The index of the light\r\n * @param defines The defines to update\r\n * @param specularSupported Specifies whether specular is supported or not (override lights data)\r\n * @param state Defines the current state regarding what is needed (normals, etc...)\r\n */\r\n MaterialHelper.PrepareDefinesForLight = function (scene, mesh, light, lightIndex, defines, specularSupported, state) {\r\n state.needNormals = true;\r\n if (defines[\"LIGHT\" + lightIndex] === undefined) {\r\n state.needRebuild = true;\r\n }\r\n defines[\"LIGHT\" + lightIndex] = true;\r\n defines[\"SPOTLIGHT\" + lightIndex] = false;\r\n defines[\"HEMILIGHT\" + lightIndex] = false;\r\n defines[\"POINTLIGHT\" + lightIndex] = false;\r\n defines[\"DIRLIGHT\" + lightIndex] = false;\r\n light.prepareLightSpecificDefines(defines, lightIndex);\r\n // FallOff.\r\n defines[\"LIGHT_FALLOFF_PHYSICAL\" + lightIndex] = false;\r\n defines[\"LIGHT_FALLOFF_GLTF\" + lightIndex] = false;\r\n defines[\"LIGHT_FALLOFF_STANDARD\" + lightIndex] = false;\r\n switch (light.falloffType) {\r\n case Light.FALLOFF_GLTF:\r\n defines[\"LIGHT_FALLOFF_GLTF\" + lightIndex] = true;\r\n break;\r\n case Light.FALLOFF_PHYSICAL:\r\n defines[\"LIGHT_FALLOFF_PHYSICAL\" + lightIndex] = true;\r\n break;\r\n case Light.FALLOFF_STANDARD:\r\n defines[\"LIGHT_FALLOFF_STANDARD\" + lightIndex] = true;\r\n break;\r\n }\r\n // Specular\r\n if (specularSupported && !light.specular.equalsFloats(0, 0, 0)) {\r\n state.specularEnabled = true;\r\n }\r\n // Shadows\r\n defines[\"SHADOW\" + lightIndex] = false;\r\n defines[\"SHADOWCSM\" + lightIndex] = false;\r\n defines[\"SHADOWCSMDEBUG\" + lightIndex] = false;\r\n defines[\"SHADOWCSMNUM_CASCADES\" + lightIndex] = false;\r\n defines[\"SHADOWCSMUSESHADOWMAXZ\" + lightIndex] = false;\r\n defines[\"SHADOWCSMNOBLEND\" + lightIndex] = false;\r\n defines[\"SHADOWCSM_RIGHTHANDED\" + lightIndex] = false;\r\n defines[\"SHADOWPCF\" + lightIndex] = false;\r\n defines[\"SHADOWPCSS\" + lightIndex] = false;\r\n defines[\"SHADOWPOISSON\" + lightIndex] = false;\r\n defines[\"SHADOWESM\" + lightIndex] = false;\r\n defines[\"SHADOWCLOSEESM\" + lightIndex] = false;\r\n defines[\"SHADOWCUBE\" + lightIndex] = false;\r\n defines[\"SHADOWLOWQUALITY\" + lightIndex] = false;\r\n defines[\"SHADOWMEDIUMQUALITY\" + lightIndex] = false;\r\n if (mesh && mesh.receiveShadows && scene.shadowsEnabled && light.shadowEnabled) {\r\n var shadowGenerator = light.getShadowGenerator();\r\n if (shadowGenerator) {\r\n var shadowMap = shadowGenerator.getShadowMap();\r\n if (shadowMap) {\r\n if (shadowMap.renderList && shadowMap.renderList.length > 0) {\r\n state.shadowEnabled = true;\r\n shadowGenerator.prepareDefines(defines, lightIndex);\r\n }\r\n }\r\n }\r\n }\r\n if (light.lightmapMode != Light.LIGHTMAP_DEFAULT) {\r\n state.lightmapMode = true;\r\n defines[\"LIGHTMAPEXCLUDED\" + lightIndex] = true;\r\n defines[\"LIGHTMAPNOSPECULAR\" + lightIndex] = (light.lightmapMode == Light.LIGHTMAP_SHADOWSONLY);\r\n }\r\n else {\r\n defines[\"LIGHTMAPEXCLUDED\" + lightIndex] = false;\r\n defines[\"LIGHTMAPNOSPECULAR\" + lightIndex] = false;\r\n }\r\n };\r\n /**\r\n * Prepares the defines related to the light information passed in parameter\r\n * @param scene The scene we are intending to draw\r\n * @param mesh The mesh the effect is compiling for\r\n * @param defines The defines to update\r\n * @param specularSupported Specifies whether specular is supported or not (override lights data)\r\n * @param maxSimultaneousLights Specfies how manuy lights can be added to the effect at max\r\n * @param disableLighting Specifies whether the lighting is disabled (override scene and light)\r\n * @returns true if normals will be required for the rest of the effect\r\n */\r\n MaterialHelper.PrepareDefinesForLights = function (scene, mesh, defines, specularSupported, maxSimultaneousLights, disableLighting) {\r\n if (maxSimultaneousLights === void 0) { maxSimultaneousLights = 4; }\r\n if (disableLighting === void 0) { disableLighting = false; }\r\n if (!defines._areLightsDirty) {\r\n return defines._needNormals;\r\n }\r\n var lightIndex = 0;\r\n var state = {\r\n needNormals: false,\r\n needRebuild: false,\r\n lightmapMode: false,\r\n shadowEnabled: false,\r\n specularEnabled: false\r\n };\r\n if (scene.lightsEnabled && !disableLighting) {\r\n for (var _i = 0, _a = mesh.lightSources; _i < _a.length; _i++) {\r\n var light = _a[_i];\r\n this.PrepareDefinesForLight(scene, mesh, light, lightIndex, defines, specularSupported, state);\r\n lightIndex++;\r\n if (lightIndex === maxSimultaneousLights) {\r\n break;\r\n }\r\n }\r\n }\r\n defines[\"SPECULARTERM\"] = state.specularEnabled;\r\n defines[\"SHADOWS\"] = state.shadowEnabled;\r\n // Resetting all other lights if any\r\n for (var index = lightIndex; index < maxSimultaneousLights; index++) {\r\n if (defines[\"LIGHT\" + index] !== undefined) {\r\n defines[\"LIGHT\" + index] = false;\r\n defines[\"HEMILIGHT\" + index] = false;\r\n defines[\"POINTLIGHT\" + index] = false;\r\n defines[\"DIRLIGHT\" + index] = false;\r\n defines[\"SPOTLIGHT\" + index] = false;\r\n defines[\"SHADOW\" + index] = false;\r\n defines[\"SHADOWCSM\" + index] = false;\r\n defines[\"SHADOWCSMDEBUG\" + index] = false;\r\n defines[\"SHADOWCSMNUM_CASCADES\" + index] = false;\r\n defines[\"SHADOWCSMUSESHADOWMAXZ\" + index] = false;\r\n defines[\"SHADOWCSMNOBLEND\" + index] = false;\r\n defines[\"SHADOWCSM_RIGHTHANDED\" + index] = false;\r\n defines[\"SHADOWPCF\" + index] = false;\r\n defines[\"SHADOWPCSS\" + index] = false;\r\n defines[\"SHADOWPOISSON\" + index] = false;\r\n defines[\"SHADOWESM\" + index] = false;\r\n defines[\"SHADOWCLOSEESM\" + index] = false;\r\n defines[\"SHADOWCUBE\" + index] = false;\r\n defines[\"SHADOWLOWQUALITY\" + index] = false;\r\n defines[\"SHADOWMEDIUMQUALITY\" + index] = false;\r\n }\r\n }\r\n var caps = scene.getEngine().getCaps();\r\n if (defines[\"SHADOWFLOAT\"] === undefined) {\r\n state.needRebuild = true;\r\n }\r\n defines[\"SHADOWFLOAT\"] = state.shadowEnabled &&\r\n ((caps.textureFloatRender && caps.textureFloatLinearFiltering) ||\r\n (caps.textureHalfFloatRender && caps.textureHalfFloatLinearFiltering));\r\n defines[\"LIGHTMAPEXCLUDED\"] = state.lightmapMode;\r\n if (state.needRebuild) {\r\n defines.rebuild();\r\n }\r\n return state.needNormals;\r\n };\r\n /**\r\n * Prepares the uniforms and samplers list to be used in the effect (for a specific light)\r\n * @param lightIndex defines the light index\r\n * @param uniformsList The uniform list\r\n * @param samplersList The sampler list\r\n * @param projectedLightTexture defines if projected texture must be used\r\n * @param uniformBuffersList defines an optional list of uniform buffers\r\n * @param updateOnlyBuffersList True to only update the uniformBuffersList array\r\n */\r\n MaterialHelper.PrepareUniformsAndSamplersForLight = function (lightIndex, uniformsList, samplersList, projectedLightTexture, uniformBuffersList, updateOnlyBuffersList) {\r\n if (uniformBuffersList === void 0) { uniformBuffersList = null; }\r\n if (updateOnlyBuffersList === void 0) { updateOnlyBuffersList = false; }\r\n if (uniformBuffersList) {\r\n uniformBuffersList.push(\"Light\" + lightIndex);\r\n }\r\n if (updateOnlyBuffersList) {\r\n return;\r\n }\r\n uniformsList.push(\"vLightData\" + lightIndex, \"vLightDiffuse\" + lightIndex, \"vLightSpecular\" + lightIndex, \"vLightDirection\" + lightIndex, \"vLightFalloff\" + lightIndex, \"vLightGround\" + lightIndex, \"lightMatrix\" + lightIndex, \"shadowsInfo\" + lightIndex, \"depthValues\" + lightIndex);\r\n samplersList.push(\"shadowSampler\" + lightIndex);\r\n samplersList.push(\"depthSampler\" + lightIndex);\r\n uniformsList.push(\"viewFrustumZ\" + lightIndex, \"cascadeBlendFactor\" + lightIndex, \"lightSizeUVCorrection\" + lightIndex, \"depthCorrection\" + lightIndex, \"penumbraDarkness\" + lightIndex, \"frustumLengths\" + lightIndex);\r\n if (projectedLightTexture) {\r\n samplersList.push(\"projectionLightSampler\" + lightIndex);\r\n uniformsList.push(\"textureProjectionMatrix\" + lightIndex);\r\n }\r\n };\r\n /**\r\n * Prepares the uniforms and samplers list to be used in the effect\r\n * @param uniformsListOrOptions The uniform names to prepare or an EffectCreationOptions containing the liist and extra information\r\n * @param samplersList The sampler list\r\n * @param defines The defines helping in the list generation\r\n * @param maxSimultaneousLights The maximum number of simultanous light allowed in the effect\r\n */\r\n MaterialHelper.PrepareUniformsAndSamplersList = function (uniformsListOrOptions, samplersList, defines, maxSimultaneousLights) {\r\n if (maxSimultaneousLights === void 0) { maxSimultaneousLights = 4; }\r\n var uniformsList;\r\n var uniformBuffersList = null;\r\n if (uniformsListOrOptions.uniformsNames) {\r\n var options = uniformsListOrOptions;\r\n uniformsList = options.uniformsNames;\r\n uniformBuffersList = options.uniformBuffersNames;\r\n samplersList = options.samplers;\r\n defines = options.defines;\r\n maxSimultaneousLights = options.maxSimultaneousLights || 0;\r\n }\r\n else {\r\n uniformsList = uniformsListOrOptions;\r\n if (!samplersList) {\r\n samplersList = [];\r\n }\r\n }\r\n for (var lightIndex = 0; lightIndex < maxSimultaneousLights; lightIndex++) {\r\n if (!defines[\"LIGHT\" + lightIndex]) {\r\n break;\r\n }\r\n this.PrepareUniformsAndSamplersForLight(lightIndex, uniformsList, samplersList, defines[\"PROJECTEDLIGHTTEXTURE\" + lightIndex], uniformBuffersList);\r\n }\r\n if (defines[\"NUM_MORPH_INFLUENCERS\"]) {\r\n uniformsList.push(\"morphTargetInfluences\");\r\n }\r\n };\r\n /**\r\n * This helps decreasing rank by rank the shadow quality (0 being the highest rank and quality)\r\n * @param defines The defines to update while falling back\r\n * @param fallbacks The authorized effect fallbacks\r\n * @param maxSimultaneousLights The maximum number of lights allowed\r\n * @param rank the current rank of the Effect\r\n * @returns The newly affected rank\r\n */\r\n MaterialHelper.HandleFallbacksForShadows = function (defines, fallbacks, maxSimultaneousLights, rank) {\r\n if (maxSimultaneousLights === void 0) { maxSimultaneousLights = 4; }\r\n if (rank === void 0) { rank = 0; }\r\n var lightFallbackRank = 0;\r\n for (var lightIndex = 0; lightIndex < maxSimultaneousLights; lightIndex++) {\r\n if (!defines[\"LIGHT\" + lightIndex]) {\r\n break;\r\n }\r\n if (lightIndex > 0) {\r\n lightFallbackRank = rank + lightIndex;\r\n fallbacks.addFallback(lightFallbackRank, \"LIGHT\" + lightIndex);\r\n }\r\n if (!defines[\"SHADOWS\"]) {\r\n if (defines[\"SHADOW\" + lightIndex]) {\r\n fallbacks.addFallback(rank, \"SHADOW\" + lightIndex);\r\n }\r\n if (defines[\"SHADOWPCF\" + lightIndex]) {\r\n fallbacks.addFallback(rank, \"SHADOWPCF\" + lightIndex);\r\n }\r\n if (defines[\"SHADOWPCSS\" + lightIndex]) {\r\n fallbacks.addFallback(rank, \"SHADOWPCSS\" + lightIndex);\r\n }\r\n if (defines[\"SHADOWPOISSON\" + lightIndex]) {\r\n fallbacks.addFallback(rank, \"SHADOWPOISSON\" + lightIndex);\r\n }\r\n if (defines[\"SHADOWESM\" + lightIndex]) {\r\n fallbacks.addFallback(rank, \"SHADOWESM\" + lightIndex);\r\n }\r\n if (defines[\"SHADOWCLOSEESM\" + lightIndex]) {\r\n fallbacks.addFallback(rank, \"SHADOWCLOSEESM\" + lightIndex);\r\n }\r\n }\r\n }\r\n return lightFallbackRank++;\r\n };\r\n /**\r\n * Prepares the list of attributes required for morph targets according to the effect defines.\r\n * @param attribs The current list of supported attribs\r\n * @param mesh The mesh to prepare the morph targets attributes for\r\n * @param influencers The number of influencers\r\n */\r\n MaterialHelper.PrepareAttributesForMorphTargetsInfluencers = function (attribs, mesh, influencers) {\r\n this._TmpMorphInfluencers.NUM_MORPH_INFLUENCERS = influencers;\r\n this.PrepareAttributesForMorphTargets(attribs, mesh, this._TmpMorphInfluencers);\r\n };\r\n /**\r\n * Prepares the list of attributes required for morph targets according to the effect defines.\r\n * @param attribs The current list of supported attribs\r\n * @param mesh The mesh to prepare the morph targets attributes for\r\n * @param defines The current Defines of the effect\r\n */\r\n MaterialHelper.PrepareAttributesForMorphTargets = function (attribs, mesh, defines) {\r\n var influencers = defines[\"NUM_MORPH_INFLUENCERS\"];\r\n if (influencers > 0 && EngineStore.LastCreatedEngine) {\r\n var maxAttributesCount = EngineStore.LastCreatedEngine.getCaps().maxVertexAttribs;\r\n var manager = mesh.morphTargetManager;\r\n var normal = manager && manager.supportsNormals && defines[\"NORMAL\"];\r\n var tangent = manager && manager.supportsTangents && defines[\"TANGENT\"];\r\n var uv = manager && manager.supportsUVs && defines[\"UV1\"];\r\n for (var index = 0; index < influencers; index++) {\r\n attribs.push(VertexBuffer.PositionKind + index);\r\n if (normal) {\r\n attribs.push(VertexBuffer.NormalKind + index);\r\n }\r\n if (tangent) {\r\n attribs.push(VertexBuffer.TangentKind + index);\r\n }\r\n if (uv) {\r\n attribs.push(VertexBuffer.UVKind + \"_\" + index);\r\n }\r\n if (attribs.length > maxAttributesCount) {\r\n Logger.Error(\"Cannot add more vertex attributes for mesh \" + mesh.name);\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Prepares the list of attributes required for bones according to the effect defines.\r\n * @param attribs The current list of supported attribs\r\n * @param mesh The mesh to prepare the bones attributes for\r\n * @param defines The current Defines of the effect\r\n * @param fallbacks The current efffect fallback strategy\r\n */\r\n MaterialHelper.PrepareAttributesForBones = function (attribs, mesh, defines, fallbacks) {\r\n if (defines[\"NUM_BONE_INFLUENCERS\"] > 0) {\r\n fallbacks.addCPUSkinningFallback(0, mesh);\r\n attribs.push(VertexBuffer.MatricesIndicesKind);\r\n attribs.push(VertexBuffer.MatricesWeightsKind);\r\n if (defines[\"NUM_BONE_INFLUENCERS\"] > 4) {\r\n attribs.push(VertexBuffer.MatricesIndicesExtraKind);\r\n attribs.push(VertexBuffer.MatricesWeightsExtraKind);\r\n }\r\n }\r\n };\r\n /**\r\n * Check and prepare the list of attributes required for instances according to the effect defines.\r\n * @param attribs The current list of supported attribs\r\n * @param defines The current MaterialDefines of the effect\r\n */\r\n MaterialHelper.PrepareAttributesForInstances = function (attribs, defines) {\r\n if (defines[\"INSTANCES\"] || defines[\"THIN_INSTANCES\"]) {\r\n this.PushAttributesForInstances(attribs);\r\n }\r\n };\r\n /**\r\n * Add the list of attributes required for instances to the attribs array.\r\n * @param attribs The current list of supported attribs\r\n */\r\n MaterialHelper.PushAttributesForInstances = function (attribs) {\r\n attribs.push(\"world0\");\r\n attribs.push(\"world1\");\r\n attribs.push(\"world2\");\r\n attribs.push(\"world3\");\r\n };\r\n /**\r\n * Binds the light information to the effect.\r\n * @param light The light containing the generator\r\n * @param effect The effect we are binding the data to\r\n * @param lightIndex The light index in the effect used to render\r\n */\r\n MaterialHelper.BindLightProperties = function (light, effect, lightIndex) {\r\n light.transferToEffect(effect, lightIndex + \"\");\r\n };\r\n /**\r\n * Binds the lights information from the scene to the effect for the given mesh.\r\n * @param light Light to bind\r\n * @param lightIndex Light index\r\n * @param scene The scene where the light belongs to\r\n * @param effect The effect we are binding the data to\r\n * @param useSpecular Defines if specular is supported\r\n * @param rebuildInParallel Specifies whether the shader is rebuilding in parallel\r\n */\r\n MaterialHelper.BindLight = function (light, lightIndex, scene, effect, useSpecular, rebuildInParallel) {\r\n if (rebuildInParallel === void 0) { rebuildInParallel = false; }\r\n light._bindLight(lightIndex, scene, effect, useSpecular, rebuildInParallel);\r\n };\r\n /**\r\n * Binds the lights information from the scene to the effect for the given mesh.\r\n * @param scene The scene the lights belongs to\r\n * @param mesh The mesh we are binding the information to render\r\n * @param effect The effect we are binding the data to\r\n * @param defines The generated defines for the effect\r\n * @param maxSimultaneousLights The maximum number of light that can be bound to the effect\r\n * @param rebuildInParallel Specifies whether the shader is rebuilding in parallel\r\n */\r\n MaterialHelper.BindLights = function (scene, mesh, effect, defines, maxSimultaneousLights, rebuildInParallel) {\r\n if (maxSimultaneousLights === void 0) { maxSimultaneousLights = 4; }\r\n if (rebuildInParallel === void 0) { rebuildInParallel = false; }\r\n var len = Math.min(mesh.lightSources.length, maxSimultaneousLights);\r\n for (var i = 0; i < len; i++) {\r\n var light = mesh.lightSources[i];\r\n this.BindLight(light, i, scene, effect, typeof defines === \"boolean\" ? defines : defines[\"SPECULARTERM\"], rebuildInParallel);\r\n }\r\n };\r\n /**\r\n * Binds the fog information from the scene to the effect for the given mesh.\r\n * @param scene The scene the lights belongs to\r\n * @param mesh The mesh we are binding the information to render\r\n * @param effect The effect we are binding the data to\r\n * @param linearSpace Defines if the fog effect is applied in linear space\r\n */\r\n MaterialHelper.BindFogParameters = function (scene, mesh, effect, linearSpace) {\r\n if (linearSpace === void 0) { linearSpace = false; }\r\n if (scene.fogEnabled && mesh.applyFog && scene.fogMode !== Scene.FOGMODE_NONE) {\r\n effect.setFloat4(\"vFogInfos\", scene.fogMode, scene.fogStart, scene.fogEnd, scene.fogDensity);\r\n // Convert fog color to linear space if used in a linear space computed shader.\r\n if (linearSpace) {\r\n scene.fogColor.toLinearSpaceToRef(this._tempFogColor);\r\n effect.setColor3(\"vFogColor\", this._tempFogColor);\r\n }\r\n else {\r\n effect.setColor3(\"vFogColor\", scene.fogColor);\r\n }\r\n }\r\n };\r\n /**\r\n * Binds the bones information from the mesh to the effect.\r\n * @param mesh The mesh we are binding the information to render\r\n * @param effect The effect we are binding the data to\r\n * @param prePassConfiguration Configuration for the prepass, in case prepass is activated\r\n */\r\n MaterialHelper.BindBonesParameters = function (mesh, effect, prePassConfiguration) {\r\n if (!effect || !mesh) {\r\n return;\r\n }\r\n if (mesh.computeBonesUsingShaders && effect._bonesComputationForcedToCPU) {\r\n mesh.computeBonesUsingShaders = false;\r\n }\r\n if (mesh.useBones && mesh.computeBonesUsingShaders && mesh.skeleton) {\r\n var skeleton = mesh.skeleton;\r\n if (skeleton.isUsingTextureForMatrices && effect.getUniformIndex(\"boneTextureWidth\") > -1) {\r\n var boneTexture = skeleton.getTransformMatrixTexture(mesh);\r\n effect.setTexture(\"boneSampler\", boneTexture);\r\n effect.setFloat(\"boneTextureWidth\", 4.0 * (skeleton.bones.length + 1));\r\n }\r\n else {\r\n var matrices = skeleton.getTransformMatrices(mesh);\r\n if (matrices) {\r\n effect.setMatrices(\"mBones\", matrices);\r\n if (prePassConfiguration && mesh.getScene().prePassRenderer && mesh.getScene().prePassRenderer.getIndex(2)) {\r\n if (prePassConfiguration.previousBones[mesh.uniqueId]) {\r\n effect.setMatrices(\"mPreviousBones\", prePassConfiguration.previousBones[mesh.uniqueId]);\r\n }\r\n MaterialHelper._CopyBonesTransformationMatrices(matrices, prePassConfiguration.previousBones[mesh.uniqueId]);\r\n }\r\n }\r\n }\r\n }\r\n };\r\n // Copies the bones transformation matrices into the target array and returns the target's reference\r\n MaterialHelper._CopyBonesTransformationMatrices = function (source, target) {\r\n target.set(source);\r\n return target;\r\n };\r\n /**\r\n * Binds the morph targets information from the mesh to the effect.\r\n * @param abstractMesh The mesh we are binding the information to render\r\n * @param effect The effect we are binding the data to\r\n */\r\n MaterialHelper.BindMorphTargetParameters = function (abstractMesh, effect) {\r\n var manager = abstractMesh.morphTargetManager;\r\n if (!abstractMesh || !manager) {\r\n return;\r\n }\r\n effect.setFloatArray(\"morphTargetInfluences\", manager.influences);\r\n };\r\n /**\r\n * Binds the logarithmic depth information from the scene to the effect for the given defines.\r\n * @param defines The generated defines used in the effect\r\n * @param effect The effect we are binding the data to\r\n * @param scene The scene we are willing to render with logarithmic scale for\r\n */\r\n MaterialHelper.BindLogDepth = function (defines, effect, scene) {\r\n if (defines[\"LOGARITHMICDEPTH\"]) {\r\n effect.setFloat(\"logarithmicDepthConstant\", 2.0 / (Math.log(scene.activeCamera.maxZ + 1.0) / Math.LN2));\r\n }\r\n };\r\n /**\r\n * Binds the clip plane information from the scene to the effect.\r\n * @param scene The scene the clip plane information are extracted from\r\n * @param effect The effect we are binding the data to\r\n */\r\n MaterialHelper.BindClipPlane = function (effect, scene) {\r\n ThinMaterialHelper.BindClipPlane(effect, scene);\r\n };\r\n MaterialHelper._TmpMorphInfluencers = { \"NUM_MORPH_INFLUENCERS\": 0 };\r\n MaterialHelper._tempFogColor = Color3.Black();\r\n return MaterialHelper;\r\n}());\r\nexport { MaterialHelper };\r\n//# sourceMappingURL=materialHelper.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, SerializationHelper, serializeAsTexture } from \"../../Misc/decorators\";\r\nimport { Observable } from \"../../Misc/observable\";\r\nimport { Matrix } from \"../../Maths/math.vector\";\r\nimport { EngineStore } from \"../../Engines/engineStore\";\r\nimport { GUID } from '../../Misc/guid';\r\nimport \"../../Misc/fileTools\";\r\nimport { ThinTexture } from './thinTexture';\r\n/**\r\n * Base class of all the textures in babylon.\r\n * It groups all the common properties the materials, post process, lights... might need\r\n * in order to make a correct use of the texture.\r\n */\r\nvar BaseTexture = /** @class */ (function (_super) {\r\n __extends(BaseTexture, _super);\r\n /**\r\n * Instantiates a new BaseTexture.\r\n * Base class of all the textures in babylon.\r\n * It groups all the common properties the materials, post process, lights... might need\r\n * in order to make a correct use of the texture.\r\n * @param sceneOrEngine Define the scene or engine the texture blongs to\r\n */\r\n function BaseTexture(sceneOrEngine) {\r\n var _this = _super.call(this, null) || this;\r\n /**\r\n * Gets or sets an object used to store user defined information.\r\n */\r\n _this.metadata = null;\r\n /**\r\n * For internal use only. Please do not use.\r\n */\r\n _this.reservedDataStore = null;\r\n _this._hasAlpha = false;\r\n /**\r\n * Defines if the alpha value should be determined via the rgb values.\r\n * If true the luminance of the pixel might be used to find the corresponding alpha value.\r\n */\r\n _this.getAlphaFromRGB = false;\r\n /**\r\n * Intensity or strength of the texture.\r\n * It is commonly used by materials to fine tune the intensity of the texture\r\n */\r\n _this.level = 1;\r\n /**\r\n * Define the UV chanel to use starting from 0 and defaulting to 0.\r\n * This is part of the texture as textures usually maps to one uv set.\r\n */\r\n _this.coordinatesIndex = 0;\r\n _this._coordinatesMode = 0;\r\n /**\r\n * | Value | Type | Description |\r\n * | ----- | ------------------ | ----------- |\r\n * | 0 | CLAMP_ADDRESSMODE | |\r\n * | 1 | WRAP_ADDRESSMODE | |\r\n * | 2 | MIRROR_ADDRESSMODE | |\r\n */\r\n _this.wrapR = 1;\r\n /**\r\n * With compliant hardware and browser (supporting anisotropic filtering)\r\n * this defines the level of anisotropic filtering in the texture.\r\n * The higher the better but the slower. This defaults to 4 as it seems to be the best tradeoff.\r\n */\r\n _this.anisotropicFilteringLevel = BaseTexture.DEFAULT_ANISOTROPIC_FILTERING_LEVEL;\r\n _this._isCube = false;\r\n _this._gammaSpace = true;\r\n /**\r\n * Is Z inverted in the texture (useful in a cube texture).\r\n */\r\n _this.invertZ = false;\r\n /**\r\n * @hidden\r\n */\r\n _this.lodLevelInAlpha = false;\r\n /**\r\n * Define if the texture is a render target.\r\n */\r\n _this.isRenderTarget = false;\r\n /** @hidden */\r\n _this._prefiltered = false;\r\n /**\r\n * Define the list of animation attached to the texture.\r\n */\r\n _this.animations = new Array();\r\n /**\r\n * An event triggered when the texture is disposed.\r\n */\r\n _this.onDisposeObservable = new Observable();\r\n _this._onDisposeObserver = null;\r\n _this._scene = null;\r\n /** @hidden */\r\n _this._texture = null;\r\n _this._uid = null;\r\n if (sceneOrEngine) {\r\n if (BaseTexture._isScene(sceneOrEngine)) {\r\n _this._scene = sceneOrEngine;\r\n }\r\n else {\r\n _this._engine = sceneOrEngine;\r\n }\r\n }\r\n else {\r\n _this._scene = EngineStore.LastCreatedScene;\r\n }\r\n if (_this._scene) {\r\n _this.uniqueId = _this._scene.getUniqueId();\r\n _this._scene.addTexture(_this);\r\n _this._engine = _this._scene.getEngine();\r\n }\r\n _this._uid = null;\r\n return _this;\r\n }\r\n Object.defineProperty(BaseTexture.prototype, \"hasAlpha\", {\r\n get: function () {\r\n return this._hasAlpha;\r\n },\r\n /**\r\n * Define if the texture is having a usable alpha value (can be use for transparency or glossiness for instance).\r\n */\r\n set: function (value) {\r\n if (this._hasAlpha === value) {\r\n return;\r\n }\r\n this._hasAlpha = value;\r\n if (this._scene) {\r\n this._scene.markAllMaterialsAsDirty(1 | 16);\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"coordinatesMode\", {\r\n get: function () {\r\n return this._coordinatesMode;\r\n },\r\n /**\r\n * How a texture is mapped.\r\n *\r\n * | Value | Type | Description |\r\n * | ----- | ----------------------------------- | ----------- |\r\n * | 0 | EXPLICIT_MODE | |\r\n * | 1 | SPHERICAL_MODE | |\r\n * | 2 | PLANAR_MODE | |\r\n * | 3 | CUBIC_MODE | |\r\n * | 4 | PROJECTION_MODE | |\r\n * | 5 | SKYBOX_MODE | |\r\n * | 6 | INVCUBIC_MODE | |\r\n * | 7 | EQUIRECTANGULAR_MODE | |\r\n * | 8 | FIXED_EQUIRECTANGULAR_MODE | |\r\n * | 9 | FIXED_EQUIRECTANGULAR_MIRRORED_MODE | |\r\n */\r\n set: function (value) {\r\n if (this._coordinatesMode === value) {\r\n return;\r\n }\r\n this._coordinatesMode = value;\r\n if (this._scene) {\r\n this._scene.markAllMaterialsAsDirty(1);\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"wrapU\", {\r\n /**\r\n * | Value | Type | Description |\r\n * | ----- | ------------------ | ----------- |\r\n * | 0 | CLAMP_ADDRESSMODE | |\r\n * | 1 | WRAP_ADDRESSMODE | |\r\n * | 2 | MIRROR_ADDRESSMODE | |\r\n */\r\n get: function () {\r\n return this._wrapU;\r\n },\r\n set: function (value) {\r\n this._wrapU = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"wrapV\", {\r\n /**\r\n * | Value | Type | Description |\r\n * | ----- | ------------------ | ----------- |\r\n * | 0 | CLAMP_ADDRESSMODE | |\r\n * | 1 | WRAP_ADDRESSMODE | |\r\n * | 2 | MIRROR_ADDRESSMODE | |\r\n */\r\n get: function () {\r\n return this._wrapV;\r\n },\r\n set: function (value) {\r\n this._wrapV = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"isCube\", {\r\n /**\r\n * Define if the texture is a cube texture or if false a 2d texture.\r\n */\r\n get: function () {\r\n if (!this._texture) {\r\n return this._isCube;\r\n }\r\n return this._texture.isCube;\r\n },\r\n set: function (value) {\r\n if (!this._texture) {\r\n this._isCube = value;\r\n }\r\n else {\r\n this._texture.isCube = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"is3D\", {\r\n /**\r\n * Define if the texture is a 3d texture (webgl 2) or if false a 2d texture.\r\n */\r\n get: function () {\r\n if (!this._texture) {\r\n return false;\r\n }\r\n return this._texture.is3D;\r\n },\r\n set: function (value) {\r\n if (!this._texture) {\r\n return;\r\n }\r\n this._texture.is3D = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"is2DArray\", {\r\n /**\r\n * Define if the texture is a 2d array texture (webgl 2) or if false a 2d texture.\r\n */\r\n get: function () {\r\n if (!this._texture) {\r\n return false;\r\n }\r\n return this._texture.is2DArray;\r\n },\r\n set: function (value) {\r\n if (!this._texture) {\r\n return;\r\n }\r\n this._texture.is2DArray = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"gammaSpace\", {\r\n /**\r\n * Define if the texture contains data in gamma space (most of the png/jpg aside bump).\r\n * HDR texture are usually stored in linear space.\r\n * This only impacts the PBR and Background materials\r\n */\r\n get: function () {\r\n if (!this._texture) {\r\n return this._gammaSpace;\r\n }\r\n else {\r\n if (this._texture._gammaSpace === null) {\r\n this._texture._gammaSpace = this._gammaSpace;\r\n }\r\n }\r\n return this._texture._gammaSpace;\r\n },\r\n set: function (gamma) {\r\n if (!this._texture) {\r\n if (this._gammaSpace === gamma) {\r\n return;\r\n }\r\n this._gammaSpace = gamma;\r\n }\r\n else {\r\n if (this._texture._gammaSpace === gamma) {\r\n return;\r\n }\r\n this._texture._gammaSpace = gamma;\r\n }\r\n this._markAllSubMeshesAsTexturesDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"isRGBD\", {\r\n /**\r\n * Gets or sets whether or not the texture contains RGBD data.\r\n */\r\n get: function () {\r\n return this._texture != null && this._texture._isRGBD;\r\n },\r\n set: function (value) {\r\n if (this._texture) {\r\n this._texture._isRGBD = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"noMipmap\", {\r\n /**\r\n * Are mip maps generated for this texture or not.\r\n */\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"lodGenerationOffset\", {\r\n /**\r\n * With prefiltered texture, defined the offset used during the prefiltering steps.\r\n */\r\n get: function () {\r\n if (this._texture) {\r\n return this._texture._lodGenerationOffset;\r\n }\r\n return 0.0;\r\n },\r\n set: function (value) {\r\n if (this._texture) {\r\n this._texture._lodGenerationOffset = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"lodGenerationScale\", {\r\n /**\r\n * With prefiltered texture, defined the scale used during the prefiltering steps.\r\n */\r\n get: function () {\r\n if (this._texture) {\r\n return this._texture._lodGenerationScale;\r\n }\r\n return 0.0;\r\n },\r\n set: function (value) {\r\n if (this._texture) {\r\n this._texture._lodGenerationScale = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"linearSpecularLOD\", {\r\n /**\r\n * With prefiltered texture, defined if the specular generation is based on a linear ramp.\r\n * By default we are using a log2 of the linear roughness helping to keep a better resolution for\r\n * average roughness values.\r\n */\r\n get: function () {\r\n if (this._texture) {\r\n return this._texture._linearSpecularLOD;\r\n }\r\n return false;\r\n },\r\n set: function (value) {\r\n if (this._texture) {\r\n this._texture._linearSpecularLOD = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"irradianceTexture\", {\r\n /**\r\n * In case a better definition than spherical harmonics is required for the diffuse part of the environment.\r\n * You can set the irradiance texture to rely on a texture instead of the spherical approach.\r\n * This texture need to have the same characteristics than its parent (Cube vs 2d, coordinates mode, Gamma/Linear, RGBD).\r\n */\r\n get: function () {\r\n if (this._texture) {\r\n return this._texture._irradianceTexture;\r\n }\r\n return null;\r\n },\r\n set: function (value) {\r\n if (this._texture) {\r\n this._texture._irradianceTexture = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"uid\", {\r\n /**\r\n * Define the unique id of the texture in the scene.\r\n */\r\n get: function () {\r\n if (!this._uid) {\r\n this._uid = GUID.RandomId();\r\n }\r\n return this._uid;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Return a string representation of the texture.\r\n * @returns the texture as a string\r\n */\r\n BaseTexture.prototype.toString = function () {\r\n return this.name;\r\n };\r\n /**\r\n * Get the class name of the texture.\r\n * @returns \"BaseTexture\"\r\n */\r\n BaseTexture.prototype.getClassName = function () {\r\n return \"BaseTexture\";\r\n };\r\n Object.defineProperty(BaseTexture.prototype, \"onDispose\", {\r\n /**\r\n * Callback triggered when the texture has been disposed.\r\n * Kept for back compatibility, you can use the onDisposeObservable instead.\r\n */\r\n set: function (callback) {\r\n if (this._onDisposeObserver) {\r\n this.onDisposeObservable.remove(this._onDisposeObserver);\r\n }\r\n this._onDisposeObserver = this.onDisposeObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"isBlocking\", {\r\n /**\r\n * Define if the texture is preventinga material to render or not.\r\n * If not and the texture is not ready, the engine will use a default black texture instead.\r\n */\r\n get: function () {\r\n return true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Get the scene the texture belongs to.\r\n * @returns the scene or null if undefined\r\n */\r\n BaseTexture.prototype.getScene = function () {\r\n return this._scene;\r\n };\r\n /** @hidden */\r\n BaseTexture.prototype._getEngine = function () {\r\n return this._engine;\r\n };\r\n /**\r\n * Checks if the texture has the same transform matrix than another texture\r\n * @param texture texture to check against\r\n * @returns true if the transforms are the same, else false\r\n */\r\n BaseTexture.prototype.checkTransformsAreIdentical = function (texture) {\r\n return texture !== null;\r\n };\r\n /**\r\n * Get the texture transform matrix used to offset tile the texture for istance.\r\n * @returns the transformation matrix\r\n */\r\n BaseTexture.prototype.getTextureMatrix = function () {\r\n return Matrix.IdentityReadOnly;\r\n };\r\n /**\r\n * Get the texture reflection matrix used to rotate/transform the reflection.\r\n * @returns the reflection matrix\r\n */\r\n BaseTexture.prototype.getReflectionTextureMatrix = function () {\r\n return Matrix.IdentityReadOnly;\r\n };\r\n /**\r\n * Get if the texture is ready to be consumed (either it is ready or it is not blocking)\r\n * @returns true if ready or not blocking\r\n */\r\n BaseTexture.prototype.isReadyOrNotBlocking = function () {\r\n return !this.isBlocking || this.isReady();\r\n };\r\n /**\r\n * Scales the texture if is `canRescale()`\r\n * @param ratio the resize factor we want to use to rescale\r\n */\r\n BaseTexture.prototype.scale = function (ratio) {\r\n };\r\n Object.defineProperty(BaseTexture.prototype, \"canRescale\", {\r\n /**\r\n * Get if the texture can rescale.\r\n */\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n BaseTexture.prototype._getFromCache = function (url, noMipmap, sampling, invertY) {\r\n var engine = this._getEngine();\r\n if (!engine) {\r\n return null;\r\n }\r\n var texturesCache = engine.getLoadedTexturesCache();\r\n for (var index = 0; index < texturesCache.length; index++) {\r\n var texturesCacheEntry = texturesCache[index];\r\n if (invertY === undefined || invertY === texturesCacheEntry.invertY) {\r\n if (texturesCacheEntry.url === url && texturesCacheEntry.generateMipMaps === !noMipmap) {\r\n if (!sampling || sampling === texturesCacheEntry.samplingMode) {\r\n texturesCacheEntry.incrementReferences();\r\n return texturesCacheEntry;\r\n }\r\n }\r\n }\r\n }\r\n return null;\r\n };\r\n /** @hidden */\r\n BaseTexture.prototype._rebuild = function () {\r\n };\r\n /**\r\n * Clones the texture.\r\n * @returns the cloned texture\r\n */\r\n BaseTexture.prototype.clone = function () {\r\n return null;\r\n };\r\n Object.defineProperty(BaseTexture.prototype, \"textureType\", {\r\n /**\r\n * Get the texture underlying type (INT, FLOAT...)\r\n */\r\n get: function () {\r\n if (!this._texture) {\r\n return 0;\r\n }\r\n return (this._texture.type !== undefined) ? this._texture.type : 0;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"textureFormat\", {\r\n /**\r\n * Get the texture underlying format (RGB, RGBA...)\r\n */\r\n get: function () {\r\n if (!this._texture) {\r\n return 5;\r\n }\r\n return (this._texture.format !== undefined) ? this._texture.format : 5;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Indicates that textures need to be re-calculated for all materials\r\n */\r\n BaseTexture.prototype._markAllSubMeshesAsTexturesDirty = function () {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n scene.markAllMaterialsAsDirty(1);\r\n };\r\n /**\r\n * Reads the pixels stored in the webgl texture and returns them as an ArrayBuffer.\r\n * This will returns an RGBA array buffer containing either in values (0-255) or\r\n * float values (0-1) depending of the underlying buffer type.\r\n * @param faceIndex defines the face of the texture to read (in case of cube texture)\r\n * @param level defines the LOD level of the texture to read (in case of Mip Maps)\r\n * @param buffer defines a user defined buffer to fill with data (can be null)\r\n * @returns The Array buffer containing the pixels data.\r\n */\r\n BaseTexture.prototype.readPixels = function (faceIndex, level, buffer) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (level === void 0) { level = 0; }\r\n if (buffer === void 0) { buffer = null; }\r\n if (!this._texture) {\r\n return null;\r\n }\r\n var size = this.getSize();\r\n var width = size.width;\r\n var height = size.height;\r\n var engine = this._getEngine();\r\n if (!engine) {\r\n return null;\r\n }\r\n if (level != 0) {\r\n width = width / Math.pow(2, level);\r\n height = height / Math.pow(2, level);\r\n width = Math.round(width);\r\n height = Math.round(height);\r\n }\r\n try {\r\n if (this._texture.isCube) {\r\n return engine._readTexturePixels(this._texture, width, height, faceIndex, level, buffer);\r\n }\r\n return engine._readTexturePixels(this._texture, width, height, -1, level, buffer);\r\n }\r\n catch (e) {\r\n return null;\r\n }\r\n };\r\n Object.defineProperty(BaseTexture.prototype, \"_lodTextureHigh\", {\r\n /** @hidden */\r\n get: function () {\r\n if (this._texture) {\r\n return this._texture._lodTextureHigh;\r\n }\r\n return null;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"_lodTextureMid\", {\r\n /** @hidden */\r\n get: function () {\r\n if (this._texture) {\r\n return this._texture._lodTextureMid;\r\n }\r\n return null;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseTexture.prototype, \"_lodTextureLow\", {\r\n /** @hidden */\r\n get: function () {\r\n if (this._texture) {\r\n return this._texture._lodTextureLow;\r\n }\r\n return null;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Dispose the texture and release its associated resources.\r\n */\r\n BaseTexture.prototype.dispose = function () {\r\n if (this._scene) {\r\n // Animations\r\n if (this._scene.stopAnimation) {\r\n this._scene.stopAnimation(this);\r\n }\r\n // Remove from scene\r\n this._scene._removePendingData(this);\r\n var index = this._scene.textures.indexOf(this);\r\n if (index >= 0) {\r\n this._scene.textures.splice(index, 1);\r\n }\r\n this._scene.onTextureRemovedObservable.notifyObservers(this);\r\n this._scene = null;\r\n }\r\n // Callback\r\n this.onDisposeObservable.notifyObservers(this);\r\n this.onDisposeObservable.clear();\r\n _super.prototype.dispose.call(this);\r\n };\r\n /**\r\n * Serialize the texture into a JSON representation that can be parsed later on.\r\n * @returns the JSON representation of the texture\r\n */\r\n BaseTexture.prototype.serialize = function () {\r\n if (!this.name) {\r\n return null;\r\n }\r\n var serializationObject = SerializationHelper.Serialize(this);\r\n // Animations\r\n SerializationHelper.AppendSerializedAnimations(this, serializationObject);\r\n return serializationObject;\r\n };\r\n /**\r\n * Helper function to be called back once a list of texture contains only ready textures.\r\n * @param textures Define the list of textures to wait for\r\n * @param callback Define the callback triggered once the entire list will be ready\r\n */\r\n BaseTexture.WhenAllReady = function (textures, callback) {\r\n var numRemaining = textures.length;\r\n if (numRemaining === 0) {\r\n callback();\r\n return;\r\n }\r\n for (var i = 0; i < textures.length; i++) {\r\n var texture = textures[i];\r\n if (texture.isReady()) {\r\n if (--numRemaining === 0) {\r\n callback();\r\n }\r\n }\r\n else {\r\n var onLoadObservable = texture.onLoadObservable;\r\n if (onLoadObservable) {\r\n onLoadObservable.addOnce(function () {\r\n if (--numRemaining === 0) {\r\n callback();\r\n }\r\n });\r\n }\r\n }\r\n }\r\n };\r\n BaseTexture._isScene = function (sceneOrEngine) {\r\n return sceneOrEngine.getClassName() === \"Scene\";\r\n };\r\n /**\r\n * Default anisotropic filtering level for the application.\r\n * It is set to 4 as a good tradeoff between perf and quality.\r\n */\r\n BaseTexture.DEFAULT_ANISOTROPIC_FILTERING_LEVEL = 4;\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"uniqueId\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"name\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"metadata\", void 0);\r\n __decorate([\r\n serialize(\"hasAlpha\")\r\n ], BaseTexture.prototype, \"_hasAlpha\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"getAlphaFromRGB\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"level\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"coordinatesIndex\", void 0);\r\n __decorate([\r\n serialize(\"coordinatesMode\")\r\n ], BaseTexture.prototype, \"_coordinatesMode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"wrapU\", null);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"wrapV\", null);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"wrapR\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"anisotropicFilteringLevel\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"isCube\", null);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"is3D\", null);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"is2DArray\", null);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"gammaSpace\", null);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"invertZ\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"lodLevelInAlpha\", void 0);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"lodGenerationOffset\", null);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"lodGenerationScale\", null);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"linearSpecularLOD\", null);\r\n __decorate([\r\n serializeAsTexture()\r\n ], BaseTexture.prototype, \"irradianceTexture\", null);\r\n __decorate([\r\n serialize()\r\n ], BaseTexture.prototype, \"isRenderTarget\", void 0);\r\n return BaseTexture;\r\n}(ThinTexture));\r\nexport { BaseTexture };\r\n//# sourceMappingURL=baseTexture.js.map","import { Size } from '../../Maths/math.size';\r\n/**\r\n * Base class of all the textures in babylon.\r\n * It groups all the common properties required to work with Thin Engine.\r\n */\r\nvar ThinTexture = /** @class */ (function () {\r\n /**\r\n * Instantiates a new ThinTexture.\r\n * Base class of all the textures in babylon.\r\n * This can be used as an internal texture wrapper in ThinEngine to benefit from the cache\r\n * @param internalTexture Define the internalTexture to wrap\r\n */\r\n function ThinTexture(internalTexture) {\r\n this._wrapU = 1;\r\n this._wrapV = 1;\r\n /**\r\n * | Value | Type | Description |\r\n * | ----- | ------------------ | ----------- |\r\n * | 0 | CLAMP_ADDRESSMODE | |\r\n * | 1 | WRAP_ADDRESSMODE | |\r\n * | 2 | MIRROR_ADDRESSMODE | |\r\n */\r\n this.wrapR = 1;\r\n /**\r\n * With compliant hardware and browser (supporting anisotropic filtering)\r\n * this defines the level of anisotropic filtering in the texture.\r\n * The higher the better but the slower. This defaults to 4 as it seems to be the best tradeoff.\r\n */\r\n this.anisotropicFilteringLevel = 4;\r\n /**\r\n * Define the current state of the loading sequence when in delayed load mode.\r\n */\r\n this.delayLoadState = 0;\r\n /** @hidden */\r\n this._texture = null;\r\n this._engine = null;\r\n this._cachedSize = Size.Zero();\r\n this._cachedBaseSize = Size.Zero();\r\n this._texture = internalTexture;\r\n if (this._texture) {\r\n this._engine = this._texture.getEngine();\r\n }\r\n }\r\n Object.defineProperty(ThinTexture.prototype, \"wrapU\", {\r\n /**\r\n * | Value | Type | Description |\r\n * | ----- | ------------------ | ----------- |\r\n * | 0 | CLAMP_ADDRESSMODE | |\r\n * | 1 | WRAP_ADDRESSMODE | |\r\n * | 2 | MIRROR_ADDRESSMODE | |\r\n */\r\n get: function () {\r\n return this._wrapU;\r\n },\r\n set: function (value) {\r\n this._wrapU = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinTexture.prototype, \"wrapV\", {\r\n /**\r\n * | Value | Type | Description |\r\n * | ----- | ------------------ | ----------- |\r\n * | 0 | CLAMP_ADDRESSMODE | |\r\n * | 1 | WRAP_ADDRESSMODE | |\r\n * | 2 | MIRROR_ADDRESSMODE | |\r\n */\r\n get: function () {\r\n return this._wrapV;\r\n },\r\n set: function (value) {\r\n this._wrapV = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinTexture.prototype, \"coordinatesMode\", {\r\n /**\r\n * How a texture is mapped.\r\n * Unused in thin texture mode.\r\n */\r\n get: function () {\r\n return 0;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinTexture.prototype, \"isCube\", {\r\n /**\r\n * Define if the texture is a cube texture or if false a 2d texture.\r\n */\r\n get: function () {\r\n if (!this._texture) {\r\n return false;\r\n }\r\n return this._texture.isCube;\r\n },\r\n set: function (value) {\r\n if (!this._texture) {\r\n return;\r\n }\r\n this._texture.isCube = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinTexture.prototype, \"is3D\", {\r\n /**\r\n * Define if the texture is a 3d texture (webgl 2) or if false a 2d texture.\r\n */\r\n get: function () {\r\n if (!this._texture) {\r\n return false;\r\n }\r\n return this._texture.is3D;\r\n },\r\n set: function (value) {\r\n if (!this._texture) {\r\n return;\r\n }\r\n this._texture.is3D = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinTexture.prototype, \"is2DArray\", {\r\n /**\r\n * Define if the texture is a 2d array texture (webgl 2) or if false a 2d texture.\r\n */\r\n get: function () {\r\n if (!this._texture) {\r\n return false;\r\n }\r\n return this._texture.is2DArray;\r\n },\r\n set: function (value) {\r\n if (!this._texture) {\r\n return;\r\n }\r\n this._texture.is2DArray = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Get the class name of the texture.\r\n * @returns \"ThinTexture\"\r\n */\r\n ThinTexture.prototype.getClassName = function () {\r\n return \"ThinTexture\";\r\n };\r\n /**\r\n * Get if the texture is ready to be used (downloaded, converted, mip mapped...).\r\n * @returns true if fully ready\r\n */\r\n ThinTexture.prototype.isReady = function () {\r\n if (this.delayLoadState === 4) {\r\n this.delayLoad();\r\n return false;\r\n }\r\n if (this._texture) {\r\n return this._texture.isReady;\r\n }\r\n return false;\r\n };\r\n /**\r\n * Triggers the load sequence in delayed load mode.\r\n */\r\n ThinTexture.prototype.delayLoad = function () {\r\n };\r\n /**\r\n * Get the underlying lower level texture from Babylon.\r\n * @returns the insternal texture\r\n */\r\n ThinTexture.prototype.getInternalTexture = function () {\r\n return this._texture;\r\n };\r\n /**\r\n * Get the size of the texture.\r\n * @returns the texture size.\r\n */\r\n ThinTexture.prototype.getSize = function () {\r\n if (this._texture) {\r\n if (this._texture.width) {\r\n this._cachedSize.width = this._texture.width;\r\n this._cachedSize.height = this._texture.height;\r\n return this._cachedSize;\r\n }\r\n if (this._texture._size) {\r\n this._cachedSize.width = this._texture._size;\r\n this._cachedSize.height = this._texture._size;\r\n return this._cachedSize;\r\n }\r\n }\r\n return this._cachedSize;\r\n };\r\n /**\r\n * Get the base size of the texture.\r\n * It can be different from the size if the texture has been resized for POT for instance\r\n * @returns the base size\r\n */\r\n ThinTexture.prototype.getBaseSize = function () {\r\n if (!this.isReady() || !this._texture) {\r\n this._cachedBaseSize.width = 0;\r\n this._cachedBaseSize.height = 0;\r\n return this._cachedBaseSize;\r\n }\r\n if (this._texture._size) {\r\n this._cachedBaseSize.width = this._texture._size;\r\n this._cachedBaseSize.height = this._texture._size;\r\n return this._cachedBaseSize;\r\n }\r\n this._cachedBaseSize.width = this._texture.baseWidth;\r\n this._cachedBaseSize.height = this._texture.baseHeight;\r\n return this._cachedBaseSize;\r\n };\r\n /**\r\n * Update the sampling mode of the texture.\r\n * Default is Trilinear mode.\r\n *\r\n * | Value | Type | Description |\r\n * | ----- | ------------------ | ----------- |\r\n * | 1 | NEAREST_SAMPLINGMODE or NEAREST_NEAREST_MIPLINEAR | Nearest is: mag = nearest, min = nearest, mip = linear |\r\n * | 2 | BILINEAR_SAMPLINGMODE or LINEAR_LINEAR_MIPNEAREST | Bilinear is: mag = linear, min = linear, mip = nearest |\r\n * | 3 | TRILINEAR_SAMPLINGMODE or LINEAR_LINEAR_MIPLINEAR | Trilinear is: mag = linear, min = linear, mip = linear |\r\n * | 4 | NEAREST_NEAREST_MIPNEAREST | |\r\n * | 5 | NEAREST_LINEAR_MIPNEAREST | |\r\n * | 6 | NEAREST_LINEAR_MIPLINEAR | |\r\n * | 7 | NEAREST_LINEAR | |\r\n * | 8 | NEAREST_NEAREST | |\r\n * | 9 | LINEAR_NEAREST_MIPNEAREST | |\r\n * | 10 | LINEAR_NEAREST_MIPLINEAR | |\r\n * | 11 | LINEAR_LINEAR | |\r\n * | 12 | LINEAR_NEAREST | |\r\n *\r\n * > _mag_: magnification filter (close to the viewer)\r\n * > _min_: minification filter (far from the viewer)\r\n * > _mip_: filter used between mip map levels\r\n *@param samplingMode Define the new sampling mode of the texture\r\n */\r\n ThinTexture.prototype.updateSamplingMode = function (samplingMode) {\r\n if (this._texture && this._engine) {\r\n this._engine.updateTextureSamplingMode(samplingMode, this._texture);\r\n }\r\n };\r\n /**\r\n * Release and destroy the underlying lower level texture aka internalTexture.\r\n */\r\n ThinTexture.prototype.releaseInternalTexture = function () {\r\n if (this._texture) {\r\n this._texture.dispose();\r\n this._texture = null;\r\n }\r\n };\r\n /**\r\n * Dispose the texture and release its associated resources.\r\n */\r\n ThinTexture.prototype.dispose = function () {\r\n if (this._texture) {\r\n this.releaseInternalTexture();\r\n this._engine = null;\r\n }\r\n };\r\n return ThinTexture;\r\n}());\r\nexport { ThinTexture };\r\n//# sourceMappingURL=thinTexture.js.map","/**\r\n * Class used to host copy specific utilities\r\n */\r\nvar CopyTools = /** @class */ (function () {\r\n function CopyTools() {\r\n }\r\n /**\r\n * Reads the pixels stored in the webgl texture and returns them as a base64 string\r\n * @param texture defines the texture to read pixels from\r\n * @param faceIndex defines the face of the texture to read (in case of cube texture)\r\n * @param level defines the LOD level of the texture to read (in case of Mip Maps)\r\n * @returns The base64 encoded string or null\r\n */\r\n CopyTools.GenerateBase64StringFromTexture = function (texture, faceIndex, level) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (level === void 0) { level = 0; }\r\n var internalTexture = texture.getInternalTexture();\r\n if (!internalTexture) {\r\n return null;\r\n }\r\n var pixels = texture.readPixels(faceIndex, level);\r\n if (!pixels) {\r\n return null;\r\n }\r\n var size = texture.getSize();\r\n var width = size.width;\r\n var height = size.height;\r\n if (pixels instanceof Float32Array) {\r\n var len = pixels.byteLength / pixels.BYTES_PER_ELEMENT;\r\n var npixels = new Uint8Array(len);\r\n while (--len >= 0) {\r\n var val = pixels[len];\r\n if (val < 0) {\r\n val = 0;\r\n }\r\n else if (val > 1) {\r\n val = 1;\r\n }\r\n npixels[len] = val * 255;\r\n }\r\n pixels = npixels;\r\n }\r\n var canvas = document.createElement('canvas');\r\n canvas.width = width;\r\n canvas.height = height;\r\n var ctx = canvas.getContext('2d');\r\n if (!ctx) {\r\n return null;\r\n }\r\n var imageData = ctx.createImageData(width, height);\r\n var castData = imageData.data;\r\n castData.set(pixels);\r\n ctx.putImageData(imageData, 0, 0);\r\n if (internalTexture.invertY) {\r\n var canvas2 = document.createElement('canvas');\r\n canvas2.width = width;\r\n canvas2.height = height;\r\n var ctx2 = canvas2.getContext('2d');\r\n if (!ctx2) {\r\n return null;\r\n }\r\n ctx2.translate(0, height);\r\n ctx2.scale(1, -1);\r\n ctx2.drawImage(canvas, 0, 0);\r\n return canvas2.toDataURL('image/png');\r\n }\r\n return canvas.toDataURL('image/png');\r\n };\r\n return CopyTools;\r\n}());\r\nexport { CopyTools };\r\n//# sourceMappingURL=copyTools.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, SerializationHelper } from \"../../Misc/decorators\";\r\nimport { Observable } from \"../../Misc/observable\";\r\nimport { Matrix, TmpVectors, Vector3 } from \"../../Maths/math.vector\";\r\nimport { BaseTexture } from \"../../Materials/Textures/baseTexture\";\r\nimport { _TypeStore } from '../../Misc/typeStore';\r\nimport { _DevTools } from '../../Misc/devTools';\r\nimport { TimingTools } from '../../Misc/timingTools';\r\nimport { InstantiationTools } from '../../Misc/instantiationTools';\r\nimport { Plane } from '../../Maths/math.plane';\r\nimport { StringTools } from '../../Misc/stringTools';\r\nimport { CopyTools } from '../../Misc/copyTools';\r\n/**\r\n * This represents a texture in babylon. It can be easily loaded from a network, base64 or html input.\r\n * @see https://doc.babylonjs.com/babylon101/materials#texture\r\n */\r\nvar Texture = /** @class */ (function (_super) {\r\n __extends(Texture, _super);\r\n /**\r\n * Instantiates a new texture.\r\n * This represents a texture in babylon. It can be easily loaded from a network, base64 or html input.\r\n * @see https://doc.babylonjs.com/babylon101/materials#texture\r\n * @param url defines the url of the picture to load as a texture\r\n * @param sceneOrEngine defines the scene or engine the texture will belong to\r\n * @param noMipmap defines if the texture will require mip maps or not\r\n * @param invertY defines if the texture needs to be inverted on the y axis during loading\r\n * @param samplingMode defines the sampling mode we want for the texture while fectching from it (Texture.NEAREST_SAMPLINGMODE...)\r\n * @param onLoad defines a callback triggered when the texture has been loaded\r\n * @param onError defines a callback triggered when an error occurred during the loading session\r\n * @param buffer defines the buffer to load the texture from in case the texture is loaded from a buffer representation\r\n * @param deleteBuffer defines if the buffer we are loading the texture from should be deleted after load\r\n * @param format defines the format of the texture we are trying to load (Engine.TEXTUREFORMAT_RGBA...)\r\n * @param mimeType defines an optional mime type information\r\n * @param loaderOptions options to be passed to the loader\r\n */\r\n function Texture(url, sceneOrEngine, noMipmap, invertY, samplingMode, onLoad, onError, buffer, deleteBuffer, format, mimeType, loaderOptions) {\r\n if (noMipmap === void 0) { noMipmap = false; }\r\n if (invertY === void 0) { invertY = true; }\r\n if (samplingMode === void 0) { samplingMode = Texture.TRILINEAR_SAMPLINGMODE; }\r\n if (onLoad === void 0) { onLoad = null; }\r\n if (onError === void 0) { onError = null; }\r\n if (buffer === void 0) { buffer = null; }\r\n if (deleteBuffer === void 0) { deleteBuffer = false; }\r\n var _this = _super.call(this, sceneOrEngine) || this;\r\n /**\r\n * Define the url of the texture.\r\n */\r\n _this.url = null;\r\n /**\r\n * Define an offset on the texture to offset the u coordinates of the UVs\r\n * @see https://doc.babylonjs.com/how_to/more_materials#offsetting\r\n */\r\n _this.uOffset = 0;\r\n /**\r\n * Define an offset on the texture to offset the v coordinates of the UVs\r\n * @see https://doc.babylonjs.com/how_to/more_materials#offsetting\r\n */\r\n _this.vOffset = 0;\r\n /**\r\n * Define an offset on the texture to scale the u coordinates of the UVs\r\n * @see https://doc.babylonjs.com/how_to/more_materials#tiling\r\n */\r\n _this.uScale = 1.0;\r\n /**\r\n * Define an offset on the texture to scale the v coordinates of the UVs\r\n * @see https://doc.babylonjs.com/how_to/more_materials#tiling\r\n */\r\n _this.vScale = 1.0;\r\n /**\r\n * Define an offset on the texture to rotate around the u coordinates of the UVs\r\n * @see https://doc.babylonjs.com/how_to/more_materials\r\n */\r\n _this.uAng = 0;\r\n /**\r\n * Define an offset on the texture to rotate around the v coordinates of the UVs\r\n * @see https://doc.babylonjs.com/how_to/more_materials\r\n */\r\n _this.vAng = 0;\r\n /**\r\n * Define an offset on the texture to rotate around the w coordinates of the UVs (in case of 3d texture)\r\n * @see https://doc.babylonjs.com/how_to/more_materials\r\n */\r\n _this.wAng = 0;\r\n /**\r\n * Defines the center of rotation (U)\r\n */\r\n _this.uRotationCenter = 0.5;\r\n /**\r\n * Defines the center of rotation (V)\r\n */\r\n _this.vRotationCenter = 0.5;\r\n /**\r\n * Defines the center of rotation (W)\r\n */\r\n _this.wRotationCenter = 0.5;\r\n /**\r\n * Sets this property to true to avoid deformations when rotating the texture with non-uniform scaling\r\n */\r\n _this.homogeneousRotationInUVTransform = false;\r\n /**\r\n * List of inspectable custom properties (used by the Inspector)\r\n * @see https://doc.babylonjs.com/how_to/debug_layer#extensibility\r\n */\r\n _this.inspectableCustomProperties = null;\r\n _this._noMipmap = false;\r\n /** @hidden */\r\n _this._invertY = false;\r\n _this._rowGenerationMatrix = null;\r\n _this._cachedTextureMatrix = null;\r\n _this._projectionModeMatrix = null;\r\n _this._t0 = null;\r\n _this._t1 = null;\r\n _this._t2 = null;\r\n _this._cachedUOffset = -1;\r\n _this._cachedVOffset = -1;\r\n _this._cachedUScale = 0;\r\n _this._cachedVScale = 0;\r\n _this._cachedUAng = -1;\r\n _this._cachedVAng = -1;\r\n _this._cachedWAng = -1;\r\n _this._cachedProjectionMatrixId = -1;\r\n _this._cachedURotationCenter = -1;\r\n _this._cachedVRotationCenter = -1;\r\n _this._cachedWRotationCenter = -1;\r\n _this._cachedHomogeneousRotationInUVTransform = false;\r\n _this._cachedCoordinatesMode = -1;\r\n /** @hidden */\r\n _this._initialSamplingMode = Texture.BILINEAR_SAMPLINGMODE;\r\n /** @hidden */\r\n _this._buffer = null;\r\n _this._deleteBuffer = false;\r\n _this._format = null;\r\n _this._delayedOnLoad = null;\r\n _this._delayedOnError = null;\r\n /**\r\n * Observable triggered once the texture has been loaded.\r\n */\r\n _this.onLoadObservable = new Observable();\r\n _this._isBlocking = true;\r\n _this.name = url || \"\";\r\n _this.url = url;\r\n _this._noMipmap = noMipmap;\r\n _this._invertY = invertY;\r\n _this._initialSamplingMode = samplingMode;\r\n _this._buffer = buffer;\r\n _this._deleteBuffer = deleteBuffer;\r\n _this._mimeType = mimeType;\r\n _this._loaderOptions = loaderOptions;\r\n if (format) {\r\n _this._format = format;\r\n }\r\n var scene = _this.getScene();\r\n var engine = _this._getEngine();\r\n if (!engine) {\r\n return _this;\r\n }\r\n engine.onBeforeTextureInitObservable.notifyObservers(_this);\r\n var load = function () {\r\n if (_this._texture) {\r\n if (_this._texture._invertVScale) {\r\n _this.vScale *= -1;\r\n _this.vOffset += 1;\r\n }\r\n // Update texutre to match internal texture's wrapping\r\n if (_this._texture._cachedWrapU !== null) {\r\n _this.wrapU = _this._texture._cachedWrapU;\r\n _this._texture._cachedWrapU = null;\r\n }\r\n if (_this._texture._cachedWrapV !== null) {\r\n _this.wrapV = _this._texture._cachedWrapV;\r\n _this._texture._cachedWrapV = null;\r\n }\r\n if (_this._texture._cachedWrapR !== null) {\r\n _this.wrapR = _this._texture._cachedWrapR;\r\n _this._texture._cachedWrapR = null;\r\n }\r\n }\r\n if (_this.onLoadObservable.hasObservers()) {\r\n _this.onLoadObservable.notifyObservers(_this);\r\n }\r\n if (onLoad) {\r\n onLoad();\r\n }\r\n if (!_this.isBlocking && scene) {\r\n scene.resetCachedMaterial();\r\n }\r\n };\r\n if (!_this.url) {\r\n _this._delayedOnLoad = load;\r\n _this._delayedOnError = onError;\r\n return _this;\r\n }\r\n _this._texture = _this._getFromCache(_this.url, noMipmap, samplingMode, invertY);\r\n if (!_this._texture) {\r\n if (!scene || !scene.useDelayedTextureLoading) {\r\n _this._texture = engine.createTexture(_this.url, noMipmap, invertY, scene, samplingMode, load, onError, _this._buffer, undefined, _this._format, null, mimeType, loaderOptions);\r\n if (deleteBuffer) {\r\n _this._buffer = null;\r\n }\r\n }\r\n else {\r\n _this.delayLoadState = 4;\r\n _this._delayedOnLoad = load;\r\n _this._delayedOnError = onError;\r\n }\r\n }\r\n else {\r\n if (_this._texture.isReady) {\r\n TimingTools.SetImmediate(function () { return load(); });\r\n }\r\n else {\r\n _this._texture.onLoadedObservable.add(load);\r\n }\r\n }\r\n return _this;\r\n }\r\n Object.defineProperty(Texture.prototype, \"noMipmap\", {\r\n /**\r\n * Are mip maps generated for this texture or not.\r\n */\r\n get: function () {\r\n return this._noMipmap;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Texture.prototype, \"mimeType\", {\r\n /** Returns the texture mime type if it was defined by a loader (undefined else) */\r\n get: function () {\r\n return this._mimeType;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Texture.prototype, \"isBlocking\", {\r\n get: function () {\r\n return this._isBlocking;\r\n },\r\n /**\r\n * Is the texture preventing material to render while loading.\r\n * If false, a default texture will be used instead of the loading one during the preparation step.\r\n */\r\n set: function (value) {\r\n this._isBlocking = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Texture.prototype, \"samplingMode\", {\r\n /**\r\n * Get the current sampling mode associated with the texture.\r\n */\r\n get: function () {\r\n if (!this._texture) {\r\n return this._initialSamplingMode;\r\n }\r\n return this._texture.samplingMode;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Texture.prototype, \"invertY\", {\r\n /**\r\n * Gets a boolean indicating if the texture needs to be inverted on the y axis during loading\r\n */\r\n get: function () {\r\n return this._invertY;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Update the url (and optional buffer) of this texture if url was null during construction.\r\n * @param url the url of the texture\r\n * @param buffer the buffer of the texture (defaults to null)\r\n * @param onLoad callback called when the texture is loaded (defaults to null)\r\n */\r\n Texture.prototype.updateURL = function (url, buffer, onLoad) {\r\n if (buffer === void 0) { buffer = null; }\r\n if (this.url) {\r\n this.releaseInternalTexture();\r\n this.getScene().markAllMaterialsAsDirty(1);\r\n }\r\n if (!this.name || StringTools.StartsWith(this.name, \"data:\")) {\r\n this.name = url;\r\n }\r\n this.url = url;\r\n this._buffer = buffer;\r\n this.delayLoadState = 4;\r\n if (onLoad) {\r\n this._delayedOnLoad = onLoad;\r\n }\r\n this.delayLoad();\r\n };\r\n /**\r\n * Finish the loading sequence of a texture flagged as delayed load.\r\n * @hidden\r\n */\r\n Texture.prototype.delayLoad = function () {\r\n if (this.delayLoadState !== 4) {\r\n return;\r\n }\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n this.delayLoadState = 1;\r\n this._texture = this._getFromCache(this.url, this._noMipmap, this.samplingMode, this._invertY);\r\n if (!this._texture) {\r\n this._texture = scene.getEngine().createTexture(this.url, this._noMipmap, this._invertY, scene, this.samplingMode, this._delayedOnLoad, this._delayedOnError, this._buffer, null, this._format, null, this._mimeType, this._loaderOptions);\r\n if (this._deleteBuffer) {\r\n this._buffer = null;\r\n }\r\n }\r\n else {\r\n if (this._delayedOnLoad) {\r\n if (this._texture.isReady) {\r\n TimingTools.SetImmediate(this._delayedOnLoad);\r\n }\r\n else {\r\n this._texture.onLoadedObservable.add(this._delayedOnLoad);\r\n }\r\n }\r\n }\r\n this._delayedOnLoad = null;\r\n this._delayedOnError = null;\r\n };\r\n Texture.prototype._prepareRowForTextureGeneration = function (x, y, z, t) {\r\n x *= this._cachedUScale;\r\n y *= this._cachedVScale;\r\n x -= this.uRotationCenter * this._cachedUScale;\r\n y -= this.vRotationCenter * this._cachedVScale;\r\n z -= this.wRotationCenter;\r\n Vector3.TransformCoordinatesFromFloatsToRef(x, y, z, this._rowGenerationMatrix, t);\r\n t.x += this.uRotationCenter * this._cachedUScale + this._cachedUOffset;\r\n t.y += this.vRotationCenter * this._cachedVScale + this._cachedVOffset;\r\n t.z += this.wRotationCenter;\r\n };\r\n /**\r\n * Checks if the texture has the same transform matrix than another texture\r\n * @param texture texture to check against\r\n * @returns true if the transforms are the same, else false\r\n */\r\n Texture.prototype.checkTransformsAreIdentical = function (texture) {\r\n return texture !== null &&\r\n this.uOffset === texture.uOffset &&\r\n this.vOffset === texture.vOffset &&\r\n this.uScale === texture.uScale &&\r\n this.vScale === texture.vScale &&\r\n this.uAng === texture.uAng &&\r\n this.vAng === texture.vAng &&\r\n this.wAng === texture.wAng;\r\n };\r\n /**\r\n * Get the current texture matrix which includes the requested offsetting, tiling and rotation components.\r\n * @returns the transform matrix of the texture.\r\n */\r\n Texture.prototype.getTextureMatrix = function (uBase) {\r\n var _this = this;\r\n if (uBase === void 0) { uBase = 1; }\r\n if (this.uOffset === this._cachedUOffset &&\r\n this.vOffset === this._cachedVOffset &&\r\n this.uScale * uBase === this._cachedUScale &&\r\n this.vScale === this._cachedVScale &&\r\n this.uAng === this._cachedUAng &&\r\n this.vAng === this._cachedVAng &&\r\n this.wAng === this._cachedWAng &&\r\n this.uRotationCenter === this._cachedURotationCenter &&\r\n this.vRotationCenter === this._cachedVRotationCenter &&\r\n this.wRotationCenter === this._cachedWRotationCenter &&\r\n this.homogeneousRotationInUVTransform === this._cachedHomogeneousRotationInUVTransform) {\r\n return this._cachedTextureMatrix;\r\n }\r\n this._cachedUOffset = this.uOffset;\r\n this._cachedVOffset = this.vOffset;\r\n this._cachedUScale = this.uScale * uBase;\r\n this._cachedVScale = this.vScale;\r\n this._cachedUAng = this.uAng;\r\n this._cachedVAng = this.vAng;\r\n this._cachedWAng = this.wAng;\r\n this._cachedURotationCenter = this.uRotationCenter;\r\n this._cachedVRotationCenter = this.vRotationCenter;\r\n this._cachedWRotationCenter = this.wRotationCenter;\r\n this._cachedHomogeneousRotationInUVTransform = this.homogeneousRotationInUVTransform;\r\n if (!this._cachedTextureMatrix || !this._rowGenerationMatrix) {\r\n this._cachedTextureMatrix = Matrix.Zero();\r\n this._rowGenerationMatrix = new Matrix();\r\n this._t0 = Vector3.Zero();\r\n this._t1 = Vector3.Zero();\r\n this._t2 = Vector3.Zero();\r\n }\r\n Matrix.RotationYawPitchRollToRef(this.vAng, this.uAng, this.wAng, this._rowGenerationMatrix);\r\n if (this.homogeneousRotationInUVTransform) {\r\n Matrix.TranslationToRef(-this._cachedURotationCenter, -this._cachedVRotationCenter, -this._cachedWRotationCenter, TmpVectors.Matrix[0]);\r\n Matrix.TranslationToRef(this._cachedURotationCenter, this._cachedVRotationCenter, this._cachedWRotationCenter, TmpVectors.Matrix[1]);\r\n Matrix.ScalingToRef(this._cachedUScale, this._cachedVScale, 0, TmpVectors.Matrix[2]);\r\n Matrix.TranslationToRef(this._cachedUOffset, this._cachedVOffset, 0, TmpVectors.Matrix[3]);\r\n TmpVectors.Matrix[0].multiplyToRef(this._rowGenerationMatrix, this._cachedTextureMatrix);\r\n this._cachedTextureMatrix.multiplyToRef(TmpVectors.Matrix[1], this._cachedTextureMatrix);\r\n this._cachedTextureMatrix.multiplyToRef(TmpVectors.Matrix[2], this._cachedTextureMatrix);\r\n this._cachedTextureMatrix.multiplyToRef(TmpVectors.Matrix[3], this._cachedTextureMatrix);\r\n // copy the translation row to the 3rd row of the matrix so that we don't need to update the shaders (which expects the translation to be on the 3rd row)\r\n this._cachedTextureMatrix.setRowFromFloats(2, this._cachedTextureMatrix.m[12], this._cachedTextureMatrix.m[13], this._cachedTextureMatrix.m[14], 1);\r\n }\r\n else {\r\n this._prepareRowForTextureGeneration(0, 0, 0, this._t0);\r\n this._prepareRowForTextureGeneration(1.0, 0, 0, this._t1);\r\n this._prepareRowForTextureGeneration(0, 1.0, 0, this._t2);\r\n this._t1.subtractInPlace(this._t0);\r\n this._t2.subtractInPlace(this._t0);\r\n Matrix.FromValuesToRef(this._t1.x, this._t1.y, this._t1.z, 0.0, this._t2.x, this._t2.y, this._t2.z, 0.0, this._t0.x, this._t0.y, this._t0.z, 0.0, 0.0, 0.0, 0.0, 1.0, this._cachedTextureMatrix);\r\n }\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return this._cachedTextureMatrix;\r\n }\r\n scene.markAllMaterialsAsDirty(1, function (mat) {\r\n return mat.hasTexture(_this);\r\n });\r\n return this._cachedTextureMatrix;\r\n };\r\n /**\r\n * Get the current matrix used to apply reflection. This is useful to rotate an environment texture for instance.\r\n * @returns The reflection texture transform\r\n */\r\n Texture.prototype.getReflectionTextureMatrix = function () {\r\n var _this = this;\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return this._cachedTextureMatrix;\r\n }\r\n if (this.uOffset === this._cachedUOffset &&\r\n this.vOffset === this._cachedVOffset &&\r\n this.uScale === this._cachedUScale &&\r\n this.vScale === this._cachedVScale &&\r\n this.coordinatesMode === this._cachedCoordinatesMode) {\r\n if (this.coordinatesMode === Texture.PROJECTION_MODE) {\r\n if (this._cachedProjectionMatrixId === scene.getProjectionMatrix().updateFlag) {\r\n return this._cachedTextureMatrix;\r\n }\r\n }\r\n else {\r\n return this._cachedTextureMatrix;\r\n }\r\n }\r\n if (!this._cachedTextureMatrix) {\r\n this._cachedTextureMatrix = Matrix.Zero();\r\n }\r\n if (!this._projectionModeMatrix) {\r\n this._projectionModeMatrix = Matrix.Zero();\r\n }\r\n this._cachedUOffset = this.uOffset;\r\n this._cachedVOffset = this.vOffset;\r\n this._cachedUScale = this.uScale;\r\n this._cachedVScale = this.vScale;\r\n this._cachedCoordinatesMode = this.coordinatesMode;\r\n switch (this.coordinatesMode) {\r\n case Texture.PLANAR_MODE:\r\n Matrix.IdentityToRef(this._cachedTextureMatrix);\r\n this._cachedTextureMatrix[0] = this.uScale;\r\n this._cachedTextureMatrix[5] = this.vScale;\r\n this._cachedTextureMatrix[12] = this.uOffset;\r\n this._cachedTextureMatrix[13] = this.vOffset;\r\n break;\r\n case Texture.PROJECTION_MODE:\r\n Matrix.FromValuesToRef(0.5, 0.0, 0.0, 0.0, 0.0, -0.5, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.5, 0.5, 1.0, 1.0, this._projectionModeMatrix);\r\n var projectionMatrix = scene.getProjectionMatrix();\r\n this._cachedProjectionMatrixId = projectionMatrix.updateFlag;\r\n projectionMatrix.multiplyToRef(this._projectionModeMatrix, this._cachedTextureMatrix);\r\n break;\r\n default:\r\n Matrix.IdentityToRef(this._cachedTextureMatrix);\r\n break;\r\n }\r\n scene.markAllMaterialsAsDirty(1, function (mat) {\r\n return (mat.getActiveTextures().indexOf(_this) !== -1);\r\n });\r\n return this._cachedTextureMatrix;\r\n };\r\n /**\r\n * Clones the texture.\r\n * @returns the cloned texture\r\n */\r\n Texture.prototype.clone = function () {\r\n var _this = this;\r\n return SerializationHelper.Clone(function () {\r\n return new Texture(_this._texture ? _this._texture.url : null, _this.getScene(), _this._noMipmap, _this._invertY, _this.samplingMode, undefined, undefined, _this._texture ? _this._texture._buffer : undefined);\r\n }, this);\r\n };\r\n /**\r\n * Serialize the texture to a JSON representation we can easily use in the resepective Parse function.\r\n * @returns The JSON representation of the texture\r\n */\r\n Texture.prototype.serialize = function () {\r\n var savedName = this.name;\r\n if (!Texture.SerializeBuffers) {\r\n if (StringTools.StartsWith(this.name, \"data:\")) {\r\n this.name = \"\";\r\n }\r\n }\r\n if (StringTools.StartsWith(this.name, \"data:\") && this.url === this.name) {\r\n this.url = \"\";\r\n }\r\n var serializationObject = _super.prototype.serialize.call(this);\r\n if (!serializationObject) {\r\n return null;\r\n }\r\n if (Texture.SerializeBuffers || Texture.ForceSerializeBuffers) {\r\n if (typeof this._buffer === \"string\" && this._buffer.substr(0, 5) === \"data:\") {\r\n serializationObject.base64String = this._buffer;\r\n serializationObject.name = serializationObject.name.replace(\"data:\", \"\");\r\n }\r\n else if (this.url && StringTools.StartsWith(this.url, \"data:\") && this._buffer instanceof Uint8Array) {\r\n serializationObject.base64String = \"data:image/png;base64,\" + StringTools.EncodeArrayBufferToBase64(this._buffer);\r\n }\r\n else if (Texture.ForceSerializeBuffers) {\r\n serializationObject.base64String = CopyTools.GenerateBase64StringFromTexture(this);\r\n }\r\n }\r\n serializationObject.invertY = this._invertY;\r\n serializationObject.samplingMode = this.samplingMode;\r\n this.name = savedName;\r\n return serializationObject;\r\n };\r\n /**\r\n * Get the current class name of the texture useful for serialization or dynamic coding.\r\n * @returns \"Texture\"\r\n */\r\n Texture.prototype.getClassName = function () {\r\n return \"Texture\";\r\n };\r\n /**\r\n * Dispose the texture and release its associated resources.\r\n */\r\n Texture.prototype.dispose = function () {\r\n _super.prototype.dispose.call(this);\r\n this.onLoadObservable.clear();\r\n this._delayedOnLoad = null;\r\n this._delayedOnError = null;\r\n };\r\n /**\r\n * Parse the JSON representation of a texture in order to recreate the texture in the given scene.\r\n * @param parsedTexture Define the JSON representation of the texture\r\n * @param scene Define the scene the parsed texture should be instantiated in\r\n * @param rootUrl Define the root url of the parsing sequence in the case of relative dependencies\r\n * @returns The parsed texture if successful\r\n */\r\n Texture.Parse = function (parsedTexture, scene, rootUrl) {\r\n if (parsedTexture.customType) {\r\n var customTexture = InstantiationTools.Instantiate(parsedTexture.customType);\r\n // Update Sampling Mode\r\n var parsedCustomTexture = customTexture.Parse(parsedTexture, scene, rootUrl);\r\n if (parsedTexture.samplingMode && parsedCustomTexture.updateSamplingMode && parsedCustomTexture._samplingMode) {\r\n if (parsedCustomTexture._samplingMode !== parsedTexture.samplingMode) {\r\n parsedCustomTexture.updateSamplingMode(parsedTexture.samplingMode);\r\n }\r\n }\r\n return parsedCustomTexture;\r\n }\r\n if (parsedTexture.isCube && !parsedTexture.isRenderTarget) {\r\n return Texture._CubeTextureParser(parsedTexture, scene, rootUrl);\r\n }\r\n if (!parsedTexture.name && !parsedTexture.isRenderTarget) {\r\n return null;\r\n }\r\n var onLoaded = function () {\r\n // Clear cache\r\n if (texture && texture._texture) {\r\n texture._texture._cachedWrapU = null;\r\n texture._texture._cachedWrapV = null;\r\n texture._texture._cachedWrapR = null;\r\n }\r\n // Update Sampling Mode\r\n if (parsedTexture.samplingMode) {\r\n var sampling = parsedTexture.samplingMode;\r\n if (texture && texture.samplingMode !== sampling) {\r\n texture.updateSamplingMode(sampling);\r\n }\r\n }\r\n // Animations\r\n if (texture && parsedTexture.animations) {\r\n for (var animationIndex = 0; animationIndex < parsedTexture.animations.length; animationIndex++) {\r\n var parsedAnimation = parsedTexture.animations[animationIndex];\r\n var internalClass = _TypeStore.GetClass(\"BABYLON.Animation\");\r\n if (internalClass) {\r\n texture.animations.push(internalClass.Parse(parsedAnimation));\r\n }\r\n }\r\n }\r\n };\r\n var texture = SerializationHelper.Parse(function () {\r\n var generateMipMaps = true;\r\n if (parsedTexture.noMipmap) {\r\n generateMipMaps = false;\r\n }\r\n if (parsedTexture.mirrorPlane) {\r\n var mirrorTexture = Texture._CreateMirror(parsedTexture.name, parsedTexture.renderTargetSize, scene, generateMipMaps);\r\n mirrorTexture._waitingRenderList = parsedTexture.renderList;\r\n mirrorTexture.mirrorPlane = Plane.FromArray(parsedTexture.mirrorPlane);\r\n onLoaded();\r\n return mirrorTexture;\r\n }\r\n else if (parsedTexture.isRenderTarget) {\r\n var renderTargetTexture = null;\r\n if (parsedTexture.isCube) {\r\n // Search for an existing reflection probe (which contains a cube render target texture)\r\n if (scene.reflectionProbes) {\r\n for (var index = 0; index < scene.reflectionProbes.length; index++) {\r\n var probe = scene.reflectionProbes[index];\r\n if (probe.name === parsedTexture.name) {\r\n return probe.cubeTexture;\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n renderTargetTexture = Texture._CreateRenderTargetTexture(parsedTexture.name, parsedTexture.renderTargetSize, scene, generateMipMaps);\r\n renderTargetTexture._waitingRenderList = parsedTexture.renderList;\r\n }\r\n onLoaded();\r\n return renderTargetTexture;\r\n }\r\n else {\r\n var texture;\r\n if (parsedTexture.base64String) {\r\n texture = Texture.CreateFromBase64String(parsedTexture.base64String, parsedTexture.name, scene, !generateMipMaps, parsedTexture.invertY, undefined, onLoaded);\r\n }\r\n else {\r\n var url = void 0;\r\n if (parsedTexture.name && parsedTexture.name.indexOf(\"://\") > 0) {\r\n url = parsedTexture.name;\r\n }\r\n else {\r\n url = rootUrl + parsedTexture.name;\r\n }\r\n if (StringTools.StartsWith(parsedTexture.url, \"data:\") || (Texture.UseSerializedUrlIfAny && parsedTexture.url)) {\r\n url = parsedTexture.url;\r\n }\r\n texture = new Texture(url, scene, !generateMipMaps, parsedTexture.invertY, undefined, onLoaded);\r\n }\r\n return texture;\r\n }\r\n }, parsedTexture, scene);\r\n return texture;\r\n };\r\n /**\r\n * Creates a texture from its base 64 representation.\r\n * @param data Define the base64 payload without the data: prefix\r\n * @param name Define the name of the texture in the scene useful fo caching purpose for instance\r\n * @param scene Define the scene the texture should belong to\r\n * @param noMipmap Forces the texture to not create mip map information if true\r\n * @param invertY define if the texture needs to be inverted on the y axis during loading\r\n * @param samplingMode define the sampling mode we want for the texture while fectching from it (Texture.NEAREST_SAMPLINGMODE...)\r\n * @param onLoad define a callback triggered when the texture has been loaded\r\n * @param onError define a callback triggered when an error occurred during the loading session\r\n * @param format define the format of the texture we are trying to load (Engine.TEXTUREFORMAT_RGBA...)\r\n * @returns the created texture\r\n */\r\n Texture.CreateFromBase64String = function (data, name, scene, noMipmap, invertY, samplingMode, onLoad, onError, format) {\r\n if (samplingMode === void 0) { samplingMode = Texture.TRILINEAR_SAMPLINGMODE; }\r\n if (onLoad === void 0) { onLoad = null; }\r\n if (onError === void 0) { onError = null; }\r\n if (format === void 0) { format = 5; }\r\n return new Texture(\"data:\" + name, scene, noMipmap, invertY, samplingMode, onLoad, onError, data, false, format);\r\n };\r\n /**\r\n * Creates a texture from its data: representation. (data: will be added in case only the payload has been passed in)\r\n * @param data Define the base64 payload without the data: prefix\r\n * @param name Define the name of the texture in the scene useful fo caching purpose for instance\r\n * @param buffer define the buffer to load the texture from in case the texture is loaded from a buffer representation\r\n * @param scene Define the scene the texture should belong to\r\n * @param deleteBuffer define if the buffer we are loading the texture from should be deleted after load\r\n * @param noMipmap Forces the texture to not create mip map information if true\r\n * @param invertY define if the texture needs to be inverted on the y axis during loading\r\n * @param samplingMode define the sampling mode we want for the texture while fectching from it (Texture.NEAREST_SAMPLINGMODE...)\r\n * @param onLoad define a callback triggered when the texture has been loaded\r\n * @param onError define a callback triggered when an error occurred during the loading session\r\n * @param format define the format of the texture we are trying to load (Engine.TEXTUREFORMAT_RGBA...)\r\n * @returns the created texture\r\n */\r\n Texture.LoadFromDataString = function (name, buffer, scene, deleteBuffer, noMipmap, invertY, samplingMode, onLoad, onError, format) {\r\n if (deleteBuffer === void 0) { deleteBuffer = false; }\r\n if (noMipmap === void 0) { noMipmap = false; }\r\n if (invertY === void 0) { invertY = true; }\r\n if (samplingMode === void 0) { samplingMode = Texture.TRILINEAR_SAMPLINGMODE; }\r\n if (onLoad === void 0) { onLoad = null; }\r\n if (onError === void 0) { onError = null; }\r\n if (format === void 0) { format = 5; }\r\n if (name.substr(0, 5) !== \"data:\") {\r\n name = \"data:\" + name;\r\n }\r\n return new Texture(name, scene, noMipmap, invertY, samplingMode, onLoad, onError, buffer, deleteBuffer, format);\r\n };\r\n /**\r\n * Gets or sets a general boolean used to indicate that textures containing direct data (buffers) must be saved as part of the serialization process\r\n */\r\n Texture.SerializeBuffers = true;\r\n /**\r\n * Gets or sets a general boolean used to indicate that texture buffers must be saved as part of the serialization process.\r\n * If no buffer exists, one will be created as base64 string from the internal webgl data.\r\n */\r\n Texture.ForceSerializeBuffers = false;\r\n /** @hidden */\r\n Texture._CubeTextureParser = function (jsonTexture, scene, rootUrl) {\r\n throw _DevTools.WarnImport(\"CubeTexture\");\r\n };\r\n /** @hidden */\r\n Texture._CreateMirror = function (name, renderTargetSize, scene, generateMipMaps) {\r\n throw _DevTools.WarnImport(\"MirrorTexture\");\r\n };\r\n /** @hidden */\r\n Texture._CreateRenderTargetTexture = function (name, renderTargetSize, scene, generateMipMaps) {\r\n throw _DevTools.WarnImport(\"RenderTargetTexture\");\r\n };\r\n /** nearest is mag = nearest and min = nearest and mip = linear */\r\n Texture.NEAREST_SAMPLINGMODE = 1;\r\n /** nearest is mag = nearest and min = nearest and mip = linear */\r\n Texture.NEAREST_NEAREST_MIPLINEAR = 8; // nearest is mag = nearest and min = nearest and mip = linear\r\n /** Bilinear is mag = linear and min = linear and mip = nearest */\r\n Texture.BILINEAR_SAMPLINGMODE = 2;\r\n /** Bilinear is mag = linear and min = linear and mip = nearest */\r\n Texture.LINEAR_LINEAR_MIPNEAREST = 11; // Bilinear is mag = linear and min = linear and mip = nearest\r\n /** Trilinear is mag = linear and min = linear and mip = linear */\r\n Texture.TRILINEAR_SAMPLINGMODE = 3;\r\n /** Trilinear is mag = linear and min = linear and mip = linear */\r\n Texture.LINEAR_LINEAR_MIPLINEAR = 3; // Trilinear is mag = linear and min = linear and mip = linear\r\n /** mag = nearest and min = nearest and mip = nearest */\r\n Texture.NEAREST_NEAREST_MIPNEAREST = 4;\r\n /** mag = nearest and min = linear and mip = nearest */\r\n Texture.NEAREST_LINEAR_MIPNEAREST = 5;\r\n /** mag = nearest and min = linear and mip = linear */\r\n Texture.NEAREST_LINEAR_MIPLINEAR = 6;\r\n /** mag = nearest and min = linear and mip = none */\r\n Texture.NEAREST_LINEAR = 7;\r\n /** mag = nearest and min = nearest and mip = none */\r\n Texture.NEAREST_NEAREST = 1;\r\n /** mag = linear and min = nearest and mip = nearest */\r\n Texture.LINEAR_NEAREST_MIPNEAREST = 9;\r\n /** mag = linear and min = nearest and mip = linear */\r\n Texture.LINEAR_NEAREST_MIPLINEAR = 10;\r\n /** mag = linear and min = linear and mip = none */\r\n Texture.LINEAR_LINEAR = 2;\r\n /** mag = linear and min = nearest and mip = none */\r\n Texture.LINEAR_NEAREST = 12;\r\n /** Explicit coordinates mode */\r\n Texture.EXPLICIT_MODE = 0;\r\n /** Spherical coordinates mode */\r\n Texture.SPHERICAL_MODE = 1;\r\n /** Planar coordinates mode */\r\n Texture.PLANAR_MODE = 2;\r\n /** Cubic coordinates mode */\r\n Texture.CUBIC_MODE = 3;\r\n /** Projection coordinates mode */\r\n Texture.PROJECTION_MODE = 4;\r\n /** Inverse Cubic coordinates mode */\r\n Texture.SKYBOX_MODE = 5;\r\n /** Inverse Cubic coordinates mode */\r\n Texture.INVCUBIC_MODE = 6;\r\n /** Equirectangular coordinates mode */\r\n Texture.EQUIRECTANGULAR_MODE = 7;\r\n /** Equirectangular Fixed coordinates mode */\r\n Texture.FIXED_EQUIRECTANGULAR_MODE = 8;\r\n /** Equirectangular Fixed Mirrored coordinates mode */\r\n Texture.FIXED_EQUIRECTANGULAR_MIRRORED_MODE = 9;\r\n /** Texture is not repeating outside of 0..1 UVs */\r\n Texture.CLAMP_ADDRESSMODE = 0;\r\n /** Texture is repeating outside of 0..1 UVs */\r\n Texture.WRAP_ADDRESSMODE = 1;\r\n /** Texture is repeating and mirrored */\r\n Texture.MIRROR_ADDRESSMODE = 2;\r\n /**\r\n * Gets or sets a boolean which defines if the texture url must be build from the serialized URL instead of just using the name and loading them side by side with the scene file\r\n */\r\n Texture.UseSerializedUrlIfAny = false;\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"url\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"uOffset\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"vOffset\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"uScale\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"vScale\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"uAng\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"vAng\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"wAng\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"uRotationCenter\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"vRotationCenter\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"wRotationCenter\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"homogeneousRotationInUVTransform\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Texture.prototype, \"isBlocking\", null);\r\n return Texture;\r\n}(BaseTexture));\r\nexport { Texture };\r\n// References the dependencies.\r\n_TypeStore.RegisteredTypes[\"BABYLON.Texture\"] = Texture;\r\nSerializationHelper._TextureParser = Texture.Parse;\r\n//# sourceMappingURL=texture.js.map","/**\r\n * @hidden\r\n **/\r\nvar DepthCullingState = /** @class */ (function () {\r\n /**\r\n * Initializes the state.\r\n */\r\n function DepthCullingState() {\r\n this._isDepthTestDirty = false;\r\n this._isDepthMaskDirty = false;\r\n this._isDepthFuncDirty = false;\r\n this._isCullFaceDirty = false;\r\n this._isCullDirty = false;\r\n this._isZOffsetDirty = false;\r\n this._isFrontFaceDirty = false;\r\n this.reset();\r\n }\r\n Object.defineProperty(DepthCullingState.prototype, \"isDirty\", {\r\n get: function () {\r\n return this._isDepthFuncDirty || this._isDepthTestDirty || this._isDepthMaskDirty || this._isCullFaceDirty || this._isCullDirty || this._isZOffsetDirty || this._isFrontFaceDirty;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(DepthCullingState.prototype, \"zOffset\", {\r\n get: function () {\r\n return this._zOffset;\r\n },\r\n set: function (value) {\r\n if (this._zOffset === value) {\r\n return;\r\n }\r\n this._zOffset = value;\r\n this._isZOffsetDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(DepthCullingState.prototype, \"cullFace\", {\r\n get: function () {\r\n return this._cullFace;\r\n },\r\n set: function (value) {\r\n if (this._cullFace === value) {\r\n return;\r\n }\r\n this._cullFace = value;\r\n this._isCullFaceDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(DepthCullingState.prototype, \"cull\", {\r\n get: function () {\r\n return this._cull;\r\n },\r\n set: function (value) {\r\n if (this._cull === value) {\r\n return;\r\n }\r\n this._cull = value;\r\n this._isCullDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(DepthCullingState.prototype, \"depthFunc\", {\r\n get: function () {\r\n return this._depthFunc;\r\n },\r\n set: function (value) {\r\n if (this._depthFunc === value) {\r\n return;\r\n }\r\n this._depthFunc = value;\r\n this._isDepthFuncDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(DepthCullingState.prototype, \"depthMask\", {\r\n get: function () {\r\n return this._depthMask;\r\n },\r\n set: function (value) {\r\n if (this._depthMask === value) {\r\n return;\r\n }\r\n this._depthMask = value;\r\n this._isDepthMaskDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(DepthCullingState.prototype, \"depthTest\", {\r\n get: function () {\r\n return this._depthTest;\r\n },\r\n set: function (value) {\r\n if (this._depthTest === value) {\r\n return;\r\n }\r\n this._depthTest = value;\r\n this._isDepthTestDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(DepthCullingState.prototype, \"frontFace\", {\r\n get: function () {\r\n return this._frontFace;\r\n },\r\n set: function (value) {\r\n if (this._frontFace === value) {\r\n return;\r\n }\r\n this._frontFace = value;\r\n this._isFrontFaceDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n DepthCullingState.prototype.reset = function () {\r\n this._depthMask = true;\r\n this._depthTest = true;\r\n this._depthFunc = null;\r\n this._cullFace = null;\r\n this._cull = null;\r\n this._zOffset = 0;\r\n this._frontFace = null;\r\n this._isDepthTestDirty = true;\r\n this._isDepthMaskDirty = true;\r\n this._isDepthFuncDirty = false;\r\n this._isCullFaceDirty = false;\r\n this._isCullDirty = false;\r\n this._isZOffsetDirty = false;\r\n this._isFrontFaceDirty = false;\r\n };\r\n DepthCullingState.prototype.apply = function (gl) {\r\n if (!this.isDirty) {\r\n return;\r\n }\r\n // Cull\r\n if (this._isCullDirty) {\r\n if (this.cull) {\r\n gl.enable(gl.CULL_FACE);\r\n }\r\n else {\r\n gl.disable(gl.CULL_FACE);\r\n }\r\n this._isCullDirty = false;\r\n }\r\n // Cull face\r\n if (this._isCullFaceDirty) {\r\n gl.cullFace(this.cullFace);\r\n this._isCullFaceDirty = false;\r\n }\r\n // Depth mask\r\n if (this._isDepthMaskDirty) {\r\n gl.depthMask(this.depthMask);\r\n this._isDepthMaskDirty = false;\r\n }\r\n // Depth test\r\n if (this._isDepthTestDirty) {\r\n if (this.depthTest) {\r\n gl.enable(gl.DEPTH_TEST);\r\n }\r\n else {\r\n gl.disable(gl.DEPTH_TEST);\r\n }\r\n this._isDepthTestDirty = false;\r\n }\r\n // Depth func\r\n if (this._isDepthFuncDirty) {\r\n gl.depthFunc(this.depthFunc);\r\n this._isDepthFuncDirty = false;\r\n }\r\n // zOffset\r\n if (this._isZOffsetDirty) {\r\n if (this.zOffset) {\r\n gl.enable(gl.POLYGON_OFFSET_FILL);\r\n gl.polygonOffset(this.zOffset, 0);\r\n }\r\n else {\r\n gl.disable(gl.POLYGON_OFFSET_FILL);\r\n }\r\n this._isZOffsetDirty = false;\r\n }\r\n // Front face\r\n if (this._isFrontFaceDirty) {\r\n gl.frontFace(this.frontFace);\r\n this._isFrontFaceDirty = false;\r\n }\r\n };\r\n return DepthCullingState;\r\n}());\r\nexport { DepthCullingState };\r\n//# sourceMappingURL=depthCullingState.js.map","/**\r\n * @hidden\r\n **/\r\nvar StencilState = /** @class */ (function () {\r\n function StencilState() {\r\n this._isStencilTestDirty = false;\r\n this._isStencilMaskDirty = false;\r\n this._isStencilFuncDirty = false;\r\n this._isStencilOpDirty = false;\r\n this.reset();\r\n }\r\n Object.defineProperty(StencilState.prototype, \"isDirty\", {\r\n get: function () {\r\n return this._isStencilTestDirty || this._isStencilMaskDirty || this._isStencilFuncDirty || this._isStencilOpDirty;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StencilState.prototype, \"stencilFunc\", {\r\n get: function () {\r\n return this._stencilFunc;\r\n },\r\n set: function (value) {\r\n if (this._stencilFunc === value) {\r\n return;\r\n }\r\n this._stencilFunc = value;\r\n this._isStencilFuncDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StencilState.prototype, \"stencilFuncRef\", {\r\n get: function () {\r\n return this._stencilFuncRef;\r\n },\r\n set: function (value) {\r\n if (this._stencilFuncRef === value) {\r\n return;\r\n }\r\n this._stencilFuncRef = value;\r\n this._isStencilFuncDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StencilState.prototype, \"stencilFuncMask\", {\r\n get: function () {\r\n return this._stencilFuncMask;\r\n },\r\n set: function (value) {\r\n if (this._stencilFuncMask === value) {\r\n return;\r\n }\r\n this._stencilFuncMask = value;\r\n this._isStencilFuncDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StencilState.prototype, \"stencilOpStencilFail\", {\r\n get: function () {\r\n return this._stencilOpStencilFail;\r\n },\r\n set: function (value) {\r\n if (this._stencilOpStencilFail === value) {\r\n return;\r\n }\r\n this._stencilOpStencilFail = value;\r\n this._isStencilOpDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StencilState.prototype, \"stencilOpDepthFail\", {\r\n get: function () {\r\n return this._stencilOpDepthFail;\r\n },\r\n set: function (value) {\r\n if (this._stencilOpDepthFail === value) {\r\n return;\r\n }\r\n this._stencilOpDepthFail = value;\r\n this._isStencilOpDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StencilState.prototype, \"stencilOpStencilDepthPass\", {\r\n get: function () {\r\n return this._stencilOpStencilDepthPass;\r\n },\r\n set: function (value) {\r\n if (this._stencilOpStencilDepthPass === value) {\r\n return;\r\n }\r\n this._stencilOpStencilDepthPass = value;\r\n this._isStencilOpDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StencilState.prototype, \"stencilMask\", {\r\n get: function () {\r\n return this._stencilMask;\r\n },\r\n set: function (value) {\r\n if (this._stencilMask === value) {\r\n return;\r\n }\r\n this._stencilMask = value;\r\n this._isStencilMaskDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StencilState.prototype, \"stencilTest\", {\r\n get: function () {\r\n return this._stencilTest;\r\n },\r\n set: function (value) {\r\n if (this._stencilTest === value) {\r\n return;\r\n }\r\n this._stencilTest = value;\r\n this._isStencilTestDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n StencilState.prototype.reset = function () {\r\n this._stencilTest = false;\r\n this._stencilMask = 0xFF;\r\n this._stencilFunc = StencilState.ALWAYS;\r\n this._stencilFuncRef = 1;\r\n this._stencilFuncMask = 0xFF;\r\n this._stencilOpStencilFail = StencilState.KEEP;\r\n this._stencilOpDepthFail = StencilState.KEEP;\r\n this._stencilOpStencilDepthPass = StencilState.REPLACE;\r\n this._isStencilTestDirty = true;\r\n this._isStencilMaskDirty = true;\r\n this._isStencilFuncDirty = true;\r\n this._isStencilOpDirty = true;\r\n };\r\n StencilState.prototype.apply = function (gl) {\r\n if (!this.isDirty) {\r\n return;\r\n }\r\n // Stencil test\r\n if (this._isStencilTestDirty) {\r\n if (this.stencilTest) {\r\n gl.enable(gl.STENCIL_TEST);\r\n }\r\n else {\r\n gl.disable(gl.STENCIL_TEST);\r\n }\r\n this._isStencilTestDirty = false;\r\n }\r\n // Stencil mask\r\n if (this._isStencilMaskDirty) {\r\n gl.stencilMask(this.stencilMask);\r\n this._isStencilMaskDirty = false;\r\n }\r\n // Stencil func\r\n if (this._isStencilFuncDirty) {\r\n gl.stencilFunc(this.stencilFunc, this.stencilFuncRef, this.stencilFuncMask);\r\n this._isStencilFuncDirty = false;\r\n }\r\n // Stencil op\r\n if (this._isStencilOpDirty) {\r\n gl.stencilOp(this.stencilOpStencilFail, this.stencilOpDepthFail, this.stencilOpStencilDepthPass);\r\n this._isStencilOpDirty = false;\r\n }\r\n };\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will always pass. i.e. Pixels will be drawn in the order they are drawn */\r\n StencilState.ALWAYS = 519;\r\n /** Passed to stencilOperation to specify that stencil value must be kept */\r\n StencilState.KEEP = 7680;\r\n /** Passed to stencilOperation to specify that stencil value must be replaced */\r\n StencilState.REPLACE = 7681;\r\n return StencilState;\r\n}());\r\nexport { StencilState };\r\n//# sourceMappingURL=stencilState.js.map","/**\r\n * @hidden\r\n **/\r\nvar AlphaState = /** @class */ (function () {\r\n /**\r\n * Initializes the state.\r\n */\r\n function AlphaState() {\r\n this._isAlphaBlendDirty = false;\r\n this._isBlendFunctionParametersDirty = false;\r\n this._isBlendEquationParametersDirty = false;\r\n this._isBlendConstantsDirty = false;\r\n this._alphaBlend = false;\r\n this._blendFunctionParameters = new Array(4);\r\n this._blendEquationParameters = new Array(2);\r\n this._blendConstants = new Array(4);\r\n this.reset();\r\n }\r\n Object.defineProperty(AlphaState.prototype, \"isDirty\", {\r\n get: function () {\r\n return this._isAlphaBlendDirty || this._isBlendFunctionParametersDirty;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AlphaState.prototype, \"alphaBlend\", {\r\n get: function () {\r\n return this._alphaBlend;\r\n },\r\n set: function (value) {\r\n if (this._alphaBlend === value) {\r\n return;\r\n }\r\n this._alphaBlend = value;\r\n this._isAlphaBlendDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n AlphaState.prototype.setAlphaBlendConstants = function (r, g, b, a) {\r\n if (this._blendConstants[0] === r &&\r\n this._blendConstants[1] === g &&\r\n this._blendConstants[2] === b &&\r\n this._blendConstants[3] === a) {\r\n return;\r\n }\r\n this._blendConstants[0] = r;\r\n this._blendConstants[1] = g;\r\n this._blendConstants[2] = b;\r\n this._blendConstants[3] = a;\r\n this._isBlendConstantsDirty = true;\r\n };\r\n AlphaState.prototype.setAlphaBlendFunctionParameters = function (value0, value1, value2, value3) {\r\n if (this._blendFunctionParameters[0] === value0 &&\r\n this._blendFunctionParameters[1] === value1 &&\r\n this._blendFunctionParameters[2] === value2 &&\r\n this._blendFunctionParameters[3] === value3) {\r\n return;\r\n }\r\n this._blendFunctionParameters[0] = value0;\r\n this._blendFunctionParameters[1] = value1;\r\n this._blendFunctionParameters[2] = value2;\r\n this._blendFunctionParameters[3] = value3;\r\n this._isBlendFunctionParametersDirty = true;\r\n };\r\n AlphaState.prototype.setAlphaEquationParameters = function (rgb, alpha) {\r\n if (this._blendEquationParameters[0] === rgb &&\r\n this._blendEquationParameters[1] === alpha) {\r\n return;\r\n }\r\n this._blendEquationParameters[0] = rgb;\r\n this._blendEquationParameters[1] = alpha;\r\n this._isBlendEquationParametersDirty = true;\r\n };\r\n AlphaState.prototype.reset = function () {\r\n this._alphaBlend = false;\r\n this._blendFunctionParameters[0] = null;\r\n this._blendFunctionParameters[1] = null;\r\n this._blendFunctionParameters[2] = null;\r\n this._blendFunctionParameters[3] = null;\r\n this._blendEquationParameters[0] = null;\r\n this._blendEquationParameters[1] = null;\r\n this._blendConstants[0] = null;\r\n this._blendConstants[1] = null;\r\n this._blendConstants[2] = null;\r\n this._blendConstants[3] = null;\r\n this._isAlphaBlendDirty = true;\r\n this._isBlendFunctionParametersDirty = false;\r\n this._isBlendEquationParametersDirty = false;\r\n this._isBlendConstantsDirty = false;\r\n };\r\n AlphaState.prototype.apply = function (gl) {\r\n if (!this.isDirty) {\r\n return;\r\n }\r\n // Alpha blend\r\n if (this._isAlphaBlendDirty) {\r\n if (this._alphaBlend) {\r\n gl.enable(gl.BLEND);\r\n }\r\n else {\r\n gl.disable(gl.BLEND);\r\n }\r\n this._isAlphaBlendDirty = false;\r\n }\r\n // Alpha function\r\n if (this._isBlendFunctionParametersDirty) {\r\n gl.blendFuncSeparate(this._blendFunctionParameters[0], this._blendFunctionParameters[1], this._blendFunctionParameters[2], this._blendFunctionParameters[3]);\r\n this._isBlendFunctionParametersDirty = false;\r\n }\r\n // Alpha equation\r\n if (this._isBlendEquationParametersDirty) {\r\n gl.blendEquationSeparate(this._blendEquationParameters[0], this._blendEquationParameters[1]);\r\n this._isBlendEquationParametersDirty = false;\r\n }\r\n // Constants\r\n if (this._isBlendConstantsDirty) {\r\n gl.blendColor(this._blendConstants[0], this._blendConstants[1], this._blendConstants[2], this._blendConstants[3]);\r\n this._isBlendConstantsDirty = false;\r\n }\r\n };\r\n return AlphaState;\r\n}());\r\nexport { AlphaState };\r\n//# sourceMappingURL=alphaCullingState.js.map","/** @hidden */\r\nvar WebGLShaderProcessor = /** @class */ (function () {\r\n function WebGLShaderProcessor() {\r\n }\r\n WebGLShaderProcessor.prototype.postProcessor = function (code, defines, isFragment, engine) {\r\n // Remove extensions\r\n if (!engine.getCaps().drawBuffersExtension) {\r\n // even if enclosed in #if/#endif, IE11 does parse the #extension declaration, so we need to remove it altogether\r\n var regex = /#extension.+GL_EXT_draw_buffers.+(enable|require)/g;\r\n code = code.replace(regex, \"\");\r\n }\r\n return code;\r\n };\r\n return WebGLShaderProcessor;\r\n}());\r\nexport { WebGLShaderProcessor };\r\n//# sourceMappingURL=webGLShaderProcessors.js.map","/** @hidden */\r\nvar WebGL2ShaderProcessor = /** @class */ (function () {\r\n function WebGL2ShaderProcessor() {\r\n }\r\n WebGL2ShaderProcessor.prototype.attributeProcessor = function (attribute) {\r\n return attribute.replace(\"attribute\", \"in\");\r\n };\r\n WebGL2ShaderProcessor.prototype.varyingProcessor = function (varying, isFragment) {\r\n return varying.replace(\"varying\", isFragment ? \"in\" : \"out\");\r\n };\r\n WebGL2ShaderProcessor.prototype.postProcessor = function (code, defines, isFragment) {\r\n var hasDrawBuffersExtension = code.search(/#extension.+GL_EXT_draw_buffers.+require/) !== -1;\r\n // Remove extensions\r\n var regex = /#extension.+(GL_OVR_multiview2|GL_OES_standard_derivatives|GL_EXT_shader_texture_lod|GL_EXT_frag_depth|GL_EXT_draw_buffers).+(enable|require)/g;\r\n code = code.replace(regex, \"\");\r\n // Replace instructions\r\n code = code.replace(/texture2D\\s*\\(/g, \"texture(\");\r\n if (isFragment) {\r\n code = code.replace(/texture2DLodEXT\\s*\\(/g, \"textureLod(\");\r\n code = code.replace(/textureCubeLodEXT\\s*\\(/g, \"textureLod(\");\r\n code = code.replace(/textureCube\\s*\\(/g, \"texture(\");\r\n code = code.replace(/gl_FragDepthEXT/g, \"gl_FragDepth\");\r\n code = code.replace(/gl_FragColor/g, \"glFragColor\");\r\n code = code.replace(/gl_FragData/g, \"glFragData\");\r\n code = code.replace(/void\\s+?main\\s*\\(/g, (hasDrawBuffersExtension ? \"\" : \"out vec4 glFragColor;\\n\") + \"void main(\");\r\n }\r\n else {\r\n var hasMultiviewExtension = defines.indexOf(\"#define MULTIVIEW\") !== -1;\r\n if (hasMultiviewExtension) {\r\n return \"#extension GL_OVR_multiview2 : require\\nlayout (num_views = 2) in;\\n\" + code;\r\n }\r\n }\r\n return code;\r\n };\r\n return WebGL2ShaderProcessor;\r\n}());\r\nexport { WebGL2ShaderProcessor };\r\n//# sourceMappingURL=webGL2ShaderProcessors.js.map","/** @hidden */\r\nvar WebGLPipelineContext = /** @class */ (function () {\r\n function WebGLPipelineContext() {\r\n this.vertexCompilationError = null;\r\n this.fragmentCompilationError = null;\r\n this.programLinkError = null;\r\n this.programValidationError = null;\r\n }\r\n Object.defineProperty(WebGLPipelineContext.prototype, \"isAsync\", {\r\n get: function () {\r\n return this.isParallelCompiled;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(WebGLPipelineContext.prototype, \"isReady\", {\r\n get: function () {\r\n if (this.program) {\r\n if (this.isParallelCompiled) {\r\n return this.engine._isRenderingStateCompiled(this);\r\n }\r\n return true;\r\n }\r\n return false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n WebGLPipelineContext.prototype._handlesSpectorRebuildCallback = function (onCompiled) {\r\n if (onCompiled && this.program) {\r\n onCompiled(this.program);\r\n }\r\n };\r\n WebGLPipelineContext.prototype._getVertexShaderCode = function () {\r\n return this.vertexShader ? this.engine._getShaderSource(this.vertexShader) : null;\r\n };\r\n WebGLPipelineContext.prototype._getFragmentShaderCode = function () {\r\n return this.fragmentShader ? this.engine._getShaderSource(this.fragmentShader) : null;\r\n };\r\n return WebGLPipelineContext;\r\n}());\r\nexport { WebGLPipelineContext };\r\n//# sourceMappingURL=webGLPipelineContext.js.map","import { EngineStore } from './engineStore';\r\nimport { Effect } from '../Materials/effect';\r\nimport { _DevTools } from '../Misc/devTools';\r\nimport { Observable } from '../Misc/observable';\r\nimport { DepthCullingState } from '../States/depthCullingState';\r\nimport { StencilState } from '../States/stencilState';\r\nimport { AlphaState } from '../States/alphaCullingState';\r\nimport { InternalTexture, InternalTextureSource } from '../Materials/Textures/internalTexture';\r\nimport { Logger } from '../Misc/logger';\r\nimport { DomManagement } from '../Misc/domManagement';\r\nimport { WebGLShaderProcessor } from './WebGL/webGLShaderProcessors';\r\nimport { WebGL2ShaderProcessor } from './WebGL/webGL2ShaderProcessors';\r\nimport { WebGLDataBuffer } from '../Meshes/WebGL/webGLDataBuffer';\r\nimport { WebGLPipelineContext } from './WebGL/webGLPipelineContext';\r\nimport { CanvasGenerator } from '../Misc/canvasGenerator';\r\nimport { PerformanceConfigurator } from './performanceConfigurator';\r\n/**\r\n * Keeps track of all the buffer info used in engine.\r\n */\r\nvar BufferPointer = /** @class */ (function () {\r\n function BufferPointer() {\r\n }\r\n return BufferPointer;\r\n}());\r\n/**\r\n * The base engine class (root of all engines)\r\n */\r\nvar ThinEngine = /** @class */ (function () {\r\n /**\r\n * Creates a new engine\r\n * @param canvasOrContext defines the canvas or WebGL context to use for rendering. If you provide a WebGL context, Babylon.js will not hook events on the canvas (like pointers, keyboards, etc...) so no event observables will be available. This is mostly used when Babylon.js is used as a plugin on a system which alreay used the WebGL context\r\n * @param antialias defines enable antialiasing (default: false)\r\n * @param options defines further options to be sent to the getContext() function\r\n * @param adaptToDeviceRatio defines whether to adapt to the device's viewport characteristics (default: false)\r\n */\r\n function ThinEngine(canvasOrContext, antialias, options, adaptToDeviceRatio) {\r\n var _this = this;\r\n if (adaptToDeviceRatio === void 0) { adaptToDeviceRatio = false; }\r\n /**\r\n * Gets or sets a boolean that indicates if textures must be forced to power of 2 size even if not required\r\n */\r\n this.forcePOTTextures = false;\r\n /**\r\n * Gets a boolean indicating if the engine is currently rendering in fullscreen mode\r\n */\r\n this.isFullscreen = false;\r\n /**\r\n * Gets or sets a boolean indicating if back faces must be culled (true by default)\r\n */\r\n this.cullBackFaces = true;\r\n /**\r\n * Gets or sets a boolean indicating if the engine must keep rendering even if the window is not in foregroun\r\n */\r\n this.renderEvenInBackground = true;\r\n /**\r\n * Gets or sets a boolean indicating that cache can be kept between frames\r\n */\r\n this.preventCacheWipeBetweenFrames = false;\r\n /** Gets or sets a boolean indicating if the engine should validate programs after compilation */\r\n this.validateShaderPrograms = false;\r\n /**\r\n * Gets or sets a boolean indicating if depth buffer should be reverse, going from far to near.\r\n * This can provide greater z depth for distant objects.\r\n */\r\n this.useReverseDepthBuffer = false;\r\n // Uniform buffers list\r\n /**\r\n * Gets or sets a boolean indicating that uniform buffers must be disabled even if they are supported\r\n */\r\n this.disableUniformBuffers = false;\r\n /** @hidden */\r\n this._uniformBuffers = new Array();\r\n /** @hidden */\r\n this._webGLVersion = 1.0;\r\n this._windowIsBackground = false;\r\n this._highPrecisionShadersAllowed = true;\r\n /** @hidden */\r\n this._badOS = false;\r\n /** @hidden */\r\n this._badDesktopOS = false;\r\n this._renderingQueueLaunched = false;\r\n this._activeRenderLoops = new Array();\r\n // Lost context\r\n /**\r\n * Observable signaled when a context lost event is raised\r\n */\r\n this.onContextLostObservable = new Observable();\r\n /**\r\n * Observable signaled when a context restored event is raised\r\n */\r\n this.onContextRestoredObservable = new Observable();\r\n this._contextWasLost = false;\r\n /** @hidden */\r\n this._doNotHandleContextLost = false;\r\n /**\r\n * Gets or sets a boolean indicating that vertex array object must be disabled even if they are supported\r\n */\r\n this.disableVertexArrayObjects = false;\r\n // States\r\n /** @hidden */\r\n this._colorWrite = true;\r\n /** @hidden */\r\n this._colorWriteChanged = true;\r\n /** @hidden */\r\n this._depthCullingState = new DepthCullingState();\r\n /** @hidden */\r\n this._stencilState = new StencilState();\r\n /** @hidden */\r\n this._alphaState = new AlphaState();\r\n /** @hidden */\r\n this._alphaMode = 1;\r\n /** @hidden */\r\n this._alphaEquation = 0;\r\n // Cache\r\n /** @hidden */\r\n this._internalTexturesCache = new Array();\r\n /** @hidden */\r\n this._activeChannel = 0;\r\n this._currentTextureChannel = -1;\r\n /** @hidden */\r\n this._boundTexturesCache = {};\r\n this._compiledEffects = {};\r\n this._vertexAttribArraysEnabled = [];\r\n this._uintIndicesCurrentlySet = false;\r\n this._currentBoundBuffer = new Array();\r\n /** @hidden */\r\n this._currentFramebuffer = null;\r\n /** @hidden */\r\n this._dummyFramebuffer = null;\r\n this._currentBufferPointers = new Array();\r\n this._currentInstanceLocations = new Array();\r\n this._currentInstanceBuffers = new Array();\r\n this._vaoRecordInProgress = false;\r\n this._mustWipeVertexAttributes = false;\r\n this._nextFreeTextureSlots = new Array();\r\n this._maxSimultaneousTextures = 0;\r\n this._activeRequests = new Array();\r\n /** @hidden */\r\n this._transformTextureUrl = null;\r\n /**\r\n * Gets information about the current host\r\n */\r\n this.hostInformation = {\r\n isMobile: false\r\n };\r\n /**\r\n * Defines whether the engine has been created with the premultipliedAlpha option on or not.\r\n */\r\n this.premultipliedAlpha = true;\r\n /**\r\n * Observable event triggered before each texture is initialized\r\n */\r\n this.onBeforeTextureInitObservable = new Observable();\r\n this._viewportCached = { x: 0, y: 0, z: 0, w: 0 };\r\n this._unpackFlipYCached = null;\r\n /**\r\n * In case you are sharing the context with other applications, it might\r\n * be interested to not cache the unpack flip y state to ensure a consistent\r\n * value would be set.\r\n */\r\n this.enableUnpackFlipYCached = true;\r\n this._getDepthStencilBuffer = function (width, height, samples, internalFormat, msInternalFormat, attachment) {\r\n var gl = _this._gl;\r\n var depthStencilBuffer = gl.createRenderbuffer();\r\n gl.bindRenderbuffer(gl.RENDERBUFFER, depthStencilBuffer);\r\n if (samples > 1 && gl.renderbufferStorageMultisample) {\r\n gl.renderbufferStorageMultisample(gl.RENDERBUFFER, samples, msInternalFormat, width, height);\r\n }\r\n else {\r\n gl.renderbufferStorage(gl.RENDERBUFFER, internalFormat, width, height);\r\n }\r\n gl.framebufferRenderbuffer(gl.FRAMEBUFFER, attachment, gl.RENDERBUFFER, depthStencilBuffer);\r\n gl.bindRenderbuffer(gl.RENDERBUFFER, null);\r\n return depthStencilBuffer;\r\n };\r\n this._boundUniforms = {};\r\n var canvas = null;\r\n if (!canvasOrContext) {\r\n return;\r\n }\r\n options = options || {};\r\n PerformanceConfigurator.SetMatrixPrecision(!!options.useHighPrecisionMatrix);\r\n if (canvasOrContext.getContext) {\r\n canvas = canvasOrContext;\r\n this._renderingCanvas = canvas;\r\n if (antialias != null) {\r\n options.antialias = antialias;\r\n }\r\n if (options.deterministicLockstep === undefined) {\r\n options.deterministicLockstep = false;\r\n }\r\n if (options.lockstepMaxSteps === undefined) {\r\n options.lockstepMaxSteps = 4;\r\n }\r\n if (options.timeStep === undefined) {\r\n options.timeStep = 1 / 60;\r\n }\r\n if (options.preserveDrawingBuffer === undefined) {\r\n options.preserveDrawingBuffer = false;\r\n }\r\n if (options.audioEngine === undefined) {\r\n options.audioEngine = true;\r\n }\r\n if (options.stencil === undefined) {\r\n options.stencil = true;\r\n }\r\n if (options.premultipliedAlpha === false) {\r\n this.premultipliedAlpha = false;\r\n }\r\n if (options.xrCompatible === undefined) {\r\n options.xrCompatible = true;\r\n }\r\n this._doNotHandleContextLost = options.doNotHandleContextLost ? true : false;\r\n // Exceptions\r\n if (navigator && navigator.userAgent) {\r\n var ua = navigator.userAgent;\r\n this.hostInformation.isMobile = ua.indexOf(\"Mobile\") !== -1;\r\n for (var _i = 0, _a = ThinEngine.ExceptionList; _i < _a.length; _i++) {\r\n var exception = _a[_i];\r\n var key = exception.key;\r\n var targets = exception.targets;\r\n var check = new RegExp(key);\r\n if (check.test(ua)) {\r\n if (exception.capture && exception.captureConstraint) {\r\n var capture = exception.capture;\r\n var constraint = exception.captureConstraint;\r\n var regex = new RegExp(capture);\r\n var matches = regex.exec(ua);\r\n if (matches && matches.length > 0) {\r\n var capturedValue = parseInt(matches[matches.length - 1]);\r\n if (capturedValue >= constraint) {\r\n continue;\r\n }\r\n }\r\n }\r\n for (var _b = 0, targets_1 = targets; _b < targets_1.length; _b++) {\r\n var target = targets_1[_b];\r\n switch (target) {\r\n case \"uniformBuffer\":\r\n this.disableUniformBuffers = true;\r\n break;\r\n case \"vao\":\r\n this.disableVertexArrayObjects = true;\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n // Context lost\r\n if (!this._doNotHandleContextLost) {\r\n this._onContextLost = function (evt) {\r\n evt.preventDefault();\r\n _this._contextWasLost = true;\r\n Logger.Warn(\"WebGL context lost.\");\r\n _this.onContextLostObservable.notifyObservers(_this);\r\n };\r\n this._onContextRestored = function () {\r\n // Adding a timeout to avoid race condition at browser level\r\n setTimeout(function () {\r\n // Rebuild gl context\r\n _this._initGLContext();\r\n // Rebuild effects\r\n _this._rebuildEffects();\r\n // Rebuild textures\r\n _this._rebuildInternalTextures();\r\n // Rebuild buffers\r\n _this._rebuildBuffers();\r\n // Cache\r\n _this.wipeCaches(true);\r\n Logger.Warn(\"WebGL context successfully restored.\");\r\n _this.onContextRestoredObservable.notifyObservers(_this);\r\n _this._contextWasLost = false;\r\n }, 0);\r\n };\r\n canvas.addEventListener(\"webglcontextlost\", this._onContextLost, false);\r\n canvas.addEventListener(\"webglcontextrestored\", this._onContextRestored, false);\r\n options.powerPreference = \"high-performance\";\r\n }\r\n // GL\r\n if (!options.disableWebGL2Support) {\r\n try {\r\n this._gl = (canvas.getContext(\"webgl2\", options) || canvas.getContext(\"experimental-webgl2\", options));\r\n if (this._gl) {\r\n this._webGLVersion = 2.0;\r\n // Prevent weird browsers to lie (yeah that happens!)\r\n if (!this._gl.deleteQuery) {\r\n this._webGLVersion = 1.0;\r\n }\r\n }\r\n }\r\n catch (e) {\r\n // Do nothing\r\n }\r\n }\r\n if (!this._gl) {\r\n if (!canvas) {\r\n throw new Error(\"The provided canvas is null or undefined.\");\r\n }\r\n try {\r\n this._gl = (canvas.getContext(\"webgl\", options) || canvas.getContext(\"experimental-webgl\", options));\r\n }\r\n catch (e) {\r\n throw new Error(\"WebGL not supported\");\r\n }\r\n }\r\n if (!this._gl) {\r\n throw new Error(\"WebGL not supported\");\r\n }\r\n }\r\n else {\r\n this._gl = canvasOrContext;\r\n this._renderingCanvas = this._gl.canvas;\r\n if (this._gl.renderbufferStorageMultisample) {\r\n this._webGLVersion = 2.0;\r\n }\r\n var attributes = this._gl.getContextAttributes();\r\n if (attributes) {\r\n options.stencil = attributes.stencil;\r\n }\r\n }\r\n // Ensures a consistent color space unpacking of textures cross browser.\r\n this._gl.pixelStorei(this._gl.UNPACK_COLORSPACE_CONVERSION_WEBGL, this._gl.NONE);\r\n if (options.useHighPrecisionFloats !== undefined) {\r\n this._highPrecisionShadersAllowed = options.useHighPrecisionFloats;\r\n }\r\n // Viewport\r\n var devicePixelRatio = DomManagement.IsWindowObjectExist() ? (window.devicePixelRatio || 1.0) : 1.0;\r\n var limitDeviceRatio = options.limitDeviceRatio || devicePixelRatio;\r\n this._hardwareScalingLevel = adaptToDeviceRatio ? 1.0 / Math.min(limitDeviceRatio, devicePixelRatio) : 1.0;\r\n this.resize();\r\n this._isStencilEnable = options.stencil ? true : false;\r\n this._initGLContext();\r\n // Prepare buffer pointers\r\n for (var i = 0; i < this._caps.maxVertexAttribs; i++) {\r\n this._currentBufferPointers[i] = new BufferPointer();\r\n }\r\n // Shader processor\r\n if (this.webGLVersion > 1) {\r\n this._shaderProcessor = new WebGL2ShaderProcessor();\r\n }\r\n else {\r\n this._shaderProcessor = new WebGLShaderProcessor();\r\n }\r\n // Detect if we are running on a faulty buggy OS.\r\n this._badOS = /iPad/i.test(navigator.userAgent) || /iPhone/i.test(navigator.userAgent);\r\n // Starting with iOS 14, we can trust the browser\r\n // let matches = navigator.userAgent.match(/Version\\/(\\d+)/);\r\n // if (matches && matches.length === 2) {\r\n // if (parseInt(matches[1]) >= 14) {\r\n // this._badOS = false;\r\n // }\r\n // }\r\n // Detect if we are running on a faulty buggy desktop OS.\r\n this._badDesktopOS = /^((?!chrome|android).)*safari/i.test(navigator.userAgent);\r\n this._creationOptions = options;\r\n console.log(\"Babylon.js v\" + ThinEngine.Version + \" - \" + this.description);\r\n }\r\n Object.defineProperty(ThinEngine, \"NpmPackage\", {\r\n /**\r\n * Returns the current npm package of the sdk\r\n */\r\n // Not mixed with Version for tooling purpose.\r\n get: function () {\r\n return \"babylonjs@4.2.0\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine, \"Version\", {\r\n /**\r\n * Returns the current version of the framework\r\n */\r\n get: function () {\r\n return \"4.2.0\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"description\", {\r\n /**\r\n * Returns a string describing the current engine\r\n */\r\n get: function () {\r\n var description = \"WebGL\" + this.webGLVersion;\r\n if (this._caps.parallelShaderCompile) {\r\n description += \" - Parallel shader compilation\";\r\n }\r\n return description;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine, \"ShadersRepository\", {\r\n /**\r\n * Gets or sets the relative url used to load shaders if using the engine in non-minified mode\r\n */\r\n get: function () {\r\n return Effect.ShadersRepository;\r\n },\r\n set: function (value) {\r\n Effect.ShadersRepository = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"supportsUniformBuffers\", {\r\n /**\r\n * Gets a boolean indicating that the engine supports uniform buffers\r\n * @see https://doc.babylonjs.com/features/webgl2#uniform-buffer-objets\r\n */\r\n get: function () {\r\n return this.webGLVersion > 1 && !this.disableUniformBuffers;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"_shouldUseHighPrecisionShader\", {\r\n /** @hidden */\r\n get: function () {\r\n return !!(this._caps.highPrecisionShaderSupported && this._highPrecisionShadersAllowed);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"needPOTTextures\", {\r\n /**\r\n * Gets a boolean indicating that only power of 2 textures are supported\r\n * Please note that you can still use non power of 2 textures but in this case the engine will forcefully convert them\r\n */\r\n get: function () {\r\n return this._webGLVersion < 2 || this.forcePOTTextures;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"doNotHandleContextLost\", {\r\n /**\r\n * Gets or sets a boolean indicating if resources should be retained to be able to handle context lost events\r\n * @see https://doc.babylonjs.com/how_to/optimizing_your_scene#handling-webgl-context-lost\r\n */\r\n get: function () {\r\n return this._doNotHandleContextLost;\r\n },\r\n set: function (value) {\r\n this._doNotHandleContextLost = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"_supportsHardwareTextureRescaling\", {\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"framebufferDimensionsObject\", {\r\n /**\r\n * sets the object from which width and height will be taken from when getting render width and height\r\n * Will fallback to the gl object\r\n * @param dimensions the framebuffer width and height that will be used.\r\n */\r\n set: function (dimensions) {\r\n this._framebufferDimensionsObject = dimensions;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"currentViewport\", {\r\n /**\r\n * Gets the current viewport\r\n */\r\n get: function () {\r\n return this._cachedViewport;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"emptyTexture\", {\r\n /**\r\n * Gets the default empty texture\r\n */\r\n get: function () {\r\n if (!this._emptyTexture) {\r\n this._emptyTexture = this.createRawTexture(new Uint8Array(4), 1, 1, 5, false, false, 1);\r\n }\r\n return this._emptyTexture;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"emptyTexture3D\", {\r\n /**\r\n * Gets the default empty 3D texture\r\n */\r\n get: function () {\r\n if (!this._emptyTexture3D) {\r\n this._emptyTexture3D = this.createRawTexture3D(new Uint8Array(4), 1, 1, 1, 5, false, false, 1);\r\n }\r\n return this._emptyTexture3D;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"emptyTexture2DArray\", {\r\n /**\r\n * Gets the default empty 2D array texture\r\n */\r\n get: function () {\r\n if (!this._emptyTexture2DArray) {\r\n this._emptyTexture2DArray = this.createRawTexture2DArray(new Uint8Array(4), 1, 1, 1, 5, false, false, 1);\r\n }\r\n return this._emptyTexture2DArray;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"emptyCubeTexture\", {\r\n /**\r\n * Gets the default empty cube texture\r\n */\r\n get: function () {\r\n if (!this._emptyCubeTexture) {\r\n var faceData = new Uint8Array(4);\r\n var cubeData = [faceData, faceData, faceData, faceData, faceData, faceData];\r\n this._emptyCubeTexture = this.createRawCubeTexture(cubeData, 1, 5, 0, false, false, 1);\r\n }\r\n return this._emptyCubeTexture;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n ThinEngine.prototype._rebuildInternalTextures = function () {\r\n var currentState = this._internalTexturesCache.slice(); // Do a copy because the rebuild will add proxies\r\n for (var _i = 0, currentState_1 = currentState; _i < currentState_1.length; _i++) {\r\n var internalTexture = currentState_1[_i];\r\n internalTexture._rebuild();\r\n }\r\n };\r\n ThinEngine.prototype._rebuildEffects = function () {\r\n for (var key in this._compiledEffects) {\r\n var effect = this._compiledEffects[key];\r\n effect._prepareEffect();\r\n }\r\n Effect.ResetCache();\r\n };\r\n /**\r\n * Gets a boolean indicating if all created effects are ready\r\n * @returns true if all effects are ready\r\n */\r\n ThinEngine.prototype.areAllEffectsReady = function () {\r\n for (var key in this._compiledEffects) {\r\n var effect = this._compiledEffects[key];\r\n if (!effect.isReady()) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n ThinEngine.prototype._rebuildBuffers = function () {\r\n // Uniforms\r\n for (var _i = 0, _a = this._uniformBuffers; _i < _a.length; _i++) {\r\n var uniformBuffer = _a[_i];\r\n uniformBuffer._rebuild();\r\n }\r\n };\r\n ThinEngine.prototype._initGLContext = function () {\r\n // Caps\r\n this._caps = {\r\n maxTexturesImageUnits: this._gl.getParameter(this._gl.MAX_TEXTURE_IMAGE_UNITS),\r\n maxCombinedTexturesImageUnits: this._gl.getParameter(this._gl.MAX_COMBINED_TEXTURE_IMAGE_UNITS),\r\n maxVertexTextureImageUnits: this._gl.getParameter(this._gl.MAX_VERTEX_TEXTURE_IMAGE_UNITS),\r\n maxTextureSize: this._gl.getParameter(this._gl.MAX_TEXTURE_SIZE),\r\n maxSamples: this._webGLVersion > 1 ? this._gl.getParameter(this._gl.MAX_SAMPLES) : 1,\r\n maxCubemapTextureSize: this._gl.getParameter(this._gl.MAX_CUBE_MAP_TEXTURE_SIZE),\r\n maxRenderTextureSize: this._gl.getParameter(this._gl.MAX_RENDERBUFFER_SIZE),\r\n maxVertexAttribs: this._gl.getParameter(this._gl.MAX_VERTEX_ATTRIBS),\r\n maxVaryingVectors: this._gl.getParameter(this._gl.MAX_VARYING_VECTORS),\r\n maxFragmentUniformVectors: this._gl.getParameter(this._gl.MAX_FRAGMENT_UNIFORM_VECTORS),\r\n maxVertexUniformVectors: this._gl.getParameter(this._gl.MAX_VERTEX_UNIFORM_VECTORS),\r\n parallelShaderCompile: this._gl.getExtension('KHR_parallel_shader_compile'),\r\n standardDerivatives: this._webGLVersion > 1 || (this._gl.getExtension('OES_standard_derivatives') !== null),\r\n maxAnisotropy: 1,\r\n astc: this._gl.getExtension('WEBGL_compressed_texture_astc') || this._gl.getExtension('WEBKIT_WEBGL_compressed_texture_astc'),\r\n bptc: this._gl.getExtension('EXT_texture_compression_bptc') || this._gl.getExtension('WEBKIT_EXT_texture_compression_bptc'),\r\n s3tc: this._gl.getExtension('WEBGL_compressed_texture_s3tc') || this._gl.getExtension('WEBKIT_WEBGL_compressed_texture_s3tc'),\r\n pvrtc: this._gl.getExtension('WEBGL_compressed_texture_pvrtc') || this._gl.getExtension('WEBKIT_WEBGL_compressed_texture_pvrtc'),\r\n etc1: this._gl.getExtension('WEBGL_compressed_texture_etc1') || this._gl.getExtension('WEBKIT_WEBGL_compressed_texture_etc1'),\r\n etc2: this._gl.getExtension('WEBGL_compressed_texture_etc') || this._gl.getExtension('WEBKIT_WEBGL_compressed_texture_etc') ||\r\n this._gl.getExtension('WEBGL_compressed_texture_es3_0'),\r\n textureAnisotropicFilterExtension: this._gl.getExtension('EXT_texture_filter_anisotropic') || this._gl.getExtension('WEBKIT_EXT_texture_filter_anisotropic') || this._gl.getExtension('MOZ_EXT_texture_filter_anisotropic'),\r\n uintIndices: this._webGLVersion > 1 || this._gl.getExtension('OES_element_index_uint') !== null,\r\n fragmentDepthSupported: this._webGLVersion > 1 || this._gl.getExtension('EXT_frag_depth') !== null,\r\n highPrecisionShaderSupported: false,\r\n timerQuery: this._gl.getExtension('EXT_disjoint_timer_query_webgl2') || this._gl.getExtension(\"EXT_disjoint_timer_query\"),\r\n canUseTimestampForTimerQuery: false,\r\n drawBuffersExtension: false,\r\n maxMSAASamples: 1,\r\n colorBufferFloat: this._webGLVersion > 1 && this._gl.getExtension('EXT_color_buffer_float'),\r\n textureFloat: (this._webGLVersion > 1 || this._gl.getExtension('OES_texture_float')) ? true : false,\r\n textureHalfFloat: (this._webGLVersion > 1 || this._gl.getExtension('OES_texture_half_float')) ? true : false,\r\n textureHalfFloatRender: false,\r\n textureFloatLinearFiltering: false,\r\n textureFloatRender: false,\r\n textureHalfFloatLinearFiltering: false,\r\n vertexArrayObject: false,\r\n instancedArrays: false,\r\n textureLOD: (this._webGLVersion > 1 || this._gl.getExtension('EXT_shader_texture_lod')) ? true : false,\r\n blendMinMax: false,\r\n multiview: this._gl.getExtension('OVR_multiview2'),\r\n oculusMultiview: this._gl.getExtension('OCULUS_multiview'),\r\n depthTextureExtension: false\r\n };\r\n // Infos\r\n this._glVersion = this._gl.getParameter(this._gl.VERSION);\r\n var rendererInfo = this._gl.getExtension(\"WEBGL_debug_renderer_info\");\r\n if (rendererInfo != null) {\r\n this._glRenderer = this._gl.getParameter(rendererInfo.UNMASKED_RENDERER_WEBGL);\r\n this._glVendor = this._gl.getParameter(rendererInfo.UNMASKED_VENDOR_WEBGL);\r\n }\r\n if (!this._glVendor) {\r\n this._glVendor = \"Unknown vendor\";\r\n }\r\n if (!this._glRenderer) {\r\n this._glRenderer = \"Unknown renderer\";\r\n }\r\n // Constants\r\n if (this._gl.HALF_FLOAT_OES !== 0x8D61) {\r\n this._gl.HALF_FLOAT_OES = 0x8D61; // Half floating-point type (16-bit).\r\n }\r\n if (this._gl.RGBA16F !== 0x881A) {\r\n this._gl.RGBA16F = 0x881A; // RGBA 16-bit floating-point color-renderable internal sized format.\r\n }\r\n if (this._gl.RGBA32F !== 0x8814) {\r\n this._gl.RGBA32F = 0x8814; // RGBA 32-bit floating-point color-renderable internal sized format.\r\n }\r\n if (this._gl.DEPTH24_STENCIL8 !== 35056) {\r\n this._gl.DEPTH24_STENCIL8 = 35056;\r\n }\r\n // Extensions\r\n if (this._caps.timerQuery) {\r\n if (this._webGLVersion === 1) {\r\n this._gl.getQuery = this._caps.timerQuery.getQueryEXT.bind(this._caps.timerQuery);\r\n }\r\n this._caps.canUseTimestampForTimerQuery = this._gl.getQuery(this._caps.timerQuery.TIMESTAMP_EXT, this._caps.timerQuery.QUERY_COUNTER_BITS_EXT) > 0;\r\n }\r\n this._caps.maxAnisotropy = this._caps.textureAnisotropicFilterExtension ? this._gl.getParameter(this._caps.textureAnisotropicFilterExtension.MAX_TEXTURE_MAX_ANISOTROPY_EXT) : 0;\r\n this._caps.textureFloatLinearFiltering = this._caps.textureFloat && this._gl.getExtension('OES_texture_float_linear') ? true : false;\r\n this._caps.textureFloatRender = this._caps.textureFloat && this._canRenderToFloatFramebuffer() ? true : false;\r\n this._caps.textureHalfFloatLinearFiltering = (this._webGLVersion > 1 || (this._caps.textureHalfFloat && this._gl.getExtension('OES_texture_half_float_linear'))) ? true : false;\r\n // Checks if some of the format renders first to allow the use of webgl inspector.\r\n if (this._webGLVersion > 1) {\r\n if (this._gl.HALF_FLOAT_OES !== 0x140B) {\r\n this._gl.HALF_FLOAT_OES = 0x140B;\r\n }\r\n }\r\n this._caps.textureHalfFloatRender = this._caps.textureHalfFloat && this._canRenderToHalfFloatFramebuffer();\r\n // Draw buffers\r\n if (this._webGLVersion > 1) {\r\n this._caps.drawBuffersExtension = true;\r\n this._caps.maxMSAASamples = this._gl.getParameter(this._gl.MAX_SAMPLES);\r\n }\r\n else {\r\n var drawBuffersExtension = this._gl.getExtension('WEBGL_draw_buffers');\r\n if (drawBuffersExtension !== null) {\r\n this._caps.drawBuffersExtension = true;\r\n this._gl.drawBuffers = drawBuffersExtension.drawBuffersWEBGL.bind(drawBuffersExtension);\r\n this._gl.DRAW_FRAMEBUFFER = this._gl.FRAMEBUFFER;\r\n for (var i = 0; i < 16; i++) {\r\n this._gl[\"COLOR_ATTACHMENT\" + i + \"_WEBGL\"] = drawBuffersExtension[\"COLOR_ATTACHMENT\" + i + \"_WEBGL\"];\r\n }\r\n }\r\n }\r\n // Depth Texture\r\n if (this._webGLVersion > 1) {\r\n this._caps.depthTextureExtension = true;\r\n }\r\n else {\r\n var depthTextureExtension = this._gl.getExtension('WEBGL_depth_texture');\r\n if (depthTextureExtension != null) {\r\n this._caps.depthTextureExtension = true;\r\n this._gl.UNSIGNED_INT_24_8 = depthTextureExtension.UNSIGNED_INT_24_8_WEBGL;\r\n }\r\n }\r\n // Vertex array object\r\n if (this.disableVertexArrayObjects) {\r\n this._caps.vertexArrayObject = false;\r\n }\r\n else if (this._webGLVersion > 1) {\r\n this._caps.vertexArrayObject = true;\r\n }\r\n else {\r\n var vertexArrayObjectExtension = this._gl.getExtension('OES_vertex_array_object');\r\n if (vertexArrayObjectExtension != null) {\r\n this._caps.vertexArrayObject = true;\r\n this._gl.createVertexArray = vertexArrayObjectExtension.createVertexArrayOES.bind(vertexArrayObjectExtension);\r\n this._gl.bindVertexArray = vertexArrayObjectExtension.bindVertexArrayOES.bind(vertexArrayObjectExtension);\r\n this._gl.deleteVertexArray = vertexArrayObjectExtension.deleteVertexArrayOES.bind(vertexArrayObjectExtension);\r\n }\r\n }\r\n // Instances count\r\n if (this._webGLVersion > 1) {\r\n this._caps.instancedArrays = true;\r\n }\r\n else {\r\n var instanceExtension = this._gl.getExtension('ANGLE_instanced_arrays');\r\n if (instanceExtension != null) {\r\n this._caps.instancedArrays = true;\r\n this._gl.drawArraysInstanced = instanceExtension.drawArraysInstancedANGLE.bind(instanceExtension);\r\n this._gl.drawElementsInstanced = instanceExtension.drawElementsInstancedANGLE.bind(instanceExtension);\r\n this._gl.vertexAttribDivisor = instanceExtension.vertexAttribDivisorANGLE.bind(instanceExtension);\r\n }\r\n else {\r\n this._caps.instancedArrays = false;\r\n }\r\n }\r\n if (this._gl.getShaderPrecisionFormat) {\r\n var vertex_highp = this._gl.getShaderPrecisionFormat(this._gl.VERTEX_SHADER, this._gl.HIGH_FLOAT);\r\n var fragment_highp = this._gl.getShaderPrecisionFormat(this._gl.FRAGMENT_SHADER, this._gl.HIGH_FLOAT);\r\n if (vertex_highp && fragment_highp) {\r\n this._caps.highPrecisionShaderSupported = vertex_highp.precision !== 0 && fragment_highp.precision !== 0;\r\n }\r\n }\r\n if (this._webGLVersion > 1) {\r\n this._caps.blendMinMax = true;\r\n }\r\n else {\r\n var blendMinMaxExtension = this._gl.getExtension('EXT_blend_minmax');\r\n if (blendMinMaxExtension != null) {\r\n this._caps.blendMinMax = true;\r\n this._gl.MAX = blendMinMaxExtension.MAX_EXT;\r\n this._gl.MIN = blendMinMaxExtension.MIN_EXT;\r\n }\r\n }\r\n // Depth buffer\r\n this._depthCullingState.depthTest = true;\r\n this._depthCullingState.depthFunc = this._gl.LEQUAL;\r\n this._depthCullingState.depthMask = true;\r\n // Texture maps\r\n this._maxSimultaneousTextures = this._caps.maxCombinedTexturesImageUnits;\r\n for (var slot = 0; slot < this._maxSimultaneousTextures; slot++) {\r\n this._nextFreeTextureSlots.push(slot);\r\n }\r\n };\r\n Object.defineProperty(ThinEngine.prototype, \"webGLVersion\", {\r\n /**\r\n * Gets version of the current webGL context\r\n */\r\n get: function () {\r\n return this._webGLVersion;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets a string identifying the name of the class\r\n * @returns \"Engine\" string\r\n */\r\n ThinEngine.prototype.getClassName = function () {\r\n return \"ThinEngine\";\r\n };\r\n Object.defineProperty(ThinEngine.prototype, \"isStencilEnable\", {\r\n /**\r\n * Returns true if the stencil buffer has been enabled through the creation option of the context.\r\n */\r\n get: function () {\r\n return this._isStencilEnable;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n ThinEngine.prototype._prepareWorkingCanvas = function () {\r\n if (this._workingCanvas) {\r\n return;\r\n }\r\n this._workingCanvas = CanvasGenerator.CreateCanvas(1, 1);\r\n var context = this._workingCanvas.getContext(\"2d\");\r\n if (context) {\r\n this._workingContext = context;\r\n }\r\n };\r\n /**\r\n * Reset the texture cache to empty state\r\n */\r\n ThinEngine.prototype.resetTextureCache = function () {\r\n for (var key in this._boundTexturesCache) {\r\n if (!this._boundTexturesCache.hasOwnProperty(key)) {\r\n continue;\r\n }\r\n this._boundTexturesCache[key] = null;\r\n }\r\n this._currentTextureChannel = -1;\r\n };\r\n /**\r\n * Gets an object containing information about the current webGL context\r\n * @returns an object containing the vender, the renderer and the version of the current webGL context\r\n */\r\n ThinEngine.prototype.getGlInfo = function () {\r\n return {\r\n vendor: this._glVendor,\r\n renderer: this._glRenderer,\r\n version: this._glVersion\r\n };\r\n };\r\n /**\r\n * Defines the hardware scaling level.\r\n * By default the hardware scaling level is computed from the window device ratio.\r\n * if level = 1 then the engine will render at the exact resolution of the canvas. If level = 0.5 then the engine will render at twice the size of the canvas.\r\n * @param level defines the level to use\r\n */\r\n ThinEngine.prototype.setHardwareScalingLevel = function (level) {\r\n this._hardwareScalingLevel = level;\r\n this.resize();\r\n };\r\n /**\r\n * Gets the current hardware scaling level.\r\n * By default the hardware scaling level is computed from the window device ratio.\r\n * if level = 1 then the engine will render at the exact resolution of the canvas. If level = 0.5 then the engine will render at twice the size of the canvas.\r\n * @returns a number indicating the current hardware scaling level\r\n */\r\n ThinEngine.prototype.getHardwareScalingLevel = function () {\r\n return this._hardwareScalingLevel;\r\n };\r\n /**\r\n * Gets the list of loaded textures\r\n * @returns an array containing all loaded textures\r\n */\r\n ThinEngine.prototype.getLoadedTexturesCache = function () {\r\n return this._internalTexturesCache;\r\n };\r\n /**\r\n * Gets the object containing all engine capabilities\r\n * @returns the EngineCapabilities object\r\n */\r\n ThinEngine.prototype.getCaps = function () {\r\n return this._caps;\r\n };\r\n /**\r\n * stop executing a render loop function and remove it from the execution array\r\n * @param renderFunction defines the function to be removed. If not provided all functions will be removed.\r\n */\r\n ThinEngine.prototype.stopRenderLoop = function (renderFunction) {\r\n if (!renderFunction) {\r\n this._activeRenderLoops = [];\r\n return;\r\n }\r\n var index = this._activeRenderLoops.indexOf(renderFunction);\r\n if (index >= 0) {\r\n this._activeRenderLoops.splice(index, 1);\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._renderLoop = function () {\r\n if (!this._contextWasLost) {\r\n var shouldRender = true;\r\n if (!this.renderEvenInBackground && this._windowIsBackground) {\r\n shouldRender = false;\r\n }\r\n if (shouldRender) {\r\n // Start new frame\r\n this.beginFrame();\r\n for (var index = 0; index < this._activeRenderLoops.length; index++) {\r\n var renderFunction = this._activeRenderLoops[index];\r\n renderFunction();\r\n }\r\n // Present\r\n this.endFrame();\r\n }\r\n }\r\n if (this._activeRenderLoops.length > 0) {\r\n this._frameHandler = this._queueNewFrame(this._boundRenderFunction, this.getHostWindow());\r\n }\r\n else {\r\n this._renderingQueueLaunched = false;\r\n }\r\n };\r\n /**\r\n * Gets the HTML canvas attached with the current webGL context\r\n * @returns a HTML canvas\r\n */\r\n ThinEngine.prototype.getRenderingCanvas = function () {\r\n return this._renderingCanvas;\r\n };\r\n /**\r\n * Gets host window\r\n * @returns the host window object\r\n */\r\n ThinEngine.prototype.getHostWindow = function () {\r\n if (!DomManagement.IsWindowObjectExist()) {\r\n return null;\r\n }\r\n if (this._renderingCanvas && this._renderingCanvas.ownerDocument && this._renderingCanvas.ownerDocument.defaultView) {\r\n return this._renderingCanvas.ownerDocument.defaultView;\r\n }\r\n return window;\r\n };\r\n /**\r\n * Gets the current render width\r\n * @param useScreen defines if screen size must be used (or the current render target if any)\r\n * @returns a number defining the current render width\r\n */\r\n ThinEngine.prototype.getRenderWidth = function (useScreen) {\r\n if (useScreen === void 0) { useScreen = false; }\r\n if (!useScreen && this._currentRenderTarget) {\r\n return this._currentRenderTarget.width;\r\n }\r\n return this._framebufferDimensionsObject ? this._framebufferDimensionsObject.framebufferWidth : this._gl.drawingBufferWidth;\r\n };\r\n /**\r\n * Gets the current render height\r\n * @param useScreen defines if screen size must be used (or the current render target if any)\r\n * @returns a number defining the current render height\r\n */\r\n ThinEngine.prototype.getRenderHeight = function (useScreen) {\r\n if (useScreen === void 0) { useScreen = false; }\r\n if (!useScreen && this._currentRenderTarget) {\r\n return this._currentRenderTarget.height;\r\n }\r\n return this._framebufferDimensionsObject ? this._framebufferDimensionsObject.framebufferHeight : this._gl.drawingBufferHeight;\r\n };\r\n /**\r\n * Can be used to override the current requestAnimationFrame requester.\r\n * @hidden\r\n */\r\n ThinEngine.prototype._queueNewFrame = function (bindedRenderFunction, requester) {\r\n return ThinEngine.QueueNewFrame(bindedRenderFunction, requester);\r\n };\r\n /**\r\n * Register and execute a render loop. The engine can have more than one render function\r\n * @param renderFunction defines the function to continuously execute\r\n */\r\n ThinEngine.prototype.runRenderLoop = function (renderFunction) {\r\n if (this._activeRenderLoops.indexOf(renderFunction) !== -1) {\r\n return;\r\n }\r\n this._activeRenderLoops.push(renderFunction);\r\n if (!this._renderingQueueLaunched) {\r\n this._renderingQueueLaunched = true;\r\n this._boundRenderFunction = this._renderLoop.bind(this);\r\n this._frameHandler = this._queueNewFrame(this._boundRenderFunction, this.getHostWindow());\r\n }\r\n };\r\n /**\r\n * Clear the current render buffer or the current render target (if any is set up)\r\n * @param color defines the color to use\r\n * @param backBuffer defines if the back buffer must be cleared\r\n * @param depth defines if the depth buffer must be cleared\r\n * @param stencil defines if the stencil buffer must be cleared\r\n */\r\n ThinEngine.prototype.clear = function (color, backBuffer, depth, stencil) {\r\n if (stencil === void 0) { stencil = false; }\r\n this.applyStates();\r\n var mode = 0;\r\n if (backBuffer && color) {\r\n this._gl.clearColor(color.r, color.g, color.b, color.a !== undefined ? color.a : 1.0);\r\n mode |= this._gl.COLOR_BUFFER_BIT;\r\n }\r\n if (depth) {\r\n if (this.useReverseDepthBuffer) {\r\n this._depthCullingState.depthFunc = this._gl.GREATER;\r\n this._gl.clearDepth(0.0);\r\n }\r\n else {\r\n this._gl.clearDepth(1.0);\r\n }\r\n mode |= this._gl.DEPTH_BUFFER_BIT;\r\n }\r\n if (stencil) {\r\n this._gl.clearStencil(0);\r\n mode |= this._gl.STENCIL_BUFFER_BIT;\r\n }\r\n this._gl.clear(mode);\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._viewport = function (x, y, width, height) {\r\n if (x !== this._viewportCached.x ||\r\n y !== this._viewportCached.y ||\r\n width !== this._viewportCached.z ||\r\n height !== this._viewportCached.w) {\r\n this._viewportCached.x = x;\r\n this._viewportCached.y = y;\r\n this._viewportCached.z = width;\r\n this._viewportCached.w = height;\r\n this._gl.viewport(x, y, width, height);\r\n }\r\n };\r\n /**\r\n * Set the WebGL's viewport\r\n * @param viewport defines the viewport element to be used\r\n * @param requiredWidth defines the width required for rendering. If not provided the rendering canvas' width is used\r\n * @param requiredHeight defines the height required for rendering. If not provided the rendering canvas' height is used\r\n */\r\n ThinEngine.prototype.setViewport = function (viewport, requiredWidth, requiredHeight) {\r\n var width = requiredWidth || this.getRenderWidth();\r\n var height = requiredHeight || this.getRenderHeight();\r\n var x = viewport.x || 0;\r\n var y = viewport.y || 0;\r\n this._cachedViewport = viewport;\r\n this._viewport(x * width, y * height, width * viewport.width, height * viewport.height);\r\n };\r\n /**\r\n * Begin a new frame\r\n */\r\n ThinEngine.prototype.beginFrame = function () {\r\n };\r\n /**\r\n * Enf the current frame\r\n */\r\n ThinEngine.prototype.endFrame = function () {\r\n // Force a flush in case we are using a bad OS.\r\n if (this._badOS) {\r\n this.flushFramebuffer();\r\n }\r\n };\r\n /**\r\n * Resize the view according to the canvas' size\r\n */\r\n ThinEngine.prototype.resize = function () {\r\n var width;\r\n var height;\r\n if (DomManagement.IsWindowObjectExist()) {\r\n width = this._renderingCanvas ? (this._renderingCanvas.clientWidth || this._renderingCanvas.width) : window.innerWidth;\r\n height = this._renderingCanvas ? (this._renderingCanvas.clientHeight || this._renderingCanvas.height) : window.innerHeight;\r\n }\r\n else {\r\n width = this._renderingCanvas ? this._renderingCanvas.width : 100;\r\n height = this._renderingCanvas ? this._renderingCanvas.height : 100;\r\n }\r\n this.setSize(width / this._hardwareScalingLevel, height / this._hardwareScalingLevel);\r\n };\r\n /**\r\n * Force a specific size of the canvas\r\n * @param width defines the new canvas' width\r\n * @param height defines the new canvas' height\r\n * @returns true if the size was changed\r\n */\r\n ThinEngine.prototype.setSize = function (width, height) {\r\n if (!this._renderingCanvas) {\r\n return false;\r\n }\r\n width = width | 0;\r\n height = height | 0;\r\n if (this._renderingCanvas.width === width && this._renderingCanvas.height === height) {\r\n return false;\r\n }\r\n this._renderingCanvas.width = width;\r\n this._renderingCanvas.height = height;\r\n return true;\r\n };\r\n /**\r\n * Binds the frame buffer to the specified texture.\r\n * @param texture The texture to render to or null for the default canvas\r\n * @param faceIndex The face of the texture to render to in case of cube texture\r\n * @param requiredWidth The width of the target to render to\r\n * @param requiredHeight The height of the target to render to\r\n * @param forceFullscreenViewport Forces the viewport to be the entire texture/screen if true\r\n * @param lodLevel defines the lod level to bind to the frame buffer\r\n * @param layer defines the 2d array index to bind to frame buffer to\r\n */\r\n ThinEngine.prototype.bindFramebuffer = function (texture, faceIndex, requiredWidth, requiredHeight, forceFullscreenViewport, lodLevel, layer) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (lodLevel === void 0) { lodLevel = 0; }\r\n if (layer === void 0) { layer = 0; }\r\n if (this._currentRenderTarget) {\r\n this.unBindFramebuffer(this._currentRenderTarget);\r\n }\r\n this._currentRenderTarget = texture;\r\n this._bindUnboundFramebuffer(texture._MSAAFramebuffer ? texture._MSAAFramebuffer : texture._framebuffer);\r\n var gl = this._gl;\r\n if (texture.is2DArray) {\r\n gl.framebufferTextureLayer(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, texture._webGLTexture, lodLevel, layer);\r\n }\r\n else if (texture.isCube) {\r\n gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_CUBE_MAP_POSITIVE_X + faceIndex, texture._webGLTexture, lodLevel);\r\n }\r\n var depthStencilTexture = texture._depthStencilTexture;\r\n if (depthStencilTexture) {\r\n var attachment = (depthStencilTexture._generateStencilBuffer) ? gl.DEPTH_STENCIL_ATTACHMENT : gl.DEPTH_ATTACHMENT;\r\n if (texture.is2DArray) {\r\n gl.framebufferTextureLayer(gl.FRAMEBUFFER, attachment, depthStencilTexture._webGLTexture, lodLevel, layer);\r\n }\r\n else if (texture.isCube) {\r\n gl.framebufferTexture2D(gl.FRAMEBUFFER, attachment, gl.TEXTURE_CUBE_MAP_POSITIVE_X + faceIndex, depthStencilTexture._webGLTexture, lodLevel);\r\n }\r\n else {\r\n gl.framebufferTexture2D(gl.FRAMEBUFFER, attachment, gl.TEXTURE_2D, depthStencilTexture._webGLTexture, lodLevel);\r\n }\r\n }\r\n if (this._cachedViewport && !forceFullscreenViewport) {\r\n this.setViewport(this._cachedViewport, requiredWidth, requiredHeight);\r\n }\r\n else {\r\n if (!requiredWidth) {\r\n requiredWidth = texture.width;\r\n if (lodLevel) {\r\n requiredWidth = requiredWidth / Math.pow(2, lodLevel);\r\n }\r\n }\r\n if (!requiredHeight) {\r\n requiredHeight = texture.height;\r\n if (lodLevel) {\r\n requiredHeight = requiredHeight / Math.pow(2, lodLevel);\r\n }\r\n }\r\n this._viewport(0, 0, requiredWidth, requiredHeight);\r\n }\r\n this.wipeCaches();\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._bindUnboundFramebuffer = function (framebuffer) {\r\n if (this._currentFramebuffer !== framebuffer) {\r\n this._gl.bindFramebuffer(this._gl.FRAMEBUFFER, framebuffer);\r\n this._currentFramebuffer = framebuffer;\r\n }\r\n };\r\n /**\r\n * Unbind the current render target texture from the webGL context\r\n * @param texture defines the render target texture to unbind\r\n * @param disableGenerateMipMaps defines a boolean indicating that mipmaps must not be generated\r\n * @param onBeforeUnbind defines a function which will be called before the effective unbind\r\n */\r\n ThinEngine.prototype.unBindFramebuffer = function (texture, disableGenerateMipMaps, onBeforeUnbind) {\r\n if (disableGenerateMipMaps === void 0) { disableGenerateMipMaps = false; }\r\n this._currentRenderTarget = null;\r\n // If MSAA, we need to bitblt back to main texture\r\n var gl = this._gl;\r\n if (texture._MSAAFramebuffer) {\r\n if (texture._textureArray) {\r\n // This texture is part of a MRT texture, we need to treat all attachments\r\n this.unBindMultiColorAttachmentFramebuffer(texture._textureArray, disableGenerateMipMaps, onBeforeUnbind);\r\n return;\r\n }\r\n gl.bindFramebuffer(gl.READ_FRAMEBUFFER, texture._MSAAFramebuffer);\r\n gl.bindFramebuffer(gl.DRAW_FRAMEBUFFER, texture._framebuffer);\r\n gl.blitFramebuffer(0, 0, texture.width, texture.height, 0, 0, texture.width, texture.height, gl.COLOR_BUFFER_BIT, gl.NEAREST);\r\n }\r\n if (texture.generateMipMaps && !disableGenerateMipMaps && !texture.isCube) {\r\n this._bindTextureDirectly(gl.TEXTURE_2D, texture, true);\r\n gl.generateMipmap(gl.TEXTURE_2D);\r\n this._bindTextureDirectly(gl.TEXTURE_2D, null);\r\n }\r\n if (onBeforeUnbind) {\r\n if (texture._MSAAFramebuffer) {\r\n // Bind the correct framebuffer\r\n this._bindUnboundFramebuffer(texture._framebuffer);\r\n }\r\n onBeforeUnbind();\r\n }\r\n this._bindUnboundFramebuffer(null);\r\n };\r\n /**\r\n * Force a webGL flush (ie. a flush of all waiting webGL commands)\r\n */\r\n ThinEngine.prototype.flushFramebuffer = function () {\r\n this._gl.flush();\r\n };\r\n /**\r\n * Unbind the current render target and bind the default framebuffer\r\n */\r\n ThinEngine.prototype.restoreDefaultFramebuffer = function () {\r\n if (this._currentRenderTarget) {\r\n this.unBindFramebuffer(this._currentRenderTarget);\r\n }\r\n else {\r\n this._bindUnboundFramebuffer(null);\r\n }\r\n if (this._cachedViewport) {\r\n this.setViewport(this._cachedViewport);\r\n }\r\n this.wipeCaches();\r\n };\r\n // VBOs\r\n /** @hidden */\r\n ThinEngine.prototype._resetVertexBufferBinding = function () {\r\n this.bindArrayBuffer(null);\r\n this._cachedVertexBuffers = null;\r\n };\r\n /**\r\n * Creates a vertex buffer\r\n * @param data the data for the vertex buffer\r\n * @returns the new WebGL static buffer\r\n */\r\n ThinEngine.prototype.createVertexBuffer = function (data) {\r\n return this._createVertexBuffer(data, this._gl.STATIC_DRAW);\r\n };\r\n ThinEngine.prototype._createVertexBuffer = function (data, usage) {\r\n var vbo = this._gl.createBuffer();\r\n if (!vbo) {\r\n throw new Error(\"Unable to create vertex buffer\");\r\n }\r\n var dataBuffer = new WebGLDataBuffer(vbo);\r\n this.bindArrayBuffer(dataBuffer);\r\n if (data instanceof Array) {\r\n this._gl.bufferData(this._gl.ARRAY_BUFFER, new Float32Array(data), this._gl.STATIC_DRAW);\r\n }\r\n else {\r\n this._gl.bufferData(this._gl.ARRAY_BUFFER, data, this._gl.STATIC_DRAW);\r\n }\r\n this._resetVertexBufferBinding();\r\n dataBuffer.references = 1;\r\n return dataBuffer;\r\n };\r\n /**\r\n * Creates a dynamic vertex buffer\r\n * @param data the data for the dynamic vertex buffer\r\n * @returns the new WebGL dynamic buffer\r\n */\r\n ThinEngine.prototype.createDynamicVertexBuffer = function (data) {\r\n return this._createVertexBuffer(data, this._gl.DYNAMIC_DRAW);\r\n };\r\n ThinEngine.prototype._resetIndexBufferBinding = function () {\r\n this.bindIndexBuffer(null);\r\n this._cachedIndexBuffer = null;\r\n };\r\n /**\r\n * Creates a new index buffer\r\n * @param indices defines the content of the index buffer\r\n * @param updatable defines if the index buffer must be updatable\r\n * @returns a new webGL buffer\r\n */\r\n ThinEngine.prototype.createIndexBuffer = function (indices, updatable) {\r\n var vbo = this._gl.createBuffer();\r\n var dataBuffer = new WebGLDataBuffer(vbo);\r\n if (!vbo) {\r\n throw new Error(\"Unable to create index buffer\");\r\n }\r\n this.bindIndexBuffer(dataBuffer);\r\n var data = this._normalizeIndexData(indices);\r\n this._gl.bufferData(this._gl.ELEMENT_ARRAY_BUFFER, data, updatable ? this._gl.DYNAMIC_DRAW : this._gl.STATIC_DRAW);\r\n this._resetIndexBufferBinding();\r\n dataBuffer.references = 1;\r\n dataBuffer.is32Bits = (data.BYTES_PER_ELEMENT === 4);\r\n return dataBuffer;\r\n };\r\n ThinEngine.prototype._normalizeIndexData = function (indices) {\r\n if (indices instanceof Uint16Array) {\r\n return indices;\r\n }\r\n // Check 32 bit support\r\n if (this._caps.uintIndices) {\r\n if (indices instanceof Uint32Array) {\r\n return indices;\r\n }\r\n else {\r\n // number[] or Int32Array, check if 32 bit is necessary\r\n for (var index = 0; index < indices.length; index++) {\r\n if (indices[index] >= 65535) {\r\n return new Uint32Array(indices);\r\n }\r\n }\r\n return new Uint16Array(indices);\r\n }\r\n }\r\n // No 32 bit support, force conversion to 16 bit (values greater 16 bit are lost)\r\n return new Uint16Array(indices);\r\n };\r\n /**\r\n * Bind a webGL buffer to the webGL context\r\n * @param buffer defines the buffer to bind\r\n */\r\n ThinEngine.prototype.bindArrayBuffer = function (buffer) {\r\n if (!this._vaoRecordInProgress) {\r\n this._unbindVertexArrayObject();\r\n }\r\n this.bindBuffer(buffer, this._gl.ARRAY_BUFFER);\r\n };\r\n /**\r\n * Bind a specific block at a given index in a specific shader program\r\n * @param pipelineContext defines the pipeline context to use\r\n * @param blockName defines the block name\r\n * @param index defines the index where to bind the block\r\n */\r\n ThinEngine.prototype.bindUniformBlock = function (pipelineContext, blockName, index) {\r\n var program = pipelineContext.program;\r\n var uniformLocation = this._gl.getUniformBlockIndex(program, blockName);\r\n this._gl.uniformBlockBinding(program, uniformLocation, index);\r\n };\r\n ThinEngine.prototype.bindIndexBuffer = function (buffer) {\r\n if (!this._vaoRecordInProgress) {\r\n this._unbindVertexArrayObject();\r\n }\r\n this.bindBuffer(buffer, this._gl.ELEMENT_ARRAY_BUFFER);\r\n };\r\n ThinEngine.prototype.bindBuffer = function (buffer, target) {\r\n if (this._vaoRecordInProgress || this._currentBoundBuffer[target] !== buffer) {\r\n this._gl.bindBuffer(target, buffer ? buffer.underlyingResource : null);\r\n this._currentBoundBuffer[target] = buffer;\r\n }\r\n };\r\n /**\r\n * update the bound buffer with the given data\r\n * @param data defines the data to update\r\n */\r\n ThinEngine.prototype.updateArrayBuffer = function (data) {\r\n this._gl.bufferSubData(this._gl.ARRAY_BUFFER, 0, data);\r\n };\r\n ThinEngine.prototype._vertexAttribPointer = function (buffer, indx, size, type, normalized, stride, offset) {\r\n var pointer = this._currentBufferPointers[indx];\r\n if (!pointer) {\r\n return;\r\n }\r\n var changed = false;\r\n if (!pointer.active) {\r\n changed = true;\r\n pointer.active = true;\r\n pointer.index = indx;\r\n pointer.size = size;\r\n pointer.type = type;\r\n pointer.normalized = normalized;\r\n pointer.stride = stride;\r\n pointer.offset = offset;\r\n pointer.buffer = buffer;\r\n }\r\n else {\r\n if (pointer.buffer !== buffer) {\r\n pointer.buffer = buffer;\r\n changed = true;\r\n }\r\n if (pointer.size !== size) {\r\n pointer.size = size;\r\n changed = true;\r\n }\r\n if (pointer.type !== type) {\r\n pointer.type = type;\r\n changed = true;\r\n }\r\n if (pointer.normalized !== normalized) {\r\n pointer.normalized = normalized;\r\n changed = true;\r\n }\r\n if (pointer.stride !== stride) {\r\n pointer.stride = stride;\r\n changed = true;\r\n }\r\n if (pointer.offset !== offset) {\r\n pointer.offset = offset;\r\n changed = true;\r\n }\r\n }\r\n if (changed || this._vaoRecordInProgress) {\r\n this.bindArrayBuffer(buffer);\r\n this._gl.vertexAttribPointer(indx, size, type, normalized, stride, offset);\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._bindIndexBufferWithCache = function (indexBuffer) {\r\n if (indexBuffer == null) {\r\n return;\r\n }\r\n if (this._cachedIndexBuffer !== indexBuffer) {\r\n this._cachedIndexBuffer = indexBuffer;\r\n this.bindIndexBuffer(indexBuffer);\r\n this._uintIndicesCurrentlySet = indexBuffer.is32Bits;\r\n }\r\n };\r\n ThinEngine.prototype._bindVertexBuffersAttributes = function (vertexBuffers, effect) {\r\n var attributes = effect.getAttributesNames();\r\n if (!this._vaoRecordInProgress) {\r\n this._unbindVertexArrayObject();\r\n }\r\n this.unbindAllAttributes();\r\n for (var index = 0; index < attributes.length; index++) {\r\n var order = effect.getAttributeLocation(index);\r\n if (order >= 0) {\r\n var vertexBuffer = vertexBuffers[attributes[index]];\r\n if (!vertexBuffer) {\r\n continue;\r\n }\r\n this._gl.enableVertexAttribArray(order);\r\n if (!this._vaoRecordInProgress) {\r\n this._vertexAttribArraysEnabled[order] = true;\r\n }\r\n var buffer = vertexBuffer.getBuffer();\r\n if (buffer) {\r\n this._vertexAttribPointer(buffer, order, vertexBuffer.getSize(), vertexBuffer.type, vertexBuffer.normalized, vertexBuffer.byteStride, vertexBuffer.byteOffset);\r\n if (vertexBuffer.getIsInstanced()) {\r\n this._gl.vertexAttribDivisor(order, vertexBuffer.getInstanceDivisor());\r\n if (!this._vaoRecordInProgress) {\r\n this._currentInstanceLocations.push(order);\r\n this._currentInstanceBuffers.push(buffer);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Records a vertex array object\r\n * @see https://doc.babylonjs.com/features/webgl2#vertex-array-objects\r\n * @param vertexBuffers defines the list of vertex buffers to store\r\n * @param indexBuffer defines the index buffer to store\r\n * @param effect defines the effect to store\r\n * @returns the new vertex array object\r\n */\r\n ThinEngine.prototype.recordVertexArrayObject = function (vertexBuffers, indexBuffer, effect) {\r\n var vao = this._gl.createVertexArray();\r\n this._vaoRecordInProgress = true;\r\n this._gl.bindVertexArray(vao);\r\n this._mustWipeVertexAttributes = true;\r\n this._bindVertexBuffersAttributes(vertexBuffers, effect);\r\n this.bindIndexBuffer(indexBuffer);\r\n this._vaoRecordInProgress = false;\r\n this._gl.bindVertexArray(null);\r\n return vao;\r\n };\r\n /**\r\n * Bind a specific vertex array object\r\n * @see https://doc.babylonjs.com/features/webgl2#vertex-array-objects\r\n * @param vertexArrayObject defines the vertex array object to bind\r\n * @param indexBuffer defines the index buffer to bind\r\n */\r\n ThinEngine.prototype.bindVertexArrayObject = function (vertexArrayObject, indexBuffer) {\r\n if (this._cachedVertexArrayObject !== vertexArrayObject) {\r\n this._cachedVertexArrayObject = vertexArrayObject;\r\n this._gl.bindVertexArray(vertexArrayObject);\r\n this._cachedVertexBuffers = null;\r\n this._cachedIndexBuffer = null;\r\n this._uintIndicesCurrentlySet = indexBuffer != null && indexBuffer.is32Bits;\r\n this._mustWipeVertexAttributes = true;\r\n }\r\n };\r\n /**\r\n * Bind webGl buffers directly to the webGL context\r\n * @param vertexBuffer defines the vertex buffer to bind\r\n * @param indexBuffer defines the index buffer to bind\r\n * @param vertexDeclaration defines the vertex declaration to use with the vertex buffer\r\n * @param vertexStrideSize defines the vertex stride of the vertex buffer\r\n * @param effect defines the effect associated with the vertex buffer\r\n */\r\n ThinEngine.prototype.bindBuffersDirectly = function (vertexBuffer, indexBuffer, vertexDeclaration, vertexStrideSize, effect) {\r\n if (this._cachedVertexBuffers !== vertexBuffer || this._cachedEffectForVertexBuffers !== effect) {\r\n this._cachedVertexBuffers = vertexBuffer;\r\n this._cachedEffectForVertexBuffers = effect;\r\n var attributesCount = effect.getAttributesCount();\r\n this._unbindVertexArrayObject();\r\n this.unbindAllAttributes();\r\n var offset = 0;\r\n for (var index = 0; index < attributesCount; index++) {\r\n if (index < vertexDeclaration.length) {\r\n var order = effect.getAttributeLocation(index);\r\n if (order >= 0) {\r\n this._gl.enableVertexAttribArray(order);\r\n this._vertexAttribArraysEnabled[order] = true;\r\n this._vertexAttribPointer(vertexBuffer, order, vertexDeclaration[index], this._gl.FLOAT, false, vertexStrideSize, offset);\r\n }\r\n offset += vertexDeclaration[index] * 4;\r\n }\r\n }\r\n }\r\n this._bindIndexBufferWithCache(indexBuffer);\r\n };\r\n ThinEngine.prototype._unbindVertexArrayObject = function () {\r\n if (!this._cachedVertexArrayObject) {\r\n return;\r\n }\r\n this._cachedVertexArrayObject = null;\r\n this._gl.bindVertexArray(null);\r\n };\r\n /**\r\n * Bind a list of vertex buffers to the webGL context\r\n * @param vertexBuffers defines the list of vertex buffers to bind\r\n * @param indexBuffer defines the index buffer to bind\r\n * @param effect defines the effect associated with the vertex buffers\r\n */\r\n ThinEngine.prototype.bindBuffers = function (vertexBuffers, indexBuffer, effect) {\r\n if (this._cachedVertexBuffers !== vertexBuffers || this._cachedEffectForVertexBuffers !== effect) {\r\n this._cachedVertexBuffers = vertexBuffers;\r\n this._cachedEffectForVertexBuffers = effect;\r\n this._bindVertexBuffersAttributes(vertexBuffers, effect);\r\n }\r\n this._bindIndexBufferWithCache(indexBuffer);\r\n };\r\n /**\r\n * Unbind all instance attributes\r\n */\r\n ThinEngine.prototype.unbindInstanceAttributes = function () {\r\n var boundBuffer;\r\n for (var i = 0, ul = this._currentInstanceLocations.length; i < ul; i++) {\r\n var instancesBuffer = this._currentInstanceBuffers[i];\r\n if (boundBuffer != instancesBuffer && instancesBuffer.references) {\r\n boundBuffer = instancesBuffer;\r\n this.bindArrayBuffer(instancesBuffer);\r\n }\r\n var offsetLocation = this._currentInstanceLocations[i];\r\n this._gl.vertexAttribDivisor(offsetLocation, 0);\r\n }\r\n this._currentInstanceBuffers.length = 0;\r\n this._currentInstanceLocations.length = 0;\r\n };\r\n /**\r\n * Release and free the memory of a vertex array object\r\n * @param vao defines the vertex array object to delete\r\n */\r\n ThinEngine.prototype.releaseVertexArrayObject = function (vao) {\r\n this._gl.deleteVertexArray(vao);\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._releaseBuffer = function (buffer) {\r\n buffer.references--;\r\n if (buffer.references === 0) {\r\n this._deleteBuffer(buffer);\r\n return true;\r\n }\r\n return false;\r\n };\r\n ThinEngine.prototype._deleteBuffer = function (buffer) {\r\n this._gl.deleteBuffer(buffer.underlyingResource);\r\n };\r\n /**\r\n * Update the content of a webGL buffer used with instanciation and bind it to the webGL context\r\n * @param instancesBuffer defines the webGL buffer to update and bind\r\n * @param data defines the data to store in the buffer\r\n * @param offsetLocations defines the offsets or attributes information used to determine where data must be stored in the buffer\r\n */\r\n ThinEngine.prototype.updateAndBindInstancesBuffer = function (instancesBuffer, data, offsetLocations) {\r\n this.bindArrayBuffer(instancesBuffer);\r\n if (data) {\r\n this._gl.bufferSubData(this._gl.ARRAY_BUFFER, 0, data);\r\n }\r\n if (offsetLocations[0].index !== undefined) {\r\n this.bindInstancesBuffer(instancesBuffer, offsetLocations, true);\r\n }\r\n else {\r\n for (var index = 0; index < 4; index++) {\r\n var offsetLocation = offsetLocations[index];\r\n if (!this._vertexAttribArraysEnabled[offsetLocation]) {\r\n this._gl.enableVertexAttribArray(offsetLocation);\r\n this._vertexAttribArraysEnabled[offsetLocation] = true;\r\n }\r\n this._vertexAttribPointer(instancesBuffer, offsetLocation, 4, this._gl.FLOAT, false, 64, index * 16);\r\n this._gl.vertexAttribDivisor(offsetLocation, 1);\r\n this._currentInstanceLocations.push(offsetLocation);\r\n this._currentInstanceBuffers.push(instancesBuffer);\r\n }\r\n }\r\n };\r\n /**\r\n * Bind the content of a webGL buffer used with instantiation\r\n * @param instancesBuffer defines the webGL buffer to bind\r\n * @param attributesInfo defines the offsets or attributes information used to determine where data must be stored in the buffer\r\n * @param computeStride defines Whether to compute the strides from the info or use the default 0\r\n */\r\n ThinEngine.prototype.bindInstancesBuffer = function (instancesBuffer, attributesInfo, computeStride) {\r\n if (computeStride === void 0) { computeStride = true; }\r\n this.bindArrayBuffer(instancesBuffer);\r\n var stride = 0;\r\n if (computeStride) {\r\n for (var i = 0; i < attributesInfo.length; i++) {\r\n var ai = attributesInfo[i];\r\n stride += ai.attributeSize * 4;\r\n }\r\n }\r\n for (var i = 0; i < attributesInfo.length; i++) {\r\n var ai = attributesInfo[i];\r\n if (ai.index === undefined) {\r\n ai.index = this._currentEffect.getAttributeLocationByName(ai.attributeName);\r\n }\r\n if (ai.index < 0) {\r\n continue;\r\n }\r\n if (!this._vertexAttribArraysEnabled[ai.index]) {\r\n this._gl.enableVertexAttribArray(ai.index);\r\n this._vertexAttribArraysEnabled[ai.index] = true;\r\n }\r\n this._vertexAttribPointer(instancesBuffer, ai.index, ai.attributeSize, ai.attributeType || this._gl.FLOAT, ai.normalized || false, stride, ai.offset);\r\n this._gl.vertexAttribDivisor(ai.index, ai.divisor === undefined ? 1 : ai.divisor);\r\n this._currentInstanceLocations.push(ai.index);\r\n this._currentInstanceBuffers.push(instancesBuffer);\r\n }\r\n };\r\n /**\r\n * Disable the instance attribute corresponding to the name in parameter\r\n * @param name defines the name of the attribute to disable\r\n */\r\n ThinEngine.prototype.disableInstanceAttributeByName = function (name) {\r\n if (!this._currentEffect) {\r\n return;\r\n }\r\n var attributeLocation = this._currentEffect.getAttributeLocationByName(name);\r\n this.disableInstanceAttribute(attributeLocation);\r\n };\r\n /**\r\n * Disable the instance attribute corresponding to the location in parameter\r\n * @param attributeLocation defines the attribute location of the attribute to disable\r\n */\r\n ThinEngine.prototype.disableInstanceAttribute = function (attributeLocation) {\r\n var shouldClean = false;\r\n var index;\r\n while ((index = this._currentInstanceLocations.indexOf(attributeLocation)) !== -1) {\r\n this._currentInstanceLocations.splice(index, 1);\r\n this._currentInstanceBuffers.splice(index, 1);\r\n shouldClean = true;\r\n index = this._currentInstanceLocations.indexOf(attributeLocation);\r\n }\r\n if (shouldClean) {\r\n this._gl.vertexAttribDivisor(attributeLocation, 0);\r\n this.disableAttributeByIndex(attributeLocation);\r\n }\r\n };\r\n /**\r\n * Disable the attribute corresponding to the location in parameter\r\n * @param attributeLocation defines the attribute location of the attribute to disable\r\n */\r\n ThinEngine.prototype.disableAttributeByIndex = function (attributeLocation) {\r\n this._gl.disableVertexAttribArray(attributeLocation);\r\n this._vertexAttribArraysEnabled[attributeLocation] = false;\r\n this._currentBufferPointers[attributeLocation].active = false;\r\n };\r\n /**\r\n * Send a draw order\r\n * @param useTriangles defines if triangles must be used to draw (else wireframe will be used)\r\n * @param indexStart defines the starting index\r\n * @param indexCount defines the number of index to draw\r\n * @param instancesCount defines the number of instances to draw (if instanciation is enabled)\r\n */\r\n ThinEngine.prototype.draw = function (useTriangles, indexStart, indexCount, instancesCount) {\r\n this.drawElementsType(useTriangles ? 0 : 1, indexStart, indexCount, instancesCount);\r\n };\r\n /**\r\n * Draw a list of points\r\n * @param verticesStart defines the index of first vertex to draw\r\n * @param verticesCount defines the count of vertices to draw\r\n * @param instancesCount defines the number of instances to draw (if instanciation is enabled)\r\n */\r\n ThinEngine.prototype.drawPointClouds = function (verticesStart, verticesCount, instancesCount) {\r\n this.drawArraysType(2, verticesStart, verticesCount, instancesCount);\r\n };\r\n /**\r\n * Draw a list of unindexed primitives\r\n * @param useTriangles defines if triangles must be used to draw (else wireframe will be used)\r\n * @param verticesStart defines the index of first vertex to draw\r\n * @param verticesCount defines the count of vertices to draw\r\n * @param instancesCount defines the number of instances to draw (if instanciation is enabled)\r\n */\r\n ThinEngine.prototype.drawUnIndexed = function (useTriangles, verticesStart, verticesCount, instancesCount) {\r\n this.drawArraysType(useTriangles ? 0 : 1, verticesStart, verticesCount, instancesCount);\r\n };\r\n /**\r\n * Draw a list of indexed primitives\r\n * @param fillMode defines the primitive to use\r\n * @param indexStart defines the starting index\r\n * @param indexCount defines the number of index to draw\r\n * @param instancesCount defines the number of instances to draw (if instanciation is enabled)\r\n */\r\n ThinEngine.prototype.drawElementsType = function (fillMode, indexStart, indexCount, instancesCount) {\r\n // Apply states\r\n this.applyStates();\r\n this._reportDrawCall();\r\n // Render\r\n var drawMode = this._drawMode(fillMode);\r\n var indexFormat = this._uintIndicesCurrentlySet ? this._gl.UNSIGNED_INT : this._gl.UNSIGNED_SHORT;\r\n var mult = this._uintIndicesCurrentlySet ? 4 : 2;\r\n if (instancesCount) {\r\n this._gl.drawElementsInstanced(drawMode, indexCount, indexFormat, indexStart * mult, instancesCount);\r\n }\r\n else {\r\n this._gl.drawElements(drawMode, indexCount, indexFormat, indexStart * mult);\r\n }\r\n };\r\n /**\r\n * Draw a list of unindexed primitives\r\n * @param fillMode defines the primitive to use\r\n * @param verticesStart defines the index of first vertex to draw\r\n * @param verticesCount defines the count of vertices to draw\r\n * @param instancesCount defines the number of instances to draw (if instanciation is enabled)\r\n */\r\n ThinEngine.prototype.drawArraysType = function (fillMode, verticesStart, verticesCount, instancesCount) {\r\n // Apply states\r\n this.applyStates();\r\n this._reportDrawCall();\r\n var drawMode = this._drawMode(fillMode);\r\n if (instancesCount) {\r\n this._gl.drawArraysInstanced(drawMode, verticesStart, verticesCount, instancesCount);\r\n }\r\n else {\r\n this._gl.drawArrays(drawMode, verticesStart, verticesCount);\r\n }\r\n };\r\n ThinEngine.prototype._drawMode = function (fillMode) {\r\n switch (fillMode) {\r\n // Triangle views\r\n case 0:\r\n return this._gl.TRIANGLES;\r\n case 2:\r\n return this._gl.POINTS;\r\n case 1:\r\n return this._gl.LINES;\r\n // Draw modes\r\n case 3:\r\n return this._gl.POINTS;\r\n case 4:\r\n return this._gl.LINES;\r\n case 5:\r\n return this._gl.LINE_LOOP;\r\n case 6:\r\n return this._gl.LINE_STRIP;\r\n case 7:\r\n return this._gl.TRIANGLE_STRIP;\r\n case 8:\r\n return this._gl.TRIANGLE_FAN;\r\n default:\r\n return this._gl.TRIANGLES;\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._reportDrawCall = function () {\r\n // Will be implemented by children\r\n };\r\n // Shaders\r\n /** @hidden */\r\n ThinEngine.prototype._releaseEffect = function (effect) {\r\n if (this._compiledEffects[effect._key]) {\r\n delete this._compiledEffects[effect._key];\r\n this._deletePipelineContext(effect.getPipelineContext());\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._deletePipelineContext = function (pipelineContext) {\r\n var webGLPipelineContext = pipelineContext;\r\n if (webGLPipelineContext && webGLPipelineContext.program) {\r\n webGLPipelineContext.program.__SPECTOR_rebuildProgram = null;\r\n this._gl.deleteProgram(webGLPipelineContext.program);\r\n }\r\n };\r\n /**\r\n * Create a new effect (used to store vertex/fragment shaders)\r\n * @param baseName defines the base name of the effect (The name of file without .fragment.fx or .vertex.fx)\r\n * @param attributesNamesOrOptions defines either a list of attribute names or an IEffectCreationOptions object\r\n * @param uniformsNamesOrEngine defines either a list of uniform names or the engine to use\r\n * @param samplers defines an array of string used to represent textures\r\n * @param defines defines the string containing the defines to use to compile the shaders\r\n * @param fallbacks defines the list of potential fallbacks to use if shader conmpilation fails\r\n * @param onCompiled defines a function to call when the effect creation is successful\r\n * @param onError defines a function to call when the effect creation has failed\r\n * @param indexParameters defines an object containing the index values to use to compile shaders (like the maximum number of simultaneous lights)\r\n * @returns the new Effect\r\n */\r\n ThinEngine.prototype.createEffect = function (baseName, attributesNamesOrOptions, uniformsNamesOrEngine, samplers, defines, fallbacks, onCompiled, onError, indexParameters) {\r\n var vertex = baseName.vertexElement || baseName.vertex || baseName.vertexToken || baseName.vertexSource || baseName;\r\n var fragment = baseName.fragmentElement || baseName.fragment || baseName.fragmentToken || baseName.fragmentSource || baseName;\r\n var name = vertex + \"+\" + fragment + \"@\" + (defines ? defines : attributesNamesOrOptions.defines);\r\n if (this._compiledEffects[name]) {\r\n var compiledEffect = this._compiledEffects[name];\r\n if (onCompiled && compiledEffect.isReady()) {\r\n onCompiled(compiledEffect);\r\n }\r\n return compiledEffect;\r\n }\r\n var effect = new Effect(baseName, attributesNamesOrOptions, uniformsNamesOrEngine, samplers, this, defines, fallbacks, onCompiled, onError, indexParameters);\r\n effect._key = name;\r\n this._compiledEffects[name] = effect;\r\n return effect;\r\n };\r\n ThinEngine._ConcatenateShader = function (source, defines, shaderVersion) {\r\n if (shaderVersion === void 0) { shaderVersion = \"\"; }\r\n return shaderVersion + (defines ? defines + \"\\n\" : \"\") + source;\r\n };\r\n ThinEngine.prototype._compileShader = function (source, type, defines, shaderVersion) {\r\n return this._compileRawShader(ThinEngine._ConcatenateShader(source, defines, shaderVersion), type);\r\n };\r\n ThinEngine.prototype._compileRawShader = function (source, type) {\r\n var gl = this._gl;\r\n var shader = gl.createShader(type === \"vertex\" ? gl.VERTEX_SHADER : gl.FRAGMENT_SHADER);\r\n if (!shader) {\r\n throw new Error(\"Something went wrong while compile the shader.\");\r\n }\r\n gl.shaderSource(shader, source);\r\n gl.compileShader(shader);\r\n return shader;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._getShaderSource = function (shader) {\r\n return this._gl.getShaderSource(shader);\r\n };\r\n /**\r\n * Directly creates a webGL program\r\n * @param pipelineContext defines the pipeline context to attach to\r\n * @param vertexCode defines the vertex shader code to use\r\n * @param fragmentCode defines the fragment shader code to use\r\n * @param context defines the webGL context to use (if not set, the current one will be used)\r\n * @param transformFeedbackVaryings defines the list of transform feedback varyings to use\r\n * @returns the new webGL program\r\n */\r\n ThinEngine.prototype.createRawShaderProgram = function (pipelineContext, vertexCode, fragmentCode, context, transformFeedbackVaryings) {\r\n if (transformFeedbackVaryings === void 0) { transformFeedbackVaryings = null; }\r\n context = context || this._gl;\r\n var vertexShader = this._compileRawShader(vertexCode, \"vertex\");\r\n var fragmentShader = this._compileRawShader(fragmentCode, \"fragment\");\r\n return this._createShaderProgram(pipelineContext, vertexShader, fragmentShader, context, transformFeedbackVaryings);\r\n };\r\n /**\r\n * Creates a webGL program\r\n * @param pipelineContext defines the pipeline context to attach to\r\n * @param vertexCode defines the vertex shader code to use\r\n * @param fragmentCode defines the fragment shader code to use\r\n * @param defines defines the string containing the defines to use to compile the shaders\r\n * @param context defines the webGL context to use (if not set, the current one will be used)\r\n * @param transformFeedbackVaryings defines the list of transform feedback varyings to use\r\n * @returns the new webGL program\r\n */\r\n ThinEngine.prototype.createShaderProgram = function (pipelineContext, vertexCode, fragmentCode, defines, context, transformFeedbackVaryings) {\r\n if (transformFeedbackVaryings === void 0) { transformFeedbackVaryings = null; }\r\n context = context || this._gl;\r\n var shaderVersion = (this._webGLVersion > 1) ? \"#version 300 es\\n#define WEBGL2 \\n\" : \"\";\r\n var vertexShader = this._compileShader(vertexCode, \"vertex\", defines, shaderVersion);\r\n var fragmentShader = this._compileShader(fragmentCode, \"fragment\", defines, shaderVersion);\r\n return this._createShaderProgram(pipelineContext, vertexShader, fragmentShader, context, transformFeedbackVaryings);\r\n };\r\n /**\r\n * Creates a new pipeline context\r\n * @returns the new pipeline\r\n */\r\n ThinEngine.prototype.createPipelineContext = function () {\r\n var pipelineContext = new WebGLPipelineContext();\r\n pipelineContext.engine = this;\r\n if (this._caps.parallelShaderCompile) {\r\n pipelineContext.isParallelCompiled = true;\r\n }\r\n return pipelineContext;\r\n };\r\n ThinEngine.prototype._createShaderProgram = function (pipelineContext, vertexShader, fragmentShader, context, transformFeedbackVaryings) {\r\n if (transformFeedbackVaryings === void 0) { transformFeedbackVaryings = null; }\r\n var shaderProgram = context.createProgram();\r\n pipelineContext.program = shaderProgram;\r\n if (!shaderProgram) {\r\n throw new Error(\"Unable to create program\");\r\n }\r\n context.attachShader(shaderProgram, vertexShader);\r\n context.attachShader(shaderProgram, fragmentShader);\r\n context.linkProgram(shaderProgram);\r\n pipelineContext.context = context;\r\n pipelineContext.vertexShader = vertexShader;\r\n pipelineContext.fragmentShader = fragmentShader;\r\n if (!pipelineContext.isParallelCompiled) {\r\n this._finalizePipelineContext(pipelineContext);\r\n }\r\n return shaderProgram;\r\n };\r\n ThinEngine.prototype._finalizePipelineContext = function (pipelineContext) {\r\n var context = pipelineContext.context;\r\n var vertexShader = pipelineContext.vertexShader;\r\n var fragmentShader = pipelineContext.fragmentShader;\r\n var program = pipelineContext.program;\r\n var linked = context.getProgramParameter(program, context.LINK_STATUS);\r\n if (!linked) { // Get more info\r\n // Vertex\r\n if (!this._gl.getShaderParameter(vertexShader, this._gl.COMPILE_STATUS)) {\r\n var log = this._gl.getShaderInfoLog(vertexShader);\r\n if (log) {\r\n pipelineContext.vertexCompilationError = log;\r\n throw new Error(\"VERTEX SHADER \" + log);\r\n }\r\n }\r\n // Fragment\r\n if (!this._gl.getShaderParameter(fragmentShader, this._gl.COMPILE_STATUS)) {\r\n var log = this._gl.getShaderInfoLog(fragmentShader);\r\n if (log) {\r\n pipelineContext.fragmentCompilationError = log;\r\n throw new Error(\"FRAGMENT SHADER \" + log);\r\n }\r\n }\r\n var error = context.getProgramInfoLog(program);\r\n if (error) {\r\n pipelineContext.programLinkError = error;\r\n throw new Error(error);\r\n }\r\n }\r\n if (this.validateShaderPrograms) {\r\n context.validateProgram(program);\r\n var validated = context.getProgramParameter(program, context.VALIDATE_STATUS);\r\n if (!validated) {\r\n var error = context.getProgramInfoLog(program);\r\n if (error) {\r\n pipelineContext.programValidationError = error;\r\n throw new Error(error);\r\n }\r\n }\r\n }\r\n context.deleteShader(vertexShader);\r\n context.deleteShader(fragmentShader);\r\n pipelineContext.vertexShader = undefined;\r\n pipelineContext.fragmentShader = undefined;\r\n if (pipelineContext.onCompiled) {\r\n pipelineContext.onCompiled();\r\n pipelineContext.onCompiled = undefined;\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._preparePipelineContext = function (pipelineContext, vertexSourceCode, fragmentSourceCode, createAsRaw, rebuildRebind, defines, transformFeedbackVaryings) {\r\n var webGLRenderingState = pipelineContext;\r\n if (createAsRaw) {\r\n webGLRenderingState.program = this.createRawShaderProgram(webGLRenderingState, vertexSourceCode, fragmentSourceCode, undefined, transformFeedbackVaryings);\r\n }\r\n else {\r\n webGLRenderingState.program = this.createShaderProgram(webGLRenderingState, vertexSourceCode, fragmentSourceCode, defines, undefined, transformFeedbackVaryings);\r\n }\r\n webGLRenderingState.program.__SPECTOR_rebuildProgram = rebuildRebind;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._isRenderingStateCompiled = function (pipelineContext) {\r\n var webGLPipelineContext = pipelineContext;\r\n if (this._gl.getProgramParameter(webGLPipelineContext.program, this._caps.parallelShaderCompile.COMPLETION_STATUS_KHR)) {\r\n this._finalizePipelineContext(webGLPipelineContext);\r\n return true;\r\n }\r\n return false;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._executeWhenRenderingStateIsCompiled = function (pipelineContext, action) {\r\n var webGLPipelineContext = pipelineContext;\r\n if (!webGLPipelineContext.isParallelCompiled) {\r\n action();\r\n return;\r\n }\r\n var oldHandler = webGLPipelineContext.onCompiled;\r\n if (oldHandler) {\r\n webGLPipelineContext.onCompiled = function () {\r\n oldHandler();\r\n action();\r\n };\r\n }\r\n else {\r\n webGLPipelineContext.onCompiled = action;\r\n }\r\n };\r\n /**\r\n * Gets the list of webGL uniform locations associated with a specific program based on a list of uniform names\r\n * @param pipelineContext defines the pipeline context to use\r\n * @param uniformsNames defines the list of uniform names\r\n * @returns an array of webGL uniform locations\r\n */\r\n ThinEngine.prototype.getUniforms = function (pipelineContext, uniformsNames) {\r\n var results = new Array();\r\n var webGLPipelineContext = pipelineContext;\r\n for (var index = 0; index < uniformsNames.length; index++) {\r\n results.push(this._gl.getUniformLocation(webGLPipelineContext.program, uniformsNames[index]));\r\n }\r\n return results;\r\n };\r\n /**\r\n * Gets the lsit of active attributes for a given webGL program\r\n * @param pipelineContext defines the pipeline context to use\r\n * @param attributesNames defines the list of attribute names to get\r\n * @returns an array of indices indicating the offset of each attribute\r\n */\r\n ThinEngine.prototype.getAttributes = function (pipelineContext, attributesNames) {\r\n var results = [];\r\n var webGLPipelineContext = pipelineContext;\r\n for (var index = 0; index < attributesNames.length; index++) {\r\n try {\r\n results.push(this._gl.getAttribLocation(webGLPipelineContext.program, attributesNames[index]));\r\n }\r\n catch (e) {\r\n results.push(-1);\r\n }\r\n }\r\n return results;\r\n };\r\n /**\r\n * Activates an effect, mkaing it the current one (ie. the one used for rendering)\r\n * @param effect defines the effect to activate\r\n */\r\n ThinEngine.prototype.enableEffect = function (effect) {\r\n if (!effect || effect === this._currentEffect) {\r\n return;\r\n }\r\n // Use program\r\n this.bindSamplers(effect);\r\n this._currentEffect = effect;\r\n if (effect.onBind) {\r\n effect.onBind(effect);\r\n }\r\n if (effect._onBindObservable) {\r\n effect._onBindObservable.notifyObservers(effect);\r\n }\r\n };\r\n /**\r\n * Set the value of an uniform to a number (int)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param value defines the int number to store\r\n * @returns true if the value was set\r\n */\r\n ThinEngine.prototype.setInt = function (uniform, value) {\r\n if (!uniform) {\r\n return false;\r\n }\r\n this._gl.uniform1i(uniform, value);\r\n return true;\r\n };\r\n /**\r\n * Set the value of an uniform to an array of int32\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param array defines the array of int32 to store\r\n * @returns true if the value was set\r\n */\r\n ThinEngine.prototype.setIntArray = function (uniform, array) {\r\n if (!uniform) {\r\n return false;\r\n }\r\n this._gl.uniform1iv(uniform, array);\r\n return true;\r\n };\r\n /**\r\n * Set the value of an uniform to an array of int32 (stored as vec2)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param array defines the array of int32 to store\r\n * @returns true if the value was set\r\n */\r\n ThinEngine.prototype.setIntArray2 = function (uniform, array) {\r\n if (!uniform || array.length % 2 !== 0) {\r\n return false;\r\n }\r\n this._gl.uniform2iv(uniform, array);\r\n return true;\r\n };\r\n /**\r\n * Set the value of an uniform to an array of int32 (stored as vec3)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param array defines the array of int32 to store\r\n * @returns true if the value was set\r\n */\r\n ThinEngine.prototype.setIntArray3 = function (uniform, array) {\r\n if (!uniform || array.length % 3 !== 0) {\r\n return false;\r\n }\r\n this._gl.uniform3iv(uniform, array);\r\n return true;\r\n };\r\n /**\r\n * Set the value of an uniform to an array of int32 (stored as vec4)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param array defines the array of int32 to store\r\n * @returns true if the value was set\r\n */\r\n ThinEngine.prototype.setIntArray4 = function (uniform, array) {\r\n if (!uniform || array.length % 4 !== 0) {\r\n return false;\r\n }\r\n this._gl.uniform4iv(uniform, array);\r\n return true;\r\n };\r\n /**\r\n * Set the value of an uniform to an array of number\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param array defines the array of number to store\r\n * @returns true if the value was set\r\n */\r\n ThinEngine.prototype.setArray = function (uniform, array) {\r\n if (!uniform) {\r\n return false;\r\n }\r\n this._gl.uniform1fv(uniform, array);\r\n return true;\r\n };\r\n /**\r\n * Set the value of an uniform to an array of number (stored as vec2)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param array defines the array of number to store\r\n * @returns true if the value was set\r\n */\r\n ThinEngine.prototype.setArray2 = function (uniform, array) {\r\n if (!uniform || array.length % 2 !== 0) {\r\n return false;\r\n }\r\n this._gl.uniform2fv(uniform, array);\r\n return true;\r\n };\r\n /**\r\n * Set the value of an uniform to an array of number (stored as vec3)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param array defines the array of number to store\r\n * @returns true if the value was set\r\n */\r\n ThinEngine.prototype.setArray3 = function (uniform, array) {\r\n if (!uniform || array.length % 3 !== 0) {\r\n return false;\r\n }\r\n this._gl.uniform3fv(uniform, array);\r\n return true;\r\n };\r\n /**\r\n * Set the value of an uniform to an array of number (stored as vec4)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param array defines the array of number to store\r\n * @returns true if the value was set\r\n */\r\n ThinEngine.prototype.setArray4 = function (uniform, array) {\r\n if (!uniform || array.length % 4 !== 0) {\r\n return false;\r\n }\r\n this._gl.uniform4fv(uniform, array);\r\n return true;\r\n };\r\n /**\r\n * Set the value of an uniform to an array of float32 (stored as matrices)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param matrices defines the array of float32 to store\r\n * @returns true if the value was set\r\n */\r\n ThinEngine.prototype.setMatrices = function (uniform, matrices) {\r\n if (!uniform) {\r\n return false;\r\n }\r\n this._gl.uniformMatrix4fv(uniform, false, matrices);\r\n return true;\r\n };\r\n /**\r\n * Set the value of an uniform to a matrix (3x3)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param matrix defines the Float32Array representing the 3x3 matrix to store\r\n * @returns true if the value was set\r\n */\r\n ThinEngine.prototype.setMatrix3x3 = function (uniform, matrix) {\r\n if (!uniform) {\r\n return false;\r\n }\r\n this._gl.uniformMatrix3fv(uniform, false, matrix);\r\n return true;\r\n };\r\n /**\r\n * Set the value of an uniform to a matrix (2x2)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param matrix defines the Float32Array representing the 2x2 matrix to store\r\n * @returns true if the value was set\r\n */\r\n ThinEngine.prototype.setMatrix2x2 = function (uniform, matrix) {\r\n if (!uniform) {\r\n return false;\r\n }\r\n this._gl.uniformMatrix2fv(uniform, false, matrix);\r\n return true;\r\n };\r\n /**\r\n * Set the value of an uniform to a number (float)\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param value defines the float number to store\r\n * @returns true if the value was transfered\r\n */\r\n ThinEngine.prototype.setFloat = function (uniform, value) {\r\n if (!uniform) {\r\n return false;\r\n }\r\n this._gl.uniform1f(uniform, value);\r\n return true;\r\n };\r\n /**\r\n * Set the value of an uniform to a vec2\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param x defines the 1st component of the value\r\n * @param y defines the 2nd component of the value\r\n * @returns true if the value was set\r\n */\r\n ThinEngine.prototype.setFloat2 = function (uniform, x, y) {\r\n if (!uniform) {\r\n return false;\r\n }\r\n this._gl.uniform2f(uniform, x, y);\r\n return true;\r\n };\r\n /**\r\n * Set the value of an uniform to a vec3\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param x defines the 1st component of the value\r\n * @param y defines the 2nd component of the value\r\n * @param z defines the 3rd component of the value\r\n * @returns true if the value was set\r\n */\r\n ThinEngine.prototype.setFloat3 = function (uniform, x, y, z) {\r\n if (!uniform) {\r\n return false;\r\n }\r\n this._gl.uniform3f(uniform, x, y, z);\r\n return true;\r\n };\r\n /**\r\n * Set the value of an uniform to a vec4\r\n * @param uniform defines the webGL uniform location where to store the value\r\n * @param x defines the 1st component of the value\r\n * @param y defines the 2nd component of the value\r\n * @param z defines the 3rd component of the value\r\n * @param w defines the 4th component of the value\r\n * @returns true if the value was set\r\n */\r\n ThinEngine.prototype.setFloat4 = function (uniform, x, y, z, w) {\r\n if (!uniform) {\r\n return false;\r\n }\r\n this._gl.uniform4f(uniform, x, y, z, w);\r\n return true;\r\n };\r\n // States\r\n /**\r\n * Apply all cached states (depth, culling, stencil and alpha)\r\n */\r\n ThinEngine.prototype.applyStates = function () {\r\n this._depthCullingState.apply(this._gl);\r\n this._stencilState.apply(this._gl);\r\n this._alphaState.apply(this._gl);\r\n if (this._colorWriteChanged) {\r\n this._colorWriteChanged = false;\r\n var enable = this._colorWrite;\r\n this._gl.colorMask(enable, enable, enable, enable);\r\n }\r\n };\r\n /**\r\n * Enable or disable color writing\r\n * @param enable defines the state to set\r\n */\r\n ThinEngine.prototype.setColorWrite = function (enable) {\r\n if (enable !== this._colorWrite) {\r\n this._colorWriteChanged = true;\r\n this._colorWrite = enable;\r\n }\r\n };\r\n /**\r\n * Gets a boolean indicating if color writing is enabled\r\n * @returns the current color writing state\r\n */\r\n ThinEngine.prototype.getColorWrite = function () {\r\n return this._colorWrite;\r\n };\r\n Object.defineProperty(ThinEngine.prototype, \"depthCullingState\", {\r\n /**\r\n * Gets the depth culling state manager\r\n */\r\n get: function () {\r\n return this._depthCullingState;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"alphaState\", {\r\n /**\r\n * Gets the alpha state manager\r\n */\r\n get: function () {\r\n return this._alphaState;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ThinEngine.prototype, \"stencilState\", {\r\n /**\r\n * Gets the stencil state manager\r\n */\r\n get: function () {\r\n return this._stencilState;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n // Textures\r\n /**\r\n * Clears the list of texture accessible through engine.\r\n * This can help preventing texture load conflict due to name collision.\r\n */\r\n ThinEngine.prototype.clearInternalTexturesCache = function () {\r\n this._internalTexturesCache = [];\r\n };\r\n /**\r\n * Force the entire cache to be cleared\r\n * You should not have to use this function unless your engine needs to share the webGL context with another engine\r\n * @param bruteForce defines a boolean to force clearing ALL caches (including stencil, detoh and alpha states)\r\n */\r\n ThinEngine.prototype.wipeCaches = function (bruteForce) {\r\n if (this.preventCacheWipeBetweenFrames && !bruteForce) {\r\n return;\r\n }\r\n this._currentEffect = null;\r\n this._viewportCached.x = 0;\r\n this._viewportCached.y = 0;\r\n this._viewportCached.z = 0;\r\n this._viewportCached.w = 0;\r\n // Done before in case we clean the attributes\r\n this._unbindVertexArrayObject();\r\n if (bruteForce) {\r\n this._currentProgram = null;\r\n this.resetTextureCache();\r\n this._stencilState.reset();\r\n this._depthCullingState.reset();\r\n this._depthCullingState.depthFunc = this._gl.LEQUAL;\r\n this._alphaState.reset();\r\n this._alphaMode = 1;\r\n this._alphaEquation = 0;\r\n this._colorWrite = true;\r\n this._colorWriteChanged = true;\r\n this._unpackFlipYCached = null;\r\n this._gl.pixelStorei(this._gl.UNPACK_COLORSPACE_CONVERSION_WEBGL, this._gl.NONE);\r\n this._gl.pixelStorei(this._gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, 0);\r\n this._mustWipeVertexAttributes = true;\r\n this.unbindAllAttributes();\r\n }\r\n this._resetVertexBufferBinding();\r\n this._cachedIndexBuffer = null;\r\n this._cachedEffectForVertexBuffers = null;\r\n this.bindIndexBuffer(null);\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._getSamplingParameters = function (samplingMode, generateMipMaps) {\r\n var gl = this._gl;\r\n var magFilter = gl.NEAREST;\r\n var minFilter = gl.NEAREST;\r\n switch (samplingMode) {\r\n case 11:\r\n magFilter = gl.LINEAR;\r\n if (generateMipMaps) {\r\n minFilter = gl.LINEAR_MIPMAP_NEAREST;\r\n }\r\n else {\r\n minFilter = gl.LINEAR;\r\n }\r\n break;\r\n case 3:\r\n magFilter = gl.LINEAR;\r\n if (generateMipMaps) {\r\n minFilter = gl.LINEAR_MIPMAP_LINEAR;\r\n }\r\n else {\r\n minFilter = gl.LINEAR;\r\n }\r\n break;\r\n case 8:\r\n magFilter = gl.NEAREST;\r\n if (generateMipMaps) {\r\n minFilter = gl.NEAREST_MIPMAP_LINEAR;\r\n }\r\n else {\r\n minFilter = gl.NEAREST;\r\n }\r\n break;\r\n case 4:\r\n magFilter = gl.NEAREST;\r\n if (generateMipMaps) {\r\n minFilter = gl.NEAREST_MIPMAP_NEAREST;\r\n }\r\n else {\r\n minFilter = gl.NEAREST;\r\n }\r\n break;\r\n case 5:\r\n magFilter = gl.NEAREST;\r\n if (generateMipMaps) {\r\n minFilter = gl.LINEAR_MIPMAP_NEAREST;\r\n }\r\n else {\r\n minFilter = gl.LINEAR;\r\n }\r\n break;\r\n case 6:\r\n magFilter = gl.NEAREST;\r\n if (generateMipMaps) {\r\n minFilter = gl.LINEAR_MIPMAP_LINEAR;\r\n }\r\n else {\r\n minFilter = gl.LINEAR;\r\n }\r\n break;\r\n case 7:\r\n magFilter = gl.NEAREST;\r\n minFilter = gl.LINEAR;\r\n break;\r\n case 1:\r\n magFilter = gl.NEAREST;\r\n minFilter = gl.NEAREST;\r\n break;\r\n case 9:\r\n magFilter = gl.LINEAR;\r\n if (generateMipMaps) {\r\n minFilter = gl.NEAREST_MIPMAP_NEAREST;\r\n }\r\n else {\r\n minFilter = gl.NEAREST;\r\n }\r\n break;\r\n case 10:\r\n magFilter = gl.LINEAR;\r\n if (generateMipMaps) {\r\n minFilter = gl.NEAREST_MIPMAP_LINEAR;\r\n }\r\n else {\r\n minFilter = gl.NEAREST;\r\n }\r\n break;\r\n case 2:\r\n magFilter = gl.LINEAR;\r\n minFilter = gl.LINEAR;\r\n break;\r\n case 12:\r\n magFilter = gl.LINEAR;\r\n minFilter = gl.NEAREST;\r\n break;\r\n }\r\n return {\r\n min: minFilter,\r\n mag: magFilter\r\n };\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._createTexture = function () {\r\n var texture = this._gl.createTexture();\r\n if (!texture) {\r\n throw new Error(\"Unable to create texture\");\r\n }\r\n return texture;\r\n };\r\n /**\r\n * Usually called from Texture.ts.\r\n * Passed information to create a WebGLTexture\r\n * @param url defines a value which contains one of the following:\r\n * * A conventional http URL, e.g. 'http://...' or 'file://...'\r\n * * A base64 string of in-line texture data, e.g. '...'\r\n * * An indicator that data being passed using the buffer parameter, e.g. 'data:mytexture.jpg'\r\n * @param noMipmap defines a boolean indicating that no mipmaps shall be generated. Ignored for compressed textures. They must be in the file\r\n * @param invertY when true, image is flipped when loaded. You probably want true. Certain compressed textures may invert this if their default is inverted (eg. ktx)\r\n * @param scene needed for loading to the correct scene\r\n * @param samplingMode mode with should be used sample / access the texture (Default: Texture.TRILINEAR_SAMPLINGMODE)\r\n * @param onLoad optional callback to be called upon successful completion\r\n * @param onError optional callback to be called upon failure\r\n * @param buffer a source of a file previously fetched as either a base64 string, an ArrayBuffer (compressed or image format), HTMLImageElement (image format), or a Blob\r\n * @param fallback an internal argument in case the function must be called again, due to etc1 not having alpha capabilities\r\n * @param format internal format. Default: RGB when extension is '.jpg' else RGBA. Ignored for compressed textures\r\n * @param forcedExtension defines the extension to use to pick the right loader\r\n * @param mimeType defines an optional mime type\r\n * @param loaderOptions options to be passed to the loader\r\n * @returns a InternalTexture for assignment back into BABYLON.Texture\r\n */\r\n ThinEngine.prototype.createTexture = function (url, noMipmap, invertY, scene, samplingMode, onLoad, onError, buffer, fallback, format, forcedExtension, mimeType, loaderOptions) {\r\n var _this = this;\r\n if (samplingMode === void 0) { samplingMode = 3; }\r\n if (onLoad === void 0) { onLoad = null; }\r\n if (onError === void 0) { onError = null; }\r\n if (buffer === void 0) { buffer = null; }\r\n if (fallback === void 0) { fallback = null; }\r\n if (format === void 0) { format = null; }\r\n if (forcedExtension === void 0) { forcedExtension = null; }\r\n url = url || \"\";\r\n var fromData = url.substr(0, 5) === \"data:\";\r\n var fromBlob = url.substr(0, 5) === \"blob:\";\r\n var isBase64 = fromData && url.indexOf(\";base64,\") !== -1;\r\n var texture = fallback ? fallback : new InternalTexture(this, InternalTextureSource.Url);\r\n var originalUrl = url;\r\n if (this._transformTextureUrl && !isBase64 && !fallback && !buffer) {\r\n url = this._transformTextureUrl(url);\r\n }\r\n if (originalUrl !== url) {\r\n texture._originalUrl = originalUrl;\r\n }\r\n // establish the file extension, if possible\r\n var lastDot = url.lastIndexOf('.');\r\n var extension = forcedExtension ? forcedExtension : (lastDot > -1 ? url.substring(lastDot).toLowerCase() : \"\");\r\n var loader = null;\r\n // Remove query string\r\n var queryStringIndex = extension.indexOf(\"?\");\r\n if (queryStringIndex > -1) {\r\n extension = extension.split(\"?\")[0];\r\n }\r\n for (var _i = 0, _a = ThinEngine._TextureLoaders; _i < _a.length; _i++) {\r\n var availableLoader = _a[_i];\r\n if (availableLoader.canLoad(extension, mimeType)) {\r\n loader = availableLoader;\r\n break;\r\n }\r\n }\r\n if (scene) {\r\n scene._addPendingData(texture);\r\n }\r\n texture.url = url;\r\n texture.generateMipMaps = !noMipmap;\r\n texture.samplingMode = samplingMode;\r\n texture.invertY = invertY;\r\n if (!this._doNotHandleContextLost) {\r\n // Keep a link to the buffer only if we plan to handle context lost\r\n texture._buffer = buffer;\r\n }\r\n var onLoadObserver = null;\r\n if (onLoad && !fallback) {\r\n onLoadObserver = texture.onLoadedObservable.add(onLoad);\r\n }\r\n if (!fallback) {\r\n this._internalTexturesCache.push(texture);\r\n }\r\n var onInternalError = function (message, exception) {\r\n if (scene) {\r\n scene._removePendingData(texture);\r\n }\r\n if (url === originalUrl) {\r\n if (onLoadObserver) {\r\n texture.onLoadedObservable.remove(onLoadObserver);\r\n }\r\n if (EngineStore.UseFallbackTexture) {\r\n _this.createTexture(EngineStore.FallbackTexture, noMipmap, texture.invertY, scene, samplingMode, null, onError, buffer, texture);\r\n }\r\n if (onError) {\r\n onError((message || \"Unknown error\") + (EngineStore.UseFallbackTexture ? \" - Fallback texture was used\" : \"\"), exception);\r\n }\r\n }\r\n else {\r\n // fall back to the original url if the transformed url fails to load\r\n Logger.Warn(\"Failed to load \" + url + \", falling back to \" + originalUrl);\r\n _this.createTexture(originalUrl, noMipmap, texture.invertY, scene, samplingMode, onLoad, onError, buffer, texture, format, forcedExtension, mimeType, loaderOptions);\r\n }\r\n };\r\n // processing for non-image formats\r\n if (loader) {\r\n var callback_1 = function (data) {\r\n loader.loadData(data, texture, function (width, height, loadMipmap, isCompressed, done, loadFailed) {\r\n if (loadFailed) {\r\n onInternalError(\"TextureLoader failed to load data\");\r\n }\r\n else {\r\n _this._prepareWebGLTexture(texture, scene, width, height, texture.invertY, !loadMipmap, isCompressed, function () {\r\n done();\r\n return false;\r\n }, samplingMode);\r\n }\r\n }, loaderOptions);\r\n };\r\n if (!buffer) {\r\n this._loadFile(url, function (data) { return callback_1(new Uint8Array(data)); }, undefined, scene ? scene.offlineProvider : undefined, true, function (request, exception) {\r\n onInternalError(\"Unable to load \" + (request ? request.responseURL : url, exception));\r\n });\r\n }\r\n else {\r\n if (buffer instanceof ArrayBuffer) {\r\n callback_1(new Uint8Array(buffer));\r\n }\r\n else if (ArrayBuffer.isView(buffer)) {\r\n callback_1(buffer);\r\n }\r\n else {\r\n if (onError) {\r\n onError(\"Unable to load: only ArrayBuffer or ArrayBufferView is supported\", null);\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n var onload_1 = function (img) {\r\n if (fromBlob && !_this._doNotHandleContextLost) {\r\n // We need to store the image if we need to rebuild the texture\r\n // in case of a webgl context lost\r\n texture._buffer = img;\r\n }\r\n _this._prepareWebGLTexture(texture, scene, img.width, img.height, texture.invertY, noMipmap, false, function (potWidth, potHeight, continuationCallback) {\r\n var gl = _this._gl;\r\n var isPot = (img.width === potWidth && img.height === potHeight);\r\n var internalFormat = format ? _this._getInternalFormat(format) : ((extension === \".jpg\") ? gl.RGB : gl.RGBA);\r\n if (isPot) {\r\n gl.texImage2D(gl.TEXTURE_2D, 0, internalFormat, internalFormat, gl.UNSIGNED_BYTE, img);\r\n return false;\r\n }\r\n var maxTextureSize = _this._caps.maxTextureSize;\r\n if (img.width > maxTextureSize || img.height > maxTextureSize || !_this._supportsHardwareTextureRescaling) {\r\n _this._prepareWorkingCanvas();\r\n if (!_this._workingCanvas || !_this._workingContext) {\r\n return false;\r\n }\r\n _this._workingCanvas.width = potWidth;\r\n _this._workingCanvas.height = potHeight;\r\n _this._workingContext.drawImage(img, 0, 0, img.width, img.height, 0, 0, potWidth, potHeight);\r\n gl.texImage2D(gl.TEXTURE_2D, 0, internalFormat, internalFormat, gl.UNSIGNED_BYTE, _this._workingCanvas);\r\n texture.width = potWidth;\r\n texture.height = potHeight;\r\n return false;\r\n }\r\n else {\r\n // Using shaders when possible to rescale because canvas.drawImage is lossy\r\n var source_1 = new InternalTexture(_this, InternalTextureSource.Temp);\r\n _this._bindTextureDirectly(gl.TEXTURE_2D, source_1, true);\r\n gl.texImage2D(gl.TEXTURE_2D, 0, internalFormat, internalFormat, gl.UNSIGNED_BYTE, img);\r\n _this._rescaleTexture(source_1, texture, scene, internalFormat, function () {\r\n _this._releaseTexture(source_1);\r\n _this._bindTextureDirectly(gl.TEXTURE_2D, texture, true);\r\n continuationCallback();\r\n });\r\n }\r\n return true;\r\n }, samplingMode);\r\n };\r\n if (!fromData || isBase64) {\r\n if (buffer && (buffer.decoding || buffer.close)) {\r\n onload_1(buffer);\r\n }\r\n else {\r\n ThinEngine._FileToolsLoadImage(url, onload_1, onInternalError, scene ? scene.offlineProvider : null, mimeType);\r\n }\r\n }\r\n else if (typeof buffer === \"string\" || buffer instanceof ArrayBuffer || ArrayBuffer.isView(buffer) || buffer instanceof Blob) {\r\n ThinEngine._FileToolsLoadImage(buffer, onload_1, onInternalError, scene ? scene.offlineProvider : null, mimeType);\r\n }\r\n else if (buffer) {\r\n onload_1(buffer);\r\n }\r\n }\r\n return texture;\r\n };\r\n /**\r\n * Loads an image as an HTMLImageElement.\r\n * @param input url string, ArrayBuffer, or Blob to load\r\n * @param onLoad callback called when the image successfully loads\r\n * @param onError callback called when the image fails to load\r\n * @param offlineProvider offline provider for caching\r\n * @param mimeType optional mime type\r\n * @returns the HTMLImageElement of the loaded image\r\n * @hidden\r\n */\r\n ThinEngine._FileToolsLoadImage = function (input, onLoad, onError, offlineProvider, mimeType) {\r\n throw _DevTools.WarnImport(\"FileTools\");\r\n };\r\n /**\r\n * @hidden\r\n */\r\n ThinEngine.prototype._rescaleTexture = function (source, destination, scene, internalFormat, onComplete) {\r\n };\r\n /**\r\n * Creates a raw texture\r\n * @param data defines the data to store in the texture\r\n * @param width defines the width of the texture\r\n * @param height defines the height of the texture\r\n * @param format defines the format of the data\r\n * @param generateMipMaps defines if the engine should generate the mip levels\r\n * @param invertY defines if data must be stored with Y axis inverted\r\n * @param samplingMode defines the required sampling mode (Texture.NEAREST_SAMPLINGMODE by default)\r\n * @param compression defines the compression used (null by default)\r\n * @param type defines the type fo the data (Engine.TEXTURETYPE_UNSIGNED_INT by default)\r\n * @returns the raw texture inside an InternalTexture\r\n */\r\n ThinEngine.prototype.createRawTexture = function (data, width, height, format, generateMipMaps, invertY, samplingMode, compression, type) {\r\n if (compression === void 0) { compression = null; }\r\n if (type === void 0) { type = 0; }\r\n throw _DevTools.WarnImport(\"Engine.RawTexture\");\r\n };\r\n /**\r\n * Creates a new raw cube texture\r\n * @param data defines the array of data to use to create each face\r\n * @param size defines the size of the textures\r\n * @param format defines the format of the data\r\n * @param type defines the type of the data (like Engine.TEXTURETYPE_UNSIGNED_INT)\r\n * @param generateMipMaps defines if the engine should generate the mip levels\r\n * @param invertY defines if data must be stored with Y axis inverted\r\n * @param samplingMode defines the required sampling mode (like Texture.NEAREST_SAMPLINGMODE)\r\n * @param compression defines the compression used (null by default)\r\n * @returns the cube texture as an InternalTexture\r\n */\r\n ThinEngine.prototype.createRawCubeTexture = function (data, size, format, type, generateMipMaps, invertY, samplingMode, compression) {\r\n if (compression === void 0) { compression = null; }\r\n throw _DevTools.WarnImport(\"Engine.RawTexture\");\r\n };\r\n /**\r\n * Creates a new raw 3D texture\r\n * @param data defines the data used to create the texture\r\n * @param width defines the width of the texture\r\n * @param height defines the height of the texture\r\n * @param depth defines the depth of the texture\r\n * @param format defines the format of the texture\r\n * @param generateMipMaps defines if the engine must generate mip levels\r\n * @param invertY defines if data must be stored with Y axis inverted\r\n * @param samplingMode defines the required sampling mode (like Texture.NEAREST_SAMPLINGMODE)\r\n * @param compression defines the compressed used (can be null)\r\n * @param textureType defines the compressed used (can be null)\r\n * @returns a new raw 3D texture (stored in an InternalTexture)\r\n */\r\n ThinEngine.prototype.createRawTexture3D = function (data, width, height, depth, format, generateMipMaps, invertY, samplingMode, compression, textureType) {\r\n if (compression === void 0) { compression = null; }\r\n if (textureType === void 0) { textureType = 0; }\r\n throw _DevTools.WarnImport(\"Engine.RawTexture\");\r\n };\r\n /**\r\n * Creates a new raw 2D array texture\r\n * @param data defines the data used to create the texture\r\n * @param width defines the width of the texture\r\n * @param height defines the height of the texture\r\n * @param depth defines the number of layers of the texture\r\n * @param format defines the format of the texture\r\n * @param generateMipMaps defines if the engine must generate mip levels\r\n * @param invertY defines if data must be stored with Y axis inverted\r\n * @param samplingMode defines the required sampling mode (like Texture.NEAREST_SAMPLINGMODE)\r\n * @param compression defines the compressed used (can be null)\r\n * @param textureType defines the compressed used (can be null)\r\n * @returns a new raw 2D array texture (stored in an InternalTexture)\r\n */\r\n ThinEngine.prototype.createRawTexture2DArray = function (data, width, height, depth, format, generateMipMaps, invertY, samplingMode, compression, textureType) {\r\n if (compression === void 0) { compression = null; }\r\n if (textureType === void 0) { textureType = 0; }\r\n throw _DevTools.WarnImport(\"Engine.RawTexture\");\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._unpackFlipY = function (value) {\r\n if (this._unpackFlipYCached !== value) {\r\n this._gl.pixelStorei(this._gl.UNPACK_FLIP_Y_WEBGL, value ? 1 : 0);\r\n if (this.enableUnpackFlipYCached) {\r\n this._unpackFlipYCached = value;\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._getUnpackAlignement = function () {\r\n return this._gl.getParameter(this._gl.UNPACK_ALIGNMENT);\r\n };\r\n ThinEngine.prototype._getTextureTarget = function (texture) {\r\n if (texture.isCube) {\r\n return this._gl.TEXTURE_CUBE_MAP;\r\n }\r\n else if (texture.is3D) {\r\n return this._gl.TEXTURE_3D;\r\n }\r\n else if (texture.is2DArray || texture.isMultiview) {\r\n return this._gl.TEXTURE_2D_ARRAY;\r\n }\r\n return this._gl.TEXTURE_2D;\r\n };\r\n /**\r\n * Update the sampling mode of a given texture\r\n * @param samplingMode defines the required sampling mode\r\n * @param texture defines the texture to update\r\n * @param generateMipMaps defines whether to generate mipmaps for the texture\r\n */\r\n ThinEngine.prototype.updateTextureSamplingMode = function (samplingMode, texture, generateMipMaps) {\r\n if (generateMipMaps === void 0) { generateMipMaps = false; }\r\n var target = this._getTextureTarget(texture);\r\n var filters = this._getSamplingParameters(samplingMode, texture.generateMipMaps || generateMipMaps);\r\n this._setTextureParameterInteger(target, this._gl.TEXTURE_MAG_FILTER, filters.mag, texture);\r\n this._setTextureParameterInteger(target, this._gl.TEXTURE_MIN_FILTER, filters.min);\r\n if (generateMipMaps) {\r\n texture.generateMipMaps = true;\r\n this._gl.generateMipmap(target);\r\n }\r\n this._bindTextureDirectly(target, null);\r\n texture.samplingMode = samplingMode;\r\n };\r\n /**\r\n * Update the sampling mode of a given texture\r\n * @param texture defines the texture to update\r\n * @param wrapU defines the texture wrap mode of the u coordinates\r\n * @param wrapV defines the texture wrap mode of the v coordinates\r\n * @param wrapR defines the texture wrap mode of the r coordinates\r\n */\r\n ThinEngine.prototype.updateTextureWrappingMode = function (texture, wrapU, wrapV, wrapR) {\r\n if (wrapV === void 0) { wrapV = null; }\r\n if (wrapR === void 0) { wrapR = null; }\r\n var target = this._getTextureTarget(texture);\r\n if (wrapU !== null) {\r\n this._setTextureParameterInteger(target, this._gl.TEXTURE_WRAP_S, this._getTextureWrapMode(wrapU), texture);\r\n texture._cachedWrapU = wrapU;\r\n }\r\n if (wrapV !== null) {\r\n this._setTextureParameterInteger(target, this._gl.TEXTURE_WRAP_T, this._getTextureWrapMode(wrapV), texture);\r\n texture._cachedWrapV = wrapV;\r\n }\r\n if ((texture.is2DArray || texture.is3D) && (wrapR !== null)) {\r\n this._setTextureParameterInteger(target, this._gl.TEXTURE_WRAP_R, this._getTextureWrapMode(wrapR), texture);\r\n texture._cachedWrapR = wrapR;\r\n }\r\n this._bindTextureDirectly(target, null);\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._setupDepthStencilTexture = function (internalTexture, size, generateStencil, bilinearFiltering, comparisonFunction) {\r\n var width = size.width || size;\r\n var height = size.height || size;\r\n var layers = size.layers || 0;\r\n internalTexture.baseWidth = width;\r\n internalTexture.baseHeight = height;\r\n internalTexture.width = width;\r\n internalTexture.height = height;\r\n internalTexture.is2DArray = layers > 0;\r\n internalTexture.depth = layers;\r\n internalTexture.isReady = true;\r\n internalTexture.samples = 1;\r\n internalTexture.generateMipMaps = false;\r\n internalTexture._generateDepthBuffer = true;\r\n internalTexture._generateStencilBuffer = generateStencil;\r\n internalTexture.samplingMode = bilinearFiltering ? 2 : 1;\r\n internalTexture.type = 0;\r\n internalTexture._comparisonFunction = comparisonFunction;\r\n var gl = this._gl;\r\n var target = this._getTextureTarget(internalTexture);\r\n var samplingParameters = this._getSamplingParameters(internalTexture.samplingMode, false);\r\n gl.texParameteri(target, gl.TEXTURE_MAG_FILTER, samplingParameters.mag);\r\n gl.texParameteri(target, gl.TEXTURE_MIN_FILTER, samplingParameters.min);\r\n gl.texParameteri(target, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\r\n gl.texParameteri(target, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\r\n if (comparisonFunction === 0) {\r\n gl.texParameteri(target, gl.TEXTURE_COMPARE_FUNC, 515);\r\n gl.texParameteri(target, gl.TEXTURE_COMPARE_MODE, gl.NONE);\r\n }\r\n else {\r\n gl.texParameteri(target, gl.TEXTURE_COMPARE_FUNC, comparisonFunction);\r\n gl.texParameteri(target, gl.TEXTURE_COMPARE_MODE, gl.COMPARE_REF_TO_TEXTURE);\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._uploadCompressedDataToTextureDirectly = function (texture, internalFormat, width, height, data, faceIndex, lod) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (lod === void 0) { lod = 0; }\r\n var gl = this._gl;\r\n var target = gl.TEXTURE_2D;\r\n if (texture.isCube) {\r\n target = gl.TEXTURE_CUBE_MAP_POSITIVE_X + faceIndex;\r\n }\r\n this._gl.compressedTexImage2D(target, lod, internalFormat, width, height, 0, data);\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._uploadDataToTextureDirectly = function (texture, imageData, faceIndex, lod, babylonInternalFormat, useTextureWidthAndHeight) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (lod === void 0) { lod = 0; }\r\n if (useTextureWidthAndHeight === void 0) { useTextureWidthAndHeight = false; }\r\n var gl = this._gl;\r\n var textureType = this._getWebGLTextureType(texture.type);\r\n var format = this._getInternalFormat(texture.format);\r\n var internalFormat = babylonInternalFormat === undefined ? this._getRGBABufferInternalSizedFormat(texture.type, texture.format) : this._getInternalFormat(babylonInternalFormat);\r\n this._unpackFlipY(texture.invertY);\r\n var target = gl.TEXTURE_2D;\r\n if (texture.isCube) {\r\n target = gl.TEXTURE_CUBE_MAP_POSITIVE_X + faceIndex;\r\n }\r\n var lodMaxWidth = Math.round(Math.log(texture.width) * Math.LOG2E);\r\n var lodMaxHeight = Math.round(Math.log(texture.height) * Math.LOG2E);\r\n var width = useTextureWidthAndHeight ? texture.width : Math.pow(2, Math.max(lodMaxWidth - lod, 0));\r\n var height = useTextureWidthAndHeight ? texture.height : Math.pow(2, Math.max(lodMaxHeight - lod, 0));\r\n gl.texImage2D(target, lod, internalFormat, width, height, 0, format, textureType, imageData);\r\n };\r\n /**\r\n * Update a portion of an internal texture\r\n * @param texture defines the texture to update\r\n * @param imageData defines the data to store into the texture\r\n * @param xOffset defines the x coordinates of the update rectangle\r\n * @param yOffset defines the y coordinates of the update rectangle\r\n * @param width defines the width of the update rectangle\r\n * @param height defines the height of the update rectangle\r\n * @param faceIndex defines the face index if texture is a cube (0 by default)\r\n * @param lod defines the lod level to update (0 by default)\r\n */\r\n ThinEngine.prototype.updateTextureData = function (texture, imageData, xOffset, yOffset, width, height, faceIndex, lod) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (lod === void 0) { lod = 0; }\r\n var gl = this._gl;\r\n var textureType = this._getWebGLTextureType(texture.type);\r\n var format = this._getInternalFormat(texture.format);\r\n this._unpackFlipY(texture.invertY);\r\n var target = gl.TEXTURE_2D;\r\n if (texture.isCube) {\r\n target = gl.TEXTURE_CUBE_MAP_POSITIVE_X + faceIndex;\r\n }\r\n gl.texSubImage2D(target, lod, xOffset, yOffset, width, height, format, textureType, imageData);\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._uploadArrayBufferViewToTexture = function (texture, imageData, faceIndex, lod) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (lod === void 0) { lod = 0; }\r\n var gl = this._gl;\r\n var bindTarget = texture.isCube ? gl.TEXTURE_CUBE_MAP : gl.TEXTURE_2D;\r\n this._bindTextureDirectly(bindTarget, texture, true);\r\n this._uploadDataToTextureDirectly(texture, imageData, faceIndex, lod);\r\n this._bindTextureDirectly(bindTarget, null, true);\r\n };\r\n ThinEngine.prototype._prepareWebGLTextureContinuation = function (texture, scene, noMipmap, isCompressed, samplingMode) {\r\n var gl = this._gl;\r\n if (!gl) {\r\n return;\r\n }\r\n var filters = this._getSamplingParameters(samplingMode, !noMipmap);\r\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, filters.mag);\r\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, filters.min);\r\n if (!noMipmap && !isCompressed) {\r\n gl.generateMipmap(gl.TEXTURE_2D);\r\n }\r\n this._bindTextureDirectly(gl.TEXTURE_2D, null);\r\n // this.resetTextureCache();\r\n if (scene) {\r\n scene._removePendingData(texture);\r\n }\r\n texture.onLoadedObservable.notifyObservers(texture);\r\n texture.onLoadedObservable.clear();\r\n };\r\n ThinEngine.prototype._prepareWebGLTexture = function (texture, scene, width, height, invertY, noMipmap, isCompressed, processFunction, samplingMode) {\r\n var _this = this;\r\n if (samplingMode === void 0) { samplingMode = 3; }\r\n var maxTextureSize = this.getCaps().maxTextureSize;\r\n var potWidth = Math.min(maxTextureSize, this.needPOTTextures ? ThinEngine.GetExponentOfTwo(width, maxTextureSize) : width);\r\n var potHeight = Math.min(maxTextureSize, this.needPOTTextures ? ThinEngine.GetExponentOfTwo(height, maxTextureSize) : height);\r\n var gl = this._gl;\r\n if (!gl) {\r\n return;\r\n }\r\n if (!texture._webGLTexture) {\r\n // this.resetTextureCache();\r\n if (scene) {\r\n scene._removePendingData(texture);\r\n }\r\n return;\r\n }\r\n this._bindTextureDirectly(gl.TEXTURE_2D, texture, true);\r\n this._unpackFlipY(invertY === undefined ? true : (invertY ? true : false));\r\n texture.baseWidth = width;\r\n texture.baseHeight = height;\r\n texture.width = potWidth;\r\n texture.height = potHeight;\r\n texture.isReady = true;\r\n if (processFunction(potWidth, potHeight, function () {\r\n _this._prepareWebGLTextureContinuation(texture, scene, noMipmap, isCompressed, samplingMode);\r\n })) {\r\n // Returning as texture needs extra async steps\r\n return;\r\n }\r\n this._prepareWebGLTextureContinuation(texture, scene, noMipmap, isCompressed, samplingMode);\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._setupFramebufferDepthAttachments = function (generateStencilBuffer, generateDepthBuffer, width, height, samples) {\r\n if (samples === void 0) { samples = 1; }\r\n var gl = this._gl;\r\n // Create the depth/stencil buffer\r\n if (generateStencilBuffer && generateDepthBuffer) {\r\n return this._getDepthStencilBuffer(width, height, samples, gl.DEPTH_STENCIL, gl.DEPTH24_STENCIL8, gl.DEPTH_STENCIL_ATTACHMENT);\r\n }\r\n if (generateDepthBuffer) {\r\n var depthFormat = gl.DEPTH_COMPONENT16;\r\n if (this._webGLVersion > 1) {\r\n depthFormat = gl.DEPTH_COMPONENT32F;\r\n }\r\n return this._getDepthStencilBuffer(width, height, samples, depthFormat, depthFormat, gl.DEPTH_ATTACHMENT);\r\n }\r\n if (generateStencilBuffer) {\r\n return this._getDepthStencilBuffer(width, height, samples, gl.STENCIL_INDEX8, gl.STENCIL_INDEX8, gl.STENCIL_ATTACHMENT);\r\n }\r\n return null;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._releaseFramebufferObjects = function (texture) {\r\n var gl = this._gl;\r\n if (texture._framebuffer) {\r\n gl.deleteFramebuffer(texture._framebuffer);\r\n texture._framebuffer = null;\r\n }\r\n if (texture._depthStencilBuffer) {\r\n gl.deleteRenderbuffer(texture._depthStencilBuffer);\r\n texture._depthStencilBuffer = null;\r\n }\r\n if (texture._MSAAFramebuffer) {\r\n gl.deleteFramebuffer(texture._MSAAFramebuffer);\r\n texture._MSAAFramebuffer = null;\r\n }\r\n if (texture._MSAARenderBuffer) {\r\n gl.deleteRenderbuffer(texture._MSAARenderBuffer);\r\n texture._MSAARenderBuffer = null;\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._releaseTexture = function (texture) {\r\n this._releaseFramebufferObjects(texture);\r\n this._deleteTexture(texture._webGLTexture);\r\n // Unbind channels\r\n this.unbindAllTextures();\r\n var index = this._internalTexturesCache.indexOf(texture);\r\n if (index !== -1) {\r\n this._internalTexturesCache.splice(index, 1);\r\n }\r\n // Integrated fixed lod samplers.\r\n if (texture._lodTextureHigh) {\r\n texture._lodTextureHigh.dispose();\r\n }\r\n if (texture._lodTextureMid) {\r\n texture._lodTextureMid.dispose();\r\n }\r\n if (texture._lodTextureLow) {\r\n texture._lodTextureLow.dispose();\r\n }\r\n // Integrated irradiance map.\r\n if (texture._irradianceTexture) {\r\n texture._irradianceTexture.dispose();\r\n }\r\n };\r\n ThinEngine.prototype._deleteTexture = function (texture) {\r\n this._gl.deleteTexture(texture);\r\n };\r\n ThinEngine.prototype._setProgram = function (program) {\r\n if (this._currentProgram !== program) {\r\n this._gl.useProgram(program);\r\n this._currentProgram = program;\r\n }\r\n };\r\n /**\r\n * Binds an effect to the webGL context\r\n * @param effect defines the effect to bind\r\n */\r\n ThinEngine.prototype.bindSamplers = function (effect) {\r\n var webGLPipelineContext = effect.getPipelineContext();\r\n this._setProgram(webGLPipelineContext.program);\r\n var samplers = effect.getSamplers();\r\n for (var index = 0; index < samplers.length; index++) {\r\n var uniform = effect.getUniform(samplers[index]);\r\n if (uniform) {\r\n this._boundUniforms[index] = uniform;\r\n }\r\n }\r\n this._currentEffect = null;\r\n };\r\n ThinEngine.prototype._activateCurrentTexture = function () {\r\n if (this._currentTextureChannel !== this._activeChannel) {\r\n this._gl.activeTexture(this._gl.TEXTURE0 + this._activeChannel);\r\n this._currentTextureChannel = this._activeChannel;\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._bindTextureDirectly = function (target, texture, forTextureDataUpdate, force) {\r\n if (forTextureDataUpdate === void 0) { forTextureDataUpdate = false; }\r\n if (force === void 0) { force = false; }\r\n var wasPreviouslyBound = false;\r\n var isTextureForRendering = texture && texture._associatedChannel > -1;\r\n if (forTextureDataUpdate && isTextureForRendering) {\r\n this._activeChannel = texture._associatedChannel;\r\n }\r\n var currentTextureBound = this._boundTexturesCache[this._activeChannel];\r\n if (currentTextureBound !== texture || force) {\r\n this._activateCurrentTexture();\r\n if (texture && texture.isMultiview) {\r\n this._gl.bindTexture(target, texture ? texture._colorTextureArray : null);\r\n }\r\n else {\r\n this._gl.bindTexture(target, texture ? texture._webGLTexture : null);\r\n }\r\n this._boundTexturesCache[this._activeChannel] = texture;\r\n if (texture) {\r\n texture._associatedChannel = this._activeChannel;\r\n }\r\n }\r\n else if (forTextureDataUpdate) {\r\n wasPreviouslyBound = true;\r\n this._activateCurrentTexture();\r\n }\r\n if (isTextureForRendering && !forTextureDataUpdate) {\r\n this._bindSamplerUniformToChannel(texture._associatedChannel, this._activeChannel);\r\n }\r\n return wasPreviouslyBound;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._bindTexture = function (channel, texture) {\r\n if (channel === undefined) {\r\n return;\r\n }\r\n if (texture) {\r\n texture._associatedChannel = channel;\r\n }\r\n this._activeChannel = channel;\r\n var target = texture ? this._getTextureTarget(texture) : this._gl.TEXTURE_2D;\r\n this._bindTextureDirectly(target, texture);\r\n };\r\n /**\r\n * Unbind all textures from the webGL context\r\n */\r\n ThinEngine.prototype.unbindAllTextures = function () {\r\n for (var channel = 0; channel < this._maxSimultaneousTextures; channel++) {\r\n this._activeChannel = channel;\r\n this._bindTextureDirectly(this._gl.TEXTURE_2D, null);\r\n this._bindTextureDirectly(this._gl.TEXTURE_CUBE_MAP, null);\r\n if (this.webGLVersion > 1) {\r\n this._bindTextureDirectly(this._gl.TEXTURE_3D, null);\r\n this._bindTextureDirectly(this._gl.TEXTURE_2D_ARRAY, null);\r\n }\r\n }\r\n };\r\n /**\r\n * Sets a texture to the according uniform.\r\n * @param channel The texture channel\r\n * @param uniform The uniform to set\r\n * @param texture The texture to apply\r\n */\r\n ThinEngine.prototype.setTexture = function (channel, uniform, texture) {\r\n if (channel === undefined) {\r\n return;\r\n }\r\n if (uniform) {\r\n this._boundUniforms[channel] = uniform;\r\n }\r\n this._setTexture(channel, texture);\r\n };\r\n ThinEngine.prototype._bindSamplerUniformToChannel = function (sourceSlot, destination) {\r\n var uniform = this._boundUniforms[sourceSlot];\r\n if (!uniform || uniform._currentState === destination) {\r\n return;\r\n }\r\n this._gl.uniform1i(uniform, destination);\r\n uniform._currentState = destination;\r\n };\r\n ThinEngine.prototype._getTextureWrapMode = function (mode) {\r\n switch (mode) {\r\n case 1:\r\n return this._gl.REPEAT;\r\n case 0:\r\n return this._gl.CLAMP_TO_EDGE;\r\n case 2:\r\n return this._gl.MIRRORED_REPEAT;\r\n }\r\n return this._gl.REPEAT;\r\n };\r\n ThinEngine.prototype._setTexture = function (channel, texture, isPartOfTextureArray, depthStencilTexture) {\r\n if (isPartOfTextureArray === void 0) { isPartOfTextureArray = false; }\r\n if (depthStencilTexture === void 0) { depthStencilTexture = false; }\r\n // Not ready?\r\n if (!texture) {\r\n if (this._boundTexturesCache[channel] != null) {\r\n this._activeChannel = channel;\r\n this._bindTextureDirectly(this._gl.TEXTURE_2D, null);\r\n this._bindTextureDirectly(this._gl.TEXTURE_CUBE_MAP, null);\r\n if (this.webGLVersion > 1) {\r\n this._bindTextureDirectly(this._gl.TEXTURE_3D, null);\r\n this._bindTextureDirectly(this._gl.TEXTURE_2D_ARRAY, null);\r\n }\r\n }\r\n return false;\r\n }\r\n // Video\r\n if (texture.video) {\r\n this._activeChannel = channel;\r\n texture.update();\r\n }\r\n else if (texture.delayLoadState === 4) { // Delay loading\r\n texture.delayLoad();\r\n return false;\r\n }\r\n var internalTexture;\r\n if (depthStencilTexture) {\r\n internalTexture = texture.depthStencilTexture;\r\n }\r\n else if (texture.isReady()) {\r\n internalTexture = texture.getInternalTexture();\r\n }\r\n else if (texture.isCube) {\r\n internalTexture = this.emptyCubeTexture;\r\n }\r\n else if (texture.is3D) {\r\n internalTexture = this.emptyTexture3D;\r\n }\r\n else if (texture.is2DArray) {\r\n internalTexture = this.emptyTexture2DArray;\r\n }\r\n else {\r\n internalTexture = this.emptyTexture;\r\n }\r\n if (!isPartOfTextureArray && internalTexture) {\r\n internalTexture._associatedChannel = channel;\r\n }\r\n var needToBind = true;\r\n if (this._boundTexturesCache[channel] === internalTexture) {\r\n if (!isPartOfTextureArray) {\r\n this._bindSamplerUniformToChannel(internalTexture._associatedChannel, channel);\r\n }\r\n needToBind = false;\r\n }\r\n this._activeChannel = channel;\r\n var target = this._getTextureTarget(internalTexture);\r\n if (needToBind) {\r\n this._bindTextureDirectly(target, internalTexture, isPartOfTextureArray);\r\n }\r\n if (internalTexture && !internalTexture.isMultiview) {\r\n // CUBIC_MODE and SKYBOX_MODE both require CLAMP_TO_EDGE. All other modes use REPEAT.\r\n if (internalTexture.isCube && internalTexture._cachedCoordinatesMode !== texture.coordinatesMode) {\r\n internalTexture._cachedCoordinatesMode = texture.coordinatesMode;\r\n var textureWrapMode = (texture.coordinatesMode !== 3 && texture.coordinatesMode !== 5) ? 1 : 0;\r\n texture.wrapU = textureWrapMode;\r\n texture.wrapV = textureWrapMode;\r\n }\r\n if (internalTexture._cachedWrapU !== texture.wrapU) {\r\n internalTexture._cachedWrapU = texture.wrapU;\r\n this._setTextureParameterInteger(target, this._gl.TEXTURE_WRAP_S, this._getTextureWrapMode(texture.wrapU), internalTexture);\r\n }\r\n if (internalTexture._cachedWrapV !== texture.wrapV) {\r\n internalTexture._cachedWrapV = texture.wrapV;\r\n this._setTextureParameterInteger(target, this._gl.TEXTURE_WRAP_T, this._getTextureWrapMode(texture.wrapV), internalTexture);\r\n }\r\n if (internalTexture.is3D && internalTexture._cachedWrapR !== texture.wrapR) {\r\n internalTexture._cachedWrapR = texture.wrapR;\r\n this._setTextureParameterInteger(target, this._gl.TEXTURE_WRAP_R, this._getTextureWrapMode(texture.wrapR), internalTexture);\r\n }\r\n this._setAnisotropicLevel(target, internalTexture, texture.anisotropicFilteringLevel);\r\n }\r\n return true;\r\n };\r\n /**\r\n * Sets an array of texture to the webGL context\r\n * @param channel defines the channel where the texture array must be set\r\n * @param uniform defines the associated uniform location\r\n * @param textures defines the array of textures to bind\r\n */\r\n ThinEngine.prototype.setTextureArray = function (channel, uniform, textures) {\r\n if (channel === undefined || !uniform) {\r\n return;\r\n }\r\n if (!this._textureUnits || this._textureUnits.length !== textures.length) {\r\n this._textureUnits = new Int32Array(textures.length);\r\n }\r\n for (var i = 0; i < textures.length; i++) {\r\n var texture = textures[i].getInternalTexture();\r\n if (texture) {\r\n this._textureUnits[i] = channel + i;\r\n texture._associatedChannel = channel + i;\r\n }\r\n else {\r\n this._textureUnits[i] = -1;\r\n }\r\n }\r\n this._gl.uniform1iv(uniform, this._textureUnits);\r\n for (var index = 0; index < textures.length; index++) {\r\n this._setTexture(this._textureUnits[index], textures[index], true);\r\n }\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._setAnisotropicLevel = function (target, internalTexture, anisotropicFilteringLevel) {\r\n var anisotropicFilterExtension = this._caps.textureAnisotropicFilterExtension;\r\n if (internalTexture.samplingMode !== 11\r\n && internalTexture.samplingMode !== 3\r\n && internalTexture.samplingMode !== 2) {\r\n anisotropicFilteringLevel = 1; // Forcing the anisotropic to 1 because else webgl will force filters to linear\r\n }\r\n if (anisotropicFilterExtension && internalTexture._cachedAnisotropicFilteringLevel !== anisotropicFilteringLevel) {\r\n this._setTextureParameterFloat(target, anisotropicFilterExtension.TEXTURE_MAX_ANISOTROPY_EXT, Math.min(anisotropicFilteringLevel, this._caps.maxAnisotropy), internalTexture);\r\n internalTexture._cachedAnisotropicFilteringLevel = anisotropicFilteringLevel;\r\n }\r\n };\r\n ThinEngine.prototype._setTextureParameterFloat = function (target, parameter, value, texture) {\r\n this._bindTextureDirectly(target, texture, true, true);\r\n this._gl.texParameterf(target, parameter, value);\r\n };\r\n ThinEngine.prototype._setTextureParameterInteger = function (target, parameter, value, texture) {\r\n if (texture) {\r\n this._bindTextureDirectly(target, texture, true, true);\r\n }\r\n this._gl.texParameteri(target, parameter, value);\r\n };\r\n /**\r\n * Unbind all vertex attributes from the webGL context\r\n */\r\n ThinEngine.prototype.unbindAllAttributes = function () {\r\n if (this._mustWipeVertexAttributes) {\r\n this._mustWipeVertexAttributes = false;\r\n for (var i = 0; i < this._caps.maxVertexAttribs; i++) {\r\n this.disableAttributeByIndex(i);\r\n }\r\n return;\r\n }\r\n for (var i = 0, ul = this._vertexAttribArraysEnabled.length; i < ul; i++) {\r\n if (i >= this._caps.maxVertexAttribs || !this._vertexAttribArraysEnabled[i]) {\r\n continue;\r\n }\r\n this.disableAttributeByIndex(i);\r\n }\r\n };\r\n /**\r\n * Force the engine to release all cached effects. This means that next effect compilation will have to be done completely even if a similar effect was already compiled\r\n */\r\n ThinEngine.prototype.releaseEffects = function () {\r\n for (var name in this._compiledEffects) {\r\n var webGLPipelineContext = this._compiledEffects[name].getPipelineContext();\r\n this._deletePipelineContext(webGLPipelineContext);\r\n }\r\n this._compiledEffects = {};\r\n };\r\n /**\r\n * Dispose and release all associated resources\r\n */\r\n ThinEngine.prototype.dispose = function () {\r\n this.stopRenderLoop();\r\n // Clear observables\r\n if (this.onBeforeTextureInitObservable) {\r\n this.onBeforeTextureInitObservable.clear();\r\n }\r\n // Empty texture\r\n if (this._emptyTexture) {\r\n this._releaseTexture(this._emptyTexture);\r\n this._emptyTexture = null;\r\n }\r\n if (this._emptyCubeTexture) {\r\n this._releaseTexture(this._emptyCubeTexture);\r\n this._emptyCubeTexture = null;\r\n }\r\n if (this._dummyFramebuffer) {\r\n this._gl.deleteFramebuffer(this._dummyFramebuffer);\r\n }\r\n // Release effects\r\n this.releaseEffects();\r\n // Unbind\r\n this.unbindAllAttributes();\r\n this._boundUniforms = [];\r\n // Events\r\n if (DomManagement.IsWindowObjectExist()) {\r\n if (this._renderingCanvas) {\r\n if (!this._doNotHandleContextLost) {\r\n this._renderingCanvas.removeEventListener(\"webglcontextlost\", this._onContextLost);\r\n this._renderingCanvas.removeEventListener(\"webglcontextrestored\", this._onContextRestored);\r\n }\r\n }\r\n }\r\n this._workingCanvas = null;\r\n this._workingContext = null;\r\n this._currentBufferPointers = [];\r\n this._renderingCanvas = null;\r\n this._currentProgram = null;\r\n this._boundRenderFunction = null;\r\n Effect.ResetCache();\r\n // Abort active requests\r\n for (var _i = 0, _a = this._activeRequests; _i < _a.length; _i++) {\r\n var request = _a[_i];\r\n request.abort();\r\n }\r\n };\r\n /**\r\n * Attach a new callback raised when context lost event is fired\r\n * @param callback defines the callback to call\r\n */\r\n ThinEngine.prototype.attachContextLostEvent = function (callback) {\r\n if (this._renderingCanvas) {\r\n this._renderingCanvas.addEventListener(\"webglcontextlost\", callback, false);\r\n }\r\n };\r\n /**\r\n * Attach a new callback raised when context restored event is fired\r\n * @param callback defines the callback to call\r\n */\r\n ThinEngine.prototype.attachContextRestoredEvent = function (callback) {\r\n if (this._renderingCanvas) {\r\n this._renderingCanvas.addEventListener(\"webglcontextrestored\", callback, false);\r\n }\r\n };\r\n /**\r\n * Get the current error code of the webGL context\r\n * @returns the error code\r\n * @see https://developer.mozilla.org/en-US/docs/Web/API/WebGLRenderingContext/getError\r\n */\r\n ThinEngine.prototype.getError = function () {\r\n return this._gl.getError();\r\n };\r\n ThinEngine.prototype._canRenderToFloatFramebuffer = function () {\r\n if (this._webGLVersion > 1) {\r\n return this._caps.colorBufferFloat;\r\n }\r\n return this._canRenderToFramebuffer(1);\r\n };\r\n ThinEngine.prototype._canRenderToHalfFloatFramebuffer = function () {\r\n if (this._webGLVersion > 1) {\r\n return this._caps.colorBufferFloat;\r\n }\r\n return this._canRenderToFramebuffer(2);\r\n };\r\n // Thank you : http://stackoverflow.com/questions/28827511/webgl-ios-render-to-floating-point-texture\r\n ThinEngine.prototype._canRenderToFramebuffer = function (type) {\r\n var gl = this._gl;\r\n //clear existing errors\r\n while (gl.getError() !== gl.NO_ERROR) { }\r\n var successful = true;\r\n var texture = gl.createTexture();\r\n gl.bindTexture(gl.TEXTURE_2D, texture);\r\n gl.texImage2D(gl.TEXTURE_2D, 0, this._getRGBABufferInternalSizedFormat(type), 1, 1, 0, gl.RGBA, this._getWebGLTextureType(type), null);\r\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);\r\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);\r\n var fb = gl.createFramebuffer();\r\n gl.bindFramebuffer(gl.FRAMEBUFFER, fb);\r\n gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture, 0);\r\n var status = gl.checkFramebufferStatus(gl.FRAMEBUFFER);\r\n successful = successful && (status === gl.FRAMEBUFFER_COMPLETE);\r\n successful = successful && (gl.getError() === gl.NO_ERROR);\r\n //try render by clearing frame buffer's color buffer\r\n if (successful) {\r\n gl.clear(gl.COLOR_BUFFER_BIT);\r\n successful = successful && (gl.getError() === gl.NO_ERROR);\r\n }\r\n //try reading from frame to ensure render occurs (just creating the FBO is not sufficient to determine if rendering is supported)\r\n if (successful) {\r\n //in practice it's sufficient to just read from the backbuffer rather than handle potentially issues reading from the texture\r\n gl.bindFramebuffer(gl.FRAMEBUFFER, null);\r\n var readFormat = gl.RGBA;\r\n var readType = gl.UNSIGNED_BYTE;\r\n var buffer = new Uint8Array(4);\r\n gl.readPixels(0, 0, 1, 1, readFormat, readType, buffer);\r\n successful = successful && (gl.getError() === gl.NO_ERROR);\r\n }\r\n //clean up\r\n gl.deleteTexture(texture);\r\n gl.deleteFramebuffer(fb);\r\n gl.bindFramebuffer(gl.FRAMEBUFFER, null);\r\n //clear accumulated errors\r\n while (!successful && (gl.getError() !== gl.NO_ERROR)) { }\r\n return successful;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._getWebGLTextureType = function (type) {\r\n if (this._webGLVersion === 1) {\r\n switch (type) {\r\n case 1:\r\n return this._gl.FLOAT;\r\n case 2:\r\n return this._gl.HALF_FLOAT_OES;\r\n case 0:\r\n return this._gl.UNSIGNED_BYTE;\r\n case 8:\r\n return this._gl.UNSIGNED_SHORT_4_4_4_4;\r\n case 9:\r\n return this._gl.UNSIGNED_SHORT_5_5_5_1;\r\n case 10:\r\n return this._gl.UNSIGNED_SHORT_5_6_5;\r\n }\r\n return this._gl.UNSIGNED_BYTE;\r\n }\r\n switch (type) {\r\n case 3:\r\n return this._gl.BYTE;\r\n case 0:\r\n return this._gl.UNSIGNED_BYTE;\r\n case 4:\r\n return this._gl.SHORT;\r\n case 5:\r\n return this._gl.UNSIGNED_SHORT;\r\n case 6:\r\n return this._gl.INT;\r\n case 7: // Refers to UNSIGNED_INT\r\n return this._gl.UNSIGNED_INT;\r\n case 1:\r\n return this._gl.FLOAT;\r\n case 2:\r\n return this._gl.HALF_FLOAT;\r\n case 8:\r\n return this._gl.UNSIGNED_SHORT_4_4_4_4;\r\n case 9:\r\n return this._gl.UNSIGNED_SHORT_5_5_5_1;\r\n case 10:\r\n return this._gl.UNSIGNED_SHORT_5_6_5;\r\n case 11:\r\n return this._gl.UNSIGNED_INT_2_10_10_10_REV;\r\n case 12:\r\n return this._gl.UNSIGNED_INT_24_8;\r\n case 13:\r\n return this._gl.UNSIGNED_INT_10F_11F_11F_REV;\r\n case 14:\r\n return this._gl.UNSIGNED_INT_5_9_9_9_REV;\r\n case 15:\r\n return this._gl.FLOAT_32_UNSIGNED_INT_24_8_REV;\r\n }\r\n return this._gl.UNSIGNED_BYTE;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._getInternalFormat = function (format) {\r\n var internalFormat = this._gl.RGBA;\r\n switch (format) {\r\n case 0:\r\n internalFormat = this._gl.ALPHA;\r\n break;\r\n case 1:\r\n internalFormat = this._gl.LUMINANCE;\r\n break;\r\n case 2:\r\n internalFormat = this._gl.LUMINANCE_ALPHA;\r\n break;\r\n case 6:\r\n internalFormat = this._gl.RED;\r\n break;\r\n case 7:\r\n internalFormat = this._gl.RG;\r\n break;\r\n case 4:\r\n internalFormat = this._gl.RGB;\r\n break;\r\n case 5:\r\n internalFormat = this._gl.RGBA;\r\n break;\r\n }\r\n if (this._webGLVersion > 1) {\r\n switch (format) {\r\n case 8:\r\n internalFormat = this._gl.RED_INTEGER;\r\n break;\r\n case 9:\r\n internalFormat = this._gl.RG_INTEGER;\r\n break;\r\n case 10:\r\n internalFormat = this._gl.RGB_INTEGER;\r\n break;\r\n case 11:\r\n internalFormat = this._gl.RGBA_INTEGER;\r\n break;\r\n }\r\n }\r\n return internalFormat;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._getRGBABufferInternalSizedFormat = function (type, format) {\r\n if (this._webGLVersion === 1) {\r\n if (format !== undefined) {\r\n switch (format) {\r\n case 0:\r\n return this._gl.ALPHA;\r\n case 1:\r\n return this._gl.LUMINANCE;\r\n case 2:\r\n return this._gl.LUMINANCE_ALPHA;\r\n case 4:\r\n return this._gl.RGB;\r\n }\r\n }\r\n return this._gl.RGBA;\r\n }\r\n switch (type) {\r\n case 3:\r\n switch (format) {\r\n case 6:\r\n return this._gl.R8_SNORM;\r\n case 7:\r\n return this._gl.RG8_SNORM;\r\n case 4:\r\n return this._gl.RGB8_SNORM;\r\n case 8:\r\n return this._gl.R8I;\r\n case 9:\r\n return this._gl.RG8I;\r\n case 10:\r\n return this._gl.RGB8I;\r\n case 11:\r\n return this._gl.RGBA8I;\r\n default:\r\n return this._gl.RGBA8_SNORM;\r\n }\r\n case 0:\r\n switch (format) {\r\n case 6:\r\n return this._gl.R8;\r\n case 7:\r\n return this._gl.RG8;\r\n case 4:\r\n return this._gl.RGB8; // By default. Other possibilities are RGB565, SRGB8.\r\n case 5:\r\n return this._gl.RGBA8; // By default. Other possibilities are RGB5_A1, RGBA4, SRGB8_ALPHA8.\r\n case 8:\r\n return this._gl.R8UI;\r\n case 9:\r\n return this._gl.RG8UI;\r\n case 10:\r\n return this._gl.RGB8UI;\r\n case 11:\r\n return this._gl.RGBA8UI;\r\n case 0:\r\n return this._gl.ALPHA;\r\n case 1:\r\n return this._gl.LUMINANCE;\r\n case 2:\r\n return this._gl.LUMINANCE_ALPHA;\r\n default:\r\n return this._gl.RGBA8;\r\n }\r\n case 4:\r\n switch (format) {\r\n case 8:\r\n return this._gl.R16I;\r\n case 9:\r\n return this._gl.RG16I;\r\n case 10:\r\n return this._gl.RGB16I;\r\n case 11:\r\n return this._gl.RGBA16I;\r\n default:\r\n return this._gl.RGBA16I;\r\n }\r\n case 5:\r\n switch (format) {\r\n case 8:\r\n return this._gl.R16UI;\r\n case 9:\r\n return this._gl.RG16UI;\r\n case 10:\r\n return this._gl.RGB16UI;\r\n case 11:\r\n return this._gl.RGBA16UI;\r\n default:\r\n return this._gl.RGBA16UI;\r\n }\r\n case 6:\r\n switch (format) {\r\n case 8:\r\n return this._gl.R32I;\r\n case 9:\r\n return this._gl.RG32I;\r\n case 10:\r\n return this._gl.RGB32I;\r\n case 11:\r\n return this._gl.RGBA32I;\r\n default:\r\n return this._gl.RGBA32I;\r\n }\r\n case 7: // Refers to UNSIGNED_INT\r\n switch (format) {\r\n case 8:\r\n return this._gl.R32UI;\r\n case 9:\r\n return this._gl.RG32UI;\r\n case 10:\r\n return this._gl.RGB32UI;\r\n case 11:\r\n return this._gl.RGBA32UI;\r\n default:\r\n return this._gl.RGBA32UI;\r\n }\r\n case 1:\r\n switch (format) {\r\n case 6:\r\n return this._gl.R32F; // By default. Other possibility is R16F.\r\n case 7:\r\n return this._gl.RG32F; // By default. Other possibility is RG16F.\r\n case 4:\r\n return this._gl.RGB32F; // By default. Other possibilities are RGB16F, R11F_G11F_B10F, RGB9_E5.\r\n case 5:\r\n return this._gl.RGBA32F; // By default. Other possibility is RGBA16F.\r\n default:\r\n return this._gl.RGBA32F;\r\n }\r\n case 2:\r\n switch (format) {\r\n case 6:\r\n return this._gl.R16F;\r\n case 7:\r\n return this._gl.RG16F;\r\n case 4:\r\n return this._gl.RGB16F; // By default. Other possibilities are R11F_G11F_B10F, RGB9_E5.\r\n case 5:\r\n return this._gl.RGBA16F;\r\n default:\r\n return this._gl.RGBA16F;\r\n }\r\n case 10:\r\n return this._gl.RGB565;\r\n case 13:\r\n return this._gl.R11F_G11F_B10F;\r\n case 14:\r\n return this._gl.RGB9_E5;\r\n case 8:\r\n return this._gl.RGBA4;\r\n case 9:\r\n return this._gl.RGB5_A1;\r\n case 11:\r\n switch (format) {\r\n case 5:\r\n return this._gl.RGB10_A2; // By default. Other possibility is RGB5_A1.\r\n case 11:\r\n return this._gl.RGB10_A2UI;\r\n default:\r\n return this._gl.RGB10_A2;\r\n }\r\n }\r\n return this._gl.RGBA8;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._getRGBAMultiSampleBufferFormat = function (type) {\r\n if (type === 1) {\r\n return this._gl.RGBA32F;\r\n }\r\n else if (type === 2) {\r\n return this._gl.RGBA16F;\r\n }\r\n return this._gl.RGBA8;\r\n };\r\n /** @hidden */\r\n ThinEngine.prototype._loadFile = function (url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError) {\r\n var _this = this;\r\n var request = ThinEngine._FileToolsLoadFile(url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError);\r\n this._activeRequests.push(request);\r\n request.onCompleteObservable.add(function (request) {\r\n _this._activeRequests.splice(_this._activeRequests.indexOf(request), 1);\r\n });\r\n return request;\r\n };\r\n /**\r\n * Loads a file from a url\r\n * @param url url to load\r\n * @param onSuccess callback called when the file successfully loads\r\n * @param onProgress callback called while file is loading (if the server supports this mode)\r\n * @param offlineProvider defines the offline provider for caching\r\n * @param useArrayBuffer defines a boolean indicating that date must be returned as ArrayBuffer\r\n * @param onError callback called when the file fails to load\r\n * @returns a file request object\r\n * @hidden\r\n */\r\n ThinEngine._FileToolsLoadFile = function (url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError) {\r\n throw _DevTools.WarnImport(\"FileTools\");\r\n };\r\n /**\r\n * Reads pixels from the current frame buffer. Please note that this function can be slow\r\n * @param x defines the x coordinate of the rectangle where pixels must be read\r\n * @param y defines the y coordinate of the rectangle where pixels must be read\r\n * @param width defines the width of the rectangle where pixels must be read\r\n * @param height defines the height of the rectangle where pixels must be read\r\n * @param hasAlpha defines whether the output should have alpha or not (defaults to true)\r\n * @returns a Uint8Array containing RGBA colors\r\n */\r\n ThinEngine.prototype.readPixels = function (x, y, width, height, hasAlpha) {\r\n if (hasAlpha === void 0) { hasAlpha = true; }\r\n var numChannels = hasAlpha ? 4 : 3;\r\n var format = hasAlpha ? this._gl.RGBA : this._gl.RGB;\r\n var data = new Uint8Array(height * width * numChannels);\r\n this._gl.readPixels(x, y, width, height, format, this._gl.UNSIGNED_BYTE, data);\r\n return data;\r\n };\r\n Object.defineProperty(ThinEngine, \"IsSupported\", {\r\n /**\r\n * Gets a boolean indicating if the engine can be instanciated (ie. if a webGL context can be found)\r\n */\r\n get: function () {\r\n return this.isSupported(); // Backward compat\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets a boolean indicating if the engine can be instanciated (ie. if a webGL context can be found)\r\n * @returns true if the engine can be created\r\n * @ignorenaming\r\n */\r\n ThinEngine.isSupported = function () {\r\n if (this._HasMajorPerformanceCaveat !== null) {\r\n return !this._HasMajorPerformanceCaveat; // We know it is performant so WebGL is supported\r\n }\r\n if (this._IsSupported === null) {\r\n try {\r\n var tempcanvas = CanvasGenerator.CreateCanvas(1, 1);\r\n var gl = tempcanvas.getContext(\"webgl\") || tempcanvas.getContext(\"experimental-webgl\");\r\n this._IsSupported = gl != null && !!window.WebGLRenderingContext;\r\n }\r\n catch (e) {\r\n this._IsSupported = false;\r\n }\r\n }\r\n return this._IsSupported;\r\n };\r\n Object.defineProperty(ThinEngine, \"HasMajorPerformanceCaveat\", {\r\n /**\r\n * Gets a boolean indicating if the engine can be instanciated on a performant device (ie. if a webGL context can be found and it does not use a slow implementation)\r\n */\r\n get: function () {\r\n if (this._HasMajorPerformanceCaveat === null) {\r\n try {\r\n var tempcanvas = CanvasGenerator.CreateCanvas(1, 1);\r\n var gl = tempcanvas.getContext(\"webgl\", { failIfMajorPerformanceCaveat: true }) || tempcanvas.getContext(\"experimental-webgl\", { failIfMajorPerformanceCaveat: true });\r\n this._HasMajorPerformanceCaveat = !gl;\r\n }\r\n catch (e) {\r\n this._HasMajorPerformanceCaveat = false;\r\n }\r\n }\r\n return this._HasMajorPerformanceCaveat;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Find the next highest power of two.\r\n * @param x Number to start search from.\r\n * @return Next highest power of two.\r\n */\r\n ThinEngine.CeilingPOT = function (x) {\r\n x--;\r\n x |= x >> 1;\r\n x |= x >> 2;\r\n x |= x >> 4;\r\n x |= x >> 8;\r\n x |= x >> 16;\r\n x++;\r\n return x;\r\n };\r\n /**\r\n * Find the next lowest power of two.\r\n * @param x Number to start search from.\r\n * @return Next lowest power of two.\r\n */\r\n ThinEngine.FloorPOT = function (x) {\r\n x = x | (x >> 1);\r\n x = x | (x >> 2);\r\n x = x | (x >> 4);\r\n x = x | (x >> 8);\r\n x = x | (x >> 16);\r\n return x - (x >> 1);\r\n };\r\n /**\r\n * Find the nearest power of two.\r\n * @param x Number to start search from.\r\n * @return Next nearest power of two.\r\n */\r\n ThinEngine.NearestPOT = function (x) {\r\n var c = ThinEngine.CeilingPOT(x);\r\n var f = ThinEngine.FloorPOT(x);\r\n return (c - x) > (x - f) ? f : c;\r\n };\r\n /**\r\n * Get the closest exponent of two\r\n * @param value defines the value to approximate\r\n * @param max defines the maximum value to return\r\n * @param mode defines how to define the closest value\r\n * @returns closest exponent of two of the given value\r\n */\r\n ThinEngine.GetExponentOfTwo = function (value, max, mode) {\r\n if (mode === void 0) { mode = 2; }\r\n var pot;\r\n switch (mode) {\r\n case 1:\r\n pot = ThinEngine.FloorPOT(value);\r\n break;\r\n case 2:\r\n pot = ThinEngine.NearestPOT(value);\r\n break;\r\n case 3:\r\n default:\r\n pot = ThinEngine.CeilingPOT(value);\r\n break;\r\n }\r\n return Math.min(pot, max);\r\n };\r\n /**\r\n * Queue a new function into the requested animation frame pool (ie. this function will be executed byt the browser for the next frame)\r\n * @param func - the function to be called\r\n * @param requester - the object that will request the next frame. Falls back to window.\r\n * @returns frame number\r\n */\r\n ThinEngine.QueueNewFrame = function (func, requester) {\r\n if (!DomManagement.IsWindowObjectExist()) {\r\n if (typeof requestAnimationFrame !== \"undefined\") {\r\n return requestAnimationFrame(func);\r\n }\r\n return setTimeout(func, 16);\r\n }\r\n if (!requester) {\r\n requester = window;\r\n }\r\n if (requester.requestPostAnimationFrame) {\r\n return requester.requestPostAnimationFrame(func);\r\n }\r\n else if (requester.requestAnimationFrame) {\r\n return requester.requestAnimationFrame(func);\r\n }\r\n else if (requester.msRequestAnimationFrame) {\r\n return requester.msRequestAnimationFrame(func);\r\n }\r\n else if (requester.webkitRequestAnimationFrame) {\r\n return requester.webkitRequestAnimationFrame(func);\r\n }\r\n else if (requester.mozRequestAnimationFrame) {\r\n return requester.mozRequestAnimationFrame(func);\r\n }\r\n else if (requester.oRequestAnimationFrame) {\r\n return requester.oRequestAnimationFrame(func);\r\n }\r\n else {\r\n return window.setTimeout(func, 16);\r\n }\r\n };\r\n /**\r\n * Gets host document\r\n * @returns the host document object\r\n */\r\n ThinEngine.prototype.getHostDocument = function () {\r\n if (this._renderingCanvas && this._renderingCanvas.ownerDocument) {\r\n return this._renderingCanvas.ownerDocument;\r\n }\r\n return document;\r\n };\r\n /** Use this array to turn off some WebGL2 features on known buggy browsers version */\r\n ThinEngine.ExceptionList = [\r\n { key: \"Chrome\\/63\\.0\", capture: \"63\\\\.0\\\\.3239\\\\.(\\\\d+)\", captureConstraint: 108, targets: [\"uniformBuffer\"] },\r\n { key: \"Firefox\\/58\", capture: null, captureConstraint: null, targets: [\"uniformBuffer\"] },\r\n { key: \"Firefox\\/59\", capture: null, captureConstraint: null, targets: [\"uniformBuffer\"] },\r\n { key: \"Chrome\\/72.+?Mobile\", capture: null, captureConstraint: null, targets: [\"vao\"] },\r\n { key: \"Chrome\\/73.+?Mobile\", capture: null, captureConstraint: null, targets: [\"vao\"] },\r\n { key: \"Chrome\\/74.+?Mobile\", capture: null, captureConstraint: null, targets: [\"vao\"] },\r\n { key: \"Mac OS.+Chrome\\/71\", capture: null, captureConstraint: null, targets: [\"vao\"] },\r\n { key: \"Mac OS.+Chrome\\/72\", capture: null, captureConstraint: null, targets: [\"vao\"] }\r\n ];\r\n /** @hidden */\r\n ThinEngine._TextureLoaders = [];\r\n // Updatable statics so stick with vars here\r\n /**\r\n * Gets or sets the epsilon value used by collision engine\r\n */\r\n ThinEngine.CollisionsEpsilon = 0.001;\r\n // Statics\r\n ThinEngine._IsSupported = null;\r\n ThinEngine._HasMajorPerformanceCaveat = null;\r\n return ThinEngine;\r\n}());\r\nexport { ThinEngine };\r\n//# sourceMappingURL=thinEngine.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, SerializationHelper, serializeAsVector3 } from \"../Misc/decorators\";\r\nimport { SmartArray } from \"../Misc/smartArray\";\r\nimport { Tools } from \"../Misc/tools\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { Matrix, Vector3, Quaternion } from \"../Maths/math.vector\";\r\nimport { Node } from \"../node\";\r\nimport { Logger } from \"../Misc/logger\";\r\nimport { _TypeStore } from '../Misc/typeStore';\r\nimport { _DevTools } from '../Misc/devTools';\r\nimport { Viewport } from '../Maths/math.viewport';\r\nimport { Frustum } from '../Maths/math.frustum';\r\n/**\r\n * This is the base class of all the camera used in the application.\r\n * @see https://doc.babylonjs.com/features/cameras\r\n */\r\nvar Camera = /** @class */ (function (_super) {\r\n __extends(Camera, _super);\r\n /**\r\n * Instantiates a new camera object.\r\n * This should not be used directly but through the inherited cameras: ArcRotate, Free...\r\n * @see https://doc.babylonjs.com/features/cameras\r\n * @param name Defines the name of the camera in the scene\r\n * @param position Defines the position of the camera\r\n * @param scene Defines the scene the camera belongs too\r\n * @param setActiveOnSceneIfNoneActive Defines if the camera should be set as active after creation if no other camera have been defined in the scene\r\n */\r\n function Camera(name, position, scene, setActiveOnSceneIfNoneActive) {\r\n if (setActiveOnSceneIfNoneActive === void 0) { setActiveOnSceneIfNoneActive = true; }\r\n var _this = _super.call(this, name, scene) || this;\r\n /** @hidden */\r\n _this._position = Vector3.Zero();\r\n _this._upVector = Vector3.Up();\r\n /**\r\n * Define the current limit on the left side for an orthographic camera\r\n * In scene unit\r\n */\r\n _this.orthoLeft = null;\r\n /**\r\n * Define the current limit on the right side for an orthographic camera\r\n * In scene unit\r\n */\r\n _this.orthoRight = null;\r\n /**\r\n * Define the current limit on the bottom side for an orthographic camera\r\n * In scene unit\r\n */\r\n _this.orthoBottom = null;\r\n /**\r\n * Define the current limit on the top side for an orthographic camera\r\n * In scene unit\r\n */\r\n _this.orthoTop = null;\r\n /**\r\n * Field Of View is set in Radians. (default is 0.8)\r\n */\r\n _this.fov = 0.8;\r\n /**\r\n * Define the minimum distance the camera can see from.\r\n * This is important to note that the depth buffer are not infinite and the closer it starts\r\n * the more your scene might encounter depth fighting issue.\r\n */\r\n _this.minZ = 1;\r\n /**\r\n * Define the maximum distance the camera can see to.\r\n * This is important to note that the depth buffer are not infinite and the further it end\r\n * the more your scene might encounter depth fighting issue.\r\n */\r\n _this.maxZ = 10000.0;\r\n /**\r\n * Define the default inertia of the camera.\r\n * This helps giving a smooth feeling to the camera movement.\r\n */\r\n _this.inertia = 0.9;\r\n /**\r\n * Define the mode of the camera (Camera.PERSPECTIVE_CAMERA or Camera.ORTHOGRAPHIC_CAMERA)\r\n */\r\n _this.mode = Camera.PERSPECTIVE_CAMERA;\r\n /**\r\n * Define whether the camera is intermediate.\r\n * This is useful to not present the output directly to the screen in case of rig without post process for instance\r\n */\r\n _this.isIntermediate = false;\r\n /**\r\n * Define the viewport of the camera.\r\n * This correspond to the portion of the screen the camera will render to in normalized 0 to 1 unit.\r\n */\r\n _this.viewport = new Viewport(0, 0, 1.0, 1.0);\r\n /**\r\n * Restricts the camera to viewing objects with the same layerMask.\r\n * A camera with a layerMask of 1 will render mesh.layerMask & camera.layerMask!== 0\r\n */\r\n _this.layerMask = 0x0FFFFFFF;\r\n /**\r\n * fovMode sets the camera frustum bounds to the viewport bounds. (default is FOVMODE_VERTICAL_FIXED)\r\n */\r\n _this.fovMode = Camera.FOVMODE_VERTICAL_FIXED;\r\n /**\r\n * Rig mode of the camera.\r\n * This is useful to create the camera with two \"eyes\" instead of one to create VR or stereoscopic scenes.\r\n * This is normally controlled byt the camera themselves as internal use.\r\n */\r\n _this.cameraRigMode = Camera.RIG_MODE_NONE;\r\n /**\r\n * Defines the list of custom render target which are rendered to and then used as the input to this camera's render. Eg. display another camera view on a TV in the main scene\r\n * This is pretty helpfull if you wish to make a camera render to a texture you could reuse somewhere\r\n * else in the scene. (Eg. security camera)\r\n *\r\n * To change the final output target of the camera, camera.outputRenderTarget should be used instead (eg. webXR renders to a render target corrisponding to an HMD)\r\n */\r\n _this.customRenderTargets = new Array();\r\n /**\r\n * When set, the camera will render to this render target instead of the default canvas\r\n *\r\n * If the desire is to use the output of a camera as a texture in the scene consider using camera.customRenderTargets instead\r\n */\r\n _this.outputRenderTarget = null;\r\n /**\r\n * Observable triggered when the camera view matrix has changed.\r\n */\r\n _this.onViewMatrixChangedObservable = new Observable();\r\n /**\r\n * Observable triggered when the camera Projection matrix has changed.\r\n */\r\n _this.onProjectionMatrixChangedObservable = new Observable();\r\n /**\r\n * Observable triggered when the inputs have been processed.\r\n */\r\n _this.onAfterCheckInputsObservable = new Observable();\r\n /**\r\n * Observable triggered when reset has been called and applied to the camera.\r\n */\r\n _this.onRestoreStateObservable = new Observable();\r\n /**\r\n * Is this camera a part of a rig system?\r\n */\r\n _this.isRigCamera = false;\r\n /** @hidden */\r\n _this._rigCameras = new Array();\r\n _this._webvrViewMatrix = Matrix.Identity();\r\n /** @hidden */\r\n _this._skipRendering = false;\r\n /** @hidden */\r\n _this._projectionMatrix = new Matrix();\r\n /** @hidden */\r\n _this._postProcesses = new Array();\r\n /** @hidden */\r\n _this._activeMeshes = new SmartArray(256);\r\n _this._globalPosition = Vector3.Zero();\r\n /** @hidden */\r\n _this._computedViewMatrix = Matrix.Identity();\r\n _this._doNotComputeProjectionMatrix = false;\r\n _this._transformMatrix = Matrix.Zero();\r\n _this._refreshFrustumPlanes = true;\r\n /** @hidden */\r\n _this._isCamera = true;\r\n /** @hidden */\r\n _this._isLeftCamera = false;\r\n /** @hidden */\r\n _this._isRightCamera = false;\r\n _this.getScene().addCamera(_this);\r\n if (setActiveOnSceneIfNoneActive && !_this.getScene().activeCamera) {\r\n _this.getScene().activeCamera = _this;\r\n }\r\n _this.position = position;\r\n return _this;\r\n }\r\n Object.defineProperty(Camera.prototype, \"position\", {\r\n /**\r\n * Define the current local position of the camera in the scene\r\n */\r\n get: function () {\r\n return this._position;\r\n },\r\n set: function (newPosition) {\r\n this._position = newPosition;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Camera.prototype, \"upVector\", {\r\n get: function () {\r\n return this._upVector;\r\n },\r\n /**\r\n * The vector the camera should consider as up.\r\n * (default is Vector3(0, 1, 0) aka Vector3.Up())\r\n */\r\n set: function (vec) {\r\n this._upVector = vec;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Store current camera state (fov, position, etc..)\r\n * @returns the camera\r\n */\r\n Camera.prototype.storeState = function () {\r\n this._stateStored = true;\r\n this._storedFov = this.fov;\r\n return this;\r\n };\r\n /**\r\n * Restores the camera state values if it has been stored. You must call storeState() first\r\n */\r\n Camera.prototype._restoreStateValues = function () {\r\n if (!this._stateStored) {\r\n return false;\r\n }\r\n this.fov = this._storedFov;\r\n return true;\r\n };\r\n /**\r\n * Restored camera state. You must call storeState() first.\r\n * @returns true if restored and false otherwise\r\n */\r\n Camera.prototype.restoreState = function () {\r\n if (this._restoreStateValues()) {\r\n this.onRestoreStateObservable.notifyObservers(this);\r\n return true;\r\n }\r\n return false;\r\n };\r\n /**\r\n * Gets the class name of the camera.\r\n * @returns the class name\r\n */\r\n Camera.prototype.getClassName = function () {\r\n return \"Camera\";\r\n };\r\n /**\r\n * Gets a string representation of the camera useful for debug purpose.\r\n * @param fullDetails Defines that a more verboe level of logging is required\r\n * @returns the string representation\r\n */\r\n Camera.prototype.toString = function (fullDetails) {\r\n var ret = \"Name: \" + this.name;\r\n ret += \", type: \" + this.getClassName();\r\n if (this.animations) {\r\n for (var i = 0; i < this.animations.length; i++) {\r\n ret += \", animation[0]: \" + this.animations[i].toString(fullDetails);\r\n }\r\n }\r\n if (fullDetails) {\r\n }\r\n return ret;\r\n };\r\n Object.defineProperty(Camera.prototype, \"globalPosition\", {\r\n /**\r\n * Gets the current world space position of the camera.\r\n */\r\n get: function () {\r\n return this._globalPosition;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the list of active meshes this frame (meshes no culled or excluded by lod s in the frame)\r\n * @returns the active meshe list\r\n */\r\n Camera.prototype.getActiveMeshes = function () {\r\n return this._activeMeshes;\r\n };\r\n /**\r\n * Check whether a mesh is part of the current active mesh list of the camera\r\n * @param mesh Defines the mesh to check\r\n * @returns true if active, false otherwise\r\n */\r\n Camera.prototype.isActiveMesh = function (mesh) {\r\n return (this._activeMeshes.indexOf(mesh) !== -1);\r\n };\r\n /**\r\n * Is this camera ready to be used/rendered\r\n * @param completeCheck defines if a complete check (including post processes) has to be done (false by default)\r\n * @return true if the camera is ready\r\n */\r\n Camera.prototype.isReady = function (completeCheck) {\r\n if (completeCheck === void 0) { completeCheck = false; }\r\n if (completeCheck) {\r\n for (var _i = 0, _a = this._postProcesses; _i < _a.length; _i++) {\r\n var pp = _a[_i];\r\n if (pp && !pp.isReady()) {\r\n return false;\r\n }\r\n }\r\n }\r\n return _super.prototype.isReady.call(this, completeCheck);\r\n };\r\n /** @hidden */\r\n Camera.prototype._initCache = function () {\r\n _super.prototype._initCache.call(this);\r\n this._cache.position = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n this._cache.upVector = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n this._cache.mode = undefined;\r\n this._cache.minZ = undefined;\r\n this._cache.maxZ = undefined;\r\n this._cache.fov = undefined;\r\n this._cache.fovMode = undefined;\r\n this._cache.aspectRatio = undefined;\r\n this._cache.orthoLeft = undefined;\r\n this._cache.orthoRight = undefined;\r\n this._cache.orthoBottom = undefined;\r\n this._cache.orthoTop = undefined;\r\n this._cache.renderWidth = undefined;\r\n this._cache.renderHeight = undefined;\r\n };\r\n /** @hidden */\r\n Camera.prototype._updateCache = function (ignoreParentClass) {\r\n if (!ignoreParentClass) {\r\n _super.prototype._updateCache.call(this);\r\n }\r\n this._cache.position.copyFrom(this.position);\r\n this._cache.upVector.copyFrom(this.upVector);\r\n };\r\n /** @hidden */\r\n Camera.prototype._isSynchronized = function () {\r\n return this._isSynchronizedViewMatrix() && this._isSynchronizedProjectionMatrix();\r\n };\r\n /** @hidden */\r\n Camera.prototype._isSynchronizedViewMatrix = function () {\r\n if (!_super.prototype._isSynchronized.call(this)) {\r\n return false;\r\n }\r\n return this._cache.position.equals(this.position)\r\n && this._cache.upVector.equals(this.upVector)\r\n && this.isSynchronizedWithParent();\r\n };\r\n /** @hidden */\r\n Camera.prototype._isSynchronizedProjectionMatrix = function () {\r\n var check = this._cache.mode === this.mode\r\n && this._cache.minZ === this.minZ\r\n && this._cache.maxZ === this.maxZ;\r\n if (!check) {\r\n return false;\r\n }\r\n var engine = this.getEngine();\r\n if (this.mode === Camera.PERSPECTIVE_CAMERA) {\r\n check = this._cache.fov === this.fov\r\n && this._cache.fovMode === this.fovMode\r\n && this._cache.aspectRatio === engine.getAspectRatio(this);\r\n }\r\n else {\r\n check = this._cache.orthoLeft === this.orthoLeft\r\n && this._cache.orthoRight === this.orthoRight\r\n && this._cache.orthoBottom === this.orthoBottom\r\n && this._cache.orthoTop === this.orthoTop\r\n && this._cache.renderWidth === engine.getRenderWidth()\r\n && this._cache.renderHeight === engine.getRenderHeight();\r\n }\r\n return check;\r\n };\r\n /**\r\n * Attach the input controls to a specific dom element to get the input from.\r\n * @param ignored defines an ignored parameter kept for backward compatibility. If you want to define the source input element, you can set engine.inputElement before calling camera.attachControl\r\n * @param noPreventDefault Defines whether event caught by the controls should call preventdefault() (https://developer.mozilla.org/en-US/docs/Web/API/Event/preventDefault)\r\n */\r\n Camera.prototype.attachControl = function (ignored, noPreventDefault) {\r\n };\r\n /**\r\n * Detach the current controls from the specified dom element.\r\n * @param ignored defines an ignored parameter kept for backward compatibility. If you want to define the source input element, you can set engine.inputElement before calling camera.attachControl\r\n */\r\n Camera.prototype.detachControl = function (ignored) {\r\n };\r\n /**\r\n * Update the camera state according to the different inputs gathered during the frame.\r\n */\r\n Camera.prototype.update = function () {\r\n this._checkInputs();\r\n if (this.cameraRigMode !== Camera.RIG_MODE_NONE) {\r\n this._updateRigCameras();\r\n }\r\n };\r\n /** @hidden */\r\n Camera.prototype._checkInputs = function () {\r\n this.onAfterCheckInputsObservable.notifyObservers(this);\r\n };\r\n Object.defineProperty(Camera.prototype, \"rigCameras\", {\r\n /** @hidden */\r\n get: function () {\r\n return this._rigCameras;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Camera.prototype, \"rigPostProcess\", {\r\n /**\r\n * Gets the post process used by the rig cameras\r\n */\r\n get: function () {\r\n return this._rigPostProcess;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Internal, gets the first post proces.\r\n * @returns the first post process to be run on this camera.\r\n */\r\n Camera.prototype._getFirstPostProcess = function () {\r\n for (var ppIndex = 0; ppIndex < this._postProcesses.length; ppIndex++) {\r\n if (this._postProcesses[ppIndex] !== null) {\r\n return this._postProcesses[ppIndex];\r\n }\r\n }\r\n return null;\r\n };\r\n Camera.prototype._cascadePostProcessesToRigCams = function () {\r\n // invalidate framebuffer\r\n var firstPostProcess = this._getFirstPostProcess();\r\n if (firstPostProcess) {\r\n firstPostProcess.markTextureDirty();\r\n }\r\n // glue the rigPostProcess to the end of the user postprocesses & assign to each sub-camera\r\n for (var i = 0, len = this._rigCameras.length; i < len; i++) {\r\n var cam = this._rigCameras[i];\r\n var rigPostProcess = cam._rigPostProcess;\r\n // for VR rig, there does not have to be a post process\r\n if (rigPostProcess) {\r\n var isPass = rigPostProcess.getEffectName() === \"pass\";\r\n if (isPass) {\r\n // any rig which has a PassPostProcess for rig[0], cannot be isIntermediate when there are also user postProcesses\r\n cam.isIntermediate = this._postProcesses.length === 0;\r\n }\r\n cam._postProcesses = this._postProcesses.slice(0).concat(rigPostProcess);\r\n rigPostProcess.markTextureDirty();\r\n }\r\n else {\r\n cam._postProcesses = this._postProcesses.slice(0);\r\n }\r\n }\r\n };\r\n /**\r\n * Attach a post process to the camera.\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_postprocesses#attach-postprocess\r\n * @param postProcess The post process to attach to the camera\r\n * @param insertAt The position of the post process in case several of them are in use in the scene\r\n * @returns the position the post process has been inserted at\r\n */\r\n Camera.prototype.attachPostProcess = function (postProcess, insertAt) {\r\n if (insertAt === void 0) { insertAt = null; }\r\n if (!postProcess.isReusable() && this._postProcesses.indexOf(postProcess) > -1) {\r\n Logger.Error(\"You're trying to reuse a post process not defined as reusable.\");\r\n return 0;\r\n }\r\n if (insertAt == null || insertAt < 0) {\r\n this._postProcesses.push(postProcess);\r\n }\r\n else if (this._postProcesses[insertAt] === null) {\r\n this._postProcesses[insertAt] = postProcess;\r\n }\r\n else {\r\n this._postProcesses.splice(insertAt, 0, postProcess);\r\n }\r\n this._cascadePostProcessesToRigCams(); // also ensures framebuffer invalidated\r\n // Update prePass\r\n if (this._scene.prePassRenderer) {\r\n this._scene.prePassRenderer.markAsDirty();\r\n }\r\n return this._postProcesses.indexOf(postProcess);\r\n };\r\n /**\r\n * Detach a post process to the camera.\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_postprocesses#attach-postprocess\r\n * @param postProcess The post process to detach from the camera\r\n */\r\n Camera.prototype.detachPostProcess = function (postProcess) {\r\n var idx = this._postProcesses.indexOf(postProcess);\r\n if (idx !== -1) {\r\n this._postProcesses[idx] = null;\r\n }\r\n // Update prePass\r\n if (this._scene.prePassRenderer) {\r\n this._scene.prePassRenderer.markAsDirty();\r\n }\r\n this._cascadePostProcessesToRigCams(); // also ensures framebuffer invalidated\r\n };\r\n /**\r\n * Gets the current world matrix of the camera\r\n */\r\n Camera.prototype.getWorldMatrix = function () {\r\n if (this._isSynchronizedViewMatrix()) {\r\n return this._worldMatrix;\r\n }\r\n // Getting the the view matrix will also compute the world matrix.\r\n this.getViewMatrix();\r\n return this._worldMatrix;\r\n };\r\n /** @hidden */\r\n Camera.prototype._getViewMatrix = function () {\r\n return Matrix.Identity();\r\n };\r\n /**\r\n * Gets the current view matrix of the camera.\r\n * @param force forces the camera to recompute the matrix without looking at the cached state\r\n * @returns the view matrix\r\n */\r\n Camera.prototype.getViewMatrix = function (force) {\r\n if (!force && this._isSynchronizedViewMatrix()) {\r\n return this._computedViewMatrix;\r\n }\r\n this.updateCache();\r\n this._computedViewMatrix = this._getViewMatrix();\r\n this._currentRenderId = this.getScene().getRenderId();\r\n this._childUpdateId++;\r\n this._refreshFrustumPlanes = true;\r\n if (this._cameraRigParams && this._cameraRigParams.vrPreViewMatrix) {\r\n this._computedViewMatrix.multiplyToRef(this._cameraRigParams.vrPreViewMatrix, this._computedViewMatrix);\r\n }\r\n // Notify parent camera if rig camera is changed\r\n if (this.parent && this.parent.onViewMatrixChangedObservable) {\r\n this.parent.onViewMatrixChangedObservable.notifyObservers(this.parent);\r\n }\r\n this.onViewMatrixChangedObservable.notifyObservers(this);\r\n this._computedViewMatrix.invertToRef(this._worldMatrix);\r\n return this._computedViewMatrix;\r\n };\r\n /**\r\n * Freeze the projection matrix.\r\n * It will prevent the cache check of the camera projection compute and can speed up perf\r\n * if no parameter of the camera are meant to change\r\n * @param projection Defines manually a projection if necessary\r\n */\r\n Camera.prototype.freezeProjectionMatrix = function (projection) {\r\n this._doNotComputeProjectionMatrix = true;\r\n if (projection !== undefined) {\r\n this._projectionMatrix = projection;\r\n }\r\n };\r\n /**\r\n * Unfreeze the projection matrix if it has previously been freezed by freezeProjectionMatrix.\r\n */\r\n Camera.prototype.unfreezeProjectionMatrix = function () {\r\n this._doNotComputeProjectionMatrix = false;\r\n };\r\n /**\r\n * Gets the current projection matrix of the camera.\r\n * @param force forces the camera to recompute the matrix without looking at the cached state\r\n * @returns the projection matrix\r\n */\r\n Camera.prototype.getProjectionMatrix = function (force) {\r\n var _a, _b, _c, _d, _e, _f, _g, _h;\r\n if (this._doNotComputeProjectionMatrix || (!force && this._isSynchronizedProjectionMatrix())) {\r\n return this._projectionMatrix;\r\n }\r\n // Cache\r\n this._cache.mode = this.mode;\r\n this._cache.minZ = this.minZ;\r\n this._cache.maxZ = this.maxZ;\r\n // Matrix\r\n this._refreshFrustumPlanes = true;\r\n var engine = this.getEngine();\r\n var scene = this.getScene();\r\n if (this.mode === Camera.PERSPECTIVE_CAMERA) {\r\n this._cache.fov = this.fov;\r\n this._cache.fovMode = this.fovMode;\r\n this._cache.aspectRatio = engine.getAspectRatio(this);\r\n if (this.minZ <= 0) {\r\n this.minZ = 0.1;\r\n }\r\n var reverseDepth = engine.useReverseDepthBuffer;\r\n var getProjectionMatrix = void 0;\r\n if (scene.useRightHandedSystem) {\r\n getProjectionMatrix = reverseDepth ? Matrix.PerspectiveFovReverseRHToRef : Matrix.PerspectiveFovRHToRef;\r\n }\r\n else {\r\n getProjectionMatrix = reverseDepth ? Matrix.PerspectiveFovReverseLHToRef : Matrix.PerspectiveFovLHToRef;\r\n }\r\n getProjectionMatrix(this.fov, engine.getAspectRatio(this), this.minZ, this.maxZ, this._projectionMatrix, this.fovMode === Camera.FOVMODE_VERTICAL_FIXED);\r\n }\r\n else {\r\n var halfWidth = engine.getRenderWidth() / 2.0;\r\n var halfHeight = engine.getRenderHeight() / 2.0;\r\n if (scene.useRightHandedSystem) {\r\n Matrix.OrthoOffCenterRHToRef((_a = this.orthoLeft) !== null && _a !== void 0 ? _a : -halfWidth, (_b = this.orthoRight) !== null && _b !== void 0 ? _b : halfWidth, (_c = this.orthoBottom) !== null && _c !== void 0 ? _c : -halfHeight, (_d = this.orthoTop) !== null && _d !== void 0 ? _d : halfHeight, this.minZ, this.maxZ, this._projectionMatrix);\r\n }\r\n else {\r\n Matrix.OrthoOffCenterLHToRef((_e = this.orthoLeft) !== null && _e !== void 0 ? _e : -halfWidth, (_f = this.orthoRight) !== null && _f !== void 0 ? _f : halfWidth, (_g = this.orthoBottom) !== null && _g !== void 0 ? _g : -halfHeight, (_h = this.orthoTop) !== null && _h !== void 0 ? _h : halfHeight, this.minZ, this.maxZ, this._projectionMatrix);\r\n }\r\n this._cache.orthoLeft = this.orthoLeft;\r\n this._cache.orthoRight = this.orthoRight;\r\n this._cache.orthoBottom = this.orthoBottom;\r\n this._cache.orthoTop = this.orthoTop;\r\n this._cache.renderWidth = engine.getRenderWidth();\r\n this._cache.renderHeight = engine.getRenderHeight();\r\n }\r\n this.onProjectionMatrixChangedObservable.notifyObservers(this);\r\n return this._projectionMatrix;\r\n };\r\n /**\r\n * Gets the transformation matrix (ie. the multiplication of view by projection matrices)\r\n * @returns a Matrix\r\n */\r\n Camera.prototype.getTransformationMatrix = function () {\r\n this._computedViewMatrix.multiplyToRef(this._projectionMatrix, this._transformMatrix);\r\n return this._transformMatrix;\r\n };\r\n Camera.prototype._updateFrustumPlanes = function () {\r\n if (!this._refreshFrustumPlanes) {\r\n return;\r\n }\r\n this.getTransformationMatrix();\r\n if (!this._frustumPlanes) {\r\n this._frustumPlanes = Frustum.GetPlanes(this._transformMatrix);\r\n }\r\n else {\r\n Frustum.GetPlanesToRef(this._transformMatrix, this._frustumPlanes);\r\n }\r\n this._refreshFrustumPlanes = false;\r\n };\r\n /**\r\n * Checks if a cullable object (mesh...) is in the camera frustum\r\n * This checks the bounding box center. See isCompletelyInFrustum for a full bounding check\r\n * @param target The object to check\r\n * @param checkRigCameras If the rig cameras should be checked (eg. with webVR camera both eyes should be checked) (Default: false)\r\n * @returns true if the object is in frustum otherwise false\r\n */\r\n Camera.prototype.isInFrustum = function (target, checkRigCameras) {\r\n if (checkRigCameras === void 0) { checkRigCameras = false; }\r\n this._updateFrustumPlanes();\r\n if (checkRigCameras && this.rigCameras.length > 0) {\r\n var result = false;\r\n this.rigCameras.forEach(function (cam) {\r\n cam._updateFrustumPlanes();\r\n result = result || target.isInFrustum(cam._frustumPlanes);\r\n });\r\n return result;\r\n }\r\n else {\r\n return target.isInFrustum(this._frustumPlanes);\r\n }\r\n };\r\n /**\r\n * Checks if a cullable object (mesh...) is in the camera frustum\r\n * Unlike isInFrustum this cheks the full bounding box\r\n * @param target The object to check\r\n * @returns true if the object is in frustum otherwise false\r\n */\r\n Camera.prototype.isCompletelyInFrustum = function (target) {\r\n this._updateFrustumPlanes();\r\n return target.isCompletelyInFrustum(this._frustumPlanes);\r\n };\r\n /**\r\n * Gets a ray in the forward direction from the camera.\r\n * @param length Defines the length of the ray to create\r\n * @param transform Defines the transform to apply to the ray, by default the world matrx is used to create a workd space ray\r\n * @param origin Defines the start point of the ray which defaults to the camera position\r\n * @returns the forward ray\r\n */\r\n Camera.prototype.getForwardRay = function (length, transform, origin) {\r\n if (length === void 0) { length = 100; }\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /**\r\n * Gets a ray in the forward direction from the camera.\r\n * @param refRay the ray to (re)use when setting the values\r\n * @param length Defines the length of the ray to create\r\n * @param transform Defines the transform to apply to the ray, by default the world matrx is used to create a workd space ray\r\n * @param origin Defines the start point of the ray which defaults to the camera position\r\n * @returns the forward ray\r\n */\r\n Camera.prototype.getForwardRayToRef = function (refRay, length, transform, origin) {\r\n if (length === void 0) { length = 100; }\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /**\r\n * Releases resources associated with this node.\r\n * @param doNotRecurse Set to true to not recurse into each children (recurse into each children by default)\r\n * @param disposeMaterialAndTextures Set to true to also dispose referenced materials and textures (false by default)\r\n */\r\n Camera.prototype.dispose = function (doNotRecurse, disposeMaterialAndTextures) {\r\n if (disposeMaterialAndTextures === void 0) { disposeMaterialAndTextures = false; }\r\n // Observables\r\n this.onViewMatrixChangedObservable.clear();\r\n this.onProjectionMatrixChangedObservable.clear();\r\n this.onAfterCheckInputsObservable.clear();\r\n this.onRestoreStateObservable.clear();\r\n // Inputs\r\n if (this.inputs) {\r\n this.inputs.clear();\r\n }\r\n // Animations\r\n this.getScene().stopAnimation(this);\r\n // Remove from scene\r\n this.getScene().removeCamera(this);\r\n while (this._rigCameras.length > 0) {\r\n var camera = this._rigCameras.pop();\r\n if (camera) {\r\n camera.dispose();\r\n }\r\n }\r\n // Postprocesses\r\n if (this._rigPostProcess) {\r\n this._rigPostProcess.dispose(this);\r\n this._rigPostProcess = null;\r\n this._postProcesses = [];\r\n }\r\n else if (this.cameraRigMode !== Camera.RIG_MODE_NONE) {\r\n this._rigPostProcess = null;\r\n this._postProcesses = [];\r\n }\r\n else {\r\n var i = this._postProcesses.length;\r\n while (--i >= 0) {\r\n var postProcess = this._postProcesses[i];\r\n if (postProcess) {\r\n postProcess.dispose(this);\r\n }\r\n }\r\n }\r\n // Render targets\r\n var i = this.customRenderTargets.length;\r\n while (--i >= 0) {\r\n this.customRenderTargets[i].dispose();\r\n }\r\n this.customRenderTargets = [];\r\n // Active Meshes\r\n this._activeMeshes.dispose();\r\n _super.prototype.dispose.call(this, doNotRecurse, disposeMaterialAndTextures);\r\n };\r\n Object.defineProperty(Camera.prototype, \"isLeftCamera\", {\r\n /**\r\n * Gets the left camera of a rig setup in case of Rigged Camera\r\n */\r\n get: function () {\r\n return this._isLeftCamera;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Camera.prototype, \"isRightCamera\", {\r\n /**\r\n * Gets the right camera of a rig setup in case of Rigged Camera\r\n */\r\n get: function () {\r\n return this._isRightCamera;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Camera.prototype, \"leftCamera\", {\r\n /**\r\n * Gets the left camera of a rig setup in case of Rigged Camera\r\n */\r\n get: function () {\r\n if (this._rigCameras.length < 1) {\r\n return null;\r\n }\r\n return this._rigCameras[0];\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Camera.prototype, \"rightCamera\", {\r\n /**\r\n * Gets the right camera of a rig setup in case of Rigged Camera\r\n */\r\n get: function () {\r\n if (this._rigCameras.length < 2) {\r\n return null;\r\n }\r\n return this._rigCameras[1];\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the left camera target of a rig setup in case of Rigged Camera\r\n * @returns the target position\r\n */\r\n Camera.prototype.getLeftTarget = function () {\r\n if (this._rigCameras.length < 1) {\r\n return null;\r\n }\r\n return this._rigCameras[0].getTarget();\r\n };\r\n /**\r\n * Gets the right camera target of a rig setup in case of Rigged Camera\r\n * @returns the target position\r\n */\r\n Camera.prototype.getRightTarget = function () {\r\n if (this._rigCameras.length < 2) {\r\n return null;\r\n }\r\n return this._rigCameras[1].getTarget();\r\n };\r\n /**\r\n * @hidden\r\n */\r\n Camera.prototype.setCameraRigMode = function (mode, rigParams) {\r\n if (this.cameraRigMode === mode) {\r\n return;\r\n }\r\n while (this._rigCameras.length > 0) {\r\n var camera = this._rigCameras.pop();\r\n if (camera) {\r\n camera.dispose();\r\n }\r\n }\r\n this.cameraRigMode = mode;\r\n this._cameraRigParams = {};\r\n //we have to implement stereo camera calcultating left and right viewpoints from interaxialDistance and target,\r\n //not from a given angle as it is now, but until that complete code rewriting provisional stereoHalfAngle value is introduced\r\n this._cameraRigParams.interaxialDistance = rigParams.interaxialDistance || 0.0637;\r\n this._cameraRigParams.stereoHalfAngle = Tools.ToRadians(this._cameraRigParams.interaxialDistance / 0.0637);\r\n // create the rig cameras, unless none\r\n if (this.cameraRigMode !== Camera.RIG_MODE_NONE) {\r\n var leftCamera = this.createRigCamera(this.name + \"_L\", 0);\r\n if (leftCamera) {\r\n leftCamera._isLeftCamera = true;\r\n }\r\n var rightCamera = this.createRigCamera(this.name + \"_R\", 1);\r\n if (rightCamera) {\r\n rightCamera._isRightCamera = true;\r\n }\r\n if (leftCamera && rightCamera) {\r\n this._rigCameras.push(leftCamera);\r\n this._rigCameras.push(rightCamera);\r\n }\r\n }\r\n switch (this.cameraRigMode) {\r\n case Camera.RIG_MODE_STEREOSCOPIC_ANAGLYPH:\r\n Camera._setStereoscopicAnaglyphRigMode(this);\r\n break;\r\n case Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL:\r\n case Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED:\r\n case Camera.RIG_MODE_STEREOSCOPIC_OVERUNDER:\r\n case Camera.RIG_MODE_STEREOSCOPIC_INTERLACED:\r\n Camera._setStereoscopicRigMode(this);\r\n break;\r\n case Camera.RIG_MODE_VR:\r\n Camera._setVRRigMode(this, rigParams);\r\n break;\r\n case Camera.RIG_MODE_WEBVR:\r\n Camera._setWebVRRigMode(this, rigParams);\r\n break;\r\n }\r\n this._cascadePostProcessesToRigCams();\r\n this.update();\r\n };\r\n /** @hidden */\r\n Camera._setStereoscopicRigMode = function (camera) {\r\n throw \"Import Cameras/RigModes/stereoscopicRigMode before using stereoscopic rig mode\";\r\n };\r\n /** @hidden */\r\n Camera._setStereoscopicAnaglyphRigMode = function (camera) {\r\n throw \"Import Cameras/RigModes/stereoscopicAnaglyphRigMode before using stereoscopic anaglyph rig mode\";\r\n };\r\n /** @hidden */\r\n Camera._setVRRigMode = function (camera, rigParams) {\r\n throw \"Import Cameras/RigModes/vrRigMode before using VR rig mode\";\r\n };\r\n /** @hidden */\r\n Camera._setWebVRRigMode = function (camera, rigParams) {\r\n throw \"Import Cameras/RigModes/WebVRRigMode before using Web VR rig mode\";\r\n };\r\n /** @hidden */\r\n Camera.prototype._getVRProjectionMatrix = function () {\r\n Matrix.PerspectiveFovLHToRef(this._cameraRigParams.vrMetrics.aspectRatioFov, this._cameraRigParams.vrMetrics.aspectRatio, this.minZ, this.maxZ, this._cameraRigParams.vrWorkMatrix);\r\n this._cameraRigParams.vrWorkMatrix.multiplyToRef(this._cameraRigParams.vrHMatrix, this._projectionMatrix);\r\n return this._projectionMatrix;\r\n };\r\n Camera.prototype._updateCameraRotationMatrix = function () {\r\n //Here for WebVR\r\n };\r\n Camera.prototype._updateWebVRCameraRotationMatrix = function () {\r\n //Here for WebVR\r\n };\r\n /**\r\n * This function MUST be overwritten by the different WebVR cameras available.\r\n * The context in which it is running is the RIG camera. So 'this' is the TargetCamera, left or right.\r\n * @hidden\r\n */\r\n Camera.prototype._getWebVRProjectionMatrix = function () {\r\n return Matrix.Identity();\r\n };\r\n /**\r\n * This function MUST be overwritten by the different WebVR cameras available.\r\n * The context in which it is running is the RIG camera. So 'this' is the TargetCamera, left or right.\r\n * @hidden\r\n */\r\n Camera.prototype._getWebVRViewMatrix = function () {\r\n return Matrix.Identity();\r\n };\r\n /** @hidden */\r\n Camera.prototype.setCameraRigParameter = function (name, value) {\r\n if (!this._cameraRigParams) {\r\n this._cameraRigParams = {};\r\n }\r\n this._cameraRigParams[name] = value;\r\n //provisionnally:\r\n if (name === \"interaxialDistance\") {\r\n this._cameraRigParams.stereoHalfAngle = Tools.ToRadians(value / 0.0637);\r\n }\r\n };\r\n /**\r\n * needs to be overridden by children so sub has required properties to be copied\r\n * @hidden\r\n */\r\n Camera.prototype.createRigCamera = function (name, cameraIndex) {\r\n return null;\r\n };\r\n /**\r\n * May need to be overridden by children\r\n * @hidden\r\n */\r\n Camera.prototype._updateRigCameras = function () {\r\n for (var i = 0; i < this._rigCameras.length; i++) {\r\n this._rigCameras[i].minZ = this.minZ;\r\n this._rigCameras[i].maxZ = this.maxZ;\r\n this._rigCameras[i].fov = this.fov;\r\n this._rigCameras[i].upVector.copyFrom(this.upVector);\r\n }\r\n // only update viewport when ANAGLYPH\r\n if (this.cameraRigMode === Camera.RIG_MODE_STEREOSCOPIC_ANAGLYPH) {\r\n this._rigCameras[0].viewport = this._rigCameras[1].viewport = this.viewport;\r\n }\r\n };\r\n /** @hidden */\r\n Camera.prototype._setupInputs = function () {\r\n };\r\n /**\r\n * Serialiaze the camera setup to a json represention\r\n * @returns the JSON representation\r\n */\r\n Camera.prototype.serialize = function () {\r\n var serializationObject = SerializationHelper.Serialize(this);\r\n // Type\r\n serializationObject.type = this.getClassName();\r\n // Parent\r\n if (this.parent) {\r\n serializationObject.parentId = this.parent.id;\r\n }\r\n if (this.inputs) {\r\n this.inputs.serialize(serializationObject);\r\n }\r\n // Animations\r\n SerializationHelper.AppendSerializedAnimations(this, serializationObject);\r\n serializationObject.ranges = this.serializeAnimationRanges();\r\n return serializationObject;\r\n };\r\n /**\r\n * Clones the current camera.\r\n * @param name The cloned camera name\r\n * @returns the cloned camera\r\n */\r\n Camera.prototype.clone = function (name) {\r\n return SerializationHelper.Clone(Camera.GetConstructorFromName(this.getClassName(), name, this.getScene(), this.interaxialDistance, this.isStereoscopicSideBySide), this);\r\n };\r\n /**\r\n * Gets the direction of the camera relative to a given local axis.\r\n * @param localAxis Defines the reference axis to provide a relative direction.\r\n * @return the direction\r\n */\r\n Camera.prototype.getDirection = function (localAxis) {\r\n var result = Vector3.Zero();\r\n this.getDirectionToRef(localAxis, result);\r\n return result;\r\n };\r\n Object.defineProperty(Camera.prototype, \"absoluteRotation\", {\r\n /**\r\n * Returns the current camera absolute rotation\r\n */\r\n get: function () {\r\n var result = Quaternion.Zero();\r\n this.getWorldMatrix().decompose(undefined, result);\r\n return result;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the direction of the camera relative to a given local axis into a passed vector.\r\n * @param localAxis Defines the reference axis to provide a relative direction.\r\n * @param result Defines the vector to store the result in\r\n */\r\n Camera.prototype.getDirectionToRef = function (localAxis, result) {\r\n Vector3.TransformNormalToRef(localAxis, this.getWorldMatrix(), result);\r\n };\r\n /**\r\n * Gets a camera constructor for a given camera type\r\n * @param type The type of the camera to construct (should be equal to one of the camera class name)\r\n * @param name The name of the camera the result will be able to instantiate\r\n * @param scene The scene the result will construct the camera in\r\n * @param interaxial_distance In case of stereoscopic setup, the distance between both eyes\r\n * @param isStereoscopicSideBySide In case of stereoscopic setup, should the sereo be side b side\r\n * @returns a factory method to construc the camera\r\n */\r\n Camera.GetConstructorFromName = function (type, name, scene, interaxial_distance, isStereoscopicSideBySide) {\r\n if (interaxial_distance === void 0) { interaxial_distance = 0; }\r\n if (isStereoscopicSideBySide === void 0) { isStereoscopicSideBySide = true; }\r\n var constructorFunc = Node.Construct(type, name, scene, {\r\n interaxial_distance: interaxial_distance,\r\n isStereoscopicSideBySide: isStereoscopicSideBySide\r\n });\r\n if (constructorFunc) {\r\n return constructorFunc;\r\n }\r\n // Default to universal camera\r\n return function () { return Camera._createDefaultParsedCamera(name, scene); };\r\n };\r\n /**\r\n * Compute the world matrix of the camera.\r\n * @returns the camera world matrix\r\n */\r\n Camera.prototype.computeWorldMatrix = function () {\r\n return this.getWorldMatrix();\r\n };\r\n /**\r\n * Parse a JSON and creates the camera from the parsed information\r\n * @param parsedCamera The JSON to parse\r\n * @param scene The scene to instantiate the camera in\r\n * @returns the newly constructed camera\r\n */\r\n Camera.Parse = function (parsedCamera, scene) {\r\n var type = parsedCamera.type;\r\n var construct = Camera.GetConstructorFromName(type, parsedCamera.name, scene, parsedCamera.interaxial_distance, parsedCamera.isStereoscopicSideBySide);\r\n var camera = SerializationHelper.Parse(construct, parsedCamera, scene);\r\n // Parent\r\n if (parsedCamera.parentId) {\r\n camera._waitingParentId = parsedCamera.parentId;\r\n }\r\n //If camera has an input manager, let it parse inputs settings\r\n if (camera.inputs) {\r\n camera.inputs.parse(parsedCamera);\r\n camera._setupInputs();\r\n }\r\n if (parsedCamera.upVector) {\r\n camera.upVector = Vector3.FromArray(parsedCamera.upVector); // need to force the upVector\r\n }\r\n if (camera.setPosition) { // need to force position\r\n camera.position.copyFromFloats(0, 0, 0);\r\n camera.setPosition(Vector3.FromArray(parsedCamera.position));\r\n }\r\n // Target\r\n if (parsedCamera.target) {\r\n if (camera.setTarget) {\r\n camera.setTarget(Vector3.FromArray(parsedCamera.target));\r\n }\r\n }\r\n // Apply 3d rig, when found\r\n if (parsedCamera.cameraRigMode) {\r\n var rigParams = (parsedCamera.interaxial_distance) ? { interaxialDistance: parsedCamera.interaxial_distance } : {};\r\n camera.setCameraRigMode(parsedCamera.cameraRigMode, rigParams);\r\n }\r\n // Animations\r\n if (parsedCamera.animations) {\r\n for (var animationIndex = 0; animationIndex < parsedCamera.animations.length; animationIndex++) {\r\n var parsedAnimation = parsedCamera.animations[animationIndex];\r\n var internalClass = _TypeStore.GetClass(\"BABYLON.Animation\");\r\n if (internalClass) {\r\n camera.animations.push(internalClass.Parse(parsedAnimation));\r\n }\r\n }\r\n Node.ParseAnimationRanges(camera, parsedCamera, scene);\r\n }\r\n if (parsedCamera.autoAnimate) {\r\n scene.beginAnimation(camera, parsedCamera.autoAnimateFrom, parsedCamera.autoAnimateTo, parsedCamera.autoAnimateLoop, parsedCamera.autoAnimateSpeed || 1.0);\r\n }\r\n return camera;\r\n };\r\n /** @hidden */\r\n Camera._createDefaultParsedCamera = function (name, scene) {\r\n throw _DevTools.WarnImport(\"UniversalCamera\");\r\n };\r\n /**\r\n * This is the default projection mode used by the cameras.\r\n * It helps recreating a feeling of perspective and better appreciate depth.\r\n * This is the best way to simulate real life cameras.\r\n */\r\n Camera.PERSPECTIVE_CAMERA = 0;\r\n /**\r\n * This helps creating camera with an orthographic mode.\r\n * Orthographic is commonly used in engineering as a means to produce object specifications that communicate dimensions unambiguously, each line of 1 unit length (cm, meter..whatever) will appear to have the same length everywhere on the drawing. This allows the drafter to dimension only a subset of lines and let the reader know that other lines of that length on the drawing are also that length in reality. Every parallel line in the drawing is also parallel in the object.\r\n */\r\n Camera.ORTHOGRAPHIC_CAMERA = 1;\r\n /**\r\n * This is the default FOV mode for perspective cameras.\r\n * This setting aligns the upper and lower bounds of the viewport to the upper and lower bounds of the camera frustum.\r\n */\r\n Camera.FOVMODE_VERTICAL_FIXED = 0;\r\n /**\r\n * This setting aligns the left and right bounds of the viewport to the left and right bounds of the camera frustum.\r\n */\r\n Camera.FOVMODE_HORIZONTAL_FIXED = 1;\r\n /**\r\n * This specifies ther is no need for a camera rig.\r\n * Basically only one eye is rendered corresponding to the camera.\r\n */\r\n Camera.RIG_MODE_NONE = 0;\r\n /**\r\n * Simulates a camera Rig with one blue eye and one red eye.\r\n * This can be use with 3d blue and red glasses.\r\n */\r\n Camera.RIG_MODE_STEREOSCOPIC_ANAGLYPH = 10;\r\n /**\r\n * Defines that both eyes of the camera will be rendered side by side with a parallel target.\r\n */\r\n Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL = 11;\r\n /**\r\n * Defines that both eyes of the camera will be rendered side by side with a none parallel target.\r\n */\r\n Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED = 12;\r\n /**\r\n * Defines that both eyes of the camera will be rendered over under each other.\r\n */\r\n Camera.RIG_MODE_STEREOSCOPIC_OVERUNDER = 13;\r\n /**\r\n * Defines that both eyes of the camera will be rendered on successive lines interlaced for passive 3d monitors.\r\n */\r\n Camera.RIG_MODE_STEREOSCOPIC_INTERLACED = 14;\r\n /**\r\n * Defines that both eyes of the camera should be renderered in a VR mode (carbox).\r\n */\r\n Camera.RIG_MODE_VR = 20;\r\n /**\r\n * Defines that both eyes of the camera should be renderered in a VR mode (webVR).\r\n */\r\n Camera.RIG_MODE_WEBVR = 21;\r\n /**\r\n * Custom rig mode allowing rig cameras to be populated manually with any number of cameras\r\n */\r\n Camera.RIG_MODE_CUSTOM = 22;\r\n /**\r\n * Defines if by default attaching controls should prevent the default javascript event to continue.\r\n */\r\n Camera.ForceAttachControlToAlwaysPreventDefault = false;\r\n __decorate([\r\n serializeAsVector3(\"position\")\r\n ], Camera.prototype, \"_position\", void 0);\r\n __decorate([\r\n serializeAsVector3(\"upVector\")\r\n ], Camera.prototype, \"_upVector\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"orthoLeft\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"orthoRight\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"orthoBottom\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"orthoTop\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"fov\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"minZ\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"maxZ\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"inertia\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"mode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"layerMask\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"fovMode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"cameraRigMode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"interaxialDistance\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Camera.prototype, \"isStereoscopicSideBySide\", void 0);\r\n return Camera;\r\n}(Node));\r\nexport { Camera };\r\n//# sourceMappingURL=camera.js.map","/**\r\n * Class used to evalaute queries containing `and` and `or` operators\r\n */\r\nvar AndOrNotEvaluator = /** @class */ (function () {\r\n function AndOrNotEvaluator() {\r\n }\r\n /**\r\n * Evaluate a query\r\n * @param query defines the query to evaluate\r\n * @param evaluateCallback defines the callback used to filter result\r\n * @returns true if the query matches\r\n */\r\n AndOrNotEvaluator.Eval = function (query, evaluateCallback) {\r\n if (!query.match(/\\([^\\(\\)]*\\)/g)) {\r\n query = AndOrNotEvaluator._HandleParenthesisContent(query, evaluateCallback);\r\n }\r\n else {\r\n query = query.replace(/\\([^\\(\\)]*\\)/g, function (r) {\r\n // remove parenthesis\r\n r = r.slice(1, r.length - 1);\r\n return AndOrNotEvaluator._HandleParenthesisContent(r, evaluateCallback);\r\n });\r\n }\r\n if (query === \"true\") {\r\n return true;\r\n }\r\n if (query === \"false\") {\r\n return false;\r\n }\r\n return AndOrNotEvaluator.Eval(query, evaluateCallback);\r\n };\r\n AndOrNotEvaluator._HandleParenthesisContent = function (parenthesisContent, evaluateCallback) {\r\n evaluateCallback = evaluateCallback || (function (r) {\r\n return r === \"true\" ? true : false;\r\n });\r\n var result;\r\n var or = parenthesisContent.split(\"||\");\r\n for (var i in or) {\r\n if (or.hasOwnProperty(i)) {\r\n var ori = AndOrNotEvaluator._SimplifyNegation(or[i].trim());\r\n var and = ori.split(\"&&\");\r\n if (and.length > 1) {\r\n for (var j = 0; j < and.length; ++j) {\r\n var andj = AndOrNotEvaluator._SimplifyNegation(and[j].trim());\r\n if (andj !== \"true\" && andj !== \"false\") {\r\n if (andj[0] === \"!\") {\r\n result = !evaluateCallback(andj.substring(1));\r\n }\r\n else {\r\n result = evaluateCallback(andj);\r\n }\r\n }\r\n else {\r\n result = andj === \"true\" ? true : false;\r\n }\r\n if (!result) { // no need to continue since 'false && ... && ...' will always return false\r\n ori = \"false\";\r\n break;\r\n }\r\n }\r\n }\r\n if (result || ori === \"true\") { // no need to continue since 'true || ... || ...' will always return true\r\n result = true;\r\n break;\r\n }\r\n // result equals false (or undefined)\r\n if (ori !== \"true\" && ori !== \"false\") {\r\n if (ori[0] === \"!\") {\r\n result = !evaluateCallback(ori.substring(1));\r\n }\r\n else {\r\n result = evaluateCallback(ori);\r\n }\r\n }\r\n else {\r\n result = ori === \"true\" ? true : false;\r\n }\r\n }\r\n }\r\n // the whole parenthesis scope is replaced by 'true' or 'false'\r\n return result ? \"true\" : \"false\";\r\n };\r\n AndOrNotEvaluator._SimplifyNegation = function (booleanString) {\r\n booleanString = booleanString.replace(/^[\\s!]+/, function (r) {\r\n // remove whitespaces\r\n r = r.replace(/[\\s]/g, function () { return \"\"; });\r\n return r.length % 2 ? \"!\" : \"\";\r\n });\r\n booleanString = booleanString.trim();\r\n if (booleanString === \"!true\") {\r\n booleanString = \"false\";\r\n }\r\n else if (booleanString === \"!false\") {\r\n booleanString = \"true\";\r\n }\r\n return booleanString;\r\n };\r\n return AndOrNotEvaluator;\r\n}());\r\nexport { AndOrNotEvaluator };\r\n//# sourceMappingURL=andOrNotEvaluator.js.map","import { AndOrNotEvaluator } from \"./andOrNotEvaluator\";\r\n/**\r\n * Class used to store custom tags\r\n */\r\nvar Tags = /** @class */ (function () {\r\n function Tags() {\r\n }\r\n /**\r\n * Adds support for tags on the given object\r\n * @param obj defines the object to use\r\n */\r\n Tags.EnableFor = function (obj) {\r\n obj._tags = obj._tags || {};\r\n obj.hasTags = function () {\r\n return Tags.HasTags(obj);\r\n };\r\n obj.addTags = function (tagsString) {\r\n return Tags.AddTagsTo(obj, tagsString);\r\n };\r\n obj.removeTags = function (tagsString) {\r\n return Tags.RemoveTagsFrom(obj, tagsString);\r\n };\r\n obj.matchesTagsQuery = function (tagsQuery) {\r\n return Tags.MatchesQuery(obj, tagsQuery);\r\n };\r\n };\r\n /**\r\n * Removes tags support\r\n * @param obj defines the object to use\r\n */\r\n Tags.DisableFor = function (obj) {\r\n delete obj._tags;\r\n delete obj.hasTags;\r\n delete obj.addTags;\r\n delete obj.removeTags;\r\n delete obj.matchesTagsQuery;\r\n };\r\n /**\r\n * Gets a boolean indicating if the given object has tags\r\n * @param obj defines the object to use\r\n * @returns a boolean\r\n */\r\n Tags.HasTags = function (obj) {\r\n if (!obj._tags) {\r\n return false;\r\n }\r\n var tags = obj._tags;\r\n for (var i in tags) {\r\n if (tags.hasOwnProperty(i)) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n };\r\n /**\r\n * Gets the tags available on a given object\r\n * @param obj defines the object to use\r\n * @param asString defines if the tags must be returned as a string instead of an array of strings\r\n * @returns the tags\r\n */\r\n Tags.GetTags = function (obj, asString) {\r\n if (asString === void 0) { asString = true; }\r\n if (!obj._tags) {\r\n return null;\r\n }\r\n if (asString) {\r\n var tagsArray = [];\r\n for (var tag in obj._tags) {\r\n if (obj._tags.hasOwnProperty(tag) && obj._tags[tag] === true) {\r\n tagsArray.push(tag);\r\n }\r\n }\r\n return tagsArray.join(\" \");\r\n }\r\n else {\r\n return obj._tags;\r\n }\r\n };\r\n /**\r\n * Adds tags to an object\r\n * @param obj defines the object to use\r\n * @param tagsString defines the tag string. The tags 'true' and 'false' are reserved and cannot be used as tags.\r\n * A tag cannot start with '||', '&&', and '!'. It cannot contain whitespaces\r\n */\r\n Tags.AddTagsTo = function (obj, tagsString) {\r\n if (!tagsString) {\r\n return;\r\n }\r\n if (typeof tagsString !== \"string\") {\r\n return;\r\n }\r\n var tags = tagsString.split(\" \");\r\n tags.forEach(function (tag, index, array) {\r\n Tags._AddTagTo(obj, tag);\r\n });\r\n };\r\n /**\r\n * @hidden\r\n */\r\n Tags._AddTagTo = function (obj, tag) {\r\n tag = tag.trim();\r\n if (tag === \"\" || tag === \"true\" || tag === \"false\") {\r\n return;\r\n }\r\n if (tag.match(/[\\s]/) || tag.match(/^([!]|([|]|[&]){2})/)) {\r\n return;\r\n }\r\n Tags.EnableFor(obj);\r\n obj._tags[tag] = true;\r\n };\r\n /**\r\n * Removes specific tags from a specific object\r\n * @param obj defines the object to use\r\n * @param tagsString defines the tags to remove\r\n */\r\n Tags.RemoveTagsFrom = function (obj, tagsString) {\r\n if (!Tags.HasTags(obj)) {\r\n return;\r\n }\r\n var tags = tagsString.split(\" \");\r\n for (var t in tags) {\r\n Tags._RemoveTagFrom(obj, tags[t]);\r\n }\r\n };\r\n /**\r\n * @hidden\r\n */\r\n Tags._RemoveTagFrom = function (obj, tag) {\r\n delete obj._tags[tag];\r\n };\r\n /**\r\n * Defines if tags hosted on an object match a given query\r\n * @param obj defines the object to use\r\n * @param tagsQuery defines the tag query\r\n * @returns a boolean\r\n */\r\n Tags.MatchesQuery = function (obj, tagsQuery) {\r\n if (tagsQuery === undefined) {\r\n return true;\r\n }\r\n if (tagsQuery === \"\") {\r\n return Tags.HasTags(obj);\r\n }\r\n return AndOrNotEvaluator.Eval(tagsQuery, function (r) { return Tags.HasTags(obj) && obj._tags[r]; });\r\n };\r\n return Tags;\r\n}());\r\nexport { Tags };\r\n//# sourceMappingURL=tags.js.map","import { __extends } from \"tslib\";\r\n/**\r\n * Groups all the scene component constants in one place to ease maintenance.\r\n * @hidden\r\n */\r\nvar SceneComponentConstants = /** @class */ (function () {\r\n function SceneComponentConstants() {\r\n }\r\n SceneComponentConstants.NAME_EFFECTLAYER = \"EffectLayer\";\r\n SceneComponentConstants.NAME_LAYER = \"Layer\";\r\n SceneComponentConstants.NAME_LENSFLARESYSTEM = \"LensFlareSystem\";\r\n SceneComponentConstants.NAME_BOUNDINGBOXRENDERER = \"BoundingBoxRenderer\";\r\n SceneComponentConstants.NAME_PARTICLESYSTEM = \"ParticleSystem\";\r\n SceneComponentConstants.NAME_GAMEPAD = \"Gamepad\";\r\n SceneComponentConstants.NAME_SIMPLIFICATIONQUEUE = \"SimplificationQueue\";\r\n SceneComponentConstants.NAME_GEOMETRYBUFFERRENDERER = \"GeometryBufferRenderer\";\r\n SceneComponentConstants.NAME_PREPASSRENDERER = \"PrePassRenderer\";\r\n SceneComponentConstants.NAME_DEPTHRENDERER = \"DepthRenderer\";\r\n SceneComponentConstants.NAME_POSTPROCESSRENDERPIPELINEMANAGER = \"PostProcessRenderPipelineManager\";\r\n SceneComponentConstants.NAME_SPRITE = \"Sprite\";\r\n SceneComponentConstants.NAME_SUBSURFACE = \"SubSurface\";\r\n SceneComponentConstants.NAME_OUTLINERENDERER = \"Outline\";\r\n SceneComponentConstants.NAME_PROCEDURALTEXTURE = \"ProceduralTexture\";\r\n SceneComponentConstants.NAME_SHADOWGENERATOR = \"ShadowGenerator\";\r\n SceneComponentConstants.NAME_OCTREE = \"Octree\";\r\n SceneComponentConstants.NAME_PHYSICSENGINE = \"PhysicsEngine\";\r\n SceneComponentConstants.NAME_AUDIO = \"Audio\";\r\n SceneComponentConstants.STEP_ISREADYFORMESH_EFFECTLAYER = 0;\r\n SceneComponentConstants.STEP_BEFOREEVALUATEACTIVEMESH_BOUNDINGBOXRENDERER = 0;\r\n SceneComponentConstants.STEP_EVALUATESUBMESH_BOUNDINGBOXRENDERER = 0;\r\n SceneComponentConstants.STEP_PREACTIVEMESH_BOUNDINGBOXRENDERER = 0;\r\n SceneComponentConstants.STEP_CAMERADRAWRENDERTARGET_EFFECTLAYER = 1;\r\n SceneComponentConstants.STEP_BEFORECAMERADRAW_EFFECTLAYER = 0;\r\n SceneComponentConstants.STEP_BEFORECAMERADRAW_LAYER = 1;\r\n SceneComponentConstants.STEP_BEFORECAMERADRAW_PREPASS = 2;\r\n SceneComponentConstants.STEP_BEFORERENDERTARGETDRAW_LAYER = 0;\r\n SceneComponentConstants.STEP_BEFORERENDERINGMESH_PREPASS = 0;\r\n SceneComponentConstants.STEP_BEFORERENDERINGMESH_OUTLINE = 1;\r\n SceneComponentConstants.STEP_AFTERRENDERINGMESH_PREPASS = 0;\r\n SceneComponentConstants.STEP_AFTERRENDERINGMESH_OUTLINE = 1;\r\n SceneComponentConstants.STEP_AFTERRENDERINGGROUPDRAW_EFFECTLAYER_DRAW = 0;\r\n SceneComponentConstants.STEP_AFTERRENDERINGGROUPDRAW_BOUNDINGBOXRENDERER = 1;\r\n SceneComponentConstants.STEP_BEFORECAMERAUPDATE_SIMPLIFICATIONQUEUE = 0;\r\n SceneComponentConstants.STEP_BEFORECAMERAUPDATE_GAMEPAD = 1;\r\n SceneComponentConstants.STEP_BEFORECLEAR_PROCEDURALTEXTURE = 0;\r\n SceneComponentConstants.STEP_AFTERRENDERTARGETDRAW_LAYER = 0;\r\n SceneComponentConstants.STEP_AFTERCAMERADRAW_EFFECTLAYER = 0;\r\n SceneComponentConstants.STEP_AFTERCAMERADRAW_LENSFLARESYSTEM = 1;\r\n SceneComponentConstants.STEP_AFTERCAMERADRAW_EFFECTLAYER_DRAW = 2;\r\n SceneComponentConstants.STEP_AFTERCAMERADRAW_LAYER = 3;\r\n SceneComponentConstants.STEP_AFTERCAMERADRAW_PREPASS = 4;\r\n SceneComponentConstants.STEP_AFTERRENDER_AUDIO = 0;\r\n SceneComponentConstants.STEP_GATHERRENDERTARGETS_DEPTHRENDERER = 0;\r\n SceneComponentConstants.STEP_GATHERRENDERTARGETS_GEOMETRYBUFFERRENDERER = 1;\r\n SceneComponentConstants.STEP_GATHERRENDERTARGETS_SHADOWGENERATOR = 2;\r\n SceneComponentConstants.STEP_GATHERRENDERTARGETS_POSTPROCESSRENDERPIPELINEMANAGER = 3;\r\n SceneComponentConstants.STEP_GATHERACTIVECAMERARENDERTARGETS_DEPTHRENDERER = 0;\r\n SceneComponentConstants.STEP_BEFORECLEARSTAGE_PREPASS = 0;\r\n SceneComponentConstants.STEP_POINTERMOVE_SPRITE = 0;\r\n SceneComponentConstants.STEP_POINTERDOWN_SPRITE = 0;\r\n SceneComponentConstants.STEP_POINTERUP_SPRITE = 0;\r\n return SceneComponentConstants;\r\n}());\r\nexport { SceneComponentConstants };\r\n/**\r\n * Representation of a stage in the scene (Basically a list of ordered steps)\r\n * @hidden\r\n */\r\nvar Stage = /** @class */ (function (_super) {\r\n __extends(Stage, _super);\r\n /**\r\n * Hide ctor from the rest of the world.\r\n * @param items The items to add.\r\n */\r\n function Stage(items) {\r\n return _super.apply(this, items) || this;\r\n }\r\n /**\r\n * Creates a new Stage.\r\n * @returns A new instance of a Stage\r\n */\r\n Stage.Create = function () {\r\n return Object.create(Stage.prototype);\r\n };\r\n /**\r\n * Registers a step in an ordered way in the targeted stage.\r\n * @param index Defines the position to register the step in\r\n * @param component Defines the component attached to the step\r\n * @param action Defines the action to launch during the step\r\n */\r\n Stage.prototype.registerStep = function (index, component, action) {\r\n var i = 0;\r\n var maxIndex = Number.MAX_VALUE;\r\n for (; i < this.length; i++) {\r\n var step = this[i];\r\n maxIndex = step.index;\r\n if (index < maxIndex) {\r\n break;\r\n }\r\n }\r\n this.splice(i, 0, { index: index, component: component, action: action.bind(component) });\r\n };\r\n /**\r\n * Clears all the steps from the stage.\r\n */\r\n Stage.prototype.clear = function () {\r\n this.length = 0;\r\n };\r\n return Stage;\r\n}(Array));\r\nexport { Stage };\r\n//# sourceMappingURL=sceneComponent.js.map","import { __assign, __decorate } from \"tslib\";\r\nimport { serialize, SerializationHelper } from \"../Misc/decorators\";\r\nimport { Tools } from \"../Misc/tools\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { EngineStore } from \"../Engines/engineStore\";\r\nimport { SubMesh } from \"../Meshes/subMesh\";\r\nimport { UniformBuffer } from \"./uniformBuffer\";\r\nimport { Logger } from \"../Misc/logger\";\r\nimport { Plane } from '../Maths/math.plane';\r\n/**\r\n * Base class for the main features of a material in Babylon.js\r\n */\r\nvar Material = /** @class */ (function () {\r\n /**\r\n * Creates a material instance\r\n * @param name defines the name of the material\r\n * @param scene defines the scene to reference\r\n * @param doNotAdd specifies if the material should be added to the scene\r\n */\r\n function Material(name, scene, doNotAdd) {\r\n /**\r\n * Custom shadow depth material to use for shadow rendering instead of the in-built one\r\n */\r\n this.shadowDepthWrapper = null;\r\n /**\r\n * Gets or sets a boolean indicating that the material is allowed (if supported) to do shader hot swapping.\r\n * This means that the material can keep using a previous shader while a new one is being compiled.\r\n * This is mostly used when shader parallel compilation is supported (true by default)\r\n */\r\n this.allowShaderHotSwapping = true;\r\n /**\r\n * Gets or sets user defined metadata\r\n */\r\n this.metadata = null;\r\n /**\r\n * For internal use only. Please do not use.\r\n */\r\n this.reservedDataStore = null;\r\n /**\r\n * Specifies if the ready state should be checked on each call\r\n */\r\n this.checkReadyOnEveryCall = false;\r\n /**\r\n * Specifies if the ready state should be checked once\r\n */\r\n this.checkReadyOnlyOnce = false;\r\n /**\r\n * The state of the material\r\n */\r\n this.state = \"\";\r\n /**\r\n * The alpha value of the material\r\n */\r\n this._alpha = 1.0;\r\n /**\r\n * Specifies if back face culling is enabled\r\n */\r\n this._backFaceCulling = true;\r\n /**\r\n * Callback triggered when the material is compiled\r\n */\r\n this.onCompiled = null;\r\n /**\r\n * Callback triggered when an error occurs\r\n */\r\n this.onError = null;\r\n /**\r\n * Callback triggered to get the render target textures\r\n */\r\n this.getRenderTargetTextures = null;\r\n /**\r\n * Specifies if the material should be serialized\r\n */\r\n this.doNotSerialize = false;\r\n /**\r\n * @hidden\r\n */\r\n this._storeEffectOnSubMeshes = false;\r\n /**\r\n * Stores the animations for the material\r\n */\r\n this.animations = null;\r\n /**\r\n * An event triggered when the material is disposed\r\n */\r\n this.onDisposeObservable = new Observable();\r\n /**\r\n * An observer which watches for dispose events\r\n */\r\n this._onDisposeObserver = null;\r\n this._onUnBindObservable = null;\r\n /**\r\n * An observer which watches for bind events\r\n */\r\n this._onBindObserver = null;\r\n /**\r\n * Stores the value of the alpha mode\r\n */\r\n this._alphaMode = 2;\r\n /**\r\n * Stores the state of the need depth pre-pass value\r\n */\r\n this._needDepthPrePass = false;\r\n /**\r\n * Specifies if depth writing should be disabled\r\n */\r\n this.disableDepthWrite = false;\r\n /**\r\n * Specifies if color writing should be disabled\r\n */\r\n this.disableColorWrite = false;\r\n /**\r\n * Specifies if depth writing should be forced\r\n */\r\n this.forceDepthWrite = false;\r\n /**\r\n * Specifies the depth function that should be used. 0 means the default engine function\r\n */\r\n this.depthFunction = 0;\r\n /**\r\n * Specifies if there should be a separate pass for culling\r\n */\r\n this.separateCullingPass = false;\r\n /**\r\n * Stores the state specifing if fog should be enabled\r\n */\r\n this._fogEnabled = true;\r\n /**\r\n * Stores the size of points\r\n */\r\n this.pointSize = 1.0;\r\n /**\r\n * Stores the z offset value\r\n */\r\n this.zOffset = 0;\r\n /**\r\n * @hidden\r\n * Stores the effects for the material\r\n */\r\n this._effect = null;\r\n /**\r\n * Specifies if uniform buffers should be used\r\n */\r\n this._useUBO = false;\r\n /**\r\n * Stores the fill mode state\r\n */\r\n this._fillMode = Material.TriangleFillMode;\r\n /**\r\n * Specifies if the depth write state should be cached\r\n */\r\n this._cachedDepthWriteState = false;\r\n /**\r\n * Specifies if the color write state should be cached\r\n */\r\n this._cachedColorWriteState = false;\r\n /**\r\n * Specifies if the depth function state should be cached\r\n */\r\n this._cachedDepthFunctionState = 0;\r\n /** @hidden */\r\n this._indexInSceneMaterialArray = -1;\r\n /** @hidden */\r\n this.meshMap = null;\r\n /**\r\n * Enforces alpha test in opaque or blend mode in order to improve the performances of some situations.\r\n */\r\n this._forceAlphaTest = false;\r\n /**\r\n * The transparency mode of the material.\r\n */\r\n this._transparencyMode = null;\r\n this.name = name;\r\n var idSubscript = 1;\r\n this._scene = scene || EngineStore.LastCreatedScene;\r\n this.id = name || Tools.RandomId();\r\n while (this._scene.getMaterialByID(this.id)) {\r\n this.id = name + \" \" + idSubscript++;\r\n }\r\n this.uniqueId = this._scene.getUniqueId();\r\n if (this._scene.useRightHandedSystem) {\r\n this.sideOrientation = Material.ClockWiseSideOrientation;\r\n }\r\n else {\r\n this.sideOrientation = Material.CounterClockWiseSideOrientation;\r\n }\r\n this._uniformBuffer = new UniformBuffer(this._scene.getEngine());\r\n this._useUBO = this.getScene().getEngine().supportsUniformBuffers;\r\n if (!doNotAdd) {\r\n this._scene.addMaterial(this);\r\n }\r\n if (this._scene.useMaterialMeshMap) {\r\n this.meshMap = {};\r\n }\r\n }\r\n Object.defineProperty(Material.prototype, \"canRenderToMRT\", {\r\n /**\r\n * If the material can be rendered to several textures with MRT extension\r\n */\r\n get: function () {\r\n // By default, shaders are not compatible with MRTs\r\n // Base classes should override that if their shader supports MRT\r\n return false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"alpha\", {\r\n /**\r\n * Gets the alpha value of the material\r\n */\r\n get: function () {\r\n return this._alpha;\r\n },\r\n /**\r\n * Sets the alpha value of the material\r\n */\r\n set: function (value) {\r\n if (this._alpha === value) {\r\n return;\r\n }\r\n this._alpha = value;\r\n this.markAsDirty(Material.MiscDirtyFlag);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"backFaceCulling\", {\r\n /**\r\n * Gets the back-face culling state\r\n */\r\n get: function () {\r\n return this._backFaceCulling;\r\n },\r\n /**\r\n * Sets the back-face culling state\r\n */\r\n set: function (value) {\r\n if (this._backFaceCulling === value) {\r\n return;\r\n }\r\n this._backFaceCulling = value;\r\n this.markAsDirty(Material.TextureDirtyFlag);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"hasRenderTargetTextures\", {\r\n /**\r\n * Gets a boolean indicating that current material needs to register RTT\r\n */\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"onDispose\", {\r\n /**\r\n * Called during a dispose event\r\n */\r\n set: function (callback) {\r\n if (this._onDisposeObserver) {\r\n this.onDisposeObservable.remove(this._onDisposeObserver);\r\n }\r\n this._onDisposeObserver = this.onDisposeObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"onBindObservable\", {\r\n /**\r\n * An event triggered when the material is bound\r\n */\r\n get: function () {\r\n if (!this._onBindObservable) {\r\n this._onBindObservable = new Observable();\r\n }\r\n return this._onBindObservable;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"onBind\", {\r\n /**\r\n * Called during a bind event\r\n */\r\n set: function (callback) {\r\n if (this._onBindObserver) {\r\n this.onBindObservable.remove(this._onBindObserver);\r\n }\r\n this._onBindObserver = this.onBindObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"onUnBindObservable\", {\r\n /**\r\n * An event triggered when the material is unbound\r\n */\r\n get: function () {\r\n if (!this._onUnBindObservable) {\r\n this._onUnBindObservable = new Observable();\r\n }\r\n return this._onUnBindObservable;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"onEffectCreatedObservable\", {\r\n /**\r\n * An event triggered when the effect is (re)created\r\n */\r\n get: function () {\r\n if (!this._onEffectCreatedObservable) {\r\n this._onEffectCreatedObservable = new Observable();\r\n }\r\n return this._onEffectCreatedObservable;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"alphaMode\", {\r\n /**\r\n * Gets the value of the alpha mode\r\n */\r\n get: function () {\r\n return this._alphaMode;\r\n },\r\n /**\r\n * Sets the value of the alpha mode.\r\n *\r\n * | Value | Type | Description |\r\n * | --- | --- | --- |\r\n * | 0 | ALPHA_DISABLE | |\r\n * | 1 | ALPHA_ADD | |\r\n * | 2 | ALPHA_COMBINE | |\r\n * | 3 | ALPHA_SUBTRACT | |\r\n * | 4 | ALPHA_MULTIPLY | |\r\n * | 5 | ALPHA_MAXIMIZED | |\r\n * | 6 | ALPHA_ONEONE | |\r\n * | 7 | ALPHA_PREMULTIPLIED | |\r\n * | 8 | ALPHA_PREMULTIPLIED_PORTERDUFF | |\r\n * | 9 | ALPHA_INTERPOLATE | |\r\n * | 10 | ALPHA_SCREENMODE | |\r\n *\r\n */\r\n set: function (value) {\r\n if (this._alphaMode === value) {\r\n return;\r\n }\r\n this._alphaMode = value;\r\n this.markAsDirty(Material.TextureDirtyFlag);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"needDepthPrePass\", {\r\n /**\r\n * Gets the depth pre-pass value\r\n */\r\n get: function () {\r\n return this._needDepthPrePass;\r\n },\r\n /**\r\n * Sets the need depth pre-pass value\r\n */\r\n set: function (value) {\r\n if (this._needDepthPrePass === value) {\r\n return;\r\n }\r\n this._needDepthPrePass = value;\r\n if (this._needDepthPrePass) {\r\n this.checkReadyOnEveryCall = true;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"fogEnabled\", {\r\n /**\r\n * Gets the value of the fog enabled state\r\n */\r\n get: function () {\r\n return this._fogEnabled;\r\n },\r\n /**\r\n * Sets the state for enabling fog\r\n */\r\n set: function (value) {\r\n if (this._fogEnabled === value) {\r\n return;\r\n }\r\n this._fogEnabled = value;\r\n this.markAsDirty(Material.MiscDirtyFlag);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"wireframe\", {\r\n get: function () {\r\n switch (this._fillMode) {\r\n case Material.WireFrameFillMode:\r\n case Material.LineListDrawMode:\r\n case Material.LineLoopDrawMode:\r\n case Material.LineStripDrawMode:\r\n return true;\r\n }\r\n return this._scene.forceWireframe;\r\n },\r\n /**\r\n * Sets the state of wireframe mode\r\n */\r\n set: function (value) {\r\n this.fillMode = (value ? Material.WireFrameFillMode : Material.TriangleFillMode);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"pointsCloud\", {\r\n /**\r\n * Gets the value specifying if point clouds are enabled\r\n */\r\n get: function () {\r\n switch (this._fillMode) {\r\n case Material.PointFillMode:\r\n case Material.PointListDrawMode:\r\n return true;\r\n }\r\n return this._scene.forcePointsCloud;\r\n },\r\n /**\r\n * Sets the state of point cloud mode\r\n */\r\n set: function (value) {\r\n this.fillMode = (value ? Material.PointFillMode : Material.TriangleFillMode);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"fillMode\", {\r\n /**\r\n * Gets the material fill mode\r\n */\r\n get: function () {\r\n return this._fillMode;\r\n },\r\n /**\r\n * Sets the material fill mode\r\n */\r\n set: function (value) {\r\n if (this._fillMode === value) {\r\n return;\r\n }\r\n this._fillMode = value;\r\n this.markAsDirty(Material.MiscDirtyFlag);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Returns a string representation of the current material\r\n * @param fullDetails defines a boolean indicating which levels of logging is desired\r\n * @returns a string with material information\r\n */\r\n Material.prototype.toString = function (fullDetails) {\r\n var ret = \"Name: \" + this.name;\r\n if (fullDetails) {\r\n }\r\n return ret;\r\n };\r\n /**\r\n * Gets the class name of the material\r\n * @returns a string with the class name of the material\r\n */\r\n Material.prototype.getClassName = function () {\r\n return \"Material\";\r\n };\r\n Object.defineProperty(Material.prototype, \"isFrozen\", {\r\n /**\r\n * Specifies if updates for the material been locked\r\n */\r\n get: function () {\r\n return this.checkReadyOnlyOnce;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Locks updates for the material\r\n */\r\n Material.prototype.freeze = function () {\r\n this.markDirty();\r\n this.checkReadyOnlyOnce = true;\r\n };\r\n /**\r\n * Unlocks updates for the material\r\n */\r\n Material.prototype.unfreeze = function () {\r\n this.markDirty();\r\n this.checkReadyOnlyOnce = false;\r\n };\r\n /**\r\n * Specifies if the material is ready to be used\r\n * @param mesh defines the mesh to check\r\n * @param useInstances specifies if instances should be used\r\n * @returns a boolean indicating if the material is ready to be used\r\n */\r\n Material.prototype.isReady = function (mesh, useInstances) {\r\n return true;\r\n };\r\n /**\r\n * Specifies that the submesh is ready to be used\r\n * @param mesh defines the mesh to check\r\n * @param subMesh defines which submesh to check\r\n * @param useInstances specifies that instances should be used\r\n * @returns a boolean indicating that the submesh is ready or not\r\n */\r\n Material.prototype.isReadyForSubMesh = function (mesh, subMesh, useInstances) {\r\n return false;\r\n };\r\n /**\r\n * Returns the material effect\r\n * @returns the effect associated with the material\r\n */\r\n Material.prototype.getEffect = function () {\r\n return this._effect;\r\n };\r\n /**\r\n * Returns the current scene\r\n * @returns a Scene\r\n */\r\n Material.prototype.getScene = function () {\r\n return this._scene;\r\n };\r\n Object.defineProperty(Material.prototype, \"transparencyMode\", {\r\n /**\r\n * Gets the current transparency mode.\r\n */\r\n get: function () {\r\n return this._transparencyMode;\r\n },\r\n /**\r\n * Sets the transparency mode of the material.\r\n *\r\n * | Value | Type | Description |\r\n * | ----- | ----------------------------------- | ----------- |\r\n * | 0 | OPAQUE | |\r\n * | 1 | ALPHATEST | |\r\n * | 2 | ALPHABLEND | |\r\n * | 3 | ALPHATESTANDBLEND | |\r\n *\r\n */\r\n set: function (value) {\r\n if (this._transparencyMode === value) {\r\n return;\r\n }\r\n this._transparencyMode = value;\r\n this._forceAlphaTest = (value === Material.MATERIAL_ALPHATESTANDBLEND);\r\n this._markAllSubMeshesAsTexturesAndMiscDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Material.prototype, \"_disableAlphaBlending\", {\r\n /**\r\n * Returns true if alpha blending should be disabled.\r\n */\r\n get: function () {\r\n return (this._transparencyMode === Material.MATERIAL_OPAQUE ||\r\n this._transparencyMode === Material.MATERIAL_ALPHATEST);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Specifies whether or not this material should be rendered in alpha blend mode.\r\n * @returns a boolean specifying if alpha blending is needed\r\n */\r\n Material.prototype.needAlphaBlending = function () {\r\n if (this._disableAlphaBlending) {\r\n return false;\r\n }\r\n return (this.alpha < 1.0);\r\n };\r\n /**\r\n * Specifies if the mesh will require alpha blending\r\n * @param mesh defines the mesh to check\r\n * @returns a boolean specifying if alpha blending is needed for the mesh\r\n */\r\n Material.prototype.needAlphaBlendingForMesh = function (mesh) {\r\n if (this._disableAlphaBlending && mesh.visibility >= 1.0) {\r\n return false;\r\n }\r\n return this.needAlphaBlending() || (mesh.visibility < 1.0) || mesh.hasVertexAlpha;\r\n };\r\n /**\r\n * Specifies whether or not this material should be rendered in alpha test mode.\r\n * @returns a boolean specifying if an alpha test is needed.\r\n */\r\n Material.prototype.needAlphaTesting = function () {\r\n if (this._forceAlphaTest) {\r\n return true;\r\n }\r\n return false;\r\n };\r\n /**\r\n * Specifies if material alpha testing should be turned on for the mesh\r\n * @param mesh defines the mesh to check\r\n */\r\n Material.prototype._shouldTurnAlphaTestOn = function (mesh) {\r\n return (!this.needAlphaBlendingForMesh(mesh) && this.needAlphaTesting());\r\n };\r\n /**\r\n * Gets the texture used for the alpha test\r\n * @returns the texture to use for alpha testing\r\n */\r\n Material.prototype.getAlphaTestTexture = function () {\r\n return null;\r\n };\r\n /**\r\n * Marks the material to indicate that it needs to be re-calculated\r\n */\r\n Material.prototype.markDirty = function () {\r\n var meshes = this.getScene().meshes;\r\n for (var _i = 0, meshes_1 = meshes; _i < meshes_1.length; _i++) {\r\n var mesh = meshes_1[_i];\r\n if (!mesh.subMeshes) {\r\n continue;\r\n }\r\n for (var _a = 0, _b = mesh.subMeshes; _a < _b.length; _a++) {\r\n var subMesh = _b[_a];\r\n if (subMesh.getMaterial() !== this) {\r\n continue;\r\n }\r\n if (!subMesh.effect) {\r\n continue;\r\n }\r\n subMesh.effect._wasPreviouslyReady = false;\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n Material.prototype._preBind = function (effect, overrideOrientation) {\r\n if (overrideOrientation === void 0) { overrideOrientation = null; }\r\n var engine = this._scene.getEngine();\r\n var orientation = (overrideOrientation == null) ? this.sideOrientation : overrideOrientation;\r\n var reverse = orientation === Material.ClockWiseSideOrientation;\r\n engine.enableEffect(effect ? effect : this._effect);\r\n engine.setState(this.backFaceCulling, this.zOffset, false, reverse);\r\n return reverse;\r\n };\r\n /**\r\n * Binds the material to the mesh\r\n * @param world defines the world transformation matrix\r\n * @param mesh defines the mesh to bind the material to\r\n */\r\n Material.prototype.bind = function (world, mesh) {\r\n };\r\n /**\r\n * Binds the submesh to the material\r\n * @param world defines the world transformation matrix\r\n * @param mesh defines the mesh containing the submesh\r\n * @param subMesh defines the submesh to bind the material to\r\n */\r\n Material.prototype.bindForSubMesh = function (world, mesh, subMesh) {\r\n };\r\n /**\r\n * Binds the world matrix to the material\r\n * @param world defines the world transformation matrix\r\n */\r\n Material.prototype.bindOnlyWorldMatrix = function (world) {\r\n };\r\n /**\r\n * Binds the scene's uniform buffer to the effect.\r\n * @param effect defines the effect to bind to the scene uniform buffer\r\n * @param sceneUbo defines the uniform buffer storing scene data\r\n */\r\n Material.prototype.bindSceneUniformBuffer = function (effect, sceneUbo) {\r\n sceneUbo.bindToEffect(effect, \"Scene\");\r\n };\r\n /**\r\n * Binds the view matrix to the effect\r\n * @param effect defines the effect to bind the view matrix to\r\n */\r\n Material.prototype.bindView = function (effect) {\r\n if (!this._useUBO) {\r\n effect.setMatrix(\"view\", this.getScene().getViewMatrix());\r\n }\r\n else {\r\n this.bindSceneUniformBuffer(effect, this.getScene().getSceneUniformBuffer());\r\n }\r\n };\r\n /**\r\n * Binds the view projection matrix to the effect\r\n * @param effect defines the effect to bind the view projection matrix to\r\n */\r\n Material.prototype.bindViewProjection = function (effect) {\r\n if (!this._useUBO) {\r\n effect.setMatrix(\"viewProjection\", this.getScene().getTransformMatrix());\r\n }\r\n else {\r\n this.bindSceneUniformBuffer(effect, this.getScene().getSceneUniformBuffer());\r\n }\r\n };\r\n /**\r\n * Processes to execute after binding the material to a mesh\r\n * @param mesh defines the rendered mesh\r\n */\r\n Material.prototype._afterBind = function (mesh) {\r\n this._scene._cachedMaterial = this;\r\n if (mesh) {\r\n this._scene._cachedVisibility = mesh.visibility;\r\n }\r\n else {\r\n this._scene._cachedVisibility = 1;\r\n }\r\n if (this._onBindObservable && mesh) {\r\n this._onBindObservable.notifyObservers(mesh);\r\n }\r\n if (this.disableDepthWrite) {\r\n var engine = this._scene.getEngine();\r\n this._cachedDepthWriteState = engine.getDepthWrite();\r\n engine.setDepthWrite(false);\r\n }\r\n if (this.disableColorWrite) {\r\n var engine = this._scene.getEngine();\r\n this._cachedColorWriteState = engine.getColorWrite();\r\n engine.setColorWrite(false);\r\n }\r\n if (this.depthFunction !== 0) {\r\n var engine = this._scene.getEngine();\r\n this._cachedDepthFunctionState = engine.getDepthFunction() || 0;\r\n engine.setDepthFunction(this.depthFunction);\r\n }\r\n };\r\n /**\r\n * Unbinds the material from the mesh\r\n */\r\n Material.prototype.unbind = function () {\r\n if (this._onUnBindObservable) {\r\n this._onUnBindObservable.notifyObservers(this);\r\n }\r\n if (this.depthFunction !== 0) {\r\n var engine = this._scene.getEngine();\r\n engine.setDepthFunction(this._cachedDepthFunctionState);\r\n }\r\n if (this.disableDepthWrite) {\r\n var engine = this._scene.getEngine();\r\n engine.setDepthWrite(this._cachedDepthWriteState);\r\n }\r\n if (this.disableColorWrite) {\r\n var engine = this._scene.getEngine();\r\n engine.setColorWrite(this._cachedColorWriteState);\r\n }\r\n };\r\n /**\r\n * Gets the active textures from the material\r\n * @returns an array of textures\r\n */\r\n Material.prototype.getActiveTextures = function () {\r\n return [];\r\n };\r\n /**\r\n * Specifies if the material uses a texture\r\n * @param texture defines the texture to check against the material\r\n * @returns a boolean specifying if the material uses the texture\r\n */\r\n Material.prototype.hasTexture = function (texture) {\r\n return false;\r\n };\r\n /**\r\n * Makes a duplicate of the material, and gives it a new name\r\n * @param name defines the new name for the duplicated material\r\n * @returns the cloned material\r\n */\r\n Material.prototype.clone = function (name) {\r\n return null;\r\n };\r\n /**\r\n * Gets the meshes bound to the material\r\n * @returns an array of meshes bound to the material\r\n */\r\n Material.prototype.getBindedMeshes = function () {\r\n var _this = this;\r\n if (this.meshMap) {\r\n var result = new Array();\r\n for (var meshId in this.meshMap) {\r\n var mesh = this.meshMap[meshId];\r\n if (mesh) {\r\n result.push(mesh);\r\n }\r\n }\r\n return result;\r\n }\r\n else {\r\n var meshes = this._scene.meshes;\r\n return meshes.filter(function (mesh) { return mesh.material === _this; });\r\n }\r\n };\r\n /**\r\n * Force shader compilation\r\n * @param mesh defines the mesh associated with this material\r\n * @param onCompiled defines a function to execute once the material is compiled\r\n * @param options defines the options to configure the compilation\r\n * @param onError defines a function to execute if the material fails compiling\r\n */\r\n Material.prototype.forceCompilation = function (mesh, onCompiled, options, onError) {\r\n var _this = this;\r\n var localOptions = __assign({ clipPlane: false, useInstances: false }, options);\r\n var scene = this.getScene();\r\n var currentHotSwapingState = this.allowShaderHotSwapping;\r\n this.allowShaderHotSwapping = false; // Turned off to let us evaluate the real compilation state\r\n var checkReady = function () {\r\n if (!_this._scene || !_this._scene.getEngine()) {\r\n return;\r\n }\r\n var clipPlaneState = scene.clipPlane;\r\n if (localOptions.clipPlane) {\r\n scene.clipPlane = new Plane(0, 0, 0, 1);\r\n }\r\n if (_this._storeEffectOnSubMeshes) {\r\n var allDone = true, lastError = null;\r\n if (mesh.subMeshes) {\r\n var tempSubMesh = new SubMesh(0, 0, 0, 0, 0, mesh, undefined, false, false);\r\n if (tempSubMesh._materialDefines) {\r\n tempSubMesh._materialDefines._renderId = -1;\r\n }\r\n if (!_this.isReadyForSubMesh(mesh, tempSubMesh, localOptions.useInstances)) {\r\n if (tempSubMesh.effect && tempSubMesh.effect.getCompilationError() && tempSubMesh.effect.allFallbacksProcessed()) {\r\n lastError = tempSubMesh.effect.getCompilationError();\r\n }\r\n else {\r\n allDone = false;\r\n setTimeout(checkReady, 16);\r\n }\r\n }\r\n }\r\n if (allDone) {\r\n _this.allowShaderHotSwapping = currentHotSwapingState;\r\n if (lastError) {\r\n if (onError) {\r\n onError(lastError);\r\n }\r\n }\r\n if (onCompiled) {\r\n onCompiled(_this);\r\n }\r\n }\r\n }\r\n else {\r\n if (_this.isReady()) {\r\n _this.allowShaderHotSwapping = currentHotSwapingState;\r\n if (onCompiled) {\r\n onCompiled(_this);\r\n }\r\n }\r\n else {\r\n setTimeout(checkReady, 16);\r\n }\r\n }\r\n if (localOptions.clipPlane) {\r\n scene.clipPlane = clipPlaneState;\r\n }\r\n };\r\n checkReady();\r\n };\r\n /**\r\n * Force shader compilation\r\n * @param mesh defines the mesh that will use this material\r\n * @param options defines additional options for compiling the shaders\r\n * @returns a promise that resolves when the compilation completes\r\n */\r\n Material.prototype.forceCompilationAsync = function (mesh, options) {\r\n var _this = this;\r\n return new Promise(function (resolve, reject) {\r\n _this.forceCompilation(mesh, function () {\r\n resolve();\r\n }, options, function (reason) {\r\n reject(reason);\r\n });\r\n });\r\n };\r\n /**\r\n * Marks a define in the material to indicate that it needs to be re-computed\r\n * @param flag defines a flag used to determine which parts of the material have to be marked as dirty\r\n */\r\n Material.prototype.markAsDirty = function (flag) {\r\n if (this.getScene().blockMaterialDirtyMechanism) {\r\n return;\r\n }\r\n Material._DirtyCallbackArray.length = 0;\r\n if (flag & Material.TextureDirtyFlag) {\r\n Material._DirtyCallbackArray.push(Material._TextureDirtyCallBack);\r\n }\r\n if (flag & Material.LightDirtyFlag) {\r\n Material._DirtyCallbackArray.push(Material._LightsDirtyCallBack);\r\n }\r\n if (flag & Material.FresnelDirtyFlag) {\r\n Material._DirtyCallbackArray.push(Material._FresnelDirtyCallBack);\r\n }\r\n if (flag & Material.AttributesDirtyFlag) {\r\n Material._DirtyCallbackArray.push(Material._AttributeDirtyCallBack);\r\n }\r\n if (flag & Material.MiscDirtyFlag) {\r\n Material._DirtyCallbackArray.push(Material._MiscDirtyCallBack);\r\n }\r\n if (flag & Material.PrePassDirtyFlag) {\r\n Material._DirtyCallbackArray.push(Material._PrePassDirtyCallBack);\r\n }\r\n if (Material._DirtyCallbackArray.length) {\r\n this._markAllSubMeshesAsDirty(Material._RunDirtyCallBacks);\r\n }\r\n this.getScene().resetCachedMaterial();\r\n };\r\n /**\r\n * Marks all submeshes of a material to indicate that their material defines need to be re-calculated\r\n * @param func defines a function which checks material defines against the submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsDirty = function (func) {\r\n if (this.getScene().blockMaterialDirtyMechanism) {\r\n return;\r\n }\r\n var meshes = this.getScene().meshes;\r\n for (var _i = 0, meshes_2 = meshes; _i < meshes_2.length; _i++) {\r\n var mesh = meshes_2[_i];\r\n if (!mesh.subMeshes) {\r\n continue;\r\n }\r\n for (var _a = 0, _b = mesh.subMeshes; _a < _b.length; _a++) {\r\n var subMesh = _b[_a];\r\n if (subMesh.getMaterial() !== this) {\r\n continue;\r\n }\r\n if (!subMesh._materialDefines) {\r\n continue;\r\n }\r\n func(subMesh._materialDefines);\r\n }\r\n }\r\n };\r\n /**\r\n * Indicates that the scene should check if the rendering now needs a prepass\r\n */\r\n Material.prototype._markScenePrePassDirty = function () {\r\n if (this.getScene().blockMaterialDirtyMechanism) {\r\n return;\r\n }\r\n var prePassRenderer = this.getScene().enablePrePassRenderer();\r\n if (prePassRenderer) {\r\n prePassRenderer.markAsDirty();\r\n }\r\n };\r\n /**\r\n * Indicates that we need to re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsAllDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._AllDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that image processing needs to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsImageProcessingDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._ImageProcessingDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that textures need to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsTexturesDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._TextureDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that fresnel needs to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsFresnelDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._FresnelDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that fresnel and misc need to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsFresnelAndMiscDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._FresnelAndMiscDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that lights need to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsLightsDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._LightsDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that attributes need to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsAttributesDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._AttributeDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that misc needs to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsMiscDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._MiscDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that prepass needs to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsPrePassDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._MiscDirtyCallBack);\r\n };\r\n /**\r\n * Indicates that textures and misc need to be re-calculated for all submeshes\r\n */\r\n Material.prototype._markAllSubMeshesAsTexturesAndMiscDirty = function () {\r\n this._markAllSubMeshesAsDirty(Material._TextureAndMiscDirtyCallBack);\r\n };\r\n /**\r\n * Sets the required values to the prepass renderer.\r\n * @param prePassRenderer defines the prepass renderer to setup.\r\n * @returns true if the pre pass is needed.\r\n */\r\n Material.prototype.setPrePassRenderer = function (prePassRenderer) {\r\n // Do Nothing by default\r\n return false;\r\n };\r\n /**\r\n * Disposes the material\r\n * @param forceDisposeEffect specifies if effects should be forcefully disposed\r\n * @param forceDisposeTextures specifies if textures should be forcefully disposed\r\n * @param notBoundToMesh specifies if the material that is being disposed is known to be not bound to any mesh\r\n */\r\n Material.prototype.dispose = function (forceDisposeEffect, forceDisposeTextures, notBoundToMesh) {\r\n var scene = this.getScene();\r\n // Animations\r\n scene.stopAnimation(this);\r\n scene.freeProcessedMaterials();\r\n // Remove from scene\r\n scene.removeMaterial(this);\r\n if (notBoundToMesh !== true) {\r\n // Remove from meshes\r\n if (this.meshMap) {\r\n for (var meshId in this.meshMap) {\r\n var mesh = this.meshMap[meshId];\r\n if (mesh) {\r\n mesh.material = null; // will set the entry in the map to undefined\r\n this.releaseVertexArrayObject(mesh, forceDisposeEffect);\r\n }\r\n }\r\n }\r\n else {\r\n var meshes = scene.meshes;\r\n for (var _i = 0, meshes_3 = meshes; _i < meshes_3.length; _i++) {\r\n var mesh = meshes_3[_i];\r\n if (mesh.material === this && !mesh.sourceMesh) {\r\n mesh.material = null;\r\n this.releaseVertexArrayObject(mesh, forceDisposeEffect);\r\n }\r\n }\r\n }\r\n }\r\n this._uniformBuffer.dispose();\r\n // Shader are kept in cache for further use but we can get rid of this by using forceDisposeEffect\r\n if (forceDisposeEffect && this._effect) {\r\n if (!this._storeEffectOnSubMeshes) {\r\n this._effect.dispose();\r\n }\r\n this._effect = null;\r\n }\r\n // Callback\r\n this.onDisposeObservable.notifyObservers(this);\r\n this.onDisposeObservable.clear();\r\n if (this._onBindObservable) {\r\n this._onBindObservable.clear();\r\n }\r\n if (this._onUnBindObservable) {\r\n this._onUnBindObservable.clear();\r\n }\r\n if (this._onEffectCreatedObservable) {\r\n this._onEffectCreatedObservable.clear();\r\n }\r\n };\r\n /** @hidden */\r\n Material.prototype.releaseVertexArrayObject = function (mesh, forceDisposeEffect) {\r\n if (mesh.geometry) {\r\n var geometry = (mesh.geometry);\r\n if (this._storeEffectOnSubMeshes) {\r\n for (var _i = 0, _a = mesh.subMeshes; _i < _a.length; _i++) {\r\n var subMesh = _a[_i];\r\n geometry._releaseVertexArrayObject(subMesh._materialEffect);\r\n if (forceDisposeEffect && subMesh._materialEffect) {\r\n subMesh._materialEffect.dispose();\r\n }\r\n }\r\n }\r\n else {\r\n geometry._releaseVertexArrayObject(this._effect);\r\n }\r\n }\r\n };\r\n /**\r\n * Serializes this material\r\n * @returns the serialized material object\r\n */\r\n Material.prototype.serialize = function () {\r\n return SerializationHelper.Serialize(this);\r\n };\r\n /**\r\n * Creates a material from parsed material data\r\n * @param parsedMaterial defines parsed material data\r\n * @param scene defines the hosting scene\r\n * @param rootUrl defines the root URL to use to load textures\r\n * @returns a new material\r\n */\r\n Material.Parse = function (parsedMaterial, scene, rootUrl) {\r\n if (!parsedMaterial.customType) {\r\n parsedMaterial.customType = \"BABYLON.StandardMaterial\";\r\n }\r\n else if (parsedMaterial.customType === \"BABYLON.PBRMaterial\" && parsedMaterial.overloadedAlbedo) {\r\n parsedMaterial.customType = \"BABYLON.LegacyPBRMaterial\";\r\n if (!BABYLON.LegacyPBRMaterial) {\r\n Logger.Error(\"Your scene is trying to load a legacy version of the PBRMaterial, please, include it from the materials library.\");\r\n return null;\r\n }\r\n }\r\n var materialType = Tools.Instantiate(parsedMaterial.customType);\r\n return materialType.Parse(parsedMaterial, scene, rootUrl);\r\n };\r\n /**\r\n * Returns the triangle fill mode\r\n */\r\n Material.TriangleFillMode = 0;\r\n /**\r\n * Returns the wireframe mode\r\n */\r\n Material.WireFrameFillMode = 1;\r\n /**\r\n * Returns the point fill mode\r\n */\r\n Material.PointFillMode = 2;\r\n /**\r\n * Returns the point list draw mode\r\n */\r\n Material.PointListDrawMode = 3;\r\n /**\r\n * Returns the line list draw mode\r\n */\r\n Material.LineListDrawMode = 4;\r\n /**\r\n * Returns the line loop draw mode\r\n */\r\n Material.LineLoopDrawMode = 5;\r\n /**\r\n * Returns the line strip draw mode\r\n */\r\n Material.LineStripDrawMode = 6;\r\n /**\r\n * Returns the triangle strip draw mode\r\n */\r\n Material.TriangleStripDrawMode = 7;\r\n /**\r\n * Returns the triangle fan draw mode\r\n */\r\n Material.TriangleFanDrawMode = 8;\r\n /**\r\n * Stores the clock-wise side orientation\r\n */\r\n Material.ClockWiseSideOrientation = 0;\r\n /**\r\n * Stores the counter clock-wise side orientation\r\n */\r\n Material.CounterClockWiseSideOrientation = 1;\r\n /**\r\n * The dirty texture flag value\r\n */\r\n Material.TextureDirtyFlag = 1;\r\n /**\r\n * The dirty light flag value\r\n */\r\n Material.LightDirtyFlag = 2;\r\n /**\r\n * The dirty fresnel flag value\r\n */\r\n Material.FresnelDirtyFlag = 4;\r\n /**\r\n * The dirty attribute flag value\r\n */\r\n Material.AttributesDirtyFlag = 8;\r\n /**\r\n * The dirty misc flag value\r\n */\r\n Material.MiscDirtyFlag = 16;\r\n /**\r\n * The dirty prepass flag value\r\n */\r\n Material.PrePassDirtyFlag = 32;\r\n /**\r\n * The all dirty flag value\r\n */\r\n Material.AllDirtyFlag = 63;\r\n /**\r\n * MaterialTransparencyMode: No transparency mode, Alpha channel is not use.\r\n */\r\n Material.MATERIAL_OPAQUE = 0;\r\n /**\r\n * MaterialTransparencyMode: Alpha Test mode, pixel are discarded below a certain threshold defined by the alpha cutoff value.\r\n */\r\n Material.MATERIAL_ALPHATEST = 1;\r\n /**\r\n * MaterialTransparencyMode: Pixels are blended (according to the alpha mode) with the already drawn pixels in the current frame buffer.\r\n */\r\n Material.MATERIAL_ALPHABLEND = 2;\r\n /**\r\n * MaterialTransparencyMode: Pixels are blended (according to the alpha mode) with the already drawn pixels in the current frame buffer.\r\n * They are also discarded below the alpha cutoff threshold to improve performances.\r\n */\r\n Material.MATERIAL_ALPHATESTANDBLEND = 3;\r\n /**\r\n * The Whiteout method is used to blend normals.\r\n * Details of the algorithm can be found here: https://blog.selfshadow.com/publications/blending-in-detail/\r\n */\r\n Material.MATERIAL_NORMALBLENDMETHOD_WHITEOUT = 0;\r\n /**\r\n * The Reoriented Normal Mapping method is used to blend normals.\r\n * Details of the algorithm can be found here: https://blog.selfshadow.com/publications/blending-in-detail/\r\n */\r\n Material.MATERIAL_NORMALBLENDMETHOD_RNM = 1;\r\n Material._AllDirtyCallBack = function (defines) { return defines.markAllAsDirty(); };\r\n Material._ImageProcessingDirtyCallBack = function (defines) { return defines.markAsImageProcessingDirty(); };\r\n Material._TextureDirtyCallBack = function (defines) { return defines.markAsTexturesDirty(); };\r\n Material._FresnelDirtyCallBack = function (defines) { return defines.markAsFresnelDirty(); };\r\n Material._MiscDirtyCallBack = function (defines) { return defines.markAsMiscDirty(); };\r\n Material._PrePassDirtyCallBack = function (defines) { return defines.markAsPrePassDirty(); };\r\n Material._LightsDirtyCallBack = function (defines) { return defines.markAsLightDirty(); };\r\n Material._AttributeDirtyCallBack = function (defines) { return defines.markAsAttributesDirty(); };\r\n Material._FresnelAndMiscDirtyCallBack = function (defines) {\r\n Material._FresnelDirtyCallBack(defines);\r\n Material._MiscDirtyCallBack(defines);\r\n };\r\n Material._TextureAndMiscDirtyCallBack = function (defines) {\r\n Material._TextureDirtyCallBack(defines);\r\n Material._MiscDirtyCallBack(defines);\r\n };\r\n Material._DirtyCallbackArray = [];\r\n Material._RunDirtyCallBacks = function (defines) {\r\n for (var _i = 0, _a = Material._DirtyCallbackArray; _i < _a.length; _i++) {\r\n var cb = _a[_i];\r\n cb(defines);\r\n }\r\n };\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"id\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"uniqueId\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"name\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"checkReadyOnEveryCall\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"checkReadyOnlyOnce\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"state\", void 0);\r\n __decorate([\r\n serialize(\"alpha\")\r\n ], Material.prototype, \"_alpha\", void 0);\r\n __decorate([\r\n serialize(\"backFaceCulling\")\r\n ], Material.prototype, \"_backFaceCulling\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"sideOrientation\", void 0);\r\n __decorate([\r\n serialize(\"alphaMode\")\r\n ], Material.prototype, \"_alphaMode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"_needDepthPrePass\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"disableDepthWrite\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"disableColorWrite\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"forceDepthWrite\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"depthFunction\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"separateCullingPass\", void 0);\r\n __decorate([\r\n serialize(\"fogEnabled\")\r\n ], Material.prototype, \"_fogEnabled\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"pointSize\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"zOffset\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"pointsCloud\", null);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"fillMode\", null);\r\n __decorate([\r\n serialize()\r\n ], Material.prototype, \"transparencyMode\", null);\r\n return Material;\r\n}());\r\nexport { Material };\r\n//# sourceMappingURL=material.js.map","import { PrecisionDate } from \"./precisionDate\";\r\n/**\r\n * Performance monitor tracks rolling average frame-time and frame-time variance over a user defined sliding-window\r\n */\r\nvar PerformanceMonitor = /** @class */ (function () {\r\n /**\r\n * constructor\r\n * @param frameSampleSize The number of samples required to saturate the sliding window\r\n */\r\n function PerformanceMonitor(frameSampleSize) {\r\n if (frameSampleSize === void 0) { frameSampleSize = 30; }\r\n this._enabled = true;\r\n this._rollingFrameTime = new RollingAverage(frameSampleSize);\r\n }\r\n /**\r\n * Samples current frame\r\n * @param timeMs A timestamp in milliseconds of the current frame to compare with other frames\r\n */\r\n PerformanceMonitor.prototype.sampleFrame = function (timeMs) {\r\n if (timeMs === void 0) { timeMs = PrecisionDate.Now; }\r\n if (!this._enabled) {\r\n return;\r\n }\r\n if (this._lastFrameTimeMs != null) {\r\n var dt = timeMs - this._lastFrameTimeMs;\r\n this._rollingFrameTime.add(dt);\r\n }\r\n this._lastFrameTimeMs = timeMs;\r\n };\r\n Object.defineProperty(PerformanceMonitor.prototype, \"averageFrameTime\", {\r\n /**\r\n * Returns the average frame time in milliseconds over the sliding window (or the subset of frames sampled so far)\r\n */\r\n get: function () {\r\n return this._rollingFrameTime.average;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerformanceMonitor.prototype, \"averageFrameTimeVariance\", {\r\n /**\r\n * Returns the variance frame time in milliseconds over the sliding window (or the subset of frames sampled so far)\r\n */\r\n get: function () {\r\n return this._rollingFrameTime.variance;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerformanceMonitor.prototype, \"instantaneousFrameTime\", {\r\n /**\r\n * Returns the frame time of the most recent frame\r\n */\r\n get: function () {\r\n return this._rollingFrameTime.history(0);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerformanceMonitor.prototype, \"averageFPS\", {\r\n /**\r\n * Returns the average framerate in frames per second over the sliding window (or the subset of frames sampled so far)\r\n */\r\n get: function () {\r\n return 1000.0 / this._rollingFrameTime.average;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerformanceMonitor.prototype, \"instantaneousFPS\", {\r\n /**\r\n * Returns the average framerate in frames per second using the most recent frame time\r\n */\r\n get: function () {\r\n var history = this._rollingFrameTime.history(0);\r\n if (history === 0) {\r\n return 0;\r\n }\r\n return 1000.0 / history;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerformanceMonitor.prototype, \"isSaturated\", {\r\n /**\r\n * Returns true if enough samples have been taken to completely fill the sliding window\r\n */\r\n get: function () {\r\n return this._rollingFrameTime.isSaturated();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Enables contributions to the sliding window sample set\r\n */\r\n PerformanceMonitor.prototype.enable = function () {\r\n this._enabled = true;\r\n };\r\n /**\r\n * Disables contributions to the sliding window sample set\r\n * Samples will not be interpolated over the disabled period\r\n */\r\n PerformanceMonitor.prototype.disable = function () {\r\n this._enabled = false;\r\n //clear last sample to avoid interpolating over the disabled period when next enabled\r\n this._lastFrameTimeMs = null;\r\n };\r\n Object.defineProperty(PerformanceMonitor.prototype, \"isEnabled\", {\r\n /**\r\n * Returns true if sampling is enabled\r\n */\r\n get: function () {\r\n return this._enabled;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Resets performance monitor\r\n */\r\n PerformanceMonitor.prototype.reset = function () {\r\n //clear last sample to avoid interpolating over the disabled period when next enabled\r\n this._lastFrameTimeMs = null;\r\n //wipe record\r\n this._rollingFrameTime.reset();\r\n };\r\n return PerformanceMonitor;\r\n}());\r\nexport { PerformanceMonitor };\r\n/**\r\n * RollingAverage\r\n *\r\n * Utility to efficiently compute the rolling average and variance over a sliding window of samples\r\n */\r\nvar RollingAverage = /** @class */ (function () {\r\n /**\r\n * constructor\r\n * @param length The number of samples required to saturate the sliding window\r\n */\r\n function RollingAverage(length) {\r\n this._samples = new Array(length);\r\n this.reset();\r\n }\r\n /**\r\n * Adds a sample to the sample set\r\n * @param v The sample value\r\n */\r\n RollingAverage.prototype.add = function (v) {\r\n //http://en.wikipedia.org/wiki/Algorithms_for_calculating_variance\r\n var delta;\r\n //we need to check if we've already wrapped round\r\n if (this.isSaturated()) {\r\n //remove bottom of stack from mean\r\n var bottomValue = this._samples[this._pos];\r\n delta = bottomValue - this.average;\r\n this.average -= delta / (this._sampleCount - 1);\r\n this._m2 -= delta * (bottomValue - this.average);\r\n }\r\n else {\r\n this._sampleCount++;\r\n }\r\n //add new value to mean\r\n delta = v - this.average;\r\n this.average += delta / (this._sampleCount);\r\n this._m2 += delta * (v - this.average);\r\n //set the new variance\r\n this.variance = this._m2 / (this._sampleCount - 1);\r\n this._samples[this._pos] = v;\r\n this._pos++;\r\n this._pos %= this._samples.length; //positive wrap around\r\n };\r\n /**\r\n * Returns previously added values or null if outside of history or outside the sliding window domain\r\n * @param i Index in history. For example, pass 0 for the most recent value and 1 for the value before that\r\n * @return Value previously recorded with add() or null if outside of range\r\n */\r\n RollingAverage.prototype.history = function (i) {\r\n if ((i >= this._sampleCount) || (i >= this._samples.length)) {\r\n return 0;\r\n }\r\n var i0 = this._wrapPosition(this._pos - 1.0);\r\n return this._samples[this._wrapPosition(i0 - i)];\r\n };\r\n /**\r\n * Returns true if enough samples have been taken to completely fill the sliding window\r\n * @return true if sample-set saturated\r\n */\r\n RollingAverage.prototype.isSaturated = function () {\r\n return this._sampleCount >= this._samples.length;\r\n };\r\n /**\r\n * Resets the rolling average (equivalent to 0 samples taken so far)\r\n */\r\n RollingAverage.prototype.reset = function () {\r\n this.average = 0;\r\n this.variance = 0;\r\n this._sampleCount = 0;\r\n this._pos = 0;\r\n this._m2 = 0;\r\n };\r\n /**\r\n * Wraps a value around the sample range boundaries\r\n * @param i Position in sample range, for example if the sample length is 5, and i is -3, then 2 will be returned.\r\n * @return Wrapped position in sample range\r\n */\r\n RollingAverage.prototype._wrapPosition = function (i) {\r\n var max = this._samples.length;\r\n return ((i % max) + max) % max;\r\n };\r\n return RollingAverage;\r\n}());\r\nexport { RollingAverage };\r\n//# sourceMappingURL=performanceMonitor.js.map","import { ThinEngine } from \"../../Engines/thinEngine\";\r\nThinEngine.prototype.setAlphaConstants = function (r, g, b, a) {\r\n this._alphaState.setAlphaBlendConstants(r, g, b, a);\r\n};\r\nThinEngine.prototype.setAlphaMode = function (mode, noDepthWriteChange) {\r\n if (noDepthWriteChange === void 0) { noDepthWriteChange = false; }\r\n if (this._alphaMode === mode) {\r\n return;\r\n }\r\n switch (mode) {\r\n case 0:\r\n this._alphaState.alphaBlend = false;\r\n break;\r\n case 7:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE, this._gl.ONE_MINUS_SRC_ALPHA, this._gl.ONE, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 8:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE, this._gl.ONE_MINUS_SRC_ALPHA, this._gl.ONE, this._gl.ONE_MINUS_SRC_ALPHA);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 2:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.SRC_ALPHA, this._gl.ONE_MINUS_SRC_ALPHA, this._gl.ONE, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 6:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE, this._gl.ONE, this._gl.ZERO, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 1:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.SRC_ALPHA, this._gl.ONE, this._gl.ZERO, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 3:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ZERO, this._gl.ONE_MINUS_SRC_COLOR, this._gl.ONE, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 4:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.DST_COLOR, this._gl.ZERO, this._gl.ONE, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 5:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.SRC_ALPHA, this._gl.ONE_MINUS_SRC_COLOR, this._gl.ONE, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 9:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.CONSTANT_COLOR, this._gl.ONE_MINUS_CONSTANT_COLOR, this._gl.CONSTANT_ALPHA, this._gl.ONE_MINUS_CONSTANT_ALPHA);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 10:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE, this._gl.ONE_MINUS_SRC_COLOR, this._gl.ONE, this._gl.ONE_MINUS_SRC_ALPHA);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 11:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE, this._gl.ONE, this._gl.ONE, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 12:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.DST_ALPHA, this._gl.ONE, this._gl.ZERO, this._gl.ZERO);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 13:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE_MINUS_DST_COLOR, this._gl.ONE_MINUS_SRC_COLOR, this._gl.ONE_MINUS_DST_ALPHA, this._gl.ONE_MINUS_SRC_ALPHA);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 14:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE, this._gl.ONE_MINUS_SRC_ALPHA, this._gl.ONE, this._gl.ONE_MINUS_SRC_ALPHA);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 15:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE, this._gl.ONE, this._gl.ONE, this._gl.ZERO);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n case 16:\r\n this._alphaState.setAlphaBlendFunctionParameters(this._gl.ONE_MINUS_DST_COLOR, this._gl.ONE_MINUS_SRC_COLOR, this._gl.ZERO, this._gl.ONE);\r\n this._alphaState.alphaBlend = true;\r\n break;\r\n }\r\n if (!noDepthWriteChange) {\r\n this.depthCullingState.depthMask = (mode === 0);\r\n }\r\n this._alphaMode = mode;\r\n};\r\nThinEngine.prototype.getAlphaMode = function () {\r\n return this._alphaMode;\r\n};\r\nThinEngine.prototype.setAlphaEquation = function (equation) {\r\n if (this._alphaEquation === equation) {\r\n return;\r\n }\r\n switch (equation) {\r\n case 0:\r\n this._alphaState.setAlphaEquationParameters(this._gl.FUNC_ADD, this._gl.FUNC_ADD);\r\n break;\r\n case 1:\r\n this._alphaState.setAlphaEquationParameters(this._gl.FUNC_SUBTRACT, this._gl.FUNC_SUBTRACT);\r\n break;\r\n case 2:\r\n this._alphaState.setAlphaEquationParameters(this._gl.FUNC_REVERSE_SUBTRACT, this._gl.FUNC_REVERSE_SUBTRACT);\r\n break;\r\n case 3:\r\n this._alphaState.setAlphaEquationParameters(this._gl.MAX, this._gl.MAX);\r\n break;\r\n case 4:\r\n this._alphaState.setAlphaEquationParameters(this._gl.MIN, this._gl.MIN);\r\n break;\r\n case 5:\r\n this._alphaState.setAlphaEquationParameters(this._gl.MIN, this._gl.FUNC_ADD);\r\n break;\r\n }\r\n this._alphaEquation = equation;\r\n};\r\nThinEngine.prototype.getAlphaEquation = function () {\r\n return this._alphaEquation;\r\n};\r\n//# sourceMappingURL=engine.alpha.js.map","import { ThinEngine } from \"../../Engines/thinEngine\";\r\nThinEngine.prototype._readTexturePixels = function (texture, width, height, faceIndex, level, buffer) {\r\n if (faceIndex === void 0) { faceIndex = -1; }\r\n if (level === void 0) { level = 0; }\r\n if (buffer === void 0) { buffer = null; }\r\n var gl = this._gl;\r\n if (!gl) {\r\n throw new Error(\"Engine does not have gl rendering context.\");\r\n }\r\n if (!this._dummyFramebuffer) {\r\n var dummy = gl.createFramebuffer();\r\n if (!dummy) {\r\n throw new Error(\"Unable to create dummy framebuffer\");\r\n }\r\n this._dummyFramebuffer = dummy;\r\n }\r\n gl.bindFramebuffer(gl.FRAMEBUFFER, this._dummyFramebuffer);\r\n if (faceIndex > -1) {\r\n gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_CUBE_MAP_POSITIVE_X + faceIndex, texture._webGLTexture, level);\r\n }\r\n else {\r\n gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture._webGLTexture, level);\r\n }\r\n var readType = (texture.type !== undefined) ? this._getWebGLTextureType(texture.type) : gl.UNSIGNED_BYTE;\r\n switch (readType) {\r\n case gl.UNSIGNED_BYTE:\r\n if (!buffer) {\r\n buffer = new Uint8Array(4 * width * height);\r\n }\r\n readType = gl.UNSIGNED_BYTE;\r\n break;\r\n default:\r\n if (!buffer) {\r\n buffer = new Float32Array(4 * width * height);\r\n }\r\n readType = gl.FLOAT;\r\n break;\r\n }\r\n gl.readPixels(0, 0, width, height, gl.RGBA, readType, buffer);\r\n gl.bindFramebuffer(gl.FRAMEBUFFER, this._currentFramebuffer);\r\n return buffer;\r\n};\r\n//# sourceMappingURL=engine.readTexture.js.map","import { ThinEngine } from \"../../Engines/thinEngine\";\r\nThinEngine.prototype.updateDynamicIndexBuffer = function (indexBuffer, indices, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n // Force cache update\r\n this._currentBoundBuffer[this._gl.ELEMENT_ARRAY_BUFFER] = null;\r\n this.bindIndexBuffer(indexBuffer);\r\n var arrayBuffer;\r\n if (indices instanceof Uint16Array || indices instanceof Uint32Array) {\r\n arrayBuffer = indices;\r\n }\r\n else {\r\n arrayBuffer = indexBuffer.is32Bits ? new Uint32Array(indices) : new Uint16Array(indices);\r\n }\r\n this._gl.bufferData(this._gl.ELEMENT_ARRAY_BUFFER, arrayBuffer, this._gl.DYNAMIC_DRAW);\r\n this._resetIndexBufferBinding();\r\n};\r\nThinEngine.prototype.updateDynamicVertexBuffer = function (vertexBuffer, data, byteOffset, byteLength) {\r\n this.bindArrayBuffer(vertexBuffer);\r\n if (byteOffset === undefined) {\r\n byteOffset = 0;\r\n }\r\n var dataLength = data.length || data.byteLength;\r\n if (byteLength === undefined || byteLength >= dataLength && byteOffset === 0) {\r\n if (data instanceof Array) {\r\n this._gl.bufferSubData(this._gl.ARRAY_BUFFER, byteOffset, new Float32Array(data));\r\n }\r\n else {\r\n this._gl.bufferSubData(this._gl.ARRAY_BUFFER, byteOffset, data);\r\n }\r\n }\r\n else {\r\n if (data instanceof Array) {\r\n this._gl.bufferSubData(this._gl.ARRAY_BUFFER, 0, new Float32Array(data).subarray(byteOffset, byteOffset + byteLength));\r\n }\r\n else {\r\n if (data instanceof ArrayBuffer) {\r\n data = new Uint8Array(data, byteOffset, byteLength);\r\n }\r\n else {\r\n data = new Uint8Array(data.buffer, data.byteOffset + byteOffset, byteLength);\r\n }\r\n this._gl.bufferSubData(this._gl.ARRAY_BUFFER, 0, data);\r\n }\r\n }\r\n this._resetVertexBufferBinding();\r\n};\r\n//# sourceMappingURL=engine.dynamicBuffer.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { DomManagement } from \"../Misc/domManagement\";\r\nimport { EngineStore } from \"./engineStore\";\r\nimport { _DevTools } from '../Misc/devTools';\r\nimport { ThinEngine } from './thinEngine';\r\nimport { PerformanceMonitor } from '../Misc/performanceMonitor';\r\nimport { PerfCounter } from '../Misc/perfCounter';\r\nimport { WebGLDataBuffer } from '../Meshes/WebGL/webGLDataBuffer';\r\nimport { Logger } from '../Misc/logger';\r\nimport \"./Extensions/engine.alpha\";\r\nimport \"./Extensions/engine.readTexture\";\r\nimport \"./Extensions/engine.dynamicBuffer\";\r\n/**\r\n * The engine class is responsible for interfacing with all lower-level APIs such as WebGL and Audio\r\n */\r\nvar Engine = /** @class */ (function (_super) {\r\n __extends(Engine, _super);\r\n /**\r\n * Creates a new engine\r\n * @param canvasOrContext defines the canvas or WebGL context to use for rendering. If you provide a WebGL context, Babylon.js will not hook events on the canvas (like pointers, keyboards, etc...) so no event observables will be available. This is mostly used when Babylon.js is used as a plugin on a system which alreay used the WebGL context\r\n * @param antialias defines enable antialiasing (default: false)\r\n * @param options defines further options to be sent to the getContext() function\r\n * @param adaptToDeviceRatio defines whether to adapt to the device's viewport characteristics (default: false)\r\n */\r\n function Engine(canvasOrContext, antialias, options, adaptToDeviceRatio) {\r\n if (adaptToDeviceRatio === void 0) { adaptToDeviceRatio = false; }\r\n var _this = _super.call(this, canvasOrContext, antialias, options, adaptToDeviceRatio) || this;\r\n // Members\r\n /**\r\n * Gets or sets a boolean to enable/disable IndexedDB support and avoid XHR on .manifest\r\n **/\r\n _this.enableOfflineSupport = false;\r\n /**\r\n * Gets or sets a boolean to enable/disable checking manifest if IndexedDB support is enabled (js will always consider the database is up to date)\r\n **/\r\n _this.disableManifestCheck = false;\r\n /**\r\n * Gets the list of created scenes\r\n */\r\n _this.scenes = new Array();\r\n /**\r\n * Event raised when a new scene is created\r\n */\r\n _this.onNewSceneAddedObservable = new Observable();\r\n /**\r\n * Gets the list of created postprocesses\r\n */\r\n _this.postProcesses = new Array();\r\n /**\r\n * Gets a boolean indicating if the pointer is currently locked\r\n */\r\n _this.isPointerLock = false;\r\n // Observables\r\n /**\r\n * Observable event triggered each time the rendering canvas is resized\r\n */\r\n _this.onResizeObservable = new Observable();\r\n /**\r\n * Observable event triggered each time the canvas loses focus\r\n */\r\n _this.onCanvasBlurObservable = new Observable();\r\n /**\r\n * Observable event triggered each time the canvas gains focus\r\n */\r\n _this.onCanvasFocusObservable = new Observable();\r\n /**\r\n * Observable event triggered each time the canvas receives pointerout event\r\n */\r\n _this.onCanvasPointerOutObservable = new Observable();\r\n /**\r\n * Observable raised when the engine begins a new frame\r\n */\r\n _this.onBeginFrameObservable = new Observable();\r\n /**\r\n * If set, will be used to request the next animation frame for the render loop\r\n */\r\n _this.customAnimationFrameRequester = null;\r\n /**\r\n * Observable raised when the engine ends the current frame\r\n */\r\n _this.onEndFrameObservable = new Observable();\r\n /**\r\n * Observable raised when the engine is about to compile a shader\r\n */\r\n _this.onBeforeShaderCompilationObservable = new Observable();\r\n /**\r\n * Observable raised when the engine has jsut compiled a shader\r\n */\r\n _this.onAfterShaderCompilationObservable = new Observable();\r\n // Deterministic lockstepMaxSteps\r\n _this._deterministicLockstep = false;\r\n _this._lockstepMaxSteps = 4;\r\n _this._timeStep = 1 / 60;\r\n // FPS\r\n _this._fps = 60;\r\n _this._deltaTime = 0;\r\n /** @hidden */\r\n _this._drawCalls = new PerfCounter();\r\n /** Gets or sets the tab index to set to the rendering canvas. 1 is the minimum value to set to be able to capture keyboard events */\r\n _this.canvasTabIndex = 1;\r\n /**\r\n * Turn this value on if you want to pause FPS computation when in background\r\n */\r\n _this.disablePerformanceMonitorInBackground = false;\r\n _this._performanceMonitor = new PerformanceMonitor();\r\n Engine.Instances.push(_this);\r\n if (!canvasOrContext) {\r\n return _this;\r\n }\r\n options = _this._creationOptions;\r\n if (canvasOrContext.getContext) {\r\n var canvas_1 = canvasOrContext;\r\n _this._onCanvasFocus = function () {\r\n _this.onCanvasFocusObservable.notifyObservers(_this);\r\n };\r\n _this._onCanvasBlur = function () {\r\n _this.onCanvasBlurObservable.notifyObservers(_this);\r\n };\r\n canvas_1.addEventListener(\"focus\", _this._onCanvasFocus);\r\n canvas_1.addEventListener(\"blur\", _this._onCanvasBlur);\r\n _this._onBlur = function () {\r\n if (_this.disablePerformanceMonitorInBackground) {\r\n _this._performanceMonitor.disable();\r\n }\r\n _this._windowIsBackground = true;\r\n };\r\n _this._onFocus = function () {\r\n if (_this.disablePerformanceMonitorInBackground) {\r\n _this._performanceMonitor.enable();\r\n }\r\n _this._windowIsBackground = false;\r\n };\r\n _this._onCanvasPointerOut = function (ev) {\r\n _this.onCanvasPointerOutObservable.notifyObservers(ev);\r\n };\r\n canvas_1.addEventListener(\"pointerout\", _this._onCanvasPointerOut);\r\n if (DomManagement.IsWindowObjectExist()) {\r\n var hostWindow = _this.getHostWindow();\r\n hostWindow.addEventListener(\"blur\", _this._onBlur);\r\n hostWindow.addEventListener(\"focus\", _this._onFocus);\r\n var anyDoc_1 = document;\r\n // Fullscreen\r\n _this._onFullscreenChange = function () {\r\n if (anyDoc_1.fullscreen !== undefined) {\r\n _this.isFullscreen = anyDoc_1.fullscreen;\r\n }\r\n else if (anyDoc_1.mozFullScreen !== undefined) {\r\n _this.isFullscreen = anyDoc_1.mozFullScreen;\r\n }\r\n else if (anyDoc_1.webkitIsFullScreen !== undefined) {\r\n _this.isFullscreen = anyDoc_1.webkitIsFullScreen;\r\n }\r\n else if (anyDoc_1.msIsFullScreen !== undefined) {\r\n _this.isFullscreen = anyDoc_1.msIsFullScreen;\r\n }\r\n // Pointer lock\r\n if (_this.isFullscreen && _this._pointerLockRequested && canvas_1) {\r\n Engine._RequestPointerlock(canvas_1);\r\n }\r\n };\r\n document.addEventListener(\"fullscreenchange\", _this._onFullscreenChange, false);\r\n document.addEventListener(\"mozfullscreenchange\", _this._onFullscreenChange, false);\r\n document.addEventListener(\"webkitfullscreenchange\", _this._onFullscreenChange, false);\r\n document.addEventListener(\"msfullscreenchange\", _this._onFullscreenChange, false);\r\n // Pointer lock\r\n _this._onPointerLockChange = function () {\r\n _this.isPointerLock = (anyDoc_1.mozPointerLockElement === canvas_1 ||\r\n anyDoc_1.webkitPointerLockElement === canvas_1 ||\r\n anyDoc_1.msPointerLockElement === canvas_1 ||\r\n anyDoc_1.pointerLockElement === canvas_1);\r\n };\r\n document.addEventListener(\"pointerlockchange\", _this._onPointerLockChange, false);\r\n document.addEventListener(\"mspointerlockchange\", _this._onPointerLockChange, false);\r\n document.addEventListener(\"mozpointerlockchange\", _this._onPointerLockChange, false);\r\n document.addEventListener(\"webkitpointerlockchange\", _this._onPointerLockChange, false);\r\n // Create Audio Engine if needed.\r\n if (!Engine.audioEngine && options.audioEngine && Engine.AudioEngineFactory) {\r\n Engine.audioEngine = Engine.AudioEngineFactory(_this.getRenderingCanvas());\r\n }\r\n }\r\n _this._connectVREvents();\r\n _this.enableOfflineSupport = Engine.OfflineProviderFactory !== undefined;\r\n if (!options.doNotHandleTouchAction) {\r\n _this._disableTouchAction();\r\n }\r\n _this._deterministicLockstep = !!options.deterministicLockstep;\r\n _this._lockstepMaxSteps = options.lockstepMaxSteps || 0;\r\n _this._timeStep = options.timeStep || 1 / 60;\r\n }\r\n // Load WebVR Devices\r\n _this._prepareVRComponent();\r\n if (options.autoEnableWebVR) {\r\n _this.initWebVR();\r\n }\r\n return _this;\r\n }\r\n Object.defineProperty(Engine, \"NpmPackage\", {\r\n /**\r\n * Returns the current npm package of the sdk\r\n */\r\n // Not mixed with Version for tooling purpose.\r\n get: function () {\r\n return ThinEngine.NpmPackage;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Engine, \"Version\", {\r\n /**\r\n * Returns the current version of the framework\r\n */\r\n get: function () {\r\n return ThinEngine.Version;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Engine, \"Instances\", {\r\n /** Gets the list of created engines */\r\n get: function () {\r\n return EngineStore.Instances;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Engine, \"LastCreatedEngine\", {\r\n /**\r\n * Gets the latest created engine\r\n */\r\n get: function () {\r\n return EngineStore.LastCreatedEngine;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Engine, \"LastCreatedScene\", {\r\n /**\r\n * Gets the latest created scene\r\n */\r\n get: function () {\r\n return EngineStore.LastCreatedScene;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Will flag all materials in all scenes in all engines as dirty to trigger new shader compilation\r\n * @param flag defines which part of the materials must be marked as dirty\r\n * @param predicate defines a predicate used to filter which materials should be affected\r\n */\r\n Engine.MarkAllMaterialsAsDirty = function (flag, predicate) {\r\n for (var engineIndex = 0; engineIndex < Engine.Instances.length; engineIndex++) {\r\n var engine = Engine.Instances[engineIndex];\r\n for (var sceneIndex = 0; sceneIndex < engine.scenes.length; sceneIndex++) {\r\n engine.scenes[sceneIndex].markAllMaterialsAsDirty(flag, predicate);\r\n }\r\n }\r\n };\r\n /**\r\n * Method called to create the default loading screen.\r\n * This can be overriden in your own app.\r\n * @param canvas The rendering canvas element\r\n * @returns The loading screen\r\n */\r\n Engine.DefaultLoadingScreenFactory = function (canvas) {\r\n throw _DevTools.WarnImport(\"LoadingScreen\");\r\n };\r\n Object.defineProperty(Engine.prototype, \"_supportsHardwareTextureRescaling\", {\r\n get: function () {\r\n return !!Engine._RescalePostProcessFactory;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Engine.prototype, \"performanceMonitor\", {\r\n /**\r\n * Gets the performance monitor attached to this engine\r\n * @see https://doc.babylonjs.com/how_to/optimizing_your_scene#engineinstrumentation\r\n */\r\n get: function () {\r\n return this._performanceMonitor;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n // Events\r\n /**\r\n * Gets the HTML element used to attach event listeners\r\n * @returns a HTML element\r\n */\r\n Engine.prototype.getInputElement = function () {\r\n return this._renderingCanvas;\r\n };\r\n /**\r\n * Gets current aspect ratio\r\n * @param viewportOwner defines the camera to use to get the aspect ratio\r\n * @param useScreen defines if screen size must be used (or the current render target if any)\r\n * @returns a number defining the aspect ratio\r\n */\r\n Engine.prototype.getAspectRatio = function (viewportOwner, useScreen) {\r\n if (useScreen === void 0) { useScreen = false; }\r\n var viewport = viewportOwner.viewport;\r\n return (this.getRenderWidth(useScreen) * viewport.width) / (this.getRenderHeight(useScreen) * viewport.height);\r\n };\r\n /**\r\n * Gets current screen aspect ratio\r\n * @returns a number defining the aspect ratio\r\n */\r\n Engine.prototype.getScreenAspectRatio = function () {\r\n return (this.getRenderWidth(true)) / (this.getRenderHeight(true));\r\n };\r\n /**\r\n * Gets the client rect of the HTML canvas attached with the current webGL context\r\n * @returns a client rectanglee\r\n */\r\n Engine.prototype.getRenderingCanvasClientRect = function () {\r\n if (!this._renderingCanvas) {\r\n return null;\r\n }\r\n return this._renderingCanvas.getBoundingClientRect();\r\n };\r\n /**\r\n * Gets the client rect of the HTML element used for events\r\n * @returns a client rectanglee\r\n */\r\n Engine.prototype.getInputElementClientRect = function () {\r\n if (!this._renderingCanvas) {\r\n return null;\r\n }\r\n return this.getInputElement().getBoundingClientRect();\r\n };\r\n /**\r\n * Gets a boolean indicating that the engine is running in deterministic lock step mode\r\n * @see https://doc.babylonjs.com/babylon101/animations#deterministic-lockstep\r\n * @returns true if engine is in deterministic lock step mode\r\n */\r\n Engine.prototype.isDeterministicLockStep = function () {\r\n return this._deterministicLockstep;\r\n };\r\n /**\r\n * Gets the max steps when engine is running in deterministic lock step\r\n * @see https://doc.babylonjs.com/babylon101/animations#deterministic-lockstep\r\n * @returns the max steps\r\n */\r\n Engine.prototype.getLockstepMaxSteps = function () {\r\n return this._lockstepMaxSteps;\r\n };\r\n /**\r\n * Returns the time in ms between steps when using deterministic lock step.\r\n * @returns time step in (ms)\r\n */\r\n Engine.prototype.getTimeStep = function () {\r\n return this._timeStep * 1000;\r\n };\r\n /**\r\n * Force the mipmap generation for the given render target texture\r\n * @param texture defines the render target texture to use\r\n * @param unbind defines whether or not to unbind the texture after generation. Defaults to true.\r\n */\r\n Engine.prototype.generateMipMapsForCubemap = function (texture, unbind) {\r\n if (unbind === void 0) { unbind = true; }\r\n if (texture.generateMipMaps) {\r\n var gl = this._gl;\r\n this._bindTextureDirectly(gl.TEXTURE_CUBE_MAP, texture, true);\r\n gl.generateMipmap(gl.TEXTURE_CUBE_MAP);\r\n if (unbind) {\r\n this._bindTextureDirectly(gl.TEXTURE_CUBE_MAP, null);\r\n }\r\n }\r\n };\r\n /** States */\r\n /**\r\n * Set various states to the webGL context\r\n * @param culling defines backface culling state\r\n * @param zOffset defines the value to apply to zOffset (0 by default)\r\n * @param force defines if states must be applied even if cache is up to date\r\n * @param reverseSide defines if culling must be reversed (CCW instead of CW and CW instead of CCW)\r\n */\r\n Engine.prototype.setState = function (culling, zOffset, force, reverseSide) {\r\n if (zOffset === void 0) { zOffset = 0; }\r\n if (reverseSide === void 0) { reverseSide = false; }\r\n // Culling\r\n if (this._depthCullingState.cull !== culling || force) {\r\n this._depthCullingState.cull = culling;\r\n }\r\n // Cull face\r\n var cullFace = this.cullBackFaces ? this._gl.BACK : this._gl.FRONT;\r\n if (this._depthCullingState.cullFace !== cullFace || force) {\r\n this._depthCullingState.cullFace = cullFace;\r\n }\r\n // Z offset\r\n this.setZOffset(zOffset);\r\n // Front face\r\n var frontFace = reverseSide ? this._gl.CW : this._gl.CCW;\r\n if (this._depthCullingState.frontFace !== frontFace || force) {\r\n this._depthCullingState.frontFace = frontFace;\r\n }\r\n };\r\n /**\r\n * Set the z offset to apply to current rendering\r\n * @param value defines the offset to apply\r\n */\r\n Engine.prototype.setZOffset = function (value) {\r\n this._depthCullingState.zOffset = value;\r\n };\r\n /**\r\n * Gets the current value of the zOffset\r\n * @returns the current zOffset state\r\n */\r\n Engine.prototype.getZOffset = function () {\r\n return this._depthCullingState.zOffset;\r\n };\r\n /**\r\n * Enable or disable depth buffering\r\n * @param enable defines the state to set\r\n */\r\n Engine.prototype.setDepthBuffer = function (enable) {\r\n this._depthCullingState.depthTest = enable;\r\n };\r\n /**\r\n * Gets a boolean indicating if depth writing is enabled\r\n * @returns the current depth writing state\r\n */\r\n Engine.prototype.getDepthWrite = function () {\r\n return this._depthCullingState.depthMask;\r\n };\r\n /**\r\n * Enable or disable depth writing\r\n * @param enable defines the state to set\r\n */\r\n Engine.prototype.setDepthWrite = function (enable) {\r\n this._depthCullingState.depthMask = enable;\r\n };\r\n /**\r\n * Gets a boolean indicating if stencil buffer is enabled\r\n * @returns the current stencil buffer state\r\n */\r\n Engine.prototype.getStencilBuffer = function () {\r\n return this._stencilState.stencilTest;\r\n };\r\n /**\r\n * Enable or disable the stencil buffer\r\n * @param enable defines if the stencil buffer must be enabled or disabled\r\n */\r\n Engine.prototype.setStencilBuffer = function (enable) {\r\n this._stencilState.stencilTest = enable;\r\n };\r\n /**\r\n * Gets the current stencil mask\r\n * @returns a number defining the new stencil mask to use\r\n */\r\n Engine.prototype.getStencilMask = function () {\r\n return this._stencilState.stencilMask;\r\n };\r\n /**\r\n * Sets the current stencil mask\r\n * @param mask defines the new stencil mask to use\r\n */\r\n Engine.prototype.setStencilMask = function (mask) {\r\n this._stencilState.stencilMask = mask;\r\n };\r\n /**\r\n * Gets the current stencil function\r\n * @returns a number defining the stencil function to use\r\n */\r\n Engine.prototype.getStencilFunction = function () {\r\n return this._stencilState.stencilFunc;\r\n };\r\n /**\r\n * Gets the current stencil reference value\r\n * @returns a number defining the stencil reference value to use\r\n */\r\n Engine.prototype.getStencilFunctionReference = function () {\r\n return this._stencilState.stencilFuncRef;\r\n };\r\n /**\r\n * Gets the current stencil mask\r\n * @returns a number defining the stencil mask to use\r\n */\r\n Engine.prototype.getStencilFunctionMask = function () {\r\n return this._stencilState.stencilFuncMask;\r\n };\r\n /**\r\n * Sets the current stencil function\r\n * @param stencilFunc defines the new stencil function to use\r\n */\r\n Engine.prototype.setStencilFunction = function (stencilFunc) {\r\n this._stencilState.stencilFunc = stencilFunc;\r\n };\r\n /**\r\n * Sets the current stencil reference\r\n * @param reference defines the new stencil reference to use\r\n */\r\n Engine.prototype.setStencilFunctionReference = function (reference) {\r\n this._stencilState.stencilFuncRef = reference;\r\n };\r\n /**\r\n * Sets the current stencil mask\r\n * @param mask defines the new stencil mask to use\r\n */\r\n Engine.prototype.setStencilFunctionMask = function (mask) {\r\n this._stencilState.stencilFuncMask = mask;\r\n };\r\n /**\r\n * Gets the current stencil operation when stencil fails\r\n * @returns a number defining stencil operation to use when stencil fails\r\n */\r\n Engine.prototype.getStencilOperationFail = function () {\r\n return this._stencilState.stencilOpStencilFail;\r\n };\r\n /**\r\n * Gets the current stencil operation when depth fails\r\n * @returns a number defining stencil operation to use when depth fails\r\n */\r\n Engine.prototype.getStencilOperationDepthFail = function () {\r\n return this._stencilState.stencilOpDepthFail;\r\n };\r\n /**\r\n * Gets the current stencil operation when stencil passes\r\n * @returns a number defining stencil operation to use when stencil passes\r\n */\r\n Engine.prototype.getStencilOperationPass = function () {\r\n return this._stencilState.stencilOpStencilDepthPass;\r\n };\r\n /**\r\n * Sets the stencil operation to use when stencil fails\r\n * @param operation defines the stencil operation to use when stencil fails\r\n */\r\n Engine.prototype.setStencilOperationFail = function (operation) {\r\n this._stencilState.stencilOpStencilFail = operation;\r\n };\r\n /**\r\n * Sets the stencil operation to use when depth fails\r\n * @param operation defines the stencil operation to use when depth fails\r\n */\r\n Engine.prototype.setStencilOperationDepthFail = function (operation) {\r\n this._stencilState.stencilOpDepthFail = operation;\r\n };\r\n /**\r\n * Sets the stencil operation to use when stencil passes\r\n * @param operation defines the stencil operation to use when stencil passes\r\n */\r\n Engine.prototype.setStencilOperationPass = function (operation) {\r\n this._stencilState.stencilOpStencilDepthPass = operation;\r\n };\r\n /**\r\n * Sets a boolean indicating if the dithering state is enabled or disabled\r\n * @param value defines the dithering state\r\n */\r\n Engine.prototype.setDitheringState = function (value) {\r\n if (value) {\r\n this._gl.enable(this._gl.DITHER);\r\n }\r\n else {\r\n this._gl.disable(this._gl.DITHER);\r\n }\r\n };\r\n /**\r\n * Sets a boolean indicating if the rasterizer state is enabled or disabled\r\n * @param value defines the rasterizer state\r\n */\r\n Engine.prototype.setRasterizerState = function (value) {\r\n if (value) {\r\n this._gl.disable(this._gl.RASTERIZER_DISCARD);\r\n }\r\n else {\r\n this._gl.enable(this._gl.RASTERIZER_DISCARD);\r\n }\r\n };\r\n /**\r\n * Gets the current depth function\r\n * @returns a number defining the depth function\r\n */\r\n Engine.prototype.getDepthFunction = function () {\r\n return this._depthCullingState.depthFunc;\r\n };\r\n /**\r\n * Sets the current depth function\r\n * @param depthFunc defines the function to use\r\n */\r\n Engine.prototype.setDepthFunction = function (depthFunc) {\r\n this._depthCullingState.depthFunc = depthFunc;\r\n };\r\n /**\r\n * Sets the current depth function to GREATER\r\n */\r\n Engine.prototype.setDepthFunctionToGreater = function () {\r\n this._depthCullingState.depthFunc = this._gl.GREATER;\r\n };\r\n /**\r\n * Sets the current depth function to GEQUAL\r\n */\r\n Engine.prototype.setDepthFunctionToGreaterOrEqual = function () {\r\n this._depthCullingState.depthFunc = this._gl.GEQUAL;\r\n };\r\n /**\r\n * Sets the current depth function to LESS\r\n */\r\n Engine.prototype.setDepthFunctionToLess = function () {\r\n this._depthCullingState.depthFunc = this._gl.LESS;\r\n };\r\n /**\r\n * Sets the current depth function to LEQUAL\r\n */\r\n Engine.prototype.setDepthFunctionToLessOrEqual = function () {\r\n this._depthCullingState.depthFunc = this._gl.LEQUAL;\r\n };\r\n /**\r\n * Caches the the state of the stencil buffer\r\n */\r\n Engine.prototype.cacheStencilState = function () {\r\n this._cachedStencilBuffer = this.getStencilBuffer();\r\n this._cachedStencilFunction = this.getStencilFunction();\r\n this._cachedStencilMask = this.getStencilMask();\r\n this._cachedStencilOperationPass = this.getStencilOperationPass();\r\n this._cachedStencilOperationFail = this.getStencilOperationFail();\r\n this._cachedStencilOperationDepthFail = this.getStencilOperationDepthFail();\r\n this._cachedStencilReference = this.getStencilFunctionReference();\r\n };\r\n /**\r\n * Restores the state of the stencil buffer\r\n */\r\n Engine.prototype.restoreStencilState = function () {\r\n this.setStencilFunction(this._cachedStencilFunction);\r\n this.setStencilMask(this._cachedStencilMask);\r\n this.setStencilBuffer(this._cachedStencilBuffer);\r\n this.setStencilOperationPass(this._cachedStencilOperationPass);\r\n this.setStencilOperationFail(this._cachedStencilOperationFail);\r\n this.setStencilOperationDepthFail(this._cachedStencilOperationDepthFail);\r\n this.setStencilFunctionReference(this._cachedStencilReference);\r\n };\r\n /**\r\n * Directly set the WebGL Viewport\r\n * @param x defines the x coordinate of the viewport (in screen space)\r\n * @param y defines the y coordinate of the viewport (in screen space)\r\n * @param width defines the width of the viewport (in screen space)\r\n * @param height defines the height of the viewport (in screen space)\r\n * @return the current viewport Object (if any) that is being replaced by this call. You can restore this viewport later on to go back to the original state\r\n */\r\n Engine.prototype.setDirectViewport = function (x, y, width, height) {\r\n var currentViewport = this._cachedViewport;\r\n this._cachedViewport = null;\r\n this._viewport(x, y, width, height);\r\n return currentViewport;\r\n };\r\n /**\r\n * Executes a scissor clear (ie. a clear on a specific portion of the screen)\r\n * @param x defines the x-coordinate of the top left corner of the clear rectangle\r\n * @param y defines the y-coordinate of the corner of the clear rectangle\r\n * @param width defines the width of the clear rectangle\r\n * @param height defines the height of the clear rectangle\r\n * @param clearColor defines the clear color\r\n */\r\n Engine.prototype.scissorClear = function (x, y, width, height, clearColor) {\r\n this.enableScissor(x, y, width, height);\r\n this.clear(clearColor, true, true, true);\r\n this.disableScissor();\r\n };\r\n /**\r\n * Enable scissor test on a specific rectangle (ie. render will only be executed on a specific portion of the screen)\r\n * @param x defines the x-coordinate of the top left corner of the clear rectangle\r\n * @param y defines the y-coordinate of the corner of the clear rectangle\r\n * @param width defines the width of the clear rectangle\r\n * @param height defines the height of the clear rectangle\r\n */\r\n Engine.prototype.enableScissor = function (x, y, width, height) {\r\n var gl = this._gl;\r\n // Change state\r\n gl.enable(gl.SCISSOR_TEST);\r\n gl.scissor(x, y, width, height);\r\n };\r\n /**\r\n * Disable previously set scissor test rectangle\r\n */\r\n Engine.prototype.disableScissor = function () {\r\n var gl = this._gl;\r\n gl.disable(gl.SCISSOR_TEST);\r\n };\r\n Engine.prototype._reportDrawCall = function () {\r\n this._drawCalls.addCount(1, false);\r\n };\r\n /**\r\n * Initializes a webVR display and starts listening to display change events\r\n * The onVRDisplayChangedObservable will be notified upon these changes\r\n * @returns The onVRDisplayChangedObservable\r\n */\r\n Engine.prototype.initWebVR = function () {\r\n throw _DevTools.WarnImport(\"WebVRCamera\");\r\n };\r\n /** @hidden */\r\n Engine.prototype._prepareVRComponent = function () {\r\n // Do nothing as the engine side effect will overload it\r\n };\r\n /** @hidden */\r\n Engine.prototype._connectVREvents = function (canvas, document) {\r\n // Do nothing as the engine side effect will overload it\r\n };\r\n /** @hidden */\r\n Engine.prototype._submitVRFrame = function () {\r\n // Do nothing as the engine side effect will overload it\r\n };\r\n /**\r\n * Call this function to leave webVR mode\r\n * Will do nothing if webVR is not supported or if there is no webVR device\r\n * @see https://doc.babylonjs.com/how_to/webvr_camera\r\n */\r\n Engine.prototype.disableVR = function () {\r\n // Do nothing as the engine side effect will overload it\r\n };\r\n /**\r\n * Gets a boolean indicating that the system is in VR mode and is presenting\r\n * @returns true if VR mode is engaged\r\n */\r\n Engine.prototype.isVRPresenting = function () {\r\n return false;\r\n };\r\n /** @hidden */\r\n Engine.prototype._requestVRFrame = function () {\r\n // Do nothing as the engine side effect will overload it\r\n };\r\n /** @hidden */\r\n Engine.prototype._loadFileAsync = function (url, offlineProvider, useArrayBuffer) {\r\n var _this = this;\r\n return new Promise(function (resolve, reject) {\r\n _this._loadFile(url, function (data) {\r\n resolve(data);\r\n }, undefined, offlineProvider, useArrayBuffer, function (request, exception) {\r\n reject(exception);\r\n });\r\n });\r\n };\r\n /**\r\n * Gets the source code of the vertex shader associated with a specific webGL program\r\n * @param program defines the program to use\r\n * @returns a string containing the source code of the vertex shader associated with the program\r\n */\r\n Engine.prototype.getVertexShaderSource = function (program) {\r\n var shaders = this._gl.getAttachedShaders(program);\r\n if (!shaders) {\r\n return null;\r\n }\r\n return this._gl.getShaderSource(shaders[0]);\r\n };\r\n /**\r\n * Gets the source code of the fragment shader associated with a specific webGL program\r\n * @param program defines the program to use\r\n * @returns a string containing the source code of the fragment shader associated with the program\r\n */\r\n Engine.prototype.getFragmentShaderSource = function (program) {\r\n var shaders = this._gl.getAttachedShaders(program);\r\n if (!shaders) {\r\n return null;\r\n }\r\n return this._gl.getShaderSource(shaders[1]);\r\n };\r\n /**\r\n * Sets a depth stencil texture from a render target to the according uniform.\r\n * @param channel The texture channel\r\n * @param uniform The uniform to set\r\n * @param texture The render target texture containing the depth stencil texture to apply\r\n */\r\n Engine.prototype.setDepthStencilTexture = function (channel, uniform, texture) {\r\n if (channel === undefined) {\r\n return;\r\n }\r\n if (uniform) {\r\n this._boundUniforms[channel] = uniform;\r\n }\r\n if (!texture || !texture.depthStencilTexture) {\r\n this._setTexture(channel, null);\r\n }\r\n else {\r\n this._setTexture(channel, texture, false, true);\r\n }\r\n };\r\n /**\r\n * Sets a texture to the webGL context from a postprocess\r\n * @param channel defines the channel to use\r\n * @param postProcess defines the source postprocess\r\n */\r\n Engine.prototype.setTextureFromPostProcess = function (channel, postProcess) {\r\n this._bindTexture(channel, postProcess ? postProcess._textures.data[postProcess._currentRenderTextureInd] : null);\r\n };\r\n /**\r\n * Binds the output of the passed in post process to the texture channel specified\r\n * @param channel The channel the texture should be bound to\r\n * @param postProcess The post process which's output should be bound\r\n */\r\n Engine.prototype.setTextureFromPostProcessOutput = function (channel, postProcess) {\r\n this._bindTexture(channel, postProcess ? postProcess._outputTexture : null);\r\n };\r\n Engine.prototype._rebuildBuffers = function () {\r\n // Index / Vertex\r\n for (var _i = 0, _a = this.scenes; _i < _a.length; _i++) {\r\n var scene = _a[_i];\r\n scene.resetCachedMaterial();\r\n scene._rebuildGeometries();\r\n scene._rebuildTextures();\r\n }\r\n _super.prototype._rebuildBuffers.call(this);\r\n };\r\n /** @hidden */\r\n Engine.prototype._renderFrame = function () {\r\n for (var index = 0; index < this._activeRenderLoops.length; index++) {\r\n var renderFunction = this._activeRenderLoops[index];\r\n renderFunction();\r\n }\r\n };\r\n Engine.prototype._renderLoop = function () {\r\n if (!this._contextWasLost) {\r\n var shouldRender = true;\r\n if (!this.renderEvenInBackground && this._windowIsBackground) {\r\n shouldRender = false;\r\n }\r\n if (shouldRender) {\r\n // Start new frame\r\n this.beginFrame();\r\n // Child canvases\r\n if (!this._renderViews()) {\r\n // Main frame\r\n this._renderFrame();\r\n }\r\n // Present\r\n this.endFrame();\r\n }\r\n }\r\n if (this._activeRenderLoops.length > 0) {\r\n // Register new frame\r\n if (this.customAnimationFrameRequester) {\r\n this.customAnimationFrameRequester.requestID = this._queueNewFrame(this.customAnimationFrameRequester.renderFunction || this._boundRenderFunction, this.customAnimationFrameRequester);\r\n this._frameHandler = this.customAnimationFrameRequester.requestID;\r\n }\r\n else if (this.isVRPresenting()) {\r\n this._requestVRFrame();\r\n }\r\n else {\r\n this._frameHandler = this._queueNewFrame(this._boundRenderFunction, this.getHostWindow());\r\n }\r\n }\r\n else {\r\n this._renderingQueueLaunched = false;\r\n }\r\n };\r\n /** @hidden */\r\n Engine.prototype._renderViews = function () {\r\n return false;\r\n };\r\n /**\r\n * Toggle full screen mode\r\n * @param requestPointerLock defines if a pointer lock should be requested from the user\r\n */\r\n Engine.prototype.switchFullscreen = function (requestPointerLock) {\r\n if (this.isFullscreen) {\r\n this.exitFullscreen();\r\n }\r\n else {\r\n this.enterFullscreen(requestPointerLock);\r\n }\r\n };\r\n /**\r\n * Enters full screen mode\r\n * @param requestPointerLock defines if a pointer lock should be requested from the user\r\n */\r\n Engine.prototype.enterFullscreen = function (requestPointerLock) {\r\n if (!this.isFullscreen) {\r\n this._pointerLockRequested = requestPointerLock;\r\n if (this._renderingCanvas) {\r\n Engine._RequestFullscreen(this._renderingCanvas);\r\n }\r\n }\r\n };\r\n /**\r\n * Exits full screen mode\r\n */\r\n Engine.prototype.exitFullscreen = function () {\r\n if (this.isFullscreen) {\r\n Engine._ExitFullscreen();\r\n }\r\n };\r\n /**\r\n * Enters Pointerlock mode\r\n */\r\n Engine.prototype.enterPointerlock = function () {\r\n if (this._renderingCanvas) {\r\n Engine._RequestPointerlock(this._renderingCanvas);\r\n }\r\n };\r\n /**\r\n * Exits Pointerlock mode\r\n */\r\n Engine.prototype.exitPointerlock = function () {\r\n Engine._ExitPointerlock();\r\n };\r\n /**\r\n * Begin a new frame\r\n */\r\n Engine.prototype.beginFrame = function () {\r\n this._measureFps();\r\n this.onBeginFrameObservable.notifyObservers(this);\r\n _super.prototype.beginFrame.call(this);\r\n };\r\n /**\r\n * Enf the current frame\r\n */\r\n Engine.prototype.endFrame = function () {\r\n _super.prototype.endFrame.call(this);\r\n this._submitVRFrame();\r\n this.onEndFrameObservable.notifyObservers(this);\r\n };\r\n Engine.prototype.resize = function () {\r\n // We're not resizing the size of the canvas while in VR mode & presenting\r\n if (this.isVRPresenting()) {\r\n return;\r\n }\r\n _super.prototype.resize.call(this);\r\n };\r\n /**\r\n * Force a specific size of the canvas\r\n * @param width defines the new canvas' width\r\n * @param height defines the new canvas' height\r\n * @returns true if the size was changed\r\n */\r\n Engine.prototype.setSize = function (width, height) {\r\n if (!this._renderingCanvas) {\r\n return false;\r\n }\r\n if (!_super.prototype.setSize.call(this, width, height)) {\r\n return false;\r\n }\r\n if (this.scenes) {\r\n for (var index = 0; index < this.scenes.length; index++) {\r\n var scene = this.scenes[index];\r\n for (var camIndex = 0; camIndex < scene.cameras.length; camIndex++) {\r\n var cam = scene.cameras[camIndex];\r\n cam._currentRenderId = 0;\r\n }\r\n }\r\n if (this.onResizeObservable.hasObservers()) {\r\n this.onResizeObservable.notifyObservers(this);\r\n }\r\n }\r\n return true;\r\n };\r\n Engine.prototype._deletePipelineContext = function (pipelineContext) {\r\n var webGLPipelineContext = pipelineContext;\r\n if (webGLPipelineContext && webGLPipelineContext.program) {\r\n if (webGLPipelineContext.transformFeedback) {\r\n this.deleteTransformFeedback(webGLPipelineContext.transformFeedback);\r\n webGLPipelineContext.transformFeedback = null;\r\n }\r\n }\r\n _super.prototype._deletePipelineContext.call(this, pipelineContext);\r\n };\r\n Engine.prototype.createShaderProgram = function (pipelineContext, vertexCode, fragmentCode, defines, context, transformFeedbackVaryings) {\r\n if (transformFeedbackVaryings === void 0) { transformFeedbackVaryings = null; }\r\n context = context || this._gl;\r\n this.onBeforeShaderCompilationObservable.notifyObservers(this);\r\n var program = _super.prototype.createShaderProgram.call(this, pipelineContext, vertexCode, fragmentCode, defines, context, transformFeedbackVaryings);\r\n this.onAfterShaderCompilationObservable.notifyObservers(this);\r\n return program;\r\n };\r\n Engine.prototype._createShaderProgram = function (pipelineContext, vertexShader, fragmentShader, context, transformFeedbackVaryings) {\r\n if (transformFeedbackVaryings === void 0) { transformFeedbackVaryings = null; }\r\n var shaderProgram = context.createProgram();\r\n pipelineContext.program = shaderProgram;\r\n if (!shaderProgram) {\r\n throw new Error(\"Unable to create program\");\r\n }\r\n context.attachShader(shaderProgram, vertexShader);\r\n context.attachShader(shaderProgram, fragmentShader);\r\n if (this.webGLVersion > 1 && transformFeedbackVaryings) {\r\n var transformFeedback = this.createTransformFeedback();\r\n this.bindTransformFeedback(transformFeedback);\r\n this.setTranformFeedbackVaryings(shaderProgram, transformFeedbackVaryings);\r\n pipelineContext.transformFeedback = transformFeedback;\r\n }\r\n context.linkProgram(shaderProgram);\r\n if (this.webGLVersion > 1 && transformFeedbackVaryings) {\r\n this.bindTransformFeedback(null);\r\n }\r\n pipelineContext.context = context;\r\n pipelineContext.vertexShader = vertexShader;\r\n pipelineContext.fragmentShader = fragmentShader;\r\n if (!pipelineContext.isParallelCompiled) {\r\n this._finalizePipelineContext(pipelineContext);\r\n }\r\n return shaderProgram;\r\n };\r\n Engine.prototype._releaseTexture = function (texture) {\r\n _super.prototype._releaseTexture.call(this, texture);\r\n // Set output texture of post process to null if the texture has been released/disposed\r\n this.scenes.forEach(function (scene) {\r\n scene.postProcesses.forEach(function (postProcess) {\r\n if (postProcess._outputTexture == texture) {\r\n postProcess._outputTexture = null;\r\n }\r\n });\r\n scene.cameras.forEach(function (camera) {\r\n camera._postProcesses.forEach(function (postProcess) {\r\n if (postProcess) {\r\n if (postProcess._outputTexture == texture) {\r\n postProcess._outputTexture = null;\r\n }\r\n }\r\n });\r\n });\r\n });\r\n };\r\n /**\r\n * @hidden\r\n * Rescales a texture\r\n * @param source input texutre\r\n * @param destination destination texture\r\n * @param scene scene to use to render the resize\r\n * @param internalFormat format to use when resizing\r\n * @param onComplete callback to be called when resize has completed\r\n */\r\n Engine.prototype._rescaleTexture = function (source, destination, scene, internalFormat, onComplete) {\r\n var _this = this;\r\n this._gl.texParameteri(this._gl.TEXTURE_2D, this._gl.TEXTURE_MAG_FILTER, this._gl.LINEAR);\r\n this._gl.texParameteri(this._gl.TEXTURE_2D, this._gl.TEXTURE_MIN_FILTER, this._gl.LINEAR);\r\n this._gl.texParameteri(this._gl.TEXTURE_2D, this._gl.TEXTURE_WRAP_S, this._gl.CLAMP_TO_EDGE);\r\n this._gl.texParameteri(this._gl.TEXTURE_2D, this._gl.TEXTURE_WRAP_T, this._gl.CLAMP_TO_EDGE);\r\n var rtt = this.createRenderTargetTexture({\r\n width: destination.width,\r\n height: destination.height,\r\n }, {\r\n generateMipMaps: false,\r\n type: 0,\r\n samplingMode: 2,\r\n generateDepthBuffer: false,\r\n generateStencilBuffer: false\r\n });\r\n if (!this._rescalePostProcess && Engine._RescalePostProcessFactory) {\r\n this._rescalePostProcess = Engine._RescalePostProcessFactory(this);\r\n }\r\n this._rescalePostProcess.getEffect().executeWhenCompiled(function () {\r\n _this._rescalePostProcess.onApply = function (effect) {\r\n effect._bindTexture(\"textureSampler\", source);\r\n };\r\n var hostingScene = scene;\r\n if (!hostingScene) {\r\n hostingScene = _this.scenes[_this.scenes.length - 1];\r\n }\r\n hostingScene.postProcessManager.directRender([_this._rescalePostProcess], rtt, true);\r\n _this._bindTextureDirectly(_this._gl.TEXTURE_2D, destination, true);\r\n _this._gl.copyTexImage2D(_this._gl.TEXTURE_2D, 0, internalFormat, 0, 0, destination.width, destination.height, 0);\r\n _this.unBindFramebuffer(rtt);\r\n _this._releaseTexture(rtt);\r\n if (onComplete) {\r\n onComplete();\r\n }\r\n });\r\n };\r\n // FPS\r\n /**\r\n * Gets the current framerate\r\n * @returns a number representing the framerate\r\n */\r\n Engine.prototype.getFps = function () {\r\n return this._fps;\r\n };\r\n /**\r\n * Gets the time spent between current and previous frame\r\n * @returns a number representing the delta time in ms\r\n */\r\n Engine.prototype.getDeltaTime = function () {\r\n return this._deltaTime;\r\n };\r\n Engine.prototype._measureFps = function () {\r\n this._performanceMonitor.sampleFrame();\r\n this._fps = this._performanceMonitor.averageFPS;\r\n this._deltaTime = this._performanceMonitor.instantaneousFrameTime || 0;\r\n };\r\n /** @hidden */\r\n Engine.prototype._uploadImageToTexture = function (texture, image, faceIndex, lod) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (lod === void 0) { lod = 0; }\r\n var gl = this._gl;\r\n var textureType = this._getWebGLTextureType(texture.type);\r\n var format = this._getInternalFormat(texture.format);\r\n var internalFormat = this._getRGBABufferInternalSizedFormat(texture.type, format);\r\n var bindTarget = texture.isCube ? gl.TEXTURE_CUBE_MAP : gl.TEXTURE_2D;\r\n this._bindTextureDirectly(bindTarget, texture, true);\r\n this._unpackFlipY(texture.invertY);\r\n var target = gl.TEXTURE_2D;\r\n if (texture.isCube) {\r\n target = gl.TEXTURE_CUBE_MAP_POSITIVE_X + faceIndex;\r\n }\r\n gl.texImage2D(target, lod, internalFormat, format, textureType, image);\r\n this._bindTextureDirectly(bindTarget, null, true);\r\n };\r\n /**\r\n * Updates the sample count of a render target texture\r\n * @see https://doc.babylonjs.com/features/webgl2#multisample-render-targets\r\n * @param texture defines the texture to update\r\n * @param samples defines the sample count to set\r\n * @returns the effective sample count (could be 0 if multisample render targets are not supported)\r\n */\r\n Engine.prototype.updateRenderTargetTextureSampleCount = function (texture, samples) {\r\n if (this.webGLVersion < 2 || !texture) {\r\n return 1;\r\n }\r\n if (texture.samples === samples) {\r\n return samples;\r\n }\r\n var gl = this._gl;\r\n samples = Math.min(samples, this.getCaps().maxMSAASamples);\r\n // Dispose previous render buffers\r\n if (texture._depthStencilBuffer) {\r\n gl.deleteRenderbuffer(texture._depthStencilBuffer);\r\n texture._depthStencilBuffer = null;\r\n }\r\n if (texture._MSAAFramebuffer) {\r\n gl.deleteFramebuffer(texture._MSAAFramebuffer);\r\n texture._MSAAFramebuffer = null;\r\n }\r\n if (texture._MSAARenderBuffer) {\r\n gl.deleteRenderbuffer(texture._MSAARenderBuffer);\r\n texture._MSAARenderBuffer = null;\r\n }\r\n if (samples > 1 && gl.renderbufferStorageMultisample) {\r\n var framebuffer = gl.createFramebuffer();\r\n if (!framebuffer) {\r\n throw new Error(\"Unable to create multi sampled framebuffer\");\r\n }\r\n texture._MSAAFramebuffer = framebuffer;\r\n this._bindUnboundFramebuffer(texture._MSAAFramebuffer);\r\n var colorRenderbuffer = gl.createRenderbuffer();\r\n if (!colorRenderbuffer) {\r\n throw new Error(\"Unable to create multi sampled framebuffer\");\r\n }\r\n gl.bindRenderbuffer(gl.RENDERBUFFER, colorRenderbuffer);\r\n gl.renderbufferStorageMultisample(gl.RENDERBUFFER, samples, this._getRGBAMultiSampleBufferFormat(texture.type), texture.width, texture.height);\r\n gl.framebufferRenderbuffer(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.RENDERBUFFER, colorRenderbuffer);\r\n texture._MSAARenderBuffer = colorRenderbuffer;\r\n }\r\n else {\r\n this._bindUnboundFramebuffer(texture._framebuffer);\r\n }\r\n texture.samples = samples;\r\n texture._depthStencilBuffer = this._setupFramebufferDepthAttachments(texture._generateStencilBuffer, texture._generateDepthBuffer, texture.width, texture.height, samples);\r\n this._bindUnboundFramebuffer(null);\r\n return samples;\r\n };\r\n /**\r\n * Updates a depth texture Comparison Mode and Function.\r\n * If the comparison Function is equal to 0, the mode will be set to none.\r\n * Otherwise, this only works in webgl 2 and requires a shadow sampler in the shader.\r\n * @param texture The texture to set the comparison function for\r\n * @param comparisonFunction The comparison function to set, 0 if no comparison required\r\n */\r\n Engine.prototype.updateTextureComparisonFunction = function (texture, comparisonFunction) {\r\n if (this.webGLVersion === 1) {\r\n Logger.Error(\"WebGL 1 does not support texture comparison.\");\r\n return;\r\n }\r\n var gl = this._gl;\r\n if (texture.isCube) {\r\n this._bindTextureDirectly(this._gl.TEXTURE_CUBE_MAP, texture, true);\r\n if (comparisonFunction === 0) {\r\n gl.texParameteri(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_COMPARE_FUNC, 515);\r\n gl.texParameteri(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_COMPARE_MODE, gl.NONE);\r\n }\r\n else {\r\n gl.texParameteri(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_COMPARE_FUNC, comparisonFunction);\r\n gl.texParameteri(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_COMPARE_MODE, gl.COMPARE_REF_TO_TEXTURE);\r\n }\r\n this._bindTextureDirectly(this._gl.TEXTURE_CUBE_MAP, null);\r\n }\r\n else {\r\n this._bindTextureDirectly(this._gl.TEXTURE_2D, texture, true);\r\n if (comparisonFunction === 0) {\r\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_COMPARE_FUNC, 515);\r\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_COMPARE_MODE, gl.NONE);\r\n }\r\n else {\r\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_COMPARE_FUNC, comparisonFunction);\r\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_COMPARE_MODE, gl.COMPARE_REF_TO_TEXTURE);\r\n }\r\n this._bindTextureDirectly(this._gl.TEXTURE_2D, null);\r\n }\r\n texture._comparisonFunction = comparisonFunction;\r\n };\r\n /**\r\n * Creates a webGL buffer to use with instanciation\r\n * @param capacity defines the size of the buffer\r\n * @returns the webGL buffer\r\n */\r\n Engine.prototype.createInstancesBuffer = function (capacity) {\r\n var buffer = this._gl.createBuffer();\r\n if (!buffer) {\r\n throw new Error(\"Unable to create instance buffer\");\r\n }\r\n var result = new WebGLDataBuffer(buffer);\r\n result.capacity = capacity;\r\n this.bindArrayBuffer(result);\r\n this._gl.bufferData(this._gl.ARRAY_BUFFER, capacity, this._gl.DYNAMIC_DRAW);\r\n return result;\r\n };\r\n /**\r\n * Delete a webGL buffer used with instanciation\r\n * @param buffer defines the webGL buffer to delete\r\n */\r\n Engine.prototype.deleteInstancesBuffer = function (buffer) {\r\n this._gl.deleteBuffer(buffer);\r\n };\r\n Engine.prototype._clientWaitAsync = function (sync, flags, interval_ms) {\r\n if (flags === void 0) { flags = 0; }\r\n if (interval_ms === void 0) { interval_ms = 10; }\r\n var gl = this._gl;\r\n return new Promise(function (resolve, reject) {\r\n var check = function () {\r\n var res = gl.clientWaitSync(sync, flags, 0);\r\n if (res == gl.WAIT_FAILED) {\r\n reject();\r\n return;\r\n }\r\n if (res == gl.TIMEOUT_EXPIRED) {\r\n setTimeout(check, interval_ms);\r\n return;\r\n }\r\n resolve();\r\n };\r\n check();\r\n });\r\n };\r\n /** @hidden */\r\n Engine.prototype._readPixelsAsync = function (x, y, w, h, format, type, outputBuffer) {\r\n if (this._webGLVersion < 2) {\r\n throw new Error(\"_readPixelsAsync only work on WebGL2+\");\r\n }\r\n var gl = this._gl;\r\n var buf = gl.createBuffer();\r\n gl.bindBuffer(gl.PIXEL_PACK_BUFFER, buf);\r\n gl.bufferData(gl.PIXEL_PACK_BUFFER, outputBuffer.byteLength, gl.STREAM_READ);\r\n gl.readPixels(x, y, w, h, format, type, 0);\r\n gl.bindBuffer(gl.PIXEL_PACK_BUFFER, null);\r\n var sync = gl.fenceSync(gl.SYNC_GPU_COMMANDS_COMPLETE, 0);\r\n if (!sync) {\r\n return null;\r\n }\r\n gl.flush();\r\n return this._clientWaitAsync(sync, 0, 10).then(function () {\r\n gl.deleteSync(sync);\r\n gl.bindBuffer(gl.PIXEL_PACK_BUFFER, buf);\r\n gl.getBufferSubData(gl.PIXEL_PACK_BUFFER, 0, outputBuffer);\r\n gl.bindBuffer(gl.PIXEL_PACK_BUFFER, null);\r\n gl.deleteBuffer(buf);\r\n return outputBuffer;\r\n });\r\n };\r\n Engine.prototype.dispose = function () {\r\n this.hideLoadingUI();\r\n this.onNewSceneAddedObservable.clear();\r\n // Release postProcesses\r\n while (this.postProcesses.length) {\r\n this.postProcesses[0].dispose();\r\n }\r\n // Rescale PP\r\n if (this._rescalePostProcess) {\r\n this._rescalePostProcess.dispose();\r\n }\r\n // Release scenes\r\n while (this.scenes.length) {\r\n this.scenes[0].dispose();\r\n }\r\n // Release audio engine\r\n if (Engine.Instances.length === 1 && Engine.audioEngine) {\r\n Engine.audioEngine.dispose();\r\n }\r\n //WebVR\r\n this.disableVR();\r\n // Events\r\n if (DomManagement.IsWindowObjectExist()) {\r\n window.removeEventListener(\"blur\", this._onBlur);\r\n window.removeEventListener(\"focus\", this._onFocus);\r\n if (this._renderingCanvas) {\r\n this._renderingCanvas.removeEventListener(\"focus\", this._onCanvasFocus);\r\n this._renderingCanvas.removeEventListener(\"blur\", this._onCanvasBlur);\r\n this._renderingCanvas.removeEventListener(\"pointerout\", this._onCanvasPointerOut);\r\n }\r\n if (DomManagement.IsDocumentAvailable()) {\r\n document.removeEventListener(\"fullscreenchange\", this._onFullscreenChange);\r\n document.removeEventListener(\"mozfullscreenchange\", this._onFullscreenChange);\r\n document.removeEventListener(\"webkitfullscreenchange\", this._onFullscreenChange);\r\n document.removeEventListener(\"msfullscreenchange\", this._onFullscreenChange);\r\n document.removeEventListener(\"pointerlockchange\", this._onPointerLockChange);\r\n document.removeEventListener(\"mspointerlockchange\", this._onPointerLockChange);\r\n document.removeEventListener(\"mozpointerlockchange\", this._onPointerLockChange);\r\n document.removeEventListener(\"webkitpointerlockchange\", this._onPointerLockChange);\r\n }\r\n }\r\n _super.prototype.dispose.call(this);\r\n // Remove from Instances\r\n var index = Engine.Instances.indexOf(this);\r\n if (index >= 0) {\r\n Engine.Instances.splice(index, 1);\r\n }\r\n // Observables\r\n this.onResizeObservable.clear();\r\n this.onCanvasBlurObservable.clear();\r\n this.onCanvasFocusObservable.clear();\r\n this.onCanvasPointerOutObservable.clear();\r\n this.onBeginFrameObservable.clear();\r\n this.onEndFrameObservable.clear();\r\n };\r\n Engine.prototype._disableTouchAction = function () {\r\n if (!this._renderingCanvas || !this._renderingCanvas.setAttribute) {\r\n return;\r\n }\r\n this._renderingCanvas.setAttribute(\"touch-action\", \"none\");\r\n this._renderingCanvas.style.touchAction = \"none\";\r\n this._renderingCanvas.style.msTouchAction = \"none\";\r\n };\r\n // Loading screen\r\n /**\r\n * Display the loading screen\r\n * @see https://doc.babylonjs.com/how_to/creating_a_custom_loading_screen\r\n */\r\n Engine.prototype.displayLoadingUI = function () {\r\n if (!DomManagement.IsWindowObjectExist()) {\r\n return;\r\n }\r\n var loadingScreen = this.loadingScreen;\r\n if (loadingScreen) {\r\n loadingScreen.displayLoadingUI();\r\n }\r\n };\r\n /**\r\n * Hide the loading screen\r\n * @see https://doc.babylonjs.com/how_to/creating_a_custom_loading_screen\r\n */\r\n Engine.prototype.hideLoadingUI = function () {\r\n if (!DomManagement.IsWindowObjectExist()) {\r\n return;\r\n }\r\n var loadingScreen = this._loadingScreen;\r\n if (loadingScreen) {\r\n loadingScreen.hideLoadingUI();\r\n }\r\n };\r\n Object.defineProperty(Engine.prototype, \"loadingScreen\", {\r\n /**\r\n * Gets the current loading screen object\r\n * @see https://doc.babylonjs.com/how_to/creating_a_custom_loading_screen\r\n */\r\n get: function () {\r\n if (!this._loadingScreen && this._renderingCanvas) {\r\n this._loadingScreen = Engine.DefaultLoadingScreenFactory(this._renderingCanvas);\r\n }\r\n return this._loadingScreen;\r\n },\r\n /**\r\n * Sets the current loading screen object\r\n * @see https://doc.babylonjs.com/how_to/creating_a_custom_loading_screen\r\n */\r\n set: function (loadingScreen) {\r\n this._loadingScreen = loadingScreen;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Engine.prototype, \"loadingUIText\", {\r\n /**\r\n * Sets the current loading screen text\r\n * @see https://doc.babylonjs.com/how_to/creating_a_custom_loading_screen\r\n */\r\n set: function (text) {\r\n this.loadingScreen.loadingUIText = text;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Engine.prototype, \"loadingUIBackgroundColor\", {\r\n /**\r\n * Sets the current loading screen background color\r\n * @see https://doc.babylonjs.com/how_to/creating_a_custom_loading_screen\r\n */\r\n set: function (color) {\r\n this.loadingScreen.loadingUIBackgroundColor = color;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** Pointerlock and fullscreen */\r\n /**\r\n * Ask the browser to promote the current element to pointerlock mode\r\n * @param element defines the DOM element to promote\r\n */\r\n Engine._RequestPointerlock = function (element) {\r\n element.requestPointerLock = element.requestPointerLock || element.msRequestPointerLock || element.mozRequestPointerLock || element.webkitRequestPointerLock;\r\n if (element.requestPointerLock) {\r\n element.requestPointerLock();\r\n }\r\n };\r\n /**\r\n * Asks the browser to exit pointerlock mode\r\n */\r\n Engine._ExitPointerlock = function () {\r\n var anyDoc = document;\r\n document.exitPointerLock = document.exitPointerLock || anyDoc.msExitPointerLock || anyDoc.mozExitPointerLock || anyDoc.webkitExitPointerLock;\r\n if (document.exitPointerLock) {\r\n document.exitPointerLock();\r\n }\r\n };\r\n /**\r\n * Ask the browser to promote the current element to fullscreen rendering mode\r\n * @param element defines the DOM element to promote\r\n */\r\n Engine._RequestFullscreen = function (element) {\r\n var requestFunction = element.requestFullscreen || element.msRequestFullscreen || element.webkitRequestFullscreen || element.mozRequestFullScreen;\r\n if (!requestFunction) {\r\n return;\r\n }\r\n requestFunction.call(element);\r\n };\r\n /**\r\n * Asks the browser to exit fullscreen mode\r\n */\r\n Engine._ExitFullscreen = function () {\r\n var anyDoc = document;\r\n if (document.exitFullscreen) {\r\n document.exitFullscreen();\r\n }\r\n else if (anyDoc.mozCancelFullScreen) {\r\n anyDoc.mozCancelFullScreen();\r\n }\r\n else if (anyDoc.webkitCancelFullScreen) {\r\n anyDoc.webkitCancelFullScreen();\r\n }\r\n else if (anyDoc.msCancelFullScreen) {\r\n anyDoc.msCancelFullScreen();\r\n }\r\n };\r\n // Const statics\r\n /** Defines that alpha blending is disabled */\r\n Engine.ALPHA_DISABLE = 0;\r\n /** Defines that alpha blending to SRC ALPHA * SRC + DEST */\r\n Engine.ALPHA_ADD = 1;\r\n /** Defines that alpha blending to SRC ALPHA * SRC + (1 - SRC ALPHA) * DEST */\r\n Engine.ALPHA_COMBINE = 2;\r\n /** Defines that alpha blending to DEST - SRC * DEST */\r\n Engine.ALPHA_SUBTRACT = 3;\r\n /** Defines that alpha blending to SRC * DEST */\r\n Engine.ALPHA_MULTIPLY = 4;\r\n /** Defines that alpha blending to SRC ALPHA * SRC + (1 - SRC) * DEST */\r\n Engine.ALPHA_MAXIMIZED = 5;\r\n /** Defines that alpha blending to SRC + DEST */\r\n Engine.ALPHA_ONEONE = 6;\r\n /** Defines that alpha blending to SRC + (1 - SRC ALPHA) * DEST */\r\n Engine.ALPHA_PREMULTIPLIED = 7;\r\n /**\r\n * Defines that alpha blending to SRC + (1 - SRC ALPHA) * DEST\r\n * Alpha will be set to (1 - SRC ALPHA) * DEST ALPHA\r\n */\r\n Engine.ALPHA_PREMULTIPLIED_PORTERDUFF = 8;\r\n /** Defines that alpha blending to CST * SRC + (1 - CST) * DEST */\r\n Engine.ALPHA_INTERPOLATE = 9;\r\n /**\r\n * Defines that alpha blending to SRC + (1 - SRC) * DEST\r\n * Alpha will be set to SRC ALPHA + (1 - SRC ALPHA) * DEST ALPHA\r\n */\r\n Engine.ALPHA_SCREENMODE = 10;\r\n /** Defines that the ressource is not delayed*/\r\n Engine.DELAYLOADSTATE_NONE = 0;\r\n /** Defines that the ressource was successfully delay loaded */\r\n Engine.DELAYLOADSTATE_LOADED = 1;\r\n /** Defines that the ressource is currently delay loading */\r\n Engine.DELAYLOADSTATE_LOADING = 2;\r\n /** Defines that the ressource is delayed and has not started loading */\r\n Engine.DELAYLOADSTATE_NOTLOADED = 4;\r\n // Depht or Stencil test Constants.\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will never pass. i.e. Nothing will be drawn */\r\n Engine.NEVER = 512;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will always pass. i.e. Pixels will be drawn in the order they are drawn */\r\n Engine.ALWAYS = 519;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is less than the stored value */\r\n Engine.LESS = 513;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is equals to the stored value */\r\n Engine.EQUAL = 514;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is less than or equal to the stored value */\r\n Engine.LEQUAL = 515;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is greater than the stored value */\r\n Engine.GREATER = 516;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is greater than or equal to the stored value */\r\n Engine.GEQUAL = 518;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is not equal to the stored value */\r\n Engine.NOTEQUAL = 517;\r\n // Stencil Actions Constants.\r\n /** Passed to stencilOperation to specify that stencil value must be kept */\r\n Engine.KEEP = 7680;\r\n /** Passed to stencilOperation to specify that stencil value must be replaced */\r\n Engine.REPLACE = 7681;\r\n /** Passed to stencilOperation to specify that stencil value must be incremented */\r\n Engine.INCR = 7682;\r\n /** Passed to stencilOperation to specify that stencil value must be decremented */\r\n Engine.DECR = 7683;\r\n /** Passed to stencilOperation to specify that stencil value must be inverted */\r\n Engine.INVERT = 5386;\r\n /** Passed to stencilOperation to specify that stencil value must be incremented with wrapping */\r\n Engine.INCR_WRAP = 34055;\r\n /** Passed to stencilOperation to specify that stencil value must be decremented with wrapping */\r\n Engine.DECR_WRAP = 34056;\r\n /** Texture is not repeating outside of 0..1 UVs */\r\n Engine.TEXTURE_CLAMP_ADDRESSMODE = 0;\r\n /** Texture is repeating outside of 0..1 UVs */\r\n Engine.TEXTURE_WRAP_ADDRESSMODE = 1;\r\n /** Texture is repeating and mirrored */\r\n Engine.TEXTURE_MIRROR_ADDRESSMODE = 2;\r\n /** ALPHA */\r\n Engine.TEXTUREFORMAT_ALPHA = 0;\r\n /** LUMINANCE */\r\n Engine.TEXTUREFORMAT_LUMINANCE = 1;\r\n /** LUMINANCE_ALPHA */\r\n Engine.TEXTUREFORMAT_LUMINANCE_ALPHA = 2;\r\n /** RGB */\r\n Engine.TEXTUREFORMAT_RGB = 4;\r\n /** RGBA */\r\n Engine.TEXTUREFORMAT_RGBA = 5;\r\n /** RED */\r\n Engine.TEXTUREFORMAT_RED = 6;\r\n /** RED (2nd reference) */\r\n Engine.TEXTUREFORMAT_R = 6;\r\n /** RG */\r\n Engine.TEXTUREFORMAT_RG = 7;\r\n /** RED_INTEGER */\r\n Engine.TEXTUREFORMAT_RED_INTEGER = 8;\r\n /** RED_INTEGER (2nd reference) */\r\n Engine.TEXTUREFORMAT_R_INTEGER = 8;\r\n /** RG_INTEGER */\r\n Engine.TEXTUREFORMAT_RG_INTEGER = 9;\r\n /** RGB_INTEGER */\r\n Engine.TEXTUREFORMAT_RGB_INTEGER = 10;\r\n /** RGBA_INTEGER */\r\n Engine.TEXTUREFORMAT_RGBA_INTEGER = 11;\r\n /** UNSIGNED_BYTE */\r\n Engine.TEXTURETYPE_UNSIGNED_BYTE = 0;\r\n /** UNSIGNED_BYTE (2nd reference) */\r\n Engine.TEXTURETYPE_UNSIGNED_INT = 0;\r\n /** FLOAT */\r\n Engine.TEXTURETYPE_FLOAT = 1;\r\n /** HALF_FLOAT */\r\n Engine.TEXTURETYPE_HALF_FLOAT = 2;\r\n /** BYTE */\r\n Engine.TEXTURETYPE_BYTE = 3;\r\n /** SHORT */\r\n Engine.TEXTURETYPE_SHORT = 4;\r\n /** UNSIGNED_SHORT */\r\n Engine.TEXTURETYPE_UNSIGNED_SHORT = 5;\r\n /** INT */\r\n Engine.TEXTURETYPE_INT = 6;\r\n /** UNSIGNED_INT */\r\n Engine.TEXTURETYPE_UNSIGNED_INTEGER = 7;\r\n /** UNSIGNED_SHORT_4_4_4_4 */\r\n Engine.TEXTURETYPE_UNSIGNED_SHORT_4_4_4_4 = 8;\r\n /** UNSIGNED_SHORT_5_5_5_1 */\r\n Engine.TEXTURETYPE_UNSIGNED_SHORT_5_5_5_1 = 9;\r\n /** UNSIGNED_SHORT_5_6_5 */\r\n Engine.TEXTURETYPE_UNSIGNED_SHORT_5_6_5 = 10;\r\n /** UNSIGNED_INT_2_10_10_10_REV */\r\n Engine.TEXTURETYPE_UNSIGNED_INT_2_10_10_10_REV = 11;\r\n /** UNSIGNED_INT_24_8 */\r\n Engine.TEXTURETYPE_UNSIGNED_INT_24_8 = 12;\r\n /** UNSIGNED_INT_10F_11F_11F_REV */\r\n Engine.TEXTURETYPE_UNSIGNED_INT_10F_11F_11F_REV = 13;\r\n /** UNSIGNED_INT_5_9_9_9_REV */\r\n Engine.TEXTURETYPE_UNSIGNED_INT_5_9_9_9_REV = 14;\r\n /** FLOAT_32_UNSIGNED_INT_24_8_REV */\r\n Engine.TEXTURETYPE_FLOAT_32_UNSIGNED_INT_24_8_REV = 15;\r\n /** nearest is mag = nearest and min = nearest and mip = linear */\r\n Engine.TEXTURE_NEAREST_SAMPLINGMODE = 1;\r\n /** Bilinear is mag = linear and min = linear and mip = nearest */\r\n Engine.TEXTURE_BILINEAR_SAMPLINGMODE = 2;\r\n /** Trilinear is mag = linear and min = linear and mip = linear */\r\n Engine.TEXTURE_TRILINEAR_SAMPLINGMODE = 3;\r\n /** nearest is mag = nearest and min = nearest and mip = linear */\r\n Engine.TEXTURE_NEAREST_NEAREST_MIPLINEAR = 8;\r\n /** Bilinear is mag = linear and min = linear and mip = nearest */\r\n Engine.TEXTURE_LINEAR_LINEAR_MIPNEAREST = 11;\r\n /** Trilinear is mag = linear and min = linear and mip = linear */\r\n Engine.TEXTURE_LINEAR_LINEAR_MIPLINEAR = 3;\r\n /** mag = nearest and min = nearest and mip = nearest */\r\n Engine.TEXTURE_NEAREST_NEAREST_MIPNEAREST = 4;\r\n /** mag = nearest and min = linear and mip = nearest */\r\n Engine.TEXTURE_NEAREST_LINEAR_MIPNEAREST = 5;\r\n /** mag = nearest and min = linear and mip = linear */\r\n Engine.TEXTURE_NEAREST_LINEAR_MIPLINEAR = 6;\r\n /** mag = nearest and min = linear and mip = none */\r\n Engine.TEXTURE_NEAREST_LINEAR = 7;\r\n /** mag = nearest and min = nearest and mip = none */\r\n Engine.TEXTURE_NEAREST_NEAREST = 1;\r\n /** mag = linear and min = nearest and mip = nearest */\r\n Engine.TEXTURE_LINEAR_NEAREST_MIPNEAREST = 9;\r\n /** mag = linear and min = nearest and mip = linear */\r\n Engine.TEXTURE_LINEAR_NEAREST_MIPLINEAR = 10;\r\n /** mag = linear and min = linear and mip = none */\r\n Engine.TEXTURE_LINEAR_LINEAR = 2;\r\n /** mag = linear and min = nearest and mip = none */\r\n Engine.TEXTURE_LINEAR_NEAREST = 12;\r\n /** Explicit coordinates mode */\r\n Engine.TEXTURE_EXPLICIT_MODE = 0;\r\n /** Spherical coordinates mode */\r\n Engine.TEXTURE_SPHERICAL_MODE = 1;\r\n /** Planar coordinates mode */\r\n Engine.TEXTURE_PLANAR_MODE = 2;\r\n /** Cubic coordinates mode */\r\n Engine.TEXTURE_CUBIC_MODE = 3;\r\n /** Projection coordinates mode */\r\n Engine.TEXTURE_PROJECTION_MODE = 4;\r\n /** Skybox coordinates mode */\r\n Engine.TEXTURE_SKYBOX_MODE = 5;\r\n /** Inverse Cubic coordinates mode */\r\n Engine.TEXTURE_INVCUBIC_MODE = 6;\r\n /** Equirectangular coordinates mode */\r\n Engine.TEXTURE_EQUIRECTANGULAR_MODE = 7;\r\n /** Equirectangular Fixed coordinates mode */\r\n Engine.TEXTURE_FIXED_EQUIRECTANGULAR_MODE = 8;\r\n /** Equirectangular Fixed Mirrored coordinates mode */\r\n Engine.TEXTURE_FIXED_EQUIRECTANGULAR_MIRRORED_MODE = 9;\r\n // Texture rescaling mode\r\n /** Defines that texture rescaling will use a floor to find the closer power of 2 size */\r\n Engine.SCALEMODE_FLOOR = 1;\r\n /** Defines that texture rescaling will look for the nearest power of 2 size */\r\n Engine.SCALEMODE_NEAREST = 2;\r\n /** Defines that texture rescaling will use a ceil to find the closer power of 2 size */\r\n Engine.SCALEMODE_CEILING = 3;\r\n /**\r\n * Method called to create the default rescale post process on each engine.\r\n */\r\n Engine._RescalePostProcessFactory = null;\r\n return Engine;\r\n}(ThinEngine));\r\nexport { Engine };\r\n//# sourceMappingURL=engine.js.map","/**\r\n * The engine store class is responsible to hold all the instances of Engine and Scene created\r\n * during the life time of the application.\r\n */\r\nvar EngineStore = /** @class */ (function () {\r\n function EngineStore() {\r\n }\r\n Object.defineProperty(EngineStore, \"LastCreatedEngine\", {\r\n /**\r\n * Gets the latest created engine\r\n */\r\n get: function () {\r\n if (this.Instances.length === 0) {\r\n return null;\r\n }\r\n return this.Instances[this.Instances.length - 1];\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(EngineStore, \"LastCreatedScene\", {\r\n /**\r\n * Gets the latest created scene\r\n */\r\n get: function () {\r\n return this._LastCreatedScene;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** Gets the list of created engines */\r\n EngineStore.Instances = new Array();\r\n /** @hidden */\r\n EngineStore._LastCreatedScene = null;\r\n /**\r\n * Gets or sets a global variable indicating if fallback texture must be used when a texture cannot be loaded\r\n * @ignorenaming\r\n */\r\n EngineStore.UseFallbackTexture = true;\r\n /**\r\n * Texture content used if a texture cannot loaded\r\n * @ignorenaming\r\n */\r\n EngineStore.FallbackTexture = \"\";\r\n return EngineStore;\r\n}());\r\nexport { EngineStore };\r\n//# sourceMappingURL=engineStore.js.map","/**\r\n * Sets of helpers dealing with the DOM and some of the recurrent functions needed in\r\n * Babylon.js\r\n */\r\nvar DomManagement = /** @class */ (function () {\r\n function DomManagement() {\r\n }\r\n /**\r\n * Checks if the window object exists\r\n * @returns true if the window object exists\r\n */\r\n DomManagement.IsWindowObjectExist = function () {\r\n return (typeof window) !== \"undefined\";\r\n };\r\n /**\r\n * Checks if the navigator object exists\r\n * @returns true if the navigator object exists\r\n */\r\n DomManagement.IsNavigatorAvailable = function () {\r\n return (typeof navigator) !== \"undefined\";\r\n };\r\n /**\r\n * Check if the document object exists\r\n * @returns true if the document object exists\r\n */\r\n DomManagement.IsDocumentAvailable = function () {\r\n return (typeof document) !== \"undefined\";\r\n };\r\n /**\r\n * Extracts text content from a DOM element hierarchy\r\n * @param element defines the root element\r\n * @returns a string\r\n */\r\n DomManagement.GetDOMTextContent = function (element) {\r\n var result = \"\";\r\n var child = element.firstChild;\r\n while (child) {\r\n if (child.nodeType === 3) {\r\n result += child.textContent;\r\n }\r\n child = (child.nextSibling);\r\n }\r\n return result;\r\n };\r\n return DomManagement;\r\n}());\r\nexport { DomManagement };\r\n//# sourceMappingURL=domManagement.js.map","/**\r\n * This class implement a typical dictionary using a string as key and the generic type T as value.\r\n * The underlying implementation relies on an associative array to ensure the best performances.\r\n * The value can be anything including 'null' but except 'undefined'\r\n */\r\nvar StringDictionary = /** @class */ (function () {\r\n function StringDictionary() {\r\n this._count = 0;\r\n this._data = {};\r\n }\r\n /**\r\n * This will clear this dictionary and copy the content from the 'source' one.\r\n * If the T value is a custom object, it won't be copied/cloned, the same object will be used\r\n * @param source the dictionary to take the content from and copy to this dictionary\r\n */\r\n StringDictionary.prototype.copyFrom = function (source) {\r\n var _this = this;\r\n this.clear();\r\n source.forEach(function (t, v) { return _this.add(t, v); });\r\n };\r\n /**\r\n * Get a value based from its key\r\n * @param key the given key to get the matching value from\r\n * @return the value if found, otherwise undefined is returned\r\n */\r\n StringDictionary.prototype.get = function (key) {\r\n var val = this._data[key];\r\n if (val !== undefined) {\r\n return val;\r\n }\r\n return undefined;\r\n };\r\n /**\r\n * Get a value from its key or add it if it doesn't exist.\r\n * This method will ensure you that a given key/data will be present in the dictionary.\r\n * @param key the given key to get the matching value from\r\n * @param factory the factory that will create the value if the key is not present in the dictionary.\r\n * The factory will only be invoked if there's no data for the given key.\r\n * @return the value corresponding to the key.\r\n */\r\n StringDictionary.prototype.getOrAddWithFactory = function (key, factory) {\r\n var val = this.get(key);\r\n if (val !== undefined) {\r\n return val;\r\n }\r\n val = factory(key);\r\n if (val) {\r\n this.add(key, val);\r\n }\r\n return val;\r\n };\r\n /**\r\n * Get a value from its key if present in the dictionary otherwise add it\r\n * @param key the key to get the value from\r\n * @param val if there's no such key/value pair in the dictionary add it with this value\r\n * @return the value corresponding to the key\r\n */\r\n StringDictionary.prototype.getOrAdd = function (key, val) {\r\n var curVal = this.get(key);\r\n if (curVal !== undefined) {\r\n return curVal;\r\n }\r\n this.add(key, val);\r\n return val;\r\n };\r\n /**\r\n * Check if there's a given key in the dictionary\r\n * @param key the key to check for\r\n * @return true if the key is present, false otherwise\r\n */\r\n StringDictionary.prototype.contains = function (key) {\r\n return this._data[key] !== undefined;\r\n };\r\n /**\r\n * Add a new key and its corresponding value\r\n * @param key the key to add\r\n * @param value the value corresponding to the key\r\n * @return true if the operation completed successfully, false if we couldn't insert the key/value because there was already this key in the dictionary\r\n */\r\n StringDictionary.prototype.add = function (key, value) {\r\n if (this._data[key] !== undefined) {\r\n return false;\r\n }\r\n this._data[key] = value;\r\n ++this._count;\r\n return true;\r\n };\r\n /**\r\n * Update a specific value associated to a key\r\n * @param key defines the key to use\r\n * @param value defines the value to store\r\n * @returns true if the value was updated (or false if the key was not found)\r\n */\r\n StringDictionary.prototype.set = function (key, value) {\r\n if (this._data[key] === undefined) {\r\n return false;\r\n }\r\n this._data[key] = value;\r\n return true;\r\n };\r\n /**\r\n * Get the element of the given key and remove it from the dictionary\r\n * @param key defines the key to search\r\n * @returns the value associated with the key or null if not found\r\n */\r\n StringDictionary.prototype.getAndRemove = function (key) {\r\n var val = this.get(key);\r\n if (val !== undefined) {\r\n delete this._data[key];\r\n --this._count;\r\n return val;\r\n }\r\n return null;\r\n };\r\n /**\r\n * Remove a key/value from the dictionary.\r\n * @param key the key to remove\r\n * @return true if the item was successfully deleted, false if no item with such key exist in the dictionary\r\n */\r\n StringDictionary.prototype.remove = function (key) {\r\n if (this.contains(key)) {\r\n delete this._data[key];\r\n --this._count;\r\n return true;\r\n }\r\n return false;\r\n };\r\n /**\r\n * Clear the whole content of the dictionary\r\n */\r\n StringDictionary.prototype.clear = function () {\r\n this._data = {};\r\n this._count = 0;\r\n };\r\n Object.defineProperty(StringDictionary.prototype, \"count\", {\r\n /**\r\n * Gets the current count\r\n */\r\n get: function () {\r\n return this._count;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Execute a callback on each key/val of the dictionary.\r\n * Note that you can remove any element in this dictionary in the callback implementation\r\n * @param callback the callback to execute on a given key/value pair\r\n */\r\n StringDictionary.prototype.forEach = function (callback) {\r\n for (var cur in this._data) {\r\n var val = this._data[cur];\r\n callback(cur, val);\r\n }\r\n };\r\n /**\r\n * Execute a callback on every occurrence of the dictionary until it returns a valid TRes object.\r\n * If the callback returns null or undefined the method will iterate to the next key/value pair\r\n * Note that you can remove any element in this dictionary in the callback implementation\r\n * @param callback the callback to execute, if it return a valid T instanced object the enumeration will stop and the object will be returned\r\n * @returns the first item\r\n */\r\n StringDictionary.prototype.first = function (callback) {\r\n for (var cur in this._data) {\r\n var val = this._data[cur];\r\n var res = callback(cur, val);\r\n if (res) {\r\n return res;\r\n }\r\n }\r\n return null;\r\n };\r\n return StringDictionary;\r\n}());\r\nexport { StringDictionary };\r\n//# sourceMappingURL=stringDictionary.js.map","/**\r\n * Base class of the scene acting as a container for the different elements composing a scene.\r\n * This class is dynamically extended by the different components of the scene increasing\r\n * flexibility and reducing coupling\r\n */\r\nvar AbstractScene = /** @class */ (function () {\r\n function AbstractScene() {\r\n /**\r\n * Gets the list of root nodes (ie. nodes with no parent)\r\n */\r\n this.rootNodes = new Array();\r\n /** All of the cameras added to this scene\r\n * @see https://doc.babylonjs.com/babylon101/cameras\r\n */\r\n this.cameras = new Array();\r\n /**\r\n * All of the lights added to this scene\r\n * @see https://doc.babylonjs.com/babylon101/lights\r\n */\r\n this.lights = new Array();\r\n /**\r\n * All of the (abstract) meshes added to this scene\r\n */\r\n this.meshes = new Array();\r\n /**\r\n * The list of skeletons added to the scene\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_bones_and_skeletons\r\n */\r\n this.skeletons = new Array();\r\n /**\r\n * All of the particle systems added to this scene\r\n * @see https://doc.babylonjs.com/babylon101/particles\r\n */\r\n this.particleSystems = new Array();\r\n /**\r\n * Gets a list of Animations associated with the scene\r\n */\r\n this.animations = [];\r\n /**\r\n * All of the animation groups added to this scene\r\n * @see https://doc.babylonjs.com/how_to/group\r\n */\r\n this.animationGroups = new Array();\r\n /**\r\n * All of the multi-materials added to this scene\r\n * @see https://doc.babylonjs.com/how_to/multi_materials\r\n */\r\n this.multiMaterials = new Array();\r\n /**\r\n * All of the materials added to this scene\r\n * In the context of a Scene, it is not supposed to be modified manually.\r\n * Any addition or removal should be done using the addMaterial and removeMaterial Scene methods.\r\n * Note also that the order of the Material within the array is not significant and might change.\r\n * @see https://doc.babylonjs.com/babylon101/materials\r\n */\r\n this.materials = new Array();\r\n /**\r\n * The list of morph target managers added to the scene\r\n * @see https://doc.babylonjs.com/how_to/how_to_dynamically_morph_a_mesh\r\n */\r\n this.morphTargetManagers = new Array();\r\n /**\r\n * The list of geometries used in the scene.\r\n */\r\n this.geometries = new Array();\r\n /**\r\n * All of the tranform nodes added to this scene\r\n * In the context of a Scene, it is not supposed to be modified manually.\r\n * Any addition or removal should be done using the addTransformNode and removeTransformNode Scene methods.\r\n * Note also that the order of the TransformNode wihin the array is not significant and might change.\r\n * @see https://doc.babylonjs.com/how_to/transformnode\r\n */\r\n this.transformNodes = new Array();\r\n /**\r\n * ActionManagers available on the scene.\r\n */\r\n this.actionManagers = new Array();\r\n /**\r\n * Textures to keep.\r\n */\r\n this.textures = new Array();\r\n /** @hidden */\r\n this._environmentTexture = null;\r\n /**\r\n * The list of postprocesses added to the scene\r\n */\r\n this.postProcesses = new Array();\r\n }\r\n /**\r\n * Adds a parser in the list of available ones\r\n * @param name Defines the name of the parser\r\n * @param parser Defines the parser to add\r\n */\r\n AbstractScene.AddParser = function (name, parser) {\r\n this._BabylonFileParsers[name] = parser;\r\n };\r\n /**\r\n * Gets a general parser from the list of avaialble ones\r\n * @param name Defines the name of the parser\r\n * @returns the requested parser or null\r\n */\r\n AbstractScene.GetParser = function (name) {\r\n if (this._BabylonFileParsers[name]) {\r\n return this._BabylonFileParsers[name];\r\n }\r\n return null;\r\n };\r\n /**\r\n * Adds n individual parser in the list of available ones\r\n * @param name Defines the name of the parser\r\n * @param parser Defines the parser to add\r\n */\r\n AbstractScene.AddIndividualParser = function (name, parser) {\r\n this._IndividualBabylonFileParsers[name] = parser;\r\n };\r\n /**\r\n * Gets an individual parser from the list of avaialble ones\r\n * @param name Defines the name of the parser\r\n * @returns the requested parser or null\r\n */\r\n AbstractScene.GetIndividualParser = function (name) {\r\n if (this._IndividualBabylonFileParsers[name]) {\r\n return this._IndividualBabylonFileParsers[name];\r\n }\r\n return null;\r\n };\r\n /**\r\n * Parser json data and populate both a scene and its associated container object\r\n * @param jsonData Defines the data to parse\r\n * @param scene Defines the scene to parse the data for\r\n * @param container Defines the container attached to the parsing sequence\r\n * @param rootUrl Defines the root url of the data\r\n */\r\n AbstractScene.Parse = function (jsonData, scene, container, rootUrl) {\r\n for (var parserName in this._BabylonFileParsers) {\r\n if (this._BabylonFileParsers.hasOwnProperty(parserName)) {\r\n this._BabylonFileParsers[parserName](jsonData, scene, container, rootUrl);\r\n }\r\n }\r\n };\r\n Object.defineProperty(AbstractScene.prototype, \"environmentTexture\", {\r\n /**\r\n * Texture used in all pbr material as the reflection texture.\r\n * As in the majority of the scene they are the same (exception for multi room and so on),\r\n * this is easier to reference from here than from all the materials.\r\n */\r\n get: function () {\r\n return this._environmentTexture;\r\n },\r\n set: function (value) {\r\n this._environmentTexture = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * @returns all meshes, lights, cameras, transformNodes and bones\r\n */\r\n AbstractScene.prototype.getNodes = function () {\r\n var nodes = new Array();\r\n nodes = nodes.concat(this.meshes);\r\n nodes = nodes.concat(this.lights);\r\n nodes = nodes.concat(this.cameras);\r\n nodes = nodes.concat(this.transformNodes); // dummies\r\n this.skeletons.forEach(function (skeleton) { return nodes = nodes.concat(skeleton.bones); });\r\n return nodes;\r\n };\r\n /**\r\n * Stores the list of available parsers in the application.\r\n */\r\n AbstractScene._BabylonFileParsers = {};\r\n /**\r\n * Stores the list of available individual parsers in the application.\r\n */\r\n AbstractScene._IndividualBabylonFileParsers = {};\r\n return AbstractScene;\r\n}());\r\nexport { AbstractScene };\r\n//# sourceMappingURL=abstractScene.js.map","/**\r\n * ActionEvent is the event being sent when an action is triggered.\r\n */\r\nvar ActionEvent = /** @class */ (function () {\r\n /**\r\n * Creates a new ActionEvent\r\n * @param source The mesh or sprite that triggered the action\r\n * @param pointerX The X mouse cursor position at the time of the event\r\n * @param pointerY The Y mouse cursor position at the time of the event\r\n * @param meshUnderPointer The mesh that is currently pointed at (can be null)\r\n * @param sourceEvent the original (browser) event that triggered the ActionEvent\r\n * @param additionalData additional data for the event\r\n */\r\n function ActionEvent(\r\n /** The mesh or sprite that triggered the action */\r\n source, \r\n /** The X mouse cursor position at the time of the event */\r\n pointerX, \r\n /** The Y mouse cursor position at the time of the event */\r\n pointerY, \r\n /** The mesh that is currently pointed at (can be null) */\r\n meshUnderPointer, \r\n /** the original (browser) event that triggered the ActionEvent */\r\n sourceEvent, \r\n /** additional data for the event */\r\n additionalData) {\r\n this.source = source;\r\n this.pointerX = pointerX;\r\n this.pointerY = pointerY;\r\n this.meshUnderPointer = meshUnderPointer;\r\n this.sourceEvent = sourceEvent;\r\n this.additionalData = additionalData;\r\n }\r\n /**\r\n * Helper function to auto-create an ActionEvent from a source mesh.\r\n * @param source The source mesh that triggered the event\r\n * @param evt The original (browser) event\r\n * @param additionalData additional data for the event\r\n * @returns the new ActionEvent\r\n */\r\n ActionEvent.CreateNew = function (source, evt, additionalData) {\r\n var scene = source.getScene();\r\n return new ActionEvent(source, scene.pointerX, scene.pointerY, scene.meshUnderPointer || source, evt, additionalData);\r\n };\r\n /**\r\n * Helper function to auto-create an ActionEvent from a source sprite\r\n * @param source The source sprite that triggered the event\r\n * @param scene Scene associated with the sprite\r\n * @param evt The original (browser) event\r\n * @param additionalData additional data for the event\r\n * @returns the new ActionEvent\r\n */\r\n ActionEvent.CreateNewFromSprite = function (source, scene, evt, additionalData) {\r\n return new ActionEvent(source, scene.pointerX, scene.pointerY, scene.meshUnderPointer, evt, additionalData);\r\n };\r\n /**\r\n * Helper function to auto-create an ActionEvent from a scene. If triggered by a mesh use ActionEvent.CreateNew\r\n * @param scene the scene where the event occurred\r\n * @param evt The original (browser) event\r\n * @returns the new ActionEvent\r\n */\r\n ActionEvent.CreateNewFromScene = function (scene, evt) {\r\n return new ActionEvent(null, scene.pointerX, scene.pointerY, scene.meshUnderPointer, evt);\r\n };\r\n /**\r\n * Helper function to auto-create an ActionEvent from a primitive\r\n * @param prim defines the target primitive\r\n * @param pointerPos defines the pointer position\r\n * @param evt The original (browser) event\r\n * @param additionalData additional data for the event\r\n * @returns the new ActionEvent\r\n */\r\n ActionEvent.CreateNewFromPrimitive = function (prim, pointerPos, evt, additionalData) {\r\n return new ActionEvent(prim, pointerPos.x, pointerPos.y, null, evt, additionalData);\r\n };\r\n return ActionEvent;\r\n}());\r\nexport { ActionEvent };\r\n//# sourceMappingURL=actionEvent.js.map","/**\r\n * Abstract class used to decouple action Manager from scene and meshes.\r\n * Do not instantiate.\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions\r\n */\r\nvar AbstractActionManager = /** @class */ (function () {\r\n function AbstractActionManager() {\r\n /** Gets the cursor to use when hovering items */\r\n this.hoverCursor = '';\r\n /** Gets the list of actions */\r\n this.actions = new Array();\r\n /**\r\n * Gets or sets a boolean indicating that the manager is recursive meaning that it can trigger action from children\r\n */\r\n this.isRecursive = false;\r\n }\r\n Object.defineProperty(AbstractActionManager, \"HasTriggers\", {\r\n /**\r\n * Does exist one action manager with at least one trigger\r\n **/\r\n get: function () {\r\n for (var t in AbstractActionManager.Triggers) {\r\n if (AbstractActionManager.Triggers.hasOwnProperty(t)) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractActionManager, \"HasPickTriggers\", {\r\n /**\r\n * Does exist one action manager with at least one pick trigger\r\n **/\r\n get: function () {\r\n for (var t in AbstractActionManager.Triggers) {\r\n if (AbstractActionManager.Triggers.hasOwnProperty(t)) {\r\n var t_int = parseInt(t);\r\n if (t_int >= 1 && t_int <= 7) {\r\n return true;\r\n }\r\n }\r\n }\r\n return false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Does exist one action manager that handles actions of a given trigger\r\n * @param trigger defines the trigger to be tested\r\n * @return a boolean indicating whether the trigger is handeled by at least one action manager\r\n **/\r\n AbstractActionManager.HasSpecificTrigger = function (trigger) {\r\n for (var t in AbstractActionManager.Triggers) {\r\n if (AbstractActionManager.Triggers.hasOwnProperty(t)) {\r\n var t_int = parseInt(t);\r\n if (t_int === trigger) {\r\n return true;\r\n }\r\n }\r\n }\r\n return false;\r\n };\r\n /** Gets the list of active triggers */\r\n AbstractActionManager.Triggers = {};\r\n return AbstractActionManager;\r\n}());\r\nexport { AbstractActionManager };\r\n//# sourceMappingURL=abstractActionManager.js.map","import { PointerInfoPre, PointerInfo, PointerEventTypes } from \"../Events/pointerEvents\";\r\nimport { AbstractActionManager } from \"../Actions/abstractActionManager\";\r\nimport { Vector2, Matrix } from \"../Maths/math.vector\";\r\nimport { ActionEvent } from \"../Actions/actionEvent\";\r\nimport { Tools } from \"../Misc/tools\";\r\nimport { KeyboardEventTypes, KeyboardInfoPre, KeyboardInfo } from \"../Events/keyboardEvents\";\r\n/** @hidden */\r\nvar _ClickInfo = /** @class */ (function () {\r\n function _ClickInfo() {\r\n this._singleClick = false;\r\n this._doubleClick = false;\r\n this._hasSwiped = false;\r\n this._ignore = false;\r\n }\r\n Object.defineProperty(_ClickInfo.prototype, \"singleClick\", {\r\n get: function () {\r\n return this._singleClick;\r\n },\r\n set: function (b) {\r\n this._singleClick = b;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(_ClickInfo.prototype, \"doubleClick\", {\r\n get: function () {\r\n return this._doubleClick;\r\n },\r\n set: function (b) {\r\n this._doubleClick = b;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(_ClickInfo.prototype, \"hasSwiped\", {\r\n get: function () {\r\n return this._hasSwiped;\r\n },\r\n set: function (b) {\r\n this._hasSwiped = b;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(_ClickInfo.prototype, \"ignore\", {\r\n get: function () {\r\n return this._ignore;\r\n },\r\n set: function (b) {\r\n this._ignore = b;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n return _ClickInfo;\r\n}());\r\n/**\r\n * Class used to manage all inputs for the scene.\r\n */\r\nvar InputManager = /** @class */ (function () {\r\n /**\r\n * Creates a new InputManager\r\n * @param scene defines the hosting scene\r\n */\r\n function InputManager(scene) {\r\n /** This is a defensive check to not allow control attachment prior to an already active one. If already attached, previous control is unattached before attaching the new one. */\r\n this._alreadyAttached = false;\r\n // Pointers\r\n this._wheelEventName = \"\";\r\n this._meshPickProceed = false;\r\n this._currentPickResult = null;\r\n this._previousPickResult = null;\r\n this._totalPointersPressed = 0;\r\n this._doubleClickOccured = false;\r\n this._pointerX = 0;\r\n this._pointerY = 0;\r\n this._startingPointerPosition = new Vector2(0, 0);\r\n this._previousStartingPointerPosition = new Vector2(0, 0);\r\n this._startingPointerTime = 0;\r\n this._previousStartingPointerTime = 0;\r\n this._pointerCaptures = {};\r\n this._meshUnderPointerId = [];\r\n this._keyboardIsAttached = false;\r\n this._scene = scene;\r\n }\r\n Object.defineProperty(InputManager.prototype, \"meshUnderPointer\", {\r\n /**\r\n * Gets the mesh that is currently under the pointer\r\n */\r\n get: function () {\r\n return this._pointerOverMesh;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * When using more than one pointer (for example in XR) you can get the mesh under the specific pointer\r\n * @param pointerId the pointer id to use\r\n * @returns The mesh under this pointer id or null if not found\r\n */\r\n InputManager.prototype.getMeshUnderPointerByPointerId = function (pointerId) {\r\n return this._meshUnderPointerId[pointerId];\r\n };\r\n Object.defineProperty(InputManager.prototype, \"unTranslatedPointer\", {\r\n /**\r\n * Gets the pointer coordinates in 2D without any translation (ie. straight out of the pointer event)\r\n */\r\n get: function () {\r\n return new Vector2(this._unTranslatedPointerX, this._unTranslatedPointerY);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputManager.prototype, \"pointerX\", {\r\n /**\r\n * Gets or sets the current on-screen X position of the pointer\r\n */\r\n get: function () {\r\n return this._pointerX;\r\n },\r\n set: function (value) {\r\n this._pointerX = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputManager.prototype, \"pointerY\", {\r\n /**\r\n * Gets or sets the current on-screen Y position of the pointer\r\n */\r\n get: function () {\r\n return this._pointerY;\r\n },\r\n set: function (value) {\r\n this._pointerY = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n InputManager.prototype._updatePointerPosition = function (evt) {\r\n var canvasRect = this._scene.getEngine().getInputElementClientRect();\r\n if (!canvasRect) {\r\n return;\r\n }\r\n this._pointerX = evt.clientX - canvasRect.left;\r\n this._pointerY = evt.clientY - canvasRect.top;\r\n this._unTranslatedPointerX = this._pointerX;\r\n this._unTranslatedPointerY = this._pointerY;\r\n };\r\n InputManager.prototype._processPointerMove = function (pickResult, evt) {\r\n var scene = this._scene;\r\n var engine = scene.getEngine();\r\n var canvas = engine.getInputElement();\r\n if (!canvas) {\r\n return;\r\n }\r\n canvas.tabIndex = engine.canvasTabIndex;\r\n // Restore pointer\r\n if (!scene.doNotHandleCursors) {\r\n canvas.style.cursor = scene.defaultCursor;\r\n }\r\n var isMeshPicked = pickResult && pickResult.hit && pickResult.pickedMesh ? true : false;\r\n if (isMeshPicked) {\r\n scene.setPointerOverMesh(pickResult.pickedMesh, evt.pointerId);\r\n if (this._pointerOverMesh && this._pointerOverMesh.actionManager && this._pointerOverMesh.actionManager.hasPointerTriggers) {\r\n if (!scene.doNotHandleCursors) {\r\n if (this._pointerOverMesh.actionManager.hoverCursor) {\r\n canvas.style.cursor = this._pointerOverMesh.actionManager.hoverCursor;\r\n }\r\n else {\r\n canvas.style.cursor = scene.hoverCursor;\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n scene.setPointerOverMesh(null, evt.pointerId);\r\n }\r\n for (var _i = 0, _a = scene._pointerMoveStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n pickResult = step.action(this._unTranslatedPointerX, this._unTranslatedPointerY, pickResult, isMeshPicked, canvas);\r\n }\r\n if (pickResult) {\r\n var type = evt.type === this._wheelEventName ? PointerEventTypes.POINTERWHEEL : PointerEventTypes.POINTERMOVE;\r\n if (scene.onPointerMove) {\r\n scene.onPointerMove(evt, pickResult, type);\r\n }\r\n if (scene.onPointerObservable.hasObservers()) {\r\n var pi = new PointerInfo(type, evt, pickResult);\r\n this._setRayOnPointerInfo(pi);\r\n scene.onPointerObservable.notifyObservers(pi, type);\r\n }\r\n }\r\n };\r\n // Pointers handling\r\n InputManager.prototype._setRayOnPointerInfo = function (pointerInfo) {\r\n var scene = this._scene;\r\n if (pointerInfo.pickInfo && !pointerInfo.pickInfo._pickingUnavailable) {\r\n if (!pointerInfo.pickInfo.ray) {\r\n pointerInfo.pickInfo.ray = scene.createPickingRay(pointerInfo.event.offsetX, pointerInfo.event.offsetY, Matrix.Identity(), scene.activeCamera);\r\n }\r\n }\r\n };\r\n InputManager.prototype._checkPrePointerObservable = function (pickResult, evt, type) {\r\n var scene = this._scene;\r\n var pi = new PointerInfoPre(type, evt, this._unTranslatedPointerX, this._unTranslatedPointerY);\r\n if (pickResult) {\r\n pi.ray = pickResult.ray;\r\n }\r\n scene.onPrePointerObservable.notifyObservers(pi, type);\r\n if (pi.skipOnPointerObservable) {\r\n return true;\r\n }\r\n else {\r\n return false;\r\n }\r\n };\r\n /**\r\n * Use this method to simulate a pointer move on a mesh\r\n * The pickResult parameter can be obtained from a scene.pick or scene.pickWithRay\r\n * @param pickResult pickingInfo of the object wished to simulate pointer event on\r\n * @param pointerEventInit pointer event state to be used when simulating the pointer event (eg. pointer id for multitouch)\r\n */\r\n InputManager.prototype.simulatePointerMove = function (pickResult, pointerEventInit) {\r\n var evt = new PointerEvent(\"pointermove\", pointerEventInit);\r\n if (this._checkPrePointerObservable(pickResult, evt, PointerEventTypes.POINTERMOVE)) {\r\n return;\r\n }\r\n this._processPointerMove(pickResult, evt);\r\n };\r\n /**\r\n * Use this method to simulate a pointer down on a mesh\r\n * The pickResult parameter can be obtained from a scene.pick or scene.pickWithRay\r\n * @param pickResult pickingInfo of the object wished to simulate pointer event on\r\n * @param pointerEventInit pointer event state to be used when simulating the pointer event (eg. pointer id for multitouch)\r\n */\r\n InputManager.prototype.simulatePointerDown = function (pickResult, pointerEventInit) {\r\n var evt = new PointerEvent(\"pointerdown\", pointerEventInit);\r\n if (this._checkPrePointerObservable(pickResult, evt, PointerEventTypes.POINTERDOWN)) {\r\n return;\r\n }\r\n this._processPointerDown(pickResult, evt);\r\n };\r\n InputManager.prototype._processPointerDown = function (pickResult, evt) {\r\n var _this = this;\r\n var scene = this._scene;\r\n if (pickResult && pickResult.hit && pickResult.pickedMesh) {\r\n this._pickedDownMesh = pickResult.pickedMesh;\r\n var actionManager = pickResult.pickedMesh._getActionManagerForTrigger();\r\n if (actionManager) {\r\n if (actionManager.hasPickTriggers) {\r\n actionManager.processTrigger(5, ActionEvent.CreateNew(pickResult.pickedMesh, evt));\r\n switch (evt.button) {\r\n case 0:\r\n actionManager.processTrigger(2, ActionEvent.CreateNew(pickResult.pickedMesh, evt));\r\n break;\r\n case 1:\r\n actionManager.processTrigger(4, ActionEvent.CreateNew(pickResult.pickedMesh, evt));\r\n break;\r\n case 2:\r\n actionManager.processTrigger(3, ActionEvent.CreateNew(pickResult.pickedMesh, evt));\r\n break;\r\n }\r\n }\r\n if (actionManager.hasSpecificTrigger(8)) {\r\n window.setTimeout(function () {\r\n var pickResult = scene.pick(_this._unTranslatedPointerX, _this._unTranslatedPointerY, function (mesh) { return (mesh.isPickable && mesh.isVisible && mesh.isReady() && mesh.actionManager && mesh.actionManager.hasSpecificTrigger(8) && mesh == _this._pickedDownMesh); }, false, scene.cameraToUseForPointers);\r\n if (pickResult && pickResult.hit && pickResult.pickedMesh && actionManager) {\r\n if (_this._totalPointersPressed !== 0 && Date.now() - _this._startingPointerTime > InputManager.LongPressDelay && !_this._isPointerSwiping()) {\r\n _this._startingPointerTime = 0;\r\n actionManager.processTrigger(8, ActionEvent.CreateNew(pickResult.pickedMesh, evt));\r\n }\r\n }\r\n }, InputManager.LongPressDelay);\r\n }\r\n }\r\n }\r\n else {\r\n for (var _i = 0, _a = scene._pointerDownStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n pickResult = step.action(this._unTranslatedPointerX, this._unTranslatedPointerY, pickResult, evt);\r\n }\r\n }\r\n if (pickResult) {\r\n var type = PointerEventTypes.POINTERDOWN;\r\n if (scene.onPointerDown) {\r\n scene.onPointerDown(evt, pickResult, type);\r\n }\r\n if (scene.onPointerObservable.hasObservers()) {\r\n var pi = new PointerInfo(type, evt, pickResult);\r\n this._setRayOnPointerInfo(pi);\r\n scene.onPointerObservable.notifyObservers(pi, type);\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n InputManager.prototype._isPointerSwiping = function () {\r\n return Math.abs(this._startingPointerPosition.x - this._pointerX) > InputManager.DragMovementThreshold || Math.abs(this._startingPointerPosition.y - this._pointerY) > InputManager.DragMovementThreshold;\r\n };\r\n /**\r\n * Use this method to simulate a pointer up on a mesh\r\n * The pickResult parameter can be obtained from a scene.pick or scene.pickWithRay\r\n * @param pickResult pickingInfo of the object wished to simulate pointer event on\r\n * @param pointerEventInit pointer event state to be used when simulating the pointer event (eg. pointer id for multitouch)\r\n * @param doubleTap indicates that the pointer up event should be considered as part of a double click (false by default)\r\n */\r\n InputManager.prototype.simulatePointerUp = function (pickResult, pointerEventInit, doubleTap) {\r\n var evt = new PointerEvent(\"pointerup\", pointerEventInit);\r\n var clickInfo = new _ClickInfo();\r\n if (doubleTap) {\r\n clickInfo.doubleClick = true;\r\n }\r\n else {\r\n clickInfo.singleClick = true;\r\n }\r\n if (this._checkPrePointerObservable(pickResult, evt, PointerEventTypes.POINTERUP)) {\r\n return;\r\n }\r\n this._processPointerUp(pickResult, evt, clickInfo);\r\n };\r\n InputManager.prototype._processPointerUp = function (pickResult, evt, clickInfo) {\r\n var scene = this._scene;\r\n if (pickResult && pickResult && pickResult.pickedMesh) {\r\n this._pickedUpMesh = pickResult.pickedMesh;\r\n if (this._pickedDownMesh === this._pickedUpMesh) {\r\n if (scene.onPointerPick) {\r\n scene.onPointerPick(evt, pickResult);\r\n }\r\n if (clickInfo.singleClick && !clickInfo.ignore && scene.onPointerObservable.hasObservers()) {\r\n var type_1 = PointerEventTypes.POINTERPICK;\r\n var pi = new PointerInfo(type_1, evt, pickResult);\r\n this._setRayOnPointerInfo(pi);\r\n scene.onPointerObservable.notifyObservers(pi, type_1);\r\n }\r\n }\r\n var actionManager = pickResult.pickedMesh._getActionManagerForTrigger();\r\n if (actionManager && !clickInfo.ignore) {\r\n actionManager.processTrigger(7, ActionEvent.CreateNew(pickResult.pickedMesh, evt));\r\n if (!clickInfo.hasSwiped && clickInfo.singleClick) {\r\n actionManager.processTrigger(1, ActionEvent.CreateNew(pickResult.pickedMesh, evt));\r\n }\r\n var doubleClickActionManager = pickResult.pickedMesh._getActionManagerForTrigger(6);\r\n if (clickInfo.doubleClick && doubleClickActionManager) {\r\n doubleClickActionManager.processTrigger(6, ActionEvent.CreateNew(pickResult.pickedMesh, evt));\r\n }\r\n }\r\n }\r\n else {\r\n if (!clickInfo.ignore) {\r\n for (var _i = 0, _a = scene._pointerUpStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n pickResult = step.action(this._unTranslatedPointerX, this._unTranslatedPointerY, pickResult, evt);\r\n }\r\n }\r\n }\r\n if (this._pickedDownMesh && this._pickedDownMesh !== this._pickedUpMesh) {\r\n var pickedDownActionManager = this._pickedDownMesh._getActionManagerForTrigger(16);\r\n if (pickedDownActionManager) {\r\n pickedDownActionManager.processTrigger(16, ActionEvent.CreateNew(this._pickedDownMesh, evt));\r\n }\r\n }\r\n var type = 0;\r\n if (scene.onPointerObservable.hasObservers()) {\r\n if (!clickInfo.ignore && !clickInfo.hasSwiped) {\r\n if (clickInfo.singleClick && scene.onPointerObservable.hasSpecificMask(PointerEventTypes.POINTERTAP)) {\r\n type = PointerEventTypes.POINTERTAP;\r\n }\r\n else if (clickInfo.doubleClick && scene.onPointerObservable.hasSpecificMask(PointerEventTypes.POINTERDOUBLETAP)) {\r\n type = PointerEventTypes.POINTERDOUBLETAP;\r\n }\r\n if (type) {\r\n var pi = new PointerInfo(type, evt, pickResult);\r\n this._setRayOnPointerInfo(pi);\r\n scene.onPointerObservable.notifyObservers(pi, type);\r\n }\r\n }\r\n if (!clickInfo.ignore) {\r\n type = PointerEventTypes.POINTERUP;\r\n var pi = new PointerInfo(type, evt, pickResult);\r\n this._setRayOnPointerInfo(pi);\r\n scene.onPointerObservable.notifyObservers(pi, type);\r\n }\r\n }\r\n if (scene.onPointerUp && !clickInfo.ignore) {\r\n scene.onPointerUp(evt, pickResult, type);\r\n }\r\n };\r\n /**\r\n * Gets a boolean indicating if the current pointer event is captured (meaning that the scene has already handled the pointer down)\r\n * @param pointerId defines the pointer id to use in a multi-touch scenario (0 by default)\r\n * @returns true if the pointer was captured\r\n */\r\n InputManager.prototype.isPointerCaptured = function (pointerId) {\r\n if (pointerId === void 0) { pointerId = 0; }\r\n return this._pointerCaptures[pointerId];\r\n };\r\n /**\r\n * Attach events to the canvas (To handle actionManagers triggers and raise onPointerMove, onPointerDown and onPointerUp\r\n * @param attachUp defines if you want to attach events to pointerup\r\n * @param attachDown defines if you want to attach events to pointerdown\r\n * @param attachMove defines if you want to attach events to pointermove\r\n * @param elementToAttachTo defines the target DOM element to attach to (will use the canvas by default)\r\n */\r\n InputManager.prototype.attachControl = function (attachUp, attachDown, attachMove, elementToAttachTo) {\r\n var _this = this;\r\n if (attachUp === void 0) { attachUp = true; }\r\n if (attachDown === void 0) { attachDown = true; }\r\n if (attachMove === void 0) { attachMove = true; }\r\n if (elementToAttachTo === void 0) { elementToAttachTo = null; }\r\n var scene = this._scene;\r\n if (!elementToAttachTo) {\r\n elementToAttachTo = scene.getEngine().getInputElement();\r\n }\r\n if (!elementToAttachTo) {\r\n return;\r\n }\r\n if (this._alreadyAttached) {\r\n this.detachControl();\r\n }\r\n this._alreadyAttachedTo = elementToAttachTo;\r\n var engine = scene.getEngine();\r\n this._initActionManager = function (act, clickInfo) {\r\n if (!_this._meshPickProceed) {\r\n var pickResult = scene.pick(_this._unTranslatedPointerX, _this._unTranslatedPointerY, scene.pointerDownPredicate, false, scene.cameraToUseForPointers);\r\n _this._currentPickResult = pickResult;\r\n if (pickResult) {\r\n act = pickResult.hit && pickResult.pickedMesh ? pickResult.pickedMesh._getActionManagerForTrigger() : null;\r\n }\r\n _this._meshPickProceed = true;\r\n }\r\n return act;\r\n };\r\n this._delayedSimpleClick = function (btn, clickInfo, cb) {\r\n // double click delay is over and that no double click has been raised since, or the 2 consecutive keys pressed are different\r\n if ((Date.now() - _this._previousStartingPointerTime > InputManager.DoubleClickDelay && !_this._doubleClickOccured) || btn !== _this._previousButtonPressed) {\r\n _this._doubleClickOccured = false;\r\n clickInfo.singleClick = true;\r\n clickInfo.ignore = false;\r\n cb(clickInfo, _this._currentPickResult);\r\n }\r\n };\r\n this._initClickEvent = function (obs1, obs2, evt, cb) {\r\n var clickInfo = new _ClickInfo();\r\n _this._currentPickResult = null;\r\n var act = null;\r\n var checkPicking = obs1.hasSpecificMask(PointerEventTypes.POINTERPICK) ||\r\n obs2.hasSpecificMask(PointerEventTypes.POINTERPICK) ||\r\n obs1.hasSpecificMask(PointerEventTypes.POINTERTAP) ||\r\n obs2.hasSpecificMask(PointerEventTypes.POINTERTAP) ||\r\n obs1.hasSpecificMask(PointerEventTypes.POINTERDOUBLETAP) ||\r\n obs2.hasSpecificMask(PointerEventTypes.POINTERDOUBLETAP);\r\n if (!checkPicking && AbstractActionManager) {\r\n act = _this._initActionManager(act, clickInfo);\r\n if (act) {\r\n checkPicking = act.hasPickTriggers;\r\n }\r\n }\r\n var needToIgnoreNext = false;\r\n if (checkPicking) {\r\n var btn = evt.button;\r\n clickInfo.hasSwiped = _this._isPointerSwiping();\r\n if (!clickInfo.hasSwiped) {\r\n var checkSingleClickImmediately = !InputManager.ExclusiveDoubleClickMode;\r\n if (!checkSingleClickImmediately) {\r\n checkSingleClickImmediately = !obs1.hasSpecificMask(PointerEventTypes.POINTERDOUBLETAP) && !obs2.hasSpecificMask(PointerEventTypes.POINTERDOUBLETAP);\r\n if (checkSingleClickImmediately && !AbstractActionManager.HasSpecificTrigger(6)) {\r\n act = _this._initActionManager(act, clickInfo);\r\n if (act) {\r\n checkSingleClickImmediately = !act.hasSpecificTrigger(6);\r\n }\r\n }\r\n }\r\n if (checkSingleClickImmediately) {\r\n // single click detected if double click delay is over or two different successive keys pressed without exclusive double click or no double click required\r\n if (Date.now() - _this._previousStartingPointerTime > InputManager.DoubleClickDelay || btn !== _this._previousButtonPressed) {\r\n clickInfo.singleClick = true;\r\n cb(clickInfo, _this._currentPickResult);\r\n needToIgnoreNext = true;\r\n }\r\n }\r\n // at least one double click is required to be check and exclusive double click is enabled\r\n else {\r\n // wait that no double click has been raised during the double click delay\r\n _this._previousDelayedSimpleClickTimeout = _this._delayedSimpleClickTimeout;\r\n _this._delayedSimpleClickTimeout = window.setTimeout(_this._delayedSimpleClick.bind(_this, btn, clickInfo, cb), InputManager.DoubleClickDelay);\r\n }\r\n var checkDoubleClick = obs1.hasSpecificMask(PointerEventTypes.POINTERDOUBLETAP) || obs2.hasSpecificMask(PointerEventTypes.POINTERDOUBLETAP);\r\n if (!checkDoubleClick && AbstractActionManager.HasSpecificTrigger(6)) {\r\n act = _this._initActionManager(act, clickInfo);\r\n if (act) {\r\n checkDoubleClick = act.hasSpecificTrigger(6);\r\n }\r\n }\r\n if (checkDoubleClick) {\r\n // two successive keys pressed are equal, double click delay is not over and double click has not just occurred\r\n if (btn === _this._previousButtonPressed && Date.now() - _this._previousStartingPointerTime < InputManager.DoubleClickDelay && !_this._doubleClickOccured) {\r\n // pointer has not moved for 2 clicks, it's a double click\r\n if (!clickInfo.hasSwiped && !_this._isPointerSwiping()) {\r\n _this._previousStartingPointerTime = 0;\r\n _this._doubleClickOccured = true;\r\n clickInfo.doubleClick = true;\r\n clickInfo.ignore = false;\r\n if (InputManager.ExclusiveDoubleClickMode && _this._previousDelayedSimpleClickTimeout) {\r\n clearTimeout(_this._previousDelayedSimpleClickTimeout);\r\n }\r\n _this._previousDelayedSimpleClickTimeout = _this._delayedSimpleClickTimeout;\r\n cb(clickInfo, _this._currentPickResult);\r\n }\r\n // if the two successive clicks are too far, it's just two simple clicks\r\n else {\r\n _this._doubleClickOccured = false;\r\n _this._previousStartingPointerTime = _this._startingPointerTime;\r\n _this._previousStartingPointerPosition.x = _this._startingPointerPosition.x;\r\n _this._previousStartingPointerPosition.y = _this._startingPointerPosition.y;\r\n _this._previousButtonPressed = btn;\r\n if (InputManager.ExclusiveDoubleClickMode) {\r\n if (_this._previousDelayedSimpleClickTimeout) {\r\n clearTimeout(_this._previousDelayedSimpleClickTimeout);\r\n }\r\n _this._previousDelayedSimpleClickTimeout = _this._delayedSimpleClickTimeout;\r\n cb(clickInfo, _this._previousPickResult);\r\n }\r\n else {\r\n cb(clickInfo, _this._currentPickResult);\r\n }\r\n }\r\n needToIgnoreNext = true;\r\n }\r\n // just the first click of the double has been raised\r\n else {\r\n _this._doubleClickOccured = false;\r\n _this._previousStartingPointerTime = _this._startingPointerTime;\r\n _this._previousStartingPointerPosition.x = _this._startingPointerPosition.x;\r\n _this._previousStartingPointerPosition.y = _this._startingPointerPosition.y;\r\n _this._previousButtonPressed = btn;\r\n }\r\n }\r\n }\r\n }\r\n if (!needToIgnoreNext) {\r\n cb(clickInfo, _this._currentPickResult);\r\n }\r\n };\r\n this._onPointerMove = function (evt) {\r\n // preserve compatibility with Safari when pointerId is not present\r\n if (evt.pointerId === undefined) {\r\n evt.pointerId = 0;\r\n }\r\n _this._updatePointerPosition(evt);\r\n // PreObservable support\r\n if (_this._checkPrePointerObservable(null, evt, evt.type === _this._wheelEventName ? PointerEventTypes.POINTERWHEEL : PointerEventTypes.POINTERMOVE)) {\r\n return;\r\n }\r\n if (!scene.cameraToUseForPointers && !scene.activeCamera) {\r\n return;\r\n }\r\n if (!scene.pointerMovePredicate) {\r\n scene.pointerMovePredicate = function (mesh) {\r\n return mesh.isPickable &&\r\n mesh.isVisible &&\r\n mesh.isReady() &&\r\n mesh.isEnabled() &&\r\n (mesh.enablePointerMoveEvents || scene.constantlyUpdateMeshUnderPointer || mesh._getActionManagerForTrigger() != null) &&\r\n (!scene.cameraToUseForPointers || (scene.cameraToUseForPointers.layerMask & mesh.layerMask) !== 0);\r\n };\r\n }\r\n // Meshes\r\n var pickResult = scene.pick(_this._unTranslatedPointerX, _this._unTranslatedPointerY, scene.pointerMovePredicate, false, scene.cameraToUseForPointers);\r\n _this._processPointerMove(pickResult, evt);\r\n };\r\n this._onPointerDown = function (evt) {\r\n _this._totalPointersPressed++;\r\n _this._pickedDownMesh = null;\r\n _this._meshPickProceed = false;\r\n // preserve compatibility with Safari when pointerId is not present\r\n if (evt.pointerId === undefined) {\r\n evt.pointerId = 0;\r\n }\r\n _this._updatePointerPosition(evt);\r\n if (scene.preventDefaultOnPointerDown && elementToAttachTo) {\r\n evt.preventDefault();\r\n elementToAttachTo.focus();\r\n }\r\n _this._startingPointerPosition.x = _this._pointerX;\r\n _this._startingPointerPosition.y = _this._pointerY;\r\n _this._startingPointerTime = Date.now();\r\n // PreObservable support\r\n if (_this._checkPrePointerObservable(null, evt, PointerEventTypes.POINTERDOWN)) {\r\n return;\r\n }\r\n if (!scene.cameraToUseForPointers && !scene.activeCamera) {\r\n return;\r\n }\r\n _this._pointerCaptures[evt.pointerId] = true;\r\n if (!scene.pointerDownPredicate) {\r\n scene.pointerDownPredicate = function (mesh) {\r\n return mesh.isPickable && mesh.isVisible && mesh.isReady() && mesh.isEnabled() && (!scene.cameraToUseForPointers || (scene.cameraToUseForPointers.layerMask & mesh.layerMask) !== 0);\r\n };\r\n }\r\n // Meshes\r\n _this._pickedDownMesh = null;\r\n var pickResult = scene.pick(_this._unTranslatedPointerX, _this._unTranslatedPointerY, scene.pointerDownPredicate, false, scene.cameraToUseForPointers);\r\n _this._processPointerDown(pickResult, evt);\r\n };\r\n this._onPointerUp = function (evt) {\r\n if (_this._totalPointersPressed === 0) {\r\n // We are attaching the pointer up to windows because of a bug in FF\r\n return; // So we need to test it the pointer down was pressed before.\r\n }\r\n _this._totalPointersPressed--;\r\n _this._pickedUpMesh = null;\r\n _this._meshPickProceed = false;\r\n // preserve compatibility with Safari when pointerId is not present\r\n if (evt.pointerId === undefined) {\r\n evt.pointerId = 0;\r\n }\r\n _this._updatePointerPosition(evt);\r\n if (scene.preventDefaultOnPointerUp && elementToAttachTo) {\r\n evt.preventDefault();\r\n elementToAttachTo.focus();\r\n }\r\n _this._initClickEvent(scene.onPrePointerObservable, scene.onPointerObservable, evt, function (clickInfo, pickResult) {\r\n // PreObservable support\r\n if (scene.onPrePointerObservable.hasObservers()) {\r\n if (!clickInfo.ignore) {\r\n if (!clickInfo.hasSwiped) {\r\n if (clickInfo.singleClick && scene.onPrePointerObservable.hasSpecificMask(PointerEventTypes.POINTERTAP)) {\r\n if (_this._checkPrePointerObservable(null, evt, PointerEventTypes.POINTERTAP)) {\r\n return;\r\n }\r\n }\r\n if (clickInfo.doubleClick && scene.onPrePointerObservable.hasSpecificMask(PointerEventTypes.POINTERDOUBLETAP)) {\r\n if (_this._checkPrePointerObservable(null, evt, PointerEventTypes.POINTERDOUBLETAP)) {\r\n return;\r\n }\r\n }\r\n }\r\n if (_this._checkPrePointerObservable(null, evt, PointerEventTypes.POINTERUP)) {\r\n return;\r\n }\r\n }\r\n }\r\n if (!_this._pointerCaptures[evt.pointerId]) {\r\n return;\r\n }\r\n _this._pointerCaptures[evt.pointerId] = false;\r\n if (!scene.cameraToUseForPointers && !scene.activeCamera) {\r\n return;\r\n }\r\n if (!scene.pointerUpPredicate) {\r\n scene.pointerUpPredicate = function (mesh) {\r\n return mesh.isPickable && mesh.isVisible && mesh.isReady() && mesh.isEnabled() && (!scene.cameraToUseForPointers || (scene.cameraToUseForPointers.layerMask & mesh.layerMask) !== 0);\r\n };\r\n }\r\n // Meshes\r\n if (!_this._meshPickProceed && ((AbstractActionManager && AbstractActionManager.HasTriggers) || scene.onPointerObservable.hasObservers())) {\r\n _this._initActionManager(null, clickInfo);\r\n }\r\n if (!pickResult) {\r\n pickResult = _this._currentPickResult;\r\n }\r\n _this._processPointerUp(pickResult, evt, clickInfo);\r\n _this._previousPickResult = _this._currentPickResult;\r\n });\r\n };\r\n this._onKeyDown = function (evt) {\r\n var type = KeyboardEventTypes.KEYDOWN;\r\n if (scene.onPreKeyboardObservable.hasObservers()) {\r\n var pi = new KeyboardInfoPre(type, evt);\r\n scene.onPreKeyboardObservable.notifyObservers(pi, type);\r\n if (pi.skipOnPointerObservable) {\r\n return;\r\n }\r\n }\r\n if (scene.onKeyboardObservable.hasObservers()) {\r\n var pi = new KeyboardInfo(type, evt);\r\n scene.onKeyboardObservable.notifyObservers(pi, type);\r\n }\r\n if (scene.actionManager) {\r\n scene.actionManager.processTrigger(14, ActionEvent.CreateNewFromScene(scene, evt));\r\n }\r\n };\r\n this._onKeyUp = function (evt) {\r\n var type = KeyboardEventTypes.KEYUP;\r\n if (scene.onPreKeyboardObservable.hasObservers()) {\r\n var pi = new KeyboardInfoPre(type, evt);\r\n scene.onPreKeyboardObservable.notifyObservers(pi, type);\r\n if (pi.skipOnPointerObservable) {\r\n return;\r\n }\r\n }\r\n if (scene.onKeyboardObservable.hasObservers()) {\r\n var pi = new KeyboardInfo(type, evt);\r\n scene.onKeyboardObservable.notifyObservers(pi, type);\r\n }\r\n if (scene.actionManager) {\r\n scene.actionManager.processTrigger(15, ActionEvent.CreateNewFromScene(scene, evt));\r\n }\r\n };\r\n var attachedFunction = function () {\r\n if (!elementToAttachTo || _this._keyboardIsAttached) {\r\n return;\r\n }\r\n elementToAttachTo.addEventListener(\"keydown\", _this._onKeyDown, false);\r\n elementToAttachTo.addEventListener(\"keyup\", _this._onKeyUp, false);\r\n _this._keyboardIsAttached = true;\r\n };\r\n // Keyboard events\r\n this._onCanvasFocusObserver = engine.onCanvasFocusObservable.add((function () {\r\n if (document.activeElement === elementToAttachTo) {\r\n attachedFunction();\r\n }\r\n return attachedFunction;\r\n })());\r\n this._onCanvasBlurObserver = engine.onCanvasBlurObservable.add(function () {\r\n if (!elementToAttachTo) {\r\n return;\r\n }\r\n elementToAttachTo.removeEventListener(\"keydown\", _this._onKeyDown);\r\n elementToAttachTo.removeEventListener(\"keyup\", _this._onKeyUp);\r\n _this._keyboardIsAttached = false;\r\n });\r\n attachedFunction();\r\n // Pointer events\r\n var eventPrefix = Tools.GetPointerPrefix(engine);\r\n if (attachMove) {\r\n elementToAttachTo.addEventListener(eventPrefix + \"move\", this._onPointerMove, false);\r\n // Wheel\r\n this._wheelEventName =\r\n \"onwheel\" in document.createElement(\"div\")\r\n ? \"wheel\" // Modern browsers support \"wheel\"\r\n : document.onmousewheel !== undefined\r\n ? \"mousewheel\" // Webkit and IE support at least \"mousewheel\"\r\n : \"DOMMouseScroll\"; // let's assume that remaining browsers are older Firefox\r\n elementToAttachTo.addEventListener(this._wheelEventName, this._onPointerMove, false);\r\n }\r\n if (attachDown) {\r\n elementToAttachTo.addEventListener(eventPrefix + \"down\", this._onPointerDown, false);\r\n }\r\n if (attachUp) {\r\n var hostWindow = scene.getEngine().getHostWindow();\r\n if (hostWindow) {\r\n hostWindow.addEventListener(eventPrefix + \"up\", this._onPointerUp, false);\r\n }\r\n }\r\n this._alreadyAttached = true;\r\n };\r\n /**\r\n * Detaches all event handlers\r\n */\r\n InputManager.prototype.detachControl = function () {\r\n var engine = this._scene.getEngine();\r\n var eventPrefix = Tools.GetPointerPrefix(engine);\r\n if (!this._alreadyAttachedTo) {\r\n return;\r\n }\r\n if (!this._alreadyAttached) {\r\n return;\r\n }\r\n // Pointer\r\n this._alreadyAttachedTo.removeEventListener(eventPrefix + \"move\", this._onPointerMove);\r\n this._alreadyAttachedTo.removeEventListener(this._wheelEventName, this._onPointerMove);\r\n this._alreadyAttachedTo.removeEventListener(eventPrefix + \"down\", this._onPointerDown);\r\n window.removeEventListener(eventPrefix + \"up\", this._onPointerUp);\r\n // Blur / Focus\r\n if (this._onCanvasBlurObserver) {\r\n engine.onCanvasBlurObservable.remove(this._onCanvasBlurObserver);\r\n }\r\n if (this._onCanvasFocusObserver) {\r\n engine.onCanvasFocusObservable.remove(this._onCanvasFocusObserver);\r\n }\r\n // Keyboard\r\n this._alreadyAttachedTo.removeEventListener(\"keydown\", this._onKeyDown);\r\n this._alreadyAttachedTo.removeEventListener(\"keyup\", this._onKeyUp);\r\n // Cursor\r\n if (!this._scene.doNotHandleCursors) {\r\n this._alreadyAttachedTo.style.cursor = this._scene.defaultCursor;\r\n }\r\n this._alreadyAttached = false;\r\n };\r\n /**\r\n * Force the value of meshUnderPointer\r\n * @param mesh defines the mesh to use\r\n * @param pointerId optional pointer id when using more than one pointer. Defaults to 0\r\n */\r\n InputManager.prototype.setPointerOverMesh = function (mesh, pointerId) {\r\n if (pointerId === void 0) { pointerId = 0; }\r\n // Sanity check\r\n if (pointerId < 0) {\r\n pointerId = 0;\r\n }\r\n if (this._meshUnderPointerId[pointerId] === mesh) {\r\n return;\r\n }\r\n var underPointerMesh = this._meshUnderPointerId[pointerId];\r\n var actionManager;\r\n if (underPointerMesh) {\r\n actionManager = underPointerMesh._getActionManagerForTrigger(10);\r\n if (actionManager) {\r\n actionManager.processTrigger(10, ActionEvent.CreateNew(underPointerMesh, undefined, { pointerId: pointerId }));\r\n }\r\n }\r\n this._meshUnderPointerId[pointerId] = mesh;\r\n this._pointerOverMesh = mesh;\r\n underPointerMesh = this._meshUnderPointerId[pointerId];\r\n if (underPointerMesh) {\r\n actionManager = underPointerMesh._getActionManagerForTrigger(9);\r\n if (actionManager) {\r\n actionManager.processTrigger(9, ActionEvent.CreateNew(underPointerMesh, undefined, { pointerId: pointerId }));\r\n }\r\n }\r\n };\r\n /**\r\n * Gets the mesh under the pointer\r\n * @returns a Mesh or null if no mesh is under the pointer\r\n */\r\n InputManager.prototype.getPointerOverMesh = function () {\r\n return this._pointerOverMesh;\r\n };\r\n /** The distance in pixel that you have to move to prevent some events */\r\n InputManager.DragMovementThreshold = 10; // in pixels\r\n /** Time in milliseconds to wait to raise long press events if button is still pressed */\r\n InputManager.LongPressDelay = 500; // in milliseconds\r\n /** Time in milliseconds with two consecutive clicks will be considered as a double click */\r\n InputManager.DoubleClickDelay = 300; // in milliseconds\r\n /** If you need to check double click without raising a single click at first click, enable this flag */\r\n InputManager.ExclusiveDoubleClickMode = false;\r\n return InputManager;\r\n}());\r\nexport { InputManager };\r\n//# sourceMappingURL=scene.inputManager.js.map","/**\r\n * Helper class used to generate session unique ID\r\n */\r\nvar UniqueIdGenerator = /** @class */ (function () {\r\n function UniqueIdGenerator() {\r\n }\r\n Object.defineProperty(UniqueIdGenerator, \"UniqueId\", {\r\n /**\r\n * Gets an unique (relatively to the current scene) Id\r\n */\r\n get: function () {\r\n var result = this._UniqueIdCounter;\r\n this._UniqueIdCounter++;\r\n return result;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n // Statics\r\n UniqueIdGenerator._UniqueIdCounter = 0;\r\n return UniqueIdGenerator;\r\n}());\r\nexport { UniqueIdGenerator };\r\n//# sourceMappingURL=uniqueIdGenerator.js.map","import { __assign, __extends } from \"tslib\";\r\nimport { Tools } from \"./Misc/tools\";\r\nimport { PrecisionDate } from \"./Misc/precisionDate\";\r\nimport { Observable } from \"./Misc/observable\";\r\nimport { SmartArrayNoDuplicate, SmartArray } from \"./Misc/smartArray\";\r\nimport { StringDictionary } from \"./Misc/stringDictionary\";\r\nimport { Tags } from \"./Misc/tags\";\r\nimport { Vector3, Matrix } from \"./Maths/math.vector\";\r\nimport { TransformNode } from \"./Meshes/transformNode\";\r\nimport { AbstractMesh } from \"./Meshes/abstractMesh\";\r\nimport { Camera } from \"./Cameras/camera\";\r\nimport { AbstractScene } from \"./abstractScene\";\r\nimport { ImageProcessingConfiguration } from \"./Materials/imageProcessingConfiguration\";\r\nimport { UniformBuffer } from \"./Materials/uniformBuffer\";\r\nimport { Light } from \"./Lights/light\";\r\nimport { PickingInfo } from \"./Collisions/pickingInfo\";\r\nimport { ActionEvent } from \"./Actions/actionEvent\";\r\nimport { PostProcessManager } from \"./PostProcesses/postProcessManager\";\r\nimport { RenderingManager } from \"./Rendering/renderingManager\";\r\nimport { Stage } from \"./sceneComponent\";\r\nimport { DomManagement } from \"./Misc/domManagement\";\r\nimport { Logger } from \"./Misc/logger\";\r\nimport { EngineStore } from \"./Engines/engineStore\";\r\nimport { _DevTools } from './Misc/devTools';\r\nimport { InputManager } from './Inputs/scene.inputManager';\r\nimport { PerfCounter } from './Misc/perfCounter';\r\nimport { Color4, Color3 } from './Maths/math.color';\r\nimport { Frustum } from './Maths/math.frustum';\r\nimport { UniqueIdGenerator } from './Misc/uniqueIdGenerator';\r\nimport { FileTools } from './Misc/fileTools';\r\n/**\r\n * Represents a scene to be rendered by the engine.\r\n * @see https://doc.babylonjs.com/features/scene\r\n */\r\nvar Scene = /** @class */ (function (_super) {\r\n __extends(Scene, _super);\r\n /**\r\n * Creates a new Scene\r\n * @param engine defines the engine to use to render this scene\r\n * @param options defines the scene options\r\n */\r\n function Scene(engine, options) {\r\n var _this = _super.call(this) || this;\r\n // Members\r\n /** @hidden */\r\n _this._inputManager = new InputManager(_this);\r\n /** Define this parameter if you are using multiple cameras and you want to specify which one should be used for pointer position */\r\n _this.cameraToUseForPointers = null;\r\n /** @hidden */\r\n _this._isScene = true;\r\n /** @hidden */\r\n _this._blockEntityCollection = false;\r\n /**\r\n * Gets or sets a boolean that indicates if the scene must clear the render buffer before rendering a frame\r\n */\r\n _this.autoClear = true;\r\n /**\r\n * Gets or sets a boolean that indicates if the scene must clear the depth and stencil buffers before rendering a frame\r\n */\r\n _this.autoClearDepthAndStencil = true;\r\n /**\r\n * Defines the color used to clear the render buffer (Default is (0.2, 0.2, 0.3, 1.0))\r\n */\r\n _this.clearColor = new Color4(0.2, 0.2, 0.3, 1.0);\r\n /**\r\n * Defines the color used to simulate the ambient color (Default is (0, 0, 0))\r\n */\r\n _this.ambientColor = new Color3(0, 0, 0);\r\n /** @hidden */\r\n _this._environmentIntensity = 1;\r\n _this._forceWireframe = false;\r\n _this._skipFrustumClipping = false;\r\n _this._forcePointsCloud = false;\r\n /**\r\n * Gets or sets a boolean indicating if animations are enabled\r\n */\r\n _this.animationsEnabled = true;\r\n _this._animationPropertiesOverride = null;\r\n /**\r\n * Gets or sets a boolean indicating if a constant deltatime has to be used\r\n * This is mostly useful for testing purposes when you do not want the animations to scale with the framerate\r\n */\r\n _this.useConstantAnimationDeltaTime = false;\r\n /**\r\n * Gets or sets a boolean indicating if the scene must keep the meshUnderPointer property updated\r\n * Please note that it requires to run a ray cast through the scene on every frame\r\n */\r\n _this.constantlyUpdateMeshUnderPointer = false;\r\n /**\r\n * Defines the HTML cursor to use when hovering over interactive elements\r\n */\r\n _this.hoverCursor = \"pointer\";\r\n /**\r\n * Defines the HTML default cursor to use (empty by default)\r\n */\r\n _this.defaultCursor = \"\";\r\n /**\r\n * Defines whether cursors are handled by the scene.\r\n */\r\n _this.doNotHandleCursors = false;\r\n /**\r\n * This is used to call preventDefault() on pointer down\r\n * in order to block unwanted artifacts like system double clicks\r\n */\r\n _this.preventDefaultOnPointerDown = true;\r\n /**\r\n * This is used to call preventDefault() on pointer up\r\n * in order to block unwanted artifacts like system double clicks\r\n */\r\n _this.preventDefaultOnPointerUp = true;\r\n // Metadata\r\n /**\r\n * Gets or sets user defined metadata\r\n */\r\n _this.metadata = null;\r\n /**\r\n * For internal use only. Please do not use.\r\n */\r\n _this.reservedDataStore = null;\r\n /**\r\n * Use this array to add regular expressions used to disable offline support for specific urls\r\n */\r\n _this.disableOfflineSupportExceptionRules = new Array();\r\n /**\r\n * An event triggered when the scene is disposed.\r\n */\r\n _this.onDisposeObservable = new Observable();\r\n _this._onDisposeObserver = null;\r\n /**\r\n * An event triggered before rendering the scene (right after animations and physics)\r\n */\r\n _this.onBeforeRenderObservable = new Observable();\r\n _this._onBeforeRenderObserver = null;\r\n /**\r\n * An event triggered after rendering the scene\r\n */\r\n _this.onAfterRenderObservable = new Observable();\r\n /**\r\n * An event triggered after rendering the scene for an active camera (When scene.render is called this will be called after each camera)\r\n */\r\n _this.onAfterRenderCameraObservable = new Observable();\r\n _this._onAfterRenderObserver = null;\r\n /**\r\n * An event triggered before animating the scene\r\n */\r\n _this.onBeforeAnimationsObservable = new Observable();\r\n /**\r\n * An event triggered after animations processing\r\n */\r\n _this.onAfterAnimationsObservable = new Observable();\r\n /**\r\n * An event triggered before draw calls are ready to be sent\r\n */\r\n _this.onBeforeDrawPhaseObservable = new Observable();\r\n /**\r\n * An event triggered after draw calls have been sent\r\n */\r\n _this.onAfterDrawPhaseObservable = new Observable();\r\n /**\r\n * An event triggered when the scene is ready\r\n */\r\n _this.onReadyObservable = new Observable();\r\n /**\r\n * An event triggered before rendering a camera\r\n */\r\n _this.onBeforeCameraRenderObservable = new Observable();\r\n _this._onBeforeCameraRenderObserver = null;\r\n /**\r\n * An event triggered after rendering a camera\r\n */\r\n _this.onAfterCameraRenderObservable = new Observable();\r\n _this._onAfterCameraRenderObserver = null;\r\n /**\r\n * An event triggered when active meshes evaluation is about to start\r\n */\r\n _this.onBeforeActiveMeshesEvaluationObservable = new Observable();\r\n /**\r\n * An event triggered when active meshes evaluation is done\r\n */\r\n _this.onAfterActiveMeshesEvaluationObservable = new Observable();\r\n /**\r\n * An event triggered when particles rendering is about to start\r\n * Note: This event can be trigger more than once per frame (because particles can be rendered by render target textures as well)\r\n */\r\n _this.onBeforeParticlesRenderingObservable = new Observable();\r\n /**\r\n * An event triggered when particles rendering is done\r\n * Note: This event can be trigger more than once per frame (because particles can be rendered by render target textures as well)\r\n */\r\n _this.onAfterParticlesRenderingObservable = new Observable();\r\n /**\r\n * An event triggered when SceneLoader.Append or SceneLoader.Load or SceneLoader.ImportMesh were successfully executed\r\n */\r\n _this.onDataLoadedObservable = new Observable();\r\n /**\r\n * An event triggered when a camera is created\r\n */\r\n _this.onNewCameraAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a camera is removed\r\n */\r\n _this.onCameraRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when a light is created\r\n */\r\n _this.onNewLightAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a light is removed\r\n */\r\n _this.onLightRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when a geometry is created\r\n */\r\n _this.onNewGeometryAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a geometry is removed\r\n */\r\n _this.onGeometryRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when a transform node is created\r\n */\r\n _this.onNewTransformNodeAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a transform node is removed\r\n */\r\n _this.onTransformNodeRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when a mesh is created\r\n */\r\n _this.onNewMeshAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a mesh is removed\r\n */\r\n _this.onMeshRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when a skeleton is created\r\n */\r\n _this.onNewSkeletonAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a skeleton is removed\r\n */\r\n _this.onSkeletonRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when a material is created\r\n */\r\n _this.onNewMaterialAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a multi material is created\r\n */\r\n _this.onNewMultiMaterialAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a material is removed\r\n */\r\n _this.onMaterialRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when a multi material is removed\r\n */\r\n _this.onMultiMaterialRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when a texture is created\r\n */\r\n _this.onNewTextureAddedObservable = new Observable();\r\n /**\r\n * An event triggered when a texture is removed\r\n */\r\n _this.onTextureRemovedObservable = new Observable();\r\n /**\r\n * An event triggered when render targets are about to be rendered\r\n * Can happen multiple times per frame.\r\n */\r\n _this.onBeforeRenderTargetsRenderObservable = new Observable();\r\n /**\r\n * An event triggered when render targets were rendered.\r\n * Can happen multiple times per frame.\r\n */\r\n _this.onAfterRenderTargetsRenderObservable = new Observable();\r\n /**\r\n * An event triggered before calculating deterministic simulation step\r\n */\r\n _this.onBeforeStepObservable = new Observable();\r\n /**\r\n * An event triggered after calculating deterministic simulation step\r\n */\r\n _this.onAfterStepObservable = new Observable();\r\n /**\r\n * An event triggered when the activeCamera property is updated\r\n */\r\n _this.onActiveCameraChanged = new Observable();\r\n /**\r\n * This Observable will be triggered before rendering each renderingGroup of each rendered camera.\r\n * The RenderinGroupInfo class contains all the information about the context in which the observable is called\r\n * If you wish to register an Observer only for a given set of renderingGroup, use the mask with a combination of the renderingGroup index elevated to the power of two (1 for renderingGroup 0, 2 for renderingrOup1, 4 for 2 and 8 for 3)\r\n */\r\n _this.onBeforeRenderingGroupObservable = new Observable();\r\n /**\r\n * This Observable will be triggered after rendering each renderingGroup of each rendered camera.\r\n * The RenderinGroupInfo class contains all the information about the context in which the observable is called\r\n * If you wish to register an Observer only for a given set of renderingGroup, use the mask with a combination of the renderingGroup index elevated to the power of two (1 for renderingGroup 0, 2 for renderingrOup1, 4 for 2 and 8 for 3)\r\n */\r\n _this.onAfterRenderingGroupObservable = new Observable();\r\n /**\r\n * This Observable will when a mesh has been imported into the scene.\r\n */\r\n _this.onMeshImportedObservable = new Observable();\r\n /**\r\n * This Observable will when an animation file has been imported into the scene.\r\n */\r\n _this.onAnimationFileImportedObservable = new Observable();\r\n // Animations\r\n /** @hidden */\r\n _this._registeredForLateAnimationBindings = new SmartArrayNoDuplicate(256);\r\n /**\r\n * This observable event is triggered when any ponter event is triggered. It is registered during Scene.attachControl() and it is called BEFORE the 3D engine process anything (mesh/sprite picking for instance).\r\n * You have the possibility to skip the process and the call to onPointerObservable by setting PointerInfoPre.skipOnPointerObservable to true\r\n */\r\n _this.onPrePointerObservable = new Observable();\r\n /**\r\n * Observable event triggered each time an input event is received from the rendering canvas\r\n */\r\n _this.onPointerObservable = new Observable();\r\n // Keyboard\r\n /**\r\n * This observable event is triggered when any keyboard event si raised and registered during Scene.attachControl()\r\n * You have the possibility to skip the process and the call to onKeyboardObservable by setting KeyboardInfoPre.skipOnPointerObservable to true\r\n */\r\n _this.onPreKeyboardObservable = new Observable();\r\n /**\r\n * Observable event triggered each time an keyboard event is received from the hosting window\r\n */\r\n _this.onKeyboardObservable = new Observable();\r\n // Coordinates system\r\n _this._useRightHandedSystem = false;\r\n // Deterministic lockstep\r\n _this._timeAccumulator = 0;\r\n _this._currentStepId = 0;\r\n _this._currentInternalStep = 0;\r\n // Fog\r\n _this._fogEnabled = true;\r\n _this._fogMode = Scene.FOGMODE_NONE;\r\n /**\r\n * Gets or sets the fog color to use\r\n * @see https://doc.babylonjs.com/babylon101/environment#fog\r\n * (Default is Color3(0.2, 0.2, 0.3))\r\n */\r\n _this.fogColor = new Color3(0.2, 0.2, 0.3);\r\n /**\r\n * Gets or sets the fog density to use\r\n * @see https://doc.babylonjs.com/babylon101/environment#fog\r\n * (Default is 0.1)\r\n */\r\n _this.fogDensity = 0.1;\r\n /**\r\n * Gets or sets the fog start distance to use\r\n * @see https://doc.babylonjs.com/babylon101/environment#fog\r\n * (Default is 0)\r\n */\r\n _this.fogStart = 0;\r\n /**\r\n * Gets or sets the fog end distance to use\r\n * @see https://doc.babylonjs.com/babylon101/environment#fog\r\n * (Default is 1000)\r\n */\r\n _this.fogEnd = 1000.0;\r\n /**\r\n * Flag indicating that the frame buffer binding is handled by another component\r\n */\r\n _this.prePass = false;\r\n // Lights\r\n _this._shadowsEnabled = true;\r\n _this._lightsEnabled = true;\r\n /** All of the active cameras added to this scene. */\r\n _this.activeCameras = new Array();\r\n // Textures\r\n _this._texturesEnabled = true;\r\n // Physics\r\n /**\r\n * Gets or sets a boolean indicating if physic engines are enabled on this scene\r\n */\r\n _this.physicsEnabled = true;\r\n // Particles\r\n /**\r\n * Gets or sets a boolean indicating if particles are enabled on this scene\r\n */\r\n _this.particlesEnabled = true;\r\n // Sprites\r\n /**\r\n * Gets or sets a boolean indicating if sprites are enabled on this scene\r\n */\r\n _this.spritesEnabled = true;\r\n // Skeletons\r\n _this._skeletonsEnabled = true;\r\n // Lens flares\r\n /**\r\n * Gets or sets a boolean indicating if lens flares are enabled on this scene\r\n */\r\n _this.lensFlaresEnabled = true;\r\n // Collisions\r\n /**\r\n * Gets or sets a boolean indicating if collisions are enabled on this scene\r\n * @see https://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity\r\n */\r\n _this.collisionsEnabled = true;\r\n /**\r\n * Defines the gravity applied to this scene (used only for collisions)\r\n * @see https://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity\r\n */\r\n _this.gravity = new Vector3(0, -9.807, 0);\r\n // Postprocesses\r\n /**\r\n * Gets or sets a boolean indicating if postprocesses are enabled on this scene\r\n */\r\n _this.postProcessesEnabled = true;\r\n // Customs render targets\r\n /**\r\n * Gets or sets a boolean indicating if render targets are enabled on this scene\r\n */\r\n _this.renderTargetsEnabled = true;\r\n /**\r\n * Gets or sets a boolean indicating if next render targets must be dumped as image for debugging purposes\r\n * We recommend not using it and instead rely on Spector.js: http://spector.babylonjs.com\r\n */\r\n _this.dumpNextRenderTargets = false;\r\n /**\r\n * The list of user defined render targets added to the scene\r\n */\r\n _this.customRenderTargets = new Array();\r\n /**\r\n * Gets the list of meshes imported to the scene through SceneLoader\r\n */\r\n _this.importedMeshesFiles = new Array();\r\n // Probes\r\n /**\r\n * Gets or sets a boolean indicating if probes are enabled on this scene\r\n */\r\n _this.probesEnabled = true;\r\n _this._meshesForIntersections = new SmartArrayNoDuplicate(256);\r\n // Procedural textures\r\n /**\r\n * Gets or sets a boolean indicating if procedural textures are enabled on this scene\r\n */\r\n _this.proceduralTexturesEnabled = true;\r\n // Performance counters\r\n _this._totalVertices = new PerfCounter();\r\n /** @hidden */\r\n _this._activeIndices = new PerfCounter();\r\n /** @hidden */\r\n _this._activeParticles = new PerfCounter();\r\n /** @hidden */\r\n _this._activeBones = new PerfCounter();\r\n /** @hidden */\r\n _this._animationTime = 0;\r\n /**\r\n * Gets or sets a general scale for animation speed\r\n * @see https://www.babylonjs-playground.com/#IBU2W7#3\r\n */\r\n _this.animationTimeScale = 1;\r\n _this._renderId = 0;\r\n _this._frameId = 0;\r\n _this._executeWhenReadyTimeoutId = -1;\r\n _this._intermediateRendering = false;\r\n _this._viewUpdateFlag = -1;\r\n _this._projectionUpdateFlag = -1;\r\n /** @hidden */\r\n _this._toBeDisposed = new Array(256);\r\n _this._activeRequests = new Array();\r\n /** @hidden */\r\n _this._pendingData = new Array();\r\n _this._isDisposed = false;\r\n /**\r\n * Gets or sets a boolean indicating that all submeshes of active meshes must be rendered\r\n * Use this boolean to avoid computing frustum clipping on submeshes (This could help when you are CPU bound)\r\n */\r\n _this.dispatchAllSubMeshesOfActiveMeshes = false;\r\n _this._activeMeshes = new SmartArray(256);\r\n _this._processedMaterials = new SmartArray(256);\r\n _this._renderTargets = new SmartArrayNoDuplicate(256);\r\n /** @hidden */\r\n _this._activeParticleSystems = new SmartArray(256);\r\n _this._activeSkeletons = new SmartArrayNoDuplicate(32);\r\n _this._softwareSkinnedMeshes = new SmartArrayNoDuplicate(32);\r\n /** @hidden */\r\n _this._activeAnimatables = new Array();\r\n _this._transformMatrix = Matrix.Zero();\r\n /**\r\n * Gets or sets a boolean indicating if lights must be sorted by priority (off by default)\r\n * This is useful if there are more lights that the maximum simulteanous authorized\r\n */\r\n _this.requireLightSorting = false;\r\n /**\r\n * @hidden\r\n * Backing store of defined scene components.\r\n */\r\n _this._components = [];\r\n /**\r\n * @hidden\r\n * Backing store of defined scene components.\r\n */\r\n _this._serializableComponents = [];\r\n /**\r\n * List of components to register on the next registration step.\r\n */\r\n _this._transientComponents = [];\r\n /**\r\n * @hidden\r\n * Defines the actions happening before camera updates.\r\n */\r\n _this._beforeCameraUpdateStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening before clear the canvas.\r\n */\r\n _this._beforeClearStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions when collecting render targets for the frame.\r\n */\r\n _this._gatherRenderTargetsStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening for one camera in the frame.\r\n */\r\n _this._gatherActiveCameraRenderTargetsStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening during the per mesh ready checks.\r\n */\r\n _this._isReadyForMeshStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening before evaluate active mesh checks.\r\n */\r\n _this._beforeEvaluateActiveMeshStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening during the evaluate sub mesh checks.\r\n */\r\n _this._evaluateSubMeshStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening during the active mesh stage.\r\n */\r\n _this._preActiveMeshStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening during the per camera render target step.\r\n */\r\n _this._cameraDrawRenderTargetStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just before the active camera is drawing.\r\n */\r\n _this._beforeCameraDrawStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just before a render target is drawing.\r\n */\r\n _this._beforeRenderTargetDrawStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just before a rendering group is drawing.\r\n */\r\n _this._beforeRenderingGroupDrawStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just before a mesh is drawing.\r\n */\r\n _this._beforeRenderingMeshStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just after a mesh has been drawn.\r\n */\r\n _this._afterRenderingMeshStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just after a rendering group has been drawn.\r\n */\r\n _this._afterRenderingGroupDrawStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just after the active camera has been drawn.\r\n */\r\n _this._afterCameraDrawStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just after a render target has been drawn.\r\n */\r\n _this._afterRenderTargetDrawStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening just after rendering all cameras and computing intersections.\r\n */\r\n _this._afterRenderStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening when a pointer move event happens.\r\n */\r\n _this._pointerMoveStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening when a pointer down event happens.\r\n */\r\n _this._pointerDownStage = Stage.Create();\r\n /**\r\n * @hidden\r\n * Defines the actions happening when a pointer up event happens.\r\n */\r\n _this._pointerUpStage = Stage.Create();\r\n /**\r\n * an optional map from Geometry Id to Geometry index in the 'geometries' array\r\n */\r\n _this.geometriesByUniqueId = null;\r\n _this._defaultMeshCandidates = {\r\n data: [],\r\n length: 0\r\n };\r\n _this._defaultSubMeshCandidates = {\r\n data: [],\r\n length: 0\r\n };\r\n _this._preventFreeActiveMeshesAndRenderingGroups = false;\r\n /** @hidden */\r\n _this._activeMeshesFrozen = false;\r\n _this._skipEvaluateActiveMeshesCompletely = false;\r\n /** @hidden */\r\n _this._allowPostProcessClearColor = true;\r\n /**\r\n * User updatable function that will return a deterministic frame time when engine is in deterministic lock step mode\r\n */\r\n _this.getDeterministicFrameTime = function () {\r\n return _this._engine.getTimeStep();\r\n };\r\n _this._blockMaterialDirtyMechanism = false;\r\n var fullOptions = __assign({ useGeometryUniqueIdsMap: true, useMaterialMeshMap: true, useClonedMeshMap: true, virtual: false }, options);\r\n _this._engine = engine || EngineStore.LastCreatedEngine;\r\n if (!fullOptions.virtual) {\r\n EngineStore._LastCreatedScene = _this;\r\n _this._engine.scenes.push(_this);\r\n }\r\n _this._uid = null;\r\n _this._renderingManager = new RenderingManager(_this);\r\n if (PostProcessManager) {\r\n _this.postProcessManager = new PostProcessManager(_this);\r\n }\r\n if (DomManagement.IsWindowObjectExist()) {\r\n _this.attachControl();\r\n }\r\n // Uniform Buffer\r\n _this._createUbo();\r\n // Default Image processing definition\r\n if (ImageProcessingConfiguration) {\r\n _this._imageProcessingConfiguration = new ImageProcessingConfiguration();\r\n }\r\n _this.setDefaultCandidateProviders();\r\n if (fullOptions.useGeometryUniqueIdsMap) {\r\n _this.geometriesByUniqueId = {};\r\n }\r\n _this.useMaterialMeshMap = fullOptions.useMaterialMeshMap;\r\n _this.useClonedMeshMap = fullOptions.useClonedMeshMap;\r\n if (!options || !options.virtual) {\r\n _this._engine.onNewSceneAddedObservable.notifyObservers(_this);\r\n }\r\n return _this;\r\n }\r\n /**\r\n * Factory used to create the default material.\r\n * @param name The name of the material to create\r\n * @param scene The scene to create the material for\r\n * @returns The default material\r\n */\r\n Scene.DefaultMaterialFactory = function (scene) {\r\n throw _DevTools.WarnImport(\"StandardMaterial\");\r\n };\r\n /**\r\n * Factory used to create the a collision coordinator.\r\n * @returns The collision coordinator\r\n */\r\n Scene.CollisionCoordinatorFactory = function () {\r\n throw _DevTools.WarnImport(\"DefaultCollisionCoordinator\");\r\n };\r\n Object.defineProperty(Scene.prototype, \"environmentTexture\", {\r\n /**\r\n * Texture used in all pbr material as the reflection texture.\r\n * As in the majority of the scene they are the same (exception for multi room and so on),\r\n * this is easier to reference from here than from all the materials.\r\n */\r\n get: function () {\r\n return this._environmentTexture;\r\n },\r\n /**\r\n * Texture used in all pbr material as the reflection texture.\r\n * As in the majority of the scene they are the same (exception for multi room and so on),\r\n * this is easier to set here than in all the materials.\r\n */\r\n set: function (value) {\r\n if (this._environmentTexture === value) {\r\n return;\r\n }\r\n this._environmentTexture = value;\r\n this.markAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"environmentIntensity\", {\r\n /**\r\n * Intensity of the environment in all pbr material.\r\n * This dims or reinforces the IBL lighting overall (reflection and diffuse).\r\n * As in the majority of the scene they are the same (exception for multi room and so on),\r\n * this is easier to reference from here than from all the materials.\r\n */\r\n get: function () {\r\n return this._environmentIntensity;\r\n },\r\n /**\r\n * Intensity of the environment in all pbr material.\r\n * This dims or reinforces the IBL lighting overall (reflection and diffuse).\r\n * As in the majority of the scene they are the same (exception for multi room and so on),\r\n * this is easier to set here than in all the materials.\r\n */\r\n set: function (value) {\r\n if (this._environmentIntensity === value) {\r\n return;\r\n }\r\n this._environmentIntensity = value;\r\n this.markAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"imageProcessingConfiguration\", {\r\n /**\r\n * Default image processing configuration used either in the rendering\r\n * Forward main pass or through the imageProcessingPostProcess if present.\r\n * As in the majority of the scene they are the same (exception for multi camera),\r\n * this is easier to reference from here than from all the materials and post process.\r\n *\r\n * No setter as we it is a shared configuration, you can set the values instead.\r\n */\r\n get: function () {\r\n return this._imageProcessingConfiguration;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"forceWireframe\", {\r\n get: function () {\r\n return this._forceWireframe;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if all rendering must be done in wireframe\r\n */\r\n set: function (value) {\r\n if (this._forceWireframe === value) {\r\n return;\r\n }\r\n this._forceWireframe = value;\r\n this.markAllMaterialsAsDirty(16);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"skipFrustumClipping\", {\r\n get: function () {\r\n return this._skipFrustumClipping;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if we should skip the frustum clipping part of the active meshes selection\r\n */\r\n set: function (value) {\r\n if (this._skipFrustumClipping === value) {\r\n return;\r\n }\r\n this._skipFrustumClipping = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"forcePointsCloud\", {\r\n get: function () {\r\n return this._forcePointsCloud;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if all rendering must be done in point cloud\r\n */\r\n set: function (value) {\r\n if (this._forcePointsCloud === value) {\r\n return;\r\n }\r\n this._forcePointsCloud = value;\r\n this.markAllMaterialsAsDirty(16);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"animationPropertiesOverride\", {\r\n /**\r\n * Gets or sets the animation properties override\r\n */\r\n get: function () {\r\n return this._animationPropertiesOverride;\r\n },\r\n set: function (value) {\r\n this._animationPropertiesOverride = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"onDispose\", {\r\n /** Sets a function to be executed when this scene is disposed. */\r\n set: function (callback) {\r\n if (this._onDisposeObserver) {\r\n this.onDisposeObservable.remove(this._onDisposeObserver);\r\n }\r\n this._onDisposeObserver = this.onDisposeObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"beforeRender\", {\r\n /** Sets a function to be executed before rendering this scene */\r\n set: function (callback) {\r\n if (this._onBeforeRenderObserver) {\r\n this.onBeforeRenderObservable.remove(this._onBeforeRenderObserver);\r\n }\r\n if (callback) {\r\n this._onBeforeRenderObserver = this.onBeforeRenderObservable.add(callback);\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"afterRender\", {\r\n /** Sets a function to be executed after rendering this scene */\r\n set: function (callback) {\r\n if (this._onAfterRenderObserver) {\r\n this.onAfterRenderObservable.remove(this._onAfterRenderObserver);\r\n }\r\n if (callback) {\r\n this._onAfterRenderObserver = this.onAfterRenderObservable.add(callback);\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"beforeCameraRender\", {\r\n /** Sets a function to be executed before rendering a camera*/\r\n set: function (callback) {\r\n if (this._onBeforeCameraRenderObserver) {\r\n this.onBeforeCameraRenderObservable.remove(this._onBeforeCameraRenderObserver);\r\n }\r\n this._onBeforeCameraRenderObserver = this.onBeforeCameraRenderObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"afterCameraRender\", {\r\n /** Sets a function to be executed after rendering a camera*/\r\n set: function (callback) {\r\n if (this._onAfterCameraRenderObserver) {\r\n this.onAfterCameraRenderObservable.remove(this._onAfterCameraRenderObserver);\r\n }\r\n this._onAfterCameraRenderObserver = this.onAfterCameraRenderObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"unTranslatedPointer\", {\r\n /**\r\n * Gets the pointer coordinates without any translation (ie. straight out of the pointer event)\r\n */\r\n get: function () {\r\n return this._inputManager.unTranslatedPointer;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene, \"DragMovementThreshold\", {\r\n /**\r\n * Gets or sets the distance in pixel that you have to move to prevent some events. Default is 10 pixels\r\n */\r\n get: function () {\r\n return InputManager.DragMovementThreshold;\r\n },\r\n set: function (value) {\r\n InputManager.DragMovementThreshold = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene, \"LongPressDelay\", {\r\n /**\r\n * Time in milliseconds to wait to raise long press events if button is still pressed. Default is 500 ms\r\n */\r\n get: function () {\r\n return InputManager.LongPressDelay;\r\n },\r\n set: function (value) {\r\n InputManager.LongPressDelay = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene, \"DoubleClickDelay\", {\r\n /**\r\n * Time in milliseconds to wait to raise long press events if button is still pressed. Default is 300 ms\r\n */\r\n get: function () {\r\n return InputManager.DoubleClickDelay;\r\n },\r\n set: function (value) {\r\n InputManager.DoubleClickDelay = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene, \"ExclusiveDoubleClickMode\", {\r\n /** If you need to check double click without raising a single click at first click, enable this flag */\r\n get: function () {\r\n return InputManager.ExclusiveDoubleClickMode;\r\n },\r\n set: function (value) {\r\n InputManager.ExclusiveDoubleClickMode = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"useRightHandedSystem\", {\r\n get: function () {\r\n return this._useRightHandedSystem;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if the scene must use right-handed coordinates system\r\n */\r\n set: function (value) {\r\n if (this._useRightHandedSystem === value) {\r\n return;\r\n }\r\n this._useRightHandedSystem = value;\r\n this.markAllMaterialsAsDirty(16);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Sets the step Id used by deterministic lock step\r\n * @see https://doc.babylonjs.com/babylon101/animations#deterministic-lockstep\r\n * @param newStepId defines the step Id\r\n */\r\n Scene.prototype.setStepId = function (newStepId) {\r\n this._currentStepId = newStepId;\r\n };\r\n /**\r\n * Gets the step Id used by deterministic lock step\r\n * @see https://doc.babylonjs.com/babylon101/animations#deterministic-lockstep\r\n * @returns the step Id\r\n */\r\n Scene.prototype.getStepId = function () {\r\n return this._currentStepId;\r\n };\r\n /**\r\n * Gets the internal step used by deterministic lock step\r\n * @see https://doc.babylonjs.com/babylon101/animations#deterministic-lockstep\r\n * @returns the internal step\r\n */\r\n Scene.prototype.getInternalStep = function () {\r\n return this._currentInternalStep;\r\n };\r\n Object.defineProperty(Scene.prototype, \"fogEnabled\", {\r\n get: function () {\r\n return this._fogEnabled;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if fog is enabled on this scene\r\n * @see https://doc.babylonjs.com/babylon101/environment#fog\r\n * (Default is true)\r\n */\r\n set: function (value) {\r\n if (this._fogEnabled === value) {\r\n return;\r\n }\r\n this._fogEnabled = value;\r\n this.markAllMaterialsAsDirty(16);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"fogMode\", {\r\n get: function () {\r\n return this._fogMode;\r\n },\r\n /**\r\n * Gets or sets the fog mode to use\r\n * @see https://doc.babylonjs.com/babylon101/environment#fog\r\n * | mode | value |\r\n * | --- | --- |\r\n * | FOGMODE_NONE | 0 |\r\n * | FOGMODE_EXP | 1 |\r\n * | FOGMODE_EXP2 | 2 |\r\n * | FOGMODE_LINEAR | 3 |\r\n */\r\n set: function (value) {\r\n if (this._fogMode === value) {\r\n return;\r\n }\r\n this._fogMode = value;\r\n this.markAllMaterialsAsDirty(16);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"shadowsEnabled\", {\r\n get: function () {\r\n return this._shadowsEnabled;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if shadows are enabled on this scene\r\n */\r\n set: function (value) {\r\n if (this._shadowsEnabled === value) {\r\n return;\r\n }\r\n this._shadowsEnabled = value;\r\n this.markAllMaterialsAsDirty(2);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"lightsEnabled\", {\r\n get: function () {\r\n return this._lightsEnabled;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if lights are enabled on this scene\r\n */\r\n set: function (value) {\r\n if (this._lightsEnabled === value) {\r\n return;\r\n }\r\n this._lightsEnabled = value;\r\n this.markAllMaterialsAsDirty(2);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"activeCamera\", {\r\n /** Gets or sets the current active camera */\r\n get: function () {\r\n return this._activeCamera;\r\n },\r\n set: function (value) {\r\n if (value === this._activeCamera) {\r\n return;\r\n }\r\n this._activeCamera = value;\r\n this.onActiveCameraChanged.notifyObservers(this);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"defaultMaterial\", {\r\n /** The default material used on meshes when no material is affected */\r\n get: function () {\r\n if (!this._defaultMaterial) {\r\n this._defaultMaterial = Scene.DefaultMaterialFactory(this);\r\n }\r\n return this._defaultMaterial;\r\n },\r\n /** The default material used on meshes when no material is affected */\r\n set: function (value) {\r\n this._defaultMaterial = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"texturesEnabled\", {\r\n get: function () {\r\n return this._texturesEnabled;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if textures are enabled on this scene\r\n */\r\n set: function (value) {\r\n if (this._texturesEnabled === value) {\r\n return;\r\n }\r\n this._texturesEnabled = value;\r\n this.markAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"skeletonsEnabled\", {\r\n get: function () {\r\n return this._skeletonsEnabled;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if skeletons are enabled on this scene\r\n */\r\n set: function (value) {\r\n if (this._skeletonsEnabled === value) {\r\n return;\r\n }\r\n this._skeletonsEnabled = value;\r\n this.markAllMaterialsAsDirty(8);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"collisionCoordinator\", {\r\n /** @hidden */\r\n get: function () {\r\n if (!this._collisionCoordinator) {\r\n this._collisionCoordinator = Scene.CollisionCoordinatorFactory();\r\n this._collisionCoordinator.init(this);\r\n }\r\n return this._collisionCoordinator;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"frustumPlanes\", {\r\n /**\r\n * Gets the list of frustum planes (built from the active camera)\r\n */\r\n get: function () {\r\n return this._frustumPlanes;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Registers the transient components if needed.\r\n */\r\n Scene.prototype._registerTransientComponents = function () {\r\n // Register components that have been associated lately to the scene.\r\n if (this._transientComponents.length > 0) {\r\n for (var _i = 0, _a = this._transientComponents; _i < _a.length; _i++) {\r\n var component = _a[_i];\r\n component.register();\r\n }\r\n this._transientComponents = [];\r\n }\r\n };\r\n /**\r\n * @hidden\r\n * Add a component to the scene.\r\n * Note that the ccomponent could be registered on th next frame if this is called after\r\n * the register component stage.\r\n * @param component Defines the component to add to the scene\r\n */\r\n Scene.prototype._addComponent = function (component) {\r\n this._components.push(component);\r\n this._transientComponents.push(component);\r\n var serializableComponent = component;\r\n if (serializableComponent.addFromContainer && serializableComponent.serialize) {\r\n this._serializableComponents.push(serializableComponent);\r\n }\r\n };\r\n /**\r\n * @hidden\r\n * Gets a component from the scene.\r\n * @param name defines the name of the component to retrieve\r\n * @returns the component or null if not present\r\n */\r\n Scene.prototype._getComponent = function (name) {\r\n for (var _i = 0, _a = this._components; _i < _a.length; _i++) {\r\n var component = _a[_i];\r\n if (component.name === name) {\r\n return component;\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a string identifying the name of the class\r\n * @returns \"Scene\" string\r\n */\r\n Scene.prototype.getClassName = function () {\r\n return \"Scene\";\r\n };\r\n /**\r\n * @hidden\r\n */\r\n Scene.prototype._getDefaultMeshCandidates = function () {\r\n this._defaultMeshCandidates.data = this.meshes;\r\n this._defaultMeshCandidates.length = this.meshes.length;\r\n return this._defaultMeshCandidates;\r\n };\r\n /**\r\n * @hidden\r\n */\r\n Scene.prototype._getDefaultSubMeshCandidates = function (mesh) {\r\n this._defaultSubMeshCandidates.data = mesh.subMeshes;\r\n this._defaultSubMeshCandidates.length = mesh.subMeshes.length;\r\n return this._defaultSubMeshCandidates;\r\n };\r\n /**\r\n * Sets the default candidate providers for the scene.\r\n * This sets the getActiveMeshCandidates, getActiveSubMeshCandidates, getIntersectingSubMeshCandidates\r\n * and getCollidingSubMeshCandidates to their default function\r\n */\r\n Scene.prototype.setDefaultCandidateProviders = function () {\r\n this.getActiveMeshCandidates = this._getDefaultMeshCandidates.bind(this);\r\n this.getActiveSubMeshCandidates = this._getDefaultSubMeshCandidates.bind(this);\r\n this.getIntersectingSubMeshCandidates = this._getDefaultSubMeshCandidates.bind(this);\r\n this.getCollidingSubMeshCandidates = this._getDefaultSubMeshCandidates.bind(this);\r\n };\r\n Object.defineProperty(Scene.prototype, \"meshUnderPointer\", {\r\n /**\r\n * Gets the mesh that is currently under the pointer\r\n */\r\n get: function () {\r\n return this._inputManager.meshUnderPointer;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"pointerX\", {\r\n /**\r\n * Gets or sets the current on-screen X position of the pointer\r\n */\r\n get: function () {\r\n return this._inputManager.pointerX;\r\n },\r\n set: function (value) {\r\n this._inputManager.pointerX = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Scene.prototype, \"pointerY\", {\r\n /**\r\n * Gets or sets the current on-screen Y position of the pointer\r\n */\r\n get: function () {\r\n return this._inputManager.pointerY;\r\n },\r\n set: function (value) {\r\n this._inputManager.pointerY = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the cached material (ie. the latest rendered one)\r\n * @returns the cached material\r\n */\r\n Scene.prototype.getCachedMaterial = function () {\r\n return this._cachedMaterial;\r\n };\r\n /**\r\n * Gets the cached effect (ie. the latest rendered one)\r\n * @returns the cached effect\r\n */\r\n Scene.prototype.getCachedEffect = function () {\r\n return this._cachedEffect;\r\n };\r\n /**\r\n * Gets the cached visibility state (ie. the latest rendered one)\r\n * @returns the cached visibility state\r\n */\r\n Scene.prototype.getCachedVisibility = function () {\r\n return this._cachedVisibility;\r\n };\r\n /**\r\n * Gets a boolean indicating if the current material / effect / visibility must be bind again\r\n * @param material defines the current material\r\n * @param effect defines the current effect\r\n * @param visibility defines the current visibility state\r\n * @returns true if one parameter is not cached\r\n */\r\n Scene.prototype.isCachedMaterialInvalid = function (material, effect, visibility) {\r\n if (visibility === void 0) { visibility = 1; }\r\n return this._cachedEffect !== effect || this._cachedMaterial !== material || this._cachedVisibility !== visibility;\r\n };\r\n /**\r\n * Gets the engine associated with the scene\r\n * @returns an Engine\r\n */\r\n Scene.prototype.getEngine = function () {\r\n return this._engine;\r\n };\r\n /**\r\n * Gets the total number of vertices rendered per frame\r\n * @returns the total number of vertices rendered per frame\r\n */\r\n Scene.prototype.getTotalVertices = function () {\r\n return this._totalVertices.current;\r\n };\r\n Object.defineProperty(Scene.prototype, \"totalVerticesPerfCounter\", {\r\n /**\r\n * Gets the performance counter for total vertices\r\n * @see https://doc.babylonjs.com/how_to/optimizing_your_scene#instrumentation\r\n */\r\n get: function () {\r\n return this._totalVertices;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the total number of active indices rendered per frame (You can deduce the number of rendered triangles by dividing this number by 3)\r\n * @returns the total number of active indices rendered per frame\r\n */\r\n Scene.prototype.getActiveIndices = function () {\r\n return this._activeIndices.current;\r\n };\r\n Object.defineProperty(Scene.prototype, \"totalActiveIndicesPerfCounter\", {\r\n /**\r\n * Gets the performance counter for active indices\r\n * @see https://doc.babylonjs.com/how_to/optimizing_your_scene#instrumentation\r\n */\r\n get: function () {\r\n return this._activeIndices;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the total number of active particles rendered per frame\r\n * @returns the total number of active particles rendered per frame\r\n */\r\n Scene.prototype.getActiveParticles = function () {\r\n return this._activeParticles.current;\r\n };\r\n Object.defineProperty(Scene.prototype, \"activeParticlesPerfCounter\", {\r\n /**\r\n * Gets the performance counter for active particles\r\n * @see https://doc.babylonjs.com/how_to/optimizing_your_scene#instrumentation\r\n */\r\n get: function () {\r\n return this._activeParticles;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the total number of active bones rendered per frame\r\n * @returns the total number of active bones rendered per frame\r\n */\r\n Scene.prototype.getActiveBones = function () {\r\n return this._activeBones.current;\r\n };\r\n Object.defineProperty(Scene.prototype, \"activeBonesPerfCounter\", {\r\n /**\r\n * Gets the performance counter for active bones\r\n * @see https://doc.babylonjs.com/how_to/optimizing_your_scene#instrumentation\r\n */\r\n get: function () {\r\n return this._activeBones;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the array of active meshes\r\n * @returns an array of AbstractMesh\r\n */\r\n Scene.prototype.getActiveMeshes = function () {\r\n return this._activeMeshes;\r\n };\r\n /**\r\n * Gets the animation ratio (which is 1.0 is the scene renders at 60fps and 2 if the scene renders at 30fps, etc.)\r\n * @returns a number\r\n */\r\n Scene.prototype.getAnimationRatio = function () {\r\n return this._animationRatio !== undefined ? this._animationRatio : 1;\r\n };\r\n /**\r\n * Gets an unique Id for the current render phase\r\n * @returns a number\r\n */\r\n Scene.prototype.getRenderId = function () {\r\n return this._renderId;\r\n };\r\n /**\r\n * Gets an unique Id for the current frame\r\n * @returns a number\r\n */\r\n Scene.prototype.getFrameId = function () {\r\n return this._frameId;\r\n };\r\n /** Call this function if you want to manually increment the render Id*/\r\n Scene.prototype.incrementRenderId = function () {\r\n this._renderId++;\r\n };\r\n Scene.prototype._createUbo = function () {\r\n this._sceneUbo = new UniformBuffer(this._engine, undefined, true);\r\n this._sceneUbo.addUniform(\"viewProjection\", 16);\r\n this._sceneUbo.addUniform(\"view\", 16);\r\n };\r\n /**\r\n * Use this method to simulate a pointer move on a mesh\r\n * The pickResult parameter can be obtained from a scene.pick or scene.pickWithRay\r\n * @param pickResult pickingInfo of the object wished to simulate pointer event on\r\n * @param pointerEventInit pointer event state to be used when simulating the pointer event (eg. pointer id for multitouch)\r\n * @returns the current scene\r\n */\r\n Scene.prototype.simulatePointerMove = function (pickResult, pointerEventInit) {\r\n this._inputManager.simulatePointerMove(pickResult, pointerEventInit);\r\n return this;\r\n };\r\n /**\r\n * Use this method to simulate a pointer down on a mesh\r\n * The pickResult parameter can be obtained from a scene.pick or scene.pickWithRay\r\n * @param pickResult pickingInfo of the object wished to simulate pointer event on\r\n * @param pointerEventInit pointer event state to be used when simulating the pointer event (eg. pointer id for multitouch)\r\n * @returns the current scene\r\n */\r\n Scene.prototype.simulatePointerDown = function (pickResult, pointerEventInit) {\r\n this._inputManager.simulatePointerDown(pickResult, pointerEventInit);\r\n return this;\r\n };\r\n /**\r\n * Use this method to simulate a pointer up on a mesh\r\n * The pickResult parameter can be obtained from a scene.pick or scene.pickWithRay\r\n * @param pickResult pickingInfo of the object wished to simulate pointer event on\r\n * @param pointerEventInit pointer event state to be used when simulating the pointer event (eg. pointer id for multitouch)\r\n * @param doubleTap indicates that the pointer up event should be considered as part of a double click (false by default)\r\n * @returns the current scene\r\n */\r\n Scene.prototype.simulatePointerUp = function (pickResult, pointerEventInit, doubleTap) {\r\n this._inputManager.simulatePointerUp(pickResult, pointerEventInit, doubleTap);\r\n return this;\r\n };\r\n /**\r\n * Gets a boolean indicating if the current pointer event is captured (meaning that the scene has already handled the pointer down)\r\n * @param pointerId defines the pointer id to use in a multi-touch scenario (0 by default)\r\n * @returns true if the pointer was captured\r\n */\r\n Scene.prototype.isPointerCaptured = function (pointerId) {\r\n if (pointerId === void 0) { pointerId = 0; }\r\n return this._inputManager.isPointerCaptured(pointerId);\r\n };\r\n /**\r\n * Attach events to the canvas (To handle actionManagers triggers and raise onPointerMove, onPointerDown and onPointerUp\r\n * @param attachUp defines if you want to attach events to pointerup\r\n * @param attachDown defines if you want to attach events to pointerdown\r\n * @param attachMove defines if you want to attach events to pointermove\r\n */\r\n Scene.prototype.attachControl = function (attachUp, attachDown, attachMove) {\r\n if (attachUp === void 0) { attachUp = true; }\r\n if (attachDown === void 0) { attachDown = true; }\r\n if (attachMove === void 0) { attachMove = true; }\r\n this._inputManager.attachControl(attachUp, attachDown, attachMove);\r\n };\r\n /** Detaches all event handlers*/\r\n Scene.prototype.detachControl = function () {\r\n this._inputManager.detachControl();\r\n };\r\n /**\r\n * This function will check if the scene can be rendered (textures are loaded, shaders are compiled)\r\n * Delay loaded resources are not taking in account\r\n * @return true if all required resources are ready\r\n */\r\n Scene.prototype.isReady = function () {\r\n if (this._isDisposed) {\r\n return false;\r\n }\r\n var index;\r\n var engine = this.getEngine();\r\n // Effects\r\n if (!engine.areAllEffectsReady()) {\r\n return false;\r\n }\r\n // Pending data\r\n if (this._pendingData.length > 0) {\r\n return false;\r\n }\r\n // Meshes\r\n for (index = 0; index < this.meshes.length; index++) {\r\n var mesh = this.meshes[index];\r\n if (!mesh.isEnabled()) {\r\n continue;\r\n }\r\n if (!mesh.subMeshes || mesh.subMeshes.length === 0) {\r\n continue;\r\n }\r\n if (!mesh.isReady(true)) {\r\n return false;\r\n }\r\n var hardwareInstancedRendering = mesh.hasThinInstances || mesh.getClassName() === \"InstancedMesh\" || mesh.getClassName() === \"InstancedLinesMesh\" || engine.getCaps().instancedArrays && mesh.instances.length > 0;\r\n // Is Ready For Mesh\r\n for (var _i = 0, _a = this._isReadyForMeshStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n if (!step.action(mesh, hardwareInstancedRendering)) {\r\n return false;\r\n }\r\n }\r\n }\r\n // Geometries\r\n for (index = 0; index < this.geometries.length; index++) {\r\n var geometry = this.geometries[index];\r\n if (geometry.delayLoadState === 2) {\r\n return false;\r\n }\r\n }\r\n // Post-processes\r\n if (this.activeCameras && this.activeCameras.length > 0) {\r\n for (var _b = 0, _c = this.activeCameras; _b < _c.length; _b++) {\r\n var camera = _c[_b];\r\n if (!camera.isReady(true)) {\r\n return false;\r\n }\r\n }\r\n }\r\n else if (this.activeCamera) {\r\n if (!this.activeCamera.isReady(true)) {\r\n return false;\r\n }\r\n }\r\n // Particles\r\n for (var _d = 0, _e = this.particleSystems; _d < _e.length; _d++) {\r\n var particleSystem = _e[_d];\r\n if (!particleSystem.isReady()) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n /** Resets all cached information relative to material (including effect and visibility) */\r\n Scene.prototype.resetCachedMaterial = function () {\r\n this._cachedMaterial = null;\r\n this._cachedEffect = null;\r\n this._cachedVisibility = null;\r\n };\r\n /**\r\n * Registers a function to be called before every frame render\r\n * @param func defines the function to register\r\n */\r\n Scene.prototype.registerBeforeRender = function (func) {\r\n this.onBeforeRenderObservable.add(func);\r\n };\r\n /**\r\n * Unregisters a function called before every frame render\r\n * @param func defines the function to unregister\r\n */\r\n Scene.prototype.unregisterBeforeRender = function (func) {\r\n this.onBeforeRenderObservable.removeCallback(func);\r\n };\r\n /**\r\n * Registers a function to be called after every frame render\r\n * @param func defines the function to register\r\n */\r\n Scene.prototype.registerAfterRender = function (func) {\r\n this.onAfterRenderObservable.add(func);\r\n };\r\n /**\r\n * Unregisters a function called after every frame render\r\n * @param func defines the function to unregister\r\n */\r\n Scene.prototype.unregisterAfterRender = function (func) {\r\n this.onAfterRenderObservable.removeCallback(func);\r\n };\r\n Scene.prototype._executeOnceBeforeRender = function (func) {\r\n var _this = this;\r\n var execFunc = function () {\r\n func();\r\n setTimeout(function () {\r\n _this.unregisterBeforeRender(execFunc);\r\n });\r\n };\r\n this.registerBeforeRender(execFunc);\r\n };\r\n /**\r\n * The provided function will run before render once and will be disposed afterwards.\r\n * A timeout delay can be provided so that the function will be executed in N ms.\r\n * The timeout is using the browser's native setTimeout so time percision cannot be guaranteed.\r\n * @param func The function to be executed.\r\n * @param timeout optional delay in ms\r\n */\r\n Scene.prototype.executeOnceBeforeRender = function (func, timeout) {\r\n var _this = this;\r\n if (timeout !== undefined) {\r\n setTimeout(function () {\r\n _this._executeOnceBeforeRender(func);\r\n }, timeout);\r\n }\r\n else {\r\n this._executeOnceBeforeRender(func);\r\n }\r\n };\r\n /** @hidden */\r\n Scene.prototype._addPendingData = function (data) {\r\n this._pendingData.push(data);\r\n };\r\n /** @hidden */\r\n Scene.prototype._removePendingData = function (data) {\r\n var wasLoading = this.isLoading;\r\n var index = this._pendingData.indexOf(data);\r\n if (index !== -1) {\r\n this._pendingData.splice(index, 1);\r\n }\r\n if (wasLoading && !this.isLoading) {\r\n this.onDataLoadedObservable.notifyObservers(this);\r\n }\r\n };\r\n /**\r\n * Returns the number of items waiting to be loaded\r\n * @returns the number of items waiting to be loaded\r\n */\r\n Scene.prototype.getWaitingItemsCount = function () {\r\n return this._pendingData.length;\r\n };\r\n Object.defineProperty(Scene.prototype, \"isLoading\", {\r\n /**\r\n * Returns a boolean indicating if the scene is still loading data\r\n */\r\n get: function () {\r\n return this._pendingData.length > 0;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Registers a function to be executed when the scene is ready\r\n * @param {Function} func - the function to be executed\r\n */\r\n Scene.prototype.executeWhenReady = function (func) {\r\n var _this = this;\r\n this.onReadyObservable.add(func);\r\n if (this._executeWhenReadyTimeoutId !== -1) {\r\n return;\r\n }\r\n this._executeWhenReadyTimeoutId = setTimeout(function () {\r\n _this._checkIsReady();\r\n }, 150);\r\n };\r\n /**\r\n * Returns a promise that resolves when the scene is ready\r\n * @returns A promise that resolves when the scene is ready\r\n */\r\n Scene.prototype.whenReadyAsync = function () {\r\n var _this = this;\r\n return new Promise(function (resolve) {\r\n _this.executeWhenReady(function () {\r\n resolve();\r\n });\r\n });\r\n };\r\n /** @hidden */\r\n Scene.prototype._checkIsReady = function () {\r\n var _this = this;\r\n this._registerTransientComponents();\r\n if (this.isReady()) {\r\n this.onReadyObservable.notifyObservers(this);\r\n this.onReadyObservable.clear();\r\n this._executeWhenReadyTimeoutId = -1;\r\n return;\r\n }\r\n if (this._isDisposed) {\r\n this.onReadyObservable.clear();\r\n this._executeWhenReadyTimeoutId = -1;\r\n return;\r\n }\r\n this._executeWhenReadyTimeoutId = setTimeout(function () {\r\n _this._checkIsReady();\r\n }, 150);\r\n };\r\n Object.defineProperty(Scene.prototype, \"animatables\", {\r\n /**\r\n * Gets all animatable attached to the scene\r\n */\r\n get: function () {\r\n return this._activeAnimatables;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Resets the last animation time frame.\r\n * Useful to override when animations start running when loading a scene for the first time.\r\n */\r\n Scene.prototype.resetLastAnimationTimeFrame = function () {\r\n this._animationTimeLast = PrecisionDate.Now;\r\n };\r\n // Matrix\r\n /**\r\n * Gets the current view matrix\r\n * @returns a Matrix\r\n */\r\n Scene.prototype.getViewMatrix = function () {\r\n return this._viewMatrix;\r\n };\r\n /**\r\n * Gets the current projection matrix\r\n * @returns a Matrix\r\n */\r\n Scene.prototype.getProjectionMatrix = function () {\r\n return this._projectionMatrix;\r\n };\r\n /**\r\n * Gets the current transform matrix\r\n * @returns a Matrix made of View * Projection\r\n */\r\n Scene.prototype.getTransformMatrix = function () {\r\n return this._transformMatrix;\r\n };\r\n /**\r\n * Sets the current transform matrix\r\n * @param viewL defines the View matrix to use\r\n * @param projectionL defines the Projection matrix to use\r\n * @param viewR defines the right View matrix to use (if provided)\r\n * @param projectionR defines the right Projection matrix to use (if provided)\r\n */\r\n Scene.prototype.setTransformMatrix = function (viewL, projectionL, viewR, projectionR) {\r\n if (this._viewUpdateFlag === viewL.updateFlag && this._projectionUpdateFlag === projectionL.updateFlag) {\r\n return;\r\n }\r\n this._viewUpdateFlag = viewL.updateFlag;\r\n this._projectionUpdateFlag = projectionL.updateFlag;\r\n this._viewMatrix = viewL;\r\n this._projectionMatrix = projectionL;\r\n this._viewMatrix.multiplyToRef(this._projectionMatrix, this._transformMatrix);\r\n // Update frustum\r\n if (!this._frustumPlanes) {\r\n this._frustumPlanes = Frustum.GetPlanes(this._transformMatrix);\r\n }\r\n else {\r\n Frustum.GetPlanesToRef(this._transformMatrix, this._frustumPlanes);\r\n }\r\n if (this._multiviewSceneUbo && this._multiviewSceneUbo.useUbo) {\r\n this._updateMultiviewUbo(viewR, projectionR);\r\n }\r\n else if (this._sceneUbo.useUbo) {\r\n this._sceneUbo.updateMatrix(\"viewProjection\", this._transformMatrix);\r\n this._sceneUbo.updateMatrix(\"view\", this._viewMatrix);\r\n this._sceneUbo.update();\r\n }\r\n };\r\n /**\r\n * Gets the uniform buffer used to store scene data\r\n * @returns a UniformBuffer\r\n */\r\n Scene.prototype.getSceneUniformBuffer = function () {\r\n return this._multiviewSceneUbo ? this._multiviewSceneUbo : this._sceneUbo;\r\n };\r\n /**\r\n * Gets an unique (relatively to the current scene) Id\r\n * @returns an unique number for the scene\r\n */\r\n Scene.prototype.getUniqueId = function () {\r\n return UniqueIdGenerator.UniqueId;\r\n };\r\n /**\r\n * Add a mesh to the list of scene's meshes\r\n * @param newMesh defines the mesh to add\r\n * @param recursive if all child meshes should also be added to the scene\r\n */\r\n Scene.prototype.addMesh = function (newMesh, recursive) {\r\n var _this = this;\r\n if (recursive === void 0) { recursive = false; }\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.meshes.push(newMesh);\r\n newMesh._resyncLightSources();\r\n if (!newMesh.parent) {\r\n newMesh._addToSceneRootNodes();\r\n }\r\n this.onNewMeshAddedObservable.notifyObservers(newMesh);\r\n if (recursive) {\r\n newMesh.getChildMeshes().forEach(function (m) {\r\n _this.addMesh(m);\r\n });\r\n }\r\n };\r\n /**\r\n * Remove a mesh for the list of scene's meshes\r\n * @param toRemove defines the mesh to remove\r\n * @param recursive if all child meshes should also be removed from the scene\r\n * @returns the index where the mesh was in the mesh list\r\n */\r\n Scene.prototype.removeMesh = function (toRemove, recursive) {\r\n var _this = this;\r\n if (recursive === void 0) { recursive = false; }\r\n var index = this.meshes.indexOf(toRemove);\r\n if (index !== -1) {\r\n // Remove from the scene if mesh found\r\n this.meshes[index] = this.meshes[this.meshes.length - 1];\r\n this.meshes.pop();\r\n if (!toRemove.parent) {\r\n toRemove._removeFromSceneRootNodes();\r\n }\r\n }\r\n this.onMeshRemovedObservable.notifyObservers(toRemove);\r\n if (recursive) {\r\n toRemove.getChildMeshes().forEach(function (m) {\r\n _this.removeMesh(m);\r\n });\r\n }\r\n return index;\r\n };\r\n /**\r\n * Add a transform node to the list of scene's transform nodes\r\n * @param newTransformNode defines the transform node to add\r\n */\r\n Scene.prototype.addTransformNode = function (newTransformNode) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n newTransformNode._indexInSceneTransformNodesArray = this.transformNodes.length;\r\n this.transformNodes.push(newTransformNode);\r\n if (!newTransformNode.parent) {\r\n newTransformNode._addToSceneRootNodes();\r\n }\r\n this.onNewTransformNodeAddedObservable.notifyObservers(newTransformNode);\r\n };\r\n /**\r\n * Remove a transform node for the list of scene's transform nodes\r\n * @param toRemove defines the transform node to remove\r\n * @returns the index where the transform node was in the transform node list\r\n */\r\n Scene.prototype.removeTransformNode = function (toRemove) {\r\n var index = toRemove._indexInSceneTransformNodesArray;\r\n if (index !== -1) {\r\n if (index !== this.transformNodes.length - 1) {\r\n var lastNode = this.transformNodes[this.transformNodes.length - 1];\r\n this.transformNodes[index] = lastNode;\r\n lastNode._indexInSceneTransformNodesArray = index;\r\n }\r\n toRemove._indexInSceneTransformNodesArray = -1;\r\n this.transformNodes.pop();\r\n if (!toRemove.parent) {\r\n toRemove._removeFromSceneRootNodes();\r\n }\r\n }\r\n this.onTransformNodeRemovedObservable.notifyObservers(toRemove);\r\n return index;\r\n };\r\n /**\r\n * Remove a skeleton for the list of scene's skeletons\r\n * @param toRemove defines the skeleton to remove\r\n * @returns the index where the skeleton was in the skeleton list\r\n */\r\n Scene.prototype.removeSkeleton = function (toRemove) {\r\n var index = this.skeletons.indexOf(toRemove);\r\n if (index !== -1) {\r\n // Remove from the scene if found\r\n this.skeletons.splice(index, 1);\r\n this.onSkeletonRemovedObservable.notifyObservers(toRemove);\r\n }\r\n return index;\r\n };\r\n /**\r\n * Remove a morph target for the list of scene's morph targets\r\n * @param toRemove defines the morph target to remove\r\n * @returns the index where the morph target was in the morph target list\r\n */\r\n Scene.prototype.removeMorphTargetManager = function (toRemove) {\r\n var index = this.morphTargetManagers.indexOf(toRemove);\r\n if (index !== -1) {\r\n // Remove from the scene if found\r\n this.morphTargetManagers.splice(index, 1);\r\n }\r\n return index;\r\n };\r\n /**\r\n * Remove a light for the list of scene's lights\r\n * @param toRemove defines the light to remove\r\n * @returns the index where the light was in the light list\r\n */\r\n Scene.prototype.removeLight = function (toRemove) {\r\n var index = this.lights.indexOf(toRemove);\r\n if (index !== -1) {\r\n // Remove from meshes\r\n for (var _i = 0, _a = this.meshes; _i < _a.length; _i++) {\r\n var mesh = _a[_i];\r\n mesh._removeLightSource(toRemove, false);\r\n }\r\n // Remove from the scene if mesh found\r\n this.lights.splice(index, 1);\r\n this.sortLightsByPriority();\r\n if (!toRemove.parent) {\r\n toRemove._removeFromSceneRootNodes();\r\n }\r\n }\r\n this.onLightRemovedObservable.notifyObservers(toRemove);\r\n return index;\r\n };\r\n /**\r\n * Remove a camera for the list of scene's cameras\r\n * @param toRemove defines the camera to remove\r\n * @returns the index where the camera was in the camera list\r\n */\r\n Scene.prototype.removeCamera = function (toRemove) {\r\n var index = this.cameras.indexOf(toRemove);\r\n if (index !== -1) {\r\n // Remove from the scene if mesh found\r\n this.cameras.splice(index, 1);\r\n if (!toRemove.parent) {\r\n toRemove._removeFromSceneRootNodes();\r\n }\r\n }\r\n // Remove from activeCameras\r\n if (this.activeCameras) {\r\n var index2 = this.activeCameras.indexOf(toRemove);\r\n if (index2 !== -1) {\r\n // Remove from the scene if mesh found\r\n this.activeCameras.splice(index2, 1);\r\n }\r\n }\r\n // Reset the activeCamera\r\n if (this.activeCamera === toRemove) {\r\n if (this.cameras.length > 0) {\r\n this.activeCamera = this.cameras[0];\r\n }\r\n else {\r\n this.activeCamera = null;\r\n }\r\n }\r\n this.onCameraRemovedObservable.notifyObservers(toRemove);\r\n return index;\r\n };\r\n /**\r\n * Remove a particle system for the list of scene's particle systems\r\n * @param toRemove defines the particle system to remove\r\n * @returns the index where the particle system was in the particle system list\r\n */\r\n Scene.prototype.removeParticleSystem = function (toRemove) {\r\n var index = this.particleSystems.indexOf(toRemove);\r\n if (index !== -1) {\r\n this.particleSystems.splice(index, 1);\r\n }\r\n return index;\r\n };\r\n /**\r\n * Remove a animation for the list of scene's animations\r\n * @param toRemove defines the animation to remove\r\n * @returns the index where the animation was in the animation list\r\n */\r\n Scene.prototype.removeAnimation = function (toRemove) {\r\n var index = this.animations.indexOf(toRemove);\r\n if (index !== -1) {\r\n this.animations.splice(index, 1);\r\n }\r\n return index;\r\n };\r\n /**\r\n * Will stop the animation of the given target\r\n * @param target - the target\r\n * @param animationName - the name of the animation to stop (all animations will be stopped if both this and targetMask are empty)\r\n * @param targetMask - a function that determines if the animation should be stopped based on its target (all animations will be stopped if both this and animationName are empty)\r\n */\r\n Scene.prototype.stopAnimation = function (target, animationName, targetMask) {\r\n // Do nothing as code will be provided by animation component\r\n };\r\n /**\r\n * Removes the given animation group from this scene.\r\n * @param toRemove The animation group to remove\r\n * @returns The index of the removed animation group\r\n */\r\n Scene.prototype.removeAnimationGroup = function (toRemove) {\r\n var index = this.animationGroups.indexOf(toRemove);\r\n if (index !== -1) {\r\n this.animationGroups.splice(index, 1);\r\n }\r\n return index;\r\n };\r\n /**\r\n * Removes the given multi-material from this scene.\r\n * @param toRemove The multi-material to remove\r\n * @returns The index of the removed multi-material\r\n */\r\n Scene.prototype.removeMultiMaterial = function (toRemove) {\r\n var index = this.multiMaterials.indexOf(toRemove);\r\n if (index !== -1) {\r\n this.multiMaterials.splice(index, 1);\r\n }\r\n this.onMultiMaterialRemovedObservable.notifyObservers(toRemove);\r\n return index;\r\n };\r\n /**\r\n * Removes the given material from this scene.\r\n * @param toRemove The material to remove\r\n * @returns The index of the removed material\r\n */\r\n Scene.prototype.removeMaterial = function (toRemove) {\r\n var index = toRemove._indexInSceneMaterialArray;\r\n if (index !== -1 && index < this.materials.length) {\r\n if (index !== this.materials.length - 1) {\r\n var lastMaterial = this.materials[this.materials.length - 1];\r\n this.materials[index] = lastMaterial;\r\n lastMaterial._indexInSceneMaterialArray = index;\r\n }\r\n toRemove._indexInSceneMaterialArray = -1;\r\n this.materials.pop();\r\n }\r\n this.onMaterialRemovedObservable.notifyObservers(toRemove);\r\n return index;\r\n };\r\n /**\r\n * Removes the given action manager from this scene.\r\n * @param toRemove The action manager to remove\r\n * @returns The index of the removed action manager\r\n */\r\n Scene.prototype.removeActionManager = function (toRemove) {\r\n var index = this.actionManagers.indexOf(toRemove);\r\n if (index !== -1) {\r\n this.actionManagers.splice(index, 1);\r\n }\r\n return index;\r\n };\r\n /**\r\n * Removes the given texture from this scene.\r\n * @param toRemove The texture to remove\r\n * @returns The index of the removed texture\r\n */\r\n Scene.prototype.removeTexture = function (toRemove) {\r\n var index = this.textures.indexOf(toRemove);\r\n if (index !== -1) {\r\n this.textures.splice(index, 1);\r\n }\r\n this.onTextureRemovedObservable.notifyObservers(toRemove);\r\n return index;\r\n };\r\n /**\r\n * Adds the given light to this scene\r\n * @param newLight The light to add\r\n */\r\n Scene.prototype.addLight = function (newLight) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.lights.push(newLight);\r\n this.sortLightsByPriority();\r\n if (!newLight.parent) {\r\n newLight._addToSceneRootNodes();\r\n }\r\n // Add light to all meshes (To support if the light is removed and then re-added)\r\n for (var _i = 0, _a = this.meshes; _i < _a.length; _i++) {\r\n var mesh = _a[_i];\r\n if (mesh.lightSources.indexOf(newLight) === -1) {\r\n mesh.lightSources.push(newLight);\r\n mesh._resyncLightSources();\r\n }\r\n }\r\n this.onNewLightAddedObservable.notifyObservers(newLight);\r\n };\r\n /**\r\n * Sorts the list list based on light priorities\r\n */\r\n Scene.prototype.sortLightsByPriority = function () {\r\n if (this.requireLightSorting) {\r\n this.lights.sort(Light.CompareLightsPriority);\r\n }\r\n };\r\n /**\r\n * Adds the given camera to this scene\r\n * @param newCamera The camera to add\r\n */\r\n Scene.prototype.addCamera = function (newCamera) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.cameras.push(newCamera);\r\n this.onNewCameraAddedObservable.notifyObservers(newCamera);\r\n if (!newCamera.parent) {\r\n newCamera._addToSceneRootNodes();\r\n }\r\n };\r\n /**\r\n * Adds the given skeleton to this scene\r\n * @param newSkeleton The skeleton to add\r\n */\r\n Scene.prototype.addSkeleton = function (newSkeleton) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.skeletons.push(newSkeleton);\r\n this.onNewSkeletonAddedObservable.notifyObservers(newSkeleton);\r\n };\r\n /**\r\n * Adds the given particle system to this scene\r\n * @param newParticleSystem The particle system to add\r\n */\r\n Scene.prototype.addParticleSystem = function (newParticleSystem) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.particleSystems.push(newParticleSystem);\r\n };\r\n /**\r\n * Adds the given animation to this scene\r\n * @param newAnimation The animation to add\r\n */\r\n Scene.prototype.addAnimation = function (newAnimation) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.animations.push(newAnimation);\r\n };\r\n /**\r\n * Adds the given animation group to this scene.\r\n * @param newAnimationGroup The animation group to add\r\n */\r\n Scene.prototype.addAnimationGroup = function (newAnimationGroup) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.animationGroups.push(newAnimationGroup);\r\n };\r\n /**\r\n * Adds the given multi-material to this scene\r\n * @param newMultiMaterial The multi-material to add\r\n */\r\n Scene.prototype.addMultiMaterial = function (newMultiMaterial) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.multiMaterials.push(newMultiMaterial);\r\n this.onNewMultiMaterialAddedObservable.notifyObservers(newMultiMaterial);\r\n };\r\n /**\r\n * Adds the given material to this scene\r\n * @param newMaterial The material to add\r\n */\r\n Scene.prototype.addMaterial = function (newMaterial) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n newMaterial._indexInSceneMaterialArray = this.materials.length;\r\n this.materials.push(newMaterial);\r\n this.onNewMaterialAddedObservable.notifyObservers(newMaterial);\r\n };\r\n /**\r\n * Adds the given morph target to this scene\r\n * @param newMorphTargetManager The morph target to add\r\n */\r\n Scene.prototype.addMorphTargetManager = function (newMorphTargetManager) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.morphTargetManagers.push(newMorphTargetManager);\r\n };\r\n /**\r\n * Adds the given geometry to this scene\r\n * @param newGeometry The geometry to add\r\n */\r\n Scene.prototype.addGeometry = function (newGeometry) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n if (this.geometriesByUniqueId) {\r\n this.geometriesByUniqueId[newGeometry.uniqueId] = this.geometries.length;\r\n }\r\n this.geometries.push(newGeometry);\r\n };\r\n /**\r\n * Adds the given action manager to this scene\r\n * @param newActionManager The action manager to add\r\n */\r\n Scene.prototype.addActionManager = function (newActionManager) {\r\n this.actionManagers.push(newActionManager);\r\n };\r\n /**\r\n * Adds the given texture to this scene.\r\n * @param newTexture The texture to add\r\n */\r\n Scene.prototype.addTexture = function (newTexture) {\r\n if (this._blockEntityCollection) {\r\n return;\r\n }\r\n this.textures.push(newTexture);\r\n this.onNewTextureAddedObservable.notifyObservers(newTexture);\r\n };\r\n /**\r\n * Switch active camera\r\n * @param newCamera defines the new active camera\r\n * @param attachControl defines if attachControl must be called for the new active camera (default: true)\r\n */\r\n Scene.prototype.switchActiveCamera = function (newCamera, attachControl) {\r\n if (attachControl === void 0) { attachControl = true; }\r\n var canvas = this._engine.getInputElement();\r\n if (!canvas) {\r\n return;\r\n }\r\n if (this.activeCamera) {\r\n this.activeCamera.detachControl();\r\n }\r\n this.activeCamera = newCamera;\r\n if (attachControl) {\r\n newCamera.attachControl();\r\n }\r\n };\r\n /**\r\n * sets the active camera of the scene using its ID\r\n * @param id defines the camera's ID\r\n * @return the new active camera or null if none found.\r\n */\r\n Scene.prototype.setActiveCameraByID = function (id) {\r\n var camera = this.getCameraByID(id);\r\n if (camera) {\r\n this.activeCamera = camera;\r\n return camera;\r\n }\r\n return null;\r\n };\r\n /**\r\n * sets the active camera of the scene using its name\r\n * @param name defines the camera's name\r\n * @returns the new active camera or null if none found.\r\n */\r\n Scene.prototype.setActiveCameraByName = function (name) {\r\n var camera = this.getCameraByName(name);\r\n if (camera) {\r\n this.activeCamera = camera;\r\n return camera;\r\n }\r\n return null;\r\n };\r\n /**\r\n * get an animation group using its name\r\n * @param name defines the material's name\r\n * @return the animation group or null if none found.\r\n */\r\n Scene.prototype.getAnimationGroupByName = function (name) {\r\n for (var index = 0; index < this.animationGroups.length; index++) {\r\n if (this.animationGroups[index].name === name) {\r\n return this.animationGroups[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Get a material using its unique id\r\n * @param uniqueId defines the material's unique id\r\n * @return the material or null if none found.\r\n */\r\n Scene.prototype.getMaterialByUniqueID = function (uniqueId) {\r\n for (var index = 0; index < this.materials.length; index++) {\r\n if (this.materials[index].uniqueId === uniqueId) {\r\n return this.materials[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * get a material using its id\r\n * @param id defines the material's ID\r\n * @return the material or null if none found.\r\n */\r\n Scene.prototype.getMaterialByID = function (id) {\r\n for (var index = 0; index < this.materials.length; index++) {\r\n if (this.materials[index].id === id) {\r\n return this.materials[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a the last added material using a given id\r\n * @param id defines the material's ID\r\n * @return the last material with the given id or null if none found.\r\n */\r\n Scene.prototype.getLastMaterialByID = function (id) {\r\n for (var index = this.materials.length - 1; index >= 0; index--) {\r\n if (this.materials[index].id === id) {\r\n return this.materials[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a material using its name\r\n * @param name defines the material's name\r\n * @return the material or null if none found.\r\n */\r\n Scene.prototype.getMaterialByName = function (name) {\r\n for (var index = 0; index < this.materials.length; index++) {\r\n if (this.materials[index].name === name) {\r\n return this.materials[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Get a texture using its unique id\r\n * @param uniqueId defines the texture's unique id\r\n * @return the texture or null if none found.\r\n */\r\n Scene.prototype.getTextureByUniqueID = function (uniqueId) {\r\n for (var index = 0; index < this.textures.length; index++) {\r\n if (this.textures[index].uniqueId === uniqueId) {\r\n return this.textures[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a camera using its id\r\n * @param id defines the id to look for\r\n * @returns the camera or null if not found\r\n */\r\n Scene.prototype.getCameraByID = function (id) {\r\n for (var index = 0; index < this.cameras.length; index++) {\r\n if (this.cameras[index].id === id) {\r\n return this.cameras[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a camera using its unique id\r\n * @param uniqueId defines the unique id to look for\r\n * @returns the camera or null if not found\r\n */\r\n Scene.prototype.getCameraByUniqueID = function (uniqueId) {\r\n for (var index = 0; index < this.cameras.length; index++) {\r\n if (this.cameras[index].uniqueId === uniqueId) {\r\n return this.cameras[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a camera using its name\r\n * @param name defines the camera's name\r\n * @return the camera or null if none found.\r\n */\r\n Scene.prototype.getCameraByName = function (name) {\r\n for (var index = 0; index < this.cameras.length; index++) {\r\n if (this.cameras[index].name === name) {\r\n return this.cameras[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a bone using its id\r\n * @param id defines the bone's id\r\n * @return the bone or null if not found\r\n */\r\n Scene.prototype.getBoneByID = function (id) {\r\n for (var skeletonIndex = 0; skeletonIndex < this.skeletons.length; skeletonIndex++) {\r\n var skeleton = this.skeletons[skeletonIndex];\r\n for (var boneIndex = 0; boneIndex < skeleton.bones.length; boneIndex++) {\r\n if (skeleton.bones[boneIndex].id === id) {\r\n return skeleton.bones[boneIndex];\r\n }\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a bone using its id\r\n * @param name defines the bone's name\r\n * @return the bone or null if not found\r\n */\r\n Scene.prototype.getBoneByName = function (name) {\r\n for (var skeletonIndex = 0; skeletonIndex < this.skeletons.length; skeletonIndex++) {\r\n var skeleton = this.skeletons[skeletonIndex];\r\n for (var boneIndex = 0; boneIndex < skeleton.bones.length; boneIndex++) {\r\n if (skeleton.bones[boneIndex].name === name) {\r\n return skeleton.bones[boneIndex];\r\n }\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a light node using its name\r\n * @param name defines the the light's name\r\n * @return the light or null if none found.\r\n */\r\n Scene.prototype.getLightByName = function (name) {\r\n for (var index = 0; index < this.lights.length; index++) {\r\n if (this.lights[index].name === name) {\r\n return this.lights[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a light node using its id\r\n * @param id defines the light's id\r\n * @return the light or null if none found.\r\n */\r\n Scene.prototype.getLightByID = function (id) {\r\n for (var index = 0; index < this.lights.length; index++) {\r\n if (this.lights[index].id === id) {\r\n return this.lights[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a light node using its scene-generated unique ID\r\n * @param uniqueId defines the light's unique id\r\n * @return the light or null if none found.\r\n */\r\n Scene.prototype.getLightByUniqueID = function (uniqueId) {\r\n for (var index = 0; index < this.lights.length; index++) {\r\n if (this.lights[index].uniqueId === uniqueId) {\r\n return this.lights[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a particle system by id\r\n * @param id defines the particle system id\r\n * @return the corresponding system or null if none found\r\n */\r\n Scene.prototype.getParticleSystemByID = function (id) {\r\n for (var index = 0; index < this.particleSystems.length; index++) {\r\n if (this.particleSystems[index].id === id) {\r\n return this.particleSystems[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a geometry using its ID\r\n * @param id defines the geometry's id\r\n * @return the geometry or null if none found.\r\n */\r\n Scene.prototype.getGeometryByID = function (id) {\r\n for (var index = 0; index < this.geometries.length; index++) {\r\n if (this.geometries[index].id === id) {\r\n return this.geometries[index];\r\n }\r\n }\r\n return null;\r\n };\r\n Scene.prototype._getGeometryByUniqueID = function (uniqueId) {\r\n if (this.geometriesByUniqueId) {\r\n var index_1 = this.geometriesByUniqueId[uniqueId];\r\n if (index_1 !== undefined) {\r\n return this.geometries[index_1];\r\n }\r\n }\r\n else {\r\n for (var index = 0; index < this.geometries.length; index++) {\r\n if (this.geometries[index].uniqueId === uniqueId) {\r\n return this.geometries[index];\r\n }\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Add a new geometry to this scene\r\n * @param geometry defines the geometry to be added to the scene.\r\n * @param force defines if the geometry must be pushed even if a geometry with this id already exists\r\n * @return a boolean defining if the geometry was added or not\r\n */\r\n Scene.prototype.pushGeometry = function (geometry, force) {\r\n if (!force && this._getGeometryByUniqueID(geometry.uniqueId)) {\r\n return false;\r\n }\r\n this.addGeometry(geometry);\r\n this.onNewGeometryAddedObservable.notifyObservers(geometry);\r\n return true;\r\n };\r\n /**\r\n * Removes an existing geometry\r\n * @param geometry defines the geometry to be removed from the scene\r\n * @return a boolean defining if the geometry was removed or not\r\n */\r\n Scene.prototype.removeGeometry = function (geometry) {\r\n var index;\r\n if (this.geometriesByUniqueId) {\r\n index = this.geometriesByUniqueId[geometry.uniqueId];\r\n if (index === undefined) {\r\n return false;\r\n }\r\n }\r\n else {\r\n index = this.geometries.indexOf(geometry);\r\n if (index < 0) {\r\n return false;\r\n }\r\n }\r\n if (index !== this.geometries.length - 1) {\r\n var lastGeometry = this.geometries[this.geometries.length - 1];\r\n if (lastGeometry) {\r\n this.geometries[index] = lastGeometry;\r\n if (this.geometriesByUniqueId) {\r\n this.geometriesByUniqueId[lastGeometry.uniqueId] = index;\r\n this.geometriesByUniqueId[geometry.uniqueId] = undefined;\r\n }\r\n }\r\n }\r\n this.geometries.pop();\r\n this.onGeometryRemovedObservable.notifyObservers(geometry);\r\n return true;\r\n };\r\n /**\r\n * Gets the list of geometries attached to the scene\r\n * @returns an array of Geometry\r\n */\r\n Scene.prototype.getGeometries = function () {\r\n return this.geometries;\r\n };\r\n /**\r\n * Gets the first added mesh found of a given ID\r\n * @param id defines the id to search for\r\n * @return the mesh found or null if not found at all\r\n */\r\n Scene.prototype.getMeshByID = function (id) {\r\n for (var index = 0; index < this.meshes.length; index++) {\r\n if (this.meshes[index].id === id) {\r\n return this.meshes[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a list of meshes using their id\r\n * @param id defines the id to search for\r\n * @returns a list of meshes\r\n */\r\n Scene.prototype.getMeshesByID = function (id) {\r\n return this.meshes.filter(function (m) {\r\n return m.id === id;\r\n });\r\n };\r\n /**\r\n * Gets the first added transform node found of a given ID\r\n * @param id defines the id to search for\r\n * @return the found transform node or null if not found at all.\r\n */\r\n Scene.prototype.getTransformNodeByID = function (id) {\r\n for (var index = 0; index < this.transformNodes.length; index++) {\r\n if (this.transformNodes[index].id === id) {\r\n return this.transformNodes[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a transform node with its auto-generated unique id\r\n * @param uniqueId efines the unique id to search for\r\n * @return the found transform node or null if not found at all.\r\n */\r\n Scene.prototype.getTransformNodeByUniqueID = function (uniqueId) {\r\n for (var index = 0; index < this.transformNodes.length; index++) {\r\n if (this.transformNodes[index].uniqueId === uniqueId) {\r\n return this.transformNodes[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a list of transform nodes using their id\r\n * @param id defines the id to search for\r\n * @returns a list of transform nodes\r\n */\r\n Scene.prototype.getTransformNodesByID = function (id) {\r\n return this.transformNodes.filter(function (m) {\r\n return m.id === id;\r\n });\r\n };\r\n /**\r\n * Gets a mesh with its auto-generated unique id\r\n * @param uniqueId defines the unique id to search for\r\n * @return the found mesh or null if not found at all.\r\n */\r\n Scene.prototype.getMeshByUniqueID = function (uniqueId) {\r\n for (var index = 0; index < this.meshes.length; index++) {\r\n if (this.meshes[index].uniqueId === uniqueId) {\r\n return this.meshes[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a the last added mesh using a given id\r\n * @param id defines the id to search for\r\n * @return the found mesh or null if not found at all.\r\n */\r\n Scene.prototype.getLastMeshByID = function (id) {\r\n for (var index = this.meshes.length - 1; index >= 0; index--) {\r\n if (this.meshes[index].id === id) {\r\n return this.meshes[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a the last added node (Mesh, Camera, Light) using a given id\r\n * @param id defines the id to search for\r\n * @return the found node or null if not found at all\r\n */\r\n Scene.prototype.getLastEntryByID = function (id) {\r\n var index;\r\n for (index = this.meshes.length - 1; index >= 0; index--) {\r\n if (this.meshes[index].id === id) {\r\n return this.meshes[index];\r\n }\r\n }\r\n for (index = this.transformNodes.length - 1; index >= 0; index--) {\r\n if (this.transformNodes[index].id === id) {\r\n return this.transformNodes[index];\r\n }\r\n }\r\n for (index = this.cameras.length - 1; index >= 0; index--) {\r\n if (this.cameras[index].id === id) {\r\n return this.cameras[index];\r\n }\r\n }\r\n for (index = this.lights.length - 1; index >= 0; index--) {\r\n if (this.lights[index].id === id) {\r\n return this.lights[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a node (Mesh, Camera, Light) using a given id\r\n * @param id defines the id to search for\r\n * @return the found node or null if not found at all\r\n */\r\n Scene.prototype.getNodeByID = function (id) {\r\n var mesh = this.getMeshByID(id);\r\n if (mesh) {\r\n return mesh;\r\n }\r\n var transformNode = this.getTransformNodeByID(id);\r\n if (transformNode) {\r\n return transformNode;\r\n }\r\n var light = this.getLightByID(id);\r\n if (light) {\r\n return light;\r\n }\r\n var camera = this.getCameraByID(id);\r\n if (camera) {\r\n return camera;\r\n }\r\n var bone = this.getBoneByID(id);\r\n if (bone) {\r\n return bone;\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a node (Mesh, Camera, Light) using a given name\r\n * @param name defines the name to search for\r\n * @return the found node or null if not found at all.\r\n */\r\n Scene.prototype.getNodeByName = function (name) {\r\n var mesh = this.getMeshByName(name);\r\n if (mesh) {\r\n return mesh;\r\n }\r\n var transformNode = this.getTransformNodeByName(name);\r\n if (transformNode) {\r\n return transformNode;\r\n }\r\n var light = this.getLightByName(name);\r\n if (light) {\r\n return light;\r\n }\r\n var camera = this.getCameraByName(name);\r\n if (camera) {\r\n return camera;\r\n }\r\n var bone = this.getBoneByName(name);\r\n if (bone) {\r\n return bone;\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a mesh using a given name\r\n * @param name defines the name to search for\r\n * @return the found mesh or null if not found at all.\r\n */\r\n Scene.prototype.getMeshByName = function (name) {\r\n for (var index = 0; index < this.meshes.length; index++) {\r\n if (this.meshes[index].name === name) {\r\n return this.meshes[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a transform node using a given name\r\n * @param name defines the name to search for\r\n * @return the found transform node or null if not found at all.\r\n */\r\n Scene.prototype.getTransformNodeByName = function (name) {\r\n for (var index = 0; index < this.transformNodes.length; index++) {\r\n if (this.transformNodes[index].name === name) {\r\n return this.transformNodes[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a skeleton using a given id (if many are found, this function will pick the last one)\r\n * @param id defines the id to search for\r\n * @return the found skeleton or null if not found at all.\r\n */\r\n Scene.prototype.getLastSkeletonByID = function (id) {\r\n for (var index = this.skeletons.length - 1; index >= 0; index--) {\r\n if (this.skeletons[index].id === id) {\r\n return this.skeletons[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a skeleton using a given auto generated unique id\r\n * @param uniqueId defines the unique id to search for\r\n * @return the found skeleton or null if not found at all.\r\n */\r\n Scene.prototype.getSkeletonByUniqueId = function (uniqueId) {\r\n for (var index = 0; index < this.skeletons.length; index++) {\r\n if (this.skeletons[index].uniqueId === uniqueId) {\r\n return this.skeletons[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a skeleton using a given id (if many are found, this function will pick the first one)\r\n * @param id defines the id to search for\r\n * @return the found skeleton or null if not found at all.\r\n */\r\n Scene.prototype.getSkeletonById = function (id) {\r\n for (var index = 0; index < this.skeletons.length; index++) {\r\n if (this.skeletons[index].id === id) {\r\n return this.skeletons[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a skeleton using a given name\r\n * @param name defines the name to search for\r\n * @return the found skeleton or null if not found at all.\r\n */\r\n Scene.prototype.getSkeletonByName = function (name) {\r\n for (var index = 0; index < this.skeletons.length; index++) {\r\n if (this.skeletons[index].name === name) {\r\n return this.skeletons[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a morph target manager using a given id (if many are found, this function will pick the last one)\r\n * @param id defines the id to search for\r\n * @return the found morph target manager or null if not found at all.\r\n */\r\n Scene.prototype.getMorphTargetManagerById = function (id) {\r\n for (var index = 0; index < this.morphTargetManagers.length; index++) {\r\n if (this.morphTargetManagers[index].uniqueId === id) {\r\n return this.morphTargetManagers[index];\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a morph target using a given id (if many are found, this function will pick the first one)\r\n * @param id defines the id to search for\r\n * @return the found morph target or null if not found at all.\r\n */\r\n Scene.prototype.getMorphTargetById = function (id) {\r\n for (var managerIndex = 0; managerIndex < this.morphTargetManagers.length; ++managerIndex) {\r\n var morphTargetManager = this.morphTargetManagers[managerIndex];\r\n for (var index = 0; index < morphTargetManager.numTargets; ++index) {\r\n var target = morphTargetManager.getTarget(index);\r\n if (target.id === id) {\r\n return target;\r\n }\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a morph target using a given name (if many are found, this function will pick the first one)\r\n * @param name defines the name to search for\r\n * @return the found morph target or null if not found at all.\r\n */\r\n Scene.prototype.getMorphTargetByName = function (name) {\r\n for (var managerIndex = 0; managerIndex < this.morphTargetManagers.length; ++managerIndex) {\r\n var morphTargetManager = this.morphTargetManagers[managerIndex];\r\n for (var index = 0; index < morphTargetManager.numTargets; ++index) {\r\n var target = morphTargetManager.getTarget(index);\r\n if (target.name === name) {\r\n return target;\r\n }\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a post process using a given name (if many are found, this function will pick the first one)\r\n * @param name defines the name to search for\r\n * @return the found post process or null if not found at all.\r\n */\r\n Scene.prototype.getPostProcessByName = function (name) {\r\n for (var postProcessIndex = 0; postProcessIndex < this.postProcesses.length; ++postProcessIndex) {\r\n var postProcess = this.postProcesses[postProcessIndex];\r\n if (postProcess.name === name) {\r\n return postProcess;\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a boolean indicating if the given mesh is active\r\n * @param mesh defines the mesh to look for\r\n * @returns true if the mesh is in the active list\r\n */\r\n Scene.prototype.isActiveMesh = function (mesh) {\r\n return (this._activeMeshes.indexOf(mesh) !== -1);\r\n };\r\n Object.defineProperty(Scene.prototype, \"uid\", {\r\n /**\r\n * Return a unique id as a string which can serve as an identifier for the scene\r\n */\r\n get: function () {\r\n if (!this._uid) {\r\n this._uid = Tools.RandomId();\r\n }\r\n return this._uid;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Add an externaly attached data from its key.\r\n * This method call will fail and return false, if such key already exists.\r\n * If you don't care and just want to get the data no matter what, use the more convenient getOrAddExternalDataWithFactory() method.\r\n * @param key the unique key that identifies the data\r\n * @param data the data object to associate to the key for this Engine instance\r\n * @return true if no such key were already present and the data was added successfully, false otherwise\r\n */\r\n Scene.prototype.addExternalData = function (key, data) {\r\n if (!this._externalData) {\r\n this._externalData = new StringDictionary();\r\n }\r\n return this._externalData.add(key, data);\r\n };\r\n /**\r\n * Get an externaly attached data from its key\r\n * @param key the unique key that identifies the data\r\n * @return the associated data, if present (can be null), or undefined if not present\r\n */\r\n Scene.prototype.getExternalData = function (key) {\r\n if (!this._externalData) {\r\n return null;\r\n }\r\n return this._externalData.get(key);\r\n };\r\n /**\r\n * Get an externaly attached data from its key, create it using a factory if it's not already present\r\n * @param key the unique key that identifies the data\r\n * @param factory the factory that will be called to create the instance if and only if it doesn't exists\r\n * @return the associated data, can be null if the factory returned null.\r\n */\r\n Scene.prototype.getOrAddExternalDataWithFactory = function (key, factory) {\r\n if (!this._externalData) {\r\n this._externalData = new StringDictionary();\r\n }\r\n return this._externalData.getOrAddWithFactory(key, factory);\r\n };\r\n /**\r\n * Remove an externaly attached data from the Engine instance\r\n * @param key the unique key that identifies the data\r\n * @return true if the data was successfully removed, false if it doesn't exist\r\n */\r\n Scene.prototype.removeExternalData = function (key) {\r\n return this._externalData.remove(key);\r\n };\r\n Scene.prototype._evaluateSubMesh = function (subMesh, mesh, initialMesh) {\r\n if (initialMesh.hasInstances || initialMesh.isAnInstance || this.dispatchAllSubMeshesOfActiveMeshes || this._skipFrustumClipping || mesh.alwaysSelectAsActiveMesh || mesh.subMeshes.length === 1 || subMesh.isInFrustum(this._frustumPlanes)) {\r\n for (var _i = 0, _a = this._evaluateSubMeshStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n step.action(mesh, subMesh);\r\n }\r\n var material = subMesh.getMaterial();\r\n if (material !== null && material !== undefined) {\r\n // Render targets\r\n if (material.hasRenderTargetTextures && material.getRenderTargetTextures != null) {\r\n if (this._processedMaterials.indexOf(material) === -1) {\r\n this._processedMaterials.push(material);\r\n this._renderTargets.concatWithNoDuplicate(material.getRenderTargetTextures());\r\n }\r\n }\r\n // Dispatch\r\n this._renderingManager.dispatch(subMesh, mesh, material);\r\n }\r\n }\r\n };\r\n /**\r\n * Clear the processed materials smart array preventing retention point in material dispose.\r\n */\r\n Scene.prototype.freeProcessedMaterials = function () {\r\n this._processedMaterials.dispose();\r\n };\r\n Object.defineProperty(Scene.prototype, \"blockfreeActiveMeshesAndRenderingGroups\", {\r\n /** Gets or sets a boolean blocking all the calls to freeActiveMeshes and freeRenderingGroups\r\n * It can be used in order to prevent going through methods freeRenderingGroups and freeActiveMeshes several times to improve performance\r\n * when disposing several meshes in a row or a hierarchy of meshes.\r\n * When used, it is the responsability of the user to blockfreeActiveMeshesAndRenderingGroups back to false.\r\n */\r\n get: function () {\r\n return this._preventFreeActiveMeshesAndRenderingGroups;\r\n },\r\n set: function (value) {\r\n if (this._preventFreeActiveMeshesAndRenderingGroups === value) {\r\n return;\r\n }\r\n if (value) {\r\n this.freeActiveMeshes();\r\n this.freeRenderingGroups();\r\n }\r\n this._preventFreeActiveMeshesAndRenderingGroups = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Clear the active meshes smart array preventing retention point in mesh dispose.\r\n */\r\n Scene.prototype.freeActiveMeshes = function () {\r\n if (this.blockfreeActiveMeshesAndRenderingGroups) {\r\n return;\r\n }\r\n this._activeMeshes.dispose();\r\n if (this.activeCamera && this.activeCamera._activeMeshes) {\r\n this.activeCamera._activeMeshes.dispose();\r\n }\r\n if (this.activeCameras) {\r\n for (var i = 0; i < this.activeCameras.length; i++) {\r\n var activeCamera = this.activeCameras[i];\r\n if (activeCamera && activeCamera._activeMeshes) {\r\n activeCamera._activeMeshes.dispose();\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Clear the info related to rendering groups preventing retention points during dispose.\r\n */\r\n Scene.prototype.freeRenderingGroups = function () {\r\n if (this.blockfreeActiveMeshesAndRenderingGroups) {\r\n return;\r\n }\r\n if (this._renderingManager) {\r\n this._renderingManager.freeRenderingGroups();\r\n }\r\n if (this.textures) {\r\n for (var i = 0; i < this.textures.length; i++) {\r\n var texture = this.textures[i];\r\n if (texture && texture.renderList) {\r\n texture.freeRenderingGroups();\r\n }\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n Scene.prototype._isInIntermediateRendering = function () {\r\n return this._intermediateRendering;\r\n };\r\n /**\r\n * Use this function to stop evaluating active meshes. The current list will be keep alive between frames\r\n * @param skipEvaluateActiveMeshes defines an optional boolean indicating that the evaluate active meshes step must be completely skipped\r\n * @param onSuccess optional success callback\r\n * @param onError optional error callback\r\n * @returns the current scene\r\n */\r\n Scene.prototype.freezeActiveMeshes = function (skipEvaluateActiveMeshes, onSuccess, onError) {\r\n var _this = this;\r\n if (skipEvaluateActiveMeshes === void 0) { skipEvaluateActiveMeshes = false; }\r\n this.executeWhenReady(function () {\r\n if (!_this.activeCamera) {\r\n onError && onError('No active camera found');\r\n return;\r\n }\r\n if (!_this._frustumPlanes) {\r\n _this.setTransformMatrix(_this.activeCamera.getViewMatrix(), _this.activeCamera.getProjectionMatrix());\r\n }\r\n _this._evaluateActiveMeshes();\r\n _this._activeMeshesFrozen = true;\r\n _this._skipEvaluateActiveMeshesCompletely = skipEvaluateActiveMeshes;\r\n for (var index = 0; index < _this._activeMeshes.length; index++) {\r\n _this._activeMeshes.data[index]._freeze();\r\n }\r\n onSuccess && onSuccess();\r\n });\r\n return this;\r\n };\r\n /**\r\n * Use this function to restart evaluating active meshes on every frame\r\n * @returns the current scene\r\n */\r\n Scene.prototype.unfreezeActiveMeshes = function () {\r\n for (var index = 0; index < this.meshes.length; index++) {\r\n var mesh = this.meshes[index];\r\n if (mesh._internalAbstractMeshDataInfo) {\r\n mesh._internalAbstractMeshDataInfo._isActive = false;\r\n }\r\n }\r\n for (var index = 0; index < this._activeMeshes.length; index++) {\r\n this._activeMeshes.data[index]._unFreeze();\r\n }\r\n this._activeMeshesFrozen = false;\r\n return this;\r\n };\r\n Scene.prototype._evaluateActiveMeshes = function () {\r\n if (this._activeMeshesFrozen && this._activeMeshes.length) {\r\n if (!this._skipEvaluateActiveMeshesCompletely) {\r\n var len_1 = this._activeMeshes.length;\r\n for (var i = 0; i < len_1; i++) {\r\n var mesh = this._activeMeshes.data[i];\r\n mesh.computeWorldMatrix();\r\n }\r\n }\r\n if (this._activeParticleSystems) {\r\n var psLength = this._activeParticleSystems.length;\r\n for (var i = 0; i < psLength; i++) {\r\n this._activeParticleSystems.data[i].animate();\r\n }\r\n }\r\n return;\r\n }\r\n if (!this.activeCamera) {\r\n return;\r\n }\r\n this.onBeforeActiveMeshesEvaluationObservable.notifyObservers(this);\r\n this.activeCamera._activeMeshes.reset();\r\n this._activeMeshes.reset();\r\n this._renderingManager.reset();\r\n this._processedMaterials.reset();\r\n this._activeParticleSystems.reset();\r\n this._activeSkeletons.reset();\r\n this._softwareSkinnedMeshes.reset();\r\n for (var _i = 0, _a = this._beforeEvaluateActiveMeshStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n step.action();\r\n }\r\n // Determine mesh candidates\r\n var meshes = this.getActiveMeshCandidates();\r\n // Check each mesh\r\n var len = meshes.length;\r\n for (var i = 0; i < len; i++) {\r\n var mesh = meshes.data[i];\r\n mesh._internalAbstractMeshDataInfo._currentLODIsUpToDate = false;\r\n if (mesh.isBlocked) {\r\n continue;\r\n }\r\n this._totalVertices.addCount(mesh.getTotalVertices(), false);\r\n if (!mesh.isReady() || !mesh.isEnabled() || mesh.scaling.lengthSquared() === 0) {\r\n continue;\r\n }\r\n mesh.computeWorldMatrix();\r\n // Intersections\r\n if (mesh.actionManager && mesh.actionManager.hasSpecificTriggers2(12, 13)) {\r\n this._meshesForIntersections.pushNoDuplicate(mesh);\r\n }\r\n // Switch to current LOD\r\n var meshToRender = this.customLODSelector ? this.customLODSelector(mesh, this.activeCamera) : mesh.getLOD(this.activeCamera);\r\n mesh._internalAbstractMeshDataInfo._currentLOD = meshToRender;\r\n mesh._internalAbstractMeshDataInfo._currentLODIsUpToDate = true;\r\n if (meshToRender === undefined || meshToRender === null) {\r\n continue;\r\n }\r\n // Compute world matrix if LOD is billboard\r\n if (meshToRender !== mesh && meshToRender.billboardMode !== TransformNode.BILLBOARDMODE_NONE) {\r\n meshToRender.computeWorldMatrix();\r\n }\r\n mesh._preActivate();\r\n if (mesh.isVisible && mesh.visibility > 0 && ((mesh.layerMask & this.activeCamera.layerMask) !== 0) && (this._skipFrustumClipping || mesh.alwaysSelectAsActiveMesh || mesh.isInFrustum(this._frustumPlanes))) {\r\n this._activeMeshes.push(mesh);\r\n this.activeCamera._activeMeshes.push(mesh);\r\n if (meshToRender !== mesh) {\r\n meshToRender._activate(this._renderId, false);\r\n }\r\n for (var _b = 0, _c = this._preActiveMeshStage; _b < _c.length; _b++) {\r\n var step = _c[_b];\r\n step.action(mesh);\r\n }\r\n if (mesh._activate(this._renderId, false)) {\r\n if (!mesh.isAnInstance) {\r\n meshToRender._internalAbstractMeshDataInfo._onlyForInstances = false;\r\n }\r\n else {\r\n if (mesh._internalAbstractMeshDataInfo._actAsRegularMesh) {\r\n meshToRender = mesh;\r\n }\r\n }\r\n meshToRender._internalAbstractMeshDataInfo._isActive = true;\r\n this._activeMesh(mesh, meshToRender);\r\n }\r\n mesh._postActivate();\r\n }\r\n }\r\n this.onAfterActiveMeshesEvaluationObservable.notifyObservers(this);\r\n // Particle systems\r\n if (this.particlesEnabled) {\r\n this.onBeforeParticlesRenderingObservable.notifyObservers(this);\r\n for (var particleIndex = 0; particleIndex < this.particleSystems.length; particleIndex++) {\r\n var particleSystem = this.particleSystems[particleIndex];\r\n if (!particleSystem.isStarted() || !particleSystem.emitter) {\r\n continue;\r\n }\r\n var emitter = particleSystem.emitter;\r\n if (!emitter.position || emitter.isEnabled()) {\r\n this._activeParticleSystems.push(particleSystem);\r\n particleSystem.animate();\r\n this._renderingManager.dispatchParticles(particleSystem);\r\n }\r\n }\r\n this.onAfterParticlesRenderingObservable.notifyObservers(this);\r\n }\r\n };\r\n Scene.prototype._activeMesh = function (sourceMesh, mesh) {\r\n if (this._skeletonsEnabled && mesh.skeleton !== null && mesh.skeleton !== undefined) {\r\n if (this._activeSkeletons.pushNoDuplicate(mesh.skeleton)) {\r\n mesh.skeleton.prepare();\r\n }\r\n if (!mesh.computeBonesUsingShaders) {\r\n this._softwareSkinnedMeshes.pushNoDuplicate(mesh);\r\n }\r\n }\r\n if (mesh !== undefined && mesh !== null\r\n && mesh.subMeshes !== undefined && mesh.subMeshes !== null && mesh.subMeshes.length > 0) {\r\n var subMeshes = this.getActiveSubMeshCandidates(mesh);\r\n var len = subMeshes.length;\r\n for (var i = 0; i < len; i++) {\r\n var subMesh = subMeshes.data[i];\r\n this._evaluateSubMesh(subMesh, mesh, sourceMesh);\r\n }\r\n }\r\n };\r\n /**\r\n * Update the transform matrix to update from the current active camera\r\n * @param force defines a boolean used to force the update even if cache is up to date\r\n */\r\n Scene.prototype.updateTransformMatrix = function (force) {\r\n if (!this.activeCamera) {\r\n return;\r\n }\r\n this.setTransformMatrix(this.activeCamera.getViewMatrix(), this.activeCamera.getProjectionMatrix(force));\r\n };\r\n Scene.prototype._bindFrameBuffer = function () {\r\n if (this.activeCamera && this.activeCamera._multiviewTexture) {\r\n this.activeCamera._multiviewTexture._bindFrameBuffer();\r\n }\r\n else if (this.activeCamera && this.activeCamera.outputRenderTarget) {\r\n var useMultiview = this.getEngine().getCaps().multiview && this.activeCamera.outputRenderTarget && this.activeCamera.outputRenderTarget.getViewCount() > 1;\r\n if (useMultiview) {\r\n this.activeCamera.outputRenderTarget._bindFrameBuffer();\r\n }\r\n else {\r\n var internalTexture = this.activeCamera.outputRenderTarget.getInternalTexture();\r\n if (internalTexture) {\r\n this.getEngine().bindFramebuffer(internalTexture);\r\n }\r\n else {\r\n Logger.Error(\"Camera contains invalid customDefaultRenderTarget\");\r\n }\r\n }\r\n }\r\n else {\r\n this.getEngine().restoreDefaultFramebuffer(); // Restore back buffer if needed\r\n }\r\n };\r\n /** @hidden */\r\n Scene.prototype._renderForCamera = function (camera, rigParent) {\r\n if (camera && camera._skipRendering) {\r\n return;\r\n }\r\n var engine = this._engine;\r\n // Use _activeCamera instead of activeCamera to avoid onActiveCameraChanged\r\n this._activeCamera = camera;\r\n if (!this.activeCamera) {\r\n throw new Error(\"Active camera not set\");\r\n }\r\n // Viewport\r\n engine.setViewport(this.activeCamera.viewport);\r\n // Camera\r\n this.resetCachedMaterial();\r\n this._renderId++;\r\n var useMultiview = this.getEngine().getCaps().multiview && camera.outputRenderTarget && camera.outputRenderTarget.getViewCount() > 1;\r\n if (useMultiview) {\r\n this.setTransformMatrix(camera._rigCameras[0].getViewMatrix(), camera._rigCameras[0].getProjectionMatrix(), camera._rigCameras[1].getViewMatrix(), camera._rigCameras[1].getProjectionMatrix());\r\n }\r\n else {\r\n this.updateTransformMatrix();\r\n }\r\n this.onBeforeCameraRenderObservable.notifyObservers(this.activeCamera);\r\n // Meshes\r\n this._evaluateActiveMeshes();\r\n // Software skinning\r\n for (var softwareSkinnedMeshIndex = 0; softwareSkinnedMeshIndex < this._softwareSkinnedMeshes.length; softwareSkinnedMeshIndex++) {\r\n var mesh = this._softwareSkinnedMeshes.data[softwareSkinnedMeshIndex];\r\n mesh.applySkeleton(mesh.skeleton);\r\n }\r\n // Render targets\r\n this.onBeforeRenderTargetsRenderObservable.notifyObservers(this);\r\n if (camera.customRenderTargets && camera.customRenderTargets.length > 0) {\r\n this._renderTargets.concatWithNoDuplicate(camera.customRenderTargets);\r\n }\r\n if (rigParent && rigParent.customRenderTargets && rigParent.customRenderTargets.length > 0) {\r\n this._renderTargets.concatWithNoDuplicate(rigParent.customRenderTargets);\r\n }\r\n // Collects render targets from external components.\r\n for (var _i = 0, _a = this._gatherActiveCameraRenderTargetsStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n step.action(this._renderTargets);\r\n }\r\n var needRebind = false;\r\n if (this.renderTargetsEnabled) {\r\n this._intermediateRendering = true;\r\n if (this._renderTargets.length > 0) {\r\n Tools.StartPerformanceCounter(\"Render targets\", this._renderTargets.length > 0);\r\n for (var renderIndex = 0; renderIndex < this._renderTargets.length; renderIndex++) {\r\n var renderTarget = this._renderTargets.data[renderIndex];\r\n if (renderTarget._shouldRender()) {\r\n this._renderId++;\r\n var hasSpecialRenderTargetCamera = renderTarget.activeCamera && renderTarget.activeCamera !== this.activeCamera;\r\n renderTarget.render(hasSpecialRenderTargetCamera, this.dumpNextRenderTargets);\r\n needRebind = true;\r\n }\r\n }\r\n Tools.EndPerformanceCounter(\"Render targets\", this._renderTargets.length > 0);\r\n this._renderId++;\r\n }\r\n for (var _b = 0, _c = this._cameraDrawRenderTargetStage; _b < _c.length; _b++) {\r\n var step = _c[_b];\r\n needRebind = step.action(this.activeCamera) || needRebind;\r\n }\r\n this._intermediateRendering = false;\r\n // Need to bind if sub-camera has an outputRenderTarget eg. for webXR\r\n if (this.activeCamera && this.activeCamera.outputRenderTarget) {\r\n needRebind = true;\r\n }\r\n }\r\n // Restore framebuffer after rendering to targets\r\n if (needRebind && !this.prePass) {\r\n this._bindFrameBuffer();\r\n }\r\n this.onAfterRenderTargetsRenderObservable.notifyObservers(this);\r\n // Prepare Frame\r\n if (this.postProcessManager && !camera._multiviewTexture && !this.prePass) {\r\n this.postProcessManager._prepareFrame();\r\n }\r\n // Before Camera Draw\r\n for (var _d = 0, _e = this._beforeCameraDrawStage; _d < _e.length; _d++) {\r\n var step = _e[_d];\r\n step.action(this.activeCamera);\r\n }\r\n // Render\r\n this.onBeforeDrawPhaseObservable.notifyObservers(this);\r\n this._renderingManager.render(null, null, true, true);\r\n this.onAfterDrawPhaseObservable.notifyObservers(this);\r\n // After Camera Draw\r\n for (var _f = 0, _g = this._afterCameraDrawStage; _f < _g.length; _f++) {\r\n var step = _g[_f];\r\n step.action(this.activeCamera);\r\n }\r\n // Finalize frame\r\n if (this.postProcessManager && !camera._multiviewTexture) {\r\n // if the camera has an output render target, render the post process to the render target\r\n var texture = camera.outputRenderTarget ? camera.outputRenderTarget.getInternalTexture() : undefined;\r\n this.postProcessManager._finalizeFrame(camera.isIntermediate, texture);\r\n }\r\n // Reset some special arrays\r\n this._renderTargets.reset();\r\n this.onAfterCameraRenderObservable.notifyObservers(this.activeCamera);\r\n };\r\n Scene.prototype._processSubCameras = function (camera) {\r\n if (camera.cameraRigMode === Camera.RIG_MODE_NONE || (camera.outputRenderTarget && camera.outputRenderTarget.getViewCount() > 1 && this.getEngine().getCaps().multiview)) {\r\n this._renderForCamera(camera);\r\n this.onAfterRenderCameraObservable.notifyObservers(camera);\r\n return;\r\n }\r\n if (camera._useMultiviewToSingleView) {\r\n this._renderMultiviewToSingleView(camera);\r\n }\r\n else {\r\n // rig cameras\r\n for (var index = 0; index < camera._rigCameras.length; index++) {\r\n this._renderForCamera(camera._rigCameras[index], camera);\r\n }\r\n }\r\n // Use _activeCamera instead of activeCamera to avoid onActiveCameraChanged\r\n this._activeCamera = camera;\r\n this.setTransformMatrix(this._activeCamera.getViewMatrix(), this._activeCamera.getProjectionMatrix());\r\n this.onAfterRenderCameraObservable.notifyObservers(camera);\r\n };\r\n Scene.prototype._checkIntersections = function () {\r\n for (var index = 0; index < this._meshesForIntersections.length; index++) {\r\n var sourceMesh = this._meshesForIntersections.data[index];\r\n if (!sourceMesh.actionManager) {\r\n continue;\r\n }\r\n for (var actionIndex = 0; sourceMesh.actionManager && actionIndex < sourceMesh.actionManager.actions.length; actionIndex++) {\r\n var action = sourceMesh.actionManager.actions[actionIndex];\r\n if (action.trigger === 12 || action.trigger === 13) {\r\n var parameters = action.getTriggerParameter();\r\n var otherMesh = parameters instanceof AbstractMesh ? parameters : parameters.mesh;\r\n var areIntersecting = otherMesh.intersectsMesh(sourceMesh, parameters.usePreciseIntersection);\r\n var currentIntersectionInProgress = sourceMesh._intersectionsInProgress.indexOf(otherMesh);\r\n if (areIntersecting && currentIntersectionInProgress === -1) {\r\n if (action.trigger === 12) {\r\n action._executeCurrent(ActionEvent.CreateNew(sourceMesh, undefined, otherMesh));\r\n sourceMesh._intersectionsInProgress.push(otherMesh);\r\n }\r\n else if (action.trigger === 13) {\r\n sourceMesh._intersectionsInProgress.push(otherMesh);\r\n }\r\n }\r\n else if (!areIntersecting && currentIntersectionInProgress > -1) {\r\n //They intersected, and now they don't.\r\n //is this trigger an exit trigger? execute an event.\r\n if (action.trigger === 13) {\r\n action._executeCurrent(ActionEvent.CreateNew(sourceMesh, undefined, otherMesh));\r\n }\r\n //if this is an exit trigger, or no exit trigger exists, remove the id from the intersection in progress array.\r\n if (!sourceMesh.actionManager.hasSpecificTrigger(13, function (parameter) {\r\n var parameterMesh = parameter instanceof AbstractMesh ? parameter : parameter.mesh;\r\n return otherMesh === parameterMesh;\r\n }) || action.trigger === 13) {\r\n sourceMesh._intersectionsInProgress.splice(currentIntersectionInProgress, 1);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n Scene.prototype._advancePhysicsEngineStep = function (step) {\r\n // Do nothing. Code will be replaced if physics engine component is referenced\r\n };\r\n /** @hidden */\r\n Scene.prototype._animate = function () {\r\n // Nothing to do as long as Animatable have not been imported.\r\n };\r\n /** Execute all animations (for a frame) */\r\n Scene.prototype.animate = function () {\r\n if (this._engine.isDeterministicLockStep()) {\r\n var deltaTime = Math.max(Scene.MinDeltaTime, Math.min(this._engine.getDeltaTime(), Scene.MaxDeltaTime)) + this._timeAccumulator;\r\n var defaultFrameTime = this._engine.getTimeStep();\r\n var defaultFPS = (1000.0 / defaultFrameTime) / 1000.0;\r\n var stepsTaken = 0;\r\n var maxSubSteps = this._engine.getLockstepMaxSteps();\r\n var internalSteps = Math.floor(deltaTime / defaultFrameTime);\r\n internalSteps = Math.min(internalSteps, maxSubSteps);\r\n while (deltaTime > 0 && stepsTaken < internalSteps) {\r\n this.onBeforeStepObservable.notifyObservers(this);\r\n // Animations\r\n this._animationRatio = defaultFrameTime * defaultFPS;\r\n this._animate();\r\n this.onAfterAnimationsObservable.notifyObservers(this);\r\n // Physics\r\n if (this.physicsEnabled) {\r\n this._advancePhysicsEngineStep(defaultFrameTime);\r\n }\r\n this.onAfterStepObservable.notifyObservers(this);\r\n this._currentStepId++;\r\n stepsTaken++;\r\n deltaTime -= defaultFrameTime;\r\n }\r\n this._timeAccumulator = deltaTime < 0 ? 0 : deltaTime;\r\n }\r\n else {\r\n // Animations\r\n var deltaTime = this.useConstantAnimationDeltaTime ? 16 : Math.max(Scene.MinDeltaTime, Math.min(this._engine.getDeltaTime(), Scene.MaxDeltaTime));\r\n this._animationRatio = deltaTime * (60.0 / 1000.0);\r\n this._animate();\r\n this.onAfterAnimationsObservable.notifyObservers(this);\r\n // Physics\r\n if (this.physicsEnabled) {\r\n this._advancePhysicsEngineStep(deltaTime);\r\n }\r\n }\r\n };\r\n /**\r\n * Render the scene\r\n * @param updateCameras defines a boolean indicating if cameras must update according to their inputs (true by default)\r\n * @param ignoreAnimations defines a boolean indicating if animations should not be executed (false by default)\r\n */\r\n Scene.prototype.render = function (updateCameras, ignoreAnimations) {\r\n if (updateCameras === void 0) { updateCameras = true; }\r\n if (ignoreAnimations === void 0) { ignoreAnimations = false; }\r\n if (this.isDisposed) {\r\n return;\r\n }\r\n if (this.onReadyObservable.hasObservers() && this._executeWhenReadyTimeoutId === -1) {\r\n this._checkIsReady();\r\n }\r\n this._frameId++;\r\n // Register components that have been associated lately to the scene.\r\n this._registerTransientComponents();\r\n this._activeParticles.fetchNewFrame();\r\n this._totalVertices.fetchNewFrame();\r\n this._activeIndices.fetchNewFrame();\r\n this._activeBones.fetchNewFrame();\r\n this._meshesForIntersections.reset();\r\n this.resetCachedMaterial();\r\n this.onBeforeAnimationsObservable.notifyObservers(this);\r\n // Actions\r\n if (this.actionManager) {\r\n this.actionManager.processTrigger(11);\r\n }\r\n // Animations\r\n if (!ignoreAnimations) {\r\n this.animate();\r\n }\r\n // Before camera update steps\r\n for (var _i = 0, _a = this._beforeCameraUpdateStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n step.action();\r\n }\r\n // Update Cameras\r\n if (updateCameras) {\r\n if (this.activeCameras && this.activeCameras.length > 0) {\r\n for (var cameraIndex = 0; cameraIndex < this.activeCameras.length; cameraIndex++) {\r\n var camera = this.activeCameras[cameraIndex];\r\n camera.update();\r\n if (camera.cameraRigMode !== Camera.RIG_MODE_NONE) {\r\n // rig cameras\r\n for (var index = 0; index < camera._rigCameras.length; index++) {\r\n camera._rigCameras[index].update();\r\n }\r\n }\r\n }\r\n }\r\n else if (this.activeCamera) {\r\n this.activeCamera.update();\r\n if (this.activeCamera.cameraRigMode !== Camera.RIG_MODE_NONE) {\r\n // rig cameras\r\n for (var index = 0; index < this.activeCamera._rigCameras.length; index++) {\r\n this.activeCamera._rigCameras[index].update();\r\n }\r\n }\r\n }\r\n }\r\n // Before render\r\n this.onBeforeRenderObservable.notifyObservers(this);\r\n // Customs render targets\r\n this.onBeforeRenderTargetsRenderObservable.notifyObservers(this);\r\n var engine = this.getEngine();\r\n var currentActiveCamera = this.activeCamera;\r\n if (this.renderTargetsEnabled) {\r\n Tools.StartPerformanceCounter(\"Custom render targets\", this.customRenderTargets.length > 0);\r\n this._intermediateRendering = true;\r\n for (var customIndex = 0; customIndex < this.customRenderTargets.length; customIndex++) {\r\n var renderTarget = this.customRenderTargets[customIndex];\r\n if (renderTarget._shouldRender()) {\r\n this._renderId++;\r\n this.activeCamera = renderTarget.activeCamera || this.activeCamera;\r\n if (!this.activeCamera) {\r\n throw new Error(\"Active camera not set\");\r\n }\r\n // Viewport\r\n engine.setViewport(this.activeCamera.viewport);\r\n // Camera\r\n this.updateTransformMatrix();\r\n renderTarget.render(currentActiveCamera !== this.activeCamera, this.dumpNextRenderTargets);\r\n }\r\n }\r\n Tools.EndPerformanceCounter(\"Custom render targets\", this.customRenderTargets.length > 0);\r\n this._intermediateRendering = false;\r\n this._renderId++;\r\n }\r\n // Restore back buffer\r\n this.activeCamera = currentActiveCamera;\r\n if (this._activeCamera && this._activeCamera.cameraRigMode !== Camera.RIG_MODE_CUSTOM && !this.prePass) {\r\n this._bindFrameBuffer();\r\n }\r\n this.onAfterRenderTargetsRenderObservable.notifyObservers(this);\r\n for (var _b = 0, _c = this._beforeClearStage; _b < _c.length; _b++) {\r\n var step = _c[_b];\r\n step.action();\r\n }\r\n // Clear\r\n if ((this.autoClearDepthAndStencil || this.autoClear) && !this.prePass) {\r\n this._engine.clear(this.clearColor, this.autoClear || this.forceWireframe || this.forcePointsCloud, this.autoClearDepthAndStencil, this.autoClearDepthAndStencil);\r\n }\r\n // Collects render targets from external components.\r\n for (var _d = 0, _e = this._gatherRenderTargetsStage; _d < _e.length; _d++) {\r\n var step = _e[_d];\r\n step.action(this._renderTargets);\r\n }\r\n // Multi-cameras?\r\n if (this.activeCameras && this.activeCameras.length > 0) {\r\n for (var cameraIndex = 0; cameraIndex < this.activeCameras.length; cameraIndex++) {\r\n if (cameraIndex > 0) {\r\n this._engine.clear(null, false, true, true);\r\n }\r\n this._processSubCameras(this.activeCameras[cameraIndex]);\r\n }\r\n }\r\n else {\r\n if (!this.activeCamera) {\r\n throw new Error(\"No camera defined\");\r\n }\r\n this._processSubCameras(this.activeCamera);\r\n }\r\n // Intersection checks\r\n this._checkIntersections();\r\n // Executes the after render stage actions.\r\n for (var _f = 0, _g = this._afterRenderStage; _f < _g.length; _f++) {\r\n var step = _g[_f];\r\n step.action();\r\n }\r\n // After render\r\n if (this.afterRender) {\r\n this.afterRender();\r\n }\r\n this.onAfterRenderObservable.notifyObservers(this);\r\n // Cleaning\r\n if (this._toBeDisposed.length) {\r\n for (var index = 0; index < this._toBeDisposed.length; index++) {\r\n var data = this._toBeDisposed[index];\r\n if (data) {\r\n data.dispose();\r\n }\r\n }\r\n this._toBeDisposed = [];\r\n }\r\n if (this.dumpNextRenderTargets) {\r\n this.dumpNextRenderTargets = false;\r\n }\r\n this._activeBones.addCount(0, true);\r\n this._activeIndices.addCount(0, true);\r\n this._activeParticles.addCount(0, true);\r\n };\r\n /**\r\n * Freeze all materials\r\n * A frozen material will not be updatable but should be faster to render\r\n */\r\n Scene.prototype.freezeMaterials = function () {\r\n for (var i = 0; i < this.materials.length; i++) {\r\n this.materials[i].freeze();\r\n }\r\n };\r\n /**\r\n * Unfreeze all materials\r\n * A frozen material will not be updatable but should be faster to render\r\n */\r\n Scene.prototype.unfreezeMaterials = function () {\r\n for (var i = 0; i < this.materials.length; i++) {\r\n this.materials[i].unfreeze();\r\n }\r\n };\r\n /**\r\n * Releases all held ressources\r\n */\r\n Scene.prototype.dispose = function () {\r\n this.beforeRender = null;\r\n this.afterRender = null;\r\n if (EngineStore._LastCreatedScene === this) {\r\n EngineStore._LastCreatedScene = null;\r\n }\r\n this.skeletons = [];\r\n this.morphTargetManagers = [];\r\n this._transientComponents = [];\r\n this._isReadyForMeshStage.clear();\r\n this._beforeEvaluateActiveMeshStage.clear();\r\n this._evaluateSubMeshStage.clear();\r\n this._preActiveMeshStage.clear();\r\n this._cameraDrawRenderTargetStage.clear();\r\n this._beforeCameraDrawStage.clear();\r\n this._beforeRenderTargetDrawStage.clear();\r\n this._beforeRenderingGroupDrawStage.clear();\r\n this._beforeRenderingMeshStage.clear();\r\n this._afterRenderingMeshStage.clear();\r\n this._afterRenderingGroupDrawStage.clear();\r\n this._afterCameraDrawStage.clear();\r\n this._afterRenderTargetDrawStage.clear();\r\n this._afterRenderStage.clear();\r\n this._beforeCameraUpdateStage.clear();\r\n this._beforeClearStage.clear();\r\n this._gatherRenderTargetsStage.clear();\r\n this._gatherActiveCameraRenderTargetsStage.clear();\r\n this._pointerMoveStage.clear();\r\n this._pointerDownStage.clear();\r\n this._pointerUpStage.clear();\r\n for (var _i = 0, _a = this._components; _i < _a.length; _i++) {\r\n var component = _a[_i];\r\n component.dispose();\r\n }\r\n this.importedMeshesFiles = new Array();\r\n if (this.stopAllAnimations) {\r\n this.stopAllAnimations();\r\n }\r\n this.resetCachedMaterial();\r\n // Smart arrays\r\n if (this.activeCamera) {\r\n this.activeCamera._activeMeshes.dispose();\r\n this.activeCamera = null;\r\n }\r\n this._activeMeshes.dispose();\r\n this._renderingManager.dispose();\r\n this._processedMaterials.dispose();\r\n this._activeParticleSystems.dispose();\r\n this._activeSkeletons.dispose();\r\n this._softwareSkinnedMeshes.dispose();\r\n this._renderTargets.dispose();\r\n this._registeredForLateAnimationBindings.dispose();\r\n this._meshesForIntersections.dispose();\r\n this._toBeDisposed = [];\r\n // Abort active requests\r\n for (var _b = 0, _c = this._activeRequests; _b < _c.length; _b++) {\r\n var request = _c[_b];\r\n request.abort();\r\n }\r\n // Events\r\n this.onDisposeObservable.notifyObservers(this);\r\n this.onDisposeObservable.clear();\r\n this.onBeforeRenderObservable.clear();\r\n this.onAfterRenderObservable.clear();\r\n this.onBeforeRenderTargetsRenderObservable.clear();\r\n this.onAfterRenderTargetsRenderObservable.clear();\r\n this.onAfterStepObservable.clear();\r\n this.onBeforeStepObservable.clear();\r\n this.onBeforeActiveMeshesEvaluationObservable.clear();\r\n this.onAfterActiveMeshesEvaluationObservable.clear();\r\n this.onBeforeParticlesRenderingObservable.clear();\r\n this.onAfterParticlesRenderingObservable.clear();\r\n this.onBeforeDrawPhaseObservable.clear();\r\n this.onAfterDrawPhaseObservable.clear();\r\n this.onBeforeAnimationsObservable.clear();\r\n this.onAfterAnimationsObservable.clear();\r\n this.onDataLoadedObservable.clear();\r\n this.onBeforeRenderingGroupObservable.clear();\r\n this.onAfterRenderingGroupObservable.clear();\r\n this.onMeshImportedObservable.clear();\r\n this.onBeforeCameraRenderObservable.clear();\r\n this.onAfterCameraRenderObservable.clear();\r\n this.onReadyObservable.clear();\r\n this.onNewCameraAddedObservable.clear();\r\n this.onCameraRemovedObservable.clear();\r\n this.onNewLightAddedObservable.clear();\r\n this.onLightRemovedObservable.clear();\r\n this.onNewGeometryAddedObservable.clear();\r\n this.onGeometryRemovedObservable.clear();\r\n this.onNewTransformNodeAddedObservable.clear();\r\n this.onTransformNodeRemovedObservable.clear();\r\n this.onNewMeshAddedObservable.clear();\r\n this.onMeshRemovedObservable.clear();\r\n this.onNewSkeletonAddedObservable.clear();\r\n this.onSkeletonRemovedObservable.clear();\r\n this.onNewMaterialAddedObservable.clear();\r\n this.onNewMultiMaterialAddedObservable.clear();\r\n this.onMaterialRemovedObservable.clear();\r\n this.onMultiMaterialRemovedObservable.clear();\r\n this.onNewTextureAddedObservable.clear();\r\n this.onTextureRemovedObservable.clear();\r\n this.onPrePointerObservable.clear();\r\n this.onPointerObservable.clear();\r\n this.onPreKeyboardObservable.clear();\r\n this.onKeyboardObservable.clear();\r\n this.onActiveCameraChanged.clear();\r\n this.detachControl();\r\n // Detach cameras\r\n var canvas = this._engine.getInputElement();\r\n if (canvas) {\r\n var index;\r\n for (index = 0; index < this.cameras.length; index++) {\r\n this.cameras[index].detachControl();\r\n }\r\n }\r\n // Release animation groups\r\n while (this.animationGroups.length) {\r\n this.animationGroups[0].dispose();\r\n }\r\n // Release lights\r\n while (this.lights.length) {\r\n this.lights[0].dispose();\r\n }\r\n // Release meshes\r\n while (this.meshes.length) {\r\n this.meshes[0].dispose(true);\r\n }\r\n while (this.transformNodes.length) {\r\n this.transformNodes[0].dispose(true);\r\n }\r\n // Release cameras\r\n while (this.cameras.length) {\r\n this.cameras[0].dispose();\r\n }\r\n // Release materials\r\n if (this._defaultMaterial) {\r\n this._defaultMaterial.dispose();\r\n }\r\n while (this.multiMaterials.length) {\r\n this.multiMaterials[0].dispose();\r\n }\r\n while (this.materials.length) {\r\n this.materials[0].dispose();\r\n }\r\n // Release particles\r\n while (this.particleSystems.length) {\r\n this.particleSystems[0].dispose();\r\n }\r\n // Release postProcesses\r\n while (this.postProcesses.length) {\r\n this.postProcesses[0].dispose();\r\n }\r\n // Release textures\r\n while (this.textures.length) {\r\n this.textures[0].dispose();\r\n }\r\n // Release UBO\r\n this._sceneUbo.dispose();\r\n if (this._multiviewSceneUbo) {\r\n this._multiviewSceneUbo.dispose();\r\n }\r\n // Post-processes\r\n this.postProcessManager.dispose();\r\n // Remove from engine\r\n index = this._engine.scenes.indexOf(this);\r\n if (index > -1) {\r\n this._engine.scenes.splice(index, 1);\r\n }\r\n this._engine.wipeCaches(true);\r\n this._isDisposed = true;\r\n };\r\n Object.defineProperty(Scene.prototype, \"isDisposed\", {\r\n /**\r\n * Gets if the scene is already disposed\r\n */\r\n get: function () {\r\n return this._isDisposed;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Call this function to reduce memory footprint of the scene.\r\n * Vertex buffers will not store CPU data anymore (this will prevent picking, collisions or physics to work correctly)\r\n */\r\n Scene.prototype.clearCachedVertexData = function () {\r\n for (var meshIndex = 0; meshIndex < this.meshes.length; meshIndex++) {\r\n var mesh = this.meshes[meshIndex];\r\n var geometry = mesh.geometry;\r\n if (geometry) {\r\n geometry._indices = [];\r\n for (var vbName in geometry._vertexBuffers) {\r\n if (!geometry._vertexBuffers.hasOwnProperty(vbName)) {\r\n continue;\r\n }\r\n geometry._vertexBuffers[vbName]._buffer._data = null;\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * This function will remove the local cached buffer data from texture.\r\n * It will save memory but will prevent the texture from being rebuilt\r\n */\r\n Scene.prototype.cleanCachedTextureBuffer = function () {\r\n for (var _i = 0, _a = this.textures; _i < _a.length; _i++) {\r\n var baseTexture = _a[_i];\r\n var buffer = baseTexture._buffer;\r\n if (buffer) {\r\n baseTexture._buffer = null;\r\n }\r\n }\r\n };\r\n /**\r\n * Get the world extend vectors with an optional filter\r\n *\r\n * @param filterPredicate the predicate - which meshes should be included when calculating the world size\r\n * @returns {{ min: Vector3; max: Vector3 }} min and max vectors\r\n */\r\n Scene.prototype.getWorldExtends = function (filterPredicate) {\r\n var min = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n var max = new Vector3(-Number.MAX_VALUE, -Number.MAX_VALUE, -Number.MAX_VALUE);\r\n filterPredicate = filterPredicate || (function () { return true; });\r\n this.meshes.filter(filterPredicate).forEach(function (mesh) {\r\n mesh.computeWorldMatrix(true);\r\n if (!mesh.subMeshes || mesh.subMeshes.length === 0 || mesh.infiniteDistance) {\r\n return;\r\n }\r\n var boundingInfo = mesh.getBoundingInfo();\r\n var minBox = boundingInfo.boundingBox.minimumWorld;\r\n var maxBox = boundingInfo.boundingBox.maximumWorld;\r\n Vector3.CheckExtends(minBox, min, max);\r\n Vector3.CheckExtends(maxBox, min, max);\r\n });\r\n return {\r\n min: min,\r\n max: max\r\n };\r\n };\r\n // Picking\r\n /**\r\n * Creates a ray that can be used to pick in the scene\r\n * @param x defines the x coordinate of the origin (on-screen)\r\n * @param y defines the y coordinate of the origin (on-screen)\r\n * @param world defines the world matrix to use if you want to pick in object space (instead of world space)\r\n * @param camera defines the camera to use for the picking\r\n * @param cameraViewSpace defines if picking will be done in view space (false by default)\r\n * @returns a Ray\r\n */\r\n Scene.prototype.createPickingRay = function (x, y, world, camera, cameraViewSpace) {\r\n if (cameraViewSpace === void 0) { cameraViewSpace = false; }\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /**\r\n * Creates a ray that can be used to pick in the scene\r\n * @param x defines the x coordinate of the origin (on-screen)\r\n * @param y defines the y coordinate of the origin (on-screen)\r\n * @param world defines the world matrix to use if you want to pick in object space (instead of world space)\r\n * @param result defines the ray where to store the picking ray\r\n * @param camera defines the camera to use for the picking\r\n * @param cameraViewSpace defines if picking will be done in view space (false by default)\r\n * @returns the current scene\r\n */\r\n Scene.prototype.createPickingRayToRef = function (x, y, world, result, camera, cameraViewSpace) {\r\n if (cameraViewSpace === void 0) { cameraViewSpace = false; }\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /**\r\n * Creates a ray that can be used to pick in the scene\r\n * @param x defines the x coordinate of the origin (on-screen)\r\n * @param y defines the y coordinate of the origin (on-screen)\r\n * @param camera defines the camera to use for the picking\r\n * @returns a Ray\r\n */\r\n Scene.prototype.createPickingRayInCameraSpace = function (x, y, camera) {\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /**\r\n * Creates a ray that can be used to pick in the scene\r\n * @param x defines the x coordinate of the origin (on-screen)\r\n * @param y defines the y coordinate of the origin (on-screen)\r\n * @param result defines the ray where to store the picking ray\r\n * @param camera defines the camera to use for the picking\r\n * @returns the current scene\r\n */\r\n Scene.prototype.createPickingRayInCameraSpaceToRef = function (x, y, result, camera) {\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /** Launch a ray to try to pick a mesh in the scene\r\n * @param x position on screen\r\n * @param y position on screen\r\n * @param predicate Predicate function used to determine eligible meshes. Can be set to null. In this case, a mesh must be enabled, visible and with isPickable set to true\r\n * @param fastCheck defines if the first intersection will be used (and not the closest)\r\n * @param camera to use for computing the picking ray. Can be set to null. In this case, the scene.activeCamera will be used\r\n * @param trianglePredicate defines an optional predicate used to select faces when a mesh intersection is detected\r\n * @returns a PickingInfo\r\n */\r\n Scene.prototype.pick = function (x, y, predicate, fastCheck, camera, trianglePredicate) {\r\n // Dummy info if picking as not been imported\r\n var pi = new PickingInfo();\r\n pi._pickingUnavailable = true;\r\n return pi;\r\n };\r\n /** Launch a ray to try to pick a mesh in the scene using only bounding information of the main mesh (not using submeshes)\r\n * @param x position on screen\r\n * @param y position on screen\r\n * @param predicate Predicate function used to determine eligible meshes. Can be set to null. In this case, a mesh must be enabled, visible and with isPickable set to true\r\n * @param fastCheck defines if the first intersection will be used (and not the closest)\r\n * @param camera to use for computing the picking ray. Can be set to null. In this case, the scene.activeCamera will be used\r\n * @returns a PickingInfo (Please note that some info will not be set like distance, bv, bu and everything that cannot be capture by only using bounding infos)\r\n */\r\n Scene.prototype.pickWithBoundingInfo = function (x, y, predicate, fastCheck, camera) {\r\n // Dummy info if picking as not been imported\r\n var pi = new PickingInfo();\r\n pi._pickingUnavailable = true;\r\n return pi;\r\n };\r\n /** Use the given ray to pick a mesh in the scene\r\n * @param ray The ray to use to pick meshes\r\n * @param predicate Predicate function used to determine eligible meshes. Can be set to null. In this case, a mesh must have isPickable set to true\r\n * @param fastCheck defines if the first intersection will be used (and not the closest)\r\n * @param trianglePredicate defines an optional predicate used to select faces when a mesh intersection is detected\r\n * @returns a PickingInfo\r\n */\r\n Scene.prototype.pickWithRay = function (ray, predicate, fastCheck, trianglePredicate) {\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /**\r\n * Launch a ray to try to pick a mesh in the scene\r\n * @param x X position on screen\r\n * @param y Y position on screen\r\n * @param predicate Predicate function used to determine eligible meshes. Can be set to null. In this case, a mesh must be enabled, visible and with isPickable set to true\r\n * @param camera camera to use for computing the picking ray. Can be set to null. In this case, the scene.activeCamera will be used\r\n * @param trianglePredicate defines an optional predicate used to select faces when a mesh intersection is detected\r\n * @returns an array of PickingInfo\r\n */\r\n Scene.prototype.multiPick = function (x, y, predicate, camera, trianglePredicate) {\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /**\r\n * Launch a ray to try to pick a mesh in the scene\r\n * @param ray Ray to use\r\n * @param predicate Predicate function used to determine eligible meshes. Can be set to null. In this case, a mesh must be enabled, visible and with isPickable set to true\r\n * @param trianglePredicate defines an optional predicate used to select faces when a mesh intersection is detected\r\n * @returns an array of PickingInfo\r\n */\r\n Scene.prototype.multiPickWithRay = function (ray, predicate, trianglePredicate) {\r\n throw _DevTools.WarnImport(\"Ray\");\r\n };\r\n /**\r\n * Force the value of meshUnderPointer\r\n * @param mesh defines the mesh to use\r\n * @param pointerId optional pointer id when using more than one pointer\r\n */\r\n Scene.prototype.setPointerOverMesh = function (mesh, pointerId) {\r\n this._inputManager.setPointerOverMesh(mesh, pointerId);\r\n };\r\n /**\r\n * Gets the mesh under the pointer\r\n * @returns a Mesh or null if no mesh is under the pointer\r\n */\r\n Scene.prototype.getPointerOverMesh = function () {\r\n return this._inputManager.getPointerOverMesh();\r\n };\r\n // Misc.\r\n /** @hidden */\r\n Scene.prototype._rebuildGeometries = function () {\r\n for (var _i = 0, _a = this.geometries; _i < _a.length; _i++) {\r\n var geometry = _a[_i];\r\n geometry._rebuild();\r\n }\r\n for (var _b = 0, _c = this.meshes; _b < _c.length; _b++) {\r\n var mesh = _c[_b];\r\n mesh._rebuild();\r\n }\r\n if (this.postProcessManager) {\r\n this.postProcessManager._rebuild();\r\n }\r\n for (var _d = 0, _e = this._components; _d < _e.length; _d++) {\r\n var component = _e[_d];\r\n component.rebuild();\r\n }\r\n for (var _f = 0, _g = this.particleSystems; _f < _g.length; _f++) {\r\n var system = _g[_f];\r\n system.rebuild();\r\n }\r\n };\r\n /** @hidden */\r\n Scene.prototype._rebuildTextures = function () {\r\n for (var _i = 0, _a = this.textures; _i < _a.length; _i++) {\r\n var texture = _a[_i];\r\n texture._rebuild();\r\n }\r\n this.markAllMaterialsAsDirty(1);\r\n };\r\n // Tags\r\n Scene.prototype._getByTags = function (list, tagsQuery, forEach) {\r\n if (tagsQuery === undefined) {\r\n // returns the complete list (could be done with Tags.MatchesQuery but no need to have a for-loop here)\r\n return list;\r\n }\r\n var listByTags = [];\r\n forEach = forEach || (function (item) { return; });\r\n for (var i in list) {\r\n var item = list[i];\r\n if (Tags && Tags.MatchesQuery(item, tagsQuery)) {\r\n listByTags.push(item);\r\n forEach(item);\r\n }\r\n }\r\n return listByTags;\r\n };\r\n /**\r\n * Get a list of meshes by tags\r\n * @param tagsQuery defines the tags query to use\r\n * @param forEach defines a predicate used to filter results\r\n * @returns an array of Mesh\r\n */\r\n Scene.prototype.getMeshesByTags = function (tagsQuery, forEach) {\r\n return this._getByTags(this.meshes, tagsQuery, forEach);\r\n };\r\n /**\r\n * Get a list of cameras by tags\r\n * @param tagsQuery defines the tags query to use\r\n * @param forEach defines a predicate used to filter results\r\n * @returns an array of Camera\r\n */\r\n Scene.prototype.getCamerasByTags = function (tagsQuery, forEach) {\r\n return this._getByTags(this.cameras, tagsQuery, forEach);\r\n };\r\n /**\r\n * Get a list of lights by tags\r\n * @param tagsQuery defines the tags query to use\r\n * @param forEach defines a predicate used to filter results\r\n * @returns an array of Light\r\n */\r\n Scene.prototype.getLightsByTags = function (tagsQuery, forEach) {\r\n return this._getByTags(this.lights, tagsQuery, forEach);\r\n };\r\n /**\r\n * Get a list of materials by tags\r\n * @param tagsQuery defines the tags query to use\r\n * @param forEach defines a predicate used to filter results\r\n * @returns an array of Material\r\n */\r\n Scene.prototype.getMaterialByTags = function (tagsQuery, forEach) {\r\n return this._getByTags(this.materials, tagsQuery, forEach).concat(this._getByTags(this.multiMaterials, tagsQuery, forEach));\r\n };\r\n /**\r\n * Get a list of transform nodes by tags\r\n * @param tagsQuery defines the tags query to use\r\n * @param forEach defines a predicate used to filter results\r\n * @returns an array of TransformNode\r\n */\r\n Scene.prototype.getTransformNodesByTags = function (tagsQuery, forEach) {\r\n return this._getByTags(this.transformNodes, tagsQuery, forEach);\r\n };\r\n /**\r\n * Overrides the default sort function applied in the renderging group to prepare the meshes.\r\n * This allowed control for front to back rendering or reversly depending of the special needs.\r\n *\r\n * @param renderingGroupId The rendering group id corresponding to its index\r\n * @param opaqueSortCompareFn The opaque queue comparison function use to sort.\r\n * @param alphaTestSortCompareFn The alpha test queue comparison function use to sort.\r\n * @param transparentSortCompareFn The transparent queue comparison function use to sort.\r\n */\r\n Scene.prototype.setRenderingOrder = function (renderingGroupId, opaqueSortCompareFn, alphaTestSortCompareFn, transparentSortCompareFn) {\r\n if (opaqueSortCompareFn === void 0) { opaqueSortCompareFn = null; }\r\n if (alphaTestSortCompareFn === void 0) { alphaTestSortCompareFn = null; }\r\n if (transparentSortCompareFn === void 0) { transparentSortCompareFn = null; }\r\n this._renderingManager.setRenderingOrder(renderingGroupId, opaqueSortCompareFn, alphaTestSortCompareFn, transparentSortCompareFn);\r\n };\r\n /**\r\n * Specifies whether or not the stencil and depth buffer are cleared between two rendering groups.\r\n *\r\n * @param renderingGroupId The rendering group id corresponding to its index\r\n * @param autoClearDepthStencil Automatically clears depth and stencil between groups if true.\r\n * @param depth Automatically clears depth between groups if true and autoClear is true.\r\n * @param stencil Automatically clears stencil between groups if true and autoClear is true.\r\n */\r\n Scene.prototype.setRenderingAutoClearDepthStencil = function (renderingGroupId, autoClearDepthStencil, depth, stencil) {\r\n if (depth === void 0) { depth = true; }\r\n if (stencil === void 0) { stencil = true; }\r\n this._renderingManager.setRenderingAutoClearDepthStencil(renderingGroupId, autoClearDepthStencil, depth, stencil);\r\n };\r\n /**\r\n * Gets the current auto clear configuration for one rendering group of the rendering\r\n * manager.\r\n * @param index the rendering group index to get the information for\r\n * @returns The auto clear setup for the requested rendering group\r\n */\r\n Scene.prototype.getAutoClearDepthStencilSetup = function (index) {\r\n return this._renderingManager.getAutoClearDepthStencilSetup(index);\r\n };\r\n Object.defineProperty(Scene.prototype, \"blockMaterialDirtyMechanism\", {\r\n /** Gets or sets a boolean blocking all the calls to markAllMaterialsAsDirty (ie. the materials won't be updated if they are out of sync) */\r\n get: function () {\r\n return this._blockMaterialDirtyMechanism;\r\n },\r\n set: function (value) {\r\n if (this._blockMaterialDirtyMechanism === value) {\r\n return;\r\n }\r\n this._blockMaterialDirtyMechanism = value;\r\n if (!value) { // Do a complete update\r\n this.markAllMaterialsAsDirty(63);\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Will flag all materials as dirty to trigger new shader compilation\r\n * @param flag defines the flag used to specify which material part must be marked as dirty\r\n * @param predicate If not null, it will be used to specifiy if a material has to be marked as dirty\r\n */\r\n Scene.prototype.markAllMaterialsAsDirty = function (flag, predicate) {\r\n if (this._blockMaterialDirtyMechanism) {\r\n return;\r\n }\r\n for (var _i = 0, _a = this.materials; _i < _a.length; _i++) {\r\n var material = _a[_i];\r\n if (predicate && !predicate(material)) {\r\n continue;\r\n }\r\n material.markAsDirty(flag);\r\n }\r\n };\r\n /** @hidden */\r\n Scene.prototype._loadFile = function (url, onSuccess, onProgress, useOfflineSupport, useArrayBuffer, onError) {\r\n var _this = this;\r\n var request = FileTools.LoadFile(url, onSuccess, onProgress, useOfflineSupport ? this.offlineProvider : undefined, useArrayBuffer, onError);\r\n this._activeRequests.push(request);\r\n request.onCompleteObservable.add(function (request) {\r\n _this._activeRequests.splice(_this._activeRequests.indexOf(request), 1);\r\n });\r\n return request;\r\n };\r\n /** @hidden */\r\n Scene.prototype._loadFileAsync = function (url, onProgress, useOfflineSupport, useArrayBuffer) {\r\n var _this = this;\r\n return new Promise(function (resolve, reject) {\r\n _this._loadFile(url, function (data) {\r\n resolve(data);\r\n }, onProgress, useOfflineSupport, useArrayBuffer, function (request, exception) {\r\n reject(exception);\r\n });\r\n });\r\n };\r\n /** @hidden */\r\n Scene.prototype._requestFile = function (url, onSuccess, onProgress, useOfflineSupport, useArrayBuffer, onError, onOpened) {\r\n var _this = this;\r\n var request = FileTools.RequestFile(url, onSuccess, onProgress, useOfflineSupport ? this.offlineProvider : undefined, useArrayBuffer, onError, onOpened);\r\n this._activeRequests.push(request);\r\n request.onCompleteObservable.add(function (request) {\r\n _this._activeRequests.splice(_this._activeRequests.indexOf(request), 1);\r\n });\r\n return request;\r\n };\r\n /** @hidden */\r\n Scene.prototype._requestFileAsync = function (url, onProgress, useOfflineSupport, useArrayBuffer, onOpened) {\r\n var _this = this;\r\n return new Promise(function (resolve, reject) {\r\n _this._requestFile(url, function (data) {\r\n resolve(data);\r\n }, onProgress, useOfflineSupport, useArrayBuffer, function (error) {\r\n reject(error);\r\n }, onOpened);\r\n });\r\n };\r\n /** @hidden */\r\n Scene.prototype._readFile = function (file, onSuccess, onProgress, useArrayBuffer, onError) {\r\n var _this = this;\r\n var request = FileTools.ReadFile(file, onSuccess, onProgress, useArrayBuffer, onError);\r\n this._activeRequests.push(request);\r\n request.onCompleteObservable.add(function (request) {\r\n _this._activeRequests.splice(_this._activeRequests.indexOf(request), 1);\r\n });\r\n return request;\r\n };\r\n /** @hidden */\r\n Scene.prototype._readFileAsync = function (file, onProgress, useArrayBuffer) {\r\n var _this = this;\r\n return new Promise(function (resolve, reject) {\r\n _this._readFile(file, function (data) {\r\n resolve(data);\r\n }, onProgress, useArrayBuffer, function (error) {\r\n reject(error);\r\n });\r\n });\r\n };\r\n /** The fog is deactivated */\r\n Scene.FOGMODE_NONE = 0;\r\n /** The fog density is following an exponential function */\r\n Scene.FOGMODE_EXP = 1;\r\n /** The fog density is following an exponential function faster than FOGMODE_EXP */\r\n Scene.FOGMODE_EXP2 = 2;\r\n /** The fog density is following a linear function. */\r\n Scene.FOGMODE_LINEAR = 3;\r\n /**\r\n * Gets or sets the minimum deltatime when deterministic lock step is enabled\r\n * @see https://doc.babylonjs.com/babylon101/animations#deterministic-lockstep\r\n */\r\n Scene.MinDeltaTime = 1.0;\r\n /**\r\n * Gets or sets the maximum deltatime when deterministic lock step is enabled\r\n * @see https://doc.babylonjs.com/babylon101/animations#deterministic-lockstep\r\n */\r\n Scene.MaxDeltaTime = 1000.0;\r\n return Scene;\r\n}(AbstractScene));\r\nexport { Scene };\r\n//# sourceMappingURL=scene.js.map","import { __extends } from \"tslib\";\r\n/**\r\n * Defines an GC Friendly array where the backfield array do not shrink to prevent over allocations.\r\n */\r\nvar SmartArray = /** @class */ (function () {\r\n /**\r\n * Instantiates a Smart Array.\r\n * @param capacity defines the default capacity of the array.\r\n */\r\n function SmartArray(capacity) {\r\n /**\r\n * The active length of the array.\r\n */\r\n this.length = 0;\r\n this.data = new Array(capacity);\r\n this._id = SmartArray._GlobalId++;\r\n }\r\n /**\r\n * Pushes a value at the end of the active data.\r\n * @param value defines the object to push in the array.\r\n */\r\n SmartArray.prototype.push = function (value) {\r\n this.data[this.length++] = value;\r\n if (this.length > this.data.length) {\r\n this.data.length *= 2;\r\n }\r\n };\r\n /**\r\n * Iterates over the active data and apply the lambda to them.\r\n * @param func defines the action to apply on each value.\r\n */\r\n SmartArray.prototype.forEach = function (func) {\r\n for (var index = 0; index < this.length; index++) {\r\n func(this.data[index]);\r\n }\r\n };\r\n /**\r\n * Sorts the full sets of data.\r\n * @param compareFn defines the comparison function to apply.\r\n */\r\n SmartArray.prototype.sort = function (compareFn) {\r\n this.data.sort(compareFn);\r\n };\r\n /**\r\n * Resets the active data to an empty array.\r\n */\r\n SmartArray.prototype.reset = function () {\r\n this.length = 0;\r\n };\r\n /**\r\n * Releases all the data from the array as well as the array.\r\n */\r\n SmartArray.prototype.dispose = function () {\r\n this.reset();\r\n if (this.data) {\r\n this.data.length = 0;\r\n this.data = [];\r\n }\r\n };\r\n /**\r\n * Concats the active data with a given array.\r\n * @param array defines the data to concatenate with.\r\n */\r\n SmartArray.prototype.concat = function (array) {\r\n if (array.length === 0) {\r\n return;\r\n }\r\n if (this.length + array.length > this.data.length) {\r\n this.data.length = (this.length + array.length) * 2;\r\n }\r\n for (var index = 0; index < array.length; index++) {\r\n this.data[this.length++] = (array.data || array)[index];\r\n }\r\n };\r\n /**\r\n * Returns the position of a value in the active data.\r\n * @param value defines the value to find the index for\r\n * @returns the index if found in the active data otherwise -1\r\n */\r\n SmartArray.prototype.indexOf = function (value) {\r\n var position = this.data.indexOf(value);\r\n if (position >= this.length) {\r\n return -1;\r\n }\r\n return position;\r\n };\r\n /**\r\n * Returns whether an element is part of the active data.\r\n * @param value defines the value to look for\r\n * @returns true if found in the active data otherwise false\r\n */\r\n SmartArray.prototype.contains = function (value) {\r\n return this.indexOf(value) !== -1;\r\n };\r\n // Statics\r\n SmartArray._GlobalId = 0;\r\n return SmartArray;\r\n}());\r\nexport { SmartArray };\r\n/**\r\n * Defines an GC Friendly array where the backfield array do not shrink to prevent over allocations.\r\n * The data in this array can only be present once\r\n */\r\nvar SmartArrayNoDuplicate = /** @class */ (function (_super) {\r\n __extends(SmartArrayNoDuplicate, _super);\r\n function SmartArrayNoDuplicate() {\r\n var _this = _super !== null && _super.apply(this, arguments) || this;\r\n _this._duplicateId = 0;\r\n return _this;\r\n }\r\n /**\r\n * Pushes a value at the end of the active data.\r\n * THIS DOES NOT PREVENT DUPPLICATE DATA\r\n * @param value defines the object to push in the array.\r\n */\r\n SmartArrayNoDuplicate.prototype.push = function (value) {\r\n _super.prototype.push.call(this, value);\r\n if (!value.__smartArrayFlags) {\r\n value.__smartArrayFlags = {};\r\n }\r\n value.__smartArrayFlags[this._id] = this._duplicateId;\r\n };\r\n /**\r\n * Pushes a value at the end of the active data.\r\n * If the data is already present, it won t be added again\r\n * @param value defines the object to push in the array.\r\n * @returns true if added false if it was already present\r\n */\r\n SmartArrayNoDuplicate.prototype.pushNoDuplicate = function (value) {\r\n if (value.__smartArrayFlags && value.__smartArrayFlags[this._id] === this._duplicateId) {\r\n return false;\r\n }\r\n this.push(value);\r\n return true;\r\n };\r\n /**\r\n * Resets the active data to an empty array.\r\n */\r\n SmartArrayNoDuplicate.prototype.reset = function () {\r\n _super.prototype.reset.call(this);\r\n this._duplicateId++;\r\n };\r\n /**\r\n * Concats the active data with a given array.\r\n * This ensures no dupplicate will be present in the result.\r\n * @param array defines the data to concatenate with.\r\n */\r\n SmartArrayNoDuplicate.prototype.concatWithNoDuplicate = function (array) {\r\n if (array.length === 0) {\r\n return;\r\n }\r\n if (this.length + array.length > this.data.length) {\r\n this.data.length = (this.length + array.length) * 2;\r\n }\r\n for (var index = 0; index < array.length; index++) {\r\n var item = (array.data || array)[index];\r\n this.pushNoDuplicate(item);\r\n }\r\n };\r\n return SmartArrayNoDuplicate;\r\n}(SmartArray));\r\nexport { SmartArrayNoDuplicate };\r\n//# sourceMappingURL=smartArray.js.map","import { Vector2 } from \"@babylonjs/core/Maths/math.vector\";\r\nvar tmpRect = [\r\n new Vector2(0, 0),\r\n new Vector2(0, 0),\r\n new Vector2(0, 0),\r\n new Vector2(0, 0),\r\n];\r\nvar tmpRect2 = [\r\n new Vector2(0, 0),\r\n new Vector2(0, 0),\r\n new Vector2(0, 0),\r\n new Vector2(0, 0),\r\n];\r\nvar tmpV1 = new Vector2(0, 0);\r\nvar tmpV2 = new Vector2(0, 0);\r\n/**\r\n * Class used to store 2D control sizes\r\n */\r\nvar Measure = /** @class */ (function () {\r\n /**\r\n * Creates a new measure\r\n * @param left defines left coordinate\r\n * @param top defines top coordinate\r\n * @param width defines width dimension\r\n * @param height defines height dimension\r\n */\r\n function Measure(\r\n /** defines left coordinate */\r\n left, \r\n /** defines top coordinate */\r\n top, \r\n /** defines width dimension */\r\n width, \r\n /** defines height dimension */\r\n height) {\r\n this.left = left;\r\n this.top = top;\r\n this.width = width;\r\n this.height = height;\r\n }\r\n /**\r\n * Copy from another measure\r\n * @param other defines the other measure to copy from\r\n */\r\n Measure.prototype.copyFrom = function (other) {\r\n this.left = other.left;\r\n this.top = other.top;\r\n this.width = other.width;\r\n this.height = other.height;\r\n };\r\n /**\r\n * Copy from a group of 4 floats\r\n * @param left defines left coordinate\r\n * @param top defines top coordinate\r\n * @param width defines width dimension\r\n * @param height defines height dimension\r\n */\r\n Measure.prototype.copyFromFloats = function (left, top, width, height) {\r\n this.left = left;\r\n this.top = top;\r\n this.width = width;\r\n this.height = height;\r\n };\r\n /**\r\n * Computes the axis aligned bounding box measure for two given measures\r\n * @param a Input measure\r\n * @param b Input measure\r\n * @param result the resulting bounding measure\r\n */\r\n Measure.CombineToRef = function (a, b, result) {\r\n var left = Math.min(a.left, b.left);\r\n var top = Math.min(a.top, b.top);\r\n var right = Math.max(a.left + a.width, b.left + b.width);\r\n var bottom = Math.max(a.top + a.height, b.top + b.height);\r\n result.left = left;\r\n result.top = top;\r\n result.width = right - left;\r\n result.height = bottom - top;\r\n };\r\n /**\r\n * Computes the axis aligned bounding box of the measure after it is modified by a given transform\r\n * @param transform the matrix to transform the measure before computing the AABB\r\n * @param addX number to add to left\r\n * @param addY number to add to top\r\n * @param addWidth number to add to width\r\n * @param addHeight number to add to height\r\n * @param result the resulting AABB\r\n */\r\n Measure.prototype.addAndTransformToRef = function (transform, addX, addY, addWidth, addHeight, result) {\r\n var left = this.left + addX;\r\n var top = this.top + addY;\r\n var width = this.width + addWidth;\r\n var height = this.height + addHeight;\r\n tmpRect[0].copyFromFloats(left, top);\r\n tmpRect[1].copyFromFloats(left + width, top);\r\n tmpRect[2].copyFromFloats(left + width, top + height);\r\n tmpRect[3].copyFromFloats(left, top + height);\r\n tmpV1.copyFromFloats(Number.MAX_VALUE, Number.MAX_VALUE);\r\n tmpV2.copyFromFloats(0, 0);\r\n for (var i = 0; i < 4; i++) {\r\n transform.transformCoordinates(tmpRect[i].x, tmpRect[i].y, tmpRect2[i]);\r\n tmpV1.x = Math.floor(Math.min(tmpV1.x, tmpRect2[i].x));\r\n tmpV1.y = Math.floor(Math.min(tmpV1.y, tmpRect2[i].y));\r\n tmpV2.x = Math.ceil(Math.max(tmpV2.x, tmpRect2[i].x));\r\n tmpV2.y = Math.ceil(Math.max(tmpV2.y, tmpRect2[i].y));\r\n }\r\n result.left = tmpV1.x;\r\n result.top = tmpV1.y;\r\n result.width = tmpV2.x - tmpV1.x;\r\n result.height = tmpV2.y - tmpV1.y;\r\n };\r\n /**\r\n * Computes the axis aligned bounding box of the measure after it is modified by a given transform\r\n * @param transform the matrix to transform the measure before computing the AABB\r\n * @param result the resulting AABB\r\n */\r\n Measure.prototype.transformToRef = function (transform, result) {\r\n this.addAndTransformToRef(transform, 0, 0, 0, 0, result);\r\n };\r\n /**\r\n * Check equality between this measure and another one\r\n * @param other defines the other measures\r\n * @returns true if both measures are equals\r\n */\r\n Measure.prototype.isEqualsTo = function (other) {\r\n if (this.left !== other.left) {\r\n return false;\r\n }\r\n if (this.top !== other.top) {\r\n return false;\r\n }\r\n if (this.width !== other.width) {\r\n return false;\r\n }\r\n if (this.height !== other.height) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n /**\r\n * Creates an empty measure\r\n * @returns a new measure\r\n */\r\n Measure.Empty = function () {\r\n return new Measure(0, 0, 0, 0);\r\n };\r\n return Measure;\r\n}());\r\nexport { Measure };\r\n//# sourceMappingURL=measure.js.map","/**\r\n * Class containing a set of static utilities functions for arrays.\r\n */\r\nvar ArrayTools = /** @class */ (function () {\r\n function ArrayTools() {\r\n }\r\n /**\r\n * Returns an array of the given size filled with element built from the given constructor and the paramters\r\n * @param size the number of element to construct and put in the array\r\n * @param itemBuilder a callback responsible for creating new instance of item. Called once per array entry.\r\n * @returns a new array filled with new objects\r\n */\r\n ArrayTools.BuildArray = function (size, itemBuilder) {\r\n var a = [];\r\n for (var i = 0; i < size; ++i) {\r\n a.push(itemBuilder());\r\n }\r\n return a;\r\n };\r\n return ArrayTools;\r\n}());\r\nexport { ArrayTools };\r\n//# sourceMappingURL=arrayTools.js.map","import { __extends } from \"tslib\";\r\nimport { Logger } from \"@babylonjs/core/Misc/logger\";\r\nimport { Control } from \"./control\";\r\nimport { Measure } from \"../measure\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Root class for 2D containers\r\n * @see https://doc.babylonjs.com/how_to/gui#containers\r\n */\r\nvar Container = /** @class */ (function (_super) {\r\n __extends(Container, _super);\r\n /**\r\n * Creates a new Container\r\n * @param name defines the name of the container\r\n */\r\n function Container(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n /** @hidden */\r\n _this._children = new Array();\r\n /** @hidden */\r\n _this._measureForChildren = Measure.Empty();\r\n /** @hidden */\r\n _this._background = \"\";\r\n /** @hidden */\r\n _this._adaptWidthToChildren = false;\r\n /** @hidden */\r\n _this._adaptHeightToChildren = false;\r\n /**\r\n * Gets or sets a boolean indicating that layout cycle errors should be displayed on the console\r\n */\r\n _this.logLayoutCycleErrors = false;\r\n /**\r\n * Gets or sets the number of layout cycles (a change involved by a control while evaluating the layout) allowed\r\n */\r\n _this.maxLayoutCycle = 3;\r\n return _this;\r\n }\r\n Object.defineProperty(Container.prototype, \"adaptHeightToChildren\", {\r\n /** Gets or sets a boolean indicating if the container should try to adapt to its children height */\r\n get: function () {\r\n return this._adaptHeightToChildren;\r\n },\r\n set: function (value) {\r\n if (this._adaptHeightToChildren === value) {\r\n return;\r\n }\r\n this._adaptHeightToChildren = value;\r\n if (value) {\r\n this.height = \"100%\";\r\n }\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Container.prototype, \"adaptWidthToChildren\", {\r\n /** Gets or sets a boolean indicating if the container should try to adapt to its children width */\r\n get: function () {\r\n return this._adaptWidthToChildren;\r\n },\r\n set: function (value) {\r\n if (this._adaptWidthToChildren === value) {\r\n return;\r\n }\r\n this._adaptWidthToChildren = value;\r\n if (value) {\r\n this.width = \"100%\";\r\n }\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Container.prototype, \"background\", {\r\n /** Gets or sets background color */\r\n get: function () {\r\n return this._background;\r\n },\r\n set: function (value) {\r\n if (this._background === value) {\r\n return;\r\n }\r\n this._background = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Container.prototype, \"children\", {\r\n /** Gets the list of children */\r\n get: function () {\r\n return this._children;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Container.prototype._getTypeName = function () {\r\n return \"Container\";\r\n };\r\n Container.prototype._flagDescendantsAsMatrixDirty = function () {\r\n for (var _i = 0, _a = this.children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child._markMatrixAsDirty();\r\n }\r\n };\r\n /**\r\n * Gets a child using its name\r\n * @param name defines the child name to look for\r\n * @returns the child control if found\r\n */\r\n Container.prototype.getChildByName = function (name) {\r\n for (var _i = 0, _a = this.children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (child.name === name) {\r\n return child;\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Gets a child using its type and its name\r\n * @param name defines the child name to look for\r\n * @param type defines the child type to look for\r\n * @returns the child control if found\r\n */\r\n Container.prototype.getChildByType = function (name, type) {\r\n for (var _i = 0, _a = this.children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (child.typeName === type) {\r\n return child;\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Search for a specific control in children\r\n * @param control defines the control to look for\r\n * @returns true if the control is in child list\r\n */\r\n Container.prototype.containsControl = function (control) {\r\n return this.children.indexOf(control) !== -1;\r\n };\r\n /**\r\n * Adds a new control to the current container\r\n * @param control defines the control to add\r\n * @returns the current container\r\n */\r\n Container.prototype.addControl = function (control) {\r\n if (!control) {\r\n return this;\r\n }\r\n var index = this._children.indexOf(control);\r\n if (index !== -1) {\r\n return this;\r\n }\r\n control._link(this._host);\r\n control._markAllAsDirty();\r\n this._reOrderControl(control);\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /**\r\n * Removes all controls from the current container\r\n * @returns the current container\r\n */\r\n Container.prototype.clearControls = function () {\r\n var children = this.children.slice();\r\n for (var _i = 0, children_1 = children; _i < children_1.length; _i++) {\r\n var child = children_1[_i];\r\n this.removeControl(child);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Removes a control from the current container\r\n * @param control defines the control to remove\r\n * @returns the current container\r\n */\r\n Container.prototype.removeControl = function (control) {\r\n var index = this._children.indexOf(control);\r\n if (index !== -1) {\r\n this._children.splice(index, 1);\r\n control.parent = null;\r\n }\r\n control.linkWithMesh(null);\r\n if (this._host) {\r\n this._host._cleanControlAfterRemoval(control);\r\n }\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /** @hidden */\r\n Container.prototype._reOrderControl = function (control) {\r\n this.removeControl(control);\r\n var wasAdded = false;\r\n for (var index = 0; index < this._children.length; index++) {\r\n if (this._children[index].zIndex > control.zIndex) {\r\n this._children.splice(index, 0, control);\r\n wasAdded = true;\r\n break;\r\n }\r\n }\r\n if (!wasAdded) {\r\n this._children.push(control);\r\n }\r\n control.parent = this;\r\n this._markAsDirty();\r\n };\r\n /** @hidden */\r\n Container.prototype._offsetLeft = function (offset) {\r\n _super.prototype._offsetLeft.call(this, offset);\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child._offsetLeft(offset);\r\n }\r\n };\r\n /** @hidden */\r\n Container.prototype._offsetTop = function (offset) {\r\n _super.prototype._offsetTop.call(this, offset);\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child._offsetTop(offset);\r\n }\r\n };\r\n /** @hidden */\r\n Container.prototype._markAllAsDirty = function () {\r\n _super.prototype._markAllAsDirty.call(this);\r\n for (var index = 0; index < this._children.length; index++) {\r\n this._children[index]._markAllAsDirty();\r\n }\r\n };\r\n /** @hidden */\r\n Container.prototype._localDraw = function (context) {\r\n if (this._background) {\r\n context.save();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n context.fillStyle = this._background;\r\n context.fillRect(this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n context.restore();\r\n }\r\n };\r\n /** @hidden */\r\n Container.prototype._link = function (host) {\r\n _super.prototype._link.call(this, host);\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child._link(host);\r\n }\r\n };\r\n /** @hidden */\r\n Container.prototype._beforeLayout = function () {\r\n // Do nothing\r\n };\r\n /** @hidden */\r\n Container.prototype._processMeasures = function (parentMeasure, context) {\r\n if (this._isDirty || !this._cachedParentMeasure.isEqualsTo(parentMeasure)) {\r\n _super.prototype._processMeasures.call(this, parentMeasure, context);\r\n this._evaluateClippingState(parentMeasure);\r\n }\r\n };\r\n /** @hidden */\r\n Container.prototype._layout = function (parentMeasure, context) {\r\n if (!this.isDirty && (!this.isVisible || this.notRenderable)) {\r\n return false;\r\n }\r\n this.host._numLayoutCalls++;\r\n if (this._isDirty) {\r\n this._currentMeasure.transformToRef(this._transformMatrix, this._prevCurrentMeasureTransformedIntoGlobalSpace);\r\n }\r\n var rebuildCount = 0;\r\n context.save();\r\n this._applyStates(context);\r\n this._beforeLayout();\r\n do {\r\n var computedWidth = -1;\r\n var computedHeight = -1;\r\n this._rebuildLayout = false;\r\n this._processMeasures(parentMeasure, context);\r\n if (!this._isClipped) {\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child._tempParentMeasure.copyFrom(this._measureForChildren);\r\n if (child._layout(this._measureForChildren, context)) {\r\n if (this.adaptWidthToChildren && child._width.isPixel) {\r\n computedWidth = Math.max(computedWidth, child._currentMeasure.width + child.paddingLeftInPixels + child.paddingRightInPixels);\r\n }\r\n if (this.adaptHeightToChildren && child._height.isPixel) {\r\n computedHeight = Math.max(computedHeight, child._currentMeasure.height + child.paddingTopInPixels + child.paddingBottomInPixels);\r\n }\r\n }\r\n }\r\n if (this.adaptWidthToChildren && computedWidth >= 0) {\r\n computedWidth += this.paddingLeftInPixels + this.paddingRightInPixels;\r\n if (this.width !== computedWidth + \"px\") {\r\n this.width = computedWidth + \"px\";\r\n this._rebuildLayout = true;\r\n }\r\n }\r\n if (this.adaptHeightToChildren && computedHeight >= 0) {\r\n computedHeight += this.paddingTopInPixels + this.paddingBottomInPixels;\r\n if (this.height !== computedHeight + \"px\") {\r\n this.height = computedHeight + \"px\";\r\n this._rebuildLayout = true;\r\n }\r\n }\r\n this._postMeasure();\r\n }\r\n rebuildCount++;\r\n } while (this._rebuildLayout && rebuildCount < this.maxLayoutCycle);\r\n if (rebuildCount >= 3 && this.logLayoutCycleErrors) {\r\n Logger.Error(\"Layout cycle detected in GUI (Container name=\" + this.name + \", uniqueId=\" + this.uniqueId + \")\");\r\n }\r\n context.restore();\r\n if (this._isDirty) {\r\n this.invalidateRect();\r\n this._isDirty = false;\r\n }\r\n return true;\r\n };\r\n Container.prototype._postMeasure = function () {\r\n // Do nothing by default\r\n };\r\n /** @hidden */\r\n Container.prototype._draw = function (context, invalidatedRectangle) {\r\n this._localDraw(context);\r\n if (this.clipChildren) {\r\n this._clipForChildren(context);\r\n }\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n // Only redraw parts of the screen that are invalidated\r\n if (invalidatedRectangle) {\r\n if (!child._intersectsRect(invalidatedRectangle)) {\r\n continue;\r\n }\r\n }\r\n child._render(context, invalidatedRectangle);\r\n }\r\n };\r\n Container.prototype.getDescendantsToRef = function (results, directDescendantsOnly, predicate) {\r\n if (directDescendantsOnly === void 0) { directDescendantsOnly = false; }\r\n if (!this.children) {\r\n return;\r\n }\r\n for (var index = 0; index < this.children.length; index++) {\r\n var item = this.children[index];\r\n if (!predicate || predicate(item)) {\r\n results.push(item);\r\n }\r\n if (!directDescendantsOnly) {\r\n item.getDescendantsToRef(results, false, predicate);\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n Container.prototype._processPicking = function (x, y, pi, type, pointerId, buttonIndex, deltaX, deltaY) {\r\n if (!this._isEnabled || !this.isVisible || this.notRenderable) {\r\n return false;\r\n }\r\n if (!_super.prototype.contains.call(this, x, y)) {\r\n return false;\r\n }\r\n // Checking backwards to pick closest first\r\n for (var index = this._children.length - 1; index >= 0; index--) {\r\n var child = this._children[index];\r\n if (child._processPicking(x, y, pi, type, pointerId, buttonIndex, deltaX, deltaY)) {\r\n if (child.hoverCursor) {\r\n this._host._changeCursor(child.hoverCursor);\r\n }\r\n return true;\r\n }\r\n }\r\n if (!this.isHitTestVisible) {\r\n return false;\r\n }\r\n return this._processObservables(type, x, y, pi, pointerId, buttonIndex, deltaX, deltaY);\r\n };\r\n /** @hidden */\r\n Container.prototype._additionalProcessing = function (parentMeasure, context) {\r\n _super.prototype._additionalProcessing.call(this, parentMeasure, context);\r\n this._measureForChildren.copyFrom(this._currentMeasure);\r\n };\r\n /** Releases associated resources */\r\n Container.prototype.dispose = function () {\r\n _super.prototype.dispose.call(this);\r\n for (var index = this.children.length - 1; index >= 0; index--) {\r\n this.children[index].dispose();\r\n }\r\n };\r\n return Container;\r\n}(Control));\r\nexport { Container };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Container\"] = Container;\r\n//# sourceMappingURL=container.js.map","import { __decorate } from \"tslib\";\r\nimport { Matrix, Vector3 } from \"./Maths/math.vector\";\r\nimport { serialize } from \"./Misc/decorators\";\r\nimport { Observable } from \"./Misc/observable\";\r\nimport { EngineStore } from \"./Engines/engineStore\";\r\nimport { _DevTools } from './Misc/devTools';\r\n/**\r\n * Node is the basic class for all scene objects (Mesh, Light, Camera.)\r\n */\r\nvar Node = /** @class */ (function () {\r\n /**\r\n * Creates a new Node\r\n * @param name the name and id to be given to this node\r\n * @param scene the scene this node will be added to\r\n */\r\n function Node(name, scene) {\r\n if (scene === void 0) { scene = null; }\r\n /**\r\n * Gets or sets a string used to store user defined state for the node\r\n */\r\n this.state = \"\";\r\n /**\r\n * Gets or sets an object used to store user defined information for the node\r\n */\r\n this.metadata = null;\r\n /**\r\n * For internal use only. Please do not use.\r\n */\r\n this.reservedDataStore = null;\r\n this._doNotSerialize = false;\r\n /** @hidden */\r\n this._isDisposed = false;\r\n /**\r\n * Gets a list of Animations associated with the node\r\n */\r\n this.animations = new Array();\r\n this._ranges = {};\r\n /**\r\n * Callback raised when the node is ready to be used\r\n */\r\n this.onReady = null;\r\n this._isEnabled = true;\r\n this._isParentEnabled = true;\r\n this._isReady = true;\r\n /** @hidden */\r\n this._currentRenderId = -1;\r\n this._parentUpdateId = -1;\r\n /** @hidden */\r\n this._childUpdateId = -1;\r\n /** @hidden */\r\n this._waitingParentId = null;\r\n /** @hidden */\r\n this._cache = {};\r\n this._parentNode = null;\r\n this._children = null;\r\n /** @hidden */\r\n this._worldMatrix = Matrix.Identity();\r\n /** @hidden */\r\n this._worldMatrixDeterminant = 0;\r\n /** @hidden */\r\n this._worldMatrixDeterminantIsDirty = true;\r\n /** @hidden */\r\n this._sceneRootNodesIndex = -1;\r\n this._animationPropertiesOverride = null;\r\n /** @hidden */\r\n this._isNode = true;\r\n /**\r\n * An event triggered when the mesh is disposed\r\n */\r\n this.onDisposeObservable = new Observable();\r\n this._onDisposeObserver = null;\r\n // Behaviors\r\n this._behaviors = new Array();\r\n this.name = name;\r\n this.id = name;\r\n this._scene = (scene || EngineStore.LastCreatedScene);\r\n this.uniqueId = this._scene.getUniqueId();\r\n this._initCache();\r\n }\r\n /**\r\n * Add a new node constructor\r\n * @param type defines the type name of the node to construct\r\n * @param constructorFunc defines the constructor function\r\n */\r\n Node.AddNodeConstructor = function (type, constructorFunc) {\r\n this._NodeConstructors[type] = constructorFunc;\r\n };\r\n /**\r\n * Returns a node constructor based on type name\r\n * @param type defines the type name\r\n * @param name defines the new node name\r\n * @param scene defines the hosting scene\r\n * @param options defines optional options to transmit to constructors\r\n * @returns the new constructor or null\r\n */\r\n Node.Construct = function (type, name, scene, options) {\r\n var constructorFunc = this._NodeConstructors[type];\r\n if (!constructorFunc) {\r\n return null;\r\n }\r\n return constructorFunc(name, scene, options);\r\n };\r\n Object.defineProperty(Node.prototype, \"doNotSerialize\", {\r\n /**\r\n * Gets or sets a boolean used to define if the node must be serialized\r\n */\r\n get: function () {\r\n if (this._doNotSerialize) {\r\n return true;\r\n }\r\n if (this._parentNode) {\r\n return this._parentNode.doNotSerialize;\r\n }\r\n return false;\r\n },\r\n set: function (value) {\r\n this._doNotSerialize = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets a boolean indicating if the node has been disposed\r\n * @returns true if the node was disposed\r\n */\r\n Node.prototype.isDisposed = function () {\r\n return this._isDisposed;\r\n };\r\n Object.defineProperty(Node.prototype, \"parent\", {\r\n get: function () {\r\n return this._parentNode;\r\n },\r\n /**\r\n * Gets or sets the parent of the node (without keeping the current position in the scene)\r\n * @see https://doc.babylonjs.com/how_to/parenting\r\n */\r\n set: function (parent) {\r\n if (this._parentNode === parent) {\r\n return;\r\n }\r\n var previousParentNode = this._parentNode;\r\n // Remove self from list of children of parent\r\n if (this._parentNode && this._parentNode._children !== undefined && this._parentNode._children !== null) {\r\n var index = this._parentNode._children.indexOf(this);\r\n if (index !== -1) {\r\n this._parentNode._children.splice(index, 1);\r\n }\r\n if (!parent && !this._isDisposed) {\r\n this._addToSceneRootNodes();\r\n }\r\n }\r\n // Store new parent\r\n this._parentNode = parent;\r\n // Add as child to new parent\r\n if (this._parentNode) {\r\n if (this._parentNode._children === undefined || this._parentNode._children === null) {\r\n this._parentNode._children = new Array();\r\n }\r\n this._parentNode._children.push(this);\r\n if (!previousParentNode) {\r\n this._removeFromSceneRootNodes();\r\n }\r\n }\r\n // Enabled state\r\n this._syncParentEnabledState();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n Node.prototype._addToSceneRootNodes = function () {\r\n if (this._sceneRootNodesIndex === -1) {\r\n this._sceneRootNodesIndex = this._scene.rootNodes.length;\r\n this._scene.rootNodes.push(this);\r\n }\r\n };\r\n /** @hidden */\r\n Node.prototype._removeFromSceneRootNodes = function () {\r\n if (this._sceneRootNodesIndex !== -1) {\r\n var rootNodes = this._scene.rootNodes;\r\n var lastIdx = rootNodes.length - 1;\r\n rootNodes[this._sceneRootNodesIndex] = rootNodes[lastIdx];\r\n rootNodes[this._sceneRootNodesIndex]._sceneRootNodesIndex = this._sceneRootNodesIndex;\r\n this._scene.rootNodes.pop();\r\n this._sceneRootNodesIndex = -1;\r\n }\r\n };\r\n Object.defineProperty(Node.prototype, \"animationPropertiesOverride\", {\r\n /**\r\n * Gets or sets the animation properties override\r\n */\r\n get: function () {\r\n if (!this._animationPropertiesOverride) {\r\n return this._scene.animationPropertiesOverride;\r\n }\r\n return this._animationPropertiesOverride;\r\n },\r\n set: function (value) {\r\n this._animationPropertiesOverride = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets a string identifying the name of the class\r\n * @returns \"Node\" string\r\n */\r\n Node.prototype.getClassName = function () {\r\n return \"Node\";\r\n };\r\n Object.defineProperty(Node.prototype, \"onDispose\", {\r\n /**\r\n * Sets a callback that will be raised when the node will be disposed\r\n */\r\n set: function (callback) {\r\n if (this._onDisposeObserver) {\r\n this.onDisposeObservable.remove(this._onDisposeObserver);\r\n }\r\n this._onDisposeObserver = this.onDisposeObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the scene of the node\r\n * @returns a scene\r\n */\r\n Node.prototype.getScene = function () {\r\n return this._scene;\r\n };\r\n /**\r\n * Gets the engine of the node\r\n * @returns a Engine\r\n */\r\n Node.prototype.getEngine = function () {\r\n return this._scene.getEngine();\r\n };\r\n /**\r\n * Attach a behavior to the node\r\n * @see https://doc.babylonjs.com/features/behaviour\r\n * @param behavior defines the behavior to attach\r\n * @param attachImmediately defines that the behavior must be attached even if the scene is still loading\r\n * @returns the current Node\r\n */\r\n Node.prototype.addBehavior = function (behavior, attachImmediately) {\r\n var _this = this;\r\n if (attachImmediately === void 0) { attachImmediately = false; }\r\n var index = this._behaviors.indexOf(behavior);\r\n if (index !== -1) {\r\n return this;\r\n }\r\n behavior.init();\r\n if (this._scene.isLoading && !attachImmediately) {\r\n // We defer the attach when the scene will be loaded\r\n this._scene.onDataLoadedObservable.addOnce(function () {\r\n behavior.attach(_this);\r\n });\r\n }\r\n else {\r\n behavior.attach(this);\r\n }\r\n this._behaviors.push(behavior);\r\n return this;\r\n };\r\n /**\r\n * Remove an attached behavior\r\n * @see https://doc.babylonjs.com/features/behaviour\r\n * @param behavior defines the behavior to attach\r\n * @returns the current Node\r\n */\r\n Node.prototype.removeBehavior = function (behavior) {\r\n var index = this._behaviors.indexOf(behavior);\r\n if (index === -1) {\r\n return this;\r\n }\r\n this._behaviors[index].detach();\r\n this._behaviors.splice(index, 1);\r\n return this;\r\n };\r\n Object.defineProperty(Node.prototype, \"behaviors\", {\r\n /**\r\n * Gets the list of attached behaviors\r\n * @see https://doc.babylonjs.com/features/behaviour\r\n */\r\n get: function () {\r\n return this._behaviors;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets an attached behavior by name\r\n * @param name defines the name of the behavior to look for\r\n * @see https://doc.babylonjs.com/features/behaviour\r\n * @returns null if behavior was not found else the requested behavior\r\n */\r\n Node.prototype.getBehaviorByName = function (name) {\r\n for (var _i = 0, _a = this._behaviors; _i < _a.length; _i++) {\r\n var behavior = _a[_i];\r\n if (behavior.name === name) {\r\n return behavior;\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Returns the latest update of the World matrix\r\n * @returns a Matrix\r\n */\r\n Node.prototype.getWorldMatrix = function () {\r\n if (this._currentRenderId !== this._scene.getRenderId()) {\r\n this.computeWorldMatrix();\r\n }\r\n return this._worldMatrix;\r\n };\r\n /** @hidden */\r\n Node.prototype._getWorldMatrixDeterminant = function () {\r\n if (this._worldMatrixDeterminantIsDirty) {\r\n this._worldMatrixDeterminantIsDirty = false;\r\n this._worldMatrixDeterminant = this._worldMatrix.determinant();\r\n }\r\n return this._worldMatrixDeterminant;\r\n };\r\n Object.defineProperty(Node.prototype, \"worldMatrixFromCache\", {\r\n /**\r\n * Returns directly the latest state of the mesh World matrix.\r\n * A Matrix is returned.\r\n */\r\n get: function () {\r\n return this._worldMatrix;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n // override it in derived class if you add new variables to the cache\r\n // and call the parent class method\r\n /** @hidden */\r\n Node.prototype._initCache = function () {\r\n this._cache = {};\r\n this._cache.parent = undefined;\r\n };\r\n /** @hidden */\r\n Node.prototype.updateCache = function (force) {\r\n if (!force && this.isSynchronized()) {\r\n return;\r\n }\r\n this._cache.parent = this.parent;\r\n this._updateCache();\r\n };\r\n /** @hidden */\r\n Node.prototype._getActionManagerForTrigger = function (trigger, initialCall) {\r\n if (initialCall === void 0) { initialCall = true; }\r\n if (!this.parent) {\r\n return null;\r\n }\r\n return this.parent._getActionManagerForTrigger(trigger, false);\r\n };\r\n // override it in derived class if you add new variables to the cache\r\n // and call the parent class method if !ignoreParentClass\r\n /** @hidden */\r\n Node.prototype._updateCache = function (ignoreParentClass) {\r\n };\r\n // override it in derived class if you add new variables to the cache\r\n /** @hidden */\r\n Node.prototype._isSynchronized = function () {\r\n return true;\r\n };\r\n /** @hidden */\r\n Node.prototype._markSyncedWithParent = function () {\r\n if (this._parentNode) {\r\n this._parentUpdateId = this._parentNode._childUpdateId;\r\n }\r\n };\r\n /** @hidden */\r\n Node.prototype.isSynchronizedWithParent = function () {\r\n if (!this._parentNode) {\r\n return true;\r\n }\r\n if (this._parentUpdateId !== this._parentNode._childUpdateId) {\r\n return false;\r\n }\r\n return this._parentNode.isSynchronized();\r\n };\r\n /** @hidden */\r\n Node.prototype.isSynchronized = function () {\r\n if (this._cache.parent != this._parentNode) {\r\n this._cache.parent = this._parentNode;\r\n return false;\r\n }\r\n if (this._parentNode && !this.isSynchronizedWithParent()) {\r\n return false;\r\n }\r\n return this._isSynchronized();\r\n };\r\n /**\r\n * Is this node ready to be used/rendered\r\n * @param completeCheck defines if a complete check (including materials and lights) has to be done (false by default)\r\n * @return true if the node is ready\r\n */\r\n Node.prototype.isReady = function (completeCheck) {\r\n if (completeCheck === void 0) { completeCheck = false; }\r\n return this._isReady;\r\n };\r\n /**\r\n * Is this node enabled?\r\n * If the node has a parent, all ancestors will be checked and false will be returned if any are false (not enabled), otherwise will return true\r\n * @param checkAncestors indicates if this method should check the ancestors. The default is to check the ancestors. If set to false, the method will return the value of this node without checking ancestors\r\n * @return whether this node (and its parent) is enabled\r\n */\r\n Node.prototype.isEnabled = function (checkAncestors) {\r\n if (checkAncestors === void 0) { checkAncestors = true; }\r\n if (checkAncestors === false) {\r\n return this._isEnabled;\r\n }\r\n if (!this._isEnabled) {\r\n return false;\r\n }\r\n return this._isParentEnabled;\r\n };\r\n /** @hidden */\r\n Node.prototype._syncParentEnabledState = function () {\r\n this._isParentEnabled = this._parentNode ? this._parentNode.isEnabled() : true;\r\n if (this._children) {\r\n this._children.forEach(function (c) {\r\n c._syncParentEnabledState(); // Force children to update accordingly\r\n });\r\n }\r\n };\r\n /**\r\n * Set the enabled state of this node\r\n * @param value defines the new enabled state\r\n */\r\n Node.prototype.setEnabled = function (value) {\r\n this._isEnabled = value;\r\n this._syncParentEnabledState();\r\n };\r\n /**\r\n * Is this node a descendant of the given node?\r\n * The function will iterate up the hierarchy until the ancestor was found or no more parents defined\r\n * @param ancestor defines the parent node to inspect\r\n * @returns a boolean indicating if this node is a descendant of the given node\r\n */\r\n Node.prototype.isDescendantOf = function (ancestor) {\r\n if (this.parent) {\r\n if (this.parent === ancestor) {\r\n return true;\r\n }\r\n return this.parent.isDescendantOf(ancestor);\r\n }\r\n return false;\r\n };\r\n /** @hidden */\r\n Node.prototype._getDescendants = function (results, directDescendantsOnly, predicate) {\r\n if (directDescendantsOnly === void 0) { directDescendantsOnly = false; }\r\n if (!this._children) {\r\n return;\r\n }\r\n for (var index = 0; index < this._children.length; index++) {\r\n var item = this._children[index];\r\n if (!predicate || predicate(item)) {\r\n results.push(item);\r\n }\r\n if (!directDescendantsOnly) {\r\n item._getDescendants(results, false, predicate);\r\n }\r\n }\r\n };\r\n /**\r\n * Will return all nodes that have this node as ascendant\r\n * @param directDescendantsOnly defines if true only direct descendants of 'this' will be considered, if false direct and also indirect (children of children, an so on in a recursive manner) descendants of 'this' will be considered\r\n * @param predicate defines an optional predicate that will be called on every evaluated child, the predicate must return true for a given child to be part of the result, otherwise it will be ignored\r\n * @return all children nodes of all types\r\n */\r\n Node.prototype.getDescendants = function (directDescendantsOnly, predicate) {\r\n var results = new Array();\r\n this._getDescendants(results, directDescendantsOnly, predicate);\r\n return results;\r\n };\r\n /**\r\n * Get all child-meshes of this node\r\n * @param directDescendantsOnly defines if true only direct descendants of 'this' will be considered, if false direct and also indirect (children of children, an so on in a recursive manner) descendants of 'this' will be considered (Default: false)\r\n * @param predicate defines an optional predicate that will be called on every evaluated child, the predicate must return true for a given child to be part of the result, otherwise it will be ignored\r\n * @returns an array of AbstractMesh\r\n */\r\n Node.prototype.getChildMeshes = function (directDescendantsOnly, predicate) {\r\n var results = [];\r\n this._getDescendants(results, directDescendantsOnly, function (node) {\r\n return ((!predicate || predicate(node)) && (node.cullingStrategy !== undefined));\r\n });\r\n return results;\r\n };\r\n /**\r\n * Get all direct children of this node\r\n * @param predicate defines an optional predicate that will be called on every evaluated child, the predicate must return true for a given child to be part of the result, otherwise it will be ignored\r\n * @param directDescendantsOnly defines if true only direct descendants of 'this' will be considered, if false direct and also indirect (children of children, an so on in a recursive manner) descendants of 'this' will be considered (Default: true)\r\n * @returns an array of Node\r\n */\r\n Node.prototype.getChildren = function (predicate, directDescendantsOnly) {\r\n if (directDescendantsOnly === void 0) { directDescendantsOnly = true; }\r\n return this.getDescendants(directDescendantsOnly, predicate);\r\n };\r\n /** @hidden */\r\n Node.prototype._setReady = function (state) {\r\n if (state === this._isReady) {\r\n return;\r\n }\r\n if (!state) {\r\n this._isReady = false;\r\n return;\r\n }\r\n if (this.onReady) {\r\n this.onReady(this);\r\n }\r\n this._isReady = true;\r\n };\r\n /**\r\n * Get an animation by name\r\n * @param name defines the name of the animation to look for\r\n * @returns null if not found else the requested animation\r\n */\r\n Node.prototype.getAnimationByName = function (name) {\r\n for (var i = 0; i < this.animations.length; i++) {\r\n var animation = this.animations[i];\r\n if (animation.name === name) {\r\n return animation;\r\n }\r\n }\r\n return null;\r\n };\r\n /**\r\n * Creates an animation range for this node\r\n * @param name defines the name of the range\r\n * @param from defines the starting key\r\n * @param to defines the end key\r\n */\r\n Node.prototype.createAnimationRange = function (name, from, to) {\r\n // check name not already in use\r\n if (!this._ranges[name]) {\r\n this._ranges[name] = Node._AnimationRangeFactory(name, from, to);\r\n for (var i = 0, nAnimations = this.animations.length; i < nAnimations; i++) {\r\n if (this.animations[i]) {\r\n this.animations[i].createRange(name, from, to);\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Delete a specific animation range\r\n * @param name defines the name of the range to delete\r\n * @param deleteFrames defines if animation frames from the range must be deleted as well\r\n */\r\n Node.prototype.deleteAnimationRange = function (name, deleteFrames) {\r\n if (deleteFrames === void 0) { deleteFrames = true; }\r\n for (var i = 0, nAnimations = this.animations.length; i < nAnimations; i++) {\r\n if (this.animations[i]) {\r\n this.animations[i].deleteRange(name, deleteFrames);\r\n }\r\n }\r\n this._ranges[name] = null; // said much faster than 'delete this._range[name]'\r\n };\r\n /**\r\n * Get an animation range by name\r\n * @param name defines the name of the animation range to look for\r\n * @returns null if not found else the requested animation range\r\n */\r\n Node.prototype.getAnimationRange = function (name) {\r\n return this._ranges[name] || null;\r\n };\r\n /**\r\n * Gets the list of all animation ranges defined on this node\r\n * @returns an array\r\n */\r\n Node.prototype.getAnimationRanges = function () {\r\n var animationRanges = [];\r\n var name;\r\n for (name in this._ranges) {\r\n animationRanges.push(this._ranges[name]);\r\n }\r\n return animationRanges;\r\n };\r\n /**\r\n * Will start the animation sequence\r\n * @param name defines the range frames for animation sequence\r\n * @param loop defines if the animation should loop (false by default)\r\n * @param speedRatio defines the speed factor in which to run the animation (1 by default)\r\n * @param onAnimationEnd defines a function to be executed when the animation ended (undefined by default)\r\n * @returns the object created for this animation. If range does not exist, it will return null\r\n */\r\n Node.prototype.beginAnimation = function (name, loop, speedRatio, onAnimationEnd) {\r\n var range = this.getAnimationRange(name);\r\n if (!range) {\r\n return null;\r\n }\r\n return this._scene.beginAnimation(this, range.from, range.to, loop, speedRatio, onAnimationEnd);\r\n };\r\n /**\r\n * Serialize animation ranges into a JSON compatible object\r\n * @returns serialization object\r\n */\r\n Node.prototype.serializeAnimationRanges = function () {\r\n var serializationRanges = [];\r\n for (var name in this._ranges) {\r\n var localRange = this._ranges[name];\r\n if (!localRange) {\r\n continue;\r\n }\r\n var range = {};\r\n range.name = name;\r\n range.from = localRange.from;\r\n range.to = localRange.to;\r\n serializationRanges.push(range);\r\n }\r\n return serializationRanges;\r\n };\r\n /**\r\n * Computes the world matrix of the node\r\n * @param force defines if the cache version should be invalidated forcing the world matrix to be created from scratch\r\n * @returns the world matrix\r\n */\r\n Node.prototype.computeWorldMatrix = function (force) {\r\n if (!this._worldMatrix) {\r\n this._worldMatrix = Matrix.Identity();\r\n }\r\n return this._worldMatrix;\r\n };\r\n /**\r\n * Releases resources associated with this node.\r\n * @param doNotRecurse Set to true to not recurse into each children (recurse into each children by default)\r\n * @param disposeMaterialAndTextures Set to true to also dispose referenced materials and textures (false by default)\r\n */\r\n Node.prototype.dispose = function (doNotRecurse, disposeMaterialAndTextures) {\r\n if (disposeMaterialAndTextures === void 0) { disposeMaterialAndTextures = false; }\r\n this._isDisposed = true;\r\n if (!doNotRecurse) {\r\n var nodes = this.getDescendants(true);\r\n for (var _i = 0, nodes_1 = nodes; _i < nodes_1.length; _i++) {\r\n var node = nodes_1[_i];\r\n node.dispose(doNotRecurse, disposeMaterialAndTextures);\r\n }\r\n }\r\n if (!this.parent) {\r\n this._removeFromSceneRootNodes();\r\n }\r\n else {\r\n this.parent = null;\r\n }\r\n // Callback\r\n this.onDisposeObservable.notifyObservers(this);\r\n this.onDisposeObservable.clear();\r\n // Behaviors\r\n for (var _a = 0, _b = this._behaviors; _a < _b.length; _a++) {\r\n var behavior = _b[_a];\r\n behavior.detach();\r\n }\r\n this._behaviors = [];\r\n };\r\n /**\r\n * Parse animation range data from a serialization object and store them into a given node\r\n * @param node defines where to store the animation ranges\r\n * @param parsedNode defines the serialization object to read data from\r\n * @param scene defines the hosting scene\r\n */\r\n Node.ParseAnimationRanges = function (node, parsedNode, scene) {\r\n if (parsedNode.ranges) {\r\n for (var index = 0; index < parsedNode.ranges.length; index++) {\r\n var data = parsedNode.ranges[index];\r\n node.createAnimationRange(data.name, data.from, data.to);\r\n }\r\n }\r\n };\r\n /**\r\n * Return the minimum and maximum world vectors of the entire hierarchy under current node\r\n * @param includeDescendants Include bounding info from descendants as well (true by default)\r\n * @param predicate defines a callback function that can be customize to filter what meshes should be included in the list used to compute the bounding vectors\r\n * @returns the new bounding vectors\r\n */\r\n Node.prototype.getHierarchyBoundingVectors = function (includeDescendants, predicate) {\r\n if (includeDescendants === void 0) { includeDescendants = true; }\r\n if (predicate === void 0) { predicate = null; }\r\n // Ensures that all world matrix will be recomputed.\r\n this.getScene().incrementRenderId();\r\n this.computeWorldMatrix(true);\r\n var min;\r\n var max;\r\n var thisAbstractMesh = this;\r\n if (thisAbstractMesh.getBoundingInfo && thisAbstractMesh.subMeshes) {\r\n // If this is an abstract mesh get its bounding info\r\n var boundingInfo = thisAbstractMesh.getBoundingInfo();\r\n min = boundingInfo.boundingBox.minimumWorld.clone();\r\n max = boundingInfo.boundingBox.maximumWorld.clone();\r\n }\r\n else {\r\n min = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n max = new Vector3(-Number.MAX_VALUE, -Number.MAX_VALUE, -Number.MAX_VALUE);\r\n }\r\n if (includeDescendants) {\r\n var descendants = this.getDescendants(false);\r\n for (var _i = 0, descendants_1 = descendants; _i < descendants_1.length; _i++) {\r\n var descendant = descendants_1[_i];\r\n var childMesh = descendant;\r\n childMesh.computeWorldMatrix(true);\r\n // Filters meshes based on custom predicate function.\r\n if (predicate && !predicate(childMesh)) {\r\n continue;\r\n }\r\n //make sure we have the needed params to get mix and max\r\n if (!childMesh.getBoundingInfo || childMesh.getTotalVertices() === 0) {\r\n continue;\r\n }\r\n var childBoundingInfo = childMesh.getBoundingInfo();\r\n var boundingBox = childBoundingInfo.boundingBox;\r\n var minBox = boundingBox.minimumWorld;\r\n var maxBox = boundingBox.maximumWorld;\r\n Vector3.CheckExtends(minBox, min, max);\r\n Vector3.CheckExtends(maxBox, min, max);\r\n }\r\n }\r\n return {\r\n min: min,\r\n max: max\r\n };\r\n };\r\n /** @hidden */\r\n Node._AnimationRangeFactory = function (name, from, to) {\r\n throw _DevTools.WarnImport(\"AnimationRange\");\r\n };\r\n Node._NodeConstructors = {};\r\n __decorate([\r\n serialize()\r\n ], Node.prototype, \"name\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Node.prototype, \"id\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Node.prototype, \"uniqueId\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Node.prototype, \"state\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Node.prototype, \"metadata\", void 0);\r\n return Node;\r\n}());\r\nexport { Node };\r\n//# sourceMappingURL=node.js.map","/**\r\n * Class used to help managing file picking and drag'n'drop\r\n * File Storage\r\n */\r\nvar FilesInputStore = /** @class */ (function () {\r\n function FilesInputStore() {\r\n }\r\n /**\r\n * List of files ready to be loaded\r\n */\r\n FilesInputStore.FilesToLoad = {};\r\n return FilesInputStore;\r\n}());\r\nexport { FilesInputStore };\r\n//# sourceMappingURL=filesInputStore.js.map","/**\r\n * Class used to define a retry strategy when error happens while loading assets\r\n */\r\nvar RetryStrategy = /** @class */ (function () {\r\n function RetryStrategy() {\r\n }\r\n /**\r\n * Function used to defines an exponential back off strategy\r\n * @param maxRetries defines the maximum number of retries (3 by default)\r\n * @param baseInterval defines the interval between retries\r\n * @returns the strategy function to use\r\n */\r\n RetryStrategy.ExponentialBackoff = function (maxRetries, baseInterval) {\r\n if (maxRetries === void 0) { maxRetries = 3; }\r\n if (baseInterval === void 0) { baseInterval = 500; }\r\n return function (url, request, retryIndex) {\r\n if (request.status !== 0 || retryIndex >= maxRetries || url.indexOf(\"file:\") !== -1) {\r\n return -1;\r\n }\r\n return Math.pow(2, retryIndex) * baseInterval;\r\n };\r\n };\r\n return RetryStrategy;\r\n}());\r\nexport { RetryStrategy };\r\n//# sourceMappingURL=retryStrategy.js.map","import { __extends } from \"tslib\";\r\n/**\r\n * @ignore\r\n * Application error to support additional information when loading a file\r\n */\r\nvar BaseError = /** @class */ (function (_super) {\r\n __extends(BaseError, _super);\r\n function BaseError() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n // See https://stackoverflow.com/questions/12915412/how-do-i-extend-a-host-object-e-g-error-in-typescript\r\n // and https://github.com/Microsoft/TypeScript/wiki/Breaking-Changes#extending-built-ins-like-error-array-and-map-may-no-longer-work\r\n // Polyfill for Object.setPrototypeOf if necessary.\r\n BaseError._setPrototypeOf = Object.setPrototypeOf || (function (o, proto) { o.__proto__ = proto; return o; });\r\n return BaseError;\r\n}(Error));\r\nexport { BaseError };\r\n//# sourceMappingURL=baseError.js.map","import { __extends } from \"tslib\";\r\nimport { WebRequest } from './webRequest';\r\nimport { DomManagement } from './domManagement';\r\nimport { Observable } from './observable';\r\nimport { FilesInputStore } from './filesInputStore';\r\nimport { RetryStrategy } from './retryStrategy';\r\nimport { BaseError } from './baseError';\r\nimport { StringTools } from './stringTools';\r\nimport { ThinEngine } from '../Engines/thinEngine';\r\nimport { ShaderProcessor } from '../Engines/Processors/shaderProcessor';\r\n/** @ignore */\r\nvar LoadFileError = /** @class */ (function (_super) {\r\n __extends(LoadFileError, _super);\r\n /**\r\n * Creates a new LoadFileError\r\n * @param message defines the message of the error\r\n * @param request defines the optional web request\r\n * @param file defines the optional file\r\n */\r\n function LoadFileError(message, object) {\r\n var _this = _super.call(this, message) || this;\r\n _this.name = \"LoadFileError\";\r\n BaseError._setPrototypeOf(_this, LoadFileError.prototype);\r\n if (object instanceof WebRequest) {\r\n _this.request = object;\r\n }\r\n else {\r\n _this.file = object;\r\n }\r\n return _this;\r\n }\r\n return LoadFileError;\r\n}(BaseError));\r\nexport { LoadFileError };\r\n/** @ignore */\r\nvar RequestFileError = /** @class */ (function (_super) {\r\n __extends(RequestFileError, _super);\r\n /**\r\n * Creates a new LoadFileError\r\n * @param message defines the message of the error\r\n * @param request defines the optional web request\r\n */\r\n function RequestFileError(message, request) {\r\n var _this = _super.call(this, message) || this;\r\n _this.request = request;\r\n _this.name = \"RequestFileError\";\r\n BaseError._setPrototypeOf(_this, RequestFileError.prototype);\r\n return _this;\r\n }\r\n return RequestFileError;\r\n}(BaseError));\r\nexport { RequestFileError };\r\n/** @ignore */\r\nvar ReadFileError = /** @class */ (function (_super) {\r\n __extends(ReadFileError, _super);\r\n /**\r\n * Creates a new ReadFileError\r\n * @param message defines the message of the error\r\n * @param file defines the optional file\r\n */\r\n function ReadFileError(message, file) {\r\n var _this = _super.call(this, message) || this;\r\n _this.file = file;\r\n _this.name = \"ReadFileError\";\r\n BaseError._setPrototypeOf(_this, ReadFileError.prototype);\r\n return _this;\r\n }\r\n return ReadFileError;\r\n}(BaseError));\r\nexport { ReadFileError };\r\n/**\r\n * @hidden\r\n */\r\nvar FileTools = /** @class */ (function () {\r\n function FileTools() {\r\n }\r\n /**\r\n * Removes unwanted characters from an url\r\n * @param url defines the url to clean\r\n * @returns the cleaned url\r\n */\r\n FileTools._CleanUrl = function (url) {\r\n url = url.replace(/#/mg, \"%23\");\r\n return url;\r\n };\r\n /**\r\n * Sets the cors behavior on a dom element. This will add the required Tools.CorsBehavior to the element.\r\n * @param url define the url we are trying\r\n * @param element define the dom element where to configure the cors policy\r\n */\r\n FileTools.SetCorsBehavior = function (url, element) {\r\n if (url && url.indexOf(\"data:\") === 0) {\r\n return;\r\n }\r\n if (FileTools.CorsBehavior) {\r\n if (typeof (FileTools.CorsBehavior) === 'string' || this.CorsBehavior instanceof String) {\r\n element.crossOrigin = FileTools.CorsBehavior;\r\n }\r\n else {\r\n var result = FileTools.CorsBehavior(url);\r\n if (result) {\r\n element.crossOrigin = result;\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Loads an image as an HTMLImageElement.\r\n * @param input url string, ArrayBuffer, or Blob to load\r\n * @param onLoad callback called when the image successfully loads\r\n * @param onError callback called when the image fails to load\r\n * @param offlineProvider offline provider for caching\r\n * @param mimeType optional mime type\r\n * @returns the HTMLImageElement of the loaded image\r\n */\r\n FileTools.LoadImage = function (input, onLoad, onError, offlineProvider, mimeType) {\r\n if (mimeType === void 0) { mimeType = \"\"; }\r\n var url;\r\n var usingObjectURL = false;\r\n if (input instanceof ArrayBuffer || ArrayBuffer.isView(input)) {\r\n if (typeof Blob !== 'undefined') {\r\n url = URL.createObjectURL(new Blob([input], { type: mimeType }));\r\n usingObjectURL = true;\r\n }\r\n else {\r\n url = \"data:\" + mimeType + \";base64,\" + StringTools.EncodeArrayBufferToBase64(input);\r\n }\r\n }\r\n else if (input instanceof Blob) {\r\n url = URL.createObjectURL(input);\r\n usingObjectURL = true;\r\n }\r\n else {\r\n url = FileTools._CleanUrl(input);\r\n url = FileTools.PreprocessUrl(input);\r\n }\r\n if (typeof Image === \"undefined\") {\r\n FileTools.LoadFile(url, function (data) {\r\n createImageBitmap(new Blob([data], { type: mimeType })).then(function (imgBmp) {\r\n onLoad(imgBmp);\r\n if (usingObjectURL) {\r\n URL.revokeObjectURL(url);\r\n }\r\n }).catch(function (reason) {\r\n if (onError) {\r\n onError(\"Error while trying to load image: \" + input, reason);\r\n }\r\n });\r\n }, undefined, offlineProvider || undefined, true, function (request, exception) {\r\n if (onError) {\r\n onError(\"Error while trying to load image: \" + input, exception);\r\n }\r\n });\r\n return null;\r\n }\r\n var img = new Image();\r\n FileTools.SetCorsBehavior(url, img);\r\n var loadHandler = function () {\r\n img.removeEventListener(\"load\", loadHandler);\r\n img.removeEventListener(\"error\", errorHandler);\r\n onLoad(img);\r\n // Must revoke the URL after calling onLoad to avoid security exceptions in\r\n // certain scenarios (e.g. when hosted in vscode).\r\n if (usingObjectURL && img.src) {\r\n URL.revokeObjectURL(img.src);\r\n }\r\n };\r\n var errorHandler = function (err) {\r\n img.removeEventListener(\"load\", loadHandler);\r\n img.removeEventListener(\"error\", errorHandler);\r\n if (onError) {\r\n var inputText = input.toString();\r\n onError(\"Error while trying to load image: \" + (inputText.length < 32 ? inputText : inputText.slice(0, 32) + \"...\"), err);\r\n }\r\n if (usingObjectURL && img.src) {\r\n URL.revokeObjectURL(img.src);\r\n }\r\n };\r\n img.addEventListener(\"load\", loadHandler);\r\n img.addEventListener(\"error\", errorHandler);\r\n var noOfflineSupport = function () {\r\n img.src = url;\r\n };\r\n var loadFromOfflineSupport = function () {\r\n if (offlineProvider) {\r\n offlineProvider.loadImage(url, img);\r\n }\r\n };\r\n if (url.substr(0, 5) !== \"data:\" && offlineProvider && offlineProvider.enableTexturesOffline) {\r\n offlineProvider.open(loadFromOfflineSupport, noOfflineSupport);\r\n }\r\n else {\r\n if (url.indexOf(\"file:\") !== -1) {\r\n var textureName = decodeURIComponent(url.substring(5).toLowerCase());\r\n if (FilesInputStore.FilesToLoad[textureName]) {\r\n try {\r\n var blobURL;\r\n try {\r\n blobURL = URL.createObjectURL(FilesInputStore.FilesToLoad[textureName]);\r\n }\r\n catch (ex) {\r\n // Chrome doesn't support oneTimeOnly parameter\r\n blobURL = URL.createObjectURL(FilesInputStore.FilesToLoad[textureName]);\r\n }\r\n img.src = blobURL;\r\n usingObjectURL = true;\r\n }\r\n catch (e) {\r\n img.src = \"\";\r\n }\r\n return img;\r\n }\r\n }\r\n noOfflineSupport();\r\n }\r\n return img;\r\n };\r\n /**\r\n * Reads a file from a File object\r\n * @param file defines the file to load\r\n * @param onSuccess defines the callback to call when data is loaded\r\n * @param onProgress defines the callback to call during loading process\r\n * @param useArrayBuffer defines a boolean indicating that data must be returned as an ArrayBuffer\r\n * @param onError defines the callback to call when an error occurs\r\n * @returns a file request object\r\n */\r\n FileTools.ReadFile = function (file, onSuccess, onProgress, useArrayBuffer, onError) {\r\n var reader = new FileReader();\r\n var request = {\r\n onCompleteObservable: new Observable(),\r\n abort: function () { return reader.abort(); },\r\n };\r\n reader.onloadend = function (e) { return request.onCompleteObservable.notifyObservers(request); };\r\n if (onError) {\r\n reader.onerror = function (e) {\r\n onError(new ReadFileError(\"Unable to read \" + file.name, file));\r\n };\r\n }\r\n reader.onload = function (e) {\r\n //target doesn't have result from ts 1.3\r\n onSuccess(e.target['result']);\r\n };\r\n if (onProgress) {\r\n reader.onprogress = onProgress;\r\n }\r\n if (!useArrayBuffer) {\r\n // Asynchronous read\r\n reader.readAsText(file);\r\n }\r\n else {\r\n reader.readAsArrayBuffer(file);\r\n }\r\n return request;\r\n };\r\n /**\r\n * Loads a file from a url\r\n * @param url url to load\r\n * @param onSuccess callback called when the file successfully loads\r\n * @param onProgress callback called while file is loading (if the server supports this mode)\r\n * @param offlineProvider defines the offline provider for caching\r\n * @param useArrayBuffer defines a boolean indicating that date must be returned as ArrayBuffer\r\n * @param onError callback called when the file fails to load\r\n * @returns a file request object\r\n */\r\n FileTools.LoadFile = function (url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError) {\r\n // If file and file input are set\r\n if (url.indexOf(\"file:\") !== -1) {\r\n var fileName = decodeURIComponent(url.substring(5).toLowerCase());\r\n if (fileName.indexOf('./') === 0) {\r\n fileName = fileName.substring(2);\r\n }\r\n var file = FilesInputStore.FilesToLoad[fileName];\r\n if (file) {\r\n return FileTools.ReadFile(file, onSuccess, onProgress, useArrayBuffer, onError ? function (error) { return onError(undefined, new LoadFileError(error.message, error.file)); } : undefined);\r\n }\r\n }\r\n return FileTools.RequestFile(url, function (data, request) {\r\n onSuccess(data, request ? request.responseURL : undefined);\r\n }, onProgress, offlineProvider, useArrayBuffer, onError ? function (error) {\r\n onError(error.request, new LoadFileError(error.message, error.request));\r\n } : undefined);\r\n };\r\n /**\r\n * Loads a file\r\n * @param url url to load\r\n * @param onSuccess callback called when the file successfully loads\r\n * @param onProgress callback called while file is loading (if the server supports this mode)\r\n * @param useArrayBuffer defines a boolean indicating that date must be returned as ArrayBuffer\r\n * @param onError callback called when the file fails to load\r\n * @param onOpened callback called when the web request is opened\r\n * @returns a file request object\r\n */\r\n FileTools.RequestFile = function (url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError, onOpened) {\r\n url = FileTools._CleanUrl(url);\r\n url = FileTools.PreprocessUrl(url);\r\n var loadUrl = FileTools.BaseUrl + url;\r\n var aborted = false;\r\n var fileRequest = {\r\n onCompleteObservable: new Observable(),\r\n abort: function () { return aborted = true; },\r\n };\r\n var requestFile = function () {\r\n var request = new WebRequest();\r\n var retryHandle = null;\r\n fileRequest.abort = function () {\r\n aborted = true;\r\n if (request.readyState !== (XMLHttpRequest.DONE || 4)) {\r\n request.abort();\r\n }\r\n if (retryHandle !== null) {\r\n clearTimeout(retryHandle);\r\n retryHandle = null;\r\n }\r\n };\r\n var retryLoop = function (retryIndex) {\r\n request.open('GET', loadUrl);\r\n if (onOpened) {\r\n onOpened(request);\r\n }\r\n if (useArrayBuffer) {\r\n request.responseType = \"arraybuffer\";\r\n }\r\n if (onProgress) {\r\n request.addEventListener(\"progress\", onProgress);\r\n }\r\n var onLoadEnd = function () {\r\n request.removeEventListener(\"loadend\", onLoadEnd);\r\n fileRequest.onCompleteObservable.notifyObservers(fileRequest);\r\n fileRequest.onCompleteObservable.clear();\r\n };\r\n request.addEventListener(\"loadend\", onLoadEnd);\r\n var onReadyStateChange = function () {\r\n if (aborted) {\r\n return;\r\n }\r\n // In case of undefined state in some browsers.\r\n if (request.readyState === (XMLHttpRequest.DONE || 4)) {\r\n // Some browsers have issues where onreadystatechange can be called multiple times with the same value.\r\n request.removeEventListener(\"readystatechange\", onReadyStateChange);\r\n if ((request.status >= 200 && request.status < 300) || (request.status === 0 && (!DomManagement.IsWindowObjectExist() || FileTools.IsFileURL()))) {\r\n onSuccess(useArrayBuffer ? request.response : request.responseText, request);\r\n return;\r\n }\r\n var retryStrategy = FileTools.DefaultRetryStrategy;\r\n if (retryStrategy) {\r\n var waitTime = retryStrategy(loadUrl, request, retryIndex);\r\n if (waitTime !== -1) {\r\n // Prevent the request from completing for retry.\r\n request.removeEventListener(\"loadend\", onLoadEnd);\r\n request = new WebRequest();\r\n retryHandle = setTimeout(function () { return retryLoop(retryIndex + 1); }, waitTime);\r\n return;\r\n }\r\n }\r\n var error = new RequestFileError(\"Error status: \" + request.status + \" \" + request.statusText + \" - Unable to load \" + loadUrl, request);\r\n if (onError) {\r\n onError(error);\r\n }\r\n }\r\n };\r\n request.addEventListener(\"readystatechange\", onReadyStateChange);\r\n request.send();\r\n };\r\n retryLoop(0);\r\n };\r\n // Caching all files\r\n if (offlineProvider && offlineProvider.enableSceneOffline) {\r\n var noOfflineSupport_1 = function (request) {\r\n if (request && request.status > 400) {\r\n if (onError) {\r\n onError(request);\r\n }\r\n }\r\n else {\r\n requestFile();\r\n }\r\n };\r\n var loadFromOfflineSupport = function () {\r\n // TODO: database needs to support aborting and should return a IFileRequest\r\n if (offlineProvider) {\r\n offlineProvider.loadFile(FileTools.BaseUrl + url, function (data) {\r\n if (!aborted) {\r\n onSuccess(data);\r\n }\r\n fileRequest.onCompleteObservable.notifyObservers(fileRequest);\r\n }, onProgress ? function (event) {\r\n if (!aborted) {\r\n onProgress(event);\r\n }\r\n } : undefined, noOfflineSupport_1, useArrayBuffer);\r\n }\r\n };\r\n offlineProvider.open(loadFromOfflineSupport, noOfflineSupport_1);\r\n }\r\n else {\r\n requestFile();\r\n }\r\n return fileRequest;\r\n };\r\n /**\r\n * Checks if the loaded document was accessed via `file:`-Protocol.\r\n * @returns boolean\r\n */\r\n FileTools.IsFileURL = function () {\r\n return typeof location !== \"undefined\" && location.protocol === \"file:\";\r\n };\r\n /**\r\n * Gets or sets the retry strategy to apply when an error happens while loading an asset\r\n */\r\n FileTools.DefaultRetryStrategy = RetryStrategy.ExponentialBackoff();\r\n /**\r\n * Gets or sets the base URL to use to load assets\r\n */\r\n FileTools.BaseUrl = \"\";\r\n /**\r\n * Default behaviour for cors in the application.\r\n * It can be a string if the expected behavior is identical in the entire app.\r\n * Or a callback to be able to set it per url or on a group of them (in case of Video source for instance)\r\n */\r\n FileTools.CorsBehavior = \"anonymous\";\r\n /**\r\n * Gets or sets a function used to pre-process url before using them to load assets\r\n */\r\n FileTools.PreprocessUrl = function (url) {\r\n return url;\r\n };\r\n return FileTools;\r\n}());\r\nexport { FileTools };\r\nThinEngine._FileToolsLoadImage = FileTools.LoadImage.bind(FileTools);\r\nThinEngine._FileToolsLoadFile = FileTools.LoadFile.bind(FileTools);\r\nShaderProcessor._FileToolsLoadFile = FileTools.LoadFile.bind(FileTools);\r\n//# sourceMappingURL=fileTools.js.map","import { Vector3 } from './math.vector';\r\n/** Defines supported spaces */\r\nexport var Space;\r\n(function (Space) {\r\n /** Local (object) space */\r\n Space[Space[\"LOCAL\"] = 0] = \"LOCAL\";\r\n /** World space */\r\n Space[Space[\"WORLD\"] = 1] = \"WORLD\";\r\n /** Bone space */\r\n Space[Space[\"BONE\"] = 2] = \"BONE\";\r\n})(Space || (Space = {}));\r\n/** Defines the 3 main axes */\r\nvar Axis = /** @class */ (function () {\r\n function Axis() {\r\n }\r\n /** X axis */\r\n Axis.X = new Vector3(1.0, 0.0, 0.0);\r\n /** Y axis */\r\n Axis.Y = new Vector3(0.0, 1.0, 0.0);\r\n /** Z axis */\r\n Axis.Z = new Vector3(0.0, 0.0, 1.0);\r\n return Axis;\r\n}());\r\nexport { Axis };\r\n/**\r\n * Defines cartesian components.\r\n */\r\nexport var Coordinate;\r\n(function (Coordinate) {\r\n /** X axis */\r\n Coordinate[Coordinate[\"X\"] = 0] = \"X\";\r\n /** Y axis */\r\n Coordinate[Coordinate[\"Y\"] = 1] = \"Y\";\r\n /** Z axis */\r\n Coordinate[Coordinate[\"Z\"] = 2] = \"Z\";\r\n})(Coordinate || (Coordinate = {}));\r\n//# sourceMappingURL=math.axis.js.map","import { DomManagement } from './domManagement';\r\n/**\r\n * Class containing a set of static utilities functions for precision date\r\n */\r\nvar PrecisionDate = /** @class */ (function () {\r\n function PrecisionDate() {\r\n }\r\n Object.defineProperty(PrecisionDate, \"Now\", {\r\n /**\r\n * Gets either window.performance.now() if supported or Date.now() else\r\n */\r\n get: function () {\r\n if (DomManagement.IsWindowObjectExist() && window.performance && window.performance.now) {\r\n return window.performance.now();\r\n }\r\n return Date.now();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n return PrecisionDate;\r\n}());\r\nexport { PrecisionDate };\r\n//# sourceMappingURL=precisionDate.js.map","import { ArrayTools } from \"../Misc/arrayTools\";\r\nimport { Matrix, Vector3 } from \"../Maths/math.vector\";\r\nimport { Epsilon } from '../Maths/math.constants';\r\n/**\r\n * Class used to store bounding box information\r\n */\r\nvar BoundingBox = /** @class */ (function () {\r\n /**\r\n * Creates a new bounding box\r\n * @param min defines the minimum vector (in local space)\r\n * @param max defines the maximum vector (in local space)\r\n * @param worldMatrix defines the new world matrix\r\n */\r\n function BoundingBox(min, max, worldMatrix) {\r\n /**\r\n * Gets the 8 vectors representing the bounding box in local space\r\n */\r\n this.vectors = ArrayTools.BuildArray(8, Vector3.Zero);\r\n /**\r\n * Gets the center of the bounding box in local space\r\n */\r\n this.center = Vector3.Zero();\r\n /**\r\n * Gets the center of the bounding box in world space\r\n */\r\n this.centerWorld = Vector3.Zero();\r\n /**\r\n * Gets the extend size in local space\r\n */\r\n this.extendSize = Vector3.Zero();\r\n /**\r\n * Gets the extend size in world space\r\n */\r\n this.extendSizeWorld = Vector3.Zero();\r\n /**\r\n * Gets the OBB (object bounding box) directions\r\n */\r\n this.directions = ArrayTools.BuildArray(3, Vector3.Zero);\r\n /**\r\n * Gets the 8 vectors representing the bounding box in world space\r\n */\r\n this.vectorsWorld = ArrayTools.BuildArray(8, Vector3.Zero);\r\n /**\r\n * Gets the minimum vector in world space\r\n */\r\n this.minimumWorld = Vector3.Zero();\r\n /**\r\n * Gets the maximum vector in world space\r\n */\r\n this.maximumWorld = Vector3.Zero();\r\n /**\r\n * Gets the minimum vector in local space\r\n */\r\n this.minimum = Vector3.Zero();\r\n /**\r\n * Gets the maximum vector in local space\r\n */\r\n this.maximum = Vector3.Zero();\r\n this.reConstruct(min, max, worldMatrix);\r\n }\r\n // Methods\r\n /**\r\n * Recreates the entire bounding box from scratch as if we call the constructor in place\r\n * @param min defines the new minimum vector (in local space)\r\n * @param max defines the new maximum vector (in local space)\r\n * @param worldMatrix defines the new world matrix\r\n */\r\n BoundingBox.prototype.reConstruct = function (min, max, worldMatrix) {\r\n var minX = min.x, minY = min.y, minZ = min.z, maxX = max.x, maxY = max.y, maxZ = max.z;\r\n var vectors = this.vectors;\r\n this.minimum.copyFromFloats(minX, minY, minZ);\r\n this.maximum.copyFromFloats(maxX, maxY, maxZ);\r\n vectors[0].copyFromFloats(minX, minY, minZ);\r\n vectors[1].copyFromFloats(maxX, maxY, maxZ);\r\n vectors[2].copyFromFloats(maxX, minY, minZ);\r\n vectors[3].copyFromFloats(minX, maxY, minZ);\r\n vectors[4].copyFromFloats(minX, minY, maxZ);\r\n vectors[5].copyFromFloats(maxX, maxY, minZ);\r\n vectors[6].copyFromFloats(minX, maxY, maxZ);\r\n vectors[7].copyFromFloats(maxX, minY, maxZ);\r\n // OBB\r\n max.addToRef(min, this.center).scaleInPlace(0.5);\r\n max.subtractToRef(min, this.extendSize).scaleInPlace(0.5);\r\n this._worldMatrix = worldMatrix || Matrix.IdentityReadOnly;\r\n this._update(this._worldMatrix);\r\n };\r\n /**\r\n * Scale the current bounding box by applying a scale factor\r\n * @param factor defines the scale factor to apply\r\n * @returns the current bounding box\r\n */\r\n BoundingBox.prototype.scale = function (factor) {\r\n var tmpVectors = BoundingBox.TmpVector3;\r\n var diff = this.maximum.subtractToRef(this.minimum, tmpVectors[0]);\r\n var len = diff.length();\r\n diff.normalizeFromLength(len);\r\n var distance = len * factor;\r\n var newRadius = diff.scaleInPlace(distance * 0.5);\r\n var min = this.center.subtractToRef(newRadius, tmpVectors[1]);\r\n var max = this.center.addToRef(newRadius, tmpVectors[2]);\r\n this.reConstruct(min, max, this._worldMatrix);\r\n return this;\r\n };\r\n /**\r\n * Gets the world matrix of the bounding box\r\n * @returns a matrix\r\n */\r\n BoundingBox.prototype.getWorldMatrix = function () {\r\n return this._worldMatrix;\r\n };\r\n /** @hidden */\r\n BoundingBox.prototype._update = function (world) {\r\n var minWorld = this.minimumWorld;\r\n var maxWorld = this.maximumWorld;\r\n var directions = this.directions;\r\n var vectorsWorld = this.vectorsWorld;\r\n var vectors = this.vectors;\r\n if (!world.isIdentity()) {\r\n minWorld.setAll(Number.MAX_VALUE);\r\n maxWorld.setAll(-Number.MAX_VALUE);\r\n for (var index = 0; index < 8; ++index) {\r\n var v = vectorsWorld[index];\r\n Vector3.TransformCoordinatesToRef(vectors[index], world, v);\r\n minWorld.minimizeInPlace(v);\r\n maxWorld.maximizeInPlace(v);\r\n }\r\n // Extend\r\n maxWorld.subtractToRef(minWorld, this.extendSizeWorld).scaleInPlace(0.5);\r\n maxWorld.addToRef(minWorld, this.centerWorld).scaleInPlace(0.5);\r\n }\r\n else {\r\n minWorld.copyFrom(this.minimum);\r\n maxWorld.copyFrom(this.maximum);\r\n for (var index = 0; index < 8; ++index) {\r\n vectorsWorld[index].copyFrom(vectors[index]);\r\n }\r\n // Extend\r\n this.extendSizeWorld.copyFrom(this.extendSize);\r\n this.centerWorld.copyFrom(this.center);\r\n }\r\n Vector3.FromArrayToRef(world.m, 0, directions[0]);\r\n Vector3.FromArrayToRef(world.m, 4, directions[1]);\r\n Vector3.FromArrayToRef(world.m, 8, directions[2]);\r\n this._worldMatrix = world;\r\n };\r\n /**\r\n * Tests if the bounding box is intersecting the frustum planes\r\n * @param frustumPlanes defines the frustum planes to test\r\n * @returns true if there is an intersection\r\n */\r\n BoundingBox.prototype.isInFrustum = function (frustumPlanes) {\r\n return BoundingBox.IsInFrustum(this.vectorsWorld, frustumPlanes);\r\n };\r\n /**\r\n * Tests if the bounding box is entirely inside the frustum planes\r\n * @param frustumPlanes defines the frustum planes to test\r\n * @returns true if there is an inclusion\r\n */\r\n BoundingBox.prototype.isCompletelyInFrustum = function (frustumPlanes) {\r\n return BoundingBox.IsCompletelyInFrustum(this.vectorsWorld, frustumPlanes);\r\n };\r\n /**\r\n * Tests if a point is inside the bounding box\r\n * @param point defines the point to test\r\n * @returns true if the point is inside the bounding box\r\n */\r\n BoundingBox.prototype.intersectsPoint = function (point) {\r\n var min = this.minimumWorld;\r\n var max = this.maximumWorld;\r\n var minX = min.x, minY = min.y, minZ = min.z, maxX = max.x, maxY = max.y, maxZ = max.z;\r\n var pointX = point.x, pointY = point.y, pointZ = point.z;\r\n var delta = -Epsilon;\r\n if (maxX - pointX < delta || delta > pointX - minX) {\r\n return false;\r\n }\r\n if (maxY - pointY < delta || delta > pointY - minY) {\r\n return false;\r\n }\r\n if (maxZ - pointZ < delta || delta > pointZ - minZ) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n /**\r\n * Tests if the bounding box intersects with a bounding sphere\r\n * @param sphere defines the sphere to test\r\n * @returns true if there is an intersection\r\n */\r\n BoundingBox.prototype.intersectsSphere = function (sphere) {\r\n return BoundingBox.IntersectsSphere(this.minimumWorld, this.maximumWorld, sphere.centerWorld, sphere.radiusWorld);\r\n };\r\n /**\r\n * Tests if the bounding box intersects with a box defined by a min and max vectors\r\n * @param min defines the min vector to use\r\n * @param max defines the max vector to use\r\n * @returns true if there is an intersection\r\n */\r\n BoundingBox.prototype.intersectsMinMax = function (min, max) {\r\n var myMin = this.minimumWorld;\r\n var myMax = this.maximumWorld;\r\n var myMinX = myMin.x, myMinY = myMin.y, myMinZ = myMin.z, myMaxX = myMax.x, myMaxY = myMax.y, myMaxZ = myMax.z;\r\n var minX = min.x, minY = min.y, minZ = min.z, maxX = max.x, maxY = max.y, maxZ = max.z;\r\n if (myMaxX < minX || myMinX > maxX) {\r\n return false;\r\n }\r\n if (myMaxY < minY || myMinY > maxY) {\r\n return false;\r\n }\r\n if (myMaxZ < minZ || myMinZ > maxZ) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n // Statics\r\n /**\r\n * Tests if two bounding boxes are intersections\r\n * @param box0 defines the first box to test\r\n * @param box1 defines the second box to test\r\n * @returns true if there is an intersection\r\n */\r\n BoundingBox.Intersects = function (box0, box1) {\r\n return box0.intersectsMinMax(box1.minimumWorld, box1.maximumWorld);\r\n };\r\n /**\r\n * Tests if a bounding box defines by a min/max vectors intersects a sphere\r\n * @param minPoint defines the minimum vector of the bounding box\r\n * @param maxPoint defines the maximum vector of the bounding box\r\n * @param sphereCenter defines the sphere center\r\n * @param sphereRadius defines the sphere radius\r\n * @returns true if there is an intersection\r\n */\r\n BoundingBox.IntersectsSphere = function (minPoint, maxPoint, sphereCenter, sphereRadius) {\r\n var vector = BoundingBox.TmpVector3[0];\r\n Vector3.ClampToRef(sphereCenter, minPoint, maxPoint, vector);\r\n var num = Vector3.DistanceSquared(sphereCenter, vector);\r\n return (num <= (sphereRadius * sphereRadius));\r\n };\r\n /**\r\n * Tests if a bounding box defined with 8 vectors is entirely inside frustum planes\r\n * @param boundingVectors defines an array of 8 vectors representing a bounding box\r\n * @param frustumPlanes defines the frustum planes to test\r\n * @return true if there is an inclusion\r\n */\r\n BoundingBox.IsCompletelyInFrustum = function (boundingVectors, frustumPlanes) {\r\n for (var p = 0; p < 6; ++p) {\r\n var frustumPlane = frustumPlanes[p];\r\n for (var i = 0; i < 8; ++i) {\r\n if (frustumPlane.dotCoordinate(boundingVectors[i]) < 0) {\r\n return false;\r\n }\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Tests if a bounding box defined with 8 vectors intersects frustum planes\r\n * @param boundingVectors defines an array of 8 vectors representing a bounding box\r\n * @param frustumPlanes defines the frustum planes to test\r\n * @return true if there is an intersection\r\n */\r\n BoundingBox.IsInFrustum = function (boundingVectors, frustumPlanes) {\r\n for (var p = 0; p < 6; ++p) {\r\n var canReturnFalse = true;\r\n var frustumPlane = frustumPlanes[p];\r\n for (var i = 0; i < 8; ++i) {\r\n if (frustumPlane.dotCoordinate(boundingVectors[i]) >= 0) {\r\n canReturnFalse = false;\r\n break;\r\n }\r\n }\r\n if (canReturnFalse) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n BoundingBox.TmpVector3 = ArrayTools.BuildArray(3, Vector3.Zero);\r\n return BoundingBox;\r\n}());\r\nexport { BoundingBox };\r\n//# sourceMappingURL=boundingBox.js.map","import { ArrayTools } from \"../Misc/arrayTools\";\r\nimport { Matrix, Vector3 } from \"../Maths/math.vector\";\r\n/**\r\n * Class used to store bounding sphere information\r\n */\r\nvar BoundingSphere = /** @class */ (function () {\r\n /**\r\n * Creates a new bounding sphere\r\n * @param min defines the minimum vector (in local space)\r\n * @param max defines the maximum vector (in local space)\r\n * @param worldMatrix defines the new world matrix\r\n */\r\n function BoundingSphere(min, max, worldMatrix) {\r\n /**\r\n * Gets the center of the bounding sphere in local space\r\n */\r\n this.center = Vector3.Zero();\r\n /**\r\n * Gets the center of the bounding sphere in world space\r\n */\r\n this.centerWorld = Vector3.Zero();\r\n /**\r\n * Gets the minimum vector in local space\r\n */\r\n this.minimum = Vector3.Zero();\r\n /**\r\n * Gets the maximum vector in local space\r\n */\r\n this.maximum = Vector3.Zero();\r\n this.reConstruct(min, max, worldMatrix);\r\n }\r\n /**\r\n * Recreates the entire bounding sphere from scratch as if we call the constructor in place\r\n * @param min defines the new minimum vector (in local space)\r\n * @param max defines the new maximum vector (in local space)\r\n * @param worldMatrix defines the new world matrix\r\n */\r\n BoundingSphere.prototype.reConstruct = function (min, max, worldMatrix) {\r\n this.minimum.copyFrom(min);\r\n this.maximum.copyFrom(max);\r\n var distance = Vector3.Distance(min, max);\r\n max.addToRef(min, this.center).scaleInPlace(0.5);\r\n this.radius = distance * 0.5;\r\n this._update(worldMatrix || Matrix.IdentityReadOnly);\r\n };\r\n /**\r\n * Scale the current bounding sphere by applying a scale factor\r\n * @param factor defines the scale factor to apply\r\n * @returns the current bounding box\r\n */\r\n BoundingSphere.prototype.scale = function (factor) {\r\n var newRadius = this.radius * factor;\r\n var tmpVectors = BoundingSphere.TmpVector3;\r\n var tempRadiusVector = tmpVectors[0].setAll(newRadius);\r\n var min = this.center.subtractToRef(tempRadiusVector, tmpVectors[1]);\r\n var max = this.center.addToRef(tempRadiusVector, tmpVectors[2]);\r\n this.reConstruct(min, max, this._worldMatrix);\r\n return this;\r\n };\r\n /**\r\n * Gets the world matrix of the bounding box\r\n * @returns a matrix\r\n */\r\n BoundingSphere.prototype.getWorldMatrix = function () {\r\n return this._worldMatrix;\r\n };\r\n // Methods\r\n /** @hidden */\r\n BoundingSphere.prototype._update = function (worldMatrix) {\r\n if (!worldMatrix.isIdentity()) {\r\n Vector3.TransformCoordinatesToRef(this.center, worldMatrix, this.centerWorld);\r\n var tempVector = BoundingSphere.TmpVector3[0];\r\n Vector3.TransformNormalFromFloatsToRef(1.0, 1.0, 1.0, worldMatrix, tempVector);\r\n this.radiusWorld = Math.max(Math.abs(tempVector.x), Math.abs(tempVector.y), Math.abs(tempVector.z)) * this.radius;\r\n }\r\n else {\r\n this.centerWorld.copyFrom(this.center);\r\n this.radiusWorld = this.radius;\r\n }\r\n };\r\n /**\r\n * Tests if the bounding sphere is intersecting the frustum planes\r\n * @param frustumPlanes defines the frustum planes to test\r\n * @returns true if there is an intersection\r\n */\r\n BoundingSphere.prototype.isInFrustum = function (frustumPlanes) {\r\n var center = this.centerWorld;\r\n var radius = this.radiusWorld;\r\n for (var i = 0; i < 6; i++) {\r\n if (frustumPlanes[i].dotCoordinate(center) <= -radius) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Tests if the bounding sphere center is in between the frustum planes.\r\n * Used for optimistic fast inclusion.\r\n * @param frustumPlanes defines the frustum planes to test\r\n * @returns true if the sphere center is in between the frustum planes\r\n */\r\n BoundingSphere.prototype.isCenterInFrustum = function (frustumPlanes) {\r\n var center = this.centerWorld;\r\n for (var i = 0; i < 6; i++) {\r\n if (frustumPlanes[i].dotCoordinate(center) < 0) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Tests if a point is inside the bounding sphere\r\n * @param point defines the point to test\r\n * @returns true if the point is inside the bounding sphere\r\n */\r\n BoundingSphere.prototype.intersectsPoint = function (point) {\r\n var squareDistance = Vector3.DistanceSquared(this.centerWorld, point);\r\n if (this.radiusWorld * this.radiusWorld < squareDistance) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n // Statics\r\n /**\r\n * Checks if two sphere intersct\r\n * @param sphere0 sphere 0\r\n * @param sphere1 sphere 1\r\n * @returns true if the speres intersect\r\n */\r\n BoundingSphere.Intersects = function (sphere0, sphere1) {\r\n var squareDistance = Vector3.DistanceSquared(sphere0.centerWorld, sphere1.centerWorld);\r\n var radiusSum = sphere0.radiusWorld + sphere1.radiusWorld;\r\n if (radiusSum * radiusSum < squareDistance) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n BoundingSphere.TmpVector3 = ArrayTools.BuildArray(3, Vector3.Zero);\r\n return BoundingSphere;\r\n}());\r\nexport { BoundingSphere };\r\n//# sourceMappingURL=boundingSphere.js.map","import { ArrayTools } from \"../Misc/arrayTools\";\r\nimport { Vector3 } from \"../Maths/math.vector\";\r\nimport { BoundingBox } from \"./boundingBox\";\r\nimport { BoundingSphere } from \"./boundingSphere\";\r\nvar _result0 = { min: 0, max: 0 };\r\nvar _result1 = { min: 0, max: 0 };\r\nvar computeBoxExtents = function (axis, box, result) {\r\n var p = Vector3.Dot(box.centerWorld, axis);\r\n var r0 = Math.abs(Vector3.Dot(box.directions[0], axis)) * box.extendSize.x;\r\n var r1 = Math.abs(Vector3.Dot(box.directions[1], axis)) * box.extendSize.y;\r\n var r2 = Math.abs(Vector3.Dot(box.directions[2], axis)) * box.extendSize.z;\r\n var r = r0 + r1 + r2;\r\n result.min = p - r;\r\n result.max = p + r;\r\n};\r\nvar axisOverlap = function (axis, box0, box1) {\r\n computeBoxExtents(axis, box0, _result0);\r\n computeBoxExtents(axis, box1, _result1);\r\n return !(_result0.min > _result1.max || _result1.min > _result0.max);\r\n};\r\n/**\r\n * Info for a bounding data of a mesh\r\n */\r\nvar BoundingInfo = /** @class */ (function () {\r\n /**\r\n * Constructs bounding info\r\n * @param minimum min vector of the bounding box/sphere\r\n * @param maximum max vector of the bounding box/sphere\r\n * @param worldMatrix defines the new world matrix\r\n */\r\n function BoundingInfo(minimum, maximum, worldMatrix) {\r\n this._isLocked = false;\r\n this.boundingBox = new BoundingBox(minimum, maximum, worldMatrix);\r\n this.boundingSphere = new BoundingSphere(minimum, maximum, worldMatrix);\r\n }\r\n /**\r\n * Recreates the entire bounding info from scratch as if we call the constructor in place\r\n * @param min defines the new minimum vector (in local space)\r\n * @param max defines the new maximum vector (in local space)\r\n * @param worldMatrix defines the new world matrix\r\n */\r\n BoundingInfo.prototype.reConstruct = function (min, max, worldMatrix) {\r\n this.boundingBox.reConstruct(min, max, worldMatrix);\r\n this.boundingSphere.reConstruct(min, max, worldMatrix);\r\n };\r\n Object.defineProperty(BoundingInfo.prototype, \"minimum\", {\r\n /**\r\n * min vector of the bounding box/sphere\r\n */\r\n get: function () {\r\n return this.boundingBox.minimum;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BoundingInfo.prototype, \"maximum\", {\r\n /**\r\n * max vector of the bounding box/sphere\r\n */\r\n get: function () {\r\n return this.boundingBox.maximum;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BoundingInfo.prototype, \"isLocked\", {\r\n /**\r\n * If the info is locked and won't be updated to avoid perf overhead\r\n */\r\n get: function () {\r\n return this._isLocked;\r\n },\r\n set: function (value) {\r\n this._isLocked = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n // Methods\r\n /**\r\n * Updates the bounding sphere and box\r\n * @param world world matrix to be used to update\r\n */\r\n BoundingInfo.prototype.update = function (world) {\r\n if (this._isLocked) {\r\n return;\r\n }\r\n this.boundingBox._update(world);\r\n this.boundingSphere._update(world);\r\n };\r\n /**\r\n * Recreate the bounding info to be centered around a specific point given a specific extend.\r\n * @param center New center of the bounding info\r\n * @param extend New extend of the bounding info\r\n * @returns the current bounding info\r\n */\r\n BoundingInfo.prototype.centerOn = function (center, extend) {\r\n var minimum = BoundingInfo.TmpVector3[0].copyFrom(center).subtractInPlace(extend);\r\n var maximum = BoundingInfo.TmpVector3[1].copyFrom(center).addInPlace(extend);\r\n this.boundingBox.reConstruct(minimum, maximum, this.boundingBox.getWorldMatrix());\r\n this.boundingSphere.reConstruct(minimum, maximum, this.boundingBox.getWorldMatrix());\r\n return this;\r\n };\r\n /**\r\n * Scale the current bounding info by applying a scale factor\r\n * @param factor defines the scale factor to apply\r\n * @returns the current bounding info\r\n */\r\n BoundingInfo.prototype.scale = function (factor) {\r\n this.boundingBox.scale(factor);\r\n this.boundingSphere.scale(factor);\r\n return this;\r\n };\r\n /**\r\n * Returns `true` if the bounding info is within the frustum defined by the passed array of planes.\r\n * @param frustumPlanes defines the frustum to test\r\n * @param strategy defines the strategy to use for the culling (default is BABYLON.AbstractMesh.CULLINGSTRATEGY_STANDARD)\r\n * @returns true if the bounding info is in the frustum planes\r\n */\r\n BoundingInfo.prototype.isInFrustum = function (frustumPlanes, strategy) {\r\n if (strategy === void 0) { strategy = 0; }\r\n var inclusionTest = (strategy === 2 || strategy === 3);\r\n if (inclusionTest) {\r\n if (this.boundingSphere.isCenterInFrustum(frustumPlanes)) {\r\n return true;\r\n }\r\n }\r\n if (!this.boundingSphere.isInFrustum(frustumPlanes)) {\r\n return false;\r\n }\r\n var bSphereOnlyTest = (strategy === 1 || strategy === 3);\r\n if (bSphereOnlyTest) {\r\n return true;\r\n }\r\n return this.boundingBox.isInFrustum(frustumPlanes);\r\n };\r\n Object.defineProperty(BoundingInfo.prototype, \"diagonalLength\", {\r\n /**\r\n * Gets the world distance between the min and max points of the bounding box\r\n */\r\n get: function () {\r\n var boundingBox = this.boundingBox;\r\n var diag = boundingBox.maximumWorld.subtractToRef(boundingBox.minimumWorld, BoundingInfo.TmpVector3[0]);\r\n return diag.length();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Checks if a cullable object (mesh...) is in the camera frustum\r\n * Unlike isInFrustum this cheks the full bounding box\r\n * @param frustumPlanes Camera near/planes\r\n * @returns true if the object is in frustum otherwise false\r\n */\r\n BoundingInfo.prototype.isCompletelyInFrustum = function (frustumPlanes) {\r\n return this.boundingBox.isCompletelyInFrustum(frustumPlanes);\r\n };\r\n /** @hidden */\r\n BoundingInfo.prototype._checkCollision = function (collider) {\r\n return collider._canDoCollision(this.boundingSphere.centerWorld, this.boundingSphere.radiusWorld, this.boundingBox.minimumWorld, this.boundingBox.maximumWorld);\r\n };\r\n /**\r\n * Checks if a point is inside the bounding box and bounding sphere or the mesh\r\n * @see https://doc.babylonjs.com/babylon101/intersect_collisions_-_mesh\r\n * @param point the point to check intersection with\r\n * @returns if the point intersects\r\n */\r\n BoundingInfo.prototype.intersectsPoint = function (point) {\r\n if (!this.boundingSphere.centerWorld) {\r\n return false;\r\n }\r\n if (!this.boundingSphere.intersectsPoint(point)) {\r\n return false;\r\n }\r\n if (!this.boundingBox.intersectsPoint(point)) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n /**\r\n * Checks if another bounding info intersects the bounding box and bounding sphere or the mesh\r\n * @see https://doc.babylonjs.com/babylon101/intersect_collisions_-_mesh\r\n * @param boundingInfo the bounding info to check intersection with\r\n * @param precise if the intersection should be done using OBB\r\n * @returns if the bounding info intersects\r\n */\r\n BoundingInfo.prototype.intersects = function (boundingInfo, precise) {\r\n if (!BoundingSphere.Intersects(this.boundingSphere, boundingInfo.boundingSphere)) {\r\n return false;\r\n }\r\n if (!BoundingBox.Intersects(this.boundingBox, boundingInfo.boundingBox)) {\r\n return false;\r\n }\r\n if (!precise) {\r\n return true;\r\n }\r\n var box0 = this.boundingBox;\r\n var box1 = boundingInfo.boundingBox;\r\n if (!axisOverlap(box0.directions[0], box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(box0.directions[1], box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(box0.directions[2], box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(box1.directions[0], box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(box1.directions[1], box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(box1.directions[2], box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[0], box1.directions[0]), box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[0], box1.directions[1]), box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[0], box1.directions[2]), box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[1], box1.directions[0]), box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[1], box1.directions[1]), box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[1], box1.directions[2]), box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[2], box1.directions[0]), box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[2], box1.directions[1]), box0, box1)) {\r\n return false;\r\n }\r\n if (!axisOverlap(Vector3.Cross(box0.directions[2], box1.directions[2]), box0, box1)) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n BoundingInfo.TmpVector3 = ArrayTools.BuildArray(2, Vector3.Zero);\r\n return BoundingInfo;\r\n}());\r\nexport { BoundingInfo };\r\n//# sourceMappingURL=boundingInfo.js.map","import { Observable } from \"../../Misc/observable\";\r\nimport { RenderTargetCreationOptions } from \"../../Materials/Textures/renderTargetCreationOptions\";\r\nimport { _DevTools } from '../../Misc/devTools';\r\n/**\r\n * Defines the source of the internal texture\r\n */\r\nexport var InternalTextureSource;\r\n(function (InternalTextureSource) {\r\n /**\r\n * The source of the texture data is unknown\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Unknown\"] = 0] = \"Unknown\";\r\n /**\r\n * Texture data comes from an URL\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Url\"] = 1] = \"Url\";\r\n /**\r\n * Texture data is only used for temporary storage\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Temp\"] = 2] = \"Temp\";\r\n /**\r\n * Texture data comes from raw data (ArrayBuffer)\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Raw\"] = 3] = \"Raw\";\r\n /**\r\n * Texture content is dynamic (video or dynamic texture)\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Dynamic\"] = 4] = \"Dynamic\";\r\n /**\r\n * Texture content is generated by rendering to it\r\n */\r\n InternalTextureSource[InternalTextureSource[\"RenderTarget\"] = 5] = \"RenderTarget\";\r\n /**\r\n * Texture content is part of a multi render target process\r\n */\r\n InternalTextureSource[InternalTextureSource[\"MultiRenderTarget\"] = 6] = \"MultiRenderTarget\";\r\n /**\r\n * Texture data comes from a cube data file\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Cube\"] = 7] = \"Cube\";\r\n /**\r\n * Texture data comes from a raw cube data\r\n */\r\n InternalTextureSource[InternalTextureSource[\"CubeRaw\"] = 8] = \"CubeRaw\";\r\n /**\r\n * Texture data come from a prefiltered cube data file\r\n */\r\n InternalTextureSource[InternalTextureSource[\"CubePrefiltered\"] = 9] = \"CubePrefiltered\";\r\n /**\r\n * Texture content is raw 3D data\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Raw3D\"] = 10] = \"Raw3D\";\r\n /**\r\n * Texture content is raw 2D array data\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Raw2DArray\"] = 11] = \"Raw2DArray\";\r\n /**\r\n * Texture content is a depth texture\r\n */\r\n InternalTextureSource[InternalTextureSource[\"Depth\"] = 12] = \"Depth\";\r\n /**\r\n * Texture data comes from a raw cube data encoded with RGBD\r\n */\r\n InternalTextureSource[InternalTextureSource[\"CubeRawRGBD\"] = 13] = \"CubeRawRGBD\";\r\n})(InternalTextureSource || (InternalTextureSource = {}));\r\n/**\r\n * Class used to store data associated with WebGL texture data for the engine\r\n * This class should not be used directly\r\n */\r\nvar InternalTexture = /** @class */ (function () {\r\n /**\r\n * Creates a new InternalTexture\r\n * @param engine defines the engine to use\r\n * @param source defines the type of data that will be used\r\n * @param delayAllocation if the texture allocation should be delayed (default: false)\r\n */\r\n function InternalTexture(engine, source, delayAllocation) {\r\n if (delayAllocation === void 0) { delayAllocation = false; }\r\n /**\r\n * Defines if the texture is ready\r\n */\r\n this.isReady = false;\r\n /**\r\n * Defines if the texture is a cube texture\r\n */\r\n this.isCube = false;\r\n /**\r\n * Defines if the texture contains 3D data\r\n */\r\n this.is3D = false;\r\n /**\r\n * Defines if the texture contains 2D array data\r\n */\r\n this.is2DArray = false;\r\n /**\r\n * Defines if the texture contains multiview data\r\n */\r\n this.isMultiview = false;\r\n /**\r\n * Gets the URL used to load this texture\r\n */\r\n this.url = \"\";\r\n /**\r\n * Gets the sampling mode of the texture\r\n */\r\n this.samplingMode = -1;\r\n /**\r\n * Gets a boolean indicating if the texture needs mipmaps generation\r\n */\r\n this.generateMipMaps = false;\r\n /**\r\n * Gets the number of samples used by the texture (WebGL2+ only)\r\n */\r\n this.samples = 0;\r\n /**\r\n * Gets the type of the texture (int, float...)\r\n */\r\n this.type = -1;\r\n /**\r\n * Gets the format of the texture (RGB, RGBA...)\r\n */\r\n this.format = -1;\r\n /**\r\n * Observable called when the texture is loaded\r\n */\r\n this.onLoadedObservable = new Observable();\r\n /**\r\n * Gets the width of the texture\r\n */\r\n this.width = 0;\r\n /**\r\n * Gets the height of the texture\r\n */\r\n this.height = 0;\r\n /**\r\n * Gets the depth of the texture\r\n */\r\n this.depth = 0;\r\n /**\r\n * Gets the initial width of the texture (It could be rescaled if the current system does not support non power of two textures)\r\n */\r\n this.baseWidth = 0;\r\n /**\r\n * Gets the initial height of the texture (It could be rescaled if the current system does not support non power of two textures)\r\n */\r\n this.baseHeight = 0;\r\n /**\r\n * Gets the initial depth of the texture (It could be rescaled if the current system does not support non power of two textures)\r\n */\r\n this.baseDepth = 0;\r\n /**\r\n * Gets a boolean indicating if the texture is inverted on Y axis\r\n */\r\n this.invertY = false;\r\n // Private\r\n /** @hidden */\r\n this._invertVScale = false;\r\n /** @hidden */\r\n this._associatedChannel = -1;\r\n /** @hidden */\r\n this._source = InternalTextureSource.Unknown;\r\n /** @hidden */\r\n this._buffer = null;\r\n /** @hidden */\r\n this._bufferView = null;\r\n /** @hidden */\r\n this._bufferViewArray = null;\r\n /** @hidden */\r\n this._bufferViewArrayArray = null;\r\n /** @hidden */\r\n this._size = 0;\r\n /** @hidden */\r\n this._extension = \"\";\r\n /** @hidden */\r\n this._files = null;\r\n /** @hidden */\r\n this._workingCanvas = null;\r\n /** @hidden */\r\n this._workingContext = null;\r\n /** @hidden */\r\n this._framebuffer = null;\r\n /** @hidden */\r\n this._depthStencilBuffer = null;\r\n /** @hidden */\r\n this._MSAAFramebuffer = null;\r\n /** @hidden */\r\n this._MSAARenderBuffer = null;\r\n /** @hidden */\r\n this._attachments = null;\r\n /** @hidden */\r\n this._textureArray = null;\r\n /** @hidden */\r\n this._cachedCoordinatesMode = null;\r\n /** @hidden */\r\n this._cachedWrapU = null;\r\n /** @hidden */\r\n this._cachedWrapV = null;\r\n /** @hidden */\r\n this._cachedWrapR = null;\r\n /** @hidden */\r\n this._cachedAnisotropicFilteringLevel = null;\r\n /** @hidden */\r\n this._isDisabled = false;\r\n /** @hidden */\r\n this._compression = null;\r\n /** @hidden */\r\n this._generateStencilBuffer = false;\r\n /** @hidden */\r\n this._generateDepthBuffer = false;\r\n /** @hidden */\r\n this._comparisonFunction = 0;\r\n /** @hidden */\r\n this._sphericalPolynomial = null;\r\n /** @hidden */\r\n this._lodGenerationScale = 0;\r\n /** @hidden */\r\n this._lodGenerationOffset = 0;\r\n // Multiview\r\n /** @hidden */\r\n this._colorTextureArray = null;\r\n /** @hidden */\r\n this._depthStencilTextureArray = null;\r\n // The following three fields helps sharing generated fixed LODs for texture filtering\r\n // In environment not supporting the textureLOD extension like EDGE. They are for internal use only.\r\n // They are at the level of the gl texture to benefit from the cache.\r\n /** @hidden */\r\n this._lodTextureHigh = null;\r\n /** @hidden */\r\n this._lodTextureMid = null;\r\n /** @hidden */\r\n this._lodTextureLow = null;\r\n /** @hidden */\r\n this._isRGBD = false;\r\n /** @hidden */\r\n this._linearSpecularLOD = false;\r\n /** @hidden */\r\n this._irradianceTexture = null;\r\n /** @hidden */\r\n this._webGLTexture = null;\r\n /** @hidden */\r\n this._references = 1;\r\n /** @hidden */\r\n this._gammaSpace = null;\r\n this._engine = engine;\r\n this._source = source;\r\n if (!delayAllocation) {\r\n this._webGLTexture = engine._createTexture();\r\n }\r\n }\r\n /**\r\n * Gets the Engine the texture belongs to.\r\n * @returns The babylon engine\r\n */\r\n InternalTexture.prototype.getEngine = function () {\r\n return this._engine;\r\n };\r\n Object.defineProperty(InternalTexture.prototype, \"source\", {\r\n /**\r\n * Gets the data source type of the texture\r\n */\r\n get: function () {\r\n return this._source;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Increments the number of references (ie. the number of Texture that point to it)\r\n */\r\n InternalTexture.prototype.incrementReferences = function () {\r\n this._references++;\r\n };\r\n /**\r\n * Change the size of the texture (not the size of the content)\r\n * @param width defines the new width\r\n * @param height defines the new height\r\n * @param depth defines the new depth (1 by default)\r\n */\r\n InternalTexture.prototype.updateSize = function (width, height, depth) {\r\n if (depth === void 0) { depth = 1; }\r\n this.width = width;\r\n this.height = height;\r\n this.depth = depth;\r\n this.baseWidth = width;\r\n this.baseHeight = height;\r\n this.baseDepth = depth;\r\n this._size = width * height * depth;\r\n };\r\n /** @hidden */\r\n InternalTexture.prototype._rebuild = function () {\r\n var _this = this;\r\n var _a;\r\n var proxy;\r\n this.isReady = false;\r\n this._cachedCoordinatesMode = null;\r\n this._cachedWrapU = null;\r\n this._cachedWrapV = null;\r\n this._cachedAnisotropicFilteringLevel = null;\r\n switch (this.source) {\r\n case InternalTextureSource.Temp:\r\n return;\r\n case InternalTextureSource.Url:\r\n proxy = this._engine.createTexture((_a = this._originalUrl) !== null && _a !== void 0 ? _a : this.url, !this.generateMipMaps, this.invertY, null, this.samplingMode, function () {\r\n proxy._swapAndDie(_this);\r\n _this.isReady = true;\r\n }, null, this._buffer, undefined, this.format);\r\n return;\r\n case InternalTextureSource.Raw:\r\n proxy = this._engine.createRawTexture(this._bufferView, this.baseWidth, this.baseHeight, this.format, this.generateMipMaps, this.invertY, this.samplingMode, this._compression);\r\n proxy._swapAndDie(this);\r\n this.isReady = true;\r\n return;\r\n case InternalTextureSource.Raw3D:\r\n proxy = this._engine.createRawTexture3D(this._bufferView, this.baseWidth, this.baseHeight, this.baseDepth, this.format, this.generateMipMaps, this.invertY, this.samplingMode, this._compression);\r\n proxy._swapAndDie(this);\r\n this.isReady = true;\r\n return;\r\n case InternalTextureSource.Raw2DArray:\r\n proxy = this._engine.createRawTexture2DArray(this._bufferView, this.baseWidth, this.baseHeight, this.baseDepth, this.format, this.generateMipMaps, this.invertY, this.samplingMode, this._compression);\r\n proxy._swapAndDie(this);\r\n this.isReady = true;\r\n return;\r\n case InternalTextureSource.Dynamic:\r\n proxy = this._engine.createDynamicTexture(this.baseWidth, this.baseHeight, this.generateMipMaps, this.samplingMode);\r\n proxy._swapAndDie(this);\r\n this._engine.updateDynamicTexture(this, this._engine.getRenderingCanvas(), this.invertY, undefined, undefined, true);\r\n // The engine will make sure to update content so no need to flag it as isReady = true\r\n return;\r\n case InternalTextureSource.RenderTarget:\r\n var options = new RenderTargetCreationOptions();\r\n options.generateDepthBuffer = this._generateDepthBuffer;\r\n options.generateMipMaps = this.generateMipMaps;\r\n options.generateStencilBuffer = this._generateStencilBuffer;\r\n options.samplingMode = this.samplingMode;\r\n options.type = this.type;\r\n if (this.isCube) {\r\n proxy = this._engine.createRenderTargetCubeTexture(this.width, options);\r\n }\r\n else {\r\n var size_1 = {\r\n width: this.width,\r\n height: this.height,\r\n layers: this.is2DArray ? this.depth : undefined\r\n };\r\n proxy = this._engine.createRenderTargetTexture(size_1, options);\r\n }\r\n proxy._swapAndDie(this);\r\n this.isReady = true;\r\n return;\r\n case InternalTextureSource.Depth:\r\n var depthTextureOptions = {\r\n bilinearFiltering: this.samplingMode !== 2,\r\n comparisonFunction: this._comparisonFunction,\r\n generateStencil: this._generateStencilBuffer,\r\n isCube: this.isCube\r\n };\r\n var size = {\r\n width: this.width,\r\n height: this.height,\r\n layers: this.is2DArray ? this.depth : undefined\r\n };\r\n proxy = this._engine.createDepthStencilTexture(size, depthTextureOptions);\r\n proxy._swapAndDie(this);\r\n this.isReady = true;\r\n return;\r\n case InternalTextureSource.Cube:\r\n proxy = this._engine.createCubeTexture(this.url, null, this._files, !this.generateMipMaps, function () {\r\n proxy._swapAndDie(_this);\r\n _this.isReady = true;\r\n }, null, this.format, this._extension);\r\n return;\r\n case InternalTextureSource.CubeRaw:\r\n proxy = this._engine.createRawCubeTexture(this._bufferViewArray, this.width, this.format, this.type, this.generateMipMaps, this.invertY, this.samplingMode, this._compression);\r\n proxy._swapAndDie(this);\r\n this.isReady = true;\r\n return;\r\n case InternalTextureSource.CubeRawRGBD:\r\n proxy = this._engine.createRawCubeTexture(null, this.width, this.format, this.type, this.generateMipMaps, this.invertY, this.samplingMode, this._compression);\r\n InternalTexture._UpdateRGBDAsync(proxy, this._bufferViewArrayArray, this._sphericalPolynomial, this._lodGenerationScale, this._lodGenerationOffset).then(function () {\r\n proxy._swapAndDie(_this);\r\n _this.isReady = true;\r\n });\r\n return;\r\n case InternalTextureSource.CubePrefiltered:\r\n proxy = this._engine.createPrefilteredCubeTexture(this.url, null, this._lodGenerationScale, this._lodGenerationOffset, function (proxy) {\r\n if (proxy) {\r\n proxy._swapAndDie(_this);\r\n }\r\n _this.isReady = true;\r\n }, null, this.format, this._extension);\r\n proxy._sphericalPolynomial = this._sphericalPolynomial;\r\n return;\r\n }\r\n };\r\n /** @hidden */\r\n InternalTexture.prototype._swapAndDie = function (target) {\r\n target._webGLTexture = this._webGLTexture;\r\n target._isRGBD = this._isRGBD;\r\n if (this._framebuffer) {\r\n target._framebuffer = this._framebuffer;\r\n }\r\n if (this._depthStencilBuffer) {\r\n target._depthStencilBuffer = this._depthStencilBuffer;\r\n }\r\n target._depthStencilTexture = this._depthStencilTexture;\r\n if (this._lodTextureHigh) {\r\n if (target._lodTextureHigh) {\r\n target._lodTextureHigh.dispose();\r\n }\r\n target._lodTextureHigh = this._lodTextureHigh;\r\n }\r\n if (this._lodTextureMid) {\r\n if (target._lodTextureMid) {\r\n target._lodTextureMid.dispose();\r\n }\r\n target._lodTextureMid = this._lodTextureMid;\r\n }\r\n if (this._lodTextureLow) {\r\n if (target._lodTextureLow) {\r\n target._lodTextureLow.dispose();\r\n }\r\n target._lodTextureLow = this._lodTextureLow;\r\n }\r\n if (this._irradianceTexture) {\r\n if (target._irradianceTexture) {\r\n target._irradianceTexture.dispose();\r\n }\r\n target._irradianceTexture = this._irradianceTexture;\r\n }\r\n var cache = this._engine.getLoadedTexturesCache();\r\n var index = cache.indexOf(this);\r\n if (index !== -1) {\r\n cache.splice(index, 1);\r\n }\r\n var index = cache.indexOf(target);\r\n if (index === -1) {\r\n cache.push(target);\r\n }\r\n };\r\n /**\r\n * Dispose the current allocated resources\r\n */\r\n InternalTexture.prototype.dispose = function () {\r\n if (!this._webGLTexture) {\r\n return;\r\n }\r\n this._references--;\r\n if (this._references === 0) {\r\n this._engine._releaseTexture(this);\r\n this._webGLTexture = null;\r\n }\r\n };\r\n /** @hidden */\r\n InternalTexture._UpdateRGBDAsync = function (internalTexture, data, sphericalPolynomial, lodScale, lodOffset) {\r\n throw _DevTools.WarnImport(\"environmentTextureTools\");\r\n };\r\n return InternalTexture;\r\n}());\r\nexport { InternalTexture };\r\n//# sourceMappingURL=internalTexture.js.map","/**\r\n * Helper to manipulate strings\r\n */\r\nvar StringTools = /** @class */ (function () {\r\n function StringTools() {\r\n }\r\n /**\r\n * Checks for a matching suffix at the end of a string (for ES5 and lower)\r\n * @param str Source string\r\n * @param suffix Suffix to search for in the source string\r\n * @returns Boolean indicating whether the suffix was found (true) or not (false)\r\n */\r\n StringTools.EndsWith = function (str, suffix) {\r\n return str.indexOf(suffix, str.length - suffix.length) !== -1;\r\n };\r\n /**\r\n * Checks for a matching suffix at the beginning of a string (for ES5 and lower)\r\n * @param str Source string\r\n * @param suffix Suffix to search for in the source string\r\n * @returns Boolean indicating whether the suffix was found (true) or not (false)\r\n */\r\n StringTools.StartsWith = function (str, suffix) {\r\n if (!str) {\r\n return false;\r\n }\r\n return str.indexOf(suffix) === 0;\r\n };\r\n /**\r\n * Decodes a buffer into a string\r\n * @param buffer The buffer to decode\r\n * @returns The decoded string\r\n */\r\n StringTools.Decode = function (buffer) {\r\n if (typeof TextDecoder !== \"undefined\") {\r\n return new TextDecoder().decode(buffer);\r\n }\r\n var result = \"\";\r\n for (var i = 0; i < buffer.byteLength; i++) {\r\n result += String.fromCharCode(buffer[i]);\r\n }\r\n return result;\r\n };\r\n /**\r\n * Encode a buffer to a base64 string\r\n * @param buffer defines the buffer to encode\r\n * @returns the encoded string\r\n */\r\n StringTools.EncodeArrayBufferToBase64 = function (buffer) {\r\n var keyStr = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\";\r\n var output = \"\";\r\n var chr1, chr2, chr3, enc1, enc2, enc3, enc4;\r\n var i = 0;\r\n var bytes = ArrayBuffer.isView(buffer) ? new Uint8Array(buffer.buffer, buffer.byteOffset, buffer.byteLength) : new Uint8Array(buffer);\r\n while (i < bytes.length) {\r\n chr1 = bytes[i++];\r\n chr2 = i < bytes.length ? bytes[i++] : Number.NaN;\r\n chr3 = i < bytes.length ? bytes[i++] : Number.NaN;\r\n enc1 = chr1 >> 2;\r\n enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);\r\n enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);\r\n enc4 = chr3 & 63;\r\n if (isNaN(chr2)) {\r\n enc3 = enc4 = 64;\r\n }\r\n else if (isNaN(chr3)) {\r\n enc4 = 64;\r\n }\r\n output += keyStr.charAt(enc1) + keyStr.charAt(enc2) +\r\n keyStr.charAt(enc3) + keyStr.charAt(enc4);\r\n }\r\n return output;\r\n };\r\n /**\r\n * Converts a number to string and pads with preceeding zeroes until it is of specified length.\r\n * @param num the number to convert and pad\r\n * @param length the expected length of the string\r\n * @returns the padded string\r\n */\r\n StringTools.PadNumber = function (num, length) {\r\n var str = String(num);\r\n while (str.length < length) {\r\n str = \"0\" + str;\r\n }\r\n return str;\r\n };\r\n return StringTools;\r\n}());\r\nexport { StringTools };\r\n//# sourceMappingURL=stringTools.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, serializeAsVector3, serializeAsQuaternion, SerializationHelper } from \"../Misc/decorators\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { Quaternion, Matrix, Vector3, TmpVectors } from \"../Maths/math.vector\";\r\nimport { Node } from \"../node\";\r\nimport { Space } from '../Maths/math.axis';\r\n/**\r\n * A TransformNode is an object that is not rendered but can be used as a center of transformation. This can decrease memory usage and increase rendering speed compared to using an empty mesh as a parent and is less complicated than using a pivot matrix.\r\n * @see https://doc.babylonjs.com/how_to/transformnode\r\n */\r\nvar TransformNode = /** @class */ (function (_super) {\r\n __extends(TransformNode, _super);\r\n function TransformNode(name, scene, isPure) {\r\n if (scene === void 0) { scene = null; }\r\n if (isPure === void 0) { isPure = true; }\r\n var _this = _super.call(this, name, scene) || this;\r\n _this._forward = new Vector3(0, 0, 1);\r\n _this._forwardInverted = new Vector3(0, 0, -1);\r\n _this._up = new Vector3(0, 1, 0);\r\n _this._right = new Vector3(1, 0, 0);\r\n _this._rightInverted = new Vector3(-1, 0, 0);\r\n // Properties\r\n _this._position = Vector3.Zero();\r\n _this._rotation = Vector3.Zero();\r\n _this._rotationQuaternion = null;\r\n _this._scaling = Vector3.One();\r\n _this._isDirty = false;\r\n _this._transformToBoneReferal = null;\r\n _this._isAbsoluteSynced = false;\r\n _this._billboardMode = TransformNode.BILLBOARDMODE_NONE;\r\n _this._preserveParentRotationForBillboard = false;\r\n /**\r\n * Multiplication factor on scale x/y/z when computing the world matrix. Eg. for a 1x1x1 cube setting this to 2 will make it a 2x2x2 cube\r\n */\r\n _this.scalingDeterminant = 1;\r\n _this._infiniteDistance = false;\r\n /**\r\n * Gets or sets a boolean indicating that non uniform scaling (when at least one component is different from others) should be ignored.\r\n * By default the system will update normals to compensate\r\n */\r\n _this.ignoreNonUniformScaling = false;\r\n /**\r\n * Gets or sets a boolean indicating that even if rotationQuaternion is defined, you can keep updating rotation property and Babylon.js will just mix both\r\n */\r\n _this.reIntegrateRotationIntoRotationQuaternion = false;\r\n // Cache\r\n /** @hidden */\r\n _this._poseMatrix = null;\r\n /** @hidden */\r\n _this._localMatrix = Matrix.Zero();\r\n _this._usePivotMatrix = false;\r\n _this._absolutePosition = Vector3.Zero();\r\n _this._absoluteScaling = Vector3.Zero();\r\n _this._absoluteRotationQuaternion = Quaternion.Identity();\r\n _this._pivotMatrix = Matrix.Identity();\r\n /** @hidden */\r\n _this._postMultiplyPivotMatrix = false;\r\n _this._isWorldMatrixFrozen = false;\r\n /** @hidden */\r\n _this._indexInSceneTransformNodesArray = -1;\r\n /**\r\n * An event triggered after the world matrix is updated\r\n */\r\n _this.onAfterWorldMatrixUpdateObservable = new Observable();\r\n _this._nonUniformScaling = false;\r\n if (isPure) {\r\n _this.getScene().addTransformNode(_this);\r\n }\r\n return _this;\r\n }\r\n Object.defineProperty(TransformNode.prototype, \"billboardMode\", {\r\n /**\r\n * Gets or sets the billboard mode. Default is 0.\r\n *\r\n * | Value | Type | Description |\r\n * | --- | --- | --- |\r\n * | 0 | BILLBOARDMODE_NONE | |\r\n * | 1 | BILLBOARDMODE_X | |\r\n * | 2 | BILLBOARDMODE_Y | |\r\n * | 4 | BILLBOARDMODE_Z | |\r\n * | 7 | BILLBOARDMODE_ALL | |\r\n *\r\n */\r\n get: function () {\r\n return this._billboardMode;\r\n },\r\n set: function (value) {\r\n if (this._billboardMode === value) {\r\n return;\r\n }\r\n this._billboardMode = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"preserveParentRotationForBillboard\", {\r\n /**\r\n * Gets or sets a boolean indicating that parent rotation should be preserved when using billboards.\r\n * This could be useful for glTF objects where parent rotation helps converting from right handed to left handed\r\n */\r\n get: function () {\r\n return this._preserveParentRotationForBillboard;\r\n },\r\n set: function (value) {\r\n if (value === this._preserveParentRotationForBillboard) {\r\n return;\r\n }\r\n this._preserveParentRotationForBillboard = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"infiniteDistance\", {\r\n /**\r\n * Gets or sets the distance of the object to max, often used by skybox\r\n */\r\n get: function () {\r\n return this._infiniteDistance;\r\n },\r\n set: function (value) {\r\n if (this._infiniteDistance === value) {\r\n return;\r\n }\r\n this._infiniteDistance = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets a string identifying the name of the class\r\n * @returns \"TransformNode\" string\r\n */\r\n TransformNode.prototype.getClassName = function () {\r\n return \"TransformNode\";\r\n };\r\n Object.defineProperty(TransformNode.prototype, \"position\", {\r\n /**\r\n * Gets or set the node position (default is (0.0, 0.0, 0.0))\r\n */\r\n get: function () {\r\n return this._position;\r\n },\r\n set: function (newPosition) {\r\n this._position = newPosition;\r\n this._isDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"rotation\", {\r\n /**\r\n * Gets or sets the rotation property : a Vector3 defining the rotation value in radians around each local axis X, Y, Z (default is (0.0, 0.0, 0.0)).\r\n * If rotation quaternion is set, this Vector3 will be ignored and copy from the quaternion\r\n */\r\n get: function () {\r\n return this._rotation;\r\n },\r\n set: function (newRotation) {\r\n this._rotation = newRotation;\r\n this._rotationQuaternion = null;\r\n this._isDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"scaling\", {\r\n /**\r\n * Gets or sets the scaling property : a Vector3 defining the node scaling along each local axis X, Y, Z (default is (0.0, 0.0, 0.0)).\r\n */\r\n get: function () {\r\n return this._scaling;\r\n },\r\n set: function (newScaling) {\r\n this._scaling = newScaling;\r\n this._isDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"rotationQuaternion\", {\r\n /**\r\n * Gets or sets the rotation Quaternion property : this a Quaternion object defining the node rotation by using a unit quaternion (undefined by default, but can be null).\r\n * If set, only the rotationQuaternion is then used to compute the node rotation (ie. node.rotation will be ignored)\r\n */\r\n get: function () {\r\n return this._rotationQuaternion;\r\n },\r\n set: function (quaternion) {\r\n this._rotationQuaternion = quaternion;\r\n //reset the rotation vector.\r\n if (quaternion) {\r\n this._rotation.setAll(0.0);\r\n }\r\n this._isDirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"forward\", {\r\n /**\r\n * The forward direction of that transform in world space.\r\n */\r\n get: function () {\r\n return Vector3.Normalize(Vector3.TransformNormal(this.getScene().useRightHandedSystem ? this._forwardInverted : this._forward, this.getWorldMatrix()));\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"up\", {\r\n /**\r\n * The up direction of that transform in world space.\r\n */\r\n get: function () {\r\n return Vector3.Normalize(Vector3.TransformNormal(this._up, this.getWorldMatrix()));\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"right\", {\r\n /**\r\n * The right direction of that transform in world space.\r\n */\r\n get: function () {\r\n return Vector3.Normalize(Vector3.TransformNormal(this.getScene().useRightHandedSystem ? this._rightInverted : this._right, this.getWorldMatrix()));\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Copies the parameter passed Matrix into the mesh Pose matrix.\r\n * @param matrix the matrix to copy the pose from\r\n * @returns this TransformNode.\r\n */\r\n TransformNode.prototype.updatePoseMatrix = function (matrix) {\r\n if (!this._poseMatrix) {\r\n this._poseMatrix = matrix.clone();\r\n return this;\r\n }\r\n this._poseMatrix.copyFrom(matrix);\r\n return this;\r\n };\r\n /**\r\n * Returns the mesh Pose matrix.\r\n * @returns the pose matrix\r\n */\r\n TransformNode.prototype.getPoseMatrix = function () {\r\n if (!this._poseMatrix) {\r\n this._poseMatrix = Matrix.Identity();\r\n }\r\n return this._poseMatrix;\r\n };\r\n /** @hidden */\r\n TransformNode.prototype._isSynchronized = function () {\r\n var cache = this._cache;\r\n if (this.billboardMode !== cache.billboardMode || this.billboardMode !== TransformNode.BILLBOARDMODE_NONE) {\r\n return false;\r\n }\r\n if (cache.pivotMatrixUpdated) {\r\n return false;\r\n }\r\n if (this.infiniteDistance) {\r\n return false;\r\n }\r\n if (this.position._isDirty) {\r\n return false;\r\n }\r\n if (this.scaling._isDirty) {\r\n return false;\r\n }\r\n if (this._rotationQuaternion && this._rotationQuaternion._isDirty || this.rotation._isDirty) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n /** @hidden */\r\n TransformNode.prototype._initCache = function () {\r\n _super.prototype._initCache.call(this);\r\n var cache = this._cache;\r\n cache.localMatrixUpdated = false;\r\n cache.billboardMode = -1;\r\n cache.infiniteDistance = false;\r\n };\r\n /**\r\n * Flag the transform node as dirty (Forcing it to update everything)\r\n * @param property if set to \"rotation\" the objects rotationQuaternion will be set to null\r\n * @returns this transform node\r\n */\r\n TransformNode.prototype.markAsDirty = function (property) {\r\n this._currentRenderId = Number.MAX_VALUE;\r\n this._isDirty = true;\r\n return this;\r\n };\r\n Object.defineProperty(TransformNode.prototype, \"absolutePosition\", {\r\n /**\r\n * Returns the current mesh absolute position.\r\n * Returns a Vector3.\r\n */\r\n get: function () {\r\n return this._absolutePosition;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"absoluteScaling\", {\r\n /**\r\n * Returns the current mesh absolute scaling.\r\n * Returns a Vector3.\r\n */\r\n get: function () {\r\n this._syncAbsoluteScalingAndRotation();\r\n return this._absoluteScaling;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TransformNode.prototype, \"absoluteRotationQuaternion\", {\r\n /**\r\n * Returns the current mesh absolute rotation.\r\n * Returns a Quaternion.\r\n */\r\n get: function () {\r\n this._syncAbsoluteScalingAndRotation();\r\n return this._absoluteRotationQuaternion;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Sets a new matrix to apply before all other transformation\r\n * @param matrix defines the transform matrix\r\n * @returns the current TransformNode\r\n */\r\n TransformNode.prototype.setPreTransformMatrix = function (matrix) {\r\n return this.setPivotMatrix(matrix, false);\r\n };\r\n /**\r\n * Sets a new pivot matrix to the current node\r\n * @param matrix defines the new pivot matrix to use\r\n * @param postMultiplyPivotMatrix defines if the pivot matrix must be cancelled in the world matrix. When this parameter is set to true (default), the inverse of the pivot matrix is also applied at the end to cancel the transformation effect\r\n * @returns the current TransformNode\r\n */\r\n TransformNode.prototype.setPivotMatrix = function (matrix, postMultiplyPivotMatrix) {\r\n if (postMultiplyPivotMatrix === void 0) { postMultiplyPivotMatrix = true; }\r\n this._pivotMatrix.copyFrom(matrix);\r\n this._usePivotMatrix = !this._pivotMatrix.isIdentity();\r\n this._cache.pivotMatrixUpdated = true;\r\n this._postMultiplyPivotMatrix = postMultiplyPivotMatrix;\r\n if (this._postMultiplyPivotMatrix) {\r\n if (!this._pivotMatrixInverse) {\r\n this._pivotMatrixInverse = Matrix.Invert(this._pivotMatrix);\r\n }\r\n else {\r\n this._pivotMatrix.invertToRef(this._pivotMatrixInverse);\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Returns the mesh pivot matrix.\r\n * Default : Identity.\r\n * @returns the matrix\r\n */\r\n TransformNode.prototype.getPivotMatrix = function () {\r\n return this._pivotMatrix;\r\n };\r\n /**\r\n * Instantiate (when possible) or clone that node with its hierarchy\r\n * @param newParent defines the new parent to use for the instance (or clone)\r\n * @param options defines options to configure how copy is done\r\n * @param onNewNodeCreated defines an option callback to call when a clone or an instance is created\r\n * @returns an instance (or a clone) of the current node with its hiearchy\r\n */\r\n TransformNode.prototype.instantiateHierarchy = function (newParent, options, onNewNodeCreated) {\r\n if (newParent === void 0) { newParent = null; }\r\n var clone = this.clone(\"Clone of \" + (this.name || this.id), newParent || this.parent, true);\r\n if (clone) {\r\n if (onNewNodeCreated) {\r\n onNewNodeCreated(this, clone);\r\n }\r\n }\r\n for (var _i = 0, _a = this.getChildTransformNodes(true); _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child.instantiateHierarchy(clone, options, onNewNodeCreated);\r\n }\r\n return clone;\r\n };\r\n /**\r\n * Prevents the World matrix to be computed any longer\r\n * @param newWorldMatrix defines an optional matrix to use as world matrix\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.freezeWorldMatrix = function (newWorldMatrix) {\r\n if (newWorldMatrix === void 0) { newWorldMatrix = null; }\r\n if (newWorldMatrix) {\r\n this._worldMatrix = newWorldMatrix;\r\n }\r\n else {\r\n this._isWorldMatrixFrozen = false; // no guarantee world is not already frozen, switch off temporarily\r\n this.computeWorldMatrix(true);\r\n }\r\n this._isDirty = false;\r\n this._isWorldMatrixFrozen = true;\r\n return this;\r\n };\r\n /**\r\n * Allows back the World matrix computation.\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.unfreezeWorldMatrix = function () {\r\n this._isWorldMatrixFrozen = false;\r\n this.computeWorldMatrix(true);\r\n return this;\r\n };\r\n Object.defineProperty(TransformNode.prototype, \"isWorldMatrixFrozen\", {\r\n /**\r\n * True if the World matrix has been frozen.\r\n */\r\n get: function () {\r\n return this._isWorldMatrixFrozen;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Retuns the mesh absolute position in the World.\r\n * @returns a Vector3.\r\n */\r\n TransformNode.prototype.getAbsolutePosition = function () {\r\n this.computeWorldMatrix();\r\n return this._absolutePosition;\r\n };\r\n /**\r\n * Sets the mesh absolute position in the World from a Vector3 or an Array(3).\r\n * @param absolutePosition the absolute position to set\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.setAbsolutePosition = function (absolutePosition) {\r\n if (!absolutePosition) {\r\n return this;\r\n }\r\n var absolutePositionX;\r\n var absolutePositionY;\r\n var absolutePositionZ;\r\n if (absolutePosition.x === undefined) {\r\n if (arguments.length < 3) {\r\n return this;\r\n }\r\n absolutePositionX = arguments[0];\r\n absolutePositionY = arguments[1];\r\n absolutePositionZ = arguments[2];\r\n }\r\n else {\r\n absolutePositionX = absolutePosition.x;\r\n absolutePositionY = absolutePosition.y;\r\n absolutePositionZ = absolutePosition.z;\r\n }\r\n if (this.parent) {\r\n var invertParentWorldMatrix = TmpVectors.Matrix[0];\r\n this.parent.getWorldMatrix().invertToRef(invertParentWorldMatrix);\r\n Vector3.TransformCoordinatesFromFloatsToRef(absolutePositionX, absolutePositionY, absolutePositionZ, invertParentWorldMatrix, this.position);\r\n }\r\n else {\r\n this.position.x = absolutePositionX;\r\n this.position.y = absolutePositionY;\r\n this.position.z = absolutePositionZ;\r\n }\r\n this._absolutePosition.copyFrom(absolutePosition);\r\n return this;\r\n };\r\n /**\r\n * Sets the mesh position in its local space.\r\n * @param vector3 the position to set in localspace\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.setPositionWithLocalVector = function (vector3) {\r\n this.computeWorldMatrix();\r\n this.position = Vector3.TransformNormal(vector3, this._localMatrix);\r\n return this;\r\n };\r\n /**\r\n * Returns the mesh position in the local space from the current World matrix values.\r\n * @returns a new Vector3.\r\n */\r\n TransformNode.prototype.getPositionExpressedInLocalSpace = function () {\r\n this.computeWorldMatrix();\r\n var invLocalWorldMatrix = TmpVectors.Matrix[0];\r\n this._localMatrix.invertToRef(invLocalWorldMatrix);\r\n return Vector3.TransformNormal(this.position, invLocalWorldMatrix);\r\n };\r\n /**\r\n * Translates the mesh along the passed Vector3 in its local space.\r\n * @param vector3 the distance to translate in localspace\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.locallyTranslate = function (vector3) {\r\n this.computeWorldMatrix(true);\r\n this.position = Vector3.TransformCoordinates(vector3, this._localMatrix);\r\n return this;\r\n };\r\n /**\r\n * Orients a mesh towards a target point. Mesh must be drawn facing user.\r\n * @param targetPoint the position (must be in same space as current mesh) to look at\r\n * @param yawCor optional yaw (y-axis) correction in radians\r\n * @param pitchCor optional pitch (x-axis) correction in radians\r\n * @param rollCor optional roll (z-axis) correction in radians\r\n * @param space the choosen space of the target\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.lookAt = function (targetPoint, yawCor, pitchCor, rollCor, space) {\r\n if (yawCor === void 0) { yawCor = 0; }\r\n if (pitchCor === void 0) { pitchCor = 0; }\r\n if (rollCor === void 0) { rollCor = 0; }\r\n if (space === void 0) { space = Space.LOCAL; }\r\n var dv = TransformNode._lookAtVectorCache;\r\n var pos = space === Space.LOCAL ? this.position : this.getAbsolutePosition();\r\n targetPoint.subtractToRef(pos, dv);\r\n this.setDirection(dv, yawCor, pitchCor, rollCor);\r\n // Correct for parent's rotation offset\r\n if (space === Space.WORLD && this.parent) {\r\n if (this.rotationQuaternion) {\r\n // Get local rotation matrix of the looking object\r\n var rotationMatrix = TmpVectors.Matrix[0];\r\n this.rotationQuaternion.toRotationMatrix(rotationMatrix);\r\n // Offset rotation by parent's inverted rotation matrix to correct in world space\r\n var parentRotationMatrix = TmpVectors.Matrix[1];\r\n this.parent.getWorldMatrix().getRotationMatrixToRef(parentRotationMatrix);\r\n parentRotationMatrix.invert();\r\n rotationMatrix.multiplyToRef(parentRotationMatrix, rotationMatrix);\r\n this.rotationQuaternion.fromRotationMatrix(rotationMatrix);\r\n }\r\n else {\r\n // Get local rotation matrix of the looking object\r\n var quaternionRotation = TmpVectors.Quaternion[0];\r\n Quaternion.FromEulerVectorToRef(this.rotation, quaternionRotation);\r\n var rotationMatrix = TmpVectors.Matrix[0];\r\n quaternionRotation.toRotationMatrix(rotationMatrix);\r\n // Offset rotation by parent's inverted rotation matrix to correct in world space\r\n var parentRotationMatrix = TmpVectors.Matrix[1];\r\n this.parent.getWorldMatrix().getRotationMatrixToRef(parentRotationMatrix);\r\n parentRotationMatrix.invert();\r\n rotationMatrix.multiplyToRef(parentRotationMatrix, rotationMatrix);\r\n quaternionRotation.fromRotationMatrix(rotationMatrix);\r\n quaternionRotation.toEulerAnglesToRef(this.rotation);\r\n }\r\n }\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector3 that is the localAxis, expressed in the mesh local space, rotated like the mesh.\r\n * This Vector3 is expressed in the World space.\r\n * @param localAxis axis to rotate\r\n * @returns a new Vector3 that is the localAxis, expressed in the mesh local space, rotated like the mesh.\r\n */\r\n TransformNode.prototype.getDirection = function (localAxis) {\r\n var result = Vector3.Zero();\r\n this.getDirectionToRef(localAxis, result);\r\n return result;\r\n };\r\n /**\r\n * Sets the Vector3 \"result\" as the rotated Vector3 \"localAxis\" in the same rotation than the mesh.\r\n * localAxis is expressed in the mesh local space.\r\n * result is computed in the Wordl space from the mesh World matrix.\r\n * @param localAxis axis to rotate\r\n * @param result the resulting transformnode\r\n * @returns this TransformNode.\r\n */\r\n TransformNode.prototype.getDirectionToRef = function (localAxis, result) {\r\n Vector3.TransformNormalToRef(localAxis, this.getWorldMatrix(), result);\r\n return this;\r\n };\r\n /**\r\n * Sets this transform node rotation to the given local axis.\r\n * @param localAxis the axis in local space\r\n * @param yawCor optional yaw (y-axis) correction in radians\r\n * @param pitchCor optional pitch (x-axis) correction in radians\r\n * @param rollCor optional roll (z-axis) correction in radians\r\n * @returns this TransformNode\r\n */\r\n TransformNode.prototype.setDirection = function (localAxis, yawCor, pitchCor, rollCor) {\r\n if (yawCor === void 0) { yawCor = 0; }\r\n if (pitchCor === void 0) { pitchCor = 0; }\r\n if (rollCor === void 0) { rollCor = 0; }\r\n var yaw = -Math.atan2(localAxis.z, localAxis.x) + Math.PI / 2;\r\n var len = Math.sqrt(localAxis.x * localAxis.x + localAxis.z * localAxis.z);\r\n var pitch = -Math.atan2(localAxis.y, len);\r\n if (this.rotationQuaternion) {\r\n Quaternion.RotationYawPitchRollToRef(yaw + yawCor, pitch + pitchCor, rollCor, this.rotationQuaternion);\r\n }\r\n else {\r\n this.rotation.x = pitch + pitchCor;\r\n this.rotation.y = yaw + yawCor;\r\n this.rotation.z = rollCor;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Sets a new pivot point to the current node\r\n * @param point defines the new pivot point to use\r\n * @param space defines if the point is in world or local space (local by default)\r\n * @returns the current TransformNode\r\n */\r\n TransformNode.prototype.setPivotPoint = function (point, space) {\r\n if (space === void 0) { space = Space.LOCAL; }\r\n if (this.getScene().getRenderId() == 0) {\r\n this.computeWorldMatrix(true);\r\n }\r\n var wm = this.getWorldMatrix();\r\n if (space == Space.WORLD) {\r\n var tmat = TmpVectors.Matrix[0];\r\n wm.invertToRef(tmat);\r\n point = Vector3.TransformCoordinates(point, tmat);\r\n }\r\n return this.setPivotMatrix(Matrix.Translation(-point.x, -point.y, -point.z), true);\r\n };\r\n /**\r\n * Returns a new Vector3 set with the mesh pivot point coordinates in the local space.\r\n * @returns the pivot point\r\n */\r\n TransformNode.prototype.getPivotPoint = function () {\r\n var point = Vector3.Zero();\r\n this.getPivotPointToRef(point);\r\n return point;\r\n };\r\n /**\r\n * Sets the passed Vector3 \"result\" with the coordinates of the mesh pivot point in the local space.\r\n * @param result the vector3 to store the result\r\n * @returns this TransformNode.\r\n */\r\n TransformNode.prototype.getPivotPointToRef = function (result) {\r\n result.x = -this._pivotMatrix.m[12];\r\n result.y = -this._pivotMatrix.m[13];\r\n result.z = -this._pivotMatrix.m[14];\r\n return this;\r\n };\r\n /**\r\n * Returns a new Vector3 set with the mesh pivot point World coordinates.\r\n * @returns a new Vector3 set with the mesh pivot point World coordinates.\r\n */\r\n TransformNode.prototype.getAbsolutePivotPoint = function () {\r\n var point = Vector3.Zero();\r\n this.getAbsolutePivotPointToRef(point);\r\n return point;\r\n };\r\n /**\r\n * Sets the Vector3 \"result\" coordinates with the mesh pivot point World coordinates.\r\n * @param result vector3 to store the result\r\n * @returns this TransformNode.\r\n */\r\n TransformNode.prototype.getAbsolutePivotPointToRef = function (result) {\r\n this.getPivotPointToRef(result);\r\n Vector3.TransformCoordinatesToRef(result, this.getWorldMatrix(), result);\r\n return this;\r\n };\r\n /**\r\n * Defines the passed node as the parent of the current node.\r\n * The node will remain exactly where it is and its position / rotation will be updated accordingly\r\n * @see https://doc.babylonjs.com/how_to/parenting\r\n * @param node the node ot set as the parent\r\n * @returns this TransformNode.\r\n */\r\n TransformNode.prototype.setParent = function (node) {\r\n if (!node && !this.parent) {\r\n return this;\r\n }\r\n var quatRotation = TmpVectors.Quaternion[0];\r\n var position = TmpVectors.Vector3[0];\r\n var scale = TmpVectors.Vector3[1];\r\n if (!node) {\r\n this.computeWorldMatrix(true);\r\n this.getWorldMatrix().decompose(scale, quatRotation, position);\r\n }\r\n else {\r\n var diffMatrix = TmpVectors.Matrix[0];\r\n var invParentMatrix = TmpVectors.Matrix[1];\r\n this.computeWorldMatrix(true);\r\n node.computeWorldMatrix(true);\r\n node.getWorldMatrix().invertToRef(invParentMatrix);\r\n this.getWorldMatrix().multiplyToRef(invParentMatrix, diffMatrix);\r\n diffMatrix.decompose(scale, quatRotation, position);\r\n }\r\n if (this.rotationQuaternion) {\r\n this.rotationQuaternion.copyFrom(quatRotation);\r\n }\r\n else {\r\n quatRotation.toEulerAnglesToRef(this.rotation);\r\n }\r\n this.scaling.copyFrom(scale);\r\n this.position.copyFrom(position);\r\n this.parent = node;\r\n return this;\r\n };\r\n Object.defineProperty(TransformNode.prototype, \"nonUniformScaling\", {\r\n /**\r\n * True if the scaling property of this object is non uniform eg. (1,2,1)\r\n */\r\n get: function () {\r\n return this._nonUniformScaling;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n TransformNode.prototype._updateNonUniformScalingState = function (value) {\r\n if (this._nonUniformScaling === value) {\r\n return false;\r\n }\r\n this._nonUniformScaling = value;\r\n return true;\r\n };\r\n /**\r\n * Attach the current TransformNode to another TransformNode associated with a bone\r\n * @param bone Bone affecting the TransformNode\r\n * @param affectedTransformNode TransformNode associated with the bone\r\n * @returns this object\r\n */\r\n TransformNode.prototype.attachToBone = function (bone, affectedTransformNode) {\r\n this._transformToBoneReferal = affectedTransformNode;\r\n this.parent = bone;\r\n bone.getSkeleton().prepare();\r\n if (bone.getWorldMatrix().determinant() < 0) {\r\n this.scalingDeterminant *= -1;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Detach the transform node if its associated with a bone\r\n * @returns this object\r\n */\r\n TransformNode.prototype.detachFromBone = function () {\r\n if (!this.parent) {\r\n return this;\r\n }\r\n if (this.parent.getWorldMatrix().determinant() < 0) {\r\n this.scalingDeterminant *= -1;\r\n }\r\n this._transformToBoneReferal = null;\r\n this.parent = null;\r\n return this;\r\n };\r\n /**\r\n * Rotates the mesh around the axis vector for the passed angle (amount) expressed in radians, in the given space.\r\n * space (default LOCAL) can be either Space.LOCAL, either Space.WORLD.\r\n * Note that the property `rotationQuaternion` is then automatically updated and the property `rotation` is set to (0,0,0) and no longer used.\r\n * The passed axis is also normalized.\r\n * @param axis the axis to rotate around\r\n * @param amount the amount to rotate in radians\r\n * @param space Space to rotate in (Default: local)\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.rotate = function (axis, amount, space) {\r\n axis.normalize();\r\n if (!this.rotationQuaternion) {\r\n this.rotationQuaternion = this.rotation.toQuaternion();\r\n this.rotation.setAll(0);\r\n }\r\n var rotationQuaternion;\r\n if (!space || space === Space.LOCAL) {\r\n rotationQuaternion = Quaternion.RotationAxisToRef(axis, amount, TransformNode._rotationAxisCache);\r\n this.rotationQuaternion.multiplyToRef(rotationQuaternion, this.rotationQuaternion);\r\n }\r\n else {\r\n if (this.parent) {\r\n var invertParentWorldMatrix = TmpVectors.Matrix[0];\r\n this.parent.getWorldMatrix().invertToRef(invertParentWorldMatrix);\r\n axis = Vector3.TransformNormal(axis, invertParentWorldMatrix);\r\n }\r\n rotationQuaternion = Quaternion.RotationAxisToRef(axis, amount, TransformNode._rotationAxisCache);\r\n rotationQuaternion.multiplyToRef(this.rotationQuaternion, this.rotationQuaternion);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Rotates the mesh around the axis vector for the passed angle (amount) expressed in radians, in world space.\r\n * Note that the property `rotationQuaternion` is then automatically updated and the property `rotation` is set to (0,0,0) and no longer used.\r\n * The passed axis is also normalized. .\r\n * Method is based on http://www.euclideanspace.com/maths/geometry/affine/aroundPoint/index.htm\r\n * @param point the point to rotate around\r\n * @param axis the axis to rotate around\r\n * @param amount the amount to rotate in radians\r\n * @returns the TransformNode\r\n */\r\n TransformNode.prototype.rotateAround = function (point, axis, amount) {\r\n axis.normalize();\r\n if (!this.rotationQuaternion) {\r\n this.rotationQuaternion = Quaternion.RotationYawPitchRoll(this.rotation.y, this.rotation.x, this.rotation.z);\r\n this.rotation.setAll(0);\r\n }\r\n var tmpVector = TmpVectors.Vector3[0];\r\n var finalScale = TmpVectors.Vector3[1];\r\n var finalTranslation = TmpVectors.Vector3[2];\r\n var finalRotation = TmpVectors.Quaternion[0];\r\n var translationMatrix = TmpVectors.Matrix[0]; // T\r\n var translationMatrixInv = TmpVectors.Matrix[1]; // T'\r\n var rotationMatrix = TmpVectors.Matrix[2]; // R\r\n var finalMatrix = TmpVectors.Matrix[3]; // T' x R x T\r\n point.subtractToRef(this.position, tmpVector);\r\n Matrix.TranslationToRef(tmpVector.x, tmpVector.y, tmpVector.z, translationMatrix); // T\r\n Matrix.TranslationToRef(-tmpVector.x, -tmpVector.y, -tmpVector.z, translationMatrixInv); // T'\r\n Matrix.RotationAxisToRef(axis, amount, rotationMatrix); // R\r\n translationMatrixInv.multiplyToRef(rotationMatrix, finalMatrix); // T' x R\r\n finalMatrix.multiplyToRef(translationMatrix, finalMatrix); // T' x R x T\r\n finalMatrix.decompose(finalScale, finalRotation, finalTranslation);\r\n this.position.addInPlace(finalTranslation);\r\n finalRotation.multiplyToRef(this.rotationQuaternion, this.rotationQuaternion);\r\n return this;\r\n };\r\n /**\r\n * Translates the mesh along the axis vector for the passed distance in the given space.\r\n * space (default LOCAL) can be either Space.LOCAL, either Space.WORLD.\r\n * @param axis the axis to translate in\r\n * @param distance the distance to translate\r\n * @param space Space to rotate in (Default: local)\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.translate = function (axis, distance, space) {\r\n var displacementVector = axis.scale(distance);\r\n if (!space || space === Space.LOCAL) {\r\n var tempV3 = this.getPositionExpressedInLocalSpace().add(displacementVector);\r\n this.setPositionWithLocalVector(tempV3);\r\n }\r\n else {\r\n this.setAbsolutePosition(this.getAbsolutePosition().add(displacementVector));\r\n }\r\n return this;\r\n };\r\n /**\r\n * Adds a rotation step to the mesh current rotation.\r\n * x, y, z are Euler angles expressed in radians.\r\n * This methods updates the current mesh rotation, either mesh.rotation, either mesh.rotationQuaternion if it's set.\r\n * This means this rotation is made in the mesh local space only.\r\n * It's useful to set a custom rotation order different from the BJS standard one YXZ.\r\n * Example : this rotates the mesh first around its local X axis, then around its local Z axis, finally around its local Y axis.\r\n * ```javascript\r\n * mesh.addRotation(x1, 0, 0).addRotation(0, 0, z2).addRotation(0, 0, y3);\r\n * ```\r\n * Note that `addRotation()` accumulates the passed rotation values to the current ones and computes the .rotation or .rotationQuaternion updated values.\r\n * Under the hood, only quaternions are used. So it's a little faster is you use .rotationQuaternion because it doesn't need to translate them back to Euler angles.\r\n * @param x Rotation to add\r\n * @param y Rotation to add\r\n * @param z Rotation to add\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.addRotation = function (x, y, z) {\r\n var rotationQuaternion;\r\n if (this.rotationQuaternion) {\r\n rotationQuaternion = this.rotationQuaternion;\r\n }\r\n else {\r\n rotationQuaternion = TmpVectors.Quaternion[1];\r\n Quaternion.RotationYawPitchRollToRef(this.rotation.y, this.rotation.x, this.rotation.z, rotationQuaternion);\r\n }\r\n var accumulation = TmpVectors.Quaternion[0];\r\n Quaternion.RotationYawPitchRollToRef(y, x, z, accumulation);\r\n rotationQuaternion.multiplyInPlace(accumulation);\r\n if (!this.rotationQuaternion) {\r\n rotationQuaternion.toEulerAnglesToRef(this.rotation);\r\n }\r\n return this;\r\n };\r\n /**\r\n * @hidden\r\n */\r\n TransformNode.prototype._getEffectiveParent = function () {\r\n return this.parent;\r\n };\r\n /**\r\n * Computes the world matrix of the node\r\n * @param force defines if the cache version should be invalidated forcing the world matrix to be created from scratch\r\n * @returns the world matrix\r\n */\r\n TransformNode.prototype.computeWorldMatrix = function (force) {\r\n if (this._isWorldMatrixFrozen && !this._isDirty) {\r\n return this._worldMatrix;\r\n }\r\n var currentRenderId = this.getScene().getRenderId();\r\n if (!this._isDirty && !force && this.isSynchronized()) {\r\n this._currentRenderId = currentRenderId;\r\n return this._worldMatrix;\r\n }\r\n var camera = this.getScene().activeCamera;\r\n var useBillboardPosition = (this._billboardMode & TransformNode.BILLBOARDMODE_USE_POSITION) !== 0;\r\n var useBillboardPath = this._billboardMode !== TransformNode.BILLBOARDMODE_NONE && !this.preserveParentRotationForBillboard;\r\n // Billboarding based on camera position\r\n if (useBillboardPath && camera && useBillboardPosition) {\r\n this.lookAt(camera.position);\r\n if ((this.billboardMode & TransformNode.BILLBOARDMODE_X) !== TransformNode.BILLBOARDMODE_X) {\r\n this.rotation.x = 0;\r\n }\r\n if ((this.billboardMode & TransformNode.BILLBOARDMODE_Y) !== TransformNode.BILLBOARDMODE_Y) {\r\n this.rotation.y = 0;\r\n }\r\n if ((this.billboardMode & TransformNode.BILLBOARDMODE_Z) !== TransformNode.BILLBOARDMODE_Z) {\r\n this.rotation.z = 0;\r\n }\r\n }\r\n this._updateCache();\r\n var cache = this._cache;\r\n cache.pivotMatrixUpdated = false;\r\n cache.billboardMode = this.billboardMode;\r\n cache.infiniteDistance = this.infiniteDistance;\r\n this._currentRenderId = currentRenderId;\r\n this._childUpdateId++;\r\n this._isDirty = false;\r\n this._position._isDirty = false;\r\n this._rotation._isDirty = false;\r\n this._scaling._isDirty = false;\r\n var parent = this._getEffectiveParent();\r\n // Scaling\r\n var scaling = TransformNode._TmpScaling;\r\n var translation = this._position;\r\n // Translation\r\n if (this._infiniteDistance) {\r\n if (!this.parent && camera) {\r\n var cameraWorldMatrix = camera.getWorldMatrix();\r\n var cameraGlobalPosition = new Vector3(cameraWorldMatrix.m[12], cameraWorldMatrix.m[13], cameraWorldMatrix.m[14]);\r\n translation = TransformNode._TmpTranslation;\r\n translation.copyFromFloats(this._position.x + cameraGlobalPosition.x, this._position.y + cameraGlobalPosition.y, this._position.z + cameraGlobalPosition.z);\r\n }\r\n }\r\n // Scaling\r\n scaling.copyFromFloats(this._scaling.x * this.scalingDeterminant, this._scaling.y * this.scalingDeterminant, this._scaling.z * this.scalingDeterminant);\r\n // Rotation\r\n var rotation;\r\n if (this._rotationQuaternion) {\r\n this._rotationQuaternion._isDirty = false;\r\n rotation = this._rotationQuaternion;\r\n if (this.reIntegrateRotationIntoRotationQuaternion) {\r\n var len = this.rotation.lengthSquared();\r\n if (len) {\r\n this._rotationQuaternion.multiplyInPlace(Quaternion.RotationYawPitchRoll(this._rotation.y, this._rotation.x, this._rotation.z));\r\n this._rotation.copyFromFloats(0, 0, 0);\r\n }\r\n }\r\n }\r\n else {\r\n rotation = TransformNode._TmpRotation;\r\n Quaternion.RotationYawPitchRollToRef(this._rotation.y, this._rotation.x, this._rotation.z, rotation);\r\n }\r\n // Compose\r\n if (this._usePivotMatrix) {\r\n var scaleMatrix = TmpVectors.Matrix[1];\r\n Matrix.ScalingToRef(scaling.x, scaling.y, scaling.z, scaleMatrix);\r\n // Rotation\r\n var rotationMatrix = TmpVectors.Matrix[0];\r\n rotation.toRotationMatrix(rotationMatrix);\r\n // Composing transformations\r\n this._pivotMatrix.multiplyToRef(scaleMatrix, TmpVectors.Matrix[4]);\r\n TmpVectors.Matrix[4].multiplyToRef(rotationMatrix, this._localMatrix);\r\n // Post multiply inverse of pivotMatrix\r\n if (this._postMultiplyPivotMatrix) {\r\n this._localMatrix.multiplyToRef(this._pivotMatrixInverse, this._localMatrix);\r\n }\r\n this._localMatrix.addTranslationFromFloats(translation.x, translation.y, translation.z);\r\n }\r\n else {\r\n Matrix.ComposeToRef(scaling, rotation, translation, this._localMatrix);\r\n }\r\n // Parent\r\n if (parent && parent.getWorldMatrix) {\r\n if (force) {\r\n parent.computeWorldMatrix();\r\n }\r\n if (useBillboardPath) {\r\n if (this._transformToBoneReferal) {\r\n parent.getWorldMatrix().multiplyToRef(this._transformToBoneReferal.getWorldMatrix(), TmpVectors.Matrix[7]);\r\n }\r\n else {\r\n TmpVectors.Matrix[7].copyFrom(parent.getWorldMatrix());\r\n }\r\n // Extract scaling and translation from parent\r\n var translation_1 = TmpVectors.Vector3[5];\r\n var scale = TmpVectors.Vector3[6];\r\n TmpVectors.Matrix[7].decompose(scale, undefined, translation_1);\r\n Matrix.ScalingToRef(scale.x, scale.y, scale.z, TmpVectors.Matrix[7]);\r\n TmpVectors.Matrix[7].setTranslation(translation_1);\r\n this._localMatrix.multiplyToRef(TmpVectors.Matrix[7], this._worldMatrix);\r\n }\r\n else {\r\n if (this._transformToBoneReferal) {\r\n this._localMatrix.multiplyToRef(parent.getWorldMatrix(), TmpVectors.Matrix[6]);\r\n TmpVectors.Matrix[6].multiplyToRef(this._transformToBoneReferal.getWorldMatrix(), this._worldMatrix);\r\n }\r\n else {\r\n this._localMatrix.multiplyToRef(parent.getWorldMatrix(), this._worldMatrix);\r\n }\r\n }\r\n this._markSyncedWithParent();\r\n }\r\n else {\r\n this._worldMatrix.copyFrom(this._localMatrix);\r\n }\r\n // Billboarding based on camera orientation (testing PG:http://www.babylonjs-playground.com/#UJEIL#13)\r\n if (useBillboardPath && camera && this.billboardMode && !useBillboardPosition) {\r\n var storedTranslation = TmpVectors.Vector3[0];\r\n this._worldMatrix.getTranslationToRef(storedTranslation); // Save translation\r\n // Cancel camera rotation\r\n TmpVectors.Matrix[1].copyFrom(camera.getViewMatrix());\r\n TmpVectors.Matrix[1].setTranslationFromFloats(0, 0, 0);\r\n TmpVectors.Matrix[1].invertToRef(TmpVectors.Matrix[0]);\r\n if ((this.billboardMode & TransformNode.BILLBOARDMODE_ALL) !== TransformNode.BILLBOARDMODE_ALL) {\r\n TmpVectors.Matrix[0].decompose(undefined, TmpVectors.Quaternion[0], undefined);\r\n var eulerAngles = TmpVectors.Vector3[1];\r\n TmpVectors.Quaternion[0].toEulerAnglesToRef(eulerAngles);\r\n if ((this.billboardMode & TransformNode.BILLBOARDMODE_X) !== TransformNode.BILLBOARDMODE_X) {\r\n eulerAngles.x = 0;\r\n }\r\n if ((this.billboardMode & TransformNode.BILLBOARDMODE_Y) !== TransformNode.BILLBOARDMODE_Y) {\r\n eulerAngles.y = 0;\r\n }\r\n if ((this.billboardMode & TransformNode.BILLBOARDMODE_Z) !== TransformNode.BILLBOARDMODE_Z) {\r\n eulerAngles.z = 0;\r\n }\r\n Matrix.RotationYawPitchRollToRef(eulerAngles.y, eulerAngles.x, eulerAngles.z, TmpVectors.Matrix[0]);\r\n }\r\n this._worldMatrix.setTranslationFromFloats(0, 0, 0);\r\n this._worldMatrix.multiplyToRef(TmpVectors.Matrix[0], this._worldMatrix);\r\n // Restore translation\r\n this._worldMatrix.setTranslation(TmpVectors.Vector3[0]);\r\n }\r\n // Normal matrix\r\n if (!this.ignoreNonUniformScaling) {\r\n if (this._scaling.isNonUniformWithinEpsilon(0.000001)) {\r\n this._updateNonUniformScalingState(true);\r\n }\r\n else if (parent && parent._nonUniformScaling) {\r\n this._updateNonUniformScalingState(parent._nonUniformScaling);\r\n }\r\n else {\r\n this._updateNonUniformScalingState(false);\r\n }\r\n }\r\n else {\r\n this._updateNonUniformScalingState(false);\r\n }\r\n this._afterComputeWorldMatrix();\r\n // Absolute position\r\n this._absolutePosition.copyFromFloats(this._worldMatrix.m[12], this._worldMatrix.m[13], this._worldMatrix.m[14]);\r\n this._isAbsoluteSynced = false;\r\n // Callbacks\r\n this.onAfterWorldMatrixUpdateObservable.notifyObservers(this);\r\n if (!this._poseMatrix) {\r\n this._poseMatrix = Matrix.Invert(this._worldMatrix);\r\n }\r\n // Cache the determinant\r\n this._worldMatrixDeterminantIsDirty = true;\r\n return this._worldMatrix;\r\n };\r\n /**\r\n * Resets this nodeTransform's local matrix to Matrix.Identity().\r\n * @param independentOfChildren indicates if all child nodeTransform's world-space transform should be preserved.\r\n */\r\n TransformNode.prototype.resetLocalMatrix = function (independentOfChildren) {\r\n if (independentOfChildren === void 0) { independentOfChildren = true; }\r\n this.computeWorldMatrix();\r\n if (independentOfChildren) {\r\n var children = this.getChildren();\r\n for (var i = 0; i < children.length; ++i) {\r\n var child = children[i];\r\n if (child) {\r\n child.computeWorldMatrix();\r\n var bakedMatrix = TmpVectors.Matrix[0];\r\n child._localMatrix.multiplyToRef(this._localMatrix, bakedMatrix);\r\n var tmpRotationQuaternion = TmpVectors.Quaternion[0];\r\n bakedMatrix.decompose(child.scaling, tmpRotationQuaternion, child.position);\r\n if (child.rotationQuaternion) {\r\n child.rotationQuaternion = tmpRotationQuaternion;\r\n }\r\n else {\r\n tmpRotationQuaternion.toEulerAnglesToRef(child.rotation);\r\n }\r\n }\r\n }\r\n }\r\n this.scaling.copyFromFloats(1, 1, 1);\r\n this.position.copyFromFloats(0, 0, 0);\r\n this.rotation.copyFromFloats(0, 0, 0);\r\n //only if quaternion is already set\r\n if (this.rotationQuaternion) {\r\n this.rotationQuaternion = Quaternion.Identity();\r\n }\r\n this._worldMatrix = Matrix.Identity();\r\n };\r\n TransformNode.prototype._afterComputeWorldMatrix = function () {\r\n };\r\n /**\r\n * If you'd like to be called back after the mesh position, rotation or scaling has been updated.\r\n * @param func callback function to add\r\n *\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.registerAfterWorldMatrixUpdate = function (func) {\r\n this.onAfterWorldMatrixUpdateObservable.add(func);\r\n return this;\r\n };\r\n /**\r\n * Removes a registered callback function.\r\n * @param func callback function to remove\r\n * @returns the TransformNode.\r\n */\r\n TransformNode.prototype.unregisterAfterWorldMatrixUpdate = function (func) {\r\n this.onAfterWorldMatrixUpdateObservable.removeCallback(func);\r\n return this;\r\n };\r\n /**\r\n * Gets the position of the current mesh in camera space\r\n * @param camera defines the camera to use\r\n * @returns a position\r\n */\r\n TransformNode.prototype.getPositionInCameraSpace = function (camera) {\r\n if (camera === void 0) { camera = null; }\r\n if (!camera) {\r\n camera = this.getScene().activeCamera;\r\n }\r\n return Vector3.TransformCoordinates(this.getAbsolutePosition(), camera.getViewMatrix());\r\n };\r\n /**\r\n * Returns the distance from the mesh to the active camera\r\n * @param camera defines the camera to use\r\n * @returns the distance\r\n */\r\n TransformNode.prototype.getDistanceToCamera = function (camera) {\r\n if (camera === void 0) { camera = null; }\r\n if (!camera) {\r\n camera = this.getScene().activeCamera;\r\n }\r\n return this.getAbsolutePosition().subtract(camera.globalPosition).length();\r\n };\r\n /**\r\n * Clone the current transform node\r\n * @param name Name of the new clone\r\n * @param newParent New parent for the clone\r\n * @param doNotCloneChildren Do not clone children hierarchy\r\n * @returns the new transform node\r\n */\r\n TransformNode.prototype.clone = function (name, newParent, doNotCloneChildren) {\r\n var _this = this;\r\n var result = SerializationHelper.Clone(function () { return new TransformNode(name, _this.getScene()); }, this);\r\n result.name = name;\r\n result.id = name;\r\n if (newParent) {\r\n result.parent = newParent;\r\n }\r\n if (!doNotCloneChildren) {\r\n // Children\r\n var directDescendants = this.getDescendants(true);\r\n for (var index = 0; index < directDescendants.length; index++) {\r\n var child = directDescendants[index];\r\n if (child.clone) {\r\n child.clone(name + \".\" + child.name, result);\r\n }\r\n }\r\n }\r\n return result;\r\n };\r\n /**\r\n * Serializes the objects information.\r\n * @param currentSerializationObject defines the object to serialize in\r\n * @returns the serialized object\r\n */\r\n TransformNode.prototype.serialize = function (currentSerializationObject) {\r\n var serializationObject = SerializationHelper.Serialize(this, currentSerializationObject);\r\n serializationObject.type = this.getClassName();\r\n // Parent\r\n if (this.parent) {\r\n serializationObject.parentId = this.parent.id;\r\n }\r\n serializationObject.localMatrix = this.getPivotMatrix().asArray();\r\n serializationObject.isEnabled = this.isEnabled();\r\n // Parent\r\n if (this.parent) {\r\n serializationObject.parentId = this.parent.id;\r\n }\r\n return serializationObject;\r\n };\r\n // Statics\r\n /**\r\n * Returns a new TransformNode object parsed from the source provided.\r\n * @param parsedTransformNode is the source.\r\n * @param scene the scne the object belongs to\r\n * @param rootUrl is a string, it's the root URL to prefix the `delayLoadingFile` property with\r\n * @returns a new TransformNode object parsed from the source provided.\r\n */\r\n TransformNode.Parse = function (parsedTransformNode, scene, rootUrl) {\r\n var transformNode = SerializationHelper.Parse(function () { return new TransformNode(parsedTransformNode.name, scene); }, parsedTransformNode, scene, rootUrl);\r\n if (parsedTransformNode.localMatrix) {\r\n transformNode.setPreTransformMatrix(Matrix.FromArray(parsedTransformNode.localMatrix));\r\n }\r\n else if (parsedTransformNode.pivotMatrix) {\r\n transformNode.setPivotMatrix(Matrix.FromArray(parsedTransformNode.pivotMatrix));\r\n }\r\n transformNode.setEnabled(parsedTransformNode.isEnabled);\r\n // Parent\r\n if (parsedTransformNode.parentId) {\r\n transformNode._waitingParentId = parsedTransformNode.parentId;\r\n }\r\n return transformNode;\r\n };\r\n /**\r\n * Get all child-transformNodes of this node\r\n * @param directDescendantsOnly defines if true only direct descendants of 'this' will be considered, if false direct and also indirect (children of children, an so on in a recursive manner) descendants of 'this' will be considered\r\n * @param predicate defines an optional predicate that will be called on every evaluated child, the predicate must return true for a given child to be part of the result, otherwise it will be ignored\r\n * @returns an array of TransformNode\r\n */\r\n TransformNode.prototype.getChildTransformNodes = function (directDescendantsOnly, predicate) {\r\n var results = [];\r\n this._getDescendants(results, directDescendantsOnly, function (node) {\r\n return ((!predicate || predicate(node)) && (node instanceof TransformNode));\r\n });\r\n return results;\r\n };\r\n /**\r\n * Releases resources associated with this transform node.\r\n * @param doNotRecurse Set to true to not recurse into each children (recurse into each children by default)\r\n * @param disposeMaterialAndTextures Set to true to also dispose referenced materials and textures (false by default)\r\n */\r\n TransformNode.prototype.dispose = function (doNotRecurse, disposeMaterialAndTextures) {\r\n if (disposeMaterialAndTextures === void 0) { disposeMaterialAndTextures = false; }\r\n // Animations\r\n this.getScene().stopAnimation(this);\r\n // Remove from scene\r\n this.getScene().removeTransformNode(this);\r\n this.onAfterWorldMatrixUpdateObservable.clear();\r\n if (doNotRecurse) {\r\n var transformNodes = this.getChildTransformNodes(true);\r\n for (var _i = 0, transformNodes_1 = transformNodes; _i < transformNodes_1.length; _i++) {\r\n var transformNode = transformNodes_1[_i];\r\n transformNode.parent = null;\r\n transformNode.computeWorldMatrix(true);\r\n }\r\n }\r\n _super.prototype.dispose.call(this, doNotRecurse, disposeMaterialAndTextures);\r\n };\r\n /**\r\n * Uniformly scales the mesh to fit inside of a unit cube (1 X 1 X 1 units)\r\n * @param includeDescendants Use the hierarchy's bounding box instead of the mesh's bounding box. Default is false\r\n * @param ignoreRotation ignore rotation when computing the scale (ie. object will be axis aligned). Default is false\r\n * @param predicate predicate that is passed in to getHierarchyBoundingVectors when selecting which object should be included when scaling\r\n * @returns the current mesh\r\n */\r\n TransformNode.prototype.normalizeToUnitCube = function (includeDescendants, ignoreRotation, predicate) {\r\n if (includeDescendants === void 0) { includeDescendants = true; }\r\n if (ignoreRotation === void 0) { ignoreRotation = false; }\r\n var storedRotation = null;\r\n var storedRotationQuaternion = null;\r\n if (ignoreRotation) {\r\n if (this.rotationQuaternion) {\r\n storedRotationQuaternion = this.rotationQuaternion.clone();\r\n this.rotationQuaternion.copyFromFloats(0, 0, 0, 1);\r\n }\r\n else if (this.rotation) {\r\n storedRotation = this.rotation.clone();\r\n this.rotation.copyFromFloats(0, 0, 0);\r\n }\r\n }\r\n var boundingVectors = this.getHierarchyBoundingVectors(includeDescendants, predicate);\r\n var sizeVec = boundingVectors.max.subtract(boundingVectors.min);\r\n var maxDimension = Math.max(sizeVec.x, sizeVec.y, sizeVec.z);\r\n if (maxDimension === 0) {\r\n return this;\r\n }\r\n var scale = 1 / maxDimension;\r\n this.scaling.scaleInPlace(scale);\r\n if (ignoreRotation) {\r\n if (this.rotationQuaternion && storedRotationQuaternion) {\r\n this.rotationQuaternion.copyFrom(storedRotationQuaternion);\r\n }\r\n else if (this.rotation && storedRotation) {\r\n this.rotation.copyFrom(storedRotation);\r\n }\r\n }\r\n return this;\r\n };\r\n TransformNode.prototype._syncAbsoluteScalingAndRotation = function () {\r\n if (!this._isAbsoluteSynced) {\r\n this._worldMatrix.decompose(this._absoluteScaling, this._absoluteRotationQuaternion);\r\n this._isAbsoluteSynced = true;\r\n }\r\n };\r\n // Statics\r\n /**\r\n * Object will not rotate to face the camera\r\n */\r\n TransformNode.BILLBOARDMODE_NONE = 0;\r\n /**\r\n * Object will rotate to face the camera but only on the x axis\r\n */\r\n TransformNode.BILLBOARDMODE_X = 1;\r\n /**\r\n * Object will rotate to face the camera but only on the y axis\r\n */\r\n TransformNode.BILLBOARDMODE_Y = 2;\r\n /**\r\n * Object will rotate to face the camera but only on the z axis\r\n */\r\n TransformNode.BILLBOARDMODE_Z = 4;\r\n /**\r\n * Object will rotate to face the camera\r\n */\r\n TransformNode.BILLBOARDMODE_ALL = 7;\r\n /**\r\n * Object will rotate to face the camera's position instead of orientation\r\n */\r\n TransformNode.BILLBOARDMODE_USE_POSITION = 128;\r\n TransformNode._TmpRotation = Quaternion.Zero();\r\n TransformNode._TmpScaling = Vector3.Zero();\r\n TransformNode._TmpTranslation = Vector3.Zero();\r\n TransformNode._lookAtVectorCache = new Vector3(0, 0, 0);\r\n TransformNode._rotationAxisCache = new Quaternion();\r\n __decorate([\r\n serializeAsVector3(\"position\")\r\n ], TransformNode.prototype, \"_position\", void 0);\r\n __decorate([\r\n serializeAsVector3(\"rotation\")\r\n ], TransformNode.prototype, \"_rotation\", void 0);\r\n __decorate([\r\n serializeAsQuaternion(\"rotationQuaternion\")\r\n ], TransformNode.prototype, \"_rotationQuaternion\", void 0);\r\n __decorate([\r\n serializeAsVector3(\"scaling\")\r\n ], TransformNode.prototype, \"_scaling\", void 0);\r\n __decorate([\r\n serialize(\"billboardMode\")\r\n ], TransformNode.prototype, \"_billboardMode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], TransformNode.prototype, \"scalingDeterminant\", void 0);\r\n __decorate([\r\n serialize(\"infiniteDistance\")\r\n ], TransformNode.prototype, \"_infiniteDistance\", void 0);\r\n __decorate([\r\n serialize()\r\n ], TransformNode.prototype, \"ignoreNonUniformScaling\", void 0);\r\n __decorate([\r\n serialize()\r\n ], TransformNode.prototype, \"reIntegrateRotationIntoRotationQuaternion\", void 0);\r\n return TransformNode;\r\n}(Node));\r\nexport { TransformNode };\r\n//# sourceMappingURL=transformNode.js.map","'use strict';\n\nvar bind = require('./helpers/bind');\n\n/*global toString:true*/\n\n// utils is a library of generic helper functions non-specific to axios\n\nvar toString = Object.prototype.toString;\n\n/**\n * Determine if a value is an Array\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Array, otherwise false\n */\nfunction isArray(val) {\n return toString.call(val) === '[object Array]';\n}\n\n/**\n * Determine if a value is undefined\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if the value is undefined, otherwise false\n */\nfunction isUndefined(val) {\n return typeof val === 'undefined';\n}\n\n/**\n * Determine if a value is a Buffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Buffer, otherwise false\n */\nfunction isBuffer(val) {\n return val !== null && !isUndefined(val) && val.constructor !== null && !isUndefined(val.constructor)\n && typeof val.constructor.isBuffer === 'function' && val.constructor.isBuffer(val);\n}\n\n/**\n * Determine if a value is an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an ArrayBuffer, otherwise false\n */\nfunction isArrayBuffer(val) {\n return toString.call(val) === '[object ArrayBuffer]';\n}\n\n/**\n * Determine if a value is a FormData\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an FormData, otherwise false\n */\nfunction isFormData(val) {\n return (typeof FormData !== 'undefined') && (val instanceof FormData);\n}\n\n/**\n * Determine if a value is a view on an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a view on an ArrayBuffer, otherwise false\n */\nfunction isArrayBufferView(val) {\n var result;\n if ((typeof ArrayBuffer !== 'undefined') && (ArrayBuffer.isView)) {\n result = ArrayBuffer.isView(val);\n } else {\n result = (val) && (val.buffer) && (val.buffer instanceof ArrayBuffer);\n }\n return result;\n}\n\n/**\n * Determine if a value is a String\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a String, otherwise false\n */\nfunction isString(val) {\n return typeof val === 'string';\n}\n\n/**\n * Determine if a value is a Number\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Number, otherwise false\n */\nfunction isNumber(val) {\n return typeof val === 'number';\n}\n\n/**\n * Determine if a value is an Object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Object, otherwise false\n */\nfunction isObject(val) {\n return val !== null && typeof val === 'object';\n}\n\n/**\n * Determine if a value is a plain Object\n *\n * @param {Object} val The value to test\n * @return {boolean} True if value is a plain Object, otherwise false\n */\nfunction isPlainObject(val) {\n if (toString.call(val) !== '[object Object]') {\n return false;\n }\n\n var prototype = Object.getPrototypeOf(val);\n return prototype === null || prototype === Object.prototype;\n}\n\n/**\n * Determine if a value is a Date\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Date, otherwise false\n */\nfunction isDate(val) {\n return toString.call(val) === '[object Date]';\n}\n\n/**\n * Determine if a value is a File\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a File, otherwise false\n */\nfunction isFile(val) {\n return toString.call(val) === '[object File]';\n}\n\n/**\n * Determine if a value is a Blob\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Blob, otherwise false\n */\nfunction isBlob(val) {\n return toString.call(val) === '[object Blob]';\n}\n\n/**\n * Determine if a value is a Function\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Function, otherwise false\n */\nfunction isFunction(val) {\n return toString.call(val) === '[object Function]';\n}\n\n/**\n * Determine if a value is a Stream\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Stream, otherwise false\n */\nfunction isStream(val) {\n return isObject(val) && isFunction(val.pipe);\n}\n\n/**\n * Determine if a value is a URLSearchParams object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a URLSearchParams object, otherwise false\n */\nfunction isURLSearchParams(val) {\n return typeof URLSearchParams !== 'undefined' && val instanceof URLSearchParams;\n}\n\n/**\n * Trim excess whitespace off the beginning and end of a string\n *\n * @param {String} str The String to trim\n * @returns {String} The String freed of excess whitespace\n */\nfunction trim(str) {\n return str.replace(/^\\s*/, '').replace(/\\s*$/, '');\n}\n\n/**\n * Determine if we're running in a standard browser environment\n *\n * This allows axios to run in a web worker, and react-native.\n * Both environments support XMLHttpRequest, but not fully standard globals.\n *\n * web workers:\n * typeof window -> undefined\n * typeof document -> undefined\n *\n * react-native:\n * navigator.product -> 'ReactNative'\n * nativescript\n * navigator.product -> 'NativeScript' or 'NS'\n */\nfunction isStandardBrowserEnv() {\n if (typeof navigator !== 'undefined' && (navigator.product === 'ReactNative' ||\n navigator.product === 'NativeScript' ||\n navigator.product === 'NS')) {\n return false;\n }\n return (\n typeof window !== 'undefined' &&\n typeof document !== 'undefined'\n );\n}\n\n/**\n * Iterate over an Array or an Object invoking a function for each item.\n *\n * If `obj` is an Array callback will be called passing\n * the value, index, and complete array for each item.\n *\n * If 'obj' is an Object callback will be called passing\n * the value, key, and complete object for each property.\n *\n * @param {Object|Array} obj The object to iterate\n * @param {Function} fn The callback to invoke for each item\n */\nfunction forEach(obj, fn) {\n // Don't bother if no value provided\n if (obj === null || typeof obj === 'undefined') {\n return;\n }\n\n // Force an array if not already something iterable\n if (typeof obj !== 'object') {\n /*eslint no-param-reassign:0*/\n obj = [obj];\n }\n\n if (isArray(obj)) {\n // Iterate over array values\n for (var i = 0, l = obj.length; i < l; i++) {\n fn.call(null, obj[i], i, obj);\n }\n } else {\n // Iterate over object keys\n for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) {\n fn.call(null, obj[key], key, obj);\n }\n }\n }\n}\n\n/**\n * Accepts varargs expecting each argument to be an object, then\n * immutably merges the properties of each object and returns result.\n *\n * When multiple objects contain the same key the later object in\n * the arguments list will take precedence.\n *\n * Example:\n *\n * ```js\n * var result = merge({foo: 123}, {foo: 456});\n * console.log(result.foo); // outputs 456\n * ```\n *\n * @param {Object} obj1 Object to merge\n * @returns {Object} Result of all merge properties\n */\nfunction merge(/* obj1, obj2, obj3, ... */) {\n var result = {};\n function assignValue(val, key) {\n if (isPlainObject(result[key]) && isPlainObject(val)) {\n result[key] = merge(result[key], val);\n } else if (isPlainObject(val)) {\n result[key] = merge({}, val);\n } else if (isArray(val)) {\n result[key] = val.slice();\n } else {\n result[key] = val;\n }\n }\n\n for (var i = 0, l = arguments.length; i < l; i++) {\n forEach(arguments[i], assignValue);\n }\n return result;\n}\n\n/**\n * Extends object a by mutably adding to it the properties of object b.\n *\n * @param {Object} a The object to be extended\n * @param {Object} b The object to copy properties from\n * @param {Object} thisArg The object to bind function to\n * @return {Object} The resulting value of object a\n */\nfunction extend(a, b, thisArg) {\n forEach(b, function assignValue(val, key) {\n if (thisArg && typeof val === 'function') {\n a[key] = bind(val, thisArg);\n } else {\n a[key] = val;\n }\n });\n return a;\n}\n\n/**\n * Remove byte order marker. This catches EF BB BF (the UTF-8 BOM)\n *\n * @param {string} content with BOM\n * @return {string} content value without BOM\n */\nfunction stripBOM(content) {\n if (content.charCodeAt(0) === 0xFEFF) {\n content = content.slice(1);\n }\n return content;\n}\n\nmodule.exports = {\n isArray: isArray,\n isArrayBuffer: isArrayBuffer,\n isBuffer: isBuffer,\n isFormData: isFormData,\n isArrayBufferView: isArrayBufferView,\n isString: isString,\n isNumber: isNumber,\n isObject: isObject,\n isPlainObject: isPlainObject,\n isUndefined: isUndefined,\n isDate: isDate,\n isFile: isFile,\n isBlob: isBlob,\n isFunction: isFunction,\n isStream: isStream,\n isURLSearchParams: isURLSearchParams,\n isStandardBrowserEnv: isStandardBrowserEnv,\n forEach: forEach,\n merge: merge,\n extend: extend,\n trim: trim,\n stripBOM: stripBOM\n};\n","/** @hidden */\r\nfunction createXMLHttpRequest() {\r\n // If running in Babylon Native, then defer to the native XMLHttpRequest, which has the same public contract\r\n if (typeof _native !== 'undefined' && _native.XMLHttpRequest) {\r\n return new _native.XMLHttpRequest();\r\n }\r\n else {\r\n return new XMLHttpRequest();\r\n }\r\n}\r\n/**\r\n * Extended version of XMLHttpRequest with support for customizations (headers, ...)\r\n */\r\nvar WebRequest = /** @class */ (function () {\r\n function WebRequest() {\r\n this._xhr = createXMLHttpRequest();\r\n }\r\n WebRequest.prototype._injectCustomRequestHeaders = function () {\r\n for (var key in WebRequest.CustomRequestHeaders) {\r\n var val = WebRequest.CustomRequestHeaders[key];\r\n if (val) {\r\n this._xhr.setRequestHeader(key, val);\r\n }\r\n }\r\n };\r\n Object.defineProperty(WebRequest.prototype, \"onprogress\", {\r\n /**\r\n * Gets or sets a function to be called when loading progress changes\r\n */\r\n get: function () {\r\n return this._xhr.onprogress;\r\n },\r\n set: function (value) {\r\n this._xhr.onprogress = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(WebRequest.prototype, \"readyState\", {\r\n /**\r\n * Returns client's state\r\n */\r\n get: function () {\r\n return this._xhr.readyState;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(WebRequest.prototype, \"status\", {\r\n /**\r\n * Returns client's status\r\n */\r\n get: function () {\r\n return this._xhr.status;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(WebRequest.prototype, \"statusText\", {\r\n /**\r\n * Returns client's status as a text\r\n */\r\n get: function () {\r\n return this._xhr.statusText;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(WebRequest.prototype, \"response\", {\r\n /**\r\n * Returns client's response\r\n */\r\n get: function () {\r\n return this._xhr.response;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(WebRequest.prototype, \"responseURL\", {\r\n /**\r\n * Returns client's response url\r\n */\r\n get: function () {\r\n return this._xhr.responseURL;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(WebRequest.prototype, \"responseText\", {\r\n /**\r\n * Returns client's response as text\r\n */\r\n get: function () {\r\n return this._xhr.responseText;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(WebRequest.prototype, \"responseType\", {\r\n /**\r\n * Gets or sets the expected response type\r\n */\r\n get: function () {\r\n return this._xhr.responseType;\r\n },\r\n set: function (value) {\r\n this._xhr.responseType = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n WebRequest.prototype.addEventListener = function (type, listener, options) {\r\n this._xhr.addEventListener(type, listener, options);\r\n };\r\n WebRequest.prototype.removeEventListener = function (type, listener, options) {\r\n this._xhr.removeEventListener(type, listener, options);\r\n };\r\n /**\r\n * Cancels any network activity\r\n */\r\n WebRequest.prototype.abort = function () {\r\n this._xhr.abort();\r\n };\r\n /**\r\n * Initiates the request. The optional argument provides the request body. The argument is ignored if request method is GET or HEAD\r\n * @param body defines an optional request body\r\n */\r\n WebRequest.prototype.send = function (body) {\r\n if (WebRequest.CustomRequestHeaders) {\r\n this._injectCustomRequestHeaders();\r\n }\r\n this._xhr.send(body);\r\n };\r\n /**\r\n * Sets the request method, request URL\r\n * @param method defines the method to use (GET, POST, etc..)\r\n * @param url defines the url to connect with\r\n */\r\n WebRequest.prototype.open = function (method, url) {\r\n for (var _i = 0, _a = WebRequest.CustomRequestModifiers; _i < _a.length; _i++) {\r\n var update = _a[_i];\r\n update(this._xhr, url);\r\n }\r\n // Clean url\r\n url = url.replace(\"file:http:\", \"http:\");\r\n url = url.replace(\"file:https:\", \"https:\");\r\n return this._xhr.open(method, url, true);\r\n };\r\n /**\r\n * Sets the value of a request header.\r\n * @param name The name of the header whose value is to be set\r\n * @param value The value to set as the body of the header\r\n */\r\n WebRequest.prototype.setRequestHeader = function (name, value) {\r\n this._xhr.setRequestHeader(name, value);\r\n };\r\n /**\r\n * Get the string containing the text of a particular header's value.\r\n * @param name The name of the header\r\n * @returns The string containing the text of the given header name\r\n */\r\n WebRequest.prototype.getResponseHeader = function (name) {\r\n return this._xhr.getResponseHeader(name);\r\n };\r\n /**\r\n * Custom HTTP Request Headers to be sent with XMLHttpRequests\r\n * i.e. when loading files, where the server/service expects an Authorization header\r\n */\r\n WebRequest.CustomRequestHeaders = {};\r\n /**\r\n * Add callback functions in this array to update all the requests before they get sent to the network\r\n */\r\n WebRequest.CustomRequestModifiers = new Array();\r\n return WebRequest;\r\n}());\r\nexport { WebRequest };\r\n//# sourceMappingURL=webRequest.js.map","import { Vector3, Vector2, TmpVectors } from \"../Maths/math.vector\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\n/**\r\n * Information about the result of picking within a scene\r\n * @see https://doc.babylonjs.com/babylon101/picking_collisions\r\n */\r\nvar PickingInfo = /** @class */ (function () {\r\n function PickingInfo() {\r\n /** @hidden */\r\n this._pickingUnavailable = false;\r\n /**\r\n * If the pick collided with an object\r\n */\r\n this.hit = false;\r\n /**\r\n * Distance away where the pick collided\r\n */\r\n this.distance = 0;\r\n /**\r\n * The location of pick collision\r\n */\r\n this.pickedPoint = null;\r\n /**\r\n * The mesh corresponding the the pick collision\r\n */\r\n this.pickedMesh = null;\r\n /** (See getTextureCoordinates) The barycentric U coordinate that is used when calculating the texture coordinates of the collision.*/\r\n this.bu = 0;\r\n /** (See getTextureCoordinates) The barycentric V coordinate that is used when calculating the texture coordinates of the collision.*/\r\n this.bv = 0;\r\n /** The index of the face on the mesh that was picked, or the index of the Line if the picked Mesh is a LinesMesh */\r\n this.faceId = -1;\r\n /** The index of the face on the subMesh that was picked, or the index of the Line if the picked Mesh is a LinesMesh */\r\n this.subMeshFaceId = -1;\r\n /** Id of the the submesh that was picked */\r\n this.subMeshId = 0;\r\n /** If a sprite was picked, this will be the sprite the pick collided with */\r\n this.pickedSprite = null;\r\n /** If we are pikcing a mesh with thin instance, this will give you the picked thin instance */\r\n this.thinInstanceIndex = -1;\r\n /**\r\n * If a mesh was used to do the picking (eg. 6dof controller) this will be populated.\r\n */\r\n this.originMesh = null;\r\n /**\r\n * The ray that was used to perform the picking.\r\n */\r\n this.ray = null;\r\n }\r\n /**\r\n * Gets the normal correspodning to the face the pick collided with\r\n * @param useWorldCoordinates If the resulting normal should be relative to the world (default: false)\r\n * @param useVerticesNormals If the vertices normals should be used to calculate the normal instead of the normal map\r\n * @returns The normal correspodning to the face the pick collided with\r\n */\r\n PickingInfo.prototype.getNormal = function (useWorldCoordinates, useVerticesNormals) {\r\n if (useWorldCoordinates === void 0) { useWorldCoordinates = false; }\r\n if (useVerticesNormals === void 0) { useVerticesNormals = true; }\r\n if (!this.pickedMesh || !this.pickedMesh.isVerticesDataPresent(VertexBuffer.NormalKind)) {\r\n return null;\r\n }\r\n var indices = this.pickedMesh.getIndices();\r\n if (!indices) {\r\n return null;\r\n }\r\n var result;\r\n if (useVerticesNormals) {\r\n var normals = this.pickedMesh.getVerticesData(VertexBuffer.NormalKind);\r\n var normal0 = Vector3.FromArray(normals, indices[this.faceId * 3] * 3);\r\n var normal1 = Vector3.FromArray(normals, indices[this.faceId * 3 + 1] * 3);\r\n var normal2 = Vector3.FromArray(normals, indices[this.faceId * 3 + 2] * 3);\r\n normal0 = normal0.scale(this.bu);\r\n normal1 = normal1.scale(this.bv);\r\n normal2 = normal2.scale(1.0 - this.bu - this.bv);\r\n result = new Vector3(normal0.x + normal1.x + normal2.x, normal0.y + normal1.y + normal2.y, normal0.z + normal1.z + normal2.z);\r\n }\r\n else {\r\n var positions = this.pickedMesh.getVerticesData(VertexBuffer.PositionKind);\r\n var vertex1 = Vector3.FromArray(positions, indices[this.faceId * 3] * 3);\r\n var vertex2 = Vector3.FromArray(positions, indices[this.faceId * 3 + 1] * 3);\r\n var vertex3 = Vector3.FromArray(positions, indices[this.faceId * 3 + 2] * 3);\r\n var p1p2 = vertex1.subtract(vertex2);\r\n var p3p2 = vertex3.subtract(vertex2);\r\n result = Vector3.Cross(p1p2, p3p2);\r\n }\r\n if (useWorldCoordinates) {\r\n var wm = this.pickedMesh.getWorldMatrix();\r\n if (this.pickedMesh.nonUniformScaling) {\r\n TmpVectors.Matrix[0].copyFrom(wm);\r\n wm = TmpVectors.Matrix[0];\r\n wm.setTranslationFromFloats(0, 0, 0);\r\n wm.invert();\r\n wm.transposeToRef(TmpVectors.Matrix[1]);\r\n wm = TmpVectors.Matrix[1];\r\n }\r\n result = Vector3.TransformNormal(result, wm);\r\n }\r\n result.normalize();\r\n return result;\r\n };\r\n /**\r\n * Gets the texture coordinates of where the pick occured\r\n * @returns the vector containing the coordnates of the texture\r\n */\r\n PickingInfo.prototype.getTextureCoordinates = function () {\r\n if (!this.pickedMesh || !this.pickedMesh.isVerticesDataPresent(VertexBuffer.UVKind)) {\r\n return null;\r\n }\r\n var indices = this.pickedMesh.getIndices();\r\n if (!indices) {\r\n return null;\r\n }\r\n var uvs = this.pickedMesh.getVerticesData(VertexBuffer.UVKind);\r\n if (!uvs) {\r\n return null;\r\n }\r\n var uv0 = Vector2.FromArray(uvs, indices[this.faceId * 3] * 2);\r\n var uv1 = Vector2.FromArray(uvs, indices[this.faceId * 3 + 1] * 2);\r\n var uv2 = Vector2.FromArray(uvs, indices[this.faceId * 3 + 2] * 2);\r\n uv0 = uv0.scale(this.bu);\r\n uv1 = uv1.scale(this.bv);\r\n uv2 = uv2.scale(1.0 - this.bu - this.bv);\r\n return new Vector2(uv0.x + uv1.x + uv2.x, uv0.y + uv1.y + uv2.y);\r\n };\r\n return PickingInfo;\r\n}());\r\nexport { PickingInfo };\r\n//# sourceMappingURL=pickingInfo.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, SerializationHelper, serializeAsColor3, expandToProperty } from \"../Misc/decorators\";\r\nimport { Vector3 } from \"../Maths/math.vector\";\r\nimport { Color3, TmpColors } from \"../Maths/math.color\";\r\nimport { Node } from \"../node\";\r\nimport { UniformBuffer } from \"../Materials/uniformBuffer\";\r\nimport { _TypeStore } from '../Misc/typeStore';\r\n/**\r\n * Base class of all the lights in Babylon. It groups all the generic information about lights.\r\n * Lights are used, as you would expect, to affect how meshes are seen, in terms of both illumination and colour.\r\n * All meshes allow light to pass through them unless shadow generation is activated. The default number of lights allowed is four but this can be increased.\r\n */\r\nvar Light = /** @class */ (function (_super) {\r\n __extends(Light, _super);\r\n /**\r\n * Creates a Light object in the scene.\r\n * Documentation : https://doc.babylonjs.com/babylon101/lights\r\n * @param name The firendly name of the light\r\n * @param scene The scene the light belongs too\r\n */\r\n function Light(name, scene) {\r\n var _this = _super.call(this, name, scene) || this;\r\n /**\r\n * Diffuse gives the basic color to an object.\r\n */\r\n _this.diffuse = new Color3(1.0, 1.0, 1.0);\r\n /**\r\n * Specular produces a highlight color on an object.\r\n * Note: This is note affecting PBR materials.\r\n */\r\n _this.specular = new Color3(1.0, 1.0, 1.0);\r\n /**\r\n * Defines the falloff type for this light. This lets overrriding how punctual light are\r\n * falling off base on range or angle.\r\n * This can be set to any values in Light.FALLOFF_x.\r\n *\r\n * Note: This is only useful for PBR Materials at the moment. This could be extended if required to\r\n * other types of materials.\r\n */\r\n _this.falloffType = Light.FALLOFF_DEFAULT;\r\n /**\r\n * Strength of the light.\r\n * Note: By default it is define in the framework own unit.\r\n * Note: In PBR materials the intensityMode can be use to chose what unit the intensity is defined in.\r\n */\r\n _this.intensity = 1.0;\r\n _this._range = Number.MAX_VALUE;\r\n _this._inverseSquaredRange = 0;\r\n /**\r\n * Cached photometric scale default to 1.0 as the automatic intensity mode defaults to 1.0 for every type\r\n * of light.\r\n */\r\n _this._photometricScale = 1.0;\r\n _this._intensityMode = Light.INTENSITYMODE_AUTOMATIC;\r\n _this._radius = 0.00001;\r\n /**\r\n * Defines the rendering priority of the lights. It can help in case of fallback or number of lights\r\n * exceeding the number allowed of the materials.\r\n */\r\n _this.renderPriority = 0;\r\n _this._shadowEnabled = true;\r\n _this._excludeWithLayerMask = 0;\r\n _this._includeOnlyWithLayerMask = 0;\r\n _this._lightmapMode = 0;\r\n /**\r\n * @hidden Internal use only.\r\n */\r\n _this._excludedMeshesIds = new Array();\r\n /**\r\n * @hidden Internal use only.\r\n */\r\n _this._includedOnlyMeshesIds = new Array();\r\n /** @hidden */\r\n _this._isLight = true;\r\n _this.getScene().addLight(_this);\r\n _this._uniformBuffer = new UniformBuffer(_this.getScene().getEngine());\r\n _this._buildUniformLayout();\r\n _this.includedOnlyMeshes = new Array();\r\n _this.excludedMeshes = new Array();\r\n _this._resyncMeshes();\r\n return _this;\r\n }\r\n Object.defineProperty(Light.prototype, \"range\", {\r\n /**\r\n * Defines how far from the source the light is impacting in scene units.\r\n * Note: Unused in PBR material as the distance light falloff is defined following the inverse squared falloff.\r\n */\r\n get: function () {\r\n return this._range;\r\n },\r\n /**\r\n * Defines how far from the source the light is impacting in scene units.\r\n * Note: Unused in PBR material as the distance light falloff is defined following the inverse squared falloff.\r\n */\r\n set: function (value) {\r\n this._range = value;\r\n this._inverseSquaredRange = 1.0 / (this.range * this.range);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Light.prototype, \"intensityMode\", {\r\n /**\r\n * Gets the photometric scale used to interpret the intensity.\r\n * This is only relevant with PBR Materials where the light intensity can be defined in a physical way.\r\n */\r\n get: function () {\r\n return this._intensityMode;\r\n },\r\n /**\r\n * Sets the photometric scale used to interpret the intensity.\r\n * This is only relevant with PBR Materials where the light intensity can be defined in a physical way.\r\n */\r\n set: function (value) {\r\n this._intensityMode = value;\r\n this._computePhotometricScale();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Light.prototype, \"radius\", {\r\n /**\r\n * Gets the light radius used by PBR Materials to simulate soft area lights.\r\n */\r\n get: function () {\r\n return this._radius;\r\n },\r\n /**\r\n * sets the light radius used by PBR Materials to simulate soft area lights.\r\n */\r\n set: function (value) {\r\n this._radius = value;\r\n this._computePhotometricScale();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Light.prototype, \"shadowEnabled\", {\r\n /**\r\n * Gets wether or not the shadows are enabled for this light. This can help turning off/on shadow without detaching\r\n * the current shadow generator.\r\n */\r\n get: function () {\r\n return this._shadowEnabled;\r\n },\r\n /**\r\n * Sets wether or not the shadows are enabled for this light. This can help turning off/on shadow without detaching\r\n * the current shadow generator.\r\n */\r\n set: function (value) {\r\n if (this._shadowEnabled === value) {\r\n return;\r\n }\r\n this._shadowEnabled = value;\r\n this._markMeshesAsLightDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Light.prototype, \"includedOnlyMeshes\", {\r\n /**\r\n * Gets the only meshes impacted by this light.\r\n */\r\n get: function () {\r\n return this._includedOnlyMeshes;\r\n },\r\n /**\r\n * Sets the only meshes impacted by this light.\r\n */\r\n set: function (value) {\r\n this._includedOnlyMeshes = value;\r\n this._hookArrayForIncludedOnly(value);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Light.prototype, \"excludedMeshes\", {\r\n /**\r\n * Gets the meshes not impacted by this light.\r\n */\r\n get: function () {\r\n return this._excludedMeshes;\r\n },\r\n /**\r\n * Sets the meshes not impacted by this light.\r\n */\r\n set: function (value) {\r\n this._excludedMeshes = value;\r\n this._hookArrayForExcluded(value);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Light.prototype, \"excludeWithLayerMask\", {\r\n /**\r\n * Gets the layer id use to find what meshes are not impacted by the light.\r\n * Inactive if 0\r\n */\r\n get: function () {\r\n return this._excludeWithLayerMask;\r\n },\r\n /**\r\n * Sets the layer id use to find what meshes are not impacted by the light.\r\n * Inactive if 0\r\n */\r\n set: function (value) {\r\n this._excludeWithLayerMask = value;\r\n this._resyncMeshes();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Light.prototype, \"includeOnlyWithLayerMask\", {\r\n /**\r\n * Gets the layer id use to find what meshes are impacted by the light.\r\n * Inactive if 0\r\n */\r\n get: function () {\r\n return this._includeOnlyWithLayerMask;\r\n },\r\n /**\r\n * Sets the layer id use to find what meshes are impacted by the light.\r\n * Inactive if 0\r\n */\r\n set: function (value) {\r\n this._includeOnlyWithLayerMask = value;\r\n this._resyncMeshes();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Light.prototype, \"lightmapMode\", {\r\n /**\r\n * Gets the lightmap mode of this light (should be one of the constants defined by Light.LIGHTMAP_x)\r\n */\r\n get: function () {\r\n return this._lightmapMode;\r\n },\r\n /**\r\n * Sets the lightmap mode of this light (should be one of the constants defined by Light.LIGHTMAP_x)\r\n */\r\n set: function (value) {\r\n if (this._lightmapMode === value) {\r\n return;\r\n }\r\n this._lightmapMode = value;\r\n this._markMeshesAsLightDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Sets the passed Effect \"effect\" with the Light textures.\r\n * @param effect The effect to update\r\n * @param lightIndex The index of the light in the effect to update\r\n * @returns The light\r\n */\r\n Light.prototype.transferTexturesToEffect = function (effect, lightIndex) {\r\n // Do nothing by default.\r\n return this;\r\n };\r\n /**\r\n * Binds the lights information from the scene to the effect for the given mesh.\r\n * @param lightIndex Light index\r\n * @param scene The scene where the light belongs to\r\n * @param effect The effect we are binding the data to\r\n * @param useSpecular Defines if specular is supported\r\n * @param rebuildInParallel Specifies whether the shader is rebuilding in parallel\r\n */\r\n Light.prototype._bindLight = function (lightIndex, scene, effect, useSpecular, rebuildInParallel) {\r\n if (rebuildInParallel === void 0) { rebuildInParallel = false; }\r\n var iAsString = lightIndex.toString();\r\n var needUpdate = false;\r\n if (rebuildInParallel && this._uniformBuffer._alreadyBound) {\r\n return;\r\n }\r\n this._uniformBuffer.bindToEffect(effect, \"Light\" + iAsString);\r\n if (this._renderId !== scene.getRenderId() || !this._uniformBuffer.useUbo) {\r\n this._renderId = scene.getRenderId();\r\n var scaledIntensity = this.getScaledIntensity();\r\n this.transferToEffect(effect, iAsString);\r\n this.diffuse.scaleToRef(scaledIntensity, TmpColors.Color3[0]);\r\n this._uniformBuffer.updateColor4(\"vLightDiffuse\", TmpColors.Color3[0], this.range, iAsString);\r\n if (useSpecular) {\r\n this.specular.scaleToRef(scaledIntensity, TmpColors.Color3[1]);\r\n this._uniformBuffer.updateColor4(\"vLightSpecular\", TmpColors.Color3[1], this.radius, iAsString);\r\n }\r\n needUpdate = true;\r\n }\r\n // Textures might still need to be rebound.\r\n this.transferTexturesToEffect(effect, iAsString);\r\n // Shadows\r\n if (scene.shadowsEnabled && this.shadowEnabled) {\r\n var shadowGenerator = this.getShadowGenerator();\r\n if (shadowGenerator) {\r\n shadowGenerator.bindShadowLight(iAsString, effect);\r\n needUpdate = true;\r\n }\r\n }\r\n if (needUpdate) {\r\n this._uniformBuffer.update();\r\n }\r\n };\r\n /**\r\n * Returns the string \"Light\".\r\n * @returns the class name\r\n */\r\n Light.prototype.getClassName = function () {\r\n return \"Light\";\r\n };\r\n /**\r\n * Converts the light information to a readable string for debug purpose.\r\n * @param fullDetails Supports for multiple levels of logging within scene loading\r\n * @returns the human readable light info\r\n */\r\n Light.prototype.toString = function (fullDetails) {\r\n var ret = \"Name: \" + this.name;\r\n ret += \", type: \" + ([\"Point\", \"Directional\", \"Spot\", \"Hemispheric\"])[this.getTypeID()];\r\n if (this.animations) {\r\n for (var i = 0; i < this.animations.length; i++) {\r\n ret += \", animation[0]: \" + this.animations[i].toString(fullDetails);\r\n }\r\n }\r\n if (fullDetails) {\r\n }\r\n return ret;\r\n };\r\n /** @hidden */\r\n Light.prototype._syncParentEnabledState = function () {\r\n _super.prototype._syncParentEnabledState.call(this);\r\n if (!this.isDisposed()) {\r\n this._resyncMeshes();\r\n }\r\n };\r\n /**\r\n * Set the enabled state of this node.\r\n * @param value - the new enabled state\r\n */\r\n Light.prototype.setEnabled = function (value) {\r\n _super.prototype.setEnabled.call(this, value);\r\n this._resyncMeshes();\r\n };\r\n /**\r\n * Returns the Light associated shadow generator if any.\r\n * @return the associated shadow generator.\r\n */\r\n Light.prototype.getShadowGenerator = function () {\r\n return this._shadowGenerator;\r\n };\r\n /**\r\n * Returns a Vector3, the absolute light position in the World.\r\n * @returns the world space position of the light\r\n */\r\n Light.prototype.getAbsolutePosition = function () {\r\n return Vector3.Zero();\r\n };\r\n /**\r\n * Specifies if the light will affect the passed mesh.\r\n * @param mesh The mesh to test against the light\r\n * @return true the mesh is affected otherwise, false.\r\n */\r\n Light.prototype.canAffectMesh = function (mesh) {\r\n if (!mesh) {\r\n return true;\r\n }\r\n if (this.includedOnlyMeshes && this.includedOnlyMeshes.length > 0 && this.includedOnlyMeshes.indexOf(mesh) === -1) {\r\n return false;\r\n }\r\n if (this.excludedMeshes && this.excludedMeshes.length > 0 && this.excludedMeshes.indexOf(mesh) !== -1) {\r\n return false;\r\n }\r\n if (this.includeOnlyWithLayerMask !== 0 && (this.includeOnlyWithLayerMask & mesh.layerMask) === 0) {\r\n return false;\r\n }\r\n if (this.excludeWithLayerMask !== 0 && this.excludeWithLayerMask & mesh.layerMask) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n /**\r\n * Sort function to order lights for rendering.\r\n * @param a First Light object to compare to second.\r\n * @param b Second Light object to compare first.\r\n * @return -1 to reduce's a's index relative to be, 0 for no change, 1 to increase a's index relative to b.\r\n */\r\n Light.CompareLightsPriority = function (a, b) {\r\n //shadow-casting lights have priority over non-shadow-casting lights\r\n //the renderPrioirty is a secondary sort criterion\r\n if (a.shadowEnabled !== b.shadowEnabled) {\r\n return (b.shadowEnabled ? 1 : 0) - (a.shadowEnabled ? 1 : 0);\r\n }\r\n return b.renderPriority - a.renderPriority;\r\n };\r\n /**\r\n * Releases resources associated with this node.\r\n * @param doNotRecurse Set to true to not recurse into each children (recurse into each children by default)\r\n * @param disposeMaterialAndTextures Set to true to also dispose referenced materials and textures (false by default)\r\n */\r\n Light.prototype.dispose = function (doNotRecurse, disposeMaterialAndTextures) {\r\n if (disposeMaterialAndTextures === void 0) { disposeMaterialAndTextures = false; }\r\n if (this._shadowGenerator) {\r\n this._shadowGenerator.dispose();\r\n this._shadowGenerator = null;\r\n }\r\n // Animations\r\n this.getScene().stopAnimation(this);\r\n // Remove from meshes\r\n for (var _i = 0, _a = this.getScene().meshes; _i < _a.length; _i++) {\r\n var mesh = _a[_i];\r\n mesh._removeLightSource(this, true);\r\n }\r\n this._uniformBuffer.dispose();\r\n // Remove from scene\r\n this.getScene().removeLight(this);\r\n _super.prototype.dispose.call(this, doNotRecurse, disposeMaterialAndTextures);\r\n };\r\n /**\r\n * Returns the light type ID (integer).\r\n * @returns The light Type id as a constant defines in Light.LIGHTTYPEID_x\r\n */\r\n Light.prototype.getTypeID = function () {\r\n return 0;\r\n };\r\n /**\r\n * Returns the intensity scaled by the Photometric Scale according to the light type and intensity mode.\r\n * @returns the scaled intensity in intensity mode unit\r\n */\r\n Light.prototype.getScaledIntensity = function () {\r\n return this._photometricScale * this.intensity;\r\n };\r\n /**\r\n * Returns a new Light object, named \"name\", from the current one.\r\n * @param name The name of the cloned light\r\n * @param newParent The parent of this light, if it has one\r\n * @returns the new created light\r\n */\r\n Light.prototype.clone = function (name, newParent) {\r\n if (newParent === void 0) { newParent = null; }\r\n var constructor = Light.GetConstructorFromName(this.getTypeID(), name, this.getScene());\r\n if (!constructor) {\r\n return null;\r\n }\r\n var clonedLight = SerializationHelper.Clone(constructor, this);\r\n if (newParent) {\r\n clonedLight.parent = newParent;\r\n }\r\n clonedLight.setEnabled(this.isEnabled());\r\n return clonedLight;\r\n };\r\n /**\r\n * Serializes the current light into a Serialization object.\r\n * @returns the serialized object.\r\n */\r\n Light.prototype.serialize = function () {\r\n var serializationObject = SerializationHelper.Serialize(this);\r\n // Type\r\n serializationObject.type = this.getTypeID();\r\n // Parent\r\n if (this.parent) {\r\n serializationObject.parentId = this.parent.id;\r\n }\r\n // Inclusion / exclusions\r\n if (this.excludedMeshes.length > 0) {\r\n serializationObject.excludedMeshesIds = [];\r\n this.excludedMeshes.forEach(function (mesh) {\r\n serializationObject.excludedMeshesIds.push(mesh.id);\r\n });\r\n }\r\n if (this.includedOnlyMeshes.length > 0) {\r\n serializationObject.includedOnlyMeshesIds = [];\r\n this.includedOnlyMeshes.forEach(function (mesh) {\r\n serializationObject.includedOnlyMeshesIds.push(mesh.id);\r\n });\r\n }\r\n // Animations\r\n SerializationHelper.AppendSerializedAnimations(this, serializationObject);\r\n serializationObject.ranges = this.serializeAnimationRanges();\r\n return serializationObject;\r\n };\r\n /**\r\n * Creates a new typed light from the passed type (integer) : point light = 0, directional light = 1, spot light = 2, hemispheric light = 3.\r\n * This new light is named \"name\" and added to the passed scene.\r\n * @param type Type according to the types available in Light.LIGHTTYPEID_x\r\n * @param name The friendly name of the light\r\n * @param scene The scene the new light will belong to\r\n * @returns the constructor function\r\n */\r\n Light.GetConstructorFromName = function (type, name, scene) {\r\n var constructorFunc = Node.Construct(\"Light_Type_\" + type, name, scene);\r\n if (constructorFunc) {\r\n return constructorFunc;\r\n }\r\n // Default to no light for none present once.\r\n return null;\r\n };\r\n /**\r\n * Parses the passed \"parsedLight\" and returns a new instanced Light from this parsing.\r\n * @param parsedLight The JSON representation of the light\r\n * @param scene The scene to create the parsed light in\r\n * @returns the created light after parsing\r\n */\r\n Light.Parse = function (parsedLight, scene) {\r\n var constructor = Light.GetConstructorFromName(parsedLight.type, parsedLight.name, scene);\r\n if (!constructor) {\r\n return null;\r\n }\r\n var light = SerializationHelper.Parse(constructor, parsedLight, scene);\r\n // Inclusion / exclusions\r\n if (parsedLight.excludedMeshesIds) {\r\n light._excludedMeshesIds = parsedLight.excludedMeshesIds;\r\n }\r\n if (parsedLight.includedOnlyMeshesIds) {\r\n light._includedOnlyMeshesIds = parsedLight.includedOnlyMeshesIds;\r\n }\r\n // Parent\r\n if (parsedLight.parentId) {\r\n light._waitingParentId = parsedLight.parentId;\r\n }\r\n // Falloff\r\n if (parsedLight.falloffType !== undefined) {\r\n light.falloffType = parsedLight.falloffType;\r\n }\r\n // Lightmaps\r\n if (parsedLight.lightmapMode !== undefined) {\r\n light.lightmapMode = parsedLight.lightmapMode;\r\n }\r\n // Animations\r\n if (parsedLight.animations) {\r\n for (var animationIndex = 0; animationIndex < parsedLight.animations.length; animationIndex++) {\r\n var parsedAnimation = parsedLight.animations[animationIndex];\r\n var internalClass = _TypeStore.GetClass(\"BABYLON.Animation\");\r\n if (internalClass) {\r\n light.animations.push(internalClass.Parse(parsedAnimation));\r\n }\r\n }\r\n Node.ParseAnimationRanges(light, parsedLight, scene);\r\n }\r\n if (parsedLight.autoAnimate) {\r\n scene.beginAnimation(light, parsedLight.autoAnimateFrom, parsedLight.autoAnimateTo, parsedLight.autoAnimateLoop, parsedLight.autoAnimateSpeed || 1.0);\r\n }\r\n return light;\r\n };\r\n Light.prototype._hookArrayForExcluded = function (array) {\r\n var _this = this;\r\n var oldPush = array.push;\r\n array.push = function () {\r\n var items = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n items[_i] = arguments[_i];\r\n }\r\n var result = oldPush.apply(array, items);\r\n for (var _a = 0, items_1 = items; _a < items_1.length; _a++) {\r\n var item = items_1[_a];\r\n item._resyncLightSource(_this);\r\n }\r\n return result;\r\n };\r\n var oldSplice = array.splice;\r\n array.splice = function (index, deleteCount) {\r\n var deleted = oldSplice.apply(array, [index, deleteCount]);\r\n for (var _i = 0, deleted_1 = deleted; _i < deleted_1.length; _i++) {\r\n var item = deleted_1[_i];\r\n item._resyncLightSource(_this);\r\n }\r\n return deleted;\r\n };\r\n for (var _i = 0, array_1 = array; _i < array_1.length; _i++) {\r\n var item = array_1[_i];\r\n item._resyncLightSource(this);\r\n }\r\n };\r\n Light.prototype._hookArrayForIncludedOnly = function (array) {\r\n var _this = this;\r\n var oldPush = array.push;\r\n array.push = function () {\r\n var items = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n items[_i] = arguments[_i];\r\n }\r\n var result = oldPush.apply(array, items);\r\n _this._resyncMeshes();\r\n return result;\r\n };\r\n var oldSplice = array.splice;\r\n array.splice = function (index, deleteCount) {\r\n var deleted = oldSplice.apply(array, [index, deleteCount]);\r\n _this._resyncMeshes();\r\n return deleted;\r\n };\r\n this._resyncMeshes();\r\n };\r\n Light.prototype._resyncMeshes = function () {\r\n for (var _i = 0, _a = this.getScene().meshes; _i < _a.length; _i++) {\r\n var mesh = _a[_i];\r\n mesh._resyncLightSource(this);\r\n }\r\n };\r\n /**\r\n * Forces the meshes to update their light related information in their rendering used effects\r\n * @hidden Internal Use Only\r\n */\r\n Light.prototype._markMeshesAsLightDirty = function () {\r\n for (var _i = 0, _a = this.getScene().meshes; _i < _a.length; _i++) {\r\n var mesh = _a[_i];\r\n if (mesh.lightSources.indexOf(this) !== -1) {\r\n mesh._markSubMeshesAsLightDirty();\r\n }\r\n }\r\n };\r\n /**\r\n * Recomputes the cached photometric scale if needed.\r\n */\r\n Light.prototype._computePhotometricScale = function () {\r\n this._photometricScale = this._getPhotometricScale();\r\n this.getScene().resetCachedMaterial();\r\n };\r\n /**\r\n * Returns the Photometric Scale according to the light type and intensity mode.\r\n */\r\n Light.prototype._getPhotometricScale = function () {\r\n var photometricScale = 0.0;\r\n var lightTypeID = this.getTypeID();\r\n //get photometric mode\r\n var photometricMode = this.intensityMode;\r\n if (photometricMode === Light.INTENSITYMODE_AUTOMATIC) {\r\n if (lightTypeID === Light.LIGHTTYPEID_DIRECTIONALLIGHT) {\r\n photometricMode = Light.INTENSITYMODE_ILLUMINANCE;\r\n }\r\n else {\r\n photometricMode = Light.INTENSITYMODE_LUMINOUSINTENSITY;\r\n }\r\n }\r\n //compute photometric scale\r\n switch (lightTypeID) {\r\n case Light.LIGHTTYPEID_POINTLIGHT:\r\n case Light.LIGHTTYPEID_SPOTLIGHT:\r\n switch (photometricMode) {\r\n case Light.INTENSITYMODE_LUMINOUSPOWER:\r\n photometricScale = 1.0 / (4.0 * Math.PI);\r\n break;\r\n case Light.INTENSITYMODE_LUMINOUSINTENSITY:\r\n photometricScale = 1.0;\r\n break;\r\n case Light.INTENSITYMODE_LUMINANCE:\r\n photometricScale = this.radius * this.radius;\r\n break;\r\n }\r\n break;\r\n case Light.LIGHTTYPEID_DIRECTIONALLIGHT:\r\n switch (photometricMode) {\r\n case Light.INTENSITYMODE_ILLUMINANCE:\r\n photometricScale = 1.0;\r\n break;\r\n case Light.INTENSITYMODE_LUMINANCE:\r\n // When radius (and therefore solid angle) is non-zero a directional lights brightness can be specified via central (peak) luminance.\r\n // For a directional light the 'radius' defines the angular radius (in radians) rather than world-space radius (e.g. in metres).\r\n var apexAngleRadians = this.radius;\r\n // Impose a minimum light angular size to avoid the light becoming an infinitely small angular light source (i.e. a dirac delta function).\r\n apexAngleRadians = Math.max(apexAngleRadians, 0.001);\r\n var solidAngle = 2.0 * Math.PI * (1.0 - Math.cos(apexAngleRadians));\r\n photometricScale = solidAngle;\r\n break;\r\n }\r\n break;\r\n case Light.LIGHTTYPEID_HEMISPHERICLIGHT:\r\n // No fall off in hemisperic light.\r\n photometricScale = 1.0;\r\n break;\r\n }\r\n return photometricScale;\r\n };\r\n /**\r\n * Reorder the light in the scene according to their defined priority.\r\n * @hidden Internal Use Only\r\n */\r\n Light.prototype._reorderLightsInScene = function () {\r\n var scene = this.getScene();\r\n if (this._renderPriority != 0) {\r\n scene.requireLightSorting = true;\r\n }\r\n this.getScene().sortLightsByPriority();\r\n };\r\n /**\r\n * Falloff Default: light is falling off following the material specification:\r\n * standard material is using standard falloff whereas pbr material can request special falloff per materials.\r\n */\r\n Light.FALLOFF_DEFAULT = 0;\r\n /**\r\n * Falloff Physical: light is falling off following the inverse squared distance law.\r\n */\r\n Light.FALLOFF_PHYSICAL = 1;\r\n /**\r\n * Falloff gltf: light is falling off as described in the gltf moving to PBR document\r\n * to enhance interoperability with other engines.\r\n */\r\n Light.FALLOFF_GLTF = 2;\r\n /**\r\n * Falloff Standard: light is falling off like in the standard material\r\n * to enhance interoperability with other materials.\r\n */\r\n Light.FALLOFF_STANDARD = 3;\r\n //lightmapMode Consts\r\n /**\r\n * If every light affecting the material is in this lightmapMode,\r\n * material.lightmapTexture adds or multiplies\r\n * (depends on material.useLightmapAsShadowmap)\r\n * after every other light calculations.\r\n */\r\n Light.LIGHTMAP_DEFAULT = 0;\r\n /**\r\n * material.lightmapTexture as only diffuse lighting from this light\r\n * adds only specular lighting from this light\r\n * adds dynamic shadows\r\n */\r\n Light.LIGHTMAP_SPECULAR = 1;\r\n /**\r\n * material.lightmapTexture as only lighting\r\n * no light calculation from this light\r\n * only adds dynamic shadows from this light\r\n */\r\n Light.LIGHTMAP_SHADOWSONLY = 2;\r\n // Intensity Mode Consts\r\n /**\r\n * Each light type uses the default quantity according to its type:\r\n * point/spot lights use luminous intensity\r\n * directional lights use illuminance\r\n */\r\n Light.INTENSITYMODE_AUTOMATIC = 0;\r\n /**\r\n * lumen (lm)\r\n */\r\n Light.INTENSITYMODE_LUMINOUSPOWER = 1;\r\n /**\r\n * candela (lm/sr)\r\n */\r\n Light.INTENSITYMODE_LUMINOUSINTENSITY = 2;\r\n /**\r\n * lux (lm/m^2)\r\n */\r\n Light.INTENSITYMODE_ILLUMINANCE = 3;\r\n /**\r\n * nit (cd/m^2)\r\n */\r\n Light.INTENSITYMODE_LUMINANCE = 4;\r\n // Light types ids const.\r\n /**\r\n * Light type const id of the point light.\r\n */\r\n Light.LIGHTTYPEID_POINTLIGHT = 0;\r\n /**\r\n * Light type const id of the directional light.\r\n */\r\n Light.LIGHTTYPEID_DIRECTIONALLIGHT = 1;\r\n /**\r\n * Light type const id of the spot light.\r\n */\r\n Light.LIGHTTYPEID_SPOTLIGHT = 2;\r\n /**\r\n * Light type const id of the hemispheric light.\r\n */\r\n Light.LIGHTTYPEID_HEMISPHERICLIGHT = 3;\r\n __decorate([\r\n serializeAsColor3()\r\n ], Light.prototype, \"diffuse\", void 0);\r\n __decorate([\r\n serializeAsColor3()\r\n ], Light.prototype, \"specular\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Light.prototype, \"falloffType\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Light.prototype, \"intensity\", void 0);\r\n __decorate([\r\n serialize()\r\n ], Light.prototype, \"range\", null);\r\n __decorate([\r\n serialize()\r\n ], Light.prototype, \"intensityMode\", null);\r\n __decorate([\r\n serialize()\r\n ], Light.prototype, \"radius\", null);\r\n __decorate([\r\n serialize()\r\n ], Light.prototype, \"_renderPriority\", void 0);\r\n __decorate([\r\n expandToProperty(\"_reorderLightsInScene\")\r\n ], Light.prototype, \"renderPriority\", void 0);\r\n __decorate([\r\n serialize(\"shadowEnabled\")\r\n ], Light.prototype, \"_shadowEnabled\", void 0);\r\n __decorate([\r\n serialize(\"excludeWithLayerMask\")\r\n ], Light.prototype, \"_excludeWithLayerMask\", void 0);\r\n __decorate([\r\n serialize(\"includeOnlyWithLayerMask\")\r\n ], Light.prototype, \"_includeOnlyWithLayerMask\", void 0);\r\n __decorate([\r\n serialize(\"lightmapMode\")\r\n ], Light.prototype, \"_lightmapMode\", void 0);\r\n return Light;\r\n}(Node));\r\nexport { Light };\r\n//# sourceMappingURL=light.js.map","import { VertexBuffer } from \"./buffer\";\r\nimport { IntersectionInfo } from \"../Collisions/intersectionInfo\";\r\nimport { BoundingInfo } from \"../Culling/boundingInfo\";\r\nimport { extractMinAndMaxIndexed } from '../Maths/math.functions';\r\n/**\r\n * Defines a subdivision inside a mesh\r\n */\r\nvar SubMesh = /** @class */ (function () {\r\n /**\r\n * Creates a new submesh\r\n * @param materialIndex defines the material index to use\r\n * @param verticesStart defines vertex index start\r\n * @param verticesCount defines vertices count\r\n * @param indexStart defines index start\r\n * @param indexCount defines indices count\r\n * @param mesh defines the parent mesh\r\n * @param renderingMesh defines an optional rendering mesh\r\n * @param createBoundingBox defines if bounding box should be created for this submesh\r\n * @param addToMesh defines a boolean indicating that the submesh must be added to the mesh.subMeshes array (true by default)\r\n */\r\n function SubMesh(\r\n /** the material index to use */\r\n materialIndex, \r\n /** vertex index start */\r\n verticesStart, \r\n /** vertices count */\r\n verticesCount, \r\n /** index start */\r\n indexStart, \r\n /** indices count */\r\n indexCount, mesh, renderingMesh, createBoundingBox, addToMesh) {\r\n if (createBoundingBox === void 0) { createBoundingBox = true; }\r\n if (addToMesh === void 0) { addToMesh = true; }\r\n this.materialIndex = materialIndex;\r\n this.verticesStart = verticesStart;\r\n this.verticesCount = verticesCount;\r\n this.indexStart = indexStart;\r\n this.indexCount = indexCount;\r\n /** @hidden */\r\n this._materialDefines = null;\r\n /** @hidden */\r\n this._materialEffect = null;\r\n /** @hidden */\r\n this._effectOverride = null;\r\n /** @hidden */\r\n this._linesIndexCount = 0;\r\n this._linesIndexBuffer = null;\r\n /** @hidden */\r\n this._lastColliderWorldVertices = null;\r\n /** @hidden */\r\n this._lastColliderTransformMatrix = null;\r\n /** @hidden */\r\n this._renderId = 0;\r\n /** @hidden */\r\n this._alphaIndex = 0;\r\n /** @hidden */\r\n this._distanceToCamera = 0;\r\n this._currentMaterial = null;\r\n this._mesh = mesh;\r\n this._renderingMesh = renderingMesh || mesh;\r\n if (addToMesh) {\r\n mesh.subMeshes.push(this);\r\n }\r\n this._trianglePlanes = [];\r\n this._id = mesh.subMeshes.length - 1;\r\n if (createBoundingBox) {\r\n this.refreshBoundingInfo();\r\n mesh.computeWorldMatrix(true);\r\n }\r\n }\r\n Object.defineProperty(SubMesh.prototype, \"materialDefines\", {\r\n /**\r\n * Gets material defines used by the effect associated to the sub mesh\r\n */\r\n get: function () {\r\n return this._materialDefines;\r\n },\r\n /**\r\n * Sets material defines used by the effect associated to the sub mesh\r\n */\r\n set: function (defines) {\r\n this._materialDefines = defines;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(SubMesh.prototype, \"effect\", {\r\n /**\r\n * Gets associated effect\r\n */\r\n get: function () {\r\n var _a;\r\n return (_a = this._effectOverride) !== null && _a !== void 0 ? _a : this._materialEffect;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Sets associated effect (effect used to render this submesh)\r\n * @param effect defines the effect to associate with\r\n * @param defines defines the set of defines used to compile this effect\r\n */\r\n SubMesh.prototype.setEffect = function (effect, defines) {\r\n if (defines === void 0) { defines = null; }\r\n if (this._materialEffect === effect) {\r\n if (!effect) {\r\n this._materialDefines = null;\r\n }\r\n return;\r\n }\r\n this._materialDefines = defines;\r\n this._materialEffect = effect;\r\n };\r\n /**\r\n * Add a new submesh to a mesh\r\n * @param materialIndex defines the material index to use\r\n * @param verticesStart defines vertex index start\r\n * @param verticesCount defines vertices count\r\n * @param indexStart defines index start\r\n * @param indexCount defines indices count\r\n * @param mesh defines the parent mesh\r\n * @param renderingMesh defines an optional rendering mesh\r\n * @param createBoundingBox defines if bounding box should be created for this submesh\r\n * @returns the new submesh\r\n */\r\n SubMesh.AddToMesh = function (materialIndex, verticesStart, verticesCount, indexStart, indexCount, mesh, renderingMesh, createBoundingBox) {\r\n if (createBoundingBox === void 0) { createBoundingBox = true; }\r\n return new SubMesh(materialIndex, verticesStart, verticesCount, indexStart, indexCount, mesh, renderingMesh, createBoundingBox);\r\n };\r\n Object.defineProperty(SubMesh.prototype, \"IsGlobal\", {\r\n /**\r\n * Returns true if this submesh covers the entire parent mesh\r\n * @ignorenaming\r\n */\r\n get: function () {\r\n return (this.verticesStart === 0 && this.verticesCount === this._mesh.getTotalVertices());\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Returns the submesh BoudingInfo object\r\n * @returns current bounding info (or mesh's one if the submesh is global)\r\n */\r\n SubMesh.prototype.getBoundingInfo = function () {\r\n if (this.IsGlobal) {\r\n return this._mesh.getBoundingInfo();\r\n }\r\n return this._boundingInfo;\r\n };\r\n /**\r\n * Sets the submesh BoundingInfo\r\n * @param boundingInfo defines the new bounding info to use\r\n * @returns the SubMesh\r\n */\r\n SubMesh.prototype.setBoundingInfo = function (boundingInfo) {\r\n this._boundingInfo = boundingInfo;\r\n return this;\r\n };\r\n /**\r\n * Returns the mesh of the current submesh\r\n * @return the parent mesh\r\n */\r\n SubMesh.prototype.getMesh = function () {\r\n return this._mesh;\r\n };\r\n /**\r\n * Returns the rendering mesh of the submesh\r\n * @returns the rendering mesh (could be different from parent mesh)\r\n */\r\n SubMesh.prototype.getRenderingMesh = function () {\r\n return this._renderingMesh;\r\n };\r\n /**\r\n * Returns the replacement mesh of the submesh\r\n * @returns the replacement mesh (could be different from parent mesh)\r\n */\r\n SubMesh.prototype.getReplacementMesh = function () {\r\n return this._mesh._internalAbstractMeshDataInfo._actAsRegularMesh ? this._mesh : null;\r\n };\r\n /**\r\n * Returns the effective mesh of the submesh\r\n * @returns the effective mesh (could be different from parent mesh)\r\n */\r\n SubMesh.prototype.getEffectiveMesh = function () {\r\n var replacementMesh = this._mesh._internalAbstractMeshDataInfo._actAsRegularMesh ? this._mesh : null;\r\n return replacementMesh ? replacementMesh : this._renderingMesh;\r\n };\r\n /**\r\n * Returns the submesh material\r\n * @returns null or the current material\r\n */\r\n SubMesh.prototype.getMaterial = function () {\r\n var rootMaterial = this._renderingMesh.material;\r\n if (rootMaterial === null || rootMaterial === undefined) {\r\n return this._mesh.getScene().defaultMaterial;\r\n }\r\n else if (this._IsMultiMaterial(rootMaterial)) {\r\n var effectiveMaterial = rootMaterial.getSubMaterial(this.materialIndex);\r\n if (this._currentMaterial !== effectiveMaterial) {\r\n this._currentMaterial = effectiveMaterial;\r\n this._materialDefines = null;\r\n }\r\n return effectiveMaterial;\r\n }\r\n return rootMaterial;\r\n };\r\n SubMesh.prototype._IsMultiMaterial = function (material) {\r\n return material.getSubMaterial !== undefined;\r\n };\r\n // Methods\r\n /**\r\n * Sets a new updated BoundingInfo object to the submesh\r\n * @param data defines an optional position array to use to determine the bounding info\r\n * @returns the SubMesh\r\n */\r\n SubMesh.prototype.refreshBoundingInfo = function (data) {\r\n if (data === void 0) { data = null; }\r\n this._lastColliderWorldVertices = null;\r\n if (this.IsGlobal || !this._renderingMesh || !this._renderingMesh.geometry) {\r\n return this;\r\n }\r\n if (!data) {\r\n data = this._renderingMesh.getVerticesData(VertexBuffer.PositionKind);\r\n }\r\n if (!data) {\r\n this._boundingInfo = this._mesh.getBoundingInfo();\r\n return this;\r\n }\r\n var indices = this._renderingMesh.getIndices();\r\n var extend;\r\n //is this the only submesh?\r\n if (this.indexStart === 0 && this.indexCount === indices.length) {\r\n var boundingInfo = this._renderingMesh.getBoundingInfo();\r\n //the rendering mesh's bounding info can be used, it is the standard submesh for all indices.\r\n extend = { minimum: boundingInfo.minimum.clone(), maximum: boundingInfo.maximum.clone() };\r\n }\r\n else {\r\n extend = extractMinAndMaxIndexed(data, indices, this.indexStart, this.indexCount, this._renderingMesh.geometry.boundingBias);\r\n }\r\n if (this._boundingInfo) {\r\n this._boundingInfo.reConstruct(extend.minimum, extend.maximum);\r\n }\r\n else {\r\n this._boundingInfo = new BoundingInfo(extend.minimum, extend.maximum);\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n SubMesh.prototype._checkCollision = function (collider) {\r\n var boundingInfo = this.getBoundingInfo();\r\n return boundingInfo._checkCollision(collider);\r\n };\r\n /**\r\n * Updates the submesh BoundingInfo\r\n * @param world defines the world matrix to use to update the bounding info\r\n * @returns the submesh\r\n */\r\n SubMesh.prototype.updateBoundingInfo = function (world) {\r\n var boundingInfo = this.getBoundingInfo();\r\n if (!boundingInfo) {\r\n this.refreshBoundingInfo();\r\n boundingInfo = this.getBoundingInfo();\r\n }\r\n if (boundingInfo) {\r\n boundingInfo.update(world);\r\n }\r\n return this;\r\n };\r\n /**\r\n * True is the submesh bounding box intersects the frustum defined by the passed array of planes.\r\n * @param frustumPlanes defines the frustum planes\r\n * @returns true if the submesh is intersecting with the frustum\r\n */\r\n SubMesh.prototype.isInFrustum = function (frustumPlanes) {\r\n var boundingInfo = this.getBoundingInfo();\r\n if (!boundingInfo) {\r\n return false;\r\n }\r\n return boundingInfo.isInFrustum(frustumPlanes, this._mesh.cullingStrategy);\r\n };\r\n /**\r\n * True is the submesh bounding box is completely inside the frustum defined by the passed array of planes\r\n * @param frustumPlanes defines the frustum planes\r\n * @returns true if the submesh is inside the frustum\r\n */\r\n SubMesh.prototype.isCompletelyInFrustum = function (frustumPlanes) {\r\n var boundingInfo = this.getBoundingInfo();\r\n if (!boundingInfo) {\r\n return false;\r\n }\r\n return boundingInfo.isCompletelyInFrustum(frustumPlanes);\r\n };\r\n /**\r\n * Renders the submesh\r\n * @param enableAlphaMode defines if alpha needs to be used\r\n * @returns the submesh\r\n */\r\n SubMesh.prototype.render = function (enableAlphaMode) {\r\n this._renderingMesh.render(this, enableAlphaMode, this._mesh._internalAbstractMeshDataInfo._actAsRegularMesh ? this._mesh : undefined);\r\n return this;\r\n };\r\n /**\r\n * @hidden\r\n */\r\n SubMesh.prototype._getLinesIndexBuffer = function (indices, engine) {\r\n if (!this._linesIndexBuffer) {\r\n var linesIndices = [];\r\n for (var index = this.indexStart; index < this.indexStart + this.indexCount; index += 3) {\r\n linesIndices.push(indices[index], indices[index + 1], indices[index + 1], indices[index + 2], indices[index + 2], indices[index]);\r\n }\r\n this._linesIndexBuffer = engine.createIndexBuffer(linesIndices);\r\n this._linesIndexCount = linesIndices.length;\r\n }\r\n return this._linesIndexBuffer;\r\n };\r\n /**\r\n * Checks if the submesh intersects with a ray\r\n * @param ray defines the ray to test\r\n * @returns true is the passed ray intersects the submesh bounding box\r\n */\r\n SubMesh.prototype.canIntersects = function (ray) {\r\n var boundingInfo = this.getBoundingInfo();\r\n if (!boundingInfo) {\r\n return false;\r\n }\r\n return ray.intersectsBox(boundingInfo.boundingBox);\r\n };\r\n /**\r\n * Intersects current submesh with a ray\r\n * @param ray defines the ray to test\r\n * @param positions defines mesh's positions array\r\n * @param indices defines mesh's indices array\r\n * @param fastCheck defines if the first intersection will be used (and not the closest)\r\n * @param trianglePredicate defines an optional predicate used to select faces when a mesh intersection is detected\r\n * @returns intersection info or null if no intersection\r\n */\r\n SubMesh.prototype.intersects = function (ray, positions, indices, fastCheck, trianglePredicate) {\r\n var material = this.getMaterial();\r\n if (!material) {\r\n return null;\r\n }\r\n var step = 3;\r\n var checkStopper = false;\r\n switch (material.fillMode) {\r\n case 3:\r\n case 4:\r\n case 5:\r\n case 6:\r\n case 8:\r\n return null;\r\n case 7:\r\n step = 1;\r\n checkStopper = true;\r\n break;\r\n default:\r\n break;\r\n }\r\n // LineMesh first as it's also a Mesh...\r\n if (this._mesh.getClassName() === \"InstancedLinesMesh\" || this._mesh.getClassName() === \"LinesMesh\") {\r\n // Check if mesh is unindexed\r\n if (!indices.length) {\r\n return this._intersectUnIndexedLines(ray, positions, indices, this._mesh.intersectionThreshold, fastCheck);\r\n }\r\n return this._intersectLines(ray, positions, indices, this._mesh.intersectionThreshold, fastCheck);\r\n }\r\n else {\r\n // Check if mesh is unindexed\r\n if (!indices.length && this._mesh._unIndexed) {\r\n return this._intersectUnIndexedTriangles(ray, positions, indices, fastCheck, trianglePredicate);\r\n }\r\n return this._intersectTriangles(ray, positions, indices, step, checkStopper, fastCheck, trianglePredicate);\r\n }\r\n };\r\n /** @hidden */\r\n SubMesh.prototype._intersectLines = function (ray, positions, indices, intersectionThreshold, fastCheck) {\r\n var intersectInfo = null;\r\n // Line test\r\n for (var index = this.indexStart; index < this.indexStart + this.indexCount; index += 2) {\r\n var p0 = positions[indices[index]];\r\n var p1 = positions[indices[index + 1]];\r\n var length = ray.intersectionSegment(p0, p1, intersectionThreshold);\r\n if (length < 0) {\r\n continue;\r\n }\r\n if (fastCheck || !intersectInfo || length < intersectInfo.distance) {\r\n intersectInfo = new IntersectionInfo(null, null, length);\r\n intersectInfo.faceId = index / 2;\r\n if (fastCheck) {\r\n break;\r\n }\r\n }\r\n }\r\n return intersectInfo;\r\n };\r\n /** @hidden */\r\n SubMesh.prototype._intersectUnIndexedLines = function (ray, positions, indices, intersectionThreshold, fastCheck) {\r\n var intersectInfo = null;\r\n // Line test\r\n for (var index = this.verticesStart; index < this.verticesStart + this.verticesCount; index += 2) {\r\n var p0 = positions[index];\r\n var p1 = positions[index + 1];\r\n var length = ray.intersectionSegment(p0, p1, intersectionThreshold);\r\n if (length < 0) {\r\n continue;\r\n }\r\n if (fastCheck || !intersectInfo || length < intersectInfo.distance) {\r\n intersectInfo = new IntersectionInfo(null, null, length);\r\n intersectInfo.faceId = index / 2;\r\n if (fastCheck) {\r\n break;\r\n }\r\n }\r\n }\r\n return intersectInfo;\r\n };\r\n /** @hidden */\r\n SubMesh.prototype._intersectTriangles = function (ray, positions, indices, step, checkStopper, fastCheck, trianglePredicate) {\r\n var intersectInfo = null;\r\n // Triangles test\r\n var faceID = -1;\r\n for (var index = this.indexStart; index < this.indexStart + this.indexCount; index += step) {\r\n faceID++;\r\n var indexA = indices[index];\r\n var indexB = indices[index + 1];\r\n var indexC = indices[index + 2];\r\n if (checkStopper && indexC === 0xFFFFFFFF) {\r\n index += 2;\r\n continue;\r\n }\r\n var p0 = positions[indexA];\r\n var p1 = positions[indexB];\r\n var p2 = positions[indexC];\r\n if (trianglePredicate && !trianglePredicate(p0, p1, p2, ray)) {\r\n continue;\r\n }\r\n var currentIntersectInfo = ray.intersectsTriangle(p0, p1, p2);\r\n if (currentIntersectInfo) {\r\n if (currentIntersectInfo.distance < 0) {\r\n continue;\r\n }\r\n if (fastCheck || !intersectInfo || currentIntersectInfo.distance < intersectInfo.distance) {\r\n intersectInfo = currentIntersectInfo;\r\n intersectInfo.faceId = faceID;\r\n if (fastCheck) {\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n return intersectInfo;\r\n };\r\n /** @hidden */\r\n SubMesh.prototype._intersectUnIndexedTriangles = function (ray, positions, indices, fastCheck, trianglePredicate) {\r\n var intersectInfo = null;\r\n // Triangles test\r\n for (var index = this.verticesStart; index < this.verticesStart + this.verticesCount; index += 3) {\r\n var p0 = positions[index];\r\n var p1 = positions[index + 1];\r\n var p2 = positions[index + 2];\r\n if (trianglePredicate && !trianglePredicate(p0, p1, p2, ray)) {\r\n continue;\r\n }\r\n var currentIntersectInfo = ray.intersectsTriangle(p0, p1, p2);\r\n if (currentIntersectInfo) {\r\n if (currentIntersectInfo.distance < 0) {\r\n continue;\r\n }\r\n if (fastCheck || !intersectInfo || currentIntersectInfo.distance < intersectInfo.distance) {\r\n intersectInfo = currentIntersectInfo;\r\n intersectInfo.faceId = index / 3;\r\n if (fastCheck) {\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n return intersectInfo;\r\n };\r\n /** @hidden */\r\n SubMesh.prototype._rebuild = function () {\r\n if (this._linesIndexBuffer) {\r\n this._linesIndexBuffer = null;\r\n }\r\n };\r\n // Clone\r\n /**\r\n * Creates a new submesh from the passed mesh\r\n * @param newMesh defines the new hosting mesh\r\n * @param newRenderingMesh defines an optional rendering mesh\r\n * @returns the new submesh\r\n */\r\n SubMesh.prototype.clone = function (newMesh, newRenderingMesh) {\r\n var result = new SubMesh(this.materialIndex, this.verticesStart, this.verticesCount, this.indexStart, this.indexCount, newMesh, newRenderingMesh, false);\r\n if (!this.IsGlobal) {\r\n var boundingInfo = this.getBoundingInfo();\r\n if (!boundingInfo) {\r\n return result;\r\n }\r\n result._boundingInfo = new BoundingInfo(boundingInfo.minimum, boundingInfo.maximum);\r\n }\r\n return result;\r\n };\r\n // Dispose\r\n /**\r\n * Release associated resources\r\n */\r\n SubMesh.prototype.dispose = function () {\r\n if (this._linesIndexBuffer) {\r\n this._mesh.getScene().getEngine()._releaseBuffer(this._linesIndexBuffer);\r\n this._linesIndexBuffer = null;\r\n }\r\n // Remove from mesh\r\n var index = this._mesh.subMeshes.indexOf(this);\r\n this._mesh.subMeshes.splice(index, 1);\r\n };\r\n /**\r\n * Gets the class name\r\n * @returns the string \"SubMesh\".\r\n */\r\n SubMesh.prototype.getClassName = function () {\r\n return \"SubMesh\";\r\n };\r\n // Statics\r\n /**\r\n * Creates a new submesh from indices data\r\n * @param materialIndex the index of the main mesh material\r\n * @param startIndex the index where to start the copy in the mesh indices array\r\n * @param indexCount the number of indices to copy then from the startIndex\r\n * @param mesh the main mesh to create the submesh from\r\n * @param renderingMesh the optional rendering mesh\r\n * @returns a new submesh\r\n */\r\n SubMesh.CreateFromIndices = function (materialIndex, startIndex, indexCount, mesh, renderingMesh) {\r\n var minVertexIndex = Number.MAX_VALUE;\r\n var maxVertexIndex = -Number.MAX_VALUE;\r\n var whatWillRender = (renderingMesh || mesh);\r\n var indices = whatWillRender.getIndices();\r\n for (var index = startIndex; index < startIndex + indexCount; index++) {\r\n var vertexIndex = indices[index];\r\n if (vertexIndex < minVertexIndex) {\r\n minVertexIndex = vertexIndex;\r\n }\r\n if (vertexIndex > maxVertexIndex) {\r\n maxVertexIndex = vertexIndex;\r\n }\r\n }\r\n return new SubMesh(materialIndex, minVertexIndex, maxVertexIndex - minVertexIndex + 1, startIndex, indexCount, mesh, renderingMesh);\r\n };\r\n return SubMesh;\r\n}());\r\nexport { SubMesh };\r\n//# sourceMappingURL=subMesh.js.map","import { __extends } from \"tslib\";\r\n/**\r\n * Gather the list of keyboard event types as constants.\r\n */\r\nvar KeyboardEventTypes = /** @class */ (function () {\r\n function KeyboardEventTypes() {\r\n }\r\n /**\r\n * The keydown event is fired when a key becomes active (pressed).\r\n */\r\n KeyboardEventTypes.KEYDOWN = 0x01;\r\n /**\r\n * The keyup event is fired when a key has been released.\r\n */\r\n KeyboardEventTypes.KEYUP = 0x02;\r\n return KeyboardEventTypes;\r\n}());\r\nexport { KeyboardEventTypes };\r\n/**\r\n * This class is used to store keyboard related info for the onKeyboardObservable event.\r\n */\r\nvar KeyboardInfo = /** @class */ (function () {\r\n /**\r\n * Instantiates a new keyboard info.\r\n * This class is used to store keyboard related info for the onKeyboardObservable event.\r\n * @param type Defines the type of event (KeyboardEventTypes)\r\n * @param event Defines the related dom event\r\n */\r\n function KeyboardInfo(\r\n /**\r\n * Defines the type of event (KeyboardEventTypes)\r\n */\r\n type, \r\n /**\r\n * Defines the related dom event\r\n */\r\n event) {\r\n this.type = type;\r\n this.event = event;\r\n }\r\n return KeyboardInfo;\r\n}());\r\nexport { KeyboardInfo };\r\n/**\r\n * This class is used to store keyboard related info for the onPreKeyboardObservable event.\r\n * Set the skipOnKeyboardObservable property to true if you want the engine to stop any process after this event is triggered, even not calling onKeyboardObservable\r\n */\r\nvar KeyboardInfoPre = /** @class */ (function (_super) {\r\n __extends(KeyboardInfoPre, _super);\r\n /**\r\n * Instantiates a new keyboard pre info.\r\n * This class is used to store keyboard related info for the onPreKeyboardObservable event.\r\n * @param type Defines the type of event (KeyboardEventTypes)\r\n * @param event Defines the related dom event\r\n */\r\n function KeyboardInfoPre(\r\n /**\r\n * Defines the type of event (KeyboardEventTypes)\r\n */\r\n type, \r\n /**\r\n * Defines the related dom event\r\n */\r\n event) {\r\n var _this = _super.call(this, type, event) || this;\r\n _this.type = type;\r\n _this.event = event;\r\n _this.skipOnPointerObservable = false;\r\n return _this;\r\n }\r\n return KeyboardInfoPre;\r\n}(KeyboardInfo));\r\nexport { KeyboardInfoPre };\r\n//# sourceMappingURL=keyboardEvents.js.map","/**\r\n * Gather the list of clipboard event types as constants.\r\n */\r\nvar ClipboardEventTypes = /** @class */ (function () {\r\n function ClipboardEventTypes() {\r\n }\r\n /**\r\n * The clipboard event is fired when a copy command is active (pressed).\r\n */\r\n ClipboardEventTypes.COPY = 0x01; //\r\n /**\r\n * The clipboard event is fired when a cut command is active (pressed).\r\n */\r\n ClipboardEventTypes.CUT = 0x02;\r\n /**\r\n * The clipboard event is fired when a paste command is active (pressed).\r\n */\r\n ClipboardEventTypes.PASTE = 0x03;\r\n return ClipboardEventTypes;\r\n}());\r\nexport { ClipboardEventTypes };\r\n/**\r\n * This class is used to store clipboard related info for the onClipboardObservable event.\r\n */\r\nvar ClipboardInfo = /** @class */ (function () {\r\n /**\r\n *Creates an instance of ClipboardInfo.\r\n * @param type Defines the type of event (BABYLON.ClipboardEventTypes)\r\n * @param event Defines the related dom event\r\n */\r\n function ClipboardInfo(\r\n /**\r\n * Defines the type of event (BABYLON.ClipboardEventTypes)\r\n */\r\n type, \r\n /**\r\n * Defines the related dom event\r\n */\r\n event) {\r\n this.type = type;\r\n this.event = event;\r\n }\r\n /**\r\n * Get the clipboard event's type from the keycode.\r\n * @param keyCode Defines the keyCode for the current keyboard event.\r\n * @return {number}\r\n */\r\n ClipboardInfo.GetTypeFromCharacter = function (keyCode) {\r\n var charCode = keyCode;\r\n //TODO: add codes for extended ASCII\r\n switch (charCode) {\r\n case 67: return ClipboardEventTypes.COPY;\r\n case 86: return ClipboardEventTypes.PASTE;\r\n case 88: return ClipboardEventTypes.CUT;\r\n default: return -1;\r\n }\r\n };\r\n return ClipboardInfo;\r\n}());\r\nexport { ClipboardInfo };\r\n//# sourceMappingURL=clipboardEvents.js.map","import { Vector3 } from '../Maths/math.vector';\r\n/**\r\n * @hidden\r\n */\r\nvar _MeshCollisionData = /** @class */ (function () {\r\n function _MeshCollisionData() {\r\n this._checkCollisions = false;\r\n this._collisionMask = -1;\r\n this._collisionGroup = -1;\r\n this._surroundingMeshes = null;\r\n this._collider = null;\r\n this._oldPositionForCollisions = new Vector3(0, 0, 0);\r\n this._diffPositionForCollisions = new Vector3(0, 0, 0);\r\n this._collisionResponse = true;\r\n }\r\n return _MeshCollisionData;\r\n}());\r\nexport { _MeshCollisionData };\r\n//# sourceMappingURL=meshCollisionData.js.map","import { __extends } from \"tslib\";\r\nimport { Tools } from \"../Misc/tools\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { Quaternion, Matrix, Vector3, TmpVectors } from \"../Maths/math.vector\";\r\nimport { Engine } from \"../Engines/engine\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { VertexData } from \"../Meshes/mesh.vertexData\";\r\nimport { TransformNode } from \"../Meshes/transformNode\";\r\nimport { PickingInfo } from \"../Collisions/pickingInfo\";\r\nimport { BoundingInfo } from \"../Culling/boundingInfo\";\r\nimport { _MeshCollisionData } from '../Collisions/meshCollisionData';\r\nimport { _DevTools } from '../Misc/devTools';\r\nimport { extractMinAndMax } from '../Maths/math.functions';\r\nimport { Color3, Color4 } from '../Maths/math.color';\r\nimport { Epsilon } from '../Maths/math.constants';\r\nimport { Axis } from '../Maths/math.axis';\r\nimport { _TypeStore } from '../Misc/typeStore';\r\n/** @hidden */\r\nvar _FacetDataStorage = /** @class */ (function () {\r\n function _FacetDataStorage() {\r\n this.facetNb = 0; // facet number\r\n this.partitioningSubdivisions = 10; // number of subdivisions per axis in the partioning space\r\n this.partitioningBBoxRatio = 1.01; // the partioning array space is by default 1% bigger than the bounding box\r\n this.facetDataEnabled = false; // is the facet data feature enabled on this mesh ?\r\n this.facetParameters = {}; // keep a reference to the object parameters to avoid memory re-allocation\r\n this.bbSize = Vector3.Zero(); // bbox size approximated for facet data\r\n this.subDiv = {\r\n max: 1,\r\n X: 1,\r\n Y: 1,\r\n Z: 1\r\n };\r\n this.facetDepthSort = false; // is the facet depth sort to be computed\r\n this.facetDepthSortEnabled = false; // is the facet depth sort initialized\r\n }\r\n return _FacetDataStorage;\r\n}());\r\n/**\r\n * @hidden\r\n **/\r\nvar _InternalAbstractMeshDataInfo = /** @class */ (function () {\r\n function _InternalAbstractMeshDataInfo() {\r\n this._hasVertexAlpha = false;\r\n this._useVertexColors = true;\r\n this._numBoneInfluencers = 4;\r\n this._applyFog = true;\r\n this._receiveShadows = false;\r\n this._facetData = new _FacetDataStorage();\r\n this._visibility = 1.0;\r\n this._skeleton = null;\r\n this._layerMask = 0x0FFFFFFF;\r\n this._computeBonesUsingShaders = true;\r\n this._isActive = false;\r\n this._onlyForInstances = false;\r\n this._isActiveIntermediate = false;\r\n this._onlyForInstancesIntermediate = false;\r\n this._actAsRegularMesh = false;\r\n this._currentLOD = null;\r\n this._currentLODIsUpToDate = false;\r\n }\r\n return _InternalAbstractMeshDataInfo;\r\n}());\r\n/**\r\n * Class used to store all common mesh properties\r\n */\r\nvar AbstractMesh = /** @class */ (function (_super) {\r\n __extends(AbstractMesh, _super);\r\n // Constructor\r\n /**\r\n * Creates a new AbstractMesh\r\n * @param name defines the name of the mesh\r\n * @param scene defines the hosting scene\r\n */\r\n function AbstractMesh(name, scene) {\r\n if (scene === void 0) { scene = null; }\r\n var _this = _super.call(this, name, scene, false) || this;\r\n // Internal data\r\n /** @hidden */\r\n _this._internalAbstractMeshDataInfo = new _InternalAbstractMeshDataInfo();\r\n /**\r\n * The culling strategy to use to check whether the mesh must be rendered or not.\r\n * This value can be changed at any time and will be used on the next render mesh selection.\r\n * The possible values are :\r\n * - AbstractMesh.CULLINGSTRATEGY_STANDARD\r\n * - AbstractMesh.CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY\r\n * - AbstractMesh.CULLINGSTRATEGY_OPTIMISTIC_INCLUSION\r\n * - AbstractMesh.CULLINGSTRATEGY_OPTIMISTIC_INCLUSION_THEN_BSPHERE_ONLY\r\n * Please read each static variable documentation to get details about the culling process.\r\n * */\r\n _this.cullingStrategy = AbstractMesh.CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY;\r\n // Events\r\n /**\r\n * An event triggered when this mesh collides with another one\r\n */\r\n _this.onCollideObservable = new Observable();\r\n /**\r\n * An event triggered when the collision's position changes\r\n */\r\n _this.onCollisionPositionChangeObservable = new Observable();\r\n /**\r\n * An event triggered when material is changed\r\n */\r\n _this.onMaterialChangedObservable = new Observable();\r\n // Properties\r\n /**\r\n * Gets or sets the orientation for POV movement & rotation\r\n */\r\n _this.definedFacingForward = true;\r\n /** @hidden */\r\n _this._occlusionQuery = null;\r\n /** @hidden */\r\n _this._renderingGroup = null;\r\n /** Gets or sets the alpha index used to sort transparent meshes\r\n * @see https://doc.babylonjs.com/resources/transparency_and_how_meshes_are_rendered#alpha-index\r\n */\r\n _this.alphaIndex = Number.MAX_VALUE;\r\n /**\r\n * Gets or sets a boolean indicating if the mesh is visible (renderable). Default is true\r\n */\r\n _this.isVisible = true;\r\n /**\r\n * Gets or sets a boolean indicating if the mesh can be picked (by scene.pick for instance or through actions). Default is true\r\n */\r\n _this.isPickable = true;\r\n /** Gets or sets a boolean indicating that bounding boxes of subMeshes must be rendered as well (false by default) */\r\n _this.showSubMeshesBoundingBox = false;\r\n /** Gets or sets a boolean indicating if the mesh must be considered as a ray blocker for lens flares (false by default)\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_lens_flares\r\n */\r\n _this.isBlocker = false;\r\n /**\r\n * Gets or sets a boolean indicating that pointer move events must be supported on this mesh (false by default)\r\n */\r\n _this.enablePointerMoveEvents = false;\r\n _this._renderingGroupId = 0;\r\n _this._material = null;\r\n /** Defines color to use when rendering outline */\r\n _this.outlineColor = Color3.Red();\r\n /** Define width to use when rendering outline */\r\n _this.outlineWidth = 0.02;\r\n /** Defines color to use when rendering overlay */\r\n _this.overlayColor = Color3.Red();\r\n /** Defines alpha to use when rendering overlay */\r\n _this.overlayAlpha = 0.5;\r\n /** Gets or sets a boolean indicating that internal octree (if available) can be used to boost submeshes selection (true by default) */\r\n _this.useOctreeForRenderingSelection = true;\r\n /** Gets or sets a boolean indicating that internal octree (if available) can be used to boost submeshes picking (true by default) */\r\n _this.useOctreeForPicking = true;\r\n /** Gets or sets a boolean indicating that internal octree (if available) can be used to boost submeshes collision (true by default) */\r\n _this.useOctreeForCollisions = true;\r\n /**\r\n * True if the mesh must be rendered in any case (this will shortcut the frustum clipping phase)\r\n */\r\n _this.alwaysSelectAsActiveMesh = false;\r\n /**\r\n * Gets or sets a boolean indicating that the bounding info does not need to be kept in sync (for performance reason)\r\n */\r\n _this.doNotSyncBoundingInfo = false;\r\n /**\r\n * Gets or sets the current action manager\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions\r\n */\r\n _this.actionManager = null;\r\n // Collisions\r\n _this._meshCollisionData = new _MeshCollisionData();\r\n /**\r\n * Gets or sets the ellipsoid used to impersonate this mesh when using collision engine (default is (0.5, 1, 0.5))\r\n * @see https://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity\r\n */\r\n _this.ellipsoid = new Vector3(0.5, 1, 0.5);\r\n /**\r\n * Gets or sets the ellipsoid offset used to impersonate this mesh when using collision engine (default is (0, 0, 0))\r\n * @see https://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity\r\n */\r\n _this.ellipsoidOffset = new Vector3(0, 0, 0);\r\n // Edges\r\n /**\r\n * Defines edge width used when edgesRenderer is enabled\r\n * @see https://www.babylonjs-playground.com/#10OJSG#13\r\n */\r\n _this.edgesWidth = 1;\r\n /**\r\n * Defines edge color used when edgesRenderer is enabled\r\n * @see https://www.babylonjs-playground.com/#10OJSG#13\r\n */\r\n _this.edgesColor = new Color4(1, 0, 0, 1);\r\n /** @hidden */\r\n _this._edgesRenderer = null;\r\n /** @hidden */\r\n _this._masterMesh = null;\r\n /** @hidden */\r\n _this._boundingInfo = null;\r\n /** @hidden */\r\n _this._renderId = 0;\r\n /** @hidden */\r\n _this._intersectionsInProgress = new Array();\r\n /** @hidden */\r\n _this._unIndexed = false;\r\n /** @hidden */\r\n _this._lightSources = new Array();\r\n // Loading properties\r\n /** @hidden */\r\n _this._waitingData = {\r\n lods: null,\r\n actions: null,\r\n freezeWorldMatrix: null\r\n };\r\n /** @hidden */\r\n _this._bonesTransformMatrices = null;\r\n /** @hidden */\r\n _this._transformMatrixTexture = null;\r\n /**\r\n * An event triggered when the mesh is rebuilt.\r\n */\r\n _this.onRebuildObservable = new Observable();\r\n _this._onCollisionPositionChange = function (collisionId, newPosition, collidedMesh) {\r\n if (collidedMesh === void 0) { collidedMesh = null; }\r\n newPosition.subtractToRef(_this._meshCollisionData._oldPositionForCollisions, _this._meshCollisionData._diffPositionForCollisions);\r\n if (_this._meshCollisionData._diffPositionForCollisions.length() > Engine.CollisionsEpsilon) {\r\n _this.position.addInPlace(_this._meshCollisionData._diffPositionForCollisions);\r\n }\r\n if (collidedMesh) {\r\n _this.onCollideObservable.notifyObservers(collidedMesh);\r\n }\r\n _this.onCollisionPositionChangeObservable.notifyObservers(_this.position);\r\n };\r\n _this.getScene().addMesh(_this);\r\n _this._resyncLightSources();\r\n return _this;\r\n }\r\n Object.defineProperty(AbstractMesh, \"BILLBOARDMODE_NONE\", {\r\n /**\r\n * No billboard\r\n */\r\n get: function () {\r\n return TransformNode.BILLBOARDMODE_NONE;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh, \"BILLBOARDMODE_X\", {\r\n /** Billboard on X axis */\r\n get: function () {\r\n return TransformNode.BILLBOARDMODE_X;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh, \"BILLBOARDMODE_Y\", {\r\n /** Billboard on Y axis */\r\n get: function () {\r\n return TransformNode.BILLBOARDMODE_Y;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh, \"BILLBOARDMODE_Z\", {\r\n /** Billboard on Z axis */\r\n get: function () {\r\n return TransformNode.BILLBOARDMODE_Z;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh, \"BILLBOARDMODE_ALL\", {\r\n /** Billboard on all axes */\r\n get: function () {\r\n return TransformNode.BILLBOARDMODE_ALL;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh, \"BILLBOARDMODE_USE_POSITION\", {\r\n /** Billboard on using position instead of orientation */\r\n get: function () {\r\n return TransformNode.BILLBOARDMODE_USE_POSITION;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"facetNb\", {\r\n /**\r\n * Gets the number of facets in the mesh\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata#what-is-a-mesh-facet\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._facetData.facetNb;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"partitioningSubdivisions\", {\r\n /**\r\n * Gets or set the number (integer) of subdivisions per axis in the partioning space\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata#tweaking-the-partitioning\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._facetData.partitioningSubdivisions;\r\n },\r\n set: function (nb) {\r\n this._internalAbstractMeshDataInfo._facetData.partitioningSubdivisions = nb;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"partitioningBBoxRatio\", {\r\n /**\r\n * The ratio (float) to apply to the bouding box size to set to the partioning space.\r\n * Ex : 1.01 (default) the partioning space is 1% bigger than the bounding box\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata#tweaking-the-partitioning\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._facetData.partitioningBBoxRatio;\r\n },\r\n set: function (ratio) {\r\n this._internalAbstractMeshDataInfo._facetData.partitioningBBoxRatio = ratio;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"mustDepthSortFacets\", {\r\n /**\r\n * Gets or sets a boolean indicating that the facets must be depth sorted on next call to `updateFacetData()`.\r\n * Works only for updatable meshes.\r\n * Doesn't work with multi-materials\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata#facet-depth-sort\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._facetData.facetDepthSort;\r\n },\r\n set: function (sort) {\r\n this._internalAbstractMeshDataInfo._facetData.facetDepthSort = sort;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"facetDepthSortFrom\", {\r\n /**\r\n * The location (Vector3) where the facet depth sort must be computed from.\r\n * By default, the active camera position.\r\n * Used only when facet depth sort is enabled\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata#facet-depth-sort\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._facetData.facetDepthSortFrom;\r\n },\r\n set: function (location) {\r\n this._internalAbstractMeshDataInfo._facetData.facetDepthSortFrom = location;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"isFacetDataEnabled\", {\r\n /**\r\n * gets a boolean indicating if facetData is enabled\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata#what-is-a-mesh-facet\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._facetData.facetDataEnabled;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n AbstractMesh.prototype._updateNonUniformScalingState = function (value) {\r\n if (!_super.prototype._updateNonUniformScalingState.call(this, value)) {\r\n return false;\r\n }\r\n this._markSubMeshesAsMiscDirty();\r\n return true;\r\n };\r\n Object.defineProperty(AbstractMesh.prototype, \"onCollide\", {\r\n /** Set a function to call when this mesh collides with another one */\r\n set: function (callback) {\r\n if (this._meshCollisionData._onCollideObserver) {\r\n this.onCollideObservable.remove(this._meshCollisionData._onCollideObserver);\r\n }\r\n this._meshCollisionData._onCollideObserver = this.onCollideObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"onCollisionPositionChange\", {\r\n /** Set a function to call when the collision's position changes */\r\n set: function (callback) {\r\n if (this._meshCollisionData._onCollisionPositionChangeObserver) {\r\n this.onCollisionPositionChangeObservable.remove(this._meshCollisionData._onCollisionPositionChangeObserver);\r\n }\r\n this._meshCollisionData._onCollisionPositionChangeObserver = this.onCollisionPositionChangeObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"visibility\", {\r\n /**\r\n * Gets or sets mesh visibility between 0 and 1 (default is 1)\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._visibility;\r\n },\r\n /**\r\n * Gets or sets mesh visibility between 0 and 1 (default is 1)\r\n */\r\n set: function (value) {\r\n if (this._internalAbstractMeshDataInfo._visibility === value) {\r\n return;\r\n }\r\n this._internalAbstractMeshDataInfo._visibility = value;\r\n this._markSubMeshesAsMiscDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"renderingGroupId\", {\r\n /**\r\n * Specifies the rendering group id for this mesh (0 by default)\r\n * @see https://doc.babylonjs.com/resources/transparency_and_how_meshes_are_rendered#rendering-groups\r\n */\r\n get: function () {\r\n return this._renderingGroupId;\r\n },\r\n set: function (value) {\r\n this._renderingGroupId = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"material\", {\r\n /** Gets or sets current material */\r\n get: function () {\r\n return this._material;\r\n },\r\n set: function (value) {\r\n if (this._material === value) {\r\n return;\r\n }\r\n // remove from material mesh map id needed\r\n if (this._material && this._material.meshMap) {\r\n this._material.meshMap[this.uniqueId] = undefined;\r\n }\r\n this._material = value;\r\n if (value && value.meshMap) {\r\n value.meshMap[this.uniqueId] = this;\r\n }\r\n if (this.onMaterialChangedObservable.hasObservers()) {\r\n this.onMaterialChangedObservable.notifyObservers(this);\r\n }\r\n if (!this.subMeshes) {\r\n return;\r\n }\r\n this._unBindEffect();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"receiveShadows\", {\r\n /**\r\n * Gets or sets a boolean indicating that this mesh can receive realtime shadows\r\n * @see https://doc.babylonjs.com/babylon101/shadows\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._receiveShadows;\r\n },\r\n set: function (value) {\r\n if (this._internalAbstractMeshDataInfo._receiveShadows === value) {\r\n return;\r\n }\r\n this._internalAbstractMeshDataInfo._receiveShadows = value;\r\n this._markSubMeshesAsLightDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"hasVertexAlpha\", {\r\n /** Gets or sets a boolean indicating that this mesh contains vertex color data with alpha values */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._hasVertexAlpha;\r\n },\r\n set: function (value) {\r\n if (this._internalAbstractMeshDataInfo._hasVertexAlpha === value) {\r\n return;\r\n }\r\n this._internalAbstractMeshDataInfo._hasVertexAlpha = value;\r\n this._markSubMeshesAsAttributesDirty();\r\n this._markSubMeshesAsMiscDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"useVertexColors\", {\r\n /** Gets or sets a boolean indicating that this mesh needs to use vertex color data to render (if this kind of vertex data is available in the geometry) */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._useVertexColors;\r\n },\r\n set: function (value) {\r\n if (this._internalAbstractMeshDataInfo._useVertexColors === value) {\r\n return;\r\n }\r\n this._internalAbstractMeshDataInfo._useVertexColors = value;\r\n this._markSubMeshesAsAttributesDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"computeBonesUsingShaders\", {\r\n /**\r\n * Gets or sets a boolean indicating that bone animations must be computed by the CPU (false by default)\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._computeBonesUsingShaders;\r\n },\r\n set: function (value) {\r\n if (this._internalAbstractMeshDataInfo._computeBonesUsingShaders === value) {\r\n return;\r\n }\r\n this._internalAbstractMeshDataInfo._computeBonesUsingShaders = value;\r\n this._markSubMeshesAsAttributesDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"numBoneInfluencers\", {\r\n /** Gets or sets the number of allowed bone influences per vertex (4 by default) */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._numBoneInfluencers;\r\n },\r\n set: function (value) {\r\n if (this._internalAbstractMeshDataInfo._numBoneInfluencers === value) {\r\n return;\r\n }\r\n this._internalAbstractMeshDataInfo._numBoneInfluencers = value;\r\n this._markSubMeshesAsAttributesDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"applyFog\", {\r\n /** Gets or sets a boolean indicating that this mesh will allow fog to be rendered on it (true by default) */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._applyFog;\r\n },\r\n set: function (value) {\r\n if (this._internalAbstractMeshDataInfo._applyFog === value) {\r\n return;\r\n }\r\n this._internalAbstractMeshDataInfo._applyFog = value;\r\n this._markSubMeshesAsMiscDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"layerMask\", {\r\n /**\r\n * Gets or sets the current layer mask (default is 0x0FFFFFFF)\r\n * @see https://doc.babylonjs.com/how_to/layermasks_and_multi-cam_textures\r\n */\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._layerMask;\r\n },\r\n set: function (value) {\r\n if (value === this._internalAbstractMeshDataInfo._layerMask) {\r\n return;\r\n }\r\n this._internalAbstractMeshDataInfo._layerMask = value;\r\n this._resyncLightSources();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"collisionMask\", {\r\n /**\r\n * Gets or sets a collision mask used to mask collisions (default is -1).\r\n * A collision between A and B will happen if A.collisionGroup & b.collisionMask !== 0\r\n */\r\n get: function () {\r\n return this._meshCollisionData._collisionMask;\r\n },\r\n set: function (mask) {\r\n this._meshCollisionData._collisionMask = !isNaN(mask) ? mask : -1;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"collisionResponse\", {\r\n /**\r\n * Gets or sets a collision response flag (default is true).\r\n * when collisionResponse is false, events are still triggered but colliding entity has no response\r\n * This helps creating trigger volume when user wants collision feedback events but not position/velocity\r\n * to respond to the collision.\r\n */\r\n get: function () {\r\n return this._meshCollisionData._collisionResponse;\r\n },\r\n set: function (response) {\r\n this._meshCollisionData._collisionResponse = response;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"collisionGroup\", {\r\n /**\r\n * Gets or sets the current collision group mask (-1 by default).\r\n * A collision between A and B will happen if A.collisionGroup & b.collisionMask !== 0\r\n */\r\n get: function () {\r\n return this._meshCollisionData._collisionGroup;\r\n },\r\n set: function (mask) {\r\n this._meshCollisionData._collisionGroup = !isNaN(mask) ? mask : -1;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"surroundingMeshes\", {\r\n /**\r\n * Gets or sets current surrounding meshes (null by default).\r\n *\r\n * By default collision detection is tested against every mesh in the scene.\r\n * It is possible to set surroundingMeshes to a defined list of meshes and then only these specified\r\n * meshes will be tested for the collision.\r\n *\r\n * Note: if set to an empty array no collision will happen when this mesh is moved.\r\n */\r\n get: function () {\r\n return this._meshCollisionData._surroundingMeshes;\r\n },\r\n set: function (meshes) {\r\n this._meshCollisionData._surroundingMeshes = meshes;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"lightSources\", {\r\n /** Gets the list of lights affecting that mesh */\r\n get: function () {\r\n return this._lightSources;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"_positions\", {\r\n /** @hidden */\r\n get: function () {\r\n return null;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"skeleton\", {\r\n get: function () {\r\n return this._internalAbstractMeshDataInfo._skeleton;\r\n },\r\n /**\r\n * Gets or sets a skeleton to apply skining transformations\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_bones_and_skeletons\r\n */\r\n set: function (value) {\r\n var skeleton = this._internalAbstractMeshDataInfo._skeleton;\r\n if (skeleton && skeleton.needInitialSkinMatrix) {\r\n skeleton._unregisterMeshWithPoseMatrix(this);\r\n }\r\n if (value && value.needInitialSkinMatrix) {\r\n value._registerMeshWithPoseMatrix(this);\r\n }\r\n this._internalAbstractMeshDataInfo._skeleton = value;\r\n if (!this._internalAbstractMeshDataInfo._skeleton) {\r\n this._bonesTransformMatrices = null;\r\n }\r\n this._markSubMeshesAsAttributesDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Returns the string \"AbstractMesh\"\r\n * @returns \"AbstractMesh\"\r\n */\r\n AbstractMesh.prototype.getClassName = function () {\r\n return \"AbstractMesh\";\r\n };\r\n /**\r\n * Gets a string representation of the current mesh\r\n * @param fullDetails defines a boolean indicating if full details must be included\r\n * @returns a string representation of the current mesh\r\n */\r\n AbstractMesh.prototype.toString = function (fullDetails) {\r\n var ret = \"Name: \" + this.name + \", isInstance: \" + (this.getClassName() !== \"InstancedMesh\" ? \"YES\" : \"NO\");\r\n ret += \", # of submeshes: \" + (this.subMeshes ? this.subMeshes.length : 0);\r\n var skeleton = this._internalAbstractMeshDataInfo._skeleton;\r\n if (skeleton) {\r\n ret += \", skeleton: \" + skeleton.name;\r\n }\r\n if (fullDetails) {\r\n ret += \", billboard mode: \" + ([\"NONE\", \"X\", \"Y\", null, \"Z\", null, null, \"ALL\"])[this.billboardMode];\r\n ret += \", freeze wrld mat: \" + (this._isWorldMatrixFrozen || this._waitingData.freezeWorldMatrix ? \"YES\" : \"NO\");\r\n }\r\n return ret;\r\n };\r\n /**\r\n * @hidden\r\n */\r\n AbstractMesh.prototype._getEffectiveParent = function () {\r\n if (this._masterMesh && this.billboardMode !== TransformNode.BILLBOARDMODE_NONE) {\r\n return this._masterMesh;\r\n }\r\n return _super.prototype._getEffectiveParent.call(this);\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._getActionManagerForTrigger = function (trigger, initialCall) {\r\n if (initialCall === void 0) { initialCall = true; }\r\n if (this.actionManager && (initialCall || this.actionManager.isRecursive)) {\r\n if (trigger) {\r\n if (this.actionManager.hasSpecificTrigger(trigger)) {\r\n return this.actionManager;\r\n }\r\n }\r\n else {\r\n return this.actionManager;\r\n }\r\n }\r\n if (!this.parent) {\r\n return null;\r\n }\r\n return this.parent._getActionManagerForTrigger(trigger, false);\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._rebuild = function () {\r\n this.onRebuildObservable.notifyObservers(this);\r\n if (this._occlusionQuery) {\r\n this._occlusionQuery = null;\r\n }\r\n if (!this.subMeshes) {\r\n return;\r\n }\r\n for (var _i = 0, _a = this.subMeshes; _i < _a.length; _i++) {\r\n var subMesh = _a[_i];\r\n subMesh._rebuild();\r\n }\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._resyncLightSources = function () {\r\n this._lightSources.length = 0;\r\n for (var _i = 0, _a = this.getScene().lights; _i < _a.length; _i++) {\r\n var light = _a[_i];\r\n if (!light.isEnabled()) {\r\n continue;\r\n }\r\n if (light.canAffectMesh(this)) {\r\n this._lightSources.push(light);\r\n }\r\n }\r\n this._markSubMeshesAsLightDirty();\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._resyncLightSource = function (light) {\r\n var isIn = light.isEnabled() && light.canAffectMesh(this);\r\n var index = this._lightSources.indexOf(light);\r\n var removed = false;\r\n if (index === -1) {\r\n if (!isIn) {\r\n return;\r\n }\r\n this._lightSources.push(light);\r\n }\r\n else {\r\n if (isIn) {\r\n return;\r\n }\r\n removed = true;\r\n this._lightSources.splice(index, 1);\r\n }\r\n this._markSubMeshesAsLightDirty(removed);\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._unBindEffect = function () {\r\n for (var _i = 0, _a = this.subMeshes; _i < _a.length; _i++) {\r\n var subMesh = _a[_i];\r\n subMesh.setEffect(null);\r\n }\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._removeLightSource = function (light, dispose) {\r\n var index = this._lightSources.indexOf(light);\r\n if (index === -1) {\r\n return;\r\n }\r\n this._lightSources.splice(index, 1);\r\n this._markSubMeshesAsLightDirty(dispose);\r\n };\r\n AbstractMesh.prototype._markSubMeshesAsDirty = function (func) {\r\n if (!this.subMeshes) {\r\n return;\r\n }\r\n for (var _i = 0, _a = this.subMeshes; _i < _a.length; _i++) {\r\n var subMesh = _a[_i];\r\n if (subMesh._materialDefines) {\r\n func(subMesh._materialDefines);\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._markSubMeshesAsLightDirty = function (dispose) {\r\n if (dispose === void 0) { dispose = false; }\r\n this._markSubMeshesAsDirty(function (defines) { return defines.markAsLightDirty(dispose); });\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._markSubMeshesAsAttributesDirty = function () {\r\n this._markSubMeshesAsDirty(function (defines) { return defines.markAsAttributesDirty(); });\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._markSubMeshesAsMiscDirty = function () {\r\n this._markSubMeshesAsDirty(function (defines) { return defines.markAsMiscDirty(); });\r\n };\r\n Object.defineProperty(AbstractMesh.prototype, \"scaling\", {\r\n /**\r\n * Gets or sets a Vector3 depicting the mesh scaling along each local axis X, Y, Z. Default is (1.0, 1.0, 1.0)\r\n */\r\n get: function () {\r\n return this._scaling;\r\n },\r\n set: function (newScaling) {\r\n this._scaling = newScaling;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"isBlocked\", {\r\n // Methods\r\n /**\r\n * Returns true if the mesh is blocked. Implemented by child classes\r\n */\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Returns the mesh itself by default. Implemented by child classes\r\n * @param camera defines the camera to use to pick the right LOD level\r\n * @returns the currentAbstractMesh\r\n */\r\n AbstractMesh.prototype.getLOD = function (camera) {\r\n return this;\r\n };\r\n /**\r\n * Returns 0 by default. Implemented by child classes\r\n * @returns an integer\r\n */\r\n AbstractMesh.prototype.getTotalVertices = function () {\r\n return 0;\r\n };\r\n /**\r\n * Returns a positive integer : the total number of indices in this mesh geometry.\r\n * @returns the numner of indices or zero if the mesh has no geometry.\r\n */\r\n AbstractMesh.prototype.getTotalIndices = function () {\r\n return 0;\r\n };\r\n /**\r\n * Returns null by default. Implemented by child classes\r\n * @returns null\r\n */\r\n AbstractMesh.prototype.getIndices = function () {\r\n return null;\r\n };\r\n /**\r\n * Returns the array of the requested vertex data kind. Implemented by child classes\r\n * @param kind defines the vertex data kind to use\r\n * @returns null\r\n */\r\n AbstractMesh.prototype.getVerticesData = function (kind) {\r\n return null;\r\n };\r\n /**\r\n * Sets the vertex data of the mesh geometry for the requested `kind`.\r\n * If the mesh has no geometry, a new Geometry object is set to the mesh and then passed this vertex data.\r\n * Note that a new underlying VertexBuffer object is created each call.\r\n * If the `kind` is the `PositionKind`, the mesh BoundingInfo is renewed, so the bounding box and sphere, and the mesh World Matrix is recomputed.\r\n * @param kind defines vertex data kind:\r\n * * VertexBuffer.PositionKind\r\n * * VertexBuffer.UVKind\r\n * * VertexBuffer.UV2Kind\r\n * * VertexBuffer.UV3Kind\r\n * * VertexBuffer.UV4Kind\r\n * * VertexBuffer.UV5Kind\r\n * * VertexBuffer.UV6Kind\r\n * * VertexBuffer.ColorKind\r\n * * VertexBuffer.MatricesIndicesKind\r\n * * VertexBuffer.MatricesIndicesExtraKind\r\n * * VertexBuffer.MatricesWeightsKind\r\n * * VertexBuffer.MatricesWeightsExtraKind\r\n * @param data defines the data source\r\n * @param updatable defines if the data must be flagged as updatable (or static)\r\n * @param stride defines the vertex stride (size of an entire vertex). Can be null and in this case will be deduced from vertex data kind\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.setVerticesData = function (kind, data, updatable, stride) {\r\n return this;\r\n };\r\n /**\r\n * Updates the existing vertex data of the mesh geometry for the requested `kind`.\r\n * If the mesh has no geometry, it is simply returned as it is.\r\n * @param kind defines vertex data kind:\r\n * * VertexBuffer.PositionKind\r\n * * VertexBuffer.UVKind\r\n * * VertexBuffer.UV2Kind\r\n * * VertexBuffer.UV3Kind\r\n * * VertexBuffer.UV4Kind\r\n * * VertexBuffer.UV5Kind\r\n * * VertexBuffer.UV6Kind\r\n * * VertexBuffer.ColorKind\r\n * * VertexBuffer.MatricesIndicesKind\r\n * * VertexBuffer.MatricesIndicesExtraKind\r\n * * VertexBuffer.MatricesWeightsKind\r\n * * VertexBuffer.MatricesWeightsExtraKind\r\n * @param data defines the data source\r\n * @param updateExtends If `kind` is `PositionKind` and if `updateExtends` is true, the mesh BoundingInfo is renewed, so the bounding box and sphere, and the mesh World Matrix is recomputed\r\n * @param makeItUnique If true, a new global geometry is created from this data and is set to the mesh\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.updateVerticesData = function (kind, data, updateExtends, makeItUnique) {\r\n return this;\r\n };\r\n /**\r\n * Sets the mesh indices,\r\n * If the mesh has no geometry, a new Geometry object is created and set to the mesh.\r\n * @param indices Expects an array populated with integers or a typed array (Int32Array, Uint32Array, Uint16Array)\r\n * @param totalVertices Defines the total number of vertices\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.setIndices = function (indices, totalVertices) {\r\n return this;\r\n };\r\n /**\r\n * Gets a boolean indicating if specific vertex data is present\r\n * @param kind defines the vertex data kind to use\r\n * @returns true is data kind is present\r\n */\r\n AbstractMesh.prototype.isVerticesDataPresent = function (kind) {\r\n return false;\r\n };\r\n /**\r\n * Returns the mesh BoundingInfo object or creates a new one and returns if it was undefined.\r\n * Note that it returns a shallow bounding of the mesh (i.e. it does not include children).\r\n * To get the full bounding of all children, call `getHierarchyBoundingVectors` instead.\r\n * @returns a BoundingInfo\r\n */\r\n AbstractMesh.prototype.getBoundingInfo = function () {\r\n if (this._masterMesh) {\r\n return this._masterMesh.getBoundingInfo();\r\n }\r\n if (!this._boundingInfo) {\r\n // this._boundingInfo is being created here\r\n this._updateBoundingInfo();\r\n }\r\n // cannot be null.\r\n return this._boundingInfo;\r\n };\r\n /**\r\n * Uniformly scales the mesh to fit inside of a unit cube (1 X 1 X 1 units)\r\n * @param includeDescendants Use the hierarchy's bounding box instead of the mesh's bounding box. Default is false\r\n * @param ignoreRotation ignore rotation when computing the scale (ie. object will be axis aligned). Default is false\r\n * @param predicate predicate that is passed in to getHierarchyBoundingVectors when selecting which object should be included when scaling\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.normalizeToUnitCube = function (includeDescendants, ignoreRotation, predicate) {\r\n if (includeDescendants === void 0) { includeDescendants = true; }\r\n if (ignoreRotation === void 0) { ignoreRotation = false; }\r\n return _super.prototype.normalizeToUnitCube.call(this, includeDescendants, ignoreRotation, predicate);\r\n };\r\n /**\r\n * Overwrite the current bounding info\r\n * @param boundingInfo defines the new bounding info\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.setBoundingInfo = function (boundingInfo) {\r\n this._boundingInfo = boundingInfo;\r\n return this;\r\n };\r\n Object.defineProperty(AbstractMesh.prototype, \"useBones\", {\r\n /** Gets a boolean indicating if this mesh has skinning data and an attached skeleton */\r\n get: function () {\r\n return (this.skeleton && this.getScene().skeletonsEnabled && this.isVerticesDataPresent(VertexBuffer.MatricesIndicesKind) && this.isVerticesDataPresent(VertexBuffer.MatricesWeightsKind));\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n AbstractMesh.prototype._preActivate = function () {\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._preActivateForIntermediateRendering = function (renderId) {\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._activate = function (renderId, intermediateRendering) {\r\n this._renderId = renderId;\r\n return true;\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._postActivate = function () {\r\n // Do nothing\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._freeze = function () {\r\n // Do nothing\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._unFreeze = function () {\r\n // Do nothing\r\n };\r\n /**\r\n * Gets the current world matrix\r\n * @returns a Matrix\r\n */\r\n AbstractMesh.prototype.getWorldMatrix = function () {\r\n if (this._masterMesh && this.billboardMode === TransformNode.BILLBOARDMODE_NONE) {\r\n return this._masterMesh.getWorldMatrix();\r\n }\r\n return _super.prototype.getWorldMatrix.call(this);\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._getWorldMatrixDeterminant = function () {\r\n if (this._masterMesh) {\r\n return this._masterMesh._getWorldMatrixDeterminant();\r\n }\r\n return _super.prototype._getWorldMatrixDeterminant.call(this);\r\n };\r\n Object.defineProperty(AbstractMesh.prototype, \"isAnInstance\", {\r\n /**\r\n * Gets a boolean indicating if this mesh is an instance or a regular mesh\r\n */\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"hasInstances\", {\r\n /**\r\n * Gets a boolean indicating if this mesh has instances\r\n */\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"hasThinInstances\", {\r\n /**\r\n * Gets a boolean indicating if this mesh has thin instances\r\n */\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n // ================================== Point of View Movement =================================\r\n /**\r\n * Perform relative position change from the point of view of behind the front of the mesh.\r\n * This is performed taking into account the meshes current rotation, so you do not have to care.\r\n * Supports definition of mesh facing forward or backward\r\n * @param amountRight defines the distance on the right axis\r\n * @param amountUp defines the distance on the up axis\r\n * @param amountForward defines the distance on the forward axis\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.movePOV = function (amountRight, amountUp, amountForward) {\r\n this.position.addInPlace(this.calcMovePOV(amountRight, amountUp, amountForward));\r\n return this;\r\n };\r\n /**\r\n * Calculate relative position change from the point of view of behind the front of the mesh.\r\n * This is performed taking into account the meshes current rotation, so you do not have to care.\r\n * Supports definition of mesh facing forward or backward\r\n * @param amountRight defines the distance on the right axis\r\n * @param amountUp defines the distance on the up axis\r\n * @param amountForward defines the distance on the forward axis\r\n * @returns the new displacement vector\r\n */\r\n AbstractMesh.prototype.calcMovePOV = function (amountRight, amountUp, amountForward) {\r\n var rotMatrix = new Matrix();\r\n var rotQuaternion = (this.rotationQuaternion) ? this.rotationQuaternion : Quaternion.RotationYawPitchRoll(this.rotation.y, this.rotation.x, this.rotation.z);\r\n rotQuaternion.toRotationMatrix(rotMatrix);\r\n var translationDelta = Vector3.Zero();\r\n var defForwardMult = this.definedFacingForward ? -1 : 1;\r\n Vector3.TransformCoordinatesFromFloatsToRef(amountRight * defForwardMult, amountUp, amountForward * defForwardMult, rotMatrix, translationDelta);\r\n return translationDelta;\r\n };\r\n // ================================== Point of View Rotation =================================\r\n /**\r\n * Perform relative rotation change from the point of view of behind the front of the mesh.\r\n * Supports definition of mesh facing forward or backward\r\n * @param flipBack defines the flip\r\n * @param twirlClockwise defines the twirl\r\n * @param tiltRight defines the tilt\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.rotatePOV = function (flipBack, twirlClockwise, tiltRight) {\r\n this.rotation.addInPlace(this.calcRotatePOV(flipBack, twirlClockwise, tiltRight));\r\n return this;\r\n };\r\n /**\r\n * Calculate relative rotation change from the point of view of behind the front of the mesh.\r\n * Supports definition of mesh facing forward or backward.\r\n * @param flipBack defines the flip\r\n * @param twirlClockwise defines the twirl\r\n * @param tiltRight defines the tilt\r\n * @returns the new rotation vector\r\n */\r\n AbstractMesh.prototype.calcRotatePOV = function (flipBack, twirlClockwise, tiltRight) {\r\n var defForwardMult = this.definedFacingForward ? 1 : -1;\r\n return new Vector3(flipBack * defForwardMult, twirlClockwise, tiltRight * defForwardMult);\r\n };\r\n /**\r\n * This method recomputes and sets a new BoundingInfo to the mesh unless it is locked.\r\n * This means the mesh underlying bounding box and sphere are recomputed.\r\n * @param applySkeleton defines whether to apply the skeleton before computing the bounding info\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.refreshBoundingInfo = function (applySkeleton) {\r\n if (applySkeleton === void 0) { applySkeleton = false; }\r\n if (this._boundingInfo && this._boundingInfo.isLocked) {\r\n return this;\r\n }\r\n this._refreshBoundingInfo(this._getPositionData(applySkeleton), null);\r\n return this;\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._refreshBoundingInfo = function (data, bias) {\r\n if (data) {\r\n var extend = extractMinAndMax(data, 0, this.getTotalVertices(), bias);\r\n if (this._boundingInfo) {\r\n this._boundingInfo.reConstruct(extend.minimum, extend.maximum);\r\n }\r\n else {\r\n this._boundingInfo = new BoundingInfo(extend.minimum, extend.maximum);\r\n }\r\n }\r\n if (this.subMeshes) {\r\n for (var index = 0; index < this.subMeshes.length; index++) {\r\n this.subMeshes[index].refreshBoundingInfo(data);\r\n }\r\n }\r\n this._updateBoundingInfo();\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._getPositionData = function (applySkeleton) {\r\n var data = this.getVerticesData(VertexBuffer.PositionKind);\r\n if (data && applySkeleton && this.skeleton) {\r\n data = Tools.Slice(data);\r\n this._generatePointsArray();\r\n var matricesIndicesData = this.getVerticesData(VertexBuffer.MatricesIndicesKind);\r\n var matricesWeightsData = this.getVerticesData(VertexBuffer.MatricesWeightsKind);\r\n if (matricesWeightsData && matricesIndicesData) {\r\n var needExtras = this.numBoneInfluencers > 4;\r\n var matricesIndicesExtraData = needExtras ? this.getVerticesData(VertexBuffer.MatricesIndicesExtraKind) : null;\r\n var matricesWeightsExtraData = needExtras ? this.getVerticesData(VertexBuffer.MatricesWeightsExtraKind) : null;\r\n this.skeleton.prepare();\r\n var skeletonMatrices = this.skeleton.getTransformMatrices(this);\r\n var tempVector = TmpVectors.Vector3[0];\r\n var finalMatrix = TmpVectors.Matrix[0];\r\n var tempMatrix = TmpVectors.Matrix[1];\r\n var matWeightIdx = 0;\r\n for (var index = 0; index < data.length; index += 3, matWeightIdx += 4) {\r\n finalMatrix.reset();\r\n var inf;\r\n var weight;\r\n for (inf = 0; inf < 4; inf++) {\r\n weight = matricesWeightsData[matWeightIdx + inf];\r\n if (weight > 0) {\r\n Matrix.FromFloat32ArrayToRefScaled(skeletonMatrices, Math.floor(matricesIndicesData[matWeightIdx + inf] * 16), weight, tempMatrix);\r\n finalMatrix.addToSelf(tempMatrix);\r\n }\r\n }\r\n if (needExtras) {\r\n for (inf = 0; inf < 4; inf++) {\r\n weight = matricesWeightsExtraData[matWeightIdx + inf];\r\n if (weight > 0) {\r\n Matrix.FromFloat32ArrayToRefScaled(skeletonMatrices, Math.floor(matricesIndicesExtraData[matWeightIdx + inf] * 16), weight, tempMatrix);\r\n finalMatrix.addToSelf(tempMatrix);\r\n }\r\n }\r\n }\r\n Vector3.TransformCoordinatesFromFloatsToRef(data[index], data[index + 1], data[index + 2], finalMatrix, tempVector);\r\n tempVector.toArray(data, index);\r\n if (this._positions) {\r\n this._positions[index / 3].copyFrom(tempVector);\r\n }\r\n }\r\n }\r\n }\r\n return data;\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._updateBoundingInfo = function () {\r\n var effectiveMesh = this._effectiveMesh;\r\n if (this._boundingInfo) {\r\n this._boundingInfo.update(effectiveMesh.worldMatrixFromCache);\r\n }\r\n else {\r\n this._boundingInfo = new BoundingInfo(this.absolutePosition, this.absolutePosition, effectiveMesh.worldMatrixFromCache);\r\n }\r\n this._updateSubMeshesBoundingInfo(effectiveMesh.worldMatrixFromCache);\r\n return this;\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._updateSubMeshesBoundingInfo = function (matrix) {\r\n if (!this.subMeshes) {\r\n return this;\r\n }\r\n var count = this.subMeshes.length;\r\n for (var subIndex = 0; subIndex < count; subIndex++) {\r\n var subMesh = this.subMeshes[subIndex];\r\n if (count > 1 || !subMesh.IsGlobal) {\r\n subMesh.updateBoundingInfo(matrix);\r\n }\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._afterComputeWorldMatrix = function () {\r\n if (this.doNotSyncBoundingInfo) {\r\n return;\r\n }\r\n // Bounding info\r\n this._updateBoundingInfo();\r\n };\r\n Object.defineProperty(AbstractMesh.prototype, \"_effectiveMesh\", {\r\n /** @hidden */\r\n get: function () {\r\n return (this.skeleton && this.skeleton.overrideMesh) || this;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Returns `true` if the mesh is within the frustum defined by the passed array of planes.\r\n * A mesh is in the frustum if its bounding box intersects the frustum\r\n * @param frustumPlanes defines the frustum to test\r\n * @returns true if the mesh is in the frustum planes\r\n */\r\n AbstractMesh.prototype.isInFrustum = function (frustumPlanes) {\r\n return this._boundingInfo !== null && this._boundingInfo.isInFrustum(frustumPlanes, this.cullingStrategy);\r\n };\r\n /**\r\n * Returns `true` if the mesh is completely in the frustum defined be the passed array of planes.\r\n * A mesh is completely in the frustum if its bounding box it completely inside the frustum.\r\n * @param frustumPlanes defines the frustum to test\r\n * @returns true if the mesh is completely in the frustum planes\r\n */\r\n AbstractMesh.prototype.isCompletelyInFrustum = function (frustumPlanes) {\r\n return this._boundingInfo !== null && this._boundingInfo.isCompletelyInFrustum(frustumPlanes);\r\n };\r\n /**\r\n * True if the mesh intersects another mesh or a SolidParticle object\r\n * @param mesh defines a target mesh or SolidParticle to test\r\n * @param precise Unless the parameter `precise` is set to `true` the intersection is computed according to Axis Aligned Bounding Boxes (AABB), else according to OBB (Oriented BBoxes)\r\n * @param includeDescendants Can be set to true to test if the mesh defined in parameters intersects with the current mesh or any child meshes\r\n * @returns true if there is an intersection\r\n */\r\n AbstractMesh.prototype.intersectsMesh = function (mesh, precise, includeDescendants) {\r\n if (precise === void 0) { precise = false; }\r\n if (!this._boundingInfo || !mesh._boundingInfo) {\r\n return false;\r\n }\r\n if (this._boundingInfo.intersects(mesh._boundingInfo, precise)) {\r\n return true;\r\n }\r\n if (includeDescendants) {\r\n for (var _i = 0, _a = this.getChildMeshes(); _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (child.intersectsMesh(mesh, precise, true)) {\r\n return true;\r\n }\r\n }\r\n }\r\n return false;\r\n };\r\n /**\r\n * Returns true if the passed point (Vector3) is inside the mesh bounding box\r\n * @param point defines the point to test\r\n * @returns true if there is an intersection\r\n */\r\n AbstractMesh.prototype.intersectsPoint = function (point) {\r\n if (!this._boundingInfo) {\r\n return false;\r\n }\r\n return this._boundingInfo.intersectsPoint(point);\r\n };\r\n Object.defineProperty(AbstractMesh.prototype, \"checkCollisions\", {\r\n // Collisions\r\n /**\r\n * Gets or sets a boolean indicating that this mesh can be used in the collision engine\r\n * @see https://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity\r\n */\r\n get: function () {\r\n return this._meshCollisionData._checkCollisions;\r\n },\r\n set: function (collisionEnabled) {\r\n this._meshCollisionData._checkCollisions = collisionEnabled;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AbstractMesh.prototype, \"collider\", {\r\n /**\r\n * Gets Collider object used to compute collisions (not physics)\r\n * @see https://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity\r\n */\r\n get: function () {\r\n return this._meshCollisionData._collider;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Move the mesh using collision engine\r\n * @see https://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity\r\n * @param displacement defines the requested displacement vector\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.moveWithCollisions = function (displacement) {\r\n var globalPosition = this.getAbsolutePosition();\r\n globalPosition.addToRef(this.ellipsoidOffset, this._meshCollisionData._oldPositionForCollisions);\r\n var coordinator = this.getScene().collisionCoordinator;\r\n if (!this._meshCollisionData._collider) {\r\n this._meshCollisionData._collider = coordinator.createCollider();\r\n }\r\n this._meshCollisionData._collider._radius = this.ellipsoid;\r\n coordinator.getNewPosition(this._meshCollisionData._oldPositionForCollisions, displacement, this._meshCollisionData._collider, 3, this, this._onCollisionPositionChange, this.uniqueId);\r\n return this;\r\n };\r\n // Collisions\r\n /** @hidden */\r\n AbstractMesh.prototype._collideForSubMesh = function (subMesh, transformMatrix, collider) {\r\n this._generatePointsArray();\r\n if (!this._positions) {\r\n return this;\r\n }\r\n // Transformation\r\n if (!subMesh._lastColliderWorldVertices || !subMesh._lastColliderTransformMatrix.equals(transformMatrix)) {\r\n subMesh._lastColliderTransformMatrix = transformMatrix.clone();\r\n subMesh._lastColliderWorldVertices = [];\r\n subMesh._trianglePlanes = [];\r\n var start = subMesh.verticesStart;\r\n var end = (subMesh.verticesStart + subMesh.verticesCount);\r\n for (var i = start; i < end; i++) {\r\n subMesh._lastColliderWorldVertices.push(Vector3.TransformCoordinates(this._positions[i], transformMatrix));\r\n }\r\n }\r\n // Collide\r\n collider._collide(subMesh._trianglePlanes, subMesh._lastColliderWorldVertices, this.getIndices(), subMesh.indexStart, subMesh.indexStart + subMesh.indexCount, subMesh.verticesStart, !!subMesh.getMaterial(), this);\r\n return this;\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._processCollisionsForSubMeshes = function (collider, transformMatrix) {\r\n var subMeshes = this._scene.getCollidingSubMeshCandidates(this, collider);\r\n var len = subMeshes.length;\r\n for (var index = 0; index < len; index++) {\r\n var subMesh = subMeshes.data[index];\r\n // Bounding test\r\n if (len > 1 && !subMesh._checkCollision(collider)) {\r\n continue;\r\n }\r\n this._collideForSubMesh(subMesh, transformMatrix, collider);\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._checkCollision = function (collider) {\r\n // Bounding box test\r\n if (!this._boundingInfo || !this._boundingInfo._checkCollision(collider)) {\r\n return this;\r\n }\r\n // Transformation matrix\r\n var collisionsScalingMatrix = TmpVectors.Matrix[0];\r\n var collisionsTransformMatrix = TmpVectors.Matrix[1];\r\n Matrix.ScalingToRef(1.0 / collider._radius.x, 1.0 / collider._radius.y, 1.0 / collider._radius.z, collisionsScalingMatrix);\r\n this.worldMatrixFromCache.multiplyToRef(collisionsScalingMatrix, collisionsTransformMatrix);\r\n this._processCollisionsForSubMeshes(collider, collisionsTransformMatrix);\r\n return this;\r\n };\r\n // Picking\r\n /** @hidden */\r\n AbstractMesh.prototype._generatePointsArray = function () {\r\n return false;\r\n };\r\n /**\r\n * Checks if the passed Ray intersects with the mesh\r\n * @param ray defines the ray to use\r\n * @param fastCheck defines if fast mode (but less precise) must be used (false by default)\r\n * @param trianglePredicate defines an optional predicate used to select faces when a mesh intersection is detected\r\n * @param onlyBoundingInfo defines a boolean indicating if picking should only happen using bounding info (false by default)\r\n * @param worldToUse defines the world matrix to use to get the world coordinate of the intersection point\r\n * @param skipBoundingInfo a boolean indicating if we should skip the bounding info check\r\n * @returns the picking info\r\n * @see https://doc.babylonjs.com/babylon101/intersect_collisions_-_mesh\r\n */\r\n AbstractMesh.prototype.intersects = function (ray, fastCheck, trianglePredicate, onlyBoundingInfo, worldToUse, skipBoundingInfo) {\r\n var _a;\r\n if (onlyBoundingInfo === void 0) { onlyBoundingInfo = false; }\r\n if (skipBoundingInfo === void 0) { skipBoundingInfo = false; }\r\n var pickingInfo = new PickingInfo();\r\n var intersectionThreshold = this.getClassName() === \"InstancedLinesMesh\" || this.getClassName() === \"LinesMesh\" ? this.intersectionThreshold : 0;\r\n var boundingInfo = this._boundingInfo;\r\n if (!this.subMeshes || !boundingInfo) {\r\n return pickingInfo;\r\n }\r\n if (!skipBoundingInfo && (!ray.intersectsSphere(boundingInfo.boundingSphere, intersectionThreshold) || !ray.intersectsBox(boundingInfo.boundingBox, intersectionThreshold))) {\r\n return pickingInfo;\r\n }\r\n if (onlyBoundingInfo) {\r\n pickingInfo.hit = skipBoundingInfo ? false : true;\r\n pickingInfo.pickedMesh = skipBoundingInfo ? null : this;\r\n pickingInfo.distance = skipBoundingInfo ? 0 : Vector3.Distance(ray.origin, boundingInfo.boundingSphere.center);\r\n pickingInfo.subMeshId = 0;\r\n return pickingInfo;\r\n }\r\n if (!this._generatePointsArray()) {\r\n return pickingInfo;\r\n }\r\n var intersectInfo = null;\r\n var subMeshes = this._scene.getIntersectingSubMeshCandidates(this, ray);\r\n var len = subMeshes.length;\r\n // Check if all submeshes are using a material that don't allow picking (point/lines rendering)\r\n // if no submesh can be picked that way, then fallback to BBox picking\r\n var anySubmeshSupportIntersect = false;\r\n for (var index = 0; index < len; index++) {\r\n var subMesh = subMeshes.data[index];\r\n var material = subMesh.getMaterial();\r\n if (!material) {\r\n continue;\r\n }\r\n if (((_a = this.getIndices()) === null || _a === void 0 ? void 0 : _a.length) && (material.fillMode == 7 ||\r\n material.fillMode == 0 ||\r\n material.fillMode == 1 ||\r\n material.fillMode == 2)) {\r\n anySubmeshSupportIntersect = true;\r\n break;\r\n }\r\n }\r\n // no sub mesh support intersection, fallback to BBox that has already be done\r\n if (!anySubmeshSupportIntersect) {\r\n pickingInfo.hit = true;\r\n pickingInfo.pickedMesh = this;\r\n pickingInfo.distance = Vector3.Distance(ray.origin, boundingInfo.boundingSphere.center);\r\n pickingInfo.subMeshId = -1;\r\n return pickingInfo;\r\n }\r\n // at least 1 submesh supports intersection, keep going\r\n for (var index = 0; index < len; index++) {\r\n var subMesh = subMeshes.data[index];\r\n // Bounding test\r\n if (len > 1 && !subMesh.canIntersects(ray)) {\r\n continue;\r\n }\r\n var currentIntersectInfo = subMesh.intersects(ray, this._positions, this.getIndices(), fastCheck, trianglePredicate);\r\n if (currentIntersectInfo) {\r\n if (fastCheck || !intersectInfo || currentIntersectInfo.distance < intersectInfo.distance) {\r\n intersectInfo = currentIntersectInfo;\r\n intersectInfo.subMeshId = index;\r\n if (fastCheck) {\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n if (intersectInfo) {\r\n // Get picked point\r\n var world = worldToUse !== null && worldToUse !== void 0 ? worldToUse : (this.skeleton && this.skeleton.overrideMesh ? this.skeleton.overrideMesh.getWorldMatrix() : this.getWorldMatrix());\r\n var worldOrigin = TmpVectors.Vector3[0];\r\n var direction = TmpVectors.Vector3[1];\r\n Vector3.TransformCoordinatesToRef(ray.origin, world, worldOrigin);\r\n ray.direction.scaleToRef(intersectInfo.distance, direction);\r\n var worldDirection = Vector3.TransformNormal(direction, world);\r\n var pickedPoint = worldDirection.addInPlace(worldOrigin);\r\n // Return result\r\n pickingInfo.hit = true;\r\n pickingInfo.distance = Vector3.Distance(worldOrigin, pickedPoint);\r\n pickingInfo.pickedPoint = pickedPoint;\r\n pickingInfo.pickedMesh = this;\r\n pickingInfo.bu = intersectInfo.bu || 0;\r\n pickingInfo.bv = intersectInfo.bv || 0;\r\n pickingInfo.subMeshFaceId = intersectInfo.faceId;\r\n pickingInfo.faceId = intersectInfo.faceId + subMeshes.data[intersectInfo.subMeshId].indexStart / (this.getClassName().indexOf(\"LinesMesh\") !== -1 ? 2 : 3);\r\n pickingInfo.subMeshId = intersectInfo.subMeshId;\r\n return pickingInfo;\r\n }\r\n return pickingInfo;\r\n };\r\n /**\r\n * Clones the current mesh\r\n * @param name defines the mesh name\r\n * @param newParent defines the new mesh parent\r\n * @param doNotCloneChildren defines a boolean indicating that children must not be cloned (false by default)\r\n * @returns the new mesh\r\n */\r\n AbstractMesh.prototype.clone = function (name, newParent, doNotCloneChildren) {\r\n return null;\r\n };\r\n /**\r\n * Disposes all the submeshes of the current meshnp\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.releaseSubMeshes = function () {\r\n if (this.subMeshes) {\r\n while (this.subMeshes.length) {\r\n this.subMeshes[0].dispose();\r\n }\r\n }\r\n else {\r\n this.subMeshes = new Array();\r\n }\r\n return this;\r\n };\r\n /**\r\n * Releases resources associated with this abstract mesh.\r\n * @param doNotRecurse Set to true to not recurse into each children (recurse into each children by default)\r\n * @param disposeMaterialAndTextures Set to true to also dispose referenced materials and textures (false by default)\r\n */\r\n AbstractMesh.prototype.dispose = function (doNotRecurse, disposeMaterialAndTextures) {\r\n var _this = this;\r\n if (disposeMaterialAndTextures === void 0) { disposeMaterialAndTextures = false; }\r\n var index;\r\n // mesh map release.\r\n if (this._scene.useMaterialMeshMap) {\r\n // remove from material mesh map id needed\r\n if (this._material && this._material.meshMap) {\r\n this._material.meshMap[this.uniqueId] = undefined;\r\n }\r\n }\r\n // Smart Array Retainers.\r\n this.getScene().freeActiveMeshes();\r\n this.getScene().freeRenderingGroups();\r\n // Action manager\r\n if (this.actionManager !== undefined && this.actionManager !== null) {\r\n this.actionManager.dispose();\r\n this.actionManager = null;\r\n }\r\n // Skeleton\r\n this._internalAbstractMeshDataInfo._skeleton = null;\r\n if (this._transformMatrixTexture) {\r\n this._transformMatrixTexture.dispose();\r\n this._transformMatrixTexture = null;\r\n }\r\n // Intersections in progress\r\n for (index = 0; index < this._intersectionsInProgress.length; index++) {\r\n var other = this._intersectionsInProgress[index];\r\n var pos = other._intersectionsInProgress.indexOf(this);\r\n other._intersectionsInProgress.splice(pos, 1);\r\n }\r\n this._intersectionsInProgress = [];\r\n // Lights\r\n var lights = this.getScene().lights;\r\n lights.forEach(function (light) {\r\n var meshIndex = light.includedOnlyMeshes.indexOf(_this);\r\n if (meshIndex !== -1) {\r\n light.includedOnlyMeshes.splice(meshIndex, 1);\r\n }\r\n meshIndex = light.excludedMeshes.indexOf(_this);\r\n if (meshIndex !== -1) {\r\n light.excludedMeshes.splice(meshIndex, 1);\r\n }\r\n // Shadow generators\r\n var generator = light.getShadowGenerator();\r\n if (generator) {\r\n var shadowMap = generator.getShadowMap();\r\n if (shadowMap && shadowMap.renderList) {\r\n meshIndex = shadowMap.renderList.indexOf(_this);\r\n if (meshIndex !== -1) {\r\n shadowMap.renderList.splice(meshIndex, 1);\r\n }\r\n }\r\n }\r\n });\r\n // SubMeshes\r\n if (this.getClassName() !== \"InstancedMesh\" || this.getClassName() !== \"InstancedLinesMesh\") {\r\n this.releaseSubMeshes();\r\n }\r\n // Query\r\n var engine = this.getScene().getEngine();\r\n if (this._occlusionQuery) {\r\n this.isOcclusionQueryInProgress = false;\r\n engine.deleteQuery(this._occlusionQuery);\r\n this._occlusionQuery = null;\r\n }\r\n // Engine\r\n engine.wipeCaches();\r\n // Remove from scene\r\n this.getScene().removeMesh(this);\r\n if (disposeMaterialAndTextures) {\r\n if (this.material) {\r\n if (this.material.getClassName() === \"MultiMaterial\") {\r\n this.material.dispose(false, true, true);\r\n }\r\n else {\r\n this.material.dispose(false, true);\r\n }\r\n }\r\n }\r\n if (!doNotRecurse) {\r\n // Particles\r\n for (index = 0; index < this.getScene().particleSystems.length; index++) {\r\n if (this.getScene().particleSystems[index].emitter === this) {\r\n this.getScene().particleSystems[index].dispose();\r\n index--;\r\n }\r\n }\r\n }\r\n // facet data\r\n if (this._internalAbstractMeshDataInfo._facetData.facetDataEnabled) {\r\n this.disableFacetData();\r\n }\r\n this.onAfterWorldMatrixUpdateObservable.clear();\r\n this.onCollideObservable.clear();\r\n this.onCollisionPositionChangeObservable.clear();\r\n this.onRebuildObservable.clear();\r\n _super.prototype.dispose.call(this, doNotRecurse, disposeMaterialAndTextures);\r\n };\r\n /**\r\n * Adds the passed mesh as a child to the current mesh\r\n * @param mesh defines the child mesh\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.addChild = function (mesh) {\r\n mesh.setParent(this);\r\n return this;\r\n };\r\n /**\r\n * Removes the passed mesh from the current mesh children list\r\n * @param mesh defines the child mesh\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.removeChild = function (mesh) {\r\n mesh.setParent(null);\r\n return this;\r\n };\r\n // Facet data\r\n /** @hidden */\r\n AbstractMesh.prototype._initFacetData = function () {\r\n var data = this._internalAbstractMeshDataInfo._facetData;\r\n if (!data.facetNormals) {\r\n data.facetNormals = new Array();\r\n }\r\n if (!data.facetPositions) {\r\n data.facetPositions = new Array();\r\n }\r\n if (!data.facetPartitioning) {\r\n data.facetPartitioning = new Array();\r\n }\r\n data.facetNb = (this.getIndices().length / 3) | 0;\r\n data.partitioningSubdivisions = (data.partitioningSubdivisions) ? data.partitioningSubdivisions : 10; // default nb of partitioning subdivisions = 10\r\n data.partitioningBBoxRatio = (data.partitioningBBoxRatio) ? data.partitioningBBoxRatio : 1.01; // default ratio 1.01 = the partitioning is 1% bigger than the bounding box\r\n for (var f = 0; f < data.facetNb; f++) {\r\n data.facetNormals[f] = Vector3.Zero();\r\n data.facetPositions[f] = Vector3.Zero();\r\n }\r\n data.facetDataEnabled = true;\r\n return this;\r\n };\r\n /**\r\n * Updates the mesh facetData arrays and the internal partitioning when the mesh is morphed or updated.\r\n * This method can be called within the render loop.\r\n * You don't need to call this method by yourself in the render loop when you update/morph a mesh with the methods CreateXXX() as they automatically manage this computation\r\n * @returns the current mesh\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.updateFacetData = function () {\r\n var data = this._internalAbstractMeshDataInfo._facetData;\r\n if (!data.facetDataEnabled) {\r\n this._initFacetData();\r\n }\r\n var positions = this.getVerticesData(VertexBuffer.PositionKind);\r\n var indices = this.getIndices();\r\n var normals = this.getVerticesData(VertexBuffer.NormalKind);\r\n var bInfo = this.getBoundingInfo();\r\n if (data.facetDepthSort && !data.facetDepthSortEnabled) {\r\n // init arrays, matrix and sort function on first call\r\n data.facetDepthSortEnabled = true;\r\n if (indices instanceof Uint16Array) {\r\n data.depthSortedIndices = new Uint16Array(indices);\r\n }\r\n else if (indices instanceof Uint32Array) {\r\n data.depthSortedIndices = new Uint32Array(indices);\r\n }\r\n else {\r\n var needs32bits = false;\r\n for (var i = 0; i < indices.length; i++) {\r\n if (indices[i] > 65535) {\r\n needs32bits = true;\r\n break;\r\n }\r\n }\r\n if (needs32bits) {\r\n data.depthSortedIndices = new Uint32Array(indices);\r\n }\r\n else {\r\n data.depthSortedIndices = new Uint16Array(indices);\r\n }\r\n }\r\n data.facetDepthSortFunction = function (f1, f2) {\r\n return (f2.sqDistance - f1.sqDistance);\r\n };\r\n if (!data.facetDepthSortFrom) {\r\n var camera = this.getScene().activeCamera;\r\n data.facetDepthSortFrom = (camera) ? camera.position : Vector3.Zero();\r\n }\r\n data.depthSortedFacets = [];\r\n for (var f = 0; f < data.facetNb; f++) {\r\n var depthSortedFacet = { ind: f * 3, sqDistance: 0.0 };\r\n data.depthSortedFacets.push(depthSortedFacet);\r\n }\r\n data.invertedMatrix = Matrix.Identity();\r\n data.facetDepthSortOrigin = Vector3.Zero();\r\n }\r\n data.bbSize.x = (bInfo.maximum.x - bInfo.minimum.x > Epsilon) ? bInfo.maximum.x - bInfo.minimum.x : Epsilon;\r\n data.bbSize.y = (bInfo.maximum.y - bInfo.minimum.y > Epsilon) ? bInfo.maximum.y - bInfo.minimum.y : Epsilon;\r\n data.bbSize.z = (bInfo.maximum.z - bInfo.minimum.z > Epsilon) ? bInfo.maximum.z - bInfo.minimum.z : Epsilon;\r\n var bbSizeMax = (data.bbSize.x > data.bbSize.y) ? data.bbSize.x : data.bbSize.y;\r\n bbSizeMax = (bbSizeMax > data.bbSize.z) ? bbSizeMax : data.bbSize.z;\r\n data.subDiv.max = data.partitioningSubdivisions;\r\n data.subDiv.X = Math.floor(data.subDiv.max * data.bbSize.x / bbSizeMax); // adjust the number of subdivisions per axis\r\n data.subDiv.Y = Math.floor(data.subDiv.max * data.bbSize.y / bbSizeMax); // according to each bbox size per axis\r\n data.subDiv.Z = Math.floor(data.subDiv.max * data.bbSize.z / bbSizeMax);\r\n data.subDiv.X = data.subDiv.X < 1 ? 1 : data.subDiv.X; // at least one subdivision\r\n data.subDiv.Y = data.subDiv.Y < 1 ? 1 : data.subDiv.Y;\r\n data.subDiv.Z = data.subDiv.Z < 1 ? 1 : data.subDiv.Z;\r\n // set the parameters for ComputeNormals()\r\n data.facetParameters.facetNormals = this.getFacetLocalNormals();\r\n data.facetParameters.facetPositions = this.getFacetLocalPositions();\r\n data.facetParameters.facetPartitioning = this.getFacetLocalPartitioning();\r\n data.facetParameters.bInfo = bInfo;\r\n data.facetParameters.bbSize = data.bbSize;\r\n data.facetParameters.subDiv = data.subDiv;\r\n data.facetParameters.ratio = this.partitioningBBoxRatio;\r\n data.facetParameters.depthSort = data.facetDepthSort;\r\n if (data.facetDepthSort && data.facetDepthSortEnabled) {\r\n this.computeWorldMatrix(true);\r\n this._worldMatrix.invertToRef(data.invertedMatrix);\r\n Vector3.TransformCoordinatesToRef(data.facetDepthSortFrom, data.invertedMatrix, data.facetDepthSortOrigin);\r\n data.facetParameters.distanceTo = data.facetDepthSortOrigin;\r\n }\r\n data.facetParameters.depthSortedFacets = data.depthSortedFacets;\r\n VertexData.ComputeNormals(positions, indices, normals, data.facetParameters);\r\n if (data.facetDepthSort && data.facetDepthSortEnabled) {\r\n data.depthSortedFacets.sort(data.facetDepthSortFunction);\r\n var l = (data.depthSortedIndices.length / 3) | 0;\r\n for (var f = 0; f < l; f++) {\r\n var sind = data.depthSortedFacets[f].ind;\r\n data.depthSortedIndices[f * 3] = indices[sind];\r\n data.depthSortedIndices[f * 3 + 1] = indices[sind + 1];\r\n data.depthSortedIndices[f * 3 + 2] = indices[sind + 2];\r\n }\r\n this.updateIndices(data.depthSortedIndices, undefined, true);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Returns the facetLocalNormals array.\r\n * The normals are expressed in the mesh local spac\r\n * @returns an array of Vector3\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetLocalNormals = function () {\r\n var facetData = this._internalAbstractMeshDataInfo._facetData;\r\n if (!facetData.facetNormals) {\r\n this.updateFacetData();\r\n }\r\n return facetData.facetNormals;\r\n };\r\n /**\r\n * Returns the facetLocalPositions array.\r\n * The facet positions are expressed in the mesh local space\r\n * @returns an array of Vector3\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetLocalPositions = function () {\r\n var facetData = this._internalAbstractMeshDataInfo._facetData;\r\n if (!facetData.facetPositions) {\r\n this.updateFacetData();\r\n }\r\n return facetData.facetPositions;\r\n };\r\n /**\r\n * Returns the facetLocalPartioning array\r\n * @returns an array of array of numbers\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetLocalPartitioning = function () {\r\n var facetData = this._internalAbstractMeshDataInfo._facetData;\r\n if (!facetData.facetPartitioning) {\r\n this.updateFacetData();\r\n }\r\n return facetData.facetPartitioning;\r\n };\r\n /**\r\n * Returns the i-th facet position in the world system.\r\n * This method allocates a new Vector3 per call\r\n * @param i defines the facet index\r\n * @returns a new Vector3\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetPosition = function (i) {\r\n var pos = Vector3.Zero();\r\n this.getFacetPositionToRef(i, pos);\r\n return pos;\r\n };\r\n /**\r\n * Sets the reference Vector3 with the i-th facet position in the world system\r\n * @param i defines the facet index\r\n * @param ref defines the target vector\r\n * @returns the current mesh\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetPositionToRef = function (i, ref) {\r\n var localPos = (this.getFacetLocalPositions())[i];\r\n var world = this.getWorldMatrix();\r\n Vector3.TransformCoordinatesToRef(localPos, world, ref);\r\n return this;\r\n };\r\n /**\r\n * Returns the i-th facet normal in the world system.\r\n * This method allocates a new Vector3 per call\r\n * @param i defines the facet index\r\n * @returns a new Vector3\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetNormal = function (i) {\r\n var norm = Vector3.Zero();\r\n this.getFacetNormalToRef(i, norm);\r\n return norm;\r\n };\r\n /**\r\n * Sets the reference Vector3 with the i-th facet normal in the world system\r\n * @param i defines the facet index\r\n * @param ref defines the target vector\r\n * @returns the current mesh\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetNormalToRef = function (i, ref) {\r\n var localNorm = (this.getFacetLocalNormals())[i];\r\n Vector3.TransformNormalToRef(localNorm, this.getWorldMatrix(), ref);\r\n return this;\r\n };\r\n /**\r\n * Returns the facets (in an array) in the same partitioning block than the one the passed coordinates are located (expressed in the mesh local system)\r\n * @param x defines x coordinate\r\n * @param y defines y coordinate\r\n * @param z defines z coordinate\r\n * @returns the array of facet indexes\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetsAtLocalCoordinates = function (x, y, z) {\r\n var bInfo = this.getBoundingInfo();\r\n var data = this._internalAbstractMeshDataInfo._facetData;\r\n var ox = Math.floor((x - bInfo.minimum.x * data.partitioningBBoxRatio) * data.subDiv.X * data.partitioningBBoxRatio / data.bbSize.x);\r\n var oy = Math.floor((y - bInfo.minimum.y * data.partitioningBBoxRatio) * data.subDiv.Y * data.partitioningBBoxRatio / data.bbSize.y);\r\n var oz = Math.floor((z - bInfo.minimum.z * data.partitioningBBoxRatio) * data.subDiv.Z * data.partitioningBBoxRatio / data.bbSize.z);\r\n if (ox < 0 || ox > data.subDiv.max || oy < 0 || oy > data.subDiv.max || oz < 0 || oz > data.subDiv.max) {\r\n return null;\r\n }\r\n return data.facetPartitioning[ox + data.subDiv.max * oy + data.subDiv.max * data.subDiv.max * oz];\r\n };\r\n /**\r\n * Returns the closest mesh facet index at (x,y,z) World coordinates, null if not found\r\n * @param projected sets as the (x,y,z) world projection on the facet\r\n * @param checkFace if true (default false), only the facet \"facing\" to (x,y,z) or only the ones \"turning their backs\", according to the parameter \"facing\" are returned\r\n * @param facing if facing and checkFace are true, only the facet \"facing\" to (x, y, z) are returned : positive dot (x, y, z) * facet position. If facing si false and checkFace is true, only the facet \"turning their backs\" to (x, y, z) are returned : negative dot (x, y, z) * facet position\r\n * @param x defines x coordinate\r\n * @param y defines y coordinate\r\n * @param z defines z coordinate\r\n * @returns the face index if found (or null instead)\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getClosestFacetAtCoordinates = function (x, y, z, projected, checkFace, facing) {\r\n if (checkFace === void 0) { checkFace = false; }\r\n if (facing === void 0) { facing = true; }\r\n var world = this.getWorldMatrix();\r\n var invMat = TmpVectors.Matrix[5];\r\n world.invertToRef(invMat);\r\n var invVect = TmpVectors.Vector3[8];\r\n Vector3.TransformCoordinatesFromFloatsToRef(x, y, z, invMat, invVect); // transform (x,y,z) to coordinates in the mesh local space\r\n var closest = this.getClosestFacetAtLocalCoordinates(invVect.x, invVect.y, invVect.z, projected, checkFace, facing);\r\n if (projected) {\r\n // tranform the local computed projected vector to world coordinates\r\n Vector3.TransformCoordinatesFromFloatsToRef(projected.x, projected.y, projected.z, world, projected);\r\n }\r\n return closest;\r\n };\r\n /**\r\n * Returns the closest mesh facet index at (x,y,z) local coordinates, null if not found\r\n * @param projected sets as the (x,y,z) local projection on the facet\r\n * @param checkFace if true (default false), only the facet \"facing\" to (x,y,z) or only the ones \"turning their backs\", according to the parameter \"facing\" are returned\r\n * @param facing if facing and checkFace are true, only the facet \"facing\" to (x, y, z) are returned : positive dot (x, y, z) * facet position. If facing si false and checkFace is true, only the facet \"turning their backs\" to (x, y, z) are returned : negative dot (x, y, z) * facet position\r\n * @param x defines x coordinate\r\n * @param y defines y coordinate\r\n * @param z defines z coordinate\r\n * @returns the face index if found (or null instead)\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getClosestFacetAtLocalCoordinates = function (x, y, z, projected, checkFace, facing) {\r\n if (checkFace === void 0) { checkFace = false; }\r\n if (facing === void 0) { facing = true; }\r\n var closest = null;\r\n var tmpx = 0.0;\r\n var tmpy = 0.0;\r\n var tmpz = 0.0;\r\n var d = 0.0; // tmp dot facet normal * facet position\r\n var t0 = 0.0;\r\n var projx = 0.0;\r\n var projy = 0.0;\r\n var projz = 0.0;\r\n // Get all the facets in the same partitioning block than (x, y, z)\r\n var facetPositions = this.getFacetLocalPositions();\r\n var facetNormals = this.getFacetLocalNormals();\r\n var facetsInBlock = this.getFacetsAtLocalCoordinates(x, y, z);\r\n if (!facetsInBlock) {\r\n return null;\r\n }\r\n // Get the closest facet to (x, y, z)\r\n var shortest = Number.MAX_VALUE; // init distance vars\r\n var tmpDistance = shortest;\r\n var fib; // current facet in the block\r\n var norm; // current facet normal\r\n var p0; // current facet barycenter position\r\n // loop on all the facets in the current partitioning block\r\n for (var idx = 0; idx < facetsInBlock.length; idx++) {\r\n fib = facetsInBlock[idx];\r\n norm = facetNormals[fib];\r\n p0 = facetPositions[fib];\r\n d = (x - p0.x) * norm.x + (y - p0.y) * norm.y + (z - p0.z) * norm.z;\r\n if (!checkFace || (checkFace && facing && d >= 0.0) || (checkFace && !facing && d <= 0.0)) {\r\n // compute (x,y,z) projection on the facet = (projx, projy, projz)\r\n d = norm.x * p0.x + norm.y * p0.y + norm.z * p0.z;\r\n t0 = -(norm.x * x + norm.y * y + norm.z * z - d) / (norm.x * norm.x + norm.y * norm.y + norm.z * norm.z);\r\n projx = x + norm.x * t0;\r\n projy = y + norm.y * t0;\r\n projz = z + norm.z * t0;\r\n tmpx = projx - x;\r\n tmpy = projy - y;\r\n tmpz = projz - z;\r\n tmpDistance = tmpx * tmpx + tmpy * tmpy + tmpz * tmpz; // compute length between (x, y, z) and its projection on the facet\r\n if (tmpDistance < shortest) { // just keep the closest facet to (x, y, z)\r\n shortest = tmpDistance;\r\n closest = fib;\r\n if (projected) {\r\n projected.x = projx;\r\n projected.y = projy;\r\n projected.z = projz;\r\n }\r\n }\r\n }\r\n }\r\n return closest;\r\n };\r\n /**\r\n * Returns the object \"parameter\" set with all the expected parameters for facetData computation by ComputeNormals()\r\n * @returns the parameters\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.getFacetDataParameters = function () {\r\n return this._internalAbstractMeshDataInfo._facetData.facetParameters;\r\n };\r\n /**\r\n * Disables the feature FacetData and frees the related memory\r\n * @returns the current mesh\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_facetdata\r\n */\r\n AbstractMesh.prototype.disableFacetData = function () {\r\n var facetData = this._internalAbstractMeshDataInfo._facetData;\r\n if (facetData.facetDataEnabled) {\r\n facetData.facetDataEnabled = false;\r\n facetData.facetPositions = new Array();\r\n facetData.facetNormals = new Array();\r\n facetData.facetPartitioning = new Array();\r\n facetData.facetParameters = null;\r\n facetData.depthSortedIndices = new Uint32Array(0);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Updates the AbstractMesh indices array\r\n * @param indices defines the data source\r\n * @param offset defines the offset in the index buffer where to store the new data (can be null)\r\n * @param gpuMemoryOnly defines a boolean indicating that only the GPU memory must be updated leaving the CPU version of the indices unchanged (false by default)\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.updateIndices = function (indices, offset, gpuMemoryOnly) {\r\n if (gpuMemoryOnly === void 0) { gpuMemoryOnly = false; }\r\n return this;\r\n };\r\n /**\r\n * Creates new normals data for the mesh\r\n * @param updatable defines if the normal vertex buffer must be flagged as updatable\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.createNormals = function (updatable) {\r\n var positions = this.getVerticesData(VertexBuffer.PositionKind);\r\n var indices = this.getIndices();\r\n var normals;\r\n if (this.isVerticesDataPresent(VertexBuffer.NormalKind)) {\r\n normals = this.getVerticesData(VertexBuffer.NormalKind);\r\n }\r\n else {\r\n normals = [];\r\n }\r\n VertexData.ComputeNormals(positions, indices, normals, { useRightHandedSystem: this.getScene().useRightHandedSystem });\r\n this.setVerticesData(VertexBuffer.NormalKind, normals, updatable);\r\n return this;\r\n };\r\n /**\r\n * Align the mesh with a normal\r\n * @param normal defines the normal to use\r\n * @param upDirection can be used to redefined the up vector to use (will use the (0, 1, 0) by default)\r\n * @returns the current mesh\r\n */\r\n AbstractMesh.prototype.alignWithNormal = function (normal, upDirection) {\r\n if (!upDirection) {\r\n upDirection = Axis.Y;\r\n }\r\n var axisX = TmpVectors.Vector3[0];\r\n var axisZ = TmpVectors.Vector3[1];\r\n Vector3.CrossToRef(upDirection, normal, axisZ);\r\n Vector3.CrossToRef(normal, axisZ, axisX);\r\n if (this.rotationQuaternion) {\r\n Quaternion.RotationQuaternionFromAxisToRef(axisX, normal, axisZ, this.rotationQuaternion);\r\n }\r\n else {\r\n Vector3.RotationFromAxisToRef(axisX, normal, axisZ, this.rotation);\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n AbstractMesh.prototype._checkOcclusionQuery = function () {\r\n return false;\r\n };\r\n /**\r\n * Disables the mesh edge rendering mode\r\n * @returns the currentAbstractMesh\r\n */\r\n AbstractMesh.prototype.disableEdgesRendering = function () {\r\n throw _DevTools.WarnImport(\"EdgesRenderer\");\r\n };\r\n /**\r\n * Enables the edge rendering mode on the mesh.\r\n * This mode makes the mesh edges visible\r\n * @param epsilon defines the maximal distance between two angles to detect a face\r\n * @param checkVerticesInsteadOfIndices indicates that we should check vertex list directly instead of faces\r\n * @param options options to the edge renderer\r\n * @returns the currentAbstractMesh\r\n * @see https://www.babylonjs-playground.com/#19O9TU#0\r\n */\r\n AbstractMesh.prototype.enableEdgesRendering = function (epsilon, checkVerticesInsteadOfIndices, options) {\r\n throw _DevTools.WarnImport(\"EdgesRenderer\");\r\n };\r\n /**\r\n * This function returns all of the particle systems in the scene that use the mesh as an emitter.\r\n * @returns an array of particle systems in the scene that use the mesh as an emitter\r\n */\r\n AbstractMesh.prototype.getConnectedParticleSystems = function () {\r\n var _this = this;\r\n return this._scene.particleSystems.filter(function (particleSystem) { return particleSystem.emitter === _this; });\r\n };\r\n /** No occlusion */\r\n AbstractMesh.OCCLUSION_TYPE_NONE = 0;\r\n /** Occlusion set to optimisitic */\r\n AbstractMesh.OCCLUSION_TYPE_OPTIMISTIC = 1;\r\n /** Occlusion set to strict */\r\n AbstractMesh.OCCLUSION_TYPE_STRICT = 2;\r\n /** Use an accurante occlusion algorithm */\r\n AbstractMesh.OCCLUSION_ALGORITHM_TYPE_ACCURATE = 0;\r\n /** Use a conservative occlusion algorithm */\r\n AbstractMesh.OCCLUSION_ALGORITHM_TYPE_CONSERVATIVE = 1;\r\n /** Default culling strategy : this is an exclusion test and it's the more accurate.\r\n * Test order :\r\n * Is the bounding sphere outside the frustum ?\r\n * If not, are the bounding box vertices outside the frustum ?\r\n * It not, then the cullable object is in the frustum.\r\n */\r\n AbstractMesh.CULLINGSTRATEGY_STANDARD = 0;\r\n /** Culling strategy : Bounding Sphere Only.\r\n * This is an exclusion test. It's faster than the standard strategy because the bounding box is not tested.\r\n * It's also less accurate than the standard because some not visible objects can still be selected.\r\n * Test : is the bounding sphere outside the frustum ?\r\n * If not, then the cullable object is in the frustum.\r\n */\r\n AbstractMesh.CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY = 1;\r\n /** Culling strategy : Optimistic Inclusion.\r\n * This in an inclusion test first, then the standard exclusion test.\r\n * This can be faster when a cullable object is expected to be almost always in the camera frustum.\r\n * This could also be a little slower than the standard test when the tested object center is not the frustum but one of its bounding box vertex is still inside.\r\n * Anyway, it's as accurate as the standard strategy.\r\n * Test :\r\n * Is the cullable object bounding sphere center in the frustum ?\r\n * If not, apply the default culling strategy.\r\n */\r\n AbstractMesh.CULLINGSTRATEGY_OPTIMISTIC_INCLUSION = 2;\r\n /** Culling strategy : Optimistic Inclusion then Bounding Sphere Only.\r\n * This in an inclusion test first, then the bounding sphere only exclusion test.\r\n * This can be the fastest test when a cullable object is expected to be almost always in the camera frustum.\r\n * This could also be a little slower than the BoundingSphereOnly strategy when the tested object center is not in the frustum but its bounding sphere still intersects it.\r\n * It's less accurate than the standard strategy and as accurate as the BoundingSphereOnly strategy.\r\n * Test :\r\n * Is the cullable object bounding sphere center in the frustum ?\r\n * If not, apply the Bounding Sphere Only strategy. No Bounding Box is tested here.\r\n */\r\n AbstractMesh.CULLINGSTRATEGY_OPTIMISTIC_INCLUSION_THEN_BSPHERE_ONLY = 3;\r\n return AbstractMesh;\r\n}(TransformNode));\r\nexport { AbstractMesh };\r\n_TypeStore.RegisteredTypes[\"BABYLON.AbstractMesh\"] = AbstractMesh;\r\n//# sourceMappingURL=abstractMesh.js.map","/** @hidden */\r\nvar PerformanceConfigurator = /** @class */ (function () {\r\n function PerformanceConfigurator() {\r\n }\r\n /** @hidden */\r\n PerformanceConfigurator.SetMatrixPrecision = function (use64bits) {\r\n PerformanceConfigurator.MatrixTrackPrecisionChange = false;\r\n if (use64bits && !PerformanceConfigurator.MatrixUse64Bits) {\r\n if (PerformanceConfigurator.MatrixTrackedMatrices) {\r\n for (var m = 0; m < PerformanceConfigurator.MatrixTrackedMatrices.length; ++m) {\r\n var matrix = PerformanceConfigurator.MatrixTrackedMatrices[m];\r\n var values = matrix._m;\r\n matrix._m = new Array(16);\r\n for (var i = 0; i < 16; ++i) {\r\n matrix._m[i] = values[i];\r\n }\r\n }\r\n }\r\n }\r\n PerformanceConfigurator.MatrixUse64Bits = use64bits;\r\n PerformanceConfigurator.MatrixCurrentType = PerformanceConfigurator.MatrixUse64Bits ? Array : Float32Array;\r\n PerformanceConfigurator.MatrixTrackedMatrices = null; // reclaim some memory, as we don't need _TrackedMatrices anymore\r\n };\r\n /** @hidden */\r\n PerformanceConfigurator.MatrixUse64Bits = false;\r\n /** @hidden */\r\n PerformanceConfigurator.MatrixTrackPrecisionChange = true;\r\n /** @hidden */\r\n PerformanceConfigurator.MatrixCurrentType = Float32Array;\r\n /** @hidden */\r\n PerformanceConfigurator.MatrixTrackedMatrices = [];\r\n return PerformanceConfigurator;\r\n}());\r\nexport { PerformanceConfigurator };\r\n//# sourceMappingURL=performanceConfigurator.js.map","import { Matrix } from \"../Maths/math.vector\";\r\n/**\r\n * Configuration needed for prepass-capable materials\r\n */\r\nvar PrePassConfiguration = /** @class */ (function () {\r\n function PrePassConfiguration() {\r\n /**\r\n * Previous world matrices of meshes carrying this material\r\n * Used for computing velocity\r\n */\r\n this.previousWorldMatrices = {};\r\n /**\r\n * Previous bones of meshes carrying this material\r\n * Used for computing velocity\r\n */\r\n this.previousBones = {};\r\n }\r\n /**\r\n * Add the required uniforms to the current list.\r\n * @param uniforms defines the current uniform list.\r\n */\r\n PrePassConfiguration.AddUniforms = function (uniforms) {\r\n uniforms.push(\"previousWorld\", \"previousViewProjection\");\r\n };\r\n /**\r\n * Add the required samplers to the current list.\r\n * @param samplers defines the current sampler list.\r\n */\r\n PrePassConfiguration.AddSamplers = function (samplers) {\r\n // pass\r\n };\r\n /**\r\n * Binds the material data.\r\n * @param effect defines the effect to update\r\n * @param scene defines the scene the material belongs to.\r\n * @param mesh The mesh\r\n * @param world World matrix of this mesh\r\n * @param isFrozen Is the material frozen\r\n */\r\n PrePassConfiguration.prototype.bindForSubMesh = function (effect, scene, mesh, world, isFrozen) {\r\n if (scene.prePassRenderer && scene.prePassRenderer.enabled) {\r\n if (scene.prePassRenderer.getIndex(2) !== -1) {\r\n if (!this.previousWorldMatrices[mesh.uniqueId]) {\r\n this.previousWorldMatrices[mesh.uniqueId] = Matrix.Identity();\r\n }\r\n if (!this.previousViewProjection) {\r\n this.previousViewProjection = scene.getTransformMatrix();\r\n }\r\n effect.setMatrix(\"previousWorld\", this.previousWorldMatrices[mesh.uniqueId]);\r\n effect.setMatrix(\"previousViewProjection\", this.previousViewProjection);\r\n this.previousWorldMatrices[mesh.uniqueId] = world.clone();\r\n this.previousViewProjection = scene.getTransformMatrix().clone();\r\n }\r\n }\r\n };\r\n return PrePassConfiguration;\r\n}());\r\nexport { PrePassConfiguration };\r\n//# sourceMappingURL=prePassConfiguration.js.map","import { __extends } from \"tslib\";\r\nimport { Matrix } from \"../Maths/math.vector\";\r\nimport { Material } from \"../Materials/material\";\r\n/**\r\n * Base class of materials working in push mode in babylon JS\r\n * @hidden\r\n */\r\nvar PushMaterial = /** @class */ (function (_super) {\r\n __extends(PushMaterial, _super);\r\n function PushMaterial(name, scene) {\r\n var _this = _super.call(this, name, scene) || this;\r\n _this._normalMatrix = new Matrix();\r\n _this._storeEffectOnSubMeshes = true;\r\n return _this;\r\n }\r\n PushMaterial.prototype.getEffect = function () {\r\n return this._activeEffect;\r\n };\r\n PushMaterial.prototype.isReady = function (mesh, useInstances) {\r\n if (!mesh) {\r\n return false;\r\n }\r\n if (!mesh.subMeshes || mesh.subMeshes.length === 0) {\r\n return true;\r\n }\r\n return this.isReadyForSubMesh(mesh, mesh.subMeshes[0], useInstances);\r\n };\r\n PushMaterial.prototype._isReadyForSubMesh = function (subMesh) {\r\n var defines = subMesh._materialDefines;\r\n if (!this.checkReadyOnEveryCall && subMesh.effect && defines) {\r\n if (defines._renderId === this.getScene().getRenderId()) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n };\r\n /**\r\n * Binds the given world matrix to the active effect\r\n *\r\n * @param world the matrix to bind\r\n */\r\n PushMaterial.prototype.bindOnlyWorldMatrix = function (world) {\r\n this._activeEffect.setMatrix(\"world\", world);\r\n };\r\n /**\r\n * Binds the given normal matrix to the active effect\r\n *\r\n * @param normalMatrix the matrix to bind\r\n */\r\n PushMaterial.prototype.bindOnlyNormalMatrix = function (normalMatrix) {\r\n this._activeEffect.setMatrix(\"normalMatrix\", normalMatrix);\r\n };\r\n PushMaterial.prototype.bind = function (world, mesh) {\r\n if (!mesh) {\r\n return;\r\n }\r\n this.bindForSubMesh(world, mesh, mesh.subMeshes[0]);\r\n };\r\n PushMaterial.prototype._afterBind = function (mesh, effect) {\r\n if (effect === void 0) { effect = null; }\r\n _super.prototype._afterBind.call(this, mesh);\r\n this.getScene()._cachedEffect = effect;\r\n };\r\n PushMaterial.prototype._mustRebind = function (scene, effect, visibility) {\r\n if (visibility === void 0) { visibility = 1; }\r\n return scene.isCachedMaterialInvalid(this, effect, visibility);\r\n };\r\n return PushMaterial;\r\n}(Material));\r\nexport { PushMaterial };\r\n//# sourceMappingURL=pushMaterial.js.map","import { Engine } from \"../Engines/engine\";\r\n/**\r\n * This groups all the flags used to control the materials channel.\r\n */\r\nvar MaterialFlags = /** @class */ (function () {\r\n function MaterialFlags() {\r\n }\r\n Object.defineProperty(MaterialFlags, \"DiffuseTextureEnabled\", {\r\n /**\r\n * Are diffuse textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._DiffuseTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._DiffuseTextureEnabled === value) {\r\n return;\r\n }\r\n this._DiffuseTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"DetailTextureEnabled\", {\r\n /**\r\n * Are detail textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._DetailTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._DetailTextureEnabled === value) {\r\n return;\r\n }\r\n this._DetailTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"AmbientTextureEnabled\", {\r\n /**\r\n * Are ambient textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._AmbientTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._AmbientTextureEnabled === value) {\r\n return;\r\n }\r\n this._AmbientTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"OpacityTextureEnabled\", {\r\n /**\r\n * Are opacity textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._OpacityTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._OpacityTextureEnabled === value) {\r\n return;\r\n }\r\n this._OpacityTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"ReflectionTextureEnabled\", {\r\n /**\r\n * Are reflection textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._ReflectionTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._ReflectionTextureEnabled === value) {\r\n return;\r\n }\r\n this._ReflectionTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"EmissiveTextureEnabled\", {\r\n /**\r\n * Are emissive textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._EmissiveTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._EmissiveTextureEnabled === value) {\r\n return;\r\n }\r\n this._EmissiveTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"SpecularTextureEnabled\", {\r\n /**\r\n * Are specular textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._SpecularTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._SpecularTextureEnabled === value) {\r\n return;\r\n }\r\n this._SpecularTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"BumpTextureEnabled\", {\r\n /**\r\n * Are bump textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._BumpTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._BumpTextureEnabled === value) {\r\n return;\r\n }\r\n this._BumpTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"LightmapTextureEnabled\", {\r\n /**\r\n * Are lightmap textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._LightmapTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._LightmapTextureEnabled === value) {\r\n return;\r\n }\r\n this._LightmapTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"RefractionTextureEnabled\", {\r\n /**\r\n * Are refraction textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._RefractionTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._RefractionTextureEnabled === value) {\r\n return;\r\n }\r\n this._RefractionTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"ColorGradingTextureEnabled\", {\r\n /**\r\n * Are color grading textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._ColorGradingTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._ColorGradingTextureEnabled === value) {\r\n return;\r\n }\r\n this._ColorGradingTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"FresnelEnabled\", {\r\n /**\r\n * Are fresnels enabled in the application.\r\n */\r\n get: function () {\r\n return this._FresnelEnabled;\r\n },\r\n set: function (value) {\r\n if (this._FresnelEnabled === value) {\r\n return;\r\n }\r\n this._FresnelEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(4);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"ClearCoatTextureEnabled\", {\r\n /**\r\n * Are clear coat textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._ClearCoatTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._ClearCoatTextureEnabled === value) {\r\n return;\r\n }\r\n this._ClearCoatTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"ClearCoatBumpTextureEnabled\", {\r\n /**\r\n * Are clear coat bump textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._ClearCoatBumpTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._ClearCoatBumpTextureEnabled === value) {\r\n return;\r\n }\r\n this._ClearCoatBumpTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"ClearCoatTintTextureEnabled\", {\r\n /**\r\n * Are clear coat tint textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._ClearCoatTintTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._ClearCoatTintTextureEnabled === value) {\r\n return;\r\n }\r\n this._ClearCoatTintTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"SheenTextureEnabled\", {\r\n /**\r\n * Are sheen textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._SheenTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._SheenTextureEnabled === value) {\r\n return;\r\n }\r\n this._SheenTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"AnisotropicTextureEnabled\", {\r\n /**\r\n * Are anisotropic textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._AnisotropicTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._AnisotropicTextureEnabled === value) {\r\n return;\r\n }\r\n this._AnisotropicTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MaterialFlags, \"ThicknessTextureEnabled\", {\r\n /**\r\n * Are thickness textures enabled in the application.\r\n */\r\n get: function () {\r\n return this._ThicknessTextureEnabled;\r\n },\r\n set: function (value) {\r\n if (this._ThicknessTextureEnabled === value) {\r\n return;\r\n }\r\n this._ThicknessTextureEnabled = value;\r\n Engine.MarkAllMaterialsAsDirty(1);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n // Flags used to enable or disable a type of texture for all Standard Materials\r\n MaterialFlags._DiffuseTextureEnabled = true;\r\n MaterialFlags._DetailTextureEnabled = true;\r\n MaterialFlags._AmbientTextureEnabled = true;\r\n MaterialFlags._OpacityTextureEnabled = true;\r\n MaterialFlags._ReflectionTextureEnabled = true;\r\n MaterialFlags._EmissiveTextureEnabled = true;\r\n MaterialFlags._SpecularTextureEnabled = true;\r\n MaterialFlags._BumpTextureEnabled = true;\r\n MaterialFlags._LightmapTextureEnabled = true;\r\n MaterialFlags._RefractionTextureEnabled = true;\r\n MaterialFlags._ColorGradingTextureEnabled = true;\r\n MaterialFlags._FresnelEnabled = true;\r\n MaterialFlags._ClearCoatTextureEnabled = true;\r\n MaterialFlags._ClearCoatBumpTextureEnabled = true;\r\n MaterialFlags._ClearCoatTintTextureEnabled = true;\r\n MaterialFlags._SheenTextureEnabled = true;\r\n MaterialFlags._AnisotropicTextureEnabled = true;\r\n MaterialFlags._ThicknessTextureEnabled = true;\r\n return MaterialFlags;\r\n}());\r\nexport { MaterialFlags };\r\n//# sourceMappingURL=materialFlags.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'defaultFragmentDeclaration';\r\nvar shader = \"uniform vec4 vDiffuseColor;\\n#ifdef SPECULARTERM\\nuniform vec4 vSpecularColor;\\n#endif\\nuniform vec3 vEmissiveColor;\\nuniform float visibility;\\n\\n#ifdef DIFFUSE\\nuniform vec2 vDiffuseInfos;\\n#endif\\n#ifdef AMBIENT\\nuniform vec2 vAmbientInfos;\\n#endif\\n#ifdef OPACITY\\nuniform vec2 vOpacityInfos;\\n#endif\\n#ifdef EMISSIVE\\nuniform vec2 vEmissiveInfos;\\n#endif\\n#ifdef LIGHTMAP\\nuniform vec2 vLightmapInfos;\\n#endif\\n#ifdef BUMP\\nuniform vec3 vBumpInfos;\\nuniform vec2 vTangentSpaceParams;\\n#endif\\n#if defined(REFLECTIONMAP_SPHERICAL) || defined(REFLECTIONMAP_PROJECTION) || defined(REFRACTION)\\nuniform mat4 view;\\n#endif\\n#ifdef REFRACTION\\nuniform vec4 vRefractionInfos;\\n#ifndef REFRACTIONMAP_3D\\nuniform mat4 refractionMatrix;\\n#endif\\n#ifdef REFRACTIONFRESNEL\\nuniform vec4 refractionLeftColor;\\nuniform vec4 refractionRightColor;\\n#endif\\n#endif\\n#if defined(SPECULAR) && defined(SPECULARTERM)\\nuniform vec2 vSpecularInfos;\\n#endif\\n#ifdef DIFFUSEFRESNEL\\nuniform vec4 diffuseLeftColor;\\nuniform vec4 diffuseRightColor;\\n#endif\\n#ifdef OPACITYFRESNEL\\nuniform vec4 opacityParts;\\n#endif\\n#ifdef EMISSIVEFRESNEL\\nuniform vec4 emissiveLeftColor;\\nuniform vec4 emissiveRightColor;\\n#endif\\n\\n#ifdef REFLECTION\\nuniform vec2 vReflectionInfos;\\n#if defined(REFLECTIONMAP_PLANAR) || defined(REFLECTIONMAP_CUBIC) || defined(REFLECTIONMAP_PROJECTION) || defined(REFLECTIONMAP_EQUIRECTANGULAR) || defined(REFLECTIONMAP_SPHERICAL) || defined(REFLECTIONMAP_SKYBOX)\\nuniform mat4 reflectionMatrix;\\n#endif\\n#ifndef REFLECTIONMAP_SKYBOX\\n#if defined(USE_LOCAL_REFLECTIONMAP_CUBIC) && defined(REFLECTIONMAP_CUBIC)\\nuniform vec3 vReflectionPosition;\\nuniform vec3 vReflectionSize;\\n#endif\\n#endif\\n#ifdef REFLECTIONFRESNEL\\nuniform vec4 reflectionLeftColor;\\nuniform vec4 reflectionRightColor;\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var defaultFragmentDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=defaultFragmentDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'defaultUboDeclaration';\r\nvar shader = \"layout(std140,column_major) uniform;\\nuniform Material\\n{\\nvec4 diffuseLeftColor;\\nvec4 diffuseRightColor;\\nvec4 opacityParts;\\nvec4 reflectionLeftColor;\\nvec4 reflectionRightColor;\\nvec4 refractionLeftColor;\\nvec4 refractionRightColor;\\nvec4 emissiveLeftColor;\\nvec4 emissiveRightColor;\\nvec2 vDiffuseInfos;\\nvec2 vAmbientInfos;\\nvec2 vOpacityInfos;\\nvec2 vReflectionInfos;\\nvec3 vReflectionPosition;\\nvec3 vReflectionSize;\\nvec2 vEmissiveInfos;\\nvec2 vLightmapInfos;\\nvec2 vSpecularInfos;\\nvec3 vBumpInfos;\\nmat4 diffuseMatrix;\\nmat4 ambientMatrix;\\nmat4 opacityMatrix;\\nmat4 reflectionMatrix;\\nmat4 emissiveMatrix;\\nmat4 lightmapMatrix;\\nmat4 specularMatrix;\\nmat4 bumpMatrix;\\nvec2 vTangentSpaceParams;\\nfloat pointSize;\\nmat4 refractionMatrix;\\nvec4 vRefractionInfos;\\nvec4 vSpecularColor;\\nvec3 vEmissiveColor;\\nfloat visibility;\\nvec4 vDiffuseColor;\\nvec4 vDetailInfos;\\nmat4 detailMatrix;\\n};\\nuniform Scene {\\nmat4 viewProjection;\\n#ifdef MULTIVIEW\\nmat4 viewProjectionR;\\n#endif\\nmat4 view;\\n};\\n\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var defaultUboDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=defaultUboDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'prePassDeclaration';\r\nvar shader = \"#ifdef PREPASS\\n#extension GL_EXT_draw_buffers : require\\n#ifdef WEBGL2\\nlayout(location=0) out highp vec4 glFragData[{X}];\\nhighp vec4 gl_FragColor;\\n#endif\\n#ifdef PREPASS_DEPTHNORMAL\\nvarying highp vec3 vViewPos;\\n#endif\\n#ifdef PREPASS_VELOCITY\\nvarying highp vec4 vCurrentPosition;\\nvarying highp vec4 vPreviousPosition;\\n#endif\\n#endif\\n\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var prePassDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=prePassDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'lightFragmentDeclaration';\r\nvar shader = \"#ifdef LIGHT{X}\\nuniform vec4 vLightData{X};\\nuniform vec4 vLightDiffuse{X};\\n#ifdef SPECULARTERM\\nuniform vec4 vLightSpecular{X};\\n#else\\nvec4 vLightSpecular{X}=vec4(0.);\\n#endif\\n#ifdef SHADOW{X}\\n#ifdef SHADOWCSM{X}\\nuniform mat4 lightMatrix{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float viewFrustumZ{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float frustumLengths{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float cascadeBlendFactor{X};\\nvarying vec4 vPositionFromLight{X}[SHADOWCSMNUM_CASCADES{X}];\\nvarying float vDepthMetric{X}[SHADOWCSMNUM_CASCADES{X}];\\nvarying vec4 vPositionFromCamera{X};\\n#if defined(SHADOWPCSS{X})\\nuniform highp sampler2DArrayShadow shadowSampler{X};\\nuniform highp sampler2DArray depthSampler{X};\\nuniform vec2 lightSizeUVCorrection{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float depthCorrection{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float penumbraDarkness{X};\\n#elif defined(SHADOWPCF{X})\\nuniform highp sampler2DArrayShadow shadowSampler{X};\\n#else\\nuniform highp sampler2DArray shadowSampler{X};\\n#endif\\n#ifdef SHADOWCSMDEBUG{X}\\nconst vec3 vCascadeColorsMultiplier{X}[8]=vec3[8]\\n(\\nvec3 ( 1.5,0.0,0.0 ),\\nvec3 ( 0.0,1.5,0.0 ),\\nvec3 ( 0.0,0.0,5.5 ),\\nvec3 ( 1.5,0.0,5.5 ),\\nvec3 ( 1.5,1.5,0.0 ),\\nvec3 ( 1.0,1.0,1.0 ),\\nvec3 ( 0.0,1.0,5.5 ),\\nvec3 ( 0.5,3.5,0.75 )\\n);\\nvec3 shadowDebug{X};\\n#endif\\n#ifdef SHADOWCSMUSESHADOWMAXZ{X}\\nint index{X}=-1;\\n#else\\nint index{X}=SHADOWCSMNUM_CASCADES{X}-1;\\n#endif\\nfloat diff{X}=0.;\\n#elif defined(SHADOWCUBE{X})\\nuniform samplerCube shadowSampler{X};\\n#else\\nvarying vec4 vPositionFromLight{X};\\nvarying float vDepthMetric{X};\\n#if defined(SHADOWPCSS{X})\\nuniform highp sampler2DShadow shadowSampler{X};\\nuniform highp sampler2D depthSampler{X};\\n#elif defined(SHADOWPCF{X})\\nuniform highp sampler2DShadow shadowSampler{X};\\n#else\\nuniform sampler2D shadowSampler{X};\\n#endif\\nuniform mat4 lightMatrix{X};\\n#endif\\nuniform vec4 shadowsInfo{X};\\nuniform vec2 depthValues{X};\\n#endif\\n#ifdef SPOTLIGHT{X}\\nuniform vec4 vLightDirection{X};\\nuniform vec4 vLightFalloff{X};\\n#elif defined(POINTLIGHT{X})\\nuniform vec4 vLightFalloff{X};\\n#elif defined(HEMILIGHT{X})\\nuniform vec3 vLightGround{X};\\n#endif\\n#ifdef PROJECTEDLIGHTTEXTURE{X}\\nuniform mat4 textureProjectionMatrix{X};\\nuniform sampler2D projectionLightSampler{X};\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var lightFragmentDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=lightFragmentDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'lightUboDeclaration';\r\nvar shader = \"#ifdef LIGHT{X}\\nuniform Light{X}\\n{\\nvec4 vLightData;\\nvec4 vLightDiffuse;\\nvec4 vLightSpecular;\\n#ifdef SPOTLIGHT{X}\\nvec4 vLightDirection;\\nvec4 vLightFalloff;\\n#elif defined(POINTLIGHT{X})\\nvec4 vLightFalloff;\\n#elif defined(HEMILIGHT{X})\\nvec3 vLightGround;\\n#endif\\nvec4 shadowsInfo;\\nvec2 depthValues;\\n} light{X};\\n#ifdef PROJECTEDLIGHTTEXTURE{X}\\nuniform mat4 textureProjectionMatrix{X};\\nuniform sampler2D projectionLightSampler{X};\\n#endif\\n#ifdef SHADOW{X}\\n#ifdef SHADOWCSM{X}\\nuniform mat4 lightMatrix{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float viewFrustumZ{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float frustumLengths{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float cascadeBlendFactor{X};\\nvarying vec4 vPositionFromLight{X}[SHADOWCSMNUM_CASCADES{X}];\\nvarying float vDepthMetric{X}[SHADOWCSMNUM_CASCADES{X}];\\nvarying vec4 vPositionFromCamera{X};\\n#if defined(SHADOWPCSS{X})\\nuniform highp sampler2DArrayShadow shadowSampler{X};\\nuniform highp sampler2DArray depthSampler{X};\\nuniform vec2 lightSizeUVCorrection{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float depthCorrection{X}[SHADOWCSMNUM_CASCADES{X}];\\nuniform float penumbraDarkness{X};\\n#elif defined(SHADOWPCF{X})\\nuniform highp sampler2DArrayShadow shadowSampler{X};\\n#else\\nuniform highp sampler2DArray shadowSampler{X};\\n#endif\\n#ifdef SHADOWCSMDEBUG{X}\\nconst vec3 vCascadeColorsMultiplier{X}[8]=vec3[8]\\n(\\nvec3 ( 1.5,0.0,0.0 ),\\nvec3 ( 0.0,1.5,0.0 ),\\nvec3 ( 0.0,0.0,5.5 ),\\nvec3 ( 1.5,0.0,5.5 ),\\nvec3 ( 1.5,1.5,0.0 ),\\nvec3 ( 1.0,1.0,1.0 ),\\nvec3 ( 0.0,1.0,5.5 ),\\nvec3 ( 0.5,3.5,0.75 )\\n);\\nvec3 shadowDebug{X};\\n#endif\\n#ifdef SHADOWCSMUSESHADOWMAXZ{X}\\nint index{X}=-1;\\n#else\\nint index{X}=SHADOWCSMNUM_CASCADES{X}-1;\\n#endif\\nfloat diff{X}=0.;\\n#elif defined(SHADOWCUBE{X})\\nuniform samplerCube shadowSampler{X};\\n#else\\nvarying vec4 vPositionFromLight{X};\\nvarying float vDepthMetric{X};\\n#if defined(SHADOWPCSS{X})\\nuniform highp sampler2DShadow shadowSampler{X};\\nuniform highp sampler2D depthSampler{X};\\n#elif defined(SHADOWPCF{X})\\nuniform highp sampler2DShadow shadowSampler{X};\\n#else\\nuniform sampler2D shadowSampler{X};\\n#endif\\nuniform mat4 lightMatrix{X};\\n#endif\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var lightUboDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=lightUboDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'lightsFragmentFunctions';\r\nvar shader = \"\\nstruct lightingInfo\\n{\\nvec3 diffuse;\\n#ifdef SPECULARTERM\\nvec3 specular;\\n#endif\\n#ifdef NDOTL\\nfloat ndl;\\n#endif\\n};\\nlightingInfo computeLighting(vec3 viewDirectionW,vec3 vNormal,vec4 lightData,vec3 diffuseColor,vec3 specularColor,float range,float glossiness) {\\nlightingInfo result;\\nvec3 lightVectorW;\\nfloat attenuation=1.0;\\nif (lightData.w == 0.)\\n{\\nvec3 direction=lightData.xyz-vPositionW;\\nattenuation=max(0.,1.0-length(direction)/range);\\nlightVectorW=normalize(direction);\\n}\\nelse\\n{\\nlightVectorW=normalize(-lightData.xyz);\\n}\\n\\nfloat ndl=max(0.,dot(vNormal,lightVectorW));\\n#ifdef NDOTL\\nresult.ndl=ndl;\\n#endif\\nresult.diffuse=ndl*diffuseColor*attenuation;\\n#ifdef SPECULARTERM\\n\\nvec3 angleW=normalize(viewDirectionW+lightVectorW);\\nfloat specComp=max(0.,dot(vNormal,angleW));\\nspecComp=pow(specComp,max(1.,glossiness));\\nresult.specular=specComp*specularColor*attenuation;\\n#endif\\nreturn result;\\n}\\nlightingInfo computeSpotLighting(vec3 viewDirectionW,vec3 vNormal,vec4 lightData,vec4 lightDirection,vec3 diffuseColor,vec3 specularColor,float range,float glossiness) {\\nlightingInfo result;\\nvec3 direction=lightData.xyz-vPositionW;\\nvec3 lightVectorW=normalize(direction);\\nfloat attenuation=max(0.,1.0-length(direction)/range);\\n\\nfloat cosAngle=max(0.,dot(lightDirection.xyz,-lightVectorW));\\nif (cosAngle>=lightDirection.w)\\n{\\ncosAngle=max(0.,pow(cosAngle,lightData.w));\\nattenuation*=cosAngle;\\n\\nfloat ndl=max(0.,dot(vNormal,lightVectorW));\\n#ifdef NDOTL\\nresult.ndl=ndl;\\n#endif\\nresult.diffuse=ndl*diffuseColor*attenuation;\\n#ifdef SPECULARTERM\\n\\nvec3 angleW=normalize(viewDirectionW+lightVectorW);\\nfloat specComp=max(0.,dot(vNormal,angleW));\\nspecComp=pow(specComp,max(1.,glossiness));\\nresult.specular=specComp*specularColor*attenuation;\\n#endif\\nreturn result;\\n}\\nresult.diffuse=vec3(0.);\\n#ifdef SPECULARTERM\\nresult.specular=vec3(0.);\\n#endif\\n#ifdef NDOTL\\nresult.ndl=0.;\\n#endif\\nreturn result;\\n}\\nlightingInfo computeHemisphericLighting(vec3 viewDirectionW,vec3 vNormal,vec4 lightData,vec3 diffuseColor,vec3 specularColor,vec3 groundColor,float glossiness) {\\nlightingInfo result;\\n\\nfloat ndl=dot(vNormal,lightData.xyz)*0.5+0.5;\\n#ifdef NDOTL\\nresult.ndl=ndl;\\n#endif\\nresult.diffuse=mix(groundColor,diffuseColor,ndl);\\n#ifdef SPECULARTERM\\n\\nvec3 angleW=normalize(viewDirectionW+lightData.xyz);\\nfloat specComp=max(0.,dot(vNormal,angleW));\\nspecComp=pow(specComp,max(1.,glossiness));\\nresult.specular=specComp*specularColor;\\n#endif\\nreturn result;\\n}\\n#define inline\\nvec3 computeProjectionTextureDiffuseLighting(sampler2D projectionLightSampler,mat4 textureProjectionMatrix){\\nvec4 strq=textureProjectionMatrix*vec4(vPositionW,1.0);\\nstrq/=strq.w;\\nvec3 textureColor=texture2D(projectionLightSampler,strq.xy).rgb;\\nreturn textureColor;\\n}\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var lightsFragmentFunctions = { name: name, shader: shader };\r\n//# sourceMappingURL=lightsFragmentFunctions.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'shadowsFragmentFunctions';\r\nvar shader = \"#ifdef SHADOWS\\n#ifndef SHADOWFLOAT\\n\\nfloat unpack(vec4 color)\\n{\\nconst vec4 bit_shift=vec4(1.0/(255.0*255.0*255.0),1.0/(255.0*255.0),1.0/255.0,1.0);\\nreturn dot(color,bit_shift);\\n}\\n#endif\\nfloat computeFallOff(float value,vec2 clipSpace,float frustumEdgeFalloff)\\n{\\nfloat mask=smoothstep(1.0-frustumEdgeFalloff,1.00000012,clamp(dot(clipSpace,clipSpace),0.,1.));\\nreturn mix(value,1.0,mask);\\n}\\n#define inline\\nfloat computeShadowCube(vec3 lightPosition,samplerCube shadowSampler,float darkness,vec2 depthValues)\\n{\\nvec3 directionToLight=vPositionW-lightPosition;\\nfloat depth=length(directionToLight);\\ndepth=(depth+depthValues.x)/(depthValues.y);\\ndepth=clamp(depth,0.,1.0);\\ndirectionToLight=normalize(directionToLight);\\ndirectionToLight.y=-directionToLight.y;\\n#ifndef SHADOWFLOAT\\nfloat shadow=unpack(textureCube(shadowSampler,directionToLight));\\n#else\\nfloat shadow=textureCube(shadowSampler,directionToLight).x;\\n#endif\\nreturn depth>shadow ? darkness : 1.0;\\n}\\n#define inline\\nfloat computeShadowWithPoissonSamplingCube(vec3 lightPosition,samplerCube shadowSampler,float mapSize,float darkness,vec2 depthValues)\\n{\\nvec3 directionToLight=vPositionW-lightPosition;\\nfloat depth=length(directionToLight);\\ndepth=(depth+depthValues.x)/(depthValues.y);\\ndepth=clamp(depth,0.,1.0);\\ndirectionToLight=normalize(directionToLight);\\ndirectionToLight.y=-directionToLight.y;\\nfloat visibility=1.;\\nvec3 poissonDisk[4];\\npoissonDisk[0]=vec3(-1.0,1.0,-1.0);\\npoissonDisk[1]=vec3(1.0,-1.0,-1.0);\\npoissonDisk[2]=vec3(-1.0,-1.0,-1.0);\\npoissonDisk[3]=vec3(1.0,-1.0,1.0);\\n\\n#ifndef SHADOWFLOAT\\nif (unpack(textureCube(shadowSampler,directionToLight+poissonDisk[0]*mapSize))shadow ? computeFallOff(darkness,clipSpace.xy,frustumEdgeFalloff) : 1.;\\n}\\n#endif\\n#define inline\\nfloat computeShadow(vec4 vPositionFromLight,float depthMetric,sampler2D shadowSampler,float darkness,float frustumEdgeFalloff)\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec2 uv=0.5*clipSpace.xy+vec2(0.5);\\nif (uv.x<0. || uv.x>1.0 || uv.y<0. || uv.y>1.0)\\n{\\nreturn 1.0;\\n}\\nelse\\n{\\nfloat shadowPixelDepth=clamp(depthMetric,0.,1.0);\\n#ifndef SHADOWFLOAT\\nfloat shadow=unpack(texture2D(shadowSampler,uv));\\n#else\\nfloat shadow=texture2D(shadowSampler,uv).x;\\n#endif\\nreturn shadowPixelDepth>shadow ? computeFallOff(darkness,clipSpace.xy,frustumEdgeFalloff) : 1.;\\n}\\n}\\n#define inline\\nfloat computeShadowWithPoissonSampling(vec4 vPositionFromLight,float depthMetric,sampler2D shadowSampler,float mapSize,float darkness,float frustumEdgeFalloff)\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec2 uv=0.5*clipSpace.xy+vec2(0.5);\\nif (uv.x<0. || uv.x>1.0 || uv.y<0. || uv.y>1.0)\\n{\\nreturn 1.0;\\n}\\nelse\\n{\\nfloat shadowPixelDepth=clamp(depthMetric,0.,1.0);\\nfloat visibility=1.;\\nvec2 poissonDisk[4];\\npoissonDisk[0]=vec2(-0.94201624,-0.39906216);\\npoissonDisk[1]=vec2(0.94558609,-0.76890725);\\npoissonDisk[2]=vec2(-0.094184101,-0.92938870);\\npoissonDisk[3]=vec2(0.34495938,0.29387760);\\n\\n#ifndef SHADOWFLOAT\\nif (unpack(texture2D(shadowSampler,uv+poissonDisk[0]*mapSize))1.0 || uv.y<0. || uv.y>1.0)\\n{\\nreturn 1.0;\\n}\\nelse\\n{\\nfloat shadowPixelDepth=clamp(depthMetric,0.,1.0);\\n#ifndef SHADOWFLOAT\\nfloat shadowMapSample=unpack(texture2D(shadowSampler,uv));\\n#else\\nfloat shadowMapSample=texture2D(shadowSampler,uv).x;\\n#endif\\nfloat esm=1.0-clamp(exp(min(87.,depthScale*shadowPixelDepth))*shadowMapSample,0.,1.-darkness);\\nreturn computeFallOff(esm,clipSpace.xy,frustumEdgeFalloff);\\n}\\n}\\n#define inline\\nfloat computeShadowWithCloseESM(vec4 vPositionFromLight,float depthMetric,sampler2D shadowSampler,float darkness,float depthScale,float frustumEdgeFalloff)\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec2 uv=0.5*clipSpace.xy+vec2(0.5);\\nif (uv.x<0. || uv.x>1.0 || uv.y<0. || uv.y>1.0)\\n{\\nreturn 1.0;\\n}\\nelse\\n{\\nfloat shadowPixelDepth=clamp(depthMetric,0.,1.0);\\n#ifndef SHADOWFLOAT\\nfloat shadowMapSample=unpack(texture2D(shadowSampler,uv));\\n#else\\nfloat shadowMapSample=texture2D(shadowSampler,uv).x;\\n#endif\\nfloat esm=clamp(exp(min(87.,-depthScale*(shadowPixelDepth-shadowMapSample))),darkness,1.);\\nreturn computeFallOff(esm,clipSpace.xy,frustumEdgeFalloff);\\n}\\n}\\n#ifdef WEBGL2\\n#define GREATEST_LESS_THAN_ONE 0.99999994\\n\\n#define inline\\nfloat computeShadowWithCSMPCF1(float layer,vec4 vPositionFromLight,float depthMetric,highp sampler2DArrayShadow shadowSampler,float darkness,float frustumEdgeFalloff)\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec3 uvDepth=vec3(0.5*clipSpace.xyz+vec3(0.5));\\nuvDepth.z=clamp(uvDepth.z,0.,GREATEST_LESS_THAN_ONE);\\nvec4 uvDepthLayer=vec4(uvDepth.x,uvDepth.y,layer,uvDepth.z);\\nfloat shadow=texture(shadowSampler,uvDepthLayer);\\nshadow=mix(darkness,1.,shadow);\\nreturn computeFallOff(shadow,clipSpace.xy,frustumEdgeFalloff);\\n}\\n\\n\\n\\n#define inline\\nfloat computeShadowWithCSMPCF3(float layer,vec4 vPositionFromLight,float depthMetric,highp sampler2DArrayShadow shadowSampler,vec2 shadowMapSizeAndInverse,float darkness,float frustumEdgeFalloff)\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec3 uvDepth=vec3(0.5*clipSpace.xyz+vec3(0.5));\\nuvDepth.z=clamp(uvDepth.z,0.,GREATEST_LESS_THAN_ONE);\\nvec2 uv=uvDepth.xy*shadowMapSizeAndInverse.x;\\nuv+=0.5;\\nvec2 st=fract(uv);\\nvec2 base_uv=floor(uv)-0.5;\\nbase_uv*=shadowMapSizeAndInverse.y;\\n\\n\\n\\n\\nvec2 uvw0=3.-2.*st;\\nvec2 uvw1=1.+2.*st;\\nvec2 u=vec2((2.-st.x)/uvw0.x-1.,st.x/uvw1.x+1.)*shadowMapSizeAndInverse.y;\\nvec2 v=vec2((2.-st.y)/uvw0.y-1.,st.y/uvw1.y+1.)*shadowMapSizeAndInverse.y;\\nfloat shadow=0.;\\nshadow+=uvw0.x*uvw0.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[0],v[0]),layer,uvDepth.z));\\nshadow+=uvw1.x*uvw0.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[1],v[0]),layer,uvDepth.z));\\nshadow+=uvw0.x*uvw1.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[0],v[1]),layer,uvDepth.z));\\nshadow+=uvw1.x*uvw1.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[1],v[1]),layer,uvDepth.z));\\nshadow=shadow/16.;\\nshadow=mix(darkness,1.,shadow);\\nreturn computeFallOff(shadow,clipSpace.xy,frustumEdgeFalloff);\\n}\\n\\n\\n\\n#define inline\\nfloat computeShadowWithCSMPCF5(float layer,vec4 vPositionFromLight,float depthMetric,highp sampler2DArrayShadow shadowSampler,vec2 shadowMapSizeAndInverse,float darkness,float frustumEdgeFalloff)\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec3 uvDepth=vec3(0.5*clipSpace.xyz+vec3(0.5));\\nuvDepth.z=clamp(uvDepth.z,0.,GREATEST_LESS_THAN_ONE);\\nvec2 uv=uvDepth.xy*shadowMapSizeAndInverse.x;\\nuv+=0.5;\\nvec2 st=fract(uv);\\nvec2 base_uv=floor(uv)-0.5;\\nbase_uv*=shadowMapSizeAndInverse.y;\\n\\n\\nvec2 uvw0=4.-3.*st;\\nvec2 uvw1=vec2(7.);\\nvec2 uvw2=1.+3.*st;\\nvec3 u=vec3((3.-2.*st.x)/uvw0.x-2.,(3.+st.x)/uvw1.x,st.x/uvw2.x+2.)*shadowMapSizeAndInverse.y;\\nvec3 v=vec3((3.-2.*st.y)/uvw0.y-2.,(3.+st.y)/uvw1.y,st.y/uvw2.y+2.)*shadowMapSizeAndInverse.y;\\nfloat shadow=0.;\\nshadow+=uvw0.x*uvw0.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[0],v[0]),layer,uvDepth.z));\\nshadow+=uvw1.x*uvw0.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[1],v[0]),layer,uvDepth.z));\\nshadow+=uvw2.x*uvw0.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[2],v[0]),layer,uvDepth.z));\\nshadow+=uvw0.x*uvw1.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[0],v[1]),layer,uvDepth.z));\\nshadow+=uvw1.x*uvw1.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[1],v[1]),layer,uvDepth.z));\\nshadow+=uvw2.x*uvw1.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[2],v[1]),layer,uvDepth.z));\\nshadow+=uvw0.x*uvw2.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[0],v[2]),layer,uvDepth.z));\\nshadow+=uvw1.x*uvw2.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[1],v[2]),layer,uvDepth.z));\\nshadow+=uvw2.x*uvw2.y*texture2D(shadowSampler,vec4(base_uv.xy+vec2(u[2],v[2]),layer,uvDepth.z));\\nshadow=shadow/144.;\\nshadow=mix(darkness,1.,shadow);\\nreturn computeFallOff(shadow,clipSpace.xy,frustumEdgeFalloff);\\n}\\n\\n#define inline\\nfloat computeShadowWithPCF1(vec4 vPositionFromLight,float depthMetric,sampler2DShadow shadowSampler,float darkness,float frustumEdgeFalloff)\\n{\\nif (depthMetric>1.0 || depthMetric<0.0) {\\nreturn 1.0;\\n}\\nelse\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec3 uvDepth=vec3(0.5*clipSpace.xyz+vec3(0.5));\\nfloat shadow=texture2D(shadowSampler,uvDepth);\\nshadow=mix(darkness,1.,shadow);\\nreturn computeFallOff(shadow,clipSpace.xy,frustumEdgeFalloff);\\n}\\n}\\n\\n\\n\\n#define inline\\nfloat computeShadowWithPCF3(vec4 vPositionFromLight,float depthMetric,sampler2DShadow shadowSampler,vec2 shadowMapSizeAndInverse,float darkness,float frustumEdgeFalloff)\\n{\\nif (depthMetric>1.0 || depthMetric<0.0) {\\nreturn 1.0;\\n}\\nelse\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec3 uvDepth=vec3(0.5*clipSpace.xyz+vec3(0.5));\\nvec2 uv=uvDepth.xy*shadowMapSizeAndInverse.x;\\nuv+=0.5;\\nvec2 st=fract(uv);\\nvec2 base_uv=floor(uv)-0.5;\\nbase_uv*=shadowMapSizeAndInverse.y;\\n\\n\\n\\n\\nvec2 uvw0=3.-2.*st;\\nvec2 uvw1=1.+2.*st;\\nvec2 u=vec2((2.-st.x)/uvw0.x-1.,st.x/uvw1.x+1.)*shadowMapSizeAndInverse.y;\\nvec2 v=vec2((2.-st.y)/uvw0.y-1.,st.y/uvw1.y+1.)*shadowMapSizeAndInverse.y;\\nfloat shadow=0.;\\nshadow+=uvw0.x*uvw0.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[0],v[0]),uvDepth.z));\\nshadow+=uvw1.x*uvw0.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[1],v[0]),uvDepth.z));\\nshadow+=uvw0.x*uvw1.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[0],v[1]),uvDepth.z));\\nshadow+=uvw1.x*uvw1.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[1],v[1]),uvDepth.z));\\nshadow=shadow/16.;\\nshadow=mix(darkness,1.,shadow);\\nreturn computeFallOff(shadow,clipSpace.xy,frustumEdgeFalloff);\\n}\\n}\\n\\n\\n\\n#define inline\\nfloat computeShadowWithPCF5(vec4 vPositionFromLight,float depthMetric,sampler2DShadow shadowSampler,vec2 shadowMapSizeAndInverse,float darkness,float frustumEdgeFalloff)\\n{\\nif (depthMetric>1.0 || depthMetric<0.0) {\\nreturn 1.0;\\n}\\nelse\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec3 uvDepth=vec3(0.5*clipSpace.xyz+vec3(0.5));\\nvec2 uv=uvDepth.xy*shadowMapSizeAndInverse.x;\\nuv+=0.5;\\nvec2 st=fract(uv);\\nvec2 base_uv=floor(uv)-0.5;\\nbase_uv*=shadowMapSizeAndInverse.y;\\n\\n\\nvec2 uvw0=4.-3.*st;\\nvec2 uvw1=vec2(7.);\\nvec2 uvw2=1.+3.*st;\\nvec3 u=vec3((3.-2.*st.x)/uvw0.x-2.,(3.+st.x)/uvw1.x,st.x/uvw2.x+2.)*shadowMapSizeAndInverse.y;\\nvec3 v=vec3((3.-2.*st.y)/uvw0.y-2.,(3.+st.y)/uvw1.y,st.y/uvw2.y+2.)*shadowMapSizeAndInverse.y;\\nfloat shadow=0.;\\nshadow+=uvw0.x*uvw0.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[0],v[0]),uvDepth.z));\\nshadow+=uvw1.x*uvw0.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[1],v[0]),uvDepth.z));\\nshadow+=uvw2.x*uvw0.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[2],v[0]),uvDepth.z));\\nshadow+=uvw0.x*uvw1.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[0],v[1]),uvDepth.z));\\nshadow+=uvw1.x*uvw1.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[1],v[1]),uvDepth.z));\\nshadow+=uvw2.x*uvw1.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[2],v[1]),uvDepth.z));\\nshadow+=uvw0.x*uvw2.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[0],v[2]),uvDepth.z));\\nshadow+=uvw1.x*uvw2.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[1],v[2]),uvDepth.z));\\nshadow+=uvw2.x*uvw2.y*texture2D(shadowSampler,vec3(base_uv.xy+vec2(u[2],v[2]),uvDepth.z));\\nshadow=shadow/144.;\\nshadow=mix(darkness,1.,shadow);\\nreturn computeFallOff(shadow,clipSpace.xy,frustumEdgeFalloff);\\n}\\n}\\nconst vec3 PoissonSamplers32[64]=vec3[64](\\nvec3(0.06407013,0.05409927,0.),\\nvec3(0.7366577,0.5789394,0.),\\nvec3(-0.6270542,-0.5320278,0.),\\nvec3(-0.4096107,0.8411095,0.),\\nvec3(0.6849564,-0.4990818,0.),\\nvec3(-0.874181,-0.04579735,0.),\\nvec3(0.9989998,0.0009880066,0.),\\nvec3(-0.004920578,-0.9151649,0.),\\nvec3(0.1805763,0.9747483,0.),\\nvec3(-0.2138451,0.2635818,0.),\\nvec3(0.109845,0.3884785,0.),\\nvec3(0.06876755,-0.3581074,0.),\\nvec3(0.374073,-0.7661266,0.),\\nvec3(0.3079132,-0.1216763,0.),\\nvec3(-0.3794335,-0.8271583,0.),\\nvec3(-0.203878,-0.07715034,0.),\\nvec3(0.5912697,0.1469799,0.),\\nvec3(-0.88069,0.3031784,0.),\\nvec3(0.5040108,0.8283722,0.),\\nvec3(-0.5844124,0.5494877,0.),\\nvec3(0.6017799,-0.1726654,0.),\\nvec3(-0.5554981,0.1559997,0.),\\nvec3(-0.3016369,-0.3900928,0.),\\nvec3(-0.5550632,-0.1723762,0.),\\nvec3(0.925029,0.2995041,0.),\\nvec3(-0.2473137,0.5538505,0.),\\nvec3(0.9183037,-0.2862392,0.),\\nvec3(0.2469421,0.6718712,0.),\\nvec3(0.3916397,-0.4328209,0.),\\nvec3(-0.03576927,-0.6220032,0.),\\nvec3(-0.04661255,0.7995201,0.),\\nvec3(0.4402924,0.3640312,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.),\\nvec3(0.,0.,0.)\\n);\\nconst vec3 PoissonSamplers64[64]=vec3[64](\\nvec3(-0.613392,0.617481,0.),\\nvec3(0.170019,-0.040254,0.),\\nvec3(-0.299417,0.791925,0.),\\nvec3(0.645680,0.493210,0.),\\nvec3(-0.651784,0.717887,0.),\\nvec3(0.421003,0.027070,0.),\\nvec3(-0.817194,-0.271096,0.),\\nvec3(-0.705374,-0.668203,0.),\\nvec3(0.977050,-0.108615,0.),\\nvec3(0.063326,0.142369,0.),\\nvec3(0.203528,0.214331,0.),\\nvec3(-0.667531,0.326090,0.),\\nvec3(-0.098422,-0.295755,0.),\\nvec3(-0.885922,0.215369,0.),\\nvec3(0.566637,0.605213,0.),\\nvec3(0.039766,-0.396100,0.),\\nvec3(0.751946,0.453352,0.),\\nvec3(0.078707,-0.715323,0.),\\nvec3(-0.075838,-0.529344,0.),\\nvec3(0.724479,-0.580798,0.),\\nvec3(0.222999,-0.215125,0.),\\nvec3(-0.467574,-0.405438,0.),\\nvec3(-0.248268,-0.814753,0.),\\nvec3(0.354411,-0.887570,0.),\\nvec3(0.175817,0.382366,0.),\\nvec3(0.487472,-0.063082,0.),\\nvec3(-0.084078,0.898312,0.),\\nvec3(0.488876,-0.783441,0.),\\nvec3(0.470016,0.217933,0.),\\nvec3(-0.696890,-0.549791,0.),\\nvec3(-0.149693,0.605762,0.),\\nvec3(0.034211,0.979980,0.),\\nvec3(0.503098,-0.308878,0.),\\nvec3(-0.016205,-0.872921,0.),\\nvec3(0.385784,-0.393902,0.),\\nvec3(-0.146886,-0.859249,0.),\\nvec3(0.643361,0.164098,0.),\\nvec3(0.634388,-0.049471,0.),\\nvec3(-0.688894,0.007843,0.),\\nvec3(0.464034,-0.188818,0.),\\nvec3(-0.440840,0.137486,0.),\\nvec3(0.364483,0.511704,0.),\\nvec3(0.034028,0.325968,0.),\\nvec3(0.099094,-0.308023,0.),\\nvec3(0.693960,-0.366253,0.),\\nvec3(0.678884,-0.204688,0.),\\nvec3(0.001801,0.780328,0.),\\nvec3(0.145177,-0.898984,0.),\\nvec3(0.062655,-0.611866,0.),\\nvec3(0.315226,-0.604297,0.),\\nvec3(-0.780145,0.486251,0.),\\nvec3(-0.371868,0.882138,0.),\\nvec3(0.200476,0.494430,0.),\\nvec3(-0.494552,-0.711051,0.),\\nvec3(0.612476,0.705252,0.),\\nvec3(-0.578845,-0.768792,0.),\\nvec3(-0.772454,-0.090976,0.),\\nvec3(0.504440,0.372295,0.),\\nvec3(0.155736,0.065157,0.),\\nvec3(0.391522,0.849605,0.),\\nvec3(-0.620106,-0.328104,0.),\\nvec3(0.789239,-0.419965,0.),\\nvec3(-0.545396,0.538133,0.),\\nvec3(-0.178564,-0.596057,0.)\\n);\\n\\n\\n\\n\\n\\n#define inline\\nfloat computeShadowWithCSMPCSS(float layer,vec4 vPositionFromLight,float depthMetric,highp sampler2DArray depthSampler,highp sampler2DArrayShadow shadowSampler,float shadowMapSizeInverse,float lightSizeUV,float darkness,float frustumEdgeFalloff,int searchTapCount,int pcfTapCount,vec3[64] poissonSamplers,vec2 lightSizeUVCorrection,float depthCorrection,float penumbraDarkness)\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec3 uvDepth=vec3(0.5*clipSpace.xyz+vec3(0.5));\\nuvDepth.z=clamp(uvDepth.z,0.,GREATEST_LESS_THAN_ONE);\\nvec4 uvDepthLayer=vec4(uvDepth.x,uvDepth.y,layer,uvDepth.z);\\nfloat blockerDepth=0.0;\\nfloat sumBlockerDepth=0.0;\\nfloat numBlocker=0.0;\\nfor (int i=0; i1.0 || depthMetric<0.0) {\\nreturn 1.0;\\n}\\nelse\\n{\\nvec3 clipSpace=vPositionFromLight.xyz/vPositionFromLight.w;\\nvec3 uvDepth=vec3(0.5*clipSpace.xyz+vec3(0.5));\\nfloat blockerDepth=0.0;\\nfloat sumBlockerDepth=0.0;\\nfloat numBlocker=0.0;\\nfor (int i=0; icurrRayHeight)\\n{\\nfloat delta1=currSampledHeight-currRayHeight;\\nfloat delta2=(currRayHeight+stepSize)-lastSampledHeight;\\nfloat ratio=delta1/(delta1+delta2);\\nvCurrOffset=(ratio)* vLastOffset+(1.0-ratio)*vCurrOffset;\\n\\nbreak;\\n}\\nelse\\n{\\ncurrRayHeight-=stepSize;\\nvLastOffset=vCurrOffset;\\nvCurrOffset+=stepSize*vMaxOffset;\\nlastSampledHeight=currSampledHeight;\\n}\\n}\\nreturn vCurrOffset;\\n}\\nvec2 parallaxOffset(vec3 viewDir,float heightScale)\\n{\\n\\nfloat height=texture2D(bumpSampler,vBumpUV).w;\\nvec2 texCoordOffset=heightScale*viewDir.xy*height;\\nreturn -texCoordOffset;\\n}\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var bumpFragmentFunctions = { name: name, shader: shader };\r\n//# sourceMappingURL=bumpFragmentFunctions.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'logDepthDeclaration';\r\nvar shader = \"#ifdef LOGARITHMICDEPTH\\nuniform float logarithmicDepthConstant;\\nvarying float vFragmentDepth;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var logDepthDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=logDepthDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'fogFragmentDeclaration';\r\nvar shader = \"#ifdef FOG\\n#define FOGMODE_NONE 0.\\n#define FOGMODE_EXP 1.\\n#define FOGMODE_EXP2 2.\\n#define FOGMODE_LINEAR 3.\\n#define E 2.71828\\nuniform vec4 vFogInfos;\\nuniform vec3 vFogColor;\\nvarying vec3 vFogDistance;\\nfloat CalcFogFactor()\\n{\\nfloat fogCoeff=1.0;\\nfloat fogStart=vFogInfos.y;\\nfloat fogEnd=vFogInfos.z;\\nfloat fogDensity=vFogInfos.w;\\nfloat fogDistance=length(vFogDistance);\\nif (FOGMODE_LINEAR == vFogInfos.x)\\n{\\nfogCoeff=(fogEnd-fogDistance)/(fogEnd-fogStart);\\n}\\nelse if (FOGMODE_EXP == vFogInfos.x)\\n{\\nfogCoeff=1.0/pow(E,fogDistance*fogDensity);\\n}\\nelse if (FOGMODE_EXP2 == vFogInfos.x)\\n{\\nfogCoeff=1.0/pow(E,fogDistance*fogDistance*fogDensity*fogDensity);\\n}\\nreturn clamp(fogCoeff,0.0,1.0);\\n}\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var fogFragmentDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=fogFragmentDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'bumpFragment';\r\nvar shader = \"vec2 uvOffset=vec2(0.0,0.0);\\n#if defined(BUMP) || defined(PARALLAX) || defined(DETAIL)\\n#ifdef NORMALXYSCALE\\nfloat normalScale=1.0;\\n#elif defined(BUMP)\\nfloat normalScale=vBumpInfos.y;\\n#else\\nfloat normalScale=1.0;\\n#endif\\n#if defined(TANGENT) && defined(NORMAL)\\nmat3 TBN=vTBN;\\n#elif defined(BUMP)\\nmat3 TBN=cotangent_frame(normalW*normalScale,vPositionW,vBumpUV);\\n#else\\nmat3 TBN=cotangent_frame(normalW*normalScale,vPositionW,vDetailUV,vec2(1.,1.));\\n#endif\\n#elif defined(ANISOTROPIC)\\n#if defined(TANGENT) && defined(NORMAL)\\nmat3 TBN=vTBN;\\n#else\\nmat3 TBN=cotangent_frame(normalW,vPositionW,vMainUV1,vec2(1.,1.));\\n#endif\\n#endif\\n#ifdef PARALLAX\\nmat3 invTBN=transposeMat3(TBN);\\n#ifdef PARALLAXOCCLUSION\\nuvOffset=parallaxOcclusion(invTBN*-viewDirectionW,invTBN*normalW,vBumpUV,vBumpInfos.z);\\n#else\\nuvOffset=parallaxOffset(invTBN*viewDirectionW,vBumpInfos.z);\\n#endif\\n#endif\\n#ifdef DETAIL\\nvec4 detailColor=texture2D(detailSampler,vDetailUV+uvOffset);\\nvec2 detailNormalRG=detailColor.wy*2.0-1.0;\\nfloat detailNormalB=sqrt(1.-saturate(dot(detailNormalRG,detailNormalRG)));\\nvec3 detailNormal=vec3(detailNormalRG,detailNormalB);\\n#endif\\n#ifdef BUMP\\n#ifdef OBJECTSPACE_NORMALMAP\\nnormalW=normalize(texture2D(bumpSampler,vBumpUV).xyz*2.0-1.0);\\nnormalW=normalize(mat3(normalMatrix)*normalW);\\n#elif !defined(DETAIL)\\nnormalW=perturbNormal(TBN,vBumpUV+uvOffset);\\n#else\\nvec3 bumpNormal=texture2D(bumpSampler,vBumpUV+uvOffset).xyz*2.0-1.0;\\n\\n#if DETAIL_NORMALBLENDMETHOD == 0\\ndetailNormal.xy*=vDetailInfos.z;\\nvec3 blendedNormal=normalize(vec3(bumpNormal.xy+detailNormal.xy,bumpNormal.z*detailNormal.z));\\n#elif DETAIL_NORMALBLENDMETHOD == 1\\ndetailNormal.xy*=vDetailInfos.z;\\nbumpNormal+=vec3(0.0,0.0,1.0);\\ndetailNormal*=vec3(-1.0,-1.0,1.0);\\nvec3 blendedNormal=bumpNormal*dot(bumpNormal,detailNormal)/bumpNormal.z-detailNormal;\\n#endif\\nnormalW=perturbNormalBase(TBN,blendedNormal,vBumpInfos.y);\\n#endif\\n#elif defined(DETAIL)\\ndetailNormal.xy*=vDetailInfos.z;\\nnormalW=perturbNormalBase(TBN,detailNormal,vDetailInfos.z);\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var bumpFragment = { name: name, shader: shader };\r\n//# sourceMappingURL=bumpFragment.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'depthPrePass';\r\nvar shader = \"#ifdef DEPTHPREPASS\\ngl_FragColor=vec4(0.,0.,0.,1.0);\\nreturn;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var depthPrePass = { name: name, shader: shader };\r\n//# sourceMappingURL=depthPrePass.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'lightFragment';\r\nvar shader = \"#ifdef LIGHT{X}\\n#if defined(SHADOWONLY) || defined(LIGHTMAP) && defined(LIGHTMAPEXCLUDED{X}) && defined(LIGHTMAPNOSPECULAR{X})\\n\\n#else\\n#ifdef PBR\\n\\n#ifdef SPOTLIGHT{X}\\npreInfo=computePointAndSpotPreLightingInfo(light{X}.vLightData,viewDirectionW,normalW);\\n#elif defined(POINTLIGHT{X})\\npreInfo=computePointAndSpotPreLightingInfo(light{X}.vLightData,viewDirectionW,normalW);\\n#elif defined(HEMILIGHT{X})\\npreInfo=computeHemisphericPreLightingInfo(light{X}.vLightData,viewDirectionW,normalW);\\n#elif defined(DIRLIGHT{X})\\npreInfo=computeDirectionalPreLightingInfo(light{X}.vLightData,viewDirectionW,normalW);\\n#endif\\npreInfo.NdotV=NdotV;\\n\\n#ifdef SPOTLIGHT{X}\\n#ifdef LIGHT_FALLOFF_GLTF{X}\\npreInfo.attenuation=computeDistanceLightFalloff_GLTF(preInfo.lightDistanceSquared,light{X}.vLightFalloff.y);\\npreInfo.attenuation*=computeDirectionalLightFalloff_GLTF(light{X}.vLightDirection.xyz,preInfo.L,light{X}.vLightFalloff.z,light{X}.vLightFalloff.w);\\n#elif defined(LIGHT_FALLOFF_PHYSICAL{X})\\npreInfo.attenuation=computeDistanceLightFalloff_Physical(preInfo.lightDistanceSquared);\\npreInfo.attenuation*=computeDirectionalLightFalloff_Physical(light{X}.vLightDirection.xyz,preInfo.L,light{X}.vLightDirection.w);\\n#elif defined(LIGHT_FALLOFF_STANDARD{X})\\npreInfo.attenuation=computeDistanceLightFalloff_Standard(preInfo.lightOffset,light{X}.vLightFalloff.x);\\npreInfo.attenuation*=computeDirectionalLightFalloff_Standard(light{X}.vLightDirection.xyz,preInfo.L,light{X}.vLightDirection.w,light{X}.vLightData.w);\\n#else\\npreInfo.attenuation=computeDistanceLightFalloff(preInfo.lightOffset,preInfo.lightDistanceSquared,light{X}.vLightFalloff.x,light{X}.vLightFalloff.y);\\npreInfo.attenuation*=computeDirectionalLightFalloff(light{X}.vLightDirection.xyz,preInfo.L,light{X}.vLightDirection.w,light{X}.vLightData.w,light{X}.vLightFalloff.z,light{X}.vLightFalloff.w);\\n#endif\\n#elif defined(POINTLIGHT{X})\\n#ifdef LIGHT_FALLOFF_GLTF{X}\\npreInfo.attenuation=computeDistanceLightFalloff_GLTF(preInfo.lightDistanceSquared,light{X}.vLightFalloff.y);\\n#elif defined(LIGHT_FALLOFF_PHYSICAL{X})\\npreInfo.attenuation=computeDistanceLightFalloff_Physical(preInfo.lightDistanceSquared);\\n#elif defined(LIGHT_FALLOFF_STANDARD{X})\\npreInfo.attenuation=computeDistanceLightFalloff_Standard(preInfo.lightOffset,light{X}.vLightFalloff.x);\\n#else\\npreInfo.attenuation=computeDistanceLightFalloff(preInfo.lightOffset,preInfo.lightDistanceSquared,light{X}.vLightFalloff.x,light{X}.vLightFalloff.y);\\n#endif\\n#else\\npreInfo.attenuation=1.0;\\n#endif\\n\\n\\n#ifdef HEMILIGHT{X}\\npreInfo.roughness=roughness;\\n#else\\npreInfo.roughness=adjustRoughnessFromLightProperties(roughness,light{X}.vLightSpecular.a,preInfo.lightDistance);\\n#endif\\n\\n#ifdef HEMILIGHT{X}\\ninfo.diffuse=computeHemisphericDiffuseLighting(preInfo,light{X}.vLightDiffuse.rgb,light{X}.vLightGround);\\n#elif defined(SS_TRANSLUCENCY)\\ninfo.diffuse=computeDiffuseAndTransmittedLighting(preInfo,light{X}.vLightDiffuse.rgb,subSurfaceOut.transmittance);\\n#else\\ninfo.diffuse=computeDiffuseLighting(preInfo,light{X}.vLightDiffuse.rgb);\\n#endif\\n\\n#ifdef SPECULARTERM\\n#ifdef ANISOTROPIC\\ninfo.specular=computeAnisotropicSpecularLighting(preInfo,viewDirectionW,normalW,anisotropicOut.anisotropicTangent,anisotropicOut.anisotropicBitangent,anisotropicOut.anisotropy,clearcoatOut.specularEnvironmentR0,specularEnvironmentR90,AARoughnessFactors.x,light{X}.vLightDiffuse.rgb);\\n#else\\ninfo.specular=computeSpecularLighting(preInfo,normalW,clearcoatOut.specularEnvironmentR0,specularEnvironmentR90,AARoughnessFactors.x,light{X}.vLightDiffuse.rgb);\\n#endif\\n#endif\\n\\n#ifdef SHEEN\\n#ifdef SHEEN_LINKWITHALBEDO\\n\\npreInfo.roughness=sheenOut.sheenIntensity;\\n#else\\n#ifdef HEMILIGHT{X}\\npreInfo.roughness=sheenOut.sheenRoughness;\\n#else\\npreInfo.roughness=adjustRoughnessFromLightProperties(sheenOut.sheenRoughness,light{X}.vLightSpecular.a,preInfo.lightDistance);\\n#endif\\n#endif\\ninfo.sheen=computeSheenLighting(preInfo,normalW,sheenOut.sheenColor,specularEnvironmentR90,AARoughnessFactors.x,light{X}.vLightDiffuse.rgb);\\n#endif\\n\\n#ifdef CLEARCOAT\\n\\n#ifdef HEMILIGHT{X}\\npreInfo.roughness=clearcoatOut.clearCoatRoughness;\\n#else\\npreInfo.roughness=adjustRoughnessFromLightProperties(clearcoatOut.clearCoatRoughness,light{X}.vLightSpecular.a,preInfo.lightDistance);\\n#endif\\ninfo.clearCoat=computeClearCoatLighting(preInfo,clearcoatOut.clearCoatNormalW,clearcoatOut.clearCoatAARoughnessFactors.x,clearcoatOut.clearCoatIntensity,light{X}.vLightDiffuse.rgb);\\n#ifdef CLEARCOAT_TINT\\n\\nabsorption=computeClearCoatLightingAbsorption(clearcoatOut.clearCoatNdotVRefract,preInfo.L,clearcoatOut.clearCoatNormalW,clearcoatOut.clearCoatColor,clearcoatOut.clearCoatThickness,clearcoatOut.clearCoatIntensity);\\ninfo.diffuse*=absorption;\\n#ifdef SPECULARTERM\\ninfo.specular*=absorption;\\n#endif\\n#endif\\n\\ninfo.diffuse*=info.clearCoat.w;\\n#ifdef SPECULARTERM\\ninfo.specular*=info.clearCoat.w;\\n#endif\\n#ifdef SHEEN\\ninfo.sheen*=info.clearCoat.w;\\n#endif\\n#endif\\n#else\\n#ifdef SPOTLIGHT{X}\\ninfo=computeSpotLighting(viewDirectionW,normalW,light{X}.vLightData,light{X}.vLightDirection,light{X}.vLightDiffuse.rgb,light{X}.vLightSpecular.rgb,light{X}.vLightDiffuse.a,glossiness);\\n#elif defined(HEMILIGHT{X})\\ninfo=computeHemisphericLighting(viewDirectionW,normalW,light{X}.vLightData,light{X}.vLightDiffuse.rgb,light{X}.vLightSpecular.rgb,light{X}.vLightGround,glossiness);\\n#elif defined(POINTLIGHT{X}) || defined(DIRLIGHT{X})\\ninfo=computeLighting(viewDirectionW,normalW,light{X}.vLightData,light{X}.vLightDiffuse.rgb,light{X}.vLightSpecular.rgb,light{X}.vLightDiffuse.a,glossiness);\\n#endif\\n#endif\\n#ifdef PROJECTEDLIGHTTEXTURE{X}\\ninfo.diffuse*=computeProjectionTextureDiffuseLighting(projectionLightSampler{X},textureProjectionMatrix{X});\\n#endif\\n#endif\\n#ifdef SHADOW{X}\\n#ifdef SHADOWCSM{X}\\nfor (int i=0; i=0.) {\\nindex{X}=i;\\nbreak;\\n}\\n}\\n#ifdef SHADOWCSMUSESHADOWMAXZ{X}\\nif (index{X}>=0)\\n#endif\\n{\\n#if defined(SHADOWPCF{X})\\n#if defined(SHADOWLOWQUALITY{X})\\nshadow=computeShadowWithCSMPCF1(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#elif defined(SHADOWMEDIUMQUALITY{X})\\nshadow=computeShadowWithCSMPCF3(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],shadowSampler{X},light{X}.shadowsInfo.yz,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#else\\nshadow=computeShadowWithCSMPCF5(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],shadowSampler{X},light{X}.shadowsInfo.yz,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#endif\\n#elif defined(SHADOWPCSS{X})\\n#if defined(SHADOWLOWQUALITY{X})\\nshadow=computeShadowWithCSMPCSS16(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w,lightSizeUVCorrection{X}[index{X}],depthCorrection{X}[index{X}],penumbraDarkness{X});\\n#elif defined(SHADOWMEDIUMQUALITY{X})\\nshadow=computeShadowWithCSMPCSS32(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w,lightSizeUVCorrection{X}[index{X}],depthCorrection{X}[index{X}],penumbraDarkness{X});\\n#else\\nshadow=computeShadowWithCSMPCSS64(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w,lightSizeUVCorrection{X}[index{X}],depthCorrection{X}[index{X}],penumbraDarkness{X});\\n#endif\\n#else\\nshadow=computeShadowCSM(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#endif\\n#ifdef SHADOWCSMDEBUG{X}\\nshadowDebug{X}=vec3(shadow)*vCascadeColorsMultiplier{X}[index{X}];\\n#endif\\n#ifndef SHADOWCSMNOBLEND{X}\\nfloat frustumLength=frustumLengths{X}[index{X}];\\nfloat diffRatio=clamp(diff{X}/frustumLength,0.,1.)*cascadeBlendFactor{X};\\nif (index{X}<(SHADOWCSMNUM_CASCADES{X}-1) && diffRatio<1.)\\n{\\nindex{X}+=1;\\nfloat nextShadow=0.;\\n#if defined(SHADOWPCF{X})\\n#if defined(SHADOWLOWQUALITY{X})\\nnextShadow=computeShadowWithCSMPCF1(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#elif defined(SHADOWMEDIUMQUALITY{X})\\nnextShadow=computeShadowWithCSMPCF3(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],shadowSampler{X},light{X}.shadowsInfo.yz,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#else\\nnextShadow=computeShadowWithCSMPCF5(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],shadowSampler{X},light{X}.shadowsInfo.yz,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#endif\\n#elif defined(SHADOWPCSS{X})\\n#if defined(SHADOWLOWQUALITY{X})\\nnextShadow=computeShadowWithCSMPCSS16(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w,lightSizeUVCorrection{X}[index{X}],depthCorrection{X}[index{X}],penumbraDarkness{X});\\n#elif defined(SHADOWMEDIUMQUALITY{X})\\nnextShadow=computeShadowWithCSMPCSS32(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w,lightSizeUVCorrection{X}[index{X}],depthCorrection{X}[index{X}],penumbraDarkness{X});\\n#else\\nnextShadow=computeShadowWithCSMPCSS64(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w,lightSizeUVCorrection{X}[index{X}],depthCorrection{X}[index{X}],penumbraDarkness{X});\\n#endif\\n#else\\nnextShadow=computeShadowCSM(float(index{X}),vPositionFromLight{X}[index{X}],vDepthMetric{X}[index{X}],shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#endif\\nshadow=mix(nextShadow,shadow,diffRatio);\\n#ifdef SHADOWCSMDEBUG{X}\\nshadowDebug{X}=mix(vec3(nextShadow)*vCascadeColorsMultiplier{X}[index{X}],shadowDebug{X},diffRatio);\\n#endif\\n}\\n#endif\\n}\\n#elif defined(SHADOWCLOSEESM{X})\\n#if defined(SHADOWCUBE{X})\\nshadow=computeShadowWithCloseESMCube(light{X}.vLightData.xyz,shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.z,light{X}.depthValues);\\n#else\\nshadow=computeShadowWithCloseESM(vPositionFromLight{X},vDepthMetric{X},shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.z,light{X}.shadowsInfo.w);\\n#endif\\n#elif defined(SHADOWESM{X})\\n#if defined(SHADOWCUBE{X})\\nshadow=computeShadowWithESMCube(light{X}.vLightData.xyz,shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.z,light{X}.depthValues);\\n#else\\nshadow=computeShadowWithESM(vPositionFromLight{X},vDepthMetric{X},shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.z,light{X}.shadowsInfo.w);\\n#endif\\n#elif defined(SHADOWPOISSON{X})\\n#if defined(SHADOWCUBE{X})\\nshadow=computeShadowWithPoissonSamplingCube(light{X}.vLightData.xyz,shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.x,light{X}.depthValues);\\n#else\\nshadow=computeShadowWithPoissonSampling(vPositionFromLight{X},vDepthMetric{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#endif\\n#elif defined(SHADOWPCF{X})\\n#if defined(SHADOWLOWQUALITY{X})\\nshadow=computeShadowWithPCF1(vPositionFromLight{X},vDepthMetric{X},shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#elif defined(SHADOWMEDIUMQUALITY{X})\\nshadow=computeShadowWithPCF3(vPositionFromLight{X},vDepthMetric{X},shadowSampler{X},light{X}.shadowsInfo.yz,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#else\\nshadow=computeShadowWithPCF5(vPositionFromLight{X},vDepthMetric{X},shadowSampler{X},light{X}.shadowsInfo.yz,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#endif\\n#elif defined(SHADOWPCSS{X})\\n#if defined(SHADOWLOWQUALITY{X})\\nshadow=computeShadowWithPCSS16(vPositionFromLight{X},vDepthMetric{X},depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#elif defined(SHADOWMEDIUMQUALITY{X})\\nshadow=computeShadowWithPCSS32(vPositionFromLight{X},vDepthMetric{X},depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#else\\nshadow=computeShadowWithPCSS64(vPositionFromLight{X},vDepthMetric{X},depthSampler{X},shadowSampler{X},light{X}.shadowsInfo.y,light{X}.shadowsInfo.z,light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#endif\\n#else\\n#if defined(SHADOWCUBE{X})\\nshadow=computeShadowCube(light{X}.vLightData.xyz,shadowSampler{X},light{X}.shadowsInfo.x,light{X}.depthValues);\\n#else\\nshadow=computeShadow(vPositionFromLight{X},vDepthMetric{X},shadowSampler{X},light{X}.shadowsInfo.x,light{X}.shadowsInfo.w);\\n#endif\\n#endif\\n#ifdef SHADOWONLY\\n#ifndef SHADOWINUSE\\n#define SHADOWINUSE\\n#endif\\nglobalShadow+=shadow;\\nshadowLightCount+=1.0;\\n#endif\\n#else\\nshadow=1.;\\n#endif\\n#ifndef SHADOWONLY\\n#ifdef CUSTOMUSERLIGHTING\\ndiffuseBase+=computeCustomDiffuseLighting(info,diffuseBase,shadow);\\n#ifdef SPECULARTERM\\nspecularBase+=computeCustomSpecularLighting(info,specularBase,shadow);\\n#endif\\n#elif defined(LIGHTMAP) && defined(LIGHTMAPEXCLUDED{X})\\ndiffuseBase+=lightmapColor.rgb*shadow;\\n#ifdef SPECULARTERM\\n#ifndef LIGHTMAPNOSPECULAR{X}\\nspecularBase+=info.specular*shadow*lightmapColor.rgb;\\n#endif\\n#endif\\n#ifdef CLEARCOAT\\n#ifndef LIGHTMAPNOSPECULAR{X}\\nclearCoatBase+=info.clearCoat.rgb*shadow*lightmapColor.rgb;\\n#endif\\n#endif\\n#ifdef SHEEN\\n#ifndef LIGHTMAPNOSPECULAR{X}\\nsheenBase+=info.sheen.rgb*shadow;\\n#endif\\n#endif\\n#else\\n#ifdef SHADOWCSMDEBUG{X}\\ndiffuseBase+=info.diffuse*shadowDebug{X};\\n#else\\ndiffuseBase+=info.diffuse*shadow;\\n#endif\\n#ifdef SPECULARTERM\\nspecularBase+=info.specular*shadow;\\n#endif\\n#ifdef CLEARCOAT\\nclearCoatBase+=info.clearCoat.rgb*shadow;\\n#endif\\n#ifdef SHEEN\\nsheenBase+=info.sheen.rgb*shadow;\\n#endif\\n#endif\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var lightFragment = { name: name, shader: shader };\r\n//# sourceMappingURL=lightFragment.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'logDepthFragment';\r\nvar shader = \"#ifdef LOGARITHMICDEPTH\\ngl_FragDepthEXT=log2(vFragmentDepth)*logarithmicDepthConstant*0.5;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var logDepthFragment = { name: name, shader: shader };\r\n//# sourceMappingURL=logDepthFragment.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'fogFragment';\r\nvar shader = \"#ifdef FOG\\nfloat fog=CalcFogFactor();\\ncolor.rgb=fog*color.rgb+(1.0-fog)*vFogColor;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var fogFragment = { name: name, shader: shader };\r\n//# sourceMappingURL=fogFragment.js.map","import { Effect } from \"../Materials/effect\";\r\nimport \"./ShadersInclude/defaultFragmentDeclaration\";\r\nimport \"./ShadersInclude/defaultUboDeclaration\";\r\nimport \"./ShadersInclude/prePassDeclaration\";\r\nimport \"./ShadersInclude/helperFunctions\";\r\nimport \"./ShadersInclude/lightFragmentDeclaration\";\r\nimport \"./ShadersInclude/lightUboDeclaration\";\r\nimport \"./ShadersInclude/lightsFragmentFunctions\";\r\nimport \"./ShadersInclude/shadowsFragmentFunctions\";\r\nimport \"./ShadersInclude/fresnelFunction\";\r\nimport \"./ShadersInclude/reflectionFunction\";\r\nimport \"./ShadersInclude/imageProcessingDeclaration\";\r\nimport \"./ShadersInclude/imageProcessingFunctions\";\r\nimport \"./ShadersInclude/bumpFragmentMainFunctions\";\r\nimport \"./ShadersInclude/bumpFragmentFunctions\";\r\nimport \"./ShadersInclude/clipPlaneFragmentDeclaration\";\r\nimport \"./ShadersInclude/logDepthDeclaration\";\r\nimport \"./ShadersInclude/fogFragmentDeclaration\";\r\nimport \"./ShadersInclude/clipPlaneFragment\";\r\nimport \"./ShadersInclude/bumpFragment\";\r\nimport \"./ShadersInclude/depthPrePass\";\r\nimport \"./ShadersInclude/lightFragment\";\r\nimport \"./ShadersInclude/logDepthFragment\";\r\nimport \"./ShadersInclude/fogFragment\";\r\nvar name = 'defaultPixelShader';\r\nvar shader = \"#include<__decl__defaultFragment>\\n#if defined(BUMP) || !defined(NORMAL)\\n#extension GL_OES_standard_derivatives : enable\\n#endif\\n#include[SCENE_MRT_COUNT]\\n#define CUSTOM_FRAGMENT_BEGIN\\n#ifdef LOGARITHMICDEPTH\\n#extension GL_EXT_frag_depth : enable\\n#endif\\n\\n#define RECIPROCAL_PI2 0.15915494\\nuniform vec3 vEyePosition;\\nuniform vec3 vAmbientColor;\\n\\nvarying vec3 vPositionW;\\n#ifdef NORMAL\\nvarying vec3 vNormalW;\\n#endif\\n#ifdef VERTEXCOLOR\\nvarying vec4 vColor;\\n#endif\\n#ifdef MAINUV1\\nvarying vec2 vMainUV1;\\n#endif\\n#ifdef MAINUV2\\nvarying vec2 vMainUV2;\\n#endif\\n\\n#include\\n\\n#include<__decl__lightFragment>[0..maxSimultaneousLights]\\n#include\\n#include\\n\\n#ifdef DIFFUSE\\n#if DIFFUSEDIRECTUV == 1\\n#define vDiffuseUV vMainUV1\\n#elif DIFFUSEDIRECTUV == 2\\n#define vDiffuseUV vMainUV2\\n#else\\nvarying vec2 vDiffuseUV;\\n#endif\\nuniform sampler2D diffuseSampler;\\n#endif\\n#ifdef AMBIENT\\n#if AMBIENTDIRECTUV == 1\\n#define vAmbientUV vMainUV1\\n#elif AMBIENTDIRECTUV == 2\\n#define vAmbientUV vMainUV2\\n#else\\nvarying vec2 vAmbientUV;\\n#endif\\nuniform sampler2D ambientSampler;\\n#endif\\n#ifdef OPACITY\\n#if OPACITYDIRECTUV == 1\\n#define vOpacityUV vMainUV1\\n#elif OPACITYDIRECTUV == 2\\n#define vOpacityUV vMainUV2\\n#else\\nvarying vec2 vOpacityUV;\\n#endif\\nuniform sampler2D opacitySampler;\\n#endif\\n#ifdef EMISSIVE\\n#if EMISSIVEDIRECTUV == 1\\n#define vEmissiveUV vMainUV1\\n#elif EMISSIVEDIRECTUV == 2\\n#define vEmissiveUV vMainUV2\\n#else\\nvarying vec2 vEmissiveUV;\\n#endif\\nuniform sampler2D emissiveSampler;\\n#endif\\n#ifdef LIGHTMAP\\n#if LIGHTMAPDIRECTUV == 1\\n#define vLightmapUV vMainUV1\\n#elif LIGHTMAPDIRECTUV == 2\\n#define vLightmapUV vMainUV2\\n#else\\nvarying vec2 vLightmapUV;\\n#endif\\nuniform sampler2D lightmapSampler;\\n#endif\\n#ifdef REFRACTION\\n#ifdef REFRACTIONMAP_3D\\nuniform samplerCube refractionCubeSampler;\\n#else\\nuniform sampler2D refraction2DSampler;\\n#endif\\n#endif\\n#if defined(SPECULAR) && defined(SPECULARTERM)\\n#if SPECULARDIRECTUV == 1\\n#define vSpecularUV vMainUV1\\n#elif SPECULARDIRECTUV == 2\\n#define vSpecularUV vMainUV2\\n#else\\nvarying vec2 vSpecularUV;\\n#endif\\nuniform sampler2D specularSampler;\\n#endif\\n#ifdef ALPHATEST\\nuniform float alphaCutOff;\\n#endif\\n\\n#include\\n\\n#ifdef REFLECTION\\n#ifdef REFLECTIONMAP_3D\\nuniform samplerCube reflectionCubeSampler;\\n#else\\nuniform sampler2D reflection2DSampler;\\n#endif\\n#ifdef REFLECTIONMAP_SKYBOX\\nvarying vec3 vPositionUVW;\\n#else\\n#if defined(REFLECTIONMAP_EQUIRECTANGULAR_FIXED) || defined(REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED)\\nvarying vec3 vDirectionW;\\n#endif\\n#endif\\n#include\\n#endif\\n#include\\n#include\\n#include\\n#include\\n#include\\n#include\\n#include\\n#define CUSTOM_FRAGMENT_DEFINITIONS\\nvoid main(void) {\\n#define CUSTOM_FRAGMENT_MAIN_BEGIN\\n#include\\nvec3 viewDirectionW=normalize(vEyePosition-vPositionW);\\n\\nvec4 baseColor=vec4(1.,1.,1.,1.);\\nvec3 diffuseColor=vDiffuseColor.rgb;\\n\\nfloat alpha=vDiffuseColor.a;\\n\\n#ifdef NORMAL\\nvec3 normalW=normalize(vNormalW);\\n#else\\nvec3 normalW=normalize(-cross(dFdx(vPositionW),dFdy(vPositionW)));\\n#endif\\n#include\\n#ifdef TWOSIDEDLIGHTING\\nnormalW=gl_FrontFacing ? normalW : -normalW;\\n#endif\\n#ifdef DIFFUSE\\nbaseColor=texture2D(diffuseSampler,vDiffuseUV+uvOffset);\\n#if defined(ALPHATEST) && !defined(ALPHATEST_AFTERALLALPHACOMPUTATIONS)\\nif (baseColor.a\\n#ifdef VERTEXCOLOR\\nbaseColor.rgb*=vColor.rgb;\\n#endif\\n#ifdef DETAIL\\nbaseColor.rgb=baseColor.rgb*2.0*mix(0.5,detailColor.r,vDetailInfos.y);\\n#endif\\n#define CUSTOM_FRAGMENT_UPDATE_DIFFUSE\\n\\nvec3 baseAmbientColor=vec3(1.,1.,1.);\\n#ifdef AMBIENT\\nbaseAmbientColor=texture2D(ambientSampler,vAmbientUV+uvOffset).rgb*vAmbientInfos.y;\\n#endif\\n#define CUSTOM_FRAGMENT_BEFORE_LIGHTS\\n\\n#ifdef SPECULARTERM\\nfloat glossiness=vSpecularColor.a;\\nvec3 specularColor=vSpecularColor.rgb;\\n#ifdef SPECULAR\\nvec4 specularMapColor=texture2D(specularSampler,vSpecularUV+uvOffset);\\nspecularColor=specularMapColor.rgb;\\n#ifdef GLOSSINESS\\nglossiness=glossiness*specularMapColor.a;\\n#endif\\n#endif\\n#else\\nfloat glossiness=0.;\\n#endif\\n\\nvec3 diffuseBase=vec3(0.,0.,0.);\\nlightingInfo info;\\n#ifdef SPECULARTERM\\nvec3 specularBase=vec3(0.,0.,0.);\\n#endif\\nfloat shadow=1.;\\n#ifdef LIGHTMAP\\nvec4 lightmapColor=texture2D(lightmapSampler,vLightmapUV+uvOffset);\\n#ifdef RGBDLIGHTMAP\\nlightmapColor.rgb=fromRGBD(lightmapColor);\\n#endif\\nlightmapColor.rgb*=vLightmapInfos.y;\\n#endif\\n#include[0..maxSimultaneousLights]\\n\\nvec4 refractionColor=vec4(0.,0.,0.,1.);\\n#ifdef REFRACTION\\nvec3 refractionVector=normalize(refract(-viewDirectionW,normalW,vRefractionInfos.y));\\n#ifdef REFRACTIONMAP_3D\\nrefractionVector.y=refractionVector.y*vRefractionInfos.w;\\nif (dot(refractionVector,viewDirectionW)<1.0) {\\nrefractionColor=textureCube(refractionCubeSampler,refractionVector);\\n}\\n#else\\nvec3 vRefractionUVW=vec3(refractionMatrix*(view*vec4(vPositionW+refractionVector*vRefractionInfos.z,1.0)));\\nvec2 refractionCoords=vRefractionUVW.xy/vRefractionUVW.z;\\nrefractionCoords.y=1.0-refractionCoords.y;\\nrefractionColor=texture2D(refraction2DSampler,refractionCoords);\\n#endif\\n#ifdef RGBDREFRACTION\\nrefractionColor.rgb=fromRGBD(refractionColor);\\n#endif\\n#ifdef IS_REFRACTION_LINEAR\\nrefractionColor.rgb=toGammaSpace(refractionColor.rgb);\\n#endif\\nrefractionColor.rgb*=vRefractionInfos.x;\\n#endif\\n\\nvec4 reflectionColor=vec4(0.,0.,0.,1.);\\n#ifdef REFLECTION\\nvec3 vReflectionUVW=computeReflectionCoords(vec4(vPositionW,1.0),normalW);\\n#ifdef REFLECTIONMAP_3D\\n#ifdef ROUGHNESS\\nfloat bias=vReflectionInfos.y;\\n#ifdef SPECULARTERM\\n#ifdef SPECULAR\\n#ifdef GLOSSINESS\\nbias*=(1.0-specularMapColor.a);\\n#endif\\n#endif\\n#endif\\nreflectionColor=textureCube(reflectionCubeSampler,vReflectionUVW,bias);\\n#else\\nreflectionColor=textureCube(reflectionCubeSampler,vReflectionUVW);\\n#endif\\n#else\\nvec2 coords=vReflectionUVW.xy;\\n#ifdef REFLECTIONMAP_PROJECTION\\ncoords/=vReflectionUVW.z;\\n#endif\\ncoords.y=1.0-coords.y;\\nreflectionColor=texture2D(reflection2DSampler,coords);\\n#endif\\n#ifdef RGBDREFLECTION\\nreflectionColor.rgb=fromRGBD(reflectionColor);\\n#endif\\n#ifdef IS_REFLECTION_LINEAR\\nreflectionColor.rgb=toGammaSpace(reflectionColor.rgb);\\n#endif\\nreflectionColor.rgb*=vReflectionInfos.x;\\n#ifdef REFLECTIONFRESNEL\\nfloat reflectionFresnelTerm=computeFresnelTerm(viewDirectionW,normalW,reflectionRightColor.a,reflectionLeftColor.a);\\n#ifdef REFLECTIONFRESNELFROMSPECULAR\\n#ifdef SPECULARTERM\\nreflectionColor.rgb*=specularColor.rgb*(1.0-reflectionFresnelTerm)+reflectionFresnelTerm*reflectionRightColor.rgb;\\n#else\\nreflectionColor.rgb*=reflectionLeftColor.rgb*(1.0-reflectionFresnelTerm)+reflectionFresnelTerm*reflectionRightColor.rgb;\\n#endif\\n#else\\nreflectionColor.rgb*=reflectionLeftColor.rgb*(1.0-reflectionFresnelTerm)+reflectionFresnelTerm*reflectionRightColor.rgb;\\n#endif\\n#endif\\n#endif\\n#ifdef REFRACTIONFRESNEL\\nfloat refractionFresnelTerm=computeFresnelTerm(viewDirectionW,normalW,refractionRightColor.a,refractionLeftColor.a);\\nrefractionColor.rgb*=refractionLeftColor.rgb*(1.0-refractionFresnelTerm)+refractionFresnelTerm*refractionRightColor.rgb;\\n#endif\\n#ifdef OPACITY\\nvec4 opacityMap=texture2D(opacitySampler,vOpacityUV+uvOffset);\\n#ifdef OPACITYRGB\\nopacityMap.rgb=opacityMap.rgb*vec3(0.3,0.59,0.11);\\nalpha*=(opacityMap.x+opacityMap.y+opacityMap.z)* vOpacityInfos.y;\\n#else\\nalpha*=opacityMap.a*vOpacityInfos.y;\\n#endif\\n#endif\\n#ifdef VERTEXALPHA\\nalpha*=vColor.a;\\n#endif\\n#ifdef OPACITYFRESNEL\\nfloat opacityFresnelTerm=computeFresnelTerm(viewDirectionW,normalW,opacityParts.z,opacityParts.w);\\nalpha+=opacityParts.x*(1.0-opacityFresnelTerm)+opacityFresnelTerm*opacityParts.y;\\n#endif\\n#ifdef ALPHATEST\\n#ifdef ALPHATEST_AFTERALLALPHACOMPUTATIONS\\nif (alpha\\n#include\\n\\n\\n#ifdef IMAGEPROCESSINGPOSTPROCESS\\ncolor.rgb=toLinearSpace(color.rgb);\\n#else\\n#ifdef IMAGEPROCESSING\\ncolor.rgb=toLinearSpace(color.rgb);\\ncolor=applyImageProcessing(color);\\n#endif\\n#endif\\ncolor.a*=visibility;\\n#ifdef PREMULTIPLYALPHA\\n\\ncolor.rgb*=color.a;\\n#endif\\n#define CUSTOM_FRAGMENT_BEFORE_FRAGCOLOR\\n#ifdef PREPASS\\ngl_FragData[0]=color;\\n#ifdef PREPASS_POSITION\\ngl_FragData[PREPASS_POSITION_INDEX]=vec4(vPositionW,1.0);\\n#endif\\n#ifdef PREPASS_VELOCITY\\nvec2 a=(vCurrentPosition.xy/vCurrentPosition.w)*0.5+0.5;\\nvec2 b=(vPreviousPosition.xy/vPreviousPosition.w)*0.5+0.5;\\nvec2 velocity=abs(a-b);\\nvelocity=vec2(pow(velocity.x,1.0/3.0),pow(velocity.y,1.0/3.0))*sign(a-b)*0.5+0.5;\\ngl_FragData[PREPASS_VELOCITY_INDEX]=vec4(velocity,0.0,1.0);\\n#endif\\n#ifdef PREPASS_IRRADIANCE\\ngl_FragData[PREPASS_IRRADIANCE_INDEX]=vec4(0.0,0.0,0.0,1.0);\\n#endif\\n#ifdef PREPASS_DEPTHNORMAL\\ngl_FragData[PREPASS_DEPTHNORMAL_INDEX]=vec4(vViewPos.z,(view*vec4(normalW,0.0)).rgb);\\n#endif\\n#ifdef PREPASS_ALBEDO\\ngl_FragData[PREPASS_ALBEDO_INDEX]=vec4(0.0,0.0,0.0,1.0);\\n#endif\\n#ifdef PREPASS_REFLECTIVITY\\n#if defined(SPECULAR)\\ngl_FragData[PREPASS_REFLECTIVITY_INDEX]=specularMapColor;\\n#else\\ngl_FragData[PREPASS_REFLECTIVITY_INDEX]=vec4(0.0,0.0,0.0,1.0);\\n#endif\\n#endif\\n#endif\\n#if !defined(PREPASS) || defined(WEBGL2)\\ngl_FragColor=color;\\n#endif\\n}\\n\";\r\nEffect.ShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var defaultPixelShader = { name: name, shader: shader };\r\n//# sourceMappingURL=default.fragment.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'defaultVertexDeclaration';\r\nvar shader = \"\\nuniform mat4 viewProjection;\\nuniform mat4 view;\\n#ifdef DIFFUSE\\nuniform mat4 diffuseMatrix;\\nuniform vec2 vDiffuseInfos;\\n#endif\\n#ifdef AMBIENT\\nuniform mat4 ambientMatrix;\\nuniform vec2 vAmbientInfos;\\n#endif\\n#ifdef OPACITY\\nuniform mat4 opacityMatrix;\\nuniform vec2 vOpacityInfos;\\n#endif\\n#ifdef EMISSIVE\\nuniform vec2 vEmissiveInfos;\\nuniform mat4 emissiveMatrix;\\n#endif\\n#ifdef LIGHTMAP\\nuniform vec2 vLightmapInfos;\\nuniform mat4 lightmapMatrix;\\n#endif\\n#if defined(SPECULAR) && defined(SPECULARTERM)\\nuniform vec2 vSpecularInfos;\\nuniform mat4 specularMatrix;\\n#endif\\n#ifdef BUMP\\nuniform vec3 vBumpInfos;\\nuniform mat4 bumpMatrix;\\n#endif\\n#ifdef REFLECTION\\nuniform mat4 reflectionMatrix;\\n#endif\\n#ifdef POINTSIZE\\nuniform float pointSize;\\n#endif\\n\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var defaultVertexDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=defaultVertexDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'prePassVertexDeclaration';\r\nvar shader = \"#ifdef PREPASS\\n#ifdef PREPASS_DEPTHNORMAL\\nvarying vec3 vViewPos;\\n#endif\\n#ifdef PREPASS_VELOCITY\\nuniform mat4 previousWorld;\\nuniform mat4 previousViewProjection;\\nvarying vec4 vCurrentPosition;\\nvarying vec4 vPreviousPosition;\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var prePassVertexDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=prePassVertexDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'bumpVertexDeclaration';\r\nvar shader = \"#if defined(BUMP) || defined(PARALLAX) || defined(CLEARCOAT_BUMP) || defined(ANISOTROPIC)\\n#if defined(TANGENT) && defined(NORMAL)\\nvarying mat3 vTBN;\\n#endif\\n#endif\\n\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var bumpVertexDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=bumpVertexDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'fogVertexDeclaration';\r\nvar shader = \"#ifdef FOG\\nvarying vec3 vFogDistance;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var fogVertexDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=fogVertexDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'morphTargetsVertexGlobalDeclaration';\r\nvar shader = \"#ifdef MORPHTARGETS\\nuniform float morphTargetInfluences[NUM_MORPH_INFLUENCERS];\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var morphTargetsVertexGlobalDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=morphTargetsVertexGlobalDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'morphTargetsVertexDeclaration';\r\nvar shader = \"#ifdef MORPHTARGETS\\nattribute vec3 position{X};\\n#ifdef MORPHTARGETS_NORMAL\\nattribute vec3 normal{X};\\n#endif\\n#ifdef MORPHTARGETS_TANGENT\\nattribute vec3 tangent{X};\\n#endif\\n#ifdef MORPHTARGETS_UV\\nattribute vec2 uv_{X};\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var morphTargetsVertexDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=morphTargetsVertexDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'morphTargetsVertex';\r\nvar shader = \"#ifdef MORPHTARGETS\\npositionUpdated+=(position{X}-position)*morphTargetInfluences[{X}];\\n#ifdef MORPHTARGETS_NORMAL\\nnormalUpdated+=(normal{X}-normal)*morphTargetInfluences[{X}];\\n#endif\\n#ifdef MORPHTARGETS_TANGENT\\ntangentUpdated.xyz+=(tangent{X}-tangent.xyz)*morphTargetInfluences[{X}];\\n#endif\\n#ifdef MORPHTARGETS_UV\\nuvUpdated+=(uv_{X}-uv)*morphTargetInfluences[{X}];\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var morphTargetsVertex = { name: name, shader: shader };\r\n//# sourceMappingURL=morphTargetsVertex.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'prePassVertex';\r\nvar shader = \"#ifdef PREPASS_DEPTHNORMAL\\nvViewPos=(view*worldPos).rgb;\\n#endif\\n#if defined(PREPASS_VELOCITY) && defined(BONES_VELOCITY_ENABLED)\\nvCurrentPosition=viewProjection*worldPos;\\n#if NUM_BONE_INFLUENCERS>0\\nmat4 previousInfluence;\\npreviousInfluence=mPreviousBones[int(matricesIndices[0])]*matricesWeights[0];\\n#if NUM_BONE_INFLUENCERS>1\\npreviousInfluence+=mPreviousBones[int(matricesIndices[1])]*matricesWeights[1];\\n#endif\\n#if NUM_BONE_INFLUENCERS>2\\npreviousInfluence+=mPreviousBones[int(matricesIndices[2])]*matricesWeights[2];\\n#endif\\n#if NUM_BONE_INFLUENCERS>3\\npreviousInfluence+=mPreviousBones[int(matricesIndices[3])]*matricesWeights[3];\\n#endif\\n#if NUM_BONE_INFLUENCERS>4\\npreviousInfluence+=mPreviousBones[int(matricesIndicesExtra[0])]*matricesWeightsExtra[0];\\n#endif\\n#if NUM_BONE_INFLUENCERS>5\\npreviousInfluence+=mPreviousBones[int(matricesIndicesExtra[1])]*matricesWeightsExtra[1];\\n#endif\\n#if NUM_BONE_INFLUENCERS>6\\npreviousInfluence+=mPreviousBones[int(matricesIndicesExtra[2])]*matricesWeightsExtra[2];\\n#endif\\n#if NUM_BONE_INFLUENCERS>7\\npreviousInfluence+=mPreviousBones[int(matricesIndicesExtra[3])]*matricesWeightsExtra[3];\\n#endif\\nvPreviousPosition=previousViewProjection*previousWorld*previousInfluence*vec4(positionUpdated,1.0);\\n#else\\nvPreviousPosition=previousViewProjection*previousWorld*vec4(positionUpdated,1.0);\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var prePassVertex = { name: name, shader: shader };\r\n//# sourceMappingURL=prePassVertex.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'bumpVertex';\r\nvar shader = \"#if defined(BUMP) || defined(PARALLAX) || defined(CLEARCOAT_BUMP) || defined(ANISOTROPIC)\\n#if defined(TANGENT) && defined(NORMAL)\\nvec3 tbnNormal=normalize(normalUpdated);\\nvec3 tbnTangent=normalize(tangentUpdated.xyz);\\nvec3 tbnBitangent=cross(tbnNormal,tbnTangent)*tangentUpdated.w;\\nvTBN=mat3(finalWorld)*mat3(tbnTangent,tbnBitangent,tbnNormal);\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var bumpVertex = { name: name, shader: shader };\r\n//# sourceMappingURL=bumpVertex.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'fogVertex';\r\nvar shader = \"#ifdef FOG\\nvFogDistance=(view*worldPos).xyz;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var fogVertex = { name: name, shader: shader };\r\n//# sourceMappingURL=fogVertex.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'shadowsVertex';\r\nvar shader = \"#ifdef SHADOWS\\n#if defined(SHADOWCSM{X})\\nvPositionFromCamera{X}=view*worldPos;\\nfor (int i=0; i\\n\\n#define CUSTOM_VERTEX_BEGIN\\nattribute vec3 position;\\n#ifdef NORMAL\\nattribute vec3 normal;\\n#endif\\n#ifdef TANGENT\\nattribute vec4 tangent;\\n#endif\\n#ifdef UV1\\nattribute vec2 uv;\\n#endif\\n#ifdef UV2\\nattribute vec2 uv2;\\n#endif\\n#ifdef VERTEXCOLOR\\nattribute vec4 color;\\n#endif\\n#include\\n#include\\n\\n#include\\n#include\\n#ifdef MAINUV1\\nvarying vec2 vMainUV1;\\n#endif\\n#ifdef MAINUV2\\nvarying vec2 vMainUV2;\\n#endif\\n#if defined(DIFFUSE) && DIFFUSEDIRECTUV == 0\\nvarying vec2 vDiffuseUV;\\n#endif\\n#if defined(DETAIL) && DETAILDIRECTUV == 0\\nvarying vec2 vDetailUV;\\n#endif\\n#if defined(AMBIENT) && AMBIENTDIRECTUV == 0\\nvarying vec2 vAmbientUV;\\n#endif\\n#if defined(OPACITY) && OPACITYDIRECTUV == 0\\nvarying vec2 vOpacityUV;\\n#endif\\n#if defined(EMISSIVE) && EMISSIVEDIRECTUV == 0\\nvarying vec2 vEmissiveUV;\\n#endif\\n#if defined(LIGHTMAP) && LIGHTMAPDIRECTUV == 0\\nvarying vec2 vLightmapUV;\\n#endif\\n#if defined(SPECULAR) && defined(SPECULARTERM) && SPECULARDIRECTUV == 0\\nvarying vec2 vSpecularUV;\\n#endif\\n#if defined(BUMP) && BUMPDIRECTUV == 0\\nvarying vec2 vBumpUV;\\n#endif\\n\\nvarying vec3 vPositionW;\\n#ifdef NORMAL\\nvarying vec3 vNormalW;\\n#endif\\n#ifdef VERTEXCOLOR\\nvarying vec4 vColor;\\n#endif\\n#include\\n#include\\n#include\\n#include<__decl__lightFragment>[0..maxSimultaneousLights]\\n#include\\n#include[0..maxSimultaneousMorphTargets]\\n#ifdef REFLECTIONMAP_SKYBOX\\nvarying vec3 vPositionUVW;\\n#endif\\n#if defined(REFLECTIONMAP_EQUIRECTANGULAR_FIXED) || defined(REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED)\\nvarying vec3 vDirectionW;\\n#endif\\n#include\\n#define CUSTOM_VERTEX_DEFINITIONS\\nvoid main(void) {\\n#define CUSTOM_VERTEX_MAIN_BEGIN\\nvec3 positionUpdated=position;\\n#ifdef NORMAL\\nvec3 normalUpdated=normal;\\n#endif\\n#ifdef TANGENT\\nvec4 tangentUpdated=tangent;\\n#endif\\n#ifdef UV1\\nvec2 uvUpdated=uv;\\n#endif\\n#include[0..maxSimultaneousMorphTargets]\\n#ifdef REFLECTIONMAP_SKYBOX\\nvPositionUVW=positionUpdated;\\n#endif\\n#define CUSTOM_VERTEX_UPDATE_POSITION\\n#define CUSTOM_VERTEX_UPDATE_NORMAL\\n#include\\n#if defined(PREPASS) && defined(PREPASS_VELOCITY) && !defined(BONES_VELOCITY_ENABLED)\\n\\nvCurrentPosition=viewProjection*finalWorld*vec4(positionUpdated,1.0);\\nvPreviousPosition=previousViewProjection*previousWorld*vec4(positionUpdated,1.0);\\n#endif\\n#include\\nvec4 worldPos=finalWorld*vec4(positionUpdated,1.0);\\n#ifdef NORMAL\\nmat3 normalWorld=mat3(finalWorld);\\n#if defined(INSTANCES) && defined(THIN_INSTANCES)\\nvNormalW=normalUpdated/vec3(dot(normalWorld[0],normalWorld[0]),dot(normalWorld[1],normalWorld[1]),dot(normalWorld[2],normalWorld[2]));\\nvNormalW=normalize(normalWorld*vNormalW);\\n#else\\n#ifdef NONUNIFORMSCALING\\nnormalWorld=transposeMat3(inverseMat3(normalWorld));\\n#endif\\nvNormalW=normalize(normalWorld*normalUpdated);\\n#endif\\n#endif\\n#define CUSTOM_VERTEX_UPDATE_WORLDPOS\\n#ifdef MULTIVIEW\\nif (gl_ViewID_OVR == 0u) {\\ngl_Position=viewProjection*worldPos;\\n} else {\\ngl_Position=viewProjectionR*worldPos;\\n}\\n#else\\ngl_Position=viewProjection*worldPos;\\n#endif\\nvPositionW=vec3(worldPos);\\n#include\\n#if defined(REFLECTIONMAP_EQUIRECTANGULAR_FIXED) || defined(REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED)\\nvDirectionW=normalize(vec3(finalWorld*vec4(positionUpdated,0.0)));\\n#endif\\n\\n#ifndef UV1\\nvec2 uvUpdated=vec2(0.,0.);\\n#endif\\n#ifndef UV2\\nvec2 uv2=vec2(0.,0.);\\n#endif\\n#ifdef MAINUV1\\nvMainUV1=uvUpdated;\\n#endif\\n#ifdef MAINUV2\\nvMainUV2=uv2;\\n#endif\\n#if defined(DIFFUSE) && DIFFUSEDIRECTUV == 0\\nif (vDiffuseInfos.x == 0.)\\n{\\nvDiffuseUV=vec2(diffuseMatrix*vec4(uvUpdated,1.0,0.0));\\n}\\nelse\\n{\\nvDiffuseUV=vec2(diffuseMatrix*vec4(uv2,1.0,0.0));\\n}\\n#endif\\n#if defined(DETAIL) && DETAILDIRECTUV == 0\\nif (vDetailInfos.x == 0.)\\n{\\nvDetailUV=vec2(detailMatrix*vec4(uvUpdated,1.0,0.0));\\n}\\nelse\\n{\\nvDetailUV=vec2(detailMatrix*vec4(uv2,1.0,0.0));\\n}\\n#endif\\n#if defined(AMBIENT) && AMBIENTDIRECTUV == 0\\nif (vAmbientInfos.x == 0.)\\n{\\nvAmbientUV=vec2(ambientMatrix*vec4(uvUpdated,1.0,0.0));\\n}\\nelse\\n{\\nvAmbientUV=vec2(ambientMatrix*vec4(uv2,1.0,0.0));\\n}\\n#endif\\n#if defined(OPACITY) && OPACITYDIRECTUV == 0\\nif (vOpacityInfos.x == 0.)\\n{\\nvOpacityUV=vec2(opacityMatrix*vec4(uvUpdated,1.0,0.0));\\n}\\nelse\\n{\\nvOpacityUV=vec2(opacityMatrix*vec4(uv2,1.0,0.0));\\n}\\n#endif\\n#if defined(EMISSIVE) && EMISSIVEDIRECTUV == 0\\nif (vEmissiveInfos.x == 0.)\\n{\\nvEmissiveUV=vec2(emissiveMatrix*vec4(uvUpdated,1.0,0.0));\\n}\\nelse\\n{\\nvEmissiveUV=vec2(emissiveMatrix*vec4(uv2,1.0,0.0));\\n}\\n#endif\\n#if defined(LIGHTMAP) && LIGHTMAPDIRECTUV == 0\\nif (vLightmapInfos.x == 0.)\\n{\\nvLightmapUV=vec2(lightmapMatrix*vec4(uvUpdated,1.0,0.0));\\n}\\nelse\\n{\\nvLightmapUV=vec2(lightmapMatrix*vec4(uv2,1.0,0.0));\\n}\\n#endif\\n#if defined(SPECULAR) && defined(SPECULARTERM) && SPECULARDIRECTUV == 0\\nif (vSpecularInfos.x == 0.)\\n{\\nvSpecularUV=vec2(specularMatrix*vec4(uvUpdated,1.0,0.0));\\n}\\nelse\\n{\\nvSpecularUV=vec2(specularMatrix*vec4(uv2,1.0,0.0));\\n}\\n#endif\\n#if defined(BUMP) && BUMPDIRECTUV == 0\\nif (vBumpInfos.x == 0.)\\n{\\nvBumpUV=vec2(bumpMatrix*vec4(uvUpdated,1.0,0.0));\\n}\\nelse\\n{\\nvBumpUV=vec2(bumpMatrix*vec4(uv2,1.0,0.0));\\n}\\n#endif\\n#include\\n#include\\n#include\\n#include[0..maxSimultaneousLights]\\n#ifdef VERTEXCOLOR\\n\\nvColor=color;\\n#endif\\n#include\\n#include\\n#define CUSTOM_VERTEX_MAIN_END\\n}\\n\";\r\nEffect.ShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var defaultVertexShader = { name: name, shader: shader };\r\n//# sourceMappingURL=default.vertex.js.map","import { __decorate } from \"tslib\";\r\nimport { Material } from \"./material\";\r\nimport { serialize, expandToProperty, serializeAsTexture, SerializationHelper } from '../Misc/decorators';\r\nimport { MaterialFlags } from './materialFlags';\r\nimport { MaterialHelper } from './materialHelper';\r\n/**\r\n * Define the code related to the detail map parameters of a material\r\n *\r\n * Inspired from:\r\n * Unity: https://docs.unity3d.com/Packages/com.unity.render-pipelines.high-definition@9.0/manual/Mask-Map-and-Detail-Map.html and https://docs.unity3d.com/Manual/StandardShaderMaterialParameterDetail.html\r\n * Unreal: https://docs.unrealengine.com/en-US/Engine/Rendering/Materials/HowTo/DetailTexturing/index.html\r\n * Cryengine: https://docs.cryengine.com/display/SDKDOC2/Detail+Maps\r\n */\r\nvar DetailMapConfiguration = /** @class */ (function () {\r\n /**\r\n * Instantiate a new detail map\r\n * @param markAllSubMeshesAsTexturesDirty Callback to flag the material to dirty\r\n */\r\n function DetailMapConfiguration(markAllSubMeshesAsTexturesDirty) {\r\n this._texture = null;\r\n /**\r\n * Defines how strongly the detail diffuse/albedo channel is blended with the regular diffuse/albedo texture\r\n * Bigger values mean stronger blending\r\n */\r\n this.diffuseBlendLevel = 1;\r\n /**\r\n * Defines how strongly the detail roughness channel is blended with the regular roughness value\r\n * Bigger values mean stronger blending. Only used with PBR materials\r\n */\r\n this.roughnessBlendLevel = 1;\r\n /**\r\n * Defines how strong the bump effect from the detail map is\r\n * Bigger values mean stronger effect\r\n */\r\n this.bumpLevel = 1;\r\n this._normalBlendMethod = Material.MATERIAL_NORMALBLENDMETHOD_WHITEOUT;\r\n this._isEnabled = false;\r\n /**\r\n * Enable or disable the detail map on this material\r\n */\r\n this.isEnabled = false;\r\n this._internalMarkAllSubMeshesAsTexturesDirty = markAllSubMeshesAsTexturesDirty;\r\n }\r\n /** @hidden */\r\n DetailMapConfiguration.prototype._markAllSubMeshesAsTexturesDirty = function () {\r\n this._internalMarkAllSubMeshesAsTexturesDirty();\r\n };\r\n /**\r\n * Gets whether the submesh is ready to be used or not.\r\n * @param defines the list of \"defines\" to update.\r\n * @param scene defines the scene the material belongs to.\r\n * @returns - boolean indicating that the submesh is ready or not.\r\n */\r\n DetailMapConfiguration.prototype.isReadyForSubMesh = function (defines, scene) {\r\n var engine = scene.getEngine();\r\n if (defines._areTexturesDirty && scene.texturesEnabled) {\r\n if (engine.getCaps().standardDerivatives && this._texture && MaterialFlags.DetailTextureEnabled) {\r\n // Detail texture cannot be not blocking.\r\n if (!this._texture.isReady()) {\r\n return false;\r\n }\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Update the defines for detail map usage\r\n * @param defines the list of \"defines\" to update.\r\n * @param scene defines the scene the material belongs to.\r\n */\r\n DetailMapConfiguration.prototype.prepareDefines = function (defines, scene) {\r\n if (this._isEnabled) {\r\n defines.DETAIL_NORMALBLENDMETHOD = this._normalBlendMethod;\r\n var engine = scene.getEngine();\r\n if (defines._areTexturesDirty) {\r\n if (engine.getCaps().standardDerivatives && this._texture && MaterialFlags.DetailTextureEnabled && this._isEnabled) {\r\n MaterialHelper.PrepareDefinesForMergedUV(this._texture, defines, \"DETAIL\");\r\n defines.DETAIL_NORMALBLENDMETHOD = this._normalBlendMethod;\r\n }\r\n else {\r\n defines.DETAIL = false;\r\n }\r\n }\r\n }\r\n else {\r\n defines.DETAIL = false;\r\n }\r\n };\r\n /**\r\n * Binds the material data.\r\n * @param uniformBuffer defines the Uniform buffer to fill in.\r\n * @param scene defines the scene the material belongs to.\r\n * @param isFrozen defines whether the material is frozen or not.\r\n */\r\n DetailMapConfiguration.prototype.bindForSubMesh = function (uniformBuffer, scene, isFrozen) {\r\n if (!this._isEnabled) {\r\n return;\r\n }\r\n if (!uniformBuffer.useUbo || !isFrozen || !uniformBuffer.isSync) {\r\n if (this._texture && MaterialFlags.DetailTextureEnabled) {\r\n uniformBuffer.updateFloat4(\"vDetailInfos\", this._texture.coordinatesIndex, this.diffuseBlendLevel, this.bumpLevel, this.roughnessBlendLevel);\r\n MaterialHelper.BindTextureMatrix(this._texture, uniformBuffer, \"detail\");\r\n }\r\n }\r\n // Textures\r\n if (scene.texturesEnabled) {\r\n if (this._texture && MaterialFlags.DetailTextureEnabled) {\r\n uniformBuffer.setTexture(\"detailSampler\", this._texture);\r\n }\r\n }\r\n };\r\n /**\r\n * Checks to see if a texture is used in the material.\r\n * @param texture - Base texture to use.\r\n * @returns - Boolean specifying if a texture is used in the material.\r\n */\r\n DetailMapConfiguration.prototype.hasTexture = function (texture) {\r\n if (this._texture === texture) {\r\n return true;\r\n }\r\n return false;\r\n };\r\n /**\r\n * Returns an array of the actively used textures.\r\n * @param activeTextures Array of BaseTextures\r\n */\r\n DetailMapConfiguration.prototype.getActiveTextures = function (activeTextures) {\r\n if (this._texture) {\r\n activeTextures.push(this._texture);\r\n }\r\n };\r\n /**\r\n * Returns the animatable textures.\r\n * @param animatables Array of animatable textures.\r\n */\r\n DetailMapConfiguration.prototype.getAnimatables = function (animatables) {\r\n if (this._texture && this._texture.animations && this._texture.animations.length > 0) {\r\n animatables.push(this._texture);\r\n }\r\n };\r\n /**\r\n * Disposes the resources of the material.\r\n * @param forceDisposeTextures - Forces the disposal of all textures.\r\n */\r\n DetailMapConfiguration.prototype.dispose = function (forceDisposeTextures) {\r\n var _a;\r\n if (forceDisposeTextures) {\r\n (_a = this._texture) === null || _a === void 0 ? void 0 : _a.dispose();\r\n }\r\n };\r\n /**\r\n * Get the current class name useful for serialization or dynamic coding.\r\n * @returns \"DetailMap\"\r\n */\r\n DetailMapConfiguration.prototype.getClassName = function () {\r\n return \"DetailMap\";\r\n };\r\n /**\r\n * Add the required uniforms to the current list.\r\n * @param uniforms defines the current uniform list.\r\n */\r\n DetailMapConfiguration.AddUniforms = function (uniforms) {\r\n uniforms.push(\"vDetailInfos\");\r\n };\r\n /**\r\n * Add the required samplers to the current list.\r\n * @param samplers defines the current sampler list.\r\n */\r\n DetailMapConfiguration.AddSamplers = function (samplers) {\r\n samplers.push(\"detailSampler\");\r\n };\r\n /**\r\n * Add the required uniforms to the current buffer.\r\n * @param uniformBuffer defines the current uniform buffer.\r\n */\r\n DetailMapConfiguration.PrepareUniformBuffer = function (uniformBuffer) {\r\n uniformBuffer.addUniform(\"vDetailInfos\", 4);\r\n uniformBuffer.addUniform(\"detailMatrix\", 16);\r\n };\r\n /**\r\n * Makes a duplicate of the current instance into another one.\r\n * @param detailMap define the instance where to copy the info\r\n */\r\n DetailMapConfiguration.prototype.copyTo = function (detailMap) {\r\n SerializationHelper.Clone(function () { return detailMap; }, this);\r\n };\r\n /**\r\n * Serializes this detail map instance\r\n * @returns - An object with the serialized instance.\r\n */\r\n DetailMapConfiguration.prototype.serialize = function () {\r\n return SerializationHelper.Serialize(this);\r\n };\r\n /**\r\n * Parses a detail map setting from a serialized object.\r\n * @param source - Serialized object.\r\n * @param scene Defines the scene we are parsing for\r\n * @param rootUrl Defines the rootUrl to load from\r\n */\r\n DetailMapConfiguration.prototype.parse = function (source, scene, rootUrl) {\r\n var _this = this;\r\n SerializationHelper.Parse(function () { return _this; }, source, scene, rootUrl);\r\n };\r\n __decorate([\r\n serializeAsTexture(\"detailTexture\"),\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], DetailMapConfiguration.prototype, \"texture\", void 0);\r\n __decorate([\r\n serialize()\r\n ], DetailMapConfiguration.prototype, \"diffuseBlendLevel\", void 0);\r\n __decorate([\r\n serialize()\r\n ], DetailMapConfiguration.prototype, \"roughnessBlendLevel\", void 0);\r\n __decorate([\r\n serialize()\r\n ], DetailMapConfiguration.prototype, \"bumpLevel\", void 0);\r\n __decorate([\r\n serialize(),\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], DetailMapConfiguration.prototype, \"normalBlendMethod\", void 0);\r\n __decorate([\r\n serialize(),\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], DetailMapConfiguration.prototype, \"isEnabled\", void 0);\r\n return DetailMapConfiguration;\r\n}());\r\nexport { DetailMapConfiguration };\r\n//# sourceMappingURL=material.detailMapConfiguration.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, SerializationHelper, serializeAsColor3, expandToProperty, serializeAsFresnelParameters, serializeAsTexture } from \"../Misc/decorators\";\r\nimport { SmartArray } from \"../Misc/smartArray\";\r\nimport { Scene } from \"../scene\";\r\nimport { Matrix } from \"../Maths/math.vector\";\r\nimport { Color3 } from '../Maths/math.color';\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { PrePassConfiguration } from \"./prePassConfiguration\";\r\nimport { ImageProcessingConfiguration } from \"./imageProcessingConfiguration\";\r\nimport { Material } from \"../Materials/material\";\r\nimport { MaterialDefines } from \"../Materials/materialDefines\";\r\nimport { PushMaterial } from \"./pushMaterial\";\r\nimport { MaterialHelper } from \"./materialHelper\";\r\nimport { Texture } from \"../Materials/Textures/texture\";\r\nimport { _TypeStore } from \"../Misc/typeStore\";\r\nimport { MaterialFlags } from \"./materialFlags\";\r\nimport \"../Shaders/default.fragment\";\r\nimport \"../Shaders/default.vertex\";\r\nimport { EffectFallbacks } from './effectFallbacks';\r\nimport { DetailMapConfiguration } from './material.detailMapConfiguration';\r\nvar onCreatedEffectParameters = { effect: null, subMesh: null };\r\n/** @hidden */\r\nvar StandardMaterialDefines = /** @class */ (function (_super) {\r\n __extends(StandardMaterialDefines, _super);\r\n function StandardMaterialDefines() {\r\n var _this = _super.call(this) || this;\r\n _this.MAINUV1 = false;\r\n _this.MAINUV2 = false;\r\n _this.DIFFUSE = false;\r\n _this.DIFFUSEDIRECTUV = 0;\r\n _this.DETAIL = false;\r\n _this.DETAILDIRECTUV = 0;\r\n _this.DETAIL_NORMALBLENDMETHOD = 0;\r\n _this.AMBIENT = false;\r\n _this.AMBIENTDIRECTUV = 0;\r\n _this.OPACITY = false;\r\n _this.OPACITYDIRECTUV = 0;\r\n _this.OPACITYRGB = false;\r\n _this.REFLECTION = false;\r\n _this.EMISSIVE = false;\r\n _this.EMISSIVEDIRECTUV = 0;\r\n _this.SPECULAR = false;\r\n _this.SPECULARDIRECTUV = 0;\r\n _this.BUMP = false;\r\n _this.BUMPDIRECTUV = 0;\r\n _this.PARALLAX = false;\r\n _this.PARALLAXOCCLUSION = false;\r\n _this.SPECULAROVERALPHA = false;\r\n _this.CLIPPLANE = false;\r\n _this.CLIPPLANE2 = false;\r\n _this.CLIPPLANE3 = false;\r\n _this.CLIPPLANE4 = false;\r\n _this.CLIPPLANE5 = false;\r\n _this.CLIPPLANE6 = false;\r\n _this.ALPHATEST = false;\r\n _this.DEPTHPREPASS = false;\r\n _this.ALPHAFROMDIFFUSE = false;\r\n _this.POINTSIZE = false;\r\n _this.FOG = false;\r\n _this.SPECULARTERM = false;\r\n _this.DIFFUSEFRESNEL = false;\r\n _this.OPACITYFRESNEL = false;\r\n _this.REFLECTIONFRESNEL = false;\r\n _this.REFRACTIONFRESNEL = false;\r\n _this.EMISSIVEFRESNEL = false;\r\n _this.FRESNEL = false;\r\n _this.NORMAL = false;\r\n _this.UV1 = false;\r\n _this.UV2 = false;\r\n _this.VERTEXCOLOR = false;\r\n _this.VERTEXALPHA = false;\r\n _this.NUM_BONE_INFLUENCERS = 0;\r\n _this.BonesPerMesh = 0;\r\n _this.BONETEXTURE = false;\r\n _this.BONES_VELOCITY_ENABLED = false;\r\n _this.INSTANCES = false;\r\n _this.THIN_INSTANCES = false;\r\n _this.GLOSSINESS = false;\r\n _this.ROUGHNESS = false;\r\n _this.EMISSIVEASILLUMINATION = false;\r\n _this.LINKEMISSIVEWITHDIFFUSE = false;\r\n _this.REFLECTIONFRESNELFROMSPECULAR = false;\r\n _this.LIGHTMAP = false;\r\n _this.LIGHTMAPDIRECTUV = 0;\r\n _this.OBJECTSPACE_NORMALMAP = false;\r\n _this.USELIGHTMAPASSHADOWMAP = false;\r\n _this.REFLECTIONMAP_3D = false;\r\n _this.REFLECTIONMAP_SPHERICAL = false;\r\n _this.REFLECTIONMAP_PLANAR = false;\r\n _this.REFLECTIONMAP_CUBIC = false;\r\n _this.USE_LOCAL_REFLECTIONMAP_CUBIC = false;\r\n _this.REFLECTIONMAP_PROJECTION = false;\r\n _this.REFLECTIONMAP_SKYBOX = false;\r\n _this.REFLECTIONMAP_EXPLICIT = false;\r\n _this.REFLECTIONMAP_EQUIRECTANGULAR = false;\r\n _this.REFLECTIONMAP_EQUIRECTANGULAR_FIXED = false;\r\n _this.REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED = false;\r\n _this.INVERTCUBICMAP = false;\r\n _this.LOGARITHMICDEPTH = false;\r\n _this.REFRACTION = false;\r\n _this.REFRACTIONMAP_3D = false;\r\n _this.REFLECTIONOVERALPHA = false;\r\n _this.TWOSIDEDLIGHTING = false;\r\n _this.SHADOWFLOAT = false;\r\n _this.MORPHTARGETS = false;\r\n _this.MORPHTARGETS_NORMAL = false;\r\n _this.MORPHTARGETS_TANGENT = false;\r\n _this.MORPHTARGETS_UV = false;\r\n _this.NUM_MORPH_INFLUENCERS = 0;\r\n _this.NONUNIFORMSCALING = false; // https://playground.babylonjs.com#V6DWIH\r\n _this.PREMULTIPLYALPHA = false; // https://playground.babylonjs.com#LNVJJ7\r\n _this.ALPHATEST_AFTERALLALPHACOMPUTATIONS = false;\r\n _this.ALPHABLEND = true;\r\n _this.PREPASS = false;\r\n _this.PREPASS_IRRADIANCE = false;\r\n _this.PREPASS_IRRADIANCE_INDEX = -1;\r\n _this.PREPASS_ALBEDO = false;\r\n _this.PREPASS_ALBEDO_INDEX = -1;\r\n _this.PREPASS_DEPTHNORMAL = false;\r\n _this.PREPASS_DEPTHNORMAL_INDEX = -1;\r\n _this.PREPASS_POSITION = false;\r\n _this.PREPASS_POSITION_INDEX = -1;\r\n _this.PREPASS_VELOCITY = false;\r\n _this.PREPASS_VELOCITY_INDEX = -1;\r\n _this.PREPASS_REFLECTIVITY = false;\r\n _this.PREPASS_REFLECTIVITY_INDEX = -1;\r\n _this.SCENE_MRT_COUNT = 0;\r\n _this.RGBDLIGHTMAP = false;\r\n _this.RGBDREFLECTION = false;\r\n _this.RGBDREFRACTION = false;\r\n _this.IMAGEPROCESSING = false;\r\n _this.VIGNETTE = false;\r\n _this.VIGNETTEBLENDMODEMULTIPLY = false;\r\n _this.VIGNETTEBLENDMODEOPAQUE = false;\r\n _this.TONEMAPPING = false;\r\n _this.TONEMAPPING_ACES = false;\r\n _this.CONTRAST = false;\r\n _this.COLORCURVES = false;\r\n _this.COLORGRADING = false;\r\n _this.COLORGRADING3D = false;\r\n _this.SAMPLER3DGREENDEPTH = false;\r\n _this.SAMPLER3DBGRMAP = false;\r\n _this.IMAGEPROCESSINGPOSTPROCESS = false;\r\n _this.MULTIVIEW = false;\r\n /**\r\n * If the reflection texture on this material is in linear color space\r\n * @hidden\r\n */\r\n _this.IS_REFLECTION_LINEAR = false;\r\n /**\r\n * If the refraction texture on this material is in linear color space\r\n * @hidden\r\n */\r\n _this.IS_REFRACTION_LINEAR = false;\r\n _this.EXPOSURE = false;\r\n _this.rebuild();\r\n return _this;\r\n }\r\n StandardMaterialDefines.prototype.setReflectionMode = function (modeToEnable) {\r\n var modes = [\r\n \"REFLECTIONMAP_CUBIC\", \"REFLECTIONMAP_EXPLICIT\", \"REFLECTIONMAP_PLANAR\",\r\n \"REFLECTIONMAP_PROJECTION\", \"REFLECTIONMAP_PROJECTION\", \"REFLECTIONMAP_SKYBOX\",\r\n \"REFLECTIONMAP_SPHERICAL\", \"REFLECTIONMAP_EQUIRECTANGULAR\", \"REFLECTIONMAP_EQUIRECTANGULAR_FIXED\",\r\n \"REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED\"\r\n ];\r\n for (var _i = 0, modes_1 = modes; _i < modes_1.length; _i++) {\r\n var mode = modes_1[_i];\r\n this[mode] = (mode === modeToEnable);\r\n }\r\n };\r\n return StandardMaterialDefines;\r\n}(MaterialDefines));\r\nexport { StandardMaterialDefines };\r\n/**\r\n * This is the default material used in Babylon. It is the best trade off between quality\r\n * and performances.\r\n * @see https://doc.babylonjs.com/babylon101/materials\r\n */\r\nvar StandardMaterial = /** @class */ (function (_super) {\r\n __extends(StandardMaterial, _super);\r\n /**\r\n * Instantiates a new standard material.\r\n * This is the default material used in Babylon. It is the best trade off between quality\r\n * and performances.\r\n * @see https://doc.babylonjs.com/babylon101/materials\r\n * @param name Define the name of the material in the scene\r\n * @param scene Define the scene the material belong to\r\n */\r\n function StandardMaterial(name, scene) {\r\n var _this = _super.call(this, name, scene) || this;\r\n _this._diffuseTexture = null;\r\n _this._ambientTexture = null;\r\n _this._opacityTexture = null;\r\n _this._reflectionTexture = null;\r\n _this._emissiveTexture = null;\r\n _this._specularTexture = null;\r\n _this._bumpTexture = null;\r\n _this._lightmapTexture = null;\r\n _this._refractionTexture = null;\r\n /**\r\n * The color of the material lit by the environmental background lighting.\r\n * @see https://doc.babylonjs.com/babylon101/materials#ambient-color-example\r\n */\r\n _this.ambientColor = new Color3(0, 0, 0);\r\n /**\r\n * The basic color of the material as viewed under a light.\r\n */\r\n _this.diffuseColor = new Color3(1, 1, 1);\r\n /**\r\n * Define how the color and intensity of the highlight given by the light in the material.\r\n */\r\n _this.specularColor = new Color3(1, 1, 1);\r\n /**\r\n * Define the color of the material as if self lit.\r\n * This will be mixed in the final result even in the absence of light.\r\n */\r\n _this.emissiveColor = new Color3(0, 0, 0);\r\n /**\r\n * Defines how sharp are the highlights in the material.\r\n * The bigger the value the sharper giving a more glossy feeling to the result.\r\n * Reversely, the smaller the value the blurrier giving a more rough feeling to the result.\r\n */\r\n _this.specularPower = 64;\r\n _this._useAlphaFromDiffuseTexture = false;\r\n _this._useEmissiveAsIllumination = false;\r\n _this._linkEmissiveWithDiffuse = false;\r\n _this._useSpecularOverAlpha = false;\r\n _this._useReflectionOverAlpha = false;\r\n _this._disableLighting = false;\r\n _this._useObjectSpaceNormalMap = false;\r\n _this._useParallax = false;\r\n _this._useParallaxOcclusion = false;\r\n /**\r\n * Apply a scaling factor that determine which \"depth\" the height map should reprensent. A value between 0.05 and 0.1 is reasonnable in Parallax, you can reach 0.2 using Parallax Occlusion.\r\n */\r\n _this.parallaxScaleBias = 0.05;\r\n _this._roughness = 0;\r\n /**\r\n * In case of refraction, define the value of the index of refraction.\r\n * @see https://doc.babylonjs.com/how_to/reflect#how-to-obtain-reflections-and-refractions\r\n */\r\n _this.indexOfRefraction = 0.98;\r\n /**\r\n * Invert the refraction texture alongside the y axis.\r\n * It can be useful with procedural textures or probe for instance.\r\n * @see https://doc.babylonjs.com/how_to/reflect#how-to-obtain-reflections-and-refractions\r\n */\r\n _this.invertRefractionY = true;\r\n /**\r\n * Defines the alpha limits in alpha test mode.\r\n */\r\n _this.alphaCutOff = 0.4;\r\n _this._useLightmapAsShadowmap = false;\r\n _this._useReflectionFresnelFromSpecular = false;\r\n _this._useGlossinessFromSpecularMapAlpha = false;\r\n _this._maxSimultaneousLights = 4;\r\n _this._invertNormalMapX = false;\r\n _this._invertNormalMapY = false;\r\n _this._twoSidedLighting = false;\r\n /**\r\n * Defines the detail map parameters for the material.\r\n */\r\n _this.detailMap = new DetailMapConfiguration(_this._markAllSubMeshesAsTexturesDirty.bind(_this));\r\n _this._renderTargets = new SmartArray(16);\r\n _this._worldViewProjectionMatrix = Matrix.Zero();\r\n _this._globalAmbientColor = new Color3(0, 0, 0);\r\n _this._rebuildInParallel = false;\r\n // Setup the default processing configuration to the scene.\r\n _this._attachImageProcessingConfiguration(null);\r\n _this.prePassConfiguration = new PrePassConfiguration();\r\n _this.getRenderTargetTextures = function () {\r\n _this._renderTargets.reset();\r\n if (StandardMaterial.ReflectionTextureEnabled && _this._reflectionTexture && _this._reflectionTexture.isRenderTarget) {\r\n _this._renderTargets.push(_this._reflectionTexture);\r\n }\r\n if (StandardMaterial.RefractionTextureEnabled && _this._refractionTexture && _this._refractionTexture.isRenderTarget) {\r\n _this._renderTargets.push(_this._refractionTexture);\r\n }\r\n return _this._renderTargets;\r\n };\r\n return _this;\r\n }\r\n Object.defineProperty(StandardMaterial.prototype, \"imageProcessingConfiguration\", {\r\n /**\r\n * Gets the image processing configuration used either in this material.\r\n */\r\n get: function () {\r\n return this._imageProcessingConfiguration;\r\n },\r\n /**\r\n * Sets the Default image processing configuration used either in the this material.\r\n *\r\n * If sets to null, the scene one is in use.\r\n */\r\n set: function (value) {\r\n this._attachImageProcessingConfiguration(value);\r\n // Ensure the effect will be rebuilt.\r\n this._markAllSubMeshesAsTexturesDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Attaches a new image processing configuration to the Standard Material.\r\n * @param configuration\r\n */\r\n StandardMaterial.prototype._attachImageProcessingConfiguration = function (configuration) {\r\n var _this = this;\r\n if (configuration === this._imageProcessingConfiguration) {\r\n return;\r\n }\r\n // Detaches observer\r\n if (this._imageProcessingConfiguration && this._imageProcessingObserver) {\r\n this._imageProcessingConfiguration.onUpdateParameters.remove(this._imageProcessingObserver);\r\n }\r\n // Pick the scene configuration if needed\r\n if (!configuration) {\r\n this._imageProcessingConfiguration = this.getScene().imageProcessingConfiguration;\r\n }\r\n else {\r\n this._imageProcessingConfiguration = configuration;\r\n }\r\n // Attaches observer\r\n if (this._imageProcessingConfiguration) {\r\n this._imageProcessingObserver = this._imageProcessingConfiguration.onUpdateParameters.add(function () {\r\n _this._markAllSubMeshesAsImageProcessingDirty();\r\n });\r\n }\r\n };\r\n Object.defineProperty(StandardMaterial.prototype, \"cameraColorCurvesEnabled\", {\r\n /**\r\n * Gets wether the color curves effect is enabled.\r\n */\r\n get: function () {\r\n return this.imageProcessingConfiguration.colorCurvesEnabled;\r\n },\r\n /**\r\n * Sets wether the color curves effect is enabled.\r\n */\r\n set: function (value) {\r\n this.imageProcessingConfiguration.colorCurvesEnabled = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial.prototype, \"cameraColorGradingEnabled\", {\r\n /**\r\n * Gets wether the color grading effect is enabled.\r\n */\r\n get: function () {\r\n return this.imageProcessingConfiguration.colorGradingEnabled;\r\n },\r\n /**\r\n * Gets wether the color grading effect is enabled.\r\n */\r\n set: function (value) {\r\n this.imageProcessingConfiguration.colorGradingEnabled = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial.prototype, \"cameraToneMappingEnabled\", {\r\n /**\r\n * Gets wether tonemapping is enabled or not.\r\n */\r\n get: function () {\r\n return this._imageProcessingConfiguration.toneMappingEnabled;\r\n },\r\n /**\r\n * Sets wether tonemapping is enabled or not\r\n */\r\n set: function (value) {\r\n this._imageProcessingConfiguration.toneMappingEnabled = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial.prototype, \"cameraExposure\", {\r\n /**\r\n * The camera exposure used on this material.\r\n * This property is here and not in the camera to allow controlling exposure without full screen post process.\r\n * This corresponds to a photographic exposure.\r\n */\r\n get: function () {\r\n return this._imageProcessingConfiguration.exposure;\r\n },\r\n /**\r\n * The camera exposure used on this material.\r\n * This property is here and not in the camera to allow controlling exposure without full screen post process.\r\n * This corresponds to a photographic exposure.\r\n */\r\n set: function (value) {\r\n this._imageProcessingConfiguration.exposure = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial.prototype, \"cameraContrast\", {\r\n /**\r\n * Gets The camera contrast used on this material.\r\n */\r\n get: function () {\r\n return this._imageProcessingConfiguration.contrast;\r\n },\r\n /**\r\n * Sets The camera contrast used on this material.\r\n */\r\n set: function (value) {\r\n this._imageProcessingConfiguration.contrast = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial.prototype, \"cameraColorGradingTexture\", {\r\n /**\r\n * Gets the Color Grading 2D Lookup Texture.\r\n */\r\n get: function () {\r\n return this._imageProcessingConfiguration.colorGradingTexture;\r\n },\r\n /**\r\n * Sets the Color Grading 2D Lookup Texture.\r\n */\r\n set: function (value) {\r\n this._imageProcessingConfiguration.colorGradingTexture = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial.prototype, \"cameraColorCurves\", {\r\n /**\r\n * The color grading curves provide additional color adjustmnent that is applied after any color grading transform (3D LUT).\r\n * They allow basic adjustment of saturation and small exposure adjustments, along with color filter tinting to provide white balance adjustment or more stylistic effects.\r\n * These are similar to controls found in many professional imaging or colorist software. The global controls are applied to the entire image. For advanced tuning, extra controls are provided to adjust the shadow, midtone and highlight areas of the image;\r\n * corresponding to low luminance, medium luminance, and high luminance areas respectively.\r\n */\r\n get: function () {\r\n return this._imageProcessingConfiguration.colorCurves;\r\n },\r\n /**\r\n * The color grading curves provide additional color adjustmnent that is applied after any color grading transform (3D LUT).\r\n * They allow basic adjustment of saturation and small exposure adjustments, along with color filter tinting to provide white balance adjustment or more stylistic effects.\r\n * These are similar to controls found in many professional imaging or colorist software. The global controls are applied to the entire image. For advanced tuning, extra controls are provided to adjust the shadow, midtone and highlight areas of the image;\r\n * corresponding to low luminance, medium luminance, and high luminance areas respectively.\r\n */\r\n set: function (value) {\r\n this._imageProcessingConfiguration.colorCurves = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial.prototype, \"canRenderToMRT\", {\r\n /**\r\n * Can this material render to several textures at once\r\n */\r\n get: function () {\r\n return true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial.prototype, \"hasRenderTargetTextures\", {\r\n /**\r\n * Gets a boolean indicating that current material needs to register RTT\r\n */\r\n get: function () {\r\n if (StandardMaterial.ReflectionTextureEnabled && this._reflectionTexture && this._reflectionTexture.isRenderTarget) {\r\n return true;\r\n }\r\n if (StandardMaterial.RefractionTextureEnabled && this._refractionTexture && this._refractionTexture.isRenderTarget) {\r\n return true;\r\n }\r\n return false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the current class name of the material e.g. \"StandardMaterial\"\r\n * Mainly use in serialization.\r\n * @returns the class name\r\n */\r\n StandardMaterial.prototype.getClassName = function () {\r\n return \"StandardMaterial\";\r\n };\r\n Object.defineProperty(StandardMaterial.prototype, \"useLogarithmicDepth\", {\r\n /**\r\n * In case the depth buffer does not allow enough depth precision for your scene (might be the case in large scenes)\r\n * You can try switching to logarithmic depth.\r\n * @see https://doc.babylonjs.com/how_to/using_logarithmic_depth_buffer\r\n */\r\n get: function () {\r\n return this._useLogarithmicDepth;\r\n },\r\n set: function (value) {\r\n this._useLogarithmicDepth = value && this.getScene().getEngine().getCaps().fragmentDepthSupported;\r\n this._markAllSubMeshesAsMiscDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Specifies if the material will require alpha blending\r\n * @returns a boolean specifying if alpha blending is needed\r\n */\r\n StandardMaterial.prototype.needAlphaBlending = function () {\r\n if (this._disableAlphaBlending) {\r\n return false;\r\n }\r\n return (this.alpha < 1.0) || (this._opacityTexture != null) || this._shouldUseAlphaFromDiffuseTexture() || this._opacityFresnelParameters && this._opacityFresnelParameters.isEnabled;\r\n };\r\n /**\r\n * Specifies if this material should be rendered in alpha test mode\r\n * @returns a boolean specifying if an alpha test is needed.\r\n */\r\n StandardMaterial.prototype.needAlphaTesting = function () {\r\n if (this._forceAlphaTest) {\r\n return true;\r\n }\r\n return this._hasAlphaChannel() && (this._transparencyMode == null || this._transparencyMode === Material.MATERIAL_ALPHATEST);\r\n };\r\n /**\r\n * Specifies whether or not the alpha value of the diffuse texture should be used for alpha blending.\r\n */\r\n StandardMaterial.prototype._shouldUseAlphaFromDiffuseTexture = function () {\r\n return this._diffuseTexture != null && this._diffuseTexture.hasAlpha && this._useAlphaFromDiffuseTexture && this._transparencyMode !== Material.MATERIAL_OPAQUE;\r\n };\r\n /**\r\n * Specifies whether or not there is a usable alpha channel for transparency.\r\n */\r\n StandardMaterial.prototype._hasAlphaChannel = function () {\r\n return (this._diffuseTexture != null && this._diffuseTexture.hasAlpha) || this._opacityTexture != null;\r\n };\r\n /**\r\n * Get the texture used for alpha test purpose.\r\n * @returns the diffuse texture in case of the standard material.\r\n */\r\n StandardMaterial.prototype.getAlphaTestTexture = function () {\r\n return this._diffuseTexture;\r\n };\r\n /**\r\n * Get if the submesh is ready to be used and all its information available.\r\n * Child classes can use it to update shaders\r\n * @param mesh defines the mesh to check\r\n * @param subMesh defines which submesh to check\r\n * @param useInstances specifies that instances should be used\r\n * @returns a boolean indicating that the submesh is ready or not\r\n */\r\n StandardMaterial.prototype.isReadyForSubMesh = function (mesh, subMesh, useInstances) {\r\n if (useInstances === void 0) { useInstances = false; }\r\n if (subMesh.effect && this.isFrozen) {\r\n if (subMesh.effect._wasPreviouslyReady) {\r\n return true;\r\n }\r\n }\r\n if (!subMesh._materialDefines) {\r\n subMesh._materialDefines = new StandardMaterialDefines();\r\n }\r\n var scene = this.getScene();\r\n var defines = subMesh._materialDefines;\r\n if (this._isReadyForSubMesh(subMesh)) {\r\n return true;\r\n }\r\n var engine = scene.getEngine();\r\n // Lights\r\n defines._needNormals = MaterialHelper.PrepareDefinesForLights(scene, mesh, defines, true, this._maxSimultaneousLights, this._disableLighting);\r\n // Multiview\r\n MaterialHelper.PrepareDefinesForMultiview(scene, defines);\r\n // PrePass\r\n MaterialHelper.PrepareDefinesForPrePass(scene, defines, this.canRenderToMRT);\r\n // Textures\r\n if (defines._areTexturesDirty) {\r\n defines._needUVs = false;\r\n defines.MAINUV1 = false;\r\n defines.MAINUV2 = false;\r\n if (scene.texturesEnabled) {\r\n if (this._diffuseTexture && StandardMaterial.DiffuseTextureEnabled) {\r\n if (!this._diffuseTexture.isReadyOrNotBlocking()) {\r\n return false;\r\n }\r\n else {\r\n MaterialHelper.PrepareDefinesForMergedUV(this._diffuseTexture, defines, \"DIFFUSE\");\r\n }\r\n }\r\n else {\r\n defines.DIFFUSE = false;\r\n }\r\n if (this._ambientTexture && StandardMaterial.AmbientTextureEnabled) {\r\n if (!this._ambientTexture.isReadyOrNotBlocking()) {\r\n return false;\r\n }\r\n else {\r\n MaterialHelper.PrepareDefinesForMergedUV(this._ambientTexture, defines, \"AMBIENT\");\r\n }\r\n }\r\n else {\r\n defines.AMBIENT = false;\r\n }\r\n if (this._opacityTexture && StandardMaterial.OpacityTextureEnabled) {\r\n if (!this._opacityTexture.isReadyOrNotBlocking()) {\r\n return false;\r\n }\r\n else {\r\n MaterialHelper.PrepareDefinesForMergedUV(this._opacityTexture, defines, \"OPACITY\");\r\n defines.OPACITYRGB = this._opacityTexture.getAlphaFromRGB;\r\n }\r\n }\r\n else {\r\n defines.OPACITY = false;\r\n }\r\n if (this._reflectionTexture && StandardMaterial.ReflectionTextureEnabled) {\r\n if (!this._reflectionTexture.isReadyOrNotBlocking()) {\r\n return false;\r\n }\r\n else {\r\n defines._needNormals = true;\r\n defines.REFLECTION = true;\r\n defines.ROUGHNESS = (this._roughness > 0);\r\n defines.REFLECTIONOVERALPHA = this._useReflectionOverAlpha;\r\n defines.INVERTCUBICMAP = (this._reflectionTexture.coordinatesMode === Texture.INVCUBIC_MODE);\r\n defines.REFLECTIONMAP_3D = this._reflectionTexture.isCube;\r\n defines.RGBDREFLECTION = this._reflectionTexture.isRGBD;\r\n switch (this._reflectionTexture.coordinatesMode) {\r\n case Texture.EXPLICIT_MODE:\r\n defines.setReflectionMode(\"REFLECTIONMAP_EXPLICIT\");\r\n break;\r\n case Texture.PLANAR_MODE:\r\n defines.setReflectionMode(\"REFLECTIONMAP_PLANAR\");\r\n break;\r\n case Texture.PROJECTION_MODE:\r\n defines.setReflectionMode(\"REFLECTIONMAP_PROJECTION\");\r\n break;\r\n case Texture.SKYBOX_MODE:\r\n defines.setReflectionMode(\"REFLECTIONMAP_SKYBOX\");\r\n break;\r\n case Texture.SPHERICAL_MODE:\r\n defines.setReflectionMode(\"REFLECTIONMAP_SPHERICAL\");\r\n break;\r\n case Texture.EQUIRECTANGULAR_MODE:\r\n defines.setReflectionMode(\"REFLECTIONMAP_EQUIRECTANGULAR\");\r\n break;\r\n case Texture.FIXED_EQUIRECTANGULAR_MODE:\r\n defines.setReflectionMode(\"REFLECTIONMAP_EQUIRECTANGULAR_FIXED\");\r\n break;\r\n case Texture.FIXED_EQUIRECTANGULAR_MIRRORED_MODE:\r\n defines.setReflectionMode(\"REFLECTIONMAP_MIRROREDEQUIRECTANGULAR_FIXED\");\r\n break;\r\n case Texture.CUBIC_MODE:\r\n case Texture.INVCUBIC_MODE:\r\n default:\r\n defines.setReflectionMode(\"REFLECTIONMAP_CUBIC\");\r\n break;\r\n }\r\n defines.USE_LOCAL_REFLECTIONMAP_CUBIC = this._reflectionTexture.boundingBoxSize ? true : false;\r\n }\r\n }\r\n else {\r\n defines.REFLECTION = false;\r\n }\r\n if (this._emissiveTexture && StandardMaterial.EmissiveTextureEnabled) {\r\n if (!this._emissiveTexture.isReadyOrNotBlocking()) {\r\n return false;\r\n }\r\n else {\r\n MaterialHelper.PrepareDefinesForMergedUV(this._emissiveTexture, defines, \"EMISSIVE\");\r\n }\r\n }\r\n else {\r\n defines.EMISSIVE = false;\r\n }\r\n if (this._lightmapTexture && StandardMaterial.LightmapTextureEnabled) {\r\n if (!this._lightmapTexture.isReadyOrNotBlocking()) {\r\n return false;\r\n }\r\n else {\r\n MaterialHelper.PrepareDefinesForMergedUV(this._lightmapTexture, defines, \"LIGHTMAP\");\r\n defines.USELIGHTMAPASSHADOWMAP = this._useLightmapAsShadowmap;\r\n defines.RGBDLIGHTMAP = this._lightmapTexture.isRGBD;\r\n }\r\n }\r\n else {\r\n defines.LIGHTMAP = false;\r\n }\r\n if (this._specularTexture && StandardMaterial.SpecularTextureEnabled) {\r\n if (!this._specularTexture.isReadyOrNotBlocking()) {\r\n return false;\r\n }\r\n else {\r\n MaterialHelper.PrepareDefinesForMergedUV(this._specularTexture, defines, \"SPECULAR\");\r\n defines.GLOSSINESS = this._useGlossinessFromSpecularMapAlpha;\r\n }\r\n }\r\n else {\r\n defines.SPECULAR = false;\r\n }\r\n if (scene.getEngine().getCaps().standardDerivatives && this._bumpTexture && StandardMaterial.BumpTextureEnabled) {\r\n // Bump texure can not be not blocking.\r\n if (!this._bumpTexture.isReady()) {\r\n return false;\r\n }\r\n else {\r\n MaterialHelper.PrepareDefinesForMergedUV(this._bumpTexture, defines, \"BUMP\");\r\n defines.PARALLAX = this._useParallax;\r\n defines.PARALLAXOCCLUSION = this._useParallaxOcclusion;\r\n }\r\n defines.OBJECTSPACE_NORMALMAP = this._useObjectSpaceNormalMap;\r\n }\r\n else {\r\n defines.BUMP = false;\r\n }\r\n if (this._refractionTexture && StandardMaterial.RefractionTextureEnabled) {\r\n if (!this._refractionTexture.isReadyOrNotBlocking()) {\r\n return false;\r\n }\r\n else {\r\n defines._needUVs = true;\r\n defines.REFRACTION = true;\r\n defines.REFRACTIONMAP_3D = this._refractionTexture.isCube;\r\n defines.RGBDREFRACTION = this._refractionTexture.isRGBD;\r\n }\r\n }\r\n else {\r\n defines.REFRACTION = false;\r\n }\r\n defines.TWOSIDEDLIGHTING = !this._backFaceCulling && this._twoSidedLighting;\r\n }\r\n else {\r\n defines.DIFFUSE = false;\r\n defines.AMBIENT = false;\r\n defines.OPACITY = false;\r\n defines.REFLECTION = false;\r\n defines.EMISSIVE = false;\r\n defines.LIGHTMAP = false;\r\n defines.BUMP = false;\r\n defines.REFRACTION = false;\r\n }\r\n defines.ALPHAFROMDIFFUSE = this._shouldUseAlphaFromDiffuseTexture();\r\n defines.EMISSIVEASILLUMINATION = this._useEmissiveAsIllumination;\r\n defines.LINKEMISSIVEWITHDIFFUSE = this._linkEmissiveWithDiffuse;\r\n defines.SPECULAROVERALPHA = this._useSpecularOverAlpha;\r\n defines.PREMULTIPLYALPHA = (this.alphaMode === 7 || this.alphaMode === 8);\r\n defines.ALPHATEST_AFTERALLALPHACOMPUTATIONS = this.transparencyMode !== null;\r\n defines.ALPHABLEND = this.transparencyMode === null || this.needAlphaBlendingForMesh(mesh); // check on null for backward compatibility\r\n }\r\n if (!this.detailMap.isReadyForSubMesh(defines, scene)) {\r\n return false;\r\n }\r\n if (defines._areImageProcessingDirty && this._imageProcessingConfiguration) {\r\n if (!this._imageProcessingConfiguration.isReady()) {\r\n return false;\r\n }\r\n this._imageProcessingConfiguration.prepareDefines(defines);\r\n defines.IS_REFLECTION_LINEAR = (this.reflectionTexture != null && !this.reflectionTexture.gammaSpace);\r\n defines.IS_REFRACTION_LINEAR = (this.refractionTexture != null && !this.refractionTexture.gammaSpace);\r\n }\r\n if (defines._areFresnelDirty) {\r\n if (StandardMaterial.FresnelEnabled) {\r\n // Fresnel\r\n if (this._diffuseFresnelParameters || this._opacityFresnelParameters ||\r\n this._emissiveFresnelParameters || this._refractionFresnelParameters ||\r\n this._reflectionFresnelParameters) {\r\n defines.DIFFUSEFRESNEL = (this._diffuseFresnelParameters && this._diffuseFresnelParameters.isEnabled);\r\n defines.OPACITYFRESNEL = (this._opacityFresnelParameters && this._opacityFresnelParameters.isEnabled);\r\n defines.REFLECTIONFRESNEL = (this._reflectionFresnelParameters && this._reflectionFresnelParameters.isEnabled);\r\n defines.REFLECTIONFRESNELFROMSPECULAR = this._useReflectionFresnelFromSpecular;\r\n defines.REFRACTIONFRESNEL = (this._refractionFresnelParameters && this._refractionFresnelParameters.isEnabled);\r\n defines.EMISSIVEFRESNEL = (this._emissiveFresnelParameters && this._emissiveFresnelParameters.isEnabled);\r\n defines._needNormals = true;\r\n defines.FRESNEL = true;\r\n }\r\n }\r\n else {\r\n defines.FRESNEL = false;\r\n }\r\n }\r\n // Misc.\r\n MaterialHelper.PrepareDefinesForMisc(mesh, scene, this._useLogarithmicDepth, this.pointsCloud, this.fogEnabled, this._shouldTurnAlphaTestOn(mesh) || this._forceAlphaTest, defines);\r\n // Attribs\r\n MaterialHelper.PrepareDefinesForAttributes(mesh, defines, true, true, true);\r\n // Values that need to be evaluated on every frame\r\n MaterialHelper.PrepareDefinesForFrameBoundValues(scene, engine, defines, useInstances, null, subMesh.getRenderingMesh().hasThinInstances);\r\n // External config\r\n this.detailMap.prepareDefines(defines, scene);\r\n // Get correct effect\r\n if (defines.isDirty) {\r\n var lightDisposed = defines._areLightsDisposed;\r\n defines.markAsProcessed();\r\n // Fallbacks\r\n var fallbacks = new EffectFallbacks();\r\n if (defines.REFLECTION) {\r\n fallbacks.addFallback(0, \"REFLECTION\");\r\n }\r\n if (defines.SPECULAR) {\r\n fallbacks.addFallback(0, \"SPECULAR\");\r\n }\r\n if (defines.BUMP) {\r\n fallbacks.addFallback(0, \"BUMP\");\r\n }\r\n if (defines.PARALLAX) {\r\n fallbacks.addFallback(1, \"PARALLAX\");\r\n }\r\n if (defines.PARALLAXOCCLUSION) {\r\n fallbacks.addFallback(0, \"PARALLAXOCCLUSION\");\r\n }\r\n if (defines.SPECULAROVERALPHA) {\r\n fallbacks.addFallback(0, \"SPECULAROVERALPHA\");\r\n }\r\n if (defines.FOG) {\r\n fallbacks.addFallback(1, \"FOG\");\r\n }\r\n if (defines.POINTSIZE) {\r\n fallbacks.addFallback(0, \"POINTSIZE\");\r\n }\r\n if (defines.LOGARITHMICDEPTH) {\r\n fallbacks.addFallback(0, \"LOGARITHMICDEPTH\");\r\n }\r\n MaterialHelper.HandleFallbacksForShadows(defines, fallbacks, this._maxSimultaneousLights);\r\n if (defines.SPECULARTERM) {\r\n fallbacks.addFallback(0, \"SPECULARTERM\");\r\n }\r\n if (defines.DIFFUSEFRESNEL) {\r\n fallbacks.addFallback(1, \"DIFFUSEFRESNEL\");\r\n }\r\n if (defines.OPACITYFRESNEL) {\r\n fallbacks.addFallback(2, \"OPACITYFRESNEL\");\r\n }\r\n if (defines.REFLECTIONFRESNEL) {\r\n fallbacks.addFallback(3, \"REFLECTIONFRESNEL\");\r\n }\r\n if (defines.EMISSIVEFRESNEL) {\r\n fallbacks.addFallback(4, \"EMISSIVEFRESNEL\");\r\n }\r\n if (defines.FRESNEL) {\r\n fallbacks.addFallback(4, \"FRESNEL\");\r\n }\r\n if (defines.MULTIVIEW) {\r\n fallbacks.addFallback(0, \"MULTIVIEW\");\r\n }\r\n //Attributes\r\n var attribs = [VertexBuffer.PositionKind];\r\n if (defines.NORMAL) {\r\n attribs.push(VertexBuffer.NormalKind);\r\n }\r\n if (defines.UV1) {\r\n attribs.push(VertexBuffer.UVKind);\r\n }\r\n if (defines.UV2) {\r\n attribs.push(VertexBuffer.UV2Kind);\r\n }\r\n if (defines.VERTEXCOLOR) {\r\n attribs.push(VertexBuffer.ColorKind);\r\n }\r\n MaterialHelper.PrepareAttributesForBones(attribs, mesh, defines, fallbacks);\r\n MaterialHelper.PrepareAttributesForInstances(attribs, defines);\r\n MaterialHelper.PrepareAttributesForMorphTargets(attribs, mesh, defines);\r\n var shaderName = \"default\";\r\n var uniforms = [\"world\", \"view\", \"viewProjection\", \"vEyePosition\", \"vLightsType\", \"vAmbientColor\", \"vDiffuseColor\", \"vSpecularColor\", \"vEmissiveColor\", \"visibility\",\r\n \"vFogInfos\", \"vFogColor\", \"pointSize\",\r\n \"vDiffuseInfos\", \"vAmbientInfos\", \"vOpacityInfos\", \"vReflectionInfos\", \"vEmissiveInfos\", \"vSpecularInfos\", \"vBumpInfos\", \"vLightmapInfos\", \"vRefractionInfos\",\r\n \"mBones\",\r\n \"vClipPlane\", \"vClipPlane2\", \"vClipPlane3\", \"vClipPlane4\", \"vClipPlane5\", \"vClipPlane6\", \"diffuseMatrix\", \"ambientMatrix\", \"opacityMatrix\", \"reflectionMatrix\", \"emissiveMatrix\", \"specularMatrix\", \"bumpMatrix\", \"normalMatrix\", \"lightmapMatrix\", \"refractionMatrix\",\r\n \"diffuseLeftColor\", \"diffuseRightColor\", \"opacityParts\", \"reflectionLeftColor\", \"reflectionRightColor\", \"emissiveLeftColor\", \"emissiveRightColor\", \"refractionLeftColor\", \"refractionRightColor\",\r\n \"vReflectionPosition\", \"vReflectionSize\",\r\n \"logarithmicDepthConstant\", \"vTangentSpaceParams\", \"alphaCutOff\", \"boneTextureWidth\"\r\n ];\r\n var samplers = [\"diffuseSampler\", \"ambientSampler\", \"opacitySampler\", \"reflectionCubeSampler\",\r\n \"reflection2DSampler\", \"emissiveSampler\", \"specularSampler\", \"bumpSampler\", \"lightmapSampler\",\r\n \"refractionCubeSampler\", \"refraction2DSampler\", \"boneSampler\"];\r\n var uniformBuffers = [\"Material\", \"Scene\"];\r\n DetailMapConfiguration.AddUniforms(uniforms);\r\n DetailMapConfiguration.AddSamplers(samplers);\r\n PrePassConfiguration.AddUniforms(uniforms);\r\n PrePassConfiguration.AddSamplers(uniforms);\r\n if (ImageProcessingConfiguration) {\r\n ImageProcessingConfiguration.PrepareUniforms(uniforms, defines);\r\n ImageProcessingConfiguration.PrepareSamplers(samplers, defines);\r\n }\r\n MaterialHelper.PrepareUniformsAndSamplersList({\r\n uniformsNames: uniforms,\r\n uniformBuffersNames: uniformBuffers,\r\n samplers: samplers,\r\n defines: defines,\r\n maxSimultaneousLights: this._maxSimultaneousLights\r\n });\r\n var csnrOptions = {};\r\n if (this.customShaderNameResolve) {\r\n shaderName = this.customShaderNameResolve(shaderName, uniforms, uniformBuffers, samplers, defines, attribs, csnrOptions);\r\n }\r\n var join = defines.toString();\r\n var previousEffect = subMesh.effect;\r\n var effect = scene.getEngine().createEffect(shaderName, {\r\n attributes: attribs,\r\n uniformsNames: uniforms,\r\n uniformBuffersNames: uniformBuffers,\r\n samplers: samplers,\r\n defines: join,\r\n fallbacks: fallbacks,\r\n onCompiled: this.onCompiled,\r\n onError: this.onError,\r\n indexParameters: { maxSimultaneousLights: this._maxSimultaneousLights, maxSimultaneousMorphTargets: defines.NUM_MORPH_INFLUENCERS },\r\n processFinalCode: csnrOptions.processFinalCode,\r\n multiTarget: defines.PREPASS\r\n }, engine);\r\n if (effect) {\r\n if (this._onEffectCreatedObservable) {\r\n onCreatedEffectParameters.effect = effect;\r\n onCreatedEffectParameters.subMesh = subMesh;\r\n this._onEffectCreatedObservable.notifyObservers(onCreatedEffectParameters);\r\n }\r\n // Use previous effect while new one is compiling\r\n if (this.allowShaderHotSwapping && previousEffect && !effect.isReady()) {\r\n effect = previousEffect;\r\n this._rebuildInParallel = true;\r\n defines.markAsUnprocessed();\r\n if (lightDisposed) {\r\n // re register in case it takes more than one frame.\r\n defines._areLightsDisposed = true;\r\n return false;\r\n }\r\n }\r\n else {\r\n this._rebuildInParallel = false;\r\n scene.resetCachedMaterial();\r\n subMesh.setEffect(effect, defines);\r\n this.buildUniformLayout();\r\n }\r\n }\r\n }\r\n if (!subMesh.effect || !subMesh.effect.isReady()) {\r\n return false;\r\n }\r\n defines._renderId = scene.getRenderId();\r\n subMesh.effect._wasPreviouslyReady = true;\r\n return true;\r\n };\r\n /**\r\n * Builds the material UBO layouts.\r\n * Used internally during the effect preparation.\r\n */\r\n StandardMaterial.prototype.buildUniformLayout = function () {\r\n // Order is important !\r\n var ubo = this._uniformBuffer;\r\n ubo.addUniform(\"diffuseLeftColor\", 4);\r\n ubo.addUniform(\"diffuseRightColor\", 4);\r\n ubo.addUniform(\"opacityParts\", 4);\r\n ubo.addUniform(\"reflectionLeftColor\", 4);\r\n ubo.addUniform(\"reflectionRightColor\", 4);\r\n ubo.addUniform(\"refractionLeftColor\", 4);\r\n ubo.addUniform(\"refractionRightColor\", 4);\r\n ubo.addUniform(\"emissiveLeftColor\", 4);\r\n ubo.addUniform(\"emissiveRightColor\", 4);\r\n ubo.addUniform(\"vDiffuseInfos\", 2);\r\n ubo.addUniform(\"vAmbientInfos\", 2);\r\n ubo.addUniform(\"vOpacityInfos\", 2);\r\n ubo.addUniform(\"vReflectionInfos\", 2);\r\n ubo.addUniform(\"vReflectionPosition\", 3);\r\n ubo.addUniform(\"vReflectionSize\", 3);\r\n ubo.addUniform(\"vEmissiveInfos\", 2);\r\n ubo.addUniform(\"vLightmapInfos\", 2);\r\n ubo.addUniform(\"vSpecularInfos\", 2);\r\n ubo.addUniform(\"vBumpInfos\", 3);\r\n ubo.addUniform(\"diffuseMatrix\", 16);\r\n ubo.addUniform(\"ambientMatrix\", 16);\r\n ubo.addUniform(\"opacityMatrix\", 16);\r\n ubo.addUniform(\"reflectionMatrix\", 16);\r\n ubo.addUniform(\"emissiveMatrix\", 16);\r\n ubo.addUniform(\"lightmapMatrix\", 16);\r\n ubo.addUniform(\"specularMatrix\", 16);\r\n ubo.addUniform(\"bumpMatrix\", 16);\r\n ubo.addUniform(\"vTangentSpaceParams\", 2);\r\n ubo.addUniform(\"pointSize\", 1);\r\n ubo.addUniform(\"refractionMatrix\", 16);\r\n ubo.addUniform(\"vRefractionInfos\", 4);\r\n ubo.addUniform(\"vSpecularColor\", 4);\r\n ubo.addUniform(\"vEmissiveColor\", 3);\r\n ubo.addUniform(\"visibility\", 1);\r\n ubo.addUniform(\"vDiffuseColor\", 4);\r\n DetailMapConfiguration.PrepareUniformBuffer(ubo);\r\n ubo.create();\r\n };\r\n /**\r\n * Unbinds the material from the mesh\r\n */\r\n StandardMaterial.prototype.unbind = function () {\r\n if (this._activeEffect) {\r\n var needFlag = false;\r\n if (this._reflectionTexture && this._reflectionTexture.isRenderTarget) {\r\n this._activeEffect.setTexture(\"reflection2DSampler\", null);\r\n needFlag = true;\r\n }\r\n if (this._refractionTexture && this._refractionTexture.isRenderTarget) {\r\n this._activeEffect.setTexture(\"refraction2DSampler\", null);\r\n needFlag = true;\r\n }\r\n if (needFlag) {\r\n this._markAllSubMeshesAsTexturesDirty();\r\n }\r\n }\r\n _super.prototype.unbind.call(this);\r\n };\r\n /**\r\n * Binds the submesh to this material by preparing the effect and shader to draw\r\n * @param world defines the world transformation matrix\r\n * @param mesh defines the mesh containing the submesh\r\n * @param subMesh defines the submesh to bind the material to\r\n */\r\n StandardMaterial.prototype.bindForSubMesh = function (world, mesh, subMesh) {\r\n var scene = this.getScene();\r\n var defines = subMesh._materialDefines;\r\n if (!defines) {\r\n return;\r\n }\r\n var effect = subMesh.effect;\r\n if (!effect) {\r\n return;\r\n }\r\n this._activeEffect = effect;\r\n // Matrices\r\n if (!defines.INSTANCES || defines.THIN_INSTANCES) {\r\n this.bindOnlyWorldMatrix(world);\r\n }\r\n // PrePass\r\n this.prePassConfiguration.bindForSubMesh(this._activeEffect, scene, mesh, world, this.isFrozen);\r\n // Normal Matrix\r\n if (defines.OBJECTSPACE_NORMALMAP) {\r\n world.toNormalMatrix(this._normalMatrix);\r\n this.bindOnlyNormalMatrix(this._normalMatrix);\r\n }\r\n var mustRebind = this._mustRebind(scene, effect, mesh.visibility);\r\n // Bones\r\n MaterialHelper.BindBonesParameters(mesh, effect);\r\n var ubo = this._uniformBuffer;\r\n if (mustRebind) {\r\n ubo.bindToEffect(effect, \"Material\");\r\n this.bindViewProjection(effect);\r\n if (!ubo.useUbo || !this.isFrozen || !ubo.isSync) {\r\n if (StandardMaterial.FresnelEnabled && defines.FRESNEL) {\r\n // Fresnel\r\n if (this.diffuseFresnelParameters && this.diffuseFresnelParameters.isEnabled) {\r\n ubo.updateColor4(\"diffuseLeftColor\", this.diffuseFresnelParameters.leftColor, this.diffuseFresnelParameters.power);\r\n ubo.updateColor4(\"diffuseRightColor\", this.diffuseFresnelParameters.rightColor, this.diffuseFresnelParameters.bias);\r\n }\r\n if (this.opacityFresnelParameters && this.opacityFresnelParameters.isEnabled) {\r\n ubo.updateColor4(\"opacityParts\", new Color3(this.opacityFresnelParameters.leftColor.toLuminance(), this.opacityFresnelParameters.rightColor.toLuminance(), this.opacityFresnelParameters.bias), this.opacityFresnelParameters.power);\r\n }\r\n if (this.reflectionFresnelParameters && this.reflectionFresnelParameters.isEnabled) {\r\n ubo.updateColor4(\"reflectionLeftColor\", this.reflectionFresnelParameters.leftColor, this.reflectionFresnelParameters.power);\r\n ubo.updateColor4(\"reflectionRightColor\", this.reflectionFresnelParameters.rightColor, this.reflectionFresnelParameters.bias);\r\n }\r\n if (this.refractionFresnelParameters && this.refractionFresnelParameters.isEnabled) {\r\n ubo.updateColor4(\"refractionLeftColor\", this.refractionFresnelParameters.leftColor, this.refractionFresnelParameters.power);\r\n ubo.updateColor4(\"refractionRightColor\", this.refractionFresnelParameters.rightColor, this.refractionFresnelParameters.bias);\r\n }\r\n if (this.emissiveFresnelParameters && this.emissiveFresnelParameters.isEnabled) {\r\n ubo.updateColor4(\"emissiveLeftColor\", this.emissiveFresnelParameters.leftColor, this.emissiveFresnelParameters.power);\r\n ubo.updateColor4(\"emissiveRightColor\", this.emissiveFresnelParameters.rightColor, this.emissiveFresnelParameters.bias);\r\n }\r\n }\r\n // Textures\r\n if (scene.texturesEnabled) {\r\n if (this._diffuseTexture && StandardMaterial.DiffuseTextureEnabled) {\r\n ubo.updateFloat2(\"vDiffuseInfos\", this._diffuseTexture.coordinatesIndex, this._diffuseTexture.level);\r\n MaterialHelper.BindTextureMatrix(this._diffuseTexture, ubo, \"diffuse\");\r\n }\r\n if (this._ambientTexture && StandardMaterial.AmbientTextureEnabled) {\r\n ubo.updateFloat2(\"vAmbientInfos\", this._ambientTexture.coordinatesIndex, this._ambientTexture.level);\r\n MaterialHelper.BindTextureMatrix(this._ambientTexture, ubo, \"ambient\");\r\n }\r\n if (this._opacityTexture && StandardMaterial.OpacityTextureEnabled) {\r\n ubo.updateFloat2(\"vOpacityInfos\", this._opacityTexture.coordinatesIndex, this._opacityTexture.level);\r\n MaterialHelper.BindTextureMatrix(this._opacityTexture, ubo, \"opacity\");\r\n }\r\n if (this._hasAlphaChannel()) {\r\n effect.setFloat(\"alphaCutOff\", this.alphaCutOff);\r\n }\r\n if (this._reflectionTexture && StandardMaterial.ReflectionTextureEnabled) {\r\n ubo.updateFloat2(\"vReflectionInfos\", this._reflectionTexture.level, this.roughness);\r\n ubo.updateMatrix(\"reflectionMatrix\", this._reflectionTexture.getReflectionTextureMatrix());\r\n if (this._reflectionTexture.boundingBoxSize) {\r\n var cubeTexture = this._reflectionTexture;\r\n ubo.updateVector3(\"vReflectionPosition\", cubeTexture.boundingBoxPosition);\r\n ubo.updateVector3(\"vReflectionSize\", cubeTexture.boundingBoxSize);\r\n }\r\n }\r\n if (this._emissiveTexture && StandardMaterial.EmissiveTextureEnabled) {\r\n ubo.updateFloat2(\"vEmissiveInfos\", this._emissiveTexture.coordinatesIndex, this._emissiveTexture.level);\r\n MaterialHelper.BindTextureMatrix(this._emissiveTexture, ubo, \"emissive\");\r\n }\r\n if (this._lightmapTexture && StandardMaterial.LightmapTextureEnabled) {\r\n ubo.updateFloat2(\"vLightmapInfos\", this._lightmapTexture.coordinatesIndex, this._lightmapTexture.level);\r\n MaterialHelper.BindTextureMatrix(this._lightmapTexture, ubo, \"lightmap\");\r\n }\r\n if (this._specularTexture && StandardMaterial.SpecularTextureEnabled) {\r\n ubo.updateFloat2(\"vSpecularInfos\", this._specularTexture.coordinatesIndex, this._specularTexture.level);\r\n MaterialHelper.BindTextureMatrix(this._specularTexture, ubo, \"specular\");\r\n }\r\n if (this._bumpTexture && scene.getEngine().getCaps().standardDerivatives && StandardMaterial.BumpTextureEnabled) {\r\n ubo.updateFloat3(\"vBumpInfos\", this._bumpTexture.coordinatesIndex, 1.0 / this._bumpTexture.level, this.parallaxScaleBias);\r\n MaterialHelper.BindTextureMatrix(this._bumpTexture, ubo, \"bump\");\r\n if (scene._mirroredCameraPosition) {\r\n ubo.updateFloat2(\"vTangentSpaceParams\", this._invertNormalMapX ? 1.0 : -1.0, this._invertNormalMapY ? 1.0 : -1.0);\r\n }\r\n else {\r\n ubo.updateFloat2(\"vTangentSpaceParams\", this._invertNormalMapX ? -1.0 : 1.0, this._invertNormalMapY ? -1.0 : 1.0);\r\n }\r\n }\r\n if (this._refractionTexture && StandardMaterial.RefractionTextureEnabled) {\r\n var depth = 1.0;\r\n if (!this._refractionTexture.isCube) {\r\n ubo.updateMatrix(\"refractionMatrix\", this._refractionTexture.getReflectionTextureMatrix());\r\n if (this._refractionTexture.depth) {\r\n depth = this._refractionTexture.depth;\r\n }\r\n }\r\n ubo.updateFloat4(\"vRefractionInfos\", this._refractionTexture.level, this.indexOfRefraction, depth, this.invertRefractionY ? -1 : 1);\r\n }\r\n }\r\n // Point size\r\n if (this.pointsCloud) {\r\n ubo.updateFloat(\"pointSize\", this.pointSize);\r\n }\r\n if (defines.SPECULARTERM) {\r\n ubo.updateColor4(\"vSpecularColor\", this.specularColor, this.specularPower);\r\n }\r\n ubo.updateColor3(\"vEmissiveColor\", StandardMaterial.EmissiveTextureEnabled ? this.emissiveColor : Color3.BlackReadOnly);\r\n // Diffuse\r\n ubo.updateColor4(\"vDiffuseColor\", this.diffuseColor, this.alpha);\r\n }\r\n // Visibility\r\n ubo.updateFloat(\"visibility\", mesh.visibility);\r\n // Textures\r\n if (scene.texturesEnabled) {\r\n if (this._diffuseTexture && StandardMaterial.DiffuseTextureEnabled) {\r\n effect.setTexture(\"diffuseSampler\", this._diffuseTexture);\r\n }\r\n if (this._ambientTexture && StandardMaterial.AmbientTextureEnabled) {\r\n effect.setTexture(\"ambientSampler\", this._ambientTexture);\r\n }\r\n if (this._opacityTexture && StandardMaterial.OpacityTextureEnabled) {\r\n effect.setTexture(\"opacitySampler\", this._opacityTexture);\r\n }\r\n if (this._reflectionTexture && StandardMaterial.ReflectionTextureEnabled) {\r\n if (this._reflectionTexture.isCube) {\r\n effect.setTexture(\"reflectionCubeSampler\", this._reflectionTexture);\r\n }\r\n else {\r\n effect.setTexture(\"reflection2DSampler\", this._reflectionTexture);\r\n }\r\n }\r\n if (this._emissiveTexture && StandardMaterial.EmissiveTextureEnabled) {\r\n effect.setTexture(\"emissiveSampler\", this._emissiveTexture);\r\n }\r\n if (this._lightmapTexture && StandardMaterial.LightmapTextureEnabled) {\r\n effect.setTexture(\"lightmapSampler\", this._lightmapTexture);\r\n }\r\n if (this._specularTexture && StandardMaterial.SpecularTextureEnabled) {\r\n effect.setTexture(\"specularSampler\", this._specularTexture);\r\n }\r\n if (this._bumpTexture && scene.getEngine().getCaps().standardDerivatives && StandardMaterial.BumpTextureEnabled) {\r\n effect.setTexture(\"bumpSampler\", this._bumpTexture);\r\n }\r\n if (this._refractionTexture && StandardMaterial.RefractionTextureEnabled) {\r\n var depth = 1.0;\r\n if (this._refractionTexture.isCube) {\r\n effect.setTexture(\"refractionCubeSampler\", this._refractionTexture);\r\n }\r\n else {\r\n effect.setTexture(\"refraction2DSampler\", this._refractionTexture);\r\n }\r\n }\r\n }\r\n this.detailMap.bindForSubMesh(ubo, scene, this.isFrozen);\r\n // Clip plane\r\n MaterialHelper.BindClipPlane(effect, scene);\r\n // Colors\r\n scene.ambientColor.multiplyToRef(this.ambientColor, this._globalAmbientColor);\r\n MaterialHelper.BindEyePosition(effect, scene);\r\n effect.setColor3(\"vAmbientColor\", this._globalAmbientColor);\r\n }\r\n if (mustRebind || !this.isFrozen) {\r\n // Lights\r\n if (scene.lightsEnabled && !this._disableLighting) {\r\n MaterialHelper.BindLights(scene, mesh, effect, defines, this._maxSimultaneousLights, this._rebuildInParallel);\r\n }\r\n // View\r\n if (scene.fogEnabled && mesh.applyFog && scene.fogMode !== Scene.FOGMODE_NONE || this._reflectionTexture || this._refractionTexture) {\r\n this.bindView(effect);\r\n }\r\n // Fog\r\n MaterialHelper.BindFogParameters(scene, mesh, effect);\r\n // Morph targets\r\n if (defines.NUM_MORPH_INFLUENCERS) {\r\n MaterialHelper.BindMorphTargetParameters(mesh, effect);\r\n }\r\n // Log. depth\r\n if (this.useLogarithmicDepth) {\r\n MaterialHelper.BindLogDepth(defines, effect, scene);\r\n }\r\n // image processing\r\n if (this._imageProcessingConfiguration && !this._imageProcessingConfiguration.applyByPostProcess) {\r\n this._imageProcessingConfiguration.bind(this._activeEffect);\r\n }\r\n }\r\n ubo.update();\r\n this._afterBind(mesh, this._activeEffect);\r\n };\r\n /**\r\n * Get the list of animatables in the material.\r\n * @returns the list of animatables object used in the material\r\n */\r\n StandardMaterial.prototype.getAnimatables = function () {\r\n var results = [];\r\n if (this._diffuseTexture && this._diffuseTexture.animations && this._diffuseTexture.animations.length > 0) {\r\n results.push(this._diffuseTexture);\r\n }\r\n if (this._ambientTexture && this._ambientTexture.animations && this._ambientTexture.animations.length > 0) {\r\n results.push(this._ambientTexture);\r\n }\r\n if (this._opacityTexture && this._opacityTexture.animations && this._opacityTexture.animations.length > 0) {\r\n results.push(this._opacityTexture);\r\n }\r\n if (this._reflectionTexture && this._reflectionTexture.animations && this._reflectionTexture.animations.length > 0) {\r\n results.push(this._reflectionTexture);\r\n }\r\n if (this._emissiveTexture && this._emissiveTexture.animations && this._emissiveTexture.animations.length > 0) {\r\n results.push(this._emissiveTexture);\r\n }\r\n if (this._specularTexture && this._specularTexture.animations && this._specularTexture.animations.length > 0) {\r\n results.push(this._specularTexture);\r\n }\r\n if (this._bumpTexture && this._bumpTexture.animations && this._bumpTexture.animations.length > 0) {\r\n results.push(this._bumpTexture);\r\n }\r\n if (this._lightmapTexture && this._lightmapTexture.animations && this._lightmapTexture.animations.length > 0) {\r\n results.push(this._lightmapTexture);\r\n }\r\n if (this._refractionTexture && this._refractionTexture.animations && this._refractionTexture.animations.length > 0) {\r\n results.push(this._refractionTexture);\r\n }\r\n this.detailMap.getAnimatables(results);\r\n return results;\r\n };\r\n /**\r\n * Gets the active textures from the material\r\n * @returns an array of textures\r\n */\r\n StandardMaterial.prototype.getActiveTextures = function () {\r\n var activeTextures = _super.prototype.getActiveTextures.call(this);\r\n if (this._diffuseTexture) {\r\n activeTextures.push(this._diffuseTexture);\r\n }\r\n if (this._ambientTexture) {\r\n activeTextures.push(this._ambientTexture);\r\n }\r\n if (this._opacityTexture) {\r\n activeTextures.push(this._opacityTexture);\r\n }\r\n if (this._reflectionTexture) {\r\n activeTextures.push(this._reflectionTexture);\r\n }\r\n if (this._emissiveTexture) {\r\n activeTextures.push(this._emissiveTexture);\r\n }\r\n if (this._specularTexture) {\r\n activeTextures.push(this._specularTexture);\r\n }\r\n if (this._bumpTexture) {\r\n activeTextures.push(this._bumpTexture);\r\n }\r\n if (this._lightmapTexture) {\r\n activeTextures.push(this._lightmapTexture);\r\n }\r\n if (this._refractionTexture) {\r\n activeTextures.push(this._refractionTexture);\r\n }\r\n this.detailMap.getActiveTextures(activeTextures);\r\n return activeTextures;\r\n };\r\n /**\r\n * Specifies if the material uses a texture\r\n * @param texture defines the texture to check against the material\r\n * @returns a boolean specifying if the material uses the texture\r\n */\r\n StandardMaterial.prototype.hasTexture = function (texture) {\r\n if (_super.prototype.hasTexture.call(this, texture)) {\r\n return true;\r\n }\r\n if (this._diffuseTexture === texture) {\r\n return true;\r\n }\r\n if (this._ambientTexture === texture) {\r\n return true;\r\n }\r\n if (this._opacityTexture === texture) {\r\n return true;\r\n }\r\n if (this._reflectionTexture === texture) {\r\n return true;\r\n }\r\n if (this._emissiveTexture === texture) {\r\n return true;\r\n }\r\n if (this._specularTexture === texture) {\r\n return true;\r\n }\r\n if (this._bumpTexture === texture) {\r\n return true;\r\n }\r\n if (this._lightmapTexture === texture) {\r\n return true;\r\n }\r\n if (this._refractionTexture === texture) {\r\n return true;\r\n }\r\n return this.detailMap.hasTexture(texture);\r\n };\r\n /**\r\n * Disposes the material\r\n * @param forceDisposeEffect specifies if effects should be forcefully disposed\r\n * @param forceDisposeTextures specifies if textures should be forcefully disposed\r\n */\r\n StandardMaterial.prototype.dispose = function (forceDisposeEffect, forceDisposeTextures) {\r\n var _a, _b, _c, _d, _e, _f, _g, _h, _j;\r\n if (forceDisposeTextures) {\r\n (_a = this._diffuseTexture) === null || _a === void 0 ? void 0 : _a.dispose();\r\n (_b = this._ambientTexture) === null || _b === void 0 ? void 0 : _b.dispose();\r\n (_c = this._opacityTexture) === null || _c === void 0 ? void 0 : _c.dispose();\r\n (_d = this._reflectionTexture) === null || _d === void 0 ? void 0 : _d.dispose();\r\n (_e = this._emissiveTexture) === null || _e === void 0 ? void 0 : _e.dispose();\r\n (_f = this._specularTexture) === null || _f === void 0 ? void 0 : _f.dispose();\r\n (_g = this._bumpTexture) === null || _g === void 0 ? void 0 : _g.dispose();\r\n (_h = this._lightmapTexture) === null || _h === void 0 ? void 0 : _h.dispose();\r\n (_j = this._refractionTexture) === null || _j === void 0 ? void 0 : _j.dispose();\r\n }\r\n this.detailMap.dispose(forceDisposeTextures);\r\n if (this._imageProcessingConfiguration && this._imageProcessingObserver) {\r\n this._imageProcessingConfiguration.onUpdateParameters.remove(this._imageProcessingObserver);\r\n }\r\n _super.prototype.dispose.call(this, forceDisposeEffect, forceDisposeTextures);\r\n };\r\n /**\r\n * Makes a duplicate of the material, and gives it a new name\r\n * @param name defines the new name for the duplicated material\r\n * @returns the cloned material\r\n */\r\n StandardMaterial.prototype.clone = function (name) {\r\n var _this = this;\r\n var result = SerializationHelper.Clone(function () { return new StandardMaterial(name, _this.getScene()); }, this);\r\n result.name = name;\r\n result.id = name;\r\n return result;\r\n };\r\n /**\r\n * Serializes this material in a JSON representation\r\n * @returns the serialized material object\r\n */\r\n StandardMaterial.prototype.serialize = function () {\r\n return SerializationHelper.Serialize(this);\r\n };\r\n /**\r\n * Creates a standard material from parsed material data\r\n * @param source defines the JSON representation of the material\r\n * @param scene defines the hosting scene\r\n * @param rootUrl defines the root URL to use to load textures and relative dependencies\r\n * @returns a new standard material\r\n */\r\n StandardMaterial.Parse = function (source, scene, rootUrl) {\r\n return SerializationHelper.Parse(function () { return new StandardMaterial(source.name, scene); }, source, scene, rootUrl);\r\n };\r\n Object.defineProperty(StandardMaterial, \"DiffuseTextureEnabled\", {\r\n // Flags used to enable or disable a type of texture for all Standard Materials\r\n /**\r\n * Are diffuse textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.DiffuseTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.DiffuseTextureEnabled = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"DetailTextureEnabled\", {\r\n /**\r\n * Are detail textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.DetailTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.DetailTextureEnabled = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"AmbientTextureEnabled\", {\r\n /**\r\n * Are ambient textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.AmbientTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.AmbientTextureEnabled = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"OpacityTextureEnabled\", {\r\n /**\r\n * Are opacity textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.OpacityTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.OpacityTextureEnabled = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"ReflectionTextureEnabled\", {\r\n /**\r\n * Are reflection textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.ReflectionTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.ReflectionTextureEnabled = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"EmissiveTextureEnabled\", {\r\n /**\r\n * Are emissive textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.EmissiveTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.EmissiveTextureEnabled = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"SpecularTextureEnabled\", {\r\n /**\r\n * Are specular textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.SpecularTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.SpecularTextureEnabled = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"BumpTextureEnabled\", {\r\n /**\r\n * Are bump textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.BumpTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.BumpTextureEnabled = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"LightmapTextureEnabled\", {\r\n /**\r\n * Are lightmap textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.LightmapTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.LightmapTextureEnabled = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"RefractionTextureEnabled\", {\r\n /**\r\n * Are refraction textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.RefractionTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.RefractionTextureEnabled = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"ColorGradingTextureEnabled\", {\r\n /**\r\n * Are color grading textures enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.ColorGradingTextureEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.ColorGradingTextureEnabled = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StandardMaterial, \"FresnelEnabled\", {\r\n /**\r\n * Are fresnels enabled in the application.\r\n */\r\n get: function () {\r\n return MaterialFlags.FresnelEnabled;\r\n },\r\n set: function (value) {\r\n MaterialFlags.FresnelEnabled = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n __decorate([\r\n serializeAsTexture(\"diffuseTexture\")\r\n ], StandardMaterial.prototype, \"_diffuseTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesAndMiscDirty\")\r\n ], StandardMaterial.prototype, \"diffuseTexture\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"ambientTexture\")\r\n ], StandardMaterial.prototype, \"_ambientTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"ambientTexture\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"opacityTexture\")\r\n ], StandardMaterial.prototype, \"_opacityTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesAndMiscDirty\")\r\n ], StandardMaterial.prototype, \"opacityTexture\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"reflectionTexture\")\r\n ], StandardMaterial.prototype, \"_reflectionTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"reflectionTexture\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"emissiveTexture\")\r\n ], StandardMaterial.prototype, \"_emissiveTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"emissiveTexture\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"specularTexture\")\r\n ], StandardMaterial.prototype, \"_specularTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"specularTexture\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"bumpTexture\")\r\n ], StandardMaterial.prototype, \"_bumpTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"bumpTexture\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"lightmapTexture\")\r\n ], StandardMaterial.prototype, \"_lightmapTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"lightmapTexture\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"refractionTexture\")\r\n ], StandardMaterial.prototype, \"_refractionTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"refractionTexture\", void 0);\r\n __decorate([\r\n serializeAsColor3(\"ambient\")\r\n ], StandardMaterial.prototype, \"ambientColor\", void 0);\r\n __decorate([\r\n serializeAsColor3(\"diffuse\")\r\n ], StandardMaterial.prototype, \"diffuseColor\", void 0);\r\n __decorate([\r\n serializeAsColor3(\"specular\")\r\n ], StandardMaterial.prototype, \"specularColor\", void 0);\r\n __decorate([\r\n serializeAsColor3(\"emissive\")\r\n ], StandardMaterial.prototype, \"emissiveColor\", void 0);\r\n __decorate([\r\n serialize()\r\n ], StandardMaterial.prototype, \"specularPower\", void 0);\r\n __decorate([\r\n serialize(\"useAlphaFromDiffuseTexture\")\r\n ], StandardMaterial.prototype, \"_useAlphaFromDiffuseTexture\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesAndMiscDirty\")\r\n ], StandardMaterial.prototype, \"useAlphaFromDiffuseTexture\", void 0);\r\n __decorate([\r\n serialize(\"useEmissiveAsIllumination\")\r\n ], StandardMaterial.prototype, \"_useEmissiveAsIllumination\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useEmissiveAsIllumination\", void 0);\r\n __decorate([\r\n serialize(\"linkEmissiveWithDiffuse\")\r\n ], StandardMaterial.prototype, \"_linkEmissiveWithDiffuse\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"linkEmissiveWithDiffuse\", void 0);\r\n __decorate([\r\n serialize(\"useSpecularOverAlpha\")\r\n ], StandardMaterial.prototype, \"_useSpecularOverAlpha\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useSpecularOverAlpha\", void 0);\r\n __decorate([\r\n serialize(\"useReflectionOverAlpha\")\r\n ], StandardMaterial.prototype, \"_useReflectionOverAlpha\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useReflectionOverAlpha\", void 0);\r\n __decorate([\r\n serialize(\"disableLighting\")\r\n ], StandardMaterial.prototype, \"_disableLighting\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsLightsDirty\")\r\n ], StandardMaterial.prototype, \"disableLighting\", void 0);\r\n __decorate([\r\n serialize(\"useObjectSpaceNormalMap\")\r\n ], StandardMaterial.prototype, \"_useObjectSpaceNormalMap\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useObjectSpaceNormalMap\", void 0);\r\n __decorate([\r\n serialize(\"useParallax\")\r\n ], StandardMaterial.prototype, \"_useParallax\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useParallax\", void 0);\r\n __decorate([\r\n serialize(\"useParallaxOcclusion\")\r\n ], StandardMaterial.prototype, \"_useParallaxOcclusion\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useParallaxOcclusion\", void 0);\r\n __decorate([\r\n serialize()\r\n ], StandardMaterial.prototype, \"parallaxScaleBias\", void 0);\r\n __decorate([\r\n serialize(\"roughness\")\r\n ], StandardMaterial.prototype, \"_roughness\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"roughness\", void 0);\r\n __decorate([\r\n serialize()\r\n ], StandardMaterial.prototype, \"indexOfRefraction\", void 0);\r\n __decorate([\r\n serialize()\r\n ], StandardMaterial.prototype, \"invertRefractionY\", void 0);\r\n __decorate([\r\n serialize()\r\n ], StandardMaterial.prototype, \"alphaCutOff\", void 0);\r\n __decorate([\r\n serialize(\"useLightmapAsShadowmap\")\r\n ], StandardMaterial.prototype, \"_useLightmapAsShadowmap\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useLightmapAsShadowmap\", void 0);\r\n __decorate([\r\n serializeAsFresnelParameters(\"diffuseFresnelParameters\")\r\n ], StandardMaterial.prototype, \"_diffuseFresnelParameters\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsFresnelDirty\")\r\n ], StandardMaterial.prototype, \"diffuseFresnelParameters\", void 0);\r\n __decorate([\r\n serializeAsFresnelParameters(\"opacityFresnelParameters\")\r\n ], StandardMaterial.prototype, \"_opacityFresnelParameters\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsFresnelAndMiscDirty\")\r\n ], StandardMaterial.prototype, \"opacityFresnelParameters\", void 0);\r\n __decorate([\r\n serializeAsFresnelParameters(\"reflectionFresnelParameters\")\r\n ], StandardMaterial.prototype, \"_reflectionFresnelParameters\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsFresnelDirty\")\r\n ], StandardMaterial.prototype, \"reflectionFresnelParameters\", void 0);\r\n __decorate([\r\n serializeAsFresnelParameters(\"refractionFresnelParameters\")\r\n ], StandardMaterial.prototype, \"_refractionFresnelParameters\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsFresnelDirty\")\r\n ], StandardMaterial.prototype, \"refractionFresnelParameters\", void 0);\r\n __decorate([\r\n serializeAsFresnelParameters(\"emissiveFresnelParameters\")\r\n ], StandardMaterial.prototype, \"_emissiveFresnelParameters\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsFresnelDirty\")\r\n ], StandardMaterial.prototype, \"emissiveFresnelParameters\", void 0);\r\n __decorate([\r\n serialize(\"useReflectionFresnelFromSpecular\")\r\n ], StandardMaterial.prototype, \"_useReflectionFresnelFromSpecular\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsFresnelDirty\")\r\n ], StandardMaterial.prototype, \"useReflectionFresnelFromSpecular\", void 0);\r\n __decorate([\r\n serialize(\"useGlossinessFromSpecularMapAlpha\")\r\n ], StandardMaterial.prototype, \"_useGlossinessFromSpecularMapAlpha\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"useGlossinessFromSpecularMapAlpha\", void 0);\r\n __decorate([\r\n serialize(\"maxSimultaneousLights\")\r\n ], StandardMaterial.prototype, \"_maxSimultaneousLights\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsLightsDirty\")\r\n ], StandardMaterial.prototype, \"maxSimultaneousLights\", void 0);\r\n __decorate([\r\n serialize(\"invertNormalMapX\")\r\n ], StandardMaterial.prototype, \"_invertNormalMapX\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"invertNormalMapX\", void 0);\r\n __decorate([\r\n serialize(\"invertNormalMapY\")\r\n ], StandardMaterial.prototype, \"_invertNormalMapY\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"invertNormalMapY\", void 0);\r\n __decorate([\r\n serialize(\"twoSidedLighting\")\r\n ], StandardMaterial.prototype, \"_twoSidedLighting\", void 0);\r\n __decorate([\r\n expandToProperty(\"_markAllSubMeshesAsTexturesDirty\")\r\n ], StandardMaterial.prototype, \"twoSidedLighting\", void 0);\r\n __decorate([\r\n serialize()\r\n ], StandardMaterial.prototype, \"useLogarithmicDepth\", null);\r\n return StandardMaterial;\r\n}(PushMaterial));\r\nexport { StandardMaterial };\r\n_TypeStore.RegisteredTypes[\"BABYLON.StandardMaterial\"] = StandardMaterial;\r\nScene.DefaultMaterialFactory = function (scene) {\r\n return new StandardMaterial(\"default material\", scene);\r\n};\r\n//# sourceMappingURL=standardMaterial.js.map","import { Vector3, Matrix } from './math.vector';\r\n/**\r\n * Represents a plane by the equation ax + by + cz + d = 0\r\n */\r\nvar Plane = /** @class */ (function () {\r\n /**\r\n * Creates a Plane object according to the given floats a, b, c, d and the plane equation : ax + by + cz + d = 0\r\n * @param a a component of the plane\r\n * @param b b component of the plane\r\n * @param c c component of the plane\r\n * @param d d component of the plane\r\n */\r\n function Plane(a, b, c, d) {\r\n this.normal = new Vector3(a, b, c);\r\n this.d = d;\r\n }\r\n /**\r\n * @returns the plane coordinates as a new array of 4 elements [a, b, c, d].\r\n */\r\n Plane.prototype.asArray = function () {\r\n return [this.normal.x, this.normal.y, this.normal.z, this.d];\r\n };\r\n // Methods\r\n /**\r\n * @returns a new plane copied from the current Plane.\r\n */\r\n Plane.prototype.clone = function () {\r\n return new Plane(this.normal.x, this.normal.y, this.normal.z, this.d);\r\n };\r\n /**\r\n * @returns the string \"Plane\".\r\n */\r\n Plane.prototype.getClassName = function () {\r\n return \"Plane\";\r\n };\r\n /**\r\n * @returns the Plane hash code.\r\n */\r\n Plane.prototype.getHashCode = function () {\r\n var hash = this.normal.getHashCode();\r\n hash = (hash * 397) ^ (this.d | 0);\r\n return hash;\r\n };\r\n /**\r\n * Normalize the current Plane in place.\r\n * @returns the updated Plane.\r\n */\r\n Plane.prototype.normalize = function () {\r\n var norm = (Math.sqrt((this.normal.x * this.normal.x) + (this.normal.y * this.normal.y) + (this.normal.z * this.normal.z)));\r\n var magnitude = 0.0;\r\n if (norm !== 0) {\r\n magnitude = 1.0 / norm;\r\n }\r\n this.normal.x *= magnitude;\r\n this.normal.y *= magnitude;\r\n this.normal.z *= magnitude;\r\n this.d *= magnitude;\r\n return this;\r\n };\r\n /**\r\n * Applies a transformation the plane and returns the result\r\n * @param transformation the transformation matrix to be applied to the plane\r\n * @returns a new Plane as the result of the transformation of the current Plane by the given matrix.\r\n */\r\n Plane.prototype.transform = function (transformation) {\r\n var invertedMatrix = Plane._TmpMatrix;\r\n transformation.invertToRef(invertedMatrix);\r\n var m = invertedMatrix.m;\r\n var x = this.normal.x;\r\n var y = this.normal.y;\r\n var z = this.normal.z;\r\n var d = this.d;\r\n var normalX = x * m[0] + y * m[1] + z * m[2] + d * m[3];\r\n var normalY = x * m[4] + y * m[5] + z * m[6] + d * m[7];\r\n var normalZ = x * m[8] + y * m[9] + z * m[10] + d * m[11];\r\n var finalD = x * m[12] + y * m[13] + z * m[14] + d * m[15];\r\n return new Plane(normalX, normalY, normalZ, finalD);\r\n };\r\n /**\r\n * Compute the dot product between the point and the plane normal\r\n * @param point point to calculate the dot product with\r\n * @returns the dot product (float) of the point coordinates and the plane normal.\r\n */\r\n Plane.prototype.dotCoordinate = function (point) {\r\n return ((((this.normal.x * point.x) + (this.normal.y * point.y)) + (this.normal.z * point.z)) + this.d);\r\n };\r\n /**\r\n * Updates the current Plane from the plane defined by the three given points.\r\n * @param point1 one of the points used to contruct the plane\r\n * @param point2 one of the points used to contruct the plane\r\n * @param point3 one of the points used to contruct the plane\r\n * @returns the updated Plane.\r\n */\r\n Plane.prototype.copyFromPoints = function (point1, point2, point3) {\r\n var x1 = point2.x - point1.x;\r\n var y1 = point2.y - point1.y;\r\n var z1 = point2.z - point1.z;\r\n var x2 = point3.x - point1.x;\r\n var y2 = point3.y - point1.y;\r\n var z2 = point3.z - point1.z;\r\n var yz = (y1 * z2) - (z1 * y2);\r\n var xz = (z1 * x2) - (x1 * z2);\r\n var xy = (x1 * y2) - (y1 * x2);\r\n var pyth = (Math.sqrt((yz * yz) + (xz * xz) + (xy * xy)));\r\n var invPyth;\r\n if (pyth !== 0) {\r\n invPyth = 1.0 / pyth;\r\n }\r\n else {\r\n invPyth = 0.0;\r\n }\r\n this.normal.x = yz * invPyth;\r\n this.normal.y = xz * invPyth;\r\n this.normal.z = xy * invPyth;\r\n this.d = -((this.normal.x * point1.x) + (this.normal.y * point1.y) + (this.normal.z * point1.z));\r\n return this;\r\n };\r\n /**\r\n * Checks if the plane is facing a given direction (meaning if the plane's normal is pointing in the opposite direction of the given vector).\r\n * Note that for this function to work as expected you should make sure that:\r\n * - direction and the plane normal are normalized\r\n * - epsilon is a number just bigger than -1, something like -0.99 for eg\r\n * @param direction the direction to check if the plane is facing\r\n * @param epsilon value the dot product is compared against (returns true if dot <= epsilon)\r\n * @returns True if the plane is facing the given direction\r\n */\r\n Plane.prototype.isFrontFacingTo = function (direction, epsilon) {\r\n var dot = Vector3.Dot(this.normal, direction);\r\n return (dot <= epsilon);\r\n };\r\n /**\r\n * Calculates the distance to a point\r\n * @param point point to calculate distance to\r\n * @returns the signed distance (float) from the given point to the Plane.\r\n */\r\n Plane.prototype.signedDistanceTo = function (point) {\r\n return Vector3.Dot(point, this.normal) + this.d;\r\n };\r\n // Statics\r\n /**\r\n * Creates a plane from an array\r\n * @param array the array to create a plane from\r\n * @returns a new Plane from the given array.\r\n */\r\n Plane.FromArray = function (array) {\r\n return new Plane(array[0], array[1], array[2], array[3]);\r\n };\r\n /**\r\n * Creates a plane from three points\r\n * @param point1 point used to create the plane\r\n * @param point2 point used to create the plane\r\n * @param point3 point used to create the plane\r\n * @returns a new Plane defined by the three given points.\r\n */\r\n Plane.FromPoints = function (point1, point2, point3) {\r\n var result = new Plane(0.0, 0.0, 0.0, 0.0);\r\n result.copyFromPoints(point1, point2, point3);\r\n return result;\r\n };\r\n /**\r\n * Creates a plane from an origin point and a normal\r\n * @param origin origin of the plane to be constructed\r\n * @param normal normal of the plane to be constructed\r\n * @returns a new Plane the normal vector to this plane at the given origin point.\r\n * Note : the vector \"normal\" is updated because normalized.\r\n */\r\n Plane.FromPositionAndNormal = function (origin, normal) {\r\n var result = new Plane(0.0, 0.0, 0.0, 0.0);\r\n normal.normalize();\r\n result.normal = normal;\r\n result.d = -(normal.x * origin.x + normal.y * origin.y + normal.z * origin.z);\r\n return result;\r\n };\r\n /**\r\n * Calculates the distance from a plane and a point\r\n * @param origin origin of the plane to be constructed\r\n * @param normal normal of the plane to be constructed\r\n * @param point point to calculate distance to\r\n * @returns the signed distance between the plane defined by the normal vector at the \"origin\"\" point and the given other point.\r\n */\r\n Plane.SignedDistanceToPlaneFromPositionAndNormal = function (origin, normal, point) {\r\n var d = -(normal.x * origin.x + normal.y * origin.y + normal.z * origin.z);\r\n return Vector3.Dot(point, normal) + d;\r\n };\r\n Plane._TmpMatrix = Matrix.Identity();\r\n return Plane;\r\n}());\r\nexport { Plane };\r\n//# sourceMappingURL=math.plane.js.map","import { Plane } from './math.plane';\r\n/**\r\n * Represents a camera frustum\r\n */\r\nvar Frustum = /** @class */ (function () {\r\n function Frustum() {\r\n }\r\n /**\r\n * Gets the planes representing the frustum\r\n * @param transform matrix to be applied to the returned planes\r\n * @returns a new array of 6 Frustum planes computed by the given transformation matrix.\r\n */\r\n Frustum.GetPlanes = function (transform) {\r\n var frustumPlanes = [];\r\n for (var index = 0; index < 6; index++) {\r\n frustumPlanes.push(new Plane(0.0, 0.0, 0.0, 0.0));\r\n }\r\n Frustum.GetPlanesToRef(transform, frustumPlanes);\r\n return frustumPlanes;\r\n };\r\n /**\r\n * Gets the near frustum plane transformed by the transform matrix\r\n * @param transform transformation matrix to be applied to the resulting frustum plane\r\n * @param frustumPlane the resuling frustum plane\r\n */\r\n Frustum.GetNearPlaneToRef = function (transform, frustumPlane) {\r\n var m = transform.m;\r\n frustumPlane.normal.x = m[3] + m[2];\r\n frustumPlane.normal.y = m[7] + m[6];\r\n frustumPlane.normal.z = m[11] + m[10];\r\n frustumPlane.d = m[15] + m[14];\r\n frustumPlane.normalize();\r\n };\r\n /**\r\n * Gets the far frustum plane transformed by the transform matrix\r\n * @param transform transformation matrix to be applied to the resulting frustum plane\r\n * @param frustumPlane the resuling frustum plane\r\n */\r\n Frustum.GetFarPlaneToRef = function (transform, frustumPlane) {\r\n var m = transform.m;\r\n frustumPlane.normal.x = m[3] - m[2];\r\n frustumPlane.normal.y = m[7] - m[6];\r\n frustumPlane.normal.z = m[11] - m[10];\r\n frustumPlane.d = m[15] - m[14];\r\n frustumPlane.normalize();\r\n };\r\n /**\r\n * Gets the left frustum plane transformed by the transform matrix\r\n * @param transform transformation matrix to be applied to the resulting frustum plane\r\n * @param frustumPlane the resuling frustum plane\r\n */\r\n Frustum.GetLeftPlaneToRef = function (transform, frustumPlane) {\r\n var m = transform.m;\r\n frustumPlane.normal.x = m[3] + m[0];\r\n frustumPlane.normal.y = m[7] + m[4];\r\n frustumPlane.normal.z = m[11] + m[8];\r\n frustumPlane.d = m[15] + m[12];\r\n frustumPlane.normalize();\r\n };\r\n /**\r\n * Gets the right frustum plane transformed by the transform matrix\r\n * @param transform transformation matrix to be applied to the resulting frustum plane\r\n * @param frustumPlane the resuling frustum plane\r\n */\r\n Frustum.GetRightPlaneToRef = function (transform, frustumPlane) {\r\n var m = transform.m;\r\n frustumPlane.normal.x = m[3] - m[0];\r\n frustumPlane.normal.y = m[7] - m[4];\r\n frustumPlane.normal.z = m[11] - m[8];\r\n frustumPlane.d = m[15] - m[12];\r\n frustumPlane.normalize();\r\n };\r\n /**\r\n * Gets the top frustum plane transformed by the transform matrix\r\n * @param transform transformation matrix to be applied to the resulting frustum plane\r\n * @param frustumPlane the resuling frustum plane\r\n */\r\n Frustum.GetTopPlaneToRef = function (transform, frustumPlane) {\r\n var m = transform.m;\r\n frustumPlane.normal.x = m[3] - m[1];\r\n frustumPlane.normal.y = m[7] - m[5];\r\n frustumPlane.normal.z = m[11] - m[9];\r\n frustumPlane.d = m[15] - m[13];\r\n frustumPlane.normalize();\r\n };\r\n /**\r\n * Gets the bottom frustum plane transformed by the transform matrix\r\n * @param transform transformation matrix to be applied to the resulting frustum plane\r\n * @param frustumPlane the resuling frustum plane\r\n */\r\n Frustum.GetBottomPlaneToRef = function (transform, frustumPlane) {\r\n var m = transform.m;\r\n frustumPlane.normal.x = m[3] + m[1];\r\n frustumPlane.normal.y = m[7] + m[5];\r\n frustumPlane.normal.z = m[11] + m[9];\r\n frustumPlane.d = m[15] + m[13];\r\n frustumPlane.normalize();\r\n };\r\n /**\r\n * Sets the given array \"frustumPlanes\" with the 6 Frustum planes computed by the given transformation matrix.\r\n * @param transform transformation matrix to be applied to the resulting frustum planes\r\n * @param frustumPlanes the resuling frustum planes\r\n */\r\n Frustum.GetPlanesToRef = function (transform, frustumPlanes) {\r\n // Near\r\n Frustum.GetNearPlaneToRef(transform, frustumPlanes[0]);\r\n // Far\r\n Frustum.GetFarPlaneToRef(transform, frustumPlanes[1]);\r\n // Left\r\n Frustum.GetLeftPlaneToRef(transform, frustumPlanes[2]);\r\n // Right\r\n Frustum.GetRightPlaneToRef(transform, frustumPlanes[3]);\r\n // Top\r\n Frustum.GetTopPlaneToRef(transform, frustumPlanes[4]);\r\n // Bottom\r\n Frustum.GetBottomPlaneToRef(transform, frustumPlanes[5]);\r\n };\r\n return Frustum;\r\n}());\r\nexport { Frustum };\r\n//# sourceMappingURL=math.frustum.js.map","/**\r\n * Size containing widht and height\r\n */\r\nvar Size = /** @class */ (function () {\r\n /**\r\n * Creates a Size object from the given width and height (floats).\r\n * @param width width of the new size\r\n * @param height height of the new size\r\n */\r\n function Size(width, height) {\r\n this.width = width;\r\n this.height = height;\r\n }\r\n /**\r\n * Returns a string with the Size width and height\r\n * @returns a string with the Size width and height\r\n */\r\n Size.prototype.toString = function () {\r\n return \"{W: \" + this.width + \", H: \" + this.height + \"}\";\r\n };\r\n /**\r\n * \"Size\"\r\n * @returns the string \"Size\"\r\n */\r\n Size.prototype.getClassName = function () {\r\n return \"Size\";\r\n };\r\n /**\r\n * Returns the Size hash code.\r\n * @returns a hash code for a unique width and height\r\n */\r\n Size.prototype.getHashCode = function () {\r\n var hash = this.width | 0;\r\n hash = (hash * 397) ^ (this.height | 0);\r\n return hash;\r\n };\r\n /**\r\n * Updates the current size from the given one.\r\n * @param src the given size\r\n */\r\n Size.prototype.copyFrom = function (src) {\r\n this.width = src.width;\r\n this.height = src.height;\r\n };\r\n /**\r\n * Updates in place the current Size from the given floats.\r\n * @param width width of the new size\r\n * @param height height of the new size\r\n * @returns the updated Size.\r\n */\r\n Size.prototype.copyFromFloats = function (width, height) {\r\n this.width = width;\r\n this.height = height;\r\n return this;\r\n };\r\n /**\r\n * Updates in place the current Size from the given floats.\r\n * @param width width to set\r\n * @param height height to set\r\n * @returns the updated Size.\r\n */\r\n Size.prototype.set = function (width, height) {\r\n return this.copyFromFloats(width, height);\r\n };\r\n /**\r\n * Multiplies the width and height by numbers\r\n * @param w factor to multiple the width by\r\n * @param h factor to multiple the height by\r\n * @returns a new Size set with the multiplication result of the current Size and the given floats.\r\n */\r\n Size.prototype.multiplyByFloats = function (w, h) {\r\n return new Size(this.width * w, this.height * h);\r\n };\r\n /**\r\n * Clones the size\r\n * @returns a new Size copied from the given one.\r\n */\r\n Size.prototype.clone = function () {\r\n return new Size(this.width, this.height);\r\n };\r\n /**\r\n * True if the current Size and the given one width and height are strictly equal.\r\n * @param other the other size to compare against\r\n * @returns True if the current Size and the given one width and height are strictly equal.\r\n */\r\n Size.prototype.equals = function (other) {\r\n if (!other) {\r\n return false;\r\n }\r\n return (this.width === other.width) && (this.height === other.height);\r\n };\r\n Object.defineProperty(Size.prototype, \"surface\", {\r\n /**\r\n * The surface of the Size : width * height (float).\r\n */\r\n get: function () {\r\n return this.width * this.height;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Create a new size of zero\r\n * @returns a new Size set to (0.0, 0.0)\r\n */\r\n Size.Zero = function () {\r\n return new Size(0.0, 0.0);\r\n };\r\n /**\r\n * Sums the width and height of two sizes\r\n * @param otherSize size to add to this size\r\n * @returns a new Size set as the addition result of the current Size and the given one.\r\n */\r\n Size.prototype.add = function (otherSize) {\r\n var r = new Size(this.width + otherSize.width, this.height + otherSize.height);\r\n return r;\r\n };\r\n /**\r\n * Subtracts the width and height of two\r\n * @param otherSize size to subtract to this size\r\n * @returns a new Size set as the subtraction result of the given one from the current Size.\r\n */\r\n Size.prototype.subtract = function (otherSize) {\r\n var r = new Size(this.width - otherSize.width, this.height - otherSize.height);\r\n return r;\r\n };\r\n /**\r\n * Creates a new Size set at the linear interpolation \"amount\" between \"start\" and \"end\"\r\n * @param start starting size to lerp between\r\n * @param end end size to lerp between\r\n * @param amount amount to lerp between the start and end values\r\n * @returns a new Size set at the linear interpolation \"amount\" between \"start\" and \"end\"\r\n */\r\n Size.Lerp = function (start, end, amount) {\r\n var w = start.width + ((end.width - start.width) * amount);\r\n var h = start.height + ((end.height - start.height) * amount);\r\n return new Size(w, h);\r\n };\r\n return Size;\r\n}());\r\nexport { Size };\r\n//# sourceMappingURL=math.size.js.map","/**\r\n * Helper class used to generate a canvas to manipulate images\r\n */\r\nvar CanvasGenerator = /** @class */ (function () {\r\n function CanvasGenerator() {\r\n }\r\n /**\r\n * Create a new canvas (or offscreen canvas depending on the context)\r\n * @param width defines the expected width\r\n * @param height defines the expected height\r\n * @return a new canvas or offscreen canvas\r\n */\r\n CanvasGenerator.CreateCanvas = function (width, height) {\r\n if (typeof document === \"undefined\") {\r\n return new OffscreenCanvas(width, height);\r\n }\r\n var canvas = document.createElement(\"canvas\");\r\n canvas.width = width;\r\n canvas.height = height;\r\n return canvas;\r\n };\r\n return CanvasGenerator;\r\n}());\r\nexport { CanvasGenerator };\r\n//# sourceMappingURL=canvasGenerator.js.map","import { __extends } from \"tslib\";\r\nimport { DataBuffer } from '../dataBuffer';\r\n/** @hidden */\r\nvar WebGLDataBuffer = /** @class */ (function (_super) {\r\n __extends(WebGLDataBuffer, _super);\r\n function WebGLDataBuffer(resource) {\r\n var _this = _super.call(this) || this;\r\n _this._buffer = resource;\r\n return _this;\r\n }\r\n Object.defineProperty(WebGLDataBuffer.prototype, \"underlyingResource\", {\r\n get: function () {\r\n return this._buffer;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n return WebGLDataBuffer;\r\n}(DataBuffer));\r\nexport { WebGLDataBuffer };\r\n//# sourceMappingURL=webGLDataBuffer.js.map","/**\r\n * Class used to store gfx data (like WebGLBuffer)\r\n */\r\nvar DataBuffer = /** @class */ (function () {\r\n function DataBuffer() {\r\n /**\r\n * Gets or sets the number of objects referencing this buffer\r\n */\r\n this.references = 0;\r\n /** Gets or sets the size of the underlying buffer */\r\n this.capacity = 0;\r\n /**\r\n * Gets or sets a boolean indicating if the buffer contains 32bits indices\r\n */\r\n this.is32Bits = false;\r\n }\r\n Object.defineProperty(DataBuffer.prototype, \"underlyingResource\", {\r\n /**\r\n * Gets the underlying buffer\r\n */\r\n get: function () {\r\n return null;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n return DataBuffer;\r\n}());\r\nexport { DataBuffer };\r\n//# sourceMappingURL=dataBuffer.js.map","import { Vector3, Vector2 } from './math.vector';\r\n/**\r\n * Contains position and normal vectors for a vertex\r\n */\r\nvar PositionNormalVertex = /** @class */ (function () {\r\n /**\r\n * Creates a PositionNormalVertex\r\n * @param position the position of the vertex (defaut: 0,0,0)\r\n * @param normal the normal of the vertex (defaut: 0,1,0)\r\n */\r\n function PositionNormalVertex(\r\n /** the position of the vertex (defaut: 0,0,0) */\r\n position, \r\n /** the normal of the vertex (defaut: 0,1,0) */\r\n normal) {\r\n if (position === void 0) { position = Vector3.Zero(); }\r\n if (normal === void 0) { normal = Vector3.Up(); }\r\n this.position = position;\r\n this.normal = normal;\r\n }\r\n /**\r\n * Clones the PositionNormalVertex\r\n * @returns the cloned PositionNormalVertex\r\n */\r\n PositionNormalVertex.prototype.clone = function () {\r\n return new PositionNormalVertex(this.position.clone(), this.normal.clone());\r\n };\r\n return PositionNormalVertex;\r\n}());\r\nexport { PositionNormalVertex };\r\n/**\r\n * Contains position, normal and uv vectors for a vertex\r\n */\r\nvar PositionNormalTextureVertex = /** @class */ (function () {\r\n /**\r\n * Creates a PositionNormalTextureVertex\r\n * @param position the position of the vertex (defaut: 0,0,0)\r\n * @param normal the normal of the vertex (defaut: 0,1,0)\r\n * @param uv the uv of the vertex (default: 0,0)\r\n */\r\n function PositionNormalTextureVertex(\r\n /** the position of the vertex (defaut: 0,0,0) */\r\n position, \r\n /** the normal of the vertex (defaut: 0,1,0) */\r\n normal, \r\n /** the uv of the vertex (default: 0,0) */\r\n uv) {\r\n if (position === void 0) { position = Vector3.Zero(); }\r\n if (normal === void 0) { normal = Vector3.Up(); }\r\n if (uv === void 0) { uv = Vector2.Zero(); }\r\n this.position = position;\r\n this.normal = normal;\r\n this.uv = uv;\r\n }\r\n /**\r\n * Clones the PositionNormalTextureVertex\r\n * @returns the cloned PositionNormalTextureVertex\r\n */\r\n PositionNormalTextureVertex.prototype.clone = function () {\r\n return new PositionNormalTextureVertex(this.position.clone(), this.normal.clone(), this.uv.clone());\r\n };\r\n return PositionNormalTextureVertex;\r\n}());\r\nexport { PositionNormalTextureVertex };\r\n//# sourceMappingURL=math.vertexFormat.js.map","/**\r\n * Class used to represent a viewport on screen\r\n */\r\nvar Viewport = /** @class */ (function () {\r\n /**\r\n * Creates a Viewport object located at (x, y) and sized (width, height)\r\n * @param x defines viewport left coordinate\r\n * @param y defines viewport top coordinate\r\n * @param width defines the viewport width\r\n * @param height defines the viewport height\r\n */\r\n function Viewport(\r\n /** viewport left coordinate */\r\n x, \r\n /** viewport top coordinate */\r\n y, \r\n /**viewport width */\r\n width, \r\n /** viewport height */\r\n height) {\r\n this.x = x;\r\n this.y = y;\r\n this.width = width;\r\n this.height = height;\r\n }\r\n /**\r\n * Creates a new viewport using absolute sizing (from 0-> width, 0-> height instead of 0->1)\r\n * @param renderWidth defines the rendering width\r\n * @param renderHeight defines the rendering height\r\n * @returns a new Viewport\r\n */\r\n Viewport.prototype.toGlobal = function (renderWidth, renderHeight) {\r\n return new Viewport(this.x * renderWidth, this.y * renderHeight, this.width * renderWidth, this.height * renderHeight);\r\n };\r\n /**\r\n * Stores absolute viewport value into a target viewport (from 0-> width, 0-> height instead of 0->1)\r\n * @param renderWidth defines the rendering width\r\n * @param renderHeight defines the rendering height\r\n * @param ref defines the target viewport\r\n * @returns the current viewport\r\n */\r\n Viewport.prototype.toGlobalToRef = function (renderWidth, renderHeight, ref) {\r\n ref.x = this.x * renderWidth;\r\n ref.y = this.y * renderHeight;\r\n ref.width = this.width * renderWidth;\r\n ref.height = this.height * renderHeight;\r\n return this;\r\n };\r\n /**\r\n * Returns a new Viewport copied from the current one\r\n * @returns a new Viewport\r\n */\r\n Viewport.prototype.clone = function () {\r\n return new Viewport(this.x, this.y, this.width, this.height);\r\n };\r\n return Viewport;\r\n}());\r\nexport { Viewport };\r\n//# sourceMappingURL=math.viewport.js.map","import { PrecisionDate } from './precisionDate';\r\n/**\r\n * This class is used to track a performance counter which is number based.\r\n * The user has access to many properties which give statistics of different nature.\r\n *\r\n * The implementer can track two kinds of Performance Counter: time and count.\r\n * For time you can optionally call fetchNewFrame() to notify the start of a new frame to monitor, then call beginMonitoring() to start and endMonitoring() to record the lapsed time. endMonitoring takes a newFrame parameter for you to specify if the monitored time should be set for a new frame or accumulated to the current frame being monitored.\r\n * For count you first have to call fetchNewFrame() to notify the start of a new frame to monitor, then call addCount() how many time required to increment the count value you monitor.\r\n */\r\nvar PerfCounter = /** @class */ (function () {\r\n /**\r\n * Creates a new counter\r\n */\r\n function PerfCounter() {\r\n this._startMonitoringTime = 0;\r\n this._min = 0;\r\n this._max = 0;\r\n this._average = 0;\r\n this._lastSecAverage = 0;\r\n this._current = 0;\r\n this._totalValueCount = 0;\r\n this._totalAccumulated = 0;\r\n this._lastSecAccumulated = 0;\r\n this._lastSecTime = 0;\r\n this._lastSecValueCount = 0;\r\n }\r\n Object.defineProperty(PerfCounter.prototype, \"min\", {\r\n /**\r\n * Returns the smallest value ever\r\n */\r\n get: function () {\r\n return this._min;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerfCounter.prototype, \"max\", {\r\n /**\r\n * Returns the biggest value ever\r\n */\r\n get: function () {\r\n return this._max;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerfCounter.prototype, \"average\", {\r\n /**\r\n * Returns the average value since the performance counter is running\r\n */\r\n get: function () {\r\n return this._average;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerfCounter.prototype, \"lastSecAverage\", {\r\n /**\r\n * Returns the average value of the last second the counter was monitored\r\n */\r\n get: function () {\r\n return this._lastSecAverage;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerfCounter.prototype, \"current\", {\r\n /**\r\n * Returns the current value\r\n */\r\n get: function () {\r\n return this._current;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerfCounter.prototype, \"total\", {\r\n /**\r\n * Gets the accumulated total\r\n */\r\n get: function () {\r\n return this._totalAccumulated;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PerfCounter.prototype, \"count\", {\r\n /**\r\n * Gets the total value count\r\n */\r\n get: function () {\r\n return this._totalValueCount;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Call this method to start monitoring a new frame.\r\n * This scenario is typically used when you accumulate monitoring time many times for a single frame, you call this method at the start of the frame, then beginMonitoring to start recording and endMonitoring(false) to accumulated the recorded time to the PerfCounter or addCount() to accumulate a monitored count.\r\n */\r\n PerfCounter.prototype.fetchNewFrame = function () {\r\n this._totalValueCount++;\r\n this._current = 0;\r\n this._lastSecValueCount++;\r\n };\r\n /**\r\n * Call this method to monitor a count of something (e.g. mesh drawn in viewport count)\r\n * @param newCount the count value to add to the monitored count\r\n * @param fetchResult true when it's the last time in the frame you add to the counter and you wish to update the statistics properties (min/max/average), false if you only want to update statistics.\r\n */\r\n PerfCounter.prototype.addCount = function (newCount, fetchResult) {\r\n if (!PerfCounter.Enabled) {\r\n return;\r\n }\r\n this._current += newCount;\r\n if (fetchResult) {\r\n this._fetchResult();\r\n }\r\n };\r\n /**\r\n * Start monitoring this performance counter\r\n */\r\n PerfCounter.prototype.beginMonitoring = function () {\r\n if (!PerfCounter.Enabled) {\r\n return;\r\n }\r\n this._startMonitoringTime = PrecisionDate.Now;\r\n };\r\n /**\r\n * Compute the time lapsed since the previous beginMonitoring() call.\r\n * @param newFrame true by default to fetch the result and monitor a new frame, if false the time monitored will be added to the current frame counter\r\n */\r\n PerfCounter.prototype.endMonitoring = function (newFrame) {\r\n if (newFrame === void 0) { newFrame = true; }\r\n if (!PerfCounter.Enabled) {\r\n return;\r\n }\r\n if (newFrame) {\r\n this.fetchNewFrame();\r\n }\r\n var currentTime = PrecisionDate.Now;\r\n this._current = currentTime - this._startMonitoringTime;\r\n if (newFrame) {\r\n this._fetchResult();\r\n }\r\n };\r\n PerfCounter.prototype._fetchResult = function () {\r\n this._totalAccumulated += this._current;\r\n this._lastSecAccumulated += this._current;\r\n // Min/Max update\r\n this._min = Math.min(this._min, this._current);\r\n this._max = Math.max(this._max, this._current);\r\n this._average = this._totalAccumulated / this._totalValueCount;\r\n // Reset last sec?\r\n var now = PrecisionDate.Now;\r\n if ((now - this._lastSecTime) > 1000) {\r\n this._lastSecAverage = this._lastSecAccumulated / this._lastSecValueCount;\r\n this._lastSecTime = now;\r\n this._lastSecAccumulated = 0;\r\n this._lastSecValueCount = 0;\r\n }\r\n };\r\n /**\r\n * Gets or sets a global boolean to turn on and off all the counters\r\n */\r\n PerfCounter.Enabled = true;\r\n return PerfCounter;\r\n}());\r\nexport { PerfCounter };\r\n//# sourceMappingURL=perfCounter.js.map","import { __decorate } from \"tslib\";\r\nimport { SerializationHelper, serialize } from \"../Misc/decorators\";\r\nimport { Color4 } from '../Maths/math.color';\r\n/**\r\n * The color grading curves provide additional color adjustmnent that is applied after any color grading transform (3D LUT).\r\n * They allow basic adjustment of saturation and small exposure adjustments, along with color filter tinting to provide white balance adjustment or more stylistic effects.\r\n * These are similar to controls found in many professional imaging or colorist software. The global controls are applied to the entire image. For advanced tuning, extra controls are provided to adjust the shadow, midtone and highlight areas of the image;\r\n * corresponding to low luminance, medium luminance, and high luminance areas respectively.\r\n */\r\nvar ColorCurves = /** @class */ (function () {\r\n function ColorCurves() {\r\n this._dirty = true;\r\n this._tempColor = new Color4(0, 0, 0, 0);\r\n this._globalCurve = new Color4(0, 0, 0, 0);\r\n this._highlightsCurve = new Color4(0, 0, 0, 0);\r\n this._midtonesCurve = new Color4(0, 0, 0, 0);\r\n this._shadowsCurve = new Color4(0, 0, 0, 0);\r\n this._positiveCurve = new Color4(0, 0, 0, 0);\r\n this._negativeCurve = new Color4(0, 0, 0, 0);\r\n this._globalHue = 30;\r\n this._globalDensity = 0;\r\n this._globalSaturation = 0;\r\n this._globalExposure = 0;\r\n this._highlightsHue = 30;\r\n this._highlightsDensity = 0;\r\n this._highlightsSaturation = 0;\r\n this._highlightsExposure = 0;\r\n this._midtonesHue = 30;\r\n this._midtonesDensity = 0;\r\n this._midtonesSaturation = 0;\r\n this._midtonesExposure = 0;\r\n this._shadowsHue = 30;\r\n this._shadowsDensity = 0;\r\n this._shadowsSaturation = 0;\r\n this._shadowsExposure = 0;\r\n }\r\n Object.defineProperty(ColorCurves.prototype, \"globalHue\", {\r\n /**\r\n * Gets the global Hue value.\r\n * The hue value is a standard HSB hue in the range [0,360] where 0=red, 120=green and 240=blue. The default value is 30 degrees (orange).\r\n */\r\n get: function () {\r\n return this._globalHue;\r\n },\r\n /**\r\n * Sets the global Hue value.\r\n * The hue value is a standard HSB hue in the range [0,360] where 0=red, 120=green and 240=blue. The default value is 30 degrees (orange).\r\n */\r\n set: function (value) {\r\n this._globalHue = value;\r\n this._dirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"globalDensity\", {\r\n /**\r\n * Gets the global Density value.\r\n * The density value is in range [-100,+100] where 0 means the color filter has no effect and +100 means the color filter has maximum effect.\r\n * Values less than zero provide a filter of opposite hue.\r\n */\r\n get: function () {\r\n return this._globalDensity;\r\n },\r\n /**\r\n * Sets the global Density value.\r\n * The density value is in range [-100,+100] where 0 means the color filter has no effect and +100 means the color filter has maximum effect.\r\n * Values less than zero provide a filter of opposite hue.\r\n */\r\n set: function (value) {\r\n this._globalDensity = value;\r\n this._dirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"globalSaturation\", {\r\n /**\r\n * Gets the global Saturation value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase saturation and negative values decrease saturation.\r\n */\r\n get: function () {\r\n return this._globalSaturation;\r\n },\r\n /**\r\n * Sets the global Saturation value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase saturation and negative values decrease saturation.\r\n */\r\n set: function (value) {\r\n this._globalSaturation = value;\r\n this._dirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"globalExposure\", {\r\n /**\r\n * Gets the global Exposure value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase exposure and negative values decrease exposure.\r\n */\r\n get: function () {\r\n return this._globalExposure;\r\n },\r\n /**\r\n * Sets the global Exposure value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase exposure and negative values decrease exposure.\r\n */\r\n set: function (value) {\r\n this._globalExposure = value;\r\n this._dirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"highlightsHue\", {\r\n /**\r\n * Gets the highlights Hue value.\r\n * The hue value is a standard HSB hue in the range [0,360] where 0=red, 120=green and 240=blue. The default value is 30 degrees (orange).\r\n */\r\n get: function () {\r\n return this._highlightsHue;\r\n },\r\n /**\r\n * Sets the highlights Hue value.\r\n * The hue value is a standard HSB hue in the range [0,360] where 0=red, 120=green and 240=blue. The default value is 30 degrees (orange).\r\n */\r\n set: function (value) {\r\n this._highlightsHue = value;\r\n this._dirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"highlightsDensity\", {\r\n /**\r\n * Gets the highlights Density value.\r\n * The density value is in range [-100,+100] where 0 means the color filter has no effect and +100 means the color filter has maximum effect.\r\n * Values less than zero provide a filter of opposite hue.\r\n */\r\n get: function () {\r\n return this._highlightsDensity;\r\n },\r\n /**\r\n * Sets the highlights Density value.\r\n * The density value is in range [-100,+100] where 0 means the color filter has no effect and +100 means the color filter has maximum effect.\r\n * Values less than zero provide a filter of opposite hue.\r\n */\r\n set: function (value) {\r\n this._highlightsDensity = value;\r\n this._dirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"highlightsSaturation\", {\r\n /**\r\n * Gets the highlights Saturation value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase saturation and negative values decrease saturation.\r\n */\r\n get: function () {\r\n return this._highlightsSaturation;\r\n },\r\n /**\r\n * Sets the highlights Saturation value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase saturation and negative values decrease saturation.\r\n */\r\n set: function (value) {\r\n this._highlightsSaturation = value;\r\n this._dirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"highlightsExposure\", {\r\n /**\r\n * Gets the highlights Exposure value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase exposure and negative values decrease exposure.\r\n */\r\n get: function () {\r\n return this._highlightsExposure;\r\n },\r\n /**\r\n * Sets the highlights Exposure value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase exposure and negative values decrease exposure.\r\n */\r\n set: function (value) {\r\n this._highlightsExposure = value;\r\n this._dirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"midtonesHue\", {\r\n /**\r\n * Gets the midtones Hue value.\r\n * The hue value is a standard HSB hue in the range [0,360] where 0=red, 120=green and 240=blue. The default value is 30 degrees (orange).\r\n */\r\n get: function () {\r\n return this._midtonesHue;\r\n },\r\n /**\r\n * Sets the midtones Hue value.\r\n * The hue value is a standard HSB hue in the range [0,360] where 0=red, 120=green and 240=blue. The default value is 30 degrees (orange).\r\n */\r\n set: function (value) {\r\n this._midtonesHue = value;\r\n this._dirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"midtonesDensity\", {\r\n /**\r\n * Gets the midtones Density value.\r\n * The density value is in range [-100,+100] where 0 means the color filter has no effect and +100 means the color filter has maximum effect.\r\n * Values less than zero provide a filter of opposite hue.\r\n */\r\n get: function () {\r\n return this._midtonesDensity;\r\n },\r\n /**\r\n * Sets the midtones Density value.\r\n * The density value is in range [-100,+100] where 0 means the color filter has no effect and +100 means the color filter has maximum effect.\r\n * Values less than zero provide a filter of opposite hue.\r\n */\r\n set: function (value) {\r\n this._midtonesDensity = value;\r\n this._dirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"midtonesSaturation\", {\r\n /**\r\n * Gets the midtones Saturation value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase saturation and negative values decrease saturation.\r\n */\r\n get: function () {\r\n return this._midtonesSaturation;\r\n },\r\n /**\r\n * Sets the midtones Saturation value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase saturation and negative values decrease saturation.\r\n */\r\n set: function (value) {\r\n this._midtonesSaturation = value;\r\n this._dirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"midtonesExposure\", {\r\n /**\r\n * Gets the midtones Exposure value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase exposure and negative values decrease exposure.\r\n */\r\n get: function () {\r\n return this._midtonesExposure;\r\n },\r\n /**\r\n * Sets the midtones Exposure value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase exposure and negative values decrease exposure.\r\n */\r\n set: function (value) {\r\n this._midtonesExposure = value;\r\n this._dirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"shadowsHue\", {\r\n /**\r\n * Gets the shadows Hue value.\r\n * The hue value is a standard HSB hue in the range [0,360] where 0=red, 120=green and 240=blue. The default value is 30 degrees (orange).\r\n */\r\n get: function () {\r\n return this._shadowsHue;\r\n },\r\n /**\r\n * Sets the shadows Hue value.\r\n * The hue value is a standard HSB hue in the range [0,360] where 0=red, 120=green and 240=blue. The default value is 30 degrees (orange).\r\n */\r\n set: function (value) {\r\n this._shadowsHue = value;\r\n this._dirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"shadowsDensity\", {\r\n /**\r\n * Gets the shadows Density value.\r\n * The density value is in range [-100,+100] where 0 means the color filter has no effect and +100 means the color filter has maximum effect.\r\n * Values less than zero provide a filter of opposite hue.\r\n */\r\n get: function () {\r\n return this._shadowsDensity;\r\n },\r\n /**\r\n * Sets the shadows Density value.\r\n * The density value is in range [-100,+100] where 0 means the color filter has no effect and +100 means the color filter has maximum effect.\r\n * Values less than zero provide a filter of opposite hue.\r\n */\r\n set: function (value) {\r\n this._shadowsDensity = value;\r\n this._dirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"shadowsSaturation\", {\r\n /**\r\n * Gets the shadows Saturation value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase saturation and negative values decrease saturation.\r\n */\r\n get: function () {\r\n return this._shadowsSaturation;\r\n },\r\n /**\r\n * Sets the shadows Saturation value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase saturation and negative values decrease saturation.\r\n */\r\n set: function (value) {\r\n this._shadowsSaturation = value;\r\n this._dirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorCurves.prototype, \"shadowsExposure\", {\r\n /**\r\n * Gets the shadows Exposure value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase exposure and negative values decrease exposure.\r\n */\r\n get: function () {\r\n return this._shadowsExposure;\r\n },\r\n /**\r\n * Sets the shadows Exposure value.\r\n * This is an adjustment value in the range [-100,+100], where the default value of 0.0 makes no adjustment, positive values increase exposure and negative values decrease exposure.\r\n */\r\n set: function (value) {\r\n this._shadowsExposure = value;\r\n this._dirty = true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Returns the class name\r\n * @returns The class name\r\n */\r\n ColorCurves.prototype.getClassName = function () {\r\n return \"ColorCurves\";\r\n };\r\n /**\r\n * Binds the color curves to the shader.\r\n * @param colorCurves The color curve to bind\r\n * @param effect The effect to bind to\r\n * @param positiveUniform The positive uniform shader parameter\r\n * @param neutralUniform The neutral uniform shader parameter\r\n * @param negativeUniform The negative uniform shader parameter\r\n */\r\n ColorCurves.Bind = function (colorCurves, effect, positiveUniform, neutralUniform, negativeUniform) {\r\n if (positiveUniform === void 0) { positiveUniform = \"vCameraColorCurvePositive\"; }\r\n if (neutralUniform === void 0) { neutralUniform = \"vCameraColorCurveNeutral\"; }\r\n if (negativeUniform === void 0) { negativeUniform = \"vCameraColorCurveNegative\"; }\r\n if (colorCurves._dirty) {\r\n colorCurves._dirty = false;\r\n // Fill in global info.\r\n colorCurves.getColorGradingDataToRef(colorCurves._globalHue, colorCurves._globalDensity, colorCurves._globalSaturation, colorCurves._globalExposure, colorCurves._globalCurve);\r\n // Compute highlights info.\r\n colorCurves.getColorGradingDataToRef(colorCurves._highlightsHue, colorCurves._highlightsDensity, colorCurves._highlightsSaturation, colorCurves._highlightsExposure, colorCurves._tempColor);\r\n colorCurves._tempColor.multiplyToRef(colorCurves._globalCurve, colorCurves._highlightsCurve);\r\n // Compute midtones info.\r\n colorCurves.getColorGradingDataToRef(colorCurves._midtonesHue, colorCurves._midtonesDensity, colorCurves._midtonesSaturation, colorCurves._midtonesExposure, colorCurves._tempColor);\r\n colorCurves._tempColor.multiplyToRef(colorCurves._globalCurve, colorCurves._midtonesCurve);\r\n // Compute shadows info.\r\n colorCurves.getColorGradingDataToRef(colorCurves._shadowsHue, colorCurves._shadowsDensity, colorCurves._shadowsSaturation, colorCurves._shadowsExposure, colorCurves._tempColor);\r\n colorCurves._tempColor.multiplyToRef(colorCurves._globalCurve, colorCurves._shadowsCurve);\r\n // Compute deltas (neutral is midtones).\r\n colorCurves._highlightsCurve.subtractToRef(colorCurves._midtonesCurve, colorCurves._positiveCurve);\r\n colorCurves._midtonesCurve.subtractToRef(colorCurves._shadowsCurve, colorCurves._negativeCurve);\r\n }\r\n if (effect) {\r\n effect.setFloat4(positiveUniform, colorCurves._positiveCurve.r, colorCurves._positiveCurve.g, colorCurves._positiveCurve.b, colorCurves._positiveCurve.a);\r\n effect.setFloat4(neutralUniform, colorCurves._midtonesCurve.r, colorCurves._midtonesCurve.g, colorCurves._midtonesCurve.b, colorCurves._midtonesCurve.a);\r\n effect.setFloat4(negativeUniform, colorCurves._negativeCurve.r, colorCurves._negativeCurve.g, colorCurves._negativeCurve.b, colorCurves._negativeCurve.a);\r\n }\r\n };\r\n /**\r\n * Prepare the list of uniforms associated with the ColorCurves effects.\r\n * @param uniformsList The list of uniforms used in the effect\r\n */\r\n ColorCurves.PrepareUniforms = function (uniformsList) {\r\n uniformsList.push(\"vCameraColorCurveNeutral\", \"vCameraColorCurvePositive\", \"vCameraColorCurveNegative\");\r\n };\r\n /**\r\n * Returns color grading data based on a hue, density, saturation and exposure value.\r\n * @param filterHue The hue of the color filter.\r\n * @param filterDensity The density of the color filter.\r\n * @param saturation The saturation.\r\n * @param exposure The exposure.\r\n * @param result The result data container.\r\n */\r\n ColorCurves.prototype.getColorGradingDataToRef = function (hue, density, saturation, exposure, result) {\r\n if (hue == null) {\r\n return;\r\n }\r\n hue = ColorCurves.clamp(hue, 0, 360);\r\n density = ColorCurves.clamp(density, -100, 100);\r\n saturation = ColorCurves.clamp(saturation, -100, 100);\r\n exposure = ColorCurves.clamp(exposure, -100, 100);\r\n // Remap the slider/config filter density with non-linear mapping and also scale by half\r\n // so that the maximum filter density is only 50% control. This provides fine control\r\n // for small values and reasonable range.\r\n density = ColorCurves.applyColorGradingSliderNonlinear(density);\r\n density *= 0.5;\r\n exposure = ColorCurves.applyColorGradingSliderNonlinear(exposure);\r\n if (density < 0) {\r\n density *= -1;\r\n hue = (hue + 180) % 360;\r\n }\r\n ColorCurves.fromHSBToRef(hue, density, 50 + 0.25 * exposure, result);\r\n result.scaleToRef(2, result);\r\n result.a = 1 + 0.01 * saturation;\r\n };\r\n /**\r\n * Takes an input slider value and returns an adjusted value that provides extra control near the centre.\r\n * @param value The input slider value in range [-100,100].\r\n * @returns Adjusted value.\r\n */\r\n ColorCurves.applyColorGradingSliderNonlinear = function (value) {\r\n value /= 100;\r\n var x = Math.abs(value);\r\n x = Math.pow(x, 2);\r\n if (value < 0) {\r\n x *= -1;\r\n }\r\n x *= 100;\r\n return x;\r\n };\r\n /**\r\n * Returns an RGBA Color4 based on Hue, Saturation and Brightness (also referred to as value, HSV).\r\n * @param hue The hue (H) input.\r\n * @param saturation The saturation (S) input.\r\n * @param brightness The brightness (B) input.\r\n * @result An RGBA color represented as Vector4.\r\n */\r\n ColorCurves.fromHSBToRef = function (hue, saturation, brightness, result) {\r\n var h = ColorCurves.clamp(hue, 0, 360);\r\n var s = ColorCurves.clamp(saturation / 100, 0, 1);\r\n var v = ColorCurves.clamp(brightness / 100, 0, 1);\r\n if (s === 0) {\r\n result.r = v;\r\n result.g = v;\r\n result.b = v;\r\n }\r\n else {\r\n // sector 0 to 5\r\n h /= 60;\r\n var i = Math.floor(h);\r\n // fractional part of h\r\n var f = h - i;\r\n var p = v * (1 - s);\r\n var q = v * (1 - s * f);\r\n var t = v * (1 - s * (1 - f));\r\n switch (i) {\r\n case 0:\r\n result.r = v;\r\n result.g = t;\r\n result.b = p;\r\n break;\r\n case 1:\r\n result.r = q;\r\n result.g = v;\r\n result.b = p;\r\n break;\r\n case 2:\r\n result.r = p;\r\n result.g = v;\r\n result.b = t;\r\n break;\r\n case 3:\r\n result.r = p;\r\n result.g = q;\r\n result.b = v;\r\n break;\r\n case 4:\r\n result.r = t;\r\n result.g = p;\r\n result.b = v;\r\n break;\r\n default: // case 5:\r\n result.r = v;\r\n result.g = p;\r\n result.b = q;\r\n break;\r\n }\r\n }\r\n result.a = 1;\r\n };\r\n /**\r\n * Returns a value clamped between min and max\r\n * @param value The value to clamp\r\n * @param min The minimum of value\r\n * @param max The maximum of value\r\n * @returns The clamped value.\r\n */\r\n ColorCurves.clamp = function (value, min, max) {\r\n return Math.min(Math.max(value, min), max);\r\n };\r\n /**\r\n * Clones the current color curve instance.\r\n * @return The cloned curves\r\n */\r\n ColorCurves.prototype.clone = function () {\r\n return SerializationHelper.Clone(function () { return new ColorCurves(); }, this);\r\n };\r\n /**\r\n * Serializes the current color curve instance to a json representation.\r\n * @return a JSON representation\r\n */\r\n ColorCurves.prototype.serialize = function () {\r\n return SerializationHelper.Serialize(this);\r\n };\r\n /**\r\n * Parses the color curve from a json representation.\r\n * @param source the JSON source to parse\r\n * @return The parsed curves\r\n */\r\n ColorCurves.Parse = function (source) {\r\n return SerializationHelper.Parse(function () { return new ColorCurves(); }, source, null, null);\r\n };\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_globalHue\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_globalDensity\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_globalSaturation\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_globalExposure\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_highlightsHue\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_highlightsDensity\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_highlightsSaturation\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_highlightsExposure\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_midtonesHue\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_midtonesDensity\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_midtonesSaturation\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ColorCurves.prototype, \"_midtonesExposure\", void 0);\r\n return ColorCurves;\r\n}());\r\nexport { ColorCurves };\r\n// References the dependencies.\r\nSerializationHelper._ColorCurvesParser = ColorCurves.Parse;\r\n//# sourceMappingURL=colorCurves.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, SerializationHelper, serializeAsTexture, serializeAsColorCurves, serializeAsColor4 } from \"../Misc/decorators\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { Tools } from \"../Misc/tools\";\r\nimport { Color4 } from \"../Maths/math.color\";\r\nimport { MaterialDefines } from \"../Materials/materialDefines\";\r\nimport { ColorCurves } from \"../Materials/colorCurves\";\r\n/**\r\n * @hidden\r\n */\r\nvar ImageProcessingConfigurationDefines = /** @class */ (function (_super) {\r\n __extends(ImageProcessingConfigurationDefines, _super);\r\n function ImageProcessingConfigurationDefines() {\r\n var _this = _super.call(this) || this;\r\n _this.IMAGEPROCESSING = false;\r\n _this.VIGNETTE = false;\r\n _this.VIGNETTEBLENDMODEMULTIPLY = false;\r\n _this.VIGNETTEBLENDMODEOPAQUE = false;\r\n _this.TONEMAPPING = false;\r\n _this.TONEMAPPING_ACES = false;\r\n _this.CONTRAST = false;\r\n _this.COLORCURVES = false;\r\n _this.COLORGRADING = false;\r\n _this.COLORGRADING3D = false;\r\n _this.SAMPLER3DGREENDEPTH = false;\r\n _this.SAMPLER3DBGRMAP = false;\r\n _this.IMAGEPROCESSINGPOSTPROCESS = false;\r\n _this.EXPOSURE = false;\r\n _this.rebuild();\r\n return _this;\r\n }\r\n return ImageProcessingConfigurationDefines;\r\n}(MaterialDefines));\r\nexport { ImageProcessingConfigurationDefines };\r\n/**\r\n * This groups together the common properties used for image processing either in direct forward pass\r\n * or through post processing effect depending on the use of the image processing pipeline in your scene\r\n * or not.\r\n */\r\nvar ImageProcessingConfiguration = /** @class */ (function () {\r\n function ImageProcessingConfiguration() {\r\n /**\r\n * Color curves setup used in the effect if colorCurvesEnabled is set to true\r\n */\r\n this.colorCurves = new ColorCurves();\r\n this._colorCurvesEnabled = false;\r\n this._colorGradingEnabled = false;\r\n this._colorGradingWithGreenDepth = true;\r\n this._colorGradingBGR = true;\r\n /** @hidden */\r\n this._exposure = 1.0;\r\n this._toneMappingEnabled = false;\r\n this._toneMappingType = ImageProcessingConfiguration.TONEMAPPING_STANDARD;\r\n this._contrast = 1.0;\r\n /**\r\n * Vignette stretch size.\r\n */\r\n this.vignetteStretch = 0;\r\n /**\r\n * Vignette centre X Offset.\r\n */\r\n this.vignetteCentreX = 0;\r\n /**\r\n * Vignette centre Y Offset.\r\n */\r\n this.vignetteCentreY = 0;\r\n /**\r\n * Vignette weight or intensity of the vignette effect.\r\n */\r\n this.vignetteWeight = 1.5;\r\n /**\r\n * Color of the vignette applied on the screen through the chosen blend mode (vignetteBlendMode)\r\n * if vignetteEnabled is set to true.\r\n */\r\n this.vignetteColor = new Color4(0, 0, 0, 0);\r\n /**\r\n * Camera field of view used by the Vignette effect.\r\n */\r\n this.vignetteCameraFov = 0.5;\r\n this._vignetteBlendMode = ImageProcessingConfiguration.VIGNETTEMODE_MULTIPLY;\r\n this._vignetteEnabled = false;\r\n this._applyByPostProcess = false;\r\n this._isEnabled = true;\r\n /**\r\n * An event triggered when the configuration changes and requires Shader to Update some parameters.\r\n */\r\n this.onUpdateParameters = new Observable();\r\n }\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"colorCurvesEnabled\", {\r\n /**\r\n * Gets wether the color curves effect is enabled.\r\n */\r\n get: function () {\r\n return this._colorCurvesEnabled;\r\n },\r\n /**\r\n * Sets wether the color curves effect is enabled.\r\n */\r\n set: function (value) {\r\n if (this._colorCurvesEnabled === value) {\r\n return;\r\n }\r\n this._colorCurvesEnabled = value;\r\n this._updateParameters();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"colorGradingTexture\", {\r\n /**\r\n * Color grading LUT texture used in the effect if colorGradingEnabled is set to true\r\n */\r\n get: function () {\r\n return this._colorGradingTexture;\r\n },\r\n /**\r\n * Color grading LUT texture used in the effect if colorGradingEnabled is set to true\r\n */\r\n set: function (value) {\r\n if (this._colorGradingTexture === value) {\r\n return;\r\n }\r\n this._colorGradingTexture = value;\r\n this._updateParameters();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"colorGradingEnabled\", {\r\n /**\r\n * Gets wether the color grading effect is enabled.\r\n */\r\n get: function () {\r\n return this._colorGradingEnabled;\r\n },\r\n /**\r\n * Sets wether the color grading effect is enabled.\r\n */\r\n set: function (value) {\r\n if (this._colorGradingEnabled === value) {\r\n return;\r\n }\r\n this._colorGradingEnabled = value;\r\n this._updateParameters();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"colorGradingWithGreenDepth\", {\r\n /**\r\n * Gets wether the color grading effect is using a green depth for the 3d Texture.\r\n */\r\n get: function () {\r\n return this._colorGradingWithGreenDepth;\r\n },\r\n /**\r\n * Sets wether the color grading effect is using a green depth for the 3d Texture.\r\n */\r\n set: function (value) {\r\n if (this._colorGradingWithGreenDepth === value) {\r\n return;\r\n }\r\n this._colorGradingWithGreenDepth = value;\r\n this._updateParameters();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"colorGradingBGR\", {\r\n /**\r\n * Gets wether the color grading texture contains BGR values.\r\n */\r\n get: function () {\r\n return this._colorGradingBGR;\r\n },\r\n /**\r\n * Sets wether the color grading texture contains BGR values.\r\n */\r\n set: function (value) {\r\n if (this._colorGradingBGR === value) {\r\n return;\r\n }\r\n this._colorGradingBGR = value;\r\n this._updateParameters();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"exposure\", {\r\n /**\r\n * Gets the Exposure used in the effect.\r\n */\r\n get: function () {\r\n return this._exposure;\r\n },\r\n /**\r\n * Sets the Exposure used in the effect.\r\n */\r\n set: function (value) {\r\n if (this._exposure === value) {\r\n return;\r\n }\r\n this._exposure = value;\r\n this._updateParameters();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"toneMappingEnabled\", {\r\n /**\r\n * Gets wether the tone mapping effect is enabled.\r\n */\r\n get: function () {\r\n return this._toneMappingEnabled;\r\n },\r\n /**\r\n * Sets wether the tone mapping effect is enabled.\r\n */\r\n set: function (value) {\r\n if (this._toneMappingEnabled === value) {\r\n return;\r\n }\r\n this._toneMappingEnabled = value;\r\n this._updateParameters();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"toneMappingType\", {\r\n /**\r\n * Gets the type of tone mapping effect.\r\n */\r\n get: function () {\r\n return this._toneMappingType;\r\n },\r\n /**\r\n * Sets the type of tone mapping effect used in BabylonJS.\r\n */\r\n set: function (value) {\r\n if (this._toneMappingType === value) {\r\n return;\r\n }\r\n this._toneMappingType = value;\r\n this._updateParameters();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"contrast\", {\r\n /**\r\n * Gets the contrast used in the effect.\r\n */\r\n get: function () {\r\n return this._contrast;\r\n },\r\n /**\r\n * Sets the contrast used in the effect.\r\n */\r\n set: function (value) {\r\n if (this._contrast === value) {\r\n return;\r\n }\r\n this._contrast = value;\r\n this._updateParameters();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"vignetteBlendMode\", {\r\n /**\r\n * Gets the vignette blend mode allowing different kind of effect.\r\n */\r\n get: function () {\r\n return this._vignetteBlendMode;\r\n },\r\n /**\r\n * Sets the vignette blend mode allowing different kind of effect.\r\n */\r\n set: function (value) {\r\n if (this._vignetteBlendMode === value) {\r\n return;\r\n }\r\n this._vignetteBlendMode = value;\r\n this._updateParameters();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"vignetteEnabled\", {\r\n /**\r\n * Gets wether the vignette effect is enabled.\r\n */\r\n get: function () {\r\n return this._vignetteEnabled;\r\n },\r\n /**\r\n * Sets wether the vignette effect is enabled.\r\n */\r\n set: function (value) {\r\n if (this._vignetteEnabled === value) {\r\n return;\r\n }\r\n this._vignetteEnabled = value;\r\n this._updateParameters();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"applyByPostProcess\", {\r\n /**\r\n * Gets wether the image processing is applied through a post process or not.\r\n */\r\n get: function () {\r\n return this._applyByPostProcess;\r\n },\r\n /**\r\n * Sets wether the image processing is applied through a post process or not.\r\n */\r\n set: function (value) {\r\n if (this._applyByPostProcess === value) {\r\n return;\r\n }\r\n this._applyByPostProcess = value;\r\n this._updateParameters();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration.prototype, \"isEnabled\", {\r\n /**\r\n * Gets wether the image processing is enabled or not.\r\n */\r\n get: function () {\r\n return this._isEnabled;\r\n },\r\n /**\r\n * Sets wether the image processing is enabled or not.\r\n */\r\n set: function (value) {\r\n if (this._isEnabled === value) {\r\n return;\r\n }\r\n this._isEnabled = value;\r\n this._updateParameters();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Method called each time the image processing information changes requires to recompile the effect.\r\n */\r\n ImageProcessingConfiguration.prototype._updateParameters = function () {\r\n this.onUpdateParameters.notifyObservers(this);\r\n };\r\n /**\r\n * Gets the current class name.\r\n * @return \"ImageProcessingConfiguration\"\r\n */\r\n ImageProcessingConfiguration.prototype.getClassName = function () {\r\n return \"ImageProcessingConfiguration\";\r\n };\r\n /**\r\n * Prepare the list of uniforms associated with the Image Processing effects.\r\n * @param uniforms The list of uniforms used in the effect\r\n * @param defines the list of defines currently in use\r\n */\r\n ImageProcessingConfiguration.PrepareUniforms = function (uniforms, defines) {\r\n if (defines.EXPOSURE) {\r\n uniforms.push(\"exposureLinear\");\r\n }\r\n if (defines.CONTRAST) {\r\n uniforms.push(\"contrast\");\r\n }\r\n if (defines.COLORGRADING) {\r\n uniforms.push(\"colorTransformSettings\");\r\n }\r\n if (defines.VIGNETTE) {\r\n uniforms.push(\"vInverseScreenSize\");\r\n uniforms.push(\"vignetteSettings1\");\r\n uniforms.push(\"vignetteSettings2\");\r\n }\r\n if (defines.COLORCURVES) {\r\n ColorCurves.PrepareUniforms(uniforms);\r\n }\r\n };\r\n /**\r\n * Prepare the list of samplers associated with the Image Processing effects.\r\n * @param samplersList The list of uniforms used in the effect\r\n * @param defines the list of defines currently in use\r\n */\r\n ImageProcessingConfiguration.PrepareSamplers = function (samplersList, defines) {\r\n if (defines.COLORGRADING) {\r\n samplersList.push(\"txColorTransform\");\r\n }\r\n };\r\n /**\r\n * Prepare the list of defines associated to the shader.\r\n * @param defines the list of defines to complete\r\n * @param forPostProcess Define if we are currently in post process mode or not\r\n */\r\n ImageProcessingConfiguration.prototype.prepareDefines = function (defines, forPostProcess) {\r\n if (forPostProcess === void 0) { forPostProcess = false; }\r\n if (forPostProcess !== this.applyByPostProcess || !this._isEnabled) {\r\n defines.VIGNETTE = false;\r\n defines.TONEMAPPING = false;\r\n defines.TONEMAPPING_ACES = false;\r\n defines.CONTRAST = false;\r\n defines.EXPOSURE = false;\r\n defines.COLORCURVES = false;\r\n defines.COLORGRADING = false;\r\n defines.COLORGRADING3D = false;\r\n defines.IMAGEPROCESSING = false;\r\n defines.IMAGEPROCESSINGPOSTPROCESS = this.applyByPostProcess && this._isEnabled;\r\n return;\r\n }\r\n defines.VIGNETTE = this.vignetteEnabled;\r\n defines.VIGNETTEBLENDMODEMULTIPLY = (this.vignetteBlendMode === ImageProcessingConfiguration._VIGNETTEMODE_MULTIPLY);\r\n defines.VIGNETTEBLENDMODEOPAQUE = !defines.VIGNETTEBLENDMODEMULTIPLY;\r\n defines.TONEMAPPING = this.toneMappingEnabled;\r\n switch (this._toneMappingType) {\r\n case ImageProcessingConfiguration.TONEMAPPING_ACES:\r\n defines.TONEMAPPING_ACES = true;\r\n break;\r\n default:\r\n defines.TONEMAPPING_ACES = false;\r\n break;\r\n }\r\n defines.CONTRAST = (this.contrast !== 1.0);\r\n defines.EXPOSURE = (this.exposure !== 1.0);\r\n defines.COLORCURVES = (this.colorCurvesEnabled && !!this.colorCurves);\r\n defines.COLORGRADING = (this.colorGradingEnabled && !!this.colorGradingTexture);\r\n if (defines.COLORGRADING) {\r\n defines.COLORGRADING3D = this.colorGradingTexture.is3D;\r\n }\r\n else {\r\n defines.COLORGRADING3D = false;\r\n }\r\n defines.SAMPLER3DGREENDEPTH = this.colorGradingWithGreenDepth;\r\n defines.SAMPLER3DBGRMAP = this.colorGradingBGR;\r\n defines.IMAGEPROCESSINGPOSTPROCESS = this.applyByPostProcess;\r\n defines.IMAGEPROCESSING = defines.VIGNETTE || defines.TONEMAPPING || defines.CONTRAST || defines.EXPOSURE || defines.COLORCURVES || defines.COLORGRADING;\r\n };\r\n /**\r\n * Returns true if all the image processing information are ready.\r\n * @returns True if ready, otherwise, false\r\n */\r\n ImageProcessingConfiguration.prototype.isReady = function () {\r\n // Color Grading texure can not be none blocking.\r\n return !this.colorGradingEnabled || !this.colorGradingTexture || this.colorGradingTexture.isReady();\r\n };\r\n /**\r\n * Binds the image processing to the shader.\r\n * @param effect The effect to bind to\r\n * @param overrideAspectRatio Override the aspect ratio of the effect\r\n */\r\n ImageProcessingConfiguration.prototype.bind = function (effect, overrideAspectRatio) {\r\n // Color Curves\r\n if (this._colorCurvesEnabled && this.colorCurves) {\r\n ColorCurves.Bind(this.colorCurves, effect);\r\n }\r\n // Vignette\r\n if (this._vignetteEnabled) {\r\n var inverseWidth = 1 / effect.getEngine().getRenderWidth();\r\n var inverseHeight = 1 / effect.getEngine().getRenderHeight();\r\n effect.setFloat2(\"vInverseScreenSize\", inverseWidth, inverseHeight);\r\n var aspectRatio = overrideAspectRatio != null ? overrideAspectRatio : (inverseHeight / inverseWidth);\r\n var vignetteScaleY = Math.tan(this.vignetteCameraFov * 0.5);\r\n var vignetteScaleX = vignetteScaleY * aspectRatio;\r\n var vignetteScaleGeometricMean = Math.sqrt(vignetteScaleX * vignetteScaleY);\r\n vignetteScaleX = Tools.Mix(vignetteScaleX, vignetteScaleGeometricMean, this.vignetteStretch);\r\n vignetteScaleY = Tools.Mix(vignetteScaleY, vignetteScaleGeometricMean, this.vignetteStretch);\r\n effect.setFloat4(\"vignetteSettings1\", vignetteScaleX, vignetteScaleY, -vignetteScaleX * this.vignetteCentreX, -vignetteScaleY * this.vignetteCentreY);\r\n var vignettePower = -2.0 * this.vignetteWeight;\r\n effect.setFloat4(\"vignetteSettings2\", this.vignetteColor.r, this.vignetteColor.g, this.vignetteColor.b, vignettePower);\r\n }\r\n // Exposure\r\n effect.setFloat(\"exposureLinear\", this.exposure);\r\n // Contrast\r\n effect.setFloat(\"contrast\", this.contrast);\r\n // Color transform settings\r\n if (this.colorGradingTexture) {\r\n effect.setTexture(\"txColorTransform\", this.colorGradingTexture);\r\n var textureSize = this.colorGradingTexture.getSize().height;\r\n effect.setFloat4(\"colorTransformSettings\", (textureSize - 1) / textureSize, // textureScale\r\n 0.5 / textureSize, // textureOffset\r\n textureSize, // textureSize\r\n this.colorGradingTexture.level // weight\r\n );\r\n }\r\n };\r\n /**\r\n * Clones the current image processing instance.\r\n * @return The cloned image processing\r\n */\r\n ImageProcessingConfiguration.prototype.clone = function () {\r\n return SerializationHelper.Clone(function () { return new ImageProcessingConfiguration(); }, this);\r\n };\r\n /**\r\n * Serializes the current image processing instance to a json representation.\r\n * @return a JSON representation\r\n */\r\n ImageProcessingConfiguration.prototype.serialize = function () {\r\n return SerializationHelper.Serialize(this);\r\n };\r\n /**\r\n * Parses the image processing from a json representation.\r\n * @param source the JSON source to parse\r\n * @return The parsed image processing\r\n */\r\n ImageProcessingConfiguration.Parse = function (source) {\r\n return SerializationHelper.Parse(function () { return new ImageProcessingConfiguration(); }, source, null, null);\r\n };\r\n Object.defineProperty(ImageProcessingConfiguration, \"VIGNETTEMODE_MULTIPLY\", {\r\n /**\r\n * Used to apply the vignette as a mix with the pixel color.\r\n */\r\n get: function () {\r\n return this._VIGNETTEMODE_MULTIPLY;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageProcessingConfiguration, \"VIGNETTEMODE_OPAQUE\", {\r\n /**\r\n * Used to apply the vignette as a replacement of the pixel color.\r\n */\r\n get: function () {\r\n return this._VIGNETTEMODE_OPAQUE;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Default tone mapping applied in BabylonJS.\r\n */\r\n ImageProcessingConfiguration.TONEMAPPING_STANDARD = 0;\r\n /**\r\n * ACES Tone mapping (used by default in unreal and unity). This can help getting closer\r\n * to other engines rendering to increase portability.\r\n */\r\n ImageProcessingConfiguration.TONEMAPPING_ACES = 1;\r\n // Static constants associated to the image processing.\r\n ImageProcessingConfiguration._VIGNETTEMODE_MULTIPLY = 0;\r\n ImageProcessingConfiguration._VIGNETTEMODE_OPAQUE = 1;\r\n __decorate([\r\n serializeAsColorCurves()\r\n ], ImageProcessingConfiguration.prototype, \"colorCurves\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_colorCurvesEnabled\", void 0);\r\n __decorate([\r\n serializeAsTexture(\"colorGradingTexture\")\r\n ], ImageProcessingConfiguration.prototype, \"_colorGradingTexture\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_colorGradingEnabled\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_colorGradingWithGreenDepth\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_colorGradingBGR\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_exposure\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_toneMappingEnabled\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_toneMappingType\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_contrast\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"vignetteStretch\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"vignetteCentreX\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"vignetteCentreY\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"vignetteWeight\", void 0);\r\n __decorate([\r\n serializeAsColor4()\r\n ], ImageProcessingConfiguration.prototype, \"vignetteColor\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"vignetteCameraFov\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_vignetteBlendMode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_vignetteEnabled\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_applyByPostProcess\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ImageProcessingConfiguration.prototype, \"_isEnabled\", void 0);\r\n return ImageProcessingConfiguration;\r\n}());\r\nexport { ImageProcessingConfiguration };\r\n// References the dependencies.\r\nSerializationHelper._ImageProcessingConfigurationParser = ImageProcessingConfiguration.Parse;\r\n//# sourceMappingURL=imageProcessingConfiguration.js.map","/*!\r\n * babyplots - Easy, fast, interactive 3D visualizations\r\n *\r\n * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved.\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n * \r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n * \r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n * \r\n * ---------------------------------------------\r\n * \r\n * babyplots includes CCapture.js, released under the following license:\r\n * \r\n * CCapture - A library to capture canvas-based animations\r\n * \r\n * The MIT License\r\n * \r\n * Copyright (c) 2012 Jaume Sanchez Elias\r\n * \r\n * Permission is hereby granted, free of charge, to any person obtaining a copy\r\n * of this software and associated documentation files (the \"Software\"), to deal\r\n * in the Software without restriction, including without limitation the rights\r\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\r\n * copies of the Software, and to permit persons to whom the Software is\r\n * furnished to do so, subject to the following conditions:\r\n * \r\n * The above copyright notice and this permission notice shall be included in\r\n * all copies or substantial portions of the Software.\r\n * \r\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\r\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\r\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\r\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\r\n * THE SOFTWARE.\r\n * \r\n * ---------------------------------------------\r\n * \r\n * babyplots includes axios, released under the following license:\r\n * \r\n * Copyright (c) 2014-present Matt Zabriskie\r\n * \r\n * Permission is hereby granted, free of charge, to any person obtaining a copy\r\n * of this software and associated documentation files (the \"Software\"), to deal\r\n * in the Software without restriction, including without limitation the rights\r\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\r\n * copies of the Software, and to permit persons to whom the Software is\r\n * furnished to do so, subject to the following conditions:\r\n * \r\n * The above copyright notice and this permission notice shall be included in\r\n * all copies or substantial portions of the Software.\r\n * \r\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\r\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\r\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\r\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\r\n * THE SOFTWARE.\r\n * \r\n * ---------------------------------------------\r\n * \r\n * babyplots includes uuid, released under the following license:\r\n * \r\n * The MIT License (MIT)\r\n * \r\n * Copyright (c) 2010-2020 Robert Kieffer and other contributors\r\n * \r\n * Permission is hereby granted, free of charge, to any person obtaining a copy\r\n * of this software and associated documentation files (the \"Software\"), to deal\r\n * in the Software without restriction, including without limitation the rights\r\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\r\n * copies of the Software, and to permit persons to whom the Software is furnished\r\n * to do so, subject to the following conditions:\r\n * \r\n * The above copyright notice and this permission notice shall be included in all\r\n * copies or substantial portions of the Software.\r\n * \r\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\r\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\r\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\r\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\r\n * THE SOFTWARE.\r\n * \r\n */\r\n\r\nimport { Scene } from \"@babylonjs/core/scene\";\r\nimport { Engine } from \"@babylonjs/core/Engines/engine\";\r\nimport { Mesh } from \"@babylonjs/core/Meshes/mesh\";\r\nimport { ArcRotateCamera } from \"@babylonjs/core/Cameras/arcRotateCamera\";\r\nimport { HemisphericLight } from \"@babylonjs/core/Lights/hemisphericLight\";\r\nimport { Vector3, Color4, Color3 } from \"@babylonjs/core/Maths/math\";\r\nimport { BoxBuilder } from \"@babylonjs/core/Meshes/Builders/boxBuilder\";\r\nimport { AdvancedDynamicTexture } from \"@babylonjs/gui/2D/advancedDynamicTexture\";\r\nimport { Rectangle, TextBlock, Grid, Control } from \"@babylonjs/gui/2D/controls\";\r\nimport { ScreenshotTools } from \"@babylonjs/core/Misc/screenshotTools\";\r\nimport chroma from \"chroma-js\";\r\nimport download from \"downloadjs\";\r\nimport { v4 as uuidv4 } from \"uuid\";\r\n\r\nconst axios = require('axios').default;\r\n\r\nimport { AnnotationManager } from \"./Label\";\r\n\r\n/**\r\n * Interface for object containing information about axis setup.\r\n */\r\nexport interface AxisData {\r\n showAxes: boolean[];\r\n static: boolean;\r\n axisLabels: string[];\r\n range: number[][];\r\n color: string[];\r\n scale: number[];\r\n tickBreaks: number[];\r\n showTickLines: boolean[][];\r\n tickLineColor: string[][];\r\n showPlanes: boolean[];\r\n planeColor: string[];\r\n plotType: string;\r\n colnames: string[];\r\n rownames: string[];\r\n}\r\n\r\nimport { Axes } from \"./Axes\";\r\n\r\nexport const buttonSVGs = {\r\n logo: '',\r\n toJson: '',\r\n labels: '',\r\n publish: '',\r\n replay: '',\r\n record: ''\r\n}\r\n\r\nexport const styleText = [\r\n \".bbp.button-bar { position: absolute; z-index: 2; overflow: hidden; padding: 0 10px 4px 0; }\",\r\n \".bbp.button-bar > .button { float: right; width: 75px; height: 30px; cursor: pointer; border-radius: 2px; background-color: #f0f0f0; margin: 0 4px 0 0; }\",\r\n \".bbp.button-bar > .button:hover { background-color: #ddd; }\",\r\n \".bbp.button-bar > .button > svg { width: 75px; height: 30px; }\",\r\n \".bbp.label-control { position: absolute; z-index: 3; font-family: sans-serif; width: 200px; background-color: #f0f0f0; padding: 5px; border-radius: 2px; }\",\r\n \".bbp.label-control > label { font-size: 11pt; }\",\r\n \".bbp.label-control > .edit-container { overflow: auto; }\",\r\n \".bbp.label-control > .edit-container > .label-form { margin-top: 5px; padding-top: 20px; border-top: solid thin #ccc; }\",\r\n \".bbp.label-control .label-form > input { width: 100%; box-sizing: border-box; }\",\r\n \".bbp.label-control .label-form > button { border: none; font-weight: bold; background-color: white; padding: 5px 10px; margin: 5px 0 2px 0; width: 100%; cursor: pointer; }\",\r\n \".bbp.label-control .label-form > button:hover { background-color: #ddd; }\",\r\n \".bbp.overlay { position: absolute; z-index: 3; overflow: hidden; top: 0; left: 0; right: 0; bottom: 0; width: 100%; height: 100%; background-color: #fff5; display: flex; justify-content: center; align-items: center;}\",\r\n \".bbp.overlay > h5.loading-message { color: #000; font-family: Verdana, sans-serif;}\",\r\n \".bbp.publish-form > label { display: block; text-align: left; font-family: Verdana, sans-serif; }\",\r\n \".bbp.publish-form > input { width: 100%; margin-bottom: 15px; box-sizing: border-box; }\",\r\n \".bbp.publish-form > .publish-btn { border: none; font-weight: bold; background-color: #e95420; color: white; padding: 5px 10px; margin: 5px 0 2px 0; width: 100%; cursor: pointer; }\",\r\n \".bbp.publish-form > .publish-btn:hover { background-color: #ca491a }\",\r\n \".bbp.publish-form > .close-btn, .bbp.publish-form > .cancel-btn { border: none; font-weight: bold; background-color: white; padding: 5px 10px; margin: 5px 0 2px 0; width: 100%; cursor: pointer; }\",\r\n \".bbp.publish-form > .close-btn:hover, .bbp.publish-form > .cancel-btn:hover { background-color: #ddd }\",\r\n \".bbp.publish-form > p.form-info { font-size: 8pt; font-family: Verdana, sans-serif; }\",\r\n \".bbp.publish-form > p.message { font-size: 10pt; font-family: Verdana, sans-serif; }\",\r\n \".bbp.publish-form > p.message.warning { color: red; margin-top: 0px; }\",\r\n \".bbp.publish-form > p.message.success { color: green; }\",\r\n].join(\" \");\r\n\r\nexport interface LegendData {\r\n showLegend: boolean;\r\n discrete: boolean;\r\n breaks: string[];\r\n colorScale: string;\r\n inverted: boolean;\r\n position: string;\r\n customColorScale?: string[];\r\n fontSize?: number;\r\n fontColor?: string;\r\n legendTitle?: string;\r\n legendTitleFontSize?: number;\r\n}\r\n\r\nexport abstract class Plot {\r\n protected _coords: number[][];\r\n protected _coordColors: string[];\r\n protected _groups: string[];\r\n protected _groupNames: string[];\r\n protected _size: number = 1;\r\n protected _scene: Scene;\r\n\r\n mesh: Mesh;\r\n meshes: Mesh[];\r\n selection: number[]; // contains indices of cells in selection cube\r\n legendData: LegendData;\r\n xScale: number;\r\n yScale: number;\r\n zScale: number;\r\n\r\n constructor(\r\n scene: Scene,\r\n coordinates: number[][],\r\n colorVar: string[],\r\n size: number,\r\n legendData: LegendData,\r\n xScale: number = 1,\r\n yScale: number = 1,\r\n zScale: number = 1\r\n ) {\r\n this._scene = scene;\r\n this._coords = coordinates;\r\n this._coordColors = colorVar;\r\n this._size = size;\r\n this.legendData = legendData;\r\n this.xScale = xScale\r\n this.yScale = yScale\r\n this.zScale = zScale\r\n }\r\n\r\n updateSize(): void { }\r\n update(): boolean { return false }\r\n resetAnimation(): void { }\r\n}\r\n\r\n\r\ndeclare global {\r\n interface Array {\r\n min(): number;\r\n max(): number;\r\n }\r\n}\r\n\r\nArray.prototype.min = function (): number {\r\n if (this.length > 65536) {\r\n let r = this[0];\r\n this.forEach(function (v: number, _i: any, _a: any) { if (v < r) r = v; });\r\n return r;\r\n } else {\r\n return Math.min.apply(null, this);\r\n }\r\n}\r\n\r\nArray.prototype.max = function (): number {\r\n if (this.length > 65536) {\r\n let r = this[0];\r\n this.forEach(function (v: number, _i: any, _a: any) { if (v > r) r = v; });\r\n return r;\r\n } else {\r\n return Math.max.apply(null, this);\r\n }\r\n}\r\n\r\nexport function matrixMax(matrix: number[][]): number {\r\n let maxRow = matrix.map(function (row) { return row.max(); });\r\n let max = maxRow.max();\r\n return max\r\n}\r\n\r\nexport function matrixMin(matrix: number[][]): number {\r\n let minRow = matrix.map(function (row) { return row.min(); });\r\n let min = minRow.min();\r\n return min\r\n}\r\n\r\nexport function getUniqueVals(source: string[]): string[] {\r\n let length = source.length;\r\n let result: string[] = [];\r\n let seen = new Set();\r\n\r\n outer:\r\n for (let index = 0; index < length; index++) {\r\n let value = source[index];\r\n if (seen.has(value)) continue outer;\r\n seen.add(value);\r\n result.push(value);\r\n }\r\n\r\n return result;\r\n}\r\n\r\nimport { ImgStack } from \"./ImgStack\";\r\nimport { ShapeCloud } from \"./ShapeCloud\";\r\nimport { PointCloud } from \"./PointCloud\";\r\nimport { Surface } from \"./Surface\";\r\nimport { HeatMap } from \"./HeatMap\";\r\nimport { BoundingBox } from \"@babylonjs/core/Culling/boundingBox\";\r\n\r\nexport const PLOTTYPES = {\r\n 'pointCloud': ['coordinates', 'colorBy', 'colorVar'],\r\n 'surface': ['coordinates', 'colorBy', 'colorVar'],\r\n 'heatMap': ['coordinates', 'colorBy', 'colorVar'],\r\n 'imageStack': ['values', 'indices', 'attributes']\r\n}\r\n\r\n/**\r\n * Takes a reasonable guess if a plot can be created from the provided object\r\n * @param plotData Object containing data to be checked for valid plot information\r\n */\r\nexport function isValidPlot(plotData: {}): boolean {\r\n for (let plotIdx = 0; plotIdx < plotData[\"plots\"].length; plotIdx++) {\r\n const plot = plotData[\"plots\"][plotIdx];\r\n let pltType = plot[\"plotType\"]\r\n if (PLOTTYPES.hasOwnProperty(pltType)) {\r\n for (let i = 0; i < PLOTTYPES[pltType].length; i++) {\r\n const prop = PLOTTYPES[pltType][i];\r\n if (plot[prop] === undefined) {\r\n console.log('Plot ' + plotIdx + ' is missing property:' + prop);\r\n return false;\r\n }\r\n }\r\n } else {\r\n console.log('Unrecognized plot type')\r\n return false;\r\n }\r\n }\r\n return true;\r\n}\r\n\r\nexport class Plots {\r\n private _engine: Engine;\r\n private _hl1: HemisphericLight;\r\n private _hl2: HemisphericLight;\r\n protected _legend: AdvancedDynamicTexture;\r\n protected _showLegend: boolean = true;\r\n private _hasAnim: boolean = false;\r\n private _axes: Axes[] = [];\r\n private _downloadObj: {} = {};\r\n private _buttonBar: HTMLDivElement;\r\n private _annotationManager: AnnotationManager;\r\n private _backgroundColor: string;\r\n private _recording: boolean = false;\r\n private _turned: number = 0;\r\n private _capturer: CCapture;\r\n private _wasTurning: boolean = false;\r\n private _xScale: number = 1;\r\n private _yScale: number = 1;\r\n private _zScale: number = 1;\r\n private _publishFormOverlay: HTMLDivElement;\r\n private _uniqID: string;\r\n\r\n canvas: HTMLCanvasElement;\r\n scene: Scene;\r\n camera: ArcRotateCamera;\r\n plots: Plot[] = [];\r\n turntable: boolean;\r\n rotationRate: number;\r\n fixedSize = false;\r\n ymax: number = 0;\r\n R: boolean = false;\r\n\r\n /**\r\n * Initialize the 3d visualization\r\n * @param canvasElement ID of the canvas element in the dom\r\n * @param backgroundColor Background color of the plot\r\n */\r\n constructor(canvasElement: string, options = {}) {\r\n // create unique id, needed if multiple babyplots canvases are on the same page.\r\n this._uniqID = uuidv4();\r\n\r\n // apply options\r\n // default settings\r\n let opts = {\r\n backgroundColor: \"#ffffffff\",\r\n xScale: 1,\r\n yScale: 1,\r\n zScale: 1,\r\n turntable: false,\r\n rotationRate: 0.01\r\n }\r\n Object.assign(opts, options);\r\n\r\n this.turntable = opts.turntable;\r\n this.rotationRate = opts.rotationRate;\r\n\r\n // setup enginge and scene\r\n this._backgroundColor = opts.backgroundColor;\r\n this.canvas = document.getElementById(canvasElement) as HTMLCanvasElement;\r\n this._engine = new Engine(this.canvas, true, { preserveDrawingBuffer: true, stencil: true });\r\n this.scene = new Scene(this._engine);\r\n\r\n // camera\r\n this.camera = new ArcRotateCamera(\"Camera\", 0, 0, 10, Vector3.Zero(), this.scene);\r\n this.camera.attachControl(this.canvas, true);\r\n this.scene.activeCamera = this.camera;\r\n this.camera.inputs.attached.keyboard.detachControl();\r\n this.camera.wheelPrecision = 50;\r\n\r\n // background color\r\n this.scene.clearColor = Color4.FromHexString(opts.backgroundColor);\r\n\r\n // Axis scales\r\n this._xScale = opts.xScale;\r\n this._yScale = opts.yScale;\r\n this._zScale = opts.zScale;\r\n\r\n // two lights to illuminate the cells uniformly (top and bottom)\r\n this._hl1 = new HemisphericLight(\"HemiLight\", new Vector3(0, 1, 0), this.scene);\r\n this._hl1.diffuse = new Color3(1, 1, 1);\r\n this._hl1.specular = new Color3(0, 0, 0);\r\n // bottom light slightly weaker for better depth perception and orientation\r\n this._hl2 = new HemisphericLight(\"HemiLight\", new Vector3(0, -1, 0), this.scene);\r\n this._hl2.diffuse = new Color3(0.8, 0.8, 0.8);\r\n this._hl2.specular = new Color3(0, 0, 0);\r\n\r\n this._annotationManager = new AnnotationManager(this.canvas, this.scene, this.ymax, this.camera);\r\n\r\n this.scene.registerBeforeRender(this._prepRender.bind(this));\r\n\r\n this.scene.registerAfterRender(this._afterRender.bind(this));\r\n\r\n // create container for buttons\r\n // create css style\r\n let styleElem = document.createElement(\"style\");\r\n styleElem.appendChild(document.createTextNode(styleText));\r\n document.getElementsByTagName('head')[0].appendChild(styleElem);\r\n // create ui elements\r\n let buttonBar = document.createElement(\"div\");\r\n buttonBar.className = \"bbp button-bar\"\r\n buttonBar.style.top = this.canvas.clientTop + 5 + \"px\";\r\n buttonBar.style.left = this.canvas.clientLeft + 5 + \"px\";\r\n this.canvas.parentNode.appendChild(buttonBar);\r\n this._buttonBar = buttonBar;\r\n // prepare download object\r\n this._downloadObj = {\r\n plots: []\r\n };\r\n }\r\n\r\n fromJSON(plotData: {}): void {\r\n if (plotData[\"turntable\"] !== undefined) {\r\n this.turntable = plotData[\"turntable\"];\r\n }\r\n if (plotData[\"rotationRate\"] !== undefined) {\r\n this.rotationRate = plotData[\"rotationRate\"];\r\n }\r\n if (plotData[\"backgroundColor\"]) {\r\n this._backgroundColor = plotData[\"backgroundColor\"];\r\n this.scene.clearColor = Color4.FromHexString(this._backgroundColor);\r\n }\r\n if (plotData[\"xScale\"] !== undefined) {\r\n this._xScale = plotData[\"xScale\"];\r\n }\r\n if (plotData[\"yScale\"] !== undefined) {\r\n this._yScale = plotData[\"yScale\"];\r\n }\r\n if (plotData[\"zScale\"] !== undefined) {\r\n this._zScale = plotData[\"zScale\"];\r\n }\r\n for (let plotIdx = 0; plotIdx < plotData[\"plots\"].length; plotIdx++) {\r\n const plot = plotData[\"plots\"][plotIdx];\r\n if (plot[\"plotType\"] === \"imageStack\") {\r\n this.addImgStack(\r\n plot[\"values\"],\r\n plot[\"indices\"],\r\n plot[\"attributes\"],\r\n {\r\n size: plot[\"size\"],\r\n colorScale: plot[\"colorScale\"],\r\n showLegend: plot[\"showLegend\"],\r\n fontSize: plot[\"fontSize\"],\r\n fontColor: plot[\"fontColor\"],\r\n legendTitle: plot[\"legendTitle\"],\r\n legendTitleFontSize: plot[\"legendTitleFontSize\"],\r\n legendPosition: plot[\"legendPosition\"],\r\n showAxes: plot[\"showAxes\"],\r\n axisLabels: plot[\"axisLabels\"],\r\n axisColors: plot[\"axisColors\"],\r\n tickBreaks: plot[\"tickBreaks\"],\r\n showTickLines: plot[\"showTickLines\"],\r\n tickLineColors: plot[\"tickLineColors\"],\r\n intensityMode: plot[\"intensityMode\"]\r\n }\r\n )\r\n } else if ([\"pointCloud\", \"heatMap\", \"surface\", \"shapeCloud\"].indexOf(plot[\"plotType\"]) !== -1) {\r\n this.addPlot(\r\n plot[\"coordinates\"],\r\n plot[\"plotType\"],\r\n plot[\"colorBy\"],\r\n plot[\"colorVar\"],\r\n {\r\n size: plot[\"size\"],\r\n colorScale: plot[\"colorScale\"],\r\n customColorScale: plot[\"customColorScale\"],\r\n colorScaleInverted: plot[\"colorScaleInverted\"],\r\n sortedCategories: plot[\"sortedCategories\"],\r\n showLegend: plot[\"showLegend\"],\r\n fontSize: plot[\"fontSize\"],\r\n fontColor: plot[\"fontColor\"],\r\n legendTitle: plot[\"legendTitle\"],\r\n legendTitleFontSize: plot[\"legendTitleFontSize\"],\r\n legendPosition: plot[\"legendPosition\"],\r\n showAxes: plot[\"showAxes\"],\r\n axisLabels: plot[\"axisLabels\"],\r\n axisColors: plot[\"axisColors\"],\r\n tickBreaks: plot[\"tickBreaks\"],\r\n showTickLines: plot[\"showTickLines\"],\r\n tickLineColors: plot[\"tickLineColors\"],\r\n folded: plot[\"folded\"],\r\n foldedEmbedding: plot[\"foldedEmbedding\"],\r\n foldAnimDelay: plot[\"foldAnimDelay\"],\r\n foldAnimDuration: plot[\"foldAnimDuration\"],\r\n colnames: plot[\"colnames\"],\r\n rownames: plot[\"rownames\"],\r\n shape: plot[\"shape\"]\r\n }\r\n )\r\n }\r\n }\r\n if (plotData[\"labels\"]) {\r\n this._annotationManager.fixedLabels = true;\r\n let labelData = plotData[\"labels\"];\r\n if (labelData.length > 0) {\r\n if (Array.isArray(labelData[0])) {\r\n this._annotationManager.addLabels(labelData);\r\n } else {\r\n // legacy label saving\r\n for (let i = 0; i < labelData.length; i++) {\r\n const label = labelData[i];\r\n if (label[\"text\"] && label[\"position\"]) {\r\n this._annotationManager.addLabel(label[\"text\"], label[\"position\"]);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n if (plotData[\"cameraAlpha\"] !== undefined) {\r\n this.camera.alpha = plotData[\"cameraAlpha\"];\r\n }\r\n if (plotData[\"cameraBeta\"] !== undefined) {\r\n this.camera.beta = plotData[\"cameraBeta\"];\r\n }\r\n if (plotData[\"cameraRadius\"] !== undefined) {\r\n this.camera.radius = plotData[\"cameraRadius\"];\r\n }\r\n }\r\n\r\n createButtons(whichBtns = [\"json\", \"label\", \"publish\", \"record\"]): void {\r\n if (whichBtns.indexOf(\"json\") !== -1) {\r\n let jsonBtn = document.createElement(\"div\");\r\n jsonBtn.className = \"button\";\r\n jsonBtn.onclick = this._downloadJson.bind(this);\r\n jsonBtn.innerHTML = buttonSVGs.toJson;\r\n this._buttonBar.appendChild(jsonBtn);\r\n }\r\n if (whichBtns.indexOf(\"label\") !== -1) {\r\n let labelBtn = document.createElement(\"div\");\r\n labelBtn.className = \"button\";\r\n labelBtn.onclick = this._annotationManager.toggleLabelControl.bind(this._annotationManager);\r\n labelBtn.innerHTML = buttonSVGs.labels;\r\n this._buttonBar.appendChild(labelBtn);\r\n }\r\n if (whichBtns.indexOf(\"record\") !== -1) {\r\n let recordBtn = document.createElement(\"div\");\r\n recordBtn.className = \"button\";\r\n recordBtn.onclick = this._startRecording.bind(this);\r\n recordBtn.innerHTML = buttonSVGs.record;\r\n this._buttonBar.appendChild(recordBtn);\r\n }\r\n if (whichBtns.indexOf(\"publish\") !== -1) {\r\n let publishBtn = document.createElement(\"div\");\r\n publishBtn.className = \"button\";\r\n publishBtn.onclick = this._createPublishForm.bind(this);\r\n publishBtn.innerHTML = buttonSVGs.publish;\r\n this._buttonBar.appendChild(publishBtn);\r\n }\r\n }\r\n\r\n private _prepDownloadObj() {\r\n this._downloadObj[\"turntable\"] = this.turntable;\r\n this._downloadObj[\"rotationRate\"] = this.rotationRate;\r\n this._downloadObj[\"backgroundColor\"] = this._backgroundColor;\r\n this._downloadObj[\"xScale\"] = this._xScale;\r\n this._downloadObj[\"yScale\"] = this._yScale;\r\n this._downloadObj[\"zScale\"] = this._zScale;\r\n this._downloadObj[\"cameraAlpha\"] = this.camera.alpha;\r\n this._downloadObj[\"cameraBeta\"] = this.camera.beta;\r\n this._downloadObj[\"cameraRadius\"] = this.camera.radius;\r\n this._downloadObj[\"labels\"] = this._annotationManager.exportLabels();\r\n this._downloadObj[\"cameraAlpha\"] = this.camera.alpha;\r\n this._downloadObj[\"cameraBeta\"] = this.camera.beta;\r\n this._downloadObj[\"cameraRadius\"] = this.camera.radius;\r\n }\r\n\r\n private _downloadJson() {\r\n let dlElement = document.createElement(\"a\");\r\n this._prepDownloadObj();\r\n let dlContent = encodeURIComponent(JSON.stringify(this._downloadObj));\r\n dlElement.setAttribute(\"href\", \"data:text/plain;charset=utf-8,\" + dlContent);\r\n dlElement.setAttribute(\"download\", \"babyplots_export.json\");\r\n dlElement.style.display = \"none\";\r\n document.body.appendChild(dlElement);\r\n dlElement.click();\r\n document.body.removeChild(dlElement);\r\n }\r\n\r\n private _createPublishForm() {\r\n\r\n if (this._publishFormOverlay !== undefined) {\r\n return\r\n }\r\n\r\n let formOverlay = document.createElement(\"div\");\r\n\r\n formOverlay.id = \"publishOverlay_\" + this._uniqID;\r\n formOverlay.style.position = \"absolute\";\r\n let r = this.canvas.getBoundingClientRect();\r\n formOverlay.style.top = r.y + \"px\";\r\n formOverlay.style.left = r.x + \"px\";\r\n formOverlay.style.width = r.width + \"px\";\r\n formOverlay.style.height = r.height + \"px\";\r\n formOverlay.style.backgroundColor = \"#ffffff66\";\r\n let formBox = document.createElement(\"div\");\r\n formBox.style.width = \"180px\";\r\n formBox.style.margin = \"42px auto\";\r\n formBox.style.backgroundColor = \"white\";\r\n formBox.style.padding = \"15px 30px\";\r\n formBox.style.borderRadius = \"10px\";\r\n formBox.style.boxShadow = \"0 0 10px #0003\";\r\n formBox.className = \"bbp publish-form\"\r\n formOverlay.appendChild(formBox);\r\n // Upload description text\r\n let formInfo = document.createElement(\"p\");\r\n formInfo.innerText = \"Upload the plot to your account on https://bp.bleb.li. Only you will be able to see it. You can change the access settings in your account.\";\r\n formInfo.className = \"form-info\";\r\n formBox.appendChild(formInfo);\r\n // Inputs and their labels\r\n let usernameLabel = document.createElement(\"label\");\r\n usernameLabel.id = \"publishUsernameLabel_\" + this._uniqID;\r\n usernameLabel.innerText = \"Username:\";\r\n let usernameInput = document.createElement(\"input\");\r\n usernameInput.type = \"text\";\r\n usernameInput.id = \"publishUsername_\" + this._uniqID;\r\n let passwordLabel = document.createElement(\"label\");\r\n passwordLabel.id = \"publishPasswordLabel_\" + this._uniqID;\r\n passwordLabel.innerText = \"Password:\"\r\n let passwordInput = document.createElement(\"input\");\r\n passwordInput.type = \"password\";\r\n passwordInput.id = \"publishPassword_\" + this._uniqID;\r\n let titleLabel = document.createElement(\"label\");\r\n titleLabel.id = \"publishTitleLabel_\" + this._uniqID;\r\n titleLabel.innerText = \"Plot title:\";\r\n let titleInput = document.createElement(\"input\");\r\n titleInput.type = \"text\";\r\n titleInput.id = \"publishTitle_\" + this._uniqID;\r\n // message placeholder\r\n let msg = document.createElement(\"p\");\r\n msg.id = \"publishMessage_\" + this._uniqID;\r\n // Buttons\r\n let publishBtn = document.createElement(\"button\");\r\n publishBtn.className = \"publish-btn\";\r\n publishBtn.id = \"publishBtn_\" + this._uniqID;\r\n publishBtn.onclick = this._tryPublish.bind(this);\r\n publishBtn.innerText = \"Login and publish\";\r\n let cancelBtn = document.createElement(\"button\");\r\n cancelBtn.className = \"cancel-btn\";\r\n cancelBtn.id = \"cancelBtn_\" + this._uniqID;\r\n cancelBtn.onclick = this._cancelPublish.bind(this);\r\n cancelBtn.innerText = \"Cancel\";\r\n let closeBtn = document.createElement(\"button\");\r\n closeBtn.className = \"close-btn\";\r\n closeBtn.id = \"closeBtn_\" + this._uniqID;\r\n closeBtn.onclick = this._cancelPublish.bind(this);\r\n closeBtn.innerText = \"Close\";\r\n closeBtn.style.display = \"none\";\r\n\r\n // Add all form elements to the form\r\n formBox.appendChild(usernameLabel);\r\n formBox.appendChild(usernameInput);\r\n formBox.appendChild(passwordLabel);\r\n formBox.appendChild(passwordInput);\r\n formBox.appendChild(titleLabel);\r\n formBox.appendChild(titleInput);\r\n formBox.appendChild(msg);\r\n formBox.appendChild(publishBtn);\r\n formBox.appendChild(cancelBtn);\r\n formBox.appendChild(closeBtn);\r\n this._publishFormOverlay = formOverlay;\r\n this.canvas.parentNode.appendChild(formOverlay);\r\n }\r\n\r\n private _resizePublishOverlay() {\r\n if (this._publishFormOverlay === undefined) {\r\n return\r\n }\r\n let r = this.canvas.getBoundingClientRect();\r\n this._publishFormOverlay.style.left = r.x + \"px\";\r\n this._publishFormOverlay.style.top = r.y + \"px\";\r\n this._publishFormOverlay.style.width = r.width + \"px\";\r\n this._publishFormOverlay.style.height = r.height + \"px\";\r\n }\r\n\r\n private _tryPublish() {\r\n this.thumbnail(80, (function (thumb_data) {\r\n this._prepDownloadObj();\r\n axios({\r\n method: 'post',\r\n url: 'https://bp.bleb.li/api/publish',\r\n headers: {\r\n 'Content-Type': \"application/json;charset=UTF-8\"\r\n },\r\n data: {\r\n username: (document.getElementById(\"publishUsername_\" + this._uniqID) as HTMLInputElement).value,\r\n password: (document.getElementById(\"publishPassword_\" + this._uniqID) as HTMLInputElement).value,\r\n plotData: JSON.stringify(this._downloadObj),\r\n plotName: (document.getElementById(\"publishTitle_\" + this._uniqID) as HTMLInputElement).value,\r\n thumb: thumb_data\r\n },\r\n\r\n })\r\n .then((function (response) {\r\n let msg = document.getElementById(\"publishMessage_\" + this._uniqID);\r\n msg.innerText = \"Successfully published plot!\";\r\n msg.className = \"message success\";\r\n document.getElementById(\"publishUsername_\" + this._uniqID).style.display = \"none\";\r\n document.getElementById(\"publishUsernameLabel_\" + this._uniqID).style.display = \"none\";\r\n document.getElementById(\"publishPassword_\" + this._uniqID).style.display = \"none\";\r\n document.getElementById(\"publishPasswordLabel_\" + this._uniqID).style.display = \"none\";\r\n document.getElementById(\"publishTitle_\" + this._uniqID).style.display = \"none\";\r\n document.getElementById(\"publishTitleLabel_\" + this._uniqID).style.display = \"none\";\r\n document.getElementById(\"publishBtn_\" + this._uniqID).style.display = \"none\";\r\n document.getElementById(\"cancelBtn_\" + this._uniqID).style.display = \"none\";\r\n document.getElementById(\"closeBtn_\" + this._uniqID).style.display = \"block\";\r\n\r\n }).bind(this))\r\n .catch((function (response) {\r\n if (response.response.data[\"status\"] === \"not authorized\") {\r\n console.log(\"wrong credentials\");\r\n let msg = document.getElementById(\"publishMessage_\" + this._uniqID);\r\n msg.innerText = \"Invalid username or password.\";\r\n msg.className = \"message warning\";\r\n }\r\n console.log(response);\r\n }).bind(this))\r\n }).bind(this));\r\n }\r\n\r\n private _cancelPublish() {\r\n this._publishFormOverlay.remove();\r\n this._publishFormOverlay = undefined;\r\n }\r\n\r\n private _resetAnimation() {\r\n this._hasAnim = true;\r\n this.plots[0].resetAnimation();\r\n let boundingBox = this.plots[0].mesh.getBoundingInfo().boundingBox;\r\n let rangeX = [\r\n boundingBox.minimumWorld.x,\r\n boundingBox.maximumWorld.x\r\n ]\r\n let rangeY = [\r\n boundingBox.minimumWorld.y,\r\n boundingBox.maximumWorld.y\r\n ]\r\n let rangeZ = [\r\n boundingBox.minimumWorld.z,\r\n boundingBox.maximumWorld.z\r\n ]\r\n this._axes[0].axisData.range = [rangeX, rangeY, rangeZ]\r\n this._axes[0].update(this.camera, true);\r\n }\r\n\r\n private _startRecording() {\r\n this._recording = true;\r\n }\r\n\r\n /**\r\n * Register before render\r\n */\r\n private _prepRender(): void {\r\n // rotate camera around plot if turntable is true\r\n if (this.turntable) {\r\n this.camera.alpha += this.rotationRate;\r\n }\r\n // update plots with animations\r\n if (this._hasAnim) {\r\n this._hasAnim = this.plots[0].update();\r\n if (!this._hasAnim) {\r\n let boundingBox = this.plots[0].mesh.getBoundingInfo().boundingBox;\r\n let rangeX = [\r\n boundingBox.minimumWorld.x,\r\n boundingBox.maximumWorld.x\r\n ]\r\n let rangeY = [\r\n boundingBox.minimumWorld.y,\r\n boundingBox.maximumWorld.y\r\n ]\r\n let rangeZ = [\r\n boundingBox.minimumWorld.z,\r\n boundingBox.maximumWorld.z\r\n ]\r\n this._axes[0].axisData.range = [rangeX, rangeY, rangeZ]\r\n this._axes[0].update(this.camera, true);\r\n }\r\n }\r\n // update axis drawing\r\n if (this._axes) {\r\n for (let i = 0; i < this._axes.length; i++) {\r\n this._axes[i].update(this.camera);\r\n }\r\n }\r\n\r\n // update labels\r\n this._annotationManager.update();\r\n\r\n // for (let pltIdx = 0; pltIdx < this.plots.length; pltIdx++) {\r\n // const plot = this.plots[pltIdx];\r\n // plot.update(); \r\n // }\r\n // if (this._mouseOverCheck) {\r\n // const pickResult = this._scene.pick(this._scene.pointerX, this._scene.pointerY);\r\n // const faceId = pickResult.faceId;\r\n // if (faceId == -1) {\r\n // return;\r\n // }\r\n // const idx = this._SPS.pickedParticles[faceId].idx;\r\n // this._mouseOverCallback(idx);\r\n // }\r\n }\r\n\r\n\r\n private _afterRender(): void {\r\n if (this._recording) {\r\n // start recording:\r\n if (this._turned === 0) {\r\n let worker = \"./\";\r\n if (this.R) {\r\n worker = \"lib/babyplots-1/\";\r\n }\r\n this._capturer = new CCapture({\r\n format: \"gif\",\r\n framerate: 30,\r\n verbose: false,\r\n display: false,\r\n quality: 50,\r\n workersPath: worker\r\n });\r\n // create capturer, enable turning\r\n this._capturer.start();\r\n this.rotationRate = 0.02;\r\n // to return turntable option to its initial state after recording\r\n if (this.turntable) {\r\n this._wasTurning = true;\r\n } else {\r\n this.turntable = true;\r\n }\r\n let loadingOverlay = document.createElement(\"div\");\r\n loadingOverlay.className = \"bbp overlay\";\r\n loadingOverlay.id = \"GIFloadingOverlay_\" + this._uniqID;\r\n let loadingText = document.createElement(\"h5\");\r\n loadingText.className = \".loading-message\";\r\n loadingText.innerText = \"Recording GIF...\";\r\n loadingText.id = \"GIFloadingText_\" + this._uniqID;\r\n loadingOverlay.appendChild(loadingText);\r\n this.canvas.parentNode.appendChild(loadingOverlay);\r\n }\r\n // recording in progress:\r\n if (this._turned < 2 * Math.PI) {\r\n // while recording, count rotation and capture screenshots\r\n this._turned += this.rotationRate;\r\n this._capturer.capture(this.canvas);\r\n } else {\r\n // after capturing 360°, stop capturing and save gif\r\n this._recording = false;\r\n this._capturer.stop();\r\n let loadingText = document.getElementById(\"GIFloadingText_\" + this._uniqID);\r\n loadingText.innerText = \"Saving GIF...\";\r\n this._capturer.save(function (blob) {\r\n download(blob, \"babyplots.gif\", 'image/gif');\r\n document.getElementById(\"GIFloadingText_\" + this._uniqID).remove();\r\n document.getElementById(\"GIFloadingOverlay_\" + this._uniqID).remove();\r\n });\r\n this._turned = 0;\r\n this.rotationRate = 0.01;\r\n this._hl2.diffuse = new Color3(0.8, 0.8, 0.8);\r\n if (!this._wasTurning) {\r\n this.turntable = false;\r\n }\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Zoom camera to fit the complete SPS into the field of view\r\n */\r\n private _cameraFitPlot(xRange: number[], yRange: number[], zRange: number[]): void {\r\n let xSize = xRange[1] - xRange[0];\r\n let ySize = yRange[1] - yRange[0];\r\n let zSize = zRange[1] - zRange[0];\r\n let box = BoxBuilder.CreateBox('bdbx', {\r\n width: xSize, height: ySize, depth: zSize\r\n }, this.scene);\r\n let xCenter = xRange[1] - xSize / 2;\r\n let yCenter = yRange[1] - ySize / 2;\r\n let zCenter = zRange[1] - zSize / 2;\r\n box.position = new Vector3(xCenter, yCenter, zCenter);\r\n this.camera.position = new Vector3(xCenter, ySize, zCenter);\r\n this.camera.target = new Vector3(xCenter, yCenter, zCenter);\r\n let radius = box.getBoundingInfo().boundingSphere.radiusWorld;\r\n let aspectRatio = this._engine.getAspectRatio(this.camera);\r\n let halfMinFov = this.camera.fov / 2;\r\n if (aspectRatio < 1) {\r\n halfMinFov = Math.atan(aspectRatio * Math.tan(this.camera.fov / 2));\r\n }\r\n let viewRadius = Math.abs(radius / Math.sin(halfMinFov));\r\n this.camera.radius = viewRadius;\r\n box.dispose();\r\n this.camera.alpha = 0;\r\n this.camera.beta = 1; // 0 is top view, Pi is bottom\r\n this.ymax = yRange[1];\r\n }\r\n\r\n addImgStack(\r\n values: number[],\r\n indices: number[],\r\n attributes: { dim: number[] },\r\n options: {}\r\n ) {\r\n // default options\r\n let opts = {\r\n size: 1,\r\n colorScale: null,\r\n showLegend: false,\r\n fontSize: 11,\r\n fontColor: \"black\",\r\n legendTitle: null,\r\n legendTitleFontSize: 16,\r\n legendPosition: null,\r\n showAxes: [false, false, false],\r\n axisLabels: [\"X\", \"Y\", \"Z\"],\r\n axisColors: [\"#666666\", \"#666666\", \"#666666\"],\r\n tickBreaks: [2, 2, 2],\r\n showTickLines: [[false, false], [false, false], [false, false]],\r\n tickLineColors: [[\"#aaaaaa\", \"#aaaaaa\"], [\"#aaaaaa\", \"#aaaaaa\"], [\"#aaaaaa\", \"#aaaaaa\"]],\r\n intensityMode: \"alpha\"\r\n }\r\n // apply user options\r\n Object.assign(opts, options);\r\n // prepare object for download as json button\r\n this._downloadObj[\"plots\"].push({\r\n plotType: \"imageStack\",\r\n values: values,\r\n indices: indices,\r\n attributes: attributes,\r\n size: opts.size,\r\n colorScale: opts.colorScale,\r\n showLegend: opts.showLegend,\r\n fontSize: opts.fontSize,\r\n fontColor: opts.fontColor,\r\n legendTitle: opts.legendTitle,\r\n legendTitleFontSize: opts.legendTitleFontSize,\r\n legendPosition: opts.legendPosition,\r\n showAxes: opts.showAxes,\r\n axisLabels: opts.axisLabels,\r\n axisColors: opts.axisColors,\r\n tickBreaks: opts.tickBreaks,\r\n showTickLines: opts.showTickLines,\r\n tickLineColors: opts.tickLineColors,\r\n intensityMode: opts.intensityMode\r\n })\r\n let legendData: LegendData = {\r\n showLegend: false,\r\n discrete: false,\r\n breaks: [],\r\n colorScale: \"\",\r\n inverted: false,\r\n position: opts.legendPosition\r\n }\r\n legendData.fontSize = opts.fontSize;\r\n legendData.fontColor = opts.fontColor;\r\n legendData.legendTitle = opts.legendTitle;\r\n legendData.legendTitleFontSize = opts.legendTitleFontSize;\r\n\r\n let plot = new ImgStack(\r\n this.scene,\r\n values,\r\n indices,\r\n attributes,\r\n legendData,\r\n opts.size,\r\n this._backgroundColor,\r\n opts.intensityMode,\r\n this._xScale,\r\n this._yScale,\r\n this._zScale\r\n );\r\n this.plots.push(plot);\r\n this._updateLegend();\r\n this._cameraFitPlot([0, attributes.dim[2]], [0, attributes.dim[0]], [0, attributes.dim[1]]);\r\n this.camera.wheelPrecision = 1;\r\n return this;\r\n }\r\n\r\n addPlot(\r\n coordinates: number[][],\r\n plotType: string,\r\n colorBy: string,\r\n colorVar: string[] | number[],\r\n options = {}\r\n ): Plots {\r\n // default options\r\n let opts = {\r\n size: 1,\r\n xScale: 1,\r\n yScale: 1,\r\n zScale: 1,\r\n colorScale: \"Oranges\",\r\n customColorScale: [],\r\n colorScaleInverted: false,\r\n sortedCategories: [],\r\n showLegend: false,\r\n fontSize: 11,\r\n fontColor: \"black\",\r\n legendTitle: null,\r\n legendTitleFontSize: 16,\r\n legendPosition: null,\r\n showAxes: [false, false, false],\r\n axisLabels: [\"X\", \"Y\", \"Z\"],\r\n axisColors: [\"#666666\", \"#666666\", \"#666666\"],\r\n tickBreaks: [2, 2, 2],\r\n showTickLines: [[false, false], [false, false], [false, false]],\r\n tickLineColors: [[\"#aaaaaa\", \"#aaaaaa\"], [\"#aaaaaa\", \"#aaaaaa\"], [\"#aaaaaa\", \"#aaaaaa\"]],\r\n folded: false,\r\n foldedEmbedding: null,\r\n foldAnimDelay: null,\r\n foldAnimDuration: null,\r\n colnames: null,\r\n rownames: null,\r\n shape: null,\r\n shading: true\r\n }\r\n // apply user options\r\n Object.assign(opts, options);\r\n // create plot data object for download as json button\r\n this._downloadObj[\"plots\"].push({\r\n plotType: plotType,\r\n coordinates: coordinates,\r\n colorBy: colorBy,\r\n colorVar: colorVar,\r\n size: opts.size,\r\n colorScale: opts.colorScale,\r\n customColorScale: opts.customColorScale,\r\n colorScaleInverted: opts.colorScaleInverted,\r\n sortedCategories: opts.sortedCategories,\r\n showLegend: opts.showLegend,\r\n fontSize: opts.fontSize,\r\n fontColor: opts.fontColor,\r\n legendTitle: opts.legendTitle,\r\n legendTitleFontSize: opts.legendTitleFontSize,\r\n legendPosition: opts.legendPosition,\r\n showAxes: opts.showAxes,\r\n axisLabels: opts.axisLabels,\r\n axisColors: opts.axisColors,\r\n tickBreaks: opts.tickBreaks,\r\n showTickLines: opts.showTickLines,\r\n tickLineColors: opts.tickLineColors,\r\n folded: opts.folded,\r\n foldedEmbedding: opts.foldedEmbedding,\r\n foldAnimDelay: opts.foldAnimDelay,\r\n foldAnimDuration: opts.foldAnimDuration,\r\n colnames: opts.colnames,\r\n rownames: opts.rownames,\r\n shape: opts.shape,\r\n shading: opts.shading\r\n })\r\n\r\n let coordColors: string[] = [];\r\n var legendData: LegendData;\r\n let rangeX: number[];\r\n let rangeY: number[];\r\n let rangeZ: number[];\r\n this._hasAnim = opts.folded;\r\n if (opts.folded) {\r\n let replayBtn = document.createElement(\"div\");\r\n replayBtn.className = \"button\"\r\n replayBtn.innerHTML = buttonSVGs.replay;\r\n replayBtn.onclick = this._resetAnimation.bind(this);\r\n this._buttonBar.appendChild(replayBtn);\r\n }\r\n\r\n switch (colorBy) {\r\n case \"categories\":\r\n // color plot by discrete categories\r\n let groups = colorVar as string[];\r\n let uniqueGroups = getUniqueVals(groups);\r\n // sortedCategories can contain an array of category names to order the groups for coloring.\r\n // sortedCategories must be of same length as unique groups in colorVar.\r\n // if no custom ordering is performed through sortedCategories, groups will be sorted alphabetically.\r\n uniqueGroups.sort();\r\n if (opts.sortedCategories) {\r\n if (uniqueGroups.length === opts.sortedCategories.length) {\r\n // sortedCategories must contain the same category names as those present in colorVar.\r\n if (JSON.stringify(uniqueGroups) === JSON.stringify(opts.sortedCategories.slice(0).sort())) {\r\n uniqueGroups = opts.sortedCategories;\r\n }\r\n }\r\n }\r\n let nColors = uniqueGroups.length;\r\n // Paired is default color scale for discrete variable coloring\r\n let colors = chroma.scale(chroma.brewer.Paired).mode('lch').colors(nColors);\r\n // check if color scale should be custom\r\n if (opts.colorScale === \"custom\") {\r\n if (opts.customColorScale !== undefined && opts.customColorScale.length !== 0) {\r\n if (opts.colorScaleInverted) {\r\n colors = chroma.scale(opts.customColorScale).domain([1, 0]).mode('lch').colors(nColors);\r\n } else {\r\n colors = chroma.scale(opts.customColorScale).mode('lch').colors(nColors);\r\n }\r\n } else {\r\n // set colorScale variable to default for legend if custom color scale is invalid\r\n opts.colorScale = \"Paired\";\r\n }\r\n } else {\r\n // check if user selected color scale is a valid chromajs color brewer name\r\n if (opts.colorScale && chroma.brewer.hasOwnProperty(opts.colorScale)) {\r\n if (opts.colorScaleInverted) {\r\n colors = chroma.scale(chroma.brewer[opts.colorScale]).domain([1, 0]).mode('lch').colors(nColors);\r\n } else {\r\n colors = chroma.scale(chroma.brewer[opts.colorScale]).mode('lch').colors(nColors);\r\n }\r\n } else {\r\n // set colorScale variable to default for legend if user selected is not valid\r\n opts.colorScale = \"Paired\";\r\n }\r\n }\r\n for (let i = 0; i < nColors; i++) {\r\n colors[i] += \"ff\";\r\n }\r\n // apply colors to plot points\r\n for (let i = 0; i < colorVar.length; i++) {\r\n let colorIndex = uniqueGroups.indexOf(groups[i]);\r\n coordColors.push(colors[colorIndex]);\r\n }\r\n // prepare object for legend drawing\r\n legendData = {\r\n showLegend: opts.showLegend,\r\n discrete: true,\r\n breaks: uniqueGroups,\r\n colorScale: opts.colorScale,\r\n customColorScale: opts.customColorScale,\r\n inverted: false,\r\n position: opts.legendPosition\r\n }\r\n break;\r\n case \"values\":\r\n // color by a continuous variable\r\n let min = colorVar.min();\r\n let max = colorVar.max();\r\n // Oranges is default color scale for continuous variable coloring\r\n let colorfunc = chroma.scale(chroma.brewer.Oranges).mode('lch');\r\n // check if color scale should be custom\r\n if (opts.colorScale === \"custom\") {\r\n // check if custom color scale is valid\r\n if (opts.customColorScale !== undefined && opts.customColorScale.length !== 0) {\r\n if (opts.colorScaleInverted) {\r\n colorfunc = chroma.scale(opts.customColorScale).domain([1, 0]).mode('lch');\r\n } else {\r\n colorfunc = chroma.scale(opts.customColorScale).mode('lch');\r\n }\r\n } else {\r\n // set colorScale variable to default for legend if custom color scale is invalid\r\n opts.colorScale = \"Oranges\";\r\n }\r\n } else {\r\n // check if user selected color scale is a valid chromajs color brewer name\r\n if (opts.colorScale && chroma.brewer.hasOwnProperty(opts.colorScale)) {\r\n if (opts.colorScaleInverted) {\r\n colorfunc = chroma.scale(chroma.brewer[opts.colorScale]).domain([1, 0]).mode('lch');\r\n } else {\r\n colorfunc = chroma.scale(chroma.brewer[opts.colorScale]).mode('lch');\r\n }\r\n } else {\r\n // set colorScale variable to default for legend if user selected is not valid\r\n opts.colorScale = \"Oranges\";\r\n }\r\n }\r\n // normalize the values to 0-1 range\r\n let norm = (colorVar as number[]).slice().map(v => (v - min) / (max - min));\r\n // apply colors to plot points\r\n coordColors = norm.map(v => colorfunc(v).alpha(1).hex(\"rgba\"));\r\n // prepare object for legend drawing\r\n legendData = {\r\n showLegend: opts.showLegend,\r\n discrete: false,\r\n breaks: [min.toString(), max.toString()],\r\n colorScale: opts.colorScale,\r\n customColorScale: opts.customColorScale,\r\n inverted: opts.colorScaleInverted,\r\n position: opts.legendPosition\r\n }\r\n break;\r\n case \"direct\":\r\n // color by color hex strings in colorVar\r\n for (let i = 0; i < colorVar.length; i++) {\r\n let cl = colorVar[i];\r\n cl = chroma(cl).hex();\r\n if (cl.length == 7) {\r\n cl += \"ff\";\r\n }\r\n coordColors.push(cl);\r\n }\r\n // prepare object for legend drawing\r\n legendData = {\r\n showLegend: false,\r\n discrete: false,\r\n breaks: [],\r\n colorScale: \"\",\r\n customColorScale: opts.customColorScale,\r\n inverted: false,\r\n position: opts.legendPosition\r\n }\r\n break;\r\n }\r\n // add remaining properties to legend object\r\n legendData.fontSize = opts.fontSize;\r\n legendData.fontColor = opts.fontColor;\r\n legendData.legendTitle = opts.legendTitle;\r\n legendData.legendTitleFontSize = opts.legendTitleFontSize;\r\n\r\n let plot: Plot;\r\n let scale: number[];\r\n let boundingBox: BoundingBox;\r\n switch (plotType) {\r\n case \"pointCloud\":\r\n plot = new PointCloud(\r\n this.scene,\r\n coordinates,\r\n coordColors,\r\n opts.size,\r\n legendData,\r\n opts.folded,\r\n opts.foldedEmbedding,\r\n opts.foldAnimDelay,\r\n opts.foldAnimDuration,\r\n this._xScale,\r\n this._yScale,\r\n this._zScale\r\n );\r\n boundingBox = plot.mesh.getBoundingInfo().boundingBox;\r\n rangeX = [\r\n boundingBox.minimumWorld.x,\r\n boundingBox.maximumWorld.x\r\n ]\r\n rangeY = [\r\n boundingBox.minimumWorld.y,\r\n boundingBox.maximumWorld.y\r\n ]\r\n rangeZ = [\r\n boundingBox.minimumWorld.z,\r\n boundingBox.maximumWorld.z\r\n ]\r\n scale = [\r\n this._xScale,\r\n this._yScale,\r\n this._zScale,\r\n ]\r\n break;\r\n case \"surface\":\r\n plot = new Surface(\r\n this.scene,\r\n coordinates,\r\n coordColors,\r\n opts.size,\r\n legendData,\r\n this._xScale,\r\n this._yScale,\r\n this._zScale\r\n );\r\n rangeX = [0, coordinates.length * this._xScale];\r\n rangeZ = [0, coordinates[0].length * this._zScale];\r\n rangeY = [\r\n matrixMin(coordinates) * this._yScale,\r\n matrixMax(coordinates) * this._yScale\r\n ];\r\n scale = [\r\n this._xScale,\r\n this._yScale,\r\n this._zScale,\r\n ]\r\n break\r\n case \"shapeCloud\":\r\n plot = new ShapeCloud(\r\n this.scene,\r\n coordinates,\r\n coordColors,\r\n opts.shape,\r\n opts.shading,\r\n opts.size,\r\n legendData,\r\n this._xScale,\r\n this._yScale,\r\n this._zScale\r\n );\r\n boundingBox = plot.mesh.getBoundingInfo().boundingBox;\r\n rangeX = [\r\n boundingBox.minimumWorld.x,\r\n boundingBox.maximumWorld.x\r\n ]\r\n rangeY = [\r\n boundingBox.minimumWorld.y,\r\n boundingBox.maximumWorld.y\r\n ]\r\n rangeZ = [\r\n boundingBox.minimumWorld.z,\r\n boundingBox.maximumWorld.z\r\n ]\r\n scale = [\r\n this._xScale,\r\n this._yScale,\r\n this._zScale,\r\n ]\r\n break;\r\n case \"heatMap\":\r\n plot = new HeatMap(\r\n this.scene,\r\n coordinates,\r\n coordColors,\r\n opts.size,\r\n legendData,\r\n this._xScale,\r\n this._yScale,\r\n this._zScale\r\n );\r\n rangeX = [0, coordinates.length * this._xScale];\r\n rangeZ = [0, coordinates[0].length * this._zScale];\r\n rangeY = [\r\n matrixMin(coordinates) * this._yScale,\r\n matrixMax(coordinates) * this._yScale\r\n ];\r\n scale = [\r\n this._xScale,\r\n this._yScale,\r\n this._zScale,\r\n ]\r\n break\r\n }\r\n\r\n this.plots.push(plot);\r\n this._updateLegend();\r\n let axisData: AxisData = {\r\n showAxes: opts.showAxes,\r\n static: true,\r\n axisLabels: opts.axisLabels,\r\n range: [rangeX, rangeY, rangeZ],\r\n color: opts.axisColors,\r\n scale: scale,\r\n tickBreaks: opts.tickBreaks,\r\n showTickLines: opts.showTickLines,\r\n tickLineColor: opts.tickLineColors,\r\n showPlanes: [false, false, false],\r\n planeColor: [\"#cccccc88\", \"#cccccc88\", \"#cccccc88\"],\r\n plotType: plotType,\r\n colnames: opts.colnames,\r\n rownames: opts.rownames\r\n }\r\n this._axes.push(new Axes(axisData, this.scene, plotType == \"heatMap\"));\r\n this._cameraFitPlot(rangeX, rangeY, rangeZ);\r\n return this\r\n }\r\n\r\n /**\r\n * Creates a color legend for the plots\r\n */\r\n private _updateLegend(): void {\r\n if (this._legend) { this._legend.dispose(); }\r\n\r\n // create fullscreen GUI texture\r\n let uiLayer = AdvancedDynamicTexture.CreateFullscreenUI(\"UI\");\r\n\r\n let rightFree = true;\r\n let leftFree = true;\r\n for (let i = 0; i < this.plots.length; i++) {\r\n const plot = this.plots[i];\r\n let legendData = plot.legendData;\r\n if ([\"right\", \"left\"].indexOf(legendData.position) === -1) {\r\n legendData.position = null;\r\n }\r\n if (legendData.showLegend) {\r\n if (legendData.position === null) {\r\n if (rightFree) {\r\n legendData.position = \"right\";\r\n rightFree = false;\r\n } else if (leftFree) {\r\n legendData.position = \"left\";\r\n leftFree = false;\r\n } else {\r\n legendData.showLegend = false;\r\n }\r\n } else {\r\n if (legendData.position === \"right\") {\r\n rightFree = false;\r\n } else {\r\n leftFree = false;\r\n }\r\n }\r\n uiLayer = this._createPlotLegend(legendData, uiLayer);\r\n }\r\n }\r\n this._legend = uiLayer;\r\n }\r\n\r\n private _createPlotLegend(legendData: LegendData, uiLayer: AdvancedDynamicTexture): AdvancedDynamicTexture {\r\n if (!legendData.showLegend) {\r\n return uiLayer;\r\n }\r\n let n: number;\r\n let breakN = 20;\r\n // create grid for placing legend in correct position\r\n let grid = new Grid();\r\n uiLayer.addControl(grid);\r\n\r\n // main position of legend (right middle)\r\n let legendWidth = 0.2;\r\n\r\n if (legendData.discrete) {\r\n // number of clusters\r\n n = legendData.breaks.length;\r\n\r\n if (n > breakN * 2) {\r\n legendWidth = 0.4;\r\n }\r\n else if (n > breakN) {\r\n legendWidth = 0.3;\r\n }\r\n }\r\n\r\n let legendColumn = 1;\r\n if (legendData.position === \"right\") {\r\n grid.addColumnDefinition(1 - legendWidth);\r\n grid.addColumnDefinition(legendWidth);\r\n } else {\r\n grid.addColumnDefinition(legendWidth);\r\n grid.addColumnDefinition(1 - legendWidth);\r\n legendColumn = 0;\r\n }\r\n if (legendData.legendTitle && legendData.legendTitle !== \"\") {\r\n grid.addRowDefinition(0.1);\r\n grid.addRowDefinition(0.85);\r\n grid.addRowDefinition(0.05);\r\n }\r\n else {\r\n grid.addRowDefinition(0.05);\r\n grid.addRowDefinition(0.9);\r\n grid.addRowDefinition(0.05);\r\n }\r\n\r\n if (legendData.legendTitle) {\r\n let legendTitle = new TextBlock();\r\n legendTitle.text = legendData.legendTitle;\r\n legendTitle.color = legendData.fontColor;\r\n legendTitle.fontWeight = \"bold\";\r\n if (legendData.legendTitleFontSize) {\r\n legendTitle.fontSize = legendData.legendTitleFontSize + \"px\";\r\n }\r\n else {\r\n legendTitle.fontSize = \"20px\";\r\n }\r\n legendTitle.verticalAlignment = Control.VERTICAL_ALIGNMENT_BOTTOM;\r\n legendTitle.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n grid.addControl(legendTitle, 0, legendColumn);\r\n }\r\n\r\n // for continuous measures display color bar and max and min values.\r\n if (!legendData.discrete) {\r\n\r\n let innerGrid = new Grid();\r\n innerGrid.addColumnDefinition(0.2);\r\n innerGrid.addColumnDefinition(0.8);\r\n grid.addControl(innerGrid, 1, legendColumn);\r\n\r\n let nBreaks = 115;\r\n let labelSpace = 0.15;\r\n if (this.canvas.height < 70) {\r\n nBreaks = 10;\r\n labelSpace = 0.45;\r\n innerGrid.addRowDefinition(1);\r\n }\r\n else if (this.canvas.height < 130) {\r\n nBreaks = 50;\r\n labelSpace = 0.3;\r\n innerGrid.addRowDefinition(1);\r\n }\r\n else {\r\n let padding = (this.canvas.height - 115) / 2;\r\n innerGrid.addRowDefinition(padding, true);\r\n innerGrid.addRowDefinition(115, true);\r\n innerGrid.addRowDefinition(padding, true);\r\n }\r\n // color bar\r\n let colors: string[];\r\n if (legendData.colorScale === \"custom\") {\r\n colors = chroma.scale(legendData.customColorScale).mode('lch').colors(nBreaks);\r\n }\r\n else {\r\n colors = chroma.scale(chroma.brewer[legendData.colorScale]).mode('lch').colors(nBreaks);\r\n }\r\n let scaleGrid = new Grid();\r\n for (let i = 0; i < nBreaks; i++) {\r\n scaleGrid.addRowDefinition(1 / nBreaks);\r\n let legendColor = new Rectangle();\r\n if (legendData.inverted) {\r\n legendColor.background = colors[i];\r\n }\r\n else {\r\n legendColor.background = colors[colors.length - i - 1];\r\n }\r\n legendColor.thickness = 0;\r\n legendColor.width = 0.5;\r\n legendColor.height = 1;\r\n scaleGrid.addControl(legendColor, i, 0);\r\n }\r\n\r\n // label text\r\n let labelGrid = new Grid();\r\n labelGrid.addColumnDefinition(1);\r\n labelGrid.addRowDefinition(labelSpace);\r\n labelGrid.addRowDefinition(1 - labelSpace * 2);\r\n labelGrid.addRowDefinition(labelSpace);\r\n\r\n if (this.canvas.height < 130) {\r\n innerGrid.addControl(scaleGrid, 0, 0);\r\n innerGrid.addControl(labelGrid, 0, 1);\r\n }\r\n else {\r\n innerGrid.addControl(scaleGrid, 1, 0);\r\n innerGrid.addControl(labelGrid, 1, 1);\r\n }\r\n\r\n let minText = new TextBlock();\r\n minText.text = parseFloat(legendData.breaks[0]).toFixed(2);\r\n minText.color = legendData.fontColor;\r\n minText.fontSize = legendData.fontSize + \"px\";\r\n minText.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n labelGrid.addControl(minText, 2, 0);\r\n\r\n let maxText = new TextBlock();\r\n maxText.text = parseFloat(legendData.breaks[1]).toFixed(2);\r\n maxText.color = legendData.fontColor;\r\n maxText.fontSize = legendData.fontSize + \"px\";\r\n maxText.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n labelGrid.addControl(maxText, 0, 0);\r\n }\r\n else {\r\n // inner Grid contains legend rows and columns for color and text\r\n var innerGrid = new Grid();\r\n // two legend columns when more than 15 colors\r\n if (n > breakN * 2) {\r\n innerGrid.addColumnDefinition(0.1);\r\n innerGrid.addColumnDefinition(0.4);\r\n innerGrid.addColumnDefinition(0.1);\r\n innerGrid.addColumnDefinition(0.4);\r\n innerGrid.addColumnDefinition(0.1);\r\n innerGrid.addColumnDefinition(0.4);\r\n }\r\n else if (n > breakN) {\r\n innerGrid.addColumnDefinition(0.1);\r\n innerGrid.addColumnDefinition(0.4);\r\n innerGrid.addColumnDefinition(0.1);\r\n innerGrid.addColumnDefinition(0.4);\r\n }\r\n else {\r\n innerGrid.addColumnDefinition(0.2);\r\n innerGrid.addColumnDefinition(0.8);\r\n }\r\n for (let i = 0; i < n && i < breakN; i++) {\r\n if (n > breakN) {\r\n innerGrid.addRowDefinition(1 / breakN);\r\n }\r\n else {\r\n innerGrid.addRowDefinition(1 / n);\r\n }\r\n }\r\n grid.addControl(innerGrid, 1, legendColumn);\r\n\r\n let colors: string[];\r\n if (legendData.colorScale === \"custom\") {\r\n colors = chroma.scale(legendData.customColorScale).mode('lch').colors(n);\r\n }\r\n else {\r\n colors = chroma.scale(chroma.brewer[legendData.colorScale]).mode('lch').colors(n);\r\n }\r\n\r\n // add color box and legend text\r\n for (let i = 0; i < n; i++) {\r\n // color\r\n var legendColor = new Rectangle();\r\n legendColor.background = colors[i];\r\n legendColor.thickness = 0;\r\n legendColor.width = legendData.fontSize + \"px\";\r\n legendColor.height = legendData.fontSize + \"px\";\r\n // use second column for many entries\r\n if (i > breakN * 2 - 1) {\r\n innerGrid.addControl(legendColor, i - breakN * 2, 4);\r\n }\r\n else if (i > breakN - 1) {\r\n innerGrid.addControl(legendColor, i - breakN, 2);\r\n }\r\n else {\r\n innerGrid.addControl(legendColor, i, 0);\r\n }\r\n // text\r\n var legendText = new TextBlock();\r\n legendText.text = legendData.breaks[i].toString();\r\n legendText.color = legendData.fontColor;\r\n legendText.fontSize = legendData.fontSize + \"px\";\r\n legendText.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n // use second column for many entries\r\n if (i > breakN * 2 - 1) {\r\n innerGrid.addControl(legendText, i - breakN * 2, 5);\r\n }\r\n if (i > breakN - 1) {\r\n innerGrid.addControl(legendText, i - breakN, 3);\r\n }\r\n else {\r\n innerGrid.addControl(legendText, i, 1);\r\n }\r\n }\r\n }\r\n return uiLayer;\r\n }\r\n\r\n /**\r\n * Start rendering the scene\r\n */\r\n doRender(): Plots {\r\n this._engine.runRenderLoop(() => {\r\n this.scene.render();\r\n });\r\n return this;\r\n }\r\n\r\n resize(width?: number, height?: number): Plots {\r\n if (width !== undefined && height !== undefined) {\r\n if (this.R) {\r\n let pad = parseInt(document.body.style.padding.substring(0, document.body.style.padding.length - 2));\r\n this.canvas.width = width - 2 * pad;\r\n this.canvas.height = height - 2 * pad;\r\n } else {\r\n this.canvas.width = width;\r\n this.canvas.height = height;\r\n }\r\n }\r\n this._updateLegend();\r\n this._resizePublishOverlay();\r\n this._engine.resize();\r\n return this\r\n }\r\n\r\n thumbnail(size: number, saveCallback: (data: string) => void): void {\r\n ScreenshotTools.CreateScreenshot(this._engine, this.camera, size, saveCallback);\r\n }\r\n\r\n dispose(): void {\r\n this.scene.dispose();\r\n this._engine.dispose();\r\n }\r\n\r\n /**\r\n * Add labels from a list of labels.\r\n * \r\n * @param labelList List of lists with the first three elements of the inner lists being the x, y and z coordinates, and the fourth the label text.\r\n */\r\n addLabels(labelList: [[number, number, number, string]]): void {\r\n this._annotationManager.addLabels(labelList);\r\n }\r\n\r\n}\r\n","import { StringTools } from './stringTools';\r\nimport { Logger } from './logger';\r\nvar cloneValue = function (source, destinationObject) {\r\n if (!source) {\r\n return null;\r\n }\r\n if (source.getClassName && source.getClassName() === \"Mesh\") {\r\n return null;\r\n }\r\n if (source.getClassName && source.getClassName() === \"SubMesh\") {\r\n return source.clone(destinationObject);\r\n }\r\n else if (source.clone) {\r\n return source.clone();\r\n }\r\n return null;\r\n};\r\nfunction getAllPropertyNames(obj) {\r\n var props = [];\r\n do {\r\n Object.getOwnPropertyNames(obj).forEach(function (prop) {\r\n if (props.indexOf(prop) === -1) {\r\n props.push(prop);\r\n }\r\n });\r\n } while (obj = Object.getPrototypeOf(obj));\r\n return props;\r\n}\r\n/**\r\n * Class containing a set of static utilities functions for deep copy.\r\n */\r\nvar DeepCopier = /** @class */ (function () {\r\n function DeepCopier() {\r\n }\r\n /**\r\n * Tries to copy an object by duplicating every property\r\n * @param source defines the source object\r\n * @param destination defines the target object\r\n * @param doNotCopyList defines a list of properties to avoid\r\n * @param mustCopyList defines a list of properties to copy (even if they start with _)\r\n */\r\n DeepCopier.DeepCopy = function (source, destination, doNotCopyList, mustCopyList) {\r\n var proerties = getAllPropertyNames(source);\r\n for (var _i = 0, proerties_1 = proerties; _i < proerties_1.length; _i++) {\r\n var prop = proerties_1[_i];\r\n if (prop[0] === \"_\" && (!mustCopyList || mustCopyList.indexOf(prop) === -1)) {\r\n continue;\r\n }\r\n if (StringTools.EndsWith(prop, \"Observable\")) {\r\n continue;\r\n }\r\n if (doNotCopyList && doNotCopyList.indexOf(prop) !== -1) {\r\n continue;\r\n }\r\n var sourceValue = source[prop];\r\n var typeOfSourceValue = typeof sourceValue;\r\n if (typeOfSourceValue === \"function\") {\r\n continue;\r\n }\r\n try {\r\n if (typeOfSourceValue === \"object\") {\r\n if (sourceValue instanceof Array) {\r\n destination[prop] = [];\r\n if (sourceValue.length > 0) {\r\n if (typeof sourceValue[0] == \"object\") {\r\n for (var index = 0; index < sourceValue.length; index++) {\r\n var clonedValue = cloneValue(sourceValue[index], destination);\r\n if (destination[prop].indexOf(clonedValue) === -1) { // Test if auto inject was not done\r\n destination[prop].push(clonedValue);\r\n }\r\n }\r\n }\r\n else {\r\n destination[prop] = sourceValue.slice(0);\r\n }\r\n }\r\n }\r\n else {\r\n destination[prop] = cloneValue(sourceValue, destination);\r\n }\r\n }\r\n else {\r\n destination[prop] = sourceValue;\r\n }\r\n }\r\n catch (e) {\r\n // Log a warning (it could be because of a read-only property)\r\n Logger.Warn(e.message);\r\n }\r\n }\r\n };\r\n return DeepCopier;\r\n}());\r\nexport { DeepCopier };\r\n//# sourceMappingURL=deepCopier.js.map","import { Vector3 } from './math.vector';\r\n/**\r\n * Extracts minimum and maximum values from a list of indexed positions\r\n * @param positions defines the positions to use\r\n * @param indices defines the indices to the positions\r\n * @param indexStart defines the start index\r\n * @param indexCount defines the end index\r\n * @param bias defines bias value to add to the result\r\n * @return minimum and maximum values\r\n */\r\nexport function extractMinAndMaxIndexed(positions, indices, indexStart, indexCount, bias) {\r\n if (bias === void 0) { bias = null; }\r\n var minimum = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n var maximum = new Vector3(-Number.MAX_VALUE, -Number.MAX_VALUE, -Number.MAX_VALUE);\r\n for (var index = indexStart; index < indexStart + indexCount; index++) {\r\n var offset = indices[index] * 3;\r\n var x = positions[offset];\r\n var y = positions[offset + 1];\r\n var z = positions[offset + 2];\r\n minimum.minimizeInPlaceFromFloats(x, y, z);\r\n maximum.maximizeInPlaceFromFloats(x, y, z);\r\n }\r\n if (bias) {\r\n minimum.x -= minimum.x * bias.x + bias.y;\r\n minimum.y -= minimum.y * bias.x + bias.y;\r\n minimum.z -= minimum.z * bias.x + bias.y;\r\n maximum.x += maximum.x * bias.x + bias.y;\r\n maximum.y += maximum.y * bias.x + bias.y;\r\n maximum.z += maximum.z * bias.x + bias.y;\r\n }\r\n return {\r\n minimum: minimum,\r\n maximum: maximum\r\n };\r\n}\r\n/**\r\n * Extracts minimum and maximum values from a list of positions\r\n * @param positions defines the positions to use\r\n * @param start defines the start index in the positions array\r\n * @param count defines the number of positions to handle\r\n * @param bias defines bias value to add to the result\r\n * @param stride defines the stride size to use (distance between two positions in the positions array)\r\n * @return minimum and maximum values\r\n */\r\nexport function extractMinAndMax(positions, start, count, bias, stride) {\r\n if (bias === void 0) { bias = null; }\r\n var minimum = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n var maximum = new Vector3(-Number.MAX_VALUE, -Number.MAX_VALUE, -Number.MAX_VALUE);\r\n if (!stride) {\r\n stride = 3;\r\n }\r\n for (var index = start, offset = start * stride; index < start + count; index++, offset += stride) {\r\n var x = positions[offset];\r\n var y = positions[offset + 1];\r\n var z = positions[offset + 2];\r\n minimum.minimizeInPlaceFromFloats(x, y, z);\r\n maximum.maximizeInPlaceFromFloats(x, y, z);\r\n }\r\n if (bias) {\r\n minimum.x -= minimum.x * bias.x + bias.y;\r\n minimum.y -= minimum.y * bias.x + bias.y;\r\n minimum.z -= minimum.z * bias.x + bias.y;\r\n maximum.x += maximum.x * bias.x + bias.y;\r\n maximum.y += maximum.y * bias.x + bias.y;\r\n maximum.z += maximum.z * bias.x + bias.y;\r\n }\r\n return {\r\n minimum: minimum,\r\n maximum: maximum\r\n };\r\n}\r\n//# sourceMappingURL=math.functions.js.map","import { ThinEngine } from \"../../Engines/thinEngine\";\r\nimport { WebGLDataBuffer } from '../../Meshes/WebGL/webGLDataBuffer';\r\nThinEngine.prototype.createUniformBuffer = function (elements) {\r\n var ubo = this._gl.createBuffer();\r\n if (!ubo) {\r\n throw new Error(\"Unable to create uniform buffer\");\r\n }\r\n var result = new WebGLDataBuffer(ubo);\r\n this.bindUniformBuffer(result);\r\n if (elements instanceof Float32Array) {\r\n this._gl.bufferData(this._gl.UNIFORM_BUFFER, elements, this._gl.STATIC_DRAW);\r\n }\r\n else {\r\n this._gl.bufferData(this._gl.UNIFORM_BUFFER, new Float32Array(elements), this._gl.STATIC_DRAW);\r\n }\r\n this.bindUniformBuffer(null);\r\n result.references = 1;\r\n return result;\r\n};\r\nThinEngine.prototype.createDynamicUniformBuffer = function (elements) {\r\n var ubo = this._gl.createBuffer();\r\n if (!ubo) {\r\n throw new Error(\"Unable to create dynamic uniform buffer\");\r\n }\r\n var result = new WebGLDataBuffer(ubo);\r\n this.bindUniformBuffer(result);\r\n if (elements instanceof Float32Array) {\r\n this._gl.bufferData(this._gl.UNIFORM_BUFFER, elements, this._gl.DYNAMIC_DRAW);\r\n }\r\n else {\r\n this._gl.bufferData(this._gl.UNIFORM_BUFFER, new Float32Array(elements), this._gl.DYNAMIC_DRAW);\r\n }\r\n this.bindUniformBuffer(null);\r\n result.references = 1;\r\n return result;\r\n};\r\nThinEngine.prototype.updateUniformBuffer = function (uniformBuffer, elements, offset, count) {\r\n this.bindUniformBuffer(uniformBuffer);\r\n if (offset === undefined) {\r\n offset = 0;\r\n }\r\n if (count === undefined) {\r\n if (elements instanceof Float32Array) {\r\n this._gl.bufferSubData(this._gl.UNIFORM_BUFFER, offset, elements);\r\n }\r\n else {\r\n this._gl.bufferSubData(this._gl.UNIFORM_BUFFER, offset, new Float32Array(elements));\r\n }\r\n }\r\n else {\r\n if (elements instanceof Float32Array) {\r\n this._gl.bufferSubData(this._gl.UNIFORM_BUFFER, 0, elements.subarray(offset, offset + count));\r\n }\r\n else {\r\n this._gl.bufferSubData(this._gl.UNIFORM_BUFFER, 0, new Float32Array(elements).subarray(offset, offset + count));\r\n }\r\n }\r\n this.bindUniformBuffer(null);\r\n};\r\nThinEngine.prototype.bindUniformBuffer = function (buffer) {\r\n this._gl.bindBuffer(this._gl.UNIFORM_BUFFER, buffer ? buffer.underlyingResource : null);\r\n};\r\nThinEngine.prototype.bindUniformBufferBase = function (buffer, location) {\r\n this._gl.bindBufferBase(this._gl.UNIFORM_BUFFER, location, buffer ? buffer.underlyingResource : null);\r\n};\r\nThinEngine.prototype.bindUniformBlock = function (pipelineContext, blockName, index) {\r\n var program = pipelineContext.program;\r\n var uniformLocation = this._gl.getUniformBlockIndex(program, blockName);\r\n this._gl.uniformBlockBinding(program, uniformLocation, index);\r\n};\r\n//# sourceMappingURL=engine.uniformBuffer.js.map","import { Logger } from \"../Misc/logger\";\r\nimport \"../Engines/Extensions/engine.uniformBuffer\";\r\n/**\r\n * Uniform buffer objects.\r\n *\r\n * Handles blocks of uniform on the GPU.\r\n *\r\n * If WebGL 2 is not available, this class falls back on traditionnal setUniformXXX calls.\r\n *\r\n * For more information, please refer to :\r\n * https://www.khronos.org/opengl/wiki/Uniform_Buffer_Object\r\n */\r\nvar UniformBuffer = /** @class */ (function () {\r\n /**\r\n * Instantiates a new Uniform buffer objects.\r\n *\r\n * Handles blocks of uniform on the GPU.\r\n *\r\n * If WebGL 2 is not available, this class falls back on traditionnal setUniformXXX calls.\r\n *\r\n * For more information, please refer to :\r\n * @see https://www.khronos.org/opengl/wiki/Uniform_Buffer_Object\r\n * @param engine Define the engine the buffer is associated with\r\n * @param data Define the data contained in the buffer\r\n * @param dynamic Define if the buffer is updatable\r\n */\r\n function UniformBuffer(engine, data, dynamic) {\r\n /** @hidden */\r\n this._alreadyBound = false;\r\n // Matrix cache\r\n this._valueCache = {};\r\n this._engine = engine;\r\n this._noUBO = !engine.supportsUniformBuffers;\r\n this._dynamic = dynamic;\r\n this._data = data || [];\r\n this._uniformLocations = {};\r\n this._uniformSizes = {};\r\n this._uniformLocationPointer = 0;\r\n this._needSync = false;\r\n if (this._noUBO) {\r\n this.updateMatrix3x3 = this._updateMatrix3x3ForEffect;\r\n this.updateMatrix2x2 = this._updateMatrix2x2ForEffect;\r\n this.updateFloat = this._updateFloatForEffect;\r\n this.updateFloat2 = this._updateFloat2ForEffect;\r\n this.updateFloat3 = this._updateFloat3ForEffect;\r\n this.updateFloat4 = this._updateFloat4ForEffect;\r\n this.updateMatrix = this._updateMatrixForEffect;\r\n this.updateVector3 = this._updateVector3ForEffect;\r\n this.updateVector4 = this._updateVector4ForEffect;\r\n this.updateColor3 = this._updateColor3ForEffect;\r\n this.updateColor4 = this._updateColor4ForEffect;\r\n }\r\n else {\r\n this._engine._uniformBuffers.push(this);\r\n this.updateMatrix3x3 = this._updateMatrix3x3ForUniform;\r\n this.updateMatrix2x2 = this._updateMatrix2x2ForUniform;\r\n this.updateFloat = this._updateFloatForUniform;\r\n this.updateFloat2 = this._updateFloat2ForUniform;\r\n this.updateFloat3 = this._updateFloat3ForUniform;\r\n this.updateFloat4 = this._updateFloat4ForUniform;\r\n this.updateMatrix = this._updateMatrixForUniform;\r\n this.updateVector3 = this._updateVector3ForUniform;\r\n this.updateVector4 = this._updateVector4ForUniform;\r\n this.updateColor3 = this._updateColor3ForUniform;\r\n this.updateColor4 = this._updateColor4ForUniform;\r\n }\r\n }\r\n Object.defineProperty(UniformBuffer.prototype, \"useUbo\", {\r\n /**\r\n * Indicates if the buffer is using the WebGL2 UBO implementation,\r\n * or just falling back on setUniformXXX calls.\r\n */\r\n get: function () {\r\n return !this._noUBO;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(UniformBuffer.prototype, \"isSync\", {\r\n /**\r\n * Indicates if the WebGL underlying uniform buffer is in sync\r\n * with the javascript cache data.\r\n */\r\n get: function () {\r\n return !this._needSync;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Indicates if the WebGL underlying uniform buffer is dynamic.\r\n * Also, a dynamic UniformBuffer will disable cache verification and always\r\n * update the underlying WebGL uniform buffer to the GPU.\r\n * @returns if Dynamic, otherwise false\r\n */\r\n UniformBuffer.prototype.isDynamic = function () {\r\n return this._dynamic !== undefined;\r\n };\r\n /**\r\n * The data cache on JS side.\r\n * @returns the underlying data as a float array\r\n */\r\n UniformBuffer.prototype.getData = function () {\r\n return this._bufferData;\r\n };\r\n /**\r\n * The underlying WebGL Uniform buffer.\r\n * @returns the webgl buffer\r\n */\r\n UniformBuffer.prototype.getBuffer = function () {\r\n return this._buffer;\r\n };\r\n /**\r\n * std140 layout specifies how to align data within an UBO structure.\r\n * See https://khronos.org/registry/OpenGL/specs/gl/glspec45.core.pdf#page=159\r\n * for specs.\r\n */\r\n UniformBuffer.prototype._fillAlignment = function (size) {\r\n // This code has been simplified because we only use floats, vectors of 1, 2, 3, 4 components\r\n // and 4x4 matrices\r\n // TODO : change if other types are used\r\n var alignment;\r\n if (size <= 2) {\r\n alignment = size;\r\n }\r\n else {\r\n alignment = 4;\r\n }\r\n if ((this._uniformLocationPointer % alignment) !== 0) {\r\n var oldPointer = this._uniformLocationPointer;\r\n this._uniformLocationPointer += alignment - (this._uniformLocationPointer % alignment);\r\n var diff = this._uniformLocationPointer - oldPointer;\r\n for (var i = 0; i < diff; i++) {\r\n this._data.push(0);\r\n }\r\n }\r\n };\r\n /**\r\n * Adds an uniform in the buffer.\r\n * Warning : the subsequents calls of this function must be in the same order as declared in the shader\r\n * for the layout to be correct !\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n * @param size Data size, or data directly.\r\n */\r\n UniformBuffer.prototype.addUniform = function (name, size) {\r\n if (this._noUBO) {\r\n return;\r\n }\r\n if (this._uniformLocations[name] !== undefined) {\r\n // Already existing uniform\r\n return;\r\n }\r\n // This function must be called in the order of the shader layout !\r\n // size can be the size of the uniform, or data directly\r\n var data;\r\n if (size instanceof Array) {\r\n data = size;\r\n size = data.length;\r\n }\r\n else {\r\n size = size;\r\n data = [];\r\n // Fill with zeros\r\n for (var i = 0; i < size; i++) {\r\n data.push(0);\r\n }\r\n }\r\n this._fillAlignment(size);\r\n this._uniformSizes[name] = size;\r\n this._uniformLocations[name] = this._uniformLocationPointer;\r\n this._uniformLocationPointer += size;\r\n for (var i = 0; i < size; i++) {\r\n this._data.push(data[i]);\r\n }\r\n this._needSync = true;\r\n };\r\n /**\r\n * Adds a Matrix 4x4 to the uniform buffer.\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n * @param mat A 4x4 matrix.\r\n */\r\n UniformBuffer.prototype.addMatrix = function (name, mat) {\r\n this.addUniform(name, Array.prototype.slice.call(mat.toArray()));\r\n };\r\n /**\r\n * Adds a vec2 to the uniform buffer.\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n * @param x Define the x component value of the vec2\r\n * @param y Define the y component value of the vec2\r\n */\r\n UniformBuffer.prototype.addFloat2 = function (name, x, y) {\r\n var temp = [x, y];\r\n this.addUniform(name, temp);\r\n };\r\n /**\r\n * Adds a vec3 to the uniform buffer.\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n * @param x Define the x component value of the vec3\r\n * @param y Define the y component value of the vec3\r\n * @param z Define the z component value of the vec3\r\n */\r\n UniformBuffer.prototype.addFloat3 = function (name, x, y, z) {\r\n var temp = [x, y, z];\r\n this.addUniform(name, temp);\r\n };\r\n /**\r\n * Adds a vec3 to the uniform buffer.\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n * @param color Define the vec3 from a Color\r\n */\r\n UniformBuffer.prototype.addColor3 = function (name, color) {\r\n var temp = new Array();\r\n color.toArray(temp);\r\n this.addUniform(name, temp);\r\n };\r\n /**\r\n * Adds a vec4 to the uniform buffer.\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n * @param color Define the rgb components from a Color\r\n * @param alpha Define the a component of the vec4\r\n */\r\n UniformBuffer.prototype.addColor4 = function (name, color, alpha) {\r\n var temp = new Array();\r\n color.toArray(temp);\r\n temp.push(alpha);\r\n this.addUniform(name, temp);\r\n };\r\n /**\r\n * Adds a vec3 to the uniform buffer.\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n * @param vector Define the vec3 components from a Vector\r\n */\r\n UniformBuffer.prototype.addVector3 = function (name, vector) {\r\n var temp = new Array();\r\n vector.toArray(temp);\r\n this.addUniform(name, temp);\r\n };\r\n /**\r\n * Adds a Matrix 3x3 to the uniform buffer.\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n */\r\n UniformBuffer.prototype.addMatrix3x3 = function (name) {\r\n this.addUniform(name, 12);\r\n };\r\n /**\r\n * Adds a Matrix 2x2 to the uniform buffer.\r\n * @param name Name of the uniform, as used in the uniform block in the shader.\r\n */\r\n UniformBuffer.prototype.addMatrix2x2 = function (name) {\r\n this.addUniform(name, 8);\r\n };\r\n /**\r\n * Effectively creates the WebGL Uniform Buffer, once layout is completed with `addUniform`.\r\n */\r\n UniformBuffer.prototype.create = function () {\r\n if (this._noUBO) {\r\n return;\r\n }\r\n if (this._buffer) {\r\n return; // nothing to do\r\n }\r\n // See spec, alignment must be filled as a vec4\r\n this._fillAlignment(4);\r\n this._bufferData = new Float32Array(this._data);\r\n this._rebuild();\r\n this._needSync = true;\r\n };\r\n /** @hidden */\r\n UniformBuffer.prototype._rebuild = function () {\r\n if (this._noUBO || !this._bufferData) {\r\n return;\r\n }\r\n if (this._dynamic) {\r\n this._buffer = this._engine.createDynamicUniformBuffer(this._bufferData);\r\n }\r\n else {\r\n this._buffer = this._engine.createUniformBuffer(this._bufferData);\r\n }\r\n };\r\n /**\r\n * Updates the WebGL Uniform Buffer on the GPU.\r\n * If the `dynamic` flag is set to true, no cache comparison is done.\r\n * Otherwise, the buffer will be updated only if the cache differs.\r\n */\r\n UniformBuffer.prototype.update = function () {\r\n if (!this._buffer) {\r\n this.create();\r\n return;\r\n }\r\n if (!this._dynamic && !this._needSync) {\r\n return;\r\n }\r\n this._engine.updateUniformBuffer(this._buffer, this._bufferData);\r\n this._needSync = false;\r\n };\r\n /**\r\n * Updates the value of an uniform. The `update` method must be called afterwards to make it effective in the GPU.\r\n * @param uniformName Define the name of the uniform, as used in the uniform block in the shader.\r\n * @param data Define the flattened data\r\n * @param size Define the size of the data.\r\n */\r\n UniformBuffer.prototype.updateUniform = function (uniformName, data, size) {\r\n var location = this._uniformLocations[uniformName];\r\n if (location === undefined) {\r\n if (this._buffer) {\r\n // Cannot add an uniform if the buffer is already created\r\n Logger.Error(\"Cannot add an uniform after UBO has been created.\");\r\n return;\r\n }\r\n this.addUniform(uniformName, size);\r\n location = this._uniformLocations[uniformName];\r\n }\r\n if (!this._buffer) {\r\n this.create();\r\n }\r\n if (!this._dynamic) {\r\n // Cache for static uniform buffers\r\n var changed = false;\r\n for (var i = 0; i < size; i++) {\r\n // We are checking the matrix cache before calling updateUniform so we do not need to check it here\r\n // Hence the test for size === 16 to simply commit the matrix values\r\n if (size === 16 || this._bufferData[location + i] !== data[i]) {\r\n changed = true;\r\n this._bufferData[location + i] = data[i];\r\n }\r\n }\r\n this._needSync = this._needSync || changed;\r\n }\r\n else {\r\n // No cache for dynamic\r\n for (var i = 0; i < size; i++) {\r\n this._bufferData[location + i] = data[i];\r\n }\r\n }\r\n };\r\n UniformBuffer.prototype._cacheMatrix = function (name, matrix) {\r\n var cache = this._valueCache[name];\r\n var flag = matrix.updateFlag;\r\n if (cache !== undefined && cache === flag) {\r\n return false;\r\n }\r\n this._valueCache[name] = flag;\r\n return true;\r\n };\r\n // Update methods\r\n UniformBuffer.prototype._updateMatrix3x3ForUniform = function (name, matrix) {\r\n // To match std140, matrix must be realigned\r\n for (var i = 0; i < 3; i++) {\r\n UniformBuffer._tempBuffer[i * 4] = matrix[i * 3];\r\n UniformBuffer._tempBuffer[i * 4 + 1] = matrix[i * 3 + 1];\r\n UniformBuffer._tempBuffer[i * 4 + 2] = matrix[i * 3 + 2];\r\n UniformBuffer._tempBuffer[i * 4 + 3] = 0.0;\r\n }\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 12);\r\n };\r\n UniformBuffer.prototype._updateMatrix3x3ForEffect = function (name, matrix) {\r\n this._currentEffect.setMatrix3x3(name, matrix);\r\n };\r\n UniformBuffer.prototype._updateMatrix2x2ForEffect = function (name, matrix) {\r\n this._currentEffect.setMatrix2x2(name, matrix);\r\n };\r\n UniformBuffer.prototype._updateMatrix2x2ForUniform = function (name, matrix) {\r\n // To match std140, matrix must be realigned\r\n for (var i = 0; i < 2; i++) {\r\n UniformBuffer._tempBuffer[i * 4] = matrix[i * 2];\r\n UniformBuffer._tempBuffer[i * 4 + 1] = matrix[i * 2 + 1];\r\n UniformBuffer._tempBuffer[i * 4 + 2] = 0.0;\r\n UniformBuffer._tempBuffer[i * 4 + 3] = 0.0;\r\n }\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 8);\r\n };\r\n UniformBuffer.prototype._updateFloatForEffect = function (name, x) {\r\n this._currentEffect.setFloat(name, x);\r\n };\r\n UniformBuffer.prototype._updateFloatForUniform = function (name, x) {\r\n UniformBuffer._tempBuffer[0] = x;\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 1);\r\n };\r\n UniformBuffer.prototype._updateFloat2ForEffect = function (name, x, y, suffix) {\r\n if (suffix === void 0) { suffix = \"\"; }\r\n this._currentEffect.setFloat2(name + suffix, x, y);\r\n };\r\n UniformBuffer.prototype._updateFloat2ForUniform = function (name, x, y) {\r\n UniformBuffer._tempBuffer[0] = x;\r\n UniformBuffer._tempBuffer[1] = y;\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 2);\r\n };\r\n UniformBuffer.prototype._updateFloat3ForEffect = function (name, x, y, z, suffix) {\r\n if (suffix === void 0) { suffix = \"\"; }\r\n this._currentEffect.setFloat3(name + suffix, x, y, z);\r\n };\r\n UniformBuffer.prototype._updateFloat3ForUniform = function (name, x, y, z) {\r\n UniformBuffer._tempBuffer[0] = x;\r\n UniformBuffer._tempBuffer[1] = y;\r\n UniformBuffer._tempBuffer[2] = z;\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 3);\r\n };\r\n UniformBuffer.prototype._updateFloat4ForEffect = function (name, x, y, z, w, suffix) {\r\n if (suffix === void 0) { suffix = \"\"; }\r\n this._currentEffect.setFloat4(name + suffix, x, y, z, w);\r\n };\r\n UniformBuffer.prototype._updateFloat4ForUniform = function (name, x, y, z, w) {\r\n UniformBuffer._tempBuffer[0] = x;\r\n UniformBuffer._tempBuffer[1] = y;\r\n UniformBuffer._tempBuffer[2] = z;\r\n UniformBuffer._tempBuffer[3] = w;\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 4);\r\n };\r\n UniformBuffer.prototype._updateMatrixForEffect = function (name, mat) {\r\n this._currentEffect.setMatrix(name, mat);\r\n };\r\n UniformBuffer.prototype._updateMatrixForUniform = function (name, mat) {\r\n if (this._cacheMatrix(name, mat)) {\r\n this.updateUniform(name, mat.toArray(), 16);\r\n }\r\n };\r\n UniformBuffer.prototype._updateVector3ForEffect = function (name, vector) {\r\n this._currentEffect.setVector3(name, vector);\r\n };\r\n UniformBuffer.prototype._updateVector3ForUniform = function (name, vector) {\r\n vector.toArray(UniformBuffer._tempBuffer);\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 3);\r\n };\r\n UniformBuffer.prototype._updateVector4ForEffect = function (name, vector) {\r\n this._currentEffect.setVector4(name, vector);\r\n };\r\n UniformBuffer.prototype._updateVector4ForUniform = function (name, vector) {\r\n vector.toArray(UniformBuffer._tempBuffer);\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 4);\r\n };\r\n UniformBuffer.prototype._updateColor3ForEffect = function (name, color, suffix) {\r\n if (suffix === void 0) { suffix = \"\"; }\r\n this._currentEffect.setColor3(name + suffix, color);\r\n };\r\n UniformBuffer.prototype._updateColor3ForUniform = function (name, color) {\r\n color.toArray(UniformBuffer._tempBuffer);\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 3);\r\n };\r\n UniformBuffer.prototype._updateColor4ForEffect = function (name, color, alpha, suffix) {\r\n if (suffix === void 0) { suffix = \"\"; }\r\n this._currentEffect.setColor4(name + suffix, color, alpha);\r\n };\r\n UniformBuffer.prototype._updateColor4ForUniform = function (name, color, alpha) {\r\n color.toArray(UniformBuffer._tempBuffer);\r\n UniformBuffer._tempBuffer[3] = alpha;\r\n this.updateUniform(name, UniformBuffer._tempBuffer, 4);\r\n };\r\n /**\r\n * Sets a sampler uniform on the effect.\r\n * @param name Define the name of the sampler.\r\n * @param texture Define the texture to set in the sampler\r\n */\r\n UniformBuffer.prototype.setTexture = function (name, texture) {\r\n this._currentEffect.setTexture(name, texture);\r\n };\r\n /**\r\n * Directly updates the value of the uniform in the cache AND on the GPU.\r\n * @param uniformName Define the name of the uniform, as used in the uniform block in the shader.\r\n * @param data Define the flattened data\r\n */\r\n UniformBuffer.prototype.updateUniformDirectly = function (uniformName, data) {\r\n this.updateUniform(uniformName, data, data.length);\r\n this.update();\r\n };\r\n /**\r\n * Binds this uniform buffer to an effect.\r\n * @param effect Define the effect to bind the buffer to\r\n * @param name Name of the uniform block in the shader.\r\n */\r\n UniformBuffer.prototype.bindToEffect = function (effect, name) {\r\n this._currentEffect = effect;\r\n if (this._noUBO || !this._buffer) {\r\n return;\r\n }\r\n this._alreadyBound = true;\r\n effect.bindUniformBuffer(this._buffer, name);\r\n };\r\n /**\r\n * Disposes the uniform buffer.\r\n */\r\n UniformBuffer.prototype.dispose = function () {\r\n if (this._noUBO) {\r\n return;\r\n }\r\n var uniformBuffers = this._engine._uniformBuffers;\r\n var index = uniformBuffers.indexOf(this);\r\n if (index !== -1) {\r\n uniformBuffers[index] = uniformBuffers[uniformBuffers.length - 1];\r\n uniformBuffers.pop();\r\n }\r\n if (!this._buffer) {\r\n return;\r\n }\r\n if (this._engine._releaseBuffer(this._buffer)) {\r\n this._buffer = null;\r\n }\r\n };\r\n // Pool for avoiding memory leaks\r\n UniformBuffer._MAX_UNIFORM_SIZE = 256;\r\n UniformBuffer._tempBuffer = new Float32Array(UniformBuffer._MAX_UNIFORM_SIZE);\r\n return UniformBuffer;\r\n}());\r\nexport { UniformBuffer };\r\n//# sourceMappingURL=uniformBuffer.js.map","import { Logger } from './logger';\r\nimport { _TypeStore } from './typeStore';\r\n/**\r\n * Class used to enable instatition of objects by class name\r\n */\r\nvar InstantiationTools = /** @class */ (function () {\r\n function InstantiationTools() {\r\n }\r\n /**\r\n * Tries to instantiate a new object from a given class name\r\n * @param className defines the class name to instantiate\r\n * @returns the new object or null if the system was not able to do the instantiation\r\n */\r\n InstantiationTools.Instantiate = function (className) {\r\n if (this.RegisteredExternalClasses && this.RegisteredExternalClasses[className]) {\r\n return this.RegisteredExternalClasses[className];\r\n }\r\n var internalClass = _TypeStore.GetClass(className);\r\n if (internalClass) {\r\n return internalClass;\r\n }\r\n Logger.Warn(className + \" not found, you may have missed an import.\");\r\n var arr = className.split(\".\");\r\n var fn = (window || this);\r\n for (var i = 0, len = arr.length; i < len; i++) {\r\n fn = fn[arr[i]];\r\n }\r\n if (typeof fn !== \"function\") {\r\n return null;\r\n }\r\n return fn;\r\n };\r\n /**\r\n * Use this object to register external classes like custom textures or material\r\n * to allow the laoders to instantiate them\r\n */\r\n InstantiationTools.RegisteredExternalClasses = {};\r\n return InstantiationTools;\r\n}());\r\nexport { InstantiationTools };\r\n//# sourceMappingURL=instantiationTools.js.map","import { DomManagement } from './domManagement';\r\n/**\r\n * Class used to provide helper for timing\r\n */\r\nvar TimingTools = /** @class */ (function () {\r\n function TimingTools() {\r\n }\r\n /**\r\n * Polyfill for setImmediate\r\n * @param action defines the action to execute after the current execution block\r\n */\r\n TimingTools.SetImmediate = function (action) {\r\n if (DomManagement.IsWindowObjectExist() && window.setImmediate) {\r\n window.setImmediate(action);\r\n }\r\n else {\r\n setTimeout(action, 1);\r\n }\r\n };\r\n return TimingTools;\r\n}());\r\nexport { TimingTools };\r\n//# sourceMappingURL=timingTools.js.map","import { Material } from \"../Materials/material\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\n/**\r\n * PostProcessManager is used to manage one or more post processes or post process pipelines\r\n * See https://doc.babylonjs.com/how_to/how_to_use_postprocesses\r\n */\r\nvar PostProcessManager = /** @class */ (function () {\r\n /**\r\n * Creates a new instance PostProcess\r\n * @param scene The scene that the post process is associated with.\r\n */\r\n function PostProcessManager(scene) {\r\n this._vertexBuffers = {};\r\n this._scene = scene;\r\n }\r\n PostProcessManager.prototype._prepareBuffers = function () {\r\n if (this._vertexBuffers[VertexBuffer.PositionKind]) {\r\n return;\r\n }\r\n // VBO\r\n var vertices = [];\r\n vertices.push(1, 1);\r\n vertices.push(-1, 1);\r\n vertices.push(-1, -1);\r\n vertices.push(1, -1);\r\n this._vertexBuffers[VertexBuffer.PositionKind] = new VertexBuffer(this._scene.getEngine(), vertices, VertexBuffer.PositionKind, false, false, 2);\r\n this._buildIndexBuffer();\r\n };\r\n PostProcessManager.prototype._buildIndexBuffer = function () {\r\n // Indices\r\n var indices = [];\r\n indices.push(0);\r\n indices.push(1);\r\n indices.push(2);\r\n indices.push(0);\r\n indices.push(2);\r\n indices.push(3);\r\n this._indexBuffer = this._scene.getEngine().createIndexBuffer(indices);\r\n };\r\n /**\r\n * Rebuilds the vertex buffers of the manager.\r\n * @hidden\r\n */\r\n PostProcessManager.prototype._rebuild = function () {\r\n var vb = this._vertexBuffers[VertexBuffer.PositionKind];\r\n if (!vb) {\r\n return;\r\n }\r\n vb._rebuild();\r\n this._buildIndexBuffer();\r\n };\r\n // Methods\r\n /**\r\n * Prepares a frame to be run through a post process.\r\n * @param sourceTexture The input texture to the post procesess. (default: null)\r\n * @param postProcesses An array of post processes to be run. (default: null)\r\n * @returns True if the post processes were able to be run.\r\n * @hidden\r\n */\r\n PostProcessManager.prototype._prepareFrame = function (sourceTexture, postProcesses) {\r\n if (sourceTexture === void 0) { sourceTexture = null; }\r\n if (postProcesses === void 0) { postProcesses = null; }\r\n var camera = this._scene.activeCamera;\r\n if (!camera) {\r\n return false;\r\n }\r\n postProcesses = postProcesses || camera._postProcesses.filter(function (pp) { return pp != null; });\r\n if (!postProcesses || postProcesses.length === 0 || !this._scene.postProcessesEnabled) {\r\n return false;\r\n }\r\n postProcesses[0].activate(camera, sourceTexture, postProcesses !== null && postProcesses !== undefined);\r\n return true;\r\n };\r\n /**\r\n * Manually render a set of post processes to a texture.\r\n * Please note, the frame buffer won't be unbound after the call in case you have more render to do.\r\n * @param postProcesses An array of post processes to be run.\r\n * @param targetTexture The target texture to render to.\r\n * @param forceFullscreenViewport force gl.viewport to be full screen eg. 0,0,textureWidth,textureHeight\r\n * @param faceIndex defines the face to render to if a cubemap is defined as the target\r\n * @param lodLevel defines which lod of the texture to render to\r\n * @param doNotBindFrambuffer If set to true, assumes that the framebuffer has been bound previously\r\n */\r\n PostProcessManager.prototype.directRender = function (postProcesses, targetTexture, forceFullscreenViewport, faceIndex, lodLevel, doNotBindFrambuffer) {\r\n if (targetTexture === void 0) { targetTexture = null; }\r\n if (forceFullscreenViewport === void 0) { forceFullscreenViewport = false; }\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (lodLevel === void 0) { lodLevel = 0; }\r\n if (doNotBindFrambuffer === void 0) { doNotBindFrambuffer = false; }\r\n var engine = this._scene.getEngine();\r\n for (var index = 0; index < postProcesses.length; index++) {\r\n if (index < postProcesses.length - 1) {\r\n postProcesses[index + 1].activate(this._scene.activeCamera, targetTexture);\r\n }\r\n else {\r\n if (targetTexture) {\r\n engine.bindFramebuffer(targetTexture, faceIndex, undefined, undefined, forceFullscreenViewport, lodLevel);\r\n }\r\n else if (!doNotBindFrambuffer) {\r\n engine.restoreDefaultFramebuffer();\r\n }\r\n }\r\n var pp = postProcesses[index];\r\n var effect = pp.apply();\r\n if (effect) {\r\n pp.onBeforeRenderObservable.notifyObservers(effect);\r\n // VBOs\r\n this._prepareBuffers();\r\n engine.bindBuffers(this._vertexBuffers, this._indexBuffer, effect);\r\n // Draw order\r\n engine.drawElementsType(Material.TriangleFillMode, 0, 6);\r\n pp.onAfterRenderObservable.notifyObservers(effect);\r\n }\r\n }\r\n // Restore depth buffer\r\n engine.setDepthBuffer(true);\r\n engine.setDepthWrite(true);\r\n };\r\n /**\r\n * Finalize the result of the output of the postprocesses.\r\n * @param doNotPresent If true the result will not be displayed to the screen.\r\n * @param targetTexture The target texture to render to.\r\n * @param faceIndex The index of the face to bind the target texture to.\r\n * @param postProcesses The array of post processes to render.\r\n * @param forceFullscreenViewport force gl.viewport to be full screen eg. 0,0,textureWidth,textureHeight (default: false)\r\n * @hidden\r\n */\r\n PostProcessManager.prototype._finalizeFrame = function (doNotPresent, targetTexture, faceIndex, postProcesses, forceFullscreenViewport) {\r\n if (forceFullscreenViewport === void 0) { forceFullscreenViewport = false; }\r\n var camera = this._scene.activeCamera;\r\n if (!camera) {\r\n return;\r\n }\r\n postProcesses = postProcesses || camera._postProcesses.filter(function (pp) { return pp != null; });\r\n if (postProcesses.length === 0 || !this._scene.postProcessesEnabled) {\r\n return;\r\n }\r\n var engine = this._scene.getEngine();\r\n for (var index = 0, len = postProcesses.length; index < len; index++) {\r\n var pp = postProcesses[index];\r\n if (index < len - 1) {\r\n pp._outputTexture = postProcesses[index + 1].activate(camera, targetTexture);\r\n }\r\n else {\r\n if (targetTexture) {\r\n engine.bindFramebuffer(targetTexture, faceIndex, undefined, undefined, forceFullscreenViewport);\r\n pp._outputTexture = targetTexture;\r\n }\r\n else {\r\n engine.restoreDefaultFramebuffer();\r\n pp._outputTexture = null;\r\n }\r\n }\r\n if (doNotPresent) {\r\n break;\r\n }\r\n var effect = pp.apply();\r\n if (effect) {\r\n pp.onBeforeRenderObservable.notifyObservers(effect);\r\n // VBOs\r\n this._prepareBuffers();\r\n engine.bindBuffers(this._vertexBuffers, this._indexBuffer, effect);\r\n // Draw order\r\n engine.drawElementsType(Material.TriangleFillMode, 0, 6);\r\n pp.onAfterRenderObservable.notifyObservers(effect);\r\n }\r\n }\r\n // Restore states\r\n engine.setDepthBuffer(true);\r\n engine.setDepthWrite(true);\r\n engine.setAlphaMode(0);\r\n };\r\n /**\r\n * Disposes of the post process manager.\r\n */\r\n PostProcessManager.prototype.dispose = function () {\r\n var buffer = this._vertexBuffers[VertexBuffer.PositionKind];\r\n if (buffer) {\r\n buffer.dispose();\r\n this._vertexBuffers[VertexBuffer.PositionKind] = null;\r\n }\r\n if (this._indexBuffer) {\r\n this._scene.getEngine()._releaseBuffer(this._indexBuffer);\r\n this._indexBuffer = null;\r\n }\r\n };\r\n return PostProcessManager;\r\n}());\r\nexport { PostProcessManager };\r\n//# sourceMappingURL=postProcessManager.js.map","/**\r\n * @hidden\r\n */\r\nvar IntersectionInfo = /** @class */ (function () {\r\n function IntersectionInfo(bu, bv, distance) {\r\n this.bu = bu;\r\n this.bv = bv;\r\n this.distance = distance;\r\n this.faceId = 0;\r\n this.subMeshId = 0;\r\n }\r\n return IntersectionInfo;\r\n}());\r\nexport { IntersectionInfo };\r\n//# sourceMappingURL=intersectionInfo.js.map","import { StringTools } from '../../Misc/stringTools';\r\n/** @hidden */\r\nvar ShaderCodeNode = /** @class */ (function () {\r\n function ShaderCodeNode() {\r\n this.children = [];\r\n }\r\n ShaderCodeNode.prototype.isValid = function (preprocessors) {\r\n return true;\r\n };\r\n ShaderCodeNode.prototype.process = function (preprocessors, options) {\r\n var result = \"\";\r\n if (this.line) {\r\n var value = this.line;\r\n var processor = options.processor;\r\n if (processor) {\r\n // This must be done before other replacements to avoid mistakenly changing something that was already changed.\r\n if (processor.lineProcessor) {\r\n value = processor.lineProcessor(value, options.isFragment);\r\n }\r\n if (processor.attributeProcessor && StringTools.StartsWith(this.line, \"attribute\")) {\r\n value = processor.attributeProcessor(this.line);\r\n }\r\n else if (processor.varyingProcessor && StringTools.StartsWith(this.line, \"varying\")) {\r\n value = processor.varyingProcessor(this.line, options.isFragment);\r\n }\r\n else if ((processor.uniformProcessor || processor.uniformBufferProcessor) && StringTools.StartsWith(this.line, \"uniform\")) {\r\n var regex = /uniform (.+) (.+)/;\r\n if (regex.test(this.line)) { // uniform\r\n if (processor.uniformProcessor) {\r\n value = processor.uniformProcessor(this.line, options.isFragment);\r\n }\r\n }\r\n else { // Uniform buffer\r\n if (processor.uniformBufferProcessor) {\r\n value = processor.uniformBufferProcessor(this.line, options.isFragment);\r\n options.lookForClosingBracketForUniformBuffer = true;\r\n }\r\n }\r\n }\r\n if (processor.endOfUniformBufferProcessor) {\r\n if (options.lookForClosingBracketForUniformBuffer && this.line.indexOf(\"}\") !== -1) {\r\n options.lookForClosingBracketForUniformBuffer = false;\r\n value = processor.endOfUniformBufferProcessor(this.line, options.isFragment);\r\n }\r\n }\r\n }\r\n result += value + \"\\r\\n\";\r\n }\r\n this.children.forEach(function (child) {\r\n result += child.process(preprocessors, options);\r\n });\r\n if (this.additionalDefineKey) {\r\n preprocessors[this.additionalDefineKey] = this.additionalDefineValue || \"true\";\r\n }\r\n return result;\r\n };\r\n return ShaderCodeNode;\r\n}());\r\nexport { ShaderCodeNode };\r\n//# sourceMappingURL=shaderCodeNode.js.map","/** @hidden */\r\nvar ShaderCodeCursor = /** @class */ (function () {\r\n function ShaderCodeCursor() {\r\n }\r\n Object.defineProperty(ShaderCodeCursor.prototype, \"currentLine\", {\r\n get: function () {\r\n return this._lines[this.lineIndex];\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ShaderCodeCursor.prototype, \"canRead\", {\r\n get: function () {\r\n return this.lineIndex < this._lines.length - 1;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ShaderCodeCursor.prototype, \"lines\", {\r\n set: function (value) {\r\n this._lines = [];\r\n for (var _i = 0, value_1 = value; _i < value_1.length; _i++) {\r\n var line = value_1[_i];\r\n // Prevent removing line break in macros.\r\n if (line[0] === \"#\") {\r\n this._lines.push(line);\r\n continue;\r\n }\r\n var split = line.split(\";\");\r\n for (var index = 0; index < split.length; index++) {\r\n var subLine = split[index];\r\n subLine = subLine.trim();\r\n if (!subLine) {\r\n continue;\r\n }\r\n this._lines.push(subLine + (index !== split.length - 1 ? \";\" : \"\"));\r\n }\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n return ShaderCodeCursor;\r\n}());\r\nexport { ShaderCodeCursor };\r\n//# sourceMappingURL=shaderCodeCursor.js.map","import { __extends } from \"tslib\";\r\nimport { ShaderCodeNode } from './shaderCodeNode';\r\n/** @hidden */\r\nvar ShaderCodeConditionNode = /** @class */ (function (_super) {\r\n __extends(ShaderCodeConditionNode, _super);\r\n function ShaderCodeConditionNode() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n ShaderCodeConditionNode.prototype.process = function (preprocessors, options) {\r\n for (var index = 0; index < this.children.length; index++) {\r\n var node = this.children[index];\r\n if (node.isValid(preprocessors)) {\r\n return node.process(preprocessors, options);\r\n }\r\n }\r\n return \"\";\r\n };\r\n return ShaderCodeConditionNode;\r\n}(ShaderCodeNode));\r\nexport { ShaderCodeConditionNode };\r\n//# sourceMappingURL=shaderCodeConditionNode.js.map","import { __extends } from \"tslib\";\r\nimport { ShaderCodeNode } from './shaderCodeNode';\r\n/** @hidden */\r\nvar ShaderCodeTestNode = /** @class */ (function (_super) {\r\n __extends(ShaderCodeTestNode, _super);\r\n function ShaderCodeTestNode() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n ShaderCodeTestNode.prototype.isValid = function (preprocessors) {\r\n return this.testExpression.isTrue(preprocessors);\r\n };\r\n return ShaderCodeTestNode;\r\n}(ShaderCodeNode));\r\nexport { ShaderCodeTestNode };\r\n//# sourceMappingURL=shaderCodeTestNode.js.map","/** @hidden */\r\nvar ShaderDefineExpression = /** @class */ (function () {\r\n function ShaderDefineExpression() {\r\n }\r\n ShaderDefineExpression.prototype.isTrue = function (preprocessors) {\r\n return true;\r\n };\r\n ShaderDefineExpression.postfixToInfix = function (postfix) {\r\n var stack = [];\r\n for (var _i = 0, postfix_1 = postfix; _i < postfix_1.length; _i++) {\r\n var c = postfix_1[_i];\r\n if (ShaderDefineExpression._OperatorPriority[c] === undefined) {\r\n stack.push(c);\r\n }\r\n else {\r\n var v1 = stack[stack.length - 1], v2 = stack[stack.length - 2];\r\n stack.length -= 2;\r\n stack.push(\"(\" + v2 + c + v1 + \")\");\r\n }\r\n }\r\n return stack[stack.length - 1];\r\n };\r\n ShaderDefineExpression.infixToPostfix = function (infix) {\r\n var result = [];\r\n var stackIdx = -1;\r\n var pushOperand = function () {\r\n operand = operand.trim();\r\n if (operand !== '') {\r\n result.push(operand);\r\n operand = '';\r\n }\r\n };\r\n var push = function (s) {\r\n if (stackIdx < ShaderDefineExpression._Stack.length - 1) {\r\n ShaderDefineExpression._Stack[++stackIdx] = s;\r\n }\r\n };\r\n var peek = function () { return ShaderDefineExpression._Stack[stackIdx]; };\r\n var pop = function () { return stackIdx === -1 ? '!!INVALID EXPRESSION!!' : ShaderDefineExpression._Stack[stackIdx--]; };\r\n var idx = 0, operand = '';\r\n while (idx < infix.length) {\r\n var c = infix.charAt(idx), token = idx < infix.length - 1 ? infix.substr(idx, 2) : '';\r\n if (c === '(') {\r\n operand = '';\r\n push(c);\r\n }\r\n else if (c === ')') {\r\n pushOperand();\r\n while (stackIdx !== -1 && peek() !== '(') {\r\n result.push(pop());\r\n }\r\n pop();\r\n }\r\n else if (ShaderDefineExpression._OperatorPriority[token] > 1) {\r\n pushOperand();\r\n while (stackIdx !== -1 && ShaderDefineExpression._OperatorPriority[peek()] >= ShaderDefineExpression._OperatorPriority[token]) {\r\n result.push(pop());\r\n }\r\n push(token);\r\n idx++;\r\n }\r\n else {\r\n operand += c;\r\n }\r\n idx++;\r\n }\r\n pushOperand();\r\n while (stackIdx !== -1) {\r\n if (peek() === '(') {\r\n pop();\r\n }\r\n else {\r\n result.push(pop());\r\n }\r\n }\r\n return result;\r\n };\r\n ShaderDefineExpression._OperatorPriority = {\r\n \")\": 0,\r\n \"(\": 1,\r\n \"||\": 2,\r\n \"&&\": 3,\r\n };\r\n ShaderDefineExpression._Stack = ['', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', ''];\r\n return ShaderDefineExpression;\r\n}());\r\nexport { ShaderDefineExpression };\r\n//# sourceMappingURL=shaderDefineExpression.js.map","import { __extends } from \"tslib\";\r\nimport { ShaderDefineExpression } from \"../shaderDefineExpression\";\r\n/** @hidden */\r\nvar ShaderDefineIsDefinedOperator = /** @class */ (function (_super) {\r\n __extends(ShaderDefineIsDefinedOperator, _super);\r\n function ShaderDefineIsDefinedOperator(define, not) {\r\n if (not === void 0) { not = false; }\r\n var _this = _super.call(this) || this;\r\n _this.define = define;\r\n _this.not = not;\r\n return _this;\r\n }\r\n ShaderDefineIsDefinedOperator.prototype.isTrue = function (preprocessors) {\r\n var condition = preprocessors[this.define] !== undefined;\r\n if (this.not) {\r\n condition = !condition;\r\n }\r\n return condition;\r\n };\r\n return ShaderDefineIsDefinedOperator;\r\n}(ShaderDefineExpression));\r\nexport { ShaderDefineIsDefinedOperator };\r\n//# sourceMappingURL=shaderDefineIsDefinedOperator.js.map","import { __extends } from \"tslib\";\r\nimport { ShaderDefineExpression } from '../shaderDefineExpression';\r\n/** @hidden */\r\nvar ShaderDefineOrOperator = /** @class */ (function (_super) {\r\n __extends(ShaderDefineOrOperator, _super);\r\n function ShaderDefineOrOperator() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n ShaderDefineOrOperator.prototype.isTrue = function (preprocessors) {\r\n return this.leftOperand.isTrue(preprocessors) || this.rightOperand.isTrue(preprocessors);\r\n };\r\n return ShaderDefineOrOperator;\r\n}(ShaderDefineExpression));\r\nexport { ShaderDefineOrOperator };\r\n//# sourceMappingURL=shaderDefineOrOperator.js.map","import { __extends } from \"tslib\";\r\nimport { ShaderDefineExpression } from '../shaderDefineExpression';\r\n/** @hidden */\r\nvar ShaderDefineAndOperator = /** @class */ (function (_super) {\r\n __extends(ShaderDefineAndOperator, _super);\r\n function ShaderDefineAndOperator() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n ShaderDefineAndOperator.prototype.isTrue = function (preprocessors) {\r\n return this.leftOperand.isTrue(preprocessors) && this.rightOperand.isTrue(preprocessors);\r\n };\r\n return ShaderDefineAndOperator;\r\n}(ShaderDefineExpression));\r\nexport { ShaderDefineAndOperator };\r\n//# sourceMappingURL=shaderDefineAndOperator.js.map","import { __extends } from \"tslib\";\r\nimport { ShaderDefineExpression } from '../shaderDefineExpression';\r\n/** @hidden */\r\nvar ShaderDefineArithmeticOperator = /** @class */ (function (_super) {\r\n __extends(ShaderDefineArithmeticOperator, _super);\r\n function ShaderDefineArithmeticOperator(define, operand, testValue) {\r\n var _this = _super.call(this) || this;\r\n _this.define = define;\r\n _this.operand = operand;\r\n _this.testValue = testValue;\r\n return _this;\r\n }\r\n ShaderDefineArithmeticOperator.prototype.isTrue = function (preprocessors) {\r\n var value = preprocessors[this.define];\r\n if (value === undefined) {\r\n value = this.define;\r\n }\r\n var condition = false;\r\n var left = parseInt(value);\r\n var right = parseInt(this.testValue);\r\n switch (this.operand) {\r\n case \">\":\r\n condition = left > right;\r\n break;\r\n case \"<\":\r\n condition = left < right;\r\n break;\r\n case \"<=\":\r\n condition = left <= right;\r\n break;\r\n case \">=\":\r\n condition = left >= right;\r\n break;\r\n case \"==\":\r\n condition = left === right;\r\n break;\r\n }\r\n return condition;\r\n };\r\n return ShaderDefineArithmeticOperator;\r\n}(ShaderDefineExpression));\r\nexport { ShaderDefineArithmeticOperator };\r\n//# sourceMappingURL=shaderDefineArithmeticOperator.js.map","import { ShaderCodeNode } from './shaderCodeNode';\r\nimport { ShaderCodeCursor } from './shaderCodeCursor';\r\nimport { ShaderCodeConditionNode } from './shaderCodeConditionNode';\r\nimport { ShaderCodeTestNode } from './shaderCodeTestNode';\r\nimport { ShaderDefineIsDefinedOperator } from './Expressions/Operators/shaderDefineIsDefinedOperator';\r\nimport { ShaderDefineOrOperator } from './Expressions/Operators/shaderDefineOrOperator';\r\nimport { ShaderDefineAndOperator } from './Expressions/Operators/shaderDefineAndOperator';\r\nimport { ShaderDefineExpression } from './Expressions/shaderDefineExpression';\r\nimport { ShaderDefineArithmeticOperator } from './Expressions/Operators/shaderDefineArithmeticOperator';\r\nimport { _DevTools } from '../../Misc/devTools';\r\nvar regexSE = /defined\\s*?\\((.+?)\\)/g;\r\nvar regexSERevert = /defined\\s*?\\[(.+?)\\]/g;\r\n/** @hidden */\r\nvar ShaderProcessor = /** @class */ (function () {\r\n function ShaderProcessor() {\r\n }\r\n ShaderProcessor.Process = function (sourceCode, options, callback, engine) {\r\n var _this = this;\r\n this._ProcessIncludes(sourceCode, options, function (codeWithIncludes) {\r\n var migratedCode = _this._ProcessShaderConversion(codeWithIncludes, options, engine);\r\n callback(migratedCode);\r\n });\r\n };\r\n ShaderProcessor._ProcessPrecision = function (source, options) {\r\n var shouldUseHighPrecisionShader = options.shouldUseHighPrecisionShader;\r\n if (source.indexOf(\"precision highp float\") === -1) {\r\n if (!shouldUseHighPrecisionShader) {\r\n source = \"precision mediump float;\\n\" + source;\r\n }\r\n else {\r\n source = \"precision highp float;\\n\" + source;\r\n }\r\n }\r\n else {\r\n if (!shouldUseHighPrecisionShader) { // Moving highp to mediump\r\n source = source.replace(\"precision highp float\", \"precision mediump float\");\r\n }\r\n }\r\n return source;\r\n };\r\n ShaderProcessor._ExtractOperation = function (expression) {\r\n var regex = /defined\\((.+)\\)/;\r\n var match = regex.exec(expression);\r\n if (match && match.length) {\r\n return new ShaderDefineIsDefinedOperator(match[1].trim(), expression[0] === \"!\");\r\n }\r\n var operators = [\"==\", \">=\", \"<=\", \"<\", \">\"];\r\n var operator = \"\";\r\n var indexOperator = 0;\r\n for (var _i = 0, operators_1 = operators; _i < operators_1.length; _i++) {\r\n operator = operators_1[_i];\r\n indexOperator = expression.indexOf(operator);\r\n if (indexOperator > -1) {\r\n break;\r\n }\r\n }\r\n if (indexOperator === -1) {\r\n return new ShaderDefineIsDefinedOperator(expression);\r\n }\r\n var define = expression.substring(0, indexOperator).trim();\r\n var value = expression.substring(indexOperator + operator.length).trim();\r\n return new ShaderDefineArithmeticOperator(define, operator, value);\r\n };\r\n ShaderProcessor._BuildSubExpression = function (expression) {\r\n expression = expression.replace(regexSE, \"defined[$1]\");\r\n var postfix = ShaderDefineExpression.infixToPostfix(expression);\r\n var stack = [];\r\n for (var _i = 0, postfix_1 = postfix; _i < postfix_1.length; _i++) {\r\n var c = postfix_1[_i];\r\n if (c !== '||' && c !== '&&') {\r\n stack.push(c);\r\n }\r\n else if (stack.length >= 2) {\r\n var v1 = stack[stack.length - 1], v2 = stack[stack.length - 2];\r\n stack.length -= 2;\r\n var operator = c == '&&' ? new ShaderDefineAndOperator() : new ShaderDefineOrOperator();\r\n if (typeof (v1) === 'string') {\r\n v1 = v1.replace(regexSERevert, \"defined($1)\");\r\n }\r\n if (typeof (v2) === 'string') {\r\n v2 = v2.replace(regexSERevert, \"defined($1)\");\r\n }\r\n operator.leftOperand = typeof (v2) === 'string' ? this._ExtractOperation(v2) : v2;\r\n operator.rightOperand = typeof (v1) === 'string' ? this._ExtractOperation(v1) : v1;\r\n stack.push(operator);\r\n }\r\n }\r\n var result = stack[stack.length - 1];\r\n if (typeof (result) === 'string') {\r\n result = result.replace(regexSERevert, \"defined($1)\");\r\n }\r\n // note: stack.length !== 1 if there was an error in the parsing\r\n return typeof (result) === 'string' ? this._ExtractOperation(result) : result;\r\n };\r\n ShaderProcessor._BuildExpression = function (line, start) {\r\n var node = new ShaderCodeTestNode();\r\n var command = line.substring(0, start);\r\n var expression = line.substring(start);\r\n expression = expression.substring(0, ((expression.indexOf(\"//\") + 1) || (expression.length + 1)) - 1).trim();\r\n if (command === \"#ifdef\") {\r\n node.testExpression = new ShaderDefineIsDefinedOperator(expression);\r\n }\r\n else if (command === \"#ifndef\") {\r\n node.testExpression = new ShaderDefineIsDefinedOperator(expression, true);\r\n }\r\n else {\r\n node.testExpression = this._BuildSubExpression(expression);\r\n }\r\n return node;\r\n };\r\n ShaderProcessor._MoveCursorWithinIf = function (cursor, rootNode, ifNode) {\r\n var line = cursor.currentLine;\r\n while (this._MoveCursor(cursor, ifNode)) {\r\n line = cursor.currentLine;\r\n var first5 = line.substring(0, 5).toLowerCase();\r\n if (first5 === \"#else\") {\r\n var elseNode = new ShaderCodeNode();\r\n rootNode.children.push(elseNode);\r\n this._MoveCursor(cursor, elseNode);\r\n return;\r\n }\r\n else if (first5 === \"#elif\") {\r\n var elifNode = this._BuildExpression(line, 5);\r\n rootNode.children.push(elifNode);\r\n ifNode = elifNode;\r\n }\r\n }\r\n };\r\n ShaderProcessor._MoveCursor = function (cursor, rootNode) {\r\n while (cursor.canRead) {\r\n cursor.lineIndex++;\r\n var line = cursor.currentLine;\r\n var keywords = /(#ifdef)|(#else)|(#elif)|(#endif)|(#ifndef)|(#if)/;\r\n var matches = keywords.exec(line);\r\n if (matches && matches.length) {\r\n var keyword = matches[0];\r\n switch (keyword) {\r\n case \"#ifdef\": {\r\n var newRootNode = new ShaderCodeConditionNode();\r\n rootNode.children.push(newRootNode);\r\n var ifNode = this._BuildExpression(line, 6);\r\n newRootNode.children.push(ifNode);\r\n this._MoveCursorWithinIf(cursor, newRootNode, ifNode);\r\n break;\r\n }\r\n case \"#else\":\r\n case \"#elif\":\r\n return true;\r\n case \"#endif\":\r\n return false;\r\n case \"#ifndef\": {\r\n var newRootNode = new ShaderCodeConditionNode();\r\n rootNode.children.push(newRootNode);\r\n var ifNode = this._BuildExpression(line, 7);\r\n newRootNode.children.push(ifNode);\r\n this._MoveCursorWithinIf(cursor, newRootNode, ifNode);\r\n break;\r\n }\r\n case \"#if\": {\r\n var newRootNode = new ShaderCodeConditionNode();\r\n var ifNode = this._BuildExpression(line, 3);\r\n rootNode.children.push(newRootNode);\r\n newRootNode.children.push(ifNode);\r\n this._MoveCursorWithinIf(cursor, newRootNode, ifNode);\r\n break;\r\n }\r\n }\r\n }\r\n else {\r\n var newNode = new ShaderCodeNode();\r\n newNode.line = line;\r\n rootNode.children.push(newNode);\r\n // Detect additional defines\r\n if (line[0] === \"#\" && line[1] === \"d\") {\r\n var split = line.replace(\";\", \"\").split(\" \");\r\n newNode.additionalDefineKey = split[1];\r\n if (split.length === 3) {\r\n newNode.additionalDefineValue = split[2];\r\n }\r\n }\r\n }\r\n }\r\n return false;\r\n };\r\n ShaderProcessor._EvaluatePreProcessors = function (sourceCode, preprocessors, options) {\r\n var rootNode = new ShaderCodeNode();\r\n var cursor = new ShaderCodeCursor();\r\n cursor.lineIndex = -1;\r\n cursor.lines = sourceCode.split(\"\\n\");\r\n // Decompose (We keep it in 2 steps so it is easier to maintain and perf hit is insignificant)\r\n this._MoveCursor(cursor, rootNode);\r\n // Recompose\r\n return rootNode.process(preprocessors, options);\r\n };\r\n ShaderProcessor._PreparePreProcessors = function (options) {\r\n var defines = options.defines;\r\n var preprocessors = {};\r\n for (var _i = 0, defines_1 = defines; _i < defines_1.length; _i++) {\r\n var define = defines_1[_i];\r\n var keyValue = define.replace(\"#define\", \"\").replace(\";\", \"\").trim();\r\n var split = keyValue.split(\" \");\r\n preprocessors[split[0]] = split.length > 1 ? split[1] : \"\";\r\n }\r\n preprocessors[\"GL_ES\"] = \"true\";\r\n preprocessors[\"__VERSION__\"] = options.version;\r\n preprocessors[options.platformName] = \"true\";\r\n return preprocessors;\r\n };\r\n ShaderProcessor._ProcessShaderConversion = function (sourceCode, options, engine) {\r\n var preparedSourceCode = this._ProcessPrecision(sourceCode, options);\r\n if (!options.processor) {\r\n return preparedSourceCode;\r\n }\r\n // Already converted\r\n if (preparedSourceCode.indexOf(\"#version 3\") !== -1) {\r\n return preparedSourceCode.replace(\"#version 300 es\", \"\");\r\n }\r\n var defines = options.defines;\r\n var preprocessors = this._PreparePreProcessors(options);\r\n // General pre processing\r\n if (options.processor.preProcessor) {\r\n preparedSourceCode = options.processor.preProcessor(preparedSourceCode, defines, options.isFragment);\r\n }\r\n preparedSourceCode = this._EvaluatePreProcessors(preparedSourceCode, preprocessors, options);\r\n // Post processing\r\n if (options.processor.postProcessor) {\r\n preparedSourceCode = options.processor.postProcessor(preparedSourceCode, defines, options.isFragment, engine);\r\n }\r\n return preparedSourceCode;\r\n };\r\n ShaderProcessor._ProcessIncludes = function (sourceCode, options, callback) {\r\n var _this = this;\r\n var regex = /#include<(.+)>(\\((.*)\\))*(\\[(.*)\\])*/g;\r\n var match = regex.exec(sourceCode);\r\n var returnValue = new String(sourceCode);\r\n var keepProcessing = false;\r\n while (match != null) {\r\n var includeFile = match[1];\r\n // Uniform declaration\r\n if (includeFile.indexOf(\"__decl__\") !== -1) {\r\n includeFile = includeFile.replace(/__decl__/, \"\");\r\n if (options.supportsUniformBuffers) {\r\n includeFile = includeFile.replace(/Vertex/, \"Ubo\");\r\n includeFile = includeFile.replace(/Fragment/, \"Ubo\");\r\n }\r\n includeFile = includeFile + \"Declaration\";\r\n }\r\n if (options.includesShadersStore[includeFile]) {\r\n // Substitution\r\n var includeContent = options.includesShadersStore[includeFile];\r\n if (match[2]) {\r\n var splits = match[3].split(\",\");\r\n for (var index = 0; index < splits.length; index += 2) {\r\n var source = new RegExp(splits[index], \"g\");\r\n var dest = splits[index + 1];\r\n includeContent = includeContent.replace(source, dest);\r\n }\r\n }\r\n if (match[4]) {\r\n var indexString = match[5];\r\n if (indexString.indexOf(\"..\") !== -1) {\r\n var indexSplits = indexString.split(\"..\");\r\n var minIndex = parseInt(indexSplits[0]);\r\n var maxIndex = parseInt(indexSplits[1]);\r\n var sourceIncludeContent = includeContent.slice(0);\r\n includeContent = \"\";\r\n if (isNaN(maxIndex)) {\r\n maxIndex = options.indexParameters[indexSplits[1]];\r\n }\r\n for (var i = minIndex; i < maxIndex; i++) {\r\n if (!options.supportsUniformBuffers) {\r\n // Ubo replacement\r\n sourceIncludeContent = sourceIncludeContent.replace(/light\\{X\\}.(\\w*)/g, function (str, p1) {\r\n return p1 + \"{X}\";\r\n });\r\n }\r\n includeContent += sourceIncludeContent.replace(/\\{X\\}/g, i.toString()) + \"\\n\";\r\n }\r\n }\r\n else {\r\n if (!options.supportsUniformBuffers) {\r\n // Ubo replacement\r\n includeContent = includeContent.replace(/light\\{X\\}.(\\w*)/g, function (str, p1) {\r\n return p1 + \"{X}\";\r\n });\r\n }\r\n includeContent = includeContent.replace(/\\{X\\}/g, indexString);\r\n }\r\n }\r\n // Replace\r\n returnValue = returnValue.replace(match[0], includeContent);\r\n keepProcessing = keepProcessing || includeContent.indexOf(\"#include<\") >= 0;\r\n }\r\n else {\r\n var includeShaderUrl = options.shadersRepository + \"ShadersInclude/\" + includeFile + \".fx\";\r\n ShaderProcessor._FileToolsLoadFile(includeShaderUrl, function (fileContent) {\r\n options.includesShadersStore[includeFile] = fileContent;\r\n _this._ProcessIncludes(returnValue, options, callback);\r\n });\r\n return;\r\n }\r\n match = regex.exec(sourceCode);\r\n }\r\n if (keepProcessing) {\r\n this._ProcessIncludes(returnValue.toString(), options, callback);\r\n }\r\n else {\r\n callback(returnValue);\r\n }\r\n };\r\n /**\r\n * Loads a file from a url\r\n * @param url url to load\r\n * @param onSuccess callback called when the file successfully loads\r\n * @param onProgress callback called while file is loading (if the server supports this mode)\r\n * @param offlineProvider defines the offline provider for caching\r\n * @param useArrayBuffer defines a boolean indicating that date must be returned as ArrayBuffer\r\n * @param onError callback called when the file fails to load\r\n * @returns a file request object\r\n * @hidden\r\n */\r\n ShaderProcessor._FileToolsLoadFile = function (url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError) {\r\n throw _DevTools.WarnImport(\"FileTools\");\r\n };\r\n return ShaderProcessor;\r\n}());\r\nexport { ShaderProcessor };\r\n//# sourceMappingURL=shaderProcessor.js.map","import { Scalar } from \"./math.scalar\";\r\nimport { Vector2, Vector3, Quaternion, Matrix } from \"./math.vector\";\r\nimport { Epsilon } from \"./math.constants\";\r\n/**\r\n * Defines potential orientation for back face culling\r\n */\r\nexport var Orientation;\r\n(function (Orientation) {\r\n /**\r\n * Clockwise\r\n */\r\n Orientation[Orientation[\"CW\"] = 0] = \"CW\";\r\n /** Counter clockwise */\r\n Orientation[Orientation[\"CCW\"] = 1] = \"CCW\";\r\n})(Orientation || (Orientation = {}));\r\n/** Class used to represent a Bezier curve */\r\nvar BezierCurve = /** @class */ (function () {\r\n function BezierCurve() {\r\n }\r\n /**\r\n * Returns the cubic Bezier interpolated value (float) at \"t\" (float) from the given x1, y1, x2, y2 floats\r\n * @param t defines the time\r\n * @param x1 defines the left coordinate on X axis\r\n * @param y1 defines the left coordinate on Y axis\r\n * @param x2 defines the right coordinate on X axis\r\n * @param y2 defines the right coordinate on Y axis\r\n * @returns the interpolated value\r\n */\r\n BezierCurve.Interpolate = function (t, x1, y1, x2, y2) {\r\n // Extract X (which is equal to time here)\r\n var f0 = 1 - 3 * x2 + 3 * x1;\r\n var f1 = 3 * x2 - 6 * x1;\r\n var f2 = 3 * x1;\r\n var refinedT = t;\r\n for (var i = 0; i < 5; i++) {\r\n var refinedT2 = refinedT * refinedT;\r\n var refinedT3 = refinedT2 * refinedT;\r\n var x = f0 * refinedT3 + f1 * refinedT2 + f2 * refinedT;\r\n var slope = 1.0 / (3.0 * f0 * refinedT2 + 2.0 * f1 * refinedT + f2);\r\n refinedT -= (x - t) * slope;\r\n refinedT = Math.min(1, Math.max(0, refinedT));\r\n }\r\n // Resolve cubic bezier for the given x\r\n return 3 * Math.pow(1 - refinedT, 2) * refinedT * y1 + 3 * (1 - refinedT) * Math.pow(refinedT, 2) * y2 + Math.pow(refinedT, 3);\r\n };\r\n return BezierCurve;\r\n}());\r\nexport { BezierCurve };\r\n/**\r\n * Defines angle representation\r\n */\r\nvar Angle = /** @class */ (function () {\r\n /**\r\n * Creates an Angle object of \"radians\" radians (float).\r\n * @param radians the angle in radians\r\n */\r\n function Angle(radians) {\r\n this._radians = radians;\r\n if (this._radians < 0.0) {\r\n this._radians += 2.0 * Math.PI;\r\n }\r\n }\r\n /**\r\n * Get value in degrees\r\n * @returns the Angle value in degrees (float)\r\n */\r\n Angle.prototype.degrees = function () {\r\n return (this._radians * 180.0) / Math.PI;\r\n };\r\n /**\r\n * Get value in radians\r\n * @returns the Angle value in radians (float)\r\n */\r\n Angle.prototype.radians = function () {\r\n return this._radians;\r\n };\r\n /**\r\n * Gets a new Angle object valued with the gradient angle, in radians, of the line joining two points\r\n * @param a defines first point as the origin\r\n * @param b defines point\r\n * @returns a new Angle\r\n */\r\n Angle.BetweenTwoPoints = function (a, b) {\r\n var delta = b.subtract(a);\r\n var theta = Math.atan2(delta.y, delta.x);\r\n return new Angle(theta);\r\n };\r\n /**\r\n * Gets a new Angle object from the given float in radians\r\n * @param radians defines the angle value in radians\r\n * @returns a new Angle\r\n */\r\n Angle.FromRadians = function (radians) {\r\n return new Angle(radians);\r\n };\r\n /**\r\n * Gets a new Angle object from the given float in degrees\r\n * @param degrees defines the angle value in degrees\r\n * @returns a new Angle\r\n */\r\n Angle.FromDegrees = function (degrees) {\r\n return new Angle((degrees * Math.PI) / 180.0);\r\n };\r\n return Angle;\r\n}());\r\nexport { Angle };\r\n/**\r\n * This represents an arc in a 2d space.\r\n */\r\nvar Arc2 = /** @class */ (function () {\r\n /**\r\n * Creates an Arc object from the three given points : start, middle and end.\r\n * @param startPoint Defines the start point of the arc\r\n * @param midPoint Defines the midlle point of the arc\r\n * @param endPoint Defines the end point of the arc\r\n */\r\n function Arc2(\r\n /** Defines the start point of the arc */\r\n startPoint, \r\n /** Defines the mid point of the arc */\r\n midPoint, \r\n /** Defines the end point of the arc */\r\n endPoint) {\r\n this.startPoint = startPoint;\r\n this.midPoint = midPoint;\r\n this.endPoint = endPoint;\r\n var temp = Math.pow(midPoint.x, 2) + Math.pow(midPoint.y, 2);\r\n var startToMid = (Math.pow(startPoint.x, 2) + Math.pow(startPoint.y, 2) - temp) / 2;\r\n var midToEnd = (temp - Math.pow(endPoint.x, 2) - Math.pow(endPoint.y, 2)) / 2;\r\n var det = (startPoint.x - midPoint.x) * (midPoint.y - endPoint.y) - (midPoint.x - endPoint.x) * (startPoint.y - midPoint.y);\r\n this.centerPoint = new Vector2((startToMid * (midPoint.y - endPoint.y) - midToEnd * (startPoint.y - midPoint.y)) / det, ((startPoint.x - midPoint.x) * midToEnd - (midPoint.x - endPoint.x) * startToMid) / det);\r\n this.radius = this.centerPoint.subtract(this.startPoint).length();\r\n this.startAngle = Angle.BetweenTwoPoints(this.centerPoint, this.startPoint);\r\n var a1 = this.startAngle.degrees();\r\n var a2 = Angle.BetweenTwoPoints(this.centerPoint, this.midPoint).degrees();\r\n var a3 = Angle.BetweenTwoPoints(this.centerPoint, this.endPoint).degrees();\r\n // angles correction\r\n if (a2 - a1 > +180.0) {\r\n a2 -= 360.0;\r\n }\r\n if (a2 - a1 < -180.0) {\r\n a2 += 360.0;\r\n }\r\n if (a3 - a2 > +180.0) {\r\n a3 -= 360.0;\r\n }\r\n if (a3 - a2 < -180.0) {\r\n a3 += 360.0;\r\n }\r\n this.orientation = a2 - a1 < 0 ? Orientation.CW : Orientation.CCW;\r\n this.angle = Angle.FromDegrees(this.orientation === Orientation.CW ? a1 - a3 : a3 - a1);\r\n }\r\n return Arc2;\r\n}());\r\nexport { Arc2 };\r\n/**\r\n * Represents a 2D path made up of multiple 2D points\r\n */\r\nvar Path2 = /** @class */ (function () {\r\n /**\r\n * Creates a Path2 object from the starting 2D coordinates x and y.\r\n * @param x the starting points x value\r\n * @param y the starting points y value\r\n */\r\n function Path2(x, y) {\r\n this._points = new Array();\r\n this._length = 0.0;\r\n /**\r\n * If the path start and end point are the same\r\n */\r\n this.closed = false;\r\n this._points.push(new Vector2(x, y));\r\n }\r\n /**\r\n * Adds a new segment until the given coordinates (x, y) to the current Path2.\r\n * @param x the added points x value\r\n * @param y the added points y value\r\n * @returns the updated Path2.\r\n */\r\n Path2.prototype.addLineTo = function (x, y) {\r\n if (this.closed) {\r\n return this;\r\n }\r\n var newPoint = new Vector2(x, y);\r\n var previousPoint = this._points[this._points.length - 1];\r\n this._points.push(newPoint);\r\n this._length += newPoint.subtract(previousPoint).length();\r\n return this;\r\n };\r\n /**\r\n * Adds _numberOfSegments_ segments according to the arc definition (middle point coordinates, end point coordinates, the arc start point being the current Path2 last point) to the current Path2.\r\n * @param midX middle point x value\r\n * @param midY middle point y value\r\n * @param endX end point x value\r\n * @param endY end point y value\r\n * @param numberOfSegments (default: 36)\r\n * @returns the updated Path2.\r\n */\r\n Path2.prototype.addArcTo = function (midX, midY, endX, endY, numberOfSegments) {\r\n if (numberOfSegments === void 0) { numberOfSegments = 36; }\r\n if (this.closed) {\r\n return this;\r\n }\r\n var startPoint = this._points[this._points.length - 1];\r\n var midPoint = new Vector2(midX, midY);\r\n var endPoint = new Vector2(endX, endY);\r\n var arc = new Arc2(startPoint, midPoint, endPoint);\r\n var increment = arc.angle.radians() / numberOfSegments;\r\n if (arc.orientation === Orientation.CW) {\r\n increment *= -1;\r\n }\r\n var currentAngle = arc.startAngle.radians() + increment;\r\n for (var i = 0; i < numberOfSegments; i++) {\r\n var x = Math.cos(currentAngle) * arc.radius + arc.centerPoint.x;\r\n var y = Math.sin(currentAngle) * arc.radius + arc.centerPoint.y;\r\n this.addLineTo(x, y);\r\n currentAngle += increment;\r\n }\r\n return this;\r\n };\r\n /**\r\n * Closes the Path2.\r\n * @returns the Path2.\r\n */\r\n Path2.prototype.close = function () {\r\n this.closed = true;\r\n return this;\r\n };\r\n /**\r\n * Gets the sum of the distance between each sequential point in the path\r\n * @returns the Path2 total length (float).\r\n */\r\n Path2.prototype.length = function () {\r\n var result = this._length;\r\n if (this.closed) {\r\n var lastPoint = this._points[this._points.length - 1];\r\n var firstPoint = this._points[0];\r\n result += firstPoint.subtract(lastPoint).length();\r\n }\r\n return result;\r\n };\r\n /**\r\n * Gets the points which construct the path\r\n * @returns the Path2 internal array of points.\r\n */\r\n Path2.prototype.getPoints = function () {\r\n return this._points;\r\n };\r\n /**\r\n * Retreives the point at the distance aways from the starting point\r\n * @param normalizedLengthPosition the length along the path to retreive the point from\r\n * @returns a new Vector2 located at a percentage of the Path2 total length on this path.\r\n */\r\n Path2.prototype.getPointAtLengthPosition = function (normalizedLengthPosition) {\r\n if (normalizedLengthPosition < 0 || normalizedLengthPosition > 1) {\r\n return Vector2.Zero();\r\n }\r\n var lengthPosition = normalizedLengthPosition * this.length();\r\n var previousOffset = 0;\r\n for (var i = 0; i < this._points.length; i++) {\r\n var j = (i + 1) % this._points.length;\r\n var a = this._points[i];\r\n var b = this._points[j];\r\n var bToA = b.subtract(a);\r\n var nextOffset = bToA.length() + previousOffset;\r\n if (lengthPosition >= previousOffset && lengthPosition <= nextOffset) {\r\n var dir = bToA.normalize();\r\n var localOffset = lengthPosition - previousOffset;\r\n return new Vector2(a.x + dir.x * localOffset, a.y + dir.y * localOffset);\r\n }\r\n previousOffset = nextOffset;\r\n }\r\n return Vector2.Zero();\r\n };\r\n /**\r\n * Creates a new path starting from an x and y position\r\n * @param x starting x value\r\n * @param y starting y value\r\n * @returns a new Path2 starting at the coordinates (x, y).\r\n */\r\n Path2.StartingAt = function (x, y) {\r\n return new Path2(x, y);\r\n };\r\n return Path2;\r\n}());\r\nexport { Path2 };\r\n/**\r\n * Represents a 3D path made up of multiple 3D points\r\n */\r\nvar Path3D = /** @class */ (function () {\r\n /**\r\n * new Path3D(path, normal, raw)\r\n * Creates a Path3D. A Path3D is a logical math object, so not a mesh.\r\n * please read the description in the tutorial : https://doc.babylonjs.com/how_to/how_to_use_path3d\r\n * @param path an array of Vector3, the curve axis of the Path3D\r\n * @param firstNormal (options) Vector3, the first wanted normal to the curve. Ex (0, 1, 0) for a vertical normal.\r\n * @param raw (optional, default false) : boolean, if true the returned Path3D isn't normalized. Useful to depict path acceleration or speed.\r\n * @param alignTangentsWithPath (optional, default false) : boolean, if true the tangents will be aligned with the path.\r\n */\r\n function Path3D(\r\n /**\r\n * an array of Vector3, the curve axis of the Path3D\r\n */\r\n path, firstNormal, raw, alignTangentsWithPath) {\r\n if (firstNormal === void 0) { firstNormal = null; }\r\n if (alignTangentsWithPath === void 0) { alignTangentsWithPath = false; }\r\n this.path = path;\r\n this._curve = new Array();\r\n this._distances = new Array();\r\n this._tangents = new Array();\r\n this._normals = new Array();\r\n this._binormals = new Array();\r\n // holds interpolated point data\r\n this._pointAtData = {\r\n id: 0,\r\n point: Vector3.Zero(),\r\n previousPointArrayIndex: 0,\r\n position: 0,\r\n subPosition: 0,\r\n interpolateReady: false,\r\n interpolationMatrix: Matrix.Identity(),\r\n };\r\n for (var p = 0; p < path.length; p++) {\r\n this._curve[p] = path[p].clone(); // hard copy\r\n }\r\n this._raw = raw || false;\r\n this._alignTangentsWithPath = alignTangentsWithPath;\r\n this._compute(firstNormal, alignTangentsWithPath);\r\n }\r\n /**\r\n * Returns the Path3D array of successive Vector3 designing its curve.\r\n * @returns the Path3D array of successive Vector3 designing its curve.\r\n */\r\n Path3D.prototype.getCurve = function () {\r\n return this._curve;\r\n };\r\n /**\r\n * Returns the Path3D array of successive Vector3 designing its curve.\r\n * @returns the Path3D array of successive Vector3 designing its curve.\r\n */\r\n Path3D.prototype.getPoints = function () {\r\n return this._curve;\r\n };\r\n /**\r\n * @returns the computed length (float) of the path.\r\n */\r\n Path3D.prototype.length = function () {\r\n return this._distances[this._distances.length - 1];\r\n };\r\n /**\r\n * Returns an array populated with tangent vectors on each Path3D curve point.\r\n * @returns an array populated with tangent vectors on each Path3D curve point.\r\n */\r\n Path3D.prototype.getTangents = function () {\r\n return this._tangents;\r\n };\r\n /**\r\n * Returns an array populated with normal vectors on each Path3D curve point.\r\n * @returns an array populated with normal vectors on each Path3D curve point.\r\n */\r\n Path3D.prototype.getNormals = function () {\r\n return this._normals;\r\n };\r\n /**\r\n * Returns an array populated with binormal vectors on each Path3D curve point.\r\n * @returns an array populated with binormal vectors on each Path3D curve point.\r\n */\r\n Path3D.prototype.getBinormals = function () {\r\n return this._binormals;\r\n };\r\n /**\r\n * Returns an array populated with distances (float) of the i-th point from the first curve point.\r\n * @returns an array populated with distances (float) of the i-th point from the first curve point.\r\n */\r\n Path3D.prototype.getDistances = function () {\r\n return this._distances;\r\n };\r\n /**\r\n * Returns an interpolated point along this path\r\n * @param position the position of the point along this path, from 0.0 to 1.0\r\n * @returns a new Vector3 as the point\r\n */\r\n Path3D.prototype.getPointAt = function (position) {\r\n return this._updatePointAtData(position).point;\r\n };\r\n /**\r\n * Returns the tangent vector of an interpolated Path3D curve point at the specified position along this path.\r\n * @param position the position of the point along this path, from 0.0 to 1.0\r\n * @param interpolated (optional, default false) : boolean, if true returns an interpolated tangent instead of the tangent of the previous path point.\r\n * @returns a tangent vector corresponding to the interpolated Path3D curve point, if not interpolated, the tangent is taken from the precomputed tangents array.\r\n */\r\n Path3D.prototype.getTangentAt = function (position, interpolated) {\r\n if (interpolated === void 0) { interpolated = false; }\r\n this._updatePointAtData(position, interpolated);\r\n return interpolated ? Vector3.TransformCoordinates(Vector3.Forward(), this._pointAtData.interpolationMatrix) : this._tangents[this._pointAtData.previousPointArrayIndex];\r\n };\r\n /**\r\n * Returns the tangent vector of an interpolated Path3D curve point at the specified position along this path.\r\n * @param position the position of the point along this path, from 0.0 to 1.0\r\n * @param interpolated (optional, default false) : boolean, if true returns an interpolated normal instead of the normal of the previous path point.\r\n * @returns a normal vector corresponding to the interpolated Path3D curve point, if not interpolated, the normal is taken from the precomputed normals array.\r\n */\r\n Path3D.prototype.getNormalAt = function (position, interpolated) {\r\n if (interpolated === void 0) { interpolated = false; }\r\n this._updatePointAtData(position, interpolated);\r\n return interpolated ? Vector3.TransformCoordinates(Vector3.Right(), this._pointAtData.interpolationMatrix) : this._normals[this._pointAtData.previousPointArrayIndex];\r\n };\r\n /**\r\n * Returns the binormal vector of an interpolated Path3D curve point at the specified position along this path.\r\n * @param position the position of the point along this path, from 0.0 to 1.0\r\n * @param interpolated (optional, default false) : boolean, if true returns an interpolated binormal instead of the binormal of the previous path point.\r\n * @returns a binormal vector corresponding to the interpolated Path3D curve point, if not interpolated, the binormal is taken from the precomputed binormals array.\r\n */\r\n Path3D.prototype.getBinormalAt = function (position, interpolated) {\r\n if (interpolated === void 0) { interpolated = false; }\r\n this._updatePointAtData(position, interpolated);\r\n return interpolated ? Vector3.TransformCoordinates(Vector3.UpReadOnly, this._pointAtData.interpolationMatrix) : this._binormals[this._pointAtData.previousPointArrayIndex];\r\n };\r\n /**\r\n * Returns the distance (float) of an interpolated Path3D curve point at the specified position along this path.\r\n * @param position the position of the point along this path, from 0.0 to 1.0\r\n * @returns the distance of the interpolated Path3D curve point at the specified position along this path.\r\n */\r\n Path3D.prototype.getDistanceAt = function (position) {\r\n return this.length() * position;\r\n };\r\n /**\r\n * Returns the array index of the previous point of an interpolated point along this path\r\n * @param position the position of the point to interpolate along this path, from 0.0 to 1.0\r\n * @returns the array index\r\n */\r\n Path3D.prototype.getPreviousPointIndexAt = function (position) {\r\n this._updatePointAtData(position);\r\n return this._pointAtData.previousPointArrayIndex;\r\n };\r\n /**\r\n * Returns the position of an interpolated point relative to the two path points it lies between, from 0.0 (point A) to 1.0 (point B)\r\n * @param position the position of the point to interpolate along this path, from 0.0 to 1.0\r\n * @returns the sub position\r\n */\r\n Path3D.prototype.getSubPositionAt = function (position) {\r\n this._updatePointAtData(position);\r\n return this._pointAtData.subPosition;\r\n };\r\n /**\r\n * Returns the position of the closest virtual point on this path to an arbitrary Vector3, from 0.0 to 1.0\r\n * @param target the vector of which to get the closest position to\r\n * @returns the position of the closest virtual point on this path to the target vector\r\n */\r\n Path3D.prototype.getClosestPositionTo = function (target) {\r\n var smallestDistance = Number.MAX_VALUE;\r\n var closestPosition = 0.0;\r\n for (var i = 0; i < this._curve.length - 1; i++) {\r\n var point = this._curve[i + 0];\r\n var tangent = this._curve[i + 1].subtract(point).normalize();\r\n var subLength = this._distances[i + 1] - this._distances[i + 0];\r\n var subPosition = Math.min((Math.max(Vector3.Dot(tangent, target.subtract(point).normalize()), 0.0) * Vector3.Distance(point, target)) / subLength, 1.0);\r\n var distance = Vector3.Distance(point.add(tangent.scale(subPosition * subLength)), target);\r\n if (distance < smallestDistance) {\r\n smallestDistance = distance;\r\n closestPosition = (this._distances[i + 0] + subLength * subPosition) / this.length();\r\n }\r\n }\r\n return closestPosition;\r\n };\r\n /**\r\n * Returns a sub path (slice) of this path\r\n * @param start the position of the fist path point, from 0.0 to 1.0, or a negative value, which will get wrapped around from the end of the path to 0.0 to 1.0 values\r\n * @param end the position of the last path point, from 0.0 to 1.0, or a negative value, which will get wrapped around from the end of the path to 0.0 to 1.0 values\r\n * @returns a sub path (slice) of this path\r\n */\r\n Path3D.prototype.slice = function (start, end) {\r\n if (start === void 0) { start = 0.0; }\r\n if (end === void 0) { end = 1.0; }\r\n if (start < 0.0) {\r\n start = 1 - ((start * -1.0) % 1.0);\r\n }\r\n if (end < 0.0) {\r\n end = 1 - ((end * -1.0) % 1.0);\r\n }\r\n if (start > end) {\r\n var _start = start;\r\n start = end;\r\n end = _start;\r\n }\r\n var curvePoints = this.getCurve();\r\n var startPoint = this.getPointAt(start);\r\n var startIndex = this.getPreviousPointIndexAt(start);\r\n var endPoint = this.getPointAt(end);\r\n var endIndex = this.getPreviousPointIndexAt(end) + 1;\r\n var slicePoints = [];\r\n if (start !== 0.0) {\r\n startIndex++;\r\n slicePoints.push(startPoint);\r\n }\r\n slicePoints.push.apply(slicePoints, curvePoints.slice(startIndex, endIndex));\r\n if (end !== 1.0 || start === 1.0) {\r\n slicePoints.push(endPoint);\r\n }\r\n return new Path3D(slicePoints, this.getNormalAt(start), this._raw, this._alignTangentsWithPath);\r\n };\r\n /**\r\n * Forces the Path3D tangent, normal, binormal and distance recomputation.\r\n * @param path path which all values are copied into the curves points\r\n * @param firstNormal which should be projected onto the curve\r\n * @param alignTangentsWithPath (optional, default false) : boolean, if true the tangents will be aligned with the path\r\n * @returns the same object updated.\r\n */\r\n Path3D.prototype.update = function (path, firstNormal, alignTangentsWithPath) {\r\n if (firstNormal === void 0) { firstNormal = null; }\r\n if (alignTangentsWithPath === void 0) { alignTangentsWithPath = false; }\r\n for (var p = 0; p < path.length; p++) {\r\n this._curve[p].x = path[p].x;\r\n this._curve[p].y = path[p].y;\r\n this._curve[p].z = path[p].z;\r\n }\r\n this._compute(firstNormal, alignTangentsWithPath);\r\n return this;\r\n };\r\n // private function compute() : computes tangents, normals and binormals\r\n Path3D.prototype._compute = function (firstNormal, alignTangentsWithPath) {\r\n if (alignTangentsWithPath === void 0) { alignTangentsWithPath = false; }\r\n var l = this._curve.length;\r\n if (l < 2) {\r\n return;\r\n }\r\n // first and last tangents\r\n this._tangents[0] = this._getFirstNonNullVector(0);\r\n if (!this._raw) {\r\n this._tangents[0].normalize();\r\n }\r\n this._tangents[l - 1] = this._curve[l - 1].subtract(this._curve[l - 2]);\r\n if (!this._raw) {\r\n this._tangents[l - 1].normalize();\r\n }\r\n // normals and binormals at first point : arbitrary vector with _normalVector()\r\n var tg0 = this._tangents[0];\r\n var pp0 = this._normalVector(tg0, firstNormal);\r\n this._normals[0] = pp0;\r\n if (!this._raw) {\r\n this._normals[0].normalize();\r\n }\r\n this._binormals[0] = Vector3.Cross(tg0, this._normals[0]);\r\n if (!this._raw) {\r\n this._binormals[0].normalize();\r\n }\r\n this._distances[0] = 0.0;\r\n // normals and binormals : next points\r\n var prev; // previous vector (segment)\r\n var cur; // current vector (segment)\r\n var curTang; // current tangent\r\n // previous normal\r\n var prevNor; // previous normal\r\n var prevBinor; // previous binormal\r\n for (var i = 1; i < l; i++) {\r\n // tangents\r\n prev = this._getLastNonNullVector(i);\r\n if (i < l - 1) {\r\n cur = this._getFirstNonNullVector(i);\r\n this._tangents[i] = alignTangentsWithPath ? cur : prev.add(cur);\r\n this._tangents[i].normalize();\r\n }\r\n this._distances[i] = this._distances[i - 1] + this._curve[i].subtract(this._curve[i - 1]).length();\r\n // normals and binormals\r\n // http://www.cs.cmu.edu/afs/andrew/scs/cs/15-462/web/old/asst2camera.html\r\n curTang = this._tangents[i];\r\n prevBinor = this._binormals[i - 1];\r\n this._normals[i] = Vector3.Cross(prevBinor, curTang);\r\n if (!this._raw) {\r\n if (this._normals[i].length() === 0) {\r\n prevNor = this._normals[i - 1];\r\n this._normals[i] = prevNor.clone();\r\n }\r\n else {\r\n this._normals[i].normalize();\r\n }\r\n }\r\n this._binormals[i] = Vector3.Cross(curTang, this._normals[i]);\r\n if (!this._raw) {\r\n this._binormals[i].normalize();\r\n }\r\n }\r\n this._pointAtData.id = NaN;\r\n };\r\n // private function getFirstNonNullVector(index)\r\n // returns the first non null vector from index : curve[index + N].subtract(curve[index])\r\n Path3D.prototype._getFirstNonNullVector = function (index) {\r\n var i = 1;\r\n var nNVector = this._curve[index + i].subtract(this._curve[index]);\r\n while (nNVector.length() === 0 && index + i + 1 < this._curve.length) {\r\n i++;\r\n nNVector = this._curve[index + i].subtract(this._curve[index]);\r\n }\r\n return nNVector;\r\n };\r\n // private function getLastNonNullVector(index)\r\n // returns the last non null vector from index : curve[index].subtract(curve[index - N])\r\n Path3D.prototype._getLastNonNullVector = function (index) {\r\n var i = 1;\r\n var nLVector = this._curve[index].subtract(this._curve[index - i]);\r\n while (nLVector.length() === 0 && index > i + 1) {\r\n i++;\r\n nLVector = this._curve[index].subtract(this._curve[index - i]);\r\n }\r\n return nLVector;\r\n };\r\n // private function normalVector(v0, vt, va) :\r\n // returns an arbitrary point in the plane defined by the point v0 and the vector vt orthogonal to this plane\r\n // if va is passed, it returns the va projection on the plane orthogonal to vt at the point v0\r\n Path3D.prototype._normalVector = function (vt, va) {\r\n var normal0;\r\n var tgl = vt.length();\r\n if (tgl === 0.0) {\r\n tgl = 1.0;\r\n }\r\n if (va === undefined || va === null) {\r\n var point;\r\n if (!Scalar.WithinEpsilon(Math.abs(vt.y) / tgl, 1.0, Epsilon)) {\r\n // search for a point in the plane\r\n point = new Vector3(0.0, -1.0, 0.0);\r\n }\r\n else if (!Scalar.WithinEpsilon(Math.abs(vt.x) / tgl, 1.0, Epsilon)) {\r\n point = new Vector3(1.0, 0.0, 0.0);\r\n }\r\n else if (!Scalar.WithinEpsilon(Math.abs(vt.z) / tgl, 1.0, Epsilon)) {\r\n point = new Vector3(0.0, 0.0, 1.0);\r\n }\r\n else {\r\n point = Vector3.Zero();\r\n }\r\n normal0 = Vector3.Cross(vt, point);\r\n }\r\n else {\r\n normal0 = Vector3.Cross(vt, va);\r\n Vector3.CrossToRef(normal0, vt, normal0);\r\n }\r\n normal0.normalize();\r\n return normal0;\r\n };\r\n /**\r\n * Updates the point at data for an interpolated point along this curve\r\n * @param position the position of the point along this curve, from 0.0 to 1.0\r\n * @interpolateTNB wether to compute the interpolated tangent, normal and binormal\r\n * @returns the (updated) point at data\r\n */\r\n Path3D.prototype._updatePointAtData = function (position, interpolateTNB) {\r\n if (interpolateTNB === void 0) { interpolateTNB = false; }\r\n // set an id for caching the result\r\n if (this._pointAtData.id === position) {\r\n if (!this._pointAtData.interpolateReady) {\r\n this._updateInterpolationMatrix();\r\n }\r\n return this._pointAtData;\r\n }\r\n else {\r\n this._pointAtData.id = position;\r\n }\r\n var curvePoints = this.getPoints();\r\n // clamp position between 0.0 and 1.0\r\n if (position <= 0.0) {\r\n return this._setPointAtData(0.0, 0.0, curvePoints[0], 0, interpolateTNB);\r\n }\r\n else if (position >= 1.0) {\r\n return this._setPointAtData(1.0, 1.0, curvePoints[curvePoints.length - 1], curvePoints.length - 1, interpolateTNB);\r\n }\r\n var previousPoint = curvePoints[0];\r\n var currentPoint;\r\n var currentLength = 0.0;\r\n var targetLength = position * this.length();\r\n for (var i = 1; i < curvePoints.length; i++) {\r\n currentPoint = curvePoints[i];\r\n var distance = Vector3.Distance(previousPoint, currentPoint);\r\n currentLength += distance;\r\n if (currentLength === targetLength) {\r\n return this._setPointAtData(position, 1.0, currentPoint, i, interpolateTNB);\r\n }\r\n else if (currentLength > targetLength) {\r\n var toLength = currentLength - targetLength;\r\n var diff = toLength / distance;\r\n var dir = previousPoint.subtract(currentPoint);\r\n var point = currentPoint.add(dir.scaleInPlace(diff));\r\n return this._setPointAtData(position, 1 - diff, point, i - 1, interpolateTNB);\r\n }\r\n previousPoint = currentPoint;\r\n }\r\n return this._pointAtData;\r\n };\r\n /**\r\n * Updates the point at data from the specified parameters\r\n * @param position where along the path the interpolated point is, from 0.0 to 1.0\r\n * @param point the interpolated point\r\n * @param parentIndex the index of an existing curve point that is on, or else positionally the first behind, the interpolated point\r\n */\r\n Path3D.prototype._setPointAtData = function (position, subPosition, point, parentIndex, interpolateTNB) {\r\n this._pointAtData.point = point;\r\n this._pointAtData.position = position;\r\n this._pointAtData.subPosition = subPosition;\r\n this._pointAtData.previousPointArrayIndex = parentIndex;\r\n this._pointAtData.interpolateReady = interpolateTNB;\r\n if (interpolateTNB) {\r\n this._updateInterpolationMatrix();\r\n }\r\n return this._pointAtData;\r\n };\r\n /**\r\n * Updates the point at interpolation matrix for the tangents, normals and binormals\r\n */\r\n Path3D.prototype._updateInterpolationMatrix = function () {\r\n this._pointAtData.interpolationMatrix = Matrix.Identity();\r\n var parentIndex = this._pointAtData.previousPointArrayIndex;\r\n if (parentIndex !== this._tangents.length - 1) {\r\n var index = parentIndex + 1;\r\n var tangentFrom = this._tangents[parentIndex].clone();\r\n var normalFrom = this._normals[parentIndex].clone();\r\n var binormalFrom = this._binormals[parentIndex].clone();\r\n var tangentTo = this._tangents[index].clone();\r\n var normalTo = this._normals[index].clone();\r\n var binormalTo = this._binormals[index].clone();\r\n var quatFrom = Quaternion.RotationQuaternionFromAxis(normalFrom, binormalFrom, tangentFrom);\r\n var quatTo = Quaternion.RotationQuaternionFromAxis(normalTo, binormalTo, tangentTo);\r\n var quatAt = Quaternion.Slerp(quatFrom, quatTo, this._pointAtData.subPosition);\r\n quatAt.toRotationMatrix(this._pointAtData.interpolationMatrix);\r\n }\r\n };\r\n return Path3D;\r\n}());\r\nexport { Path3D };\r\n/**\r\n * A Curve3 object is a logical object, so not a mesh, to handle curves in the 3D geometric space.\r\n * A Curve3 is designed from a series of successive Vector3.\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_curve3\r\n */\r\nvar Curve3 = /** @class */ (function () {\r\n /**\r\n * A Curve3 object is a logical object, so not a mesh, to handle curves in the 3D geometric space.\r\n * A Curve3 is designed from a series of successive Vector3.\r\n * Tuto : https://doc.babylonjs.com/how_to/how_to_use_curve3#curve3-object\r\n * @param points points which make up the curve\r\n */\r\n function Curve3(points) {\r\n this._length = 0.0;\r\n this._points = points;\r\n this._length = this._computeLength(points);\r\n }\r\n /**\r\n * Returns a Curve3 object along a Quadratic Bezier curve : https://doc.babylonjs.com/how_to/how_to_use_curve3#quadratic-bezier-curve\r\n * @param v0 (Vector3) the origin point of the Quadratic Bezier\r\n * @param v1 (Vector3) the control point\r\n * @param v2 (Vector3) the end point of the Quadratic Bezier\r\n * @param nbPoints (integer) the wanted number of points in the curve\r\n * @returns the created Curve3\r\n */\r\n Curve3.CreateQuadraticBezier = function (v0, v1, v2, nbPoints) {\r\n nbPoints = nbPoints > 2 ? nbPoints : 3;\r\n var bez = new Array();\r\n var equation = function (t, val0, val1, val2) {\r\n var res = (1.0 - t) * (1.0 - t) * val0 + 2.0 * t * (1.0 - t) * val1 + t * t * val2;\r\n return res;\r\n };\r\n for (var i = 0; i <= nbPoints; i++) {\r\n bez.push(new Vector3(equation(i / nbPoints, v0.x, v1.x, v2.x), equation(i / nbPoints, v0.y, v1.y, v2.y), equation(i / nbPoints, v0.z, v1.z, v2.z)));\r\n }\r\n return new Curve3(bez);\r\n };\r\n /**\r\n * Returns a Curve3 object along a Cubic Bezier curve : https://doc.babylonjs.com/how_to/how_to_use_curve3#cubic-bezier-curve\r\n * @param v0 (Vector3) the origin point of the Cubic Bezier\r\n * @param v1 (Vector3) the first control point\r\n * @param v2 (Vector3) the second control point\r\n * @param v3 (Vector3) the end point of the Cubic Bezier\r\n * @param nbPoints (integer) the wanted number of points in the curve\r\n * @returns the created Curve3\r\n */\r\n Curve3.CreateCubicBezier = function (v0, v1, v2, v3, nbPoints) {\r\n nbPoints = nbPoints > 3 ? nbPoints : 4;\r\n var bez = new Array();\r\n var equation = function (t, val0, val1, val2, val3) {\r\n var res = (1.0 - t) * (1.0 - t) * (1.0 - t) * val0 + 3.0 * t * (1.0 - t) * (1.0 - t) * val1 + 3.0 * t * t * (1.0 - t) * val2 + t * t * t * val3;\r\n return res;\r\n };\r\n for (var i = 0; i <= nbPoints; i++) {\r\n bez.push(new Vector3(equation(i / nbPoints, v0.x, v1.x, v2.x, v3.x), equation(i / nbPoints, v0.y, v1.y, v2.y, v3.y), equation(i / nbPoints, v0.z, v1.z, v2.z, v3.z)));\r\n }\r\n return new Curve3(bez);\r\n };\r\n /**\r\n * Returns a Curve3 object along a Hermite Spline curve : https://doc.babylonjs.com/how_to/how_to_use_curve3#hermite-spline\r\n * @param p1 (Vector3) the origin point of the Hermite Spline\r\n * @param t1 (Vector3) the tangent vector at the origin point\r\n * @param p2 (Vector3) the end point of the Hermite Spline\r\n * @param t2 (Vector3) the tangent vector at the end point\r\n * @param nbPoints (integer) the wanted number of points in the curve\r\n * @returns the created Curve3\r\n */\r\n Curve3.CreateHermiteSpline = function (p1, t1, p2, t2, nbPoints) {\r\n var hermite = new Array();\r\n var step = 1.0 / nbPoints;\r\n for (var i = 0; i <= nbPoints; i++) {\r\n hermite.push(Vector3.Hermite(p1, t1, p2, t2, i * step));\r\n }\r\n return new Curve3(hermite);\r\n };\r\n /**\r\n * Returns a Curve3 object along a CatmullRom Spline curve :\r\n * @param points (array of Vector3) the points the spline must pass through. At least, four points required\r\n * @param nbPoints (integer) the wanted number of points between each curve control points\r\n * @param closed (boolean) optional with default false, when true forms a closed loop from the points\r\n * @returns the created Curve3\r\n */\r\n Curve3.CreateCatmullRomSpline = function (points, nbPoints, closed) {\r\n var catmullRom = new Array();\r\n var step = 1.0 / nbPoints;\r\n var amount = 0.0;\r\n if (closed) {\r\n var pointsCount = points.length;\r\n for (var i = 0; i < pointsCount; i++) {\r\n amount = 0;\r\n for (var c = 0; c < nbPoints; c++) {\r\n catmullRom.push(Vector3.CatmullRom(points[i % pointsCount], points[(i + 1) % pointsCount], points[(i + 2) % pointsCount], points[(i + 3) % pointsCount], amount));\r\n amount += step;\r\n }\r\n }\r\n catmullRom.push(catmullRom[0]);\r\n }\r\n else {\r\n var totalPoints = new Array();\r\n totalPoints.push(points[0].clone());\r\n Array.prototype.push.apply(totalPoints, points);\r\n totalPoints.push(points[points.length - 1].clone());\r\n for (var i = 0; i < totalPoints.length - 3; i++) {\r\n amount = 0;\r\n for (var c = 0; c < nbPoints; c++) {\r\n catmullRom.push(Vector3.CatmullRom(totalPoints[i], totalPoints[i + 1], totalPoints[i + 2], totalPoints[i + 3], amount));\r\n amount += step;\r\n }\r\n }\r\n i--;\r\n catmullRom.push(Vector3.CatmullRom(totalPoints[i], totalPoints[i + 1], totalPoints[i + 2], totalPoints[i + 3], amount));\r\n }\r\n return new Curve3(catmullRom);\r\n };\r\n /**\r\n * @returns the Curve3 stored array of successive Vector3\r\n */\r\n Curve3.prototype.getPoints = function () {\r\n return this._points;\r\n };\r\n /**\r\n * @returns the computed length (float) of the curve.\r\n */\r\n Curve3.prototype.length = function () {\r\n return this._length;\r\n };\r\n /**\r\n * Returns a new instance of Curve3 object : var curve = curveA.continue(curveB);\r\n * This new Curve3 is built by translating and sticking the curveB at the end of the curveA.\r\n * curveA and curveB keep unchanged.\r\n * @param curve the curve to continue from this curve\r\n * @returns the newly constructed curve\r\n */\r\n Curve3.prototype.continue = function (curve) {\r\n var lastPoint = this._points[this._points.length - 1];\r\n var continuedPoints = this._points.slice();\r\n var curvePoints = curve.getPoints();\r\n for (var i = 1; i < curvePoints.length; i++) {\r\n continuedPoints.push(curvePoints[i].subtract(curvePoints[0]).add(lastPoint));\r\n }\r\n var continuedCurve = new Curve3(continuedPoints);\r\n return continuedCurve;\r\n };\r\n Curve3.prototype._computeLength = function (path) {\r\n var l = 0;\r\n for (var i = 1; i < path.length; i++) {\r\n l += path[i].subtract(path[i - 1]).length();\r\n }\r\n return l;\r\n };\r\n return Curve3;\r\n}());\r\nexport { Curve3 };\r\n//# sourceMappingURL=math.path.js.map","/**\r\n * Define options used to create a render target texture\r\n */\r\nvar RenderTargetCreationOptions = /** @class */ (function () {\r\n function RenderTargetCreationOptions() {\r\n }\r\n return RenderTargetCreationOptions;\r\n}());\r\nexport { RenderTargetCreationOptions };\r\n//# sourceMappingURL=renderTargetCreationOptions.js.map","/**\r\n * Class used to manipulate GUIDs\r\n */\r\nvar GUID = /** @class */ (function () {\r\n function GUID() {\r\n }\r\n /**\r\n * Implementation from http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/2117523#answer-2117523\r\n * Be aware Math.random() could cause collisions, but:\r\n * \"All but 6 of the 128 bits of the ID are randomly generated, which means that for any two ids, there's a 1 in 2^^122 (or 5.3x10^^36) chance they'll collide\"\r\n * @returns a pseudo random id\r\n */\r\n GUID.RandomId = function () {\r\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {\r\n var r = Math.random() * 16 | 0, v = c === 'x' ? r : (r & 0x3 | 0x8);\r\n return v.toString(16);\r\n });\r\n };\r\n return GUID;\r\n}());\r\nexport { GUID };\r\n//# sourceMappingURL=guid.js.map","/**\r\n * Manages the defines for the Material\r\n */\r\nvar MaterialDefines = /** @class */ (function () {\r\n function MaterialDefines() {\r\n this._isDirty = true;\r\n /** @hidden */\r\n this._areLightsDirty = true;\r\n /** @hidden */\r\n this._areLightsDisposed = false;\r\n /** @hidden */\r\n this._areAttributesDirty = true;\r\n /** @hidden */\r\n this._areTexturesDirty = true;\r\n /** @hidden */\r\n this._areFresnelDirty = true;\r\n /** @hidden */\r\n this._areMiscDirty = true;\r\n /** @hidden */\r\n this._arePrePassDirty = true;\r\n /** @hidden */\r\n this._areImageProcessingDirty = true;\r\n /** @hidden */\r\n this._normals = false;\r\n /** @hidden */\r\n this._uvs = false;\r\n /** @hidden */\r\n this._needNormals = false;\r\n /** @hidden */\r\n this._needUVs = false;\r\n }\r\n Object.defineProperty(MaterialDefines.prototype, \"isDirty\", {\r\n /**\r\n * Specifies if the material needs to be re-calculated\r\n */\r\n get: function () {\r\n return this._isDirty;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Marks the material to indicate that it has been re-calculated\r\n */\r\n MaterialDefines.prototype.markAsProcessed = function () {\r\n this._isDirty = false;\r\n this._areAttributesDirty = false;\r\n this._areTexturesDirty = false;\r\n this._areFresnelDirty = false;\r\n this._areLightsDirty = false;\r\n this._areLightsDisposed = false;\r\n this._areMiscDirty = false;\r\n this._arePrePassDirty = false;\r\n this._areImageProcessingDirty = false;\r\n };\r\n /**\r\n * Marks the material to indicate that it needs to be re-calculated\r\n */\r\n MaterialDefines.prototype.markAsUnprocessed = function () {\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Marks the material to indicate all of its defines need to be re-calculated\r\n */\r\n MaterialDefines.prototype.markAllAsDirty = function () {\r\n this._areTexturesDirty = true;\r\n this._areAttributesDirty = true;\r\n this._areLightsDirty = true;\r\n this._areFresnelDirty = true;\r\n this._areMiscDirty = true;\r\n this._areImageProcessingDirty = true;\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Marks the material to indicate that image processing needs to be re-calculated\r\n */\r\n MaterialDefines.prototype.markAsImageProcessingDirty = function () {\r\n this._areImageProcessingDirty = true;\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Marks the material to indicate the lights need to be re-calculated\r\n * @param disposed Defines whether the light is dirty due to dispose or not\r\n */\r\n MaterialDefines.prototype.markAsLightDirty = function (disposed) {\r\n if (disposed === void 0) { disposed = false; }\r\n this._areLightsDirty = true;\r\n this._areLightsDisposed = this._areLightsDisposed || disposed;\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Marks the attribute state as changed\r\n */\r\n MaterialDefines.prototype.markAsAttributesDirty = function () {\r\n this._areAttributesDirty = true;\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Marks the texture state as changed\r\n */\r\n MaterialDefines.prototype.markAsTexturesDirty = function () {\r\n this._areTexturesDirty = true;\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Marks the fresnel state as changed\r\n */\r\n MaterialDefines.prototype.markAsFresnelDirty = function () {\r\n this._areFresnelDirty = true;\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Marks the misc state as changed\r\n */\r\n MaterialDefines.prototype.markAsMiscDirty = function () {\r\n this._areMiscDirty = true;\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Marks the prepass state as changed\r\n */\r\n MaterialDefines.prototype.markAsPrePassDirty = function () {\r\n this._arePrePassDirty = true;\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Rebuilds the material defines\r\n */\r\n MaterialDefines.prototype.rebuild = function () {\r\n this._keys = [];\r\n for (var _i = 0, _a = Object.keys(this); _i < _a.length; _i++) {\r\n var key = _a[_i];\r\n if (key[0] === \"_\") {\r\n continue;\r\n }\r\n this._keys.push(key);\r\n }\r\n };\r\n /**\r\n * Specifies if two material defines are equal\r\n * @param other - A material define instance to compare to\r\n * @returns - Boolean indicating if the material defines are equal (true) or not (false)\r\n */\r\n MaterialDefines.prototype.isEqual = function (other) {\r\n if (this._keys.length !== other._keys.length) {\r\n return false;\r\n }\r\n for (var index = 0; index < this._keys.length; index++) {\r\n var prop = this._keys[index];\r\n if (this[prop] !== other[prop]) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Clones this instance's defines to another instance\r\n * @param other - material defines to clone values to\r\n */\r\n MaterialDefines.prototype.cloneTo = function (other) {\r\n if (this._keys.length !== other._keys.length) {\r\n other._keys = this._keys.slice(0);\r\n }\r\n for (var index = 0; index < this._keys.length; index++) {\r\n var prop = this._keys[index];\r\n other[prop] = this[prop];\r\n }\r\n };\r\n /**\r\n * Resets the material define values\r\n */\r\n MaterialDefines.prototype.reset = function () {\r\n for (var index = 0; index < this._keys.length; index++) {\r\n var prop = this._keys[index];\r\n var type = typeof this[prop];\r\n switch (type) {\r\n case \"number\":\r\n this[prop] = 0;\r\n break;\r\n case \"string\":\r\n this[prop] = \"\";\r\n break;\r\n default:\r\n this[prop] = false;\r\n break;\r\n }\r\n }\r\n };\r\n /**\r\n * Converts the material define values to a string\r\n * @returns - String of material define information\r\n */\r\n MaterialDefines.prototype.toString = function () {\r\n var result = \"\";\r\n for (var index = 0; index < this._keys.length; index++) {\r\n var prop = this._keys[index];\r\n var value = this[prop];\r\n var type = typeof value;\r\n switch (type) {\r\n case \"number\":\r\n case \"string\":\r\n result += \"#define \" + prop + \" \" + value + \"\\n\";\r\n break;\r\n default:\r\n if (value) {\r\n result += \"#define \" + prop + \"\\n\";\r\n }\r\n break;\r\n }\r\n }\r\n return result;\r\n };\r\n return MaterialDefines;\r\n}());\r\nexport { MaterialDefines };\r\n//# sourceMappingURL=materialDefines.js.map","/**\r\n * EffectFallbacks can be used to add fallbacks (properties to disable) to certain properties when desired to improve performance.\r\n * (Eg. Start at high quality with reflection and fog, if fps is low, remove reflection, if still low remove fog)\r\n */\r\nvar EffectFallbacks = /** @class */ (function () {\r\n function EffectFallbacks() {\r\n this._defines = {};\r\n this._currentRank = 32;\r\n this._maxRank = -1;\r\n this._mesh = null;\r\n }\r\n /**\r\n * Removes the fallback from the bound mesh.\r\n */\r\n EffectFallbacks.prototype.unBindMesh = function () {\r\n this._mesh = null;\r\n };\r\n /**\r\n * Adds a fallback on the specified property.\r\n * @param rank The rank of the fallback (Lower ranks will be fallbacked to first)\r\n * @param define The name of the define in the shader\r\n */\r\n EffectFallbacks.prototype.addFallback = function (rank, define) {\r\n if (!this._defines[rank]) {\r\n if (rank < this._currentRank) {\r\n this._currentRank = rank;\r\n }\r\n if (rank > this._maxRank) {\r\n this._maxRank = rank;\r\n }\r\n this._defines[rank] = new Array();\r\n }\r\n this._defines[rank].push(define);\r\n };\r\n /**\r\n * Sets the mesh to use CPU skinning when needing to fallback.\r\n * @param rank The rank of the fallback (Lower ranks will be fallbacked to first)\r\n * @param mesh The mesh to use the fallbacks.\r\n */\r\n EffectFallbacks.prototype.addCPUSkinningFallback = function (rank, mesh) {\r\n this._mesh = mesh;\r\n if (rank < this._currentRank) {\r\n this._currentRank = rank;\r\n }\r\n if (rank > this._maxRank) {\r\n this._maxRank = rank;\r\n }\r\n };\r\n Object.defineProperty(EffectFallbacks.prototype, \"hasMoreFallbacks\", {\r\n /**\r\n * Checks to see if more fallbacks are still availible.\r\n */\r\n get: function () {\r\n return this._currentRank <= this._maxRank;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Removes the defines that should be removed when falling back.\r\n * @param currentDefines defines the current define statements for the shader.\r\n * @param effect defines the current effect we try to compile\r\n * @returns The resulting defines with defines of the current rank removed.\r\n */\r\n EffectFallbacks.prototype.reduce = function (currentDefines, effect) {\r\n // First we try to switch to CPU skinning\r\n if (this._mesh && this._mesh.computeBonesUsingShaders && this._mesh.numBoneInfluencers > 0) {\r\n this._mesh.computeBonesUsingShaders = false;\r\n currentDefines = currentDefines.replace(\"#define NUM_BONE_INFLUENCERS \" + this._mesh.numBoneInfluencers, \"#define NUM_BONE_INFLUENCERS 0\");\r\n effect._bonesComputationForcedToCPU = true;\r\n var scene = this._mesh.getScene();\r\n for (var index = 0; index < scene.meshes.length; index++) {\r\n var otherMesh = scene.meshes[index];\r\n if (!otherMesh.material) {\r\n if (!this._mesh.material && otherMesh.computeBonesUsingShaders && otherMesh.numBoneInfluencers > 0) {\r\n otherMesh.computeBonesUsingShaders = false;\r\n }\r\n continue;\r\n }\r\n if (!otherMesh.computeBonesUsingShaders || otherMesh.numBoneInfluencers === 0) {\r\n continue;\r\n }\r\n if (otherMesh.material.getEffect() === effect) {\r\n otherMesh.computeBonesUsingShaders = false;\r\n }\r\n else if (otherMesh.subMeshes) {\r\n for (var _i = 0, _a = otherMesh.subMeshes; _i < _a.length; _i++) {\r\n var subMesh = _a[_i];\r\n var subMeshEffect = subMesh.effect;\r\n if (subMeshEffect === effect) {\r\n otherMesh.computeBonesUsingShaders = false;\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n var currentFallbacks = this._defines[this._currentRank];\r\n if (currentFallbacks) {\r\n for (var index = 0; index < currentFallbacks.length; index++) {\r\n currentDefines = currentDefines.replace(\"#define \" + currentFallbacks[index], \"\");\r\n }\r\n }\r\n this._currentRank++;\r\n }\r\n return currentDefines;\r\n };\r\n return EffectFallbacks;\r\n}());\r\nexport { EffectFallbacks };\r\n//# sourceMappingURL=effectFallbacks.js.map","import { SmartArray, SmartArrayNoDuplicate } from \"../Misc/smartArray\";\r\nimport { Vector3 } from \"../Maths/math.vector\";\r\n/**\r\n * This represents the object necessary to create a rendering group.\r\n * This is exclusively used and created by the rendering manager.\r\n * To modify the behavior, you use the available helpers in your scene or meshes.\r\n * @hidden\r\n */\r\nvar RenderingGroup = /** @class */ (function () {\r\n /**\r\n * Creates a new rendering group.\r\n * @param index The rendering group index\r\n * @param opaqueSortCompareFn The opaque sort comparison function. If null no order is applied\r\n * @param alphaTestSortCompareFn The alpha test sort comparison function. If null no order is applied\r\n * @param transparentSortCompareFn The transparent sort comparison function. If null back to front + alpha index sort is applied\r\n */\r\n function RenderingGroup(index, scene, opaqueSortCompareFn, alphaTestSortCompareFn, transparentSortCompareFn) {\r\n if (opaqueSortCompareFn === void 0) { opaqueSortCompareFn = null; }\r\n if (alphaTestSortCompareFn === void 0) { alphaTestSortCompareFn = null; }\r\n if (transparentSortCompareFn === void 0) { transparentSortCompareFn = null; }\r\n this.index = index;\r\n this._opaqueSubMeshes = new SmartArray(256);\r\n this._transparentSubMeshes = new SmartArray(256);\r\n this._alphaTestSubMeshes = new SmartArray(256);\r\n this._depthOnlySubMeshes = new SmartArray(256);\r\n this._particleSystems = new SmartArray(256);\r\n this._spriteManagers = new SmartArray(256);\r\n /** @hidden */\r\n this._edgesRenderers = new SmartArrayNoDuplicate(16);\r\n this._scene = scene;\r\n this.opaqueSortCompareFn = opaqueSortCompareFn;\r\n this.alphaTestSortCompareFn = alphaTestSortCompareFn;\r\n this.transparentSortCompareFn = transparentSortCompareFn;\r\n }\r\n Object.defineProperty(RenderingGroup.prototype, \"opaqueSortCompareFn\", {\r\n /**\r\n * Set the opaque sort comparison function.\r\n * If null the sub meshes will be render in the order they were created\r\n */\r\n set: function (value) {\r\n this._opaqueSortCompareFn = value;\r\n if (value) {\r\n this._renderOpaque = this.renderOpaqueSorted;\r\n }\r\n else {\r\n this._renderOpaque = RenderingGroup.renderUnsorted;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(RenderingGroup.prototype, \"alphaTestSortCompareFn\", {\r\n /**\r\n * Set the alpha test sort comparison function.\r\n * If null the sub meshes will be render in the order they were created\r\n */\r\n set: function (value) {\r\n this._alphaTestSortCompareFn = value;\r\n if (value) {\r\n this._renderAlphaTest = this.renderAlphaTestSorted;\r\n }\r\n else {\r\n this._renderAlphaTest = RenderingGroup.renderUnsorted;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(RenderingGroup.prototype, \"transparentSortCompareFn\", {\r\n /**\r\n * Set the transparent sort comparison function.\r\n * If null the sub meshes will be render in the order they were created\r\n */\r\n set: function (value) {\r\n if (value) {\r\n this._transparentSortCompareFn = value;\r\n }\r\n else {\r\n this._transparentSortCompareFn = RenderingGroup.defaultTransparentSortCompare;\r\n }\r\n this._renderTransparent = this.renderTransparentSorted;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Render all the sub meshes contained in the group.\r\n * @param customRenderFunction Used to override the default render behaviour of the group.\r\n * @returns true if rendered some submeshes.\r\n */\r\n RenderingGroup.prototype.render = function (customRenderFunction, renderSprites, renderParticles, activeMeshes) {\r\n if (customRenderFunction) {\r\n customRenderFunction(this._opaqueSubMeshes, this._alphaTestSubMeshes, this._transparentSubMeshes, this._depthOnlySubMeshes);\r\n return;\r\n }\r\n var engine = this._scene.getEngine();\r\n // Depth only\r\n if (this._depthOnlySubMeshes.length !== 0) {\r\n engine.setColorWrite(false);\r\n this._renderAlphaTest(this._depthOnlySubMeshes);\r\n engine.setColorWrite(true);\r\n }\r\n // Opaque\r\n if (this._opaqueSubMeshes.length !== 0) {\r\n this._renderOpaque(this._opaqueSubMeshes);\r\n }\r\n // Alpha test\r\n if (this._alphaTestSubMeshes.length !== 0) {\r\n this._renderAlphaTest(this._alphaTestSubMeshes);\r\n }\r\n var stencilState = engine.getStencilBuffer();\r\n engine.setStencilBuffer(false);\r\n // Sprites\r\n if (renderSprites) {\r\n this._renderSprites();\r\n }\r\n // Particles\r\n if (renderParticles) {\r\n this._renderParticles(activeMeshes);\r\n }\r\n if (this.onBeforeTransparentRendering) {\r\n this.onBeforeTransparentRendering();\r\n }\r\n // Transparent\r\n if (this._transparentSubMeshes.length !== 0) {\r\n engine.setStencilBuffer(stencilState);\r\n this._renderTransparent(this._transparentSubMeshes);\r\n engine.setAlphaMode(0);\r\n }\r\n // Set back stencil to false in case it changes before the edge renderer.\r\n engine.setStencilBuffer(false);\r\n // Edges\r\n if (this._edgesRenderers.length) {\r\n for (var edgesRendererIndex = 0; edgesRendererIndex < this._edgesRenderers.length; edgesRendererIndex++) {\r\n this._edgesRenderers.data[edgesRendererIndex].render();\r\n }\r\n engine.setAlphaMode(0);\r\n }\r\n // Restore Stencil state.\r\n engine.setStencilBuffer(stencilState);\r\n };\r\n /**\r\n * Renders the opaque submeshes in the order from the opaqueSortCompareFn.\r\n * @param subMeshes The submeshes to render\r\n */\r\n RenderingGroup.prototype.renderOpaqueSorted = function (subMeshes) {\r\n return RenderingGroup.renderSorted(subMeshes, this._opaqueSortCompareFn, this._scene.activeCamera, false);\r\n };\r\n /**\r\n * Renders the opaque submeshes in the order from the alphatestSortCompareFn.\r\n * @param subMeshes The submeshes to render\r\n */\r\n RenderingGroup.prototype.renderAlphaTestSorted = function (subMeshes) {\r\n return RenderingGroup.renderSorted(subMeshes, this._alphaTestSortCompareFn, this._scene.activeCamera, false);\r\n };\r\n /**\r\n * Renders the opaque submeshes in the order from the transparentSortCompareFn.\r\n * @param subMeshes The submeshes to render\r\n */\r\n RenderingGroup.prototype.renderTransparentSorted = function (subMeshes) {\r\n return RenderingGroup.renderSorted(subMeshes, this._transparentSortCompareFn, this._scene.activeCamera, true);\r\n };\r\n /**\r\n * Renders the submeshes in a specified order.\r\n * @param subMeshes The submeshes to sort before render\r\n * @param sortCompareFn The comparison function use to sort\r\n * @param cameraPosition The camera position use to preprocess the submeshes to help sorting\r\n * @param transparent Specifies to activate blending if true\r\n */\r\n RenderingGroup.renderSorted = function (subMeshes, sortCompareFn, camera, transparent) {\r\n var subIndex = 0;\r\n var subMesh;\r\n var cameraPosition = camera ? camera.globalPosition : RenderingGroup._zeroVector;\r\n for (; subIndex < subMeshes.length; subIndex++) {\r\n subMesh = subMeshes.data[subIndex];\r\n subMesh._alphaIndex = subMesh.getMesh().alphaIndex;\r\n subMesh._distanceToCamera = Vector3.Distance(subMesh.getBoundingInfo().boundingSphere.centerWorld, cameraPosition);\r\n }\r\n var sortedArray = subMeshes.data.slice(0, subMeshes.length);\r\n if (sortCompareFn) {\r\n sortedArray.sort(sortCompareFn);\r\n }\r\n for (subIndex = 0; subIndex < sortedArray.length; subIndex++) {\r\n subMesh = sortedArray[subIndex];\r\n if (transparent) {\r\n var material = subMesh.getMaterial();\r\n if (material && material.needDepthPrePass) {\r\n var engine = material.getScene().getEngine();\r\n engine.setColorWrite(false);\r\n engine.setAlphaMode(0);\r\n subMesh.render(false);\r\n engine.setColorWrite(true);\r\n }\r\n }\r\n subMesh.render(transparent);\r\n }\r\n };\r\n /**\r\n * Renders the submeshes in the order they were dispatched (no sort applied).\r\n * @param subMeshes The submeshes to render\r\n */\r\n RenderingGroup.renderUnsorted = function (subMeshes) {\r\n for (var subIndex = 0; subIndex < subMeshes.length; subIndex++) {\r\n var submesh = subMeshes.data[subIndex];\r\n submesh.render(false);\r\n }\r\n };\r\n /**\r\n * Build in function which can be applied to ensure meshes of a special queue (opaque, alpha test, transparent)\r\n * are rendered back to front if in the same alpha index.\r\n *\r\n * @param a The first submesh\r\n * @param b The second submesh\r\n * @returns The result of the comparison\r\n */\r\n RenderingGroup.defaultTransparentSortCompare = function (a, b) {\r\n // Alpha index first\r\n if (a._alphaIndex > b._alphaIndex) {\r\n return 1;\r\n }\r\n if (a._alphaIndex < b._alphaIndex) {\r\n return -1;\r\n }\r\n // Then distance to camera\r\n return RenderingGroup.backToFrontSortCompare(a, b);\r\n };\r\n /**\r\n * Build in function which can be applied to ensure meshes of a special queue (opaque, alpha test, transparent)\r\n * are rendered back to front.\r\n *\r\n * @param a The first submesh\r\n * @param b The second submesh\r\n * @returns The result of the comparison\r\n */\r\n RenderingGroup.backToFrontSortCompare = function (a, b) {\r\n // Then distance to camera\r\n if (a._distanceToCamera < b._distanceToCamera) {\r\n return 1;\r\n }\r\n if (a._distanceToCamera > b._distanceToCamera) {\r\n return -1;\r\n }\r\n return 0;\r\n };\r\n /**\r\n * Build in function which can be applied to ensure meshes of a special queue (opaque, alpha test, transparent)\r\n * are rendered front to back (prevent overdraw).\r\n *\r\n * @param a The first submesh\r\n * @param b The second submesh\r\n * @returns The result of the comparison\r\n */\r\n RenderingGroup.frontToBackSortCompare = function (a, b) {\r\n // Then distance to camera\r\n if (a._distanceToCamera < b._distanceToCamera) {\r\n return -1;\r\n }\r\n if (a._distanceToCamera > b._distanceToCamera) {\r\n return 1;\r\n }\r\n return 0;\r\n };\r\n /**\r\n * Resets the different lists of submeshes to prepare a new frame.\r\n */\r\n RenderingGroup.prototype.prepare = function () {\r\n this._opaqueSubMeshes.reset();\r\n this._transparentSubMeshes.reset();\r\n this._alphaTestSubMeshes.reset();\r\n this._depthOnlySubMeshes.reset();\r\n this._particleSystems.reset();\r\n this._spriteManagers.reset();\r\n this._edgesRenderers.reset();\r\n };\r\n RenderingGroup.prototype.dispose = function () {\r\n this._opaqueSubMeshes.dispose();\r\n this._transparentSubMeshes.dispose();\r\n this._alphaTestSubMeshes.dispose();\r\n this._depthOnlySubMeshes.dispose();\r\n this._particleSystems.dispose();\r\n this._spriteManagers.dispose();\r\n this._edgesRenderers.dispose();\r\n };\r\n /**\r\n * Inserts the submesh in its correct queue depending on its material.\r\n * @param subMesh The submesh to dispatch\r\n * @param [mesh] Optional reference to the submeshes's mesh. Provide if you have an exiting reference to improve performance.\r\n * @param [material] Optional reference to the submeshes's material. Provide if you have an exiting reference to improve performance.\r\n */\r\n RenderingGroup.prototype.dispatch = function (subMesh, mesh, material) {\r\n // Get mesh and materials if not provided\r\n if (mesh === undefined) {\r\n mesh = subMesh.getMesh();\r\n }\r\n if (material === undefined) {\r\n material = subMesh.getMaterial();\r\n }\r\n if (material === null || material === undefined) {\r\n return;\r\n }\r\n if (material.needAlphaBlendingForMesh(mesh)) { // Transparent\r\n this._transparentSubMeshes.push(subMesh);\r\n }\r\n else if (material.needAlphaTesting()) { // Alpha test\r\n if (material.needDepthPrePass) {\r\n this._depthOnlySubMeshes.push(subMesh);\r\n }\r\n this._alphaTestSubMeshes.push(subMesh);\r\n }\r\n else {\r\n if (material.needDepthPrePass) {\r\n this._depthOnlySubMeshes.push(subMesh);\r\n }\r\n this._opaqueSubMeshes.push(subMesh); // Opaque\r\n }\r\n mesh._renderingGroup = this;\r\n if (mesh._edgesRenderer && mesh._edgesRenderer.isEnabled) {\r\n this._edgesRenderers.pushNoDuplicate(mesh._edgesRenderer);\r\n }\r\n };\r\n RenderingGroup.prototype.dispatchSprites = function (spriteManager) {\r\n this._spriteManagers.push(spriteManager);\r\n };\r\n RenderingGroup.prototype.dispatchParticles = function (particleSystem) {\r\n this._particleSystems.push(particleSystem);\r\n };\r\n RenderingGroup.prototype._renderParticles = function (activeMeshes) {\r\n if (this._particleSystems.length === 0) {\r\n return;\r\n }\r\n // Particles\r\n var activeCamera = this._scene.activeCamera;\r\n this._scene.onBeforeParticlesRenderingObservable.notifyObservers(this._scene);\r\n for (var particleIndex = 0; particleIndex < this._particleSystems.length; particleIndex++) {\r\n var particleSystem = this._particleSystems.data[particleIndex];\r\n if ((activeCamera && activeCamera.layerMask & particleSystem.layerMask) === 0) {\r\n continue;\r\n }\r\n var emitter = particleSystem.emitter;\r\n if (!emitter.position || !activeMeshes || activeMeshes.indexOf(emitter) !== -1) {\r\n this._scene._activeParticles.addCount(particleSystem.render(), false);\r\n }\r\n }\r\n this._scene.onAfterParticlesRenderingObservable.notifyObservers(this._scene);\r\n };\r\n RenderingGroup.prototype._renderSprites = function () {\r\n if (!this._scene.spritesEnabled || this._spriteManagers.length === 0) {\r\n return;\r\n }\r\n // Sprites\r\n var activeCamera = this._scene.activeCamera;\r\n this._scene.onBeforeSpritesRenderingObservable.notifyObservers(this._scene);\r\n for (var id = 0; id < this._spriteManagers.length; id++) {\r\n var spriteManager = this._spriteManagers.data[id];\r\n if (((activeCamera && activeCamera.layerMask & spriteManager.layerMask) !== 0)) {\r\n spriteManager.render();\r\n }\r\n }\r\n this._scene.onAfterSpritesRenderingObservable.notifyObservers(this._scene);\r\n };\r\n RenderingGroup._zeroVector = Vector3.Zero();\r\n return RenderingGroup;\r\n}());\r\nexport { RenderingGroup };\r\n//# sourceMappingURL=renderingGroup.js.map","import { RenderingGroup } from \"./renderingGroup\";\r\n/**\r\n * This class is used by the onRenderingGroupObservable\r\n */\r\nvar RenderingGroupInfo = /** @class */ (function () {\r\n function RenderingGroupInfo() {\r\n }\r\n return RenderingGroupInfo;\r\n}());\r\nexport { RenderingGroupInfo };\r\n/**\r\n * This is the manager responsible of all the rendering for meshes sprites and particles.\r\n * It is enable to manage the different groups as well as the different necessary sort functions.\r\n * This should not be used directly aside of the few static configurations\r\n */\r\nvar RenderingManager = /** @class */ (function () {\r\n /**\r\n * Instantiates a new rendering group for a particular scene\r\n * @param scene Defines the scene the groups belongs to\r\n */\r\n function RenderingManager(scene) {\r\n /**\r\n * @hidden\r\n */\r\n this._useSceneAutoClearSetup = false;\r\n this._renderingGroups = new Array();\r\n this._autoClearDepthStencil = {};\r\n this._customOpaqueSortCompareFn = {};\r\n this._customAlphaTestSortCompareFn = {};\r\n this._customTransparentSortCompareFn = {};\r\n this._renderingGroupInfo = new RenderingGroupInfo();\r\n this._scene = scene;\r\n for (var i = RenderingManager.MIN_RENDERINGGROUPS; i < RenderingManager.MAX_RENDERINGGROUPS; i++) {\r\n this._autoClearDepthStencil[i] = { autoClear: true, depth: true, stencil: true };\r\n }\r\n }\r\n RenderingManager.prototype._clearDepthStencilBuffer = function (depth, stencil) {\r\n if (depth === void 0) { depth = true; }\r\n if (stencil === void 0) { stencil = true; }\r\n if (this._depthStencilBufferAlreadyCleaned) {\r\n return;\r\n }\r\n this._scene.getEngine().clear(null, false, depth, stencil);\r\n this._depthStencilBufferAlreadyCleaned = true;\r\n };\r\n /**\r\n * Renders the entire managed groups. This is used by the scene or the different rennder targets.\r\n * @hidden\r\n */\r\n RenderingManager.prototype.render = function (customRenderFunction, activeMeshes, renderParticles, renderSprites) {\r\n // Update the observable context (not null as it only goes away on dispose)\r\n var info = this._renderingGroupInfo;\r\n info.scene = this._scene;\r\n info.camera = this._scene.activeCamera;\r\n // Dispatch sprites\r\n if (this._scene.spriteManagers && renderSprites) {\r\n for (var index = 0; index < this._scene.spriteManagers.length; index++) {\r\n var manager = this._scene.spriteManagers[index];\r\n this.dispatchSprites(manager);\r\n }\r\n }\r\n // Render\r\n for (var index = RenderingManager.MIN_RENDERINGGROUPS; index < RenderingManager.MAX_RENDERINGGROUPS; index++) {\r\n this._depthStencilBufferAlreadyCleaned = index === RenderingManager.MIN_RENDERINGGROUPS;\r\n var renderingGroup = this._renderingGroups[index];\r\n if (!renderingGroup) {\r\n continue;\r\n }\r\n var renderingGroupMask = Math.pow(2, index);\r\n info.renderingGroupId = index;\r\n // Before Observable\r\n this._scene.onBeforeRenderingGroupObservable.notifyObservers(info, renderingGroupMask);\r\n // Clear depth/stencil if needed\r\n if (RenderingManager.AUTOCLEAR) {\r\n var autoClear = this._useSceneAutoClearSetup ?\r\n this._scene.getAutoClearDepthStencilSetup(index) :\r\n this._autoClearDepthStencil[index];\r\n if (autoClear && autoClear.autoClear) {\r\n this._clearDepthStencilBuffer(autoClear.depth, autoClear.stencil);\r\n }\r\n }\r\n // Render\r\n for (var _i = 0, _a = this._scene._beforeRenderingGroupDrawStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n step.action(index);\r\n }\r\n renderingGroup.render(customRenderFunction, renderSprites, renderParticles, activeMeshes);\r\n for (var _b = 0, _c = this._scene._afterRenderingGroupDrawStage; _b < _c.length; _b++) {\r\n var step = _c[_b];\r\n step.action(index);\r\n }\r\n // After Observable\r\n this._scene.onAfterRenderingGroupObservable.notifyObservers(info, renderingGroupMask);\r\n }\r\n };\r\n /**\r\n * Resets the different information of the group to prepare a new frame\r\n * @hidden\r\n */\r\n RenderingManager.prototype.reset = function () {\r\n for (var index = RenderingManager.MIN_RENDERINGGROUPS; index < RenderingManager.MAX_RENDERINGGROUPS; index++) {\r\n var renderingGroup = this._renderingGroups[index];\r\n if (renderingGroup) {\r\n renderingGroup.prepare();\r\n }\r\n }\r\n };\r\n /**\r\n * Dispose and release the group and its associated resources.\r\n * @hidden\r\n */\r\n RenderingManager.prototype.dispose = function () {\r\n this.freeRenderingGroups();\r\n this._renderingGroups.length = 0;\r\n this._renderingGroupInfo = null;\r\n };\r\n /**\r\n * Clear the info related to rendering groups preventing retention points during dispose.\r\n */\r\n RenderingManager.prototype.freeRenderingGroups = function () {\r\n for (var index = RenderingManager.MIN_RENDERINGGROUPS; index < RenderingManager.MAX_RENDERINGGROUPS; index++) {\r\n var renderingGroup = this._renderingGroups[index];\r\n if (renderingGroup) {\r\n renderingGroup.dispose();\r\n }\r\n }\r\n };\r\n RenderingManager.prototype._prepareRenderingGroup = function (renderingGroupId) {\r\n if (this._renderingGroups[renderingGroupId] === undefined) {\r\n this._renderingGroups[renderingGroupId] = new RenderingGroup(renderingGroupId, this._scene, this._customOpaqueSortCompareFn[renderingGroupId], this._customAlphaTestSortCompareFn[renderingGroupId], this._customTransparentSortCompareFn[renderingGroupId]);\r\n }\r\n };\r\n /**\r\n * Add a sprite manager to the rendering manager in order to render it this frame.\r\n * @param spriteManager Define the sprite manager to render\r\n */\r\n RenderingManager.prototype.dispatchSprites = function (spriteManager) {\r\n var renderingGroupId = spriteManager.renderingGroupId || 0;\r\n this._prepareRenderingGroup(renderingGroupId);\r\n this._renderingGroups[renderingGroupId].dispatchSprites(spriteManager);\r\n };\r\n /**\r\n * Add a particle system to the rendering manager in order to render it this frame.\r\n * @param particleSystem Define the particle system to render\r\n */\r\n RenderingManager.prototype.dispatchParticles = function (particleSystem) {\r\n var renderingGroupId = particleSystem.renderingGroupId || 0;\r\n this._prepareRenderingGroup(renderingGroupId);\r\n this._renderingGroups[renderingGroupId].dispatchParticles(particleSystem);\r\n };\r\n /**\r\n * Add a submesh to the manager in order to render it this frame\r\n * @param subMesh The submesh to dispatch\r\n * @param mesh Optional reference to the submeshes's mesh. Provide if you have an exiting reference to improve performance.\r\n * @param material Optional reference to the submeshes's material. Provide if you have an exiting reference to improve performance.\r\n */\r\n RenderingManager.prototype.dispatch = function (subMesh, mesh, material) {\r\n if (mesh === undefined) {\r\n mesh = subMesh.getMesh();\r\n }\r\n var renderingGroupId = mesh.renderingGroupId || 0;\r\n this._prepareRenderingGroup(renderingGroupId);\r\n this._renderingGroups[renderingGroupId].dispatch(subMesh, mesh, material);\r\n };\r\n /**\r\n * Overrides the default sort function applied in the renderging group to prepare the meshes.\r\n * This allowed control for front to back rendering or reversly depending of the special needs.\r\n *\r\n * @param renderingGroupId The rendering group id corresponding to its index\r\n * @param opaqueSortCompareFn The opaque queue comparison function use to sort.\r\n * @param alphaTestSortCompareFn The alpha test queue comparison function use to sort.\r\n * @param transparentSortCompareFn The transparent queue comparison function use to sort.\r\n */\r\n RenderingManager.prototype.setRenderingOrder = function (renderingGroupId, opaqueSortCompareFn, alphaTestSortCompareFn, transparentSortCompareFn) {\r\n if (opaqueSortCompareFn === void 0) { opaqueSortCompareFn = null; }\r\n if (alphaTestSortCompareFn === void 0) { alphaTestSortCompareFn = null; }\r\n if (transparentSortCompareFn === void 0) { transparentSortCompareFn = null; }\r\n this._customOpaqueSortCompareFn[renderingGroupId] = opaqueSortCompareFn;\r\n this._customAlphaTestSortCompareFn[renderingGroupId] = alphaTestSortCompareFn;\r\n this._customTransparentSortCompareFn[renderingGroupId] = transparentSortCompareFn;\r\n if (this._renderingGroups[renderingGroupId]) {\r\n var group = this._renderingGroups[renderingGroupId];\r\n group.opaqueSortCompareFn = this._customOpaqueSortCompareFn[renderingGroupId];\r\n group.alphaTestSortCompareFn = this._customAlphaTestSortCompareFn[renderingGroupId];\r\n group.transparentSortCompareFn = this._customTransparentSortCompareFn[renderingGroupId];\r\n }\r\n };\r\n /**\r\n * Specifies whether or not the stencil and depth buffer are cleared between two rendering groups.\r\n *\r\n * @param renderingGroupId The rendering group id corresponding to its index\r\n * @param autoClearDepthStencil Automatically clears depth and stencil between groups if true.\r\n * @param depth Automatically clears depth between groups if true and autoClear is true.\r\n * @param stencil Automatically clears stencil between groups if true and autoClear is true.\r\n */\r\n RenderingManager.prototype.setRenderingAutoClearDepthStencil = function (renderingGroupId, autoClearDepthStencil, depth, stencil) {\r\n if (depth === void 0) { depth = true; }\r\n if (stencil === void 0) { stencil = true; }\r\n this._autoClearDepthStencil[renderingGroupId] = {\r\n autoClear: autoClearDepthStencil,\r\n depth: depth,\r\n stencil: stencil\r\n };\r\n };\r\n /**\r\n * Gets the current auto clear configuration for one rendering group of the rendering\r\n * manager.\r\n * @param index the rendering group index to get the information for\r\n * @returns The auto clear setup for the requested rendering group\r\n */\r\n RenderingManager.prototype.getAutoClearDepthStencilSetup = function (index) {\r\n return this._autoClearDepthStencil[index];\r\n };\r\n /**\r\n * The max id used for rendering groups (not included)\r\n */\r\n RenderingManager.MAX_RENDERINGGROUPS = 4;\r\n /**\r\n * The min id used for rendering groups (included)\r\n */\r\n RenderingManager.MIN_RENDERINGGROUPS = 0;\r\n /**\r\n * Used to globally prevent autoclearing scenes.\r\n */\r\n RenderingManager.AUTOCLEAR = true;\r\n return RenderingManager;\r\n}());\r\nexport { RenderingManager };\r\n//# sourceMappingURL=renderingManager.js.map","import { Vector4 } from \"../../Maths/math.vector\";\r\nimport { Color4 } from '../../Maths/math.color';\r\nimport { Mesh } from \"../mesh\";\r\nimport { VertexData } from \"../mesh.vertexData\";\r\nVertexData.CreateBox = function (options) {\r\n var nbFaces = 6;\r\n var indices = [0, 1, 2, 0, 2, 3, 4, 5, 6, 4, 6, 7, 8, 9, 10, 8, 10, 11, 12, 13, 14, 12, 14, 15, 16, 17, 18, 16, 18, 19, 20, 21, 22, 20, 22, 23];\r\n var normals = [0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0];\r\n var uvs = [];\r\n var positions = [];\r\n var width = options.width || options.size || 1;\r\n var height = options.height || options.size || 1;\r\n var depth = options.depth || options.size || 1;\r\n var wrap = options.wrap || false;\r\n var topBaseAt = (options.topBaseAt === void 0) ? 1 : options.topBaseAt;\r\n var bottomBaseAt = (options.bottomBaseAt === void 0) ? 0 : options.bottomBaseAt;\r\n topBaseAt = (topBaseAt + 4) % 4; // places values as 0 to 3\r\n bottomBaseAt = (bottomBaseAt + 4) % 4; // places values as 0 to 3\r\n var topOrder = [2, 0, 3, 1];\r\n var bottomOrder = [2, 0, 1, 3];\r\n var topIndex = topOrder[topBaseAt];\r\n var bottomIndex = bottomOrder[bottomBaseAt];\r\n var basePositions = [1, -1, 1, -1, -1, 1, -1, 1, 1, 1, 1, 1, 1, 1, -1, -1, 1, -1, -1, -1, -1, 1, -1, -1, 1, 1, -1, 1, -1, -1, 1, -1, 1, 1, 1, 1, -1, 1, 1, -1, -1, 1, -1, -1, -1, -1, 1, -1, -1, 1, 1, -1, 1, -1, 1, 1, -1, 1, 1, 1, 1, -1, 1, 1, -1, -1, -1, -1, -1, -1, -1, 1];\r\n if (wrap) {\r\n indices = [2, 3, 0, 2, 0, 1, 4, 5, 6, 4, 6, 7, 9, 10, 11, 9, 11, 8, 12, 14, 15, 12, 13, 14];\r\n basePositions = [-1, 1, 1, 1, 1, 1, 1, -1, 1, -1, -1, 1, 1, 1, -1, -1, 1, -1, -1, -1, -1, 1, -1, -1, 1, 1, 1, 1, 1, -1, 1, -1, -1, 1, -1, 1, -1, 1, -1, -1, 1, 1, -1, -1, 1, -1, -1, -1];\r\n var topFaceBase = [[1, 1, 1], [-1, 1, 1], [-1, 1, -1], [1, 1, -1]];\r\n var bottomFaceBase = [[-1, -1, 1], [1, -1, 1], [1, -1, -1], [-1, -1, -1]];\r\n var topFaceOrder = [17, 18, 19, 16];\r\n var bottomFaceOrder = [22, 23, 20, 21];\r\n while (topIndex > 0) {\r\n topFaceBase.unshift(topFaceBase.pop());\r\n topFaceOrder.unshift(topFaceOrder.pop());\r\n topIndex--;\r\n }\r\n while (bottomIndex > 0) {\r\n bottomFaceBase.unshift(bottomFaceBase.pop());\r\n bottomFaceOrder.unshift(bottomFaceOrder.pop());\r\n bottomIndex--;\r\n }\r\n topFaceBase = topFaceBase.flat();\r\n bottomFaceBase = bottomFaceBase.flat();\r\n basePositions = basePositions.concat(topFaceBase).concat(bottomFaceBase);\r\n indices.push(topFaceOrder[0], topFaceOrder[2], topFaceOrder[3], topFaceOrder[0], topFaceOrder[1], topFaceOrder[2]);\r\n indices.push(bottomFaceOrder[0], bottomFaceOrder[2], bottomFaceOrder[3], bottomFaceOrder[0], bottomFaceOrder[1], bottomFaceOrder[2]);\r\n }\r\n var scaleArray = [width / 2, height / 2, depth / 2];\r\n positions = basePositions.reduce(function (accumulator, currentValue, currentIndex) { return accumulator.concat(currentValue * scaleArray[currentIndex % 3]); }, []);\r\n var sideOrientation = (options.sideOrientation === 0) ? 0 : options.sideOrientation || VertexData.DEFAULTSIDE;\r\n var faceUV = options.faceUV || new Array(6);\r\n var faceColors = options.faceColors;\r\n var colors = [];\r\n // default face colors and UV if undefined\r\n for (var f = 0; f < 6; f++) {\r\n if (faceUV[f] === undefined) {\r\n faceUV[f] = new Vector4(0, 0, 1, 1);\r\n }\r\n if (faceColors && faceColors[f] === undefined) {\r\n faceColors[f] = new Color4(1, 1, 1, 1);\r\n }\r\n }\r\n // Create each face in turn.\r\n for (var index = 0; index < nbFaces; index++) {\r\n uvs.push(faceUV[index].z, faceUV[index].w);\r\n uvs.push(faceUV[index].x, faceUV[index].w);\r\n uvs.push(faceUV[index].x, faceUV[index].y);\r\n uvs.push(faceUV[index].z, faceUV[index].y);\r\n if (faceColors) {\r\n for (var c = 0; c < 4; c++) {\r\n colors.push(faceColors[index].r, faceColors[index].g, faceColors[index].b, faceColors[index].a);\r\n }\r\n }\r\n }\r\n // sides\r\n VertexData._ComputeSides(sideOrientation, positions, indices, normals, uvs, options.frontUVs, options.backUVs);\r\n // Result\r\n var vertexData = new VertexData();\r\n vertexData.indices = indices;\r\n vertexData.positions = positions;\r\n vertexData.normals = normals;\r\n vertexData.uvs = uvs;\r\n if (faceColors) {\r\n var totalColors = (sideOrientation === VertexData.DOUBLESIDE) ? colors.concat(colors) : colors;\r\n vertexData.colors = totalColors;\r\n }\r\n return vertexData;\r\n};\r\nMesh.CreateBox = function (name, size, scene, updatable, sideOrientation) {\r\n if (scene === void 0) { scene = null; }\r\n var options = {\r\n size: size,\r\n sideOrientation: sideOrientation,\r\n updatable: updatable\r\n };\r\n return BoxBuilder.CreateBox(name, options, scene);\r\n};\r\n/**\r\n * Class containing static functions to help procedurally build meshes\r\n */\r\nvar BoxBuilder = /** @class */ (function () {\r\n function BoxBuilder() {\r\n }\r\n /**\r\n * Creates a box mesh\r\n * * The parameter `size` sets the size (float) of each box side (default 1)\r\n * * You can set some different box dimensions by using the parameters `width`, `height` and `depth` (all by default have the same value of `size`)\r\n * * You can set different colors and different images to each box side by using the parameters `faceColors` (an array of 6 Color3 elements) and `faceUV` (an array of 6 Vector4 elements)\r\n * * Please read this tutorial : https://doc.babylonjs.com/how_to/createbox_per_face_textures_and_colors\r\n * * You can also set the mesh side orientation with the values : BABYLON.Mesh.FRONTSIDE (default), BABYLON.Mesh.BACKSIDE or BABYLON.Mesh.DOUBLESIDE\r\n * * If you create a double-sided mesh, you can choose what parts of the texture image to crop and stick respectively on the front and the back sides with the parameters `frontUVs` and `backUVs` (Vector4). Detail here : https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @see https://doc.babylonjs.com/how_to/set_shapes#box\r\n * @param name defines the name of the mesh\r\n * @param options defines the options used to create the mesh\r\n * @param scene defines the hosting scene\r\n * @returns the box mesh\r\n */\r\n BoxBuilder.CreateBox = function (name, options, scene) {\r\n if (scene === void 0) { scene = null; }\r\n var box = new Mesh(name, scene);\r\n options.sideOrientation = Mesh._GetDefaultSideOrientation(options.sideOrientation);\r\n box._originalBuilderSideOrientation = options.sideOrientation;\r\n var vertexData = VertexData.CreateBox(options);\r\n vertexData.applyToMesh(box, options.updatable);\r\n return box;\r\n };\r\n return BoxBuilder;\r\n}());\r\nexport { BoxBuilder };\r\n//# sourceMappingURL=boxBuilder.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'helperFunctions';\r\nvar shader = \"const float PI=3.1415926535897932384626433832795;\\nconst float HALF_MIN=5.96046448e-08;\\nconst float LinearEncodePowerApprox=2.2;\\nconst float GammaEncodePowerApprox=1.0/LinearEncodePowerApprox;\\nconst vec3 LuminanceEncodeApprox=vec3(0.2126,0.7152,0.0722);\\nconst float Epsilon=0.0000001;\\n#define saturate(x) clamp(x,0.0,1.0)\\n#define absEps(x) abs(x)+Epsilon\\n#define maxEps(x) max(x,Epsilon)\\n#define saturateEps(x) clamp(x,Epsilon,1.0)\\nmat3 transposeMat3(mat3 inMatrix) {\\nvec3 i0=inMatrix[0];\\nvec3 i1=inMatrix[1];\\nvec3 i2=inMatrix[2];\\nmat3 outMatrix=mat3(\\nvec3(i0.x,i1.x,i2.x),\\nvec3(i0.y,i1.y,i2.y),\\nvec3(i0.z,i1.z,i2.z)\\n);\\nreturn outMatrix;\\n}\\n\\nmat3 inverseMat3(mat3 inMatrix) {\\nfloat a00=inMatrix[0][0],a01=inMatrix[0][1],a02=inMatrix[0][2];\\nfloat a10=inMatrix[1][0],a11=inMatrix[1][1],a12=inMatrix[1][2];\\nfloat a20=inMatrix[2][0],a21=inMatrix[2][1],a22=inMatrix[2][2];\\nfloat b01=a22*a11-a12*a21;\\nfloat b11=-a22*a10+a12*a20;\\nfloat b21=a21*a10-a11*a20;\\nfloat det=a00*b01+a01*b11+a02*b21;\\nreturn mat3(b01,(-a22*a01+a02*a21),(a12*a01-a02*a11),\\nb11,(a22*a00-a02*a20),(-a12*a00+a02*a10),\\nb21,(-a21*a00+a01*a20),(a11*a00-a01*a10))/det;\\n}\\nfloat toLinearSpace(float color)\\n{\\nreturn pow(color,LinearEncodePowerApprox);\\n}\\nvec3 toLinearSpace(vec3 color)\\n{\\nreturn pow(color,vec3(LinearEncodePowerApprox));\\n}\\nvec4 toLinearSpace(vec4 color)\\n{\\nreturn vec4(pow(color.rgb,vec3(LinearEncodePowerApprox)),color.a);\\n}\\nvec3 toGammaSpace(vec3 color)\\n{\\nreturn pow(color,vec3(GammaEncodePowerApprox));\\n}\\nvec4 toGammaSpace(vec4 color)\\n{\\nreturn vec4(pow(color.rgb,vec3(GammaEncodePowerApprox)),color.a);\\n}\\nfloat toGammaSpace(float color)\\n{\\nreturn pow(color,GammaEncodePowerApprox);\\n}\\nfloat square(float value)\\n{\\nreturn value*value;\\n}\\nfloat pow5(float value) {\\nfloat sq=value*value;\\nreturn sq*sq*value;\\n}\\nfloat getLuminance(vec3 color)\\n{\\nreturn clamp(dot(color,LuminanceEncodeApprox),0.,1.);\\n}\\n\\nfloat getRand(vec2 seed) {\\nreturn fract(sin(dot(seed.xy ,vec2(12.9898,78.233)))*43758.5453);\\n}\\nfloat dither(vec2 seed,float varianceAmount) {\\nfloat rand=getRand(seed);\\nfloat dither=mix(-varianceAmount/255.0,varianceAmount/255.0,rand);\\nreturn dither;\\n}\\n\\nconst float rgbdMaxRange=255.0;\\nvec4 toRGBD(vec3 color) {\\nfloat maxRGB=maxEps(max(color.r,max(color.g,color.b)));\\nfloat D=max(rgbdMaxRange/maxRGB,1.);\\nD=clamp(floor(D)/255.0,0.,1.);\\n\\nvec3 rgb=color.rgb*D;\\n\\nrgb=toGammaSpace(rgb);\\nreturn vec4(rgb,D);\\n}\\nvec3 fromRGBD(vec4 rgbd) {\\n\\nrgbd.rgb=toLinearSpace(rgbd.rgb);\\n\\nreturn rgbd.rgb/rgbd.a;\\n}\\n\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var helperFunctions = { name: name, shader: shader };\r\n//# sourceMappingURL=helperFunctions.js.map","/**\n * chroma.js - JavaScript library for color conversions\n *\n * Copyright (c) 2011-2019, Gregor Aisch\n * All rights reserved.\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n *\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the documentation\n * and/or other materials provided with the distribution.\n *\n * 3. The name Gregor Aisch may not be used to endorse or promote products\n * derived from this software without specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\n * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL GREGOR AISCH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,\n * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,\n * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,\n * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY\n * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n *\n * -------------------------------------------------------\n *\n * chroma.js includes colors from colorbrewer2.org, which are released under\n * the following license:\n *\n * Copyright (c) 2002 Cynthia Brewer, Mark Harrower,\n * and The Pennsylvania State University.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing,\n * software distributed under the License is distributed on an\n * \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,\n * either express or implied. See the License for the specific\n * language governing permissions and limitations under the License.\n *\n * ------------------------------------------------------\n *\n * Named colors are taken from X11 Color Names.\n * http://www.w3.org/TR/css3-color/#svg-color\n *\n * @preserve\n */\n\n(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (global.chroma = factory());\n}(this, (function () { 'use strict';\n\n var limit = function (x, min, max) {\n if ( min === void 0 ) min=0;\n if ( max === void 0 ) max=1;\n\n return x < min ? min : x > max ? max : x;\n };\n\n var clip_rgb = function (rgb) {\n rgb._clipped = false;\n rgb._unclipped = rgb.slice(0);\n for (var i=0; i<=3; i++) {\n if (i < 3) {\n if (rgb[i] < 0 || rgb[i] > 255) { rgb._clipped = true; }\n rgb[i] = limit(rgb[i], 0, 255);\n } else if (i === 3) {\n rgb[i] = limit(rgb[i], 0, 1);\n }\n }\n return rgb;\n };\n\n // ported from jQuery's $.type\n var classToType = {};\n for (var i = 0, list = ['Boolean', 'Number', 'String', 'Function', 'Array', 'Date', 'RegExp', 'Undefined', 'Null']; i < list.length; i += 1) {\n var name = list[i];\n\n classToType[(\"[object \" + name + \"]\")] = name.toLowerCase();\n }\n var type = function(obj) {\n return classToType[Object.prototype.toString.call(obj)] || \"object\";\n };\n\n var unpack = function (args, keyOrder) {\n if ( keyOrder === void 0 ) keyOrder=null;\n\n \t// if called with more than 3 arguments, we return the arguments\n if (args.length >= 3) { return Array.prototype.slice.call(args); }\n // with less than 3 args we check if first arg is object\n // and use the keyOrder string to extract and sort properties\n \tif (type(args[0]) == 'object' && keyOrder) {\n \t\treturn keyOrder.split('')\n \t\t\t.filter(function (k) { return args[0][k] !== undefined; })\n \t\t\t.map(function (k) { return args[0][k]; });\n \t}\n \t// otherwise we just return the first argument\n \t// (which we suppose is an array of args)\n return args[0];\n };\n\n var last = function (args) {\n if (args.length < 2) { return null; }\n var l = args.length-1;\n if (type(args[l]) == 'string') { return args[l].toLowerCase(); }\n return null;\n };\n\n var PI = Math.PI;\n\n var utils = {\n \tclip_rgb: clip_rgb,\n \tlimit: limit,\n \ttype: type,\n \tunpack: unpack,\n \tlast: last,\n \tPI: PI,\n \tTWOPI: PI*2,\n \tPITHIRD: PI/3,\n \tDEG2RAD: PI / 180,\n \tRAD2DEG: 180 / PI\n };\n\n var input = {\n \tformat: {},\n \tautodetect: []\n };\n\n var last$1 = utils.last;\n var clip_rgb$1 = utils.clip_rgb;\n var type$1 = utils.type;\n\n\n var Color = function Color() {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var me = this;\n if (type$1(args[0]) === 'object' &&\n args[0].constructor &&\n args[0].constructor === this.constructor) {\n // the argument is already a Color instance\n return args[0];\n }\n\n // last argument could be the mode\n var mode = last$1(args);\n var autodetect = false;\n\n if (!mode) {\n autodetect = true;\n if (!input.sorted) {\n input.autodetect = input.autodetect.sort(function (a,b) { return b.p - a.p; });\n input.sorted = true;\n }\n // auto-detect format\n for (var i = 0, list = input.autodetect; i < list.length; i += 1) {\n var chk = list[i];\n\n mode = chk.test.apply(chk, args);\n if (mode) { break; }\n }\n }\n\n if (input.format[mode]) {\n var rgb = input.format[mode].apply(null, autodetect ? args : args.slice(0,-1));\n me._rgb = clip_rgb$1(rgb);\n } else {\n throw new Error('unknown format: '+args);\n }\n\n // add alpha channel\n if (me._rgb.length === 3) { me._rgb.push(1); }\n };\n\n Color.prototype.toString = function toString () {\n if (type$1(this.hex) == 'function') { return this.hex(); }\n return (\"[\" + (this._rgb.join(',')) + \"]\");\n };\n\n var Color_1 = Color;\n\n var chroma = function () {\n \tvar args = [], len = arguments.length;\n \twhile ( len-- ) args[ len ] = arguments[ len ];\n\n \treturn new (Function.prototype.bind.apply( chroma.Color, [ null ].concat( args) ));\n };\n\n chroma.Color = Color_1;\n chroma.version = '2.1.0';\n\n var chroma_1 = chroma;\n\n var unpack$1 = utils.unpack;\n var max = Math.max;\n\n var rgb2cmyk = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$1(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n r = r / 255;\n g = g / 255;\n b = b / 255;\n var k = 1 - max(r,max(g,b));\n var f = k < 1 ? 1 / (1-k) : 0;\n var c = (1-r-k) * f;\n var m = (1-g-k) * f;\n var y = (1-b-k) * f;\n return [c,m,y,k];\n };\n\n var rgb2cmyk_1 = rgb2cmyk;\n\n var unpack$2 = utils.unpack;\n\n var cmyk2rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$2(args, 'cmyk');\n var c = args[0];\n var m = args[1];\n var y = args[2];\n var k = args[3];\n var alpha = args.length > 4 ? args[4] : 1;\n if (k === 1) { return [0,0,0,alpha]; }\n return [\n c >= 1 ? 0 : 255 * (1-c) * (1-k), // r\n m >= 1 ? 0 : 255 * (1-m) * (1-k), // g\n y >= 1 ? 0 : 255 * (1-y) * (1-k), // b\n alpha\n ];\n };\n\n var cmyk2rgb_1 = cmyk2rgb;\n\n var unpack$3 = utils.unpack;\n var type$2 = utils.type;\n\n\n\n Color_1.prototype.cmyk = function() {\n return rgb2cmyk_1(this._rgb);\n };\n\n chroma_1.cmyk = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['cmyk']) ));\n };\n\n input.format.cmyk = cmyk2rgb_1;\n\n input.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$3(args, 'cmyk');\n if (type$2(args) === 'array' && args.length === 4) {\n return 'cmyk';\n }\n }\n });\n\n var unpack$4 = utils.unpack;\n var last$2 = utils.last;\n var rnd = function (a) { return Math.round(a*100)/100; };\n\n /*\n * supported arguments:\n * - hsl2css(h,s,l)\n * - hsl2css(h,s,l,a)\n * - hsl2css([h,s,l], mode)\n * - hsl2css([h,s,l,a], mode)\n * - hsl2css({h,s,l,a}, mode)\n */\n var hsl2css = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var hsla = unpack$4(args, 'hsla');\n var mode = last$2(args) || 'lsa';\n hsla[0] = rnd(hsla[0] || 0);\n hsla[1] = rnd(hsla[1]*100) + '%';\n hsla[2] = rnd(hsla[2]*100) + '%';\n if (mode === 'hsla' || (hsla.length > 3 && hsla[3]<1)) {\n hsla[3] = hsla.length > 3 ? hsla[3] : 1;\n mode = 'hsla';\n } else {\n hsla.length = 3;\n }\n return (mode + \"(\" + (hsla.join(',')) + \")\");\n };\n\n var hsl2css_1 = hsl2css;\n\n var unpack$5 = utils.unpack;\n\n /*\n * supported arguments:\n * - rgb2hsl(r,g,b)\n * - rgb2hsl(r,g,b,a)\n * - rgb2hsl([r,g,b])\n * - rgb2hsl([r,g,b,a])\n * - rgb2hsl({r,g,b,a})\n */\n var rgb2hsl = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$5(args, 'rgba');\n var r = args[0];\n var g = args[1];\n var b = args[2];\n\n r /= 255;\n g /= 255;\n b /= 255;\n\n var min = Math.min(r, g, b);\n var max = Math.max(r, g, b);\n\n var l = (max + min) / 2;\n var s, h;\n\n if (max === min){\n s = 0;\n h = Number.NaN;\n } else {\n s = l < 0.5 ? (max - min) / (max + min) : (max - min) / (2 - max - min);\n }\n\n if (r == max) { h = (g - b) / (max - min); }\n else if (g == max) { h = 2 + (b - r) / (max - min); }\n else if (b == max) { h = 4 + (r - g) / (max - min); }\n\n h *= 60;\n if (h < 0) { h += 360; }\n if (args.length>3 && args[3]!==undefined) { return [h,s,l,args[3]]; }\n return [h,s,l];\n };\n\n var rgb2hsl_1 = rgb2hsl;\n\n var unpack$6 = utils.unpack;\n var last$3 = utils.last;\n\n\n var round = Math.round;\n\n /*\n * supported arguments:\n * - rgb2css(r,g,b)\n * - rgb2css(r,g,b,a)\n * - rgb2css([r,g,b], mode)\n * - rgb2css([r,g,b,a], mode)\n * - rgb2css({r,g,b,a}, mode)\n */\n var rgb2css = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var rgba = unpack$6(args, 'rgba');\n var mode = last$3(args) || 'rgb';\n if (mode.substr(0,3) == 'hsl') {\n return hsl2css_1(rgb2hsl_1(rgba), mode);\n }\n rgba[0] = round(rgba[0]);\n rgba[1] = round(rgba[1]);\n rgba[2] = round(rgba[2]);\n if (mode === 'rgba' || (rgba.length > 3 && rgba[3]<1)) {\n rgba[3] = rgba.length > 3 ? rgba[3] : 1;\n mode = 'rgba';\n }\n return (mode + \"(\" + (rgba.slice(0,mode==='rgb'?3:4).join(',')) + \")\");\n };\n\n var rgb2css_1 = rgb2css;\n\n var unpack$7 = utils.unpack;\n var round$1 = Math.round;\n\n var hsl2rgb = function () {\n var assign;\n\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n args = unpack$7(args, 'hsl');\n var h = args[0];\n var s = args[1];\n var l = args[2];\n var r,g,b;\n if (s === 0) {\n r = g = b = l*255;\n } else {\n var t3 = [0,0,0];\n var c = [0,0,0];\n var t2 = l < 0.5 ? l * (1+s) : l+s-l*s;\n var t1 = 2 * l - t2;\n var h_ = h / 360;\n t3[0] = h_ + 1/3;\n t3[1] = h_;\n t3[2] = h_ - 1/3;\n for (var i=0; i<3; i++) {\n if (t3[i] < 0) { t3[i] += 1; }\n if (t3[i] > 1) { t3[i] -= 1; }\n if (6 * t3[i] < 1)\n { c[i] = t1 + (t2 - t1) * 6 * t3[i]; }\n else if (2 * t3[i] < 1)\n { c[i] = t2; }\n else if (3 * t3[i] < 2)\n { c[i] = t1 + (t2 - t1) * ((2 / 3) - t3[i]) * 6; }\n else\n { c[i] = t1; }\n }\n (assign = [round$1(c[0]*255),round$1(c[1]*255),round$1(c[2]*255)], r = assign[0], g = assign[1], b = assign[2]);\n }\n if (args.length > 3) {\n // keep alpha channel\n return [r,g,b,args[3]];\n }\n return [r,g,b,1];\n };\n\n var hsl2rgb_1 = hsl2rgb;\n\n var RE_RGB = /^rgb\\(\\s*(-?\\d+),\\s*(-?\\d+)\\s*,\\s*(-?\\d+)\\s*\\)$/;\n var RE_RGBA = /^rgba\\(\\s*(-?\\d+),\\s*(-?\\d+)\\s*,\\s*(-?\\d+)\\s*,\\s*([01]|[01]?\\.\\d+)\\)$/;\n var RE_RGB_PCT = /^rgb\\(\\s*(-?\\d+(?:\\.\\d+)?)%,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*\\)$/;\n var RE_RGBA_PCT = /^rgba\\(\\s*(-?\\d+(?:\\.\\d+)?)%,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*([01]|[01]?\\.\\d+)\\)$/;\n var RE_HSL = /^hsl\\(\\s*(-?\\d+(?:\\.\\d+)?),\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*\\)$/;\n var RE_HSLA = /^hsla\\(\\s*(-?\\d+(?:\\.\\d+)?),\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*([01]|[01]?\\.\\d+)\\)$/;\n\n var round$2 = Math.round;\n\n var css2rgb = function (css) {\n css = css.toLowerCase().trim();\n var m;\n\n if (input.format.named) {\n try {\n return input.format.named(css);\n } catch (e) {\n // eslint-disable-next-line\n }\n }\n\n // rgb(250,20,0)\n if ((m = css.match(RE_RGB))) {\n var rgb = m.slice(1,4);\n for (var i=0; i<3; i++) {\n rgb[i] = +rgb[i];\n }\n rgb[3] = 1; // default alpha\n return rgb;\n }\n\n // rgba(250,20,0,0.4)\n if ((m = css.match(RE_RGBA))) {\n var rgb$1 = m.slice(1,5);\n for (var i$1=0; i$1<4; i$1++) {\n rgb$1[i$1] = +rgb$1[i$1];\n }\n return rgb$1;\n }\n\n // rgb(100%,0%,0%)\n if ((m = css.match(RE_RGB_PCT))) {\n var rgb$2 = m.slice(1,4);\n for (var i$2=0; i$2<3; i$2++) {\n rgb$2[i$2] = round$2(rgb$2[i$2] * 2.55);\n }\n rgb$2[3] = 1; // default alpha\n return rgb$2;\n }\n\n // rgba(100%,0%,0%,0.4)\n if ((m = css.match(RE_RGBA_PCT))) {\n var rgb$3 = m.slice(1,5);\n for (var i$3=0; i$3<3; i$3++) {\n rgb$3[i$3] = round$2(rgb$3[i$3] * 2.55);\n }\n rgb$3[3] = +rgb$3[3];\n return rgb$3;\n }\n\n // hsl(0,100%,50%)\n if ((m = css.match(RE_HSL))) {\n var hsl = m.slice(1,4);\n hsl[1] *= 0.01;\n hsl[2] *= 0.01;\n var rgb$4 = hsl2rgb_1(hsl);\n rgb$4[3] = 1;\n return rgb$4;\n }\n\n // hsla(0,100%,50%,0.5)\n if ((m = css.match(RE_HSLA))) {\n var hsl$1 = m.slice(1,4);\n hsl$1[1] *= 0.01;\n hsl$1[2] *= 0.01;\n var rgb$5 = hsl2rgb_1(hsl$1);\n rgb$5[3] = +m[4]; // default alpha = 1\n return rgb$5;\n }\n };\n\n css2rgb.test = function (s) {\n return RE_RGB.test(s) ||\n RE_RGBA.test(s) ||\n RE_RGB_PCT.test(s) ||\n RE_RGBA_PCT.test(s) ||\n RE_HSL.test(s) ||\n RE_HSLA.test(s);\n };\n\n var css2rgb_1 = css2rgb;\n\n var type$3 = utils.type;\n\n\n\n\n Color_1.prototype.css = function(mode) {\n return rgb2css_1(this._rgb, mode);\n };\n\n chroma_1.css = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['css']) ));\n };\n\n input.format.css = css2rgb_1;\n\n input.autodetect.push({\n p: 5,\n test: function (h) {\n var rest = [], len = arguments.length - 1;\n while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];\n\n if (!rest.length && type$3(h) === 'string' && css2rgb_1.test(h)) {\n return 'css';\n }\n }\n });\n\n var unpack$8 = utils.unpack;\n\n input.format.gl = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var rgb = unpack$8(args, 'rgba');\n rgb[0] *= 255;\n rgb[1] *= 255;\n rgb[2] *= 255;\n return rgb;\n };\n\n chroma_1.gl = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['gl']) ));\n };\n\n Color_1.prototype.gl = function() {\n var rgb = this._rgb;\n return [rgb[0]/255, rgb[1]/255, rgb[2]/255, rgb[3]];\n };\n\n var unpack$9 = utils.unpack;\n\n var rgb2hcg = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$9(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n var min = Math.min(r, g, b);\n var max = Math.max(r, g, b);\n var delta = max - min;\n var c = delta * 100 / 255;\n var _g = min / (255 - delta) * 100;\n var h;\n if (delta === 0) {\n h = Number.NaN;\n } else {\n if (r === max) { h = (g - b) / delta; }\n if (g === max) { h = 2+(b - r) / delta; }\n if (b === max) { h = 4+(r - g) / delta; }\n h *= 60;\n if (h < 0) { h += 360; }\n }\n return [h, c, _g];\n };\n\n var rgb2hcg_1 = rgb2hcg;\n\n var unpack$a = utils.unpack;\n var floor = Math.floor;\n\n /*\n * this is basically just HSV with some minor tweaks\n *\n * hue.. [0..360]\n * chroma .. [0..1]\n * grayness .. [0..1]\n */\n\n var hcg2rgb = function () {\n var assign, assign$1, assign$2, assign$3, assign$4, assign$5;\n\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n args = unpack$a(args, 'hcg');\n var h = args[0];\n var c = args[1];\n var _g = args[2];\n var r,g,b;\n _g = _g * 255;\n var _c = c * 255;\n if (c === 0) {\n r = g = b = _g;\n } else {\n if (h === 360) { h = 0; }\n if (h > 360) { h -= 360; }\n if (h < 0) { h += 360; }\n h /= 60;\n var i = floor(h);\n var f = h - i;\n var p = _g * (1 - c);\n var q = p + _c * (1 - f);\n var t = p + _c * f;\n var v = p + _c;\n switch (i) {\n case 0: (assign = [v, t, p], r = assign[0], g = assign[1], b = assign[2]); break\n case 1: (assign$1 = [q, v, p], r = assign$1[0], g = assign$1[1], b = assign$1[2]); break\n case 2: (assign$2 = [p, v, t], r = assign$2[0], g = assign$2[1], b = assign$2[2]); break\n case 3: (assign$3 = [p, q, v], r = assign$3[0], g = assign$3[1], b = assign$3[2]); break\n case 4: (assign$4 = [t, p, v], r = assign$4[0], g = assign$4[1], b = assign$4[2]); break\n case 5: (assign$5 = [v, p, q], r = assign$5[0], g = assign$5[1], b = assign$5[2]); break\n }\n }\n return [r, g, b, args.length > 3 ? args[3] : 1];\n };\n\n var hcg2rgb_1 = hcg2rgb;\n\n var unpack$b = utils.unpack;\n var type$4 = utils.type;\n\n\n\n\n\n\n Color_1.prototype.hcg = function() {\n return rgb2hcg_1(this._rgb);\n };\n\n chroma_1.hcg = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hcg']) ));\n };\n\n input.format.hcg = hcg2rgb_1;\n\n input.autodetect.push({\n p: 1,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$b(args, 'hcg');\n if (type$4(args) === 'array' && args.length === 3) {\n return 'hcg';\n }\n }\n });\n\n var unpack$c = utils.unpack;\n var last$4 = utils.last;\n var round$3 = Math.round;\n\n var rgb2hex = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$c(args, 'rgba');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n var a = ref[3];\n var mode = last$4(args) || 'auto';\n if (a === undefined) { a = 1; }\n if (mode === 'auto') {\n mode = a < 1 ? 'rgba' : 'rgb';\n }\n r = round$3(r);\n g = round$3(g);\n b = round$3(b);\n var u = r << 16 | g << 8 | b;\n var str = \"000000\" + u.toString(16); //#.toUpperCase();\n str = str.substr(str.length - 6);\n var hxa = '0' + round$3(a * 255).toString(16);\n hxa = hxa.substr(hxa.length - 2);\n switch (mode.toLowerCase()) {\n case 'rgba': return (\"#\" + str + hxa);\n case 'argb': return (\"#\" + hxa + str);\n default: return (\"#\" + str);\n }\n };\n\n var rgb2hex_1 = rgb2hex;\n\n var RE_HEX = /^#?([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/;\n var RE_HEXA = /^#?([A-Fa-f0-9]{8}|[A-Fa-f0-9]{4})$/;\n\n var hex2rgb = function (hex) {\n if (hex.match(RE_HEX)) {\n // remove optional leading #\n if (hex.length === 4 || hex.length === 7) {\n hex = hex.substr(1);\n }\n // expand short-notation to full six-digit\n if (hex.length === 3) {\n hex = hex.split('');\n hex = hex[0]+hex[0]+hex[1]+hex[1]+hex[2]+hex[2];\n }\n var u = parseInt(hex, 16);\n var r = u >> 16;\n var g = u >> 8 & 0xFF;\n var b = u & 0xFF;\n return [r,g,b,1];\n }\n\n // match rgba hex format, eg #FF000077\n if (hex.match(RE_HEXA)) {\n if (hex.length === 5 || hex.length === 9) {\n // remove optional leading #\n hex = hex.substr(1);\n }\n // expand short-notation to full eight-digit\n if (hex.length === 4) {\n hex = hex.split('');\n hex = hex[0]+hex[0]+hex[1]+hex[1]+hex[2]+hex[2]+hex[3]+hex[3];\n }\n var u$1 = parseInt(hex, 16);\n var r$1 = u$1 >> 24 & 0xFF;\n var g$1 = u$1 >> 16 & 0xFF;\n var b$1 = u$1 >> 8 & 0xFF;\n var a = Math.round((u$1 & 0xFF) / 0xFF * 100) / 100;\n return [r$1,g$1,b$1,a];\n }\n\n // we used to check for css colors here\n // if _input.css? and rgb = _input.css hex\n // return rgb\n\n throw new Error((\"unknown hex color: \" + hex));\n };\n\n var hex2rgb_1 = hex2rgb;\n\n var type$5 = utils.type;\n\n\n\n\n Color_1.prototype.hex = function(mode) {\n return rgb2hex_1(this._rgb, mode);\n };\n\n chroma_1.hex = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hex']) ));\n };\n\n input.format.hex = hex2rgb_1;\n input.autodetect.push({\n p: 4,\n test: function (h) {\n var rest = [], len = arguments.length - 1;\n while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];\n\n if (!rest.length && type$5(h) === 'string' && [3,4,5,6,7,8,9].indexOf(h.length) >= 0) {\n return 'hex';\n }\n }\n });\n\n var unpack$d = utils.unpack;\n var TWOPI = utils.TWOPI;\n var min = Math.min;\n var sqrt = Math.sqrt;\n var acos = Math.acos;\n\n var rgb2hsi = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n /*\n borrowed from here:\n http://hummer.stanford.edu/museinfo/doc/examples/humdrum/keyscape2/rgb2hsi.cpp\n */\n var ref = unpack$d(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n r /= 255;\n g /= 255;\n b /= 255;\n var h;\n var min_ = min(r,g,b);\n var i = (r+g+b) / 3;\n var s = i > 0 ? 1 - min_/i : 0;\n if (s === 0) {\n h = NaN;\n } else {\n h = ((r-g)+(r-b)) / 2;\n h /= sqrt((r-g)*(r-g) + (r-b)*(g-b));\n h = acos(h);\n if (b > g) {\n h = TWOPI - h;\n }\n h /= TWOPI;\n }\n return [h*360,s,i];\n };\n\n var rgb2hsi_1 = rgb2hsi;\n\n var unpack$e = utils.unpack;\n var limit$1 = utils.limit;\n var TWOPI$1 = utils.TWOPI;\n var PITHIRD = utils.PITHIRD;\n var cos = Math.cos;\n\n /*\n * hue [0..360]\n * saturation [0..1]\n * intensity [0..1]\n */\n var hsi2rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n /*\n borrowed from here:\n http://hummer.stanford.edu/museinfo/doc/examples/humdrum/keyscape2/hsi2rgb.cpp\n */\n args = unpack$e(args, 'hsi');\n var h = args[0];\n var s = args[1];\n var i = args[2];\n var r,g,b;\n\n if (isNaN(h)) { h = 0; }\n if (isNaN(s)) { s = 0; }\n // normalize hue\n if (h > 360) { h -= 360; }\n if (h < 0) { h += 360; }\n h /= 360;\n if (h < 1/3) {\n b = (1-s)/3;\n r = (1+s*cos(TWOPI$1*h)/cos(PITHIRD-TWOPI$1*h))/3;\n g = 1 - (b+r);\n } else if (h < 2/3) {\n h -= 1/3;\n r = (1-s)/3;\n g = (1+s*cos(TWOPI$1*h)/cos(PITHIRD-TWOPI$1*h))/3;\n b = 1 - (r+g);\n } else {\n h -= 2/3;\n g = (1-s)/3;\n b = (1+s*cos(TWOPI$1*h)/cos(PITHIRD-TWOPI$1*h))/3;\n r = 1 - (g+b);\n }\n r = limit$1(i*r*3);\n g = limit$1(i*g*3);\n b = limit$1(i*b*3);\n return [r*255, g*255, b*255, args.length > 3 ? args[3] : 1];\n };\n\n var hsi2rgb_1 = hsi2rgb;\n\n var unpack$f = utils.unpack;\n var type$6 = utils.type;\n\n\n\n\n\n\n Color_1.prototype.hsi = function() {\n return rgb2hsi_1(this._rgb);\n };\n\n chroma_1.hsi = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hsi']) ));\n };\n\n input.format.hsi = hsi2rgb_1;\n\n input.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$f(args, 'hsi');\n if (type$6(args) === 'array' && args.length === 3) {\n return 'hsi';\n }\n }\n });\n\n var unpack$g = utils.unpack;\n var type$7 = utils.type;\n\n\n\n\n\n\n Color_1.prototype.hsl = function() {\n return rgb2hsl_1(this._rgb);\n };\n\n chroma_1.hsl = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hsl']) ));\n };\n\n input.format.hsl = hsl2rgb_1;\n\n input.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$g(args, 'hsl');\n if (type$7(args) === 'array' && args.length === 3) {\n return 'hsl';\n }\n }\n });\n\n var unpack$h = utils.unpack;\n var min$1 = Math.min;\n var max$1 = Math.max;\n\n /*\n * supported arguments:\n * - rgb2hsv(r,g,b)\n * - rgb2hsv([r,g,b])\n * - rgb2hsv({r,g,b})\n */\n var rgb2hsl$1 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$h(args, 'rgb');\n var r = args[0];\n var g = args[1];\n var b = args[2];\n var min_ = min$1(r, g, b);\n var max_ = max$1(r, g, b);\n var delta = max_ - min_;\n var h,s,v;\n v = max_ / 255.0;\n if (max_ === 0) {\n h = Number.NaN;\n s = 0;\n } else {\n s = delta / max_;\n if (r === max_) { h = (g - b) / delta; }\n if (g === max_) { h = 2+(b - r) / delta; }\n if (b === max_) { h = 4+(r - g) / delta; }\n h *= 60;\n if (h < 0) { h += 360; }\n }\n return [h, s, v]\n };\n\n var rgb2hsv = rgb2hsl$1;\n\n var unpack$i = utils.unpack;\n var floor$1 = Math.floor;\n\n var hsv2rgb = function () {\n var assign, assign$1, assign$2, assign$3, assign$4, assign$5;\n\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n args = unpack$i(args, 'hsv');\n var h = args[0];\n var s = args[1];\n var v = args[2];\n var r,g,b;\n v *= 255;\n if (s === 0) {\n r = g = b = v;\n } else {\n if (h === 360) { h = 0; }\n if (h > 360) { h -= 360; }\n if (h < 0) { h += 360; }\n h /= 60;\n\n var i = floor$1(h);\n var f = h - i;\n var p = v * (1 - s);\n var q = v * (1 - s * f);\n var t = v * (1 - s * (1 - f));\n\n switch (i) {\n case 0: (assign = [v, t, p], r = assign[0], g = assign[1], b = assign[2]); break\n case 1: (assign$1 = [q, v, p], r = assign$1[0], g = assign$1[1], b = assign$1[2]); break\n case 2: (assign$2 = [p, v, t], r = assign$2[0], g = assign$2[1], b = assign$2[2]); break\n case 3: (assign$3 = [p, q, v], r = assign$3[0], g = assign$3[1], b = assign$3[2]); break\n case 4: (assign$4 = [t, p, v], r = assign$4[0], g = assign$4[1], b = assign$4[2]); break\n case 5: (assign$5 = [v, p, q], r = assign$5[0], g = assign$5[1], b = assign$5[2]); break\n }\n }\n return [r,g,b,args.length > 3?args[3]:1];\n };\n\n var hsv2rgb_1 = hsv2rgb;\n\n var unpack$j = utils.unpack;\n var type$8 = utils.type;\n\n\n\n\n\n\n Color_1.prototype.hsv = function() {\n return rgb2hsv(this._rgb);\n };\n\n chroma_1.hsv = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hsv']) ));\n };\n\n input.format.hsv = hsv2rgb_1;\n\n input.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$j(args, 'hsv');\n if (type$8(args) === 'array' && args.length === 3) {\n return 'hsv';\n }\n }\n });\n\n var labConstants = {\n // Corresponds roughly to RGB brighter/darker\n Kn: 18,\n\n // D65 standard referent\n Xn: 0.950470,\n Yn: 1,\n Zn: 1.088830,\n\n t0: 0.137931034, // 4 / 29\n t1: 0.206896552, // 6 / 29\n t2: 0.12841855, // 3 * t1 * t1\n t3: 0.008856452, // t1 * t1 * t1\n };\n\n var unpack$k = utils.unpack;\n var pow = Math.pow;\n\n var rgb2lab = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$k(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n var ref$1 = rgb2xyz(r,g,b);\n var x = ref$1[0];\n var y = ref$1[1];\n var z = ref$1[2];\n var l = 116 * y - 16;\n return [l < 0 ? 0 : l, 500 * (x - y), 200 * (y - z)];\n };\n\n var rgb_xyz = function (r) {\n if ((r /= 255) <= 0.04045) { return r / 12.92; }\n return pow((r + 0.055) / 1.055, 2.4);\n };\n\n var xyz_lab = function (t) {\n if (t > labConstants.t3) { return pow(t, 1 / 3); }\n return t / labConstants.t2 + labConstants.t0;\n };\n\n var rgb2xyz = function (r,g,b) {\n r = rgb_xyz(r);\n g = rgb_xyz(g);\n b = rgb_xyz(b);\n var x = xyz_lab((0.4124564 * r + 0.3575761 * g + 0.1804375 * b) / labConstants.Xn);\n var y = xyz_lab((0.2126729 * r + 0.7151522 * g + 0.0721750 * b) / labConstants.Yn);\n var z = xyz_lab((0.0193339 * r + 0.1191920 * g + 0.9503041 * b) / labConstants.Zn);\n return [x,y,z];\n };\n\n var rgb2lab_1 = rgb2lab;\n\n var unpack$l = utils.unpack;\n var pow$1 = Math.pow;\n\n /*\n * L* [0..100]\n * a [-100..100]\n * b [-100..100]\n */\n var lab2rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$l(args, 'lab');\n var l = args[0];\n var a = args[1];\n var b = args[2];\n var x,y,z, r,g,b_;\n\n y = (l + 16) / 116;\n x = isNaN(a) ? y : y + a / 500;\n z = isNaN(b) ? y : y - b / 200;\n\n y = labConstants.Yn * lab_xyz(y);\n x = labConstants.Xn * lab_xyz(x);\n z = labConstants.Zn * lab_xyz(z);\n\n r = xyz_rgb(3.2404542 * x - 1.5371385 * y - 0.4985314 * z); // D65 -> sRGB\n g = xyz_rgb(-0.9692660 * x + 1.8760108 * y + 0.0415560 * z);\n b_ = xyz_rgb(0.0556434 * x - 0.2040259 * y + 1.0572252 * z);\n\n return [r,g,b_,args.length > 3 ? args[3] : 1];\n };\n\n var xyz_rgb = function (r) {\n return 255 * (r <= 0.00304 ? 12.92 * r : 1.055 * pow$1(r, 1 / 2.4) - 0.055)\n };\n\n var lab_xyz = function (t) {\n return t > labConstants.t1 ? t * t * t : labConstants.t2 * (t - labConstants.t0)\n };\n\n var lab2rgb_1 = lab2rgb;\n\n var unpack$m = utils.unpack;\n var type$9 = utils.type;\n\n\n\n\n\n\n Color_1.prototype.lab = function() {\n return rgb2lab_1(this._rgb);\n };\n\n chroma_1.lab = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['lab']) ));\n };\n\n input.format.lab = lab2rgb_1;\n\n input.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$m(args, 'lab');\n if (type$9(args) === 'array' && args.length === 3) {\n return 'lab';\n }\n }\n });\n\n var unpack$n = utils.unpack;\n var RAD2DEG = utils.RAD2DEG;\n var sqrt$1 = Math.sqrt;\n var atan2 = Math.atan2;\n var round$4 = Math.round;\n\n var lab2lch = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$n(args, 'lab');\n var l = ref[0];\n var a = ref[1];\n var b = ref[2];\n var c = sqrt$1(a * a + b * b);\n var h = (atan2(b, a) * RAD2DEG + 360) % 360;\n if (round$4(c*10000) === 0) { h = Number.NaN; }\n return [l, c, h];\n };\n\n var lab2lch_1 = lab2lch;\n\n var unpack$o = utils.unpack;\n\n\n\n var rgb2lch = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$o(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n var ref$1 = rgb2lab_1(r,g,b);\n var l = ref$1[0];\n var a = ref$1[1];\n var b_ = ref$1[2];\n return lab2lch_1(l,a,b_);\n };\n\n var rgb2lch_1 = rgb2lch;\n\n var unpack$p = utils.unpack;\n var DEG2RAD = utils.DEG2RAD;\n var sin = Math.sin;\n var cos$1 = Math.cos;\n\n var lch2lab = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n /*\n Convert from a qualitative parameter h and a quantitative parameter l to a 24-bit pixel.\n These formulas were invented by David Dalrymple to obtain maximum contrast without going\n out of gamut if the parameters are in the range 0-1.\n\n A saturation multiplier was added by Gregor Aisch\n */\n var ref = unpack$p(args, 'lch');\n var l = ref[0];\n var c = ref[1];\n var h = ref[2];\n if (isNaN(h)) { h = 0; }\n h = h * DEG2RAD;\n return [l, cos$1(h) * c, sin(h) * c]\n };\n\n var lch2lab_1 = lch2lab;\n\n var unpack$q = utils.unpack;\n\n\n\n var lch2rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$q(args, 'lch');\n var l = args[0];\n var c = args[1];\n var h = args[2];\n var ref = lch2lab_1 (l,c,h);\n var L = ref[0];\n var a = ref[1];\n var b_ = ref[2];\n var ref$1 = lab2rgb_1 (L,a,b_);\n var r = ref$1[0];\n var g = ref$1[1];\n var b = ref$1[2];\n return [r, g, b, args.length > 3 ? args[3] : 1];\n };\n\n var lch2rgb_1 = lch2rgb;\n\n var unpack$r = utils.unpack;\n\n\n var hcl2rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var hcl = unpack$r(args, 'hcl').reverse();\n return lch2rgb_1.apply(void 0, hcl);\n };\n\n var hcl2rgb_1 = hcl2rgb;\n\n var unpack$s = utils.unpack;\n var type$a = utils.type;\n\n\n\n\n\n\n Color_1.prototype.lch = function() { return rgb2lch_1(this._rgb); };\n Color_1.prototype.hcl = function() { return rgb2lch_1(this._rgb).reverse(); };\n\n chroma_1.lch = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['lch']) ));\n };\n chroma_1.hcl = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hcl']) ));\n };\n\n input.format.lch = lch2rgb_1;\n input.format.hcl = hcl2rgb_1;\n\n ['lch','hcl'].forEach(function (m) { return input.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$s(args, m);\n if (type$a(args) === 'array' && args.length === 3) {\n return m;\n }\n }\n }); });\n\n /**\n \tX11 color names\n\n \thttp://www.w3.org/TR/css3-color/#svg-color\n */\n\n var w3cx11 = {\n aliceblue: '#f0f8ff',\n antiquewhite: '#faebd7',\n aqua: '#00ffff',\n aquamarine: '#7fffd4',\n azure: '#f0ffff',\n beige: '#f5f5dc',\n bisque: '#ffe4c4',\n black: '#000000',\n blanchedalmond: '#ffebcd',\n blue: '#0000ff',\n blueviolet: '#8a2be2',\n brown: '#a52a2a',\n burlywood: '#deb887',\n cadetblue: '#5f9ea0',\n chartreuse: '#7fff00',\n chocolate: '#d2691e',\n coral: '#ff7f50',\n cornflower: '#6495ed',\n cornflowerblue: '#6495ed',\n cornsilk: '#fff8dc',\n crimson: '#dc143c',\n cyan: '#00ffff',\n darkblue: '#00008b',\n darkcyan: '#008b8b',\n darkgoldenrod: '#b8860b',\n darkgray: '#a9a9a9',\n darkgreen: '#006400',\n darkgrey: '#a9a9a9',\n darkkhaki: '#bdb76b',\n darkmagenta: '#8b008b',\n darkolivegreen: '#556b2f',\n darkorange: '#ff8c00',\n darkorchid: '#9932cc',\n darkred: '#8b0000',\n darksalmon: '#e9967a',\n darkseagreen: '#8fbc8f',\n darkslateblue: '#483d8b',\n darkslategray: '#2f4f4f',\n darkslategrey: '#2f4f4f',\n darkturquoise: '#00ced1',\n darkviolet: '#9400d3',\n deeppink: '#ff1493',\n deepskyblue: '#00bfff',\n dimgray: '#696969',\n dimgrey: '#696969',\n dodgerblue: '#1e90ff',\n firebrick: '#b22222',\n floralwhite: '#fffaf0',\n forestgreen: '#228b22',\n fuchsia: '#ff00ff',\n gainsboro: '#dcdcdc',\n ghostwhite: '#f8f8ff',\n gold: '#ffd700',\n goldenrod: '#daa520',\n gray: '#808080',\n green: '#008000',\n greenyellow: '#adff2f',\n grey: '#808080',\n honeydew: '#f0fff0',\n hotpink: '#ff69b4',\n indianred: '#cd5c5c',\n indigo: '#4b0082',\n ivory: '#fffff0',\n khaki: '#f0e68c',\n laserlemon: '#ffff54',\n lavender: '#e6e6fa',\n lavenderblush: '#fff0f5',\n lawngreen: '#7cfc00',\n lemonchiffon: '#fffacd',\n lightblue: '#add8e6',\n lightcoral: '#f08080',\n lightcyan: '#e0ffff',\n lightgoldenrod: '#fafad2',\n lightgoldenrodyellow: '#fafad2',\n lightgray: '#d3d3d3',\n lightgreen: '#90ee90',\n lightgrey: '#d3d3d3',\n lightpink: '#ffb6c1',\n lightsalmon: '#ffa07a',\n lightseagreen: '#20b2aa',\n lightskyblue: '#87cefa',\n lightslategray: '#778899',\n lightslategrey: '#778899',\n lightsteelblue: '#b0c4de',\n lightyellow: '#ffffe0',\n lime: '#00ff00',\n limegreen: '#32cd32',\n linen: '#faf0e6',\n magenta: '#ff00ff',\n maroon: '#800000',\n maroon2: '#7f0000',\n maroon3: '#b03060',\n mediumaquamarine: '#66cdaa',\n mediumblue: '#0000cd',\n mediumorchid: '#ba55d3',\n mediumpurple: '#9370db',\n mediumseagreen: '#3cb371',\n mediumslateblue: '#7b68ee',\n mediumspringgreen: '#00fa9a',\n mediumturquoise: '#48d1cc',\n mediumvioletred: '#c71585',\n midnightblue: '#191970',\n mintcream: '#f5fffa',\n mistyrose: '#ffe4e1',\n moccasin: '#ffe4b5',\n navajowhite: '#ffdead',\n navy: '#000080',\n oldlace: '#fdf5e6',\n olive: '#808000',\n olivedrab: '#6b8e23',\n orange: '#ffa500',\n orangered: '#ff4500',\n orchid: '#da70d6',\n palegoldenrod: '#eee8aa',\n palegreen: '#98fb98',\n paleturquoise: '#afeeee',\n palevioletred: '#db7093',\n papayawhip: '#ffefd5',\n peachpuff: '#ffdab9',\n peru: '#cd853f',\n pink: '#ffc0cb',\n plum: '#dda0dd',\n powderblue: '#b0e0e6',\n purple: '#800080',\n purple2: '#7f007f',\n purple3: '#a020f0',\n rebeccapurple: '#663399',\n red: '#ff0000',\n rosybrown: '#bc8f8f',\n royalblue: '#4169e1',\n saddlebrown: '#8b4513',\n salmon: '#fa8072',\n sandybrown: '#f4a460',\n seagreen: '#2e8b57',\n seashell: '#fff5ee',\n sienna: '#a0522d',\n silver: '#c0c0c0',\n skyblue: '#87ceeb',\n slateblue: '#6a5acd',\n slategray: '#708090',\n slategrey: '#708090',\n snow: '#fffafa',\n springgreen: '#00ff7f',\n steelblue: '#4682b4',\n tan: '#d2b48c',\n teal: '#008080',\n thistle: '#d8bfd8',\n tomato: '#ff6347',\n turquoise: '#40e0d0',\n violet: '#ee82ee',\n wheat: '#f5deb3',\n white: '#ffffff',\n whitesmoke: '#f5f5f5',\n yellow: '#ffff00',\n yellowgreen: '#9acd32'\n };\n\n var w3cx11_1 = w3cx11;\n\n var type$b = utils.type;\n\n\n\n\n\n Color_1.prototype.name = function() {\n var hex = rgb2hex_1(this._rgb, 'rgb');\n for (var i = 0, list = Object.keys(w3cx11_1); i < list.length; i += 1) {\n var n = list[i];\n\n if (w3cx11_1[n] === hex) { return n.toLowerCase(); }\n }\n return hex;\n };\n\n input.format.named = function (name) {\n name = name.toLowerCase();\n if (w3cx11_1[name]) { return hex2rgb_1(w3cx11_1[name]); }\n throw new Error('unknown color name: '+name);\n };\n\n input.autodetect.push({\n p: 5,\n test: function (h) {\n var rest = [], len = arguments.length - 1;\n while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];\n\n if (!rest.length && type$b(h) === 'string' && w3cx11_1[h.toLowerCase()]) {\n return 'named';\n }\n }\n });\n\n var unpack$t = utils.unpack;\n\n var rgb2num = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$t(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n return (r << 16) + (g << 8) + b;\n };\n\n var rgb2num_1 = rgb2num;\n\n var type$c = utils.type;\n\n var num2rgb = function (num) {\n if (type$c(num) == \"number\" && num >= 0 && num <= 0xFFFFFF) {\n var r = num >> 16;\n var g = (num >> 8) & 0xFF;\n var b = num & 0xFF;\n return [r,g,b,1];\n }\n throw new Error(\"unknown num color: \"+num);\n };\n\n var num2rgb_1 = num2rgb;\n\n var type$d = utils.type;\n\n\n\n Color_1.prototype.num = function() {\n return rgb2num_1(this._rgb);\n };\n\n chroma_1.num = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['num']) ));\n };\n\n input.format.num = num2rgb_1;\n\n input.autodetect.push({\n p: 5,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n if (args.length === 1 && type$d(args[0]) === 'number' && args[0] >= 0 && args[0] <= 0xFFFFFF) {\n return 'num';\n }\n }\n });\n\n var unpack$u = utils.unpack;\n var type$e = utils.type;\n var round$5 = Math.round;\n\n Color_1.prototype.rgb = function(rnd) {\n if ( rnd === void 0 ) rnd=true;\n\n if (rnd === false) { return this._rgb.slice(0,3); }\n return this._rgb.slice(0,3).map(round$5);\n };\n\n Color_1.prototype.rgba = function(rnd) {\n if ( rnd === void 0 ) rnd=true;\n\n return this._rgb.slice(0,4).map(function (v,i) {\n return i<3 ? (rnd === false ? v : round$5(v)) : v;\n });\n };\n\n chroma_1.rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['rgb']) ));\n };\n\n input.format.rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var rgba = unpack$u(args, 'rgba');\n if (rgba[3] === undefined) { rgba[3] = 1; }\n return rgba;\n };\n\n input.autodetect.push({\n p: 3,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$u(args, 'rgba');\n if (type$e(args) === 'array' && (args.length === 3 ||\n args.length === 4 && type$e(args[3]) == 'number' && args[3] >= 0 && args[3] <= 1)) {\n return 'rgb';\n }\n }\n });\n\n /*\n * Based on implementation by Neil Bartlett\n * https://github.com/neilbartlett/color-temperature\n */\n\n var log = Math.log;\n\n var temperature2rgb = function (kelvin) {\n var temp = kelvin / 100;\n var r,g,b;\n if (temp < 66) {\n r = 255;\n g = -155.25485562709179 - 0.44596950469579133 * (g = temp-2) + 104.49216199393888 * log(g);\n b = temp < 20 ? 0 : -254.76935184120902 + 0.8274096064007395 * (b = temp-10) + 115.67994401066147 * log(b);\n } else {\n r = 351.97690566805693 + 0.114206453784165 * (r = temp-55) - 40.25366309332127 * log(r);\n g = 325.4494125711974 + 0.07943456536662342 * (g = temp-50) - 28.0852963507957 * log(g);\n b = 255;\n }\n return [r,g,b,1];\n };\n\n var temperature2rgb_1 = temperature2rgb;\n\n /*\n * Based on implementation by Neil Bartlett\n * https://github.com/neilbartlett/color-temperature\n **/\n\n\n var unpack$v = utils.unpack;\n var round$6 = Math.round;\n\n var rgb2temperature = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var rgb = unpack$v(args, 'rgb');\n var r = rgb[0], b = rgb[2];\n var minTemp = 1000;\n var maxTemp = 40000;\n var eps = 0.4;\n var temp;\n while (maxTemp - minTemp > eps) {\n temp = (maxTemp + minTemp) * 0.5;\n var rgb$1 = temperature2rgb_1(temp);\n if ((rgb$1[2] / rgb$1[0]) >= (b / r)) {\n maxTemp = temp;\n } else {\n minTemp = temp;\n }\n }\n return round$6(temp);\n };\n\n var rgb2temperature_1 = rgb2temperature;\n\n Color_1.prototype.temp =\n Color_1.prototype.kelvin =\n Color_1.prototype.temperature = function() {\n return rgb2temperature_1(this._rgb);\n };\n\n chroma_1.temp =\n chroma_1.kelvin =\n chroma_1.temperature = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['temp']) ));\n };\n\n input.format.temp =\n input.format.kelvin =\n input.format.temperature = temperature2rgb_1;\n\n var type$f = utils.type;\n\n Color_1.prototype.alpha = function(a, mutate) {\n if ( mutate === void 0 ) mutate=false;\n\n if (a !== undefined && type$f(a) === 'number') {\n if (mutate) {\n this._rgb[3] = a;\n return this;\n }\n return new Color_1([this._rgb[0], this._rgb[1], this._rgb[2], a], 'rgb');\n }\n return this._rgb[3];\n };\n\n Color_1.prototype.clipped = function() {\n return this._rgb._clipped || false;\n };\n\n Color_1.prototype.darken = function(amount) {\n \tif ( amount === void 0 ) amount=1;\n\n \tvar me = this;\n \tvar lab = me.lab();\n \tlab[0] -= labConstants.Kn * amount;\n \treturn new Color_1(lab, 'lab').alpha(me.alpha(), true);\n };\n\n Color_1.prototype.brighten = function(amount) {\n \tif ( amount === void 0 ) amount=1;\n\n \treturn this.darken(-amount);\n };\n\n Color_1.prototype.darker = Color_1.prototype.darken;\n Color_1.prototype.brighter = Color_1.prototype.brighten;\n\n Color_1.prototype.get = function(mc) {\n var ref = mc.split('.');\n var mode = ref[0];\n var channel = ref[1];\n var src = this[mode]();\n if (channel) {\n var i = mode.indexOf(channel);\n if (i > -1) { return src[i]; }\n throw new Error((\"unknown channel \" + channel + \" in mode \" + mode));\n } else {\n return src;\n }\n };\n\n var type$g = utils.type;\n var pow$2 = Math.pow;\n\n var EPS = 1e-7;\n var MAX_ITER = 20;\n\n Color_1.prototype.luminance = function(lum) {\n if (lum !== undefined && type$g(lum) === 'number') {\n if (lum === 0) {\n // return pure black\n return new Color_1([0,0,0,this._rgb[3]], 'rgb');\n }\n if (lum === 1) {\n // return pure white\n return new Color_1([255,255,255,this._rgb[3]], 'rgb');\n }\n // compute new color using...\n var cur_lum = this.luminance();\n var mode = 'rgb';\n var max_iter = MAX_ITER;\n\n var test = function (low, high) {\n var mid = low.interpolate(high, 0.5, mode);\n var lm = mid.luminance();\n if (Math.abs(lum - lm) < EPS || !max_iter--) {\n // close enough\n return mid;\n }\n return lm > lum ? test(low, mid) : test(mid, high);\n };\n\n var rgb = (cur_lum > lum ? test(new Color_1([0,0,0]), this) : test(this, new Color_1([255,255,255]))).rgb();\n return new Color_1(rgb.concat( [this._rgb[3]]));\n }\n return rgb2luminance.apply(void 0, (this._rgb).slice(0,3));\n };\n\n\n var rgb2luminance = function (r,g,b) {\n // relative luminance\n // see http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef\n r = luminance_x(r);\n g = luminance_x(g);\n b = luminance_x(b);\n return 0.2126 * r + 0.7152 * g + 0.0722 * b;\n };\n\n var luminance_x = function (x) {\n x /= 255;\n return x <= 0.03928 ? x/12.92 : pow$2((x+0.055)/1.055, 2.4);\n };\n\n var interpolator = {};\n\n var type$h = utils.type;\n\n\n var mix = function (col1, col2, f) {\n if ( f === void 0 ) f=0.5;\n var rest = [], len = arguments.length - 3;\n while ( len-- > 0 ) rest[ len ] = arguments[ len + 3 ];\n\n var mode = rest[0] || 'lrgb';\n if (!interpolator[mode] && !rest.length) {\n // fall back to the first supported mode\n mode = Object.keys(interpolator)[0];\n }\n if (!interpolator[mode]) {\n throw new Error((\"interpolation mode \" + mode + \" is not defined\"));\n }\n if (type$h(col1) !== 'object') { col1 = new Color_1(col1); }\n if (type$h(col2) !== 'object') { col2 = new Color_1(col2); }\n return interpolator[mode](col1, col2, f)\n .alpha(col1.alpha() + f * (col2.alpha() - col1.alpha()));\n };\n\n Color_1.prototype.mix =\n Color_1.prototype.interpolate = function(col2, f) {\n \tif ( f === void 0 ) f=0.5;\n \tvar rest = [], len = arguments.length - 2;\n \twhile ( len-- > 0 ) rest[ len ] = arguments[ len + 2 ];\n\n \treturn mix.apply(void 0, [ this, col2, f ].concat( rest ));\n };\n\n Color_1.prototype.premultiply = function(mutate) {\n \tif ( mutate === void 0 ) mutate=false;\n\n \tvar rgb = this._rgb;\n \tvar a = rgb[3];\n \tif (mutate) {\n \t\tthis._rgb = [rgb[0]*a, rgb[1]*a, rgb[2]*a, a];\n \t\treturn this;\n \t} else {\n \t\treturn new Color_1([rgb[0]*a, rgb[1]*a, rgb[2]*a, a], 'rgb');\n \t}\n };\n\n Color_1.prototype.saturate = function(amount) {\n \tif ( amount === void 0 ) amount=1;\n\n \tvar me = this;\n \tvar lch = me.lch();\n \tlch[1] += labConstants.Kn * amount;\n \tif (lch[1] < 0) { lch[1] = 0; }\n \treturn new Color_1(lch, 'lch').alpha(me.alpha(), true);\n };\n\n Color_1.prototype.desaturate = function(amount) {\n \tif ( amount === void 0 ) amount=1;\n\n \treturn this.saturate(-amount);\n };\n\n var type$i = utils.type;\n\n Color_1.prototype.set = function(mc, value, mutate) {\n if ( mutate === void 0 ) mutate=false;\n\n var ref = mc.split('.');\n var mode = ref[0];\n var channel = ref[1];\n var src = this[mode]();\n if (channel) {\n var i = mode.indexOf(channel);\n if (i > -1) {\n if (type$i(value) == 'string') {\n switch(value.charAt(0)) {\n case '+': src[i] += +value; break;\n case '-': src[i] += +value; break;\n case '*': src[i] *= +(value.substr(1)); break;\n case '/': src[i] /= +(value.substr(1)); break;\n default: src[i] = +value;\n }\n } else if (type$i(value) === 'number') {\n src[i] = value;\n } else {\n throw new Error(\"unsupported value for Color.set\");\n }\n var out = new Color_1(src, mode);\n if (mutate) {\n this._rgb = out._rgb;\n return this;\n }\n return out;\n }\n throw new Error((\"unknown channel \" + channel + \" in mode \" + mode));\n } else {\n return src;\n }\n };\n\n var rgb$1 = function (col1, col2, f) {\n var xyz0 = col1._rgb;\n var xyz1 = col2._rgb;\n return new Color_1(\n xyz0[0] + f * (xyz1[0]-xyz0[0]),\n xyz0[1] + f * (xyz1[1]-xyz0[1]),\n xyz0[2] + f * (xyz1[2]-xyz0[2]),\n 'rgb'\n )\n };\n\n // register interpolator\n interpolator.rgb = rgb$1;\n\n var sqrt$2 = Math.sqrt;\n var pow$3 = Math.pow;\n\n var lrgb = function (col1, col2, f) {\n var ref = col1._rgb;\n var x1 = ref[0];\n var y1 = ref[1];\n var z1 = ref[2];\n var ref$1 = col2._rgb;\n var x2 = ref$1[0];\n var y2 = ref$1[1];\n var z2 = ref$1[2];\n return new Color_1(\n sqrt$2(pow$3(x1,2) * (1-f) + pow$3(x2,2) * f),\n sqrt$2(pow$3(y1,2) * (1-f) + pow$3(y2,2) * f),\n sqrt$2(pow$3(z1,2) * (1-f) + pow$3(z2,2) * f),\n 'rgb'\n )\n };\n\n // register interpolator\n interpolator.lrgb = lrgb;\n\n var lab$1 = function (col1, col2, f) {\n var xyz0 = col1.lab();\n var xyz1 = col2.lab();\n return new Color_1(\n xyz0[0] + f * (xyz1[0]-xyz0[0]),\n xyz0[1] + f * (xyz1[1]-xyz0[1]),\n xyz0[2] + f * (xyz1[2]-xyz0[2]),\n 'lab'\n )\n };\n\n // register interpolator\n interpolator.lab = lab$1;\n\n var _hsx = function (col1, col2, f, m) {\n var assign, assign$1;\n\n var xyz0, xyz1;\n if (m === 'hsl') {\n xyz0 = col1.hsl();\n xyz1 = col2.hsl();\n } else if (m === 'hsv') {\n xyz0 = col1.hsv();\n xyz1 = col2.hsv();\n } else if (m === 'hcg') {\n xyz0 = col1.hcg();\n xyz1 = col2.hcg();\n } else if (m === 'hsi') {\n xyz0 = col1.hsi();\n xyz1 = col2.hsi();\n } else if (m === 'lch' || m === 'hcl') {\n m = 'hcl';\n xyz0 = col1.hcl();\n xyz1 = col2.hcl();\n }\n\n var hue0, hue1, sat0, sat1, lbv0, lbv1;\n if (m.substr(0, 1) === 'h') {\n (assign = xyz0, hue0 = assign[0], sat0 = assign[1], lbv0 = assign[2]);\n (assign$1 = xyz1, hue1 = assign$1[0], sat1 = assign$1[1], lbv1 = assign$1[2]);\n }\n\n var sat, hue, lbv, dh;\n\n if (!isNaN(hue0) && !isNaN(hue1)) {\n // both colors have hue\n if (hue1 > hue0 && hue1 - hue0 > 180) {\n dh = hue1-(hue0+360);\n } else if (hue1 < hue0 && hue0 - hue1 > 180) {\n dh = hue1+360-hue0;\n } else{\n dh = hue1 - hue0;\n }\n hue = hue0 + f * dh;\n } else if (!isNaN(hue0)) {\n hue = hue0;\n if ((lbv1 == 1 || lbv1 == 0) && m != 'hsv') { sat = sat0; }\n } else if (!isNaN(hue1)) {\n hue = hue1;\n if ((lbv0 == 1 || lbv0 == 0) && m != 'hsv') { sat = sat1; }\n } else {\n hue = Number.NaN;\n }\n\n if (sat === undefined) { sat = sat0 + f * (sat1 - sat0); }\n lbv = lbv0 + f * (lbv1-lbv0);\n return new Color_1([hue, sat, lbv], m);\n };\n\n var lch$1 = function (col1, col2, f) {\n \treturn _hsx(col1, col2, f, 'lch');\n };\n\n // register interpolator\n interpolator.lch = lch$1;\n interpolator.hcl = lch$1;\n\n var num$1 = function (col1, col2, f) {\n var c1 = col1.num();\n var c2 = col2.num();\n return new Color_1(c1 + f * (c2-c1), 'num')\n };\n\n // register interpolator\n interpolator.num = num$1;\n\n var hcg$1 = function (col1, col2, f) {\n \treturn _hsx(col1, col2, f, 'hcg');\n };\n\n // register interpolator\n interpolator.hcg = hcg$1;\n\n var hsi$1 = function (col1, col2, f) {\n \treturn _hsx(col1, col2, f, 'hsi');\n };\n\n // register interpolator\n interpolator.hsi = hsi$1;\n\n var hsl$1 = function (col1, col2, f) {\n \treturn _hsx(col1, col2, f, 'hsl');\n };\n\n // register interpolator\n interpolator.hsl = hsl$1;\n\n var hsv$1 = function (col1, col2, f) {\n \treturn _hsx(col1, col2, f, 'hsv');\n };\n\n // register interpolator\n interpolator.hsv = hsv$1;\n\n var clip_rgb$2 = utils.clip_rgb;\n var pow$4 = Math.pow;\n var sqrt$3 = Math.sqrt;\n var PI$1 = Math.PI;\n var cos$2 = Math.cos;\n var sin$1 = Math.sin;\n var atan2$1 = Math.atan2;\n\n var average = function (colors, mode, weights) {\n if ( mode === void 0 ) mode='lrgb';\n if ( weights === void 0 ) weights=null;\n\n var l = colors.length;\n if (!weights) { weights = Array.from(new Array(l)).map(function () { return 1; }); }\n // normalize weights\n var k = l / weights.reduce(function(a, b) { return a + b; });\n weights.forEach(function (w,i) { weights[i] *= k; });\n // convert colors to Color objects\n colors = colors.map(function (c) { return new Color_1(c); });\n if (mode === 'lrgb') {\n return _average_lrgb(colors, weights)\n }\n var first = colors.shift();\n var xyz = first.get(mode);\n var cnt = [];\n var dx = 0;\n var dy = 0;\n // initial color\n for (var i=0; i= 360) { A$1 -= 360; }\n xyz[i$1] = A$1;\n } else {\n xyz[i$1] = xyz[i$1]/cnt[i$1];\n }\n }\n alpha /= l;\n return (new Color_1(xyz, mode)).alpha(alpha > 0.99999 ? 1 : alpha, true);\n };\n\n\n var _average_lrgb = function (colors, weights) {\n var l = colors.length;\n var xyz = [0,0,0,0];\n for (var i=0; i < colors.length; i++) {\n var col = colors[i];\n var f = weights[i] / l;\n var rgb = col._rgb;\n xyz[0] += pow$4(rgb[0],2) * f;\n xyz[1] += pow$4(rgb[1],2) * f;\n xyz[2] += pow$4(rgb[2],2) * f;\n xyz[3] += rgb[3] * f;\n }\n xyz[0] = sqrt$3(xyz[0]);\n xyz[1] = sqrt$3(xyz[1]);\n xyz[2] = sqrt$3(xyz[2]);\n if (xyz[3] > 0.9999999) { xyz[3] = 1; }\n return new Color_1(clip_rgb$2(xyz));\n };\n\n // minimal multi-purpose interface\n\n // @requires utils color analyze\n\n\n var type$j = utils.type;\n\n var pow$5 = Math.pow;\n\n var scale = function(colors) {\n\n // constructor\n var _mode = 'rgb';\n var _nacol = chroma_1('#ccc');\n var _spread = 0;\n // const _fixed = false;\n var _domain = [0, 1];\n var _pos = [];\n var _padding = [0,0];\n var _classes = false;\n var _colors = [];\n var _out = false;\n var _min = 0;\n var _max = 1;\n var _correctLightness = false;\n var _colorCache = {};\n var _useCache = true;\n var _gamma = 1;\n\n // private methods\n\n var setColors = function(colors) {\n colors = colors || ['#fff', '#000'];\n if (colors && type$j(colors) === 'string' && chroma_1.brewer &&\n chroma_1.brewer[colors.toLowerCase()]) {\n colors = chroma_1.brewer[colors.toLowerCase()];\n }\n if (type$j(colors) === 'array') {\n // handle single color\n if (colors.length === 1) {\n colors = [colors[0], colors[0]];\n }\n // make a copy of the colors\n colors = colors.slice(0);\n // convert to chroma classes\n for (var c=0; c= _classes[i]) {\n i++;\n }\n return i-1;\n }\n return 0;\n };\n\n var tMapLightness = function (t) { return t; };\n var tMapDomain = function (t) { return t; };\n\n // const classifyValue = function(value) {\n // let val = value;\n // if (_classes.length > 2) {\n // const n = _classes.length-1;\n // const i = getClass(value);\n // const minc = _classes[0] + ((_classes[1]-_classes[0]) * (0 + (_spread * 0.5))); // center of 1st class\n // const maxc = _classes[n-1] + ((_classes[n]-_classes[n-1]) * (1 - (_spread * 0.5))); // center of last class\n // val = _min + ((((_classes[i] + ((_classes[i+1] - _classes[i]) * 0.5)) - minc) / (maxc-minc)) * (_max - _min));\n // }\n // return val;\n // };\n\n var getColor = function(val, bypassMap) {\n var col, t;\n if (bypassMap == null) { bypassMap = false; }\n if (isNaN(val) || (val === null)) { return _nacol; }\n if (!bypassMap) {\n if (_classes && (_classes.length > 2)) {\n // find the class\n var c = getClass(val);\n t = c / (_classes.length-2);\n } else if (_max !== _min) {\n // just interpolate between min/max\n t = (val - _min) / (_max - _min);\n } else {\n t = 1;\n }\n } else {\n t = val;\n }\n\n // domain map\n t = tMapDomain(t);\n\n if (!bypassMap) {\n t = tMapLightness(t); // lightness correction\n }\n\n if (_gamma !== 1) { t = pow$5(t, _gamma); }\n\n t = _padding[0] + (t * (1 - _padding[0] - _padding[1]));\n\n t = Math.min(1, Math.max(0, t));\n\n var k = Math.floor(t * 10000);\n\n if (_useCache && _colorCache[k]) {\n col = _colorCache[k];\n } else {\n if (type$j(_colors) === 'array') {\n //for i in [0.._pos.length-1]\n for (var i=0; i<_pos.length; i++) {\n var p = _pos[i];\n if (t <= p) {\n col = _colors[i];\n break;\n }\n if ((t >= p) && (i === (_pos.length-1))) {\n col = _colors[i];\n break;\n }\n if (t > p && t < _pos[i+1]) {\n t = (t-p)/(_pos[i+1]-p);\n col = chroma_1.interpolate(_colors[i], _colors[i+1], t, _mode);\n break;\n }\n }\n } else if (type$j(_colors) === 'function') {\n col = _colors(t);\n }\n if (_useCache) { _colorCache[k] = col; }\n }\n return col;\n };\n\n var resetCache = function () { return _colorCache = {}; };\n\n setColors(colors);\n\n // public interface\n\n var f = function(v) {\n var c = chroma_1(getColor(v));\n if (_out && c[_out]) { return c[_out](); } else { return c; }\n };\n\n f.classes = function(classes) {\n if (classes != null) {\n if (type$j(classes) === 'array') {\n _classes = classes;\n _domain = [classes[0], classes[classes.length-1]];\n } else {\n var d = chroma_1.analyze(_domain);\n if (classes === 0) {\n _classes = [d.min, d.max];\n } else {\n _classes = chroma_1.limits(d, 'e', classes);\n }\n }\n return f;\n }\n return _classes;\n };\n\n\n f.domain = function(domain) {\n if (!arguments.length) {\n return _domain;\n }\n _min = domain[0];\n _max = domain[domain.length-1];\n _pos = [];\n var k = _colors.length;\n if ((domain.length === k) && (_min !== _max)) {\n // update positions\n for (var i = 0, list = Array.from(domain); i < list.length; i += 1) {\n var d = list[i];\n\n _pos.push((d-_min) / (_max-_min));\n }\n } else {\n for (var c=0; c 2) {\n // set domain map\n var tOut = domain.map(function (d,i) { return i/(domain.length-1); });\n var tBreaks = domain.map(function (d) { return (d - _min) / (_max - _min); });\n if (!tBreaks.every(function (val, i) { return tOut[i] === val; })) {\n tMapDomain = function (t) {\n if (t <= 0 || t >= 1) { return t; }\n var i = 0;\n while (t >= tBreaks[i+1]) { i++; }\n var f = (t - tBreaks[i]) / (tBreaks[i+1] - tBreaks[i]);\n var out = tOut[i] + f * (tOut[i+1] - tOut[i]);\n return out;\n };\n }\n\n }\n }\n _domain = [_min, _max];\n return f;\n };\n\n f.mode = function(_m) {\n if (!arguments.length) {\n return _mode;\n }\n _mode = _m;\n resetCache();\n return f;\n };\n\n f.range = function(colors, _pos) {\n setColors(colors, _pos);\n return f;\n };\n\n f.out = function(_o) {\n _out = _o;\n return f;\n };\n\n f.spread = function(val) {\n if (!arguments.length) {\n return _spread;\n }\n _spread = val;\n return f;\n };\n\n f.correctLightness = function(v) {\n if (v == null) { v = true; }\n _correctLightness = v;\n resetCache();\n if (_correctLightness) {\n tMapLightness = function(t) {\n var L0 = getColor(0, true).lab()[0];\n var L1 = getColor(1, true).lab()[0];\n var pol = L0 > L1;\n var L_actual = getColor(t, true).lab()[0];\n var L_ideal = L0 + ((L1 - L0) * t);\n var L_diff = L_actual - L_ideal;\n var t0 = 0;\n var t1 = 1;\n var max_iter = 20;\n while ((Math.abs(L_diff) > 1e-2) && (max_iter-- > 0)) {\n (function() {\n if (pol) { L_diff *= -1; }\n if (L_diff < 0) {\n t0 = t;\n t += (t1 - t) * 0.5;\n } else {\n t1 = t;\n t += (t0 - t) * 0.5;\n }\n L_actual = getColor(t, true).lab()[0];\n return L_diff = L_actual - L_ideal;\n })();\n }\n return t;\n };\n } else {\n tMapLightness = function (t) { return t; };\n }\n return f;\n };\n\n f.padding = function(p) {\n if (p != null) {\n if (type$j(p) === 'number') {\n p = [p,p];\n }\n _padding = p;\n return f;\n } else {\n return _padding;\n }\n };\n\n f.colors = function(numColors, out) {\n // If no arguments are given, return the original colors that were provided\n if (arguments.length < 2) { out = 'hex'; }\n var result = [];\n\n if (arguments.length === 0) {\n result = _colors.slice(0);\n\n } else if (numColors === 1) {\n result = [f(0.5)];\n\n } else if (numColors > 1) {\n var dm = _domain[0];\n var dd = _domain[1] - dm;\n result = __range__(0, numColors, false).map(function (i) { return f( dm + ((i/(numColors-1)) * dd) ); });\n\n } else { // returns all colors based on the defined classes\n colors = [];\n var samples = [];\n if (_classes && (_classes.length > 2)) {\n for (var i = 1, end = _classes.length, asc = 1 <= end; asc ? i < end : i > end; asc ? i++ : i--) {\n samples.push((_classes[i-1]+_classes[i])*0.5);\n }\n } else {\n samples = _domain;\n }\n result = samples.map(function (v) { return f(v); });\n }\n\n if (chroma_1[out]) {\n result = result.map(function (c) { return c[out](); });\n }\n return result;\n };\n\n f.cache = function(c) {\n if (c != null) {\n _useCache = c;\n return f;\n } else {\n return _useCache;\n }\n };\n\n f.gamma = function(g) {\n if (g != null) {\n _gamma = g;\n return f;\n } else {\n return _gamma;\n }\n };\n\n f.nodata = function(d) {\n if (d != null) {\n _nacol = chroma_1(d);\n return f;\n } else {\n return _nacol;\n }\n };\n\n return f;\n };\n\n function __range__(left, right, inclusive) {\n var range = [];\n var ascending = left < right;\n var end = !inclusive ? right : ascending ? right + 1 : right - 1;\n for (var i = left; ascending ? i < end : i > end; ascending ? i++ : i--) {\n range.push(i);\n }\n return range;\n }\n\n //\n // interpolates between a set of colors uzing a bezier spline\n //\n\n // @requires utils lab\n\n\n\n\n var bezier = function(colors) {\n var assign, assign$1, assign$2;\n\n var I, lab0, lab1, lab2;\n colors = colors.map(function (c) { return new Color_1(c); });\n if (colors.length === 2) {\n // linear interpolation\n (assign = colors.map(function (c) { return c.lab(); }), lab0 = assign[0], lab1 = assign[1]);\n I = function(t) {\n var lab = ([0, 1, 2].map(function (i) { return lab0[i] + (t * (lab1[i] - lab0[i])); }));\n return new Color_1(lab, 'lab');\n };\n } else if (colors.length === 3) {\n // quadratic bezier interpolation\n (assign$1 = colors.map(function (c) { return c.lab(); }), lab0 = assign$1[0], lab1 = assign$1[1], lab2 = assign$1[2]);\n I = function(t) {\n var lab = ([0, 1, 2].map(function (i) { return ((1-t)*(1-t) * lab0[i]) + (2 * (1-t) * t * lab1[i]) + (t * t * lab2[i]); }));\n return new Color_1(lab, 'lab');\n };\n } else if (colors.length === 4) {\n // cubic bezier interpolation\n var lab3;\n (assign$2 = colors.map(function (c) { return c.lab(); }), lab0 = assign$2[0], lab1 = assign$2[1], lab2 = assign$2[2], lab3 = assign$2[3]);\n I = function(t) {\n var lab = ([0, 1, 2].map(function (i) { return ((1-t)*(1-t)*(1-t) * lab0[i]) + (3 * (1-t) * (1-t) * t * lab1[i]) + (3 * (1-t) * t * t * lab2[i]) + (t*t*t * lab3[i]); }));\n return new Color_1(lab, 'lab');\n };\n } else if (colors.length === 5) {\n var I0 = bezier(colors.slice(0, 3));\n var I1 = bezier(colors.slice(2, 5));\n I = function(t) {\n if (t < 0.5) {\n return I0(t*2);\n } else {\n return I1((t-0.5)*2);\n }\n };\n }\n return I;\n };\n\n var bezier_1 = function (colors) {\n var f = bezier(colors);\n f.scale = function () { return scale(f); };\n return f;\n };\n\n /*\n * interpolates between a set of colors uzing a bezier spline\n * blend mode formulas taken from http://www.venture-ware.com/kevin/coding/lets-learn-math-photoshop-blend-modes/\n */\n\n\n\n\n var blend = function (bottom, top, mode) {\n if (!blend[mode]) {\n throw new Error('unknown blend mode ' + mode);\n }\n return blend[mode](bottom, top);\n };\n\n var blend_f = function (f) { return function (bottom,top) {\n var c0 = chroma_1(top).rgb();\n var c1 = chroma_1(bottom).rgb();\n return chroma_1.rgb(f(c0, c1));\n }; };\n\n var each = function (f) { return function (c0, c1) {\n var out = [];\n out[0] = f(c0[0], c1[0]);\n out[1] = f(c0[1], c1[1]);\n out[2] = f(c0[2], c1[2]);\n return out;\n }; };\n\n var normal = function (a) { return a; };\n var multiply = function (a,b) { return a * b / 255; };\n var darken$1 = function (a,b) { return a > b ? b : a; };\n var lighten = function (a,b) { return a > b ? a : b; };\n var screen = function (a,b) { return 255 * (1 - (1-a/255) * (1-b/255)); };\n var overlay = function (a,b) { return b < 128 ? 2 * a * b / 255 : 255 * (1 - 2 * (1 - a / 255 ) * ( 1 - b / 255 )); };\n var burn = function (a,b) { return 255 * (1 - (1 - b / 255) / (a/255)); };\n var dodge = function (a,b) {\n if (a === 255) { return 255; }\n a = 255 * (b / 255) / (1 - a / 255);\n return a > 255 ? 255 : a\n };\n\n // # add = (a,b) ->\n // # if (a + b > 255) then 255 else a + b\n\n blend.normal = blend_f(each(normal));\n blend.multiply = blend_f(each(multiply));\n blend.screen = blend_f(each(screen));\n blend.overlay = blend_f(each(overlay));\n blend.darken = blend_f(each(darken$1));\n blend.lighten = blend_f(each(lighten));\n blend.dodge = blend_f(each(dodge));\n blend.burn = blend_f(each(burn));\n // blend.add = blend_f(each(add));\n\n var blend_1 = blend;\n\n // cubehelix interpolation\n // based on D.A. Green \"A colour scheme for the display of astronomical intensity images\"\n // http://astron-soc.in/bulletin/11June/289392011.pdf\n\n var type$k = utils.type;\n var clip_rgb$3 = utils.clip_rgb;\n var TWOPI$2 = utils.TWOPI;\n var pow$6 = Math.pow;\n var sin$2 = Math.sin;\n var cos$3 = Math.cos;\n\n\n var cubehelix = function(start, rotations, hue, gamma, lightness) {\n if ( start === void 0 ) start=300;\n if ( rotations === void 0 ) rotations=-1.5;\n if ( hue === void 0 ) hue=1;\n if ( gamma === void 0 ) gamma=1;\n if ( lightness === void 0 ) lightness=[0,1];\n\n var dh = 0, dl;\n if (type$k(lightness) === 'array') {\n dl = lightness[1] - lightness[0];\n } else {\n dl = 0;\n lightness = [lightness, lightness];\n }\n\n var f = function(fract) {\n var a = TWOPI$2 * (((start+120)/360) + (rotations * fract));\n var l = pow$6(lightness[0] + (dl * fract), gamma);\n var h = dh !== 0 ? hue[0] + (fract * dh) : hue;\n var amp = (h * l * (1-l)) / 2;\n var cos_a = cos$3(a);\n var sin_a = sin$2(a);\n var r = l + (amp * ((-0.14861 * cos_a) + (1.78277* sin_a)));\n var g = l + (amp * ((-0.29227 * cos_a) - (0.90649* sin_a)));\n var b = l + (amp * (+1.97294 * cos_a));\n return chroma_1(clip_rgb$3([r*255,g*255,b*255,1]));\n };\n\n f.start = function(s) {\n if ((s == null)) { return start; }\n start = s;\n return f;\n };\n\n f.rotations = function(r) {\n if ((r == null)) { return rotations; }\n rotations = r;\n return f;\n };\n\n f.gamma = function(g) {\n if ((g == null)) { return gamma; }\n gamma = g;\n return f;\n };\n\n f.hue = function(h) {\n if ((h == null)) { return hue; }\n hue = h;\n if (type$k(hue) === 'array') {\n dh = hue[1] - hue[0];\n if (dh === 0) { hue = hue[1]; }\n } else {\n dh = 0;\n }\n return f;\n };\n\n f.lightness = function(h) {\n if ((h == null)) { return lightness; }\n if (type$k(h) === 'array') {\n lightness = h;\n dl = h[1] - h[0];\n } else {\n lightness = [h,h];\n dl = 0;\n }\n return f;\n };\n\n f.scale = function () { return chroma_1.scale(f); };\n\n f.hue(hue);\n\n return f;\n };\n\n var digits = '0123456789abcdef';\n\n var floor$2 = Math.floor;\n var random = Math.random;\n\n var random_1 = function () {\n var code = '#';\n for (var i=0; i<6; i++) {\n code += digits.charAt(floor$2(random() * 16));\n }\n return new Color_1(code, 'hex');\n };\n\n var log$1 = Math.log;\n var pow$7 = Math.pow;\n var floor$3 = Math.floor;\n var abs = Math.abs;\n\n\n var analyze = function (data, key) {\n if ( key === void 0 ) key=null;\n\n var r = {\n min: Number.MAX_VALUE,\n max: Number.MAX_VALUE*-1,\n sum: 0,\n values: [],\n count: 0\n };\n if (type(data) === 'object') {\n data = Object.values(data);\n }\n data.forEach(function (val) {\n if (key && type(val) === 'object') { val = val[key]; }\n if (val !== undefined && val !== null && !isNaN(val)) {\n r.values.push(val);\n r.sum += val;\n if (val < r.min) { r.min = val; }\n if (val > r.max) { r.max = val; }\n r.count += 1;\n }\n });\n\n r.domain = [r.min, r.max];\n\n r.limits = function (mode, num) { return limits(r, mode, num); };\n\n return r;\n };\n\n\n var limits = function (data, mode, num) {\n if ( mode === void 0 ) mode='equal';\n if ( num === void 0 ) num=7;\n\n if (type(data) == 'array') {\n data = analyze(data);\n }\n var min = data.min;\n var max = data.max;\n var values = data.values.sort(function (a,b) { return a-b; });\n\n if (num === 1) { return [min,max]; }\n\n var limits = [];\n\n if (mode.substr(0,1) === 'c') { // continuous\n limits.push(min);\n limits.push(max);\n }\n\n if (mode.substr(0,1) === 'e') { // equal interval\n limits.push(min);\n for (var i=1; i 0');\n }\n var min_log = Math.LOG10E * log$1(min);\n var max_log = Math.LOG10E * log$1(max);\n limits.push(min);\n for (var i$1=1; i$1 pb\n var pr = p - pb;\n limits.push((values[pb]*(1-pr)) + (values[pb+1]*pr));\n }\n }\n limits.push(max);\n\n }\n\n else if (mode.substr(0,1) === 'k') { // k-means clustering\n /*\n implementation based on\n http://code.google.com/p/figue/source/browse/trunk/figue.js#336\n simplified for 1-d input values\n */\n var cluster;\n var n = values.length;\n var assignments = new Array(n);\n var clusterSizes = new Array(num);\n var repeat = true;\n var nb_iters = 0;\n var centroids = null;\n\n // get seed values\n centroids = [];\n centroids.push(min);\n for (var i$3=1; i$3 200) {\n repeat = false;\n }\n }\n\n // finished k-means clustering\n // the next part is borrowed from gabrielflor.it\n var kClusters = {};\n for (var j$5=0; j$5 l2 ? (l1 + 0.05) / (l2 + 0.05) : (l2 + 0.05) / (l1 + 0.05);\n };\n\n var sqrt$4 = Math.sqrt;\n var atan2$2 = Math.atan2;\n var abs$1 = Math.abs;\n var cos$4 = Math.cos;\n var PI$2 = Math.PI;\n\n var deltaE = function(a, b, L, C) {\n if ( L === void 0 ) L=1;\n if ( C === void 0 ) C=1;\n\n // Delta E (CMC)\n // see http://www.brucelindbloom.com/index.html?Eqn_DeltaE_CMC.html\n a = new Color_1(a);\n b = new Color_1(b);\n var ref = Array.from(a.lab());\n var L1 = ref[0];\n var a1 = ref[1];\n var b1 = ref[2];\n var ref$1 = Array.from(b.lab());\n var L2 = ref$1[0];\n var a2 = ref$1[1];\n var b2 = ref$1[2];\n var c1 = sqrt$4((a1 * a1) + (b1 * b1));\n var c2 = sqrt$4((a2 * a2) + (b2 * b2));\n var sl = L1 < 16.0 ? 0.511 : (0.040975 * L1) / (1.0 + (0.01765 * L1));\n var sc = ((0.0638 * c1) / (1.0 + (0.0131 * c1))) + 0.638;\n var h1 = c1 < 0.000001 ? 0.0 : (atan2$2(b1, a1) * 180.0) / PI$2;\n while (h1 < 0) { h1 += 360; }\n while (h1 >= 360) { h1 -= 360; }\n var t = (h1 >= 164.0) && (h1 <= 345.0) ? (0.56 + abs$1(0.2 * cos$4((PI$2 * (h1 + 168.0)) / 180.0))) : (0.36 + abs$1(0.4 * cos$4((PI$2 * (h1 + 35.0)) / 180.0)));\n var c4 = c1 * c1 * c1 * c1;\n var f = sqrt$4(c4 / (c4 + 1900.0));\n var sh = sc * (((f * t) + 1.0) - f);\n var delL = L1 - L2;\n var delC = c1 - c2;\n var delA = a1 - a2;\n var delB = b1 - b2;\n var dH2 = ((delA * delA) + (delB * delB)) - (delC * delC);\n var v1 = delL / (L * sl);\n var v2 = delC / (C * sc);\n var v3 = sh;\n return sqrt$4((v1 * v1) + (v2 * v2) + (dH2 / (v3 * v3)));\n };\n\n // simple Euclidean distance\n var distance = function(a, b, mode) {\n if ( mode === void 0 ) mode='lab';\n\n // Delta E (CIE 1976)\n // see http://www.brucelindbloom.com/index.html?Equations.html\n a = new Color_1(a);\n b = new Color_1(b);\n var l1 = a.get(mode);\n var l2 = b.get(mode);\n var sum_sq = 0;\n for (var i in l1) {\n var d = (l1[i] || 0) - (l2[i] || 0);\n sum_sq += d*d;\n }\n return Math.sqrt(sum_sq);\n };\n\n var valid = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n try {\n new (Function.prototype.bind.apply( Color_1, [ null ].concat( args) ));\n return true;\n } catch (e) {\n return false;\n }\n };\n\n // some pre-defined color scales:\n\n\n\n\n var scales = {\n \tcool: function cool() { return scale([chroma_1.hsl(180,1,.9), chroma_1.hsl(250,.7,.4)]) },\n \thot: function hot() { return scale(['#000','#f00','#ff0','#fff'], [0,.25,.75,1]).mode('rgb') }\n };\n\n /**\n ColorBrewer colors for chroma.js\n\n Copyright (c) 2002 Cynthia Brewer, Mark Harrower, and The\n Pennsylvania State University.\n\n Licensed under the Apache License, Version 2.0 (the \"License\");\n you may not use this file except in compliance with the License.\n You may obtain a copy of the License at\n http://www.apache.org/licenses/LICENSE-2.0\n\n Unless required by applicable law or agreed to in writing, software distributed\n under the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR\n CONDITIONS OF ANY KIND, either express or implied. See the License for the\n specific language governing permissions and limitations under the License.\n */\n\n var colorbrewer = {\n // sequential\n OrRd: ['#fff7ec', '#fee8c8', '#fdd49e', '#fdbb84', '#fc8d59', '#ef6548', '#d7301f', '#b30000', '#7f0000'],\n PuBu: ['#fff7fb', '#ece7f2', '#d0d1e6', '#a6bddb', '#74a9cf', '#3690c0', '#0570b0', '#045a8d', '#023858'],\n BuPu: ['#f7fcfd', '#e0ecf4', '#bfd3e6', '#9ebcda', '#8c96c6', '#8c6bb1', '#88419d', '#810f7c', '#4d004b'],\n Oranges: ['#fff5eb', '#fee6ce', '#fdd0a2', '#fdae6b', '#fd8d3c', '#f16913', '#d94801', '#a63603', '#7f2704'],\n BuGn: ['#f7fcfd', '#e5f5f9', '#ccece6', '#99d8c9', '#66c2a4', '#41ae76', '#238b45', '#006d2c', '#00441b'],\n YlOrBr: ['#ffffe5', '#fff7bc', '#fee391', '#fec44f', '#fe9929', '#ec7014', '#cc4c02', '#993404', '#662506'],\n YlGn: ['#ffffe5', '#f7fcb9', '#d9f0a3', '#addd8e', '#78c679', '#41ab5d', '#238443', '#006837', '#004529'],\n Reds: ['#fff5f0', '#fee0d2', '#fcbba1', '#fc9272', '#fb6a4a', '#ef3b2c', '#cb181d', '#a50f15', '#67000d'],\n RdPu: ['#fff7f3', '#fde0dd', '#fcc5c0', '#fa9fb5', '#f768a1', '#dd3497', '#ae017e', '#7a0177', '#49006a'],\n Greens: ['#f7fcf5', '#e5f5e0', '#c7e9c0', '#a1d99b', '#74c476', '#41ab5d', '#238b45', '#006d2c', '#00441b'],\n YlGnBu: ['#ffffd9', '#edf8b1', '#c7e9b4', '#7fcdbb', '#41b6c4', '#1d91c0', '#225ea8', '#253494', '#081d58'],\n Purples: ['#fcfbfd', '#efedf5', '#dadaeb', '#bcbddc', '#9e9ac8', '#807dba', '#6a51a3', '#54278f', '#3f007d'],\n GnBu: ['#f7fcf0', '#e0f3db', '#ccebc5', '#a8ddb5', '#7bccc4', '#4eb3d3', '#2b8cbe', '#0868ac', '#084081'],\n Greys: ['#ffffff', '#f0f0f0', '#d9d9d9', '#bdbdbd', '#969696', '#737373', '#525252', '#252525', '#000000'],\n YlOrRd: ['#ffffcc', '#ffeda0', '#fed976', '#feb24c', '#fd8d3c', '#fc4e2a', '#e31a1c', '#bd0026', '#800026'],\n PuRd: ['#f7f4f9', '#e7e1ef', '#d4b9da', '#c994c7', '#df65b0', '#e7298a', '#ce1256', '#980043', '#67001f'],\n Blues: ['#f7fbff', '#deebf7', '#c6dbef', '#9ecae1', '#6baed6', '#4292c6', '#2171b5', '#08519c', '#08306b'],\n PuBuGn: ['#fff7fb', '#ece2f0', '#d0d1e6', '#a6bddb', '#67a9cf', '#3690c0', '#02818a', '#016c59', '#014636'],\n Viridis: ['#440154', '#482777', '#3f4a8a', '#31678e', '#26838f', '#1f9d8a', '#6cce5a', '#b6de2b', '#fee825'],\n\n // diverging\n\n Spectral: ['#9e0142', '#d53e4f', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#e6f598', '#abdda4', '#66c2a5', '#3288bd', '#5e4fa2'],\n RdYlGn: ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#d9ef8b', '#a6d96a', '#66bd63', '#1a9850', '#006837'],\n RdBu: ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#f7f7f7', '#d1e5f0', '#92c5de', '#4393c3', '#2166ac', '#053061'],\n PiYG: ['#8e0152', '#c51b7d', '#de77ae', '#f1b6da', '#fde0ef', '#f7f7f7', '#e6f5d0', '#b8e186', '#7fbc41', '#4d9221', '#276419'],\n PRGn: ['#40004b', '#762a83', '#9970ab', '#c2a5cf', '#e7d4e8', '#f7f7f7', '#d9f0d3', '#a6dba0', '#5aae61', '#1b7837', '#00441b'],\n RdYlBu: ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee090', '#ffffbf', '#e0f3f8', '#abd9e9', '#74add1', '#4575b4', '#313695'],\n BrBG: ['#543005', '#8c510a', '#bf812d', '#dfc27d', '#f6e8c3', '#f5f5f5', '#c7eae5', '#80cdc1', '#35978f', '#01665e', '#003c30'],\n RdGy: ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#ffffff', '#e0e0e0', '#bababa', '#878787', '#4d4d4d', '#1a1a1a'],\n PuOr: ['#7f3b08', '#b35806', '#e08214', '#fdb863', '#fee0b6', '#f7f7f7', '#d8daeb', '#b2abd2', '#8073ac', '#542788', '#2d004b'],\n\n // qualitative\n\n Set2: ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3', '#a6d854', '#ffd92f', '#e5c494', '#b3b3b3'],\n Accent: ['#7fc97f', '#beaed4', '#fdc086', '#ffff99', '#386cb0', '#f0027f', '#bf5b17', '#666666'],\n Set1: ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00', '#ffff33', '#a65628', '#f781bf', '#999999'],\n Set3: ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5', '#d9d9d9', '#bc80bd', '#ccebc5', '#ffed6f'],\n Dark2: ['#1b9e77', '#d95f02', '#7570b3', '#e7298a', '#66a61e', '#e6ab02', '#a6761d', '#666666'],\n Paired: ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00', '#cab2d6', '#6a3d9a', '#ffff99', '#b15928'],\n Pastel2: ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4', '#e6f5c9', '#fff2ae', '#f1e2cc', '#cccccc'],\n Pastel1: ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6', '#ffffcc', '#e5d8bd', '#fddaec', '#f2f2f2'],\n };\n\n // add lowercase aliases for case-insensitive matches\n for (var i$1 = 0, list$1 = Object.keys(colorbrewer); i$1 < list$1.length; i$1 += 1) {\n var key = list$1[i$1];\n\n colorbrewer[key.toLowerCase()] = colorbrewer[key];\n }\n\n var colorbrewer_1 = colorbrewer;\n\n // feel free to comment out anything to rollup\n // a smaller chroma.js built\n\n // io --> convert colors\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n // operators --> modify existing Colors\n\n\n\n\n\n\n\n\n\n\n // interpolators\n\n\n\n\n\n\n\n\n\n\n // generators -- > create new colors\n chroma_1.average = average;\n chroma_1.bezier = bezier_1;\n chroma_1.blend = blend_1;\n chroma_1.cubehelix = cubehelix;\n chroma_1.mix = chroma_1.interpolate = mix;\n chroma_1.random = random_1;\n chroma_1.scale = scale;\n\n // other utility methods\n chroma_1.analyze = analyze_1.analyze;\n chroma_1.contrast = contrast;\n chroma_1.deltaE = deltaE;\n chroma_1.distance = distance;\n chroma_1.limits = analyze_1.limits;\n chroma_1.valid = valid;\n\n // scale\n chroma_1.scales = scales;\n\n // colors\n chroma_1.colors = w3cx11_1;\n chroma_1.brewer = colorbrewer_1;\n\n var chroma_js = chroma_1;\n\n return chroma_js;\n\n})));\n","import { Mesh } from \"../mesh\";\r\nimport { VertexData } from \"../mesh.vertexData\";\r\nVertexData.CreatePlane = function (options) {\r\n var indices = [];\r\n var positions = [];\r\n var normals = [];\r\n var uvs = [];\r\n var width = options.width || options.size || 1;\r\n var height = options.height || options.size || 1;\r\n var sideOrientation = (options.sideOrientation === 0) ? 0 : options.sideOrientation || VertexData.DEFAULTSIDE;\r\n // Vertices\r\n var halfWidth = width / 2.0;\r\n var halfHeight = height / 2.0;\r\n positions.push(-halfWidth, -halfHeight, 0);\r\n normals.push(0, 0, -1.0);\r\n uvs.push(0.0, 0.0);\r\n positions.push(halfWidth, -halfHeight, 0);\r\n normals.push(0, 0, -1.0);\r\n uvs.push(1.0, 0.0);\r\n positions.push(halfWidth, halfHeight, 0);\r\n normals.push(0, 0, -1.0);\r\n uvs.push(1.0, 1.0);\r\n positions.push(-halfWidth, halfHeight, 0);\r\n normals.push(0, 0, -1.0);\r\n uvs.push(0.0, 1.0);\r\n // Indices\r\n indices.push(0);\r\n indices.push(1);\r\n indices.push(2);\r\n indices.push(0);\r\n indices.push(2);\r\n indices.push(3);\r\n // Sides\r\n VertexData._ComputeSides(sideOrientation, positions, indices, normals, uvs, options.frontUVs, options.backUVs);\r\n // Result\r\n var vertexData = new VertexData();\r\n vertexData.indices = indices;\r\n vertexData.positions = positions;\r\n vertexData.normals = normals;\r\n vertexData.uvs = uvs;\r\n return vertexData;\r\n};\r\nMesh.CreatePlane = function (name, size, scene, updatable, sideOrientation) {\r\n var options = {\r\n size: size,\r\n width: size,\r\n height: size,\r\n sideOrientation: sideOrientation,\r\n updatable: updatable\r\n };\r\n return PlaneBuilder.CreatePlane(name, options, scene);\r\n};\r\n/**\r\n * Class containing static functions to help procedurally build meshes\r\n */\r\nvar PlaneBuilder = /** @class */ (function () {\r\n function PlaneBuilder() {\r\n }\r\n /**\r\n * Creates a plane mesh\r\n * * The parameter `size` sets the size (float) of both sides of the plane at once (default 1)\r\n * * You can set some different plane dimensions by using the parameters `width` and `height` (both by default have the same value of `size`)\r\n * * The parameter `sourcePlane` is a Plane instance. It builds a mesh plane from a Math plane\r\n * * You can also set the mesh side orientation with the values : BABYLON.Mesh.FRONTSIDE (default), BABYLON.Mesh.BACKSIDE or BABYLON.Mesh.DOUBLESIDE\r\n * * If you create a double-sided mesh, you can choose what parts of the texture image to crop and stick respectively on the front and the back sides with the parameters `frontUVs` and `backUVs` (Vector4). Detail here : https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @param name defines the name of the mesh\r\n * @param options defines the options used to create the mesh\r\n * @param scene defines the hosting scene\r\n * @returns the plane mesh\r\n * @see https://doc.babylonjs.com/how_to/set_shapes#plane\r\n */\r\n PlaneBuilder.CreatePlane = function (name, options, scene) {\r\n if (scene === void 0) { scene = null; }\r\n var plane = new Mesh(name, scene);\r\n options.sideOrientation = Mesh._GetDefaultSideOrientation(options.sideOrientation);\r\n plane._originalBuilderSideOrientation = options.sideOrientation;\r\n var vertexData = VertexData.CreatePlane(options);\r\n vertexData.applyToMesh(plane, options.updatable);\r\n if (options.sourcePlane) {\r\n plane.translate(options.sourcePlane.normal, -options.sourcePlane.d);\r\n plane.setDirection(options.sourcePlane.normal.scale(-1));\r\n }\r\n return plane;\r\n };\r\n return PlaneBuilder;\r\n}());\r\nexport { PlaneBuilder };\r\n//# sourceMappingURL=planeBuilder.js.map","import { ThinEngine } from \"../../Engines/thinEngine\";\r\nimport { InternalTexture, InternalTextureSource } from '../../Materials/Textures/internalTexture';\r\nThinEngine.prototype.createDynamicTexture = function (width, height, generateMipMaps, samplingMode) {\r\n var texture = new InternalTexture(this, InternalTextureSource.Dynamic);\r\n texture.baseWidth = width;\r\n texture.baseHeight = height;\r\n if (generateMipMaps) {\r\n width = this.needPOTTextures ? ThinEngine.GetExponentOfTwo(width, this._caps.maxTextureSize) : width;\r\n height = this.needPOTTextures ? ThinEngine.GetExponentOfTwo(height, this._caps.maxTextureSize) : height;\r\n }\r\n // this.resetTextureCache();\r\n texture.width = width;\r\n texture.height = height;\r\n texture.isReady = false;\r\n texture.generateMipMaps = generateMipMaps;\r\n texture.samplingMode = samplingMode;\r\n this.updateTextureSamplingMode(samplingMode, texture);\r\n this._internalTexturesCache.push(texture);\r\n return texture;\r\n};\r\nThinEngine.prototype.updateDynamicTexture = function (texture, source, invertY, premulAlpha, format, forceBindTexture) {\r\n if (premulAlpha === void 0) { premulAlpha = false; }\r\n if (forceBindTexture === void 0) { forceBindTexture = false; }\r\n if (!texture) {\r\n return;\r\n }\r\n var gl = this._gl;\r\n var target = gl.TEXTURE_2D;\r\n var wasPreviouslyBound = this._bindTextureDirectly(target, texture, true, forceBindTexture);\r\n this._unpackFlipY(invertY === undefined ? texture.invertY : invertY);\r\n if (premulAlpha) {\r\n gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, 1);\r\n }\r\n var textureType = this._getWebGLTextureType(texture.type);\r\n var glformat = this._getInternalFormat(format ? format : texture.format);\r\n var internalFormat = this._getRGBABufferInternalSizedFormat(texture.type, glformat);\r\n gl.texImage2D(target, 0, internalFormat, glformat, textureType, source);\r\n if (texture.generateMipMaps) {\r\n gl.generateMipmap(target);\r\n }\r\n if (!wasPreviouslyBound) {\r\n this._bindTextureDirectly(target, null);\r\n }\r\n if (premulAlpha) {\r\n gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, 0);\r\n }\r\n texture.isReady = true;\r\n};\r\n//# sourceMappingURL=engine.dynamicTexture.js.map","import { __extends } from \"tslib\";\r\nimport { Logger } from \"../../Misc/logger\";\r\nimport { Texture } from \"../../Materials/Textures/texture\";\r\nimport \"../../Engines/Extensions/engine.dynamicTexture\";\r\nimport { CanvasGenerator } from '../../Misc/canvasGenerator';\r\n/**\r\n * A class extending Texture allowing drawing on a texture\r\n * @see https://doc.babylonjs.com/how_to/dynamictexture\r\n */\r\nvar DynamicTexture = /** @class */ (function (_super) {\r\n __extends(DynamicTexture, _super);\r\n /**\r\n * Creates a DynamicTexture\r\n * @param name defines the name of the texture\r\n * @param options provides 3 alternatives for width and height of texture, a canvas, object with width and height properties, number for both width and height\r\n * @param scene defines the scene where you want the texture\r\n * @param generateMipMaps defines the use of MinMaps or not (default is false)\r\n * @param samplingMode defines the sampling mode to use (default is Texture.TRILINEAR_SAMPLINGMODE)\r\n * @param format defines the texture format to use (default is Engine.TEXTUREFORMAT_RGBA)\r\n * @param invertY defines if the texture needs to be inverted on the y axis during loading\r\n */\r\n function DynamicTexture(name, options, scene, generateMipMaps, samplingMode, format, invertY) {\r\n if (scene === void 0) { scene = null; }\r\n if (samplingMode === void 0) { samplingMode = 3; }\r\n if (format === void 0) { format = 5; }\r\n var _this = _super.call(this, null, scene, !generateMipMaps, invertY, samplingMode, undefined, undefined, undefined, undefined, format) || this;\r\n _this.name = name;\r\n _this.wrapU = Texture.CLAMP_ADDRESSMODE;\r\n _this.wrapV = Texture.CLAMP_ADDRESSMODE;\r\n _this._generateMipMaps = generateMipMaps;\r\n var engine = _this._getEngine();\r\n if (!engine) {\r\n return _this;\r\n }\r\n if (options.getContext) {\r\n _this._canvas = options;\r\n _this._texture = engine.createDynamicTexture(options.width, options.height, generateMipMaps, samplingMode);\r\n }\r\n else {\r\n _this._canvas = CanvasGenerator.CreateCanvas(1, 1);\r\n if (options.width || options.width === 0) {\r\n _this._texture = engine.createDynamicTexture(options.width, options.height, generateMipMaps, samplingMode);\r\n }\r\n else {\r\n _this._texture = engine.createDynamicTexture(options, options, generateMipMaps, samplingMode);\r\n }\r\n }\r\n var textureSize = _this.getSize();\r\n _this._canvas.width = textureSize.width;\r\n _this._canvas.height = textureSize.height;\r\n _this._context = _this._canvas.getContext(\"2d\");\r\n return _this;\r\n }\r\n /**\r\n * Get the current class name of the texture useful for serialization or dynamic coding.\r\n * @returns \"DynamicTexture\"\r\n */\r\n DynamicTexture.prototype.getClassName = function () {\r\n return \"DynamicTexture\";\r\n };\r\n Object.defineProperty(DynamicTexture.prototype, \"canRescale\", {\r\n /**\r\n * Gets the current state of canRescale\r\n */\r\n get: function () {\r\n return true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n DynamicTexture.prototype._recreate = function (textureSize) {\r\n this._canvas.width = textureSize.width;\r\n this._canvas.height = textureSize.height;\r\n this.releaseInternalTexture();\r\n this._texture = this._getEngine().createDynamicTexture(textureSize.width, textureSize.height, this._generateMipMaps, this.samplingMode);\r\n };\r\n /**\r\n * Scales the texture\r\n * @param ratio the scale factor to apply to both width and height\r\n */\r\n DynamicTexture.prototype.scale = function (ratio) {\r\n var textureSize = this.getSize();\r\n textureSize.width *= ratio;\r\n textureSize.height *= ratio;\r\n this._recreate(textureSize);\r\n };\r\n /**\r\n * Resizes the texture\r\n * @param width the new width\r\n * @param height the new height\r\n */\r\n DynamicTexture.prototype.scaleTo = function (width, height) {\r\n var textureSize = this.getSize();\r\n textureSize.width = width;\r\n textureSize.height = height;\r\n this._recreate(textureSize);\r\n };\r\n /**\r\n * Gets the context of the canvas used by the texture\r\n * @returns the canvas context of the dynamic texture\r\n */\r\n DynamicTexture.prototype.getContext = function () {\r\n return this._context;\r\n };\r\n /**\r\n * Clears the texture\r\n */\r\n DynamicTexture.prototype.clear = function () {\r\n var size = this.getSize();\r\n this._context.fillRect(0, 0, size.width, size.height);\r\n };\r\n /**\r\n * Updates the texture\r\n * @param invertY defines the direction for the Y axis (default is true - y increases downwards)\r\n * @param premulAlpha defines if alpha is stored as premultiplied (default is false)\r\n */\r\n DynamicTexture.prototype.update = function (invertY, premulAlpha) {\r\n if (premulAlpha === void 0) { premulAlpha = false; }\r\n this._getEngine().updateDynamicTexture(this._texture, this._canvas, invertY === undefined ? true : invertY, premulAlpha, this._format || undefined);\r\n };\r\n /**\r\n * Draws text onto the texture\r\n * @param text defines the text to be drawn\r\n * @param x defines the placement of the text from the left\r\n * @param y defines the placement of the text from the top when invertY is true and from the bottom when false\r\n * @param font defines the font to be used with font-style, font-size, font-name\r\n * @param color defines the color used for the text\r\n * @param clearColor defines the color for the canvas, use null to not overwrite canvas\r\n * @param invertY defines the direction for the Y axis (default is true - y increases downwards)\r\n * @param update defines whether texture is immediately update (default is true)\r\n */\r\n DynamicTexture.prototype.drawText = function (text, x, y, font, color, clearColor, invertY, update) {\r\n if (update === void 0) { update = true; }\r\n var size = this.getSize();\r\n if (clearColor) {\r\n this._context.fillStyle = clearColor;\r\n this._context.fillRect(0, 0, size.width, size.height);\r\n }\r\n this._context.font = font;\r\n if (x === null || x === undefined) {\r\n var textSize = this._context.measureText(text);\r\n x = (size.width - textSize.width) / 2;\r\n }\r\n if (y === null || y === undefined) {\r\n var fontSize = parseInt((font.replace(/\\D/g, '')));\r\n y = (size.height / 2) + (fontSize / 3.65);\r\n }\r\n this._context.fillStyle = color || \"\";\r\n this._context.fillText(text, x, y);\r\n if (update) {\r\n this.update(invertY);\r\n }\r\n };\r\n /**\r\n * Clones the texture\r\n * @returns the clone of the texture.\r\n */\r\n DynamicTexture.prototype.clone = function () {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return this;\r\n }\r\n var textureSize = this.getSize();\r\n var newTexture = new DynamicTexture(this.name, textureSize, scene, this._generateMipMaps);\r\n // Base texture\r\n newTexture.hasAlpha = this.hasAlpha;\r\n newTexture.level = this.level;\r\n // Dynamic Texture\r\n newTexture.wrapU = this.wrapU;\r\n newTexture.wrapV = this.wrapV;\r\n return newTexture;\r\n };\r\n /**\r\n * Serializes the dynamic texture. The scene should be ready before the dynamic texture is serialized\r\n * @returns a serialized dynamic texture object\r\n */\r\n DynamicTexture.prototype.serialize = function () {\r\n var scene = this.getScene();\r\n if (scene && !scene.isReady()) {\r\n Logger.Warn(\"The scene must be ready before serializing the dynamic texture\");\r\n }\r\n var serializationObject = _super.prototype.serialize.call(this);\r\n if (this._IsCanvasElement(this._canvas)) {\r\n serializationObject.base64String = this._canvas.toDataURL();\r\n }\r\n serializationObject.invertY = this._invertY;\r\n serializationObject.samplingMode = this.samplingMode;\r\n return serializationObject;\r\n };\r\n DynamicTexture.prototype._IsCanvasElement = function (canvas) {\r\n return canvas.toDataURL !== undefined;\r\n };\r\n /** @hidden */\r\n DynamicTexture.prototype._rebuild = function () {\r\n this.update();\r\n };\r\n return DynamicTexture;\r\n}(Texture));\r\nexport { DynamicTexture };\r\n//# sourceMappingURL=dynamicTexture.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'clipPlaneFragmentDeclaration';\r\nvar shader = \"#ifdef CLIPPLANE\\nvarying float fClipDistance;\\n#endif\\n#ifdef CLIPPLANE2\\nvarying float fClipDistance2;\\n#endif\\n#ifdef CLIPPLANE3\\nvarying float fClipDistance3;\\n#endif\\n#ifdef CLIPPLANE4\\nvarying float fClipDistance4;\\n#endif\\n#ifdef CLIPPLANE5\\nvarying float fClipDistance5;\\n#endif\\n#ifdef CLIPPLANE6\\nvarying float fClipDistance6;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var clipPlaneFragmentDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=clipPlaneFragmentDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'clipPlaneFragment';\r\nvar shader = \"#ifdef CLIPPLANE\\nif (fClipDistance>0.0)\\n{\\ndiscard;\\n}\\n#endif\\n#ifdef CLIPPLANE2\\nif (fClipDistance2>0.0)\\n{\\ndiscard;\\n}\\n#endif\\n#ifdef CLIPPLANE3\\nif (fClipDistance3>0.0)\\n{\\ndiscard;\\n}\\n#endif\\n#ifdef CLIPPLANE4\\nif (fClipDistance4>0.0)\\n{\\ndiscard;\\n}\\n#endif\\n#ifdef CLIPPLANE5\\nif (fClipDistance5>0.0)\\n{\\ndiscard;\\n}\\n#endif\\n#ifdef CLIPPLANE6\\nif (fClipDistance6>0.0)\\n{\\ndiscard;\\n}\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var clipPlaneFragment = { name: name, shader: shader };\r\n//# sourceMappingURL=clipPlaneFragment.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'bonesDeclaration';\r\nvar shader = \"#if NUM_BONE_INFLUENCERS>0\\n#ifdef BONETEXTURE\\nuniform sampler2D boneSampler;\\nuniform float boneTextureWidth;\\n#else\\nuniform mat4 mBones[BonesPerMesh];\\n#ifdef BONES_VELOCITY_ENABLED\\nuniform mat4 mPreviousBones[BonesPerMesh];\\n#endif\\n#endif\\nattribute vec4 matricesIndices;\\nattribute vec4 matricesWeights;\\n#if NUM_BONE_INFLUENCERS>4\\nattribute vec4 matricesIndicesExtra;\\nattribute vec4 matricesWeightsExtra;\\n#endif\\n#ifdef BONETEXTURE\\n#define inline\\nmat4 readMatrixFromRawSampler(sampler2D smp,float index)\\n{\\nfloat offset=index*4.0;\\nfloat dx=1.0/boneTextureWidth;\\nvec4 m0=texture2D(smp,vec2(dx*(offset+0.5),0.));\\nvec4 m1=texture2D(smp,vec2(dx*(offset+1.5),0.));\\nvec4 m2=texture2D(smp,vec2(dx*(offset+2.5),0.));\\nvec4 m3=texture2D(smp,vec2(dx*(offset+3.5),0.));\\nreturn mat4(m0,m1,m2,m3);\\n}\\n#endif\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var bonesDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=bonesDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'instancesDeclaration';\r\nvar shader = \"#ifdef INSTANCES\\nattribute vec4 world0;\\nattribute vec4 world1;\\nattribute vec4 world2;\\nattribute vec4 world3;\\n#ifdef THIN_INSTANCES\\nuniform mat4 world;\\n#endif\\n#else\\nuniform mat4 world;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var instancesDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=instancesDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'clipPlaneVertexDeclaration';\r\nvar shader = \"#ifdef CLIPPLANE\\nuniform vec4 vClipPlane;\\nvarying float fClipDistance;\\n#endif\\n#ifdef CLIPPLANE2\\nuniform vec4 vClipPlane2;\\nvarying float fClipDistance2;\\n#endif\\n#ifdef CLIPPLANE3\\nuniform vec4 vClipPlane3;\\nvarying float fClipDistance3;\\n#endif\\n#ifdef CLIPPLANE4\\nuniform vec4 vClipPlane4;\\nvarying float fClipDistance4;\\n#endif\\n#ifdef CLIPPLANE5\\nuniform vec4 vClipPlane5;\\nvarying float fClipDistance5;\\n#endif\\n#ifdef CLIPPLANE6\\nuniform vec4 vClipPlane6;\\nvarying float fClipDistance6;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var clipPlaneVertexDeclaration = { name: name, shader: shader };\r\n//# sourceMappingURL=clipPlaneVertexDeclaration.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'instancesVertex';\r\nvar shader = \"#ifdef INSTANCES\\nmat4 finalWorld=mat4(world0,world1,world2,world3);\\n#ifdef THIN_INSTANCES\\nfinalWorld=world*finalWorld;\\n#endif\\n#else\\nmat4 finalWorld=world;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var instancesVertex = { name: name, shader: shader };\r\n//# sourceMappingURL=instancesVertex.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'bonesVertex';\r\nvar shader = \"#if NUM_BONE_INFLUENCERS>0\\nmat4 influence;\\n#ifdef BONETEXTURE\\ninfluence=readMatrixFromRawSampler(boneSampler,matricesIndices[0])*matricesWeights[0];\\n#if NUM_BONE_INFLUENCERS>1\\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndices[1])*matricesWeights[1];\\n#endif\\n#if NUM_BONE_INFLUENCERS>2\\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndices[2])*matricesWeights[2];\\n#endif\\n#if NUM_BONE_INFLUENCERS>3\\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndices[3])*matricesWeights[3];\\n#endif\\n#if NUM_BONE_INFLUENCERS>4\\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndicesExtra[0])*matricesWeightsExtra[0];\\n#endif\\n#if NUM_BONE_INFLUENCERS>5\\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndicesExtra[1])*matricesWeightsExtra[1];\\n#endif\\n#if NUM_BONE_INFLUENCERS>6\\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndicesExtra[2])*matricesWeightsExtra[2];\\n#endif\\n#if NUM_BONE_INFLUENCERS>7\\ninfluence+=readMatrixFromRawSampler(boneSampler,matricesIndicesExtra[3])*matricesWeightsExtra[3];\\n#endif\\n#else\\ninfluence=mBones[int(matricesIndices[0])]*matricesWeights[0];\\n#if NUM_BONE_INFLUENCERS>1\\ninfluence+=mBones[int(matricesIndices[1])]*matricesWeights[1];\\n#endif\\n#if NUM_BONE_INFLUENCERS>2\\ninfluence+=mBones[int(matricesIndices[2])]*matricesWeights[2];\\n#endif\\n#if NUM_BONE_INFLUENCERS>3\\ninfluence+=mBones[int(matricesIndices[3])]*matricesWeights[3];\\n#endif\\n#if NUM_BONE_INFLUENCERS>4\\ninfluence+=mBones[int(matricesIndicesExtra[0])]*matricesWeightsExtra[0];\\n#endif\\n#if NUM_BONE_INFLUENCERS>5\\ninfluence+=mBones[int(matricesIndicesExtra[1])]*matricesWeightsExtra[1];\\n#endif\\n#if NUM_BONE_INFLUENCERS>6\\ninfluence+=mBones[int(matricesIndicesExtra[2])]*matricesWeightsExtra[2];\\n#endif\\n#if NUM_BONE_INFLUENCERS>7\\ninfluence+=mBones[int(matricesIndicesExtra[3])]*matricesWeightsExtra[3];\\n#endif\\n#endif\\nfinalWorld=finalWorld*influence;\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var bonesVertex = { name: name, shader: shader };\r\n//# sourceMappingURL=bonesVertex.js.map","import { Effect } from \"../../Materials/effect\";\r\nvar name = 'clipPlaneVertex';\r\nvar shader = \"#ifdef CLIPPLANE\\nfClipDistance=dot(worldPos,vClipPlane);\\n#endif\\n#ifdef CLIPPLANE2\\nfClipDistance2=dot(worldPos,vClipPlane2);\\n#endif\\n#ifdef CLIPPLANE3\\nfClipDistance3=dot(worldPos,vClipPlane3);\\n#endif\\n#ifdef CLIPPLANE4\\nfClipDistance4=dot(worldPos,vClipPlane4);\\n#endif\\n#ifdef CLIPPLANE5\\nfClipDistance5=dot(worldPos,vClipPlane5);\\n#endif\\n#ifdef CLIPPLANE6\\nfClipDistance6=dot(worldPos,vClipPlane6);\\n#endif\";\r\nEffect.IncludesShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var clipPlaneVertex = { name: name, shader: shader };\r\n//# sourceMappingURL=clipPlaneVertex.js.map","'use strict';\n\nmodule.exports = function bind(fn, thisArg) {\n return function wrap() {\n var args = new Array(arguments.length);\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i];\n }\n return fn.apply(thisArg, args);\n };\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nfunction encode(val) {\n return encodeURIComponent(val).\n replace(/%3A/gi, ':').\n replace(/%24/g, '$').\n replace(/%2C/gi, ',').\n replace(/%20/g, '+').\n replace(/%5B/gi, '[').\n replace(/%5D/gi, ']');\n}\n\n/**\n * Build a URL by appending params to the end\n *\n * @param {string} url The base of the url (e.g., http://www.google.com)\n * @param {object} [params] The params to be appended\n * @returns {string} The formatted url\n */\nmodule.exports = function buildURL(url, params, paramsSerializer) {\n /*eslint no-param-reassign:0*/\n if (!params) {\n return url;\n }\n\n var serializedParams;\n if (paramsSerializer) {\n serializedParams = paramsSerializer(params);\n } else if (utils.isURLSearchParams(params)) {\n serializedParams = params.toString();\n } else {\n var parts = [];\n\n utils.forEach(params, function serialize(val, key) {\n if (val === null || typeof val === 'undefined') {\n return;\n }\n\n if (utils.isArray(val)) {\n key = key + '[]';\n } else {\n val = [val];\n }\n\n utils.forEach(val, function parseValue(v) {\n if (utils.isDate(v)) {\n v = v.toISOString();\n } else if (utils.isObject(v)) {\n v = JSON.stringify(v);\n }\n parts.push(encode(key) + '=' + encode(v));\n });\n });\n\n serializedParams = parts.join('&');\n }\n\n if (serializedParams) {\n var hashmarkIndex = url.indexOf('#');\n if (hashmarkIndex !== -1) {\n url = url.slice(0, hashmarkIndex);\n }\n\n url += (url.indexOf('?') === -1 ? '?' : '&') + serializedParams;\n }\n\n return url;\n};\n","'use strict';\n\nmodule.exports = function isCancel(value) {\n return !!(value && value.__CANCEL__);\n};\n","'use strict';\n\nvar utils = require('./utils');\nvar normalizeHeaderName = require('./helpers/normalizeHeaderName');\n\nvar DEFAULT_CONTENT_TYPE = {\n 'Content-Type': 'application/x-www-form-urlencoded'\n};\n\nfunction setContentTypeIfUnset(headers, value) {\n if (!utils.isUndefined(headers) && utils.isUndefined(headers['Content-Type'])) {\n headers['Content-Type'] = value;\n }\n}\n\nfunction getDefaultAdapter() {\n var adapter;\n if (typeof XMLHttpRequest !== 'undefined') {\n // For browsers use XHR adapter\n adapter = require('./adapters/xhr');\n } else if (typeof process !== 'undefined' && Object.prototype.toString.call(process) === '[object process]') {\n // For node use HTTP adapter\n adapter = require('./adapters/http');\n }\n return adapter;\n}\n\nvar defaults = {\n adapter: getDefaultAdapter(),\n\n transformRequest: [function transformRequest(data, headers) {\n normalizeHeaderName(headers, 'Accept');\n normalizeHeaderName(headers, 'Content-Type');\n if (utils.isFormData(data) ||\n utils.isArrayBuffer(data) ||\n utils.isBuffer(data) ||\n utils.isStream(data) ||\n utils.isFile(data) ||\n utils.isBlob(data)\n ) {\n return data;\n }\n if (utils.isArrayBufferView(data)) {\n return data.buffer;\n }\n if (utils.isURLSearchParams(data)) {\n setContentTypeIfUnset(headers, 'application/x-www-form-urlencoded;charset=utf-8');\n return data.toString();\n }\n if (utils.isObject(data)) {\n setContentTypeIfUnset(headers, 'application/json;charset=utf-8');\n return JSON.stringify(data);\n }\n return data;\n }],\n\n transformResponse: [function transformResponse(data) {\n /*eslint no-param-reassign:0*/\n if (typeof data === 'string') {\n try {\n data = JSON.parse(data);\n } catch (e) { /* Ignore */ }\n }\n return data;\n }],\n\n /**\n * A timeout in milliseconds to abort a request. If set to 0 (default) a\n * timeout is not created.\n */\n timeout: 0,\n\n xsrfCookieName: 'XSRF-TOKEN',\n xsrfHeaderName: 'X-XSRF-TOKEN',\n\n maxContentLength: -1,\n maxBodyLength: -1,\n\n validateStatus: function validateStatus(status) {\n return status >= 200 && status < 300;\n }\n};\n\ndefaults.headers = {\n common: {\n 'Accept': 'application/json, text/plain, */*'\n }\n};\n\nutils.forEach(['delete', 'get', 'head'], function forEachMethodNoData(method) {\n defaults.headers[method] = {};\n});\n\nutils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n defaults.headers[method] = utils.merge(DEFAULT_CONTENT_TYPE);\n});\n\nmodule.exports = defaults;\n","'use strict';\n\nvar utils = require('./../utils');\nvar settle = require('./../core/settle');\nvar cookies = require('./../helpers/cookies');\nvar buildURL = require('./../helpers/buildURL');\nvar buildFullPath = require('../core/buildFullPath');\nvar parseHeaders = require('./../helpers/parseHeaders');\nvar isURLSameOrigin = require('./../helpers/isURLSameOrigin');\nvar createError = require('../core/createError');\n\nmodule.exports = function xhrAdapter(config) {\n return new Promise(function dispatchXhrRequest(resolve, reject) {\n var requestData = config.data;\n var requestHeaders = config.headers;\n\n if (utils.isFormData(requestData)) {\n delete requestHeaders['Content-Type']; // Let the browser set it\n }\n\n var request = new XMLHttpRequest();\n\n // HTTP basic authentication\n if (config.auth) {\n var username = config.auth.username || '';\n var password = config.auth.password ? unescape(encodeURIComponent(config.auth.password)) : '';\n requestHeaders.Authorization = 'Basic ' + btoa(username + ':' + password);\n }\n\n var fullPath = buildFullPath(config.baseURL, config.url);\n request.open(config.method.toUpperCase(), buildURL(fullPath, config.params, config.paramsSerializer), true);\n\n // Set the request timeout in MS\n request.timeout = config.timeout;\n\n // Listen for ready state\n request.onreadystatechange = function handleLoad() {\n if (!request || request.readyState !== 4) {\n return;\n }\n\n // The request errored out and we didn't get a response, this will be\n // handled by onerror instead\n // With one exception: request that using file: protocol, most browsers\n // will return status as 0 even though it's a successful request\n if (request.status === 0 && !(request.responseURL && request.responseURL.indexOf('file:') === 0)) {\n return;\n }\n\n // Prepare the response\n var responseHeaders = 'getAllResponseHeaders' in request ? parseHeaders(request.getAllResponseHeaders()) : null;\n var responseData = !config.responseType || config.responseType === 'text' ? request.responseText : request.response;\n var response = {\n data: responseData,\n status: request.status,\n statusText: request.statusText,\n headers: responseHeaders,\n config: config,\n request: request\n };\n\n settle(resolve, reject, response);\n\n // Clean up request\n request = null;\n };\n\n // Handle browser request cancellation (as opposed to a manual cancellation)\n request.onabort = function handleAbort() {\n if (!request) {\n return;\n }\n\n reject(createError('Request aborted', config, 'ECONNABORTED', request));\n\n // Clean up request\n request = null;\n };\n\n // Handle low level network errors\n request.onerror = function handleError() {\n // Real errors are hidden from us by the browser\n // onerror should only fire if it's a network error\n reject(createError('Network Error', config, null, request));\n\n // Clean up request\n request = null;\n };\n\n // Handle timeout\n request.ontimeout = function handleTimeout() {\n var timeoutErrorMessage = 'timeout of ' + config.timeout + 'ms exceeded';\n if (config.timeoutErrorMessage) {\n timeoutErrorMessage = config.timeoutErrorMessage;\n }\n reject(createError(timeoutErrorMessage, config, 'ECONNABORTED',\n request));\n\n // Clean up request\n request = null;\n };\n\n // Add xsrf header\n // This is only done if running in a standard browser environment.\n // Specifically not if we're in a web worker, or react-native.\n if (utils.isStandardBrowserEnv()) {\n // Add xsrf header\n var xsrfValue = (config.withCredentials || isURLSameOrigin(fullPath)) && config.xsrfCookieName ?\n cookies.read(config.xsrfCookieName) :\n undefined;\n\n if (xsrfValue) {\n requestHeaders[config.xsrfHeaderName] = xsrfValue;\n }\n }\n\n // Add headers to the request\n if ('setRequestHeader' in request) {\n utils.forEach(requestHeaders, function setRequestHeader(val, key) {\n if (typeof requestData === 'undefined' && key.toLowerCase() === 'content-type') {\n // Remove Content-Type if data is undefined\n delete requestHeaders[key];\n } else {\n // Otherwise add header to the request\n request.setRequestHeader(key, val);\n }\n });\n }\n\n // Add withCredentials to request if needed\n if (!utils.isUndefined(config.withCredentials)) {\n request.withCredentials = !!config.withCredentials;\n }\n\n // Add responseType to request if needed\n if (config.responseType) {\n try {\n request.responseType = config.responseType;\n } catch (e) {\n // Expected DOMException thrown by browsers not compatible XMLHttpRequest Level 2.\n // But, this can be suppressed for 'json' type as it can be parsed by default 'transformResponse' function.\n if (config.responseType !== 'json') {\n throw e;\n }\n }\n }\n\n // Handle progress if needed\n if (typeof config.onDownloadProgress === 'function') {\n request.addEventListener('progress', config.onDownloadProgress);\n }\n\n // Not all browsers support upload events\n if (typeof config.onUploadProgress === 'function' && request.upload) {\n request.upload.addEventListener('progress', config.onUploadProgress);\n }\n\n if (config.cancelToken) {\n // Handle cancellation\n config.cancelToken.promise.then(function onCanceled(cancel) {\n if (!request) {\n return;\n }\n\n request.abort();\n reject(cancel);\n // Clean up request\n request = null;\n });\n }\n\n if (!requestData) {\n requestData = null;\n }\n\n // Send the request\n request.send(requestData);\n });\n};\n","'use strict';\n\nvar enhanceError = require('./enhanceError');\n\n/**\n * Create an Error with the specified message, config, error code, request and response.\n *\n * @param {string} message The error message.\n * @param {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The created error.\n */\nmodule.exports = function createError(message, config, code, request, response) {\n var error = new Error(message);\n return enhanceError(error, config, code, request, response);\n};\n","'use strict';\n\nvar utils = require('../utils');\n\n/**\n * Config-specific merge-function which creates a new config-object\n * by merging two configuration objects together.\n *\n * @param {Object} config1\n * @param {Object} config2\n * @returns {Object} New object resulting from merging config2 to config1\n */\nmodule.exports = function mergeConfig(config1, config2) {\n // eslint-disable-next-line no-param-reassign\n config2 = config2 || {};\n var config = {};\n\n var valueFromConfig2Keys = ['url', 'method', 'data'];\n var mergeDeepPropertiesKeys = ['headers', 'auth', 'proxy', 'params'];\n var defaultToConfig2Keys = [\n 'baseURL', 'transformRequest', 'transformResponse', 'paramsSerializer',\n 'timeout', 'timeoutMessage', 'withCredentials', 'adapter', 'responseType', 'xsrfCookieName',\n 'xsrfHeaderName', 'onUploadProgress', 'onDownloadProgress', 'decompress',\n 'maxContentLength', 'maxBodyLength', 'maxRedirects', 'transport', 'httpAgent',\n 'httpsAgent', 'cancelToken', 'socketPath', 'responseEncoding'\n ];\n var directMergeKeys = ['validateStatus'];\n\n function getMergedValue(target, source) {\n if (utils.isPlainObject(target) && utils.isPlainObject(source)) {\n return utils.merge(target, source);\n } else if (utils.isPlainObject(source)) {\n return utils.merge({}, source);\n } else if (utils.isArray(source)) {\n return source.slice();\n }\n return source;\n }\n\n function mergeDeepProperties(prop) {\n if (!utils.isUndefined(config2[prop])) {\n config[prop] = getMergedValue(config1[prop], config2[prop]);\n } else if (!utils.isUndefined(config1[prop])) {\n config[prop] = getMergedValue(undefined, config1[prop]);\n }\n }\n\n utils.forEach(valueFromConfig2Keys, function valueFromConfig2(prop) {\n if (!utils.isUndefined(config2[prop])) {\n config[prop] = getMergedValue(undefined, config2[prop]);\n }\n });\n\n utils.forEach(mergeDeepPropertiesKeys, mergeDeepProperties);\n\n utils.forEach(defaultToConfig2Keys, function defaultToConfig2(prop) {\n if (!utils.isUndefined(config2[prop])) {\n config[prop] = getMergedValue(undefined, config2[prop]);\n } else if (!utils.isUndefined(config1[prop])) {\n config[prop] = getMergedValue(undefined, config1[prop]);\n }\n });\n\n utils.forEach(directMergeKeys, function merge(prop) {\n if (prop in config2) {\n config[prop] = getMergedValue(config1[prop], config2[prop]);\n } else if (prop in config1) {\n config[prop] = getMergedValue(undefined, config1[prop]);\n }\n });\n\n var axiosKeys = valueFromConfig2Keys\n .concat(mergeDeepPropertiesKeys)\n .concat(defaultToConfig2Keys)\n .concat(directMergeKeys);\n\n var otherKeys = Object\n .keys(config1)\n .concat(Object.keys(config2))\n .filter(function filterAxiosKeys(key) {\n return axiosKeys.indexOf(key) === -1;\n });\n\n utils.forEach(otherKeys, mergeDeepProperties);\n\n return config;\n};\n","'use strict';\n\n/**\n * A `Cancel` is an object that is thrown when an operation is canceled.\n *\n * @class\n * @param {string=} message The message.\n */\nfunction Cancel(message) {\n this.message = message;\n}\n\nCancel.prototype.toString = function toString() {\n return 'Cancel' + (this.message ? ': ' + this.message : '');\n};\n\nCancel.prototype.__CANCEL__ = true;\n\nmodule.exports = Cancel;\n","import { Vector4, Vector3, Vector2 } from \"../../Maths/math.vector\";\r\nimport { Color4 } from '../../Maths/math.color';\r\nimport { Mesh } from \"../mesh\";\r\nimport { VertexData } from \"../mesh.vertexData\";\r\nimport { Scene } from \"../../scene\";\r\nimport { Axis } from '../../Maths/math.axis';\r\nVertexData.CreateCylinder = function (options) {\r\n var height = options.height || 2;\r\n var diameterTop = (options.diameterTop === 0) ? 0 : options.diameterTop || options.diameter || 1;\r\n var diameterBottom = (options.diameterBottom === 0) ? 0 : options.diameterBottom || options.diameter || 1;\r\n diameterTop = diameterTop || 0.00001; // Prevent broken normals\r\n diameterBottom = diameterBottom || 0.00001; // Prevent broken normals\r\n var tessellation = options.tessellation || 24;\r\n var subdivisions = options.subdivisions || 1;\r\n var hasRings = options.hasRings ? true : false;\r\n var enclose = options.enclose ? true : false;\r\n var cap = (options.cap === 0) ? 0 : options.cap || Mesh.CAP_ALL;\r\n var arc = options.arc && (options.arc <= 0 || options.arc > 1) ? 1.0 : options.arc || 1.0;\r\n var sideOrientation = (options.sideOrientation === 0) ? 0 : options.sideOrientation || VertexData.DEFAULTSIDE;\r\n var faceUV = options.faceUV || new Array(3);\r\n var faceColors = options.faceColors;\r\n // default face colors and UV if undefined\r\n var quadNb = (arc !== 1 && enclose) ? 2 : 0;\r\n var ringNb = (hasRings) ? subdivisions : 1;\r\n var surfaceNb = 2 + (1 + quadNb) * ringNb;\r\n var f;\r\n for (f = 0; f < surfaceNb; f++) {\r\n if (faceColors && faceColors[f] === undefined) {\r\n faceColors[f] = new Color4(1, 1, 1, 1);\r\n }\r\n }\r\n for (f = 0; f < surfaceNb; f++) {\r\n if (faceUV && faceUV[f] === undefined) {\r\n faceUV[f] = new Vector4(0, 0, 1, 1);\r\n }\r\n }\r\n var indices = new Array();\r\n var positions = new Array();\r\n var normals = new Array();\r\n var uvs = new Array();\r\n var colors = new Array();\r\n var angle_step = Math.PI * 2 * arc / tessellation;\r\n var angle;\r\n var h;\r\n var radius;\r\n var tan = (diameterBottom - diameterTop) / 2 / height;\r\n var ringVertex = Vector3.Zero();\r\n var ringNormal = Vector3.Zero();\r\n var ringFirstVertex = Vector3.Zero();\r\n var ringFirstNormal = Vector3.Zero();\r\n var quadNormal = Vector3.Zero();\r\n var Y = Axis.Y;\r\n // positions, normals, uvs\r\n var i;\r\n var j;\r\n var r;\r\n var ringIdx = 1;\r\n var s = 1; // surface index\r\n var cs = 0;\r\n var v = 0;\r\n for (i = 0; i <= subdivisions; i++) {\r\n h = i / subdivisions;\r\n radius = (h * (diameterTop - diameterBottom) + diameterBottom) / 2;\r\n ringIdx = (hasRings && i !== 0 && i !== subdivisions) ? 2 : 1;\r\n for (r = 0; r < ringIdx; r++) {\r\n if (hasRings) {\r\n s += r;\r\n }\r\n if (enclose) {\r\n s += 2 * r;\r\n }\r\n for (j = 0; j <= tessellation; j++) {\r\n angle = j * angle_step;\r\n // position\r\n ringVertex.x = Math.cos(-angle) * radius;\r\n ringVertex.y = -height / 2 + h * height;\r\n ringVertex.z = Math.sin(-angle) * radius;\r\n // normal\r\n if (diameterTop === 0 && i === subdivisions) {\r\n // if no top cap, reuse former normals\r\n ringNormal.x = normals[normals.length - (tessellation + 1) * 3];\r\n ringNormal.y = normals[normals.length - (tessellation + 1) * 3 + 1];\r\n ringNormal.z = normals[normals.length - (tessellation + 1) * 3 + 2];\r\n }\r\n else {\r\n ringNormal.x = ringVertex.x;\r\n ringNormal.z = ringVertex.z;\r\n ringNormal.y = Math.sqrt(ringNormal.x * ringNormal.x + ringNormal.z * ringNormal.z) * tan;\r\n ringNormal.normalize();\r\n }\r\n // keep first ring vertex values for enclose\r\n if (j === 0) {\r\n ringFirstVertex.copyFrom(ringVertex);\r\n ringFirstNormal.copyFrom(ringNormal);\r\n }\r\n positions.push(ringVertex.x, ringVertex.y, ringVertex.z);\r\n normals.push(ringNormal.x, ringNormal.y, ringNormal.z);\r\n if (hasRings) {\r\n v = (cs !== s) ? faceUV[s].y : faceUV[s].w;\r\n }\r\n else {\r\n v = faceUV[s].y + (faceUV[s].w - faceUV[s].y) * h;\r\n }\r\n uvs.push(faceUV[s].x + (faceUV[s].z - faceUV[s].x) * j / tessellation, v);\r\n if (faceColors) {\r\n colors.push(faceColors[s].r, faceColors[s].g, faceColors[s].b, faceColors[s].a);\r\n }\r\n }\r\n // if enclose, add four vertices and their dedicated normals\r\n if (arc !== 1 && enclose) {\r\n positions.push(ringVertex.x, ringVertex.y, ringVertex.z);\r\n positions.push(0, ringVertex.y, 0);\r\n positions.push(0, ringVertex.y, 0);\r\n positions.push(ringFirstVertex.x, ringFirstVertex.y, ringFirstVertex.z);\r\n Vector3.CrossToRef(Y, ringNormal, quadNormal);\r\n quadNormal.normalize();\r\n normals.push(quadNormal.x, quadNormal.y, quadNormal.z, quadNormal.x, quadNormal.y, quadNormal.z);\r\n Vector3.CrossToRef(ringFirstNormal, Y, quadNormal);\r\n quadNormal.normalize();\r\n normals.push(quadNormal.x, quadNormal.y, quadNormal.z, quadNormal.x, quadNormal.y, quadNormal.z);\r\n if (hasRings) {\r\n v = (cs !== s) ? faceUV[s + 1].y : faceUV[s + 1].w;\r\n }\r\n else {\r\n v = faceUV[s + 1].y + (faceUV[s + 1].w - faceUV[s + 1].y) * h;\r\n }\r\n uvs.push(faceUV[s + 1].x, v);\r\n uvs.push(faceUV[s + 1].z, v);\r\n if (hasRings) {\r\n v = (cs !== s) ? faceUV[s + 2].y : faceUV[s + 2].w;\r\n }\r\n else {\r\n v = faceUV[s + 2].y + (faceUV[s + 2].w - faceUV[s + 2].y) * h;\r\n }\r\n uvs.push(faceUV[s + 2].x, v);\r\n uvs.push(faceUV[s + 2].z, v);\r\n if (faceColors) {\r\n colors.push(faceColors[s + 1].r, faceColors[s + 1].g, faceColors[s + 1].b, faceColors[s + 1].a);\r\n colors.push(faceColors[s + 1].r, faceColors[s + 1].g, faceColors[s + 1].b, faceColors[s + 1].a);\r\n colors.push(faceColors[s + 2].r, faceColors[s + 2].g, faceColors[s + 2].b, faceColors[s + 2].a);\r\n colors.push(faceColors[s + 2].r, faceColors[s + 2].g, faceColors[s + 2].b, faceColors[s + 2].a);\r\n }\r\n }\r\n if (cs !== s) {\r\n cs = s;\r\n }\r\n }\r\n }\r\n // indices\r\n var e = (arc !== 1 && enclose) ? tessellation + 4 : tessellation; // correction of number of iteration if enclose\r\n var s;\r\n i = 0;\r\n for (s = 0; s < subdivisions; s++) {\r\n var i0 = 0;\r\n var i1 = 0;\r\n var i2 = 0;\r\n var i3 = 0;\r\n for (j = 0; j < tessellation; j++) {\r\n i0 = i * (e + 1) + j;\r\n i1 = (i + 1) * (e + 1) + j;\r\n i2 = i * (e + 1) + (j + 1);\r\n i3 = (i + 1) * (e + 1) + (j + 1);\r\n indices.push(i0, i1, i2);\r\n indices.push(i3, i2, i1);\r\n }\r\n if (arc !== 1 && enclose) { // if enclose, add two quads\r\n indices.push(i0 + 2, i1 + 2, i2 + 2);\r\n indices.push(i3 + 2, i2 + 2, i1 + 2);\r\n indices.push(i0 + 4, i1 + 4, i2 + 4);\r\n indices.push(i3 + 4, i2 + 4, i1 + 4);\r\n }\r\n i = (hasRings) ? (i + 2) : (i + 1);\r\n }\r\n // Caps\r\n var createCylinderCap = function (isTop) {\r\n var radius = isTop ? diameterTop / 2 : diameterBottom / 2;\r\n if (radius === 0) {\r\n return;\r\n }\r\n // Cap positions, normals & uvs\r\n var angle;\r\n var circleVector;\r\n var i;\r\n var u = (isTop) ? faceUV[surfaceNb - 1] : faceUV[0];\r\n var c = null;\r\n if (faceColors) {\r\n c = (isTop) ? faceColors[surfaceNb - 1] : faceColors[0];\r\n }\r\n // cap center\r\n var vbase = positions.length / 3;\r\n var offset = isTop ? height / 2 : -height / 2;\r\n var center = new Vector3(0, offset, 0);\r\n positions.push(center.x, center.y, center.z);\r\n normals.push(0, isTop ? 1 : -1, 0);\r\n uvs.push(u.x + (u.z - u.x) * 0.5, u.y + (u.w - u.y) * 0.5);\r\n if (c) {\r\n colors.push(c.r, c.g, c.b, c.a);\r\n }\r\n var textureScale = new Vector2(0.5, 0.5);\r\n for (i = 0; i <= tessellation; i++) {\r\n angle = Math.PI * 2 * i * arc / tessellation;\r\n var cos = Math.cos(-angle);\r\n var sin = Math.sin(-angle);\r\n circleVector = new Vector3(cos * radius, offset, sin * radius);\r\n var textureCoordinate = new Vector2(cos * textureScale.x + 0.5, sin * textureScale.y + 0.5);\r\n positions.push(circleVector.x, circleVector.y, circleVector.z);\r\n normals.push(0, isTop ? 1 : -1, 0);\r\n uvs.push(u.x + (u.z - u.x) * textureCoordinate.x, u.y + (u.w - u.y) * textureCoordinate.y);\r\n if (c) {\r\n colors.push(c.r, c.g, c.b, c.a);\r\n }\r\n }\r\n // Cap indices\r\n for (i = 0; i < tessellation; i++) {\r\n if (!isTop) {\r\n indices.push(vbase);\r\n indices.push(vbase + (i + 1));\r\n indices.push(vbase + (i + 2));\r\n }\r\n else {\r\n indices.push(vbase);\r\n indices.push(vbase + (i + 2));\r\n indices.push(vbase + (i + 1));\r\n }\r\n }\r\n };\r\n // add caps to geometry based on cap parameter\r\n if ((cap === Mesh.CAP_START)\r\n || (cap === Mesh.CAP_ALL)) {\r\n createCylinderCap(false);\r\n }\r\n if ((cap === Mesh.CAP_END)\r\n || (cap === Mesh.CAP_ALL)) {\r\n createCylinderCap(true);\r\n }\r\n // Sides\r\n VertexData._ComputeSides(sideOrientation, positions, indices, normals, uvs, options.frontUVs, options.backUVs);\r\n var vertexData = new VertexData();\r\n vertexData.indices = indices;\r\n vertexData.positions = positions;\r\n vertexData.normals = normals;\r\n vertexData.uvs = uvs;\r\n if (faceColors) {\r\n vertexData.colors = colors;\r\n }\r\n return vertexData;\r\n};\r\nMesh.CreateCylinder = function (name, height, diameterTop, diameterBottom, tessellation, subdivisions, scene, updatable, sideOrientation) {\r\n if (scene === undefined || !(scene instanceof Scene)) {\r\n if (scene !== undefined) {\r\n sideOrientation = updatable || Mesh.DEFAULTSIDE;\r\n updatable = scene;\r\n }\r\n scene = subdivisions;\r\n subdivisions = 1;\r\n }\r\n var options = {\r\n height: height,\r\n diameterTop: diameterTop,\r\n diameterBottom: diameterBottom,\r\n tessellation: tessellation,\r\n subdivisions: subdivisions,\r\n sideOrientation: sideOrientation,\r\n updatable: updatable\r\n };\r\n return CylinderBuilder.CreateCylinder(name, options, scene);\r\n};\r\n/**\r\n * Class containing static functions to help procedurally build meshes\r\n */\r\nvar CylinderBuilder = /** @class */ (function () {\r\n function CylinderBuilder() {\r\n }\r\n /**\r\n * Creates a cylinder or a cone mesh\r\n * * The parameter `height` sets the height size (float) of the cylinder/cone (float, default 2).\r\n * * The parameter `diameter` sets the diameter of the top and bottom cap at once (float, default 1).\r\n * * The parameters `diameterTop` and `diameterBottom` overwrite the parameter `diameter` and set respectively the top cap and bottom cap diameter (floats, default 1). The parameter \"diameterBottom\" can't be zero.\r\n * * The parameter `tessellation` sets the number of cylinder sides (positive integer, default 24). Set it to 3 to get a prism for instance.\r\n * * The parameter `subdivisions` sets the number of rings along the cylinder height (positive integer, default 1).\r\n * * The parameter `hasRings` (boolean, default false) makes the subdivisions independent from each other, so they become different faces.\r\n * * The parameter `enclose` (boolean, default false) adds two extra faces per subdivision to a sliced cylinder to close it around its height axis.\r\n * * The parameter `cap` sets the way the cylinder is capped. Possible values : BABYLON.Mesh.NO_CAP, BABYLON.Mesh.CAP_START, BABYLON.Mesh.CAP_END, BABYLON.Mesh.CAP_ALL (default).\r\n * * The parameter `arc` (float, default 1) is the ratio (max 1) to apply to the circumference to slice the cylinder.\r\n * * You can set different colors and different images to each box side by using the parameters `faceColors` (an array of n Color3 elements) and `faceUV` (an array of n Vector4 elements).\r\n * * The value of n is the number of cylinder faces. If the cylinder has only 1 subdivisions, n equals : top face + cylinder surface + bottom face = 3\r\n * * Now, if the cylinder has 5 independent subdivisions (hasRings = true), n equals : top face + 5 stripe surfaces + bottom face = 2 + 5 = 7\r\n * * Finally, if the cylinder has 5 independent subdivisions and is enclose, n equals : top face + 5 x (stripe surface + 2 closing faces) + bottom face = 2 + 5 * 3 = 17\r\n * * Each array (color or UVs) is always ordered the same way : the first element is the bottom cap, the last element is the top cap. The other elements are each a ring surface.\r\n * * If `enclose` is false, a ring surface is one element.\r\n * * If `enclose` is true, a ring surface is 3 successive elements in the array : the tubular surface, then the two closing faces.\r\n * * Example how to set colors and textures on a sliced cylinder : https://www.html5gamedevs.com/topic/17945-creating-a-closed-slice-of-a-cylinder/#comment-106379\r\n * * You can also set the mesh side orientation with the values : BABYLON.Mesh.FRONTSIDE (default), BABYLON.Mesh.BACKSIDE or BABYLON.Mesh.DOUBLESIDE\r\n * * If you create a double-sided mesh, you can choose what parts of the texture image to crop and stick respectively on the front and the back sides with the parameters `frontUVs` and `backUVs` (Vector4). Detail here : https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created.\r\n * @param name defines the name of the mesh\r\n * @param options defines the options used to create the mesh\r\n * @param scene defines the hosting scene\r\n * @returns the cylinder mesh\r\n * @see https://doc.babylonjs.com/how_to/set_shapes#cylinder-or-cone\r\n */\r\n CylinderBuilder.CreateCylinder = function (name, options, scene) {\r\n var cylinder = new Mesh(name, scene);\r\n options.sideOrientation = Mesh._GetDefaultSideOrientation(options.sideOrientation);\r\n cylinder._originalBuilderSideOrientation = options.sideOrientation;\r\n var vertexData = VertexData.CreateCylinder(options);\r\n vertexData.applyToMesh(cylinder, options.updatable);\r\n return cylinder;\r\n };\r\n return CylinderBuilder;\r\n}());\r\nexport { CylinderBuilder };\r\n//# sourceMappingURL=cylinderBuilder.js.map","import { __extends } from \"tslib\";\r\nimport { Container } from \"./container\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/** Class used to create rectangle container */\r\nvar Rectangle = /** @class */ (function (_super) {\r\n __extends(Rectangle, _super);\r\n /**\r\n * Creates a new Rectangle\r\n * @param name defines the control name\r\n */\r\n function Rectangle(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._thickness = 1;\r\n _this._cornerRadius = 0;\r\n return _this;\r\n }\r\n Object.defineProperty(Rectangle.prototype, \"thickness\", {\r\n /** Gets or sets border thickness */\r\n get: function () {\r\n return this._thickness;\r\n },\r\n set: function (value) {\r\n if (this._thickness === value) {\r\n return;\r\n }\r\n this._thickness = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Rectangle.prototype, \"cornerRadius\", {\r\n /** Gets or sets the corner radius angle */\r\n get: function () {\r\n return this._cornerRadius;\r\n },\r\n set: function (value) {\r\n if (value < 0) {\r\n value = 0;\r\n }\r\n if (this._cornerRadius === value) {\r\n return;\r\n }\r\n this._cornerRadius = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Rectangle.prototype._getTypeName = function () {\r\n return \"Rectangle\";\r\n };\r\n Rectangle.prototype._localDraw = function (context) {\r\n context.save();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n if (this._background) {\r\n context.fillStyle = this._background;\r\n if (this._cornerRadius) {\r\n this._drawRoundedRect(context, this._thickness / 2);\r\n context.fill();\r\n }\r\n else {\r\n context.fillRect(this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n }\r\n }\r\n if (this._thickness) {\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n if (this.color) {\r\n context.strokeStyle = this.color;\r\n }\r\n context.lineWidth = this._thickness;\r\n if (this._cornerRadius) {\r\n this._drawRoundedRect(context, this._thickness / 2);\r\n context.stroke();\r\n }\r\n else {\r\n context.strokeRect(this._currentMeasure.left + this._thickness / 2, this._currentMeasure.top + this._thickness / 2, this._currentMeasure.width - this._thickness, this._currentMeasure.height - this._thickness);\r\n }\r\n }\r\n context.restore();\r\n };\r\n Rectangle.prototype._additionalProcessing = function (parentMeasure, context) {\r\n _super.prototype._additionalProcessing.call(this, parentMeasure, context);\r\n this._measureForChildren.width -= 2 * this._thickness;\r\n this._measureForChildren.height -= 2 * this._thickness;\r\n this._measureForChildren.left += this._thickness;\r\n this._measureForChildren.top += this._thickness;\r\n };\r\n Rectangle.prototype._drawRoundedRect = function (context, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n var x = this._currentMeasure.left + offset;\r\n var y = this._currentMeasure.top + offset;\r\n var width = this._currentMeasure.width - offset * 2;\r\n var height = this._currentMeasure.height - offset * 2;\r\n var radius = Math.min(height / 2 - 2, Math.min(width / 2 - 2, this._cornerRadius));\r\n context.beginPath();\r\n context.moveTo(x + radius, y);\r\n context.lineTo(x + width - radius, y);\r\n context.quadraticCurveTo(x + width, y, x + width, y + radius);\r\n context.lineTo(x + width, y + height - radius);\r\n context.quadraticCurveTo(x + width, y + height, x + width - radius, y + height);\r\n context.lineTo(x + radius, y + height);\r\n context.quadraticCurveTo(x, y + height, x, y + height - radius);\r\n context.lineTo(x, y + radius);\r\n context.quadraticCurveTo(x, y, x + radius, y);\r\n context.closePath();\r\n };\r\n Rectangle.prototype._clipForChildren = function (context) {\r\n if (this._cornerRadius) {\r\n this._drawRoundedRect(context, this._thickness);\r\n context.clip();\r\n }\r\n };\r\n return Rectangle;\r\n}(Container));\r\nexport { Rectangle };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Rectangle\"] = Rectangle;\r\n//# sourceMappingURL=rectangle.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { ValueAndUnit } from \"../valueAndUnit\";\r\nimport { Control } from \"./control\";\r\nimport { _TypeStore } from \"@babylonjs/core/Misc/typeStore\";\r\n/**\r\n * Enum that determines the text-wrapping mode to use.\r\n */\r\nexport var TextWrapping;\r\n(function (TextWrapping) {\r\n /**\r\n * Clip the text when it's larger than Control.width; this is the default mode.\r\n */\r\n TextWrapping[TextWrapping[\"Clip\"] = 0] = \"Clip\";\r\n /**\r\n * Wrap the text word-wise, i.e. try to add line-breaks at word boundary to fit within Control.width.\r\n */\r\n TextWrapping[TextWrapping[\"WordWrap\"] = 1] = \"WordWrap\";\r\n /**\r\n * Ellipsize the text, i.e. shrink with trailing … when text is larger than Control.width.\r\n */\r\n TextWrapping[TextWrapping[\"Ellipsis\"] = 2] = \"Ellipsis\";\r\n})(TextWrapping || (TextWrapping = {}));\r\n/**\r\n * Class used to create text block control\r\n */\r\nvar TextBlock = /** @class */ (function (_super) {\r\n __extends(TextBlock, _super);\r\n /**\r\n * Creates a new TextBlock object\r\n * @param name defines the name of the control\r\n * @param text defines the text to display (emptry string by default)\r\n */\r\n function TextBlock(\r\n /**\r\n * Defines the name of the control\r\n */\r\n name, text) {\r\n if (text === void 0) { text = \"\"; }\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._text = \"\";\r\n _this._textWrapping = TextWrapping.Clip;\r\n _this._textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_CENTER;\r\n _this._textVerticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n _this._resizeToFit = false;\r\n _this._lineSpacing = new ValueAndUnit(0);\r\n _this._outlineWidth = 0;\r\n _this._outlineColor = \"white\";\r\n _this._underline = false;\r\n _this._lineThrough = false;\r\n /**\r\n * An event triggered after the text is changed\r\n */\r\n _this.onTextChangedObservable = new Observable();\r\n /**\r\n * An event triggered after the text was broken up into lines\r\n */\r\n _this.onLinesReadyObservable = new Observable();\r\n _this.text = text;\r\n return _this;\r\n }\r\n Object.defineProperty(TextBlock.prototype, \"lines\", {\r\n /**\r\n * Return the line list (you may need to use the onLinesReadyObservable to make sure the list is ready)\r\n */\r\n get: function () {\r\n return this._lines;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"resizeToFit\", {\r\n /**\r\n * Gets or sets an boolean indicating that the TextBlock will be resized to fit container\r\n */\r\n get: function () {\r\n return this._resizeToFit;\r\n },\r\n /**\r\n * Gets or sets an boolean indicating that the TextBlock will be resized to fit container\r\n */\r\n set: function (value) {\r\n if (this._resizeToFit === value) {\r\n return;\r\n }\r\n this._resizeToFit = value;\r\n if (this._resizeToFit) {\r\n this._width.ignoreAdaptiveScaling = true;\r\n this._height.ignoreAdaptiveScaling = true;\r\n }\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"textWrapping\", {\r\n /**\r\n * Gets or sets a boolean indicating if text must be wrapped\r\n */\r\n get: function () {\r\n return this._textWrapping;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating if text must be wrapped\r\n */\r\n set: function (value) {\r\n if (this._textWrapping === value) {\r\n return;\r\n }\r\n this._textWrapping = +value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"text\", {\r\n /**\r\n * Gets or sets text to display\r\n */\r\n get: function () {\r\n return this._text;\r\n },\r\n /**\r\n * Gets or sets text to display\r\n */\r\n set: function (value) {\r\n if (this._text === value) {\r\n return;\r\n }\r\n this._text = value;\r\n this._markAsDirty();\r\n this.onTextChangedObservable.notifyObservers(this);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"textHorizontalAlignment\", {\r\n /**\r\n * Gets or sets text horizontal alignment (BABYLON.GUI.Control.HORIZONTAL_ALIGNMENT_CENTER by default)\r\n */\r\n get: function () {\r\n return this._textHorizontalAlignment;\r\n },\r\n /**\r\n * Gets or sets text horizontal alignment (BABYLON.GUI.Control.HORIZONTAL_ALIGNMENT_CENTER by default)\r\n */\r\n set: function (value) {\r\n if (this._textHorizontalAlignment === value) {\r\n return;\r\n }\r\n this._textHorizontalAlignment = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"textVerticalAlignment\", {\r\n /**\r\n * Gets or sets text vertical alignment (BABYLON.GUI.Control.VERTICAL_ALIGNMENT_CENTER by default)\r\n */\r\n get: function () {\r\n return this._textVerticalAlignment;\r\n },\r\n /**\r\n * Gets or sets text vertical alignment (BABYLON.GUI.Control.VERTICAL_ALIGNMENT_CENTER by default)\r\n */\r\n set: function (value) {\r\n if (this._textVerticalAlignment === value) {\r\n return;\r\n }\r\n this._textVerticalAlignment = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"lineSpacing\", {\r\n /**\r\n * Gets or sets line spacing value\r\n */\r\n get: function () {\r\n return this._lineSpacing.toString(this._host);\r\n },\r\n /**\r\n * Gets or sets line spacing value\r\n */\r\n set: function (value) {\r\n if (this._lineSpacing.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"outlineWidth\", {\r\n /**\r\n * Gets or sets outlineWidth of the text to display\r\n */\r\n get: function () {\r\n return this._outlineWidth;\r\n },\r\n /**\r\n * Gets or sets outlineWidth of the text to display\r\n */\r\n set: function (value) {\r\n if (this._outlineWidth === value) {\r\n return;\r\n }\r\n this._outlineWidth = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"underline\", {\r\n /**\r\n * Gets or sets a boolean indicating that text must have underline\r\n */\r\n get: function () {\r\n return this._underline;\r\n },\r\n /**\r\n * Gets or sets a boolean indicating that text must have underline\r\n */\r\n set: function (value) {\r\n if (this._underline === value) {\r\n return;\r\n }\r\n this._underline = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"lineThrough\", {\r\n /**\r\n * Gets or sets an boolean indicating that text must be crossed out\r\n */\r\n get: function () {\r\n return this._lineThrough;\r\n },\r\n /**\r\n * Gets or sets an boolean indicating that text must be crossed out\r\n */\r\n set: function (value) {\r\n if (this._lineThrough === value) {\r\n return;\r\n }\r\n this._lineThrough = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextBlock.prototype, \"outlineColor\", {\r\n /**\r\n * Gets or sets outlineColor of the text to display\r\n */\r\n get: function () {\r\n return this._outlineColor;\r\n },\r\n /**\r\n * Gets or sets outlineColor of the text to display\r\n */\r\n set: function (value) {\r\n if (this._outlineColor === value) {\r\n return;\r\n }\r\n this._outlineColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n TextBlock.prototype._getTypeName = function () {\r\n return \"TextBlock\";\r\n };\r\n TextBlock.prototype._processMeasures = function (parentMeasure, context) {\r\n if (!this._fontOffset) {\r\n this._fontOffset = Control._GetFontOffset(context.font);\r\n }\r\n _super.prototype._processMeasures.call(this, parentMeasure, context);\r\n // Prepare lines\r\n this._lines = this._breakLines(this._currentMeasure.width, context);\r\n this.onLinesReadyObservable.notifyObservers(this);\r\n var maxLineWidth = 0;\r\n for (var i = 0; i < this._lines.length; i++) {\r\n var line = this._lines[i];\r\n if (line.width > maxLineWidth) {\r\n maxLineWidth = line.width;\r\n }\r\n }\r\n if (this._resizeToFit) {\r\n if (this._textWrapping === TextWrapping.Clip) {\r\n var newWidth = (this.paddingLeftInPixels + this.paddingRightInPixels + maxLineWidth) | 0;\r\n if (newWidth !== this._width.internalValue) {\r\n this._width.updateInPlace(newWidth, ValueAndUnit.UNITMODE_PIXEL);\r\n this._rebuildLayout = true;\r\n }\r\n }\r\n var newHeight = (this.paddingTopInPixels + this.paddingBottomInPixels + this._fontOffset.height * this._lines.length) | 0;\r\n if (this._lines.length > 0 && this._lineSpacing.internalValue !== 0) {\r\n var lineSpacing = 0;\r\n if (this._lineSpacing.isPixel) {\r\n lineSpacing = this._lineSpacing.getValue(this._host);\r\n }\r\n else {\r\n lineSpacing = this._lineSpacing.getValue(this._host) * this._height.getValueInPixel(this._host, this._cachedParentMeasure.height);\r\n }\r\n newHeight += (this._lines.length - 1) * lineSpacing;\r\n }\r\n if (newHeight !== this._height.internalValue) {\r\n this._height.updateInPlace(newHeight, ValueAndUnit.UNITMODE_PIXEL);\r\n this._rebuildLayout = true;\r\n }\r\n }\r\n };\r\n TextBlock.prototype._drawText = function (text, textWidth, y, context) {\r\n var width = this._currentMeasure.width;\r\n var x = 0;\r\n switch (this._textHorizontalAlignment) {\r\n case Control.HORIZONTAL_ALIGNMENT_LEFT:\r\n x = 0;\r\n break;\r\n case Control.HORIZONTAL_ALIGNMENT_RIGHT:\r\n x = width - textWidth;\r\n break;\r\n case Control.HORIZONTAL_ALIGNMENT_CENTER:\r\n x = (width - textWidth) / 2;\r\n break;\r\n }\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n if (this.outlineWidth) {\r\n context.strokeText(text, this._currentMeasure.left + x, y);\r\n }\r\n context.fillText(text, this._currentMeasure.left + x, y);\r\n if (this._underline) {\r\n context.beginPath();\r\n context.lineWidth = Math.round(this.fontSizeInPixels * 0.05);\r\n context.moveTo(this._currentMeasure.left + x, y + 3);\r\n context.lineTo(this._currentMeasure.left + x + textWidth, y + 3);\r\n context.stroke();\r\n context.closePath();\r\n }\r\n if (this._lineThrough) {\r\n context.beginPath();\r\n context.lineWidth = Math.round(this.fontSizeInPixels * 0.05);\r\n context.moveTo(this._currentMeasure.left + x, y - this.fontSizeInPixels / 3);\r\n context.lineTo(this._currentMeasure.left + x + textWidth, y - this.fontSizeInPixels / 3);\r\n context.stroke();\r\n context.closePath();\r\n }\r\n };\r\n /** @hidden */\r\n TextBlock.prototype._draw = function (context, invalidatedRectangle) {\r\n context.save();\r\n this._applyStates(context);\r\n // Render lines\r\n this._renderLines(context);\r\n context.restore();\r\n };\r\n TextBlock.prototype._applyStates = function (context) {\r\n _super.prototype._applyStates.call(this, context);\r\n if (this.outlineWidth) {\r\n context.lineWidth = this.outlineWidth;\r\n context.strokeStyle = this.outlineColor;\r\n context.lineJoin = 'miter';\r\n context.miterLimit = 2;\r\n }\r\n };\r\n TextBlock.prototype._breakLines = function (refWidth, context) {\r\n var lines = [];\r\n var _lines = this.text.split(\"\\n\");\r\n if (this._textWrapping === TextWrapping.Ellipsis) {\r\n for (var _i = 0, _lines_1 = _lines; _i < _lines_1.length; _i++) {\r\n var _line = _lines_1[_i];\r\n lines.push(this._parseLineEllipsis(_line, refWidth, context));\r\n }\r\n }\r\n else if (this._textWrapping === TextWrapping.WordWrap) {\r\n for (var _a = 0, _lines_2 = _lines; _a < _lines_2.length; _a++) {\r\n var _line = _lines_2[_a];\r\n lines.push.apply(lines, this._parseLineWordWrap(_line, refWidth, context));\r\n }\r\n }\r\n else {\r\n for (var _b = 0, _lines_3 = _lines; _b < _lines_3.length; _b++) {\r\n var _line = _lines_3[_b];\r\n lines.push(this._parseLine(_line, context));\r\n }\r\n }\r\n return lines;\r\n };\r\n TextBlock.prototype._parseLine = function (line, context) {\r\n if (line === void 0) { line = \"\"; }\r\n return { text: line, width: context.measureText(line).width };\r\n };\r\n TextBlock.prototype._parseLineEllipsis = function (line, width, context) {\r\n if (line === void 0) { line = \"\"; }\r\n var lineWidth = context.measureText(line).width;\r\n if (lineWidth > width) {\r\n line += \"…\";\r\n }\r\n // unicode support. split('') does not work with unicode!\r\n // make sure Array.from is available\r\n var characters = Array.from && Array.from(line);\r\n if (!characters) {\r\n // no array.from, use the old method\r\n while (line.length > 2 && lineWidth > width) {\r\n line = line.slice(0, -2) + \"…\";\r\n lineWidth = context.measureText(line).width;\r\n }\r\n }\r\n else {\r\n while (characters.length && lineWidth > width) {\r\n characters.pop();\r\n line = characters.join(\"\") + \"...\";\r\n lineWidth = context.measureText(line).width;\r\n }\r\n }\r\n return { text: line, width: lineWidth };\r\n };\r\n TextBlock.prototype._parseLineWordWrap = function (line, width, context) {\r\n if (line === void 0) { line = \"\"; }\r\n var lines = [];\r\n var words = this.wordSplittingFunction ? this.wordSplittingFunction(line) : line.split(\" \");\r\n var lineWidth = 0;\r\n for (var n = 0; n < words.length; n++) {\r\n var testLine = n > 0 ? line + \" \" + words[n] : words[0];\r\n var metrics = context.measureText(testLine);\r\n var testWidth = metrics.width;\r\n if (testWidth > width && n > 0) {\r\n lines.push({ text: line, width: lineWidth });\r\n line = words[n];\r\n lineWidth = context.measureText(line).width;\r\n }\r\n else {\r\n lineWidth = testWidth;\r\n line = testLine;\r\n }\r\n }\r\n lines.push({ text: line, width: lineWidth });\r\n return lines;\r\n };\r\n TextBlock.prototype._renderLines = function (context) {\r\n var height = this._currentMeasure.height;\r\n var rootY = 0;\r\n switch (this._textVerticalAlignment) {\r\n case Control.VERTICAL_ALIGNMENT_TOP:\r\n rootY = this._fontOffset.ascent;\r\n break;\r\n case Control.VERTICAL_ALIGNMENT_BOTTOM:\r\n rootY = height - this._fontOffset.height * (this._lines.length - 1) - this._fontOffset.descent;\r\n break;\r\n case Control.VERTICAL_ALIGNMENT_CENTER:\r\n rootY = this._fontOffset.ascent + (height - this._fontOffset.height * this._lines.length) / 2;\r\n break;\r\n }\r\n rootY += this._currentMeasure.top;\r\n for (var i = 0; i < this._lines.length; i++) {\r\n var line = this._lines[i];\r\n if (i !== 0 && this._lineSpacing.internalValue !== 0) {\r\n if (this._lineSpacing.isPixel) {\r\n rootY += this._lineSpacing.getValue(this._host);\r\n }\r\n else {\r\n rootY = rootY + this._lineSpacing.getValue(this._host) * this._height.getValueInPixel(this._host, this._cachedParentMeasure.height);\r\n }\r\n }\r\n this._drawText(line.text, line.width, rootY, context);\r\n rootY += this._fontOffset.height;\r\n }\r\n };\r\n /**\r\n * Given a width constraint applied on the text block, find the expected height\r\n * @returns expected height\r\n */\r\n TextBlock.prototype.computeExpectedHeight = function () {\r\n if (this.text && this.widthInPixels) {\r\n var context_1 = document.createElement(\"canvas\").getContext(\"2d\");\r\n if (context_1) {\r\n this._applyStates(context_1);\r\n if (!this._fontOffset) {\r\n this._fontOffset = Control._GetFontOffset(context_1.font);\r\n }\r\n var lines = this._lines ? this._lines : this._breakLines(this.widthInPixels - this.paddingLeftInPixels - this.paddingRightInPixels, context_1);\r\n var newHeight = this.paddingTopInPixels + this.paddingBottomInPixels + this._fontOffset.height * lines.length;\r\n if (lines.length > 0 && this._lineSpacing.internalValue !== 0) {\r\n var lineSpacing = 0;\r\n if (this._lineSpacing.isPixel) {\r\n lineSpacing = this._lineSpacing.getValue(this._host);\r\n }\r\n else {\r\n lineSpacing = this._lineSpacing.getValue(this._host) * this._height.getValueInPixel(this._host, this._cachedParentMeasure.height);\r\n }\r\n newHeight += (lines.length - 1) * lineSpacing;\r\n }\r\n return newHeight;\r\n }\r\n }\r\n return 0;\r\n };\r\n TextBlock.prototype.dispose = function () {\r\n _super.prototype.dispose.call(this);\r\n this.onTextChangedObservable.clear();\r\n };\r\n return TextBlock;\r\n}(Control));\r\nexport { TextBlock };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.TextBlock\"] = TextBlock;\r\n//# sourceMappingURL=textBlock.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { Tools } from \"@babylonjs/core/Misc/tools\";\r\nimport { Control } from \"./control\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create 2D images\r\n */\r\nvar Image = /** @class */ (function (_super) {\r\n __extends(Image, _super);\r\n /**\r\n * Creates a new Image\r\n * @param name defines the control name\r\n * @param url defines the image url\r\n */\r\n function Image(name, url) {\r\n if (url === void 0) { url = null; }\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._workingCanvas = null;\r\n _this._loaded = false;\r\n _this._stretch = Image.STRETCH_FILL;\r\n _this._autoScale = false;\r\n _this._sourceLeft = 0;\r\n _this._sourceTop = 0;\r\n _this._sourceWidth = 0;\r\n _this._sourceHeight = 0;\r\n _this._svgAttributesComputationCompleted = false;\r\n _this._isSVG = false;\r\n _this._cellWidth = 0;\r\n _this._cellHeight = 0;\r\n _this._cellId = -1;\r\n _this._populateNinePatchSlicesFromImage = false;\r\n _this._imageDataCache = { data: null, key: \"\" };\r\n /**\r\n * Observable notified when the content is loaded\r\n */\r\n _this.onImageLoadedObservable = new Observable();\r\n /**\r\n * Observable notified when _sourceLeft, _sourceTop, _sourceWidth and _sourceHeight are computed\r\n */\r\n _this.onSVGAttributesComputedObservable = new Observable();\r\n _this.source = url;\r\n return _this;\r\n }\r\n Object.defineProperty(Image.prototype, \"isLoaded\", {\r\n /**\r\n * Gets a boolean indicating that the content is loaded\r\n */\r\n get: function () {\r\n return this._loaded;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"populateNinePatchSlicesFromImage\", {\r\n /**\r\n * Gets or sets a boolean indicating if nine patch slices (left, top, right, bottom) should be read from image data\r\n */\r\n get: function () {\r\n return this._populateNinePatchSlicesFromImage;\r\n },\r\n set: function (value) {\r\n if (this._populateNinePatchSlicesFromImage === value) {\r\n return;\r\n }\r\n this._populateNinePatchSlicesFromImage = value;\r\n if (this._populateNinePatchSlicesFromImage && this._loaded) {\r\n this._extractNinePatchSliceDataFromImage();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"detectPointerOnOpaqueOnly\", {\r\n /**\r\n * Gets or sets a boolean indicating if pointers should only be validated on pixels with alpha > 0.\r\n * Beware using this as this will comsume more memory as the image has to be stored twice\r\n */\r\n get: function () {\r\n return this._detectPointerOnOpaqueOnly;\r\n },\r\n set: function (value) {\r\n if (this._detectPointerOnOpaqueOnly === value) {\r\n return;\r\n }\r\n this._detectPointerOnOpaqueOnly = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"sliceLeft\", {\r\n /**\r\n * Gets or sets the left value for slicing (9-patch)\r\n */\r\n get: function () {\r\n return this._sliceLeft;\r\n },\r\n set: function (value) {\r\n if (this._sliceLeft === value) {\r\n return;\r\n }\r\n this._sliceLeft = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"sliceRight\", {\r\n /**\r\n * Gets or sets the right value for slicing (9-patch)\r\n */\r\n get: function () {\r\n return this._sliceRight;\r\n },\r\n set: function (value) {\r\n if (this._sliceRight === value) {\r\n return;\r\n }\r\n this._sliceRight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"sliceTop\", {\r\n /**\r\n * Gets or sets the top value for slicing (9-patch)\r\n */\r\n get: function () {\r\n return this._sliceTop;\r\n },\r\n set: function (value) {\r\n if (this._sliceTop === value) {\r\n return;\r\n }\r\n this._sliceTop = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"sliceBottom\", {\r\n /**\r\n * Gets or sets the bottom value for slicing (9-patch)\r\n */\r\n get: function () {\r\n return this._sliceBottom;\r\n },\r\n set: function (value) {\r\n if (this._sliceBottom === value) {\r\n return;\r\n }\r\n this._sliceBottom = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"sourceLeft\", {\r\n /**\r\n * Gets or sets the left coordinate in the source image\r\n */\r\n get: function () {\r\n return this._sourceLeft;\r\n },\r\n set: function (value) {\r\n if (this._sourceLeft === value) {\r\n return;\r\n }\r\n this._sourceLeft = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"sourceTop\", {\r\n /**\r\n * Gets or sets the top coordinate in the source image\r\n */\r\n get: function () {\r\n return this._sourceTop;\r\n },\r\n set: function (value) {\r\n if (this._sourceTop === value) {\r\n return;\r\n }\r\n this._sourceTop = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"sourceWidth\", {\r\n /**\r\n * Gets or sets the width to capture in the source image\r\n */\r\n get: function () {\r\n return this._sourceWidth;\r\n },\r\n set: function (value) {\r\n if (this._sourceWidth === value) {\r\n return;\r\n }\r\n this._sourceWidth = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"sourceHeight\", {\r\n /**\r\n * Gets or sets the height to capture in the source image\r\n */\r\n get: function () {\r\n return this._sourceHeight;\r\n },\r\n set: function (value) {\r\n if (this._sourceHeight === value) {\r\n return;\r\n }\r\n this._sourceHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"isSVG\", {\r\n /** Indicates if the format of the image is SVG */\r\n get: function () {\r\n return this._isSVG;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"svgAttributesComputationCompleted\", {\r\n /** Gets the status of the SVG attributes computation (sourceLeft, sourceTop, sourceWidth, sourceHeight) */\r\n get: function () {\r\n return this._svgAttributesComputationCompleted;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"autoScale\", {\r\n /**\r\n * Gets or sets a boolean indicating if the image can force its container to adapt its size\r\n * @see https://doc.babylonjs.com/how_to/gui#image\r\n */\r\n get: function () {\r\n return this._autoScale;\r\n },\r\n set: function (value) {\r\n if (this._autoScale === value) {\r\n return;\r\n }\r\n this._autoScale = value;\r\n if (value && this._loaded) {\r\n this.synchronizeSizeWithContent();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"stretch\", {\r\n /** Gets or sets the streching mode used by the image */\r\n get: function () {\r\n return this._stretch;\r\n },\r\n set: function (value) {\r\n if (this._stretch === value) {\r\n return;\r\n }\r\n this._stretch = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n Image.prototype._rotate90 = function (n, preserveProperties) {\r\n if (preserveProperties === void 0) { preserveProperties = false; }\r\n var canvas = document.createElement('canvas');\r\n var context = canvas.getContext('2d');\r\n var width = this._domImage.width;\r\n var height = this._domImage.height;\r\n canvas.width = height;\r\n canvas.height = width;\r\n context.translate(canvas.width / 2, canvas.height / 2);\r\n context.rotate(n * Math.PI / 2);\r\n context.drawImage(this._domImage, 0, 0, width, height, -width / 2, -height / 2, width, height);\r\n var dataUrl = canvas.toDataURL(\"image/jpg\");\r\n var rotatedImage = new Image(this.name + \"rotated\", dataUrl);\r\n if (preserveProperties) {\r\n rotatedImage._stretch = this._stretch;\r\n rotatedImage._autoScale = this._autoScale;\r\n rotatedImage._cellId = this._cellId;\r\n rotatedImage._cellWidth = n % 1 ? this._cellHeight : this._cellWidth;\r\n rotatedImage._cellHeight = n % 1 ? this._cellWidth : this._cellHeight;\r\n }\r\n this._handleRotationForSVGImage(this, rotatedImage, n);\r\n this._imageDataCache.data = null;\r\n return rotatedImage;\r\n };\r\n Image.prototype._handleRotationForSVGImage = function (srcImage, dstImage, n) {\r\n var _this = this;\r\n if (!srcImage._isSVG) {\r\n return;\r\n }\r\n if (srcImage._svgAttributesComputationCompleted) {\r\n this._rotate90SourceProperties(srcImage, dstImage, n);\r\n this._markAsDirty();\r\n }\r\n else {\r\n srcImage.onSVGAttributesComputedObservable.addOnce(function () {\r\n _this._rotate90SourceProperties(srcImage, dstImage, n);\r\n _this._markAsDirty();\r\n });\r\n }\r\n };\r\n Image.prototype._rotate90SourceProperties = function (srcImage, dstImage, n) {\r\n var _a, _b;\r\n var srcLeft = srcImage.sourceLeft, srcTop = srcImage.sourceTop, srcWidth = srcImage.domImage.width, srcHeight = srcImage.domImage.height;\r\n var dstLeft = srcLeft, dstTop = srcTop, dstWidth = srcImage.sourceWidth, dstHeight = srcImage.sourceHeight;\r\n if (n != 0) {\r\n var mult = n < 0 ? -1 : 1;\r\n n = n % 4;\r\n for (var i = 0; i < Math.abs(n); ++i) {\r\n dstLeft = -(srcTop - srcHeight / 2) * mult + srcHeight / 2;\r\n dstTop = (srcLeft - srcWidth / 2) * mult + srcWidth / 2;\r\n _a = [dstHeight, dstWidth], dstWidth = _a[0], dstHeight = _a[1];\r\n if (n < 0) {\r\n dstTop -= dstHeight;\r\n }\r\n else {\r\n dstLeft -= dstWidth;\r\n }\r\n srcLeft = dstLeft;\r\n srcTop = dstTop;\r\n _b = [srcHeight, srcWidth], srcWidth = _b[0], srcHeight = _b[1];\r\n }\r\n }\r\n dstImage.sourceLeft = dstLeft;\r\n dstImage.sourceTop = dstTop;\r\n dstImage.sourceWidth = dstWidth;\r\n dstImage.sourceHeight = dstHeight;\r\n };\r\n Object.defineProperty(Image.prototype, \"domImage\", {\r\n get: function () {\r\n return this._domImage;\r\n },\r\n /**\r\n * Gets or sets the internal DOM image used to render the control\r\n */\r\n set: function (value) {\r\n var _this = this;\r\n this._domImage = value;\r\n this._loaded = false;\r\n this._imageDataCache.data = null;\r\n if (this._domImage.width) {\r\n this._onImageLoaded();\r\n }\r\n else {\r\n this._domImage.onload = function () {\r\n _this._onImageLoaded();\r\n };\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Image.prototype._onImageLoaded = function () {\r\n this._imageDataCache.data = null;\r\n this._imageWidth = this._domImage.width;\r\n this._imageHeight = this._domImage.height;\r\n this._loaded = true;\r\n if (this._populateNinePatchSlicesFromImage) {\r\n this._extractNinePatchSliceDataFromImage();\r\n }\r\n if (this._autoScale) {\r\n this.synchronizeSizeWithContent();\r\n }\r\n this.onImageLoadedObservable.notifyObservers(this);\r\n this._markAsDirty();\r\n };\r\n Image.prototype._extractNinePatchSliceDataFromImage = function () {\r\n if (!this._workingCanvas) {\r\n this._workingCanvas = document.createElement('canvas');\r\n }\r\n var canvas = this._workingCanvas;\r\n var context = canvas.getContext('2d');\r\n var width = this._domImage.width;\r\n var height = this._domImage.height;\r\n canvas.width = width;\r\n canvas.height = height;\r\n context.drawImage(this._domImage, 0, 0, width, height);\r\n var imageData = context.getImageData(0, 0, width, height);\r\n // Left and right\r\n this._sliceLeft = -1;\r\n this._sliceRight = -1;\r\n for (var x = 0; x < width; x++) {\r\n var alpha = imageData.data[x * 4 + 3];\r\n if (alpha > 127 && this._sliceLeft === -1) {\r\n this._sliceLeft = x;\r\n continue;\r\n }\r\n if (alpha < 127 && this._sliceLeft > -1) {\r\n this._sliceRight = x;\r\n break;\r\n }\r\n }\r\n // top and bottom\r\n this._sliceTop = -1;\r\n this._sliceBottom = -1;\r\n for (var y = 0; y < height; y++) {\r\n var alpha = imageData.data[y * width * 4 + 3];\r\n if (alpha > 127 && this._sliceTop === -1) {\r\n this._sliceTop = y;\r\n continue;\r\n }\r\n if (alpha < 127 && this._sliceTop > -1) {\r\n this._sliceBottom = y;\r\n break;\r\n }\r\n }\r\n };\r\n Object.defineProperty(Image.prototype, \"source\", {\r\n /**\r\n * Gets or sets image source url\r\n */\r\n set: function (value) {\r\n var _this = this;\r\n if (this._source === value) {\r\n return;\r\n }\r\n this._loaded = false;\r\n this._source = value;\r\n this._imageDataCache.data = null;\r\n if (value) {\r\n value = this._svgCheck(value);\r\n }\r\n this._domImage = document.createElement(\"img\");\r\n this._domImage.onload = function () {\r\n _this._onImageLoaded();\r\n };\r\n if (value) {\r\n Tools.SetCorsBehavior(value, this._domImage);\r\n this._domImage.src = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Checks for svg document with icon id present\r\n */\r\n Image.prototype._svgCheck = function (value) {\r\n var _this = this;\r\n if (window.SVGSVGElement && (value.search(/.svg#/gi) !== -1) && (value.indexOf(\"#\") === value.lastIndexOf(\"#\"))) {\r\n this._isSVG = true;\r\n var svgsrc = value.split('#')[0];\r\n var elemid = value.split('#')[1];\r\n // check if object alr exist in document\r\n var svgExist = document.body.querySelector('object[data=\"' + svgsrc + '\"]');\r\n if (svgExist) {\r\n var svgDoc = svgExist.contentDocument;\r\n // get viewbox width and height, get svg document width and height in px\r\n if (svgDoc && svgDoc.documentElement) {\r\n var vb = svgDoc.documentElement.getAttribute(\"viewBox\");\r\n var docwidth = Number(svgDoc.documentElement.getAttribute(\"width\"));\r\n var docheight = Number(svgDoc.documentElement.getAttribute(\"height\"));\r\n var elem = svgDoc.getElementById(elemid);\r\n if (elem && vb && docwidth && docheight) {\r\n this._getSVGAttribs(svgExist, elemid);\r\n return value;\r\n }\r\n }\r\n // wait for object to load\r\n svgExist.addEventListener(\"load\", function () {\r\n _this._getSVGAttribs(svgExist, elemid);\r\n });\r\n }\r\n else {\r\n // create document object\r\n var svgImage = document.createElement(\"object\");\r\n svgImage.data = svgsrc;\r\n svgImage.type = \"image/svg+xml\";\r\n svgImage.width = \"0%\";\r\n svgImage.height = \"0%\";\r\n document.body.appendChild(svgImage);\r\n // when the object has loaded, get the element attribs\r\n svgImage.onload = function () {\r\n var svgobj = document.body.querySelector('object[data=\"' + svgsrc + '\"]');\r\n if (svgobj) {\r\n _this._getSVGAttribs(svgobj, elemid);\r\n }\r\n };\r\n }\r\n return svgsrc;\r\n }\r\n else {\r\n return value;\r\n }\r\n };\r\n /**\r\n * Sets sourceLeft, sourceTop, sourceWidth, sourceHeight automatically\r\n * given external svg file and icon id\r\n */\r\n Image.prototype._getSVGAttribs = function (svgsrc, elemid) {\r\n var svgDoc = svgsrc.contentDocument;\r\n // get viewbox width and height, get svg document width and height in px\r\n if (svgDoc && svgDoc.documentElement) {\r\n var vb = svgDoc.documentElement.getAttribute(\"viewBox\");\r\n var docwidth = Number(svgDoc.documentElement.getAttribute(\"width\"));\r\n var docheight = Number(svgDoc.documentElement.getAttribute(\"height\"));\r\n // get element bbox and matrix transform\r\n var elem = svgDoc.getElementById(elemid);\r\n if (vb && docwidth && docheight && elem) {\r\n var vb_width = Number(vb.split(\" \")[2]);\r\n var vb_height = Number(vb.split(\" \")[3]);\r\n var elem_bbox = elem.getBBox();\r\n var elem_matrix_a = 1;\r\n var elem_matrix_d = 1;\r\n var elem_matrix_e = 0;\r\n var elem_matrix_f = 0;\r\n if (elem.transform && elem.transform.baseVal.consolidate()) {\r\n elem_matrix_a = elem.transform.baseVal.consolidate().matrix.a;\r\n elem_matrix_d = elem.transform.baseVal.consolidate().matrix.d;\r\n elem_matrix_e = elem.transform.baseVal.consolidate().matrix.e;\r\n elem_matrix_f = elem.transform.baseVal.consolidate().matrix.f;\r\n }\r\n // compute source coordinates and dimensions\r\n this.sourceLeft = ((elem_matrix_a * elem_bbox.x + elem_matrix_e) * docwidth) / vb_width;\r\n this.sourceTop = ((elem_matrix_d * elem_bbox.y + elem_matrix_f) * docheight) / vb_height;\r\n this.sourceWidth = (elem_bbox.width * elem_matrix_a) * (docwidth / vb_width);\r\n this.sourceHeight = (elem_bbox.height * elem_matrix_d) * (docheight / vb_height);\r\n this._svgAttributesComputationCompleted = true;\r\n this.onSVGAttributesComputedObservable.notifyObservers(this);\r\n }\r\n }\r\n };\r\n Object.defineProperty(Image.prototype, \"cellWidth\", {\r\n /**\r\n * Gets or sets the cell width to use when animation sheet is enabled\r\n * @see https://doc.babylonjs.com/how_to/gui#image\r\n */\r\n get: function () {\r\n return this._cellWidth;\r\n },\r\n set: function (value) {\r\n if (this._cellWidth === value) {\r\n return;\r\n }\r\n this._cellWidth = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"cellHeight\", {\r\n /**\r\n * Gets or sets the cell height to use when animation sheet is enabled\r\n * @see https://doc.babylonjs.com/how_to/gui#image\r\n */\r\n get: function () {\r\n return this._cellHeight;\r\n },\r\n set: function (value) {\r\n if (this._cellHeight === value) {\r\n return;\r\n }\r\n this._cellHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Image.prototype, \"cellId\", {\r\n /**\r\n * Gets or sets the cell id to use (this will turn on the animation sheet mode)\r\n * @see https://doc.babylonjs.com/how_to/gui#image\r\n */\r\n get: function () {\r\n return this._cellId;\r\n },\r\n set: function (value) {\r\n if (this._cellId === value) {\r\n return;\r\n }\r\n this._cellId = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Tests if a given coordinates belong to the current control\r\n * @param x defines x coordinate to test\r\n * @param y defines y coordinate to test\r\n * @returns true if the coordinates are inside the control\r\n */\r\n Image.prototype.contains = function (x, y) {\r\n if (!_super.prototype.contains.call(this, x, y)) {\r\n return false;\r\n }\r\n if (!this._detectPointerOnOpaqueOnly || !this._workingCanvas) {\r\n return true;\r\n }\r\n var width = this._currentMeasure.width | 0;\r\n var height = this._currentMeasure.height | 0;\r\n var key = width + \"_\" + height;\r\n var imageData = this._imageDataCache.data;\r\n if (!imageData || this._imageDataCache.key !== key) {\r\n var canvas = this._workingCanvas;\r\n var context_1 = canvas.getContext(\"2d\");\r\n this._imageDataCache.data = imageData = context_1.getImageData(0, 0, width, height).data;\r\n this._imageDataCache.key = key;\r\n }\r\n x = (x - this._currentMeasure.left) | 0;\r\n y = (y - this._currentMeasure.top) | 0;\r\n var pickedPixel = imageData[(x + y * width) * 4 + 3];\r\n return pickedPixel > 0;\r\n };\r\n Image.prototype._getTypeName = function () {\r\n return \"Image\";\r\n };\r\n /** Force the control to synchronize with its content */\r\n Image.prototype.synchronizeSizeWithContent = function () {\r\n if (!this._loaded) {\r\n return;\r\n }\r\n this.width = this._domImage.width + \"px\";\r\n this.height = this._domImage.height + \"px\";\r\n };\r\n Image.prototype._processMeasures = function (parentMeasure, context) {\r\n if (this._loaded) {\r\n switch (this._stretch) {\r\n case Image.STRETCH_NONE:\r\n break;\r\n case Image.STRETCH_FILL:\r\n break;\r\n case Image.STRETCH_UNIFORM:\r\n break;\r\n case Image.STRETCH_NINE_PATCH:\r\n break;\r\n case Image.STRETCH_EXTEND:\r\n if (this._autoScale) {\r\n this.synchronizeSizeWithContent();\r\n }\r\n if (this.parent && this.parent.parent) { // Will update root size if root is not the top root\r\n this.parent.adaptWidthToChildren = true;\r\n this.parent.adaptHeightToChildren = true;\r\n }\r\n break;\r\n }\r\n }\r\n _super.prototype._processMeasures.call(this, parentMeasure, context);\r\n };\r\n Image.prototype._prepareWorkingCanvasForOpaqueDetection = function () {\r\n if (!this._detectPointerOnOpaqueOnly) {\r\n return;\r\n }\r\n if (!this._workingCanvas) {\r\n this._workingCanvas = document.createElement('canvas');\r\n }\r\n var canvas = this._workingCanvas;\r\n var width = this._currentMeasure.width;\r\n var height = this._currentMeasure.height;\r\n var context = canvas.getContext(\"2d\");\r\n canvas.width = width;\r\n canvas.height = height;\r\n context.clearRect(0, 0, width, height);\r\n };\r\n Image.prototype._drawImage = function (context, sx, sy, sw, sh, tx, ty, tw, th) {\r\n context.drawImage(this._domImage, sx, sy, sw, sh, tx, ty, tw, th);\r\n if (!this._detectPointerOnOpaqueOnly) {\r\n return;\r\n }\r\n var canvas = this._workingCanvas;\r\n context = canvas.getContext(\"2d\");\r\n context.drawImage(this._domImage, sx, sy, sw, sh, tx - this._currentMeasure.left, ty - this._currentMeasure.top, tw, th);\r\n };\r\n Image.prototype._draw = function (context) {\r\n context.save();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n var x, y, width, height;\r\n if (this.cellId == -1) {\r\n x = this._sourceLeft;\r\n y = this._sourceTop;\r\n width = this._sourceWidth ? this._sourceWidth : this._imageWidth;\r\n height = this._sourceHeight ? this._sourceHeight : this._imageHeight;\r\n }\r\n else {\r\n var rowCount = this._domImage.naturalWidth / this.cellWidth;\r\n var column = (this.cellId / rowCount) >> 0;\r\n var row = this.cellId % rowCount;\r\n x = this.cellWidth * row;\r\n y = this.cellHeight * column;\r\n width = this.cellWidth;\r\n height = this.cellHeight;\r\n }\r\n this._prepareWorkingCanvasForOpaqueDetection();\r\n this._applyStates(context);\r\n if (this._loaded) {\r\n switch (this._stretch) {\r\n case Image.STRETCH_NONE:\r\n this._drawImage(context, x, y, width, height, this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n break;\r\n case Image.STRETCH_FILL:\r\n this._drawImage(context, x, y, width, height, this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n break;\r\n case Image.STRETCH_UNIFORM:\r\n var hRatio = this._currentMeasure.width / width;\r\n var vRatio = this._currentMeasure.height / height;\r\n var ratio = Math.min(hRatio, vRatio);\r\n var centerX = (this._currentMeasure.width - width * ratio) / 2;\r\n var centerY = (this._currentMeasure.height - height * ratio) / 2;\r\n this._drawImage(context, x, y, width, height, this._currentMeasure.left + centerX, this._currentMeasure.top + centerY, width * ratio, height * ratio);\r\n break;\r\n case Image.STRETCH_EXTEND:\r\n this._drawImage(context, x, y, width, height, this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n break;\r\n case Image.STRETCH_NINE_PATCH:\r\n this._renderNinePatch(context);\r\n break;\r\n }\r\n }\r\n context.restore();\r\n };\r\n Image.prototype._renderCornerPatch = function (context, x, y, width, height, targetX, targetY) {\r\n this._drawImage(context, x, y, width, height, this._currentMeasure.left + targetX, this._currentMeasure.top + targetY, width, height);\r\n };\r\n Image.prototype._renderNinePatch = function (context) {\r\n var height = this._imageHeight;\r\n var leftWidth = this._sliceLeft;\r\n var topHeight = this._sliceTop;\r\n var bottomHeight = this._imageHeight - this._sliceBottom;\r\n var rightWidth = this._imageWidth - this._sliceRight;\r\n var left = 0;\r\n var top = 0;\r\n if (this._populateNinePatchSlicesFromImage) {\r\n left = 1;\r\n top = 1;\r\n height -= 2;\r\n leftWidth -= 1;\r\n topHeight -= 1;\r\n bottomHeight -= 1;\r\n rightWidth -= 1;\r\n }\r\n var centerWidth = this._sliceRight - this._sliceLeft;\r\n var targetCenterWidth = this._currentMeasure.width - rightWidth - this.sliceLeft;\r\n var targetTopHeight = this._currentMeasure.height - height + this._sliceBottom;\r\n // Corners\r\n this._renderCornerPatch(context, left, top, leftWidth, topHeight, 0, 0);\r\n this._renderCornerPatch(context, left, this._sliceBottom, leftWidth, height - this._sliceBottom, 0, targetTopHeight);\r\n this._renderCornerPatch(context, this._sliceRight, top, rightWidth, topHeight, this._currentMeasure.width - rightWidth, 0);\r\n this._renderCornerPatch(context, this._sliceRight, this._sliceBottom, rightWidth, height - this._sliceBottom, this._currentMeasure.width - rightWidth, targetTopHeight);\r\n // Center\r\n this._drawImage(context, this._sliceLeft, this._sliceTop, centerWidth, this._sliceBottom - this._sliceTop, this._currentMeasure.left + leftWidth, this._currentMeasure.top + topHeight, targetCenterWidth, targetTopHeight - topHeight);\r\n // Borders\r\n this._drawImage(context, left, this._sliceTop, leftWidth, this._sliceBottom - this._sliceTop, this._currentMeasure.left, this._currentMeasure.top + topHeight, leftWidth, targetTopHeight - topHeight);\r\n this._drawImage(context, this._sliceRight, this._sliceTop, leftWidth, this._sliceBottom - this._sliceTop, this._currentMeasure.left + this._currentMeasure.width - rightWidth, this._currentMeasure.top + topHeight, leftWidth, targetTopHeight - topHeight);\r\n this._drawImage(context, this._sliceLeft, top, centerWidth, topHeight, this._currentMeasure.left + leftWidth, this._currentMeasure.top, targetCenterWidth, topHeight);\r\n this._drawImage(context, this._sliceLeft, this._sliceBottom, centerWidth, bottomHeight, this._currentMeasure.left + leftWidth, this._currentMeasure.top + targetTopHeight, targetCenterWidth, bottomHeight);\r\n };\r\n Image.prototype.dispose = function () {\r\n _super.prototype.dispose.call(this);\r\n this.onImageLoadedObservable.clear();\r\n this.onSVGAttributesComputedObservable.clear();\r\n };\r\n // Static\r\n /** STRETCH_NONE */\r\n Image.STRETCH_NONE = 0;\r\n /** STRETCH_FILL */\r\n Image.STRETCH_FILL = 1;\r\n /** STRETCH_UNIFORM */\r\n Image.STRETCH_UNIFORM = 2;\r\n /** STRETCH_EXTEND */\r\n Image.STRETCH_EXTEND = 3;\r\n /** NINE_PATCH */\r\n Image.STRETCH_NINE_PATCH = 4;\r\n return Image;\r\n}(Control));\r\nexport { Image };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Image\"] = Image;\r\n//# sourceMappingURL=image.js.map","import { __extends } from \"tslib\";\r\nimport { Rectangle } from \"./rectangle\";\r\nimport { Control } from \"./control\";\r\nimport { TextBlock } from \"./textBlock\";\r\nimport { Image } from \"./image\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create 2D buttons\r\n */\r\nvar Button = /** @class */ (function (_super) {\r\n __extends(Button, _super);\r\n /**\r\n * Creates a new Button\r\n * @param name defines the name of the button\r\n */\r\n function Button(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n /**\r\n * Gets or sets a boolean indicating that the button will let internal controls handle picking instead of doing it directly using its bounding info\r\n */\r\n _this.delegatePickingToChildren = false;\r\n _this.thickness = 1;\r\n _this.isPointerBlocker = true;\r\n var alphaStore = null;\r\n _this.pointerEnterAnimation = function () {\r\n alphaStore = _this.alpha;\r\n _this.alpha -= 0.1;\r\n };\r\n _this.pointerOutAnimation = function () {\r\n if (alphaStore !== null) {\r\n _this.alpha = alphaStore;\r\n }\r\n };\r\n _this.pointerDownAnimation = function () {\r\n _this.scaleX -= 0.05;\r\n _this.scaleY -= 0.05;\r\n };\r\n _this.pointerUpAnimation = function () {\r\n _this.scaleX += 0.05;\r\n _this.scaleY += 0.05;\r\n };\r\n return _this;\r\n }\r\n Object.defineProperty(Button.prototype, \"image\", {\r\n /**\r\n * Returns the image part of the button (if any)\r\n */\r\n get: function () {\r\n return this._image;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Button.prototype, \"textBlock\", {\r\n /**\r\n * Returns the image part of the button (if any)\r\n */\r\n get: function () {\r\n return this._textBlock;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Button.prototype._getTypeName = function () {\r\n return \"Button\";\r\n };\r\n // While being a container, the button behaves like a control.\r\n /** @hidden */\r\n Button.prototype._processPicking = function (x, y, pi, type, pointerId, buttonIndex, deltaX, deltaY) {\r\n if (!this._isEnabled || !this.isHitTestVisible || !this.isVisible || this.notRenderable) {\r\n return false;\r\n }\r\n if (!_super.prototype.contains.call(this, x, y)) {\r\n return false;\r\n }\r\n if (this.delegatePickingToChildren) {\r\n var contains = false;\r\n for (var index = this._children.length - 1; index >= 0; index--) {\r\n var child = this._children[index];\r\n if (child.isEnabled && child.isHitTestVisible && child.isVisible && !child.notRenderable && child.contains(x, y)) {\r\n contains = true;\r\n break;\r\n }\r\n }\r\n if (!contains) {\r\n return false;\r\n }\r\n }\r\n this._processObservables(type, x, y, pi, pointerId, buttonIndex, deltaX, deltaY);\r\n return true;\r\n };\r\n /** @hidden */\r\n Button.prototype._onPointerEnter = function (target, pi) {\r\n if (!_super.prototype._onPointerEnter.call(this, target, pi)) {\r\n return false;\r\n }\r\n if (this.pointerEnterAnimation) {\r\n this.pointerEnterAnimation();\r\n }\r\n return true;\r\n };\r\n /** @hidden */\r\n Button.prototype._onPointerOut = function (target, pi, force) {\r\n if (force === void 0) { force = false; }\r\n if (this.pointerOutAnimation) {\r\n this.pointerOutAnimation();\r\n }\r\n _super.prototype._onPointerOut.call(this, target, pi, force);\r\n };\r\n /** @hidden */\r\n Button.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex, pi) {\r\n if (!_super.prototype._onPointerDown.call(this, target, coordinates, pointerId, buttonIndex, pi)) {\r\n return false;\r\n }\r\n if (this.pointerDownAnimation) {\r\n this.pointerDownAnimation();\r\n }\r\n return true;\r\n };\r\n /** @hidden */\r\n Button.prototype._onPointerUp = function (target, coordinates, pointerId, buttonIndex, notifyClick, pi) {\r\n if (this.pointerUpAnimation) {\r\n this.pointerUpAnimation();\r\n }\r\n _super.prototype._onPointerUp.call(this, target, coordinates, pointerId, buttonIndex, notifyClick, pi);\r\n };\r\n // Statics\r\n /**\r\n * Creates a new button made with an image and a text\r\n * @param name defines the name of the button\r\n * @param text defines the text of the button\r\n * @param imageUrl defines the url of the image\r\n * @returns a new Button\r\n */\r\n Button.CreateImageButton = function (name, text, imageUrl) {\r\n var result = new Button(name);\r\n // Adding text\r\n var textBlock = new TextBlock(name + \"_button\", text);\r\n textBlock.textWrapping = true;\r\n textBlock.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_CENTER;\r\n textBlock.paddingLeft = \"20%\";\r\n result.addControl(textBlock);\r\n // Adding image\r\n var iconImage = new Image(name + \"_icon\", imageUrl);\r\n iconImage.width = \"20%\";\r\n iconImage.stretch = Image.STRETCH_UNIFORM;\r\n iconImage.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n result.addControl(iconImage);\r\n // Store\r\n result._image = iconImage;\r\n result._textBlock = textBlock;\r\n return result;\r\n };\r\n /**\r\n * Creates a new button made with an image\r\n * @param name defines the name of the button\r\n * @param imageUrl defines the url of the image\r\n * @returns a new Button\r\n */\r\n Button.CreateImageOnlyButton = function (name, imageUrl) {\r\n var result = new Button(name);\r\n // Adding image\r\n var iconImage = new Image(name + \"_icon\", imageUrl);\r\n iconImage.stretch = Image.STRETCH_FILL;\r\n iconImage.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n result.addControl(iconImage);\r\n // Store\r\n result._image = iconImage;\r\n return result;\r\n };\r\n /**\r\n * Creates a new button made with a text\r\n * @param name defines the name of the button\r\n * @param text defines the text of the button\r\n * @returns a new Button\r\n */\r\n Button.CreateSimpleButton = function (name, text) {\r\n var result = new Button(name);\r\n // Adding text\r\n var textBlock = new TextBlock(name + \"_button\", text);\r\n textBlock.textWrapping = true;\r\n textBlock.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_CENTER;\r\n result.addControl(textBlock);\r\n // Store\r\n result._textBlock = textBlock;\r\n return result;\r\n };\r\n /**\r\n * Creates a new button made with an image and a centered text\r\n * @param name defines the name of the button\r\n * @param text defines the text of the button\r\n * @param imageUrl defines the url of the image\r\n * @returns a new Button\r\n */\r\n Button.CreateImageWithCenterTextButton = function (name, text, imageUrl) {\r\n var result = new Button(name);\r\n // Adding image\r\n var iconImage = new Image(name + \"_icon\", imageUrl);\r\n iconImage.stretch = Image.STRETCH_FILL;\r\n result.addControl(iconImage);\r\n // Adding text\r\n var textBlock = new TextBlock(name + \"_button\", text);\r\n textBlock.textWrapping = true;\r\n textBlock.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_CENTER;\r\n result.addControl(textBlock);\r\n // Store\r\n result._image = iconImage;\r\n result._textBlock = textBlock;\r\n return result;\r\n };\r\n return Button;\r\n}(Rectangle));\r\nexport { Button };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Button\"] = Button;\r\n//# sourceMappingURL=button.js.map","import { __extends } from \"tslib\";\r\nimport { Tools } from \"@babylonjs/core/Misc/tools\";\r\nimport { Container } from \"./container\";\r\nimport { Control } from \"./control\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create a 2D stack panel container\r\n */\r\nvar StackPanel = /** @class */ (function (_super) {\r\n __extends(StackPanel, _super);\r\n /**\r\n * Creates a new StackPanel\r\n * @param name defines control name\r\n */\r\n function StackPanel(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._isVertical = true;\r\n _this._manualWidth = false;\r\n _this._manualHeight = false;\r\n _this._doNotTrackManualChanges = false;\r\n /**\r\n * Gets or sets a boolean indicating that layou warnings should be ignored\r\n */\r\n _this.ignoreLayoutWarnings = false;\r\n return _this;\r\n }\r\n Object.defineProperty(StackPanel.prototype, \"isVertical\", {\r\n /** Gets or sets a boolean indicating if the stack panel is vertical or horizontal*/\r\n get: function () {\r\n return this._isVertical;\r\n },\r\n set: function (value) {\r\n if (this._isVertical === value) {\r\n return;\r\n }\r\n this._isVertical = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StackPanel.prototype, \"width\", {\r\n get: function () {\r\n return this._width.toString(this._host);\r\n },\r\n /**\r\n * Gets or sets panel width.\r\n * This value should not be set when in horizontal mode as it will be computed automatically\r\n */\r\n set: function (value) {\r\n if (!this._doNotTrackManualChanges) {\r\n this._manualWidth = true;\r\n }\r\n if (this._width.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._width.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(StackPanel.prototype, \"height\", {\r\n get: function () {\r\n return this._height.toString(this._host);\r\n },\r\n /**\r\n * Gets or sets panel height.\r\n * This value should not be set when in vertical mode as it will be computed automatically\r\n */\r\n set: function (value) {\r\n if (!this._doNotTrackManualChanges) {\r\n this._manualHeight = true;\r\n }\r\n if (this._height.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._height.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n StackPanel.prototype._getTypeName = function () {\r\n return \"StackPanel\";\r\n };\r\n /** @hidden */\r\n StackPanel.prototype._preMeasure = function (parentMeasure, context) {\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (this._isVertical) {\r\n child.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n }\r\n else {\r\n child.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n }\r\n }\r\n _super.prototype._preMeasure.call(this, parentMeasure, context);\r\n };\r\n StackPanel.prototype._additionalProcessing = function (parentMeasure, context) {\r\n _super.prototype._additionalProcessing.call(this, parentMeasure, context);\r\n this._measureForChildren.copyFrom(parentMeasure);\r\n this._measureForChildren.left = this._currentMeasure.left;\r\n this._measureForChildren.top = this._currentMeasure.top;\r\n if (!this.isVertical || this._manualWidth) {\r\n this._measureForChildren.width = this._currentMeasure.width;\r\n }\r\n if (this.isVertical || this._manualHeight) {\r\n this._measureForChildren.height = this._currentMeasure.height;\r\n }\r\n };\r\n StackPanel.prototype._postMeasure = function () {\r\n var stackWidth = 0;\r\n var stackHeight = 0;\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (!child.isVisible || child.notRenderable) {\r\n continue;\r\n }\r\n if (this._isVertical) {\r\n if (child.top !== stackHeight + \"px\") {\r\n child.top = stackHeight + \"px\";\r\n this._rebuildLayout = true;\r\n child._top.ignoreAdaptiveScaling = true;\r\n }\r\n if (child._height.isPercentage && !child._automaticSize) {\r\n if (!this.ignoreLayoutWarnings) {\r\n Tools.Warn(\"Control (Name:\" + child.name + \", UniqueId:\" + child.uniqueId + \") is using height in percentage mode inside a vertical StackPanel\");\r\n }\r\n }\r\n else {\r\n stackHeight += child._currentMeasure.height + child.paddingTopInPixels + child.paddingBottomInPixels;\r\n }\r\n }\r\n else {\r\n if (child.left !== stackWidth + \"px\") {\r\n child.left = stackWidth + \"px\";\r\n this._rebuildLayout = true;\r\n child._left.ignoreAdaptiveScaling = true;\r\n }\r\n if (child._width.isPercentage && !child._automaticSize) {\r\n if (!this.ignoreLayoutWarnings) {\r\n Tools.Warn(\"Control (Name:\" + child.name + \", UniqueId:\" + child.uniqueId + \") is using width in percentage mode inside a horizontal StackPanel\");\r\n }\r\n }\r\n else {\r\n stackWidth += child._currentMeasure.width + child.paddingLeftInPixels + child.paddingRightInPixels;\r\n }\r\n }\r\n }\r\n stackWidth += this.paddingLeftInPixels + this.paddingRightInPixels;\r\n stackHeight += this.paddingTopInPixels + this.paddingBottomInPixels;\r\n this._doNotTrackManualChanges = true;\r\n // Let stack panel width or height default to stackHeight and stackWidth if dimensions are not specified.\r\n // User can now define their own height and width for stack panel.\r\n var panelWidthChanged = false;\r\n var panelHeightChanged = false;\r\n if (!this._manualHeight && this._isVertical) { // do not specify height if strictly defined by user\r\n var previousHeight = this.height;\r\n this.height = stackHeight + \"px\";\r\n panelHeightChanged = previousHeight !== this.height || !this._height.ignoreAdaptiveScaling;\r\n }\r\n if (!this._manualWidth && !this._isVertical) { // do not specify width if strictly defined by user\r\n var previousWidth = this.width;\r\n this.width = stackWidth + \"px\";\r\n panelWidthChanged = previousWidth !== this.width || !this._width.ignoreAdaptiveScaling;\r\n }\r\n if (panelHeightChanged) {\r\n this._height.ignoreAdaptiveScaling = true;\r\n }\r\n if (panelWidthChanged) {\r\n this._width.ignoreAdaptiveScaling = true;\r\n }\r\n this._doNotTrackManualChanges = false;\r\n if (panelWidthChanged || panelHeightChanged) {\r\n this._rebuildLayout = true;\r\n }\r\n _super.prototype._postMeasure.call(this);\r\n };\r\n return StackPanel;\r\n}(Container));\r\nexport { StackPanel };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.StackPanel\"] = StackPanel;\r\n//# sourceMappingURL=stackPanel.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { Control } from \"./control\";\r\nimport { StackPanel } from \"./stackPanel\";\r\nimport { TextBlock } from \"./textBlock\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to represent a 2D checkbox\r\n */\r\nvar Checkbox = /** @class */ (function (_super) {\r\n __extends(Checkbox, _super);\r\n /**\r\n * Creates a new CheckBox\r\n * @param name defines the control name\r\n */\r\n function Checkbox(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._isChecked = false;\r\n _this._background = \"black\";\r\n _this._checkSizeRatio = 0.8;\r\n _this._thickness = 1;\r\n /**\r\n * Observable raised when isChecked property changes\r\n */\r\n _this.onIsCheckedChangedObservable = new Observable();\r\n _this.isPointerBlocker = true;\r\n return _this;\r\n }\r\n Object.defineProperty(Checkbox.prototype, \"thickness\", {\r\n /** Gets or sets border thickness */\r\n get: function () {\r\n return this._thickness;\r\n },\r\n set: function (value) {\r\n if (this._thickness === value) {\r\n return;\r\n }\r\n this._thickness = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Checkbox.prototype, \"checkSizeRatio\", {\r\n /** Gets or sets a value indicating the ratio between overall size and check size */\r\n get: function () {\r\n return this._checkSizeRatio;\r\n },\r\n set: function (value) {\r\n value = Math.max(Math.min(1, value), 0);\r\n if (this._checkSizeRatio === value) {\r\n return;\r\n }\r\n this._checkSizeRatio = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Checkbox.prototype, \"background\", {\r\n /** Gets or sets background color */\r\n get: function () {\r\n return this._background;\r\n },\r\n set: function (value) {\r\n if (this._background === value) {\r\n return;\r\n }\r\n this._background = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Checkbox.prototype, \"isChecked\", {\r\n /** Gets or sets a boolean indicating if the checkbox is checked or not */\r\n get: function () {\r\n return this._isChecked;\r\n },\r\n set: function (value) {\r\n if (this._isChecked === value) {\r\n return;\r\n }\r\n this._isChecked = value;\r\n this._markAsDirty();\r\n this.onIsCheckedChangedObservable.notifyObservers(value);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Checkbox.prototype._getTypeName = function () {\r\n return \"Checkbox\";\r\n };\r\n /** @hidden */\r\n Checkbox.prototype._draw = function (context, invalidatedRectangle) {\r\n context.save();\r\n this._applyStates(context);\r\n var actualWidth = this._currentMeasure.width - this._thickness;\r\n var actualHeight = this._currentMeasure.height - this._thickness;\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n context.fillStyle = this._isEnabled ? this._background : this._disabledColor;\r\n context.fillRect(this._currentMeasure.left + this._thickness / 2, this._currentMeasure.top + this._thickness / 2, actualWidth, actualHeight);\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n if (this._isChecked) {\r\n context.fillStyle = this._isEnabled ? this.color : this._disabledColorItem;\r\n var offsetWidth = actualWidth * this._checkSizeRatio;\r\n var offseHeight = actualHeight * this._checkSizeRatio;\r\n context.fillRect(this._currentMeasure.left + this._thickness / 2 + (actualWidth - offsetWidth) / 2, this._currentMeasure.top + this._thickness / 2 + (actualHeight - offseHeight) / 2, offsetWidth, offseHeight);\r\n }\r\n context.strokeStyle = this.color;\r\n context.lineWidth = this._thickness;\r\n context.strokeRect(this._currentMeasure.left + this._thickness / 2, this._currentMeasure.top + this._thickness / 2, actualWidth, actualHeight);\r\n context.restore();\r\n };\r\n // Events\r\n /** @hidden */\r\n Checkbox.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex, pi) {\r\n if (!_super.prototype._onPointerDown.call(this, target, coordinates, pointerId, buttonIndex, pi)) {\r\n return false;\r\n }\r\n this.isChecked = !this.isChecked;\r\n return true;\r\n };\r\n /**\r\n * Utility function to easily create a checkbox with a header\r\n * @param title defines the label to use for the header\r\n * @param onValueChanged defines the callback to call when value changes\r\n * @returns a StackPanel containing the checkbox and a textBlock\r\n */\r\n Checkbox.AddCheckBoxWithHeader = function (title, onValueChanged) {\r\n var panel = new StackPanel();\r\n panel.isVertical = false;\r\n panel.height = \"30px\";\r\n var checkbox = new Checkbox();\r\n checkbox.width = \"20px\";\r\n checkbox.height = \"20px\";\r\n checkbox.isChecked = true;\r\n checkbox.color = \"green\";\r\n checkbox.onIsCheckedChangedObservable.add(onValueChanged);\r\n panel.addControl(checkbox);\r\n var header = new TextBlock();\r\n header.text = title;\r\n header.width = \"180px\";\r\n header.paddingLeft = \"5px\";\r\n header.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n header.color = \"white\";\r\n panel.addControl(header);\r\n return panel;\r\n };\r\n return Checkbox;\r\n}(Control));\r\nexport { Checkbox };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Checkbox\"] = Checkbox;\r\n//# sourceMappingURL=checkbox.js.map","import { __spreadArrays } from \"tslib\";\r\n/** @hidden */\r\nvar TextWrapper = /** @class */ (function () {\r\n function TextWrapper() {\r\n }\r\n Object.defineProperty(TextWrapper.prototype, \"text\", {\r\n get: function () {\r\n return this._characters ? this._characters.join(\"\") : this._text;\r\n },\r\n set: function (txt) {\r\n this._text = txt;\r\n this._characters = Array.from && Array.from(txt);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(TextWrapper.prototype, \"length\", {\r\n get: function () {\r\n return this._characters ? this._characters.length : this._text.length;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n TextWrapper.prototype.removePart = function (idxStart, idxEnd, insertTxt) {\r\n var _a;\r\n this._text = this._text.slice(0, idxStart) + (insertTxt ? insertTxt : \"\") + this._text.slice(idxEnd);\r\n if (this._characters) {\r\n var newCharacters = insertTxt ? Array.from(insertTxt) : [];\r\n (_a = this._characters).splice.apply(_a, __spreadArrays([idxStart, idxEnd - idxStart], newCharacters));\r\n }\r\n };\r\n TextWrapper.prototype.charAt = function (idx) {\r\n return this._characters ? this._characters[idx] : this._text.charAt(idx);\r\n };\r\n TextWrapper.prototype.substr = function (from, length) {\r\n if (this._characters) {\r\n if (isNaN(from)) {\r\n from = 0;\r\n }\r\n else if (from >= 0) {\r\n from = Math.min(from, this._characters.length);\r\n }\r\n else {\r\n from = this._characters.length + Math.max(from, -this._characters.length);\r\n }\r\n if (length === undefined) {\r\n length = this._characters.length - from;\r\n }\r\n else if (isNaN(length)) {\r\n length = 0;\r\n }\r\n else if (length < 0) {\r\n length = 0;\r\n }\r\n var temp = [];\r\n while (--length >= 0) {\r\n temp[length] = this._characters[from + length];\r\n }\r\n return temp.join(\"\");\r\n }\r\n return this._text.substr(from, length);\r\n };\r\n TextWrapper.prototype.substring = function (from, to) {\r\n if (this._characters) {\r\n if (isNaN(from)) {\r\n from = 0;\r\n }\r\n else if (from > this._characters.length) {\r\n from = this._characters.length;\r\n }\r\n else if (from < 0) {\r\n from = 0;\r\n }\r\n if (to === undefined) {\r\n to = this._characters.length;\r\n }\r\n else if (isNaN(to)) {\r\n to = 0;\r\n }\r\n else if (to > this._characters.length) {\r\n to = this._characters.length;\r\n }\r\n else if (to < 0) {\r\n to = 0;\r\n }\r\n var temp = [];\r\n var idx = 0;\r\n while (from < to) {\r\n temp[idx++] = this._characters[from++];\r\n }\r\n return temp.join(\"\");\r\n }\r\n return this._text.substring(from, to);\r\n };\r\n TextWrapper.prototype.isWord = function (index) {\r\n var rWord = /\\w/g;\r\n return this._characters ? this._characters[index].search(rWord) !== -1 : this._text.search(rWord) !== -1;\r\n };\r\n return TextWrapper;\r\n}());\r\nexport { TextWrapper };\r\n//# sourceMappingURL=textWrapper.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { ClipboardEventTypes } from \"@babylonjs/core/Events/clipboardEvents\";\r\nimport { PointerEventTypes } from '@babylonjs/core/Events/pointerEvents';\r\nimport { Control } from \"./control\";\r\nimport { ValueAndUnit } from \"../valueAndUnit\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\nimport { TextWrapper } from './textWrapper';\r\n/**\r\n * Class used to create input text control\r\n */\r\nvar InputText = /** @class */ (function (_super) {\r\n __extends(InputText, _super);\r\n /**\r\n * Creates a new InputText\r\n * @param name defines the control name\r\n * @param text defines the text of the control\r\n */\r\n function InputText(name, text) {\r\n if (text === void 0) { text = \"\"; }\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._placeholderText = \"\";\r\n _this._background = \"#222222\";\r\n _this._focusedBackground = \"#000000\";\r\n _this._focusedColor = \"white\";\r\n _this._placeholderColor = \"gray\";\r\n _this._thickness = 1;\r\n _this._margin = new ValueAndUnit(10, ValueAndUnit.UNITMODE_PIXEL);\r\n _this._autoStretchWidth = true;\r\n _this._maxWidth = new ValueAndUnit(1, ValueAndUnit.UNITMODE_PERCENTAGE, false);\r\n _this._isFocused = false;\r\n _this._blinkIsEven = false;\r\n _this._cursorOffset = 0;\r\n _this._deadKey = false;\r\n _this._addKey = true;\r\n _this._currentKey = \"\";\r\n _this._isTextHighlightOn = false;\r\n _this._textHighlightColor = \"#d5e0ff\";\r\n _this._highligherOpacity = 0.4;\r\n _this._highlightedText = \"\";\r\n _this._startHighlightIndex = 0;\r\n _this._endHighlightIndex = 0;\r\n _this._cursorIndex = -1;\r\n _this._onFocusSelectAll = false;\r\n _this._isPointerDown = false;\r\n /** Gets or sets a string representing the message displayed on mobile when the control gets the focus */\r\n _this.promptMessage = \"Please enter text:\";\r\n /** Force disable prompt on mobile device */\r\n _this.disableMobilePrompt = false;\r\n /** Observable raised when the text changes */\r\n _this.onTextChangedObservable = new Observable();\r\n /** Observable raised just before an entered character is to be added */\r\n _this.onBeforeKeyAddObservable = new Observable();\r\n /** Observable raised when the control gets the focus */\r\n _this.onFocusObservable = new Observable();\r\n /** Observable raised when the control loses the focus */\r\n _this.onBlurObservable = new Observable();\r\n /**Observable raised when the text is highlighted */\r\n _this.onTextHighlightObservable = new Observable();\r\n /**Observable raised when copy event is triggered */\r\n _this.onTextCopyObservable = new Observable();\r\n /** Observable raised when cut event is triggered */\r\n _this.onTextCutObservable = new Observable();\r\n /** Observable raised when paste event is triggered */\r\n _this.onTextPasteObservable = new Observable();\r\n /** Observable raised when a key event was processed */\r\n _this.onKeyboardEventProcessedObservable = new Observable();\r\n _this.text = text;\r\n _this.isPointerBlocker = true;\r\n return _this;\r\n }\r\n Object.defineProperty(InputText.prototype, \"maxWidth\", {\r\n /** Gets or sets the maximum width allowed by the control */\r\n get: function () {\r\n return this._maxWidth.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._maxWidth.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._maxWidth.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"maxWidthInPixels\", {\r\n /** Gets the maximum width allowed by the control in pixels */\r\n get: function () {\r\n return this._maxWidth.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"highligherOpacity\", {\r\n /** Gets or sets the text highlighter transparency; default: 0.4 */\r\n get: function () {\r\n return this._highligherOpacity;\r\n },\r\n set: function (value) {\r\n if (this._highligherOpacity === value) {\r\n return;\r\n }\r\n this._highligherOpacity = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"onFocusSelectAll\", {\r\n /** Gets or sets a boolean indicating whether to select complete text by default on input focus */\r\n get: function () {\r\n return this._onFocusSelectAll;\r\n },\r\n set: function (value) {\r\n if (this._onFocusSelectAll === value) {\r\n return;\r\n }\r\n this._onFocusSelectAll = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"textHighlightColor\", {\r\n /** Gets or sets the text hightlight color */\r\n get: function () {\r\n return this._textHighlightColor;\r\n },\r\n set: function (value) {\r\n if (this._textHighlightColor === value) {\r\n return;\r\n }\r\n this._textHighlightColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"margin\", {\r\n /** Gets or sets control margin */\r\n get: function () {\r\n return this._margin.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._margin.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._margin.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"marginInPixels\", {\r\n /** Gets control margin in pixels */\r\n get: function () {\r\n return this._margin.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"autoStretchWidth\", {\r\n /** Gets or sets a boolean indicating if the control can auto stretch its width to adapt to the text */\r\n get: function () {\r\n return this._autoStretchWidth;\r\n },\r\n set: function (value) {\r\n if (this._autoStretchWidth === value) {\r\n return;\r\n }\r\n this._autoStretchWidth = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"thickness\", {\r\n /** Gets or sets border thickness */\r\n get: function () {\r\n return this._thickness;\r\n },\r\n set: function (value) {\r\n if (this._thickness === value) {\r\n return;\r\n }\r\n this._thickness = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"focusedBackground\", {\r\n /** Gets or sets the background color when focused */\r\n get: function () {\r\n return this._focusedBackground;\r\n },\r\n set: function (value) {\r\n if (this._focusedBackground === value) {\r\n return;\r\n }\r\n this._focusedBackground = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"focusedColor\", {\r\n /** Gets or sets the background color when focused */\r\n get: function () {\r\n return this._focusedColor;\r\n },\r\n set: function (value) {\r\n if (this._focusedColor === value) {\r\n return;\r\n }\r\n this._focusedColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"background\", {\r\n /** Gets or sets the background color */\r\n get: function () {\r\n return this._background;\r\n },\r\n set: function (value) {\r\n if (this._background === value) {\r\n return;\r\n }\r\n this._background = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"placeholderColor\", {\r\n /** Gets or sets the placeholder color */\r\n get: function () {\r\n return this._placeholderColor;\r\n },\r\n set: function (value) {\r\n if (this._placeholderColor === value) {\r\n return;\r\n }\r\n this._placeholderColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"placeholderText\", {\r\n /** Gets or sets the text displayed when the control is empty */\r\n get: function () {\r\n return this._placeholderText;\r\n },\r\n set: function (value) {\r\n if (this._placeholderText === value) {\r\n return;\r\n }\r\n this._placeholderText = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"deadKey\", {\r\n /** Gets or sets the dead key flag */\r\n get: function () {\r\n return this._deadKey;\r\n },\r\n set: function (flag) {\r\n this._deadKey = flag;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"highlightedText\", {\r\n /** Gets or sets the highlight text */\r\n get: function () {\r\n return this._highlightedText;\r\n },\r\n set: function (text) {\r\n if (this._highlightedText === text) {\r\n return;\r\n }\r\n this._highlightedText = text;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"addKey\", {\r\n /** Gets or sets if the current key should be added */\r\n get: function () {\r\n return this._addKey;\r\n },\r\n set: function (flag) {\r\n this._addKey = flag;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"currentKey\", {\r\n /** Gets or sets the value of the current key being entered */\r\n get: function () {\r\n return this._currentKey;\r\n },\r\n set: function (key) {\r\n this._currentKey = key;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InputText.prototype, \"text\", {\r\n /** Gets or sets the text displayed in the control */\r\n get: function () {\r\n return this._textWrapper.text;\r\n },\r\n set: function (value) {\r\n var valueAsString = value.toString(); // Forcing convertion\r\n if (!this._textWrapper) {\r\n this._textWrapper = new TextWrapper();\r\n }\r\n if (this._textWrapper.text === valueAsString) {\r\n return;\r\n }\r\n this._textWrapper.text = valueAsString;\r\n this._textHasChanged();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n InputText.prototype._textHasChanged = function () {\r\n this._markAsDirty();\r\n this.onTextChangedObservable.notifyObservers(this);\r\n };\r\n Object.defineProperty(InputText.prototype, \"width\", {\r\n /** Gets or sets control width */\r\n get: function () {\r\n return this._width.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._width.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._width.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n this.autoStretchWidth = false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n InputText.prototype.onBlur = function () {\r\n this._isFocused = false;\r\n this._scrollLeft = null;\r\n this._cursorOffset = 0;\r\n clearTimeout(this._blinkTimeout);\r\n this._markAsDirty();\r\n this.onBlurObservable.notifyObservers(this);\r\n this._host.unRegisterClipboardEvents();\r\n if (this._onClipboardObserver) {\r\n this._host.onClipboardObservable.remove(this._onClipboardObserver);\r\n }\r\n var scene = this._host.getScene();\r\n if (this._onPointerDblTapObserver && scene) {\r\n scene.onPointerObservable.remove(this._onPointerDblTapObserver);\r\n }\r\n };\r\n /** @hidden */\r\n InputText.prototype.onFocus = function () {\r\n var _this = this;\r\n if (!this._isEnabled) {\r\n return;\r\n }\r\n this._scrollLeft = null;\r\n this._isFocused = true;\r\n this._blinkIsEven = false;\r\n this._cursorOffset = 0;\r\n this._markAsDirty();\r\n this.onFocusObservable.notifyObservers(this);\r\n if (navigator.userAgent.indexOf(\"Mobile\") !== -1 && !this.disableMobilePrompt) {\r\n var value = prompt(this.promptMessage);\r\n if (value !== null) {\r\n this.text = value;\r\n }\r\n this._host.focusedControl = null;\r\n return;\r\n }\r\n this._host.registerClipboardEvents();\r\n this._onClipboardObserver = this._host.onClipboardObservable.add(function (clipboardInfo) {\r\n // process clipboard event, can be configured.\r\n switch (clipboardInfo.type) {\r\n case ClipboardEventTypes.COPY:\r\n _this._onCopyText(clipboardInfo.event);\r\n _this.onTextCopyObservable.notifyObservers(_this);\r\n break;\r\n case ClipboardEventTypes.CUT:\r\n _this._onCutText(clipboardInfo.event);\r\n _this.onTextCutObservable.notifyObservers(_this);\r\n break;\r\n case ClipboardEventTypes.PASTE:\r\n _this._onPasteText(clipboardInfo.event);\r\n _this.onTextPasteObservable.notifyObservers(_this);\r\n break;\r\n default: return;\r\n }\r\n });\r\n var scene = this._host.getScene();\r\n if (scene) {\r\n //register the pointer double tap event\r\n this._onPointerDblTapObserver = scene.onPointerObservable.add(function (pointerInfo) {\r\n if (!_this._isFocused) {\r\n return;\r\n }\r\n if (pointerInfo.type === PointerEventTypes.POINTERDOUBLETAP) {\r\n _this._processDblClick(pointerInfo);\r\n }\r\n });\r\n }\r\n if (this._onFocusSelectAll) {\r\n this._selectAllText();\r\n }\r\n };\r\n InputText.prototype._getTypeName = function () {\r\n return \"InputText\";\r\n };\r\n /**\r\n * Function called to get the list of controls that should not steal the focus from this control\r\n * @returns an array of controls\r\n */\r\n InputText.prototype.keepsFocusWith = function () {\r\n if (!this._connectedVirtualKeyboard) {\r\n return null;\r\n }\r\n return [this._connectedVirtualKeyboard];\r\n };\r\n /** @hidden */\r\n InputText.prototype.processKey = function (keyCode, key, evt) {\r\n //return if clipboard event keys (i.e -ctr/cmd + c,v,x)\r\n if (evt && (evt.ctrlKey || evt.metaKey) && (keyCode === 67 || keyCode === 86 || keyCode === 88)) {\r\n return;\r\n }\r\n //select all\r\n if (evt && (evt.ctrlKey || evt.metaKey) && keyCode === 65) {\r\n this._selectAllText();\r\n evt.preventDefault();\r\n return;\r\n }\r\n // Specific cases\r\n switch (keyCode) {\r\n case 32: //SPACE\r\n key = \" \"; //ie11 key for space is \"Spacebar\"\r\n break;\r\n case 191: //SLASH\r\n if (evt) {\r\n evt.preventDefault();\r\n }\r\n break;\r\n case 8: // BACKSPACE\r\n if (this._textWrapper.text && this._textWrapper.length > 0) {\r\n //delete the highlighted text\r\n if (this._isTextHighlightOn) {\r\n this._textWrapper.removePart(this._startHighlightIndex, this._endHighlightIndex);\r\n this._textHasChanged();\r\n this._isTextHighlightOn = false;\r\n this._cursorOffset = this._textWrapper.length - this._startHighlightIndex;\r\n this._blinkIsEven = false;\r\n if (evt) {\r\n evt.preventDefault();\r\n }\r\n return;\r\n }\r\n //delete single character\r\n if (this._cursorOffset === 0) {\r\n this.text = this._textWrapper.substr(0, this._textWrapper.length - 1);\r\n }\r\n else {\r\n var deletePosition = this._textWrapper.length - this._cursorOffset;\r\n if (deletePosition > 0) {\r\n this._textWrapper.removePart(deletePosition - 1, deletePosition);\r\n this._textHasChanged();\r\n }\r\n }\r\n }\r\n if (evt) {\r\n evt.preventDefault();\r\n }\r\n return;\r\n case 46: // DELETE\r\n if (this._isTextHighlightOn) {\r\n this._textWrapper.removePart(this._startHighlightIndex, this._endHighlightIndex);\r\n this._textHasChanged();\r\n this._isTextHighlightOn = false;\r\n this._cursorOffset = this._textWrapper.length - this._startHighlightIndex;\r\n if (evt) {\r\n evt.preventDefault();\r\n }\r\n return;\r\n }\r\n if (this._textWrapper.text && this._textWrapper.length > 0 && this._cursorOffset > 0) {\r\n var deletePosition = this._textWrapper.length - this._cursorOffset;\r\n this._textWrapper.removePart(deletePosition, deletePosition + 1);\r\n this._textHasChanged();\r\n this._cursorOffset--;\r\n }\r\n if (evt) {\r\n evt.preventDefault();\r\n }\r\n return;\r\n case 13: // RETURN\r\n this._host.focusedControl = null;\r\n this._isTextHighlightOn = false;\r\n return;\r\n case 35: // END\r\n this._cursorOffset = 0;\r\n this._blinkIsEven = false;\r\n this._isTextHighlightOn = false;\r\n this._markAsDirty();\r\n return;\r\n case 36: // HOME\r\n this._cursorOffset = this._textWrapper.length;\r\n this._blinkIsEven = false;\r\n this._isTextHighlightOn = false;\r\n this._markAsDirty();\r\n return;\r\n case 37: // LEFT\r\n this._cursorOffset++;\r\n if (this._cursorOffset > this._textWrapper.length) {\r\n this._cursorOffset = this._textWrapper.length;\r\n }\r\n if (evt && evt.shiftKey) {\r\n // update the cursor\r\n this._blinkIsEven = false;\r\n // shift + ctrl/cmd + <-\r\n if (evt.ctrlKey || evt.metaKey) {\r\n if (!this._isTextHighlightOn) {\r\n if (this._textWrapper.length === this._cursorOffset) {\r\n return;\r\n }\r\n else {\r\n this._endHighlightIndex = this._textWrapper.length - this._cursorOffset + 1;\r\n }\r\n }\r\n this._startHighlightIndex = 0;\r\n this._cursorIndex = this._textWrapper.length - this._endHighlightIndex;\r\n this._cursorOffset = this._textWrapper.length;\r\n this._isTextHighlightOn = true;\r\n this._markAsDirty();\r\n return;\r\n }\r\n //store the starting point\r\n if (!this._isTextHighlightOn) {\r\n this._isTextHighlightOn = true;\r\n this._cursorIndex = (this._cursorOffset >= this._textWrapper.length) ? this._textWrapper.length : this._cursorOffset - 1;\r\n }\r\n //if text is already highlighted\r\n else if (this._cursorIndex === -1) {\r\n this._cursorIndex = this._textWrapper.length - this._endHighlightIndex;\r\n this._cursorOffset = (this._startHighlightIndex === 0) ? this._textWrapper.length : this._textWrapper.length - this._startHighlightIndex + 1;\r\n }\r\n //set the highlight indexes\r\n if (this._cursorIndex < this._cursorOffset) {\r\n this._endHighlightIndex = this._textWrapper.length - this._cursorIndex;\r\n this._startHighlightIndex = this._textWrapper.length - this._cursorOffset;\r\n }\r\n else if (this._cursorIndex > this._cursorOffset) {\r\n this._endHighlightIndex = this._textWrapper.length - this._cursorOffset;\r\n this._startHighlightIndex = this._textWrapper.length - this._cursorIndex;\r\n }\r\n else {\r\n this._isTextHighlightOn = false;\r\n }\r\n this._markAsDirty();\r\n return;\r\n }\r\n if (this._isTextHighlightOn) {\r\n this._cursorOffset = this._textWrapper.length - this._startHighlightIndex;\r\n this._isTextHighlightOn = false;\r\n }\r\n if (evt && (evt.ctrlKey || evt.metaKey)) {\r\n this._cursorOffset = this._textWrapper.length;\r\n evt.preventDefault();\r\n }\r\n this._blinkIsEven = false;\r\n this._isTextHighlightOn = false;\r\n this._cursorIndex = -1;\r\n this._markAsDirty();\r\n return;\r\n case 39: // RIGHT\r\n this._cursorOffset--;\r\n if (this._cursorOffset < 0) {\r\n this._cursorOffset = 0;\r\n }\r\n if (evt && evt.shiftKey) {\r\n //update the cursor\r\n this._blinkIsEven = false;\r\n //shift + ctrl/cmd + ->\r\n if (evt.ctrlKey || evt.metaKey) {\r\n if (!this._isTextHighlightOn) {\r\n if (this._cursorOffset === 0) {\r\n return;\r\n }\r\n else {\r\n this._startHighlightIndex = this._textWrapper.length - this._cursorOffset - 1;\r\n }\r\n }\r\n this._endHighlightIndex = this._textWrapper.length;\r\n this._isTextHighlightOn = true;\r\n this._cursorIndex = this._textWrapper.length - this._startHighlightIndex;\r\n this._cursorOffset = 0;\r\n this._markAsDirty();\r\n return;\r\n }\r\n if (!this._isTextHighlightOn) {\r\n this._isTextHighlightOn = true;\r\n this._cursorIndex = (this._cursorOffset <= 0) ? 0 : this._cursorOffset + 1;\r\n }\r\n //if text is already highlighted\r\n else if (this._cursorIndex === -1) {\r\n this._cursorIndex = this._textWrapper.length - this._startHighlightIndex;\r\n this._cursorOffset = (this._textWrapper.length === this._endHighlightIndex) ? 0 : this._textWrapper.length - this._endHighlightIndex - 1;\r\n }\r\n //set the highlight indexes\r\n if (this._cursorIndex < this._cursorOffset) {\r\n this._endHighlightIndex = this._textWrapper.length - this._cursorIndex;\r\n this._startHighlightIndex = this._textWrapper.length - this._cursorOffset;\r\n }\r\n else if (this._cursorIndex > this._cursorOffset) {\r\n this._endHighlightIndex = this._textWrapper.length - this._cursorOffset;\r\n this._startHighlightIndex = this._textWrapper.length - this._cursorIndex;\r\n }\r\n else {\r\n this._isTextHighlightOn = false;\r\n }\r\n this._markAsDirty();\r\n return;\r\n }\r\n if (this._isTextHighlightOn) {\r\n this._cursorOffset = this._textWrapper.length - this._endHighlightIndex;\r\n this._isTextHighlightOn = false;\r\n }\r\n //ctr + ->\r\n if (evt && (evt.ctrlKey || evt.metaKey)) {\r\n this._cursorOffset = 0;\r\n evt.preventDefault();\r\n }\r\n this._blinkIsEven = false;\r\n this._isTextHighlightOn = false;\r\n this._cursorIndex = -1;\r\n this._markAsDirty();\r\n return;\r\n case 222: // Dead\r\n if (evt) {\r\n evt.preventDefault();\r\n }\r\n this._cursorIndex = -1;\r\n this.deadKey = true;\r\n break;\r\n }\r\n // Printable characters\r\n if (key &&\r\n ((keyCode === -1) || // Direct access\r\n (keyCode === 32) || // Space\r\n (keyCode > 47 && keyCode < 64) || // Numbers\r\n (keyCode > 64 && keyCode < 91) || // Letters\r\n (keyCode > 159 && keyCode < 193) || // Special characters\r\n (keyCode > 218 && keyCode < 223) || // Special characters\r\n (keyCode > 95 && keyCode < 112))) { // Numpad\r\n this._currentKey = key;\r\n this.onBeforeKeyAddObservable.notifyObservers(this);\r\n key = this._currentKey;\r\n if (this._addKey) {\r\n if (this._isTextHighlightOn) {\r\n this._textWrapper.removePart(this._startHighlightIndex, this._endHighlightIndex, key);\r\n this._textHasChanged();\r\n this._cursorOffset = this._textWrapper.length - (this._startHighlightIndex + 1);\r\n this._isTextHighlightOn = false;\r\n this._blinkIsEven = false;\r\n this._markAsDirty();\r\n }\r\n else if (this._cursorOffset === 0) {\r\n this.text += key;\r\n }\r\n else {\r\n var insertPosition = this._textWrapper.length - this._cursorOffset;\r\n this._textWrapper.removePart(insertPosition, insertPosition, key);\r\n this._textHasChanged();\r\n }\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n InputText.prototype._updateValueFromCursorIndex = function (offset) {\r\n //update the cursor\r\n this._blinkIsEven = false;\r\n if (this._cursorIndex === -1) {\r\n this._cursorIndex = offset;\r\n }\r\n else {\r\n if (this._cursorIndex < this._cursorOffset) {\r\n this._endHighlightIndex = this._textWrapper.length - this._cursorIndex;\r\n this._startHighlightIndex = this._textWrapper.length - this._cursorOffset;\r\n }\r\n else if (this._cursorIndex > this._cursorOffset) {\r\n this._endHighlightIndex = this._textWrapper.length - this._cursorOffset;\r\n this._startHighlightIndex = this._textWrapper.length - this._cursorIndex;\r\n }\r\n else {\r\n this._isTextHighlightOn = false;\r\n this._markAsDirty();\r\n return;\r\n }\r\n }\r\n this._isTextHighlightOn = true;\r\n this._markAsDirty();\r\n };\r\n /** @hidden */\r\n InputText.prototype._processDblClick = function (evt) {\r\n //pre-find the start and end index of the word under cursor, speeds up the rendering\r\n this._startHighlightIndex = this._textWrapper.length - this._cursorOffset;\r\n this._endHighlightIndex = this._startHighlightIndex;\r\n var moveLeft, moveRight;\r\n do {\r\n moveRight = this._endHighlightIndex < this._textWrapper.length && this._textWrapper.isWord(this._endHighlightIndex) ? ++this._endHighlightIndex : 0;\r\n moveLeft = this._startHighlightIndex > 0 && this._textWrapper.isWord(this._startHighlightIndex - 1) ? --this._startHighlightIndex : 0;\r\n } while (moveLeft || moveRight);\r\n this._cursorOffset = this._textWrapper.length - this._startHighlightIndex;\r\n this.onTextHighlightObservable.notifyObservers(this);\r\n this._isTextHighlightOn = true;\r\n this._clickedCoordinate = null;\r\n this._blinkIsEven = true;\r\n this._cursorIndex = -1;\r\n this._markAsDirty();\r\n };\r\n /** @hidden */\r\n InputText.prototype._selectAllText = function () {\r\n this._blinkIsEven = true;\r\n this._isTextHighlightOn = true;\r\n this._startHighlightIndex = 0;\r\n this._endHighlightIndex = this._textWrapper.length;\r\n this._cursorOffset = this._textWrapper.length;\r\n this._cursorIndex = -1;\r\n this._markAsDirty();\r\n };\r\n /**\r\n * Handles the keyboard event\r\n * @param evt Defines the KeyboardEvent\r\n */\r\n InputText.prototype.processKeyboard = function (evt) {\r\n // process pressed key\r\n this.processKey(evt.keyCode, evt.key, evt);\r\n this.onKeyboardEventProcessedObservable.notifyObservers(evt);\r\n };\r\n /** @hidden */\r\n InputText.prototype._onCopyText = function (ev) {\r\n this._isTextHighlightOn = false;\r\n //when write permission to clipbaord data is denied\r\n try {\r\n ev.clipboardData && ev.clipboardData.setData(\"text/plain\", this._highlightedText);\r\n }\r\n catch (_a) { } //pass\r\n this._host.clipboardData = this._highlightedText;\r\n };\r\n /** @hidden */\r\n InputText.prototype._onCutText = function (ev) {\r\n if (!this._highlightedText) {\r\n return;\r\n }\r\n this._textWrapper.removePart(this._startHighlightIndex, this._endHighlightIndex);\r\n this._textHasChanged();\r\n this._isTextHighlightOn = false;\r\n this._cursorOffset = this._textWrapper.length - this._startHighlightIndex;\r\n //when write permission to clipbaord data is denied\r\n try {\r\n ev.clipboardData && ev.clipboardData.setData(\"text/plain\", this._highlightedText);\r\n }\r\n catch (_a) { } //pass\r\n this._host.clipboardData = this._highlightedText;\r\n this._highlightedText = \"\";\r\n };\r\n /** @hidden */\r\n InputText.prototype._onPasteText = function (ev) {\r\n var data = \"\";\r\n if (ev.clipboardData && ev.clipboardData.types.indexOf(\"text/plain\") !== -1) {\r\n data = ev.clipboardData.getData(\"text/plain\");\r\n }\r\n else {\r\n //get the cached data; returns blank string by default\r\n data = this._host.clipboardData;\r\n }\r\n var insertPosition = this._textWrapper.length - this._cursorOffset;\r\n this._textWrapper.removePart(insertPosition, insertPosition, data);\r\n this._textHasChanged();\r\n };\r\n InputText.prototype._draw = function (context, invalidatedRectangle) {\r\n var _this = this;\r\n context.save();\r\n this._applyStates(context);\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n // Background\r\n if (this._isFocused) {\r\n if (this._focusedBackground) {\r\n context.fillStyle = this._isEnabled ? this._focusedBackground : this._disabledColor;\r\n context.fillRect(this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n }\r\n }\r\n else if (this._background) {\r\n context.fillStyle = this._isEnabled ? this._background : this._disabledColor;\r\n context.fillRect(this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n }\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n if (!this._fontOffset) {\r\n this._fontOffset = Control._GetFontOffset(context.font);\r\n }\r\n // Text\r\n var clipTextLeft = this._currentMeasure.left + this._margin.getValueInPixel(this._host, this._tempParentMeasure.width);\r\n if (this.color) {\r\n context.fillStyle = this.color;\r\n }\r\n var text = this._beforeRenderText(this._textWrapper);\r\n if (!this._isFocused && !this._textWrapper.text && this._placeholderText) {\r\n text = new TextWrapper();\r\n text.text = this._placeholderText;\r\n if (this._placeholderColor) {\r\n context.fillStyle = this._placeholderColor;\r\n }\r\n }\r\n this._textWidth = context.measureText(text.text).width;\r\n var marginWidth = this._margin.getValueInPixel(this._host, this._tempParentMeasure.width) * 2;\r\n if (this._autoStretchWidth) {\r\n this.width = Math.min(this._maxWidth.getValueInPixel(this._host, this._tempParentMeasure.width), this._textWidth + marginWidth) + \"px\";\r\n }\r\n var rootY = this._fontOffset.ascent + (this._currentMeasure.height - this._fontOffset.height) / 2;\r\n var availableWidth = this._width.getValueInPixel(this._host, this._tempParentMeasure.width) - marginWidth;\r\n context.save();\r\n context.beginPath();\r\n context.rect(clipTextLeft, this._currentMeasure.top + (this._currentMeasure.height - this._fontOffset.height) / 2, availableWidth + 2, this._currentMeasure.height);\r\n context.clip();\r\n if (this._isFocused && this._textWidth > availableWidth) {\r\n var textLeft = clipTextLeft - this._textWidth + availableWidth;\r\n if (!this._scrollLeft) {\r\n this._scrollLeft = textLeft;\r\n }\r\n }\r\n else {\r\n this._scrollLeft = clipTextLeft;\r\n }\r\n context.fillText(text.text, this._scrollLeft, this._currentMeasure.top + rootY);\r\n // Cursor\r\n if (this._isFocused) {\r\n // Need to move cursor\r\n if (this._clickedCoordinate) {\r\n var rightPosition = this._scrollLeft + this._textWidth;\r\n var absoluteCursorPosition = rightPosition - this._clickedCoordinate;\r\n var currentSize = 0;\r\n this._cursorOffset = 0;\r\n var previousDist = 0;\r\n do {\r\n if (this._cursorOffset) {\r\n previousDist = Math.abs(absoluteCursorPosition - currentSize);\r\n }\r\n this._cursorOffset++;\r\n currentSize = context.measureText(text.substr(text.length - this._cursorOffset, this._cursorOffset)).width;\r\n } while (currentSize < absoluteCursorPosition && (text.length >= this._cursorOffset));\r\n // Find closest move\r\n if (Math.abs(absoluteCursorPosition - currentSize) > previousDist) {\r\n this._cursorOffset--;\r\n }\r\n this._blinkIsEven = false;\r\n this._clickedCoordinate = null;\r\n }\r\n // Render cursor\r\n if (!this._blinkIsEven) {\r\n var cursorOffsetText = text.substr(text.length - this._cursorOffset);\r\n var cursorOffsetWidth = context.measureText(cursorOffsetText).width;\r\n var cursorLeft = this._scrollLeft + this._textWidth - cursorOffsetWidth;\r\n if (cursorLeft < clipTextLeft) {\r\n this._scrollLeft += (clipTextLeft - cursorLeft);\r\n cursorLeft = clipTextLeft;\r\n this._markAsDirty();\r\n }\r\n else if (cursorLeft > clipTextLeft + availableWidth) {\r\n this._scrollLeft += (clipTextLeft + availableWidth - cursorLeft);\r\n cursorLeft = clipTextLeft + availableWidth;\r\n this._markAsDirty();\r\n }\r\n if (!this._isTextHighlightOn) {\r\n context.fillRect(cursorLeft, this._currentMeasure.top + (this._currentMeasure.height - this._fontOffset.height) / 2, 2, this._fontOffset.height);\r\n }\r\n }\r\n clearTimeout(this._blinkTimeout);\r\n this._blinkTimeout = setTimeout(function () {\r\n _this._blinkIsEven = !_this._blinkIsEven;\r\n _this._markAsDirty();\r\n }, 500);\r\n //show the highlighted text\r\n if (this._isTextHighlightOn) {\r\n clearTimeout(this._blinkTimeout);\r\n var highlightCursorOffsetWidth = context.measureText(text.substring(this._startHighlightIndex)).width;\r\n var highlightCursorLeft = this._scrollLeft + this._textWidth - highlightCursorOffsetWidth;\r\n this._highlightedText = text.substring(this._startHighlightIndex, this._endHighlightIndex);\r\n var width = context.measureText(text.substring(this._startHighlightIndex, this._endHighlightIndex)).width;\r\n if (highlightCursorLeft < clipTextLeft) {\r\n width = width - (clipTextLeft - highlightCursorLeft);\r\n if (!width) {\r\n // when using left arrow on text.length > availableWidth;\r\n // assigns the width of the first letter after clipTextLeft\r\n width = context.measureText(text.charAt(text.length - this._cursorOffset)).width;\r\n }\r\n highlightCursorLeft = clipTextLeft;\r\n }\r\n //for transparancy\r\n context.globalAlpha = this._highligherOpacity;\r\n context.fillStyle = this._textHighlightColor;\r\n context.fillRect(highlightCursorLeft, this._currentMeasure.top + (this._currentMeasure.height - this._fontOffset.height) / 2, width, this._fontOffset.height);\r\n context.globalAlpha = 1.0;\r\n }\r\n }\r\n context.restore();\r\n // Border\r\n if (this._thickness) {\r\n if (this._isFocused) {\r\n if (this.focusedColor) {\r\n context.strokeStyle = this.focusedColor;\r\n }\r\n }\r\n else {\r\n if (this.color) {\r\n context.strokeStyle = this.color;\r\n }\r\n }\r\n context.lineWidth = this._thickness;\r\n context.strokeRect(this._currentMeasure.left + this._thickness / 2, this._currentMeasure.top + this._thickness / 2, this._currentMeasure.width - this._thickness, this._currentMeasure.height - this._thickness);\r\n }\r\n context.restore();\r\n };\r\n InputText.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex, pi) {\r\n if (!_super.prototype._onPointerDown.call(this, target, coordinates, pointerId, buttonIndex, pi)) {\r\n return false;\r\n }\r\n this._clickedCoordinate = coordinates.x;\r\n this._isTextHighlightOn = false;\r\n this._highlightedText = \"\";\r\n this._cursorIndex = -1;\r\n this._isPointerDown = true;\r\n this._host._capturingControl[pointerId] = this;\r\n if (this._host.focusedControl === this) {\r\n // Move cursor\r\n clearTimeout(this._blinkTimeout);\r\n this._markAsDirty();\r\n return true;\r\n }\r\n if (!this._isEnabled) {\r\n return false;\r\n }\r\n this._host.focusedControl = this;\r\n return true;\r\n };\r\n InputText.prototype._onPointerMove = function (target, coordinates, pointerId, pi) {\r\n if (this._host.focusedControl === this && this._isPointerDown) {\r\n this._clickedCoordinate = coordinates.x;\r\n this._markAsDirty();\r\n this._updateValueFromCursorIndex(this._cursorOffset);\r\n }\r\n _super.prototype._onPointerMove.call(this, target, coordinates, pointerId, pi);\r\n };\r\n InputText.prototype._onPointerUp = function (target, coordinates, pointerId, buttonIndex, notifyClick) {\r\n this._isPointerDown = false;\r\n delete this._host._capturingControl[pointerId];\r\n _super.prototype._onPointerUp.call(this, target, coordinates, pointerId, buttonIndex, notifyClick);\r\n };\r\n InputText.prototype._beforeRenderText = function (textWrapper) {\r\n return textWrapper;\r\n };\r\n InputText.prototype.dispose = function () {\r\n _super.prototype.dispose.call(this);\r\n this.onBlurObservable.clear();\r\n this.onFocusObservable.clear();\r\n this.onTextChangedObservable.clear();\r\n this.onTextCopyObservable.clear();\r\n this.onTextCutObservable.clear();\r\n this.onTextPasteObservable.clear();\r\n this.onTextHighlightObservable.clear();\r\n this.onKeyboardEventProcessedObservable.clear();\r\n };\r\n return InputText;\r\n}(Control));\r\nexport { InputText };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.InputText\"] = InputText;\r\n//# sourceMappingURL=inputText.js.map","import { __extends } from \"tslib\";\r\nimport { Container } from \"./container\";\r\nimport { ValueAndUnit } from \"../valueAndUnit\";\r\nimport { Control } from \"./control\";\r\nimport { Tools } from '@babylonjs/core/Misc/tools';\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create a 2D grid container\r\n */\r\nvar Grid = /** @class */ (function (_super) {\r\n __extends(Grid, _super);\r\n /**\r\n * Creates a new Grid\r\n * @param name defines control name\r\n */\r\n function Grid(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._rowDefinitions = new Array();\r\n _this._columnDefinitions = new Array();\r\n _this._cells = {};\r\n _this._childControls = new Array();\r\n return _this;\r\n }\r\n Object.defineProperty(Grid.prototype, \"columnCount\", {\r\n /**\r\n * Gets the number of columns\r\n */\r\n get: function () {\r\n return this._columnDefinitions.length;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Grid.prototype, \"rowCount\", {\r\n /**\r\n * Gets the number of rows\r\n */\r\n get: function () {\r\n return this._rowDefinitions.length;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Grid.prototype, \"children\", {\r\n /** Gets the list of children */\r\n get: function () {\r\n return this._childControls;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Grid.prototype, \"cells\", {\r\n /** Gets the list of cells (e.g. the containers) */\r\n get: function () {\r\n return this._cells;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the definition of a specific row\r\n * @param index defines the index of the row\r\n * @returns the row definition\r\n */\r\n Grid.prototype.getRowDefinition = function (index) {\r\n if (index < 0 || index >= this._rowDefinitions.length) {\r\n return null;\r\n }\r\n return this._rowDefinitions[index];\r\n };\r\n /**\r\n * Gets the definition of a specific column\r\n * @param index defines the index of the column\r\n * @returns the column definition\r\n */\r\n Grid.prototype.getColumnDefinition = function (index) {\r\n if (index < 0 || index >= this._columnDefinitions.length) {\r\n return null;\r\n }\r\n return this._columnDefinitions[index];\r\n };\r\n /**\r\n * Adds a new row to the grid\r\n * @param height defines the height of the row (either in pixel or a value between 0 and 1)\r\n * @param isPixel defines if the height is expressed in pixel (or in percentage)\r\n * @returns the current grid\r\n */\r\n Grid.prototype.addRowDefinition = function (height, isPixel) {\r\n if (isPixel === void 0) { isPixel = false; }\r\n this._rowDefinitions.push(new ValueAndUnit(height, isPixel ? ValueAndUnit.UNITMODE_PIXEL : ValueAndUnit.UNITMODE_PERCENTAGE));\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /**\r\n * Adds a new column to the grid\r\n * @param width defines the width of the column (either in pixel or a value between 0 and 1)\r\n * @param isPixel defines if the width is expressed in pixel (or in percentage)\r\n * @returns the current grid\r\n */\r\n Grid.prototype.addColumnDefinition = function (width, isPixel) {\r\n if (isPixel === void 0) { isPixel = false; }\r\n this._columnDefinitions.push(new ValueAndUnit(width, isPixel ? ValueAndUnit.UNITMODE_PIXEL : ValueAndUnit.UNITMODE_PERCENTAGE));\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /**\r\n * Update a row definition\r\n * @param index defines the index of the row to update\r\n * @param height defines the height of the row (either in pixel or a value between 0 and 1)\r\n * @param isPixel defines if the weight is expressed in pixel (or in percentage)\r\n * @returns the current grid\r\n */\r\n Grid.prototype.setRowDefinition = function (index, height, isPixel) {\r\n if (isPixel === void 0) { isPixel = false; }\r\n if (index < 0 || index >= this._rowDefinitions.length) {\r\n return this;\r\n }\r\n var current = this._rowDefinitions[index];\r\n if (current && current.isPixel === isPixel && current.internalValue === height) {\r\n return this;\r\n }\r\n this._rowDefinitions[index] = new ValueAndUnit(height, isPixel ? ValueAndUnit.UNITMODE_PIXEL : ValueAndUnit.UNITMODE_PERCENTAGE);\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /**\r\n * Update a column definition\r\n * @param index defines the index of the column to update\r\n * @param width defines the width of the column (either in pixel or a value between 0 and 1)\r\n * @param isPixel defines if the width is expressed in pixel (or in percentage)\r\n * @returns the current grid\r\n */\r\n Grid.prototype.setColumnDefinition = function (index, width, isPixel) {\r\n if (isPixel === void 0) { isPixel = false; }\r\n if (index < 0 || index >= this._columnDefinitions.length) {\r\n return this;\r\n }\r\n var current = this._columnDefinitions[index];\r\n if (current && current.isPixel === isPixel && current.internalValue === width) {\r\n return this;\r\n }\r\n this._columnDefinitions[index] = new ValueAndUnit(width, isPixel ? ValueAndUnit.UNITMODE_PIXEL : ValueAndUnit.UNITMODE_PERCENTAGE);\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /**\r\n * Gets the list of children stored in a specific cell\r\n * @param row defines the row to check\r\n * @param column defines the column to check\r\n * @returns the list of controls\r\n */\r\n Grid.prototype.getChildrenAt = function (row, column) {\r\n var cell = this._cells[row + \":\" + column];\r\n if (!cell) {\r\n return null;\r\n }\r\n return cell.children;\r\n };\r\n /**\r\n * Gets a string representing the child cell info (row x column)\r\n * @param child defines the control to get info from\r\n * @returns a string containing the child cell info (row x column)\r\n */\r\n Grid.prototype.getChildCellInfo = function (child) {\r\n return child._tag;\r\n };\r\n Grid.prototype._removeCell = function (cell, key) {\r\n if (!cell) {\r\n return;\r\n }\r\n _super.prototype.removeControl.call(this, cell);\r\n for (var _i = 0, _a = cell.children; _i < _a.length; _i++) {\r\n var control = _a[_i];\r\n var childIndex = this._childControls.indexOf(control);\r\n if (childIndex !== -1) {\r\n this._childControls.splice(childIndex, 1);\r\n }\r\n }\r\n delete this._cells[key];\r\n };\r\n Grid.prototype._offsetCell = function (previousKey, key) {\r\n if (!this._cells[key]) {\r\n return;\r\n }\r\n this._cells[previousKey] = this._cells[key];\r\n for (var _i = 0, _a = this._cells[previousKey].children; _i < _a.length; _i++) {\r\n var control = _a[_i];\r\n control._tag = previousKey;\r\n }\r\n delete this._cells[key];\r\n };\r\n /**\r\n * Remove a column definition at specified index\r\n * @param index defines the index of the column to remove\r\n * @returns the current grid\r\n */\r\n Grid.prototype.removeColumnDefinition = function (index) {\r\n if (index < 0 || index >= this._columnDefinitions.length) {\r\n return this;\r\n }\r\n for (var x = 0; x < this._rowDefinitions.length; x++) {\r\n var key = x + \":\" + index;\r\n var cell = this._cells[key];\r\n this._removeCell(cell, key);\r\n }\r\n for (var x = 0; x < this._rowDefinitions.length; x++) {\r\n for (var y = index + 1; y < this._columnDefinitions.length; y++) {\r\n var previousKey = x + \":\" + (y - 1);\r\n var key = x + \":\" + y;\r\n this._offsetCell(previousKey, key);\r\n }\r\n }\r\n this._columnDefinitions.splice(index, 1);\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /**\r\n * Remove a row definition at specified index\r\n * @param index defines the index of the row to remove\r\n * @returns the current grid\r\n */\r\n Grid.prototype.removeRowDefinition = function (index) {\r\n if (index < 0 || index >= this._rowDefinitions.length) {\r\n return this;\r\n }\r\n for (var y = 0; y < this._columnDefinitions.length; y++) {\r\n var key = index + \":\" + y;\r\n var cell = this._cells[key];\r\n this._removeCell(cell, key);\r\n }\r\n for (var y = 0; y < this._columnDefinitions.length; y++) {\r\n for (var x = index + 1; x < this._rowDefinitions.length; x++) {\r\n var previousKey = x - 1 + \":\" + y;\r\n var key = x + \":\" + y;\r\n this._offsetCell(previousKey, key);\r\n }\r\n }\r\n this._rowDefinitions.splice(index, 1);\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /**\r\n * Adds a new control to the current grid\r\n * @param control defines the control to add\r\n * @param row defines the row where to add the control (0 by default)\r\n * @param column defines the column where to add the control (0 by default)\r\n * @returns the current grid\r\n */\r\n Grid.prototype.addControl = function (control, row, column) {\r\n if (row === void 0) { row = 0; }\r\n if (column === void 0) { column = 0; }\r\n if (this._rowDefinitions.length === 0) {\r\n // Add default row definition\r\n this.addRowDefinition(1, false);\r\n }\r\n if (this._columnDefinitions.length === 0) {\r\n // Add default column definition\r\n this.addColumnDefinition(1, false);\r\n }\r\n if (this._childControls.indexOf(control) !== -1) {\r\n Tools.Warn(\"Control (Name:\" + control.name + \", UniqueId:\" + control.uniqueId + \") is already associated with this grid. You must remove it before reattaching it\");\r\n return this;\r\n }\r\n var x = Math.min(row, this._rowDefinitions.length - 1);\r\n var y = Math.min(column, this._columnDefinitions.length - 1);\r\n var key = x + \":\" + y;\r\n var goodContainer = this._cells[key];\r\n if (!goodContainer) {\r\n goodContainer = new Container(key);\r\n this._cells[key] = goodContainer;\r\n goodContainer.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n goodContainer.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n _super.prototype.addControl.call(this, goodContainer);\r\n }\r\n goodContainer.addControl(control);\r\n this._childControls.push(control);\r\n control._tag = key;\r\n control.parent = this;\r\n this._markAsDirty();\r\n return this;\r\n };\r\n /**\r\n * Removes a control from the current container\r\n * @param control defines the control to remove\r\n * @returns the current container\r\n */\r\n Grid.prototype.removeControl = function (control) {\r\n var index = this._childControls.indexOf(control);\r\n if (index !== -1) {\r\n this._childControls.splice(index, 1);\r\n }\r\n var cell = this._cells[control._tag];\r\n if (cell) {\r\n cell.removeControl(control);\r\n control._tag = null;\r\n }\r\n this._markAsDirty();\r\n return this;\r\n };\r\n Grid.prototype._getTypeName = function () {\r\n return \"Grid\";\r\n };\r\n Grid.prototype._getGridDefinitions = function (definitionCallback) {\r\n var widths = [];\r\n var heights = [];\r\n var lefts = [];\r\n var tops = [];\r\n var availableWidth = this._currentMeasure.width;\r\n var globalWidthPercentage = 0;\r\n var availableHeight = this._currentMeasure.height;\r\n var globalHeightPercentage = 0;\r\n // Heights\r\n var index = 0;\r\n for (var _i = 0, _a = this._rowDefinitions; _i < _a.length; _i++) {\r\n var value = _a[_i];\r\n if (value.isPixel) {\r\n var height = value.getValue(this._host);\r\n availableHeight -= height;\r\n heights[index] = height;\r\n }\r\n else {\r\n globalHeightPercentage += value.internalValue;\r\n }\r\n index++;\r\n }\r\n var top = 0;\r\n index = 0;\r\n for (var _b = 0, _c = this._rowDefinitions; _b < _c.length; _b++) {\r\n var value = _c[_b];\r\n tops.push(top);\r\n if (!value.isPixel) {\r\n var height = (value.internalValue / globalHeightPercentage) * availableHeight;\r\n top += height;\r\n heights[index] = height;\r\n }\r\n else {\r\n top += value.getValue(this._host);\r\n }\r\n index++;\r\n }\r\n // Widths\r\n index = 0;\r\n for (var _d = 0, _e = this._columnDefinitions; _d < _e.length; _d++) {\r\n var value = _e[_d];\r\n if (value.isPixel) {\r\n var width = value.getValue(this._host);\r\n availableWidth -= width;\r\n widths[index] = width;\r\n }\r\n else {\r\n globalWidthPercentage += value.internalValue;\r\n }\r\n index++;\r\n }\r\n var left = 0;\r\n index = 0;\r\n for (var _f = 0, _g = this._columnDefinitions; _f < _g.length; _f++) {\r\n var value = _g[_f];\r\n lefts.push(left);\r\n if (!value.isPixel) {\r\n var width = (value.internalValue / globalWidthPercentage) * availableWidth;\r\n left += width;\r\n widths[index] = width;\r\n }\r\n else {\r\n left += value.getValue(this._host);\r\n }\r\n index++;\r\n }\r\n definitionCallback(lefts, tops, widths, heights);\r\n };\r\n Grid.prototype._additionalProcessing = function (parentMeasure, context) {\r\n var _this = this;\r\n this._getGridDefinitions(function (lefts, tops, widths, heights) {\r\n // Setting child sizes\r\n for (var key in _this._cells) {\r\n if (!_this._cells.hasOwnProperty(key)) {\r\n continue;\r\n }\r\n var split = key.split(\":\");\r\n var x = parseInt(split[0]);\r\n var y = parseInt(split[1]);\r\n var cell = _this._cells[key];\r\n cell.left = lefts[y] + \"px\";\r\n cell.top = tops[x] + \"px\";\r\n cell.width = widths[y] + \"px\";\r\n cell.height = heights[x] + \"px\";\r\n cell._left.ignoreAdaptiveScaling = true;\r\n cell._top.ignoreAdaptiveScaling = true;\r\n cell._width.ignoreAdaptiveScaling = true;\r\n cell._height.ignoreAdaptiveScaling = true;\r\n }\r\n });\r\n _super.prototype._additionalProcessing.call(this, parentMeasure, context);\r\n };\r\n Grid.prototype._flagDescendantsAsMatrixDirty = function () {\r\n for (var key in this._cells) {\r\n if (!this._cells.hasOwnProperty(key)) {\r\n continue;\r\n }\r\n var child = this._cells[key];\r\n child._markMatrixAsDirty();\r\n }\r\n };\r\n Grid.prototype._renderHighlightSpecific = function (context) {\r\n var _this = this;\r\n _super.prototype._renderHighlightSpecific.call(this, context);\r\n this._getGridDefinitions(function (lefts, tops, widths, heights) {\r\n // Columns\r\n for (var index = 0; index < lefts.length; index++) {\r\n var left = _this._currentMeasure.left + lefts[index] + widths[index];\r\n context.beginPath();\r\n context.moveTo(left, _this._currentMeasure.top);\r\n context.lineTo(left, _this._currentMeasure.top + _this._currentMeasure.height);\r\n context.stroke();\r\n }\r\n // Rows\r\n for (var index = 0; index < tops.length; index++) {\r\n var top_1 = _this._currentMeasure.top + tops[index] + heights[index];\r\n context.beginPath();\r\n context.moveTo(_this._currentMeasure.left, top_1);\r\n context.lineTo(_this._currentMeasure.left + _this._currentMeasure.width, top_1);\r\n context.stroke();\r\n }\r\n });\r\n context.restore();\r\n };\r\n /** Releases associated resources */\r\n Grid.prototype.dispose = function () {\r\n _super.prototype.dispose.call(this);\r\n for (var _i = 0, _a = this._childControls; _i < _a.length; _i++) {\r\n var control = _a[_i];\r\n control.dispose();\r\n }\r\n this._childControls = [];\r\n };\r\n return Grid;\r\n}(Container));\r\nexport { Grid };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Grid\"] = Grid;\r\n//# sourceMappingURL=grid.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { Control } from \"./control\";\r\nimport { InputText } from \"./inputText\";\r\nimport { Rectangle } from \"./rectangle\";\r\nimport { Button } from \"./button\";\r\nimport { Grid } from \"./grid\";\r\nimport { TextBlock } from \"../controls/textBlock\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\nimport { Color3 } from '@babylonjs/core/Maths/math.color';\r\n/** Class used to create color pickers */\r\nvar ColorPicker = /** @class */ (function (_super) {\r\n __extends(ColorPicker, _super);\r\n /**\r\n * Creates a new ColorPicker\r\n * @param name defines the control name\r\n */\r\n function ColorPicker(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._value = Color3.Red();\r\n _this._tmpColor = new Color3();\r\n _this._pointerStartedOnSquare = false;\r\n _this._pointerStartedOnWheel = false;\r\n _this._squareLeft = 0;\r\n _this._squareTop = 0;\r\n _this._squareSize = 0;\r\n _this._h = 360;\r\n _this._s = 1;\r\n _this._v = 1;\r\n _this._lastPointerDownID = -1;\r\n /**\r\n * Observable raised when the value changes\r\n */\r\n _this.onValueChangedObservable = new Observable();\r\n // Events\r\n _this._pointerIsDown = false;\r\n _this.value = new Color3(.88, .1, .1);\r\n _this.size = \"200px\";\r\n _this.isPointerBlocker = true;\r\n return _this;\r\n }\r\n Object.defineProperty(ColorPicker.prototype, \"value\", {\r\n /** Gets or sets the color of the color picker */\r\n get: function () {\r\n return this._value;\r\n },\r\n set: function (value) {\r\n if (this._value.equals(value)) {\r\n return;\r\n }\r\n this._value.copyFrom(value);\r\n this._value.toHSVToRef(this._tmpColor);\r\n this._h = this._tmpColor.r;\r\n this._s = Math.max(this._tmpColor.g, 0.00001);\r\n this._v = Math.max(this._tmpColor.b, 0.00001);\r\n this._markAsDirty();\r\n if (this._value.r <= ColorPicker._Epsilon) {\r\n this._value.r = 0;\r\n }\r\n if (this._value.g <= ColorPicker._Epsilon) {\r\n this._value.g = 0;\r\n }\r\n if (this._value.b <= ColorPicker._Epsilon) {\r\n this._value.b = 0;\r\n }\r\n if (this._value.r >= 1.0 - ColorPicker._Epsilon) {\r\n this._value.r = 1.0;\r\n }\r\n if (this._value.g >= 1.0 - ColorPicker._Epsilon) {\r\n this._value.g = 1.0;\r\n }\r\n if (this._value.b >= 1.0 - ColorPicker._Epsilon) {\r\n this._value.b = 1.0;\r\n }\r\n this.onValueChangedObservable.notifyObservers(this._value);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorPicker.prototype, \"width\", {\r\n /**\r\n * Gets or sets control width\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._width.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._width.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._width.fromString(value)) {\r\n this._height.fromString(value);\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorPicker.prototype, \"height\", {\r\n /**\r\n * Gets or sets control height\r\n * @see https://doc.babylonjs.com/how_to/gui#position-and-size\r\n */\r\n get: function () {\r\n return this._height.toString(this._host);\r\n },\r\n /** Gets or sets control height */\r\n set: function (value) {\r\n if (this._height.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._height.fromString(value)) {\r\n this._width.fromString(value);\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ColorPicker.prototype, \"size\", {\r\n /** Gets or sets control size */\r\n get: function () {\r\n return this.width;\r\n },\r\n set: function (value) {\r\n this.width = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n ColorPicker.prototype._getTypeName = function () {\r\n return \"ColorPicker\";\r\n };\r\n /** @hidden */\r\n ColorPicker.prototype._preMeasure = function (parentMeasure, context) {\r\n if (parentMeasure.width < parentMeasure.height) {\r\n this._currentMeasure.height = parentMeasure.width;\r\n }\r\n else {\r\n this._currentMeasure.width = parentMeasure.height;\r\n }\r\n };\r\n ColorPicker.prototype._updateSquareProps = function () {\r\n var radius = Math.min(this._currentMeasure.width, this._currentMeasure.height) * .5;\r\n var wheelThickness = radius * .2;\r\n var innerDiameter = (radius - wheelThickness) * 2;\r\n var squareSize = innerDiameter / (Math.sqrt(2));\r\n var offset = radius - squareSize * .5;\r\n this._squareLeft = this._currentMeasure.left + offset;\r\n this._squareTop = this._currentMeasure.top + offset;\r\n this._squareSize = squareSize;\r\n };\r\n ColorPicker.prototype._drawGradientSquare = function (hueValue, left, top, width, height, context) {\r\n var lgh = context.createLinearGradient(left, top, width + left, top);\r\n lgh.addColorStop(0, '#fff');\r\n lgh.addColorStop(1, 'hsl(' + hueValue + ', 100%, 50%)');\r\n context.fillStyle = lgh;\r\n context.fillRect(left, top, width, height);\r\n var lgv = context.createLinearGradient(left, top, left, height + top);\r\n lgv.addColorStop(0, 'rgba(0,0,0,0)');\r\n lgv.addColorStop(1, '#000');\r\n context.fillStyle = lgv;\r\n context.fillRect(left, top, width, height);\r\n };\r\n ColorPicker.prototype._drawCircle = function (centerX, centerY, radius, context) {\r\n context.beginPath();\r\n context.arc(centerX, centerY, radius + 1, 0, 2 * Math.PI, false);\r\n context.lineWidth = 3;\r\n context.strokeStyle = '#333333';\r\n context.stroke();\r\n context.beginPath();\r\n context.arc(centerX, centerY, radius, 0, 2 * Math.PI, false);\r\n context.lineWidth = 3;\r\n context.strokeStyle = '#ffffff';\r\n context.stroke();\r\n };\r\n ColorPicker.prototype._createColorWheelCanvas = function (radius, thickness) {\r\n var canvas = document.createElement(\"canvas\");\r\n canvas.width = radius * 2;\r\n canvas.height = radius * 2;\r\n var context = canvas.getContext(\"2d\");\r\n var image = context.getImageData(0, 0, radius * 2, radius * 2);\r\n var data = image.data;\r\n var color = this._tmpColor;\r\n var maxDistSq = radius * radius;\r\n var innerRadius = radius - thickness;\r\n var minDistSq = innerRadius * innerRadius;\r\n for (var x = -radius; x < radius; x++) {\r\n for (var y = -radius; y < radius; y++) {\r\n var distSq = x * x + y * y;\r\n if (distSq > maxDistSq || distSq < minDistSq) {\r\n continue;\r\n }\r\n var dist = Math.sqrt(distSq);\r\n var ang = Math.atan2(y, x);\r\n Color3.HSVtoRGBToRef(ang * 180 / Math.PI + 180, dist / radius, 1, color);\r\n var index = ((x + radius) + ((y + radius) * 2 * radius)) * 4;\r\n data[index] = color.r * 255;\r\n data[index + 1] = color.g * 255;\r\n data[index + 2] = color.b * 255;\r\n var alphaRatio = (dist - innerRadius) / (radius - innerRadius);\r\n //apply less alpha to bigger color pickers\r\n var alphaAmount = .2;\r\n var maxAlpha = .2;\r\n var minAlpha = .04;\r\n var lowerRadius = 50;\r\n var upperRadius = 150;\r\n if (radius < lowerRadius) {\r\n alphaAmount = maxAlpha;\r\n }\r\n else if (radius > upperRadius) {\r\n alphaAmount = minAlpha;\r\n }\r\n else {\r\n alphaAmount = (minAlpha - maxAlpha) * (radius - lowerRadius) / (upperRadius - lowerRadius) + maxAlpha;\r\n }\r\n var alphaRatio = (dist - innerRadius) / (radius - innerRadius);\r\n if (alphaRatio < alphaAmount) {\r\n data[index + 3] = 255 * (alphaRatio / alphaAmount);\r\n }\r\n else if (alphaRatio > 1 - alphaAmount) {\r\n data[index + 3] = 255 * (1.0 - ((alphaRatio - (1 - alphaAmount)) / alphaAmount));\r\n }\r\n else {\r\n data[index + 3] = 255;\r\n }\r\n }\r\n }\r\n context.putImageData(image, 0, 0);\r\n return canvas;\r\n };\r\n /** @hidden */\r\n ColorPicker.prototype._draw = function (context) {\r\n context.save();\r\n this._applyStates(context);\r\n var radius = Math.min(this._currentMeasure.width, this._currentMeasure.height) * .5;\r\n var wheelThickness = radius * .2;\r\n var left = this._currentMeasure.left;\r\n var top = this._currentMeasure.top;\r\n if (!this._colorWheelCanvas || this._colorWheelCanvas.width != radius * 2) {\r\n this._colorWheelCanvas = this._createColorWheelCanvas(radius, wheelThickness);\r\n }\r\n this._updateSquareProps();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n context.fillRect(this._squareLeft, this._squareTop, this._squareSize, this._squareSize);\r\n }\r\n context.drawImage(this._colorWheelCanvas, left, top);\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n this._drawGradientSquare(this._h, this._squareLeft, this._squareTop, this._squareSize, this._squareSize, context);\r\n var cx = this._squareLeft + this._squareSize * this._s;\r\n var cy = this._squareTop + this._squareSize * (1 - this._v);\r\n this._drawCircle(cx, cy, radius * .04, context);\r\n var dist = radius - wheelThickness * .5;\r\n cx = left + radius + Math.cos((this._h - 180) * Math.PI / 180) * dist;\r\n cy = top + radius + Math.sin((this._h - 180) * Math.PI / 180) * dist;\r\n this._drawCircle(cx, cy, wheelThickness * .35, context);\r\n context.restore();\r\n };\r\n ColorPicker.prototype._updateValueFromPointer = function (x, y) {\r\n if (this._pointerStartedOnWheel) {\r\n var radius = Math.min(this._currentMeasure.width, this._currentMeasure.height) * .5;\r\n var centerX = radius + this._currentMeasure.left;\r\n var centerY = radius + this._currentMeasure.top;\r\n this._h = Math.atan2(y - centerY, x - centerX) * 180 / Math.PI + 180;\r\n }\r\n else if (this._pointerStartedOnSquare) {\r\n this._updateSquareProps();\r\n this._s = (x - this._squareLeft) / this._squareSize;\r\n this._v = 1 - (y - this._squareTop) / this._squareSize;\r\n this._s = Math.min(this._s, 1);\r\n this._s = Math.max(this._s, ColorPicker._Epsilon);\r\n this._v = Math.min(this._v, 1);\r\n this._v = Math.max(this._v, ColorPicker._Epsilon);\r\n }\r\n Color3.HSVtoRGBToRef(this._h, this._s, this._v, this._tmpColor);\r\n this.value = this._tmpColor;\r\n };\r\n ColorPicker.prototype._isPointOnSquare = function (x, y) {\r\n this._updateSquareProps();\r\n var left = this._squareLeft;\r\n var top = this._squareTop;\r\n var size = this._squareSize;\r\n if (x >= left && x <= left + size &&\r\n y >= top && y <= top + size) {\r\n return true;\r\n }\r\n return false;\r\n };\r\n ColorPicker.prototype._isPointOnWheel = function (x, y) {\r\n var radius = Math.min(this._currentMeasure.width, this._currentMeasure.height) * .5;\r\n var centerX = radius + this._currentMeasure.left;\r\n var centerY = radius + this._currentMeasure.top;\r\n var wheelThickness = radius * .2;\r\n var innerRadius = radius - wheelThickness;\r\n var radiusSq = radius * radius;\r\n var innerRadiusSq = innerRadius * innerRadius;\r\n var dx = x - centerX;\r\n var dy = y - centerY;\r\n var distSq = dx * dx + dy * dy;\r\n if (distSq <= radiusSq && distSq >= innerRadiusSq) {\r\n return true;\r\n }\r\n return false;\r\n };\r\n ColorPicker.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex, pi) {\r\n if (!_super.prototype._onPointerDown.call(this, target, coordinates, pointerId, buttonIndex, pi)) {\r\n return false;\r\n }\r\n this._pointerIsDown = true;\r\n this._pointerStartedOnSquare = false;\r\n this._pointerStartedOnWheel = false;\r\n // Invert transform\r\n this._invertTransformMatrix.transformCoordinates(coordinates.x, coordinates.y, this._transformedPosition);\r\n var x = this._transformedPosition.x;\r\n var y = this._transformedPosition.y;\r\n if (this._isPointOnSquare(x, y)) {\r\n this._pointerStartedOnSquare = true;\r\n }\r\n else if (this._isPointOnWheel(x, y)) {\r\n this._pointerStartedOnWheel = true;\r\n }\r\n this._updateValueFromPointer(x, y);\r\n this._host._capturingControl[pointerId] = this;\r\n this._lastPointerDownID = pointerId;\r\n return true;\r\n };\r\n ColorPicker.prototype._onPointerMove = function (target, coordinates, pointerId, pi) {\r\n // Only listen to pointer move events coming from the last pointer to click on the element (To support dual vr controller interaction)\r\n if (pointerId != this._lastPointerDownID) {\r\n return;\r\n }\r\n // Invert transform\r\n this._invertTransformMatrix.transformCoordinates(coordinates.x, coordinates.y, this._transformedPosition);\r\n var x = this._transformedPosition.x;\r\n var y = this._transformedPosition.y;\r\n if (this._pointerIsDown) {\r\n this._updateValueFromPointer(x, y);\r\n }\r\n _super.prototype._onPointerMove.call(this, target, coordinates, pointerId, pi);\r\n };\r\n ColorPicker.prototype._onPointerUp = function (target, coordinates, pointerId, buttonIndex, notifyClick, pi) {\r\n this._pointerIsDown = false;\r\n delete this._host._capturingControl[pointerId];\r\n _super.prototype._onPointerUp.call(this, target, coordinates, pointerId, buttonIndex, notifyClick, pi);\r\n };\r\n ColorPicker.prototype._onCanvasBlur = function () {\r\n this._forcePointerUp();\r\n _super.prototype._onCanvasBlur.call(this);\r\n };\r\n /**\r\n * This function expands the color picker by creating a color picker dialog with manual\r\n * color value input and the ability to save colors into an array to be used later in\r\n * subsequent launches of the dialogue.\r\n * @param advancedTexture defines the AdvancedDynamicTexture the dialog is assigned to\r\n * @param options defines size for dialog and options for saved colors. Also accepts last color picked as hex string and saved colors array as hex strings.\r\n * @returns picked color as a hex string and the saved colors array as hex strings.\r\n */\r\n ColorPicker.ShowPickerDialogAsync = function (advancedTexture, options) {\r\n return new Promise(function (resolve, reject) {\r\n // Default options\r\n options.pickerWidth = options.pickerWidth || \"640px\";\r\n options.pickerHeight = options.pickerHeight || \"400px\";\r\n options.headerHeight = options.headerHeight || \"35px\";\r\n options.lastColor = options.lastColor || \"#000000\";\r\n options.swatchLimit = options.swatchLimit || 20;\r\n options.numSwatchesPerLine = options.numSwatchesPerLine || 10;\r\n // Window size settings\r\n var drawerMaxRows = options.swatchLimit / options.numSwatchesPerLine;\r\n var rawSwatchSize = parseFloat(options.pickerWidth) / options.numSwatchesPerLine;\r\n var gutterSize = Math.floor(rawSwatchSize * 0.25);\r\n var colGutters = gutterSize * (options.numSwatchesPerLine + 1);\r\n var swatchSize = Math.floor((parseFloat(options.pickerWidth) - colGutters) / options.numSwatchesPerLine);\r\n var drawerMaxSize = (swatchSize * drawerMaxRows) + (gutterSize * (drawerMaxRows + 1));\r\n var containerSize = (parseInt(options.pickerHeight) + drawerMaxSize + Math.floor(swatchSize * 0.25)).toString() + \"px\";\r\n // Button Colors\r\n var buttonColor = \"#c0c0c0\";\r\n var buttonBackgroundColor = \"#535353\";\r\n var buttonBackgroundHoverColor = \"#414141\";\r\n var buttonBackgroundClickColor = \"515151\";\r\n var buttonDisabledColor = \"#555555\";\r\n var buttonDisabledBackgroundColor = \"#454545\";\r\n var currentSwatchesOutlineColor = \"#404040\";\r\n var luminanceLimitColor = Color3.FromHexString(\"#dddddd\");\r\n var luminanceLimit = luminanceLimitColor.r + luminanceLimitColor.g + luminanceLimitColor.b;\r\n var iconColorDark = \"#aaaaaa\";\r\n var iconColorLight = \"#ffffff\";\r\n var closeIconColor;\r\n // Button settings\r\n var buttonFontSize;\r\n var butEdit;\r\n var buttonWidth;\r\n var buttonHeight;\r\n // Input Text Colors\r\n var inputFieldLabels = [\"R\", \"G\", \"B\"];\r\n var inputTextBackgroundColor = \"#454545\";\r\n var inputTextColor = \"#f0f0f0\";\r\n // This is the current color as set by either the picker or by entering a value\r\n var currentColor;\r\n // This int is used for naming swatches and serves as the index for calling them from the list\r\n var swatchNumber;\r\n // Menu Panel options. We need to know if the swatchDrawer exists so we can create it if needed.\r\n var swatchDrawer;\r\n var editSwatchMode = false;\r\n // Color InputText fields that will be updated upon value change\r\n var picker;\r\n var rValInt;\r\n var gValInt;\r\n var bValInt;\r\n var rValDec;\r\n var gValDec;\r\n var bValDec;\r\n var hexVal;\r\n var newSwatch;\r\n var lastVal;\r\n var activeField;\r\n /**\r\n * Will update all values for InputText and ColorPicker controls based on the BABYLON.Color3 passed to this function.\r\n * Each InputText control and the ColorPicker control will be tested to see if they are the activeField and if they\r\n * are will receive no update. This is to prevent the input from the user being overwritten.\r\n */\r\n function updateValues(value, inputField) {\r\n activeField = inputField;\r\n var pickedColor = value.toHexString();\r\n newSwatch.background = pickedColor;\r\n if (rValInt.name != activeField) {\r\n rValInt.text = Math.floor(value.r * 255).toString();\r\n }\r\n if (gValInt.name != activeField) {\r\n gValInt.text = Math.floor(value.g * 255).toString();\r\n }\r\n if (bValInt.name != activeField) {\r\n bValInt.text = Math.floor(value.b * 255).toString();\r\n }\r\n if (rValDec.name != activeField) {\r\n rValDec.text = value.r.toString();\r\n }\r\n if (gValDec.name != activeField) {\r\n gValDec.text = value.g.toString();\r\n }\r\n if (bValDec.name != activeField) {\r\n bValDec.text = value.b.toString();\r\n }\r\n if (hexVal.name != activeField) {\r\n var minusPound = pickedColor.split(\"#\");\r\n hexVal.text = minusPound[1];\r\n }\r\n if (picker.name != activeField) {\r\n picker.value = value;\r\n }\r\n }\r\n // When the user enters an integer for R, G, or B we check to make sure it is a valid number and replace if not.\r\n function updateInt(field, channel) {\r\n var newValue = field.text;\r\n var checkVal = /[^0-9]/g.test(newValue);\r\n if (checkVal) {\r\n field.text = lastVal;\r\n return;\r\n }\r\n else {\r\n if (newValue != \"\") {\r\n if (Math.floor(parseInt(newValue)) < 0) {\r\n newValue = \"0\";\r\n }\r\n else if (Math.floor(parseInt(newValue)) > 255) {\r\n newValue = \"255\";\r\n }\r\n else if (isNaN(parseInt(newValue))) {\r\n newValue = \"0\";\r\n }\r\n }\r\n if (activeField == field.name) {\r\n lastVal = newValue;\r\n }\r\n }\r\n if (newValue != \"\") {\r\n newValue = parseInt(newValue).toString();\r\n field.text = newValue;\r\n var newSwatchRGB = Color3.FromHexString(newSwatch.background);\r\n if (activeField == field.name) {\r\n if (channel == \"r\") {\r\n updateValues(new Color3((parseInt(newValue)) / 255, newSwatchRGB.g, newSwatchRGB.b), field.name);\r\n }\r\n else if (channel == \"g\") {\r\n updateValues(new Color3(newSwatchRGB.r, (parseInt(newValue)) / 255, newSwatchRGB.b), field.name);\r\n }\r\n else {\r\n updateValues(new Color3(newSwatchRGB.r, newSwatchRGB.g, (parseInt(newValue)) / 255), field.name);\r\n }\r\n }\r\n }\r\n }\r\n // When the user enters a float for R, G, or B we check to make sure it is a valid number and replace if not.\r\n function updateFloat(field, channel) {\r\n var newValue = field.text;\r\n var checkVal = /[^0-9\\.]/g.test(newValue);\r\n if (checkVal) {\r\n field.text = lastVal;\r\n return;\r\n }\r\n else {\r\n if (newValue != \"\" && newValue != \".\" && parseFloat(newValue) != 0) {\r\n if (parseFloat(newValue) < 0.0) {\r\n newValue = \"0.0\";\r\n }\r\n else if (parseFloat(newValue) > 1.0) {\r\n newValue = \"1.0\";\r\n }\r\n else if (isNaN(parseFloat(newValue))) {\r\n newValue = \"0.0\";\r\n }\r\n }\r\n if (activeField == field.name) {\r\n lastVal = newValue;\r\n }\r\n }\r\n if (newValue != \"\" && newValue != \".\" && parseFloat(newValue) != 0) {\r\n newValue = parseFloat(newValue).toString();\r\n field.text = newValue;\r\n }\r\n else {\r\n newValue = \"0.0\";\r\n }\r\n var newSwatchRGB = Color3.FromHexString(newSwatch.background);\r\n if (activeField == field.name) {\r\n if (channel == \"r\") {\r\n updateValues(new Color3(parseFloat(newValue), newSwatchRGB.g, newSwatchRGB.b), field.name);\r\n }\r\n else if (channel == \"g\") {\r\n updateValues(new Color3(newSwatchRGB.r, parseFloat(newValue), newSwatchRGB.b), field.name);\r\n }\r\n else {\r\n updateValues(new Color3(newSwatchRGB.r, newSwatchRGB.g, parseFloat(newValue)), field.name);\r\n }\r\n }\r\n }\r\n // Removes the current index from the savedColors array. Drawer can then be regenerated.\r\n function deleteSwatch(index) {\r\n if (options.savedColors) {\r\n options.savedColors.splice(index, 1);\r\n }\r\n if (options.savedColors && options.savedColors.length == 0) {\r\n setEditButtonVisibility(false);\r\n editSwatchMode = false;\r\n }\r\n }\r\n // Creates and styles an individual swatch when updateSwatches is called.\r\n function createSwatch() {\r\n if (options.savedColors && options.savedColors[swatchNumber]) {\r\n if (editSwatchMode) {\r\n var icon = \"b\";\r\n }\r\n else {\r\n var icon = \"\";\r\n }\r\n var swatch = Button.CreateSimpleButton(\"Swatch_\" + swatchNumber, icon);\r\n swatch.fontFamily = \"BabylonJSglyphs\";\r\n var swatchColor = Color3.FromHexString(options.savedColors[swatchNumber]);\r\n var swatchLuminence = swatchColor.r + swatchColor.g + swatchColor.b;\r\n // Set color of outline and textBlock based on luminance of the color swatch so feedback always visible\r\n if (swatchLuminence > luminanceLimit) {\r\n swatch.color = iconColorDark;\r\n }\r\n else {\r\n swatch.color = iconColorLight;\r\n }\r\n swatch.fontSize = Math.floor(swatchSize * 0.7);\r\n swatch.textBlock.verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n swatch.height = swatch.width = (swatchSize).toString() + \"px\";\r\n swatch.background = options.savedColors[swatchNumber];\r\n swatch.thickness = 2;\r\n var metadata_1 = swatchNumber;\r\n swatch.pointerDownAnimation = function () {\r\n swatch.thickness = 4;\r\n };\r\n swatch.pointerUpAnimation = function () {\r\n swatch.thickness = 3;\r\n };\r\n swatch.pointerEnterAnimation = function () {\r\n swatch.thickness = 3;\r\n };\r\n swatch.pointerOutAnimation = function () {\r\n swatch.thickness = 2;\r\n };\r\n swatch.onPointerClickObservable.add(function () {\r\n if (!editSwatchMode) {\r\n if (options.savedColors) {\r\n updateValues(Color3.FromHexString(options.savedColors[metadata_1]), swatch.name);\r\n }\r\n }\r\n else {\r\n deleteSwatch(metadata_1);\r\n updateSwatches(\"\", butSave);\r\n }\r\n });\r\n return swatch;\r\n }\r\n else {\r\n return null;\r\n }\r\n }\r\n // Mode switch to render button text and close symbols on swatch controls\r\n function editSwatches(mode) {\r\n if (mode !== undefined) {\r\n editSwatchMode = mode;\r\n }\r\n if (editSwatchMode) {\r\n for (var i = 0; i < swatchDrawer.children.length; i++) {\r\n var thisButton = swatchDrawer.children[i];\r\n thisButton.textBlock.text = \"b\";\r\n }\r\n if (butEdit !== undefined) {\r\n butEdit.textBlock.text = \"Done\";\r\n }\r\n }\r\n else {\r\n for (var i = 0; i < swatchDrawer.children.length; i++) {\r\n var thisButton = swatchDrawer.children[i];\r\n thisButton.textBlock.text = \"\";\r\n }\r\n if (butEdit !== undefined) {\r\n butEdit.textBlock.text = \"Edit\";\r\n }\r\n }\r\n }\r\n /**\r\n * When Save Color button is pressed this function will first create a swatch drawer if one is not already\r\n * made. Then all controls are removed from the drawer and we step through the savedColors array and\r\n * creates one swatch per color. It will also set the height of the drawer control based on how many\r\n * saved colors there are and how many can be stored per row.\r\n */\r\n function updateSwatches(color, button) {\r\n if (options.savedColors) {\r\n if (color != \"\") {\r\n options.savedColors.push(color);\r\n }\r\n swatchNumber = 0;\r\n swatchDrawer.clearControls();\r\n var rowCount = Math.ceil(options.savedColors.length / options.numSwatchesPerLine);\r\n if (rowCount == 0) {\r\n var gutterCount = 0;\r\n }\r\n else {\r\n var gutterCount = rowCount + 1;\r\n }\r\n if (swatchDrawer.rowCount != rowCount + gutterCount) {\r\n var currentRows = swatchDrawer.rowCount;\r\n for (var i = 0; i < currentRows; i++) {\r\n swatchDrawer.removeRowDefinition(0);\r\n }\r\n for (var i = 0; i < rowCount + gutterCount; i++) {\r\n if (i % 2) {\r\n swatchDrawer.addRowDefinition(swatchSize, true);\r\n }\r\n else {\r\n swatchDrawer.addRowDefinition(gutterSize, true);\r\n }\r\n }\r\n }\r\n swatchDrawer.height = ((swatchSize * rowCount) + (gutterCount * gutterSize)).toString() + \"px\";\r\n for (var y = 1, thisRow = 1; y < rowCount + gutterCount; y += 2, thisRow++) {\r\n // Determine number of buttons to create per row based on the button limit per row and number of saved colors\r\n if (options.savedColors.length > thisRow * options.numSwatchesPerLine) {\r\n var totalButtonsThisRow = options.numSwatchesPerLine;\r\n }\r\n else {\r\n var totalButtonsThisRow = options.savedColors.length - ((thisRow - 1) * options.numSwatchesPerLine);\r\n }\r\n var buttonIterations = (Math.min(Math.max(totalButtonsThisRow, 0), options.numSwatchesPerLine));\r\n for (var x = 0, w = 1; x < buttonIterations; x++) {\r\n if (x > options.numSwatchesPerLine) {\r\n continue;\r\n }\r\n var swatch = createSwatch();\r\n if (swatch != null) {\r\n swatchDrawer.addControl(swatch, y, w);\r\n w += 2;\r\n swatchNumber++;\r\n }\r\n else {\r\n continue;\r\n }\r\n }\r\n }\r\n if (options.savedColors.length >= options.swatchLimit) {\r\n disableButton(button, true);\r\n }\r\n else {\r\n disableButton(button, false);\r\n }\r\n }\r\n }\r\n // Shows or hides edit swatches button depending on if there are saved swatches\r\n function setEditButtonVisibility(enableButton) {\r\n if (enableButton) {\r\n butEdit = Button.CreateSimpleButton(\"butEdit\", \"Edit\");\r\n butEdit.width = buttonWidth;\r\n butEdit.height = buttonHeight;\r\n butEdit.left = (Math.floor(parseInt(buttonWidth) * 0.1)).toString() + \"px\";\r\n butEdit.top = (parseFloat(butEdit.left) * -1).toString() + \"px\";\r\n butEdit.verticalAlignment = Control.VERTICAL_ALIGNMENT_BOTTOM;\r\n butEdit.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n butEdit.thickness = 2;\r\n butEdit.color = buttonColor;\r\n butEdit.fontSize = buttonFontSize;\r\n butEdit.background = buttonBackgroundColor;\r\n butEdit.onPointerEnterObservable.add(function () {\r\n butEdit.background = buttonBackgroundHoverColor;\r\n });\r\n butEdit.onPointerOutObservable.add(function () {\r\n butEdit.background = buttonBackgroundColor;\r\n });\r\n butEdit.pointerDownAnimation = function () {\r\n butEdit.background = buttonBackgroundClickColor;\r\n };\r\n butEdit.pointerUpAnimation = function () {\r\n butEdit.background = buttonBackgroundHoverColor;\r\n };\r\n butEdit.onPointerClickObservable.add(function () {\r\n if (editSwatchMode) {\r\n editSwatchMode = false;\r\n }\r\n else {\r\n editSwatchMode = true;\r\n }\r\n editSwatches();\r\n });\r\n pickerGrid.addControl(butEdit, 1, 0);\r\n }\r\n else {\r\n pickerGrid.removeControl(butEdit);\r\n }\r\n }\r\n // Called when the user hits the limit of saved colors in the drawer.\r\n function disableButton(button, disabled) {\r\n if (disabled) {\r\n button.color = buttonDisabledColor;\r\n button.background = buttonDisabledBackgroundColor;\r\n }\r\n else {\r\n button.color = buttonColor;\r\n button.background = buttonBackgroundColor;\r\n }\r\n }\r\n // Passes last chosen color back to scene and kills dialog by removing from AdvancedDynamicTexture\r\n function closePicker(color) {\r\n if (options.savedColors && options.savedColors.length > 0) {\r\n resolve({\r\n savedColors: options.savedColors,\r\n pickedColor: color\r\n });\r\n }\r\n else {\r\n resolve({\r\n pickedColor: color\r\n });\r\n }\r\n advancedTexture.removeControl(dialogContainer);\r\n }\r\n // Dialogue menu container which will contain both the main dialogue window and the swatch drawer which opens once a color is saved.\r\n var dialogContainer = new Grid();\r\n dialogContainer.name = \"Dialog Container\";\r\n dialogContainer.width = options.pickerWidth;\r\n if (options.savedColors) {\r\n dialogContainer.height = containerSize;\r\n var topRow = parseInt(options.pickerHeight) / parseInt(containerSize);\r\n dialogContainer.addRowDefinition(topRow, false);\r\n dialogContainer.addRowDefinition(1.0 - topRow, false);\r\n }\r\n else {\r\n dialogContainer.height = options.pickerHeight;\r\n dialogContainer.addRowDefinition(1.0, false);\r\n }\r\n advancedTexture.addControl(dialogContainer);\r\n // Swatch drawer which contains all saved color buttons\r\n if (options.savedColors) {\r\n swatchDrawer = new Grid();\r\n swatchDrawer.name = \"Swatch Drawer\";\r\n swatchDrawer.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n swatchDrawer.background = buttonBackgroundColor;\r\n swatchDrawer.width = options.pickerWidth;\r\n var initialRows = options.savedColors.length / options.numSwatchesPerLine;\r\n if (initialRows == 0) {\r\n var gutterCount = 0;\r\n }\r\n else {\r\n var gutterCount = initialRows + 1;\r\n }\r\n swatchDrawer.height = ((swatchSize * initialRows) + (gutterCount * gutterSize)).toString() + \"px\";\r\n swatchDrawer.top = Math.floor(swatchSize * 0.25).toString() + \"px\";\r\n for (var i = 0; i < (Math.ceil(options.savedColors.length / options.numSwatchesPerLine) * 2) + 1; i++) {\r\n if (i % 2 != 0) {\r\n swatchDrawer.addRowDefinition(swatchSize, true);\r\n }\r\n else {\r\n swatchDrawer.addRowDefinition(gutterSize, true);\r\n }\r\n }\r\n for (var i = 0; i < options.numSwatchesPerLine * 2 + 1; i++) {\r\n if (i % 2 != 0) {\r\n swatchDrawer.addColumnDefinition(swatchSize, true);\r\n }\r\n else {\r\n swatchDrawer.addColumnDefinition(gutterSize, true);\r\n }\r\n }\r\n dialogContainer.addControl(swatchDrawer, 1, 0);\r\n }\r\n // Picker container\r\n var pickerPanel = new Grid();\r\n pickerPanel.name = \"Picker Panel\";\r\n pickerPanel.height = options.pickerHeight;\r\n var panelHead = parseInt(options.headerHeight) / parseInt(options.pickerHeight);\r\n var pickerPanelRows = [panelHead, 1.0 - panelHead];\r\n pickerPanel.addRowDefinition(pickerPanelRows[0], false);\r\n pickerPanel.addRowDefinition(pickerPanelRows[1], false);\r\n dialogContainer.addControl(pickerPanel, 0, 0);\r\n // Picker container header\r\n var header = new Rectangle();\r\n header.name = \"Dialogue Header Bar\";\r\n header.background = \"#cccccc\";\r\n header.thickness = 0;\r\n pickerPanel.addControl(header, 0, 0);\r\n // Header close button\r\n var closeButton = Button.CreateSimpleButton(\"closeButton\", \"a\");\r\n closeButton.fontFamily = \"BabylonJSglyphs\";\r\n var headerColor3 = Color3.FromHexString(header.background);\r\n closeIconColor = new Color3(1.0 - headerColor3.r, 1.0 - headerColor3.g, 1.0 - headerColor3.b);\r\n closeButton.color = closeIconColor.toHexString();\r\n closeButton.fontSize = Math.floor(parseInt(options.headerHeight) * 0.6);\r\n closeButton.textBlock.textVerticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n closeButton.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_RIGHT;\r\n closeButton.height = closeButton.width = options.headerHeight;\r\n closeButton.background = header.background;\r\n closeButton.thickness = 0;\r\n closeButton.pointerDownAnimation = function () {\r\n };\r\n closeButton.pointerUpAnimation = function () {\r\n closeButton.background = header.background;\r\n };\r\n closeButton.pointerEnterAnimation = function () {\r\n closeButton.color = header.background;\r\n closeButton.background = \"red\";\r\n };\r\n closeButton.pointerOutAnimation = function () {\r\n closeButton.color = closeIconColor.toHexString();\r\n closeButton.background = header.background;\r\n };\r\n closeButton.onPointerClickObservable.add(function () {\r\n closePicker(currentSwatch.background);\r\n });\r\n pickerPanel.addControl(closeButton, 0, 0);\r\n // Dialog container body\r\n var dialogBody = new Grid();\r\n dialogBody.name = \"Dialogue Body\";\r\n dialogBody.background = buttonBackgroundColor;\r\n var dialogBodyCols = [0.4375, 0.5625];\r\n dialogBody.addRowDefinition(1.0, false);\r\n dialogBody.addColumnDefinition(dialogBodyCols[0], false);\r\n dialogBody.addColumnDefinition(dialogBodyCols[1], false);\r\n pickerPanel.addControl(dialogBody, 1, 0);\r\n // Picker grid\r\n var pickerGrid = new Grid();\r\n pickerGrid.name = \"Picker Grid\";\r\n pickerGrid.addRowDefinition(0.85, false);\r\n pickerGrid.addRowDefinition(0.15, false);\r\n dialogBody.addControl(pickerGrid, 0, 0);\r\n // Picker control\r\n picker = new ColorPicker();\r\n picker.name = \"GUI Color Picker\";\r\n if (options.pickerHeight < options.pickerWidth) {\r\n picker.width = 0.89;\r\n }\r\n else {\r\n picker.height = 0.89;\r\n }\r\n picker.value = Color3.FromHexString(options.lastColor);\r\n picker.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_CENTER;\r\n picker.verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n picker.onPointerDownObservable.add(function () {\r\n activeField = picker.name;\r\n lastVal = \"\";\r\n editSwatches(false);\r\n });\r\n picker.onValueChangedObservable.add(function (value) {\r\n if (activeField == picker.name) {\r\n updateValues(value, picker.name);\r\n }\r\n });\r\n pickerGrid.addControl(picker, 0, 0);\r\n // Picker body right quarant\r\n var pickerBodyRight = new Grid();\r\n pickerBodyRight.name = \"Dialogue Right Half\";\r\n pickerBodyRight.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n var pickerBodyRightRows = [0.514, 0.486];\r\n pickerBodyRight.addRowDefinition(pickerBodyRightRows[0], false);\r\n pickerBodyRight.addRowDefinition(pickerBodyRightRows[1], false);\r\n dialogBody.addControl(pickerBodyRight, 1, 1);\r\n // Picker container swatches and buttons\r\n var pickerSwatchesButtons = new Grid();\r\n pickerSwatchesButtons.name = \"Swatches and Buttons\";\r\n var pickerButtonsCol = [0.417, 0.583];\r\n pickerSwatchesButtons.addRowDefinition(1.0, false);\r\n pickerSwatchesButtons.addColumnDefinition(pickerButtonsCol[0], false);\r\n pickerSwatchesButtons.addColumnDefinition(pickerButtonsCol[1], false);\r\n pickerBodyRight.addControl(pickerSwatchesButtons, 0, 0);\r\n // Picker Swatches quadrant\r\n var pickerSwatches = new Grid();\r\n pickerSwatches.name = \"New and Current Swatches\";\r\n var pickeSwatchesRows = [0.04, 0.16, 0.64, 0.16];\r\n pickerSwatches.addRowDefinition(pickeSwatchesRows[0], false);\r\n pickerSwatches.addRowDefinition(pickeSwatchesRows[1], false);\r\n pickerSwatches.addRowDefinition(pickeSwatchesRows[2], false);\r\n pickerSwatches.addRowDefinition(pickeSwatchesRows[3], false);\r\n pickerSwatchesButtons.addControl(pickerSwatches, 0, 0);\r\n // Active swatches\r\n var activeSwatches = new Grid();\r\n activeSwatches.name = \"Active Swatches\";\r\n activeSwatches.width = 0.67;\r\n activeSwatches.addRowDefinition(0.5, false);\r\n activeSwatches.addRowDefinition(0.5, false);\r\n pickerSwatches.addControl(activeSwatches, 2, 0);\r\n var labelWidth = (Math.floor(parseInt(options.pickerWidth) * dialogBodyCols[1] * pickerButtonsCol[0] * 0.11));\r\n var labelHeight = (Math.floor(parseInt(options.pickerHeight) * pickerPanelRows[1] * pickerBodyRightRows[0] * pickeSwatchesRows[1] * 0.5));\r\n if (options.pickerWidth > options.pickerHeight) {\r\n var labelTextSize = labelHeight;\r\n }\r\n else {\r\n var labelTextSize = labelWidth;\r\n }\r\n // New color swatch and previous color button\r\n var newText = new TextBlock();\r\n newText.text = \"new\";\r\n newText.name = \"New Color Label\";\r\n newText.color = buttonColor;\r\n newText.fontSize = labelTextSize;\r\n pickerSwatches.addControl(newText, 1, 0);\r\n newSwatch = new Rectangle();\r\n newSwatch.name = \"New Color Swatch\";\r\n newSwatch.background = options.lastColor;\r\n newSwatch.thickness = 0;\r\n activeSwatches.addControl(newSwatch, 0, 0);\r\n var currentSwatch = Button.CreateSimpleButton(\"currentSwatch\", \"\");\r\n currentSwatch.background = options.lastColor;\r\n currentSwatch.thickness = 0;\r\n currentSwatch.onPointerClickObservable.add(function () {\r\n var revertColor = Color3.FromHexString(currentSwatch.background);\r\n updateValues(revertColor, currentSwatch.name);\r\n editSwatches(false);\r\n });\r\n currentSwatch.pointerDownAnimation = function () { };\r\n currentSwatch.pointerUpAnimation = function () { };\r\n currentSwatch.pointerEnterAnimation = function () { };\r\n currentSwatch.pointerOutAnimation = function () { };\r\n activeSwatches.addControl(currentSwatch, 1, 0);\r\n var swatchOutline = new Rectangle();\r\n swatchOutline.name = \"Swatch Outline\";\r\n swatchOutline.width = 0.67;\r\n swatchOutline.thickness = 2;\r\n swatchOutline.color = currentSwatchesOutlineColor;\r\n swatchOutline.isHitTestVisible = false;\r\n pickerSwatches.addControl(swatchOutline, 2, 0);\r\n var currentText = new TextBlock();\r\n currentText.name = \"Current Color Label\";\r\n currentText.text = \"current\";\r\n currentText.color = buttonColor;\r\n currentText.fontSize = labelTextSize;\r\n pickerSwatches.addControl(currentText, 3, 0);\r\n // Buttons grid\r\n var buttonGrid = new Grid();\r\n buttonGrid.name = \"Button Grid\";\r\n buttonGrid.height = 0.8;\r\n var buttonGridRows = 1 / 3;\r\n buttonGrid.addRowDefinition(buttonGridRows, false);\r\n buttonGrid.addRowDefinition(buttonGridRows, false);\r\n buttonGrid.addRowDefinition(buttonGridRows, false);\r\n pickerSwatchesButtons.addControl(buttonGrid, 0, 1);\r\n // Determine pixel width and height for all buttons from overall panel dimensions\r\n buttonWidth = (Math.floor(parseInt(options.pickerWidth) * dialogBodyCols[1] * pickerButtonsCol[1] * 0.67)).toString() + \"px\";\r\n buttonHeight = (Math.floor(parseInt(options.pickerHeight) * pickerPanelRows[1] * pickerBodyRightRows[0] * (parseFloat(buttonGrid.height.toString()) / 100) * buttonGridRows * 0.7)).toString() + \"px\";\r\n // Determine button type size\r\n if (parseFloat(buttonWidth) > parseFloat(buttonHeight)) {\r\n buttonFontSize = Math.floor(parseFloat(buttonHeight) * 0.45);\r\n }\r\n else {\r\n buttonFontSize = Math.floor(parseFloat(buttonWidth) * 0.11);\r\n }\r\n // Panel Buttons\r\n var butOK = Button.CreateSimpleButton(\"butOK\", \"OK\");\r\n butOK.width = buttonWidth;\r\n butOK.height = buttonHeight;\r\n butOK.verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n butOK.thickness = 2;\r\n butOK.color = buttonColor;\r\n butOK.fontSize = buttonFontSize;\r\n butOK.background = buttonBackgroundColor;\r\n butOK.onPointerEnterObservable.add(function () { butOK.background = buttonBackgroundHoverColor; });\r\n butOK.onPointerOutObservable.add(function () { butOK.background = buttonBackgroundColor; });\r\n butOK.pointerDownAnimation = function () {\r\n butOK.background = buttonBackgroundClickColor;\r\n };\r\n butOK.pointerUpAnimation = function () {\r\n butOK.background = buttonBackgroundHoverColor;\r\n };\r\n butOK.onPointerClickObservable.add(function () {\r\n editSwatches(false);\r\n closePicker(newSwatch.background);\r\n });\r\n buttonGrid.addControl(butOK, 0, 0);\r\n var butCancel = Button.CreateSimpleButton(\"butCancel\", \"Cancel\");\r\n butCancel.width = buttonWidth;\r\n butCancel.height = buttonHeight;\r\n butCancel.verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n butCancel.thickness = 2;\r\n butCancel.color = buttonColor;\r\n butCancel.fontSize = buttonFontSize;\r\n butCancel.background = buttonBackgroundColor;\r\n butCancel.onPointerEnterObservable.add(function () { butCancel.background = buttonBackgroundHoverColor; });\r\n butCancel.onPointerOutObservable.add(function () { butCancel.background = buttonBackgroundColor; });\r\n butCancel.pointerDownAnimation = function () {\r\n butCancel.background = buttonBackgroundClickColor;\r\n };\r\n butCancel.pointerUpAnimation = function () {\r\n butCancel.background = buttonBackgroundHoverColor;\r\n };\r\n butCancel.onPointerClickObservable.add(function () {\r\n editSwatches(false);\r\n closePicker(currentSwatch.background);\r\n });\r\n buttonGrid.addControl(butCancel, 1, 0);\r\n if (options.savedColors) {\r\n var butSave = Button.CreateSimpleButton(\"butSave\", \"Save\");\r\n butSave.width = buttonWidth;\r\n butSave.height = buttonHeight;\r\n butSave.verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n butSave.thickness = 2;\r\n butSave.fontSize = buttonFontSize;\r\n if (options.savedColors.length < options.swatchLimit) {\r\n butSave.color = buttonColor;\r\n butSave.background = buttonBackgroundColor;\r\n }\r\n else {\r\n disableButton(butSave, true);\r\n }\r\n butSave.onPointerEnterObservable.add(function () {\r\n if (options.savedColors) {\r\n if (options.savedColors.length < options.swatchLimit) {\r\n butSave.background = buttonBackgroundHoverColor;\r\n }\r\n }\r\n });\r\n butSave.onPointerOutObservable.add(function () {\r\n if (options.savedColors) {\r\n if (options.savedColors.length < options.swatchLimit) {\r\n butSave.background = buttonBackgroundColor;\r\n }\r\n }\r\n });\r\n butSave.pointerDownAnimation = function () {\r\n if (options.savedColors) {\r\n if (options.savedColors.length < options.swatchLimit) {\r\n butSave.background = buttonBackgroundClickColor;\r\n }\r\n }\r\n };\r\n butSave.pointerUpAnimation = function () {\r\n if (options.savedColors) {\r\n if (options.savedColors.length < options.swatchLimit) {\r\n butSave.background = buttonBackgroundHoverColor;\r\n }\r\n }\r\n };\r\n butSave.onPointerClickObservable.add(function () {\r\n if (options.savedColors) {\r\n if (options.savedColors.length == 0) {\r\n setEditButtonVisibility(true);\r\n }\r\n if (options.savedColors.length < options.swatchLimit) {\r\n updateSwatches(newSwatch.background, butSave);\r\n }\r\n editSwatches(false);\r\n }\r\n });\r\n if (options.savedColors.length > 0) {\r\n setEditButtonVisibility(true);\r\n }\r\n buttonGrid.addControl(butSave, 2, 0);\r\n }\r\n // Picker color values input\r\n var pickerColorValues = new Grid();\r\n pickerColorValues.name = \"Dialog Lower Right\";\r\n pickerColorValues.addRowDefinition(0.02, false);\r\n pickerColorValues.addRowDefinition(0.63, false);\r\n pickerColorValues.addRowDefinition(0.21, false);\r\n pickerColorValues.addRowDefinition(0.14, false);\r\n pickerBodyRight.addControl(pickerColorValues, 1, 0);\r\n // RGB values text boxes\r\n currentColor = Color3.FromHexString(options.lastColor);\r\n var rgbValuesQuadrant = new Grid();\r\n rgbValuesQuadrant.name = \"RGB Values\";\r\n rgbValuesQuadrant.width = 0.82;\r\n rgbValuesQuadrant.verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n rgbValuesQuadrant.addRowDefinition(1 / 3, false);\r\n rgbValuesQuadrant.addRowDefinition(1 / 3, false);\r\n rgbValuesQuadrant.addRowDefinition(1 / 3, false);\r\n rgbValuesQuadrant.addColumnDefinition(0.1, false);\r\n rgbValuesQuadrant.addColumnDefinition(0.2, false);\r\n rgbValuesQuadrant.addColumnDefinition(0.7, false);\r\n pickerColorValues.addControl(rgbValuesQuadrant, 1, 0);\r\n for (var i = 0; i < inputFieldLabels.length; i++) {\r\n var labelText = new TextBlock();\r\n labelText.text = inputFieldLabels[i];\r\n labelText.color = buttonColor;\r\n labelText.fontSize = buttonFontSize;\r\n rgbValuesQuadrant.addControl(labelText, i, 0);\r\n }\r\n // Input fields for RGB values\r\n rValInt = new InputText();\r\n rValInt.width = 0.83;\r\n rValInt.height = 0.72;\r\n rValInt.name = \"rIntField\";\r\n rValInt.fontSize = buttonFontSize;\r\n rValInt.text = (currentColor.r * 255).toString();\r\n rValInt.color = inputTextColor;\r\n rValInt.background = inputTextBackgroundColor;\r\n rValInt.onFocusObservable.add(function () {\r\n activeField = rValInt.name;\r\n lastVal = rValInt.text;\r\n editSwatches(false);\r\n });\r\n rValInt.onBlurObservable.add(function () {\r\n if (rValInt.text == \"\") {\r\n rValInt.text = \"0\";\r\n }\r\n updateInt(rValInt, \"r\");\r\n if (activeField == rValInt.name) {\r\n activeField = \"\";\r\n }\r\n });\r\n rValInt.onTextChangedObservable.add(function () {\r\n if (activeField == rValInt.name) {\r\n updateInt(rValInt, \"r\");\r\n }\r\n });\r\n rgbValuesQuadrant.addControl(rValInt, 0, 1);\r\n gValInt = new InputText();\r\n gValInt.width = 0.83;\r\n gValInt.height = 0.72;\r\n gValInt.name = \"gIntField\";\r\n gValInt.fontSize = buttonFontSize;\r\n gValInt.text = (currentColor.g * 255).toString();\r\n gValInt.color = inputTextColor;\r\n gValInt.background = inputTextBackgroundColor;\r\n gValInt.onFocusObservable.add(function () {\r\n activeField = gValInt.name;\r\n lastVal = gValInt.text;\r\n editSwatches(false);\r\n });\r\n gValInt.onBlurObservable.add(function () {\r\n if (gValInt.text == \"\") {\r\n gValInt.text = \"0\";\r\n }\r\n updateInt(gValInt, \"g\");\r\n if (activeField == gValInt.name) {\r\n activeField = \"\";\r\n }\r\n });\r\n gValInt.onTextChangedObservable.add(function () {\r\n if (activeField == gValInt.name) {\r\n updateInt(gValInt, \"g\");\r\n }\r\n });\r\n rgbValuesQuadrant.addControl(gValInt, 1, 1);\r\n bValInt = new InputText();\r\n bValInt.width = 0.83;\r\n bValInt.height = 0.72;\r\n bValInt.name = \"bIntField\";\r\n bValInt.fontSize = buttonFontSize;\r\n bValInt.text = (currentColor.b * 255).toString();\r\n bValInt.color = inputTextColor;\r\n bValInt.background = inputTextBackgroundColor;\r\n bValInt.onFocusObservable.add(function () {\r\n activeField = bValInt.name;\r\n lastVal = bValInt.text;\r\n editSwatches(false);\r\n });\r\n bValInt.onBlurObservable.add(function () {\r\n if (bValInt.text == \"\") {\r\n bValInt.text = \"0\";\r\n }\r\n updateInt(bValInt, \"b\");\r\n if (activeField == bValInt.name) {\r\n activeField = \"\";\r\n }\r\n });\r\n bValInt.onTextChangedObservable.add(function () {\r\n if (activeField == bValInt.name) {\r\n updateInt(bValInt, \"b\");\r\n }\r\n });\r\n rgbValuesQuadrant.addControl(bValInt, 2, 1);\r\n rValDec = new InputText();\r\n rValDec.width = 0.95;\r\n rValDec.height = 0.72;\r\n rValDec.name = \"rDecField\";\r\n rValDec.fontSize = buttonFontSize;\r\n rValDec.text = currentColor.r.toString();\r\n rValDec.color = inputTextColor;\r\n rValDec.background = inputTextBackgroundColor;\r\n rValDec.onFocusObservable.add(function () {\r\n activeField = rValDec.name;\r\n lastVal = rValDec.text;\r\n editSwatches(false);\r\n });\r\n rValDec.onBlurObservable.add(function () {\r\n if (parseFloat(rValDec.text) == 0 || rValDec.text == \"\") {\r\n rValDec.text = \"0\";\r\n updateFloat(rValDec, \"r\");\r\n }\r\n if (activeField == rValDec.name) {\r\n activeField = \"\";\r\n }\r\n });\r\n rValDec.onTextChangedObservable.add(function () {\r\n if (activeField == rValDec.name) {\r\n updateFloat(rValDec, \"r\");\r\n }\r\n });\r\n rgbValuesQuadrant.addControl(rValDec, 0, 2);\r\n gValDec = new InputText();\r\n gValDec.width = 0.95;\r\n gValDec.height = 0.72;\r\n gValDec.name = \"gDecField\";\r\n gValDec.fontSize = buttonFontSize;\r\n gValDec.text = currentColor.g.toString();\r\n gValDec.color = inputTextColor;\r\n gValDec.background = inputTextBackgroundColor;\r\n gValDec.onFocusObservable.add(function () {\r\n activeField = gValDec.name;\r\n lastVal = gValDec.text;\r\n editSwatches(false);\r\n });\r\n gValDec.onBlurObservable.add(function () {\r\n if (parseFloat(gValDec.text) == 0 || gValDec.text == \"\") {\r\n gValDec.text = \"0\";\r\n updateFloat(gValDec, \"g\");\r\n }\r\n if (activeField == gValDec.name) {\r\n activeField = \"\";\r\n }\r\n });\r\n gValDec.onTextChangedObservable.add(function () {\r\n if (activeField == gValDec.name) {\r\n updateFloat(gValDec, \"g\");\r\n }\r\n });\r\n rgbValuesQuadrant.addControl(gValDec, 1, 2);\r\n bValDec = new InputText();\r\n bValDec.width = 0.95;\r\n bValDec.height = 0.72;\r\n bValDec.name = \"bDecField\";\r\n bValDec.fontSize = buttonFontSize;\r\n bValDec.text = currentColor.b.toString();\r\n bValDec.color = inputTextColor;\r\n bValDec.background = inputTextBackgroundColor;\r\n bValDec.onFocusObservable.add(function () {\r\n activeField = bValDec.name;\r\n lastVal = bValDec.text;\r\n editSwatches(false);\r\n });\r\n bValDec.onBlurObservable.add(function () {\r\n if (parseFloat(bValDec.text) == 0 || bValDec.text == \"\") {\r\n bValDec.text = \"0\";\r\n updateFloat(bValDec, \"b\");\r\n }\r\n if (activeField == bValDec.name) {\r\n activeField = \"\";\r\n }\r\n });\r\n bValDec.onTextChangedObservable.add(function () {\r\n if (activeField == bValDec.name) {\r\n updateFloat(bValDec, \"b\");\r\n }\r\n });\r\n rgbValuesQuadrant.addControl(bValDec, 2, 2);\r\n // Hex value input\r\n var hexValueQuadrant = new Grid();\r\n hexValueQuadrant.name = \"Hex Value\";\r\n hexValueQuadrant.width = 0.82;\r\n hexValueQuadrant.addRowDefinition(1.0, false);\r\n hexValueQuadrant.addColumnDefinition(0.1, false);\r\n hexValueQuadrant.addColumnDefinition(0.9, false);\r\n pickerColorValues.addControl(hexValueQuadrant, 2, 0);\r\n var labelText = new TextBlock();\r\n labelText.text = \"#\";\r\n labelText.color = buttonColor;\r\n labelText.fontSize = buttonFontSize;\r\n hexValueQuadrant.addControl(labelText, 0, 0);\r\n hexVal = new InputText();\r\n hexVal.width = 0.96;\r\n hexVal.height = 0.72;\r\n hexVal.name = \"hexField\";\r\n hexVal.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_CENTER;\r\n hexVal.fontSize = buttonFontSize;\r\n var minusPound = options.lastColor.split(\"#\");\r\n hexVal.text = minusPound[1];\r\n hexVal.color = inputTextColor;\r\n hexVal.background = inputTextBackgroundColor;\r\n hexVal.onFocusObservable.add(function () {\r\n activeField = hexVal.name;\r\n lastVal = hexVal.text;\r\n editSwatches(false);\r\n });\r\n hexVal.onBlurObservable.add(function () {\r\n if (hexVal.text.length == 3) {\r\n var val = hexVal.text.split(\"\");\r\n hexVal.text = val[0] + val[0] + val[1] + val[1] + val[2] + val[2];\r\n }\r\n if (hexVal.text == \"\") {\r\n hexVal.text = \"000000\";\r\n updateValues(Color3.FromHexString(hexVal.text), \"b\");\r\n }\r\n if (activeField == hexVal.name) {\r\n activeField = \"\";\r\n }\r\n });\r\n hexVal.onTextChangedObservable.add(function () {\r\n var newHexValue = hexVal.text;\r\n var checkHex = /[^0-9A-F]/i.test(newHexValue);\r\n if ((hexVal.text.length > 6 || checkHex) && activeField == hexVal.name) {\r\n hexVal.text = lastVal;\r\n }\r\n else {\r\n if (hexVal.text.length < 6) {\r\n var leadingZero = 6 - hexVal.text.length;\r\n for (var i = 0; i < leadingZero; i++) {\r\n newHexValue = \"0\" + newHexValue;\r\n }\r\n }\r\n if (hexVal.text.length == 3) {\r\n var val = hexVal.text.split(\"\");\r\n newHexValue = val[0] + val[0] + val[1] + val[1] + val[2] + val[2];\r\n }\r\n newHexValue = \"#\" + newHexValue;\r\n if (activeField == hexVal.name) {\r\n lastVal = hexVal.text;\r\n updateValues(Color3.FromHexString(newHexValue), hexVal.name);\r\n }\r\n }\r\n });\r\n hexValueQuadrant.addControl(hexVal, 0, 1);\r\n if (options.savedColors && options.savedColors.length > 0) {\r\n updateSwatches(\"\", butSave);\r\n }\r\n });\r\n };\r\n ColorPicker._Epsilon = 0.000001;\r\n return ColorPicker;\r\n}(Control));\r\nexport { ColorPicker };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.ColorPicker\"] = ColorPicker;\r\n//# sourceMappingURL=colorpicker.js.map","import { __extends } from \"tslib\";\r\nimport { Container } from \"./container\";\r\nimport { Control } from \"./control\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/** Class used to create 2D ellipse containers */\r\nvar Ellipse = /** @class */ (function (_super) {\r\n __extends(Ellipse, _super);\r\n /**\r\n * Creates a new Ellipse\r\n * @param name defines the control name\r\n */\r\n function Ellipse(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._thickness = 1;\r\n return _this;\r\n }\r\n Object.defineProperty(Ellipse.prototype, \"thickness\", {\r\n /** Gets or sets border thickness */\r\n get: function () {\r\n return this._thickness;\r\n },\r\n set: function (value) {\r\n if (this._thickness === value) {\r\n return;\r\n }\r\n this._thickness = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Ellipse.prototype._getTypeName = function () {\r\n return \"Ellipse\";\r\n };\r\n Ellipse.prototype._localDraw = function (context) {\r\n context.save();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n Control.drawEllipse(this._currentMeasure.left + this._currentMeasure.width / 2, this._currentMeasure.top + this._currentMeasure.height / 2, this._currentMeasure.width / 2 - this._thickness / 2, this._currentMeasure.height / 2 - this._thickness / 2, context);\r\n if (this._background) {\r\n context.fillStyle = this._background;\r\n context.fill();\r\n }\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n if (this._thickness) {\r\n if (this.color) {\r\n context.strokeStyle = this.color;\r\n }\r\n context.lineWidth = this._thickness;\r\n context.stroke();\r\n }\r\n context.restore();\r\n };\r\n Ellipse.prototype._additionalProcessing = function (parentMeasure, context) {\r\n _super.prototype._additionalProcessing.call(this, parentMeasure, context);\r\n this._measureForChildren.width -= 2 * this._thickness;\r\n this._measureForChildren.height -= 2 * this._thickness;\r\n this._measureForChildren.left += this._thickness;\r\n this._measureForChildren.top += this._thickness;\r\n };\r\n Ellipse.prototype._clipForChildren = function (context) {\r\n Control.drawEllipse(this._currentMeasure.left + this._currentMeasure.width / 2, this._currentMeasure.top + this._currentMeasure.height / 2, this._currentMeasure.width / 2, this._currentMeasure.height / 2, context);\r\n context.clip();\r\n };\r\n return Ellipse;\r\n}(Container));\r\nexport { Ellipse };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Ellipse\"] = Ellipse;\r\n//# sourceMappingURL=ellipse.js.map","import { __extends } from \"tslib\";\r\nimport { InputText } from \"./inputText\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\nimport { TextWrapper } from './textWrapper';\r\n/**\r\n * Class used to create a password control\r\n */\r\nvar InputPassword = /** @class */ (function (_super) {\r\n __extends(InputPassword, _super);\r\n function InputPassword() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n InputPassword.prototype._beforeRenderText = function (textWrapper) {\r\n var pwdTextWrapper = new TextWrapper();\r\n var txt = \"\";\r\n for (var i = 0; i < textWrapper.length; i++) {\r\n txt += \"\\u2022\";\r\n }\r\n pwdTextWrapper.text = txt;\r\n return pwdTextWrapper;\r\n };\r\n return InputPassword;\r\n}(InputText));\r\nexport { InputPassword };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.InputPassword\"] = InputPassword;\r\n//# sourceMappingURL=inputPassword.js.map","import { __extends } from \"tslib\";\r\nimport { Vector3, Matrix } from \"@babylonjs/core/Maths/math.vector\";\r\nimport { Tools } from \"@babylonjs/core/Misc/tools\";\r\nimport { Control } from \"./control\";\r\nimport { ValueAndUnit } from \"../valueAndUnit\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/** Class used to render 2D lines */\r\nvar Line = /** @class */ (function (_super) {\r\n __extends(Line, _super);\r\n /**\r\n * Creates a new Line\r\n * @param name defines the control name\r\n */\r\n function Line(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._lineWidth = 1;\r\n _this._x1 = new ValueAndUnit(0);\r\n _this._y1 = new ValueAndUnit(0);\r\n _this._x2 = new ValueAndUnit(0);\r\n _this._y2 = new ValueAndUnit(0);\r\n _this._dash = new Array();\r\n _this._automaticSize = true;\r\n _this.isHitTestVisible = false;\r\n _this._horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _this._verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n return _this;\r\n }\r\n Object.defineProperty(Line.prototype, \"dash\", {\r\n /** Gets or sets the dash pattern */\r\n get: function () {\r\n return this._dash;\r\n },\r\n set: function (value) {\r\n if (this._dash === value) {\r\n return;\r\n }\r\n this._dash = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"connectedControl\", {\r\n /** Gets or sets the control connected with the line end */\r\n get: function () {\r\n return this._connectedControl;\r\n },\r\n set: function (value) {\r\n var _this = this;\r\n if (this._connectedControl === value) {\r\n return;\r\n }\r\n if (this._connectedControlDirtyObserver && this._connectedControl) {\r\n this._connectedControl.onDirtyObservable.remove(this._connectedControlDirtyObserver);\r\n this._connectedControlDirtyObserver = null;\r\n }\r\n if (value) {\r\n this._connectedControlDirtyObserver = value.onDirtyObservable.add(function () { return _this._markAsDirty(); });\r\n }\r\n this._connectedControl = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"x1\", {\r\n /** Gets or sets start coordinates on X axis */\r\n get: function () {\r\n return this._x1.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._x1.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._x1.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"y1\", {\r\n /** Gets or sets start coordinates on Y axis */\r\n get: function () {\r\n return this._y1.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._y1.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._y1.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"x2\", {\r\n /** Gets or sets end coordinates on X axis */\r\n get: function () {\r\n return this._x2.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._x2.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._x2.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"y2\", {\r\n /** Gets or sets end coordinates on Y axis */\r\n get: function () {\r\n return this._y2.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._y2.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._y2.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"lineWidth\", {\r\n /** Gets or sets line width */\r\n get: function () {\r\n return this._lineWidth;\r\n },\r\n set: function (value) {\r\n if (this._lineWidth === value) {\r\n return;\r\n }\r\n this._lineWidth = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"horizontalAlignment\", {\r\n /** Gets or sets horizontal alignment */\r\n set: function (value) {\r\n return;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"verticalAlignment\", {\r\n /** Gets or sets vertical alignment */\r\n set: function (value) {\r\n return;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"_effectiveX2\", {\r\n get: function () {\r\n return (this._connectedControl ? this._connectedControl.centerX : 0) + this._x2.getValue(this._host);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Line.prototype, \"_effectiveY2\", {\r\n get: function () {\r\n return (this._connectedControl ? this._connectedControl.centerY : 0) + this._y2.getValue(this._host);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Line.prototype._getTypeName = function () {\r\n return \"Line\";\r\n };\r\n Line.prototype._draw = function (context) {\r\n context.save();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n this._applyStates(context);\r\n context.strokeStyle = this.color;\r\n context.lineWidth = this._lineWidth;\r\n context.setLineDash(this._dash);\r\n context.beginPath();\r\n context.moveTo(this._cachedParentMeasure.left + this._x1.getValue(this._host), this._cachedParentMeasure.top + this._y1.getValue(this._host));\r\n context.lineTo(this._cachedParentMeasure.left + this._effectiveX2, this._cachedParentMeasure.top + this._effectiveY2);\r\n context.stroke();\r\n context.restore();\r\n };\r\n Line.prototype._measure = function () {\r\n // Width / Height\r\n this._currentMeasure.width = Math.abs(this._x1.getValue(this._host) - this._effectiveX2) + this._lineWidth;\r\n this._currentMeasure.height = Math.abs(this._y1.getValue(this._host) - this._effectiveY2) + this._lineWidth;\r\n };\r\n Line.prototype._computeAlignment = function (parentMeasure, context) {\r\n this._currentMeasure.left = parentMeasure.left + Math.min(this._x1.getValue(this._host), this._effectiveX2) - this._lineWidth / 2;\r\n this._currentMeasure.top = parentMeasure.top + Math.min(this._y1.getValue(this._host), this._effectiveY2) - this._lineWidth / 2;\r\n };\r\n /**\r\n * Move one end of the line given 3D cartesian coordinates.\r\n * @param position Targeted world position\r\n * @param scene Scene\r\n * @param end (opt) Set to true to assign x2 and y2 coordinates of the line. Default assign to x1 and y1.\r\n */\r\n Line.prototype.moveToVector3 = function (position, scene, end) {\r\n if (end === void 0) { end = false; }\r\n if (!this._host || this.parent !== this._host._rootContainer) {\r\n Tools.Error(\"Cannot move a control to a vector3 if the control is not at root level\");\r\n return;\r\n }\r\n var globalViewport = this._host._getGlobalViewport(scene);\r\n var projectedPosition = Vector3.Project(position, Matrix.Identity(), scene.getTransformMatrix(), globalViewport);\r\n this._moveToProjectedPosition(projectedPosition, end);\r\n if (projectedPosition.z < 0 || projectedPosition.z > 1) {\r\n this.notRenderable = true;\r\n return;\r\n }\r\n this.notRenderable = false;\r\n };\r\n /**\r\n * Move one end of the line to a position in screen absolute space.\r\n * @param projectedPosition Position in screen absolute space (X, Y)\r\n * @param end (opt) Set to true to assign x2 and y2 coordinates of the line. Default assign to x1 and y1.\r\n */\r\n Line.prototype._moveToProjectedPosition = function (projectedPosition, end) {\r\n if (end === void 0) { end = false; }\r\n var x = (projectedPosition.x + this._linkOffsetX.getValue(this._host)) + \"px\";\r\n var y = (projectedPosition.y + this._linkOffsetY.getValue(this._host)) + \"px\";\r\n if (end) {\r\n this.x2 = x;\r\n this.y2 = y;\r\n this._x2.ignoreAdaptiveScaling = true;\r\n this._y2.ignoreAdaptiveScaling = true;\r\n }\r\n else {\r\n this.x1 = x;\r\n this.y1 = y;\r\n this._x1.ignoreAdaptiveScaling = true;\r\n this._y1.ignoreAdaptiveScaling = true;\r\n }\r\n };\r\n return Line;\r\n}(Control));\r\nexport { Line };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Line\"] = Line;\r\n//# sourceMappingURL=line.js.map","import { Vector3 } from \"@babylonjs/core/Maths/math.vector\";\r\nimport { Epsilon } from '@babylonjs/core/Maths/math.constants';\r\nimport { ValueAndUnit } from \"./valueAndUnit\";\r\n/**\r\n * Class used to store a point for a MultiLine object.\r\n * The point can be pure 2D coordinates, a mesh or a control\r\n */\r\nvar MultiLinePoint = /** @class */ (function () {\r\n /**\r\n * Creates a new MultiLinePoint\r\n * @param multiLine defines the source MultiLine object\r\n */\r\n function MultiLinePoint(multiLine) {\r\n this._multiLine = multiLine;\r\n this._x = new ValueAndUnit(0);\r\n this._y = new ValueAndUnit(0);\r\n this._point = new Vector3(0, 0, 0);\r\n }\r\n Object.defineProperty(MultiLinePoint.prototype, \"x\", {\r\n /** Gets or sets x coordinate */\r\n get: function () {\r\n return this._x.toString(this._multiLine._host);\r\n },\r\n set: function (value) {\r\n if (this._x.toString(this._multiLine._host) === value) {\r\n return;\r\n }\r\n if (this._x.fromString(value)) {\r\n this._multiLine._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MultiLinePoint.prototype, \"y\", {\r\n /** Gets or sets y coordinate */\r\n get: function () {\r\n return this._y.toString(this._multiLine._host);\r\n },\r\n set: function (value) {\r\n if (this._y.toString(this._multiLine._host) === value) {\r\n return;\r\n }\r\n if (this._y.fromString(value)) {\r\n this._multiLine._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MultiLinePoint.prototype, \"control\", {\r\n /** Gets or sets the control associated with this point */\r\n get: function () {\r\n return this._control;\r\n },\r\n set: function (value) {\r\n if (this._control === value) {\r\n return;\r\n }\r\n if (this._control && this._controlObserver) {\r\n this._control.onDirtyObservable.remove(this._controlObserver);\r\n this._controlObserver = null;\r\n }\r\n this._control = value;\r\n if (this._control) {\r\n this._controlObserver = this._control.onDirtyObservable.add(this._multiLine.onPointUpdate);\r\n }\r\n this._multiLine._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MultiLinePoint.prototype, \"mesh\", {\r\n /** Gets or sets the mesh associated with this point */\r\n get: function () {\r\n return this._mesh;\r\n },\r\n set: function (value) {\r\n if (this._mesh === value) {\r\n return;\r\n }\r\n if (this._mesh && this._meshObserver) {\r\n this._mesh.getScene().onAfterCameraRenderObservable.remove(this._meshObserver);\r\n }\r\n this._mesh = value;\r\n if (this._mesh) {\r\n this._meshObserver = this._mesh.getScene().onAfterCameraRenderObservable.add(this._multiLine.onPointUpdate);\r\n }\r\n this._multiLine._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** Resets links */\r\n MultiLinePoint.prototype.resetLinks = function () {\r\n this.control = null;\r\n this.mesh = null;\r\n };\r\n /**\r\n * Gets a translation vector with Z component\r\n * @returns the translation vector\r\n */\r\n MultiLinePoint.prototype.translate = function () {\r\n this._point = this._translatePoint();\r\n return this._point;\r\n };\r\n MultiLinePoint.prototype._translatePoint = function () {\r\n if (this._mesh != null) {\r\n return this._multiLine._host.getProjectedPositionWithZ(this._mesh.getBoundingInfo().boundingSphere.center, this._mesh.getWorldMatrix());\r\n }\r\n else if (this._control != null) {\r\n return new Vector3(this._control.centerX, this._control.centerY, 1. - Epsilon);\r\n }\r\n else {\r\n var host = this._multiLine._host;\r\n var xValue = this._x.getValueInPixel(host, Number(host._canvas.width));\r\n var yValue = this._y.getValueInPixel(host, Number(host._canvas.height));\r\n return new Vector3(xValue, yValue, 1. - Epsilon);\r\n }\r\n };\r\n /** Release associated resources */\r\n MultiLinePoint.prototype.dispose = function () {\r\n this.resetLinks();\r\n };\r\n return MultiLinePoint;\r\n}());\r\nexport { MultiLinePoint };\r\n//# sourceMappingURL=multiLinePoint.js.map","import { __extends } from \"tslib\";\r\nimport { AbstractMesh } from \"@babylonjs/core/Meshes/abstractMesh\";\r\nimport { Control } from \"./control\";\r\nimport { MultiLinePoint } from \"../multiLinePoint\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create multi line control\r\n */\r\nvar MultiLine = /** @class */ (function (_super) {\r\n __extends(MultiLine, _super);\r\n /**\r\n * Creates a new MultiLine\r\n * @param name defines the control name\r\n */\r\n function MultiLine(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._lineWidth = 1;\r\n /** Function called when a point is updated */\r\n _this.onPointUpdate = function () {\r\n _this._markAsDirty();\r\n };\r\n _this._automaticSize = true;\r\n _this.isHitTestVisible = false;\r\n _this._horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _this._verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n _this._dash = [];\r\n _this._points = [];\r\n return _this;\r\n }\r\n Object.defineProperty(MultiLine.prototype, \"dash\", {\r\n /** Gets or sets dash pattern */\r\n get: function () {\r\n return this._dash;\r\n },\r\n set: function (value) {\r\n if (this._dash === value) {\r\n return;\r\n }\r\n this._dash = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets point stored at specified index\r\n * @param index defines the index to look for\r\n * @returns the requested point if found\r\n */\r\n MultiLine.prototype.getAt = function (index) {\r\n if (!this._points[index]) {\r\n this._points[index] = new MultiLinePoint(this);\r\n }\r\n return this._points[index];\r\n };\r\n /**\r\n * Adds new points to the point collection\r\n * @param items defines the list of items (mesh, control or 2d coordiantes) to add\r\n * @returns the list of created MultiLinePoint\r\n */\r\n MultiLine.prototype.add = function () {\r\n var _this = this;\r\n var items = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n items[_i] = arguments[_i];\r\n }\r\n return items.map(function (item) { return _this.push(item); });\r\n };\r\n /**\r\n * Adds a new point to the point collection\r\n * @param item defines the item (mesh, control or 2d coordiantes) to add\r\n * @returns the created MultiLinePoint\r\n */\r\n MultiLine.prototype.push = function (item) {\r\n var point = this.getAt(this._points.length);\r\n if (item == null) {\r\n return point;\r\n }\r\n if (item instanceof AbstractMesh) {\r\n point.mesh = item;\r\n }\r\n else if (item instanceof Control) {\r\n point.control = item;\r\n }\r\n else if (item.x != null && item.y != null) {\r\n point.x = item.x;\r\n point.y = item.y;\r\n }\r\n return point;\r\n };\r\n /**\r\n * Remove a specific value or point from the active point collection\r\n * @param value defines the value or point to remove\r\n */\r\n MultiLine.prototype.remove = function (value) {\r\n var index;\r\n if (value instanceof MultiLinePoint) {\r\n index = this._points.indexOf(value);\r\n if (index === -1) {\r\n return;\r\n }\r\n }\r\n else {\r\n index = value;\r\n }\r\n var point = this._points[index];\r\n if (!point) {\r\n return;\r\n }\r\n point.dispose();\r\n this._points.splice(index, 1);\r\n };\r\n /**\r\n * Resets this object to initial state (no point)\r\n */\r\n MultiLine.prototype.reset = function () {\r\n while (this._points.length > 0) {\r\n this.remove(this._points.length - 1);\r\n }\r\n };\r\n /**\r\n * Resets all links\r\n */\r\n MultiLine.prototype.resetLinks = function () {\r\n this._points.forEach(function (point) {\r\n if (point != null) {\r\n point.resetLinks();\r\n }\r\n });\r\n };\r\n Object.defineProperty(MultiLine.prototype, \"lineWidth\", {\r\n /** Gets or sets line width */\r\n get: function () {\r\n return this._lineWidth;\r\n },\r\n set: function (value) {\r\n if (this._lineWidth === value) {\r\n return;\r\n }\r\n this._lineWidth = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MultiLine.prototype, \"horizontalAlignment\", {\r\n set: function (value) {\r\n return;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(MultiLine.prototype, \"verticalAlignment\", {\r\n set: function (value) {\r\n return;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n MultiLine.prototype._getTypeName = function () {\r\n return \"MultiLine\";\r\n };\r\n MultiLine.prototype._draw = function (context, invalidatedRectangle) {\r\n context.save();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n this._applyStates(context);\r\n context.strokeStyle = this.color;\r\n context.lineWidth = this._lineWidth;\r\n context.setLineDash(this._dash);\r\n context.beginPath();\r\n var first = true; //first index is not necessarily 0\r\n var previousPoint;\r\n this._points.forEach(function (point) {\r\n if (!point) {\r\n return;\r\n }\r\n if (first) {\r\n context.moveTo(point._point.x, point._point.y);\r\n first = false;\r\n }\r\n else {\r\n if (point._point.z < 1 && previousPoint.z < 1) {\r\n context.lineTo(point._point.x, point._point.y);\r\n }\r\n else {\r\n context.moveTo(point._point.x, point._point.y);\r\n }\r\n }\r\n previousPoint = point._point;\r\n });\r\n context.stroke();\r\n context.restore();\r\n };\r\n MultiLine.prototype._additionalProcessing = function (parentMeasure, context) {\r\n var _this = this;\r\n this._minX = null;\r\n this._minY = null;\r\n this._maxX = null;\r\n this._maxY = null;\r\n this._points.forEach(function (point, index) {\r\n if (!point) {\r\n return;\r\n }\r\n point.translate();\r\n if (_this._minX == null || point._point.x < _this._minX) {\r\n _this._minX = point._point.x;\r\n }\r\n if (_this._minY == null || point._point.y < _this._minY) {\r\n _this._minY = point._point.y;\r\n }\r\n if (_this._maxX == null || point._point.x > _this._maxX) {\r\n _this._maxX = point._point.x;\r\n }\r\n if (_this._maxY == null || point._point.y > _this._maxY) {\r\n _this._maxY = point._point.y;\r\n }\r\n });\r\n if (this._minX == null) {\r\n this._minX = 0;\r\n }\r\n if (this._minY == null) {\r\n this._minY = 0;\r\n }\r\n if (this._maxX == null) {\r\n this._maxX = 0;\r\n }\r\n if (this._maxY == null) {\r\n this._maxY = 0;\r\n }\r\n };\r\n MultiLine.prototype._measure = function () {\r\n if (this._minX == null || this._maxX == null || this._minY == null || this._maxY == null) {\r\n return;\r\n }\r\n this._currentMeasure.width = Math.abs(this._maxX - this._minX) + this._lineWidth;\r\n this._currentMeasure.height = Math.abs(this._maxY - this._minY) + this._lineWidth;\r\n };\r\n MultiLine.prototype._computeAlignment = function (parentMeasure, context) {\r\n if (this._minX == null || this._minY == null) {\r\n return;\r\n }\r\n this._currentMeasure.left = this._minX - this._lineWidth / 2;\r\n this._currentMeasure.top = this._minY - this._lineWidth / 2;\r\n };\r\n MultiLine.prototype.dispose = function () {\r\n this.reset();\r\n _super.prototype.dispose.call(this);\r\n };\r\n return MultiLine;\r\n}(Control));\r\nexport { MultiLine };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.MultiLine\"] = MultiLine;\r\n//# sourceMappingURL=multiLine.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { Control } from \"./control\";\r\nimport { StackPanel } from \"./stackPanel\";\r\nimport { TextBlock } from \"./textBlock\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create radio button controls\r\n */\r\nvar RadioButton = /** @class */ (function (_super) {\r\n __extends(RadioButton, _super);\r\n /**\r\n * Creates a new RadioButton\r\n * @param name defines the control name\r\n */\r\n function RadioButton(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._isChecked = false;\r\n _this._background = \"black\";\r\n _this._checkSizeRatio = 0.8;\r\n _this._thickness = 1;\r\n /** Gets or sets group name */\r\n _this.group = \"\";\r\n /** Observable raised when isChecked is changed */\r\n _this.onIsCheckedChangedObservable = new Observable();\r\n _this.isPointerBlocker = true;\r\n return _this;\r\n }\r\n Object.defineProperty(RadioButton.prototype, \"thickness\", {\r\n /** Gets or sets border thickness */\r\n get: function () {\r\n return this._thickness;\r\n },\r\n set: function (value) {\r\n if (this._thickness === value) {\r\n return;\r\n }\r\n this._thickness = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(RadioButton.prototype, \"checkSizeRatio\", {\r\n /** Gets or sets a value indicating the ratio between overall size and check size */\r\n get: function () {\r\n return this._checkSizeRatio;\r\n },\r\n set: function (value) {\r\n value = Math.max(Math.min(1, value), 0);\r\n if (this._checkSizeRatio === value) {\r\n return;\r\n }\r\n this._checkSizeRatio = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(RadioButton.prototype, \"background\", {\r\n /** Gets or sets background color */\r\n get: function () {\r\n return this._background;\r\n },\r\n set: function (value) {\r\n if (this._background === value) {\r\n return;\r\n }\r\n this._background = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(RadioButton.prototype, \"isChecked\", {\r\n /** Gets or sets a boolean indicating if the checkbox is checked or not */\r\n get: function () {\r\n return this._isChecked;\r\n },\r\n set: function (value) {\r\n var _this = this;\r\n if (this._isChecked === value) {\r\n return;\r\n }\r\n this._isChecked = value;\r\n this._markAsDirty();\r\n this.onIsCheckedChangedObservable.notifyObservers(value);\r\n if (this._isChecked && this._host) {\r\n // Update all controls from same group\r\n this._host.executeOnAllControls(function (control) {\r\n if (control === _this) {\r\n return;\r\n }\r\n if (control.group === undefined) {\r\n return;\r\n }\r\n var childRadio = control;\r\n if (childRadio.group === _this.group) {\r\n childRadio.isChecked = false;\r\n }\r\n });\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n RadioButton.prototype._getTypeName = function () {\r\n return \"RadioButton\";\r\n };\r\n RadioButton.prototype._draw = function (context) {\r\n context.save();\r\n this._applyStates(context);\r\n var actualWidth = this._currentMeasure.width - this._thickness;\r\n var actualHeight = this._currentMeasure.height - this._thickness;\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n // Outer\r\n Control.drawEllipse(this._currentMeasure.left + this._currentMeasure.width / 2, this._currentMeasure.top + this._currentMeasure.height / 2, this._currentMeasure.width / 2 - this._thickness / 2, this._currentMeasure.height / 2 - this._thickness / 2, context);\r\n context.fillStyle = this._isEnabled ? this._background : this._disabledColor;\r\n context.fill();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n context.strokeStyle = this.color;\r\n context.lineWidth = this._thickness;\r\n context.stroke();\r\n // Inner\r\n if (this._isChecked) {\r\n context.fillStyle = this._isEnabled ? this.color : this._disabledColor;\r\n var offsetWidth = actualWidth * this._checkSizeRatio;\r\n var offseHeight = actualHeight * this._checkSizeRatio;\r\n Control.drawEllipse(this._currentMeasure.left + this._currentMeasure.width / 2, this._currentMeasure.top + this._currentMeasure.height / 2, offsetWidth / 2 - this._thickness / 2, offseHeight / 2 - this._thickness / 2, context);\r\n context.fill();\r\n }\r\n context.restore();\r\n };\r\n // Events\r\n RadioButton.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex, pi) {\r\n if (!_super.prototype._onPointerDown.call(this, target, coordinates, pointerId, buttonIndex, pi)) {\r\n return false;\r\n }\r\n if (!this.isChecked) {\r\n this.isChecked = true;\r\n }\r\n return true;\r\n };\r\n /**\r\n * Utility function to easily create a radio button with a header\r\n * @param title defines the label to use for the header\r\n * @param group defines the group to use for the radio button\r\n * @param isChecked defines the initial state of the radio button\r\n * @param onValueChanged defines the callback to call when value changes\r\n * @returns a StackPanel containing the radio button and a textBlock\r\n */\r\n RadioButton.AddRadioButtonWithHeader = function (title, group, isChecked, onValueChanged) {\r\n var panel = new StackPanel();\r\n panel.isVertical = false;\r\n panel.height = \"30px\";\r\n var radio = new RadioButton();\r\n radio.width = \"20px\";\r\n radio.height = \"20px\";\r\n radio.isChecked = isChecked;\r\n radio.color = \"green\";\r\n radio.group = group;\r\n radio.onIsCheckedChangedObservable.add(function (value) { return onValueChanged(radio, value); });\r\n panel.addControl(radio);\r\n var header = new TextBlock();\r\n header.text = title;\r\n header.width = \"180px\";\r\n header.paddingLeft = \"5px\";\r\n header.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n header.color = \"white\";\r\n panel.addControl(header);\r\n return panel;\r\n };\r\n return RadioButton;\r\n}(Control));\r\nexport { RadioButton };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.RadioButton\"] = RadioButton;\r\n//# sourceMappingURL=radioButton.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { Control } from \"../control\";\r\nimport { ValueAndUnit } from \"../../valueAndUnit\";\r\n/**\r\n * Class used to create slider controls\r\n */\r\nvar BaseSlider = /** @class */ (function (_super) {\r\n __extends(BaseSlider, _super);\r\n /**\r\n * Creates a new BaseSlider\r\n * @param name defines the control name\r\n */\r\n function BaseSlider(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._thumbWidth = new ValueAndUnit(20, ValueAndUnit.UNITMODE_PIXEL, false);\r\n _this._minimum = 0;\r\n _this._maximum = 100;\r\n _this._value = 50;\r\n _this._isVertical = false;\r\n _this._barOffset = new ValueAndUnit(5, ValueAndUnit.UNITMODE_PIXEL, false);\r\n _this._isThumbClamped = false;\r\n _this._displayThumb = true;\r\n _this._step = 0;\r\n _this._lastPointerDownID = -1;\r\n // Shared rendering info\r\n _this._effectiveBarOffset = 0;\r\n /** Observable raised when the sldier value changes */\r\n _this.onValueChangedObservable = new Observable();\r\n // Events\r\n _this._pointerIsDown = false;\r\n _this.isPointerBlocker = true;\r\n return _this;\r\n }\r\n Object.defineProperty(BaseSlider.prototype, \"displayThumb\", {\r\n /** Gets or sets a boolean indicating if the thumb must be rendered */\r\n get: function () {\r\n return this._displayThumb;\r\n },\r\n set: function (value) {\r\n if (this._displayThumb === value) {\r\n return;\r\n }\r\n this._displayThumb = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"step\", {\r\n /** Gets or sets a step to apply to values (0 by default) */\r\n get: function () {\r\n return this._step;\r\n },\r\n set: function (value) {\r\n if (this._step === value) {\r\n return;\r\n }\r\n this._step = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"barOffset\", {\r\n /** Gets or sets main bar offset (ie. the margin applied to the value bar) */\r\n get: function () {\r\n return this._barOffset.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._barOffset.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._barOffset.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"barOffsetInPixels\", {\r\n /** Gets main bar offset in pixels*/\r\n get: function () {\r\n return this._barOffset.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"thumbWidth\", {\r\n /** Gets or sets thumb width */\r\n get: function () {\r\n return this._thumbWidth.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._thumbWidth.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._thumbWidth.fromString(value)) {\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"thumbWidthInPixels\", {\r\n /** Gets thumb width in pixels */\r\n get: function () {\r\n return this._thumbWidth.getValueInPixel(this._host, this._cachedParentMeasure.width);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"minimum\", {\r\n /** Gets or sets minimum value */\r\n get: function () {\r\n return this._minimum;\r\n },\r\n set: function (value) {\r\n if (this._minimum === value) {\r\n return;\r\n }\r\n this._minimum = value;\r\n this._markAsDirty();\r\n this.value = Math.max(Math.min(this.value, this._maximum), this._minimum);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"maximum\", {\r\n /** Gets or sets maximum value */\r\n get: function () {\r\n return this._maximum;\r\n },\r\n set: function (value) {\r\n if (this._maximum === value) {\r\n return;\r\n }\r\n this._maximum = value;\r\n this._markAsDirty();\r\n this.value = Math.max(Math.min(this.value, this._maximum), this._minimum);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"value\", {\r\n /** Gets or sets current value */\r\n get: function () {\r\n return this._value;\r\n },\r\n set: function (value) {\r\n value = Math.max(Math.min(value, this._maximum), this._minimum);\r\n if (this._value === value) {\r\n return;\r\n }\r\n this._value = value;\r\n this._markAsDirty();\r\n this.onValueChangedObservable.notifyObservers(this._value);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"isVertical\", {\r\n /**Gets or sets a boolean indicating if the slider should be vertical or horizontal */\r\n get: function () {\r\n return this._isVertical;\r\n },\r\n set: function (value) {\r\n if (this._isVertical === value) {\r\n return;\r\n }\r\n this._isVertical = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BaseSlider.prototype, \"isThumbClamped\", {\r\n /** Gets or sets a value indicating if the thumb can go over main bar extends */\r\n get: function () {\r\n return this._isThumbClamped;\r\n },\r\n set: function (value) {\r\n if (this._isThumbClamped === value) {\r\n return;\r\n }\r\n this._isThumbClamped = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n BaseSlider.prototype._getTypeName = function () {\r\n return \"BaseSlider\";\r\n };\r\n BaseSlider.prototype._getThumbPosition = function () {\r\n if (this.isVertical) {\r\n return ((this.maximum - this.value) / (this.maximum - this.minimum)) * this._backgroundBoxLength;\r\n }\r\n return ((this.value - this.minimum) / (this.maximum - this.minimum)) * this._backgroundBoxLength;\r\n };\r\n BaseSlider.prototype._getThumbThickness = function (type) {\r\n var thumbThickness = 0;\r\n switch (type) {\r\n case \"circle\":\r\n if (this._thumbWidth.isPixel) {\r\n thumbThickness = Math.max(this._thumbWidth.getValue(this._host), this._backgroundBoxThickness);\r\n }\r\n else {\r\n thumbThickness = this._backgroundBoxThickness * this._thumbWidth.getValue(this._host);\r\n }\r\n break;\r\n case \"rectangle\":\r\n if (this._thumbWidth.isPixel) {\r\n thumbThickness = Math.min(this._thumbWidth.getValue(this._host), this._backgroundBoxThickness);\r\n }\r\n else {\r\n thumbThickness = this._backgroundBoxThickness * this._thumbWidth.getValue(this._host);\r\n }\r\n }\r\n return thumbThickness;\r\n };\r\n BaseSlider.prototype._prepareRenderingData = function (type) {\r\n // Main bar\r\n this._effectiveBarOffset = 0;\r\n this._renderLeft = this._currentMeasure.left;\r\n this._renderTop = this._currentMeasure.top;\r\n this._renderWidth = this._currentMeasure.width;\r\n this._renderHeight = this._currentMeasure.height;\r\n this._backgroundBoxLength = Math.max(this._currentMeasure.width, this._currentMeasure.height);\r\n this._backgroundBoxThickness = Math.min(this._currentMeasure.width, this._currentMeasure.height);\r\n this._effectiveThumbThickness = this._getThumbThickness(type);\r\n if (this.displayThumb) {\r\n this._backgroundBoxLength -= this._effectiveThumbThickness;\r\n }\r\n //throw error when height is less than width for vertical slider\r\n if ((this.isVertical && this._currentMeasure.height < this._currentMeasure.width)) {\r\n console.error(\"Height should be greater than width\");\r\n return;\r\n }\r\n if (this._barOffset.isPixel) {\r\n this._effectiveBarOffset = Math.min(this._barOffset.getValue(this._host), this._backgroundBoxThickness);\r\n }\r\n else {\r\n this._effectiveBarOffset = this._backgroundBoxThickness * this._barOffset.getValue(this._host);\r\n }\r\n this._backgroundBoxThickness -= (this._effectiveBarOffset * 2);\r\n if (this.isVertical) {\r\n this._renderLeft += this._effectiveBarOffset;\r\n if (!this.isThumbClamped && this.displayThumb) {\r\n this._renderTop += (this._effectiveThumbThickness / 2);\r\n }\r\n this._renderHeight = this._backgroundBoxLength;\r\n this._renderWidth = this._backgroundBoxThickness;\r\n }\r\n else {\r\n this._renderTop += this._effectiveBarOffset;\r\n if (!this.isThumbClamped && this.displayThumb) {\r\n this._renderLeft += (this._effectiveThumbThickness / 2);\r\n }\r\n this._renderHeight = this._backgroundBoxThickness;\r\n this._renderWidth = this._backgroundBoxLength;\r\n }\r\n };\r\n /** @hidden */\r\n BaseSlider.prototype._updateValueFromPointer = function (x, y) {\r\n if (this.rotation != 0) {\r\n this._invertTransformMatrix.transformCoordinates(x, y, this._transformedPosition);\r\n x = this._transformedPosition.x;\r\n y = this._transformedPosition.y;\r\n }\r\n var value;\r\n if (this._isVertical) {\r\n value = this._minimum + (1 - ((y - this._currentMeasure.top) / this._currentMeasure.height)) * (this._maximum - this._minimum);\r\n }\r\n else {\r\n value = this._minimum + ((x - this._currentMeasure.left) / this._currentMeasure.width) * (this._maximum - this._minimum);\r\n }\r\n var mult = (1 / this._step) | 0;\r\n this.value = this._step ? ((value * mult) | 0) / mult : value;\r\n };\r\n BaseSlider.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex, pi) {\r\n if (!_super.prototype._onPointerDown.call(this, target, coordinates, pointerId, buttonIndex, pi)) {\r\n return false;\r\n }\r\n this._pointerIsDown = true;\r\n this._updateValueFromPointer(coordinates.x, coordinates.y);\r\n this._host._capturingControl[pointerId] = this;\r\n this._lastPointerDownID = pointerId;\r\n return true;\r\n };\r\n BaseSlider.prototype._onPointerMove = function (target, coordinates, pointerId, pi) {\r\n // Only listen to pointer move events coming from the last pointer to click on the element (To support dual vr controller interaction)\r\n if (pointerId != this._lastPointerDownID) {\r\n return;\r\n }\r\n if (this._pointerIsDown) {\r\n this._updateValueFromPointer(coordinates.x, coordinates.y);\r\n }\r\n _super.prototype._onPointerMove.call(this, target, coordinates, pointerId, pi);\r\n };\r\n BaseSlider.prototype._onPointerUp = function (target, coordinates, pointerId, buttonIndex, notifyClick) {\r\n this._pointerIsDown = false;\r\n delete this._host._capturingControl[pointerId];\r\n _super.prototype._onPointerUp.call(this, target, coordinates, pointerId, buttonIndex, notifyClick);\r\n };\r\n BaseSlider.prototype._onCanvasBlur = function () {\r\n this._forcePointerUp();\r\n _super.prototype._onCanvasBlur.call(this);\r\n };\r\n return BaseSlider;\r\n}(Control));\r\nexport { BaseSlider };\r\n//# sourceMappingURL=baseSlider.js.map","import { __extends } from \"tslib\";\r\nimport { BaseSlider } from \"./baseSlider\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create slider controls\r\n */\r\nvar Slider = /** @class */ (function (_super) {\r\n __extends(Slider, _super);\r\n /**\r\n * Creates a new Slider\r\n * @param name defines the control name\r\n */\r\n function Slider(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._background = \"black\";\r\n _this._borderColor = \"white\";\r\n _this._thumbColor = \"\";\r\n _this._isThumbCircle = false;\r\n _this._displayValueBar = true;\r\n return _this;\r\n }\r\n Object.defineProperty(Slider.prototype, \"displayValueBar\", {\r\n /** Gets or sets a boolean indicating if the value bar must be rendered */\r\n get: function () {\r\n return this._displayValueBar;\r\n },\r\n set: function (value) {\r\n if (this._displayValueBar === value) {\r\n return;\r\n }\r\n this._displayValueBar = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Slider.prototype, \"borderColor\", {\r\n /** Gets or sets border color */\r\n get: function () {\r\n return this._borderColor;\r\n },\r\n set: function (value) {\r\n if (this._borderColor === value) {\r\n return;\r\n }\r\n this._borderColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Slider.prototype, \"background\", {\r\n /** Gets or sets background color */\r\n get: function () {\r\n return this._background;\r\n },\r\n set: function (value) {\r\n if (this._background === value) {\r\n return;\r\n }\r\n this._background = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Slider.prototype, \"thumbColor\", {\r\n /** Gets or sets thumb's color */\r\n get: function () {\r\n return this._thumbColor;\r\n },\r\n set: function (value) {\r\n if (this._thumbColor === value) {\r\n return;\r\n }\r\n this._thumbColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Slider.prototype, \"isThumbCircle\", {\r\n /** Gets or sets a boolean indicating if the thumb should be round or square */\r\n get: function () {\r\n return this._isThumbCircle;\r\n },\r\n set: function (value) {\r\n if (this._isThumbCircle === value) {\r\n return;\r\n }\r\n this._isThumbCircle = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Slider.prototype._getTypeName = function () {\r\n return \"Slider\";\r\n };\r\n Slider.prototype._draw = function (context, invalidatedRectangle) {\r\n context.save();\r\n this._applyStates(context);\r\n this._prepareRenderingData(this.isThumbCircle ? \"circle\" : \"rectangle\");\r\n var left = this._renderLeft;\r\n var top = this._renderTop;\r\n var width = this._renderWidth;\r\n var height = this._renderHeight;\r\n var radius = 0;\r\n if (this.isThumbClamped && this.isThumbCircle) {\r\n if (this.isVertical) {\r\n top += (this._effectiveThumbThickness / 2);\r\n }\r\n else {\r\n left += (this._effectiveThumbThickness / 2);\r\n }\r\n radius = this._backgroundBoxThickness / 2;\r\n }\r\n else {\r\n radius = (this._effectiveThumbThickness - this._effectiveBarOffset) / 2;\r\n }\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n var thumbPosition = this._getThumbPosition();\r\n context.fillStyle = this._background;\r\n if (this.isVertical) {\r\n if (this.isThumbClamped) {\r\n if (this.isThumbCircle) {\r\n context.beginPath();\r\n context.arc(left + this._backgroundBoxThickness / 2, top, radius, Math.PI, 2 * Math.PI);\r\n context.fill();\r\n context.fillRect(left, top, width, height);\r\n }\r\n else {\r\n context.fillRect(left, top, width, height + this._effectiveThumbThickness);\r\n }\r\n }\r\n else {\r\n context.fillRect(left, top, width, height);\r\n }\r\n }\r\n else {\r\n if (this.isThumbClamped) {\r\n if (this.isThumbCircle) {\r\n context.beginPath();\r\n context.arc(left + this._backgroundBoxLength, top + (this._backgroundBoxThickness / 2), radius, 0, 2 * Math.PI);\r\n context.fill();\r\n context.fillRect(left, top, width, height);\r\n }\r\n else {\r\n context.fillRect(left, top, width + this._effectiveThumbThickness, height);\r\n }\r\n }\r\n else {\r\n context.fillRect(left, top, width, height);\r\n }\r\n }\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n // Value bar\r\n context.fillStyle = this.color;\r\n if (this._displayValueBar) {\r\n if (this.isVertical) {\r\n if (this.isThumbClamped) {\r\n if (this.isThumbCircle) {\r\n context.beginPath();\r\n context.arc(left + this._backgroundBoxThickness / 2, top + this._backgroundBoxLength, radius, 0, 2 * Math.PI);\r\n context.fill();\r\n context.fillRect(left, top + thumbPosition, width, height - thumbPosition);\r\n }\r\n else {\r\n context.fillRect(left, top + thumbPosition, width, height - thumbPosition + this._effectiveThumbThickness);\r\n }\r\n }\r\n else {\r\n context.fillRect(left, top + thumbPosition, width, height - thumbPosition);\r\n }\r\n }\r\n else {\r\n if (this.isThumbClamped) {\r\n if (this.isThumbCircle) {\r\n context.beginPath();\r\n context.arc(left, top + this._backgroundBoxThickness / 2, radius, 0, 2 * Math.PI);\r\n context.fill();\r\n context.fillRect(left, top, thumbPosition, height);\r\n }\r\n else {\r\n context.fillRect(left, top, thumbPosition, height);\r\n }\r\n }\r\n else {\r\n context.fillRect(left, top, thumbPosition, height);\r\n }\r\n }\r\n }\r\n // Thumb\r\n context.fillStyle = this._thumbColor || this.color;\r\n if (this.displayThumb) {\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowColor = this.shadowColor;\r\n context.shadowBlur = this.shadowBlur;\r\n context.shadowOffsetX = this.shadowOffsetX;\r\n context.shadowOffsetY = this.shadowOffsetY;\r\n }\r\n if (this._isThumbCircle) {\r\n context.beginPath();\r\n if (this.isVertical) {\r\n context.arc(left + this._backgroundBoxThickness / 2, top + thumbPosition, radius, 0, 2 * Math.PI);\r\n }\r\n else {\r\n context.arc(left + thumbPosition, top + (this._backgroundBoxThickness / 2), radius, 0, 2 * Math.PI);\r\n }\r\n context.fill();\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n context.strokeStyle = this._borderColor;\r\n context.stroke();\r\n }\r\n else {\r\n if (this.isVertical) {\r\n context.fillRect(left - this._effectiveBarOffset, this._currentMeasure.top + thumbPosition, this._currentMeasure.width, this._effectiveThumbThickness);\r\n }\r\n else {\r\n context.fillRect(this._currentMeasure.left + thumbPosition, this._currentMeasure.top, this._effectiveThumbThickness, this._currentMeasure.height);\r\n }\r\n if (this.shadowBlur || this.shadowOffsetX || this.shadowOffsetY) {\r\n context.shadowBlur = 0;\r\n context.shadowOffsetX = 0;\r\n context.shadowOffsetY = 0;\r\n }\r\n context.strokeStyle = this._borderColor;\r\n if (this.isVertical) {\r\n context.strokeRect(left - this._effectiveBarOffset, this._currentMeasure.top + thumbPosition, this._currentMeasure.width, this._effectiveThumbThickness);\r\n }\r\n else {\r\n context.strokeRect(this._currentMeasure.left + thumbPosition, this._currentMeasure.top, this._effectiveThumbThickness, this._currentMeasure.height);\r\n }\r\n }\r\n }\r\n context.restore();\r\n };\r\n return Slider;\r\n}(BaseSlider));\r\nexport { Slider };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.Slider\"] = Slider;\r\n//# sourceMappingURL=slider.js.map","import { __extends } from \"tslib\";\r\nimport { Rectangle } from \"./rectangle\";\r\nimport { StackPanel } from \"./stackPanel\";\r\nimport { Control } from \"./control\";\r\nimport { TextBlock } from \"./textBlock\";\r\nimport { Checkbox } from \"./checkbox\";\r\nimport { RadioButton } from \"./radioButton\";\r\nimport { Slider } from \"./sliders/slider\";\r\nimport { Container } from \"./container\";\r\n/** Class used to create a RadioGroup\r\n * which contains groups of radio buttons\r\n*/\r\nvar SelectorGroup = /** @class */ (function () {\r\n /**\r\n * Creates a new SelectorGroup\r\n * @param name of group, used as a group heading\r\n */\r\n function SelectorGroup(\r\n /** name of SelectorGroup */\r\n name) {\r\n this.name = name;\r\n this._groupPanel = new StackPanel();\r\n this._selectors = new Array();\r\n this._groupPanel.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n this._groupPanel.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n this._groupHeader = this._addGroupHeader(name);\r\n }\r\n Object.defineProperty(SelectorGroup.prototype, \"groupPanel\", {\r\n /** Gets the groupPanel of the SelectorGroup */\r\n get: function () {\r\n return this._groupPanel;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(SelectorGroup.prototype, \"selectors\", {\r\n /** Gets the selectors array */\r\n get: function () {\r\n return this._selectors;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(SelectorGroup.prototype, \"header\", {\r\n /** Gets and sets the group header */\r\n get: function () {\r\n return this._groupHeader.text;\r\n },\r\n set: function (label) {\r\n if (this._groupHeader.text === \"label\") {\r\n return;\r\n }\r\n this._groupHeader.text = label;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n SelectorGroup.prototype._addGroupHeader = function (text) {\r\n var groupHeading = new TextBlock(\"groupHead\", text);\r\n groupHeading.width = 0.9;\r\n groupHeading.height = \"30px\";\r\n groupHeading.textWrapping = true;\r\n groupHeading.color = \"black\";\r\n groupHeading.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n groupHeading.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n groupHeading.left = \"2px\";\r\n this._groupPanel.addControl(groupHeading);\r\n return groupHeading;\r\n };\r\n /** @hidden*/\r\n SelectorGroup.prototype._getSelector = function (selectorNb) {\r\n if (selectorNb < 0 || selectorNb >= this._selectors.length) {\r\n return;\r\n }\r\n return this._selectors[selectorNb];\r\n };\r\n /** Removes the selector at the given position\r\n * @param selectorNb the position of the selector within the group\r\n */\r\n SelectorGroup.prototype.removeSelector = function (selectorNb) {\r\n if (selectorNb < 0 || selectorNb >= this._selectors.length) {\r\n return;\r\n }\r\n this._groupPanel.removeControl(this._selectors[selectorNb]);\r\n this._selectors.splice(selectorNb, 1);\r\n };\r\n return SelectorGroup;\r\n}());\r\nexport { SelectorGroup };\r\n/** Class used to create a CheckboxGroup\r\n * which contains groups of checkbox buttons\r\n*/\r\nvar CheckboxGroup = /** @class */ (function (_super) {\r\n __extends(CheckboxGroup, _super);\r\n function CheckboxGroup() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n /** Adds a checkbox as a control\r\n * @param text is the label for the selector\r\n * @param func is the function called when the Selector is checked\r\n * @param checked is true when Selector is checked\r\n */\r\n CheckboxGroup.prototype.addCheckbox = function (text, func, checked) {\r\n if (func === void 0) { func = function (s) { }; }\r\n if (checked === void 0) { checked = false; }\r\n var checked = checked || false;\r\n var button = new Checkbox();\r\n button.width = \"20px\";\r\n button.height = \"20px\";\r\n button.color = \"#364249\";\r\n button.background = \"#CCCCCC\";\r\n button.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n button.onIsCheckedChangedObservable.add(function (state) {\r\n func(state);\r\n });\r\n var _selector = Control.AddHeader(button, text, \"200px\", { isHorizontal: true, controlFirst: true });\r\n _selector.height = \"30px\";\r\n _selector.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _selector.left = \"4px\";\r\n this.groupPanel.addControl(_selector);\r\n this.selectors.push(_selector);\r\n button.isChecked = checked;\r\n if (this.groupPanel.parent && this.groupPanel.parent.parent) {\r\n button.color = this.groupPanel.parent.parent.buttonColor;\r\n button.background = this.groupPanel.parent.parent.buttonBackground;\r\n }\r\n };\r\n /** @hidden */\r\n CheckboxGroup.prototype._setSelectorLabel = function (selectorNb, label) {\r\n this.selectors[selectorNb].children[1].text = label;\r\n };\r\n /** @hidden */\r\n CheckboxGroup.prototype._setSelectorLabelColor = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[1].color = color;\r\n };\r\n /** @hidden */\r\n CheckboxGroup.prototype._setSelectorButtonColor = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[0].color = color;\r\n };\r\n /** @hidden */\r\n CheckboxGroup.prototype._setSelectorButtonBackground = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[0].background = color;\r\n };\r\n return CheckboxGroup;\r\n}(SelectorGroup));\r\nexport { CheckboxGroup };\r\n/** Class used to create a RadioGroup\r\n * which contains groups of radio buttons\r\n*/\r\nvar RadioGroup = /** @class */ (function (_super) {\r\n __extends(RadioGroup, _super);\r\n function RadioGroup() {\r\n var _this = _super !== null && _super.apply(this, arguments) || this;\r\n _this._selectNb = 0;\r\n return _this;\r\n }\r\n /** Adds a radio button as a control\r\n * @param label is the label for the selector\r\n * @param func is the function called when the Selector is checked\r\n * @param checked is true when Selector is checked\r\n */\r\n RadioGroup.prototype.addRadio = function (label, func, checked) {\r\n if (func === void 0) { func = function (n) { }; }\r\n if (checked === void 0) { checked = false; }\r\n var nb = this._selectNb++;\r\n var button = new RadioButton();\r\n button.name = label;\r\n button.width = \"20px\";\r\n button.height = \"20px\";\r\n button.color = \"#364249\";\r\n button.background = \"#CCCCCC\";\r\n button.group = this.name;\r\n button.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n button.onIsCheckedChangedObservable.add(function (state) {\r\n if (state) {\r\n func(nb);\r\n }\r\n });\r\n var _selector = Control.AddHeader(button, label, \"200px\", { isHorizontal: true, controlFirst: true });\r\n _selector.height = \"30px\";\r\n _selector.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _selector.left = \"4px\";\r\n this.groupPanel.addControl(_selector);\r\n this.selectors.push(_selector);\r\n button.isChecked = checked;\r\n if (this.groupPanel.parent && this.groupPanel.parent.parent) {\r\n button.color = this.groupPanel.parent.parent.buttonColor;\r\n button.background = this.groupPanel.parent.parent.buttonBackground;\r\n }\r\n };\r\n /** @hidden */\r\n RadioGroup.prototype._setSelectorLabel = function (selectorNb, label) {\r\n this.selectors[selectorNb].children[1].text = label;\r\n };\r\n /** @hidden */\r\n RadioGroup.prototype._setSelectorLabelColor = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[1].color = color;\r\n };\r\n /** @hidden */\r\n RadioGroup.prototype._setSelectorButtonColor = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[0].color = color;\r\n };\r\n /** @hidden */\r\n RadioGroup.prototype._setSelectorButtonBackground = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[0].background = color;\r\n };\r\n return RadioGroup;\r\n}(SelectorGroup));\r\nexport { RadioGroup };\r\n/** Class used to create a SliderGroup\r\n * which contains groups of slider buttons\r\n*/\r\nvar SliderGroup = /** @class */ (function (_super) {\r\n __extends(SliderGroup, _super);\r\n function SliderGroup() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n /**\r\n * Adds a slider to the SelectorGroup\r\n * @param label is the label for the SliderBar\r\n * @param func is the function called when the Slider moves\r\n * @param unit is a string describing the units used, eg degrees or metres\r\n * @param min is the minimum value for the Slider\r\n * @param max is the maximum value for the Slider\r\n * @param value is the start value for the Slider between min and max\r\n * @param onValueChange is the function used to format the value displayed, eg radians to degrees\r\n */\r\n SliderGroup.prototype.addSlider = function (label, func, unit, min, max, value, onValueChange) {\r\n if (func === void 0) { func = function (v) { }; }\r\n if (unit === void 0) { unit = \"Units\"; }\r\n if (min === void 0) { min = 0; }\r\n if (max === void 0) { max = 0; }\r\n if (value === void 0) { value = 0; }\r\n if (onValueChange === void 0) { onValueChange = function (v) { return v | 0; }; }\r\n var button = new Slider();\r\n button.name = unit;\r\n button.value = value;\r\n button.minimum = min;\r\n button.maximum = max;\r\n button.width = 0.9;\r\n button.height = \"20px\";\r\n button.color = \"#364249\";\r\n button.background = \"#CCCCCC\";\r\n button.borderColor = \"black\";\r\n button.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n button.left = \"4px\";\r\n button.paddingBottom = \"4px\";\r\n button.onValueChangedObservable.add(function (value) {\r\n button.parent.children[0].text = button.parent.children[0].name + \": \" + onValueChange(value) + \" \" + button.name;\r\n func(value);\r\n });\r\n var _selector = Control.AddHeader(button, label + \": \" + onValueChange(value) + \" \" + unit, \"30px\", { isHorizontal: false, controlFirst: false });\r\n _selector.height = \"60px\";\r\n _selector.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _selector.left = \"4px\";\r\n _selector.children[0].name = label;\r\n this.groupPanel.addControl(_selector);\r\n this.selectors.push(_selector);\r\n if (this.groupPanel.parent && this.groupPanel.parent.parent) {\r\n button.color = this.groupPanel.parent.parent.buttonColor;\r\n button.background = this.groupPanel.parent.parent.buttonBackground;\r\n }\r\n };\r\n /** @hidden */\r\n SliderGroup.prototype._setSelectorLabel = function (selectorNb, label) {\r\n this.selectors[selectorNb].children[0].name = label;\r\n this.selectors[selectorNb].children[0].text = label + \": \" + this.selectors[selectorNb].children[1].value + \" \" + this.selectors[selectorNb].children[1].name;\r\n };\r\n /** @hidden */\r\n SliderGroup.prototype._setSelectorLabelColor = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[0].color = color;\r\n };\r\n /** @hidden */\r\n SliderGroup.prototype._setSelectorButtonColor = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[1].color = color;\r\n };\r\n /** @hidden */\r\n SliderGroup.prototype._setSelectorButtonBackground = function (selectorNb, color) {\r\n this.selectors[selectorNb].children[1].background = color;\r\n };\r\n return SliderGroup;\r\n}(SelectorGroup));\r\nexport { SliderGroup };\r\n/** Class used to hold the controls for the checkboxes, radio buttons and sliders\r\n * @see https://doc.babylonjs.com/how_to/selector\r\n*/\r\nvar SelectionPanel = /** @class */ (function (_super) {\r\n __extends(SelectionPanel, _super);\r\n /**\r\n * Creates a new SelectionPanel\r\n * @param name of SelectionPanel\r\n * @param groups is an array of SelectionGroups\r\n */\r\n function SelectionPanel(\r\n /** name of SelectionPanel */\r\n name, \r\n /** an array of SelectionGroups */\r\n groups) {\r\n if (groups === void 0) { groups = []; }\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this.groups = groups;\r\n _this._buttonColor = \"#364249\";\r\n _this._buttonBackground = \"#CCCCCC\";\r\n _this._headerColor = \"black\";\r\n _this._barColor = \"white\";\r\n _this._barHeight = \"2px\";\r\n _this._spacerHeight = \"20px\";\r\n _this._bars = new Array();\r\n _this._groups = groups;\r\n _this.thickness = 2;\r\n _this._panel = new StackPanel();\r\n _this._panel.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n _this._panel.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _this._panel.top = 5;\r\n _this._panel.left = 5;\r\n _this._panel.width = 0.95;\r\n if (groups.length > 0) {\r\n for (var i = 0; i < groups.length - 1; i++) {\r\n _this._panel.addControl(groups[i].groupPanel);\r\n _this._addSpacer();\r\n }\r\n _this._panel.addControl(groups[groups.length - 1].groupPanel);\r\n }\r\n _this.addControl(_this._panel);\r\n return _this;\r\n }\r\n SelectionPanel.prototype._getTypeName = function () {\r\n return \"SelectionPanel\";\r\n };\r\n Object.defineProperty(SelectionPanel.prototype, \"panel\", {\r\n /** Gets the (stack) panel of the SelectionPanel */\r\n get: function () {\r\n return this._panel;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(SelectionPanel.prototype, \"headerColor\", {\r\n /** Gets or sets the headerColor */\r\n get: function () {\r\n return this._headerColor;\r\n },\r\n set: function (color) {\r\n if (this._headerColor === color) {\r\n return;\r\n }\r\n this._headerColor = color;\r\n this._setHeaderColor();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n SelectionPanel.prototype._setHeaderColor = function () {\r\n for (var i = 0; i < this._groups.length; i++) {\r\n this._groups[i].groupPanel.children[0].color = this._headerColor;\r\n }\r\n };\r\n Object.defineProperty(SelectionPanel.prototype, \"buttonColor\", {\r\n /** Gets or sets the button color */\r\n get: function () {\r\n return this._buttonColor;\r\n },\r\n set: function (color) {\r\n if (this._buttonColor === color) {\r\n return;\r\n }\r\n this._buttonColor = color;\r\n this._setbuttonColor();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n SelectionPanel.prototype._setbuttonColor = function () {\r\n for (var i = 0; i < this._groups.length; i++) {\r\n for (var j = 0; j < this._groups[i].selectors.length; j++) {\r\n this._groups[i]._setSelectorButtonColor(j, this._buttonColor);\r\n }\r\n }\r\n };\r\n Object.defineProperty(SelectionPanel.prototype, \"labelColor\", {\r\n /** Gets or sets the label color */\r\n get: function () {\r\n return this._labelColor;\r\n },\r\n set: function (color) {\r\n if (this._labelColor === color) {\r\n return;\r\n }\r\n this._labelColor = color;\r\n this._setLabelColor();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n SelectionPanel.prototype._setLabelColor = function () {\r\n for (var i = 0; i < this._groups.length; i++) {\r\n for (var j = 0; j < this._groups[i].selectors.length; j++) {\r\n this._groups[i]._setSelectorLabelColor(j, this._labelColor);\r\n }\r\n }\r\n };\r\n Object.defineProperty(SelectionPanel.prototype, \"buttonBackground\", {\r\n /** Gets or sets the button background */\r\n get: function () {\r\n return this._buttonBackground;\r\n },\r\n set: function (color) {\r\n if (this._buttonBackground === color) {\r\n return;\r\n }\r\n this._buttonBackground = color;\r\n this._setButtonBackground();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n SelectionPanel.prototype._setButtonBackground = function () {\r\n for (var i = 0; i < this._groups.length; i++) {\r\n for (var j = 0; j < this._groups[i].selectors.length; j++) {\r\n this._groups[i]._setSelectorButtonBackground(j, this._buttonBackground);\r\n }\r\n }\r\n };\r\n Object.defineProperty(SelectionPanel.prototype, \"barColor\", {\r\n /** Gets or sets the color of separator bar */\r\n get: function () {\r\n return this._barColor;\r\n },\r\n set: function (color) {\r\n if (this._barColor === color) {\r\n return;\r\n }\r\n this._barColor = color;\r\n this._setBarColor();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n SelectionPanel.prototype._setBarColor = function () {\r\n for (var i = 0; i < this._bars.length; i++) {\r\n this._bars[i].children[0].background = this._barColor;\r\n }\r\n };\r\n Object.defineProperty(SelectionPanel.prototype, \"barHeight\", {\r\n /** Gets or sets the height of separator bar */\r\n get: function () {\r\n return this._barHeight;\r\n },\r\n set: function (value) {\r\n if (this._barHeight === value) {\r\n return;\r\n }\r\n this._barHeight = value;\r\n this._setBarHeight();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n SelectionPanel.prototype._setBarHeight = function () {\r\n for (var i = 0; i < this._bars.length; i++) {\r\n this._bars[i].children[0].height = this._barHeight;\r\n }\r\n };\r\n Object.defineProperty(SelectionPanel.prototype, \"spacerHeight\", {\r\n /** Gets or sets the height of spacers*/\r\n get: function () {\r\n return this._spacerHeight;\r\n },\r\n set: function (value) {\r\n if (this._spacerHeight === value) {\r\n return;\r\n }\r\n this._spacerHeight = value;\r\n this._setSpacerHeight();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n SelectionPanel.prototype._setSpacerHeight = function () {\r\n for (var i = 0; i < this._bars.length; i++) {\r\n this._bars[i].height = this._spacerHeight;\r\n }\r\n };\r\n /** Adds a bar between groups */\r\n SelectionPanel.prototype._addSpacer = function () {\r\n var separator = new Container();\r\n separator.width = 1;\r\n separator.height = this._spacerHeight;\r\n separator.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n var bar = new Rectangle();\r\n bar.width = 1;\r\n bar.height = this._barHeight;\r\n bar.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n bar.verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n bar.background = this._barColor;\r\n bar.color = \"transparent\";\r\n separator.addControl(bar);\r\n this._panel.addControl(separator);\r\n this._bars.push(separator);\r\n };\r\n /** Add a group to the selection panel\r\n * @param group is the selector group to add\r\n */\r\n SelectionPanel.prototype.addGroup = function (group) {\r\n if (this._groups.length > 0) {\r\n this._addSpacer();\r\n }\r\n this._panel.addControl(group.groupPanel);\r\n this._groups.push(group);\r\n group.groupPanel.children[0].color = this._headerColor;\r\n for (var j = 0; j < group.selectors.length; j++) {\r\n group._setSelectorButtonColor(j, this._buttonColor);\r\n group._setSelectorButtonBackground(j, this._buttonBackground);\r\n }\r\n };\r\n /** Remove the group from the given position\r\n * @param groupNb is the position of the group in the list\r\n */\r\n SelectionPanel.prototype.removeGroup = function (groupNb) {\r\n if (groupNb < 0 || groupNb >= this._groups.length) {\r\n return;\r\n }\r\n var group = this._groups[groupNb];\r\n this._panel.removeControl(group.groupPanel);\r\n this._groups.splice(groupNb, 1);\r\n if (groupNb < this._bars.length) {\r\n this._panel.removeControl(this._bars[groupNb]);\r\n this._bars.splice(groupNb, 1);\r\n }\r\n };\r\n /** Change a group header label\r\n * @param label is the new group header label\r\n * @param groupNb is the number of the group to relabel\r\n * */\r\n SelectionPanel.prototype.setHeaderName = function (label, groupNb) {\r\n if (groupNb < 0 || groupNb >= this._groups.length) {\r\n return;\r\n }\r\n var group = this._groups[groupNb];\r\n group.groupPanel.children[0].text = label;\r\n };\r\n /** Change selector label to the one given\r\n * @param label is the new selector label\r\n * @param groupNb is the number of the groupcontaining the selector\r\n * @param selectorNb is the number of the selector within a group to relabel\r\n * */\r\n SelectionPanel.prototype.relabel = function (label, groupNb, selectorNb) {\r\n if (groupNb < 0 || groupNb >= this._groups.length) {\r\n return;\r\n }\r\n var group = this._groups[groupNb];\r\n if (selectorNb < 0 || selectorNb >= group.selectors.length) {\r\n return;\r\n }\r\n group._setSelectorLabel(selectorNb, label);\r\n };\r\n /** For a given group position remove the selector at the given position\r\n * @param groupNb is the number of the group to remove the selector from\r\n * @param selectorNb is the number of the selector within the group\r\n */\r\n SelectionPanel.prototype.removeFromGroupSelector = function (groupNb, selectorNb) {\r\n if (groupNb < 0 || groupNb >= this._groups.length) {\r\n return;\r\n }\r\n var group = this._groups[groupNb];\r\n if (selectorNb < 0 || selectorNb >= group.selectors.length) {\r\n return;\r\n }\r\n group.removeSelector(selectorNb);\r\n };\r\n /** For a given group position of correct type add a checkbox button\r\n * @param groupNb is the number of the group to remove the selector from\r\n * @param label is the label for the selector\r\n * @param func is the function called when the Selector is checked\r\n * @param checked is true when Selector is checked\r\n */\r\n SelectionPanel.prototype.addToGroupCheckbox = function (groupNb, label, func, checked) {\r\n if (func === void 0) { func = function () { }; }\r\n if (checked === void 0) { checked = false; }\r\n if (groupNb < 0 || groupNb >= this._groups.length) {\r\n return;\r\n }\r\n var group = this._groups[groupNb];\r\n group.addCheckbox(label, func, checked);\r\n };\r\n /** For a given group position of correct type add a radio button\r\n * @param groupNb is the number of the group to remove the selector from\r\n * @param label is the label for the selector\r\n * @param func is the function called when the Selector is checked\r\n * @param checked is true when Selector is checked\r\n */\r\n SelectionPanel.prototype.addToGroupRadio = function (groupNb, label, func, checked) {\r\n if (func === void 0) { func = function () { }; }\r\n if (checked === void 0) { checked = false; }\r\n if (groupNb < 0 || groupNb >= this._groups.length) {\r\n return;\r\n }\r\n var group = this._groups[groupNb];\r\n group.addRadio(label, func, checked);\r\n };\r\n /**\r\n * For a given slider group add a slider\r\n * @param groupNb is the number of the group to add the slider to\r\n * @param label is the label for the Slider\r\n * @param func is the function called when the Slider moves\r\n * @param unit is a string describing the units used, eg degrees or metres\r\n * @param min is the minimum value for the Slider\r\n * @param max is the maximum value for the Slider\r\n * @param value is the start value for the Slider between min and max\r\n * @param onVal is the function used to format the value displayed, eg radians to degrees\r\n */\r\n SelectionPanel.prototype.addToGroupSlider = function (groupNb, label, func, unit, min, max, value, onVal) {\r\n if (func === void 0) { func = function () { }; }\r\n if (unit === void 0) { unit = \"Units\"; }\r\n if (min === void 0) { min = 0; }\r\n if (max === void 0) { max = 0; }\r\n if (value === void 0) { value = 0; }\r\n if (onVal === void 0) { onVal = function (v) { return v | 0; }; }\r\n if (groupNb < 0 || groupNb >= this._groups.length) {\r\n return;\r\n }\r\n var group = this._groups[groupNb];\r\n group.addSlider(label, func, unit, min, max, value, onVal);\r\n };\r\n return SelectionPanel;\r\n}(Rectangle));\r\nexport { SelectionPanel };\r\n//# sourceMappingURL=selector.js.map","import { __extends } from \"tslib\";\r\nimport { Measure } from \"../../measure\";\r\nimport { Container } from \"../container\";\r\nimport { ValueAndUnit } from \"../../valueAndUnit\";\r\nimport { Control } from \"../control\";\r\n/**\r\n * Class used to hold a the container for ScrollViewer\r\n * @hidden\r\n*/\r\nvar _ScrollViewerWindow = /** @class */ (function (_super) {\r\n __extends(_ScrollViewerWindow, _super);\r\n /**\r\n * Creates a new ScrollViewerWindow\r\n * @param name of ScrollViewerWindow\r\n */\r\n function _ScrollViewerWindow(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this._freezeControls = false;\r\n _this._bucketWidth = 0;\r\n _this._bucketHeight = 0;\r\n _this._buckets = {};\r\n return _this;\r\n }\r\n Object.defineProperty(_ScrollViewerWindow.prototype, \"freezeControls\", {\r\n get: function () {\r\n return this._freezeControls;\r\n },\r\n set: function (value) {\r\n if (this._freezeControls === value) {\r\n return;\r\n }\r\n if (!value) {\r\n this._restoreMeasures();\r\n }\r\n // trigger a full normal layout calculation to be sure all children have their measures up to date\r\n this._freezeControls = false;\r\n var textureSize = this.host.getSize();\r\n var renderWidth = textureSize.width;\r\n var renderHeight = textureSize.height;\r\n var context = this.host.getContext();\r\n var measure = new Measure(0, 0, renderWidth, renderHeight);\r\n this.host._numLayoutCalls = 0;\r\n this.host._rootContainer._layout(measure, context);\r\n // in freeze mode, prepare children measures accordingly\r\n if (value) {\r\n this._updateMeasures();\r\n if (this._useBuckets()) {\r\n this._makeBuckets();\r\n }\r\n }\r\n this._freezeControls = value;\r\n this.host.markAsDirty(); // redraw with the (new) current settings\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(_ScrollViewerWindow.prototype, \"bucketWidth\", {\r\n get: function () {\r\n return this._bucketWidth;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(_ScrollViewerWindow.prototype, \"bucketHeight\", {\r\n get: function () {\r\n return this._bucketHeight;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n _ScrollViewerWindow.prototype.setBucketSizes = function (width, height) {\r\n this._bucketWidth = width;\r\n this._bucketHeight = height;\r\n if (this._useBuckets()) {\r\n if (this._freezeControls) {\r\n this._makeBuckets();\r\n }\r\n }\r\n else {\r\n this._buckets = {};\r\n }\r\n };\r\n _ScrollViewerWindow.prototype._useBuckets = function () {\r\n return this._bucketWidth > 0 && this._bucketHeight > 0;\r\n };\r\n _ScrollViewerWindow.prototype._makeBuckets = function () {\r\n this._buckets = {};\r\n this._bucketLen = Math.ceil(this.widthInPixels / this._bucketWidth);\r\n this._dispatchInBuckets(this._children);\r\n this._oldLeft = null;\r\n this._oldTop = null;\r\n };\r\n _ScrollViewerWindow.prototype._dispatchInBuckets = function (children) {\r\n for (var i = 0; i < children.length; ++i) {\r\n var child = children[i];\r\n var bStartX = Math.max(0, Math.floor((child._customData._origLeft - this._customData.origLeft) / this._bucketWidth)), bEndX = Math.floor((child._customData._origLeft - this._customData.origLeft + child._currentMeasure.width - 1) / this._bucketWidth), bStartY = Math.max(0, Math.floor((child._customData._origTop - this._customData.origTop) / this._bucketHeight)), bEndY = Math.floor((child._customData._origTop - this._customData.origTop + child._currentMeasure.height - 1) / this._bucketHeight);\r\n while (bStartY <= bEndY) {\r\n for (var x = bStartX; x <= bEndX; ++x) {\r\n var bucket = bStartY * this._bucketLen + x, lstc = this._buckets[bucket];\r\n if (!lstc) {\r\n lstc = [];\r\n this._buckets[bucket] = lstc;\r\n }\r\n lstc.push(child);\r\n }\r\n bStartY++;\r\n }\r\n if (child instanceof Container && child._children.length > 0) {\r\n this._dispatchInBuckets(child._children);\r\n }\r\n }\r\n };\r\n // reset left and top measures for the window and all its children\r\n _ScrollViewerWindow.prototype._updateMeasures = function () {\r\n var left = this.leftInPixels | 0, top = this.topInPixels | 0;\r\n this._measureForChildren.left -= left;\r\n this._measureForChildren.top -= top;\r\n this._currentMeasure.left -= left;\r\n this._currentMeasure.top -= top;\r\n this._customData.origLeftForChildren = this._measureForChildren.left;\r\n this._customData.origTopForChildren = this._measureForChildren.top;\r\n this._customData.origLeft = this._currentMeasure.left;\r\n this._customData.origTop = this._currentMeasure.top;\r\n this._updateChildrenMeasures(this._children, left, top);\r\n };\r\n _ScrollViewerWindow.prototype._updateChildrenMeasures = function (children, left, top) {\r\n for (var i = 0; i < children.length; ++i) {\r\n var child = children[i];\r\n child._currentMeasure.left -= left;\r\n child._currentMeasure.top -= top;\r\n child._customData._origLeft = child._currentMeasure.left; // save the original left and top values for each child\r\n child._customData._origTop = child._currentMeasure.top;\r\n if (child instanceof Container && child._children.length > 0) {\r\n this._updateChildrenMeasures(child._children, left, top);\r\n }\r\n }\r\n };\r\n _ScrollViewerWindow.prototype._restoreMeasures = function () {\r\n var left = this.leftInPixels | 0, top = this.topInPixels | 0;\r\n this._measureForChildren.left = this._customData.origLeftForChildren + left;\r\n this._measureForChildren.top = this._customData.origTopForChildren + top;\r\n this._currentMeasure.left = this._customData.origLeft + left;\r\n this._currentMeasure.top = this._customData.origTop + top;\r\n };\r\n _ScrollViewerWindow.prototype._getTypeName = function () {\r\n return \"ScrollViewerWindow\";\r\n };\r\n /** @hidden */\r\n _ScrollViewerWindow.prototype._additionalProcessing = function (parentMeasure, context) {\r\n _super.prototype._additionalProcessing.call(this, parentMeasure, context);\r\n this._parentMeasure = parentMeasure;\r\n this._measureForChildren.left = this._currentMeasure.left;\r\n this._measureForChildren.top = this._currentMeasure.top;\r\n this._measureForChildren.width = parentMeasure.width;\r\n this._measureForChildren.height = parentMeasure.height;\r\n };\r\n /** @hidden */\r\n _ScrollViewerWindow.prototype._layout = function (parentMeasure, context) {\r\n if (this._freezeControls) {\r\n this.invalidateRect(); // will trigger a redraw of the window\r\n return false;\r\n }\r\n return _super.prototype._layout.call(this, parentMeasure, context);\r\n };\r\n _ScrollViewerWindow.prototype._scrollChildren = function (children, left, top) {\r\n for (var i = 0; i < children.length; ++i) {\r\n var child = children[i];\r\n child._currentMeasure.left = child._customData._origLeft + left;\r\n child._currentMeasure.top = child._customData._origTop + top;\r\n child._isClipped = false; // clipping will be handled by _draw and the call to _intersectsRect()\r\n if (child instanceof Container && child._children.length > 0) {\r\n this._scrollChildren(child._children, left, top);\r\n }\r\n }\r\n };\r\n _ScrollViewerWindow.prototype._scrollChildrenWithBuckets = function (left, top, scrollLeft, scrollTop) {\r\n var bStartX = Math.max(0, Math.floor(-left / this._bucketWidth)), bEndX = Math.floor((-left + this._parentMeasure.width - 1) / this._bucketWidth), bStartY = Math.max(0, Math.floor(-top / this._bucketHeight)), bEndY = Math.floor((-top + this._parentMeasure.height - 1) / this._bucketHeight);\r\n while (bStartY <= bEndY) {\r\n for (var x = bStartX; x <= bEndX; ++x) {\r\n var bucket = bStartY * this._bucketLen + x, lstc = this._buckets[bucket];\r\n if (lstc) {\r\n for (var i = 0; i < lstc.length; ++i) {\r\n var child = lstc[i];\r\n child._currentMeasure.left = child._customData._origLeft + scrollLeft;\r\n child._currentMeasure.top = child._customData._origTop + scrollTop;\r\n child._isClipped = false; // clipping will be handled by _draw and the call to _intersectsRect()\r\n }\r\n }\r\n }\r\n bStartY++;\r\n }\r\n };\r\n /** @hidden */\r\n _ScrollViewerWindow.prototype._draw = function (context, invalidatedRectangle) {\r\n if (!this._freezeControls) {\r\n _super.prototype._draw.call(this, context, invalidatedRectangle);\r\n return;\r\n }\r\n this._localDraw(context);\r\n if (this.clipChildren) {\r\n this._clipForChildren(context);\r\n }\r\n var left = this.leftInPixels | 0, top = this.topInPixels | 0;\r\n if (this._useBuckets()) {\r\n if (this._oldLeft !== null && this._oldTop !== null) {\r\n this._scrollChildrenWithBuckets(this._oldLeft, this._oldTop, left, top);\r\n this._scrollChildrenWithBuckets(left, top, left, top);\r\n }\r\n else {\r\n this._scrollChildren(this._children, left, top);\r\n }\r\n }\r\n else {\r\n this._scrollChildren(this._children, left, top);\r\n }\r\n this._oldLeft = left;\r\n this._oldTop = top;\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (!child._intersectsRect(this._parentMeasure)) {\r\n continue;\r\n }\r\n child._render(context, this._parentMeasure);\r\n }\r\n };\r\n _ScrollViewerWindow.prototype._postMeasure = function () {\r\n if (this._freezeControls) {\r\n _super.prototype._postMeasure.call(this);\r\n return;\r\n }\r\n var maxWidth = this.parentClientWidth;\r\n var maxHeight = this.parentClientHeight;\r\n for (var _i = 0, _a = this.children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (!child.isVisible || child.notRenderable) {\r\n continue;\r\n }\r\n if (child.horizontalAlignment === Control.HORIZONTAL_ALIGNMENT_CENTER) {\r\n child._offsetLeft(this._currentMeasure.left - child._currentMeasure.left);\r\n }\r\n if (child.verticalAlignment === Control.VERTICAL_ALIGNMENT_CENTER) {\r\n child._offsetTop(this._currentMeasure.top - child._currentMeasure.top);\r\n }\r\n maxWidth = Math.max(maxWidth, child._currentMeasure.left - this._currentMeasure.left + child._currentMeasure.width + child.paddingRightInPixels);\r\n maxHeight = Math.max(maxHeight, child._currentMeasure.top - this._currentMeasure.top + child._currentMeasure.height + child.paddingBottomInPixels);\r\n }\r\n if (this._currentMeasure.width !== maxWidth) {\r\n this._width.updateInPlace(maxWidth, ValueAndUnit.UNITMODE_PIXEL);\r\n this._currentMeasure.width = maxWidth;\r\n this._rebuildLayout = true;\r\n this._isDirty = true;\r\n }\r\n if (this._currentMeasure.height !== maxHeight) {\r\n this._height.updateInPlace(maxHeight, ValueAndUnit.UNITMODE_PIXEL);\r\n this._currentMeasure.height = maxHeight;\r\n this._rebuildLayout = true;\r\n this._isDirty = true;\r\n }\r\n _super.prototype._postMeasure.call(this);\r\n };\r\n return _ScrollViewerWindow;\r\n}(Container));\r\nexport { _ScrollViewerWindow };\r\n//# sourceMappingURL=scrollViewerWindow.js.map","import { __extends } from \"tslib\";\r\nimport { BaseSlider } from \"./baseSlider\";\r\nimport { Measure } from \"../../measure\";\r\n/**\r\n * Class used to create slider controls\r\n */\r\nvar ScrollBar = /** @class */ (function (_super) {\r\n __extends(ScrollBar, _super);\r\n /**\r\n * Creates a new Slider\r\n * @param name defines the control name\r\n */\r\n function ScrollBar(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._background = \"black\";\r\n _this._borderColor = \"white\";\r\n _this._tempMeasure = new Measure(0, 0, 0, 0);\r\n return _this;\r\n }\r\n Object.defineProperty(ScrollBar.prototype, \"borderColor\", {\r\n /** Gets or sets border color */\r\n get: function () {\r\n return this._borderColor;\r\n },\r\n set: function (value) {\r\n if (this._borderColor === value) {\r\n return;\r\n }\r\n this._borderColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollBar.prototype, \"background\", {\r\n /** Gets or sets background color */\r\n get: function () {\r\n return this._background;\r\n },\r\n set: function (value) {\r\n if (this._background === value) {\r\n return;\r\n }\r\n this._background = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n ScrollBar.prototype._getTypeName = function () {\r\n return \"Scrollbar\";\r\n };\r\n ScrollBar.prototype._getThumbThickness = function () {\r\n var thumbThickness = 0;\r\n if (this._thumbWidth.isPixel) {\r\n thumbThickness = this._thumbWidth.getValue(this._host);\r\n }\r\n else {\r\n thumbThickness = this._backgroundBoxThickness * this._thumbWidth.getValue(this._host);\r\n }\r\n return thumbThickness;\r\n };\r\n ScrollBar.prototype._draw = function (context) {\r\n context.save();\r\n this._applyStates(context);\r\n this._prepareRenderingData(\"rectangle\");\r\n var left = this._renderLeft;\r\n var thumbPosition = this._getThumbPosition();\r\n context.fillStyle = this._background;\r\n context.fillRect(this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n // Value bar\r\n context.fillStyle = this.color;\r\n // Thumb\r\n if (this.isVertical) {\r\n this._tempMeasure.left = left - this._effectiveBarOffset;\r\n this._tempMeasure.top = this._currentMeasure.top + thumbPosition;\r\n this._tempMeasure.width = this._currentMeasure.width;\r\n this._tempMeasure.height = this._effectiveThumbThickness;\r\n }\r\n else {\r\n this._tempMeasure.left = this._currentMeasure.left + thumbPosition;\r\n this._tempMeasure.top = this._currentMeasure.top;\r\n this._tempMeasure.width = this._effectiveThumbThickness;\r\n this._tempMeasure.height = this._currentMeasure.height;\r\n }\r\n context.fillRect(this._tempMeasure.left, this._tempMeasure.top, this._tempMeasure.width, this._tempMeasure.height);\r\n context.restore();\r\n };\r\n /** @hidden */\r\n ScrollBar.prototype._updateValueFromPointer = function (x, y) {\r\n if (this.rotation != 0) {\r\n this._invertTransformMatrix.transformCoordinates(x, y, this._transformedPosition);\r\n x = this._transformedPosition.x;\r\n y = this._transformedPosition.y;\r\n }\r\n if (this._first) {\r\n this._first = false;\r\n this._originX = x;\r\n this._originY = y;\r\n // Check if move is required\r\n if (x < this._tempMeasure.left || x > this._tempMeasure.left + this._tempMeasure.width || y < this._tempMeasure.top || y > this._tempMeasure.top + this._tempMeasure.height) {\r\n if (this.isVertical) {\r\n this.value = this.minimum + (1 - ((y - this._currentMeasure.top) / this._currentMeasure.height)) * (this.maximum - this.minimum);\r\n }\r\n else {\r\n this.value = this.minimum + ((x - this._currentMeasure.left) / this._currentMeasure.width) * (this.maximum - this.minimum);\r\n }\r\n }\r\n }\r\n // Delta mode\r\n var delta = 0;\r\n if (this.isVertical) {\r\n delta = -((y - this._originY) / (this._currentMeasure.height - this._effectiveThumbThickness));\r\n }\r\n else {\r\n delta = (x - this._originX) / (this._currentMeasure.width - this._effectiveThumbThickness);\r\n }\r\n this.value += delta * (this.maximum - this.minimum);\r\n this._originX = x;\r\n this._originY = y;\r\n };\r\n ScrollBar.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex, pi) {\r\n this._first = true;\r\n return _super.prototype._onPointerDown.call(this, target, coordinates, pointerId, buttonIndex, pi);\r\n };\r\n return ScrollBar;\r\n}(BaseSlider));\r\nexport { ScrollBar };\r\n//# sourceMappingURL=scrollBar.js.map","import { __extends } from \"tslib\";\r\nimport { BaseSlider } from \"./baseSlider\";\r\nimport { Measure } from \"../../measure\";\r\n/**\r\n * Class used to create slider controls\r\n */\r\nvar ImageScrollBar = /** @class */ (function (_super) {\r\n __extends(ImageScrollBar, _super);\r\n /**\r\n * Creates a new ImageScrollBar\r\n * @param name defines the control name\r\n */\r\n function ImageScrollBar(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._thumbLength = 0.5;\r\n _this._thumbHeight = 1;\r\n _this._barImageHeight = 1;\r\n _this._tempMeasure = new Measure(0, 0, 0, 0);\r\n /** Number of 90° rotation to apply on the images when in vertical mode */\r\n _this.num90RotationInVerticalMode = 1;\r\n return _this;\r\n }\r\n Object.defineProperty(ImageScrollBar.prototype, \"backgroundImage\", {\r\n /**\r\n * Gets or sets the image used to render the background for horizontal bar\r\n */\r\n get: function () {\r\n return this._backgroundBaseImage;\r\n },\r\n set: function (value) {\r\n var _this = this;\r\n if (this._backgroundBaseImage === value) {\r\n return;\r\n }\r\n this._backgroundBaseImage = value;\r\n if (this.isVertical && this.num90RotationInVerticalMode !== 0) {\r\n if (!value.isLoaded) {\r\n value.onImageLoadedObservable.addOnce(function () {\r\n var rotatedValue = value._rotate90(_this.num90RotationInVerticalMode, true);\r\n _this._backgroundImage = rotatedValue;\r\n if (!rotatedValue.isLoaded) {\r\n rotatedValue.onImageLoadedObservable.addOnce(function () {\r\n _this._markAsDirty();\r\n });\r\n }\r\n _this._markAsDirty();\r\n });\r\n }\r\n else {\r\n this._backgroundImage = value._rotate90(this.num90RotationInVerticalMode, true);\r\n this._markAsDirty();\r\n }\r\n }\r\n else {\r\n this._backgroundImage = value;\r\n if (value && !value.isLoaded) {\r\n value.onImageLoadedObservable.addOnce(function () {\r\n _this._markAsDirty();\r\n });\r\n }\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageScrollBar.prototype, \"thumbImage\", {\r\n /**\r\n * Gets or sets the image used to render the thumb\r\n */\r\n get: function () {\r\n return this._thumbBaseImage;\r\n },\r\n set: function (value) {\r\n var _this = this;\r\n if (this._thumbBaseImage === value) {\r\n return;\r\n }\r\n this._thumbBaseImage = value;\r\n if (this.isVertical && this.num90RotationInVerticalMode !== 0) {\r\n if (!value.isLoaded) {\r\n value.onImageLoadedObservable.addOnce(function () {\r\n var rotatedValue = value._rotate90(-_this.num90RotationInVerticalMode, true);\r\n _this._thumbImage = rotatedValue;\r\n if (!rotatedValue.isLoaded) {\r\n rotatedValue.onImageLoadedObservable.addOnce(function () {\r\n _this._markAsDirty();\r\n });\r\n }\r\n _this._markAsDirty();\r\n });\r\n }\r\n else {\r\n this._thumbImage = value._rotate90(-this.num90RotationInVerticalMode, true);\r\n this._markAsDirty();\r\n }\r\n }\r\n else {\r\n this._thumbImage = value;\r\n if (value && !value.isLoaded) {\r\n value.onImageLoadedObservable.addOnce(function () {\r\n _this._markAsDirty();\r\n });\r\n }\r\n this._markAsDirty();\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageScrollBar.prototype, \"thumbLength\", {\r\n /**\r\n * Gets or sets the length of the thumb\r\n */\r\n get: function () {\r\n return this._thumbLength;\r\n },\r\n set: function (value) {\r\n if (this._thumbLength === value) {\r\n return;\r\n }\r\n this._thumbLength = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageScrollBar.prototype, \"thumbHeight\", {\r\n /**\r\n * Gets or sets the height of the thumb\r\n */\r\n get: function () {\r\n return this._thumbHeight;\r\n },\r\n set: function (value) {\r\n if (this._thumbLength === value) {\r\n return;\r\n }\r\n this._thumbHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageScrollBar.prototype, \"barImageHeight\", {\r\n /**\r\n * Gets or sets the height of the bar image\r\n */\r\n get: function () {\r\n return this._barImageHeight;\r\n },\r\n set: function (value) {\r\n if (this._barImageHeight === value) {\r\n return;\r\n }\r\n this._barImageHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n ImageScrollBar.prototype._getTypeName = function () {\r\n return \"ImageScrollBar\";\r\n };\r\n ImageScrollBar.prototype._getThumbThickness = function () {\r\n var thumbThickness = 0;\r\n if (this._thumbWidth.isPixel) {\r\n thumbThickness = this._thumbWidth.getValue(this._host);\r\n }\r\n else {\r\n thumbThickness = this._backgroundBoxThickness * this._thumbWidth.getValue(this._host);\r\n }\r\n return thumbThickness;\r\n };\r\n ImageScrollBar.prototype._draw = function (context) {\r\n context.save();\r\n this._applyStates(context);\r\n this._prepareRenderingData(\"rectangle\");\r\n var thumbPosition = this._getThumbPosition();\r\n var left = this._renderLeft;\r\n var top = this._renderTop;\r\n var width = this._renderWidth;\r\n var height = this._renderHeight;\r\n // Background\r\n if (this._backgroundImage) {\r\n this._tempMeasure.copyFromFloats(left, top, width, height);\r\n if (this.isVertical) {\r\n this._tempMeasure.copyFromFloats(left + width * (1 - this._barImageHeight) * 0.5, this._currentMeasure.top, width * this._barImageHeight, height);\r\n this._tempMeasure.height += this._effectiveThumbThickness;\r\n this._backgroundImage._currentMeasure.copyFrom(this._tempMeasure);\r\n }\r\n else {\r\n this._tempMeasure.copyFromFloats(this._currentMeasure.left, top + height * (1 - this._barImageHeight) * 0.5, width, height * this._barImageHeight);\r\n this._tempMeasure.width += this._effectiveThumbThickness;\r\n this._backgroundImage._currentMeasure.copyFrom(this._tempMeasure);\r\n }\r\n this._backgroundImage._draw(context);\r\n }\r\n // Thumb\r\n if (this.isVertical) {\r\n this._tempMeasure.copyFromFloats(left - this._effectiveBarOffset + this._currentMeasure.width * (1 - this._thumbHeight) * 0.5, this._currentMeasure.top + thumbPosition, this._currentMeasure.width * this._thumbHeight, this._effectiveThumbThickness);\r\n }\r\n else {\r\n this._tempMeasure.copyFromFloats(this._currentMeasure.left + thumbPosition, this._currentMeasure.top + this._currentMeasure.height * (1 - this._thumbHeight) * 0.5, this._effectiveThumbThickness, this._currentMeasure.height * this._thumbHeight);\r\n }\r\n if (this._thumbImage) {\r\n this._thumbImage._currentMeasure.copyFrom(this._tempMeasure);\r\n this._thumbImage._draw(context);\r\n }\r\n context.restore();\r\n };\r\n /** @hidden */\r\n ImageScrollBar.prototype._updateValueFromPointer = function (x, y) {\r\n if (this.rotation != 0) {\r\n this._invertTransformMatrix.transformCoordinates(x, y, this._transformedPosition);\r\n x = this._transformedPosition.x;\r\n y = this._transformedPosition.y;\r\n }\r\n if (this._first) {\r\n this._first = false;\r\n this._originX = x;\r\n this._originY = y;\r\n // Check if move is required\r\n if (x < this._tempMeasure.left || x > this._tempMeasure.left + this._tempMeasure.width || y < this._tempMeasure.top || y > this._tempMeasure.top + this._tempMeasure.height) {\r\n if (this.isVertical) {\r\n this.value = this.minimum + (1 - ((y - this._currentMeasure.top) / this._currentMeasure.height)) * (this.maximum - this.minimum);\r\n }\r\n else {\r\n this.value = this.minimum + ((x - this._currentMeasure.left) / this._currentMeasure.width) * (this.maximum - this.minimum);\r\n }\r\n }\r\n }\r\n // Delta mode\r\n var delta = 0;\r\n if (this.isVertical) {\r\n delta = -((y - this._originY) / (this._currentMeasure.height - this._effectiveThumbThickness));\r\n }\r\n else {\r\n delta = (x - this._originX) / (this._currentMeasure.width - this._effectiveThumbThickness);\r\n }\r\n this.value += delta * (this.maximum - this.minimum);\r\n this._originX = x;\r\n this._originY = y;\r\n };\r\n ImageScrollBar.prototype._onPointerDown = function (target, coordinates, pointerId, buttonIndex, pi) {\r\n this._first = true;\r\n return _super.prototype._onPointerDown.call(this, target, coordinates, pointerId, buttonIndex, pi);\r\n };\r\n return ImageScrollBar;\r\n}(BaseSlider));\r\nexport { ImageScrollBar };\r\n//# sourceMappingURL=imageScrollBar.js.map","import { __extends } from \"tslib\";\r\nimport { Rectangle } from \"../rectangle\";\r\nimport { Grid } from \"../grid\";\r\nimport { Control } from \"../control\";\r\nimport { _ScrollViewerWindow } from \"./scrollViewerWindow\";\r\nimport { ScrollBar } from \"../sliders/scrollBar\";\r\nimport { ImageScrollBar } from \"../sliders/imageScrollBar\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to hold a viewer window and sliders in a grid\r\n*/\r\nvar ScrollViewer = /** @class */ (function (_super) {\r\n __extends(ScrollViewer, _super);\r\n /**\r\n * Creates a new ScrollViewer\r\n * @param name of ScrollViewer\r\n */\r\n function ScrollViewer(name, isImageBased) {\r\n var _this = _super.call(this, name) || this;\r\n _this._barSize = 20;\r\n _this._pointerIsOver = false;\r\n _this._wheelPrecision = 0.05;\r\n _this._thumbLength = 0.5;\r\n _this._thumbHeight = 1;\r\n _this._barImageHeight = 1;\r\n _this._horizontalBarImageHeight = 1;\r\n _this._verticalBarImageHeight = 1;\r\n _this._oldWindowContentsWidth = 0;\r\n _this._oldWindowContentsHeight = 0;\r\n _this._forceHorizontalBar = false;\r\n _this._forceVerticalBar = false;\r\n _this._useImageBar = isImageBased ? isImageBased : false;\r\n _this.onDirtyObservable.add(function () {\r\n _this._horizontalBarSpace.color = _this.color;\r\n _this._verticalBarSpace.color = _this.color;\r\n _this._dragSpace.color = _this.color;\r\n });\r\n _this.onPointerEnterObservable.add(function () {\r\n _this._pointerIsOver = true;\r\n });\r\n _this.onPointerOutObservable.add(function () {\r\n _this._pointerIsOver = false;\r\n });\r\n _this._grid = new Grid();\r\n if (_this._useImageBar) {\r\n _this._horizontalBar = new ImageScrollBar();\r\n _this._verticalBar = new ImageScrollBar();\r\n }\r\n else {\r\n _this._horizontalBar = new ScrollBar();\r\n _this._verticalBar = new ScrollBar();\r\n }\r\n _this._window = new _ScrollViewerWindow(\"scrollViewer_window\");\r\n _this._window.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _this._window.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n _this._grid.addColumnDefinition(1);\r\n _this._grid.addColumnDefinition(0, true);\r\n _this._grid.addRowDefinition(1);\r\n _this._grid.addRowDefinition(0, true);\r\n _super.prototype.addControl.call(_this, _this._grid);\r\n _this._grid.addControl(_this._window, 0, 0);\r\n _this._verticalBarSpace = new Rectangle();\r\n _this._verticalBarSpace.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _this._verticalBarSpace.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n _this._verticalBarSpace.thickness = 1;\r\n _this._grid.addControl(_this._verticalBarSpace, 0, 1);\r\n _this._addBar(_this._verticalBar, _this._verticalBarSpace, true, Math.PI);\r\n _this._horizontalBarSpace = new Rectangle();\r\n _this._horizontalBarSpace.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n _this._horizontalBarSpace.verticalAlignment = Control.VERTICAL_ALIGNMENT_TOP;\r\n _this._horizontalBarSpace.thickness = 1;\r\n _this._grid.addControl(_this._horizontalBarSpace, 1, 0);\r\n _this._addBar(_this._horizontalBar, _this._horizontalBarSpace, false, 0);\r\n _this._dragSpace = new Rectangle();\r\n _this._dragSpace.thickness = 1;\r\n _this._grid.addControl(_this._dragSpace, 1, 1);\r\n // Colors\r\n if (!_this._useImageBar) {\r\n _this.barColor = \"grey\";\r\n _this.barBackground = \"transparent\";\r\n }\r\n return _this;\r\n }\r\n Object.defineProperty(ScrollViewer.prototype, \"horizontalBar\", {\r\n /**\r\n * Gets the horizontal scrollbar\r\n */\r\n get: function () {\r\n return this._horizontalBar;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"verticalBar\", {\r\n /**\r\n * Gets the vertical scrollbar\r\n */\r\n get: function () {\r\n return this._verticalBar;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Adds a new control to the current container\r\n * @param control defines the control to add\r\n * @returns the current container\r\n */\r\n ScrollViewer.prototype.addControl = function (control) {\r\n if (!control) {\r\n return this;\r\n }\r\n this._window.addControl(control);\r\n return this;\r\n };\r\n /**\r\n * Removes a control from the current container\r\n * @param control defines the control to remove\r\n * @returns the current container\r\n */\r\n ScrollViewer.prototype.removeControl = function (control) {\r\n this._window.removeControl(control);\r\n return this;\r\n };\r\n Object.defineProperty(ScrollViewer.prototype, \"children\", {\r\n /** Gets the list of children */\r\n get: function () {\r\n return this._window.children;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n ScrollViewer.prototype._flagDescendantsAsMatrixDirty = function () {\r\n for (var _i = 0, _a = this._children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n child._markMatrixAsDirty();\r\n }\r\n };\r\n Object.defineProperty(ScrollViewer.prototype, \"freezeControls\", {\r\n /**\r\n * Freezes or unfreezes the controls in the window.\r\n * When controls are frozen, the scroll viewer can render a lot more quickly but updates to positions/sizes of controls\r\n * are not taken into account. If you want to change positions/sizes, unfreeze, perform the changes then freeze again\r\n */\r\n get: function () {\r\n return this._window.freezeControls;\r\n },\r\n set: function (value) {\r\n this._window.freezeControls = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"bucketWidth\", {\r\n /** Gets the bucket width */\r\n get: function () {\r\n return this._window.bucketWidth;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"bucketHeight\", {\r\n /** Gets the bucket height */\r\n get: function () {\r\n return this._window.bucketHeight;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Sets the bucket sizes.\r\n * When freezeControls is true, setting a non-zero bucket size will improve performances by updating only\r\n * controls that are visible. The bucket sizes is used to subdivide (internally) the window area to smaller areas into which\r\n * controls are dispatched. So, the size should be roughly equals to the mean size of all the controls of\r\n * the window. To disable the usage of buckets, sets either width or height (or both) to 0.\r\n * Please note that using this option will raise the memory usage (the higher the bucket sizes, the less memory\r\n * used), that's why it is not enabled by default.\r\n * @param width width of the bucket\r\n * @param height height of the bucket\r\n */\r\n ScrollViewer.prototype.setBucketSizes = function (width, height) {\r\n this._window.setBucketSizes(width, height);\r\n };\r\n Object.defineProperty(ScrollViewer.prototype, \"forceHorizontalBar\", {\r\n /**\r\n * Forces the horizontal scroll bar to be displayed\r\n */\r\n get: function () {\r\n return this._forceHorizontalBar;\r\n },\r\n set: function (value) {\r\n this._grid.setRowDefinition(1, value ? this._barSize : 0, true);\r\n this._horizontalBar.isVisible = value;\r\n this._forceHorizontalBar = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"forceVerticalBar\", {\r\n /**\r\n * Forces the vertical scroll bar to be displayed\r\n */\r\n get: function () {\r\n return this._forceVerticalBar;\r\n },\r\n set: function (value) {\r\n this._grid.setColumnDefinition(1, value ? this._barSize : 0, true);\r\n this._verticalBar.isVisible = value;\r\n this._forceVerticalBar = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** Reset the scroll viewer window to initial size */\r\n ScrollViewer.prototype.resetWindow = function () {\r\n this._window.width = \"100%\";\r\n this._window.height = \"100%\";\r\n };\r\n ScrollViewer.prototype._getTypeName = function () {\r\n return \"ScrollViewer\";\r\n };\r\n ScrollViewer.prototype._buildClientSizes = function () {\r\n var ratio = this.host.idealRatio;\r\n this._window.parentClientWidth = this._currentMeasure.width - (this._verticalBar.isVisible || this.forceVerticalBar ? this._barSize * ratio : 0) - 2 * this.thickness;\r\n this._window.parentClientHeight = this._currentMeasure.height - (this._horizontalBar.isVisible || this.forceHorizontalBar ? this._barSize * ratio : 0) - 2 * this.thickness;\r\n this._clientWidth = this._window.parentClientWidth;\r\n this._clientHeight = this._window.parentClientHeight;\r\n };\r\n ScrollViewer.prototype._additionalProcessing = function (parentMeasure, context) {\r\n _super.prototype._additionalProcessing.call(this, parentMeasure, context);\r\n this._buildClientSizes();\r\n };\r\n ScrollViewer.prototype._postMeasure = function () {\r\n _super.prototype._postMeasure.call(this);\r\n this._updateScroller();\r\n this._setWindowPosition(false);\r\n };\r\n Object.defineProperty(ScrollViewer.prototype, \"wheelPrecision\", {\r\n /**\r\n * Gets or sets the mouse wheel precision\r\n * from 0 to 1 with a default value of 0.05\r\n * */\r\n get: function () {\r\n return this._wheelPrecision;\r\n },\r\n set: function (value) {\r\n if (this._wheelPrecision === value) {\r\n return;\r\n }\r\n if (value < 0) {\r\n value = 0;\r\n }\r\n if (value > 1) {\r\n value = 1;\r\n }\r\n this._wheelPrecision = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"scrollBackground\", {\r\n /** Gets or sets the scroll bar container background color */\r\n get: function () {\r\n return this._horizontalBarSpace.background;\r\n },\r\n set: function (color) {\r\n if (this._horizontalBarSpace.background === color) {\r\n return;\r\n }\r\n this._horizontalBarSpace.background = color;\r\n this._verticalBarSpace.background = color;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"barColor\", {\r\n /** Gets or sets the bar color */\r\n get: function () {\r\n return this._barColor;\r\n },\r\n set: function (color) {\r\n if (this._barColor === color) {\r\n return;\r\n }\r\n this._barColor = color;\r\n this._horizontalBar.color = color;\r\n this._verticalBar.color = color;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"thumbImage\", {\r\n /** Gets or sets the bar image */\r\n get: function () {\r\n return this._barImage;\r\n },\r\n set: function (value) {\r\n if (this._barImage === value) {\r\n return;\r\n }\r\n this._barImage = value;\r\n var hb = this._horizontalBar;\r\n var vb = this._verticalBar;\r\n hb.thumbImage = value;\r\n vb.thumbImage = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"horizontalThumbImage\", {\r\n /** Gets or sets the horizontal bar image */\r\n get: function () {\r\n return this._horizontalBarImage;\r\n },\r\n set: function (value) {\r\n if (this._horizontalBarImage === value) {\r\n return;\r\n }\r\n this._horizontalBarImage = value;\r\n var hb = this._horizontalBar;\r\n hb.thumbImage = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"verticalThumbImage\", {\r\n /** Gets or sets the vertical bar image */\r\n get: function () {\r\n return this._verticalBarImage;\r\n },\r\n set: function (value) {\r\n if (this._verticalBarImage === value) {\r\n return;\r\n }\r\n this._verticalBarImage = value;\r\n var vb = this._verticalBar;\r\n vb.thumbImage = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"barSize\", {\r\n /** Gets or sets the size of the bar */\r\n get: function () {\r\n return this._barSize;\r\n },\r\n set: function (value) {\r\n if (this._barSize === value) {\r\n return;\r\n }\r\n this._barSize = value;\r\n this._markAsDirty();\r\n if (this._horizontalBar.isVisible) {\r\n this._grid.setRowDefinition(1, this._barSize, true);\r\n }\r\n if (this._verticalBar.isVisible) {\r\n this._grid.setColumnDefinition(1, this._barSize, true);\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"thumbLength\", {\r\n /** Gets or sets the length of the thumb */\r\n get: function () {\r\n return this._thumbLength;\r\n },\r\n set: function (value) {\r\n if (this._thumbLength === value) {\r\n return;\r\n }\r\n if (value <= 0) {\r\n value = 0.1;\r\n }\r\n if (value > 1) {\r\n value = 1;\r\n }\r\n this._thumbLength = value;\r\n var hb = this._horizontalBar;\r\n var vb = this._verticalBar;\r\n hb.thumbLength = value;\r\n vb.thumbLength = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"thumbHeight\", {\r\n /** Gets or sets the height of the thumb */\r\n get: function () {\r\n return this._thumbHeight;\r\n },\r\n set: function (value) {\r\n if (this._thumbHeight === value) {\r\n return;\r\n }\r\n if (value <= 0) {\r\n value = 0.1;\r\n }\r\n if (value > 1) {\r\n value = 1;\r\n }\r\n this._thumbHeight = value;\r\n var hb = this._horizontalBar;\r\n var vb = this._verticalBar;\r\n hb.thumbHeight = value;\r\n vb.thumbHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"barImageHeight\", {\r\n /** Gets or sets the height of the bar image */\r\n get: function () {\r\n return this._barImageHeight;\r\n },\r\n set: function (value) {\r\n if (this._barImageHeight === value) {\r\n return;\r\n }\r\n if (value <= 0) {\r\n value = 0.1;\r\n }\r\n if (value > 1) {\r\n value = 1;\r\n }\r\n this._barImageHeight = value;\r\n var hb = this._horizontalBar;\r\n var vb = this._verticalBar;\r\n hb.barImageHeight = value;\r\n vb.barImageHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"horizontalBarImageHeight\", {\r\n /** Gets or sets the height of the horizontal bar image */\r\n get: function () {\r\n return this._horizontalBarImageHeight;\r\n },\r\n set: function (value) {\r\n if (this._horizontalBarImageHeight === value) {\r\n return;\r\n }\r\n if (value <= 0) {\r\n value = 0.1;\r\n }\r\n if (value > 1) {\r\n value = 1;\r\n }\r\n this._horizontalBarImageHeight = value;\r\n var hb = this._horizontalBar;\r\n hb.barImageHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"verticalBarImageHeight\", {\r\n /** Gets or sets the height of the vertical bar image */\r\n get: function () {\r\n return this._verticalBarImageHeight;\r\n },\r\n set: function (value) {\r\n if (this._verticalBarImageHeight === value) {\r\n return;\r\n }\r\n if (value <= 0) {\r\n value = 0.1;\r\n }\r\n if (value > 1) {\r\n value = 1;\r\n }\r\n this._verticalBarImageHeight = value;\r\n var vb = this._verticalBar;\r\n vb.barImageHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"barBackground\", {\r\n /** Gets or sets the bar background */\r\n get: function () {\r\n return this._barBackground;\r\n },\r\n set: function (color) {\r\n if (this._barBackground === color) {\r\n return;\r\n }\r\n this._barBackground = color;\r\n var hb = this._horizontalBar;\r\n var vb = this._verticalBar;\r\n hb.background = color;\r\n vb.background = color;\r\n this._dragSpace.background = color;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"barImage\", {\r\n /** Gets or sets the bar background image */\r\n get: function () {\r\n return this._barBackgroundImage;\r\n },\r\n set: function (value) {\r\n if (this._barBackgroundImage === value) {\r\n }\r\n this._barBackgroundImage = value;\r\n var hb = this._horizontalBar;\r\n var vb = this._verticalBar;\r\n hb.backgroundImage = value;\r\n vb.backgroundImage = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"horizontalBarImage\", {\r\n /** Gets or sets the horizontal bar background image */\r\n get: function () {\r\n return this._horizontalBarBackgroundImage;\r\n },\r\n set: function (value) {\r\n if (this._horizontalBarBackgroundImage === value) {\r\n }\r\n this._horizontalBarBackgroundImage = value;\r\n var hb = this._horizontalBar;\r\n hb.backgroundImage = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ScrollViewer.prototype, \"verticalBarImage\", {\r\n /** Gets or sets the vertical bar background image */\r\n get: function () {\r\n return this._verticalBarBackgroundImage;\r\n },\r\n set: function (value) {\r\n if (this._verticalBarBackgroundImage === value) {\r\n }\r\n this._verticalBarBackgroundImage = value;\r\n var vb = this._verticalBar;\r\n vb.backgroundImage = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n ScrollViewer.prototype._setWindowPosition = function (force) {\r\n if (force === void 0) { force = true; }\r\n var ratio = this.host.idealRatio;\r\n var windowContentsWidth = this._window._currentMeasure.width;\r\n var windowContentsHeight = this._window._currentMeasure.height;\r\n if (!force && this._oldWindowContentsWidth === windowContentsWidth && this._oldWindowContentsHeight === windowContentsHeight) {\r\n return;\r\n }\r\n this._oldWindowContentsWidth = windowContentsWidth;\r\n this._oldWindowContentsHeight = windowContentsHeight;\r\n var _endLeft = this._clientWidth - windowContentsWidth;\r\n var _endTop = this._clientHeight - windowContentsHeight;\r\n var newLeft = (this._horizontalBar.value / ratio) * _endLeft + \"px\";\r\n var newTop = (this._verticalBar.value / ratio) * _endTop + \"px\";\r\n if (newLeft !== this._window.left) {\r\n this._window.left = newLeft;\r\n if (!this.freezeControls) {\r\n this._rebuildLayout = true;\r\n }\r\n }\r\n if (newTop !== this._window.top) {\r\n this._window.top = newTop;\r\n if (!this.freezeControls) {\r\n this._rebuildLayout = true;\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n ScrollViewer.prototype._updateScroller = function () {\r\n var windowContentsWidth = this._window._currentMeasure.width;\r\n var windowContentsHeight = this._window._currentMeasure.height;\r\n if (this._horizontalBar.isVisible && windowContentsWidth <= this._clientWidth && !this.forceHorizontalBar) {\r\n this._grid.setRowDefinition(1, 0, true);\r\n this._horizontalBar.isVisible = false;\r\n this._horizontalBar.value = 0;\r\n this._rebuildLayout = true;\r\n }\r\n else if (!this._horizontalBar.isVisible && (windowContentsWidth > this._clientWidth || this.forceHorizontalBar)) {\r\n this._grid.setRowDefinition(1, this._barSize, true);\r\n this._horizontalBar.isVisible = true;\r\n this._rebuildLayout = true;\r\n }\r\n if (this._verticalBar.isVisible && windowContentsHeight <= this._clientHeight && !this.forceVerticalBar) {\r\n this._grid.setColumnDefinition(1, 0, true);\r\n this._verticalBar.isVisible = false;\r\n this._verticalBar.value = 0;\r\n this._rebuildLayout = true;\r\n }\r\n else if (!this._verticalBar.isVisible && (windowContentsHeight > this._clientHeight || this.forceVerticalBar)) {\r\n this._grid.setColumnDefinition(1, this._barSize, true);\r\n this._verticalBar.isVisible = true;\r\n this._rebuildLayout = true;\r\n }\r\n this._buildClientSizes();\r\n var ratio = this.host.idealRatio;\r\n this._horizontalBar.thumbWidth = this._thumbLength * 0.9 * (this._clientWidth / ratio) + \"px\";\r\n this._verticalBar.thumbWidth = this._thumbLength * 0.9 * (this._clientHeight / ratio) + \"px\";\r\n };\r\n ScrollViewer.prototype._link = function (host) {\r\n _super.prototype._link.call(this, host);\r\n this._attachWheel();\r\n };\r\n /** @hidden */\r\n ScrollViewer.prototype._addBar = function (barControl, barContainer, isVertical, rotation) {\r\n var _this = this;\r\n barControl.paddingLeft = 0;\r\n barControl.width = \"100%\";\r\n barControl.height = \"100%\";\r\n barControl.barOffset = 0;\r\n barControl.value = 0;\r\n barControl.maximum = 1;\r\n barControl.horizontalAlignment = Control.HORIZONTAL_ALIGNMENT_CENTER;\r\n barControl.verticalAlignment = Control.VERTICAL_ALIGNMENT_CENTER;\r\n barControl.isVertical = isVertical;\r\n barControl.rotation = rotation;\r\n barControl.isVisible = false;\r\n barContainer.addControl(barControl);\r\n barControl.onValueChangedObservable.add(function (value) {\r\n _this._setWindowPosition();\r\n });\r\n };\r\n /** @hidden */\r\n ScrollViewer.prototype._attachWheel = function () {\r\n var _this = this;\r\n if (!this._host || this._onWheelObserver) {\r\n return;\r\n }\r\n this._onWheelObserver = this.onWheelObservable.add(function (pi) {\r\n if (!_this._pointerIsOver) {\r\n return;\r\n }\r\n if (_this._verticalBar.isVisible == true) {\r\n if (pi.y < 0 && _this._verticalBar.value > 0) {\r\n _this._verticalBar.value -= _this._wheelPrecision;\r\n }\r\n else if (pi.y > 0 && _this._verticalBar.value < _this._verticalBar.maximum) {\r\n _this._verticalBar.value += _this._wheelPrecision;\r\n }\r\n }\r\n if (_this._horizontalBar.isVisible == true) {\r\n if (pi.x < 0 && _this._horizontalBar.value < _this._horizontalBar.maximum) {\r\n _this._horizontalBar.value += _this._wheelPrecision;\r\n }\r\n else if (pi.x > 0 && _this._horizontalBar.value > 0) {\r\n _this._horizontalBar.value -= _this._wheelPrecision;\r\n }\r\n }\r\n });\r\n };\r\n ScrollViewer.prototype._renderHighlightSpecific = function (context) {\r\n if (!this.isHighlighted) {\r\n return;\r\n }\r\n _super.prototype._renderHighlightSpecific.call(this, context);\r\n this._grid._renderHighlightSpecific(context);\r\n context.restore();\r\n };\r\n /** Releases associated resources */\r\n ScrollViewer.prototype.dispose = function () {\r\n this.onWheelObservable.remove(this._onWheelObserver);\r\n this._onWheelObserver = null;\r\n _super.prototype.dispose.call(this);\r\n };\r\n return ScrollViewer;\r\n}(Rectangle));\r\nexport { ScrollViewer };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.ScrollViewer\"] = ScrollViewer;\r\n//# sourceMappingURL=scrollViewer.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { StackPanel } from \"./stackPanel\";\r\nimport { Button } from \"./button\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to store key control properties\r\n */\r\nvar KeyPropertySet = /** @class */ (function () {\r\n function KeyPropertySet() {\r\n }\r\n return KeyPropertySet;\r\n}());\r\nexport { KeyPropertySet };\r\n/**\r\n * Class used to create virtual keyboard\r\n */\r\nvar VirtualKeyboard = /** @class */ (function (_super) {\r\n __extends(VirtualKeyboard, _super);\r\n function VirtualKeyboard() {\r\n var _this = _super !== null && _super.apply(this, arguments) || this;\r\n /** Observable raised when a key is pressed */\r\n _this.onKeyPressObservable = new Observable();\r\n /** Gets or sets default key button width */\r\n _this.defaultButtonWidth = \"40px\";\r\n /** Gets or sets default key button height */\r\n _this.defaultButtonHeight = \"40px\";\r\n /** Gets or sets default key button left padding */\r\n _this.defaultButtonPaddingLeft = \"2px\";\r\n /** Gets or sets default key button right padding */\r\n _this.defaultButtonPaddingRight = \"2px\";\r\n /** Gets or sets default key button top padding */\r\n _this.defaultButtonPaddingTop = \"2px\";\r\n /** Gets or sets default key button bottom padding */\r\n _this.defaultButtonPaddingBottom = \"2px\";\r\n /** Gets or sets default key button foreground color */\r\n _this.defaultButtonColor = \"#DDD\";\r\n /** Gets or sets default key button background color */\r\n _this.defaultButtonBackground = \"#070707\";\r\n /** Gets or sets shift button foreground color */\r\n _this.shiftButtonColor = \"#7799FF\";\r\n /** Gets or sets shift button thickness*/\r\n _this.selectedShiftThickness = 1;\r\n /** Gets shift key state */\r\n _this.shiftState = 0;\r\n _this._currentlyConnectedInputText = null;\r\n _this._connectedInputTexts = [];\r\n _this._onKeyPressObserver = null;\r\n return _this;\r\n }\r\n VirtualKeyboard.prototype._getTypeName = function () {\r\n return \"VirtualKeyboard\";\r\n };\r\n VirtualKeyboard.prototype._createKey = function (key, propertySet) {\r\n var _this = this;\r\n var button = Button.CreateSimpleButton(key, key);\r\n button.width = propertySet && propertySet.width ? propertySet.width : this.defaultButtonWidth;\r\n button.height = propertySet && propertySet.height ? propertySet.height : this.defaultButtonHeight;\r\n button.color = propertySet && propertySet.color ? propertySet.color : this.defaultButtonColor;\r\n button.background = propertySet && propertySet.background ? propertySet.background : this.defaultButtonBackground;\r\n button.paddingLeft = propertySet && propertySet.paddingLeft ? propertySet.paddingLeft : this.defaultButtonPaddingLeft;\r\n button.paddingRight = propertySet && propertySet.paddingRight ? propertySet.paddingRight : this.defaultButtonPaddingRight;\r\n button.paddingTop = propertySet && propertySet.paddingTop ? propertySet.paddingTop : this.defaultButtonPaddingTop;\r\n button.paddingBottom = propertySet && propertySet.paddingBottom ? propertySet.paddingBottom : this.defaultButtonPaddingBottom;\r\n button.thickness = 0;\r\n button.isFocusInvisible = true;\r\n button.shadowColor = this.shadowColor;\r\n button.shadowBlur = this.shadowBlur;\r\n button.shadowOffsetX = this.shadowOffsetX;\r\n button.shadowOffsetY = this.shadowOffsetY;\r\n button.onPointerUpObservable.add(function () {\r\n _this.onKeyPressObservable.notifyObservers(key);\r\n });\r\n return button;\r\n };\r\n /**\r\n * Adds a new row of keys\r\n * @param keys defines the list of keys to add\r\n * @param propertySets defines the associated property sets\r\n */\r\n VirtualKeyboard.prototype.addKeysRow = function (keys, propertySets) {\r\n var panel = new StackPanel();\r\n panel.isVertical = false;\r\n panel.isFocusInvisible = true;\r\n var maxKey = null;\r\n for (var i = 0; i < keys.length; i++) {\r\n var properties = null;\r\n if (propertySets && propertySets.length === keys.length) {\r\n properties = propertySets[i];\r\n }\r\n var key = this._createKey(keys[i], properties);\r\n if (!maxKey || key.heightInPixels > maxKey.heightInPixels) {\r\n maxKey = key;\r\n }\r\n panel.addControl(key);\r\n }\r\n panel.height = maxKey ? maxKey.height : this.defaultButtonHeight;\r\n this.addControl(panel);\r\n };\r\n /**\r\n * Set the shift key to a specific state\r\n * @param shiftState defines the new shift state\r\n */\r\n VirtualKeyboard.prototype.applyShiftState = function (shiftState) {\r\n if (!this.children) {\r\n return;\r\n }\r\n for (var i = 0; i < this.children.length; i++) {\r\n var row = this.children[i];\r\n if (!row || !row.children) {\r\n continue;\r\n }\r\n var rowContainer = row;\r\n for (var j = 0; j < rowContainer.children.length; j++) {\r\n var button = rowContainer.children[j];\r\n if (!button || !button.children[0]) {\r\n continue;\r\n }\r\n var button_tblock = button.children[0];\r\n if (button_tblock.text === \"\\u21E7\") {\r\n button.color = (shiftState ? this.shiftButtonColor : this.defaultButtonColor);\r\n button.thickness = (shiftState > 1 ? this.selectedShiftThickness : 0);\r\n }\r\n button_tblock.text = (shiftState > 0 ? button_tblock.text.toUpperCase() : button_tblock.text.toLowerCase());\r\n }\r\n }\r\n };\r\n Object.defineProperty(VirtualKeyboard.prototype, \"connectedInputText\", {\r\n /** Gets the input text control currently attached to the keyboard */\r\n get: function () {\r\n return this._currentlyConnectedInputText;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Connects the keyboard with an input text control\r\n *\r\n * @param input defines the target control\r\n */\r\n VirtualKeyboard.prototype.connect = function (input) {\r\n var _this = this;\r\n var inputTextAlreadyConnected = this._connectedInputTexts.some(function (a) { return a.input === input; });\r\n if (inputTextAlreadyConnected) {\r\n return;\r\n }\r\n if (this._onKeyPressObserver === null) {\r\n this._onKeyPressObserver = this.onKeyPressObservable.add(function (key) {\r\n if (!_this._currentlyConnectedInputText) {\r\n return;\r\n }\r\n _this._currentlyConnectedInputText._host.focusedControl = _this._currentlyConnectedInputText;\r\n switch (key) {\r\n case \"\\u21E7\":\r\n _this.shiftState++;\r\n if (_this.shiftState > 2) {\r\n _this.shiftState = 0;\r\n }\r\n _this.applyShiftState(_this.shiftState);\r\n return;\r\n case \"\\u2190\":\r\n _this._currentlyConnectedInputText.processKey(8);\r\n return;\r\n case \"\\u21B5\":\r\n _this._currentlyConnectedInputText.processKey(13);\r\n return;\r\n }\r\n _this._currentlyConnectedInputText.processKey(-1, (_this.shiftState ? key.toUpperCase() : key));\r\n if (_this.shiftState === 1) {\r\n _this.shiftState = 0;\r\n _this.applyShiftState(_this.shiftState);\r\n }\r\n });\r\n }\r\n this.isVisible = false;\r\n this._currentlyConnectedInputText = input;\r\n input._connectedVirtualKeyboard = this;\r\n // Events hooking\r\n var onFocusObserver = input.onFocusObservable.add(function () {\r\n _this._currentlyConnectedInputText = input;\r\n input._connectedVirtualKeyboard = _this;\r\n _this.isVisible = true;\r\n });\r\n var onBlurObserver = input.onBlurObservable.add(function () {\r\n input._connectedVirtualKeyboard = null;\r\n _this._currentlyConnectedInputText = null;\r\n _this.isVisible = false;\r\n });\r\n this._connectedInputTexts.push({\r\n input: input,\r\n onBlurObserver: onBlurObserver,\r\n onFocusObserver: onFocusObserver\r\n });\r\n };\r\n /**\r\n * Disconnects the keyboard from connected InputText controls\r\n *\r\n * @param input optionally defines a target control, otherwise all are disconnected\r\n */\r\n VirtualKeyboard.prototype.disconnect = function (input) {\r\n var _this = this;\r\n if (input) {\r\n // .find not available on IE\r\n var filtered = this._connectedInputTexts.filter(function (a) { return a.input === input; });\r\n if (filtered.length === 1) {\r\n this._removeConnectedInputObservables(filtered[0]);\r\n this._connectedInputTexts = this._connectedInputTexts.filter(function (a) { return a.input !== input; });\r\n if (this._currentlyConnectedInputText === input) {\r\n this._currentlyConnectedInputText = null;\r\n }\r\n }\r\n }\r\n else {\r\n this._connectedInputTexts.forEach(function (connectedInputText) {\r\n _this._removeConnectedInputObservables(connectedInputText);\r\n });\r\n this._connectedInputTexts = [];\r\n }\r\n if (this._connectedInputTexts.length === 0) {\r\n this._currentlyConnectedInputText = null;\r\n this.onKeyPressObservable.remove(this._onKeyPressObserver);\r\n this._onKeyPressObserver = null;\r\n }\r\n };\r\n VirtualKeyboard.prototype._removeConnectedInputObservables = function (connectedInputText) {\r\n connectedInputText.input._connectedVirtualKeyboard = null;\r\n connectedInputText.input.onFocusObservable.remove(connectedInputText.onFocusObserver);\r\n connectedInputText.input.onBlurObservable.remove(connectedInputText.onBlurObserver);\r\n };\r\n /**\r\n * Release all resources\r\n */\r\n VirtualKeyboard.prototype.dispose = function () {\r\n _super.prototype.dispose.call(this);\r\n this.disconnect();\r\n };\r\n // Statics\r\n /**\r\n * Creates a new keyboard using a default layout\r\n *\r\n * @param name defines control name\r\n * @returns a new VirtualKeyboard\r\n */\r\n VirtualKeyboard.CreateDefaultLayout = function (name) {\r\n var returnValue = new VirtualKeyboard(name);\r\n returnValue.addKeysRow([\"1\", \"2\", \"3\", \"4\", \"5\", \"6\", \"7\", \"8\", \"9\", \"0\", \"\\u2190\"]);\r\n returnValue.addKeysRow([\"q\", \"w\", \"e\", \"r\", \"t\", \"y\", \"u\", \"i\", \"o\", \"p\"]);\r\n returnValue.addKeysRow([\"a\", \"s\", \"d\", \"f\", \"g\", \"h\", \"j\", \"k\", \"l\", \";\", \"'\", \"\\u21B5\"]);\r\n returnValue.addKeysRow([\"\\u21E7\", \"z\", \"x\", \"c\", \"v\", \"b\", \"n\", \"m\", \",\", \".\", \"/\"]);\r\n returnValue.addKeysRow([\" \"], [{ width: \"200px\" }]);\r\n return returnValue;\r\n };\r\n return VirtualKeyboard;\r\n}(StackPanel));\r\nexport { VirtualKeyboard };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.VirtualKeyboard\"] = VirtualKeyboard;\r\n//# sourceMappingURL=virtualKeyboard.js.map","import { __extends } from \"tslib\";\r\nimport { Control } from \"./control\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/** Class used to render a grid */\r\nvar DisplayGrid = /** @class */ (function (_super) {\r\n __extends(DisplayGrid, _super);\r\n /**\r\n * Creates a new GridDisplayRectangle\r\n * @param name defines the control name\r\n */\r\n function DisplayGrid(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._cellWidth = 20;\r\n _this._cellHeight = 20;\r\n _this._minorLineTickness = 1;\r\n _this._minorLineColor = \"DarkGray\";\r\n _this._majorLineTickness = 2;\r\n _this._majorLineColor = \"White\";\r\n _this._majorLineFrequency = 5;\r\n _this._background = \"Black\";\r\n _this._displayMajorLines = true;\r\n _this._displayMinorLines = true;\r\n return _this;\r\n }\r\n Object.defineProperty(DisplayGrid.prototype, \"displayMinorLines\", {\r\n /** Gets or sets a boolean indicating if minor lines must be rendered (true by default)) */\r\n get: function () {\r\n return this._displayMinorLines;\r\n },\r\n set: function (value) {\r\n if (this._displayMinorLines === value) {\r\n return;\r\n }\r\n this._displayMinorLines = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"displayMajorLines\", {\r\n /** Gets or sets a boolean indicating if major lines must be rendered (true by default)) */\r\n get: function () {\r\n return this._displayMajorLines;\r\n },\r\n set: function (value) {\r\n if (this._displayMajorLines === value) {\r\n return;\r\n }\r\n this._displayMajorLines = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"background\", {\r\n /** Gets or sets background color (Black by default) */\r\n get: function () {\r\n return this._background;\r\n },\r\n set: function (value) {\r\n if (this._background === value) {\r\n return;\r\n }\r\n this._background = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"cellWidth\", {\r\n /** Gets or sets the width of each cell (20 by default) */\r\n get: function () {\r\n return this._cellWidth;\r\n },\r\n set: function (value) {\r\n this._cellWidth = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"cellHeight\", {\r\n /** Gets or sets the height of each cell (20 by default) */\r\n get: function () {\r\n return this._cellHeight;\r\n },\r\n set: function (value) {\r\n this._cellHeight = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"minorLineTickness\", {\r\n /** Gets or sets the tickness of minor lines (1 by default) */\r\n get: function () {\r\n return this._minorLineTickness;\r\n },\r\n set: function (value) {\r\n this._minorLineTickness = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"minorLineColor\", {\r\n /** Gets or sets the color of minor lines (DarkGray by default) */\r\n get: function () {\r\n return this._minorLineColor;\r\n },\r\n set: function (value) {\r\n this._minorLineColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"majorLineTickness\", {\r\n /** Gets or sets the tickness of major lines (2 by default) */\r\n get: function () {\r\n return this._majorLineTickness;\r\n },\r\n set: function (value) {\r\n this._majorLineTickness = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"majorLineColor\", {\r\n /** Gets or sets the color of major lines (White by default) */\r\n get: function () {\r\n return this._majorLineColor;\r\n },\r\n set: function (value) {\r\n this._majorLineColor = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(DisplayGrid.prototype, \"majorLineFrequency\", {\r\n /** Gets or sets the frequency of major lines (default is 1 every 5 minor lines)*/\r\n get: function () {\r\n return this._majorLineFrequency;\r\n },\r\n set: function (value) {\r\n this._majorLineFrequency = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n DisplayGrid.prototype._draw = function (context, invalidatedRectangle) {\r\n context.save();\r\n this._applyStates(context);\r\n if (this._isEnabled) {\r\n if (this._background) {\r\n context.fillStyle = this._background;\r\n context.fillRect(this._currentMeasure.left, this._currentMeasure.top, this._currentMeasure.width, this._currentMeasure.height);\r\n }\r\n var cellCountX = this._currentMeasure.width / this._cellWidth;\r\n var cellCountY = this._currentMeasure.height / this._cellHeight;\r\n // Minor lines\r\n var left = this._currentMeasure.left + this._currentMeasure.width / 2;\r\n var top_1 = this._currentMeasure.top + this._currentMeasure.height / 2;\r\n if (this._displayMinorLines) {\r\n context.strokeStyle = this._minorLineColor;\r\n context.lineWidth = this._minorLineTickness;\r\n for (var x = -cellCountX / 2; x < cellCountX / 2; x++) {\r\n var cellX = left + x * this.cellWidth;\r\n context.beginPath();\r\n context.moveTo(cellX, this._currentMeasure.top);\r\n context.lineTo(cellX, this._currentMeasure.top + this._currentMeasure.height);\r\n context.stroke();\r\n }\r\n for (var y = -cellCountY / 2; y < cellCountY / 2; y++) {\r\n var cellY = top_1 + y * this.cellHeight;\r\n context.beginPath();\r\n context.moveTo(this._currentMeasure.left, cellY);\r\n context.lineTo(this._currentMeasure.left + this._currentMeasure.width, cellY);\r\n context.stroke();\r\n }\r\n }\r\n // Major lines\r\n if (this._displayMajorLines) {\r\n context.strokeStyle = this._majorLineColor;\r\n context.lineWidth = this._majorLineTickness;\r\n for (var x = -cellCountX / 2 + this._majorLineFrequency; x < cellCountX / 2; x += this._majorLineFrequency) {\r\n var cellX = left + x * this.cellWidth;\r\n context.beginPath();\r\n context.moveTo(cellX, this._currentMeasure.top);\r\n context.lineTo(cellX, this._currentMeasure.top + this._currentMeasure.height);\r\n context.stroke();\r\n }\r\n for (var y = -cellCountY / 2 + this._majorLineFrequency; y < cellCountY / 2; y += this._majorLineFrequency) {\r\n var cellY = top_1 + y * this.cellHeight;\r\n context.moveTo(this._currentMeasure.left, cellY);\r\n context.lineTo(this._currentMeasure.left + this._currentMeasure.width, cellY);\r\n context.closePath();\r\n context.stroke();\r\n }\r\n }\r\n }\r\n context.restore();\r\n };\r\n DisplayGrid.prototype._getTypeName = function () {\r\n return \"DisplayGrid\";\r\n };\r\n return DisplayGrid;\r\n}(Control));\r\nexport { DisplayGrid };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.DisplayGrid\"] = DisplayGrid;\r\n//# sourceMappingURL=displayGrid.js.map","import { __extends } from \"tslib\";\r\nimport { BaseSlider } from \"./baseSlider\";\r\nimport { Measure } from \"../../measure\";\r\nimport { _TypeStore } from '@babylonjs/core/Misc/typeStore';\r\n/**\r\n * Class used to create slider controls based on images\r\n */\r\nvar ImageBasedSlider = /** @class */ (function (_super) {\r\n __extends(ImageBasedSlider, _super);\r\n /**\r\n * Creates a new ImageBasedSlider\r\n * @param name defines the control name\r\n */\r\n function ImageBasedSlider(name) {\r\n var _this = _super.call(this, name) || this;\r\n _this.name = name;\r\n _this._tempMeasure = new Measure(0, 0, 0, 0);\r\n return _this;\r\n }\r\n Object.defineProperty(ImageBasedSlider.prototype, \"displayThumb\", {\r\n get: function () {\r\n return this._displayThumb && this.thumbImage != null;\r\n },\r\n set: function (value) {\r\n if (this._displayThumb === value) {\r\n return;\r\n }\r\n this._displayThumb = value;\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageBasedSlider.prototype, \"backgroundImage\", {\r\n /**\r\n * Gets or sets the image used to render the background\r\n */\r\n get: function () {\r\n return this._backgroundImage;\r\n },\r\n set: function (value) {\r\n var _this = this;\r\n if (this._backgroundImage === value) {\r\n return;\r\n }\r\n this._backgroundImage = value;\r\n if (value && !value.isLoaded) {\r\n value.onImageLoadedObservable.addOnce(function () { return _this._markAsDirty(); });\r\n }\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageBasedSlider.prototype, \"valueBarImage\", {\r\n /**\r\n * Gets or sets the image used to render the value bar\r\n */\r\n get: function () {\r\n return this._valueBarImage;\r\n },\r\n set: function (value) {\r\n var _this = this;\r\n if (this._valueBarImage === value) {\r\n return;\r\n }\r\n this._valueBarImage = value;\r\n if (value && !value.isLoaded) {\r\n value.onImageLoadedObservable.addOnce(function () { return _this._markAsDirty(); });\r\n }\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ImageBasedSlider.prototype, \"thumbImage\", {\r\n /**\r\n * Gets or sets the image used to render the thumb\r\n */\r\n get: function () {\r\n return this._thumbImage;\r\n },\r\n set: function (value) {\r\n var _this = this;\r\n if (this._thumbImage === value) {\r\n return;\r\n }\r\n this._thumbImage = value;\r\n if (value && !value.isLoaded) {\r\n value.onImageLoadedObservable.addOnce(function () { return _this._markAsDirty(); });\r\n }\r\n this._markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n ImageBasedSlider.prototype._getTypeName = function () {\r\n return \"ImageBasedSlider\";\r\n };\r\n ImageBasedSlider.prototype._draw = function (context, invalidatedRectangle) {\r\n context.save();\r\n this._applyStates(context);\r\n this._prepareRenderingData(\"rectangle\");\r\n var thumbPosition = this._getThumbPosition();\r\n var left = this._renderLeft;\r\n var top = this._renderTop;\r\n var width = this._renderWidth;\r\n var height = this._renderHeight;\r\n // Background\r\n if (this._backgroundImage) {\r\n this._tempMeasure.copyFromFloats(left, top, width, height);\r\n if (this.isThumbClamped && this.displayThumb) {\r\n if (this.isVertical) {\r\n this._tempMeasure.height += this._effectiveThumbThickness;\r\n }\r\n else {\r\n this._tempMeasure.width += this._effectiveThumbThickness;\r\n }\r\n }\r\n this._backgroundImage._currentMeasure.copyFrom(this._tempMeasure);\r\n this._backgroundImage._draw(context);\r\n }\r\n // Bar\r\n if (this._valueBarImage) {\r\n if (this.isVertical) {\r\n if (this.isThumbClamped && this.displayThumb) {\r\n this._tempMeasure.copyFromFloats(left, top + thumbPosition, width, height - thumbPosition + this._effectiveThumbThickness);\r\n }\r\n else {\r\n this._tempMeasure.copyFromFloats(left, top + thumbPosition, width, height - thumbPosition);\r\n }\r\n }\r\n else {\r\n if (this.isThumbClamped && this.displayThumb) {\r\n this._tempMeasure.copyFromFloats(left, top, thumbPosition + this._effectiveThumbThickness / 2, height);\r\n }\r\n else {\r\n this._tempMeasure.copyFromFloats(left, top, thumbPosition, height);\r\n }\r\n }\r\n this._valueBarImage._currentMeasure.copyFrom(this._tempMeasure);\r\n this._valueBarImage._draw(context);\r\n }\r\n // Thumb\r\n if (this.displayThumb) {\r\n if (this.isVertical) {\r\n this._tempMeasure.copyFromFloats(left - this._effectiveBarOffset, this._currentMeasure.top + thumbPosition, this._currentMeasure.width, this._effectiveThumbThickness);\r\n }\r\n else {\r\n this._tempMeasure.copyFromFloats(this._currentMeasure.left + thumbPosition, this._currentMeasure.top, this._effectiveThumbThickness, this._currentMeasure.height);\r\n }\r\n this._thumbImage._currentMeasure.copyFrom(this._tempMeasure);\r\n this._thumbImage._draw(context);\r\n }\r\n context.restore();\r\n };\r\n return ImageBasedSlider;\r\n}(BaseSlider));\r\nexport { ImageBasedSlider };\r\n_TypeStore.RegisteredTypes[\"BABYLON.GUI.ImageBasedSlider\"] = ImageBasedSlider;\r\n//# sourceMappingURL=imageBasedSlider.js.map","import { Control } from \"./control\";\r\nimport { StackPanel } from \"./stackPanel\";\r\nimport { TextBlock } from \"./textBlock\";\r\n/**\r\n * Forcing an export so that this code will execute\r\n * @hidden\r\n */\r\nvar name = \"Statics\";\r\nexport { name };\r\n/**\r\n * Creates a stack panel that can be used to render headers\r\n * @param control defines the control to associate with the header\r\n * @param text defines the text of the header\r\n * @param size defines the size of the header\r\n * @param options defines options used to configure the header\r\n * @returns a new StackPanel\r\n */\r\nControl.AddHeader = function (control, text, size, options) {\r\n var panel = new StackPanel(\"panel\");\r\n var isHorizontal = options ? options.isHorizontal : true;\r\n var controlFirst = options ? options.controlFirst : true;\r\n panel.isVertical = !isHorizontal;\r\n var header = new TextBlock(\"header\");\r\n header.text = text;\r\n header.textHorizontalAlignment = Control.HORIZONTAL_ALIGNMENT_LEFT;\r\n if (isHorizontal) {\r\n header.width = size;\r\n }\r\n else {\r\n header.height = size;\r\n }\r\n if (controlFirst) {\r\n panel.addControl(control);\r\n panel.addControl(header);\r\n header.paddingLeft = \"5px\";\r\n }\r\n else {\r\n panel.addControl(header);\r\n panel.addControl(control);\r\n header.paddingRight = \"5px\";\r\n }\r\n header.shadowBlur = control.shadowBlur;\r\n header.shadowColor = control.shadowColor;\r\n header.shadowOffsetX = control.shadowOffsetX;\r\n header.shadowOffsetY = control.shadowOffsetY;\r\n return panel;\r\n};\r\n//# sourceMappingURL=statics.js.map","import { SceneComponentConstants } from \"../sceneComponent\";\r\n/**\r\n * Defines the layer scene component responsible to manage any layers\r\n * in a given scene.\r\n */\r\nvar LayerSceneComponent = /** @class */ (function () {\r\n /**\r\n * Creates a new instance of the component for the given scene\r\n * @param scene Defines the scene to register the component in\r\n */\r\n function LayerSceneComponent(scene) {\r\n /**\r\n * The component name helpfull to identify the component in the list of scene components.\r\n */\r\n this.name = SceneComponentConstants.NAME_LAYER;\r\n this.scene = scene;\r\n this._engine = scene.getEngine();\r\n scene.layers = new Array();\r\n }\r\n /**\r\n * Registers the component in a given scene\r\n */\r\n LayerSceneComponent.prototype.register = function () {\r\n this.scene._beforeCameraDrawStage.registerStep(SceneComponentConstants.STEP_BEFORECAMERADRAW_LAYER, this, this._drawCameraBackground);\r\n this.scene._afterCameraDrawStage.registerStep(SceneComponentConstants.STEP_AFTERCAMERADRAW_LAYER, this, this._drawCameraForeground);\r\n this.scene._beforeRenderTargetDrawStage.registerStep(SceneComponentConstants.STEP_BEFORERENDERTARGETDRAW_LAYER, this, this._drawRenderTargetBackground);\r\n this.scene._afterRenderTargetDrawStage.registerStep(SceneComponentConstants.STEP_AFTERRENDERTARGETDRAW_LAYER, this, this._drawRenderTargetForeground);\r\n };\r\n /**\r\n * Rebuilds the elements related to this component in case of\r\n * context lost for instance.\r\n */\r\n LayerSceneComponent.prototype.rebuild = function () {\r\n var layers = this.scene.layers;\r\n for (var _i = 0, layers_1 = layers; _i < layers_1.length; _i++) {\r\n var layer = layers_1[_i];\r\n layer._rebuild();\r\n }\r\n };\r\n /**\r\n * Disposes the component and the associated ressources.\r\n */\r\n LayerSceneComponent.prototype.dispose = function () {\r\n var layers = this.scene.layers;\r\n while (layers.length) {\r\n layers[0].dispose();\r\n }\r\n };\r\n LayerSceneComponent.prototype._draw = function (predicate) {\r\n var layers = this.scene.layers;\r\n if (layers.length) {\r\n this._engine.setDepthBuffer(false);\r\n for (var _i = 0, layers_2 = layers; _i < layers_2.length; _i++) {\r\n var layer = layers_2[_i];\r\n if (predicate(layer)) {\r\n layer.render();\r\n }\r\n }\r\n this._engine.setDepthBuffer(true);\r\n }\r\n };\r\n LayerSceneComponent.prototype._drawCameraPredicate = function (layer, isBackground, cameraLayerMask) {\r\n return !layer.renderOnlyInRenderTargetTextures &&\r\n layer.isBackground === isBackground &&\r\n ((layer.layerMask & cameraLayerMask) !== 0);\r\n };\r\n LayerSceneComponent.prototype._drawCameraBackground = function (camera) {\r\n var _this = this;\r\n this._draw(function (layer) {\r\n return _this._drawCameraPredicate(layer, true, camera.layerMask);\r\n });\r\n };\r\n LayerSceneComponent.prototype._drawCameraForeground = function (camera) {\r\n var _this = this;\r\n this._draw(function (layer) {\r\n return _this._drawCameraPredicate(layer, false, camera.layerMask);\r\n });\r\n };\r\n LayerSceneComponent.prototype._drawRenderTargetPredicate = function (layer, isBackground, cameraLayerMask, renderTargetTexture) {\r\n return (layer.renderTargetTextures.length > 0) &&\r\n layer.isBackground === isBackground &&\r\n (layer.renderTargetTextures.indexOf(renderTargetTexture) > -1) &&\r\n ((layer.layerMask & cameraLayerMask) !== 0);\r\n };\r\n LayerSceneComponent.prototype._drawRenderTargetBackground = function (renderTarget) {\r\n var _this = this;\r\n this._draw(function (layer) {\r\n return _this._drawRenderTargetPredicate(layer, true, _this.scene.activeCamera.layerMask, renderTarget);\r\n });\r\n };\r\n LayerSceneComponent.prototype._drawRenderTargetForeground = function (renderTarget) {\r\n var _this = this;\r\n this._draw(function (layer) {\r\n return _this._drawRenderTargetPredicate(layer, false, _this.scene.activeCamera.layerMask, renderTarget);\r\n });\r\n };\r\n /**\r\n * Adds all the elements from the container to the scene\r\n * @param container the container holding the elements\r\n */\r\n LayerSceneComponent.prototype.addFromContainer = function (container) {\r\n var _this = this;\r\n if (!container.layers) {\r\n return;\r\n }\r\n container.layers.forEach(function (layer) {\r\n _this.scene.layers.push(layer);\r\n });\r\n };\r\n /**\r\n * Removes all the elements in the container from the scene\r\n * @param container contains the elements to remove\r\n * @param dispose if the removed element should be disposed (default: false)\r\n */\r\n LayerSceneComponent.prototype.removeFromContainer = function (container, dispose) {\r\n var _this = this;\r\n if (dispose === void 0) { dispose = false; }\r\n if (!container.layers) {\r\n return;\r\n }\r\n container.layers.forEach(function (layer) {\r\n var index = _this.scene.layers.indexOf(layer);\r\n if (index !== -1) {\r\n _this.scene.layers.splice(index, 1);\r\n }\r\n if (dispose) {\r\n layer.dispose();\r\n }\r\n });\r\n };\r\n return LayerSceneComponent;\r\n}());\r\nexport { LayerSceneComponent };\r\n//# sourceMappingURL=layerSceneComponent.js.map","import { Effect } from \"../Materials/effect\";\r\nimport \"./ShadersInclude/helperFunctions\";\r\nvar name = 'layerPixelShader';\r\nvar shader = \"\\nvarying vec2 vUV;\\nuniform sampler2D textureSampler;\\n\\nuniform vec4 color;\\n\\n#include\\nvoid main(void) {\\nvec4 baseColor=texture2D(textureSampler,vUV);\\n#ifdef LINEAR\\nbaseColor.rgb=toGammaSpace(baseColor.rgb);\\n#endif\\n#ifdef ALPHATEST\\nif (baseColor.a<0.4)\\ndiscard;\\n#endif\\ngl_FragColor=baseColor*color;\\n}\";\r\nEffect.ShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var layerPixelShader = { name: name, shader: shader };\r\n//# sourceMappingURL=layer.fragment.js.map","import { Effect } from \"../Materials/effect\";\r\nvar name = 'layerVertexShader';\r\nvar shader = \"\\nattribute vec2 position;\\n\\nuniform vec2 scale;\\nuniform vec2 offset;\\nuniform mat4 textureMatrix;\\n\\nvarying vec2 vUV;\\nconst vec2 madd=vec2(0.5,0.5);\\nvoid main(void) {\\nvec2 shiftedPosition=position*scale+offset;\\nvUV=vec2(textureMatrix*vec4(shiftedPosition*madd+madd,1.0,0.0));\\ngl_Position=vec4(shiftedPosition,0.0,1.0);\\n}\";\r\nEffect.ShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var layerVertexShader = { name: name, shader: shader };\r\n//# sourceMappingURL=layer.vertex.js.map","import { Observable } from \"../Misc/observable\";\r\nimport { Vector2 } from \"../Maths/math.vector\";\r\nimport { Color4 } from '../Maths/math.color';\r\nimport { EngineStore } from \"../Engines/engineStore\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { Material } from \"../Materials/material\";\r\nimport { Texture } from \"../Materials/Textures/texture\";\r\nimport { SceneComponentConstants } from \"../sceneComponent\";\r\nimport { LayerSceneComponent } from \"./layerSceneComponent\";\r\nimport \"../Shaders/layer.fragment\";\r\nimport \"../Shaders/layer.vertex\";\r\n/**\r\n * This represents a full screen 2d layer.\r\n * This can be useful to display a picture in the background of your scene for instance.\r\n * @see https://www.babylonjs-playground.com/#08A2BS#1\r\n */\r\nvar Layer = /** @class */ (function () {\r\n /**\r\n * Instantiates a new layer.\r\n * This represents a full screen 2d layer.\r\n * This can be useful to display a picture in the background of your scene for instance.\r\n * @see https://www.babylonjs-playground.com/#08A2BS#1\r\n * @param name Define the name of the layer in the scene\r\n * @param imgUrl Define the url of the texture to display in the layer\r\n * @param scene Define the scene the layer belongs to\r\n * @param isBackground Defines whether the layer is displayed in front or behind the scene\r\n * @param color Defines a color for the layer\r\n */\r\n function Layer(\r\n /**\r\n * Define the name of the layer.\r\n */\r\n name, imgUrl, scene, isBackground, color) {\r\n this.name = name;\r\n /**\r\n * Define the scale of the layer in order to zoom in out of the texture.\r\n */\r\n this.scale = new Vector2(1, 1);\r\n /**\r\n * Define an offset for the layer in order to shift the texture.\r\n */\r\n this.offset = new Vector2(0, 0);\r\n /**\r\n * Define the alpha blending mode used in the layer in case the texture or color has an alpha.\r\n */\r\n this.alphaBlendingMode = 2;\r\n /**\r\n * Define a mask to restrict the layer to only some of the scene cameras.\r\n */\r\n this.layerMask = 0x0FFFFFFF;\r\n /**\r\n * Define the list of render target the layer is visible into.\r\n */\r\n this.renderTargetTextures = [];\r\n /**\r\n * Define if the layer is only used in renderTarget or if it also\r\n * renders in the main frame buffer of the canvas.\r\n */\r\n this.renderOnlyInRenderTargetTextures = false;\r\n this._vertexBuffers = {};\r\n /**\r\n * An event triggered when the layer is disposed.\r\n */\r\n this.onDisposeObservable = new Observable();\r\n /**\r\n * An event triggered before rendering the scene\r\n */\r\n this.onBeforeRenderObservable = new Observable();\r\n /**\r\n * An event triggered after rendering the scene\r\n */\r\n this.onAfterRenderObservable = new Observable();\r\n this.texture = imgUrl ? new Texture(imgUrl, scene, true) : null;\r\n this.isBackground = isBackground === undefined ? true : isBackground;\r\n this.color = color === undefined ? new Color4(1, 1, 1, 1) : color;\r\n this._scene = (scene || EngineStore.LastCreatedScene);\r\n var layerComponent = this._scene._getComponent(SceneComponentConstants.NAME_LAYER);\r\n if (!layerComponent) {\r\n layerComponent = new LayerSceneComponent(this._scene);\r\n this._scene._addComponent(layerComponent);\r\n }\r\n this._scene.layers.push(this);\r\n var engine = this._scene.getEngine();\r\n // VBO\r\n var vertices = [];\r\n vertices.push(1, 1);\r\n vertices.push(-1, 1);\r\n vertices.push(-1, -1);\r\n vertices.push(1, -1);\r\n var vertexBuffer = new VertexBuffer(engine, vertices, VertexBuffer.PositionKind, false, false, 2);\r\n this._vertexBuffers[VertexBuffer.PositionKind] = vertexBuffer;\r\n this._createIndexBuffer();\r\n }\r\n Object.defineProperty(Layer.prototype, \"onDispose\", {\r\n /**\r\n * Back compatibility with callback before the onDisposeObservable existed.\r\n * The set callback will be triggered when the layer has been disposed.\r\n */\r\n set: function (callback) {\r\n if (this._onDisposeObserver) {\r\n this.onDisposeObservable.remove(this._onDisposeObserver);\r\n }\r\n this._onDisposeObserver = this.onDisposeObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Layer.prototype, \"onBeforeRender\", {\r\n /**\r\n * Back compatibility with callback before the onBeforeRenderObservable existed.\r\n * The set callback will be triggered just before rendering the layer.\r\n */\r\n set: function (callback) {\r\n if (this._onBeforeRenderObserver) {\r\n this.onBeforeRenderObservable.remove(this._onBeforeRenderObserver);\r\n }\r\n this._onBeforeRenderObserver = this.onBeforeRenderObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Layer.prototype, \"onAfterRender\", {\r\n /**\r\n * Back compatibility with callback before the onAfterRenderObservable existed.\r\n * The set callback will be triggered just after rendering the layer.\r\n */\r\n set: function (callback) {\r\n if (this._onAfterRenderObserver) {\r\n this.onAfterRenderObservable.remove(this._onAfterRenderObserver);\r\n }\r\n this._onAfterRenderObserver = this.onAfterRenderObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Layer.prototype._createIndexBuffer = function () {\r\n var engine = this._scene.getEngine();\r\n // Indices\r\n var indices = [];\r\n indices.push(0);\r\n indices.push(1);\r\n indices.push(2);\r\n indices.push(0);\r\n indices.push(2);\r\n indices.push(3);\r\n this._indexBuffer = engine.createIndexBuffer(indices);\r\n };\r\n /** @hidden */\r\n Layer.prototype._rebuild = function () {\r\n var vb = this._vertexBuffers[VertexBuffer.PositionKind];\r\n if (vb) {\r\n vb._rebuild();\r\n }\r\n this._createIndexBuffer();\r\n };\r\n /**\r\n * Renders the layer in the scene.\r\n */\r\n Layer.prototype.render = function () {\r\n var engine = this._scene.getEngine();\r\n var defines = \"\";\r\n if (this.alphaTest) {\r\n defines = \"#define ALPHATEST\";\r\n }\r\n if (this.texture && !this.texture.gammaSpace) {\r\n defines += \"\\r\\n#define LINEAR\";\r\n }\r\n if (this._previousDefines !== defines) {\r\n this._previousDefines = defines;\r\n this._effect = engine.createEffect(\"layer\", [VertexBuffer.PositionKind], [\"textureMatrix\", \"color\", \"scale\", \"offset\"], [\"textureSampler\"], defines);\r\n }\r\n var currentEffect = this._effect;\r\n // Check\r\n if (!currentEffect || !currentEffect.isReady() || !this.texture || !this.texture.isReady()) {\r\n return;\r\n }\r\n var engine = this._scene.getEngine();\r\n this.onBeforeRenderObservable.notifyObservers(this);\r\n // Render\r\n engine.enableEffect(currentEffect);\r\n engine.setState(false);\r\n // Texture\r\n currentEffect.setTexture(\"textureSampler\", this.texture);\r\n currentEffect.setMatrix(\"textureMatrix\", this.texture.getTextureMatrix());\r\n // Color\r\n currentEffect.setFloat4(\"color\", this.color.r, this.color.g, this.color.b, this.color.a);\r\n // Scale / offset\r\n currentEffect.setVector2(\"offset\", this.offset);\r\n currentEffect.setVector2(\"scale\", this.scale);\r\n // VBOs\r\n engine.bindBuffers(this._vertexBuffers, this._indexBuffer, currentEffect);\r\n // Draw order\r\n if (!this.alphaTest) {\r\n engine.setAlphaMode(this.alphaBlendingMode);\r\n engine.drawElementsType(Material.TriangleFillMode, 0, 6);\r\n engine.setAlphaMode(0);\r\n }\r\n else {\r\n engine.drawElementsType(Material.TriangleFillMode, 0, 6);\r\n }\r\n this.onAfterRenderObservable.notifyObservers(this);\r\n };\r\n /**\r\n * Disposes and releases the associated ressources.\r\n */\r\n Layer.prototype.dispose = function () {\r\n var vertexBuffer = this._vertexBuffers[VertexBuffer.PositionKind];\r\n if (vertexBuffer) {\r\n vertexBuffer.dispose();\r\n this._vertexBuffers[VertexBuffer.PositionKind] = null;\r\n }\r\n if (this._indexBuffer) {\r\n this._scene.getEngine()._releaseBuffer(this._indexBuffer);\r\n this._indexBuffer = null;\r\n }\r\n if (this.texture) {\r\n this.texture.dispose();\r\n this.texture = null;\r\n }\r\n // Clean RTT list\r\n this.renderTargetTextures = [];\r\n // Remove from scene\r\n var index = this._scene.layers.indexOf(this);\r\n this._scene.layers.splice(index, 1);\r\n // Callback\r\n this.onDisposeObservable.notifyObservers(this);\r\n this.onDisposeObservable.clear();\r\n this.onAfterRenderObservable.clear();\r\n this.onBeforeRenderObservable.clear();\r\n };\r\n return Layer;\r\n}());\r\nexport { Layer };\r\n//# sourceMappingURL=layer.js.map","import { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { ValueAndUnit } from \"./valueAndUnit\";\r\n/**\r\n * Define a style used by control to automatically setup properties based on a template.\r\n * Only support font related properties so far\r\n */\r\nvar Style = /** @class */ (function () {\r\n /**\r\n * Creates a new style object\r\n * @param host defines the AdvancedDynamicTexture which hosts this style\r\n */\r\n function Style(host) {\r\n this._fontFamily = \"Arial\";\r\n this._fontStyle = \"\";\r\n this._fontWeight = \"\";\r\n /** @hidden */\r\n this._fontSize = new ValueAndUnit(18, ValueAndUnit.UNITMODE_PIXEL, false);\r\n /**\r\n * Observable raised when the style values are changed\r\n */\r\n this.onChangedObservable = new Observable();\r\n this._host = host;\r\n }\r\n Object.defineProperty(Style.prototype, \"fontSize\", {\r\n /**\r\n * Gets or sets the font size\r\n */\r\n get: function () {\r\n return this._fontSize.toString(this._host);\r\n },\r\n set: function (value) {\r\n if (this._fontSize.toString(this._host) === value) {\r\n return;\r\n }\r\n if (this._fontSize.fromString(value)) {\r\n this.onChangedObservable.notifyObservers(this);\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Style.prototype, \"fontFamily\", {\r\n /**\r\n * Gets or sets the font family\r\n */\r\n get: function () {\r\n return this._fontFamily;\r\n },\r\n set: function (value) {\r\n if (this._fontFamily === value) {\r\n return;\r\n }\r\n this._fontFamily = value;\r\n this.onChangedObservable.notifyObservers(this);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Style.prototype, \"fontStyle\", {\r\n /**\r\n * Gets or sets the font style\r\n */\r\n get: function () {\r\n return this._fontStyle;\r\n },\r\n set: function (value) {\r\n if (this._fontStyle === value) {\r\n return;\r\n }\r\n this._fontStyle = value;\r\n this.onChangedObservable.notifyObservers(this);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Style.prototype, \"fontWeight\", {\r\n /** Gets or sets font weight */\r\n get: function () {\r\n return this._fontWeight;\r\n },\r\n set: function (value) {\r\n if (this._fontWeight === value) {\r\n return;\r\n }\r\n this._fontWeight = value;\r\n this.onChangedObservable.notifyObservers(this);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** Dispose all associated resources */\r\n Style.prototype.dispose = function () {\r\n this.onChangedObservable.clear();\r\n };\r\n return Style;\r\n}());\r\nexport { Style };\r\n//# sourceMappingURL=style.js.map","/** Defines the cross module used constants to avoid circular dependncies */\r\nvar Constants = /** @class */ (function () {\r\n function Constants() {\r\n }\r\n /** Defines that alpha blending is disabled */\r\n Constants.ALPHA_DISABLE = 0;\r\n /** Defines that alpha blending is SRC ALPHA * SRC + DEST */\r\n Constants.ALPHA_ADD = 1;\r\n /** Defines that alpha blending is SRC ALPHA * SRC + (1 - SRC ALPHA) * DEST */\r\n Constants.ALPHA_COMBINE = 2;\r\n /** Defines that alpha blending is DEST - SRC * DEST */\r\n Constants.ALPHA_SUBTRACT = 3;\r\n /** Defines that alpha blending is SRC * DEST */\r\n Constants.ALPHA_MULTIPLY = 4;\r\n /** Defines that alpha blending is SRC ALPHA * SRC + (1 - SRC) * DEST */\r\n Constants.ALPHA_MAXIMIZED = 5;\r\n /** Defines that alpha blending is SRC + DEST */\r\n Constants.ALPHA_ONEONE = 6;\r\n /** Defines that alpha blending is SRC + (1 - SRC ALPHA) * DEST */\r\n Constants.ALPHA_PREMULTIPLIED = 7;\r\n /**\r\n * Defines that alpha blending is SRC + (1 - SRC ALPHA) * DEST\r\n * Alpha will be set to (1 - SRC ALPHA) * DEST ALPHA\r\n */\r\n Constants.ALPHA_PREMULTIPLIED_PORTERDUFF = 8;\r\n /** Defines that alpha blending is CST * SRC + (1 - CST) * DEST */\r\n Constants.ALPHA_INTERPOLATE = 9;\r\n /**\r\n * Defines that alpha blending is SRC + (1 - SRC) * DEST\r\n * Alpha will be set to SRC ALPHA + (1 - SRC ALPHA) * DEST ALPHA\r\n */\r\n Constants.ALPHA_SCREENMODE = 10;\r\n /**\r\n * Defines that alpha blending is SRC + DST\r\n * Alpha will be set to SRC ALPHA + DST ALPHA\r\n */\r\n Constants.ALPHA_ONEONE_ONEONE = 11;\r\n /**\r\n * Defines that alpha blending is SRC * DST ALPHA + DST\r\n * Alpha will be set to 0\r\n */\r\n Constants.ALPHA_ALPHATOCOLOR = 12;\r\n /**\r\n * Defines that alpha blending is SRC * (1 - DST) + DST * (1 - SRC)\r\n */\r\n Constants.ALPHA_REVERSEONEMINUS = 13;\r\n /**\r\n * Defines that alpha blending is SRC + DST * (1 - SRC ALPHA)\r\n * Alpha will be set to SRC ALPHA + DST ALPHA * (1 - SRC ALPHA)\r\n */\r\n Constants.ALPHA_SRC_DSTONEMINUSSRCALPHA = 14;\r\n /**\r\n * Defines that alpha blending is SRC + DST\r\n * Alpha will be set to SRC ALPHA\r\n */\r\n Constants.ALPHA_ONEONE_ONEZERO = 15;\r\n /**\r\n * Defines that alpha blending is SRC * (1 - DST) + DST * (1 - SRC)\r\n * Alpha will be set to DST ALPHA\r\n */\r\n Constants.ALPHA_EXCLUSION = 16;\r\n /** Defines that alpha blending equation a SUM */\r\n Constants.ALPHA_EQUATION_ADD = 0;\r\n /** Defines that alpha blending equation a SUBSTRACTION */\r\n Constants.ALPHA_EQUATION_SUBSTRACT = 1;\r\n /** Defines that alpha blending equation a REVERSE SUBSTRACTION */\r\n Constants.ALPHA_EQUATION_REVERSE_SUBTRACT = 2;\r\n /** Defines that alpha blending equation a MAX operation */\r\n Constants.ALPHA_EQUATION_MAX = 3;\r\n /** Defines that alpha blending equation a MIN operation */\r\n Constants.ALPHA_EQUATION_MIN = 4;\r\n /**\r\n * Defines that alpha blending equation a DARKEN operation:\r\n * It takes the min of the src and sums the alpha channels.\r\n */\r\n Constants.ALPHA_EQUATION_DARKEN = 5;\r\n /** Defines that the ressource is not delayed*/\r\n Constants.DELAYLOADSTATE_NONE = 0;\r\n /** Defines that the ressource was successfully delay loaded */\r\n Constants.DELAYLOADSTATE_LOADED = 1;\r\n /** Defines that the ressource is currently delay loading */\r\n Constants.DELAYLOADSTATE_LOADING = 2;\r\n /** Defines that the ressource is delayed and has not started loading */\r\n Constants.DELAYLOADSTATE_NOTLOADED = 4;\r\n // Depht or Stencil test Constants.\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will never pass. i.e. Nothing will be drawn */\r\n Constants.NEVER = 0x0200;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will always pass. i.e. Pixels will be drawn in the order they are drawn */\r\n Constants.ALWAYS = 0x0207;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is less than the stored value */\r\n Constants.LESS = 0x0201;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is equals to the stored value */\r\n Constants.EQUAL = 0x0202;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is less than or equal to the stored value */\r\n Constants.LEQUAL = 0x0203;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is greater than the stored value */\r\n Constants.GREATER = 0x0204;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is greater than or equal to the stored value */\r\n Constants.GEQUAL = 0x0206;\r\n /** Passed to depthFunction or stencilFunction to specify depth or stencil tests will pass if the new depth value is not equal to the stored value */\r\n Constants.NOTEQUAL = 0x0205;\r\n // Stencil Actions Constants.\r\n /** Passed to stencilOperation to specify that stencil value must be kept */\r\n Constants.KEEP = 0x1E00;\r\n /** Passed to stencilOperation to specify that stencil value must be replaced */\r\n Constants.REPLACE = 0x1E01;\r\n /** Passed to stencilOperation to specify that stencil value must be incremented */\r\n Constants.INCR = 0x1E02;\r\n /** Passed to stencilOperation to specify that stencil value must be decremented */\r\n Constants.DECR = 0x1E03;\r\n /** Passed to stencilOperation to specify that stencil value must be inverted */\r\n Constants.INVERT = 0x150A;\r\n /** Passed to stencilOperation to specify that stencil value must be incremented with wrapping */\r\n Constants.INCR_WRAP = 0x8507;\r\n /** Passed to stencilOperation to specify that stencil value must be decremented with wrapping */\r\n Constants.DECR_WRAP = 0x8508;\r\n /** Texture is not repeating outside of 0..1 UVs */\r\n Constants.TEXTURE_CLAMP_ADDRESSMODE = 0;\r\n /** Texture is repeating outside of 0..1 UVs */\r\n Constants.TEXTURE_WRAP_ADDRESSMODE = 1;\r\n /** Texture is repeating and mirrored */\r\n Constants.TEXTURE_MIRROR_ADDRESSMODE = 2;\r\n /** ALPHA */\r\n Constants.TEXTUREFORMAT_ALPHA = 0;\r\n /** LUMINANCE */\r\n Constants.TEXTUREFORMAT_LUMINANCE = 1;\r\n /** LUMINANCE_ALPHA */\r\n Constants.TEXTUREFORMAT_LUMINANCE_ALPHA = 2;\r\n /** RGB */\r\n Constants.TEXTUREFORMAT_RGB = 4;\r\n /** RGBA */\r\n Constants.TEXTUREFORMAT_RGBA = 5;\r\n /** RED */\r\n Constants.TEXTUREFORMAT_RED = 6;\r\n /** RED (2nd reference) */\r\n Constants.TEXTUREFORMAT_R = 6;\r\n /** RG */\r\n Constants.TEXTUREFORMAT_RG = 7;\r\n /** RED_INTEGER */\r\n Constants.TEXTUREFORMAT_RED_INTEGER = 8;\r\n /** RED_INTEGER (2nd reference) */\r\n Constants.TEXTUREFORMAT_R_INTEGER = 8;\r\n /** RG_INTEGER */\r\n Constants.TEXTUREFORMAT_RG_INTEGER = 9;\r\n /** RGB_INTEGER */\r\n Constants.TEXTUREFORMAT_RGB_INTEGER = 10;\r\n /** RGBA_INTEGER */\r\n Constants.TEXTUREFORMAT_RGBA_INTEGER = 11;\r\n /** UNSIGNED_BYTE */\r\n Constants.TEXTURETYPE_UNSIGNED_BYTE = 0;\r\n /** UNSIGNED_BYTE (2nd reference) */\r\n Constants.TEXTURETYPE_UNSIGNED_INT = 0;\r\n /** FLOAT */\r\n Constants.TEXTURETYPE_FLOAT = 1;\r\n /** HALF_FLOAT */\r\n Constants.TEXTURETYPE_HALF_FLOAT = 2;\r\n /** BYTE */\r\n Constants.TEXTURETYPE_BYTE = 3;\r\n /** SHORT */\r\n Constants.TEXTURETYPE_SHORT = 4;\r\n /** UNSIGNED_SHORT */\r\n Constants.TEXTURETYPE_UNSIGNED_SHORT = 5;\r\n /** INT */\r\n Constants.TEXTURETYPE_INT = 6;\r\n /** UNSIGNED_INT */\r\n Constants.TEXTURETYPE_UNSIGNED_INTEGER = 7;\r\n /** UNSIGNED_SHORT_4_4_4_4 */\r\n Constants.TEXTURETYPE_UNSIGNED_SHORT_4_4_4_4 = 8;\r\n /** UNSIGNED_SHORT_5_5_5_1 */\r\n Constants.TEXTURETYPE_UNSIGNED_SHORT_5_5_5_1 = 9;\r\n /** UNSIGNED_SHORT_5_6_5 */\r\n Constants.TEXTURETYPE_UNSIGNED_SHORT_5_6_5 = 10;\r\n /** UNSIGNED_INT_2_10_10_10_REV */\r\n Constants.TEXTURETYPE_UNSIGNED_INT_2_10_10_10_REV = 11;\r\n /** UNSIGNED_INT_24_8 */\r\n Constants.TEXTURETYPE_UNSIGNED_INT_24_8 = 12;\r\n /** UNSIGNED_INT_10F_11F_11F_REV */\r\n Constants.TEXTURETYPE_UNSIGNED_INT_10F_11F_11F_REV = 13;\r\n /** UNSIGNED_INT_5_9_9_9_REV */\r\n Constants.TEXTURETYPE_UNSIGNED_INT_5_9_9_9_REV = 14;\r\n /** FLOAT_32_UNSIGNED_INT_24_8_REV */\r\n Constants.TEXTURETYPE_FLOAT_32_UNSIGNED_INT_24_8_REV = 15;\r\n /** nearest is mag = nearest and min = nearest and no mip */\r\n Constants.TEXTURE_NEAREST_SAMPLINGMODE = 1;\r\n /** mag = nearest and min = nearest and mip = none */\r\n Constants.TEXTURE_NEAREST_NEAREST = 1;\r\n /** Bilinear is mag = linear and min = linear and no mip */\r\n Constants.TEXTURE_BILINEAR_SAMPLINGMODE = 2;\r\n /** mag = linear and min = linear and mip = none */\r\n Constants.TEXTURE_LINEAR_LINEAR = 2;\r\n /** Trilinear is mag = linear and min = linear and mip = linear */\r\n Constants.TEXTURE_TRILINEAR_SAMPLINGMODE = 3;\r\n /** Trilinear is mag = linear and min = linear and mip = linear */\r\n Constants.TEXTURE_LINEAR_LINEAR_MIPLINEAR = 3;\r\n /** mag = nearest and min = nearest and mip = nearest */\r\n Constants.TEXTURE_NEAREST_NEAREST_MIPNEAREST = 4;\r\n /** mag = nearest and min = linear and mip = nearest */\r\n Constants.TEXTURE_NEAREST_LINEAR_MIPNEAREST = 5;\r\n /** mag = nearest and min = linear and mip = linear */\r\n Constants.TEXTURE_NEAREST_LINEAR_MIPLINEAR = 6;\r\n /** mag = nearest and min = linear and mip = none */\r\n Constants.TEXTURE_NEAREST_LINEAR = 7;\r\n /** nearest is mag = nearest and min = nearest and mip = linear */\r\n Constants.TEXTURE_NEAREST_NEAREST_MIPLINEAR = 8;\r\n /** mag = linear and min = nearest and mip = nearest */\r\n Constants.TEXTURE_LINEAR_NEAREST_MIPNEAREST = 9;\r\n /** mag = linear and min = nearest and mip = linear */\r\n Constants.TEXTURE_LINEAR_NEAREST_MIPLINEAR = 10;\r\n /** Bilinear is mag = linear and min = linear and mip = nearest */\r\n Constants.TEXTURE_LINEAR_LINEAR_MIPNEAREST = 11;\r\n /** mag = linear and min = nearest and mip = none */\r\n Constants.TEXTURE_LINEAR_NEAREST = 12;\r\n /** Explicit coordinates mode */\r\n Constants.TEXTURE_EXPLICIT_MODE = 0;\r\n /** Spherical coordinates mode */\r\n Constants.TEXTURE_SPHERICAL_MODE = 1;\r\n /** Planar coordinates mode */\r\n Constants.TEXTURE_PLANAR_MODE = 2;\r\n /** Cubic coordinates mode */\r\n Constants.TEXTURE_CUBIC_MODE = 3;\r\n /** Projection coordinates mode */\r\n Constants.TEXTURE_PROJECTION_MODE = 4;\r\n /** Skybox coordinates mode */\r\n Constants.TEXTURE_SKYBOX_MODE = 5;\r\n /** Inverse Cubic coordinates mode */\r\n Constants.TEXTURE_INVCUBIC_MODE = 6;\r\n /** Equirectangular coordinates mode */\r\n Constants.TEXTURE_EQUIRECTANGULAR_MODE = 7;\r\n /** Equirectangular Fixed coordinates mode */\r\n Constants.TEXTURE_FIXED_EQUIRECTANGULAR_MODE = 8;\r\n /** Equirectangular Fixed Mirrored coordinates mode */\r\n Constants.TEXTURE_FIXED_EQUIRECTANGULAR_MIRRORED_MODE = 9;\r\n /** Offline (baking) quality for texture filtering */\r\n Constants.TEXTURE_FILTERING_QUALITY_OFFLINE = 4096;\r\n /** High quality for texture filtering */\r\n Constants.TEXTURE_FILTERING_QUALITY_HIGH = 64;\r\n /** Medium quality for texture filtering */\r\n Constants.TEXTURE_FILTERING_QUALITY_MEDIUM = 16;\r\n /** Low quality for texture filtering */\r\n Constants.TEXTURE_FILTERING_QUALITY_LOW = 8;\r\n // Texture rescaling mode\r\n /** Defines that texture rescaling will use a floor to find the closer power of 2 size */\r\n Constants.SCALEMODE_FLOOR = 1;\r\n /** Defines that texture rescaling will look for the nearest power of 2 size */\r\n Constants.SCALEMODE_NEAREST = 2;\r\n /** Defines that texture rescaling will use a ceil to find the closer power of 2 size */\r\n Constants.SCALEMODE_CEILING = 3;\r\n /**\r\n * The dirty texture flag value\r\n */\r\n Constants.MATERIAL_TextureDirtyFlag = 1;\r\n /**\r\n * The dirty light flag value\r\n */\r\n Constants.MATERIAL_LightDirtyFlag = 2;\r\n /**\r\n * The dirty fresnel flag value\r\n */\r\n Constants.MATERIAL_FresnelDirtyFlag = 4;\r\n /**\r\n * The dirty attribute flag value\r\n */\r\n Constants.MATERIAL_AttributesDirtyFlag = 8;\r\n /**\r\n * The dirty misc flag value\r\n */\r\n Constants.MATERIAL_MiscDirtyFlag = 16;\r\n /**\r\n * The dirty prepass flag value\r\n */\r\n Constants.MATERIAL_PrePassDirtyFlag = 32;\r\n /**\r\n * The all dirty flag value\r\n */\r\n Constants.MATERIAL_AllDirtyFlag = 63;\r\n /**\r\n * Returns the triangle fill mode\r\n */\r\n Constants.MATERIAL_TriangleFillMode = 0;\r\n /**\r\n * Returns the wireframe mode\r\n */\r\n Constants.MATERIAL_WireFrameFillMode = 1;\r\n /**\r\n * Returns the point fill mode\r\n */\r\n Constants.MATERIAL_PointFillMode = 2;\r\n /**\r\n * Returns the point list draw mode\r\n */\r\n Constants.MATERIAL_PointListDrawMode = 3;\r\n /**\r\n * Returns the line list draw mode\r\n */\r\n Constants.MATERIAL_LineListDrawMode = 4;\r\n /**\r\n * Returns the line loop draw mode\r\n */\r\n Constants.MATERIAL_LineLoopDrawMode = 5;\r\n /**\r\n * Returns the line strip draw mode\r\n */\r\n Constants.MATERIAL_LineStripDrawMode = 6;\r\n /**\r\n * Returns the triangle strip draw mode\r\n */\r\n Constants.MATERIAL_TriangleStripDrawMode = 7;\r\n /**\r\n * Returns the triangle fan draw mode\r\n */\r\n Constants.MATERIAL_TriangleFanDrawMode = 8;\r\n /**\r\n * Stores the clock-wise side orientation\r\n */\r\n Constants.MATERIAL_ClockWiseSideOrientation = 0;\r\n /**\r\n * Stores the counter clock-wise side orientation\r\n */\r\n Constants.MATERIAL_CounterClockWiseSideOrientation = 1;\r\n /**\r\n * Nothing\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_NothingTrigger = 0;\r\n /**\r\n * On pick\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnPickTrigger = 1;\r\n /**\r\n * On left pick\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnLeftPickTrigger = 2;\r\n /**\r\n * On right pick\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnRightPickTrigger = 3;\r\n /**\r\n * On center pick\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnCenterPickTrigger = 4;\r\n /**\r\n * On pick down\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnPickDownTrigger = 5;\r\n /**\r\n * On double pick\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnDoublePickTrigger = 6;\r\n /**\r\n * On pick up\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnPickUpTrigger = 7;\r\n /**\r\n * On pick out.\r\n * This trigger will only be raised if you also declared a OnPickDown\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnPickOutTrigger = 16;\r\n /**\r\n * On long press\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnLongPressTrigger = 8;\r\n /**\r\n * On pointer over\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnPointerOverTrigger = 9;\r\n /**\r\n * On pointer out\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnPointerOutTrigger = 10;\r\n /**\r\n * On every frame\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnEveryFrameTrigger = 11;\r\n /**\r\n * On intersection enter\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnIntersectionEnterTrigger = 12;\r\n /**\r\n * On intersection exit\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnIntersectionExitTrigger = 13;\r\n /**\r\n * On key down\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnKeyDownTrigger = 14;\r\n /**\r\n * On key up\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_actions#triggers\r\n */\r\n Constants.ACTION_OnKeyUpTrigger = 15;\r\n /**\r\n * Billboard mode will only apply to Y axis\r\n */\r\n Constants.PARTICLES_BILLBOARDMODE_Y = 2;\r\n /**\r\n * Billboard mode will apply to all axes\r\n */\r\n Constants.PARTICLES_BILLBOARDMODE_ALL = 7;\r\n /**\r\n * Special billboard mode where the particle will be biilboard to the camera but rotated to align with direction\r\n */\r\n Constants.PARTICLES_BILLBOARDMODE_STRETCHED = 8;\r\n /** Default culling strategy : this is an exclusion test and it's the more accurate.\r\n * Test order :\r\n * Is the bounding sphere outside the frustum ?\r\n * If not, are the bounding box vertices outside the frustum ?\r\n * It not, then the cullable object is in the frustum.\r\n */\r\n Constants.MESHES_CULLINGSTRATEGY_STANDARD = 0;\r\n /** Culling strategy : Bounding Sphere Only.\r\n * This is an exclusion test. It's faster than the standard strategy because the bounding box is not tested.\r\n * It's also less accurate than the standard because some not visible objects can still be selected.\r\n * Test : is the bounding sphere outside the frustum ?\r\n * If not, then the cullable object is in the frustum.\r\n */\r\n Constants.MESHES_CULLINGSTRATEGY_BOUNDINGSPHERE_ONLY = 1;\r\n /** Culling strategy : Optimistic Inclusion.\r\n * This in an inclusion test first, then the standard exclusion test.\r\n * This can be faster when a cullable object is expected to be almost always in the camera frustum.\r\n * This could also be a little slower than the standard test when the tested object center is not the frustum but one of its bounding box vertex is still inside.\r\n * Anyway, it's as accurate as the standard strategy.\r\n * Test :\r\n * Is the cullable object bounding sphere center in the frustum ?\r\n * If not, apply the default culling strategy.\r\n */\r\n Constants.MESHES_CULLINGSTRATEGY_OPTIMISTIC_INCLUSION = 2;\r\n /** Culling strategy : Optimistic Inclusion then Bounding Sphere Only.\r\n * This in an inclusion test first, then the bounding sphere only exclusion test.\r\n * This can be the fastest test when a cullable object is expected to be almost always in the camera frustum.\r\n * This could also be a little slower than the BoundingSphereOnly strategy when the tested object center is not in the frustum but its bounding sphere still intersects it.\r\n * It's less accurate than the standard strategy and as accurate as the BoundingSphereOnly strategy.\r\n * Test :\r\n * Is the cullable object bounding sphere center in the frustum ?\r\n * If not, apply the Bounding Sphere Only strategy. No Bounding Box is tested here.\r\n */\r\n Constants.MESHES_CULLINGSTRATEGY_OPTIMISTIC_INCLUSION_THEN_BSPHERE_ONLY = 3;\r\n /**\r\n * No logging while loading\r\n */\r\n Constants.SCENELOADER_NO_LOGGING = 0;\r\n /**\r\n * Minimal logging while loading\r\n */\r\n Constants.SCENELOADER_MINIMAL_LOGGING = 1;\r\n /**\r\n * Summary logging while loading\r\n */\r\n Constants.SCENELOADER_SUMMARY_LOGGING = 2;\r\n /**\r\n * Detailled logging while loading\r\n */\r\n Constants.SCENELOADER_DETAILED_LOGGING = 3;\r\n /**\r\n * Constant used to retrieve the irradiance texture index in the textures array in the prepass\r\n * using getIndex(0)\r\n */\r\n Constants.PREPASS_IRRADIANCE_TEXTURE_TYPE = 0;\r\n /**\r\n * Constant used to retrieve the position texture index in the textures array in the prepass\r\n * using getIndex(undefined)\r\n */\r\n Constants.PREPASS_POSITION_TEXTURE_TYPE = 1;\r\n /**\r\n * Constant used to retrieve the velocity texture index in the textures array in the prepass\r\n * using getIndex(undefined)\r\n */\r\n Constants.PREPASS_VELOCITY_TEXTURE_TYPE = 2;\r\n /**\r\n * Constant used to retrieve the reflectivity texture index in the textures array in the prepass\r\n * using the getIndex(3)\r\n */\r\n Constants.PREPASS_REFLECTIVITY_TEXTURE_TYPE = 3;\r\n /**\r\n * Constant used to retrieve the lit color texture index in the textures array in the prepass\r\n * using the getIndex(4)\r\n */\r\n Constants.PREPASS_COLOR_TEXTURE_TYPE = 4;\r\n /**\r\n * Constant used to retrieve depth + normal index in the textures array in the prepass\r\n * using the getIndex(5)\r\n */\r\n Constants.PREPASS_DEPTHNORMAL_TEXTURE_TYPE = 5;\r\n /**\r\n * Constant used to retrieve albedo index in the textures array in the prepass\r\n * using the getIndex(6)\r\n */\r\n Constants.PREPASS_ALBEDO_TEXTURE_TYPE = 6;\r\n return Constants;\r\n}());\r\nexport { Constants };\r\n//# sourceMappingURL=constants.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"@babylonjs/core/Misc/observable\";\r\nimport { Vector2, Vector3 } from \"@babylonjs/core/Maths/math.vector\";\r\nimport { Tools } from \"@babylonjs/core/Misc/tools\";\r\nimport { PointerEventTypes } from '@babylonjs/core/Events/pointerEvents';\r\nimport { ClipboardEventTypes, ClipboardInfo } from \"@babylonjs/core/Events/clipboardEvents\";\r\nimport { KeyboardEventTypes } from \"@babylonjs/core/Events/keyboardEvents\";\r\nimport { StandardMaterial } from \"@babylonjs/core/Materials/standardMaterial\";\r\nimport { Texture } from \"@babylonjs/core/Materials/Textures/texture\";\r\nimport { DynamicTexture } from \"@babylonjs/core/Materials/Textures/dynamicTexture\";\r\nimport { Layer } from \"@babylonjs/core/Layers/layer\";\r\nimport { Container } from \"./controls/container\";\r\nimport { Style } from \"./style\";\r\nimport { Measure } from \"./measure\";\r\nimport { Constants } from '@babylonjs/core/Engines/constants';\r\nimport { Viewport } from '@babylonjs/core/Maths/math.viewport';\r\nimport { Color3 } from '@babylonjs/core/Maths/math.color';\r\n/**\r\n* Class used to create texture to support 2D GUI elements\r\n* @see https://doc.babylonjs.com/how_to/gui\r\n*/\r\nvar AdvancedDynamicTexture = /** @class */ (function (_super) {\r\n __extends(AdvancedDynamicTexture, _super);\r\n /**\r\n * Creates a new AdvancedDynamicTexture\r\n * @param name defines the name of the texture\r\n * @param width defines the width of the texture\r\n * @param height defines the height of the texture\r\n * @param scene defines the hosting scene\r\n * @param generateMipMaps defines a boolean indicating if mipmaps must be generated (false by default)\r\n * @param samplingMode defines the texture sampling mode (Texture.NEAREST_SAMPLINGMODE by default)\r\n * @param invertY defines if the texture needs to be inverted on the y axis during loading (true by default)\r\n */\r\n function AdvancedDynamicTexture(name, width, height, scene, generateMipMaps, samplingMode, invertY) {\r\n if (width === void 0) { width = 0; }\r\n if (height === void 0) { height = 0; }\r\n if (generateMipMaps === void 0) { generateMipMaps = false; }\r\n if (samplingMode === void 0) { samplingMode = Texture.NEAREST_SAMPLINGMODE; }\r\n var _this = _super.call(this, name, { width: width, height: height }, scene, generateMipMaps, samplingMode, Constants.TEXTUREFORMAT_RGBA, invertY) || this;\r\n _this._isDirty = false;\r\n /** @hidden */\r\n _this._rootContainer = new Container(\"root\");\r\n /** @hidden */\r\n _this._lastControlOver = {};\r\n /** @hidden */\r\n _this._lastControlDown = {};\r\n /** @hidden */\r\n _this._capturingControl = {};\r\n /** @hidden */\r\n _this._linkedControls = new Array();\r\n _this._isFullscreen = false;\r\n _this._fullscreenViewport = new Viewport(0, 0, 1, 1);\r\n _this._idealWidth = 0;\r\n _this._idealHeight = 0;\r\n _this._useSmallestIdeal = false;\r\n _this._renderAtIdealSize = false;\r\n _this._blockNextFocusCheck = false;\r\n _this._renderScale = 1;\r\n _this._cursorChanged = false;\r\n _this._defaultMousePointerId = 0;\r\n /** @hidden */\r\n _this._numLayoutCalls = 0;\r\n /** @hidden */\r\n _this._numRenderCalls = 0;\r\n /**\r\n * Define type to string to ensure compatibility across browsers\r\n * Safari doesn't support DataTransfer constructor\r\n */\r\n _this._clipboardData = \"\";\r\n /**\r\n * Observable event triggered each time an clipboard event is received from the rendering canvas\r\n */\r\n _this.onClipboardObservable = new Observable();\r\n /**\r\n * Observable event triggered each time a pointer down is intercepted by a control\r\n */\r\n _this.onControlPickedObservable = new Observable();\r\n /**\r\n * Observable event triggered before layout is evaluated\r\n */\r\n _this.onBeginLayoutObservable = new Observable();\r\n /**\r\n * Observable event triggered after the layout was evaluated\r\n */\r\n _this.onEndLayoutObservable = new Observable();\r\n /**\r\n * Observable event triggered before the texture is rendered\r\n */\r\n _this.onBeginRenderObservable = new Observable();\r\n /**\r\n * Observable event triggered after the texture was rendered\r\n */\r\n _this.onEndRenderObservable = new Observable();\r\n /**\r\n * Gets or sets a boolean defining if alpha is stored as premultiplied\r\n */\r\n _this.premulAlpha = false;\r\n /**\r\n * Gets or sets a boolean indicating that the canvas must be reverted on Y when updating the texture\r\n */\r\n _this.applyYInversionOnUpdate = true;\r\n _this._useInvalidateRectOptimization = true;\r\n // Invalidated rectangle which is the combination of all invalidated controls after they have been rotated into absolute position\r\n _this._invalidatedRectangle = null;\r\n _this._clearMeasure = new Measure(0, 0, 0, 0);\r\n /** @hidden */\r\n _this.onClipboardCopy = function (rawEvt) {\r\n var evt = rawEvt;\r\n var ev = new ClipboardInfo(ClipboardEventTypes.COPY, evt);\r\n _this.onClipboardObservable.notifyObservers(ev);\r\n evt.preventDefault();\r\n };\r\n /** @hidden */\r\n _this.onClipboardCut = function (rawEvt) {\r\n var evt = rawEvt;\r\n var ev = new ClipboardInfo(ClipboardEventTypes.CUT, evt);\r\n _this.onClipboardObservable.notifyObservers(ev);\r\n evt.preventDefault();\r\n };\r\n /** @hidden */\r\n _this.onClipboardPaste = function (rawEvt) {\r\n var evt = rawEvt;\r\n var ev = new ClipboardInfo(ClipboardEventTypes.PASTE, evt);\r\n _this.onClipboardObservable.notifyObservers(ev);\r\n evt.preventDefault();\r\n };\r\n scene = _this.getScene();\r\n if (!scene || !_this._texture) {\r\n return _this;\r\n }\r\n _this._rootElement = scene.getEngine().getInputElement();\r\n _this._renderObserver = scene.onBeforeCameraRenderObservable.add(function (camera) { return _this._checkUpdate(camera); });\r\n _this._preKeyboardObserver = scene.onPreKeyboardObservable.add(function (info) {\r\n if (!_this._focusedControl) {\r\n return;\r\n }\r\n if (info.type === KeyboardEventTypes.KEYDOWN) {\r\n _this._focusedControl.processKeyboard(info.event);\r\n }\r\n info.skipOnPointerObservable = true;\r\n });\r\n _this._rootContainer._link(_this);\r\n _this.hasAlpha = true;\r\n if (!width || !height) {\r\n _this._resizeObserver = scene.getEngine().onResizeObservable.add(function () { return _this._onResize(); });\r\n _this._onResize();\r\n }\r\n _this._texture.isReady = true;\r\n return _this;\r\n }\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"numLayoutCalls\", {\r\n /** Gets the number of layout calls made the last time the ADT has been rendered */\r\n get: function () {\r\n return this._numLayoutCalls;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"numRenderCalls\", {\r\n /** Gets the number of render calls made the last time the ADT has been rendered */\r\n get: function () {\r\n return this._numRenderCalls;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"renderScale\", {\r\n /**\r\n * Gets or sets a number used to scale rendering size (2 means that the texture will be twice bigger).\r\n * Useful when you want more antialiasing\r\n */\r\n get: function () {\r\n return this._renderScale;\r\n },\r\n set: function (value) {\r\n if (value === this._renderScale) {\r\n return;\r\n }\r\n this._renderScale = value;\r\n this._onResize();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"background\", {\r\n /** Gets or sets the background color */\r\n get: function () {\r\n return this._background;\r\n },\r\n set: function (value) {\r\n if (this._background === value) {\r\n return;\r\n }\r\n this._background = value;\r\n this.markAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"idealWidth\", {\r\n /**\r\n * Gets or sets the ideal width used to design controls.\r\n * The GUI will then rescale everything accordingly\r\n * @see https://doc.babylonjs.com/how_to/gui#adaptive-scaling\r\n */\r\n get: function () {\r\n return this._idealWidth;\r\n },\r\n set: function (value) {\r\n if (this._idealWidth === value) {\r\n return;\r\n }\r\n this._idealWidth = value;\r\n this.markAsDirty();\r\n this._rootContainer._markAllAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"idealHeight\", {\r\n /**\r\n * Gets or sets the ideal height used to design controls.\r\n * The GUI will then rescale everything accordingly\r\n * @see https://doc.babylonjs.com/how_to/gui#adaptive-scaling\r\n */\r\n get: function () {\r\n return this._idealHeight;\r\n },\r\n set: function (value) {\r\n if (this._idealHeight === value) {\r\n return;\r\n }\r\n this._idealHeight = value;\r\n this.markAsDirty();\r\n this._rootContainer._markAllAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"useSmallestIdeal\", {\r\n /**\r\n * Gets or sets a boolean indicating if the smallest ideal value must be used if idealWidth and idealHeight are both set\r\n * @see https://doc.babylonjs.com/how_to/gui#adaptive-scaling\r\n */\r\n get: function () {\r\n return this._useSmallestIdeal;\r\n },\r\n set: function (value) {\r\n if (this._useSmallestIdeal === value) {\r\n return;\r\n }\r\n this._useSmallestIdeal = value;\r\n this.markAsDirty();\r\n this._rootContainer._markAllAsDirty();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"renderAtIdealSize\", {\r\n /**\r\n * Gets or sets a boolean indicating if adaptive scaling must be used\r\n * @see https://doc.babylonjs.com/how_to/gui#adaptive-scaling\r\n */\r\n get: function () {\r\n return this._renderAtIdealSize;\r\n },\r\n set: function (value) {\r\n if (this._renderAtIdealSize === value) {\r\n return;\r\n }\r\n this._renderAtIdealSize = value;\r\n this._onResize();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"idealRatio\", {\r\n /**\r\n * Gets the ratio used when in \"ideal mode\"\r\n * @see https://doc.babylonjs.com/how_to/gui#adaptive-scaling\r\n * */\r\n get: function () {\r\n var rwidth = 0;\r\n var rheight = 0;\r\n if (this._idealWidth) {\r\n rwidth = (this.getSize().width) / this._idealWidth;\r\n }\r\n if (this._idealHeight) {\r\n rheight = (this.getSize().height) / this._idealHeight;\r\n }\r\n if (this._useSmallestIdeal && this._idealWidth && this._idealHeight) {\r\n return window.innerWidth < window.innerHeight ? rwidth : rheight;\r\n }\r\n if (this._idealWidth) { // horizontal\r\n return rwidth;\r\n }\r\n if (this._idealHeight) { // vertical\r\n return rheight;\r\n }\r\n return 1;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"layer\", {\r\n /**\r\n * Gets the underlying layer used to render the texture when in fullscreen mode\r\n */\r\n get: function () {\r\n return this._layerToDispose;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"rootContainer\", {\r\n /**\r\n * Gets the root container control\r\n */\r\n get: function () {\r\n return this._rootContainer;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Returns an array containing the root container.\r\n * This is mostly used to let the Inspector introspects the ADT\r\n * @returns an array containing the rootContainer\r\n */\r\n AdvancedDynamicTexture.prototype.getChildren = function () {\r\n return [this._rootContainer];\r\n };\r\n /**\r\n * Will return all controls that are inside this texture\r\n * @param directDescendantsOnly defines if true only direct descendants of 'this' will be considered, if false direct and also indirect (children of children, an so on in a recursive manner) descendants of 'this' will be considered\r\n * @param predicate defines an optional predicate that will be called on every evaluated child, the predicate must return true for a given child to be part of the result, otherwise it will be ignored\r\n * @return all child controls\r\n */\r\n AdvancedDynamicTexture.prototype.getDescendants = function (directDescendantsOnly, predicate) {\r\n return this._rootContainer.getDescendants(directDescendantsOnly, predicate);\r\n };\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"focusedControl\", {\r\n /**\r\n * Gets or sets the current focused control\r\n */\r\n get: function () {\r\n return this._focusedControl;\r\n },\r\n set: function (control) {\r\n if (this._focusedControl == control) {\r\n return;\r\n }\r\n if (this._focusedControl) {\r\n this._focusedControl.onBlur();\r\n }\r\n if (control) {\r\n control.onFocus();\r\n }\r\n this._focusedControl = control;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"isForeground\", {\r\n /**\r\n * Gets or sets a boolean indicating if the texture must be rendered in background or foreground when in fullscreen mode\r\n */\r\n get: function () {\r\n if (!this.layer) {\r\n return true;\r\n }\r\n return (!this.layer.isBackground);\r\n },\r\n set: function (value) {\r\n if (!this.layer) {\r\n return;\r\n }\r\n if (this.layer.isBackground === !value) {\r\n return;\r\n }\r\n this.layer.isBackground = !value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"clipboardData\", {\r\n /**\r\n * Gets or set information about clipboardData\r\n */\r\n get: function () {\r\n return this._clipboardData;\r\n },\r\n set: function (value) {\r\n this._clipboardData = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Get the current class name of the texture useful for serialization or dynamic coding.\r\n * @returns \"AdvancedDynamicTexture\"\r\n */\r\n AdvancedDynamicTexture.prototype.getClassName = function () {\r\n return \"AdvancedDynamicTexture\";\r\n };\r\n /**\r\n * Function used to execute a function on all controls\r\n * @param func defines the function to execute\r\n * @param container defines the container where controls belong. If null the root container will be used\r\n */\r\n AdvancedDynamicTexture.prototype.executeOnAllControls = function (func, container) {\r\n if (!container) {\r\n container = this._rootContainer;\r\n }\r\n func(container);\r\n for (var _i = 0, _a = container.children; _i < _a.length; _i++) {\r\n var child = _a[_i];\r\n if (child.children) {\r\n this.executeOnAllControls(func, child);\r\n continue;\r\n }\r\n func(child);\r\n }\r\n };\r\n Object.defineProperty(AdvancedDynamicTexture.prototype, \"useInvalidateRectOptimization\", {\r\n /**\r\n * Gets or sets a boolean indicating if the InvalidateRect optimization should be turned on\r\n */\r\n get: function () {\r\n return this._useInvalidateRectOptimization;\r\n },\r\n set: function (value) {\r\n this._useInvalidateRectOptimization = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Invalidates a rectangle area on the gui texture\r\n * @param invalidMinX left most position of the rectangle to invalidate in the texture\r\n * @param invalidMinY top most position of the rectangle to invalidate in the texture\r\n * @param invalidMaxX right most position of the rectangle to invalidate in the texture\r\n * @param invalidMaxY bottom most position of the rectangle to invalidate in the texture\r\n */\r\n AdvancedDynamicTexture.prototype.invalidateRect = function (invalidMinX, invalidMinY, invalidMaxX, invalidMaxY) {\r\n if (!this._useInvalidateRectOptimization) {\r\n return;\r\n }\r\n if (!this._invalidatedRectangle) {\r\n this._invalidatedRectangle = new Measure(invalidMinX, invalidMinY, invalidMaxX - invalidMinX + 1, invalidMaxY - invalidMinY + 1);\r\n }\r\n else {\r\n // Compute intersection\r\n var maxX = Math.ceil(Math.max(this._invalidatedRectangle.left + this._invalidatedRectangle.width - 1, invalidMaxX));\r\n var maxY = Math.ceil(Math.max(this._invalidatedRectangle.top + this._invalidatedRectangle.height - 1, invalidMaxY));\r\n this._invalidatedRectangle.left = Math.floor(Math.min(this._invalidatedRectangle.left, invalidMinX));\r\n this._invalidatedRectangle.top = Math.floor(Math.min(this._invalidatedRectangle.top, invalidMinY));\r\n this._invalidatedRectangle.width = maxX - this._invalidatedRectangle.left + 1;\r\n this._invalidatedRectangle.height = maxY - this._invalidatedRectangle.top + 1;\r\n }\r\n };\r\n /**\r\n * Marks the texture as dirty forcing a complete update\r\n */\r\n AdvancedDynamicTexture.prototype.markAsDirty = function () {\r\n this._isDirty = true;\r\n };\r\n /**\r\n * Helper function used to create a new style\r\n * @returns a new style\r\n * @see https://doc.babylonjs.com/how_to/gui#styles\r\n */\r\n AdvancedDynamicTexture.prototype.createStyle = function () {\r\n return new Style(this);\r\n };\r\n /**\r\n * Adds a new control to the root container\r\n * @param control defines the control to add\r\n * @returns the current texture\r\n */\r\n AdvancedDynamicTexture.prototype.addControl = function (control) {\r\n this._rootContainer.addControl(control);\r\n return this;\r\n };\r\n /**\r\n * Removes a control from the root container\r\n * @param control defines the control to remove\r\n * @returns the current texture\r\n */\r\n AdvancedDynamicTexture.prototype.removeControl = function (control) {\r\n this._rootContainer.removeControl(control);\r\n return this;\r\n };\r\n /**\r\n * Release all resources\r\n */\r\n AdvancedDynamicTexture.prototype.dispose = function () {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n this._rootElement = null;\r\n scene.onBeforeCameraRenderObservable.remove(this._renderObserver);\r\n if (this._resizeObserver) {\r\n scene.getEngine().onResizeObservable.remove(this._resizeObserver);\r\n }\r\n if (this._pointerMoveObserver) {\r\n scene.onPrePointerObservable.remove(this._pointerMoveObserver);\r\n }\r\n if (this._pointerObserver) {\r\n scene.onPointerObservable.remove(this._pointerObserver);\r\n }\r\n if (this._preKeyboardObserver) {\r\n scene.onPreKeyboardObservable.remove(this._preKeyboardObserver);\r\n }\r\n if (this._canvasPointerOutObserver) {\r\n scene.getEngine().onCanvasPointerOutObservable.remove(this._canvasPointerOutObserver);\r\n }\r\n if (this._canvasBlurObserver) {\r\n scene.getEngine().onCanvasBlurObservable.remove(this._canvasBlurObserver);\r\n }\r\n if (this._layerToDispose) {\r\n this._layerToDispose.texture = null;\r\n this._layerToDispose.dispose();\r\n this._layerToDispose = null;\r\n }\r\n this._rootContainer.dispose();\r\n this.onClipboardObservable.clear();\r\n this.onControlPickedObservable.clear();\r\n this.onBeginRenderObservable.clear();\r\n this.onEndRenderObservable.clear();\r\n this.onBeginLayoutObservable.clear();\r\n this.onEndLayoutObservable.clear();\r\n _super.prototype.dispose.call(this);\r\n };\r\n AdvancedDynamicTexture.prototype._onResize = function () {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n // Check size\r\n var engine = scene.getEngine();\r\n var textureSize = this.getSize();\r\n var renderWidth = engine.getRenderWidth() * this._renderScale;\r\n var renderHeight = engine.getRenderHeight() * this._renderScale;\r\n if (this._renderAtIdealSize) {\r\n if (this._idealWidth) {\r\n renderHeight = (renderHeight * this._idealWidth) / renderWidth;\r\n renderWidth = this._idealWidth;\r\n }\r\n else if (this._idealHeight) {\r\n renderWidth = (renderWidth * this._idealHeight) / renderHeight;\r\n renderHeight = this._idealHeight;\r\n }\r\n }\r\n if (textureSize.width !== renderWidth || textureSize.height !== renderHeight) {\r\n this.scaleTo(renderWidth, renderHeight);\r\n this.markAsDirty();\r\n if (this._idealWidth || this._idealHeight) {\r\n this._rootContainer._markAllAsDirty();\r\n }\r\n }\r\n this.invalidateRect(0, 0, textureSize.width - 1, textureSize.height - 1);\r\n };\r\n /** @hidden */\r\n AdvancedDynamicTexture.prototype._getGlobalViewport = function (scene) {\r\n var engine = scene.getEngine();\r\n return this._fullscreenViewport.toGlobal(engine.getRenderWidth(), engine.getRenderHeight());\r\n };\r\n /**\r\n * Get screen coordinates for a vector3\r\n * @param position defines the position to project\r\n * @param worldMatrix defines the world matrix to use\r\n * @returns the projected position\r\n */\r\n AdvancedDynamicTexture.prototype.getProjectedPosition = function (position, worldMatrix) {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return Vector2.Zero();\r\n }\r\n var globalViewport = this._getGlobalViewport(scene);\r\n var projectedPosition = Vector3.Project(position, worldMatrix, scene.getTransformMatrix(), globalViewport);\r\n projectedPosition.scaleInPlace(this.renderScale);\r\n return new Vector2(projectedPosition.x, projectedPosition.y);\r\n };\r\n /**\r\n * Get screen coordinates for a vector3\r\n * @param position defines the position to project\r\n * @param worldMatrix defines the world matrix to use\r\n * @returns the projected position with Z\r\n */\r\n AdvancedDynamicTexture.prototype.getProjectedPositionWithZ = function (position, worldMatrix) {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return Vector3.Zero();\r\n }\r\n var globalViewport = this._getGlobalViewport(scene);\r\n var projectedPosition = Vector3.Project(position, worldMatrix, scene.getTransformMatrix(), globalViewport);\r\n projectedPosition.scaleInPlace(this.renderScale);\r\n return new Vector3(projectedPosition.x, projectedPosition.y, projectedPosition.z);\r\n };\r\n AdvancedDynamicTexture.prototype._checkUpdate = function (camera) {\r\n if (this._layerToDispose) {\r\n if ((camera.layerMask & this._layerToDispose.layerMask) === 0) {\r\n return;\r\n }\r\n }\r\n if (this._isFullscreen && this._linkedControls.length) {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n var globalViewport = this._getGlobalViewport(scene);\r\n var _loop_1 = function (control) {\r\n if (!control.isVisible) {\r\n return \"continue\";\r\n }\r\n var mesh = control._linkedMesh;\r\n if (!mesh || mesh.isDisposed()) {\r\n Tools.SetImmediate(function () {\r\n control.linkWithMesh(null);\r\n });\r\n return \"continue\";\r\n }\r\n var position = mesh.getBoundingInfo ? mesh.getBoundingInfo().boundingSphere.center : Vector3.ZeroReadOnly;\r\n var projectedPosition = Vector3.Project(position, mesh.getWorldMatrix(), scene.getTransformMatrix(), globalViewport);\r\n if (projectedPosition.z < 0 || projectedPosition.z > 1) {\r\n control.notRenderable = true;\r\n return \"continue\";\r\n }\r\n control.notRenderable = false;\r\n // Account for RenderScale.\r\n projectedPosition.scaleInPlace(this_1.renderScale);\r\n control._moveToProjectedPosition(projectedPosition);\r\n };\r\n var this_1 = this;\r\n for (var _i = 0, _a = this._linkedControls; _i < _a.length; _i++) {\r\n var control = _a[_i];\r\n _loop_1(control);\r\n }\r\n }\r\n if (!this._isDirty && !this._rootContainer.isDirty) {\r\n return;\r\n }\r\n this._isDirty = false;\r\n this._render();\r\n this.update(this.applyYInversionOnUpdate, this.premulAlpha);\r\n };\r\n AdvancedDynamicTexture.prototype._render = function () {\r\n var textureSize = this.getSize();\r\n var renderWidth = textureSize.width;\r\n var renderHeight = textureSize.height;\r\n var context = this.getContext();\r\n context.font = \"18px Arial\";\r\n context.strokeStyle = \"white\";\r\n // Layout\r\n this.onBeginLayoutObservable.notifyObservers(this);\r\n var measure = new Measure(0, 0, renderWidth, renderHeight);\r\n this._numLayoutCalls = 0;\r\n this._rootContainer._layout(measure, context);\r\n this.onEndLayoutObservable.notifyObservers(this);\r\n this._isDirty = false; // Restoring the dirty state that could have been set by controls during layout processing\r\n // Clear\r\n if (this._invalidatedRectangle) {\r\n this._clearMeasure.copyFrom(this._invalidatedRectangle);\r\n }\r\n else {\r\n this._clearMeasure.copyFromFloats(0, 0, renderWidth, renderHeight);\r\n }\r\n context.clearRect(this._clearMeasure.left, this._clearMeasure.top, this._clearMeasure.width, this._clearMeasure.height);\r\n if (this._background) {\r\n context.save();\r\n context.fillStyle = this._background;\r\n context.fillRect(this._clearMeasure.left, this._clearMeasure.top, this._clearMeasure.width, this._clearMeasure.height);\r\n context.restore();\r\n }\r\n // Render\r\n this.onBeginRenderObservable.notifyObservers(this);\r\n this._numRenderCalls = 0;\r\n this._rootContainer._render(context, this._invalidatedRectangle);\r\n this.onEndRenderObservable.notifyObservers(this);\r\n this._invalidatedRectangle = null;\r\n };\r\n /** @hidden */\r\n AdvancedDynamicTexture.prototype._changeCursor = function (cursor) {\r\n if (this._rootElement) {\r\n this._rootElement.style.cursor = cursor;\r\n this._cursorChanged = true;\r\n }\r\n };\r\n /** @hidden */\r\n AdvancedDynamicTexture.prototype._registerLastControlDown = function (control, pointerId) {\r\n this._lastControlDown[pointerId] = control;\r\n this.onControlPickedObservable.notifyObservers(control);\r\n };\r\n AdvancedDynamicTexture.prototype._doPicking = function (x, y, pi, type, pointerId, buttonIndex, deltaX, deltaY) {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n var engine = scene.getEngine();\r\n var textureSize = this.getSize();\r\n if (this._isFullscreen) {\r\n var camera = scene.cameraToUseForPointers || scene.activeCamera;\r\n var viewport = camera.viewport;\r\n x = x * (textureSize.width / (engine.getRenderWidth() * viewport.width));\r\n y = y * (textureSize.height / (engine.getRenderHeight() * viewport.height));\r\n }\r\n if (this._capturingControl[pointerId]) {\r\n this._capturingControl[pointerId]._processObservables(type, x, y, pi, pointerId, buttonIndex);\r\n return;\r\n }\r\n this._cursorChanged = false;\r\n if (!this._rootContainer._processPicking(x, y, pi, type, pointerId, buttonIndex, deltaX, deltaY)) {\r\n this._changeCursor(\"\");\r\n if (type === PointerEventTypes.POINTERMOVE) {\r\n if (this._lastControlOver[pointerId]) {\r\n this._lastControlOver[pointerId]._onPointerOut(this._lastControlOver[pointerId], pi);\r\n delete this._lastControlOver[pointerId];\r\n }\r\n }\r\n }\r\n if (!this._cursorChanged) {\r\n this._changeCursor(\"\");\r\n }\r\n this._manageFocus();\r\n };\r\n /** @hidden */\r\n AdvancedDynamicTexture.prototype._cleanControlAfterRemovalFromList = function (list, control) {\r\n for (var pointerId in list) {\r\n if (!list.hasOwnProperty(pointerId)) {\r\n continue;\r\n }\r\n var lastControlOver = list[pointerId];\r\n if (lastControlOver === control) {\r\n delete list[pointerId];\r\n }\r\n }\r\n };\r\n /** @hidden */\r\n AdvancedDynamicTexture.prototype._cleanControlAfterRemoval = function (control) {\r\n this._cleanControlAfterRemovalFromList(this._lastControlDown, control);\r\n this._cleanControlAfterRemovalFromList(this._lastControlOver, control);\r\n };\r\n /** Attach to all scene events required to support pointer events */\r\n AdvancedDynamicTexture.prototype.attach = function () {\r\n var _this = this;\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n var tempViewport = new Viewport(0, 0, 0, 0);\r\n this._pointerMoveObserver = scene.onPrePointerObservable.add(function (pi, state) {\r\n if (scene.isPointerCaptured((pi.event).pointerId)) {\r\n return;\r\n }\r\n if (pi.type !== PointerEventTypes.POINTERMOVE\r\n && pi.type !== PointerEventTypes.POINTERUP\r\n && pi.type !== PointerEventTypes.POINTERDOWN\r\n && pi.type !== PointerEventTypes.POINTERWHEEL) {\r\n return;\r\n }\r\n if (!scene) {\r\n return;\r\n }\r\n if (pi.type === PointerEventTypes.POINTERMOVE && pi.event.pointerId) {\r\n _this._defaultMousePointerId = pi.event.pointerId; // This is required to make sure we have the correct pointer ID for wheel\r\n }\r\n var camera = scene.cameraToUseForPointers || scene.activeCamera;\r\n var engine = scene.getEngine();\r\n if (!camera) {\r\n tempViewport.x = 0;\r\n tempViewport.y = 0;\r\n tempViewport.width = engine.getRenderWidth();\r\n tempViewport.height = engine.getRenderHeight();\r\n }\r\n else {\r\n camera.viewport.toGlobalToRef(engine.getRenderWidth(), engine.getRenderHeight(), tempViewport);\r\n }\r\n var x = scene.pointerX / engine.getHardwareScalingLevel() - tempViewport.x;\r\n var y = scene.pointerY / engine.getHardwareScalingLevel() - (engine.getRenderHeight() - tempViewport.y - tempViewport.height);\r\n _this._shouldBlockPointer = false;\r\n // Do picking modifies _shouldBlockPointer\r\n var pointerId = pi.event.pointerId || _this._defaultMousePointerId;\r\n _this._doPicking(x, y, pi, pi.type, pointerId, pi.event.button, pi.event.deltaX, pi.event.deltaY);\r\n // Avoid overwriting a true skipOnPointerObservable to false\r\n if (_this._shouldBlockPointer) {\r\n pi.skipOnPointerObservable = _this._shouldBlockPointer;\r\n }\r\n });\r\n this._attachToOnPointerOut(scene);\r\n this._attachToOnBlur(scene);\r\n };\r\n /**\r\n * Register the clipboard Events onto the canvas\r\n */\r\n AdvancedDynamicTexture.prototype.registerClipboardEvents = function () {\r\n self.addEventListener(\"copy\", this.onClipboardCopy, false);\r\n self.addEventListener(\"cut\", this.onClipboardCut, false);\r\n self.addEventListener(\"paste\", this.onClipboardPaste, false);\r\n };\r\n /**\r\n * Unregister the clipboard Events from the canvas\r\n */\r\n AdvancedDynamicTexture.prototype.unRegisterClipboardEvents = function () {\r\n self.removeEventListener(\"copy\", this.onClipboardCopy);\r\n self.removeEventListener(\"cut\", this.onClipboardCut);\r\n self.removeEventListener(\"paste\", this.onClipboardPaste);\r\n };\r\n /**\r\n * Connect the texture to a hosting mesh to enable interactions\r\n * @param mesh defines the mesh to attach to\r\n * @param supportPointerMove defines a boolean indicating if pointer move events must be catched as well\r\n */\r\n AdvancedDynamicTexture.prototype.attachToMesh = function (mesh, supportPointerMove) {\r\n var _this = this;\r\n if (supportPointerMove === void 0) { supportPointerMove = true; }\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n this._pointerObserver = scene.onPointerObservable.add(function (pi, state) {\r\n if (pi.type !== PointerEventTypes.POINTERMOVE\r\n && pi.type !== PointerEventTypes.POINTERUP\r\n && pi.type !== PointerEventTypes.POINTERDOWN) {\r\n return;\r\n }\r\n var pointerId = pi.event.pointerId || _this._defaultMousePointerId;\r\n if (pi.pickInfo && pi.pickInfo.hit && pi.pickInfo.pickedMesh === mesh) {\r\n var uv = pi.pickInfo.getTextureCoordinates();\r\n if (uv) {\r\n var size = _this.getSize();\r\n _this._doPicking(uv.x * size.width, (_this.applyYInversionOnUpdate ? (1.0 - uv.y) : uv.y) * size.height, pi, pi.type, pointerId, pi.event.button);\r\n }\r\n }\r\n else if (pi.type === PointerEventTypes.POINTERUP) {\r\n if (_this._lastControlDown[pointerId]) {\r\n _this._lastControlDown[pointerId]._forcePointerUp(pointerId);\r\n }\r\n delete _this._lastControlDown[pointerId];\r\n if (_this.focusedControl) {\r\n var friendlyControls = _this.focusedControl.keepsFocusWith();\r\n var canMoveFocus = true;\r\n if (friendlyControls) {\r\n for (var _i = 0, friendlyControls_1 = friendlyControls; _i < friendlyControls_1.length; _i++) {\r\n var control = friendlyControls_1[_i];\r\n // Same host, no need to keep the focus\r\n if (_this === control._host) {\r\n continue;\r\n }\r\n // Different hosts\r\n var otherHost = control._host;\r\n if (otherHost._lastControlOver[pointerId] && otherHost._lastControlOver[pointerId].isAscendant(control)) {\r\n canMoveFocus = false;\r\n break;\r\n }\r\n }\r\n }\r\n if (canMoveFocus) {\r\n _this.focusedControl = null;\r\n }\r\n }\r\n }\r\n else if (pi.type === PointerEventTypes.POINTERMOVE) {\r\n if (_this._lastControlOver[pointerId]) {\r\n _this._lastControlOver[pointerId]._onPointerOut(_this._lastControlOver[pointerId], pi, true);\r\n }\r\n delete _this._lastControlOver[pointerId];\r\n }\r\n });\r\n mesh.enablePointerMoveEvents = supportPointerMove;\r\n this._attachToOnPointerOut(scene);\r\n this._attachToOnBlur(scene);\r\n };\r\n /**\r\n * Move the focus to a specific control\r\n * @param control defines the control which will receive the focus\r\n */\r\n AdvancedDynamicTexture.prototype.moveFocusToControl = function (control) {\r\n this.focusedControl = control;\r\n this._lastPickedControl = control;\r\n this._blockNextFocusCheck = true;\r\n };\r\n AdvancedDynamicTexture.prototype._manageFocus = function () {\r\n if (this._blockNextFocusCheck) {\r\n this._blockNextFocusCheck = false;\r\n this._lastPickedControl = this._focusedControl;\r\n return;\r\n }\r\n // Focus management\r\n if (this._focusedControl) {\r\n if (this._focusedControl !== this._lastPickedControl) {\r\n if (this._lastPickedControl.isFocusInvisible) {\r\n return;\r\n }\r\n this.focusedControl = null;\r\n }\r\n }\r\n };\r\n AdvancedDynamicTexture.prototype._attachToOnPointerOut = function (scene) {\r\n var _this = this;\r\n this._canvasPointerOutObserver = scene.getEngine().onCanvasPointerOutObservable.add(function (pointerEvent) {\r\n if (_this._lastControlOver[pointerEvent.pointerId]) {\r\n _this._lastControlOver[pointerEvent.pointerId]._onPointerOut(_this._lastControlOver[pointerEvent.pointerId], null);\r\n }\r\n delete _this._lastControlOver[pointerEvent.pointerId];\r\n if (_this._lastControlDown[pointerEvent.pointerId] && _this._lastControlDown[pointerEvent.pointerId] !== _this._capturingControl[pointerEvent.pointerId]) {\r\n _this._lastControlDown[pointerEvent.pointerId]._forcePointerUp();\r\n delete _this._lastControlDown[pointerEvent.pointerId];\r\n }\r\n });\r\n };\r\n AdvancedDynamicTexture.prototype._attachToOnBlur = function (scene) {\r\n var _this = this;\r\n this._canvasBlurObserver = scene.getEngine().onCanvasBlurObservable.add(function (pointerEvent) {\r\n Object.entries(_this._lastControlDown).forEach(function (_a) {\r\n var key = _a[0], value = _a[1];\r\n value._onCanvasBlur();\r\n });\r\n _this._lastControlDown = {};\r\n });\r\n };\r\n // Statics\r\n /**\r\n * Creates a new AdvancedDynamicTexture in projected mode (ie. attached to a mesh)\r\n * @param mesh defines the mesh which will receive the texture\r\n * @param width defines the texture width (1024 by default)\r\n * @param height defines the texture height (1024 by default)\r\n * @param supportPointerMove defines a boolean indicating if the texture must capture move events (true by default)\r\n * @param onlyAlphaTesting defines a boolean indicating that alpha blending will not be used (only alpha testing) (false by default)\r\n * @param invertY defines if the texture needs to be inverted on the y axis during loading (true by default)\r\n * @returns a new AdvancedDynamicTexture\r\n */\r\n AdvancedDynamicTexture.CreateForMesh = function (mesh, width, height, supportPointerMove, onlyAlphaTesting, invertY) {\r\n if (width === void 0) { width = 1024; }\r\n if (height === void 0) { height = 1024; }\r\n if (supportPointerMove === void 0) { supportPointerMove = true; }\r\n if (onlyAlphaTesting === void 0) { onlyAlphaTesting = false; }\r\n var result = new AdvancedDynamicTexture(mesh.name + \" AdvancedDynamicTexture\", width, height, mesh.getScene(), true, Texture.TRILINEAR_SAMPLINGMODE, invertY);\r\n var material = new StandardMaterial(\"AdvancedDynamicTextureMaterial\", mesh.getScene());\r\n material.backFaceCulling = false;\r\n material.diffuseColor = Color3.Black();\r\n material.specularColor = Color3.Black();\r\n if (onlyAlphaTesting) {\r\n material.diffuseTexture = result;\r\n material.emissiveTexture = result;\r\n result.hasAlpha = true;\r\n }\r\n else {\r\n material.emissiveTexture = result;\r\n material.opacityTexture = result;\r\n }\r\n mesh.material = material;\r\n result.attachToMesh(mesh, supportPointerMove);\r\n return result;\r\n };\r\n /**\r\n * Creates a new AdvancedDynamicTexture in projected mode (ie. attached to a mesh) BUT do not create a new material for the mesh. You will be responsible for connecting the texture\r\n * @param mesh defines the mesh which will receive the texture\r\n * @param width defines the texture width (1024 by default)\r\n * @param height defines the texture height (1024 by default)\r\n * @param supportPointerMove defines a boolean indicating if the texture must capture move events (true by default)\r\n * @param invertY defines if the texture needs to be inverted on the y axis during loading (true by default)\r\n * @returns a new AdvancedDynamicTexture\r\n */\r\n AdvancedDynamicTexture.CreateForMeshTexture = function (mesh, width, height, supportPointerMove, invertY) {\r\n if (width === void 0) { width = 1024; }\r\n if (height === void 0) { height = 1024; }\r\n if (supportPointerMove === void 0) { supportPointerMove = true; }\r\n var result = new AdvancedDynamicTexture(mesh.name + \" AdvancedDynamicTexture\", width, height, mesh.getScene(), true, Texture.TRILINEAR_SAMPLINGMODE, invertY);\r\n result.attachToMesh(mesh, supportPointerMove);\r\n return result;\r\n };\r\n /**\r\n * Creates a new AdvancedDynamicTexture in fullscreen mode.\r\n * In this mode the texture will rely on a layer for its rendering.\r\n * This allows it to be treated like any other layer.\r\n * As such, if you have a multi camera setup, you can set the layerMask on the GUI as well.\r\n * LayerMask is set through advancedTexture.layer.layerMask\r\n * @param name defines name for the texture\r\n * @param foreground defines a boolean indicating if the texture must be rendered in foreground (default is true)\r\n * @param scene defines the hsoting scene\r\n * @param sampling defines the texture sampling mode (Texture.BILINEAR_SAMPLINGMODE by default)\r\n * @returns a new AdvancedDynamicTexture\r\n */\r\n AdvancedDynamicTexture.CreateFullscreenUI = function (name, foreground, scene, sampling) {\r\n if (foreground === void 0) { foreground = true; }\r\n if (scene === void 0) { scene = null; }\r\n if (sampling === void 0) { sampling = Texture.BILINEAR_SAMPLINGMODE; }\r\n var result = new AdvancedDynamicTexture(name, 0, 0, scene, false, sampling);\r\n // Display\r\n var layer = new Layer(name + \"_layer\", null, scene, !foreground);\r\n layer.texture = result;\r\n result._layerToDispose = layer;\r\n result._isFullscreen = true;\r\n // Attach\r\n result.attach();\r\n return result;\r\n };\r\n return AdvancedDynamicTexture;\r\n}(DynamicTexture));\r\nexport { AdvancedDynamicTexture };\r\n//# sourceMappingURL=advancedDynamicTexture.js.map","import { __extends } from \"tslib\";\r\nimport { TmpVectors } from \"../Maths/math.vector\";\r\nimport { Logger } from \"../Misc/logger\";\r\nimport { AbstractMesh } from \"../Meshes/abstractMesh\";\r\nimport { Mesh } from \"../Meshes/mesh\";\r\nimport { DeepCopier } from \"../Misc/deepCopier\";\r\nimport { TransformNode } from './transformNode';\r\nimport { VertexBuffer } from './buffer';\r\nimport { BoundingInfo } from '../Culling/boundingInfo';\r\nimport { Tools } from '../Misc/tools';\r\nMesh._instancedMeshFactory = function (name, mesh) {\r\n var instance = new InstancedMesh(name, mesh);\r\n if (mesh.instancedBuffers) {\r\n instance.instancedBuffers = {};\r\n for (var key in mesh.instancedBuffers) {\r\n instance.instancedBuffers[key] = mesh.instancedBuffers[key];\r\n }\r\n }\r\n return instance;\r\n};\r\n/**\r\n * Creates an instance based on a source mesh.\r\n */\r\nvar InstancedMesh = /** @class */ (function (_super) {\r\n __extends(InstancedMesh, _super);\r\n function InstancedMesh(name, source) {\r\n var _this = _super.call(this, name, source.getScene()) || this;\r\n /** @hidden */\r\n _this._indexInSourceMeshInstanceArray = -1;\r\n source.addInstance(_this);\r\n _this._sourceMesh = source;\r\n _this._unIndexed = source._unIndexed;\r\n _this.position.copyFrom(source.position);\r\n _this.rotation.copyFrom(source.rotation);\r\n _this.scaling.copyFrom(source.scaling);\r\n if (source.rotationQuaternion) {\r\n _this.rotationQuaternion = source.rotationQuaternion.clone();\r\n }\r\n _this.animations = Tools.Slice(source.animations);\r\n for (var _i = 0, _a = source.getAnimationRanges(); _i < _a.length; _i++) {\r\n var range = _a[_i];\r\n if (range != null) {\r\n _this.createAnimationRange(range.name, range.from, range.to);\r\n }\r\n }\r\n _this.infiniteDistance = source.infiniteDistance;\r\n _this.setPivotMatrix(source.getPivotMatrix());\r\n _this.refreshBoundingInfo();\r\n _this._syncSubMeshes();\r\n return _this;\r\n }\r\n /**\r\n * Returns the string \"InstancedMesh\".\r\n */\r\n InstancedMesh.prototype.getClassName = function () {\r\n return \"InstancedMesh\";\r\n };\r\n Object.defineProperty(InstancedMesh.prototype, \"lightSources\", {\r\n /** Gets the list of lights affecting that mesh */\r\n get: function () {\r\n return this._sourceMesh._lightSources;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n InstancedMesh.prototype._resyncLightSources = function () {\r\n // Do nothing as all the work will be done by source mesh\r\n };\r\n InstancedMesh.prototype._resyncLightSource = function (light) {\r\n // Do nothing as all the work will be done by source mesh\r\n };\r\n InstancedMesh.prototype._removeLightSource = function (light, dispose) {\r\n // Do nothing as all the work will be done by source mesh\r\n };\r\n Object.defineProperty(InstancedMesh.prototype, \"receiveShadows\", {\r\n // Methods\r\n /**\r\n * If the source mesh receives shadows\r\n */\r\n get: function () {\r\n return this._sourceMesh.receiveShadows;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InstancedMesh.prototype, \"material\", {\r\n /**\r\n * The material of the source mesh\r\n */\r\n get: function () {\r\n return this._sourceMesh.material;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InstancedMesh.prototype, \"visibility\", {\r\n /**\r\n * Visibility of the source mesh\r\n */\r\n get: function () {\r\n return this._sourceMesh.visibility;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InstancedMesh.prototype, \"skeleton\", {\r\n /**\r\n * Skeleton of the source mesh\r\n */\r\n get: function () {\r\n return this._sourceMesh.skeleton;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(InstancedMesh.prototype, \"renderingGroupId\", {\r\n /**\r\n * Rendering ground id of the source mesh\r\n */\r\n get: function () {\r\n return this._sourceMesh.renderingGroupId;\r\n },\r\n set: function (value) {\r\n if (!this._sourceMesh || value === this._sourceMesh.renderingGroupId) {\r\n return;\r\n }\r\n //no-op with warning\r\n Logger.Warn(\"Note - setting renderingGroupId of an instanced mesh has no effect on the scene\");\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Returns the total number of vertices (integer).\r\n */\r\n InstancedMesh.prototype.getTotalVertices = function () {\r\n return this._sourceMesh ? this._sourceMesh.getTotalVertices() : 0;\r\n };\r\n /**\r\n * Returns a positive integer : the total number of indices in this mesh geometry.\r\n * @returns the numner of indices or zero if the mesh has no geometry.\r\n */\r\n InstancedMesh.prototype.getTotalIndices = function () {\r\n return this._sourceMesh.getTotalIndices();\r\n };\r\n Object.defineProperty(InstancedMesh.prototype, \"sourceMesh\", {\r\n /**\r\n * The source mesh of the instance\r\n */\r\n get: function () {\r\n return this._sourceMesh;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Creates a new InstancedMesh object from the mesh model.\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_instances\r\n * @param name defines the name of the new instance\r\n * @returns a new InstancedMesh\r\n */\r\n InstancedMesh.prototype.createInstance = function (name) {\r\n return this._sourceMesh.createInstance(name);\r\n };\r\n /**\r\n * Is this node ready to be used/rendered\r\n * @param completeCheck defines if a complete check (including materials and lights) has to be done (false by default)\r\n * @return {boolean} is it ready\r\n */\r\n InstancedMesh.prototype.isReady = function (completeCheck) {\r\n if (completeCheck === void 0) { completeCheck = false; }\r\n return this._sourceMesh.isReady(completeCheck, true);\r\n };\r\n /**\r\n * Returns an array of integers or a typed array (Int32Array, Uint32Array, Uint16Array) populated with the mesh indices.\r\n * @param kind kind of verticies to retreive (eg. positons, normals, uvs, etc.)\r\n * @param copyWhenShared If true (default false) and and if the mesh geometry is shared among some other meshes, the returned array is a copy of the internal one.\r\n * @returns a float array or a Float32Array of the requested kind of data : positons, normals, uvs, etc.\r\n */\r\n InstancedMesh.prototype.getVerticesData = function (kind, copyWhenShared) {\r\n return this._sourceMesh.getVerticesData(kind, copyWhenShared);\r\n };\r\n /**\r\n * Sets the vertex data of the mesh geometry for the requested `kind`.\r\n * If the mesh has no geometry, a new Geometry object is set to the mesh and then passed this vertex data.\r\n * The `data` are either a numeric array either a Float32Array.\r\n * The parameter `updatable` is passed as is to the underlying Geometry object constructor (if initianilly none) or updater.\r\n * The parameter `stride` is an optional positive integer, it is usually automatically deducted from the `kind` (3 for positions or normals, 2 for UV, etc).\r\n * Note that a new underlying VertexBuffer object is created each call.\r\n * If the `kind` is the `PositionKind`, the mesh BoundingInfo is renewed, so the bounding box and sphere, and the mesh World Matrix is recomputed.\r\n *\r\n * Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n *\r\n * Returns the Mesh.\r\n */\r\n InstancedMesh.prototype.setVerticesData = function (kind, data, updatable, stride) {\r\n if (this.sourceMesh) {\r\n this.sourceMesh.setVerticesData(kind, data, updatable, stride);\r\n }\r\n return this.sourceMesh;\r\n };\r\n /**\r\n * Updates the existing vertex data of the mesh geometry for the requested `kind`.\r\n * If the mesh has no geometry, it is simply returned as it is.\r\n * The `data` are either a numeric array either a Float32Array.\r\n * No new underlying VertexBuffer object is created.\r\n * If the `kind` is the `PositionKind` and if `updateExtends` is true, the mesh BoundingInfo is renewed, so the bounding box and sphere, and the mesh World Matrix is recomputed.\r\n * If the parameter `makeItUnique` is true, a new global geometry is created from this positions and is set to the mesh.\r\n *\r\n * Possible `kind` values :\r\n * - VertexBuffer.PositionKind\r\n * - VertexBuffer.UVKind\r\n * - VertexBuffer.UV2Kind\r\n * - VertexBuffer.UV3Kind\r\n * - VertexBuffer.UV4Kind\r\n * - VertexBuffer.UV5Kind\r\n * - VertexBuffer.UV6Kind\r\n * - VertexBuffer.ColorKind\r\n * - VertexBuffer.MatricesIndicesKind\r\n * - VertexBuffer.MatricesIndicesExtraKind\r\n * - VertexBuffer.MatricesWeightsKind\r\n * - VertexBuffer.MatricesWeightsExtraKind\r\n *\r\n * Returns the Mesh.\r\n */\r\n InstancedMesh.prototype.updateVerticesData = function (kind, data, updateExtends, makeItUnique) {\r\n if (this.sourceMesh) {\r\n this.sourceMesh.updateVerticesData(kind, data, updateExtends, makeItUnique);\r\n }\r\n return this.sourceMesh;\r\n };\r\n /**\r\n * Sets the mesh indices.\r\n * Expects an array populated with integers or a typed array (Int32Array, Uint32Array, Uint16Array).\r\n * If the mesh has no geometry, a new Geometry object is created and set to the mesh.\r\n * This method creates a new index buffer each call.\r\n * Returns the Mesh.\r\n */\r\n InstancedMesh.prototype.setIndices = function (indices, totalVertices) {\r\n if (totalVertices === void 0) { totalVertices = null; }\r\n if (this.sourceMesh) {\r\n this.sourceMesh.setIndices(indices, totalVertices);\r\n }\r\n return this.sourceMesh;\r\n };\r\n /**\r\n * Boolean : True if the mesh owns the requested kind of data.\r\n */\r\n InstancedMesh.prototype.isVerticesDataPresent = function (kind) {\r\n return this._sourceMesh.isVerticesDataPresent(kind);\r\n };\r\n /**\r\n * Returns an array of indices (IndicesArray).\r\n */\r\n InstancedMesh.prototype.getIndices = function () {\r\n return this._sourceMesh.getIndices();\r\n };\r\n Object.defineProperty(InstancedMesh.prototype, \"_positions\", {\r\n get: function () {\r\n return this._sourceMesh._positions;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * This method recomputes and sets a new BoundingInfo to the mesh unless it is locked.\r\n * This means the mesh underlying bounding box and sphere are recomputed.\r\n * @param applySkeleton defines whether to apply the skeleton before computing the bounding info\r\n * @returns the current mesh\r\n */\r\n InstancedMesh.prototype.refreshBoundingInfo = function (applySkeleton) {\r\n if (applySkeleton === void 0) { applySkeleton = false; }\r\n if (this._boundingInfo && this._boundingInfo.isLocked) {\r\n return this;\r\n }\r\n var bias = this._sourceMesh.geometry ? this._sourceMesh.geometry.boundingBias : null;\r\n this._refreshBoundingInfo(this._sourceMesh._getPositionData(applySkeleton), bias);\r\n return this;\r\n };\r\n /** @hidden */\r\n InstancedMesh.prototype._preActivate = function () {\r\n if (this._currentLOD) {\r\n this._currentLOD._preActivate();\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n InstancedMesh.prototype._activate = function (renderId, intermediateRendering) {\r\n if (!this._sourceMesh.subMeshes) {\r\n Logger.Warn(\"Instances should only be created for meshes with geometry.\");\r\n }\r\n if (this._currentLOD) {\r\n var differentSign = (this._currentLOD._getWorldMatrixDeterminant() > 0) !== (this._getWorldMatrixDeterminant() > 0);\r\n if (differentSign) {\r\n this._internalAbstractMeshDataInfo._actAsRegularMesh = true;\r\n return true;\r\n }\r\n this._internalAbstractMeshDataInfo._actAsRegularMesh = false;\r\n this._currentLOD._registerInstanceForRenderId(this, renderId);\r\n if (intermediateRendering) {\r\n if (!this._currentLOD._internalAbstractMeshDataInfo._isActiveIntermediate) {\r\n this._currentLOD._internalAbstractMeshDataInfo._onlyForInstancesIntermediate = true;\r\n return true;\r\n }\r\n }\r\n else {\r\n if (!this._currentLOD._internalAbstractMeshDataInfo._isActive) {\r\n this._currentLOD._internalAbstractMeshDataInfo._onlyForInstances = true;\r\n return true;\r\n }\r\n }\r\n }\r\n return false;\r\n };\r\n /** @hidden */\r\n InstancedMesh.prototype._postActivate = function () {\r\n if (this._sourceMesh.edgesShareWithInstances && this._sourceMesh._edgesRenderer && this._sourceMesh._edgesRenderer.isEnabled && this._sourceMesh._renderingGroup) {\r\n // we are using the edge renderer of the source mesh\r\n this._sourceMesh._renderingGroup._edgesRenderers.pushNoDuplicate(this._sourceMesh._edgesRenderer);\r\n this._sourceMesh._edgesRenderer.customInstances.push(this.getWorldMatrix());\r\n }\r\n else if (this._edgesRenderer && this._edgesRenderer.isEnabled && this._sourceMesh._renderingGroup) {\r\n // we are using the edge renderer defined for this instance\r\n this._sourceMesh._renderingGroup._edgesRenderers.push(this._edgesRenderer);\r\n }\r\n };\r\n InstancedMesh.prototype.getWorldMatrix = function () {\r\n if (this._currentLOD && this._currentLOD.billboardMode !== TransformNode.BILLBOARDMODE_NONE && this._currentLOD._masterMesh !== this) {\r\n var tempMaster = this._currentLOD._masterMesh;\r\n this._currentLOD._masterMesh = this;\r\n TmpVectors.Vector3[7].copyFrom(this._currentLOD.position);\r\n this._currentLOD.position.set(0, 0, 0);\r\n TmpVectors.Matrix[0].copyFrom(this._currentLOD.computeWorldMatrix(true));\r\n this._currentLOD.position.copyFrom(TmpVectors.Vector3[7]);\r\n this._currentLOD._masterMesh = tempMaster;\r\n return TmpVectors.Matrix[0];\r\n }\r\n return _super.prototype.getWorldMatrix.call(this);\r\n };\r\n Object.defineProperty(InstancedMesh.prototype, \"isAnInstance\", {\r\n get: function () {\r\n return true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Returns the current associated LOD AbstractMesh.\r\n */\r\n InstancedMesh.prototype.getLOD = function (camera) {\r\n if (!camera) {\r\n return this;\r\n }\r\n var boundingInfo = this.getBoundingInfo();\r\n this._currentLOD = this.sourceMesh.getLOD(camera, boundingInfo.boundingSphere);\r\n if (this._currentLOD === this.sourceMesh) {\r\n return this.sourceMesh;\r\n }\r\n return this._currentLOD;\r\n };\r\n /** @hidden */\r\n InstancedMesh.prototype._preActivateForIntermediateRendering = function (renderId) {\r\n return this.sourceMesh._preActivateForIntermediateRendering(renderId);\r\n };\r\n /** @hidden */\r\n InstancedMesh.prototype._syncSubMeshes = function () {\r\n this.releaseSubMeshes();\r\n if (this._sourceMesh.subMeshes) {\r\n for (var index = 0; index < this._sourceMesh.subMeshes.length; index++) {\r\n this._sourceMesh.subMeshes[index].clone(this, this._sourceMesh);\r\n }\r\n }\r\n return this;\r\n };\r\n /** @hidden */\r\n InstancedMesh.prototype._generatePointsArray = function () {\r\n return this._sourceMesh._generatePointsArray();\r\n };\r\n /** @hidden */\r\n InstancedMesh.prototype._updateBoundingInfo = function () {\r\n var effectiveMesh = this;\r\n if (this._boundingInfo) {\r\n this._boundingInfo.update(effectiveMesh.worldMatrixFromCache);\r\n }\r\n else {\r\n this._boundingInfo = new BoundingInfo(this.absolutePosition, this.absolutePosition, effectiveMesh.worldMatrixFromCache);\r\n }\r\n this._updateSubMeshesBoundingInfo(effectiveMesh.worldMatrixFromCache);\r\n return this;\r\n };\r\n /**\r\n * Creates a new InstancedMesh from the current mesh.\r\n * - name (string) : the cloned mesh name\r\n * - newParent (optional Node) : the optional Node to parent the clone to.\r\n * - doNotCloneChildren (optional boolean, default `false`) : if `true` the model children aren't cloned.\r\n *\r\n * Returns the clone.\r\n */\r\n InstancedMesh.prototype.clone = function (name, newParent, doNotCloneChildren) {\r\n if (newParent === void 0) { newParent = null; }\r\n var result = this._sourceMesh.createInstance(name);\r\n // Deep copy\r\n DeepCopier.DeepCopy(this, result, [\r\n \"name\", \"subMeshes\", \"uniqueId\", \"parent\", \"lightSources\",\r\n \"receiveShadows\", \"material\", \"visibility\", \"skeleton\",\r\n \"sourceMesh\", \"isAnInstance\", \"facetNb\", \"isFacetDataEnabled\",\r\n \"isBlocked\", \"useBones\", \"hasInstances\", \"collider\", \"edgesRenderer\",\r\n \"forward\", \"up\", \"right\", \"absolutePosition\", \"absoluteScaling\", \"absoluteRotationQuaternion\",\r\n \"isWorldMatrixFrozen\", \"nonUniformScaling\", \"behaviors\", \"worldMatrixFromCache\", \"hasThinInstances\"\r\n ], []);\r\n // Bounding info\r\n this.refreshBoundingInfo();\r\n // Parent\r\n if (newParent) {\r\n result.parent = newParent;\r\n }\r\n if (!doNotCloneChildren) {\r\n // Children\r\n for (var index = 0; index < this.getScene().meshes.length; index++) {\r\n var mesh = this.getScene().meshes[index];\r\n if (mesh.parent === this) {\r\n mesh.clone(mesh.name, result);\r\n }\r\n }\r\n }\r\n result.computeWorldMatrix(true);\r\n return result;\r\n };\r\n /**\r\n * Disposes the InstancedMesh.\r\n * Returns nothing.\r\n */\r\n InstancedMesh.prototype.dispose = function (doNotRecurse, disposeMaterialAndTextures) {\r\n if (disposeMaterialAndTextures === void 0) { disposeMaterialAndTextures = false; }\r\n // Remove from mesh\r\n this._sourceMesh.removeInstance(this);\r\n _super.prototype.dispose.call(this, doNotRecurse, disposeMaterialAndTextures);\r\n };\r\n return InstancedMesh;\r\n}(AbstractMesh));\r\nexport { InstancedMesh };\r\nMesh.prototype.edgesShareWithInstances = false;\r\nMesh.prototype.registerInstancedBuffer = function (kind, stride) {\r\n // Remove existing one\r\n this.removeVerticesData(kind);\r\n // Creates the instancedBuffer field if not present\r\n if (!this.instancedBuffers) {\r\n this.instancedBuffers = {};\r\n for (var _i = 0, _a = this.instances; _i < _a.length; _i++) {\r\n var instance = _a[_i];\r\n instance.instancedBuffers = {};\r\n }\r\n this._userInstancedBuffersStorage = {\r\n data: {},\r\n vertexBuffers: {},\r\n strides: {},\r\n sizes: {}\r\n };\r\n }\r\n // Creates an empty property for this kind\r\n this.instancedBuffers[kind] = null;\r\n this._userInstancedBuffersStorage.strides[kind] = stride;\r\n this._userInstancedBuffersStorage.sizes[kind] = stride * 32; // Initial size\r\n this._userInstancedBuffersStorage.data[kind] = new Float32Array(this._userInstancedBuffersStorage.sizes[kind]);\r\n this._userInstancedBuffersStorage.vertexBuffers[kind] = new VertexBuffer(this.getEngine(), this._userInstancedBuffersStorage.data[kind], kind, true, false, stride, true);\r\n this.setVerticesBuffer(this._userInstancedBuffersStorage.vertexBuffers[kind]);\r\n for (var _b = 0, _c = this.instances; _b < _c.length; _b++) {\r\n var instance = _c[_b];\r\n instance.instancedBuffers[kind] = null;\r\n }\r\n};\r\nMesh.prototype._processInstancedBuffers = function (visibleInstances, renderSelf) {\r\n var instanceCount = visibleInstances.length;\r\n for (var kind in this.instancedBuffers) {\r\n var size = this._userInstancedBuffersStorage.sizes[kind];\r\n var stride = this._userInstancedBuffersStorage.strides[kind];\r\n // Resize if required\r\n var expectedSize = (instanceCount + 1) * stride;\r\n while (size < expectedSize) {\r\n size *= 2;\r\n }\r\n if (this._userInstancedBuffersStorage.data[kind].length != size) {\r\n this._userInstancedBuffersStorage.data[kind] = new Float32Array(size);\r\n this._userInstancedBuffersStorage.sizes[kind] = size;\r\n if (this._userInstancedBuffersStorage.vertexBuffers[kind]) {\r\n this._userInstancedBuffersStorage.vertexBuffers[kind].dispose();\r\n this._userInstancedBuffersStorage.vertexBuffers[kind] = null;\r\n }\r\n }\r\n var data = this._userInstancedBuffersStorage.data[kind];\r\n // Update data buffer\r\n var offset = 0;\r\n if (renderSelf) {\r\n var value = this.instancedBuffers[kind];\r\n if (value.toArray) {\r\n value.toArray(data, offset);\r\n }\r\n else {\r\n value.copyToArray(data, offset);\r\n }\r\n offset += stride;\r\n }\r\n for (var instanceIndex = 0; instanceIndex < instanceCount; instanceIndex++) {\r\n var instance = visibleInstances[instanceIndex];\r\n var value = instance.instancedBuffers[kind];\r\n if (value.toArray) {\r\n value.toArray(data, offset);\r\n }\r\n else {\r\n value.copyToArray(data, offset);\r\n }\r\n offset += stride;\r\n }\r\n // Update vertex buffer\r\n if (!this._userInstancedBuffersStorage.vertexBuffers[kind]) {\r\n this._userInstancedBuffersStorage.vertexBuffers[kind] = new VertexBuffer(this.getEngine(), this._userInstancedBuffersStorage.data[kind], kind, true, false, stride, true);\r\n this.setVerticesBuffer(this._userInstancedBuffersStorage.vertexBuffers[kind]);\r\n }\r\n else {\r\n this._userInstancedBuffersStorage.vertexBuffers[kind].updateDirectly(data, 0);\r\n }\r\n }\r\n};\r\nMesh.prototype._disposeInstanceSpecificData = function () {\r\n if (this._instanceDataStorage.instancesBuffer) {\r\n this._instanceDataStorage.instancesBuffer.dispose();\r\n this._instanceDataStorage.instancesBuffer = null;\r\n }\r\n while (this.instances.length) {\r\n this.instances[0].dispose();\r\n }\r\n for (var kind in this.instancedBuffers) {\r\n if (this._userInstancedBuffersStorage.vertexBuffers[kind]) {\r\n this._userInstancedBuffersStorage.vertexBuffers[kind].dispose();\r\n }\r\n }\r\n this.instancedBuffers = {};\r\n};\r\n//# sourceMappingURL=instancedMesh.js.map","import { __assign, __extends } from \"tslib\";\r\nimport { SerializationHelper } from \"../Misc/decorators\";\r\nimport { Matrix, Vector3, Vector2, Vector4 } from \"../Maths/math.vector\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { Texture } from \"../Materials/Textures/texture\";\r\nimport { MaterialHelper } from \"./materialHelper\";\r\nimport { Material } from \"./material\";\r\nimport { _TypeStore } from '../Misc/typeStore';\r\nimport { Color3, Color4 } from '../Maths/math.color';\r\nimport { EffectFallbacks } from './effectFallbacks';\r\nimport { WebRequest } from '../Misc/webRequest';\r\nimport { Engine } from '../Engines/engine';\r\nvar onCreatedEffectParameters = { effect: null, subMesh: null };\r\n/**\r\n * The ShaderMaterial object has the necessary methods to pass data from your scene to the Vertex and Fragment Shaders and returns a material that can be applied to any mesh.\r\n *\r\n * This returned material effects how the mesh will look based on the code in the shaders.\r\n *\r\n * @see https://doc.babylonjs.com/how_to/shader_material\r\n */\r\nvar ShaderMaterial = /** @class */ (function (_super) {\r\n __extends(ShaderMaterial, _super);\r\n /**\r\n * Instantiate a new shader material.\r\n * The ShaderMaterial object has the necessary methods to pass data from your scene to the Vertex and Fragment Shaders and returns a material that can be applied to any mesh.\r\n * This returned material effects how the mesh will look based on the code in the shaders.\r\n * @see https://doc.babylonjs.com/how_to/shader_material\r\n * @param name Define the name of the material in the scene\r\n * @param scene Define the scene the material belongs to\r\n * @param shaderPath Defines the route to the shader code in one of three ways:\r\n * * object: { vertex: \"custom\", fragment: \"custom\" }, used with Effect.ShadersStore[\"customVertexShader\"] and Effect.ShadersStore[\"customFragmentShader\"]\r\n * * object: { vertexElement: \"vertexShaderCode\", fragmentElement: \"fragmentShaderCode\" }, used with shader code in script tags\r\n * * object: { vertexSource: \"vertex shader code string\", fragmentSource: \"fragment shader code string\" } using with strings containing the shaders code\r\n * * string: \"./COMMON_NAME\", used with external files COMMON_NAME.vertex.fx and COMMON_NAME.fragment.fx in index.html folder.\r\n * @param options Define the options used to create the shader\r\n */\r\n function ShaderMaterial(name, scene, shaderPath, options) {\r\n if (options === void 0) { options = {}; }\r\n var _this = _super.call(this, name, scene) || this;\r\n _this._textures = {};\r\n _this._textureArrays = {};\r\n _this._floats = {};\r\n _this._ints = {};\r\n _this._floatsArrays = {};\r\n _this._colors3 = {};\r\n _this._colors3Arrays = {};\r\n _this._colors4 = {};\r\n _this._colors4Arrays = {};\r\n _this._vectors2 = {};\r\n _this._vectors3 = {};\r\n _this._vectors4 = {};\r\n _this._matrices = {};\r\n _this._matrixArrays = {};\r\n _this._matrices3x3 = {};\r\n _this._matrices2x2 = {};\r\n _this._vectors2Arrays = {};\r\n _this._vectors3Arrays = {};\r\n _this._vectors4Arrays = {};\r\n _this._cachedWorldViewMatrix = new Matrix();\r\n _this._cachedWorldViewProjectionMatrix = new Matrix();\r\n _this._multiview = false;\r\n _this._shaderPath = shaderPath;\r\n _this._options = __assign({ needAlphaBlending: false, needAlphaTesting: false, attributes: [\"position\", \"normal\", \"uv\"], uniforms: [\"worldViewProjection\"], uniformBuffers: [], samplers: [], defines: [] }, options);\r\n return _this;\r\n }\r\n Object.defineProperty(ShaderMaterial.prototype, \"shaderPath\", {\r\n /**\r\n * Gets the shader path used to define the shader code\r\n * It can be modified to trigger a new compilation\r\n */\r\n get: function () {\r\n return this._shaderPath;\r\n },\r\n /**\r\n * Sets the shader path used to define the shader code\r\n * It can be modified to trigger a new compilation\r\n */\r\n set: function (shaderPath) {\r\n this._shaderPath = shaderPath;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ShaderMaterial.prototype, \"options\", {\r\n /**\r\n * Gets the options used to compile the shader.\r\n * They can be modified to trigger a new compilation\r\n */\r\n get: function () {\r\n return this._options;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets the current class name of the material e.g. \"ShaderMaterial\"\r\n * Mainly use in serialization.\r\n * @returns the class name\r\n */\r\n ShaderMaterial.prototype.getClassName = function () {\r\n return \"ShaderMaterial\";\r\n };\r\n /**\r\n * Specifies if the material will require alpha blending\r\n * @returns a boolean specifying if alpha blending is needed\r\n */\r\n ShaderMaterial.prototype.needAlphaBlending = function () {\r\n return (this.alpha < 1.0) || this._options.needAlphaBlending;\r\n };\r\n /**\r\n * Specifies if this material should be rendered in alpha test mode\r\n * @returns a boolean specifying if an alpha test is needed.\r\n */\r\n ShaderMaterial.prototype.needAlphaTesting = function () {\r\n return this._options.needAlphaTesting;\r\n };\r\n ShaderMaterial.prototype._checkUniform = function (uniformName) {\r\n if (this._options.uniforms.indexOf(uniformName) === -1) {\r\n this._options.uniforms.push(uniformName);\r\n }\r\n };\r\n /**\r\n * Set a texture in the shader.\r\n * @param name Define the name of the uniform samplers as defined in the shader\r\n * @param texture Define the texture to bind to this sampler\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setTexture = function (name, texture) {\r\n if (this._options.samplers.indexOf(name) === -1) {\r\n this._options.samplers.push(name);\r\n }\r\n this._textures[name] = texture;\r\n return this;\r\n };\r\n /**\r\n * Set a texture array in the shader.\r\n * @param name Define the name of the uniform sampler array as defined in the shader\r\n * @param textures Define the list of textures to bind to this sampler\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setTextureArray = function (name, textures) {\r\n if (this._options.samplers.indexOf(name) === -1) {\r\n this._options.samplers.push(name);\r\n }\r\n this._checkUniform(name);\r\n this._textureArrays[name] = textures;\r\n return this;\r\n };\r\n /**\r\n * Set a float in the shader.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setFloat = function (name, value) {\r\n this._checkUniform(name);\r\n this._floats[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a int in the shader.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setInt = function (name, value) {\r\n this._checkUniform(name);\r\n this._ints[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set an array of floats in the shader.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setFloats = function (name, value) {\r\n this._checkUniform(name);\r\n this._floatsArrays[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a vec3 in the shader from a Color3.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setColor3 = function (name, value) {\r\n this._checkUniform(name);\r\n this._colors3[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a vec3 array in the shader from a Color3 array.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setColor3Array = function (name, value) {\r\n this._checkUniform(name);\r\n this._colors3Arrays[name] = value.reduce(function (arr, color) {\r\n color.toArray(arr, arr.length);\r\n return arr;\r\n }, []);\r\n return this;\r\n };\r\n /**\r\n * Set a vec4 in the shader from a Color4.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setColor4 = function (name, value) {\r\n this._checkUniform(name);\r\n this._colors4[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a vec4 array in the shader from a Color4 array.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setColor4Array = function (name, value) {\r\n this._checkUniform(name);\r\n this._colors4Arrays[name] = value.reduce(function (arr, color) {\r\n color.toArray(arr, arr.length);\r\n return arr;\r\n }, []);\r\n return this;\r\n };\r\n /**\r\n * Set a vec2 in the shader from a Vector2.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setVector2 = function (name, value) {\r\n this._checkUniform(name);\r\n this._vectors2[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a vec3 in the shader from a Vector3.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setVector3 = function (name, value) {\r\n this._checkUniform(name);\r\n this._vectors3[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a vec4 in the shader from a Vector4.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setVector4 = function (name, value) {\r\n this._checkUniform(name);\r\n this._vectors4[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a mat4 in the shader from a Matrix.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setMatrix = function (name, value) {\r\n this._checkUniform(name);\r\n this._matrices[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a float32Array in the shader from a matrix array.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setMatrices = function (name, value) {\r\n this._checkUniform(name);\r\n var float32Array = new Float32Array(value.length * 16);\r\n for (var index = 0; index < value.length; index++) {\r\n var matrix = value[index];\r\n matrix.copyToArray(float32Array, index * 16);\r\n }\r\n this._matrixArrays[name] = float32Array;\r\n return this;\r\n };\r\n /**\r\n * Set a mat3 in the shader from a Float32Array.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setMatrix3x3 = function (name, value) {\r\n this._checkUniform(name);\r\n this._matrices3x3[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a mat2 in the shader from a Float32Array.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setMatrix2x2 = function (name, value) {\r\n this._checkUniform(name);\r\n this._matrices2x2[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a vec2 array in the shader from a number array.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setArray2 = function (name, value) {\r\n this._checkUniform(name);\r\n this._vectors2Arrays[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a vec3 array in the shader from a number array.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setArray3 = function (name, value) {\r\n this._checkUniform(name);\r\n this._vectors3Arrays[name] = value;\r\n return this;\r\n };\r\n /**\r\n * Set a vec4 array in the shader from a number array.\r\n * @param name Define the name of the uniform as defined in the shader\r\n * @param value Define the value to give to the uniform\r\n * @return the material itself allowing \"fluent\" like uniform updates\r\n */\r\n ShaderMaterial.prototype.setArray4 = function (name, value) {\r\n this._checkUniform(name);\r\n this._vectors4Arrays[name] = value;\r\n return this;\r\n };\r\n ShaderMaterial.prototype._checkCache = function (mesh, useInstances) {\r\n if (!mesh) {\r\n return true;\r\n }\r\n if (this._effect && (this._effect.defines.indexOf(\"#define INSTANCES\") !== -1) !== useInstances) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n /**\r\n * Specifies that the submesh is ready to be used\r\n * @param mesh defines the mesh to check\r\n * @param subMesh defines which submesh to check\r\n * @param useInstances specifies that instances should be used\r\n * @returns a boolean indicating that the submesh is ready or not\r\n */\r\n ShaderMaterial.prototype.isReadyForSubMesh = function (mesh, subMesh, useInstances) {\r\n return this.isReady(mesh, useInstances);\r\n };\r\n /**\r\n * Checks if the material is ready to render the requested mesh\r\n * @param mesh Define the mesh to render\r\n * @param useInstances Define whether or not the material is used with instances\r\n * @returns true if ready, otherwise false\r\n */\r\n ShaderMaterial.prototype.isReady = function (mesh, useInstances) {\r\n var _a, _b;\r\n if (this._effect && this.isFrozen) {\r\n if (this._effect._wasPreviouslyReady) {\r\n return true;\r\n }\r\n }\r\n var scene = this.getScene();\r\n var engine = scene.getEngine();\r\n if (!this.checkReadyOnEveryCall) {\r\n if (this._renderId === scene.getRenderId()) {\r\n if (this._checkCache(mesh, useInstances)) {\r\n return true;\r\n }\r\n }\r\n }\r\n // Instances\r\n var defines = [];\r\n var attribs = [];\r\n var fallbacks = new EffectFallbacks();\r\n // global multiview\r\n if (engine.getCaps().multiview &&\r\n scene.activeCamera &&\r\n scene.activeCamera.outputRenderTarget &&\r\n scene.activeCamera.outputRenderTarget.getViewCount() > 1) {\r\n this._multiview = true;\r\n defines.push(\"#define MULTIVIEW\");\r\n if (this._options.uniforms.indexOf(\"viewProjection\") !== -1 &&\r\n this._options.uniforms.push(\"viewProjectionR\") === -1) {\r\n this._options.uniforms.push(\"viewProjectionR\");\r\n }\r\n }\r\n for (var index = 0; index < this._options.defines.length; index++) {\r\n defines.push(this._options.defines[index]);\r\n }\r\n for (var index = 0; index < this._options.attributes.length; index++) {\r\n attribs.push(this._options.attributes[index]);\r\n }\r\n if (mesh && mesh.isVerticesDataPresent(VertexBuffer.ColorKind)) {\r\n attribs.push(VertexBuffer.ColorKind);\r\n defines.push(\"#define VERTEXCOLOR\");\r\n }\r\n if (useInstances) {\r\n defines.push(\"#define INSTANCES\");\r\n MaterialHelper.PushAttributesForInstances(attribs);\r\n if (mesh === null || mesh === void 0 ? void 0 : mesh.hasThinInstances) {\r\n defines.push(\"#define THIN_INSTANCES\");\r\n }\r\n }\r\n // Bones\r\n var numInfluencers = 0;\r\n if (mesh && mesh.useBones && mesh.computeBonesUsingShaders && mesh.skeleton) {\r\n attribs.push(VertexBuffer.MatricesIndicesKind);\r\n attribs.push(VertexBuffer.MatricesWeightsKind);\r\n if (mesh.numBoneInfluencers > 4) {\r\n attribs.push(VertexBuffer.MatricesIndicesExtraKind);\r\n attribs.push(VertexBuffer.MatricesWeightsExtraKind);\r\n }\r\n var skeleton = mesh.skeleton;\r\n numInfluencers = mesh.numBoneInfluencers;\r\n defines.push(\"#define NUM_BONE_INFLUENCERS \" + numInfluencers);\r\n fallbacks.addCPUSkinningFallback(0, mesh);\r\n if (skeleton.isUsingTextureForMatrices) {\r\n defines.push(\"#define BONETEXTURE\");\r\n if (this._options.uniforms.indexOf(\"boneTextureWidth\") === -1) {\r\n this._options.uniforms.push(\"boneTextureWidth\");\r\n }\r\n if (this._options.samplers.indexOf(\"boneSampler\") === -1) {\r\n this._options.samplers.push(\"boneSampler\");\r\n }\r\n }\r\n else {\r\n defines.push(\"#define BonesPerMesh \" + (skeleton.bones.length + 1));\r\n if (this._options.uniforms.indexOf(\"mBones\") === -1) {\r\n this._options.uniforms.push(\"mBones\");\r\n }\r\n }\r\n }\r\n else {\r\n defines.push(\"#define NUM_BONE_INFLUENCERS 0\");\r\n }\r\n // Textures\r\n for (var name in this._textures) {\r\n if (!this._textures[name].isReady()) {\r\n return false;\r\n }\r\n }\r\n // Alpha test\r\n if (mesh && this._shouldTurnAlphaTestOn(mesh)) {\r\n defines.push(\"#define ALPHATEST\");\r\n }\r\n var shaderName = this._shaderPath, uniforms = this._options.uniforms, uniformBuffers = this._options.uniformBuffers, samplers = this._options.samplers;\r\n if (this.customShaderNameResolve) {\r\n uniforms = uniforms.slice();\r\n uniformBuffers = uniformBuffers.slice();\r\n samplers = samplers.slice();\r\n shaderName = this.customShaderNameResolve(shaderName, uniforms, uniformBuffers, samplers, defines, attribs);\r\n }\r\n var previousEffect = this._effect;\r\n var join = defines.join(\"\\n\");\r\n if (this._cachedDefines !== join) {\r\n this._cachedDefines = join;\r\n this._effect = engine.createEffect(shaderName, {\r\n attributes: attribs,\r\n uniformsNames: uniforms,\r\n uniformBuffersNames: uniformBuffers,\r\n samplers: samplers,\r\n defines: join,\r\n fallbacks: fallbacks,\r\n onCompiled: this.onCompiled,\r\n onError: this.onError,\r\n indexParameters: { maxSimultaneousMorphTargets: numInfluencers }\r\n }, engine);\r\n if (this._onEffectCreatedObservable) {\r\n onCreatedEffectParameters.effect = this._effect;\r\n this._onEffectCreatedObservable.notifyObservers(onCreatedEffectParameters);\r\n }\r\n }\r\n if ((_b = !((_a = this._effect) === null || _a === void 0 ? void 0 : _a.isReady())) !== null && _b !== void 0 ? _b : true) {\r\n return false;\r\n }\r\n if (previousEffect !== this._effect) {\r\n scene.resetCachedMaterial();\r\n }\r\n this._renderId = scene.getRenderId();\r\n this._effect._wasPreviouslyReady = true;\r\n return true;\r\n };\r\n /**\r\n * Binds the world matrix to the material\r\n * @param world defines the world transformation matrix\r\n * @param effectOverride - If provided, use this effect instead of internal effect\r\n */\r\n ShaderMaterial.prototype.bindOnlyWorldMatrix = function (world, effectOverride) {\r\n var scene = this.getScene();\r\n var effect = effectOverride !== null && effectOverride !== void 0 ? effectOverride : this._effect;\r\n if (!effect) {\r\n return;\r\n }\r\n if (this._options.uniforms.indexOf(\"world\") !== -1) {\r\n effect.setMatrix(\"world\", world);\r\n }\r\n if (this._options.uniforms.indexOf(\"worldView\") !== -1) {\r\n world.multiplyToRef(scene.getViewMatrix(), this._cachedWorldViewMatrix);\r\n effect.setMatrix(\"worldView\", this._cachedWorldViewMatrix);\r\n }\r\n if (this._options.uniforms.indexOf(\"worldViewProjection\") !== -1) {\r\n world.multiplyToRef(scene.getTransformMatrix(), this._cachedWorldViewProjectionMatrix);\r\n effect.setMatrix(\"worldViewProjection\", this._cachedWorldViewProjectionMatrix);\r\n }\r\n };\r\n /**\r\n * Binds the submesh to this material by preparing the effect and shader to draw\r\n * @param world defines the world transformation matrix\r\n * @param mesh defines the mesh containing the submesh\r\n * @param subMesh defines the submesh to bind the material to\r\n */\r\n ShaderMaterial.prototype.bindForSubMesh = function (world, mesh, subMesh) {\r\n this.bind(world, mesh, subMesh._effectOverride);\r\n };\r\n /**\r\n * Binds the material to the mesh\r\n * @param world defines the world transformation matrix\r\n * @param mesh defines the mesh to bind the material to\r\n * @param effectOverride - If provided, use this effect instead of internal effect\r\n */\r\n ShaderMaterial.prototype.bind = function (world, mesh, effectOverride) {\r\n // Std values\r\n this.bindOnlyWorldMatrix(world, effectOverride);\r\n var effect = effectOverride !== null && effectOverride !== void 0 ? effectOverride : this._effect;\r\n if (effect && this.getScene().getCachedMaterial() !== this) {\r\n if (this._options.uniforms.indexOf(\"view\") !== -1) {\r\n effect.setMatrix(\"view\", this.getScene().getViewMatrix());\r\n }\r\n if (this._options.uniforms.indexOf(\"projection\") !== -1) {\r\n effect.setMatrix(\"projection\", this.getScene().getProjectionMatrix());\r\n }\r\n if (this._options.uniforms.indexOf(\"viewProjection\") !== -1) {\r\n effect.setMatrix(\"viewProjection\", this.getScene().getTransformMatrix());\r\n if (this._multiview) {\r\n effect.setMatrix(\"viewProjectionR\", this.getScene()._transformMatrixR);\r\n }\r\n }\r\n if (this.getScene().activeCamera && this._options.uniforms.indexOf(\"cameraPosition\") !== -1) {\r\n effect.setVector3(\"cameraPosition\", this.getScene().activeCamera.globalPosition);\r\n }\r\n // Bones\r\n MaterialHelper.BindBonesParameters(mesh, effect);\r\n var name;\r\n // Texture\r\n for (name in this._textures) {\r\n effect.setTexture(name, this._textures[name]);\r\n }\r\n // Texture arrays\r\n for (name in this._textureArrays) {\r\n effect.setTextureArray(name, this._textureArrays[name]);\r\n }\r\n // Int\r\n for (name in this._ints) {\r\n effect.setInt(name, this._ints[name]);\r\n }\r\n // Float\r\n for (name in this._floats) {\r\n effect.setFloat(name, this._floats[name]);\r\n }\r\n // Floats\r\n for (name in this._floatsArrays) {\r\n effect.setArray(name, this._floatsArrays[name]);\r\n }\r\n // Color3\r\n for (name in this._colors3) {\r\n effect.setColor3(name, this._colors3[name]);\r\n }\r\n // Color3Array\r\n for (name in this._colors3Arrays) {\r\n effect.setArray3(name, this._colors3Arrays[name]);\r\n }\r\n // Color4\r\n for (name in this._colors4) {\r\n var color = this._colors4[name];\r\n effect.setFloat4(name, color.r, color.g, color.b, color.a);\r\n }\r\n // Color4Array\r\n for (name in this._colors4Arrays) {\r\n effect.setArray4(name, this._colors4Arrays[name]);\r\n }\r\n // Vector2\r\n for (name in this._vectors2) {\r\n effect.setVector2(name, this._vectors2[name]);\r\n }\r\n // Vector3\r\n for (name in this._vectors3) {\r\n effect.setVector3(name, this._vectors3[name]);\r\n }\r\n // Vector4\r\n for (name in this._vectors4) {\r\n effect.setVector4(name, this._vectors4[name]);\r\n }\r\n // Matrix\r\n for (name in this._matrices) {\r\n effect.setMatrix(name, this._matrices[name]);\r\n }\r\n // MatrixArray\r\n for (name in this._matrixArrays) {\r\n effect.setMatrices(name, this._matrixArrays[name]);\r\n }\r\n // Matrix 3x3\r\n for (name in this._matrices3x3) {\r\n effect.setMatrix3x3(name, this._matrices3x3[name]);\r\n }\r\n // Matrix 2x2\r\n for (name in this._matrices2x2) {\r\n effect.setMatrix2x2(name, this._matrices2x2[name]);\r\n }\r\n // Vector2Array\r\n for (name in this._vectors2Arrays) {\r\n effect.setArray2(name, this._vectors2Arrays[name]);\r\n }\r\n // Vector3Array\r\n for (name in this._vectors3Arrays) {\r\n effect.setArray3(name, this._vectors3Arrays[name]);\r\n }\r\n // Vector4Array\r\n for (name in this._vectors4Arrays) {\r\n effect.setArray4(name, this._vectors4Arrays[name]);\r\n }\r\n }\r\n var seffect = this._effect;\r\n this._effect = effect; // make sure the active effect is the right one if there are some observers for onBind that would need to get the current effect\r\n this._afterBind(mesh);\r\n this._effect = seffect;\r\n };\r\n ShaderMaterial.prototype._afterBind = function (mesh) {\r\n _super.prototype._afterBind.call(this, mesh);\r\n this.getScene()._cachedEffect = this._effect;\r\n };\r\n /**\r\n * Gets the active textures from the material\r\n * @returns an array of textures\r\n */\r\n ShaderMaterial.prototype.getActiveTextures = function () {\r\n var activeTextures = _super.prototype.getActiveTextures.call(this);\r\n for (var name in this._textures) {\r\n activeTextures.push(this._textures[name]);\r\n }\r\n for (var name in this._textureArrays) {\r\n var array = this._textureArrays[name];\r\n for (var index = 0; index < array.length; index++) {\r\n activeTextures.push(array[index]);\r\n }\r\n }\r\n return activeTextures;\r\n };\r\n /**\r\n * Specifies if the material uses a texture\r\n * @param texture defines the texture to check against the material\r\n * @returns a boolean specifying if the material uses the texture\r\n */\r\n ShaderMaterial.prototype.hasTexture = function (texture) {\r\n if (_super.prototype.hasTexture.call(this, texture)) {\r\n return true;\r\n }\r\n for (var name in this._textures) {\r\n if (this._textures[name] === texture) {\r\n return true;\r\n }\r\n }\r\n for (var name in this._textureArrays) {\r\n var array = this._textureArrays[name];\r\n for (var index = 0; index < array.length; index++) {\r\n if (array[index] === texture) {\r\n return true;\r\n }\r\n }\r\n }\r\n return false;\r\n };\r\n /**\r\n * Makes a duplicate of the material, and gives it a new name\r\n * @param name defines the new name for the duplicated material\r\n * @returns the cloned material\r\n */\r\n ShaderMaterial.prototype.clone = function (name) {\r\n var _this = this;\r\n var result = SerializationHelper.Clone(function () { return new ShaderMaterial(name, _this.getScene(), _this._shaderPath, _this._options); }, this);\r\n result.name = name;\r\n result.id = name;\r\n // Shader code path\r\n if (typeof result._shaderPath === 'object') {\r\n result._shaderPath = __assign({}, result._shaderPath);\r\n }\r\n // Options\r\n this._options = __assign({}, this._options);\r\n Object.keys(this._options).forEach(function (propName) {\r\n var propValue = _this._options[propName];\r\n if (Array.isArray(propValue)) {\r\n _this._options[propName] = propValue.slice(0);\r\n }\r\n });\r\n // Texture\r\n for (var key in this._textures) {\r\n result.setTexture(key, this._textures[key]);\r\n }\r\n // Float\r\n for (var key in this._floats) {\r\n result.setFloat(key, this._floats[key]);\r\n }\r\n // Floats\r\n for (var key in this._floatsArrays) {\r\n result.setFloats(key, this._floatsArrays[key]);\r\n }\r\n // Color3\r\n for (var key in this._colors3) {\r\n result.setColor3(key, this._colors3[key]);\r\n }\r\n // Color4\r\n for (var key in this._colors4) {\r\n result.setColor4(key, this._colors4[key]);\r\n }\r\n // Vector2\r\n for (var key in this._vectors2) {\r\n result.setVector2(key, this._vectors2[key]);\r\n }\r\n // Vector3\r\n for (var key in this._vectors3) {\r\n result.setVector3(key, this._vectors3[key]);\r\n }\r\n // Vector4\r\n for (var key in this._vectors4) {\r\n result.setVector4(key, this._vectors4[key]);\r\n }\r\n // Matrix\r\n for (var key in this._matrices) {\r\n result.setMatrix(key, this._matrices[key]);\r\n }\r\n // Matrix 3x3\r\n for (var key in this._matrices3x3) {\r\n result.setMatrix3x3(key, this._matrices3x3[key]);\r\n }\r\n // Matrix 2x2\r\n for (var key in this._matrices2x2) {\r\n result.setMatrix2x2(key, this._matrices2x2[key]);\r\n }\r\n return result;\r\n };\r\n /**\r\n * Disposes the material\r\n * @param forceDisposeEffect specifies if effects should be forcefully disposed\r\n * @param forceDisposeTextures specifies if textures should be forcefully disposed\r\n * @param notBoundToMesh specifies if the material that is being disposed is known to be not bound to any mesh\r\n */\r\n ShaderMaterial.prototype.dispose = function (forceDisposeEffect, forceDisposeTextures, notBoundToMesh) {\r\n if (forceDisposeTextures) {\r\n var name;\r\n for (name in this._textures) {\r\n this._textures[name].dispose();\r\n }\r\n for (name in this._textureArrays) {\r\n var array = this._textureArrays[name];\r\n for (var index = 0; index < array.length; index++) {\r\n array[index].dispose();\r\n }\r\n }\r\n }\r\n this._textures = {};\r\n _super.prototype.dispose.call(this, forceDisposeEffect, forceDisposeTextures, notBoundToMesh);\r\n };\r\n /**\r\n * Serializes this material in a JSON representation\r\n * @returns the serialized material object\r\n */\r\n ShaderMaterial.prototype.serialize = function () {\r\n var serializationObject = SerializationHelper.Serialize(this);\r\n serializationObject.customType = \"BABYLON.ShaderMaterial\";\r\n serializationObject.options = this._options;\r\n serializationObject.shaderPath = this._shaderPath;\r\n var name;\r\n // Texture\r\n serializationObject.textures = {};\r\n for (name in this._textures) {\r\n serializationObject.textures[name] = this._textures[name].serialize();\r\n }\r\n // Texture arrays\r\n serializationObject.textureArrays = {};\r\n for (name in this._textureArrays) {\r\n serializationObject.textureArrays[name] = [];\r\n var array = this._textureArrays[name];\r\n for (var index = 0; index < array.length; index++) {\r\n serializationObject.textureArrays[name].push(array[index].serialize());\r\n }\r\n }\r\n // Float\r\n serializationObject.floats = {};\r\n for (name in this._floats) {\r\n serializationObject.floats[name] = this._floats[name];\r\n }\r\n // Floats\r\n serializationObject.FloatArrays = {};\r\n for (name in this._floatsArrays) {\r\n serializationObject.FloatArrays[name] = this._floatsArrays[name];\r\n }\r\n // Color3\r\n serializationObject.colors3 = {};\r\n for (name in this._colors3) {\r\n serializationObject.colors3[name] = this._colors3[name].asArray();\r\n }\r\n // Color3 array\r\n serializationObject.colors3Arrays = {};\r\n for (name in this._colors3Arrays) {\r\n serializationObject.colors3Arrays[name] = this._colors3Arrays[name];\r\n }\r\n // Color4\r\n serializationObject.colors4 = {};\r\n for (name in this._colors4) {\r\n serializationObject.colors4[name] = this._colors4[name].asArray();\r\n }\r\n // Color4 array\r\n serializationObject.colors4Arrays = {};\r\n for (name in this._colors4Arrays) {\r\n serializationObject.colors4Arrays[name] = this._colors4Arrays[name];\r\n }\r\n // Vector2\r\n serializationObject.vectors2 = {};\r\n for (name in this._vectors2) {\r\n serializationObject.vectors2[name] = this._vectors2[name].asArray();\r\n }\r\n // Vector3\r\n serializationObject.vectors3 = {};\r\n for (name in this._vectors3) {\r\n serializationObject.vectors3[name] = this._vectors3[name].asArray();\r\n }\r\n // Vector4\r\n serializationObject.vectors4 = {};\r\n for (name in this._vectors4) {\r\n serializationObject.vectors4[name] = this._vectors4[name].asArray();\r\n }\r\n // Matrix\r\n serializationObject.matrices = {};\r\n for (name in this._matrices) {\r\n serializationObject.matrices[name] = this._matrices[name].asArray();\r\n }\r\n // MatrixArray\r\n serializationObject.matrixArray = {};\r\n for (name in this._matrixArrays) {\r\n serializationObject.matrixArray[name] = this._matrixArrays[name];\r\n }\r\n // Matrix 3x3\r\n serializationObject.matrices3x3 = {};\r\n for (name in this._matrices3x3) {\r\n serializationObject.matrices3x3[name] = this._matrices3x3[name];\r\n }\r\n // Matrix 2x2\r\n serializationObject.matrices2x2 = {};\r\n for (name in this._matrices2x2) {\r\n serializationObject.matrices2x2[name] = this._matrices2x2[name];\r\n }\r\n // Vector2Array\r\n serializationObject.vectors2Arrays = {};\r\n for (name in this._vectors2Arrays) {\r\n serializationObject.vectors2Arrays[name] = this._vectors2Arrays[name];\r\n }\r\n // Vector3Array\r\n serializationObject.vectors3Arrays = {};\r\n for (name in this._vectors3Arrays) {\r\n serializationObject.vectors3Arrays[name] = this._vectors3Arrays[name];\r\n }\r\n // Vector4Array\r\n serializationObject.vectors4Arrays = {};\r\n for (name in this._vectors4Arrays) {\r\n serializationObject.vectors4Arrays[name] = this._vectors4Arrays[name];\r\n }\r\n return serializationObject;\r\n };\r\n /**\r\n * Creates a shader material from parsed shader material data\r\n * @param source defines the JSON represnetation of the material\r\n * @param scene defines the hosting scene\r\n * @param rootUrl defines the root URL to use to load textures and relative dependencies\r\n * @returns a new material\r\n */\r\n ShaderMaterial.Parse = function (source, scene, rootUrl) {\r\n var material = SerializationHelper.Parse(function () { return new ShaderMaterial(source.name, scene, source.shaderPath, source.options); }, source, scene, rootUrl);\r\n var name;\r\n // Texture\r\n for (name in source.textures) {\r\n material.setTexture(name, Texture.Parse(source.textures[name], scene, rootUrl));\r\n }\r\n // Texture arrays\r\n for (name in source.textureArrays) {\r\n var array = source.textureArrays[name];\r\n var textureArray = new Array();\r\n for (var index = 0; index < array.length; index++) {\r\n textureArray.push(Texture.Parse(array[index], scene, rootUrl));\r\n }\r\n material.setTextureArray(name, textureArray);\r\n }\r\n // Float\r\n for (name in source.floats) {\r\n material.setFloat(name, source.floats[name]);\r\n }\r\n // Float s\r\n for (name in source.floatsArrays) {\r\n material.setFloats(name, source.floatsArrays[name]);\r\n }\r\n // Color3\r\n for (name in source.colors3) {\r\n material.setColor3(name, Color3.FromArray(source.colors3[name]));\r\n }\r\n // Color3 arrays\r\n for (name in source.colors3Arrays) {\r\n var colors = source.colors3Arrays[name].reduce(function (arr, num, i) {\r\n if (i % 3 === 0) {\r\n arr.push([num]);\r\n }\r\n else {\r\n arr[arr.length - 1].push(num);\r\n }\r\n return arr;\r\n }, []).map(function (color) { return Color3.FromArray(color); });\r\n material.setColor3Array(name, colors);\r\n }\r\n // Color4\r\n for (name in source.colors4) {\r\n material.setColor4(name, Color4.FromArray(source.colors4[name]));\r\n }\r\n // Color4 arrays\r\n for (name in source.colors4Arrays) {\r\n var colors = source.colors4Arrays[name].reduce(function (arr, num, i) {\r\n if (i % 4 === 0) {\r\n arr.push([num]);\r\n }\r\n else {\r\n arr[arr.length - 1].push(num);\r\n }\r\n return arr;\r\n }, []).map(function (color) { return Color4.FromArray(color); });\r\n material.setColor4Array(name, colors);\r\n }\r\n // Vector2\r\n for (name in source.vectors2) {\r\n material.setVector2(name, Vector2.FromArray(source.vectors2[name]));\r\n }\r\n // Vector3\r\n for (name in source.vectors3) {\r\n material.setVector3(name, Vector3.FromArray(source.vectors3[name]));\r\n }\r\n // Vector4\r\n for (name in source.vectors4) {\r\n material.setVector4(name, Vector4.FromArray(source.vectors4[name]));\r\n }\r\n // Matrix\r\n for (name in source.matrices) {\r\n material.setMatrix(name, Matrix.FromArray(source.matrices[name]));\r\n }\r\n // MatrixArray\r\n for (name in source.matrixArray) {\r\n material._matrixArrays[name] = new Float32Array(source.matrixArray[name]);\r\n }\r\n // Matrix 3x3\r\n for (name in source.matrices3x3) {\r\n material.setMatrix3x3(name, source.matrices3x3[name]);\r\n }\r\n // Matrix 2x2\r\n for (name in source.matrices2x2) {\r\n material.setMatrix2x2(name, source.matrices2x2[name]);\r\n }\r\n // Vector2Array\r\n for (name in source.vectors2Arrays) {\r\n material.setArray2(name, source.vectors2Arrays[name]);\r\n }\r\n // Vector3Array\r\n for (name in source.vectors3Arrays) {\r\n material.setArray3(name, source.vectors3Arrays[name]);\r\n }\r\n // Vector4Array\r\n for (name in source.vectors4Arrays) {\r\n material.setArray4(name, source.vectors4Arrays[name]);\r\n }\r\n return material;\r\n };\r\n /**\r\n * Creates a new ShaderMaterial from a snippet saved in a remote file\r\n * @param name defines the name of the ShaderMaterial to create (can be null or empty to use the one from the json data)\r\n * @param url defines the url to load from\r\n * @param scene defines the hosting scene\r\n * @param rootUrl defines the root URL to use to load textures and relative dependencies\r\n * @returns a promise that will resolve to the new ShaderMaterial\r\n */\r\n ShaderMaterial.ParseFromFileAsync = function (name, url, scene, rootUrl) {\r\n var _this = this;\r\n if (rootUrl === void 0) { rootUrl = \"\"; }\r\n return new Promise(function (resolve, reject) {\r\n var request = new WebRequest();\r\n request.addEventListener(\"readystatechange\", function () {\r\n if (request.readyState == 4) {\r\n if (request.status == 200) {\r\n var serializationObject = JSON.parse(request.responseText);\r\n var output = _this.Parse(serializationObject, scene || Engine.LastCreatedScene, rootUrl);\r\n if (name) {\r\n output.name = name;\r\n }\r\n resolve(output);\r\n }\r\n else {\r\n reject(\"Unable to load the ShaderMaterial\");\r\n }\r\n }\r\n });\r\n request.open(\"GET\", url);\r\n request.send();\r\n });\r\n };\r\n /**\r\n * Creates a ShaderMaterial from a snippet saved by the Inspector\r\n * @param snippetId defines the snippet to load\r\n * @param scene defines the hosting scene\r\n * @param rootUrl defines the root URL to use to load textures and relative dependencies\r\n * @returns a promise that will resolve to the new ShaderMaterial\r\n */\r\n ShaderMaterial.CreateFromSnippetAsync = function (snippetId, scene, rootUrl) {\r\n var _this = this;\r\n if (rootUrl === void 0) { rootUrl = \"\"; }\r\n return new Promise(function (resolve, reject) {\r\n var request = new WebRequest();\r\n request.addEventListener(\"readystatechange\", function () {\r\n if (request.readyState == 4) {\r\n if (request.status == 200) {\r\n var snippet = JSON.parse(JSON.parse(request.responseText).jsonPayload);\r\n var serializationObject = JSON.parse(snippet.shaderMaterial);\r\n var output = _this.Parse(serializationObject, scene || Engine.LastCreatedScene, rootUrl);\r\n output.snippetId = snippetId;\r\n resolve(output);\r\n }\r\n else {\r\n reject(\"Unable to load the snippet \" + snippetId);\r\n }\r\n }\r\n });\r\n request.open(\"GET\", _this.SnippetUrl + \"/\" + snippetId.replace(/#/g, \"/\"));\r\n request.send();\r\n });\r\n };\r\n /** Define the Url to load snippets */\r\n ShaderMaterial.SnippetUrl = \"https://snippet.babylonjs.com\";\r\n return ShaderMaterial;\r\n}(Material));\r\nexport { ShaderMaterial };\r\n_TypeStore.RegisteredTypes[\"BABYLON.ShaderMaterial\"] = ShaderMaterial;\r\n//# sourceMappingURL=shaderMaterial.js.map","import { Effect } from \"../Materials/effect\";\r\nimport \"./ShadersInclude/clipPlaneFragmentDeclaration\";\r\nimport \"./ShadersInclude/clipPlaneFragment\";\r\nvar name = 'colorPixelShader';\r\nvar shader = \"#ifdef VERTEXCOLOR\\nvarying vec4 vColor;\\n#else\\nuniform vec4 color;\\n#endif\\n#include\\nvoid main(void) {\\n#include\\n#ifdef VERTEXCOLOR\\ngl_FragColor=vColor;\\n#else\\ngl_FragColor=color;\\n#endif\\n}\";\r\nEffect.ShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var colorPixelShader = { name: name, shader: shader };\r\n//# sourceMappingURL=color.fragment.js.map","import { Effect } from \"../Materials/effect\";\r\nimport \"./ShadersInclude/bonesDeclaration\";\r\nimport \"./ShadersInclude/clipPlaneVertexDeclaration\";\r\nimport \"./ShadersInclude/instancesDeclaration\";\r\nimport \"./ShadersInclude/instancesVertex\";\r\nimport \"./ShadersInclude/bonesVertex\";\r\nimport \"./ShadersInclude/clipPlaneVertex\";\r\nvar name = 'colorVertexShader';\r\nvar shader = \"\\nattribute vec3 position;\\n#ifdef VERTEXCOLOR\\nattribute vec4 color;\\n#endif\\n#include\\n#include\\n\\n#include\\nuniform mat4 viewProjection;\\n#ifdef MULTIVIEW\\nuniform mat4 viewProjectionR;\\n#endif\\n\\n#ifdef VERTEXCOLOR\\nvarying vec4 vColor;\\n#endif\\nvoid main(void) {\\n#include\\n#include\\nvec4 worldPos=finalWorld*vec4(position,1.0);\\n#ifdef MULTIVIEW\\nif (gl_ViewID_OVR == 0u) {\\ngl_Position=viewProjection*worldPos;\\n} else {\\ngl_Position=viewProjectionR*worldPos;\\n}\\n#else\\ngl_Position=viewProjection*worldPos;\\n#endif\\n#include\\n#ifdef VERTEXCOLOR\\n\\nvColor=color;\\n#endif\\n}\";\r\nEffect.ShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var colorVertexShader = { name: name, shader: shader };\r\n//# sourceMappingURL=color.vertex.js.map","import { __extends } from \"tslib\";\r\nimport { Color3, Color4 } from \"../Maths/math.color\";\r\nimport { VertexBuffer } from \"../Meshes/buffer\";\r\nimport { Mesh } from \"../Meshes/mesh\";\r\nimport { InstancedMesh } from \"../Meshes/instancedMesh\";\r\nimport { Material } from \"../Materials/material\";\r\nimport { ShaderMaterial } from \"../Materials/shaderMaterial\";\r\nimport { MaterialHelper } from '../Materials/materialHelper';\r\nimport \"../Shaders/color.fragment\";\r\nimport \"../Shaders/color.vertex\";\r\n/**\r\n * Line mesh\r\n * @see https://doc.babylonjs.com/babylon101/parametric_shapes\r\n */\r\nvar LinesMesh = /** @class */ (function (_super) {\r\n __extends(LinesMesh, _super);\r\n /**\r\n * Creates a new LinesMesh\r\n * @param name defines the name\r\n * @param scene defines the hosting scene\r\n * @param parent defines the parent mesh if any\r\n * @param source defines the optional source LinesMesh used to clone data from\r\n * @param doNotCloneChildren When cloning, skip cloning child meshes of source, default False.\r\n * When false, achieved by calling a clone(), also passing False.\r\n * This will make creation of children, recursive.\r\n * @param useVertexColor defines if this LinesMesh supports vertex color\r\n * @param useVertexAlpha defines if this LinesMesh supports vertex alpha\r\n */\r\n function LinesMesh(name, scene, parent, source, doNotCloneChildren, \r\n /**\r\n * If vertex color should be applied to the mesh\r\n */\r\n useVertexColor, \r\n /**\r\n * If vertex alpha should be applied to the mesh\r\n */\r\n useVertexAlpha) {\r\n if (scene === void 0) { scene = null; }\r\n if (parent === void 0) { parent = null; }\r\n if (source === void 0) { source = null; }\r\n var _this = _super.call(this, name, scene, parent, source, doNotCloneChildren) || this;\r\n _this.useVertexColor = useVertexColor;\r\n _this.useVertexAlpha = useVertexAlpha;\r\n /**\r\n * Color of the line (Default: White)\r\n */\r\n _this.color = new Color3(1, 1, 1);\r\n /**\r\n * Alpha of the line (Default: 1)\r\n */\r\n _this.alpha = 1;\r\n if (source) {\r\n _this.color = source.color.clone();\r\n _this.alpha = source.alpha;\r\n _this.useVertexColor = source.useVertexColor;\r\n _this.useVertexAlpha = source.useVertexAlpha;\r\n }\r\n _this.intersectionThreshold = 0.1;\r\n var defines = [];\r\n var options = {\r\n attributes: [VertexBuffer.PositionKind, \"world0\", \"world1\", \"world2\", \"world3\"],\r\n uniforms: [\"vClipPlane\", \"vClipPlane2\", \"vClipPlane3\", \"vClipPlane4\", \"vClipPlane5\", \"vClipPlane6\", \"world\", \"viewProjection\"],\r\n needAlphaBlending: true,\r\n defines: defines\r\n };\r\n if (useVertexAlpha === false) {\r\n options.needAlphaBlending = false;\r\n }\r\n if (!useVertexColor) {\r\n options.uniforms.push(\"color\");\r\n _this.color4 = new Color4();\r\n }\r\n else {\r\n options.defines.push(\"#define VERTEXCOLOR\");\r\n options.attributes.push(VertexBuffer.ColorKind);\r\n }\r\n _this._colorShader = new ShaderMaterial(\"colorShader\", _this.getScene(), \"color\", options);\r\n return _this;\r\n }\r\n LinesMesh.prototype._addClipPlaneDefine = function (label) {\r\n var define = \"#define \" + label;\r\n var index = this._colorShader.options.defines.indexOf(define);\r\n if (index !== -1) {\r\n return;\r\n }\r\n this._colorShader.options.defines.push(define);\r\n };\r\n LinesMesh.prototype._removeClipPlaneDefine = function (label) {\r\n var define = \"#define \" + label;\r\n var index = this._colorShader.options.defines.indexOf(define);\r\n if (index === -1) {\r\n return;\r\n }\r\n this._colorShader.options.defines.splice(index, 1);\r\n };\r\n LinesMesh.prototype.isReady = function () {\r\n var scene = this.getScene();\r\n // Clip planes\r\n scene.clipPlane ? this._addClipPlaneDefine(\"CLIPPLANE\") : this._removeClipPlaneDefine(\"CLIPPLANE\");\r\n scene.clipPlane2 ? this._addClipPlaneDefine(\"CLIPPLANE2\") : this._removeClipPlaneDefine(\"CLIPPLANE2\");\r\n scene.clipPlane3 ? this._addClipPlaneDefine(\"CLIPPLANE3\") : this._removeClipPlaneDefine(\"CLIPPLANE3\");\r\n scene.clipPlane4 ? this._addClipPlaneDefine(\"CLIPPLANE4\") : this._removeClipPlaneDefine(\"CLIPPLANE4\");\r\n scene.clipPlane5 ? this._addClipPlaneDefine(\"CLIPPLANE5\") : this._removeClipPlaneDefine(\"CLIPPLANE5\");\r\n scene.clipPlane6 ? this._addClipPlaneDefine(\"CLIPPLANE6\") : this._removeClipPlaneDefine(\"CLIPPLANE6\");\r\n if (!this._colorShader.isReady(this)) {\r\n return false;\r\n }\r\n return _super.prototype.isReady.call(this);\r\n };\r\n /**\r\n * Returns the string \"LineMesh\"\r\n */\r\n LinesMesh.prototype.getClassName = function () {\r\n return \"LinesMesh\";\r\n };\r\n Object.defineProperty(LinesMesh.prototype, \"material\", {\r\n /**\r\n * @hidden\r\n */\r\n get: function () {\r\n return this._colorShader;\r\n },\r\n /**\r\n * @hidden\r\n */\r\n set: function (value) {\r\n // Do nothing\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(LinesMesh.prototype, \"checkCollisions\", {\r\n /**\r\n * @hidden\r\n */\r\n get: function () {\r\n return false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /** @hidden */\r\n LinesMesh.prototype._bind = function (subMesh, effect, fillMode) {\r\n if (!this._geometry) {\r\n return this;\r\n }\r\n var colorEffect = this._colorShader.getEffect();\r\n // VBOs\r\n var indexToBind = this.isUnIndexed ? null : this._geometry.getIndexBuffer();\r\n this._geometry._bind(colorEffect, indexToBind);\r\n // Color\r\n if (!this.useVertexColor) {\r\n var _a = this.color, r = _a.r, g = _a.g, b = _a.b;\r\n this.color4.set(r, g, b, this.alpha);\r\n this._colorShader.setColor4(\"color\", this.color4);\r\n }\r\n // Clip planes\r\n MaterialHelper.BindClipPlane(colorEffect, this.getScene());\r\n return this;\r\n };\r\n /** @hidden */\r\n LinesMesh.prototype._draw = function (subMesh, fillMode, instancesCount) {\r\n if (!this._geometry || !this._geometry.getVertexBuffers() || (!this._unIndexed && !this._geometry.getIndexBuffer())) {\r\n return this;\r\n }\r\n var engine = this.getScene().getEngine();\r\n // Draw order\r\n if (this._unIndexed) {\r\n engine.drawArraysType(Material.LineListDrawMode, subMesh.verticesStart, subMesh.verticesCount, instancesCount);\r\n }\r\n else {\r\n engine.drawElementsType(Material.LineListDrawMode, subMesh.indexStart, subMesh.indexCount, instancesCount);\r\n }\r\n return this;\r\n };\r\n /**\r\n * Disposes of the line mesh\r\n * @param doNotRecurse If children should be disposed\r\n */\r\n LinesMesh.prototype.dispose = function (doNotRecurse) {\r\n this._colorShader.dispose(false, false, true);\r\n _super.prototype.dispose.call(this, doNotRecurse);\r\n };\r\n /**\r\n * Returns a new LineMesh object cloned from the current one.\r\n */\r\n LinesMesh.prototype.clone = function (name, newParent, doNotCloneChildren) {\r\n if (newParent === void 0) { newParent = null; }\r\n return new LinesMesh(name, this.getScene(), newParent, this, doNotCloneChildren);\r\n };\r\n /**\r\n * Creates a new InstancedLinesMesh object from the mesh model.\r\n * @see https://doc.babylonjs.com/how_to/how_to_use_instances\r\n * @param name defines the name of the new instance\r\n * @returns a new InstancedLinesMesh\r\n */\r\n LinesMesh.prototype.createInstance = function (name) {\r\n return new InstancedLinesMesh(name, this);\r\n };\r\n return LinesMesh;\r\n}(Mesh));\r\nexport { LinesMesh };\r\n/**\r\n * Creates an instance based on a source LinesMesh\r\n */\r\nvar InstancedLinesMesh = /** @class */ (function (_super) {\r\n __extends(InstancedLinesMesh, _super);\r\n function InstancedLinesMesh(name, source) {\r\n var _this = _super.call(this, name, source) || this;\r\n _this.intersectionThreshold = source.intersectionThreshold;\r\n return _this;\r\n }\r\n /**\r\n * Returns the string \"InstancedLinesMesh\".\r\n */\r\n InstancedLinesMesh.prototype.getClassName = function () {\r\n return \"InstancedLinesMesh\";\r\n };\r\n return InstancedLinesMesh;\r\n}(InstancedMesh));\r\nexport { InstancedLinesMesh };\r\n//# sourceMappingURL=linesMesh.js.map","import { Vector3 } from \"../../Maths/math.vector\";\r\nimport { _CreationDataStorage, Mesh } from \"../mesh\";\r\nimport { VertexData } from \"../mesh.vertexData\";\r\nimport { LinesMesh } from \"../../Meshes/linesMesh\";\r\nimport { VertexBuffer } from \"../../Meshes/buffer\";\r\nVertexData.CreateLineSystem = function (options) {\r\n var indices = [];\r\n var positions = [];\r\n var lines = options.lines;\r\n var colors = options.colors;\r\n var vertexColors = [];\r\n var idx = 0;\r\n for (var l = 0; l < lines.length; l++) {\r\n var points = lines[l];\r\n for (var index = 0; index < points.length; index++) {\r\n positions.push(points[index].x, points[index].y, points[index].z);\r\n if (colors) {\r\n var color = colors[l];\r\n vertexColors.push(color[index].r, color[index].g, color[index].b, color[index].a);\r\n }\r\n if (index > 0) {\r\n indices.push(idx - 1);\r\n indices.push(idx);\r\n }\r\n idx++;\r\n }\r\n }\r\n var vertexData = new VertexData();\r\n vertexData.indices = indices;\r\n vertexData.positions = positions;\r\n if (colors) {\r\n vertexData.colors = vertexColors;\r\n }\r\n return vertexData;\r\n};\r\nVertexData.CreateDashedLines = function (options) {\r\n var dashSize = options.dashSize || 3;\r\n var gapSize = options.gapSize || 1;\r\n var dashNb = options.dashNb || 200;\r\n var points = options.points;\r\n var positions = new Array();\r\n var indices = new Array();\r\n var curvect = Vector3.Zero();\r\n var lg = 0;\r\n var nb = 0;\r\n var shft = 0;\r\n var dashshft = 0;\r\n var curshft = 0;\r\n var idx = 0;\r\n var i = 0;\r\n for (i = 0; i < points.length - 1; i++) {\r\n points[i + 1].subtractToRef(points[i], curvect);\r\n lg += curvect.length();\r\n }\r\n shft = lg / dashNb;\r\n dashshft = dashSize * shft / (dashSize + gapSize);\r\n for (i = 0; i < points.length - 1; i++) {\r\n points[i + 1].subtractToRef(points[i], curvect);\r\n nb = Math.floor(curvect.length() / shft);\r\n curvect.normalize();\r\n for (var j = 0; j < nb; j++) {\r\n curshft = shft * j;\r\n positions.push(points[i].x + curshft * curvect.x, points[i].y + curshft * curvect.y, points[i].z + curshft * curvect.z);\r\n positions.push(points[i].x + (curshft + dashshft) * curvect.x, points[i].y + (curshft + dashshft) * curvect.y, points[i].z + (curshft + dashshft) * curvect.z);\r\n indices.push(idx, idx + 1);\r\n idx += 2;\r\n }\r\n }\r\n // Result\r\n var vertexData = new VertexData();\r\n vertexData.positions = positions;\r\n vertexData.indices = indices;\r\n return vertexData;\r\n};\r\nMesh.CreateLines = function (name, points, scene, updatable, instance) {\r\n if (scene === void 0) { scene = null; }\r\n if (updatable === void 0) { updatable = false; }\r\n if (instance === void 0) { instance = null; }\r\n var options = {\r\n points: points,\r\n updatable: updatable,\r\n instance: instance\r\n };\r\n return LinesBuilder.CreateLines(name, options, scene);\r\n};\r\nMesh.CreateDashedLines = function (name, points, dashSize, gapSize, dashNb, scene, updatable, instance) {\r\n if (scene === void 0) { scene = null; }\r\n var options = {\r\n points: points,\r\n dashSize: dashSize,\r\n gapSize: gapSize,\r\n dashNb: dashNb,\r\n updatable: updatable,\r\n instance: instance\r\n };\r\n return LinesBuilder.CreateDashedLines(name, options, scene);\r\n};\r\n/**\r\n * Class containing static functions to help procedurally build meshes\r\n */\r\nvar LinesBuilder = /** @class */ (function () {\r\n function LinesBuilder() {\r\n }\r\n /**\r\n * Creates a line system mesh. A line system is a pool of many lines gathered in a single mesh\r\n * * A line system mesh is considered as a parametric shape since it has no predefined original shape. Its shape is determined by the passed array of lines as an input parameter\r\n * * Like every other parametric shape, it is dynamically updatable by passing an existing instance of LineSystem to this static function\r\n * * The parameter `lines` is an array of lines, each line being an array of successive Vector3\r\n * * The optional parameter `instance` is an instance of an existing LineSystem object to be updated with the passed `lines` parameter\r\n * * The optional parameter `colors` is an array of line colors, each line colors being an array of successive Color4, one per line point\r\n * * The optional parameter `useVertexAlpha` is to be set to `false` (default `true`) when you don't need the alpha blending (faster)\r\n * * Updating a simple Line mesh, you just need to update every line in the `lines` array : https://doc.babylonjs.com/how_to/how_to_dynamically_morph_a_mesh#lines-and-dashedlines\r\n * * When updating an instance, remember that only line point positions can change, not the number of points, neither the number of lines\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @see https://doc.babylonjs.com/how_to/parametric_shapes#line-system\r\n * @param name defines the name of the new line system\r\n * @param options defines the options used to create the line system\r\n * @param scene defines the hosting scene\r\n * @returns a new line system mesh\r\n */\r\n LinesBuilder.CreateLineSystem = function (name, options, scene) {\r\n var instance = options.instance;\r\n var lines = options.lines;\r\n var colors = options.colors;\r\n if (instance) { // lines update\r\n var positions = instance.getVerticesData(VertexBuffer.PositionKind);\r\n var vertexColor;\r\n var lineColors;\r\n if (colors) {\r\n vertexColor = instance.getVerticesData(VertexBuffer.ColorKind);\r\n }\r\n var i = 0;\r\n var c = 0;\r\n for (var l = 0; l < lines.length; l++) {\r\n var points = lines[l];\r\n for (var p = 0; p < points.length; p++) {\r\n positions[i] = points[p].x;\r\n positions[i + 1] = points[p].y;\r\n positions[i + 2] = points[p].z;\r\n if (colors && vertexColor) {\r\n lineColors = colors[l];\r\n vertexColor[c] = lineColors[p].r;\r\n vertexColor[c + 1] = lineColors[p].g;\r\n vertexColor[c + 2] = lineColors[p].b;\r\n vertexColor[c + 3] = lineColors[p].a;\r\n c += 4;\r\n }\r\n i += 3;\r\n }\r\n }\r\n instance.updateVerticesData(VertexBuffer.PositionKind, positions, false, false);\r\n if (colors && vertexColor) {\r\n instance.updateVerticesData(VertexBuffer.ColorKind, vertexColor, false, false);\r\n }\r\n return instance;\r\n }\r\n // line system creation\r\n var useVertexColor = (colors) ? true : false;\r\n var lineSystem = new LinesMesh(name, scene, null, undefined, undefined, useVertexColor, options.useVertexAlpha);\r\n var vertexData = VertexData.CreateLineSystem(options);\r\n vertexData.applyToMesh(lineSystem, options.updatable);\r\n return lineSystem;\r\n };\r\n /**\r\n * Creates a line mesh\r\n * A line mesh is considered as a parametric shape since it has no predefined original shape. Its shape is determined by the passed array of points as an input parameter\r\n * * Like every other parametric shape, it is dynamically updatable by passing an existing instance of LineMesh to this static function\r\n * * The parameter `points` is an array successive Vector3\r\n * * The optional parameter `instance` is an instance of an existing LineMesh object to be updated with the passed `points` parameter : https://doc.babylonjs.com/how_to/how_to_dynamically_morph_a_mesh#lines-and-dashedlines\r\n * * The optional parameter `colors` is an array of successive Color4, one per line point\r\n * * The optional parameter `useVertexAlpha` is to be set to `false` (default `true`) when you don't need alpha blending (faster)\r\n * * When updating an instance, remember that only point positions can change, not the number of points\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @see https://doc.babylonjs.com/how_to/parametric_shapes#lines\r\n * @param name defines the name of the new line system\r\n * @param options defines the options used to create the line system\r\n * @param scene defines the hosting scene\r\n * @returns a new line mesh\r\n */\r\n LinesBuilder.CreateLines = function (name, options, scene) {\r\n if (scene === void 0) { scene = null; }\r\n var colors = (options.colors) ? [options.colors] : null;\r\n var lines = LinesBuilder.CreateLineSystem(name, { lines: [options.points], updatable: options.updatable, instance: options.instance, colors: colors, useVertexAlpha: options.useVertexAlpha }, scene);\r\n return lines;\r\n };\r\n /**\r\n * Creates a dashed line mesh\r\n * * A dashed line mesh is considered as a parametric shape since it has no predefined original shape. Its shape is determined by the passed array of points as an input parameter\r\n * * Like every other parametric shape, it is dynamically updatable by passing an existing instance of LineMesh to this static function\r\n * * The parameter `points` is an array successive Vector3\r\n * * The parameter `dashNb` is the intended total number of dashes (positive integer, default 200)\r\n * * The parameter `dashSize` is the size of the dashes relatively the dash number (positive float, default 3)\r\n * * The parameter `gapSize` is the size of the gap between two successive dashes relatively the dash number (positive float, default 1)\r\n * * The optional parameter `instance` is an instance of an existing LineMesh object to be updated with the passed `points` parameter : https://doc.babylonjs.com/how_to/how_to_dynamically_morph_a_mesh#lines-and-dashedlines\r\n * * The optional parameter `useVertexAlpha` is to be set to `false` (default `true`) when you don't need the alpha blending (faster)\r\n * * When updating an instance, remember that only point positions can change, not the number of points\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @param name defines the name of the mesh\r\n * @param options defines the options used to create the mesh\r\n * @param scene defines the hosting scene\r\n * @returns the dashed line mesh\r\n * @see https://doc.babylonjs.com/how_to/parametric_shapes#dashed-lines\r\n */\r\n LinesBuilder.CreateDashedLines = function (name, options, scene) {\r\n if (scene === void 0) { scene = null; }\r\n var points = options.points;\r\n var instance = options.instance;\r\n var gapSize = options.gapSize || 1;\r\n var dashSize = options.dashSize || 3;\r\n if (instance) { // dashed lines update\r\n var positionFunction = function (positions) {\r\n var curvect = Vector3.Zero();\r\n var nbSeg = positions.length / 6;\r\n var lg = 0;\r\n var nb = 0;\r\n var shft = 0;\r\n var dashshft = 0;\r\n var curshft = 0;\r\n var p = 0;\r\n var i = 0;\r\n var j = 0;\r\n for (i = 0; i < points.length - 1; i++) {\r\n points[i + 1].subtractToRef(points[i], curvect);\r\n lg += curvect.length();\r\n }\r\n shft = lg / nbSeg;\r\n var dashSize = instance._creationDataStorage.dashSize;\r\n var gapSize = instance._creationDataStorage.gapSize;\r\n dashshft = dashSize * shft / (dashSize + gapSize);\r\n for (i = 0; i < points.length - 1; i++) {\r\n points[i + 1].subtractToRef(points[i], curvect);\r\n nb = Math.floor(curvect.length() / shft);\r\n curvect.normalize();\r\n j = 0;\r\n while (j < nb && p < positions.length) {\r\n curshft = shft * j;\r\n positions[p] = points[i].x + curshft * curvect.x;\r\n positions[p + 1] = points[i].y + curshft * curvect.y;\r\n positions[p + 2] = points[i].z + curshft * curvect.z;\r\n positions[p + 3] = points[i].x + (curshft + dashshft) * curvect.x;\r\n positions[p + 4] = points[i].y + (curshft + dashshft) * curvect.y;\r\n positions[p + 5] = points[i].z + (curshft + dashshft) * curvect.z;\r\n p += 6;\r\n j++;\r\n }\r\n }\r\n while (p < positions.length) {\r\n positions[p] = points[i].x;\r\n positions[p + 1] = points[i].y;\r\n positions[p + 2] = points[i].z;\r\n p += 3;\r\n }\r\n };\r\n instance.updateMeshPositions(positionFunction, false);\r\n return instance;\r\n }\r\n // dashed lines creation\r\n var dashedLines = new LinesMesh(name, scene, null, undefined, undefined, undefined, options.useVertexAlpha);\r\n var vertexData = VertexData.CreateDashedLines(options);\r\n vertexData.applyToMesh(dashedLines, options.updatable);\r\n dashedLines._creationDataStorage = new _CreationDataStorage();\r\n dashedLines._creationDataStorage.dashSize = dashSize;\r\n dashedLines._creationDataStorage.gapSize = gapSize;\r\n return dashedLines;\r\n };\r\n return LinesBuilder;\r\n}());\r\nexport { LinesBuilder };\r\n//# sourceMappingURL=linesBuilder.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serializeAsColor3, serializeAsVector3 } from \"../Misc/decorators\";\r\nimport { Matrix, Vector3 } from \"../Maths/math.vector\";\r\nimport { Color3 } from \"../Maths/math.color\";\r\nimport { Node } from \"../node\";\r\nimport { Light } from \"./light\";\r\nNode.AddNodeConstructor(\"Light_Type_3\", function (name, scene) {\r\n return function () { return new HemisphericLight(name, Vector3.Zero(), scene); };\r\n});\r\n/**\r\n * The HemisphericLight simulates the ambient environment light,\r\n * so the passed direction is the light reflection direction, not the incoming direction.\r\n */\r\nvar HemisphericLight = /** @class */ (function (_super) {\r\n __extends(HemisphericLight, _super);\r\n /**\r\n * Creates a HemisphericLight object in the scene according to the passed direction (Vector3).\r\n * The HemisphericLight simulates the ambient environment light, so the passed direction is the light reflection direction, not the incoming direction.\r\n * The HemisphericLight can't cast shadows.\r\n * Documentation : https://doc.babylonjs.com/babylon101/lights\r\n * @param name The friendly name of the light\r\n * @param direction The direction of the light reflection\r\n * @param scene The scene the light belongs to\r\n */\r\n function HemisphericLight(name, direction, scene) {\r\n var _this = _super.call(this, name, scene) || this;\r\n /**\r\n * The groundColor is the light in the opposite direction to the one specified during creation.\r\n * You can think of the diffuse and specular light as coming from the centre of the object in the given direction and the groundColor light in the opposite direction.\r\n */\r\n _this.groundColor = new Color3(0.0, 0.0, 0.0);\r\n _this.direction = direction || Vector3.Up();\r\n return _this;\r\n }\r\n HemisphericLight.prototype._buildUniformLayout = function () {\r\n this._uniformBuffer.addUniform(\"vLightData\", 4);\r\n this._uniformBuffer.addUniform(\"vLightDiffuse\", 4);\r\n this._uniformBuffer.addUniform(\"vLightSpecular\", 4);\r\n this._uniformBuffer.addUniform(\"vLightGround\", 3);\r\n this._uniformBuffer.addUniform(\"shadowsInfo\", 3);\r\n this._uniformBuffer.addUniform(\"depthValues\", 2);\r\n this._uniformBuffer.create();\r\n };\r\n /**\r\n * Returns the string \"HemisphericLight\".\r\n * @return The class name\r\n */\r\n HemisphericLight.prototype.getClassName = function () {\r\n return \"HemisphericLight\";\r\n };\r\n /**\r\n * Sets the HemisphericLight direction towards the passed target (Vector3).\r\n * Returns the updated direction.\r\n * @param target The target the direction should point to\r\n * @return The computed direction\r\n */\r\n HemisphericLight.prototype.setDirectionToTarget = function (target) {\r\n this.direction = Vector3.Normalize(target.subtract(Vector3.Zero()));\r\n return this.direction;\r\n };\r\n /**\r\n * Returns the shadow generator associated to the light.\r\n * @returns Always null for hemispheric lights because it does not support shadows.\r\n */\r\n HemisphericLight.prototype.getShadowGenerator = function () {\r\n return null;\r\n };\r\n /**\r\n * Sets the passed Effect object with the HemisphericLight normalized direction and color and the passed name (string).\r\n * @param effect The effect to update\r\n * @param lightIndex The index of the light in the effect to update\r\n * @returns The hemispheric light\r\n */\r\n HemisphericLight.prototype.transferToEffect = function (effect, lightIndex) {\r\n var normalizeDirection = Vector3.Normalize(this.direction);\r\n this._uniformBuffer.updateFloat4(\"vLightData\", normalizeDirection.x, normalizeDirection.y, normalizeDirection.z, 0.0, lightIndex);\r\n this._uniformBuffer.updateColor3(\"vLightGround\", this.groundColor.scale(this.intensity), lightIndex);\r\n return this;\r\n };\r\n HemisphericLight.prototype.transferToNodeMaterialEffect = function (effect, lightDataUniformName) {\r\n var normalizeDirection = Vector3.Normalize(this.direction);\r\n effect.setFloat3(lightDataUniformName, normalizeDirection.x, normalizeDirection.y, normalizeDirection.z);\r\n return this;\r\n };\r\n /**\r\n * Computes the world matrix of the node\r\n * @param force defines if the cache version should be invalidated forcing the world matrix to be created from scratch\r\n * @param useWasUpdatedFlag defines a reserved property\r\n * @returns the world matrix\r\n */\r\n HemisphericLight.prototype.computeWorldMatrix = function () {\r\n if (!this._worldMatrix) {\r\n this._worldMatrix = Matrix.Identity();\r\n }\r\n return this._worldMatrix;\r\n };\r\n /**\r\n * Returns the integer 3.\r\n * @return The light Type id as a constant defines in Light.LIGHTTYPEID_x\r\n */\r\n HemisphericLight.prototype.getTypeID = function () {\r\n return Light.LIGHTTYPEID_HEMISPHERICLIGHT;\r\n };\r\n /**\r\n * Prepares the list of defines specific to the light type.\r\n * @param defines the list of defines\r\n * @param lightIndex defines the index of the light for the effect\r\n */\r\n HemisphericLight.prototype.prepareLightSpecificDefines = function (defines, lightIndex) {\r\n defines[\"HEMILIGHT\" + lightIndex] = true;\r\n };\r\n __decorate([\r\n serializeAsColor3()\r\n ], HemisphericLight.prototype, \"groundColor\", void 0);\r\n __decorate([\r\n serializeAsVector3()\r\n ], HemisphericLight.prototype, \"direction\", void 0);\r\n return HemisphericLight;\r\n}(Light));\r\nexport { HemisphericLight };\r\n//# sourceMappingURL=hemisphericLight.js.map","//download.js v4.2, by dandavis; 2008-2016. [MIT] see http://danml.com/download.html for tests/usage\n// v1 landed a FF+Chrome compat way of downloading strings to local un-named files, upgraded to use a hidden frame and optional mime\n// v2 added named files via a[download], msSaveBlob, IE (10+) support, and window.URL support for larger+faster saves than dataURLs\n// v3 added dataURL and Blob Input, bind-toggle arity, and legacy dataURL fallback was improved with force-download mime and base64 support. 3.1 improved safari handling.\n// v4 adds AMD/UMD, commonJS, and plain browser support\n// v4.1 adds url download capability via solo URL argument (same domain/CORS only)\n// v4.2 adds semantic variable names, long (over 2MB) dataURL support, and hidden by default temp anchors\n// https://github.com/rndme/download\n\n(function (root, factory) {\n\tif (typeof define === 'function' && define.amd) {\n\t\t// AMD. Register as an anonymous module.\n\t\tdefine([], factory);\n\t} else if (typeof exports === 'object') {\n\t\t// Node. Does not work with strict CommonJS, but\n\t\t// only CommonJS-like environments that support module.exports,\n\t\t// like Node.\n\t\tmodule.exports = factory();\n\t} else {\n\t\t// Browser globals (root is window)\n\t\troot.download = factory();\n }\n}(this, function () {\n\n\treturn function download(data, strFileName, strMimeType) {\n\n\t\tvar self = window, // this script is only for browsers anyway...\n\t\t\tdefaultMime = \"application/octet-stream\", // this default mime also triggers iframe downloads\n\t\t\tmimeType = strMimeType || defaultMime,\n\t\t\tpayload = data,\n\t\t\turl = !strFileName && !strMimeType && payload,\n\t\t\tanchor = document.createElement(\"a\"),\n\t\t\ttoString = function(a){return String(a);},\n\t\t\tmyBlob = (self.Blob || self.MozBlob || self.WebKitBlob || toString),\n\t\t\tfileName = strFileName || \"download\",\n\t\t\tblob,\n\t\t\treader;\n\t\t\tmyBlob= myBlob.call ? myBlob.bind(self) : Blob ;\n\t \n\t\tif(String(this)===\"true\"){ //reverse arguments, allowing download.bind(true, \"text/xml\", \"export.xml\") to act as a callback\n\t\t\tpayload=[payload, mimeType];\n\t\t\tmimeType=payload[0];\n\t\t\tpayload=payload[1];\n\t\t}\n\n\n\t\tif(url && url.length< 2048){ // if no filename and no mime, assume a url was passed as the only argument\n\t\t\tfileName = url.split(\"/\").pop().split(\"?\")[0];\n\t\t\tanchor.href = url; // assign href prop to temp anchor\n\t\t \tif(anchor.href.indexOf(url) !== -1){ // if the browser determines that it's a potentially valid url path:\n \t\tvar ajax=new XMLHttpRequest();\n \t\tajax.open( \"GET\", url, true);\n \t\tajax.responseType = 'blob';\n \t\tajax.onload= function(e){ \n\t\t\t\t download(e.target.response, fileName, defaultMime);\n\t\t\t\t};\n \t\tsetTimeout(function(){ ajax.send();}, 0); // allows setting custom ajax headers using the return:\n\t\t\t return ajax;\n\t\t\t} // end if valid url?\n\t\t} // end if url?\n\n\n\t\t//go ahead and download dataURLs right away\n\t\tif(/^data:([\\w+-]+\\/[\\w+.-]+)?[,;]/.test(payload)){\n\t\t\n\t\t\tif(payload.length > (1024*1024*1.999) && myBlob !== toString ){\n\t\t\t\tpayload=dataUrlToBlob(payload);\n\t\t\t\tmimeType=payload.type || defaultMime;\n\t\t\t}else{\t\t\t\n\t\t\t\treturn navigator.msSaveBlob ? // IE10 can't do a[download], only Blobs:\n\t\t\t\t\tnavigator.msSaveBlob(dataUrlToBlob(payload), fileName) :\n\t\t\t\t\tsaver(payload) ; // everyone else can save dataURLs un-processed\n\t\t\t}\n\t\t\t\n\t\t}else{//not data url, is it a string with special needs?\n\t\t\tif(/([\\x80-\\xff])/.test(payload)){\t\t\t \n\t\t\t\tvar i=0, tempUiArr= new Uint8Array(payload.length), mx=tempUiArr.length;\n\t\t\t\tfor(i;i 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","'use strict';\n\nvar utils = require('../utils');\n\nmodule.exports = function normalizeHeaderName(headers, normalizedName) {\n utils.forEach(headers, function processHeader(value, name) {\n if (name !== normalizedName && name.toUpperCase() === normalizedName.toUpperCase()) {\n headers[normalizedName] = value;\n delete headers[name];\n }\n });\n};\n","'use strict';\n\nvar createError = require('./createError');\n\n/**\n * Resolve or reject a Promise based on response status.\n *\n * @param {Function} resolve A function that resolves the promise.\n * @param {Function} reject A function that rejects the promise.\n * @param {object} response The response.\n */\nmodule.exports = function settle(resolve, reject, response) {\n var validateStatus = response.config.validateStatus;\n if (!response.status || !validateStatus || validateStatus(response.status)) {\n resolve(response);\n } else {\n reject(createError(\n 'Request failed with status code ' + response.status,\n response.config,\n null,\n response.request,\n response\n ));\n }\n};\n","'use strict';\n\n/**\n * Update an Error with the specified config, error code, and response.\n *\n * @param {Error} error The error to update.\n * @param {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The error.\n */\nmodule.exports = function enhanceError(error, config, code, request, response) {\n error.config = config;\n if (code) {\n error.code = code;\n }\n\n error.request = request;\n error.response = response;\n error.isAxiosError = true;\n\n error.toJSON = function toJSON() {\n return {\n // Standard\n message: this.message,\n name: this.name,\n // Microsoft\n description: this.description,\n number: this.number,\n // Mozilla\n fileName: this.fileName,\n lineNumber: this.lineNumber,\n columnNumber: this.columnNumber,\n stack: this.stack,\n // Axios\n config: this.config,\n code: this.code\n };\n };\n return error;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nmodule.exports = (\n utils.isStandardBrowserEnv() ?\n\n // Standard browser envs support document.cookie\n (function standardBrowserEnv() {\n return {\n write: function write(name, value, expires, path, domain, secure) {\n var cookie = [];\n cookie.push(name + '=' + encodeURIComponent(value));\n\n if (utils.isNumber(expires)) {\n cookie.push('expires=' + new Date(expires).toGMTString());\n }\n\n if (utils.isString(path)) {\n cookie.push('path=' + path);\n }\n\n if (utils.isString(domain)) {\n cookie.push('domain=' + domain);\n }\n\n if (secure === true) {\n cookie.push('secure');\n }\n\n document.cookie = cookie.join('; ');\n },\n\n read: function read(name) {\n var match = document.cookie.match(new RegExp('(^|;\\\\s*)(' + name + ')=([^;]*)'));\n return (match ? decodeURIComponent(match[3]) : null);\n },\n\n remove: function remove(name) {\n this.write(name, '', Date.now() - 86400000);\n }\n };\n })() :\n\n // Non standard browser env (web workers, react-native) lack needed support.\n (function nonStandardBrowserEnv() {\n return {\n write: function write() {},\n read: function read() { return null; },\n remove: function remove() {}\n };\n })()\n);\n","'use strict';\n\nvar isAbsoluteURL = require('../helpers/isAbsoluteURL');\nvar combineURLs = require('../helpers/combineURLs');\n\n/**\n * Creates a new URL by combining the baseURL with the requestedURL,\n * only when the requestedURL is not already an absolute URL.\n * If the requestURL is absolute, this function returns the requestedURL untouched.\n *\n * @param {string} baseURL The base URL\n * @param {string} requestedURL Absolute or relative URL to combine\n * @returns {string} The combined full path\n */\nmodule.exports = function buildFullPath(baseURL, requestedURL) {\n if (baseURL && !isAbsoluteURL(requestedURL)) {\n return combineURLs(baseURL, requestedURL);\n }\n return requestedURL;\n};\n","'use strict';\n\n/**\n * Determines whether the specified URL is absolute\n *\n * @param {string} url The URL to test\n * @returns {boolean} True if the specified URL is absolute, otherwise false\n */\nmodule.exports = function isAbsoluteURL(url) {\n // A URL is considered absolute if it begins with \"://\" or \"//\" (protocol-relative URL).\n // RFC 3986 defines scheme name as a sequence of characters beginning with a letter and followed\n // by any combination of letters, digits, plus, period, or hyphen.\n return /^([a-z][a-z\\d\\+\\-\\.]*:)?\\/\\//i.test(url);\n};\n","'use strict';\n\n/**\n * Creates a new URL by combining the specified URLs\n *\n * @param {string} baseURL The base URL\n * @param {string} relativeURL The relative URL\n * @returns {string} The combined URL\n */\nmodule.exports = function combineURLs(baseURL, relativeURL) {\n return relativeURL\n ? baseURL.replace(/\\/+$/, '') + '/' + relativeURL.replace(/^\\/+/, '')\n : baseURL;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\n// Headers whose duplicates are ignored by node\n// c.f. https://nodejs.org/api/http.html#http_message_headers\nvar ignoreDuplicateOf = [\n 'age', 'authorization', 'content-length', 'content-type', 'etag',\n 'expires', 'from', 'host', 'if-modified-since', 'if-unmodified-since',\n 'last-modified', 'location', 'max-forwards', 'proxy-authorization',\n 'referer', 'retry-after', 'user-agent'\n];\n\n/**\n * Parse headers into an object\n *\n * ```\n * Date: Wed, 27 Aug 2014 08:58:49 GMT\n * Content-Type: application/json\n * Connection: keep-alive\n * Transfer-Encoding: chunked\n * ```\n *\n * @param {String} headers Headers needing to be parsed\n * @returns {Object} Headers parsed into an object\n */\nmodule.exports = function parseHeaders(headers) {\n var parsed = {};\n var key;\n var val;\n var i;\n\n if (!headers) { return parsed; }\n\n utils.forEach(headers.split('\\n'), function parser(line) {\n i = line.indexOf(':');\n key = utils.trim(line.substr(0, i)).toLowerCase();\n val = utils.trim(line.substr(i + 1));\n\n if (key) {\n if (parsed[key] && ignoreDuplicateOf.indexOf(key) >= 0) {\n return;\n }\n if (key === 'set-cookie') {\n parsed[key] = (parsed[key] ? parsed[key] : []).concat([val]);\n } else {\n parsed[key] = parsed[key] ? parsed[key] + ', ' + val : val;\n }\n }\n });\n\n return parsed;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nmodule.exports = (\n utils.isStandardBrowserEnv() ?\n\n // Standard browser envs have full support of the APIs needed to test\n // whether the request URL is of the same origin as current location.\n (function standardBrowserEnv() {\n var msie = /(msie|trident)/i.test(navigator.userAgent);\n var urlParsingNode = document.createElement('a');\n var originURL;\n\n /**\n * Parse a URL to discover it's components\n *\n * @param {String} url The URL to be parsed\n * @returns {Object}\n */\n function resolveURL(url) {\n var href = url;\n\n if (msie) {\n // IE needs attribute set twice to normalize properties\n urlParsingNode.setAttribute('href', href);\n href = urlParsingNode.href;\n }\n\n urlParsingNode.setAttribute('href', href);\n\n // urlParsingNode provides the UrlUtils interface - http://url.spec.whatwg.org/#urlutils\n return {\n href: urlParsingNode.href,\n protocol: urlParsingNode.protocol ? urlParsingNode.protocol.replace(/:$/, '') : '',\n host: urlParsingNode.host,\n search: urlParsingNode.search ? urlParsingNode.search.replace(/^\\?/, '') : '',\n hash: urlParsingNode.hash ? urlParsingNode.hash.replace(/^#/, '') : '',\n hostname: urlParsingNode.hostname,\n port: urlParsingNode.port,\n pathname: (urlParsingNode.pathname.charAt(0) === '/') ?\n urlParsingNode.pathname :\n '/' + urlParsingNode.pathname\n };\n }\n\n originURL = resolveURL(window.location.href);\n\n /**\n * Determine if a URL shares the same origin as the current location\n *\n * @param {String} requestURL The URL to test\n * @returns {boolean} True if URL shares the same origin, otherwise false\n */\n return function isURLSameOrigin(requestURL) {\n var parsed = (utils.isString(requestURL)) ? resolveURL(requestURL) : requestURL;\n return (parsed.protocol === originURL.protocol &&\n parsed.host === originURL.host);\n };\n })() :\n\n // Non standard browser envs (web workers, react-native) lack needed support.\n (function nonStandardBrowserEnv() {\n return function isURLSameOrigin() {\n return true;\n };\n })()\n);\n","'use strict';\n\nvar Cancel = require('./Cancel');\n\n/**\n * A `CancelToken` is an object that can be used to request cancellation of an operation.\n *\n * @class\n * @param {Function} executor The executor function.\n */\nfunction CancelToken(executor) {\n if (typeof executor !== 'function') {\n throw new TypeError('executor must be a function.');\n }\n\n var resolvePromise;\n this.promise = new Promise(function promiseExecutor(resolve) {\n resolvePromise = resolve;\n });\n\n var token = this;\n executor(function cancel(message) {\n if (token.reason) {\n // Cancellation has already been requested\n return;\n }\n\n token.reason = new Cancel(message);\n resolvePromise(token.reason);\n });\n}\n\n/**\n * Throws a `Cancel` if cancellation has been requested.\n */\nCancelToken.prototype.throwIfRequested = function throwIfRequested() {\n if (this.reason) {\n throw this.reason;\n }\n};\n\n/**\n * Returns an object that contains a new `CancelToken` and a function that, when called,\n * cancels the `CancelToken`.\n */\nCancelToken.source = function source() {\n var cancel;\n var token = new CancelToken(function executor(c) {\n cancel = c;\n });\n return {\n token: token,\n cancel: cancel\n };\n};\n\nmodule.exports = CancelToken;\n","'use strict';\n\n/**\n * Syntactic sugar for invoking a function and expanding an array for arguments.\n *\n * Common use case would be to use `Function.prototype.apply`.\n *\n * ```js\n * function f(x, y, z) {}\n * var args = [1, 2, 3];\n * f.apply(null, args);\n * ```\n *\n * With `spread` this example can be re-written.\n *\n * ```js\n * spread(function(x, y, z) {})([1, 2, 3]);\n * ```\n *\n * @param {Function} callback\n * @returns {Function}\n */\nmodule.exports = function spread(callback) {\n return function wrap(arr) {\n return callback.apply(null, arr);\n };\n};\n","/**\r\n * Babyplots - Easy, fast, interactive 3D visualizations\r\n *\r\n * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved.\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n * \r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n * \r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n * \r\n */\r\n\r\nimport { Scene } from \"@babylonjs/core/scene\";\r\nimport { ArcRotateCamera } from \"@babylonjs/core/Cameras/arcRotateCamera\";\r\nimport { Mesh } from \"@babylonjs/core/Meshes/mesh\";\r\nimport { Vector3, Axis, Color3 } from \"@babylonjs/core/Maths/math\";\r\nimport { PlaneBuilder } from \"@babylonjs/core/Meshes/Builders/planeBuilder\";\r\nimport { PointerDragBehavior } from \"@babylonjs/core/Behaviors/Meshes/pointerDragBehavior\";\r\nimport { AdvancedDynamicTexture } from \"@babylonjs/gui/2D/advancedDynamicTexture\";\r\nimport { Rectangle, TextBlock } from \"@babylonjs/gui/2D/controls\";\r\nimport { LinesBuilder } from \"@babylonjs/core/Meshes/Builders/linesBuilder\";\r\nimport { LinesMesh } from \"@babylonjs/core/Meshes/linesMesh\";\r\nimport { CylinderBuilder } from \"@babylonjs/core/Meshes/Builders/cylinderBuilder\";\r\n\r\nclass Arrow {\r\n private _lines: LinesMesh;\r\n private _tip: Mesh;\r\n\r\n size: number = 1;\r\n\r\n constructor(from: Vector3, to: Vector3, scene: Scene, color?: string) {\r\n let lines = LinesBuilder.CreateLineSystem('ls', {\r\n lines: [[from, to]],\r\n updatable: true\r\n }, scene);\r\n\r\n lines.color = new Color3(0, 0, 0);\r\n if (color !== undefined) {\r\n lines.color = Color3.FromHexString(color);\r\n }\r\n this._lines = lines;\r\n let tip = CylinderBuilder.CreateCylinder(\"tip\", {\r\n diameterTop: 0,\r\n diameterBottom: this.size,\r\n tessellation: 36\r\n }, scene);\r\n tip.position = to;\r\n\r\n }\r\n}\r\n\r\nclass Label {\r\n private _label: Mesh;\r\n private _background: Rectangle;\r\n private _text: TextBlock;\r\n\r\n size: number = 100;\r\n color: string = \"black\";\r\n fixed: boolean = false;\r\n\r\n constructor(text: string, position: Vector3, scene: Scene, color?: string) {\r\n let plane = PlaneBuilder.CreatePlane('label', {\r\n width: 5,\r\n height: 5\r\n }, scene);\r\n\r\n if (color !== undefined) {\r\n this.color = color;\r\n }\r\n\r\n plane.position = position;\r\n\r\n let advancedTexture = AdvancedDynamicTexture.CreateForMesh(plane);\r\n\r\n let background = new Rectangle();\r\n background.color = \"red\";\r\n background.alpha = 0\r\n advancedTexture.addControl(background);\r\n this._background = background;\r\n\r\n let textBlock = new TextBlock();\r\n textBlock.text = text;\r\n textBlock.color = this.color;\r\n textBlock.fontSize = this.size;\r\n advancedTexture.addControl(textBlock);\r\n this._text = textBlock;\r\n\r\n if (!this.fixed) {\r\n makeDraggable(plane);\r\n }\r\n\r\n this._label = plane;\r\n }\r\n\r\n setText(text: string) {\r\n this._text.text = text;\r\n }\r\n\r\n update(camera: ArcRotateCamera, scene: Scene) {\r\n // draw 3d labels in plot\r\n let axis1 = Vector3.Cross(camera.position, Axis.Y);\r\n let axis2 = Vector3.Cross(axis1, camera.position);\r\n let axis3 = Vector3.Cross(axis1, axis2);\r\n this._label.rotation = Vector3.RotationFromAxis(axis1, axis2, axis3);\r\n\r\n if (!this.fixed) {\r\n // highlighting label under mouse cursor\r\n const meshUnderPointer = scene.meshUnderPointer as Mesh;\r\n if (this._label === meshUnderPointer) {\r\n this._background.alpha = 1;\r\n } else {\r\n this._background.alpha = 0;\r\n }\r\n }\r\n }\r\n\r\n fix() {\r\n this._label.removeBehavior(this._label.getBehaviorByName(\"PointerDrag\"));\r\n this.fixed = true;\r\n }\r\n\r\n unfix() {\r\n makeDraggable(this._label);\r\n this.fixed = false;\r\n }\r\n\r\n dispose() {\r\n this._text.dispose();\r\n this._background.dispose();\r\n this._label.dispose();\r\n }\r\n\r\n export(): [number, number, number, string] {\r\n return [\r\n this._label.position.x,\r\n this._label.position.y,\r\n this._label.position.z,\r\n this._text.text\r\n ]\r\n }\r\n}\r\n\r\nexport class AnnotationManager {\r\n private _canvas: HTMLCanvasElement;\r\n private _scene: Scene;\r\n private _ymax: number;\r\n private _camera: ArcRotateCamera;\r\n private _labelControlBox: HTMLDivElement;\r\n private _editLabelContainer: HTMLDivElement;\r\n private _editLabelForms: HTMLDivElement[] = [];\r\n private _addLabelTextInput: HTMLInputElement;\r\n private _showLabels: boolean = false;\r\n private _arrows: Arrow[] = [];\r\n private _showArrows: boolean = false;\r\n\r\n labels: Label[] = [];\r\n fixedLabels: boolean = false;\r\n fixedArrows: boolean = false;\r\n\r\n constructor(canvas: HTMLCanvasElement, scene: Scene, ymax: number, camera: ArcRotateCamera) {\r\n this._canvas = canvas;\r\n this._scene = scene;\r\n this._ymax = ymax;\r\n this._camera = camera;\r\n this._createLabelForms();\r\n }\r\n\r\n private _createLabelForms() {\r\n let labelBox = document.createElement(\"div\");\r\n labelBox.className = \"bbp label-control\";\r\n labelBox.style.display = \"none\";\r\n labelBox.style.top = this._canvas.clientTop + 40 + \"px\";\r\n labelBox.style.left = this._canvas.clientTop + 5 + \"px\";\r\n let addLabelForm = document.createElement(\"div\");\r\n addLabelForm.className = \"label-form\";\r\n let addLabelLabel = document.createElement(\"label\");\r\n addLabelLabel.innerText = \"Label Text:\";\r\n addLabelLabel.htmlFor = \"addLabelInput\";\r\n let addLabelInput = document.createElement(\"input\");\r\n addLabelInput.name = \"addLabelInput\";\r\n addLabelInput.type = \"text\";\r\n this._addLabelTextInput = addLabelInput;\r\n let addLabelBtn = document.createElement(\"button\");\r\n addLabelBtn.innerText = \"Add Label\";\r\n addLabelBtn.onclick = this._addLabelBtnClick.bind(this);\r\n addLabelForm.appendChild(addLabelLabel);\r\n addLabelForm.appendChild(addLabelInput);\r\n addLabelForm.appendChild(addLabelBtn);\r\n labelBox.appendChild(addLabelForm);\r\n let editLabelContainer = document.createElement(\"div\");\r\n editLabelContainer.className = \"edit-container\";\r\n editLabelContainer.style.maxHeight = (this._canvas.height - 100).toString() + \"px\";\r\n labelBox.appendChild(editLabelContainer);\r\n this._editLabelContainer = editLabelContainer;\r\n this._labelControlBox = labelBox;\r\n this._canvas.parentNode.appendChild(labelBox);\r\n }\r\n\r\n update() {\r\n if (this._showArrows) {\r\n\r\n }\r\n if (this._showLabels) {\r\n for (let i = 0; i < this.labels.length; i++) {\r\n const label = this.labels[i];\r\n label.update(this._camera, this._scene);\r\n }\r\n }\r\n }\r\n\r\n toggleLabelControl() {\r\n if (this._labelControlBox.style.display == \"none\") {\r\n this._labelControlBox.style.display = \"block\";\r\n this.unfixLabels();\r\n } else {\r\n this._labelControlBox.style.display = \"none\";\r\n this.fixLabels();\r\n }\r\n }\r\n\r\n private _addLabelBtnClick(event: Event) {\r\n event.preventDefault();\r\n this.addLabel(this._addLabelTextInput.value);\r\n }\r\n\r\n addArrow(from: number[], to: number[]) {\r\n this._arrows.push(new Arrow(\r\n Vector3.FromArray(from),\r\n Vector3.FromArray(to),\r\n this._scene\r\n ));\r\n }\r\n\r\n /**\r\n * Add a 3d label to the plot\r\n * @param text Label title\r\n * @param [moveCallback] On dragging of label in 3d plot, the final position will be passed to this function\r\n */\r\n addLabel(text: string, position?: number[]): number {\r\n this._addLabelTextInput.value = \"\";\r\n let labelIdx = this.labels.length;\r\n\r\n let pos: Vector3;\r\n if (position) {\r\n pos = Vector3.FromArray(position)\r\n } else {\r\n pos = new Vector3(0, this._ymax + 2, 0);\r\n }\r\n\r\n let newLabel = new Label(text, pos, this._scene);\r\n\r\n this.labels.push(newLabel);\r\n\r\n let editLabelForm = document.createElement(\"div\");\r\n editLabelForm.className = \"label-form\";\r\n let editLabelLabel = document.createElement(\"label\");\r\n editLabelLabel.innerText = \"Edit Label Text:\";\r\n editLabelLabel.htmlFor = \"editLabelInput\";\r\n editLabelForm.appendChild(editLabelLabel);\r\n let editLabelInput = document.createElement(\"input\");\r\n editLabelInput.name = \"editLabelInput\";\r\n editLabelInput.type = \"text\";\r\n editLabelInput.value = text;\r\n editLabelInput.dataset.labelnum = labelIdx.toString();\r\n editLabelInput.onkeyup = this._editLabelText.bind(this);\r\n editLabelForm.appendChild(editLabelInput);\r\n let rmvLabelBtn = document.createElement(\"button\");\r\n rmvLabelBtn.innerText = \"Remove Label\"\r\n rmvLabelBtn.onclick = this._removeLabel.bind(this);\r\n rmvLabelBtn.dataset.labelnum = labelIdx.toString();\r\n editLabelForm.appendChild(rmvLabelBtn);\r\n editLabelForm.dataset.labelnum = labelIdx.toString();\r\n this._editLabelForms.push(editLabelForm);\r\n this._editLabelContainer.appendChild(editLabelForm);\r\n\r\n this._showLabels = true;\r\n return labelIdx;\r\n }\r\n\r\n /**\r\n * Add multiple labels from a list of labels.\r\n * \r\n * @param labelList List of lists with the first three elements of the inner lists being the x, y and z coordinates, and the fourth the label text.\r\n */\r\n addLabels(labelList: [[number, number, number, string]]): void {\r\n for (let i = 0; i < labelList.length; i++) {\r\n const label = labelList[i];\r\n let text = label[3];\r\n let position = label.slice(0, 3) as number[];\r\n this.addLabel(text, position);\r\n }\r\n }\r\n\r\n private _editLabelText(ev: Event): void {\r\n let inputElem = ev.target as HTMLInputElement;\r\n this.labels[parseInt(inputElem.dataset.labelnum)].setText(inputElem.value);\r\n }\r\n\r\n private _removeLabel(ev: Event) {\r\n let btn = ev.target as HTMLButtonElement;\r\n let labelNum = parseInt(btn.dataset.labelnum);\r\n this.labels[labelNum].dispose();\r\n this.labels.splice(labelNum, 1);\r\n let thisForm: HTMLDivElement;\r\n this._editLabelForms.forEach(eLabelForm => {\r\n if (parseInt(eLabelForm.dataset.labelnum) == labelNum) {\r\n thisForm = eLabelForm;\r\n } else if (parseInt(eLabelForm.dataset.labelnum) > labelNum) {\r\n let oldNum = parseInt(eLabelForm.dataset.labelnum)\r\n let newNum = (oldNum - 1).toString()\r\n eLabelForm.dataset.labelnum = newNum;\r\n let oInput = eLabelForm.querySelector('input[data-labelnum=\"' + oldNum + '\"]') as HTMLInputElement;\r\n oInput.dataset.labelnum = newNum;\r\n let oBtn = eLabelForm.querySelector('button[data-labelnum=\"' + oldNum + '\"]') as HTMLButtonElement;\r\n oBtn.dataset.labelnum = newNum;\r\n }\r\n });\r\n thisForm.parentNode.removeChild(thisForm);\r\n }\r\n\r\n exportLabels(): any[] {\r\n let labels = [];\r\n for (let i = 0; i < this.labels.length; i++) {\r\n labels.push(this.labels[i].export());\r\n }\r\n return labels;\r\n }\r\n\r\n fixLabels() {\r\n for (let i = 0; i < this.labels.length; i++) {\r\n this.labels[i].fix();\r\n }\r\n this.fixedLabels = true;\r\n }\r\n\r\n unfixLabels() {\r\n for (let i = 0; i < this.labels.length; i++) {\r\n this.labels[i].unfix();\r\n }\r\n this.fixedLabels = false;\r\n }\r\n}\r\n\r\nfunction makeDraggable(label: Mesh) {\r\n let labelDragBehavior = new PointerDragBehavior();\r\n label.addBehavior(labelDragBehavior);\r\n}","/**\r\n * Babyplots - Easy, fast, interactive 3D visualizations\r\n *\r\n * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved.\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n * \r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n * \r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n * \r\n */\r\n\r\nimport { Scene } from \"@babylonjs/core/scene\";\r\nimport { ArcRotateCamera } from \"@babylonjs/core/Cameras/arcRotateCamera\";\r\nimport { Mesh } from \"@babylonjs/core/Meshes/mesh\";\r\nimport { LinesBuilder } from \"@babylonjs/core/Meshes/Builders/linesBuilder\";\r\nimport { LinesMesh } from \"@babylonjs/core/Meshes/linesMesh\";\r\nimport { Vector3, Axis, Color3} from \"@babylonjs/core/Maths/math\";\r\nimport { DynamicTexture } from \"@babylonjs/core/Materials/Textures/dynamicTexture\";\r\nimport { StandardMaterial } from \"@babylonjs/core/Materials/standardMaterial\";\r\nimport { AxisData } from \"./babyplots\";\r\n\r\n/**\r\n * Class to store and update plot axes.\r\n */\r\nexport class Axes {\r\n private _axes: LinesMesh[] = [];\r\n private _axisLabels: Mesh[] = [];\r\n private _ticks: LinesMesh[] = [];\r\n private _tickLabels: Mesh[] = [];\r\n private _tickLines: LinesMesh[] = [];\r\n private _scene: Scene;\r\n axisData: AxisData;\r\n /**\r\n * Create axes for plot.\r\n * @param axisData object containing all information about axis setup.\r\n * @param scene BABYLON scene.\r\n */\r\n constructor(axisData: AxisData, scene: Scene, heatmap: boolean = false) {\r\n this.axisData = axisData;\r\n this._scene = scene;\r\n this._createAxes(heatmap);\r\n }\r\n private _roundTicks(num: number, scale: number = 2): number {\r\n if (!(\"\" + num).includes(\"e\")) {\r\n return +(Math.round(parseFloat(num.toString() + \"e+\" + scale.toString())) + \"e-\" + scale);\r\n }\r\n else {\r\n var arr = (\"\" + num).split(\"e\");\r\n var sig = \"\";\r\n if (+arr[1] + scale > 0) {\r\n sig = \"+\";\r\n }\r\n return +(Math.round(parseFloat(+arr[0].toString() + \"e\" + sig.toString() + (+arr[1].toString() + scale.toString()))) + \"e-\" + scale);\r\n }\r\n }\r\n private _createAxes(heatmap: boolean = false): void {\r\n if (heatmap) {\r\n // Tick breaks for heat map on x and z coordinates have to match columns and rows\r\n this.axisData.tickBreaks[0] = 1;\r\n this.axisData.tickBreaks[2] = 1;\r\n }\r\n // Apply scaling factor to tick break interval to get distance between ticks\r\n let xtickBreaks = this.axisData.tickBreaks[0] * this.axisData.scale[0];\r\n let ytickBreaks = this.axisData.tickBreaks[1] * this.axisData.scale[1];\r\n let ztickBreaks = this.axisData.tickBreaks[2] * this.axisData.scale[2];\r\n // Find minima and maxima of the axes as a multiple of the tick interval distance\r\n let xmin = Math.floor(this.axisData.range[0][0] / xtickBreaks) * xtickBreaks;\r\n let ymin = Math.floor(this.axisData.range[1][0] / ytickBreaks) * ytickBreaks;\r\n let zmin = Math.floor(this.axisData.range[2][0] / ztickBreaks) * ztickBreaks;\r\n let xmax = Math.ceil(this.axisData.range[0][1] / xtickBreaks) * xtickBreaks;\r\n let ymax = Math.ceil(this.axisData.range[1][1] / ytickBreaks) * ytickBreaks;\r\n let zmax = Math.ceil(this.axisData.range[2][1] / ztickBreaks) * ztickBreaks;\r\n // Create X axis\r\n if (this.axisData.showAxes[0]) {\r\n // Create axis line\r\n let axisX = LinesBuilder.CreateLines(\"axisX\", {\r\n points: [\r\n new Vector3(xmin, ymin, zmin),\r\n new Vector3(xmax, ymin, zmin)\r\n ]\r\n }, this._scene);\r\n // Apply axis color\r\n axisX.color = Color3.FromHexString(this.axisData.color[0]);\r\n this._axes.push(axisX);\r\n // Create axis label\r\n let xChar = this._makeTextPlane(this.axisData.axisLabels[0], 1, this.axisData.color[0]);\r\n // Place label near end of the axis\r\n xChar.position = new Vector3(xmax / 2, ymin - 0.5 * ymax, zmin);\r\n this._axisLabels.push(xChar);\r\n // Create ticks and tick lines\r\n let xTicks = [];\r\n // Find x coordinates for ticks\r\n // Negative ticks\r\n for (let i = 0; i < -Math.ceil(this.axisData.range[0][0] / xtickBreaks); i++) {\r\n xTicks.push(-(i + 1) * xtickBreaks);\r\n }\r\n // Positive ticks\r\n for (let i = 0; i <= Math.ceil(this.axisData.range[0][1] / xtickBreaks); i++) {\r\n xTicks.push(i * xtickBreaks);\r\n }\r\n // Usually ticks start with 0, heat map starts with 1\r\n let startTick = 0;\r\n if (heatmap) {\r\n startTick = 1;\r\n }\r\n // Create all ticks\r\n for (let i = startTick; i < xTicks.length; i++) {\r\n let tickPos = xTicks[i];\r\n if (heatmap) {\r\n tickPos = tickPos - 0.5 * this.axisData.scale[0];\r\n }\r\n let tick = LinesBuilder.CreateLines(\"xTicks\", {\r\n points: [\r\n new Vector3(tickPos, ymin, zmin + 0.05 * xmax),\r\n new Vector3(tickPos, ymin, zmin),\r\n new Vector3(tickPos, ymin + 0.05 * ymax, zmin)\r\n ]\r\n }, this._scene);\r\n tick.color = Color3.FromHexString(this.axisData.color[0]);\r\n this._ticks.push(tick);\r\n let tickLabel = this._roundTicks(tickPos / this.axisData.scale[0]).toString();\r\n if (heatmap) {\r\n tickLabel = this.axisData.colnames[i - 1];\r\n }\r\n if (tickLabel === undefined) {\r\n continue;\r\n }\r\n let tickChar = this._makeTextPlane(tickLabel, 0.6, this.axisData.color[0]);\r\n tickChar.position = new Vector3(tickPos, ymin - 0.1 * ymax, zmin);\r\n this._tickLabels.push(tickChar);\r\n if (this.axisData.showTickLines[0][0]) {\r\n let tickLine = LinesBuilder.CreateLines(\"xTickLines\", {\r\n points: [\r\n new Vector3(tickPos, ymax, zmin),\r\n new Vector3(tickPos, ymin, zmin)\r\n ]\r\n }, this._scene);\r\n tickLine.color = Color3.FromHexString(this.axisData.tickLineColor[0][0]);\r\n this._tickLines.push(tickLine);\r\n }\r\n if (this.axisData.showTickLines[0][1]) {\r\n let tickLine = LinesBuilder.CreateLines(\"xTickLines\", {\r\n points: [\r\n new Vector3(tickPos, ymin, zmax),\r\n new Vector3(tickPos, ymin, zmin)\r\n ]\r\n }, this._scene);\r\n tickLine.color = Color3.FromHexString(this.axisData.tickLineColor[0][1]);\r\n this._tickLines.push(tickLine);\r\n }\r\n }\r\n }\r\n // create Y axis\r\n if (this.axisData.showAxes[1]) {\r\n // axis\r\n let axisY = LinesBuilder.CreateLines(\"axisY\", {\r\n points: [\r\n new Vector3(xmin, ymin, zmin),\r\n new Vector3(xmin, ymax, zmin)\r\n ]\r\n }, this._scene);\r\n axisY.color = Color3.FromHexString(this.axisData.color[1]);\r\n this._axes.push(axisY);\r\n // label\r\n let yChar = this._makeTextPlane(this.axisData.axisLabels[1], 1, this.axisData.color[1]);\r\n yChar.position = new Vector3(xmin, ymax / 2, zmin - 0.5 * ymax);\r\n this._axisLabels.push(yChar);\r\n // y ticks and tick lines\r\n let yTicks = [];\r\n for (let i = 0; i < -Math.ceil(this.axisData.range[1][0] / ytickBreaks); i++) {\r\n yTicks.push(-(i + 1) * ytickBreaks);\r\n }\r\n for (let i = 0; i <= Math.ceil(this.axisData.range[1][1] / ytickBreaks); i++) {\r\n yTicks.push(i * ytickBreaks);\r\n }\r\n for (let i = 0; i < yTicks.length; i++) {\r\n let tickPos = yTicks[i];\r\n let tick = LinesBuilder.CreateLines(\"yTicks\", {\r\n points: [\r\n new Vector3(xmin, tickPos, zmin + 0.05 * zmax),\r\n new Vector3(xmin, tickPos, zmin),\r\n new Vector3(xmin + 0.05 * xmax, tickPos, zmin)\r\n ]\r\n }, this._scene);\r\n tick.color = Color3.FromHexString(this.axisData.color[1]);\r\n this._ticks.push(tick);\r\n let tickLabel = this._roundTicks(tickPos / this.axisData.scale[1]);\r\n let tickChar = this._makeTextPlane(tickLabel.toString(), 0.6, this.axisData.color[1]);\r\n tickChar.position = new Vector3(xmin, tickPos, zmin - 0.05 * ymax);\r\n this._tickLabels.push(tickChar);\r\n // tick lines\r\n if (this.axisData.showTickLines[1][0]) {\r\n let tickLine = LinesBuilder.CreateLines(\"yTicksLines\", {\r\n points: [\r\n new Vector3(xmax, tickPos, zmin),\r\n new Vector3(xmin, tickPos, zmin)\r\n ]\r\n }, this._scene);\r\n tickLine.color = Color3.FromHexString(this.axisData.tickLineColor[1][0]);\r\n this._tickLines.push(tickLine);\r\n }\r\n if (this.axisData.showTickLines[1][1]) {\r\n let tickLine = LinesBuilder.CreateLines(\"yTickLines\", {\r\n points: [\r\n new Vector3(xmin, tickPos, zmax),\r\n new Vector3(xmin, tickPos, zmin)\r\n ]\r\n }, this._scene);\r\n tickLine.color = Color3.FromHexString(this.axisData.tickLineColor[1][1]);\r\n this._tickLines.push(tickLine);\r\n }\r\n }\r\n }\r\n // create Z axis\r\n if (this.axisData.showAxes[2]) {\r\n // axis\r\n let axisZ = LinesBuilder.CreateLines(\"axisZ\", {\r\n points: [\r\n new Vector3(xmin, ymin, zmin),\r\n new Vector3(xmin, ymin, zmax)\r\n ]\r\n }, this._scene);\r\n axisZ.color = Color3.FromHexString(this.axisData.color[2]);\r\n this._axes.push(axisZ);\r\n // label\r\n let zChar = this._makeTextPlane(this.axisData.axisLabels[2], 1, this.axisData.color[2]);\r\n zChar.position = new Vector3(xmin, ymin - 0.5 * ymax, zmax / 2);\r\n this._axisLabels.push(zChar);\r\n // z ticks and tick lines\r\n let zTicks = [];\r\n for (let i = 0; i < -Math.ceil(this.axisData.range[2][0] / ztickBreaks); i++) {\r\n zTicks.push(-(i + 1) * ztickBreaks);\r\n }\r\n for (let i = 0; i <= Math.ceil(this.axisData.range[2][1] / ztickBreaks); i++) {\r\n zTicks.push(i * ztickBreaks);\r\n }\r\n let startTick = 0;\r\n if (heatmap) {\r\n startTick = 1;\r\n }\r\n for (let i = startTick; i < zTicks.length; i++) {\r\n let tickPos = zTicks[i];\r\n if (heatmap) {\r\n tickPos = tickPos - 0.5 * this.axisData.scale[2];\r\n }\r\n let tick = LinesBuilder.CreateLines(\"zTicks\", {\r\n points: [\r\n new Vector3(xmin + 0.05 * xmax, ymin, tickPos),\r\n new Vector3(xmin, ymin, tickPos),\r\n new Vector3(xmin, ymin + 0.05 * ymax, tickPos)\r\n ]\r\n }, this._scene);\r\n tick.color = Color3.FromHexString(this.axisData.color[2]);\r\n this._ticks.push(tick);\r\n let tickLabel = this._roundTicks(tickPos / this.axisData.scale[2]).toString();\r\n if (heatmap) {\r\n tickLabel = this.axisData.rownames[i - 1];\r\n }\r\n if (tickLabel === undefined) {\r\n continue;\r\n }\r\n let tickChar = this._makeTextPlane(tickLabel, 0.6, this.axisData.color[2]);\r\n tickChar.position = new Vector3(xmin, ymin - 0.1 * ymax, tickPos);\r\n this._tickLabels.push(tickChar);\r\n // tick lines\r\n if (this.axisData.showTickLines[2][0]) {\r\n let tickLine = LinesBuilder.CreateLines(\"zTickLines\", {\r\n points: [\r\n new Vector3(xmax, ymin, tickPos),\r\n new Vector3(xmin, ymin, tickPos)\r\n ]\r\n }, this._scene);\r\n tickLine.color = Color3.FromHexString(this.axisData.tickLineColor[2][0]);\r\n this._tickLines.push(tickLine);\r\n }\r\n if (this.axisData.showTickLines[2][1]) {\r\n let tickLine = LinesBuilder.CreateLines(\"zTickLines\", {\r\n points: [\r\n new Vector3(xmin, ymax, tickPos),\r\n new Vector3(xmin, ymin, tickPos)\r\n ]\r\n }, this._scene);\r\n tickLine.color = Color3.FromHexString(this.axisData.tickLineColor[2][1]);\r\n this._tickLines.push(tickLine);\r\n }\r\n }\r\n }\r\n }\r\n private _makeTextPlane(text: string, size: number, color: string): Mesh {\r\n var dynamicTexture = new DynamicTexture(\"DynamicTexture\", 75, this._scene, true);\r\n dynamicTexture.hasAlpha = true;\r\n dynamicTexture.drawText(text, 5, 40, (40 - text.length * 4) + \"px Arial\", color, \"transparent\", true);\r\n var plane = Mesh.CreatePlane(\"TextPlane\", size, this._scene, true);\r\n var material = new StandardMaterial(\"TextPlaneMaterial\", this._scene);\r\n material.backFaceCulling = false;\r\n material.specularColor = new Color3(0, 0, 0);\r\n material.diffuseTexture = dynamicTexture;\r\n plane.material = material;\r\n return plane;\r\n }\r\n update(camera: ArcRotateCamera, updateAxisData?: boolean): void {\r\n if (updateAxisData) {\r\n for (let i = 0; i < this._axes.length; i++) {\r\n this._axes[i].dispose();\r\n }\r\n for (let i = 0; i < this._axisLabels.length; i++) {\r\n this._axisLabels[i].dispose();\r\n }\r\n for (let i = 0; i < this._ticks.length; i++) {\r\n this._ticks[i].dispose();\r\n }\r\n for (let i = 0; i < this._tickLabels.length; i++) {\r\n this._tickLabels[i].dispose();\r\n }\r\n for (let i = 0; i < this._tickLines.length; i++) {\r\n this._tickLines[i].dispose();\r\n }\r\n this._createAxes();\r\n }\r\n if (this.axisData.showAxes) {\r\n let axis1 = Vector3.Cross(camera.position, Axis.Y);\r\n let axis2 = Vector3.Cross(axis1, camera.position);\r\n let axis3 = Vector3.Cross(axis1, axis2);\r\n for (let i = 0; i < this._axisLabels.length; i++) {\r\n this._axisLabels[i].rotation = Vector3.RotationFromAxis(axis1, axis2, axis3);\r\n }\r\n for (let i = 0; i < this._tickLabels.length; i++) {\r\n this._tickLabels[i].rotation = Vector3.RotationFromAxis(axis1, axis2, axis3);\r\n }\r\n }\r\n }\r\n}\r\n","/**\r\n * Babyplots - Easy, fast, interactive 3D visualizations\r\n *\r\n * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved.\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n * \r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n * \r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n * \r\n */\r\n\r\nimport { Scene } from \"@babylonjs/core/scene\";\r\nimport { Mesh } from \"@babylonjs/core/Meshes/mesh\";\r\nimport { Color3 } from \"@babylonjs/core/Maths/math\";\r\nimport { VertexData } from \"@babylonjs/core/Meshes/mesh.vertexData\";\r\nimport { StandardMaterial } from \"@babylonjs/core/Materials/standardMaterial\";\r\nimport { Plot, LegendData } from \"./babyplots\";\r\nimport chroma from \"chroma-js\";\r\n\r\n\r\n\r\nexport class ImgStack extends Plot {\r\n private _backgroundColor: string;\r\n private _intensityMode: string;\r\n private _channelCoords: number[][][];\r\n private _channelCoordIntensities: number[][];\r\n constructor(\r\n scene: Scene,\r\n values: number[],\r\n indices: number[],\r\n attributes: { dim: number[] },\r\n legendData: LegendData,\r\n size: number,\r\n backgroundColor: string,\r\n intensityMode: string,\r\n xScale: number = 1,\r\n yScale: number = 1,\r\n zScale: number = 1\r\n ) {\r\n let colSize = attributes.dim[0];\r\n let rowSize = attributes.dim[1];\r\n let channels = attributes.dim[2];\r\n let slices = attributes.dim[3];\r\n let channelSize = colSize * rowSize;\r\n let sliceSize = channelSize * channels;\r\n let coords = [];\r\n let Intensities = [];\r\n for (let i = 0; i < channels; i++) {\r\n coords.push([]);\r\n Intensities.push([]);\r\n }\r\n for (let i = 0; i < indices.length; i++) {\r\n const index = indices[i];\r\n let slice = Math.floor(index / sliceSize);\r\n let sliceIndex = index - sliceSize * slice;\r\n let channel = Math.floor(sliceIndex / channelSize);\r\n let channelIndex = sliceIndex - channelSize * channel;\r\n let row = Math.floor(channelIndex / colSize);\r\n let col = channelIndex % colSize;\r\n coords[channel].push([\r\n col * xScale,\r\n row * yScale,\r\n slice * zScale\r\n ]);\r\n Intensities[channel].push(values[i]);\r\n }\r\n super(scene, [], [], size, legendData, xScale, yScale, zScale);\r\n this._channelCoords = coords;\r\n this._channelCoordIntensities = Intensities;\r\n this._backgroundColor = backgroundColor;\r\n this._intensityMode = intensityMode;\r\n this.meshes = [];\r\n this._createImgStack();\r\n }\r\n\r\n private _createImgStack(): void {\r\n let positions = [];\r\n let colors = [];\r\n for (let c = 0; c < this._channelCoords.length; c++) {\r\n const channelIntensities = this._channelCoordIntensities[c];\r\n if (channelIntensities.length === 0) {\r\n continue;\r\n }\r\n const channelCoords = this._channelCoords[c];\r\n let channelColor: string;\r\n if (c == 0) {\r\n channelColor = \"#ff0000\";\r\n } else if (c == 1) {\r\n channelColor = \"#00ff00\";\r\n } else {\r\n channelColor = \"#0000ff\";\r\n }\r\n let channelColorRGB = chroma(channelColor).rgb();\r\n channelColorRGB[0] = channelColorRGB[0] / 255;\r\n channelColorRGB[1] = channelColorRGB[1] / 255;\r\n channelColorRGB[2] = channelColorRGB[2] / 255;\r\n if (this._intensityMode === \"alpha\") {\r\n let alphaLevels = 10;\r\n let minIntensity = channelIntensities.min();\r\n let alphaPositions: number[][] = [];\r\n let alphaColors: number[][] = [];\r\n let alphaIntensities: number[] = [];\r\n for (let i = 0; i < alphaLevels; i++) {\r\n alphaPositions.push([]);\r\n alphaColors.push([]);\r\n alphaIntensities.push((i + 1) * (1 / alphaLevels));\r\n }\r\n\r\n for (let p = 0; p < channelCoords.length; p++) {\r\n for (let intens = 0; intens < alphaIntensities.length; intens++) {\r\n const testIntensity = alphaIntensities[intens];\r\n if ((channelIntensities[p] - minIntensity) / (1 - minIntensity) <= testIntensity) {\r\n alphaPositions[intens].push(\r\n channelCoords[p][2],\r\n channelCoords[p][0],\r\n channelCoords[p][1]\r\n );\r\n alphaColors[intens].push(\r\n channelColorRGB[0],\r\n channelColorRGB[1],\r\n channelColorRGB[2],\r\n 1\r\n );\r\n break;\r\n }\r\n }\r\n }\r\n\r\n for (let intensIdx = 0; intensIdx < alphaIntensities.length; intensIdx++) {\r\n if (alphaColors[intensIdx].length <= 4) {\r\n continue;\r\n }\r\n let customMesh = new Mesh(`custom-${c}_${intensIdx}`, this._scene);\r\n const intensity = alphaIntensities[intensIdx];\r\n let vertexData = new VertexData();\r\n vertexData.positions = alphaPositions[intensIdx];\r\n vertexData.colors = alphaColors[intensIdx];\r\n vertexData.applyToMesh(customMesh, true);\r\n let mat = new StandardMaterial(`mat-${c}_${intensIdx}`, this._scene);\r\n mat.emissiveColor = new Color3(1, 1, 1);\r\n mat.disableLighting = true;\r\n mat.pointsCloud = true;\r\n mat.pointSize = this._size;\r\n mat.alpha = intensity;\r\n customMesh.material = mat;\r\n this.meshes.push(customMesh);\r\n }\r\n\r\n } else {\r\n for (let p = 0; p < channelCoords.length; p++) {\r\n positions.push(channelCoords[p][2], channelCoords[p][0], channelCoords[p][1]);\r\n if (this._intensityMode === \"mix\") {\r\n let colormix = chroma.mix(this._backgroundColor, channelColor, channelIntensities[p]).rgb();\r\n colors.push(colormix[0] / 255, colormix[1] / 255, colormix[2] / 255, 1);\r\n } else {\r\n colors.push(channelColorRGB[0], channelColorRGB[1], channelColorRGB[2], 1);\r\n }\r\n }\r\n let customMesh = new Mesh(`custom-${c}`, this._scene);\r\n let vertexData = new VertexData();\r\n vertexData.positions = positions;\r\n vertexData.colors = colors;\r\n vertexData.applyToMesh(customMesh, true);\r\n let mat = new StandardMaterial(`mat-${c}`, this._scene);\r\n mat.emissiveColor = new Color3(1, 1, 1);\r\n mat.disableLighting = true;\r\n mat.pointsCloud = true;\r\n mat.pointSize = this._size;\r\n customMesh.material = mat;\r\n this.meshes.push(customMesh);\r\n }\r\n }\r\n }\r\n}","/**\r\n * Babyplots - Easy, fast, interactive 3D visualizations\r\n *\r\n * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved.\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n * \r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n * \r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n * \r\n */\r\n\r\nimport { Scene } from \"@babylonjs/core/scene\";\r\nimport { Mesh } from \"@babylonjs/core/Meshes/mesh\";\r\nimport \"@babylonjs/core/Meshes/thinInstanceMesh\";\r\nimport { SphereBuilder } from \"@babylonjs/core/Meshes/Builders/sphereBuilder\";\r\nimport { BoxBuilder } from \"@babylonjs/core/Meshes/Builders/boxBuilder\";\r\nimport { TorusBuilder } from \"@babylonjs/core/Meshes/Builders/torusBuilder\";\r\nimport { CylinderBuilder } from \"@babylonjs/core/Meshes/Builders/cylinderBuilder\";\r\nimport { Color3, Color4, Matrix } from \"@babylonjs/core/Maths/math\";\r\nimport { StandardMaterial } from \"@babylonjs/core/Materials/standardMaterial\";\r\nimport { Plot, LegendData } from \"./babyplots\";\r\n\r\nexport class ShapeCloud extends Plot {\r\n private _shape: string;\r\n private _shading: boolean;\r\n constructor(\r\n scene: Scene,\r\n coordinates: number[][],\r\n colorVar: string[],\r\n shape: string,\r\n shading: boolean,\r\n size: number,\r\n legendData: LegendData,\r\n xScale: number = 1,\r\n yScale: number = 1,\r\n zScale: number = 1\r\n ) {\r\n super(scene, coordinates, colorVar, size * 0.1, legendData, xScale, yScale, zScale);\r\n this._shape = shape;\r\n this._shading = shading;\r\n this._createShapeCloud();\r\n }\r\n /**\r\n * Creates shapes at coordinates\r\n */\r\n private _createShapeCloud(): void {\r\n let instanceCount = this._coords.length;\r\n\r\n let matricesData = new Float32Array(16 * instanceCount);\r\n let colorData = new Float32Array(4 * instanceCount);\r\n\r\n // set position and color data for shapes\r\n for (let i = 0; i < instanceCount; i++) {\r\n let matrix = Matrix.Translation(\r\n this._coords[i][0] * this.xScale,\r\n this._coords[i][1] * this.zScale,\r\n this._coords[i][2] * this.yScale\r\n );\r\n\r\n matrix.copyToArray(matricesData, i * 16);\r\n\r\n let col = Color4.FromHexString(this._coordColors[i]);\r\n\r\n colorData.set(col.asArray(), i * 4);\r\n }\r\n\r\n let origMesh: Mesh;\r\n\r\n switch (this._shape) {\r\n case \"box\":\r\n origMesh = BoxBuilder.CreateBox(\"root\", { size: this._size });\r\n break;\r\n case \"sphere\":\r\n origMesh = SphereBuilder.CreateSphere(\"root\", { diameter: this._size });\r\n break;\r\n case \"cone\":\r\n origMesh = CylinderBuilder.CreateCylinder(\"root\", { height: this._size, diameterBottom: this._size, diameterTop: 0 }, this._scene);\r\n break;\r\n case \"torus\":\r\n origMesh = TorusBuilder.CreateTorus(\"root\", { diameter: this._size, thickness: this._size * 0.5 }, this._scene);\r\n break;\r\n case \"cylinder\":\r\n origMesh = CylinderBuilder.CreateCylinder(\"root\", { height: this._size, diameter: this._size }, this._scene);\r\n break;\r\n default:\r\n origMesh = BoxBuilder.CreateBox(\"root\", { size: 1 });\r\n break;\r\n }\r\n \r\n origMesh.thinInstanceSetBuffer(\"matrix\", matricesData, 16, true);\r\n origMesh.thinInstanceSetBuffer(\"color\", colorData, 4, true);\r\n\r\n let mat = new StandardMaterial(\"shapeMat\", this._scene);\r\n if (!this._shading) {\r\n mat.disableLighting = true;\r\n mat.emissiveColor = Color3.White();\r\n }\r\n origMesh.material = mat;\r\n \r\n this.mesh = origMesh;\r\n Object.defineProperty(this, \"alpha\", {\r\n set(newAlpha) {\r\n this.mesh.material.alpha = newAlpha;\r\n }\r\n });\r\n }\r\n}\r\n","import { Mesh } from \"../Meshes/mesh\";\r\nimport { VertexBuffer, Buffer } from './buffer';\r\nimport { Matrix, Vector3, TmpVectors } from '../Maths/math.vector';\r\nMesh.prototype.thinInstanceAdd = function (matrix, refresh) {\r\n if (refresh === void 0) { refresh = true; }\r\n this._thinInstanceUpdateBufferSize(\"matrix\", Array.isArray(matrix) ? matrix.length : 1);\r\n var index = this._thinInstanceDataStorage.instancesCount;\r\n if (Array.isArray(matrix)) {\r\n for (var i = 0; i < matrix.length; ++i) {\r\n this.thinInstanceSetMatrixAt(this._thinInstanceDataStorage.instancesCount++, matrix[i], (i === matrix.length - 1) && refresh);\r\n }\r\n }\r\n else {\r\n this.thinInstanceSetMatrixAt(this._thinInstanceDataStorage.instancesCount++, matrix, refresh);\r\n }\r\n return index;\r\n};\r\nMesh.prototype.thinInstanceAddSelf = function (refresh) {\r\n if (refresh === void 0) { refresh = true; }\r\n return this.thinInstanceAdd(Matrix.IdentityReadOnly, refresh);\r\n};\r\nMesh.prototype.thinInstanceRegisterAttribute = function (kind, stride) {\r\n this.removeVerticesData(kind);\r\n this._thinInstanceInitializeUserStorage();\r\n this._userThinInstanceBuffersStorage.strides[kind] = stride;\r\n this._userThinInstanceBuffersStorage.sizes[kind] = stride * Math.max(32, this._thinInstanceDataStorage.instancesCount); // Initial size\r\n this._userThinInstanceBuffersStorage.data[kind] = new Float32Array(this._userThinInstanceBuffersStorage.sizes[kind]);\r\n this._userThinInstanceBuffersStorage.vertexBuffers[kind] = new VertexBuffer(this.getEngine(), this._userThinInstanceBuffersStorage.data[kind], kind, true, false, stride, true);\r\n this.setVerticesBuffer(this._userThinInstanceBuffersStorage.vertexBuffers[kind]);\r\n};\r\nMesh.prototype.thinInstanceSetMatrixAt = function (index, matrix, refresh) {\r\n if (refresh === void 0) { refresh = true; }\r\n if (!this._thinInstanceDataStorage.matrixData || index >= this._thinInstanceDataStorage.instancesCount) {\r\n return false;\r\n }\r\n var matrixData = this._thinInstanceDataStorage.matrixData;\r\n matrix.copyToArray(matrixData, index * 16);\r\n if (this._thinInstanceDataStorage.worldMatrices) {\r\n this._thinInstanceDataStorage.worldMatrices[index] = matrix;\r\n }\r\n if (refresh) {\r\n this.thinInstanceBufferUpdated(\"matrix\");\r\n if (!this.doNotSyncBoundingInfo) {\r\n this.thinInstanceRefreshBoundingInfo(false);\r\n }\r\n }\r\n return true;\r\n};\r\nMesh.prototype.thinInstanceSetAttributeAt = function (kind, index, value, refresh) {\r\n if (refresh === void 0) { refresh = true; }\r\n if (!this._userThinInstanceBuffersStorage || !this._userThinInstanceBuffersStorage.data[kind] || index >= this._thinInstanceDataStorage.instancesCount) {\r\n return false;\r\n }\r\n this._thinInstanceUpdateBufferSize(kind, 0); // make sur the buffer for the kind attribute is big enough\r\n this._userThinInstanceBuffersStorage.data[kind].set(value, index * this._userThinInstanceBuffersStorage.strides[kind]);\r\n if (refresh) {\r\n this.thinInstanceBufferUpdated(kind);\r\n }\r\n return true;\r\n};\r\nObject.defineProperty(Mesh.prototype, \"thinInstanceCount\", {\r\n get: function () {\r\n return this._thinInstanceDataStorage.instancesCount;\r\n },\r\n set: function (value) {\r\n var _a, _b;\r\n var numMaxInstances = ((_b = (_a = this._thinInstanceDataStorage.matrixData) === null || _a === void 0 ? void 0 : _a.length) !== null && _b !== void 0 ? _b : 0) / 16;\r\n if (value <= numMaxInstances) {\r\n this._thinInstanceDataStorage.instancesCount = value;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n});\r\nMesh.prototype.thinInstanceSetBuffer = function (kind, buffer, stride, staticBuffer) {\r\n var _a, _b;\r\n if (stride === void 0) { stride = 0; }\r\n if (staticBuffer === void 0) { staticBuffer = false; }\r\n stride = stride || 16;\r\n if (kind === \"matrix\") {\r\n (_a = this._thinInstanceDataStorage.matrixBuffer) === null || _a === void 0 ? void 0 : _a.dispose();\r\n this._thinInstanceDataStorage.matrixBuffer = null;\r\n this._thinInstanceDataStorage.matrixBufferSize = buffer ? buffer.length : 32 * stride;\r\n this._thinInstanceDataStorage.matrixData = buffer;\r\n this._thinInstanceDataStorage.worldMatrices = null;\r\n if (buffer !== null) {\r\n this._thinInstanceDataStorage.instancesCount = buffer.length / stride;\r\n var matrixBuffer = new Buffer(this.getEngine(), buffer, !staticBuffer, stride, false, true);\r\n this._thinInstanceDataStorage.matrixBuffer = matrixBuffer;\r\n this.setVerticesBuffer(matrixBuffer.createVertexBuffer(\"world0\", 0, 4));\r\n this.setVerticesBuffer(matrixBuffer.createVertexBuffer(\"world1\", 4, 4));\r\n this.setVerticesBuffer(matrixBuffer.createVertexBuffer(\"world2\", 8, 4));\r\n this.setVerticesBuffer(matrixBuffer.createVertexBuffer(\"world3\", 12, 4));\r\n if (!this.doNotSyncBoundingInfo) {\r\n this.thinInstanceRefreshBoundingInfo(false);\r\n }\r\n }\r\n else {\r\n this._thinInstanceDataStorage.instancesCount = 0;\r\n if (!this.doNotSyncBoundingInfo) {\r\n // mesh has no more thin instances, so need to recompute the bounding box because it's the regular mesh that will now be displayed\r\n this.refreshBoundingInfo(true);\r\n }\r\n }\r\n }\r\n else {\r\n if (buffer === null) {\r\n if ((_b = this._userThinInstanceBuffersStorage) === null || _b === void 0 ? void 0 : _b.data[kind]) {\r\n this.removeVerticesData(kind);\r\n delete this._userThinInstanceBuffersStorage.data[kind];\r\n delete this._userThinInstanceBuffersStorage.strides[kind];\r\n delete this._userThinInstanceBuffersStorage.sizes[kind];\r\n delete this._userThinInstanceBuffersStorage.vertexBuffers[kind];\r\n }\r\n }\r\n else {\r\n this._thinInstanceInitializeUserStorage();\r\n this._userThinInstanceBuffersStorage.data[kind] = buffer;\r\n this._userThinInstanceBuffersStorage.strides[kind] = stride;\r\n this._userThinInstanceBuffersStorage.sizes[kind] = buffer.length;\r\n this._userThinInstanceBuffersStorage.vertexBuffers[kind] = new VertexBuffer(this.getEngine(), buffer, kind, !staticBuffer, false, stride, true);\r\n this.setVerticesBuffer(this._userThinInstanceBuffersStorage.vertexBuffers[kind]);\r\n }\r\n }\r\n};\r\nMesh.prototype.thinInstanceBufferUpdated = function (kind) {\r\n var _a;\r\n if (kind === \"matrix\") {\r\n if (this._thinInstanceDataStorage.matrixBuffer) {\r\n this._thinInstanceDataStorage.matrixBuffer.updateDirectly(this._thinInstanceDataStorage.matrixData, 0, this._thinInstanceDataStorage.instancesCount);\r\n }\r\n }\r\n else if ((_a = this._userThinInstanceBuffersStorage) === null || _a === void 0 ? void 0 : _a.vertexBuffers[kind]) {\r\n this._userThinInstanceBuffersStorage.vertexBuffers[kind].updateDirectly(this._userThinInstanceBuffersStorage.data[kind], 0);\r\n }\r\n};\r\nMesh.prototype.thinInstancePartialBufferUpdate = function (kind, data, offset) {\r\n var _a;\r\n if (kind === \"matrix\") {\r\n if (this._thinInstanceDataStorage.matrixBuffer) {\r\n this._thinInstanceDataStorage.matrixBuffer.updateDirectly(data, offset);\r\n }\r\n }\r\n else if ((_a = this._userThinInstanceBuffersStorage) === null || _a === void 0 ? void 0 : _a.vertexBuffers[kind]) {\r\n this._userThinInstanceBuffersStorage.vertexBuffers[kind].updateDirectly(data, offset);\r\n }\r\n};\r\nMesh.prototype.thinInstanceGetWorldMatrices = function () {\r\n if (!this._thinInstanceDataStorage.matrixData || !this._thinInstanceDataStorage.matrixBuffer) {\r\n return [];\r\n }\r\n var matrixData = this._thinInstanceDataStorage.matrixData;\r\n if (!this._thinInstanceDataStorage.worldMatrices) {\r\n this._thinInstanceDataStorage.worldMatrices = new Array();\r\n for (var i = 0; i < this._thinInstanceDataStorage.instancesCount; ++i) {\r\n this._thinInstanceDataStorage.worldMatrices[i] = Matrix.FromArray(matrixData, i * 16);\r\n }\r\n }\r\n return this._thinInstanceDataStorage.worldMatrices;\r\n};\r\nMesh.prototype.thinInstanceRefreshBoundingInfo = function (forceRefreshParentInfo) {\r\n if (forceRefreshParentInfo === void 0) { forceRefreshParentInfo = false; }\r\n if (!this._thinInstanceDataStorage.matrixData || !this._thinInstanceDataStorage.matrixBuffer) {\r\n return;\r\n }\r\n var vectors = this._thinInstanceDataStorage.boundingVectors;\r\n if (forceRefreshParentInfo) {\r\n vectors.length = 0;\r\n this.refreshBoundingInfo(true);\r\n }\r\n var boundingInfo = this.getBoundingInfo();\r\n var matrixData = this._thinInstanceDataStorage.matrixData;\r\n if (vectors.length === 0) {\r\n for (var v = 0; v < boundingInfo.boundingBox.vectors.length; ++v) {\r\n vectors.push(boundingInfo.boundingBox.vectors[v].clone());\r\n }\r\n }\r\n TmpVectors.Vector3[0].setAll(Number.POSITIVE_INFINITY); // min\r\n TmpVectors.Vector3[1].setAll(Number.NEGATIVE_INFINITY); // max\r\n for (var i = 0; i < this._thinInstanceDataStorage.instancesCount; ++i) {\r\n Matrix.FromArrayToRef(matrixData, i * 16, TmpVectors.Matrix[0]);\r\n for (var v = 0; v < vectors.length; ++v) {\r\n Vector3.TransformCoordinatesToRef(vectors[v], TmpVectors.Matrix[0], TmpVectors.Vector3[2]);\r\n TmpVectors.Vector3[0].minimizeInPlace(TmpVectors.Vector3[2]);\r\n TmpVectors.Vector3[1].maximizeInPlace(TmpVectors.Vector3[2]);\r\n }\r\n }\r\n boundingInfo.reConstruct(TmpVectors.Vector3[0], TmpVectors.Vector3[1]);\r\n this._updateBoundingInfo();\r\n};\r\nMesh.prototype._thinInstanceUpdateBufferSize = function (kind, numInstances) {\r\n var _a, _b;\r\n if (numInstances === void 0) { numInstances = 1; }\r\n var kindIsMatrix = kind === \"matrix\";\r\n if (!kindIsMatrix && (!this._userThinInstanceBuffersStorage || !this._userThinInstanceBuffersStorage.strides[kind])) {\r\n return;\r\n }\r\n var stride = kindIsMatrix ? 16 : this._userThinInstanceBuffersStorage.strides[kind];\r\n var currentSize = kindIsMatrix ? this._thinInstanceDataStorage.matrixBufferSize : this._userThinInstanceBuffersStorage.sizes[kind];\r\n var data = kindIsMatrix ? this._thinInstanceDataStorage.matrixData : this._userThinInstanceBuffersStorage.data[kind];\r\n var bufferSize = (this._thinInstanceDataStorage.instancesCount + numInstances) * stride;\r\n var newSize = currentSize;\r\n while (newSize < bufferSize) {\r\n newSize *= 2;\r\n }\r\n if (!data || currentSize != newSize) {\r\n if (!data) {\r\n data = new Float32Array(newSize);\r\n }\r\n else {\r\n var newData = new Float32Array(newSize);\r\n newData.set(data, 0);\r\n data = newData;\r\n }\r\n if (kindIsMatrix) {\r\n (_a = this._thinInstanceDataStorage.matrixBuffer) === null || _a === void 0 ? void 0 : _a.dispose();\r\n var matrixBuffer = new Buffer(this.getEngine(), data, true, stride, false, true);\r\n this._thinInstanceDataStorage.matrixBuffer = matrixBuffer;\r\n this._thinInstanceDataStorage.matrixData = data;\r\n this._thinInstanceDataStorage.matrixBufferSize = newSize;\r\n this.setVerticesBuffer(matrixBuffer.createVertexBuffer(\"world0\", 0, 4));\r\n this.setVerticesBuffer(matrixBuffer.createVertexBuffer(\"world1\", 4, 4));\r\n this.setVerticesBuffer(matrixBuffer.createVertexBuffer(\"world2\", 8, 4));\r\n this.setVerticesBuffer(matrixBuffer.createVertexBuffer(\"world3\", 12, 4));\r\n }\r\n else {\r\n (_b = this._userThinInstanceBuffersStorage.vertexBuffers[kind]) === null || _b === void 0 ? void 0 : _b.dispose();\r\n this._userThinInstanceBuffersStorage.data[kind] = data;\r\n this._userThinInstanceBuffersStorage.sizes[kind] = newSize;\r\n this._userThinInstanceBuffersStorage.vertexBuffers[kind] = new VertexBuffer(this.getEngine(), data, kind, true, false, stride, true);\r\n this.setVerticesBuffer(this._userThinInstanceBuffersStorage.vertexBuffers[kind]);\r\n }\r\n }\r\n};\r\nMesh.prototype._thinInstanceInitializeUserStorage = function () {\r\n if (!this._userThinInstanceBuffersStorage) {\r\n this._userThinInstanceBuffersStorage = {\r\n data: {},\r\n sizes: {},\r\n vertexBuffers: {},\r\n strides: {},\r\n };\r\n }\r\n};\r\nMesh.prototype._disposeThinInstanceSpecificData = function () {\r\n var _a;\r\n if ((_a = this._thinInstanceDataStorage) === null || _a === void 0 ? void 0 : _a.matrixBuffer) {\r\n this._thinInstanceDataStorage.matrixBuffer.dispose();\r\n this._thinInstanceDataStorage.matrixBuffer = null;\r\n }\r\n};\r\n//# sourceMappingURL=thinInstanceMesh.js.map","import { Vector3, Matrix } from \"../../Maths/math.vector\";\r\nimport { Mesh } from \"../mesh\";\r\nimport { VertexData } from \"../mesh.vertexData\";\r\nVertexData.CreateSphere = function (options) {\r\n var segments = options.segments || 32;\r\n var diameterX = options.diameterX || options.diameter || 1;\r\n var diameterY = options.diameterY || options.diameter || 1;\r\n var diameterZ = options.diameterZ || options.diameter || 1;\r\n var arc = options.arc && (options.arc <= 0 || options.arc > 1) ? 1.0 : options.arc || 1.0;\r\n var slice = options.slice && (options.slice <= 0) ? 1.0 : options.slice || 1.0;\r\n var sideOrientation = (options.sideOrientation === 0) ? 0 : options.sideOrientation || VertexData.DEFAULTSIDE;\r\n var dedupTopBottomIndices = !!options.dedupTopBottomIndices;\r\n var radius = new Vector3(diameterX / 2, diameterY / 2, diameterZ / 2);\r\n var totalZRotationSteps = 2 + segments;\r\n var totalYRotationSteps = 2 * totalZRotationSteps;\r\n var indices = [];\r\n var positions = [];\r\n var normals = [];\r\n var uvs = [];\r\n for (var zRotationStep = 0; zRotationStep <= totalZRotationSteps; zRotationStep++) {\r\n var normalizedZ = zRotationStep / totalZRotationSteps;\r\n var angleZ = normalizedZ * Math.PI * slice;\r\n for (var yRotationStep = 0; yRotationStep <= totalYRotationSteps; yRotationStep++) {\r\n var normalizedY = yRotationStep / totalYRotationSteps;\r\n var angleY = normalizedY * Math.PI * 2 * arc;\r\n var rotationZ = Matrix.RotationZ(-angleZ);\r\n var rotationY = Matrix.RotationY(angleY);\r\n var afterRotZ = Vector3.TransformCoordinates(Vector3.Up(), rotationZ);\r\n var complete = Vector3.TransformCoordinates(afterRotZ, rotationY);\r\n var vertex = complete.multiply(radius);\r\n var normal = complete.divide(radius).normalize();\r\n positions.push(vertex.x, vertex.y, vertex.z);\r\n normals.push(normal.x, normal.y, normal.z);\r\n uvs.push(normalizedY, normalizedZ);\r\n }\r\n if (zRotationStep > 0) {\r\n var verticesCount = positions.length / 3;\r\n for (var firstIndex = verticesCount - 2 * (totalYRotationSteps + 1); (firstIndex + totalYRotationSteps + 2) < verticesCount; firstIndex++) {\r\n if (dedupTopBottomIndices) {\r\n if (zRotationStep > 1) {\r\n indices.push((firstIndex));\r\n indices.push((firstIndex + 1));\r\n indices.push(firstIndex + totalYRotationSteps + 1);\r\n }\r\n if (zRotationStep < totalZRotationSteps || slice < 1.0) {\r\n indices.push((firstIndex + totalYRotationSteps + 1));\r\n indices.push((firstIndex + 1));\r\n indices.push((firstIndex + totalYRotationSteps + 2));\r\n }\r\n }\r\n else {\r\n indices.push(firstIndex);\r\n indices.push(firstIndex + 1);\r\n indices.push(firstIndex + totalYRotationSteps + 1);\r\n indices.push(firstIndex + totalYRotationSteps + 1);\r\n indices.push(firstIndex + 1);\r\n indices.push(firstIndex + totalYRotationSteps + 2);\r\n }\r\n }\r\n }\r\n }\r\n // Sides\r\n VertexData._ComputeSides(sideOrientation, positions, indices, normals, uvs, options.frontUVs, options.backUVs);\r\n // Result\r\n var vertexData = new VertexData();\r\n vertexData.indices = indices;\r\n vertexData.positions = positions;\r\n vertexData.normals = normals;\r\n vertexData.uvs = uvs;\r\n return vertexData;\r\n};\r\nMesh.CreateSphere = function (name, segments, diameter, scene, updatable, sideOrientation) {\r\n var options = {\r\n segments: segments,\r\n diameterX: diameter,\r\n diameterY: diameter,\r\n diameterZ: diameter,\r\n sideOrientation: sideOrientation,\r\n updatable: updatable\r\n };\r\n return SphereBuilder.CreateSphere(name, options, scene);\r\n};\r\n/**\r\n * Class containing static functions to help procedurally build meshes\r\n */\r\nvar SphereBuilder = /** @class */ (function () {\r\n function SphereBuilder() {\r\n }\r\n /**\r\n * Creates a sphere mesh\r\n * * The parameter `diameter` sets the diameter size (float) of the sphere (default 1)\r\n * * You can set some different sphere dimensions, for instance to build an ellipsoid, by using the parameters `diameterX`, `diameterY` and `diameterZ` (all by default have the same value of `diameter`)\r\n * * The parameter `segments` sets the sphere number of horizontal stripes (positive integer, default 32)\r\n * * You can create an unclosed sphere with the parameter `arc` (positive float, default 1), valued between 0 and 1, what is the ratio of the circumference (latitude) : 2 x PI x ratio\r\n * * You can create an unclosed sphere on its height with the parameter `slice` (positive float, default1), valued between 0 and 1, what is the height ratio (longitude)\r\n * * You can also set the mesh side orientation with the values : BABYLON.Mesh.FRONTSIDE (default), BABYLON.Mesh.BACKSIDE or BABYLON.Mesh.DOUBLESIDE\r\n * * If you create a double-sided mesh, you can choose what parts of the texture image to crop and stick respectively on the front and the back sides with the parameters `frontUVs` and `backUVs` (Vector4). Detail here : https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created\r\n * @param name defines the name of the mesh\r\n * @param options defines the options used to create the mesh\r\n * @param scene defines the hosting scene\r\n * @returns the sphere mesh\r\n * @see https://doc.babylonjs.com/how_to/set_shapes#sphere\r\n */\r\n SphereBuilder.CreateSphere = function (name, options, scene) {\r\n if (scene === void 0) { scene = null; }\r\n var sphere = new Mesh(name, scene);\r\n options.sideOrientation = Mesh._GetDefaultSideOrientation(options.sideOrientation);\r\n sphere._originalBuilderSideOrientation = options.sideOrientation;\r\n var vertexData = VertexData.CreateSphere(options);\r\n vertexData.applyToMesh(sphere, options.updatable);\r\n return sphere;\r\n };\r\n return SphereBuilder;\r\n}());\r\nexport { SphereBuilder };\r\n//# sourceMappingURL=sphereBuilder.js.map","import { Matrix, Vector3, Vector2 } from \"../../Maths/math.vector\";\r\nimport { Mesh } from \"../mesh\";\r\nimport { VertexData } from \"../mesh.vertexData\";\r\nVertexData.CreateTorus = function (options) {\r\n var indices = [];\r\n var positions = [];\r\n var normals = [];\r\n var uvs = [];\r\n var diameter = options.diameter || 1;\r\n var thickness = options.thickness || 0.5;\r\n var tessellation = options.tessellation || 16;\r\n var sideOrientation = (options.sideOrientation === 0) ? 0 : options.sideOrientation || VertexData.DEFAULTSIDE;\r\n var stride = tessellation + 1;\r\n for (var i = 0; i <= tessellation; i++) {\r\n var u = i / tessellation;\r\n var outerAngle = i * Math.PI * 2.0 / tessellation - Math.PI / 2.0;\r\n var transform = Matrix.Translation(diameter / 2.0, 0, 0).multiply(Matrix.RotationY(outerAngle));\r\n for (var j = 0; j <= tessellation; j++) {\r\n var v = 1 - j / tessellation;\r\n var innerAngle = j * Math.PI * 2.0 / tessellation + Math.PI;\r\n var dx = Math.cos(innerAngle);\r\n var dy = Math.sin(innerAngle);\r\n // Create a vertex.\r\n var normal = new Vector3(dx, dy, 0);\r\n var position = normal.scale(thickness / 2);\r\n var textureCoordinate = new Vector2(u, v);\r\n position = Vector3.TransformCoordinates(position, transform);\r\n normal = Vector3.TransformNormal(normal, transform);\r\n positions.push(position.x, position.y, position.z);\r\n normals.push(normal.x, normal.y, normal.z);\r\n uvs.push(textureCoordinate.x, textureCoordinate.y);\r\n // And create indices for two triangles.\r\n var nextI = (i + 1) % stride;\r\n var nextJ = (j + 1) % stride;\r\n indices.push(i * stride + j);\r\n indices.push(i * stride + nextJ);\r\n indices.push(nextI * stride + j);\r\n indices.push(i * stride + nextJ);\r\n indices.push(nextI * stride + nextJ);\r\n indices.push(nextI * stride + j);\r\n }\r\n }\r\n // Sides\r\n VertexData._ComputeSides(sideOrientation, positions, indices, normals, uvs, options.frontUVs, options.backUVs);\r\n // Result\r\n var vertexData = new VertexData();\r\n vertexData.indices = indices;\r\n vertexData.positions = positions;\r\n vertexData.normals = normals;\r\n vertexData.uvs = uvs;\r\n return vertexData;\r\n};\r\nMesh.CreateTorus = function (name, diameter, thickness, tessellation, scene, updatable, sideOrientation) {\r\n var options = {\r\n diameter: diameter,\r\n thickness: thickness,\r\n tessellation: tessellation,\r\n sideOrientation: sideOrientation,\r\n updatable: updatable\r\n };\r\n return TorusBuilder.CreateTorus(name, options, scene);\r\n};\r\n/**\r\n * Class containing static functions to help procedurally build meshes\r\n */\r\nvar TorusBuilder = /** @class */ (function () {\r\n function TorusBuilder() {\r\n }\r\n /**\r\n * Creates a torus mesh\r\n * * The parameter `diameter` sets the diameter size (float) of the torus (default 1)\r\n * * The parameter `thickness` sets the diameter size of the tube of the torus (float, default 0.5)\r\n * * The parameter `tessellation` sets the number of torus sides (postive integer, default 16)\r\n * * You can also set the mesh side orientation with the values : BABYLON.Mesh.FRONTSIDE (default), BABYLON.Mesh.BACKSIDE or BABYLON.Mesh.DOUBLESIDE\r\n * * If you create a double-sided mesh, you can choose what parts of the texture image to crop and stick respectively on the front and the back sides with the parameters `frontUVs` and `backUVs` (Vector4). Detail here : https://doc.babylonjs.com/babylon101/discover_basic_elements#side-orientation\r\n * * The mesh can be set to updatable with the boolean parameter `updatable` (default false) if its internal geometry is supposed to change once created.\r\n * @param name defines the name of the mesh\r\n * @param options defines the options used to create the mesh\r\n * @param scene defines the hosting scene\r\n * @returns the torus mesh\r\n * @see https://doc.babylonjs.com/how_to/set_shapes#torus\r\n */\r\n TorusBuilder.CreateTorus = function (name, options, scene) {\r\n var torus = new Mesh(name, scene);\r\n options.sideOrientation = Mesh._GetDefaultSideOrientation(options.sideOrientation);\r\n torus._originalBuilderSideOrientation = options.sideOrientation;\r\n var vertexData = VertexData.CreateTorus(options);\r\n vertexData.applyToMesh(torus, options.updatable);\r\n return torus;\r\n };\r\n return TorusBuilder;\r\n}());\r\nexport { TorusBuilder };\r\n//# sourceMappingURL=torusBuilder.js.map","/**\r\n * Babyplots - Easy, fast, interactive 3D visualizations\r\n *\r\n * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved.\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n * \r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n * \r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n * \r\n */\r\n\r\nimport { Scene } from \"@babylonjs/core/scene\";\r\nimport { Mesh } from \"@babylonjs/core/Meshes/mesh\";\r\nimport { Vector3, Color4, Color3 } from \"@babylonjs/core/Maths/math\";\r\nimport { VertexData } from \"@babylonjs/core/Meshes/mesh.vertexData\";\r\nimport { StandardMaterial } from \"@babylonjs/core/Materials/standardMaterial\";\r\nimport { FloatArray } from \"@babylonjs/core/types\";\r\nimport { PickingInfo } from \"@babylonjs/core/Collisions/pickingInfo\";\r\nimport { Plot, LegendData } from \"./babyplots\";\r\n\r\nexport class PointCloud extends Plot {\r\n private _pointPicking: boolean = false;\r\n private _selectionCallback = function (selection: number[]) { return false; };\r\n private _folded: boolean;\r\n private _foldedEmbedding: number[][];\r\n private _foldVectors: Vector3[] = [];\r\n private _foldCounter: number = 0;\r\n private _foldAnimFrames: number = 200;\r\n private _foldVectorFract: Vector3[] = [];\r\n private _foldDelay: number = 100;\r\n constructor(\r\n scene: Scene,\r\n coordinates: number[][],\r\n colorVar: string[],\r\n size: number,\r\n legendData: LegendData,\r\n folded?: boolean,\r\n foldedEmbedding?: number[][],\r\n foldAnimDelay?: number,\r\n foldAnimDuration?: number,\r\n xScale: number = 1,\r\n yScale: number = 1,\r\n zScale: number = 1\r\n ) {\r\n super(scene, coordinates, colorVar, size, legendData, xScale, yScale, zScale);\r\n this._folded = folded;\r\n if (foldAnimDelay) {\r\n this._foldDelay = foldAnimDelay;\r\n }\r\n if (foldAnimDuration) {\r\n this._foldAnimFrames = foldAnimDuration;\r\n }\r\n if (folded) {\r\n if (foldedEmbedding) {\r\n for (let i = 0; i < foldedEmbedding.length; i++) {\r\n if (foldedEmbedding[i].length == 2) {\r\n foldedEmbedding[i].push(0);\r\n }\r\n let fv = new Vector3(\r\n coordinates[i][0] * this.xScale,\r\n coordinates[i][2] * this.zScale,\r\n coordinates[i][1] * this.yScale\r\n ).subtractFromFloats(\r\n foldedEmbedding[i][0] * this.xScale,\r\n 0,\r\n foldedEmbedding[i][1] * this.yScale,\r\n );\r\n this._foldVectors.push(fv);\r\n this._foldVectorFract.push(fv.divide(new Vector3(this._foldAnimFrames, this._foldAnimFrames, this._foldAnimFrames)));\r\n }\r\n this._foldedEmbedding = foldedEmbedding;\r\n } else {\r\n foldedEmbedding = JSON.parse(JSON.stringify(coordinates));\r\n for (let i = 0; i < foldedEmbedding.length; i++) {\r\n foldedEmbedding[i][2] = 0;\r\n let fv = new Vector3(\r\n coordinates[i][0] * this.xScale,\r\n coordinates[i][2] * this.zScale,\r\n coordinates[i][1] * this.yScale\r\n ).subtractFromFloats(\r\n foldedEmbedding[i][0] * this.xScale,\r\n 0,\r\n foldedEmbedding[i][1] * this.yScale\r\n );\r\n this._foldVectors.push(fv);\r\n this._foldVectorFract.push(fv.divide(new Vector3(this._foldAnimFrames, this._foldAnimFrames, this._foldAnimFrames)));\r\n }\r\n this._foldedEmbedding = foldedEmbedding;\r\n }\r\n }\r\n this._createPointCloud();\r\n }\r\n /**\r\n * Positions spheres according to coordinates in a SPS\r\n */\r\n private _createPointCloud(): void {\r\n // prototype cell\r\n let customMesh = new Mesh(\"custom\", this._scene);\r\n // Set arrays for positions and indices\r\n let positions = [];\r\n let colors = [];\r\n if (this._folded) {\r\n for (let p = 0; p < this._coords.length; p++) {\r\n positions.push(\r\n this._foldedEmbedding[p][0] * this.xScale,\r\n this._foldedEmbedding[p][2] * this.zScale,\r\n this._foldedEmbedding[p][1] * this.yScale\r\n );\r\n let col = Color4.FromHexString(this._coordColors[p]);\r\n colors.push(col.r, col.g, col.b, col.a);\r\n }\r\n } else {\r\n for (let p = 0; p < this._coords.length; p++) {\r\n positions.push(\r\n this._coords[p][0] * this.xScale,\r\n this._coords[p][2] * this.zScale,\r\n this._coords[p][1] * this.yScale\r\n );\r\n let col = Color4.FromHexString(this._coordColors[p]);\r\n colors.push(col.r, col.g, col.b, col.a);\r\n }\r\n }\r\n var vertexData = new VertexData();\r\n // Assign positions\r\n vertexData.positions = positions;\r\n vertexData.colors = colors;\r\n // Apply vertexData to custom mesh\r\n vertexData.applyToMesh(customMesh, true);\r\n var mat = new StandardMaterial(\"mat\", this._scene);\r\n mat.emissiveColor = new Color3(1, 1, 1);\r\n mat.disableLighting = true;\r\n mat.pointsCloud = true;\r\n mat.pointSize = this._size;\r\n customMesh.material = mat;\r\n this.mesh = customMesh;\r\n Object.defineProperty(this, \"alpha\", {\r\n set(newAlpha) {\r\n this.mesh.material.alpha = newAlpha;\r\n }\r\n });\r\n }\r\n\r\n resetAnimation(): void {\r\n this._folded = true;\r\n let positionFunction = function (positions: FloatArray) {\r\n let numberOfVertices = positions.length / 3;\r\n for (let i = 0; i < numberOfVertices; i++) {\r\n positions[i * 3] = this._foldedEmbedding[i][0] * this.xScale;\r\n positions[i * 3 + 1] = this._foldedEmbedding[i][2] * this.zScale;\r\n positions[i * 3 + 2] = this._foldedEmbedding[i][1] * this.yScale;\r\n }\r\n }\r\n this.mesh.updateMeshPositions(positionFunction.bind(this), true);\r\n this.mesh.refreshBoundingInfo();\r\n this._foldCounter = 0;\r\n }\r\n\r\n update(): boolean {\r\n if (this.mesh && this._folded) {\r\n if (this._foldCounter < this._foldDelay) {\r\n this._foldCounter += 1;\r\n } else if (this._foldCounter < this._foldAnimFrames + this._foldDelay) {\r\n let positionFunction = function (positions: FloatArray) {\r\n let numberOfVertices = positions.length / 3;\r\n for (let i = 0; i < numberOfVertices; i++) {\r\n let posVector = new Vector3(\r\n positions[i * 3],\r\n positions[i * 3 + 1],\r\n positions[i * 3 + 2]\r\n ).addInPlace(this._foldVectorFract[i]);\r\n positions[i * 3] = posVector.x;\r\n positions[i * 3 + 1] = posVector.y;\r\n positions[i * 3 + 2] = posVector.z;\r\n }\r\n }\r\n this.mesh.updateMeshPositions(positionFunction.bind(this), true);\r\n this._foldCounter += 1;\r\n } else {\r\n this._folded = false;\r\n let positionFunction = function (positions: FloatArray) {\r\n let numberOfVertices = positions.length / 3;\r\n for (let i = 0; i < numberOfVertices; i++) {\r\n positions[i * 3] = this._coords[i][0] * this.xScale;\r\n positions[i * 3 + 1] = this._coords[i][2] * this.zScale;\r\n positions[i * 3 + 2] = this._coords[i][1] * this.yScale;\r\n }\r\n }\r\n this.mesh.updateMeshPositions(positionFunction.bind(this), true);\r\n this.mesh.refreshBoundingInfo();\r\n }\r\n }\r\n return this._folded;\r\n }\r\n}\r\n","/**\r\n * Babyplots - Easy, fast, interactive 3D visualizations\r\n *\r\n * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved.\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n * \r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n * \r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n * \r\n */\r\n\r\nimport { Scene } from \"@babylonjs/core/scene\";\r\nimport { Mesh } from \"@babylonjs/core/Meshes/mesh\";\r\nimport { VertexData } from \"@babylonjs/core/Meshes/mesh.vertexData\";\r\nimport { StandardMaterial } from \"@babylonjs/core/Materials/standardMaterial\";\r\nimport { Plot, LegendData, matrixMax } from \"./babyplots\";\r\nimport chroma from \"chroma-js\";\r\n\r\n\r\nexport class Surface extends Plot {\r\n constructor(\r\n scene: Scene,\r\n coordinates: number[][],\r\n colorVar: string[],\r\n size: number,\r\n legendData: LegendData,\r\n xScale: number = 1,\r\n yScale: number = 1,\r\n zScale: number = 1\r\n ) {\r\n super(scene, coordinates, colorVar, size, legendData, xScale, yScale, zScale);\r\n this._createSurface();\r\n }\r\n private _createSurface(): void {\r\n var surface = new Mesh(\"surface\", this._scene);\r\n var positions = [];\r\n var indices = [];\r\n for (let row = 0; row < this._coords.length; row++) {\r\n const rowCoords = this._coords[row];\r\n for (let column = 0; column < rowCoords.length; column++) {\r\n const coord = rowCoords[column];\r\n positions.push(\r\n column * this.xScale,\r\n coord * this.yScale,\r\n row * this.zScale\r\n );\r\n if (row < this._coords.length - 1 && column < rowCoords.length - 1) {\r\n indices.push(\r\n column + row * rowCoords.length,\r\n rowCoords.length + row * rowCoords.length + column,\r\n column + row * rowCoords.length + 1,\r\n column + row * rowCoords.length + 1,\r\n rowCoords.length + row * rowCoords.length + column,\r\n rowCoords.length + row * rowCoords.length + column + 1\r\n );\r\n }\r\n }\r\n }\r\n var colors = [];\r\n for (let i = 0; i < this._coordColors.length; i++) {\r\n const hex = this._coordColors[i];\r\n let rgba = chroma(hex).rgba();\r\n colors.push(rgba[0] / 255, rgba[1] / 255, rgba[2] / 255, rgba[3]);\r\n }\r\n var normals = [];\r\n var vertexData = new VertexData();\r\n VertexData.ComputeNormals(positions, indices, normals);\r\n vertexData.positions = positions;\r\n vertexData.indices = indices;\r\n vertexData.colors = colors;\r\n vertexData.normals = normals;\r\n vertexData.applyToMesh(surface);\r\n var mat = new StandardMaterial(\"surfaceMat\", this._scene);\r\n mat.backFaceCulling = false;\r\n mat.alpha = 1;\r\n surface.material = mat;\r\n this.mesh = surface;\r\n Object.defineProperty(this, \"alpha\", {\r\n set(newAlpha) {\r\n this.mesh.material.alpha = newAlpha;\r\n }\r\n });\r\n }\r\n}\r\n","/**\r\n * Babyplots - Easy, fast, interactive 3D visualizations\r\n *\r\n * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved.\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n * \r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n * \r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n * \r\n */\r\n\r\nimport { Scene } from \"@babylonjs/core/scene\";\r\nimport { Mesh } from \"@babylonjs/core/Meshes/mesh\";\r\nimport { Color3, Vector3 } from \"@babylonjs/core/Maths/math\";\r\nimport { BoxBuilder } from \"@babylonjs/core/Meshes/Builders/boxBuilder\";\r\nimport { PlaneBuilder } from \"@babylonjs/core/Meshes/Builders/planeBuilder\";\r\nimport { StandardMaterial } from \"@babylonjs/core/Materials/standardMaterial\";\r\nimport { Plot, LegendData, matrixMax } from \"./babyplots\";\r\n\r\nexport class HeatMap extends Plot {\r\n constructor(\r\n scene: Scene,\r\n coordinates: number[][],\r\n colorVar: string[],\r\n size: number,\r\n legendData: LegendData,\r\n xScale: number = 1,\r\n yScale: number = 1,\r\n zScale: number = 1\r\n ) {\r\n super(scene, coordinates, colorVar, size, legendData, xScale, yScale, zScale);\r\n this._createHeatMap();\r\n }\r\n private _createHeatMap(): void {\r\n let boxes = [];\r\n for (let row = 0; row < this._coords.length; row++) {\r\n const rowCoords = this._coords[row];\r\n for (let column = 0; column < rowCoords.length; column++) {\r\n const coord = rowCoords[column];\r\n if (coord > 0) {\r\n let height = coord * this.yScale;\r\n let box = BoxBuilder.CreateBox(\"box_\" + row + \"-\" + column, {\r\n height: height,\r\n width: this.xScale * this._size,\r\n depth: this.zScale * this._size\r\n }, this._scene);\r\n box.position = new Vector3(\r\n row * this.xScale + 0.5 * this.xScale,\r\n height / 2,\r\n column * this.zScale + 0.5 * this.zScale\r\n );\r\n let mat = new StandardMaterial(\"box_\" + row + \"-\" + column + \"_color\", this._scene);\r\n mat.alpha = 1;\r\n mat.diffuseColor = Color3.FromHexString(\r\n this._coordColors[column + row * rowCoords.length].substring(0, 7)\r\n );\r\n box.material = mat;\r\n boxes.push(box);\r\n }\r\n else {\r\n let box = PlaneBuilder.CreatePlane(\r\n \"box_\" + row + \"-\" + column,\r\n {\r\n width: this.xScale * this._size,\r\n height: this.zScale * this._size\r\n }, this._scene);\r\n box.position = new Vector3(\r\n row * this.xScale + 0.5 * this.xScale,\r\n 0,\r\n column * this.zScale + 0.5 * this.zScale\r\n );\r\n box.rotation.x = Math.PI / 2;\r\n let mat = new StandardMaterial(\"box_\" + row + \"-\" + column + \"_color\", this._scene);\r\n mat.alpha = 1;\r\n mat.diffuseColor = Color3.FromHexString(\r\n this._coordColors[column + row * rowCoords.length].substring(0, 7)\r\n );\r\n mat.backFaceCulling = false;\r\n box.material = mat;\r\n boxes.push(box);\r\n }\r\n }\r\n }\r\n this.meshes = boxes;\r\n Object.defineProperty(this, \"alpha\", {\r\n set(newAlpha) {\r\n for (let i = 0; i < this.meshes.length; i++) {\r\n const box = this.meshes[i] as Mesh;\r\n box.material.alpha = newAlpha;\r\n }\r\n }\r\n });\r\n }\r\n}\r\n","/**\r\n * Enum for the animation key frame interpolation type\r\n */\r\nexport var AnimationKeyInterpolation;\r\n(function (AnimationKeyInterpolation) {\r\n /**\r\n * Do not interpolate between keys and use the start key value only. Tangents are ignored\r\n */\r\n AnimationKeyInterpolation[AnimationKeyInterpolation[\"STEP\"] = 1] = \"STEP\";\r\n})(AnimationKeyInterpolation || (AnimationKeyInterpolation = {}));\r\n//# sourceMappingURL=animationKey.js.map","import { PointerEventTypes } from \"../../Events/pointerEvents\";\r\nimport { PrecisionDate } from \"../../Misc/precisionDate\";\r\n/**\r\n * The autoRotation behavior (AutoRotationBehavior) is designed to create a smooth rotation of an ArcRotateCamera when there is no user interaction.\r\n * @see https://doc.babylonjs.com/how_to/camera_behaviors#autorotation-behavior\r\n */\r\nvar AutoRotationBehavior = /** @class */ (function () {\r\n function AutoRotationBehavior() {\r\n this._zoomStopsAnimation = false;\r\n this._idleRotationSpeed = 0.05;\r\n this._idleRotationWaitTime = 2000;\r\n this._idleRotationSpinupTime = 2000;\r\n this._isPointerDown = false;\r\n this._lastFrameTime = null;\r\n this._lastInteractionTime = -Infinity;\r\n this._cameraRotationSpeed = 0;\r\n this._lastFrameRadius = 0;\r\n }\r\n Object.defineProperty(AutoRotationBehavior.prototype, \"name\", {\r\n /**\r\n * Gets the name of the behavior.\r\n */\r\n get: function () {\r\n return \"AutoRotation\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AutoRotationBehavior.prototype, \"zoomStopsAnimation\", {\r\n /**\r\n * Gets the flag that indicates if user zooming should stop animation.\r\n */\r\n get: function () {\r\n return this._zoomStopsAnimation;\r\n },\r\n /**\r\n * Sets the flag that indicates if user zooming should stop animation.\r\n */\r\n set: function (flag) {\r\n this._zoomStopsAnimation = flag;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AutoRotationBehavior.prototype, \"idleRotationSpeed\", {\r\n /**\r\n * Gets the default speed at which the camera rotates around the model.\r\n */\r\n get: function () {\r\n return this._idleRotationSpeed;\r\n },\r\n /**\r\n * Sets the default speed at which the camera rotates around the model.\r\n */\r\n set: function (speed) {\r\n this._idleRotationSpeed = speed;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AutoRotationBehavior.prototype, \"idleRotationWaitTime\", {\r\n /**\r\n * Gets the time (milliseconds) to wait after user interaction before the camera starts rotating.\r\n */\r\n get: function () {\r\n return this._idleRotationWaitTime;\r\n },\r\n /**\r\n * Sets the time (in milliseconds) to wait after user interaction before the camera starts rotating.\r\n */\r\n set: function (time) {\r\n this._idleRotationWaitTime = time;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AutoRotationBehavior.prototype, \"idleRotationSpinupTime\", {\r\n /**\r\n * Gets the time (milliseconds) to take to spin up to the full idle rotation speed.\r\n */\r\n get: function () {\r\n return this._idleRotationSpinupTime;\r\n },\r\n /**\r\n * Sets the time (milliseconds) to take to spin up to the full idle rotation speed.\r\n */\r\n set: function (time) {\r\n this._idleRotationSpinupTime = time;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(AutoRotationBehavior.prototype, \"rotationInProgress\", {\r\n /**\r\n * Gets a value indicating if the camera is currently rotating because of this behavior\r\n */\r\n get: function () {\r\n return Math.abs(this._cameraRotationSpeed) > 0;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Initializes the behavior.\r\n */\r\n AutoRotationBehavior.prototype.init = function () {\r\n // Do notihng\r\n };\r\n /**\r\n * Attaches the behavior to its arc rotate camera.\r\n * @param camera Defines the camera to attach the behavior to\r\n */\r\n AutoRotationBehavior.prototype.attach = function (camera) {\r\n var _this = this;\r\n this._attachedCamera = camera;\r\n var scene = this._attachedCamera.getScene();\r\n this._onPrePointerObservableObserver = scene.onPrePointerObservable.add(function (pointerInfoPre) {\r\n if (pointerInfoPre.type === PointerEventTypes.POINTERDOWN) {\r\n _this._isPointerDown = true;\r\n return;\r\n }\r\n if (pointerInfoPre.type === PointerEventTypes.POINTERUP) {\r\n _this._isPointerDown = false;\r\n }\r\n });\r\n this._onAfterCheckInputsObserver = camera.onAfterCheckInputsObservable.add(function () {\r\n var now = PrecisionDate.Now;\r\n var dt = 0;\r\n if (_this._lastFrameTime != null) {\r\n dt = now - _this._lastFrameTime;\r\n }\r\n _this._lastFrameTime = now;\r\n // Stop the animation if there is user interaction and the animation should stop for this interaction\r\n _this._applyUserInteraction();\r\n var timeToRotation = now - _this._lastInteractionTime - _this._idleRotationWaitTime;\r\n var scale = Math.max(Math.min(timeToRotation / (_this._idleRotationSpinupTime), 1), 0);\r\n _this._cameraRotationSpeed = _this._idleRotationSpeed * scale;\r\n // Step camera rotation by rotation speed\r\n if (_this._attachedCamera) {\r\n _this._attachedCamera.alpha -= _this._cameraRotationSpeed * (dt / 1000);\r\n }\r\n });\r\n };\r\n /**\r\n * Detaches the behavior from its current arc rotate camera.\r\n */\r\n AutoRotationBehavior.prototype.detach = function () {\r\n if (!this._attachedCamera) {\r\n return;\r\n }\r\n var scene = this._attachedCamera.getScene();\r\n if (this._onPrePointerObservableObserver) {\r\n scene.onPrePointerObservable.remove(this._onPrePointerObservableObserver);\r\n }\r\n this._attachedCamera.onAfterCheckInputsObservable.remove(this._onAfterCheckInputsObserver);\r\n this._attachedCamera = null;\r\n };\r\n /**\r\n * Returns true if user is scrolling.\r\n * @return true if user is scrolling.\r\n */\r\n AutoRotationBehavior.prototype._userIsZooming = function () {\r\n if (!this._attachedCamera) {\r\n return false;\r\n }\r\n return this._attachedCamera.inertialRadiusOffset !== 0;\r\n };\r\n AutoRotationBehavior.prototype._shouldAnimationStopForInteraction = function () {\r\n if (!this._attachedCamera) {\r\n return false;\r\n }\r\n var zoomHasHitLimit = false;\r\n if (this._lastFrameRadius === this._attachedCamera.radius && this._attachedCamera.inertialRadiusOffset !== 0) {\r\n zoomHasHitLimit = true;\r\n }\r\n // Update the record of previous radius - works as an approx. indicator of hitting radius limits\r\n this._lastFrameRadius = this._attachedCamera.radius;\r\n return this._zoomStopsAnimation ? zoomHasHitLimit : this._userIsZooming();\r\n };\r\n /**\r\n * Applies any current user interaction to the camera. Takes into account maximum alpha rotation.\r\n */\r\n AutoRotationBehavior.prototype._applyUserInteraction = function () {\r\n if (this._userIsMoving() && !this._shouldAnimationStopForInteraction()) {\r\n this._lastInteractionTime = PrecisionDate.Now;\r\n }\r\n };\r\n // Tools\r\n AutoRotationBehavior.prototype._userIsMoving = function () {\r\n if (!this._attachedCamera) {\r\n return false;\r\n }\r\n return this._attachedCamera.inertialAlphaOffset !== 0 ||\r\n this._attachedCamera.inertialBetaOffset !== 0 ||\r\n this._attachedCamera.inertialRadiusOffset !== 0 ||\r\n this._attachedCamera.inertialPanningX !== 0 ||\r\n this._attachedCamera.inertialPanningY !== 0 ||\r\n this._isPointerDown;\r\n };\r\n return AutoRotationBehavior;\r\n}());\r\nexport { AutoRotationBehavior };\r\n//# sourceMappingURL=autoRotationBehavior.js.map","import { __extends } from \"tslib\";\r\nimport { BezierCurve } from \"../Maths/math.path\";\r\n/**\r\n * Base class used for every default easing function.\r\n * @see https://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar EasingFunction = /** @class */ (function () {\r\n function EasingFunction() {\r\n this._easingMode = EasingFunction.EASINGMODE_EASEIN;\r\n }\r\n /**\r\n * Sets the easing mode of the current function.\r\n * @param easingMode Defines the willing mode (EASINGMODE_EASEIN, EASINGMODE_EASEOUT or EASINGMODE_EASEINOUT)\r\n */\r\n EasingFunction.prototype.setEasingMode = function (easingMode) {\r\n var n = Math.min(Math.max(easingMode, 0), 2);\r\n this._easingMode = n;\r\n };\r\n /**\r\n * Gets the current easing mode.\r\n * @returns the easing mode\r\n */\r\n EasingFunction.prototype.getEasingMode = function () {\r\n return this._easingMode;\r\n };\r\n /**\r\n * @hidden\r\n */\r\n EasingFunction.prototype.easeInCore = function (gradient) {\r\n throw new Error('You must implement this method');\r\n };\r\n /**\r\n * Given an input gradient between 0 and 1, this returns the corresponding value\r\n * of the easing function.\r\n * @param gradient Defines the value between 0 and 1 we want the easing value for\r\n * @returns the corresponding value on the curve defined by the easing function\r\n */\r\n EasingFunction.prototype.ease = function (gradient) {\r\n switch (this._easingMode) {\r\n case EasingFunction.EASINGMODE_EASEIN:\r\n return this.easeInCore(gradient);\r\n case EasingFunction.EASINGMODE_EASEOUT:\r\n return (1 - this.easeInCore(1 - gradient));\r\n }\r\n if (gradient >= 0.5) {\r\n return (((1 - this.easeInCore((1 - gradient) * 2)) * 0.5) + 0.5);\r\n }\r\n return (this.easeInCore(gradient * 2) * 0.5);\r\n };\r\n /**\r\n * Interpolation follows the mathematical formula associated with the easing function.\r\n */\r\n EasingFunction.EASINGMODE_EASEIN = 0;\r\n /**\r\n * Interpolation follows 100% interpolation minus the output of the formula associated with the easing function.\r\n */\r\n EasingFunction.EASINGMODE_EASEOUT = 1;\r\n /**\r\n * Interpolation uses EaseIn for the first half of the animation and EaseOut for the second half.\r\n */\r\n EasingFunction.EASINGMODE_EASEINOUT = 2;\r\n return EasingFunction;\r\n}());\r\nexport { EasingFunction };\r\n/**\r\n * Easing function with a circle shape (see link below).\r\n * @see https://easings.net/#easeInCirc\r\n * @see https://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar CircleEase = /** @class */ (function (_super) {\r\n __extends(CircleEase, _super);\r\n function CircleEase() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n /** @hidden */\r\n CircleEase.prototype.easeInCore = function (gradient) {\r\n gradient = Math.max(0, Math.min(1, gradient));\r\n return (1.0 - Math.sqrt(1.0 - (gradient * gradient)));\r\n };\r\n return CircleEase;\r\n}(EasingFunction));\r\nexport { CircleEase };\r\n/**\r\n * Easing function with a ease back shape (see link below).\r\n * @see https://easings.net/#easeInBack\r\n * @see https://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar BackEase = /** @class */ (function (_super) {\r\n __extends(BackEase, _super);\r\n /**\r\n * Instantiates a back ease easing\r\n * @see https://easings.net/#easeInBack\r\n * @param amplitude Defines the amplitude of the function\r\n */\r\n function BackEase(\r\n /** Defines the amplitude of the function */\r\n amplitude) {\r\n if (amplitude === void 0) { amplitude = 1; }\r\n var _this = _super.call(this) || this;\r\n _this.amplitude = amplitude;\r\n return _this;\r\n }\r\n /** @hidden */\r\n BackEase.prototype.easeInCore = function (gradient) {\r\n var num = Math.max(0, this.amplitude);\r\n return (Math.pow(gradient, 3.0) - ((gradient * num) * Math.sin(3.1415926535897931 * gradient)));\r\n };\r\n return BackEase;\r\n}(EasingFunction));\r\nexport { BackEase };\r\n/**\r\n * Easing function with a bouncing shape (see link below).\r\n * @see https://easings.net/#easeInBounce\r\n * @see https://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar BounceEase = /** @class */ (function (_super) {\r\n __extends(BounceEase, _super);\r\n /**\r\n * Instantiates a bounce easing\r\n * @see https://easings.net/#easeInBounce\r\n * @param bounces Defines the number of bounces\r\n * @param bounciness Defines the amplitude of the bounce\r\n */\r\n function BounceEase(\r\n /** Defines the number of bounces */\r\n bounces, \r\n /** Defines the amplitude of the bounce */\r\n bounciness) {\r\n if (bounces === void 0) { bounces = 3; }\r\n if (bounciness === void 0) { bounciness = 2; }\r\n var _this = _super.call(this) || this;\r\n _this.bounces = bounces;\r\n _this.bounciness = bounciness;\r\n return _this;\r\n }\r\n /** @hidden */\r\n BounceEase.prototype.easeInCore = function (gradient) {\r\n var y = Math.max(0.0, this.bounces);\r\n var bounciness = this.bounciness;\r\n if (bounciness <= 1.0) {\r\n bounciness = 1.001;\r\n }\r\n var num9 = Math.pow(bounciness, y);\r\n var num5 = 1.0 - bounciness;\r\n var num4 = ((1.0 - num9) / num5) + (num9 * 0.5);\r\n var num15 = gradient * num4;\r\n var num65 = Math.log((-num15 * (1.0 - bounciness)) + 1.0) / Math.log(bounciness);\r\n var num3 = Math.floor(num65);\r\n var num13 = num3 + 1.0;\r\n var num8 = (1.0 - Math.pow(bounciness, num3)) / (num5 * num4);\r\n var num12 = (1.0 - Math.pow(bounciness, num13)) / (num5 * num4);\r\n var num7 = (num8 + num12) * 0.5;\r\n var num6 = gradient - num7;\r\n var num2 = num7 - num8;\r\n return (((-Math.pow(1.0 / bounciness, y - num3) / (num2 * num2)) * (num6 - num2)) * (num6 + num2));\r\n };\r\n return BounceEase;\r\n}(EasingFunction));\r\nexport { BounceEase };\r\n/**\r\n * Easing function with a power of 3 shape (see link below).\r\n * @see https://easings.net/#easeInCubic\r\n * @see https://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar CubicEase = /** @class */ (function (_super) {\r\n __extends(CubicEase, _super);\r\n function CubicEase() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n /** @hidden */\r\n CubicEase.prototype.easeInCore = function (gradient) {\r\n return (gradient * gradient * gradient);\r\n };\r\n return CubicEase;\r\n}(EasingFunction));\r\nexport { CubicEase };\r\n/**\r\n * Easing function with an elastic shape (see link below).\r\n * @see https://easings.net/#easeInElastic\r\n * @see https://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar ElasticEase = /** @class */ (function (_super) {\r\n __extends(ElasticEase, _super);\r\n /**\r\n * Instantiates an elastic easing function\r\n * @see https://easings.net/#easeInElastic\r\n * @param oscillations Defines the number of oscillations\r\n * @param springiness Defines the amplitude of the oscillations\r\n */\r\n function ElasticEase(\r\n /** Defines the number of oscillations*/\r\n oscillations, \r\n /** Defines the amplitude of the oscillations*/\r\n springiness) {\r\n if (oscillations === void 0) { oscillations = 3; }\r\n if (springiness === void 0) { springiness = 3; }\r\n var _this = _super.call(this) || this;\r\n _this.oscillations = oscillations;\r\n _this.springiness = springiness;\r\n return _this;\r\n }\r\n /** @hidden */\r\n ElasticEase.prototype.easeInCore = function (gradient) {\r\n var num2;\r\n var num3 = Math.max(0.0, this.oscillations);\r\n var num = Math.max(0.0, this.springiness);\r\n if (num == 0) {\r\n num2 = gradient;\r\n }\r\n else {\r\n num2 = (Math.exp(num * gradient) - 1.0) / (Math.exp(num) - 1.0);\r\n }\r\n return (num2 * Math.sin(((6.2831853071795862 * num3) + 1.5707963267948966) * gradient));\r\n };\r\n return ElasticEase;\r\n}(EasingFunction));\r\nexport { ElasticEase };\r\n/**\r\n * Easing function with an exponential shape (see link below).\r\n * @see https://easings.net/#easeInExpo\r\n * @see https://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar ExponentialEase = /** @class */ (function (_super) {\r\n __extends(ExponentialEase, _super);\r\n /**\r\n * Instantiates an exponential easing function\r\n * @see https://easings.net/#easeInExpo\r\n * @param exponent Defines the exponent of the function\r\n */\r\n function ExponentialEase(\r\n /** Defines the exponent of the function */\r\n exponent) {\r\n if (exponent === void 0) { exponent = 2; }\r\n var _this = _super.call(this) || this;\r\n _this.exponent = exponent;\r\n return _this;\r\n }\r\n /** @hidden */\r\n ExponentialEase.prototype.easeInCore = function (gradient) {\r\n if (this.exponent <= 0) {\r\n return gradient;\r\n }\r\n return ((Math.exp(this.exponent * gradient) - 1.0) / (Math.exp(this.exponent) - 1.0));\r\n };\r\n return ExponentialEase;\r\n}(EasingFunction));\r\nexport { ExponentialEase };\r\n/**\r\n * Easing function with a power shape (see link below).\r\n * @see https://easings.net/#easeInQuad\r\n * @see https://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar PowerEase = /** @class */ (function (_super) {\r\n __extends(PowerEase, _super);\r\n /**\r\n * Instantiates an power base easing function\r\n * @see https://easings.net/#easeInQuad\r\n * @param power Defines the power of the function\r\n */\r\n function PowerEase(\r\n /** Defines the power of the function */\r\n power) {\r\n if (power === void 0) { power = 2; }\r\n var _this = _super.call(this) || this;\r\n _this.power = power;\r\n return _this;\r\n }\r\n /** @hidden */\r\n PowerEase.prototype.easeInCore = function (gradient) {\r\n var y = Math.max(0.0, this.power);\r\n return Math.pow(gradient, y);\r\n };\r\n return PowerEase;\r\n}(EasingFunction));\r\nexport { PowerEase };\r\n/**\r\n * Easing function with a power of 2 shape (see link below).\r\n * @see https://easings.net/#easeInQuad\r\n * @see https://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar QuadraticEase = /** @class */ (function (_super) {\r\n __extends(QuadraticEase, _super);\r\n function QuadraticEase() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n /** @hidden */\r\n QuadraticEase.prototype.easeInCore = function (gradient) {\r\n return (gradient * gradient);\r\n };\r\n return QuadraticEase;\r\n}(EasingFunction));\r\nexport { QuadraticEase };\r\n/**\r\n * Easing function with a power of 4 shape (see link below).\r\n * @see https://easings.net/#easeInQuart\r\n * @see https://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar QuarticEase = /** @class */ (function (_super) {\r\n __extends(QuarticEase, _super);\r\n function QuarticEase() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n /** @hidden */\r\n QuarticEase.prototype.easeInCore = function (gradient) {\r\n return (gradient * gradient * gradient * gradient);\r\n };\r\n return QuarticEase;\r\n}(EasingFunction));\r\nexport { QuarticEase };\r\n/**\r\n * Easing function with a power of 5 shape (see link below).\r\n * @see https://easings.net/#easeInQuint\r\n * @see https://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar QuinticEase = /** @class */ (function (_super) {\r\n __extends(QuinticEase, _super);\r\n function QuinticEase() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n /** @hidden */\r\n QuinticEase.prototype.easeInCore = function (gradient) {\r\n return (gradient * gradient * gradient * gradient * gradient);\r\n };\r\n return QuinticEase;\r\n}(EasingFunction));\r\nexport { QuinticEase };\r\n/**\r\n * Easing function with a sin shape (see link below).\r\n * @see https://easings.net/#easeInSine\r\n * @see https://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar SineEase = /** @class */ (function (_super) {\r\n __extends(SineEase, _super);\r\n function SineEase() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n /** @hidden */\r\n SineEase.prototype.easeInCore = function (gradient) {\r\n return (1.0 - Math.sin(1.5707963267948966 * (1.0 - gradient)));\r\n };\r\n return SineEase;\r\n}(EasingFunction));\r\nexport { SineEase };\r\n/**\r\n * Easing function with a bezier shape (see link below).\r\n * @see http://cubic-bezier.com/#.17,.67,.83,.67\r\n * @see https://doc.babylonjs.com/babylon101/animations#easing-functions\r\n */\r\nvar BezierCurveEase = /** @class */ (function (_super) {\r\n __extends(BezierCurveEase, _super);\r\n /**\r\n * Instantiates a bezier function\r\n * @see http://cubic-bezier.com/#.17,.67,.83,.67\r\n * @param x1 Defines the x component of the start tangent in the bezier curve\r\n * @param y1 Defines the y component of the start tangent in the bezier curve\r\n * @param x2 Defines the x component of the end tangent in the bezier curve\r\n * @param y2 Defines the y component of the end tangent in the bezier curve\r\n */\r\n function BezierCurveEase(\r\n /** Defines the x component of the start tangent in the bezier curve */\r\n x1, \r\n /** Defines the y component of the start tangent in the bezier curve */\r\n y1, \r\n /** Defines the x component of the end tangent in the bezier curve */\r\n x2, \r\n /** Defines the y component of the end tangent in the bezier curve */\r\n y2) {\r\n if (x1 === void 0) { x1 = 0; }\r\n if (y1 === void 0) { y1 = 0; }\r\n if (x2 === void 0) { x2 = 1; }\r\n if (y2 === void 0) { y2 = 1; }\r\n var _this = _super.call(this) || this;\r\n _this.x1 = x1;\r\n _this.y1 = y1;\r\n _this.x2 = x2;\r\n _this.y2 = y2;\r\n return _this;\r\n }\r\n /** @hidden */\r\n BezierCurveEase.prototype.easeInCore = function (gradient) {\r\n return BezierCurve.Interpolate(gradient, this.x1, this.y1, this.x2, this.y2);\r\n };\r\n return BezierCurveEase;\r\n}(EasingFunction));\r\nexport { BezierCurveEase };\r\n//# sourceMappingURL=easing.js.map","/**\r\n * Represents the range of an animation\r\n */\r\nvar AnimationRange = /** @class */ (function () {\r\n /**\r\n * Initializes the range of an animation\r\n * @param name The name of the animation range\r\n * @param from The starting frame of the animation\r\n * @param to The ending frame of the animation\r\n */\r\n function AnimationRange(\r\n /**The name of the animation range**/\r\n name, \r\n /**The starting frame of the animation */\r\n from, \r\n /**The ending frame of the animation*/\r\n to) {\r\n this.name = name;\r\n this.from = from;\r\n this.to = to;\r\n }\r\n /**\r\n * Makes a copy of the animation range\r\n * @returns A copy of the animation range\r\n */\r\n AnimationRange.prototype.clone = function () {\r\n return new AnimationRange(this.name, this.from, this.to);\r\n };\r\n return AnimationRange;\r\n}());\r\nexport { AnimationRange };\r\n//# sourceMappingURL=animationRange.js.map","import { Vector3, Quaternion, Vector2, Matrix, TmpVectors } from \"../Maths/math.vector\";\r\nimport { Color3, Color4 } from '../Maths/math.color';\r\nimport { Scalar } from \"../Maths/math.scalar\";\r\nimport { SerializationHelper } from \"../Misc/decorators\";\r\nimport { _TypeStore } from '../Misc/typeStore';\r\nimport { AnimationKeyInterpolation } from './animationKey';\r\nimport { AnimationRange } from './animationRange';\r\nimport { Node } from \"../node\";\r\nimport { Size } from '../Maths/math.size';\r\nimport { WebRequest } from '../Misc/webRequest';\r\n/**\r\n * @hidden\r\n */\r\nvar _IAnimationState = /** @class */ (function () {\r\n function _IAnimationState() {\r\n }\r\n return _IAnimationState;\r\n}());\r\nexport { _IAnimationState };\r\n/**\r\n * Class used to store any kind of animation\r\n */\r\nvar Animation = /** @class */ (function () {\r\n /**\r\n * Initializes the animation\r\n * @param name Name of the animation\r\n * @param targetProperty Property to animate\r\n * @param framePerSecond The frames per second of the animation\r\n * @param dataType The data type of the animation\r\n * @param loopMode The loop mode of the animation\r\n * @param enableBlending Specifies if blending should be enabled\r\n */\r\n function Animation(\r\n /**Name of the animation */\r\n name, \r\n /**Property to animate */\r\n targetProperty, \r\n /**The frames per second of the animation */\r\n framePerSecond, \r\n /**The data type of the animation */\r\n dataType, \r\n /**The loop mode of the animation */\r\n loopMode, \r\n /**Specifies if blending should be enabled */\r\n enableBlending) {\r\n this.name = name;\r\n this.targetProperty = targetProperty;\r\n this.framePerSecond = framePerSecond;\r\n this.dataType = dataType;\r\n this.loopMode = loopMode;\r\n this.enableBlending = enableBlending;\r\n /**\r\n * @hidden Internal use only\r\n */\r\n this._runtimeAnimations = new Array();\r\n /**\r\n * The set of event that will be linked to this animation\r\n */\r\n this._events = new Array();\r\n /**\r\n * Stores the blending speed of the animation\r\n */\r\n this.blendingSpeed = 0.01;\r\n /**\r\n * Stores the animation ranges for the animation\r\n */\r\n this._ranges = {};\r\n this.targetPropertyPath = targetProperty.split(\".\");\r\n this.dataType = dataType;\r\n this.loopMode = loopMode === undefined ? Animation.ANIMATIONLOOPMODE_CYCLE : loopMode;\r\n }\r\n /**\r\n * @hidden Internal use\r\n */\r\n Animation._PrepareAnimation = function (name, targetProperty, framePerSecond, totalFrame, from, to, loopMode, easingFunction) {\r\n var dataType = undefined;\r\n if (!isNaN(parseFloat(from)) && isFinite(from)) {\r\n dataType = Animation.ANIMATIONTYPE_FLOAT;\r\n }\r\n else if (from instanceof Quaternion) {\r\n dataType = Animation.ANIMATIONTYPE_QUATERNION;\r\n }\r\n else if (from instanceof Vector3) {\r\n dataType = Animation.ANIMATIONTYPE_VECTOR3;\r\n }\r\n else if (from instanceof Vector2) {\r\n dataType = Animation.ANIMATIONTYPE_VECTOR2;\r\n }\r\n else if (from instanceof Color3) {\r\n dataType = Animation.ANIMATIONTYPE_COLOR3;\r\n }\r\n else if (from instanceof Color4) {\r\n dataType = Animation.ANIMATIONTYPE_COLOR4;\r\n }\r\n else if (from instanceof Size) {\r\n dataType = Animation.ANIMATIONTYPE_SIZE;\r\n }\r\n if (dataType == undefined) {\r\n return null;\r\n }\r\n var animation = new Animation(name, targetProperty, framePerSecond, dataType, loopMode);\r\n var keys = [{ frame: 0, value: from }, { frame: totalFrame, value: to }];\r\n animation.setKeys(keys);\r\n if (easingFunction !== undefined) {\r\n animation.setEasingFunction(easingFunction);\r\n }\r\n return animation;\r\n };\r\n /**\r\n * Sets up an animation\r\n * @param property The property to animate\r\n * @param animationType The animation type to apply\r\n * @param framePerSecond The frames per second of the animation\r\n * @param easingFunction The easing function used in the animation\r\n * @returns The created animation\r\n */\r\n Animation.CreateAnimation = function (property, animationType, framePerSecond, easingFunction) {\r\n var animation = new Animation(property + \"Animation\", property, framePerSecond, animationType, Animation.ANIMATIONLOOPMODE_CONSTANT);\r\n animation.setEasingFunction(easingFunction);\r\n return animation;\r\n };\r\n /**\r\n * Create and start an animation on a node\r\n * @param name defines the name of the global animation that will be run on all nodes\r\n * @param node defines the root node where the animation will take place\r\n * @param targetProperty defines property to animate\r\n * @param framePerSecond defines the number of frame per second yo use\r\n * @param totalFrame defines the number of frames in total\r\n * @param from defines the initial value\r\n * @param to defines the final value\r\n * @param loopMode defines which loop mode you want to use (off by default)\r\n * @param easingFunction defines the easing function to use (linear by default)\r\n * @param onAnimationEnd defines the callback to call when animation end\r\n * @returns the animatable created for this animation\r\n */\r\n Animation.CreateAndStartAnimation = function (name, node, targetProperty, framePerSecond, totalFrame, from, to, loopMode, easingFunction, onAnimationEnd) {\r\n var animation = Animation._PrepareAnimation(name, targetProperty, framePerSecond, totalFrame, from, to, loopMode, easingFunction);\r\n if (!animation) {\r\n return null;\r\n }\r\n return node.getScene().beginDirectAnimation(node, [animation], 0, totalFrame, (animation.loopMode === 1), 1.0, onAnimationEnd);\r\n };\r\n /**\r\n * Create and start an animation on a node and its descendants\r\n * @param name defines the name of the global animation that will be run on all nodes\r\n * @param node defines the root node where the animation will take place\r\n * @param directDescendantsOnly if true only direct descendants will be used, if false direct and also indirect (children of children, an so on in a recursive manner) descendants will be used\r\n * @param targetProperty defines property to animate\r\n * @param framePerSecond defines the number of frame per second to use\r\n * @param totalFrame defines the number of frames in total\r\n * @param from defines the initial value\r\n * @param to defines the final value\r\n * @param loopMode defines which loop mode you want to use (off by default)\r\n * @param easingFunction defines the easing function to use (linear by default)\r\n * @param onAnimationEnd defines the callback to call when an animation ends (will be called once per node)\r\n * @returns the list of animatables created for all nodes\r\n * @example https://www.babylonjs-playground.com/#MH0VLI\r\n */\r\n Animation.CreateAndStartHierarchyAnimation = function (name, node, directDescendantsOnly, targetProperty, framePerSecond, totalFrame, from, to, loopMode, easingFunction, onAnimationEnd) {\r\n var animation = Animation._PrepareAnimation(name, targetProperty, framePerSecond, totalFrame, from, to, loopMode, easingFunction);\r\n if (!animation) {\r\n return null;\r\n }\r\n var scene = node.getScene();\r\n return scene.beginDirectHierarchyAnimation(node, directDescendantsOnly, [animation], 0, totalFrame, (animation.loopMode === 1), 1.0, onAnimationEnd);\r\n };\r\n /**\r\n * Creates a new animation, merges it with the existing animations and starts it\r\n * @param name Name of the animation\r\n * @param node Node which contains the scene that begins the animations\r\n * @param targetProperty Specifies which property to animate\r\n * @param framePerSecond The frames per second of the animation\r\n * @param totalFrame The total number of frames\r\n * @param from The frame at the beginning of the animation\r\n * @param to The frame at the end of the animation\r\n * @param loopMode Specifies the loop mode of the animation\r\n * @param easingFunction (Optional) The easing function of the animation, which allow custom mathematical formulas for animations\r\n * @param onAnimationEnd Callback to run once the animation is complete\r\n * @returns Nullable animation\r\n */\r\n Animation.CreateMergeAndStartAnimation = function (name, node, targetProperty, framePerSecond, totalFrame, from, to, loopMode, easingFunction, onAnimationEnd) {\r\n var animation = Animation._PrepareAnimation(name, targetProperty, framePerSecond, totalFrame, from, to, loopMode, easingFunction);\r\n if (!animation) {\r\n return null;\r\n }\r\n node.animations.push(animation);\r\n return node.getScene().beginAnimation(node, 0, totalFrame, (animation.loopMode === 1), 1.0, onAnimationEnd);\r\n };\r\n /**\r\n * Convert the keyframes for all animations belonging to the group to be relative to a given reference frame.\r\n * @param sourceAnimation defines the Animation containing keyframes to convert\r\n * @param referenceFrame defines the frame that keyframes in the range will be relative to\r\n * @param range defines the name of the AnimationRange belonging to the Animation to convert\r\n * @param cloneOriginal defines whether or not to clone the animation and convert the clone or convert the original animation (default is false)\r\n * @param clonedName defines the name of the resulting cloned Animation if cloneOriginal is true\r\n * @returns a new Animation if cloneOriginal is true or the original Animation if cloneOriginal is false\r\n */\r\n Animation.MakeAnimationAdditive = function (sourceAnimation, referenceFrame, range, cloneOriginal, clonedName) {\r\n if (referenceFrame === void 0) { referenceFrame = 0; }\r\n if (cloneOriginal === void 0) { cloneOriginal = false; }\r\n var animation = sourceAnimation;\r\n if (cloneOriginal) {\r\n animation = sourceAnimation.clone();\r\n animation.name = clonedName || animation.name;\r\n }\r\n if (!animation._keys.length) {\r\n return animation;\r\n }\r\n referenceFrame = referenceFrame >= 0 ? referenceFrame : 0;\r\n var startIndex = 0;\r\n var firstKey = animation._keys[0];\r\n var endIndex = animation._keys.length - 1;\r\n var lastKey = animation._keys[endIndex];\r\n var valueStore = {\r\n referenceValue: firstKey.value,\r\n referencePosition: TmpVectors.Vector3[0],\r\n referenceQuaternion: TmpVectors.Quaternion[0],\r\n referenceScaling: TmpVectors.Vector3[1],\r\n keyPosition: TmpVectors.Vector3[2],\r\n keyQuaternion: TmpVectors.Quaternion[1],\r\n keyScaling: TmpVectors.Vector3[3]\r\n };\r\n var referenceFound = false;\r\n var from = firstKey.frame;\r\n var to = lastKey.frame;\r\n if (range) {\r\n var rangeValue = animation.getRange(range);\r\n if (rangeValue) {\r\n from = rangeValue.from;\r\n to = rangeValue.to;\r\n }\r\n }\r\n var fromKeyFound = firstKey.frame === from;\r\n var toKeyFound = lastKey.frame === to;\r\n // There's only one key, so use it\r\n if (animation._keys.length === 1) {\r\n var value = animation._getKeyValue(animation._keys[0]);\r\n valueStore.referenceValue = value.clone ? value.clone() : value;\r\n referenceFound = true;\r\n }\r\n // Reference frame is before the first frame, so just use the first frame\r\n else if (referenceFrame <= firstKey.frame) {\r\n var value = animation._getKeyValue(firstKey.value);\r\n valueStore.referenceValue = value.clone ? value.clone() : value;\r\n referenceFound = true;\r\n }\r\n // Reference frame is after the last frame, so just use the last frame\r\n else if (referenceFrame >= lastKey.frame) {\r\n var value = animation._getKeyValue(lastKey.value);\r\n valueStore.referenceValue = value.clone ? value.clone() : value;\r\n referenceFound = true;\r\n }\r\n // Find key bookends, create them if they don't exist\r\n var index = 0;\r\n while (!referenceFound || !fromKeyFound || !toKeyFound && index < animation._keys.length - 1) {\r\n var currentKey = animation._keys[index];\r\n var nextKey = animation._keys[index + 1];\r\n // If reference frame wasn't found yet, check if we can interpolate to it\r\n if (!referenceFound && referenceFrame >= currentKey.frame && referenceFrame <= nextKey.frame) {\r\n var value = void 0;\r\n if (referenceFrame === currentKey.frame) {\r\n value = animation._getKeyValue(currentKey.value);\r\n }\r\n else if (referenceFrame === nextKey.frame) {\r\n value = animation._getKeyValue(nextKey.value);\r\n }\r\n else {\r\n var animationState = {\r\n key: index,\r\n repeatCount: 0,\r\n loopMode: this.ANIMATIONLOOPMODE_CONSTANT\r\n };\r\n value = animation._interpolate(referenceFrame, animationState);\r\n }\r\n valueStore.referenceValue = value.clone ? value.clone() : value;\r\n referenceFound = true;\r\n }\r\n // If from key wasn't found yet, check if we can interpolate to it\r\n if (!fromKeyFound && from >= currentKey.frame && from <= nextKey.frame) {\r\n if (from === currentKey.frame) {\r\n startIndex = index;\r\n }\r\n else if (from === nextKey.frame) {\r\n startIndex = index + 1;\r\n }\r\n else {\r\n var animationState = {\r\n key: index,\r\n repeatCount: 0,\r\n loopMode: this.ANIMATIONLOOPMODE_CONSTANT\r\n };\r\n var value = animation._interpolate(from, animationState);\r\n var key = {\r\n frame: from,\r\n value: value.clone ? value.clone() : value\r\n };\r\n animation._keys.splice(index + 1, 0, key);\r\n startIndex = index + 1;\r\n }\r\n fromKeyFound = true;\r\n }\r\n // If to key wasn't found yet, check if we can interpolate to it\r\n if (!toKeyFound && to >= currentKey.frame && to <= nextKey.frame) {\r\n if (to === currentKey.frame) {\r\n endIndex = index;\r\n }\r\n else if (to === nextKey.frame) {\r\n endIndex = index + 1;\r\n }\r\n else {\r\n var animationState = {\r\n key: index,\r\n repeatCount: 0,\r\n loopMode: this.ANIMATIONLOOPMODE_CONSTANT\r\n };\r\n var value = animation._interpolate(to, animationState);\r\n var key = {\r\n frame: to,\r\n value: value.clone ? value.clone() : value\r\n };\r\n animation._keys.splice(index + 1, 0, key);\r\n endIndex = index + 1;\r\n }\r\n toKeyFound = true;\r\n }\r\n index++;\r\n }\r\n // Conjugate the quaternion\r\n if (animation.dataType === Animation.ANIMATIONTYPE_QUATERNION) {\r\n valueStore.referenceValue.normalize().conjugateInPlace();\r\n }\r\n // Decompose matrix and conjugate the quaternion\r\n else if (animation.dataType === Animation.ANIMATIONTYPE_MATRIX) {\r\n valueStore.referenceValue.decompose(valueStore.referenceScaling, valueStore.referenceQuaternion, valueStore.referencePosition);\r\n valueStore.referenceQuaternion.normalize().conjugateInPlace();\r\n }\r\n // Subtract the reference value from all of the key values\r\n for (var index = startIndex; index <= endIndex; index++) {\r\n var key = animation._keys[index];\r\n // If this key was duplicated to create a frame 0 key, skip it because its value has already been updated\r\n if (index && animation.dataType !== Animation.ANIMATIONTYPE_FLOAT && key.value === firstKey.value) {\r\n continue;\r\n }\r\n switch (animation.dataType) {\r\n case Animation.ANIMATIONTYPE_MATRIX:\r\n key.value.decompose(valueStore.keyScaling, valueStore.keyQuaternion, valueStore.keyPosition);\r\n valueStore.keyPosition.subtractInPlace(valueStore.referencePosition);\r\n valueStore.keyScaling.divideInPlace(valueStore.referenceScaling);\r\n valueStore.referenceQuaternion.multiplyToRef(valueStore.keyQuaternion, valueStore.keyQuaternion);\r\n Matrix.ComposeToRef(valueStore.keyScaling, valueStore.keyQuaternion, valueStore.keyPosition, key.value);\r\n break;\r\n case Animation.ANIMATIONTYPE_QUATERNION:\r\n valueStore.referenceValue.multiplyToRef(key.value, key.value);\r\n break;\r\n case Animation.ANIMATIONTYPE_VECTOR2:\r\n case Animation.ANIMATIONTYPE_VECTOR3:\r\n case Animation.ANIMATIONTYPE_COLOR3:\r\n case Animation.ANIMATIONTYPE_COLOR4:\r\n key.value.subtractToRef(valueStore.referenceValue, key.value);\r\n break;\r\n case Animation.ANIMATIONTYPE_SIZE:\r\n key.value.width -= valueStore.referenceValue.width;\r\n key.value.height -= valueStore.referenceValue.height;\r\n break;\r\n default:\r\n key.value -= valueStore.referenceValue;\r\n }\r\n }\r\n return animation;\r\n };\r\n /**\r\n * Transition property of an host to the target Value\r\n * @param property The property to transition\r\n * @param targetValue The target Value of the property\r\n * @param host The object where the property to animate belongs\r\n * @param scene Scene used to run the animation\r\n * @param frameRate Framerate (in frame/s) to use\r\n * @param transition The transition type we want to use\r\n * @param duration The duration of the animation, in milliseconds\r\n * @param onAnimationEnd Callback trigger at the end of the animation\r\n * @returns Nullable animation\r\n */\r\n Animation.TransitionTo = function (property, targetValue, host, scene, frameRate, transition, duration, onAnimationEnd) {\r\n if (onAnimationEnd === void 0) { onAnimationEnd = null; }\r\n if (duration <= 0) {\r\n host[property] = targetValue;\r\n if (onAnimationEnd) {\r\n onAnimationEnd();\r\n }\r\n return null;\r\n }\r\n var endFrame = frameRate * (duration / 1000);\r\n transition.setKeys([{\r\n frame: 0,\r\n value: host[property].clone ? host[property].clone() : host[property]\r\n },\r\n {\r\n frame: endFrame,\r\n value: targetValue\r\n }]);\r\n if (!host.animations) {\r\n host.animations = [];\r\n }\r\n host.animations.push(transition);\r\n var animation = scene.beginAnimation(host, 0, endFrame, false);\r\n animation.onAnimationEnd = onAnimationEnd;\r\n return animation;\r\n };\r\n Object.defineProperty(Animation.prototype, \"runtimeAnimations\", {\r\n /**\r\n * Return the array of runtime animations currently using this animation\r\n */\r\n get: function () {\r\n return this._runtimeAnimations;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(Animation.prototype, \"hasRunningRuntimeAnimations\", {\r\n /**\r\n * Specifies if any of the runtime animations are currently running\r\n */\r\n get: function () {\r\n for (var _i = 0, _a = this._runtimeAnimations; _i < _a.length; _i++) {\r\n var runtimeAnimation = _a[_i];\r\n if (!runtimeAnimation.isStopped) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n // Methods\r\n /**\r\n * Converts the animation to a string\r\n * @param fullDetails support for multiple levels of logging within scene loading\r\n * @returns String form of the animation\r\n */\r\n Animation.prototype.toString = function (fullDetails) {\r\n var ret = \"Name: \" + this.name + \", property: \" + this.targetProperty;\r\n ret += \", datatype: \" + ([\"Float\", \"Vector3\", \"Quaternion\", \"Matrix\", \"Color3\", \"Vector2\"])[this.dataType];\r\n ret += \", nKeys: \" + (this._keys ? this._keys.length : \"none\");\r\n ret += \", nRanges: \" + (this._ranges ? Object.keys(this._ranges).length : \"none\");\r\n if (fullDetails) {\r\n ret += \", Ranges: {\";\r\n var first = true;\r\n for (var name in this._ranges) {\r\n if (first) {\r\n ret += \", \";\r\n first = false;\r\n }\r\n ret += name;\r\n }\r\n ret += \"}\";\r\n }\r\n return ret;\r\n };\r\n /**\r\n * Add an event to this animation\r\n * @param event Event to add\r\n */\r\n Animation.prototype.addEvent = function (event) {\r\n this._events.push(event);\r\n this._events.sort(function (a, b) { return a.frame - b.frame; });\r\n };\r\n /**\r\n * Remove all events found at the given frame\r\n * @param frame The frame to remove events from\r\n */\r\n Animation.prototype.removeEvents = function (frame) {\r\n for (var index = 0; index < this._events.length; index++) {\r\n if (this._events[index].frame === frame) {\r\n this._events.splice(index, 1);\r\n index--;\r\n }\r\n }\r\n };\r\n /**\r\n * Retrieves all the events from the animation\r\n * @returns Events from the animation\r\n */\r\n Animation.prototype.getEvents = function () {\r\n return this._events;\r\n };\r\n /**\r\n * Creates an animation range\r\n * @param name Name of the animation range\r\n * @param from Starting frame of the animation range\r\n * @param to Ending frame of the animation\r\n */\r\n Animation.prototype.createRange = function (name, from, to) {\r\n // check name not already in use; could happen for bones after serialized\r\n if (!this._ranges[name]) {\r\n this._ranges[name] = new AnimationRange(name, from, to);\r\n }\r\n };\r\n /**\r\n * Deletes an animation range by name\r\n * @param name Name of the animation range to delete\r\n * @param deleteFrames Specifies if the key frames for the range should also be deleted (true) or not (false)\r\n */\r\n Animation.prototype.deleteRange = function (name, deleteFrames) {\r\n if (deleteFrames === void 0) { deleteFrames = true; }\r\n var range = this._ranges[name];\r\n if (!range) {\r\n return;\r\n }\r\n if (deleteFrames) {\r\n var from = range.from;\r\n var to = range.to;\r\n // this loop MUST go high to low for multiple splices to work\r\n for (var key = this._keys.length - 1; key >= 0; key--) {\r\n if (this._keys[key].frame >= from && this._keys[key].frame <= to) {\r\n this._keys.splice(key, 1);\r\n }\r\n }\r\n }\r\n this._ranges[name] = null; // said much faster than 'delete this._range[name]'\r\n };\r\n /**\r\n * Gets the animation range by name, or null if not defined\r\n * @param name Name of the animation range\r\n * @returns Nullable animation range\r\n */\r\n Animation.prototype.getRange = function (name) {\r\n return this._ranges[name];\r\n };\r\n /**\r\n * Gets the key frames from the animation\r\n * @returns The key frames of the animation\r\n */\r\n Animation.prototype.getKeys = function () {\r\n return this._keys;\r\n };\r\n /**\r\n * Gets the highest frame rate of the animation\r\n * @returns Highest frame rate of the animation\r\n */\r\n Animation.prototype.getHighestFrame = function () {\r\n var ret = 0;\r\n for (var key = 0, nKeys = this._keys.length; key < nKeys; key++) {\r\n if (ret < this._keys[key].frame) {\r\n ret = this._keys[key].frame;\r\n }\r\n }\r\n return ret;\r\n };\r\n /**\r\n * Gets the easing function of the animation\r\n * @returns Easing function of the animation\r\n */\r\n Animation.prototype.getEasingFunction = function () {\r\n return this._easingFunction;\r\n };\r\n /**\r\n * Sets the easing function of the animation\r\n * @param easingFunction A custom mathematical formula for animation\r\n */\r\n Animation.prototype.setEasingFunction = function (easingFunction) {\r\n this._easingFunction = easingFunction;\r\n };\r\n /**\r\n * Interpolates a scalar linearly\r\n * @param startValue Start value of the animation curve\r\n * @param endValue End value of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated scalar value\r\n */\r\n Animation.prototype.floatInterpolateFunction = function (startValue, endValue, gradient) {\r\n return Scalar.Lerp(startValue, endValue, gradient);\r\n };\r\n /**\r\n * Interpolates a scalar cubically\r\n * @param startValue Start value of the animation curve\r\n * @param outTangent End tangent of the animation\r\n * @param endValue End value of the animation curve\r\n * @param inTangent Start tangent of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated scalar value\r\n */\r\n Animation.prototype.floatInterpolateFunctionWithTangents = function (startValue, outTangent, endValue, inTangent, gradient) {\r\n return Scalar.Hermite(startValue, outTangent, endValue, inTangent, gradient);\r\n };\r\n /**\r\n * Interpolates a quaternion using a spherical linear interpolation\r\n * @param startValue Start value of the animation curve\r\n * @param endValue End value of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated quaternion value\r\n */\r\n Animation.prototype.quaternionInterpolateFunction = function (startValue, endValue, gradient) {\r\n return Quaternion.Slerp(startValue, endValue, gradient);\r\n };\r\n /**\r\n * Interpolates a quaternion cubically\r\n * @param startValue Start value of the animation curve\r\n * @param outTangent End tangent of the animation curve\r\n * @param endValue End value of the animation curve\r\n * @param inTangent Start tangent of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated quaternion value\r\n */\r\n Animation.prototype.quaternionInterpolateFunctionWithTangents = function (startValue, outTangent, endValue, inTangent, gradient) {\r\n return Quaternion.Hermite(startValue, outTangent, endValue, inTangent, gradient).normalize();\r\n };\r\n /**\r\n * Interpolates a Vector3 linearl\r\n * @param startValue Start value of the animation curve\r\n * @param endValue End value of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated scalar value\r\n */\r\n Animation.prototype.vector3InterpolateFunction = function (startValue, endValue, gradient) {\r\n return Vector3.Lerp(startValue, endValue, gradient);\r\n };\r\n /**\r\n * Interpolates a Vector3 cubically\r\n * @param startValue Start value of the animation curve\r\n * @param outTangent End tangent of the animation\r\n * @param endValue End value of the animation curve\r\n * @param inTangent Start tangent of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns InterpolatedVector3 value\r\n */\r\n Animation.prototype.vector3InterpolateFunctionWithTangents = function (startValue, outTangent, endValue, inTangent, gradient) {\r\n return Vector3.Hermite(startValue, outTangent, endValue, inTangent, gradient);\r\n };\r\n /**\r\n * Interpolates a Vector2 linearly\r\n * @param startValue Start value of the animation curve\r\n * @param endValue End value of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated Vector2 value\r\n */\r\n Animation.prototype.vector2InterpolateFunction = function (startValue, endValue, gradient) {\r\n return Vector2.Lerp(startValue, endValue, gradient);\r\n };\r\n /**\r\n * Interpolates a Vector2 cubically\r\n * @param startValue Start value of the animation curve\r\n * @param outTangent End tangent of the animation\r\n * @param endValue End value of the animation curve\r\n * @param inTangent Start tangent of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated Vector2 value\r\n */\r\n Animation.prototype.vector2InterpolateFunctionWithTangents = function (startValue, outTangent, endValue, inTangent, gradient) {\r\n return Vector2.Hermite(startValue, outTangent, endValue, inTangent, gradient);\r\n };\r\n /**\r\n * Interpolates a size linearly\r\n * @param startValue Start value of the animation curve\r\n * @param endValue End value of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated Size value\r\n */\r\n Animation.prototype.sizeInterpolateFunction = function (startValue, endValue, gradient) {\r\n return Size.Lerp(startValue, endValue, gradient);\r\n };\r\n /**\r\n * Interpolates a Color3 linearly\r\n * @param startValue Start value of the animation curve\r\n * @param endValue End value of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated Color3 value\r\n */\r\n Animation.prototype.color3InterpolateFunction = function (startValue, endValue, gradient) {\r\n return Color3.Lerp(startValue, endValue, gradient);\r\n };\r\n /**\r\n * Interpolates a Color4 linearly\r\n * @param startValue Start value of the animation curve\r\n * @param endValue End value of the animation curve\r\n * @param gradient Scalar amount to interpolate\r\n * @returns Interpolated Color3 value\r\n */\r\n Animation.prototype.color4InterpolateFunction = function (startValue, endValue, gradient) {\r\n return Color4.Lerp(startValue, endValue, gradient);\r\n };\r\n /**\r\n * @hidden Internal use only\r\n */\r\n Animation.prototype._getKeyValue = function (value) {\r\n if (typeof value === \"function\") {\r\n return value();\r\n }\r\n return value;\r\n };\r\n /**\r\n * @hidden Internal use only\r\n */\r\n Animation.prototype._interpolate = function (currentFrame, state) {\r\n if (state.loopMode === Animation.ANIMATIONLOOPMODE_CONSTANT && state.repeatCount > 0) {\r\n return state.highLimitValue.clone ? state.highLimitValue.clone() : state.highLimitValue;\r\n }\r\n var keys = this._keys;\r\n if (keys.length === 1) {\r\n return this._getKeyValue(keys[0].value);\r\n }\r\n var startKeyIndex = state.key;\r\n if (keys[startKeyIndex].frame >= currentFrame) {\r\n while (startKeyIndex - 1 >= 0 && keys[startKeyIndex].frame >= currentFrame) {\r\n startKeyIndex--;\r\n }\r\n }\r\n for (var key = startKeyIndex; key < keys.length; key++) {\r\n var endKey = keys[key + 1];\r\n if (endKey.frame >= currentFrame) {\r\n state.key = key;\r\n var startKey = keys[key];\r\n var startValue = this._getKeyValue(startKey.value);\r\n if (startKey.interpolation === AnimationKeyInterpolation.STEP) {\r\n return startValue;\r\n }\r\n var endValue = this._getKeyValue(endKey.value);\r\n var useTangent = startKey.outTangent !== undefined && endKey.inTangent !== undefined;\r\n var frameDelta = endKey.frame - startKey.frame;\r\n // gradient : percent of currentFrame between the frame inf and the frame sup\r\n var gradient = (currentFrame - startKey.frame) / frameDelta;\r\n // check for easingFunction and correction of gradient\r\n var easingFunction = this.getEasingFunction();\r\n if (easingFunction != null) {\r\n gradient = easingFunction.ease(gradient);\r\n }\r\n switch (this.dataType) {\r\n // Float\r\n case Animation.ANIMATIONTYPE_FLOAT:\r\n var floatValue = useTangent ? this.floatInterpolateFunctionWithTangents(startValue, startKey.outTangent * frameDelta, endValue, endKey.inTangent * frameDelta, gradient) : this.floatInterpolateFunction(startValue, endValue, gradient);\r\n switch (state.loopMode) {\r\n case Animation.ANIMATIONLOOPMODE_CYCLE:\r\n case Animation.ANIMATIONLOOPMODE_CONSTANT:\r\n return floatValue;\r\n case Animation.ANIMATIONLOOPMODE_RELATIVE:\r\n return state.offsetValue * state.repeatCount + floatValue;\r\n }\r\n break;\r\n // Quaternion\r\n case Animation.ANIMATIONTYPE_QUATERNION:\r\n var quatValue = useTangent ? this.quaternionInterpolateFunctionWithTangents(startValue, startKey.outTangent.scale(frameDelta), endValue, endKey.inTangent.scale(frameDelta), gradient) : this.quaternionInterpolateFunction(startValue, endValue, gradient);\r\n switch (state.loopMode) {\r\n case Animation.ANIMATIONLOOPMODE_CYCLE:\r\n case Animation.ANIMATIONLOOPMODE_CONSTANT:\r\n return quatValue;\r\n case Animation.ANIMATIONLOOPMODE_RELATIVE:\r\n return quatValue.addInPlace(state.offsetValue.scale(state.repeatCount));\r\n }\r\n return quatValue;\r\n // Vector3\r\n case Animation.ANIMATIONTYPE_VECTOR3:\r\n var vec3Value = useTangent ? this.vector3InterpolateFunctionWithTangents(startValue, startKey.outTangent.scale(frameDelta), endValue, endKey.inTangent.scale(frameDelta), gradient) : this.vector3InterpolateFunction(startValue, endValue, gradient);\r\n switch (state.loopMode) {\r\n case Animation.ANIMATIONLOOPMODE_CYCLE:\r\n case Animation.ANIMATIONLOOPMODE_CONSTANT:\r\n return vec3Value;\r\n case Animation.ANIMATIONLOOPMODE_RELATIVE:\r\n return vec3Value.add(state.offsetValue.scale(state.repeatCount));\r\n }\r\n // Vector2\r\n case Animation.ANIMATIONTYPE_VECTOR2:\r\n var vec2Value = useTangent ? this.vector2InterpolateFunctionWithTangents(startValue, startKey.outTangent.scale(frameDelta), endValue, endKey.inTangent.scale(frameDelta), gradient) : this.vector2InterpolateFunction(startValue, endValue, gradient);\r\n switch (state.loopMode) {\r\n case Animation.ANIMATIONLOOPMODE_CYCLE:\r\n case Animation.ANIMATIONLOOPMODE_CONSTANT:\r\n return vec2Value;\r\n case Animation.ANIMATIONLOOPMODE_RELATIVE:\r\n return vec2Value.add(state.offsetValue.scale(state.repeatCount));\r\n }\r\n // Size\r\n case Animation.ANIMATIONTYPE_SIZE:\r\n switch (state.loopMode) {\r\n case Animation.ANIMATIONLOOPMODE_CYCLE:\r\n case Animation.ANIMATIONLOOPMODE_CONSTANT:\r\n return this.sizeInterpolateFunction(startValue, endValue, gradient);\r\n case Animation.ANIMATIONLOOPMODE_RELATIVE:\r\n return this.sizeInterpolateFunction(startValue, endValue, gradient).add(state.offsetValue.scale(state.repeatCount));\r\n }\r\n // Color3\r\n case Animation.ANIMATIONTYPE_COLOR3:\r\n switch (state.loopMode) {\r\n case Animation.ANIMATIONLOOPMODE_CYCLE:\r\n case Animation.ANIMATIONLOOPMODE_CONSTANT:\r\n return this.color3InterpolateFunction(startValue, endValue, gradient);\r\n case Animation.ANIMATIONLOOPMODE_RELATIVE:\r\n return this.color3InterpolateFunction(startValue, endValue, gradient).add(state.offsetValue.scale(state.repeatCount));\r\n }\r\n // Color4\r\n case Animation.ANIMATIONTYPE_COLOR4:\r\n switch (state.loopMode) {\r\n case Animation.ANIMATIONLOOPMODE_CYCLE:\r\n case Animation.ANIMATIONLOOPMODE_CONSTANT:\r\n return this.color4InterpolateFunction(startValue, endValue, gradient);\r\n case Animation.ANIMATIONLOOPMODE_RELATIVE:\r\n return this.color4InterpolateFunction(startValue, endValue, gradient).add(state.offsetValue.scale(state.repeatCount));\r\n }\r\n // Matrix\r\n case Animation.ANIMATIONTYPE_MATRIX:\r\n switch (state.loopMode) {\r\n case Animation.ANIMATIONLOOPMODE_CYCLE:\r\n case Animation.ANIMATIONLOOPMODE_CONSTANT:\r\n if (Animation.AllowMatricesInterpolation) {\r\n return this.matrixInterpolateFunction(startValue, endValue, gradient, state.workValue);\r\n }\r\n case Animation.ANIMATIONLOOPMODE_RELATIVE:\r\n return startValue;\r\n }\r\n default:\r\n break;\r\n }\r\n break;\r\n }\r\n }\r\n return this._getKeyValue(keys[keys.length - 1].value);\r\n };\r\n /**\r\n * Defines the function to use to interpolate matrices\r\n * @param startValue defines the start matrix\r\n * @param endValue defines the end matrix\r\n * @param gradient defines the gradient between both matrices\r\n * @param result defines an optional target matrix where to store the interpolation\r\n * @returns the interpolated matrix\r\n */\r\n Animation.prototype.matrixInterpolateFunction = function (startValue, endValue, gradient, result) {\r\n if (Animation.AllowMatrixDecomposeForInterpolation) {\r\n if (result) {\r\n Matrix.DecomposeLerpToRef(startValue, endValue, gradient, result);\r\n return result;\r\n }\r\n return Matrix.DecomposeLerp(startValue, endValue, gradient);\r\n }\r\n if (result) {\r\n Matrix.LerpToRef(startValue, endValue, gradient, result);\r\n return result;\r\n }\r\n return Matrix.Lerp(startValue, endValue, gradient);\r\n };\r\n /**\r\n * Makes a copy of the animation\r\n * @returns Cloned animation\r\n */\r\n Animation.prototype.clone = function () {\r\n var clone = new Animation(this.name, this.targetPropertyPath.join(\".\"), this.framePerSecond, this.dataType, this.loopMode);\r\n clone.enableBlending = this.enableBlending;\r\n clone.blendingSpeed = this.blendingSpeed;\r\n if (this._keys) {\r\n clone.setKeys(this._keys);\r\n }\r\n if (this._ranges) {\r\n clone._ranges = {};\r\n for (var name in this._ranges) {\r\n var range = this._ranges[name];\r\n if (!range) {\r\n continue;\r\n }\r\n clone._ranges[name] = range.clone();\r\n }\r\n }\r\n return clone;\r\n };\r\n /**\r\n * Sets the key frames of the animation\r\n * @param values The animation key frames to set\r\n */\r\n Animation.prototype.setKeys = function (values) {\r\n this._keys = values.slice(0);\r\n };\r\n /**\r\n * Serializes the animation to an object\r\n * @returns Serialized object\r\n */\r\n Animation.prototype.serialize = function () {\r\n var serializationObject = {};\r\n serializationObject.name = this.name;\r\n serializationObject.property = this.targetProperty;\r\n serializationObject.framePerSecond = this.framePerSecond;\r\n serializationObject.dataType = this.dataType;\r\n serializationObject.loopBehavior = this.loopMode;\r\n serializationObject.enableBlending = this.enableBlending;\r\n serializationObject.blendingSpeed = this.blendingSpeed;\r\n var dataType = this.dataType;\r\n serializationObject.keys = [];\r\n var keys = this.getKeys();\r\n for (var index = 0; index < keys.length; index++) {\r\n var animationKey = keys[index];\r\n var key = {};\r\n key.frame = animationKey.frame;\r\n switch (dataType) {\r\n case Animation.ANIMATIONTYPE_FLOAT:\r\n key.values = [animationKey.value];\r\n if (animationKey.inTangent !== undefined) {\r\n key.values.push(animationKey.inTangent);\r\n }\r\n if (animationKey.outTangent !== undefined) {\r\n if (animationKey.inTangent === undefined) {\r\n key.values.push(undefined);\r\n }\r\n key.values.push(animationKey.outTangent);\r\n }\r\n break;\r\n case Animation.ANIMATIONTYPE_QUATERNION:\r\n case Animation.ANIMATIONTYPE_MATRIX:\r\n case Animation.ANIMATIONTYPE_VECTOR3:\r\n case Animation.ANIMATIONTYPE_COLOR3:\r\n case Animation.ANIMATIONTYPE_COLOR4:\r\n key.values = animationKey.value.asArray();\r\n if (animationKey.inTangent != undefined) {\r\n key.values.push(animationKey.inTangent.asArray());\r\n }\r\n if (animationKey.outTangent != undefined) {\r\n if (animationKey.inTangent === undefined) {\r\n key.values.push(undefined);\r\n }\r\n key.values.push(animationKey.outTangent.asArray());\r\n }\r\n break;\r\n }\r\n serializationObject.keys.push(key);\r\n }\r\n serializationObject.ranges = [];\r\n for (var name in this._ranges) {\r\n var source = this._ranges[name];\r\n if (!source) {\r\n continue;\r\n }\r\n var range = {};\r\n range.name = name;\r\n range.from = source.from;\r\n range.to = source.to;\r\n serializationObject.ranges.push(range);\r\n }\r\n return serializationObject;\r\n };\r\n /** @hidden */\r\n Animation._UniversalLerp = function (left, right, amount) {\r\n var constructor = left.constructor;\r\n if (constructor.Lerp) { // Lerp supported\r\n return constructor.Lerp(left, right, amount);\r\n }\r\n else if (constructor.Slerp) { // Slerp supported\r\n return constructor.Slerp(left, right, amount);\r\n }\r\n else if (left.toFixed) { // Number\r\n return left * (1.0 - amount) + amount * right;\r\n }\r\n else { // Blending not supported\r\n return right;\r\n }\r\n };\r\n /**\r\n * Parses an animation object and creates an animation\r\n * @param parsedAnimation Parsed animation object\r\n * @returns Animation object\r\n */\r\n Animation.Parse = function (parsedAnimation) {\r\n var animation = new Animation(parsedAnimation.name, parsedAnimation.property, parsedAnimation.framePerSecond, parsedAnimation.dataType, parsedAnimation.loopBehavior);\r\n var dataType = parsedAnimation.dataType;\r\n var keys = [];\r\n var data;\r\n var index;\r\n if (parsedAnimation.enableBlending) {\r\n animation.enableBlending = parsedAnimation.enableBlending;\r\n }\r\n if (parsedAnimation.blendingSpeed) {\r\n animation.blendingSpeed = parsedAnimation.blendingSpeed;\r\n }\r\n for (index = 0; index < parsedAnimation.keys.length; index++) {\r\n var key = parsedAnimation.keys[index];\r\n var inTangent;\r\n var outTangent;\r\n switch (dataType) {\r\n case Animation.ANIMATIONTYPE_FLOAT:\r\n data = key.values[0];\r\n if (key.values.length >= 1) {\r\n inTangent = key.values[1];\r\n }\r\n if (key.values.length >= 2) {\r\n outTangent = key.values[2];\r\n }\r\n break;\r\n case Animation.ANIMATIONTYPE_QUATERNION:\r\n data = Quaternion.FromArray(key.values);\r\n if (key.values.length >= 8) {\r\n var _inTangent = Quaternion.FromArray(key.values.slice(4, 8));\r\n if (!_inTangent.equals(Quaternion.Zero())) {\r\n inTangent = _inTangent;\r\n }\r\n }\r\n if (key.values.length >= 12) {\r\n var _outTangent = Quaternion.FromArray(key.values.slice(8, 12));\r\n if (!_outTangent.equals(Quaternion.Zero())) {\r\n outTangent = _outTangent;\r\n }\r\n }\r\n break;\r\n case Animation.ANIMATIONTYPE_MATRIX:\r\n data = Matrix.FromArray(key.values);\r\n break;\r\n case Animation.ANIMATIONTYPE_COLOR3:\r\n data = Color3.FromArray(key.values);\r\n break;\r\n case Animation.ANIMATIONTYPE_COLOR4:\r\n data = Color4.FromArray(key.values);\r\n break;\r\n case Animation.ANIMATIONTYPE_VECTOR3:\r\n default:\r\n data = Vector3.FromArray(key.values);\r\n break;\r\n }\r\n var keyData = {};\r\n keyData.frame = key.frame;\r\n keyData.value = data;\r\n if (inTangent != undefined) {\r\n keyData.inTangent = inTangent;\r\n }\r\n if (outTangent != undefined) {\r\n keyData.outTangent = outTangent;\r\n }\r\n keys.push(keyData);\r\n }\r\n animation.setKeys(keys);\r\n if (parsedAnimation.ranges) {\r\n for (index = 0; index < parsedAnimation.ranges.length; index++) {\r\n data = parsedAnimation.ranges[index];\r\n animation.createRange(data.name, data.from, data.to);\r\n }\r\n }\r\n return animation;\r\n };\r\n /**\r\n * Appends the serialized animations from the source animations\r\n * @param source Source containing the animations\r\n * @param destination Target to store the animations\r\n */\r\n Animation.AppendSerializedAnimations = function (source, destination) {\r\n SerializationHelper.AppendSerializedAnimations(source, destination);\r\n };\r\n /**\r\n * Creates a new animation or an array of animations from a snippet saved in a remote file\r\n * @param name defines the name of the animation to create (can be null or empty to use the one from the json data)\r\n * @param url defines the url to load from\r\n * @returns a promise that will resolve to the new animation or an array of animations\r\n */\r\n Animation.ParseFromFileAsync = function (name, url) {\r\n var _this = this;\r\n return new Promise(function (resolve, reject) {\r\n var request = new WebRequest();\r\n request.addEventListener(\"readystatechange\", function () {\r\n if (request.readyState == 4) {\r\n if (request.status == 200) {\r\n var serializationObject = JSON.parse(request.responseText);\r\n if (serializationObject.length) {\r\n var output = new Array();\r\n for (var _i = 0, serializationObject_1 = serializationObject; _i < serializationObject_1.length; _i++) {\r\n var serializedAnimation = serializationObject_1[_i];\r\n output.push(_this.Parse(serializedAnimation));\r\n }\r\n resolve(output);\r\n }\r\n else {\r\n var output = _this.Parse(serializationObject);\r\n if (name) {\r\n output.name = name;\r\n }\r\n resolve(output);\r\n }\r\n }\r\n else {\r\n reject(\"Unable to load the animation\");\r\n }\r\n }\r\n });\r\n request.open(\"GET\", url);\r\n request.send();\r\n });\r\n };\r\n /**\r\n * Creates an animation or an array of animations from a snippet saved by the Inspector\r\n * @param snippetId defines the snippet to load\r\n * @returns a promise that will resolve to the new animation or a new array of animations\r\n */\r\n Animation.CreateFromSnippetAsync = function (snippetId) {\r\n var _this = this;\r\n return new Promise(function (resolve, reject) {\r\n var request = new WebRequest();\r\n request.addEventListener(\"readystatechange\", function () {\r\n if (request.readyState == 4) {\r\n if (request.status == 200) {\r\n var snippet = JSON.parse(JSON.parse(request.responseText).jsonPayload);\r\n if (snippet.animations) {\r\n var serializationObject = JSON.parse(snippet.animations);\r\n var output = new Array();\r\n for (var _i = 0, serializationObject_2 = serializationObject; _i < serializationObject_2.length; _i++) {\r\n var serializedAnimation = serializationObject_2[_i];\r\n output.push(_this.Parse(serializedAnimation));\r\n }\r\n resolve(output);\r\n }\r\n else {\r\n var serializationObject = JSON.parse(snippet.animation);\r\n var output = _this.Parse(serializationObject);\r\n output.snippetId = snippetId;\r\n resolve(output);\r\n }\r\n }\r\n else {\r\n reject(\"Unable to load the snippet \" + snippetId);\r\n }\r\n }\r\n });\r\n request.open(\"GET\", _this.SnippetUrl + \"/\" + snippetId.replace(/#/g, \"/\"));\r\n request.send();\r\n });\r\n };\r\n /**\r\n * Use matrix interpolation instead of using direct key value when animating matrices\r\n */\r\n Animation.AllowMatricesInterpolation = false;\r\n /**\r\n * When matrix interpolation is enabled, this boolean forces the system to use Matrix.DecomposeLerp instead of Matrix.Lerp. Interpolation is more precise but slower\r\n */\r\n Animation.AllowMatrixDecomposeForInterpolation = true;\r\n /** Define the Url to load snippets */\r\n Animation.SnippetUrl = \"https://snippet.babylonjs.com\";\r\n // Statics\r\n /**\r\n * Float animation type\r\n */\r\n Animation.ANIMATIONTYPE_FLOAT = 0;\r\n /**\r\n * Vector3 animation type\r\n */\r\n Animation.ANIMATIONTYPE_VECTOR3 = 1;\r\n /**\r\n * Quaternion animation type\r\n */\r\n Animation.ANIMATIONTYPE_QUATERNION = 2;\r\n /**\r\n * Matrix animation type\r\n */\r\n Animation.ANIMATIONTYPE_MATRIX = 3;\r\n /**\r\n * Color3 animation type\r\n */\r\n Animation.ANIMATIONTYPE_COLOR3 = 4;\r\n /**\r\n * Color3 animation type\r\n */\r\n Animation.ANIMATIONTYPE_COLOR4 = 7;\r\n /**\r\n * Vector2 animation type\r\n */\r\n Animation.ANIMATIONTYPE_VECTOR2 = 5;\r\n /**\r\n * Size animation type\r\n */\r\n Animation.ANIMATIONTYPE_SIZE = 6;\r\n /**\r\n * Relative Loop Mode\r\n */\r\n Animation.ANIMATIONLOOPMODE_RELATIVE = 0;\r\n /**\r\n * Cycle Loop Mode\r\n */\r\n Animation.ANIMATIONLOOPMODE_CYCLE = 1;\r\n /**\r\n * Constant Loop Mode\r\n */\r\n Animation.ANIMATIONLOOPMODE_CONSTANT = 2;\r\n return Animation;\r\n}());\r\nexport { Animation };\r\n_TypeStore.RegisteredTypes[\"BABYLON.Animation\"] = Animation;\r\nNode._AnimationRangeFactory = function (name, from, to) { return new AnimationRange(name, from, to); };\r\n//# sourceMappingURL=animation.js.map","import { BackEase, EasingFunction } from \"../../Animations/easing\";\r\nimport { Animation } from \"../../Animations/animation\";\r\n/**\r\n * Add a bouncing effect to an ArcRotateCamera when reaching a specified minimum and maximum radius\r\n * @see https://doc.babylonjs.com/how_to/camera_behaviors#bouncing-behavior\r\n */\r\nvar BouncingBehavior = /** @class */ (function () {\r\n function BouncingBehavior() {\r\n /**\r\n * The duration of the animation, in milliseconds\r\n */\r\n this.transitionDuration = 450;\r\n /**\r\n * Length of the distance animated by the transition when lower radius is reached\r\n */\r\n this.lowerRadiusTransitionRange = 2;\r\n /**\r\n * Length of the distance animated by the transition when upper radius is reached\r\n */\r\n this.upperRadiusTransitionRange = -2;\r\n this._autoTransitionRange = false;\r\n // Animations\r\n this._radiusIsAnimating = false;\r\n this._radiusBounceTransition = null;\r\n this._animatables = new Array();\r\n }\r\n Object.defineProperty(BouncingBehavior.prototype, \"name\", {\r\n /**\r\n * Gets the name of the behavior.\r\n */\r\n get: function () {\r\n return \"Bouncing\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(BouncingBehavior.prototype, \"autoTransitionRange\", {\r\n /**\r\n * Gets a value indicating if the lowerRadiusTransitionRange and upperRadiusTransitionRange are defined automatically\r\n */\r\n get: function () {\r\n return this._autoTransitionRange;\r\n },\r\n /**\r\n * Sets a value indicating if the lowerRadiusTransitionRange and upperRadiusTransitionRange are defined automatically\r\n * Transition ranges will be set to 5% of the bounding box diagonal in world space\r\n */\r\n set: function (value) {\r\n var _this = this;\r\n if (this._autoTransitionRange === value) {\r\n return;\r\n }\r\n this._autoTransitionRange = value;\r\n var camera = this._attachedCamera;\r\n if (!camera) {\r\n return;\r\n }\r\n if (value) {\r\n this._onMeshTargetChangedObserver = camera.onMeshTargetChangedObservable.add(function (mesh) {\r\n if (!mesh) {\r\n return;\r\n }\r\n mesh.computeWorldMatrix(true);\r\n var diagonal = mesh.getBoundingInfo().diagonalLength;\r\n _this.lowerRadiusTransitionRange = diagonal * 0.05;\r\n _this.upperRadiusTransitionRange = diagonal * 0.05;\r\n });\r\n }\r\n else if (this._onMeshTargetChangedObserver) {\r\n camera.onMeshTargetChangedObservable.remove(this._onMeshTargetChangedObserver);\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Initializes the behavior.\r\n */\r\n BouncingBehavior.prototype.init = function () {\r\n // Do notihng\r\n };\r\n /**\r\n * Attaches the behavior to its arc rotate camera.\r\n * @param camera Defines the camera to attach the behavior to\r\n */\r\n BouncingBehavior.prototype.attach = function (camera) {\r\n var _this = this;\r\n this._attachedCamera = camera;\r\n this._onAfterCheckInputsObserver = camera.onAfterCheckInputsObservable.add(function () {\r\n if (!_this._attachedCamera) {\r\n return;\r\n }\r\n // Add the bounce animation to the lower radius limit\r\n if (_this._isRadiusAtLimit(_this._attachedCamera.lowerRadiusLimit)) {\r\n _this._applyBoundRadiusAnimation(_this.lowerRadiusTransitionRange);\r\n }\r\n // Add the bounce animation to the upper radius limit\r\n if (_this._isRadiusAtLimit(_this._attachedCamera.upperRadiusLimit)) {\r\n _this._applyBoundRadiusAnimation(_this.upperRadiusTransitionRange);\r\n }\r\n });\r\n };\r\n /**\r\n * Detaches the behavior from its current arc rotate camera.\r\n */\r\n BouncingBehavior.prototype.detach = function () {\r\n if (!this._attachedCamera) {\r\n return;\r\n }\r\n if (this._onAfterCheckInputsObserver) {\r\n this._attachedCamera.onAfterCheckInputsObservable.remove(this._onAfterCheckInputsObserver);\r\n }\r\n if (this._onMeshTargetChangedObserver) {\r\n this._attachedCamera.onMeshTargetChangedObservable.remove(this._onMeshTargetChangedObserver);\r\n }\r\n this._attachedCamera = null;\r\n };\r\n /**\r\n * Checks if the camera radius is at the specified limit. Takes into account animation locks.\r\n * @param radiusLimit The limit to check against.\r\n * @return Bool to indicate if at limit.\r\n */\r\n BouncingBehavior.prototype._isRadiusAtLimit = function (radiusLimit) {\r\n if (!this._attachedCamera) {\r\n return false;\r\n }\r\n if (this._attachedCamera.radius === radiusLimit && !this._radiusIsAnimating) {\r\n return true;\r\n }\r\n return false;\r\n };\r\n /**\r\n * Applies an animation to the radius of the camera, extending by the radiusDelta.\r\n * @param radiusDelta The delta by which to animate to. Can be negative.\r\n */\r\n BouncingBehavior.prototype._applyBoundRadiusAnimation = function (radiusDelta) {\r\n var _this = this;\r\n if (!this._attachedCamera) {\r\n return;\r\n }\r\n if (!this._radiusBounceTransition) {\r\n BouncingBehavior.EasingFunction.setEasingMode(BouncingBehavior.EasingMode);\r\n this._radiusBounceTransition = Animation.CreateAnimation(\"radius\", Animation.ANIMATIONTYPE_FLOAT, 60, BouncingBehavior.EasingFunction);\r\n }\r\n // Prevent zoom until bounce has completed\r\n this._cachedWheelPrecision = this._attachedCamera.wheelPrecision;\r\n this._attachedCamera.wheelPrecision = Infinity;\r\n this._attachedCamera.inertialRadiusOffset = 0;\r\n // Animate to the radius limit\r\n this.stopAllAnimations();\r\n this._radiusIsAnimating = true;\r\n var animatable = Animation.TransitionTo(\"radius\", this._attachedCamera.radius + radiusDelta, this._attachedCamera, this._attachedCamera.getScene(), 60, this._radiusBounceTransition, this.transitionDuration, function () { return _this._clearAnimationLocks(); });\r\n if (animatable) {\r\n this._animatables.push(animatable);\r\n }\r\n };\r\n /**\r\n * Removes all animation locks. Allows new animations to be added to any of the camera properties.\r\n */\r\n BouncingBehavior.prototype._clearAnimationLocks = function () {\r\n this._radiusIsAnimating = false;\r\n if (this._attachedCamera) {\r\n this._attachedCamera.wheelPrecision = this._cachedWheelPrecision;\r\n }\r\n };\r\n /**\r\n * Stops and removes all animations that have been applied to the camera\r\n */\r\n BouncingBehavior.prototype.stopAllAnimations = function () {\r\n if (this._attachedCamera) {\r\n this._attachedCamera.animations = [];\r\n }\r\n while (this._animatables.length) {\r\n this._animatables[0].onAnimationEnd = null;\r\n this._animatables[0].stop();\r\n this._animatables.shift();\r\n }\r\n };\r\n /**\r\n * The easing function used by animations\r\n */\r\n BouncingBehavior.EasingFunction = new BackEase(0.3);\r\n /**\r\n * The easing mode used by animations\r\n */\r\n BouncingBehavior.EasingMode = EasingFunction.EASINGMODE_EASEOUT;\r\n return BouncingBehavior;\r\n}());\r\nexport { BouncingBehavior };\r\n//# sourceMappingURL=bouncingBehavior.js.map","import { ExponentialEase, EasingFunction } from \"../../Animations/easing\";\r\nimport { PointerEventTypes } from \"../../Events/pointerEvents\";\r\nimport { PrecisionDate } from \"../../Misc/precisionDate\";\r\nimport { Vector3, Vector2 } from \"../../Maths/math.vector\";\r\nimport { Animation } from \"../../Animations/animation\";\r\n/**\r\n * The framing behavior (FramingBehavior) is designed to automatically position an ArcRotateCamera when its target is set to a mesh. It is also useful if you want to prevent the camera to go under a virtual horizontal plane.\r\n * @see https://doc.babylonjs.com/how_to/camera_behaviors#framing-behavior\r\n */\r\nvar FramingBehavior = /** @class */ (function () {\r\n function FramingBehavior() {\r\n this._mode = FramingBehavior.FitFrustumSidesMode;\r\n this._radiusScale = 1.0;\r\n this._positionScale = 0.5;\r\n this._defaultElevation = 0.3;\r\n this._elevationReturnTime = 1500;\r\n this._elevationReturnWaitTime = 1000;\r\n this._zoomStopsAnimation = false;\r\n this._framingTime = 1500;\r\n /**\r\n * Define if the behavior should automatically change the configured\r\n * camera limits and sensibilities.\r\n */\r\n this.autoCorrectCameraLimitsAndSensibility = true;\r\n this._isPointerDown = false;\r\n this._lastInteractionTime = -Infinity;\r\n // Framing control\r\n this._animatables = new Array();\r\n this._betaIsAnimating = false;\r\n }\r\n Object.defineProperty(FramingBehavior.prototype, \"name\", {\r\n /**\r\n * Gets the name of the behavior.\r\n */\r\n get: function () {\r\n return \"Framing\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(FramingBehavior.prototype, \"mode\", {\r\n /**\r\n * Gets current mode used by the behavior.\r\n */\r\n get: function () {\r\n return this._mode;\r\n },\r\n /**\r\n * Sets the current mode used by the behavior\r\n */\r\n set: function (mode) {\r\n this._mode = mode;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(FramingBehavior.prototype, \"radiusScale\", {\r\n /**\r\n * Gets the scale applied to the radius\r\n */\r\n get: function () {\r\n return this._radiusScale;\r\n },\r\n /**\r\n * Sets the scale applied to the radius (1 by default)\r\n */\r\n set: function (radius) {\r\n this._radiusScale = radius;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(FramingBehavior.prototype, \"positionScale\", {\r\n /**\r\n * Gets the scale to apply on Y axis to position camera focus. 0.5 by default which means the center of the bounding box.\r\n */\r\n get: function () {\r\n return this._positionScale;\r\n },\r\n /**\r\n * Sets the scale to apply on Y axis to position camera focus. 0.5 by default which means the center of the bounding box.\r\n */\r\n set: function (scale) {\r\n this._positionScale = scale;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(FramingBehavior.prototype, \"defaultElevation\", {\r\n /**\r\n * Gets the angle above/below the horizontal plane to return to when the return to default elevation idle\r\n * behaviour is triggered, in radians.\r\n */\r\n get: function () {\r\n return this._defaultElevation;\r\n },\r\n /**\r\n * Sets the angle above/below the horizontal plane to return to when the return to default elevation idle\r\n * behaviour is triggered, in radians.\r\n */\r\n set: function (elevation) {\r\n this._defaultElevation = elevation;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(FramingBehavior.prototype, \"elevationReturnTime\", {\r\n /**\r\n * Gets the time (in milliseconds) taken to return to the default beta position.\r\n * Negative value indicates camera should not return to default.\r\n */\r\n get: function () {\r\n return this._elevationReturnTime;\r\n },\r\n /**\r\n * Sets the time (in milliseconds) taken to return to the default beta position.\r\n * Negative value indicates camera should not return to default.\r\n */\r\n set: function (speed) {\r\n this._elevationReturnTime = speed;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(FramingBehavior.prototype, \"elevationReturnWaitTime\", {\r\n /**\r\n * Gets the delay (in milliseconds) taken before the camera returns to the default beta position.\r\n */\r\n get: function () {\r\n return this._elevationReturnWaitTime;\r\n },\r\n /**\r\n * Sets the delay (in milliseconds) taken before the camera returns to the default beta position.\r\n */\r\n set: function (time) {\r\n this._elevationReturnWaitTime = time;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(FramingBehavior.prototype, \"zoomStopsAnimation\", {\r\n /**\r\n * Gets the flag that indicates if user zooming should stop animation.\r\n */\r\n get: function () {\r\n return this._zoomStopsAnimation;\r\n },\r\n /**\r\n * Sets the flag that indicates if user zooming should stop animation.\r\n */\r\n set: function (flag) {\r\n this._zoomStopsAnimation = flag;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(FramingBehavior.prototype, \"framingTime\", {\r\n /**\r\n * Gets the transition time when framing the mesh, in milliseconds\r\n */\r\n get: function () {\r\n return this._framingTime;\r\n },\r\n /**\r\n * Sets the transition time when framing the mesh, in milliseconds\r\n */\r\n set: function (time) {\r\n this._framingTime = time;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Initializes the behavior.\r\n */\r\n FramingBehavior.prototype.init = function () {\r\n // Do notihng\r\n };\r\n /**\r\n * Attaches the behavior to its arc rotate camera.\r\n * @param camera Defines the camera to attach the behavior to\r\n */\r\n FramingBehavior.prototype.attach = function (camera) {\r\n var _this = this;\r\n this._attachedCamera = camera;\r\n var scene = this._attachedCamera.getScene();\r\n FramingBehavior.EasingFunction.setEasingMode(FramingBehavior.EasingMode);\r\n this._onPrePointerObservableObserver = scene.onPrePointerObservable.add(function (pointerInfoPre) {\r\n if (pointerInfoPre.type === PointerEventTypes.POINTERDOWN) {\r\n _this._isPointerDown = true;\r\n return;\r\n }\r\n if (pointerInfoPre.type === PointerEventTypes.POINTERUP) {\r\n _this._isPointerDown = false;\r\n }\r\n });\r\n this._onMeshTargetChangedObserver = camera.onMeshTargetChangedObservable.add(function (mesh) {\r\n if (mesh) {\r\n _this.zoomOnMesh(mesh);\r\n }\r\n });\r\n this._onAfterCheckInputsObserver = camera.onAfterCheckInputsObservable.add(function () {\r\n // Stop the animation if there is user interaction and the animation should stop for this interaction\r\n _this._applyUserInteraction();\r\n // Maintain the camera above the ground. If the user pulls the camera beneath the ground plane, lift it\r\n // back to the default position after a given timeout\r\n _this._maintainCameraAboveGround();\r\n });\r\n };\r\n /**\r\n * Detaches the behavior from its current arc rotate camera.\r\n */\r\n FramingBehavior.prototype.detach = function () {\r\n if (!this._attachedCamera) {\r\n return;\r\n }\r\n var scene = this._attachedCamera.getScene();\r\n if (this._onPrePointerObservableObserver) {\r\n scene.onPrePointerObservable.remove(this._onPrePointerObservableObserver);\r\n }\r\n if (this._onAfterCheckInputsObserver) {\r\n this._attachedCamera.onAfterCheckInputsObservable.remove(this._onAfterCheckInputsObserver);\r\n }\r\n if (this._onMeshTargetChangedObserver) {\r\n this._attachedCamera.onMeshTargetChangedObservable.remove(this._onMeshTargetChangedObserver);\r\n }\r\n this._attachedCamera = null;\r\n };\r\n /**\r\n * Targets the given mesh and updates zoom level accordingly.\r\n * @param mesh The mesh to target.\r\n * @param focusOnOriginXZ Determines if the camera should focus on 0 in the X and Z axis instead of the mesh\r\n * @param onAnimationEnd Callback triggered at the end of the framing animation\r\n */\r\n FramingBehavior.prototype.zoomOnMesh = function (mesh, focusOnOriginXZ, onAnimationEnd) {\r\n if (focusOnOriginXZ === void 0) { focusOnOriginXZ = false; }\r\n if (onAnimationEnd === void 0) { onAnimationEnd = null; }\r\n mesh.computeWorldMatrix(true);\r\n var boundingBox = mesh.getBoundingInfo().boundingBox;\r\n this.zoomOnBoundingInfo(boundingBox.minimumWorld, boundingBox.maximumWorld, focusOnOriginXZ, onAnimationEnd);\r\n };\r\n /**\r\n * Targets the given mesh with its children and updates zoom level accordingly.\r\n * @param mesh The mesh to target.\r\n * @param focusOnOriginXZ Determines if the camera should focus on 0 in the X and Z axis instead of the mesh\r\n * @param onAnimationEnd Callback triggered at the end of the framing animation\r\n */\r\n FramingBehavior.prototype.zoomOnMeshHierarchy = function (mesh, focusOnOriginXZ, onAnimationEnd) {\r\n if (focusOnOriginXZ === void 0) { focusOnOriginXZ = false; }\r\n if (onAnimationEnd === void 0) { onAnimationEnd = null; }\r\n mesh.computeWorldMatrix(true);\r\n var boundingBox = mesh.getHierarchyBoundingVectors(true);\r\n this.zoomOnBoundingInfo(boundingBox.min, boundingBox.max, focusOnOriginXZ, onAnimationEnd);\r\n };\r\n /**\r\n * Targets the given meshes with their children and updates zoom level accordingly.\r\n * @param meshes The mesh to target.\r\n * @param focusOnOriginXZ Determines if the camera should focus on 0 in the X and Z axis instead of the mesh\r\n * @param onAnimationEnd Callback triggered at the end of the framing animation\r\n */\r\n FramingBehavior.prototype.zoomOnMeshesHierarchy = function (meshes, focusOnOriginXZ, onAnimationEnd) {\r\n if (focusOnOriginXZ === void 0) { focusOnOriginXZ = false; }\r\n if (onAnimationEnd === void 0) { onAnimationEnd = null; }\r\n var min = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n var max = new Vector3(-Number.MAX_VALUE, -Number.MAX_VALUE, -Number.MAX_VALUE);\r\n for (var i = 0; i < meshes.length; i++) {\r\n var boundingInfo = meshes[i].getHierarchyBoundingVectors(true);\r\n Vector3.CheckExtends(boundingInfo.min, min, max);\r\n Vector3.CheckExtends(boundingInfo.max, min, max);\r\n }\r\n this.zoomOnBoundingInfo(min, max, focusOnOriginXZ, onAnimationEnd);\r\n };\r\n /**\r\n * Targets the bounding box info defined by its extends and updates zoom level accordingly.\r\n * @param minimumWorld Determines the smaller position of the bounding box extend\r\n * @param maximumWorld Determines the bigger position of the bounding box extend\r\n * @param focusOnOriginXZ Determines if the camera should focus on 0 in the X and Z axis instead of the mesh\r\n * @param onAnimationEnd Callback triggered at the end of the framing animation\r\n */\r\n FramingBehavior.prototype.zoomOnBoundingInfo = function (minimumWorld, maximumWorld, focusOnOriginXZ, onAnimationEnd) {\r\n var _this = this;\r\n if (focusOnOriginXZ === void 0) { focusOnOriginXZ = false; }\r\n if (onAnimationEnd === void 0) { onAnimationEnd = null; }\r\n var zoomTarget;\r\n if (!this._attachedCamera) {\r\n return;\r\n }\r\n // Find target by interpolating from bottom of bounding box in world-space to top via framingPositionY\r\n var bottom = minimumWorld.y;\r\n var top = maximumWorld.y;\r\n var zoomTargetY = bottom + (top - bottom) * this._positionScale;\r\n var radiusWorld = maximumWorld.subtract(minimumWorld).scale(0.5);\r\n if (focusOnOriginXZ) {\r\n zoomTarget = new Vector3(0, zoomTargetY, 0);\r\n }\r\n else {\r\n var centerWorld = minimumWorld.add(radiusWorld);\r\n zoomTarget = new Vector3(centerWorld.x, zoomTargetY, centerWorld.z);\r\n }\r\n if (!this._vectorTransition) {\r\n this._vectorTransition = Animation.CreateAnimation(\"target\", Animation.ANIMATIONTYPE_VECTOR3, 60, FramingBehavior.EasingFunction);\r\n }\r\n this._betaIsAnimating = true;\r\n var animatable = Animation.TransitionTo(\"target\", zoomTarget, this._attachedCamera, this._attachedCamera.getScene(), 60, this._vectorTransition, this._framingTime);\r\n if (animatable) {\r\n this._animatables.push(animatable);\r\n }\r\n // sets the radius and lower radius bounds\r\n // Small delta ensures camera is not always at lower zoom limit.\r\n var radius = 0;\r\n if (this._mode === FramingBehavior.FitFrustumSidesMode) {\r\n var position = this._calculateLowerRadiusFromModelBoundingSphere(minimumWorld, maximumWorld);\r\n if (this.autoCorrectCameraLimitsAndSensibility) {\r\n this._attachedCamera.lowerRadiusLimit = radiusWorld.length() + this._attachedCamera.minZ;\r\n }\r\n radius = position;\r\n }\r\n else if (this._mode === FramingBehavior.IgnoreBoundsSizeMode) {\r\n radius = this._calculateLowerRadiusFromModelBoundingSphere(minimumWorld, maximumWorld);\r\n if (this.autoCorrectCameraLimitsAndSensibility && this._attachedCamera.lowerRadiusLimit === null) {\r\n this._attachedCamera.lowerRadiusLimit = this._attachedCamera.minZ;\r\n }\r\n }\r\n // Set sensibilities\r\n if (this.autoCorrectCameraLimitsAndSensibility) {\r\n var extend = maximumWorld.subtract(minimumWorld).length();\r\n this._attachedCamera.panningSensibility = 5000 / extend;\r\n this._attachedCamera.wheelPrecision = 100 / radius;\r\n }\r\n // transition to new radius\r\n if (!this._radiusTransition) {\r\n this._radiusTransition = Animation.CreateAnimation(\"radius\", Animation.ANIMATIONTYPE_FLOAT, 60, FramingBehavior.EasingFunction);\r\n }\r\n animatable = Animation.TransitionTo(\"radius\", radius, this._attachedCamera, this._attachedCamera.getScene(), 60, this._radiusTransition, this._framingTime, function () {\r\n _this.stopAllAnimations();\r\n if (onAnimationEnd) {\r\n onAnimationEnd();\r\n }\r\n if (_this._attachedCamera && _this._attachedCamera.useInputToRestoreState) {\r\n _this._attachedCamera.storeState();\r\n }\r\n });\r\n if (animatable) {\r\n this._animatables.push(animatable);\r\n }\r\n };\r\n /**\r\n * Calculates the lowest radius for the camera based on the bounding box of the mesh.\r\n * @param mesh The mesh on which to base the calculation. mesh boundingInfo used to estimate necessary\r\n *\t\t\t frustum width.\r\n * @return The minimum distance from the primary mesh's center point at which the camera must be kept in order\r\n *\t\t to fully enclose the mesh in the viewing frustum.\r\n */\r\n FramingBehavior.prototype._calculateLowerRadiusFromModelBoundingSphere = function (minimumWorld, maximumWorld) {\r\n var size = maximumWorld.subtract(minimumWorld);\r\n var boxVectorGlobalDiagonal = size.length();\r\n var frustumSlope = this._getFrustumSlope();\r\n // Formula for setting distance\r\n // (Good explanation: http://stackoverflow.com/questions/2866350/move-camera-to-fit-3d-scene)\r\n var radiusWithoutFraming = boxVectorGlobalDiagonal * 0.5;\r\n // Horizon distance\r\n var radius = radiusWithoutFraming * this._radiusScale;\r\n var distanceForHorizontalFrustum = radius * Math.sqrt(1.0 + 1.0 / (frustumSlope.x * frustumSlope.x));\r\n var distanceForVerticalFrustum = radius * Math.sqrt(1.0 + 1.0 / (frustumSlope.y * frustumSlope.y));\r\n var distance = Math.max(distanceForHorizontalFrustum, distanceForVerticalFrustum);\r\n var camera = this._attachedCamera;\r\n if (!camera) {\r\n return 0;\r\n }\r\n if (camera.lowerRadiusLimit && this._mode === FramingBehavior.IgnoreBoundsSizeMode) {\r\n // Don't exceed the requested limit\r\n distance = distance < camera.lowerRadiusLimit ? camera.lowerRadiusLimit : distance;\r\n }\r\n // Don't exceed the upper radius limit\r\n if (camera.upperRadiusLimit) {\r\n distance = distance > camera.upperRadiusLimit ? camera.upperRadiusLimit : distance;\r\n }\r\n return distance;\r\n };\r\n /**\r\n * Keeps the camera above the ground plane. If the user pulls the camera below the ground plane, the camera\r\n * is automatically returned to its default position (expected to be above ground plane).\r\n */\r\n FramingBehavior.prototype._maintainCameraAboveGround = function () {\r\n var _this = this;\r\n if (this._elevationReturnTime < 0) {\r\n return;\r\n }\r\n var timeSinceInteraction = PrecisionDate.Now - this._lastInteractionTime;\r\n var defaultBeta = Math.PI * 0.5 - this._defaultElevation;\r\n var limitBeta = Math.PI * 0.5;\r\n // Bring the camera back up if below the ground plane\r\n if (this._attachedCamera && !this._betaIsAnimating && this._attachedCamera.beta > limitBeta && timeSinceInteraction >= this._elevationReturnWaitTime) {\r\n this._betaIsAnimating = true;\r\n //Transition to new position\r\n this.stopAllAnimations();\r\n if (!this._betaTransition) {\r\n this._betaTransition = Animation.CreateAnimation(\"beta\", Animation.ANIMATIONTYPE_FLOAT, 60, FramingBehavior.EasingFunction);\r\n }\r\n var animatabe = Animation.TransitionTo(\"beta\", defaultBeta, this._attachedCamera, this._attachedCamera.getScene(), 60, this._betaTransition, this._elevationReturnTime, function () {\r\n _this._clearAnimationLocks();\r\n _this.stopAllAnimations();\r\n });\r\n if (animatabe) {\r\n this._animatables.push(animatabe);\r\n }\r\n }\r\n };\r\n /**\r\n * Returns the frustum slope based on the canvas ratio and camera FOV\r\n * @returns The frustum slope represented as a Vector2 with X and Y slopes\r\n */\r\n FramingBehavior.prototype._getFrustumSlope = function () {\r\n // Calculate the viewport ratio\r\n // Aspect Ratio is Height/Width.\r\n var camera = this._attachedCamera;\r\n if (!camera) {\r\n return Vector2.Zero();\r\n }\r\n var engine = camera.getScene().getEngine();\r\n var aspectRatio = engine.getAspectRatio(camera);\r\n // Camera FOV is the vertical field of view (top-bottom) in radians.\r\n // Slope of the frustum top/bottom planes in view space, relative to the forward vector.\r\n var frustumSlopeY = Math.tan(camera.fov / 2);\r\n // Slope of the frustum left/right planes in view space, relative to the forward vector.\r\n // Provides the amount that one side (e.g. left) of the frustum gets wider for every unit\r\n // along the forward vector.\r\n var frustumSlopeX = frustumSlopeY * aspectRatio;\r\n return new Vector2(frustumSlopeX, frustumSlopeY);\r\n };\r\n /**\r\n * Removes all animation locks. Allows new animations to be added to any of the arcCamera properties.\r\n */\r\n FramingBehavior.prototype._clearAnimationLocks = function () {\r\n this._betaIsAnimating = false;\r\n };\r\n /**\r\n * Applies any current user interaction to the camera. Takes into account maximum alpha rotation.\r\n */\r\n FramingBehavior.prototype._applyUserInteraction = function () {\r\n if (this.isUserIsMoving) {\r\n this._lastInteractionTime = PrecisionDate.Now;\r\n this.stopAllAnimations();\r\n this._clearAnimationLocks();\r\n }\r\n };\r\n /**\r\n * Stops and removes all animations that have been applied to the camera\r\n */\r\n FramingBehavior.prototype.stopAllAnimations = function () {\r\n if (this._attachedCamera) {\r\n this._attachedCamera.animations = [];\r\n }\r\n while (this._animatables.length) {\r\n if (this._animatables[0]) {\r\n this._animatables[0].onAnimationEnd = null;\r\n this._animatables[0].stop();\r\n }\r\n this._animatables.shift();\r\n }\r\n };\r\n Object.defineProperty(FramingBehavior.prototype, \"isUserIsMoving\", {\r\n /**\r\n * Gets a value indicating if the user is moving the camera\r\n */\r\n get: function () {\r\n if (!this._attachedCamera) {\r\n return false;\r\n }\r\n return this._attachedCamera.inertialAlphaOffset !== 0 ||\r\n this._attachedCamera.inertialBetaOffset !== 0 ||\r\n this._attachedCamera.inertialRadiusOffset !== 0 ||\r\n this._attachedCamera.inertialPanningX !== 0 ||\r\n this._attachedCamera.inertialPanningY !== 0 ||\r\n this._isPointerDown;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * The easing function used by animations\r\n */\r\n FramingBehavior.EasingFunction = new ExponentialEase();\r\n /**\r\n * The easing mode used by animations\r\n */\r\n FramingBehavior.EasingMode = EasingFunction.EASINGMODE_EASEINOUT;\r\n // Statics\r\n /**\r\n * The camera can move all the way towards the mesh.\r\n */\r\n FramingBehavior.IgnoreBoundsSizeMode = 0;\r\n /**\r\n * The camera is not allowed to zoom closer to the mesh than the point at which the adjusted bounding sphere touches the frustum sides\r\n */\r\n FramingBehavior.FitFrustumSidesMode = 1;\r\n return FramingBehavior;\r\n}());\r\nexport { FramingBehavior };\r\n//# sourceMappingURL=framingBehavior.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, serializeAsVector3, serializeAsMeshReference } from \"../Misc/decorators\";\r\nimport { Camera } from \"./camera\";\r\nimport { Quaternion, Matrix, Vector3, Vector2, TmpVectors } from \"../Maths/math.vector\";\r\nimport { Epsilon } from '../Maths/math.constants';\r\nimport { Axis } from '../Maths/math.axis';\r\n/**\r\n * A target camera takes a mesh or position as a target and continues to look at it while it moves.\r\n * This is the base of the follow, arc rotate cameras and Free camera\r\n * @see https://doc.babylonjs.com/features/cameras\r\n */\r\nvar TargetCamera = /** @class */ (function (_super) {\r\n __extends(TargetCamera, _super);\r\n /**\r\n * Instantiates a target camera that takes a mesh or position as a target and continues to look at it while it moves.\r\n * This is the base of the follow, arc rotate cameras and Free camera\r\n * @see https://doc.babylonjs.com/features/cameras\r\n * @param name Defines the name of the camera in the scene\r\n * @param position Defines the start position of the camera in the scene\r\n * @param scene Defines the scene the camera belongs to\r\n * @param setActiveOnSceneIfNoneActive Defines wheter the camera should be marked as active if not other active cameras have been defined\r\n */\r\n function TargetCamera(name, position, scene, setActiveOnSceneIfNoneActive) {\r\n if (setActiveOnSceneIfNoneActive === void 0) { setActiveOnSceneIfNoneActive = true; }\r\n var _this = _super.call(this, name, position, scene, setActiveOnSceneIfNoneActive) || this;\r\n _this._tmpUpVector = Vector3.Zero();\r\n _this._tmpTargetVector = Vector3.Zero();\r\n /**\r\n * Define the current direction the camera is moving to\r\n */\r\n _this.cameraDirection = new Vector3(0, 0, 0);\r\n /**\r\n * Define the current rotation the camera is rotating to\r\n */\r\n _this.cameraRotation = new Vector2(0, 0);\r\n /** Gets or sets a boolean indicating that the scaling of the parent hierarchy will not be taken in account by the camera */\r\n _this.ignoreParentScaling = false;\r\n /**\r\n * When set, the up vector of the camera will be updated by the rotation of the camera\r\n */\r\n _this.updateUpVectorFromRotation = false;\r\n _this._tmpQuaternion = new Quaternion();\r\n /**\r\n * Define the current rotation of the camera\r\n */\r\n _this.rotation = new Vector3(0, 0, 0);\r\n /**\r\n * Define the current speed of the camera\r\n */\r\n _this.speed = 2.0;\r\n /**\r\n * Add constraint to the camera to prevent it to move freely in all directions and\r\n * around all axis.\r\n */\r\n _this.noRotationConstraint = false;\r\n /**\r\n * Reverses mouselook direction to 'natural' panning as opposed to traditional direct\r\n * panning\r\n */\r\n _this.invertRotation = false;\r\n /**\r\n * Speed multiplier for inverse camera panning\r\n */\r\n _this.inverseRotationSpeed = 0.2;\r\n /**\r\n * Define the current target of the camera as an object or a position.\r\n */\r\n _this.lockedTarget = null;\r\n /** @hidden */\r\n _this._currentTarget = Vector3.Zero();\r\n /** @hidden */\r\n _this._initialFocalDistance = 1;\r\n /** @hidden */\r\n _this._viewMatrix = Matrix.Zero();\r\n /** @hidden */\r\n _this._camMatrix = Matrix.Zero();\r\n /** @hidden */\r\n _this._cameraTransformMatrix = Matrix.Zero();\r\n /** @hidden */\r\n _this._cameraRotationMatrix = Matrix.Zero();\r\n /** @hidden */\r\n _this._referencePoint = new Vector3(0, 0, 1);\r\n /** @hidden */\r\n _this._transformedReferencePoint = Vector3.Zero();\r\n _this._defaultUp = Vector3.Up();\r\n _this._cachedRotationZ = 0;\r\n _this._cachedQuaternionRotationZ = 0;\r\n return _this;\r\n }\r\n /**\r\n * Gets the position in front of the camera at a given distance.\r\n * @param distance The distance from the camera we want the position to be\r\n * @returns the position\r\n */\r\n TargetCamera.prototype.getFrontPosition = function (distance) {\r\n this.getWorldMatrix();\r\n var direction = this.getTarget().subtract(this.position);\r\n direction.normalize();\r\n direction.scaleInPlace(distance);\r\n return this.globalPosition.add(direction);\r\n };\r\n /** @hidden */\r\n TargetCamera.prototype._getLockedTargetPosition = function () {\r\n if (!this.lockedTarget) {\r\n return null;\r\n }\r\n if (this.lockedTarget.absolutePosition) {\r\n this.lockedTarget.computeWorldMatrix();\r\n }\r\n return this.lockedTarget.absolutePosition || this.lockedTarget;\r\n };\r\n /**\r\n * Store current camera state of the camera (fov, position, rotation, etc..)\r\n * @returns the camera\r\n */\r\n TargetCamera.prototype.storeState = function () {\r\n this._storedPosition = this.position.clone();\r\n this._storedRotation = this.rotation.clone();\r\n if (this.rotationQuaternion) {\r\n this._storedRotationQuaternion = this.rotationQuaternion.clone();\r\n }\r\n return _super.prototype.storeState.call(this);\r\n };\r\n /**\r\n * Restored camera state. You must call storeState() first\r\n * @returns whether it was successful or not\r\n * @hidden\r\n */\r\n TargetCamera.prototype._restoreStateValues = function () {\r\n if (!_super.prototype._restoreStateValues.call(this)) {\r\n return false;\r\n }\r\n this.position = this._storedPosition.clone();\r\n this.rotation = this._storedRotation.clone();\r\n if (this.rotationQuaternion) {\r\n this.rotationQuaternion = this._storedRotationQuaternion.clone();\r\n }\r\n this.cameraDirection.copyFromFloats(0, 0, 0);\r\n this.cameraRotation.copyFromFloats(0, 0);\r\n return true;\r\n };\r\n /** @hidden */\r\n TargetCamera.prototype._initCache = function () {\r\n _super.prototype._initCache.call(this);\r\n this._cache.lockedTarget = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n this._cache.rotation = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n this._cache.rotationQuaternion = new Quaternion(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n };\r\n /** @hidden */\r\n TargetCamera.prototype._updateCache = function (ignoreParentClass) {\r\n if (!ignoreParentClass) {\r\n _super.prototype._updateCache.call(this);\r\n }\r\n var lockedTargetPosition = this._getLockedTargetPosition();\r\n if (!lockedTargetPosition) {\r\n this._cache.lockedTarget = null;\r\n }\r\n else {\r\n if (!this._cache.lockedTarget) {\r\n this._cache.lockedTarget = lockedTargetPosition.clone();\r\n }\r\n else {\r\n this._cache.lockedTarget.copyFrom(lockedTargetPosition);\r\n }\r\n }\r\n this._cache.rotation.copyFrom(this.rotation);\r\n if (this.rotationQuaternion) {\r\n this._cache.rotationQuaternion.copyFrom(this.rotationQuaternion);\r\n }\r\n };\r\n // Synchronized\r\n /** @hidden */\r\n TargetCamera.prototype._isSynchronizedViewMatrix = function () {\r\n if (!_super.prototype._isSynchronizedViewMatrix.call(this)) {\r\n return false;\r\n }\r\n var lockedTargetPosition = this._getLockedTargetPosition();\r\n return (this._cache.lockedTarget ? this._cache.lockedTarget.equals(lockedTargetPosition) : !lockedTargetPosition)\r\n && (this.rotationQuaternion ? this.rotationQuaternion.equals(this._cache.rotationQuaternion) : this._cache.rotation.equals(this.rotation));\r\n };\r\n // Methods\r\n /** @hidden */\r\n TargetCamera.prototype._computeLocalCameraSpeed = function () {\r\n var engine = this.getEngine();\r\n return this.speed * Math.sqrt((engine.getDeltaTime() / (engine.getFps() * 100.0)));\r\n };\r\n // Target\r\n /**\r\n * Defines the target the camera should look at.\r\n * @param target Defines the new target as a Vector or a mesh\r\n */\r\n TargetCamera.prototype.setTarget = function (target) {\r\n this.upVector.normalize();\r\n this._initialFocalDistance = target.subtract(this.position).length();\r\n if (this.position.z === target.z) {\r\n this.position.z += Epsilon;\r\n }\r\n this._referencePoint.normalize().scaleInPlace(this._initialFocalDistance);\r\n Matrix.LookAtLHToRef(this.position, target, this._defaultUp, this._camMatrix);\r\n this._camMatrix.invert();\r\n this.rotation.x = Math.atan(this._camMatrix.m[6] / this._camMatrix.m[10]);\r\n var vDir = target.subtract(this.position);\r\n if (vDir.x >= 0.0) {\r\n this.rotation.y = (-Math.atan(vDir.z / vDir.x) + Math.PI / 2.0);\r\n }\r\n else {\r\n this.rotation.y = (-Math.atan(vDir.z / vDir.x) - Math.PI / 2.0);\r\n }\r\n this.rotation.z = 0;\r\n if (isNaN(this.rotation.x)) {\r\n this.rotation.x = 0;\r\n }\r\n if (isNaN(this.rotation.y)) {\r\n this.rotation.y = 0;\r\n }\r\n if (isNaN(this.rotation.z)) {\r\n this.rotation.z = 0;\r\n }\r\n if (this.rotationQuaternion) {\r\n Quaternion.RotationYawPitchRollToRef(this.rotation.y, this.rotation.x, this.rotation.z, this.rotationQuaternion);\r\n }\r\n };\r\n Object.defineProperty(TargetCamera.prototype, \"target\", {\r\n /**\r\n * Defines the target point of the camera.\r\n * The camera looks towards it form the radius distance.\r\n */\r\n get: function () {\r\n return this.getTarget();\r\n },\r\n set: function (value) {\r\n this.setTarget(value);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Return the current target position of the camera. This value is expressed in local space.\r\n * @returns the target position\r\n */\r\n TargetCamera.prototype.getTarget = function () {\r\n return this._currentTarget;\r\n };\r\n /** @hidden */\r\n TargetCamera.prototype._decideIfNeedsToMove = function () {\r\n return Math.abs(this.cameraDirection.x) > 0 || Math.abs(this.cameraDirection.y) > 0 || Math.abs(this.cameraDirection.z) > 0;\r\n };\r\n /** @hidden */\r\n TargetCamera.prototype._updatePosition = function () {\r\n if (this.parent) {\r\n this.parent.getWorldMatrix().invertToRef(TmpVectors.Matrix[0]);\r\n Vector3.TransformNormalToRef(this.cameraDirection, TmpVectors.Matrix[0], TmpVectors.Vector3[0]);\r\n this.position.addInPlace(TmpVectors.Vector3[0]);\r\n return;\r\n }\r\n this.position.addInPlace(this.cameraDirection);\r\n };\r\n /** @hidden */\r\n TargetCamera.prototype._checkInputs = function () {\r\n var directionMultiplier = this.invertRotation ? -this.inverseRotationSpeed : 1.0;\r\n var needToMove = this._decideIfNeedsToMove();\r\n var needToRotate = Math.abs(this.cameraRotation.x) > 0 || Math.abs(this.cameraRotation.y) > 0;\r\n // Move\r\n if (needToMove) {\r\n this._updatePosition();\r\n }\r\n // Rotate\r\n if (needToRotate) {\r\n //rotate, if quaternion is set and rotation was used\r\n if (this.rotationQuaternion) {\r\n this.rotationQuaternion.toEulerAnglesToRef(this.rotation);\r\n }\r\n this.rotation.x += this.cameraRotation.x * directionMultiplier;\r\n this.rotation.y += this.cameraRotation.y * directionMultiplier;\r\n // Apply constraints\r\n if (!this.noRotationConstraint) {\r\n var limit = 1.570796;\r\n if (this.rotation.x > limit) {\r\n this.rotation.x = limit;\r\n }\r\n if (this.rotation.x < -limit) {\r\n this.rotation.x = -limit;\r\n }\r\n }\r\n //rotate, if quaternion is set and rotation was used\r\n if (this.rotationQuaternion) {\r\n var len = this.rotation.lengthSquared();\r\n if (len) {\r\n Quaternion.RotationYawPitchRollToRef(this.rotation.y, this.rotation.x, this.rotation.z, this.rotationQuaternion);\r\n }\r\n }\r\n }\r\n // Inertia\r\n if (needToMove) {\r\n if (Math.abs(this.cameraDirection.x) < this.speed * Epsilon) {\r\n this.cameraDirection.x = 0;\r\n }\r\n if (Math.abs(this.cameraDirection.y) < this.speed * Epsilon) {\r\n this.cameraDirection.y = 0;\r\n }\r\n if (Math.abs(this.cameraDirection.z) < this.speed * Epsilon) {\r\n this.cameraDirection.z = 0;\r\n }\r\n this.cameraDirection.scaleInPlace(this.inertia);\r\n }\r\n if (needToRotate) {\r\n if (Math.abs(this.cameraRotation.x) < this.speed * Epsilon) {\r\n this.cameraRotation.x = 0;\r\n }\r\n if (Math.abs(this.cameraRotation.y) < this.speed * Epsilon) {\r\n this.cameraRotation.y = 0;\r\n }\r\n this.cameraRotation.scaleInPlace(this.inertia);\r\n }\r\n _super.prototype._checkInputs.call(this);\r\n };\r\n TargetCamera.prototype._updateCameraRotationMatrix = function () {\r\n if (this.rotationQuaternion) {\r\n this.rotationQuaternion.toRotationMatrix(this._cameraRotationMatrix);\r\n }\r\n else {\r\n Matrix.RotationYawPitchRollToRef(this.rotation.y, this.rotation.x, this.rotation.z, this._cameraRotationMatrix);\r\n }\r\n };\r\n /**\r\n * Update the up vector to apply the rotation of the camera (So if you changed the camera rotation.z this will let you update the up vector as well)\r\n * @returns the current camera\r\n */\r\n TargetCamera.prototype._rotateUpVectorWithCameraRotationMatrix = function () {\r\n Vector3.TransformNormalToRef(this._defaultUp, this._cameraRotationMatrix, this.upVector);\r\n return this;\r\n };\r\n /** @hidden */\r\n TargetCamera.prototype._getViewMatrix = function () {\r\n if (this.lockedTarget) {\r\n this.setTarget(this._getLockedTargetPosition());\r\n }\r\n // Compute\r\n this._updateCameraRotationMatrix();\r\n // Apply the changed rotation to the upVector\r\n if (this.rotationQuaternion && this._cachedQuaternionRotationZ != this.rotationQuaternion.z) {\r\n this._rotateUpVectorWithCameraRotationMatrix();\r\n this._cachedQuaternionRotationZ = this.rotationQuaternion.z;\r\n }\r\n else if (this._cachedRotationZ != this.rotation.z) {\r\n this._rotateUpVectorWithCameraRotationMatrix();\r\n this._cachedRotationZ = this.rotation.z;\r\n }\r\n Vector3.TransformCoordinatesToRef(this._referencePoint, this._cameraRotationMatrix, this._transformedReferencePoint);\r\n // Computing target and final matrix\r\n this.position.addToRef(this._transformedReferencePoint, this._currentTarget);\r\n if (this.updateUpVectorFromRotation) {\r\n if (this.rotationQuaternion) {\r\n Axis.Y.rotateByQuaternionToRef(this.rotationQuaternion, this.upVector);\r\n }\r\n else {\r\n Quaternion.FromEulerVectorToRef(this.rotation, this._tmpQuaternion);\r\n Axis.Y.rotateByQuaternionToRef(this._tmpQuaternion, this.upVector);\r\n }\r\n }\r\n this._computeViewMatrix(this.position, this._currentTarget, this.upVector);\r\n return this._viewMatrix;\r\n };\r\n TargetCamera.prototype._computeViewMatrix = function (position, target, up) {\r\n if (this.ignoreParentScaling) {\r\n if (this.parent) {\r\n var parentWorldMatrix = this.parent.getWorldMatrix();\r\n Vector3.TransformCoordinatesToRef(position, parentWorldMatrix, this._globalPosition);\r\n Vector3.TransformCoordinatesToRef(target, parentWorldMatrix, this._tmpTargetVector);\r\n Vector3.TransformNormalToRef(up, parentWorldMatrix, this._tmpUpVector);\r\n this._markSyncedWithParent();\r\n }\r\n else {\r\n this._globalPosition.copyFrom(position);\r\n this._tmpTargetVector.copyFrom(target);\r\n this._tmpUpVector.copyFrom(up);\r\n }\r\n if (this.getScene().useRightHandedSystem) {\r\n Matrix.LookAtRHToRef(this._globalPosition, this._tmpTargetVector, this._tmpUpVector, this._viewMatrix);\r\n }\r\n else {\r\n Matrix.LookAtLHToRef(this._globalPosition, this._tmpTargetVector, this._tmpUpVector, this._viewMatrix);\r\n }\r\n return;\r\n }\r\n if (this.getScene().useRightHandedSystem) {\r\n Matrix.LookAtRHToRef(position, target, up, this._viewMatrix);\r\n }\r\n else {\r\n Matrix.LookAtLHToRef(position, target, up, this._viewMatrix);\r\n }\r\n if (this.parent) {\r\n var parentWorldMatrix = this.parent.getWorldMatrix();\r\n this._viewMatrix.invert();\r\n this._viewMatrix.multiplyToRef(parentWorldMatrix, this._viewMatrix);\r\n this._viewMatrix.getTranslationToRef(this._globalPosition);\r\n this._viewMatrix.invert();\r\n this._markSyncedWithParent();\r\n }\r\n else {\r\n this._globalPosition.copyFrom(position);\r\n }\r\n };\r\n /**\r\n * @hidden\r\n */\r\n TargetCamera.prototype.createRigCamera = function (name, cameraIndex) {\r\n if (this.cameraRigMode !== Camera.RIG_MODE_NONE) {\r\n var rigCamera = new TargetCamera(name, this.position.clone(), this.getScene());\r\n rigCamera.isRigCamera = true;\r\n rigCamera.rigParent = this;\r\n if (this.cameraRigMode === Camera.RIG_MODE_VR || this.cameraRigMode === Camera.RIG_MODE_WEBVR) {\r\n if (!this.rotationQuaternion) {\r\n this.rotationQuaternion = new Quaternion();\r\n }\r\n rigCamera._cameraRigParams = {};\r\n rigCamera.rotationQuaternion = new Quaternion();\r\n }\r\n return rigCamera;\r\n }\r\n return null;\r\n };\r\n /**\r\n * @hidden\r\n */\r\n TargetCamera.prototype._updateRigCameras = function () {\r\n var camLeft = this._rigCameras[0];\r\n var camRight = this._rigCameras[1];\r\n this.computeWorldMatrix();\r\n switch (this.cameraRigMode) {\r\n case Camera.RIG_MODE_STEREOSCOPIC_ANAGLYPH:\r\n case Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL:\r\n case Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED:\r\n case Camera.RIG_MODE_STEREOSCOPIC_OVERUNDER:\r\n case Camera.RIG_MODE_STEREOSCOPIC_INTERLACED:\r\n //provisionnaly using _cameraRigParams.stereoHalfAngle instead of calculations based on _cameraRigParams.interaxialDistance:\r\n var leftSign = (this.cameraRigMode === Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED) ? 1 : -1;\r\n var rightSign = (this.cameraRigMode === Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED) ? -1 : 1;\r\n this._getRigCamPositionAndTarget(this._cameraRigParams.stereoHalfAngle * leftSign, camLeft);\r\n this._getRigCamPositionAndTarget(this._cameraRigParams.stereoHalfAngle * rightSign, camRight);\r\n break;\r\n case Camera.RIG_MODE_VR:\r\n if (camLeft.rotationQuaternion) {\r\n camLeft.rotationQuaternion.copyFrom(this.rotationQuaternion);\r\n camRight.rotationQuaternion.copyFrom(this.rotationQuaternion);\r\n }\r\n else {\r\n camLeft.rotation.copyFrom(this.rotation);\r\n camRight.rotation.copyFrom(this.rotation);\r\n }\r\n camLeft.position.copyFrom(this.position);\r\n camRight.position.copyFrom(this.position);\r\n break;\r\n }\r\n _super.prototype._updateRigCameras.call(this);\r\n };\r\n TargetCamera.prototype._getRigCamPositionAndTarget = function (halfSpace, rigCamera) {\r\n var target = this.getTarget();\r\n target.subtractToRef(this.position, TargetCamera._TargetFocalPoint);\r\n TargetCamera._TargetFocalPoint.normalize().scaleInPlace(this._initialFocalDistance);\r\n var newFocalTarget = TargetCamera._TargetFocalPoint.addInPlace(this.position);\r\n Matrix.TranslationToRef(-newFocalTarget.x, -newFocalTarget.y, -newFocalTarget.z, TargetCamera._TargetTransformMatrix);\r\n TargetCamera._TargetTransformMatrix.multiplyToRef(Matrix.RotationAxis(rigCamera.upVector, halfSpace), TargetCamera._RigCamTransformMatrix);\r\n Matrix.TranslationToRef(newFocalTarget.x, newFocalTarget.y, newFocalTarget.z, TargetCamera._TargetTransformMatrix);\r\n TargetCamera._RigCamTransformMatrix.multiplyToRef(TargetCamera._TargetTransformMatrix, TargetCamera._RigCamTransformMatrix);\r\n Vector3.TransformCoordinatesToRef(this.position, TargetCamera._RigCamTransformMatrix, rigCamera.position);\r\n rigCamera.setTarget(newFocalTarget);\r\n };\r\n /**\r\n * Gets the current object class name.\r\n * @return the class name\r\n */\r\n TargetCamera.prototype.getClassName = function () {\r\n return \"TargetCamera\";\r\n };\r\n TargetCamera._RigCamTransformMatrix = new Matrix();\r\n TargetCamera._TargetTransformMatrix = new Matrix();\r\n TargetCamera._TargetFocalPoint = new Vector3();\r\n __decorate([\r\n serializeAsVector3()\r\n ], TargetCamera.prototype, \"rotation\", void 0);\r\n __decorate([\r\n serialize()\r\n ], TargetCamera.prototype, \"speed\", void 0);\r\n __decorate([\r\n serializeAsMeshReference(\"lockedTargetId\")\r\n ], TargetCamera.prototype, \"lockedTarget\", void 0);\r\n return TargetCamera;\r\n}(Camera));\r\nexport { TargetCamera };\r\n//# sourceMappingURL=targetCamera.js.map","import { Logger } from \"../Misc/logger\";\r\nimport { SerializationHelper } from \"../Misc/decorators\";\r\nimport { Camera } from \"./camera\";\r\n/**\r\n * @ignore\r\n * This is a list of all the different input types that are available in the application.\r\n * Fo instance: ArcRotateCameraGamepadInput...\r\n */\r\nexport var CameraInputTypes = {};\r\n/**\r\n * This represents the input manager used within a camera.\r\n * It helps dealing with all the different kind of input attached to a camera.\r\n * @see https://doc.babylonjs.com/how_to/customizing_camera_inputs\r\n */\r\nvar CameraInputsManager = /** @class */ (function () {\r\n /**\r\n * Instantiate a new Camera Input Manager.\r\n * @param camera Defines the camera the input manager blongs to\r\n */\r\n function CameraInputsManager(camera) {\r\n /**\r\n * Defines the dom element the camera is collecting inputs from.\r\n * This is null if the controls have not been attached.\r\n */\r\n this.attachedToElement = false;\r\n this.attached = {};\r\n this.camera = camera;\r\n this.checkInputs = function () { };\r\n }\r\n /**\r\n * Add an input method to a camera\r\n * @see https://doc.babylonjs.com/how_to/customizing_camera_inputs\r\n * @param input camera input method\r\n */\r\n CameraInputsManager.prototype.add = function (input) {\r\n var type = input.getSimpleName();\r\n if (this.attached[type]) {\r\n Logger.Warn(\"camera input of type \" + type + \" already exists on camera\");\r\n return;\r\n }\r\n this.attached[type] = input;\r\n input.camera = this.camera;\r\n //for checkInputs, we are dynamically creating a function\r\n //the goal is to avoid the performance penalty of looping for inputs in the render loop\r\n if (input.checkInputs) {\r\n this.checkInputs = this._addCheckInputs(input.checkInputs.bind(input));\r\n }\r\n if (this.attachedToElement) {\r\n input.attachControl();\r\n }\r\n };\r\n /**\r\n * Remove a specific input method from a camera\r\n * example: camera.inputs.remove(camera.inputs.attached.mouse);\r\n * @param inputToRemove camera input method\r\n */\r\n CameraInputsManager.prototype.remove = function (inputToRemove) {\r\n for (var cam in this.attached) {\r\n var input = this.attached[cam];\r\n if (input === inputToRemove) {\r\n input.detachControl();\r\n input.camera = null;\r\n delete this.attached[cam];\r\n this.rebuildInputCheck();\r\n }\r\n }\r\n };\r\n /**\r\n * Remove a specific input type from a camera\r\n * example: camera.inputs.remove(\"ArcRotateCameraGamepadInput\");\r\n * @param inputType the type of the input to remove\r\n */\r\n CameraInputsManager.prototype.removeByType = function (inputType) {\r\n for (var cam in this.attached) {\r\n var input = this.attached[cam];\r\n if (input.getClassName() === inputType) {\r\n input.detachControl();\r\n input.camera = null;\r\n delete this.attached[cam];\r\n this.rebuildInputCheck();\r\n }\r\n }\r\n };\r\n CameraInputsManager.prototype._addCheckInputs = function (fn) {\r\n var current = this.checkInputs;\r\n return function () {\r\n current();\r\n fn();\r\n };\r\n };\r\n /**\r\n * Attach the input controls to the currently attached dom element to listen the events from.\r\n * @param input Defines the input to attach\r\n */\r\n CameraInputsManager.prototype.attachInput = function (input) {\r\n if (this.attachedToElement) {\r\n input.attachControl(this.noPreventDefault);\r\n }\r\n };\r\n /**\r\n * Attach the current manager inputs controls to a specific dom element to listen the events from.\r\n * @param element Defines the dom element to collect the events from\r\n * @param noPreventDefault Defines whether event caught by the controls should call preventdefault() (https://developer.mozilla.org/en-US/docs/Web/API/Event/preventDefault)\r\n */\r\n CameraInputsManager.prototype.attachElement = function (noPreventDefault) {\r\n if (noPreventDefault === void 0) { noPreventDefault = false; }\r\n if (this.attachedToElement) {\r\n return;\r\n }\r\n noPreventDefault = Camera.ForceAttachControlToAlwaysPreventDefault ? false : noPreventDefault;\r\n this.attachedToElement = true;\r\n this.noPreventDefault = noPreventDefault;\r\n for (var cam in this.attached) {\r\n this.attached[cam].attachControl(noPreventDefault);\r\n }\r\n };\r\n /**\r\n * Detach the current manager inputs controls from a specific dom element.\r\n * @param element Defines the dom element to collect the events from\r\n * @param disconnect Defines whether the input should be removed from the current list of attached inputs\r\n */\r\n CameraInputsManager.prototype.detachElement = function (disconnect) {\r\n if (disconnect === void 0) { disconnect = false; }\r\n for (var cam in this.attached) {\r\n this.attached[cam].detachControl();\r\n if (disconnect) {\r\n this.attached[cam].camera = null;\r\n }\r\n }\r\n this.attachedToElement = false;\r\n };\r\n /**\r\n * Rebuild the dynamic inputCheck function from the current list of\r\n * defined inputs in the manager.\r\n */\r\n CameraInputsManager.prototype.rebuildInputCheck = function () {\r\n this.checkInputs = function () { };\r\n for (var cam in this.attached) {\r\n var input = this.attached[cam];\r\n if (input.checkInputs) {\r\n this.checkInputs = this._addCheckInputs(input.checkInputs.bind(input));\r\n }\r\n }\r\n };\r\n /**\r\n * Remove all attached input methods from a camera\r\n */\r\n CameraInputsManager.prototype.clear = function () {\r\n if (this.attachedToElement) {\r\n this.detachElement(true);\r\n }\r\n this.attached = {};\r\n this.attachedToElement = false;\r\n this.checkInputs = function () { };\r\n };\r\n /**\r\n * Serialize the current input manager attached to a camera.\r\n * This ensures than once parsed,\r\n * the input associated to the camera will be identical to the current ones\r\n * @param serializedCamera Defines the camera serialization JSON the input serialization should write to\r\n */\r\n CameraInputsManager.prototype.serialize = function (serializedCamera) {\r\n var inputs = {};\r\n for (var cam in this.attached) {\r\n var input = this.attached[cam];\r\n var res = SerializationHelper.Serialize(input);\r\n inputs[input.getClassName()] = res;\r\n }\r\n serializedCamera.inputsmgr = inputs;\r\n };\r\n /**\r\n * Parses an input manager serialized JSON to restore the previous list of inputs\r\n * and states associated to a camera.\r\n * @param parsedCamera Defines the JSON to parse\r\n */\r\n CameraInputsManager.prototype.parse = function (parsedCamera) {\r\n var parsedInputs = parsedCamera.inputsmgr;\r\n if (parsedInputs) {\r\n this.clear();\r\n for (var n in parsedInputs) {\r\n var construct = CameraInputTypes[n];\r\n if (construct) {\r\n var parsedinput = parsedInputs[n];\r\n var input = SerializationHelper.Parse(function () {\r\n return new construct();\r\n }, parsedinput, null);\r\n this.add(input);\r\n }\r\n }\r\n }\r\n else {\r\n //2016-03-08 this part is for managing backward compatibility\r\n for (var n in this.attached) {\r\n var construct = CameraInputTypes[this.attached[n].getClassName()];\r\n if (construct) {\r\n var input = SerializationHelper.Parse(function () {\r\n return new construct();\r\n }, parsedCamera, null);\r\n this.remove(this.attached[n]);\r\n this.add(input);\r\n }\r\n }\r\n }\r\n };\r\n return CameraInputsManager;\r\n}());\r\nexport { CameraInputsManager };\r\n//# sourceMappingURL=cameraInputsManager.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize } from \"../../Misc/decorators\";\r\nimport { CameraInputTypes } from \"../../Cameras/cameraInputsManager\";\r\nimport { BaseCameraPointersInput } from \"../../Cameras/Inputs/BaseCameraPointersInput\";\r\n/**\r\n * Manage the pointers inputs to control an arc rotate camera.\r\n * @see https://doc.babylonjs.com/how_to/customizing_camera_inputs\r\n */\r\nvar ArcRotateCameraPointersInput = /** @class */ (function (_super) {\r\n __extends(ArcRotateCameraPointersInput, _super);\r\n function ArcRotateCameraPointersInput() {\r\n var _this = _super !== null && _super.apply(this, arguments) || this;\r\n /**\r\n * Defines the buttons associated with the input to handle camera move.\r\n */\r\n _this.buttons = [0, 1, 2];\r\n /**\r\n * Defines the pointer angular sensibility along the X axis or how fast is\r\n * the camera rotating.\r\n */\r\n _this.angularSensibilityX = 1000.0;\r\n /**\r\n * Defines the pointer angular sensibility along the Y axis or how fast is\r\n * the camera rotating.\r\n */\r\n _this.angularSensibilityY = 1000.0;\r\n /**\r\n * Defines the pointer pinch precision or how fast is the camera zooming.\r\n */\r\n _this.pinchPrecision = 12.0;\r\n /**\r\n * pinchDeltaPercentage will be used instead of pinchPrecision if different\r\n * from 0.\r\n * It defines the percentage of current camera.radius to use as delta when\r\n * pinch zoom is used.\r\n */\r\n _this.pinchDeltaPercentage = 0;\r\n /**\r\n * When useNaturalPinchZoom is true, multi touch zoom will zoom in such\r\n * that any object in the plane at the camera's target point will scale\r\n * perfectly with finger motion.\r\n * Overrides pinchDeltaPercentage and pinchPrecision.\r\n */\r\n _this.useNaturalPinchZoom = false;\r\n /**\r\n * Defines the pointer panning sensibility or how fast is the camera moving.\r\n */\r\n _this.panningSensibility = 1000.0;\r\n /**\r\n * Defines whether panning (2 fingers swipe) is enabled through multitouch.\r\n */\r\n _this.multiTouchPanning = true;\r\n /**\r\n * Defines whether panning is enabled for both pan (2 fingers swipe) and\r\n * zoom (pinch) through multitouch.\r\n */\r\n _this.multiTouchPanAndZoom = true;\r\n /**\r\n * Revers pinch action direction.\r\n */\r\n _this.pinchInwards = true;\r\n _this._isPanClick = false;\r\n _this._twoFingerActivityCount = 0;\r\n _this._isPinching = false;\r\n return _this;\r\n }\r\n /**\r\n * Gets the class name of the current input.\r\n * @returns the class name\r\n */\r\n ArcRotateCameraPointersInput.prototype.getClassName = function () {\r\n return \"ArcRotateCameraPointersInput\";\r\n };\r\n /**\r\n * Called on pointer POINTERMOVE event if only a single touch is active.\r\n */\r\n ArcRotateCameraPointersInput.prototype.onTouch = function (point, offsetX, offsetY) {\r\n if (this.panningSensibility !== 0 &&\r\n ((this._ctrlKey && this.camera._useCtrlForPanning) || this._isPanClick)) {\r\n this.camera.inertialPanningX += -offsetX / this.panningSensibility;\r\n this.camera.inertialPanningY += offsetY / this.panningSensibility;\r\n }\r\n else {\r\n this.camera.inertialAlphaOffset -= offsetX / this.angularSensibilityX;\r\n this.camera.inertialBetaOffset -= offsetY / this.angularSensibilityY;\r\n }\r\n };\r\n /**\r\n * Called on pointer POINTERDOUBLETAP event.\r\n */\r\n ArcRotateCameraPointersInput.prototype.onDoubleTap = function (type) {\r\n if (this.camera.useInputToRestoreState) {\r\n this.camera.restoreState();\r\n }\r\n };\r\n /**\r\n * Called on pointer POINTERMOVE event if multiple touches are active.\r\n */\r\n ArcRotateCameraPointersInput.prototype.onMultiTouch = function (pointA, pointB, previousPinchSquaredDistance, pinchSquaredDistance, previousMultiTouchPanPosition, multiTouchPanPosition) {\r\n if (previousPinchSquaredDistance === 0 && previousMultiTouchPanPosition === null) {\r\n // First time this method is called for new pinch.\r\n // Next time this is called there will be a\r\n // previousPinchSquaredDistance and pinchSquaredDistance to compare.\r\n return;\r\n }\r\n if (pinchSquaredDistance === 0 && multiTouchPanPosition === null) {\r\n // Last time this method is called at the end of a pinch.\r\n return;\r\n }\r\n var direction = this.pinchInwards ? 1 : -1;\r\n if (this.multiTouchPanAndZoom) {\r\n if (this.useNaturalPinchZoom) {\r\n this.camera.radius = this.camera.radius *\r\n Math.sqrt(previousPinchSquaredDistance) / Math.sqrt(pinchSquaredDistance);\r\n }\r\n else if (this.pinchDeltaPercentage) {\r\n this.camera.inertialRadiusOffset +=\r\n (pinchSquaredDistance - previousPinchSquaredDistance) * 0.001 *\r\n this.camera.radius * this.pinchDeltaPercentage;\r\n }\r\n else {\r\n this.camera.inertialRadiusOffset +=\r\n (pinchSquaredDistance - previousPinchSquaredDistance) /\r\n (this.pinchPrecision * direction *\r\n (this.angularSensibilityX + this.angularSensibilityY) / 2);\r\n }\r\n if (this.panningSensibility !== 0 &&\r\n previousMultiTouchPanPosition && multiTouchPanPosition) {\r\n var moveDeltaX = multiTouchPanPosition.x - previousMultiTouchPanPosition.x;\r\n var moveDeltaY = multiTouchPanPosition.y - previousMultiTouchPanPosition.y;\r\n this.camera.inertialPanningX += -moveDeltaX / this.panningSensibility;\r\n this.camera.inertialPanningY += moveDeltaY / this.panningSensibility;\r\n }\r\n }\r\n else {\r\n this._twoFingerActivityCount++;\r\n var previousPinchDistance = Math.sqrt(previousPinchSquaredDistance);\r\n var pinchDistance = Math.sqrt(pinchSquaredDistance);\r\n if (this._isPinching ||\r\n (this._twoFingerActivityCount < 20 &&\r\n Math.abs(pinchDistance - previousPinchDistance) >\r\n this.camera.pinchToPanMaxDistance)) {\r\n // Since pinch has not been active long, assume we intend to zoom.\r\n if (this.pinchDeltaPercentage) {\r\n this.camera.inertialRadiusOffset +=\r\n (pinchSquaredDistance - previousPinchSquaredDistance) * 0.001 *\r\n this.camera.radius * this.pinchDeltaPercentage;\r\n }\r\n else {\r\n this.camera.inertialRadiusOffset +=\r\n (pinchSquaredDistance - previousPinchSquaredDistance) /\r\n (this.pinchPrecision * direction *\r\n (this.angularSensibilityX + this.angularSensibilityY) / 2);\r\n }\r\n // Since we are pinching, remain pinching on next iteration.\r\n this._isPinching = true;\r\n }\r\n else {\r\n // Pause between pinch starting and moving implies not a zoom event.\r\n // Pan instead.\r\n if (this.panningSensibility !== 0 && this.multiTouchPanning &&\r\n multiTouchPanPosition && previousMultiTouchPanPosition) {\r\n var moveDeltaX = multiTouchPanPosition.x - previousMultiTouchPanPosition.x;\r\n var moveDeltaY = multiTouchPanPosition.y - previousMultiTouchPanPosition.y;\r\n this.camera.inertialPanningX += -moveDeltaX / this.panningSensibility;\r\n this.camera.inertialPanningY += moveDeltaY / this.panningSensibility;\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Called each time a new POINTERDOWN event occurs. Ie, for each button\r\n * press.\r\n */\r\n ArcRotateCameraPointersInput.prototype.onButtonDown = function (evt) {\r\n this._isPanClick = evt.button === this.camera._panningMouseButton;\r\n };\r\n /**\r\n * Called each time a new POINTERUP event occurs. Ie, for each button\r\n * release.\r\n */\r\n ArcRotateCameraPointersInput.prototype.onButtonUp = function (evt) {\r\n this._twoFingerActivityCount = 0;\r\n this._isPinching = false;\r\n };\r\n /**\r\n * Called when window becomes inactive.\r\n */\r\n ArcRotateCameraPointersInput.prototype.onLostFocus = function () {\r\n this._isPanClick = false;\r\n this._twoFingerActivityCount = 0;\r\n this._isPinching = false;\r\n };\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"buttons\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"angularSensibilityX\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"angularSensibilityY\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"pinchPrecision\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"pinchDeltaPercentage\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"useNaturalPinchZoom\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"panningSensibility\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"multiTouchPanning\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraPointersInput.prototype, \"multiTouchPanAndZoom\", void 0);\r\n return ArcRotateCameraPointersInput;\r\n}(BaseCameraPointersInput));\r\nexport { ArcRotateCameraPointersInput };\r\nCameraInputTypes[\"ArcRotateCameraPointersInput\"] =\r\n ArcRotateCameraPointersInput;\r\n//# sourceMappingURL=arcRotateCameraPointersInput.js.map","import { __decorate } from \"tslib\";\r\nimport { serialize } from \"../../Misc/decorators\";\r\nimport { Tools } from \"../../Misc/tools\";\r\nimport { PointerEventTypes } from \"../../Events/pointerEvents\";\r\n/**\r\n * Base class for Camera Pointer Inputs.\r\n * See FollowCameraPointersInput in src/Cameras/Inputs/followCameraPointersInput.ts\r\n * for example usage.\r\n */\r\nvar BaseCameraPointersInput = /** @class */ (function () {\r\n function BaseCameraPointersInput() {\r\n /**\r\n * Defines the buttons associated with the input to handle camera move.\r\n */\r\n this.buttons = [0, 1, 2];\r\n }\r\n /**\r\n * Attach the input controls to a specific dom element to get the input from.\r\n * @param element Defines the element the controls should be listened from\r\n * @param noPreventDefault Defines whether event caught by the controls should call preventdefault() (https://developer.mozilla.org/en-US/docs/Web/API/Event/preventDefault)\r\n */\r\n BaseCameraPointersInput.prototype.attachControl = function (noPreventDefault) {\r\n var _this = this;\r\n noPreventDefault = Tools.BackCompatCameraNoPreventDefault(arguments);\r\n var engine = this.camera.getEngine();\r\n var element = engine.getInputElement();\r\n var previousPinchSquaredDistance = 0;\r\n var previousMultiTouchPanPosition = null;\r\n this.pointA = null;\r\n this.pointB = null;\r\n this._altKey = false;\r\n this._ctrlKey = false;\r\n this._metaKey = false;\r\n this._shiftKey = false;\r\n this._buttonsPressed = 0;\r\n this._pointerInput = function (p, s) {\r\n var evt = p.event;\r\n var isTouch = evt.pointerType === \"touch\";\r\n if (engine.isInVRExclusivePointerMode) {\r\n return;\r\n }\r\n if (p.type !== PointerEventTypes.POINTERMOVE &&\r\n _this.buttons.indexOf(evt.button) === -1) {\r\n return;\r\n }\r\n var srcElement = (evt.srcElement || evt.target);\r\n _this._altKey = evt.altKey;\r\n _this._ctrlKey = evt.ctrlKey;\r\n _this._metaKey = evt.metaKey;\r\n _this._shiftKey = evt.shiftKey;\r\n _this._buttonsPressed = evt.buttons;\r\n if (engine.isPointerLock) {\r\n var offsetX = evt.movementX ||\r\n evt.mozMovementX ||\r\n evt.webkitMovementX ||\r\n evt.msMovementX ||\r\n 0;\r\n var offsetY = evt.movementY ||\r\n evt.mozMovementY ||\r\n evt.webkitMovementY ||\r\n evt.msMovementY ||\r\n 0;\r\n _this.onTouch(null, offsetX, offsetY);\r\n _this.pointA = null;\r\n _this.pointB = null;\r\n }\r\n else if (p.type === PointerEventTypes.POINTERDOWN && srcElement) {\r\n try {\r\n srcElement.setPointerCapture(evt.pointerId);\r\n }\r\n catch (e) {\r\n //Nothing to do with the error. Execution will continue.\r\n }\r\n if (_this.pointA === null) {\r\n _this.pointA = { x: evt.clientX,\r\n y: evt.clientY,\r\n pointerId: evt.pointerId,\r\n type: evt.pointerType };\r\n }\r\n else if (_this.pointB === null) {\r\n _this.pointB = { x: evt.clientX,\r\n y: evt.clientY,\r\n pointerId: evt.pointerId,\r\n type: evt.pointerType };\r\n }\r\n _this.onButtonDown(evt);\r\n if (!noPreventDefault) {\r\n evt.preventDefault();\r\n element && element.focus();\r\n }\r\n }\r\n else if (p.type === PointerEventTypes.POINTERDOUBLETAP) {\r\n _this.onDoubleTap(evt.pointerType);\r\n }\r\n else if (p.type === PointerEventTypes.POINTERUP && srcElement) {\r\n try {\r\n srcElement.releasePointerCapture(evt.pointerId);\r\n }\r\n catch (e) {\r\n //Nothing to do with the error.\r\n }\r\n if (!isTouch) {\r\n _this.pointB = null; // Mouse and pen are mono pointer\r\n }\r\n //would be better to use pointers.remove(evt.pointerId) for multitouch gestures,\r\n //but emptying completely pointers collection is required to fix a bug on iPhone :\r\n //when changing orientation while pinching camera,\r\n //one pointer stay pressed forever if we don't release all pointers\r\n //will be ok to put back pointers.remove(evt.pointerId); when iPhone bug corrected\r\n if (engine._badOS) {\r\n _this.pointA = _this.pointB = null;\r\n }\r\n else {\r\n //only remove the impacted pointer in case of multitouch allowing on most\r\n //platforms switching from rotate to zoom and pan seamlessly.\r\n if (_this.pointB && _this.pointA && _this.pointA.pointerId == evt.pointerId) {\r\n _this.pointA = _this.pointB;\r\n _this.pointB = null;\r\n }\r\n else if (_this.pointA && _this.pointB &&\r\n _this.pointB.pointerId == evt.pointerId) {\r\n _this.pointB = null;\r\n }\r\n else {\r\n _this.pointA = _this.pointB = null;\r\n }\r\n }\r\n if (previousPinchSquaredDistance !== 0 || previousMultiTouchPanPosition) {\r\n // Previous pinch data is populated but a button has been lifted\r\n // so pinch has ended.\r\n _this.onMultiTouch(_this.pointA, _this.pointB, previousPinchSquaredDistance, 0, // pinchSquaredDistance\r\n previousMultiTouchPanPosition, null // multiTouchPanPosition\r\n );\r\n previousPinchSquaredDistance = 0;\r\n previousMultiTouchPanPosition = null;\r\n }\r\n _this.onButtonUp(evt);\r\n if (!noPreventDefault) {\r\n evt.preventDefault();\r\n }\r\n }\r\n else if (p.type === PointerEventTypes.POINTERMOVE) {\r\n if (!noPreventDefault) {\r\n evt.preventDefault();\r\n }\r\n // One button down\r\n if (_this.pointA && _this.pointB === null) {\r\n var offsetX = evt.clientX - _this.pointA.x;\r\n var offsetY = evt.clientY - _this.pointA.y;\r\n _this.onTouch(_this.pointA, offsetX, offsetY);\r\n _this.pointA.x = evt.clientX;\r\n _this.pointA.y = evt.clientY;\r\n }\r\n // Two buttons down: pinch\r\n else if (_this.pointA && _this.pointB) {\r\n var ed = (_this.pointA.pointerId === evt.pointerId) ?\r\n _this.pointA : _this.pointB;\r\n ed.x = evt.clientX;\r\n ed.y = evt.clientY;\r\n var distX = _this.pointA.x - _this.pointB.x;\r\n var distY = _this.pointA.y - _this.pointB.y;\r\n var pinchSquaredDistance = (distX * distX) + (distY * distY);\r\n var multiTouchPanPosition = { x: (_this.pointA.x + _this.pointB.x) / 2,\r\n y: (_this.pointA.y + _this.pointB.y) / 2,\r\n pointerId: evt.pointerId,\r\n type: p.type };\r\n _this.onMultiTouch(_this.pointA, _this.pointB, previousPinchSquaredDistance, pinchSquaredDistance, previousMultiTouchPanPosition, multiTouchPanPosition);\r\n previousMultiTouchPanPosition = multiTouchPanPosition;\r\n previousPinchSquaredDistance = pinchSquaredDistance;\r\n }\r\n }\r\n };\r\n this._observer = this.camera.getScene().onPointerObservable.add(this._pointerInput, PointerEventTypes.POINTERDOWN | PointerEventTypes.POINTERUP |\r\n PointerEventTypes.POINTERMOVE);\r\n this._onLostFocus = function () {\r\n _this.pointA = _this.pointB = null;\r\n previousPinchSquaredDistance = 0;\r\n previousMultiTouchPanPosition = null;\r\n _this.onLostFocus();\r\n };\r\n element && element.addEventListener(\"contextmenu\", this.onContextMenu.bind(this), false);\r\n var hostWindow = this.camera.getScene().getEngine().getHostWindow();\r\n if (hostWindow) {\r\n Tools.RegisterTopRootEvents(hostWindow, [\r\n { name: \"blur\", handler: this._onLostFocus }\r\n ]);\r\n }\r\n };\r\n /**\r\n * Detach the current controls from the specified dom element.\r\n * @param ignored defines an ignored parameter kept for backward compatibility. If you want to define the source input element, you can set engine.inputElement before calling camera.attachControl\r\n */\r\n BaseCameraPointersInput.prototype.detachControl = function (ignored) {\r\n if (this._onLostFocus) {\r\n var hostWindow = this.camera.getScene().getEngine().getHostWindow();\r\n if (hostWindow) {\r\n Tools.UnregisterTopRootEvents(hostWindow, [\r\n { name: \"blur\", handler: this._onLostFocus }\r\n ]);\r\n }\r\n }\r\n if (this._observer) {\r\n this.camera.getScene().onPointerObservable.remove(this._observer);\r\n this._observer = null;\r\n if (this.onContextMenu) {\r\n var inputElement = this.camera.getScene().getEngine().getInputElement();\r\n inputElement && inputElement.removeEventListener(\"contextmenu\", this.onContextMenu);\r\n }\r\n this._onLostFocus = null;\r\n }\r\n this._altKey = false;\r\n this._ctrlKey = false;\r\n this._metaKey = false;\r\n this._shiftKey = false;\r\n this._buttonsPressed = 0;\r\n };\r\n /**\r\n * Gets the class name of the current input.\r\n * @returns the class name\r\n */\r\n BaseCameraPointersInput.prototype.getClassName = function () {\r\n return \"BaseCameraPointersInput\";\r\n };\r\n /**\r\n * Get the friendly name associated with the input class.\r\n * @returns the input friendly name\r\n */\r\n BaseCameraPointersInput.prototype.getSimpleName = function () {\r\n return \"pointers\";\r\n };\r\n /**\r\n * Called on pointer POINTERDOUBLETAP event.\r\n * Override this method to provide functionality on POINTERDOUBLETAP event.\r\n */\r\n BaseCameraPointersInput.prototype.onDoubleTap = function (type) {\r\n };\r\n /**\r\n * Called on pointer POINTERMOVE event if only a single touch is active.\r\n * Override this method to provide functionality.\r\n */\r\n BaseCameraPointersInput.prototype.onTouch = function (point, offsetX, offsetY) {\r\n };\r\n /**\r\n * Called on pointer POINTERMOVE event if multiple touches are active.\r\n * Override this method to provide functionality.\r\n */\r\n BaseCameraPointersInput.prototype.onMultiTouch = function (pointA, pointB, previousPinchSquaredDistance, pinchSquaredDistance, previousMultiTouchPanPosition, multiTouchPanPosition) {\r\n };\r\n /**\r\n * Called on JS contextmenu event.\r\n * Override this method to provide functionality.\r\n */\r\n BaseCameraPointersInput.prototype.onContextMenu = function (evt) {\r\n evt.preventDefault();\r\n };\r\n /**\r\n * Called each time a new POINTERDOWN event occurs. Ie, for each button\r\n * press.\r\n * Override this method to provide functionality.\r\n */\r\n BaseCameraPointersInput.prototype.onButtonDown = function (evt) {\r\n };\r\n /**\r\n * Called each time a new POINTERUP event occurs. Ie, for each button\r\n * release.\r\n * Override this method to provide functionality.\r\n */\r\n BaseCameraPointersInput.prototype.onButtonUp = function (evt) {\r\n };\r\n /**\r\n * Called when window becomes inactive.\r\n * Override this method to provide functionality.\r\n */\r\n BaseCameraPointersInput.prototype.onLostFocus = function () {\r\n };\r\n __decorate([\r\n serialize()\r\n ], BaseCameraPointersInput.prototype, \"buttons\", void 0);\r\n return BaseCameraPointersInput;\r\n}());\r\nexport { BaseCameraPointersInput };\r\n//# sourceMappingURL=BaseCameraPointersInput.js.map","import { __decorate } from \"tslib\";\r\nimport { serialize } from \"../../Misc/decorators\";\r\nimport { CameraInputTypes } from \"../../Cameras/cameraInputsManager\";\r\nimport { KeyboardEventTypes } from \"../../Events/keyboardEvents\";\r\nimport { Tools } from '../../Misc/tools';\r\n/**\r\n * Manage the keyboard inputs to control the movement of an arc rotate camera.\r\n * @see https://doc.babylonjs.com/how_to/customizing_camera_inputs\r\n */\r\nvar ArcRotateCameraKeyboardMoveInput = /** @class */ (function () {\r\n function ArcRotateCameraKeyboardMoveInput() {\r\n /**\r\n * Defines the list of key codes associated with the up action (increase alpha)\r\n */\r\n this.keysUp = [38];\r\n /**\r\n * Defines the list of key codes associated with the down action (decrease alpha)\r\n */\r\n this.keysDown = [40];\r\n /**\r\n * Defines the list of key codes associated with the left action (increase beta)\r\n */\r\n this.keysLeft = [37];\r\n /**\r\n * Defines the list of key codes associated with the right action (decrease beta)\r\n */\r\n this.keysRight = [39];\r\n /**\r\n * Defines the list of key codes associated with the reset action.\r\n * Those keys reset the camera to its last stored state (with the method camera.storeState())\r\n */\r\n this.keysReset = [220];\r\n /**\r\n * Defines the panning sensibility of the inputs.\r\n * (How fast is the camera panning)\r\n */\r\n this.panningSensibility = 50.0;\r\n /**\r\n * Defines the zooming sensibility of the inputs.\r\n * (How fast is the camera zooming)\r\n */\r\n this.zoomingSensibility = 25.0;\r\n /**\r\n * Defines whether maintaining the alt key down switch the movement mode from\r\n * orientation to zoom.\r\n */\r\n this.useAltToZoom = true;\r\n /**\r\n * Rotation speed of the camera\r\n */\r\n this.angularSpeed = 0.01;\r\n this._keys = new Array();\r\n }\r\n /**\r\n * Attach the input controls to a specific dom element to get the input from.\r\n * @param noPreventDefault Defines whether event caught by the controls should call preventdefault() (https://developer.mozilla.org/en-US/docs/Web/API/Event/preventDefault)\r\n */\r\n ArcRotateCameraKeyboardMoveInput.prototype.attachControl = function (noPreventDefault) {\r\n var _this = this;\r\n // was there a second variable defined?\r\n noPreventDefault = Tools.BackCompatCameraNoPreventDefault(arguments);\r\n if (this._onCanvasBlurObserver) {\r\n return;\r\n }\r\n this._scene = this.camera.getScene();\r\n this._engine = this._scene.getEngine();\r\n this._onCanvasBlurObserver = this._engine.onCanvasBlurObservable.add(function () {\r\n _this._keys = [];\r\n });\r\n this._onKeyboardObserver = this._scene.onKeyboardObservable.add(function (info) {\r\n var evt = info.event;\r\n if (!evt.metaKey) {\r\n if (info.type === KeyboardEventTypes.KEYDOWN) {\r\n _this._ctrlPressed = evt.ctrlKey;\r\n _this._altPressed = evt.altKey;\r\n if (_this.keysUp.indexOf(evt.keyCode) !== -1 || _this.keysDown.indexOf(evt.keyCode) !== -1 || _this.keysLeft.indexOf(evt.keyCode) !== -1 || _this.keysRight.indexOf(evt.keyCode) !== -1 || _this.keysReset.indexOf(evt.keyCode) !== -1) {\r\n var index = _this._keys.indexOf(evt.keyCode);\r\n if (index === -1) {\r\n _this._keys.push(evt.keyCode);\r\n }\r\n if (evt.preventDefault) {\r\n if (!noPreventDefault) {\r\n evt.preventDefault();\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n if (_this.keysUp.indexOf(evt.keyCode) !== -1 || _this.keysDown.indexOf(evt.keyCode) !== -1 || _this.keysLeft.indexOf(evt.keyCode) !== -1 || _this.keysRight.indexOf(evt.keyCode) !== -1 || _this.keysReset.indexOf(evt.keyCode) !== -1) {\r\n var index = _this._keys.indexOf(evt.keyCode);\r\n if (index >= 0) {\r\n _this._keys.splice(index, 1);\r\n }\r\n if (evt.preventDefault) {\r\n if (!noPreventDefault) {\r\n evt.preventDefault();\r\n }\r\n }\r\n }\r\n }\r\n }\r\n });\r\n };\r\n /**\r\n * Detach the current controls from the specified dom element.\r\n * @param ignored defines an ignored parameter kept for backward compatibility. If you want to define the source input element, you can set engine.inputElement before calling camera.attachControl\r\n */\r\n ArcRotateCameraKeyboardMoveInput.prototype.detachControl = function (ignored) {\r\n if (this._scene) {\r\n if (this._onKeyboardObserver) {\r\n this._scene.onKeyboardObservable.remove(this._onKeyboardObserver);\r\n }\r\n if (this._onCanvasBlurObserver) {\r\n this._engine.onCanvasBlurObservable.remove(this._onCanvasBlurObserver);\r\n }\r\n this._onKeyboardObserver = null;\r\n this._onCanvasBlurObserver = null;\r\n }\r\n this._keys = [];\r\n };\r\n /**\r\n * Update the current camera state depending on the inputs that have been used this frame.\r\n * This is a dynamically created lambda to avoid the performance penalty of looping for inputs in the render loop.\r\n */\r\n ArcRotateCameraKeyboardMoveInput.prototype.checkInputs = function () {\r\n if (this._onKeyboardObserver) {\r\n var camera = this.camera;\r\n for (var index = 0; index < this._keys.length; index++) {\r\n var keyCode = this._keys[index];\r\n if (this.keysLeft.indexOf(keyCode) !== -1) {\r\n if (this._ctrlPressed && this.camera._useCtrlForPanning) {\r\n camera.inertialPanningX -= 1 / this.panningSensibility;\r\n }\r\n else {\r\n camera.inertialAlphaOffset -= this.angularSpeed;\r\n }\r\n }\r\n else if (this.keysUp.indexOf(keyCode) !== -1) {\r\n if (this._ctrlPressed && this.camera._useCtrlForPanning) {\r\n camera.inertialPanningY += 1 / this.panningSensibility;\r\n }\r\n else if (this._altPressed && this.useAltToZoom) {\r\n camera.inertialRadiusOffset += 1 / this.zoomingSensibility;\r\n }\r\n else {\r\n camera.inertialBetaOffset -= this.angularSpeed;\r\n }\r\n }\r\n else if (this.keysRight.indexOf(keyCode) !== -1) {\r\n if (this._ctrlPressed && this.camera._useCtrlForPanning) {\r\n camera.inertialPanningX += 1 / this.panningSensibility;\r\n }\r\n else {\r\n camera.inertialAlphaOffset += this.angularSpeed;\r\n }\r\n }\r\n else if (this.keysDown.indexOf(keyCode) !== -1) {\r\n if (this._ctrlPressed && this.camera._useCtrlForPanning) {\r\n camera.inertialPanningY -= 1 / this.panningSensibility;\r\n }\r\n else if (this._altPressed && this.useAltToZoom) {\r\n camera.inertialRadiusOffset -= 1 / this.zoomingSensibility;\r\n }\r\n else {\r\n camera.inertialBetaOffset += this.angularSpeed;\r\n }\r\n }\r\n else if (this.keysReset.indexOf(keyCode) !== -1) {\r\n if (camera.useInputToRestoreState) {\r\n camera.restoreState();\r\n }\r\n }\r\n }\r\n }\r\n };\r\n /**\r\n * Gets the class name of the current intput.\r\n * @returns the class name\r\n */\r\n ArcRotateCameraKeyboardMoveInput.prototype.getClassName = function () {\r\n return \"ArcRotateCameraKeyboardMoveInput\";\r\n };\r\n /**\r\n * Get the friendly name associated with the input class.\r\n * @returns the input friendly name\r\n */\r\n ArcRotateCameraKeyboardMoveInput.prototype.getSimpleName = function () {\r\n return \"keyboard\";\r\n };\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"keysUp\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"keysDown\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"keysLeft\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"keysRight\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"keysReset\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"panningSensibility\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"zoomingSensibility\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"useAltToZoom\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraKeyboardMoveInput.prototype, \"angularSpeed\", void 0);\r\n return ArcRotateCameraKeyboardMoveInput;\r\n}());\r\nexport { ArcRotateCameraKeyboardMoveInput };\r\nCameraInputTypes[\"ArcRotateCameraKeyboardMoveInput\"] = ArcRotateCameraKeyboardMoveInput;\r\n//# sourceMappingURL=arcRotateCameraKeyboardMoveInput.js.map","import { __decorate } from \"tslib\";\r\nimport { serialize } from \"../../Misc/decorators\";\r\nimport { CameraInputTypes } from \"../../Cameras/cameraInputsManager\";\r\nimport { PointerEventTypes } from \"../../Events/pointerEvents\";\r\nimport { Scalar } from '../../Maths/math.scalar';\r\nimport { Tools } from '../../Misc/tools';\r\n/**\r\n * Manage the mouse wheel inputs to control an arc rotate camera.\r\n * @see https://doc.babylonjs.com/how_to/customizing_camera_inputs\r\n */\r\nvar ArcRotateCameraMouseWheelInput = /** @class */ (function () {\r\n function ArcRotateCameraMouseWheelInput() {\r\n /**\r\n * Gets or Set the mouse wheel precision or how fast is the camera zooming.\r\n */\r\n this.wheelPrecision = 3.0;\r\n /**\r\n * wheelDeltaPercentage will be used instead of wheelPrecision if different from 0.\r\n * It defines the percentage of current camera.radius to use as delta when wheel is used.\r\n */\r\n this.wheelDeltaPercentage = 0;\r\n }\r\n ArcRotateCameraMouseWheelInput.prototype.computeDeltaFromMouseWheelLegacyEvent = function (mouseWheelDelta, radius) {\r\n var delta = 0;\r\n var wheelDelta = (mouseWheelDelta * 0.01 * this.wheelDeltaPercentage) * radius;\r\n if (mouseWheelDelta > 0) {\r\n delta = wheelDelta / (1.0 + this.wheelDeltaPercentage);\r\n }\r\n else {\r\n delta = wheelDelta * (1.0 + this.wheelDeltaPercentage);\r\n }\r\n return delta;\r\n };\r\n /**\r\n * Attach the input controls to a specific dom element to get the input from.\r\n * @param noPreventDefault Defines whether event caught by the controls should call preventdefault() (https://developer.mozilla.org/en-US/docs/Web/API/Event/preventDefault)\r\n */\r\n ArcRotateCameraMouseWheelInput.prototype.attachControl = function (noPreventDefault) {\r\n var _this = this;\r\n // was there a second variable defined?\r\n noPreventDefault = Tools.BackCompatCameraNoPreventDefault(arguments);\r\n this._wheel = function (p, s) {\r\n //sanity check - this should be a PointerWheel event.\r\n if (p.type !== PointerEventTypes.POINTERWHEEL) {\r\n return;\r\n }\r\n var event = p.event;\r\n var delta = 0;\r\n var mouseWheelLegacyEvent = event;\r\n var wheelDelta = 0;\r\n if (mouseWheelLegacyEvent.wheelDelta) {\r\n wheelDelta = mouseWheelLegacyEvent.wheelDelta;\r\n }\r\n else {\r\n wheelDelta = -(event.deltaY || event.detail) * 60;\r\n }\r\n if (_this.wheelDeltaPercentage) {\r\n delta = _this.computeDeltaFromMouseWheelLegacyEvent(wheelDelta, _this.camera.radius);\r\n // If zooming in, estimate the target radius and use that to compute the delta for inertia\r\n // this will stop multiple scroll events zooming in from adding too much inertia\r\n if (delta > 0) {\r\n var estimatedTargetRadius = _this.camera.radius;\r\n var targetInertia = _this.camera.inertialRadiusOffset + delta;\r\n for (var i = 0; i < 20 && Math.abs(targetInertia) > 0.001; i++) {\r\n estimatedTargetRadius -= targetInertia;\r\n targetInertia *= _this.camera.inertia;\r\n }\r\n estimatedTargetRadius = Scalar.Clamp(estimatedTargetRadius, 0, Number.MAX_VALUE);\r\n delta = _this.computeDeltaFromMouseWheelLegacyEvent(wheelDelta, estimatedTargetRadius);\r\n }\r\n }\r\n else {\r\n delta = wheelDelta / (_this.wheelPrecision * 40);\r\n }\r\n if (delta) {\r\n _this.camera.inertialRadiusOffset += delta;\r\n }\r\n if (event.preventDefault) {\r\n if (!noPreventDefault) {\r\n event.preventDefault();\r\n }\r\n }\r\n };\r\n this._observer = this.camera.getScene().onPointerObservable.add(this._wheel, PointerEventTypes.POINTERWHEEL);\r\n };\r\n /**\r\n * Detach the current controls from the specified dom element.\r\n * @param ignored defines an ignored parameter kept for backward compatibility. If you want to define the source input element, you can set engine.inputElement before calling camera.attachControl\r\n */\r\n ArcRotateCameraMouseWheelInput.prototype.detachControl = function (ignored) {\r\n if (this._observer) {\r\n this.camera.getScene().onPointerObservable.remove(this._observer);\r\n this._observer = null;\r\n this._wheel = null;\r\n }\r\n };\r\n /**\r\n * Gets the class name of the current intput.\r\n * @returns the class name\r\n */\r\n ArcRotateCameraMouseWheelInput.prototype.getClassName = function () {\r\n return \"ArcRotateCameraMouseWheelInput\";\r\n };\r\n /**\r\n * Get the friendly name associated with the input class.\r\n * @returns the input friendly name\r\n */\r\n ArcRotateCameraMouseWheelInput.prototype.getSimpleName = function () {\r\n return \"mousewheel\";\r\n };\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraMouseWheelInput.prototype, \"wheelPrecision\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCameraMouseWheelInput.prototype, \"wheelDeltaPercentage\", void 0);\r\n return ArcRotateCameraMouseWheelInput;\r\n}());\r\nexport { ArcRotateCameraMouseWheelInput };\r\nCameraInputTypes[\"ArcRotateCameraMouseWheelInput\"] = ArcRotateCameraMouseWheelInput;\r\n//# sourceMappingURL=arcRotateCameraMouseWheelInput.js.map","import { __extends } from \"tslib\";\r\nimport { ArcRotateCameraPointersInput } from \"../Cameras/Inputs/arcRotateCameraPointersInput\";\r\nimport { ArcRotateCameraKeyboardMoveInput } from \"../Cameras/Inputs/arcRotateCameraKeyboardMoveInput\";\r\nimport { ArcRotateCameraMouseWheelInput } from \"../Cameras/Inputs/arcRotateCameraMouseWheelInput\";\r\nimport { CameraInputsManager } from \"../Cameras/cameraInputsManager\";\r\n/**\r\n * Default Inputs manager for the ArcRotateCamera.\r\n * It groups all the default supported inputs for ease of use.\r\n * @see https://doc.babylonjs.com/how_to/customizing_camera_inputs\r\n */\r\nvar ArcRotateCameraInputsManager = /** @class */ (function (_super) {\r\n __extends(ArcRotateCameraInputsManager, _super);\r\n /**\r\n * Instantiates a new ArcRotateCameraInputsManager.\r\n * @param camera Defines the camera the inputs belong to\r\n */\r\n function ArcRotateCameraInputsManager(camera) {\r\n return _super.call(this, camera) || this;\r\n }\r\n /**\r\n * Add mouse wheel input support to the input manager.\r\n * @returns the current input manager\r\n */\r\n ArcRotateCameraInputsManager.prototype.addMouseWheel = function () {\r\n this.add(new ArcRotateCameraMouseWheelInput());\r\n return this;\r\n };\r\n /**\r\n * Add pointers input support to the input manager.\r\n * @returns the current input manager\r\n */\r\n ArcRotateCameraInputsManager.prototype.addPointers = function () {\r\n this.add(new ArcRotateCameraPointersInput());\r\n return this;\r\n };\r\n /**\r\n * Add keyboard input support to the input manager.\r\n * @returns the current input manager\r\n */\r\n ArcRotateCameraInputsManager.prototype.addKeyboard = function () {\r\n this.add(new ArcRotateCameraKeyboardMoveInput());\r\n return this;\r\n };\r\n return ArcRotateCameraInputsManager;\r\n}(CameraInputsManager));\r\nexport { ArcRotateCameraInputsManager };\r\n//# sourceMappingURL=arcRotateCameraInputsManager.js.map","import { __decorate, __extends } from \"tslib\";\r\nimport { serialize, serializeAsVector3 } from \"../Misc/decorators\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { Matrix, Vector3, Vector2 } from \"../Maths/math.vector\";\r\nimport { Node } from \"../node\";\r\nimport { Mesh } from \"../Meshes/mesh\";\r\nimport { AutoRotationBehavior } from \"../Behaviors/Cameras/autoRotationBehavior\";\r\nimport { BouncingBehavior } from \"../Behaviors/Cameras/bouncingBehavior\";\r\nimport { FramingBehavior } from \"../Behaviors/Cameras/framingBehavior\";\r\nimport { Camera } from \"./camera\";\r\nimport { TargetCamera } from \"./targetCamera\";\r\nimport { ArcRotateCameraInputsManager } from \"../Cameras/arcRotateCameraInputsManager\";\r\nimport { Epsilon } from \"../Maths/math.constants\";\r\nimport { Tools } from \"../Misc/tools\";\r\nNode.AddNodeConstructor(\"ArcRotateCamera\", function (name, scene) {\r\n return function () { return new ArcRotateCamera(name, 0, 0, 1.0, Vector3.Zero(), scene); };\r\n});\r\n/**\r\n * This represents an orbital type of camera.\r\n *\r\n * This camera always points towards a given target position and can be rotated around that target with the target as the centre of rotation. It can be controlled with cursors and mouse, or with touch events.\r\n * Think of this camera as one orbiting its target position, or more imaginatively as a spy satellite orbiting the earth. Its position relative to the target (earth) can be set by three parameters, alpha (radians) the longitudinal rotation, beta (radians) the latitudinal rotation and radius the distance from the target position.\r\n * @see https://doc.babylonjs.com/babylon101/cameras#arc-rotate-camera\r\n */\r\nvar ArcRotateCamera = /** @class */ (function (_super) {\r\n __extends(ArcRotateCamera, _super);\r\n /**\r\n * Instantiates a new ArcRotateCamera in a given scene\r\n * @param name Defines the name of the camera\r\n * @param alpha Defines the camera rotation along the logitudinal axis\r\n * @param beta Defines the camera rotation along the latitudinal axis\r\n * @param radius Defines the camera distance from its target\r\n * @param target Defines the camera target\r\n * @param scene Defines the scene the camera belongs to\r\n * @param setActiveOnSceneIfNoneActive Defines wheter the camera should be marked as active if not other active cameras have been defined\r\n */\r\n function ArcRotateCamera(name, alpha, beta, radius, target, scene, setActiveOnSceneIfNoneActive) {\r\n if (setActiveOnSceneIfNoneActive === void 0) { setActiveOnSceneIfNoneActive = true; }\r\n var _this = _super.call(this, name, Vector3.Zero(), scene, setActiveOnSceneIfNoneActive) || this;\r\n /**\r\n * Current inertia value on the longitudinal axis.\r\n * The bigger this number the longer it will take for the camera to stop.\r\n */\r\n _this.inertialAlphaOffset = 0;\r\n /**\r\n * Current inertia value on the latitudinal axis.\r\n * The bigger this number the longer it will take for the camera to stop.\r\n */\r\n _this.inertialBetaOffset = 0;\r\n /**\r\n * Current inertia value on the radius axis.\r\n * The bigger this number the longer it will take for the camera to stop.\r\n */\r\n _this.inertialRadiusOffset = 0;\r\n /**\r\n * Minimum allowed angle on the longitudinal axis.\r\n * This can help limiting how the Camera is able to move in the scene.\r\n */\r\n _this.lowerAlphaLimit = null;\r\n /**\r\n * Maximum allowed angle on the longitudinal axis.\r\n * This can help limiting how the Camera is able to move in the scene.\r\n */\r\n _this.upperAlphaLimit = null;\r\n /**\r\n * Minimum allowed angle on the latitudinal axis.\r\n * This can help limiting how the Camera is able to move in the scene.\r\n */\r\n _this.lowerBetaLimit = 0.01;\r\n /**\r\n * Maximum allowed angle on the latitudinal axis.\r\n * This can help limiting how the Camera is able to move in the scene.\r\n */\r\n _this.upperBetaLimit = Math.PI - 0.01;\r\n /**\r\n * Minimum allowed distance of the camera to the target (The camera can not get closer).\r\n * This can help limiting how the Camera is able to move in the scene.\r\n */\r\n _this.lowerRadiusLimit = null;\r\n /**\r\n * Maximum allowed distance of the camera to the target (The camera can not get further).\r\n * This can help limiting how the Camera is able to move in the scene.\r\n */\r\n _this.upperRadiusLimit = null;\r\n /**\r\n * Defines the current inertia value used during panning of the camera along the X axis.\r\n */\r\n _this.inertialPanningX = 0;\r\n /**\r\n * Defines the current inertia value used during panning of the camera along the Y axis.\r\n */\r\n _this.inertialPanningY = 0;\r\n /**\r\n * Defines the distance used to consider the camera in pan mode vs pinch/zoom.\r\n * Basically if your fingers moves away from more than this distance you will be considered\r\n * in pinch mode.\r\n */\r\n _this.pinchToPanMaxDistance = 20;\r\n /**\r\n * Defines the maximum distance the camera can pan.\r\n * This could help keeping the cammera always in your scene.\r\n */\r\n _this.panningDistanceLimit = null;\r\n /**\r\n * Defines the target of the camera before paning.\r\n */\r\n _this.panningOriginTarget = Vector3.Zero();\r\n /**\r\n * Defines the value of the inertia used during panning.\r\n * 0 would mean stop inertia and one would mean no decelleration at all.\r\n */\r\n _this.panningInertia = 0.9;\r\n //-- end properties for backward compatibility for inputs\r\n /**\r\n * Defines how much the radius should be scaled while zomming on a particular mesh (through the zoomOn function)\r\n */\r\n _this.zoomOnFactor = 1;\r\n /**\r\n * Defines a screen offset for the camera position.\r\n */\r\n _this.targetScreenOffset = Vector2.Zero();\r\n /**\r\n * Allows the camera to be completely reversed.\r\n * If false the camera can not arrive upside down.\r\n */\r\n _this.allowUpsideDown = true;\r\n /**\r\n * Define if double tap/click is used to restore the previously saved state of the camera.\r\n */\r\n _this.useInputToRestoreState = true;\r\n /** @hidden */\r\n _this._viewMatrix = new Matrix();\r\n /**\r\n * Defines the allowed panning axis.\r\n */\r\n _this.panningAxis = new Vector3(1, 1, 0);\r\n /**\r\n * Observable triggered when the mesh target has been changed on the camera.\r\n */\r\n _this.onMeshTargetChangedObservable = new Observable();\r\n /**\r\n * Defines whether the camera should check collision with the objects oh the scene.\r\n * @see https://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity#how-can-i-do-this\r\n */\r\n _this.checkCollisions = false;\r\n /**\r\n * Defines the collision radius of the camera.\r\n * This simulates a sphere around the camera.\r\n * @see https://doc.babylonjs.com/babylon101/cameras,_mesh_collisions_and_gravity#arcrotatecamera\r\n */\r\n _this.collisionRadius = new Vector3(0.5, 0.5, 0.5);\r\n _this._previousPosition = Vector3.Zero();\r\n _this._collisionVelocity = Vector3.Zero();\r\n _this._newPosition = Vector3.Zero();\r\n _this._computationVector = Vector3.Zero();\r\n _this._onCollisionPositionChange = function (collisionId, newPosition, collidedMesh) {\r\n if (collidedMesh === void 0) { collidedMesh = null; }\r\n if (!collidedMesh) {\r\n _this._previousPosition.copyFrom(_this._position);\r\n }\r\n else {\r\n _this.setPosition(newPosition);\r\n if (_this.onCollide) {\r\n _this.onCollide(collidedMesh);\r\n }\r\n }\r\n // Recompute because of constraints\r\n var cosa = Math.cos(_this.alpha);\r\n var sina = Math.sin(_this.alpha);\r\n var cosb = Math.cos(_this.beta);\r\n var sinb = Math.sin(_this.beta);\r\n if (sinb === 0) {\r\n sinb = 0.0001;\r\n }\r\n var target = _this._getTargetPosition();\r\n _this._computationVector.copyFromFloats(_this.radius * cosa * sinb, _this.radius * cosb, _this.radius * sina * sinb);\r\n target.addToRef(_this._computationVector, _this._newPosition);\r\n _this._position.copyFrom(_this._newPosition);\r\n var up = _this.upVector;\r\n if (_this.allowUpsideDown && _this.beta < 0) {\r\n up = up.clone();\r\n up = up.negate();\r\n }\r\n _this._computeViewMatrix(_this._position, target, up);\r\n _this._viewMatrix.addAtIndex(12, _this.targetScreenOffset.x);\r\n _this._viewMatrix.addAtIndex(13, _this.targetScreenOffset.y);\r\n _this._collisionTriggered = false;\r\n };\r\n _this._target = Vector3.Zero();\r\n if (target) {\r\n _this.setTarget(target);\r\n }\r\n _this.alpha = alpha;\r\n _this.beta = beta;\r\n _this.radius = radius;\r\n _this.getViewMatrix();\r\n _this.inputs = new ArcRotateCameraInputsManager(_this);\r\n _this.inputs.addKeyboard().addMouseWheel().addPointers();\r\n return _this;\r\n }\r\n Object.defineProperty(ArcRotateCamera.prototype, \"target\", {\r\n /**\r\n * Defines the target point of the camera.\r\n * The camera looks towards it form the radius distance.\r\n * Please note that you can set the target to a mesh and thus the target will be copied from mesh.position\r\n */\r\n get: function () {\r\n return this._target;\r\n },\r\n set: function (value) {\r\n this.setTarget(value);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"position\", {\r\n /**\r\n * Define the current local position of the camera in the scene\r\n */\r\n get: function () {\r\n return this._position;\r\n },\r\n set: function (newPosition) {\r\n this.setPosition(newPosition);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"upVector\", {\r\n get: function () {\r\n return this._upVector;\r\n },\r\n /**\r\n * The vector the camera should consider as up. (default is Vector3(0, 1, 0) as returned by Vector3.Up())\r\n * Setting this will copy the given vector to the camera's upVector, and set rotation matrices to and from Y up.\r\n * DO NOT set the up vector using copyFrom or copyFromFloats, as this bypasses setting the above matrices.\r\n */\r\n set: function (vec) {\r\n if (!this._upToYMatrix) {\r\n this._YToUpMatrix = new Matrix();\r\n this._upToYMatrix = new Matrix();\r\n this._upVector = Vector3.Zero();\r\n }\r\n vec.normalize();\r\n this._upVector.copyFrom(vec);\r\n this.setMatUp();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Sets the Y-up to camera up-vector rotation matrix, and the up-vector to Y-up rotation matrix.\r\n */\r\n ArcRotateCamera.prototype.setMatUp = function () {\r\n // from y-up to custom-up (used in _getViewMatrix)\r\n Matrix.RotationAlignToRef(Vector3.UpReadOnly, this._upVector, this._YToUpMatrix);\r\n // from custom-up to y-up (used in rebuildAnglesAndRadius)\r\n Matrix.RotationAlignToRef(this._upVector, Vector3.UpReadOnly, this._upToYMatrix);\r\n };\r\n Object.defineProperty(ArcRotateCamera.prototype, \"angularSensibilityX\", {\r\n //-- begin properties for backward compatibility for inputs\r\n /**\r\n * Gets or Set the pointer angular sensibility along the X axis or how fast is the camera rotating.\r\n */\r\n get: function () {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n return pointers.angularSensibilityX;\r\n }\r\n return 0;\r\n },\r\n set: function (value) {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n pointers.angularSensibilityX = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"angularSensibilityY\", {\r\n /**\r\n * Gets or Set the pointer angular sensibility along the Y axis or how fast is the camera rotating.\r\n */\r\n get: function () {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n return pointers.angularSensibilityY;\r\n }\r\n return 0;\r\n },\r\n set: function (value) {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n pointers.angularSensibilityY = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"pinchPrecision\", {\r\n /**\r\n * Gets or Set the pointer pinch precision or how fast is the camera zooming.\r\n */\r\n get: function () {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n return pointers.pinchPrecision;\r\n }\r\n return 0;\r\n },\r\n set: function (value) {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n pointers.pinchPrecision = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"pinchDeltaPercentage\", {\r\n /**\r\n * Gets or Set the pointer pinch delta percentage or how fast is the camera zooming.\r\n * It will be used instead of pinchDeltaPrecision if different from 0.\r\n * It defines the percentage of current camera.radius to use as delta when pinch zoom is used.\r\n */\r\n get: function () {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n return pointers.pinchDeltaPercentage;\r\n }\r\n return 0;\r\n },\r\n set: function (value) {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n pointers.pinchDeltaPercentage = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"useNaturalPinchZoom\", {\r\n /**\r\n * Gets or Set the pointer use natural pinch zoom to override the pinch precision\r\n * and pinch delta percentage.\r\n * When useNaturalPinchZoom is true, multi touch zoom will zoom in such\r\n * that any object in the plane at the camera's target point will scale\r\n * perfectly with finger motion.\r\n */\r\n get: function () {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n return pointers.useNaturalPinchZoom;\r\n }\r\n return false;\r\n },\r\n set: function (value) {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n pointers.useNaturalPinchZoom = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"panningSensibility\", {\r\n /**\r\n * Gets or Set the pointer panning sensibility or how fast is the camera moving.\r\n */\r\n get: function () {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n return pointers.panningSensibility;\r\n }\r\n return 0;\r\n },\r\n set: function (value) {\r\n var pointers = this.inputs.attached[\"pointers\"];\r\n if (pointers) {\r\n pointers.panningSensibility = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"keysUp\", {\r\n /**\r\n * Gets or Set the list of keyboard keys used to control beta angle in a positive direction.\r\n */\r\n get: function () {\r\n var keyboard = this.inputs.attached[\"keyboard\"];\r\n if (keyboard) {\r\n return keyboard.keysUp;\r\n }\r\n return [];\r\n },\r\n set: function (value) {\r\n var keyboard = this.inputs.attached[\"keyboard\"];\r\n if (keyboard) {\r\n keyboard.keysUp = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"keysDown\", {\r\n /**\r\n * Gets or Set the list of keyboard keys used to control beta angle in a negative direction.\r\n */\r\n get: function () {\r\n var keyboard = this.inputs.attached[\"keyboard\"];\r\n if (keyboard) {\r\n return keyboard.keysDown;\r\n }\r\n return [];\r\n },\r\n set: function (value) {\r\n var keyboard = this.inputs.attached[\"keyboard\"];\r\n if (keyboard) {\r\n keyboard.keysDown = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"keysLeft\", {\r\n /**\r\n * Gets or Set the list of keyboard keys used to control alpha angle in a negative direction.\r\n */\r\n get: function () {\r\n var keyboard = this.inputs.attached[\"keyboard\"];\r\n if (keyboard) {\r\n return keyboard.keysLeft;\r\n }\r\n return [];\r\n },\r\n set: function (value) {\r\n var keyboard = this.inputs.attached[\"keyboard\"];\r\n if (keyboard) {\r\n keyboard.keysLeft = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"keysRight\", {\r\n /**\r\n * Gets or Set the list of keyboard keys used to control alpha angle in a positive direction.\r\n */\r\n get: function () {\r\n var keyboard = this.inputs.attached[\"keyboard\"];\r\n if (keyboard) {\r\n return keyboard.keysRight;\r\n }\r\n return [];\r\n },\r\n set: function (value) {\r\n var keyboard = this.inputs.attached[\"keyboard\"];\r\n if (keyboard) {\r\n keyboard.keysRight = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"wheelPrecision\", {\r\n /**\r\n * Gets or Set the mouse wheel precision or how fast is the camera zooming.\r\n */\r\n get: function () {\r\n var mousewheel = this.inputs.attached[\"mousewheel\"];\r\n if (mousewheel) {\r\n return mousewheel.wheelPrecision;\r\n }\r\n return 0;\r\n },\r\n set: function (value) {\r\n var mousewheel = this.inputs.attached[\"mousewheel\"];\r\n if (mousewheel) {\r\n mousewheel.wheelPrecision = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"wheelDeltaPercentage\", {\r\n /**\r\n * Gets or Set the mouse wheel delta percentage or how fast is the camera zooming.\r\n * It will be used instead of pinchDeltaPrecision if different from 0.\r\n * It defines the percentage of current camera.radius to use as delta when pinch zoom is used.\r\n */\r\n get: function () {\r\n var mousewheel = this.inputs.attached[\"mousewheel\"];\r\n if (mousewheel) {\r\n return mousewheel.wheelDeltaPercentage;\r\n }\r\n return 0;\r\n },\r\n set: function (value) {\r\n var mousewheel = this.inputs.attached[\"mousewheel\"];\r\n if (mousewheel) {\r\n mousewheel.wheelDeltaPercentage = value;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"bouncingBehavior\", {\r\n /**\r\n * Gets the bouncing behavior of the camera if it has been enabled.\r\n * @see https://doc.babylonjs.com/how_to/camera_behaviors#bouncing-behavior\r\n */\r\n get: function () {\r\n return this._bouncingBehavior;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"useBouncingBehavior\", {\r\n /**\r\n * Defines if the bouncing behavior of the camera is enabled on the camera.\r\n * @see https://doc.babylonjs.com/how_to/camera_behaviors#bouncing-behavior\r\n */\r\n get: function () {\r\n return this._bouncingBehavior != null;\r\n },\r\n set: function (value) {\r\n if (value === this.useBouncingBehavior) {\r\n return;\r\n }\r\n if (value) {\r\n this._bouncingBehavior = new BouncingBehavior();\r\n this.addBehavior(this._bouncingBehavior);\r\n }\r\n else if (this._bouncingBehavior) {\r\n this.removeBehavior(this._bouncingBehavior);\r\n this._bouncingBehavior = null;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"framingBehavior\", {\r\n /**\r\n * Gets the framing behavior of the camera if it has been enabled.\r\n * @see https://doc.babylonjs.com/how_to/camera_behaviors#framing-behavior\r\n */\r\n get: function () {\r\n return this._framingBehavior;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"useFramingBehavior\", {\r\n /**\r\n * Defines if the framing behavior of the camera is enabled on the camera.\r\n * @see https://doc.babylonjs.com/how_to/camera_behaviors#framing-behavior\r\n */\r\n get: function () {\r\n return this._framingBehavior != null;\r\n },\r\n set: function (value) {\r\n if (value === this.useFramingBehavior) {\r\n return;\r\n }\r\n if (value) {\r\n this._framingBehavior = new FramingBehavior();\r\n this.addBehavior(this._framingBehavior);\r\n }\r\n else if (this._framingBehavior) {\r\n this.removeBehavior(this._framingBehavior);\r\n this._framingBehavior = null;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"autoRotationBehavior\", {\r\n /**\r\n * Gets the auto rotation behavior of the camera if it has been enabled.\r\n * @see https://doc.babylonjs.com/how_to/camera_behaviors#autorotation-behavior\r\n */\r\n get: function () {\r\n return this._autoRotationBehavior;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(ArcRotateCamera.prototype, \"useAutoRotationBehavior\", {\r\n /**\r\n * Defines if the auto rotation behavior of the camera is enabled on the camera.\r\n * @see https://doc.babylonjs.com/how_to/camera_behaviors#autorotation-behavior\r\n */\r\n get: function () {\r\n return this._autoRotationBehavior != null;\r\n },\r\n set: function (value) {\r\n if (value === this.useAutoRotationBehavior) {\r\n return;\r\n }\r\n if (value) {\r\n this._autoRotationBehavior = new AutoRotationBehavior();\r\n this.addBehavior(this._autoRotationBehavior);\r\n }\r\n else if (this._autoRotationBehavior) {\r\n this.removeBehavior(this._autoRotationBehavior);\r\n this._autoRotationBehavior = null;\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n // Cache\r\n /** @hidden */\r\n ArcRotateCamera.prototype._initCache = function () {\r\n _super.prototype._initCache.call(this);\r\n this._cache._target = new Vector3(Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE);\r\n this._cache.alpha = undefined;\r\n this._cache.beta = undefined;\r\n this._cache.radius = undefined;\r\n this._cache.targetScreenOffset = Vector2.Zero();\r\n };\r\n /** @hidden */\r\n ArcRotateCamera.prototype._updateCache = function (ignoreParentClass) {\r\n if (!ignoreParentClass) {\r\n _super.prototype._updateCache.call(this);\r\n }\r\n this._cache._target.copyFrom(this._getTargetPosition());\r\n this._cache.alpha = this.alpha;\r\n this._cache.beta = this.beta;\r\n this._cache.radius = this.radius;\r\n this._cache.targetScreenOffset.copyFrom(this.targetScreenOffset);\r\n };\r\n ArcRotateCamera.prototype._getTargetPosition = function () {\r\n if (this._targetHost && this._targetHost.getAbsolutePosition) {\r\n var pos = this._targetHost.absolutePosition;\r\n if (this._targetBoundingCenter) {\r\n pos.addToRef(this._targetBoundingCenter, this._target);\r\n }\r\n else {\r\n this._target.copyFrom(pos);\r\n }\r\n }\r\n var lockedTargetPosition = this._getLockedTargetPosition();\r\n if (lockedTargetPosition) {\r\n return lockedTargetPosition;\r\n }\r\n return this._target;\r\n };\r\n /**\r\n * Stores the current state of the camera (alpha, beta, radius and target)\r\n * @returns the camera itself\r\n */\r\n ArcRotateCamera.prototype.storeState = function () {\r\n this._storedAlpha = this.alpha;\r\n this._storedBeta = this.beta;\r\n this._storedRadius = this.radius;\r\n this._storedTarget = this._getTargetPosition().clone();\r\n this._storedTargetScreenOffset = this.targetScreenOffset.clone();\r\n return _super.prototype.storeState.call(this);\r\n };\r\n /**\r\n * @hidden\r\n * Restored camera state. You must call storeState() first\r\n */\r\n ArcRotateCamera.prototype._restoreStateValues = function () {\r\n if (!_super.prototype._restoreStateValues.call(this)) {\r\n return false;\r\n }\r\n this.setTarget(this._storedTarget.clone());\r\n this.alpha = this._storedAlpha;\r\n this.beta = this._storedBeta;\r\n this.radius = this._storedRadius;\r\n this.targetScreenOffset = this._storedTargetScreenOffset.clone();\r\n this.inertialAlphaOffset = 0;\r\n this.inertialBetaOffset = 0;\r\n this.inertialRadiusOffset = 0;\r\n this.inertialPanningX = 0;\r\n this.inertialPanningY = 0;\r\n return true;\r\n };\r\n // Synchronized\r\n /** @hidden */\r\n ArcRotateCamera.prototype._isSynchronizedViewMatrix = function () {\r\n if (!_super.prototype._isSynchronizedViewMatrix.call(this)) {\r\n return false;\r\n }\r\n return this._cache._target.equals(this._getTargetPosition()) && this._cache.alpha === this.alpha && this._cache.beta === this.beta && this._cache.radius === this.radius && this._cache.targetScreenOffset.equals(this.targetScreenOffset);\r\n };\r\n /**\r\n * Attached controls to the current camera.\r\n * @param ignored defines an ignored parameter kept for backward compatibility. If you want to define the source input element, you can set engine.inputElement before calling camera.attachControl\r\n * @param noPreventDefault Defines whether event caught by the controls should call preventdefault() (https://developer.mozilla.org/en-US/docs/Web/API/Event/preventDefault)\r\n * @param useCtrlForPanning Defines whether ctrl is used for paning within the controls\r\n * @param panningMouseButton Defines whether panning is allowed through mouse click button\r\n */\r\n ArcRotateCamera.prototype.attachControl = function (ignored, noPreventDefault, useCtrlForPanning, panningMouseButton) {\r\n var _this = this;\r\n if (useCtrlForPanning === void 0) { useCtrlForPanning = true; }\r\n if (panningMouseButton === void 0) { panningMouseButton = 2; }\r\n noPreventDefault = Tools.BackCompatCameraNoPreventDefault(arguments);\r\n this._useCtrlForPanning = useCtrlForPanning;\r\n this._panningMouseButton = panningMouseButton;\r\n // backwards compatibility\r\n if (typeof arguments[0] === \"boolean\") {\r\n if (arguments.length > 1) {\r\n this._useCtrlForPanning = arguments[1];\r\n }\r\n if (arguments.length > 2) {\r\n this._panningMouseButton = arguments[2];\r\n }\r\n }\r\n this.inputs.attachElement(noPreventDefault);\r\n this._reset = function () {\r\n _this.inertialAlphaOffset = 0;\r\n _this.inertialBetaOffset = 0;\r\n _this.inertialRadiusOffset = 0;\r\n _this.inertialPanningX = 0;\r\n _this.inertialPanningY = 0;\r\n };\r\n };\r\n /**\r\n * Detach the current controls from the specified dom element.\r\n * @param ignored defines an ignored parameter kept for backward compatibility. If you want to define the source input element, you can set engine.inputElement before calling camera.attachControl\r\n */\r\n ArcRotateCamera.prototype.detachControl = function (ignored) {\r\n this.inputs.detachElement();\r\n if (this._reset) {\r\n this._reset();\r\n }\r\n };\r\n /** @hidden */\r\n ArcRotateCamera.prototype._checkInputs = function () {\r\n //if (async) collision inspection was triggered, don't update the camera's position - until the collision callback was called.\r\n if (this._collisionTriggered) {\r\n return;\r\n }\r\n this.inputs.checkInputs();\r\n // Inertia\r\n if (this.inertialAlphaOffset !== 0 || this.inertialBetaOffset !== 0 || this.inertialRadiusOffset !== 0) {\r\n var inertialAlphaOffset = this.inertialAlphaOffset;\r\n if (this.beta <= 0) {\r\n inertialAlphaOffset *= -1;\r\n }\r\n if (this.getScene().useRightHandedSystem) {\r\n inertialAlphaOffset *= -1;\r\n }\r\n if (this.parent && this.parent._getWorldMatrixDeterminant() < 0) {\r\n inertialAlphaOffset *= -1;\r\n }\r\n this.alpha += inertialAlphaOffset;\r\n this.beta += this.inertialBetaOffset;\r\n this.radius -= this.inertialRadiusOffset;\r\n this.inertialAlphaOffset *= this.inertia;\r\n this.inertialBetaOffset *= this.inertia;\r\n this.inertialRadiusOffset *= this.inertia;\r\n if (Math.abs(this.inertialAlphaOffset) < Epsilon) {\r\n this.inertialAlphaOffset = 0;\r\n }\r\n if (Math.abs(this.inertialBetaOffset) < Epsilon) {\r\n this.inertialBetaOffset = 0;\r\n }\r\n if (Math.abs(this.inertialRadiusOffset) < this.speed * Epsilon) {\r\n this.inertialRadiusOffset = 0;\r\n }\r\n }\r\n // Panning inertia\r\n if (this.inertialPanningX !== 0 || this.inertialPanningY !== 0) {\r\n if (!this._localDirection) {\r\n this._localDirection = Vector3.Zero();\r\n this._transformedDirection = Vector3.Zero();\r\n }\r\n this._localDirection.copyFromFloats(this.inertialPanningX, this.inertialPanningY, this.inertialPanningY);\r\n this._localDirection.multiplyInPlace(this.panningAxis);\r\n this._viewMatrix.invertToRef(this._cameraTransformMatrix);\r\n Vector3.TransformNormalToRef(this._localDirection, this._cameraTransformMatrix, this._transformedDirection);\r\n //Eliminate y if map panning is enabled (panningAxis == 1,0,1)\r\n if (!this.panningAxis.y) {\r\n this._transformedDirection.y = 0;\r\n }\r\n if (!this._targetHost) {\r\n if (this.panningDistanceLimit) {\r\n this._transformedDirection.addInPlace(this._target);\r\n var distanceSquared = Vector3.DistanceSquared(this._transformedDirection, this.panningOriginTarget);\r\n if (distanceSquared <= this.panningDistanceLimit * this.panningDistanceLimit) {\r\n this._target.copyFrom(this._transformedDirection);\r\n }\r\n }\r\n else {\r\n this._target.addInPlace(this._transformedDirection);\r\n }\r\n }\r\n this.inertialPanningX *= this.panningInertia;\r\n this.inertialPanningY *= this.panningInertia;\r\n if (Math.abs(this.inertialPanningX) < this.speed * Epsilon) {\r\n this.inertialPanningX = 0;\r\n }\r\n if (Math.abs(this.inertialPanningY) < this.speed * Epsilon) {\r\n this.inertialPanningY = 0;\r\n }\r\n }\r\n // Limits\r\n this._checkLimits();\r\n _super.prototype._checkInputs.call(this);\r\n };\r\n ArcRotateCamera.prototype._checkLimits = function () {\r\n if (this.lowerBetaLimit === null || this.lowerBetaLimit === undefined) {\r\n if (this.allowUpsideDown && this.beta > Math.PI) {\r\n this.beta = this.beta - 2 * Math.PI;\r\n }\r\n }\r\n else {\r\n if (this.beta < this.lowerBetaLimit) {\r\n this.beta = this.lowerBetaLimit;\r\n }\r\n }\r\n if (this.upperBetaLimit === null || this.upperBetaLimit === undefined) {\r\n if (this.allowUpsideDown && this.beta < -Math.PI) {\r\n this.beta = this.beta + 2 * Math.PI;\r\n }\r\n }\r\n else {\r\n if (this.beta > this.upperBetaLimit) {\r\n this.beta = this.upperBetaLimit;\r\n }\r\n }\r\n if (this.lowerAlphaLimit !== null && this.alpha < this.lowerAlphaLimit) {\r\n this.alpha = this.lowerAlphaLimit;\r\n }\r\n if (this.upperAlphaLimit !== null && this.alpha > this.upperAlphaLimit) {\r\n this.alpha = this.upperAlphaLimit;\r\n }\r\n if (this.lowerRadiusLimit !== null && this.radius < this.lowerRadiusLimit) {\r\n this.radius = this.lowerRadiusLimit;\r\n this.inertialRadiusOffset = 0;\r\n }\r\n if (this.upperRadiusLimit !== null && this.radius > this.upperRadiusLimit) {\r\n this.radius = this.upperRadiusLimit;\r\n this.inertialRadiusOffset = 0;\r\n }\r\n };\r\n /**\r\n * Rebuilds angles (alpha, beta) and radius from the give position and target\r\n */\r\n ArcRotateCamera.prototype.rebuildAnglesAndRadius = function () {\r\n this._position.subtractToRef(this._getTargetPosition(), this._computationVector);\r\n // need to rotate to Y up equivalent if up vector not Axis.Y\r\n if (this._upVector.x !== 0 || this._upVector.y !== 1.0 || this._upVector.z !== 0) {\r\n Vector3.TransformCoordinatesToRef(this._computationVector, this._upToYMatrix, this._computationVector);\r\n }\r\n this.radius = this._computationVector.length();\r\n if (this.radius === 0) {\r\n this.radius = 0.0001; // Just to avoid division by zero\r\n }\r\n // Alpha\r\n var previousAlpha = this.alpha;\r\n if (this._computationVector.x === 0 && this._computationVector.z === 0) {\r\n this.alpha = Math.PI / 2; // avoid division by zero when looking along up axis, and set to acos(0)\r\n }\r\n else {\r\n this.alpha = Math.acos(this._computationVector.x / Math.sqrt(Math.pow(this._computationVector.x, 2) + Math.pow(this._computationVector.z, 2)));\r\n }\r\n if (this._computationVector.z < 0) {\r\n this.alpha = 2 * Math.PI - this.alpha;\r\n }\r\n // Calculate the number of revolutions between the new and old alpha values.\r\n var alphaCorrectionTurns = Math.round((previousAlpha - this.alpha) / (2.0 * Math.PI));\r\n // Adjust alpha so that its numerical representation is the closest one to the old value.\r\n this.alpha += alphaCorrectionTurns * 2.0 * Math.PI;\r\n // Beta\r\n this.beta = Math.acos(this._computationVector.y / this.radius);\r\n this._checkLimits();\r\n };\r\n /**\r\n * Use a position to define the current camera related information like alpha, beta and radius\r\n * @param position Defines the position to set the camera at\r\n */\r\n ArcRotateCamera.prototype.setPosition = function (position) {\r\n if (this._position.equals(position)) {\r\n return;\r\n }\r\n this._position.copyFrom(position);\r\n this.rebuildAnglesAndRadius();\r\n };\r\n /**\r\n * Defines the target the camera should look at.\r\n * This will automatically adapt alpha beta and radius to fit within the new target.\r\n * @param target Defines the new target as a Vector or a mesh\r\n * @param toBoundingCenter In case of a mesh target, defines whether to target the mesh position or its bounding information center\r\n * @param allowSamePosition If false, prevents reapplying the new computed position if it is identical to the current one (optim)\r\n */\r\n ArcRotateCamera.prototype.setTarget = function (target, toBoundingCenter, allowSamePosition) {\r\n if (toBoundingCenter === void 0) { toBoundingCenter = false; }\r\n if (allowSamePosition === void 0) { allowSamePosition = false; }\r\n if (target.getBoundingInfo) {\r\n if (toBoundingCenter) {\r\n this._targetBoundingCenter = target.getBoundingInfo().boundingBox.centerWorld.clone();\r\n }\r\n else {\r\n this._targetBoundingCenter = null;\r\n }\r\n target.computeWorldMatrix();\r\n this._targetHost = target;\r\n this._target = this._getTargetPosition();\r\n this.onMeshTargetChangedObservable.notifyObservers(this._targetHost);\r\n }\r\n else {\r\n var newTarget = target;\r\n var currentTarget = this._getTargetPosition();\r\n if (currentTarget && !allowSamePosition && currentTarget.equals(newTarget)) {\r\n return;\r\n }\r\n this._targetHost = null;\r\n this._target = newTarget;\r\n this._targetBoundingCenter = null;\r\n this.onMeshTargetChangedObservable.notifyObservers(null);\r\n }\r\n this.rebuildAnglesAndRadius();\r\n };\r\n /** @hidden */\r\n ArcRotateCamera.prototype._getViewMatrix = function () {\r\n // Compute\r\n var cosa = Math.cos(this.alpha);\r\n var sina = Math.sin(this.alpha);\r\n var cosb = Math.cos(this.beta);\r\n var sinb = Math.sin(this.beta);\r\n if (sinb === 0) {\r\n sinb = 0.0001;\r\n }\r\n if (this.radius === 0) {\r\n this.radius = 0.0001; // Just to avoid division by zero\r\n }\r\n var target = this._getTargetPosition();\r\n this._computationVector.copyFromFloats(this.radius * cosa * sinb, this.radius * cosb, this.radius * sina * sinb);\r\n // Rotate according to up vector\r\n if (this._upVector.x !== 0 || this._upVector.y !== 1.0 || this._upVector.z !== 0) {\r\n Vector3.TransformCoordinatesToRef(this._computationVector, this._YToUpMatrix, this._computationVector);\r\n }\r\n target.addToRef(this._computationVector, this._newPosition);\r\n if (this.getScene().collisionsEnabled && this.checkCollisions) {\r\n var coordinator = this.getScene().collisionCoordinator;\r\n if (!this._collider) {\r\n this._collider = coordinator.createCollider();\r\n }\r\n this._collider._radius = this.collisionRadius;\r\n this._newPosition.subtractToRef(this._position, this._collisionVelocity);\r\n this._collisionTriggered = true;\r\n coordinator.getNewPosition(this._position, this._collisionVelocity, this._collider, 3, null, this._onCollisionPositionChange, this.uniqueId);\r\n }\r\n else {\r\n this._position.copyFrom(this._newPosition);\r\n var up = this.upVector;\r\n if (this.allowUpsideDown && sinb < 0) {\r\n up = up.negate();\r\n }\r\n this._computeViewMatrix(this._position, target, up);\r\n this._viewMatrix.addAtIndex(12, this.targetScreenOffset.x);\r\n this._viewMatrix.addAtIndex(13, this.targetScreenOffset.y);\r\n }\r\n this._currentTarget = target;\r\n return this._viewMatrix;\r\n };\r\n /**\r\n * Zooms on a mesh to be at the min distance where we could see it fully in the current viewport.\r\n * @param meshes Defines the mesh to zoom on\r\n * @param doNotUpdateMaxZ Defines whether or not maxZ should be updated whilst zooming on the mesh (this can happen if the mesh is big and the maxradius pretty small for instance)\r\n */\r\n ArcRotateCamera.prototype.zoomOn = function (meshes, doNotUpdateMaxZ) {\r\n if (doNotUpdateMaxZ === void 0) { doNotUpdateMaxZ = false; }\r\n meshes = meshes || this.getScene().meshes;\r\n var minMaxVector = Mesh.MinMax(meshes);\r\n var distance = Vector3.Distance(minMaxVector.min, minMaxVector.max);\r\n this.radius = distance * this.zoomOnFactor;\r\n this.focusOn({ min: minMaxVector.min, max: minMaxVector.max, distance: distance }, doNotUpdateMaxZ);\r\n };\r\n /**\r\n * Focus on a mesh or a bounding box. This adapts the target and maxRadius if necessary but does not update the current radius.\r\n * The target will be changed but the radius\r\n * @param meshesOrMinMaxVectorAndDistance Defines the mesh or bounding info to focus on\r\n * @param doNotUpdateMaxZ Defines whether or not maxZ should be updated whilst zooming on the mesh (this can happen if the mesh is big and the maxradius pretty small for instance)\r\n */\r\n ArcRotateCamera.prototype.focusOn = function (meshesOrMinMaxVectorAndDistance, doNotUpdateMaxZ) {\r\n if (doNotUpdateMaxZ === void 0) { doNotUpdateMaxZ = false; }\r\n var meshesOrMinMaxVector;\r\n var distance;\r\n if (meshesOrMinMaxVectorAndDistance.min === undefined) {\r\n // meshes\r\n var meshes = meshesOrMinMaxVectorAndDistance || this.getScene().meshes;\r\n meshesOrMinMaxVector = Mesh.MinMax(meshes);\r\n distance = Vector3.Distance(meshesOrMinMaxVector.min, meshesOrMinMaxVector.max);\r\n }\r\n else {\r\n //minMaxVector and distance\r\n var minMaxVectorAndDistance = meshesOrMinMaxVectorAndDistance;\r\n meshesOrMinMaxVector = minMaxVectorAndDistance;\r\n distance = minMaxVectorAndDistance.distance;\r\n }\r\n this._target = Mesh.Center(meshesOrMinMaxVector);\r\n if (!doNotUpdateMaxZ) {\r\n this.maxZ = distance * 2;\r\n }\r\n };\r\n /**\r\n * @override\r\n * Override Camera.createRigCamera\r\n */\r\n ArcRotateCamera.prototype.createRigCamera = function (name, cameraIndex) {\r\n var alphaShift = 0;\r\n switch (this.cameraRigMode) {\r\n case Camera.RIG_MODE_STEREOSCOPIC_ANAGLYPH:\r\n case Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL:\r\n case Camera.RIG_MODE_STEREOSCOPIC_OVERUNDER:\r\n case Camera.RIG_MODE_STEREOSCOPIC_INTERLACED:\r\n case Camera.RIG_MODE_VR:\r\n alphaShift = this._cameraRigParams.stereoHalfAngle * (cameraIndex === 0 ? 1 : -1);\r\n break;\r\n case Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED:\r\n alphaShift = this._cameraRigParams.stereoHalfAngle * (cameraIndex === 0 ? -1 : 1);\r\n break;\r\n }\r\n var rigCam = new ArcRotateCamera(name, this.alpha + alphaShift, this.beta, this.radius, this._target, this.getScene());\r\n rigCam._cameraRigParams = {};\r\n rigCam.isRigCamera = true;\r\n rigCam.rigParent = this;\r\n rigCam.upVector = this.upVector;\r\n return rigCam;\r\n };\r\n /**\r\n * @hidden\r\n * @override\r\n * Override Camera._updateRigCameras\r\n */\r\n ArcRotateCamera.prototype._updateRigCameras = function () {\r\n var camLeft = this._rigCameras[0];\r\n var camRight = this._rigCameras[1];\r\n camLeft.beta = camRight.beta = this.beta;\r\n switch (this.cameraRigMode) {\r\n case Camera.RIG_MODE_STEREOSCOPIC_ANAGLYPH:\r\n case Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_PARALLEL:\r\n case Camera.RIG_MODE_STEREOSCOPIC_OVERUNDER:\r\n case Camera.RIG_MODE_STEREOSCOPIC_INTERLACED:\r\n case Camera.RIG_MODE_VR:\r\n camLeft.alpha = this.alpha - this._cameraRigParams.stereoHalfAngle;\r\n camRight.alpha = this.alpha + this._cameraRigParams.stereoHalfAngle;\r\n break;\r\n case Camera.RIG_MODE_STEREOSCOPIC_SIDEBYSIDE_CROSSEYED:\r\n camLeft.alpha = this.alpha + this._cameraRigParams.stereoHalfAngle;\r\n camRight.alpha = this.alpha - this._cameraRigParams.stereoHalfAngle;\r\n break;\r\n }\r\n _super.prototype._updateRigCameras.call(this);\r\n };\r\n /**\r\n * Destroy the camera and release the current resources hold by it.\r\n */\r\n ArcRotateCamera.prototype.dispose = function () {\r\n this.inputs.clear();\r\n _super.prototype.dispose.call(this);\r\n };\r\n /**\r\n * Gets the current object class name.\r\n * @return the class name\r\n */\r\n ArcRotateCamera.prototype.getClassName = function () {\r\n return \"ArcRotateCamera\";\r\n };\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"alpha\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"beta\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"radius\", void 0);\r\n __decorate([\r\n serializeAsVector3(\"target\")\r\n ], ArcRotateCamera.prototype, \"_target\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"inertialAlphaOffset\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"inertialBetaOffset\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"inertialRadiusOffset\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"lowerAlphaLimit\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"upperAlphaLimit\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"lowerBetaLimit\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"upperBetaLimit\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"lowerRadiusLimit\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"upperRadiusLimit\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"inertialPanningX\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"inertialPanningY\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"pinchToPanMaxDistance\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"panningDistanceLimit\", void 0);\r\n __decorate([\r\n serializeAsVector3()\r\n ], ArcRotateCamera.prototype, \"panningOriginTarget\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"panningInertia\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"zoomOnFactor\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"targetScreenOffset\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"allowUpsideDown\", void 0);\r\n __decorate([\r\n serialize()\r\n ], ArcRotateCamera.prototype, \"useInputToRestoreState\", void 0);\r\n return ArcRotateCamera;\r\n}(TargetCamera));\r\nexport { ArcRotateCamera };\r\n//# sourceMappingURL=arcRotateCamera.js.map","// Unique ID creation requires a high quality random # generator. In the browser we therefore\n// require the crypto API and do not support built-in fallback to lower quality random number\n// generators (like Math.random()).\n// getRandomValues needs to be invoked in a context where \"this\" is a Crypto implementation. Also,\n// find the complete implementation of crypto (msCrypto) on IE11.\nvar getRandomValues = typeof crypto !== 'undefined' && crypto.getRandomValues && crypto.getRandomValues.bind(crypto) || typeof msCrypto !== 'undefined' && typeof msCrypto.getRandomValues === 'function' && msCrypto.getRandomValues.bind(msCrypto);\nvar rnds8 = new Uint8Array(16);\nexport default function rng() {\n if (!getRandomValues) {\n throw new Error('crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported');\n }\n\n return getRandomValues(rnds8);\n}","export default /^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;","import validate from './validate.js';\n/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\n\nvar byteToHex = [];\n\nfor (var i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).substr(1));\n}\n\nfunction stringify(arr) {\n var offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n // Note: Be careful editing this code! It's been tuned for performance\n // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434\n var uuid = (byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]).toLowerCase(); // Consistency check for valid UUID. If this throws, it's likely due to one\n // of the following:\n // - One or more input array values don't map to a hex octet (leading to\n // \"undefined\" in the uuid)\n // - Invalid input values for the RFC `version` or `variant` fields\n\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n\n return uuid;\n}\n\nexport default stringify;","import REGEX from './regex.js';\n\nfunction validate(uuid) {\n return typeof uuid === 'string' && REGEX.test(uuid);\n}\n\nexport default validate;","import rng from './rng.js';\nimport stringify from './stringify.js'; // **`v1()` - Generate time-based UUID**\n//\n// Inspired by https://github.com/LiosK/UUID.js\n// and http://docs.python.org/library/uuid.html\n\nvar _nodeId;\n\nvar _clockseq; // Previous uuid creation time\n\n\nvar _lastMSecs = 0;\nvar _lastNSecs = 0; // See https://github.com/uuidjs/uuid for API details\n\nfunction v1(options, buf, offset) {\n var i = buf && offset || 0;\n var b = buf || new Array(16);\n options = options || {};\n var node = options.node || _nodeId;\n var clockseq = options.clockseq !== undefined ? options.clockseq : _clockseq; // node and clockseq need to be initialized to random values if they're not\n // specified. We do this lazily to minimize issues related to insufficient\n // system entropy. See #189\n\n if (node == null || clockseq == null) {\n var seedBytes = options.random || (options.rng || rng)();\n\n if (node == null) {\n // Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1)\n node = _nodeId = [seedBytes[0] | 0x01, seedBytes[1], seedBytes[2], seedBytes[3], seedBytes[4], seedBytes[5]];\n }\n\n if (clockseq == null) {\n // Per 4.2.2, randomize (14 bit) clockseq\n clockseq = _clockseq = (seedBytes[6] << 8 | seedBytes[7]) & 0x3fff;\n }\n } // UUID timestamps are 100 nano-second units since the Gregorian epoch,\n // (1582-10-15 00:00). JSNumbers aren't precise enough for this, so\n // time is handled internally as 'msecs' (integer milliseconds) and 'nsecs'\n // (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00.\n\n\n var msecs = options.msecs !== undefined ? options.msecs : Date.now(); // Per 4.2.1.2, use count of uuid's generated during the current clock\n // cycle to simulate higher resolution clock\n\n var nsecs = options.nsecs !== undefined ? options.nsecs : _lastNSecs + 1; // Time since last uuid creation (in msecs)\n\n var dt = msecs - _lastMSecs + (nsecs - _lastNSecs) / 10000; // Per 4.2.1.2, Bump clockseq on clock regression\n\n if (dt < 0 && options.clockseq === undefined) {\n clockseq = clockseq + 1 & 0x3fff;\n } // Reset nsecs if clock regresses (new clockseq) or we've moved onto a new\n // time interval\n\n\n if ((dt < 0 || msecs > _lastMSecs) && options.nsecs === undefined) {\n nsecs = 0;\n } // Per 4.2.1.2 Throw error if too many uuids are requested\n\n\n if (nsecs >= 10000) {\n throw new Error(\"uuid.v1(): Can't create more than 10M uuids/sec\");\n }\n\n _lastMSecs = msecs;\n _lastNSecs = nsecs;\n _clockseq = clockseq; // Per 4.1.4 - Convert from unix epoch to Gregorian epoch\n\n msecs += 12219292800000; // `time_low`\n\n var tl = ((msecs & 0xfffffff) * 10000 + nsecs) % 0x100000000;\n b[i++] = tl >>> 24 & 0xff;\n b[i++] = tl >>> 16 & 0xff;\n b[i++] = tl >>> 8 & 0xff;\n b[i++] = tl & 0xff; // `time_mid`\n\n var tmh = msecs / 0x100000000 * 10000 & 0xfffffff;\n b[i++] = tmh >>> 8 & 0xff;\n b[i++] = tmh & 0xff; // `time_high_and_version`\n\n b[i++] = tmh >>> 24 & 0xf | 0x10; // include version\n\n b[i++] = tmh >>> 16 & 0xff; // `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant)\n\n b[i++] = clockseq >>> 8 | 0x80; // `clock_seq_low`\n\n b[i++] = clockseq & 0xff; // `node`\n\n for (var n = 0; n < 6; ++n) {\n b[i + n] = node[n];\n }\n\n return buf || stringify(b);\n}\n\nexport default v1;","import validate from './validate.js';\n\nfunction parse(uuid) {\n if (!validate(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n var v;\n var arr = new Uint8Array(16); // Parse ########-....-....-....-............\n\n arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;\n arr[1] = v >>> 16 & 0xff;\n arr[2] = v >>> 8 & 0xff;\n arr[3] = v & 0xff; // Parse ........-####-....-....-............\n\n arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;\n arr[5] = v & 0xff; // Parse ........-....-####-....-............\n\n arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;\n arr[7] = v & 0xff; // Parse ........-....-....-####-............\n\n arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;\n arr[9] = v & 0xff; // Parse ........-....-....-....-############\n // (Use \"/\" to avoid 32-bit truncation when bit-shifting high-order bytes)\n\n arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;\n arr[11] = v / 0x100000000 & 0xff;\n arr[12] = v >>> 24 & 0xff;\n arr[13] = v >>> 16 & 0xff;\n arr[14] = v >>> 8 & 0xff;\n arr[15] = v & 0xff;\n return arr;\n}\n\nexport default parse;","import stringify from './stringify.js';\nimport parse from './parse.js';\n\nfunction stringToBytes(str) {\n str = unescape(encodeURIComponent(str)); // UTF8 escape\n\n var bytes = [];\n\n for (var i = 0; i < str.length; ++i) {\n bytes.push(str.charCodeAt(i));\n }\n\n return bytes;\n}\n\nexport var DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';\nexport var URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';\nexport default function (name, version, hashfunc) {\n function generateUUID(value, namespace, buf, offset) {\n if (typeof value === 'string') {\n value = stringToBytes(value);\n }\n\n if (typeof namespace === 'string') {\n namespace = parse(namespace);\n }\n\n if (namespace.length !== 16) {\n throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');\n } // Compute hash of namespace and value, Per 4.3\n // Future: Use spread syntax when supported on all platforms, e.g. `bytes =\n // hashfunc([...namespace, ... value])`\n\n\n var bytes = new Uint8Array(16 + value.length);\n bytes.set(namespace);\n bytes.set(value, namespace.length);\n bytes = hashfunc(bytes);\n bytes[6] = bytes[6] & 0x0f | version;\n bytes[8] = bytes[8] & 0x3f | 0x80;\n\n if (buf) {\n offset = offset || 0;\n\n for (var i = 0; i < 16; ++i) {\n buf[offset + i] = bytes[i];\n }\n\n return buf;\n }\n\n return stringify(bytes);\n } // Function#name is not settable on some platforms (#270)\n\n\n try {\n generateUUID.name = name; // eslint-disable-next-line no-empty\n } catch (err) {} // For CommonJS default export support\n\n\n generateUUID.DNS = DNS;\n generateUUID.URL = URL;\n return generateUUID;\n}","/*\n * Browser-compatible JavaScript MD5\n *\n * Modification of JavaScript MD5\n * https://github.com/blueimp/JavaScript-MD5\n *\n * Copyright 2011, Sebastian Tschan\n * https://blueimp.net\n *\n * Licensed under the MIT license:\n * https://opensource.org/licenses/MIT\n *\n * Based on\n * A JavaScript implementation of the RSA Data Security, Inc. MD5 Message\n * Digest Algorithm, as defined in RFC 1321.\n * Version 2.2 Copyright (C) Paul Johnston 1999 - 2009\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n * Distributed under the BSD License\n * See http://pajhome.org.uk/crypt/md5 for more info.\n */\nfunction md5(bytes) {\n if (typeof bytes === 'string') {\n var msg = unescape(encodeURIComponent(bytes)); // UTF8 escape\n\n bytes = new Uint8Array(msg.length);\n\n for (var i = 0; i < msg.length; ++i) {\n bytes[i] = msg.charCodeAt(i);\n }\n }\n\n return md5ToHexEncodedArray(wordsToMd5(bytesToWords(bytes), bytes.length * 8));\n}\n/*\n * Convert an array of little-endian words to an array of bytes\n */\n\n\nfunction md5ToHexEncodedArray(input) {\n var output = [];\n var length32 = input.length * 32;\n var hexTab = '0123456789abcdef';\n\n for (var i = 0; i < length32; i += 8) {\n var x = input[i >> 5] >>> i % 32 & 0xff;\n var hex = parseInt(hexTab.charAt(x >>> 4 & 0x0f) + hexTab.charAt(x & 0x0f), 16);\n output.push(hex);\n }\n\n return output;\n}\n/**\n * Calculate output length with padding and bit length\n */\n\n\nfunction getOutputLength(inputLength8) {\n return (inputLength8 + 64 >>> 9 << 4) + 14 + 1;\n}\n/*\n * Calculate the MD5 of an array of little-endian words, and a bit length.\n */\n\n\nfunction wordsToMd5(x, len) {\n /* append padding */\n x[len >> 5] |= 0x80 << len % 32;\n x[getOutputLength(len) - 1] = len;\n var a = 1732584193;\n var b = -271733879;\n var c = -1732584194;\n var d = 271733878;\n\n for (var i = 0; i < x.length; i += 16) {\n var olda = a;\n var oldb = b;\n var oldc = c;\n var oldd = d;\n a = md5ff(a, b, c, d, x[i], 7, -680876936);\n d = md5ff(d, a, b, c, x[i + 1], 12, -389564586);\n c = md5ff(c, d, a, b, x[i + 2], 17, 606105819);\n b = md5ff(b, c, d, a, x[i + 3], 22, -1044525330);\n a = md5ff(a, b, c, d, x[i + 4], 7, -176418897);\n d = md5ff(d, a, b, c, x[i + 5], 12, 1200080426);\n c = md5ff(c, d, a, b, x[i + 6], 17, -1473231341);\n b = md5ff(b, c, d, a, x[i + 7], 22, -45705983);\n a = md5ff(a, b, c, d, x[i + 8], 7, 1770035416);\n d = md5ff(d, a, b, c, x[i + 9], 12, -1958414417);\n c = md5ff(c, d, a, b, x[i + 10], 17, -42063);\n b = md5ff(b, c, d, a, x[i + 11], 22, -1990404162);\n a = md5ff(a, b, c, d, x[i + 12], 7, 1804603682);\n d = md5ff(d, a, b, c, x[i + 13], 12, -40341101);\n c = md5ff(c, d, a, b, x[i + 14], 17, -1502002290);\n b = md5ff(b, c, d, a, x[i + 15], 22, 1236535329);\n a = md5gg(a, b, c, d, x[i + 1], 5, -165796510);\n d = md5gg(d, a, b, c, x[i + 6], 9, -1069501632);\n c = md5gg(c, d, a, b, x[i + 11], 14, 643717713);\n b = md5gg(b, c, d, a, x[i], 20, -373897302);\n a = md5gg(a, b, c, d, x[i + 5], 5, -701558691);\n d = md5gg(d, a, b, c, x[i + 10], 9, 38016083);\n c = md5gg(c, d, a, b, x[i + 15], 14, -660478335);\n b = md5gg(b, c, d, a, x[i + 4], 20, -405537848);\n a = md5gg(a, b, c, d, x[i + 9], 5, 568446438);\n d = md5gg(d, a, b, c, x[i + 14], 9, -1019803690);\n c = md5gg(c, d, a, b, x[i + 3], 14, -187363961);\n b = md5gg(b, c, d, a, x[i + 8], 20, 1163531501);\n a = md5gg(a, b, c, d, x[i + 13], 5, -1444681467);\n d = md5gg(d, a, b, c, x[i + 2], 9, -51403784);\n c = md5gg(c, d, a, b, x[i + 7], 14, 1735328473);\n b = md5gg(b, c, d, a, x[i + 12], 20, -1926607734);\n a = md5hh(a, b, c, d, x[i + 5], 4, -378558);\n d = md5hh(d, a, b, c, x[i + 8], 11, -2022574463);\n c = md5hh(c, d, a, b, x[i + 11], 16, 1839030562);\n b = md5hh(b, c, d, a, x[i + 14], 23, -35309556);\n a = md5hh(a, b, c, d, x[i + 1], 4, -1530992060);\n d = md5hh(d, a, b, c, x[i + 4], 11, 1272893353);\n c = md5hh(c, d, a, b, x[i + 7], 16, -155497632);\n b = md5hh(b, c, d, a, x[i + 10], 23, -1094730640);\n a = md5hh(a, b, c, d, x[i + 13], 4, 681279174);\n d = md5hh(d, a, b, c, x[i], 11, -358537222);\n c = md5hh(c, d, a, b, x[i + 3], 16, -722521979);\n b = md5hh(b, c, d, a, x[i + 6], 23, 76029189);\n a = md5hh(a, b, c, d, x[i + 9], 4, -640364487);\n d = md5hh(d, a, b, c, x[i + 12], 11, -421815835);\n c = md5hh(c, d, a, b, x[i + 15], 16, 530742520);\n b = md5hh(b, c, d, a, x[i + 2], 23, -995338651);\n a = md5ii(a, b, c, d, x[i], 6, -198630844);\n d = md5ii(d, a, b, c, x[i + 7], 10, 1126891415);\n c = md5ii(c, d, a, b, x[i + 14], 15, -1416354905);\n b = md5ii(b, c, d, a, x[i + 5], 21, -57434055);\n a = md5ii(a, b, c, d, x[i + 12], 6, 1700485571);\n d = md5ii(d, a, b, c, x[i + 3], 10, -1894986606);\n c = md5ii(c, d, a, b, x[i + 10], 15, -1051523);\n b = md5ii(b, c, d, a, x[i + 1], 21, -2054922799);\n a = md5ii(a, b, c, d, x[i + 8], 6, 1873313359);\n d = md5ii(d, a, b, c, x[i + 15], 10, -30611744);\n c = md5ii(c, d, a, b, x[i + 6], 15, -1560198380);\n b = md5ii(b, c, d, a, x[i + 13], 21, 1309151649);\n a = md5ii(a, b, c, d, x[i + 4], 6, -145523070);\n d = md5ii(d, a, b, c, x[i + 11], 10, -1120210379);\n c = md5ii(c, d, a, b, x[i + 2], 15, 718787259);\n b = md5ii(b, c, d, a, x[i + 9], 21, -343485551);\n a = safeAdd(a, olda);\n b = safeAdd(b, oldb);\n c = safeAdd(c, oldc);\n d = safeAdd(d, oldd);\n }\n\n return [a, b, c, d];\n}\n/*\n * Convert an array bytes to an array of little-endian words\n * Characters >255 have their high-byte silently ignored.\n */\n\n\nfunction bytesToWords(input) {\n if (input.length === 0) {\n return [];\n }\n\n var length8 = input.length * 8;\n var output = new Uint32Array(getOutputLength(length8));\n\n for (var i = 0; i < length8; i += 8) {\n output[i >> 5] |= (input[i / 8] & 0xff) << i % 32;\n }\n\n return output;\n}\n/*\n * Add integers, wrapping at 2^32. This uses 16-bit operations internally\n * to work around bugs in some JS interpreters.\n */\n\n\nfunction safeAdd(x, y) {\n var lsw = (x & 0xffff) + (y & 0xffff);\n var msw = (x >> 16) + (y >> 16) + (lsw >> 16);\n return msw << 16 | lsw & 0xffff;\n}\n/*\n * Bitwise rotate a 32-bit number to the left.\n */\n\n\nfunction bitRotateLeft(num, cnt) {\n return num << cnt | num >>> 32 - cnt;\n}\n/*\n * These functions implement the four basic operations the algorithm uses.\n */\n\n\nfunction md5cmn(q, a, b, x, s, t) {\n return safeAdd(bitRotateLeft(safeAdd(safeAdd(a, q), safeAdd(x, t)), s), b);\n}\n\nfunction md5ff(a, b, c, d, x, s, t) {\n return md5cmn(b & c | ~b & d, a, b, x, s, t);\n}\n\nfunction md5gg(a, b, c, d, x, s, t) {\n return md5cmn(b & d | c & ~d, a, b, x, s, t);\n}\n\nfunction md5hh(a, b, c, d, x, s, t) {\n return md5cmn(b ^ c ^ d, a, b, x, s, t);\n}\n\nfunction md5ii(a, b, c, d, x, s, t) {\n return md5cmn(c ^ (b | ~d), a, b, x, s, t);\n}\n\nexport default md5;","import v35 from './v35.js';\nimport md5 from './md5.js';\nvar v3 = v35('v3', 0x30, md5);\nexport default v3;","import rng from './rng.js';\nimport stringify from './stringify.js';\n\nfunction v4(options, buf, offset) {\n options = options || {};\n var rnds = options.random || (options.rng || rng)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n\n rnds[6] = rnds[6] & 0x0f | 0x40;\n rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided\n\n if (buf) {\n offset = offset || 0;\n\n for (var i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n\n return buf;\n }\n\n return stringify(rnds);\n}\n\nexport default v4;","// Adapted from Chris Veness' SHA1 code at\n// http://www.movable-type.co.uk/scripts/sha1.html\nfunction f(s, x, y, z) {\n switch (s) {\n case 0:\n return x & y ^ ~x & z;\n\n case 1:\n return x ^ y ^ z;\n\n case 2:\n return x & y ^ x & z ^ y & z;\n\n case 3:\n return x ^ y ^ z;\n }\n}\n\nfunction ROTL(x, n) {\n return x << n | x >>> 32 - n;\n}\n\nfunction sha1(bytes) {\n var K = [0x5a827999, 0x6ed9eba1, 0x8f1bbcdc, 0xca62c1d6];\n var H = [0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0];\n\n if (typeof bytes === 'string') {\n var msg = unescape(encodeURIComponent(bytes)); // UTF8 escape\n\n bytes = [];\n\n for (var i = 0; i < msg.length; ++i) {\n bytes.push(msg.charCodeAt(i));\n }\n } else if (!Array.isArray(bytes)) {\n // Convert Array-like to Array\n bytes = Array.prototype.slice.call(bytes);\n }\n\n bytes.push(0x80);\n var l = bytes.length / 4 + 2;\n var N = Math.ceil(l / 16);\n var M = new Array(N);\n\n for (var _i = 0; _i < N; ++_i) {\n var arr = new Uint32Array(16);\n\n for (var j = 0; j < 16; ++j) {\n arr[j] = bytes[_i * 64 + j * 4] << 24 | bytes[_i * 64 + j * 4 + 1] << 16 | bytes[_i * 64 + j * 4 + 2] << 8 | bytes[_i * 64 + j * 4 + 3];\n }\n\n M[_i] = arr;\n }\n\n M[N - 1][14] = (bytes.length - 1) * 8 / Math.pow(2, 32);\n M[N - 1][14] = Math.floor(M[N - 1][14]);\n M[N - 1][15] = (bytes.length - 1) * 8 & 0xffffffff;\n\n for (var _i2 = 0; _i2 < N; ++_i2) {\n var W = new Uint32Array(80);\n\n for (var t = 0; t < 16; ++t) {\n W[t] = M[_i2][t];\n }\n\n for (var _t = 16; _t < 80; ++_t) {\n W[_t] = ROTL(W[_t - 3] ^ W[_t - 8] ^ W[_t - 14] ^ W[_t - 16], 1);\n }\n\n var a = H[0];\n var b = H[1];\n var c = H[2];\n var d = H[3];\n var e = H[4];\n\n for (var _t2 = 0; _t2 < 80; ++_t2) {\n var s = Math.floor(_t2 / 20);\n var T = ROTL(a, 5) + f(s, b, c, d) + e + K[s] + W[_t2] >>> 0;\n e = d;\n d = c;\n c = ROTL(b, 30) >>> 0;\n b = a;\n a = T;\n }\n\n H[0] = H[0] + a >>> 0;\n H[1] = H[1] + b >>> 0;\n H[2] = H[2] + c >>> 0;\n H[3] = H[3] + d >>> 0;\n H[4] = H[4] + e >>> 0;\n }\n\n return [H[0] >> 24 & 0xff, H[0] >> 16 & 0xff, H[0] >> 8 & 0xff, H[0] & 0xff, H[1] >> 24 & 0xff, H[1] >> 16 & 0xff, H[1] >> 8 & 0xff, H[1] & 0xff, H[2] >> 24 & 0xff, H[2] >> 16 & 0xff, H[2] >> 8 & 0xff, H[2] & 0xff, H[3] >> 24 & 0xff, H[3] >> 16 & 0xff, H[3] >> 8 & 0xff, H[3] & 0xff, H[4] >> 24 & 0xff, H[4] >> 16 & 0xff, H[4] >> 8 & 0xff, H[4] & 0xff];\n}\n\nexport default sha1;","import v35 from './v35.js';\nimport sha1 from './sha1.js';\nvar v5 = v35('v5', 0x50, sha1);\nexport default v5;","export default '00000000-0000-0000-0000-000000000000';","import validate from './validate.js';\n\nfunction version(uuid) {\n if (!validate(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n return parseInt(uuid.substr(14, 1), 16);\n}\n\nexport default version;","import { __assign } from \"tslib\";\r\nimport { InternalTexture, InternalTextureSource } from '../../Materials/Textures/internalTexture';\r\nimport { Logger } from '../../Misc/logger';\r\nimport { RenderTargetCreationOptions } from '../../Materials/Textures/renderTargetCreationOptions';\r\nimport { ThinEngine } from '../thinEngine';\r\nThinEngine.prototype.createRenderTargetTexture = function (size, options) {\r\n var fullOptions = new RenderTargetCreationOptions();\r\n if (options !== undefined && typeof options === \"object\") {\r\n fullOptions.generateMipMaps = options.generateMipMaps;\r\n fullOptions.generateDepthBuffer = !!options.generateDepthBuffer;\r\n fullOptions.generateStencilBuffer = !!options.generateStencilBuffer;\r\n fullOptions.type = options.type === undefined ? 0 : options.type;\r\n fullOptions.samplingMode = options.samplingMode === undefined ? 3 : options.samplingMode;\r\n fullOptions.format = options.format === undefined ? 5 : options.format;\r\n }\r\n else {\r\n fullOptions.generateMipMaps = options;\r\n fullOptions.generateDepthBuffer = true;\r\n fullOptions.generateStencilBuffer = false;\r\n fullOptions.type = 0;\r\n fullOptions.samplingMode = 3;\r\n fullOptions.format = 5;\r\n }\r\n if (fullOptions.type === 1 && !this._caps.textureFloatLinearFiltering) {\r\n // if floating point linear (gl.FLOAT) then force to NEAREST_SAMPLINGMODE\r\n fullOptions.samplingMode = 1;\r\n }\r\n else if (fullOptions.type === 2 && !this._caps.textureHalfFloatLinearFiltering) {\r\n // if floating point linear (HALF_FLOAT) then force to NEAREST_SAMPLINGMODE\r\n fullOptions.samplingMode = 1;\r\n }\r\n if (fullOptions.type === 1 && !this._caps.textureFloat) {\r\n fullOptions.type = 0;\r\n Logger.Warn(\"Float textures are not supported. Render target forced to TEXTURETYPE_UNSIGNED_BYTE type\");\r\n }\r\n var gl = this._gl;\r\n var texture = new InternalTexture(this, InternalTextureSource.RenderTarget);\r\n var width = size.width || size;\r\n var height = size.height || size;\r\n var layers = size.layers || 0;\r\n var filters = this._getSamplingParameters(fullOptions.samplingMode, fullOptions.generateMipMaps ? true : false);\r\n var target = layers !== 0 ? gl.TEXTURE_2D_ARRAY : gl.TEXTURE_2D;\r\n var sizedFormat = this._getRGBABufferInternalSizedFormat(fullOptions.type, fullOptions.format);\r\n var internalFormat = this._getInternalFormat(fullOptions.format);\r\n var type = this._getWebGLTextureType(fullOptions.type);\r\n // Bind\r\n this._bindTextureDirectly(target, texture);\r\n if (layers !== 0) {\r\n texture.is2DArray = true;\r\n gl.texImage3D(target, 0, sizedFormat, width, height, layers, 0, internalFormat, type, null);\r\n }\r\n else {\r\n gl.texImage2D(target, 0, sizedFormat, width, height, 0, internalFormat, type, null);\r\n }\r\n gl.texParameteri(target, gl.TEXTURE_MAG_FILTER, filters.mag);\r\n gl.texParameteri(target, gl.TEXTURE_MIN_FILTER, filters.min);\r\n gl.texParameteri(target, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\r\n gl.texParameteri(target, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\r\n // MipMaps\r\n if (fullOptions.generateMipMaps) {\r\n this._gl.generateMipmap(target);\r\n }\r\n this._bindTextureDirectly(target, null);\r\n var currentFrameBuffer = this._currentFramebuffer;\r\n // Create the framebuffer\r\n var framebuffer = gl.createFramebuffer();\r\n this._bindUnboundFramebuffer(framebuffer);\r\n texture._depthStencilBuffer = this._setupFramebufferDepthAttachments(fullOptions.generateStencilBuffer ? true : false, fullOptions.generateDepthBuffer, width, height);\r\n // No need to rebind on every frame\r\n if (!texture.is2DArray) {\r\n gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture._webGLTexture, 0);\r\n }\r\n this._bindUnboundFramebuffer(currentFrameBuffer);\r\n texture._framebuffer = framebuffer;\r\n texture.baseWidth = width;\r\n texture.baseHeight = height;\r\n texture.width = width;\r\n texture.height = height;\r\n texture.depth = layers;\r\n texture.isReady = true;\r\n texture.samples = 1;\r\n texture.generateMipMaps = fullOptions.generateMipMaps ? true : false;\r\n texture.samplingMode = fullOptions.samplingMode;\r\n texture.type = fullOptions.type;\r\n texture.format = fullOptions.format;\r\n texture._generateDepthBuffer = fullOptions.generateDepthBuffer;\r\n texture._generateStencilBuffer = fullOptions.generateStencilBuffer ? true : false;\r\n this._internalTexturesCache.push(texture);\r\n return texture;\r\n};\r\nThinEngine.prototype.createDepthStencilTexture = function (size, options) {\r\n if (options.isCube) {\r\n var width = size.width || size;\r\n return this._createDepthStencilCubeTexture(width, options);\r\n }\r\n else {\r\n return this._createDepthStencilTexture(size, options);\r\n }\r\n};\r\nThinEngine.prototype._createDepthStencilTexture = function (size, options) {\r\n var gl = this._gl;\r\n var layers = size.layers || 0;\r\n var target = layers !== 0 ? gl.TEXTURE_2D_ARRAY : gl.TEXTURE_2D;\r\n var internalTexture = new InternalTexture(this, InternalTextureSource.Depth);\r\n if (!this._caps.depthTextureExtension) {\r\n Logger.Error(\"Depth texture is not supported by your browser or hardware.\");\r\n return internalTexture;\r\n }\r\n var internalOptions = __assign({ bilinearFiltering: false, comparisonFunction: 0, generateStencil: false }, options);\r\n this._bindTextureDirectly(target, internalTexture, true);\r\n this._setupDepthStencilTexture(internalTexture, size, internalOptions.generateStencil, internalOptions.bilinearFiltering, internalOptions.comparisonFunction);\r\n var type = internalOptions.generateStencil ? gl.UNSIGNED_INT_24_8 : gl.UNSIGNED_INT;\r\n var internalFormat = internalOptions.generateStencil ? gl.DEPTH_STENCIL : gl.DEPTH_COMPONENT;\r\n var sizedFormat = internalFormat;\r\n if (this.webGLVersion > 1) {\r\n sizedFormat = internalOptions.generateStencil ? gl.DEPTH24_STENCIL8 : gl.DEPTH_COMPONENT24;\r\n }\r\n if (internalTexture.is2DArray) {\r\n gl.texImage3D(target, 0, sizedFormat, internalTexture.width, internalTexture.height, layers, 0, internalFormat, type, null);\r\n }\r\n else {\r\n gl.texImage2D(target, 0, sizedFormat, internalTexture.width, internalTexture.height, 0, internalFormat, type, null);\r\n }\r\n this._bindTextureDirectly(target, null);\r\n return internalTexture;\r\n};\r\n//# sourceMappingURL=engine.renderTarget.js.map","import { __assign } from \"tslib\";\r\nimport { InternalTexture, InternalTextureSource } from '../../Materials/Textures/internalTexture';\r\nimport { Logger } from '../../Misc/logger';\r\nimport { ThinEngine } from '../thinEngine';\r\nThinEngine.prototype.createRenderTargetCubeTexture = function (size, options) {\r\n var fullOptions = __assign({ generateMipMaps: true, generateDepthBuffer: true, generateStencilBuffer: false, type: 0, samplingMode: 3, format: 5 }, options);\r\n fullOptions.generateStencilBuffer = fullOptions.generateDepthBuffer && fullOptions.generateStencilBuffer;\r\n if (fullOptions.type === 1 && !this._caps.textureFloatLinearFiltering) {\r\n // if floating point linear (gl.FLOAT) then force to NEAREST_SAMPLINGMODE\r\n fullOptions.samplingMode = 1;\r\n }\r\n else if (fullOptions.type === 2 && !this._caps.textureHalfFloatLinearFiltering) {\r\n // if floating point linear (HALF_FLOAT) then force to NEAREST_SAMPLINGMODE\r\n fullOptions.samplingMode = 1;\r\n }\r\n var gl = this._gl;\r\n var texture = new InternalTexture(this, InternalTextureSource.RenderTarget);\r\n this._bindTextureDirectly(gl.TEXTURE_CUBE_MAP, texture, true);\r\n var filters = this._getSamplingParameters(fullOptions.samplingMode, fullOptions.generateMipMaps);\r\n if (fullOptions.type === 1 && !this._caps.textureFloat) {\r\n fullOptions.type = 0;\r\n Logger.Warn(\"Float textures are not supported. Cube render target forced to TEXTURETYPE_UNESIGNED_BYTE type\");\r\n }\r\n gl.texParameteri(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_MAG_FILTER, filters.mag);\r\n gl.texParameteri(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_MIN_FILTER, filters.min);\r\n gl.texParameteri(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\r\n gl.texParameteri(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\r\n for (var face = 0; face < 6; face++) {\r\n gl.texImage2D((gl.TEXTURE_CUBE_MAP_POSITIVE_X + face), 0, this._getRGBABufferInternalSizedFormat(fullOptions.type, fullOptions.format), size, size, 0, this._getInternalFormat(fullOptions.format), this._getWebGLTextureType(fullOptions.type), null);\r\n }\r\n // Create the framebuffer\r\n var framebuffer = gl.createFramebuffer();\r\n this._bindUnboundFramebuffer(framebuffer);\r\n texture._depthStencilBuffer = this._setupFramebufferDepthAttachments(fullOptions.generateStencilBuffer, fullOptions.generateDepthBuffer, size, size);\r\n // MipMaps\r\n if (fullOptions.generateMipMaps) {\r\n gl.generateMipmap(gl.TEXTURE_CUBE_MAP);\r\n }\r\n // Unbind\r\n this._bindTextureDirectly(gl.TEXTURE_CUBE_MAP, null);\r\n this._bindUnboundFramebuffer(null);\r\n texture._framebuffer = framebuffer;\r\n texture.width = size;\r\n texture.height = size;\r\n texture.isReady = true;\r\n texture.isCube = true;\r\n texture.samples = 1;\r\n texture.generateMipMaps = fullOptions.generateMipMaps;\r\n texture.samplingMode = fullOptions.samplingMode;\r\n texture.type = fullOptions.type;\r\n texture.format = fullOptions.format;\r\n texture._generateDepthBuffer = fullOptions.generateDepthBuffer;\r\n texture._generateStencilBuffer = fullOptions.generateStencilBuffer;\r\n this._internalTexturesCache.push(texture);\r\n return texture;\r\n};\r\n//# sourceMappingURL=engine.renderTargetCube.js.map","import { __extends } from \"tslib\";\r\nimport { Observable } from \"../../Misc/observable\";\r\nimport { Tools } from \"../../Misc/tools\";\r\nimport { Matrix, Vector3 } from \"../../Maths/math.vector\";\r\nimport { Texture } from \"../../Materials/Textures/texture\";\r\nimport { PostProcessManager } from \"../../PostProcesses/postProcessManager\";\r\nimport { RenderingManager } from \"../../Rendering/renderingManager\";\r\nimport \"../../Engines/Extensions/engine.renderTarget\";\r\nimport \"../../Engines/Extensions/engine.renderTargetCube\";\r\nimport { Engine } from '../../Engines/engine';\r\n/**\r\n * This Helps creating a texture that will be created from a camera in your scene.\r\n * It is basically a dynamic texture that could be used to create special effects for instance.\r\n * Actually, It is the base of lot of effects in the framework like post process, shadows, effect layers and rendering pipelines...\r\n */\r\nvar RenderTargetTexture = /** @class */ (function (_super) {\r\n __extends(RenderTargetTexture, _super);\r\n /**\r\n * Instantiate a render target texture. This is mainly used to render of screen the scene to for instance apply post processse\r\n * or used a shadow, depth texture...\r\n * @param name The friendly name of the texture\r\n * @param size The size of the RTT (number if square, or {width: number, height:number} or {ratio:} to define a ratio from the main scene)\r\n * @param scene The scene the RTT belongs to. The latest created scene will be used if not precised.\r\n * @param generateMipMaps True if mip maps need to be generated after render.\r\n * @param doNotChangeAspectRatio True to not change the aspect ratio of the scene in the RTT\r\n * @param type The type of the buffer in the RTT (int, half float, float...)\r\n * @param isCube True if a cube texture needs to be created\r\n * @param samplingMode The sampling mode to be usedwith the render target (Linear, Nearest...)\r\n * @param generateDepthBuffer True to generate a depth buffer\r\n * @param generateStencilBuffer True to generate a stencil buffer\r\n * @param isMulti True if multiple textures need to be created (Draw Buffers)\r\n * @param format The internal format of the buffer in the RTT (RED, RG, RGB, RGBA, ALPHA...)\r\n * @param delayAllocation if the texture allocation should be delayed (default: false)\r\n */\r\n function RenderTargetTexture(name, size, scene, generateMipMaps, doNotChangeAspectRatio, type, isCube, samplingMode, generateDepthBuffer, generateStencilBuffer, isMulti, format, delayAllocation) {\r\n if (doNotChangeAspectRatio === void 0) { doNotChangeAspectRatio = true; }\r\n if (type === void 0) { type = 0; }\r\n if (isCube === void 0) { isCube = false; }\r\n if (samplingMode === void 0) { samplingMode = Texture.TRILINEAR_SAMPLINGMODE; }\r\n if (generateDepthBuffer === void 0) { generateDepthBuffer = true; }\r\n if (generateStencilBuffer === void 0) { generateStencilBuffer = false; }\r\n if (isMulti === void 0) { isMulti = false; }\r\n if (format === void 0) { format = 5; }\r\n if (delayAllocation === void 0) { delayAllocation = false; }\r\n var _this = _super.call(this, null, scene, !generateMipMaps) || this;\r\n /**\r\n * Define if particles should be rendered in your texture.\r\n */\r\n _this.renderParticles = true;\r\n /**\r\n * Define if sprites should be rendered in your texture.\r\n */\r\n _this.renderSprites = false;\r\n /**\r\n * Define if the camera viewport should be respected while rendering the texture or if the render should be done to the entire texture.\r\n */\r\n _this.ignoreCameraViewport = false;\r\n /**\r\n * An event triggered when the texture is unbind.\r\n */\r\n _this.onBeforeBindObservable = new Observable();\r\n /**\r\n * An event triggered when the texture is unbind.\r\n */\r\n _this.onAfterUnbindObservable = new Observable();\r\n /**\r\n * An event triggered before rendering the texture\r\n */\r\n _this.onBeforeRenderObservable = new Observable();\r\n /**\r\n * An event triggered after rendering the texture\r\n */\r\n _this.onAfterRenderObservable = new Observable();\r\n /**\r\n * An event triggered after the texture clear\r\n */\r\n _this.onClearObservable = new Observable();\r\n /**\r\n * An event triggered when the texture is resized.\r\n */\r\n _this.onResizeObservable = new Observable();\r\n _this._currentRefreshId = -1;\r\n _this._refreshRate = 1;\r\n _this._samples = 1;\r\n /**\r\n * Gets or sets the center of the bounding box associated with the texture (when in cube mode)\r\n * It must define where the camera used to render the texture is set\r\n */\r\n _this.boundingBoxPosition = Vector3.Zero();\r\n scene = _this.getScene();\r\n if (!scene) {\r\n return _this;\r\n }\r\n _this._coordinatesMode = Texture.PROJECTION_MODE;\r\n _this.renderList = new Array();\r\n _this.name = name;\r\n _this.isRenderTarget = true;\r\n _this._initialSizeParameter = size;\r\n _this._processSizeParameter(size);\r\n _this._resizeObserver = _this.getScene().getEngine().onResizeObservable.add(function () {\r\n });\r\n _this._generateMipMaps = generateMipMaps ? true : false;\r\n _this._doNotChangeAspectRatio = doNotChangeAspectRatio;\r\n // Rendering groups\r\n _this._renderingManager = new RenderingManager(scene);\r\n _this._renderingManager._useSceneAutoClearSetup = true;\r\n if (isMulti) {\r\n return _this;\r\n }\r\n _this._renderTargetOptions = {\r\n generateMipMaps: generateMipMaps,\r\n type: type,\r\n format: format,\r\n samplingMode: samplingMode,\r\n generateDepthBuffer: generateDepthBuffer,\r\n generateStencilBuffer: generateStencilBuffer\r\n };\r\n if (samplingMode === Texture.NEAREST_SAMPLINGMODE) {\r\n _this.wrapU = Texture.CLAMP_ADDRESSMODE;\r\n _this.wrapV = Texture.CLAMP_ADDRESSMODE;\r\n }\r\n if (!delayAllocation) {\r\n if (isCube) {\r\n _this._texture = scene.getEngine().createRenderTargetCubeTexture(_this.getRenderSize(), _this._renderTargetOptions);\r\n _this.coordinatesMode = Texture.INVCUBIC_MODE;\r\n _this._textureMatrix = Matrix.Identity();\r\n }\r\n else {\r\n _this._texture = scene.getEngine().createRenderTargetTexture(_this._size, _this._renderTargetOptions);\r\n }\r\n }\r\n return _this;\r\n }\r\n Object.defineProperty(RenderTargetTexture.prototype, \"renderList\", {\r\n /**\r\n * Use this list to define the list of mesh you want to render.\r\n */\r\n get: function () {\r\n return this._renderList;\r\n },\r\n set: function (value) {\r\n this._renderList = value;\r\n if (this._renderList) {\r\n this._hookArray(this._renderList);\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n RenderTargetTexture.prototype._hookArray = function (array) {\r\n var _this = this;\r\n var oldPush = array.push;\r\n array.push = function () {\r\n var items = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n items[_i] = arguments[_i];\r\n }\r\n var wasEmpty = array.length === 0;\r\n var result = oldPush.apply(array, items);\r\n if (wasEmpty && _this.getScene()) {\r\n _this.getScene().meshes.forEach(function (mesh) {\r\n mesh._markSubMeshesAsLightDirty();\r\n });\r\n }\r\n return result;\r\n };\r\n var oldSplice = array.splice;\r\n array.splice = function (index, deleteCount) {\r\n var deleted = oldSplice.apply(array, [index, deleteCount]);\r\n if (array.length === 0) {\r\n _this.getScene().meshes.forEach(function (mesh) {\r\n mesh._markSubMeshesAsLightDirty();\r\n });\r\n }\r\n return deleted;\r\n };\r\n };\r\n Object.defineProperty(RenderTargetTexture.prototype, \"onAfterUnbind\", {\r\n /**\r\n * Set a after unbind callback in the texture.\r\n * This has been kept for backward compatibility and use of onAfterUnbindObservable is recommended.\r\n */\r\n set: function (callback) {\r\n if (this._onAfterUnbindObserver) {\r\n this.onAfterUnbindObservable.remove(this._onAfterUnbindObserver);\r\n }\r\n this._onAfterUnbindObserver = this.onAfterUnbindObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(RenderTargetTexture.prototype, \"onBeforeRender\", {\r\n /**\r\n * Set a before render callback in the texture.\r\n * This has been kept for backward compatibility and use of onBeforeRenderObservable is recommended.\r\n */\r\n set: function (callback) {\r\n if (this._onBeforeRenderObserver) {\r\n this.onBeforeRenderObservable.remove(this._onBeforeRenderObserver);\r\n }\r\n this._onBeforeRenderObserver = this.onBeforeRenderObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(RenderTargetTexture.prototype, \"onAfterRender\", {\r\n /**\r\n * Set a after render callback in the texture.\r\n * This has been kept for backward compatibility and use of onAfterRenderObservable is recommended.\r\n */\r\n set: function (callback) {\r\n if (this._onAfterRenderObserver) {\r\n this.onAfterRenderObservable.remove(this._onAfterRenderObserver);\r\n }\r\n this._onAfterRenderObserver = this.onAfterRenderObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(RenderTargetTexture.prototype, \"onClear\", {\r\n /**\r\n * Set a clear callback in the texture.\r\n * This has been kept for backward compatibility and use of onClearObservable is recommended.\r\n */\r\n set: function (callback) {\r\n if (this._onClearObserver) {\r\n this.onClearObservable.remove(this._onClearObserver);\r\n }\r\n this._onClearObserver = this.onClearObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(RenderTargetTexture.prototype, \"renderTargetOptions\", {\r\n /**\r\n * Gets render target creation options that were used.\r\n */\r\n get: function () {\r\n return this._renderTargetOptions;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n RenderTargetTexture.prototype._onRatioRescale = function () {\r\n if (this._sizeRatio) {\r\n this.resize(this._initialSizeParameter);\r\n }\r\n };\r\n Object.defineProperty(RenderTargetTexture.prototype, \"boundingBoxSize\", {\r\n get: function () {\r\n return this._boundingBoxSize;\r\n },\r\n /**\r\n * Gets or sets the size of the bounding box associated with the texture (when in cube mode)\r\n * When defined, the cubemap will switch to local mode\r\n * @see https://community.arm.com/graphics/b/blog/posts/reflections-based-on-local-cubemaps-in-unity\r\n * @example https://www.babylonjs-playground.com/#RNASML\r\n */\r\n set: function (value) {\r\n if (this._boundingBoxSize && this._boundingBoxSize.equals(value)) {\r\n return;\r\n }\r\n this._boundingBoxSize = value;\r\n var scene = this.getScene();\r\n if (scene) {\r\n scene.markAllMaterialsAsDirty(1);\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(RenderTargetTexture.prototype, \"depthStencilTexture\", {\r\n /**\r\n * In case the RTT has been created with a depth texture, get the associated\r\n * depth texture.\r\n * Otherwise, return null.\r\n */\r\n get: function () {\r\n var _a;\r\n return ((_a = this.getInternalTexture()) === null || _a === void 0 ? void 0 : _a._depthStencilTexture) || null;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Creates a depth stencil texture.\r\n * This is only available in WebGL 2 or with the depth texture extension available.\r\n * @param comparisonFunction Specifies the comparison function to set on the texture. If 0 or undefined, the texture is not in comparison mode\r\n * @param bilinearFiltering Specifies whether or not bilinear filtering is enable on the texture\r\n * @param generateStencil Specifies whether or not a stencil should be allocated in the texture\r\n */\r\n RenderTargetTexture.prototype.createDepthStencilTexture = function (comparisonFunction, bilinearFiltering, generateStencil) {\r\n if (comparisonFunction === void 0) { comparisonFunction = 0; }\r\n if (bilinearFiltering === void 0) { bilinearFiltering = true; }\r\n if (generateStencil === void 0) { generateStencil = false; }\r\n var internalTexture = this.getInternalTexture();\r\n if (!this.getScene() || !internalTexture) {\r\n return;\r\n }\r\n var engine = this.getScene().getEngine();\r\n internalTexture._depthStencilTexture = engine.createDepthStencilTexture(this._size, {\r\n bilinearFiltering: bilinearFiltering,\r\n comparisonFunction: comparisonFunction,\r\n generateStencil: generateStencil,\r\n isCube: this.isCube\r\n });\r\n };\r\n RenderTargetTexture.prototype._processSizeParameter = function (size) {\r\n if (size.ratio) {\r\n this._sizeRatio = size.ratio;\r\n var engine = this._getEngine();\r\n this._size = {\r\n width: this._bestReflectionRenderTargetDimension(engine.getRenderWidth(), this._sizeRatio),\r\n height: this._bestReflectionRenderTargetDimension(engine.getRenderHeight(), this._sizeRatio)\r\n };\r\n }\r\n else {\r\n this._size = size;\r\n }\r\n };\r\n Object.defineProperty(RenderTargetTexture.prototype, \"samples\", {\r\n /**\r\n * Define the number of samples to use in case of MSAA.\r\n * It defaults to one meaning no MSAA has been enabled.\r\n */\r\n get: function () {\r\n return this._samples;\r\n },\r\n set: function (value) {\r\n if (this._samples === value) {\r\n return;\r\n }\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n this._samples = scene.getEngine().updateRenderTargetTextureSampleCount(this._texture, value);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Resets the refresh counter of the texture and start bak from scratch.\r\n * Could be useful to regenerate the texture if it is setup to render only once.\r\n */\r\n RenderTargetTexture.prototype.resetRefreshCounter = function () {\r\n this._currentRefreshId = -1;\r\n };\r\n Object.defineProperty(RenderTargetTexture.prototype, \"refreshRate\", {\r\n /**\r\n * Define the refresh rate of the texture or the rendering frequency.\r\n * Use 0 to render just once, 1 to render on every frame, 2 to render every two frames and so on...\r\n */\r\n get: function () {\r\n return this._refreshRate;\r\n },\r\n set: function (value) {\r\n this._refreshRate = value;\r\n this.resetRefreshCounter();\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Adds a post process to the render target rendering passes.\r\n * @param postProcess define the post process to add\r\n */\r\n RenderTargetTexture.prototype.addPostProcess = function (postProcess) {\r\n if (!this._postProcessManager) {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n this._postProcessManager = new PostProcessManager(scene);\r\n this._postProcesses = new Array();\r\n }\r\n this._postProcesses.push(postProcess);\r\n this._postProcesses[0].autoClear = false;\r\n };\r\n /**\r\n * Clear all the post processes attached to the render target\r\n * @param dispose define if the cleared post processesshould also be disposed (false by default)\r\n */\r\n RenderTargetTexture.prototype.clearPostProcesses = function (dispose) {\r\n if (dispose === void 0) { dispose = false; }\r\n if (!this._postProcesses) {\r\n return;\r\n }\r\n if (dispose) {\r\n for (var _i = 0, _a = this._postProcesses; _i < _a.length; _i++) {\r\n var postProcess = _a[_i];\r\n postProcess.dispose();\r\n }\r\n }\r\n this._postProcesses = [];\r\n };\r\n /**\r\n * Remove one of the post process from the list of attached post processes to the texture\r\n * @param postProcess define the post process to remove from the list\r\n */\r\n RenderTargetTexture.prototype.removePostProcess = function (postProcess) {\r\n if (!this._postProcesses) {\r\n return;\r\n }\r\n var index = this._postProcesses.indexOf(postProcess);\r\n if (index === -1) {\r\n return;\r\n }\r\n this._postProcesses.splice(index, 1);\r\n if (this._postProcesses.length > 0) {\r\n this._postProcesses[0].autoClear = false;\r\n }\r\n };\r\n /** @hidden */\r\n RenderTargetTexture.prototype._shouldRender = function () {\r\n if (this._currentRefreshId === -1) { // At least render once\r\n this._currentRefreshId = 1;\r\n return true;\r\n }\r\n if (this.refreshRate === this._currentRefreshId) {\r\n this._currentRefreshId = 1;\r\n return true;\r\n }\r\n this._currentRefreshId++;\r\n return false;\r\n };\r\n /**\r\n * Gets the actual render size of the texture.\r\n * @returns the width of the render size\r\n */\r\n RenderTargetTexture.prototype.getRenderSize = function () {\r\n return this.getRenderWidth();\r\n };\r\n /**\r\n * Gets the actual render width of the texture.\r\n * @returns the width of the render size\r\n */\r\n RenderTargetTexture.prototype.getRenderWidth = function () {\r\n if (this._size.width) {\r\n return this._size.width;\r\n }\r\n return this._size;\r\n };\r\n /**\r\n * Gets the actual render height of the texture.\r\n * @returns the height of the render size\r\n */\r\n RenderTargetTexture.prototype.getRenderHeight = function () {\r\n if (this._size.width) {\r\n return this._size.height;\r\n }\r\n return this._size;\r\n };\r\n /**\r\n * Gets the actual number of layers of the texture.\r\n * @returns the number of layers\r\n */\r\n RenderTargetTexture.prototype.getRenderLayers = function () {\r\n var layers = this._size.layers;\r\n if (layers) {\r\n return layers;\r\n }\r\n return 0;\r\n };\r\n Object.defineProperty(RenderTargetTexture.prototype, \"canRescale\", {\r\n /**\r\n * Get if the texture can be rescaled or not.\r\n */\r\n get: function () {\r\n return true;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Resize the texture using a ratio.\r\n * @param ratio the ratio to apply to the texture size in order to compute the new target size\r\n */\r\n RenderTargetTexture.prototype.scale = function (ratio) {\r\n var newSize = Math.max(1, this.getRenderSize() * ratio);\r\n this.resize(newSize);\r\n };\r\n /**\r\n * Get the texture reflection matrix used to rotate/transform the reflection.\r\n * @returns the reflection matrix\r\n */\r\n RenderTargetTexture.prototype.getReflectionTextureMatrix = function () {\r\n if (this.isCube) {\r\n return this._textureMatrix;\r\n }\r\n return _super.prototype.getReflectionTextureMatrix.call(this);\r\n };\r\n /**\r\n * Resize the texture to a new desired size.\r\n * Be carrefull as it will recreate all the data in the new texture.\r\n * @param size Define the new size. It can be:\r\n * - a number for squared texture,\r\n * - an object containing { width: number, height: number }\r\n * - or an object containing a ratio { ratio: number }\r\n */\r\n RenderTargetTexture.prototype.resize = function (size) {\r\n var wasCube = this.isCube;\r\n this.releaseInternalTexture();\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n this._processSizeParameter(size);\r\n if (wasCube) {\r\n this._texture = scene.getEngine().createRenderTargetCubeTexture(this.getRenderSize(), this._renderTargetOptions);\r\n }\r\n else {\r\n this._texture = scene.getEngine().createRenderTargetTexture(this._size, this._renderTargetOptions);\r\n }\r\n if (this.onResizeObservable.hasObservers()) {\r\n this.onResizeObservable.notifyObservers(this);\r\n }\r\n };\r\n /**\r\n * Renders all the objects from the render list into the texture.\r\n * @param useCameraPostProcess Define if camera post processes should be used during the rendering\r\n * @param dumpForDebug Define if the rendering result should be dumped (copied) for debugging purpose\r\n */\r\n RenderTargetTexture.prototype.render = function (useCameraPostProcess, dumpForDebug) {\r\n if (useCameraPostProcess === void 0) { useCameraPostProcess = false; }\r\n if (dumpForDebug === void 0) { dumpForDebug = false; }\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n var engine = scene.getEngine();\r\n if (this.useCameraPostProcesses !== undefined) {\r\n useCameraPostProcess = this.useCameraPostProcesses;\r\n }\r\n if (this._waitingRenderList) {\r\n this.renderList = [];\r\n for (var index = 0; index < this._waitingRenderList.length; index++) {\r\n var id = this._waitingRenderList[index];\r\n var mesh_1 = scene.getMeshByID(id);\r\n if (mesh_1) {\r\n this.renderList.push(mesh_1);\r\n }\r\n }\r\n this._waitingRenderList = undefined;\r\n }\r\n // Is predicate defined?\r\n if (this.renderListPredicate) {\r\n if (this.renderList) {\r\n this.renderList.length = 0; // Clear previous renderList\r\n }\r\n else {\r\n this.renderList = [];\r\n }\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n var sceneMeshes = scene.meshes;\r\n for (var index = 0; index < sceneMeshes.length; index++) {\r\n var mesh = sceneMeshes[index];\r\n if (this.renderListPredicate(mesh)) {\r\n this.renderList.push(mesh);\r\n }\r\n }\r\n }\r\n this.onBeforeBindObservable.notifyObservers(this);\r\n // Set custom projection.\r\n // Needs to be before binding to prevent changing the aspect ratio.\r\n var camera;\r\n if (this.activeCamera) {\r\n camera = this.activeCamera;\r\n engine.setViewport(this.activeCamera.viewport, this.getRenderWidth(), this.getRenderHeight());\r\n if (this.activeCamera !== scene.activeCamera) {\r\n scene.setTransformMatrix(this.activeCamera.getViewMatrix(), this.activeCamera.getProjectionMatrix(true));\r\n }\r\n }\r\n else {\r\n camera = scene.activeCamera;\r\n if (camera) {\r\n engine.setViewport(camera.viewport, this.getRenderWidth(), this.getRenderHeight());\r\n }\r\n }\r\n this._defaultRenderListPrepared = false;\r\n if (this.is2DArray) {\r\n for (var layer = 0; layer < this.getRenderLayers(); layer++) {\r\n this.renderToTarget(0, useCameraPostProcess, dumpForDebug, layer, camera);\r\n scene.incrementRenderId();\r\n scene.resetCachedMaterial();\r\n }\r\n }\r\n else if (this.isCube) {\r\n for (var face = 0; face < 6; face++) {\r\n this.renderToTarget(face, useCameraPostProcess, dumpForDebug, undefined, camera);\r\n scene.incrementRenderId();\r\n scene.resetCachedMaterial();\r\n }\r\n }\r\n else {\r\n this.renderToTarget(0, useCameraPostProcess, dumpForDebug, undefined, camera);\r\n }\r\n this.onAfterUnbindObservable.notifyObservers(this);\r\n if (scene.activeCamera) {\r\n // Do not avoid setting uniforms when multiple scenes are active as another camera may have overwrite these\r\n if (scene.getEngine().scenes.length > 1 || (this.activeCamera && this.activeCamera !== scene.activeCamera)) {\r\n scene.setTransformMatrix(scene.activeCamera.getViewMatrix(), scene.activeCamera.getProjectionMatrix(true));\r\n }\r\n engine.setViewport(scene.activeCamera.viewport);\r\n }\r\n scene.resetCachedMaterial();\r\n };\r\n RenderTargetTexture.prototype._bestReflectionRenderTargetDimension = function (renderDimension, scale) {\r\n var minimum = 128;\r\n var x = renderDimension * scale;\r\n var curved = Engine.NearestPOT(x + (minimum * minimum / (minimum + x)));\r\n // Ensure we don't exceed the render dimension (while staying POT)\r\n return Math.min(Engine.FloorPOT(renderDimension), curved);\r\n };\r\n RenderTargetTexture.prototype._prepareRenderingManager = function (currentRenderList, currentRenderListLength, camera, checkLayerMask) {\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n this._renderingManager.reset();\r\n var sceneRenderId = scene.getRenderId();\r\n for (var meshIndex = 0; meshIndex < currentRenderListLength; meshIndex++) {\r\n var mesh = currentRenderList[meshIndex];\r\n if (mesh && !mesh.isBlocked) {\r\n if (this.customIsReadyFunction) {\r\n if (!this.customIsReadyFunction(mesh, this.refreshRate)) {\r\n this.resetRefreshCounter();\r\n continue;\r\n }\r\n }\r\n else if (!mesh.isReady(this.refreshRate === 0)) {\r\n this.resetRefreshCounter();\r\n continue;\r\n }\r\n if (!mesh._internalAbstractMeshDataInfo._currentLODIsUpToDate && scene.activeCamera) {\r\n mesh._internalAbstractMeshDataInfo._currentLOD = scene.customLODSelector ? scene.customLODSelector(mesh, scene.activeCamera) : mesh.getLOD(scene.activeCamera);\r\n mesh._internalAbstractMeshDataInfo._currentLODIsUpToDate = true;\r\n }\r\n if (!mesh._internalAbstractMeshDataInfo._currentLOD) {\r\n continue;\r\n }\r\n var meshToRender = mesh._internalAbstractMeshDataInfo._currentLOD;\r\n meshToRender._preActivateForIntermediateRendering(sceneRenderId);\r\n var isMasked = void 0;\r\n if (checkLayerMask && camera) {\r\n isMasked = ((mesh.layerMask & camera.layerMask) === 0);\r\n }\r\n else {\r\n isMasked = false;\r\n }\r\n if (mesh.isEnabled() && mesh.isVisible && mesh.subMeshes && !isMasked) {\r\n if (meshToRender !== mesh) {\r\n meshToRender._activate(sceneRenderId, true);\r\n }\r\n if (mesh._activate(sceneRenderId, true) && mesh.subMeshes.length) {\r\n if (!mesh.isAnInstance) {\r\n meshToRender._internalAbstractMeshDataInfo._onlyForInstancesIntermediate = false;\r\n }\r\n else {\r\n if (mesh._internalAbstractMeshDataInfo._actAsRegularMesh) {\r\n meshToRender = mesh;\r\n }\r\n }\r\n meshToRender._internalAbstractMeshDataInfo._isActiveIntermediate = true;\r\n for (var subIndex = 0; subIndex < meshToRender.subMeshes.length; subIndex++) {\r\n var subMesh = meshToRender.subMeshes[subIndex];\r\n this._renderingManager.dispatch(subMesh, meshToRender);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n for (var particleIndex = 0; particleIndex < scene.particleSystems.length; particleIndex++) {\r\n var particleSystem = scene.particleSystems[particleIndex];\r\n var emitter = particleSystem.emitter;\r\n if (!particleSystem.isStarted() || !emitter || !emitter.position || !emitter.isEnabled()) {\r\n continue;\r\n }\r\n if (currentRenderList.indexOf(emitter) >= 0) {\r\n this._renderingManager.dispatchParticles(particleSystem);\r\n }\r\n }\r\n };\r\n /**\r\n * @hidden\r\n * @param faceIndex face index to bind to if this is a cubetexture\r\n * @param layer defines the index of the texture to bind in the array\r\n */\r\n RenderTargetTexture.prototype._bindFrameBuffer = function (faceIndex, layer) {\r\n if (faceIndex === void 0) { faceIndex = 0; }\r\n if (layer === void 0) { layer = 0; }\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n var engine = scene.getEngine();\r\n if (this._texture) {\r\n engine.bindFramebuffer(this._texture, this.isCube ? faceIndex : undefined, undefined, undefined, this.ignoreCameraViewport, 0, layer);\r\n }\r\n };\r\n RenderTargetTexture.prototype.unbindFrameBuffer = function (engine, faceIndex) {\r\n var _this = this;\r\n if (!this._texture) {\r\n return;\r\n }\r\n engine.unBindFramebuffer(this._texture, this.isCube, function () {\r\n _this.onAfterRenderObservable.notifyObservers(faceIndex);\r\n });\r\n };\r\n RenderTargetTexture.prototype.renderToTarget = function (faceIndex, useCameraPostProcess, dumpForDebug, layer, camera) {\r\n if (layer === void 0) { layer = 0; }\r\n if (camera === void 0) { camera = null; }\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n var engine = scene.getEngine();\r\n if (!this._texture) {\r\n return;\r\n }\r\n // Bind\r\n if (this._postProcessManager) {\r\n this._postProcessManager._prepareFrame(this._texture, this._postProcesses);\r\n }\r\n else if (!useCameraPostProcess || !scene.postProcessManager._prepareFrame(this._texture)) {\r\n this._bindFrameBuffer(faceIndex, layer);\r\n }\r\n if (this.is2DArray) {\r\n this.onBeforeRenderObservable.notifyObservers(layer);\r\n }\r\n else {\r\n this.onBeforeRenderObservable.notifyObservers(faceIndex);\r\n }\r\n // Get the list of meshes to render\r\n var currentRenderList = null;\r\n var defaultRenderList = this.renderList ? this.renderList : scene.getActiveMeshes().data;\r\n var defaultRenderListLength = this.renderList ? this.renderList.length : scene.getActiveMeshes().length;\r\n if (this.getCustomRenderList) {\r\n currentRenderList = this.getCustomRenderList(this.is2DArray ? layer : faceIndex, defaultRenderList, defaultRenderListLength);\r\n }\r\n if (!currentRenderList) {\r\n // No custom render list provided, we prepare the rendering for the default list, but check\r\n // first if we did not already performed the preparation before so as to avoid re-doing it several times\r\n if (!this._defaultRenderListPrepared) {\r\n this._prepareRenderingManager(defaultRenderList, defaultRenderListLength, camera, !this.renderList);\r\n this._defaultRenderListPrepared = true;\r\n }\r\n currentRenderList = defaultRenderList;\r\n }\r\n else {\r\n // Prepare the rendering for the custom render list provided\r\n this._prepareRenderingManager(currentRenderList, currentRenderList.length, camera, false);\r\n }\r\n // Clear\r\n if (this.onClearObservable.hasObservers()) {\r\n this.onClearObservable.notifyObservers(engine);\r\n }\r\n else {\r\n engine.clear(this.clearColor || scene.clearColor, true, true, true);\r\n }\r\n if (!this._doNotChangeAspectRatio) {\r\n scene.updateTransformMatrix(true);\r\n }\r\n // Before Camera Draw\r\n for (var _i = 0, _a = scene._beforeRenderTargetDrawStage; _i < _a.length; _i++) {\r\n var step = _a[_i];\r\n step.action(this);\r\n }\r\n // Render\r\n this._renderingManager.render(this.customRenderFunction, currentRenderList, this.renderParticles, this.renderSprites);\r\n // After Camera Draw\r\n for (var _b = 0, _c = scene._afterRenderTargetDrawStage; _b < _c.length; _b++) {\r\n var step = _c[_b];\r\n step.action(this);\r\n }\r\n if (this._postProcessManager) {\r\n this._postProcessManager._finalizeFrame(false, this._texture, faceIndex, this._postProcesses, this.ignoreCameraViewport);\r\n }\r\n else if (useCameraPostProcess) {\r\n scene.postProcessManager._finalizeFrame(false, this._texture, faceIndex);\r\n }\r\n if (!this._doNotChangeAspectRatio) {\r\n scene.updateTransformMatrix(true);\r\n }\r\n // Dump ?\r\n if (dumpForDebug) {\r\n Tools.DumpFramebuffer(this.getRenderWidth(), this.getRenderHeight(), engine);\r\n }\r\n // Unbind\r\n if (!this.isCube || faceIndex === 5) {\r\n if (this.isCube) {\r\n if (faceIndex === 5) {\r\n engine.generateMipMapsForCubemap(this._texture);\r\n }\r\n }\r\n this.unbindFrameBuffer(engine, faceIndex);\r\n }\r\n else {\r\n this.onAfterRenderObservable.notifyObservers(faceIndex);\r\n }\r\n };\r\n /**\r\n * Overrides the default sort function applied in the renderging group to prepare the meshes.\r\n * This allowed control for front to back rendering or reversly depending of the special needs.\r\n *\r\n * @param renderingGroupId The rendering group id corresponding to its index\r\n * @param opaqueSortCompareFn The opaque queue comparison function use to sort.\r\n * @param alphaTestSortCompareFn The alpha test queue comparison function use to sort.\r\n * @param transparentSortCompareFn The transparent queue comparison function use to sort.\r\n */\r\n RenderTargetTexture.prototype.setRenderingOrder = function (renderingGroupId, opaqueSortCompareFn, alphaTestSortCompareFn, transparentSortCompareFn) {\r\n if (opaqueSortCompareFn === void 0) { opaqueSortCompareFn = null; }\r\n if (alphaTestSortCompareFn === void 0) { alphaTestSortCompareFn = null; }\r\n if (transparentSortCompareFn === void 0) { transparentSortCompareFn = null; }\r\n this._renderingManager.setRenderingOrder(renderingGroupId, opaqueSortCompareFn, alphaTestSortCompareFn, transparentSortCompareFn);\r\n };\r\n /**\r\n * Specifies whether or not the stencil and depth buffer are cleared between two rendering groups.\r\n *\r\n * @param renderingGroupId The rendering group id corresponding to its index\r\n * @param autoClearDepthStencil Automatically clears depth and stencil between groups if true.\r\n */\r\n RenderTargetTexture.prototype.setRenderingAutoClearDepthStencil = function (renderingGroupId, autoClearDepthStencil) {\r\n this._renderingManager.setRenderingAutoClearDepthStencil(renderingGroupId, autoClearDepthStencil);\r\n this._renderingManager._useSceneAutoClearSetup = false;\r\n };\r\n /**\r\n * Clones the texture.\r\n * @returns the cloned texture\r\n */\r\n RenderTargetTexture.prototype.clone = function () {\r\n var textureSize = this.getSize();\r\n var newTexture = new RenderTargetTexture(this.name, textureSize, this.getScene(), this._renderTargetOptions.generateMipMaps, this._doNotChangeAspectRatio, this._renderTargetOptions.type, this.isCube, this._renderTargetOptions.samplingMode, this._renderTargetOptions.generateDepthBuffer, this._renderTargetOptions.generateStencilBuffer);\r\n // Base texture\r\n newTexture.hasAlpha = this.hasAlpha;\r\n newTexture.level = this.level;\r\n // RenderTarget Texture\r\n newTexture.coordinatesMode = this.coordinatesMode;\r\n if (this.renderList) {\r\n newTexture.renderList = this.renderList.slice(0);\r\n }\r\n return newTexture;\r\n };\r\n /**\r\n * Serialize the texture to a JSON representation we can easily use in the resepective Parse function.\r\n * @returns The JSON representation of the texture\r\n */\r\n RenderTargetTexture.prototype.serialize = function () {\r\n if (!this.name) {\r\n return null;\r\n }\r\n var serializationObject = _super.prototype.serialize.call(this);\r\n serializationObject.renderTargetSize = this.getRenderSize();\r\n serializationObject.renderList = [];\r\n if (this.renderList) {\r\n for (var index = 0; index < this.renderList.length; index++) {\r\n serializationObject.renderList.push(this.renderList[index].id);\r\n }\r\n }\r\n return serializationObject;\r\n };\r\n /**\r\n * This will remove the attached framebuffer objects. The texture will not be able to be used as render target anymore\r\n */\r\n RenderTargetTexture.prototype.disposeFramebufferObjects = function () {\r\n var objBuffer = this.getInternalTexture();\r\n var scene = this.getScene();\r\n if (objBuffer && scene) {\r\n scene.getEngine()._releaseFramebufferObjects(objBuffer);\r\n }\r\n };\r\n /**\r\n * Dispose the texture and release its associated resources.\r\n */\r\n RenderTargetTexture.prototype.dispose = function () {\r\n this.onResizeObservable.clear();\r\n this.onClearObservable.clear();\r\n this.onAfterRenderObservable.clear();\r\n this.onAfterUnbindObservable.clear();\r\n this.onBeforeBindObservable.clear();\r\n this.onBeforeRenderObservable.clear();\r\n if (this._postProcessManager) {\r\n this._postProcessManager.dispose();\r\n this._postProcessManager = null;\r\n }\r\n this.clearPostProcesses(true);\r\n if (this._resizeObserver) {\r\n this.getScene().getEngine().onResizeObservable.remove(this._resizeObserver);\r\n this._resizeObserver = null;\r\n }\r\n this.renderList = null;\r\n // Remove from custom render targets\r\n var scene = this.getScene();\r\n if (!scene) {\r\n return;\r\n }\r\n var index = scene.customRenderTargets.indexOf(this);\r\n if (index >= 0) {\r\n scene.customRenderTargets.splice(index, 1);\r\n }\r\n for (var _i = 0, _a = scene.cameras; _i < _a.length; _i++) {\r\n var camera = _a[_i];\r\n index = camera.customRenderTargets.indexOf(this);\r\n if (index >= 0) {\r\n camera.customRenderTargets.splice(index, 1);\r\n }\r\n }\r\n if (this.depthStencilTexture) {\r\n this.getScene().getEngine()._releaseTexture(this.depthStencilTexture);\r\n }\r\n _super.prototype.dispose.call(this);\r\n };\r\n /** @hidden */\r\n RenderTargetTexture.prototype._rebuild = function () {\r\n if (this.refreshRate === RenderTargetTexture.REFRESHRATE_RENDER_ONCE) {\r\n this.refreshRate = RenderTargetTexture.REFRESHRATE_RENDER_ONCE;\r\n }\r\n if (this._postProcessManager) {\r\n this._postProcessManager._rebuild();\r\n }\r\n };\r\n /**\r\n * Clear the info related to rendering groups preventing retention point in material dispose.\r\n */\r\n RenderTargetTexture.prototype.freeRenderingGroups = function () {\r\n if (this._renderingManager) {\r\n this._renderingManager.freeRenderingGroups();\r\n }\r\n };\r\n /**\r\n * Gets the number of views the corresponding to the texture (eg. a MultiviewRenderTarget will have > 1)\r\n * @returns the view count\r\n */\r\n RenderTargetTexture.prototype.getViewCount = function () {\r\n return 1;\r\n };\r\n /**\r\n * The texture will only be rendered once which can be useful to improve performance if everything in your render is static for instance.\r\n */\r\n RenderTargetTexture.REFRESHRATE_RENDER_ONCE = 0;\r\n /**\r\n * The texture will only be rendered rendered every frame and is recomended for dynamic contents.\r\n */\r\n RenderTargetTexture.REFRESHRATE_RENDER_ONEVERYFRAME = 1;\r\n /**\r\n * The texture will be rendered every 2 frames which could be enough if your dynamic objects are not\r\n * the central point of your effect and can save a lot of performances.\r\n */\r\n RenderTargetTexture.REFRESHRATE_RENDER_ONEVERYTWOFRAMES = 2;\r\n return RenderTargetTexture;\r\n}(Texture));\r\nexport { RenderTargetTexture };\r\nTexture._CreateRenderTargetTexture = function (name, renderTargetSize, scene, generateMipMaps) {\r\n return new RenderTargetTexture(name, renderTargetSize, scene, generateMipMaps);\r\n};\r\n//# sourceMappingURL=renderTargetTexture.js.map","import { Effect } from \"../Materials/effect\";\r\nvar name = 'postprocessVertexShader';\r\nvar shader = \"\\nattribute vec2 position;\\nuniform vec2 scale;\\n\\nvarying vec2 vUV;\\nconst vec2 madd=vec2(0.5,0.5);\\nvoid main(void) {\\nvUV=(position*madd+madd)*scale;\\ngl_Position=vec4(position,0.0,1.0);\\n}\";\r\nEffect.ShadersStore[name] = shader;\r\n/** @hidden */\r\nexport var postprocessVertexShader = { name: name, shader: shader };\r\n//# sourceMappingURL=postprocess.vertex.js.map","import { __decorate } from \"tslib\";\r\nimport { SmartArray } from \"../Misc/smartArray\";\r\nimport { Observable } from \"../Misc/observable\";\r\nimport { Vector2 } from \"../Maths/math.vector\";\r\nimport \"../Shaders/postprocess.vertex\";\r\nimport { Engine } from '../Engines/engine';\r\nimport \"../Engines/Extensions/engine.renderTarget\";\r\nimport { serialize, serializeAsColor4, SerializationHelper } from '../Misc/decorators';\r\nimport { _TypeStore } from '../Misc/typeStore';\r\n/**\r\n * PostProcess can be used to apply a shader to a texture after it has been rendered\r\n * See https://doc.babylonjs.com/how_to/how_to_use_postprocesses\r\n */\r\nvar PostProcess = /** @class */ (function () {\r\n /**\r\n * Creates a new instance PostProcess\r\n * @param name The name of the PostProcess.\r\n * @param fragmentUrl The url of the fragment shader to be used.\r\n * @param parameters Array of the names of uniform non-sampler2D variables that will be passed to the shader.\r\n * @param samplers Array of the names of uniform sampler2D variables that will be passed to the shader.\r\n * @param options The required width/height ratio to downsize to before computing the render pass. (Use 1.0 for full size)\r\n * @param camera The camera to apply the render pass to.\r\n * @param samplingMode The sampling mode to be used when computing the pass. (default: 0)\r\n * @param engine The engine which the post process will be applied. (default: current engine)\r\n * @param reusable If the post process can be reused on the same frame. (default: false)\r\n * @param defines String of defines that will be set when running the fragment shader. (default: null)\r\n * @param textureType Type of textures used when performing the post process. (default: 0)\r\n * @param vertexUrl The url of the vertex shader to be used. (default: \"postprocess\")\r\n * @param indexParameters The index parameters to be used for babylons include syntax \"#include[0..varyingCount]\". (default: undefined) See usage in babylon.blurPostProcess.ts and kernelBlur.vertex.fx\r\n * @param blockCompilation If the shader should not be compiled immediatly. (default: false)\r\n * @param textureFormat Format of textures used when performing the post process. (default: TEXTUREFORMAT_RGBA)\r\n */\r\n function PostProcess(name, fragmentUrl, parameters, samplers, options, camera, samplingMode, engine, reusable, defines, textureType, vertexUrl, indexParameters, blockCompilation, textureFormat) {\r\n if (samplingMode === void 0) { samplingMode = 1; }\r\n if (defines === void 0) { defines = null; }\r\n if (textureType === void 0) { textureType = 0; }\r\n if (vertexUrl === void 0) { vertexUrl = \"postprocess\"; }\r\n if (blockCompilation === void 0) { blockCompilation = false; }\r\n if (textureFormat === void 0) { textureFormat = 5; }\r\n /**\r\n * Width of the texture to apply the post process on\r\n */\r\n this.width = -1;\r\n /**\r\n * Height of the texture to apply the post process on\r\n */\r\n this.height = -1;\r\n /**\r\n * Gets the node material used to create this postprocess (null if the postprocess was manually created)\r\n */\r\n this.nodeMaterialSource = null;\r\n /**\r\n * Internal, reference to the location where this postprocess was output to. (Typically the texture on the next postprocess in the chain)\r\n * @hidden\r\n */\r\n this._outputTexture = null;\r\n /**\r\n * If the buffer needs to be cleared before applying the post process. (default: true)\r\n * Should be set to false if shader will overwrite all previous pixels.\r\n */\r\n this.autoClear = true;\r\n /**\r\n * Type of alpha mode to use when performing the post process (default: Engine.ALPHA_DISABLE)\r\n */\r\n this.alphaMode = 0;\r\n /**\r\n * Animations to be used for the post processing\r\n */\r\n this.animations = new Array();\r\n /**\r\n * Enable Pixel Perfect mode where texture is not scaled to be power of 2.\r\n * Can only be used on a single postprocess or on the last one of a chain. (default: false)\r\n */\r\n this.enablePixelPerfectMode = false;\r\n /**\r\n * Force the postprocess to be applied without taking in account viewport\r\n */\r\n this.forceFullscreenViewport = true;\r\n /**\r\n * Scale mode for the post process (default: Engine.SCALEMODE_FLOOR)\r\n *\r\n * | Value | Type | Description |\r\n * | ----- | ----------------------------------- | ----------- |\r\n * | 1 | SCALEMODE_FLOOR | [engine.scalemode_floor](https://doc.babylonjs.com/api/classes/babylon.engine#scalemode_floor) |\r\n * | 2 | SCALEMODE_NEAREST | [engine.scalemode_nearest](https://doc.babylonjs.com/api/classes/babylon.engine#scalemode_nearest) |\r\n * | 3 | SCALEMODE_CEILING | [engine.scalemode_ceiling](https://doc.babylonjs.com/api/classes/babylon.engine#scalemode_ceiling) |\r\n *\r\n */\r\n this.scaleMode = 1;\r\n /**\r\n * Force textures to be a power of two (default: false)\r\n */\r\n this.alwaysForcePOT = false;\r\n this._samples = 1;\r\n /**\r\n * Modify the scale of the post process to be the same as the viewport (default: false)\r\n */\r\n this.adaptScaleToCurrentViewport = false;\r\n this._reusable = false;\r\n /**\r\n * Smart array of input and output textures for the post process.\r\n * @hidden\r\n */\r\n this._textures = new SmartArray(2);\r\n /**\r\n * The index in _textures that corresponds to the output texture.\r\n * @hidden\r\n */\r\n this._currentRenderTextureInd = 0;\r\n this._scaleRatio = new Vector2(1, 1);\r\n this._texelSize = Vector2.Zero();\r\n // Events\r\n /**\r\n * An event triggered when the postprocess is activated.\r\n */\r\n this.onActivateObservable = new Observable();\r\n /**\r\n * An event triggered when the postprocess changes its size.\r\n */\r\n this.onSizeChangedObservable = new Observable();\r\n /**\r\n * An event triggered when the postprocess applies its effect.\r\n */\r\n this.onApplyObservable = new Observable();\r\n /**\r\n * An event triggered before rendering the postprocess\r\n */\r\n this.onBeforeRenderObservable = new Observable();\r\n /**\r\n * An event triggered after rendering the postprocess\r\n */\r\n this.onAfterRenderObservable = new Observable();\r\n this.name = name;\r\n if (camera != null) {\r\n this._camera = camera;\r\n this._scene = camera.getScene();\r\n camera.attachPostProcess(this);\r\n this._engine = this._scene.getEngine();\r\n this._scene.postProcesses.push(this);\r\n this.uniqueId = this._scene.getUniqueId();\r\n }\r\n else if (engine) {\r\n this._engine = engine;\r\n this._engine.postProcesses.push(this);\r\n }\r\n this._options = options;\r\n this.renderTargetSamplingMode = samplingMode ? samplingMode : 1;\r\n this._reusable = reusable || false;\r\n this._textureType = textureType;\r\n this._textureFormat = textureFormat;\r\n this._samplers = samplers || [];\r\n this._samplers.push(\"textureSampler\");\r\n this._fragmentUrl = fragmentUrl;\r\n this._vertexUrl = vertexUrl;\r\n this._parameters = parameters || [];\r\n this._parameters.push(\"scale\");\r\n this._indexParameters = indexParameters;\r\n if (!blockCompilation) {\r\n this.updateEffect(defines);\r\n }\r\n }\r\n Object.defineProperty(PostProcess.prototype, \"samples\", {\r\n /**\r\n * Number of sample textures (default: 1)\r\n */\r\n get: function () {\r\n return this._samples;\r\n },\r\n set: function (n) {\r\n var _this = this;\r\n this._samples = Math.min(n, this._engine.getCaps().maxMSAASamples);\r\n this._textures.forEach(function (texture) {\r\n if (texture.samples !== _this._samples) {\r\n _this._engine.updateRenderTargetTextureSampleCount(texture, _this._samples);\r\n }\r\n });\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Returns the fragment url or shader name used in the post process.\r\n * @returns the fragment url or name in the shader store.\r\n */\r\n PostProcess.prototype.getEffectName = function () {\r\n return this._fragmentUrl;\r\n };\r\n Object.defineProperty(PostProcess.prototype, \"onActivate\", {\r\n /**\r\n * A function that is added to the onActivateObservable\r\n */\r\n set: function (callback) {\r\n if (this._onActivateObserver) {\r\n this.onActivateObservable.remove(this._onActivateObserver);\r\n }\r\n if (callback) {\r\n this._onActivateObserver = this.onActivateObservable.add(callback);\r\n }\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PostProcess.prototype, \"onSizeChanged\", {\r\n /**\r\n * A function that is added to the onSizeChangedObservable\r\n */\r\n set: function (callback) {\r\n if (this._onSizeChangedObserver) {\r\n this.onSizeChangedObservable.remove(this._onSizeChangedObserver);\r\n }\r\n this._onSizeChangedObserver = this.onSizeChangedObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PostProcess.prototype, \"onApply\", {\r\n /**\r\n * A function that is added to the onApplyObservable\r\n */\r\n set: function (callback) {\r\n if (this._onApplyObserver) {\r\n this.onApplyObservable.remove(this._onApplyObserver);\r\n }\r\n this._onApplyObserver = this.onApplyObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PostProcess.prototype, \"onBeforeRender\", {\r\n /**\r\n * A function that is added to the onBeforeRenderObservable\r\n */\r\n set: function (callback) {\r\n if (this._onBeforeRenderObserver) {\r\n this.onBeforeRenderObservable.remove(this._onBeforeRenderObserver);\r\n }\r\n this._onBeforeRenderObserver = this.onBeforeRenderObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PostProcess.prototype, \"onAfterRender\", {\r\n /**\r\n * A function that is added to the onAfterRenderObservable\r\n */\r\n set: function (callback) {\r\n if (this._onAfterRenderObserver) {\r\n this.onAfterRenderObservable.remove(this._onAfterRenderObserver);\r\n }\r\n this._onAfterRenderObserver = this.onAfterRenderObservable.add(callback);\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PostProcess.prototype, \"inputTexture\", {\r\n /**\r\n * The input texture for this post process and the output texture of the previous post process. When added to a pipeline the previous post process will\r\n * render it's output into this texture and this texture will be used as textureSampler in the fragment shader of this post process.\r\n */\r\n get: function () {\r\n return this._textures.data[this._currentRenderTextureInd];\r\n },\r\n set: function (value) {\r\n this._forcedOutputTexture = value;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Since inputTexture should always be defined, if we previously manually set `inputTexture`,\r\n * the only way to unset it is to use this function to restore its internal state\r\n */\r\n PostProcess.prototype.restoreDefaultInputTexture = function () {\r\n this._forcedOutputTexture = null;\r\n };\r\n /**\r\n * Gets the camera which post process is applied to.\r\n * @returns The camera the post process is applied to.\r\n */\r\n PostProcess.prototype.getCamera = function () {\r\n return this._camera;\r\n };\r\n Object.defineProperty(PostProcess.prototype, \"texelSize\", {\r\n /**\r\n * Gets the texel size of the postprocess.\r\n * See https://en.wikipedia.org/wiki/Texel_(graphics)\r\n */\r\n get: function () {\r\n if (this._shareOutputWithPostProcess) {\r\n return this._shareOutputWithPostProcess.texelSize;\r\n }\r\n if (this._forcedOutputTexture) {\r\n this._texelSize.copyFromFloats(1.0 / this._forcedOutputTexture.width, 1.0 / this._forcedOutputTexture.height);\r\n }\r\n return this._texelSize;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Gets a string identifying the name of the class\r\n * @returns \"PostProcess\" string\r\n */\r\n PostProcess.prototype.getClassName = function () {\r\n return \"PostProcess\";\r\n };\r\n /**\r\n * Gets the engine which this post process belongs to.\r\n * @returns The engine the post process was enabled with.\r\n */\r\n PostProcess.prototype.getEngine = function () {\r\n return this._engine;\r\n };\r\n /**\r\n * The effect that is created when initializing the post process.\r\n * @returns The created effect corresponding the the postprocess.\r\n */\r\n PostProcess.prototype.getEffect = function () {\r\n return this._effect;\r\n };\r\n /**\r\n * To avoid multiple redundant textures for multiple post process, the output the output texture for this post process can be shared with another.\r\n * @param postProcess The post process to share the output with.\r\n * @returns This post process.\r\n */\r\n PostProcess.prototype.shareOutputWith = function (postProcess) {\r\n this._disposeTextures();\r\n this._shareOutputWithPostProcess = postProcess;\r\n return this;\r\n };\r\n /**\r\n * Reverses the effect of calling shareOutputWith and returns the post process back to its original state.\r\n * This should be called if the post process that shares output with this post process is disabled/disposed.\r\n */\r\n PostProcess.prototype.useOwnOutput = function () {\r\n if (this._textures.length == 0) {\r\n this._textures = new SmartArray(2);\r\n }\r\n this._shareOutputWithPostProcess = null;\r\n };\r\n /**\r\n * Updates the effect with the current post process compile time values and recompiles the shader.\r\n * @param defines Define statements that should be added at the beginning of the shader. (default: null)\r\n * @param uniforms Set of uniform variables that will be passed to the shader. (default: null)\r\n * @param samplers Set of Texture2D variables that will be passed to the shader. (default: null)\r\n * @param indexParameters The index parameters to be used for babylons include syntax \"#include[0..varyingCount]\". (default: undefined) See usage in babylon.blurPostProcess.ts and kernelBlur.vertex.fx\r\n * @param onCompiled Called when the shader has been compiled.\r\n * @param onError Called if there is an error when compiling a shader.\r\n * @param vertexUrl The url of the vertex shader to be used (default: the one given at construction time)\r\n * @param fragmentUrl The url of the fragment shader to be used (default: the one given at construction time)\r\n */\r\n PostProcess.prototype.updateEffect = function (defines, uniforms, samplers, indexParameters, onCompiled, onError, vertexUrl, fragmentUrl) {\r\n if (defines === void 0) { defines = null; }\r\n if (uniforms === void 0) { uniforms = null; }\r\n if (samplers === void 0) { samplers = null; }\r\n this._effect = this._engine.createEffect({ vertex: vertexUrl !== null && vertexUrl !== void 0 ? vertexUrl : this._vertexUrl, fragment: fragmentUrl !== null && fragmentUrl !== void 0 ? fragmentUrl : this._fragmentUrl }, [\"position\"], uniforms || this._parameters, samplers || this._samplers, defines !== null ? defines : \"\", undefined, onCompiled, onError, indexParameters || this._indexParameters);\r\n };\r\n /**\r\n * The post process is reusable if it can be used multiple times within one frame.\r\n * @returns If the post process is reusable\r\n */\r\n PostProcess.prototype.isReusable = function () {\r\n return this._reusable;\r\n };\r\n /** invalidate frameBuffer to hint the postprocess to create a depth buffer */\r\n PostProcess.prototype.markTextureDirty = function () {\r\n this.width = -1;\r\n };\r\n /**\r\n * Activates the post process by intializing the textures to be used when executed. Notifies onActivateObservable.\r\n * When this post process is used in a pipeline, this is call will bind the input texture of this post process to the output of the previous.\r\n * @param camera The camera that will be used in the post process. This camera will be used when calling onActivateObservable.\r\n * @param sourceTexture The source texture to be inspected to get the width and height if not specified in the post process constructor. (default: null)\r\n * @param forceDepthStencil If true, a depth and stencil buffer will be generated. (default: false)\r\n * @returns The target texture that was bound to be written to.\r\n */\r\n PostProcess.prototype.activate = function (camera, sourceTexture, forceDepthStencil) {\r\n var _this = this;\r\n if (sourceTexture === void 0) { sourceTexture = null; }\r\n camera = camera || this._camera;\r\n var scene = camera.getScene();\r\n var engine = scene.getEngine();\r\n var maxSize = engine.getCaps().maxTextureSize;\r\n var requiredWidth = ((sourceTexture ? sourceTexture.width : this._engine.getRenderWidth(true)) * this._options) | 0;\r\n var requiredHeight = ((sourceTexture ? sourceTexture.height : this._engine.getRenderHeight(true)) * this._options) | 0;\r\n // If rendering to a webvr camera's left or right eye only half the width should be used to avoid resize when rendered to screen\r\n var webVRCamera = camera.parent;\r\n if (webVRCamera && (webVRCamera.leftCamera == camera || webVRCamera.rightCamera == camera)) {\r\n requiredWidth /= 2;\r\n }\r\n var desiredWidth = (this._options.width || requiredWidth);\r\n var desiredHeight = this._options.height || requiredHeight;\r\n var needMipMaps = this.renderTargetSamplingMode !== 7 &&\r\n this.renderTargetSamplingMode !== 1 &&\r\n this.renderTargetSamplingMode !== 2;\r\n if (!this._shareOutputWithPostProcess && !this._forcedOutputTexture) {\r\n if (this.adaptScaleToCurrentViewport) {\r\n var currentViewport = engine.currentViewport;\r\n if (currentViewport) {\r\n desiredWidth *= currentViewport.width;\r\n desiredHeight *= currentViewport.height;\r\n }\r\n }\r\n if (needMipMaps || this.alwaysForcePOT) {\r\n if (!this._options.width) {\r\n desiredWidth = engine.needPOTTextures ? Engine.GetExponentOfTwo(desiredWidth, maxSize, this.scaleMode) : desiredWidth;\r\n }\r\n if (!this._options.height) {\r\n desiredHeight = engine.needPOTTextures ? Engine.GetExponentOfTwo(desiredHeight, maxSize, this.scaleMode) : desiredHeight;\r\n }\r\n }\r\n if (this.width !== desiredWidth || this.height !== desiredHeight) {\r\n if (this._textures.length > 0) {\r\n for (var i = 0; i < this._textures.length; i++) {\r\n this._engine._releaseTexture(this._textures.data[i]);\r\n }\r\n this._textures.reset();\r\n }\r\n this.width = desiredWidth;\r\n this.height = desiredHeight;\r\n var textureSize = { width: this.width, height: this.height };\r\n var textureOptions = {\r\n generateMipMaps: needMipMaps,\r\n generateDepthBuffer: forceDepthStencil || camera._postProcesses.indexOf(this) === 0,\r\n generateStencilBuffer: (forceDepthStencil || camera._postProcesses.indexOf(this) === 0) && this._engine.isStencilEnable,\r\n samplingMode: this.renderTargetSamplingMode,\r\n type: this._textureType,\r\n format: this._textureFormat\r\n };\r\n this._textures.push(this._engine.createRenderTargetTexture(textureSize, textureOptions));\r\n if (this._reusable) {\r\n this._textures.push(this._engine.createRenderTargetTexture(textureSize, textureOptions));\r\n }\r\n this._texelSize.copyFromFloats(1.0 / this.width, 1.0 / this.height);\r\n this.onSizeChangedObservable.notifyObservers(this);\r\n }\r\n this._textures.forEach(function (texture) {\r\n if (texture.samples !== _this.samples) {\r\n _this._engine.updateRenderTargetTextureSampleCount(texture, _this.samples);\r\n }\r\n });\r\n }\r\n var target;\r\n if (this._shareOutputWithPostProcess) {\r\n target = this._shareOutputWithPostProcess.inputTexture;\r\n }\r\n else if (this._forcedOutputTexture) {\r\n target = this._forcedOutputTexture;\r\n this.width = this._forcedOutputTexture.width;\r\n this.height = this._forcedOutputTexture.height;\r\n }\r\n else {\r\n target = this.inputTexture;\r\n }\r\n // Bind the input of this post process to be used as the output of the previous post process.\r\n if (this.enablePixelPerfectMode) {\r\n this._scaleRatio.copyFromFloats(requiredWidth / desiredWidth, requiredHeight / desiredHeight);\r\n this._engine.bindFramebuffer(target, 0, requiredWidth, requiredHeight, this.forceFullscreenViewport);\r\n }\r\n else {\r\n this._scaleRatio.copyFromFloats(1, 1);\r\n this._engine.bindFramebuffer(target, 0, undefined, undefined, this.forceFullscreenViewport);\r\n }\r\n this.onActivateObservable.notifyObservers(camera);\r\n // Clear\r\n if (this.autoClear && this.alphaMode === 0) {\r\n this._engine.clear(this.clearColor ? this.clearColor : scene.clearColor, scene._allowPostProcessClearColor, true, true);\r\n }\r\n if (this._reusable) {\r\n this._currentRenderTextureInd = (this._currentRenderTextureInd + 1) % 2;\r\n }\r\n return target;\r\n };\r\n Object.defineProperty(PostProcess.prototype, \"isSupported\", {\r\n /**\r\n * If the post process is supported.\r\n */\r\n get: function () {\r\n return this._effect.isSupported;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PostProcess.prototype, \"aspectRatio\", {\r\n /**\r\n * The aspect ratio of the output texture.\r\n */\r\n get: function () {\r\n if (this._shareOutputWithPostProcess) {\r\n return this._shareOutputWithPostProcess.aspectRatio;\r\n }\r\n if (this._forcedOutputTexture) {\r\n return this._forcedOutputTexture.width / this._forcedOutputTexture.height;\r\n }\r\n return this.width / this.height;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Get a value indicating if the post-process is ready to be used\r\n * @returns true if the post-process is ready (shader is compiled)\r\n */\r\n PostProcess.prototype.isReady = function () {\r\n return this._effect && this._effect.isReady();\r\n };\r\n /**\r\n * Binds all textures and uniforms to the shader, this will be run on every pass.\r\n * @returns the effect corresponding to this post process. Null if not compiled or not ready.\r\n */\r\n PostProcess.prototype.apply = function () {\r\n // Check\r\n if (!this._effect || !this._effect.isReady()) {\r\n return null;\r\n }\r\n // States\r\n this._engine.enableEffect(this._effect);\r\n this._engine.setState(false);\r\n this._engine.setDepthBuffer(false);\r\n this._engine.setDepthWrite(false);\r\n // Alpha\r\n this._engine.setAlphaMode(this.alphaMode);\r\n if (this.alphaConstants) {\r\n this.getEngine().setAlphaConstants(this.alphaConstants.r, this.alphaConstants.g, this.alphaConstants.b, this.alphaConstants.a);\r\n }\r\n // Bind the output texture of the preivous post process as the input to this post process.\r\n var source;\r\n if (this._shareOutputWithPostProcess) {\r\n source = this._shareOutputWithPostProcess.inputTexture;\r\n }\r\n else if (this._forcedOutputTexture) {\r\n source = this._forcedOutputTexture;\r\n }\r\n else {\r\n source = this.inputTexture;\r\n }\r\n this._effect._bindTexture(\"textureSampler\", source);\r\n // Parameters\r\n this._effect.setVector2(\"scale\", this._scaleRatio);\r\n this.onApplyObservable.notifyObservers(this._effect);\r\n return this._effect;\r\n };\r\n PostProcess.prototype._disposeTextures = function () {\r\n if (this._shareOutputWithPostProcess || this._forcedOutputTexture) {\r\n return;\r\n }\r\n if (this._textures.length > 0) {\r\n for (var i = 0; i < this._textures.length; i++) {\r\n this._engine._releaseTexture(this._textures.data[i]);\r\n }\r\n }\r\n this._textures.dispose();\r\n };\r\n /**\r\n * Sets the required values to the prepass renderer.\r\n * @param prePassRenderer defines the prepass renderer to setup.\r\n * @returns true if the pre pass is needed.\r\n */\r\n PostProcess.prototype.setPrePassRenderer = function (prePassRenderer) {\r\n if (this._prePassEffectConfiguration) {\r\n this._prePassEffectConfiguration = prePassRenderer.addEffectConfiguration(this._prePassEffectConfiguration);\r\n this._prePassEffectConfiguration.enabled = true;\r\n return true;\r\n }\r\n return false;\r\n };\r\n /**\r\n * Disposes the post process.\r\n * @param camera The camera to dispose the post process on.\r\n */\r\n PostProcess.prototype.dispose = function (camera) {\r\n camera = camera || this._camera;\r\n this._disposeTextures();\r\n var index;\r\n if (this._scene) {\r\n index = this._scene.postProcesses.indexOf(this);\r\n if (index !== -1) {\r\n this._scene.postProcesses.splice(index, 1);\r\n }\r\n }\r\n index = this._engine.postProcesses.indexOf(this);\r\n if (index !== -1) {\r\n this._engine.postProcesses.splice(index, 1);\r\n }\r\n if (!camera) {\r\n return;\r\n }\r\n camera.detachPostProcess(this);\r\n index = camera._postProcesses.indexOf(this);\r\n if (index === 0 && camera._postProcesses.length > 0) {\r\n var firstPostProcess = this._camera._getFirstPostProcess();\r\n if (firstPostProcess) {\r\n firstPostProcess.markTextureDirty();\r\n }\r\n }\r\n this.onActivateObservable.clear();\r\n this.onAfterRenderObservable.clear();\r\n this.onApplyObservable.clear();\r\n this.onBeforeRenderObservable.clear();\r\n this.onSizeChangedObservable.clear();\r\n };\r\n /**\r\n * Serializes the particle system to a JSON object\r\n * @returns the JSON object\r\n */\r\n PostProcess.prototype.serialize = function () {\r\n var serializationObject = SerializationHelper.Serialize(this);\r\n serializationObject.customType = \"BABYLON.\" + this.getClassName();\r\n serializationObject.cameraId = this.getCamera().id;\r\n serializationObject.reusable = this._reusable;\r\n serializationObject.options = this._options;\r\n serializationObject.textureType = this._textureType;\r\n return serializationObject;\r\n };\r\n /**\r\n * Creates a material from parsed material data\r\n * @param parsedPostProcess defines parsed post process data\r\n * @param scene defines the hosting scene\r\n * @param rootUrl defines the root URL to use to load textures\r\n * @returns a new post process\r\n */\r\n PostProcess.Parse = function (parsedPostProcess, scene, rootUrl) {\r\n var postProcessType = _TypeStore.GetClass(parsedPostProcess.customType);\r\n if (!postProcessType || !postProcessType._Parse) {\r\n return null;\r\n }\r\n var camera = scene.getCameraByID(parsedPostProcess.cameraId);\r\n if (!camera) {\r\n return null;\r\n }\r\n return postProcessType._Parse(parsedPostProcess, camera, scene, rootUrl);\r\n };\r\n __decorate([\r\n serialize()\r\n ], PostProcess.prototype, \"uniqueId\", void 0);\r\n __decorate([\r\n serialize()\r\n ], PostProcess.prototype, \"name\", void 0);\r\n __decorate([\r\n serialize()\r\n ], PostProcess.prototype, \"width\", void 0);\r\n __decorate([\r\n serialize()\r\n ], PostProcess.prototype, \"height\", void 0);\r\n __decorate([\r\n serialize()\r\n ], PostProcess.prototype, \"renderTargetSamplingMode\", void 0);\r\n __decorate([\r\n serializeAsColor4()\r\n ], PostProcess.prototype, \"clearColor\", void 0);\r\n __decorate([\r\n serialize()\r\n ], PostProcess.prototype, \"autoClear\", void 0);\r\n __decorate([\r\n serialize()\r\n ], PostProcess.prototype, \"alphaMode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], PostProcess.prototype, \"alphaConstants\", void 0);\r\n __decorate([\r\n serialize()\r\n ], PostProcess.prototype, \"enablePixelPerfectMode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], PostProcess.prototype, \"forceFullscreenViewport\", void 0);\r\n __decorate([\r\n serialize()\r\n ], PostProcess.prototype, \"scaleMode\", void 0);\r\n __decorate([\r\n serialize()\r\n ], PostProcess.prototype, \"alwaysForcePOT\", void 0);\r\n __decorate([\r\n serialize(\"samples\")\r\n ], PostProcess.prototype, \"_samples\", void 0);\r\n __decorate([\r\n serialize()\r\n ], PostProcess.prototype, \"adaptScaleToCurrentViewport\", void 0);\r\n return PostProcess;\r\n}());\r\nexport { PostProcess };\r\n_TypeStore.RegisteredTypes[\"BABYLON.PostProcess\"] = PostProcess;\r\n//# sourceMappingURL=postProcess.js.map","import { Effect } from \"../Materials/effect\";\r\nvar name = 'fxaaPixelShader';\r\nvar shader = \"uniform sampler2D textureSampler;\\nuniform vec2 texelSize;\\nvarying vec2 vUV;\\nvarying vec2 sampleCoordS;\\nvarying vec2 sampleCoordE;\\nvarying vec2 sampleCoordN;\\nvarying vec2 sampleCoordW;\\nvarying vec2 sampleCoordNW;\\nvarying vec2 sampleCoordSE;\\nvarying vec2 sampleCoordNE;\\nvarying vec2 sampleCoordSW;\\nconst float fxaaQualitySubpix=1.0;\\nconst float fxaaQualityEdgeThreshold=0.166;\\nconst float fxaaQualityEdgeThresholdMin=0.0833;\\nconst vec3 kLumaCoefficients=vec3(0.2126,0.7152,0.0722);\\n#define FxaaLuma(rgba) dot(rgba.rgb,kLumaCoefficients)\\nvoid main(){\\nvec2 posM;\\nposM.x=vUV.x;\\nposM.y=vUV.y;\\nvec4 rgbyM=texture2D(textureSampler,vUV,0.0);\\nfloat lumaM=FxaaLuma(rgbyM);\\nfloat lumaS=FxaaLuma(texture2D(textureSampler,sampleCoordS,0.0));\\nfloat lumaE=FxaaLuma(texture2D(textureSampler,sampleCoordE,0.0));\\nfloat lumaN=FxaaLuma(texture2D(textureSampler,sampleCoordN,0.0));\\nfloat lumaW=FxaaLuma(texture2D(textureSampler,sampleCoordW,0.0));\\nfloat maxSM=max(lumaS,lumaM);\\nfloat minSM=min(lumaS,lumaM);\\nfloat maxESM=max(lumaE,maxSM);\\nfloat minESM=min(lumaE,minSM);\\nfloat maxWN=max(lumaN,lumaW);\\nfloat minWN=min(lumaN,lumaW);\\nfloat rangeMax=max(maxWN,maxESM);\\nfloat rangeMin=min(minWN,minESM);\\nfloat rangeMaxScaled=rangeMax*fxaaQualityEdgeThreshold;\\nfloat range=rangeMax-rangeMin;\\nfloat rangeMaxClamped=max(fxaaQualityEdgeThresholdMin,rangeMaxScaled);\\n#ifndef MALI\\nif(range=edgeVert;\\nfloat subpixA=subpixNSWE*2.0+subpixNWSWNESE;\\nif (!horzSpan)\\n{\\nlumaN=lumaW;\\n}\\nif (!horzSpan)\\n{\\nlumaS=lumaE;\\n}\\nif (horzSpan)\\n{\\nlengthSign=texelSize.y;\\n}\\nfloat subpixB=(subpixA*(1.0/12.0))-lumaM;\\nfloat gradientN=lumaN-lumaM;\\nfloat gradientS=lumaS-lumaM;\\nfloat lumaNN=lumaN+lumaM;\\nfloat lumaSS=lumaS+lumaM;\\nbool pairN=abs(gradientN)>=abs(gradientS);\\nfloat gradient=max(abs(gradientN),abs(gradientS));\\nif (pairN)\\n{\\nlengthSign=-lengthSign;\\n}\\nfloat subpixC=clamp(abs(subpixB)*subpixRcpRange,0.0,1.0);\\nvec2 posB;\\nposB.x=posM.x;\\nposB.y=posM.y;\\nvec2 offNP;\\noffNP.x=(!horzSpan) ? 0.0 : texelSize.x;\\noffNP.y=(horzSpan) ? 0.0 : texelSize.y;\\nif (!horzSpan)\\n{\\nposB.x+=lengthSign*0.5;\\n}\\nif (horzSpan)\\n{\\nposB.y+=lengthSign*0.5;\\n}\\nvec2 posN;\\nposN.x=posB.x-offNP.x*1.5;\\nposN.y=posB.y-offNP.y*1.5;\\nvec2 posP;\\nposP.x=posB.x+offNP.x*1.5;\\nposP.y=posB.y+offNP.y*1.5;\\nfloat subpixD=((-2.0)*subpixC)+3.0;\\nfloat lumaEndN=FxaaLuma(texture2D(textureSampler,posN,0.0));\\nfloat subpixE=subpixC*subpixC;\\nfloat lumaEndP=FxaaLuma(texture2D(textureSampler,posP,0.0));\\nif (!pairN)\\n{\\nlumaNN=lumaSS;\\n}\\nfloat gradientScaled=gradient*1.0/4.0;\\nfloat lumaMM=lumaM-lumaNN*0.5;\\nfloat subpixF=subpixD*subpixE;\\nbool lumaMLTZero=lumaMM<0.0;\\nlumaEndN-=lumaNN*0.5;\\nlumaEndP-=lumaNN*0.5;\\nbool doneN=abs(lumaEndN)>=gradientScaled;\\nbool doneP=abs(lumaEndP)>=gradientScaled;\\nif (!doneN)\\n{\\nposN.x-=offNP.x*3.0;\\n}\\nif (!doneN)\\n{\\nposN.y-=offNP.y*3.0;\\n}\\nbool doneNP=(!doneN) || (!doneP);\\nif (!doneP)\\n{\\nposP.x+=offNP.x*3.0;\\n}\\nif (!doneP)\\n{\\nposP.y+=offNP.y*3.0;\\n}\\nif (doneNP)\\n{\\nif (!doneN) lumaEndN=FxaaLuma(texture2D(textureSampler,posN.xy,0.0));\\nif (!doneP) lumaEndP=FxaaLuma(texture2D(textureSampler,posP.xy,0.0));\\nif (!doneN) lumaEndN=lumaEndN-lumaNN*0.5;\\nif (!doneP) lumaEndP=lumaEndP-lumaNN*0.5;\\ndoneN=abs(lumaEndN)>=gradientScaled;\\ndoneP=abs(lumaEndP)>=gradientScaled;\\nif (!doneN) posN.x-=offNP.x*12.0;\\nif (!doneN) posN.y-=offNP.y*12.0;\\ndoneNP=(!doneN) || (!doneP);\\nif (!doneP) posP.x+=offNP.x*12.0;\\nif (!doneP) posP.y+=offNP.y*12.0;\\n}\\nfloat dstN=posM.x-posN.x;\\nfloat dstP=posP.x-posM.x;\\nif (!horzSpan)\\n{\\ndstN=posM.y-posN.y;\\n}\\nif (!horzSpan)\\n{\\ndstP=posP.y-posM.y;\\n}\\nbool goodSpanN=(lumaEndN<0.0) != lumaMLTZero;\\nfloat spanLength=(dstP+dstN);\\nbool goodSpanP=(lumaEndP<0.0) != lumaMLTZero;\\nfloat spanLengthRcp=1.0/spanLength;\\nbool directionN=dstN -1) {\r\n return \"#define MALI 1\\n\";\r\n }\r\n return null;\r\n };\r\n /** @hidden */\r\n FxaaPostProcess._Parse = function (parsedPostProcess, targetCamera, scene, rootUrl) {\r\n return SerializationHelper.Parse(function () {\r\n return new FxaaPostProcess(parsedPostProcess.name, parsedPostProcess.options, targetCamera, parsedPostProcess.renderTargetSamplingMode, scene.getEngine(), parsedPostProcess.reusable);\r\n }, parsedPostProcess, scene, rootUrl);\r\n };\r\n return FxaaPostProcess;\r\n}(PostProcess));\r\nexport { FxaaPostProcess };\r\n_TypeStore.RegisteredTypes[\"BABYLON.FxaaPostProcess\"] = FxaaPostProcess;\r\n//# sourceMappingURL=fxaaPostProcess.js.map","import { Texture } from \"../Materials/Textures/texture\";\r\nimport { RenderTargetTexture } from \"../Materials/Textures/renderTargetTexture\";\r\nimport { FxaaPostProcess } from \"../PostProcesses/fxaaPostProcess\";\r\nimport { Logger } from \"./logger\";\r\nimport { Tools } from \"./tools\";\r\n/**\r\n * Class containing a set of static utilities functions for screenshots\r\n */\r\nvar ScreenshotTools = /** @class */ (function () {\r\n function ScreenshotTools() {\r\n }\r\n /**\r\n * Captures a screenshot of the current rendering\r\n * @see https://doc.babylonjs.com/how_to/render_scene_on_a_png\r\n * @param engine defines the rendering engine\r\n * @param camera defines the source camera\r\n * @param size This parameter can be set to a single number or to an object with the\r\n * following (optional) properties: precision, width, height. If a single number is passed,\r\n * it will be used for both width and height. If an object is passed, the screenshot size\r\n * will be derived from the parameters. The precision property is a multiplier allowing\r\n * rendering at a higher or lower resolution\r\n * @param successCallback defines the callback receives a single parameter which contains the\r\n * screenshot as a string of base64-encoded characters. This string can be assigned to the\r\n * src parameter of an to display it\r\n * @param mimeType defines the MIME type of the screenshot image (default: image/png).\r\n * Check your browser for supported MIME types\r\n */\r\n ScreenshotTools.CreateScreenshot = function (engine, camera, size, successCallback, mimeType) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n var _a = ScreenshotTools._getScreenshotSize(engine, camera, size), height = _a.height, width = _a.width;\r\n if (!(height && width)) {\r\n Logger.Error(\"Invalid 'size' parameter !\");\r\n return;\r\n }\r\n if (!Tools._ScreenshotCanvas) {\r\n Tools._ScreenshotCanvas = document.createElement('canvas');\r\n }\r\n Tools._ScreenshotCanvas.width = width;\r\n Tools._ScreenshotCanvas.height = height;\r\n var renderContext = Tools._ScreenshotCanvas.getContext(\"2d\");\r\n var ratio = engine.getRenderWidth() / engine.getRenderHeight();\r\n var newWidth = width;\r\n var newHeight = newWidth / ratio;\r\n if (newHeight > height) {\r\n newHeight = height;\r\n newWidth = newHeight * ratio;\r\n }\r\n var offsetX = Math.max(0, width - newWidth) / 2;\r\n var offsetY = Math.max(0, height - newHeight) / 2;\r\n var renderingCanvas = engine.getRenderingCanvas();\r\n if (renderContext && renderingCanvas) {\r\n renderContext.drawImage(renderingCanvas, offsetX, offsetY, newWidth, newHeight);\r\n }\r\n Tools.EncodeScreenshotCanvasData(successCallback, mimeType);\r\n };\r\n /**\r\n * Captures a screenshot of the current rendering\r\n * @see https://doc.babylonjs.com/how_to/render_scene_on_a_png\r\n * @param engine defines the rendering engine\r\n * @param camera defines the source camera\r\n * @param size This parameter can be set to a single number or to an object with the\r\n * following (optional) properties: precision, width, height. If a single number is passed,\r\n * it will be used for both width and height. If an object is passed, the screenshot size\r\n * will be derived from the parameters. The precision property is a multiplier allowing\r\n * rendering at a higher or lower resolution\r\n * @param mimeType defines the MIME type of the screenshot image (default: image/png).\r\n * Check your browser for supported MIME types\r\n * @returns screenshot as a string of base64-encoded characters. This string can be assigned\r\n * to the src parameter of an to display it\r\n */\r\n ScreenshotTools.CreateScreenshotAsync = function (engine, camera, size, mimeType) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n return new Promise(function (resolve, reject) {\r\n ScreenshotTools.CreateScreenshot(engine, camera, size, function (data) {\r\n if (typeof (data) !== \"undefined\") {\r\n resolve(data);\r\n }\r\n else {\r\n reject(new Error(\"Data is undefined\"));\r\n }\r\n }, mimeType);\r\n });\r\n };\r\n /**\r\n * Generates an image screenshot from the specified camera.\r\n * @see https://doc.babylonjs.com/how_to/render_scene_on_a_png\r\n * @param engine The engine to use for rendering\r\n * @param camera The camera to use for rendering\r\n * @param size This parameter can be set to a single number or to an object with the\r\n * following (optional) properties: precision, width, height. If a single number is passed,\r\n * it will be used for both width and height. If an object is passed, the screenshot size\r\n * will be derived from the parameters. The precision property is a multiplier allowing\r\n * rendering at a higher or lower resolution\r\n * @param successCallback The callback receives a single parameter which contains the\r\n * screenshot as a string of base64-encoded characters. This string can be assigned to the\r\n * src parameter of an to display it\r\n * @param mimeType The MIME type of the screenshot image (default: image/png).\r\n * Check your browser for supported MIME types\r\n * @param samples Texture samples (default: 1)\r\n * @param antialiasing Whether antialiasing should be turned on or not (default: false)\r\n * @param fileName A name for for the downloaded file.\r\n * @param renderSprites Whether the sprites should be rendered or not (default: false)\r\n * @param enableStencilBuffer Whether the stencil buffer should be enabled or not (default: false)\r\n */\r\n ScreenshotTools.CreateScreenshotUsingRenderTarget = function (engine, camera, size, successCallback, mimeType, samples, antialiasing, fileName, renderSprites, enableStencilBuffer) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n if (samples === void 0) { samples = 1; }\r\n if (antialiasing === void 0) { antialiasing = false; }\r\n if (renderSprites === void 0) { renderSprites = false; }\r\n if (enableStencilBuffer === void 0) { enableStencilBuffer = false; }\r\n var _a = ScreenshotTools._getScreenshotSize(engine, camera, size), height = _a.height, width = _a.width;\r\n var targetTextureSize = { width: width, height: height };\r\n if (!(height && width)) {\r\n Logger.Error(\"Invalid 'size' parameter !\");\r\n return;\r\n }\r\n var renderCanvas = engine.getRenderingCanvas();\r\n if (!renderCanvas) {\r\n Logger.Error(\"No rendering canvas found !\");\r\n return;\r\n }\r\n var originalSize = { width: renderCanvas.width, height: renderCanvas.height };\r\n engine.setSize(width, height);\r\n var scene = camera.getScene();\r\n var previousCamera = null;\r\n var previousCameras = scene.activeCameras;\r\n if (scene.activeCamera !== camera || scene.activeCameras && scene.activeCameras.length) {\r\n previousCamera = scene.activeCamera;\r\n scene.activeCamera = camera;\r\n }\r\n scene.render();\r\n // At this point size can be a number, or an object (according to engine.prototype.createRenderTargetTexture method)\r\n var texture = new RenderTargetTexture(\"screenShot\", targetTextureSize, scene, false, false, 0, false, Texture.NEAREST_SAMPLINGMODE, undefined, enableStencilBuffer);\r\n texture.renderList = null;\r\n texture.samples = samples;\r\n texture.renderSprites = renderSprites;\r\n texture.onAfterRenderObservable.add(function () {\r\n Tools.DumpFramebuffer(width, height, engine, successCallback, mimeType, fileName);\r\n });\r\n var renderToTexture = function () {\r\n scene.incrementRenderId();\r\n scene.resetCachedMaterial();\r\n texture.render(true);\r\n texture.dispose();\r\n if (previousCamera) {\r\n scene.activeCamera = previousCamera;\r\n }\r\n scene.activeCameras = previousCameras;\r\n engine.setSize(originalSize.width, originalSize.height);\r\n camera.getProjectionMatrix(true); // Force cache refresh;\r\n };\r\n if (antialiasing) {\r\n var fxaaPostProcess = new FxaaPostProcess('antialiasing', 1.0, scene.activeCamera);\r\n texture.addPostProcess(fxaaPostProcess);\r\n // Async Shader Compilation can lead to none ready effects in synchronous code\r\n if (!fxaaPostProcess.getEffect().isReady()) {\r\n fxaaPostProcess.getEffect().onCompiled = function () {\r\n renderToTexture();\r\n };\r\n }\r\n // The effect is ready we can render\r\n else {\r\n renderToTexture();\r\n }\r\n }\r\n else {\r\n // No need to wait for extra resources to be ready\r\n renderToTexture();\r\n }\r\n };\r\n /**\r\n * Generates an image screenshot from the specified camera.\r\n * @see https://doc.babylonjs.com/how_to/render_scene_on_a_png\r\n * @param engine The engine to use for rendering\r\n * @param camera The camera to use for rendering\r\n * @param size This parameter can be set to a single number or to an object with the\r\n * following (optional) properties: precision, width, height. If a single number is passed,\r\n * it will be used for both width and height. If an object is passed, the screenshot size\r\n * will be derived from the parameters. The precision property is a multiplier allowing\r\n * rendering at a higher or lower resolution\r\n * @param mimeType The MIME type of the screenshot image (default: image/png).\r\n * Check your browser for supported MIME types\r\n * @param samples Texture samples (default: 1)\r\n * @param antialiasing Whether antialiasing should be turned on or not (default: false)\r\n * @param fileName A name for for the downloaded file.\r\n * @param renderSprites Whether the sprites should be rendered or not (default: false)\r\n * @returns screenshot as a string of base64-encoded characters. This string can be assigned\r\n * to the src parameter of an to display it\r\n */\r\n ScreenshotTools.CreateScreenshotUsingRenderTargetAsync = function (engine, camera, size, mimeType, samples, antialiasing, fileName, renderSprites) {\r\n if (mimeType === void 0) { mimeType = \"image/png\"; }\r\n if (samples === void 0) { samples = 1; }\r\n if (antialiasing === void 0) { antialiasing = false; }\r\n if (renderSprites === void 0) { renderSprites = false; }\r\n return new Promise(function (resolve, reject) {\r\n ScreenshotTools.CreateScreenshotUsingRenderTarget(engine, camera, size, function (data) {\r\n if (typeof (data) !== \"undefined\") {\r\n resolve(data);\r\n }\r\n else {\r\n reject(new Error(\"Data is undefined\"));\r\n }\r\n }, mimeType, samples, antialiasing, fileName, renderSprites);\r\n });\r\n };\r\n /**\r\n * Gets height and width for screenshot size\r\n * @private\r\n */\r\n ScreenshotTools._getScreenshotSize = function (engine, camera, size) {\r\n var height = 0;\r\n var width = 0;\r\n //If a size value defined as object\r\n if (typeof (size) === 'object') {\r\n var precision = size.precision\r\n ? Math.abs(size.precision) // prevent GL_INVALID_VALUE : glViewport: negative width/height\r\n : 1;\r\n //If a width and height values is specified\r\n if (size.width && size.height) {\r\n height = size.height * precision;\r\n width = size.width * precision;\r\n }\r\n //If passing only width, computing height to keep display canvas ratio.\r\n else if (size.width && !size.height) {\r\n width = size.width * precision;\r\n height = Math.round(width / engine.getAspectRatio(camera));\r\n }\r\n //If passing only height, computing width to keep display canvas ratio.\r\n else if (size.height && !size.width) {\r\n height = size.height * precision;\r\n width = Math.round(height * engine.getAspectRatio(camera));\r\n }\r\n else {\r\n width = Math.round(engine.getRenderWidth() * precision);\r\n height = Math.round(width / engine.getAspectRatio(camera));\r\n }\r\n }\r\n //Assuming here that \"size\" parameter is a number\r\n else if (!isNaN(size)) {\r\n height = size;\r\n width = size;\r\n }\r\n // When creating the image data from the CanvasRenderingContext2D, the width and height is clamped to the size of the _gl context\r\n // On certain GPUs, it seems as if the _gl context truncates to an integer automatically. Therefore, if a user tries to pass the width of their canvas element\r\n // and it happens to be a float (1000.5 x 600.5 px), the engine.readPixels will return a different size array than context.createImageData\r\n // to resolve this, we truncate the floats here to ensure the same size\r\n if (width) {\r\n width = Math.floor(width);\r\n }\r\n if (height) {\r\n height = Math.floor(height);\r\n }\r\n return { height: height | 0, width: width | 0 };\r\n };\r\n return ScreenshotTools;\r\n}());\r\nexport { ScreenshotTools };\r\nTools.CreateScreenshot = ScreenshotTools.CreateScreenshot;\r\nTools.CreateScreenshotAsync = ScreenshotTools.CreateScreenshotAsync;\r\nTools.CreateScreenshotUsingRenderTarget = ScreenshotTools.CreateScreenshotUsingRenderTarget;\r\nTools.CreateScreenshotUsingRenderTargetAsync = ScreenshotTools.CreateScreenshotUsingRenderTargetAsync;\r\n//# sourceMappingURL=screenshotTools.js.map","import { ArrayTools } from \"../Misc/arrayTools\";\r\nimport { Matrix, Vector3, TmpVectors } from \"../Maths/math.vector\";\r\nimport { PickingInfo } from \"../Collisions/pickingInfo\";\r\nimport { IntersectionInfo } from \"../Collisions/intersectionInfo\";\r\nimport { Scene } from \"../scene\";\r\nimport { Camera } from \"../Cameras/camera\";\r\n/**\r\n * Class representing a ray with position and direction\r\n */\r\nvar Ray = /** @class */ (function () {\r\n /**\r\n * Creates a new ray\r\n * @param origin origin point\r\n * @param direction direction\r\n * @param length length of the ray\r\n */\r\n function Ray(\r\n /** origin point */\r\n origin, \r\n /** direction */\r\n direction, \r\n /** length of the ray */\r\n length) {\r\n if (length === void 0) { length = Number.MAX_VALUE; }\r\n this.origin = origin;\r\n this.direction = direction;\r\n this.length = length;\r\n }\r\n // Methods\r\n /**\r\n * Checks if the ray intersects a box\r\n * This does not account for the ray lenght by design to improve perfs.\r\n * @param minimum bound of the box\r\n * @param maximum bound of the box\r\n * @param intersectionTreshold extra extend to be added to the box in all direction\r\n * @returns if the box was hit\r\n */\r\n Ray.prototype.intersectsBoxMinMax = function (minimum, maximum, intersectionTreshold) {\r\n if (intersectionTreshold === void 0) { intersectionTreshold = 0; }\r\n var newMinimum = Ray._TmpVector3[0].copyFromFloats(minimum.x - intersectionTreshold, minimum.y - intersectionTreshold, minimum.z - intersectionTreshold);\r\n var newMaximum = Ray._TmpVector3[1].copyFromFloats(maximum.x + intersectionTreshold, maximum.y + intersectionTreshold, maximum.z + intersectionTreshold);\r\n var d = 0.0;\r\n var maxValue = Number.MAX_VALUE;\r\n var inv;\r\n var min;\r\n var max;\r\n var temp;\r\n if (Math.abs(this.direction.x) < 0.0000001) {\r\n if (this.origin.x < newMinimum.x || this.origin.x > newMaximum.x) {\r\n return false;\r\n }\r\n }\r\n else {\r\n inv = 1.0 / this.direction.x;\r\n min = (newMinimum.x - this.origin.x) * inv;\r\n max = (newMaximum.x - this.origin.x) * inv;\r\n if (max === -Infinity) {\r\n max = Infinity;\r\n }\r\n if (min > max) {\r\n temp = min;\r\n min = max;\r\n max = temp;\r\n }\r\n d = Math.max(min, d);\r\n maxValue = Math.min(max, maxValue);\r\n if (d > maxValue) {\r\n return false;\r\n }\r\n }\r\n if (Math.abs(this.direction.y) < 0.0000001) {\r\n if (this.origin.y < newMinimum.y || this.origin.y > newMaximum.y) {\r\n return false;\r\n }\r\n }\r\n else {\r\n inv = 1.0 / this.direction.y;\r\n min = (newMinimum.y - this.origin.y) * inv;\r\n max = (newMaximum.y - this.origin.y) * inv;\r\n if (max === -Infinity) {\r\n max = Infinity;\r\n }\r\n if (min > max) {\r\n temp = min;\r\n min = max;\r\n max = temp;\r\n }\r\n d = Math.max(min, d);\r\n maxValue = Math.min(max, maxValue);\r\n if (d > maxValue) {\r\n return false;\r\n }\r\n }\r\n if (Math.abs(this.direction.z) < 0.0000001) {\r\n if (this.origin.z < newMinimum.z || this.origin.z > newMaximum.z) {\r\n return false;\r\n }\r\n }\r\n else {\r\n inv = 1.0 / this.direction.z;\r\n min = (newMinimum.z - this.origin.z) * inv;\r\n max = (newMaximum.z - this.origin.z) * inv;\r\n if (max === -Infinity) {\r\n max = Infinity;\r\n }\r\n if (min > max) {\r\n temp = min;\r\n min = max;\r\n max = temp;\r\n }\r\n d = Math.max(min, d);\r\n maxValue = Math.min(max, maxValue);\r\n if (d > maxValue) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n /**\r\n * Checks if the ray intersects a box\r\n * This does not account for the ray lenght by design to improve perfs.\r\n * @param box the bounding box to check\r\n * @param intersectionTreshold extra extend to be added to the BoundingBox in all direction\r\n * @returns if the box was hit\r\n */\r\n Ray.prototype.intersectsBox = function (box, intersectionTreshold) {\r\n if (intersectionTreshold === void 0) { intersectionTreshold = 0; }\r\n return this.intersectsBoxMinMax(box.minimum, box.maximum, intersectionTreshold);\r\n };\r\n /**\r\n * If the ray hits a sphere\r\n * @param sphere the bounding sphere to check\r\n * @param intersectionTreshold extra extend to be added to the BoundingSphere in all direction\r\n * @returns true if it hits the sphere\r\n */\r\n Ray.prototype.intersectsSphere = function (sphere, intersectionTreshold) {\r\n if (intersectionTreshold === void 0) { intersectionTreshold = 0; }\r\n var x = sphere.center.x - this.origin.x;\r\n var y = sphere.center.y - this.origin.y;\r\n var z = sphere.center.z - this.origin.z;\r\n var pyth = x * x + y * y + z * z;\r\n var radius = sphere.radius + intersectionTreshold;\r\n var rr = radius * radius;\r\n if (pyth <= rr) {\r\n return true;\r\n }\r\n var dot = x * this.direction.x + y * this.direction.y + z * this.direction.z;\r\n if (dot < 0.0) {\r\n return false;\r\n }\r\n var temp = pyth - dot * dot;\r\n return temp <= rr;\r\n };\r\n /**\r\n * If the ray hits a triange\r\n * @param vertex0 triangle vertex\r\n * @param vertex1 triangle vertex\r\n * @param vertex2 triangle vertex\r\n * @returns intersection information if hit\r\n */\r\n Ray.prototype.intersectsTriangle = function (vertex0, vertex1, vertex2) {\r\n var edge1 = Ray._TmpVector3[0];\r\n var edge2 = Ray._TmpVector3[1];\r\n var pvec = Ray._TmpVector3[2];\r\n var tvec = Ray._TmpVector3[3];\r\n var qvec = Ray._TmpVector3[4];\r\n vertex1.subtractToRef(vertex0, edge1);\r\n vertex2.subtractToRef(vertex0, edge2);\r\n Vector3.CrossToRef(this.direction, edge2, pvec);\r\n var det = Vector3.Dot(edge1, pvec);\r\n if (det === 0) {\r\n return null;\r\n }\r\n var invdet = 1 / det;\r\n this.origin.subtractToRef(vertex0, tvec);\r\n var bv = Vector3.Dot(tvec, pvec) * invdet;\r\n if (bv < 0 || bv > 1.0) {\r\n return null;\r\n }\r\n Vector3.CrossToRef(tvec, edge1, qvec);\r\n var bw = Vector3.Dot(this.direction, qvec) * invdet;\r\n if (bw < 0 || bv + bw > 1.0) {\r\n return null;\r\n }\r\n //check if the distance is longer than the predefined length.\r\n var distance = Vector3.Dot(edge2, qvec) * invdet;\r\n if (distance > this.length) {\r\n return null;\r\n }\r\n return new IntersectionInfo(1 - bv - bw, bv, distance);\r\n };\r\n /**\r\n * Checks if ray intersects a plane\r\n * @param plane the plane to check\r\n * @returns the distance away it was hit\r\n */\r\n Ray.prototype.intersectsPlane = function (plane) {\r\n var distance;\r\n var result1 = Vector3.Dot(plane.normal, this.direction);\r\n if (Math.abs(result1) < 9.99999997475243e-7) {\r\n return null;\r\n }\r\n else {\r\n var result2 = Vector3.Dot(plane.normal, this.origin);\r\n distance = (-plane.d - result2) / result1;\r\n if (distance < 0.0) {\r\n if (distance < -9.99999997475243e-7) {\r\n return null;\r\n }\r\n else {\r\n return 0;\r\n }\r\n }\r\n return distance;\r\n }\r\n };\r\n /**\r\n * Calculate the intercept of a ray on a given axis\r\n * @param axis to check 'x' | 'y' | 'z'\r\n * @param offset from axis interception (i.e. an offset of 1y is intercepted above ground)\r\n * @returns a vector containing the coordinates where 'axis' is equal to zero (else offset), or null if there is no intercept.\r\n */\r\n Ray.prototype.intersectsAxis = function (axis, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n switch (axis) {\r\n case \"y\":\r\n var t = (this.origin.y - offset) / this.direction.y;\r\n if (t > 0) {\r\n return null;\r\n }\r\n return new Vector3(this.origin.x + this.direction.x * -t, offset, this.origin.z + this.direction.z * -t);\r\n case \"x\":\r\n var t = (this.origin.x - offset) / this.direction.x;\r\n if (t > 0) {\r\n return null;\r\n }\r\n return new Vector3(offset, this.origin.y + this.direction.y * -t, this.origin.z + this.direction.z * -t);\r\n case \"z\":\r\n var t = (this.origin.z - offset) / this.direction.z;\r\n if (t > 0) {\r\n return null;\r\n }\r\n return new Vector3(this.origin.x + this.direction.x * -t, this.origin.y + this.direction.y * -t, offset);\r\n default:\r\n return null;\r\n }\r\n };\r\n /**\r\n * Checks if ray intersects a mesh\r\n * @param mesh the mesh to check\r\n * @param fastCheck defines if the first intersection will be used (and not the closest)\r\n * @returns picking info of the intersecton\r\n */\r\n Ray.prototype.intersectsMesh = function (mesh, fastCheck) {\r\n var tm = TmpVectors.Matrix[0];\r\n mesh.getWorldMatrix().invertToRef(tm);\r\n if (this._tmpRay) {\r\n Ray.TransformToRef(this, tm, this._tmpRay);\r\n }\r\n else {\r\n this._tmpRay = Ray.Transform(this, tm);\r\n }\r\n return mesh.intersects(this._tmpRay, fastCheck);\r\n };\r\n /**\r\n * Checks if ray intersects a mesh\r\n * @param meshes the meshes to check\r\n * @param fastCheck defines if the first intersection will be used (and not the closest)\r\n * @param results array to store result in\r\n * @returns Array of picking infos\r\n */\r\n Ray.prototype.intersectsMeshes = function (meshes, fastCheck, results) {\r\n if (results) {\r\n results.length = 0;\r\n }\r\n else {\r\n results = [];\r\n }\r\n for (var i = 0; i < meshes.length; i++) {\r\n var pickInfo = this.intersectsMesh(meshes[i], fastCheck);\r\n if (pickInfo.hit) {\r\n results.push(pickInfo);\r\n }\r\n }\r\n results.sort(this._comparePickingInfo);\r\n return results;\r\n };\r\n Ray.prototype._comparePickingInfo = function (pickingInfoA, pickingInfoB) {\r\n if (pickingInfoA.distance < pickingInfoB.distance) {\r\n return -1;\r\n }\r\n else if (pickingInfoA.distance > pickingInfoB.distance) {\r\n return 1;\r\n }\r\n else {\r\n return 0;\r\n }\r\n };\r\n /**\r\n * Intersection test between the ray and a given segment whithin a given tolerance (threshold)\r\n * @param sega the first point of the segment to test the intersection against\r\n * @param segb the second point of the segment to test the intersection against\r\n * @param threshold the tolerance margin, if the ray doesn't intersect the segment but is close to the given threshold, the intersection is successful\r\n * @return the distance from the ray origin to the intersection point if there's intersection, or -1 if there's no intersection\r\n */\r\n Ray.prototype.intersectionSegment = function (sega, segb, threshold) {\r\n var o = this.origin;\r\n var u = TmpVectors.Vector3[0];\r\n var rsegb = TmpVectors.Vector3[1];\r\n var v = TmpVectors.Vector3[2];\r\n var w = TmpVectors.Vector3[3];\r\n segb.subtractToRef(sega, u);\r\n this.direction.scaleToRef(Ray.rayl, v);\r\n o.addToRef(v, rsegb);\r\n sega.subtractToRef(o, w);\r\n var a = Vector3.Dot(u, u); // always >= 0\r\n var b = Vector3.Dot(u, v);\r\n var c = Vector3.Dot(v, v); // always >= 0\r\n var d = Vector3.Dot(u, w);\r\n var e = Vector3.Dot(v, w);\r\n var D = a * c - b * b; // always >= 0\r\n var sc, sN, sD = D; // sc = sN / sD, default sD = D >= 0\r\n var tc, tN, tD = D; // tc = tN / tD, default tD = D >= 0\r\n // compute the line parameters of the two closest points\r\n if (D < Ray.smallnum) {\r\n // the lines are almost parallel\r\n sN = 0.0; // force using point P0 on segment S1\r\n sD = 1.0; // to prevent possible division by 0.0 later\r\n tN = e;\r\n tD = c;\r\n }\r\n else {\r\n // get the closest points on the infinite lines\r\n sN = b * e - c * d;\r\n tN = a * e - b * d;\r\n if (sN < 0.0) {\r\n // sc < 0 => the s=0 edge is visible\r\n sN = 0.0;\r\n tN = e;\r\n tD = c;\r\n }\r\n else if (sN > sD) {\r\n // sc > 1 => the s=1 edge is visible\r\n sN = sD;\r\n tN = e + b;\r\n tD = c;\r\n }\r\n }\r\n if (tN < 0.0) {\r\n // tc < 0 => the t=0 edge is visible\r\n tN = 0.0;\r\n // recompute sc for this edge\r\n if (-d < 0.0) {\r\n sN = 0.0;\r\n }\r\n else if (-d > a) {\r\n sN = sD;\r\n }\r\n else {\r\n sN = -d;\r\n sD = a;\r\n }\r\n }\r\n else if (tN > tD) {\r\n // tc > 1 => the t=1 edge is visible\r\n tN = tD;\r\n // recompute sc for this edge\r\n if (-d + b < 0.0) {\r\n sN = 0;\r\n }\r\n else if (-d + b > a) {\r\n sN = sD;\r\n }\r\n else {\r\n sN = -d + b;\r\n sD = a;\r\n }\r\n }\r\n // finally do the division to get sc and tc\r\n sc = Math.abs(sN) < Ray.smallnum ? 0.0 : sN / sD;\r\n tc = Math.abs(tN) < Ray.smallnum ? 0.0 : tN / tD;\r\n // get the difference of the two closest points\r\n var qtc = TmpVectors.Vector3[4];\r\n v.scaleToRef(tc, qtc);\r\n var qsc = TmpVectors.Vector3[5];\r\n u.scaleToRef(sc, qsc);\r\n qsc.addInPlace(w);\r\n var dP = TmpVectors.Vector3[6];\r\n qsc.subtractToRef(qtc, dP); // = S1(sc) - S2(tc)\r\n var isIntersected = tc > 0 && tc <= this.length && dP.lengthSquared() < threshold * threshold; // return intersection result\r\n if (isIntersected) {\r\n return qsc.length();\r\n }\r\n return -1;\r\n };\r\n /**\r\n * Update the ray from viewport position\r\n * @param x position\r\n * @param y y position\r\n * @param viewportWidth viewport width\r\n * @param viewportHeight viewport height\r\n * @param world world matrix\r\n * @param view view matrix\r\n * @param projection projection matrix\r\n * @returns this ray updated\r\n */\r\n Ray.prototype.update = function (x, y, viewportWidth, viewportHeight, world, view, projection) {\r\n this.unprojectRayToRef(x, y, viewportWidth, viewportHeight, world, view, projection);\r\n return this;\r\n };\r\n // Statics\r\n /**\r\n * Creates a ray with origin and direction of 0,0,0\r\n * @returns the new ray\r\n */\r\n Ray.Zero = function () {\r\n return new Ray(Vector3.Zero(), Vector3.Zero());\r\n };\r\n /**\r\n * Creates a new ray from screen space and viewport\r\n * @param x position\r\n * @param y y position\r\n * @param viewportWidth viewport width\r\n * @param viewportHeight viewport height\r\n * @param world world matrix\r\n * @param view view matrix\r\n * @param projection projection matrix\r\n * @returns new ray\r\n */\r\n Ray.CreateNew = function (x, y, viewportWidth, viewportHeight, world, view, projection) {\r\n var result = Ray.Zero();\r\n return result.update(x, y, viewportWidth, viewportHeight, world, view, projection);\r\n };\r\n /**\r\n * Function will create a new transformed ray starting from origin and ending at the end point. Ray's length will be set, and ray will be\r\n * transformed to the given world matrix.\r\n * @param origin The origin point\r\n * @param end The end point\r\n * @param world a matrix to transform the ray to. Default is the identity matrix.\r\n * @returns the new ray\r\n */\r\n Ray.CreateNewFromTo = function (origin, end, world) {\r\n if (world === void 0) { world = Matrix.IdentityReadOnly; }\r\n var direction = end.subtract(origin);\r\n var length = Math.sqrt(direction.x * direction.x + direction.y * direction.y + direction.z * direction.z);\r\n direction.normalize();\r\n return Ray.Transform(new Ray(origin, direction, length), world);\r\n };\r\n /**\r\n * Transforms a ray by a matrix\r\n * @param ray ray to transform\r\n * @param matrix matrix to apply\r\n * @returns the resulting new ray\r\n */\r\n Ray.Transform = function (ray, matrix) {\r\n var result = new Ray(new Vector3(0, 0, 0), new Vector3(0, 0, 0));\r\n Ray.TransformToRef(ray, matrix, result);\r\n return result;\r\n };\r\n /**\r\n * Transforms a ray by a matrix\r\n * @param ray ray to transform\r\n * @param matrix matrix to apply\r\n * @param result ray to store result in\r\n */\r\n Ray.TransformToRef = function (ray, matrix, result) {\r\n Vector3.TransformCoordinatesToRef(ray.origin, matrix, result.origin);\r\n Vector3.TransformNormalToRef(ray.direction, matrix, result.direction);\r\n result.length = ray.length;\r\n var dir = result.direction;\r\n var len = dir.length();\r\n if (!(len === 0 || len === 1)) {\r\n var num = 1.0 / len;\r\n dir.x *= num;\r\n dir.y *= num;\r\n dir.z *= num;\r\n result.length *= len;\r\n }\r\n };\r\n /**\r\n * Unproject a ray from screen space to object space\r\n * @param sourceX defines the screen space x coordinate to use\r\n * @param sourceY defines the screen space y coordinate to use\r\n * @param viewportWidth defines the current width of the viewport\r\n * @param viewportHeight defines the current height of the viewport\r\n * @param world defines the world matrix to use (can be set to Identity to go to world space)\r\n * @param view defines the view matrix to use\r\n * @param projection defines the projection matrix to use\r\n */\r\n Ray.prototype.unprojectRayToRef = function (sourceX, sourceY, viewportWidth, viewportHeight, world, view, projection) {\r\n var matrix = TmpVectors.Matrix[0];\r\n world.multiplyToRef(view, matrix);\r\n matrix.multiplyToRef(projection, matrix);\r\n matrix.invert();\r\n var nearScreenSource = TmpVectors.Vector3[0];\r\n nearScreenSource.x = (sourceX / viewportWidth) * 2 - 1;\r\n nearScreenSource.y = -((sourceY / viewportHeight) * 2 - 1);\r\n nearScreenSource.z = -1.0;\r\n var farScreenSource = TmpVectors.Vector3[1].copyFromFloats(nearScreenSource.x, nearScreenSource.y, 1.0);\r\n var nearVec3 = TmpVectors.Vector3[2];\r\n var farVec3 = TmpVectors.Vector3[3];\r\n Vector3._UnprojectFromInvertedMatrixToRef(nearScreenSource, matrix, nearVec3);\r\n Vector3._UnprojectFromInvertedMatrixToRef(farScreenSource, matrix, farVec3);\r\n this.origin.copyFrom(nearVec3);\r\n farVec3.subtractToRef(nearVec3, this.direction);\r\n this.direction.normalize();\r\n };\r\n Ray._TmpVector3 = ArrayTools.BuildArray(6, Vector3.Zero);\r\n Ray.smallnum = 0.00000001;\r\n Ray.rayl = 10e8;\r\n return Ray;\r\n}());\r\nexport { Ray };\r\nScene.prototype.createPickingRay = function (x, y, world, camera, cameraViewSpace) {\r\n if (cameraViewSpace === void 0) { cameraViewSpace = false; }\r\n var result = Ray.Zero();\r\n this.createPickingRayToRef(x, y, world, result, camera, cameraViewSpace);\r\n return result;\r\n};\r\nScene.prototype.createPickingRayToRef = function (x, y, world, result, camera, cameraViewSpace) {\r\n if (cameraViewSpace === void 0) { cameraViewSpace = false; }\r\n var engine = this.getEngine();\r\n if (!camera) {\r\n if (!this.activeCamera) {\r\n return this;\r\n }\r\n camera = this.activeCamera;\r\n }\r\n var cameraViewport = camera.viewport;\r\n var viewport = cameraViewport.toGlobal(engine.getRenderWidth(), engine.getRenderHeight());\r\n // Moving coordinates to local viewport world\r\n x = x / engine.getHardwareScalingLevel() - viewport.x;\r\n y = y / engine.getHardwareScalingLevel() - (engine.getRenderHeight() - viewport.y - viewport.height);\r\n result.update(x, y, viewport.width, viewport.height, world ? world : Matrix.IdentityReadOnly, cameraViewSpace ? Matrix.IdentityReadOnly : camera.getViewMatrix(), camera.getProjectionMatrix());\r\n return this;\r\n};\r\nScene.prototype.createPickingRayInCameraSpace = function (x, y, camera) {\r\n var result = Ray.Zero();\r\n this.createPickingRayInCameraSpaceToRef(x, y, result, camera);\r\n return result;\r\n};\r\nScene.prototype.createPickingRayInCameraSpaceToRef = function (x, y, result, camera) {\r\n if (!PickingInfo) {\r\n return this;\r\n }\r\n var engine = this.getEngine();\r\n if (!camera) {\r\n if (!this.activeCamera) {\r\n throw new Error(\"Active camera not set\");\r\n }\r\n camera = this.activeCamera;\r\n }\r\n var cameraViewport = camera.viewport;\r\n var viewport = cameraViewport.toGlobal(engine.getRenderWidth(), engine.getRenderHeight());\r\n var identity = Matrix.Identity();\r\n // Moving coordinates to local viewport world\r\n x = x / engine.getHardwareScalingLevel() - viewport.x;\r\n y = y / engine.getHardwareScalingLevel() - (engine.getRenderHeight() - viewport.y - viewport.height);\r\n result.update(x, y, viewport.width, viewport.height, identity, identity, camera.getProjectionMatrix());\r\n return this;\r\n};\r\nScene.prototype._internalPickForMesh = function (pickingInfo, rayFunction, mesh, world, fastCheck, onlyBoundingInfo, trianglePredicate, skipBoundingInfo) {\r\n var ray = rayFunction(world);\r\n var result = mesh.intersects(ray, fastCheck, trianglePredicate, onlyBoundingInfo, world, skipBoundingInfo);\r\n if (!result || !result.hit) {\r\n return null;\r\n }\r\n if (!fastCheck && pickingInfo != null && result.distance >= pickingInfo.distance) {\r\n return null;\r\n }\r\n return result;\r\n};\r\nScene.prototype._internalPick = function (rayFunction, predicate, fastCheck, onlyBoundingInfo, trianglePredicate) {\r\n if (!PickingInfo) {\r\n return null;\r\n }\r\n var pickingInfo = null;\r\n for (var meshIndex = 0; meshIndex < this.meshes.length; meshIndex++) {\r\n var mesh = this.meshes[meshIndex];\r\n if (predicate) {\r\n if (!predicate(mesh)) {\r\n continue;\r\n }\r\n }\r\n else if (!mesh.isEnabled() || !mesh.isVisible || !mesh.isPickable) {\r\n continue;\r\n }\r\n var world = mesh.skeleton && mesh.skeleton.overrideMesh ? mesh.skeleton.overrideMesh.getWorldMatrix() : mesh.getWorldMatrix();\r\n if (mesh.hasThinInstances && mesh.thinInstanceEnablePicking) {\r\n // first check if the ray intersects the whole bounding box/sphere of the mesh\r\n var result = this._internalPickForMesh(pickingInfo, rayFunction, mesh, world, true, true, trianglePredicate);\r\n if (result) {\r\n if (onlyBoundingInfo) {\r\n // the user only asked for a bounding info check so we can return\r\n return pickingInfo;\r\n }\r\n var tmpMatrix = TmpVectors.Matrix[1];\r\n var thinMatrices = mesh.thinInstanceGetWorldMatrices();\r\n for (var index = 0; index < thinMatrices.length; index++) {\r\n var thinMatrix = thinMatrices[index];\r\n thinMatrix.multiplyToRef(world, tmpMatrix);\r\n var result_1 = this._internalPickForMesh(pickingInfo, rayFunction, mesh, tmpMatrix, fastCheck, onlyBoundingInfo, trianglePredicate, true);\r\n if (result_1) {\r\n pickingInfo = result_1;\r\n pickingInfo.thinInstanceIndex = index;\r\n if (fastCheck) {\r\n return pickingInfo;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n var result = this._internalPickForMesh(pickingInfo, rayFunction, mesh, world, fastCheck, onlyBoundingInfo, trianglePredicate);\r\n if (result) {\r\n pickingInfo = result;\r\n if (fastCheck) {\r\n return pickingInfo;\r\n }\r\n }\r\n }\r\n }\r\n return pickingInfo || new PickingInfo();\r\n};\r\nScene.prototype._internalMultiPick = function (rayFunction, predicate, trianglePredicate) {\r\n if (!PickingInfo) {\r\n return null;\r\n }\r\n var pickingInfos = new Array();\r\n for (var meshIndex = 0; meshIndex < this.meshes.length; meshIndex++) {\r\n var mesh = this.meshes[meshIndex];\r\n if (predicate) {\r\n if (!predicate(mesh)) {\r\n continue;\r\n }\r\n }\r\n else if (!mesh.isEnabled() || !mesh.isVisible || !mesh.isPickable) {\r\n continue;\r\n }\r\n var world = mesh.skeleton && mesh.skeleton.overrideMesh ? mesh.skeleton.overrideMesh.getWorldMatrix() : mesh.getWorldMatrix();\r\n if (mesh.hasThinInstances && mesh.thinInstanceEnablePicking) {\r\n var result = this._internalPickForMesh(null, rayFunction, mesh, world, true, true, trianglePredicate);\r\n if (result) {\r\n var tmpMatrix = TmpVectors.Matrix[1];\r\n var thinMatrices = mesh.thinInstanceGetWorldMatrices();\r\n for (var index = 0; index < thinMatrices.length; index++) {\r\n var thinMatrix = thinMatrices[index];\r\n thinMatrix.multiplyToRef(world, tmpMatrix);\r\n var result_2 = this._internalPickForMesh(null, rayFunction, mesh, tmpMatrix, false, false, trianglePredicate, true);\r\n if (result_2) {\r\n result_2.thinInstanceIndex = index;\r\n pickingInfos.push(result_2);\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n var result = this._internalPickForMesh(null, rayFunction, mesh, world, false, false, trianglePredicate);\r\n if (result) {\r\n pickingInfos.push(result);\r\n }\r\n }\r\n }\r\n return pickingInfos;\r\n};\r\nScene.prototype.pickWithBoundingInfo = function (x, y, predicate, fastCheck, camera) {\r\n var _this = this;\r\n if (!PickingInfo) {\r\n return null;\r\n }\r\n var result = this._internalPick(function (world) {\r\n if (!_this._tempPickingRay) {\r\n _this._tempPickingRay = Ray.Zero();\r\n }\r\n _this.createPickingRayToRef(x, y, world, _this._tempPickingRay, camera || null);\r\n return _this._tempPickingRay;\r\n }, predicate, fastCheck, true);\r\n if (result) {\r\n result.ray = this.createPickingRay(x, y, Matrix.Identity(), camera || null);\r\n }\r\n return result;\r\n};\r\nScene.prototype.pick = function (x, y, predicate, fastCheck, camera, trianglePredicate) {\r\n var _this = this;\r\n if (!PickingInfo) {\r\n return null;\r\n }\r\n var result = this._internalPick(function (world) {\r\n if (!_this._tempPickingRay) {\r\n _this._tempPickingRay = Ray.Zero();\r\n }\r\n _this.createPickingRayToRef(x, y, world, _this._tempPickingRay, camera || null);\r\n return _this._tempPickingRay;\r\n }, predicate, fastCheck, false, trianglePredicate);\r\n if (result) {\r\n result.ray = this.createPickingRay(x, y, Matrix.Identity(), camera || null);\r\n }\r\n return result;\r\n};\r\nScene.prototype.pickWithRay = function (ray, predicate, fastCheck, trianglePredicate) {\r\n var _this = this;\r\n var result = this._internalPick(function (world) {\r\n if (!_this._pickWithRayInverseMatrix) {\r\n _this._pickWithRayInverseMatrix = Matrix.Identity();\r\n }\r\n world.invertToRef(_this._pickWithRayInverseMatrix);\r\n if (!_this._cachedRayForTransform) {\r\n _this._cachedRayForTransform = Ray.Zero();\r\n }\r\n Ray.TransformToRef(ray, _this._pickWithRayInverseMatrix, _this._cachedRayForTransform);\r\n return _this._cachedRayForTransform;\r\n }, predicate, fastCheck, false, trianglePredicate);\r\n if (result) {\r\n result.ray = ray;\r\n }\r\n return result;\r\n};\r\nScene.prototype.multiPick = function (x, y, predicate, camera, trianglePredicate) {\r\n var _this = this;\r\n return this._internalMultiPick(function (world) { return _this.createPickingRay(x, y, world, camera || null); }, predicate, trianglePredicate);\r\n};\r\nScene.prototype.multiPickWithRay = function (ray, predicate, trianglePredicate) {\r\n var _this = this;\r\n return this._internalMultiPick(function (world) {\r\n if (!_this._pickWithRayInverseMatrix) {\r\n _this._pickWithRayInverseMatrix = Matrix.Identity();\r\n }\r\n world.invertToRef(_this._pickWithRayInverseMatrix);\r\n if (!_this._cachedRayForTransform) {\r\n _this._cachedRayForTransform = Ray.Zero();\r\n }\r\n Ray.TransformToRef(ray, _this._pickWithRayInverseMatrix, _this._cachedRayForTransform);\r\n return _this._cachedRayForTransform;\r\n }, predicate, trianglePredicate);\r\n};\r\nCamera.prototype.getForwardRay = function (length, transform, origin) {\r\n if (length === void 0) { length = 100; }\r\n return this.getForwardRayToRef(new Ray(Vector3.Zero(), Vector3.Zero(), length), length, transform, origin);\r\n};\r\nCamera.prototype.getForwardRayToRef = function (refRay, length, transform, origin) {\r\n if (length === void 0) { length = 100; }\r\n if (!transform) {\r\n transform = this.getWorldMatrix();\r\n }\r\n refRay.length = length;\r\n if (!origin) {\r\n refRay.origin.copyFrom(this.position);\r\n }\r\n else {\r\n refRay.origin.copyFrom(origin);\r\n }\r\n TmpVectors.Vector3[2].set(0, 0, this._scene.useRightHandedSystem ? -1 : 1);\r\n Vector3.TransformNormalToRef(TmpVectors.Vector3[2], transform, TmpVectors.Vector3[3]);\r\n Vector3.NormalizeToRef(TmpVectors.Vector3[3], refRay.direction);\r\n return refRay;\r\n};\r\n//# sourceMappingURL=ray.js.map","import { Vector3, Matrix } from '../Maths/math.vector';\r\n/**\r\n * Class containing a set of static utilities functions for managing Pivots\r\n * @hidden\r\n */\r\nvar PivotTools = /** @class */ (function () {\r\n function PivotTools() {\r\n }\r\n /** @hidden */\r\n PivotTools._RemoveAndStorePivotPoint = function (mesh) {\r\n if (mesh && PivotTools._PivotCached === 0) {\r\n // Save old pivot and set pivot to 0,0,0\r\n mesh.getPivotPointToRef(PivotTools._OldPivotPoint);\r\n PivotTools._PivotPostMultiplyPivotMatrix = mesh._postMultiplyPivotMatrix;\r\n if (!PivotTools._OldPivotPoint.equalsToFloats(0, 0, 0)) {\r\n mesh.setPivotMatrix(Matrix.IdentityReadOnly);\r\n PivotTools._OldPivotPoint.subtractToRef(mesh.getPivotPoint(), PivotTools._PivotTranslation);\r\n PivotTools._PivotTmpVector.copyFromFloats(1, 1, 1);\r\n PivotTools._PivotTmpVector.subtractInPlace(mesh.scaling);\r\n PivotTools._PivotTmpVector.multiplyInPlace(PivotTools._PivotTranslation);\r\n mesh.position.addInPlace(PivotTools._PivotTmpVector);\r\n }\r\n }\r\n PivotTools._PivotCached++;\r\n };\r\n /** @hidden */\r\n PivotTools._RestorePivotPoint = function (mesh) {\r\n if (mesh && !PivotTools._OldPivotPoint.equalsToFloats(0, 0, 0) && PivotTools._PivotCached === 1) {\r\n mesh.setPivotPoint(PivotTools._OldPivotPoint);\r\n mesh._postMultiplyPivotMatrix = PivotTools._PivotPostMultiplyPivotMatrix;\r\n PivotTools._PivotTmpVector.copyFromFloats(1, 1, 1);\r\n PivotTools._PivotTmpVector.subtractInPlace(mesh.scaling);\r\n PivotTools._PivotTmpVector.multiplyInPlace(PivotTools._PivotTranslation);\r\n mesh.position.subtractInPlace(PivotTools._PivotTmpVector);\r\n }\r\n this._PivotCached--;\r\n };\r\n // Stores the state of the pivot cache (_oldPivotPoint, _pivotTranslation)\r\n // store/remove pivot point should only be applied during their outermost calls\r\n PivotTools._PivotCached = 0;\r\n PivotTools._OldPivotPoint = new Vector3();\r\n PivotTools._PivotTranslation = new Vector3();\r\n PivotTools._PivotTmpVector = new Vector3();\r\n PivotTools._PivotPostMultiplyPivotMatrix = false;\r\n return PivotTools;\r\n}());\r\nexport { PivotTools };\r\n//# sourceMappingURL=pivotTools.js.map","import { Mesh } from \"../../Meshes/mesh\";\r\nimport { Scene } from \"../../scene\";\r\nimport { Observable } from \"../../Misc/observable\";\r\nimport { Vector3 } from \"../../Maths/math.vector\";\r\nimport { PointerEventTypes } from \"../../Events/pointerEvents\";\r\nimport { Ray } from \"../../Culling/ray\";\r\nimport { PivotTools } from '../../Misc/pivotTools';\r\nimport \"../../Meshes/Builders/planeBuilder\";\r\n/**\r\n * A behavior that when attached to a mesh will allow the mesh to be dragged around the screen based on pointer events\r\n */\r\nvar PointerDragBehavior = /** @class */ (function () {\r\n /**\r\n * Creates a pointer drag behavior that can be attached to a mesh\r\n * @param options The drag axis or normal of the plane that will be dragged across. If no options are specified the drag plane will always face the ray's origin (eg. camera)\r\n */\r\n function PointerDragBehavior(options) {\r\n this._useAlternatePickedPointAboveMaxDragAngleDragSpeed = -1.1;\r\n /**\r\n * The maximum tolerated angle between the drag plane and dragging pointer rays to trigger pointer events. Set to 0 to allow any angle (default: 0)\r\n */\r\n this.maxDragAngle = 0;\r\n /**\r\n * @hidden\r\n */\r\n this._useAlternatePickedPointAboveMaxDragAngle = false;\r\n /**\r\n * The id of the pointer that is currently interacting with the behavior (-1 when no pointer is active)\r\n */\r\n this.currentDraggingPointerID = -1;\r\n /**\r\n * If the behavior is currently in a dragging state\r\n */\r\n this.dragging = false;\r\n /**\r\n * The distance towards the target drag position to move each frame. This can be useful to avoid jitter. Set this to 1 for no delay. (Default: 0.2)\r\n */\r\n this.dragDeltaRatio = 0.2;\r\n /**\r\n * If the drag plane orientation should be updated during the dragging (Default: true)\r\n */\r\n this.updateDragPlane = true;\r\n // Debug mode will display drag planes to help visualize behavior\r\n this._debugMode = false;\r\n this._moving = false;\r\n /**\r\n * Fires each time the attached mesh is dragged with the pointer\r\n * * delta between last drag position and current drag position in world space\r\n * * dragDistance along the drag axis\r\n * * dragPlaneNormal normal of the current drag plane used during the drag\r\n * * dragPlanePoint in world space where the drag intersects the drag plane\r\n */\r\n this.onDragObservable = new Observable();\r\n /**\r\n * Fires each time a drag begins (eg. mouse down on mesh)\r\n */\r\n this.onDragStartObservable = new Observable();\r\n /**\r\n * Fires each time a drag ends (eg. mouse release after drag)\r\n */\r\n this.onDragEndObservable = new Observable();\r\n /**\r\n * If the attached mesh should be moved when dragged\r\n */\r\n this.moveAttached = true;\r\n /**\r\n * If the drag behavior will react to drag events (Default: true)\r\n */\r\n this.enabled = true;\r\n /**\r\n * If pointer events should start and release the drag (Default: true)\r\n */\r\n this.startAndReleaseDragOnPointerEvents = true;\r\n /**\r\n * If camera controls should be detached during the drag\r\n */\r\n this.detachCameraControls = true;\r\n /**\r\n * If set, the drag plane/axis will be rotated based on the attached mesh's world rotation (Default: true)\r\n */\r\n this.useObjectOrientationForDragging = true;\r\n /**\r\n * Predicate to determine if it is valid to move the object to a new position when it is moved\r\n */\r\n this.validateDrag = function (targetPosition) { return true; };\r\n this._tmpVector = new Vector3(0, 0, 0);\r\n this._alternatePickedPoint = new Vector3(0, 0, 0);\r\n this._worldDragAxis = new Vector3(0, 0, 0);\r\n this._targetPosition = new Vector3(0, 0, 0);\r\n this._attachedToElement = false;\r\n this._startDragRay = new Ray(new Vector3(), new Vector3());\r\n this._lastPointerRay = {};\r\n this._dragDelta = new Vector3();\r\n // Variables to avoid instantiation in the below method\r\n this._pointA = new Vector3(0, 0, 0);\r\n this._pointC = new Vector3(0, 0, 0);\r\n this._localAxis = new Vector3(0, 0, 0);\r\n this._lookAt = new Vector3(0, 0, 0);\r\n this._options = options ? options : {};\r\n var optionCount = 0;\r\n if (this._options.dragAxis) {\r\n optionCount++;\r\n }\r\n if (this._options.dragPlaneNormal) {\r\n optionCount++;\r\n }\r\n if (optionCount > 1) {\r\n throw \"Multiple drag modes specified in dragBehavior options. Only one expected\";\r\n }\r\n }\r\n Object.defineProperty(PointerDragBehavior.prototype, \"options\", {\r\n /**\r\n * Gets the options used by the behavior\r\n */\r\n get: function () {\r\n return this._options;\r\n },\r\n /**\r\n * Sets the options used by the behavior\r\n */\r\n set: function (options) {\r\n this._options = options;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n Object.defineProperty(PointerDragBehavior.prototype, \"name\", {\r\n /**\r\n * The name of the behavior\r\n */\r\n get: function () {\r\n return \"PointerDrag\";\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n /**\r\n * Initializes the behavior\r\n */\r\n PointerDragBehavior.prototype.init = function () { };\r\n /**\r\n * Attaches the drag behavior the passed in mesh\r\n * @param ownerNode The mesh that will be dragged around once attached\r\n * @param predicate Predicate to use for pick filtering\r\n */\r\n PointerDragBehavior.prototype.attach = function (ownerNode, predicate) {\r\n var _this = this;\r\n this._scene = ownerNode.getScene();\r\n this.attachedNode = ownerNode;\r\n // Initialize drag plane to not interfere with existing scene\r\n if (!PointerDragBehavior._planeScene) {\r\n if (this._debugMode) {\r\n PointerDragBehavior._planeScene = this._scene;\r\n }\r\n else {\r\n PointerDragBehavior._planeScene = new Scene(this._scene.getEngine(), { virtual: true });\r\n PointerDragBehavior._planeScene.detachControl();\r\n this._scene.onDisposeObservable.addOnce(function () {\r\n PointerDragBehavior._planeScene.dispose();\r\n PointerDragBehavior._planeScene = null;\r\n });\r\n }\r\n }\r\n this._dragPlane = Mesh.CreatePlane(\"pointerDragPlane\", this._debugMode ? 1 : 10000, PointerDragBehavior._planeScene, false, Mesh.DOUBLESIDE);\r\n // State of the drag\r\n this.lastDragPosition = new Vector3(0, 0, 0);\r\n var pickPredicate = !!predicate ? predicate : function (m) {\r\n return _this.attachedNode == m || m.isDescendantOf(_this.attachedNode);\r\n };\r\n this._pointerObserver = this._scene.onPointerObservable.add(function (pointerInfo, eventState) {\r\n if (!_this.enabled) {\r\n return;\r\n }\r\n if (pointerInfo.type == PointerEventTypes.POINTERDOWN) {\r\n if (_this.startAndReleaseDragOnPointerEvents && !_this.dragging && pointerInfo.pickInfo && pointerInfo.pickInfo.hit && pointerInfo.pickInfo.pickedMesh && pointerInfo.pickInfo.pickedPoint && pointerInfo.pickInfo.ray && pickPredicate(pointerInfo.pickInfo.pickedMesh)) {\r\n _this._startDrag(pointerInfo.event.pointerId, pointerInfo.pickInfo.ray, pointerInfo.pickInfo.pickedPoint);\r\n }\r\n }\r\n else if (pointerInfo.type == PointerEventTypes.POINTERUP) {\r\n if (_this.startAndReleaseDragOnPointerEvents && _this.currentDraggingPointerID == pointerInfo.event.pointerId) {\r\n _this.releaseDrag();\r\n }\r\n }\r\n else if (pointerInfo.type == PointerEventTypes.POINTERMOVE) {\r\n var pointerId = pointerInfo.event.pointerId;\r\n // If drag was started with anyMouseID specified, set pointerID to the next mouse that moved\r\n if (_this.currentDraggingPointerID === PointerDragBehavior._AnyMouseID && pointerId !== PointerDragBehavior._AnyMouseID) {\r\n var evt = pointerInfo.event;\r\n var isMouseEvent = evt.pointerType === \"mouse\" || (!_this._scene.getEngine().hostInformation.isMobile && evt instanceof MouseEvent);\r\n if (isMouseEvent) {\r\n if (_this._lastPointerRay[_this.currentDraggingPointerID]) {\r\n _this._lastPointerRay[pointerId] = _this._lastPointerRay[_this.currentDraggingPointerID];\r\n delete _this._lastPointerRay[_this.currentDraggingPointerID];\r\n }\r\n _this.currentDraggingPointerID = pointerId;\r\n }\r\n }\r\n // Keep track of last pointer ray, this is used simulating the start of a drag in startDrag()\r\n if (!_this._lastPointerRay[pointerId]) {\r\n _this._lastPointerRay[pointerId] = new Ray(new Vector3(), new Vector3());\r\n }\r\n if (pointerInfo.pickInfo && pointerInfo.pickInfo.ray) {\r\n _this._lastPointerRay[pointerId].origin.copyFrom(pointerInfo.pickInfo.ray.origin);\r\n _this._lastPointerRay[pointerId].direction.copyFrom(pointerInfo.pickInfo.ray.direction);\r\n if (_this.currentDraggingPointerID == pointerId && _this.dragging) {\r\n _this._moveDrag(pointerInfo.pickInfo.ray);\r\n }\r\n }\r\n }\r\n });\r\n this._beforeRenderObserver = this._scene.onBeforeRenderObservable.add(function () {\r\n if (_this._moving && _this.moveAttached) {\r\n PivotTools._RemoveAndStorePivotPoint(_this.attachedNode);\r\n // Slowly move mesh to avoid jitter\r\n _this._targetPosition.subtractToRef((_this.attachedNode).absolutePosition, _this._tmpVector);\r\n _this._tmpVector.scaleInPlace(_this.dragDeltaRatio);\r\n (_this.attachedNode).getAbsolutePosition().addToRef(_this._tmpVector, _this._tmpVector);\r\n if (_this.validateDrag(_this._tmpVector)) {\r\n (_this.attachedNode).setAbsolutePosition(_this._tmpVector);\r\n }\r\n PivotTools._RestorePivotPoint(_this.attachedNode);\r\n }\r\n });\r\n };\r\n /**\r\n * Force relase the drag action by code.\r\n */\r\n PointerDragBehavior.prototype.releaseDrag = function () {\r\n if (this.dragging) {\r\n this.dragging = false;\r\n this.onDragEndObservable.notifyObservers({ dragPlanePoint: this.lastDragPosition, pointerId: this.currentDraggingPointerID });\r\n }\r\n this.currentDraggingPointerID = -1;\r\n this._moving = false;\r\n // Reattach camera controls\r\n if (this.detachCameraControls && this._attachedToElement && this._scene.activeCamera && !this._scene.activeCamera.leftCamera) {\r\n if (this._scene.activeCamera.getClassName() === \"ArcRotateCamera\") {\r\n var arcRotateCamera = this._scene.activeCamera;\r\n arcRotateCamera.attachControl(arcRotateCamera.inputs ? arcRotateCamera.inputs.noPreventDefault : true, arcRotateCamera._useCtrlForPanning, arcRotateCamera._panningMouseButton);\r\n }\r\n else {\r\n this._scene.activeCamera.attachControl(this._scene.activeCamera.inputs ? this._scene.activeCamera.inputs.noPreventDefault : true);\r\n }\r\n this._attachedToElement = false;\r\n }\r\n };\r\n /**\r\n * Simulates the start of a pointer drag event on the behavior\r\n * @param pointerId pointerID of the pointer that should be simulated (Default: Any mouse pointer ID)\r\n * @param fromRay initial ray of the pointer to be simulated (Default: Ray from camera to attached mesh)\r\n * @param startPickedPoint picked point of the pointer to be simulated (Default: attached mesh position)\r\n */\r\n PointerDragBehavior.prototype.startDrag = function (pointerId, fromRay, startPickedPoint) {\r\n if (pointerId === void 0) { pointerId = PointerDragBehavior._AnyMouseID; }\r\n this._startDrag(pointerId, fromRay, startPickedPoint);\r\n var lastRay = this._lastPointerRay[pointerId];\r\n if (pointerId === PointerDragBehavior._AnyMouseID) {\r\n lastRay = this._lastPointerRay[Object.keys(this._lastPointerRay)[0]];\r\n }\r\n if (lastRay) {\r\n // if there was a last pointer ray drag the object there\r\n this._moveDrag(lastRay);\r\n }\r\n };\r\n PointerDragBehavior.prototype._startDrag = function (pointerId, fromRay, startPickedPoint) {\r\n if (!this._scene.activeCamera || this.dragging || !this.attachedNode) {\r\n return;\r\n }\r\n PivotTools._RemoveAndStorePivotPoint(this.attachedNode);\r\n // Create start ray from the camera to the object\r\n if (fromRay) {\r\n this._startDragRay.direction.copyFrom(fromRay.direction);\r\n this._startDragRay.origin.copyFrom(fromRay.origin);\r\n }\r\n else {\r\n this._startDragRay.origin.copyFrom(this._scene.activeCamera.position);\r\n this.attachedNode.getWorldMatrix().getTranslationToRef(this._tmpVector);\r\n this._tmpVector.subtractToRef(this._scene.activeCamera.position, this._startDragRay.direction);\r\n }\r\n this._updateDragPlanePosition(this._startDragRay, startPickedPoint ? startPickedPoint : this._tmpVector);\r\n var pickedPoint = this._pickWithRayOnDragPlane(this._startDragRay);\r\n if (pickedPoint) {\r\n this.dragging = true;\r\n this.currentDraggingPointerID = pointerId;\r\n this.lastDragPosition.copyFrom(pickedPoint);\r\n this.onDragStartObservable.notifyObservers({ dragPlanePoint: pickedPoint, pointerId: this.currentDraggingPointerID });\r\n this._targetPosition.copyFrom((this.attachedNode).absolutePosition);\r\n // Detatch camera controls\r\n if (this.detachCameraControls && this._scene.activeCamera && this._scene.activeCamera.inputs && !this._scene.activeCamera.leftCamera) {\r\n if (this._scene.activeCamera.inputs.attachedToElement) {\r\n this._scene.activeCamera.detachControl();\r\n this._attachedToElement = true;\r\n }\r\n else {\r\n this._attachedToElement = false;\r\n }\r\n }\r\n }\r\n PivotTools._RestorePivotPoint(this.attachedNode);\r\n };\r\n PointerDragBehavior.prototype._moveDrag = function (ray) {\r\n this._moving = true;\r\n var pickedPoint = this._pickWithRayOnDragPlane(ray);\r\n if (pickedPoint) {\r\n if (this.updateDragPlane) {\r\n this._updateDragPlanePosition(ray, pickedPoint);\r\n }\r\n var dragLength = 0;\r\n // depending on the drag mode option drag accordingly\r\n if (this._options.dragAxis) {\r\n // Convert local drag axis to world if useObjectOrientationForDragging\r\n this.useObjectOrientationForDragging ? Vector3.TransformCoordinatesToRef(this._options.dragAxis, this.attachedNode.getWorldMatrix().getRotationMatrix(), this._worldDragAxis) : this._worldDragAxis.copyFrom(this._options.dragAxis);\r\n // Project delta drag from the drag plane onto the drag axis\r\n pickedPoint.subtractToRef(this.lastDragPosition, this._tmpVector);\r\n dragLength = Vector3.Dot(this._tmpVector, this._worldDragAxis);\r\n this._worldDragAxis.scaleToRef(dragLength, this._dragDelta);\r\n }\r\n else {\r\n dragLength = this._dragDelta.length();\r\n pickedPoint.subtractToRef(this.lastDragPosition, this._dragDelta);\r\n }\r\n this._targetPosition.addInPlace(this._dragDelta);\r\n this.onDragObservable.notifyObservers({ dragDistance: dragLength, delta: this._dragDelta, dragPlanePoint: pickedPoint, dragPlaneNormal: this._dragPlane.forward, pointerId: this.currentDraggingPointerID });\r\n this.lastDragPosition.copyFrom(pickedPoint);\r\n }\r\n };\r\n PointerDragBehavior.prototype._pickWithRayOnDragPlane = function (ray) {\r\n var _this = this;\r\n if (!ray) {\r\n return null;\r\n }\r\n // Calculate angle between plane normal and ray\r\n var angle = Math.acos(Vector3.Dot(this._dragPlane.forward, ray.direction));\r\n // Correct if ray is casted from oposite side\r\n if (angle > Math.PI / 2) {\r\n angle = Math.PI - angle;\r\n }\r\n // If the angle is too perpendicular to the plane pick another point on the plane where it is looking\r\n if (this.maxDragAngle > 0 && angle > this.maxDragAngle) {\r\n if (this._useAlternatePickedPointAboveMaxDragAngle) {\r\n // Invert ray direction along the towards object axis\r\n this._tmpVector.copyFrom(ray.direction);\r\n (this.attachedNode).absolutePosition.subtractToRef(ray.origin, this._alternatePickedPoint);\r\n this._alternatePickedPoint.normalize();\r\n this._alternatePickedPoint.scaleInPlace(this._useAlternatePickedPointAboveMaxDragAngleDragSpeed * Vector3.Dot(this._alternatePickedPoint, this._tmpVector));\r\n this._tmpVector.addInPlace(this._alternatePickedPoint);\r\n // Project resulting vector onto the drag plane and add it to the attached nodes absolute position to get a picked point\r\n var dot = Vector3.Dot(this._dragPlane.forward, this._tmpVector);\r\n this._dragPlane.forward.scaleToRef(-dot, this._alternatePickedPoint);\r\n this._alternatePickedPoint.addInPlace(this._tmpVector);\r\n this._alternatePickedPoint.addInPlace((this.attachedNode).absolutePosition);\r\n return this._alternatePickedPoint;\r\n }\r\n else {\r\n return null;\r\n }\r\n }\r\n var pickResult = PointerDragBehavior._planeScene.pickWithRay(ray, function (m) { return m == _this._dragPlane; });\r\n if (pickResult && pickResult.hit && pickResult.pickedMesh && pickResult.pickedPoint) {\r\n return pickResult.pickedPoint;\r\n }\r\n else {\r\n return null;\r\n }\r\n };\r\n // Position the drag plane based on the attached mesh position, for single axis rotate the plane along the axis to face the camera\r\n PointerDragBehavior.prototype._updateDragPlanePosition = function (ray, dragPlanePosition) {\r\n this._pointA.copyFrom(dragPlanePosition);\r\n if (this._options.dragAxis) {\r\n this.useObjectOrientationForDragging ? Vector3.TransformCoordinatesToRef(this._options.dragAxis, this.attachedNode.getWorldMatrix().getRotationMatrix(), this._localAxis) : this._localAxis.copyFrom(this._options.dragAxis);\r\n // Calculate plane normal that is the cross product of local axis and (eye-dragPlanePosition)\r\n ray.origin.subtractToRef(this._pointA, this._pointC);\r\n this._pointC.normalize();\r\n if (Math.abs(Vector3.Dot(this._localAxis, this._pointC)) > 0.999) {\r\n // the drag axis is colinear with the (eye to position) ray. The cross product will give jittered values.\r\n // A new axis vector need to be computed\r\n if (Math.abs(Vector3.Dot(Vector3.UpReadOnly, this._pointC)) > 0.999) {\r\n this._lookAt.copyFrom(Vector3.Right());\r\n }\r\n else {\r\n this._lookAt.copyFrom(Vector3.UpReadOnly);\r\n }\r\n }\r\n else {\r\n Vector3.CrossToRef(this._localAxis, this._pointC, this._lookAt);\r\n // Get perpendicular line from previous result and drag axis to adjust lineB to be perpendiculat to camera\r\n Vector3.CrossToRef(this._localAxis, this._lookAt, this._lookAt);\r\n this._lookAt.normalize();\r\n }\r\n this._dragPlane.position.copyFrom(this._pointA);\r\n this._pointA.addToRef(this._lookAt, this._lookAt);\r\n this._dragPlane.lookAt(this._lookAt);\r\n }\r\n else if (this._options.dragPlaneNormal) {\r\n this.useObjectOrientationForDragging ? Vector3.TransformCoordinatesToRef(this._options.dragPlaneNormal, this.attachedNode.getWorldMatrix().getRotationMatrix(), this._localAxis) : this._localAxis.copyFrom(this._options.dragPlaneNormal);\r\n this._dragPlane.position.copyFrom(this._pointA);\r\n this._pointA.addToRef(this._localAxis, this._lookAt);\r\n this._dragPlane.lookAt(this._lookAt);\r\n }\r\n else {\r\n this._dragPlane.position.copyFrom(this._pointA);\r\n this._dragPlane.lookAt(ray.origin);\r\n }\r\n // Update the position of the drag plane so it doesn't get out of sync with the node (eg. when moving back and forth quickly)\r\n this._dragPlane.position.copyFrom(this.attachedNode.absolutePosition);\r\n this._dragPlane.computeWorldMatrix(true);\r\n };\r\n /**\r\n * Detaches the behavior from the mesh\r\n */\r\n PointerDragBehavior.prototype.detach = function () {\r\n if (this._pointerObserver) {\r\n this._scene.onPointerObservable.remove(this._pointerObserver);\r\n }\r\n if (this._beforeRenderObserver) {\r\n this._scene.onBeforeRenderObservable.remove(this._beforeRenderObserver);\r\n }\r\n this.releaseDrag();\r\n };\r\n PointerDragBehavior._AnyMouseID = -2;\r\n return PointerDragBehavior;\r\n}());\r\nexport { PointerDragBehavior };\r\n//# sourceMappingURL=pointerDragBehavior.js.map"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/shapeCloud.js b/dist/examples/shapeCloud.js new file mode 100644 index 0000000..cdc323e --- /dev/null +++ b/dist/examples/shapeCloud.js @@ -0,0 +1,20 @@ +/** + * Babyplots - Easy, fast, interactive 3D visualizations + * + * Copyright (c) 2020, Nils Jonathan Trost. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ + +var shapeCloudData = {"plots": [{"coordinates":[[-5.47153894407619,3.67779276573484,-6.35111913665569],[-2.61245796977612,-2.70889789878519,-3.17913754221493],[9.99126237737431,1.10790763395374,-1.32628120736659],[-4.43661059752594,7.1221142335046,7.96931899541464],[-5.05150160251378,-2.87331558404765,-3.58752082431472],[2.5242102147851,6.43553119256394,6.82000274040814],[2.4991850340614,-10.0488341523659,-0.337696560946577],[1.01875761486695,-0.537381178921556,-6.19166554351576],[-2.99886874655236,0.504805267698767,3.19367896009439],[-4.54994531702934,-6.54805073827955,7.63002710396403],[0.0951571794772316,0.0398564113411531,3.28176077458545],[-0.806023472903699,-5.04034273810298,1.0525357485761],[-5.16554106574114,-6.95336853105865,-10.0653252594533],[-4.60018575528974,-2.83303421513727,-3.03783180980087],[1.44881420251451,5.96047078753375,6.81932618038018],[-5.6696390805676,6.86954396858672,9.13958852865695],[-4.59728835019765,-4.59145620929501,-3.33877343345014],[9.00746866533667,0.878762688252265,-1.44786219424637],[3.08280431554593,11.0291914702725,-2.16657849741601],[0.943184788879634,0.466127455145566,2.85630077131722],[1.27668873214606,11.8487448181335,-2.55346789411674],[-3.14482845857894,-2.77629472510634,4.75588399016803],[1.06679962812625,-5.55241327077101,-5.81317832871156],[0.43871409080554,6.08805260339985,8.81039875169945],[-4.19254030042605,5.94537504527274,-1.28610519957492],[4.28159307815506,3.64286625720354,1.73441098233917],[3.38593717917397,3.26913776833656,8.47397013437597],[-7.62176677943305,0.0535262960287396,-8.3315792691975],[-8.3998211561527,-5.73171389744446,0.926154965327053],[-4.65042536476337,9.91523669327817,-4.52708448073364],[0.957053230085163,-0.681435418538715,-6.41432355529934],[1.0209480460382,3.71863492032872,-8.6779009888486],[-0.126383560704165,0.42837813234961,-3.18655701623089],[2.20121077868748,3.71546581435369,-6.3883125053213],[-4.75709237951533,7.00507512141293,7.78223344798512],[-2.55315028317587,-0.958972017115755,-3.71669377381557],[0.715696739803465,-5.12151916042716,4.30764815264045],[-3.47910842187861,5.97133857227979,-0.94446352620415],[-3.21990267921271,11.3719235953516,3.60453982647139],[-2.68644837020339,5.22086634731912,-2.29647104255497],[0.385853204359147,4.29952756812018,-3.56519132993658],[-2.75092032027317,-1.98793560090363,-4.39649641015279],[4.24716940835048,1.36053342773327,2.52833635347697],[-6.74411738155452,-1.53255857930988,-5.0570024221338],[0.0240394787861776,0.270290247656984,-2.45291167123535],[2.14097687483466,11.1623928964804,-2.74063753281234],[2.9359053326595,5.49188298903688,6.90282477888433],[2.80223534399015,-5.698183259232,-4.75568886726455],[-8.03421166802666,-5.67278694146874,0.497125786685607],[9.35206476622094,-4.62923547365785,-5.39309816269407],[4.2054173008268,-6.28804912287038,-1.73167741812214],[1.73034591882598,-5.15833333765836,0.757720388475919],[-3.08663750415441,5.25009338641972,-2.69488947239683],[-1.7514749843604,-6.38627462105389,-1.5089393393755],[-5.13355032576869,-1.36467549080105,1.6439091352048],[0.00950641526146256,-0.954801357291704,-13.3880280546713],[-0.861514885972196,6.12751735036093,9.00626046998682],[2.20689825477232,-9.82415862701461,1.46404036728078],[-6.18758833193879,-3.04916365190025,-5.18491022694179],[1.35182392475406,3.85322968479977,-6.4669132080412],[-3.13916727010771,-3.15161059096384,-0.588408495340419],[-5.6114503103738,1.13341530522782,3.54635795318756],[-9.07979844176044,-0.616063125916824,-5.44245382262634],[3.33230757404059,4.58327181865086,8.03533853575673],[9.18434040044501,4.31421084481572,-2.20408004769402],[11.8797653229545,1.89300879974714,-1.29144755356564],[-2.53656886847183,-3.60321824463958,-9.58262359823094],[-1.06613841835049,-6.85374087522778,-0.651916302576144],[2.77227759442607,-8.64187781632986,-2.09499446523834],[-2.12297000791382,-0.314810396215794,-4.88833533937149],[2.90425695362822,-4.9626533447947,-1.13597238250005],[3.93052134813446,10.5233084931842,-1.09079334968552],[-4.89043041193315,-2.85029658169182,-3.45851507382322],[0.708560674244168,-6.60915647450648,3.38018478922562],[-4.15622327671885,1.23698331432396,4.12395611860463],[3.24739623359712,5.48497605735176,7.79072144567228],[2.54666067986862,11.7111119233821,-2.11178085849808],[4.15863893697475,4.9778160016123,2.70017157753635],[2.94724977730105,-10.0228457982564,-0.58279522773556],[1.7236912633786,-0.989252735645487,-4.67702858180537],[1.38040213624401,-4.59010146474567,-4.94359595056941],[2.17482856285448,-9.89447459054482,-1.96288507920562],[1.09456800902325,6.19498678281561,7.19106027043583],[2.89120863561363,-9.43807003355192,-0.313113456364075],[3.04689783673037,11.7941275723826,-2.16291327804159],[-0.130585724292282,-1.20003549041624,-11.1620162924192],[3.8951252507816,3.53009439907467,2.14490779775913],[-3.84481807030058,0.74125342199109,1.95083501246773],[-3.57620379542586,0.343902435965645,4.56914237116236],[1.33070159867285,-3.05209051406474,-11.8187580023047],[-9.60504336748751,0.45888681618788,-5.56922770730532],[2.08872644436912,5.35515037321878,7.53703715749108],[-2.86942916399952,-3.21522353635151,-7.30207291405258],[-3.60091931784191,0.1165489636129,5.60531529464569],[3.88965468764908,6.20293544045307,8.29634857226621],[4.28561045842084,-4.76190052835046,-1.63176129549586],[0.338417263847518,3.40943577148194,-8.6553793294077],[-5.08269112687548,6.38346046534227,8.40572057172104],[0.551737939237601,-9.2097675108995,0.76117602429814],[1.46143392032802,-4.807735528811,-2.50687750570406],[-2.11504319524943,6.46832987621366,-1.4747253913326],[-4.52848577021752,6.03462092228872,8.45227921474327],[-6.26194143116002,-3.11268854373733,-4.74185819442342],[2.5013764015314,5.33911518675316,7.48723132316719],[-0.14101761388142,0.228836439246601,3.21245693418576],[2.22190796713598,6.35827347366739,-11.2896102721189],[-4.70797799703279,-0.477131105388377,4.79827601265744],[1.96071507396569,-7.72139908596853,2.4740612644752],[7.60119390216064,2.84821345775688,-0.755666988229137],[3.64932542226793,-6.13812119315919,-1.42962693307125],[-9.18525505898978,-1.74934158441996,-3.62659893400018],[1.18259415214062,-6.60166737960543,0.386910355173421],[-6.30330171604585,3.19944622831804,-3.744533532725],[-5.05026778969786,1.94438939278626,4.62036667545839],[-5.29231854650357,2.81213584681586,-5.26639352432225],[10.6625962445561,-1.29170396521498,-1.92258322575924],[0.54185175086946,-9.45412418951582,0.960879339371323],[3.79204549774346,-0.0106961533527478,-9.55769360046557],[-2.83959032735865,-1.85108647405802,-6.16742657252068],[-3.91978449349362,8.00490280002224,-6.03154742013595],[-5.94734033753772,3.20136273433627,-5.62270159435917],[3.33678792616418,-5.17000157493834,-5.37276314267225],[-6.04675463808877,-3.26733095575817,4.71446210786286],[-4.6773191721699,-1.15434598379746,2.52313114965453],[-4.63766502004951,-1.24094744965015,1.88645064718934],[3.33738996508265,10.0482075476771,-1.23189237590141],[-0.0703521799442852,-3.04479734175858,-10.1117955120714],[0.865391536708639,-4.15135305871358,-5.60311275468067],[-0.0797672818106948,-3.30951882211898,12.2941061494614],[3.03806621537707,5.82957147652396,9.0197528531695],[9.59062461004037,3.38506996783659,-1.94532549480344],[-6.32580567737306,-6.2512010134055,7.27725007293752],[0.791517134176048,-3.56685269333983,8.94640603193506],[3.79786077591591,10.5803403570047,-1.42030101457815],[2.67267791229162,3.51027587451402,0.784426019961236],[8.37907738184545,0.853924988445878,-1.62649818227794],[-5.9603969647522,-6.28970802028317,-1.16698658979063],[3.88071973567832,-7.10013553271274,-2.0334475335802],[3.86473378070335,2.2761731809828,2.92203982787502],[-1.34067935322109,-8.01488521996664,-5.61024682129008],[-2.0508023038856,6.40362489808643,-0.271519131439479],[-4.44588100851668,0.751304543635314,2.66528534405619],[1.86753493053632,-7.27452989632755,-0.126102478564643],[8.04566440905797,2.88393939311459,-2.23817101928458],[0.661780200521482,-2.57605895158794,13.2196180349998],[3.34500238222181,-9.97999994472629,-0.562454441538425],[3.45619727356582,11.3236560547327,-1.83194027865684],[2.80484607104344,-4.21603725416191,-1.94717074880791],[1.99414395710239,4.02651435035535,7.82656546531826],[2.03202934797045,-7.87164714872422,-10.9176626851791],[3.05897551650439,-2.35839362987456,-6.72198228126223],[-8.58859310127346,-6.38771743844301,1.26756546334556],[7.74249076536825,-2.8494561736106,-5.03738919289373],[8.49550225784216,-3.74796998306791,-4.05181316968045],[0.501860723804498,-5.45446957541402,4.30470754278095],[0.439357514987981,1.27323500440993,-2.28773484089142],[4.87312107137984,1.64242194283367,4.69863236911915],[7.43133901969668,-1.26764120664617,-10.6778106473516],[1.50844898777456,-2.96656426431315,12.3734594194612],[-5.77511319652959,7.33809017089054,8.93588663315996],[0.973074468237991,-4.89305160989765,-2.00448618603158],[4.66374165415747,-0.964815100968287,-6.53441263955592],[3.15316642343598,4.42337239181681,7.85450303078724],[3.01734739421175,-0.268746838209342,-12.2673976436299],[1.54538710506244,6.18299540450652,9.06518460497716],[-6.66755840164859,-6.93889278487681,1.07226343580773],[3.35020633787026,-5.75660252995717,-5.25353821963177],[-4.99131427550135,6.88974075853934,8.47319576094788],[0.459263897865268,-2.72384407209839,-11.6059143186305],[0.489604421362509,-5.81957475889252,2.4633655571101],[4.04247267643977,4.35318114285617,8.52706297273681],[-9.55245537631772,-0.117781790808152,-5.63382335020378],[2.04859117903779,11.5906905386348,-1.47944669441108],[-3.28834579969973,-1.74682888812558,2.13308914234046],[-4.28220464552882,-6.16357149199599,-9.33819007431092],[0.775674698649653,-5.45044615189147,10.8468917933501],[1.41204340556145,-8.62908275495387,2.41175986135323],[-9.34490566421072,-1.27006858738331,-3.93670044219495],[-2.65825053570728,7.01721443275248,-0.525884397828371],[-1.65830035233859,3.31352166597836,-2.34334498945432],[-9.46933844729661,-1.74052055631248,-3.78303528659548],[3.7843172648119,-9.24433789576918,-0.388400417246798],[7.84724470487013,5.88884492726369,1.25714370848286],[10.5945504344555,0.0762091056068838,-1.00411672847569],[-0.694180822411703,1.40998702626272,-2.18685898571693],[-2.61940897385415,-2.54861348636403,-6.49132372053283],[0.0344591128396636,-6.21840297214609,2.3514191381401],[1.63329933882781,6.52009445727712,-11.9541229186213],[-0.104833139948341,-3.49586444232147,-11.0554345913393],[7.01346222858322,3.94188049577116,0.194039620270774],[7.31191759048707,-1.9763870471301,-10.285546086008],[-4.667065903277,8.93469544871842,-4.11555238571514],[-1.68361206744769,3.93820210916796,-2.64707166990867],[4.3477341301722,5.40450493412791,8.19786006344606],[-4.80785157914077,-0.136142838310488,-1.7630585633975],[1.21318805599972,-4.47210416835788,3.91242510957498],[-4.82685158678701,-0.321016440569984,-1.16778097423303],[2.25229575316466,3.93655502106016,7.8912826818171],[1.56482068001841,1.69736635984885,-6.02401927739155],[-2.80288566616273,-5.04815556868907,-7.80138002347395],[-5.93922753663032,-4.0393326905252,-4.62826196055562],[2.85151069411159,-1.78169456740411,-4.52252201412591],[-8.31106949669762,-5.47690815324539,0.370530293633526],[0.782867321884952,3.49495886315442,-7.9722902800279],[2.8282987808784,-6.01328174806141,4.47780143674742],[1.70585614436263,-5.9494959729639,4.02398740209748],[4.35019274425527,2.94193965084334,2.51861640164422],[3.25772015179244,4.04605280952783,8.09758794464085],[4.32406088887456,6.0116390040817,8.48747157318516],[-5.1881696511839,-5.55869537446667,-1.77622966373959],[3.6440265576923,-9.61825217036814,-1.31311000926339],[0.55806946335087,0.469554626597528,3.21502738438395],[3.1082998071913,11.5315451157237,-0.906019122300576],[2.31445459140981,-9.01473490435753,-1.06767059715629],[4.59414873513006,-5.84153198358222,-2.89414024996331],[-5.57782276193677,-1.26848826735741,0.668800957477384],[-4.63194487640396,7.48091643167505,9.33870889942061],[1.59321275405568,0.998367431480045,3.35985835668906],[-6.07534107534678,7.15723446973172,8.76350381404135],[-9.2648546145738,-1.89756297883045,-3.22306541623163],[1.64896257955765,1.56086084974121,-9.9315169611352],[-0.50994447592792,0.82721528199405,-7.23922753471746],[1.27525423666628,-9.7966738962328,1.8728137891305],[3.71114026492811,11.2855134088085,-2.282321968967],[-6.62280283227905,-5.88364756249238,7.28486655974502],[1.60055039016639,3.08784993786071,-3.56781593470498],[3.9144795324035,10.2675626172398,-0.910912387118012],[2.93616433577945,6.67507567100082,8.36227103730582],[-3.52031530622609,-6.30349472085928,-2.25288206338079],[2.63144515589339,-9.91036678194456,0.475486784789189],[-3.16847931998426,-4.30720811415825,-7.64727973909732],[-3.26488631263708,0.555356915116836,4.29762962433697],[1.34388541109361,-7.95232378314789,-10.3912826801092],[4.13593452389881,-6.98206080264616,-2.12615333555143],[-7.59485863635931,0.00975968286557027,-8.94013309714251],[2.73360033466662,11.3876733440931,-2.47311258425845],[-1.7328181513662,-6.44229331564151,-0.528718615523781],[-0.494322867937823,4.60411875204403,-0.583430938412946],[1.58737193543268,-8.69218173997143,2.99119517469876],[-9.60518857245563,-0.0726712802088825,-5.34787658165251],[-4.93501809477133,0.204753662947399,3.66399475194365],[-5.77435795395783,10.9523978221715,-4.73061087959721],[4.7651333622982,-2.73729817873818,-7.07848565860106],[-7.07258846356524,2.91156005361472,-4.89509039136255],[-2.07006275192951,1.55105788007252,3.20390523539555],[-3.95367774345377,-4.24491240325462,-1.79040887165191],[-9.11939885947262,-1.37828807848413,-3.72483933204252],[-4.49561775045677,1.03542584747664,2.81659251781806],[1.53810579920635,-9.22572306653278,2.38288827859834],[2.06966602455207,6.25104612045217,-11.9871064932499],[1.66878049840499,11.4705297805626,-2.7143161259357],[-2.77155585964637,-2.71068784380969,-5.94311139529847],[2.96193135828127,6.30220695532747,8.62597622709661],[4.70659421922385,-3.07301475745256,-3.86437245090726],[3.03549182720769,6.34353067092558,8.51794754047659],[-3.80346767940466,3.48010704658182,-6.6638581031065],[8.79768211066864,-3.60912794411166,-3.7114160712354],[1.45870062790449,-5.77068236941363,4.14403451653673],[-6.20326413219834,6.82415020329405,8.8213501592708],[-0.138318719913412,-2.6946718269564,11.3428192576949],[3.43017043771939,-3.05205642007268,11.8625502084781],[-5.09630076677633,7.9327395436616,8.47257391548318],[8.80239306041645,-3.53111163959728,-1.7268370291913],[1.00913539921491,-8.47702916088179,3.09605106083401],[-0.562111617933349,0.682036234765309,3.11563847058145],[1.63208019494629,-7.00873598636367,3.78379796742562],[-6.4918743396908,7.68471810706686,8.10140905318065],[2.86905180193396,-3.10226296706201,9.30621786568098],[1.88951979974333,-6.9977951640619,2.41787134120051],[2.88816435635979,-9.39197238814911,0.451786793781491],[-2.7608679527491,-3.19839996012534,-0.816830507218824],[-4.16527691178341,-5.71596281334178,-1.02886936858309],[0.425867879264705,-4.91086318491618,10.9565720891488],[-5.87332024492486,-6.16856565971983,7.38328059841925],[0.95829171362335,0.655628473138434,3.10495074614483],[-6.53166113793018,-3.80196393402916,-4.09421836228207],[1.86278694702734,6.60454211689793,-11.6504329613733],[-2.05526814205311,6.5525702840255,-0.977069125956686],[9.18756587781923,-3.66263644668425,-5.25053645750081],[-2.7676145885229,4.97831543158599,-6.85612769177465],[3.96567896652338,-3.15727804100411,-4.43943067808992],[-4.3673774062689,0.068341066436951,-1.03133574086371],[-3.83955032910983,0.232200357580894,2.53870513805302],[2.43536808014848,3.71814850484684,7.8837747240487],[12.1156524615181,2.93103164468649,-1.27418554530909],[0.365381229199186,-6.35706017510921,3.33345376250359],[11.1263849515782,3.25742599376621,-2.26567289950733],[2.22537319388171,0.222308164978005,3.22858878523782],[6.98094805933069,-1.8224783406044,-10.0597269481775],[-5.08496715432808,-4.9223519997532,-2.53339721925283],[1.67364956094596,-4.14913439635794,-0.286259547557524],[5.04774222982741,2.79179281412268,2.13512208543522],[0.83199308324684,-3.91630085026116,10.3426595901609],[0.769426101531543,-2.62210748623528,12.0086863733873],[-8.73183931315099,-6.36853351693467,0.692539679433649],[4.19843487235459,5.66860714061734,7.62869649135181],[-5.85228677831751,-1.05051707655227,-1.11006559480163],[1.33606631936213,-3.35330698512694,12.9031968648446],[-2.56433050611413,0.529878415251193,-1.34297852523933],[-4.42219732763941,-0.945654379136943,2.18892892351777],[2.49519048913362,4.18007817905513,7.77665929049897],[-6.12350302550636,-2.92337699312481,-5.46970098921357],[3.78438742188464,4.79267789439283,8.7537537248634],[1.89232992659332,-8.80410638261753,2.51088568179531],[0.562023283316379,-0.346586942606134,-12.9166516399822],[0.0206386424815439,-2.95002481929592,2.23130525661911],[2.36133685367308,-9.36029066670436,0.167577372225851],[-4.86423723419998,-0.191307742356142,4.68834486408168],[-1.99313891503513,8.62244165458974,2.87601396923707],[-3.76086489493401,4.08976220572003,-6.93593195947396],[5.11566961692756,1.4493657412652,5.92865987652631],[-4.98795364982099,-6.76679874804256,-9.96019058713978],[1.47541750540618,-4.06522671515321,12.087240377421],[-3.96219930263773,6.9350543905669,8.93637647791477],[-2.77295005345592,4.47371779165414,-7.52015064773865],[0.750127804252144,-3.4903246654798,9.85253082110551],[2.54816676559498,3.5394372050588,0.709544807471724],[-4.2048209146682,-5.76275579100353,-1.32516672809483],[-5.31547593583983,-5.82717150840393,-1.09247328526088],[1.19185899169561,-2.39099724312809,12.3770292797577],[-3.56270987437804,-5.74896851813619,7.58359983061371],[0.70943140115007,-6.50819754322948,4.15414506126491],[4.97589239019347,2.66460318585785,2.54076519805606],[4.8193566661955,-1.67188014397271,-6.69319196569812],[-2.11879680065055,-0.896784029044051,0.429943384527896],[9.88249868366553,3.81828647149468,-2.74199607277627],[4.36296520381881,5.76986941747333,2.62830901298512],[3.93721514690861,6.14526459701462,-0.0702252497642641],[-4.86807119626509,-7.02325856163558,-9.70998432381267],[4.29804315797526,5.32309954382756,2.93300633193273],[-3.50431394329222,0.569597885968134,4.57022615659372],[1.45160528142207,12.4469067080493,-1.42582157376516],[2.77698740097484,-8.64674949306103,-0.89337495372783],[-5.33529738331007,6.57147646902158,8.48109588236347],[2.56295326444715,6.22290018887751,-10.9631675168712],[-4.47279393708253,-0.529876161924955,4.23690568250359],[3.96397685505002,5.57807647057999,8.27540234221796],[-5.3467934159194,7.3360356051399,8.07799141534755],[-5.24434780166445,6.83762895671544,8.94240642296998],[-6.56231214971499,-4.1367081768967,-3.84794559768551],[-5.39767716306541,-5.64588245243157,7.6837219928627],[-6.07078987716093,7.28743437190869,8.75071167753544],[2.46608687615236,-9.76992090096562,-1.10515697419059],[1.5069077668216,-9.03723332267826,1.05921416082047],[-0.127951835793043,-2.90771440584896,-10.5251295460975],[2.3166331798017,-5.29489599247853,2.33708380802233],[1.29742422509474,-4.45308106315583,2.34643361772775],[0.40511073659265,-2.66199761627894,-4.81915937532583],[-3.74266755638909,12.3937088668937,4.14246695565317],[12.5396660147352,3.10215861287481,-1.0222997233446],[-4.38440171863844,5.83617067126805,0.534589884182872],[9.37995727815727,3.0829125013653,-1.6497410819382],[0.50265120596046,3.20274981164099,-8.54367816651737],[-2.08807017853119,-0.425297231015016,-4.01739230273846],[-2.35383549494669,-3.85359065234626,-0.351767263686981],[-3.45728932532085,1.16807864529084,-1.83497272547804],[3.92930579522592,-6.44430867971471,-1.6455760253262],[-5.41058550947494,-1.09015940356709,-1.46183063271939],[-0.240052209461105,-2.84879683518838,11.8294091719314],[9.91496005183775,3.14097729060196,-0.240262938152047],[-4.58847105245535,-5.89936962735771,7.96503662550857],[-6.76134483393319,8.4719769360815,-4.07528942516152],[4.25224335309505,1.9617573305012,2.6742291240825],[-3.48209356232334,5.5010268490896,-2.39844560508135],[2.26509806079015,3.92477679901716,7.88892293651018],[0.156023666933844,0.627276712863223,-3.20748707900057],[2.24178705917813,-5.99792679049351,4.4723006077947],[1.2364352636477,2.58391621501681,-3.77126373966386],[-7.15439200126317,2.62152469368178,-4.79086895393993],[-3.37670111985355,-4.8977271144915,-0.922551105909208],[2.37546411198575,11.059238120615,-1.89030052019599],[-3.31664080882676,6.45628626468239,-0.90100331302736],[-5.60295119541763,-3.16871289400004,-5.49287988730328],[1.03981753829185,-9.73479327463259,1.27624431943762],[-4.92597082945919,3.61334690897189,-6.54635752970362],[5.1989002034744,-2.83674395042052,-3.87257795406894],[-1.90768705798371,3.45802776602129,-2.55946668021387],[-4.20808939475054,0.805574350100731,2.51250942347569],[9.57028509901151,-4.71715003407696,-6.06609957641489],[-0.796184869965945,0.361253234545044,-7.16298285394026],[-1.82582209466133,6.38078054417524,-0.655992750766531],[1.82399086514804,-4.1578557817772,10.1111550796511],[-3.70219828545819,4.02184067086134,-7.08499903981728],[1.56290387145446,3.90519626360256,-5.8083203884309],[4.12003050761941,2.13361843605365,-10.0321079803871],[0.654911393173693,-5.03541997633271,4.09646133287355],[-1.01666806973414,-7.08972360546175,-0.28411941421064],[3.09232114047968,-2.60611201481463,-6.72240275574407],[-1.97834464757544,-2.32347052034856,-3.93437772916279],[4.38380128339789,-5.13793141564001,-1.90954256471682],[-2.60761494456766,-2.9207035104577,2.01568419369871],[-1.8050585851892,8.80497433913342,2.82458858198907],[-5.27015032107273,-1.21377399859166,-1.1327466583653],[0.827349412788953,-3.08162340699821,13.4371985913435],[-6.18348879878459,-2.80308718855562,-5.07862437582378],[8.410226996186,-4.02143650779685,-1.61897140441041],[1.6244653196925,6.52299895632326,8.50457168805615],[-2.61131037374341,-1.05309978093539,-7.41647002507982],[-2.89494914749529,4.66847252413735,1.08929653695943],[1.63868032067137,-4.19543826692445,1.87253852692537],[0.980956913033246,-3.90742849015983,-0.712146842075265],[-2.09739553247648,5.83483765729913,-0.0202724825523077],[-4.35034159045481,6.22424209395199,-0.277077484380239],[-4.15397534320184,1.25477552540649,3.90257295338046],[2.59931484329284,0.653318634480493,3.54025599941323],[-0.237270737638751,-2.69140818520696,-2.41603887892111],[-3.88997318570856,-0.465989022252931,2.18000582722886],[-2.96271128350626,-0.76735996246118,3.22998475272775],[1.67353865817825,-9.40056990778913,1.53726672917504],[0.287632269775543,-5.02281989507364,-1.41569913517402],[-3.92995073042263,-6.13658741244058,7.58953693467405],[1.31445692179154,-5.41620853333285,11.752613102623],[-3.97705097085229,0.691635411247519,4.42671154032556],[1.53968410249424,-0.0121868229568155,4.25998919547663],[-1.11046156343081,4.23359387865352,0.209804517046917],[-4.40712427065264,-0.815589018013093,2.90921246660624],[11.86039188286,1.28652061686592,-1.65629930763185],[-3.3565350669565,-4.43766432939333,-1.33525617572659],[-2.21338366152434,-2.56439294541391,9.23900511064577],[-2.31897069513783,-4.60309063563673,0.147949214901452],[-3.8935074763114,2.71153100537806,5.60667246941761],[8.17323101376932,4.52858342614657,-0.674090092150975],[1.91665353123658,-7.74941013651077,2.3213889830144],[0.085162028902473,4.73678890751162,-1.95644629522648],[-9.20740083119127,-0.571043581854262,-4.81442773979791],[-5.10741051026293,0.291010088713768,-1.48111490189645],[-5.41285310127108,7.64334407731166,7.51224637581806],[1.71896242120211,0.628773207188001,3.24997357118257],[-6.1284047221188,7.02189514326578,8.5314428645126],[4.11828992897747,5.07980799430585,9.23602376403194],[3.58727306844746,-5.2701243470142,-0.805208549031622],[8.16514117389037,3.92920499227012,-0.823269568517549],[3.86300897064672,5.79963297477976,9.22200926235103],[1.95290272061513,11.4477258397343,-1.97481418508984],[2.21590855225763,5.83065522595523,7.3928610371642],[1.23021628820289,-4.68074740077252,3.78977385059517],[1.85803829539982,-5.14294649852335,2.20789355830301],[3.29770603590136,-3.64408592405711,-10.6456412121907],[-4.76266738703973,-2.72746151913181,-3.32965799720805],[2.1089152409915,-4.8990700161732,11.0624705475475],[-2.90030303677031,6.83609375462189,-1.09939383791605],[1.8832758114568,-5.45238089187562,2.89107328032034],[2.20577376493049,0.599729118787216,-7.02662619859022],[-2.38196642363379,-0.0912462268557375,-4.0325558340976],[-3.64524256089397,4.3288930157303,-7.21642676736242],[-5.35918454681074,9.32339049736979,-7.40065869484304],[-4.37145533702839,1.2316463616785,4.90778728333577],[-2.93193835391225,6.18387908560739,-1.01516764839756],[-4.4003133569428,-0.143382674898563,2.84053870971849],[-0.153224120042409,-2.5576165774313,-9.53884385228055],[-1.50543236524196,-4.86616460200051,1.55746236790147],[2.61032329066134,-8.73051008407434,0.89625144596506],[3.31085356696867,-0.0760690545446399,-11.5931306645364],[-4.04431508560996,-0.619446147165149,3.10179655840232],[-5.86834534065607,-6.11875212771073,-1.29870435466182],[9.05509707943441,-3.93923205381757,-3.83614568232163],[-5.3767928118614,-0.882744219840045,0.495279556139777],[5.08434722334404,-1.42494968374845,-6.67540059969212],[-4.5333967467047,-6.59374857763672,-9.81946800478696],[-3.74667849091963,2.21591062887573,4.58274062727557],[1.60470843914114,3.94492333204383,-4.62958357592069],[-1.62252018407729,2.70610838207573,-2.08572303198551],[2.39267940925525,-7.19723722480166,4.39907318666717],[-2.87925162502122,-0.298496265310047,3.49642917378022],[-4.31926671439907,6.62816406654237,-5.16788595972793],[-2.23982807360483,-2.83661546511503,-0.948555216336113],[2.25322428921204,-7.45335665589078,2.96795306695109],[-8.43033761910405,-5.83330361422014,0.291506093948583],[2.91652587731894,11.9973509810739,-1.47771941547899],[-1.63306168141486,4.74361392727605,-2.99832020015724],[1.41814366737497,11.9198666443026,-1.63520465192436],[2.35939853840771,6.17055265953409,7.85435960008451],[-3.54397902073062,3.67807092701586,5.79346252384504],[-5.91230163017706,-3.40272599610458,-4.88068299783502],[2.30503302488737,6.47126620062042,8.55472154109703],[-2.90590741211326,-1.84687691161316,-1.48375019074957],[-4.10595599547514,0.75524390670821,5.17116807814705],[-5.83826289429973,6.74673677184841,8.85934402878139],[2.05539436055622,-7.74006496896725,-0.905590216149027],[3.01525705709683,6.31238693923188,6.81412107227842],[-4.19367511244163,-5.44569155087176,-9.60481455312488],[0.301514179586664,-1.36666898081338,0.656825966495323],[-2.33226213478316,-3.53616693863788,-0.693552625979212],[-3.6764296896679,-0.0662640871849662,2.10954090849456],[2.04585688707597,-9.77455011092791,0.887731310176571],[0.952702071333076,-3.66599056898884,11.4219489719953],[9.16784171942411,-4.25931882489012,-0.923332369628806],[4.01018986611372,-0.235787586416238,-3.79950583065066],[2.79099158109341,-2.03201063089223,-6.71363303786603],[-3.54878479331703,-2.41165386298855,4.65430703545533],[2.56797167480336,-2.45715009471127,-7.02827943515253],[8.5514308974699,4.52799292868931,-1.79419522708021],[-7.73538004037982,-1.01520030519652,-5.14154062556514],[2.99343939673488,12.337023306699,-1.40969806425953],[0.0741120951040848,-7.10082278831732,-5.97205852592641],[1.82371626396483,6.59970570390205,6.92271492706236],[2.10604518005649,-4.12145158662571,10.3398057445309],[2.09722431356769,6.61762952443992,7.62711494205687],[0.997194741328023,-3.9458290241219,-2.66628079707191],[3.6649399453761,10.5814003635237,-1.10753977276834],[2.96037023458497,-4.29515732228401,10.75076324228],[0.758784548375357,-3.4953789688233,13.1961644857387],[-1.47736485664461,-3.87127492851804,-1.05761759365269],[-2.79080421865186,4.45559071715422,-7.86367682216468],[-1.26918955716703,-3.98016698494755,-1.55443026678245],[3.9443404439543,10.7573449181415,-0.639530357337868],[-9.39776190956158,-0.973127014337512,-5.19782623493077],[-0.012648967208077,-8.11935617646629,0.669176304093937],[1.45285916128301,6.5479628259141,7.32138661106578],[2.8652203224394,6.7739385455168,-11.8236294998712],[0.237455754804057,-7.40723526276346,2.28837263060459],[1.60350816800721,-4.35103926913048,-0.490212289592017],[-2.1294847899888,4.64148243771384,-2.30818822444946],[3.35495566548379,-4.47082628910472,10.3696947129404],[-6.78965574305885,-6.15626483104584,6.74646022963085],[-4.010095971485,-6.64083959861199,-2.24064495241096],[-0.233144867053216,-5.8277052111387,1.82657643080424],[0.905169121463623,-5.5498782763631,4.79802844132858],[1.62656061879534,-6.7139590317696,4.46406083666837],[2.14717229226124,3.66682421845624,-5.71843585719108],[4.86894433551506,1.91248150680629,-8.74623439986603],[-1.04789872519537,-7.44120302546203,0.426535407671179],[1.71546112108944,-5.17971390869691,-6.14787862425216],[0.50853722897984,-8.03835857205291,0.823728633242447],[2.16869118311383,-3.86131388994663,-1.57567590690599],[3.10955821018329,-9.42607275104967,-2.05837446606155],[8.95205604377654,-4.20140321274096,-5.39889274564175],[-5.1726921399761,-5.66174342470995,7.75064030030979],[2.16232563057344,6.74610408528979,7.530774358054],[4.88346166914229,2.07754527154986,4.18533734876494],[0.152496334753111,-1.51521415860498,-13.384086177422],[-2.52079247789398,4.91149112310423,-7.24543040337838],[0.695251497186671,-5.70881138199073,3.67071439296485],[3.78347911899916,-6.09471919010095,-1.24133091687302],[11.6574792705977,1.48740296236027,-1.69447690374714],[-5.66843323035957,6.99586280138014,7.94742673755112],[4.30696578158146,3.05386658656409,2.01627502316158],[10.2244996315868,4.26098359529744,-0.649947337612457],[7.65714360552226,-1.53248632876297,-10.5765894546038],[10.4477217006963,5.39631185065343,-1.71519267868549],[-0.443662813848807,0.945570708648751,3.35989784699342],[3.58933840753215,3.65319448721251,1.14540132518144],[1.63681804732581,2.57082725374739,-2.35009628039922],[-3.9342814107154,1.80648229948799,2.77192073695518],[2.19206389584128,-10.2782399302386,0.0416357091510333],[-2.34470976112217,1.99256395832234,-6.84914699156921],[-1.25371149747413,0.623193111585015,-1.97694764113032],[-3.04019132655388,-0.727311890516923,2.40115686809212],[0.0407334260347937,-0.0778667557753572,3.12053960611836],[0.337720099607059,-3.05571823038529,-12.1662334041704],[-3.79640755037898,0.744383809780147,4.98024302284529],[3.50317379933006,6.1905887519059,6.70135320095531],[10.8667647081676,6.24053225792029,-1.02547839103524],[1.51646477920549,-8.96544191167284,1.3430171345712],[-1.67431927659456,-6.55597562226892,-1.71765321908639],[-2.44689502339225,4.77167042502012,-6.34896135018358],[1.17474387332858,-7.31840176669912,4.1941895429586],[8.275920395379,-4.23189752712567,-1.39461904839452],[-4.44868423948074,-0.0023998280725398,-1.62340550681632],[2.33815091179453,5.85851109318611,9.00538967080226],[3.85246746189447,6.31279566715896,8.41369108652762],[-0.482808092358437,-5.20327641956545,-2.45963555609975],[7.59354386614596,-1.94526215155329,-10.3568324203545],[0.629876221898744,-4.05212280523336,-2.42700977777032],[2.23831279687123,6.31382760026809,7.12192251060668],[1.85056377063374,3.62167812980774,7.8789462914095],[-0.0812456536085676,-7.7983819310277,0.783769097706819],[2.10704345777196,-3.27428388405298,12.7740496311495],[9.6469585895432,4.57714385905337,-1.54671307980077],[0.389238968005161,-2.7700071547021,10.9628612396437],[1.39758140021593,0.641692763855135,3.60494325544011],[-5.07287788161814,-2.97326167714625,-4.81907297125843],[4.35345742728701,3.13186025153516,2.44165107212112],[1.71381595807288,-5.26835095824071,11.1278375675262],[-5.97433109826548,7.63329922695171,8.95496040781507],[-3.45271498683046,-5.17400846649463,-1.72912108890592],[-4.35468684827022,-6.77171837932475,-9.514769116505],[-1.73098112454255,-2.38191546085556,-12.1479062472997],[7.84312635394735,-2.85025143875543,-4.83679725108932],[3.55553707545187,5.48020288128664,8.24189288961636],[0.611388845159558,-5.07946969082897,2.30733202450199],[0.0922240687488604,-2.53542952602521,12.5018758186144],[0.553410423976293,-1.76928061812558,-1.55477004165144],[-0.0193006580852871,-1.91777002007401,1.33746830747061],[-3.02786738993962,6.66199294000702,-0.706062457432872],[1.26477155360814,-0.136747926115195,4.19586997163398],[4.11724531741184,4.7982361111812,2.69933279676739],[4.8446180868822,-0.912591398666935,-2.73414828049645],[-1.93826439960615,-4.91401149703201,1.81747882719121],[-4.33828025806222,-0.371546150279673,-1.26219554268938],[9.7153810467476,3.79932331988283,-3.06081552491936],[4.24704290571467,5.32594758143739,8.43787725787145],[-4.53345071847823,-6.0558721178664,-1.58125993116203],[3.15256756554056,5.68639324097221,8.40332023357825],[-5.24739369477949,-5.2218262106878,-2.5557687888678],[2.87556234043217,6.67158038030609,7.43492292387233],[3.69974680724665,-7.86339982126675,-1.60788590302661],[2.90609345759549,6.45773812311349,6.74592231461513],[4.49543747726817,-1.45891085167264,-11.4213193422252],[4.26896571040337,3.29447297984037,1.63922278456686],[0.0478522086453765,-6.60012648578044,2.8446832221587],[-2.80390503099444,-1.2268601088031,-3.90264801142492],[-2.86042415533433,6.4392859304516,0.453825434284719],[-4.03881211928546,2.676336597038,-5.82069201000637],[3.29481425455362,5.36105324085764,7.32708897053149],[-7.93631815543236,-6.24176414380389,1.99345016146809],[4.35719505649204,5.89693449238401,8.1169833661108],[-3.89808256561785,1.10630737084949,5.28685214750882],[2.45885100977861,-9.85985024219336,-1.85512339038055],[0.605549538740119,3.53026696871088,-8.57655525136382],[5.30912726039972,-2.03360536985203,-6.87418544558617],[-4.07505238340382,11.867495513708,4.13263759098562],[-0.77189624276136,-7.71052961181117,-5.72015835752317],[-6.97106680614074,-6.2559723234381,-0.231895605436603],[8.58601122101793,-3.75101868953144,-1.39232187005202],[-5.35099038836718,7.55261911249406,7.59356444672003],[-1.14052973484262,3.59194276482611,-2.06065596677105],[8.38301087976661,6.25423322577624,2.39515430417114],[8.45602590854502,3.82583068933923,-2.27617396302322],[9.33730511793305,-3.86586661903381,-5.5023062779133],[3.48205129429255,5.97734727739745,8.54256793413375],[-1.83621702251908,-0.57015243843173,0.245584936199193],[-2.68137742155239,4.12418386763579,-6.96105939939027],[2.44168459776739,3.988067867354,8.02367409726799],[9.50706802518161,-4.44512615449525,-6.00475549931517],[-6.353977977486,-4.33679536259054,-2.93574431248049],[0.968146263547448,-4.02044410735177,-1.40602254378954],[0.517803978820547,-2.80632211846532,9.5117050634679],[0.057667921106283,0.942083682290934,-4.95813694316334],[1.20172193838281,12.0771744447425,-1.27008252897908],[4.40574082129237,-7.77797684797663,-2.75624940885238],[8.72954722405263,3.59963819176582,-2.13962273056394],[-3.47810969311281,-3.93443018803591,-8.31753333360777],[4.16978959355992,-2.46281626779249,-6.75775479776226],[7.09697820130139,-1.13909862285692,-10.7350406043163],[-4.44839633086158,-3.89003682537138,-1.18611367638037],[8.72107665880952,-3.93049768578391,-1.08201847544941],[11.742763355725,1.36996693423972,-1.34851098821782],[-2.32449947328517,-3.56916225378926,-0.223456367839881],[-3.65662594434293,11.9024974354421,3.93449846953674],[2.57462581593888,1.47144022280288,1.3839321667558],[0.414113667194106,3.59746412227067,-6.23790840465509],[7.83119019061186,-2.94052845443286,-4.79004405506837],[8.95412378781573,3.91870112328779,-2.09272922782976],[1.58130618525049,-9.2252902031383,1.1254452319456],[2.23030563151573,-9.67027430145699,-1.20822295367509],[7.25838209232678,4.08673031744969,-0.0545068942099735],[3.77674058403359,-5.67339678732463,-1.6400263088489],[2.15058014208681,6.68927755816385,7.90628186357145],[-6.37721440519959,-3.77897171803258,-4.36678057450863],[4.72549626361093,2.40331635789662,4.05580340042522],[-0.180451473618396,-8.39062545202521,1.09505932252154],[8.35342634806193,-3.10392617277857,-4.46067720997067],[10.0030439239136,3.29262710554036,-3.19016510235526],[4.04028595504425,-8.42709663465233,-0.118588601129866],[5.14270009788658,-1.85275818071367,-6.85419661526471],[-9.31196845014582,1.02357684146961,-6.12545068772594],[-4.13148483784975,6.15606562268655,0.112971559483274],[3.26946439828312,4.56762599199704,8.71896548302562],[3.22648266075996,11.9197471002687,-0.772647120969811],[-0.929125653562228,-3.01976590940754,-1.97174716563269],[3.00305059117267,-7.44424905958933,-1.80949180154069],[-3.47450780642925,5.53440517522631,0.0630689576901467],[0.200903037703299,-8.77270753154079,1.16621835491137],[-2.90292983076174,4.97098143879568,0.538651296301128],[3.72692652705319,-5.2692487654755,-5.42515339807248],[-2.28639540201736,0.904568110640021,3.04435917611652],[0.844819819258645,-8.98210411592959,1.43832286609782],[-4.13813043839484,0.417256360818398,5.11295567146825],[2.1996666632725,0.620687243748151,3.03700926650478],[-6.29994898739338,-4.03167516290826,-4.25372617620877],[1.32544971795712,-5.13121168149495,11.1669288696834],[10.1796654802151,-1.05167212334809,0.789535439827162],[4.04045179371811,2.98141065375922,2.38061696095818],[0.536421910141364,-3.45852511327435,2.60024742759969],[-3.81705352856833,-0.472390825124328,0.306250859343403],[1.28254625668765,-7.98743456066104,2.07055541668325],[-3.4003683054216,-4.31600002986244,-9.07475989934184],[3.52659187363082,5.35362990435024,8.61687717964226],[3.4360339698435,6.03267297464628,7.83708168928669],[-2.78818393307796,3.98827447667494,-2.41082318124561],[1.57705148012025,-9.60962386900249,1.66281733429297],[1.06077336028683,-2.70269333652988,-11.3652715331873],[1.1209837791156,-3.09466595815551,12.8935601742159],[3.54421953722872,-5.11587871114781,-5.64449966055707],[1.59222030348426,-0.484432450249647,-9.81315769541838],[-5.38579163956444,8.73948400796396,-4.34526556036118],[0.985560170224243,5.96187797376467,7.047154009989],[1.93605750472594,-4.49574630301247,12.3178183537432],[-2.19175867091825,-3.64489782414046,-9.70051443827729],[-4.47302690171076,1.70961671234856,2.7401891704616],[2.44859420148932,-10.0853157371291,-1.84015658704088],[-5.58997223385908,-3.21556909649396,-5.22894520801072],[-3.827653586502,-6.53175163071353,-1.77186611397578],[-3.56559601524129,9.88333035444395,-6.75772869482079],[1.51319667980077,3.93291699060792,-6.44975010029791],[1.88915799933422,-2.21863992466822,-7.50933694196237],[0.739611406210701,-7.5110695273053,3.30802044026746],[-3.36053575654534,0.94510765098851,2.52526890275827],[1.61233116267135,-5.38254966062619,10.8530999173956],[3.97873966784199,-8.81743662187769,-0.342333605557128],[-5.195614923565,-6.42128589836167,-1.87711537534099],[2.72957992269016,6.02397126519379,-11.261892604252],[2.64392705801691,-2.81641385013654,9.48077338684887],[-1.54041616141041,-2.15008074785174,-3.7698937067644],[3.1372128664468,-8.92524083824805,0.572649882444538],[-0.300159281730458,5.97642090720565,8.65789463753015],[-5.85698621247761,-0.270554529182942,-0.882573532366071],[3.01086976577799,-2.49425234259553,-4.44894810528715],[0.0865374580568343,-7.1662920061893,-5.70840585905441],[2.81772555275301,-2.06955829141484,-4.59777820287512],[-4.27836838053516,6.70640542263507,9.27309261797255],[3.12182182968717,11.7192606523703,-1.12085596230741],[2.88728272272329,-2.51313920762116,-6.76290150660555],[2.90230541931678,-7.83528189376404,-2.16329877621385],[-4.04960584233046,0.0997427051167467,3.59126535670867],[1.18663916102373,-9.07380684390422,-0.406321251324716],[-0.555306166620537,-2.9891153413848,-1.70225399174823],[1.03469605229775,3.924401483232,-4.46952275203],[3.70929574527644,1.30830055967777,-10.0555559441086],[1.71171090817961,-4.39234773191287,-0.431075220399072],[0.615967397372343,-4.05352394505108,-1.57245150470255],[-2.83769913807935,4.14215631667632,-6.55822726466397],[1.23996903816548,0.631961071512114,2.50162539511112],[-4.35289533168221,9.61834544014841,-4.5920405371935],[-9.22733110717693,-1.79090430821548,-3.04175709383252],[0.714700573509086,-3.21353249127017,12.9893761108301],[0.98222955167213,-5.54293815817551,4.87983213824154],[-4.18541520573546,-6.96995219540135,-2.67803321162279],[4.57904291825595,1.88723747029579,-9.81801244615511],[-3.11677424984673,6.65823264086756,0.0126585272695435],[1.0052313207468,-4.68057234590285,10.9197385339959],[2.24679331311565,4.05311833368301,8.00220354199044],[1.97006675061724,-9.84909688400189,0.496417617973325],[-2.78529890162434,-1.30161558314842,3.5727581001063],[-7.12813641875183,2.67646011289176,-5.49223886702985],[-0.579202217551292,1.8655814593875,-4.83249461639697],[1.79120549003797,-8.7025170193386,1.54290642985734],[-2.43622808785492,-3.37244742915314,-0.538617863013394],[-6.24223681268172,-3.46894182885968,-4.17421067444896],[-5.9911874899972,-4.34454792150732,-3.68440007316646],[-2.63950343760966,6.40668739188143,-1.69919437350839],[-1.66583632106711,7.23673713171371,-7.2564650145639],[1.16362332644632,-4.78580770179946,11.2595181973105],[9.35595062364974,2.78610679241205,-1.52608931506986],[2.55180404479387,4.10870078640565,7.60058467709033],[-4.07067004505769,0.700325365719028,5.06608756321028],[8.21779132807951,2.68122506904824,-1.06610133059365],[3.18877350955003,11.4963894921453,-2.91565141339033],[-1.96798351222566,-1.30876014048852,0.707827493494963],[3.47128854429416,6.00005649098454,7.11813336874666],[-2.01271231238874,-2.75411392053464,9.1062344162145],[1.52224592252125,-3.1335587618296,-7.65912615034643],[-4.43292643192357,-6.92263329316855,-2.2506013101654],[3.07418862510955,-3.51622161629186,10.4592628477302],[0.122992260250727,-2.28601334987648,-0.0723713961675844],[-3.51593365877873,12.413823169219,4.39850627571848],[-2.9557726663054,5.81390636624186,-2.4322536169894],[8.61616919831142,3.96720737996322,-1.64272672670579],[-6.08186058237419,-3.36557435088433,4.70795517601526],[3.5591243791082,5.74166546170879,8.19484654330972],[1.11997366451644,-0.868027567930507,-6.52331551849899],[2.04970918468897,-3.27602060651591,-7.59457104205289],[3.40902278252727,-5.92813800135104,-1.05174430522203],[-6.17619043929425,-4.2244819483103,-4.2226089136747],[1.79745913274514,-5.02958948546261,10.8968817419668],[1.79814255371807,-3.83745595936052,12.3078511426481],[3.77732592350148,11.2691448516246,-2.57057937157866],[-2.49545130323151,4.99318546984211,-7.80550853429339],[3.0772012118153,-6.07214047494907,-1.22378606273618],[-3.94893267114453,1.0097668400061,4.79535618337],[1.21752071122128,-4.32614000579437,2.98660064928253],[-1.06104573664916,1.87005954221383,1.70376041328628],[3.27518055321621,5.18159430979537,9.16197174792003],[0.135487411243098,-6.89453797972717,-0.656900511595519],[-3.28505670354087,6.72034725816258,-0.823715678637326],[1.86009816762099,-5.54878824442884,3.7835915688226],[-0.761055742470037,-5.09539434818641,-2.65897676692466],[1.86325769594446,-5.88271535658989,3.47393091936648],[-4.79565612369256,1.24286323355929,5.05778619523196],[2.97196011021283,5.93767780264414,-10.8469620023848],[0.0885853989091714,-4.11917457903148,-1.04397078110596],[-2.67903971429726,-0.469203781328482,3.90321854004664],[3.29051926533008,-4.20009169771184,-1.44493183496459],[-8.50060043225445,-6.12390568080483,0.786284446821139],[10.2375924892407,1.79410164300489,-1.89981486473913],[2.42776544398982,-5.35685051327849,4.58849582460535],[-2.81823729101397,-2.09049943755112,-6.42459129185945],[3.29807635775676,-4.21196595448633,10.0165911344202],[1.79539229973931,-5.2433235249402,-6.1339410544272],[1.03773369926244,-4.57205907381551,-2.17217472215635],[2.47971308034182,-4.23675697393664,10.62079291416],[3.31488717127796,-9.54113052353793,-0.36798394986843],[1.23903591119219,5.57272760445255,7.70649126424765],[-4.2347266713963,-0.709295489334107,3.40029643521577],[1.34047026458827,1.86114676140754,-9.77872831634176],[1.48021017049921,-4.90648080372129,10.8231799842347],[-7.88144142606023,-5.67657121818801,1.79394821226569],[-5.18366512388485,0.78531851901176,3.26843354826576],[10.4073805238995,0.0407231016269032,-0.476379787617247],[-0.16957714427614,-6.77781616515238,1.72299002674984],[3.25470705954698,3.37032969214348,1.17910040127281],[4.52640657633342,-2.97878474879735,-3.84623083489498],[0.717261203687846,-2.4941901064086,12.6131859352361],[-5.41912282496908,-6.2132746876292,-1.72284840762822],[2.99278947161575,-8.66228180150159,-0.232707208445015],[3.49130307390974,3.46677340681176,1.1889042663912],[-4.81549320884478,3.67328866191455,-6.83459150696964],[-4.1996935568027,0.795298341482694,3.13297820159345],[-9.74995557170598,0.213013456482189,-5.33804888247359],[2.36783766796498,5.74507526760806,9.00797971548987],[4.12234372708239,-8.41000942186548,0.0198638839763507],[9.57159191620593,-4.1641966727871,-4.39366261413708],[-0.561891593581879,-0.290197676042952,-8.17415593420986],[0.843996140021269,-7.62822343226975,1.20022549351205],[0.701903194628559,7.33159638402086,-6.2848333126778],[-3.33876363680043,-4.41852262032453,-8.83780188090666],[-6.01931993430995,-2.44536601992972,-4.48462415011831],[2.40655954269943,-2.46170819158724,-7.90897597463654],[3.40266700367346,11.6326969279359,-0.662200990402892],[-4.40135219651553,3.41362787606591,-6.5804109459853],[3.65062005828435,-0.530447642509883,-12.4648691757676],[-3.98648698138518,6.40009105559008,-0.591864832565754],[0.756009894872722,-5.1404694227117,10.915123736336],[0.396177629164324,7.10959237067269,-6.16630530214054],[9.44996741757595,-3.91915218840502,-5.22337340391879],[-3.77668488456073,1.57841344550072,4.72728367653229],[2.2252798322598,-9.26361870434093,1.62891789312507],[3.63673603365952,11.328389086649,-3.13692471902938],[2.16818940728803,-10.0161077348385,0.0355141679248645],[3.50763890457993,-6.48481530595716,-1.64902673427196],[0.334253814017739,9.06150887771981,-7.78011499486616],[2.79681698263741,6.31655312965105,9.30134667702549],[0.642242856301847,0.546429074790049,-3.12429840117761],[1.74548582547484,6.41494095214271,8.82996725309372],[-4.93342875106694,-5.18153506508281,-3.13536725870425],[0.916321370681466,5.79987019376527,7.34706139921303],[-2.76398993648087,3.58852304552697,-6.27380728861982],[-2.28845173256585,-2.40203670744679,9.20410782825436],[9.99283815891636,3.76854733211205,-2.93882991576972],[0.384295024588638,-2.76477470887895,11.5405232481073],[-0.432561205448377,0.507757628704347,-2.7194724263239],[-6.23082019190163,-3.00018953473778,-4.70717317532154],[2.48047476346897,-4.40890944098943,10.5540105509846],[2.5151987066169,-2.67912821038236,-7.0170699455093],[1.03834241326156,-6.0609831164026,2.9498494698811],[4.34272570710599,5.2211976347769,8.41342300262682],[1.93869981391413,-9.18400136591481,1.28842741789723],[-6.35472697052919,7.52675358670693,8.84981781845101],[-0.496138282738452,-0.948679806570433,-13.855321149558],[4.10465613598089,-6.84218136298622,-2.20222019396046],[-0.115203164929234,-7.28052605582079,-6.24456806604034],[-4.20268356709927,1.08019157332927,5.01038809635528],[9.70153760418389,2.60704114979461,-0.700956238993887],[7.59810955961051,-1.51762767032724,-10.5844998628985],[1.10085387073245,3.17900232968519,-6.7523733491927],[2.1981512737159,0.13156800624303,3.29865778028055],[-4.24711289147543,5.73425657755908,-1.36117492096987],[0.795512776005516,-8.85250703300054,2.49591387290021],[2.50461534816596,11.4033332761653,-1.57041305194054],[7.37396084255406,-2.06565721221322,-10.3438349886156],[3.09532652735521,-7.96563666849871,-2.15577994490395],[10.7327499400863,2.64213234354914,-0.639335335701374],[9.80513606297478,-4.88053546452162,-4.72086542217574],[8.90395622850007,4.38033067221867,-1.98365442071022],[-0.426711030021458,-2.83516063892919,-1.44090263656947],[2.82036774797002,-3.7395446723076,-10.972717347066],[0.481740273885682,0.540309937521013,4.23416685178729],[-0.407416214183665,-0.343245736288482,3.3216864099236],[2.40996665856518,4.77392140837158,6.80962548351323],[2.90828638578308,-3.26618360167365,11.3415071065898],[-1.92603624427196,7.00823590659379,-0.747325125933492],[-4.42629235286119,-5.7277872055531,-2.51793920119729],[-5.66059318428018,-6.47628515147766,-1.44212573173259],[2.02642726498797,6.60214106988086,7.6033206852615],[-2.67834549772261,5.14409364034244,-1.1255726802092],[3.02229260140093,-3.83801018255613,11.5081290124917],[1.61325715712018,6.19041807926179,9.53757134948241],[-6.60248874784224,-3.07108580411134,-4.57757810616714],[3.04126289233426,-2.64176894644126,-6.74226934138603],[-4.14050438058398,1.66437036783939,4.85398414072425],[1.98540817047179,-4.99567842385667,11.1621932983607],[-2.16736303521087,-4.01983626270721,-9.40122925134939],[-2.37458018436009,0.295553051469755,-0.448407547003602],[-1.11439333844875,9.45624321257457,2.31915782191211],[-2.0639703927674,-4.68455778416365,-0.429769270327996],[3.48818354268512,-9.40317436729868,-0.826401626086569],[-4.06143103441175,4.23182143924503,-6.73146856851951],[9.59155289788274,1.01226194897415,-1.12601972517296],[2.69525713130622,-2.19758890209264,-4.33432779456986],[-4.99118779553943,-6.43094615660522,7.60777392441381],[-3.83738998901195,11.7647651291925,3.9291062959733],[3.2133727445741,0.321646571761953,-11.1836616408402],[9.4223497958737,2.22302430579917,-2.57302083951862],[-0.849914437787739,1.28069184450432,-2.74019770706081],[-5.47713423352545,-1.77736980097327,-0.262621831133801],[1.14652852388395,12.1938493840363,-1.40463234293197],[2.35816138579864,5.70182995202496,6.79997761828741],[1.83701524113145,6.40536380951832,-11.4584274649881],[-2.16490077633219,5.76950728666153,-0.104769252816152],[8.08626476586458,4.13439759888244,-2.34904512040765],[0.907438328840101,6.31299487577742,7.33041332252161],[0.574356483712659,0.216237840133282,3.68797666889457],[-3.29074484105855,-0.599406487794843,0.818054646373877],[4.42440966324866,-6.61472881664411,-1.3487504180392],[-5.0618272800167,7.05567119753924,9.01471854409318],[3.30506988714623,6.60704367948835,8.88911213852542],[1.26822922176073,1.84396409590146,-2.8175596884475],[0.119274707623218,-1.77976930532967,1.29671719149703],[-7.63225703185967,-6.88864948582398,1.58558207493127],[11.0069635046323,3.26115366243019,-1.58257506273148],[-0.34962303967097,1.00750928457829,-7.69504048785176],[0.82579718110171,-8.70975631362612,1.16240798167299],[1.92349207225924,-5.39735819179703,2.28694826125203],[3.07296093756496,10.4258348078473,-2.42383095759335],[-7.74038775176154,-6.84974665005078,1.06351895320761],[-2.0099807096206,-4.73605701798869,1.84964984543743],[-4.55872685465487,-0.103271008071369,4.66881704138549],[2.41503326900472,6.27798909245821,-11.6966193361867],[3.88170910573277,-8.65678054297121,-1.118699950385],[2.15853403722941,-9.28746319312338,-0.461326449038998],[-0.413483448045347,3.54042357338075,-8.6022059881483],[4.47874562619613,1.80585511709917,-9.97570419536298],[-6.27783819228686,8.70903376697305,8.00602407010459],[-7.65231190158323,-5.81648929149505,6.76006074393461],[2.34981286103877,6.62920021372263,6.96156177007578],[9.44568113488301,4.35468183291647,-2.15234454287168],[4.39489259896978,2.22487595295535,-10.0767159975951],[0.205973179275861,-1.87374144857246,-13.0957799804941],[3.24655454267853,-2.59369109682505,-3.59611899276705],[-1.92514678797554,7.03794918322128,-1.10192555470969],[1.56041988344895,-5.34017286927163,10.8668161476312],[2.45863257754255,-4.65386315362505,10.6181495247076],[2.95405765098995,-5.22144299950687,-0.986763893211547],[1.55016878514926,-2.53246371383079,12.4188976982726],[-6.61562313903973,-5.81327095057857,7.44212723419995],[-6.20897657914949,-4.09308451233451,-4.27018165033904],[3.3580074270242,4.35157990834178,7.76850154376971],[5.31204867987648,1.39353738281895,5.49997194096218],[9.58740816366695,2.69421850377078,-2.83715420051087],[0.678432574466787,-3.5617461950768,-5.65200153338408],[0.40639993483888,-5.4772039244051,4.24553749120123],[-6.04851503254353,-4.34026603997806,-4.26253840799764],[3.77994854307368,5.67862170250621,7.99117106282627],[9.59092448757549,-4.55196389327092,-5.04146704716521],[3.5975341354745,6.43593482099875,7.51722740595556],[-6.03691793206898,-0.904416374891463,-1.13989338270461],[-1.64428759636684,7.3097536493311,-7.22979956514848],[0.783442448496977,-9.21446325778872,2.33901618450253],[-3.8484811406325,-3.57721029738881,-10.7858705766941],[-0.507097789007943,0.595922597956174,-2.68779807696234],[-4.70230007464175,-0.0572839976322508,-1.709229497425],[3.74328731182138,-4.55235064810309,-1.50257512448806],[3.26659697387372,5.06544555157207,9.11235231931003],[9.26249794041671,1.19645881430601,-0.551684216038076],[-2.79059832805068,-2.64744250473602,-0.366875435330249],[1.63866913406245,-5.31609561151381,10.8940825301974],[-9.3265885551143,0.811823875915082,-6.13440521212851],[2.68141073468819,-10.1088145285375,-0.478643954892346],[-1.61674303439901,7.32761265499522,-7.21197564096967],[-5.95205906143088,-3.02234414142214,-5.59015858790013],[-5.1884554309959,-1.3857994697193,2.44844794545485],[1.58409719143996,-3.77513049546695,12.2665361747832],[-5.57260738674213,-1.7389563823041,-6.26699190714358],[-5.02038241818357,-5.15933381421337,-2.60543447066217],[2.08008593543729,4.5369212075893,8.69101246251374],[2.81119939911334,-2.654881967977,-7.00430551023792],[1.35637374611308,3.70783207226468,-3.9663039646286],[1.80503585345459,-4.61778290834759,4.21814081040926],[0.875017558547572,-9.00210373091815,2.42134145556328],[-2.95911332867848,-3.39500819739008,-7.36533590357166],[3.42738995254345,-9.6477851217634,-1.31991983446546],[-5.42871078685328,-2.43843805361435,4.37965188267708],[-4.53625367804912,8.05003518393521,-5.31699873848027],[11.7797816188767,0.65013420100207,-1.20334786061805],[4.4885742668567,-7.22687294305158,-2.83275527201096],[-8.8184964060814,-0.689399542449205,-4.71851842718055],[3.8906307502103,6.45915971726299,7.87284668550195],[-3.24641733289864,-5.57809679099309,7.05135211921598],[-5.17397610834737,-6.72624620363035,-9.87673788949162],[3.1666534066219,11.1447920152624,-0.89003186031894],[0.146641701553096,-1.1975619546285,-13.6063594841184],[5.84150122777775,2.71095937807507,2.13683336380608],[0.18291847197045,9.45502219530106,-7.71524269081011],[2.60527251905027,-9.32200684752222,-0.827239159679774],[3.81663989265973,5.16793547441271,7.34411873935863],[8.42960707787256,2.6943052134932,-1.41076412490007],[-3.36930799037791,0.0941173209724958,2.6758810562312],[-2.46119938811274,7.00750887724953,-0.119513520926921],[0.0112489379503606,-1.34350029398273,-13.5875994461676],[10.9941444859173,-2.10230044044851,-0.901146593572836],[-2.38811899620318,0.0202667025818473,-0.131725553371462],[-6.47646869322648,-7.08676014402347,1.38633468297111],[0.708383045882725,5.7529454358309,8.1221556438952],[8.7897977680028,-4.64140593438094,-1.19723726297026],[-4.55413930987165,-5.38924823414651,-2.17154575034196],[-8.44254446179031,-6.81000869118298,1.60069328080653],[1.44504395426489,6.56525432899109,7.84826795964608],[0.229339194500954,-2.73227753480611,12.2092073117799],[9.7458853238121,3.36175193306511,-1.58865877379374],[1.90033972625829,-5.5616357766704,2.62943415926066],[2.0922105660556,-5.62644233280275,2.20244462437522],[-5.79537721687577,-3.61145511302894,-1.9383979179539],[3.20051917479349,-9.29941791297824,0.261312505151218],[7.23633812840955,-1.44007775574018,-10.7433568896957],[-0.514644933722988,-5.50271017214684,1.85947993033886],[1.7262507024482,-6.21762023547035,2.88906586395449],[-4.43540161002862,-6.05968401310592,7.81908695471084],[-1.78152551387068,5.06024413253465,-3.16821466966854],[-4.07901462616625,2.95495872519228,4.77853096262409],[1.66780963317536,-7.72990432134217,3.96568676012352],[5.37810211953339,1.28122087207745,5.80905420107405],[-1.50755596956262,-8.17338864058556,-5.80738046671941],[-1.18665850492723,10.0456130927515,3.16777264653654],[-4.76636539628337,-6.73287035611484,-9.30694856337747],[-2.73902304632923,5.17535797935807,-3.1037406649547],[-3.85999663775172,1.56023645899576,3.35221054106934],[3.57825737611635,10.6912698467013,-2.01367016358596],[0.0178517968466992,-2.91323237971442,-1.07842815397944],[-3.76724691859616,-2.39511627965678,-1.64233451340257],[8.35615109747885,3.36626322006482,-2.0131647176893],[-1.34175704799711,1.54238277188613,-2.46298566322729],[-4.13216996612952,-0.153488580274847,-0.507186459414144],[-2.84773856803151,-3.21899282838438,-8.10403547888826],[-9.60738468111938,0.656007706710976,-5.68940393472337],[-6.91699030969322,2.10053758279583,-5.59925895012093],[2.91976361074178,-9.90590268337233,-1.48830530086826],[-6.59575785079983,2.4327735533252,-6.19078489499113],[5.72303083944665,-0.290062168162451,-10.0250234747837],[0.780998542450454,-8.20684857600328,0.682443116251645],[-0.712619403458067,1.86992624068076,-2.03160042158213],[0.388287110732195,9.02811643576939,-7.78223863721755],[1.77837087136843,-3.2354160081673,11.1199091399357],[-2.33923696645311,6.0405388910451,-0.907814035579089],[-2.70891357701545,-4.3257023011362,-0.0806356166052273],[2.55567477634119,6.70134554465401,-11.5460304615394],[-8.75510194693548,-5.82693998597454,1.10108222348275],[-3.81397983035627,-5.8302776619369,-2.39081238916204],[-5.39942043456384,3.12332078194589,-6.72219973719995],[3.62154420684334,11.4336226472181,-1.49877744218578],[0.255718360239157,0.457314139809779,3.61978086958522],[1.86918959191744,-8.5932339850159,1.91787277505618],[-6.16362080109144,3.25461796135091,-6.22139831408379],[2.1234689769098,-0.285799745578546,-9.9345885730602],[-5.19119014333797,0.976806247715159,4.15310569093504],[-9.48819517751797,-0.462670008741258,-4.75634887074255],[0.297574454923939,-5.7059856340097,2.12341338268324],[2.09961189089884,0.165245231703913,3.94893447273569],[1.04566471759784,-6.682004822702,4.55070443044551],[9.76439405381798,2.28199243048729,-1.09197525394876],[8.63479153957761,-4.57831655846367,-1.85726489435029],[-2.90217999580173,7.17290143891728,-0.76747579074095],[2.2514598113281,-5.1935666650887,4.64376801040636],[-5.02595674738729,-6.17610250897743,-9.9294366302568],[0.64774429034758,-3.44750569142189,-11.8145650241103],[-9.6213881912713,-1.83440851811291,-3.88502274461429],[2.08454703381541,-5.82491674773759,1.79352007963387],[-3.99040763455778,-1.54053320041871,4.25974551342763],[-5.61635808788294,9.91532882239037,-7.44025503676501],[2.38776250386396,-2.88157436478586,10.958965794753],[2.70307809648519,-6.69538121615543,-1.45769783011425],[3.28534402706419,11.5102336465369,-1.20872647568468],[-3.16826014662888,1.08903062079952,4.26938360480867],[-1.62831513381882,3.06100404451842,-2.44526138803598],[-5.15507310372956,-0.942096310402681,2.19559735317611],[7.15458271349676,5.04547945776212,0.0351635220826916],[3.6328463897686,-3.80164879223236,11.3084151584794],[-6.07876050444414,7.18411481263134,8.13821712364274],[12.2302814883728,2.52228792884746,-1.28698932700644],[-1.42027433296855,-2.61673318026235,-11.996472898883],[0.505753258924362,-2.82048326420733,-0.692387646666093],[10.3278282566624,4.85347570134582,-1.77756672983855],[-5.31764057167967,9.84899425624376,-7.23426101892078],[-2.85228052831589,-5.01637313708394,-7.09394549596385],[1.33758247255462,-0.207877603727527,-8.38806732774823],[1.29610412068782,12.5970913187933,-2.30881107259113],[3.93966937876479,5.05884514993497,7.92675096417527],[-3.5661444486697,0.625389603047536,4.80670698669817],[-3.33962638142541,6.88808923506682,-1.41019886249191],[-6.30851779653947,10.9975155655241,-4.27578317021918],[-2.22677635103805,4.59406728575397,-7.86027788312937],[8.82817935449864,4.2268375297492,-2.02017793627448],[-7.10815805667773,-5.63825625966474,7.19362380327351],[-1.21335840111561,6.54739604881865,8.85677024184932],[-3.84206162086135,0.920228640734985,3.51424726397231],[7.78346892739714,5.33501209057146,2.758431871874],[2.62411614923227,3.87487431068531,7.75983336473351],[-3.48822598395626,-2.5610716823951,4.6840350442017],[-5.35522587993812,6.76747809870137,8.8537455731155],[-1.10421568761646,-7.28013235024184,-0.942507038255271],[1.75985253316871,-3.24897834575384,10.4866379377465],[-3.10354668443133,4.79273050781311,-1.14701248696913],[2.73966091890274,2.73301738313753,2.74095624144171],[10.5105372297997,2.8893089542202,-1.42037264630111],[-0.70531027464115,-1.72271778006636,0.214884083875738],[2.56863590268689,6.81794766706567,7.98626990976206],[-4.10833426328705,-5.84150843630862,-1.88948903890752],[0.705789861506923,-8.24920211913706,0.242594397208068],[7.52743217244462,-1.68105802315531,-10.7909386996212],[2.53834334673804,-9.10062648674822,-2.23209517604182],[-3.95056960091377,-0.145131046256273,2.63354725038883],[1.36671710006152,-4.39703409838441,10.9297172030821],[-6.20765116507561,3.70164310524953,-5.05205451191761],[4.23975693664564,5.03987313420178,2.86980008001544],[-1.62606063473879,7.29414089378908,-7.17468693067632],[-0.604602023950931,-3.27864997522683,-1.4713121701375],[-4.33500515527882,0.786798362439877,4.10524905862932],[2.50454148551606,-2.1494920303729,-6.59460558055155],[1.53792269426374,-1.35999742135279,-6.69381107421814],[10.2634197520992,1.9577722072035,-2.5134579960527],[2.56089135235349,6.35555752750355,7.88067490893587],[9.26285668114948,-3.65794544576119,-4.98578958816556],[0.00728558343359165,0.964317509914787,3.77264444639143],[2.37498331267167,0.206210878594998,-11.7522120433085],[3.29206325065763,-4.8789541543998,-1.76665382526966],[-0.475419235313966,1.61490498013563,-1.31508458386083],[-4.4586317267271,-0.60887976178466,2.13283163844369],[2.53182363485602,4.97679884407077,8.03620899539045],[3.70337852461146,-8.33612599885965,-1.23713618924078],[-8.4586053389067,0.0991140279470648,-4.56910985905214],[-5.09303949105536,6.02447160433524,8.92035558468386],[-2.05559975701278,5.18041153400954,-7.02122180309309],[-6.70357113028378,-6.25614003013561,-0.457315129667203],[3.61465878168608,5.73094762665269,8.43978069499433],[2.57931619124553,6.45135683544072,7.3475641322461],[2.91249585723908,6.63786622777631,8.28610608323557],[3.58444681788106,12.0059330215453,-1.38352916629007],[-2.51465285819137,6.80546486544134,-0.500002184252103],[-3.36404867408373,-3.74433852878802,-1.05704430663424],[0.999570863174275,3.2510693595571,-7.37387567988867],[0.202956556636229,9.04531300688196,-7.742978164104],[-0.382298720620056,-2.04424529034107,-4.75826088566199],[-2.71019886001601,-2.16459177585295,-3.56915033974939],[-5.4250342065931,-5.82729925936798,7.91287185606169],[2.10906829161496,-4.76274866303694,4.36415721901179],[-4.64203595393141,-6.46584943510601,-9.65054684810424],[3.1423110406521,6.45606349988083,7.96943203147001],[3.45793342592935,-3.19022751564531,11.7043749126291],[3.61329152903126,10.748502191535,-1.51944165100414],[2.98851733881811,-4.15968929972496,11.7535805681038],[-2.34477651034741,-3.41062546616189,-0.164574599104327],[-3.7069365362534,5.46607204299074,-2.70142906740581],[2.49231696343839,6.52701074798662,8.14795153928369],[-0.0870988818534612,-6.75263575458856,-6.07007545063215],[4.35255379779659,-2.98509372090654,-3.86223797846502],[2.68105667231685,-7.81783869859173,1.94921375704125],[8.79514864056265,-3.83655110947182,-1.5994559671286],[-4.23562401220322,1.77320305501104,3.38934056428029],[0.121230973272934,-8.072594789651,1.08985294014574],[-7.66319098011508,-5.9119332255229,1.50275930771067],[-0.102657778013051,-2.99264272052844,10.9691344846841],[2.66595538007727,5.8236444406204,6.26446731124752],[-0.772880012930606,-6.55426076304359,1.3060259263728],[-1.94656113780028,-2.56113884413157,9.49189349691508],[-4.56191510837178,-1.46463050353002,3.65418454925143],[2.85668011783959,6.00380697287172,8.12187513471171],[-3.86601221826265,-4.81290309558984,-11.4784491431924],[-0.526217653342586,2.96257219276791,-7.21362222206097],[2.10560172755601,-7.90658327307179,2.42815393896054],[4.62754810841333,-1.63777118624697,-6.80670112474708],[2.43686166061223,5.11925020940396,7.25865673130502],[-0.31362540914883,-0.389518250097046,3.08502015621756],[-0.0465009284492407,-2.81886066490056,10.8003118964328],[0.587191747387114,1.74403825775296,-2.71366528609952],[-5.97713365790579,2.75986990353472,-5.69954124386803],[-5.67568485080857,6.40088647646528,8.7241710809636],[2.89191452107964,6.64788404547794,-11.8218460748994],[0.0958902220785682,0.0370770150295655,-2.24444897074454],[-0.637227680178282,2.79043977756925,-8.27497764949758],[2.77066953594686,6.68916253611619,7.91148888389655],[-2.82402790759542,-1.58748471472187,-4.1711807869587],[1.62179074781974,-3.5486740088011,12.826097124614],[2.55803867289351,6.42144051637723,7.35970086775992],[-0.652363121738165,0.487907779942018,-2.91210331476614],[8.97113994719217,-4.30869630692477,-2.57913838744223],[-4.61982526223917,-5.46656445549532,-1.89334595847965],[-4.80081275554249,6.08933274562875,8.74527898735672],[8.3004659299247,2.9710759935991,-2.22244465663783],[1.22042933415847,-4.58813025671878,4.57363328292265],[1.7997039776515,4.93316501887307,7.64887175187881],[4.47734364781572,1.95536351082335,-9.12407160704123],[7.21898326910337,3.70779376900993,-0.899293340751539],[-1.77444298138228,-0.721240454799435,-1.68261011154754],[-3.37990845585344,0.522566376510334,3.16952438038726],[-4.3104135278743,4.88891125591597,0.292674730663235],[11.1327046116342,0.466850777913388,-1.23913705020236],[-5.5775237083358,3.81845316081704,-5.83178474900415],[0.686971579577582,1.68429842360566,-2.4524007421229],[-2.98245055327653,6.23974276456122,-0.173008855700233],[-6.22771236279034,2.60485808225035,-6.46465185281342],[-3.44806808826363,11.4784017358638,3.48061602406449],[-0.233214272508412,-3.55191189886352,11.1285857233092],[2.94016967396738,10.727131978422,-1.97807699265715],[-3.36203590698175,-1.68340257415426,-8.3833005489253],[1.50157240386079,1.34455540872443,-9.46099227815344],[2.06725924126423,-2.50869437672371,10.2379530634755],[-1.56071803231066,1.09210881522893,-1.69218480497569],[-3.65550468171141,-0.154903028516948,2.87137577433915],[2.94234392168566,11.5283124035669,-1.52349495112283],[-5.40302608018009,-6.43610652779893,-1.743180420367],[-3.52048597729243,0.570627764753938,1.89135122483247],[-5.38770554081669,0.858100607445896,4.67751100697257],[2.27541653275538,-7.71835636731604,-10.966345153671],[3.73972618227238,4.57662712040601,8.54107194798384],[-4.57544666427721,1.5484071554116,4.38944687478926],[-4.27557560537478,-5.85350297076153,-9.63552203042738],[1.97387981605437,-6.55940700743854,3.9860510708789],[2.73965389389413,10.8827055505232,-2.50232980011959],[-0.312323768969322,-0.838283842071553,-11.041600654884],[-9.04615369710051,-1.38729683503779,-5.180313962157],[-9.03659018393457,0.393439892683101,-6.25270746460548],[2.93835284971623,11.3762503842127,-3.18389235864024],[3.05632384660893,6.64058504076328,-11.0868942708644],[-2.1733108168637,-3.44314723305635,-0.460400963664936],[9.4896345557114,-4.87678504012637,-5.98193346524543],[2.4711023176178,5.7689310500006,7.33797827893103],[-6.00706355098685,6.63878313692081,8.69440491770273],[3.97699433521054,0.775405114580992,-9.28744630866438],[2.53926312088372,-10.0764234444781,-0.0975594500273604],[1.80763923672738,-3.47900760122568,11.9491401021666],[-4.13785250771835,3.33295895210439,-6.66368868497167],[-3.59735204288161,-2.17453719224985,4.16128638706948],[-2.6106063804018,4.86309210811718,-2.32792150149552],[-4.08462495450456,-1.19685940975648,3.02128106073731],[10.8449066959267,2.27613601134731,-1.16335593618161],[-2.58119361167352,-3.13705530422313,0.42272237837221],[-4.67174371729225,0.300166682444435,3.53557637263961],[1.22280005217836,-2.9442245008891,12.923698020926],[-4.01682984230089,5.42179858281547,-1.04697480316993],[1.7144417269884,-5.54858397732812,10.6828745006029],[0.505500161674727,-3.76208695273328,12.7465543601746],[8.72127582898593,-2.43647368163851,-2.75134862754626],[-8.36462882462471,-6.32614059139507,0.430370406051294],[1.32081903704105,-9.63807587960694,1.60553565008223],[-3.44489659441799,6.99414697303343,-1.09059297064594],[-6.4617434130288,9.0134098326868,-4.36703776876498],[9.21237470430644,7.28454344037523,0.240954114884386],[2.08589913554765,-5.31080822110766,2.7192815797125],[-2.90733654036575,5.43738506677333,-0.272116181057506],[-2.43462564891183,5.39661990459439,-2.82775565794851],[-5.26482863142323,-2.93717162197175,-9.23057617900707],[-2.94238446864892,2.40056047919607,-5.44778328300142],[-3.48040873215709,1.32687386655399,2.79570565243961],[-0.161556293907273,-6.4692988428145,-5.69186099809471],[2.88869620322065,12.0017557159113,-2.63329139024598],[-0.747180057262025,-4.0671267981511,-1.38152839440905],[-1.36037424360709,-6.80676882755963,-1.51398153059246],[1.79633793305259,-8.55443783186559,-0.270814487537179],[0.202227921853496,-3.28419204971203,-11.9097573891316],[-2.89143451880941,-4.61335461527994,-7.62748348088396],[4.17307106730494,4.3871732411977,8.59122930081907],[-4.21101216565652,7.50053428622669,-5.72418105795208],[-3.89169718399712,7.00754956731685,9.22538289581898],[9.09815875833953,-4.36135597075554,-2.02754861788591],[-5.22630554980605,6.57366186072639,8.51434595171792],[-2.63849624240612,11.6930212897761,3.56313594294062],[-5.6807010972105,-6.20428264161476,-1.7840029357326],[7.25152790569776,-1.73508733391368,-10.440412557694],[-2.78928101848273,-0.0662469521440678,-0.308372988731428],[-3.17670639691208,-4.39238410423456,-1.56483812747991],[-4.06511028994365,-0.0596862045920581,3.48260137818938],[2.4882496919499,6.94596766664461,-11.3362277162615],[1.50192363466846,6.36187079691874,9.3866396481104],[-6.32709692998843,-3.28798222769927,-1.67114135440405],[2.82573639252408,-9.38524179535067,-2.3780673724235],[5.9302365007457,2.62662928389971,2.30589936755336],[1.54933603536785,-1.73824254216421,-7.20112803548737],[2.19579597447225,11.9475769266292,-2.54979028373574],[1.64876707022719,3.07032118006073,-3.878659935332],[2.28480759451076,6.08535533756017,7.61574945514545],[9.4726397642194,2.17901719100433,-1.92627246678],[-4.62257284263876,8.29170544175591,7.78201108550679],[-3.86850583141058,0.272736483795366,1.68348853304908],[1.87810775227041,-5.38323768351799,2.22713185491946],[-3.24466343262901,-3.00866912854229,-1.41507091021065],[-4.3424143402917,0.682324480326592,2.82537336197684],[3.14143735963245,11.6072406374127,-0.917750299809489],[2.31536626596988,-3.05256269249752,10.9396453228178],[-1.04861698674388,9.91184366998527,3.17784422767714],[-1.62159607499835,2.97468569415481,-2.02903139696594],[-0.418660505812265,3.25799283604662,-8.68271074390001],[-9.53328985510151,-1.56868182068584,-3.8236697037996],[-3.84029108802681,-3.77198113469146,-10.6192126762112],[-5.37596597651595,0.755347942777434,4.64955063875008],[9.3197631821895,3.57871935779887,-0.623693103441899],[2.83046729577147,-6.61336600904692,-1.89182518726625],[1.11688427801949,-6.74837555124604,4.59008834301906],[-3.07169962171755,4.42334398018285,0.153291748617571],[10.8756100593126,0.53467734647856,-0.722678545574839],[2.27187472273438,11.5963114063767,-2.1000869026562],[-3.48170977887415,-0.982115676101673,1.73062569349339],[-4.82439180713239,-6.42590000833864,-2.58461274234929],[-3.64665300790838,4.18469458605443,0.247844326019357],[1.62258243297217,10.7846415498745,-2.57080495506815],[1.05361066639704,2.93473617319248,-3.9678238336126],[-3.65961362829658,-5.57384428686588,7.70562274826503],[-3.42665568647801,-3.52750769309733,-8.22965591119058],[0.391915932885142,-8.50351998732083,0.810783690087497],[-2.52065752836475,-3.84807833147819,0.225541737918654],[2.15601424167984,0.249829649045911,4.41282460186819],[0.378024118682075,-3.31542441868357,10.1902528822548],[2.73806734114086,-8.05060664875101,3.3924411043187],[-3.77294175049584,-0.371186972222354,0.290357400165622],[-5.07455004312498,1.20673419034103,2.85436277143408],[2.9994991623756,6.18023186236089,6.31217537742943],[-8.13879741009616,-6.50724711120596,0.875522851692619],[3.33263147827484,-9.11198248812289,-0.632079037195844],[-6.69433942159128,-5.54653136769652,7.33511119886826],[2.45353458499949,6.69629500258609,7.13808865404434],[-1.28182604693942,0.435375717043663,3.23279081696598],[2.45429872487682,-1.77970966252656,-7.72308942832175],[1.48971746546734,-5.5966083404161,4.21154050647033],[-4.91612917762176,-6.72107021043712,-2.81742270994973],[-6.02983357284779,7.49483597443531,8.01770610756278],[-5.47540575902457,1.42071711664419,4.31351538988325],[-1.71226455739354,4.49987626886606,-2.94420016841675],[2.34154082514714,4.52814493809506,8.63451597961433],[-4.09017064884846,3.0333936575611,5.46645760343156],[-4.54750355107095,-1.27208973489942,1.93375976620044],[-0.432096706307359,-0.950405814686974,-13.8383810921901],[3.42974369012416,-6.44544255208539,-0.959853437444879],[3.35675843383272,-9.52041459683747,-0.646140330344467],[0.36513245393678,0.15411241482404,3.36905666795667],[-1.81406647180141,-4.74097405278309,1.77539835456576],[-4.45846610638241,-6.83332181631278,-9.97094814506585],[2.58092817057494,11.082657393918,-1.36820021149384],[-3.9049714870809,-5.89918167532172,7.87247726986901],[4.32046975616493,-1.45384532457291,-11.6271729335275],[0.18014186205643,8.9848539166555,-7.81229716927268],[1.52302890048729,-7.76844736386131,4.08339341697117],[3.56168295371684,-0.432654667709305,-2.98310890756811],[-3.77512615610386,0.174972937974022,2.29294621798745],[3.58193360057986,12.0663976743891,-1.73320744278028],[2.40916518575888,-10.0398289867622,0.958404246812343],[5.77589539321804,-0.307866031530504,-9.9456049091972],[-3.23136902047928,-4.8261311460833,-1.67740225853549],[-4.21153069073746,1.30812723099582,4.34345989683775],[-2.73281224485394,-1.9051607915736,-3.52459454784527],[1.7355615904358,1.29985278689369,-5.52727913821539],[3.75208900136891,-6.05670745300854,-1.14500115054532],[1.9682653577311,-4.72255896936802,0.534318301086639],[-4.24754785054723,-0.11810785544639,4.16771902903123],[2.44308346347092,3.6961860340391,8.16547153528425],[1.58341416219737,-3.51072758323205,11.9587396604169],[-4.17743897173008,-1.17673377559454,2.18127920738045],[1.86175445955064,-5.62700425886738,1.5091069263068],[2.25378174424026,-10.2391181614056,0.340093503995089],[-6.6301904351142,8.47389441991257,-4.2801182121464],[-7.73063624021164,-6.99336444957631,1.57722999476672],[0.0461254101198389,3.25235736425233,-2.354556940116],[0.995621169918063,-6.31023760951298,-0.16968046809033],[0.191685458060212,-1.94188594642366,-12.9748148998629],[1.98138161770213,1.63075626904674,-9.95372932571438],[2.40536101058912,-2.81483537260475,-7.13944608656458],[-2.608425261841,-2.38275960820036,9.12184017941399],[-4.04395836381809,-4.999091752843,-11.2333519861178],[1.05402020867165,3.90230889489909,-5.91070238250345],[2.90092189928894,11.8665745525405,-2.97663871723015],[-3.5338109427253,-3.84100447242902,-9.88809968662405],[1.34386569199905,2.98079681708434,-3.78671260052294],[-4.87962669532638,-3.76147338899644,-1.82875686170422],[-2.0519028462333,8.62022668410862,2.82842091794397],[8.27210520691449,4.12618236142758,-1.83316098979166],[1.13157849298495,-6.4164293429257,0.998020976031626],[0.974315461199152,-4.9874356190141,-1.80171916940518],[7.25411116763508,5.04962855963291,-0.505733293089375],[1.15451679192581,-4.62453744728244,3.07973294521144],[1.26167394473759,-4.23299740787204,-2.408034601811],[0.815134592928048,3.89248778410726,-5.79845106356699],[-4.13183003063915,-6.4690020131648,-1.37716110713282],[2.77512426417438,6.48509726361202,7.06906713324188],[1.41884778510878,-3.27479695338333,10.6792141704022],[-2.65500929976769,-3.03481532206241,-2.73794942965609],[2.83864944982177,-9.03156049208071,-0.763059281530977],[8.50631869806557,3.78164444709189,-1.8931440244048],[2.26055751507455,11.6044388770697,-2.17818168069064],[-8.5778687895703,-1.17845878982495,-3.86854694742065],[0.809175378417372,-7.48864770693998,2.31168354074912],[-2.8192921876476,1.12764662433701,2.79762648830116],[2.41127607727738,-5.13777547818798,3.90200196904343],[-2.44114285012909,7.27730503377341,-1.12155675131381],[5.0522767315484,1.61399476295549,4.97674511205368],[11.4477245430057,3.13337404132176,-2.14117308540861],[-4.7172253831902,-3.74165373778279,-1.58604891739158],[-7.68974811515093,-6.58112502763745,0.591548358907585],[0.0381027271304226,-6.69614274278611,-6.00180003442776],[-3.98158475676997,-3.06593182984513,-8.05889139364898],[8.37780477873954,4.29193399324805,-1.42495285833488],[4.68845807540235,-0.165894269218748,-3.36240664702498],[-1.64806837483321,10.183711430778,3.48352661850554],[-3.76196093576259,-3.54886928657697,-7.97414281427131],[-2.31303068715038,-0.573349889622656,0.774692490837533],[-3.88320742859489,1.2699097336385,4.2388075954094],[4.16617490347887,11.6965308384146,-1.2224770350443],[1.36950407671505,11.773825560385,-1.30248483458176],[-0.0569314833430601,-6.90478102818393,-5.77764127127479],[2.20185978448479,-9.14900043871592,0.897212011475696],[3.47905067144183,-5.91435166638127,-5.05387300907013],[1.92362462210553,-9.18272217442803,2.47896364280519],[1.75987550703002,1.68427069925594,-9.97337635934547],[2.52455528115034,-9.51028136832254,1.52715270219262],[1.40016189117954,3.6436257122692,-3.81133850319237],[7.53511848068641,4.86275192906761,-0.908288225863941],[-7.63962271933179,-0.729653024928579,-4.2349861560526],[1.81314987107208,-0.448922304431128,-9.80473212252764],[8.78590021916274,4.53843827230804,-1.81017507978705],[4.36041477144127,-5.32439292785277,-1.20506878859577],[2.52804035559222,5.89626697509191,-11.7029163434034],[3.19458619848095,4.60057239132665,8.85159813821238],[2.84324388436512,5.54341906210645,8.65996483875229],[2.27213292151466,-2.75866078292714,10.27678357743],[-2.51859217963616,-3.66563977785219,-0.257317150234993],[2.5241332520099,6.12858484934696,7.532982586835],[0.925160298416836,-0.00779667006015061,-2.58143758050076],[3.95841625147203,11.0366200646305,-2.766299794083],[1.77418161099942,1.21065168376637,2.28231549087925],[0.840439346089745,-4.82006915496874,-5.31419477188166],[0.248469119785159,-3.06433421027121,12.5273327004028],[8.35875631187322,4.1909515255089,-1.02818336771471],[3.38158237929519,-0.274350363512524,-12.7121868736376],[-2.00561022246947,-2.07711679672217,-8.64133671327974],[4.45991207186707,-1.53763567536448,-11.3534272110321],[-6.7912409698472,2.92374675972388,-4.21306337964356],[10.3681217190498,-1.27665581982914,1.22311270669891],[8.41639966873075,6.47068656280738,2.20120224729033],[-5.74149643338467,-3.41102968462611,-5.05775397195912],[0.433020987416429,-3.3360228884282,12.7373504021887],[1.81322381258734,6.12978475188248,-11.2396428189467],[3.89844260649593,-6.37985555167881,-1.39423655062857],[-4.4915379717878,-5.51092080033476,-1.26589951877178],[8.27673171241323,4.6979822451808,-2.04128480895549],[0.596534837765284,0.181007167241254,-7.33527300722239],[-0.557518806028003,1.44257253173138,-1.89349817143526],[-1.4487291889474,1.81494824185778,2.29088190489266],[0.11246253315988,-3.20554769110385,-10.8046438736575],[-5.99985693677789,6.70949810329215,8.81023822569945],[-0.702258931313437,-6.63985542059418,1.58389535770905],[3.03894145140997,6.20418981183121,8.27460462978497],[9.23656888597359,2.32303836229115,-1.71868333498587],[4.10241248223071,4.92316813597577,8.45935569267136],[2.78004798495548,6.39040444286302,-12.1746889898688],[1.46088482424097,6.00544796342355,9.44290398722623],[3.70155056711139,1.18286371002638,-9.80606908360324],[1.3376215631841,-8.22460042143523,1.79577478425171],[-2.10104715203066,0.419043959199492,4.34614637017145],[-4.28799907784281,-5.59782517590468,-2.48757899247928],[8.8071812629282,-2.94954426158658,-4.27616330166148],[-3.41090456361696,-0.560124162278336,2.47422606857063],[-8.65885643294919,-1.39283806481553,-4.1396847457873],[-3.58173960364257,12.3522318634828,3.60621868279488],[0.622039818375445,-8.44533379489481,1.94404875731582],[-2.95813659595585,11.6723769614853,3.57794196846659],[-2.11808300385187,-3.69253145546057,-9.55762064330646],[-2.62453331882103,3.91070385904413,-0.219531376122248],[-0.856160862515594,0.713606313319028,-7.4899459894938],[0.903783600586243,-2.79934180553991,10.5756490185124],[2.21943383985621,-5.67243106716689,-2.00136866014656],[-4.71389532228457,-6.07165479200057,-9.97255555013316],[1.78515168982771,-5.5208014667189,1.97996283080819],[3.68477984534694,5.50433536189511,8.23288439414023],[1.67734944899166,-2.4489535301146,12.6752086647587],[-5.89488324818851,7.03927074781667,8.78671319388526],[-4.36409912421767,1.89794805283029,3.98261081870296],[-3.03951799055088,9.70293475442673,-6.28396319826757],[3.44434109166598,11.3072155878441,-1.5834305143676],[3.77190526748509,-0.871639795467224,-3.22169967841779],[4.41682235353499,1.99377173403665,-9.22326341136991],[-1.86238941098098,-2.49988123427895,-3.61982814594685],[-5.47117350546005,7.92516683604708,8.81763085045205],[-0.130744431045867,0.340672378804366,-2.49696369386779],[-8.98255383656072,-1.3203215318424,-4.04878153834676],[1.71345026994373,-9.6110645708593,2.28368445443748],[-5.95132682408758,-5.19877990096506,7.62121977253581],[2.26768849776959,-2.6273704868515,-4.43893469159501],[-2.94261036259469,4.62844125877035,-7.54571627889651],[-5.21656103018835,3.88363042651625,-6.38455635801978],[-4.09316953961183,2.13083778645819,5.63046925419904],[2.05947082257479,-9.73989047772121,-1.19449418747694],[-3.48350144403696,-5.0020055238039,-1.69335279206276],[-5.82358642815871,-3.33227761053561,-5.16916506340616],[7.43733121386033,-1.68524064281518,-10.671033092217],[9.38109953927394,1.6263717236209,-1.69131425664188],[1.65971120123327,3.69833239009954,-3.60022954641177],[1.24607059853753,-2.98531180822367,-7.69192194179044],[2.25212817549051,-7.66713605527103,-10.6694544652801],[-1.90071212426508,3.75448981554765,-2.51352789170938],[-4.95598555732639,1.48084972901745,3.12398306504101],[3.25891396404157,-9.55760276693747,-1.00709165683097],[0.116387198085733,-8.28047606625509,1.29165757707087],[3.43566758597732,0.527345345068388,-8.82116159731112],[-2.17573860979428,4.63682114597396,-2.6597975141302],[3.56944253389966,4.59606752250356,8.67853185179792],[0.612083117683066,-8.852582361703,2.21201960732797],[4.04212282316082,5.56715560403104,7.67447762201065],[2.25282044122009,4.07296318264829,7.14478624147271],[2.83402264799769,10.5068793735957,-1.92257830285606],[3.04595018323695,11.6475794251197,-0.979047736480129],[7.48621530538596,2.62563308420087,-1.87423020263372],[0.88024509228777,-9.12511352545799,1.19501467544109],[-4.98256080307844,-6.88909964890877,-1.68890772335602],[-0.122806711061123,-3.05710584041467,-1.03128156210658],[2.29278604054188,6.25154773347001,6.64243920763746],[1.02152315727987,-5.84864173121043,2.48905912207493],[-8.64124544707867,-6.56834243257672,1.43138420347968],[3.77557273862789,5.85038297352356,9.33485408138128],[3.58824591740013,-6.10861322412986,-0.906010813132094],[-3.63143906299652,1.48619040460073,2.08897951941409],[1.85780484961631,5.63970760072178,8.45705659858847],[9.36714563339558,2.90572105454424,-2.77422656027537],[-8.61693450382552,0.159828932459774,-5.61188792903427],[-6.83102812989515,-5.5779580756177,7.42175791388598],[-3.9926406488302,0.95191579627397,5.40148405094942],[-8.69362338520359,-6.26081534255464,0.706357882060861],[-5.81476032116556,2.85946211587222,-6.45896254171999],[-3.59991325533191,-4.97958853404354,-1.36447789005832],[2.36768842479238,-5.1289297441611,-1.90615156641426],[-2.14793088432479,5.42287507817035,-2.8208383238321],[-4.26895063989692,5.6793339987647,-0.292914274832703],[0.18345870568283,-2.64173983074407,-4.92038589498036],[-1.87237309530046,3.0368106509518,-1.53847344037197],[0.899639674556298,-8.02390953561776,1.04690742118536],[1.6062860545492,1.6815935349488,-10.188470637897],[0.483814516413621,-3.09838938583185,12.3960400715243],[9.96659810492261,3.50677085276964,-1.96827240406895],[8.03824178836894,-2.96796960988548,-4.75720949644222],[1.41788668746604,3.72817720323425,-5.61743179446722],[3.50876722592563,-5.22857131723543,-5.28408440141237],[0.533021901847349,-6.47253086215979,3.9630332324667],[-3.58214085050947,1.19150039374275,2.74651240497955],[-9.75671763169695,0.99900169677028,-5.82714226048722],[11.7797718961879,3.50117675217483,-1.05616428582199],[-3.91568470181705,3.31701505317374,5.1817439865241],[3.91907984721665,-6.7488058383231,-2.15092394885306],[5.17640340866362,1.43438684840328,5.56550940626764],[3.76377004731986,6.34900660300165,7.6099289281266],[9.4570806608288,1.15143616090421,-1.24747731773981],[-2.00760884023901,6.23216256350221,-1.40909320046541],[1.33045077458637,3.79915583485627,-6.33394239125262],[2.1298141873865,5.73932309157708,6.78252122487623],[-3.49241476513521,-0.611354542132716,2.51469914081128],[-0.979806169082353,-3.24672363736355,-1.74330237736327],[-4.76434372881205,9.38178107679163,-3.9539024274963],[-4.45083973220857,-2.06646855831934,-0.935191556483914],[3.07995297225084,11.4114613307034,-2.9987834446702],[-2.87808984478401,-1.69231416884559,-3.93641044192168],[2.61607284682768,-4.46062010886146,10.7025584975376],[-5.21278903282238,7.68672772773679,8.11113253928801],[0.437756319366742,0.789746035459788,3.40146622708881],[2.23432847251126,-2.90731726756473,10.7955811132021],[-5.02827607534612,1.60828822748751,2.12750970026762],[-0.259023249534692,9.43295095949541,-7.27036675494204],[-5.33415107615773,-2.64169968004675,-4.19014349672066],[-3.41193585666575,0.199504135991403,2.2411635151153],[2.00385382142478,-5.47403848396554,4.70815499317491],[1.8196348858441,-3.89610046207958,10.3296820996698],[-4.27321655939318,-6.94484913691218,-2.56050361724503],[-5.27251210498821,8.55552927665816,-3.92490829799009],[-2.2593809274105,5.80444860558947,-0.670751395364849],[2.55446881627443,11.5675443355964,-1.45661967414064],[-6.41610507776555,3.48003317178661,-5.3207149502438],[1.13221228449679,3.32327252336952,-3.89098390450036],[-2.86196018712075,6.60763463859159,-1.31267995374819],[1.31722378647078,-4.48770021222864,9.97070869829102],[-5.7651106205012,8.45437703255904,8.10976133765989],[1.40006460864714,3.0575288822546,-3.16754783178641],[1.6372010829639,-8.18033457092152,3.88965149493079],[-0.252765099333339,-5.40202054106769,-2.20866229717286],[-4.45568619469829,-6.73718869480237,-3.20548255971104],[-4.50009312723777,-6.28753196798967,-1.09677652499485],[-5.16026391187654,-3.05899035534776,-9.32360165047415],[1.4815922703734,3.87853857270979,-6.33099399324346],[-1.77920972295562,5.25826325817147,-3.30513878541273],[5.27132509240352,-2.6523840790204,-3.67967427607038],[9.94660523988044,2.05907480358542,-1.0148149143421],[-5.54318395949603,6.70641425342885,8.82291956459074],[2.30290195283447,5.96931778012563,-11.5269971942974],[7.35761793985084,-2.15524788142854,-10.6084971474446],[-3.10969390524413,-0.441703945070888,0.533253533145382],[-8.55587663326232,-5.78874434847794,0.470436885518507],[-0.777712642772881,4.94039746727208,-1.53781543504982],[2.68989842480199,11.7055077879758,-2.48240167002736],[-3.5211419659912,12.5991296847185,4.16259401459242],[4.15326954654843,6.04230988028204,8.91442242255819],[-2.77235538350021,3.77064225474646,-6.60378501950263],[-4.96554456768596,-0.197567342361824,3.23938178269763],[11.4408627802945,1.51554214764313,-1.7643464899854],[1.8445228491506,-5.53183306724901,-6.26751695229545],[-0.00794272496224069,-7.25783655604476,-6.03541397271311],[1.03862095298576,-6.62245821292035,4.09607336184577],[2.39003605181335,-8.90390185834962,-0.478917072019232],[0.688925833901816,7.26878865705864,-6.14451435944939],[-2.20631995935245,4.68170821386451,-7.76676177955215],[9.9348172893657,3.86673427582336,-2.30896537581124],[3.64283520724305,0.208150266838443,-10.0800516089167],[-0.407167970611352,3.7558733790978,-8.93706961326325],[1.85325078742913,1.21472232704747,2.56461521897946],[1.79766838117148,-7.06503398985565,-1.24289027273553],[9.17960093839434,-4.12913691615914,-4.31309149520957],[2.83111462866189,10.4253533301368,-1.8171295953527],[-1.60821761968449,3.30916828498291,-2.59531657575403],[1.62784318026699,0.382478480846732,3.68669258309884],[-5.08219884489896,6.52861970367446,9.05178150773822],[-5.20428376449879,6.44346425106987,9.05757450799],[-6.17620911736757,-2.83071097485306,-5.23577506878223],[1.87303753591018,-5.56603222917635,2.05110990947637],[-4.32863859552064,6.71709006662338,8.69657197309846],[-0.217462807292437,8.70579973897451,-7.55252777332065],[-4.49571971113234,-5.8262938401085,-1.28300117432184],[3.0322143029498,-0.144713648264614,-12.1637572233672],[-6.10776537734559,-3.22196337056669,4.94640412968461],[-2.9056896137955,-2.88688051235358,-0.214942922284723],[1.76831397012327,-9.06861992176232,-0.746104154482693],[3.16238006739174,-2.23561900369985,-6.83770771144004],[1.00140897719784,3.9897318731974,-6.08727243209796],[3.47787109130603,-3.22432454669331,11.605579554445],[-3.83718861291901,6.11739186382824,0.47316280786775],[-4.54748699821959,-2.91395477127902,-4.29130902028094],[3.06245652760726,5.31283769996706,9.014806960396],[1.09163714685071,0.406390808896006,3.22352134840956],[1.76310383250726,-7.89046083211746,-10.6909454736777],[2.06698230287884,6.71999906599924,7.67583680213133],[3.5196434492857,-9.4466144012529,-1.37988947969115],[-4.08572035702206,6.00722961276061,0.272841338483734],[-4.9623889154339,-0.354428972923976,2.70430970953227],[0.87980684417166,3.70571413424663,-5.85868688520084],[-2.59661743609132,5.42966486898096,-2.95403407685363],[-8.41690724867892,-6.63206993705029,0.44589896349776],[-3.85299575971317,-1.1630012199638,2.05638582164874],[10.584610699516,3.7957676361296,-2.54699225794989],[-4.77022433967677,-1.15637336278977,4.03076724485971],[-1.85578712184486,-3.48943804887897,-0.480754196587867],[1.62245985017651,10.7975095301835,-3.08712557139195],[-4.48054595075215,1.62395538323607,2.50799140384645],[-3.38208189337341,-3.68109434929023,-2.95797591207582],[-2.02182856874387,-0.0508510813616512,-4.76908008896722],[-0.986695000887349,-4.42981064385984,-1.58332292113962],[7.21270448990511,-1.89770010552822,-10.2432714168015],[-6.08360437262791,3.53905874078373,-6.06082584859892],[2.34375600998459,6.62354967968121,7.60730318044193],[1.23150718264416,-3.39571081792251,12.02457919485],[-4.02554134955402,-3.05234163110713,-2.24842530229443],[1.26351668474928,-2.87409920437408,12.9382047032171],[3.11246014047398,0.384516599040202,-11.3320390912078],[-4.26784732842597,5.54244211605834,-0.643026687605327],[1.43761048636274,3.79635764367966,-6.34719834286159],[1.67453529581435,3.00494705423249,-3.95638251533065],[4.49030254250423,-4.81922168265164,-1.6190631294119],[1.89251958330718,-6.10324799758061,-1.90820777527523],[-0.853502781604838,0.649502588106059,-7.10205884013458],[-9.06116070200687,0.21203574748313,-5.82238388205596],[1.14863513397223,-2.49118659582766,12.4916993887934],[-1.72961404675423,4.65754648426355,-3.19526587816625],[5.43041409982116,2.5423553874351,2.3348445661863],[-3.71105330025015,-5.3634699596228,7.62877042071473],[7.70921020602115,-2.11194180020964,-10.6795484126206],[2.92138190704746,11.7672660087325,-0.835170973071614],[8.42714779920721,-4.4970959908064,-1.60398988691682],[1.80178277972123,-7.47754989798165,1.71480700398733],[3.88522351403176,-2.6113166286912,-6.77301006855404],[-3.6714928270903,-3.33913687528841,-7.52462426494564],[-6.73647558857719,-6.38005675038711,0.445467044594354],[0.501109265016535,-5.4879482535754,4.5187711571996],[-7.38263508317537,-7.13889840555481,1.62828987040212],[-5.22972500694592,0.592665339901366,4.0634694090844],[0.522532613583643,-8.956269804985,1.80661537695523],[8.84255264722749,4.20590563243198,-1.06697039467854],[2.52527448672513,-0.628697261501568,-7.41477638720786],[2.06994111875408,5.91817465153014,-12.1194675350644],[0.344448314251008,-4.00610293373252,-1.52207702007184],[1.48791874238707,11.6230802998775,-2.39351520503932],[2.3614680454458,-2.64966231572361,-7.11997469755049],[4.24753032887419,2.4181711452451,-9.75370050443329],[-5.63015695776069,-3.16328891079563,-5.49299361428754],[3.97900367556762,11.4254758199302,-1.71564533144817],[9.89214552784067,6.68697803735962,-0.739159420839683],[1.73074068420304,6.11633283590369,6.82767072827645],[-6.77433261318044,9.12093599428907,-4.19969029791623],[1.24722314010393,-1.88544989972525,-10.2299671084484],[2.82693642458227,11.3229365365999,-1.70377596085463],[1.21540363288978,-3.81678835073355,11.849682781087],[3.60917224758523,-6.30676776921718,-0.963337712412691],[-1.67074090831175,6.03577758158327,-1.79934750114961],[-3.93235343744909,6.93305294119662,-5.91808666013648],[-2.07156165053733,-6.019917350438,-1.11720252624967],[-2.8387058514601,0.819454286330474,-1.00595296594405],[-5.22201526119463,1.65562236101834,2.63189189522299],[-1.98968178834721,-2.84905516760631,-0.481539111763769],[2.65269879392382,6.73051744670037,8.20566097740409],[3.21093542006768,-5.76906423265142,-0.804415781398864],[3.77792388268001,2.24455413924993,-10.1819980963375],[-3.88557898748415,8.17378827607742,8.60850585871597],[1.50122741588271,3.16673852613592,-3.5700536955143],[10.1536649519084,2.01049035057746,-1.99260274628362],[-4.24160047628831,0.562450904966351,4.09657390529075],[-0.507360175203709,-7.30567217369275,0.770269847078279],[10.6305657999008,-1.80688617704422,-0.777704739469733],[-5.29626949851679,9.19680002585168,-4.18551941182671],[9.01368747923398,-3.66999144400399,-4.65177426190285],[-6.19766524687377,-6.1608101226814,-1.28234972656072],[1.33291594241014,-8.8682148534939,2.65596437007606],[1.4433198781528,-5.7241528817853,10.9013075392979],[-3.00725827859239,5.26314266749082,-2.65283185970266],[-3.06621583930858,5.12896048173497,-7.68542791317668],[-2.0899167161369,5.53255004411796,-2.9445510916422],[-6.28461763546675,2.87051152341918,-6.51302128459436],[2.31112247564594,4.12018441581216,7.91712954397141],[0.0221694511849456,0.261214472663615,-2.28082735186759],[-4.87747548028422,-4.95866889437897,-2.11543708080041],[1.01413330385918,-8.6803646634092,2.73603350942513],[-0.203555576467872,4.30346110998917,-2.93646954472531],[2.34341145206952,-2.98941207264491,10.3751148667099],[4.42313342633674,1.40337512062087,2.37976370779284],[-1.89265008956311,0.842082661339297,3.76260297070658],[-4.75966399535357,7.83306350749614,8.75947047124456],[2.84136733888389,-4.68282592484468,11.1425454037869],[2.11713615770517,6.24601154074273,8.31478712894713],[4.01900013821241,3.43706532893147,0.382176082606316],[5.38701089522233,1.25128253477826,5.32382870531585],[1.26408667681083,2.99734227976302,-6.98514386192808],[2.49615652402135,-9.59240522619198,0.876150223471625],[-2.67930539398779,-2.74408826905533,-0.336901513620237],[0.607641885661526,-2.08561096843704,-1.89513218344457],[-4.43644417283353,-6.36320273484823,7.75899683783777],[-4.5568138852711,6.2063194431533,-0.637442280411903],[1.7356507762852,-7.54939947422675,1.88006660456264],[-1.92846792816878,0.343231004869273,-2.75237396519632],[4.35892943869257,2.13673393212315,-9.32984014880707],[3.95443135163515,4.55847481664718,9.13048510710792],[2.22432278367529,6.71988250771838,7.6758863169195],[-0.29740556147024,-3.08989888693985,-1.05603607676697],[2.84844641119152,-9.59327805261512,-0.228034146269728],[2.9296674993347,11.1978364870225,-1.30962965946364],[9.79033230863464,-4.63103408598495,-4.18485981271123],[-2.05711640409507,6.32023546326066,-0.646018564684365],[-5.24100173442664,6.9317303562751,8.89985515170676],[3.29287941252747,-0.40601876383059,-12.4011293245204],[9.34909603552856,-4.77687671386353,-5.63823595949162],[9.83634527359529,-4.45550705979092,-4.89214984845741],[3.45130687793893,11.8923765729987,-2.50922717244585],[10.4979920330506,4.9807746688772,-1.68430744086318],[-4.43678344502282,9.08246381328836,-7.49225084305543],[1.44737686442362,5.92534001500307,8.63966798934048],[-4.92754402905568,-6.26239126969853,-9.34847071562356],[1.19525623810131,6.20027060697371,6.66724223120666],[-4.0907782433392,1.08192953177898,4.7409264200039],[-2.5868583263317,7.21909519330156,-0.799267445702699],[2.64602264767259,11.3705240035658,-2.89485343370729],[-2.03658482135789,0.359447732119193,4.47270340480088],[-0.252118335944278,-4.04383450326268,11.4870618358379],[-4.59069029192501,4.91965629338495,-4.68697527144898],[-2.81846530607315,-3.14112760304787,-7.32413134173898],[-3.58727217016084,-2.57184399875771,4.18258051714316],[3.63123392924473,10.9558422156902,-1.88125299961295],[-2.38905083980152,-2.09023532027029,9.36428618303269],[1.32681972085018,-3.07198696313231,11.938044694446],[-2.24124058777211,0.331780305309182,4.33002638016711],[-0.0127417002632711,-3.3061878149217,-1.17957235294235],[-1.75815216341054,-3.69452142469981,-0.141715027231869],[-4.97801556075208,1.92098182800086,4.97616887926285],[2.52177246892149,-2.78508749890649,9.51296162541512],[2.41113903698256,-7.4126911540829,2.3332002873435],[-1.83866456960149,-1.88129745721833,-8.61363636730768],[2.02921155261382,-4.96230909078812,4.52204579698844],[3.44867843017734,5.69930908538334,9.00945549881991],[-1.89360709919954,3.33364085907264,-2.30166888172959],[-1.80766914243564,6.23983955889058,-1.26445818047846],[7.29315293444528,-1.29269770108193,-10.9345309599066],[7.84438852194364,5.99770843817252,1.45304123951022],[-5.65058989759432,3.62049051441342,-5.51404923339628],[4.09694061048295,5.47556473651904,7.83430138800793],[1.8133566107089,-8.03181065290513,4.11962322281245],[4.04664121614954,-5.07631981781745,-1.90842860937934],[0.809178877201479,-2.28879373478713,12.210708294342],[-2.61806845584917,11.3675896159478,3.27331895773638],[-4.73368844287807,6.51656280511756,8.26545931965391],[-5.29023161561764,-2.71921103713835,-3.77886857113508],[0.86513463021052,-6.85445384331434,3.81649223445857],[-3.53937235865366,0.709824626362392,5.26163826975139],[1.94470796349065,10.9252083058385,-1.65251142315863],[4.73053414302338,2.15852949740966,3.98208299979937],[-8.21740386677519,-6.44648609151687,1.22242989402368],[1.28703750884482,11.5010317230486,-2.15291138715792],[0.0683033491333662,-1.93544062152272,-13.1251701351893],[1.22092129049276,-3.05154716608809,12.6865056142609],[0.694240913883334,-4.62243651081338,-5.56368241156557],[-4.19955963365471,2.76181695397613,5.42472802187744],[-4.8194941095089,7.36483906123962,8.90306486505451],[-2.66892109122975,-1.44307774648651,-5.62891432067449],[-0.315764506625734,-7.44440851855053,-6.18167644511531],[9.96378543042187,3.42616380566232,-1.35618695410398],[3.09768026624262,-8.32329195203985,-0.786936516776091],[7.58177059935987,5.56981867896251,-0.412646175862818],[3.63064365640476,-5.59217356806144,-5.11978128648166],[-9.20746781681373,-1.41378647629881,-3.50052583706311],[2.18306859953616,-5.25177206647787,4.72761387070451],[-1.37973947199112,3.23548367370617,-1.82132243262965],[-6.83234876916625,3.03352358134572,-5.27232210734985],[3.00696643803308,-8.30527642278789,-2.05730048145507],[2.59233102850862,-9.20641320726826,0.961912917667834],[1.57725795585432,-4.55994250130193,0.0908289959448745],[0.588203430215291,3.52912231091652,-8.48727524238634],[2.12764847873777,-7.94971384987129,3.65139221412302],[4.04081564889401,5.50650620136216,9.09948810906213],[1.89209730244479,2.84439038617545,-3.13329954614126],[4.69228069930623,-2.24758634953288,-6.81405220041323],[0.0360552052639941,-4.13442091900155,-1.47444326234329],[-2.04485357862481,-0.662043102424989,2.62795558345555],[3.80110184711783,11.263040355852,-1.48541917912923],[-3.20101641614249,3.7524021421955,-7.00067135449419],[-2.93539962765795,6.97155501438046,8.78178633113528],[0.805588806971808,0.325514205051723,-2.91754424743296],[3.16403606958767,4.99874261189383,8.2827392588715],[-2.80175914610018,-2.46477953742186,-4.70124090816158],[1.235923297952,-5.7342448074958,4.28071865271836],[-2.68969024145593,12.0149879560363,3.84438702839405],[1.66814008154644,0.23305014310792,3.43483558167303],[-3.58884889830257,-3.63270733063883,-8.35050980732272],[2.51499470468259,0.0211459324826873,-12.1200134443126],[-2.02905608075472,-4.32399772113327,2.17638240985235],[11.5814338230008,1.65336518401807,-1.05187584190335],[3.20826829494678,-9.77927202115179,-1.68248665992945],[0.637085739197457,0.701035742956577,3.74790126107411],[1.67115686859897,-6.77563180601933,2.07314984606212],[1.49266049681908,-3.97735287821813,-1.64137426088549],[-4.57219374964619,-0.667467623823406,1.68744810143398],[-9.69090403741217,0.484355642625798,-6.03838157132134],[-5.31764703723209,1.47249667675767,5.36447892132899],[-7.04150948775171,-0.545450646679355,-4.36230273439976],[2.14471072532329,6.36407695806592,8.7343675629137],[4.19219667069398,3.33687850662401,2.89658019864578],[-6.25399621283187,-5.26196710549932,7.67759912185624],[-0.654266575491732,4.27292694388769,-4.44995718637335],[-0.137349037004632,9.03550718528155,-7.33860937713897],[-7.48866512863476,-0.571940758620829,-4.74259788858886],[1.28071912892413,-3.34522453049452,12.8473224216033],[-3.11261382960725,4.5146378665377,0.403967214860264],[-5.17820236567305,7.204579845055,7.85556424711346],[-0.507387482157428,0.901359407073181,3.42682768378942],[9.7414006358508,2.80875266975443,-2.39335509279148],[0.519901114880561,0.433284749311559,-3.14122583699221],[0.0281228639401259,-2.7823625539073,-0.982498535637835],[-0.0855126356297574,-0.702554919084521,-13.5166538678535],[3.64393726864677,5.76630422528634,8.01772820768891],[1.87714674122852,-3.01737632888474,-7.83511244126102],[-1.53400242639083,-6.38931238475133,-0.258664772314143],[0.951071965274118,-5.63152337560549,4.82980002543257],[1.27575946059697,-9.41953873316337,2.21544635518124],[3.96994501977981,0.716098950176339,-8.96057761290313],[-7.5233245558549,-6.02114076215072,1.98530506168638],[-4.15248381196811,0.667589459387781,2.19967857233685],[1.29767853835464,3.5279564757004,-7.01855160389685],[3.74896068272885,1.4908238782452,-9.66368339397895],[4.14037473631103,-7.82131506363745,-1.1534843454272],[2.14289459800327,0.861286215134172,-6.87755862262385],[2.96921521691024,6.89600124452286,7.66433522407955],[-2.7732232552972,-4.91040435208396,-7.69276529917673],[-2.5698594621863,-1.48498799357762,1.79765423565641],[-5.54425547142104,6.94595852964445,8.8475418744201],[-9.35654445397053,-0.346263405428213,-5.55582317174047],[2.01229256978993,6.36470995510359,7.23105151794416],[2.03884679721786,-2.99571572241567,12.3999957018608],[10.1191798525553,6.43081643749207,-0.970675372773248],[1.07216959188307,4.61778679441617,8.54728922933041],[10.4991701722165,2.51081320043386,-2.5942117287277],[9.60326949439871,2.51579741479452,-1.12401341096788],[-3.19743015359518,6.59198460494306,-0.162549310499667],[-0.36713227952766,1.43082132960087,-1.7682047120432],[-4.48578153836507,1.88816305545331,3.76998179294007],[4.70094575240056,2.22394624562033,-8.75000238491089],[1.29417028884605,-6.93860464955138,4.44077228663083],[3.2157582491665,-5.22229977034026,-1.7861480356938],[0.629023334118367,3.49533867125261,-3.81566507619351],[0.936881929073692,-2.78957252690839,-2.64056019729847],[1.2714841819771,-8.55648874126144,3.15014284819514],[1.79407573765187,-7.54539742173963,-1.43728501806735],[-1.50582082069442,4.72675462892718,0.651317090066727],[1.97767744982273,-5.4994653427487,11.1026762848412],[-1.15795278973874,-8.11730735904407,-5.95243836300018],[2.80751824892209,4.30429360986497,7.93902310428711],[-6.02839936258051,-3.86120998301649,-2.53201607021483],[-0.251079328872183,-8.31378287990131,1.52451379350674],[-6.90381352513627,-7.26513050121425,1.66088321360694],[0.0313018236154003,-7.35827389263195,0.450158074678656],[4.10253859949779,-6.14323940211608,-1.71871045926705],[10.4615455734659,1.32140455089221,-1.11382706197997],[-0.0890221476969674,-6.96678562742202,0.836381359144314],[-4.22832715126693,-5.58850162828246,-1.95544609682971],[1.38855003011235,11.5605898905174,-2.04650744617212],[-3.37169382936634,-2.66778372603073,2.06515706782098],[1.09682004524074,-0.780382591909626,-6.54007446728626],[11.5041955130099,0.971335995944607,-0.830102955155267],[-4.72651305911775,7.99946090823183,8.9987111535202],[-1.89671711561298,4.62953287639093,-7.08901578242143],[1.56857071667465,-9.1791292399434,2.43181631446773],[0.652800935310975,-4.14854686540615,-1.35643065681563],[1.52263256544966,1.61610270458119,-10.0282420113164],[-4.51877200235807,1.41562654004865,4.51265857185794],[8.76132638986151,2.77910792404431,-1.81224934805763],[-4.23992814453632,2.03837755131762,4.51729569413257],[-2.49324127680186,5.03958502536277,-3.17511243155096],[8.82752965644927,-4.56853390725295,-1.02608099214616],[-2.00941171258661,-3.25641507875767,-0.252490588159794],[1.90876311825802,10.5698369662387,-2.37928052840754],[-2.74051103641787,11.2332954612943,3.02206203629612],[-6.07184717000782,-3.16240125309388,-4.66732212938017],[1.9325290699135,5.10272140057795,8.45229931665706],[2.41032886041127,-3.55705039667529,-11.0755355680874],[-4.0888625479698,-5.14730487666861,7.67775058650506],[3.98520089002156,-4.96053499636389,-2.00771810493834],[-3.3332524614991,7.3014275744321,-0.162937093354404],[-0.0915825108414677,-3.15283928687494,10.4431065153093],[-3.53842108465621,0.397529468396889,5.89454142871197],[-4.23544146213068,-6.96905244963473,-2.56600901325277],[5.12624342886839,1.87948021754913,4.58486054982964],[-3.61049516977132,1.69581524733534,1.80807495997066],[2.34256522233785,10.180128822739,-1.84975928288329],[3.42275854065837,6.26169540461678,7.58503760727572],[3.26193952208326,11.4025563703856,-2.71270893891687],[2.61042706840854,5.98014503910221,7.23701497025181],[3.83175025695045,-5.14019590757668,-1.92790756083714],[-5.19560108326195,-6.10275428452766,-3.05975195224743],[-5.04862290686948,-0.29784511003641,4.4542149409339],[-1.99420455563616,-6.14421739077584,-1.38043657897343],[-4.50729448065308,-5.90624261646334,-9.4293359568178],[-3.71139838722321,0.750420246763669,2.53139751654562],[2.57012965821969,4.9146488806758,8.15087120867018],[-2.01393426101513,5.94503646942002,0.322885524163569],[-0.128597712621143,0.037974654840967,-0.637772190732636],[2.37757052751992,10.9478495952196,-2.5007079768343],[-3.91105815319328,1.85046819713251,3.60487788612065],[0.956957697474415,-7.07822833774372,2.55446316000079],[0.0234303599882952,-5.7986136461953,3.31817072464847],[-4.36421988292985,-5.86268481443444,7.0664923327768],[-4.63777096956909,2.01384124536114,4.62779636858142],[4.44913101654079,-2.73540923424727,-7.0301349924326],[-0.357971248338335,2.22563460601589,-5.21097038072231],[-4.93628971173704,-1.40896934034203,1.51974617322082],[-8.91711988547483,-0.680283846687905,-4.77941764831161],[-0.337935442656318,6.06161117481319,8.62067763734339],[-2.05672056985656,-0.120046771471457,-4.77137588416893],[8.36868227547836,-3.12416725812901,-4.81321104916459],[-5.1630477437351,-5.83844393960416,7.80243315088243],[-0.119558274523132,9.51480001778487,-7.54744951772017],[3.58075807559516,5.82401188269209,7.60557673184945],[-1.80705500974585,4.66271580395019,-2.43776388369453],[-3.34981994813398,4.70543971185753,-0.350194679553062],[2.64447428128253,6.02925595523373,-11.0260015318386],[0.597595519361099,-3.34639461720749,12.267451592901],[3.31709456026758,-8.64698544045139,-2.18786720101869],[1.08675470311284,-3.23509752068315,13.5121170933092],[-3.51233722746283,4.94579810659338,-0.371950188137229],[2.09789367436774,4.5193664338036,7.33545410223102],[-5.78305178204913,8.63759711641836,-4.3831859824302],[-2.78006481420299,-3.89015767868702,-9.44598792117688],[-3.79633460216417,4.79614453460703,-2.3478222677338],[0.658384656616163,0.311453995918519,-2.97901982954488],[-0.0886486843272092,-7.90202635798956,1.95748178541376],[4.01865748715112,-1.41208568786026,-2.2800763857512],[0.165098710289447,0.814149869303736,2.69025931671542],[-3.81678980247349,1.58452596199122,3.26987535652533],[0.734960856226871,4.15325056928512,-3.59566233884016],[2.62662485702077,4.0287679163045,7.92758323582376],[-3.2497314299771,-3.49090003052391,-1.62326123522949],[-9.2915775329615,-1.66701700330288,-3.36201649245293],[2.35515571413294,-3.47126922590502,11.1427896915916],[0.0483067250132623,-6.76122167911094,-5.96211183399465],[-3.5071653335149,12.3198025506646,4.33468376021879],[8.60997611835261,7.0241533656178,1.49194487481347],[3.48787727972589,3.44022463547038,1.36062205378731],[-3.91215184452642,0.40256969815812,4.77704307144761],[-4.36513713649468,5.45867371118782,0.125015619668286],[-3.1571110775301,1.03309720045043,2.8017173781029],[-6.04851986306107,7.79570710298776,8.74840759878232],[0.772894711543113,0.361593556534276,2.83632648019998],[2.187116970166,4.64368694129904,8.72974164833051],[1.88844341823836,-2.97353716347486,-7.6697247332788],[4.47753867185864,2.63447094996895,3.22823908795785],[-1.8352712585775,-1.84956891259893,-8.55842534432151],[-3.08495178946541,2.93087502695804,-5.82167624051191],[-4.21310782167641,5.94426784385356,-1.22016479374094],[0.927750297709005,-6.94083120245686,4.30164811738559],[3.6929455933396,3.88666666231349,0.863228627987485],[-3.403567295266,11.5856686349009,3.53203345088926],[1.29410469788086,-6.05158751213599,11.1752174382215],[1.49653199022582,-2.73554731717422,12.0671602284745],[-0.152614675511907,-0.0531589131985942,3.92015411624974],[-5.39273460622092,3.16429402173218,-6.73959240168447],[-5.65315619437973,-5.90799906895342,-1.45051988096096],[2.79618318161995,11.4168688013802,-3.01678339858422],[0.358127769852633,4.2481448002752,-3.47361126564742],[1.07103347534908,-6.34117504371318,4.27298833544578],[-3.56617255189684,6.40684499767751,-1.01594124057924],[11.3993335265722,1.14327629652748,-0.721998836229492],[1.06843741000224,-4.04168672041645,-2.38033293660558],[2.71580370142338,-8.24096500429811,-1.99179703030749],[-2.61721421161569,-3.44905820614853,6.46421502081574],[3.66106741395593,-6.54149711385319,-1.2830687809064],[-4.18341504673933,-6.41729573567995,-1.69614188675591],[3.80319155339915,-8.63298618709353,-0.384339633976723],[3.01562171524078,11.0275259239109,-0.679558369253521],[-3.97439668808864,-5.25906094533587,6.04395647597999],[1.51855754940182,-2.81086360919747,12.6910520632607],[0.350210955214167,-6.44860008713614,-5.82957595069032],[3.13405526226021,-5.28745780911374,-0.965175176478376],[-6.45765704329327,7.74488635112291,8.2295630136801],[-2.62036052477415,-1.42409765208694,-5.8458545626974],[7.9709675252978,5.45503210190215,2.81830738866819],[3.23053878562938,4.17279612199517,7.76057881345482],[-5.20484131085662,-4.46265558357398,-3.77191550940798],[-2.84036072899647,-2.37185821039876,-4.6962331491512],[10.4316548763873,5.24898348802118,-1.55709526113352],[9.34292901017842,-4.22698970814284,-4.44495525730416],[-5.61005143574662,-3.77727220450817,-5.01535047956739],[-4.86462655003955,-6.45324110742133,-9.22535971125649],[1.00513146707645,-5.78184100061578,4.36884466716451],[-3.5686326462404,0.849124201532049,5.16637771208114],[-0.858045545405249,0.0841086167996389,3.48785091130017],[1.55533832265114,12.2786099027559,-2.24809078947646],[-5.49938267652679,-0.893469031551761,-0.0796597813257467],[3.48465240200656,11.6525621699499,-2.93441914784896],[-0.311293805257883,-1.18556680194096,-13.8255349340384],[-4.55110057960663,2.0004716922291,5.3765194543461],[0.36281990268154,0.746065466338907,-1.6880697272018],[3.04825102580622,-7.96187955991716,-1.34042742859723],[3.26023437401182,-3.76233501913048,11.173046326993],[10.0954959736533,1.78382808341494,-0.412564693013221],[1.21489911126514,4.07030787926519,-6.17621380458461],[8.87501547159606,2.39946647941871,-1.96438975306865],[2.25226994418437,-4.98187436570513,-0.377621042339547],[-5.14329233410821,1.20746548583119,2.88178326037091],[0.0784044764439765,-5.25120521195824,3.8056566429164],[1.23517478258865,-4.98837004917814,3.68733089438539],[1.82143122702096,-9.60417531519266,0.46708304844219],[0.669347022286991,-3.75522215216994,11.058964704499],[7.33083823229046,4.1500535432951,-0.967157044590836],[2.12065004232824,5.64383861179179,7.2675640375264],[-4.27223905803301,5.22317121566209,0.0643561246520804],[3.8506981551909,0.311210744967575,-8.50657165746787],[9.3437089268299,-4.36392345064783,-4.37385583763458],[0.898867259881104,2.52317698225052,-3.39610235273601],[3.6749009028321,10.4756955221707,-2.48467830096251],[-1.550846181056,3.16056263979334,-1.41377306501508],[8.91487217574912,-2.05010765592344,-3.57521454179526],[-0.817655082347551,-6.12688049854105,-1.82560972246519],[2.76660909550783,0.361159597177424,-11.8470904962879],[2.32970473110206,-7.65732024123271,3.61955609856004],[-2.65090769554821,1.05107663914974,3.94557177269882],[1.87790220988655,0.614626142019863,3.45271680432509],[0.307881340871448,-6.1712506687588,3.99524654080861],[3.26944979134163,-4.99874054660339,-5.70359172230385],[1.75585531331609,-0.997054743047717,-4.61045883923479],[-1.85143795337566,3.61738363479212,-2.41753686493499],[-3.70047997940662,-2.73375990734901,4.85943063085014],[-5.72408160976298,-3.36183457675484,-4.70818282499329],[-5.28829201653316,-6.40619056117296,-0.740925606740649],[0.368427499065605,-2.75349737038788,-0.759712554740948],[2.98125741572862,3.84608367849107,7.56392327928525],[-3.45225539856459,5.41704767123056,0.0736699302968283],[-5.01441461952165,2.91972007962876,-5.3595943572415],[8.39415780872595,3.02414844568099,-1.27726897749779],[-8.82661423558304,-6.4955842947969,0.802175117022904],[-6.30045033418368,-2.91534078595109,-4.89406492920473],[0.583032606180229,-5.18640349931228,-5.70716966762987],[1.74049937884131,-9.18790881420377,1.98889735434632],[11.2380426150471,4.4600303317801,-2.12512986255424],[0.800261770590842,-4.49883884932937,4.45042720895206],[8.5188719512222,-4.34493961256189,-1.47709533838789],[3.48022961238639,-5.89017138232066,-4.86439609556384],[0.770818649880262,3.57629598137424,-7.15167701288892],[10.1680095323866,2.42548915310748,-0.390472026894854],[1.03102471657058,-7.56944435290983,0.688988082283765],[1.22349352784131,-5.0095257731393,-4.92381475857881],[4.20375821273196,-5.02322069803286,-1.56763373067088],[-6.75897059587885,1.89903491012818,-9.22224925995658],[4.68194439870007,1.49777847952028,-8.63610581713314],[4.31852134418916,11.2245977674163,-1.76674174442225],[9.06843973447976,3.24703389100103,-2.5248414999783],[9.24527033653722,3.03717295315337,-1.128389492538],[1.58471498744496,-5.2746167822052,3.61247834059308],[-1.41245470760352,-7.77400508400706,-5.7425721336432],[-4.7585755433884,1.78102542488075,2.60165470483571],[-1.41893182207589,-3.92106671354748,-0.451444071965956],[4.30028470496389,-5.74806239807365,-1.74315972614937],[2.135011181902,-7.61689454553903,-10.9077314351412],[-7.94088471769831,-0.876453064067882,-4.59955445133322],[-5.08039028948062,6.99625965956227,8.78107589618965],[1.45410170512765,-5.70578242305779,-1.78656002050856],[3.50907130361089,11.3465930537773,-2.14516128221502],[2.79099721521118,12.2281489333596,-3.07153212543164],[-5.35081346703501,8.85510623266162,-4.13135106103336],[3.45342538595653,-9.04708782728614,-0.912907862958638],[-1.44961038221587,-0.689702384574725,-0.487311496759149],[7.2548686732873,-2.07519221766463,-10.2724468903644],[4.05333752971078,5.8337847784279,8.35854355475398],[2.04640436795409,-9.84500553058037,0.849472798616799],[2.97167018631813,-3.48881899692411,-10.8142074371386],[-6.33652050644331,7.40104459909219,7.90742637017346],[1.49077279738648,-3.16674739991569,12.2132154938946],[-5.44116783626591,1.38732409304287,4.38817098234],[-6.06253155512228,7.72043632492753,8.90941711923201],[-4.47820769179046,7.0525808400904,-5.14453807958415],[-4.98597448603772,7.39479406807857,8.53196994748795],[0.555096036871455,-0.875691386287114,-12.8762168986925],[2.5623286252967,-2.13818499867902,-7.43859514482436],[0.148150483511721,9.12397814719233,-7.64992188888942],[-2.90648941901649,4.60359170665329,0.29149168529616],[1.14658401095663,-4.61176422706279,3.51799149814967],[-2.15888216887906,4.63792744279411,-6.39269114461219],[3.66242534308396,-8.19813058382835,-1.84846358305751],[2.35438024271467,-2.71573929822132,10.7717633413463],[2.67243651967438,11.3207024152583,-1.19200772087512],[3.94929598264091,11.1721664988055,-1.46319305568016],[1.13151905933189,0.256841343005728,3.21295588634414],[1.70823450368012,1.19973965345823,-5.73407266965646],[3.36075616014452,5.7529157705634,7.6708074969558],[1.54598259486969,-8.65604616695418,0.911981593802595],[3.7166095073419,-7.82722412760356,-1.0574366766781],[2.62038876097405,11.8709602360665,-2.15568174271438],[4.61194651676323,-1.13519337708122,-2.94920758088805],[0.786069538650614,6.05000676582589,7.44600974472155],[-3.74994318627019,5.6552425645982,-2.2016532522533],[-6.64957871236227,3.02138220130026,-4.87170219804616],[4.17295427580991,5.30122034219374,9.24892905693066],[-5.06471543584387,-5.30600534857923,-2.32032440253721],[0.45692880182217,-9.58416539317939,1.50182357540074],[4.8692369453669,-3.15262813472817,-4.32415698531977],[-3.74073859085294,1.31150477979038,1.81801592723153],[-4.99916537840485,7.04705061106137,8.61542326723334],[4.1544283768384,-1.21035925386303,-11.743608040004],[-5.30847059926337,7.94265907902798,8.01841991822208],[-3.57348274359366,-2.08457106701681,4.44635358666493],[1.33674566294238,-6.22814106737651,4.63591946285008],[-9.03704480030886,-0.535025956283544,-5.19866823154835],[2.81329614446324,11.9659606997207,-2.03799489524149],[-8.80898970515238,-1.50555369403469,-3.76786373008778],[1.41670399543276,-4.00340128553599,-0.0214352894407576],[-3.82426885526032,7.39725205662725,8.85407722899656],[-2.00855917072629,6.71874021625532,-0.540645005302339],[-5.55383506713188,8.74793729683237,-3.84246013842975],[-4.26066989333862,-0.231714081937825,3.63934132590034],[-9.26118531193898,-1.75303545278382,-3.47707014945809],[-0.594422537873902,-3.98232067075901,-1.02609773439479],[2.56770611310383,6.52387030269208,7.02303292334921],[2.19168014563499,-8.4854636740936,3.68066135631228],[-4.22126885504672,-3.45271646629914,-11.2419873911645],[-4.75332120277528,-6.94473772573961,-1.37818169993443],[-3.51087834996578,5.74622417175004,0.632565336642069],[-1.82951581511881,-8.06700911141842,-5.47595696779487],[-2.12939357134016,0.175612282776684,-4.44548160547315],[-3.75558568571116,6.97352634161224,0.31735424601821],[-5.00674064118409,-3.13021646979821,-3.81925394196065],[1.54299442582248,3.03163917895203,-3.99798639020353],[0.24256493782365,-7.58374248448214,0.542363323210635],[-7.68702285605209,-0.615752008177677,-4.65451477614767],[-0.395626935670569,-4.39420713441629,11.5398940504919],[2.0898210966232,6.41093318472532,-12.1687991945569],[5.14703983664471,1.37545449759171,6.13773758839528],[1.17558116242787,-8.46148071101418,1.26348560508549],[-3.40822594784913,0.945105030060986,3.68749688101854],[5.13344486907052,1.43148294196359,5.31230501730771],[1.01807971044061,-7.1293235076435,-0.819705306634585],[-0.325520021391898,8.89528088440656,-7.14034753395815],[3.20870253240302,11.8685411327097,-2.90817676890371],[-4.62656584472284,-0.282729498905827,4.20336359207223],[-4.06751801676236,-5.14653827350089,-9.60017825987319],[-3.95079436635603,0.843583990187922,1.84937117837156],[1.71100834025318,-3.61538278975137,12.2777038707897],[1.61137913576788,-5.55038530523256,10.9017323901179],[0.262699178563039,-7.78290473231972,1.29042090082828],[-5.95850309057493,8.51987540054103,-4.37151265377256],[1.14862040315213,-4.40357083935426,-1.79891752740963],[-3.50777729123296,-4.49798902575076,-8.72725253880973],[-4.3950755728051,8.14165128554506,-7.00423502159024],[-0.156698944854459,0.741167426605974,-7.84543720193864],[3.01008528797771,11.8538830120704,-1.72442255592775],[2.16033970371543,-9.43583457074831,0.699824111970657],[8.28989847991098,6.6257097597404,1.49009327124799],[11.1311916831657,0.351721828470834,-0.618631083387236],[2.07923317526799,-4.6307171209797,-0.250873389459702],[1.32765801375374,-4.96246145151902,11.3240713490948],[-2.56818362493309,4.51027489770209,-7.34767089756981],[-4.10555616306169,0.758191468879438,5.03022254137812],[3.54401508585543,11.253962421103,-2.15765783291133],[-6.89342733792834,-0.835780426698648,-4.83461559783444],[4.12304934499494,5.89864539954177,8.56311674741926],[3.03291074121862,6.54311692045984,7.18767650541535],[-2.01231183654478,6.3130370813059,-0.146532849690172],[2.4662505483738,-0.122360711647064,-10.1326657537303],[-2.63540809414102,-3.92495326494247,6.71269977981091],[4.81457437579851,2.10480758420389,-8.63549355561792],[-4.1557534863939,4.39893714898878,0.561311496244375],[4.27271576852608,-4.92192714877622,-1.49137954379189],[-5.98552660366192,-2.63889988928917,-5.29821582728747],[2.9016215866544,11.4734077206711,-0.935755753123414],[-2.02993384977131,1.54748234569739,3.20105896072317],[3.61649836434851,3.72646166220639,0.736513422396191],[1.48314899516778,5.8794438702147,8.73029084995853],[4.360475760243,5.07177175975571,8.44995037831028],[-2.78393938654907,7.20223371297223,-1.07180490928185],[4.43739730856393,0.13789007740976,-3.73436906211833],[3.89850828877208,-6.93677293256687,-1.53453691496923],[1.04309105314056,3.97307446099021,-8.43001815378816],[4.37448925527137,5.04703751574407,8.1297533277417],[3.16397379843688,-3.60800855711914,-10.5959649226797],[-3.44196976089835,6.77690837297009,-0.425662422201821],[1.29035025164979,-3.3775816449574,11.1201564065798],[3.74763358955792,-2.9567392773296,-3.51139440114713],[-6.91380586155843,3.20327871004928,-4.63753117788793],[-1.08945791307622,-4.89086050157759,-3.43502057853175],[-8.94750995294471,-0.800375355778556,-5.09275226495337],[3.44009337889917,10.394726260919,-1.50790320362805],[8.05154759571158,2.97493857406344,-1.11034062298014],[1.68577625887996,-8.15125387006241,3.46187565795653],[-1.44184268452058,-0.0492191213047172,3.09532887165338],[-0.117200735522781,9.28641147579569,-7.40235589255671],[0.18787157149044,-7.8573432098193,1.47666474135293],[2.1995338926265,5.32948192159638,8.8027760373247],[1.36729573189818,-2.64500944177858,-7.87657122771628],[2.09130758484402,-2.17687458795431,-8.10841054829989],[-2.28049905060746,5.20053711337164,-7.26257169045059],[2.77849840297641,5.55551731479044,7.93695322011905],[3.49352841392572,3.68980506239889,0.949897718512186],[-6.04029946191833,-4.60834554365829,-3.72967323303885],[2.75134235125392,-6.32907857762432,3.98970742777448],[1.89981083645326,6.60095643190767,7.79487974577472],[2.39239902151665,3.28471297475103,7.76539880577908],[9.55969256277904,-4.55943546168162,-5.81143105540586],[-4.18924370415882,0.474857454130076,5.60800308027661],[1.36936975074556,-4.3057631847667,-2.77104503622559],[1.68359325522487,-7.05141236270648,0.135670664160937],[-3.77273239365517,-3.52610754912711,-3.54339277480495],[-8.34653717838943,-6.47782884245595,0.624496986321469],[0.388436407890468,0.251233769048416,-1.34780240380279],[-6.33171083785365,-3.8380288667419,-3.95940010473857],[2.68009873519678,-4.60769730069254,10.8058698022157],[-0.434541479602301,4.17084436880873,-0.456878974024179],[2.36811242739868,4.90903459191328,7.77235380600074],[2.21045074215586,5.95732915412363,9.12265368569008],[9.68332187705756,-4.33489777260248,-5.00763942097139],[-4.60535135171772,-5.94074290161208,-2.30692172853533],[1.09503786501764,-5.80832036947621,3.07921034365544],[4.06591033743195,-8.67247728317703,-0.18892853825582],[2.46646980551807,-3.31134894813422,-3.74844614706206],[-4.68550961824976,6.00960684535188,9.08504027576455],[3.88902879422354,3.34855830632431,2.10595677970524],[3.78499308938593,5.25054877389904,7.50500982417864],[1.90896984287203,-9.87384581375585,0.923866225575276],[8.75825438120802,3.52925957116259,-2.3437627410707],[7.44870698437982,-2.15481810508011,-10.5656931519625],[1.27886160951015,-6.25201144062015,4.99948056538744],[-0.0750334318793989,-3.07079280794529,-10.2475455112451],[1.09397281454368,-5.2922055913488,2.29320986996012],[-2.41646869647418,4.61584244508108,-6.5632924365117],[-6.3217400769577,7.00710796533556,8.50743548275661],[-2.63989207652455,3.93535134355579,-6.66757504897242],[-6.01770938657311,8.50884122388629,7.72036585397746],[3.53596782340114,10.7604667431446,-2.25944729576486],[-3.52378275097661,-4.3935406339516,-1.71948404194442],[3.3286162970934,4.70647692220494,8.58923784755849],[4.31226630523092,-2.56806874193378,-6.87314272556499],[0.410826625824381,-8.65350771970219,0.91656681033477],[1.96196603398105,5.35147931524384,8.66350897117327],[-0.756323541709201,6.18052345369878,-8.53617204411069],[-3.77740454628251,-2.9354388524408,-7.37214647865852],[1.48555063270635,-9.43565326433004,1.56728055472792],[7.17830042173559,-1.94222803997998,-10.221600417837],[9.25003662210431,-3.6881645689794,-4.54042489931048],[-9.61008075551396,-1.47000457053498,-4.01018761178045],[-1.14854544102234,9.30516039403214,2.35864552785457],[3.12332066937411,0.0364850877009786,-12.504321106434],[3.85371984048979,5.79259259707135,8.06690252509515],[9.00123872103559,-2.18811161599331,-3.160563158219],[0.851003587337862,-5.85412818795396,2.50061853970946],[3.75853094570493,-8.6789724848319,0.0513301290734061],[-0.489522912655912,-6.78368808651154,1.81203676514926],[4.33396278839536,0.0328138298323081,-3.29314254403459],[-0.057725818393031,-8.55183938500024,0.461618342466981],[2.69555491241685,-8.28115519140849,0.30708346974112],[1.31873350572457,-7.72220682320074,3.04551740333381],[1.23798367920887,1.76277229611397,-9.62602912939533],[3.66442598115323,4.7372525889304,8.91832759740808],[1.82178350483829,5.73717533826068,8.52943252823938],[0.299196819979264,-3.09369446146214,11.17368002234],[-2.90263149302734,0.385258992729456,5.53298445035769],[9.94484672843926,2.32358657930271,-1.94302927008783],[3.59164559789985,-9.56871297047653,-0.0615412513186808],[-9.73749393609612,-0.0626277772365254,-5.16883309873321],[3.15404198427997,10.8225258898328,-1.10807788787994],[-2.319593745752,9.66027188780065,-5.81394731401198],[1.72858853601807,6.41684207513996,7.20012147071798],[-2.76911350669982,-4.95672596102371,-7.13022518810529],[-2.91754275659989,7.11450075894278,-0.704291486425437],[-4.54615358200406,-5.77437426204143,-10.1026236935644],[4.27529320578368,-8.87905952257866,-0.250283174097105],[-2.54443242901024,7.10629541943584,8.6559692444916],[2.10770074941004,-4.88969259564305,2.72129886917506],[0.861923056048921,7.42516849506062,-6.33159741300826],[-2.51315490581997,-2.9077025312246,-6.10134028773556],[-2.52473248663005,-3.61832879063343,6.58133978003866],[0.939795196768806,-5.94431664930695,1.23077329380482],[2.44804620216522,6.41654038200356,8.22231401586691],[0.554514857933055,-4.70176677435802,10.9961307363056],[-5.95661110312112,6.85569025855972,8.78881794357179],[-3.669385676385,1.16037664439913,2.61576619649323],[1.1481068782333,-9.06954367515544,1.14545479679212],[-2.16924407843734,-3.04675807160831,0.261941495621213],[2.69798020205963,-9.51836044468322,0.971900550193216],[-0.768882345553693,8.49211220474209,-7.11972765170474],[0.193612350981019,-2.5983377684963,-0.866740016772078],[-2.09965454227283,3.57889671189497,1.81983953411592],[-4.07975254868115,-5.64468048469026,-9.61564161580359],[2.24110089403555,-0.0821584532432045,3.60080622849901],[-2.72890583434811,4.82610550148229,-7.10551751773226],[-4.69176017920311,-6.76705790584069,-2.83743160065681],[-5.13483399155263,-6.49685363029725,-1.53126061938393],[-3.07946660410875,-2.52000680824098,-3.18061239302111],[10.0130763027771,-4.78718302738584,-5.31200075309915],[-6.06997756363571,11.2599913442703,-4.44661535813052],[3.92597980600458,5.70710048764892,7.13231555409157],[-2.51026412279021,-5.34097874318727,-8.05335048065892],[-6.36261614465395,8.63525252112874,-4.18792524442552],[2.22959957165514,-2.74210851509282,-7.18713788115875],[3.70543812665648,6.14088782175958,8.67259481804073],[0.842904900345693,-3.78190169768879,12.4005657454913],[1.57715507104161,-1.18219402458632,-6.82993643437466],[0.750301852837885,-8.6982788213405,2.36222849538327],[0.131245899249614,-8.65131108767062,0.616190565426764],[-3.75882781224465,12.0348090622475,3.74675391510221],[2.07314668093068,-3.23094690722315,12.6040368281956],[0.0489846761461405,0.12953418183481,-2.02735585766937],[10.4149704078046,3.08114400966337,-2.70699036693048],[1.80650531159637,3.44773208120286,-6.6649240727747],[1.89211424761761,-7.50455668498779,-0.493240533426605],[1.4639176668709,3.20563513317591,-3.9449368231327],[2.03190786726499,3.63451172682436,-6.75618361601657],[-6.01905709907569,-5.75018268105696,7.80068952994938],[-2.90276258415072,-0.617167870440644,3.73864430438301],[3.0612393021289,2.65973343982862,3.01312746615462],[-4.95503349849727,-0.547374619143413,-0.363794907299265],[2.087251208208,-4.43257774526235,1.70459233285005],[0.763200304323607,-3.57031645775729,8.74167495026658],[-4.79505993186581,-2.75478369359316,-3.19850996458904],[-2.61390261990454,7.18161180092099,-1.24244757079884],[-5.86731496542057,-3.55489016869669,-1.88732368339499],[-3.81698401968294,-3.21958246324543,-7.61741729596954],[-0.933482039664908,-8.06802124560528,-6.16950507799404],[2.41761262833948,-1.94471133177663,-7.48127177890214],[1.80764832607527,6.30177883517887,9.41594961386729],[0.793077018530124,2.21335821075156,-3.36616234110669],[9.03577853025708,-4.17311102135196,-2.62336834816212],[-9.10239701531389,-1.53762019897345,-4.21194565175996],[-3.18418705248522,6.24389489868152,0.0214359106172195],[-3.68002023172562,4.70281816445058,0.887945500978524],[-1.52486040257555,-8.05885947982805,-5.74600575169255],[-3.59314768564251,6.84780586993261,8.487675603218],[0.860879331744981,2.07087549022219,-2.78632643666742],[-2.79355138471993,4.80725543796542,-2.56862947032331],[3.34532173941922,-9.52394706570206,-0.172691813330814],[2.09580543212859,3.68244867208324,-6.38203948663985],[-2.88278156601508,10.9678709944891,3.22630383523164],[0.653727127101913,-2.9214083979922,-11.7205193867626],[-3.25227558053031,0.0194931958752111,5.48564402104461],[-3.90550485632724,9.07341119548824,-7.00713951722269],[1.30649724252419,-0.938317966349834,-6.32948443134535],[-4.33321576826309,0.0788657400739941,3.1479288887754],[3.19553632091005,5.45114742630886,7.4817494789076],[-3.68104462589905,-0.39257925624978,-1.73631369811742],[2.17083303334286,-4.61598443103428,10.6994756454407],[-0.345947311323924,3.34372003327979,-8.8347180977399],[2.06009126783921,-4.94466188970072,2.31291926087498],[-2.81977233037524,-3.94598271138909,-1.37138456941476],[-1.1984987361886,-1.28524967890875,0.516869230461267],[-5.91642965786007,-3.01167536323285,-5.07273596269101],[-5.76621604479339,3.14211751599908,-6.60940927800238],[8.8049970515386,4.81629599527769,-1.31097273835474],[0.67593903162611,0.430111625896947,-2.97460939974131],[-2.50774470354709,0.591356630644982,3.83466419442119],[1.52072489965508,6.44235524044876,-11.4594503616382],[-4.03939801882331,4.52858654310654,0.725100883404574],[-1.75201952193205,-6.40135277097888,-0.876287713243791],[2.34739243070859,4.90414645772926,8.32110012170495],[-2.85949601378819,4.86075935973205,-6.91717932339209],[-1.93967249056195,-3.32736582105726,-0.642685416973372],[2.10832131543822,-5.63782232924698,2.59229749850961],[-3.08993360907782,-3.80650662812453,-8.96668622450289],[0.582434395793399,-5.92771335574336,3.15153047370008],[5.54642410336247,2.92348764751376,2.10912848294034],[1.55314068473525,-5.60056033993163,4.71659000909633],[1.07079679817948,-8.63614438531056,1.55058697192784],[-6.09231636199499,3.66104526437435,-4.80438483523823],[-4.6043322361912,1.61445804765545,-4.58408803264499],[-9.33074551627028,-1.97944131664072,-3.88625427949369],[2.09004306075058,3.50790813182484,8.06439399288642],[2.11069464790041,-7.81562851138642,2.42925147426085],[-0.110113849280279,0.616074600473009,3.09155099505516],[7.86254642678517,2.08070247378979,-1.72486345632801],[2.79919932168449,3.22224860451477,1.16472462638145],[-5.51687993855365,1.54799574093015,4.79131075508421],[-2.78793212743253,0.445118689689058,3.04908090910663],[3.75122780611813,4.4213088218587,8.49263058188375],[3.27602756900469,11.0458256072859,-2.38155525775127],[1.68920796102268,-2.98632459574119,10.9060787408783],[4.0941784964815,2.21601292356005,-10.1851690796573],[-0.0879935314642353,-6.71328857135145,-6.00253377419453],[-9.39407938575662,0.0895230620534189,-5.22808372446266],[-2.95263606303625,0.514808450429807,4.20788721328394],[2.40762291691153,6.45887736950892,-11.7666199041667],[-4.4153854925087,-2.90959789224018,-2.80166276376555],[-2.70943078853699,-3.69798027230747,6.48418918414288],[-1.95800176701815,-4.34691746975194,1.88567405722563],[1.53560964404908,-5.29109254652048,10.7976600282555],[-4.44339987235209,1.2670339921345,4.25383330478975],[3.53975229538263,4.42138727033981,8.69489449871704],[2.78974607115341,-3.74327252606735,-10.8773683118813],[3.39863886805485,4.3701605014888,8.68328093437092],[2.1367070675883,4.83148546757212,7.81465073674822],[-0.0604082182188802,-1.21259999699174,-11.1127933685309],[-0.0426511332471647,-2.91849814242615,-9.79110463958746],[3.41903080275602,-4.28181180902756,-5.05776160499803],[3.49233452402848,-8.16907369191257,-1.80839808813993],[2.29958518140194,10.7331501348261,-3.22671796572271],[1.41324259916056,5.78868026263704,7.97078205300684],[2.24463330306175,-10.3271573298254,-0.220095523141005],[3.94966284010476,10.4438443674972,-1.03881344615835],[-0.993392173704111,-8.01423590098547,-5.97384590192903],[3.19843675054581,12.1608143232455,-3.30851102442895],[-5.11000362195736,-0.705162415268467,2.33347836212349],[1.78736436841792,5.47048138434757,7.68680110600251],[-4.03965392880063,0.856615015085281,-3.61970595681561],[-3.80287430906366,1.08540484732715,2.95621077137087],[-5.33846409145832,8.09122817717384,8.34297546276978],[1.90381392370843,-4.48984835717323,1.63762724261021],[5.22174427095965,1.52458776129285,5.22828168360345],[9.69759850621488,4.53765424263593,-1.61936997686059],[-4.36303306880584,-6.22524303931303,-2.73307707788588],[-0.731838558730972,6.07350180241334,8.67621603143857],[2.97283875806051,11.2555876280146,-1.96197273116295],[-6.2749868734254,6.78610752214323,8.40524257209082],[3.55032136502918,-5.2657499694453,-0.978001314467608],[3.70026574245343,5.99242933922993,8.15618537181127],[2.83510449753989,4.44004130856862,7.73998903553869],[2.74463708575153,-3.35813265102332,-10.8882729164315],[-5.39070015760957,1.40792468288517,3.64846271797448],[1.47959636344066,-1.38894531609758,-6.66898928664311],[-4.33570318451162,1.6689356698918,4.76152554371254],[-2.44077530957986,6.7889360484364,-1.49206738946058],[-3.30578369606919,6.11971337150214,0.706047108416776],[-7.27692585442077,0.656049282022977,-7.62431316636563],[-4.47981501562762,-1.08821378404005,2.86119581688838],[-1.21776863503988,6.47075662643464,9.0902478577032],[-6.5202823064156,2.97240089704796,-4.76460479769173],[2.35239498603697,-4.99417489090906,-0.356927603781136],[1.07251181818697,-6.43181151523254,1.55752811799429],[-6.0591333645327,3.7548218861157,-5.42040720346464],[3.2234772681923,-6.9520600291787,-1.71910877408086],[1.76984313045574,4.28344031331825,7.87401622600366],[-4.71628413480513,-6.25937125171176,7.93988264842476],[8.6029134620276,-3.8008799911741,-1.61877126809001],[-9.28274406576043,-1.66181389699226,-3.33579173401087],[1.55001329072036,5.74509364300223,8.86484536316746],[-5.2875621692367,-0.660765593229211,-0.693753479496804],[2.34756557349944,-9.95974447114761,1.68102694962906],[0.790824094697255,-4.50402877733619,-5.39088291455617],[-4.38919928443619,-5.30499099673923,-1.23765744292087],[2.18419314572877,7.01887116042596,8.54328408373989],[2.02420110866502,6.3519467525771,9.4034656209573],[-3.69602119701873,2.83284791802967,-6.96956408045693],[-7.09307676658064,2.58357450520838,-4.50582572337148],[3.79921689671538,0.697744695216522,-9.13367694443398],[1.461584542927,-4.51466312065614,10.2639947771104],[-5.0575059824497,-0.727954253190505,-0.674137650714703],[1.47464455139605,0.0147715213716386,3.18799001688402],[2.71725470129838,3.55930828451881,8.11006819322659],[-7.60546346570248,-5.86998003846204,-0.464716626089811],[-0.606480948379377,-2.60859567994137,10.1170211460367],[2.5726331524934,-1.55751396420654,-7.58948785843956],[0.0412117144309458,-7.36708933068299,1.24028327413892],[-5.36708019709583,3.38931538172908,-6.51120791872831],[1.64370574878199,0.972572138659169,3.62008383288696],[2.44597036674821,-9.71326520474208,-0.0915290830916036],[-5.04579926907171,-0.118022837105754,0.04077836232676],[-4.37974872844991,-5.91761488819326,-9.60869639135134],[11.2429515851388,-0.231093194522828,0.511227629078385],[0.98670537646137,-2.68268260089083,-11.5325157388592],[3.35651479608371,3.57370948819191,8.20547898459245],[-2.56129091496493,-2.87102244140396,-0.240264884022997],[1.8426119496199,-5.16843693661296,2.07820154827071],[-0.238463255417145,-5.80409789473824,2.59000748424371],[1.86895056361213,6.26095879599675,9.18027564916866],[-4.70060391079422,9.35968785312943,-7.54671231255585],[3.46196282589304,11.7398784098782,-2.06979946306909],[-0.403286661887517,-6.01825674235238,2.22271998242604],[0.940899623619178,2.8300161847293,-3.6671859657893],[3.32986124201322,-6.94762147572609,-1.35497280801484],[-9.18330525520471,1.04075781938935,-6.03266672431204],[0.392523888610351,-4.00980131383906,10.8848356598406],[-5.47453100544633,-0.844033897989871,-0.510648386232035],[-4.6456005169552,7.33044092061576,8.50465020604009],[2.27695312403255,-4.99409596371469,-0.470597991369063],[1.69609292144259,-3.47562814220387,12.7061130626231],[-5.67175191689315,-1.44224204627422,-0.6197436936371],[-4.98423713774021,0.980093349880051,4.26037496671665],[0.782792666217707,3.03749633189618,-7.06387853652048],[3.40638511536756,-5.08353301805895,-5.47245072975431],[-5.89223099250777,-6.23226886137843,-0.388248878998124],[4.23907676994406,-0.751393375385176,-6.36014696929642],[-5.27732416293027,7.16697481755836,8.20487182067588],[-0.78941636994293,1.52257760822977,-2.16675574851519],[-6.52280054814145,-7.05238156872594,1.41480267273948],[-0.0305672614863234,-7.41980251708647,-5.91756056970534],[-6.3504707504071,-3.16387346496716,-4.75355555534631],[-7.58763069544665,-0.0924818474540756,-8.82750982916739],[-3.07042043290335,7.1030990149219,-1.09082610492736],[3.74801370786486,3.54009768855277,0.732287185271186],[1.29498987023931,-3.59851598946436,10.8070699889975],[4.14023597503511,11.0168233030944,-2.1117873107175],[2.82855193548873,-8.71136490788633,-2.09688764028942],[2.25973256886195,-7.76770248606465,-10.7627190781729],[2.01268190479563,4.71609166155495,7.4912134449322],[-0.609962997685814,-7.53831580020657,0.968340574539969],[-7.85378313839169,-6.57740576140377,1.07659324672064],[-4.21469471310367,5.16324210303366,0.585215770431736],[-1.37759122138741,10.2303553374301,3.39874937491674],[-2.81084832860788,4.21876531114857,-6.83179728043938],[2.11629936448582,4.7471593065482,8.08997744233878],[-2.1551127918245,5.05877136741121,-7.41702703957152],[-6.7081410236042,2.40930756089031,-5.55889979226145],[0.957456996594766,1.46344117415291,-6.27885242468632],[2.24277207183285,3.10351752786068,0.715824936755805],[2.00484553617419,-7.20309247714784,1.84933484409852],[-1.8078056541072,-5.11258117884004,1.66682549031962],[-1.77238669685754,-7.24507501933558,1.31674884651021],[9.96370866282282,1.88409670348782,-1.73076713569019],[1.3687352879439,-2.04175464910203,-10.4293892907243],[3.5036067739942,-3.42628632866277,-10.316488784409],[2.16047804566595,-10.2136585189666,1.56844212264788],[-1.41118730176156,3.63640626557404,-2.61514296167702],[-4.19657717964573,2.2729354481399,4.76703196614447],[3.45320777663829,-9.30546158096812,-2.14884730781255],[1.40203297983539,0.13546860329907,3.60907955510976],[-0.108772644146385,-3.03407138746864,2.36322760720723],[-3.17084665936931,5.50056208507873,-0.322038821468852],[3.03049425865608,-1.79654015559461,-4.58171777148729],[-8.95753384817184,-1.31058530445228,-3.62769384436485],[-5.27857731579432,-6.39160268640572,-2.37709927053081],[-1.44064644406623,0.50277317425376,3.16474883710822],[2.26896158005457,-3.62798012621034,10.8302922670263],[3.81751828802019,6.49237006100215,8.12135018620716],[3.83218087240697,0.502303557229376,-8.74478975878149],[1.68944713644044,-4.49620639539362,0.597729329302587],[-4.23873109372642,5.1550808773694,0.141089468125886],[8.24801148245885,4.2858807528598,-0.429073447718308],[2.27921127629474,-8.68929422404749,-0.430841881027641],[-6.56480422841916,2.90856031688572,-6.09587922046529],[3.43326995418888,-9.7396375172536,-0.0705142057139774],[0.248683445295526,-8.20498339913516,0.322633278549254],[3.56959937118189,-1.1934588537773,-4.11189777307491],[4.65279883996449,-2.59296683820558,-6.89395003314159],[-6.52506560166379,2.30562193955304,-6.12991618440347],[-4.55034856077689,1.0186593150782,4.23240107531822],[-4.6754514560305,-5.90733454031707,-9.7879060452033],[4.75958699421215,-6.0852874548591,-1.69841238855104],[1.72772027717734,-3.19489747780162,11.9135380510701],[2.55399160837447,10.9777303315762,-1.7981685244089],[0.019836815292094,4.31541259579197,-3.86988211382515],[0.915158191718423,-4.57765390448519,-5.10555414279391],[-5.31525431397534,-6.13471821484104,-1.96153454011969],[3.80590746581177,5.40676485685009,6.66979347002729],[3.61562479560866,3.32401384612578,1.12299005830861],[-1.12619040152219,4.52316622000437,0.0229325476713727],[-0.650789737516089,-2.55558785708704,2.14540451517461],[-5.5811723921921,-6.5767169903312,7.3070737936655],[-0.210140829724762,0.509146728447559,-7.38313294581697],[-2.5636724052117,-0.256192047764852,-0.383537728572881],[2.59600519101717,-0.817047540376867,-7.34613132201552],[-4.61188021016039,-0.78643433004164,3.49162348388273],[3.60517624743251,-4.79569155904732,-0.935306361374655],[-3.06201628830063,10.986526978704,3.48921005436303],[-4.68364151541198,8.01852587284545,8.63474258058053],[-7.42424371753411,-5.91327530166344,-0.247951580874222],[-2.71933642344107,3.81929614982305,-6.27968457931305],[1.70138110721502,-5.77877134143266,3.73668158695275],[9.51030369909891,4.71228612577175,-1.41812720627759],[1.59752794052152,-4.04174579511043,-0.179677130054982],[-5.02967808003878,-1.44277809722916,-0.306367409840157],[-4.54609940381982,0.917414600416418,3.47179689185502],[-3.43832567190821,5.84153241306546,-0.425079434863595],[2.93839691238152,10.8799583027975,-1.61497729878439],[-1.77183903288271,0.169255604728945,-2.71379084545035],[-7.54894637835693,-6.11729782595032,0.530534037372926],[-2.93139740974484,-0.514097815999843,3.1180293586746],[0.0813264269823168,-7.50474246361813,0.674060608323377],[2.93940817622544,-5.66815373711769,-6.20075133293991],[0.934866112521526,-4.51597854816805,3.9057835951766],[2.42137585411309,-2.17114129910975,-6.68653454584608],[3.05934686578509,-5.79279685512713,-2.28888604192054],[0.724203464613076,-7.1632954828133,2.05924664657697],[2.39158398192835,6.22508807035564,8.93360350334324],[-7.14371149644453,-5.49803221580746,7.28407666487421],[5.04131433677945,1.9806859322172,4.29072670698707],[2.90629053883949,3.2649351035507,0.647872512145004],[3.46707567601634,-2.7519143889687,-7.13705825219999],[-9.62400885440378,-1.20991090560402,-4.20603128210807],[0.386527540287561,-3.87456513138647,11.4920867624496],[1.39385359769127,4.67582733013021,8.32092650431576],[-4.75084185942436,-0.452144245863986,-0.618968671785595],[-1.16063825711365,1.85898626667716,-1.98830981595999],[-4.43357270605084,7.92702659577958,8.76928987279864],[0.181651365858059,-7.45036647162069,0.982180394859678],[1.26904812448197,-9.3939619165178,0.352449189714383],[-2.66230482881758,-4.00032533206193,-2.20335859832127],[-4.30247363833435,6.48668197371869,8.51403158159018],[-2.44679792515164,-2.53891214657484,-3.33016554093102],[-3.97731393401147,5.52188979577166,0.197711934337231],[4.5706111413692,2.57911024509223,3.61734478878008],[3.34391733981022,-5.44680715275577,-4.84969152909396],[0.866600066322321,-6.91394516318671,1.13029076345877],[3.2866602977795,1.61450379037659,-10.0757641847825],[3.81329053998942,10.8725773635442,-1.56232773041416],[1.95171778709543,-6.99823365830949,3.44048482821405],[-4.53350305913129,6.21756350025476,8.81927887905869],[-5.03449315146596,4.00621709681479,-6.6367542417693],[-4.33782970384882,8.40935685489429,-7.12878198552526],[-7.59230345662916,-5.59413639248202,6.90026782019075],[-2.7969413367212,0.233888361132541,5.55728245218003],[-3.85288573742363,0.466921172168884,4.66486002711984],[3.25583277911104,6.24335889978109,8.3632583061693],[-5.24241130858827,0.26628887983426,-1.5978824438759],[3.1679715691469,-3.35496277913681,-10.6052400749553],[1.31390974718705,-9.39935206365206,2.26585073510779],[-2.41116433688498,7.10799340162574,-1.05605741900393],[-6.24633807524646,2.41588878853637,-5.33413110216467],[-3.66276483124483,12.439205121101,3.81895848021173],[-6.55167811563201,-1.91105418771547,3.79966485573212],[-4.55199193883411,7.47443639344443,7.92888603983332],[1.01675668846738,3.06822797777916,-7.02686835796144],[3.93541340221518,-4.74013882037167,-1.68619992706331],[2.96657627494849,6.47600203872021,7.610376251501],[2.91217810590772,-5.00251728597845,11.2036906585953],[-0.371741052631754,-7.43486226733986,-5.70447147032329],[-6.71156124159365,8.19311512106518,-3.82745789742943],[1.93262963189078,5.51862083544692,8.79488370967447],[-3.30498035661321,-3.47829955821094,-3.19398228386336],[1.44431188057943,-4.52698514063616,2.32105218613768],[-6.90192942460244,-7.00692281763331,1.32199859512658],[7.54220481392702,5.53286081642724,1.75336894016158],[-4.87007135793513,9.79009838668154,-4.33129173577443],[4.30893168260932,-5.57548195109468,-1.2377913060564],[-0.620696137595294,6.55395747342055,-8.42239509326382],[2.680550744143,-9.84141866142186,-1.10112306092669],[2.71118562597274,-5.93005723826359,3.56264090033258],[-4.65778163328789,-6.40101216872316,-2.02520920422657],[1.58112092304619,-7.17401793772271,3.57449696981025],[1.94208050770691,-5.22122721335615,-0.0652573543079855],[0.019447330809078,-2.76463799596555,10.7766654743078],[-4.6402361475934,-1.10608821799451,2.84000168629161],[5.99288629093684,-0.713520657053432,-10.1651600200394],[2.36382154572732,-9.36123563512442,2.10500993152811],[0.432951907647008,-6.4422644092389,-5.68121037030175],[8.85626436255041,-2.08711570647867,-3.65619348091818],[-5.3891970570874,7.30281364283104,9.15584119049486],[-6.23659714391332,7.71813094431264,8.10195414259689],[1.71893956918194,-2.1069132178795,-6.85137836897737],[3.78927908068066,-6.81948985583672,-1.1823760504327],[-4.60876487551685,-1.92022995973424,-4.53899918978669],[5.09735823967317,1.37687919932522,6.21469094950305],[4.39953234626658,1.98129388848243,-9.16648461927452],[1.92990714954236,-7.52510602431212,3.90110469648997],[1.48568721799607,-0.80926673491497,-4.58764926994653],[2.02259167909242,-5.26159817104977,10.8032827494808],[1.94474299800204,-4.34262150514643,-0.451274429378292],[0.704227152487119,5.40170760618472,7.62624246496299],[-3.08770542478074,0.388493346029963,2.8158724864218],[1.61299693513479,-9.52717133378433,1.82449863171935],[-1.09047375113453,0.782563288423931,4.28936207167364],[0.828921570065876,-8.00524089278657,2.25616657812039],[2.45194915002752,-1.42925349280267,-7.60877171449781],[0.697911807521637,-9.14346916976525,1.69869354620862],[-3.92997620532067,-4.87302369309668,-11.4305945074946],[-2.39510637550062,6.35947169481846,-0.433794110130735],[3.9817099279041,4.67460019472359,8.44639157072185],[1.61241918499192,-7.82755187186362,-10.5966938122413],[8.97151236730782,2.76113807074105,-2.0299396882711],[2.16742500282751,6.56574078045386,7.79868755641171],[0.524883533041853,0.563967107957688,2.87259341027356],[-5.93558466170089,-2.676612392843,-5.00899773400154],[1.81251818393439,5.38951242583956,8.81740617242389],[1.31132572003932,-4.57784417911103,-4.98741983109918],[0.867953466784019,-6.97389945059658,1.64910823613909],[-1.49775124355659,-6.78085002879031,-1.2289748534454],[9.2757987666401,3.35990870884869,-0.703253533773478],[-2.89154981105011,7.28599117444349,-0.833978067976048],[0.996818663735707,-5.3466190047695,10.9160333886365],[9.03312718773599,-0.164502205545087,-1.12274668395961],[-1.10384902144997,-7.09029490657622,-0.483819895948369],[3.26733813075779,-3.88154369994898,11.7108789078024],[0.783599092988986,-4.55885204543724,-5.50074295013454],[-3.13629503963422,6.83294358614132,-0.86472803715819],[0.790110268656927,-5.7443991624618,3.32577698401982],[1.77045642982131,-2.56978960302132,11.0475537880647],[-9.65183816865033,1.08129205798441,-6.32562661598463],[-4.72470532581889,-1.35303335645596,1.28158177600608],[-0.0975186412999958,-4.83108324118797,3.17464688618175],[3.3611893429004,4.96142090102598,9.21808212446063],[-5.11112272519663,0.0415471365040662,4.89596124987939],[-4.65272425467758,6.96099106455753,8.46054003989095],[2.87050018279294,-10.4172379812301,-0.0227420121607699],[-4.30188847030109,4.29451004961809,-6.41055347286883],[0.0703383869014346,-5.37011709710755,3.64393810800928],[10.75003575462,1.42312818416013,-0.813232977904228],[-0.557958971611919,-7.74856476282773,-5.57622453321993],[1.63262632099579,-6.90616495351188,4.61413633079238],[1.24522353277559,-8.90403361231076,0.149861683821553],[-0.352541549133694,8.85714804525647,-7.11593272177344],[-0.530707185214775,-1.34377855295711,-13.89612725074],[0.598891413223909,-0.32365045746382,-12.8501229767707],[3.34314454076127,-5.74108724304952,-5.83018361038275],[1.76524376454242,-6.06360274735387,3.55673774698497],[-2.52550272048181,0.742031595382195,-1.82112650034099],[-7.59889238427673,-0.752284441079383,-4.3812965305115],[-7.80284788681908,-6.87821707019973,1.43905643843825],[10.3766289896771,3.49026412476794,-1.46604454780825],[-4.05864764039427,5.62662469133067,0.183823660902809],[1.77824965935352,1.19403966502969,-10.2868500787658],[0.646549680613083,-2.53847156092019,13.3264142579335],[-2.3441278741672,-0.922339754125866,-5.36765697914015],[2.28519268462896,-4.61800589221627,10.8893835687901],[3.22916506294201,-3.45208124737622,-10.5323827047473],[1.51233609137909,-8.42550495318999,1.53805514148982],[-3.47945474274801,6.64014708382403,-1.02079226616526],[-2.10493995980128,-4.36954951658654,0.00675333480537732],[1.11753005845261,12.2265866074045,-1.59397876052512],[-3.27110003748949,0.659979580335309,3.62857133715246],[1.34463892923204,2.8229927589732,-3.44658882038457],[-6.30045563386403,8.0020015488984,8.00513162548739],[-3.7177021497925,-3.99044686988436,-8.83656996914077],[-2.5639456505381,4.20141810719143,0.432738474256501],[-4.51564987866282,0.772895106066842,3.04356315110935],[3.26868214999107,10.4856293756101,-2.96869515500107],[1.09749517145301,-9.00001923641933,2.42923046050983],[-4.37463741373764,-5.8737348107829,-2.69081834179026],[-5.27494678242653,6.90308262171315,8.95639837682856],[1.8931966143627,6.57720547927416,-11.3742124860778],[3.72830968736811,11.2427649218256,-2.05290603399627],[-3.75509753813612,12.3574686141457,4.17375139231025],[2.05114734864403,-3.91177317627611,12.2713666863854],[0.436215862194893,0.212799510103966,-2.71802308567573],[1.17906715370269,-5.40565513425408,4.23378175103826],[2.79200068875642,-5.03344708881673,-1.71204738338885],[3.34534902565861,3.48003160183089,1.32352903458043],[-7.27137981399021,-5.51577313115783,1.48914782135108],[1.75667308579253,12.4066722313409,-1.37607155111905],[2.46034762268431,5.78242368695543,7.69543423761932],[-3.36396547336724,-1.65954280925383,-8.37163361282901],[8.62701092246944,4.81939511909516,-1.26746190253847],[0.404900175297511,1.70132133423604,-6.45325255878897],[9.46685248091971,-4.74483936539763,-5.90123605136797],[9.3847068234804,2.62216775585224,0.0654016225669928],[2.03448895942228,-2.71007770972546,-7.82827155289339],[2.11680886072758,-9.15660400273729,0.288105367085889],[-3.18066552947918,-3.03611494640333,-7.54585083605136],[1.46605468675719,12.1573854259537,-1.65438428592528],[3.27446168907675,-7.12852206536255,-2.07649436883622],[1.36750872481355,-8.07441632365909,0.203400481081564],[-3.77179868347332,-1.27485307153757,2.00325800820981],[-2.85050289835712,0.559686499812139,4.88066898545099],[1.75099117093868,-4.19059583662791,12.0153779031968],[7.81882670330264,-1.92474191645844,-10.855596219145],[1.14363166296653,-8.72451548481257,2.37491501402053],[-3.93699373826673,4.48705998974817,-6.84987598530203],[1.20143305610354,-4.76529066950456,-4.93532941023396],[-1.91314833673982,-1.11637117188429,1.01556123428554],[4.69547828255341,-1.3313807702159,-6.63219163969887],[1.66773267908494,-7.24530765228018,-0.124143125009415],[4.79444729819609,-2.45254953258898,-6.84683686867515],[-4.57055756651831,-2.17507574462924,-0.792591332006922],[3.53889200687422,6.64068638374934,7.53641061128249],[-8.81768223591632,-1.49353917491046,-3.80084503263423],[2.44530033807877,11.2674520324498,-2.02583201191113],[2.56365063957159,-4.28063065022149,10.4785564055028],[-9.42268565915233,0.341661797412207,-5.98071802033184],[-4.04658532720955,1.49512571643058,4.29619027695128],[-5.61984823587997,3.27952699799626,-6.21782903439946],[3.28203626068075,-5.78857161147654,-4.62137402123144],[1.38281830447236,11.6271217379426,-1.92457740626504],[2.48116153846779,11.4135385828983,-1.90746233872868],[-4.34139258125238,-4.19539174624676,-1.35678679527823],[1.10448134321583,3.0474310261579,-6.78800382074866],[2.99789929352313,10.2006083937313,-1.90490055347807],[7.7459163951117,-1.791867492604,-10.878793184216],[1.67087346470381,11.030450002232,-2.45095147899044],[0.538056801060312,3.71778481944289,-6.75910776899402],[-5.22072853222038,1.64378986357808,3.60817814876293],[-9.49157006660869,-1.4740705720566,-3.55037802373121],[-1.48526088102704,3.08180529495556,-2.02748984314198],[1.1345067132685,-3.59688876660553,12.6402164064222],[-4.02512170323638,-4.96360839895849,-10.953153934883],[2.46324108950208,-9.54037899475505,-0.983682792348039],[2.95897939979712,-9.45144955288223,-0.826354653492827],[4.20109876472213,-2.97737545456877,-4.22116555486012],[4.00028926309818,4.33594487868787,8.74095046685798],[0.750965361402404,-5.0446426841867,3.42808410012586],[-5.23228815052191,7.31924617489387,9.05786654742876],[1.7348987834506,5.1640725056078,8.21912830600076],[2.98247639301352,-5.68462200557454,-4.48907058515738],[2.27898568945506,6.37784783319232,8.51164101187234],[-4.26097496341151,-0.0483780694563829,3.90251580202135],[1.84058630146453,-4.62253613515948,10.1793910236977],[-6.23654514698215,8.81249640862656,-4.97852167997759],[0.365829326649115,-2.88098078133733,-4.95918235239631],[-1.46480165937126,7.32261875143365,-7.17096126291283],[-5.69768747976238,2.77690446274035,-6.55941076275511],[-1.83286939308245,-2.25293939175027,9.44294566037111],[2.05496067907177,-5.47411996482856,-1.10154439773705],[-3.0645382763729,4.14503172854155,-7.34530191852492],[9.82701304004764,3.43521526375434,-1.59778319102608],[1.23252365525957,1.48948358369969,-9.40568294977773],[1.22694521630806,-2.35045618911999,-10.8048615866129],[3.73657295167724,-0.404431148442578,-2.63764006395475],[2.32823348489176,6.08928094202334,6.92148503028624],[0.203451089001377,-2.70592640535817,11.0190660612011],[1.71842459041494,3.13887562147258,-3.45092241581974],[9.97439707099706,2.79607413644066,-1.74711096708548],[11.9581965815924,5.46469115948156,-0.874320472827915],[-0.226201194231188,-3.69278610197915,-1.55746024262454],[0.0578116873545069,4.19848087393407,-3.12887993413172],[1.7547197623723,5.81312734066987,7.54023975047839],[2.59854270747026,6.03707688880722,7.55375446805334],[-4.3603098424722,-5.8539764847915,-2.0481152457606],[-7.69764692331517,-0.125609473584643,-8.63273175638416],[8.31874312468345,3.88671497743861,-2.68794322124198],[-2.0929461321937,4.05042176914738,-2.60503631007308],[3.41135944066753,5.85766760312274,8.13584194529847],[9.18978498775626,7.05076634685818,0.099844837501572],[-3.93806234882005,-3.59125474204033,-10.9686432442011],[9.27749665446893,-3.84499574776768,-4.18337708949168],[-4.59262129290649,2.52460445282753,4.69004577017035],[-4.76334799295216,-6.113637936742,-2.75183134932333],[3.24805732006916,11.4921554981923,-1.91199946283245],[8.36170324919185,4.66194944758336,-1.95249091607738],[1.27035339549116,-3.58231830249708,-2.73521676895973],[8.16618627888887,4.41727676534603,-1.89128108036302],[2.96435588608412,-5.65687256481328,-1.85265211126533],[5.02208365641542,1.3670182865141,5.83126482386083],[-9.6543385889989,1.01828407998149,-5.97656972047989],[-1.99455880259556,-6.25859283224387,-0.790451664004793],[1.4239725686539,6.2912236063427,7.24758737726596],[-2.10935287880592,-0.652363060235097,-4.47960927962342],[9.42320451398479,1.2605725995412,-1.36953369815024],[10.6762244309067,4.64798380864703,-0.817877994445257],[-2.26367994215398,6.14709228958983,-0.354323336588863],[10.7284328164125,1.43276119795106,-1.37288626849118],[-3.05302640830829,0.439980656089315,5.15120688956383],[-1.83583362329808,0.381006323864249,-3.08840433400592],[2.43198241641791,3.60721256864893,7.76807311799868],[-1.86749898180618,6.04072821363748,-2.09430951561516],[1.44641698783974,-2.64129022159541,12.5917908263586],[2.95593121816231,12.0609661746876,-2.73845088053309],[3.69225754316893,5.88850896244988,7.01926298119898],[-6.46987190587978,2.62155904558491,-6.07144703999667],[1.30914673616753,-8.2091618534603,3.15176183390108],[1.5875522929614,-1.24486848272046,-6.50826922717754],[1.91024026766891,-9.2138809918042,-1.15495356951282],[-5.36864191952568,9.28247460655811,-7.07236553533203],[3.12771291466786,6.52881680253124,7.66390714090994],[3.40400542895879,-5.69080536024416,-5.66475042748192],[-7.62738489346192,-1.14001546725302,-5.15456854542825],[0.65085901489416,-5.52215553887981,11.1383387509658],[-9.37147093798844,1.36336513515285,-6.26494472844635],[2.21775241785586,6.39160574037368,7.41892104156234],[2.50267716242403,-8.93644317030546,1.59110623838568],[1.11828827627611,-2.65258786426909,12.2689216084006],[-7.23327000898098,-6.53392251813042,1.75139412173088],[1.67846596662465,-3.63221842503093,12.1418232425017],[-4.7283877332044,-5.4589621198185,-2.11232114252505],[-9.06719925530932,-6.2766743129997,0.944899920609573],[1.87783130625321,11.3484237718237,-2.19884144205132],[1.0998757993737,-3.69188336366602,11.6657234859552],[2.49027144739447,5.9239556509011,7.34230708250736],[9.61286372139684,3.85123921780628,-2.33937449542513],[-1.47968611455276,1.65552676807513,2.41926033667046],[-2.8829118496708,6.58669118420039,-1.45487064583356],[3.87900001809053,-2.85838898617804,-6.70029699416035],[1.67682400670041,-8.17589826585877,-10.8132380717188],[1.87187922979976,-8.78136469083636,-1.25518002864014],[8.76192791003053,-3.73213683319587,-1.29972426262491],[0.995847812187016,-6.03426718651912,11.3274288552505],[-0.414964896843069,4.6185005905737,-0.857978495977136],[8.9464156101702,7.07169811777529,0.421152185407896],[-1.69685864961503,-3.6809106434033,-0.478175738063215],[2.56500182387585,11.1955631832587,-2.8934580698096],[1.58365416076917,-9.21545564006128,1.46679467840841],[-8.23466270282063,-6.08228283610652,0.0328947045188452],[0.374804696809282,-7.09127886390508,2.5745051728739],[8.84993496378547,-4.45131987487744,-1.61783155470395],[1.84394116606373,0.165420181365252,4.28644262419406],[-3.0740983521025,6.77647894984041,-0.054808466558708],[-1.37845077374262,6.29723964466121,8.69981011686109],[-4.62739142605188,5.80330214882065,-0.396227989512017],[3.0154243585988,-9.95464418214459,-0.949914378445252],[-2.50121177096675,11.6511302639197,3.47859105750555],[-3.95339696779871,2.28231107076132,4.37370604496419],[2.95453898979246,12.0000295424798,-0.951279880856393],[-2.96500950333105,6.05468557593161,-1.14289977029429],[0.798017338591954,2.83041626558038,-3.60484447586097],[1.60883573274321,6.16970328321929,7.78721095529868],[3.79955750899792,-7.3119918732539,-1.79410729094984],[1.08422234320848,-6.82951804051458,0.138278159268275],[0.619903307749113,1.25490462935593,-3.10992512744453],[6.62306941933631,4.90381113187721,0.23073254896308],[5.84427292058703,2.60430887015807,2.46051095867323],[-3.82368761393387,5.91157124228502,0.248010888415037],[0.994839401691027,-8.17019398855412,2.83119408977023],[3.06893675237272,6.19174748917269,7.26985449451367],[-4.46325184107124,7.10519084489557,8.61226527963841],[1.20712695667296,-0.763235818419288,-9.61956675646392],[3.47649993300366,-6.28148023430356,-0.608337807607004],[3.47928701732664,-6.02586136508411,-5.07574719050421],[2.68202933406577,-6.91268244544271,2.03250702809489],[-3.83886166687758,-3.29508792768545,-7.75741035827675],[0.717880842870974,-5.20090877267469,4.41819131531043],[-1.91203257629657,-0.229006342664216,-4.66323325262583],[4.26697807075272,-6.61336307745584,-1.75236025095042],[-3.55242798862517,5.60036425495764,-2.71077185229941],[1.17465942478546,2.14678776556766,-1.52875614330048],[2.29426102938513,4.59454068885482,7.78699374109525],[-3.84308756904468,-7.09895368839325,-2.45790407843691],[0.219906167467354,-3.39479743247569,-12.1254855604468],[1.97429682035573,4.79603351071265,7.42999682275557],[0.54363398024218,-7.75877763307245,1.56930584994458],[-1.91404272929365,-0.756020181217177,0.958089116277053],[1.9946270323838,-3.19732485741806,12.2605269918655],[-0.0949454274541686,0.209643614500208,3.11850111237991],[-2.99062000535748,4.42738076165752,-7.28640100590173],[10.267738941956,1.02124230404436,-1.11171073767913],[-0.755123172411222,1.3098608488774,-2.04592359903021],[-9.08709269132199,-1.15773201698576,-3.82375535279898],[-1.07908361752265,2.0969190115279,-2.24819628053739],[-3.35950729754172,0.22151585512192,5.17872262118584],[-2.75430049557308,5.32924570060868,0.0103584747537884],[1.29600183514938,-2.17909931847324,-10.651677062453],[-0.316962009444172,2.84313330050568,-8.30720771812194],[4.88791136750044,-1.19744013917245,-2.81858406466142],[-5.44398239848225,-3.64694045365097,-3.88530912090348],[-4.83129623523124,-5.92145986779847,-9.97303942034593],[-2.88678998067347,-1.16306355845904,-3.81938423346408],[2.94001395236021,-9.41457847645666,1.49668066830887],[-5.21670801699608,1.54987682707147,2.77596509834851],[-4.25031533037853,1.54804625125909,3.98396293503666],[1.55347664718621,-3.92571736289614,-1.5184937719783],[9.5943032036546,-4.80948404242093,-4.89706285061554],[-5.04780380912907,-0.535312682908633,4.55468083133397],[1.85474752231104,-8.50149863717822,3.53728510952136],[-4.37354439433577,2.4085117556023,5.18548714941972],[0.879877406499695,2.10703566505395,-2.55499239600835],[0.129597471349426,-5.5391041042621,11.1782958963912],[-0.293497396130302,-1.15844212659819,-11.2356322805809],[-8.67855243414095,-5.76231264878431,0.43797527992302],[-2.1990565542936,-4.64391808816499,-2.09693623181],[-7.48337084482612,-0.534708778116008,-5.41198882448557],[1.44651392172963,-6.3286536245189,-1.31066132728084],[10.0045785308255,1.13215290538234,-1.0218049987121],[9.8452220308819,-5.03437681725387,-4.88148834917439],[2.50819190093822,-3.62231053004361,-11.1721439656568],[-4.46953440766534,-6.27165844981583,-2.08867625435693],[-5.95683185335733,2.96569148403394,-6.57797719694292],[-0.156881399127923,-4.01906507950624,2.12472868085427],[1.36247401059245,-2.46989536317298,12.9964676596862],[-9.61428755956116,0.474211546528865,-5.82642024771793],[-2.85323980956002,-1.79602422495921,-4.46783669711069],[-5.6791233340731,-2.9222639355975,-5.22092431973939],[-0.784128637398966,0.396055093254458,-1.88370114776792],[-4.22257065153629,1.8679754701722,4.33143034057006],[1.62847193457394,4.02002889337918,-3.95360602575377],[-6.15130908599632,6.71084693599867,8.72756230299913],[1.22893909857117,11.9543291407761,-1.6771617050257],[4.02549975992581,5.18551890848602,9.08060028423394],[-0.997123685838871,1.07707528122019,-2.4502670069904],[-0.545298118565695,3.91241193361878,-3.21965204253871],[3.09001602608808,6.14008656133771,-11.6662071046974],[0.7244755182426,-4.77094345635538,2.78512145593406],[2.06377457932281,-10.377186850446,-0.414031498843478],[3.09477794992364,-0.589692245296084,-12.431444516195],[1.97608923486669,0.753635335260018,-6.95980135427372],[-6.54151982127201,3.41810248086189,-5.211625340095],[1.22472365675661,-5.70890467614415,4.84753852570445],[2.32921491765957,-7.85338537447364,3.51117025554828],[0.517388608861187,-3.55732272065294,-5.69384987168322],[3.9457861709985,-0.0761369912779113,-3.66878183564651],[1.08782616874192,-9.05388413514952,2.61147276963741],[2.19052585406099,10.000196579895,-2.00230750712346],[1.50776934582669,3.2586563763103,-3.55700773548529],[-4.20304252480185,-5.66072541088209,-2.84209081142489],[-5.27190539270745,9.01828375437385,-6.84638728846529],[10.9851078073533,1.14094548112235,-1.09331144701771],[-4.47804348106749,6.30339612811578,-0.0723884533515028],[-2.27386520515464,6.59410198164843,-1.03529389939182],[1.74541050960078,-9.38201194467861,2.23987940879482],[-4.75825868999662,2.55764317657873,5.41764219811789],[2.88629170327279,-2.88376997361883,-3.22411956689977],[1.52007723612354,-0.0234963101853152,3.11296360845691],[-4.84036599827812,-2.86370423729549,-3.51682599168494],[10.2463196816023,-1.98795971046368,-0.0356669480445296],[-3.54383958524306,7.01308774406824,-0.751504745982724],[-2.7564953410078,-3.71664154438068,-9.07890460724358],[-2.10928088733966,-0.456164649663015,0.261887096197375],[1.19596294566654,4.11330336831377,-4.47190109576374],[-1.97739858794449,4.29371163397002,0.825430251608721],[-6.16691160362777,-3.28061407539517,-1.72786839671981],[-6.36898423929421,3.12126242396756,-6.02774997063067],[-4.77288493866488,0.960427803410728,2.17912140885061],[-0.239447500534284,-0.351344099819161,-1.62087588344349],[9.84800085557043,3.00648355683218,-1.11468055708107],[-6.63103375755833,3.15972508168491,-4.09611444099095],[0.243232119518373,-7.63436675549745,1.34392800538982],[7.15443861012622,5.46764946644991,-0.385152149113625],[-3.12484747904228,0.68445995504002,3.19146395691566],[-5.41003178796362,-2.57954524781928,-9.10440663606919],[9.25409219940166,3.38231958172113,-0.947837669213412],[-3.1240008433962,-0.471399332637822,3.22362967543449],[9.08155070926017,6.98653273407521,0.0576617889557796],[-0.122761818464656,-2.55563368105956,1.8207702864193],[3.47923512859874,0.150385503962985,-9.74487752417688],[3.57933852566404,-9.07643329092136,-1.40210213211542],[4.2353272445763,3.45387438035267,2.99604165002207],[2.07423844719157,-9.50896567212873,2.30626399034742],[1.62385790161489,3.3852269239269,-6.55263735971646],[4.22553591544957,1.92345944582135,-9.84098168418031],[1.56554310599766,-7.80680849712274,-10.6028527337219],[-8.49344849198856,-1.20883781693331,-5.04296958765665],[1.22414809981424,11.5021621736503,-1.95192951910238],[-4.49426106988714,0.44003512447919,5.78819909299419],[-4.48508944961812,1.27151455966241,2.78758347167223],[0.58928164806793,7.1291201332371,-6.13143850291083],[-2.83502070961478,0.461794416245778,5.17630490336552],[0.247715174315882,-3.10323408322623,-11.8072691323582],[8.61585479444105,-4.35945881495988,-1.53913115126138],[0.265418361348743,-7.25026097591605,0.446575327223622],[11.7703662325299,3.22102346184307,-1.47407458763623],[1.59786276117966,3.00847716761604,-3.75826527280931],[-2.00602029590785,-2.88756990700988,-2.65697436450089],[-2.65546661264584,-3.2217627876258,-7.66036690792528],[1.22795021669979,6.48410639696921,-11.4962005791705],[0.229327867993952,0.811472128094113,3.606146914883],[-6.23593352050668,6.65434654319471,8.79171640242187],[4.35135901820772,-2.39240156012599,-6.91352446511062],[2.83686768764475,-6.35583066475313,4.44168349518574],[11.4671819204889,1.216545791399,-1.44006033262843],[-2.37138387504146,-5.05964564852161,-8.58128476583608],[-2.30318024032677,9.62608148782098,-5.86269614160283],[-5.17549643606867,-0.962122838195743,1.8456922500721],[-0.409492085016426,-7.43154878325538,-6.17844369671677],[7.37446291310972,-1.88249277379981,-10.42403663985],[-3.62220736035243,11.4432094433482,3.90617529860425],[-4.59558024170949,-7.05323676689298,-2.26097975047244],[2.96927248839241,11.8200668260734,-0.785676432399112],[10.9130926627533,3.2654355965155,-2.39069938729286],[-4.06805584268226,5.4634771458357,-2.01298400159692],[3.7744374137316,5.95990508057473,7.04340792087113],[-3.80940154937104,6.96655476446043,-0.804262762622949],[-4.32113011525391,-6.09762564212807,-9.72128851829013],[3.9009183961422,1.14679803561011,-9.84219045766998],[1.56265602605499,5.96561487820925,7.28073661697142],[3.94746485637461,4.86888399985546,8.96763589913397],[2.13387824577616,-7.82104365583138,-10.9863053248012],[-4.23752892858289,-5.27822727495925,-1.88791250274089],[-2.28363818343758,-3.61148091201144,-9.35067749103822],[-2.64948970750612,11.4209744409719,3.45434419418786],[0.929352599024309,-4.23406591895297,-2.20215362003147],[0.572072064381579,-0.315646278105944,3.50063647775267],[0.938965782017703,-4.03549964230612,-2.12836378996586],[1.80975651593311,6.12725060276658,7.01865133462903],[-2.72115162882984,-0.890297115883946,3.12652977539214],[7.91367136366399,-2.93888141948717,-4.89919170717938],[-4.15457074085475,0.805229049463707,3.12383171939836],[-5.83243738569629,-3.19339079185909,-4.98277079065839],[-5.05306479593966,1.92243572639681,4.30989964964013],[-6.09948342584306,3.61155665688293,-5.23517970762611],[7.64212820037454,3.14483434144121,-1.34655855082861],[-3.92430095576608,-5.93634575468469,7.92874311326306],[-6.5309659797907,3.35727098125723,-4.1349123454981],[5.37131145019498,2.55710480105429,2.6374432791631],[-4.73924366990302,4.12803202680726,-6.457321205908],[1.43059585723229,12.1252288901733,-1.69884609762429],[-0.437592784349169,-2.76083864767778,-1.56379048402599],[0.0437110655286548,-1.75624499430096,1.15482901527052],[2.21052266101774,-6.34299810681527,4.65158077084155],[2.12025200029002,-5.40958934486945,1.61918555198461],[1.08159055950985,-5.19809407182546,-1.72187672691687],[9.71177019250327,2.86184037619347,-0.701031774258631],[-3.53271100224559,11.6651173423597,3.58562341619767],[4.87516712184043,-0.770922592527621,-2.9279029534715],[0.713109926217704,3.71636565709919,-8.77929651572213],[1.66667806135153,6.04990028638521,6.95281073440077],[2.61273162387508,-7.8304280093713,3.56004748833622],[-5.69175752036849,-1.06921359040671,-1.46427938503714],[3.00366909175411,6.25472719225685,7.5870638905597],[-6.09599044762751,-3.3078172267324,4.6925255541757],[0.0326041522916719,-6.4609160720972,-1.35372774287495],[1.08473626247934,-0.62219532481729,-6.22267416764015],[-4.14620546057449,-5.9684933328608,-10.2091713802572],[-4.35394533486108,7.12515750150115,8.87825790823877],[2.98166260526857,-4.60919567645109,10.8939616055962],[0.806226402696744,-5.90477364667678,-5.74617030576781],[2.03098751808236,-4.40280537712945,10.0927475938084],[-6.76968892456649,-5.32951876169336,7.20068350345257],[0.389081573313447,-2.68493226930179,12.7551864064026],[6.68575591575969,5.46217529491103,0.530944305587876],[-1.52107505525726,1.058950981812,-1.77664372875504],[1.06313967378039,-5.92004283528105,3.68094616451791],[0.638452193898333,-6.50300813296524,1.17976923930097],[8.39179109674558,-4.48982220166952,-1.7914267999568],[-4.79310798812869,-1.24531083583516,2.5576867512083],[-4.49979654376054,0.0321101437814206,-1.47681201722339],[-1.94341122759831,-3.13567590296716,-9.72174176920758],[-5.16582001769527,7.48586438545694,8.99145355003962],[1.40230491430375,-3.71025242768262,10.050107390957],[-3.0711601377693,-3.12447653741598,-0.697077367509443],[-0.242501560977657,-2.96195188048448,10.4728898699944],[-5.0922827149988,-2.47490625608797,-8.84365866982428],[-2.10094316787682,-0.580243110282258,1.11701838200834],[-3.84871394060022,6.34118616055837,8.83976445415528],[-7.87533521607164,-0.81133108018807,-4.56772290839141],[3.40972727548247,3.34957350513796,0.491019262139301],[-4.55576432521598,2.00364779477593,4.80504240494579],[1.6428866476912,-1.37031498916392,-6.78352561770951],[0.210935237534063,-3.29477467800944,-11.80727124495],[-1.32131526916975,3.2940119367761,-2.53571508894637],[-6.55661588244964,9.85876234357941,-4.14571751571944],[-3.48260937750787,0.831151415067124,3.07455591230705],[1.34002610372662,12.2106181223336,-1.44543999773981],[-5.02156378830337,-0.830259335339875,0.949852932216398],[-4.65658812348446,4.81417263120621,-4.80397486532024],[-8.42284945786136,-6.25741021601467,0.71131247846968],[1.5935550088223,-7.93747832601065,-10.5691391348471],[-4.06214562213934,5.94006210363424,-0.0691178675159734],[2.94753987675789,11.7806640829775,-2.77184509813851],[1.85398629738583,-7.52471038426269,2.35872630101883],[-4.58769133185155,6.67948003708546,9.15874104951948],[-1.87861055859791,-0.277018080031156,-4.8798727208109],[-2.08471410532847,4.42300006304952,-7.69043398930785],[2.5062915764763,10.7407017733765,-2.66131332469442],[-2.47123768155667,5.10089870744732,-7.72216319424077],[-4.33151767573735,-6.39158202361034,7.21113998397292],[11.2405324260705,-0.065795372228274,0.0322132200961068],[12.3442999613656,5.15173130567847,-0.870801370283891],[3.62106106254665,-8.76343486703181,-2.123902989769],[-4.54286725274012,8.17828801276293,-7.32297514004087],[1.6432003829854,-6.34705761876052,3.83133174807251],[3.42983073718811,5.80746486070705,7.576766534955],[0.0831933137610514,-3.78056473888233,10.4461590151705],[-5.01107676319613,0.95983558643994,4.69196165710091],[0.459780604199018,3.3477756037294,-8.6803374614061],[2.05572477313841,4.25440550713926,8.28869813184366],[2.64490640053701,6.34121090679782,8.01230256782395],[-4.61850235602128,8.02863284440284,9.2304713002304],[1.01018361277288,-7.03000929412283,3.72255792120412],[1.92597248863479,-10.0609214449764,-0.00904600421641266],[1.01157776743046,-5.51723649439257,-1.01219437599266],[-3.22484171294323,4.53975283858974,-7.26682251640764],[3.30513543069126,6.49287813125329,8.3768755121216],[2.9951921365984,5.88864134164127,8.89055804737558],[3.66120839176834,10.8278135763551,-1.41807777245637],[2.62975511762926,-7.72093153225735,3.90392257212682],[3.51055382273031,5.53136409361722,8.64646656454952],[2.02090084979247,-7.7446668164359,-10.7739110035886],[3.44418647930103,5.30721521142697,7.91620246872703],[1.3372318487635,2.70013240613487,-2.28033444065279],[-0.694780597432249,6.42291315062225,9.32941568047724],[-2.60354428335303,-2.89654643535156,-6.4394544349819],[8.25579732428629,3.28841164058722,-2.35703904106029],[2.3753450771157,-4.28857261388418,10.1968630526523],[-1.11781751784193,6.16830718990888,8.81436745842128],[1.14391533928105,2.57165864899934,-3.8444621488318],[3.62909158583874,-0.533808443952801,-2.74602261277028],[3.03151996041788,9.61253072029448,-1.7029102899964],[2.27560875128675,-9.94479478361391,-1.39500047390402],[3.96424896596031,5.08925400162351,2.2654701782295],[0.716162702359183,-6.79059502113292,4.31737928501951],[1.75904017390464,11.0581977115164,-2.76893593311791],[-4.89722031540149,-5.59054979325786,-2.57626211372292],[-2.50940852976313,-0.409471896498881,-1.12684151871496],[3.19601559307986,-6.57936182004862,0.0873488558835586],[8.89074691096905,-2.19018242489053,-3.17366234314761],[-4.51059343072846,-6.76814973897936,-2.47411928981895],[3.34428046662448,-4.29428665115112,11.7153235681962],[0.0395790883474325,0.207308220910612,-2.52848848032259],[1.85176009273145,-4.38510157734218,-0.426439397126822],[-4.78688723188447,-1.52135483332149,2.83357459400787],[7.83414435132344,-1.70143558933387,-10.3826576298619],[-5.06066645556364,-2.6639007765601,4.39466899135221],[2.93876115938774,-9.06338391006091,0.835779390572068],[-0.516627968403199,2.47194198461568,-5.15626868321037],[6.69023594792176,5.4434768719272,0.744713091132721],[-5.36200322327435,0.584079041059736,4.34354209512473],[-8.59093709545042,-6.42725102329786,0.443114686266956],[1.46963944989714,-2.96584889755627,-7.65998195495928],[-3.634764730675,-4.23689745824691,-10.3362009463328],[3.49625447417568,6.09523644741254,7.80731024485003],[-6.52154799493012,8.63318830367033,-4.15079800850404],[-2.0775177501356,0.63730728984307,-2.92899542219386],[4.3100660559878,5.58318809543735,2.84324081602219],[-5.96746123213269,7.02093789878215,8.98162511797852],[1.64726267568053,10.2510366779934,-1.72316793370874],[-2.23057585862218,6.22053455371915,-0.54271128821721],[-5.33084029942057,-1.2255512190822,-0.63845224715136],[-4.14839586887631,7.54728122093518,9.10117201867661],[-5.47523328106302,-5.70612151073977,-2.8380796412788],[-2.36516494709284,-5.30255481223824,-8.44899594771237],[-2.97586953161513,-3.38746116824735,-2.37574039791175],[1.28018830781204,2.36517334197816,-3.48386256473152],[3.62051956338489,-4.52791676886835,-1.50481890295321],[-3.46987243239071,5.51682016768381,-2.61944570196294],[-2.77692146563995,-0.978374855414766,-3.71746184972688],[3.6990729020732,5.34718650536855,9.05421552694635],[2.61276680939749,-0.0370832927824534,-10.2326310080986],[-4.50827326393252,-1.94218871548851,4.08564577420639],[-4.43859232566366,1.27677782573666,3.88413520943383],[-2.9176946463184,-0.789534970937246,-3.94186884965476],[-5.10154982335507,7.70617033609003,9.03482216150765],[2.53758532994516,6.04967204841076,-11.7884894038713],[1.19840321981972,-0.0398739000616211,3.08736230103265],[-3.32451143120385,7.00191116915672,0.281053687756071],[-2.09939586838809,6.29594741679272,-0.667376834249594],[-5.15880717956342,-5.43858015422079,-2.13710287461733],[-0.605004192473432,6.52790455827632,-8.67690063098322],[0.876775215852795,-8.88611635715091,2.63600414976554],[-5.77282933067377,-2.74026151389964,-4.65367589875895],[-5.68305426270511,-1.25369874765465,4.01956023545036],[-4.45949150903148,-1.95908787375165,4.0455417529439],[-4.33464563840514,-5.34305799356785,-9.48872616902284],[-5.90747779483771,-5.79496189968412,7.57622529020608],[0.744513891909865,-6.8690654354612,-0.170493094171822],[1.69578716516413,6.34452511769259,-12.0242672608484],[-3.37148495077887,-1.58170928181683,-8.40025099808863],[10.7841045611728,0.134468127592876,-0.400619568397143],[3.82483350199222,-6.9938225898486,-0.70981742906323],[-4.52371600688667,-3.01307823171852,-3.38381526309785],[1.56211795604232,6.73135652706911,-11.2950427394196],[3.20559225776245,-9.44682957879363,-0.939595965742317],[1.32424321618864,-5.91490958484043,2.26840000071876],[-3.60291035287194,7.07797211692295,9.12618071184611],[9.7519922354705,1.15546486313906,-0.929735000670154],[0.240306970835195,-8.43653972464089,1.02327914836876],[1.84202500142928,-5.94844910082504,1.49411263378929],[-9.47504236935587,0.566019461593035,-5.51112039668942],[0.717159439444642,-5.51817960207222,4.29441604978956],[0.615819818060577,-6.38935766504771,3.24404746006922],[1.25956135527865,-3.02898400843887,-11.7131923020385],[2.502899952572,5.65231407780112,7.11293062503542],[-6.21210205990106,-6.14591163268075,-0.699794911519309],[1.55014694798612,0.298472302290454,3.4670619948991],[-5.72610006323424,-0.535069790836366,-1.58583355561496],[-0.0830065012451426,3.52626747236727,-8.74902268046191],[4.84472481744788,2.20950083662681,-8.57764462367251],[-5.51544801205436,7.98166108260787,8.42143256179505],[0.934790423018481,5.10446699669933,8.36706376279356],[3.40768365706612,-7.76666377657078,-1.89627805286766],[0.287411509753952,-2.88986506143966,-1.14470093108085],[-2.62247300651725,-3.44768953846,-0.0630513219827597],[2.03306830631735,-7.28689497106063,-1.71640061388048],[3.44572283257661,10.4618014944075,-1.78516006766114],[-4.72076941243379,9.75128110249393,-4.07094358661538],[-5.08145280161607,-0.202555159882959,4.22154172561908],[0.182361569813286,3.5898024566671,-8.8635161111067],[-6.64160080436107,2.98076318238231,-3.94879649686517],[3.17211848216834,2.41213484363809,1.27573048175311],[2.19290163309314,6.28314746493342,-11.6799648229047],[-1.39191819798651,-4.48922349168872,11.4368591397776],[-2.07590608765748,-3.50130358986994,-0.855798080400872],[1.45491039100764,2.04890980409143,-9.68817384839199],[0.635410882347988,-3.41063783050224,12.3100333774577],[1.99346655949913,-5.81603191405824,1.9585326695625],[-3.19601901864775,-1.21840160163665,-8.09085461704037],[2.9210438487365,-1.88602156373762,-4.68288765876324],[-3.15477031447986,-1.25195445877761,-7.90029423982577],[-3.88285707313592,5.59162985134408,8.40284373970299],[-3.03625182584119,-2.43689629635463,-3.19967913166514],[-4.2009835050447,1.80952406094011,-4.61793044546651],[0.21527998077049,-2.48780583335288,12.3447291885839],[8.53815273133796,-2.44847834885657,-3.93732877420311],[-4.1928162793241,-0.654923165408432,2.7964682782772],[10.6984536684985,-0.615125556270316,0.865604427430473],[-0.460087935910808,-7.45356848077604,-5.85989127443025],[7.53232984843972,-2.80088770320815,-4.69782317546075],[5.10234942325438,-2.87357009259937,-3.87381804916935],[0.883498651730483,-3.12309136539889,13.0986028922623],[1.39651453236505,-5.07391965290905,10.5286637658842],[-3.8796959869687,-6.82948651541999,-2.85146732647858],[-4.95322672755803,-6.12682091156225,-2.91893746324753],[1.95223929114312,-3.26545674087563,-4.7556366034859],[-0.300725519779386,4.77373159014284,-1.41755343564114],[2.72093599051585,6.17039791860466,-12.1665450123337],[-4.00122848120859,-2.39971722949369,4.63125829736704],[-4.99233107362167,1.42187127101737,3.84357709668697],[3.7965107983312,10.877134433079,-1.79325720194262],[3.08340011293619,-8.81009084611003,-1.8279658912116],[-0.128924821580415,9.47154185576975,-7.64990350489087],[-0.102177689635134,9.5257003636842,-7.69667486823848],[2.50041156562986,-6.92553564861134,-1.95115119864675],[0.365308155399798,-9.31996901117985,0.784164249265792],[0.251510314346249,0.162815775123633,-1.88029994268404],[4.20699325685964,11.3455268151038,-1.99315978967963],[-6.01384469846896,7.19606141161129,8.60049617156378],[5.23950822728573,1.28383268235572,5.53478358813753],[-2.0312853177702,4.57418301036751,-7.21476903872999],[3.23485651166876,6.44444840987241,8.08490511155547],[-6.17942111955767,-3.03503976076085,-5.05472450178502],[3.75138030267244,-8.0172493837121,-0.271871193854397],[0.837274971769969,0.0421079626344678,-7.36620989662673],[-4.96610659832501,6.1768968968942,8.56408442536977],[-1.94933399401213,-3.03642466181851,-9.63923142478004],[-4.71802433073477,-0.758803377402352,4.38014745941765],[1.62702823633822,-5.82466771700704,4.32603901525925],[1.68429934337761,3.69905110535971,-6.65792756200265],[4.73154205747701,1.9073212263848,-8.65110913458542],[2.63734679614267,6.2238424528816,-11.246673633919],[3.78335627116745,3.6575557202927,1.51957173588543],[2.92103749531395,-9.83911616312437,-0.424354933583565],[-6.60515495652145,8.99303874129948,-4.70444761875872],[1.29032916604707,-3.74249780461979,12.4414663074899],[-8.27169883421201,-6.86659289841024,1.49764871674215],[3.31519912771858,10.705306008517,-1.47998495895737],[-5.62602216512418,7.02792327092945,8.74102220488377],[-0.215669663206951,-5.40236477947972,-2.4427665685209],[0.231894324092305,-7.2332270931445,1.21812489137874],[2.70833424037621,7.04918688353744,7.79002701710761],[2.82917669410759,11.6576492113743,-2.43043724482143],[2.44088000003919,6.23572087859781,6.43719656400052],[-4.3389408172267,7.6967990828733,8.0220867814976],[-1.98812867325246,-1.22955868950942,1.05169219767922],[-5.3836098716403,6.95905544716239,8.39634459715366],[4.591975289695,1.35235485085251,-9.47675058188995],[-3.4723613908634,0.560979546928901,3.67993167208474],[0.0389974285774233,-1.27258348094919,-13.4371666872376],[1.8143766516322,-5.51730938832502,2.99825957616759],[-5.1502990348833,1.67338592381095,3.12482336808861],[1.75880164385308,6.24087650259779,-11.5459020247818],[6.98503714444178,4.81372068066269,-0.368105328188788],[-2.14131855781953,0.461234580551524,4.7776638466615],[2.43940632002719,-5.45056175012463,-0.693820093547445],[-4.27930921249216,1.65775982938572,2.94222020087278],[1.3708778804458,-6.77746825833017,4.12013192994057],[4.16696839938994,4.60071859053307,8.34541472077185],[1.22655459478277,2.37625245629317,-2.58499651967325],[2.12233651974462,11.8138018379893,-2.3583926720449],[1.12286358869488,-6.76465964258696,-0.0544291132211756],[2.8936632149851,3.51142756384538,1.03881673944794],[8.96427168072759,4.61165628170422,-1.92208380055908],[4.21496397942157,5.97631550833926,7.27223555724504],[8.91878774552775,-2.0189695092731,-3.34258703502173],[-4.18314575150788,-2.08539196657137,4.02728365504636],[-0.600587288730885,6.59109079271307,-8.42677785609937],[-5.09319416143081,-4.47665330840076,-2.04202518051107],[3.42674293539064,12.0541632380652,-1.92909443890062],[1.55627863085965,7.05782614183537,8.30892494176266],[2.83357553890795,-9.07206192610207,-0.122016463017727],[-1.55218262778245,4.8311185930275,-2.82503551947965],[-2.93920196599167,-5.09459196455721,-7.32577685491548],[-5.16043970918807,-6.74455981237461,-10.2607707908139],[-6.8529776391389,-6.92671978322155,1.1864278010206],[0.317124026112216,-6.54301327808998,-5.90776372948377],[1.01877641457191,-2.6345349980533,12.7309465156477],[1.46991245615286,5.6182459347626,7.36277388032125],[-1.04016292562252,-5.81522169643454,1.28629579377001],[4.01872321952374,-8.51476560599853,0.0357937728576871],[10.7671459211203,0.645200784471867,-0.789814725993421],[-2.54997715394378,4.98535393190458,-7.12220825743693],[-0.340432159451153,9.99449278588342,2.82368484676616],[9.22431324118516,2.03001643047237,-1.19805857702535],[-4.80309088575931,6.87271776024318,9.42811052917746],[8.41925036043793,1.08006023940716,0.942080999929969],[-5.36226823478829,-5.81140598630171,-2.57068949841458],[-0.398397102301568,0.569653556397854,-3.03740554248467],[0.993504049064195,3.70028399586967,-8.67145530407071],[-6.40102459047826,-4.24998604284305,-4.09233453348223],[-5.19552503595079,-6.34042113915784,-10.4904032155919],[-0.507687099235173,-0.843489474025737,-13.9525281629499],[11.7562742321935,1.10868563637539,-1.24765627553701],[-5.61775726082345,-3.03908764067286,-4.10931310453584],[-5.25126011295623,-6.56645239858851,-2.38387162783541],[-0.6900332379005,-0.1262992217234,-7.94579444072426],[-7.59788777887778,-6.67587003146619,1.31932429317126],[-1.70444605149137,-6.55265417779943,-0.491359721872478],[-6.14978641787716,3.08500856273433,-5.75267004701213],[-2.45711018810498,-3.6107394013573,6.60253558791732],[-4.35813271800812,1.17960830904576,2.71157707491287],[1.57310751624414,1.60136560923074,-9.33292296750021],[2.28070961736424,5.52107503963778,9.16699069439565],[-6.09117092079421,-3.28046856241656,-4.97879862552805],[-7.09182262696784,-5.78024260807572,7.08897861345546],[-5.33876727716273,-3.03373986670645,-9.28788920498812],[-1.33477477858255,3.71157292002288,-2.85554515867604],[-3.32935893884149,5.56138065172475,-2.46229440022842],[-3.8963793691534,1.16087813376951,4.49203018104036],[10.995448282273,1.45698998771538,-1.71289053074815],[0.015076662674975,-1.60082904292678,-13.3636815020728],[-1.79837842634374,-6.46661278552807,-1.18155068622827],[3.97131786734418,5.79836493305994,9.34359901482913],[-4.33767954665704,-5.98954271879384,7.94225707120545],[1.11276782444422,-5.4076839760542,4.47429956555197],[-1.88398832604815,-3.51317639647774,-0.659466011238591],[2.76988356784387,-3.12667407841375,10.8583474269518],[2.18620804101592,-5.539907211274,4.00443633812924],[-3.53708122024351,5.82868404533128,0.167256096291734],[7.0276501446368,3.88561366779796,0.306168102428408],[-3.26523633708504,0.336190075334961,4.09377260763162],[6.99263243510172,3.96639160731781,-0.169064345199696],[1.60390715214038,-2.67828980373689,12.3226134998239],[-3.860228195196,-4.23426895385458,6.86305245183155],[1.77527409451156,-4.7140399394744,2.60994886058213],[1.65338041868313,-8.91561918770647,1.25475292545365],[1.64500620485379,-5.47596170666074,10.6594801911411],[1.69851130121417,2.72194805831629,-2.6940496853178],[-3.68667334967156,-1.81835410170983,3.87694243322317],[0.245675470160408,-2.2503353155859,12.6133291358391],[-1.82589541530421,-4.90863241619365,-2.19951007516178],[-4.14527239000091,6.97796347132785,-0.0972868797136024],[1.66465723002275,1.8876465424866,-9.21986298627242],[-3.23720225800225,12.1147501822156,4.02098993999566],[0.493530985312323,-0.402656115813567,-12.9423217072075],[-4.97418967037194,8.3068329258068,-7.44469705404804],[9.47447535775351,1.1938990989994,-1.01651959751049],[9.98808768474919,3.48238425877719,-1.48583045197733],[-7.98308119521341,-6.32928124312781,-0.157878158036929],[-3.76304255288008,5.16117658283211,0.269494237533968],[2.16529385097874,-2.86156580473236,-7.30014929994388],[2.43887041436103,-5.63151354164413,4.60346737655248],[12.0177630932532,1.9586651448756,-1.03099004309153],[-4.26392190110334,0.143250075006847,4.76675984699604],[5.22771557009991,1.27780375931608,5.86525029204386],[-4.50764585480274,-0.419834666366684,1.86727841039748],[-3.3558244913237,0.859520879730483,2.24403926846746],[-5.23583709770248,7.15624161465809,8.4920089226636],[4.36627821147814,-5.14285380639142,-1.32990318336476],[0.156419984582989,-7.05863949699159,1.59972651500971],[2.29831168937326,6.25330873266072,9.34508661991559],[-4.10436141928358,-1.89818166930468,3.93159840429029],[-3.94362035942401,7.92024560781997,8.63376944992245],[1.80579043088189,-2.58849973424614,-7.17982031646682],[-1.83166259231786,-4.47525426484152,2.25198845893231],[-5.55320013307214,7.85514518724851,7.98131759543622],[4.23060550607662,-8.38747014612201,-0.288353756028189],[0.829739100718356,0.328859201301009,-2.293158553522],[0.297058227774684,-6.66996692755492,-1.30475039927308],[2.12983895481692,-1.45688666633216,-6.36523013124917],[8.0664765313985,5.59576404813984,2.67404214351036],[-2.54021892433413,-0.535759369780861,1.18224517506405],[0.606068306011291,-3.07548858255625,12.3852570242422],[-4.0934511340637,4.05118378065447,-6.89672520923664],[2.71020442521578,5.96098591491626,9.26878639696161],[2.73461464611844,5.45154046518886,8.8193059945903],[0.873829491619954,-5.90664183470154,0.243621593129191],[7.01102082034668,-1.08057513151077,-10.7191129091271],[3.10940886951693,11.9872839335916,-1.03101533999391],[3.62337169271747,-5.60987900207114,-1.19390085438703],[2.12581803496595,5.6193948396591,7.38044611434879],[-2.28045209555972,6.47215196420015,-0.865972073434733],[-2.76016201527157,-4.09415483681755,-2.22800704871404],[-4.03393207813936,0.934991033205609,3.7227246750524],[-2.93638845192752,7.01548394498278,-1.25333027216813],[-4.09757468538226,8.13439530051548,-5.63518240517216],[-4.65611780481526,7.13650855570332,7.88565889087715],[-5.11099283756551,-0.421511928286841,-0.510582352672558],[1.12298876293332,-4.74034833224465,-5.28534988425204],[0.202669923046374,-2.64077253748566,2.05320418777063],[-3.77207541820347,5.11419855725922,-2.47684851924232],[-4.75965090657501,-5.63130180391347,-9.63479168450325],[1.57522394802647,-9.02089104411499,-0.597872816126916],[-3.30175022619017,1.27807611080037,2.72103665522349],[2.2515724459297,4.29344800859374,7.39998862861871],[-7.56179511850809,-6.24499027398146,0.311709302339916],[0.298945588354156,-7.44395809270425,1.50076890545935],[4.36828107988333,5.59032742611505,8.72647846021729],[-5.63655237563565,1.61880772163684,4.1861332978825],[2.3279927466165,11.5516881148204,-2.5192331371758],[3.29228158074724,-9.97597483696427,0.058623285125398],[0.676038243119864,7.28424416999839,-6.2056737774731],[-4.28728003851775,5.82045069351633,0.210339480692037],[11.1480248805766,4.13016254569543,-1.97680875595423],[-0.625801620675589,2.74982415599111,-8.12105194555119],[-4.05737403670075,6.28659465854721,-0.563904315314584],[1.77391854836142,10.6292446939678,-1.4023895632638],[-3.95097285314662,-6.12681148058207,7.60205703530513],[3.51470693322436,10.8989909532153,-1.73941886590183],[-0.0378697619337083,-2.67759699420587,12.56215950992],[0.278876405711252,9.07354071346063,-7.85680255170506],[3.9432229969628,5.52153776013824,2.02261559722504],[0.336022219221279,-2.47866990979069,13.1298393522187],[-6.05716566327837,-2.95602667050863,4.89956155401123],[-6.2168548669833,-6.35787527714498,-0.162706150453384],[-3.54019172133328,-3.46343033696715,-7.5002760936264],[1.8907460411823,1.32358049773027,-5.44431248522046],[-4.56651585842905,-0.886223653823547,2.52267887464745],[1.67327100623213,5.36538918605057,7.52550124982652],[2.43591768920867,2.72777909777851,0.925707184393087],[1.6939246067196,-5.18892283786351,11.4514910329295],[-4.20298337365512,1.29674040299731,3.81640413441684],[3.90083594183245,-7.29346040008132,-2.54558667003708],[0.0722328790975398,0.978596746139988,-1.58031660038619],[3.6395978689287,11.7797844427465,-1.57186605268174],[2.25324013691479,-7.00793170131746,4.1597573792491],[-0.773838878272998,0.518830816523663,-7.33413344733639],[4.06793785775742,-1.22117590190628,-2.41928700851817],[-5.6026638526747,-3.70578723603586,-1.90665809885377],[-5.49352564337898,1.32191691545786,4.6109426362326],[-4.16302608892987,-5.88615230959988,-9.01379010434268],[0.939140007829529,-3.94146993226512,-5.3830059656019],[2.84230047267879,4.75409403413937,7.25625944322689],[1.94221838532701,-4.2327597288112,12.2163909331928],[2.08119267370073,6.28059255353585,9.211032581554],[-1.66175295275118,-0.976360793858,-1.93685572982794],[2.53236056122795,-5.33696191227678,-6.20721461295738],[-3.84189510204866,-4.81989235377215,-11.5284838798123],[2.64997676805612,-3.00245334213429,9.7213362310025],[2.30190039922077,-5.74504178558864,4.3430306687479],[-7.00815114194211,-0.903061978972306,-4.45534903053956],[2.29338381767733,-3.16569961223104,11.0059076153484],[-5.79574785676508,9.44295716355198,-3.92283845374309],[0.0728489682751871,1.87330544665123,-6.98800859714201],[3.18039646918396,3.19029871380917,0.354655611933776],[-3.69283912107866,12.3733050452158,3.85902549002231],[-0.0815956568845674,3.59612581143607,-8.73910063788921],[0.802824580980258,-3.43992025629413,10.6292925487134],[9.71033503381025,-0.199871778527427,-0.714453909681003],[2.73853348856633,6.0403373846184,-11.6929508413986],[9.94508353908269,3.73857304859061,-1.19492751468355],[3.3416284021154,-8.76729128841174,-1.59757241109488],[-2.50915705486574,0.301348986140968,-4.8190720479496],[9.59995859090675,-4.78766596481337,-5.16982727744598],[0.15069781450127,-5.33873085765728,1.55216504126262],[4.261433965272,-1.05134569803233,-6.55264754221069],[2.276449369077,-3.22335947063589,10.3931156119528],[0.842233175591898,-2.40946756735182,12.5983645388772],[-2.78953801957423,-3.84258788353652,-9.13438044703519],[2.80339581170753,0.215119767407661,-11.9901316693564],[-1.65865323445276,-0.142373890636418,3.37911675966781],[3.84315006051595,3.52091235751361,0.49376726979182],[1.92836309230196,-10.0534890589138,-0.205524794777265],[3.91016537620634,0.968955768335931,-9.72211299234886],[1.88090300351666,5.21721889714382,7.23932912032064],[1.1754868882482,6.4345757724589,7.64805541476419],[-2.19693218106306,4.70097325384499,-7.47558717163318],[8.75320786941375,3.41871157466154,-2.83915053510407],[-4.6194059065177,-5.83308864149164,-10.4231425019399],[4.18365259876372,6.063524075697,7.8690341934915],[-6.7773782902623,-5.66205784775961,0.891811256710546],[0.875626425142144,0.303836425934678,-2.6613901149873],[-9.27279610127436,0.20326741059523,-5.41927753729918],[-2.46879825873633,0.344960773135283,5.09423541724865],[3.25710564884127,10.9560681499725,-2.30900439189559],[2.41837379830756,-5.29163686209552,-6.11796743472386],[3.69183985459443,10.726045801124,-2.87991995282084],[1.49333260078723,1.86359789095839,-1.81353061305246],[-2.79257063444759,-5.38572588905716,-1.7102520835664],[-5.5832068637704,-0.269553145887471,-0.0997611475423044],[-6.25238549903316,-6.1449062750632,-1.04152998673398],[2.9801651864851,-3.57211359683549,-10.8723597402938],[2.83275540552461,6.64815649183902,7.51126775203445],[-3.76322340506615,0.676924831556992,3.08881829088527],[2.18016190930323,-5.04667852249316,11.1881822302445],[-5.18748804527914,-0.225619412459192,-0.947155781831502],[-5.46599198094814,1.13014164113936,4.07804944375389],[0.579262973294479,-3.90136033318665,-5.6390673037012],[5.72867430494428,2.70414696545445,2.36481768342809],[10.111072477235,0.272857268907578,-1.20824327220381],[0.387421711528101,-1.38230310900224,-11.0021697672301],[-1.99708237515724,-0.960940515734397,0.598632653976271],[0.861258924020082,5.32034443879484,8.20408567562491],[-3.93246295464369,-4.15578758175811,6.84006271521604],[-6.6054056376711,8.7426315078888,-4.72466464413765],[-2.89118754996844,-3.81197752348073,-1.11480741214241],[7.25290815715135,4.48705824512461,-0.842914148789167],[-8.11041633280986,-6.19691978971256,0.224545731783371],[-3.91355070814285,1.57838187176481,-6.42199824256199],[0.274184595105298,-9.32396652665614,1.39255787187936],[10.2535454135021,3.40513625269015,-2.69004693266075],[11.6814442477236,1.7999810195115,-1.00172028947613],[0.323210224767161,-2.47191599257888,-0.296129786858843],[1.75828378223389,-7.98552130587513,-10.6075216331767],[2.63066448811364,5.1869460381161,8.45290735645818],[2.20154629200516,-4.70047468245511,2.89079940202289],[2.77803245837883,4.87095708889053,7.56442495231975],[3.4363505836813,-4.94386115398961,-1.39610061982423],[9.8641870193654,5.34837311380036,-1.07134874546556],[-2.41734056417948,-0.23269565516682,-1.3136229536355],[10.8852146345071,3.16536754732752,-1.9349508777858],[2.92047617714227,11.7377263254641,-1.54249124286556],[-3.84523703450414,-4.98334394672493,7.38806936302667],[-5.22242773300792,7.90897675812791,9.23643546053019],[-6.6486539625866,2.78665291998093,-5.1094036978517],[-3.60325726923088,12.5597976797311,4.43975506538869],[-0.26878381036634,4.43403100126096,-0.743345158034729],[1.06343960863704,-5.08145088705604,-1.4260448115685],[1.84559881534935,-5.30903509508437,11.0002858162468],[9.42779800382033,-4.23357432430898,-5.72725671359376],[-3.05668197933562,-3.01089320269374,-7.55712721148262],[-4.27199912202882,0.870594447433951,5.22792046448045],[4.3561172902112,-1.51456169387819,-11.6026654549885],[-6.11214312952734,-3.29907180992451,4.96012119614641],[9.59806943312946,-4.83573683771516,-5.49592153319449],[1.75214096356517,-9.9768986425276,0.839649089736567],[-4.06348701658117,8.07403682916394,-5.51843425559477],[2.01376107558674,6.17031418857611,7.85745329816787],[0.177010314313094,-2.93520499472483,11.0893937456059],[-5.03359526145307,-0.650854721183957,-0.902967545066748],[-2.72116680154988,-0.872704552705043,2.43521541718199],[2.5020523799076,-9.48560337937491,0.303065215271219],[-3.22283926816898,6.64138959389622,-1.39544263460867],[10.6772724236297,0.48729642518305,-0.294639265608564],[-5.75824805843629,-2.65852559574653,-5.38550864924135],[1.74808473469401,-6.40039591098969,2.84420043523301],[0.578278476631943,-8.04139903167998,0.675372230066043],[1.95666682274867,10.9663641899452,-2.52771847306547],[1.28226030909801,-8.08066416703026,2.16935755584702],[0.971697859804423,0.1093237578488,2.99156341594012],[-4.01266751230842,-0.619208592091227,2.96629178236597],[-5.47425692150136,6.86153417837692,8.37630518124533],[-5.5228356611175,-2.71239131280264,-9.17508091408277],[1.99737999653902,-3.32443406582086,-4.65907991946943],[-5.13939572748849,-4.0297193380389,-3.87939485984473],[-3.18293576777725,1.45437648620646,2.44142013745323],[2.11311483791038,-6.393951869245,3.70028083753827],[9.36963916493604,-4.65357481543616,-5.77282735046815],[2.45329079975804,-10.3580336045279,0.0739160371503492],[-4.12176112631841,1.30073766059012,2.34485639866978],[1.64060585052859,-8.68828499460789,1.60951448778608],[-8.11363853170614,-6.02747643367236,0.151816025238024],[3.54446396462645,4.00298354231861,0.720248535049149],[2.55337301285909,6.45331982668141,8.92336663766763],[-2.92467230834286,4.75197266548347,-7.64033979670715],[2.56679796182032,-2.27816784598954,-4.49289738655417],[-3.16898623401812,0.257153219094472,2.25491787083246],[0.781916824727195,3.81210625892217,-8.88937978518678],[-1.69276802821348,4.59825522203946,0.859570699961563],[-5.86270404020913,-3.87380609547424,-4.42866245749561],[2.21445943870344,6.08492136332394,7.98459397737095],[2.45388769028177,-3.84957448267492,11.8569036500163],[1.69556239277319,-4.09579382135871,-0.296808464536455],[-1.38783377996755,0.170959680018825,-7.23888005963835],[-3.43980541077346,7.75657459470284,8.62892093387543],[1.42292631581752,-8.84167321138489,2.18645583077424],[1.21697314961315,-4.23262590903785,-2.81720808577753],[-0.207012749838593,-1.00861938276081,-11.0793363778757],[-0.263194340481212,-3.14639732349078,-1.37916142931055],[-0.872975973875696,-7.68284570847809,-6.00395422687128],[1.11405384286247,-8.57055368409794,2.50465801658899],[-4.68607745266804,-5.91903637225253,-2.83209256332246],[2.3014723237359,4.38889149196057,8.04175838724298],[-2.58416996776049,-1.06514832418392,2.22965372316078],[-3.70305176096156,0.828024657489689,2.98864495566089],[-5.8911904809584,8.69121883863463,-3.56635408927274],[-2.38608259624182,-3.59088567244974,6.64376130797128],[0.0784545166293898,0.599343333617699,-0.302643253020801],[2.06139009120598,-7.66452794544487,-10.7524153779038],[-5.63489255206039,-3.17202106904138,-5.08060997783963],[4.42106263539239,-6.4129552287486,-1.72604934111971],[0.295484073997532,-5.96334932801393,-6.01011854916286],[0.341790629365816,-3.2012762017613,-11.2093684953576],[-3.95334737194416,-5.86761876279432,7.80485894694792],[-7.38763129080598,-5.60925709657123,-0.132101119392674],[2.45281008465745,-7.67663121160932,3.90929844547548],[-3.28188284878202,1.16336797357425,2.13833758202529],[3.3721696716368,-9.86408997584869,-0.843097014720776],[2.24792564926828,5.43917638115226,7.21599192006064],[4.19230881448457,10.5293501970636,-1.94554088624503],[1.3172544144478,-3.69205225387728,13.2165745118613],[2.02492022365878,-1.84822133910815,-6.7424601467157],[-2.2402010039452,-3.55392592275677,-0.47112105384558],[3.56683288718884,12.1005289678936,-1.99735937359002],[0.715867703454618,-2.79672899002279,11.0301098764962],[3.52392173198741,11.464076675195,-2.28368547550796],[2.47250884973053,-2.98347666513362,10.3512068723791],[0.45454073660238,3.79598181481394,-3.55494557106699],[2.36103063829211,4.14837649832691,8.10113637161555],[3.2342174593513,-9.78468347647723,-1.6070978386881],[-0.181269178211578,-1.90977732123338,-11.485355152092],[-3.20889247299398,6.04231063722444,-1.4577558320642],[-2.61147753007349,3.99688963900906,-2.17960294844175],[-5.45782216594598,9.91101996041543,-7.38691664864037],[0.110109700590185,-3.08682631312183,-10.9523164500757],[3.96853409276737,1.45237722721257,-8.7752872352475],[4.00357218145432,-3.25560882066029,-4.10251355666301],[-2.03957546589436,6.31621670877308,0.0138597526213698],[-4.63096514411885,-6.85629621141649,-9.46922472814173],[-1.66006421389447,-3.23027967256491,-9.59699754557092],[1.92226065908337,5.7461175997975,-11.8257526015764],[2.27205989807037,6.63282378732879,7.09543490533867],[-4.3000185401673,-0.142791447531267,3.02921014208186],[0.943633778191955,-4.31968215359016,2.64463826527455],[-4.08001141338878,2.47198970799298,5.47288862507307],[-2.53152751319471,-4.24734089819257,-0.80185630116262],[-3.46620394735733,6.01628795369217,-1.42362996149061],[1.97082351041785,-4.50043128763259,-0.173680245521466],[10.4686626264773,3.0974139826629,-1.77523608802989],[3.97974191159375,2.20660068816917,-10.1623559760021],[-5.85355495093206,-3.5638067798199,-5.0472857417581],[5.04950609991399,-0.693554180532661,-2.76039425778422],[-3.74188293568915,-5.61663185972089,7.54767028110071],[11.0940963346864,-0.680287449044325,1.32951918475204],[2.6181857788275,6.59498718956857,-11.8089355023809],[-4.10139176138462,-1.1203916839152,1.91216375093232],[0.496205655620948,-2.3956395116435,-0.231631420871578],[4.19928833662149,4.49729202041072,2.87444184025753],[2.21144752774842,-8.40171580009396,1.92336589369777],[-4.72430663313371,0.108785567956185,1.60986636539493],[-0.661526151253316,-3.08010783981567,2.16276725033027],[2.37933048392352,-10.1868270048494,-1.33130531449247],[-1.37306987500046,0.0723572368948864,3.3448272008749],[-4.40194336421783,0.86036544133634,3.09521234725557],[8.55168401785399,0.857534121423523,-1.21818111923072],[11.0592518322307,3.61096813133694,-2.03262688405626],[-4.40347832766983,-0.469422325673114,3.42365499645978],[-4.27918618514196,-5.82415231350604,-1.30057682095803],[-5.27184316887852,-1.37030200817616,1.04008191128205],[-1.15945122830789,3.07897764673849,-2.48979507148751],[-2.90084797034441,0.996145803393468,4.27036850902179],[1.41105031625298,3.73883389214904,-3.75200978523729],[1.97439866083326,10.8298289698596,-1.91421664805901],[1.78711328653577,-9.6755135569053,2.27807140702387],[-6.07498015125489,-3.3660949001725,-4.53851694395932],[1.66406045463719,-9.88265378716846,2.19794351583879],[-2.68054070505208,-0.114701934929461,-0.542784006117732],[2.62500118853143,6.27777309914049,7.14956661407974],[-9.00998184545464,-6.50604719833738,0.534031131499969],[-5.1541985521285,10.3316494206856,-7.02879665901015],[-4.76761504945304,1.42737763088339,3.9357606704854],[8.02296724129121,3.57500433364959,-2.20603026166622],[-5.93538897672489,7.42126268572243,8.29820548800045],[-5.30655901482633,9.71138986495467,-3.94269878997097],[2.26786738194347,4.41468443870465,8.36119059687278],[10.310837477578,4.95096967323706,-1.46577999544608],[-5.96505266758216,-1.0225399797389,-0.983387234977341],[3.11459922051136,-9.80896545296863,-1.01879885040328],[1.42041327739456,-5.87505607101851,-1.00346194373362],[-4.87040190466581,-0.117625073154427,-1.11137549255773],[10.3307457145405,-1.9430241994757,-0.11793768426325],[-5.95471837311897,-3.00974227972167,-5.24843398182108],[-6.17317196975043,-3.14907862639705,-4.79494251761832],[-4.54948353198632,-0.138922036309769,4.51464457971155],[9.77115727066804,4.29834660804584,-2.15207318903871],[4.39238115615097,3.10132854641991,3.48304889803244],[-1.98510257316999,5.18740471684537,-3.37168508053961],[2.36396697012469,-9.74602472569438,1.87415498812124],[1.78822469947158,3.94979683541126,-3.97154775384364],[1.18250670453037,-2.9709997882017,12.7702358072662],[-4.24308667183817,-6.3724221691589,-2.93664890323764],[2.79524150986419,5.62769342148483,7.89050061547033],[2.20705905808708,6.55492965471583,-11.4563637208596],[-5.17208676761885,-5.27396385732051,-2.15962527440855],[1.11611318048431,-7.41392418352121,4.02327068135938],[2.1675774683646,-9.22430114764367,0.172257585541219],[4.35919323645305,-5.21752364527121,-1.79579724729067],[-5.22041160867164,0.992726718988801,5.17634302758743],[-0.0124456226994575,-0.0660005777979413,3.25534199578961],[4.60849654777233,-2.73018415655651,-7.01922717914881],[10.2293304168826,3.97461314771289,-1.25866614100496],[-5.28113508758502,-4.72890746305489,-1.96183149394857],[-5.26318462519286,-0.427637615959589,-0.968049167404422],[3.53803629483233,0.559514942314429,-8.75289175121831],[-3.75438019797457,8.09059835343438,8.32892620882964],[1.51581238494899,-5.60642085042914,4.44230049007356],[2.61145969577561,-9.8230712568449,-2.16884186862554],[1.32422467379279,5.62688985214802,9.05219991806999],[-9.28437064847791,1.23857913573686,-6.17944380960549],[3.386425820663,6.11244332339805,7.82610538194127],[-1.57402873052328,7.36224806059593,-7.14416619719533],[-4.65644694117731,-6.01839733619337,-2.62274045502799],[1.7598889694981,-8.01874163622794,3.51341313125719],[0.869784209347935,3.64049528954026,-6.52800471591356],[-5.83709245390026,7.18160772345824,8.81442496299742],[4.1426182437861,10.9932443483611,-1.56748064665089],[-7.43229487076133,-7.10592802507615,1.73458944214622],[1.25125915249494,-6.7636699416958,4.24240885057848],[4.06325490553333,5.21939089804961,9.35511441651619],[-4.52662940895545,-3.74519157922331,-9.08151714579123],[-0.60419826861929,-2.72255705033078,10.0068930897974],[0.838151844428102,-5.36813841564991,-5.05068809317147],[-1.78297916522482,-2.50443987277331,-3.77305958159554],[-7.52362341671375,-6.28431580062041,-0.413840439743348],[3.25065821436074,6.48599035530395,-11.6506793453106],[-3.03795320443841,-3.88990808840891,-9.34705636908912],[9.54236752223631,-4.59776011091291,-4.06458843843781],[-4.56216170324869,2.07843890889358,4.05723573544423],[0.218754010730713,-2.9648311460531,-0.799522730684167],[4.07672866538783,3.46689231437942,0.552224667470303],[-5.93390568919722,2.93551460868282,-6.08022387119253],[2.09226844533166,-10.0764177146061,-0.788064913446285],[-5.44418701142011,-1.39120110132616,-6.7102110722637],[2.13757432529173,5.66145061633765,7.32425647986321],[2.06717963921686,6.4929569211393,6.69222175826173],[3.27710487144873,5.8701764172983,8.6517855292238],[2.88888903227409,-8.32591288488404,-0.989206867215228],[-4.23336823109329,-6.99776182642628,-2.54318771773749],[3.73300586566012,-0.694860162920544,-6.2926975242788],[-4.99630890831043,-6.73589033171568,-10.166652230362],[4.78865460659733,0.0788327706782466,-3.33810787426721],[3.95817928168019,5.14889211918473,2.16707397603597],[-0.0887669747026267,-5.35250680810504,2.68882042225033],[2.55419731664527,-10.0371420476576,0.28257684944091],[9.15592385301789,3.81719782349518,-1.80950367820957],[-4.46980211231944,-6.83823894769102,-1.89095241591248],[-4.09995744943196,-4.78923853751792,-1.50926792687529],[3.97450965405737,6.41006469504048,8.52336401516441],[-3.84864800397388,1.07752292971001,4.41962609034152],[-3.94802020386415,4.26978160059735,-6.9859239153977],[1.73872095484774,3.98318287764273,-4.05137531630727],[1.58479389924877,-3.24108732664359,-7.62283602260059],[0.918894581082444,-4.28542856281129,-2.21979797198348],[3.38125405928074,-4.06407677793863,11.6680564522084],[2.60068015177619,-7.5221125599774,4.22464382878606],[-6.78050437018624,3.24462643783216,-5.84229542392527],[2.85584770059519,1.72171386972385,-10.2223897115457],[0.319347428860716,-4.80906698972699,-0.58090773931964],[-3.39088815798837,4.46261937066936,-7.10167267978816],[3.84089038373524,4.96910237098133,9.17194945907288],[-3.91179632372735,4.36090032384795,0.370303709355512],[-5.65234976464279,7.93374494723497,8.76071308034106],[5.98985523795719,-0.717591961782939,-10.036634245679],[-0.997764542309331,0.818665768503695,4.14389312889658],[-2.77144207670748,6.84073430293797,-1.31969321990038],[-2.78899572627694,4.8158435698476,-2.36470695424205],[-0.982773661909318,0.481221956303662,2.97828285030735],[-1.08859924721461,0.898710684554185,4.24664558842185],[2.67620225873394,-8.32534532722848,2.77490634724147],[-3.08019754841271,7.13156109434931,-0.657229393894334],[4.1376653481817,2.21386537639426,-9.94633574891176],[0.759995830127073,-8.97488931309731,2.05850268463782],[-3.99697497008282,-5.96684351219149,-1.41591017763098],[4.11324429498291,2.18050168983786,2.67028916320199],[2.41633937113168,3.76169269429724,7.3791340283827],[0.322484410821478,-3.21724585346776,-12.0528504816254],[-0.728977109340121,6.32240840776352,-8.49746316216987],[1.70682113867934,3.00093883455424,-2.74747072075783],[-1.12969455170538,0.846082462157482,-1.76220033314342],[-6.05328541746745,7.82503406630059,8.51336768766165],[1.21749505022117,3.1408025355727,-2.50585413467338],[-3.2420139936359,0.27592959832731,5.32297344685963],[0.0241054674683706,9.52031269776278,-7.52573377384763],[-4.90776098207659,8.0416001882508,-5.23657684055664],[9.16225809870584,-2.36710074463785,-3.65232386901593],[-3.16918077374649,-3.35448934879289,-7.99566475426493],[-4.5261841463814,1.59516993829924,2.34244633038121],[0.752909619380338,-7.6870220253087,2.10560081973685],[-0.18243510109293,9.20244165958193,-7.21381334505631],[9.85246677806574,1.59201587681485,-2.0694497679036],[-1.30956857543213,0.195673859930455,-6.96166134433396],[0.286066974329912,-6.71240288180549,-5.6797191284696],[2.15480009431707,6.10722800024014,-11.6194208507834],[3.48171955420553,10.5795862405533,-1.43977226876886],[1.75970822181751,1.38577327929847,-5.07932087226807],[0.370445587236916,-4.83106337479164,4.13415402719086],[9.30021299900281,-4.25181928996443,-1.47518585546597],[-2.76076038491443,12.13509445852,4.04892138791646],[-4.34003798890512,1.06665111695339,3.54758982161156],[-5.1654576544798,-6.18989997359435,-2.21346286125275],[3.11978322749616,-9.86416208212279,0.539864523559709],[-4.72820973315503,-7.11779439014044,-2.00343264784532],[3.02161852794932,-9.3791162358615,1.10696394525147],[-4.07340932409156,5.20550910259543,-2.17192519290543],[3.03932968520432,-6.09536823345208,-4.79402185346459],[1.60331412127015,12.0628177629794,-1.85988027457162],[-1.4369120064809,4.99571979907641,-3.14243451881659],[-4.51863203249661,-7.05063510848936,-2.43427476193105],[2.40371334558715,6.11526450117339,-11.8034701938818],[2.19492340914825,-3.41987044508375,-4.59600940504394],[-2.50793754181048,11.691374378833,3.53619038060517],[-4.85594102650741,-6.40218813088354,7.85411245118212],[2.40184267181804,-8.48233302055325,0.353129712019376],[-5.12213272278933,1.50138190619377,4.21830540865779],[-1.44268561270647,-6.80267284517863,-0.804713942655386],[-2.99523007138963,-3.27554687810328,-0.130819773711448],[-4.93919557455752,1.10196640220282,2.98041341648985],[2.77115611635851,11.6916329606873,-2.58192084995157],[7.29895091093531,5.56123912267918,0.0544275370514374],[-6.26245560391858,-2.06507363766374,3.92398458126908],[-4.47306661119944,7.79840612204106,-5.83420209603819],[-2.30710289791613,-4.82790365067464,-0.559235867769511],[-5.67332959140648,8.55132760372961,7.92938603854799],[-9.36180767805501,-1.82295440261833,-3.95200401011767],[4.39499048862932,2.47367218937363,-9.88236420553652],[1.12937855850868,-3.59348888038952,10.2260814767075],[-2.04798941531876,5.65226907634467,-0.0405095968185436],[1.14136267876292,-0.0545891226685309,-7.07835228079623],[-7.33429182952467,-0.589401774189459,-4.57674180937482],[8.30322235657305,3.34418176413653,-0.962995537854549],[1.19492367356268,-9.19765643479763,1.56231909783121],[3.4982571048919,-9.30859096214519,0.243628457422207],[-4.77983418618299,9.48023829730597,-3.98634759528156],[3.47886470515164,11.0964004693169,-2.21549614578883],[-3.68835197710637,1.48317209855639,2.65499415833689],[1.7904423324542,6.21271149827051,9.48579050491844],[8.98153110305933,-3.76900667967069,-1.22237926529042],[0.0307369690561241,-3.31733260310063,-12.0739444502616],[-4.27401937184061,6.09791969253431,0.314538571951785],[10.2114681133936,2.22174696736816,-2.26298505091305],[1.31244660869832,-2.49758923557817,12.8905255848277],[1.32145458835016,-4.58582271532412,-4.92266790810681],[1.65994370595342,-1.31719166021207,-6.81631893621865],[2.83522848529587,11.8815132448832,-2.60640038283992],[2.14401871835737,-6.01990922372568,4.74083124463302],[-6.20865282055091,-4.06276277291769,-4.38508571948863],[2.31026378259162,6.1255974892595,7.02776058909953],[7.36114703820713,-1.38785587123622,-10.7800807822677],[3.52579462652959,10.0238550646814,-1.24794537584918],[2.02700945993822,-9.9015306050288,-0.31313029607756],[-2.48183148140078,5.94776228324494,-2.23293134310496],[-0.0697762579709302,-0.0429120302758998,3.69372064764015],[1.39662709223774,-3.68343809621425,12.6411215546866],[-2.9521564428696,4.96574301710987,-7.13972636326242],[1.60809633383531,-2.69408909537255,12.7575026498595],[3.91630073351305,10.9993580174669,-1.49379547119307],[3.23153422601385,5.89094900458807,8.9751639521399],[-1.15260248473714,-3.71004869521241,-1.53714391746954],[-3.24716273032842,-0.256385445525011,2.39176278152124],[3.15687657950387,10.8679967922509,-1.67592026637466],[7.89797328996992,5.45043123817673,2.77285984360071],[-3.98034521610402,-3.16737204459848,-2.24339294302509],[1.66159176572546,-3.87703743943466,12.0488551522363],[1.18354272621004,11.7637750887377,-1.66424924129423],[8.95049308070126,7.06504590423474,0.318744951245781],[-3.74757529146643,2.22913354082817,5.14716413992064],[-0.00109264231035433,-7.03388214848237,1.93965676416366],[-0.755643562423666,6.43533674724337,9.22091956960736],[-2.98952412761563,6.7116591487378,-1.28633787073126],[1.56471990268447,1.63983171640093,-9.21368460478766],[8.94916398108837,-3.72742225607177,-2.28298706305015],[10.8777139978005,4.76250678406124,-1.30309644071197],[-4.71107987356014,-5.86824778066919,7.89420659651896],[1.07028289285661,-9.37494538719307,2.19539786704318],[1.55139591584704,0.612385088008853,3.62949336879131],[-0.182210932964041,-7.36987657916682,-5.93597402477374],[9.25115191973087,1.48367485435357,-1.24635839072003],[1.00602197844161,-4.89279180659453,3.43395114412815],[0.64341722245051,-4.62757513939596,3.76177312005019],[3.35907594861558,-9.07974179246122,0.198399479303675],[-2.49263448395454,-4.74374560028376,-0.160354113413404],[1.46983600606295,-2.88919119607855,-7.99336865343371],[-4.74662104859235,2.0666480818769,5.31598961441628],[-2.45034097090981,4.1918090432902,-7.34223255802052],[1.49192966695336,-8.38714094877171,2.62826000102812],[2.47877167556348,6.54415626287632,7.71928592989869],[-4.02991665689594,8.52571029317057,-7.10549877561777],[4.1159855852499,11.2997554390735,-2.08706849396436],[-2.25229319357245,10.4454119345579,3.66240282562252],[-4.19826601067903,0.80290789915858,3.25926803180731],[-3.57982885330555,-2.75427150708932,4.90243387652256],[-4.78953784959685,-6.0534692908363,-0.860836601053249],[-4.43347514003439,6.19764460642385,-0.40193366974933],[-3.69475759594434,-4.61490864247413,-0.728336166457245],[-5.99619119047145,-2.55393701334942,-5.28973298107194],[-7.93108923921259,-6.79313367962667,1.27809929258576],[3.2941317002768,-3.50499182968998,-10.5513710386666],[2.99382036278211,-8.81750729199784,-1.41406891271571],[-4.39728267444744,5.64893090534747,-1.27129888726853],[-3.99851807512598,0.87384280976215,2.48501809887467],[9.5240762047048,1.32775712365601,-1.61951723601125],[9.99186199220261,2.4928387902498,-2.94936874264863],[2.01150138620503,-8.94692439766882,1.66356723043595],[-4.29288767735777,-1.46344151911484,1.88379884477682],[0.417478280055714,-2.56473561943936,11.3987310546661],[-3.14177565342252,5.39439299877812,-2.24153543471814],[-3.37401382038088,0.633444135311276,5.65177947165186],[-5.38837061431267,0.87033441282993,4.40782531887474],[9.26799713952498,2.04094988677956,-1.5880261379902],[-3.28955686466735,-2.71675981694835,2.10606047479491],[2.70542369518638,-8.87402080674986,-1.45110898370005],[-6.15409112552707,-3.98962887329093,-4.65533610467544],[9.42097597570525,2.4450914719716,0.995310237693177],[-5.57600080749286,-6.37337020191775,-1.38366184189415],[1.42001673410087,-2.87254519593887,12.2054580294531],[3.33300445453958,-2.38125292428463,-6.96008786269838],[-2.41158592297672,-0.257057824768012,-4.24962869700199],[9.63292970295687,1.37779507103378,-0.969367110719283],[-5.19387684912648,7.40098768562764,8.21504701972596],[2.77490357248902,-6.30225838856924,4.37851827809725],[-3.32524911414089,-2.77206165949685,4.74658481553316],[1.60496970435114,1.77296159019034,-9.23486921434639],[-1.71352259956216,-3.18599861313407,-9.61302343156643],[2.58642318006611,4.90497725262593,8.64844737960594],[1.72973481342196,10.7752359617369,-2.97421263715488],[1.88202671764119,11.7767447631361,-1.41030853502618],[-3.66432124674415,3.46235968508815,5.82331127957486],[-1.54783570361956,7.35235889287376,-7.09084583542847],[-0.626650122991174,-7.54921316268757,-5.88187943856887],[2.1070658927941,6.34699678416949,6.82855611984433],[-2.20653687464938,6.92081468911188,-0.831668696531549],[-1.84340351184173,3.46390002549295,-2.1402929726094],[2.9476517341253,6.09810912998964,-11.7847114292706],[3.18223312809347,6.19817540468707,-10.8587025559096],[-1.74702136422318,0.387002829008553,3.44993772838236],[0.686119684823395,-5.32599762105181,4.62920366541351],[3.57057794438407,6.12906961088795,7.31447726932759],[0.526965154976253,-3.16458869599536,-11.7655753604887],[-4.87923812719437,7.44558364155605,8.8923082932447],[3.40564704168942,-7.844482040721,-1.31568367394192],[3.97025103037094,5.99489521777094,7.38461186460293],[2.56942251052479,5.98118961277438,7.52736501881912],[-4.52010926873591,0.645201894961725,5.0404754421829],[2.78540624815017,-9.83901563166577,0.249877866469444],[-4.32734650439859,-6.2363004411911,-2.07815073817433],[3.70351106766382,0.84139845182273,-10.0602430915771],[3.87684746571706,-0.795806144690499,-3.5402104295358],[-1.74584058265597,3.06217173142316,-2.43759938597411],[1.42692643131807,-5.55019323482737,4.39785890231005],[-3.66115099485171,1.87190143209124,3.59165037886483],[-2.46512928919761,-0.358881722945207,-1.18102989713692],[-4.0175791439742,8.2746411673091,-6.9974927659188],[3.02360130786585,11.202867920475,-2.88541600021842],[-5.42447245145135,6.30621421086857,8.76610535558407],[-2.77867227396402,-4.97226335605166,-1.01324712363865],[4.21876283466373,-3.02562797811098,-3.87371133854425],[-5.03756300579674,6.78191554219658,8.24166317480681],[0.707370114646968,-6.97332984808404,3.63649936136106],[1.10808733643932,-4.23780827908241,12.6902003627083],[1.36667575802797,5.45759915231297,8.69855371687482],[1.85699435060848,-4.55618216063656,-0.341441789490401],[-4.37561178322459,-5.37063835138022,-2.69636896400841],[-4.94210865918425,-5.47557746131555,-10.160455647928],[3.62845899034666,-7.92180580357685,-1.75227973434318],[1.3327189224743,-5.10328919642447,11.374896017208],[3.37654376058771,5.32532147132307,7.45554827935121],[-3.03347262041278,0.279514713296909,1.75963625296585],[-0.263938445215176,3.30006945357631,-8.55145438832991],[-0.267123762431617,-5.89351135385975,2.61404843615333],[0.252870349174045,-6.92437806699911,2.06768354422755],[-2.49004164908775,-5.22214760959105,-8.63558935684656],[-7.18108030620463,0.581022475878606,-7.4681449639406],[0.815646322521208,5.54113565172153,8.36247511921675],[1.20851465696383,-3.00930618205565,13.0240472564285],[0.583803393037892,-3.5517175993486,11.1255727306754],[-7.23669033532409,-5.75612995749357,1.44894602157218],[-3.23764087066127,5.63716978376337,-2.76457322904702],[-3.31088279115734,0.472850972695913,4.8651864122964],[8.97764345645843,-2.82807273835494,-4.10334845120823],[0.0668405167525069,-2.98693190637985,2.40525044979125],[-3.74833025130751,1.50415339521569,1.85098253615544],[-4.23988804114624,-0.119461717956244,-0.296138799904275],[-5.4950541765673,-1.48525340910751,-0.198906212379435],[-3.55220234992022,-5.30601175278947,7.68778254381246],[1.40587095607905,-9.32966321320787,2.55863664330906],[0.951506978393631,-3.21761662588803,-12.0548755027529],[0.150821367908291,1.52878775269289,-6.77832561923198],[-4.80807326535118,-0.501647901051815,-0.284671476086165],[10.3306316203954,-0.894612280208598,0.724714433860719],[-5.80161747196733,7.79193435052661,8.50718057432852],[2.88864211849998,4.29497502849913,7.96783471755749],[9.28697938703746,3.12341537144738,-2.35962314594995],[-4.30584298094438,-0.358569107460992,3.18467292614097],[4.10641105025279,0.638872044661088,-9.12470595127329],[-4.39677110847195,-0.771330219009668,1.84617721447953],[-3.96405557308096,-1.20277260523172,1.95704255522806],[-1.06384389981774,9.5435894391226,2.3833752506261],[-2.35643075738323,-3.76371515900691,0.375915628244371],[0.153625761360052,0.296266283891318,-0.941620495458816],[2.54674311204834,12.0009909230723,-2.64216600882686],[1.61666091396193,-7.91381608229989,1.66857073554381],[1.02774690696734,1.4254970252211,-6.69032677441761],[-1.72039057505773,-2.72232545596924,-2.91919444158834],[8.80238816919719,-4.32868490278153,-0.928546301144465],[9.02006318485556,3.7342873141593,-2.48593327494592],[2.10972103030331,3.73749789431118,7.22418188254151],[-2.57308447649163,-3.72076853369719,-0.750328786755365],[0.965238358497516,1.89406153993155,-3.33701367526867],[-1.84379225329539,-2.32951665456725,-12.1024031151955],[-3.67694418042193,1.06347230206736,4.86168927565353],[2.17392083659275,-6.56979837048862,4.8456051138443],[-8.82529560812147,0.349858508117863,-5.2240053511236],[1.30491400483395,4.51692494508583,8.5140644868202],[2.30342747956456,-4.82521767445858,-0.387600047529134],[4.58334677379496,-5.39781219536976,-2.64831613046843],[0.271854787266116,-2.78786477979263,10.7055468532789],[3.98943462166117,-5.31843352062778,-1.12207504444128],[-3.0903182892791,-0.13088496151602,0.485459308390553],[9.96799148098621,3.3303781323798,-1.25363944792276],[3.03005889983195,-4.93539325260584,-5.68972666733097],[-2.6127632166186,0.646843870787924,-1.00199809317749],[10.1044924650454,2.39958328073221,-0.974257072021455],[0.253387273988186,-9.34978876586038,1.64727047185905],[5.07986166039998,1.75064319284265,5.03581390157924],[-2.13175940982396,0.474238007604364,-2.72697786832673],[-2.45894577171997,4.52363783502843,-7.71886351905109],[-6.04902416214668,-2.43837236466302,-4.96852400451881],[5.0028805457605,1.86926899158249,4.72189159682851],[1.62767783919344,5.83835201656213,8.38073843001119],[-3.22022435512138,7.01465951306016,-1.35729480076347],[1.99193266108328,5.59809187406531,8.92132120283491],[3.22649896017102,-8.50848247478664,0.278971049040843],[-6.64487329346264,-2.05848118745302,3.79169775812442],[-7.71839926743808,-0.805405777791536,-4.33910384605558],[-4.21695830162436,-5.30393253535275,-9.46017469121504],[0.822603724152872,0.154724790501972,-2.14161940002092],[0.431270848025999,-5.49670882630454,11.0796798096524],[3.44049562553493,11.0851710925166,-0.901274770087367],[-4.29112883772971,-0.707607213818452,3.20569491755257],[-5.43248145239023,-2.89719961350521,-9.25164302046972],[-1.43449246838568,5.2391807201601,-0.0743498199248648],[2.11449790766218,0.467240881049284,3.22239459056019],[4.19963095376903,3.83355552125948,2.78957224676329],[-5.33293809471703,6.78160256580717,8.90365308181625],[8.62955091886481,-4.23983148719898,-0.913642273699761],[-8.47660491197834,-0.165003278267826,-4.39862458943815],[2.79369833712335,-9.69956240883527,-1.72014934109409],[1.71980955445988,-7.84566380036665,4.06054231210404],[9.20735927957398,-4.32626185232772,-3.97488535191354],[-3.79821901003611,-6.21937408097049,-2.64167018878145],[4.04662295586285,0.660045824901675,-8.68539188199338],[3.2856068877083,6.67563828717885,7.54007536705729],[1.01692844143098,-6.01883724684673,1.10754843226384],[-2.08768489251577,-3.08642315972744,-9.72300084858036],[1.08742314525942,5.59748471066491,7.75824129041728],[5.08321710825074,1.62427930621922,5.04112848823389],[1.75204619817072,-7.16982614549443,2.40352376288322],[2.81057897186749,-10.2550561613368,-0.188937819901403],[-2.51147503527194,0.795333629541354,-1.30366612103006],[2.22336877065585,0.282118680709736,3.47187102074103],[3.98458164022617,5.7908142921917,8.02182098951266],[1.29133212221618,3.77402258600651,-4.01391594283586],[2.23868628655517,4.28209046562058,-4.88351655501725],[2.54376464383717,-3.64468782371364,-5.03475855165944],[-2.8885399980202,-0.308618489679021,0.231527627727916],[-2.10099169365816,5.83197085803326,-0.223573999120911],[-2.74657453069189,-3.1535906557869,-7.39059453543202],[-3.15827384916582,8.40416765485185,-6.21417655466659],[1.36566241958463,5.61789478322399,7.73285407601095],[0.254591614504145,-2.00839137302684,-2.09322259213242],[4.12501938154875,-6.94168645476954,-1.0382220033259],[-3.0838904473124,4.06613061829025,0.553690796929137],[-3.33366423719214,9.86591150704641,-6.22927794500131],[1.95685208249566,6.01191889954973,-11.504353113792],[-3.34562647145759,6.1622571764569,0.0767921903578797],[3.00463117918279,-9.69976470265288,-1.68493849754727],[-2.88623766387202,-4.8327597323124,-8.93829872871861],[3.30975721139454,4.83764586009834,9.11017838190555],[-4.91485505832196,3.32201798839821,-6.48191420269228],[-1.79087653674886,-0.0360475741736156,-4.57360222815647],[-1.200207482708,-4.19719361526563,-0.570867418384642],[-2.94952721805751,-3.99386815222711,-1.02913714586039],[-7.89884786464446,-6.82696042536451,1.17836339009364],[3.23241309175807,6.24228317322519,7.48974864353625],[1.9743783028357,-2.39381889395165,-6.99755618309028],[-3.00983657231206,0.482853769307894,3.01734762264294],[1.18805319222039,3.30226230126372,-7.3403840980311],[1.37578466766407,1.77569586485359,-9.6570999488672],[0.182252193963617,-2.73275675652451,-4.87841389773204],[4.16269683664184,2.26705161576082,-10.3875327417026],[-8.39759188239878,0.272135208071723,-5.20113756489262],[4.03864069311451,6.17565938816295,7.72096111510283],[3.93205010184883,-5.80955039088731,-1.12840270163707],[-3.98479883436524,3.29807953576719,-6.53269706693159],[0.150494023574279,-6.38382806412775,-1.30333000248836],[-3.51739329733282,-5.74659468426187,7.58008366896532],[0.232399017074894,-3.56148451305014,-12.0484871453687],[-4.71914252100096,-0.327939135253723,2.13364512477478],[-4.50401514372902,5.30180948735656,-4.24306882052609],[-4.93213256132607,-6.53970878042419,-10.3945422204038],[9.73267314821828,4.53038721760948,-1.06432000277887],[-0.131023997903863,-8.30951518496868,0.991311487995913],[2.74954567623599,-2.15165726666742,-4.5389487880345],[-5.92882173588797,-3.30843111019357,-4.63042189033359],[-0.268741450772349,-8.41067769089242,1.47453084702523],[1.61852723342835,3.30234946953291,-3.77803239630869],[3.42407759401924,0.335956621597478,-10.4138268642299],[-4.44622228149493,-6.31914666376174,-1.11644629834408],[-9.74496984942706,-0.653336727374846,-4.37480740071235],[-6.90087255641665,-5.47228934988027,7.41394511612468],[2.90782162818983,-9.24172593717226,-1.62756908736632],[-3.37279004658812,-5.30400366545714,-1.27140060260154],[2.74139255252124,-6.84105346917532,-1.68782896083593],[0.825482611472224,-4.31236454258287,2.58997249425337],[1.53031210852685,-5.67750141454908,11.1028438045317],[-6.07473326665518,-3.83800988989565,-4.6951794419017],[-5.46945543190869,8.02239014361643,8.48600256941862],[1.66044921852104,1.47951642278523,-9.36636582299889],[-5.02608872776775,8.0546226399601,-7.53679180970641],[2.06656603004204,-5.34729932732164,1.72310505820636],[-3.37795434308082,0.783834124737555,3.14104011218063],[-2.82310549306569,10.3663512508255,-6.33941327364623],[-2.13683882977754,4.62718202068649,-6.69035468001298],[-2.03788174601891,10.7182579153553,3.42711255535262],[2.75418487272838,-7.91144936352756,-1.69545441761455],[0.60024196833387,-3.44775776223324,9.77337343421199],[-1.66038182562761,-6.06228054378759,-2.03580388160112],[1.4541571769427,3.82191610647484,-6.80497558330396],[3.08375561989293,6.28201526599795,7.91440419697357],[-1.49356334797373,2.86140641245823,-2.33632137809605],[9.88722425200331,2.8894874131016,-1.72658020105713],[1.98391634165738,-2.24627835689185,-5.81542650649549],[-3.86853200646797,-4.27177778150217,-3.20595527787454],[-0.253027747635433,-0.318021830454264,3.1535826301026],[-0.646092736277771,2.87340276090843,-8.54677271325379],[0.255283965399152,-0.0309080886884163,-1.78771782919529],[2.59609483527114,10.4601642728124,-1.51005200396518],[0.984194980935719,-4.47909792253215,-2.38123497557801],[3.1917744741907,-8.85445731746406,-2.13935621287419],[4.28709574349521,6.11754898580634,2.4897293911145],[0.210332095097941,-2.86136987651941,-0.559424128391255],[9.30029461398096,-4.10725416398444,-3.83889502130692],[3.41262351220733,5.32003634705323,7.62170780445425],[-3.79857211503968,3.48082323695303,5.70131546793205],[1.02845283225772,11.7697675894492,-1.62576341354365],[2.29296256750708,-3.48346825968245,-3.886749520533],[-0.583007147419347,1.64969298822358,-2.21834106827283],[0.280502325652858,9.44177420499289,-7.51633786328836],[-5.18296542153334,1.00240532291966,3.1753378638687],[-4.25862692834126,1.09447792670273,4.30896458075865],[0.971558186095408,-4.70985723373743,3.23593682172284],[-5.16909861308081,-6.24794183415194,7.38942811326578],[3.23621549920406,11.2562257173215,-2.08658766067817],[2.29811715168148,11.3122945562875,-3.178229432254],[-3.44891054144926,-3.93078958124106,-1.56374465425355],[-7.34219730535275,-7.05882553709282,0.933160809244677],[-0.444926438424977,-4.80836566059719,-0.743771126274663],[0.681624652858839,-8.22826152806185,1.31533453255917],[-2.40841774964385,-4.33277603584651,-0.515100613325428],[2.6434819322539,4.77263115018256,8.307312418461],[-1.42022963101596,-8.20507171990776,-5.87952284229477],[-2.40240026967774,-1.51686508718817,-3.73899419329415],[-3.27650323356112,5.46037563691975,-2.06841956637277],[2.08319009994746,-8.52689162292865,1.88495754639015],[2.96668233812729,5.82545211008155,9.20344969644631],[-5.64714434901222,-1.13035418545913,-0.0293421528130178],[10.1155396668941,2.93089939542232,-2.36156908839957],[-1.03833480451733,8.18018386463399,-6.94340145459488],[-4.15358769236815,1.19997366842642,4.21955123903099],[-6.01346817061793,8.13582813167002,7.8720135127696],[2.01124436450873,-5.67322400763571,1.32914190061155],[2.99850364542794,4.62155683941068,7.97584450012953],[-6.13542633289366,-4.39613820522234,-4.00439760933151],[3.73651982778754,1.70085918522879,-10.0021784926026],[0.202209641469538,-0.137087889501803,-0.904367617426538],[-2.16442255466548,0.45253435543177,3.24593213843813],[-8.24606003070633,-5.49858410156465,0.5010954724306],[-2.60939989350753,-0.659144032216707,-3.67855762385137],[2.96516404550099,5.50383914432187,6.80631145872301],[1.59574054447055,-2.52578128488195,12.6122092082018],[-2.99734802556792,-2.93285556690663,-6.46128540939897],[7.52062835869346,-2.02189650223694,-10.2058313018412],[-3.00360171186186,-3.20104246295937,-1.24402519146264],[-0.500263968825866,-5.01089936496543,2.66685518946715],[3.06076170768764,6.09319397125597,6.80081509221459],[-3.35413728183398,-1.84244635017811,-8.32812520317634],[-1.05411475375947,6.24403623778264,8.86043413397393],[7.88098869474355,5.60005876795654,-0.679052408605695],[-5.92212243249613,2.33202600768395,-5.3500594942548],[-1.40477936191709,0.753627017955445,3.18009151660373],[0.704548519466329,-6.6081837495,3.5311784864361],[8.01816614759906,-2.9966949606012,-4.54787289733871],[-1.9324807200076,-1.94786068306612,1.39282966827879],[-4.69096177442929,5.99644247224743,-0.294650575832347],[0.931184364744735,-9.06712151644746,1.59794640442394],[0.0628280738724037,-1.49127530826437,-13.2523010012088],[-5.54759703226007,-6.10914709770056,7.31896553042249],[-6.17420355851118,-3.00778489150451,-4.554817828543],[2.4598722492043,-7.73096407239077,-1.32814036048294],[1.23182382164715,-5.21717543972769,3.72518814768692],[1.32381697462552,-5.52111609771569,11.0488416723187],[2.63144883417422,5.94872548953837,-11.6687097921714],[-3.28608396374911,5.1435303716089,-2.41202099673729],[-1.82330974662389,-8.27036380401973,-5.53987750830184],[4.18256481339139,2.80930405224909,3.0095751984265],[1.98017509943643,6.60588015624247,-11.829406570908],[0.693098614240464,-9.28214975416925,1.24170451505662],[1.95997165168013,-9.65617906117993,-1.19100760692431],[2.65051723569097,6.05145388797448,8.7112080484283],[5.09454659971362,-2.9750782670897,-4.30700433724092],[-3.194705747352,4.56551118355916,-7.43176214575359],[-4.96131285407829,8.96562079754153,-4.13560963111844],[-1.06042067749521,-4.98154354735691,-3.31559226764461],[2.75212775251415,-2.84536129924163,9.48294075235531],[-4.22123724837566,8.36413339387046,8.73748682602812],[1.73525795283103,4.12929666367796,-4.12537590911228],[-1.23807154387848,9.56633476488988,2.91651428969003],[4.8970642601134,-2.40136477305998,-6.79969561078249],[-3.78453198487178,0.30461648036777,4.93267322963245],[1.54609697514011,1.61768423094207,-10.3790493173373],[1.97876829566748,-7.55290321371109,3.36464308961134],[3.30263476763813,-3.41708465521813,10.4228462624951],[2.3638973643111,-7.31404138813936,-1.41473907902769],[3.43471717046746,-6.50856075450567,-1.49030327959295],[8.07057618656962,3.92565091842619,-1.2000185031825],[-4.07761172683162,1.50861928856568,5.05301009783769],[7.51365401658377,4.32902769016532,-0.413196178548938],[-1.71447230772557,0.365300985246638,3.16868880213574],[2.37226663883975,-9.19660836382208,2.62786550583717],[-3.60698783528329,0.0494219294930692,4.81324161862201],[-4.04697413445626,-0.0288980385540548,3.6821003063672],[-4.3628917616095,7.91790521391178,8.90098134993467],[2.05888889438649,10.703293857136,-2.13084763956186],[-4.10536359621957,1.23912064901055,2.37835254019306],[-0.0503744270693869,-3.28300230945396,-10.8505013228724],[2.80660133339465,5.68774314460188,8.3113756507538],[-2.10096599497679,0.377889275628479,-3.45464562675286],[1.08576682604649,-5.16597110531699,10.5938666145664],[-3.0414652887552,7.06988999815338,-0.0545908499524642],[2.75416408495558,3.24660575465883,1.10987084487771],[-6.36656178805061,7.659851107671,8.4752617967421],[-4.44246184624216,-5.53855480059401,-2.38981841714388],[1.88747635952723,11.6885066855201,-1.88010091775028],[2.04415217728275,-8.75010796726188,0.185261220560306],[-3.54913875098176,-4.49160663770748,-1.37809528493299],[1.55370618613272,12.2889682978024,-1.8281614728074],[-3.20313284651091,-0.464716834430601,1.42419863996751],[0.597829809488259,-5.3675457569201,3.90587036264668],[3.48876636212819,-5.67579208406707,-5.0021251039331],[-3.62477399546574,-6.03553930249611,-2.24287101896123],[-4.34451381061905,-5.91979950505587,-9.70678902734728],[-5.36616260967484,7.83745462636301,8.41279607954385],[3.60107756112645,-5.39657206594568,-4.96635312364114],[-3.85965052929763,3.20426580240521,5.32527464393122],[-0.629574838713721,-7.42425985142134,0.743464858090546],[2.85581057633775,-4.48062943783223,10.9649928727766],[-4.32505282051737,-6.32405874241174,-9.83134964507835],[1.09877726413492,-7.34575437145811,2.05619237879882],[-1.90126479066672,10.7486793532566,2.91708849886697],[-5.48605015274859,-1.09744312144045,0.676317999738946],[3.66519328754085,11.7815717252639,-2.30740424685225],[-5.85180345403005,1.31344105986937,4.41860189334355],[1.83971707098048,-3.40527061460554,-11.5100122878057],[-0.631454927435741,-7.26880068827839,-5.7840876515365],[-2.23957139134285,-4.81904803245616,-1.30028026766187],[1.18363962258781,-9.01713938073073,0.901896993341999],[1.56666814738557,-5.6800704013964,2.86073934762688],[2.90413853703007,-4.76166757235806,11.0101281577581],[1.21293176144674,2.71374329791388,-3.67622446781196],[0.771208316776855,-5.48838535292825,4.63297350269825],[3.3192318663715,4.84466178088445,8.86577874302388],[-3.84553254788186,-3.81901501052409,-10.5424048692668],[-5.82824823090682,-6.3782733494594,7.36898079861284],[1.36670623528449,2.34871475105198,-3.04847671525728],[0.832604441969497,-9.04119202202262,2.17123955107803],[2.79790114253753,5.72165476192725,8.38894397310092],[-1.53950236834964,4.8618380154234,-3.14482744660332],[3.41211747025715,6.31226165512833,6.93932342391604],[-2.81133953840458,-2.60428864983212,-0.372151586675191],[-5.16747267490605,1.07444671047995,3.94048693172124],[-0.304439319094448,-1.05079004530447,-11.3045784595988],[-0.2736799946626,0.360633843796507,-2.94580264025184],[1.70139127999855,-4.81366189153667,0.264843844690848],[3.1120566427886,11.2346337020584,-1.8065818902663],[2.64356301668105,0.0660135693303174,-10.1974157989911],[-2.50720953461676,4.78985736915139,-7.05335184354578],[-7.18879603143178,-5.26921035975845,7.48883712528211],[1.82301263341234,-7.3357346983891,4.32921455849622],[2.22852427775486,6.01955933663498,9.79081606101952],[3.27132418251286,11.946694876377,-0.662143702902166],[2.88853793744206,-9.47895256686989,0.732057855912248],[9.17950021788569,5.88135815374932,-1.18370675721301],[-3.13581842968177,6.71232365006903,-1.21301959393038],[0.153545044184463,-5.60231370866806,-2.23572590540895],[6.96011541608274,4.77676320781469,-0.102140617499427],[3.55147964796328,10.3854028085977,-1.24145124905802],[1.49160462641177,-7.92050938204381,2.99890904865005],[-6.99011957701048,-5.84308269367677,6.68185674225943],[-2.98133700746445,-3.5127442670322,-8.20982867852215],[1.35623371608083,1.58347830561258,-9.8168557971396],[-6.34526209684981,-2.88665185470312,-4.96144380172358],[2.90951069211352,1.92345498314312,-10.259779167274],[-2.6786982236547,-4.10107700084202,-0.144114277398281],[-0.922516513823168,6.43168704766429,8.72777015220811],[-5.2783571201436,-3.26759531112157,-4.89986223537047],[3.15492233452467,-8.76534150289501,-2.25096516023358],[2.21288941616626,-8.49699565230746,-0.190053010938584],[-5.21430422180452,-1.35779811169543,0.725274811685507],[3.99701308724806,-8.31752926163219,-0.485559892027281],[3.265827151932,3.25747698741816,1.28565874510876],[-4.73380665370967,1.02256656596365,2.43149677602031],[2.51962348359178,-4.18221026849864,10.3522163458946],[-6.59156355613185,9.87565164586307,-4.25477078691311],[1.50784185039045,-4.61771971475704,2.70461363471184],[3.58058328696925,10.0079198372691,-1.30194517389467],[2.90840516170291,6.19872960177253,-11.5600768759774],[4.58381753528114,0.158673109628802,-3.56067904739381],[-0.633514488808777,6.54228133431321,-8.36363674961361],[-0.45226163274333,-0.466853664185995,-8.32043316397601],[-2.21797481298675,-0.176955973962085,-4.96378574033278],[11.0767124881475,-1.84134505833248,-1.37442302911505],[0.696829117881128,-2.85465992118467,-11.5665933184782],[1.06275822674104,4.03617398577783,-6.44577059627906],[0.43264753073675,-8.4927118014969,0.149908384861479],[2.94033680232681,10.6906017730844,-2.79891561698921],[2.51033647367679,11.7877134276281,-2.33100929359647],[1.39761739968596,2.27058252826879,-2.35919724483165],[9.30172716953215,0.616415274747209,-0.51181378343104],[-5.20566221547089,1.50662140906318,3.86326499238907],[-0.518143277478862,0.655600798823883,-6.30353816126022],[-0.641420542339675,-1.29679178526605,-0.146132406340388],[-4.20030702656522,-6.36065607019544,-1.98003845828035],[-9.05882655586145,-1.73741014716898,-3.0690772121267],[3.57061062226085,3.09388831247418,2.84955988981646],[-6.27594112582988,7.47767234478154,8.44266266063016],[-3.92399726109505,6.76438187055854,-0.947119013788665],[9.48390220242618,-4.17112217785192,-5.73163510380901],[3.1891118037473,11.5880981759535,-1.29477726093762],[4.223847038975,5.17095482186435,8.93252657664901],[3.75423593498015,-6.54185144979265,-1.33073882636821],[-1.98204341099946,4.37346702349961,-7.10415362321746],[3.60636632335083,-0.298966683566086,-9.97149760839441],[-1.06699203886435,6.28315861620644,8.98427669895782],[3.0315403681562,-3.19488022379647,-10.5873133746042],[1.24903620151496,-7.95063410176923,2.21854282091452],[-3.05533841447788,-3.33768334503498,-0.256825585909931],[-0.448368154980761,0.753825233564431,3.47572876989992],[-3.11741476683618,-0.932137744531415,3.29775191964672],[2.00046271766765,-5.96849750934928,1.21607923385389],[3.42941264753552,-7.41639386123766,-2.14372991916403],[1.06867248310139,-4.44069271737423,4.21128689286779],[1.81802578769316,6.54153211106535,7.83009362583322],[0.218961450866188,-5.4443130758238,3.86602486651752],[3.57555958156084,-8.65586444491976,-0.742824100996174],[-4.06464636441469,3.52982515519464,-6.66976963416942],[-3.91070887896902,-5.63715185936805,7.86297749535494],[-2.42931663084217,4.82910127611339,-7.4406205342644],[3.20344928392761,11.3158964860217,-1.00969172310381],[3.03812973193227,-3.32295855334804,-10.6813011819474],[0.181587329447891,-0.158910760516509,-0.874878121419551],[0.798777814151935,-5.22354725503902,10.9864969122166],[0.00201894615745546,-2.40989671940469,1.79215178948706],[-8.72743774605534,-6.2075907631851,0.765681487580374],[-0.135386162111494,-1.2673937551265,-13.5233428773256],[-4.11587216497548,-1.79085255978783,4.81746241633342],[1.84013054557921,-7.31311339125173,1.76934649637319],[-3.49291667587459,-2.81089030531155,-1.78321089546768],[6.97753182725428,4.5394144497822,-0.698745323623496],[-0.378575716587841,9.41327801040761,-7.58948126805289],[-4.71555253367883,-5.70944991263055,-10.144872793558],[1.00089832810776,2.28515844523072,-2.7940465475606],[2.1262476179108,-3.81430712584365,10.4546890683137],[2.54306459931575,6.17820905140843,7.3151315782003],[-4.29978125514276,0.792258066173896,4.31897044560455],[-2.11628705568922,-4.8098564963367,-2.20395850096115],[-3.13778650261118,-4.42828403946693,-8.93939995209139],[10.1236290549601,-1.70928281664559,0.57482710725746],[-2.84183975725636,7.05511920178745,-1.10492552924878],[1.04838509739929,-5.37368559727553,4.10815549790426],[-9.37509830200791,-1.92337657085285,-3.30693561634949],[1.81966773403105,11.4916312756128,-2.00138458732555],[7.3358962085862,5.49173505134929,1.44227407424362],[0.420865485807225,-8.44238001081315,0.910720404864401],[-2.76486814911985,10.5913104211687,3.59906556524663],[-0.418186195263018,8.96055242070896,-6.9885958731324],[3.33919435768784,10.7021672865877,-2.13787142028718],[0.574185964514282,-9.05725914386189,2.32535015507012],[0.0624809351879571,-7.65540291278964,0.635907053804787],[2.02789100401063,-5.72255290824887,2.21557187719522],[3.64445668999544,-3.50344259054454,-10.213307902188],[2.57136522183388,-8.8389927136765,2.52726924763484],[-1.77210946853345,0.0257494543868936,-2.65217697991409],[-3.39747815420262,5.34311262862353,-0.149279249133408],[-3.69442980187209,4.65361759086969,-2.518582114034],[1.00625789087478,0.563657312058009,-0.749361668853053],[-4.32278640010138,4.9080558918393,-2.38436545623206],[-9.31367436128983,0.798812947617425,-5.76684447579109],[-8.20326068800733,-6.85271814935382,1.85222714189987],[-2.87532910349862,2.33230689175835,-5.35542410877911],[3.32845610626359,0.722062963339253,-8.62301222732735],[1.10359257465139,-5.84511331412368,10.7839856079712],[9.09802131668369,3.28725503200295,-0.891022317539297],[0.818631322652645,2.6585024957052,-3.54324966478228],[1.38367881540471,2.10267964099858,-2.65623041906027],[-5.37780011053302,-2.84641011040864,-9.22588208334597],[1.66865084559223,-4.56890830489582,2.98022754603733],[10.6080104022706,3.3004044416886,-2.02278193642692],[1.92024645349751,11.530163964228,-2.28921306716195],[10.3377154563866,4.24864518234499,-1.10466879442413],[-1.77451281226414,-2.01022510192719,-8.66841779999283],[-6.18256733931239,8.54027200027565,-3.97820331775974],[-0.222520534819459,-2.62191056427242,-1.38205554641152],[-6.16439088867197,-5.9165149328202,7.61260708895564],[-5.12380487931223,-0.0206796971331519,0.0891613725349619],[1.09923088501636,-4.72058549559446,-2.20310533109263],[-1.56394003008008,5.53681362213114,0.365549089572801],[11.0333642226012,2.38011425028416,-0.974897719721945],[-6.06707251279521,7.52185462282057,8.07134580237478],[0.28444103087396,-3.16802668772513,12.0803713526642],[1.97043479224675,-3.04852782907525,10.396571752255],[10.2136168749658,3.68387355890171,-1.74836413261595],[-4.23805304035071,8.30782807017317,-6.36920674664927],[-2.95283084670912,-3.73566001478885,-0.111489153393858],[9.47958458674735,5.54852523549709,-1.29021438828669],[8.42237743185885,-3.39617694045221,-4.87351549312033],[-1.51638161442529,-2.05507000250103,-3.92558804670839],[-0.253254516851174,-5.4783167228052,2.01831237682659],[-3.9517234601141,5.26388631330627,0.373075483300055],[-3.93528407478049,-5.10677436368188,-0.85428856223155],[3.04470999139231,11.0131204736607,-1.63276951823196],[0.935902302252744,0.355786603724507,3.29218209714654],[-3.76496099192763,-5.57423388795629,-2.38945011930557],[1.16641487043702,-7.68951715132651,1.47529901183345],[3.3513323104938,-8.41344400090686,-0.393695553129827],[0.831409256127239,-7.69006246796282,2.65573798258478],[0.309634605493934,9.06675959810998,-7.91650654031033],[3.24765460256848,11.6567556106008,-1.91656212152047],[-2.6061761554157,-3.5257351367519,-0.95753973178687],[-4.49598999296879,8.32989485933867,-5.90456523335508],[-4.32286382742044,9.97262668285071,-4.80423249155948],[2.67465804071408,-3.29143506060207,-3.76674989561535],[-0.947118692003658,3.05473351032844,-1.34163768707283],[6.79626551554211,4.21161085767915,0.184424323510049],[1.93446623622549,-7.57742914718946,4.21326001910081],[2.44812053530836,6.62086674146026,-11.8381956269476],[1.47314949874835,6.19640590159407,8.90492764993307],[0.803880654686114,-2.74222566167805,13.4950509824648],[1.7945614376021,3.29703978712879,-3.13041004498564],[-6.33723643851284,-2.6016229374811,-5.14970155781072],[1.83765806025828,0.716312653204926,2.89296022152109],[1.9415016476501,-8.21664496130078,3.59810812889375],[-5.44268306428936,0.969266212774246,3.6044122170426],[2.04355733830945,6.31829590997774,6.72110158293886],[7.48582303032506,5.65304292117119,1.50851622027995],[0.864609217763128,-2.90897887723535,12.6527691722566],[1.76454548594646,-2.58042518930845,10.4208688182588],[-1.28298344276902,10.1749086706359,2.37793616139796],[-5.09508036948414,-1.48449971929149,1.73030846429219],[-2.73410517697316,-5.11951496928014,-8.86249210585051],[-2.67137963971784,-3.65143261025029,6.65866263378589],[3.32189845821617,-5.63020676590112,-2.10936896854509],[-5.50840287318031,8.9748683895128,-4.23632594526057],[-2.3751141735898,-3.50766242765561,-9.30521877934698],[0.887832713270216,-8.58763806796772,1.28101911289623],[-8.370547738108,-6.0080536041588,0.567123661952582],[-4.15705427001894,5.62822072000082,-0.222875770583949],[-4.66274123204139,-6.38164353451876,-9.6415334121522],[-5.63825507576138,-1.33821957142886,-1.12598834586054],[-2.75435548503415,0.480341566505255,-0.685444662276127],[-2.45427348803909,4.01852734387746,-0.07495338356022],[4.93766203878515,2.71724487870043,2.63528148018171],[-2.79385326097368,-1.017789446548,3.15857795414514],[4.58693435881393,1.64960407610585,-9.22145669407946],[-4.65892566874628,-6.22238101559816,-9.47598839154803],[1.26369712838403,-5.24745237997306,0.460028024239432],[0.274094104683169,-8.14892476190819,1.02262260626902],[-6.0462746976857,-3.56296043927979,-1.63112060144426],[-7.46783338754906,-5.64643231507878,7.0573069516941],[8.95245422150598,3.93622770318301,-2.60721791814918],[-5.01573208654275,-0.0815689467290033,4.0608499727143],[-7.16631735803652,-6.00778195718039,-0.555493621192307],[4.06526611195547,5.81013389948497,8.26451259811686],[2.01744308475496,-9.29067848954326,-1.23196268115412],[1.52065425962876,11.9146078496491,-2.24283759961202],[-0.445966640815307,-7.97959314171564,0.865378958731285],[9.13623425919959,-4.0571910722776,-5.23251041122602],[1.77081696170176,-3.71687051024704,12.158041238939],[0.535109094407588,-2.47848294802275,11.4288787785193],[12.2163268682227,1.40600253153016,-1.08575098452261],[-1.51461433077353,-2.59269920588699,-12.1125382572139],[2.38728818205813,4.57135376945674,7.49806053692368],[4.48785252005828,-7.16947874402143,-2.79553720225368],[-5.36305227649411,-5.88416148632905,-2.1012439297205],[7.54064062868927,-1.70897735118932,-10.7844119678748],[10.397649866356,4.1979739068943,-0.813359209999299],[2.00290936069195,-3.27227072696417,12.3017419836463],[1.11273545310621,4.18923240119365,-5.81897917804672],[2.10702796945991,2.5021390729759,0.492806534713506],[-5.58580810035164,1.47084542006832,4.6631920162111],[-3.24019619309681,-3.23476402034734,-1.20554337276586],[3.38067506657867,6.17094249063094,7.42694039857215],[7.3546823483951,-1.51852035495462,-10.6441430286446],[-4.76203025341329,1.53927654180272,3.04816724929749],[1.8778788092816,-2.69891224846776,-7.91619653588685],[1.48939047395247,12.2523427038966,-1.50011238985172],[8.42668490479434,-2.79923162577368,-4.40213955549441],[1.5645263565902,-3.64713867978993,11.0657088042254],[-5.3785024523571,-6.34421711699094,-1.09112689886748],[1.75264122450256,11.0738936972688,-3.17993137635242],[1.18875407433083,2.92437426189836,-7.13819858148789],[-3.40978553021093,11.5576325895788,3.89761385357715],[1.46395474651928,-4.03682978358873,-0.18056814483553],[1.79245719557492,-4.36573707408075,-0.205134215129538],[0.725043242128816,-3.10645571423687,12.8597682631478],[0.599257852710904,-3.10973080554575,11.5350319307259],[-8.1117585143775,-0.450348740953221,-8.0648700295137],[2.55973333005128,-3.39124269261243,-11.0819273415935],[-2.25152353420007,5.14876353977517,-2.92333222705243],[-3.54039644434008,10.2010212471999,-6.4934271067396],[-1.75703045852731,-3.29697903365699,-0.283769680674948],[2.13455611054721,-5.9619267263998,4.39188445206678],[2.02539489986034,0.143523232879084,3.58823132444345],[2.05309382890358,-9.44895432908423,1.70084750357118],[-4.57838243556063,-1.19669549284141,1.93190939884705],[-4.48747970870259,-0.155626149740723,3.11052405917073],[-3.90095606032149,12.1036671312517,3.88950457511303],[11.6686327190322,2.24813085845987,-1.26310680526338],[-1.609095671983,3.14874780632409,-2.29208633007667],[1.36912955775498,-5.99293043737671,1.34520317273298],[1.66044532982222,-5.58738384551943,2.63271844120432],[2.89216784037398,-8.93793048579252,-2.04447765583002],[-2.58009627462237,-0.0521445379902162,-0.589820123799369],[1.61261033787808,-4.27819250975657,2.90554751544029],[-4.03222633149807,3.42600170724651,5.64974219063298],[-5.51790599022063,7.14978543749535,8.91354565490256],[-3.2591723108017,4.34156519389338,-7.01865593194162],[2.98355579482078,6.04911630392314,7.20128236743658],[-5.55098561364138,1.54726221370729,3.17644422666719],[4.11633240952862,2.33680737844436,-9.90431724790781],[3.04064002640529,4.07907388806714,8.00006105833061],[-4.64008220140206,1.26431854657459,4.06791193772691],[2.93203750412808,6.5427905391015,8.08375369950802],[4.10567226548461,4.89130121891238,7.92448119445268],[2.86090197356983,12.0642425503475,-1.13619498235211],[0.618837481854374,-9.04257054819274,1.8426630062096],[-8.66941765054771,-5.65265678930435,0.764588667829662],[-5.83312865882234,-4.75752543318631,-3.77735036299165],[-5.10657349005961,2.67767901096993,-5.4632924862759],[3.12204841225871,10.6546297760064,-0.921507377450646],[1.13950682443597,-2.66383091786427,-7.8025329565105],[3.39274241360314,-1.37506603128029,-3.98205350374056],[-2.05412546211142,5.74421257108686,0.478313749048783],[-2.61310887015236,0.567435077860096,-1.28950393356377],[-4.14701184023019,2.62267047710256,5.26236740178143],[2.59685336069139,-2.88102691513613,11.2398857243966],[-0.753103961074285,0.798539043269237,4.59234720181575],[-2.06793697501302,-4.46211603912767,1.97090707609529],[9.4147624712172,3.5498477107051,-2.81733804321438],[-7.64502750761223,-0.049876131102764,-8.69151503448904],[-8.28040418232117,-0.249009794125272,-5.55196388402915],[-6.68588129027995,-6.47453173125594,0.068024735126376],[3.22164324554344,11.9072069253894,-1.9304431508425],[1.57598392785522,-3.10251180583848,11.0024748038634],[3.57382418405311,-2.84861081717054,-6.69625871607867],[-3.42327273701018,1.07849264460982,3.500058164771],[3.06653401888051,-4.00583334716333,-2.04176115925227],[-5.14834228996812,-4.9632915236146,-2.26182692896295],[3.5151886002178,-8.68068133527755,0.1058744274909],[4.76675194386421,-1.8637956753647,-6.77231610392024],[0.652265618205338,-4.5687532314131,4.17109863826547],[-6.48632304450295,2.76475540322462,-6.34275958376692],[-0.177782588710238,-7.25645554354693,1.31541980741112],[9.61446965155355,-0.279360085491408,-0.458545630206313],[-5.94570380395444,-2.86001371286279,-4.63064145320604],[7.88699500131433,5.50479287239753,-0.709867975989323],[2.56930414090299,3.97631632703081,7.53090365719144],[-1.81467770782989,0.381453334386561,-2.84749508245338],[-4.94369493669745,-0.722496090316642,2.36701282778033],[-4.06112706784543,-6.08124415202612,-2.31493152166817],[0.243328174561942,0.165353163701639,2.89864569570567],[-3.8944886187576,5.37463513583462,0.0395998746148681],[2.62347912397716,5.095080506639,8.88158022999821],[-6.58478836795914,3.10618473575212,-3.93527574862131],[0.677007701470876,-3.67786006880275,8.55182001331482],[-7.78441624563889,-6.5185917878306,1.49960182184082],[10.4235119384024,0.658084737794177,-0.734075007439183],[-5.20718913908142,-0.695109665395868,-1.14358617236724],[1.32736952521578,4.93278333974198,8.63686012281496],[2.11845138585916,-9.74463419340338,0.300460128950152],[1.2780309924478,-4.39107760001661,-4.91700476252862],[12.0314024004397,2.10575180097664,-1.56575854340423],[10.2544904957762,1.4224676698575,-1.42813607859397],[-2.64086290945149,-3.81184384621125,-9.65129762786654],[-1.44414815590148,2.80583995568867,-1.87764298613792],[-2.52630464952426,5.53624771792636,0.899960209390471],[4.21826802127448,-5.97007106353853,-1.717252955033],[-0.0194474545619493,-0.88884098286314,-13.6933493702007],[1.65143580665991,1.79061318492666,-8.8684251296673],[0.886408310369896,0.228824751310453,2.98379002087293],[1.81830391277644,-4.78486272200184,2.9448379289035],[1.07073384491408,-5.11314668310679,10.6832295257914],[-3.96154695484438,1.03906780050424,3.94687703304505],[2.58544086874158,3.90878100485465,8.16444925851853],[-3.29190513819967,-2.35081682081821,4.55736547069376],[8.79006764498384,3.30169732429169,-1.84213979640514],[2.60974691263807,11.6080881929268,-1.90653162209682],[-5.18640688302107,0.930015545936997,4.51951194058266],[2.34547129133674,6.40932778275714,-11.2374046613061],[0.290752858963693,-6.99242056825685,1.40627346144293],[1.40412692494041,-4.1835368945618,-2.62307323994587],[-4.02835657072079,-1.33125189191741,2.14687477066218],[1.17688959866038,-3.28608890548743,12.9426243806796],[3.40311592677671,-5.39675816474071,-4.74972340084976],[0.499448520269302,-2.09273394125956,-11.3300781889764],[-3.98120982605669,-6.46613705273651,-1.09913095129656],[2.10281641218297,-5.56118036844671,5.00119550284131],[-5.85104340634179,7.80633296433311,8.48722316774315],[-1.72887462490342,-3.90525498133869,-0.447597379879531],[-5.77911798881216,-6.41865749717625,-1.84591290870801],[2.82353944740171,6.23575523412119,7.52708372357573],[0.54666223825376,1.49215205618639,-4.01471523173767],[-4.96203845634566,-4.91811365030231,-1.86904118683541],[2.61019057282394,11.0716837238402,-0.974702511333178],[-0.0988007183016358,-1.37011674189479,-11.2346832199108],[1.07441203387805,-4.29581709036881,2.32104166337565],[-3.55974840224046,-4.59888056953936,-1.89793892813361],[-3.45599582733392,0.463506012381459,4.63148835512832],[9.40275960380183,3.57797946728918,-2.53780175655957],[-9.49394770884918,0.967755973806005,-6.2405365509563],[-3.09156361490156,7.83970778263485,8.42977809423537],[-6.83653131928261,1.9366476689021,-9.28410100708953],[-4.31142603625086,0.17902727364414,-1.01235574178248],[-4.62305106951432,-5.4875895934524,-1.681550853327],[-5.32356851432808,7.67620639669121,8.85570948057709],[4.89701854977062,-2.75597534604594,-7.09030887687276],[4.07258479756485,11.2067031045677,-2.1499801033735],[2.67194740184686,-10.0756217377612,-0.634820258928656],[3.58035520757629,10.784274219465,-1.2016029972278],[1.42793030209157,-7.84165558308124,3.8442359211355],[-1.81190167478747,-1.95634207413502,-4.28666435234179],[2.57220324830214,6.22594647914064,-11.781577222302],[-8.82444985496306,-0.0998157217200857,-5.25941862092203],[1.28942325164413,3.56532966229758,-3.04956796987845],[1.2834779586466,12.5745265553075,-2.0683730105631],[0.157466983393432,-2.5265277929118,12.8610066162171],[1.14643267751675,12.3773809837593,-2.26910236413336],[2.45370157264589,6.65161898521098,7.71231900609433],[1.4812382032558,-4.54731826277989,3.41377313341732],[-3.72334227412967,7.78956661128672,8.41801368357093],[-4.95658678216431,-4.79434615626365,-2.37837546111673],[0.199313284866382,-2.66152861316026,9.33041842613391],[-3.58270964343426,5.64466797415853,-2.79973489605346],[1.17950200979536,12.2276846641871,-1.5501054252999],[-3.79808379518231,-0.560674011068797,3.02761104368111],[1.0011870543818,-5.44135980673738,11.0326949600506],[-2.58311859124139,0.293689490241339,5.26693838536811],[3.7774981133293,11.1924335462428,-0.843703134303473],[-0.0199609387342319,-5.53520222575608,2.63746959992167],[0.693717649793704,-3.35595569729217,11.4488964789013],[0.70000382164408,-4.80398902752485,2.53310603004508],[0.539230411333899,-3.16743882844603,-11.9539048954329],[-8.89931030530068,-0.00780249202886507,-4.55301219485149],[-1.5728586646315,7.35124628160272,-7.29769882534002],[-6.21396748574614,7.643533636765,8.50884476899752],[-3.75230295619648,-3.93561369511179,-1.72143981851569],[-4.08214729948535,4.7494724500369,-2.42748721445722],[-1.69979455958568,-6.53517306085805,-0.859324883350957],[4.2635815278078,10.7495254206454,-1.21225189504358],[0.226205364913888,-3.19787783317299,-11.2670146928952],[-4.35988142359512,-5.08994413952001,6.87517592008715],[11.5538351674954,3.82515531087467,-1.12303306147569],[-8.43130664887701,-6.65056427067588,0.14522324988302],[-2.30103819911387,6.48766036335193,0.266628977348589],[-0.224557058583615,-6.85240146438237,-5.77549617596661],[4.03211945283809,-5.52510562322278,-2.03174310706207],[0.339789004485273,-7.00095474310406,2.96821060554314],[-4.3686629962164,6.10398534579987,8.52828931536056],[-3.67320406794255,5.41091749317322,-2.36297626474828],[2.93722214612625,6.04179160574436,7.96505421665634],[-0.320078798760146,0.712128235500893,-7.76983994261919],[8.29326875188445,3.53559468006483,-2.6544009426782],[2.47272069958254,6.59727883309446,7.79504946474276],[3.07210931718231,11.258172098863,-2.31274673784805],[-2.57603469097916,8.90101051968866,-5.79591468997749],[-5.31953602243255,-3.07284381797241,-3.90776820800156],[-1.53624613694411,9.42421014404994,3.01247619771294],[6.81679832206217,-1.34539193101182,-10.3133832002399],[2.62067409940939,-3.68393289324285,10.0199481113099],[-7.78135872532704,-0.162331841919647,-8.42875687703507],[0.842635509790511,-9.70792916914085,1.06102630622566],[2.63072152137314,-5.25181394303211,-6.16215860301544],[-3.16778654611823,0.698923012763156,4.01221682541283],[8.00646111273813,5.73706326064489,2.31214507041511],[3.25437771763679,3.24636586633737,0.273372533777382],[1.43250097521875,-6.84117179404984,1.53775558937446],[-3.38486923906053,-4.63640105729856,-1.72966021206434],[1.4056559042607,-0.974647732721281,-4.20926068808257],[-2.82945485910819,-4.21519882703216,-8.88535807672309],[-0.347237192185488,3.29090017084102,-8.73678038514987],[11.1627697133499,4.71575618874043,-1.42487363940385],[-0.992402048881616,-7.56574641158294,-6.04921371653217],[-2.70882451449064,-1.81132758287539,-3.71366868745888],[1.71330380741621,-6.36440158965285,0.409052725986192],[-1.89642717632632,-3.35535693132636,-1.25871975539402],[-3.2770663030726,6.75781456473431,-0.251090046848551],[-4.4511832094925,0.277985010084264,4.67889076199783],[3.80897937594767,10.6280125333485,-1.07893057946721],[-0.310489679715507,1.18893860267569,-2.31601211506047],[-4.53770257687255,-5.06913490151506,-3.09866874339423],[1.63737783369045,-4.60436211943432,-4.9846093560153],[-3.47245434454124,6.54027964632236,-1.23479786203468],[2.20399115807806,-7.99520876011434,3.98371637014854],[0.271749285309143,8.96669130295274,-7.63137805367122],[-0.0298728737153554,-2.69101635455054,-1.09599078438085],[1.64357763061136,11.9209903669211,-1.91880824083352],[-9.46173832887027,0.6211072566066,-5.4930553535308],[10.9049547766654,2.63405910262209,-1.53620683419657],[1.45028108194826,-6.58667033015779,0.335327160655132],[8.83408884797136,-4.29407925339589,-3.28574618788794],[2.90874364045567,6.64486860559047,8.4190800385383],[-4.40470475398185,1.58264346769518,3.64953048491874],[-5.50858691848251,7.96622741517523,8.33419490347436],[8.27336847156489,1.32967092157564,-1.92127625081931],[2.87345159909578,-3.25282268841311,-4.42036542043126],[0.0150612667002208,9.08457341452662,-7.53220273107211],[-3.90080074051056,7.05229471725411,8.0913848933951],[-6.93953966425422,-5.60450557122786,6.92041572146657],[-9.77952726583792,0.987619811219699,-6.20507870205214],[0.612111373445235,3.51784563884972,-8.7075565480446],[-0.272778178455161,-5.7805062153833,1.89398125349511],[-5.82461037231644,-6.12585427941459,-0.696541491215362],[-0.643541627361532,-7.7310789417693,0.285123655393751],[0.53012026762565,-8.21625242663218,0.970782221122768],[4.09530641133904,5.03212819629324,8.76049737135044],[-2.98481239283576,5.7252929576814,-0.221680881929495],[-4.98996714545116,7.65321457081612,9.0237900137015],[1.49453402283382,-9.40311121277349,1.6490467209971],[3.60985760481284,4.22709944941849,9.14596788284378],[-5.39820032618227,-1.58900986334309,-1.00826734275442],[4.10869886856861,5.93643975687775,8.69423374477311],[-4.05893058184649,1.6409556815296,4.14435841369643],[-0.350446060645269,-0.168029527345853,3.1406615292139],[1.45294445108304,2.22307323670844,-3.0226537888659],[4.41634897270086,2.57884209149171,3.07060071540525],[-3.01619959304797,-3.34867396496938,-1.71534767404215],[2.17748415972556,5.31282706150135,8.47860960341585],[1.47229548642074,12.0571381154789,-1.63669330410738],[3.2139108588887,11.3669372562527,-1.88922567126068],[-0.0105237891661845,-6.7903207136931,-5.94909785947462],[1.99133929012402,6.45553567495668,-12.1170284344401],[0.148301670773281,-6.02603502498506,-5.57192514287301],[-3.25892605113171,-4.34315607085632,-1.39746092005626],[0.78374768042235,0.313680729560989,3.36237532260991],[-1.09949743503864,1.32206893965958,-2.59090809568847],[-3.88303435923712,6.66759703204123,-0.643050073737498],[3.94332650040083,-6.83495430467507,-1.55081225136729],[-4.79416985338563,-5.79573751263791,-1.55771982407913],[5.2227589458093,1.28070003113899,6.2360771448892],[-2.88872669429577,-0.888972723935752,-7.67319499090801],[-3.7840016854088,1.5764358730566,1.94741673011538],[-2.56755293012822,4.0720103133045,-0.144976821702903],[-0.453474322555437,1.00881938863892,-7.82567619214079],[8.62592403887194,1.95075572645649,-1.61822296730495],[0.237334233757877,-2.96262198776701,10.9617851274404],[-3.45150847082715,-2.38864401373386,1.97475698657228],[1.73593653436864,10.9651440307273,-2.29011032386375],[-2.30678970471162,6.00606092272731,-0.134342282128792],[-8.34664015621328,-6.75942052306187,1.6977752214152],[7.95428936440762,5.33004865749804,-1.36458419965288],[-3.85645591949302,1.26248360503699,5.03779539737951],[-1.99953266273881,5.34418788438264,-3.22064701630179],[-0.0175033575295934,0.900035776951201,3.02122120912518],[-6.45273440540363,7.62525955785139,8.80089177388199],[-3.74438323875033,1.05011768301467,4.83215810591946],[-5.01510399776306,-4.94189444485479,-1.97539459612177],[-3.50287559828219,-3.78092858662138,-3.27832410469599],[0.597382212597591,-6.29254664283066,3.50062815288608],[-2.22969559571828,0.170790842841431,-1.53031799661972],[4.10004664750079,2.19143631453413,-10.0927887134789],[10.8475097440717,0.506766660250129,-1.08972462742199],[-8.81132809459869,-0.477067432176985,-4.63399436607554],[-2.26079693611564,5.07599423263985,-7.65253063216459],[-4.90563448381439,-1.49016668252488,1.56299681467611],[2.51777285095349,6.65922742228465,7.76051400211175],[2.43423756014928,-9.277291739548,-0.49076747951914],[1.4091199003766,-9.622961205599,2.07630119021404],[-3.47236460507966,-4.71491896757752,-1.0395291667602],[-2.16620687846975,6.23506869024787,-0.924248425832979],[-8.86518930105234,-5.92463989578957,0.533459867806715],[3.51444406217542,12.0674339165513,-1.98128187582971],[-5.07175317454969,-6.33057922260958,-2.3265971102988],[6.44107135656859,4.6564127767816,0.762449067287249],[1.80958455776011,0.568783824606653,3.50636383877586],[1.26036925216426,-8.55788640941292,1.64531773559686],[-4.74525276812084,-5.53426941358543,7.44496163539319],[-0.566154631183981,-0.178625266287131,-8.14308201623443],[0.995257489088531,-3.69025319591342,12.3022622849529],[2.85525697563093,-0.713452440990181,-12.0497421567999],[-4.17008839584583,1.26752910417728,3.28774105955097],[0.358220207192186,-2.15065075113934,12.2889815897827],[11.3715661899035,1.8846255334312,-1.38140796908117],[-2.52243816593828,-1.12312822848456,-5.74503911623341],[-3.87930493879103,11.7377195718631,4.04145036340328],[-0.367029641926021,1.82706153569867,-4.53577703866897],[1.67841572658626,-6.10356500388395,2.4116951983595],[-2.07477017264513,0.429993510230168,-3.34740076404384],[1.1268589067153,6.19945941144055,7.72404809563628],[2.81315517883539,11.7606478767533,-1.61558307516631],[-1.46473188958154,10.6014433822751,2.48695521463602],[-2.56512935526366,-3.77992136488028,0.387048680476426],[1.8199597031015,-10.5306135277526,-0.306376415196595],[-6.02666686584239,7.13186829597809,8.74114033798761],[-3.08381466066423,6.9632147921841,-0.778031624967989],[-3.3907035040083,6.07197078970115,0.190969533389935],[-4.71746927659823,0.557429140974255,3.2230123005052],[1.15447363121753,-4.64017269085769,-1.6112188960339],[-1.04519731573333,-7.74731360195354,-5.67463407295776],[-1.55440748665537,-4.90796620074755,1.45203889226439],[0.867225984824126,-5.65383203224919,10.7459950874774],[2.23678229955955,-5.50560693212568,1.21504785984289],[1.03339553220534,-0.453901295805817,-6.29046428497341],[8.38888675020559,-3.30994685894986,-2.13456813034832],[-5.52339868611564,-4.72179262549502,-3.99449256356504],[-3.00592648874095,-0.557328673365987,3.0697218985222],[0.683120911944471,-2.74009631645045,-11.8833021261977],[3.50464078668197,6.16507573085349,8.28648639839999],[0.168526991146205,4.294613611709,-3.27795632735302],[-7.56331490337044,-0.665567409414903,-4.58438032476716],[3.50443942809057,11.9798147979492,-1.74483777228661],[-3.63283708652118,1.24276031954755,3.61548220172573],[-4.91097345881478,-1.26339966920826,1.38098182243779],[-2.51589798754454,11.3717704353808,3.33930059947328],[2.89571121387114,10.7243247199652,-2.06312652018691],[1.63255065678416,-4.66016311148307,3.94102528239521],[5.73822764070409,2.54031853505736,2.39542040715127],[1.51702940334504,1.30855453905789,-10.0936266818893],[-0.0910683631276924,1.03117856848902,-5.59514918169517],[1.42728935432354,-0.943966527725688,-6.1123540974332],[3.23956841814997,-5.04156622244482,-5.60375465004488],[3.3218693582581,11.382207430459,-2.89712161463051],[-2.51549456898312,-0.907546182570387,-3.75762400043437],[3.16571281817052,6.85872039712869,7.72530362354387],[2.13507219247114,-10.1581316893045,-0.0558942305270019],[2.9416726245476,4.7226707581509,8.2900140315791],[-2.38891891885721,0.474084902374375,-1.92386469272567],[-2.44769192644726,-1.04789905920799,-4.0220120960674],[-9.14899269347939,-1.57482017230031,-4.28629459876716],[-0.549525694401758,-7.53628453014493,1.73844342227874],[-4.9558461663557,8.45204241232418,8.26569997841586],[1.85681768183481,-0.130837171310715,3.26319886580726],[-4.63952716696806,1.44837244361128,2.19809433747731],[-4.6932430294994,1.13893248486399,3.10031855472506],[9.62215203692462,-4.08118709798965,-5.69630515646235],[1.88831431717411,4.41028611752613,8.84639098836537],[-3.8122444675355,8.11397096146375,8.40416294255298],[1.32664172579976,-6.67222744243376,4.38704254382292],[5.20160906273928,1.44424733326273,5.25803957390993],[1.63297522133745,1.90426244208892,-4.91098347559107],[3.73809523601199,5.72621486818262,8.76619952800438],[3.8857936206604,11.585505014971,-1.84635903133634],[3.28710575641022,-3.61234940471812,10.5655594454398],[10.9781049168408,3.37416956171356,-1.8070928596068],[-3.91177597419973,-1.41739464804059,2.75527431802248],[1.62354528260387,-6.46855709410021,4.17541624818227],[3.70404825500156,-5.61051350978154,-5.11571798092288],[2.09758258777578,-9.42065592230717,2.62632226891105],[3.02010596701995,10.7822243749392,-2.4017306449924],[-3.24016793637081,5.15795084664409,-1.33750777660736],[2.96336165197083,12.4375331010883,-1.30116952452484],[-4.07671439384865,0.519940968532472,4.83697870396226],[-3.04301527476741,4.0974360649024,0.357066788354399],[-0.183789412238944,-7.27274342640171,1.68006240749075],[10.0851706913571,1.87157596411543,-1.44127400453012],[3.22348524995483,0.348414567949185,-10.1196431752636],[3.07928127665912,0.044646216163951,-11.5051424231087],[7.4229986552908,-1.59445798515255,-10.6655817074016],[8.5359409999712,6.95463217854057,1.21451964112853],[-0.931422937006295,0.569475028508132,4.41985109325712],[2.33100790854371,6.03594718905421,-12.0660996094333],[2.80940504808338,11.2205513054094,-2.45273945915678],[2.56904417463386,6.05967939306415,-11.3206398850571],[7.39831513560978,-1.51418066329287,-10.8686301033756],[3.43075725993851,5.01357509433746,7.51049509863322],[-4.54405986682685,6.90594064257519,-5.22607838412812],[-6.05377426177192,-3.25460146375159,4.75635040575437],[-4.52743287142968,-0.774642230422893,3.64294406467143],[-2.55218173051738,4.92490934343573,-7.44500631169446],[-2.04538752989976,0.124356521319752,-3.49987079531874],[3.67617990572026,5.65396296803314,7.75317930860401],[0.517953512025496,-5.98309108229107,3.91863139382674],[1.33513521131267,10.3752480749898,-1.92682500891121],[-4.0515237311068,6.45154859226106,8.02844976412497],[-6.39166121592691,6.88381853344824,8.96466911619244],[-2.84685121556643,11.7942577511813,3.77060797670589],[-0.184045559544792,-3.1170643074036,10.1296994604683],[-7.97046325379118,-0.716904042360048,-4.80574567499118],[7.25042367600631,3.66790542650097,-0.149442922410667],[1.10635634787295,2.82160662778501,-7.02035408980613],[6.7663923145233,4.60947248913129,0.0691371107212795],[-2.70558260373849,10.8389134300152,3.285789667693],[1.25964706868589,-8.23895645461963,1.02405352214077],[2.81807306139446,3.60997625370075,8.07361313636834],[1.41017933380286,-4.81343439208772,3.8676301223031],[2.14270194547256,4.0369119647197,-5.48468845907876],[-3.99580633605582,-3.54358107236179,-10.9510480578707],[-0.310998832188148,-0.748698471669015,-11.0148104070536],[3.76623855031538,5.91091220440739,7.59303365064154],[3.41703503476047,5.95627679528118,8.22529896996026],[-1.18367696419774,2.86723041175518,-2.03788011090645],[3.38667321740652,6.53082280044642,7.90448723832795],[-3.14805885294857,-1.25355579611994,2.10135042086033],[8.93728347584338,3.62846170043572,-3.17769193220087],[2.17146918505,5.01804750785488,7.74292020807893],[1.19662906094935,-9.71474639720338,0.26964211841099],[-3.60205373928081,0.546364680295353,4.65506866022069],[-4.90422188776957,-5.20354000804668,-2.56179406172209],[0.239017969329558,-7.02459579711929,-0.583143517392549],[-3.16894985047808,-2.59428306155261,4.72299939490058],[-2.95229654623559,5.3443288684099,-1.75689936263126],[-2.95190345835007,7.16841800088874,-0.594105681598912],[2.62557608720266,10.6103719914713,-1.3273727271006],[-6.3867472989829,2.55115240440562,-3.75878248628902],[1.68647406793524,-5.58433148966738,4.38375583557106],[-2.6701063619762,-1.41283710205344,-5.72305350419681],[-5.00685423610187,-6.47544281129998,7.57986453263237],[2.84276219017878,11.8489431679893,-2.10919417284611],[9.57426512492964,3.25535133561818,-1.50318227631086],[2.48624004767109,11.325746982165,-2.38103331532531],[-3.75436681844791,8.5901565774479,-6.7715105780069],[-1.17536967341267,-2.46790216056079,9.61999224536506],[-3.35540304684724,-0.656204915706478,0.192575444052905],[-5.2422252088832,0.247626028096057,1.9919421413614],[1.44432352618427,0.610871683820946,2.72386515327113],[0.822747124891471,-6.21110301574404,3.17730770779965],[10.1459966013229,3.18203647170503,-2.84807743232558],[-1.25561138217252,6.30895268981609,8.60470912299766],[-3.13287319481198,-1.18230903296918,2.0203997666423],[-3.36335801033753,-3.51363334003756,-1.32612545967362],[8.80203771850548,4.52326397940215,-1.21082378721188],[-5.97077580468013,7.80844626083666,8.155587130948],[1.66875365346647,-5.48767357031966,11.1106711184396],[-4.79409232837897,6.21273870146567,8.89704113845492],[1.47029873773225,-3.97563513749438,-1.54222266686318],[-4.39094184209393,-0.89612729343671,2.10422876159326],[3.0614345883399,5.99216711809489,-11.4056436409304],[0.682117501815587,0.613063432921367,-2.98947790115487],[2.12845590976443,11.599586044665,-2.67391826199986],[4.00357545845355,5.6065982200591,9.13743040638265],[0.267716949119335,-3.2617262013209,10.1419192355571],[-5.43153164238909,1.27319652159824,3.84401733874535],[2.92283154926315,6.645394080114,-11.6458028782067],[0.34161736793127,-6.10102423331249,-5.5271500052945],[-3.54509880710566,7.72537216182779,9.09331461285418],[0.801524492220557,-6.54019049941697,3.604190863763],[-3.00706222603839,6.42804362756216,-0.45552008359825],[3.13759453285557,-6.59481073732751,-0.465717001770896],[-4.57243726844818,8.42279547145215,-4.73038820983902],[0.704783687123117,-5.27433596767667,3.88170310358026],[-1.63538030981378,0.834504528812634,3.4164160498838],[9.3275330723915,-4.02418125082406,-5.12874182536442],[-5.69642796823052,-6.3049839774868,-1.97335522479237],[4.1399223881759,10.9234056181635,-1.32523221114569],[-2.57807584258391,1.00675487962119,3.56937449179194],[3.24275391916831,6.37367432978409,8.75738801082373],[2.29130206735594,6.3806781636472,-11.7055699848169],[2.91839175475327,-7.59037053284703,-10.0865732942938],[-0.951767879802154,-6.62157044978702,-1.38327864798813],[-0.921685492462967,-4.96819237296845,-3.57526659045445],[-4.6151430404777,0.249016062010582,2.03458769375318],[-3.05954072788512,0.417938361125432,3.60151340197735],[-0.578738952077629,-7.57337603095788,-5.94067930900068],[-1.23035610095565,-4.9160546887329,-3.30209163321403],[-7.13015433999233,-5.72374839921484,6.77439896965581],[-5.31368013336316,1.23820285867901,4.81365659874799],[2.76214589323877,11.411128601033,-2.2485629879095],[5.03823984029908,-2.13113122974332,-3.05270947768673],[0.916980901008234,-4.07157504041796,12.3310981547603],[2.02952352145902,-3.92437865746742,10.7219698199232],[-4.6393350979274,0.731168264309935,2.79786413523899],[-2.41395813733907,-2.88634416042385,-2.49848830576469],[-8.65432737731761,-1.22349300908463,-3.83739834145237],[3.01553068728488,-2.07446357749811,-6.66953959553875],[1.13301379569667,-5.6652433196819,11.499798655293],[4.07047914371418,-8.50937705639456,-0.91479471546842],[-9.20204938654871,-1.49384709151491,-3.75589166248776],[4.00331699332958,5.72064965823482,6.96174230850268],[-1.78542232866303,-8.04810002476766,-5.57239499263949],[-2.6463439019045,4.55107186380344,-6.97537874949675],[2.82415068262899,-10.0973186049888,0.24399848329474],[2.2793875439144,0.311729629712231,3.15586815051253],[-5.62908110108274,-1.4460409813734,-0.739973852815159],[3.60064857473499,3.63227604244886,0.466882293143116],[0.166719780669674,0.433221915173011,3.24305977825081],[-9.77497400384287,0.97642432199161,-5.86351424391899],[-3.09700648427331,-3.87100443076007,-8.97041991663658],[-5.13349769863402,0.937917538068577,4.01651682217734],[0.93488048213757,-7.63301417105218,1.57319651016362],[-9.16225838416104,-1.79655244275529,-3.60893551756739],[0.932195831071442,-2.82611322918267,11.4666182972574],[-3.12689692448381,7.52050268091741,-0.482885569180891],[-2.31095599833251,6.52705633920956,-0.451173687782073],[-3.19399399875767,-4.94069379787637,-1.19920417991405],[-0.914021646988947,9.72300044936883,2.73022944306869],[0.596193396228146,-8.61536170540415,0.908784967475397],[-4.13681619415794,6.47253372768882,9.14675695116484],[-3.90185648986683,2.77071921836426,-5.72845765327849],[3.25366938617073,-8.69575834692578,-1.58037025727491],[-1.8704375813346,3.21162373234293,-1.91406898306598],[-5.44406923063931,2.31868264238382,-5.00755081633048],[8.28780694756165,3.48968226078186,-2.58914955599699],[1.94737421089305,-3.29135239387241,11.2225914629448],[4.02579357209438,11.4770990669071,-1.87011413811575],[-4.82238262404782,-2.7309887041824,-3.60960715770763],[-0.486053680851611,0.732317484434057,-7.47059861067145],[0.388802661477025,-5.15278408511778,-5.29825028055532],[-4.66514455047386,-5.75211069500255,-9.6027392349028],[3.98221214603577,11.454571141353,-2.04060179499383],[3.45966085581093,5.117544490912,8.79944352133133],[1.70509642661935,-5.33963673127078,3.67510371679969],[3.66411530318396,-6.08416813045551,-1.74974151555337],[0.479685215279161,-3.28093455249541,-12.0655347461163],[2.30835053685807,-4.29277696620789,10.4919842351072],[-1.15881539527859,2.83990367657246,-2.17601626540328],[-3.42263400359042,11.1673978438397,3.4559981402333],[3.53729916851359,-9.03143151847289,-0.0263722866032274],[2.59002265310337,-6.08456861126328,-0.0359796089404004],[2.82307002380401,-4.6061325906012,-1.5092504536017],[-0.573115430298269,-4.88141594545695,1.3613211330485],[-3.17947751589604,-1.42847475442248,-8.19944758815048],[1.78705853780341,-7.2777259011284,4.28259718494358],[-6.1195158416346,-3.04023621729459,-5.23225042782026],[4.69832110123895,1.63904445838542,-8.65214202316023],[-5.70652460649792,-6.70944511402886,-1.5332036761348],[-4.18390986305465,-0.748224579670444,-0.00521724865792078],[2.75596049551538,-1.82224760967334,-4.39229751940952],[-4.05132351349007,-3.99955266613484,-1.01638735489885],[1.60864120433765,6.03185778854705,-11.4993686296322],[9.37680928811857,3.13439686789862,-1.59791506710196],[-2.34501520976749,-0.258279233399071,-0.19063665992272],[1.57005016787074,11.759212434252,-1.45748018124631],[3.04637007778742,-0.496638742710358,-11.7104206347177],[-4.35311345524727,2.31294113492607,5.29325208985132],[-0.989998357526768,-6.94091552501896,-0.236201247804503],[4.04636725863633,-3.51436541343475,-4.35932561981797],[9.77169215517027,3.01975595105605,-1.96204600829948],[-4.27513112797954,-3.41832895646299,-11.4506253254011],[-3.68197758215996,-5.80495750063459,-1.66652345300178],[5.99069054410627,2.46319801732378,2.0190338376318],[-4.31166339149843,-4.11594914711381,-1.44861572594279],[3.63082532555445,-8.08247000754791,-1.44215958562306],[-5.5376346001616,1.76046845732449,4.76294092560598],[-1.89546827235074,-4.18518001609858,0.00841562903191068],[3.25657004438097,-4.01339322301555,11.6594030044666],[1.45393325378688,1.94560728504352,-2.90194481253567],[-6.19268109686951,-3.74182799468022,4.53993100554495],[2.45846057095174,-3.25856575467013,10.42290568119],[2.26048082645883,-7.75566211792424,-0.899387001889363],[2.00412565423987,-7.59270888912659,-10.8026995219869],[1.6990007003027,-2.43691713194946,-7.9974685943736],[3.21990088148267,12.2343406465726,-2.98831853328113],[0.931325274273013,3.78017626947601,-9.01032750511451],[-6.58359472188631,6.95359924709665,8.81123686106963],[-4.12846957441397,1.6560818175099,-4.39884802106466],[-4.2226110887872,8.09162749890615,-5.95881949642979],[-2.32629697605817,5.538483396921,0.833357482207865],[-5.1535523971502,-1.12413673544043,-1.32351745961462],[-2.00458547702463,4.49346039147949,0.789232603340581],[3.96829906070931,1.40379235148394,-9.36470196723228],[10.123829603348,1.32733403545304,-0.322911532148989],[1.00413264189387,-3.62030083949518,9.41545168689955],[0.94104542688781,-2.68797587205393,11.9930088166472],[0.691147101852345,-3.33461221383217,12.6263804674113],[3.75925622203871,10.7128397491509,-1.85994150507867],[3.88497056648361,5.82040920027513,8.08710163432627],[4.56683516893647,-1.60600607039192,-6.70025960142954],[-5.12740286012234,-6.98455297102183,-10.0713110712546],[0.667861246468501,-8.06193763181828,0.455827480414591],[1.11447109540952,-7.33912544103523,1.06359178473616],[-3.24963291735597,4.24079494127944,0.890313653150516],[2.04554571420069,-2.48861481807115,10.3116616219612],[-1.77825336980452,-2.39920757845402,-12.0798498769694],[10.5678695684759,1.31928268459987,-2.10033233533868],[1.07366849040463,6.17643833980686,7.45272737381932],[1.46663400622536,6.38942251916146,7.81814960114336],[-5.56918735945756,10.9088872535475,-4.66278161207913],[-5.63349764314575,-3.44481054129646,-4.76299912946975],[2.83310739349609,5.43919042367568,7.32635957344272],[0.184352491991198,-6.18326569188707,-5.94361724664879],[-3.03607791081486,4.10442138066399,-7.42415095822382],[3.78850776830722,6.21205495173775,7.59401150307329],[-3.50348365465077,8.00150248406965,8.25825316004329],[-3.8351529069644,8.76818301952803,-6.78180758447446],[-1.75345698849916,-4.27811466504048,-0.449388191985155],[3.47489015871485,-3.66196119292633,11.6627020159438],[1.59087851377814,1.40982500966635,-4.93079935553155],[2.2786184976876,6.63605825213395,7.5544602232293],[0.576007914918827,-2.60650874137401,12.9772079263696],[-6.13816227519317,-6.47894153901542,-0.665808092476374],[9.96867959618517,3.27792659984841,-1.91066896991826],[7.18995517259736,-2.10513898002151,-10.3543137812038],[-3.53769212717923,-3.80854384945115,-8.43727196408854],[3.01673169247558,6.74711846087504,8.21654032229053],[10.7468792093783,2.37102782372129,-1.49283668339819],[4.00694402691591,4.08980959567289,8.7982953870496],[1.69959487496638,11.4644538964372,-2.07498998125494],[0.216623697813887,0.521520179668522,-3.31436393980549],[0.645845302593563,-5.21192440553475,4.17968559173477],[1.27999202129456,1.98422156526832,-2.19989562647716],[-5.61783655021356,-1.40906966226987,3.7863182888991],[-1.71925228672379,3.87115839376877,-2.40289267637744],[-3.89760141425832,3.1104273362605,5.39461923661979],[-3.64928285943,3.2907034521524,5.72289221880836],[1.88137134549853,-8.97641810106222,2.90307087928473],[3.18908960331281,4.03728755611618,8.59456236140399],[-2.05094502782951,4.56072004412517,-6.96135387311031],[1.07346496518917,-2.86867107947295,13.6302269482051],[4.14299619195241,1.80707021645145,2.56052822004472],[1.39474793100311,6.14570394762646,7.39388363632134],[4.40489885204448,1.40847495217533,-9.78612820473116],[3.08967640202638,4.89916803509442,9.14001045481757],[-5.35670729608706,1.61117425703362,5.06168424695942],[-0.417146447776911,-2.19779952459581,-1.52690483327352],[-4.44546399142917,9.91813373860574,-5.16126402465249],[3.50309375851688,5.7506457695988,6.80478799877333],[-3.65425056486444,0.42142033437505,4.93002038561403],[-0.438941207669072,-7.01764638746357,-5.83367217533698],[1.86857747528402,-1.26870252178957,-6.20348783056072],[1.4696744253891,-7.12800930359341,4.49633940701522],[-2.08430137873905,-0.633400386795785,0.89761553229901],[-6.73978842464141,2.95312645705813,-5.25162180520827],[0.991127456604126,-9.71276184953978,1.1953887195471],[0.175756726761799,-0.959658401284018,0.383651659690037],[0.132066696076761,0.0244823141702272,3.15899216141494],[3.57117080713256,5.10210388171688,8.83367347824893],[4.18715860284971,1.56995353456259,-8.77459588789398],[-7.1832109804428,-5.14021598303713,7.3970154931514],[-4.16613018862348,0.658381210581988,3.64676451686795],[-6.72241403794199,8.95622074763427,-4.42218903696495],[-3.11949863350261,11.25076164552,3.33547483914104],[2.29666752274387,-1.26708770755878,-7.60410726414246],[-4.0376782940818,-3.31593648958543,-9.28878740221957],[-3.89185939287314,6.5281144466542,8.26914233414352],[-2.04138718324207,-0.945588805301226,0.747805801228656],[-1.83262958165929,3.41081763201261,-2.70657271283759],[-6.93469386596698,-6.67269643370223,1.5509310977036],[-3.25351342814812,4.25676334516719,-6.99404556000609],[-7.74658775213026,-0.620959543344434,-4.52366926242575],[-4.00065660684219,-5.85942552820024,7.89549985251596],[-2.52908639520654,-0.650470347308938,-1.52558883701926],[-3.85950985369349,-3.61574044444515,-10.728596493503],[-4.68639018960556,-6.54003338369696,7.74301966415966],[-3.98538250582602,1.06051593168946,3.43804753761929],[-3.73305835506441,11.7332179425726,3.67432441147829],[1.14677056417983,-2.75855033151198,11.9676075952463],[-1.33922730955345,-6.70865996564075,-1.28196826686892],[8.78439031555497,3.04145034396642,-1.76879077325343],[3.25504541651771,-3.97980258401457,9.79968560681686],[1.19656154064617,1.83276586093347,-9.33151493835248],[9.9995354694894,1.4120213913465,-1.66240313943675],[-5.2045170179488,3.25305380161604,-6.77919406775848],[-4.89323337203525,-0.0824715773524898,2.27474325496111],[-3.80290741337088,0.920204204949029,5.72652782364013],[-0.153671546015468,1.03980856734722,3.91726461063701],[-3.28945426060588,4.31748549288857,-6.86130611001848],[10.4761040217123,2.04452913908341,-0.800775766028687],[7.22292906892971,-2.07088872256094,-10.5549749855155],[-4.84879577168761,8.39040180381746,-5.83074167901609],[11.674856712306,3.81087960410366,-1.55781877473563],[-4.95892053927964,0.367854217257319,4.76224943158914],[-0.214202394534713,-4.62490849074183,-0.828678693904904],[2.39603406572593,-7.79560677885503,-1.99377916233698],[11.219448856689,-1.8801221949049,-1.4346993247437],[4.37625473214897,10.920819356853,-1.24281036429997],[10.2735233535357,1.85542408300504,-0.932772870785118],[9.19381564152588,4.95621307840072,-0.862001167728487],[-4.63489587853812,5.99726197146547,-0.106439577142222],[3.6705401607605,3.85430510755909,0.901614254376472],[1.14114043356013,-7.20198266617478,4.27095022091737],[2.71617360107914,-2.33179595774617,-6.95029619989596],[3.81738041277054,-3.00800714641132,-6.75117747511916],[1.53914143884099,4.00209308833964,-5.4667798423421],[-2.60935746775526,11.7553429493076,3.48129650925307],[1.754031165038,11.914422344169,-2.39941569359779],[3.31889502437243,-4.12982869118789,-1.83442306711016],[-5.33982584775289,7.33513542429139,8.78716256493898],[10.4118610567603,-1.19240272901802,1.28652583220553],[1.23081460073002,-2.50478070402539,-7.87671815115463],[-5.28240597061038,-0.639004384202603,-0.472642189900693],[0.749058119856278,-3.97112919414542,-1.47294409090925],[1.77032475129211,4.60956269997234,8.71446700295416],[-8.80184834344659,-1.25352182286987,-4.83569586894651],[-9.84996535716557,0.651977322519547,-5.94681350287838],[-1.78048685998711,-5.19468291949742,-2.03387394528593],[4.27113546034596,5.47611161241595,2.73793453327989],[-6.30812607875464,-3.31189521905379,-1.52000032314275],[-2.14727380809247,4.92541464138462,-2.54365825594326],[-3.82091969280378,8.28166524141482,-6.48170290455687],[-7.1870404048405,-5.5797076904536,0.0572129205689335],[8.62277871402875,-4.47635092053618,-1.28224153741143],[-0.459792718930748,-7.59045128045244,1.89994487891923],[0.426370439965237,3.32457814248249,-8.79167750150359],[4.50742552325675,-2.91509397222706,-4.48012770957329],[-0.0874966885683263,3.56997984831513,-8.91858961526789],[3.37541946919464,5.97337264132069,8.66060908415174],[-1.31339148141822,-0.172773984468821,3.51493776216033],[-3.46891021420561,6.45336191136884,-1.59227606511795],[-5.08731986032256,8.21109346821751,-7.20484004855112],[3.93324443772052,-8.6661860262729,-0.86594119702166],[1.29981038710714,12.3915108376881,-1.58009811654832],[3.97200186998062,5.1277403769258,7.69708182645814],[8.69958954270584,2.19321572288184,-2.58665744180684],[3.55497550393997,-3.07677841608832,11.3717738170166],[4.52346552624628,1.69976559305079,-9.0849359660061],[-1.8492913618779,-6.41890392325247,-1.03907104023594],[1.44513801880296,0.59405453591759,3.18971998080947],[3.14882513561714,11.4453016446978,-2.21077355497599],[-5.81030374903056,1.2649060908826,4.05408362374069],[-9.68232510542469,0.953314951443431,-5.97889798154392],[2.12043253608592,-9.16365251778145,2.20160098667376],[-1.25252416345776,1.63319605550208,-2.38417541700283],[2.86351274391942,-5.0002620053781,11.2245996225301],[0.11639621404013,-2.74164105017023,11.5430620505837],[-4.42778187768217,-7.18647819741946,-2.47776490785005],[4.07405725559349,3.52953712895267,0.759882793148096],[1.32943139256677,-3.19437180193133,11.7773456841658],[3.89006437198922,11.5911959688366,-2.48864179617503],[-5.88655754640583,-2.96273927759317,-4.75496787220807],[-2.56721734453477,4.48682514118766,-7.16567064305587],[-4.89228870702531,-2.81817508547694,-3.59714677568701],[0.46026488710554,-2.75000139621009,13.1605409515069],[2.29838151343761,3.66320271622159,-5.63046713747069],[-2.89823652384405,0.537772424642079,-0.377940324686973],[1.65223606028065,-2.63245268720637,10.0798117247716],[-5.87302236420911,-0.0769141697900737,-1.02741458665906],[0.25727951441025,-3.8269854401759,11.5997074129876],[-6.09597064657158,-2.6493116130132,-5.4085748897389],[1.10973912076904,-5.83546388303235,4.79053769813979],[-4.1058007156814,0.804999062679001,3.87423553759578],[4.62850550448164,1.81750747326011,6.92373802489031],[-0.793043906419235,0.679639648828588,-7.24612491916035],[-4.77276060639529,-0.934338890883217,2.92370269325312],[-3.64923302671793,-4.49657071277656,-9.1628965634503],[9.34495405006439,4.6663742409488,-1.93028981359057],[-0.328547426676549,-1.01109443268552,-11.1492710503649],[-8.74576035773834,-1.5864582567328,-3.08207476733579],[2.40027852268919,-8.39462839352712,1.8017687794456],[-5.28393464760521,-2.6891387645184,-3.77927551189809],[2.72152277307948,11.810558276217,-0.723134929016884],[-0.645941830764584,1.31247976397675,-2.19223085937045],[1.90808012859581,-10.013119739865,0.0519021428664613],[2.03383534553315,-9.35907956640808,-0.448196658112283],[3.40007030824313,-4.85147572377659,-5.48866130541349],[10.1185121113677,0.461997438677731,-0.805927370405987],[7.98788296341598,5.45967489415534,2.83077528947986],[-2.67748218524268,-4.14283817343458,-0.545570610239704],[-2.67411484759012,3.91446536093072,-6.91119988248783],[-6.5743986877964,2.57421338669457,-5.77646205284682],[-3.38832428942484,4.75516315808657,0.0756538540624745],[4.54269432026109,-1.43649930109821,-11.1433162656353],[2.07001683207001,-9.43815118597372,0.686415170222176],[1.64767857721321,1.64351220127564,-9.29784413251289],[-5.33443808407909,1.72382856009954,2.75671224858683],[1.81386206433281,-1.55641614341333,-6.66314574195687],[-8.9855362265565,-1.50702522131649,-4.18638280074083],[2.69669866144281,6.27604729198489,6.9608257067969],[-6.53693647519595,-5.09190823878646,7.79782755741227],[-0.559895748896932,2.90190022003758,-8.59022380749092],[-2.33533649822524,-5.34483245041235,-8.2300177913883],[4.33093994804857,4.90509327788337,3.09976683932291],[9.80847274746605,-4.9309850095814,-4.82416211076753],[0.848481137632737,2.10948088417755,-4.28658696460153],[-0.204771042690389,9.08742263320477,-7.2639070045383],[8.93461445201756,4.71992277296466,-0.978382937017304],[3.75838547618935,0.12814432581356,-9.73372517443855],[1.58652722695282,-3.37231998467194,12.7890634007956],[-5.22056205316761,-0.645637848144887,1.80215212019284],[3.36851203451557,-9.56900858317005,-1.72591216420607],[-0.83910050306318,-1.98748982328678,0.948329398409736],[2.60160575847611,-3.82189331555215,-11.0929692696505],[5.02925506272933,-1.52593224887988,-6.72309381075912],[-6.69387357323357,-2.02548022080838,3.66395540478579],[2.40270779599874,6.08776404451877,7.21402881672133],[-2.31171083087134,7.03290785394528,8.70030305658365],[-7.11883819383035,-5.54642889679268,7.30093670131027],[5.12000758005576,-2.27484739661997,-6.87081662863183],[0.600110908589417,-5.06017275751507,-5.59076609872254],[-4.52491951939057,2.46739689421125,5.16370347633671],[-5.1355766852994,8.84875827247734,-3.91353304340674],[1.79898162817303,6.22887225878503,7.90476395121384],[-1.08588402705659,0.227961069200862,-7.00835140274591],[-0.0113314798582758,0.549027621725848,-1.08628416383712],[3.27983874235709,5.97423483045066,8.34240591208452],[7.25171286783448,-1.84210352282361,-10.4087342908385],[-0.248554923184959,-3.2109036975237,-0.971554842085114],[0.178832625824532,-2.94106032285617,-0.687790784811977],[8.57066360075654,-4.2649063372332,-1.09038764758003],[1.52213568178814,-9.14903697798064,1.86973634525329],[0.511761143192728,0.301240721530491,-2.82424756946717],[1.79889978922468,-0.0742529489290984,3.72519638404283],[-4.72773883871846,-6.01840473201654,-2.61587756214496],[3.91388017935485,-5.0469321904264,-1.18422935060008],[-1.96237851204453,9.16329857637062,3.45286874233984],[-6.27696807774401,2.9228605369548,-5.91288587905785],[-3.53905312247167,-5.21828186381298,7.61095597309563],[-0.833551728593689,-6.71799896285222,-1.51033381398269],[-0.737141166273197,-5.31011960034201,2.32579113002706],[-5.54831225011841,-1.3745950777269,-0.831560407884628],[0.836053087636503,-4.48133768928614,-5.496821689881],[4.33868182901693,5.35846284530714,2.9481398620186],[-2.25115706843453,5.30926332483186,-3.30481288598297],[1.46951262118741,6.46353159479297,7.50718708158852],[-4.20697729202448,6.18026099165157,8.2292587059647],[0.74948398774331,-5.55683641616775,4.05828310114921],[-3.24969616397442,-4.87107676762444,-1.2527263397365],[5.05552041029491,-2.80771116551793,-3.96885022245302],[-7.82673746959623,-5.71563489011393,0.139496789051612],[6.96708444238752,-1.24597875844888,-10.3319869839355],[5.07047403546676,1.46657278657726,6.50068303232549],[-1.88601731631522,-3.55662560373915,-9.6983326411797],[-1.65550817746234,7.44017694102375,-7.09648077294187],[1.88864170773329,6.2007478218021,7.93408454384143],[-3.79702951491866,0.169674237641475,5.22458585673062],[-3.38005409938424,-2.41640170542154,4.34286873767248],[-5.18073871742033,-7.11483770200754,-10.201811198238],[2.52010159846645,5.79386422469917,8.03073755707528],[-5.06274867490257,7.04021832321959,9.25208503139685],[-3.94829440957219,1.66000099649258,4.89148535010034],[4.5371220554411,5.81296193101138,8.06345617991831],[0.947748457650087,-0.504487523638349,-8.45301622227823],[1.78578479485337,-7.62754131228328,4.06703638718434],[1.89486105462889,-4.76270223995097,0.804293274951669],[8.79930688591338,3.22761822840286,-2.74259131266753],[2.01732853688263,-1.64437005149724,-6.98811365973989],[-0.538789779650576,0.468187370409282,-2.79323418560877],[2.43339873990704,10.4802231827328,-1.93951182238034],[2.07822438667434,-8.80516404834302,-0.641383101278334],[0.896562185279549,-3.87379997111282,-1.47871271688586],[1.19664959692152,-4.14269698661609,-2.45453986293648],[-2.41064177789989,0.254290702042924,-1.14914757629058],[-5.64430148906352,0.799441912779456,4.89594033401682],[2.99259675756787,6.16098843651854,-11.5969994348432],[9.50964617482886,-4.39303673975746,-5.24869560187704],[-5.31945080932089,-6.9255254705601,-1.77626756177461],[-0.0605963016450055,-3.40151613196542,-10.9621036255237],[-5.53182588071218,7.98858981245967,7.7402497965033],[-1.50721524848293,7.51586610520217,-7.1095064923827],[3.85231841618187,5.7665195761486,7.96859495155881],[1.3268920517259,-8.57183966810222,1.77049545491814],[3.6118249839465,-0.411478315058874,-2.81706800373015],[1.15819787410586,3.34220553611322,-6.7416983822013],[2.15571090799941,6.48930528941947,6.77963670971138],[4.05329010173422,1.76764429453091,-9.2424546933394],[5.01489555920725,1.51902245409851,5.85494926646632],[-3.81425934886315,-3.91678395723602,-3.16103970282794],[2.91951372716794,-6.03271182851885,-1.22216514033865],[0.795658666339016,1.54593528654875,-6.67575027586697],[-0.296259835750659,-2.59326777993051,11.0954614171349],[-4.11232681409493,-4.00340836210407,-1.72113661967151],[-0.513454039589816,-0.160287929865252,-8.00913657157154],[-3.32554669392093,-3.15615402173374,-1.07744223226037],[-6.64445588935327,-5.69317409529748,6.34959574350184],[-4.3653698153586,-6.50634413231665,7.53609835026017],[-5.99691006784143,3.68182721110509,-4.14478752040006],[3.38846933166197,-4.65823602221095,11.1147169856819],[3.49002454998156,5.87701732441676,7.60424014159686],[-4.52640011700497,-6.2244967113878,7.78324137779704],[0.900980687615445,-9.3267886682823,1.11661784389103],[-7.84331327953939,-0.911244640344891,-5.0248202393037],[-4.88861962334769,-0.276031903662765,-1.82869480226762],[-2.18965240529702,4.66069740445894,-7.52176349831624],[-5.9872889428502,-3.54613845659419,-1.72211125578652],[-2.01132088787957,8.49151500113945,2.84846847213354],[0.332376181290608,3.84712012154073,-3.10700885341974],[-5.88704894875876,-6.24916934758115,-0.338912533121982],[2.37440411663744,-4.95976161865546,11.0175114874441],[2.72495496230205,4.84685622074543,8.94971005372516],[-1.44184772432579,2.87095726647074,-1.19539034118198],[0.819528369136749,-8.75892560570132,2.06015953261678],[3.23260477362522,11.6178664505627,-1.42472614467864],[-5.35855617174539,8.6171650372651,-4.71193570326301],[-3.44172786409635,12.5016025671622,3.7537621847817],[-2.15878930803459,-3.33963050652165,-1.81791921092147],[9.44843080594236,2.63551489191607,-1.0022622755853],[10.8052592838537,0.460466817799404,-1.05924617511783],[-3.74154184705406,12.249168222508,3.71448839511785],[-1.91705100161202,0.228144354132274,3.331154822533],[4.11464122863022,10.6977598255741,-1.42016427218487],[-3.40079995181437,6.60219527804396,0.207921167737903],[-4.8293867429147,1.87562251414442,2.93940815687621],[-3.49022856685329,6.33957080195148,8.15983499621133],[3.85856312475889,5.14631191600988,7.55292408899405],[0.899972741156223,-3.2424294984944,12.8930943625294],[3.31797940457413,-9.47050675289628,0.592032076240766],[-3.56050807451633,1.13909671814341,3.29859346037739],[1.30802024269462,-8.69780410431125,0.238864339351042],[10.4579985665288,-0.990947018021239,1.09725845867139],[2.76544138887433,6.21976002952483,6.5413879799018],[1.61490555903523,3.02538376262953,-3.82005863983601],[1.89290408022662,0.151988202031424,4.27143097048127],[1.27762669478048,0.196375625791161,3.34504643011322],[1.3053238216513,12.2279245352052,-1.25751326572336],[3.62685616949605,-7.62513274426328,-1.10927632457063],[-5.31646709551515,3.23784842605631,-6.682166191062],[1.52623788763167,-4.01483351077303,-0.119367132044362],[-0.171380371132741,3.81968188236308,-8.58209209226647],[-9.48251844542042,-0.647616067017661,-4.76178949666728],[-5.22770577855564,-1.11084342440456,0.797344455816991],[8.45633413290905,4.72463760944206,-0.594410446789662],[-3.70407276292524,5.54566241054903,-0.821012153701289],[2.58958747067057,-9.91976898158353,-1.25691983169054],[-3.21132215233739,-3.3355102837553,-2.05474984097784],[3.18235011513776,-5.96285356533103,-4.6151205448878],[-1.64279349341761,-6.48979666616798,-1.46033563875826],[2.34014785973163,-7.68313619290901,-10.4439752098461],[-5.53169261972366,-0.599245771146573,0.316711459184635],[-8.26192460722638,-6.5190243805827,1.13033946245344],[-2.61708875669868,4.4263933621948,-1.55320100543755],[4.89206006941412,-2.99878038035799,-4.25841018635541],[-7.67268852476727,0.0223952211558536,-8.24228820777584],[1.42728239845707,-4.17228131274726,3.48022848213946],[-0.348961591678546,0.868659846599495,3.98883529865984],[7.42656893267104,5.28813668900782,0.946509044679471],[-8.37189805420093,-0.080164779382208,-5.00318679810795],[-4.004788857213,-4.07717373883834,-10.5941200348694],[-2.92825646699163,-0.379408025528363,3.3927094499716],[-3.60160226746857,-3.25673253712266,-7.45098997687445],[3.60343329067344,3.73583037988305,2.04289572826364],[3.61235572177526,10.2395414409109,-0.934870781031101],[-4.74524947617647,-0.292479787823283,2.74069111283841],[-5.06809706230365,-0.342509014034746,0.882508881817196],[-1.90602335396827,-5.7047135801116,-2.26651746488927],[3.63624748488732,10.5891944849705,-3.00306857314753],[-3.69091430232629,1.49185143936136,3.93446474373992],[-5.11540923943078,1.09591632760126,4.06207443348316],[9.16034425146257,-2.49767018607935,-3.24545450075539],[-4.3906462181238,0.668798271181535,3.26708081103328],[0.390682227376876,-5.20826661325512,2.39008426066001],[-2.46461308354576,-0.457459609730754,-5.26365987708989],[2.14880735757216,6.05998974119435,8.66189520763014],[2.13059602362548,5.88907107463743,5.96058644734104],[3.88106416643106,-5.75737986282735,-1.31216285153327],[-2.61332255509485,-0.938409856247774,-3.57598859388857],[-6.84802655240174,2.41675192523435,-5.37186037465935],[-2.47855157406301,4.71598252921271,-2.48756829164186],[9.45898853690903,-4.27210773319263,-5.45732879179463],[-6.86691592148629,9.26100950216237,-3.96827472935432],[-3.398411114373,5.99770066749212,0.149888419087061],[-4.01371399144471,-2.29224850692076,4.09301309727281],[-3.37665874886564,4.79239782728775,-2.67628350612937],[-3.31108303671971,-3.91026624812144,-8.55898528460696],[2.60681110023322,-9.41703290510402,-0.968606817311395],[-2.99259368748996,-4.90588414926189,-7.53146727873],[3.5007535866553,-9.62702559612493,0.0418327471636708],[1.85030733619732,-5.45424421339371,3.71655498649636],[-1.99894778608466,0.90437277741667,3.46425388129026],[2.07930611270849,-8.43902979369865,0.400332804275348],[3.66937896604015,4.24586599193787,8.87912679954458],[-5.03531079055619,-2.7503951630919,-9.49756718986544],[-5.23573365677407,-0.8354220367102,-0.73020129168489],[2.88707910234527,-5.66303425471423,-4.79179387968505],[-1.96532380787531,-0.105507569669292,-4.86597250847725],[-8.73536317956898,-1.72214883151848,-3.33405144588476],[6.76680311523503,4.88965908043558,0.0682907642681699],[1.01490363260126,-2.38719852554366,-7.84441067130175],[-2.20462395451531,-1.27174995969389,0.572126696725395],[-9.31356293166693,1.44757826996348,-6.47361793779456],[4.08895434013022,-8.59896571944946,-0.789251368093459],[-3.91167134211191,-6.54829875444276,-2.39384394274062],[2.49749086367979,3.78223190098462,-5.99519798622617],[1.64453001584533,1.8378980151176,-9.20376400486128],[4.10134915459744,4.3328701703243,8.67355499342029],[3.33876281235371,5.83637950629615,9.39606485177318],[2.79285875234269,0.289792006748617,-11.4155322104067],[-1.62262689957262,1.29485314866084,-1.81570153700923],[1.45024964280565,6.49633130933631,9.23385581547055],[-5.81223364761647,1.28104883310602,4.4945887698524],[-0.127601004532629,8.89432049388484,-7.21892374172706],[2.89947081727803,11.2576686856365,-1.03906872905126],[2.18767077051323,3.85131263691782,-5.96626610781428],[-8.66936503399353,-6.00754559562046,0.728034148337682],[-1.51688989115031,-7.11921592980083,-1.0675683825953],[7.06559753288583,3.99124691406954,0.230420639092135],[0.318043598002077,0.252664413204295,-7.43127776641856],[-3.5342231301842,5.0838301272826,0.0879706947202804],[-4.16380590946415,4.6278655295271,-0.179072260019029],[4.1923854555376,1.85019393470707,2.58255355115568],[-9.38928544569113,0.852841494951656,-5.87750904762104],[4.21913308523294,3.17708050140624,3.06223230555097],[1.28902216147975,-7.03826209908905,3.74324194542609],[7.70549391767804,5.96449051133125,-0.312086419864415],[-3.05277452491606,-1.36029496901313,3.81110460878382],[-4.73534196006314,5.5471149943868,0.0595607136293672],[-0.0400303201007409,-7.60512282865961,1.82506653016571],[3.49265330007972,-9.85441963707606,-0.227028903801284],[1.13586660910239,-3.06747691669847,-11.6344798639756],[2.54358876658043,11.2428546295789,-2.33936154798832],[-3.26602677566797,-0.833546463423114,3.74875181757783],[-3.2426640251446,-0.23449764258372,3.66675310611858],[9.45714810285391,3.53324630202358,-1.34925133565451],[0.383770894070033,-6.70346893328059,1.65951388407794],[2.85103626065607,5.80583910749902,7.49668202362385],[3.15103925919193,-4.84288524090101,-5.41894438339941],[-3.85820254623533,0.718679334317574,4.81242143449127],[8.45602773591418,3.16690519565895,-2.59027878253919],[-5.12664520941708,0.734195436480211,4.76009269081892],[3.04241510159638,-9.8593988494227,-1.59900224268896],[1.91742113465949,-2.27262878599752,10.9963498518131],[3.46971979265251,-9.20087669214187,-1.57868883281061],[1.54544357801445,2.91171799108297,-3.24075042278317],[1.12506839357975,-8.69745564211251,0.515858088924006],[1.20404290443806,0.745261681904515,2.84056203969233],[-6.81079566929831,8.7196791164411,-4.21621999215816],[-2.13626829854711,-3.16089262499761,-9.43807545743794],[-4.2577504426121,-6.96084481997821,-2.3268533103567],[-4.99762928912488,-0.520882944993271,4.30499363743823],[-0.148046902008986,1.2809585920754,-3.80013987922925],[0.771420860360471,-5.6456372750351,11.2865843200826],[-3.81119332419803,0.810849721930959,2.5231528719996],[1.39432905521576,-9.30921970543186,1.48920221522739],[4.791042136183,-0.212656857271625,-3.15084085519632],[0.167486603267983,-6.8824700318939,-1.20944604573267],[-4.9138610539318,2.03311100285849,3.01789776845287],[5.13439217698801,-3.05006780186157,-3.900324671883],[2.82873196132109,10.8834055194058,-0.8823969410679],[2.23210890573254,11.7751343865679,-1.57459225369267],[0.308895472938961,5.55202618389386,8.50858903497131],[-0.153845016661265,-3.29363900974618,-1.07041237444674],[-0.0643118630853973,0.538756899065594,3.42814791755207],[1.910576196299,-4.98604116354535,-0.229578165218678],[-5.989430189481,-4.04138843026204,-4.51496433832157],[9.6564742910271,5.6914715605788,-1.35565179690727],[1.08993645318397,1.8250377395933,-2.8585461675237],[0.988241200619483,-3.43265068930508,13.4215388739144],[-0.0341820763071541,-6.82641353346005,-5.545367829714],[2.19778534714767,3.93692546005136,-5.97952407194129],[-2.78390183606866,-0.97835894259561,-3.48319162646632],[2.34548082947562,0.76489466347278,-7.08106994868437],[3.19323331935073,-9.93082017096223,-0.830102484920234],[2.81353824934675,6.53202786040983,7.44923230503564],[4.82961359244945,1.89053875478014,-8.53155577405768],[-5.11210535551115,-5.58516038943009,-2.54497429154687],[2.5379295135349,-8.10708961825638,-1.50389756321909],[4.15797154759794,-8.10615416598445,-0.745799969816254],[-3.27082389587375,1.22710954742471,2.47024721929604],[2.60385664899874,5.36078874562898,6.97729916785299],[-1.93403461574488,-6.35516126518748,-0.89884527716742],[-4.21085612513851,-0.0695163362383144,0.192265072081463],[-6.38368039347919,-3.89251212698974,-4.1807691108017],[-3.44621906099801,-2.62739079072362,1.94886687847791],[-6.10775246993733,7.81852882170431,8.63703595205057],[-6.06213855537738,-2.5621964953469,-5.21655636685118],[2.1841903726964,-8.49336007669342,2.96706777378979],[3.25418750646062,-8.52789268188786,0.162429888158728],[1.83599038949945,-5.76019483615957,2.69207047297992],[1.65806967296004,3.91567841287906,-6.39377359778036],[3.41242332908329,-8.60561325109911,-0.327157578477924],[-2.07153406732646,3.33141354391722,-2.23203412389993],[-2.6994121786071,9.03242754040109,-5.75073698226933],[2.78720819772699,-2.30232031247734,-6.78329192188231],[2.08062487624378,11.0112215782053,-2.26519068338015],[0.0114932014217064,8.88506722060414,-7.3177598017941],[3.47877902995697,-1.69051227950965,-4.28283325856769],[2.07921427090678,-6.76666475314924,2.8409389000995],[-5.78477022631333,8.22342891983668,8.33187605600796],[-3.7225683745128,-3.45622614525779,-8.25697152169959],[3.87608581307408,3.63491458072361,0.748090543857207],[-5.5538453407462,-5.31052397458195,-2.42636468325846],[10.7393093561114,-0.930896373984208,1.24684385427331],[2.10642248256713,-2.57982535919091,10.9200467244576],[9.63299617249158,-0.369673435781886,-0.372236509943694],[-6.58401211021733,8.87992363651003,-4.51314938274326],[1.07705543394805,-2.6457598772527,-7.79111489419723],[9.73694079237983,-4.73541842962298,-4.27402327894606],[-4.62687167980834,7.05749791785165,8.04336331211382],[1.77709622865786,-4.30592385815293,12.2083450801797],[-2.68223764050853,-2.5844588646524,-0.977438911891697],[2.78578005604285,-3.31417241964102,9.49785092272207],[3.66384551050699,11.4880039116846,-1.78672688937862],[-4.55581216643214,0.977668842136364,3.5418666487426],[1.00582700789034,0.291350123361701,2.82593985263902],[1.97973668219888,-9.02283536666127,1.55052234737498],[-3.59231440409764,6.4848472713456,-1.54347679907463],[-2.32408745964237,6.14824745637446,-0.637730296899098],[0.125825213494115,5.26121577378376,8.50937747106544],[10.2530450083541,-1.30313961761828,1.01866395735366],[-7.67697328679828,-6.83590996779163,1.29157953412105],[1.86963743750196,6.3442256708996,7.22674424598957],[-3.46832289349272,0.986891800600736,1.97100213176615],[2.97760731897917,11.7491880350457,-2.72261932898371],[2.00503970140055,6.70560294143828,-11.3486715135448],[3.3102238914367,11.3881881372479,-1.09653803166524],[1.65257943420661,-5.77583171299351,-1.18570754535991],[-8.44358556528663,-5.56429684739433,0.738048392672774],[4.13589849179207,5.34951919134827,2.55085775069279],[2.10520289768907,-7.39652279202347,3.12336276239807],[-2.60744527691989,9.55878255130441,-5.87270006535978],[8.74907595338232,0.825883950819733,-1.39655952923984],[9.10322527056315,-3.26821130580944,-4.23409946192505],[1.69927524906598,-8.14665437082685,1.44074668034602],[2.01290375589661,6.61442517345418,9.27236941084148],[-0.155142401182301,0.186806385608061,-1.93842953533997],[8.5365969578843,1.37625169931524,-1.51120284061524],[3.37830304876331,11.5315562283037,-2.59517192480312],[3.02683979585666,11.5367796039341,-0.378180009392253],[3.93380699864035,-5.253772915356,-4.84593486731143],[-3.89358472164374,-2.86713835580424,-7.3967436448837],[-2.2299656899271,5.73086821386402,0.217094488285146],[-5.22634667464059,-0.61837755664625,0.513672614973103],[0.267608524775976,-5.25077802973045,-0.894606197118726],[3.71408280125816,6.47109186743239,8.01485247015907],[2.47847087805502,-6.68818386409187,2.34949582703466],[3.52749188190781,0.556267044717391,-8.77136096456236],[-5.50976896612662,7.45772652484268,8.35451880951794],[-0.0193796476946633,-2.95784490602271,-1.126844582345],[-2.65685200757946,-2.8930834296593,-2.98910644370426],[0.328752606101803,-7.97557511821762,2.55537586153251],[-7.44394728856398,-5.93162679456819,6.63564580363532],[-3.10258285365151,4.4068011935226,-7.05427674914242],[2.08195948322156,-4.61551817717905,-0.165260636864234],[2.6813908136051,3.68863441001903,8.63684113005768],[-1.64013311044449,5.20811744854373,-2.92311321982009],[0.47869860691241,-5.69765284947894,11.0261614899359],[0.833856285900611,-4.98567257679928,-5.47874635371126],[1.25815990083886,0.0293857987797956,3.08021912212986],[1.21916568666143,-3.61575898612218,13.3321176165082],[1.71059630928934,1.50649331537946,-10.3998795685406],[-4.63475320395696,-6.41738449725609,-9.54706651005536],[0.0168680588732431,2.36987271986619,0.0359822728924876],[-4.59577857796446,-6.59050036879892,-9.15612693045375],[-2.98521175412555,4.47855731094155,-6.79325739629468],[2.39850095283688,-2.48132440353664,-4.53883274461961],[-2.01752607666265,-2.05976764680476,-8.61943607989744],[8.10743486985317,-3.13328076410374,-4.92391534788467],[3.25886349936593,11.1255409031596,-2.33656019845179],[1.61854941008296,-3.23663552324761,12.6890398018651],[-9.13581580350977,-0.20831766453805,-5.68466330403179],[-0.36824959835392,-2.08805001410607,-2.51447325792439],[2.7620316442563,-2.34923912366146,-6.73219698020994],[3.8990378584326,6.18715863394568,8.88099963711842],[-5.73416524412469,1.51710964682769,4.11959218636943],[9.55598127430928,0.99785963252405,-1.45891478684488],[1.37083644652585,-3.88666350373016,10.1501338766397],[-4.10624133006881,-0.431494701667348,3.24707009576888],[-3.85369467602772,1.58040003399663,2.35857355940499],[10.3470986754564,2.76330002391545,-1.07347130273435],[-2.88413142669566,-2.585993681438,-0.212653847565925],[-4.29004030554683,-6.10401794030539,-2.81554288843293],[3.48400044291024,6.12780046964389,8.4310204297953],[8.53907987149346,3.98855590789766,-0.750098929901742],[-6.15580882964352,7.44604207408041,7.86769214323084],[1.42736338886388,12.1946914631376,-1.81001693299894],[3.1851470309916,-0.584051188610282,-12.493103319806],[0.612850841487586,-5.61953511152672,-5.47316018603458],[2.27772403769435,-8.62552299726629,0.445426657124641],[-1.63962722978733,-3.90548262421278,-2.69475078232676],[2.37108910691014,-5.54222932042983,-6.10495074258831],[1.517687970765,3.2723606922971,-3.16262667789326],[4.21422174447253,5.28886879989939,8.42308542906132],[3.15837147614441,-0.475560136057847,-12.2514765764742],[-5.19383759561604,-2.66204713013162,-3.94990347378284],[1.28517354880907,6.36894695500661,7.68981120868404],[11.3539937506144,4.76800165842643,-1.34452462993539],[2.58201675893154,4.81132255836663,8.24317302751914],[0.518767619282507,-3.11311060557819,-12.0467790336312],[-2.42171303265378,1.41671184667236,3.55449871626772],[-6.78070730272979,1.80166543686801,-9.18769578963808],[-3.72477029429958,-5.5579688192046,-1.42985381733177],[3.10489282189973,-10.0815940673434,0.0667821606903289],[-0.954773453777427,-7.09909049011137,0.412645050406818],[2.61397257921916,-10.0150408204567,-0.0672346616696822],[0.979219719655725,-3.55566866991674,10.6874006929427],[1.74365590752884,-0.139970047252189,3.23446476998075],[-3.83281378413808,1.4438558723749,5.07622989300042],[2.65712368117315,5.86889797672184,-11.2504072812416],[1.70111600925999,0.442087345471611,4.21594042468239],[-3.17893760731724,6.72552370197023,-0.255804110831543],[11.5966090208218,3.13764828973617,-1.4398894975749],[3.8469135093703,-8.23702417262616,-0.811255115279149],[-2.7719759517629,-2.11998882565131,-6.51519093648899],[2.34401902504365,-6.08274395931586,-0.504631785032402],[-0.0581175682984163,8.99472960705846,-7.46334160593654],[4.10068874009042,4.27186445375966,8.31417916035668],[-4.4948271965131,-2.95375113301301,-3.00880656334423],[8.16558798422493,2.69973938777774,-2.39380802495783],[9.48402064912447,1.54535027184194,-1.76625223067877],[-3.20971784252426,-3.82198116053636,-8.9411116568742],[0.0590596894800419,-5.65905898826466,2.71207030043689],[1.13112225015182,-5.65386272345998,11.2617901143702],[2.62978893613253,-9.77758505789607,-1.60017993066366],[1.97316206405529,-5.00980205720679,1.61155411879925],[-4.35578371967465,5.5141738608936,-0.804016587445403],[2.95582405624232,-6.37793704656298,-2.16459237049731],[2.72947691234302,6.44592603463979,-11.607759417119],[-0.297539836713387,0.678963540436569,-7.93202555528006],[10.0848308160554,3.50248064687821,-1.54578174786736],[7.60981869270954,-3.00561613901409,-4.04161447100962],[-1.2433619005996,6.96372805569904,-7.38498305421858],[11.0389171042149,0.324432634493629,-0.85465526763576],[3.20638543944502,6.84674987613152,7.77363355342416],[0.955147892751791,-2.71518496757167,13.2152513096255],[0.702603157943314,7.32816687041303,-6.25860769414411],[-5.28311672638022,8.07246938119857,8.82604830853674],[2.40326054884016,-5.1545309742854,4.35136422957991],[1.19361449510629,-8.35260058417888,2.04539750553937],[2.82782712627914,6.63405921655264,8.11127527803621],[4.09141071104626,-8.52866849870412,-0.286674770973319],[10.2359551776424,6.6212925349381,-0.826439574466514],[8.74559725368036,1.25752952792269,-1.52417654921809],[1.11286993240783,-5.71305198861022,4.74242710364804],[3.40618933132204,6.26174685860586,7.9904231245322],[0.205280621015657,-3.01507477404365,12.324013098301],[1.89131265719233,-0.266041768386858,3.47251425468847],[-5.34163219402609,-6.02437582123383,-2.24096735252564],[2.40984050857406,4.18130549914364,8.65749707022128],[9.49871808007801,3.16948113438594,-2.38515217832525],[10.6842629402171,2.06028488484598,-1.52570685309724],[0.977759458135555,-3.38281642870923,11.0461983973353],[1.72212400922017,-8.21303589389642,2.15431622550929],[-2.12713015794953,-0.841063040137396,1.21277150313799],[0.818166986987367,-5.90745254610106,2.75819954200963],[-3.05519520774002,-0.852933122209843,1.89733407860049],[-3.16900336104333,10.8461771808244,3.65726072470983],[-9.39863310728682,1.29594940862028,-6.16778145996414],[2.82302394718182,-7.35892395283805,3.72062100938002],[4.11337402498912,0.799099610390262,-8.93633522445415],[7.43128368233299,-2.94744448563854,-4.29176761601384],[-6.9667444307945,-5.15943676224115,7.49552033418745],[2.77145250749812,11.9413267089024,-1.51301650387795],[3.08783849647982,-3.6201853329002,11.118415576129],[-5.48663715352511,7.21377998179661,9.13270317921378],[9.03812055604366,6.86283486620452,-0.0786187295249158],[0.741849160679447,-3.36469849746097,12.1765330663293],[3.27213647972479,6.68242291840602,7.87931738648531],[-4.39770006030481,0.156447426066543,1.80279810600932],[-0.600969426849318,3.08483818815794,-8.79497189045006],[-4.63443457057181,-5.92663610827421,-1.28476467912068],[-7.1318588021422,-6.35053522149346,0.123919048157919],[-5.18413170546194,0.64879083785539,3.86501049472206],[2.68279692503754,5.80917494602276,6.89809669622497],[-6.48232388631677,-3.05776120771965,-4.81000913087647],[-0.40681752717795,-5.24702597917888,1.6054065029098],[1.40535310470184,2.52485808293815,-3.0054505641244],[2.46098970142283,-4.57457949692334,10.2228820533043],[-6.29767539320551,8.31506880410056,-4.43626352466327],[2.26636031533009,-3.35795774019517,11.1637915842126],[1.87743306592127,-7.76987476941556,3.64744263273201],[-2.8637453822037,-0.403995686755376,2.95725128071202],[-4.32137166519804,2.46633418174465,4.64377159995922],[-4.70964306687631,-6.02211018600789,7.65480540048534],[3.25247620741788,-5.97346185436437,-4.75826292064586],[1.32555337396488,1.75415074234686,-10.1464296234041],[-2.25950732961691,10.8678735165932,3.06691596929974],[-3.63018587974654,-5.92514383976805,-1.72546950250813],[-3.05203511737991,-4.28683931030277,6.94804715933611],[-3.51346784048759,0.826086454377328,3.11907947432208],[3.06260293034745,2.13094517068149,1.30121055279459],[-4.64958987822313,5.34355091206363,-4.18587657775748],[9.42942055732338,4.22870906946976,-2.52159531270928],[-5.01387833503879,8.44619962248309,-7.38261377712963],[-1.38575963625949,3.18794473248867,-2.35790807244475],[-2.71849671164847,-3.52525348814288,-1.94168028493097],[-2.92585172949346,-4.66268897916373,-7.42334585414631],[3.81430834781084,-7.68009574373978,-1.07334207133483],[-5.84145643145394,-3.56690050101719,-4.22056651000341],[4.30256378239436,3.68001169532904,3.05670267752001],[2.0091167617711,4.23395150206824,8.58226123539442],[-5.426229478535,-6.02367463518398,-1.71299361581416],[-8.29384472998174,-6.79573381782604,-0.0164362143934094],[-0.184223563022752,2.93892412946413,-7.9156367468903],[-3.55994054410346,-3.35968541942022,-7.51050937919991],[1.01302966640415,-3.61731018728882,-0.432157224747733],[-3.42870326910516,2.5541523435123,-6.77649106829391],[1.74935439807248,4.01288292930609,-5.62372995513442],[-0.298013764776233,-8.826406144079,0.745302079851428],[-4.57943551441062,1.36698086362227,3.66290146463651],[2.58372433880715,6.46239308464445,-12.048174590271],[0.194652784770206,-7.69680015215342,1.19821140444057],[10.861017598422,4.9264924415787,-1.8037749326599],[-0.318207961890368,-2.88062707575139,-1.21955740130894],[2.95878988149398,6.72252073966977,7.68801857991272],[-1.89982706407393,-0.334484949142917,-4.66270124344554],[1.50867026841495,-6.39125601648063,2.99806511729123],[-5.95763818203793,7.00560824134869,8.42709756545268],[9.45404336815153,3.22827964162563,-2.84636256634323],[3.27451868602008,6.29770970749408,7.79007731083851],[-8.71115805641915,-6.96788714769435,0.297593803451749],[4.34052118376707,4.93161853653563,8.71771249350957],[9.78332016087894,-0.164673843676499,-0.586709057204533],[-9.11321619813392,0.192674028700371,-6.2135186027097],[-5.82800016810537,-6.31108549984163,-1.12661700321116],[2.82423359516974,-8.48030359111365,-0.528997686305188],[-5.50899501735381,1.23284253723003,4.75779962920852],[-5.38563648715648,-1.33866480660895,-6.76655963885451],[-2.69577691467662,-1.17166445989248,-3.73138204651768],[4.88848596790197,-1.90309959297799,-6.77043997169853],[-3.66486551379866,0.837123212164879,4.16916342987378],[-8.50718755807092,-6.82182417851019,0.455073891204445],[-4.32903927497103,-3.33354988790786,-11.4391606572232],[3.23414568760382,11.5672312555755,-3.00060177179986],[2.5782139801496,0.0150636611161908,-10.652631575145],[0.777016176208576,-6.40202295199128,3.2337279328957],[3.30920016972113,12.0204509915915,-1.48813591734481],[4.60855284172952,-5.88208547671374,-2.84289485628894],[2.20674115058756,-7.40265854667826,-1.73054126529742],[-0.238187675113942,-2.86781514878739,-1.254189332867],[-9.70651742072753,0.682278606857949,-5.62518907575748],[-2.69915917766119,2.09310793148815,-5.26500002948334],[-4.24396185210606,1.37237193417006,3.70435844092742],[1.94013726283997,-5.29094685510187,-1.84298822254028],[-6.75296210561494,1.88448835364488,-9.21106128856181],[-0.571716051201325,0.778169931099161,3.19944901667375],[-0.0724585833776719,-1.5916061294003,-0.853503514636183],[-3.90190112436458,0.452813907600051,3.19172335680515],[0.780700560934673,0.937696424013339,-2.60233646099747],[3.4785786125527,-7.37323131956126,-0.785748508821783],[0.754107296555141,-2.97637491362952,-12.2284364574919],[2.35057746782757,6.28068120363182,-11.5813910417117],[11.5495836375978,0.751893784345852,-1.25552958622554],[-5.49122459793942,-2.84765577430768,-9.30093312064177],[-6.86114348752548,8.40054682996896,-4.01378399146116],[1.8642373985996,-5.65227329872897,3.2013314824425],[2.97430391390933,10.3904550657956,-1.67092748483642],[1.42716681932314,-6.39882654870411,3.92386663863435],[-3.81633041069812,6.71983293305618,8.73704461551605],[9.17302162818208,3.0842888605093,-0.655551481619165],[-3.73343829012704,5.49944721006786,-0.398613501013599],[3.92395084796274,11.0791814725667,-2.62052842072998],[-3.84227669685575,-1.49139566091625,3.94234810648572],[1.99804727633016,11.2339894568081,-2.94685652570314],[-4.72104605268804,-0.892035344365375,4.33414801721332],[2.75049014741933,11.7003418545075,-2.77748374106326],[2.13112030815744,-4.71544322190247,-0.302129053310239],[-4.80350857197976,-6.20450519283222,-2.33885529978619],[-3.89458360075841,-5.23927791999368,-1.94090107158582],[-2.45474567599839,-1.21562733976269,3.33747489840535],[-2.7057096146021,-3.87200011064605,6.63528508115906],[-0.1743751530321,-0.683110809086945,3.08010317133897],[7.88996767453492,5.37768829622288,2.81019178702838],[1.74391774409204,5.73805413984754,7.89013555124861],[1.90969326919409,0.416922339851767,3.19834851297341],[3.35214506559004,3.91386375506884,8.61401006492274],[1.81749967339274,3.96769796382424,-5.30966024651618],[1.79589763776805,-3.84940967215504,-1.47646444907066],[3.41330555394595,11.193766532079,-1.64372704987633],[4.93088653846618,-1.4439420537006,-2.72246379657173],[-3.18225981153868,12.406885614411,4.30824948531252],[-1.93143848993892,-2.94975746035721,-0.590677701121741],[-4.24741096241606,6.11072825270427,0.0602806722128416],[-5.59617969758539,7.66282557783028,9.08014972841357],[-8.95452648226452,-0.575914286061104,-4.93585769277966],[-3.8096509937243,-6.62131402647971,-2.11964954899576],[-2.47129260187607,-3.19476238262772,-7.47048228578639],[2.93869715981135,6.0148196304063,8.15249253744205],[8.21595360346568,5.64944148634637,2.88930325150315],[4.34317670920383,11.282215885814,-2.14120551324888],[1.78959103018884,-5.59944848887735,11.1794901646024],[8.77221562169941,7.12788424614653,0.711855157866463],[1.7180132798146,-3.67099300197259,12.2726488331985],[0.987113485154889,0.620752416839176,2.71987097476421],[1.54980440865017,-6.24690301859575,2.38711649115736],[-0.408505461542606,-2.33098510569653,-1.78307969403428],[1.23025042172886,0.511035782914691,3.63143108556385],[-3.95132187622231,-4.62919703335244,-1.61556102892986],[8.17605866703856,-2.993181769846,-4.66968697013036],[-0.138347594612311,-3.98724529979464,11.3218278014302],[-2.68132099994959,6.83272060283717,-1.04903398570719],[-2.85843247266987,-2.18353857401259,-6.60804134139766],[0.862701851555257,-2.73536748135836,12.1140703274548],[1.7556853316915,0.879107021037839,3.01719297478132],[10.1646093057077,2.31540154554376,-1.51061150975807],[-0.0276972324295526,-3.28152840456083,-10.3814658836441],[-1.65251281606935,0.0470073200015269,-4.87011943291342],[-2.68410568871061,-3.23935699662581,0.237188927034482],[3.05998147124219,5.25678043193694,7.98307528707875],[-4.13140495130591,2.60571493835184,4.92004081797099],[-2.09437562083549,-3.3073010234612,-9.66036269887547],[6.90782996518924,-2.55101207114358,-4.44740976119682],[8.86316578556447,2.35726124418387,-1.81421958072828],[0.626644459921436,-0.238741318283545,-12.854783095133],[2.84672148881601,6.30391544050484,8.32703277922844],[-4.559394923339,-7.06065056204578,-1.95082231838659],[11.5054576050527,3.57716842479259,-0.984356988698715],[-9.25623783720479,-1.54770988305475,-3.24855312776917],[-4.25009501709771,0.380438119231867,4.21267890107193],[-1.80222850939362,-4.47886205143035,2.26570023870812],[7.62824830423535,3.58682782301293,-1.99130111591611],[9.28853868050372,2.7698268942489,-2.05716397625944],[12.3906882921775,2.18546187814079,-1.16542949911397],[-3.80296625718377,-5.35314489592159,-2.27507510713043],[-1.8877181803309,6.32955013130429,-0.356301621000125],[0.132056037366994,-2.80670143030489,-0.956476485693395],[1.5061133522493,-8.96654809867374,-0.935669549375598],[-1.80821087775599,0.333161510385294,-2.10047084663521],[-4.40570350789402,-6.50021906867703,-1.21411220515947],[-4.63714001020665,6.5879199703353,-5.23392614551678],[-6.10293039789094,-6.10050247147085,-0.668250421853124],[1.1635382936268,-5.26959833396461,-1.55628074087593],[9.8603532480157,2.7895477751566,-1.80288468001462],[-5.28506974196992,-0.623832531855786,-1.78029698170928],[2.98925704642788,12.2902227267652,-3.08278202716712],[8.95172813798685,-1.94981426277786,-3.79653965901094],[1.48223348914471,0.52758571683897,3.05446786148918],[4.49238495223385,-0.979138601531239,-6.58244475944594],[-4.76598895107555,3.34702434123112,-6.75062053212255],[3.03928838916825,10.9757940030243,-3.14450766298374],[-2.67611500804741,-0.135719909514174,-0.73673812479549],[2.75234759403449,-8.42550187597634,-0.227006802039291],[-2.60625593576039,0.114209323864151,-0.965911116579791],[-5.11691590797476,0.0380813368268491,-1.83238018228788],[0.708739811855181,1.61455624589744,-2.30780337899263],[3.71504778540746,3.93310827144229,0.736443073557727],[5.05687215795749,2.65877951034037,2.74145134848496],[8.5996814080428,-2.33776349978253,-2.78505535447533],[-0.684663391487919,0.489820757935828,-2.88987852811268],[-4.82000796790412,-1.02444969273476,3.31802132391411],[7.4736924331066,-1.3281526237105,-10.2830149535667],[-7.05208957809762,-0.666703599742473,-4.49046110789365],[8.52217192575832,3.80445855365094,-1.98385806568359],[-1.76689433038521,5.18033265474786,1.05269458134061],[8.86161800064754,3.28372243773481,-1.82008002045279],[-6.87079494447424,-5.76832463617105,1.12782309594481],[3.35487620339013,6.1800531269987,8.43889556389047],[4.44783088805794,5.73375670085427,8.95517328540416],[-5.85840627981866,-3.53095353614115,4.7170638591009],[0.374172222963329,-2.50433061205559,12.9562124317938],[0.624248742340639,-5.45340831967474,-1.22443306993253],[2.41556670210669,6.43586316571954,-11.4574940668105],[1.83662308635498,-5.66395299503899,4.09913857000295],[3.69556962185196,5.47487703757635,7.0909956044319],[9.13542266375338,3.15957305438859,-1.30883238495146],[1.7580081892699,-4.89990190182828,-2.05454648365383],[0.775756736837948,-8.67352408035528,1.88024173174111],[3.46333656681552,5.98820921456928,8.05928956121685],[9.83406566732992,0.910229440012886,-1.49044986268442],[-2.75388804122696,2.10651320826872,-5.31640326441422],[3.45533177702461,-9.14823367067354,-1.36500051057718],[2.89454250315629,11.5116613351701,-2.90881222344834],[1.07941784473224,-7.97342983228183,1.97180617619482],[1.52115679739719,-6.77243673214363,0.550118869300494],[7.85210275993308,-1.77042749621948,-10.7888627093353],[-7.95626345587412,-6.96184966804153,1.67289583140279],[0.441861829275141,-5.84636648171606,11.1196072579872],[-2.26109263578464,4.10161244593341,-2.43259945742216],[2.9979926353328,-8.81943167628683,-1.2628015451472],[-3.81499236833027,-5.70806809390114,-1.82652717505239],[0.173083658442411,0.0188752064548156,2.90544460904493],[0.316305318177111,-2.83921853538341,-1.00199153883688],[-2.877511253618,10.1403871329404,-6.31732617789198],[-9.07410557812792,-1.69288441065892,-4.50364097834364],[0.601441634600151,-5.28017719771243,10.5850281314929],[0.370907007005919,2.89928358521295,-1.72174978797221],[1.36027930089545,-9.71212002451163,2.14821368603739],[-0.63283851311939,1.69401639614422,-1.64321527771144],[0.722238817495161,-2.16425809208483,-1.87646173836237],[4.35243963760567,-5.50944518237332,-1.17701116198511],[0.644056392868011,-6.7869806756077,0.13203223374322],[0.769404913693762,-5.63197386542923,10.7593763393756],[-1.51964676695655,3.66568898118291,-2.69705465078545],[-3.5072460398603,-0.632642426784808,0.485802760130951],[5.11579947243141,-1.68337844317678,-2.78034364498023],[-0.261933208416447,0.0376492518076732,2.25576913289422],[-8.73506239966546,-6.20148309642718,1.08722067897213],[1.46618391366533,-5.15325529303487,11.0521838425301],[1.92803051493931,0.479895944975286,3.66622680717505],[6.6625022565718,4.38821361167888,0.483179656779968],[2.58053694962734,-5.79020195986707,-4.37710404303081],[-1.79295759960689,6.25934704094239,-0.769389682115805],[-5.27453561030579,7.47819253339308,8.64764827992037],[-0.349443847442282,-7.37429065699438,1.40108179025613],[-6.5335725152476,-6.02051977807022,6.89682343095636],[0.749099299270476,2.91593958603985,-3.46945080988356],[2.72254033928495,12.1741429091916,-2.01766160315306],[2.45272394046932,-7.05900084248453,4.00413925280199],[1.7221478055938,11.3829608117835,-2.55193314346582],[3.03450324139168,3.99465403013377,7.76815118774428],[-3.94258066396462,1.36675133307984,5.58197979183757],[0.933406385272783,-5.58240821015108,4.00324476376043],[2.65752213772643,5.93153932842992,-11.8465525528123],[2.81047438944034,4.16917989565455,8.36369478516202],[7.3070749785869,3.59918535602071,-0.0571114721313704],[-2.4424329029169,4.56679772449322,-6.23342260719973],[-5.23571779645637,0.812005965532167,4.36915237134918],[-3.21190206380888,-0.0293496733832854,1.5901165538072],[7.688060060252,2.46507347116907,-1.6551742040161],[-3.69772304052815,0.695539390767144,2.0738443301108],[1.16641153164683,-8.85584494371766,1.76603008491761],[1.06036827017641,2.53516762412423,-3.32443740535763],[-6.10768644881687,7.31492512626967,8.8792386136284],[0.137307815352624,9.38131306707429,-7.73645366472788],[-2.16086432654147,1.25751059416028,3.65014836716375],[2.83531065649846,11.1085364444471,-1.00331037868256],[1.92004601871534,5.43138029314513,7.75200396351182],[2.85204441629994,-3.06942916350737,9.59031436548952],[0.186688726984005,-7.60435448314721,1.12572139558875],[9.389204715755,5.64813306111631,-1.21688437971695],[2.34300222556641,3.70004775170033,7.27739632752605],[-1.07956495306292,5.69801528793436,-8.18376010151152],[-5.51202355620412,-2.81221987177725,-4.42152736398027],[1.44434458242788,1.50861517519273,-4.33884792803704],[-4.60338497518616,-0.523330171157663,0.512246687443296],[4.22928660459996,2.52932624128815,-9.71534344641811],[-2.10284987499273,4.64351217620368,-5.63939444224818],[-0.77618121154633,10.0140656157524,3.00576443301233],[3.00759837331444,4.6307226483145,8.19519781288794],[-0.00224534441198887,-5.4510645743628,2.35433790897942],[9.58117036239527,5.26327822615396,-1.43645848014283],[-9.7256642868423,1.15142651204269,-5.80206634239823],[1.02988764630336,-3.21616130087838,12.1830562780443],[4.22884672220099,5.49424950925685,8.53025473229851],[1.43491808132493,11.9924032336728,-2.23458346289393],[3.06660638840904,-5.17270697874954,-2.11062729796873],[2.09561643304847,-4.83841789360921,10.5862832552767],[-5.54604018460252,-1.10374074849129,3.99186042394646],[-5.44343769553686,2.97763513557222,-6.22390832875915],[-4.54513630725164,7.22513158265835,-5.16955636947488],[2.74231091205101,-9.28622907885834,1.43353428091326],[-0.633560532505165,-2.92484967885149,9.88052972897079],[-3.60469885440064,0.724302208554886,3.45839202713437],[-4.66476682860335,0.102471917044092,-1.51876946904903],[1.61790070719534,-3.04292164343163,-7.87519392477078],[-4.98958246674076,7.69242619016507,8.41929057746934],[2.45289062870267,-0.175404351519547,-10.1661351047385],[7.31542195601793,3.85322935820376,-1.17302135906678],[2.14132804455233,6.88706839038706,-11.5593144169046],[3.24745225680944,-3.69743449014643,-4.89312588712546],[-7.84678702031354,-5.87708368138178,2.03743424905513],[-5.3086572192249,-5.6616983536865,-1.7576461003851],[4.0440169672589,-7.06884997369565,-1.57657895521632],[-3.88415678216437,9.60367996318784,-6.87582969197215],[4.14118647106477,10.8380935668213,-2.36552780917034],[1.33473539697775,-5.3397645946349,-5.72037360200694],[0.0473139762623106,0.176459616103943,3.17804119060648],[2.73930130434997,-9.40996358293809,-2.05195416107005],[-2.88838405268114,6.1461868448631,-1.38546645563476],[1.44856554797975,5.55304543344592,8.9237517254212],[4.24853670439021,-6.58764992497761,-1.46026560028051],[1.0069246925592,-5.46086297523035,10.611546658696],[-3.25608715256509,0.600461294520628,2.43789173621148],[1.67278735592484,11.2381183178426,-3.02239862387511],[4.09600200693642,1.88851833136435,-9.21626765465635],[3.34840372613032,4.50679906666007,8.53841660190634],[-3.31525033786324,-1.90759004649627,4.31369683571704],[2.79121511665627,5.94170960767474,6.52171078909788],[2.991085723959,5.14000738413791,9.1846336462378],[1.33133151493091,0.79407156379165,2.62434614770655],[2.28637824228383,5.85357615808095,-11.9498720515083],[-7.20839746684717,-6.84328332563872,1.09798408186296],[1.71060446697052,6.33827380124228,9.75252447196424],[2.3613074849255,-7.82941543696026,3.97016218662819],[-0.552963040628518,4.30949277571349,0.227607878429173],[0.759894513913224,-5.85373088211124,2.38055172192349],[2.43031957671739,-3.50788565392618,-11.1628714271257],[-1.53359309294805,7.24858518308294,-7.25651941492162],[-4.03800799249693,1.11747888194721,3.71390604480863],[2.58493317803291,4.11448184199825,7.75889332317946],[-0.236610440454103,4.65993538563514,-2.36339320357223],[-2.19379051123785,-3.34323119835205,-9.35074727271528],[-2.05464459358991,10.2216674880742,3.44723419674332],[-3.6612456837601,3.28887477938634,5.60729965025932],[-4.57036275264109,-2.80036659461325,-8.73500652485871],[-2.31148004608355,-3.51652931076186,-9.7613242455452],[1.37863661560228,-1.28224341520222,-6.61403437732869],[-4.2767129536507,8.15032271337488,-6.96989144432493],[-0.0319627650658405,-7.33010147904731,-5.9212322484258],[-7.3608568574001,-0.391700381346968,-4.81570412718638],[-4.74500415604246,-7.29358530332455,-2.15181769636596],[-1.54837509531998,10.0307652547665,3.2867658386643],[8.18922165975726,6.09146609825053,2.21695292406208],[9.44791955031452,2.23986667416414,-2.97300105637376],[-4.92858733660144,0.719320106677237,3.14611107801162],[2.19972301524315,5.86848184908621,-11.8111947953185],[1.72342525116727,-4.75447572505486,0.245258424689381],[-7.07696241793181,2.4572610897776,-5.53547004760759],[3.34083580742018,5.53928208609374,8.85276878632031],[-0.275707446655685,-6.67881795455915,-5.60040316943067],[2.49862223737116,-0.118593616849362,-10.1396753234597],[-3.14413798550606,-4.16788177114145,-8.73049282512458],[-5.06974020547448,8.64946687423402,7.95205024386839],[-4.12920290894015,7.02788958403641,8.00637451239718],[-3.81409120875745,-3.3221880884965,-7.72073656215365],[-4.25688365675851,0.0445769010515942,2.69964504513896],[10.192337408569,-1.3701115544961,0.77855865356883],[-2.88731994437941,12.2133880462595,3.97942341916567],[-2.88748070631956,2.4083077833224,-5.39411661415851],[2.83841971449008,10.3445376076786,-2.03054962251409],[0.752925495302177,-5.07017743238517,4.35754320478217],[-2.03693526855408,-3.08569216725505,-9.39286780083699],[0.459429665466122,-4.96842798399147,4.30205567641915],[4.8235235923025,-1.26638569436662,-6.61780249963418],[-1.38813546409646,-4.01113259438282,-0.295706077958894],[0.9204275931575,-5.27585154279277,10.8426636461405],[-3.35626446037761,-2.61174320057719,2.16070402357443],[3.50845134071723,-0.106287500670616,-10.1327935826087],[9.47759614238637,0.724871128589108,-0.825596862283856],[1.72308040328691,-9.65885089760566,-0.863642292440498],[-4.38071819692364,-0.288578589539273,-0.676839950750948],[1.23917933190576,-5.54527020527612,3.05296843614127],[2.34411508041215,5.39758889073118,6.0649944300375],[-4.75381435944044,-6.36240123573259,7.55991348137936],[11.0765362687364,2.09203219514453,-1.85970542736248],[-0.51017649469327,-1.0798356372849,-0.300199233015373],[4.27738019570966,5.49889900248253,2.7556990537276],[2.03106074830119,-4.68465299351986,0.461265153626761],[-6.29007291311695,-2.67852371827165,-4.72412400567626],[-5.13988138091161,6.19724104827457,8.76294371145062],[4.07803588349113,10.7274280807267,-1.09421554522149],[3.6479823021818,-7.28865515360122,-1.55903859738931],[-6.39953390249845,-4.03773600484182,-4.03128124400535],[0.139594504634975,-6.77589093627568,2.39537373692702],[-3.79475002979779,-1.46671842090124,1.81598499460552],[-2.91972791405978,-4.07488818080391,6.67355196160464],[9.51061265421137,-0.561019314410665,-0.78651660165855],[-1.33513029555647,5.07609703030324,0.362181573544683],[-7.25908457526438,0.60954770236078,-7.73976244534724],[-3.15920918519055,-3.62841850396177,-1.19784472132101],[-5.84838804957895,7.35027959489596,7.87935534635879],[4.45633754725318,-6.83347133243037,-2.65435582879831],[0.276654268821423,-4.15837935665921,10.5630885505919],[-5.94358587206578,7.58187825021006,8.99844109599234],[2.49327270250116,3.62494911209848,0.576194791098775],[-2.02054959217861,4.73998041096828,-7.30779709050286],[4.13017024744937,3.84342059062377,8.96011305127799],[0.319676913435443,4.23823362791395,-3.56511591760388],[-7.38577021885912,-5.81902236188794,-0.29724159637846],[0.913900766765478,-5.39467849593913,-5.31957345580463],[2.85852059988368,10.9204535833933,-2.14545298230837],[2.5496605926092,4.15049822072143,7.50689725772454],[1.44593411382533,-5.29496419987642,2.88218548769343],[-8.06806736161899,-0.450811582798378,-8.18951035684679],[2.78834444004551,-7.18730201402977,3.7089463147202],[-1.51287924183643,9.49856702594062,3.53130674344649],[0.760064608019729,-4.15376993026839,10.1049067289085],[2.21745501094591,-7.96381936622837,3.29729281442269],[1.11094652289741,1.78174664295584,-2.86877417064309],[-3.94060905460214,-6.16432068590092,-2.53652198374709],[9.27604117510932,2.71473224165171,-1.12097859142261],[1.85869970821747,-3.31293194219441,12.5667039582687],[1.97668117054561,-5.95061589044517,1.95608084901106],[1.73323032148461,-8.98137092118678,-0.940590788616471],[4.28767800999672,10.4412070745115,-1.79093387709005],[-3.06119048324115,0.647959876982537,3.84684985219173],[3.78475197730397,-7.16136542862585,-2.16648738177121],[3.52290685175761,-4.93806529606307,-1.34184522472792],[-4.51622160286191,-5.62676016344128,-1.32539168558449],[-3.27015278876148,-0.78965050295953,-3.64869477329863],[0.584064558920455,-3.33534986221796,10.8857561199694],[3.06302019954845,11.84281304556,-1.36967802409539],[1.26077450969994,-5.51104115513194,10.6895561940765],[0.990585980983383,-2.76559547527277,12.0028296415727],[5.01013025382679,2.7486052878221,1.95964672586982],[-0.0190992885515375,-7.88194467301249,0.918377399009105],[2.11838399820359,10.7193514830221,-3.37127056898525],[-3.12464437291146,4.53349904081379,0.853006386164416],[0.871319895361904,-9.5217301946244,1.58368483471324],[-1.17234244177822,9.97991440927757,3.32353106907971],[2.92738801975431,6.16934576002927,-11.8319999872088],[4.13242212715198,2.3823671741603,1.64859603937954],[2.80540479705023,-10.1592667036262,-1.15159908531544],[2.85928957507317,12.063709591243,-1.52003238084286],[1.77738933211619,-5.13145161947251,10.8257725729483],[-2.58275999544346,-2.03352498361064,-7.96095632974962],[-4.95798036873063,-7.02138286141254,-2.18728130667201],[1.415486943325,-8.48345351514515,3.03948651906134],[-2.15330650339415,4.25239207290246,-2.02557898136195],[-3.19763556014747,-2.66197777116715,4.74129334628634],[4.97731500463826,1.95461409027397,4.4729314349328],[-5.30868330943762,-2.68043246573252,-9.11742758305536],[-0.297165246292671,3.60469475719033,-8.80242914485613],[9.14282810191356,-3.50370463333829,-2.11753007430977],[7.69345312284023,-1.72656557629696,-10.805757280094],[0.954520281278617,-6.50386327209653,3.51475898460256],[-4.79622175774294,-0.297319096678029,-0.97022620046894],[4.32377336763379,-5.55730649902957,-1.37860951941845],[-5.26142320943956,-2.86591593708373,-4.89545013048348],[0.798039684634563,-5.44999962282351,-5.27569236867032],[1.03303980004806,-4.25376763431167,-1.91810935834305],[-3.56006601092249,4.78005625848242,-5.44493692239241],[2.77815945856936,6.40430912242486,-11.4586404818039],[-0.0475990756067393,-6.56830773061951,-1.10755321867404],[-4.15435724321165,1.11530505935335,2.94890768979101],[1.85372094933445,-2.59661967672076,-7.67378974867747],[1.85447164451303,3.94455427432919,7.79458538997865],[-4.14328746791807,2.37527054641128,5.30769210951942],[-0.0497605065598647,0.403270300707338,-0.318379121547741],[-1.6306150228555,-5.78356603331907,1.5431966530487],[0.0306145681646636,-1.53753408902038,-13.4280947222606],[1.41226090334212,3.0559674987469,-4.05375230091395],[-4.96770362108221,1.22854205317709,3.18470124020576],[11.8314460531905,0.578888301120428,-0.812660780629142],[3.26804450775783,3.66736692071276,7.89142065380396],[3.36685496036168,4.92051344527614,9.11534921081595],[-2.57217066794975,-3.15170032649232,0.15760679093355],[-4.46547594082106,-5.80682870252371,-1.69419616329602],[-3.98216245157404,6.22430401623577,-0.185034937250725],[0.722117270069231,-1.39745110753517,-2.46884415347111],[-3.2676921318783,7.17803150356998,-0.451613390471486],[2.23828260882739,6.48515799890423,9.20590425251706],[-3.3637313939991,-2.55096387351991,4.29589558858211],[1.33212158054994,-4.82495185051794,10.5680651113362],[-2.62064130851095,-2.82319756284737,-6.11666119330733],[1.18267023638221,3.45996243271836,-3.76377506232121],[0.947729429363471,-7.10229067342685,3.89237176853654],[1.63016230648203,-9.12869170367499,2.87806833418009],[2.92920387876468,5.72752451066491,-12.1931465326278],[-7.62919115762782,-6.68953158596519,1.05035099596302],[-6.05414518173723,-4.22213163292708,-4.10238025906505],[0.763038649440044,-5.93737061873001,10.803331800758],[2.51097974432129,-2.41627063571868,-7.04240640658957],[-3.30666839925702,-4.28180703113536,-1.60107138083698],[-2.45796526263826,-2.27404469901013,8.97629494055221],[2.09081582413036,-5.82857096805618,-1.08165105759273],[0.147030771839754,-3.31810367628889,12.4874677596553],[-1.70398709712491,-6.01115937852695,-1.61968373531622],[0.531498214163434,3.55233004224322,-8.60008684251947],[-0.0034683245177376,-2.9098169607692,11.1608993092815],[-2.76048752048371,-2.93981531954934,2.10791127218417],[1.27601468791408,2.38468834725814,-3.57395120574162],[-3.78359817705231,6.39568072937505,-1.09418130106835],[-2.15208071878607,-3.9686128657958,0.268029378524614],[-8.15973358555163,-6.08678139260753,1.12698974266739],[-6.35937638891418,-5.9445511250086,7.51471979365465],[0.211622809757795,-5.3335311072419,-2.25225834958679],[-0.633368067888941,1.84362149475351,-1.71542310522274],[-4.25473527781755,-0.885504515602665,2.4530940808503],[0.649263043540593,-3.80467706786945,10.1198330403685],[-5.51637969936143,7.43381148683776,8.17413399450786],[-2.76949248241465,9.07912300094027,-5.7345019400923],[-0.575746888756273,-2.7355285455755,-1.26369753103031],[-3.74977044185834,-3.43148557099605,-7.81490910123873],[0.733304200344125,-5.69843940729758,3.22959965396744],[2.16514948613775,-2.33703135776798,-7.33694468328167],[-1.48622622894919,-5.41303468119065,-2.23049009893774],[3.28027962930521,-9.98189291920182,-0.147894949360178],[-2.35784580372769,-3.29074960314087,-0.400412281158639],[3.34161762886831,-3.66657358706082,11.6298356018048],[7.37568575892484,2.76237686794924,-1.59550773074981],[5.22470687214551,1.33697066460271,5.57563209180659],[2.34413944295163,6.68581419801939,-11.5522858479881],[-5.45871852465698,-2.35664649369106,4.42533223245948],[2.86982711280248,0.132703101520314,-12.2903018280679],[4.45987227149298,-5.62283498588588,-1.67745414423605],[-4.86528478650523,-1.12596143373404,4.28852252831683],[-2.11489368280734,4.10347097478097,-2.3897533552839],[2.32773864773182,6.58556292740007,-12.1281099664538],[9.04842666825689,3.15929269695095,-2.68109402399766],[-1.50814605143229,-4.00804795448497,0.0506814529712711],[-6.72411168863716,9.20980101864172,-4.30332251190736],[-4.01264384726643,-5.49625684578788,-1.72028118203062],[9.46365033515598,-4.04788179153502,-4.2078124549238],[0.106589673092779,-3.79788091885397,10.5107778317381],[1.27483803830367,-8.62317312961894,-0.00412481469087866],[2.72058184441036,-3.52619215692536,11.7876530226162],[9.45002588047704,2.45813745707069,-1.70592806920327],[-1.59536186262533,-8.23644295991221,-5.51721337485499],[1.26436542343059,2.10628826023074,-2.35579233626986],[-4.89821507231099,9.72359172277455,-4.11743667481621],[3.13230107252046,0.288053465630733,-11.3105370994574],[-2.63903236826296,4.7016726541826,-7.39768375480856],[1.25549144773479,6.18251094082048,7.76527088638363],[-4.54006772457216,4.97358387638686,-0.41507074524471],[-8.87940571834424,-0.582124497136921,-4.41250847746209],[3.22672417504782,5.87719247056042,8.2895917052259],[-4.44224711567551,0.837329704194927,5.05756727916593],[4.16356208217819,5.90370277343392,8.54803625742946],[-1.23312804907782,-5.74813191513783,-1.43504663198107],[3.25706566430586,0.495136864225608,-10.9556296824249],[0.899550954593006,-2.83243600241568,-11.5916106442801],[-8.37421609285785,-5.76689692522646,0.670791539337208],[1.75864732736665,-2.86723319354143,10.7763581582548],[-4.71688676866134,-6.60743985526987,-10.2789636521151],[1.75295703595368,5.92193988814564,9.40969074793568],[2.85573250185401,9.70138254424941,-1.40200359647595],[0.423034281615864,-7.4847725661539,2.22790931459952],[3.36387395836694,-9.26834857301209,-1.579291365733],[2.09108602424494,-5.21436269259481,-6.00502783978302],[1.43769091111663,-5.89057574634884,3.31529054748079],[1.31731211215987,-3.87464866937813,12.8353464395486],[2.21077285790997,0.413166326697688,3.69192885886543],[3.09352370736675,-9.33427518157986,-1.01836765817919],[-3.36856422936438,12.2786628417291,3.53477135343299],[-3.18351386486642,6.04978698547843,-0.705080627427206],[3.34115461945829,11.2772857757727,-1.05567718403954],[7.55524282017776,-1.56523326312878,-10.5947298154357],[-3.22013556978623,-2.66436670959193,4.64304560870674],[-2.82772947577685,-1.71466717032133,-3.93049615051832],[-4.57773101009919,-6.29155669715568,-2.72893298816397],[-1.80051659251857,-6.55654929745461,-1.39009403641922],[-5.39276920264118,-0.623320423390266,0.603532214064213],[1.86214656383017,-9.44109596272399,2.59431035117716],[0.906250656515715,0.849661347443698,3.79247445499841],[7.35614378179878,-1.33729019417866,-10.5933326130012],[0.375828608926364,7.47934890781061,-6.36534806826329],[3.37848463346347,5.78843362593806,7.70008108234131],[-6.5503872805635,-3.75555838938919,-4.0778731510725],[-1.11469921891028,9.41862552820601,3.38963148288366],[-4.4515669439357,0.777583494460066,2.81812903890024],[2.61131503182937,6.25016115785185,6.61693632749081],[0.81108957727092,-0.743070345156077,-8.78500575688201],[-2.64504574405517,-0.761533734276183,-3.69656588812107],[3.36480460091119,5.88225994072597,7.35323894614396],[-5.31910561729861,2.7849975678815,-5.03983475113364],[3.76604449780961,-2.21129855267495,-6.6278774477055],[-0.00801405636351238,-7.86794108964633,1.15008741860966],[-5.56588578363293,-6.64260138088159,-0.827198098971778],[0.849713674367922,0.673868847250163,2.98366215553748],[-3.11297941925476,7.00608402382152,-1.06420297568906],[9.08615964913647,-4.18057812818807,-2.02059949580465],[0.0866354221595738,-2.81154994935389,11.9680054533111],[11.0824746398791,0.465647987859723,-1.12441122521788],[2.24721261394022,5.85400517622657,6.41957810785326],[-0.0960082840786864,-6.76881841913678,-5.50924342408586],[-4.41827311253791,-2.83673498811657,-2.96986158169522],[-2.43018982297601,5.08853736275455,-3.06387373781302],[-2.09154347417041,-1.35682570811757,-3.56269302018778],[-5.33616334469359,7.08479720481574,8.26571882844169],[-6.41713035433602,-5.40201092675568,7.65288781250312],[-1.14233626557711,-8.07004632767022,-5.83941693359112],[-4.44969228222645,-1.08814597470625,2.3209988040893],[0.88461291243862,-4.15442127848868,10.5857341542634],[-3.29329285330934,0.137025833970552,5.57054926050533],[4.05283696903163,-6.34686768958944,-1.16586977326294],[2.09709276266548,-2.6429709878411,-8.009413605093],[2.37501448585315,6.28814992620599,8.48883629392051],[2.33021468400692,-7.56013339443041,-10.8443946125154],[-4.10437378951651,4.95604998000172,-2.60618446408011],[3.435446576825,5.33925525781551,7.59499380549128],[5.12744883013195,1.60979225282156,5.14593251912156],[2.39245026755528,6.64294959198902,-12.000278185793],[1.5377963187059,3.94559450547618,-5.62174583284241],[7.64443801825414,4.92789630074785,-1.07074188909065],[1.11133445854639,3.16395493329255,-4.03030953660402],[-6.26895606351558,2.81811809793762,-5.80310582486377],[9.83274292566798,1.81933352326502,-0.530412885710806],[1.61588112346896,3.50870617479321,-3.69523341264468],[-1.49307415679769,-7.04945591191543,-1.1915965135461],[-6.24244807577163,3.45099582482859,-5.31122450049597],[1.38017801617017,-6.52592137455122,0.299576886884517],[-0.397294709062325,1.20727451571678,-1.90587736472945],[-1.71645907991235,-3.11282786841668,-1.36121175881423],[-5.05881984808326,-0.0679868873489569,0.413669198515867],[-2.57422145364663,-3.65150606236813,-1.77133925154455],[1.37730634203887,-7.72992090621606,1.66349530835292],[-0.50420359215935,-2.22009198346051,1.78454698875658],[-2.5842222949828,0.359564283857499,4.76802630133063],[0.123472969706378,-7.6126576594658,0.0726328860065092],[2.16760642823291,-3.52180879862011,-11.3691231121598],[0.643489016133121,-3.80573643759555,-1.12438752130634],[0.750082872519972,-7.74316236601395,-0.305828263471064],[-4.41581050692992,-0.187874920714407,-0.827279582037944],[-2.4836384864628,5.89226845676737,0.559353405394377],[0.712265773729802,0.532229903311687,3.61032023332516],[-7.77296176943595,-6.09681412250635,-0.338401837432285],[-0.720420177920934,-2.79877500588619,9.95268481648276],[-1.52652708820543,7.29068963709994,-7.20463395036321],[0.400757024425339,-2.21943437292489,-0.0596421575726402],[5.10581311997204,-2.9712106718889,-4.31201021178465],[1.55222455449778,1.52325545908383,-9.59416786895661],[1.21820164967183,-9.05347155327813,-0.734983746436904],[1.54906523387205,4.4572793503388,8.11206195530376],[3.69431168205685,11.1459515033826,-2.44733339854198],[4.57235823702673,-2.41029538153579,-6.77744132474324],[2.16768359391068,-2.75970411652121,-7.49596964738788],[2.45286759794424,-2.61016184285503,9.49091977624967],[3.19761603353998,-0.716068797864306,-12.4406305542871],[3.91590780316923,5.14445030249448,2.09788776678104],[3.0203727355166,4.52146217687746,8.45441831413086],[5.87174353306325,-0.249425774916343,-9.98417787304674],[4.20123424709215,11.4508691612861,-2.10612880693361],[-5.37747615245289,9.0908719406432,-3.85974434988203],[2.7869093195588,-8.56380758059582,2.16645599698509],[3.08163995398979,6.41626563519327,8.63007868509562],[1.07553844417137,-3.72405501405686,10.0925014545204],[2.67574142579775,11.0366334851233,-2.19609047707856],[1.39882887912264,-5.35717906945478,11.1262025353203],[-5.01986056542791,8.28714710799627,8.46173489546232],[-5.25823243116546,-2.85963603020955,-4.00031043457971],[-5.04876121152316,-6.47439296104436,-2.64778615230044],[0.927128799934875,-8.88292546662415,2.36916385821045],[10.1494862016243,3.41714428391067,-2.48733001698808],[3.32665065729082,3.85148473598253,7.62841952052337],[-3.93168540665227,1.76730603255885,-6.38363868010455],[2.04009554156926,-8.9836080945541,1.88634190245916],[-6.69569896619863,-5.65550280581203,0.930566180224665],[-2.06678191187823,5.1108123524648,-0.304559573042678],[2.07145716206867,6.01075207476728,6.56873187416346],[2.89428614859189,11.1555339312991,-1.77378918201384],[-6.98492137454455,-6.06342960062243,6.95746165033698],[-6.30368678683208,-4.11265349682086,-3.12810838285302],[2.1136703461383,-9.62199744888082,-0.402754593519862],[-5.98784467501874,-4.89535327293293,7.55575985443197],[-2.69165388685304,5.14686182881793,-2.45809193665585],[-5.01659785032101,-0.326656955925162,-1.18863459351856],[4.20050295127827,-6.27102227711149,-2.08344851402502],[-1.09033984034477,-1.31856865773796,-2.43566486500043],[-2.73768800624481,5.61483995138706,-2.99665691397031],[1.76152909968905,6.4076217891158,7.27944050732375],[3.84287000852736,6.29764778902658,7.65038654113823],[-4.1293621968483,0.581007605861119,4.69550614063468],[2.84431438709897,5.85473133230621,6.42217299644132],[2.01177441109404,6.81392608825493,7.39550932236447],[-0.467001335813812,-4.62950346341009,-0.643449928180244],[2.92109466388988,10.3943190104445,-2.61729772955558],[-3.63053337355976,6.53679367823807,-1.37501454087457],[4.26808859652234,-5.14247627586597,-1.50662332931018],[4.82162826287381,-0.0932689373713127,-3.22780265698909],[2.8862034183902,6.66314530988919,7.41642464986152],[-5.36287304650532,7.2432140848174,9.38483322092607],[2.85972376646263,4.75186627054573,8.9069120787471],[8.47743864631692,-4.12061925201094,-1.62102134717912],[0.759115385242359,-4.62228361129554,4.23279598136863],[-0.607452201770839,-6.21646172314379,1.99246081892969],[1.44776183068103,-6.73912504121782,-0.196969841692032],[-4.95368553329898,6.93844091980506,8.3951621489484],[0.159911167935058,-6.25349442133275,3.34141734603319],[-4.44620418209396,7.83330836124783,9.02894568863939],[9.87887661803702,-0.00120441642557545,-0.570470043588198],[-2.15257918904275,5.6737079554885,-2.53146610871329],[0.877091665515782,-6.25816131910433,4.18597079197578],[-5.08903697385215,2.18646042257483,5.09767764951629],[4.51757224211534,-6.87650956207599,-1.57605957766055],[-1.8182069195523,5.64276889709859,0.583329739979089],[-4.21724908153596,-0.837103156739909,3.1141923910788],[-2.40168093393296,0.676902843089513,-4.37861534702856],[-0.0729789305596701,-2.87695222911078,11.2438679556829],[-4.32105083850682,5.18527535575448,-4.40006218350752],[-4.04825833685876,8.06340173226258,-6.54576190919571],[2.79500314293037,-3.51129105452263,-10.9216988920915],[-6.50057093384873,7.3467905212588,7.98578904168114],[3.29088681441118,-3.8771309494177,11.5890611325889],[-2.49460680803028,6.91926847243891,-1.10033861886612],[-4.76674978334263,1.21230745839914,4.74028903701321],[6.70879905443984,4.81086913666758,0.887700063018273],[-3.96219990235173,0.458261876186338,2.85320337956049],[-4.96556144026075,-0.0771815250103853,-1.34581844799401],[-4.16723912365353,0.958792756872181,4.66662167783288],[-5.51683347613604,1.42992812621821,4.89524584201765],[3.63920632293496,3.96710857122143,1.57413236192822],[0.997091844074959,-4.57901293859425,3.96187048703602],[-0.232513495326628,-6.29581015629308,-1.30212526491975],[0.453788392525454,-3.64754805588733,12.3684798840253],[-4.18130271182816,5.08664153782672,-4.60683639954751],[-2.72630689129069,-2.50557254466698,-4.78582925426926],[0.877976700705448,0.620858503675995,2.8963678270848],[-2.78378826614693,-0.854249826153071,3.39766539638949],[-5.94201409216806,-4.24886907054715,-3.10605597807559],[-1.65577068790003,-7.3693494269341,1.4909957428362],[-2.02093896168403,6.88130475518719,-0.599930068422923],[1.20641833889541,12.2337791985,-1.58402533624547],[-1.47835262640708,5.31531550971313,0.102374679122999],[3.47052908767662,11.7626477371433,-2.87991794868844],[-8.40377032883188,0.665194756182475,-6.02063604079151],[0.264328533654098,-3.0458591083913,11.4804664203205],[1.35025884702619,3.72569419943201,-6.03862493101393],[-1.24101612691921,4.41913993846591,-1.15496621299258],[2.54475656486329,-2.88819429645998,10.9006257457853],[-3.52269140253562,-3.30947907737461,-7.65848641325804],[-1.87421009989977,-3.19246527615144,-9.52773065530911],[4.17496860713055,0.976837165050165,-9.35081133741568],[-5.60619524648693,7.4296436362977,9.08187143203028],[-2.73100655324346,6.69574924472462,-1.38686964064631],[3.80059362827722,-9.06331301518133,-0.905422348148977],[11.1555501623421,1.59679262289691,-1.95667826812843],[3.00404185614163,-7.97389154728714,0.976221972085391],[-8.99669992206245,-1.83871737358457,-3.23169256513545],[-6.35820415681464,2.67829884776779,-6.47425782183285],[-7.64994874673725,-5.61122147671708,-0.0318662438214146],[-0.400759769983713,-2.90294516341585,9.99375672279711],[1.26101985928186,11.2787021039073,-1.56592616378585],[-2.35465479518454,-0.815935701951083,1.41525892537069],[5.38314991649448,1.2524935877831,6.05102598152948],[2.55216320076473,-9.23718287602651,-1.01038191084249],[-1.33979945627667,-1.75967710931935,-2.94349630257495],[3.66718886695458,11.692055336849,-1.63548436229443],[-0.150616786154124,-1.88882031734501,-11.6289692665584],[-0.259418680667084,-2.51596584615428,12.4283534473182],[-4.45545940739385,-6.97388132587339,-2.73513578915758],[2.81706865937166,4.09677898881482,7.82633168871623],[3.82794990691239,6.41272828639981,6.89584036693334],[-5.1364630676546,-6.45388630509545,-2.75496357754992],[4.21641824391777,-6.14258062797433,-2.06079872912138],[2.50842714027283,-3.05383500891496,-7.49746210099789],[2.06869535953096,-5.32699864265047,2.22267213994123],[-2.1820427454705,5.79983241942189,-2.69858055716402],[-5.72251993399101,1.34420919752322,3.78825081422928],[0.896727648895757,-5.55738978049505,11.1685580715284],[8.63169756413588,7.0794431974211,1.20527653119975],[-2.59313770257815,-1.28874734960863,-5.84389465799384],[0.429366614093487,-3.37621749459159,10.7866781635732],[-6.15162530314158,-3.48592485882951,-1.69726852772856],[1.87063010456261,-7.98269122692581,0.128476993749204],[-3.62249743614319,1.19843739713681,-6.12991929710585],[-4.51409402588509,1.67367794110463,-4.57689851221721],[-1.57742058209008,0.789496308023701,3.6128784121033],[2.48167117046536,-10.3510489858538,-1.09376259639173],[-6.93346290397464,-6.00044621018412,-0.511902779101313],[-6.14927962272313,-3.91336907986873,-4.16676517750466],[2.86411782447285,-3.58209694457134,-10.785373939771],[0.230152797147716,-7.00126945305133,1.81934709708564],[-3.46455733066803,12.7015360228365,4.20353637983124],[0.058769862400554,-2.79188975455054,11.1529246571135],[1.34511964861861,3.61721005544897,-3.98683200382502],[-4.13548773295193,5.49020876173202,-0.0220406076351974],[-5.0602877985445,1.83277426764659,4.21726417296933],[9.76982529994102,-4.21663148589978,-5.4229243672651],[-1.70306317016509,-3.96306734818869,-0.845742123513029],[5.20865815562579,1.40532986950775,5.60847018555476],[-7.15275403710471,-5.87456037111773,6.39213559170932],[-4.43554855200308,-0.558750134660645,4.1524409021531],[1.16625516149581,-6.9079914787458,-0.359024452692223],[-2.76122484716461,-0.979091728328181,3.57964863990863],[4.36265980578492,5.92623935216551,8.46740783002678],[1.38958968575737,6.44170175308724,9.25157297931651],[9.38102191624319,-4.44187726107637,-6.00031897165036],[3.12465990955761,5.84798610877221,7.55407995591237],[-4.63945519975055,1.27407355289268,5.2287028938336],[-4.921064117223,-6.61047425388589,-2.8396088007086],[-2.44646195267105,-1.31896804150988,-5.5202246002023],[3.94330102222832,10.589983793636,-1.47815979964787],[1.53576982038304,-5.24645787041124,4.14871838473494],[-3.52176590384568,0.894258038817546,3.02747971092484],[-4.12068843188798,-3.36928076273881,-11.207225416645],[2.89807459672589,-9.99125417024829,-0.408946164660914],[-3.10851740714097,4.37079762876855,-7.47722702989259],[2.27795262022746,-9.64319170798088,-0.295967905478256],[3.00018107675368,-1.85954964172665,-4.69088242760608],[0.787578864811193,-8.66693523255232,2.38606835697492],[2.32435154996247,6.35725739190377,7.39338347021629],[0.689872351471569,-2.7461866607799,0.415261603979235],[8.91396436196222,-2.14670283362203,-3.27239032388176],[1.45337661669636,-7.83780434671799,3.10075961710629],[2.55628172520517,0.270599087171951,-12.0696487406202],[7.1629773921147,5.09833762699374,-0.483609555989044],[2.20264518692386,4.37059691102662,7.52175436708442],[3.17121606636223,6.09414209167172,8.73630754613232],[1.28103243529724,-9.37930788596882,1.92414137103241],[0.361348164327747,-5.52156002150209,2.06993034451759],[0.559919628985749,-8.27259035540197,1.2041506873269],[-3.70376668361917,-5.57907985025423,-2.47649631958547],[-6.3305033940559,8.39203100410467,-4.03533920871547],[-3.62360521109095,7.39243955711588,8.81940518130655],[8.85479443148751,-3.6578016603917,-1.46683687310778],[1.68686103118962,1.76671410154385,-10.254064075052],[2.71613273079652,-9.70013868526384,-1.75650932547871],[2.87591288616347,4.35626004363821,8.25262075047684],[-7.11060923792532,9.21568998935416,-4.13014468610769],[-0.679012475676607,-3.25443806580831,-1.3940647312205],[-1.72356502020328,-4.45268781333553,2.02301413835731],[10.8597465502815,3.10708066653422,-1.85245709970685],[2.12706032294942,3.88030388063066,-6.40757906421778],[-1.89568949651131,-5.64485739854529,-2.23631214821837],[0.0969782743810291,-0.0391605589745185,-0.902081195304915],[1.46546519268545,0.818634294574996,3.11340036601239],[-3.0552362533025,4.36637145654312,-7.18049147699284],[-5.55547362285736,7.13369257088708,9.11779027271181],[9.53575274496779,4.73014438045665,-1.98537099910608],[1.23144067376994,-4.55281093894314,-4.96048087543911],[3.66504966651315,10.3383287973642,-0.964729025393496],[1.70047381183634,-9.14530058272469,2.58259609500967],[2.52821146330005,5.94304921707569,9.41705133674494],[0.151951965530232,0.461277258093305,-2.64130064012557],[3.10705215109514,-5.7460611292855,-5.16576768070586],[-3.36144198136253,6.68674141775388,0.601521399337302],[1.4285714322191,-6.30014860595297,3.95189680192603],[7.37561340840072,4.64661050207473,-0.912930356558891],[1.97204921880636,5.85615849880011,-11.2119105111139],[-2.73125390639426,-2.59775530274385,-0.707321756178559],[-3.62458631031318,7.95252851842261,-6.29970787731722],[2.25479137691824,6.1618743799444,-11.6722295280973],[-7.89062748507515,-0.493802315877909,-4.63148634229169],[1.62864344544869,2.96240377429951,0.174129540340147],[-2.71335498412951,7.20327850230958,-0.824495225246411],[2.27594635556482,-10.0992386172121,-1.03382871785918],[7.27906582274317,-1.74679626493821,-10.4879532634067],[-0.858665792346466,6.06433144517087,-8.4470901489916],[4.41617581104274,5.43318563737065,8.98998287055924],[2.29483574536661,11.1426219397925,-2.14502780715409],[1.77002227700746,-1.13815155787115,-6.13395568257277],[-3.99673380672914,-1.07452953136936,2.87968827354296],[-4.64474354922586,5.27233182341333,-4.11321125580108],[0.687250214754995,-2.79902224647883,-12.2653457054434],[7.6694191938007,5.27255343358343,2.59465368215328],[-2.64348290033893,0.730000569638419,-1.35942076523471],[2.20455208982853,-5.12541848329307,-1.47013355866624],[1.57090958250674,-3.79349478455972,11.5899698156613],[-4.17605282044747,5.16201742031115,-0.160605019002928],[-4.66834984931845,-6.18897921919164,-10.0270964565963],[-3.52026438669476,1.15522162857737,-6.03269730298258],[-2.48250742464953,-3.47522789009032,6.64425614624352],[1.48057499708259,-3.58473633624938,-4.74366438113474],[-6.18416706793724,3.49568023096042,-4.64306977561894],[-0.565152257653995,6.00178114475301,8.51674499442079],[-2.87167340638495,4.8843338949172,-7.74714634189119],[1.15737574453161,-5.89960120110749,4.24399343363916],[3.20301075905899,-4.95723842614775,11.1688573835883],[-2.27815905997211,-4.27744645530609,-1.48186202707809],[-4.25418855981837,-4.08249778771814,-1.17012241409866],[1.6439494879775,-7.42507107949895,-10.4747511096742],[1.24131633600885,-6.99077812618946,-0.911762325867627],[-2.44424123116369,-0.290046090057051,2.79384582555574],[3.31208578302898,0.600825766580776,-8.89879624111015],[-2.50620015751711,6.89304658640123,-1.23351501961628],[0.65768883858587,-6.05990540272362,11.0246341962546],[2.54561808887172,12.1116127842666,-1.81274740847859],[-1.10781054174203,-8.15698072363035,-5.94919573070391],[2.78829749206155,6.11429580152566,-11.4184514985645],[-3.71252717139146,0.626916631980983,2.32054703179297],[-3.07738683967654,-4.44173334223837,-8.67152844572956],[1.36489021645066,12.1844739411485,-1.57201088621618],[-4.73219862212685,-5.79556632138774,-2.38870141470053],[-6.01308494618395,8.45657754880702,-4.34678643932178],[-5.88614013218816,7.92907028733685,8.67111880272318],[1.75357963485631,-8.23847136556386,3.02553652515314],[8.94654661354723,2.68438302645569,-2.41887645494809],[-4.17364466294338,5.09486708670656,-4.6593496521448],[2.78852664047858,5.56289008544521,-10.8711702052435],[0.197532716633752,-2.95350108957023,11.1319631948851],[3.13848710242498,-4.55261184825294,11.078727545269],[-2.41652838332598,0.536429808152348,4.47654061037412],[-6.0953692989806,6.54008101700504,8.71767694211322],[0.170510565600029,4.10031742606889,-3.86696340445561],[4.43550364094571,5.55876674563874,7.90607049991577],[9.56169051568143,-4.0449873725438,-5.50849656910597],[2.57251710379717,6.23378017640797,7.18726224411267],[0.787688061394834,3.52486160634169,-7.07055936183245],[2.36717947534669,4.29674682900763,7.33990080027025],[-3.5953290109237,5.63046487955568,-2.12872698431199],[1.06892089893932,-8.76277577410109,2.01583785678675],[-3.18420706607617,-1.20365901130235,-7.98413409684314],[-5.49436240009341,-2.76175075529637,-9.10595040101282],[0.839903936281486,-4.83945278449065,0.892727735697828],[5.65560159502172,2.72054657815056,2.3588571484023],[-4.81722767344006,-6.26511878972737,-9.52842833250211],[-7.86904447252705,-0.777084888739582,-5.33093480288372],[-5.88423669973818,6.64931205252023,8.59232269449193],[1.53805898991734,-5.26984773836592,10.6077444383685],[1.28697211084311,-7.18339958164861,2.69595930753205],[9.32108273028494,3.04484462584983,-2.24111044786243],[8.48998527357018,-4.37658397618503,-1.14240008598805],[-4.4311035484362,5.07718675897687,-4.52220975929341],[-1.22465237422406,-2.63959219897317,-11.7717441445501],[-4.25678322989807,1.21655626065305,4.11759598586142],[1.48440126802566,0.582703680237575,2.93510973704245],[-9.14725833850833,0.215417125568592,-5.65300739680874],[3.17449880485436,11.6043446655556,-2.07738383592217],[-4.2665090046197,-6.86127917259167,-1.98556196313289],[3.91843178413781,5.03872159333878,8.44053295097562],[-3.70641053685596,9.69246150123171,-6.82217365694969],[1.10855749943476,2.81430889070491,-3.67809135408562],[-2.37903681304309,4.70120318031124,-7.54266986930781],[11.7425337976355,1.14817218748415,-1.31357167427656],[4.52504421174539,5.71515318859921,2.9881168895601],[-3.39546537462073,7.02387166991572,-0.839068634045676],[2.17288890764787,6.13980430235248,-12.3360952887382],[-2.82780937818158,-1.98866181381914,-5.85988679397094],[2.2426058693851,-1.67201654640111,-6.69710151334118],[-6.40665332947443,-3.20674785149773,-1.46463269287263],[-5.54718568525165,9.78132329654297,-7.31318557461564],[1.78841316954966,4.33389774901623,8.05021436554379],[3.54711770795761,-5.05289494116025,-5.44393177812244],[-3.34392500283655,-0.0898671787197336,-1.66338536204716],[-5.15659757965181,1.21364922828991,3.84083427693247],[-2.8745473311968,6.83075447590351,-0.0341132910527562],[0.972046258953327,-3.62451544050431,11.2038856192152],[3.54707241083986,-0.0829463950883611,-10.1755481389733],[4.58581072653423,-0.0240961080328932,-3.42064689731269],[-5.61979048455449,-3.75877963095486,-1.92170926344287],[1.73785729353215,2.6706599212936,-2.4485246068321],[-1.40267592737372,-4.77096231576314,-2.23514636271785],[-2.57019542894552,0.286454299625501,3.89639206992637],[-3.61301557078178,0.0976491337598739,1.50207289420652],[-2.38710301177138,-0.0594325041141481,-0.0158980824540247],[9.02640588143601,2.7061972553569,-2.02849537782331],[-4.21130114295368,2.24247241616343,4.17701498556945],[11.0560464058557,1.67809417362664,-1.14889747992475],[2.14730948974053,-7.92626494815321,3.25395854656772],[0.200001437584812,-8.88122584482764,1.00713997202718],[-7.39997704265571,-5.58555664101743,7.07182877921101],[2.89235802846127,-1.24663172424913,-12.0640297369271],[4.53301568749279,1.98556896144685,-8.87671306795802],[3.42483875480012,-8.94101516434534,0.217512213381642],[3.00505676240744,-6.73003989221657,4.07429173986561],[2.85209592149045,-4.58189691559077,10.8814156804185],[2.21222300068188,-7.87648768809231,1.36230323417206],[9.22389082069719,-3.63035591501474,-1.18627240363652],[-5.55247755336571,-5.76968188140139,-2.55960294197969],[0.524393076577642,-8.32610819697297,0.438735914269421],[9.32686222705923,-4.17022380946046,-4.81911831917206],[1.52162528997796,1.1780599658578,-5.47414772672126],[1.633137688485,-5.921906328142,4.42600766568194],[3.84509011190254,-6.59719136033432,-1.57885196136328],[-9.26839915401329,1.07390362221544,-6.49713961794054],[-5.66998359042506,-3.62429546991514,-4.66425117826883],[0.132353539552977,-1.28113691494718,-11.0425484001196],[2.09995462088555,-7.83659199604493,-10.919959822998],[1.57572954088531,-9.03631793719426,-0.603366942339174],[1.40978142275006,-6.37294722207114,4.83598798361292],[2.70046176248034,5.29892320137792,7.24858659787051],[2.03918251157764,-9.88586238308137,-1.44912664122567],[2.35359075802768,11.7032227806748,-2.66990922500311],[2.04063792131756,0.451277868501617,3.11916693573884],[10.1642995275534,2.3753774054634,-0.949461776574353],[1.80247693198741,6.57126831566944,-11.8234930176688],[0.672809440055132,3.53307477743806,-3.65795559530427],[0.0545270295787006,-6.54299892300114,-6.04307764537963],[-2.57790965037749,-1.18652581118678,3.59092054332447],[2.68954932275789,5.98395090496587,-12.1214296343199],[-4.5293785579853,-6.52049298016915,-2.408823037518],[-1.07083936057478,-6.96169842868746,0.460779417412287],[0.0702774005933251,8.77538348172662,-7.66442822085948],[3.17061520185477,11.6712900007471,-0.800092191583716],[3.18697877440598,5.13244062437383,8.33475210617417],[-4.74156534668501,8.27258008824881,-5.07449127943728],[-5.09666086601659,7.36024703032701,9.06434978592683],[1.59073508854589,-5.13667673831864,10.8170075462305],[10.177066617201,-1.97367825115967,0.217969067213846],[-4.31173355309024,6.94409930071278,-4.97616239391135],[-2.71486702440699,5.59218837583719,-2.35252840853762],[-4.60312389768242,8.27659690892103,-7.50418167995789],[-4.06980825765287,-6.56351978496535,-3.03377879489683],[3.48388591285069,5.51965830036561,7.71612976970726],[-5.97427178397462,-3.03415572972488,-5.13038125741329],[2.91521199478954,12.0353634056544,-2.34836245770889],[-8.90657323972038,-1.15681427466914,-5.24592403733491],[8.91889116035298,-3.9577508466459,-2.02690087166503],[-3.18065137922896,7.37887316529281,-0.16976725238589],[-2.38168184422187,-0.34068110309764,-1.55733845215105],[-6.53832764714724,-6.05800420486896,-0.836625142751702],[-3.33325981443877,11.9782306162598,3.2765961469706],[-5.21422537729143,-6.76613877749141,-9.80237460115661],[1.34809657998029,-0.849089498286542,-6.12551354072277],[1.60561381118268,-5.84634959204969,11.1237745846655],[1.38061489536782,4.04296550332186,-3.97001859916584],[-3.98508910658311,-0.217294295294987,3.2669303777518],[-4.8430376309756,2.15685850487596,4.92459123906822],[-0.0531461650676386,-3.19654008791935,11.7919049193223],[1.54447362760296,-9.19895663476682,1.7647174391024],[-4.48868249363241,2.22066552411378,4.96804628329041],[-1.84926935842226,0.3883809742431,4.01271237403151],[9.3756999307119,-4.01973878240685,-5.80255957776468],[-4.86420800819377,0.771097206839414,3.05739890611307],[0.397632686350855,0.0677445770582032,-1.9466697528681],[2.19816727571511,5.81698380151689,-11.7290334000924],[1.06547834860627,-4.86352100141684,10.1473128246242],[2.82218883718241,-4.3190048555457,10.6753314979995],[2.37294469011479,6.34084809790703,-11.5238412371142],[1.40639676156207,-5.22893289664326,2.84582907246562],[1.44136209539185,-5.40503580941578,4.70716049891189],[7.20597444355127,5.42163254205667,1.23061806828019],[1.65967630170997,4.9120449019192,8.94926438352712],[-4.77310574519782,7.29364484987471,8.65329390394414],[-3.61609157948293,4.45861366682284,0.390726477918021],[-4.15441170883634,5.23349153969145,-0.763178757721728],[3.88991746663861,-5.61301508367469,-1.53628129690819],[-0.245297422814633,-1.50763201975101,-13.6363461520906],[8.71339081346497,3.84760421166623,-2.91454443892482],[-6.10053877703259,-3.04357100531956,-4.96615715027972],[3.42361034964149,6.64348805099224,7.486061223557],[1.65999399577992,11.1475775905312,-2.69898822387521],[-4.48873813068372,0.797321541105354,3.89270741419751],[3.39331902405082,0.0173919759101284,-11.0931094843358],[0.485998045728842,3.66870841721562,-3.75158266598122],[-4.07272728083902,-0.618422265305808,3.36599821769831],[1.03268909706527,-6.57539563033509,4.5951169287798],[-4.53693980999743,-6.65775459158444,-9.85052112357645],[1.26282247886461,0.0987690817434228,3.40352624997843],[1.10641063589627,3.60786226901544,-7.64681333658202],[1.88348843387517,6.23785932377508,8.92108733560125],[-8.32323007191602,-6.01064367957423,0.490446205683057],[3.79750745794771,-6.34748446709266,-1.74369335306393],[-7.4755189120709,-6.0613475937897,-0.211939784773846],[-4.1993160471036,-7.17781771204322,-2.44068234531027],[2.21858991106888,11.6212109607022,-2.39702404668859],[-3.98184821869588,1.2306735950035,3.10350629366844],[-6.63507159568179,2.83728960856933,-5.98904073163331],[2.1629029750935,5.89486304105397,9.46379163800437],[0.910220527365618,-8.40876264971382,1.91549119895956],[-5.29141661373635,7.33740758905253,8.71536164974001],[-1.86998361513534,4.7342111819886,-2.37546535867363],[4.86231170516493,-3.02736604137215,-3.90884915721562],[-3.53176050432448,-3.19564857714504,-7.47872864239747],[2.49404956513575,-9.08067545053949,0.137224829126467],[4.71757155023617,-0.210776621554176,-2.90993431787554],[9.31478272848904,7.08353677464218,-0.0349467246358741],[-7.09416368893617,-5.51527464315533,7.22059647458191],[-3.53729676348003,-2.86636121319709,-1.76607950662319],[9.9547284725569,0.820735334106847,-1.41064983888926],[-4.67158139695956,0.0874310903349577,3.55595966296099],[-4.51877941543367,-6.19685718110125,7.71073302016838],[0.308757936575925,0.4239632545534,3.3012546622737],[-4.18737114375676,1.33430628903043,2.21032906960305],[0.946257178987391,0.300416438361494,2.90284321305831],[3.23952431803288,-6.58499342945829,-1.6945660309701],[2.73751632996683,4.16593759268066,7.83344393672925],[1.22985263896706,-9.10222851715628,2.6172945408451],[0.782520778900222,-3.77028541237489,13.215092449449],[1.91342649985162,6.17883294624963,7.64598742129475],[-2.19993935930725,-0.050462711607148,-4.69227675110964],[-2.64383141803777,-1.21986197010487,3.46762143962687],[10.1197644412744,-1.96859434658576,0.146439799636726],[-4.65089193355798,1.44462281056208,2.80270040052852],[4.01101513668375,-6.65050139478313,-1.82876760941303],[9.68555610062003,3.96987371988397,-0.907869335616588],[11.5915370440603,1.75616883150765,-1.85316780929022],[0.0546924770486661,-3.49315264028944,11.9277267123903],[2.1996402217975,-3.8796335475375,10.0276029429851],[0.336668799759011,9.44689462397642,-7.36854086652798],[-5.8440085167503,-2.92047543141526,-5.4163527476353],[-3.88865998936084,5.69874396406764,-1.97004134416548],[3.04773561666444,-3.55411357455619,9.5700416346605],[1.23834939323184,-5.83243611409776,1.8993061644919],[-2.68534842290324,0.429618979170862,4.96015607664247],[-3.86872407975563,7.60775839293948,8.95241114722976],[1.78451247720408,-5.52917622238175,-6.25016651468766],[3.18667952107815,-4.09239460848605,11.3328078302403],[-4.42744636101599,5.90486967787271,0.174952862471971],[3.40341096149508,10.5097673897646,-2.92193983879947],[6.84895033940776,4.11232059433632,-0.209889539960162],[1.85267555959841,-7.60458309247443,-0.721530284601286],[0.420381033503308,-0.423876917984409,-13.1941620114755],[-2.27636812005957,4.58829953287402,-7.59769324129077],[1.5789572291635,3.71429014086937,-5.45304684126763],[-6.48160995496454,-4.29819515200789,-3.29669106026462],[0.574346150872443,-7.81746307617279,0.763189829631567],[-3.93543641021813,8.76451579899429,-7.07130096340296],[-4.37196632236348,-6.70320452361793,-9.82134164161403],[3.05025921273826,6.64704079024654,7.17706095630491],[0.26662329854987,-6.11210704935483,3.8233276860159],[4.35152273662922,5.21140332549636,8.66576990180043],[-1.6385892185862,-4.32778177254264,1.86295115106487],[-5.98943211387905,-4.96349891649932,-3.73265419929225],[-3.5063130873019,1.0030055095083,4.24341751145934],[-4.59043090415177,-5.09674107686621,5.55164484719899],[3.35051581309627,10.9032777697103,-2.02788791426486],[9.6122889449292,-4.39549734368942,-5.99610550169581],[1.26345843707931,-4.08324286841842,-2.44335170246101],[1.20261451212358,-4.36096653318827,2.67932026996117],[-6.37662470677183,-3.98410332483,-3.42565611793972],[5.10904762490372,2.84179835840044,1.98263565744049],[1.4796474539396,-6.43735643034779,2.90643865869351],[2.64719328225829,11.1403209375093,-1.89353816939084],[-1.91518980480236,-3.15683367702679,-9.67049719945643],[9.8241817016406,3.9213444021314,-1.67604788880111],[-9.58417437769983,0.522783735490058,-5.89388613638343],[8.14855532629195,4.42850236767273,-0.341018773776184],[3.03407440082464,-5.20624278561501,-5.80837315770612],[-5.23593315345134,-0.18915711829974,0.347540494984092],[7.25381859821247,3.88128822188933,-0.0554147668635341],[-2.36119157460094,4.10063649496743,0.134358622986421],[-3.83932323120414,1.87149565903263,2.56539177757757],[3.03506159519979,-9.90955193172067,0.615355265360789],[1.80646271589067,-9.09741888317371,0.641517647446704],[1.73213632817589,-0.358920300220712,-9.80623819758445],[8.21863282218799,6.40308576834381,0.917997182822107],[9.17697275028774,-4.06664328728764,-1.76222956914015],[-1.93226023885797,-0.250844521013037,-4.91842591905497],[2.40468422196195,-2.84789791293678,10.453379324531],[-5.34375406868742,6.96882713534132,8.4339554084004],[-1.81185997633015,-0.0223148718297163,3.74078589455081],[-9.11470166415739,-1.70977619335934,-3.33888703206661],[0.936540572631801,-6.15642911373261,0.58481160482839],[-5.61197958128852,-6.352414938162,-1.77128886933512],[3.39743131465961,0.942259253560181,-8.86578958789371],[3.08198326474052,-3.71119820030493,10.1179179062733],[0.779711967789278,7.36684436046974,-6.24261443307604],[-4.47011103877345,5.19602825103452,-4.30635407959978],[3.37099240487703,-2.76914030842997,-3.66677470909706],[1.57972311387849,-3.73193506339648,12.2617303829997],[-4.3465207735593,-0.952269682987821,1.77481120356648],[-4.07103986167919,1.03207134082369,5.63597444868159],[0.052236538307566,-8.90770188112582,0.894412495698893],[1.39436194615682,-9.42863146251647,1.79817411109963],[-1.18398016823104,1.27545320545745,-2.67868817203628],[2.41457248124329,-2.90170276816684,10.852196140695],[-0.162332489590149,-2.73831209615463,11.7030153226136],[9.51460803800558,-4.74726986964473,-6.03534234452094],[1.33796972687519,1.75654625123949,-5.42102095426295],[2.27605127750755,-2.60630638577182,10.3118242108058],[1.16386965147106,-6.89508483208951,3.0064147324007],[-2.67603612705955,4.73617329679171,-7.79662812452207],[-5.97191860019224,2.97773508926656,-6.14392285095419],[1.30193515833224,12.2058909965085,-1.78841121956798],[-5.29340369895036,7.74257734356568,8.93706590462058],[2.54280008913668,5.47326190713963,7.55325601674981],[-1.66985023261586,-2.19418286815014,-3.95877044494481],[-8.43422174617071,0.0211422716848291,-5.18512035284302],[4.05944721430353,2.21453311284491,-10.4515981790331],[2.6538181281802,6.45688993497154,8.3984495536305],[0.155810063443901,-8.52074827536285,1.01142126845533],[-3.62192095406943,1.2205054826693,3.38121446189597],[1.91253458231521,6.83716560728054,8.94090335492477],[2.93987787905393,11.79449969606,-1.98488208198338],[-3.27992276051643,-3.8303951760944,-2.93103234077727],[-5.70730414379922,8.14352397553115,7.90691959971668],[2.68336062104098,6.65264627095498,7.78082352230057],[2.35098334593237,6.4155981486191,-12.3765891290786],[2.55833937535989,-10.1243357807205,0.640139176851363],[4.16227839459324,-7.2322931303461,-1.37934932254949],[3.1840173438111,-7.59841524082595,-1.58117882674637],[-3.97018547716178,-5.2359453873516,7.87156760887737],[-6.27192341159054,-5.9748811916259,-0.628663491232964],[2.07994420351003,6.37900138844011,7.10838365624353],[0.271675019331788,9.38425461446139,-7.71131475757249],[-1.63421527988082,-1.91239895611237,-4.23739530395683],[2.34652181569809,-8.0014591900654,1.4816952184079],[1.93938791890545,-3.01799256874286,-8.03243387139827],[2.85675137983118,10.8525704536026,-2.16967338763728],[0.149284500726828,4.20508845952874,-3.756782910415],[3.24707182514867,5.38645761794388,7.9763238750163],[0.924760679462723,2.85080498276427,-6.91405782749349],[3.57475526739848,-0.1142516213164,-3.46567834019275],[-5.34492419302379,-0.568453690860799,-1.32798697084145],[-1.98655981727083,6.31745569595638,-1.69711335570425],[2.6964910841879,-4.47852861021487,-4.95410419167804],[-4.35609925495315,-5.53150983505694,-9.68556008281755],[10.4570018218391,1.40228498582725,-1.55944633387309],[-3.53104034496709,1.1779258897634,2.9600542604479],[0.792613878960585,-5.5145171627864,2.6340886075816],[-1.41018255632996,-7.12534583665627,-0.607510198875032],[0.120652615228342,-0.0438177179366945,-2.08233983234809],[-4.58551157202617,1.22026441398022,3.28446064968169],[-6.29061730551263,-6.30649027983524,-0.884402258152621],[3.44602920645351,6.07335593334053,7.24626354239745],[-1.69773341790672,5.44554286130122,-2.57519515637434],[-4.32737051509133,-0.275930496679596,-0.834310267416325],[1.72075924961734,-9.79715355997293,-0.12690019575579],[-4.7247329581894,7.82098252323987,8.46911549355844],[-3.57303372865316,6.59446747474012,0.00454371238323514],[-5.30563690199929,-3.80991317825717,-1.79113567567183],[-5.25833801803315,-1.38985965126286,-1.41555292413725],[-1.0267084712461,1.83829418578911,1.7493675618578],[3.0178779443994,-7.94725788905723,-1.93070560366335],[-4.29461139368077,0.760675520555646,5.79931719410964],[2.3362756502799,5.86880598687963,6.89076739320338],[-1.02371155349606,9.5896172157634,2.59651507537042],[1.52102084592,3.20075148138117,-3.60064687275761],[-2.48698182887448,-1.08128551422083,-2.19934807822125],[2.93439581023727,6.36917688870742,6.98524529089484],[1.21782843330113,6.10026200405504,9.26037333313307],[3.97937103396004,5.95524600212229,0.153638203028795],[-3.54713244296413,1.14316392145051,2.26264073010876],[1.08520132487643,-7.63490324267595,3.83999847218004],[1.01443679013701,-2.80114689621046,11.386417412871],[5.17553833920519,-2.70865119395076,-4.15135685949777],[-0.474834974421826,1.92420497355386,-4.8683675398424],[0.514868701055904,-3.86759003023819,-1.38131706507102],[-2.46237151469844,0.453266247966528,-1.4614491024343],[1.26179756049385,-2.63606702400715,12.6793012975578],[-0.447887436902147,6.19177633159713,8.92053799436149],[1.2843435955668,-7.86995970723192,1.31070596240954],[1.16107119938236,-9.88935075469043,2.15649330116189],[-2.05071966402749,3.85577237261191,-2.36570382294558],[-1.857480876565,-2.24829507675293,-12.1346100159589],[-3.7447869712977,6.79703749951057,-1.12686525792265],[2.0424718093916,0.429377767688331,3.99279118036445],[-2.18157793234401,-4.04158946626079,2.03678271645748],[0.411061624495361,-2.83353712192654,13.1269796089417],[-8.43710676781853,-6.5663862172137,1.14738647217308],[0.324542330701398,-9.11635273484947,0.831663087362676],[-0.884240147328572,6.39714320133522,8.79250464456372],[1.3795844946764,0.22306968919477,3.51214694160358],[-1.62416571720341,3.9359648344041,-2.80245585817581],[-1.36492654952324,0.280834425682067,3.96381605930412],[-5.09418834010817,-6.8775007946189,-10.3773656580229],[1.80855374582939,-4.8142244284149,0.199213112199375],[3.66910491986264,10.4950268669411,-3.29646371248253],[-2.36921620681299,-3.56002092851949,-9.84558005145296],[-3.2445038980846,0.589876059158699,3.23829144248447],[-4.53359183301122,-6.58516776977292,-2.5523767022903],[9.59726860184906,3.4901254739013,-0.70393705037004],[-3.27661820126254,-5.82730653207043,6.6745912949035],[1.17879318488292,-2.49472659508998,11.9891709551277],[0.973230139469758,2.83681863633633,-6.85162323451359],[-2.53115546569587,-3.51117014416179,-2.11460028473648],[-4.90107438740105,6.851390511654,8.87760269180637],[1.84384741456578,-4.25037902531719,11.971419517328],[11.2412506924398,-1.99763931264711,-1.26597971730751],[11.1143778178831,3.93619299092972,-1.45322442713277],[-4.31063977721276,5.1912425391306,-4.45330913553077],[4.31266129561967,4.89937029708156,8.94897997231056],[5.36231926764368,1.17585909779837,5.69299351323349],[-1.2821308771344,-7.01044787656324,-0.404114390176972],[3.4508085342558,-9.68253749632562,-0.78943682322799],[3.77847231165247,-8.20311733721494,-0.927842867728061],[-2.99333259572549,-3.24813060520605,-7.33851848637857],[1.25573927859404,5.52804665252347,8.81020347174328],[2.44477972998529,-7.80866177361243,-0.681367424849868],[-4.1577356641503,0.093245463971956,4.66621394354069],[1.7437026627489,1.2577602610905,-6.15897964482409],[-4.38666537444227,6.07241491621492,-0.884988539875234],[-3.49953399712002,-3.8630579275768,-3.21261717542059],[-1.68367679256964,4.67945443110817,-1.94589796030803],[3.00439072259629,5.64734974792765,9.39629755716589],[3.59998486428838,10.6909303403367,-1.23046087150945],[-5.10006431873664,-2.8489314183314,-4.06031832099615],[1.87659301497737,3.83024175927547,7.76655314148394],[1.21362104776448,1.5308809826126,-9.19949288807779],[1.30098027116475,-4.92897592850611,-2.22028995663329],[-3.25584878604806,0.974028705217005,2.02722751251189],[2.03531205942578,-5.11511980904886,4.95790462378987],[-2.73747962371289,9.7676499575822,-6.13923530651705],[-4.39682746280249,-5.26334779146451,-9.49132917738658],[-1.88119910321533,-4.42283724155094,2.05168461570027],[-5.81019074799814,-5.89243011767152,-1.07964435288206],[1.46790293505825,-8.46872436697471,3.09442536826708],[-3.3225837500437,6.03555831037555,-1.44919306836164],[3.332190230063,6.04991723572003,8.14566384005138],[-8.09328085213808,-7.04114510460812,1.72286245134858],[-4.27781581082435,-3.40570764642906,-11.4275345820338],[-2.57536559126933,-3.52075756016101,-9.35529065100501],[7.31190149510395,-1.48203971887027,-10.5083600160243],[2.76587222327313,6.61919135255888,7.67101958484972],[2.60878640230474,3.36127854360718,0.987681250503849],[-0.540415334943727,2.9716360272786,-8.48570450669883],[-3.32727539697814,6.4528251348918,7.97142357547402],[-5.14310176067487,-6.19625085660461,-9.94245223634988],[8.6546055352913,-3.18323408048973,-4.81484905753665],[3.07894246222654,-3.50566492779889,9.91836787991034],[-4.02496077883246,2.36366558474146,-5.07231835898386],[4.27937962950076,10.3265423988667,-0.871172268901627],[-6.88460236328902,8.39867612136789,-4.19019217576355],[2.31165018494246,3.39157354888142,7.75200503543496],[-7.07501613782149,-5.99324190913203,-0.494662529286857],[-0.6823639892841,0.587646902734308,-7.02199203998747],[-4.48333249161074,-6.18255312817839,-9.49779796354276],[-4.49719246090508,-2.82471523788822,-3.04061408904773],[-3.14388224394146,-3.33508459599009,-1.75285883598923],[2.98028212942877,5.2881855829704,6.55216885835136],[4.23187939593511,11.3637420401496,-1.85299836648191],[-6.15583839698638,-4.27792815417095,-4.36183473163122],[-4.56662262620501,-2.98221616856307,-3.13726741527712],[-2.81094981104046,4.38651901032216,-7.26818508675573],[-3.85733103618682,1.74062331239005,3.6036755740893],[-5.48897196715355,6.25476683503292,8.80995042034058],[2.89717856362359,10.380369928483,-2.05537546056693],[0.73592182651209,-3.61684001432923,11.8039823017221],[-2.28875265993486,7.12067473305889,-0.632294809524111],[-6.08860332268099,9.05344287837865,-4.6862812335557],[0.72627027033556,-7.29176342281043,-0.0590335275653345],[1.00355201319711,-2.75486408433091,12.9998664629857],[1.57477585197625,-4.26755618185354,-1.32853390262905],[1.64299359317139,-2.70637191284723,12.7248599143682],[-2.42625266585402,-3.28084984232962,0.217745726206811],[-0.0573249854961431,6.23855824729576,9.2071487946966],[-4.24055122802211,1.66584871694734,4.08435212918061],[-4.55444590684631,6.54824971090529,7.95902372691087],[1.61498342758369,-8.68034138126001,2.75499357146706],[3.34545849005042,5.90971829882248,7.75825417709497],[0.814151040129701,6.47388922760449,9.08632688896937],[1.33544692730418,-5.28618896360253,-6.12336050347509],[2.97281490431674,5.59652574153929,8.96840301307999],[2.82581954218109,6.39201181403133,-11.8573137953439],[1.69219654213988,-6.16889665161482,1.52688061597536],[3.12232611545083,10.8490799925168,-1.00814896520065],[10.1530365891012,0.273244248526616,-0.467909876672886],[-0.407618129410374,2.41265238748038,-5.43641523165534],[-4.9311350809858,-6.1656316234117,7.81801834871545],[8.62022447734418,6.98835651084766,1.16212631890867],[2.65579277201446,-5.5218492681102,4.25967899490505],[-1.29112284613015,0.313666830347218,3.33621352285405],[4.33475763143517,4.46458612094305,8.52270423278868],[-3.82760227422534,-4.73356028249014,-11.318433403185],[3.29379882699522,5.1481525718722,8.36429630696246],[-5.57166609865056,-5.75853671559237,-1.59127031452768],[-4.78411023700305,6.8395117512243,8.97297128478816],[2.38208563153746,-0.230578351017423,-9.91701139279122],[-5.63192435705186,3.84486407799872,-5.8143709736799],[0.876599188031513,-4.80730542101854,10.8960442447001],[2.19072117339399,-7.1613681530492,2.58500722008777],[-3.82786513158969,-2.82542432770485,-1.52298286279699],[0.82788284529361,-3.42280778146175,12.6527665933175],[-6.45180508002072,-4.36436023529333,-3.51493525930692],[-1.48249223351645,1.6882996900075,-2.2555794606532],[4.9901603801183,1.55924654172014,6.05540315259754],[-9.19004994941243,0.0870471958972734,-6.15751358539029],[-0.387626683134601,0.570202994898569,-1.85427088560163],[2.12389504041491,0.143657941410091,3.66793043110821],[-3.61285355766512,5.34597208245763,0.0187014598322214],[-1.25896834701677,0.419194444622499,3.13805380613478],[1.35880367735947,-6.80671933933054,0.380998305005637],[11.2576712638613,4.03295119368533,-2.06005426013774],[-3.63976196415207,-3.44067157807778,-7.83566834647099],[4.71352462697808,-1.00863222165542,-2.5308668584032],[-4.03336017392004,2.00700670561504,3.90395734010206],[8.57380950039026,6.94298671530591,1.27790803482746],[-3.76491786373596,0.572740050605297,5.00780193196721],[4.18491167706518,1.89577802938923,-9.58374683228835],[3.72964804085696,6.1650978199768,9.2629561118459],[1.20589555993447,-4.31659412236583,-2.40560328624855],[-2.16243202713948,5.3303331183003,-2.54017543804161],[3.36835247819148,-7.44061417750549,-1.69788600931034],[4.54516571743606,5.43869668529457,8.33054426854732],[0.86855745991687,-6.09079524749771,4.98278680795283],[-2.48117005059846,0.625143777106407,3.43855847255467],[-5.56307148966471,2.78134626644714,-6.72068448731635],[-4.08035357291411,-6.84891360105896,-2.75046483174312],[1.69832993262567,4.67932878661107,8.16322315006104],[0.887665735074485,3.05429929447681,-7.40860928435693],[0.359266876047763,-6.32200785492571,-5.69922291758661],[9.37792103373686,3.59582351311444,-0.966462035115855],[-1.04207413511686,3.57791604524216,-1.98569590615215],[-1.45080093925393,3.37083446001302,-2.35199379961969],[-6.31425503206265,-2.99416287812042,-4.95987123466167],[4.10370714460788,3.44531278731903,1.54156999660345],[-6.03053853515704,3.36681383070784,-6.20912646189452],[3.27583936450008,4.06900894252231,8.71716914462566],[4.28636119527425,-2.19352049111124,-6.73463128555087],[-8.2766993422701,-6.5630067074938,1.24167295042174],[-5.36212640671513,6.90096664432502,8.22897116260204],[-3.92319445952647,4.73915304410743,-0.424292644411982],[3.20377909042672,-7.52599789921437,-1.81649298751507],[0.939106965401521,1.65053684367429,-3.08643401440944],[2.43105236404639,-3.20148593975672,10.9186973060169],[-5.02127452737153,-6.01982317421181,-2.2788841258755],[2.60379171959193,6.71412908751374,7.96561763216138],[-4.61181706392293,-5.5850490776869,-2.00621502609551],[-8.92984518425194,-6.63372390376373,0.901676959007698],[2.16220305498456,-7.77537878666229,2.76995235549471],[-3.04830280858155,10.3763613608133,-6.396556268579],[1.44394897210398,-0.598694981588213,-9.71163942332053],[-6.28361554299509,-3.73571775962991,-4.12113797014391],[1.28414870134348,-0.74987529334713,-9.61261713611031],[-2.35684185682296,-0.679537973078523,1.26637761248738],[7.36677732462401,5.36885695198089,1.9303188821002],[0.0673339514650694,2.53680818316951,-5.58766027142491],[3.43871191779744,3.71406799018895,8.39102491291646],[6.96900586817958,4.54884318529045,-0.491057385896812],[-4.75035348944393,-5.7884158724246,-1.99162198319416],[2.24589230255019,-4.92471720290147,2.27023537265025],[-0.598567337593642,-0.0200484020648166,-7.85284396868958],[1.30693114948547,-2.98407929659059,-7.63843892882444],[2.98999542200766,-4.10573557882923,-1.765769750354],[1.16620603064953,6.09763026069959,8.87791165732617],[3.86024330551365,6.17023339350916,-0.0950433952403369],[4.23675276241271,1.54153813207865,-9.61780779037601],[0.0703506488259799,-4.56617810492635,10.8241616138569],[-2.90636051526563,9.76793838855196,-5.96965204626394],[-4.64541783320928,-0.703463253683771,3.51644112178229],[2.87262300430261,-3.70286227122945,-4.78879798424215],[3.3349284396045,6.56589589622236,6.92982082788613],[1.534499181699,0.274680817401635,3.58419316949699],[-2.17175339782093,-4.49769881610226,-2.05431306999867],[2.84273138922553,-3.48379610963051,-10.8773127016642],[1.47599650447244,3.15166682871424,-4.2224017986305],[-3.92213771860978,-5.66706775076116,-1.08131925297801],[-0.566515246339954,-7.51734845268974,-6.33580988115116],[4.70187282986637,2.23946217438468,4.02578085742759],[3.51728819767205,5.48964992423022,7.76038023547487],[-4.98953279367476,-0.953061483304723,0.918980421704824],[-0.0201173782275555,-2.71948067177725,-1.12484910659192],[3.79059507819883,5.60763319334311,7.28885514551137],[-4.45215149116713,8.10586263131505,9.19338296819382],[4.05546668184414,2.42963372583729,-10.238814940415],[1.86371627278253,4.50926407761405,7.53706140378393],[2.29630744316081,-5.4013507740656,3.04084253880613],[1.33336333647261,2.73833079669364,-4.39205663704609],[-5.18090322541729,7.91207862863528,7.56225010533028],[2.38586555650558,6.40498706508169,6.88028693507169],[-5.91605971271496,8.07188396326298,8.54333251241023],[8.54714987980497,3.03917100519432,-1.71914085172274],[2.20553091696828,-4.68283365281854,12.336524574704],[-4.73684557023022,6.47327287119479,8.56321570234769],[2.03053646490114,-4.09275469519613,12.3970755904098],[8.27693384889897,3.61252950282768,-2.45816581337598],[-4.69205775735793,1.28838483269637,2.2073406836647],[3.38509849662032,-3.54597029721917,-10.4442635756883],[10.6267036439227,3.35343606060686,-2.70451999105315],[-4.81839813977782,-0.866205351753649,4.50868776046346],[1.37590294613248,12.2319101246694,-1.65882545588172],[-1.98893954128053,-5.26925330033198,1.90894856524461],[3.48075099910923,-5.74569458238138,-5.11468667371398],[-0.192823954879237,-6.5464599748461,-0.754741593849819],[3.15682572237989,-0.0701984086844796,-12.2449753407198],[-0.618511755070464,-3.46762742455819,-1.24873284450424],[1.86339190035508,-7.0284751868785,0.688562145314301],[1.63652789716125,6.52363592696369,6.795581756858],[0.757142620157053,-2.65763340664395,11.610277556395],[3.51480595135563,6.17801525397055,7.72949409522515],[3.0151716767376,11.6087153484568,-1.43744191923079],[0.194602341260313,-6.68552475194151,-5.76109240857888],[-4.35547440984823,1.58621814937427,2.79484813450006],[3.16477132391783,6.30981714500941,8.92164330124123],[-4.61056808693044,7.55055869728248,9.39868632499412],[-6.56932742380054,-2.6612904684111,-4.89235987452449],[8.92256428261598,-4.17090917662059,-4.9130667692383],[2.08695220866447,2.40868064938896,0.907979955615801],[-5.12943078488217,0.908325168704232,4.21829250475677],[-2.60859489314975,-5.03211305110955,-8.18780808466894],[1.87898340412299,2.87399341143738,-2.70473757396288],[3.39541885544803,-8.85123517392991,0.0620022172874795],[-2.55322153610124,0.394969433900477,-1.18195171248986],[2.43618654280727,-9.90534474119948,0.071365757832653],[4.44991978714501,10.6076126259047,-0.905944905275523],[-4.55893816661749,0.064798736779173,-1.67990146644233],[0.124087718365396,-6.80652485299395,-5.90365827241975],[9.92169137037566,4.02555324107794,-2.55210631858009],[2.21391884324814,-10.0285717584432,-0.947466656375478],[-4.81454475512111,-5.72818546543519,-2.72502751863166],[2.32863887660448,-0.877387472776344,-7.64317545567739],[-3.44749513221726,4.34687315869805,-7.21350211691058],[-3.15539410984167,7.22000647507307,0.0550192363543933],[8.2434538301274,4.27856690363205,-1.49148180044156],[-5.59471015296939,-2.80322264063439,-4.09596944202048],[-6.94343290357213,2.59177060373796,-6.19422689162419],[2.79220508507861,-3.3344122310764,11.0505934497746],[0.823583846941102,-9.79433244665847,1.63214035481357],[-0.290402383285677,3.38380813885682,-8.81241831441258],[-0.85360964060654,2.18844975705652,-1.2946087091084],[-3.52539844352924,0.126523716204952,2.60711668682228],[2.35871412833674,3.6270732257108,8.18173011737544],[-1.52671600242362,8.03986553764286,-6.66676649546985],[-9.46994509498894,0.702003807525255,-6.41787196154918],[9.14274306629368,-4.21835859853916,-1.60279655116716],[-0.812672081951361,1.00506125787292,4.23879531522952],[-3.61024216838117,8.80436658863128,-6.57665409291383],[1.64580699037764,-4.4436143100472,-4.90685724674047],[0.790490175082338,-7.20284960751052,3.24371659705081],[1.3501149365563,0.710718089485274,2.93397241828436],[0.604652600237787,0.356072608146361,-2.65336476081489],[1.84611719419225,-3.96310156115677,10.4611636570127],[0.311258921492049,0.266704955109013,-2.77016160259904],[2.5350604277004,11.6878620752716,-2.85504645650926],[2.96373316677556,-10.0535223181538,0.221892772859375],[-1.81032423637194,-3.19165109198378,-9.86155137075745],[3.38594383889596,11.3935158227109,-1.78885381776073],[2.66591053531493,-2.25412938930557,-6.66071066662506],[-4.83263722972107,7.99473260484661,7.89269469965972],[3.71306784899371,-0.495863460070211,-3.2079988013427],[1.65866064404824,-3.50926257913552,13.0835183642182],[-2.97803817640238,4.78811647625234,0.286035245753854],[1.27800894107508,-1.77476265805785,-7.93402441689161],[-4.77537377038843,-5.74853733603948,-9.89902065734343],[1.51152644723494,3.00971209498672,-6.01120184166638],[-1.98099812737901,5.67637267208944,0.270771080443841],[0.750638827564024,-7.84800443597369,0.732775071487084],[0.422854103811867,1.11333558946423,-2.16415424245052],[-4.26438716077651,-5.96671373359792,7.95468615395727],[-1.49333398979599,0.170987493996014,-3.49887999188285],[-4.371015004434,9.94877645641477,-5.44279298601009],[-5.23200924822176,0.986497461981029,2.35205516173973],[4.17652659145504,-5.39165886327474,-1.30999501510834],[6.66776232911569,-1.13168727470482,-10.430162135653],[-0.211921352991803,8.98808026211313,-7.45645868147166],[-5.92281734406838,7.98588446744793,7.8623746172884],[4.54678904127889,2.51305157410913,-9.87455086991636],[4.04783063079076,-8.40722698125906,-0.747738910183202],[1.80630673893559,-6.17692223332665,3.63122026989095],[-4.74814302988486,1.56547895535676,3.9349187647193],[4.79050481716008,1.67297121604048,-9.62260084076879],[-1.257924160564,3.153606200966,-2.30025253810547],[2.7458980319431,-2.16800779998229,-6.67508944826004],[1.52895434030582,-1.39007390581189,-6.68269054346144],[2.18491197868713,5.86357576969313,7.03440503237835],[5.1010509036966,1.39978657458324,6.08230672058156],[2.03795949334101,-9.48620059298097,1.48175553544839],[2.39928313915164,6.30994338147494,9.19620560141635],[1.59713557761034,-2.96344222483174,-7.64842983915208],[4.19573680450192,5.60403312190049,8.26143379775607],[-0.11572704644974,-6.70202214267254,-1.26303502448459],[0.657144718844714,2.08910821366163,-6.48457269693251],[2.73735480745549,6.46427200762311,8.80024445236233],[1.84719710379894,7.06315976376896,8.29649888342527],[0.473497429645744,-5.46093256776465,4.00416426189559],[-6.43457054361656,2.79266065713791,-6.21151841300734],[-0.570727831209682,0.418417288165697,-2.93952032646497],[-1.13563728308425,-1.31690306680159,-2.90317820664796],[-3.10083379039336,4.09131854115432,-7.39677442637146],[-3.60982981619953,1.02114710785205,3.35748456537697],[0.501040538688125,1.47488791774092,-2.42461625794457],[-5.24299153279207,8.50882217504078,-6.97799753911785],[3.25460774316996,10.440909340823,-1.63787499229974],[-4.13634736262464,0.309454869866826,4.84570191658219],[-3.85087477260598,-5.38063932852287,-1.0150092586299],[-3.86837129379544,0.873009514508107,4.09811477299159],[0.0757443543328439,-1.42254889716173,-13.6477490779307],[-0.155988172976586,5.91819053216226,9.04625356219232],[-7.90100358421162,-6.63220414710269,0.763759025353211],[3.11044402908438,5.66285351925275,8.14688735868681],[4.09724699031263,-2.25527878772721,-3.52075851170174],[-1.01603581041523,0.22188880160866,3.8134425451922],[-3.62103708013031,5.73094372705855,-1.50472679636093],[3.58218092704646,-0.0873693843447962,-10.0838388727967],[-3.77577443989191,0.772521561781577,3.42235387022331],[4.4345805899535,5.83198033593883,8.34830901282994],[-5.71707753740569,-3.02616404120431,-5.54932084682213],[-1.46863964663739,-4.43449709777457,1.85718945482665],[-3.02373451290616,-3.51101330894329,-0.496997453995163],[-2.48531754049598,4.97196176684378,-7.26911038028479],[8.81506365048546,-2.20026456202722,-3.61958932093276],[-2.45865931355169,4.94379304225671,-6.43077431864392],[-2.08555752434102,-3.48120607242861,-0.84947349511297],[-1.26542899941763,-3.70593287134371,-1.03350915293967],[4.3818025921655,2.04519958066509,-9.49605101654767],[-4.91259665434135,-5.74953566355382,7.89659610297186],[-4.22261322631424,4.79315147171302,-2.49740413698325],[-4.68277512685367,-0.131560389317941,2.51156810309428],[-3.92414801673919,1.28072833976898,2.15441282609029],[-3.45627509072393,4.95068082562473,-2.25918221608008],[-4.10892727312864,-1.89875856325934,0.505805899561062],[-1.78361432554369,3.83239941600704,-2.7239577135767],[3.58445640389091,5.348341800824,7.09873797143183],[-5.43718816780684,-0.48354049102825,0.186516975784807],[1.77652457911655,-8.36735323527668,3.63493380112778],[-2.78463636650967,9.93393900447627,-5.86826704768316],[10.2354571889261,5.03000658769532,-1.52392596001623],[9.11207729978345,1.87175476192879,-1.51330187016694],[2.14763363522515,-3.46409995790405,-4.05899869939756],[0.606079185531708,-3.80774227012508,8.60421867029818],[5.1086867030822,-2.99012716855819,-4.19376030998109],[-2.95347189218424,-5.11943881945547,-8.88419049770632],[-7.36102942687452,-5.88480585315029,6.09981508549875],[1.07675020336407,1.96403238226306,-2.53345406614555],[3.77609928890442,10.4363181110461,-3.42747068855031],[3.93380571722012,-1.3017775838061,-11.8885170571456],[-1.27586997944563,2.63093664461571,-1.22745558185875],[-8.66326052858843,-0.248096096654186,-5.79413837548446],[1.44480799954309,-4.62451099545581,10.9871989528208],[-7.62809766910909,-0.525481522120453,-4.80345076525198],[2.67239288124383,-7.0849907816117,3.93689969253114],[3.76174597681286,-0.191511391142196,-2.65460725192141],[1.3400198073517,10.5783221703451,-1.8017531684155],[1.55014818746993,-8.79353410301802,2.677498768239],[-5.92937523083399,-3.01415870309831,-5.06693832884408],[4.13370566033047,-8.308647175599,-0.587423589665835],[0.352034973606845,-3.18387463198494,12.0852734259702],[0.877350858273295,2.51590556702491,-7.64350924574837],[3.59294564751124,-6.45708035687888,-1.97940912970287],[2.31816787886283,-3.93896866027032,9.91925215072962],[9.45472648101888,0.999231028522753,-1.53053159816844],[-8.61466707840979,-6.02853658355054,0.61885531940584],[-6.8188003502007,2.90245148796882,-5.61218868437495],[-7.44056222889848,-5.99074552568588,0.7744411258433],[3.82147299714288,-0.211625570342755,-3.38503280824632],[0.0868904920651328,-6.73386133025832,-5.96323160894362],[2.90420579795294,11.1859477112856,-2.10330906163354],[2.81016964879327,5.91283735024323,-11.2817591209686],[10.0450612497383,-0.296410236631335,-0.315291217661512],[-6.20117129367476,2.84098997137674,-5.70013420435835],[2.6143503301233,6.01479749543399,-10.9103991846128],[-0.711011544151298,0.475564149658539,-7.34241236924204],[-4.63502746181086,-1.17635782912289,3.36868985978688],[1.79057389336887,6.63867329273203,-11.4741456584096],[-0.705980364723311,-7.33943832306023,0.658331867078769],[3.41280329641627,3.36928843683308,0.527647068679345],[-4.84433847911104,-6.74963626733224,-9.58884908380556],[2.08847159705021,10.6263236610521,-3.32027729906602],[1.60382152856157,-2.79928891321624,-7.38094203052946],[1.75474346147087,1.2952833386825,-9.41123163483233],[-3.12245365064741,2.48277175194062,-5.40603103103483],[-3.89571842103087,9.24776761450204,-6.76351355028921],[11.460366766394,2.65785736946524,-2.15835106786446],[-4.15465442546882,1.96756268017278,4.15843852078796],[2.16327346725113,0.920500265897597,-6.69226422382628],[-0.940315998322815,1.46354372366599,-2.44543204299509],[3.87800304690572,5.62136395976533,8.72223533067156],[0.188614528938677,-3.22580635217479,-11.8741268523217],[0.421160764998934,-5.22846077116064,3.9779613184355],[-4.28460125771227,0.632583463919859,3.72506338993631],[-2.44750094280983,-2.33112066617236,9.0882577957628],[2.43528522051003,6.08780782981732,6.84155036982385],[2.50372618459721,-7.96007766762937,-0.425885100824017],[2.19723925739108,-2.68267737077475,-7.218889248632],[3.15632482324636,5.57700872071314,7.22518577465869],[-5.61798499512733,8.91863461524626,-4.70743710936948],[-5.25224871428027,-6.92976767056329,-9.96630509581616],[-5.80552356053546,-3.35498205347837,4.60145511165494],[-0.0658081219366474,-2.52321641332105,12.6298669725627],[-4.87543341947743,-6.790854596868,-2.32206332503424],[4.11931876579644,5.12345873711131,7.900125849374],[-4.66058135220715,6.29999601329511,8.80776848442201],[1.91930080957957,-3.67337736913053,12.355185020696],[1.2547652258887,11.5080775032801,-2.06029556434855],[-3.62342005548216,4.99696991438057,-2.31704113215993],[3.32985890659429,5.72143229425161,6.53949803963267],[-4.70621513106532,7.51454818457348,8.65207197604005],[3.65889479256094,-8.29020570674761,-2.11209084010528],[3.60774422292973,-7.74756567624471,-2.05992459603843],[0.770958924234866,7.32091518545865,-6.22961368111793],[-4.02467435400409,6.18397035074243,-0.566418131417615],[2.09524143073603,-2.83737659387154,-7.60644383136207],[2.20165033496211,-10.1429163759019,-0.625873585665672],[-3.84768268506597,-0.0137169976391598,3.37321171715435],[0.520289846893727,-2.66899784400466,10.2915315768603],[-4.65703007446309,-7.15931511129052,-1.62247170878427],[4.63803492318925,-0.787395394961086,-2.85595008691657],[-6.83044584747905,-6.06953004800563,-0.520229251896661],[2.22415992442868,-7.1372595202206,3.18589164254988],[3.93411909291889,-7.92729997540044,-1.71853474358586],[0.325122422778977,-8.96937016081534,1.91067849205345],[0.144278364338997,-2.47059867806921,-0.229912466384583],[-5.10534282669927,-6.63872352336848,-1.70789416209036],[-2.29357306645086,6.82789414555821,-0.196247650845344],[0.976123662069565,-0.483547516669836,-6.78171901023179],[-4.16978224770106,-0.471154105485473,1.71947291979876],[3.6757743369814,-8.74259623216639,-1.89438693467178],[-4.86890392255819,-6.43487556306022,7.70432816808287],[-2.76008980480987,6.12353621811479,-0.779600134233627],[3.57095894619588,-2.99466694269874,-4.73919288349481],[-2.41846559334132,-0.533415100810574,0.600527354691829],[8.62500556408374,6.67196113891312,0.61419758591328],[-2.93365583755768,9.51096830517182,-5.93542067980113],[1.26640405815034,-3.73459639482491,-0.473517205661865],[-0.988082581282773,-4.90530004287536,-3.25830914963888],[-4.49943144528793,0.470784241435346,4.98343754407242],[-4.4873048857193,-7.17749409607669,-2.06122633104161],[3.15616790924582,-5.67967062826348,-2.09395892923441],[7.58681809104491,-2.13741611600798,-10.3924093376076],[-4.85340195895088,9.87136973024204,-4.16751739926333],[2.04707042782525,-5.51683023615844,10.7407478179939],[2.7669331879068,5.62306983331516,7.71107243165904],[-2.37268155942893,4.13071756626677,-7.24608365480117],[2.34847255041037,3.43811117194443,0.744891578333298],[0.464559649672875,-3.39580451711843,-1.89768017543789],[7.65145399121523,5.00381141471166,-1.29140267378033],[1.84761475543001,6.07547461705609,8.56406549365007],[-4.68727720339682,0.0356307618384109,3.69417295996827],[3.38770525408506,3.59676964092057,0.34822341181352],[-5.28166321215692,-6.57476185308356,-2.39123286606052],[-0.694504527090349,1.69984627687463,-2.09427768000211],[11.6602730361706,-0.235522894966793,1.03604685376059],[-2.73275213335123,3.9385604999272,0.276246958159016],[2.94595989254432,10.7516915251459,-2.11244804517236],[8.84647349832882,3.01204383176804,-2.17749223420987],[-0.184799737465112,-1.04367423374101,-13.7230545391047],[1.06224367734981,-6.00643486380247,2.78724805007418],[3.45840022037304,1.25855378075727,-10.0213798903595],[2.50778339341992,-2.29150441628331,-6.81495750715989],[10.690023763283,2.82752592104901,-2.43709737207992],[-4.1294744405899,0.872516293710726,3.30787914301016],[-4.18933446794446,-0.423626432889734,3.1825578151939],[-1.33750617678341,-2.74293895701564,-12.0792956085584],[-7.62562531518068,0.0998014681707794,-8.07402218229648],[1.17649920589646,-9.06452498436789,0.938037965448304],[-0.0804761045773165,-7.68608304276616,0.781015164428165],[-6.6049256167379,-6.32738892639647,0.283014189963278],[2.19932552488859,11.7100787321731,-2.46413400279316],[-1.70031660504946,-8.20160754095808,-5.6639829640718],[-4.06510020999529,1.05000282678059,2.34635121973137],[-3.10673223642278,7.41352890726564,8.47678406502054],[-3.693637877446,11.474705950252,3.54860358842779],[2.13475244105063,-7.6853480522753,2.85642286145402],[-1.10687332350082,-2.19248448643144,-2.81850008118951],[0.25904018005733,-6.28688134968607,3.40276029401504],[9.00204679878251,1.55034271623091,-2.13416618252243],[-2.65248772364066,0.624150429496719,-1.1805597117409],[2.58445789814468,6.36551361556942,-11.5262187581609],[-9.3176652329774,1.29487951035551,-6.47082309224681],[-5.44679856606177,10.0077159411501,-7.41222463173456],[-0.757349428984,-7.16133021999738,-5.57389899442622],[0.709887304474729,-7.99024149763568,1.21397704091604],[0.522636411124502,-4.426299898231,10.9316469755924],[-5.01665685189126,1.50894420249123,2.51122920908872],[2.61151420043635,6.09164523073217,9.27833971545202],[-5.01495479108851,-2.80515071575565,-9.45858088092076],[2.42207759208718,-10.2407478839311,0.269437458769377],[-5.71426872422232,-6.36297532717606,-1.80498177261091],[2.83641858914042,-8.97878048994103,-1.42283521134011],[1.36887966371295,5.59434483385425,9.07216734313428],[0.618088531145237,-6.1222706690281,3.72132506589255],[-2.31248352035318,9.89608378546295,-5.89907059127462],[-4.8926136151536,-1.12512305125421,1.01272006766419],[-4.53209487851906,-1.25858648808823,1.95900184589534],[-3.96988746475298,4.18468766520837,-7.05407688320933],[5.19892769562829,1.20625882702614,6.14167860207726],[8.32444041852446,4.55933696126204,-1.05226340617441],[-7.06280851527962,-5.84695360962456,1.57382562599678],[3.40371438598949,10.7886184111078,-1.98798149029103],[-2.66733290934138,4.57845316941798,-2.77585818339349],[-5.46537330625457,-5.89831110611244,-2.15824065089411],[-9.57404799042925,-1.69785632099166,-4.00771636080663],[-2.13104337966713,4.93811185686368,-7.46818277743403],[7.90079595708253,6.11630406874135,0.984147160508926],[0.580989287203345,6.01923909618738,9.09448100793631],[-2.72313827124626,-3.35305325984336,-0.995927902646785],[4.75355112915713,-2.96438759607197,-4.04265625701866],[-0.0893314698318846,-2.85547754749784,12.3510727551334],[-3.00708423113252,4.92597552724505,-2.2755794676343],[-0.223335913167006,2.35911086976459,-5.5879954668856],[-2.74414443656177,-4.66816994297796,-8.674684230254],[3.73597944626246,3.48289665509116,0.631929220453081],[1.0570890523549,-5.58644884728459,3.90457071576067],[0.583400533242054,-7.5654320101109,1.93963331792316],[2.10906654364521,5.6877061170317,7.58472361921588],[1.43025987968069,-8.71749027070565,3.00743809227863],[1.18562183292269,-6.57549178857732,3.00092011437026],[1.06182254122875,-3.38396554365064,13.472699710796],[0.340668454013893,3.22850668408992,-2.60155478592075],[3.02499586439125,-9.68428235444132,0.0379936307130329],[1.72819040129097,-4.62117962580115,10.5054636645604],[-1.38459456346688,2.79613161069373,-1.94586518057716],[-6.44756913775293,-5.78685460249714,7.23398285613463],[0.720879957393143,3.91347479704568,-6.42926712830023],[3.23354102403603,2.36754436442294,1.35141640707648],[3.21197844576736,6.28984930482881,7.4418572084793],[1.60888508130025,-3.15936701019081,12.2406730117853],[2.16752399628636,-6.98536407639339,3.34382128331069],[-1.67730236244423,-3.00477298943842,-2.24870748917427],[-3.65009330962253,-4.9501518179757,-1.60588002407242],[-8.96023606820225,-6.70013066451447,1.01875543763635],[-1.65250961279474,-0.351941751546056,-7.22411197951851],[1.67996814255931,1.26227008781146,2.32082439843875],[9.11255814818912,4.21484364729039,-2.33907747857573],[-4.99891334994549,0.499248175306234,4.68177178250091],[7.01554375366503,4.97435082254505,-0.153225366505968],[4.51891131666109,5.42201704177748,3.23070781451086],[2.37030188320703,-0.212341792073692,-9.91803445212693],[-0.0809491864149138,-7.33072807404322,-5.85251817984978],[-0.720938784972532,6.27680658815358,-8.43958715598474],[-4.03261861099856,1.12971234174175,5.3139647544844],[-4.16583204966227,2.88983257974294,-5.31986245129444],[2.30070777030484,-6.84811649399713,4.35107072858758],[-4.99640629664409,2.09370007421883,5.02864815897737],[-1.06269365211839,6.53357416927388,8.98226959193154],[3.14693173193688,-0.287460451601629,-11.7891373542087],[1.24435103913223,-0.294779071687622,-8.45900393026852],[4.30644425218661,4.85782037366387,8.43639246835071],[-2.00436192136947,-6.29961626004016,-1.19453201005936],[0.755275996124523,-8.59127114447024,0.167511466017276],[4.1436952579608,3.12574678211041,2.92763115335316],[1.14000188836063,-3.41996876447379,13.02314713097],[-7.11463834058416,-5.73385707968387,7.20827569470754],[4.12674741391251,2.11101365329455,-10.074141625351],[1.30898264325751,-3.63264789742522,12.2023374042139],[10.0777117797893,2.65967313970947,-1.75050087672505],[-1.56480599669306,-4.02147283635549,-1.47624500644995],[-0.452512785733908,-6.98278041794278,1.03208196041614],[-4.92442279225477,-6.46043545328323,7.51817913190349],[3.31544539742686,-7.70544620921889,-1.58632617021998],[4.39239295878691,5.51881592784498,8.89643664833626],[0.246093099189616,-7.55304619376213,1.2812995252365],[-4.88478131497315,7.61863104836196,8.07091498055278],[9.12063426975809,-3.94496234626165,-1.54525476261936],[0.596765996956091,-5.37531430182575,11.2378891626927],[1.43250529866623,0.105894746388413,4.12831288142501],[3.7634068579983,11.5859784024283,-1.5428622403934],[0.210035950393735,0.124390266568736,3.08116562558618],[1.66183719634487,-3.48621461793372,13.0053316997507],[2.71898542508952,5.75989574502842,7.46534016169104],[-4.3927340674374,-6.44909228243554,-2.86790520819771],[-2.80717827419679,5.00469768036237,-7.26522446653196],[4.10357835695301,-1.13223702093772,-6.51638620767416],[3.43736469650807,-4.4116420927142,-1.58087663763691],[0.374425263811796,-2.75172734271402,-0.531837015323161],[2.03353535426139,10.4816379788799,-3.46070607613292],[-4.88275788463154,-1.3314917509136,2.7868262051151],[-3.70586743364786,6.5974209747836,-0.463977214048556],[-1.99714277496004,4.2556965626206,-2.37959978402024],[-9.24283053962189,0.480634642087208,-5.74160149626523],[2.97056602414035,5.81282329332075,8.74478729700224],[1.57402768677887,6.46950886526241,7.57445532410504],[-2.36575977176428,4.83221255785905,-2.90005149050981],[-0.776644741691664,1.35177230510049,-2.34798586126395],[-5.31545259265883,3.05834797467577,-5.38387288872429],[-4.7130338995626,0.900637374244986,2.5632055047793],[0.986220348215164,2.15997255913596,-2.8865242907889],[-5.80549880021015,3.85349336992897,-5.57721825167687],[7.89416782090762,-2.7401803196883,-4.50370565856591],[4.63120250966766,-2.94458675497648,-7.10319773957645],[-2.43173816013146,6.70575256817103,-1.00314892330292],[-3.66259426456149,4.24638065162589,-6.91834934186921],[8.84134952139268,-2.36795001011519,-2.95824888818425],[2.80595647589173,5.93576217521696,8.63371062380406],[2.50518029406707,5.65858809985893,6.19046543725878],[-4.36296904156154,-6.29863488903368,-1.47430929076963],[2.40427369260246,-2.70837314101256,11.2821890039127],[2.09644951628807,5.27432634190511,9.37255017754456],[3.91144658471195,2.26858616806281,-10.3876463442591],[1.53344617176775,1.7271316144201,-10.0786271305881],[2.26663740504123,-9.81474285513149,1.80676753151937],[0.589666411902976,-5.27312922319158,-0.879478660767799],[-0.831349399036805,-5.15938160847868,-3.3557346460358],[-2.89571912567416,-0.859312452642129,-3.57646501229194],[-0.699170529488177,6.25861197242274,8.18136015914991],[-5.26999242622767,-0.195110994386331,0.575072839999619],[1.98232664957901,-4.90023048924506,10.3671584952626],[-1.98058616270841,4.909519016909,-7.36089540019128],[-6.33654279703439,3.26064077438838,-5.67765935059401],[1.96106448314428,-5.53677137840675,-1.88116711668848],[0.570067233285209,-4.50435267193303,-5.72736779090978],[8.97908173325632,2.74433325345711,-1.44237081181743],[-6.27758693471379,3.51397452674907,-6.51866518534698],[2.59093745168064,3.73921832213062,8.08318502768123],[9.41056599119277,3.60834733558182,-1.02485667024512],[-9.52542720786183,-1.80424808608886,-3.61997254842548],[2.70570834052861,-8.68087125291659,-2.02403886015949],[11.2673768616602,3.27304740187548,-2.1364646048741],[11.3001746985547,3.19432600440173,-1.12145906707753],[-3.59856813013919,6.41853784172461,-1.35098295545337],[2.76558308735888,11.4151144499863,-2.32472340704236],[2.19401724907852,6.65278095275779,6.55734960329435],[1.809200522991,5.53574695618995,8.6029431431044],[-5.51225759595388,-1.28336353876763,-1.31407743566024],[-5.80665679255143,6.44462512741679,8.88932462028484],[3.21549365622053,-6.14205016172546,-1.22217729107781],[3.1446165464858,-10.0770139648753,-0.362797456341035],[8.81582245893708,-2.87220739990906,-2.76948277623879],[3.06848466643693,4.31476764717013,7.93051165897638],[-5.31383798302713,-5.01681511552859,-3.69913108071679],[-1.90731157735977,-4.79859932552904,2.10695530397493],[-2.81951468115104,-0.93488869023078,3.50819162270115],[2.34516859461442,6.3901565657311,-11.4120165115243],[-4.6607621898838,-0.0542555216892859,-1.35580715004899],[-0.246797738662121,8.86165194461689,-7.16599006111222],[-1.29641251957798,0.642031334784006,-1.59295292439255],[4.94657694411797,1.41490359398864,6.59196801096653],[-2.45061386839944,5.50535131778988,1.18945584477406],[-5.07448916741692,-1.36318242113921,2.6846751209809],[-1.49233236341006,-6.96173298379387,1.47659874405733],[8.26966515583164,5.41720694311272,-0.709387933628171],[4.04436966142928,-5.07252615755983,-0.968639361388831],[1.7434129830466,-6.72010711076327,3.3164171470738],[1.31218718141327,2.28190786868302,-3.53991298631895],[11.2677942619959,0.0831490540134697,-0.155801321536331],[3.39678583185505,6.48180115633122,9.09116858794832],[3.11416008346325,11.1366225140875,-1.42301975467026],[-7.13173976084698,-5.13663275171516,7.24269253387979],[3.84592297516119,4.13065574572877,2.32628921113181],[1.50502891260808,-9.50729300680825,2.47100718902034],[0.696975170813374,-0.0517006766527509,3.08124404952073],[1.22973938804343,4.05732711809106,-6.13541271677683],[2.11704965808781,-9.80542534015416,1.41431500410079],[7.2415066001674,3.68310844818922,-0.00166146497476716],[0.578193887608666,-7.19616886455945,1.54427125163211],[3.03632352308235,5.83889950999675,7.50145735860036],[1.19286522348783,-2.85280439487155,12.8468301845558],[-0.244869493931422,3.78381530938125,-8.78674676470348],[2.04037402703662,6.45225035621679,-11.8506112913524],[-1.89308264410735,-1.90706921999744,-4.06133594976101],[3.15657820364093,10.4027588673839,-1.84460573024263],[-4.52971164510505,1.22764805324809,4.91401379653015],[0.32599766869774,-2.19609712685628,-11.5329089780707],[-3.19787821976381,0.249707342970714,-1.95732769380078],[9.68066500442376,-3.98307650014982,-5.59339537433761],[3.77141510112697,5.23560153959911,7.89292086169878],[2.5592719546936,-8.50982567764739,2.40083246110225],[-6.22366487140687,-1.53987227900752,3.75203507827571],[3.21761695031159,-9.27530337078352,-1.71930559390267],[3.79506415523415,-8.71184609217421,-1.68930963033256],[-2.65648476082115,-2.55458023402924,-3.4085200583345],[11.4804390106935,3.3277127951922,-1.60476553293833],[2.69032513190544,6.463528701822,7.96203581978953],[2.12699754733027,-6.15402138433142,4.20203525282845],[-6.44787076169396,2.757727987116,-6.12135668156425],[4.01872123412039,11.2892881081451,-1.01095232875197],[1.41610951687091,-2.29171339304716,-7.94959727125082],[4.00535577393986,5.34329914916301,7.86938119051772],[2.2954435927756,3.7858546404056,-5.83118052061764],[2.5052946739605,-5.71313056272342,-1.43900977731442],[-6.79476995506296,2.66028439412765,-5.60991329507815],[-7.21384293849279,-5.85599894453875,-0.0385483169162441],[2.52920069629101,6.21486416836965,-11.4117485249438],[0.983755435960133,5.60132514035297,8.57957201945235],[3.47874753353493,11.7994360969651,-3.19840642572026],[-4.42130252024578,-1.55312114602957,1.68490012611343],[2.77962581517672,-5.15674227097449,-1.5568474717078],[-5.70166592018622,6.71136370010496,9.12760659871939],[0.769652181429099,0.27543358827486,3.20336972382338],[6.66507283075159,4.75747969766453,0.500244533644338],[9.01613011878124,2.11360999521689,-1.85240571814859],[-3.91722613771128,-6.93901519540809,-2.82954164767149],[-4.22590196178034,-3.44372851716157,-11.4631454704394],[-3.49141421812188,-1.63844996348781,3.82419316424634],[9.25853610472327,-4.37156670465222,-3.75184744402285],[-3.19360736258432,-0.453423661549058,3.16004814496139],[-8.90588735980177,-1.17877466497155,-3.98135540244735],[9.27647589076365,-3.73460457361597,-4.93768711253719],[1.27245696040866,-5.86930918987337,3.03613755720929],[-5.28528535417454,7.92661906947217,7.99755007794414],[-7.64331218811683,-5.5463484188941,6.78567745713448],[-5.73515689866512,8.90780197026028,-4.03604921754861],[0.223555964514443,-8.34985098459045,2.16923789208471],[10.9574689998335,1.80812160545634,-2.05721659556014],[-7.80798161896409,-6.61196286865025,1.55570086114879],[1.23229996827504,-3.563862340935,-4.96089538554914],[3.07111688624451,0.263039328001798,-11.4262521525458],[2.90024447094006,11.4112231977268,-1.30257942585863],[-2.03010297804323,3.4304185017418,-2.37766017860013],[9.8629881650768,2.3209698654205,-2.58273121060239],[0.80132328237768,-3.63755951498902,11.8811462395255],[-5.55266935375639,1.49849147473848,4.71630254403094],[-9.04150567846366,-5.63774067875373,0.930512509587],[-0.165023605083292,-0.924251586293692,-11.0616709702713],[-7.63283713553573,-6.41308914790109,0.443874134719965],[3.02775898951512,5.10206536904982,8.69759462032996],[-4.50544520048594,-6.23995313666234,-9.25512031873782],[-5.10589775888159,-6.47137059563814,-9.57651136407676],[1.75322821329534,1.49001882583113,-5.15940995456106],[-0.876410892977616,6.0384496421739,-8.43664600140772],[3.41225893847981,4.88396297438143,8.06104433852],[-4.22548327358278,2.91648682425677,-6.3119509367929],[2.85042020022987,-8.30343791481216,-0.98792727034472],[-3.06396597475711,8.15344560581194,-6.09899982583323],[3.31092193867385,11.3742986330941,-1.99047658567256],[0.672243050991022,3.95952583372254,-6.13649252273641],[1.24407031192284,-7.02208538303264,-0.263606596258679],[3.59924893930318,11.3680696468418,-1.89030870578205],[-5.2962136741619,-5.69392916982714,-1.64041467523462],[-4.60238683122939,9.71295675164999,-5.19597812969443],[4.46002173365144,5.95561769808814,7.75374741977632],[-3.50219601562378,-0.12967188840617,2.11703233749774],[-1.16981570566435,-8.00882739675723,-6.04482400125022],[-1.83522186185083,-4.42862394588721,-0.855487305708013],[1.41104391098682,-3.10834982957994,-7.76047938513284],[4.11127216341108,4.70397810005,8.35021903224489],[-3.8308172433051,2.80724399197058,5.53374693335895],[1.13130520552412,2.04798148278561,-3.3756499157876],[-4.551802781673,-5.5679635785543,-9.82504505829039],[2.05984013945066,-10.1492476484802,1.45271626144556],[2.62872523435035,-9.96423196003258,-0.714063852135091],[-4.46079961521044,7.15576796440925,9.31353541585531],[-6.33713041176108,3.31704865003739,-4.06566137663606],[3.18649205299186,4.64999586420876,8.97054389253936],[-3.13692799706016,4.36977893626605,-7.50682380875815],[-4.66312811133595,0.720418837466581,4.73994992566762],[-6.08155033043072,-6.04515049580718,-0.97892170802659],[0.268117883930029,-5.35888950451447,2.6038800823629],[1.83130270470094,-2.9491781908176,-7.99684301446676],[3.22175269778439,5.86584028715589,8.43960935817588],[3.05820559146447,6.54248958172952,-11.9031344702004],[1.78268981094577,-3.48373244048414,11.4807975149482],[-0.684325286223866,-7.48960947690926,0.629713202256314],[-3.05003122499103,7.10632894336129,-0.434132965971426],[8.90263380724866,3.39532867902882,-2.08155603515501],[3.36640555430837,6.09987361298808,8.2929308463067],[-4.97684491942528,-6.24597280696972,-9.98136644194279],[7.30175887206969,3.91989694021005,-1.46669084616029],[-5.64811722213976,1.14578816549515,4.76404226322088],[-2.97311976810756,-0.47932937231892,3.02733658442454],[-4.78374859207098,-6.30782235120209,-0.884222774150186],[2.46780655797342,5.9521092196333,7.05461114765092],[1.28393550811817,-8.7521190631225,1.90644199040321],[1.2083581519241,1.52684138267858,1.70024505137631],[3.59081518779461,3.41061493099128,8.64249169679666],[-5.42938991006544,3.41668369768879,-5.87701387412155],[-6.17642349213828,2.63301121404668,-5.45706960486272],[-9.79025657400388,1.1410475928932,-6.08838339168981],[-1.80383303365356,-0.92340528861839,0.906476863077024],[-3.35349788978836,-0.254733694108511,0.814332219068186],[1.10943379637813,-3.90696834788583,9.85816945207761],[-0.0156446886229558,-2.83106626908025,-0.386551357467708],[-2.06093343774768,0.123470271233368,-4.81593510334238],[3.53729050114881,4.97173671009579,8.53547316447898],[1.26728105436099,4.18939720999184,-5.84834094794258],[8.94763213538436,-4.12263802216042,-1.17681366492229],[2.28562263979616,6.22260488712093,6.62483289959659],[-3.97049365205184,-2.68310433681104,-1.69007751816507],[4.0955688701977,4.89750329673328,8.11994766622099],[-1.62640642076321,3.5205258631758,-0.903651676918587],[0.474173470789782,0.261349034806646,-3.13402003188919],[-9.45920472091948,1.28030654890679,-6.26239305607351],[1.87610160764114,-5.91795483024731,2.33379822480564],[-0.412013681303291,8.97232824254723,-7.83141974763457],[9.56916257727459,1.74195177813995,-1.45369801608339],[-0.842016212878954,-5.61980574074669,2.11899888827582],[1.70498261472844,-5.47502161311119,2.28503758710479],[-4.58443360592076,1.17319581634243,4.56193636211418],[-4.72375895619367,-0.546475421318367,4.44304081204876],[9.76103362788749,2.69257569519148,-2.61264501065272],[0.320189805287566,3.13258300411092,-5.92436315514751],[-1.50989825029294,-4.73485989666401,-2.84731288439888],[2.20122527261897,5.92199010880087,7.33456294374594],[1.5227334841567,-7.97172352564437,-10.6686193841167],[1.80448491784138,-3.59179054954553,10.051230678485],[-4.45369459123951,-6.06428930161877,-9.29803905452579],[4.52604538486298,-6.19901342489598,-2.6114685375136],[3.35631666438391,6.2236559084101,6.83248316950965],[-4.95047672981759,1.19007149971546,4.79271411488834],[-3.2071122758239,-0.89195134306589,1.52043929726518],[-5.34947483301978,7.89253368073283,8.19703708454042],[-8.63098283003648,-0.317891025588459,-4.71440131941925],[-0.702828146468027,1.45198049995694,-6.0430383619333],[4.1630102502284,4.65513020686414,9.15520885345877],[-4.77689942862402,-6.62476022684157,-9.27088377100457],[-5.31714385903537,7.60534213634308,8.90279335936478],[4.34740887849448,2.89048126843069,3.14899888571861],[-3.22390193804368,-3.28328978405385,-1.04348393260352],[4.05061448013675,2.37955840923629,7.7314316103458],[-2.44378606115333,10.9883476571842,3.09977717427623],[-3.48283376432068,-2.5494143040111,4.34346406501148],[-1.88750652118848,-4.58990181994742,-0.253471246376415],[4.07276421799095,0.529950295627044,-9.01210083984252],[2.08497999801013,-5.37518766978856,1.40826601265381],[-1.48614946916617,-3.47569026806028,-8.70754107632415],[1.41496921523359,-5.20336685574111,-2.04526436178964],[-4.11057056605086,7.51121446468411,-5.78467430448111],[-4.91392840094139,-6.42829465576091,-10.0327750943897],[-2.0423093426924,-0.535380657265232,-4.13975269477392],[-3.41596306700594,5.49536980194115,-2.84302098104077],[0.662949176420251,-6.52482469653742,-1.31637737485302],[-1.26212727298695,2.36723643775001,-1.59835009512812],[3.35352182310441,-5.90507720085901,-0.777271632686462],[1.78105651216102,4.77375860063571,8.20158192590784],[-4.81836226611372,7.50479491648496,9.47046931495148],[3.66704712925332,4.38414344227745,8.51077896430889],[2.36400060564709,5.882535554759,-11.3916519447026],[1.41885114986129,-5.1886474056247,3.33016120874141],[0.821498845332801,-7.45482960674243,1.18720829846349],[1.84678398226116,-2.83245741997779,10.9612751306873],[-3.83242049272718,-5.82435987640265,-2.30611999779042],[-0.346960833289078,-6.50700607190026,-1.36016500059461],[1.81628393430533,-8.56307345264891,0.746102125286202],[2.7506201281675,6.19953451236117,-11.7808047903098],[-0.536985941702861,-7.64312207226595,-6.18677492934353],[-1.6025061887851,3.21544465312214,-2.45766710321285],[0.399376460331419,-6.05220569981343,-5.73020991108714],[2.67636892412127,5.22028295367681,9.17739736151459],[-5.17290787733598,1.69782107621799,4.00681286927315],[-1.95846921709111,-5.02486958369542,2.02323783193712],[3.45281688835023,-5.0824883424022,-2.02108455897446],[1.51478621606838,-5.7840108511979,3.80391719153544],[-5.34108430327302,3.24249734718211,-6.69523434915642],[-4.30045452275671,0.125888635294908,-1.4065396010137],[2.67493101484208,6.378103539376,-12.175913886128],[3.77550701019788,11.7926760627601,-1.33829574528537],[1.84136922889664,-6.92686075272234,3.10312249616237],[1.94151831914962,6.18774694293281,-11.1920419979233],[-4.89631285944816,6.9284026465847,8.21831036045608],[-1.00206987165936,0.401373467346231,-7.13309669489371],[-5.95371130976908,8.64404761780854,-4.18997708529413],[1.89201100137152,-1.59888037888223,-6.75510108861812],[-3.80586561319459,-5.68194646602698,-1.23647701213385],[4.16606701393563,3.58617633665567,2.80916593060744],[10.6344501304341,2.68820098789313,-1.25556705603392],[-1.74058471544269,-3.36848825420261,-0.199198329569333],[3.03185207324885,-4.28439906441155,-1.41026539096307],[-5.37208843286919,-2.75784202479486,4.46240275668643],[-5.10023476279374,-0.562752782841309,-1.0108209256098],[2.34102492827323,-8.97495721541781,2.74390924256406],[1.34648309582569,3.897374180807,-6.62104039977171],[-5.09162767574804,7.19129052851585,8.9425751017855],[0.589067677549482,-5.47794529722105,10.9590337352096],[-0.294523168483502,-7.47783119384049,-5.72493068014125],[2.22496647917301,5.17612407876,8.05480177874316],[2.84142092499076,3.46168423125435,7.8363880642141],[-5.30122971934932,-5.96266699643563,7.64729306805908],[1.48847819302541,-8.49217806946065,2.6626942833857],[-4.25453582686269,1.3944848995379,3.37709276720956],[4.67205994043504,2.78398889121678,3.91016650856797],[9.28888299523618,-3.52968843760716,-4.80758106997336],[3.31086270137412,-5.7421114604493,-1.38112736440412],[2.65336551031094,-3.99427551951038,10.7458250225518],[7.77311796927307,4.07415570729507,-1.55174553886171],[-4.6628970615373,-0.0445246541866552,-1.65094885368695],[-4.66717791482406,-1.08912203587698,4.23298709410966],[-4.81173993462152,0.859984862475545,2.86953626172549],[-4.35645860508717,-5.79611875068369,-9.4968053426292],[-6.74084380845167,3.30594435529417,-4.66810119504038],[-3.44768411421625,0.731387210672963,2.76561460731513],[-0.467427553505336,1.42058938189428,-1.87309456898209],[-4.79698476669945,8.58935535782187,-6.73934522659006],[-8.28068086729231,0.292012387059509,-5.26900962273683],[9.58264752115267,2.18548608918302,-2.66049125186872],[-5.5143983927013,8.70269490761248,8.00466780926303],[-4.24036580110725,2.51243633235827,-6.15815749287004],[-4.66640247847478,8.19845687269377,-7.35247943322613],[1.51864070118752,-7.72947813140777,-10.6028881739225],[-4.81721179674762,0.766782945276518,3.89676690980196],[-1.31606401415571,-7.454560751941,-0.521562229195833],[3.06160706249546,11.6398898864906,-1.15663344949719],[-2.76337517189453,-0.697212302836059,3.49860310215044],[0.959874698042592,-2.91336891700863,13.4366622531846],[-3.73238721361128,-6.70509282398182,-2.78958952531933],[2.09924053223458,-6.77473926611189,3.41300313462387],[-5.4325857218812,-0.281477116104496,-1.72765754548687],[-5.65457294158885,-2.66124807703224,-4.14688951177148],[9.71018411610917,3.07915708607921,-0.467825105957886],[-5.19509278379676,-0.0347617517670775,4.54099162913196],[2.74752783775107,-8.2180537607944,-0.377772042785554],[11.1316167836156,-1.72422380750941,-1.7678101948906],[-1.77739536960909,-0.829210636495855,-1.76503408295437],[-3.18863980301138,0.111625551331595,2.28832601920301],[2.00104134864152,-6.70851819114991,1.67231714054805],[-3.65821246647099,3.34236354019135,5.5424189757725],[2.21570643637482,0.102023042654785,3.68979991587444],[5.03920086628884,-1.19540430474593,-2.68699163284907],[-2.79847484193942,5.29224485012717,-0.874453293204824],[8.82760086198387,-3.46999342879143,-4.21038349290667],[10.4241570255234,2.41735626749359,-1.98851447842937],[-7.19461628884346,-6.16894312340889,7.1575242611562],[1.519664588142,-4.9740819966834,11.5018848721261],[-3.26475502104127,6.69081069329348,-0.68166263888118],[0.547049522375818,-7.93030734724763,2.04739818471202],[1.67032189264005,4.05808276108879,-5.68624260066837],[3.68982140420015,-0.725452927662318,-3.27696212229529],[2.43152115604266,-2.71978593927997,9.55043698901676],[1.39505945650036,-4.83087516821077,10.9755083994703],[2.44485206122997,-2.82241467487055,10.4692612757853],[0.416664101659869,0.265306223250235,-3.25809359731731],[-6.12443039327119,8.03218949914788,7.78156538941313],[-4.38817072901654,3.82981927035046,-6.39545228661673],[2.68092582748932,-7.81227955916795,3.67991633927343],[3.08395351934114,-10.3966085703753,-0.638652003818017],[3.72003337770308,4.75141746595888,8.78924333250999],[4.58864951668459,10.8596811161901,-1.21921668246267],[-4.7061806071223,-2.85882210718749,-3.14434679192016],[-4.51707390169283,8.12182199461806,8.45131355815182],[3.21524848133423,-8.92243114937978,-2.41075844960838],[2.61790657606207,-10.3002934739739,-1.44226761268197],[4.19323052764369,1.54752461218489,2.56842029229845],[0.356881440185946,-4.85573212859243,4.03160701554055],[-6.55896267565576,-6.22287711685249,7.17680829413263],[1.29132000843098,-5.94921136274711,3.62897774727825],[-0.281227786091111,-6.65769002528807,-5.61649738582802],[2.81311147068601,-5.61428305603118,-6.34292642428441],[3.55839174964723,11.6104660941705,-1.72075760482163],[3.80172793824132,5.96523052088724,7.3649408498744],[-6.72063311973737,2.85999875985861,-6.10516733023252],[-0.376212864905619,-3.25489716103233,-1.8883954561513],[-3.75182051367638,1.61346633093437,3.51643569338951],[-5.07626574628616,8.62586786882458,8.04620020650206],[2.38886183231008,-2.52606172882295,10.3632844960913],[3.58649086536058,-5.96099772027004,-0.832954530652582],[-0.227414725272534,-5.54934831513723,1.9776433084437],[0.616328216784579,5.8823390471254,8.71796761546773],[0.270002461565948,-8.59686853752647,2.21526106180245],[-6.79735885966513,2.49338326259139,-5.96981331567984],[-6.84876472914783,-5.83844278222784,7.28671761532597],[-3.60723891246029,-5.55767182085424,-0.959909593079468],[0.75824055517969,0.237226125875697,4.46819808082657],[2.66783709748154,5.62524543398803,7.57551633076261],[-9.59218997542575,0.812374924318442,-6.02954873649455],[1.55809712523419,10.5562670314885,-1.87640453549626],[3.65007032581792,-4.33506168025807,-1.55964706714314],[1.67190061707986,-4.48313901313399,4.34245125058621],[-5.23070570866502,-3.57786756204718,-4.57211415294757],[-6.40072173092164,7.07217950569641,8.15059566241025],[4.04386022222786,-5.10373826862268,-1.26995386881731],[4.39061717343268,-5.78512833877775,-1.76903057288462],[-7.0719586037381,3.02389853122837,-4.70726040444063],[-4.2255315056241,-0.810009945751465,2.13629720427583],[-1.95887730262162,1.0348437387055,3.87881581484626],[9.8335037846932,0.316853037667809,-0.48334944690499],[0.983619946633356,-4.31597747668538,9.86843239066537],[10.0626733898828,0.611801383079305,-0.941687058232854],[2.59202397957833,-8.97897001789493,2.31964054629534],[-1.97957510088749,8.73062196652512,3.19658299689048],[3.53305860832999,5.39560160150648,7.81759745178367],[-2.03165542301198,0.788198632096306,3.678967057425],[3.49257761960423,-3.36182472838273,11.8414282091357],[-2.993575503469,0.223620337559641,1.53390370182264],[-4.32885236807512,2.93774529272059,-6.24910465161138],[1.89408217926289,-8.02981874981157,-10.9645830980785],[9.18278014274603,0.514814556623545,-1.52539174891287],[-9.45738482389636,0.268450889993681,-5.82929108530858],[-1.50620731683056,-3.39504651644405,-0.685568859349699],[-0.0427718700094183,-3.00572547571013,-1.06012832288777],[-8.10846308798077,-0.0472867549426697,-4.90453838907115],[1.90120836260788,-4.54255319663443,10.4906907863668],[4.22286230664931,3.31834732313546,1.59349789671993],[1.70833577697281,5.72367358491544,7.28971303596152],[-4.98109956474205,8.34090921299709,-6.72154048109745],[4.00137286535201,-6.65037494747052,-1.82344651264991],[-1.20534812863974,-2.75313894118303,-12.058573412184],[0.965347401378193,3.22634994362399,-6.81950768564695],[2.66724642998847,-3.53977293787342,-11.028514075391],[10.0191190411483,6.41423633661219,-0.897364265087028],[0.950504082446112,-6.30587643670076,3.72582555405449],[1.44013604923918,-5.36324266650504,-1.83878356039142],[-4.91948885926149,8.92702058525783,-7.51241858083679],[2.7312250670661,11.3121245322015,-1.35303250483939],[0.508293752297792,-3.23433197140591,11.1039899344834],[6.9558790664836,4.27242114073355,-0.572684343310409],[-4.70383900528961,1.12651205778824,2.77665481463897],[3.49170477941711,-5.29535697764639,-1.23924699711664],[-4.0917344993638,1.61999630275724,3.29421740300417],[1.23730890762246,3.50934558885137,-6.59060656926164],[0.773645352173944,0.741601285546564,2.90065928897218],[3.87229753423629,6.03361544209696,7.44872511156236],[4.30858925221448,11.2000987145844,-1.45720782227857],[-3.50454982300898,3.6532668041267,5.66303359764233],[0.173911238403812,-3.01170850015958,-10.677087889452],[1.66393628791611,10.7195057489941,-2.69262074053293],[2.78032029651455,-3.39251182302569,9.83304104294993],[-6.12140166729322,7.91105897838757,7.76237249166594],[-8.89110120476942,-5.49811049000663,0.790856456989141],[1.39113355941005,-8.34395748796029,1.81848304121262],[-1.74564176914888,-2.53698633939582,9.49473573205063],[-1.73574386256049,3.44150284823775,-2.27967394511707],[10.9753550026661,4.56298340596414,-1.78964098731677],[4.34886382407475,6.00926594822035,8.17259384626094],[1.51487147954499,1.37851298497071,-9.77479408999911],[1.58418851688328,3.94537772971972,-6.36779758367103],[-5.35195398754445,7.92158269543786,7.95656255864845],[-8.38770698324441,-6.07854547515368,0.739825527198416],[0.171166907659611,-6.65643849750609,-6.07598098380958],[-6.62399118321832,8.93763150963594,-4.69601958258971],[-3.01819086723527,-6.00890832577229,5.94634337740804],[-3.04673638239861,-0.702864677974513,3.18864061349713],[2.84029480319749,4.02141503705582,7.72684524616593],[3.60119555252276,-0.826534111515042,-3.97763090660911],[-5.93921748361199,8.14754769154189,-4.3320472212557],[-5.7027225694425,7.2471698003796,8.34755695079949],[2.27699490674516,-5.02953043824581,1.97757015350999],[-3.83826097729062,8.21923049901195,-6.11042558242068],[3.81630464623773,3.82689975876622,8.43613647940153],[-9.34250022505103,-1.40373211149784,-3.36214128544235],[-2.9678737147016,4.23929854333629,-7.19883051522926],[1.89981878624314,5.91470607602855,6.81431459595064],[-4.26513131443576,-7.01041402778222,-2.62191420889412],[0.769885589057119,-4.40252510427244,3.92674175212811],[0.786856941943844,-8.1253737774686,0.970874989111188],[-4.71023328107815,-0.50166184039363,0.0296006922923687],[2.12604971179908,-5.50709480558021,5.14103962574076],[2.52178714164504,-8.24090616824183,-1.24213023884188],[-5.10758808174422,9.30645817475514,-3.73733394215762],[-8.46008097750415,0.182559611239667,-5.39893116392912],[-3.40192422232548,11.3813692407735,3.54963128734385],[0.309451732100543,-8.89673144285994,0.114341907112455],[4.30963170147654,-0.941705722248402,-2.46152742207899],[1.88656685189026,-3.16774610209384,12.3430540166228],[-3.74087648402438,0.23650942040314,-1.69835661511635],[-2.24775237145831,-0.168047202986586,-4.14954684201844],[2.82281659557661,5.59343400148412,8.43498488505872],[4.00924270782434,1.33853236987861,-9.97677060643414],[0.588361607060757,1.10343413751574,4.00391779226952],[-3.3983936518246,1.51709893562135,1.69103874222265],[1.48131614269464,3.32861918012469,-4.06035556707604],[1.70481867107442,6.15526882302127,9.36632949457865],[3.40387908893626,2.84641664251639,1.24596910020114],[3.32443061749173,-5.79177256936372,-4.68584167862377],[-4.93706070133217,6.11941412261198,8.54664816810618],[0.916191220996864,3.1859520168267,-4.35877667386633],[3.01609566734749,-9.27687624523966,2.01487832575237],[7.52569474852248,-1.89464735089777,-10.4924125884902],[1.48346028020545,-6.2410033047326,4.91840977567323],[-2.09637471392099,5.92075690191014,-0.383455226834745],[-6.54271751522548,3.19287080124982,-3.99877315157699],[2.53740212543152,5.97418297926485,-12.5243325977369],[9.56016206594176,2.98311489791969,-3.12882197455414],[-5.49280127177097,-3.42018922875643,-4.59929460480005],[-1.60408412981015,0.0406179928185961,2.87718602782197],[1.05855358308239,3.26483747802212,-7.26313862730031],[3.53516112910615,11.7428493900374,-2.61331373642744],[-1.57571519212711,-3.36761155642413,-0.280203061768148],[-2.60180393995127,-2.61995297561225,-0.248900052399055],[-5.68566944028681,9.17779046723227,-3.9941753430004],[3.03753058031124,6.02689617086148,8.39256633199817],[-4.42518227119431,9.410896619468,-5.76338466543636],[1.97857792522387,-8.80714118242111,1.11382801874155],[-3.86112430532013,4.31013955307755,-7.09487157341204],[-5.53043134566408,-6.17563994010202,7.3733124730788],[1.48698407643305,-3.48462441581479,10.9260504420665],[-5.87586216915035,-4.24654837170983,-4.45839192310769],[2.58884200564235,-9.62966628752238,0.838444378579047],[-3.47310744828255,6.78123001977103,-0.990244606314861],[-1.55883251522467,-6.13377368609001,-1.46773364480818],[-2.21625749611583,-0.543935244003978,-3.26462399243746],[1.64135895466248,-4.30085825924788,-0.113858431150255],[-9.00325741245071,-1.64755332367818,-3.44745946046835],[-5.29225228438098,7.30896215268494,7.7218870651616],[3.30197343211983,-1.87978210120101,-6.74716623410116],[0.733477567067548,-7.67835654085734,0.80106252739253],[-2.09747014720096,6.53122309481377,-1.28539277818312],[1.59477962744111,3.77622949632398,-7.01406180199655],[-7.92898915422852,-0.651645610249702,-4.44599771078887],[-5.71160027718825,7.81340416617766,9.02106231720853],[-3.73669204107354,0.228902244435999,5.56716442170048],[-9.15787592564588,-1.66015972791539,-3.12400797233509],[-5.97872933385991,7.69383505559721,8.7934465282182],[-4.64002000402836,6.31109996886336,-5.01923978439282],[4.19019713288851,2.23891402873121,7.44072875955629],[9.60687052738026,4.05941407499019,-1.65994972036344],[0.551680347883924,2.20151417331949,-2.66759841980848],[-4.69179217275116,-6.94894159313876,-9.86965863612559],[-6.6427602006668,-7.15204552212287,1.50020164593854],[-9.05469201149946,-0.567591810612887,-4.82491803673084],[2.70734498285747,6.66852868553335,7.45630695926552],[4.07575848025701,2.40592542522706,2.47272780490891],[-3.45502616926806,0.325370675717515,4.21437298266242],[1.95294093584362,6.30651429389317,9.2355581174191],[-4.15388656891967,-1.8071501399153,3.98377411405875],[1.51383748467706,-5.19539921825977,4.62889778178042],[-2.63172483118829,4.87677828843655,-6.74739417396449],[-0.121751208736466,-8.12327114023726,1.45177571014277],[2.41074346518555,6.75535088365308,8.90707932668018],[2.64733745009591,-2.98502691646679,-3.25521834395985],[-5.65046490511623,-3.66447086289066,-1.77760373787681],[-0.847319662085658,3.73675476972803,-2.88690214222615],[-3.62305219071021,1.07563104101198,3.56975994735492],[-4.75655723402627,7.01491175796785,8.80335482608046],[0.789749217392316,-3.05943279942185,11.8053199014033],[1.71713822206814,-3.10461035710769,12.2760436856538],[-5.54424106075219,-6.72836647088668,-1.20243807377444],[-6.06810822896019,6.52407611593718,8.62485825772718],[1.97320939838106,-3.54550990883337,-11.4486021081314],[-5.96396907191282,6.95726022928331,8.80101683430036],[-3.76462418056732,5.99192524225879,0.246149089575476],[7.24622905649874,-2.56450071146735,-4.96058206385208],[2.34581713180759,4.72528127449368,7.81970998127299],[1.65937421933601,-9.36035919806566,0.929578585543564],[-2.29301805315741,4.06884558285789,-6.44090854886452],[0.283585927974728,-4.02177113338194,-1.31497457409269],[-3.39441352852754,-3.42897017945249,-1.59246276792856],[-1.33866542284771,4.00971613096995,-2.67910469100952],[-3.56580936649615,-1.98120451401263,-4.00599198679357],[8.67921178496252,-4.26391378758691,-1.46880125564399],[0.370778440480135,-2.88870658894165,11.0975557533313],[-8.24043592396493,-1.31682470425765,-4.03279533430243],[-2.15785049764614,-2.37739619967379,9.1090193447216],[-4.85540871889725,-6.56010318582095,-1.45240608252554],[-0.000358548288248883,0.491622746724499,-3.35613839019087],[1.74649798164895,6.11391618876055,7.62668710227608],[-5.71747446995519,3.55393128001594,-6.47394882588007],[-3.86737842205263,3.13187664516758,5.52967036883638],[-4.63594604708021,8.92651475058949,-6.93134479125905],[-6.59777707363542,3.26638267780091,-5.82498591724498],[1.31314076935408,-4.9672344986716,-5.15682814951954],[-1.09777994598494,0.992936728632852,-2.58832773340071],[-3.55347514935906,-5.36880697991757,-1.47023194718216],[2.14855583007276,6.59370053501454,7.03460111218115],[1.49064680359275,-1.30679671873802,-6.70480944574413],[-2.60404852220621,-3.06179359533,-7.17933401956116],[-4.45183300302549,-6.17900494385542,-10.1688344353264],[-6.775269942003,3.26322870106544,-4.58068464719676],[-1.58294157166051,-6.22565994978982,-1.65770425470166],[-1.47191258972619,-3.1097777598916,2.09374274845453],[3.46888601939614,-9.28908828309506,-0.623459858164256],[1.79735206486155,5.57156094156755,8.23447859978052],[3.1784834646322,-2.36646953044049,-6.83561312152487],[2.82005087103558,-4.11759246524082,10.8558472274021],[-1.4504393771676,-4.67484010109214,1.9487657222302],[-4.29366284800439,5.25341182468236,0.0681665179903883],[-2.87690081521977,11.2742831658759,3.20135882702511],[4.26202913278505,-1.9927668948477,-6.67436135152156],[-3.32126223124369,12.487961481241,4.36397898859061],[-8.46656996826088,-0.844974316274591,-4.5070011784296],[0.0953586208957199,-3.07190641946431,-10.4676182839028],[0.176603822212707,-2.54088831636539,1.91238554493558],[-3.46173746380311,4.26366268231162,-7.39026473115623],[10.1899399226854,3.08235131716639,-2.15989315024916],[-5.78755081563209,-2.98395581153111,-5.18546799888634],[0.411767128397044,0.822348931421848,3.73298902147084],[3.04883644714211,-4.02780264538177,9.74791507415115],[3.01089881322067,6.50548326744482,7.64596325999752],[0.739117674790497,-3.02713827996067,13.0261427097314],[2.13880934461777,-7.43475355949206,-10.6792693782107],[-8.83141311599823,-0.961468332448356,-4.59559009535864],[3.85794626396464,-6.02081826590165,-1.09948073839237],[-5.38166777675134,6.30690793451164,8.8059750517519],[-3.6184623155559,6.97909288032797,-0.241562963219154],[-4.2213330459306,2.82361273067875,4.61435642930852],[3.79592540850932,-7.99296672294894,-2.05257491243042],[0.761115590327771,-4.11560711685246,3.21663853634801],[2.27406110014047,10.8022621867646,-2.18125850001674],[-4.31069780436634,10.2672516111876,-5.70916997279255],[-8.18316127152927,-6.18292905804537,1.44125774641098],[-2.63696953286688,4.77465648807819,-7.72987415034685],[1.39844466187224,2.17938805806134,-2.20459159022877],[-4.7594417331619,8.21818873384298,-7.42051896500445],[2.58213734723105,10.8349441022456,-1.43509600320373],[3.49689072210618,6.33085708064407,8.82564283421604],[-3.84426005387326,1.56936389379165,2.34701229287784],[-1.69263327991878,3.03762295308046,-2.27427084139145],[-4.67317377602712,-5.89145529138612,8.02186307797553],[2.17536922707599,4.11106631058797,7.32202969545856],[0.69611517775771,0.409172316134675,3.39445999251511],[4.96584361074343,-2.75942356013892,-4.36145876852208],[1.05764432965509,-3.25756487836689,13.0169591533653],[-6.549920261788,8.62584041981374,-4.5576796746064],[-8.04420819896945,-6.91977515606552,1.72861948224972],[-0.23088928876159,2.11899155271701,-5.14008925842662],[3.6778664192762,-6.07915894478893,-0.924824429261302],[1.18745702456294,2.41537811607087,-3.2437425080622],[1.52560175994957,-9.77765938291368,1.13638137358657],[3.11486558432358,-9.43599490078072,-0.525431218732281],[3.21865092396108,-9.32382841088842,0.197533054927752],[-4.67590120068144,1.13270651367201,4.39478196380085],[-1.1976993793657,9.63226973436267,2.80657945513123],[-2.03293739287061,-2.19275748537604,-8.81895463408119],[-3.25878376777758,-4.71791662153562,-1.43009189835261],[1.80651569189617,5.59472239830058,7.08558155760106],[3.00834617856008,-5.76480374467922,-4.85484626771796],[9.98940588999667,-5.11016707091562,-5.13160455516272],[0.943274392164932,-8.44770281193928,2.76811262777783],[-2.70958539277847,-4.80963742016283,-8.64207106444528],[-0.876620624961013,-3.08498658873402,-1.20141151006225],[3.40284620822701,3.84480305388317,8.72719187799774],[4.05777341381278,11.3843460267685,-1.86238069345444],[-7.01537958490141,-6.87680783974974,1.05834575709855],[1.97898879353708,-7.67562416526289,-10.7853282116195],[9.05076425533656,-3.92133327884691,-1.87699131855364],[-0.0961002080948508,1.11683227878377,-5.69180751868182],[-1.10995427726512,-6.80362166607769,-1.24431884981412],[1.54782775527522,10.7296043557367,-2.02766909632359],[-9.2960097020406,-2.07758178997588,-3.90899855058283],[-3.54815765181447,0.419104384480955,3.09177855783217],[1.56435448774852,3.57481239034737,-6.02259964640021],[-5.03141475993916,7.85846235336627,8.99094910092194],[-2.07253616991288,3.83832667465055,-2.60809495366678],[-3.64992967355852,3.22751967925905,5.57076085759299],[-3.20858004928863,-4.1856786786598,-2.15607949037568],[-3.79665016411834,5.24254152160872,-1.63042811741538],[9.37037108695114,3.16699124791614,-2.06061279967635],[3.07794337611011,10.855876733443,-2.44414466203593],[4.07142930459104,4.45348706888065,8.55433062419692],[3.37210718004595,-8.1107312589513,-1.79108134716108],[11.8063214720894,0.881996817451888,-1.30174789479022],[-2.68901329560834,-2.85759639188422,-6.46661435866944],[3.23724189198151,-6.14091803734792,-0.832971113096966],[3.2304711591614,6.07690325106104,6.98978900643707],[4.43860890884682,5.96337702569996,8.64741628470004],[4.24106542132685,2.68464855549843,3.04064425468635],[0.228707932574459,4.27869244793435,-3.77866095521165],[1.41974798422085,-6.20715960746587,3.95649728684822],[-5.31537542935764,7.11797854514437,8.81499271682867],[0.725343293693794,-3.12830284448429,-0.705918159837654],[4.13964101887036,-0.684787593300323,-6.35030137803549],[1.05490256082589,-4.50348517763945,2.72284000699668],[-0.897030141063112,-5.91848082880153,1.18941600383494],[-4.25641599992127,7.5216499009981,9.006554805861],[-0.267713661144462,-5.27059320996916,2.54125352244128],[-2.2049021248282,-0.0774626200544912,-0.947266377407538],[4.32998469050495,-2.43364198972049,-6.75608179540102],[-4.49657016751724,-6.80263802245257,-2.4899266128502],[-2.93289742104668,-2.60314399094529,-1.03614521266424],[8.86554800326288,2.06026756104328,-1.7094692967162],[-4.89803601662321,1.81868703263707,3.17933383723161],[-4.50145758860983,0.144000295599854,3.59412795108638],[-8.71439266558147,-6.76944402042048,0.33931561201437],[0.215881478460511,-8.22098306125788,1.91440812098032],[2.68809322612481,-9.64253409469044,1.52928025704539],[1.80536925852158,0.617342482128881,3.00532127621085],[-4.60216190788932,8.8069358057306,-7.69664782046603],[2.55025618578441,-9.45203843500532,2.34556921903076],[2.99497152140599,4.59284217383882,8.27216649044665],[-4.90192285357416,-6.26576005113741,-2.63828791517827],[1.69259926657126,11.0440202868125,-2.76942294948137],[-0.777967220502504,1.27465342979546,-2.55670627871164],[3.05117451085991,6.55935422499074,7.45379736076555],[-6.25643801496443,-3.78981909536296,-4.25373952612184],[0.967387172245479,-3.40110032253455,10.503816912841],[-6.53878211870389,3.5232986434362,-5.32306208597569],[1.70665153322571,-0.454317942598221,-9.74050548523664],[2.67881278243596,4.74840444847817,8.21456717262584],[2.4719841217037,-3.25107423860865,-3.60372954796941],[1.83726126291195,3.42222755753539,0.140283211894864],[0.605129237528064,-6.21713998503894,2.81881517943347],[-2.86812174245345,-4.54028933464205,-8.68476387443919],[2.0241119281441,-7.46848090094436,-0.280706363528314],[0.983337520253725,-9.55038559182091,1.87072300113567],[-0.279376691866997,-7.19136626642529,1.12141563327629],[2.11424021636373,5.50718171077646,7.50239823541541],[-3.62908840333078,-5.01058524100755,-1.38385680514611],[-2.42206007825595,-0.0121489381627297,-1.58325995196331],[-2.90813594677009,-2.00457940678963,-4.54799752296079],[1.20650945666994,-8.61226347011386,-0.0202328746730087],[2.63035860504635,-10.1878024484644,0.292381649703193],[2.13790163739223,-3.8283282216918,10.7895642082617],[2.34191590259845,5.87003895241906,-11.3962626499344],[3.78369436680362,6.56901414375594,7.29105758291973],[-3.95105443467127,6.09372949859482,0.209592673829914],[0.841805791055001,-9.39583735803955,1.54764572700216],[-2.61811080071222,-3.23613788153304,-7.70311033785882],[-6.19532314106771,10.9384213492761,-4.36019602950941],[0.95333782717223,-3.50582203117838,12.338933374513],[-2.3832169296758,4.94462710241556,-7.50381683408186],[1.47128331708592,-2.86686678150682,-7.92690009892605],[-8.76446781200065,-6.08415012831803,0.55938737973083],[-4.68212857351327,-6.5610334492435,-2.98587936752019],[3.19913483659242,-2.9849768800427,11.6494648744775],[5.01424940647629,-1.41812457681829,-6.67279709376733],[11.3626032697011,3.70640346952031,-1.77906955879687],[0.863103995918084,0.131871216384124,2.94490749743593],[0.188008982416776,-4.84699737626145,3.59653885705955],[-4.19198084342395,5.94429224566251,8.44707234097875],[-4.32090361501821,10.1040411556522,-5.21016373267237],[-0.0785924507323335,-8.49247072692865,0.639979062167336],[3.14486015317371,5.44226974408168,7.7541495283314],[2.49803768294247,6.67562389372764,8.72660317089544],[1.9497879370119,-6.83804713179087,-10.4574253602617],[-3.70193042627771,0.854044202609113,5.22164007389913],[1.98820723337528,-9.72381147470758,-0.809301070317231],[-4.48379719410662,7.00143160927672,9.08853120894989],[-3.401206649881,0.127421157893451,1.91140249241671],[-2.45891056668615,-3.49714398195176,-9.26031516055729],[1.04209181236237,2.68051896274223,-3.40927169462584],[2.04981327846842,5.79063294151536,-12.2828061981002],[-6.89303062177781,-5.85717932109809,7.15651942916775],[-4.84730138951736,6.05148469440683,8.93550390478149],[3.99384178939437,-6.09031582372581,-1.23798527589201],[-0.319692789280777,-5.36886677878994,-3.05641410954187],[-5.59148962990104,0.0494064900821699,-1.54800174485681],[-3.60037579439523,-4.5848885180691,-1.20933345629466],[-2.98558220585143,12.3045660686388,4.10736279175899],[-2.98902393865804,3.8981134976853,-6.95746379619165],[-4.81117424751146,-3.76835234316847,-1.80218032070924],[-0.0199662703029567,-2.21826063344181,1.56364447653595],[5.00018967949188,-2.5601384457079,-3.49308481767505],[8.49597378359315,2.41000175277245,-1.9813476659883],[-4.82631106792937,6.66115871563297,8.60932765696089],[1.91991069094267,-3.01403110801458,12.9268512049863],[-5.3997568588196,-5.55759841646968,-2.06028673058182],[4.28029958722936,5.12719731182298,8.76861496660961],[2.49348756814849,6.39132581969381,8.15654226251349],[1.62316720586633,-3.53802257422783,12.879401178665],[0.977983281246845,-4.41898228611937,11.3671646234038],[-8.83984976053259,-5.95623921073849,0.99507353765027],[6.97307443707817,4.69458078342513,-0.445850848380974],[4.37828672218586,5.19183475927181,8.35689802800209],[-9.57879615147746,-1.61725712307973,-4.09804611325146],[3.84063378858855,11.0931355982882,-0.529791523284798],[-2.40667433356639,-0.619424305474608,-5.48559674338058],[4.31537533481587,-6.36717196750786,-1.7187064955226],[-4.25029109172415,0.265987768285317,4.98974651948655],[-5.33569988221397,-6.59632038813601,-9.68576713819865],[7.63907598752311,-1.79413037326487,-10.571634449521],[0.0740564789383396,4.47202630483358,-2.71485164504514],[-0.385490589030734,0.447930978711693,-2.78264402114382],[-8.41675239803413,-6.31752339974566,0.586576601840135],[4.56748551142911,-5.28938073807574,-2.28099604389161],[-9.05368973125376,0.0683113288039994,-5.49877383345871],[8.14084208065727,6.05688481990609,2.14212155499023],[1.88749154592995,1.54290453983087,-10.125000282678],[-3.61032704543546,-2.28006274873773,4.05954876709378],[0.68313456023665,-3.68906587184951,8.57695688237483],[-1.93988265337804,-0.300428363521722,-4.91253317225432],[2.57037125052752,-9.55908427890609,-2.15413318925938],[1.4688232886956,-2.37976612989985,11.0011281653075],[-3.30607662680439,5.79017291300548,-2.41555310142751],[1.56806770900315,6.31406182933066,9.25805427828387],[-3.83501109297005,3.72872521896692,5.84016612509724],[2.76098965310206,-6.80189356308149,3.95593174176474],[-6.00650246627385,7.196067919521,8.56110724573886],[1.77691010978754,1.32008618131994,-9.1843897826216],[8.60217599211341,4.38172449722696,-1.66547755871361],[-5.02145759546403,0.052387445252941,4.71465871679732],[-4.00937019252269,-4.73788196874706,7.44446515701963],[1.93758818280049,-3.61547700083562,12.4385064981029],[3.20657913687412,-4.41871133078747,-1.35397697024959],[-1.00866068892666,9.52777777333869,2.4206621105568],[2.22893040778308,-4.83215990670608,1.94022761391929],[8.32373640766398,4.57067193452219,-1.18139741526076],[-5.70425359393593,6.99946479608567,8.52817110841228],[-8.43786583665466,-0.671840988800152,-4.4962066027687],[0.0204620180945608,5.96430307981319,8.78899848176623],[0.813243066215689,-8.46533676215379,2.66900928357573],[-5.91663740970671,1.19697996860188,4.37102000152425],[-5.36254929436172,7.7301311160217,8.49495930870226],[7.2719183689316,4.76026617665578,-0.99300272748789],[-0.105357146402104,-8.90309166194936,0.733341509232168],[-3.76225684438053,-2.36030788127594,-1.64187463760274],[1.96750458411353,-2.58676728701403,10.2692696102746],[1.78193191822811,-9.88073682403195,0.906853456137266],[-5.12000348894998,-4.4039116296481,-1.73558677870064],[9.36485430700407,-3.94532152599238,-5.26766295552917],[-5.11659072975865,6.6403527911444,9.00008406645618],[1.46369415112401,3.18001760345616,-5.93723376682589],[-4.93023318292019,6.07892309270594,8.59898583898719],[0.413586522279252,-5.65212190654064,2.51226706107835],[-4.04011597176045,0.721740341194147,3.67906584635705],[-3.34946854960444,0.563132911971029,4.24786427478043],[-3.25374993638057,0.831715780624918,1.89516465913791],[-2.61681368063715,4.73694056953386,-6.65255620938794],[1.79960098952723,6.25789753335033,7.54470026138571],[7.83922710347159,4.49509356250555,-0.364756771096932],[3.54089118794018,-4.49921330690963,-1.44726744958239],[1.25734832445568,3.42999051020537,-3.72645137383582],[-3.3167993396857,1.01855604534011,3.66995797502493],[0.10522171235882,-1.33755161669599,-13.5216498976894],[-2.57742282728682,4.67797818536884,-2.74250386276974],[-7.07459205982426,2.96898667364163,-5.19762373576524],[1.51022210925554,-4.64063144606561,-0.433604700844234],[-1.70651757618206,-0.202741054156511,-4.78672824466649],[-4.11410175426564,1.79114254924228,4.73009911623899],[1.83788671272305,-5.42678538102819,2.75856401721598],[0.919617042093508,-2.44654414615009,12.3678683824931],[-0.115355093050924,0.67704479630908,2.91488832215341],[11.0917866189564,-0.218120870394025,0.385331786478896],[2.0288463880079,-5.93543390153175,-1.21884745573831],[8.67156326028914,7.1223826805934,1.14952571042906],[0.2204553067423,6.11271419596073,8.95696711625797],[2.13005882979566,-1.69458563716409,-7.79341658736875],[-2.51435806462091,-5.16808437613939,-8.56256086146853],[-1.96745481234505,5.45852262365607,-3.24823330576952],[1.41145934371204,-7.12793807771393,4.0299103257829],[-1.81450275787605,-4.9228790388012,1.79756414810304],[-4.90954028724376,0.838740808015203,4.13700934976801],[3.33520560918449,-10.0436201245939,-0.461396356424491],[3.06049445600458,4.23885145830508,8.6354086972959],[-4.07833330051967,-0.875422305225457,2.59693694371491],[-2.19347707497265,6.66104210518617,-0.085740078990712],[-4.39026101554888,7.32359094599151,9.02629293684031],[-3.95724009142605,0.531289290449681,5.09637261685672],[0.646029068078557,-8.39128484846775,0.76740367354248],[-4.76808597191635,-5.82551001125515,-1.63692309540679],[2.91628753790494,-7.75233582523142,-10.1320012255114],[1.68065837346224,-10.4667665346704,-0.174310610859351],[-4.74116259560579,7.32473992961143,9.59622486330207],[1.97334501914791,-5.34237279255932,-6.25476760939764],[1.98751305777471,-6.96439683237268,-1.67921047409619],[2.96686805042622,10.2238931357426,-2.30875188642282],[-5.21675664510975,3.53993460062495,-6.66591845468001],[2.17973189400774,11.0599746529001,-1.606035477078],[-0.924819951080185,6.27156729927713,8.72333056037727],[7.52142756430621,3.78588049775391,-1.14159882807113],[-4.94618071140206,1.48530495825246,2.37253182500741],[10.7777541447338,4.66056444797605,-2.24195375189558],[2.98869019781513,-7.9313204100197,-2.06375832788579],[-5.36469795645787,6.69056502447881,8.82162960705357],[1.06129722357914,-5.86450457647515,4.43598104905191],[8.09668911312297,5.72447980225708,2.64853677007855],[9.61757842064858,-3.8838495580765,-5.23686707150979],[-6.65820523476157,-5.61724744823764,7.43588256087249],[-2.01530726741839,-2.06146322501902,-3.73028740094524],[0.767221952468111,2.11493530595325,-2.97374535177205],[2.748797129042,6.86858418048989,8.42114348093363],[2.31542351712115,-5.7796936408338,4.49534699332449],[0.844174846843909,0.492441076513775,3.16751559317918],[4.39742192642809,-1.56709185845069,-3.15027559582455],[-4.84479855029729,8.22042859880895,-6.79394760018351],[1.28233069703739,3.53608260033215,-7.550215986136],[1.46863080001678,-6.12523208400405,-0.183023709780222],[-2.15506279201368,-2.79426178370435,-3.18474573605253],[-6.96265370571685,2.84476649113027,-5.87365630332396],[7.05879062519911,4.05649089998955,0.434079029447005],[-3.74621880619834,7.56438343930364,8.2010224716995],[1.14968297628386,-6.93412751043086,2.90320850848293],[2.70021268803244,6.18240961779499,-11.9270578827096],[1.51526980334967,12.5432944923377,-2.39990396666333],[2.29626555443678,2.69340409284735,2.30112265275326],[3.63935773212365,4.41820273965343,7.95169455090612],[1.93187232855316,4.59444806456612,9.07037452296749],[2.31504106527969,6.17793989774047,-11.0556744196222],[-0.622490276487519,-6.71595475104984,1.76902889979127],[1.14554989547189,-2.12333038498522,-7.87085856612196],[-2.39437166497634,-4.92696827486027,-0.520196637054855],[-4.75898901240326,-0.918332720761922,2.66108070457987],[3.48495070731537,5.6002255629573,7.94207126492085],[2.06141098613805,0.493981474688808,3.26547813369874],[-5.19831828780432,6.34338183272265,8.20322289013269],[0.0278169174502709,-9.09335958283225,1.46537891269185],[-9.7704738264199,0.637690322695292,-6.18664249965316],[-4.67904086565061,5.80960027471655,-0.316473575479422],[3.83908161832989,-6.93870680179346,-1.99532668259267],[-2.09253412789815,4.82240933258201,-7.23186705631637],[3.25736655551906,-0.691436398075872,-12.4255065746683],[-2.20477027250865,-2.76431522261443,9.55878868005737],[-3.87354618043806,0.782075203589111,3.29351221248241],[-3.91827440949008,-4.26467398950697,-3.09664920446628],[-8.03115390917436,-0.433249994667779,-7.76777247328281],[-2.38361128488825,10.7380003081924,3.44094124189438],[-6.81057639578371,-6.03677213409675,7.10055305317548],[-4.50475148953738,6.4893240856768,8.82654640054887],[0.752465407779142,-4.93437689767633,4.06886007534021],[2.80908068424867,6.01029918694764,7.93661612561332],[1.26171473502147,-2.80108964621481,12.4347560460616],[3.7573030731037,4.17091746425566,8.83678598893067],[-5.22538453545329,-1.6196553133971,0.900770670079032],[3.88298202402579,11.509974505675,-2.22242568395929],[-2.83775247522127,0.253457001138144,4.83256006469298],[0.925604857249897,-6.11531967732909,4.85258282967314],[-3.3476530690262,0.475478382497415,4.37847633836955],[-3.91443413668337,-6.03817211897137,7.47769885271754],[7.51696287537795,-1.48219238852222,-10.8597317726077],[1.50763124539711,-6.13873486605878,3.81135544145173],[-5.32747890290403,-6.20661531102791,-2.01682358923358],[2.10031269935661,6.44096311511442,9.49072538605377],[-5.3301359865335,-2.77863441559384,-9.09960001634578],[-4.13039236851464,-4.04988134225172,-1.18667070114739],[-4.41009786067201,7.66535456825229,-5.58767596717716],[1.33475788383478,-3.12649425136194,12.7251641595726],[-4.03761344527646,5.28914374635162,-1.97166997339644],[4.25469016868105,5.95059780925241,2.49011997565067],[4.61032326249801,5.4296538734887,8.82549536333414],[1.84512567016286,1.46896379676474,-5.00732395747582],[0.352625146845175,0.371297004055526,-2.78520708554385],[-5.85195543578404,-6.40029856167436,-1.68142621965124],[-4.32703276648893,1.7754218213053,2.25264469933179],[3.11370247766389,-8.93195011872634,-0.213462175516715],[3.06061752325001,-5.77331007002141,-1.13165722728536],[2.25333827968756,0.276698697030097,4.03889078109364],[-1.1405407528369,1.45519946397998,-2.30084715694579],[1.8966899901369,3.96227407791098,-5.93179199947039],[1.62666897417153,-9.6953655827157,2.4127839558642],[3.40493117916878,-1.29866014249734,-4.23452225709608],[-0.199361012409922,0.0652836078230078,3.46898807496416],[1.63423407255485,6.29253288839672,9.36741094257875],[5.21307512309092,-2.59466434118534,-3.53166328597818],[1.95745218855536,-3.94384338579326,12.1270798616623],[-2.60490293231761,-2.81433611089208,-6.17680969119389],[2.43308728384367,-10.3914095879429,-0.864788383001312],[-0.300692250259257,-2.53403324565069,11.4790432018735],[2.87492324203179,4.41527123775154,8.09879806355175],[-2.72198435365635,-2.25148519328346,9.01960464474021],[-2.80535461317646,-1.92995211927582,-5.65044339471926],[-4.86827901831876,-5.91002861601454,7.85356287780416],[-1.29748309181778,4.58936503077337,-3.39181419249705],[1.63314821987159,-0.466947780575784,-9.67824806532845],[-1.41494577815078,2.92426325335827,-2.0500821912766],[3.81401361255251,-3.43090886453244,-4.34086729597688],[-5.48812526707486,-3.81146159478233,-4.43448317811286],[-8.55591410623925,-5.45572486382806,0.730058348285607],[-3.37601963003448,7.66930152651465,8.68647879140136],[-2.75491820453966,4.42949921127422,-6.85014662709473],[-8.96093203788448,-0.966224064319921,-4.04177349265095],[-3.83142682965639,-1.78810466436594,3.77026631360469],[0.504261074701512,-5.99811082295263,4.55094052171114],[1.53566157642096,-7.23696410935014,3.38806559528094],[2.48742771963786,-9.01905665373665,0.755567251806159],[3.14589993294155,-9.98515729143284,0.154232015252571],[3.2808753000624,5.48589828817307,6.88748047525536],[2.05408671377181,4.11344580509243,-5.8956110133333],[10.9692982160718,-0.303148164753665,0.454547726697399],[0.915457553189194,3.09035358353906,-7.74335616088844],[2.99111622799599,-10.3845536846249,-0.714637382552964],[1.08971597345765,3.71796473273845,-6.12958267100867],[-5.62832111472066,-0.58543179661675,-1.6028492701447],[-4.98337257389458,8.29238965639657,7.92891963512297],[1.65810702321103,-7.76211734976102,0.0750803508807863],[3.3259251217487,11.1483429106626,-0.733684373902556],[0.269826846726615,-8.6854725382995,0.187584120018748],[1.87703087448662,-4.40967464626979,-0.173482234225869],[4.4255036529744,-5.2420705614937,-1.90676216862844],[8.11265784233172,1.94960568273661,-2.0909506522243],[-1.56815839125465,2.7916568557852,-1.61252922616216],[-3.78129303871312,6.92135325352345,-1.17742505467991],[7.92747044761098,-3.83546250158583,-3.40253493767641],[-4.72400726630382,8.40490755116415,-6.77377203464353],[1.46953538719335,-5.39167013159241,3.80700952954241],[9.20528288957263,-4.44674758872127,-5.98906933157956],[1.19756081245027,1.92586263392027,-3.37275914769477],[1.69652081550328,3.99316527247305,-4.4370901332377],[3.1859308034509,4.41920657175916,9.05303424617735],[-3.30255381517921,-3.58212499035355,-3.11585024474168],[1.53892787150287,1.54269241301382,-5.33906388819952],[-0.0822623165042662,1.01980938079605,-5.38522553507286],[-8.45172287382704,-6.12824058012444,0.288935065412449],[0.680248303041909,-8.11382317306142,1.12013131589933],[1.39228992020617,-4.18309721732791,12.5427420328464],[-5.77005706319156,6.63265556238003,8.79665464156568],[-1.55497853957609,-2.50190255991732,-12.065174496969],[4.24042207413593,10.5599643795119,-0.904729165836785],[1.32501008848124,0.416311710731485,3.93580289332169],[-4.84508740256846,-0.628341246137283,4.56968285156539],[-3.99297212305157,6.8507622340439,0.0770427887480094],[-5.78426370301666,-6.30098199553616,-0.889974898495751],[-4.88701350245296,8.26669410280771,-5.7307590812177],[-4.8594261968527,8.75293008899258,-7.81399519169592],[-1.03756824875746,6.08022323931181,8.73743494710273],[-2.44001812087566,-0.727555574212404,-5.44252169309913],[-5.13385239163952,-0.727426181044535,0.922979526387111],[-4.36397732190741,-0.0622187536325606,0.790503672096794],[7.90845618242832,5.76820444313877,-0.731813176080674],[-3.16141781989153,-0.714579506122324,3.31159301380656],[2.56930233617147,6.168272891408,8.03353216057987],[-5.69050416847628,6.8832561185958,8.87907941903556],[3.2652777675666,6.26627123076425,6.64336201647104],[4.86849088392554,-1.47851897362134,-6.6613032630619],[2.79542464405765,11.8226410144217,-3.04253294826582],[2.65760284727658,-3.68751535239508,-11.0600185148068],[-3.44911893904803,-0.303768774089609,1.70745139042304],[1.97074942882041,4.20738078940626,-4.66428534895593],[3.24277114998193,-4.67612092489437,-1.13656426063743],[-3.15525014319643,7.12451711762583,-0.208465207704787],[2.96316676835431,6.69737181038414,7.82520284834148],[-3.84768955515216,7.51173106676368,8.38359374288157],[2.71498679503435,-2.75186721739784,9.34043721256299],[-4.42738369990434,-6.7308080755861,-2.38035740275224],[-1.73329005211809,7.42545897078014,-7.12429145269751],[7.75972494818372,2.86234141557236,-1.48416932478744],[-0.227832890588496,-5.65667955107887,1.73917196780193],[0.137903719706942,8.75160235357434,-7.76015467954254],[6.73773638631751,4.35150866840623,-0.428587836693121],[2.06303325956455,4.88265419405466,8.88797402171847],[3.00361532490821,12.3262644337998,-1.46320018107411],[10.5194731185584,4.63017653136461,-1.89352766372172],[-4.44284808920805,6.54991880861932,8.485601581913],[2.20663405719943,-9.92395003485643,-0.254646015594321],[1.14571162060698,-9.514364358731,1.06028979278028],[2.61989162685181,6.01822559808108,7.03034144655971],[-3.35604177017942,-1.45728781671954,-8.24574656337186],[2.09807943998382,11.4227219661199,-2.24549541343372],[0.417513469642526,-8.87215041943943,2.02959553856715],[-4.11251300441208,2.1996116130399,4.69245083970941],[0.01533178985886,-4.9408084999291,-1.26378976637207],[-5.53011366697541,-6.06743469661899,-1.70364446155283],[1.07188593361333,0.620527853332667,2.94885053801474],[-2.20010798000944,-2.93281133500398,-0.575870293461575],[3.48069381231845,3.81708381300323,1.02785941373262],[0.0800302336689486,-6.91425567128216,-5.9979794155719],[0.701576415542526,-5.79761839533259,2.37210288377281],[-6.32721359605986,-1.87051078701088,3.60478109094388],[1.7419646637419,1.1031674396254,-6.34853229246329],[0.467348527484197,-5.30159217357477,2.37819622704731],[4.66925788033485,-1.12652577797648,-2.82543144840693],[2.75210403031135,6.39108578131797,8.21748993645056],[-3.24301303994491,-0.599801291906899,2.99238091869831],[1.46959320558308,5.98251857598296,8.23296279395502],[2.06379479511501,-5.46662484707161,2.28287931196703],[0.775187038188147,-6.94414530561267,3.8536938228374],[1.93210658365859,0.436588484797932,3.61391454862113],[4.00888504390534,5.42709027242883,7.37067533506685],[-5.01790394609086,1.03671305664299,5.16965723771675],[-6.57143030463599,2.91180847111876,-6.10407430714441],[-0.154145448884184,0.990681486358847,-7.6602264098667],[9.03208496546863,-3.5805913483198,-5.07753961622645],[1.9622313237178,-5.89418680003339,3.52898130724311],[2.26708010837076,-8.55259030278085,1.64151855129298],[-9.5123440832807,-0.297902839985562,-4.91291054750066],[-4.04747818890866,-3.65389452452188,-11.0802798853211],[-0.369358719704996,0.692539887817063,-7.73426149414273],[3.87030499710127,-8.00559841376304,-0.895735435146754],[2.01054625121112,-3.60517187459169,11.331219845426],[-1.94353390580782,-0.0700098353444745,-4.21675506118707],[-0.981554291978733,4.72238333614346,-1.30447350740515],[0.226223279322417,-7.77313547501088,1.79730408724506],[-3.46749298456838,-0.685196422655678,3.70910523034379],[1.43508136303335,-4.21124519266626,12.5180116886006],[-5.24354219450494,0.919243872651127,5.24449948368519],[-5.35726919090313,-4.51104117082296,-3.54758979139412],[2.58660875613132,4.42059598744594,8.29401096074935],[9.17398366397291,3.9957708480434,-1.8234198532146],[0.154500394228969,-0.720482662687645,-13.2496450666527],[-2.21613064156782,6.18549394770718,-0.275710382792642],[8.21721202794003,4.27575420514389,-2.11352280561784],[0.586512416736843,0.355252573687146,-2.24373893332143],[-4.45158756671356,4.76697163573246,0.22909082360599],[-5.85709346753738,-3.31228510128619,-4.82887984782491],[4.2560342887401,5.77773345854136,8.63966249447816],[-0.0753188989076726,-7.37422842392548,1.05534656302241],[-1.9213112344098,5.63493364785596,-2.37229748660814],[-4.14203227252895,7.92762851667069,7.84877064975093],[7.72942549391983,-1.71465200314448,-10.7304723546433],[-4.42136414884961,0.81013677349923,5.47300478070595],[3.07148214649811,6.22236406461699,6.81011775178964],[-8.29307184696565,-6.41861942058094,0.88036435306063],[7.75273209823409,2.32645378835441,-1.98496032572895],[0.87830558744461,-8.52939469663596,1.9210423165445],[-5.41619165287316,7.92899400984342,7.96362726927039],[1.67767649737583,6.2425895572208,8.03677408502917],[1.11224010073692,-8.28723598411025,2.59343907883541],[-9.47798090620999,1.28419747352226,-6.36860800309228],[7.01308901425357,2.82892468162255,-1.33121473448992],[1.59257782102261,-10.0736736339688,0.251671663042086],[-6.36552144684154,8.30799771577206,8.19892297656171],[3.72134416614526,3.5041532057627,0.427902300738554],[-7.84845641985335,-6.80356141178865,1.72059322036472],[-2.40822701482651,-0.590731169885203,-3.73026015361192],[-1.81781649929473,-5.50432101896311,-2.35121207223887],[1.49228880291423,-5.29850472556119,10.8960091445574],[9.41695867776967,-4.54640701613735,-5.90660519295064],[0.0747344718158658,-2.85775204809411,-0.732457636238663],[-0.0205380508557768,-8.58402569299338,0.40777237476214],[2.68292596077327,4.40588065922953,8.24189190368361],[-5.57087166695294,-5.12158387912314,-3.27129617909399],[1.43902339347432,-5.40754800362738,-5.96358597769702],[1.83778706890958,-9.80003994016993,0.440830551292457],[1.25128061679681,-8.62745863657938,2.70885592663614],[2.48495779066582,-10.1842997330337,-0.184001588315086],[-2.75614636844805,0.240086291474363,2.80808138222786],[0.301692530837971,-5.37715110721105,3.93017115560191],[7.47020913189618,4.51511371378929,-0.550096006312077],[-3.0643511729012,-3.04290885725601,-1.09729335391634],[-4.58122550945098,-6.49676641469229,-2.95041561720349],[-4.82250184139742,1.41757774471599,3.76406909324635],[-2.21514764592308,-3.43826478769768,-0.360066126630292],[-3.16054827085674,4.92087448737957,-6.84733069057464],[-2.24365152129317,-4.37063926833369,0.360244314962258],[0.932133983080471,6.01591424154267,9.02249235948505],[-4.91773721507165,-0.049716317629998,-1.85223607531485],[0.815842727431723,-3.73165334898489,11.9827879921088],[-5.34210294289076,7.8327198836428,8.53466094764373],[0.673460437886162,0.475404804310726,-0.717183395334781],[3.14530190104957,6.17309312946518,8.64020988757561],[-3.46597513100023,4.73252483082402,-2.1476584336622],[-0.979403639149499,1.48109198371252,-2.28293117548786],[-0.157547752038262,-7.44287882336936,0.12619605896922],[10.6195147525783,6.12909839250362,-1.11665914419111],[-1.68246301696481,1.87738687504379,-1.51377764853539],[-3.17650903194444,4.58406571120835,-7.19637390892998],[-0.0821531960662943,-2.43506943353567,-1.20390913757069],[-3.2516599992717,5.50024781462495,-2.75676308939747],[1.99720275075627,-7.42103804053072,-10.0161206272642],[-2.34264199684167,-0.137238551872354,-0.184711169383665],[8.77727273433375,-3.95914449884514,-1.47625121803512],[-1.55557869710676,4.2646658662223,-4.35130674742997],[2.36528434790753,6.04828739055563,7.48995496883708],[-0.192544277826815,-9.12759609768218,1.1253265011506],[8.95524827102367,-3.64601163716763,-1.84909229114383],[1.69907384929791,6.53185277869235,7.48900389032401],[-2.29998615730218,4.96072515007041,-1.01639161381551],[1.4414189320675,-6.12633120445646,4.78450180931888],[1.53490145557707,-3.5363678560225,12.8693165819662],[-5.28003772810683,6.0077237678107,8.54850615944498],[-5.79194989085447,7.29430514929722,8.95889180558756],[-0.045812796947809,-2.74774715391879,-9.901864077101],[3.01073287995402,6.12026006240781,8.8686502190334],[2.68886503288071,4.10030201246065,8.62913667547605],[0.997742224707978,5.56475474542462,8.23906957985767],[-5.1939360305286,9.61945923282819,-7.51975540926847],[-4.72038411426122,-6.26061644155077,-2.53621840681045],[-6.03834244719218,3.82026274237674,-4.78067339687986],[3.72924870196308,10.6358324806746,-2.21760652111013],[1.73232428554068,5.92981585648781,8.83741454565468],[-9.28417640511201,-0.295511400873795,-5.47759653927347],[-8.2587206022761,-5.64576332064097,0.431860432144977],[-3.62358156359979,1.38565382235175,3.81093471417244],[1.84979424286119,0.907890669211545,3.56745205292872],[2.90298145892119,-9.84478978507205,-0.11102328636371],[3.03542306173949,4.98948483896614,8.76952781049587],[-5.28824080575704,2.09984812015176,3.28310355116739],[-4.65589296286693,-0.332710137813903,2.58046561774323],[2.97669812949927,5.99566691844459,-11.7682758160693],[-4.85633526084644,-2.20883793461712,3.98790735049293],[2.01037018694163,6.42029541090576,8.12045980978623],[2.35905256311341,-9.32943706211991,1.30319241139996],[2.26247300965088,-9.6206756894409,0.718094344325962],[3.32925418001245,6.30231799022468,7.18657459992907],[1.03651524597201,-8.35052341732169,0.898688084684746],[-3.85351796331378,-2.19953119991965,3.94141884689924],[0.580432531966034,-5.03117790482156,4.01389138019116],[0.107447316746434,-1.59437719816489,-13.2140379173601],[-6.05266814026516,-2.76974395420251,-5.36049296127626],[1.532670448847,12.1900745709504,-2.16491114181268],[-5.06651264180209,-6.33729221483554,-10.0891751415325],[-9.51911058938189,0.456292179254667,-6.416228259144],[-2.6694673880181,4.63647422114726,-7.19627475633567],[0.939048535339709,-3.92898208218899,-1.58505138566339],[0.527139107366155,-7.68359038867175,2.05200714918873],[-0.834663897593475,4.33988623421825,0.218536202566515],[1.13194604779169,-2.73962159243968,-7.84546724857234],[-5.39328466461179,1.51569094522855,5.09756195230234],[8.63132273628846,-4.31267330232072,-1.24067285746607],[-2.8762851574414,-2.41317860209662,-4.84110346239992],[2.65930723859611,11.7394035698234,-2.64569911204912],[-2.85446882653178,-3.0924067743972,-7.3738497636123],[2.54042657801705,10.9029322045229,-2.07694464971089],[-0.0771742790354208,3.07141876472892,-7.99012003430079],[-3.10032845044941,1.02150457099297,-1.46549699906461],[3.97512956173561,5.50144587249053,7.9734441037108],[3.51268352052107,5.94664845732177,8.48195743751774],[1.48244017895504,3.47223492437718,-3.69138305653874],[3.79811363954919,-0.429091187664207,-2.44887573422602],[-4.38630653792541,6.89533402443251,-5.23426270896257],[1.67308397133152,-9.65487316702454,1.7027099674922],[-8.64228423338269,-1.46259702216806,-4.27906228296006],[7.42282407335607,4.0961916813403,-0.3130898634028],[-9.19197451724166,-1.83384173808193,-3.23469215930261],[2.05210599885745,-2.92518522452785,10.4019524033296],[2.168555816955,-5.55616872975482,2.58213626955604],[-4.22671372087156,6.12435730835308,8.74059360830282],[3.19360926998882,2.70839500295549,2.97067696015472],[3.66082909795753,-8.81205395569035,0.178904310765493],[-4.35248805380495,5.73410995291951,0.0483028338686216],[2.16819514488019,-4.93026249773538,1.50237406591936],[2.25772034578525,-3.03702451931482,-4.58526425951432],[1.12624330112749,-7.6818674670067,2.07850968761045],[-1.8676586531675,-0.566559556078591,-4.633397612897],[-8.33977560834468,-6.79594831152272,0.123251855036598],[3.09434623771757,-8.7518247107184,-1.76601687426606],[3.20658630307709,11.4295707472743,-1.91896089051966],[2.02164922782088,6.77919183093605,7.72854664441571],[3.38496158808617,11.9114113826537,-1.18689303842965],[-5.28427500814503,-4.33519610651804,-1.87966663395933],[-3.58094155363359,-5.03352770784863,-1.2400321203796],[2.36065130695828,-3.23793594598068,-7.6050910854808],[8.63064290555023,-3.78773210382922,-1.24835806042362],[-7.95473209933649,-6.28305238997337,-0.0303497561810809],[3.98562372603728,5.86951874028781,7.98713883702807],[-4.10054413135578,1.05938862886527,2.51183123956113],[-3.85441585674622,6.51592434608617,8.85855551928082],[-2.24630428159976,11.2149631516752,3.24001414427179],[-7.30861010367317,-5.80591138359759,7.20962569070762],[1.94046289948972,-8.83560614481433,1.61567073307408],[2.74127365702389,5.8607697977459,-12.1747686426041],[3.39338577948248,-8.78978983848351,-0.396833771122748],[-0.428816564884302,-0.534675898652625,-8.25393218793096],[2.59737008948954,-10.0587123201457,-1.35957934024791],[1.57497043847781,-8.28610198138871,1.68746031169029],[0.928029898517558,-5.89166504841758,4.1348090836414],[2.19862367617151,-9.14021974133042,0.0653472106738754],[10.9554144673681,-0.724408914529699,1.23189937893841],[-5.09579435730859,0.306497328279184,-1.6086541696707],[-2.16891319320016,-0.609300660240697,0.109032655197231],[-4.10826958037772,1.34349531930179,4.41887503410276],[1.96035072293488,-3.37424844101271,11.0439434950398],[-6.79892512919581,3.03411191118478,-5.89859286146346],[1.18499249141242,-6.54710627378287,0.11305725042563],[-6.27022854638081,-2.59396199708432,-4.78932606979215],[-8.90180125453937,-0.940687840179394,-5.22066663377925],[-4.50309913895459,-5.98678726177693,-9.57286849986089],[-3.25042978388627,-3.77156999731208,-3.3089311909473],[1.85821789872231,6.18631975098947,-11.1910237070373],[-3.88373480848173,1.32239679490832,2.71673036561655],[2.32247258473094,-3.26345677555897,-11.2109636885992],[1.47833290328915,-4.30181372040576,0.224279055982268],[11.8256237198755,0.785205016914923,-0.858685626672609],[1.78477261373423,-4.90221193953147,2.29594802288048],[0.317431293692412,0.602188684608521,-0.366742398051757],[-4.1987227030041,-6.26348788071809,7.98454946883039],[4.09888023871223,5.75908378334479,8.70848356579367],[-1.68592767986592,-6.94116245919115,-0.964562040208884],[-2.45246073925331,5.3071357063416,-6.80970901465099],[2.28054586563298,2.62133524605404,1.001593594009],[-2.33334388269319,-0.564938413636659,-3.9058351496295],[2.27966339028043,6.20379858042869,6.83329281605136],[-6.11206780184237,-3.06178522284765,-5.082439841737],[-7.87804288493216,-0.277834565207292,-4.98412319115353],[-3.50059702707858,3.98236809923891,-7.05075236598332],[-0.490751944596235,-4.08490626209883,-0.962333079663541],[-4.3850893964864,3.74255667615155,-6.66128293697597],[-0.384448637677366,-2.54597193713296,10.54147031674],[-1.77568103801594,0.260155239507006,4.24407014623088],[0.188701450303509,0.455839195203196,-2.83326879832629],[-2.08806782137802,5.56835476900194,-3.16457750338987],[2.64520377022133,6.67719113975947,6.73058182881792],[0.980241294165366,-4.62208016057706,-2.37383462648418],[2.84047409555616,-5.94575007506733,-4.53574550440172],[12.3901280602337,4.94491430139726,-0.864379750247113],[1.12692704063245,-5.1300061342192,3.57017347295999],[-4.87069577205179,-6.55223327886313,-9.68837160815242],[-3.84050201309595,5.76065053131843,-1.37999503806651],[-3.15108656488537,-1.45015906730817,3.61841811273176],[-3.02729337156962,-0.405668358251539,1.72643760444632],[-1.05336404207174,-6.45499427383419,-1.74438318120898],[2.53124888015052,-8.65956462504439,2.76782952559693],[-3.1256350856752,0.940390774850762,4.57394398107514],[-9.6274119965903,-0.832305386011057,-4.52897677305164],[-4.70768872953589,2.00431374172406,3.76767115015148],[-4.46365460682861,-7.01058216461774,-2.88986292890817],[3.62015426567597,-4.29011128911825,-1.36313616378847],[-4.36643393900591,-6.05140464375801,-9.2866207164994],[10.4641289253699,4.52283242326986,-0.910079235204056],[1.39436294098635,-8.22181169747903,0.628959189580735],[-5.39266392262631,-6.29222191263496,7.50745859822076],[-2.47427199156021,-3.88891282695487,-0.832157846866216],[4.0130823023881,11.0770640574252,-2.23494549789733],[1.58014543189234,2.2004239846024,-2.66842029581491],[-4.37803962208653,9.90047036760943,-5.31064756521415],[-2.11082230766906,4.27322828916325,-2.84540365770873],[-7.96313418729403,-5.9249798689078,0.402328839784467],[-4.29695443250376,-6.07955231525015,-9.60432892520054],[-1.66600962324987,-4.9930461833871,-3.14659818452939],[3.79349288688336,5.948004248339,7.09799264903249],[1.43345417192413,3.46645035413602,-5.77685488230074],[-8.03284765701945,-6.88087053791607,1.51419910976856],[-3.0748466254392,12.2476360788189,3.26754770929141],[0.468351731605633,-8.08324865788578,1.03434349302514],[0.929365707327281,6.30314586908411,7.57724574006109],[-1.71789594728266,-5.42228869917906,1.95688437652999],[-9.19020603684734,-0.77581954360398,-5.03639980161485],[-3.54297533984447,3.72270846311394,5.8036004352331],[-4.1957047696343,2.16104504937323,3.8769024359659],[-0.621658055825656,-5.24642383693863,1.70238879250648],[-3.4159045756007,7.2534193926635,8.64602569384572],[-6.03672629766338,-6.41568578935144,-1.17057467895579],[2.80436263754147,-7.6527233031587,-1.34620216633711],[0.203597188562619,9.40986978676982,-7.95448296681238],[7.58946491440854,2.34088078893545,-1.44831513432554],[-6.92252241759303,2.40503137310731,-5.52319683159054],[1.89022776552708,1.61220461329759,-9.47520465699563],[-0.115055708940717,-1.10917787817295,-11.1137883369573],[3.23899457965969,-4.13484560191645,10.0062464073941],[1.76860248796963,-0.162543466998326,-9.83576838981588],[3.469134641709,-4.68811067453724,-5.42800127752748],[-3.63241065274555,-1.75026450597125,3.7847435822439],[2.33570136100311,-9.27438428772424,-1.59465085321886],[-5.33379397610991,-3.88779008311212,-4.71120002953208],[-5.38377711636695,-5.86814972301385,-2.10126203910957],[-1.06567973732765,0.723281141972253,3.1170568438701],[-0.970390170150947,6.30800511124934,8.57012363905804],[-6.74663119936916,2.97906893944078,-4.01327758170339],[1.63476625840553,6.03569100132757,8.50972592952597],[3.63392672508143,6.71830769174717,7.90512547062088],[3.83184637780522,-2.22219958425113,-3.11401215406197],[8.9319461205696,3.87446290642789,-1.08072895381837],[-4.09806123954057,0.764081816500487,3.21938111784751],[1.52514491768037,10.6410089189086,-1.67545461723214],[-1.91293407156587,3.26572300050821,-2.26057036370905],[4.27533647722557,10.5347915869308,-0.584021832353008],[2.24355693940347,-8.57237429618991,2.01563963282973],[1.98308252446033,5.58728039799578,7.65081571355581],[1.70165811129658,3.17567449887135,-3.32777822771201],[1.17686228782537,3.01458151796798,-6.92546638775821],[-7.77362190866134,-6.43874082843997,0.458266919798002],[-1.87014788434457,3.5524607733104,-2.13309582653964],[-6.9170136658996,2.99031036822294,-4.46318310731414],[-2.70368356873428,-2.01431408789256,-5.60045331757439],[-2.05745440676825,4.52101370586905,-2.03519325422583],[-6.32918483119225,2.82679365680843,-6.3210060713399],[-9.47428855384383,1.31308778503646,-6.17560866116277],[9.8545092577292,2.27532465435937,-2.57528379429781],[2.49549572727547,-3.29024530433686,-3.63958658209403],[-6.6363809319625,-5.93213391854279,6.33892762792215],[1.21052659287952,-2.39744950304631,12.7041907800148],[-7.05510133741526,-6.3132022484456,-0.55260217603992],[8.60720676779572,-3.28676104462316,-4.48359103174173],[1.78983744310055,-7.14572062616622,2.01071047236053],[2.33114475496415,11.725969139642,-1.21135638189244],[1.15193899034299,-5.16538406940567,10.536402421974],[0.958870256034098,-5.95525858857127,10.9871547568259],[-6.99842000670104,-0.825632069778665,-4.26321478872728],[-7.02805954499761,3.04454645565631,-4.31024805293307],[4.30092620310032,1.40403131484063,-9.8412686913399],[1.6628554282758,-4.880203483322,3.32799597925455],[8.76392193741304,6.97736814541335,0.575803759117236],[-4.65762236057459,-5.79137339053186,-10.9341661049382],[-7.17219125238742,-6.5478674261249,0.298432411077331],[0.193488361149924,-6.60893788408762,-5.82851529787121],[2.36409040188103,5.65562929032175,9.01653353005179],[-2.86239247972442,7.40711743109821,-0.500340961278799],[0.347514234922958,-4.70663758141715,-5.74733354213645],[1.55139806954697,-4.56776490786841,-5.02697223743542],[1.4711061242305,5.88987830848876,8.76192225858325],[-6.01028014759031,7.347211529617,7.85417568441505],[-3.42247374948566,0.489349564809216,1.66874260527011],[-2.57415195265884,10.4549032804352,3.5658443408298],[2.19109745270638,-8.27582375938528,-0.515517250746185],[1.7645733085851,-3.4877342375699,12.0473576136404],[-3.17513877411846,6.63630450052227,-1.16178063309479],[1.61267991194328,-4.4775978551076,2.19467316808059],[9.65317499096919,-4.88623151476414,-4.63434924137924],[4.51818753876238,-6.2655905335152,-1.88378172257673],[-1.89005704714075,-6.82371427183555,1.58524479206448],[-5.33074792201966,-6.17211776154826,-1.27227984883016],[2.74119313566102,11.755215885606,-1.80518036342578],[-3.99174215779624,7.13864486219293,-5.91397959602522],[-2.9632829254445,-4.82123128512075,-7.696428264351],[0.682652121956837,-3.08706425925899,-12.0973344018445],[-0.570397260629879,2.80135976886098,-8.33934748968388],[-4.19828679365292,-3.53780403032299,-11.3255831806287],[2.61338392212172,6.44701837188162,8.75891052536382],[4.38246015405575,5.24444244632046,8.4548002308453],[-5.24691425203363,6.01660379016761,8.82785853259351],[1.36792500574463,-0.0446078880179307,3.87130761056301],[0.595318061171026,-6.50880785291582,0.276958119615454],[-5.49170376197383,-0.703046989223855,0.138100751221678],[10.8835231666095,1.46502003241387,-1.96534767256248],[2.98775560370336,-9.09211463761552,-0.154153824926331],[4.12576572942296,5.63790873532058,7.46129470682214],[-4.29129900867731,1.95008032836431,3.99985766768469],[-4.40482248411041,8.51231213987344,-6.57251167714349],[7.79231071383171,-3.08042183129446,-4.79734472423347],[4.98343202600429,1.66152073858923,4.95094436093161],[1.21449807984832,-5.18504181694983,4.87369973624074],[-0.266771790080507,-0.157198299632999,3.32619303127162],[-6.13638276106491,-3.67087107998603,-4.56244752314836],[1.72496785527383,1.49971807809873,-9.4108292047943],[-6.25094998707023,-3.20809137293373,-5.04014270596843],[-0.255505422374932,0.729930375508494,-7.2072701442629],[2.54521157776914,6.34132757347653,7.01039648413938],[2.24560377823872,6.24101069266852,9.31756766756276],[4.29111639511453,-0.784167751437822,-6.43049844983993],[-7.61369862565778,-5.87314811648292,6.29842720657094],[-2.82718465261437,4.49175130147242,-7.4645206409556],[2.76425224043148,-2.52628644705632,-6.70048164475635],[1.72223149055588,1.0603332991928,-6.77704816818937],[0.797276659697151,3.86949613481855,-8.56829872730214],[-5.25172731578118,-6.53978793245638,-1.39920717186031],[2.76891689597873,-8.77514520307909,2.21964676276807],[0.242527054489783,-8.00534410352266,0.290461256746831],[2.29820110460621,-9.72103403837529,-0.643468860704254],[2.27199613157646,5.79710207880437,6.37945983381911],[2.15112079457598,6.35813958364672,7.76460661752253],[-3.21292317331656,8.02109001194987,-5.94829142460895],[-5.4949981565561,-3.03624076936041,-4.51067317670233],[-3.054783256328,7.3162527475212,-0.429579017340373],[1.87905163447216,-5.54958466697513,5.02195433304764],[3.08421181183293,-7.33102878589414,-1.93103022929048],[7.14759415885913,4.59716740197323,0.0000724538723372303],[0.546080622222299,-3.28587845980127,-12.0797129405873],[1.43606105514875,-5.5001490561511,-6.10005025408789],[-8.09689701010259,-6.47999386087133,1.16511533300878],[-6.19155551027114,-4.65436318015067,-4.01700430985012],[-4.71399662251982,-6.22362083142707,-1.66403175371489],[-4.6773717687169,7.22868572413655,7.96463295980976],[-9.51081565916949,-1.44139240678823,-3.44386521995518],[-8.04143694142019,-7.08680303545286,1.28641778999256],[2.19739148277911,-3.99108886274413,11.7590763656658],[-2.82158216763136,-1.16906269380608,-7.70817939896502],[3.71008842609326,5.62981414856906,7.8755573614511],[0.725972168112929,0.0501068027821974,2.97499419484824],[1.44671335517253,-5.94417836643014,4.36490712583435],[2.82199627084202,-7.00536009647128,-1.31409522979687],[8.36797603317288,-3.70453793723582,-1.8364778974836],[-4.98341163248935,0.760624180940815,2.5701395842116],[-4.08195881105434,-6.843036287487,-2.84890057552619],[-3.88289232320003,0.88399682646805,3.46979530085319],[-1.28078804028539,-7.27618134303393,-0.593806483344904],[-6.19095347543665,-3.99699018256902,-4.18553746038894],[1.6535583462319,-5.99861431544697,3.96727515365529],[-1.98127401577156,-3.4990579326621,-9.80682328395263],[1.364815539149,1.83060076545437,-9.29059323728387],[0.646989582603222,-5.85994373655465,1.04118527527552],[0.992103637413724,-4.59717115608336,-5.13798258014612],[2.29404219586856,5.39685283138708,7.89012435349635],[-1.48302250227337,3.62079842493286,-2.6094889645687],[3.07338692891263,5.04909749600161,8.68246478385621],[-4.43182172158456,-5.84582298667476,-2.4802065811422],[7.7954482946687,3.68980041055845,-0.291772236641289],[-4.73867765652058,-5.9875818009976,7.70488382293636],[0.855032227588457,-0.0680542514747942,3.65525886952435],[-4.86269958638739,0.660000785185795,3.43233891176351],[-0.845458397778203,-7.99323219314663,-6.12411556802747],[8.6886531798721,4.7935846212221,-1.04089852062285],[-3.96269807451867,8.15361954264741,-5.73005435953544],[-2.1490093820087,-2.90228672396011,-3.2137666205354],[-1.65661863445593,-5.98422833332072,-2.16401879176727],[-6.15605925589151,3.28439763145138,-5.96498164411748],[1.35495826325612,4.04313533772411,-6.07352600813395],[-5.18432294527956,2.71590791845184,-6.24112293331669],[2.45275626448322,-10.1304836504823,-0.785379087643348],[3.003479625476,5.47403873414225,8.72688754989927],[-2.88863288502679,9.03533632532845,-5.78395187567977],[3.13239851405793,-3.43198712965386,10.9893860949922],[2.31279508827428,0.545437076858972,3.74505031463858],[3.36984801710012,-8.94954540453154,-2.19888221998426],[-5.9332989678099,8.31459361391846,7.82386629050363],[0.841780867122119,-8.58813250327683,2.78527060291302],[1.56575935671611,5.39992819575268,8.28901872122037],[1.93244191139974,-5.07967781606299,2.60712510390897],[1.24884174391838,3.40924112216784,-4.03135102648794],[-1.87107931272183,-5.86823107069858,-1.88694806841798],[-9.07543401274789,-1.87070958555764,-3.22339648021146],[-3.59975519024039,6.22528277464464,-0.551768910370991],[2.01347272968997,-3.69719454653941,12.1358619189031],[3.48310590795316,5.83204814214368,7.80092267780921],[4.44669584109386,4.93514376324818,3.25009820616986],[-4.37837885029703,2.72164476242048,-5.36603621717986],[-2.32600709636969,4.81012599536516,-7.10947153104684],[2.59449712171993,11.014193575207,-0.978906498678875],[2.59249140298649,3.89667568620526,8.72664398910697],[2.76628620969589,6.24988500329121,-11.488250457887],[4.51188054037945,2.27758547234055,-10.2228500711579],[2.06448317340109,0.552808070510271,3.74210777126955],[-5.82000408727002,-2.79872556098816,4.68982831058949],[-3.98440316862227,-0.268878370482368,3.16915982141595],[2.62285651444476,-2.44933008201933,-4.42205891794629],[-3.31430480983439,6.60130181908091,-0.0694519628479116],[0.622721117920409,-5.6489121111285,3.12918313889887],[-2.4475066745684,-0.8819790336333,-5.47797747655466],[-7.13172255823954,2.87753534199708,-5.21036699310834],[3.6629197324455,5.27722421181197,7.1219505636522],[1.21457220770344,-2.49823496960312,-7.92599983737254],[2.18465221065068,-10.2713965828009,-0.376834081805455],[-4.16064669473016,5.91077408731791,0.329465440835047],[1.1323706471796,-4.48682691994173,2.93056205411632],[11.6142240459592,4.16418610568726,-1.01604902921429],[-3.99116531435866,3.50718264291258,5.79209493849799],[-2.78397608697372,4.21276354942594,0.327046527634385],[-5.09386589056306,-6.077117161725,7.91167978283816],[-1.04221683433539,1.82705910790035,1.76166472231939],[-5.44721376595452,8.25142352709348,8.62048005124863],[-1.91893737368652,-4.68873249227497,-0.237238573472919],[-3.45485040678082,1.14092984784168,4.85864480263004],[-4.4538295995868,2.01697561444801,5.20250107095849],[-5.61868159784194,-4.28832565275208,-4.34048779479115],[2.75193675813953,-3.64431350967571,-10.8699659145162],[-4.21232642952824,6.05350230560333,0.0548345348014536],[2.67678261549745,4.04859225848049,7.44861703356433],[9.55214131983514,0.593958904639631,-1.36139080958266],[1.78031838358845,1.53114333141879,-4.75474506420177],[4.95892259992541,-1.97626293865987,-6.8866756848354],[-6.57275685999812,2.4219367142838,-6.56437238933563],[1.44098438430787,-9.88085186020189,1.46920434516767],[-2.423676223002,4.9370009428575,-7.0781983307883],[2.15159354416372,-7.91684784683885,-11.0821993154131],[-4.00537708309873,0.0160257597390494,-1.46385141956469],[-3.33267888875157,12.7322127177345,4.62223093231871],[4.01227120313204,-5.73980042512091,-1.91496535017774],[2.68802599876444,-9.909680885938,0.236952252024325],[0.675545873014731,-4.98851075328788,-5.6135574961613],[1.69193609809842,-9.24913601340071,1.44452929932754],[1.43804987630911,2.85238249844773,-3.98086616863375],[-5.28284213149608,-2.94471476097307,-9.36445591395488],[-3.55679445933836,-4.28419519857464,-1.68818882535393],[1.08260513008987,3.53014202496458,-3.80710580803844],[-2.67017754172112,0.321553200326473,4.24994827578264],[-3.16208071360722,0.319873437632393,4.37693057616819],[3.03752897496257,-10.1918607942282,-1.16398226433732],[-1.34625139143586,9.66237476522065,2.97197639440523],[-4.91778726109679,6.45202157912078,8.83512478058756],[4.61559652544801,-6.18415039429763,-1.84420825656421],[1.71572608047022,-8.50826458810338,-0.365607410434403],[1.85437750790231,-5.28349945927137,2.39681434594806],[-2.9937015730293,4.78456608095013,-7.3629138792354],[-6.33020458336362,-4.08690328274414,-4.11008271134275],[3.29638623330365,11.1835789927456,-1.06031096664211],[-5.07333582900251,-6.10685620902661,-2.89583435770053],[3.07359807314188,-9.74578874012382,-0.0566511137113814],[-1.85228537240998,5.59863725954468,0.687244104693001],[-5.57216040722867,-1.24162365732371,0.0803292423296491],[1.2785315067273,-5.19653770168266,11.0586289598406],[1.97623137866732,-6.18131211936959,1.20734457609928],[0.330574034363804,-8.64892842529067,0.0720118845221415],[-0.439183543954176,4.11857361486957,-0.312664206481345],[-1.82582370654474,5.19844271040886,-2.84942589237688],[-4.55300772854907,1.000754359988,3.78537702767317],[-4.62153654479415,6.10598501122241,-0.774828185567876],[-9.22198651351746,-0.554196264784672,-5.21030074299519],[9.26064207202161,0.571784677585483,-0.74971269616686],[9.13093965177601,-3.95073905605402,-1.96125986080848],[-1.7319570985111,-6.51026144574483,-1.74784560192417],[10.7783415545421,2.36605259507827,-2.36841402334421],[-4.25134345487303,1.20694958290074,2.51569583674667],[1.92602347550307,0.706885392346874,-6.87652575078376],[2.86937168336124,0.508578421211606,-11.2284485489303],[-1.62531449891411,5.61807786400462,0.505704400500458],[-3.17601418316984,6.9176676939303,-0.519184423877839],[-2.41727096503703,-3.24026458429069,-7.47711643310699],[-2.91278758555726,-1.80722000011905,-4.4126857590358],[1.61273950994051,1.70824838158181,-4.82071925037303],[-6.78355006947603,3.16016673981722,-5.22486282601073],[0.45234439698212,-3.83696345443349,-5.75940683086011],[-5.92613271257271,-2.94011161882104,-5.04621162893684],[-4.91816326105508,7.1650665130466,8.52893815046388],[4.62793221617326,1.47036788298416,-9.01761486106005],[-2.98256002190772,-4.39378471587838,6.77689035377592],[-6.20464158590337,7.39593703097862,8.9769949391996],[0.0371488884803958,-3.36087616807657,-11.9323262843441],[-2.41805769278353,-0.6004352353829,-3.57900787231596],[4.23377257644511,-6.27654629890603,-2.01810296355032],[2.26167695640767,6.67946547225773,7.4362877111509],[2.00622833795735,12.019029886288,-1.8798762937272],[-3.28716901007912,0.769247654648985,2.46207627727481],[9.52712724465112,3.09520978925523,-2.76282018640223],[-3.32000361278977,4.06795378059337,0.558789745857237],[3.90872255918446,-5.13363565330436,-2.08909323760378],[0.562350444614534,-8.41394271107875,-0.133294951957482],[-7.6968398166664,-5.98822051322495,1.85485381891403],[-4.27523271568211,1.76033884624503,2.78601107520213],[-4.15965845198044,5.10016585510706,-0.136216561144208],[1.34841118554564,-8.50781006195767,0.417348259799854],[1.57388216103141,6.05226767627497,8.43570506934364],[-3.51661719674795,4.99729611317393,-3.52640316854608],[3.75407767097339,-5.79726410610945,-1.72405186077234],[2.71068931274571,11.4337857458816,-1.51576460050689],[0.728300230226548,2.12199174254873,-3.21643982143322],[-0.241517739553549,1.01380253499276,-7.41473453145967],[-9.02776551359788,0.338608044112081,-5.62960174079712],[3.69317653492899,6.0108598052797,8.66624620566766],[1.17123671323419,4.28052806591902,-4.06331319794522],[3.03444399805138,6.11585250506722,7.11968762416227],[9.40269961684908,2.36313934819405,-1.98099298281262],[-0.0944789715731493,0.300941383304127,-2.65647959910401],[3.81763453289586,3.75796760785375,8.52659274653512],[8.59572893838728,2.31211144624398,-2.65396540951936],[-5.8540909588902,-0.801611379617388,-0.922468584449782],[-0.558556776448407,0.811222056918372,3.3728203717337],[-3.64814372981722,12.7288075858601,4.44021765191567],[-1.88384920462898,-0.117761876157351,-4.84348156836831],[3.28957411198442,6.05202435908525,7.20809774602864],[1.43452421353126,2.23784594532412,-3.71073974339343],[-4.98312124809163,-6.28988164240122,-2.49772749001316],[-1.02611217278589,9.51747931405094,2.52026802513514],[-5.47536299118167,-1.61759191538725,0.269926407248216],[-4.51650471587497,5.46587859041187,-0.325416392437982],[4.70710617871693,1.97815983423524,4.32948997981558],[4.42839131986128,2.48280289735804,-10.0828171699084],[4.2428224257469,-6.66537552963041,-2.08626409288159],[10.4995255686142,2.46435089150432,-2.25022033301536],[-5.12735166229516,6.81691082007848,9.3822936713243],[-5.47479219805458,8.36597776673167,8.05244068286866],[-3.95700610173578,4.61236362386122,0.00510149631559254],[-4.47290195651974,8.22816127259538,8.85615207918088],[-5.23388829157972,6.70665821109134,9.3329602616216],[1.29834606362048,5.51313869100965,8.3774749849985],[2.07885837186448,5.9297520237569,-11.503223286829],[-4.54514626814832,6.32271063492329,9.01125817077073],[3.33842298783283,6.21313655224552,8.61115714577965],[7.89618507035241,5.73323644599058,2.08013528018174],[-5.17135756584086,7.98651894812703,8.38969806985792],[-1.69636957755978,-8.13192997125661,-5.47210468815777],[-5.93572959873532,7.07443104515308,8.66939277342317],[-5.27780823444937,-6.10125737491958,-1.24238346761844],[0.995480956861929,5.40056526131014,8.60122892674563],[10.0922240959133,6.3256584939039,-1.0555530617159],[1.82117138228501,-9.4429105800152,2.32482318231214],[1.32637507668798,-4.08388207936748,12.3648506517436],[1.03195307999017,-2.97052115094447,-11.8597233830112],[-0.0467609448825063,-0.885539164050985,-10.9716877110133],[-0.95798703564943,0.801136093950802,3.07130234747929],[1.24530490780707,-6.16547439969957,4.62605978785252],[-4.61535018883161,5.25570899610666,-4.09893793211172],[1.41288722221198,-9.72528870965336,0.911558956524021],[0.984961922011037,-6.42561275043121,0.977742334249791],[1.84335830524449,6.37058761058547,8.75846281561651],[8.89268876745736,3.66573146870361,-1.52119683055908],[3.76659008132693,2.35975546616467,-10.3457122524892],[-6.45280919417354,-2.93508198084082,-4.9137998569428],[-4.56894063414556,-0.400490362885968,4.6607961997927],[-0.992675549763186,0.260860408846092,3.41212497898186],[3.87940627528227,-8.64598881852395,-0.357299475090688],[2.34232263937546,5.60724290785655,6.9177424806405],[8.88184780617747,-1.9890799050602,-3.36656685101201],[1.92754946336196,6.41812019378608,8.46599336680253],[2.74954945136488,-7.3756976868753,3.91040896745448],[2.49017095073597,-4.29750635931757,10.1104158807552],[-2.51600410008087,-2.80957198804826,-2.99500255650958],[-0.979539524935272,6.30933399248123,8.77321333876632],[1.59185289023012,5.91337644015521,7.17194184558994],[3.53300421399636,11.7428855235227,-1.82155040647097],[-2.58156047828978,10.7848339623118,3.21735109879764],[2.53010627507561,5.97774182573646,7.00605914182635],[-4.37835121102855,-0.424083278574377,-1.01190542630035],[4.0860147781154,-6.63631646305145,-2.03275054231667],[-4.54233064962936,-6.82892922284068,-2.80138644652407],[-0.200620116123891,4.38833615552978,-3.09070207894879],[1.88904941278466,-7.75844100288762,2.27738765790589],[2.50891691735993,5.57338361718647,6.23874655120127],[-3.88690779922737,5.49425667249847,-2.12420915396942],[2.52699442307704,11.6759381081839,-2.15221414141175],[2.74519720785277,-3.59248606376034,-10.9352299238453],[0.685083666228694,-2.99745935596267,-12.3912694919147],[-8.62591338092827,-6.64253605421492,0.907201491915609],[3.90724108759496,6.2375362160829,7.51848241803786],[2.20655077287872,-5.71350237888592,2.21289744224109],[0.708131514052999,-3.81488156469519,-2.66906423961552],[-5.49276460245795,-2.98800591090986,-5.22515284701241],[-4.29904190310789,8.36889513171467,-5.28552964065342],[3.38865564515055,-6.5312566465298,-1.47195679264898],[2.14658258892694,11.3371991811739,-2.54125397602825],[1.47239936098386,-4.94645598258982,-0.252800058508913],[-1.12154094152688,6.38915918144349,8.97482446129532],[0.693472321287696,-5.64494181394957,2.23388058006883],[0.943238646672345,-0.0708646998238387,3.5307145480633],[2.20559322383738,5.62751345238297,6.82262885617944],[1.13650846985175,-5.56517010536697,4.9733465481836],[-6.59663289818017,3.00479697781603,-3.95970187209444],[1.91802704638244,-5.6462514037717,4.6192395636785],[-3.63435429993146,7.58110650723208,8.88193841238702],[-3.34312592322587,-3.62571033138139,-1.32605382938109],[2.08434446161465,-9.87784328497902,1.7274019996781],[1.9198898143943,-8.94611365444623,2.04243339944922],[-4.460097072322,5.20554005876599,-4.34942920528967],[3.34491681878649,-4.48766566467979,-5.24216276934862],[-0.299522418281092,-6.17277497311859,1.41914626883794],[1.79794644529526,-9.28464340002213,1.99099757629483],[4.96569203432737,-1.65848831899117,-2.95957453358383],[2.98930579135638,-7.38453976863292,-0.971848661046117],[-9.1821862761293,-1.40486314800527,-5.10346383654482],[1.03743586244753,2.96147173025098,-7.00449295516465],[2.80547475341069,-10.1089585927149,0.769756016270415],[1.63465248343466,1.35881893239327,-9.83161164029091],[1.57532905965393,1.72508173204778,-9.09129860188909],[-0.223701587860985,-0.18264522723383,4.33191961368677],[3.74881453259993,-5.30948366498325,-5.55091769139764],[5.04047702097882,1.46564323659213,6.25361891473913],[0.653442775865919,3.39086454415409,-6.54171402618262],[0.815643252257094,4.05363357662255,-8.50907553923089],[-0.738678798805731,-7.86760646577645,1.02630400768071],[-9.78065285572507,0.681819152443978,-5.56215896120846],[-3.38812910878036,7.51435352651773,8.91480529615926],[-2.79322537467996,-2.44765191145585,-4.82599965109019],[0.37711602165608,3.37860584249217,-8.74795191107057],[-4.81669621622317,2.03545499632614,4.20450049938704],[3.65969478072204,4.23102498315626,8.83643432641],[-1.26914036592663,-4.88195876555285,2.01829827785829],[1.08467059376904,-6.79796459828638,0.866975958613795],[7.74864449203284,-1.71961037557296,-10.7144006699509],[3.31804057210877,11.7083907152188,-1.21285879326337],[-3.38669792438815,-5.40549123248933,-1.28433162683783],[3.42083469250918,-8.47216442614792,-0.289793051815792],[-8.22463257091917,-5.38826561707868,0.236294345161977],[-5.64338583822818,-3.63258236262087,4.34864829552066],[-5.35355985487013,-1.30839889778369,-3.97522558433041],[3.38707927201495,10.9875031129658,-1.9342069436613],[-1.64533382195822,-3.05142009268281,-9.64184342745936],[-1.79063210234962,10.3050491879234,3.31241388996286],[-1.80984680363362,-2.92919425484221,-0.639232600694739],[-2.32723787718543,-0.972726420863052,-3.62611464961568],[2.73535572506993,6.04361422381982,6.65168448825588],[6.77980098857041,4.59657286426073,0.420612302108162],[1.07274294347834,-7.28606649291451,0.983564719125517],[-4.12899539758593,8.77194174877684,-6.96503995660537],[-4.34062063556441,-5.35170625853248,-2.3875328534047],[0.76389639963963,-1.89678005769476,-2.47315554321909],[-7.10149039226328,8.53200738195313,-3.92758597296335],[2.98216829440299,-1.69637573758148,-4.36800784547615],[1.74056289757869,-1.05809173047268,-6.21206215306308],[-6.96697413958418,2.72991997694746,-4.24653128464646],[-4.03160686397022,5.33025219640331,-2.30873808661537],[-4.35903327890542,0.862793941220365,4.39738117865657],[-5.04380010531936,6.08723937613742,8.42108778542423],[-1.08585158916197,-4.91738211165953,-3.53905619731907],[-0.322715372990971,-0.936605275615945,-11.1255774856168],[2.39793435383087,-3.51990829237113,-4.07305756488794],[-4.49059503602782,4.9486157573915,-4.72694874331917],[4.5981361455343,1.78214447030589,-9.37992151388131],[-3.06029642267786,9.9355302328121,-6.50379324255938],[2.5749445037831,11.4424469107234,-1.77535901713075],[-8.13683152370582,-6.81785918772468,1.04770723579694],[-5.1368072491859,0.951104979697202,5.29608359172127],[1.11363746628441,-5.18417403958244,3.97990175582887],[7.10990167451738,3.90285777353218,0.0379851380244433],[-2.82933780410915,-2.27461339762337,-4.80354813056885],[-3.08814986967493,7.09404817737132,-0.119043567598482],[8.56931515423531,6.94021542866643,1.48971407089558],[1.1347712378537,-9.79658986364304,0.854487575042748],[-6.63293938844738,8.91284686625841,-4.19992914504383],[2.01052443798145,0.250587885772422,4.10733851355942],[0.680743860660697,-7.96670522760836,2.11492181706846],[-1.97700027647126,-3.28633247051094,-0.372314108028581],[-9.65868493974748,1.22444450949545,-6.18059131215995],[-0.989643403955215,-1.43358810686652,-2.48416133339378],[1.48666821785756,-4.35489263240813,0.18999501125081],[3.0979097261463,-4.26154468974346,-2.2667492366922],[-4.54768174293388,-5.4268572536399,7.7384942675231],[3.04311066066104,-2.31050666015823,-6.66635729057992],[1.6588012305833,6.30424518577425,7.20973181111114],[0.125734563646265,9.02619909475717,-7.55534988195049],[0.489229840651156,-2.52644288723677,-0.277850456273755],[3.4828678222788,-7.46495415744846,-1.46934243494544],[-7.24077674213856,-0.618344189849356,-4.40054826569872],[2.59050111645631,-7.42010481186394,-1.68481205116024],[-3.009923836639,-4.14521403767293,6.90021285443961],[-2.15600131721338,-2.96292444743445,-0.147252709266524],[-4.47434947547228,4.17641030062042,-6.61078803390419],[2.07707989822226,-8.04372142919441,-11.0140663757556],[-9.5498750256639,0.525434045655381,-5.69002652609016],[-6.58258269802575,3.55423088171738,-4.55934008671184],[7.91727537919254,2.43227059533749,-1.68909746072575],[-1.27765913475402,-6.80354457363851,-0.00106729068393591],[-2.19176204046954,-3.43537903244807,-9.77532463899877],[3.98155247903329,5.89329798794748,7.14026532003423],[-4.51393777012492,5.81375625335961,0.313557796541778],[-9.25670643344504,1.3162846619178,-6.29212938149535],[0.561105261572293,7.15686311572803,-6.15647931251994],[-6.46556831924844,9.28372232829717,-4.21740448452714],[1.36765861534487,-8.77019425119736,1.81630590444524],[-2.95950383517003,9.44107607928798,-6.02149889260541],[-0.0330593672783562,-3.02160447115256,9.89542599718672],[0.707449731679879,-1.96212695962853,-1.91444335012885],[-4.5904184088909,6.62364010564844,7.72729896267259],[-2.58326937238462,-4.72246108877853,-0.048524648239103],[3.13553455536741,0.181396190681465,-11.7246464424759],[9.34707367198837,-4.32365862772627,-5.89538823290627],[-2.94177012874953,-3.02792476442987,-0.378150857785526],[-4.31968954334191,-0.235256518744908,-0.504481742247943],[-5.62833054995827,-6.11533847092938,-2.16218343005977],[-2.70681008724761,-0.317078502168491,3.67098134493445],[0.623133350494326,-5.33883457330755,-5.5734009520395],[2.15513874447608,10.8591527044048,-3.12691437312433],[-6.33114854114625,7.61411153454379,8.22035497851752],[-0.270994296668965,9.41029315251182,-7.27806505310165],[2.02049971766357,-8.63783094639077,-0.764248652969022],[-0.214602593412332,-2.8796019893508,-9.95110782061786],[1.34937286532317,-7.73792631909726,-10.6359565585176],[-6.35874390819727,8.5213647655624,-4.48529430792049],[1.0584271603545,-3.18832213553679,12.6106143751166],[-1.74296042080502,-6.57440988745083,-1.74134896237823],[1.45698195926515,6.42343616689627,-11.3732380435236],[-3.41829778155234,1.48627982907601,4.29229165545708],[-4.67172317964615,-6.88054581132863,-2.47690591208314],[-2.39546633094199,-4.07532040655294,0.204682377672364],[1.96069726132593,5.93641711436597,6.78891049203231],[0.566829049598982,-2.33277111893055,12.5245571773283],[-0.103475340414836,-8.25565224394648,1.12612192093901],[4.1368686767667,11.1728143172485,-2.4074060235077],[-2.19154798425975,10.7138428725021,3.29189074571389],[1.81973059736018,10.9639168733575,-1.92826468159021],[-4.18196046459899,4.95047808810829,0.465759071414801],[9.15875086075104,-4.53540822154781,-5.93605183781878],[-5.17035786606274,-5.70385511783382,-2.0278688681654],[0.751368494428033,-8.43847281226684,1.10991643593983],[10.7422868728902,-1.97496513355671,-0.622861730948941],[-0.310936821204612,-0.857357865313511,-11.0296324095766],[3.69392323026943,6.44460459125475,7.55274724170115],[-2.48786907982102,4.61488191258247,-7.59621999535668],[1.1653406826741,6.19818250379889,7.50476468238197],[-5.11806288092052,-5.88265432208496,7.86801115116206],[4.208385692161,-5.11594115835669,-1.35147836965085],[4.05256987009071,5.71141338437351,7.35044795490974],[1.14720458404437,2.89383753669443,-4.06094857094305],[-1.81948081398256,9.00837210454223,2.77413658266269],[0.792553671206334,-3.06365738272577,12.5357597199883],[-1.29814430584444,2.91059409974311,-2.29582297050549],[-5.53805807739213,-6.11120803419847,-1.63671592605551],[1.65345569609207,-6.31556717525268,-10.3046049847875],[2.05378589290822,-7.93849602895546,3.35252514213054],[-4.68713766297784,-5.63274803310466,-1.36020998486416],[-2.77643165523437,-1.25505898493964,3.4301422132272],[8.82050428454131,-2.27383319738639,-3.04772246511337],[0.453998658616619,-3.37234777762436,9.97321804363859],[-0.0572054895191849,-7.00846293649033,-0.950887212821823],[0.895058921016715,3.28583284746823,-7.68590787264973],[-4.6780695535399,8.44708508495824,8.46081856906452],[3.5470082592337,-0.456352008419175,-3.32824330117193],[-5.19217433131961,1.43347803741741,5.13735623466512],[-5.13864351135334,8.90582580563323,-7.54777762040201],[1.18675200852662,-7.32427876140628,2.0778647669018],[-5.25874117759704,1.93455253561494,4.03330191566444],[-5.21469436378236,8.85703054336926,-7.52784642049581],[-8.16609122661781,-6.5258149420812,1.47320918416581],[9.41323564396778,0.790062666919941,-1.67869677841413],[2.42477320526014,-10.5093470249813,-1.10010097388546],[3.26558580996248,6.35000234572993,6.79049300904912],[-4.36999672337362,4.02751890385427,-6.67051911982016],[-2.57294187713456,-3.07019914493432,-2.52470729063039],[4.77680402157275,-3.09754368529897,-4.18041776814369],[8.82480893183653,-0.252231345311446,-1.22283392846563],[-3.68438937252146,-2.43830546928359,4.64602625708694],[-3.02015609505774,6.63765873695254,8.90478887319657],[-4.71905379327609,-6.14320571098591,-10.0993652086555],[2.55369703162023,-4.04244799024305,-1.54834854414385],[-2.83349510338791,-2.44109828825708,-6.88894147288596],[4.89694605420022,-1.37400539129116,-6.79422848719865],[-0.215184352378882,-4.12451052026359,-1.60532365195796],[3.24187848620303,-9.31912113634991,0.614969215608399],[-6.16897534904351,7.10411482283356,8.6319614298362],[7.12012679686906,-1.27446145874615,-10.3748350333066],[-3.68185818635453,-5.66093862021409,7.68863955323218],[-4.77280915933412,-0.324824099235576,-1.57445089064359],[1.40290202701796,-9.10741278875786,2.13293933504844],[-4.26671525468872,-0.707945772388631,2.13344282918746],[-4.84138011879355,3.52939142854436,-6.62851659304716],[-2.3673639503226,-4.54168246410032,-0.00499597563174281],[10.2141510877171,3.13771051233059,-3.07816905643602],[-3.91685805058116,-0.314620535808604,2.19639694100946],[4.06427282052984,-8.43356943367123,-0.394041961162444],[-6.03721540914425,-2.63227030314203,-5.1544254310465],[8.668114811066,2.99453560903867,-1.22699630160222],[0.888695159031674,-3.24364674096791,13.5544837532851],[10.6829987527039,2.69912678714664,-2.26449434456938],[2.68473555911197,11.23183409787,-3.05672031786736],[0.811370242405737,-2.94379957452882,-11.9580132765833],[1.9113746891614,-6.25509889221293,1.80206315387239],[4.39311716387697,4.83432678978615,8.83084448229457],[-1.86054952677065,-3.7424763304695,-0.351870025906916],[10.172493748607,3.22679266810991,-2.47396429890179],[0.808600192516572,-3.26577820279468,12.1917322056837],[-3.85719007908168,1.16783623386443,3.11493339363815],[-6.32586056872484,-3.73448695344511,-4.48788796854657],[-2.72039755377314,-3.8444663624417,-1.25876961935077],[-8.33468494391527,-6.72026544716471,0.277330102737963],[-4.50275672874908,-6.06663215948996,-2.09176386090073],[-0.431343449741573,1.34968718725482,-2.01273303568859],[-7.63486233518068,-6.1396530189845,-0.229259810661947],[10.1228081157187,2.86909234300163,-0.882488431627473],[-9.1178245773307,0.411290431124723,-5.38626081111062],[-8.25723309742583,-6.37258192027236,1.28888709201445],[0.667190430794123,-9.60186208426664,1.20626789999424],[-4.49438558212829,-3.01853989603342,-9.1691131375448],[1.67282389025118,0.811043049528264,3.08952509554684],[8.02968703644205,5.46408094414224,2.95963042623767],[-6.50515626688293,-6.41363951355323,-0.44519791241856],[-0.894110693120192,-1.38285854712173,-2.66415289922111],[0.934625672130756,-6.28291302808466,1.90487814658608],[2.95128089909744,-3.35192089306431,-10.76011989888],[2.40836246746213,5.18797340122377,8.62193689193044],[-3.36949523358657,0.333251565037692,3.13544386843413],[-1.60074033405472,-4.485943825032,-0.450917470523851],[1.84686222150375,-8.45880245527631,2.84233203464394],[1.41013869363565,-5.91715157214413,3.28697629390883],[0.0775721087514172,-2.32828773314119,-0.342909993415695],[2.74927187927776,5.51258752015234,8.42267160237142],[1.26254839485037,0.707201964622547,3.54848648940534],[1.17261072320489,0.502606098899117,3.11101612771381],[8.96937471233277,-4.33766017911818,-1.95829574197738],[-8.20897762424421,-6.60421857053723,1.33642384802727],[2.34830239634858,-8.42001798237857,1.93752624709712],[-2.67019124848914,0.630844849518378,-0.869038958934696],[2.80329634337298,0.533625752133821,-11.1538508199828],[2.39199004019361,5.69039280356479,7.24496588318742],[-4.41465570974582,7.07362510043656,-5.13559683946987],[0.632172770506278,0.402690257017955,3.52452579482512],[3.05225886080551,11.0958071880762,-2.42209819718846],[10.4446701503296,1.22066925093095,-1.28275630040096],[1.70939146621337,11.2271608636241,-2.62311599957167],[-3.14177796199965,0.496278492553385,4.54526361357044],[-0.685054759809505,4.45924089020061,-0.304220328411212],[-1.64802495595786,-2.4248614241298,-3.98301976290004],[1.56875591036361,-5.10817044960674,11.3540670582426],[2.88080083757801,5.69048462065564,6.93438579104966],[0.980526166824124,3.23233369263364,-7.03252826919314],[-0.198654636807217,-5.51432098494754,1.75110518721322],[-5.17664760122291,8.2134639724337,7.36476152448414],[2.93836340990994,-0.660596073165463,-12.3438693610861],[3.46095016597011,5.96419880140789,7.74212526379285],[9.05860884454854,6.72203197662157,-0.0546224535899879],[2.71517450136074,-10.1580217303482,0.186415024196525],[-2.51114459545236,6.96497107317471,-1.25899142795156],[3.11375150266979,-3.71891255660841,-10.7217133045288],[11.5211257910275,0.928711663562807,-0.942915872575725],[2.5088302741408,-2.20340549741777,-6.70916373125666],[1.77602170836988,-5.45651777429891,1.05355070465112],[-0.00150224324655468,9.46881034097411,-7.41056200006415],[-5.3011317160107,-0.651686259408189,1.04969197568105],[-3.6442555393191,0.456207739413881,5.61260369967321],[3.30862784492413,-6.04061855903555,-2.27188813258819],[-0.768629140137456,0.66817380772122,4.49277603277825],[1.30406454432501,-5.26499829745291,4.2248685116339],[1.74382205513706,3.95036811923018,-5.38039426654267],[-4.89589346751083,7.38712420419826,7.61550258177627],[11.4287574385936,3.49574836689306,-1.466094781452],[2.20206392618303,-6.40006878016134,3.90667657911776],[-5.10415316482736,-0.555060943253923,1.39154173046427],[2.87490875660994,6.29993355608565,7.73221506974455],[1.52619149847879,2.98125194976881,-3.36883933541937],[-3.36525224268082,0.404446805980544,3.59923610035664],[2.48883953479035,-3.3371143243032,-11.1478955124859],[9.39418445105392,-4.19391731905434,-5.63439119050058],[1.67534412244636,1.49201833659468,-9.30021085849831],[1.11777599759293,-6.53645538606396,4.35759059850806],[1.88189967386148,-10.2233648150425,1.13445786435566],[-4.98949861513669,1.17817617667496,5.33973743843377],[0.901620248352875,3.50732671861733,-7.12198284959225],[10.9656095291862,4.01044247421221,-1.7611014827529],[-2.64687603385819,-3.33081415793701,0.32155024692616],[-5.02451133992683,-4.30498400983666,-1.99617345833184],[-6.49376783637342,3.06387528914371,-4.10462469946873],[1.21728280530222,12.3757285726236,-1.4373657178051],[-0.670635116812907,0.533397862802699,3.18394766002456],[10.0848927714356,3.12401733826941,-2.26027717956337],[1.40882298353736,11.4409233353377,-1.9310285304865],[0.0141059808631222,-1.76130318306065,-13.3647758928748],[9.09457870227644,-3.77223266046128,-4.11827021078415],[3.50771918495347,4.40876968300191,8.2635549529756],[1.19366712482988,-8.44485690334316,0.613988123391121],[1.14572380804694,-8.67224496618052,2.43504382306117],[5.82332009324071,-0.767318646753526,-9.946491802783],[-3.54780732838529,-0.0829785915135699,4.06493054139465],[3.35941251369163,3.71086489892552,8.72562537608917],[2.98447177059345,5.92714383670847,-11.2799027828109],[2.27159553837418,-2.31318578775958,11.1037304782233],[-4.8945524274625,-6.03419072846012,-10.5667362676484],[-8.7127972399676,0.425764832155741,-5.62263602938611],[2.91770294358728,-4.46700933001081,11.0685421169656],[2.74348738875902,-9.51587334020667,-2.20980793052989],[2.32308067294664,-2.53953917311202,-6.9568405091177],[9.01121824407287,4.98461936758075,-1.14156686715104],[-2.17593607685199,-2.41467984007542,-3.80281543549823],[7.43848448380166,-1.79283389930908,-10.5630465361604],[-3.74282956205015,-3.29662308580754,-10.4973286438794],[1.68641036801762,-2.44902310813261,12.4475216217224],[0.671686240376394,-0.138201039692121,-6.28326678018182],[2.59816927364605,5.50472634947086,9.22841384252997],[-6.39340986005387,7.66933724313448,8.02202389011827],[-4.41052110165163,4.33992361973087,-6.6471498550047],[0.592677514640664,-9.63215471658328,1.44668681752435],[2.7562280293564,-3.8345372931442,11.0205815956475],[0.771110327223378,-1.79600376256713,-2.51683145506943],[11.8546107474217,-0.00612207579846669,0.781485891759213],[-4.4178985099501,-5.93554540244701,7.64908182845603],[-0.563273901269207,6.59305573890819,-8.4979181209696],[-4.29055779989805,1.96706049537547,4.33395780780758],[-2.34585389780888,4.93381482562306,-7.82931303841593],[-2.18079140418118,-3.63664895241234,-0.919594393743962],[-3.90377681047751,-1.2659537146962,1.35937427011174],[4.51312929253811,-6.22010169780312,-1.2963571813533],[0.480701933611152,0.448485775263654,3.11203419450987],[-4.47099064435609,1.92517740168372,4.97225845571034],[3.14362707681367,11.6804559069091,-1.92232407601643],[-1.30071739431381,-3.57536063588924,-0.807898151226746],[-3.7489595104446,-4.07762369432209,-2.12420136673189],[-2.75213010416638,0.727570190292536,2.98447260985734],[-0.389418235173966,-0.79852600037607,-0.74046086409327],[3.59815693979016,-5.56921965766706,-5.44493324633625],[2.03736321710309,-10.6121381874941,-0.785064365690039],[1.58282386405094,6.32502372326956,7.66900069572147],[-5.15570124541464,-1.28193730458149,0.451926865271682],[1.72608786915673,-9.01030079870199,0.168345195083952],[3.62099056035161,11.1984365749538,-1.08786331755295],[1.05715442909434,-2.99469346002782,-11.9581752226398],[-6.35894031841517,7.49851443031618,8.79397718399265],[2.24346682900178,-7.96568464530711,1.841028640765],[-3.53718954910809,1.17009380290209,2.41952004173588],[2.24639428726264,3.82115463216767,7.86963776346173],[-3.50990036521738,-3.55594607392865,-8.2843978588473],[2.65564192851,-3.94281014428168,10.4934838087236],[2.53669319831724,-9.04967165629784,-1.22386787722946],[-1.12190881846309,3.43595816156295,-2.59633956918067],[3.62383398239661,11.2447542994938,-2.27974687721919],[-4.19147320873133,-5.21960596760344,-2.99385016934055],[1.98454125265605,4.75100014472801,9.11757074730073],[1.63959292802856,-8.40591591664975,1.03817893582064],[1.86588467662425,-7.47090351213233,-0.459482705872999],[1.63487461069757,-4.45027019171855,-4.99192523774423],[-5.60453399871264,3.23687002973399,-6.70154970393391],[1.41515221082451,-2.17599518834387,-10.5541334677864],[8.20700204138187,6.25856443482656,1.86507986941596],[2.15286530580583,1.41680336661718,-10.3933179894264],[-4.84783352769764,8.41404501142271,-4.83413854994273],[1.83593382275464,-7.59748515728205,2.9382539672065],[-2.72555636348347,4.27282099961054,-7.38129765482791],[-2.7289810297396,10.7516248782735,3.32945244214676],[1.61696672794838,1.57213863159552,-10.0422335905523],[-4.72153012748067,-6.32258356694914,7.2540253740815],[1.20324078385721,-3.36231294342624,13.3959638690313],[0.841507794156349,-5.36853209569616,4.23446589644173],[1.8058128786142,5.12525761019816,8.90383527491845],[-4.28628151707168,2.62864272785282,4.40008349217305],[3.67184976832287,11.4227099714188,-2.19866970559604],[7.54597547353567,-1.63083522471097,-10.5135330060169],[8.98338225239929,3.16676597939036,-1.84545139474511],[-3.29055411218027,12.1600647440514,3.61151457226192],[6.07652874468192,-0.622067277316318,-10.0811313898627],[8.13648507362891,3.19321999622766,-2.31977386692136],[2.56806583615473,5.00342208491616,9.33093552318812],[-6.03714642673463,-3.71687023403042,-4.41643778338217],[-8.65341473651301,-6.90398135166538,1.14061284332801],[-5.66029388405706,1.64446199691488,4.11833085493867],[4.22820764492069,-2.3731054916639,-6.72587569998853],[-4.49720780730703,0.629342930995713,4.424856480938],[-1.28276962258918,-2.39305420129419,-2.49710387621787],[1.87043835703279,-6.79396913319355,-10.4711101098959],[-2.65911399559306,0.615797769243797,-1.12821867339982],[-5.48697276432333,1.31399152455039,4.38310506338633],[4.33496248723999,10.9792590380379,-1.21017120162111],[3.4922235040471,11.7382749507132,-2.69676821470015],[2.75136228144749,-5.73156290321632,-4.87060619886691],[-5.91248048576398,-3.02527277670648,-5.44586707915363],[2.04468852694292,6.33035670027513,7.5885772480065],[2.51242120339154,-10.090378581108,-1.10283117909869],[3.40204903373675,10.930070197098,-2.01307894009826],[-3.57980904825389,-1.95881698695543,4.36173755633476],[-5.53235780841332,-4.9256406997868,-1.20347252204969],[2.14774437415641,5.62867235672693,7.24086602065241],[-2.93658398208723,-3.9600675436965,6.76085711246807],[9.34689977960889,2.36922391044036,0.991649698548869],[-5.21429312096441,10.1562244815755,-6.79139397047783],[1.10648966973864,-2.80365051964011,12.5273276154391],[0.0950586064540226,-2.78329311268166,-9.85034316287645],[2.83467515753455,4.46179105043822,7.83250822880887],[-4.44906552905743,7.58097478814194,-5.74598789724823],[4.31968212963563,4.73291322021165,3.16037200022091],[3.18793136112952,5.77205888665604,6.99632695725203],[1.93135606617274,11.9589415200633,-2.13933580847909],[-4.56776034283,-0.338758473935541,-0.625205302445306],[4.55871961891909,-1.33634050834901,-6.63249194531364],[-2.60665607527467,4.48020952255537,-7.12476334837551],[1.65182036391295,-7.80325890977982,3.89783543780574],[-4.6710417602515,-0.757950170783487,2.16952067692124],[3.64297578036279,-8.18718312191256,-1.56588646231317],[-8.36831890406732,-6.36449783780198,0.353087015758773],[-5.83733551550112,-2.83248139644292,-4.88346149423299],[9.02982987037046,-4.07094166843234,-1.36988003709968],[-4.90291213323923,-5.94195768674499,-2.56045190311622],[2.98828503192941,-10.195679930533,-1.35819226321903],[1.47722841099256,-9.04252443130801,-0.443239749082868],[-2.14471358879632,5.73819930596483,-0.681583995771162],[-4.5572988577954,0.534261754340328,4.69880315897317],[1.76630373227214,3.13432799376733,-3.11407914224644],[-4.88290715946058,-6.82450293734136,-2.32719085433574],[2.93846522162575,6.17452830521751,-11.9629212709167],[1.57725895000057,-6.51509755237937,2.82516613625053],[-5.96710331423345,-2.70823108665467,-4.853966927634],[4.43851338642013,-7.13499972129074,-1.37121308735145],[2.23643372592292,-2.64063566507319,-7.92545371284469],[-5.43745147417628,-1.4077416406968,1.30129292468418],[-2.2530079295971,5.02372968881288,-3.09355475793013],[8.07625549575882,4.63215291491142,-1.17929435234992],[2.00300466223336,-2.34667281232001,10.2458616412021],[2.66898813322454,-10.0133782047045,-0.140304849142675],[-3.86330165982366,-4.96464859219713,7.62495044256892],[3.60830245701919,6.48918109166471,7.49040393409872],[-3.23869024625031,7.6867091973711,8.45775520833863],[3.15290395118339,3.0950343789693,0.384259274179269],[3.69260345972245,11.1423027449147,-2.77698006529886],[-0.374295989792885,6.1544769377883,8.55200044373503],[1.7033973276967,-9.597090195274,2.39975123418009],[-4.51281448121173,-6.61447989531408,-9.05784593862178],[-4.0974460668637,0.316475412045988,4.34356604415427],[2.10639105433792,-6.52984703596919,3.71946690835588],[1.01752674134269,-2.828041811203,-11.5927144870152],[-5.30256140422715,1.2502083749154,3.02446153336803],[-2.00202382897661,-4.16505221542739,-0.276322143365537],[1.88698685733249,-2.99332695295489,-8.06951537226945],[-2.31487469593529,-2.40319752236413,9.21033966751538],[1.79346261697179,-8.57091995846052,0.220695804576195],[-9.38181275422486,-1.84195183917131,-3.81334736638479],[9.55089652669319,-4.32363158911421,-5.33619734910172],[2.93716980513878,-4.26025556708655,10.8513909202939],[3.20429169054293,5.37529414106839,8.63837912116644],[3.01584026028352,4.66934020555298,9.12944069616487],[0.746050044708597,0.306868764079165,-2.76178519315589],[9.41457419223348,-4.66728439095069,-5.76446843569073],[2.95360267409866,6.56928524779116,6.74051777667186],[11.5087866794219,4.08071041185587,-0.944111443356792],[8.11706626064275,4.0503460500416,-1.41137704255768],[0.818921459927632,-5.42996440536543,4.7736480365102],[3.06943399023331,6.69359254462257,8.11162427187671],[-2.77498838595203,7.18223219477615,-0.550089418541425],[1.91793908680488,-4.64966289590118,4.42683491153125],[-5.8373362695129,-5.96211424570984,-0.960883556480122],[3.30406317623121,-7.92512788151254,-1.50353830818345],[0.628157659642871,0.510873023389716,-2.90657212733312],[3.39671140393846,11.804337412376,-3.11313514131918],[-4.16952497417612,-6.34410253185849,-2.33994827087768],[0.805814345925208,-9.54553666776677,1.44911586484686],[1.40670432121462,-6.12595912694339,-0.0796712600475699],[2.7979719783709,6.04526322571303,7.90825526626208],[-8.74061034545929,-6.43759880824469,0.397243212652157],[3.52172343273711,10.6543964190839,-1.09958456357138],[7.65218214879444,5.2097611420058,-0.585019031163393],[3.57635079204704,6.3703715818589,8.43663167242041],[2.6632840283896,5.51185676178933,7.73791359319811],[-3.5133123552783,12.4504777489696,3.81205117778184],[-9.05365785240319,0.799736200062842,-5.35370198656602],[-4.84141506092445,0.241127292119658,2.36554259557904],[3.46523660843963,11.2700629291856,-1.69646695979681],[3.24713644690983,4.80616892959927,9.16044617088486],[-2.44394048414997,-0.736584103803253,-5.24142384407333],[2.39190823784958,-4.43208035844209,10.1363195373879],[0.602607564920911,-2.90215064799421,13.219462103865],[-4.39839653991211,-0.689578573557147,3.1208862495485],[0.270751548639807,-7.07025202958502,2.63077128265233],[3.18670684741536,-3.18920394205234,10.6754402492213],[-3.34710819425498,-3.63894090682878,-3.16627429363919],[-4.58689721766929,9.24257164954497,-4.36445144351143],[2.03418710707552,-6.73526683527731,3.75878871488597],[1.50189982183091,-4.81572433213917,0.943817498308111],[1.80532479358955,-5.08177804004819,2.30955618292915],[-3.18512927748832,-0.650953579073617,1.06425924799159],[0.897014026313964,-2.66301274515787,-2.66810128182707],[2.89789005079983,-9.6857831410058,0.117463222147394],[2.88314863107905,-5.16508813325669,-1.13909938697679],[8.82428011242258,5.06399674868543,-1.88284291443329],[3.3306935180385,-8.10886515845486,-0.537358929822157],[-3.89664780898285,-1.86239522222696,4.4519279600511],[9.01349609634079,-3.76937419173663,-2.37553964963328],[1.25171896669794,-2.52958059165503,-7.99766581265602],[4.56914949061174,1.77626386705131,-9.69879463649],[-2.8331397957688,-2.4214898059041,-3.0670915242935],[-2.13019936103893,-5.59504136957674,-1.82150943627536],[-3.47102609261269,5.25688716406212,-2.73974905732706],[-4.75773675181167,-6.24646114854226,7.39711203582106],[-2.82979353690004,5.36579539838246,0.281861442301165],[-8.50458769227733,-6.18200778592313,0.333355004930267],[2.21304911308767,-7.69200018476768,2.99679231847246],[-4.12749230297081,2.60909920382568,5.58024380697861],[-4.50608155050488,2.08355038062863,3.91238674993479],[-0.43143637861276,-7.55795219467274,-6.04485235275856],[1.99338226805306,6.62866295087034,-12.0644825240593],[3.28905928537704,-10.0724405258761,-1.18872232521221],[-6.60599755021318,2.72760823973315,-4.49602504561588],[7.53660524387445,-1.82239101945804,-10.5039815297812],[2.96957994965763,6.74645961830169,8.23931630421998],[0.645569974267464,6.27784969808639,9.16519951925882],[11.7072675076481,3.36251455882081,-1.4910194414834],[4.15151084974271,10.7945559090037,-2.38811437446482],[-5.38959695590311,6.70245867404672,8.67832264764028],[8.69571620078155,3.88377671823954,-1.99817989991565],[3.17355600071044,-10.0228870468803,-0.23559408111508],[-5.28620220502037,-0.822567648319858,-1.11642255476944],[3.03045490038029,11.2854609051284,-0.506085820770808],[-6.66195260590338,8.08881328100863,-3.73815285173412],[1.28139037492751,1.69887648135462,-10.1399904923588],[-5.97847283059024,-2.78952789557864,-5.07898461345019],[1.52813810801757,-5.60770722029795,1.61638511086448],[-3.50211277629929,-0.420123387055569,0.567216847986196],[-4.87417453869466,-0.858088928148053,2.97681319295438],[1.60113060765125,3.61270177567516,-6.33573229502114],[-3.38650887223777,4.87991609873609,0.914864814145854],[2.37413529602381,2.97373022087388,0.935784744035357],[3.36558352082172,5.85501496007735,7.16098672614451],[0.30264273339395,-1.0271977736557,0.314934504009669],[-6.36176653122607,-2.8433599392999,-5.15548556922566],[1.41282208682839,-6.28009117506012,2.03236667673432],[0.942814499750331,-9.48134647711212,1.44559773193748],[3.30542589132655,0.827102223214181,-8.96701984987666],[-7.73791642324939,-0.167611741992553,-8.80165545415036],[2.89429667956553,4.18635943383319,7.58838910620295],[2.32598186302844,3.90180883866164,7.42678046895388],[0.0215470750893939,9.16958884548601,-7.44573143809566],[7.78692564234139,2.94197831138001,-1.3848612781293],[1.82932653930239,4.21289567422179,8.17613156527698],[11.3723830487958,-0.416789108131951,1.07328615633119],[-6.26125454887781,-3.29712717516369,-4.89955482469727],[0.183104874341053,1.67274253754797,-5.05508347601599],[2.89004391150559,-3.59535392095688,-10.8428301029386],[2.69738333562952,9.63519754981709,-1.55033527215104],[-5.12759694096784,-0.457527950854299,0.395865807993176],[-4.5156673771811,-0.458685799539065,4.9730210461634],[3.45379371936326,-7.82613407862044,-2.05235255392416],[1.58631657831817,-2.6527299737271,-7.4851271258082],[-9.01357167784185,-0.556142189848679,-5.51974843735554],[-0.613459636786699,-4.56010067645257,1.13150762546902],[1.70691639073879,6.21432582646331,6.45976088566416],[-6.25609359841481,8.22157270766939,-4.30374218756985],[0.549013478545247,0.155170983870864,-1.87262389907541],[-5.68087101967828,0.0411956017821221,-1.08789684735598],[7.41700204297888,-1.55866638330915,-10.6692473921666],[1.92587341568509,3.99780246548574,-6.15322017410842],[1.60285884064681,5.68489590476679,8.72382290981794],[-6.1503681187912,-3.00623196537516,5.02003060039134],[1.5990779102047,-6.99434964480829,2.02258507113345],[-4.86813910712154,-4.97073931517742,-1.95137446195743],[-6.23215379327573,-3.10115524505191,-5.26340142263416],[-4.83563676595143,7.5132203960849,7.95224862115812],[-0.993165257694047,-5.41202787521386,3.34120591748189],[-3.86908675401765,-4.76684554367235,-2.51189508734271],[3.55756050236565,5.27825476001816,8.30055867732484],[2.97262879054753,5.21512249766585,8.26661107550534],[1.59061636357893,5.14983375982374,7.40838122431136],[1.65959521435287,-9.27890850331033,2.36827870110647],[-6.08086776275577,7.65800215725292,8.16259573054715],[3.51582116023188,-5.87453860398814,-4.80953593653785],[-1.51238457579972,2.59167085367018,-1.31162284043864],[1.02421502647382,-4.69993093553622,-5.32416947849261],[-7.61151231497943,-6.05984894063764,-0.0574625290923983],[1.73286005880442,-5.51323946749152,3.23518756023181],[-4.25575081538057,-1.05613128831983,2.59452067847388],[-0.307181531304052,9.08945407431159,-7.16906107163268],[4.1133513580217,4.34473177569378,8.72200864698389],[11.6275104910867,4.13395251975269,-1.12973988128972],[-0.205457093017958,-2.70768719413193,10.8612550567995],[-2.29372141534164,-3.55208548565357,-9.39496034710382],[-4.16383464198589,6.38136254472738,8.69188732139431],[1.21174234690301,-1.02444638207843,-6.61130357665761],[-4.25463968818969,1.90361892574397,5.31718231968905],[10.6636906281296,1.15861893843398,-0.774474468577713],[0.990034961760229,-5.1618969059451,11.0358217122035],[0.446991946991106,-3.30178981378575,11.4948810275929],[-3.8979693168564,1.28699265396346,3.38343346243244],[-5.39995727908603,-1.50539761890383,-0.756877020690624],[0.296845909698442,-6.57934076521095,3.02936594010594],[0.238207568324569,-7.97734773661559,1.61844071824346],[-2.67974521490872,-3.47121266010434,-1.89072397438651],[8.91208942275297,3.31929625052503,-2.27410497385343],[2.24533663310727,-4.75642757522393,11.1947618650853],[1.16005682364547,1.9037657365796,-2.77869408190567],[-4.24509311488237,0.998792569468095,2.0728865480668],[1.99236164694931,-10.1933128204726,-0.590940637955831],[-2.84171683025217,-1.65101053666393,-4.30655095644676],[-2.3413659277208,1.79794768332125,-6.80921689848819],[2.1749388439907,6.45655391478557,8.09326649086647],[2.19148486316209,-4.88741141613861,11.1462660438628],[-2.2270142827174,0.707030673298279,4.20005838024888],[-2.3485847165898,5.40292388298741,1.1139422084068],[-1.79477058554414,-4.98049986650615,1.67532006487493],[10.0445044825875,-0.342838630165508,-0.368274230154222],[2.18648144694781,5.2222528401349,8.56145459899882],[-1.164601101105,1.67897370868608,-2.43905327116529],[-5.27095265522392,-0.568130143673433,-1.60847122509653],[1.8593501019482,-7.07480254977456,1.77791846456605],[-2.5307603076048,-2.76503518068357,-0.522934908972256],[1.46162229667861,-5.37003684689564,10.5981160187831],[-3.82767118445151,6.8611826961043,7.82114220364872],[-2.82410179755127,-5.1319300987159,-7.00076398744786],[1.19374085582713,-8.05879328423549,0.973119285664938],[2.98225650233915,12.1219641592589,-1.46854037881699],[-6.26101469002088,-2.97231116667923,-5.03406971234439],[-5.94131681619199,2.87132511531092,-5.61450390433397],[-4.67226781029645,-6.34694011732652,-9.88046863950713],[0.0605673936725969,0.881415014369954,-8.11860574464204],[2.46684674410354,6.27323713611514,-12.515608531276],[4.16766838499635,-8.86716372551486,-0.544074004777213],[1.56210688229231,4.02272853162231,-4.03017309192709],[0.290274889270832,0.274090583074213,-7.4220176514651],[3.18392708665768,6.2975263668267,7.43603748295566],[4.14243313282021,-5.9533921952893,-1.29934856333506],[-4.09894311669647,-5.23629988026613,-9.6155360078488],[-6.24047070334064,9.47586160281766,-3.72748082243925],[1.69561126066794,2.74925271510788,-2.64013233486325],[-5.23796770103173,6.38075176335052,8.60878409254501],[0.513153425172145,-2.73166479486416,13.374263001588],[3.17143880904185,-9.54056998203519,0.163356965320327],[2.82175973472433,-9.88356274289201,-0.9290683761241],[1.84889207731444,-4.92166332238441,10.5842860819539],[2.7714637384052,4.56492230665586,8.24218254007843],[0.808332248322123,4.07534726544466,-6.24203686426293],[3.28708969856579,-5.80100968472462,-4.61787667763411],[-5.68253571624427,3.84986898561268,-5.55959429273414],[-5.07964727624902,-6.15025074441146,-9.74069893475541],[1.4672761848367,-3.72878175209632,-1.63593389335338],[0.435630635317027,-2.79085849250141,13.0248302546677],[0.970746021063941,-4.75322438869932,2.80499637070775],[-4.27177798909719,1.99999756620608,-4.81841301746319],[0.986655383250674,-6.97434850094818,2.93663759313602],[7.21233278302122,4.93065341692604,1.05089033967974],[-3.14366003172703,-3.16460483285176,-0.289481061694614],[-3.42918562817887,7.06258008858026,-1.10586050517654],[3.4106737037962,-8.93092375294234,-1.25872814991387],[2.32300299170692,3.69486456674966,7.45694131404402],[2.08214329045777,-10.0157113649782,1.18243040510876],[7.54875256692419,5.45570799478705,2.17104030204641],[3.9744287989294,-8.40352636341918,-0.468595226322171],[-2.86469859723674,-2.43903458290799,-4.62408331614389],[-0.978420736203732,0.535785193129139,-7.27155381732288],[2.83183250979071,10.0598434466115,-1.73327844478872],[-3.24700865660875,3.62815947343928,5.65184681986408],[2.19708758180323,0.711449594315628,-7.03920735561889],[-3.83534500350896,0.771518188696035,5.24038289132712],[-4.83505534368127,1.54976935563882,2.50069520790861],[0.492324199871534,1.33637875623246,-2.23137047962105],[-1.65467416214567,-0.894318926001466,-1.81166680151552],[7.52895898866757,4.89437098415459,-1.22625856601506],[-0.991535887497163,1.61862648205655,-2.25072007463044],[-4.05964267352,8.0143282785175,8.37437362572785],[-6.05240051632741,-3.80660815467397,-4.36468164663637],[2.5609806295131,-9.46520008791551,-1.48760440695794],[2.53961323916982,1.64193888830835,-10.186605857254],[2.82720224896543,-8.8246335622338,-2.16226765334633],[3.32083239544447,4.15605627736762,8.06076065409483],[2.95490962884396,0.0788041206934766,-12.2798189051323],[-2.86242971165797,-2.69552829713795,-0.317824157697146],[7.19461461720201,2.64309011676049,-1.55086202099555],[7.39104319382772,3.63936191622227,-0.0292598927725632],[-1.7556740714238,-0.962893322575153,0.759509959839021],[1.76533396829993,5.7109329418248,7.61140431382143],[0.625889088472937,-3.29428893827702,11.6922093647203],[-9.01730434107154,-0.16524195896159,-5.09070795635236],[1.27172836397203,4.15875243755073,-5.79329395625897],[-3.83815619953706,0.491524120250037,2.87408294148469],[4.26971478892187,1.77689983434964,-9.71447073874955],[1.32954156657635,2.87174228915039,-3.60717256538948],[3.85356437975408,3.55289591050042,1.63105516261448],[1.6817322178583,-6.47643622931213,4.42169190747169],[-3.07643334307739,0.375810003700236,4.39587655175478],[-1.76629263401013,0.846808507448235,3.52995272378678],[-3.84401668510887,0.365420861420635,2.46826474105695],[-4.10223447201877,0.671110066966163,5.78643655148366],[11.5250439246103,3.28853739485902,-1.14592727992142],[0.615182866905795,0.121960133828664,-2.62031176023172],[0.0697419011352256,0.220370506898013,-2.73626223791917],[-6.36670508308196,-5.31627184139907,7.56563823310329],[-5.43709302574849,-1.51763773069776,-6.53405630634558],[2.6754862229088,4.16704018310917,8.09144051505538],[1.77029853040874,6.74811448966001,8.2668111646473],[2.00928574583898,4.45422849463684,8.8962537809857],[-6.64020905057456,-5.61662970600045,7.31463727251917],[-4.6053475063325,-6.22774055618948,-9.87575326422039],[-2.87269819115345,-4.52613707858874,-8.52617681679154],[0.770452434912594,-3.7945262960959,12.171685143567],[0.576861406933366,-6.25654745274804,4.21580529471827],[-2.03919985894782,-3.72367612384237,-9.5305590374002],[0.844603924947556,0.675743003693789,3.32470140932564],[4.77771301068225,1.6859825939533,-9.79681676017179],[-2.03018803000531,-0.6270306782682,-4.53507187645364],[-3.20968391005211,-6.23958861114507,6.2554977965531],[4.16445361790421,-5.50730424721698,-1.08967293050166],[-9.5332736053897,0.171607708728444,-5.78542889811905],[-5.76177244484286,-3.25134891362069,-4.85429701790305],[-5.44892100686103,0.857119789748672,5.19482627335977],[-0.317518515455526,6.28137842306419,9.16733544656613],[1.86226261626557,-4.16666168079467,11.021536982936],[1.84772374495465,1.29848538856748,-5.40242531790417],[3.48204635813897,-9.34111312387469,-1.26151735710722],[1.80589879130896,-6.32161671741852,3.3734985740729],[2.25721221901135,-2.21929606241996,11.1755579418256],[-1.7826335932869,6.18249234664307,-0.318013242083081],[3.89664510006455,-7.00882237213686,-1.07690239073791],[2.52924810015147,6.4410360766665,7.85127784226193],[4.07385149518404,-0.988944763413004,-11.6659589684829],[-3.41446764211441,0.10526341217671,5.11646859670234],[-2.42734835199034,6.01622865707604,-0.213926124855126],[2.80511878393823,-9.49941437301683,-0.63676196626193],[2.70923297396226,-9.70060601675629,1.13234463054642],[2.84731238017977,6.34956929951879,7.21097684962736],[-4.75216844865799,-6.33923426443228,-10.3010660226363],[-4.42273473921449,-6.78006430934537,-2.7447299706909],[-1.84353136124764,-1.81177589052665,-4.24939868151867],[0.335222913983768,-8.37982666687152,0.738211100458824],[-5.13546990250856,-5.63127477376748,-1.12108845925995],[2.07339543583169,6.28078051036975,-11.107965090663],[2.2761975914486,-4.58851057909668,10.2029135185403],[1.18250549460854,0.209485567286304,3.71804044759776],[4.00156884651528,-8.93140063492008,-0.873901916995877],[-3.04890540977292,4.42670269835057,0.999425995744217],[-0.745104823401281,-0.567930298187567,3.07921552671639],[-3.5978093804339,11.8929304361276,3.86847382642099],[-5.99684771532602,10.9176380245401,-4.56073168007947],[0.36294758190792,-7.99293185603437,2.08749545383259],[0.753386735185073,-8.25139044381161,0.486599627932598],[3.64128236504149,-9.7682959088824,-1.35748893477476],[8.86521737191767,-3.51891034387411,-5.30567495857817],[1.18660736264773,11.9805158109782,-2.30440608313575],[2.50712966296556,-4.46908689148009,10.2146397755948],[-5.21771098697933,1.75874357495215,2.73083417562709],[-2.36456108697661,-0.396781085459739,-0.654412049456557],[3.05621290715311,3.92854556652599,7.89856568713691],[2.6897743266429,-6.771435495131,-1.30281878837185],[-0.68068134886339,-6.08435732681822,1.96605605900519],[-5.18097508268952,-5.53125571800833,-2.01560184647294],[-3.08741032672064,-0.746390978962533,3.58533260149037],[-4.03171390551526,0.491859913628722,5.10545005686344],[11.5264229501559,0.931000491835824,-0.978003703089947],[-1.35730881685988,-3.30611878897661,-0.602894144032521],[-6.31977288492502,-4.30403251872113,-3.94974781557793],[1.92567438609665,-8.53820830075291,3.65654765670117],[-5.15843598196852,-1.23977730663602,-1.37651854820749],[1.46904951488577,-6.88162103531509,4.57673556516013],[2.6019334042206,-9.78263546071035,-0.506411944329737],[-2.87100093841648,-0.560092035309542,3.02132308616747],[-7.39754371353143,-0.680424558797699,-4.83609636942343],[2.16725476989655,6.58340101802473,7.66896170766052],[-4.24540315835828,-6.23295605138641,-9.69784572849286],[4.93914690305711,1.94936550406904,-8.6269393176167],[-3.0541421393621,11.118926147496,3.38803306011791],[4.33106321062165,5.97661915385934,2.62310644877457],[1.95039380389301,1.72327821848436,-10.3529889727761],[1.28565002516185,6.5045522646482,7.68350084185531],[-4.63699063822254,-1.31453931067958,2.68684003631238],[0.998988867250122,-3.13442011460545,12.424748394479],[0.696022809404785,0.114867224007312,2.8828497176753],[-5.87114408167004,-6.46491929305,7.38269150899948],[-4.43596273655377,-0.918779407569518,2.84036309333307],[3.95817891610557,-7.31608605985501,-1.65970941867102],[-3.78565824204787,6.89619441626495,8.97346969511582],[-3.76092368580004,1.49765132437391,-6.40339084856658],[3.50594406404306,-7.89648636598586,-0.803493085182821],[-4.78368294155539,-0.325521448640079,2.32553608843476],[2.8478069531179,6.49759632855785,8.21433566574319],[1.23132841680538,-4.79215398601466,2.0844359242594],[-5.09061815081993,1.95286308356084,4.88952096153981],[3.38335004413554,6.09582645271395,7.11837759004465],[9.118624412776,2.21970985168703,-2.02125118668872],[2.70079881137106,-7.23959701592087,-1.6330353342218],[-3.44762359245585,5.1518783778481,-2.69441560802727],[7.92870609514581,2.97395643611405,-1.22820567838433],[-5.03178221086513,-6.36722502360475,-2.28450729396333],[-5.75091864200967,8.0594000534433,8.70766156102009],[-4.77832262391787,1.89183011096364,3.09064782799001],[3.74659261164905,10.251042177036,-0.967911894180246],[-4.73077096322003,8.79955137275311,-7.68964929284595],[8.86654941273598,3.1888887204168,-1.40688775156868],[2.13704249119533,-3.96894032063444,-1.46701874601997],[-0.446657435054041,-1.32026930154553,-0.290896492393483],[1.25067209237508,-5.75616285526034,4.96610601020849],[-4.46440059761651,0.806164645301807,3.18509453885834],[2.11000596414992,-4.8242757671133,1.15304537050556],[-6.56151076054174,-6.51161713613716,-0.352665389946053],[-0.174289942830655,10.001412427492,2.70314632053826],[-2.34830133196385,4.3481309469467,-2.25302749482477],[3.75145986771092,-5.95901670180801,-1.26876619251992],[0.262029858105917,1.86200472784526,-6.89935828570175],[2.62477223710149,4.07720573415393,8.03199582641556],[7.14323124272224,-1.64160253671425,-10.5943216930559],[3.69309975845876,0.557412876330094,-8.81572888865918],[9.96440506037861,3.58998957015519,-2.50471419248745],[-4.04887741480282,3.47589815787416,5.55622662562972],[-1.45488725350614,3.22743651981967,-2.23503690394893],[-2.52545960833716,4.84695855967192,1.02196819936787],[-4.69740792090506,2.33422248589986,4.51652914021893],[-4.86579991989671,10.1545911556849,-6.81342304579156],[2.06733615807382,-7.43642692946349,3.56976047564542],[-2.32499593528334,-0.593974238840231,0.350967810861367],[-2.80851530016313,4.85093470516666,-1.70431224198353],[-4.0331497981349,7.18938448981492,-5.92488464192663],[4.2477520485424,-6.52102999980509,-1.82890608750271],[1.04919024349521,-4.5430397663829,11.0340854624121],[-8.92814826078149,-5.81109230410934,0.885537452914507],[2.85472226360482,-9.72003680884007,-1.85853190842637],[1.21667942150576,-4.46268864126042,3.69853975169398],[-9.43762478381669,0.495068044073449,-6.0590794140759],[-4.0823654922113,6.76294333718221,8.65742322401952],[7.99525053668938,6.0952013556918,1.39082437481322],[0.903667794954639,2.06759132312534,-2.47708351890133],[8.55523873764915,2.05345909050198,-1.58042264649381],[2.0518881311877,-4.45377681272207,10.4095769596279],[-4.5846705181458,8.20056289218336,-5.95633426228174],[0.624270076581233,-5.4984280059091,11.5392934451345],[0.706710123189119,-3.32253042536964,-11.8855721741147],[1.38282242743664,11.5924967059423,-1.44436741889071],[-5.46605865600563,7.05413443261236,8.97367206310019],[2.67094874727305,-5.59170310324051,-1.39787221025513],[11.5858251540893,3.08409450689361,-1.9268547577611],[2.79205232280144,-9.73615448875868,0.9297462189405],[1.90983612495871,-4.82021444109934,-0.453902871097059],[-3.6937657873636,12.0259398962648,3.54522646573775],[-2.16349631107687,-0.421459025505764,0.139336220704104],[1.23289825190736,-7.27226858279537,-0.509362709008883],[-3.96510499149427,-6.33975197063919,-2.34121862592296],[-2.74629507566714,-2.15354115003299,-4.75317869695652],[-4.3429477956701,-6.19849549107559,-1.46807742925981],[2.63241836247224,-4.07868891285251,10.2377906950076],[2.47762619570652,6.59275426208629,8.59434324256283],[8.08233873655439,-2.96680420848422,-4.848361815532],[4.90592350824553,-1.82068777698379,-6.72342981663184],[7.15492053217239,-1.86985705246988,-10.1601916390039],[1.76947947544125,-7.550192779932,4.31745501563677],[-1.02672613460833,-0.00106547636198717,3.38917062758709],[-3.16894632612386,-6.42841713927703,-1.33457099180862],[-0.187125071227329,2.3508281349911,-5.67425571059406],[-3.62996358799074,3.53991061379022,5.84186153201167],[3.56380092702048,5.15949857870298,7.29020070636703],[-6.18757121138409,-5.93892945892106,7.52588082361585],[2.13730828885552,-5.36463046955564,-5.34160911672265],[-0.642493720702081,4.5661402532303,-3.38281871878434],[-5.73226721964625,7.51297340675841,8.32616602876279],[-3.54439914650713,3.68352932626062,5.90480389324409],[-9.45351518340428,-0.40423777805865,-4.82888704065965],[3.2970129206721,-4.90127334447026,10.8693716537499],[3.64879395012181,-9.55562948580446,-1.46704214731365],[2.16460652889532,-2.95507048732974,10.5596322787672],[0.521082099703576,-6.81219400740244,3.84039611398171],[-9.38631803805843,-0.865238346266531,-4.93647718733756],[1.89307218558025,-10.4186817213331,-0.677217235331482],[0.886794495301915,1.22119008232126,-9.09477626305548],[0.0521515617662814,1.25945245333269,-5.62304416203325],[-9.77560648756965,1.21713769205625,-5.96714468164251],[1.6516589634353,-5.54390518620567,3.31459556193032],[2.23158939278123,-8.57075431242997,3.10113340751514],[-5.05869553695545,-2.82766904823781,-3.8114346264523],[2.4218667050659,5.81117226311307,-11.4295595047186],[1.492940648315,-2.74925859808506,10.9451077424519],[-6.24603333850067,7.2302430706103,8.1916616262479],[-4.85903838473008,7.91636345118593,9.22157139000139],[3.52704199214319,4.64575646952835,7.96525496796946],[3.99440900884181,5.37248651729418,7.24196908296362],[2.99292967102343,-7.65677795508104,-0.938805180607705],[-3.60994905236955,12.349582070733,4.20048012371953],[-3.17438226254651,-0.432939668258776,3.00885725294402],[-2.29418117492318,0.865000835894298,3.57994729608297],[2.3466136566336,-4.99302264258406,11.25632439318],[4.2153176043808,1.72666138930849,-9.10648141706272],[-1.8781635994338,-3.69989809867653,-0.150834143967068],[-2.68179983028986,6.37964361137524,0.274087983077602],[4.37057567982665,-1.57837462629946,-11.2472411158289],[-4.99765786878021,1.25624523831281,3.11594720008275],[8.66306563496952,-3.55796778481068,-5.15093466491164],[-5.24761215148918,-1.3522956608052,0.0954948639765781],[-0.625693111126503,0.632243020901027,3.35239040819391],[1.16031649056549,-3.76149974015696,-0.238775818470429],[4.23712411016002,1.44868975667355,-9.16342152337056],[-6.59470285722449,-6.18819456160265,-0.733160599670398],[3.32861650679779,3.48763144540789,7.9795853697045],[-4.35593203496932,1.69425172477833,4.3868606213276],[-3.56230283637803,-5.56739147061143,-2.07038286836092],[1.30229858650362,-8.3327377607607,3.08294232431695],[-7.7997396779162,-6.36188336215456,0.166824148679788],[-2.15498716129147,6.69030759455392,-1.51409065007579],[2.1526876285967,-6.21036961199344,4.12000492635998],[1.90705399561414,4.26168574203699,-6.06913359345177],[2.24592855780607,6.4250123895438,7.31434830455915],[3.98677913957726,6.25893227388102,8.36006712971961],[-1.01379270922333,-6.83614265842256,-1.38759079358138],[-9.77607656135318,-0.480390510270853,-4.67351211171146],[0.115371924945307,-1.64641727000147,-11.2899866541959],[3.14969031848848,5.08777922851598,8.5968920597943],[-3.8787252483232,5.04255722975915,-2.59702424051092],[-5.27117043656745,-1.55115194989603,0.767900733696716],[-4.8462339164589,-1.41244442292328,-6.57368585760802],[-0.526319504199187,0.340877254380451,-2.85815721149954],[1.93857138896742,-9.8968985348446,1.28769565433975],[0.0734619594116667,-7.61376204207553,0.535954285630118],[1.03824748764474,-6.50508046357648,1.23263374986487],[3.88731888287672,-8.05568564564038,-0.878327462451318],[8.52776906920457,3.031544088825,-0.825344228801595],[3.7706439818076,-1.05152577406343,-4.00304509326557],[-5.48362259398955,-5.31325861154164,7.77507857343873],[-4.09881724276583,-1.34224281007412,2.50398061710784],[0.683355855010428,-4.88052415160055,3.44971020676445],[-5.54679518599745,-1.42344115426406,-1.19709608176536],[-8.12173334938074,-0.456070264009537,-8.24252043171003],[-6.65564340294129,2.77028390929609,-6.40206292666249],[-4.76794068687925,-3.22093655929621,-9.13211453737004],[-1.90090945798177,-2.66432842660899,-3.39573151540413],[0.170871463858412,-2.62494105407341,-0.948144958802643],[1.01155339655501,-5.05448899754228,3.34447570284642],[-5.32072654739814,6.9857447441884,8.17223935161508],[1.65128186947208,10.7490830356055,-1.74218111230339],[1.47126543948965,3.79211356067758,-6.65028670841862],[-4.91878204935127,-1.44937070608465,2.408773764649],[1.65093294619291,-3.50892418928838,11.2507846835654],[-4.87256427270954,-6.40452648822045,-9.46866666083949],[0.734310985679361,-7.89466992925334,3.11975592716528],[-1.1663628736743,-5.29955862169073,1.93066806750317],[0.565935736036633,-2.89978431830979,11.9826483464489],[0.342598147419641,-4.26645568151561,-1.54361032275301],[-4.4960346245752,1.48118707837413,3.96468268064034],[4.64554333300151,-0.217635103869755,-3.15291887663639],[-1.21631735509026,10.1204272885658,3.26353331534695],[-3.39547172062211,-4.4859210970816,-8.86041318763009],[0.396891205114996,6.25754424385386,7.21631147392634],[4.71230301702083,1.6798720807869,-8.45054677259313],[1.55906431794441,-4.78541019482163,4.07679806653131],[-3.34182915852301,-6.02985632631983,-2.41168850104811],[1.64854590193682,0.509719194201985,3.4934506581825],[3.6867841744602,-5.59833875870389,-4.9028252859143],[-7.60578089186129,-6.24130964108983,-0.184871332991264],[2.68594549567838,-10.2231806584598,-1.21651172603931],[8.39677338644259,2.73223829467556,-1.02063071339565],[4.32004249301535,-5.09784145869018,-1.27418217198894],[0.536811911033646,0.808348336938667,2.79548080570297],[-4.95492827460866,-0.644010468433131,-1.26723525199632],[-5.58731459569354,-6.20356153474971,-2.03499816853536],[-0.212394068419521,-7.50955355816006,-6.16916068581885],[-5.87477661628776,-3.1947264707938,4.72825476589559],[3.51269773914162,-5.74282101946253,-0.900402489090831],[-2.13316171428198,-0.848887918917623,2.4768037755724],[2.86544127017333,-8.69671645150977,-1.16854148518944],[0.357234918462152,0.995021866503036,3.56200119391344],[-4.44118832269418,-0.47955660478962,3.54065710984583],[-4.44744040850858,1.13125528981299,4.1161972956969],[-0.134854705835928,-1.54515687306224,-11.3325846020214],[-2.32976165488418,5.06710212281705,-7.13874542903552],[1.51151862848719,-5.80789368134793,11.0509935562455],[-4.85010907018921,-5.74719594338535,-9.83265737472889],[7.12071675349067,-1.22322711552727,-10.6618992742319],[8.44613717964863,3.94493334794325,-2.14691831490406],[-0.028009977321851,4.68670841549811,-1.7393574868281],[-4.9224563282186,-0.293107159847602,2.73097702980948],[8.93696422441521,-3.38637369677537,-4.57239542743413],[1.10711660197382,0.855548601597172,3.84085430293763],[-3.82113120092948,4.11175481517453,-7.07397176509158],[-6.50203213873479,7.11286317743082,8.91926937162683],[0.444599431365814,9.28162942680114,-7.39900969989014],[-0.57210521231162,0.962851874464575,4.11269533478698],[0.756047930116488,-3.54312935397268,8.63501646897058],[1.40405480082642,-4.5699267899808,-2.4811657564116],[-3.69229540984921,0.189807116971775,4.00152503698425],[-6.37782797627713,-1.80081534206439,3.72567463230256],[-4.96191834114745,8.47290945812685,7.93513826568971],[8.97044067951134,3.81994807606557,-2.91548722648134],[-3.3168906099661,0.382837629080498,4.75797954298462],[2.77546852235349,10.5018798228395,-1.59534899049094],[3.64665151029329,-7.5304097293867,-2.16777531869672],[-3.76522367883729,-3.72588641788012,-10.5440745801927],[-2.44906274837096,-0.54944646481381,-0.320502102089242],[4.06156115732695,-2.33606154755373,-6.79771090495856],[-3.90864243316018,0.88343813604774,4.57816561068977],[9.81554736967313,-0.986264714328748,-0.478226836931977],[-4.16365906856716,7.18176557699509,8.85182341999792],[1.46100649354955,-0.954858372671106,-6.17591097110602],[2.05720817555271,6.22706146704425,9.17790407113885],[-2.39865419324688,-3.43477653582445,6.48768468859502],[-2.06559298846413,-4.94361121584007,-2.22059521224527],[-4.1759838396766,7.79555020908333,8.9183858786511],[-1.51933541105622,7.35652771864378,-7.04738015920786],[-4.1084473960703,1.96517912647884,-6.50768671897994],[8.54171537872378,-4.10110982111673,-1.21853164560514],[2.43825062921021,10.3980414642611,-1.27599984464462],[-1.6898617890341,-5.86140708626082,-2.18396559052912],[1.71201509796346,1.68388856420652,-9.24363672598828],[7.72600627295561,5.54320368996992,1.92475348257026],[-2.54801469322688,5.69465227819478,-2.85677022043552],[-3.70623355245748,1.03690921742344,2.90863944596453],[2.66663127982626,5.45425811062156,7.00161159927738],[1.10965661647453,-8.84948010823412,2.84378099253017],[-2.61995220329572,-3.18646921921199,-8.97422828875296],[-5.03403402081543,1.6385143170377,4.15897481179099],[1.29694325173658,-5.10128530665486,-5.48182486982378],[-4.08739413681981,-7.06211025026231,-2.88541461978878],[4.60819034706834,-6.13907122250497,-1.58605821845388],[-5.02679902638317,-0.14639295875178,1.00720659682933],[1.06695482481366,-6.14046739287128,4.59353119919239],[1.37596022856365,3.86347018157702,-6.42145173884078],[1.62422528146833,-5.82092019956625,11.1741582309646],[-2.66573402919305,6.95836420803912,-1.37750239382077],[-2.67757941207685,4.67576330926697,-7.34953860393571],[8.20790643655544,-4.25589583696495,-1.62546433764642],[3.90477111055896,-2.52752927503473,-6.72579674994165],[3.12900008717432,9.79006023088814,-1.54209566995072],[1.71425371850444,3.01271286548944,-3.45867065990433],[0.211228715606234,-0.27911687995258,3.52584316165595],[9.91117159917098,4.35519611383227,-2.11547038964523],[-7.34949929140906,-0.527786629898725,-4.24673746463602],[2.34402925542949,3.84704562146596,-5.74142760770176],[2.88646574283219,-3.16152891430233,-3.54574314478135],[1.16048045850057,-3.76658440562515,10.3573608411736],[-0.228795729475566,-7.58300773780104,0.272301133202135],[-1.42519311034192,2.30686294130331,-1.99278497790383],[3.68771311806866,-8.06691745050783,-1.73927247383402],[10.9819760886723,0.17966518753546,-0.810431786415649],[4.53555430129441,6.03217455386304,8.20281754210427],[1.24442203920372,-4.33308007137685,-2.46068977940816],[3.47933300455345,4.93983666088024,8.83076394968847],[-2.73141749371638,-2.33795384956482,-6.24018456178196],[-3.7075632151896,-2.22451829399159,4.34674926964149],[-4.38305221013323,5.51505312618158,0.0343036054748577],[-4.34626932625044,1.88687731469125,5.47991049169002],[-2.01481403184403,4.93322937532654,-6.55279130962434],[-7.09464878112319,-5.77515220552668,7.2217387928412],[-0.446535221726975,9.06318924306462,-7.29033836411928],[-5.99334808359524,-3.34474858843239,-5.25725833647248],[0.101918487259599,-1.03992945585333,0.221467452702825],[-4.46257713811118,-0.513925697975181,2.16644076349567],[-4.57195078357439,-0.948873844047755,2.96338885013725],[3.18748494437284,-5.08308079725888,-0.854159222119366],[-4.729942381076,-5.92500238880947,-2.78603685833471],[1.94078464435491,-3.32160762553222,12.3124166199771],[1.42571690440751,-5.91047318250192,4.66960342538117],[1.06971501037317,-4.30819045921209,-2.26193016263697],[-4.0764355233758,0.437043615247307,4.88900963029501],[3.41355737512758,-5.34469959400251,-1.12831283419636],[0.981246175053415,-5.0914954850716,-5.23708450841637],[0.260552044540216,1.88340076856931,-6.94580441078948],[4.20477958735799,5.07964432987651,2.88182425346219],[1.78166652755888,-5.81190244021012,-10.4734355940989],[-0.456767645551736,2.12244708176988,-4.95020470159132],[1.51717954315518,5.60047979239684,8.80586340018493],[9.05552773058066,2.66868128695803,-0.986909524537338],[-2.30348755907607,0.38320663355016,4.95000554496267],[1.0285632803726,-3.48100836774394,-2.5976202638074],[-3.20555086745247,4.28355172924782,-6.88712481690868],[-0.650771820382607,-1.65230136026898,-2.59455063379724],[-0.0586519709098274,-9.14950705646617,1.23194120800579],[3.36611096575001,-3.46975338971164,11.8512393287545],[1.94777266988192,-8.88878691351342,2.54759016628913],[-1.33454779895558,7.39582218465992,-6.60585172843793],[-5.10875570232597,0.909177243231147,5.20074246223379],[3.72681291440052,10.8090688459456,-1.9126965890814],[10.2185325351637,2.44672378408097,-2.53180983381988],[2.4582247124452,-7.62533578730422,2.03894454970635],[0.823832874863542,-8.76379326133913,0.527470664761028],[3.56913225151533,4.99586736262322,9.181641164416],[-4.97339161449464,9.1742795776589,-4.23597123269362],[3.20636422076739,4.62230508414082,7.75692420626288],[-5.59042888993855,7.62356231369358,8.04439900352907],[-5.88869715531056,-0.543940377759936,-0.628484831242703],[-9.35307182865018,1.12390978012195,-6.40227201600282],[-1.82589779422315,-3.24592222063289,-0.42812984200656],[-2.89728304691778,4.36354826044995,0.300652974954276],[-2.94398306346149,-4.39500154604023,-8.47823084826407],[2.14601042991765,0.752956662404099,-6.99254871513306],[-4.00666541488327,2.37736597745892,4.79744782373331],[9.72208583561769,-5.06321837778921,-5.46788402583308],[-3.52709165119381,3.69440039517836,5.77169343547476],[-9.49856480852055,0.46664212989278,-5.99185078855888],[1.38004765039041,-4.29808633596634,2.13556692119005],[8.20278989057516,2.76429063834953,-0.973144478485307],[1.01556361871496,0.101463161320339,-2.38681670321433],[0.545139623169262,-3.64078986331818,-5.76443083985536],[3.45572284166817,11.1320338983979,-1.16380565241692],[-3.33938633307879,-2.72013940683273,2.04906612668075],[0.867871657401956,0.274410793072325,3.17498821089701],[2.11692778635189,4.07089447661042,8.54225100921773],[-5.35639239387699,-1.22962269834952,0.980810156175223],[-2.88889758710181,5.05661998506555,-0.259932976424453],[3.51089802878214,3.70987864951587,0.307775843557413],[-0.37730898079211,2.95079196771088,-7.83854491947323],[0.377569258075154,-5.31326071002817,4.21145308450149],[4.60762685791785,-3.18097184954024,-4.00881115168806],[-0.225889010704568,-5.01277596476441,2.72474697940112],[-3.35075024197501,-3.23921484939469,-1.55890141645404],[1.76866410329178,5.12287335304676,8.3594886601142],[2.27373442039407,4.1031673691858,8.82521465154324],[-3.09359319723251,4.4469565761965,-0.630657095562542],[-3.17550911850524,11.4750653207625,3.41970226584628],[3.18421460302893,-4.04786836188435,10.1185522342316],[0.267438316468073,0.564843596908691,-2.81735599616911],[2.31285812823892,-2.49949039005199,-7.47374969692419],[1.20953355057347,-5.14886508256436,3.6871301912668],[2.28233949156205,-7.27525341505873,-1.11813554253657],[3.61439448045807,5.62572550780242,7.77754427798051],[1.43379539753843,-5.37470624466444,4.34524087472531],[2.41357098726843,-8.9447130354989,2.40517815235048],[9.06171041304411,1.39392812431015,-1.24063178066223],[2.6845308692079,-0.286006779801784,-12.2513480950799],[3.64832752979775,-8.41565054949485,-1.28697780024389],[10.269680994764,3.31621955366492,-2.18964889705459],[2.14393065495534,-5.27100796946598,0.458170332446753],[7.47939049091364,4.60103890031506,-0.595640656362559],[3.28151477870717,11.3983423394989,-2.81287559413029],[-9.01534456138339,-1.75014696161024,-3.6530324159356],[8.27888195875605,6.45678682877033,2.01314560952399],[0.237670773804665,-2.7951258538273,-0.765817075664515],[0.506402516505462,-4.92259898919795,3.37557583013821],[0.0559391846827005,-1.48963887703013,-11.1551638169364],[-4.31328318394038,-5.73499842822527,-10.1234449666566],[-3.79467988988494,12.5895878268339,4.58773054851323],[-4.63538754226651,0.247555191627971,-1.11037338395052],[-0.477084412326056,0.485705091814101,-2.72832711791527],[-5.87426294787728,-6.50285897032058,-1.12398660564335],[3.9372245569769,-1.05543702423975,-2.37653072106549],[1.84689955669031,-6.10236130419193,4.48195803436204],[0.310053849054491,4.31674119256191,-3.40705056655373],[2.80323582342268,3.41140079470504,0.720851254048197],[-4.62509974403651,6.3951667557492,9.01706348192462],[2.02030962992462,-6.16729642059645,-0.875301139513005],[2.0709098228214,-7.93969604124448,3.1509999417008],[-4.29355341609737,5.7251988385487,8.51441433095383],[-0.253713102121591,-3.14072853082915,2.32564158861666],[-5.40400575978539,1.62036330811547,3.08333662742159],[-4.51126816657899,6.87190234773039,9.17769799027058],[-4.82503189229159,0.125055166621378,4.04991075114154],[-5.97108055473705,-3.03527078965056,-5.40256620744089],[-4.08972820570805,6.05226382495572,-0.676172792162787],[4.12078957880832,-3.2844150584204,-4.0260165687983],[4.95586207597066,-3.04072054199184,-4.05193582130841],[6.58009188150485,-1.11888875961735,-10.2522179115504],[0.624489350076429,-3.73539153668877,12.4479585200791],[1.53342351753301,-3.38872029056138,12.362120086302],[0.285969987520446,-3.64858572842274,-5.8851704236243],[3.99794250381941,4.31247240620457,9.02034695607238],[-4.3438813197375,-6.23564788885214,-9.46237070773368],[2.37265849843994,6.93491207236108,7.73688490028388],[-0.251092737323266,0.245193440372685,-2.87763095812027],[1.2537991060737,-7.86058011771503,-10.2796639314913],[1.13703345547772,-4.62378208118536,4.23917910371529],[0.216570161375027,-3.02299813211691,12.4518423914091],[8.41701517534642,3.77899248372988,-1.83148703786954],[-4.22119045876714,6.22929897749679,-1.09588606264079],[1.30255236831112,2.21468362362894,-3.0774778371851],[3.04092380274023,-3.09093504492146,11.4890598988319],[-2.88941901377032,6.09575422917997,-1.71427689962383],[2.42672127856469,5.85263018449032,6.23039318304421],[3.98497965239036,-0.53312789332116,-6.18898748940595],[0.0731300545510504,-3.08005124912662,11.2677349301168],[-2.5368545151597,-1.19999504109941,-3.86057838159303],[4.28160004994888,3.38386940536673,0.574546513945158],[-2.04722242906212,5.74286101538662,0.930611052204632],[-7.86432759390918,-0.351135101586262,-7.72110611151069],[-2.20072610045799,-0.375145846523057,-0.942345373003544],[-7.9520800763176,-6.23545475496683,-0.0944969440424404],[0.158457925231402,9.20346433620117,-7.55848173298716],[-4.53923189786348,0.858527834216473,4.52087592514009],[10.8810641981284,3.08552066351734,-2.22410617969327],[4.14380307546548,-6.68572350872017,-2.27653544500419],[-0.956383418423446,1.41872435399096,-2.40853440918574],[8.71735137283834,4.6426894328245,-1.57109719928997],[1.0626078066513,-4.90146003502053,-5.26931473309483],[-0.0560731245291194,-3.22322601282892,-10.5566639891627],[-0.387764644808179,0.755837165974028,2.99036130504496],[2.76982306066666,-9.30557770840418,-1.40223578725771],[3.88244843334735,-3.39385414866353,-4.12650594778991],[-3.53125108802861,0.344352027323157,5.12057213368468],[-0.125011935000756,-6.56169992686897,2.78345099498003],[4.04279206289284,3.73039403355773,0.573659696318864],[1.13685561635672,3.32167540683884,-5.86396074706151],[2.95120343801827,-0.174666544854701,-11.8895595209599],[-4.20217978583641,-5.90779100406915,7.69888115247212],[0.188017130749023,-2.8658441308942,-1.27203625097751],[-8.57181691957116,-6.01075396939136,0.86223006798788],[0.68249236477791,-2.68893342010554,-11.6448969145695],[1.51645721012798,-7.80257348669847,-10.507084109646],[1.05035069470346,-4.69079733748639,-5.19898978190747],[4.78041833344137,-0.250895739184923,-3.18772509416314],[-5.81517018836066,1.25053861320394,4.18424260401217],[2.20587150309154,11.3020689553001,-2.14161281013005],[1.58955767248591,-10.3006748678173,0.0618671225302431],[4.17249136227191,3.2477391819641,1.51080524861003],[-1.73719903912741,-0.491569967281918,-4.95368898369132],[-0.995094180168651,-7.64648428705267,-5.74387788170744],[-5.37304324131219,0.0271520730456044,-0.934462088362496],[-2.84223815977157,6.51752155643709,-1.58650544426796],[9.57003019292439,-4.41274778336179,-5.6029866046327],[2.86991127898736,-8.85989832315396,-0.0561734999234649],[2.82889461705801,-9.30114993767315,-2.27992497433235],[0.426405349542485,-9.33577727625861,1.92755224311307],[-4.3737460405383,1.33055309592925,3.36329909158963],[-3.69025019924243,-0.398304051405131,0.931848676210975],[1.64412810144264,-3.13400064906407,12.5549859363354],[-3.02258875564814,11.7016687513521,2.97686311560802],[0.599494071685559,1.57348629435639,-2.35511042192957],[6.62971461963308,4.85002774091728,1.08823428817217],[2.18033636905141,-7.77769380782042,-0.651245996653906],[-5.70500643235279,-3.20681682049792,-4.28956102315833],[-1.12505113083989,-5.75360362624868,1.27141768082727],[1.24825019784664,-5.86663221169487,4.04754105387767],[1.7234640227842,-6.13769803888622,2.38220253702941],[3.85737655819701,3.24835330777621,0.298866263428208],[1.36846895120071,2.90687024348351,-3.85893034246259],[2.46632731381228,-5.85538702805991,-4.34410403866396],[1.36535787300301,-4.00547759804031,12.1326162798701],[0.600997119676726,-8.93891772325592,-0.109493902285799],[-3.09754835520394,-4.15996350682162,-8.00097002775593],[-4.47015802129873,-2.64226921054817,-4.28903937179649],[-6.03326494889277,7.6133716145176,8.79081262902679],[-6.30227402129749,2.57078742246012,-6.27242557443589],[2.70670934107425,-2.18214698012491,-6.78462940726012],[3.90124537164801,0.8555218156765,-9.3683499437755],[-0.171601694614758,-3.03979508455321,-1.19915139099187],[3.12020737378015,5.82202618873619,8.66075604244772],[0.568676861095361,0.199889883498146,-7.1247404792372],[1.6705266728708,-5.51287584331186,4.27353075359114],[-2.64993217955379,-0.203620657010902,1.31004817933823],[0.999022054862329,-8.24973028704552,1.92918355529079],[1.23255541635788,-7.81389526098639,1.76795785126311],[9.13825520564331,-4.0559184719365,-1.31890068762694],[0.168438296170126,-4.96275913891628,3.52351413813064],[-3.07825808519075,5.00914183707421,-1.36619230740432],[-4.32235461349745,6.39118768077613,8.92134798818827],[1.53166637059126,-5.22113217717732,-6.19926291336967],[-2.21756952760612,5.41303207478766,-1.81005070919553],[-3.093569401426,4.29555082325191,0.340647691078679],[-4.17339045064569,2.81273412291815,4.66928796968418],[1.98034161404591,-5.35087848066609,10.8985540419813],[2.42625969719719,6.69824116925552,-12.0905363054832],[-5.77922611194391,-2.86281151595906,-4.56640894607122],[1.29094594620478,-2.08064543642292,-10.6243229073229],[-4.14902500521998,-5.90158747814641,-9.27828605941539],[3.2828502423551,4.44660171775248,7.63132041395394],[-6.36239504531896,3.15379170620548,-6.1462012890198],[-3.88839013165003,-4.22801274844506,-2.97020970369432],[-4.69135042362048,-5.56612638628842,-2.56710945878127],[-3.77042279864936,6.70438095774189,0.199125383995593],[-1.09908321448034,-4.89448059277238,-3.06885862915853],[0.212468904796749,-2.24630328559913,12.6589592275172],[-2.39862993788464,7.01342314616782,-1.1215330345243],[-2.1302425615277,0.450449114667333,-2.79761353564017],[3.00531435339603,-7.77166272762393,-1.25297161641401],[0.746453838542368,-2.59538211547255,12.5205294130942],[-6.38725960939891,7.41751485511714,8.83561619904276],[0.989983773081982,-5.73204376090775,11.267977227142],[-4.42140802186819,-5.81949997300195,8.03902865076554],[3.01538357491465,11.8826255103982,-1.43819713135468],[-1.16246840727817,3.23054385572966,-2.08723863094715],[-2.91888661390853,-3.61045755336972,-0.419774240267222],[0.872063355042326,-6.92035369921763,0.806784202280824],[-2.8373120878776,-4.00849618440819,6.78328106280385],[3.70607504614949,-6.24001223932135,-1.67081853915101],[2.61032791902928,3.67797199656357,8.31109267148938],[-3.70494389676589,0.381009001944243,5.3457099217754],[4.83432985144061,-0.127339774815543,-3.13477679188587],[-9.27693744789493,-0.0907250558183736,-5.79699190189409],[2.42772970744525,6.28178112085556,7.31411545401417],[1.56412944439061,-8.56772348322125,2.69293409623382],[-3.91823547927871,8.39802881873221,-6.58369251772863],[-0.207767954631283,-0.727921396391186,-10.9109538091174],[-3.38303321893326,6.20893697580452,8.42616048809857],[-0.999763992509733,4.56903175770091,-0.312245180771609],[4.0547651182298,1.90275002631069,-10.2409987663789],[2.37248792209407,4.91261597607598,8.97441683141233],[1.54480801954827,3.72670653554896,-3.97446970851877],[-1.06223219815394,6.2728030691362,9.07860342798958],[10.947972309077,-1.96168213331895,-0.964552886014384],[-4.51231032050193,2.35986937309705,-5.28105382033839],[-4.43451774259912,1.85015320210769,4.04056361519148],[11.1233641473594,0.724204536942746,-1.2981377938018],[-5.62176305909772,-3.32831472735671,-4.55344965319839],[1.42880848374869,11.9325883610192,-1.90214134214799],[2.67000814519309,-6.34086526399028,3.76508249400468],[10.4359971004681,2.85205402649826,-1.04862719620405],[-5.71324130332708,7.48364521003002,8.10511983120396],[0.806031855416316,-4.56297563128495,2.97229376413852],[0.506898349564487,-6.47517483780225,-5.57819023864395],[3.34191040665504,6.17109507525642,8.78326556365474],[-1.60383623031173,-3.51651771153466,0.270986960784126],[0.33656154247012,-2.8601299349689,-1.13527570640747],[1.81397162135476,6.4609963620981,-11.8988292294106],[3.09563857008705,6.56177164115601,7.43096755550581],[0.69852358438364,-2.26550398418566,11.6909942151275],[-4.03141206195399,2.29677380400927,-4.86089994724042],[1.08016146695225,-8.5418515100518,1.56658470326999],[4.43407340150724,5.07419976613939,3.22220075386853],[1.60971494312005,-8.0318108432929,0.665976347655808],[2.22044424732541,5.9338720924528,-12.122852441191],[2.19613603559661,-2.77387824129835,10.3544162902214],[8.0641845569622,3.12148343604334,-0.73472874687944],[1.68813621148247,-2.99893007997641,-7.52260145929869],[3.91488978169449,-8.79911653364384,-0.355828413445549],[-4.15775053531511,2.22573787831508,5.08179178531721],[-2.48035956899059,6.79037742916765,-0.835790410878839],[-6.29290056419785,2.71642330965123,-6.40457897538095],[-5.41515135979662,6.89382434478603,8.31574758618624],[9.49844145374,-4.58852702880484,-4.66247111134954],[2.09633343386716,-1.71990488820726,-6.13508276680943],[1.83920703927372,5.97226065230975,-11.9259587081745],[0.59699374415043,-8.58225301622019,0.716945769611746],[2.49749233382514,-9.05944458329045,1.63585879918271],[-5.54976285343933,-4.04706497826228,-3.48915714307005],[-5.3499212380509,-1.66305348751655,-1.03093510486935],[3.97566724456015,4.04288674683824,2.42707378766847],[3.49961450261585,11.7243281546595,-1.63495447406783],[-3.62570653434242,0.618207605650406,5.70172288544672],[7.7580883624251,5.88761035453731,-0.493450125182697],[-4.77077862982525,-6.22177529213565,-9.87688493855801],[-3.98304266167539,8.79293029569152,-7.31395184438716],[1.54955323285591,-7.40110131042954,3.91548474327338],[4.85412323342311,-0.704537880132787,-2.99359306082168],[-1.4361276179787,9.81157197043644,2.32633446032727],[10.1759939160521,1.07095780574207,-1.21788693275329],[0.655203355643733,-2.18549760096241,12.396692752989],[0.71524038411322,-8.36933546312955,2.80170528503039],[0.601263683329998,-8.47611721037526,0.710482435163357],[3.44217803623655,3.81638563568835,0.365382453194318],[-5.40082040267848,-1.10363649674575,-0.722634895343858],[1.31789353250174,4.2542024556451,-6.11636746083755],[-4.13799285899599,9.33420373217476,-7.18821898212216],[3.59532296587547,5.75151000650598,8.41796363992309],[3.85494401578635,11.1824325966563,-1.81089495918934],[2.94111379467984,6.38996587319604,7.03336937979383],[-4.37099141907104,5.17342540009335,-4.40416970901675],[3.60528278435174,-6.32063972116568,-2.31988697122913],[-0.845416629677299,1.56709483773073,1.4551503338976],[1.15450275842143,-3.58919445071609,12.8684680104971],[1.41131732657512,-5.61543540566421,11.1959137165802],[-3.8028798808148,-6.36103650468238,-2.45715113683266],[4.41198681860395,-0.327898926870478,-3.48698132101287],[4.3140768375873,1.78467277617083,-8.87934315731555],[2.03410802745752,6.82537104372418,8.36131588540176],[-3.73131219196385,0.131980772361805,5.82391777619685],[-2.00279315356639,4.79328684980355,-2.81431176200381],[4.23077126478062,10.5064631904976,-1.62002986762096],[9.95234925036396,1.09283266172537,-0.918200049267128],[-4.80760678719318,0.627085812727745,3.702650844347],[-2.88921647150403,4.60565819850348,-6.99359062046629],[-4.87977482851853,1.71946890156039,5.17167585358033],[3.39368803446562,5.62304172975914,7.76472761990866],[-5.95259978417376,3.48713328150939,-4.03365169584808],[-8.79623193791614,-5.55094551710524,0.832720690584286],[-4.26743720727207,1.8417185285433,5.4557795194377],[2.39068989070578,6.07882411144935,9.35409082353126],[-3.20115606907527,4.00612261335649,-6.74199523085175],[2.78919739549638,-9.45461256654715,2.03116607651708],[4.66253488600381,1.23741961001741,-9.42963136354186],[1.38113099534284,3.97494150016457,-6.1656336796405],[0.81425093506349,-4.11456558640261,-2.56118187358912],[-4.29052296044432,-6.82568287080611,-1.69301412101663],[0.158810378614109,-8.37531078456827,1.20559393814324],[3.8410706791803,4.55017675872419,8.8670438842953],[4.45916215356408,-5.49185805903933,-1.35794454591442],[-3.66234488602999,8.10667176210353,8.44255104275401],[-1.09599062974419,1.71157723394924,-2.15463524031726],[-3.98901640975477,0.089546576488674,4.45039801620688],[4.37071001669292,-7.22865937443137,-1.33201958718391],[-4.90645813254019,-1.4505011852429,1.78958221994281],[-5.7886549499436,-3.04020341565769,-4.58540524466958],[10.4017348464715,1.64327934780394,-0.866531675917214],[1.85946156077165,-7.06168941715156,3.31049309864395],[-4.03847923913674,3.26785388607846,5.45867714215318],[-5.25805540977024,-5.66556756692887,-1.50258292832746],[9.85420518171675,3.44741233276486,-1.2261604399089],[-5.48077585680465,1.55222541293181,3.65741789883075],[-6.44942195830829,3.2513404112585,-4.40651377669922],[-6.87372546587355,-6.14261019644314,6.60139548400776],[1.51370832963908,-7.94191774706064,1.61823198203109],[-0.0540952695503103,-6.59317036975912,2.44183791280968],[3.03883949902438,-4.33579632717841,10.3939660599406],[-4.70020277033066,-6.52429552135719,-1.47835652152071],[-0.468026087694462,-8.20893843090868,1.4160907641787],[2.57566354430671,-1.35209248444382,-7.59405373840884],[-6.33871497468842,-6.39471850662138,-0.500013382206],[-4.98139215625169,7.34142635651764,7.94640274464531],[3.14190520830645,-2.88198832773575,-4.2747592695801],[7.88931876184091,5.45806540203527,2.65145623909917],[-0.571908005259359,0.0527605135702343,-0.808399169154803],[8.96842467879937,2.01451903031285,-2.05908996227518],[1.33122054028472,6.20708949504297,7.27680784249256],[1.11082403333872,-4.98078900852787,-2.01716289480931],[-5.31513344755261,1.07509376724205,4.21072187443572],[-5.35482955447131,6.55202056834535,8.9956666374395],[1.94381968007472,-2.75020467405423,10.6219187286792],[-7.92575129914952,-6.71834282142796,1.19423901041539],[-5.05949917287158,-0.200058780884042,0.0535342762860372],[1.40820500254199,-2.79880021124607,-7.97482564284165],[-2.32340822526348,5.37033001990651,-3.22954868665844],[3.21360557816769,0.12491327890577,-11.4546278925619],[-2.9269115061461,-2.97370416558114,-0.358895135345698],[1.93286831077127,0.735253035546415,-6.89522251158037],[0.421635624643913,-7.9220189099199,1.3300099431451],[-3.52296368744806,-0.0464706911016438,2.05652952142688],[1.94371920193739,-5.29009819512825,3.03891445780892],[11.4078945731087,4.83220094241836,-1.23414871830924],[-4.35471161187596,-6.06144763040702,-9.81680692512273],[4.4097331011096,5.10762483499719,3.2343568169553],[8.61651725872997,3.33855777804932,-0.920543422927753],[-4.56450175043569,1.4039234119556,5.58202112986955],[4.0079336005785,-7.16201398072714,-2.10535505795821],[3.43018865949864,-9.21397279808368,-1.95194207902334],[1.85185241436999,-3.05274452614168,11.3823794068299],[1.32422878442421,-4.46707621759056,-5.21672747228146],[4.22031071355823,1.42595808957146,2.50092763543879],[2.16695295677154,6.22381706410002,-12.2402868433561],[0.535652615998525,-5.95232802773708,2.97721800379575],[1.98582962406258,-5.88881152195496,2.55537112870392],[1.50966329797709,-0.570420687210661,-9.69590419605144],[-3.00497121976971,4.99800207813194,-0.707883677098929],[-3.97416489265671,1.5026314026402,3.89998818224741],[-8.51921614649182,-6.06180862862319,0.384986293225031],[2.36007329778481,5.77023766727187,8.77174805620673],[4.11742567462896,10.517189648939,-1.30430140320078],[8.29223330323886,6.35955358531547,1.99942373504124],[2.3183352830342,-9.70195088705637,-1.85089973877017],[8.8130027429881,2.61991538707799,-1.78689396500834],[2.97743378236547,-2.38641928022782,-6.49410244113211],[-5.27071351973794,6.43270800377038,8.82336413155669],[-3.29368900138269,-3.64412165214283,-1.60696519470091],[-6.10198696262828,-3.70723499362659,-4.06210017544088],[1.08169829336856,-6.44032747611129,4.41499393661609],[2.15581716738172,11.2977282537562,-2.73964561489975],[-3.75452364970566,3.88378709470453,-7.10810862931642],[4.04820905782659,4.77321546187225,1.99585331344974],[3.42132095389717,5.54994328877854,7.92325934127052],[-4.5154932555706,0.0291061664490418,3.80294682345449],[-3.57789359286675,4.96749033714219,-2.91549873680975],[1.18299224276407,-4.9104440800644,2.76134390709551],[-2.79333217523309,-4.32566918412846,-8.50170508266783],[2.87215677197137,11.9860793059026,-1.24479770744739],[1.44614334193083,-0.992438733770727,-6.30070652855294],[3.48975555421781,-5.02402847662552,-1.77074709180832],[-5.98106002667942,7.46676298407592,9.18501405496204],[3.80248316742694,6.15599470157028,8.09740829872701],[-4.62697949632775,-0.978422931779257,2.62664975632874],[-8.63364239626032,-6.29932945757494,0.84990921396408],[-3.28371442670271,5.0397780669905,-2.44824589496498],[-2.96974981335662,-1.64422737595199,-4.04309067059742],[3.664826133442,-3.63338228630981,-10.2117207794022],[-0.620732293866982,2.95938304865985,-7.05394016737672],[3.00748529648159,-9.68452844034768,0.54947760388175],[-3.21556230862889,0.817928817205492,4.20055784693859],[-0.977924835986198,-4.99335898075244,-3.59450554769835],[-2.56304294340606,5.71013671315052,-2.30960226790021],[-2.02926097008024,-3.1704316598328,-0.722062503559155],[1.66495346564557,5.86669345024705,9.17524952931622],[-2.54590096686206,-5.26745407676282,-8.72730165929177],[8.95728028101097,1.08191260462819,-1.2859188279435],[-0.499017965039662,1.57821654782626,-1.80527699114099],[1.84803220818892,-5.49917826410268,4.32986419262412],[-0.185650149625794,1.72189114897017,-4.42758045633834],[1.90074940831466,-8.94734472469458,-0.255520576707228],[1.84213103184295,6.53093844179024,-12.1868555916688],[1.38412844455261,-9.61549888397505,2.0848788073267],[-2.25267130840406,4.82523922792442,-7.71926732181731],[4.1432344573677,2.14454468702299,1.49681811724985],[-5.50236026497974,-6.54561590176606,-1.14032661709382],[0.630569674221189,3.41776681902209,-8.50955687267225],[0.868107449056451,-8.80921787780008,2.85490118959802],[-3.1148761591786,0.460763617203578,4.1591900575244],[2.66851998251733,6.11565230861255,7.39796040728945],[-3.3057410994966,-3.34779415947263,-3.35803058220871],[6.69304080136388,5.06098782932198,0.294947088346358],[-1.53522937783896,3.71615483580698,-2.69067684324094],[1.24941577468919,-2.11322935842764,-10.6143714306376],[-5.2584685691444,-5.9829178506161,-0.969905145941736],[-4.95416168098404,5.6502954288179,-0.551992478016884],[1.7554651699803,-7.69540947590162,-10.5650200015384],[-1.21854569915351,9.88059505013614,3.22637503107574],[3.31971945017616,-9.91439582977324,-0.786242317403463],[-2.62745296607929,-2.7826918811878,-6.36549279342164],[1.34973630010331,-7.02307819969994,4.69070770669354],[2.27782868712433,1.35675927750051,-10.2836575489946],[-3.72101579928003,-3.29814003573678,-8.04289758823433],[3.07869726239082,-4.61518533017924,10.535027310889],[1.93319788957581,3.74061601390609,8.04221548661191],[-1.78501226436387,4.45811443890094,-7.2729677424158],[2.71477950534216,11.4538697148721,-2.03597321679677],[-5.1145222845101,-6.26314141538102,-2.56186995478548],[1.1835766879963,1.59650529981355,-9.48193761773372],[1.17453593126662,-4.40787954277276,-2.48153495109568],[-5.33680514069571,0.881216805430513,3.82069287694764],[7.07263569058308,-1.35541239142571,-10.4466871878471],[-5.18366556325891,-2.63659482831433,-8.86417733797718],[-4.84249994407211,-0.753709741635,2.41011541319916],[3.27785754384593,-4.77195355405046,-1.18065142771163],[-6.05744164052237,7.17228259507894,8.4555315837769],[1.94251933290542,-0.344018868727385,3.55744137617809],[2.28187744839975,6.61428590807319,-12.0662801581999],[3.10297850114042,11.438461846493,-2.05434948278892],[-0.983381037828684,1.75121827417542,-2.35697214750716],[7.61447094454499,2.74436425966732,-0.953312759449699],[2.44732832972943,11.6039748759866,-2.40527223254904],[1.072568953302,-5.67697993614061,4.21587875260752],[9.08726972939598,3.62928904278902,-1.45180731416116],[1.18318873719293,-5.42112185652399,10.7355276852244],[-3.86745348211201,1.845245526892,5.18792342035507],[2.50854370009066,10.8195252255059,-2.09549986701288],[-1.25798029246251,-8.15822385286266,-6.06509511973309],[3.06413366291679,6.26434246860354,-11.1049500223265],[-2.45012582266888,3.88577284605123,-1.43384910725047],[1.13506444923506,-6.63129405841269,3.97125723471086],[1.72432978200226,-9.48295723801649,0.89293136018714],[-2.43591164777548,0.687434681456636,3.61604488921484],[3.34905814755166,-9.59450842569883,-1.2445511777024],[3.70428426508708,3.30125882674546,0.30492505824928],[0.859864540499433,-3.65151513173213,10.1331529112739],[1.53967707311753,6.0703019892811,9.2990292920193],[0.981949771000691,2.9038392564024,-6.64702681395537],[2.46790751055334,-6.40868362329565,4.50615787566504],[-5.69273177139049,7.05423442418007,8.46612225248862],[-3.36230650824434,8.0361348918616,8.3338129680012],[1.14805832760155,5.44240079523491,8.69367408803691],[-1.37653897149747,4.34912600524785,0.410994080061966],[-4.37725026871054,4.59055496363062,0.422575592224387],[-4.58928067715637,1.05713596998721,5.06218175973314],[10.780220688102,-1.89100725486265,-0.782055432438549],[3.19824066229856,6.08615121839671,7.75715896325614],[4.13534691986252,5.43825705159595,2.49703202083755],[0.38353095021359,0.637396203376531,-2.09121454488597],[2.34688827817456,5.50722546989916,6.64778030534787],[4.27206464186721,3.25531546504984,3.02433954535641],[3.86448820033093,-7.14033634295625,-2.29013332166955],[1.28821004589322,-5.7852721660624,3.75936108204536],[-0.377523105550169,3.73459398806954,-8.88416050354234],[0.282887292734295,9.14795614825698,-7.69552835672021],[-6.12196859666739,7.55090246128813,8.31432953036419],[2.31850553028242,-3.37819170813121,-11.2208151685682],[1.4179425067546,-4.8676415792937,-2.28335094992878],[-4.65908702799042,3.25453829556223,-6.78426910357217],[-3.96386930148861,8.39966524559112,-6.35698904564233],[1.61276707211916,0.571168692284951,2.71518526098046],[-1.59845030323181,3.88694030624976,-2.31985284587751],[1.68896981566415,-6.94776551731057,-0.333239107961026],[0.747702818962964,-7.67614386433844,2.06888742041572],[-6.65288964681285,8.65304019412103,-3.77900887085248],[0.658288447660541,-5.61905271058768,-5.50885654827894],[0.580159881422272,-2.67740014430967,13.0957701712688],[0.0841014764877451,-8.76703903791513,0.578601814617144],[-3.28760058708899,-0.307455895071511,2.40900125331003],[-9.00351890505948,-6.91020125525624,0.663081987016747],[-6.83377435520698,8.74234421034393,-4.09698357298615],[2.8091923638692,-9.78146102110641,0.619029643380849],[1.75928943813999,-6.61689020708815,4.4957126655005],[-6.88102001142052,-7.07352349784021,1.2527414859483],[1.92697586469759,0.794090700925633,-7.01931411900635],[-8.02516471770006,-6.84279598617769,1.49727889959916],[-2.00690900314367,-5.12698698253691,-2.40672724284221],[-0.196063161540034,-1.31491618730328,-11.267377697222],[-1.87861646793706,-6.30672226259312,-1.35954761526767],[-3.79063856060952,11.6900368616955,3.82384867076874],[-2.68640828775257,-0.953960520645317,3.3696235541202],[2.24997423531371,-10.3998198081232,-0.46039404998611],[1.46559043234277,4.94487476376724,8.88747382726646],[-4.9218719020789,-6.67974713295467,-2.28243572969974],[0.31061970925054,-8.30511067055294,1.66066980174218],[-1.11680596002283,-5.01820470270301,-2.4282502957228],[3.94264828725262,4.07219236988591,8.53501289413671],[3.95356392401181,1.04259013757964,-9.64522318853114],[3.84297301387478,5.74752799858225,7.0285602342253],[-2.78235520904449,5.18205776162484,-2.98585465638279],[-3.86805594351531,-5.70156571031529,7.73022542827328],[1.59786444116495,5.42144989860224,7.08549950518394],[7.20473710764735,-1.75593641635286,-10.1815564048533],[0.861894779242064,-6.90062584498266,3.42478505033069],[-5.13611916716299,-3.06185899429697,-9.23146245667952],[9.08452419704683,-3.6837513437725,-4.23445169884267],[-4.83320417075441,1.04674865629316,3.64876179530679],[3.52436961974565,5.50074281326987,7.57217954698677],[10.2633703069875,1.87436262333289,-1.87864460789551],[-4.36019046991742,9.46315454728511,-4.5931138663072],[-3.81545962392622,-5.67412495883424,7.40124957304786],[3.27449579025079,-3.69020594809757,11.5511417733521],[1.65487438978099,2.26355868131422,-3.41261891807751],[3.22761175765032,6.71384678706639,8.70190301318217],[3.23615077182525,-3.88031870156192,11.0991450357994],[-4.52899025458377,-0.13927238954919,-0.788733861440065],[-5.00936260435925,0.812376128624947,3.57458475706415],[-6.32379431270977,-3.14467575821019,-4.9215648317034],[2.60168301090645,6.06414165747363,6.83943576383463],[2.84183869713982,5.25511242758216,8.7607352482177],[-5.98590649679505,-5.97858255111489,7.61037704185264],[2.73367384301056,5.57379307316593,-11.940384989903],[5.15184977425212,1.77450149687735,4.72278138387191],[-1.90995976601333,5.16372685837537,-3.26593811713114],[-3.41879965967882,4.32572663650659,-2.44035513455029],[-0.0656971380015005,-8.03636392451545,1.62173374095163],[-3.90643469312573,1.82089795518577,-6.6465864386623],[3.08997460225714,5.34742029263252,8.08858663870923],[-5.58234584032854,-6.17071338995292,-1.16212205144992],[0.108104136346012,-4.93975279266261,3.06200508283903],[-5.38266039487729,-1.04030586516414,-1.52789698136929],[-7.71657636581448,-0.844550078679063,-4.61357118409951],[10.1280219304108,3.01545750132069,-2.22111590289082],[8.0516695942343,5.59823442704829,2.82141722797864],[-2.3150262818017,5.85321056738296,-0.248285725268262],[3.43500668714588,5.83508109891601,6.975932489593],[0.0935971415917857,-1.4558777197032,-13.2161854299273],[1.71063302097943,-5.18062128400565,10.7062725912895],[0.222226101781155,-1.84070538077409,-13.0944464833538],[-5.52541733685151,4.02049470226071,-5.35018103941948],[2.84048001291721,-8.78608646038245,-1.70577750472464],[11.9955846910654,2.33897214985397,-1.46719834907995],[-1.51160472877975,0.809138101312266,3.94642644061444],[-2.15302543048585,4.94216339752945,-3.03170816411078],[-6.98063201470309,2.62044960901512,-5.11818862964961],[3.13173481410042,5.83575640524174,6.28631673432203],[-5.62393803167195,6.82911336129783,8.91557061792586],[0.031337106059606,-2.92258954549585,-0.567994631658404],[8.05461174208994,3.9018396444104,-1.85357061518786],[3.56593517375382,11.8845328120867,-2.62301227886698],[3.13247999567839,-9.14812195180455,-2.20557671523426],[3.01713678703663,-3.51689080580919,10.3449525347891],[1.75437603487301,3.8838269896336,-5.74647090672173],[-9.51384460440527,0.580486040519257,-5.80000264257634],[2.99286656214721,5.77269000583394,-12.0792290262199],[-4.68962579424865,2.04686219295551,4.74339220610356],[-3.1343886003274,5.40824278231059,-2.87427282550879],[2.89411439992052,3.89847695066193,8.02515473436529],[-3.54246298577076,4.04605840791344,-7.18318469815395],[2.16075722525172,6.42182311380076,7.09083228580173],[8.57894258009454,-4.20800715527432,-1.10237625067192],[-4.6742015606463,-6.08046180270143,-2.41929018745698],[1.39820139781671,-9.01402315798102,2.39385238954397],[2.04779612829866,-6.40961242196472,2.84117462107082],[-2.15681638121571,-3.32533738071061,-0.569522858882812],[2.30893452690504,-9.02219498098588,1.89407580750705],[-0.142820548603541,-8.03941578114029,1.3754922140507],[0.92254303095998,2.36275497341134,-3.15447895233422],[-3.49359135679276,-4.08066752206796,-1.7130012045027],[2.1536808026384,-9.54742245953411,0.378484620910897],[-3.82936232003125,-4.76373876961962,-9.19056267696981],[1.66592472201701,-3.30651453642629,12.1877379530072],[-8.32980569963407,-6.38356977129297,0.102258992088593],[-2.89132884396294,5.45553412952131,-2.34168670309384],[9.33496409906314,4.12558075236291,-1.18284899196263],[-3.90496782442157,-3.78450119130672,-10.6129111277703],[2.57178021325897,-2.59438133692198,10.4855613491656],[-4.40249501752598,-4.62007101597777,-0.888503561671013],[-1.73304812489951,4.90421257702112,0.879434569054023],[-5.69035402364354,-4.29884185176215,-4.18100069418082],[2.48602650420057,0.194422999520135,3.39557838230188],[1.40184540315714,-7.14877070053501,-0.0337027927331944],[-0.646312248076725,0.222591431524324,-2.99283407973018],[2.0972596970251,5.57048846891309,-11.7943753131116],[-3.01653634016541,12.0036035048026,3.85561625247547],[3.71525212806484,-7.90875498343819,-0.86101229910405],[-3.19965656015497,8.07407427694031,-5.93360525112424],[-9.51230397120672,-1.01003970407057,-5.15475652112585],[-0.186288621808763,0.287375412920005,3.11958526437574],[1.69882330368065,-9.42588661767245,0.422637678141549],[0.07089896614189,-2.72676495891216,12.6034427883787],[-5.38631708121804,9.98487694205848,-7.4079086073553],[2.9686369040632,-6.29715997426101,-0.916534742411124],[3.81370654335729,2.94724114584637,8.46043149999421],[-7.82385122066968,-6.46526950109184,0.267933816588587],[8.98591367126568,3.20581975837057,-0.555077752569692],[1.78705637148771,-10.0016662745798,0.677466245321781],[8.47001296454694,6.42568766940147,0.319959554245661],[0.546795299042435,-2.75724768520195,10.9351676032943],[-3.80695530559955,-2.55231021943831,-1.79202397671683],[-0.603239658292433,2.73499478777336,-7.960455647555],[3.44091363689716,-5.84185440704773,-4.69592483143999],[-2.31454079051107,-0.558091029138013,1.23923051973644],[-1.96571714426059,-4.72788098728596,1.86394426384655],[-2.44376818425597,0.49410226748087,-1.74596803314873],[1.83957476680251,-3.3782888020622,12.7361145768465],[-4.92203702224922,-6.29192184001857,7.8362504855533],[7.04208316540204,4.00582164790704,-0.659140156375493],[-4.73261696621522,0.403462996978333,4.49813613813322],[3.02035788744059,11.9011587346653,-1.06257073777564],[1.64162758243103,-0.43721812112796,-9.84697543181484],[2.80727874283384,5.92410057599514,9.52750027664889],[-4.05176785682461,1.42510477450641,4.11485500928727],[2.97602620662863,5.9975907110253,8.19415670325145],[9.08357920463826,0.0800022617466094,-1.24641985429658],[-2.88379093894369,-2.02819117089931,-4.55233670572062],[-3.21607604364676,0.738088417038302,2.85347595356944],[2.4073972589277,6.18446222015941,7.10022885976527],[-3.27400445134374,11.4131231902475,3.35360669204313],[-4.16462812399918,0.634981474213891,5.5689125458068],[1.25561109636336,-5.62917921974542,10.800126628162],[-3.41379835047567,-2.05379809522386,4.29796604597577],[-5.42977919613114,-1.15308040317363,0.759608003570107],[0.259724011824033,-6.5779033077163,-5.86371853733162],[1.91308085488518,-7.09925278358694,4.65063940830292],[3.93294575255369,-5.0505946951097,-1.3696495188601],[-2.44683794249116,-2.6282377527272,9.30149980303269],[-5.9400793497032,2.9046307465779,-4.53945701276671],[2.65842254021281,6.56466284674829,8.0234124775316],[1.18491347343097,2.03312427496102,-1.34987712977787],[9.78932941405231,-0.0169373430185955,-0.890572053246979],[3.71343009151402,-5.57289202972547,-1.0071946216869],[2.49636113176642,10.8848906668096,-2.9356528826147],[0.881753995984966,5.43934979059856,8.52388487326681],[4.04482329213772,-6.74803133453424,-1.85599126206612],[0.754288290073332,2.11593310749492,-3.41849692140945],[-3.78586600359225,-6.37979060571784,7.28482734672548],[0.065058522767341,-1.62813290204809,-13.2649127951478],[-2.73173033516753,5.4719562979911,-2.24229426622543],[9.4643564594305,1.92742252830988,-0.234926979775054],[1.9592623396433,-6.66175478428862,2.37710155027855],[2.32365596538537,6.05748732587303,-11.5914251532561],[-6.16635865181029,7.425467938678,8.18429900030602],[-0.288744036249185,-2.32616452150899,-2.52626700436171],[-2.17563259938536,-0.413845841698455,-2.89126650920891],[7.59427269092098,3.61349488250098,-2.03628878065577],[-4.3150450885791,-4.96636467627511,5.7119137232331],[-3.05536684192845,8.939395508894,-5.55865057894764],[-2.59719109432519,-3.59148188766802,-0.969883853527051],[10.1926489777523,4.93326293484674,-1.3588963856118],[-5.08354198416,-7.06316627757132,-10.1734201960362],[1.74929137566601,5.54987021160151,7.47335754565118],[0.242555477648093,-0.46743287298977,3.09871754707104],[-1.16998016719116,-2.6084058326605,9.54661947071783],[3.85362978025854,10.8419360331694,-1.24902201939573],[-2.46241268337275,-1.13127980678565,1.14532895016828],[-4.85649700659792,-0.00174286307400695,0.583675315376764],[9.77864575151209,0.0248282625861439,-0.695498076039909],[4.22911283891703,-7.11777193651872,-1.72311013766403],[1.07975965758198,3.90041814204223,-8.54044039873033],[0.185210619030476,-1.17115103286352,-13.2479836785058],[1.78348495127017,-6.77231077284898,0.388258319775388],[-4.66984841819594,3.74941914671098,-6.76885354013439],[1.10843283252748,1.86738272927627,-3.45222398047296],[-3.07509561981468,-5.97465943349259,6.01084996146198],[-4.83642993018208,1.86010577511892,4.64181089253045],[3.41506623528197,6.75609045921647,7.99177785165684],[1.7933441446901,3.86854041169069,-3.77531391395229],[-2.79456972075794,0.258117845154343,4.34425716055156],[3.65509748159012,11.4215883042536,-2.50016673103336],[2.29023054066988,2.71540834771066,0.848047071700015],[2.3734023763703,6.89901890854342,8.60417887437799],[1.95361176527372,-2.24210856848059,11.1492277738704],[-4.24994618646004,-6.34354574670383,-9.4518751780587],[-1.98320406680346,-3.17814366849786,-9.93259472097645],[2.71076213249438,-9.6986558515872,1.37434001274834],[-4.79739905022394,-6.65779825224414,-2.75221054713833],[2.36502029489107,6.34068909227537,8.02725708789251],[-6.66443117975163,8.37804770925889,-3.86389941017593],[1.56205236296918,5.48686545340695,8.38190244272865],[-4.28882436192521,-4.61035129226445,-1.8793936422382],[-6.70593490911375,9.44569151894236,-4.20053913212362],[-5.38270920067944,-2.42296466243471,4.38113038706583],[4.13395143081385,-7.35182860290702,-1.15329796674909],[-1.76532457498344,5.18669685814078,-2.93717185803179],[2.3879147317158,4.37151931539207,8.68608246779401],[-2.58435051360269,-0.902813378617889,3.0951676663873],[-1.25678640583902,2.75384763042229,-1.83453971471952],[-5.00168301717437,1.60995567251997,2.55092328520858],[0.954641753386192,-2.62883989684468,12.9850329436543],[1.25551069507855,-7.50055024008002,3.34217404099024],[4.11866763028752,-7.99918261129296,-0.654604914486497],[-0.669638333575657,4.9089523685035,-1.27503574698568],[2.32944701597809,-10.0996297550969,-0.246347204445565],[-4.08257513548932,1.33329237856375,2.1396966077518],[-0.316592118591054,8.80666007423737,-7.46287278497281],[-2.94156424547003,2.65358691936816,-5.61590667621222],[1.12952709441804,-5.15672030379166,3.8284158260646],[-1.2835959119522,-4.88691498959247,-3.34495938594403],[3.03291441325301,-0.0833010029678478,-11.7523142265344],[0.63301324042904,-8.01213541060829,0.912759673723924],[0.731972087352467,-0.362211941037575,-6.37094258377685],[-4.56335602184812,-5.55326869789489,-2.81055216687016],[1.20276657443503,-6.14871616901115,4.58705680015663],[-1.62363404204898,7.32920574421394,-7.18524334199653],[1.99442028386015,-9.12375582778472,0.681072606089649],[-5.52397234970627,-5.93060962259019,-2.08033117956461],[7.2651625894476,4.76493369367758,-0.913377528248807],[2.14231728646716,6.56796588561513,7.95013855889712],[9.02723036858645,3.66659320529929,-2.46300669791094],[9.01442098442157,-4.24824636246578,-2.27240059658339],[2.54725280630645,4.03209474493941,7.63598899574006],[-4.46774334187393,-7.11878455934372,-2.51269170984072],[9.50094450413448,3.74848855509553,-2.60414563811222],[2.57080430369788,-10.2149169891877,-1.57263775977694],[1.50515331959276,-7.91480743563876,2.44321644071491],[3.96788006451673,-6.69577867930029,-1.38529277866388],[0.879709550214496,-5.6359247464306,4.21340796914742],[9.76432626125946,-4.9339108194474,-4.41677201518324],[3.16217824257153,-3.15375718974639,-3.64080329968279],[2.46810536391257,11.9708108774656,-1.86226710134162],[-4.85348413406348,-5.81779866400197,7.44914730596197],[-1.00978190705213,2.15641499643829,-2.16720729895086],[7.61543889337956,-3.08153750209487,-4.11524522318275],[2.63342352060543,-9.05128947054251,1.89497677038461],[1.29265716972617,-2.66993080991221,12.6554327046993],[-1.07601456923324,-4.98605420076324,-3.38291530448811],[1.69521543808147,-8.04265356065998,3.70483374382563],[4.22848034186723,-6.86155022945974,-1.56961595886604],[8.71987566404832,3.78808068628672,-1.50877789889266],[1.38473571079095,3.90927043983652,-6.11657001005993],[2.44148441774334,-8.72495610233612,0.23538171483682],[-0.239288088538717,0.780040448719516,-7.78004995098697],[-3.28678682001899,-6.31491669674074,6.0766157048103],[-2.92669148742265,-1.00570378185723,3.68146994128522],[-4.69861016012864,-0.314388430827322,1.37353372769429],[-5.06800015094346,-5.96536844973845,-1.8474757552104],[2.51336446454616,5.71504716604075,-11.7125655820227],[1.73444717261353,-10.3122816125235,-0.490141817839321],[3.7322373768505,10.6520290006516,-1.67797198535239],[2.7566464479697,-8.64887473804069,-1.15287816606454],[1.20581949807787,-5.29955821140595,3.98840131002258],[3.25316051376977,-9.61149539562273,0.203704704711312],[-9.58693708384233,-1.10758136794927,-4.32046013004286],[-2.67895892967249,6.27739049587896,0.473111802878405],[-4.33145620349894,-2.4468301164148,4.56198801453989],[3.22234870412564,4.9354552063795,9.13968495384562],[3.75936362581229,11.4798462904516,-1.27244049326094],[-2.78136191488278,2.29929878846083,-6.97161232559288],[3.59630090982849,-6.67138852255201,-1.06776855948047],[5.13128310115137,1.29209024610237,5.53422707703492],[3.35429082818735,6.52933522784179,8.46865319747315],[1.73018308778204,-4.54210592362014,2.77711032912217],[-2.33267423903329,4.97478069412204,-1.54733271975542],[0.422829156292719,-3.45540144016562,10.9288952557552],[-4.44915299553679,-5.93127121784876,-2.08512492455796],[1.84493472158237,12.0779289249605,-1.64323121092059],[0.00972803310635162,-7.59718446060157,0.857700725673062],[8.71309100916676,-2.46420758335709,-3.03957693104375],[1.7474022205148,6.64039921078008,-12.1312404388827],[-6.19464324233465,7.78186352736273,8.96516913276193],[2.70036417187083,12.0639164680299,-1.34719617006379],[-2.39836764051908,9.62329568183989,-5.76469601587858],[-4.69615281496499,-0.947386843825623,4.28375979915867],[3.87807685688994,11.2206321224649,-2.00137028424182],[5.17068449468024,1.27371172352005,5.58387183124151],[-4.20970726879734,1.25230557397146,2.0757057997946],[-2.34281249954306,0.87338860467936,2.76136498021182],[-2.84518350568089,7.36353689518177,-0.457915947409187],[2.69171320712696,5.5802677232375,7.18196979272223],[3.30111078366575,-7.41025771129312,-1.38176902504269],[-2.81258767550225,4.48992875287031,-7.26865672060452],[-3.95460037545832,-7.01094960076652,-1.77319542818588],[2.12747619717067,-6.41255701758058,3.9911523436262],[2.27358977568997,-8.9556186671708,-1.06779157091346],[1.14035021770536,3.86574983556268,-6.70220164905062],[1.25830864235826,-7.10550476995234,0.0930218703132622],[2.53143150893218,-3.38999015796778,-11.1284093524029],[10.0756345067987,4.08311458520615,-1.43175446392787],[0.466267431782618,-3.3516377376555,12.9879147422101],[1.83599935672603,-4.55081267590264,0.976296284046774],[2.13097147139794,-5.68897612156522,3.18506924423549],[1.34963963007503,-0.0143577479906483,3.49563467031456],[2.3752877212568,5.53300380017403,7.32724512499587],[7.47069050280307,4.432179953433,-0.307151461439583],[-1.79315779441182,-5.90497943496456,-0.694366547850257],[6.88046733077985,-1.55005221354414,-10.1918616002463],[-0.36426740862253,-3.59045903983825,2.34155844480403],[-4.81552268775252,9.17325133304803,-7.82845754093129],[-6.54167344191257,-5.6010451185892,6.85025686201014],[-2.32692404240368,-4.34770780581948,-2.23624447117992],[2.39824714574006,-8.44719416664148,-1.86101178749972],[3.54002876865377,11.9468194755995,-3.09660125268513],[1.78284078749549,-8.76095623287099,1.56827637578054],[1.44841206903011,-0.809160727068191,-5.98449564000928],[3.68892779445424,-8.56426385078015,-1.80034461202819],[3.06215839060412,0.027955148832961,-12.1526064361667],[-1.76270758040626,-4.32177972927725,-0.331111505358974],[1.8927424580391,-6.30342098950147,3.96159827080251],[-4.72627816488617,-1.12636034677532,3.15683567952796],[-4.06895905877737,2.63730885808161,-4.97172146499769],[7.80510919504258,5.94629921506696,1.26730066312503],[5.17958800438573,1.44790806346725,5.32623143768382],[1.06068478902442,2.44955171055103,-3.45111993488965],[3.67479977748816,11.0318611561282,-1.27248805945027],[-5.36113409224449,8.86550591941024,-7.07108922855057],[-1.46897919456539,-6.18539217001245,-1.47158361893845],[1.86436471313811,-7.10717987285141,1.35038161443582],[-2.04881122796262,-2.17754372046444,-8.78227739973016],[-4.13429676573335,-4.92528582593555,5.31368456207425],[3.28810522320876,-6.14506747904573,-0.855163294216194],[-2.54859359247481,6.0647106660095,-2.24180695804309],[-5.94666316609392,7.13310951066843,8.97422000895254],[-1.05229394816076,-7.54472448251611,-0.276684341361678],[-4.8908415372086,1.93545158116237,4.14688022758199],[10.6814411191403,-1.00170728418038,1.30287561077685],[3.24160441222325,-3.39963737537417,10.9474576366321],[2.130911813324,4.74950075066411,7.51798719483807],[-4.68092712181953,6.68390205389369,7.58572489800429],[1.06180537519896,-2.99416097138092,12.5861138493717],[1.37858904196884,-2.74919555370107,12.4524009269586],[-1.64899529040284,3.36082038952621,-2.3128885424336],[3.13171235736881,-0.404918645235222,-12.0783534135906],[-5.24457184220744,-6.356559430862,-1.69757903912873],[1.193734636057,-3.49504826735828,-0.15676047031833],[-4.14620917493363,1.30347214235911,3.24737062319869],[-3.33795212115522,4.44511512820861,0.658881570566303],[-1.78730700774731,-0.444588460567229,2.95209378795586],[-5.53067047432889,-2.38452705064799,4.61275987399409],[4.14028382461648,6.06783809706949,7.58231386526022],[-5.90727494686727,-3.07096424247505,-4.82759594135177],[-1.80959590496132,5.26512169332833,-3.1124707838475],[0.790260240737619,-5.52966257566041,-1.39577892854152],[-2.41282459138456,4.70431844937854,-7.29189215014542],[1.38483836165795,-3.22813047658892,11.9850444724135],[-3.86626733208933,0.315639763120858,5.80574791350678],[-5.54991159856617,7.13453550403027,8.25515353698122],[0.730681956208036,6.19132796730211,7.636737522636],[-6.36847962098358,3.57893326355857,-4.80776331634764],[-3.6518166414023,-5.68301699072815,-2.08802020119617],[3.05085119809697,-0.174957286428625,-12.6626650013262],[-0.714364360973584,-5.97239064152086,1.86844573729601],[1.20012487651276,2.1607899113737,-3.16318665352165],[2.98288040366631,-9.89487924227371,0.885316722764443],[-5.78124823201627,-6.33945456733291,-0.773297950686771],[7.23957643150142,-1.75528103201032,-10.3795661035259],[-6.07027064552926,-4.99992358393003,7.70779705266589],[-3.23476395570322,6.46182233525439,-1.05256680326159],[2.20321052409934,6.50445655197071,8.35052824901798],[2.1369562647277,4.81393299458274,8.26325120691345],[0.957680949560679,-5.24755764616745,4.52824511664713],[0.690645687333472,-8.41024747403949,2.03261254948055],[0.100434433125331,-8.17321864913789,-0.399464031243167],[-4.18988732991199,0.444819781761292,5.06021010481873],[3.17518670571211,5.89340736981269,8.14430572880072],[-2.8374415952877,-2.35688621746221,-4.79039972245017],[3.54825395032775,5.51920744519236,8.48342756813824],[-2.40441956377178,0.744895504961024,2.38038283411291],[9.84643589775096,6.71493179579047,-0.672064180465557],[-5.77810557886236,8.37140222814937,-4.67398991979727],[-5.12982268773189,-1.30063399611558,0.854167000083438],[1.06369877282112,-4.88367050609528,-2.19283894451938],[-6.17630192100519,-4.00519274457477,-4.09452868713631],[-0.592417420618739,6.52479847093867,-8.4120023078043],[1.45889405935979,0.320609471569049,2.95368940410158],[-4.01438409667306,6.48386589198827,-0.141081705511595],[-6.00230518127055,-3.10222056774053,-5.19893599775466],[3.50092559181112,11.2328565358177,-1.00250052234045],[2.88113202585299,11.6240630710916,-2.6415118381735],[0.157885831361232,0.083479575708809,-2.48634870464304],[-2.73357761457865,5.74716597746298,-0.800784724707184],[-2.51380817342125,10.2661665262849,-6.25761963086437],[-3.66488169376363,-5.45870777851053,-1.29944356860359],[1.87972410910581,-7.68796222114179,-0.249617337233248],[-4.76749959825876,5.73114337998817,-0.565725173001027],[0.31149907563077,-2.48895246000935,10.8482025030303],[0.587942637467633,-8.17112472265292,0.87792495019659],[3.08184206948235,9.83925975164443,-1.27519339268357],[3.36535615759533,-3.27773614234264,11.775696547134],[-2.68847470994031,-2.1190996415472,-3.28041514191635],[-0.0785460211598368,4.7223724981987,-2.12039697981473],[1.72847749511332,-2.60862007724417,-7.98543596417868],[8.89415679217578,1.31856704477637,-1.60783566716965],[-4.87619461883806,7.62196979544416,9.14553720170414],[1.20411206434306,3.44427177690148,-3.90135874092768],[0.617259654111671,-4.44101841303278,3.94461347839286],[-8.63997865940485,-5.96975066684862,0.966671635634355],[5.02186276421761,-1.91836179521801,-6.78505630407604],[-1.76195597574607,-1.68808244574151,-8.43446839810262],[-3.96457894725602,3.52413788057654,-6.33331338824846],[0.229767582908991,-7.73115369621864,0.783468028423002],[-4.30695785197402,-5.61612303506728,-0.987312281483229],[8.48757796897556,3.83343498631916,-0.814971744852397],[4.54759826314814,-6.01546456010181,-1.92510272328486],[1.46656959994625,-3.07942009877895,13.1386616260064],[-2.82412353809461,0.673888081302778,2.73847426335502],[-5.40118877631593,7.41305430969071,7.76748471241157],[3.85329034671774,5.9924293143464,8.88592405825903],[-5.90716126612959,7.6859508409891,8.74214359210016],[2.84056455865532,6.17547616126369,-11.8390368838075],[-6.16845111134995,-3.36155231064983,-5.31480718612473],[1.80133526080402,-4.14988857915486,-4.7671046856684],[1.73168897787888,-5.67832363808175,4.03732993240701],[3.7090713944285,10.5167057854663,-3.49029810347804],[0.433236210650689,9.13985601273476,-7.7655665835121],[-3.47373939551802,7.13547545838344,8.91699700572205],[-3.38778915177599,4.36362310190805,-7.22339840376634],[3.4886701295016,3.58640266995767,0.984879190834422],[-4.27813038177037,5.22930398494514,-4.40674155162747],[4.03665526928463,0.0751622333891904,-3.55516597657048],[1.9417855619818,-9.65384387036264,0.932642881424056],[2.13493484190963,1.15337147857141,-10.1387987837146],[-1.32540072377421,-6.08282601211852,0.478820442541581],[2.91102145422259,-8.76679209375479,-1.27389372059514],[-0.0714642154377626,0.197644187628969,-2.72002439301801],[-4.6010491269985,6.11906058825814,-0.347519244483636],[4.08744402002945,5.30840204555164,2.41799639971465],[4.12169383035039,2.09203423759471,2.49292045263714],[-4.60411411189834,0.94891851353497,2.42805172800449],[0.196086384645027,-3.3553106435171,-12.2428442840864],[-1.51855005975582,3.05593273845783,-1.85634313843459],[3.12818907454192,11.7910330312058,-1.54409674963592],[0.791625284676373,-9.51036005943856,1.60675250876009],[-4.10557248994766,1.75292660678125,5.39674063520546],[2.21587438743462,-5.06435221717718,11.2279942499028],[0.945008778674187,4.15060937078008,-6.00407783028874],[0.710979691372136,-3.46520197621445,13.2734592285407],[1.54131552283612,-6.07500055630127,2.90011098663006],[-1.95886116157493,-1.35424811318191,0.617116604219604],[1.17779145760651,-4.95479484381294,3.98991423856303],[1.38956413750103,12.0026440531672,-1.96574731775835],[10.9470968661714,1.285853633216,-0.903373470628795],[2.90536885344932,-8.62624362673022,-1.81921750723351],[1.43945883477514,2.05300302234209,-2.12228692108809],[-1.11501583829294,9.78598706370451,3.1522276044427],[2.36105721071757,-5.44968793838179,-5.94788819270893],[1.46171156288601,-8.88142568287749,2.19725748699781],[3.93152489356849,4.58515636827805,8.00204524950939],[3.50782181278267,-8.78501418142986,-2.21371225452632],[-2.0957415658869,4.55263547977192,-7.1917416489997],[4.23771528566084,5.28790875774771,8.30931931602912],[7.24503812036172,-2.14673111973688,-10.0671505497483],[-6.51058613115647,7.06156131936255,8.53964965204402],[2.81574658279028,5.81872397358237,-11.1617318050699],[1.75239693823864,2.5964701598589,-2.54643269155992],[-2.71770723600337,11.2353124163363,3.21059040796713],[-2.80781098643749,-4.65341626515784,-8.71602957922331],[-4.23311294155973,3.00717156669255,5.56719671808037],[-0.769417819873131,1.48598740106885,-2.21200442677646],[-1.91347521168227,4.71306830107173,-6.99241197057696],[9.06853669150586,1.78616162734319,-1.02631189578456],[-6.9874755128537,-6.49416055271062,0.329293671347654],[2.54343677924366,-5.00170554691484,-0.501544072035525],[-8.67008941637753,0.128999930705883,-4.52632291364841],[0.223340811619615,-3.33415598413266,-12.071239769128],[-4.85256444823601,1.0144637139832,2.82639389785793],[2.05372832031471,-9.7104936574117,2.08366470877355],[-3.03815409806032,11.1580115441926,3.39029851318887],[-5.31000548620989,-0.21623427570827,-1.75886395665081],[-3.34342381022884,-2.63063983253599,2.06824667586389],[0.145398136011121,-3.58910487984588,2.78739756884589],[-0.509414105488582,0.341892749443022,-2.16010625464925],[-6.08354807481004,7.09190005099238,8.44879993134249],[0.346876822816128,-2.72720104049745,-0.502532083400451],[2.67205510789173,5.93603178519639,8.2481162214913],[-2.49003778567196,6.76811276949724,-1.02016046730749],[1.21907950497811,-4.41439313957533,10.3419908143953],[10.6485115667929,4.1419787401614,-2.08143907445729],[-1.39737470603996,-7.16986373645796,-0.584416595080912],[2.3786706259827,6.09675906366324,9.57950057206857],[8.90204118396874,-2.38054469401804,-3.87453711607658],[1.29505883490517,4.21090235971633,-5.93873018575382],[-5.77594895759352,-4.55242188458017,-3.8925918109388],[2.83046377061931,-9.70468960678551,-1.28354760216882],[-0.0543875367012673,5.79338298069587,8.38476733977699],[-3.74970422197925,5.94146088034377,-1.84874692928523],[1.8809220118755,-7.93518235194611,3.8328275647515],[-9.03688746541757,-0.678346793493623,-5.05423687040634],[-3.95178367179122,-3.62651795055204,-10.8993551409079],[-2.98603794414716,-4.61776900077697,-8.78568077136693],[0.952995561265294,-3.16025874481782,11.8620475003997],[-3.46196298944095,12.7275162877077,4.34104615699791],[-4.59075938852993,-0.361115081399919,4.60372676299122],[-4.12857026124688,-6.0410155444045,7.26513396237722],[0.918179533959799,6.10823433657776,7.93469490981721],[2.54822554976442,-6.94852470561516,-1.17470625200904],[-0.418139154735704,1.92768339061817,-4.85627900355875],[-3.30410337994386,3.6583404384507,5.58476093564219],[-4.94635354473147,9.27483869324214,-3.68756439383164],[-0.579561923142557,-0.0616285907619274,-7.93942133112256],[0.456550110251188,-3.00002689144228,-11.8940660455682],[-4.19419067061742,0.634431903325375,3.44246776840958],[-3.64487321862749,7.14716671512844,8.77648285608609],[-9.5047595531671,-0.0148450708804425,-5.36842656675084],[-2.31807176170489,5.01216471137513,-7.58569186300231],[-6.09702447740388,-2.98398400059146,-4.9715820862311],[-4.3288995891394,1.22984914563339,4.62846599590203],[-0.346891873234531,-1.23746922867115,-13.7875621464124],[4.47373287090159,1.86134170026231,-9.2245119737843],[2.69596431055847,10.373465821835,-2.33165263978959],[2.03583965423044,6.5631829135969,-11.8668727246176],[-4.97203525320319,-0.44066874723293,0.660475775379367],[1.04889166829999,2.41490906627357,-3.191522302044],[3.54900252739624,6.44153412820608,8.70077537851699],[-4.59072483260906,1.82975518790535,4.43125310409014],[-4.7797863084876,-6.36032868124227,7.62486776622917],[-3.81396526501735,-5.62839720329399,-1.71289447472721],[8.57887444319036,6.52607459973862,0.40184628984903],[8.16643472626579,3.57350733877842,-2.1228372639193],[-4.9316232930446,-0.856726288742961,1.93607962388065],[3.84425245446978,5.85981337827977,7.39928437370247],[3.76805700785036,-4.8322771035379,-5.27689256840765],[0.566780154781009,-8.39932284117278,1.62584065015608],[2.65200464468106,0.214480982294229,-12.268933369225],[2.12288358664264,4.82527316569401,9.00863009541576],[2.30340107088396,6.34895437079512,-12.1659165444974],[2.33731891116002,-5.96134599172414,2.35047291223187],[-4.16718600148292,-6.78233442132094,-1.7893053896307],[2.65062618994372,11.153577335929,-2.39901480488739],[0.580490280649947,-5.80921799645738,4.51783545200424],[2.94666554383614,9.88581296497666,-1.94977188722806],[1.99721491061956,-10.3829029878407,-0.906937422318096],[-3.65786810129394,2.1302312930482,3.87520841054401],[-4.80945346990376,6.90460676741757,-5.36148293964649],[1.22166890182517,-4.81521364931363,2.14040376878884],[2.67587824018359,-9.05535333553838,1.52500988981353],[-3.58394320376393,1.1402859294429,-6.10601658169015],[-4.57287088145839,-5.57436354861819,-1.96672992684387],[-2.92778866703922,-3.32080730158647,-2.73015791442323],[-0.672046503935977,0.782732260974863,-7.28119213273297],[3.13591741715033,3.95088683357416,8.41490946403677],[-4.83354195355995,6.6839768299876,8.64377151198546],[0.84414227762114,0.42617366593959,-2.9989661572251],[-4.78272329825723,-7.02880089185978,-2.3512634094849],[-4.98607727899224,1.33663512734723,5.48975171398701],[1.69043077715848,-9.77922060669641,-0.111356006942761],[-5.47829354953765,1.290182569655,4.90728274206417],[-3.30506938044885,2.62775083570318,-5.59774354562476],[-0.487689841941788,0.165465340372777,-2.92695863397772],[1.62781949033402,-3.06605128769499,11.748314399322],[-3.22174038269179,5.43648885824935,0.280251395081449],[4.36442501575658,10.6496385132756,-0.960910340205213],[7.51886262747111,4.43415088944552,-0.169514429240592],[1.87808074897577,-6.07937117661073,-1.19269206736817],[0.721124607127725,-4.07071884880443,11.5154791113065],[-3.99427977669182,0.767540266604708,4.65143308896333],[-1.87295382399052,-5.99864031822289,-2.02768343295813],[9.85292510744462,-5.08351562840722,-4.92884880475399],[-5.08030752155716,3.6122811772072,-6.70508324433376],[2.84430546999613,5.92274221350877,-11.912364151557],[1.41628369022854,-6.32607068214878,-0.512043271228965],[-2.457410855425,-0.869858220997991,-3.55462285357923],[-5.73051218437708,-2.96700971690536,-4.31628589590667],[-5.11049494817277,9.09655491517607,-7.84523637194608],[-5.29108269409198,1.40253662879327,2.58828972733579],[2.04311102994936,-3.13050219870772,11.1398898203875],[2.51886969760562,10.4249228119169,-2.24551560140265],[-0.0805417744135316,-2.93470960477202,10.7127682935635],[7.52946256462846,5.42003590957272,-0.540344910658053],[-0.15405212126297,-7.21845512590055,-6.14453542146002],[1.78538670588439,-6.25617960165906,-1.96520851136156],[4.13078035178287,-4.95728787600239,-1.68199046100249],[3.58139455918968,0.668505071655757,-8.85603672946609],[-2.4206563116246,-3.30798863803807,-1.24619727675583],[3.69130453931451,3.86076737933552,1.33145412142417],[1.55621007533574,-8.20931298756487,0.634622015520875],[2.54959505792934,-0.128268504273794,-9.82099173585581],[-5.18567269622958,-4.21625529619618,-1.90298041759693],[2.97767860717938,-3.9313413767004,10.070462999737],[-8.52321436011595,-5.92249612320159,0.206609623178866],[8.79928985003822,1.03022113625768,-1.33231523082683],[0.820240330172493,0.296069921515791,-2.87555913349554],[-2.29802269747817,5.08141109320904,-1.97380737686899],[7.48300001318049,5.2221364893669,-0.640254564135736],[1.73225182404928,6.46623120295324,-12.1121411061299],[9.96968187815909,2.59003186269602,-1.56922944971259],[-2.61557375897567,7.44113753121443,-0.774974826124991],[3.79127429127354,-0.342753328551135,-3.73750889992091],[-0.313710651545149,1.50499479931695,-1.80872136313589],[1.68034549772476,-7.40151273293761,2.74899849076507],[-5.37179414406495,1.74270260497446,3.99966734647028],[2.42928452451535,-8.42038996311075,2.74037967814142],[-5.45858273376149,3.41334277690011,-5.93502567846651],[-5.8355309162196,-3.48228226491903,-5.05698892313386],[-3.93178609900602,6.66502903940659,9.14715061283246],[-5.4044317244031,7.25083655899563,8.88568340583586],[-3.57624695656621,8.14035957402915,-5.65671701002972],[3.9769428791442,-6.35608082529978,-1.0513886222397],[-4.62459234578178,-0.206827694728408,4.64041902719967],[2.45262019851244,2.66786220574239,1.09848666334848],[-7.94473997375734,-1.00981880416772,-5.18224017587081],[-3.31025489481858,-4.52101238280271,-1.28757913834424],[-7.23462387111963,-5.14317652508062,7.0784963916558],[3.00091623748216,-9.50819043541166,-1.86514617856313],[8.01318815502847,6.13230488943302,1.68455619500482],[-1.57923747149482,-8.23794775718837,-5.64378553712728],[11.7153051741643,1.27640036319125,-0.877928971757721],[-8.90182691022258,-5.83654584301778,0.717675106720759],[3.40768692963903,-8.14498064367533,-2.35690362055458],[9.49294974205372,2.78206477306799,-2.60964931842387],[0.97466533431035,-5.92738422067798,4.7934113545557],[-4.8411326159676,-3.1103974203977,-9.04664599825795],[-5.52143523803581,9.4842823463996,-7.36823419212392],[1.61122359456758,11.9668882557163,-1.71646472735907],[0.260874324287842,-4.29773307921185,10.7601730846589],[3.99124126014205,10.9729617922278,-2.29111114700212],[-4.0818255074849,2.67327566510108,5.17984157901873],[0.0556026824473786,-0.0151771386154966,3.56344492008503],[0.363323996582076,0.486923596924825,-3.00914610064036],[-3.25578363029669,-4.74464369916501,-1.55389398054458],[1.19199657730064,-5.19766193961365,-5.60378962423367],[-2.73981989775294,-4.61753070936319,-8.4744061969538],[-6.18360625858692,-3.09328894800361,-4.9655100017627],[-1.01704709392717,-7.58170024553358,-0.0253563898509834],[-2.42941693733939,0.549876992466417,4.43731979788026],[-1.34062137935657,2.99532185986695,-2.0006005936363],[4.46340273860744,2.81011165436618,3.36965609569638],[-3.52317010300441,7.06307662517454,8.8865417472329],[-3.1124091490111,0.816595647134233,4.46763797790747],[0.585262729014571,-3.62934991654089,2.26442463947568],[1.64566690781487,-3.76847455306078,13.0744696187232],[2.77932484216598,5.7243486049332,7.00182139952717],[6.74422856449717,4.46513212492659,0.151444408356424],[2.66819172052154,-9.18913105838377,-0.0146284234104212],[0.589504013203632,-2.9873520084368,-11.8389514474487],[2.78874047579981,6.5792950610973,9.0812656916237],[6.51998072577297,4.29921587740886,0.815947198757246],[1.11594841063097,3.398256519462,-7.47029854607253],[-3.64283681472208,12.3595839397798,4.19652139667963],[-3.63650957802443,0.92501917069712,2.3662120929509],[-3.93982645850132,0.274768557839524,5.35227487439204],[-3.98343639556765,1.63341684207111,1.96571596053533],[-5.8402221941689,3.55249391282374,-5.85222334007805],[10.2799592332859,0.372700179122624,-0.541969844720185],[8.47837320251699,-3.20285933280804,-5.03210557178677],[-3.82110485868021,-6.06592835845066,-1.20469110917357],[9.29320538401138,1.33486300113305,-1.37767761868952],[0.979652531246484,-8.73608466127715,2.52442084259108],[1.39877162655729,-5.88090305792124,3.37959408572012],[-4.13232363151889,-6.74014720095519,-2.2094203723094],[1.9871251610855,-7.70664406536739,0.0251249154689704],[9.17570991185516,4.10375858813413,-2.44229204510011],[2.30205009680266,0.622894472378964,3.6195831310662],[-4.14774264083873,-5.68262286331937,-1.61735327775676],[3.54670371692633,-4.75462376292345,-1.85463719533138],[-3.97247570186184,-1.40258612658234,1.98251692048628],[4.22829754680969,11.1387732473922,-1.97303460359707],[-2.26462295469038,-2.52023536138671,9.23737109486823],[0.370717168578017,-7.18007345051078,1.77208343673241],[3.412296727765,11.9914070092545,-1.62096689874981],[-5.00759577989531,-0.282090873909775,4.51521676691262],[-6.51018242244391,7.79373948183395,7.99969729659854],[1.85993626356889,1.44120987571094,-10.0846258950606],[-5.68541786153386,-6.51995290292581,-1.37303811899471],[-7.28354632771051,-6.14495593263408,-0.627938938336915],[-4.60457305646638,6.99895164236503,8.80656711432062],[-2.96620527285705,-0.0442774793956663,0.17501080540603],[2.826002509369,-2.47088769836655,-6.46390669032935],[2.872029329989,4.3136789911133,8.4465436869552],[-4.87294224486309,0.775351384770729,3.10451045313863],[2.74418967425989,4.41820833222275,8.29200900825503],[-2.48433463623383,-4.92545538787837,-8.61595767943809],[-4.40514390614073,0.127683301302182,-1.24800706425452],[2.43147687330413,-9.34215427629054,0.108122105858228],[-5.3203033431943,2.82763459535864,-6.35169331620975],[2.5633625124922,4.27352566302276,7.87255133158627],[1.53019116637122,-2.82745605858242,12.2463421375275],[3.12141772131217,-2.83472120232873,-6.94394287200831],[3.17823397223299,9.98253067893985,-1.86065110106769],[3.75478934018602,-7.78564688547688,-1.44700600124382],[5.16849306696054,1.62624638054404,4.99030552812936],[-4.7261800188268,7.79532648825817,-5.78000043039691],[-3.855193705971,-3.31827756293,-7.72250255107293],[-4.58474397826867,-5.60635726264636,-1.00174394016157],[-3.03572953656652,8.90652078029526,-5.92434577429528],[-0.445655076362674,1.12601248038349,3.4682331020336],[-5.40101355863759,-1.72805146205175,-0.564020248758707],[3.4706559708927,6.06959368793061,8.46963052351164],[0.291309543400708,-3.24393018276286,12.3337523491887],[-1.04896121040541,-3.74204748013335,-1.07213996055797],[-3.29352406700078,7.29186277346533,-0.51133812286233],[1.82625830163193,-8.14019761258658,1.40736565628458],[-1.07211192034321,-6.47921728195,-1.76252369632384],[-4.38331799896127,6.19705012032528,8.72281781026974],[-1.74948774186474,4.65652833273022,-7.1510326190181],[8.67712388334291,-4.06267784601211,-3.0369587115798],[9.3142928469264,-4.45437218453621,-4.4627226851205],[-3.71917335965886,5.76523985474617,0.552934486735797],[3.54698837470646,-8.90718507310794,-0.0767278766938644],[2.34298932274401,0.509062720536119,3.13262714925539],[-2.93549346722305,4.65843524417499,-7.64285024110293],[-5.48534453473418,1.28582304566432,3.49946659761589],[3.11768562620299,-5.96324922405451,-4.81495304259026],[-5.20999932674888,-1.59668840029881,0.532523854426193],[1.23215652893459,-9.9562464815113,1.20155580243903],[1.65816513750882,-9.11319569471331,2.43270640787706],[-5.51730615198176,-1.58628323680912,0.407249180989876],[-3.56808501469768,4.62818727264492,-7.25951686006457],[3.18840639524067,10.9550741005707,-2.17151058334918],[-4.08246961632623,1.06448337541254,5.01317079015815],[-5.39778130216318,-1.06486057841248,-0.714235417362645],[-5.87037048308457,6.88321909137019,8.08331581771824],[2.88599458214909,6.03188612147358,9.25330858295808],[1.25125296880553,0.0102088257476208,4.45722889271441],[-3.92737628438962,-6.27911066169747,-2.83956135699335],[1.20828327526353,-9.06040853885616,2.45635851271142],[1.78903146539341,-2.73755773725405,11.7150370203954],[3.1126914611314,-6.04923498899561,-1.39352519553809],[-4.74653843915723,-0.406555001685074,-1.04146277013579],[1.30104956746593,6.08625531510964,8.17663233569406],[3.30474102802685,5.75948423153936,7.58987101857261],[2.34739184800552,5.82591323604074,9.65736726135952],[-3.82814002784826,4.9625640042029,-5.06079958883148],[1.51262840501725,-3.21167397301848,11.7721340337302],[-4.6964892788755,-5.67304500533746,-3.00559210524215],[-2.65014376562579,11.636621236577,3.80377048181551],[3.47788190154123,3.41019303545614,0.368945961284005],[3.13807748508406,5.414685892145,9.22993321744824],[-3.63288979133883,5.00040667010803,0.507419752804017],[3.46800807785263,6.33037285016056,8.23455044340197],[-2.93216965082281,-4.30571319810469,-7.68786776119657],[7.87672122540913,2.70814514232241,-1.94739993054247],[7.48426625704707,-1.76288002991061,-10.7479628454178],[3.5713995119338,-5.70511197839927,-1.40546742456911],[1.61160580600411,6.29279935228609,9.21776608874978],[1.622690929793,3.75610428948588,-5.17383166016548],[-1.48145772339311,-0.360617380138722,3.21740239545017],[3.32159983177954,6.33876815830356,7.6349394343522],[2.71103165514843,-2.42197683593045,-6.95665942285203],[10.8100131036872,1.86378482741855,-1.23411271780348],[1.45841561582451,-8.65151138007618,3.16810611189913],[2.07186972183779,-5.090481310602,1.98228776487113],[2.97396006071238,-3.58994028945427,-10.8048627872139],[-9.45820119852728,-1.7698462392477,-3.88614625305015],[-4.0890757669384,0.780172856317835,2.3863414893527],[-5.71767401371722,-3.72733014578225,-1.89583586813421],[10.3588046338452,4.5945758174834,-2.33431871975099],[1.44954948655417,0.157668381568382,3.82752552620833],[-3.70728453348481,-3.69564200077529,-10.4470849061904],[3.46326698544928,-8.67049595580944,-0.665817090696462],[2.0435955971504,-8.55248985873974,-0.559150382327151],[-0.0167561402905785,-7.79202120262669,1.16344756458326],[3.62204619620844,-7.94112833461581,-0.592177239938534],[1.22938709066083,-6.85704006499317,-0.134967257922906],[-5.37502383862767,10.1734249050139,-7.17142272200425],[3.30092356747084,12.1130641067177,-2.83392064009621],[3.42705521610912,11.3356377607813,-1.89461181651397],[3.68499923988152,5.77007516704182,6.73475009474101],[-5.50949323389044,8.03679659765751,7.73370409365432],[-4.48843111721217,-7.2236371738174,-2.01339557134475],[-3.98142553272515,-6.88149894366591,-2.47710065168209],[2.40484557632309,6.67836489542815,-11.3848618879351],[-3.93254984547492,0.710027498321308,5.57572690546363],[1.36237257662574,-9.08811530340754,1.39280944134322],[2.60038956125251,5.73852786945143,7.98092244995889],[-3.83224547844722,1.91611557910126,3.54878962440171],[7.59595620796537,-2.729962982657,-4.91950976314582],[-3.60086252427746,5.52949701036359,-2.82279272670614],[0.00378235427492424,-1.45801898708126,-13.5244554844414],[-7.01579703242544,8.67032453926743,-4.09541364590312],[1.5505563509892,10.6136074255267,-1.90237478079088],[-3.93019239863927,4.07471614657633,-6.87655963637712],[8.92312183078797,-4.1928314782043,-2.60214422192895],[2.39442424175671,-9.89370807472578,0.500158619557858],[1.57765934752629,5.67360717226518,7.22701276314239],[2.36516401331974,-10.2943519108096,-1.47056859340771],[2.72334841196665,11.0464758277763,-2.00162050664295],[9.69198156996388,-4.63032252947015,-5.28561215532811],[3.76465613252359,-7.31837482152525,-1.5655373975965],[-1.77583820035611,-1.81940265202365,-8.58363446623207],[-3.32538612989964,5.84433704434471,-0.331971091488442],[1.88501083882931,6.43887960802562,6.75674084294119],[0.607805864192282,-7.66824129324212,0.184176835160384],[3.84972172311191,-7.64362274896256,-0.822568750400025],[-5.30603312453266,-1.44061376776048,0.736977966672419],[-4.79820361088909,-6.1532899385502,-10.320646181089],[3.10359729162386,10.0330699262826,-1.38404104830176],[-4.6459443287783,-4.8640790483926,-2.26330362371334],[-1.01586517992197,0.298824190361457,-6.95792253629414],[1.80942949720904,-6.11109389197495,2.02167888140074],[-2.94166846694892,-4.76897235477435,-7.24484727192017],[-5.99424721455649,-3.69124585357502,-4.51576765781748],[1.47146370173141,1.50832395983386,-9.06196540074643],[-1.78259071763448,-0.400145203844255,-7.00752846713694],[-1.72268809497776,-2.30682692325132,-11.9438057472732],[-3.48707448496688,12.5090274233729,4.51050353690968],[1.48835992716544,-5.97057217943309,3.68011528593599],[-5.20493581899783,-0.507577028112927,2.22717394278462],[9.61350235040224,-0.73415187079049,-0.585279603981479],[-8.66818355319619,-6.18320442579045,1.26308922939698],[0.135471537200967,0.413967682716432,-3.10746155088042],[8.47377206616764,1.12960990517076,0.805548911788338],[-1.85569923454067,-2.07233642062724,1.52638891327135],[-7.01514019047155,-7.15195005832919,1.59832546080025],[-4.48878328154192,-0.213497914453846,-1.45418906461424],[-5.26632617736769,8.97185255364708,-7.39483639467863],[0.757000102662106,5.64870627208948,7.61268251550174],[4.41145476325957,5.37021156284707,8.47237084515246],[3.84250682031374,5.92994555172801,7.07021261866944],[1.38804373961595,-5.51716469332791,11.090634892116],[-1.94804728859345,-0.16084023663389,-4.7595917194176],[-5.52741249585562,-3.12298458491928,-5.36906765214004],[1.61255382048415,-1.0229244742318,-6.20570920125867],[7.90390211217515,5.89656462751594,1.96175331530346],[4.10983233728721,-5.70789698895105,-1.0934339091059],[4.08392591714728,-5.51793029910619,-1.22130454749652],[4.35923887503448,-1.32683604028201,-11.3061439878776],[0.137420397250515,-3.35414978462654,-12.001841402623],[3.62526102920495,3.7293667882022,1.47815057057924],[1.33013502777251,-5.64691986514082,4.8288720163712],[-2.71154981714204,3.94302136544542,0.308040259498586],[0.836381244738304,-8.68086455991825,2.98034726612821],[0.511614810107824,7.19736768990886,-6.12768875941497],[0.763483262757457,-9.16549677213003,1.79554060001236],[-3.29574803743368,6.36437543943915,-0.262933071339814],[-8.22294773273768,-6.10156564986042,0.151825521178976],[-5.36342249962901,-0.97908453952049,1.5363634024551],[11.3739097937558,1.07182778847638,-1.36252881337288],[9.44555605585631,-4.33999155504244,-5.62518393797151],[-3.02863139204889,10.2232666835411,-6.38648227176844],[0.126546623821654,-7.02725033885255,-5.80649445973477],[1.12000903555405,3.81047067432971,-6.73996590937493],[-1.21049922297317,4.30049975417285,0.57799575164698],[-3.83695558608498,2.21404359207574,3.61483480848605],[-1.92619428564281,-6.30397004752942,-0.951228676082283],[-3.04833197317139,-2.81607935301525,-1.02745644748495],[-2.81502993248023,-3.18615292273267,-7.24998922620923],[0.796752133201178,-8.19384292927871,1.48288609352534],[-5.76417702110473,-3.14223606358732,-4.70849970418638],[-1.82173100326518,-5.9458796571545,-2.02548857169246],[-4.31047608925941,1.60464977672608,3.69323260881486],[-3.42123473189845,0.213052739926619,4.3993889722406],[2.22614707666094,-2.19884029997513,-7.16914774712632],[8.51723725307772,-4.16775238329382,-0.969430269969572],[-5.03731849664206,-5.90358558464214,-1.65599220825163],[1.50796889649097,-5.45491091453962,11.0858484368414],[-3.2828503887908,4.83327005581737,-2.43845738308185],[1.1450996837679,-2.38093320738511,12.7634633313242],[1.32060238035506,2.50273966113941,-3.16803345747165],[2.82829751646833,-0.956622142614284,-7.35926010634282],[-1.59075909991298,4.77271461586455,-0.0934544251447814],[-2.24367284104814,-0.415368024055409,0.561478298301666],[9.18027705688221,-4.11816372363667,-4.0941700242751],[3.41769906453158,6.23285913221061,7.71716623964935],[-0.458920630291105,5.96559856947751,8.63184039142763],[3.53265850055784,11.312805334613,-1.16539446271765],[0.841006282405897,-5.10918469798642,4.81748421966016],[-6.28361027627196,3.65849134662473,-5.29451508372766],[4.15581929836573,-1.29912449818043,-2.75851636526598],[1.15625198572156,-3.53982049964896,-0.239641240847838],[-0.247020043605657,9.28953033563204,-7.38888168960394],[0.755415041580277,-3.94171353387273,-1.46036493220535],[3.72916625125214,2.19681338685214,-10.4587477584105],[3.50994509662952,-5.68217487961599,-5.64391222544612],[-7.35760795689565,-5.82031646505551,1.48390078965412],[1.16398419311666,-6.84019109495559,3.15988854104014],[-2.85270842110699,11.430204964379,2.99243268535575],[-3.34307770036963,-3.68781217724949,-3.52460933092047],[2.8381136824443,12.0586812328256,-0.936202447575111],[-2.5241469653572,-2.83096257163135,-6.70395124448828],[9.97750660021495,3.49336856503678,-0.759531515215482],[-5.30487483940998,-6.45089534742988,-1.36812648377343],[-5.23318956867517,0.775426621291845,5.30425374569307],[2.01538043643406,3.87745922166349,7.8457200092976],[3.38883156561356,11.2245712940685,-1.79401002661269],[-6.62755481993426,3.3679828950275,-5.03920498949586],[-0.286450865753487,0.691129653226006,-3.41306073590314],[-7.52882626811687,-6.69402760787406,0.967725281075545],[3.47164563172044,-3.50149171319151,11.4822004970684],[1.17124035399612,-4.17839961591372,-2.37873141740675],[-4.93552015134838,0.228886108973313,-1.17782958608144],[2.64259255744483,6.25911369148765,-11.7124067070653],[2.78369592519346,-4.42156427794594,11.0500900954895],[-0.266961419453763,4.40758915718845,-0.877935786573091],[10.8638440959324,6.32104310063366,-0.905487178400273],[-3.40180403680948,-2.71930052380057,4.7931058060686],[7.99784911093541,4.16128411730158,-2.00378339468098],[-2.58978306773866,-3.53718649382887,-9.28739999269605],[2.03417248650266,-6.81118125517746,1.21685149369175],[8.10159681998065,6.29155730515626,1.45290922451487],[2.00090082640557,11.0846628832204,-1.83978065118555],[-4.52928001394887,0.40992407476357,4.02424722151758],[-3.02828713256649,-0.383377747080085,3.14627321398355],[-9.8201779774123,0.5951428650263,-5.45246377892439],[-3.19124819076471,-3.4680509706814,-2.31540888299981],[1.93496721150273,6.86939171312167,7.85513465242265],[0.29706528882818,-4.78017381065283,10.6868761781253],[-4.02998390577133,2.10607097964058,-6.62601211801553],[-2.5478820691717,0.499918660462461,-1.47426913480551],[2.8193804642304,10.1948311269977,-1.99278747648528],[-5.73996457078781,-3.35917383339087,-5.17213412911443],[2.48261852125209,5.78161179803272,8.60987712332295],[1.01324365663463,-6.20930565619816,3.9904511033147],[-6.77813749898749,3.04042680810757,-5.4519424559065],[-0.370804867312049,-5.10137059187216,1.56006412492183],[-8.91228834345329,-5.97812565478327,0.740310217338293],[0.846008898353257,-2.83391775560822,11.8307966886373],[7.99621897864267,4.06281824553466,-2.30850430391305],[-3.36394537932817,-1.93799497025069,-8.27795213144556],[-2.88962801362283,-3.63123206790423,-8.96183755876949],[-6.40431019158168,7.96625818814929,7.94064619566899],[9.28915669576254,-4.52685830282283,-3.86790313544203],[1.52424499542501,3.67288706901073,-3.85233708226981],[-3.60047053084896,12.7638672194673,4.04920472846375],[-4.69383437962865,-5.86220068220736,7.26937868151975],[1.86664149162424,3.50686106782775,-6.60882479963962],[-4.16134978864375,-6.13287967746712,7.70471270019093],[2.50565876136554,-10.003369215778,-1.48725660985045],[-2.40198658366221,4.52249884768091,0.935844987894798],[1.77388173714137,-7.64235610791543,2.71212027611228],[8.15004372307835,4.1428594427339,-1.85256330763032],[-1.81191782351243,-6.31375481620498,-1.8749294646192],[1.40740747286503,-8.40188600516988,3.33835414796363],[1.62804296511863,-7.4744912278709,2.77799157597569],[-4.22633910251805,6.00078348446242,-0.904028578981151],[-1.63329007920292,2.88284376837474,-1.9688523422905],[-5.08788564931036,-1.40239516693758,2.87897939710647],[0.611862455447354,-5.53128261239657,4.60437747142808],[0.62875337092994,-0.878639472752963,-12.7730657834281],[-3.83376467582765,0.675395192471822,4.00034272484024],[-4.6437116375892,-1.07556446014731,4.13748627453275],[3.1821574066103,-3.97038153227374,10.674239576133],[1.23776181478351,-6.88502409013976,-0.256049364778512],[2.1641852159824,-5.15847218652056,10.8357906276678],[2.44568802186251,6.39182303633364,6.77314320676468],[2.07254208348055,-5.10275296788693,10.7942792356871],[1.88630421894035,-5.57959146550629,4.00199310760281],[0.499744742170491,-4.63334436082244,-5.73749810324501],[1.97903968204235,-4.47478318924095,9.98003153208625],[3.7129068413237,6.2314775048357,8.29875643894625],[-3.96976182992704,6.9686752442758,-5.89846837328349],[4.99499227362936,1.80951018117062,4.69524133866055],[1.84878423873672,-6.35440471850574,4.48128760728898],[8.1282781544186,3.28330614784528,-2.04193482170763],[3.80378035319022,5.66642233327864,8.43834308355846],[2.97431185359163,5.52087798098589,6.74675797627673],[12.4005522178202,0.863224034811379,-0.195421707004024],[-5.87009793558925,-6.59154646799166,-1.41698725635254],[2.64800219995034,-4.89856209406671,10.8563507701602],[-3.46061036558911,7.28676930570979,-0.544161710264134],[-1.70051925737507,-3.63681000261221,-8.59620327992296],[4.07093502996448,5.03555923331908,2.53832567431219],[-4.21570842217775,-5.9707637797524,-2.96913923233485],[-5.10856564837805,-0.0735980706962747,3.07400116165244],[3.67587851505862,-7.61790842217607,-1.69803701039244],[1.52140566372015,-9.28362991509642,1.64778055860851],[0.814906463636717,3.47726542377301,-2.58433559449801],[11.0811499157526,0.00359775288243214,0.023789515937542],[0.215977303103038,-2.89054274761826,2.30725834384312],[-5.03663280787374,-1.25023680916106,3.01161796374716],[1.26134554516824,-3.48142456554526,11.5250294133332],[1.91352091461479,-0.0746027429300797,3.98206079602734],[3.14139207975751,9.70397891385853,-1.21780292517036],[0.777898601201963,-4.26261578980303,3.99603106135307],[-2.10118937787972,0.166146325229064,-5.16597577597814],[1.36630479056716,-8.00817435218551,-10.5923796868331],[-9.31698965440186,1.2699139707383,-6.44179226899859],[9.02383618304592,-4.13828930277565,-5.09284630869092],[1.2402477387686,-8.61615705472208,2.56897401092336],[9.73118705730647,-5.03942325168659,-5.52678767820638],[1.15429247812794,11.7654678614535,-1.7013071641914],[1.8073501854053,-3.14773616942339,12.8735694444247],[-0.506595881337567,1.38673079134337,-1.84446063826314],[3.99683652999902,2.61649991588621,3.43571901268314],[-1.12997234225718,9.88320910327355,3.21967164615765],[2.55859953573366,-10.4304183894379,-0.0532826913482083],[2.38638204936335,0.196697313477878,3.52738490759671],[2.97586289746145,5.42291724124132,7.31276959681041],[1.3310450329267,-4.78912138207813,-4.92596028356544],[11.7548318349134,3.69705170763668,-1.47853104535182],[3.84099123135615,5.78552939435537,8.15960092506979],[-3.22768266218453,7.00413567667168,-1.09768660318709],[3.31885068460307,10.5387265084366,-0.73918723260747],[-6.75461516583236,2.75452045736796,-6.05681544644436],[1.0233418347321,-6.83995749271504,0.0716579759925171],[1.20568986761232,5.38210733012324,7.59566638671441],[-4.72709857272109,-0.376265581533184,-2.06110769434717],[-4.08290025976429,-5.85844956752174,7.93309913232252],[1.7021349333763,-5.65341548848381,2.41377444168327],[5.18275043420388,1.33763903217934,5.57883017058178],[1.8608437029201,-2.18215574232513,-5.66639970294259],[0.504016512197303,-2.91240911247542,12.0295794054546],[1.85501626218366,-7.81070267908434,2.15964835936517],[-3.29775674158392,11.8108260978496,3.24692170632305],[-5.22083334455132,-0.744162126518674,-1.37849030769068],[1.57287194836023,6.30816879070417,-11.8719666082177],[-5.40394459659236,1.48446648754613,2.9557689772037],[-3.86057987421897,4.95765106642892,-4.99434028918675],[1.98931957459816,-4.58973723268948,10.8641857888963],[-0.506003237029499,-7.0665901508206,-5.74590642402747],[2.04085553744653,-9.33659740231442,2.27298432928068],[-8.58881287448478,-1.12642049895921,-4.84359740473672],[-6.54518338692646,3.24560848026137,-4.39266334429186],[9.29120362037233,-4.20533459595033,-5.34874518860823],[3.1809528541827,-4.41071402168862,10.1090753115383],[1.30498065047996,-4.29412276136406,10.2546711138768],[-1.3604686538314,-4.86082098700235,-2.20915037914915],[-7.34919436286139,-5.67680446556998,6.90625901489338],[-5.64355895926673,7.66847316656631,8.7766265519816],[1.90104971799447,4.52625421260482,8.63694700013627],[-2.57909896718466,-0.263738436178477,2.77693523010318],[-0.25039608556558,3.54115760029532,-2.96343259716109],[-3.13123222958271,-4.71068231350701,-1.30517611654981],[2.46705567284574,-9.6609828092586,1.5303544472735],[1.54983371264254,4.08411872590732,-6.11445419708076],[-2.60496274287501,-0.870708257974383,1.55048766925971],[1.93730167636316,-8.38509808795524,2.10101210892022],[0.976571771201112,-4.36839004434277,11.100267321653],[-0.810948197647335,1.47350406135434,-2.48941762818906],[-7.9760258150892,-6.71167345168879,1.69898594850297],[-7.21160245596917,-5.87069375872729,-0.507031161883078],[0.187004705775582,-2.76515611763639,10.797459754461],[-6.25062508127045,3.56788052561274,-4.83900183928455],[-5.08437432647897,6.24169906378103,9.05452742222225],[1.83333472590721,6.07509168359934,-11.4087737153165],[3.99165165491424,5.5666255603809,6.87934557019515],[0.0412600754163901,-0.282549945383769,-1.88120334941654],[-0.232124334134722,8.91560790309594,-7.27162359928248],[10.0997282092437,3.20162562938478,-1.70513398610807],[-4.71989780494354,-1.69022057261903,3.97320679965709],[2.97590096147012,3.89432968253246,8.36795809614563],[1.13845216783977,-2.67128736560349,11.0354063728505],[-2.70423892128705,5.04053243521532,-6.84261057376025],[9.33130737088332,-4.58290168963515,-5.38737547952124],[3.82189994778006,-6.10422941493189,-1.41352269768852],[2.62959079348774,6.35243297149743,8.66610545473749],[-5.31850990544355,8.17823266317939,8.02658172884986],[-2.03191212940547,-3.42584573172236,0.125248521012023],[-5.41871735160319,-0.208834232656566,-0.940475077293559],[-3.85500465240021,-3.2040829422644,-7.85815462386644],[3.61079743668668,5.49633724149332,8.14882368280236],[3.46056832273357,-7.39980682922801,-1.34674957962242],[-1.89304119036586,6.11195635431606,-0.603386597013759],[1.19755358745253,1.69030172243791,-1.2027699527004],[-4.88578049521581,7.5195107215243,8.12769750027706],[-1.34804399899615,0.765680538457706,4.28476366372975],[2.68494600705184,11.6159328589433,-2.75893263709204],[-6.41432609526482,-6.33066041806183,-0.0415071097658467],[-0.161186146641026,-1.18741313758628,-1.00616675527025],[3.08123934795675,11.4809457481866,-1.25032677829353],[4.5424396939581,-0.876481106952649,-6.48269525526654],[0.152820668231289,1.35822486201251,-5.63845212800119],[-2.48560941335517,-0.858872758243581,2.37783369516464],[-0.453248864767885,9.23684899922689,-7.22980524635809],[-3.63466993186847,-6.43702573305228,-1.9456645806508],[3.92968404040361,-5.94548792985435,-1.05593795277996],[-0.687962525430798,6.2081579221371,9.01478800169143],[-1.15519334934524,-5.7143204752976,2.11746972934606],[-6.02156520898093,8.81903454638465,-3.70587246926916],[-8.57727229355379,0.147751417844176,-4.28328833199037],[4.43484571891059,5.51748865392374,2.9851009093241],[-3.82624528973484,1.72375097073609,2.78313191294946],[-7.89585429213359,-6.88227526449682,1.5349790265961],[-1.72791248043283,-2.31289933833043,-11.9308482066462],[-0.372647338273382,-2.99292571013691,10.1956449229081],[10.8602551809686,4.76843988553113,-2.06460994481253],[2.90282928685012,11.356577096498,-1.99582276597562],[9.43593033959938,4.01290151732931,-3.01177242367486],[-3.90322330454468,1.65632197518064,5.18070712995392],[4.00379475544088,10.5656959087929,-1.24660573798729],[3.94200106381242,5.1532364506172,9.16560319222055],[-6.63169345289611,9.24197675918185,-4.11222443940482],[1.83628744909601,-3.01817689255424,12.3527376670244],[1.08796747583672,-6.69143270837459,3.25301018897062],[-2.02434859710283,-3.47573651482276,-9.6905440383707],[-5.53105099232624,6.72039792673146,8.81472023199798],[1.46321181994338,1.68492265611871,-10.1044159947296],[1.37039873612797,-9.23980061457654,1.47447024781162],[-2.22933785581605,0.984058445403032,-0.966896744836493],[-2.88188507070383,5.94061840301137,-1.83973243312807],[0.315030257267838,-5.27830391331877,2.67946782138636],[-1.38991430964765,9.20924333338194,2.3833064541916],[-3.91131679031635,6.6720097238942,8.48871502763099],[-0.396416123937497,0.372090483453635,-6.58276987253184],[1.47079118930858,-9.69715761755035,0.772481925479743],[3.32514129902978,-3.84394829679398,11.3178835213941],[9.59261110455127,2.76198366245721,-1.75969016374741],[3.32142227620194,11.9483000317703,-1.97761243881983],[-2.31883727441123,0.782305866901348,2.9056633793982],[-9.32641862606283,0.460681579435534,-6.28446467338317],[-0.706131935720317,1.00480917896325,-6.52952628403702],[-1.27546092263358,-4.37797392651764,11.3720026041438],[-4.52645520156774,1.76101408173,2.53607883875469],[-1.85309873512232,-4.41695625486459,0.00432923351106784],[2.36560135209544,5.41160111922656,6.93788656057169],[0.347094108861982,9.40963612044327,-7.32779714017129],[-2.05388862858929,5.0335201922502,-1.96407518104688],[-6.30093268088925,11.0095164532077,-4.25863650852575],[3.03093933043421,5.58479417579458,7.41860150049441],[-4.91784061680204,7.21025415740321,-5.02927690605952],[0.472582080167336,-5.3747805968771,10.8686193964083],[3.18354172020219,5.8753052276823,7.08550020002969],[-3.95461200537811,-0.325882495073312,1.14272563899936],[-1.67435140533033,-6.5814402186658,-1.87173006616339],[3.75284849141939,10.1135207273878,-0.589513586503853],[-1.52529192203706,4.48392575162709,-4.62561253089675],[3.32533928082203,11.693081003044,-1.99782986122871],[-2.02867485631731,-3.50758887971722,-0.673562784306632],[3.44604821423908,3.73838371377865,8.55384747810884],[-8.72629594786354,-5.72796602909109,0.908704020234738],[2.85232071814154,6.70014463772399,8.02242751098994],[3.3257790378546,-5.68903038922403,-4.89419012363706],[2.81068462355591,6.54073086302136,-11.2693535712532],[0.992055711757593,-5.18233551319243,-1.89250502329839],[-5.38232916706861,7.49808191834944,7.68676042972946],[1.70496911020422,-2.25977595456972,-8.25317644111843],[3.01364256995348,-8.40896003658415,0.536968120006616],[-5.18149880439736,-1.11607572400813,-1.08025512994488],[3.00805384750831,10.9555482194584,-1.99273098595258],[2.45533094688828,11.781216595035,-2.05590842977713],[0.559144053262206,-2.91575545925194,11.3523250270699],[0.765799036675389,-2.83142099819432,-11.8345403716337],[3.80860494787622,-5.58269679228967,-5.10408480126656],[3.91632381955088,-4.82093529502412,-1.35644591841746],[1.44934239607424,6.47482919939057,7.24966588947042],[-4.83815678773362,-6.29672570805226,7.42709294119178],[3.38909002243288,5.95121856114304,8.08414905015274],[-4.73760980384199,6.6666385844622,9.21270143991069],[3.40954785364433,-0.326488043166635,-12.4281232055551],[7.78440259992655,5.57067490685163,1.97361713086527],[7.26837226142887,5.32545844033281,1.49872358715855],[-5.874453704102,-2.96493685044168,-5.34362866915417],[0.578871757539821,-3.02906668863822,11.2510293240229],[3.10638497590998,6.40873152007753,7.10440388684863],[2.52296170396735,5.34751970533466,7.13305973067647],[-2.12829556920607,6.32289758758105,-1.08975649386954],[0.188471661992066,9.44680078618071,-7.47988189505409],[0.910076376763485,3.30896137732905,-7.03431047646553],[1.63571929930345,3.23488836891127,-3.65601111493944],[-2.40857432625007,-0.811237264543583,-3.35725968062968],[2.86362617019854,5.2525044625997,8.41041066130309],[3.23078178930116,0.129971246066372,-11.562539645612],[2.00477083375626,3.93467258263467,-5.57939293595285],[4.41680614123471,-7.76913236476466,-2.73736139531531],[2.80157284493001,-2.34802583179139,-6.66135496416924],[-6.20864253685526,-6.15262326015676,-0.691754863234095],[9.82873767150739,4.57948956204801,-1.81020162070067],[-4.74656335189027,-5.02314139003814,-2.0620990704723],[-4.59746849479432,-6.33293172248902,-2.40486439356528],[-0.0988915636222034,-2.55193802704355,11.4348740185713],[2.56575649118853,6.3390863765124,7.44850697213912],[3.85186139748655,10.726779576518,-1.50595031269214],[0.357746857668051,0.588052284748456,-3.23324090845192],[-3.78293314326677,1.18213201450464,4.41567717878699],[-5.27999076721097,10.0345198637028,-7.00918689579285],[-2.24684983030783,-2.60531006917091,-3.36705152398264],[2.38779950746236,-5.94020749896662,4.59175451828387],[-4.09303503190007,0.141176456309434,0.919797361445928],[-7.73687049963595,-0.771670747937963,-4.49521692095481],[-2.96523060040795,6.77079522159653,-0.564276511051843],[0.585023441219849,7.22223212551176,-6.1737732941525],[0.240286860620508,-5.54151805242834,11.066274120068],[-3.2366460930751,2.63386273646869,-5.71940993050136],[1.2147969253761,-1.96437609321573,-10.393603970631],[-4.32912863088761,-5.68950957524354,-2.25386676835259],[8.94101609910455,2.63825576870123,-1.2342294014657],[-5.54974217972692,-2.77578913950571,4.56045486593263],[3.02684519515707,6.32527754232301,9.33907772413098],[1.40495992300263,0.338501376295354,4.47715684731006],[0.0307186899769673,-1.09754982817707,-10.899920280325],[3.93707912068467,-3.34730241256226,-4.20967883356456],[3.47667550794893,5.52779051091066,6.60173935582502],[-2.27998247028847,-2.60263277460208,-8.67357833465678],[9.01479512561677,1.87334283659735,-2.26014709473416],[-1.44541020260114,-7.12072876864978,-0.915443407313601],[-3.27071653715607,0.989814043171659,3.50349058206201],[-9.07777868771488,-1.6234303705784,-3.2126848847563],[-3.12160168865095,4.1786375284888,0.813661688545064],[-1.46973116870853,-3.76482139924992,-0.480447890531905],[2.36782942893153,-2.94632579587996,11.3567626047383],[-5.80344567743646,-4.86285306513346,-3.73010554039114],[9.09282676014102,3.36556452310362,-2.7584168017793],[1.17227146545175,2.86590768648137,-3.80061815389319],[-0.109265425504173,-7.12739826381655,-6.03626464030265],[-4.36373465601971,10.2125857102204,-5.67828620388052],[-1.87757108195951,-3.21813011316918,-9.91240337778022],[-4.83387192277827,0.446548599237329,5.05314276471511],[-0.0712399768369427,-7.34263283836527,-0.813377114899321],[-1.19752527870242,-0.509760936012384,3.07336837921788],[-5.93058706954237,7.96580133302063,8.54181502571886],[-4.84293995161572,-5.64390452490718,-2.57388853375926],[-2.69929423599192,4.70722684589814,-7.1674429836],[0.95093757515251,-7.39712887922649,1.04512106030685],[-8.20132621625891,-6.79023366940307,1.6544509358527],[-4.50444891886014,-6.55702540555723,-2.67395065561837],[0.973433757421691,-5.49753087885201,4.41632525690147],[-4.71688099901314,7.7667170786934,8.5827921164842],[0.515619569550147,-5.12823931633475,-5.53389257789911],[-4.86858218626543,-7.06729514363829,-2.24102253973697],[2.51746160893098,6.73011009217023,7.00947433856274],[-0.754439518940746,1.3098761712412,-2.18206954522126],[1.76874044725979,1.41320124631034,-9.67447319057628],[-6.87751943310195,-5.60305042603815,1.08373549003124],[2.81978814869643,-3.40512893607316,11.5070518027095],[2.14811862234297,3.6549972558536,0.382243374115577],[-9.05496677170134,-0.154679532554274,-5.30250387874456],[0.0438421523552728,-1.88169907216242,1.33122360479485],[2.45188855051189,6.60041746114669,7.34454265853229],[-4.82717269459024,0.0592690465975323,-1.2780487773591],[8.74376481801919,3.0911764728855,-2.89567503309896],[-5.98838541918434,-4.04050841016483,-4.30405667817142],[-1.39766979043293,-1.86254499426226,-2.97952931378495],[1.22843704014909,-8.38091795741446,0.919448804390881],[0.496226143849218,3.35547226360304,-8.26510698058155],[9.40707996371579,-3.8983521707496,-5.35463094807282],[-4.22226122370564,1.60921448815852,-4.35938868937121],[9.88461513943809,3.66884970264267,-1.75846803769719],[-2.69864153580349,6.702300152057,-1.1016841637859],[2.28754247685877,-5.04093806268579,10.9484522837831],[3.68043246274102,4.02056655018219,8.07584654847945],[-4.20411537502913,0.672098605959873,5.65983799208213],[-1.55839204523952,10.2896850411704,3.34945269725945],[-4.58867498732203,-1.87355457449985,-4.54550207763234],[1.25597554767839,-8.27962740696285,1.65846964980385],[2.79964062307582,-8.60394496556178,-2.07117426022447],[1.53165638908655,-2.90333030979938,-7.68516670951749],[-2.05105864878535,1.7221191315241,-6.94583812220562],[4.41969134018847,5.62692424368039,7.43863000710092],[4.23993922820838,1.58087870867281,2.6664929284633],[0.176864660062567,-6.65652947449992,-5.83730542486014],[-3.11014846980539,7.61448213344872,8.50410630526127],[-6.56076594558618,3.05886146803378,-5.22655860723316],[-2.36053285169331,4.73904779356723,-7.59234966076367],[3.43497905914734,6.05630156070552,8.66086557238082],[-4.27422173107944,-5.31033301065701,-1.89330316361461],[-0.676128091733666,0.24369503596756,-2.66039088981097],[5.23070715050117,-1.65362640607215,-6.77949903766872],[0.541516229232992,-4.6894421772853,-1.83127552118217],[1.92783996293992,3.62930990363513,-6.67923910354359],[-4.9833587848677,-2.95630338321654,-3.92502318882715],[-0.0103598165347039,0.0817251189917868,3.33838718035136],[-5.00637041756142,-5.76534719644997,-1.83476089640118],[1.77508166125244,-8.42085298747092,1.58522317591859],[-4.2450515626968,1.76370545023396,-4.59383522078952],[-7.64330481739539,0.37421516881883,-7.11017062995022],[9.20013124046969,2.79882544491375,-1.74995885406287],[1.85587744911243,5.73232845823617,9.12623937637912],[-3.44416894771955,4.14547249451667,0.230138851075617],[1.1552493625836,-3.46038905673877,-2.59156441609601],[0.0997423828574445,-5.13213362483231,2.66829378757694],[1.90633961400264,1.07962636678294,2.49160524456681],[2.48755988727041,-9.93606053712045,-1.67066437571969],[-2.2133597294301,-3.36540244524111,-1.08920516493758],[-1.80124145269498,-0.418883119310083,-4.5748833929106],[2.71856206372048,6.12179252008281,-12.1627148085265],[3.10284492105097,11.1543081832117,-2.80555967525279],[3.22635119470381,-8.70746379591809,-0.688328283470408],[1.18325372627463,2.15194563900515,-2.31460433498141],[1.0824784373507,-5.54984108097661,4.81603348616334],[-6.70297964847726,8.02807005733843,7.86393424050597],[1.29385875492492,-6.02093708552101,3.80992534273069],[0.378477394773005,-2.75065464851029,10.410050928326],[-4.15337532494242,1.05063924406345,3.32092017927442],[-2.70826807038387,5.83756346206387,-0.83479680827977],[1.89120375443363,-8.94005394620049,1.20352460251093],[2.47798650111355,6.33387345257978,-11.5959840328886],[-0.0211676564246475,0.611034329414197,-2.46114486835405],[-2.21693139130277,-0.0468418259194902,-3.97460520653964],[3.19507368698596,-9.36895450140241,-0.779818408927181],[2.50676642633582,6.71223973490306,-12.0131795412345],[0.35213561423327,1.76734527496657,-6.629393996033],[9.18180935257018,-4.33961564867221,-3.66313508939813],[-5.3988008317158,7.21153780775146,9.18094599676365],[-6.26266052521298,8.78908950791567,-3.82075600459382],[-5.19620755921703,-2.65521643034759,-3.63675803768867],[-9.11233438982484,-1.34418837302384,-3.304521542445],[-4.52874191782379,-6.04020414038364,7.55662845891965],[3.45495195546317,-3.60954572823833,11.6491414114525],[2.14806902417375,-7.39994772729558,1.6719463223825],[4.44810656949948,-1.50715416000164,-11.4763950139822],[1.62147319631153,-4.89945251848471,10.6949191614138],[3.38471755073378,-1.24172841441773,-4.0637383643991],[3.13969231058566,0.967203737827306,-8.67451486520658],[-1.89892143552394,5.9552027114245,-0.350758354448622],[1.64656740819234,-8.56958445404177,1.23451161040572],[2.71035180105675,-8.59534471759368,-1.28968445272119],[1.31167013242505,-3.76053511624239,12.8450081938007],[2.85384239672509,4.33559175282257,7.93963590524563],[-5.88371432522319,8.3170204730282,-4.68971291545457],[9.85791691580466,2.04148258048336,-1.6130641055952],[12.0143096323464,2.12667072816249,-1.08526488954656],[2.73148000792205,11.7635698820313,-1.82349765445655],[-7.44754743378662,0.285039214442026,-8.20364333801033],[4.11795557422987,-4.7387494857846,-1.44474446061055],[1.54145128031481,-7.87387426765637,2.00321704348772],[1.24339928725622,-5.43732229422729,-0.107990447049598],[3.07082418934009,4.9893262050822,7.52724087118105],[4.4062328721698,-2.5371078936417,-6.78025100808734],[2.6757253792483,5.10054421429509,8.63608958412218],[1.86194503641854,6.17111770980784,7.84618538683303],[-1.41034801783238,0.673293465215306,4.04495936339669],[4.21323684970887,-8.85932686819077,-0.21645525935002],[3.94585112406073,-0.0820241797425343,-3.42792068451412],[9.52328959993713,-4.06279226806741,-5.10239381921533],[4.04521055849752,-8.239165289867,-2.30627040752976],[2.55239684892831,3.73027461326668,7.48274423440313],[1.52824016821651,10.2492446130547,-1.87606971379443],[1.53447889712468,12.5204585681994,-2.36317781094981],[2.40603356727588,-8.00185698342425,-0.777827542860741],[-4.90785195326516,2.21504028041903,-5.78455087450245],[2.69030789949104,9.67161484469264,-1.68923060447133],[1.57424044228498,-9.70622240854206,1.07929321226705],[0.48238283998547,5.73854952405422,7.90759099315247],[2.05793418703599,-7.43659818940006,1.72247797400015],[-4.78413937720216,-6.48292100395263,-2.28109250043056],[1.2004146119562,-6.2972876239953,3.41505607641398],[3.155839916357,-5.06282458581697,11.1854293699857],[-5.64307556065041,-1.5092664901916,-0.944394172509273],[3.39371603967684,-5.32183109914238,-4.75872517093613],[8.52361642115153,0.623120106690595,-1.59840114158532],[2.03879351418127,-4.18628250492964,11.734977943585],[3.56668049191555,11.8713374398861,-2.74160909636436],[-5.16287699655598,-5.82463824476249,-1.37445090361588],[0.25344841547089,-3.15197603743591,11.3015631386362],[-2.3426327495761,-4.85925916269047,-8.64643700231761],[1.24586780233338,-8.62752880821602,1.24798784225549],[9.1812963970904,-4.23255326678542,-5.75173882176805],[2.83569312033547,-3.12304581864287,11.8822846443942],[3.97077549193748,4.56004685788877,8.26051062062895],[0.714133782390096,-3.56875198495416,8.52132651683406],[-0.354295756342519,0.992901861313775,3.49554901058887],[4.29104711216257,-5.90839497902684,-1.2824311112897],[-4.28689236024342,-6.0361234440173,-2.37430755268181],[10.9843303425245,1.20391438079711,-1.73660973666759],[8.99864445352556,-3.95562150732983,-2.00506916842389],[-2.49284597321753,0.775017979817283,3.36564046612306],[3.90610337392186,-4.57206112167201,-1.65472230337919],[-5.42326016645953,-6.48584022542771,7.26532021305355],[-8.30563420382754,-6.42216349626408,1.64138859308608],[4.19748750295791,5.69006767517749,9.01707777583846],[2.70428477609809,-2.86017946160537,9.45420323123974],[-1.61895263730563,-2.42561351981958,9.4511963637647],[-4.90232563217769,-6.0451202421045,-9.89134621946973],[2.45332579854337,-2.80254505907017,11.2207326655143],[-2.38366819493514,-4.12906237205116,0.390001743045832],[-2.91650471391785,6.69895657449858,-1.64934806252074],[1.42052288765546,0.496035762250331,3.17080389632463],[4.12932879189659,-0.488173070498662,-6.22724120040421],[1.69186102354487,1.51878008874506,-8.64221094729729],[1.65569367924217,-1.32831597055901,-6.61333525843296],[-2.26824383008889,4.57039765828634,0.541681595135916],[1.93750191809031,-9.70049093870042,2.0025782301084],[-2.92676779925435,5.04546613212888,-2.61455792615595],[7.69677921413318,3.76374500949354,-0.787931450555512],[-5.45387621302727,7.5723185868099,8.79514762347695],[-0.157784402352532,-1.50643832608764,-13.3681413780485],[1.36779888692201,-3.70717466328314,12.8988321037354],[-2.85301723466669,11.43368605143,3.22623499693232],[-0.295652477320377,0.00440927780701084,3.2156171239506],[-5.58385084759778,-6.09037694306689,7.21354484822345],[2.9181670038272,5.88500408226063,7.72827623957131],[-4.71163938712666,-0.782681753110725,4.48296102594344],[2.54724810317902,3.84771494627745,8.49303638247405],[-4.7710952988942,-0.294635733651726,-0.93469921634612],[-2.43585940191799,-3.09932697191423,-0.585669981465242],[1.11215007851839,0.416256562021132,3.3988256940421],[-5.14043859217537,-0.0749282097189947,2.25893825108767],[2.69820740513135,5.73583248607118,7.91258551159075],[1.50915630016373,-6.87667154459347,3.13796512959312],[0.614145354815979,-3.39263572743392,10.905023634261],[-2.10537504555949,-5.62542263976871,-1.93892186023392],[0.487627359069612,0.875269978769599,3.87449564271021],[1.69755814195681,5.93437344759167,7.12496431537475],[-3.17568298240958,6.72887076105678,8.84763596619271],[-3.27529764704108,4.35062199571091,-0.287733236305641],[4.33243150957057,5.21279082859376,8.75607974959262],[-4.56727912611758,5.13283701393244,-0.0580147053419647],[-5.13688911058282,1.55992994754827,3.16742666605737],[4.14664027783846,10.8854100078184,-1.76386486591732],[0.600767104120931,3.51991200567294,-7.09379989344297],[-4.68767394688308,-7.00461493744716,-9.81328086247739],[0.718761453179029,-0.250699816083906,-12.7871871849534],[7.33263067476532,-1.38513802918594,-10.8733626483604],[-5.61013686757191,1.38000734170321,4.48316606928931],[2.03449284299904,4.62073571951779,9.14129420851796],[-1.15036147889428,2.17877733199984,-1.66623292199539],[1.72172387555205,-9.84470333190795,0.397628754339921],[-0.119623579092742,-0.758485382347823,-13.5758354627808],[3.38413918569456,11.9131670633873,-1.99447545189712],[-3.24746205976331,4.34508089470452,-6.82331100930677],[-4.88502918278455,3.42242260705544,-6.56745355572643],[0.389544866271802,-3.61091197650611,11.8452803029088],[2.9146930220224,6.12998089726723,7.23149920719692],[-4.94933054383679,-0.567795767336151,-0.658913255944293],[7.39925250676536,3.53243441665509,-1.04123936734577],[-1.44714518509603,-2.63491185565776,9.49811580581103],[-4.77093018257148,1.4644091954054,4.27428031276823],[-5.2578006924466,6.91272895252494,8.83809260031917],[1.01008846501648,-6.177520852659,0.441936499535158],[8.92730887791003,-2.10562868619084,-3.231015910726],[0.914068699350977,-2.85703381270182,0.333944537826532],[3.81024311346853,0.454084451941956,-9.13637422170256],[5.22938301127042,-2.92855528328798,-3.93831387595354],[-1.87224651274456,5.38063021734755,-3.39159196224898],[-3.05607766130774,0.107236094677658,0.134364847822892],[2.49308056414572,-9.89276979999381,1.47945803917993],[1.39360422490037,-8.77141067243885,-0.809244356641357],[-0.199014385169442,1.04061332815307,-7.80670429908152],[-4.05167215374728,7.72340104981492,7.88409614681549],[-9.18678611281839,-0.904620955120274,-4.4818334246401],[2.21835727061757,6.41637958303809,7.7809719750538],[0.20668550914582,-8.33347805353495,0.944146714061773],[1.75726389067798,-1.12000688434623,-4.77936218103735],[0.0761574315697847,-2.76678718458106,-1.19769844585836],[-1.82711370260184,-0.0713937653210555,-4.34048458756765],[-5.32809190210619,-3.2214540860626,-4.77879330663053],[1.3262619039586,-1.06456752154293,-6.38652591693228],[1.05280253120574,-4.81490112710419,3.99282871094161],[1.5959442645624,12.1358432891484,-1.94520256855581],[-1.61843010482749,7.35806138668317,-7.09189075594849],[-5.23954629495284,-0.460180290086416,-1.90471552637253],[-1.04051724512574,0.285009376061002,-7.03530417408964],[-3.04965486650515,-3.15774478116086,-7.4268496970136],[7.12928896427877,-1.21810276439249,-10.8183103955825],[4.26624193253154,6.06637175439176,7.73084498470042],[3.74980488171697,11.4054396095915,-1.73608494137309],[0.452510438515935,-1.03640555621923,-12.931486958738],[-5.85829660693442,3.08055167338502,-6.63779238228725],[-5.322674820263,7.34639445035901,8.02125052114422],[2.30603789088501,10.8157053574354,-2.79145244497524],[9.76516198430948,-4.37947705229173,-5.51377135053796],[0.400153184658979,-6.56737153744937,1.98524374862487],[0.525361013625795,0.718841352037315,3.57062826120414],[10.8935444583177,5.08081386051827,-1.21063772716814],[0.282034236185423,-6.26488506469167,-6.097066177085],[0.693964617774556,-5.31465507157433,4.31247778870474],[3.39346387038113,-8.92125085530562,0.128808895075638],[-3.79059610120676,11.8383179353429,3.67359098743787],[3.61558947493563,-5.53585622068337,-0.943335259762386],[-9.63743239812387,0.0325914222629775,-5.51976764757307],[11.9998172997351,2.78470202198913,-1.26629614155745],[1.08740705945394,5.42078864900733,7.76154981833769],[2.38950741271473,-6.21454806241194,2.97399214445519],[-4.61513458383354,0.222538715953415,4.38515399912751],[-5.25959368381022,10.2130042842176,-6.97629517723614],[-4.72886770617472,-5.87623776237613,-3.3124348224233],[3.81881052474303,6.55371218768205,8.47660278904642],[1.71666425056368,-2.73015818455752,11.8076398514751],[2.12007516620897,-1.7425015955922,-6.71971823908816],[-2.84744861264163,-2.18012064548081,-4.67408343190634],[-4.73601558265354,-2.30574149475428,4.17192976564877],[3.17772484090342,5.15025413049731,8.0532896567485],[2.04123800501538,-3.42251280081822,12.1404010692937],[-4.46173680717432,-7.23621973506668,-2.47265303450929],[2.52516815954754,-8.82577663555211,0.564900409724744],[4.02194452891652,3.25875573608787,2.63148922410772],[1.84100345102311,4.89642343478924,8.78595987572425],[-2.20751249232537,-3.99888650898977,0.273642868150293],[-4.11455304284657,1.24999439467901,3.51845310306755],[-0.391866126449784,3.02705056858879,-8.52560182645249],[-3.21135333281547,3.03773265183947,-5.90637945596653],[-6.74465344561462,2.79472059039336,-4.59985796169901],[-5.40139964593522,8.87849857129108,-4.1284817101426],[-1.96373329068769,-5.29532058002981,1.88343718896618],[2.08533412962846,-7.80828767486167,-10.8984055884604],[1.6641970230606,-8.69524519514583,2.80456337343156],[4.04384459540502,4.02099078135602,1.47443222670947],[3.42787563476999,5.90870259370652,7.52401648934806],[2.39427333614341,5.81779556635424,8.22475705001025],[0.956263434543768,-6.49494238930272,3.65163231791178],[-1.95123928044308,-6.21227331532797,-1.31898502950402],[10.997204018546,-0.0518705205110009,0.067371811738197],[-6.37935622201027,-3.63662206320924,-4.53084523895918],[-5.14001518042827,7.22317723084137,9.23106098300211],[2.81337050900615,-5.46639823624047,-0.992066590555222],[-4.20542251089836,5.03141722007132,-2.51978635519367],[1.74734991202724,-1.50711273765389,-6.61968814249654],[1.7168830788833,6.44913937518702,7.88523734439113],[-1.23254082908994,3.32222122953747,-2.59594330558747],[2.19322485049983,-9.3448515620415,1.83705677735417],[2.9714596576803,6.12844489396277,8.44908458972611],[3.90028602848405,10.9886508286462,-1.6723600870719],[-5.97798886069276,7.52818145711227,8.5280363819049],[-1.50701161810467,-5.41393225877846,2.05975769919757],[-2.50863653525886,-0.318767184306147,-0.716794059199869],[0.063138379147926,4.32579416050102,-3.43096195903524],[1.54786744111238,4.140433133605,-4.57702499196074],[2.5872239917116,-10.2556249865073,-1.38822786761317],[-2.04787610385438,10.7836090452569,3.36274916650789],[-3.0836654645637,6.03398290816361,-1.47694496311529],[-0.288578126452065,9.17037495521188,-7.2715666473315],[2.99134808274611,6.05519341941786,8.46368955534584],[-4.66039702191881,7.96766642519824,-6.47782101079342],[0.292828855632854,9.08587050629955,-7.75184262820177],[1.17529459448543,2.96950145941124,-6.92014839429607],[-0.0238516884150541,-2.66390677898602,-0.978402832791881],[-3.79587119494664,0.49015625925746,4.56547402017234],[3.44143095335798,4.65247947601543,8.43257429344532],[-0.955322868662183,-3.14454188620306,-1.85840770757711],[0.535555589167593,7.33866212737342,-6.29051449523772],[-4.95454384927487,7.11692740115198,9.10665762735161],[-4.07449968004751,-6.00030106074835,-9.15868859599005],[10.4358947760474,-0.766516207214235,0.655274128639286],[-6.05828597338424,6.95593441732832,8.15890147875769],[2.72046593144048,-9.94623083245838,-0.0738321321374816],[0.200633456174725,-5.06756976286302,3.88070174023991],[0.036517051914991,3.17679080357058,-8.55183548787567],[9.45895496350439,-0.37748562398811,-0.543907738948771],[3.34875281528492,-4.47047844357536,-1.214801226277],[0.0161553277139067,4.23922706380065,-3.26664976965203],[3.4515125057951,10.4110306484151,-0.8754234709866],[8.08849455698258,4.08210806280824,-1.09469494049638],[-6.39288087957396,-4.2389962072115,-3.1501127377433],[3.71134453779105,4.5340152643217,8.53138112265218],[0.365014525518417,-6.09855171155393,-6.09050006776117],[0.792222244489922,3.65991359356288,-8.37865373490475],[2.39241711768288,-8.02505893800861,-1.04956307776982],[-4.68168515673132,6.17109248968419,8.75517584579401],[0.433372978463067,-8.49912049238406,1.40370721620027],[-3.73432834869183,0.498862462211623,3.09612751807357],[1.32280922233532,-7.13773820430587,4.51712927566965],[-5.61027360226577,-2.72742729734529,4.60863604586914],[1.27108639897163,-3.68259762600315,-2.72140310126887],[2.86783545150463,11.3408772696121,-1.13457800846267],[9.38600432373964,-3.94763833217865,-4.43033948476825],[-1.27887791686091,2.71295507266148,-2.09913387121255],[-2.33880793802309,10.0167008065183,3.64329671276177],[-1.98896600300382,-3.13893930222477,-0.721406735550661],[0.75073132483227,-2.85645104650483,10.9971990973117],[-7.32409399796392,0.516442277818059,-7.92532292039276],[2.32533824075768,-3.26356201234386,10.6731319934343],[0.708018832203377,-2.34606827748807,12.8038828542302],[-2.96883787207329,4.14130472520203,-0.283270149643599],[0.774948442147227,-3.5333455352082,-1.38351879048078],[-6.25991638921525,-2.98369298443245,-4.87349442323442],[-0.10251118058842,-1.56080061536701,0.920061161145629],[-5.44337447558024,0.106271738574509,-0.434084782668369],[2.2767209285147,10.1057087928233,-1.69808972600112],[0.0195615922191363,-5.79803497399321,2.42878661860659],[1.49830798553733,-6.89183414381955,3.70931687924336],[1.67734081432465,-4.14559799373475,-5.37069797754886],[-0.0303749002794723,-2.39930974432739,11.7554358799126],[0.855298522082528,-0.0249150627428985,3.0122838329839],[-2.65898082182546,10.4833918479506,3.55117573806135],[1.56937879906068,-1.28542802207795,-6.54896516876593],[-0.151428099102333,0.500552054703457,-2.96777710389732],[2.72974607345822,11.5373002922967,-2.9019623210259],[0.514194022293903,-5.75093614802416,3.31900231907187],[0.893327394475696,5.64672029227676,8.13301841688828],[9.59790492223508,2.76791493824457,-0.997119931932086],[-5.99341821429811,6.79748057004125,9.23153579024915],[-5.88466027105296,6.8104033982829,8.51349868746348],[3.45571950453578,6.09535664586719,6.80283895114335],[-4.14680684908406,-5.91221039465393,8.06759886180073],[0.747834450176766,4.21240973500909,-5.99140773879512],[-1.74002825833026,4.73165722599485,0.0041323562478639],[-0.311190916566211,0.962353883501299,-7.62642366582643],[-3.61661230123192,-5.72579159045346,7.60154973065023],[0.252472085041199,-8.80008019265028,1.28696757347989],[2.56307483559787,3.54252086321718,7.88415911217186],[3.33621592128681,-8.84697202683332,-1.33016872725446],[1.01286947619275,-3.45906119185972,11.2942453768584],[0.152372392438897,-3.66728064136972,11.9283495404563],[8.96988475378134,-2.03203832716832,-3.58421556641405],[2.62769402846782,6.66705238020684,7.53244873901412],[2.34957506797992,-4.36610835646731,12.2439770328796],[0.971775945984454,-0.0560077103316829,-7.27368315361498],[-2.10971751310774,5.33154509298171,0.361752728376993],[-5.89729928394815,-2.85195026759537,-5.04390631212746],[2.48131522392314,-5.55396696243198,4.84681544839598],[-6.76717711750624,2.87161882604952,-4.13933780119198],[1.46120919606157,-4.64466604782003,-5.08729898781997],[4.17046932317574,-5.50375957861604,-1.24677088905323],[-6.84223600791199,-5.67624173873061,0.836526684449445],[2.71353760870812,10.1194348320284,-2.07836356025327],[0.0907916125857496,0.632310471900282,3.56711943636362],[-9.44246636535792,0.199452350105721,-5.70150366499584],[0.920512668040171,1.55208193244388,-9.01522216932415],[-4.86494013193678,-1.39250560069643,-4.43061400960216],[2.06720996819543,-5.19635287200251,4.83856070399202],[2.07344164441003,-4.91337772709244,-0.495932420960298],[11.6374702670715,0.523276112338876,-0.667162480731211],[-1.97359884862357,9.03505995331923,3.56865473193963],[-2.2718446483036,6.44494529960113,-0.793170415942787],[3.74665343299635,-2.37815837224259,-6.90552542737071],[-4.34070719628874,4.93261129185709,0.116359037911984],[-4.30818835055666,-5.02132982575652,5.51253932199565],[3.34137005953826,-9.89608242648707,-0.0647831507174439],[1.6407121085123,-9.81721700061721,1.23568133014187],[4.17433175854772,4.67176905242789,2.88936761396184],[0.842967409771976,-8.72208189956472,0.807534526628331],[-5.37778505674742,-1.28264567471159,1.29567885706174],[2.74984387273237,-6.96493571604935,3.56144967311149],[-3.51720702631674,1.19615001007004,3.32674312913794],[1.25215162604507,2.11986706120291,-3.24661480446299],[-3.77445534203622,12.5108981528103,4.42148873281856],[-3.7434218803073,-2.11848626151868,4.43193401321266],[-8.99046519985269,-5.95650075929287,0.602216335321491],[2.45233017482401,3.41988864115588,0.513107727080063],[-8.55926387316269,-0.117888450445818,-5.20014596808282],[2.00285481289056,-8.36878007961612,2.16900472213757],[8.50541822776417,-4.36984602374451,-2.49052926468212],[7.09357633647732,5.06474702817261,-0.310048606158118],[2.33423892227228,-6.48527136717573,-1.19293104971801],[1.81298902304268,6.04652969218413,7.13882886886948],[1.27583376991019,-8.08908319624531,2.79211337030137],[4.37659610809061,-1.51511751273755,-11.5489677213027],[-2.76023730633704,0.518230403084808,-0.95389149401984],[4.12379461635709,2.12178266281454,-9.66545095841666],[-4.81458850536497,-1.1681964383802,-1.26446381744626],[1.18984661329124,0.46860987966919,2.73795757552526],[1.77342609423469,6.34342995929609,6.67257858377376],[-2.84903452571905,-4.51987965134178,-8.55407902636948],[-4.07065151015972,1.24968048644124,5.54826922999575],[1.40867867106796,-8.47764621858619,1.27381226707281],[-6.61717830990548,-7.17018493435117,1.57956264359154],[8.93785155168378,-2.13550139777947,-3.03349754534207],[-6.4946502409986,8.90949673453685,-4.75289015386599],[4.80753079913422,-3.03756735171171,-3.93188506722643],[-2.74694652061185,-2.19152836068159,-4.49203302878703],[-6.0771962205108,-4.23031138972805,-4.22902404382816],[0.2125320288615,-3.65270576208038,11.9269487483326],[1.34955918415989,-6.62057008114702,3.50291323189501],[0.569919497059286,-3.46101968884182,12.868465503442],[-3.90815376434116,-5.91609807975077,-1.42096478942886],[1.20136243201616,-3.21005577378259,12.9609586802032],[9.88267254952063,1.18589449225498,-0.104757525531826],[1.41224334005211,-2.85023277994756,-7.95075678025522],[-4.05249231241583,1.67831645274123,2.58572176116765],[-3.64891477758472,-5.81248095492993,-1.35928260543933],[-0.0771731827889407,-3.08010212999829,-1.10197654685647],[-5.98647801931644,7.39885465629533,8.16171305830108],[1.81479081922446,-7.58809846119849,2.09364260398007],[-7.98509094474884,-5.57714596699577,1.69675986533074],[-5.03742035177283,0.427928967450276,4.51286087403004],[-2.34430125413234,4.43331700836143,-7.03809087959742],[0.672709638457909,-3.16967196501579,9.95449020609224],[10.6647679170316,3.97586671270365,-1.12741641173843],[7.17180954118013,-2.13099239634475,-10.3398108739945],[3.84730687488031,3.36121329874608,1.04380573949606],[-6.39928392784441,8.00298523998117,8.17603537829109],[-2.52083819450746,5.81181334230273,-2.77351420292961],[1.50442728513965,-3.1889942688438,13.4068148499218],[-3.35668821544292,-3.86262816800924,-8.8668475694737],[11.7692491612868,0.356130338952121,-0.50132712398533],[-1.15619355287285,3.56608608740945,-2.56898963187847],[8.7841695306684,3.6967895316914,-2.25433048572513],[-4.47442977106082,-5.67881723611727,-9.36178525299564],[-8.53725435597101,-0.485605490354816,-4.55282294482921],[-0.244253666453867,-7.17721971618157,-6.01954474800203],[-4.93723228310272,-6.8465892926668,-10.0514200129317],[0.217564438895587,3.48692480401511,-3.28433231284152],[-2.25540018694817,-3.52724555872724,-1.15542998725354],[-4.10008273896861,1.66037936697717,3.15985103831471],[-6.94619467580282,2.31588594391902,-5.68881471130565],[1.89520197736652,-9.76535752462082,1.80215373378677],[2.78062015371216,-3.9155021305731,11.0731734123899],[-0.0797248196714647,1.09885389194863,-7.00573884378989],[-5.78743555078801,-3.49224727276772,4.67747618410734],[2.41775220042325,-2.03736615807094,-6.46256929338015],[-2.61857645600737,0.560251956148921,-1.09683140035043],[3.5696360300996,10.993349832121,-1.01136531947124],[-3.39718388476613,0.459703552292796,5.07192368751988],[-5.12724025109335,-1.41742073968477,1.92734868818923],[7.49647282091095,-2.12930416918499,-10.4612307972269],[4.87876177849026,2.28459518569897,-8.51812823285208],[-5.44689615838953,0.959060455051394,4.40499363864317],[-5.33084144832716,8.96315931769516,-7.18016641399012],[-4.23007955792248,0.61884112338967,2.42773446229544],[-7.15321357171933,-6.25280866899837,0.310173370675232],[2.51864473332357,-3.81145497856357,11.6724741049556],[-5.30303767269789,-1.03798832373025,0.483510814274293],[-5.68845039850408,6.83920996216564,8.6318555380797],[-5.50451436985934,-3.849532202347,-1.95256968780345],[3.31158578949871,0.934634853337938,-8.54116355216517],[2.96095628165212,6.21074734875256,6.88175702921694],[1.62391036495341,10.5064064379376,-2.10945494144223],[-5.86424481770576,8.02509755052075,7.67596146354809],[-2.11328766570774,0.826437298561477,-0.866231969327677],[9.76672237551117,3.25363544857091,-1.3885398397205],[1.32818031737085,2.16762713533809,-4.55641589455162],[1.35184769407013,0.719032809969303,3.99896843425505],[-7.26100487874711,-5.29234134951725,7.25286383844869],[0.151448687333805,9.37754050833919,-7.65179235342718],[2.74600047384621,6.30395710396749,7.57988243678792],[3.65345116002663,-5.92248067019933,-5.08763427294431],[-3.90536712344346,5.03402805658432,-2.71244465606597],[3.68971169999144,-9.14513849887477,-1.24841651606529],[0.614772689172807,-0.522152741226854,-12.847081737111],[1.71391925794384,6.10409252132089,-11.8403583277841],[0.112945602716721,-8.25081907267615,0.388046326927976],[2.82874645404354,-9.63540251480278,-0.536912194106031],[1.8115630408711,-5.49400108005903,3.16818176386499],[-4.45922057286797,-6.92039704400559,-1.85203036000235],[8.08964647983533,5.87331268288892,2.4333285300752],[2.92033640288806,-3.94784160447966,10.0911821712829],[-4.26067615591328,-6.07396899188659,7.11147852775995],[-3.9417254779326,5.86058830024363,-1.59733110421049],[1.36788358386729,3.12458660322493,-3.69816471618775],[4.33394934193285,2.33364963402009,-10.0784434671666],[1.99278322345418,-3.43527165985718,10.9436141749292],[-0.180597219691149,-0.902137075092531,-11.0326972831096],[2.44438885447824,-4.73985435615168,-0.523734144769005],[-2.15507815283101,-4.75951148801343,-2.12526391557826],[-5.8556980334299,6.93840990377705,8.1168374790262],[0.642911598194184,0.267571619326914,3.16067990194944],[3.62822146223947,-6.77534890956173,-0.934255178226934],[2.58021808969281,5.94700567165898,-11.4110373892278],[-2.95859755438273,0.749437571190297,2.36290849669381],[1.48840027333901,4.04851222767452,-6.06982920680549],[-4.6023085101336,9.91503088149251,-4.76218216602259],[0.561999058003587,-4.65144409029704,-5.85369956324211],[2.02199942859996,-4.1631281160251,12.17086257823],[1.68684677051906,-4.62924923201303,1.86945926076541],[0.633957228461544,-6.03649667226136,11.2872166941626],[0.636948520702501,-9.62533189807392,1.55691616127987],[2.36988795038039,3.85932043929086,-6.32857057874991],[1.38641391339077,-9.328757080786,1.24702017427024],[-2.90910234380394,6.13504955987708,-0.138155177195839],[9.98000255687396,3.42483510522196,-0.32297485153173],[1.52542693026308,-3.51455689577382,13.2500517837359],[-6.14163852193985,2.46395646264784,-5.86914190798614],[-6.84218605830005,2.83483144180791,-5.10646964210414],[4.28099131540824,4.81269207362694,3.11121279348666],[-3.57235867718008,5.88531057504464,0.499765896744383],[7.55142753934668,5.50539121330089,1.4871228957981],[2.88788018194218,6.00663228772575,7.26568706496162],[0.0652385407202067,-1.66493921567364,-11.3170670032597],[-5.17436066377155,1.49805732758514,3.94383633980281],[-4.77040102698818,-1.50151461587013,3.42232543733198],[-5.56454872515577,6.71876316268278,8.91611703841903],[3.65237992903537,0.480488798955882,-8.63304087067881],[1.15496815279801,0.679443250826979,-0.716594586871258],[-4.81286996636841,1.20618355797886,2.913298575666],[-0.951467853348579,-2.15882467911064,1.01538925259739],[2.80447767518545,5.98975395529191,7.94702973288049],[-0.0546931532803379,-2.93281675523359,-1.12252257988426],[1.12054188171463,-8.74357750681018,2.81361644906527],[1.96564932786667,-7.64955661340122,4.48009701984179],[-6.88254485982745,8.49330593277109,-3.88025796581481],[-2.67104284564957,9.07120441151666,-5.61591163807075],[-3.94828225396852,1.93442979602255,2.71115618895989],[1.53987180273611,-5.57597134736741,11.0561309352839],[-1.4612735521792,-2.58970750326398,9.3524941659666],[-5.75769651255897,6.95108897874571,8.63025015349677],[1.56916717055358,-7.04460200486276,4.00640500009567],[3.50237364498273,-6.99052138219069,-1.93151002880702],[2.78716234515663,6.13710895236322,7.73959023557912],[-0.922812542407707,-7.5653575249644,-0.17929496267353],[1.05976968273019,-4.03931258051904,-2.40662719426908],[-5.29042112671357,-2.99379661991101,-4.9465417340237],[0.0340521116630979,-3.04612450415733,11.0995673703924],[4.14686684927286,5.3452837881822,8.78618954222668],[-2.70174459086263,5.67772124519195,-2.93261376615507],[-0.415853182807746,-5.31103462019678,1.80322415996405],[-4.74168976587503,1.89908902806972,3.52326193116935],[2.25399500480244,-2.34725198694882,-7.93044811623359],[-4.7515375267632,-6.67818466335449,-9.95237381482154],[-4.35155112978997,5.68196928276789,-0.0585840620189621],[-6.96748457891216,-0.668186852417161,-4.42734885260196],[-4.68108398326998,-6.43031095653662,-2.47136588918171],[3.26185212624616,4.39088975514618,8.17099738782616],[-6.14869799180287,-4.00308677631115,-3.41241042784028],[4.42214979858373,-1.53836246836846,-11.517457281013],[1.05151527772623,2.10791109922314,-2.7948476574308],[1.27255306372587,-3.03871300344307,12.4262768476653],[-3.97232156507307,0.931802784960283,2.9813401723391],[0.581284682377104,3.52615692990931,-4.21807548843808],[-9.52686196312865,-0.954243533396925,-4.44022697870892],[2.60255235949694,-10.482510065618,-0.757651874758187],[1.35162074684048,4.12176141565797,-5.87853427991394],[0.843794710042209,-8.80530822867946,1.8813679942391],[-5.79396452038416,-3.5317751716676,-4.98978866705711],[0.289895972181587,-4.69600934154488,2.64916419931373],[1.7484876299906,-2.02181151420926,-5.54695000531005],[1.46132007911313,-6.70999880132742,4.94680052999822],[-4.63973551341882,-0.0240807945929991,0.658784880492433],[-0.558046663719212,-7.99100278694808,0.408984027703239],[-5.09685699795287,0.69812150157445,2.47864133105694],[4.43961725966118,-5.09060050057481,-1.48636244528864],[3.62158991390414,5.30967729042831,7.08833938701911],[-3.60437390763653,12.6021965865682,4.64356429787018],[2.13506456593442,5.3335012365423,7.93985342336036],[-0.931424641189386,0.292041474518931,-6.92346233149628],[-3.62132144231192,-2.29283530324829,4.08273677927127],[-0.547458467523449,6.67637894523664,-8.43838132577546],[3.28550877748578,5.93255322604185,6.9564052591716],[-4.45192984172019,1.60399633430773,-4.51166660306206],[-6.15558600476608,-2.82100366359434,-4.54005501062208],[-5.34236814274708,3.50137117468509,-6.5606437831431],[0.233480566086996,-3.29645681403527,10.5826402433638],[1.25664504548606,-4.36975281834048,-2.47468957285418],[1.31253955772591,-6.22874503270429,4.61831262571991],[3.66475656382242,-7.38477527069125,-1.83139992468869],[-0.553320083648482,0.00726973419689236,3.34625640869199],[3.98721388948722,4.3828352872435,9.19948651071317],[-4.88876458060596,-6.65477037536397,-10.2011268533732],[1.28581071691084,3.17569911293231,-5.68189078171783],[4.9345274833974,-1.16460242622739,-2.71391390208151],[-4.39290355756905,1.72299323247792,3.43489314630199],[0.281113908804754,-2.84818970940584,12.586991482948],[3.53292326670175,10.2595565740882,-1.31419107391325],[1.22607621776018,-9.43323717886641,1.80273279795024],[0.563296981993084,5.27655420862382,8.08347793250526],[3.19071308327079,11.5986153030654,-1.28040317812427],[-6.71915328127165,-5.99391614564184,-0.535304440717353],[7.86573645925313,3.42946846573215,-2.14209347453369],[3.97443764385189,-3.32245141111682,-4.23270657660067],[7.94891863261309,-2.75598323267913,-4.66724274106222],[-4.13098042173158,-2.90341798856904,-2.60761272970597],[-3.99320294018866,6.73842612524418,-0.68352644490277],[1.19278837251993,-6.80823499957146,0.441867439748226],[2.4800010580826,-10.0070739452191,0.84026633422297],[2.25282137116721,-3.99528181231374,10.5754996587039],[1.53846652865241,-5.04498199795487,-1.27072946059525],[-0.118779645243851,1.00116846897675,-5.73429403458625],[2.81401857926571,-3.28722055641478,-10.8379060132071],[-2.26418361051348,-3.54616952402434,-9.58238396214352],[1.78498854909135,12.374096447185,-2.38382283252599],[2.15059260239607,6.17678348127094,6.39760928358786],[0.894123730898021,-6.00555991651815,11.1313185013457],[1.09331776347852,-8.37343763905665,0.528678141895114],[-3.11606080823818,-3.56987683292144,-1.2903854598717],[1.23828121104806,3.57083597406853,-3.24813416796592],[2.08262153234467,10.4405044695921,-3.51892880685676],[-3.56437816910896,4.78164158416989,-5.3147916617804],[-8.12498491637493,-0.887979442375778,-4.38280364961192],[1.26994829800842,-5.25438441264213,10.9165269368177],[-5.22345631524137,-5.9900124717195,-1.27692273674449],[7.21591459610823,-2.79309963748604,-4.29388595370104],[1.37460763177686,0.156743805524091,4.52773047437543],[-2.97222433756049,5.29999835803702,-3.15514633676128],[-7.3518501453834,-5.88977708986621,7.15182796485525],[2.18707030006442,-7.60212008372785,-10.8737921677537],[-7.69676121710007,-6.88501761185365,1.40598896871072],[-2.83050713143726,0.185197728422206,-0.306806065139072],[-2.13291867154033,0.0638014368436935,-4.68668163523709],[-8.62594600430033,-5.75504522201243,0.699103253519718],[7.73384294085506,2.93611052938196,-1.72724647520356],[4.02609768043516,4.02415904123952,2.67390526327095],[-2.26874183543455,-0.411779343346941,-3.14435743113962],[8.38683026058323,-4.69224424894565,-2.00665687686388],[-1.53314455023814,9.32605091007317,2.62521885721771],[1.25918423749668,-0.0358107224332546,3.92007000280436],[-2.62232789862977,-0.877251516844679,-3.46580601673343],[-6.04713250852392,-3.64725815081479,4.68516191805202],[-6.02673412707781,-4.49697431687209,-4.28617924413719],[3.76004177657032,11.719126416979,-2.08724650703653],[3.80124347970113,10.7270451992675,-1.40822346813201],[7.34087201238509,-1.91567378158503,-10.4835541257771],[-4.70130317809327,0.629088816195687,2.41416801295415],[-4.77267373864047,-6.2309783072519,-9.88944362581789],[1.53490405513584,1.23552938315636,-4.88484344968027],[2.25726680896272,-6.38768658494666,3.89123121215071],[1.62684168280672,6.15282016235638,8.71150188383371],[1.96093174411167,0.496773905225695,-6.30737300784746],[-2.53943524004606,4.95259782030546,-7.90628157415111],[-5.43125573876522,-2.8775345913605,-4.79999706011836],[1.25941092694617,-8.74138708468747,1.11345381594151],[1.96033604759386,2.42308112807304,0.706876494391287],[-0.518989952340967,6.32228847336688,8.99014536410281],[-5.3380734668709,-0.103014118805138,0.0774101779731066],[2.32420226868136,-7.23709094556518,0.900262824169965],[-3.40565132556994,-1.73648416122578,3.85733999006189],[1.96064545073041,-4.52309832674306,0.0804819649440215],[-5.58992820496084,-4.10652691261357,-2.15093634912217],[-4.55928449134009,0.497629051288716,4.87518584471075],[-4.90967865229296,-2.74374348057944,-4.06302952508259],[12.4092318860585,0.574307732291103,0.275239577274753],[3.74111731463109,3.54648145941417,1.49327285941096],[2.65922260958214,5.75642918939854,6.94585835417416],[-0.885304493410148,-2.83026655838062,-1.99353181339857],[3.35894603219755,5.92583516788098,6.83107615290111],[-3.74333866826602,1.76489099561023,3.04969655141913],[-6.86435039581353,2.59274360187871,-4.8280272141],[-3.74859029494063,-5.28906417192638,-1.51619476831605],[-4.42942439012263,0.854765941093756,3.57458466616964],[3.31257871612453,-4.31123626576562,11.4853883855366],[-4.68969340052709,0.816409311693183,5.45137610247406],[1.98548170055685,5.84820398978269,6.51928966729974],[1.00093870432967,4.25637514207205,-4.01204352529863],[2.35173991281735,-9.62118959797031,-0.0654494678211088],[-0.589450726991537,3.36747238632302,-2.46489428775339],[4.08849494053888,4.08291229043569,2.80898756978009],[4.27662083263212,5.48827488962141,2.78317958986112],[-0.408215862137062,-0.700763304964071,-13.8315035172354],[2.45304362020018,4.09318542587779,7.8437987808275],[-3.09061531913183,-5.12549580746994,-0.929524379359532],[2.28806732250429,-2.7693209259552,10.9739549842342],[-2.91602549368995,6.1947424621276,-1.28830083615031],[2.86112451925859,-10.1765846155774,0.675670426622771],[10.6816901630127,3.71636259492013,-1.6811039947077],[2.12356881372728,4.19839159145075,-4.65822541877067],[-0.178232981974273,-0.742357211710133,0.442104723089442],[-0.982850896280906,-3.11810952802539,1.80725168369504],[-7.05138081739823,-6.24944867671437,-0.652493226194631],[-0.44781216836516,1.05720602257903,-2.17392135833329],[-6.19571444762125,-2.94859776138294,-5.08701301246605],[3.77533200583953,11.5913705584675,-2.00266827895209],[1.84298692193778,0.0363253315896205,3.69559004210599],[-5.43155772011797,1.53673687101347,3.19557914343342],[3.86259399032463,-5.77896721721837,-0.958413083011037],[-2.69575999286007,2.26879359154849,-5.20451808662516],[2.77935411533938,-1.48082524999528,-4.39253527487725],[-1.64634286365198,-5.08063240953811,-1.95826233774715],[1.15214407432355,-5.856319018007,11.2590762293615],[-1.74723037151624,-4.71352142120003,-1.86964504394342],[-4.99252441957053,-6.62443414350452,-9.63429822835987],[-5.3891306308456,-6.57771616960147,-1.60967235814496],[0.55752346087846,-5.64949691338989,11.1468930595845],[-6.83706572653582,3.11767075146352,-4.29852522124189],[-4.66824110386137,3.63880768053421,-6.90768275139031],[-7.45495856280785,-6.59947420637906,0.974741743817665],[0.857852118542296,-5.88822022100267,-5.21827317372178],[-4.48931915520753,8.66225263326942,-7.61885068367033],[-9.62639198616866,-1.6753579194125,-3.92595407491467],[8.55574662426,4.41086664186668,-2.14912643493156],[9.03465237222406,5.85243720750195,-1.06134888843668],[2.56756921030101,10.8888018680123,-2.08151269638668],[11.3697931152117,2.81967317261298,-1.62030777824594],[-4.47346221236094,-0.433256678729425,2.92996499771641],[4.01709665966565,4.44944519150199,8.20929144062394],[5.25953724861951,1.32939363088029,5.39054756934143],[3.36400434953236,6.43581623725752,7.52549053553283],[-4.02160127680002,2.09125578712432,5.53445214099278],[-3.32474799118806,-1.74338412982621,4.17277088282001],[-5.38397693367451,-6.76312009699671,-10.230689059815],[-4.84468639306002,-6.06929698481935,-2.39899369865377],[2.12941317884459,5.81828405997076,8.30542744199171],[2.17489531577766,6.22086411261784,6.49850847443093],[1.45457642898171,0.215573850360158,3.0895925245796],[-4.24677479049485,-6.10230031617944,7.74769927106669],[0.724470302541018,-5.94421976099491,3.09739048219508],[1.25685309286631,-0.930194610176954,-6.83450872345543],[-3.76498474948978,5.89629425223465,-1.24903927878681],[9.28804136032227,0.852425062219911,-1.10063365723878],[0.668014879383685,7.21217034696398,-6.07398629307876],[-0.367928851196266,1.17027592145438,-6.47086578979646],[-3.92635529709106,0.503530078298335,3.25795223333864],[0.0875870824330292,-1.71545362464251,1.11178051302875],[-4.91578884722899,-0.148606724809248,3.04551814905621],[1.6366058048908,-9.07972594227221,-0.22477105035321],[1.73149459205495,4.14509303178512,-5.63770519982132],[2.68055726695446,-9.58410258553319,1.96014517505794],[0.96077615577787,0.973956996050269,-3.99540642012343],[-6.54726574614282,7.51265679581766,8.36147279952692],[0.0437144204259637,-7.51485418473604,-0.608341792969328],[1.29656328522561,-6.65147115186238,3.77578569643698],[1.89460800346549,4.19417399953948,-5.68343183727564],[-2.59576360136489,6.44120844362673,-0.985976994208771],[2.40085609250485,6.42050986074613,9.40430545393964],[-2.97028904254064,-3.62840087072212,-1.3897326278069],[3.59441317230769,5.23198470219054,8.23840488879308],[2.82723553862964,-9.97806809944271,-0.0363079483101805],[-4.1188701046185,-6.44779503807321,-1.97063274064869],[-3.79745813469806,-0.0641998722187243,2.12660540586987],[2.50741253932005,-3.49465166902445,-11.1253556066849],[-3.45623960164616,6.78251770094137,-1.12100226876086],[-6.34395606331003,-2.89143785087541,-5.05837394410703],[-3.42254803073379,5.61726374848828,-2.61555021392913],[-1.94474399350935,8.82534574284238,3.20894124503723],[1.90068100257878,-3.73078600237328,-4.25436188507093],[-4.97227930677969,6.3388513681333,8.68074588439693],[2.24007183737695,6.40612750613167,7.69865559230589],[-6.1880697600269,-3.08848156148649,-5.08560099950621],[3.02238966168982,-2.25112462746505,-6.48425137710949],[-2.7646628109542,2.27184936771804,-5.47794274949836],[-2.77127324829217,-1.42381323460845,-4.18938982888031],[-3.61968691374683,-6.28008799788993,-2.3389337707351],[-4.63404420103953,-6.43605074317207,7.85377635901495],[3.50779990615124,-8.17144285629252,-0.949205357717384],[1.23696459043856,1.46684772653743,-9.549805811685],[-1.94378546030682,3.28905433891976,-2.65824325362007],[0.584399318726615,-3.06948252060304,12.4455097803344],[-9.5447964827843,0.0824390981382547,-5.56434403143461],[-1.59873821181587,-4.15431397547291,-0.513915917975621],[-0.407476614479762,-6.08925445976335,-1.4343176472171],[1.41729054105762,6.08478688429543,7.3708221436308],[-0.0537621742364088,3.11461160071267,-8.30934057892052],[10.4298891294984,1.22919255405195,-0.91063636903137],[0.190027713558658,-5.62882724160354,1.65407067524575],[-6.03761487934069,-3.34712946247257,-4.84825344973233],[-1.81084871432595,4.05163311523126,-2.18572281484711],[-5.03142293086143,0.755663287310239,4.80776242009133],[-4.02125976607568,2.30138692987406,3.77779016557822],[2.7560753541149,4.55883016474728,8.50443068979776],[-3.69594904386273,3.57584414890049,6.02893668014686],[0.795361819722752,0.78613714992621,-0.740866285845548],[0.610344343640016,-6.16081566609581,1.23641588856492],[3.14493654960084,10.8882839211106,-0.806375977186052],[-3.58049881791413,-2.77274632992949,4.71806936004922],[1.69925995051042,11.9940512315221,-1.83218102927225],[-1.33698918020181,-8.12090825902187,-5.65793510335545],[-4.37966550666876,-6.35841935183207,-1.72109111791359],[-5.70618666268386,-4.59548753944689,-2.66215540636194],[-2.37834610231461,-3.66437879381589,-0.759587554017623],[-4.65728506555383,0.74552108689473,2.2867167685319],[1.38488670772467,-2.83224214498162,-7.89313686555109],[2.76969045238849,-1.76445009262803,-4.425859500042],[3.41140089424653,6.41927672356911,9.10018671756337],[-0.516739566147553,1.480727862369,-4.49636312960599],[8.57794295847139,6.95233662398406,1.05804913726144],[1.17454507219376,-3.7959099918806,9.78957996513812],[-3.00528785904826,-1.01139968565767,2.2199285883245],[1.99242369635183,-5.72518898522755,1.50547266029436],[2.25322836762384,0.233415987489067,4.15565968716404],[2.19125341997723,-2.76628925360079,-7.32260032702261],[1.20674362310158,-5.25137062840012,-4.84646410125454],[2.08973454806992,-3.258224862001,10.8138717493683],[5.13951973142967,1.44648300159724,6.02688805559011],[-5.73257370471227,9.0294732279217,-3.68048235814604],[-5.35454376105203,-0.737601246026444,0.42905921367667],[0.0656372454953525,-8.87768033002879,1.3554284773996],[-0.463882736557405,-0.511300486518963,-8.24457606626589],[-2.11200869150849,-4.92084238296165,-2.26366962941763],[-1.20043194647789,1.77443678282044,2.08025214534655],[1.54446083552607,-5.35350704665832,4.48815821278874],[0.364808644453384,1.71128264897989,-6.72781903065596],[9.38218613487396,2.40723329022619,-2.96482855661642],[1.44655266057314,1.32203148815706,-4.71590857992961],[3.13101895357601,-3.95276831503788,11.6170068432791],[-0.940690670902221,0.848786937529786,-7.44192030479256],[-2.07741893089881,-0.873798199205883,-1.41300836623269],[8.61327276833716,7.04969699972199,1.50670209175754],[0.89676039434192,-2.69025451562544,12.4114896288479],[-2.52159236840327,-2.78528583757377,-6.28198533093527],[-5.46474558850519,-4.6208418211102,-2.74147133931153],[3.62518971078746,3.94801294646608,8.95996960048656],[9.16206434060987,2.32852752484993,-2.45137684111377],[-5.25761849287289,1.58403806498843,5.36864867149079],[2.90876596251882,-6.52404982495044,-0.0405218730926721],[0.196446679578854,-2.93567969287846,11.8112533693792],[1.37227102972799,6.35866616164838,-11.33169312904],[-4.91701936448585,-5.97216105528929,-10.1039259756662],[1.53945322388057,-3.96088854122802,12.0117153323167],[1.00863397031597,-6.09721704741348,2.90218651976001],[-4.87261254151373,8.64503594182055,-7.50916275284312],[-4.49859646121808,1.66708410457116,5.18278095804389],[0.585120796156691,-2.92044046815274,13.1160060362747],[-4.32255589404684,-0.419671822790956,4.22735397454631],[2.37479364565449,-8.12434636328212,2.58792207012651],[6.84919177958121,-1.03393514964174,-10.4200711666465],[7.43855006532937,-2.94459739441647,-4.14287575472882],[1.31938984887467,-5.8970114602642,4.60898456877977],[-3.4598156867482,-1.5200081573104,3.80463363093299],[-5.04157601489918,7.24922997940506,9.11363096271857],[-8.05605903409004,-0.789619546145432,-4.54897662629923],[-3.68392885613818,6.94377626979872,-0.569167145115984],[10.7911296942163,2.65278694853256,-1.12841153315321],[1.69828660684447,11.9838043760812,-2.04769188728882],[-8.7169173546641,-0.859330136730913,-5.04284491040067],[2.44688262936958,6.34427851703339,7.070902053154],[-2.36987713169605,5.12200238092101,-3.10506938107039],[2.96234490436297,10.183775031317,-2.16706410941569],[-4.43004023967706,1.35589399159262,3.62343719165256],[0.145281438145256,0.740082798891915,4.4158510408421],[-4.55279965642428,5.29950703750171,-0.0964551222495695],[-9.3949564892841,-1.87660589807871,-4.15973099650147],[3.42692156535092,-9.54434979440065,0.499184911213743],[1.46935016821384,3.40367778341137,-4.06721864583779],[9.5901324389265,-0.243207220021408,-0.64904549984363],[3.96990799512893,4.05881607959169,8.5360552494831],[0.534331381519821,-3.66432188996135,-5.59199536204527],[4.00869529147607,-8.78449635887802,-0.110586543563927],[-3.73381981748888,-3.59423960093782,-10.7257148334958],[-0.147701918544067,-7.27821597792264,-6.23864367287587],[1.78462747777275,4.96574226828908,8.08082297565108],[3.29655761647021,0.287679666533855,-11.4952123507783],[-3.71540896691036,-6.40580343220311,-1.85620088944898],[-2.29911274963057,-1.15879229549901,0.506767582264283],[0.850103072592156,0.0398071147645855,-2.37859973900758],[3.70875396507277,-6.27041488307845,-1.5170807236822],[4.74649617690309,-3.06323257574111,-4.20473320910765],[3.87696169861769,-5.22666996446484,-5.16574062775535],[1.87495279505149,-8.45095340833645,1.21556726573982],[2.76285791259874,6.28085207011815,8.6040023512101],[-3.9218168929263,-2.18171116309171,4.02084548155687],[1.14986943162486,-6.04803298846146,4.89309686618564],[-4.81291730070022,-0.0899881457587379,0.0597967250094287],[1.63162136530053,-9.15485607551146,1.37420927138007],[0.853951467832065,-4.7640681818809,-5.48591863604411],[1.15916329394343,3.51301553928326,-6.84464253668048],[-4.43785476095959,-1.74203461776837,-4.4575375670004],[-5.8098888823517,0.975497576455033,4.53916827814612],[1.22550350814623,-8.33996422722766,2.96477436301437],[9.20685390467104,-3.68978341532452,-5.3954069840938],[1.56646810547456,-8.2657477432641,0.54485897672107],[8.25988174271015,-3.78835296093946,-3.57427364241264],[-0.0644623847098148,-3.48606575383095,-10.8846661592708],[-9.42160830739554,-0.897850649327128,-3.85138657943748],[-3.92942335727217,6.43164603858992,-0.0814738557141949],[-0.327408836068638,-8.08659009768558,1.16984583343655],[3.92975989383987,5.29361041924412,2.08689222328051],[-4.95342438600697,9.00682952081323,-6.98246240848751],[3.08275627858432,-4.58799710066827,10.5976552444521],[10.6392817620963,3.27048469656096,-2.07800262067225],[-2.42498049649181,6.99087459026035,-0.577153561598802],[1.90076892013648,-8.60669980697444,1.8147644579791],[3.65126411298083,11.3468987120759,-1.35901270633165],[-2.10838214048148,-0.0146440105024529,-5.05872771112915],[2.70734148062201,-10.1997534524013,0.516479379736579],[2.11175465127021,11.2943164715431,-2.09211582091503],[1.5113588280367,-1.99156041669111,-5.41283131587524],[-2.65647412065416,-0.580089133114592,-0.692490128299039],[-0.770753875095304,-1.67596970119726,-2.31829132893148],[1.57772594863079,2.76656175492773,-3.63573752608178],[-6.71537261566296,1.76461084262038,-9.05538793739135],[1.15130506391455,-2.6820670371433,-7.86798853856708],[-5.51160643336282,-0.823512605414053,0.682152174360587],[2.87209191263442,2.77330989419986,2.81221232637764],[-5.2596418442351,-5.77645577714762,-2.50127584033685],[0.259401773986676,-2.83112538928519,13.054433973679],[-6.33879219441744,7.17973103843412,8.33849663316043],[-1.76109755084138,-6.28045654596655,-1.78764494999997],[-3.02246087802657,9.61574197558382,-6.25230928352454],[2.18648373782651,-6.20750359290931,4.59241032034878],[-4.30730343962053,0.257963043938102,2.86779283524206],[1.56522029115753,6.64717910078206,7.52711841392538],[2.26648196436904,-2.93737376710924,-7.70002595342176],[-3.7995734016716,-2.01069616869552,3.92676173398493],[3.7358415383872,-8.21841775919616,-1.89464180088336],[-7.1721427564524,-5.15709968720843,7.42533076291112],[-3.1768025280751,10.4198203134064,-6.46452634907973],[3.34445602267477,-6.84096664805567,-1.12901024577661],[1.65797458914668,-5.42344444065792,10.7289872520756],[-4.13699825416575,2.49351744800597,5.45899613944903],[-4.0716741340952,1.33875532231891,2.14246836420213],[-3.60584078023982,6.04039868620563,-0.00954473123511906],[-3.19930890155515,7.08359912317647,-0.505265174970217],[1.97640758053888,6.39427758588882,6.49046549013506],[-5.02138398538247,-1.22895854620465,-1.4567765286639],[9.14480809055203,-4.03795327956374,-5.23399668577861],[11.3552776862246,2.93953956172614,-1.60084956078664],[-1.00368219717545,0.503850308220671,-7.15902972501065],[4.10992277939178,10.5938777018665,-1.20426203832693],[-5.17315653783872,1.76155064918027,3.18132796000422],[3.70955598338475,11.6614931264679,-2.52193171758522],[3.17887285423025,6.56128807744902,8.11346292785218],[2.58877269145656,5.89093152218087,7.10880798263101],[0.204296861371069,8.45501729891429,-7.77354196826875],[-2.12315608629011,-2.66345665328403,-0.54110527844637],[-0.103786640026267,-1.513905205145,-13.5003766974618],[1.25955823505103,-9.99435437334103,0.487484649657411],[7.19046333785006,-2.7671037202036,-4.29245805836384],[1.40128137930551,4.73413243951638,8.84963802006627],[1.941664215662,-1.46591244305805,-6.74710714226346],[-7.45662117509434,-0.815645335557077,-4.15921155529587],[1.17027169551158,2.69829157745216,-3.39530927928616],[-2.40979695415306,-2.56905480556076,9.38203512647824],[1.48269983818951,-4.24881313721508,-5.15093081438331],[3.68911786576551,6.00688827930228,7.45293443582134],[-0.537519002418421,2.90927375636706,-7.51170902435276],[-3.14761386721346,-4.51583140307496,-1.22107067081745],[3.61537667753736,-7.36426701179562,-0.50269550098469],[-7.86699020830277,-6.27505985917301,0.690520525513428],[2.63726729542004,6.45994620924177,-12.0237255161955],[-3.00064877397706,-0.117309646176881,0.113693611005041],[3.52075598597387,-0.35352992174102,-2.86187188360285],[-2.24369988982012,4.49534663562813,0.811899407789567],[3.52078695984102,-6.79388246840845,-0.946413290508674],[4.23249414983819,5.94882818238609,2.50513611176084],[-7.28262846115548,-7.02079814054848,1.34971041649664],[-0.374674824799045,4.03387023538005,-3.23767254252622],[-3.64150052332646,-5.54275072469097,-10.2592140647763],[2.09904056951514,-5.27420185024295,2.2737922506606],[2.49566018082089,-3.04817430564298,10.8408246320083],[0.678103014143799,3.54181366206488,-8.4677989023991],[-2.47222074626138,0.150983819928301,-0.592276761503414],[4.7573977670941,5.47422248640728,8.65877456661745],[-3.13519097341211,-3.70522173614808,-1.16852857703462],[-4.37678173475361,0.0619016322141643,-1.48980041057363],[-4.25331662348054,1.17414885280505,3.87911187299552],[4.2561515388951,5.80261939384234,8.98635547258088],[-1.38859306209261,3.35143444791661,-2.32363223113031],[-0.114221988833191,-1.26368111848765,-13.541080415625],[3.45101495538406,-8.04258940917525,-0.971885233711624],[-3.69727759242212,-1.44826584452424,1.88102013576311],[11.0550374130001,4.18026765339662,-2.29055898361616],[2.34599573561675,3.29610331957596,7.75485831416009],[-2.69601483956514,5.00135985197173,0.786322514150601],[-3.75353024592613,-0.304710855953382,3.48996430308464],[0.35188910235802,-2.88087630066264,12.0050579294868],[-2.11298595756175,-0.927161601614587,1.22378715976275],[1.35442795584847,-5.29287871226616,4.55474986048724],[-0.451016973155415,0.461083300583513,4.37513305575054],[2.4826039376512,6.1862119288107,6.29158020758494],[-0.663019895154945,-3.80411758153255,1.90975618762083],[-6.00443909241865,-5.37537035664257,7.77873046729321],[-3.03065383009251,5.20701273176176,-2.75491595158164],[8.83065764598084,0.944575666487165,-1.75829840132496],[-4.32749775770159,9.57070844425453,-4.51602514042174],[-3.80391702844728,4.38694425502659,0.65954196238739],[-3.2164290707935,-4.38630116391122,-0.920587070654619],[1.38732607818647,6.61764192509653,7.5203150369144],[-4.29252676970813,1.54224312901148,2.83907037414849],[-0.425358745839021,4.39171552333574,-3.3006910562777],[3.31808669747425,-5.21388595077746,-1.0839257838956],[-6.22320604271074,-3.24243048558411,4.79343617835105],[1.60819917932854,0.117549469547909,3.23912405787885],[0.477815262594853,-5.53258291877313,3.00458518657458],[1.28348523411333,3.23493471111836,-4.04150725351001],[1.16214120424613,-8.94924676067465,2.6930387358777],[-5.11965076959775,-0.370807926332543,-1.47818225733845],[2.90731376054238,5.04169896504644,7.90094312229271],[-2.78140061302468,2.42533821683012,-7.05310364871234],[4.68638618361664,-2.15589053357079,-3.22435193924114],[2.85471633791987,-2.64284935278537,-6.91995398365185],[-3.33803864777115,-0.136035678736117,2.93554151773535],[7.45176669585578,2.86013069973867,-1.80520339292756],[2.67500665989758,-9.22540398011236,0.142255303783934],[1.89989016070513,4.69913690070729,8.94299508326214],[-1.78076054536747,-1.75376628719135,-8.51396093601539],[-2.02090567673585,0.734137040600273,3.52188155238735],[-3.52107494850283,-0.199496373745011,3.00433643095562],[5.3021191121562,-2.85191693736609,-3.89216189062052],[-5.21188999151525,6.18878937161753,8.44516238405359],[10.6448177857597,4.06551172434997,-1.1578763540224],[2.24312715041423,-4.80646716126737,10.9944283760765],[1.93786936776855,-4.33584822776926,10.8341599466094],[-5.10053921456481,8.39714797797426,-7.36900858008868],[-2.69126703551963,7.231095660568,-1.43897785498166],[-3.23029183468362,5.55964314227078,-2.9285251265852],[-1.3138710565595,1.65946033401838,-2.41964986168073],[-0.501907871518141,6.14082382117713,9.11704525311547],[3.24175972880145,-9.59843676508044,-0.642278203286491],[-8.74513033395492,-0.525716625171627,-5.34038814908868],[-5.71909563387784,-3.12595342596094,-5.30437354736801],[9.98932725290731,1.55536652603924,-1.74141684999988],[-1.35216758558493,-3.80268337308081,-8.36871671045249],[3.39564939511326,4.37716963037482,8.9074684175451],[-4.77887894286241,-1.41176754232548,1.75710827022702],[-5.87716964225427,3.61286368363496,-5.61237394618008],[4.44629924948318,-5.06549512324134,-2.78341997285479],[-3.99088442099633,4.67685516883011,0.22639937317949],[10.7825837209581,2.07765923166637,-2.32956205016971],[3.33931920553453,-10.0124720430127,-0.62937545505759],[-4.30331034307767,2.23197725317722,3.47987465668082],[-3.72161016653668,-0.579653365041691,3.10050264917815],[-5.6324991956706,-2.74674946070174,-9.1671561612478],[2.88053082629055,5.02631557776461,7.87481543307052],[1.95111462979933,6.84848883699767,7.60693905850979],[-1.47300087376808,4.95638539401303,-3.25075154667985],[1.33454981596684,10.2664597782686,-1.97942148106145],[1.97179664885392,0.101585740877807,3.81757210929713],[1.35923594773739,-0.696212079719864,-9.58498850941659],[-5.04869492155887,0.043839443393064,3.32110239546671],[3.41363555308956,11.6969592555832,-0.982246265231102],[-3.50263031689312,7.05045273333137,-1.24153178324185],[-2.98631696116244,11.9081175139124,3.43452705466183],[2.89171290863674,-9.74272375569188,-0.0252211005498438],[5.05756249310535,-1.91721182194879,-6.77988200658405],[1.87170948514292,5.93698593601682,9.59303289627304],[3.9958049121626,-0.758068125900718,-6.39343374856034],[-1.90627332623318,-5.24212409474873,1.99627681722116],[-4.84954261428099,-5.69501194373181,-2.40689189419949],[0.274724183668253,-8.08118897701411,1.39932490388327],[-1.67306426352021,-4.63164396081366,2.15794558531488],[-6.34187337922733,-3.35361545705443,-4.71357222125007],[-2.56817655955635,-2.91810194423177,-6.55982294995433],[3.40672250284004,3.49408423970132,0.582962922222474],[3.21849031568025,-5.81453753777436,-1.53018338934328],[-5.3189952004379,-4.57821611784985,-2.26538652802942],[-4.51374618006054,7.25609145648027,7.57893217110612],[1.21807697412774,11.5814556878113,-1.45565794328692],[0.514647184546921,-4.35882166158044,10.8963003858261],[2.20362231724796,-2.6246990863497,11.4061748904951],[5.25417916692241,1.26305728683527,6.09181035429254],[-5.7159474229728,6.71013955515887,8.84991892607529],[2.05018821829469,-6.9144889927283,-10.4254830358298],[-6.59651436327447,6.97240290467259,8.65199594977366],[4.68137365325333,-1.73118836264195,-6.68567589759193],[6.45645353650205,-0.968174008241168,-10.2352258740326],[0.390834325104905,-0.39451007962316,-13.0225101006488],[-3.27553003004447,8.23943829580553,-6.37227315254197],[4.1209731252274,-6.42214647487658,-1.69660649512979],[8.14742035682042,2.67777788204415,-0.879975363044439],[11.846804744966,3.86771784128784,-1.10273222760837],[-0.241197207153509,-2.42922754008413,-2.54090068977415],[-2.20740455181225,0.176884845510067,-3.93545838862571],[2.89703967193307,5.39434928763133,8.96599952023697],[2.80621851822872,5.80698858574631,-12.0000960850836],[4.24573535268357,-6.95816961160482,-1.9249760790974],[3.74346399396239,-4.67633665934108,-1.53932443186475],[2.78951490235294,-4.09970111412618,10.1202974651922],[-9.34540243422369,0.467875550593131,-6.15573363571399],[-2.857278510301,7.17363793678938,-0.693536619346639],[-3.56261159744194,-3.89384287795594,6.43945037076708],[2.06751314225625,-5.28608833766461,11.039118267322],[2.45851898416375,6.25103422002621,-12.4165967667989],[4.08152983680943,-7.16667677926401,-2.22215844872854],[-5.93904055940979,-4.15354584466458,-4.66102864590256],[2.74121360002793,6.55529672493337,6.99754472382803],[-3.05921587476067,-0.653596692231139,1.39964695929954],[-3.11478830556314,-4.54750523227649,7.04155086909955],[2.48950835376713,9.7099359773182,-1.87355390414427],[-1.74944624583391,0.731757183264139,4.00249066335019],[-4.3814114994078,2.78382178714598,-5.05814936591376],[-4.17295528817811,0.957286914738882,2.33410369312157],[1.67198819800983,4.93809788571478,7.65683109320339],[-2.04769889584619,-0.00343031533786731,-3.61050770677776],[2.41192749219454,-8.71978544500997,1.27557999183779],[1.71582510542718,-7.64567935992753,-10.6614324374526],[3.47708533159239,-7.4583911293162,-1.47939483789481],[-9.28857614565556,0.809219795622194,-6.12460077150798],[-2.21061558141675,5.32253243595485,1.15056765916487],[1.67672959805835,6.51587347381666,-11.354574750945],[9.54771935849045,2.90104301396678,-0.852663255960556],[-4.695723298978,-6.30579200685765,7.23101425033165],[11.0402145059459,4.22293499200502,-0.925365207182026],[-4.48454002264358,0.418484369991442,4.07793156217636],[1.65258872865792,-8.31501965826845,2.50229739039293],[-5.26229758519915,-6.48819366527885,-10.0014002057789],[10.3483916397383,-1.68825363051975,-0.50771835682024],[1.39323516201306,-7.18791120021757,2.63650512704777],[0.443455673083872,-9.19343377144899,2.12449739691484],[-3.14753693985132,-1.10694939359501,-7.87496018853147],[-8.7944774681713,-0.559933274470811,-5.12480347240463],[1.92428640741696,-7.87978878957874,-10.691167591324],[9.36122159960799,2.59998381200517,-0.737686353393624],[-4.18887952216564,0.436292231145713,4.08865300571289],[4.53528564570855,5.92314051714628,8.45633169262793],[-3.78891330740942,0.504918675125573,5.79094006586137],[-5.74096844925419,8.55625802705656,8.35637575554988],[-3.27682731183126,3.7712795055878,-6.84264732110964],[3.07472028707409,-9.24333273812544,-1.60470313111398],[4.55079722482134,-1.00260784406308,-6.54492433994827],[3.48938606229569,3.722842273986,0.357055709080793],[1.71409277013033,-4.37238505584338,-4.90957952070511],[3.04048772341129,-9.72030749129218,0.128900137608879],[2.99674543801641,11.3753881642548,-1.39757815359879],[-5.31812477208789,-5.82469320113083,-2.31409034875589],[4.15498271230564,3.62468384313522,0.981280541671571],[3.46543111546533,-5.35026512327331,-1.99563407660443],[-5.7799110709718,7.13022505661143,9.05584292807121],[-2.77367695603177,5.78916114343129,-2.61721278473636],[-1.78190680479697,5.93406050375611,-0.653545426832418],[-1.51393457185878,-5.49598995720371,2.12159750226058],[-1.94911024719433,4.66253840261029,-7.16356064267252],[10.1900084715818,6.15097742003179,-1.1829104194872],[1.4664975448434,-4.33649146362363,-4.74453429499876],[-1.74991322159608,-5.82132478575691,1.7631460985771],[2.38870083226251,5.42238988186281,6.86635830886135],[-4.8822904931034,1.63959183613629,3.21399574100584],[-5.26274762638876,3.80794008735136,-6.43631152441318],[-5.10895622842357,-0.312391833323937,0.624559933300217],[3.25844383275633,-3.56212939307039,-10.5518580986653],[-7.36362386312485,-5.71366351237169,-0.0983713751651866],[-3.76463910014985,0.274704878584273,4.21115893989592],[4.06961328309923,6.44140685145161,7.3195136193803],[3.69716976812352,5.26071405707866,7.42250289621607],[-5.51471805928134,-3.18581967398001,-5.04767690522655],[3.50208771788534,6.15093271002866,8.65294591792587],[2.04644060663514,-3.50965795703178,-11.4015544091141],[1.36933290707941,-5.47917395979098,10.5163636517032],[-3.09601797094056,5.51086817603193,-2.76823247980034],[1.87043740648895,-9.62124713319976,1.0947587784932],[-3.96302939347325,-3.36440500961348,-8.87113396599829],[-4.6707582335728,-6.73107801068754,-1.90706408208977],[-3.20771585911897,6.79146009770813,-1.16611624329412],[-3.77366680210342,4.40981906655883,-6.94073310694523],[2.45526223292545,10.2445894592827,-1.440182574445],[-4.30762723591049,-6.60764524021093,-9.58647167239304],[3.33791530011583,4.98626352297568,8.34358559069418],[8.34272444024186,3.92138441433619,-1.69129806503861],[2.79071278300726,11.4467582514422,-2.57542617459389],[8.24436082492255,3.37299180297335,-1.93764846797488],[3.32891239067913,-9.28313130896046,-1.72183331376892],[-6.30185306057886,8.72002773723357,-4.66686483723988],[9.48474694516103,2.97668013033255,-1.23273339657249],[-3.68385033864711,-5.28067128092559,-1.34597898751979],[1.64713488375519,-1.04677161097596,-7.10404262644761],[2.81987737864699,-2.9735780373412,-3.31399861525257],[-2.33346570186261,-3.76918370680807,-1.01145644091359],[0.274436804698258,-9.46113598717156,1.89887793032049],[-4.78483793733092,-5.52191539684829,-9.83298178968737],[2.49376132198244,-3.55627447501196,-11.1669981495784],[-4.61500844981346,8.39177564617388,-6.72736155347924],[2.06150044040239,-10.5164499876593,-1.0814796546448],[1.25553422587319,-8.49786801686826,1.23161303664554],[1.59411442157778,-2.03148999691912,-5.58221835583389],[4.89347948497573,2.05452240670118,4.40947389559812],[-3.38667619078376,-3.32385418067907,-8.08168592228301],[-7.99684680141142,-0.67271348096948,-5.41724927584923],[-8.05560576536183,-0.379645931294316,-8.04516083098278],[0.370943899937481,-6.14131481282471,2.65505890960074],[-3.19833045937618,-0.63835832444386,3.50543014880339],[-4.21683127953079,9.90781081582317,-4.81591363093175],[1.35374812686327,5.5176946017654,8.46440409013202],[-3.51621038899349,1.6720836265185,3.03064210111738],[-5.51306566225746,2.97790210311658,-5.08020922358277],[0.67586502481445,-3.99110821474913,10.4468260080674],[-8.90631442518103,-0.635224673346686,-5.3496275331955],[3.15938605564075,-4.24602478428183,10.4404762884739],[-6.22949119249565,-3.34136372746788,4.91486464653081],[4.14879373405304,4.70862794124354,2.85614665864568],[2.52614465235783,11.1388516610005,-3.05571601632617],[-4.10735064170598,5.99160852135612,-0.972572462582346],[-3.1962806831806,-1.13092370000276,-8.05495935928394],[-3.96819601163369,6.83291699523175,-0.0705969528822266],[-2.26073494991276,5.17593522233978,-7.50596048351487],[-2.41699144652512,3.8175699602152,-2.47834496131256],[-5.13690104928278,0.20259078754986,-1.53828758356149],[-3.37663430040087,7.50760867984482,8.50841794883082],[-0.103699022464594,0.226471556525527,2.97788291727694],[8.67117875245033,-3.50834283885712,-1.60579371948652],[-3.83121826555065,4.85236284120196,-2.52297427957008],[-1.19259132338092,0.109084503593285,-7.48293534922982],[1.00450782973515,-3.2637501963793,12.2029122023441],[3.57386274421119,6.42571698010302,7.08452658090185],[3.90639368395069,-8.49914703731435,0.162339860790846],[2.0760026133305,-8.6565426927778,1.03157466505817],[1.7236617072577,3.00402055875246,-3.30030462019309],[0.760514665225164,-2.42000357238286,12.6169647899658],[-5.97129458727893,-3.49729248093808,4.59626360778415],[1.43795326622955,-7.88135138789409,-10.366407821982],[-3.1512498653449,0.0772715404787199,2.77803741117437],[3.49447207803377,-5.81389141303188,-1.396721305131],[2.93832341107435,4.67119174836634,7.98147965623009],[-3.27115867138987,-1.01501656391205,2.12446030400845],[-2.77411209593611,-3.07172768599947,0.0912051638405572],[-3.9693238116699,3.45546209878189,5.60334573006231],[3.18769422336596,6.50979806732214,8.45697915124292],[-4.83372612247719,-0.543654255675827,-0.961735894694534],[1.78458330142357,5.31450428806752,8.86473272722289],[2.23185321496964,3.88091523685538,7.4098873913396],[-4.3800672709998,-5.26843887059625,-0.947475150590604],[-2.96619913335775,0.37396691321234,-0.0389676714995789],[-5.00215926624351,1.46485002232037,2.72152166626877],[2.17942094442343,-4.95108035971604,-0.262694758681547],[0.311600600865769,-7.90884100297233,2.07773385538052],[-5.36441753328684,1.6419177181566,2.77974567698722],[-1.67906628862933,-3.79808576518693,-0.770038850150279],[3.0729641009364,6.38717356491805,-10.8953388855129],[9.53221153816614,3.17034853949578,-2.33117808618471],[-5.69205634890244,7.92783992685528,7.97811874712975],[0.318659491660056,-6.50503716534148,2.31118566720236],[-1.88350941886634,-6.62538419201524,1.55514531631185],[-3.02312283816658,-2.79021183607599,-0.61399191529366],[2.63943530789581,12.0159328568312,-0.953208279313625],[9.16098754575456,3.35491726471015,-0.831927072980265],[6.69320966144456,4.11564914800637,0.5276297829859],[9.19368010787312,-3.60442358166345,-4.58414900359666],[2.90436236791043,2.78016814485924,2.76329648381743],[1.90811818408646,3.5755037674937,0.29786600325199],[7.39392931455319,4.38728845522179,-1.3376515967682],[-1.48202589537718,-2.6081228438451,-12.0454040425969],[-0.446287883299078,0.670678190032701,-7.62678997705272],[-1.38285267916761,0.706975558500054,4.35670502348212],[-3.60511451292904,0.634827219326963,3.21665801115648],[-3.87177983030474,5.45278073069221,-0.520819903198086],[5.23754432173815,1.35789746367009,5.56117921242867],[4.57164311832799,-5.76684087111416,-1.94143747474823],[1.78542182780403,10.8776807913209,-2.37025759327637],[2.62563167173891,5.56140359326665,7.6753632389794],[-2.89478868901454,-1.05859809470564,-3.75113860711329],[3.72739035329772,5.74546079507094,6.84410061826459],[4.30729525310872,1.69049858242459,-9.82733373194696],[8.76703195641236,-3.71353912357801,-1.23033739922147],[0.55831056256025,5.5546660333823,8.7630626379662],[-0.180809174211253,-7.61123225284203,0.991668177853429],[0.819622051386579,-6.3717669990368,-0.156372332323161],[-6.8665071986648,-5.47689530422709,7.43422737007523],[0.39954699727474,-8.31178478118681,0.437800632761678],[4.72922529302979,-2.71741762909316,-3.50158242694767],[-5.33662087572935,-4.36927079820147,-2.25495263715869],[-5.88221723099769,3.02913640212652,-6.40920164949345],[4.48150002035962,-1.38206613997388,-11.4778618352718],[1.64931229316167,-9.53509124296939,-0.403665098498986],[2.52740853007736,5.78817558251456,-11.8967850194811],[3.12297606777555,10.7634829844763,-1.83526587352387],[1.67350556671002,-5.46720591691019,-6.34139015405884],[4.17883736592686,1.54017601023635,-9.32182589098687],[-0.934612320762875,4.30111947272585,0.312263394575695],[3.7802473017147,4.64167413565957,8.52559748741986],[2.78089562714271,-9.7935915113125,-1.4575356061829],[-5.08959958917997,-6.85785688815004,-2.00774757976444],[-1.63121204803422,-3.7494239506865,-0.860488750670896],[-5.21210619041604,0.148072891525876,-0.707279715040016],[-0.153997411943342,-0.00138125945796386,-1.25288189807236],[0.464662680319305,-5.28298556308548,-1.09368276474864],[-6.11756937109907,-3.10575593801926,-5.03590058016914],[-7.3972551498454,-5.82183833852182,6.8361961375336],[0.373969493401233,1.14456681642888,-8.45026399417543],[5.53579269068202,2.81903401776544,2.29641452526819],[-1.7779272873274,5.65256666850112,-2.51834432769659],[1.78409939288001,-6.29986334252108,2.18377246541619],[-2.61861946229735,5.06864307664944,-2.33624616660084],[8.38925761059524,3.07282761726163,-2.55420674250255],[0.650831157228918,-7.94294000198793,1.58442907629725],[-2.93548158065632,-2.75769772391969,-3.20381312134685],[1.13669279027741,-8.91004683742974,2.09422738323813],[-1.81428072348357,-3.63079814476758,-0.523514874989176],[-1.41406725276821,10.3157117700478,3.48710058698173],[-4.30515422745741,-5.48516037513674,-1.09125413263687],[-4.76645185101582,0.59387441777353,5.41644028239727],[-6.50954424168358,-6.36644083912506,-1.03946101679174],[-9.2946763799812,-1.68366292892632,-3.80485895478493],[-5.22604114037577,-3.09803800943878,-4.44619969059808],[1.51018625165612,-8.70715394975722,3.48926943757277],[-1.16336790961407,6.32580542998795,9.08704771268785],[-4.97131079327613,7.36442245752915,8.3798593927382],[-2.66639566001932,3.86704482217667,-6.63793473185412],[-3.86755134193325,-3.287347875865,-7.64754112299653],[1.1745328616211,-2.95871277619225,10.2618716785894],[-4.39659476026928,0.343958520286461,1.98249059208154],[-3.11160263962912,4.4277344057173,-7.25335851204361],[-0.365797488146846,-4.08997696519566,-1.23112662054275],[-1.9984010200082,4.51114728418161,-2.12435246629196],[-8.94102003470374,-1.5538006584595,-3.36903160603128],[9.33742455119603,3.46874705632799,-1.68827371832547],[-5.19019533751181,6.4421769427928,8.12613043128695],[-3.84313933524677,0.888425418561824,3.66147717153023],[-2.60352350295809,4.6891238187973,-6.87475456987724],[2.48068161079239,11.0621118791437,-2.76362169075253],[-2.61551472714269,-0.533597091289806,-0.526474974454448],[-4.77381136867008,0.807518413292495,3.06996530933058],[-2.98949543395619,-0.789610880508372,-3.68460108972862],[3.24684046047974,-6.27363822721455,-0.721153739642919],[-0.126403511667837,-7.23782774242661,-5.64716367457953],[1.45762384344744,-8.62563201303483,3.54622859823052],[3.16084059240343,4.01114279661461,8.11254965794635],[5.37938672334304,2.72475021491559,2.17785977413389],[3.89936017908539,4.35495168238446,8.47807194761835],[2.06639204641568,-9.22084610595608,2.57909908752322],[11.1650841707866,3.63259312660545,-1.38120117171154],[-3.22986800360837,0.241929997354508,5.79673048185501],[0.998610807877123,-0.593525251401649,-6.25157986652505],[11.0507350373319,3.51430934702041,-1.55151279144941],[-0.874919837688328,-6.28946584958738,1.87988392312702],[-4.85203401691025,-3.9857022823391,-1.73218457949447],[1.93051138584979,-5.77515605497399,2.33453119845185],[1.35940992892306,-2.56090090821164,12.2400038499949],[1.33965740157971,-7.98275733410194,3.96877807446139],[3.95921892781133,6.15590268003089,-0.0161481400876297],[-7.16204925964154,-5.50959071139953,1.44652612955166],[-4.24738174573914,-6.71535555623463,-2.41643150365075],[3.01578919729805,4.77506322668051,8.33806576879858],[-9.34984092108676,1.46549314695993,-6.38005571971459],[-6.5812534278621,-4.97846470074474,7.48268097657759],[2.27508906249608,-3.3720269869682,-11.2088920202139],[-0.0863854644349875,-7.28064663854135,-5.96324982283865],[-4.83231039036696,-5.38919245888277,-1.09906148707948],[-3.97310244590254,1.77007021547701,2.45429485342891],[2.83635583676137,0.0126079433030175,-12.6306107219597],[1.31715111303606,1.95717418993699,-2.5600153568761],[0.325547634665296,-3.10075653415031,-11.9124612960535],[0.583750814843773,-5.89983166901053,-5.52239351280846],[-2.5168981109037,6.47545571536603,-0.713824127449231],[-2.9526188883089,-4.03198922293194,-3.06730570005933],[2.29130328328055,5.80706683686307,-11.9544686634703],[4.18375389776383,-5.28055114524087,-1.36884432029343],[-4.5817573725942,-0.480559581336198,2.60083669007397],[-3.5429396334239,1.05121842230796,-1.68694709796762],[-2.53783019301259,6.39988354093504,-1.5956412632161],[0.989894785447105,-3.73803168801216,12.6268194479983],[-1.62669711548259,-6.98567620897778,-1.29265934693825],[1.43144889657959,0.142318935502669,3.53235277141638],[-3.01507855128596,7.30480302957185,-0.605916057984953],[2.71619228698857,6.64583395218079,7.27620880154037],[1.06366040681353,-3.89081744525151,-0.45873165797186],[2.39585620541818,1.45735792208663,-8.13480875890983],[-4.69812230578634,0.515563356329003,3.35549637339978],[1.08856025757189,-3.23933942558375,12.5641762281608],[3.87526240491205,-7.09814599171689,-1.67085862524081],[2.03263941830286,-9.98007128786365,-0.973507551006054],[2.85700577160709,6.04685128730352,-11.6934306594745],[1.41355040861178,-5.75635200323192,3.89939265012235],[-3.95687611106398,7.34724293400584,8.9998980190652],[4.06105744596169,3.23543152038691,1.90782284434236],[3.61940600715529,-5.47844401598784,-4.95997219568005],[4.09479466483213,4.79044437883438,2.62962945397525],[-3.22038116525038,-4.20568901828099,-8.33972388896871],[5.36922664582928,-2.74736126218955,-3.87274338292136],[1.57071516160506,-5.35889725197303,4.90679804355566],[0.622785691927944,-8.2090486054541,1.08301688632173],[-5.31412376142889,8.31738378274111,7.79931635133991],[-3.94193034938394,2.99472009792555,-6.84364079598287],[-3.78523993058696,-4.73708280885352,-11.1120034938076],[2.16585767184667,4.39468713878742,7.83823191826074],[-2.05356350166628,-5.20710978039435,-2.27734437155456],[-5.0939876784204,0.926172498291827,2.72327160703379],[-5.6258832005664,9.3291738771524,-3.81991948227847],[2.73858668327268,4.98640176591932,7.75583658515621],[-6.26568053414643,-6.41183184986645,-0.840930969744473],[-1.40367144109223,1.61107140202681,-2.50101563687278],[3.4171256656609,11.8643900791818,-1.82371110103207],[4.063792062127,5.40018146468135,8.60360183395939],[4.24017440040082,5.96187638770522,2.41961783075183],[4.38130574194666,5.13716473616492,3.19172235150714],[1.36195720774706,1.95864009114477,-2.81242785114028],[2.38056857339984,-9.1066447343163,0.818398670791767],[2.15773257215354,0.00367648852424673,3.45991007187958],[-9.1541621068031,-1.65995597540897,-4.08953222930393],[2.19391982311323,-9.1035973784588,1.85357949936669],[-8.80508789944389,-1.07573278958816,-4.13570747115482],[1.92650464558573,-5.09898038442827,4.16966247853279],[0.60313309250646,-2.54323034101887,12.3659662013972],[-2.1712093219654,4.44963900149758,0.601067572147172],[8.62167984567071,5.18727289960112,-1.47882373688007],[-6.3215952963852,-4.16424323252484,-4.00776597188238],[0.772319777737168,-6.11063252239607,0.982670467695422],[3.31341086294438,-0.382024150250823,-12.5845192507706],[0.946388534789295,-9.22269660464319,0.491129759030388],[-4.58392033671558,-5.2968805907587,-1.61043397467241],[-0.1222733232303,-3.32911777769291,-11.1991506891356],[1.67807806551939,-3.72561368986421,12.9227404410649],[-3.79995754374702,0.782229150199092,2.8700564293465],[-5.85573973045483,-1.27389555931777,-0.877451168845557],[-5.01329735622445,-6.61791016167948,-2.77207683230858],[1.37734264269188,-0.734465443837338,-6.14803904191546],[-5.33133786217587,-6.4063476650014,-2.40269108747788],[1.78441230285446,-4.95044637061618,11.0082118378799],[1.52100724767612,-8.10689086521845,3.48564895490836],[-3.53155336515709,12.6979187297172,4.03665434011794],[0.687642263903262,-7.80801872003718,1.378273402024],[2.03275551013612,-4.74571771752963,10.0443319842028],[-4.93925320052559,-1.50590454896033,3.27418892018539],[-4.99834681907118,3.1765051706178,-6.70749382953383],[-5.37013210814833,9.55381113336238,-7.40096594810576],[-4.73380272608186,1.26066212917747,4.66495915462237],[-4.16976014252144,-6.37048421539868,-1.63433569633803],[1.74601116924496,-3.81648843363726,10.0874597395582],[-0.571978158034594,-0.825495558436603,-13.9284246826725],[1.04778880328607,-4.14046750493596,-2.50122566767951],[1.16012806443609,-3.40423307657647,12.3530427209738],[4.68813529804153,1.57490025773214,-8.61665801288679],[1.91907424015766,0.635641325770763,3.28934583778012],[3.52404948693764,6.67706434987389,8.29281619576454],[0.736702823788637,-6.17044335879796,4.57196828051249],[-0.0358851914571817,-3.06734951424134,-1.41025529871476],[-5.97216715339272,-3.42504683838407,4.64640733029466],[-5.10660919588766,-6.38678885659732,-1.28731084502176],[0.40293738072231,-3.15540223130875,-0.721064254127476],[4.47851725983606,2.10648139747324,-10.1394672360439],[9.81432185266179,-4.40655255659494,-4.90300264907393],[-2.12517801895414,8.68346877856075,2.96807282807143],[0.108616135087167,9.31520920867065,-7.76085810139825],[-2.56519988180332,5.19627076813233,-2.32990089270155],[-4.93509321737321,1.84870737394612,5.11759939253302],[8.39235480642884,1.12976701605002,-1.35604530678007],[8.93829863268408,-2.29792577742929,-3.80785939700303],[3.85002812818621,3.66886582778451,0.532774820091116],[-5.92509950837222,-3.44971378688347,4.71039806009968],[-0.345307235577223,0.516360669965762,2.98313227617197],[1.4741991779902,-6.80135553464556,3.60258427949678],[4.18828435865469,1.78919539141729,-10.1698385829112],[-4.88147232686686,0.459075460721329,3.61386771330011],[1.7392651515142,4.19870666493721,-5.45631446405973],[-0.497304836520417,-6.75161156358546,1.03987828876141],[2.93991442040582,-3.52456171301439,11.8541609968079],[-6.0839625184443,7.33664639903888,8.1867173768194],[1.27877459369265,1.65357784715649,-1.20650160537286],[1.38211793983829,12.2482645484445,-2.35768901127954],[-0.409587552262204,0.679521111018978,-6.25699001060668],[2.85969205048575,0.243646372067032,-11.5006697888797],[2.83907866751801,6.23090060355228,8.6563308605569],[-2.502314841426,0.459650153829204,-1.02995415613955],[4.40003693837312,4.44585633601336,3.26688925418095],[-3.3789724869145,-2.15118249803021,4.04574386970319],[3.93320794623861,0.628256809812545,-9.24290271192709],[-3.39395003847381,-4.88910876420395,-1.52273740206549],[-4.75498477349155,1.77499560195528,3.18584931515257],[2.3804511232305,3.7585840669631,-6.03637432084636],[3.49004550482366,12.4169904605152,-2.78666906271104],[0.602399831629573,-3.23823161041836,-1.30209271060292],[7.25313403846852,-1.42333030693878,-10.503263671133],[2.2572910714369,-8.70233535846982,0.815761879787678],[1.416660404796,-8.65128117639787,2.04337020408359],[-2.42913815873234,-3.45645641766893,-1.84686243658731],[9.45178295138939,2.72788008938283,-0.610676015063212],[-3.95845049337791,-4.91580773044944,-11.4474142833904],[-3.65756045282865,-1.69654148890735,3.82937115018812],[-8.33510570579854,-5.65613941432571,0.49473482022016],[-6.42439339406873,-6.89628010757803,1.0107892702406],[0.0352921461401188,0.314603468614305,-2.23080899482004],[3.04497685043459,3.26766315095342,1.16490804607466],[-4.50837445920757,-5.85517101455048,-1.63831482116071],[3.55811353419906,11.7104964071262,-2.01938036219997],[-4.76330039780697,1.07546239830506,3.54587399830685],[0.170472791544076,6.13222852984867,9.1001298306189],[-6.40794573276465,8.75535427124439,-3.73878278732835],[1.26086103445833,5.58075440068497,8.250356927983],[2.65312828520949,-8.7019911167024,-2.04072781344606],[0.35511486324744,1.66638380154358,-6.66095901257204],[1.18108593110142,3.04601399901052,-3.81391518396742],[-2.5053594910562,-3.14215241694507,-7.04078744112711],[0.201804543150668,-4.31698866098667,10.6919489634393],[-5.24609746961799,-2.73774687275534,-3.98711233474855],[-2.54666681013234,-3.31319692830633,-7.99267359365448],[3.14138458115003,-4.84004830148215,-1.85069259438696],[4.03026407235161,10.7408450033538,-1.35423573429736],[1.80076019290139,-5.73096177565263,1.66987871734765],[9.00073341954579,3.57239899546154,-0.680825793138327],[1.27825121486756,-3.84458130082468,10.7559179155888],[2.98268956271128,2.64313445986863,2.89648337877577],[10.4773590438872,2.22475611377019,-0.991277400462757],[3.31970783539853,6.68035642423796,7.40983910796476],[-1.31714637237442,-4.65946534539883,1.90774063543351],[-5.96383033691627,3.48852476947072,-6.33628262157567],[-3.40781123333618,-0.152396249975473,2.83094674448615],[1.31455582975126,-1.35291368292044,-10.5045626303255],[2.08795306940487,11.4314868497574,-2.65471603267562],[-4.67976083549426,2.24130951424343,4.88316354655183],[7.46141610775011,-1.38078467289432,-10.9410631608543],[-5.31971322985603,-1.74939463297027,-0.432281030699652],[-8.00478732854429,-5.94486727232479,1.87233811995216],[-0.0934880197793534,4.66085039698125,-1.81719705866305],[-5.44399373989613,0.0050968413252489,-0.754730881055111],[4.14972708824228,-6.87729586464922,-2.1808238661939],[3.11248024637466,11.8741599671227,-1.67232127411219],[2.09039052060841,-7.32352028929796,3.34980747506831],[-4.92596622567618,-4.65152318955403,-2.0466615610765],[-3.68628405804817,4.16908260153382,-6.98275137580988],[-2.45256138829714,4.53027999726826,-7.24985978047979],[2.31355947893275,5.8183165017966,7.15988807292267],[3.14670012171487,5.94506000292051,6.72233785633387],[2.9399265102945,5.24037990359894,7.17638435871485],[4.07260986348572,0.0975203916572931,-9.91153985691483],[2.97462631077176,4.79047781596361,8.45153354735949],[-7.22744378539381,-6.88315717434558,1.35106085552969],[-4.6876004969132,1.12030669112251,3.23124909043253],[1.69663339508337,-7.40006888535617,4.65776789706492],[2.89194312817855,11.8432554589671,-1.23463894499745],[3.43924122468934,-9.90419135045411,-1.00843322079589],[1.04908546234801,-6.18047658158009,4.15262922986522],[-5.60141185518622,-3.34906977614772,-5.20762998213524],[-5.11947255404475,-0.399314614486198,-0.0648379889158556],[0.632354691549288,1.28780487386682,-8.62505616050119],[-5.21092759610588,3.19433866661247,-5.48877708397445],[3.71200845731927,-6.47497404111847,-1.70484646581317],[-1.75867996723392,-1.92919694023356,-3.09135336436618],[3.11411244760631,11.664320021948,-1.89928042163137],[10.3281805235651,2.84323315690843,-1.63579095900071],[-4.66021741540415,6.1154988531699,8.92250416319428],[2.61686717026794,-6.22314838238502,2.10505189773241],[2.78210672020841,-10.2100781357902,-0.248574981468888],[9.07568727305886,-3.7715257657073,-1.60877487742538],[-6.36110080144102,7.42111951615888,8.28833666423113],[1.32199942189476,-9.76812509994131,0.122026747830504],[2.2665777283837,6.47278842156784,8.14477629927782],[11.4547052668016,2.34894455117868,-2.16964419144941],[-9.28190160146785,-1.61766765811779,-4.30623331157112],[-3.29184051681118,7.14945616288948,-1.13135903000936],[-3.25530347341105,4.99096613503867,-2.38745778058357],[1.9849934074613,-5.38404568608621,2.49610266200574],[-9.49807580696543,-1.07827173886149,-3.86197090213206],[0.892171028845775,-5.1453423844613,-5.34861419278488],[3.00246823383998,12.1716839423382,-2.67992404078],[-7.50032154561157,-6.41847752132781,1.56793228293064],[1.81521550251094,0.0654541710263042,3.66670182253582],[-4.63450657753459,-5.2597293389548,-2.8237946063708],[7.61944730302242,2.68316560643225,-1.9922499553459],[-0.103610403768156,-3.15049042448861,10.55204670936],[2.19555623563654,5.7113783945938,-12.0796356727804],[-1.90479629392394,3.49945306178131,-2.3180527284865],[2.02255904465725,-3.31228628345725,12.1841538314377],[1.84603687921021,-9.24635845831169,-0.281836243802293],[1.45470197260127,-3.69904719255437,12.9277973503874],[0.806583208390755,-8.17327509172775,1.11157029652045],[1.16790788410652,5.55646963987218,8.57571052792772],[2.1997380741951,5.20009174615543,8.72890636403782],[-3.29321653297635,0.392074928074201,5.30009158017758],[3.54210446464196,5.87387014848304,9.12217736879001],[0.288161394942915,-1.13272298161563,0.469346950942488],[2.44629738545251,-5.2903247447688,-5.39471809330451],[-6.1174591288481,-3.56054652863906,-1.71657601476751],[8.61471147003929,1.48753767906967,0.186073033518609],[1.5931739690922,-8.23094738934662,0.47136465137831],[-6.46480870868928,-6.21735900096273,-0.631722154368888],[4.05251128585399,3.67375942499138,1.76025852387259],[1.79865875800099,-1.24818369950358,-6.26300212011369],[-4.34645966999907,8.40677681163889,8.31395856917404],[1.1132382959624,1.99873118654484,-1.2520880195751],[-4.12713220912342,1.93330776026559,5.32533484051277],[2.43397676235864,11.2902877807824,-2.55989195132678],[4.48169343423144,1.66347637208429,-10.0786778200561],[-4.91368421208317,-5.92676405114288,-2.54970438922825],[-6.21311723153564,-6.32365194412682,0.125235441115938],[7.84054228596258,3.8440531518376,-0.981691833583506],[-4.50989362831253,-6.33480587892411,-2.08107531014757],[-5.20907089656887,-0.432046561729615,-1.83257740583575],[0.718754057818037,-1.78691414694652,-1.80830957899586],[-4.50483014981977,-0.186546534900556,3.09106097090591],[-4.82180715373473,0.165452832991426,3.29368862821497],[0.934948886042445,-3.187128578527,12.2634926693505],[-0.698388644681692,-6.17446320379264,1.82871642639505],[0.231394108805805,-2.81934497773992,-4.87184740248899],[-6.15438390684017,6.86700956707107,8.54205288483344],[3.09099975508937,4.87591273257907,8.29738736188926],[0.16102706432393,7.93851135157212,-6.64748270983148],[-6.17003428021881,-6.37439204022012,-0.424943251133987],[1.60786243985664,-8.93966715828468,2.966748097755],[3.47966519319505,-8.1910207479724,-0.694177359150221],[-3.60606374127254,-1.85461946707282,-1.06563733311792],[1.7113678872755,4.22628884773326,7.47698824142447],[0.181717801082532,4.1365856566451,-3.43813565379991],[0.706418364710728,-8.60477048083043,0.65792239232767],[-2.46773530113795,9.96089615077216,-6.05223823394938],[2.65566738315487,-9.43452297781691,-0.206882505725323],[3.85858135547588,12.021623597494,-1.89368507370132],[-3.17751489023629,-0.456633654412583,1.76920399158201],[-8.201214190824,-0.290039031486459,-5.52647596071998],[-1.66620262639365,-6.63220260207409,-0.916607523715944],[4.00467934816924,-5.08262142351372,-1.20524111932101],[-0.199713604799499,-2.65132798231253,-2.2639857951835],[-4.48083043866429,7.89175751853533,-6.94037953270308],[-9.48427690466389,1.33136369132184,-6.4052308553974],[2.192129820468,3.77043514823141,-6.19468585632718],[2.47689136789133,-5.11328525558113,-5.98233582748701],[9.11860470570041,4.92469979556883,-1.39562208352932],[-0.0254655566634127,-3.40729787846659,-11.0767190685611],[3.23558713489958,11.7879487707215,-2.69336276521341],[2.10384702863864,-3.83293687141254,-1.73680783051525],[4.68535107043308,-2.65253262887417,-3.50818397398665],[1.58039498713151,-6.00392987888745,2.47752240787777],[-5.30432312159529,7.13572060962326,8.43635235329996],[-1.88963343591891,-0.0774694662418414,-5.33190739538645],[1.61989870443405,-7.01884726083682,0.453128501629934],[-9.65474614819705,1.31717774714428,-6.24050271893791],[3.94676414373502,5.28495903858461,7.48564496308575],[-3.93096733675784,12.1487146243823,4.04469756147963],[-2.85080474049817,7.01680430849957,-1.18172411163605],[-4.94090839746632,-7.16054807072816,-10.0159004327576],[6.87640857212952,5.45536056924148,0.840369169982656],[-5.78834071612988,7.81055903770296,8.68044417055847],[3.59900094905624,-7.34413313156628,-2.09798581992322],[2.25691028103405,-5.1186125782442,4.58446861499865],[4.30001211543608,1.79654947133117,-8.99559862123383],[-6.75149502025735,8.68831834386788,-4.56857614765185],[2.28083951200002,1.00699013025489,-10.2194984893728],[-5.42618996697243,-1.53610400403707,0.0884875005528901],[4.16236338320355,-8.01680312961703,-2.48111056162593],[-5.15913645379638,6.946649934084,8.92567761594591],[6.94243251191378,-1.08619777294581,-10.4412063173503],[-1.36250238816743,-5.0979514299867,-3.39342947314244],[2.75105437411056,11.4692628690726,-2.95137070298358],[-3.18573402564299,7.15967496095639,-1.25950083104243],[1.31346932432866,-9.47786268907962,0.990594544754928],[-8.96368113705863,-5.80998313061997,0.646635676937898],[-5.32804875868607,-3.83900442074491,-3.45999286450592],[1.43324192274081,-8.90563431602979,0.206000190827508],[-4.20595132753797,0.889207906568301,2.26863457224721],[1.51711045213779,3.80994835849544,-4.21304211840066],[9.69916047783622,-4.61231152163292,-5.60534645533267],[2.20617418749292,5.75373390532724,6.1227560268856],[2.09220644836887,-9.41909191378353,-0.32208661617394],[12.052877120424,0.885939418696797,-1.02042373824323],[-2.21520668711181,5.15544867016586,-3.0766152313736],[7.25949269495964,-1.30208667434484,-10.7775140264478],[3.50224055039213,5.7529426987161,8.61029083018862],[1.59436305213332,-8.06038165549962,2.3052952069191],[-4.20760639079584,0.951708791041414,4.81166315708636],[0.859265000594316,-8.3670728608704,1.68817253989249],[1.99316056079126,-8.32352616400337,1.34852539536252],[-7.74810374234374,-0.128476294393755,-8.8172496480652],[3.35605424941011,11.8367610812673,-1.93415876183357],[-3.5273593528324,0.796824541678154,2.09730829371625],[3.00671289706385,0.34201254068562,-12.0922833964122],[-8.39793856484116,-5.44023220593858,0.0674827006609459],[0.695268082693944,-3.22617815598593,12.0464696160302],[10.3241582579315,5.17801677016744,-1.40282509604097],[2.72895719966124,10.8949588749106,-1.90710257604521],[3.36604859235079,-8.22401307305717,0.0901768054073204],[0.956426250049023,1.81814812983173,-4.79589609889248],[-5.11342600883226,8.00622710725852,7.83515622391461],[2.25701708547183,-2.37577098616268,-6.91143961989181],[-4.77167246013253,2.01966610339651,4.88853031979231],[4.48709591891671,-6.65904314055514,-2.77544199872181],[1.16623205421703,-9.93252056044806,0.66821537551314],[-4.14103868227201,2.49171411293123,-4.9222788803329],[-8.31991297165716,-5.67288463291129,0.314877616816104],[2.49905894541324,3.66756963455189,7.59275458357621],[2.07831152839723,-9.95002159663427,2.02414556164178],[6.62999558194936,5.07927883891929,0.28272557489776],[1.88673407003042,-5.91180560458216,0.87503476041138],[3.35604915489236,11.8562618110007,-2.78924507193935],[3.33662934434072,-3.44089197841462,-10.4667857371199],[-2.39999985045848,4.83458982674332,-7.16014990647312],[2.79198590183098,12.0433959898929,-1.24296074466938],[-0.11743528245662,-8.4077775737319,1.39789386350199],[9.78591561317044,2.57498106256943,-1.84132573758644],[-4.4366345124194,-5.50966200577787,7.66847271518509],[8.97722316614598,-4.31584820126802,-2.28296350059895],[1.4605404416185,6.71882787808503,7.23892820652465],[1.02456791396485,-0.0150450253204844,2.93993514184988],[-4.27141670329628,-6.04594653497514,8.10215089039989],[2.01688684573588,3.50822106463029,0.299846178919073],[8.52478841079444,2.66572409404725,-2.55649730679705],[-4.08198296340279,1.07423512583368,4.89289627931409],[-5.50084716907341,-3.24540672097258,-4.71039720244737],[-2.65346515777829,4.71858289370608,-6.72853531888162],[10.5074798630809,3.55245489338971,-1.2144532810113],[2.39909388559724,-8.13390959036731,2.75917400429576],[3.65176595165748,-5.50736576860007,-5.01935761107446],[-2.88166171408587,-2.42105265121884,-4.3980703798712],[-2.87459543108194,5.4839424952143,-2.50949097051486],[9.2098051823722,3.60219550389381,-3.13481337027578],[3.12551260900793,-9.95359934975762,-1.15600527526037],[11.2069717192538,0.414041383246676,-0.736283941318935],[4.25922278579333,-6.68999989032538,-1.39834779466007],[3.67223635099067,6.10387425931237,8.28919989524435],[0.0181882725347786,-1.18487362581087,-13.5174871510899],[11.6936996631367,3.87576612472712,-1.53291199565092],[1.28389647017615,2.00707188271811,-1.9860773789754],[-3.97385455446159,2.51426905143882,4.77116172258443],[-5.38977561075141,3.6778728591429,-6.6118811392372],[-5.66858234266735,-3.14215423831457,-4.77401986595073],[-0.320170576161829,-2.89034636976681,-1.63740203569754],[-0.0905624796001456,-0.773581327038665,-13.5353092921343],[-0.0856011984086446,-2.96907128797021,-10.0792529606697],[1.13802382206455,5.7072883113963,7.45514645830844],[-2.34837183267339,-0.980379647293941,1.49347504792557],[3.97238895404809,-0.855651965206153,-3.81314450381899],[-3.88488079339277,-5.68504058695237,7.72161556710263],[11.8744258521507,1.97123409960282,-1.20201396627964],[-1.57368529286702,-4.75878845178396,-3.0109503619501],[0.903568286533163,-7.77196758499651,3.14037664617996],[3.43776610815931,-2.55554694556541,-6.62520345975168],[3.53583736406256,-8.19557523747084,-1.81246013146868],[-2.14307189246664,-5.40669975385239,-1.48866955428687],[-6.99976859524895,2.77080861299353,-5.45439979614682],[-0.625575871143651,6.00929718246808,8.17370133379566],[-5.71734331711864,6.65013735763272,8.55942703849295],[2.99312826536895,-3.30712378222323,11.5717920440716],[-0.294275635899706,-5.14728346831651,2.71393683568654],[2.48925433921436,-0.116192639930772,-9.99646585124558],[-3.77699657642373,-0.380550480979378,0.194754845416044],[-3.70632035187257,0.32311337233391,3.57824868209263],[-5.32528856541065,-0.556091075997053,-0.32332213500161],[-5.38420265227542,-5.97581830601781,-1.61543339706264],[2.43226150109035,6.18875638446069,7.86807632856802],[2.91753000176024,5.59467008944782,9.18810552941425],[1.55332822478566,-5.58281648767813,4.16711314706194],[-2.26519029416448,-4.66663423850053,-0.314057139845926],[-3.96135446779419,3.37168538613104,5.64267954702945],[10.655925615266,-0.948103940360867,1.15694796719163],[8.48597726731855,2.46095003765786,-2.54695017117634],[-3.07569052791028,0.474376414637812,5.44136068166658],[-2.91225789350364,0.0851144049450179,3.68831077333347],[4.10635973056466,4.98037591735975,8.11632895001245],[-3.06141857115662,9.75532754230304,-6.20120598687388],[2.25101589777117,-3.7909082735202,10.0127062693267],[3.56717688668119,11.2474131994881,-1.48037987419077],[10.7630232871524,3.74056767884346,-2.28609670360872],[-0.602819484235592,0.265462223800529,-2.95959463488358],[-8.98584009499082,-6.64334351773634,0.623644079460853],[2.64684088911069,-10.3481216490199,-1.75187088155426],[2.3591765966506,-3.36739601195239,-3.75525148549659],[9.72342470098386,-4.59743807148457,-5.32095592360106],[-2.71597089006536,9.042682231469,-5.74143249771423],[-4.46423110934786,-1.29064477528152,4.1974473513043],[2.26620453731504,-7.73917188034049,-11.0147552530323],[-2.33024743241962,4.13571462590601,-7.28150472959931],[4.10714104934923,4.03245179934902,1.19115605158354],[-2.54130998337679,6.38614121960216,0.434104483312966],[1.71682146382519,-3.10437216370183,-7.73118531337279],[-4.59487269335748,5.53390293522895,-0.328689301743427],[2.30656202657082,11.206751984689,-2.17873797070828],[0.606860141715155,-4.0055726829082,11.960308166045],[-4.59707173866193,1.61306370706223,5.1829428994287],[4.39723026125432,11.0290987269554,-1.36715062558784],[0.154869058685364,-1.42853216161322,-13.2984269199383],[0.481617049069151,-2.59452092040345,13.1860624833775],[1.64062380674368,-4.17541413272121,-0.117529007576254],[-4.96251453736066,-0.268630001257488,2.34164620605535],[3.28978922323118,-3.3732321076203,10.3461708247329],[3.72258550410881,-3.35839158684985,-10.0721211843257],[3.16907754168674,5.71500556977338,7.29066519573228],[1.33300864495321,-6.57204897236308,2.94032823391857],[-3.87267693641266,7.72935607153169,8.29349001248783],[-0.286225956594932,-7.46742899305748,0.95472701596629],[1.33262770902685,-2.91320458686808,10.5521164375832],[2.94094059504335,11.1702703390793,-1.54683144980522],[-6.12122388989405,-2.70892463637303,-4.82282817999561],[-7.25986658739182,-5.31327612370938,7.28794925663623],[3.4130544431196,-6.18069346803108,-1.1621556771585],[-1.84745823545408,-2.68725009681275,-2.77586656674188],[2.44216477972965,4.2820581493977,7.27789380556711],[7.23691385955335,5.19638150814096,-0.0256806780922829],[-4.04516189859907,1.87771717889995,-6.42178662825734],[-0.062257229793801,9.37120382355121,-7.45408230712115],[-0.27055053018938,-7.71338845478674,1.32389798145179],[0.427898602523174,-3.67120337022725,12.2415922303846],[3.42796411323739,2.78795370213693,2.96862178988969],[7.74976341457716,5.21164913534532,-1.09533355857363],[0.75831791436488,-4.83979453958601,10.964032339047],[-6.01145758188503,10.7537537523676,-4.58295263604996],[1.26635486101286,-2.82168554385112,12.1662621141801],[-0.412847161710493,3.08900032420262,-6.90288136018828],[-0.517151985184908,6.72785029098945,-8.5381696099614],[6.77054137823766,4.88846217137006,0.184778387540221],[3.5823486251754,-5.04118090311597,-1.01701812619437],[3.40616556789813,-9.26489494963818,0.179304180320081],[-7.64939303828638,-6.71319737339635,1.42231748968748],[2.17900271855586,3.91707529314073,7.5610977633485],[-3.25808857846284,-5.23325113617188,-1.47139677107571],[1.04418628437173,-7.97238488178734,0.272076341777194],[3.57343064455495,5.91591338552358,7.42816114420041],[-6.06534216312838,-3.20743216540161,-4.89007537419768],[3.28980171547978,-6.52541127321146,-1.3652826492808],[-2.25710649721754,5.30538791010739,-3.03916365253314],[-3.31593197773724,0.536182588523685,4.99387662686553],[1.76251448403888,-7.04480925382809,-10.4805593708402],[2.08469224154627,11.0155143052717,-1.86859814035515],[2.12943823731377,6.02278931330148,8.27880145218446],[-1.5269166246743,-4.9136246114466,-3.24365490798988],[0.772781515869667,-2.68527366689601,13.3514637415083],[-2.90634026360105,-0.116413632233216,0.255325952178177],[1.67593784089844,-4.67044126615521,-5.67118998763778],[9.145875504231,3.2775492114458,-2.44968040123746],[2.54242427471722,-8.64114440218168,0.558393493712845],[-5.18560771258171,-1.56876450770586,0.0149072247014757],[-3.12979335695832,-3.87721307601054,-1.24283656097582],[4.98724862320279,-1.7272420976526,-2.91920482870289],[3.77197994225875,-2.56633171775136,-6.7985077555095],[1.49023121090444,-3.04369170305703,12.7948427096405],[0.373939854438241,-8.50471303760663,0.576393327296602],[2.84101153663074,4.47209155423459,7.06526707333325],[2.32248224359635,4.5933008145951,7.67306714440363],[-0.135795853389663,-1.54902271199082,-11.297003150971],[-4.59426373078549,1.71196350641496,3.9105880278391],[-5.22163027544836,1.14115009195075,4.34854231187521],[4.52755341961492,2.7200613586463,3.51133662495947],[-4.18941599562684,4.99861812043133,-0.519579795173023],[3.14565379595691,-4.12369253680664,10.0049389899238],[3.44356095971903,-5.36727953913319,-4.70506980601632],[-3.71079357641928,-3.50163998314276,-7.94519499065251],[1.84336105749229,-4.50728860082849,-0.238634074399056],[1.48935240813885,4.28752912409765,8.24761498741104],[-7.96359372198597,-6.91633248988333,1.57871015015031],[-3.14789459860716,12.3416606572207,3.65462791846338],[-3.0134979184087,-1.19120289816016,-7.7358726617481],[-4.44616755986091,6.40898094715511,-5.23519185498864],[-5.01348423235445,-5.53634108642525,-2.63030240639788],[4.23640617731752,6.24675262745125,8.28588927673853],[2.92620705437648,3.94605399523327,8.21013051973311],[-8.73631057857557,-0.171192627150719,-4.52847217846953],[-2.42716534249834,5.20187317862466,-7.16686459151588],[10.1530291197793,-0.0428663806192211,-0.774541815212452],[1.41011416680979,-5.66637115345075,4.84929255554835],[-0.367981211449338,4.24475261070399,-0.58144615806209],[-3.14718480338329,9.99054203682942,-6.52843119647907],[1.52759001766209,-5.10414201477598,3.71669429327793],[-2.2739304243237,-4.72622405313361,-0.639549515415369],[0.650611319400554,-3.41806217590828,-2.78048930132278],[-5.83404009480332,-3.6808900137525,4.45384454026132],[0.873730333972198,-7.17702748494052,0.361021681715505],[2.24843876131793,-1.23403259709508,-7.63122971186727],[-6.0719917788279,10.9484396923495,-4.50331590175873],[-5.14145636964775,-0.380963304252797,-1.13545484429603],[3.08040890247313,-3.42947255550359,-10.7019695048824],[-5.02912852862243,-4.98767509794991,-2.23810494314189],[-6.54025906973226,-6.01938128265153,-0.485168425912712],[-2.90904071903474,5.35713515077893,-2.82964972483186],[0.567396631562443,-5.3776512496095,10.8264093096678],[2.97546875131726,-8.88488928103092,0.48232053249163],[2.06715768037202,4.67687524787012,9.06223283153716],[-2.22403677993725,-4.47414032855114,0.0145183956785315],[5.24333338562735,-2.38776689925556,-3.30929761388617],[2.36311452313808,6.68559605788615,7.18090208373769],[-1.53598087241514,5.04642896816083,-3.5721178898683],[3.84957062518156,-4.476122345547,-1.37397863637455],[1.03505808116914,-7.09642810346566,-1.38191470762738],[-5.4120847752147,6.37013731215862,9.00428752930484],[1.3915458001473,-0.0985851481574289,4.15580660518557],[9.8558960464746,-0.12645453470689,-0.877791479761441],[3.73246310411381,3.72848579722784,1.92367142472213],[3.02822556912994,-8.24805880383086,-1.9719540524543],[2.60841373529898,4.42639534424184,8.61980695251483],[2.09155087592784,-8.5442721175602,-1.01325140850352],[-3.26096256233033,0.366497853366966,5.09415186675971],[-3.98680051463437,1.79002611383656,4.33771956548476],[-5.91947651743374,-2.8094093672361,-4.75772630081431],[-2.09660894412641,4.53861128311443,-7.00773362938287],[-3.81205777187355,1.97946865220565,3.33771578602183],[11.7004158183684,3.57436816867049,-1.43145710771091],[11.6414299897203,3.66464301956654,-1.74948840415994],[-0.0461903500938224,-3.54894917818631,10.368699843426],[-7.92905711945141,-6.85659084514327,1.58611034801025],[-1.72697106974879,5.23157296844643,-3.2328631413878],[11.3454422794681,3.72753603252575,-1.12250001172921],[-3.61433773255778,3.19435685497853,5.85459443050533],[3.92633725136962,-5.3108985320425,-1.59134804578465],[-4.26589145839111,0.251102606557488,3.56924847867953],[0.722265223489215,3.25324341140396,-6.02074836298919],[7.48228033648627,-2.62820181142007,-5.06517237043736],[2.42656832330427,6.77768659442864,-12.1705326081447],[-2.17088474526849,-3.5424168262562,-0.78721516679099],[4.1687882789406,4.37755164846671,8.80618581282907],[-1.87842732815587,-1.32238687115326,1.31686176144811],[1.8499643393826,6.72040144617361,7.52355662980398],[1.46239283518978,12.4383916626389,-1.62590595666259],[-4.85944010689158,1.32679297209826,5.09538650003956],[-3.43258967380984,0.36025701582495,4.66208335945343],[-4.31606478140903,8.18887587296328,8.44938616705782],[0.803236435764145,-6.72442175180879,0.0499847284268609],[-4.58653982696283,6.24232518319997,8.50811290319205],[8.72792425097219,2.33584902174315,-2.0620196401169],[-7.05347917471163,-5.69815060668406,6.77105813401169],[3.01784668878566,6.68950140371196,8.22179201599423],[-1.29685729169136,1.47629801095677,-2.60949586847401],[6.04195927578086,-0.543514138620171,-10.0737014923058],[0.583315798924996,-7.55238811759262,2.39068441731802],[0.236723172265186,0.989503743246226,-2.00367412893586],[1.04956312911886,2.08955565528781,-3.48820236320855],[-5.03973696898383,1.57726597612307,2.49724244549147],[-4.42112535473064,5.4674762591906,-0.163336270217442],[8.57375452886857,2.2088257405846,-2.16263771136446],[-9.48308878267061,0.73356629303773,-6.07150620951761],[0.34832416947858,-9.30204053212968,1.82164012500044],[2.56089303414981,5.02526870380597,9.19550249077811],[2.43152500946839,-9.05964196707423,-1.96435533623509],[2.04180783930406,-5.38086691186963,-5.91701383841061],[-6.28083378698308,-3.92413838734093,-2.91390842748383],[-4.74090391933465,7.72782615029713,-6.52668925228206],[8.69432160806131,3.00169305721315,-1.19846669073532],[4.09925364446056,5.17715167367319,8.28041564189962],[0.882682674918543,6.40613804941235,9.14506930223708],[2.68348940344147,11.5524153892356,-2.97008638383857],[-4.30594604537457,1.78519352232024,4.26245867582065],[9.58703945093701,-4.92185745265308,-4.0843292386125],[-0.915802723855579,0.667022317913916,3.57347925499024],[-7.70984891721661,-6.40038928363673,-0.160628729380266],[-4.44202549904589,1.25609379166506,3.05991337613403],[1.05444141545909,3.32140951356187,-3.7066452538931],[8.84848168809087,-2.56843575272252,-4.07090681607871],[-4.79523842631147,9.61244205159694,-4.65513896605967],[-2.67945058643042,-2.96932970324522,-2.88160399069027],[-2.4118433450425,7.40728907816521,-0.498579156545828],[4.12158483422402,-8.74649462324245,-0.652645765247859],[4.17098484887676,-7.42919830593988,-1.19072537724063],[-2.98424660164961,6.51463815700178,-1.00605998958702],[3.08792171086304,-2.3775138252908,-6.34304391264135],[-5.00823943117202,-7.10009270234281,-9.97951103340254],[1.26906303307421,-0.548060021564408,-6.10431100016141],[-6.2268362625248,-6.31787331895834,0.2982908963077],[3.31817904469017,-0.406587627834202,-12.7057058285539],[10.1126735423185,-1.25514416981592,0.747242845313751],[2.63173531257218,-9.19105029627026,-0.729699305574829],[2.87892907454967,6.07055419272643,-11.8245846395195],[10.5335959268346,6.57262782724117,-0.810383939620134],[1.54868476882157,-5.60585749322295,-4.0110532128355],[8.91042537421525,-4.33025252668857,-3.59195097797418],[2.76159769115101,-2.37908788412117,-6.72665639514023],[2.70140209901859,12.1228876582176,-2.55884527553154],[-3.68233055956215,-4.64020119290459,-11.42291180783],[1.64115700717547,-3.57954685538435,12.2899015757908],[-5.22379482768124,3.95798387477924,-6.31372939105349],[3.09838665999009,-4.90194731178951,10.959253845011],[2.10760956927603,-6.11444256019831,2.49286894751497],[2.53777385399509,12.0197567676129,-2.93711396324486],[9.15561579341476,1.66798045035448,-1.21345622992946],[1.26163160202143,2.20355310661062,-2.04801886552656],[9.03273868703373,-3.68142313671446,-4.87405895363452],[10.1265161828782,-1.46446917305633,0.561870314256246],[-4.00333618525249,-5.56406719007265,-1.65845928638037],[3.2048532827626,-6.11009706141785,-2.31143482636283],[1.09072313200685,-6.97993590346638,3.13629493098424],[-2.79906767019722,6.97612852980441,-1.46507297304004],[2.5866434785875,-9.74167041590759,0.968830276284034],[-3.13723099811369,-1.03120698214818,3.85565722136336],[-2.45719048154003,-3.95999196364389,0.20152210600395],[-4.39709018736235,6.25671580878798,8.43551776727426],[-0.0818010072028477,2.50708863357115,-5.82624297722148],[-0.994738859918383,0.665787373710649,3.1451533557512],[3.00640818713711,10.6207152444695,-1.85474755149377],[10.807725627462,2.90261204944959,-1.49640949788335],[-2.45036311767387,5.20295633711633,-2.4168988352971],[-3.63649024450542,0.104942678564984,2.85284624477383],[1.99852508156189,-2.94437664189923,10.9265710681675],[2.73800252299283,-9.77759339509383,-0.98264340721886],[3.99158223872938,-6.51180929121549,-1.73164961223264],[-2.78524248737538,5.55625096269669,-2.98570502422294],[-2.94392984658406,-4.03172253926875,6.83167712125027],[11.8953668701827,3.43680869766684,-1.56813527453196],[3.28803644287873,5.00942788209871,8.37488663829171],[-3.25850843281215,6.85603660447746,8.96611318011674],[-9.32878896461746,-1.58075746059474,-3.86045856682597],[2.00066760349249,6.26457209927698,6.30023621426488],[2.10488647871152,-3.914566169083,11.8169218552834],[2.57424532424871,6.92938063456437,-11.9058410203769],[0.547420528117488,-8.1421123086803,0.569919112619841],[1.53794705431023,12.1730377833664,-2.2451834764791],[1.09970136220814,-4.80864320513515,-2.01238115196266],[-4.00848892193122,0.207076612996246,-1.59694341025292],[8.32047331369393,-3.04384598897957,-3.36352943175254],[3.22500681182758,5.56607083278974,7.86024672169895],[8.70987561491041,4.92696852752741,-1.3841241661935],[-3.661922048048,1.63097256358833,3.80068804860749],[-3.34070639139427,-4.75685780976924,-0.905392827806065],[3.39276972280685,-9.66380854665915,-1.21043944982328],[-0.325916736509256,1.607401864766,-4.29893251498007],[3.56693057325248,2.03865913574635,-10.3896218300363],[1.92615059489206,3.60898422955044,8.22512108811487],[-4.24731932867966,-5.58954712591708,-10.0230884198116],[3.73311839944034,6.00075039488517,9.03627821564276],[7.80578597128913,2.38599181777983,-1.77691977416675],[-3.55617492794183,0.380030085514436,2.01042690066158],[3.30269562711459,5.55539477156085,6.8318618001367],[-1.15610040394615,6.15260117760658,8.65072700239322],[-4.99131931778353,0.47143116721919,4.57805797360227],[-4.74070968748932,0.942924975717933,3.82189193590486],[1.28558514695043,-6.21160886073762,4.32339591073806],[-2.53370751756628,-3.19778471843251,-2.86791187570606],[-3.48854488957458,1.62448800987389,4.01745036291558],[-4.04962995092019,-4.37982064507774,7.01507250072661],[-0.258601894670941,-2.63804090136938,-1.20297405219656],[1.91785317172497,-7.68462076133278,3.11571431302685],[-3.47117044778827,0.732695794811346,2.52584805780192],[4.35930954155219,-1.48751842198879,-11.5407508351713],[-0.646277152929166,1.30183548458129,-2.27516544651792],[1.59824350485275,0.118553050649135,3.19111806581036],[3.28528041867578,-4.00301761470539,11.392903363338],[-5.92757222206438,6.99903460508227,8.63178306620566],[-0.0979139616429183,-2.45657184060682,1.78281897023324],[7.43340425635037,3.37490282099654,-1.66408775882501],[-0.552025811902502,-0.355260435852725,-8.10828394393553],[-3.65599019585911,1.44716305679215,5.01870875319874],[-6.41210073282613,-4.16773795298878,-4.13330504823622],[-3.56811874423384,6.39152221042429,-1.02758830300092],[1.98237667748772,-5.57225326347467,10.9646555268056],[1.44647443253698,6.71589851056775,7.64768092263691],[-2.46506049745059,0.11641287722277,-4.50906614076477],[2.55221670498553,11.1400395504475,-2.33095374090483],[2.82684483332905,-3.62223638588375,11.6415384227883],[2.78955421471884,10.6795645167759,-1.91256209520854],[2.67489991523663,5.8407133917164,-11.4448427297465],[-2.3824247724505,-3.47545551377593,6.40469406952434],[1.88684319606282,-7.72646107820713,3.88011269884157],[2.17903505320725,5.953928381287,7.06359037164136],[-4.99913632124228,-6.6146295702772,-10.2459264003721],[-2.59548419964943,-1.06674779835764,3.79826291022172],[-6.36567213212183,-3.79068794072985,-4.36032428565559],[-1.30082562703933,4.94239549384098,0.792341860164199],[-1.83901953767997,-2.7815634576873,-2.39170087242358],[-7.89301996254832,-0.720219534452669,-4.76147132760101],[2.24129450724907,-4.23954679309382,10.3973930709749],[2.71644034573783,-8.06910058620738,2.34277857782975],[4.0584839448946,3.0421344626595,1.94173440333229],[-4.09097397351465,6.17309684234698,8.77591494399894],[-5.2440570666179,6.2750053878596,8.94434166868983],[-1.15868353821782,0.333125598727588,-7.16608882094708],[-2.51356616246577,-2.74618185513288,-0.561199520977776],[-4.4378169169857,-4.95952391485618,-1.51854953637585],[-4.56084339709586,8.07749341202781,-5.14290111196403],[-8.2864299925861,-5.75371132883911,0.479315493790006],[-3.86100575124137,-0.786395416779353,2.02226257240341],[-3.80424885267953,5.07289518355199,0.682985087389167],[0.817381086727638,-3.99564895646109,-2.2845227465826],[1.22551664353162,-6.38164825293025,-0.310401789760389],[3.79116884378692,10.6176848468469,-1.56657441980656],[4.12250158127708,-2.86434782248977,-3.93330594203987],[2.53788572961866,10.8298852752508,-2.57376325627284],[-3.76036932764894,5.14566202687232,-2.71136431465584],[-4.1990102162534,-4.9822596959456,-10.3374876000496],[3.18919059495628,3.77227303556395,8.46436902899615],[-2.03288850062055,-4.34936916933221,2.13440159935154],[1.11146494140927,-6.04354323569497,3.90767380491502],[3.27979193059851,-4.15339441450404,10.2459797415989],[-5.18483022283727,0.234054744588344,-1.49784104682478],[-1.95307844962318,-0.84515331937033,0.939994312071696],[4.96141137239965,-3.07754248112156,-3.94944112983696],[-1.0943298827177,-6.97765574443554,-0.69488492374811],[-3.69965286580446,-5.80858103815007,7.4541725404742],[-1.2543506040046,-7.62755065082255,-5.56691944485414],[4.03919942688765,2.05202362595087,-9.25640354911661],[-0.245607836999147,0.253113314113614,-2.75080099570561],[-4.50957019516905,-0.124809277942856,4.21798137994011],[1.29774899506412,11.8565022565929,-2.158086362056],[-5.15687882000101,-5.12554555356891,-1.49277432950748],[0.773142346485824,-6.1226234976543,3.08387859690434],[3.55613843832652,11.1906499030091,-2.50117277806475],[-2.28235952477706,7.02047029262861,-0.5869357922427],[0.149692324061733,0.274878797768902,-3.05044768678906],[10.4532080996893,2.68515693757124,-0.821017236245176],[-5.10467543200531,1.09630674325478,3.49676390919289],[2.29959132635163,-8.44841298318333,3.35870433057419],[-2.83185223647578,4.74609291452682,-2.70866321582423],[2.29962078483715,11.8950933805173,-1.57371301757574],[-4.89548437974627,-6.58699396452185,-3.02948920492381],[-5.6004178506034,-6.66663919680665,-1.98501633937977],[1.21503268829901,-9.31638954843328,1.78364407130229],[-7.28812168733104,-6.01461924911089,6.13340776983121],[0.801392166927904,3.82701107416205,-8.82085954676008],[1.10728481499323,-5.98856944043099,11.2036863454684],[0.971996341462298,-3.82205181057657,9.91443318470371],[2.29293061194102,6.16827602268955,7.31471710942117],[-0.54105473438996,0.248725507276578,-3.21625407554365],[-6.00647155295436,-3.27069391405984,4.6247385249925],[4.31036399374913,1.92668457683452,-10.0323808151093],[8.80627203673357,6.61028144423869,0.0165719872006839],[1.556325789052,5.00406191544559,8.36974182441551],[-7.14756366018514,-6.28908653065698,-0.348422512217622],[1.88446569227418,-5.68673135684811,2.8300930855185],[2.82340527708957,-2.12114270193185,-4.18311799905545],[3.67639201804955,10.3576767318342,-1.59813568767482],[-3.43027773966644,-1.68322694789901,-4.18427917146215],[0.491187624543074,0.108700436797889,3.46031297636353],[0.0532515157273235,-2.68168080778594,-9.70526702330399],[-6.50285816576489,7.23516520173579,8.5926031572354],[8.4542786022847,5.99627008065576,-0.755201820472062],[-5.3440400142978,7.82060812536258,7.62767113997817],[2.51617808900191,6.63053733669513,8.00206993224457],[-4.60693831282011,-2.80468501629787,-2.96406815019074],[-3.76608243446647,4.2108303858567,0.212305594188198],[-2.42805657166609,3.89816747477219,-2.14627662810877],[-1.22348046564075,-2.66758880963054,9.68549920876828],[-3.63887102358074,-5.3449795004886,-1.52157996673433],[4.54237599123155,-6.21152907366348,-1.8412699174087],[3.79251494141462,-5.61373631575914,-5.27755216469705],[-3.29262576439078,6.27493766548388,-0.103479418002794],[9.35876473952372,-4.39498410510409,-3.94114828166142],[2.41559507633919,-8.30167970548174,2.88250905092676],[10.7893187996566,1.40346093900249,-2.14286429362251],[3.31515966640322,-7.6285547724705,-0.833565963919729],[2.55213104243715,-3.41315676773083,10.6520196225994],[1.21235221569311,-4.07494919783805,12.6957143555017],[0.840205641799929,3.3284448599556,-7.70502678223695],[1.98945900362863,0.387991576391771,3.45550756302066],[4.49777342016957,-5.68049973348479,-1.64011628565805],[2.76665019151909,11.3243608451601,-1.49310602054159],[-1.99832979204294,0.0846335344661464,3.31888386683588],[-1.53909979143207,3.48653326595262,-2.23825097961935],[2.07261174430587,6.05451593744301,7.23719403607654],[-3.34143627880632,-5.73717250077496,-1.76500543016069],[2.04820502073331,-5.61825705775552,4.39084372532364],[1.03030127067965,-2.64423249079175,12.5426931883489],[1.52796647021128,-3.80986014882186,10.9373873915369],[-1.23961454258684,-7.38687996072911,-0.646700603702664],[-6.53898739100227,-5.45755092872665,7.55836388960669],[-1.14937546908218,-2.63384302670585,9.60655031017163],[1.33733288144276,10.5869761018808,-1.87559559977774],[-4.8197454517748,7.18887672391943,8.14015688386894],[2.71344434116886,11.305214522974,-2.34041432045283],[-4.20018707244677,8.4953107626945,-7.0199902163179],[-0.372982829536793,-3.00702805262308,-1.56680626916629],[0.0476791863110135,-5.64783721921051,2.46071466058063],[0.6471644115159,-5.25913425392135,4.16299982680351],[-9.37214236468018,1.3473126955128,-6.29556399908078],[3.1449073721304,-9.63377576636445,0.902401566201488],[4.06204165612717,2.0767422075293,-10.6589344592686],[1.57208222129821,3.46521003405124,-4.31352798263369],[3.31694434095439,3.66840845626624,8.4896202372546],[-5.03738129064583,-5.8908756565281,-10.0932086224154],[-7.18200976150532,-5.13908698400673,7.26510507248398],[2.28597832814076,3.67560229348751,-6.28766654789355],[-1.94213221016055,-6.10649741796891,-1.30861920322011],[-2.47630724698536,-0.285925824288935,-1.83967672037363],[0.12288707708337,-1.29767628927239,0.625247438998767],[0.770350225947954,-6.24997480487186,2.65824118355296],[-3.92914008970375,-3.24076291354577,-7.28459351622937],[3.20719434597651,4.17853198173338,8.46342013878272],[11.1969886818633,3.84085789749008,-1.71393049577741],[1.53441855774155,-2.70823584671033,11.9591879895601],[1.19685870992388,-4.55928360812745,2.9334895715473],[-5.0396923801765,3.01896478754797,-6.64760245376832],[-5.29359434486762,-3.24845995551042,-4.51008478179936],[-4.5672896768383,0.144821691513949,-0.903985779425434],[0.178021627499956,0.740805061704182,3.09316975841773],[6.98728664777623,4.37435769822381,-0.82250302782166],[3.05303419316467,6.68307731422607,8.23842811156339],[3.0587787774324,-9.7958972317995,-1.61064630665508],[3.28573545827927,4.0943501190898,8.25421907051761],[-5.78025686750976,-2.67942890107411,-4.38695108383681],[3.37595825662325,-2.35899069484318,-3.97883353486573],[-6.60610829672647,7.70531528711455,8.01375339677454],[1.76782922041965,-4.76380386328241,10.8564150976561],[-4.49810127696903,-6.60859179579818,7.27909447406434],[3.90311415952124,-5.66938924353711,-1.356463558253],[0.0885933874230521,-7.68730983681097,1.87896538662655],[-4.07870183187745,-5.77791819739187,7.71801690039788],[0.477699957704042,1.44678697986758,-2.31072748764676],[1.50074377871667,-3.61297792432426,12.2803784722124],[-1.61079536921714,0.512821773144826,3.009613524026],[2.49004618657128,6.33479816064186,7.9438552685739],[-2.00616150068752,10.6337005626957,3.40726833781],[-1.92557954641598,-2.56079115895406,9.35541085768055],[2.87781428875193,-3.19776026661274,9.48656129493247],[1.39350441278608,-1.05722747972855,-6.54300584537487],[-5.43794675860374,6.11545757997701,8.66808969725487],[2.20743529910524,6.00150515644586,6.8895114428905],[-4.50674084433026,7.23336369629684,8.81263925128496],[2.62846353887262,10.3993037253493,-2.13346218364019],[-6.16296704761812,-1.72494281657626,3.70596789212707],[1.0561441505693,-4.60374572298393,2.62109025763686],[1.66977433700074,6.53625871640139,-11.2585227917203],[-9.39812073958425,-0.738537423130093,-4.10670951648679],[-5.37147994278022,7.2571198903155,8.75654940323938],[7.3570231371903,-1.74605253293106,-10.9218745629767],[1.63719764469614,11.9467254973916,-2.19379192448404],[-4.87003926736842,3.33022315179414,-6.629037916258],[-3.87602607013481,-2.44695143250998,-1.37955132392237],[-2.86859024213936,-2.25957179323057,-4.79811472778991],[9.86288259944991,-4.64370595878986,-5.47943745476722],[0.727926240251209,-5.63324457456425,10.7773118005834],[11.393062273113,1.36725649660638,-1.37741381596322],[-3.85279443957765,-6.73852100945951,-2.16231858612121],[-4.82558260213057,1.23510048882225,4.75004241984737],[-1.47273217971339,5.0211434085245,-3.16231377931266],[4.24429102348224,3.36704023308608,0.768845687802587],[-1.67113385624737,-5.19527800899639,-1.95608058795342],[-8.82022819601898,-0.280044136463507,-4.88802853237674],[-3.92271665614791,0.812836435480653,5.12648396855651],[-1.51871619071437,-7.48709488439366,1.18163259959555],[7.5994030545924,-2.65690095601799,-4.77946427502701],[4.53278942986739,2.65046684706372,-10.1856443164004],[2.7737722131228,-2.796635829108,9.43146379299],[0.190791290983368,-2.92587840060608,-10.2296536709537],[2.50408566277537,3.74857426771479,8.47976131956889],[-3.15550773972971,0.703390898866046,4.17332241300893],[1.59414983321338,-2.51102249269484,-8.26360848773956],[-5.00723158686659,-0.206487969873417,5.08268149651402],[9.70295017840552,-4.1011143815298,-5.51901708321645],[-4.81396097217844,-6.07035172478882,-2.05474123437692],[-3.96804841015739,5.16184081603125,-4.73982084895658],[1.69349119659867,-6.10807747273053,-10.3621850096706],[-4.77431713694309,-6.34490404766403,-9.56825496478463],[1.58465193789867,-4.76330254162413,11.4835428950411],[1.62609851153183,1.76103214370301,-9.0049384600288],[1.18870353821246,3.20866678864733,-6.60863918419595],[0.815270655115515,3.30659385229665,-7.21084561240249],[3.24066176520811,2.85993349887502,2.80591721529526],[2.31391066789471,5.74140001496533,7.02714814090037],[1.27962573410488,-2.48256867601815,-8.06621902317106],[9.93304221210838,3.31984070033688,-2.96730660111541],[4.39489640671407,-2.69575761100147,-7.08876365345764],[-5.18772341935405,7.44603844611868,8.58892455368524],[0.647277862128537,-8.55218820861033,1.62870185727579],[8.25932707425281,4.27393747654914,-1.44965635159377],[-3.11233663097647,7.09015705817299,-1.10779865093037],[-3.34632753519817,-3.22695107548168,-1.14721166501973],[-7.74413399424905,-0.16445453385779,-8.62329325584589],[-4.06247674967803,1.64210261668634,4.14295916903462],[-0.0481448427194746,-6.54011987302333,-0.871039569051043],[0.657464264068531,-3.43780134061079,-12.1937782320087],[3.91347116340913,-6.29316339401894,-1.57485684769349],[1.87702257556696,-8.95329289748784,2.4220101872415],[2.18336595563979,-10.4781013622775,-0.912897380848226],[-2.55914521579383,-0.351936570727936,-4.94733916745329],[1.64828345901959,3.71248009708908,-5.73519731336037],[2.95414456005114,6.0540442754262,7.09686577231654],[-1.97752825272453,-0.331145789537313,-4.82209934549728],[9.97974089330874,3.26508357991868,-0.177713823753522],[0.80531114678827,-5.24464870030047,2.04865389139812],[-6.22623163833835,8.38969511755904,-4.49020777474756],[3.05210052665587,-9.7332577007079,0.46359282902304],[8.80390130151596,-2.55658068171706,-3.6613278636579],[2.35225505229178,-2.92429663746439,-7.47171836805873],[1.87167877786318,-3.53662603131757,10.9398788928806],[2.04070214002582,6.17471904401285,8.81026629561942],[-2.13039753836306,10.9619455496188,2.89390915466471],[9.32568548492557,-3.80289144179177,-4.47983016828755],[8.90552513075053,-4.19072986433153,-0.831243414149803],[-2.44490951500086,-5.22757299419148,-8.28779434847136],[3.33075178423944,-3.44689486630382,-10.4699385386969],[1.94327925893845,-8.53890890973323,-0.236600302356917],[-1.7968717755144,-4.15997129964695,2.14503885605335],[-3.64992432250563,0.764904372434229,3.35865659450288],[1.79109121419013,11.129979482095,-2.35176323106661],[5.56740726120837,2.76170788801276,2.04715170752492],[4.22452564398086,3.45556973766757,0.73709331381357],[0.289848137515641,-5.01157571126532,-1.49662312627284],[-8.09802160248916,-6.22538998251434,0.0936128526664091],[4.33602558222997,-1.4183771828201,-11.6724550757844],[-0.283394402471054,-5.65441944237777,2.00371979039255],[-4.0924202841334,0.975252939354242,3.78839792858033],[1.11536151474798,-1.90760983690836,-7.60202195293819],[-6.76666849518134,2.9047176513983,-6.14503247910824],[10.8764609808079,6.19052264142082,-1.00972496878717],[2.35501360745531,-6.03299702527609,1.2220311640983],[2.83894993963881,5.74538646380606,8.10525691407347],[-6.11935522368176,-4.45089259497588,-4.03381449486188],[-6.15174855893583,-4.17158654182736,-3.878722147864],[-3.21443452903557,11.4119290571316,3.66267150254517],[-6.33444933828124,3.0269901884025,-5.69691106854317],[2.46877841786215,-5.39892639442132,3.63155085212819],[1.58879328066002,-3.59754981137824,11.89024282827],[0.880474546549077,1.95276766373283,-2.4666027194157],[2.84690610456379,4.08214122519162,8.80630711354285],[3.26359806721125,11.3273981098928,-0.787866691345999],[3.6500446845872,6.51694123337081,8.75779957200955],[-7.52445172997498,-0.592583541157615,-4.55812277961251],[8.88166166776588,2.31285824093326,-1.04780570659967],[-0.356297110918815,-7.19416867249226,1.0463315521731],[-4.33520426313894,2.4378891889067,5.14767672946996],[-4.09254187881067,-5.45439822102505,-2.25583866244017],[-0.0684761461009479,1.04599947613426,-3.35509882915493],[4.04367755588229,0.568365528508779,-8.81959143521286],[-0.517610863629656,0.293799450282255,-2.75558709346836],[2.70918841933755,6.48649444535945,-11.3818209174633],[-2.74353774850887,-2.7281837848895,-6.71752221212816],[-6.2159865170245,3.59399347470482,-5.54084782486581],[-3.66628512509395,0.991952601746952,3.04383994728575],[-2.07911597869045,0.0429327147207385,-3.34495452768922],[-7.15400299901707,-6.03178135973991,6.47938680970782],[0.323877675664276,-6.97486116371778,1.54927014278066],[-2.4850837004501,-3.07317879759364,-6.68363337330715],[7.37682857038479,3.73833685788518,-0.604749377889472],[-6.24168210878646,-3.48972315013291,-4.72133877215541],[-0.430653477065519,1.55523279977013,-1.605721689411],[2.74237406832512,4.11695571761376,7.63804627785441],[-1.26225857460367,-5.04291648973361,-3.20771673733283],[3.4887166365677,3.84398410212957,0.578615753292771],[0.192517353190169,-5.50339874404144,1.53623325715166],[-4.10988168331388,0.845375848173308,4.30808350308841],[-3.79306241115465,6.75196474613743,-0.806707762087652],[2.98578501852942,-3.85017070172575,10.9017753787284],[-2.70246906983135,5.50907646083059,1.10843708105374],[-8.12643152891771,-6.74367068409951,1.23488620800953],[2.98413976221758,-5.20128257912897,-0.752657029220751],[-1.40616781819214,-6.59061681155316,-0.410095837581764],[4.49055313718109,1.42560598510089,-9.51009862241933],[2.19046942949878,4.64023957346707,8.89808466956078],[1.04314097178727,-9.53553033308129,1.03591038064925],[-2.34529889303048,5.72698316694316,-1.20696726186377],[0.95851294419816,11.854829762156,-1.2950747350722],[-6.235545002719,3.58272189030373,-4.19013091950096],[-2.39211724996641,2.95964087385462,2.75327763050121],[-2.13147753472834,5.52281655679285,-2.97859263779077],[-5.38176435760944,9.61099590032165,-4.11436489884113],[0.000573341955747764,-1.17533773044271,-11.0981934600412],[3.86048536130266,5.99368891981846,8.3334680431054],[0.883451697734919,-5.60328479544633,3.47672933742363],[-4.51401242141613,8.02918026865969,8.71893380259776],[-9.10167300398683,0.370005780408606,-6.28566515046596],[-6.04390834829579,-5.80201895084527,-0.851158650791631],[4.33988666417148,4.78829835620619,3.16864228202832],[-7.85050464647299,-5.80155056470602,0.341334277088775],[3.74449180383443,-7.48514194160847,-1.46390062424981],[1.9220509757954,6.28376773799168,8.95654737243113],[1.38177428272312,-5.36662534988278,10.8727514209197],[2.91152896523998,4.55138984047345,8.91816786941613],[3.14584090419341,-5.83701714083002,-1.62983290450254],[3.15255638082398,-5.19482233788579,-5.5495446821899],[1.35303239031968,2.86042972408042,-5.80042676878134],[4.02721622859047,4.94684572207062,9.25821815053185],[1.78970698594302,-4.58409345574585,4.20658483708862],[-2.50275004100491,-0.944913552178881,-7.2956222809299],[1.06812979289718,-3.26771971384611,-2.69309881603044],[-2.55079696556972,0.741696810472257,3.5186757229207],[2.70103411860751,6.07794759901225,9.37147717955604],[-4.07928964431866,-3.39111951467981,-9.07276958180615],[-5.84770017444498,8.53513974279602,-4.94489447107058],[-4.48647110988242,-5.1321555585239,-2.52908079285062],[0.694648029312626,3.4640201806349,-3.77658395390996],[9.20780133027763,2.73406778848329,-2.41898200905722],[2.29814346260291,6.09130482953417,7.68115246612003],[0.0070429898234794,0.897701163104129,3.59133036321897],[1.74465881797216,5.7703227484637,6.75359536113041],[2.81137444408002,-9.67630160089342,-0.717125167613107],[-5.31505575244643,6.52426331785667,8.51103532266811],[1.26920774573074,-1.57175787159414,-10.6984386037067],[-1.91408097204252,10.7721096858399,2.78891697816225],[-5.48768150417152,-3.23586634210272,-4.96954263109632],[-5.30477140060903,1.41588667184741,3.64025002844318],[11.3405780767424,2.05565686285077,-1.28731466876846],[-8.34308062386107,-5.69415232328574,0.771583622501679],[8.85009088295591,-3.57960772721149,-2.58426464232028],[-0.8045474104195,0.675032331701992,-1.66708031675148],[1.87488284122392,-5.85902700234829,4.49262198066181],[3.25845292847982,6.60554610660233,7.54409236996232],[9.95533889452219,-0.581842939806427,-0.0972418212690086],[3.97802826847816,10.4007829916022,-1.40296804629606],[4.91822209382479,2.05933385277083,4.45539243165654],[-6.69770818277761,8.88349555658656,-4.57312808297743],[0.38019843295956,-2.6288225922399,-11.6910438357519],[3.60067308843707,-8.22444336798865,-1.60132764358957],[-1.95521150862422,-2.22182713840495,-3.96976287900989],[-5.17261654187945,-3.52927877334549,-5.19251651079882],[-5.72784617645236,-4.57396658853007,-4.19713787923022],[-4.94325313129488,3.29396000768044,-6.9681244632507],[-1.80166805899354,-1.31044870578558,0.670808653595591],[0.891002081116788,-5.20143398566502,4.72566625924442],[-0.284089534044507,3.26141285099895,-8.76548728217795],[6.80810257486199,4.67463041966846,-0.0203139955226371],[-7.20495459966994,-5.88476348783222,-0.0778021546966114],[2.00366820514149,6.19258259361598,8.99460904959333],[5.0489062506342,1.35613217563464,6.38998163600555],[0.662429486978921,-3.33663619395738,-12.1949059900134],[-4.28422576367616,2.06174559525903,5.42867669315232],[3.13182544560965,10.908662045318,-2.03561081039122],[8.89324874319497,3.32100041906031,-2.6914665655994],[0.652445997465787,-4.92069173957728,4.38746675993097],[2.31923191302972,10.9905255659058,-1.97910704532275],[4.0218541302203,-6.94329566714396,-2.22419626913741],[-3.2940243152251,12.3878985343684,4.19284122004467],[3.41617580539963,-4.26446107971482,-1.60946981408689],[-5.30444050206693,8.34593998277884,-4.89872284241725],[1.76973559928959,0.0897731506132988,4.43013389645142],[1.79859314263009,12.2836638779139,-1.68640508626058],[-3.67867934866406,4.31174391017754,-6.96522805866025],[-6.75020579858051,8.55447416387576,-3.93365157522136],[1.53236580488044,3.20558062222984,-3.79891786482445],[9.44134874150846,-0.029092468754925,-0.604302242813288],[2.19362637251437,10.7343589444646,-2.7057855756713],[-2.49313575102858,4.83270996376811,-7.26630629117848],[1.37566398377293,-7.04332645876795,0.131478449359582],[-3.73321277919466,1.04507703757232,3.79631095180834],[7.97541680281497,4.53376630059156,-0.537770376998725],[2.76617180061651,-9.17502692466498,2.04890801136357],[-4.9026604334239,-5.34601106617984,-2.62243564376366],[0.750810464178805,-7.97238085876609,0.523123289009971],[-2.28320717118923,4.08753431159827,-2.46680270576118],[3.07323134304698,11.5842941470336,-1.00266260242126],[1.64152907100816,5.6591396433246,8.50910174979],[2.0972982029057,6.39867447810259,6.51746422108904],[2.39733249105119,-2.23917998232571,10.9164277436518],[-4.18417883789102,5.87513752666561,-1.21291267084583],[-3.03198072276476,2.50153045534138,-5.4137566479533],[-7.31030505920206,-6.69635644266739,0.908964821689626],[3.01051701291434,-4.78182666586597,10.8296791631102],[-2.43549276374606,2.53351312222571,3.09127727518611],[1.54217422004387,-7.81717115303468,1.88629999509645],[-3.99835727954521,1.49916723093095,1.97402370897935],[-1.89598199119065,-0.512967756640907,-4.23205415754952],[2.87177320838903,-5.13044580154279,-1.52192186091924],[1.46569049995462,-1.31693621967468,-6.8051256302968],[2.75474823475993,11.5340079224459,-1.61812837544825],[-2.39783575493975,-0.40646093267379,-1.72182782771463],[-4.20059786909002,-4.27945331945493,-1.89464871763308],[4.08070027671495,5.18106580147795,7.40584460245406],[-4.65820897500256,-6.842779118317,-10.1976204402517],[3.04031725317146,11.8192911282202,-3.12242615604851],[-6.16759718242888,8.08936628911019,8.5093011558926],[3.69565577647816,6.42537984066929,7.90248353539401],[-2.0106947340114,-0.111693594856041,-4.70529693865508],[-1.33468940686228,10.190623263182,3.2479381723281],[-4.45597630489506,-0.449970707367555,2.18643967540265],[3.15079155459886,0.0782268015780532,-11.8677685924928],[1.09994400329861,-7.00864255882372,4.33415544525765],[0.390210211492893,-8.58163230556205,1.57061982385583],[1.95371348043556,-9.28644854933834,-0.805061341372272],[-6.33222914217579,7.1164600533274,8.09601327209882],[4.39432248596253,-7.73790447583902,-2.84895910853975],[-9.14180700937074,-1.51601445061405,-4.84278708632121],[0.106416602960003,8.52064105056206,-7.97175638505429],[-5.27386616613768,-0.074380889840806,0.087674500483408],[-3.02100998562071,-0.699511436184574,-3.69999651324917],[-4.42532729540233,-0.293809592538882,5.12783348510732],[8.7702783118886,1.50642875315521,-2.25102078996169],[2.80992499753079,-2.45216583318536,-6.58056402703601],[8.91977492696498,3.18651694150412,-2.22252783002638],[4.92820790386416,-2.85808781530723,-4.09559977656249],[2.9011669117969,11.1941541092658,-1.88621860625245],[-2.13316702335761,-5.82523069552957,-1.45615298598623],[-6.76632029957551,-6.64137676088888,0.403397846528757],[0.750053046133586,-9.02314832509917,1.88668888977994],[8.50420857309597,2.96699418331925,-2.64289163288675],[0.012616419630206,9.62348487005093,-7.88482619450997],[3.60276253663533,5.59403066702439,8.85282275013715],[-4.83420173759469,1.88322868321034,5.360299924712],[-4.14521040376714,-5.2633292309344,-10.3108837431487],[-6.05083148465678,-0.968679017220878,-1.06710580654035],[-1.25204220477225,0.724162409137487,2.89596216665292],[-5.4967533992342,1.21599873014146,3.81215117954577],[-2.36322906271158,2.93988258974744,2.72323905796116],[3.44746581549657,-5.04820807613805,-1.39140687899581],[3.12264983338932,5.93668155038523,8.24083455223889],[-4.73528311124746,-6.06830125563449,-2.0980955017225],[-3.188136251654,0.469672043856374,4.14052213737577],[3.53326244559884,4.29572448996319,8.08462808806032],[-4.05674055484257,0.83194743979463,2.35234421903648],[0.339673621131208,-2.98245638835594,11.2372469875506],[11.4326906268669,4.45154555212266,-1.839462078026],[-7.5200752270423,-6.23862910504142,-0.294907143791271],[9.5581892318145,-4.49837795610746,-5.36725711968741],[-0.491999983084928,3.16830907726081,-8.82409227505506],[8.58082066621624,3.57483966822623,-2.51031260309292],[1.609339373732,5.80476135941946,7.01833427699361],[-3.08766050644184,-4.68236307947402,-8.90994303947056],[9.27083552256175,2.6002695486561,-0.859624241919141],[2.88875746167739,3.91745446257705,7.68191259318796],[3.28114462472362,3.69909339813135,1.40295970585303],[-1.37296062049358,5.14737893663987,0.142494477060842],[1.94403956132398,-9.91252605114119,-1.24377471911036],[3.4725857005958,-8.92265279042199,-0.131259117596094],[-4.01387525422389,-1.4061042783826,4.22436121210261],[1.84440301214241,-7.60702158870954,3.95393046802338],[-2.37861102189204,-2.7536489526152,-0.198962086007099],[-0.403789788431002,4.31104380465764,-0.191627126606296],[-1.28022391343978,9.72299327506573,2.43619674119937],[-3.25574540877676,-6.19500482923042,-1.44861895626555],[8.22189806452295,5.92013338528056,2.64792997892842],[2.1813012522507,5.53702790093174,-11.7737943670595],[1.54388060108136,-3.67629870061235,13.0221357210817],[2.13082246354602,-3.78820567798419,12.103732466141],[3.66500144336368,5.23041553906789,6.64923838758297],[3.80898468451072,5.33619802074799,8.62469019298616],[2.7388802698773,-9.62942603673336,-1.87689415617274],[1.13930565812361,-9.5367127127663,2.2857285233833],[-0.0464903550791103,-1.47141515033337,-11.2737143732452],[-3.04329147858409,-0.992198870582248,-3.74791032267791],[3.40469608967461,11.1400971371489,-2.12314027877893],[9.10080536791664,-3.66888107581568,-4.82114214912238],[-5.28276003923375,-1.48638597531829,3.98726077126843],[2.37909281057426,-10.1577480849783,-1.6582281017622],[-1.20235647823231,0.309623172909368,-7.21132243405341],[-4.03762446278667,0.360699061799698,2.37999094532776],[9.38817195667985,2.14975646128029,-0.842320137247145],[-8.94825328015001,-1.37998866850199,-4.78515945738954],[-6.0444803161071,3.81628406472721,-4.44444515730415],[1.96573403609282,-6.80680931146064,1.61816950481031],[-1.13282697446054,-6.6872649497818,-1.43433075584943],[0.0988776835732635,-5.75113309773679,2.85988576259485],[-2.48534836437213,-1.26887875973495,-3.7448074196794],[-6.25086431675151,8.27580653746587,8.29658323029924],[-8.83356461845603,-0.221175155013383,-5.52911096489513],[-1.97502862644997,4.89012375768645,-3.19003937136469],[-7.02071296577876,8.63337832123723,-3.92926625913682],[1.90183328926832,-4.31833791483066,12.279214866228],[-6.29909416525646,7.01934952217715,8.89346759079794],[-0.0920061551751864,1.12193641488365,-7.68566431691903],[-8.37949094691575,-5.71408794794355,0.0993274857649352],[-3.25383399603234,4.27644000686561,-7.34781757404062],[3.73042195876555,-5.48715463005757,-1.33930097480073],[-3.68210997304301,0.909408531477667,2.56689377658896],[6.02200426182234,2.50598637405743,2.43302001681717],[1.28323621212468,3.95932885081254,-6.11232074496866],[-3.25242859519939,-4.91579350607671,7.20663825795735],[3.17064710101691,-8.68287659949094,-1.97947232929979],[3.57286322577375,-2.68724657290701,-3.24327725575676],[1.26385609877727,-4.94061652408709,-4.97261926430967],[-1.56355964881286,3.03524450433919,-2.06573454938153],[-3.64252975774133,-4.64443383449894,-1.25861974858623],[1.15573398132668,-6.97148215061227,4.44318360351044],[2.28808829548539,-2.85234617701364,-7.74090566326048],[-2.16635584139993,-0.584527855678723,-4.89803089591944],[-0.611559450318146,0.588252858558664,4.15098404115956],[1.17536404615093,-2.54935119565352,-7.77749594464115],[-2.17053196083553,-2.46249121596096,9.09867373073079],[-8.06039682084906,-6.28879676730373,-0.104995268365486],[4.04647148601453,11.2521057908879,-2.10306498804756],[-4.42314670645752,-6.36408186166247,-1.49123890737022],[-9.71689964858035,-0.699878715053885,-4.33503438569595],[3.60254200360101,11.1698755349808,-1.8282167375818],[8.59086682121686,-2.26083090319009,-2.92411887578625],[0.681500062306,-4.42837546763083,11.5745096035086],[-3.76424068990188,1.43292454479017,4.13304556539443],[2.62242968069603,6.51306492322058,8.52871181938706],[-2.14819057053731,-2.39057608258404,9.06331707815879],[1.8271529589074,1.30555840583305,-5.42273785747664],[0.613881538960778,-5.65248337782807,11.15383394719],[-5.98412452737596,7.33849253593318,8.15413580950528],[4.28497643760338,5.97108760471811,8.78035653321579],[4.29306992046073,-6.14695439574929,-1.88409876027001],[-1.76202339870852,2.86584431243258,-2.21469289774927],[1.7953648973519,-4.58679381432887,0.451630561919377],[4.60263252145766,-3.23127991035653,-4.35406528413311],[-0.483124861480138,1.44085749803664,-2.07833498444682],[-1.19004261213901,9.68504889859214,2.92077037750765],[-0.340051679310213,0.201009914876328,-2.63168699095276],[1.96839169937335,-9.33180378448139,0.672699430909472],[-1.1716784920539,3.51961318952496,-2.39272629428179],[0.121875286474396,0.0463166287570754,2.83372550505952],[3.55348970928726,-4.57622931061254,-1.55513520706907],[3.05821484108882,5.91137334240964,7.30914406409412],[-1.74237608308774,-1.78614141114637,-8.42550112271963],[-0.940824237188388,-4.22211532271492,-0.825957495260753],[-0.98013298438084,3.31587336896659,-2.68310393257712],[1.24007344138894,6.50308993807918,7.82124925203368],[0.412329040030317,-4.78643906900267,4.19798580598685],[-1.73419547750254,-6.66938154443114,-1.85270901826186],[-4.67708989077811,-2.13518913093847,-4.55738021652261],[4.57900698421949,2.9415901649564,3.7122913274102],[4.26700871136025,5.38416269399544,8.22805211166501],[1.16358969619544,-5.49075257152366,10.880658814073],[3.45524142178924,4.37414795749589,8.51074584658024],[1.03478196449268,-9.0697066188363,2.80992963478559],[2.1957243520756,5.02011888885363,9.05582675250275],[-2.41306016273308,-3.36979253666686,-1.34024973503628],[0.277003366771004,-6.4197434225194,-5.76450753200619],[-3.72333590020043,5.46938192420328,0.069214766257267],[-5.07948359715534,6.44756884943528,8.74141662900191],[-2.61224656615148,0.563925121772053,-1.16810683566875],[-2.31278833938244,-0.464611451211951,-3.54460383049604],[3.39615868048803,5.85524540638825,8.47463767941785],[-3.43612745665651,0.0707215081041559,5.16980717150845],[-1.73217013735878,4.00110876408526,-2.55124808836238],[-5.47690137431508,7.64020503818243,7.85831267889828],[1.24680889796048,-4.04715306010038,-2.47687485918079],[0.702205690355185,-5.86628852980677,10.9531967732024],[2.19669697102953,-10.1097443149192,-1.75947929677615],[-7.74789743462825,-1.12341978138055,-5.14002766856262],[-5.05633837266874,-6.19253022520286,-10.3881691891736],[-0.168487358618075,-0.871566178154272,-11.0701547459761],[-4.11555978139121,5.07270338721503,-0.24003149152841],[-0.137548976527641,3.56799965056383,-8.87590534791193],[0.715422923024521,-3.7739340813459,10.048079114611],[-5.70479103768147,-3.40757012599107,-4.48707487522859],[0.201503766761078,-6.57121502171236,-5.90632150056472],[0.735803821550434,-6.39895476070712,4.70906283122625],[3.48023383013369,-9.55438283813143,-0.976378382227428],[2.43896866062267,6.21461190370387,-11.6314705776788],[2.89785526758746,11.7232700491867,-1.2573239003935],[0.704749032387604,-8.99725437526082,2.18478031195209],[0.144577328021311,-3.25723816673943,-12.010535240191],[-5.20287143600414,-6.60171438841395,-9.9957091631031],[-2.62098366683634,5.84973759294134,0.832263612593908],[-2.39051262467112,-0.254991835731088,-1.59227403256019],[-8.11264217853853,-5.80216278628189,0.662131388607598],[-2.57707397355868,4.84260288530015,-2.48809062555411],[2.17801417662249,4.78371414366198,8.97328293026553],[-1.52356656247304,-6.70226727584616,-1.58685701413287],[-4.75775933507837,1.07117613639551,4.63308594470522],[-2.21797357436309,-3.27224879623235,-0.650482040259946],[-4.92327780135142,-6.1893345308242,-10.6116885729319],[2.57099832785625,11.693234844175,-1.02754729944025],[-4.39311266483865,5.09342625614223,0.355306701252571],[4.15820296515547,5.95772760235355,7.87108708644387],[-3.69637835457572,5.23342839329623,-0.815711402689553],[1.02993791414147,-6.6717829429745,0.426125859520534],[-0.334640725898995,3.23513139941605,-8.95533914941632],[1.45042783145781,5.09424847347402,8.07425345097716],[-1.19719400179909,-7.14266437739442,-1.2679780564153],[-7.59938040627376,-5.67944805467574,6.98554838640711],[1.13745492973075,1.8764936954512,-2.23896981782753],[-1.37165520002584,-5.74570351177196,1.7421509612605],[-4.18141524550628,1.47069834146432,2.31143901683116],[-0.246075299062575,3.01883910191036,-7.6016744254455],[4.69882597148569,-3.05231787107428,-4.06510724010817],[4.32311077048322,2.09781994369826,-9.89034812888248],[-1.46917400777151,0.0702800387813598,-6.99425445132481],[-4.66127068652096,7.07444658465669,9.16541787196227],[-1.23573440992027,1.89080421614381,-2.28020676024101],[-1.79129369876018,-1.83429980724893,-8.4991260609519],[1.05757839740233,5.90417625584625,8.63779016204498],[-3.91147122744175,-2.01318817172756,-3.51972064979636],[2.00524589680965,7.07174202159563,8.52121066279683],[0.765395427993306,5.88727076990082,8.13193615603415],[0.155411641886913,-6.400103136777,3.03790434141288],[-2.46501080507231,-1.01272390446038,-3.51289927857013],[2.74741082268047,-4.44410962516573,10.4032429648168],[-5.30453035492784,7.59875023586204,9.03578628062507],[1.21500319897849,-4.65855385421517,2.88646649534396],[0.0337297100607769,-1.66851789365405,1.09070249279393],[2.80871761827249,-10.3224532605563,-0.762745319217613],[-3.21273176764,0.651367627444612,3.61714691586289],[3.47716129499501,12.0985667375129,-1.74452862840043],[-6.30527985248884,3.5887614704653,-4.23750413282214],[-9.65204371362666,-1.06385594152485,-4.28135552633796],[9.11987177378598,-2.22559456220628,-3.68240084650014],[-9.32931319273828,-1.43419159574981,-4.29982321095622],[-6.57406958283469,9.58231424906521,-4.29990990530218],[3.99659436629359,11.8405842602115,-1.26403183040056],[-4.55644589043023,-0.228419967633268,2.1219106503729],[1.06838896798387,-5.52348367541772,10.6318220270542],[5.1575002554957,1.41260112271562,5.30141483382939],[-5.44514038427039,-5.735385584495,-1.19356614163898],[-2.79972446185236,-2.9597417510743,-0.511148914378131],[3.57750428405386,11.4572222221544,-0.670388150552036],[-3.19504829925116,-4.38435800979596,-1.19375964616647],[-2.7048055543978,-2.86909138841885,0.0322676059028147],[-0.712297815592319,-6.16576613193777,1.77776154243773],[2.96886406933189,6.33828252767244,7.35662193754],[-3.87010778879923,-6.33672936576112,-1.84131194715087],[1.45257387413772,-2.57554284408203,12.6584802566339],[1.46110472353041,-6.92605697645556,3.53175533599183],[-4.10689102637219,2.24023122588588,-6.55867319604456],[-4.53708421745039,-6.71689312107723,-9.4001545470888],[3.82928247066905,5.25080110924603,7.44607343555609],[-6.87119840915938,3.15981706532426,-4.99498125063495],[2.72640438607108,-9.4249593359054,-0.47759320820202],[7.77704846367942,4.70498382862503,-1.29004075017383],[7.93127269838901,-3.80556801582195,-3.4619151222849],[-3.78741587066981,1.32036831041609,4.18879337255303],[10.7050112469707,0.832429403111853,-1.63898357003341],[3.51461809249073,-5.90830566166536,-4.75433933546954],[4.34517453074622,2.27067072263757,-9.49833380290974],[-3.50017148809432,1.33889299186501,4.13338531650512],[0.158463538764415,-2.89275303934587,10.7411295091954],[-5.17041541234534,-5.24844803493373,-3.05675931400609],[-4.65556723587414,-5.75673035037261,-9.55503035562063],[0.863264375218271,0.262474083410286,-2.26434976508275],[-2.50000968568138,-1.04267380923469,3.14934657482653],[-2.70622157067431,3.95218337246085,-7.4046108840771],[-3.09252243574993,6.55428746509814,-0.366071896162101],[-5.34872217732635,-6.7762573756623,-2.28178309753757],[-1.93465150411523,5.32367436243583,-3.3229900868991],[3.06316668915653,-6.34022968961781,-1.09087417260086],[8.53974232629923,-4.63573445101202,-2.14289920803045],[-5.54796957204896,6.80329388911406,8.25819684518449],[-5.06829122228737,-0.126114122616008,-0.974892931524302],[2.89338778514918,-4.8388550502262,10.4529359520506],[-2.00952584230461,-0.797570414059597,1.14288293410367],[-3.23941251152552,-1.73074643387979,-8.4218927817775],[-3.62466031150995,5.1898874016706,0.7902227734036],[-3.8906997359673,-6.39008724584305,7.42036146462435],[8.60783465496631,-4.1305384930142,-1.32477755461978],[4.06075584843973,3.50016541096856,0.59221224307718],[2.75371045979111,11.9263237896513,-2.60990748561958],[0.141826749578792,0.249706817522526,4.14407662952433],[2.39315429547438,-5.09096996682371,11.0583531270021],[3.42764164540067,-8.12745923393223,-1.42428225394788],[-3.8120838029783,-3.75290955335547,-10.6509576804133],[1.48814956458478,6.06197870796552,7.44088410501307],[-0.355709400408723,-8.62298691499097,0.694126906955877],[8.39674537501278,4.09191759890401,-1.89502578076937],[-2.42669438257713,-0.343047984616257,0.643845002631544],[1.82820300322174,0.680982953086992,2.89553546406767],[1.92140399978118,6.40529850371211,8.18661219898356],[4.04209001966098,4.84062473354646,7.73095993191075],[1.13002000686762,-6.44928794950244,2.95169974754503],[-2.8764202905886,4.00670144572199,-0.124359827191346],[-2.06092373451706,-2.17011866163314,-8.63185230663525],[1.42334113988489,1.72895538383631,-5.11871994865159],[-2.30839942110373,-3.97574337586224,-0.375105195862638],[0.562347101188668,-8.03120022479045,0.556994269950614],[-3.26943059315801,4.70098597226213,-0.944936231912959],[3.95540780339501,4.4967961690112,2.47842356206709],[-2.54763853638542,-3.09889112438678,-7.09205853372013],[-5.62837024393199,9.3662154356029,-3.79011101623523],[8.87661704085231,-1.92974682413023,-3.59105180540442],[2.00815827705896,10.8307702285191,-2.52884351296128],[-4.59576970782029,8.09644398069732,-5.2817629259205],[-2.97962593361674,-3.38895601290561,-0.708135831058875],[2.4236997777921,6.32363189144575,6.32367466406849],[1.44217081114958,0.00318037318917985,3.21607442242255],[2.1506195900591,5.9534352494023,9.3830838923192],[4.98723452475378,1.64917821819617,5.65963504924751],[1.63178848387407,-7.080469600141,1.9700069356457],[9.07842813629997,-4.03253047177831,-4.55291987094174],[-2.67707873781478,-2.03056458813186,-6.04337657552915],[-2.25592913471892,4.81285355044044,-6.66782237597888],[0.677796807532526,-4.29423436689289,-2.20505488238378],[2.9663201438471,-2.60021574501491,-6.76687446420256],[3.11214827124635,-10.0911132984226,0.151890488598163],[7.24153739715527,4.54264238174714,-0.0462786465402458],[2.73738747749712,-2.62051328911375,-4.26444664820982],[4.14135656488198,3.40313224117872,1.25004488466482],[-4.71720142073537,6.47138866968341,8.73710121991905],[3.95112940851215,3.98499678248364,2.25219630933217],[-0.270430700332437,-0.887965240090866,-13.6583979736432],[2.55142956538513,5.97111478735583,-12.1244161512143],[1.73871168261986,11.2769542611033,-2.57249359655693],[2.59762178427273,11.6202529299676,-1.4476009948789],[-0.430335609133003,8.91777347405393,-7.46470276546182],[-4.23767285026114,2.4026132008256,-5.49719769345969],[-3.61079587066007,-6.45869206823119,-2.53986026892693],[1.3218851026785,-9.53148698474949,1.69518795176326],[0.946929986798837,3.54432157897203,-8.04457531189003],[2.18299456751061,-6.04040276401886,2.33286827309258],[-1.26733344969538,-4.99510403812652,-3.2450346817559],[-2.29321877173171,0.414494683747948,-2.11778567067794],[-6.10175216851859,3.38035990303973,-6.36329471670848],[-0.40601689573788,-7.47425201539333,0.668398001537176],[-7.0737203157566,2.71896890906069,-4.61484313872362],[2.64553509950374,3.52006455187902,0.99036473676645],[-3.85648237225341,-0.0881264617189543,2.41009208764744],[2.33352984974111,-2.32345934858847,11.1638051107576],[-0.678012034225839,-2.97648245941626,-1.16325350459897],[4.24771656735656,-5.5090124622933,-1.31653475218147],[0.975227437301537,-6.77289688650505,3.58179310443967],[-1.34371818408152,-4.83641271672518,1.40339724329493],[2.05534763938617,10.0954556988049,-2.05650842594106],[1.64151044238054,-9.67469714027011,0.564560507579756],[-8.6192957266239,-5.52920593432514,0.549212292517796],[4.12455862543752,4.93153389170503,8.92905900159727],[3.21224033050386,3.42920738777257,0.479965159074028],[2.26254827220507,-5.61821522039559,1.50994694594923],[1.50494373580774,-7.94160963374564,-10.5996722633867],[2.84077120390214,11.409116392049,-2.2502158087963],[-6.89714193634332,8.69209120470144,-4.44287734285888],[-5.01295285930073,7.59853410381796,8.05062569778044],[-3.87274484148562,-3.26979278093313,-7.68554734934588],[-5.04719151926822,-0.60810107964489,2.39323031159579],[0.77543215186114,-2.99397349139856,0.10279567601111],[2.98656239200869,11.8465662512399,-1.42166321115207],[-4.29030174790873,-5.1288095300609,-1.63500915235768],[0.592993479739701,-3.4945786014758,-5.685542192646],[-0.268810235540393,-4.22962064950762,-1.13883715035854],[-5.85524330212117,-3.30681196283545,4.70585633375158],[2.65723733767336,5.71399989691872,7.66602753488038],[-3.64783912985502,1.27321136512535,3.36516040706168],[8.91892357280416,5.07686552647412,-1.60188000662317],[5.05529291962901,-1.81588701603985,-6.84949292139919],[-3.12263481739956,6.97625873609133,-1.11784438847369],[-2.31541783549824,9.41758102879662,-5.79631765574739],[-2.26722369925166,-3.75413464562633,-9.58894741685359],[3.3869682524879,-5.45557085348228,-5.03487518233476],[10.4596449994753,3.77383092242427,-1.92103750818116],[8.33399722179738,5.08415261613559,-1.59830118571444],[-1.81850493637984,4.5641603829966,-2.80831762720114],[-7.96442990255232,-5.60295009710077,0.925924128574641],[3.93426787646068,2.35005587683264,-10.2998772230963],[2.82437193828869,10.5682052913871,-2.29027636253946],[-5.14468353310903,-5.75922506548715,-2.50253358344625],[0.362491727550238,-0.288911815209176,2.94602198421483],[2.61778537005681,-6.19088795669501,4.18140372945981],[-5.36601666622509,7.9983193416713,8.59164463350519],[1.16667149691973,5.51948595544286,8.54155304332319],[-3.61978003670961,-2.27025345198835,3.91701776926497],[-2.48942578894754,-2.78861267304377,0.131355111120151],[-6.40697992091682,-5.5634626309782,7.48569054764727],[-4.1536612347876,1.69731224168006,-4.51583350802701],[-5.9811298255713,-3.6272659861872,-3.92770750496687],[-0.938800199350647,-7.08267177326968,-1.23137982061419],[2.82479914115179,6.15734003220745,-12.2203807071926],[-4.30363286262387,-3.33639630382767,-11.4154797953297],[1.31404441207021,-6.03261168951088,4.56049571056183],[1.22463927860725,2.29435512501435,-3.59545715558319],[-2.82677370064337,-2.21379312585602,0.252883137563553],[2.60081717213011,3.52735051217528,8.31405221916838],[-3.90059184027631,2.59732377334458,4.56442086941474],[1.49014777702781,-6.34987889240067,4.47117803737247],[-0.273790107873404,-3.14994203769096,10.5694159477638],[-2.54650282685301,-0.87524495630779,-3.70934548545894],[-5.07419887334886,-0.748538291489983,0.695505201997627],[-0.308081395623115,0.780797022241496,-6.91297606454609],[-3.56668498743559,-3.79789772627216,-9.25756962513356],[-5.87675590501219,-5.24731836225417,7.67505367713922],[4.35482234094619,4.91771485751921,8.58333885982836],[3.05691552300809,-2.58409300476035,-6.70916277335338],[1.94751189738672,6.51167418448494,7.70341202087895],[-3.66460890361204,-0.394755661771002,0.176699566023278],[7.42870101439519,5.60313229438741,1.69646767736832],[3.43047631837795,6.25483178623193,8.27892940426477],[7.31238346375706,5.29566541607322,-0.259556022047824],[1.97187240207229,11.9100619371873,-1.59939279039179],[-1.84513825554167,-0.762227606809192,2.57272606760768],[1.06466768382895,-8.35250360123726,3.04792142155609],[-4.24331512341517,9.29322842787724,-4.07582431188975],[-3.71195448782607,3.95112206508,-7.08739351421955],[-2.79317558249399,-0.240860598876155,-3.26191398390653],[0.664856089558028,7.23321843207304,-6.13969648628711],[2.04648965920893,-2.98676798627563,-7.52257768731735],[-6.02945645279766,8.02252715108762,7.72220039808097],[3.27205237294182,11.4876600234863,-1.49991943526667],[1.65944709138807,3.86626975368625,-6.48761030920901],[1.98034688297323,4.0037331418483,-6.00990261294348],[-3.71991587593137,3.62171622324947,5.91097684809933],[-3.76746288318384,5.9866897359356,-0.263109707828921],[-9.59445326417606,0.363080972892325,-5.67269397817171],[8.84277381127093,-4.33929492053675,-0.696464997228054],[2.20161648065685,-2.52976578955099,-7.66648177956981],[-7.72480272412281,-5.73799229496154,-0.509633755169761],[0.583075106097211,-0.250155198268463,3.21354285999483],[-5.90687694445369,-2.86318929466151,-5.32570585291853],[4.2017279297373,-5.89966710857411,-2.62728327887875],[-2.99597932255835,-1.19943212997481,-3.83233753993513],[0.079436083319703,-5.88298864614355,1.89764379563679],[1.850443746954,5.83181976958425,8.04671779047658],[3.79770898270967,-8.93059523443846,-0.17270801626275],[3.83378345436422,-2.6691594514861,-3.63704678026724],[1.14293894223412,-3.38215785087595,11.2632121878182],[-2.92403911377182,11.949420933092,3.74282283744733],[2.16786308121189,3.92107396589709,-5.97479605259966],[9.21019032777937,4.03002628769484,-2.11994366741393],[-6.23146970624499,10.8420451806447,-4.38844864332134],[-6.16784086657421,-2.94943535180115,-5.05767200891896],[-4.15149630717851,-3.04460352367306,-8.05332760930875],[7.78471308701295,3.77170220085823,-2.25654105560129],[8.9125995780534,4.00664223737826,-1.97995127515888],[-4.72730940688111,0.277719717288419,3.14259840020296],[2.52073922840655,-9.46259437806986,-1.56939600750732],[-5.82023444065296,-4.15786975642406,-4.40129909909742],[-6.67611311424276,2.84809137702982,-4.69329451237947],[-4.41357539014483,-0.471662719622227,4.14714791733636],[-0.83049039506012,0.887183122968938,3.143291031201],[-5.64595578668421,-0.824604184815222,-0.637680977875346],[5.56743749032669,1.24517459428152,5.56980299631423],[8.21529440801832,3.35793027063339,-2.40032316406537],[-4.67927526916876,-1.45637123477872,1.97936001149811],[-5.7962105395889,-3.46331383358444,-5.29772154656172],[3.30650277581703,-4.22607057757686,-1.28093615239369],[-1.45147952699021,-6.46927639807599,-1.7182675233337],[0.2279468869105,-2.15902003442088,1.5409667831585],[1.51868087276881,-2.81461726671439,10.3402913350685],[3.34275992963078,-7.96210222544404,-2.00119098005024],[3.10729173435559,-0.196788824238736,-11.6417085782248],[-5.83928080779221,-3.4221661536933,-4.72188528372394],[5.03496873077671,2.92569227712343,1.9190593877318],[8.24514514626091,3.76883159661914,-2.14376340948435],[-3.7028434727971,-3.69182497867079,-10.3928216713517],[3.72997072238615,-8.17255761007375,-1.43936361186102],[-3.29859092114741,6.40646144158023,8.2259209012817],[1.69255973306183,-9.69600096072567,2.40609164636241],[3.15008996372301,12.335826530082,-2.70250825350371],[3.92251486912557,-5.10656485605758,-1.96088136646828],[-1.02493177080772,5.7824809856165,-8.25482841203498],[3.34536669576651,-5.82472107640759,-1.44811294605761],[1.38753156407714,-5.24621445785546,10.6809993924187],[-0.712865423502267,0.620637171559315,-7.26933203633028],[2.55518388870603,-8.00452312289283,2.5288745367526],[-3.4316334544223,6.57804604480614,-0.533215129801301],[-3.89348298085229,7.72442022098821,8.05344447168198],[-3.42673808204765,6.91969574643476,8.32723157777896],[-1.03797199958828,0.484317726083654,-7.51480623696816],[1.30971247395993,-5.00036293823124,10.8607670217498],[1.15267595670134,-6.62066137284017,-0.254598887550819],[1.65957021373642,10.7669514464667,-2.75785208887055],[5.15678825187552,1.29677665624348,6.26397641879614],[-4.1666813619862,1.38795139180126,1.90119775613132],[6.71552580294291,4.74177162420353,0.106699950731023],[0.434192695402058,-4.96849721342932,-5.79335135249942],[-2.1247755011651,-0.754808845705354,0.201708560848003],[-1.81077459904567,2.73343556992398,-1.98050353032566],[-5.83744450223823,-5.90564195702497,7.33569420174724],[-5.1854241413551,8.19999705912285,8.87289840583551],[-4.87782720690768,6.88929454132118,9.24367871491944],[0.857648884321849,3.51418170880688,-7.28632712677614],[1.54843266164819,-6.82486717306953,4.76240803871047],[9.99295743623879,1.44340183885088,-1.78562986707649],[8.45911265666977,-4.23542577160383,-2.07561806076695],[-9.30472429172673,-0.30530751304986,-5.63889495025306],[2.01266477186079,-2.75209316111602,12.7147861317458],[1.93324793736222,-8.98602339813875,1.35945522111248],[-3.48801951512767,3.06966431401943,-6.13412919122507],[-2.77130767440634,-3.35080065618529,-7.80698490345145],[-5.41792613305456,9.60987235958634,-7.53148616992248],[-4.52171587957637,-5.06793824651621,-2.80244759407268],[-4.71649385334456,3.15086032598533,-6.74972602529752],[-1.52075240979477,3.3881704165297,-2.3268919026168],[3.64685458162646,5.67290154781434,8.38048397759519],[-4.43517437006177,-5.48125558207097,-9.42048875770752],[0.455991687029795,-8.45590521625621,0.949537773131842],[-3.53490004157719,0.447115762433913,4.45799517778646],[-4.14222786595512,-5.69095603763761,-0.935058251678992],[1.67840438948133,0.172704414649741,3.58369948641428],[2.01846318265705,10.814115655613,-3.01876789729052],[-3.51289025012208,-5.25042960618539,-1.45178238416029],[-4.12716926413812,1.0708371026453,2.27616372814798],[1.33412991437883,5.96586034923637,7.09931164662209],[-0.00763660418160872,-3.13801093272072,-1.05477976071255],[1.06606925509015,-3.16314419928151,12.410574462433],[2.32438603542344,-9.73640633676225,1.77768666254434],[-4.75912959886521,-0.0246680406592137,-0.936644681737966],[-2.95371946649226,7.22705854125379,-1.13448807216307],[2.26228210665726,5.84182056162024,9.31828839034267],[1.95385705333525,-5.10288687107675,11.4539372381211],[0.648540090713578,0.408418128707081,3.07431297230461],[-2.05568540155741,0.028926869874136,-3.69190632682782],[9.03473512135063,-3.54184318008715,-5.02166883120314],[2.19866945967087,-7.455038658662,-10.8300684761174],[2.5786555481279,3.37185359650915,1.04841575305544],[-6.84635457275647,8.52614115182838,-4.03296531679185],[-3.62752873202904,-5.45345731687821,7.72197719814225],[7.76772491897965,4.18951258856146,-1.70786098803453],[2.22032576813393,-2.68384879175812,10.3405641618382],[3.93842361878988,4.10567238715437,8.52075819164462],[2.06530095279717,5.86687483573303,-11.414898197975],[-3.66420421484043,2.70483689893117,-6.85084790486314],[-6.84836957031171,-5.86049307603757,-0.579287809526178],[-0.00305866378676589,-6.55656378687422,-6.14046665712398],[-4.99077530909027,-6.86367717713737,-10.1208026962191],[0.502445957882108,-4.61060937866919,4.02779606754566],[3.72279731627761,5.52601262372922,8.07500219035754],[0.302842762555218,-3.11920621265773,-12.0354756374475],[-6.00972370724946,-3.03188772069644,-5.38753252445552],[0.272581239178539,-3.29495758853497,2.48598667370547],[-6.10398496203479,8.40812130375333,-3.99215625881007],[2.81656150563379,6.72565251607225,8.06878926977176],[2.17532367344773,11.298537172329,-2.66006062407527],[-5.52954832574652,-5.50459555046002,-2.26162400919693],[4.18936379261278,-8.89517204269679,-0.410024792479199],[1.07723395289111,-3.16044728738191,11.9283907052759],[-6.27969620572275,-2.52053349093156,-4.71933880023758],[-1.87731103285409,-2.88477533741791,-0.692818036102678],[2.99058339773468,-3.5451527436866,9.54994312792449],[10.5489551253595,2.94863479629702,-1.91268418203673],[2.48006492906203,3.39567394954965,7.64269178950996],[-1.80208087256819,-5.27434321572864,-1.1576139950575],[-6.16928678815943,9.25095859687505,-3.91487454906769],[2.62028025595617,-3.13353156077243,-3.5595100581813],[3.26813370130329,6.29789011338311,8.25313228627844],[-3.05745633949131,-0.283473029397491,3.47970595974353],[2.52913563800291,4.34325926315874,7.93240195147056],[5.08010776545524,-2.24525399810034,-3.18396175125303],[-2.41047035140741,4.57464461995455,0.786504590148238],[1.50263549815307,-8.58867444322578,2.68484869946489],[0.643008103446636,0.215133437510526,-2.95296435816637],[1.73696218688025,-3.09205291187335,12.220452029901],[-0.0421438732613681,-6.83716512585667,-6.42664272651843],[0.947188286677944,0.505444448019965,3.80589529284841],[3.88316726452704,-6.22958069028627,-1.71551479401548],[1.57629987726163,-6.19061742508602,3.95974147166483],[-8.00537656830456,-5.93743980157725,0.67556928919423],[3.85839315689972,-3.24582095080229,-4.06504061264725],[-4.57782998804958,1.06758266790476,2.8416945665358],[-5.28292215955506,1.70012460047249,4.65329561514686],[-5.32032557853046,-0.851324418575395,0.308876721900981],[1.91387636932637,3.93213456955564,-3.9529949491292],[0.282191962750052,-4.12938361853037,-1.45115066718843],[2.53677152401117,5.13565440114692,7.96318174062284],[2.33654594202203,3.94035941230725,7.50413242152408],[2.6755734993418,-3.85939623287009,-4.52940478902809],[8.95007779750937,2.67679819751495,-1.72201964774157],[-2.67970835429356,-0.899724734501021,-3.71512171369936],[-5.18115018773807,-6.97184742518917,-10.0216700248786],[7.86145993434276,3.93705420784467,-1.7817550459016],[3.16275072350649,5.93621932832237,6.65630304852612],[-3.70541917615372,8.09859446895487,8.29027091651754],[-4.14885947206476,0.75410796216808,5.87650305446301],[6.97857850682181,4.34066087187479,0.148138299764409],[-2.57187588514405,0.748709260134216,4.23592114542543],[11.5140032662797,0.2150337140705,-0.289514388847627],[-4.75136923700247,-6.86209538754094,-1.38676695725995],[0.792747592392897,-2.87146029456472,-11.6902502657538],[3.18003350798501,10.4903633025815,-1.9955031457485],[-0.523147697734078,3.06431484555823,-8.70236392709297],[1.67902763351392,-7.11477344901326,1.65873771571952],[-5.00375957104081,-4.8410555974243,7.30573153433529],[1.36125535021462,-9.38184905677566,0.298208254442442],[-5.34229829701531,-2.7031479169971,-9.11747010917594],[8.14765760139248,1.60174591947252,-1.31885184649014],[1.91378289474802,-3.17061280323226,12.2397882118485],[10.6505413965721,4.44393650251213,-2.50640236063585],[-0.0302060765214403,-3.2197345195896,-10.9211480620268],[7.29311475306188,-1.80201952380812,-10.6976220356236],[9.51246050820659,0.170932684333623,-0.782103703706267],[2.40673999323052,-8.79046670736717,-0.943456519250241],[1.23229966703876,0.226620293729943,3.33781680493789],[10.3037411608785,2.16120259837808,-2.65652638431278],[2.04837309162452,5.96907880671454,8.23619235109307],[-4.06475788497946,-1.68756368073233,4.07160950417251],[-4.02047577234075,3.6996232740997,-6.30603857093835],[0.64656964813864,-7.53759774810828,0.124660569076595],[0.162386171172217,-2.40437397973525,12.9202347845605],[-1.00070984141164,-2.80329576031379,1.95283447998283],[1.72392960643254,5.48740988000167,8.20636275015503],[-5.1105428762942,1.46486241396875,2.85101878415303],[-5.48693109245259,3.72388418703831,-6.51362045231042],[2.38098894991966,-5.6233091124513,4.21594211784322],[2.62802846069296,-8.87042227484267,0.201553893020749],[1.57274951275362,12.2086182997065,-1.3330262317493],[-1.83313754652952,5.51202209243007,-2.85052499611025],[7.33252499822925,5.38049044635541,0.0374945805413235],[-9.64063413190356,1.03687964975285,-5.96305158705648],[-0.244388626745483,4.4286157059075,-3.08135890103977],[1.22985931113766,1.45291029331007,-1.24598971906963],[1.5349299308683,2.16157045987379,-2.68297255921963],[2.69399963533477,5.81336673737627,7.79217139035009],[-1.85877485235193,3.26462069685974,-2.58186137953136],[3.15778161633108,4.74195569146133,8.71379185145088],[3.21449302587067,6.64422899192147,8.40878918821468],[8.23448517299241,6.13476437694498,2.31699017841951],[-3.89584037159402,-3.74950646765825,-9.3543847295671],[2.20173302722768,-5.85165435322478,1.8283567659075],[1.56851583657015,3.27645987260856,-3.48841567682924],[1.16008552879448,-3.40267051225584,13.2650296975837],[-3.65487947119878,-1.83248522649638,-1.12175864231308],[9.86878854278346,-5.02750241799064,-4.56459748570819],[1.28121469436053,-5.02011869878052,2.46627477435476],[-2.51894725029943,-3.0478499478114,-0.915775373218595],[2.11477590795866,-9.92138822345317,0.39042384355085],[-4.00067313450051,1.29885577256215,3.84009700055667],[3.02389862673708,-9.86499202615819,-0.806530123902377],[-4.56458970446551,0.326777255025818,3.22758274480203],[1.21886524239449,-4.66214824272877,-4.98495446622119],[-5.1284975501312,0.893031220743145,3.65126175642263],[9.5821051920514,-4.7281098389645,-5.92862652218102],[2.56513650311103,6.09975292043849,-12.4596856512383],[-3.17189086077181,0.699464394720244,1.8656207666306],[3.56472847615159,-2.2906645566351,-3.39011714968737],[-7.32649637059423,-5.72245054714603,6.44470461598648],[0.910488013384032,-3.52501976791747,10.5293245365865],[-5.59537651872501,1.42229842001611,4.24610640196767],[0.212735791999679,-2.52241649850197,12.8643631604907],[2.00864223692119,-5.60526255664176,4.38602651686663],[0.938099532135895,3.28994869617278,-7.45218333855211],[-0.169451912775707,-0.598112185456005,-13.5099921653716],[0.0681797084740087,-2.84808553715568,-1.14496568372348],[1.39447524739758,-5.82425691417685,4.06400922903605],[1.52275634428644,-5.76372230127215,3.70201524577325],[-4.25029496087227,-3.41466715964876,-11.3556611434471],[1.93014900278311,6.01768777721562,7.65933578537545],[-7.431469690139,-5.6266512743132,6.55151174269587],[-7.07070914615712,-5.52761094151283,7.32347959492472],[5.11928674404446,-2.39861141324878,-3.2742290233804],[0.800282647066019,7.40839963097455,-6.28131614759],[3.4623312496972,-5.85723870518847,-4.57081148766752],[-9.38594430213906,-1.00202308425778,-4.00814076979105],[-4.04228915258407,1.76976724078952,3.15715278310227],[-1.78707877516251,-0.5254090588582,-0.774652711385062],[0.957172888545592,-7.49089524449067,3.61786010598604],[9.74198173606935,2.84198592093682,-2.58253295014821],[9.15322980927015,-3.69287590669259,-4.53305759480763],[2.37012401557668,12.1610185914192,-1.92868306450649],[-0.253242179810471,-2.68174350121801,1.90468255087337],[-5.08808267789547,6.27093464597805,8.75639463775749],[-5.09234747653671,-6.43867267162366,-10.3051478839535],[-0.395974305261873,9.40002675692275,-7.46273172188931],[9.17492339253859,-4.13890416095003,-5.74125598955691],[0.76006481635763,-7.70032416034127,1.63219122253401],[-4.59894169746181,0.805093207301657,4.42204498639861],[2.77729907779911,0.255223336951697,-11.8208998842481],[-3.02657618009458,-0.872024160162863,-3.77289011589232],[0.58961828663747,-3.2339148861488,12.4482950180252],[-3.794030991084,-5.96951534689084,7.94766474230121],[-1.95378752058693,-5.03913285301774,1.75410668157799],[3.25172690363498,-7.16562627440025,-0.900154401898737],[0.302904166557038,0.421696195383924,3.5296259069249],[5.9442190103686,2.67756120937314,2.26466176993047],[10.4584026131684,-1.15747945043584,1.28107266057913],[-3.11717033746595,9.40044348568358,-5.77937712654969],[-7.18655366331,-0.528779067752354,-4.59078402399955],[2.32825581611193,-9.79955441875324,-0.0574396332772824],[-6.30206108417941,11.1085661049437,-4.25360783728333],[4.01450426911542,5.91157445476656,8.45784069519237],[2.65197832336074,2.73735306327765,2.70315462237957],[-6.89703817500501,3.13793065757241,-5.6526311221461],[3.45857127926776,-7.81108663053357,-1.94133187837934],[-0.494176005495684,0.890714086712834,-1.93580776785656],[-3.47530522603404,-5.09540533943767,-1.69182147447677],[1.28394636335016,5.09530498300387,8.55870602306954],[1.77182990501931,-7.38831660331262,1.40167540085077],[3.07062902713228,11.2198746408403,-1.41545216384948],[11.6340560357045,0.392486040908812,-0.64306356132009],[2.75054944048127,-9.41011234162177,0.576358396813239],[1.14528484661061,0.396805556501624,4.12205168295467],[-3.80205176206149,0.0219257534165288,3.80033606635886],[1.02949671342738,-4.71884709564639,4.48310865440713],[-3.92693767122196,0.363483151384884,5.08856859349945],[-3.19328791912454,-0.642594679057944,3.54339401670092],[8.72876648386849,0.596613821139192,-1.02063351078328],[-8.87987281125024,-1.46384557753048,-3.41262738767818],[1.24127559836078,1.9217413077026,-2.13589478215663],[-3.87564058481349,7.86937212727129,8.34194599835058],[-2.27382667060487,4.1335062671569,-2.63696155425935],[-4.48352783345283,6.06357689561377,-0.757229469077882],[8.97536721194252,-4.53766726664736,-0.847002244774807],[2.79946261982705,-10.1151913735702,0.287786018273575],[1.35579859758296,-5.88092568181947,10.9497326692396],[0.336951857560139,-9.03753228191695,1.8622388779151],[3.93075702046859,3.45066469363912,1.09791362088621],[-2.83424032375658,0.401804550033748,5.03216911365023],[-2.22626253268195,-2.56692611012225,-3.66726615727293],[1.72471441096816,-7.69483775052894,3.31114191647601],[-5.33858752712492,8.08574602979253,8.38327267229284],[1.11131174297836,-7.99607481450025,0.436424136086661],[1.45101038301404,-3.00686759599108,12.1432984571841],[1.32340029815932,-9.03233138396201,0.71777332142152],[-3.50241937843041,1.47980342555154,2.74174229851672],[3.05723103292489,-4.83131546739346,-1.82570553289362],[2.98275996215377,5.74370963630918,6.96625195519988],[-2.14869822204801,6.63927027799742,-0.867817686119982],[1.55757733054407,6.33934690930391,9.47195947314451],[1.57157165847544,-3.21321817624936,13.3301297006616],[8.71734028575823,-4.65793703354787,-1.26656498414212],[-2.30036179480316,5.56214386628643,-2.6488606418091],[-3.20383974923917,-0.787795476471775,-3.65249945386813],[-5.47475402760073,-0.762250516731559,0.549057720413815],[-6.05511603359582,-5.06573225836684,7.66539330968051],[-3.89787301104355,6.81714681914071,-0.818525364927171],[-4.64554241072935,-0.0594285335522805,3.03248869640478],[0.240536569129585,-3.26285895721845,-12.1395857209875],[-3.03807753181465,0.349762223526812,2.16823731102664],[-0.637674081173632,0.600815729075777,-2.9198422390187],[-0.00549259871992813,-8.85500629317954,1.2465039687067],[2.31892132744943,-10.4456988707044,0.279318092114888],[2.0326010344761,-6.35997901291117,2.50073732057581],[-4.24843560361538,-6.53352097333676,7.64500197190633],[1.37001016108319,5.75497041514168,6.65964192644724],[0.331795679132928,-3.08570330912229,10.7563897775069],[1.89868799387024,10.475105612375,-1.71227434636154],[10.1506614352856,-0.631313819501392,0.011819768956546],[5.72450346353505,2.59448683494496,2.50400005488333],[0.220093279545113,0.492388503237804,-2.01870244575252],[-1.91762131651752,-3.01405713435478,-0.632353076714972],[-2.77080388156736,-4.60212444249674,-8.65328006623289],[-2.30491002134796,6.61797666389369,-1.11249436589304],[-4.40485942695388,1.99905114400234,4.54057268592187],[1.42466000836564,-8.45253924416759,2.51635047200208],[8.96710081338426,3.57332502389769,-0.0407744182141096],[2.84927649925499,-4.10946097247739,-1.41451703372142],[1.59428237158868,-0.140490403148234,3.86951336908235],[4.47809152304256,-6.28925731484266,-1.44232568061483],[1.59749835797938,6.36190262548387,7.30531679478728],[2.39238857553232,-4.66752068025084,-5.45949121708665],[2.35231233298951,11.8377129960159,-2.64309852508768],[-4.59437688967874,0.434717641082659,2.72799811885854],[1.28633342575959,1.56572883022624,-9.96901187581986],[-3.84182594275979,1.45337430713701,5.63939063599263],[-7.27664404950387,-6.7050299480326,0.665395046062201],[-1.10781376298908,6.36266994820482,8.62578786346088],[-4.91619368660412,-2.58923989758901,-8.9748859408405],[0.871880186942752,-6.36864353940531,4.13795782661848],[-1.34647840957939,-4.65434794964279,-0.947524869345095],[1.22629601447212,-5.92115332431065,1.82592582019697],[8.20743404019152,2.37231197876248,-0.846629273172367],[0.328395991235108,-4.89192126827474,-0.820778796567204],[-3.64374225742444,-2.64874071143215,4.85046301375352],[0.342887568902466,-6.71816720053841,3.34135791254727],[1.03130037945771,-3.29017237388848,12.7120647903912],[-0.301241873769398,1.59384101611069,-1.78173197642182],[2.01002034012678,11.8704434249497,-1.56232651931711],[1.74315800880358,2.94227052651359,-2.82136325973186],[-5.62059058610674,3.61940912789515,-5.62605309456363],[-6.69063737808801,8.57056718042111,-4.0345639480598],[-0.17688509329736,-1.01234815418405,-11.0109217614457],[-3.59694198105926,-1.02033703773463,4.03212203997109],[-4.30863877119633,-5.74020227377444,-1.6711583358875],[2.56010293065293,5.79562918526372,-11.4854365281485],[-9.09294173539378,-1.492902440148,-3.54930877438131],[1.75677271316344,-3.24482934894253,-7.6619977653185],[1.03040323581281,-2.79071588321681,12.5509903060265],[-6.56520707472774,2.89394187900806,-4.35690317138806],[8.09676851218886,3.57436621185902,-1.88579373114193],[1.16098143692891,-4.51012264945393,2.00713031188644],[-2.52404293397578,3.99978865339573,0.298774249592242],[1.01586795356289,0.130747451876516,3.12895004730277],[2.54896212862174,6.06000312279074,9.2686400091657],[-3.63738161729531,6.84011311039011,-1.19295845069211],[-5.95028948930043,-2.53587589784735,-4.98900880525301],[2.91114907000743,5.31281183543142,8.63706752606845],[0.340953821696954,0.349312356652069,-3.18236579387451],[3.74080771269189,11.2126061153914,-2.050788811262],[3.53789411615979,10.7094704265384,-3.08296825100082],[3.53643167116494,3.40433754849136,1.23790260141622],[-5.03866271583469,7.08976705360528,9.14727882473377],[3.4232532349027,0.580814972577747,-8.7458051012895],[10.249854818902,-1.37145230012401,1.10991424588136],[1.60098257237918,-5.69047127790929,4.22352568594961],[-2.38550284554683,-3.46178651851464,6.46020725517984],[-4.97694593348708,1.51106446800144,3.32063906806121],[-1.95131150415989,4.2026295189396,0.783210214366727],[0.263954360736244,0.354977081000108,-2.28673020745431],[-2.45689017264752,-0.174876683927318,-1.30854079536138],[3.97523871045423,2.24572094580878,-10.2259646198109],[3.17126121804139,-3.961310279081,10.100223531303],[-0.816917998530737,0.459752383060577,-7.21731984809964],[-5.57231412847488,-3.8957877170818,-4.49192386302636],[3.28533534904432,-6.79744102216839,-1.23831970021685],[2.80124447786381,6.31912022777932,8.23921109047014],[-3.71289975468219,1.74094312022014,3.16767555797614],[-0.576751808140107,2.8655024121697,-8.68867919035518],[-6.75811474320461,-5.26278869125994,7.57774249076105],[-3.16074413124341,6.22284856423403,-1.49579946388551],[12.0752183422762,0.23313432004348,0.54156038537039],[-3.73150529159289,-3.45186262931848,-7.914721479653],[-0.207403945905918,-1.06011015348061,-11.1006342767975],[-5.92067962872312,7.30586783424787,8.00782167587266],[9.20962431228589,-4.05191724963614,-4.58122703389486],[-3.49453483014645,0.341687158699715,2.43220191078981],[-5.18328332779121,-6.57015708664377,-9.53830993308876],[8.88204310691853,-2.39369270893731,-2.89261956065124],[4.25614413463332,6.071738811893,7.46071007184877],[5.01791342209592,1.63261930828042,4.99166930175205],[0.652079267486519,-2.44952006764561,-12.2129038701209],[-2.36858178385269,0.609297137729216,-4.37879835954051],[1.75949173054171,-3.76186591397528,12.1183828169406],[-4.88123845973104,8.5155756790934,8.02291872992514],[-8.18642770195835,-6.135472349623,0.0466602483291914],[8.12875375682854,5.70666593834667,2.70701087038347],[-1.6525250029855,3.2716103069434,-2.15420232731125],[0.724463074025655,-6.99976737554571,2.38323039508269],[3.52877968870961,3.88465607591471,8.43939935349218],[-1.21550192046357,3.19325180105942,-2.13498051923509],[1.95024148589501,-10.1017176583579,0.470543232362663],[-3.39438980416742,6.94287150460308,-0.437951961367796],[2.49631397010075,4.2969737503209,8.97221676843204],[-5.14091526869212,0.67327156564234,4.8718435127463],[0.107885510694676,-3.45144620118994,11.1958969383882],[-1.43878442791784,4.64034335788081,-3.27995965044382],[-4.17607021104152,4.87998915718636,-0.364531914959961],[9.42939422103086,3.46023247657316,-2.98236642359687],[-9.16816624770305,-1.08305825842401,-5.16606500381892],[-6.15438903966885,7.7811403280931,8.19710410793547],[-7.03848440909618,-5.94088711352834,7.0348330225879],[3.22725720597918,11.8844598634796,-1.5037000622611],[2.21316689090694,-5.2248505135733,4.92495939248979],[-3.92765441161299,5.89573541690934,8.62411335560958],[-0.00603734428434555,0.938332016812304,3.31989081733877],[2.51315446275805,11.3993214184368,-1.82045589756618],[-4.54931574743349,-6.92042290775057,-2.71504896878487],[0.775752448784249,-9.26359683738913,1.37771011972159],[2.8084915167475,-5.49248639581696,-1.3894344586141],[9.36038254612163,-4.67793943187761,-6.14000928903485],[2.86612333068197,-2.37337150095154,-4.60618676084611],[-2.31879645833741,6.79724606484661,-0.637682024198255],[2.46744522791921,-1.76768338593109,-7.58183356784049],[9.74438139973873,3.66442855623752,-3.2349124406658],[7.97431728925845,5.36539658423797,2.89313986324065],[4.25879130981205,0.0370205463377166,-3.80904118016255],[2.86168535117869,4.5752190365083,8.71987597165572],[-5.18266309896038,1.01347070128435,4.17869480317626],[-3.03429350777471,0.396596710909316,2.95538690146951],[2.80854607300048,-4.19621902181058,10.2130070012456],[-4.88810991761264,-7.0291377935624,-2.19078630555528],[2.18149305676477,11.2875614998191,-2.59507651217285],[0.893488931694702,-5.41845974226427,-1.02373153143863],[-4.33534440110784,1.0147392456061,2.74667336910127],[-7.71286608997501,-6.24320061601768,-0.332450201770532],[-7.42662068730619,-5.90169562044453,-0.290055555821178],[9.71664685664482,3.97984499469675,-1.93776179753351],[-2.08973256071674,5.04118494719793,-7.07083800696622],[-4.827030022361,-5.8283784797842,7.42539764952111],[0.0417591747455737,3.29854727632923,-8.76506523430452],[-0.498081020290558,-0.0822545366500043,3.21407268551215],[-5.79402491175136,6.93192452331855,8.86169938515571],[4.23004677267094,5.98803303859994,7.73719403908704],[3.38636433759452,10.0199376876827,-1.42728400164733],[10.5639143208635,4.91806936822948,-0.963899188750748],[-3.55364540365117,-1.54671935093335,-4.10921383312338],[-8.58969480134036,-0.0928743614664778,-5.47699793259283],[3.90658942570062,6.4775863431068,7.87648544770378],[-0.371230261836562,8.60649559168079,-7.18322549370482],[1.62402583408916,5.4048494499546,7.87933451641912],[4.51054994929061,-1.61530763738323,-11.5474310957755],[2.90421357714998,11.5350509817034,-1.50076374432395],[1.93972136741105,6.0600699062445,8.19994050890355],[5.36988688414483,2.64428872749413,2.39063526534688],[4.18533333078232,11.1500655617173,-1.30770980117334],[-1.11885566922298,6.14278277729259,8.67848586189885],[0.154523263879797,-4.34274459791062,-0.946867433897837],[1.97038021450212,-2.34984706487493,-5.71603453552751],[0.623544734798109,-2.48250020064481,11.6367311147704],[4.88349842750567,-2.14196144350747,-6.82637236018974],[-8.71354821382016,-6.33327920856672,0.801661779681292],[8.3992592059714,4.25739814012407,-1.76490688042961],[-4.32600778100267,10.2380771490719,-5.41422419803585],[0.115031195647899,7.88736437225605,-6.58440220710589],[-5.04942650365804,7.40194276144442,8.85100292494991],[7.69863130111483,-2.19363727830626,-10.3190268844336],[1.21504243027301,-6.18320146108086,3.24671328750948],[1.87281010728001,-6.25231514582696,3.91747637945182],[-5.37518094945371,-0.0156076912887839,-0.129381263327148],[1.2419251098387,-8.01954997595616,-10.4037458075634],[4.11503073633473,-6.83326261441402,-1.20668478707586],[3.67358565990431,3.91333036012954,1.01963897913695],[-3.96472564442307,1.67994098508983,3.67755153081935],[1.11886977355447,-9.77550987866817,1.68664191983582],[-4.19411450691375,-5.90378512534298,-2.16875652405471],[8.86693980882017,-4.24484546959369,-2.98377257338896],[11.5240599602848,0.441707476038647,-0.505237201992147],[-5.95219707975001,-2.95113384647049,-5.03725020058105],[9.15898096498926,2.24220649735065,-0.85848345751673],[0.620431847336137,-2.86688926777984,12.162420405211],[-5.44976431759205,-6.24768719863152,-2.06398767109026],[-0.592361839150303,1.17528570565938,3.78368835906294],[2.11746038098976,-3.57207414176441,11.9169644065093],[-2.92771793761503,-1.83710921694607,-4.34145756665661],[10.1865917254614,3.69955592307697,-1.90843091555385],[4.18022217994512,3.8070538181969,2.26684444077025],[2.59007636796636,-2.26897211019723,-7.16458170671477],[3.46183906131537,-7.96163870467349,-1.45722837027071],[-5.76534946112413,-2.94166272231806,4.71575222834875],[1.14856251510951,-3.17039673337782,13.367372282423],[7.26496909207975,2.80160288250588,-1.52792010047612],[7.55452666514196,6.02203035179627,0.294778664654039],[-2.67139702443988,0.2984157720938,-0.353892548874485],[-1.39542746421471,8.05057401083459,-6.76088211191227],[1.38993305650932,-7.8357226522562,3.88900924313669],[3.61806739522841,-7.48766076253871,-0.756103576479034],[1.96288078025137,0.00519784527335621,4.13206649803208],[-2.68995136171356,6.48124149963547,-1.40188742897454],[-4.49903905782606,-5.27128648533227,-2.85954364934765],[-2.49881111279074,-4.52512782256737,-0.217816064662858],[1.30577068468984,3.25166082694799,-3.73705583010902],[-0.347944867471075,-4.84055262262091,-0.93031906138021],[-5.4694581395327,-5.96003929912172,7.80052275878427],[2.70542056286742,6.02313861394745,8.31450767664849],[0.268669089870111,-2.68118434310767,-0.423890927397779],[3.52491919633028,11.9459338113208,-2.92499824024785],[-2.20886094808117,-0.264392304719097,-3.59744261418662],[2.49398625852257,6.42509940629271,8.72713374048161],[-4.22102277342935,0.184210693690234,4.42425653093841],[1.47563927040614,-7.94835379648376,1.90527853756349],[-3.91320048382424,-5.40771180162138,7.69077319614849],[2.39604244021162,5.28826733554729,9.21213684613622],[-2.06010281447283,-0.560534697331874,-4.18332979048096],[8.54714279891281,3.08505658296479,-1.992906745991],[2.18033634572244,-4.12449133186127,10.0157577935472],[-4.71719796503098,1.53467121250802,4.36656555795885],[8.92991078161358,-3.95231156479875,-3.1521460509428],[8.835463045343,3.10570828257978,-1.26787718543702],[1.6489042819684,-2.72515444897486,-8.08990149522954],[-1.89032780243289,-3.74115122201381,-0.572821638253278],[3.95660387815413,12.0119396780689,-1.27432256930168],[-2.79649579095374,-1.81496532001777,-6.00186855629769],[-3.93689836001398,2.44151462133065,-6.54503475643949],[3.24071330738065,11.8777848425915,-0.993113422783983],[2.77714068221452,11.1986905204547,-2.06117736590294],[2.67590116268415,6.38237357977624,8.92838863435852],[2.3891454795167,5.79206187636207,8.55309897244404],[-5.36360578833589,-2.81454583682023,-9.10827555912769],[-4.19917975706049,-0.247184599101716,0.199679632617247],[-2.66077206785614,5.17361389380725,0.212938879437521],[-1.67602293357883,0.731921649746904,3.48234216505287],[1.45321765871634,-6.8508862245577,4.54331432185564],[2.23543570283081,5.11424421757336,8.2317115918694],[3.17803827433517,10.9782635229628,-1.41738459903842],[4.1875313494331,5.18657764519465,7.57610405370331],[2.74320776304732,5.99670908398476,-12.2652929881358],[-0.980898314137337,4.44193119107189,-0.489031381596117],[-4.98042275501864,8.64191760659446,-7.61454442346619],[9.53244626130159,3.56206700805854,-1.4494133123018],[-6.72593307525297,1.88114913888355,-9.14329693357616],[-0.202248151277523,-0.959677542974211,-13.6191805786135],[3.4558575414802,5.89206804504917,7.88084075674559],[3.8144530310675,1.8128254217692,-10.2843348401865],[1.89222234796536,0.759755205697384,3.76418256286882],[-4.08947309552697,-6.08698443207914,-1.65970386314539],[-2.52104695995691,5.07677030779846,-7.63110188979437],[1.10668991239212,-4.29415263294122,9.94710045470271],[3.31081719517083,-9.3461856659684,-1.94443791183889],[1.5854976978534,-7.17348911635076,-10.4266275788982],[1.19842703283677,-3.82984512521464,-1.57258352266136],[9.03622050724716,-2.19721506489412,-3.30139616082869],[11.8410653032234,3.60039233546915,-1.04586633400867],[-0.383740604614745,1.8489143868519,-4.74238501507991],[-6.17130739043009,-3.61616602111834,-4.50456867380029],[-3.48861762402287,0.694442323469127,4.13967204710993],[1.83456791107652,6.23812990952728,7.86953693709028],[-4.99414786216463,-6.51701051956737,-1.94240882738463],[1.97728543097906,-3.48984052417374,11.7091561574424],[1.7926567497271,1.45170571934962,-9.95265520889822],[3.5631080551732,-9.5304085097082,-0.748256460385039],[-5.00717351235405,-5.79981106662338,-1.09059402580287],[-2.74877195515927,4.16203717426797,-7.44186783823175],[-3.11601438728029,-4.42002030106547,6.98324173963027],[-5.13428966653765,-6.73836859773116,-9.92915181837498],[8.85186861957708,-2.41781375203702,-3.85837153648303],[2.33490748145213,5.46583831418458,7.65643691997014],[-3.43516983481315,1.3521092964716,2.91446434980421],[2.80338162631759,-9.66579619978657,0.460521382040226],[-7.75347316818222,-6.00176091717517,-0.0247991875266107],[2.14532765329415,4.23787071351541,8.14837356202959],[2.56510833933045,12.3726962826126,-1.92485602711739],[9.6425964721248,3.856808289278,-1.57283200832032],[1.45469707852792,10.1628697197315,-1.73816682567045],[0.637163059088794,-3.39529912675913,12.8989456184519],[7.42566149946948,3.64863728153481,-1.54625909015515],[-5.33473257180161,-0.700914995868657,0.501860401086252],[-7.79197595335135,-6.20604472148051,0.390386518881105],[-0.681231424674249,2.81262380595325,-8.35274076210151],[-2.43577076116236,0.215359398426332,-4.76367044716156],[1.81544600296118,-5.1499292783242,10.9205067172066],[-7.90919498328875,-6.37739153461995,0.304875276559701],[-4.73267921329011,3.36104921352856,-6.88540809843764],[-4.52928504237571,1.72296775137176,5.19697133112182],[-6.99905252188258,3.06413497598221,-4.73875321182969],[10.58525279027,3.68106981312867,-2.15460426676258],[1.28112947836394,-2.06438652913908,-10.5656393653003],[2.02112715277148,-2.83449472305409,-7.7670802022699],[8.85173578039352,-2.4116696774016,-3.70614184750429],[1.15264840217375,2.07927336060359,-2.23472472690794],[3.49591031545895,-6.42320877594833,-1.37969608863125],[2.01503479709457,-5.0488670773083,1.25735051133265],[-1.52654572133597,3.79596931818864,-2.65507597732207],[-5.64729396851665,-3.50746276651369,-4.63126613069294],[7.54540445683885,4.23181358808048,-1.38420645217922],[0.119036012743721,-3.17792796756363,-1.21278674017584],[-2.91843782208504,-2.0261100353127,-4.60570161093835],[-4.05169767083397,0.251737804947514,5.08909202442904],[-1.80529282469703,10.584180019544,3.11950694270223],[3.09225271354909,-0.217058196761852,-12.4102097073294],[1.73609109355285,-4.5386790284419,11.2492042717622],[-3.64381862108567,-5.89854254850993,-1.53565663158925],[3.20849501442127,-8.30289100616221,-0.836624889428262],[-3.01731177219208,12.2110428770892,3.76298708791579],[1.65645321486485,-8.0576777640943,-10.62611032813],[-3.55267863493223,0.337448941527556,5.49266885549954],[1.52409130395331,6.61993810727552,6.88081494636891],[2.01234233997998,-3.07315601742024,10.4819512451758],[-1.19836835023944,0.398589811381223,-7.17476495771167],[-6.33779046261618,-3.10188327950011,-4.53988989437961],[3.83155845708331,-6.81201904914483,-1.38508071160796],[2.0113912131408,-2.73765335128774,-7.87105407527361],[0.27843151462613,-5.35186595206562,3.33693375194559],[-0.64160220168681,-3.08973586839499,-1.5730165650018],[1.82015259430356,-3.40977072745149,11.8479334927807],[-3.80632318683398,0.876993068580613,5.82650929285342],[2.40378192627046,6.30111002696996,7.20762071670677],[-8.03870626795042,-6.20363901966847,0.201405891320764],[1.93272899880192,6.06074182135448,-11.2787212402536],[1.63501111725604,-4.0254394760425,11.948609539834],[1.96561699239121,6.36954744640749,-11.5788073909885],[2.62312343578494,-8.69376532624161,-1.78000346744684],[-4.56681033281326,5.33262871020029,-4.23502972542298],[10.6666004878746,3.77236943178015,-2.7748409639531],[-7.79380670530176,-0.209871814409384,-8.76753422180936],[3.13784978455412,-2.01150705740999,-4.6368124331736],[2.57490984101357,-1.15391459663208,-7.40043938588739],[4.69757679900973,-2.69462156792363,-7.01809939073024],[-3.17227227970749,-2.95502405770502,-1.16654129651375],[9.64783718141108,-4.70042131057384,-5.32982832413405],[0.974160816589217,3.56048664763839,-6.84423602623768],[2.52202854742752,-2.38136250818539,-6.49309402474715],[1.30738566778715,-9.47001841215507,1.15416527791864],[-2.20391422228094,-3.14200233648611,-0.553955166777961],[-4.51039167144497,1.05000217499617,3.67422795264332],[0.739654769907385,-5.21605494850469,4.41132847419811],[-2.9859792892793,-3.70091100699569,-2.25943286784998],[3.94658767399484,6.36132435809435,8.43219241352456],[1.50063636893169,-8.96275449236336,0.56531644700253],[1.9214722994983,-9.35528830685831,1.74154958200148],[4.99843975629741,1.41745417157798,6.41407411066459],[-1.9775796626684,-2.3626269563758,9.2681747944701],[2.96916046200418,-7.93620306396563,-1.7282013551778],[9.85341016809333,-4.6908369303323,-4.85701493328565],[1.1610280823109,6.41947941835395,8.78392641528754],[-2.19262171653796,-3.23973524910236,0.238400826351941],[-2.68069229532499,4.4527658399318,-6.89126698119779],[0.993330364624515,-3.26316630621471,13.2813737385076],[1.44343655886071,-5.24364598503477,3.84510876335005],[-5.04056220318275,-6.47356092319404,-9.48583326548393],[1.92076542527755,-4.60589329896998,-0.338004831144949],[3.14116998598202,-4.78797495702304,-5.57526288205105],[0.627487626895453,-2.63998148873555,-0.112144969733342],[10.0016891797203,0.159749776596125,-0.463247034419655],[-3.28848641060736,5.76810912509554,-2.56334328546984],[2.35970659143987,-7.5775992538664,-1.84730760253985],[2.79200822650372,5.78023182114767,8.47585054378392],[3.2969020039807,11.1902816372831,-1.61387716753021],[-7.73179640727369,-5.55401650704614,1.88359399077784],[-3.23446344200663,6.66115938529901,-0.812945302554141],[-4.85661681558958,1.07229392760841,2.95131917174328],[3.50306191847492,5.2826516666723,8.3661420247623],[1.79549207402269,4.03390628236269,-5.71058905056533],[-3.78587581850971,1.29454405060978,3.97293707679903],[-0.739696059111032,0.429215853955694,-6.67188437037487],[0.625285684134716,-8.41305695866053,2.66933710104194],[0.150255915397199,-3.10142535206049,9.78682084931644],[1.19275939688321,3.88703901655464,-5.69677448880267],[3.16462625617293,-2.7177480631633,-3.64059680042988],[10.3026749015671,4.25265411411901,-1.09554908178651],[1.00137763891044,-4.292951820714,2.56275689543623],[1.01106782248068,3.78162520910736,-3.60321241025194],[0.329335001856123,-2.00436346974788,-1.01493068517655],[9.55536100574591,-4.56647353357888,-5.89595511741383],[-4.00253283402027,-6.25911292697248,-1.51802051366111],[0.0287371333068043,-6.6925834397074,-1.07703720733442],[1.29083151034829,12.308586441865,-1.56695628571552],[-5.97006809030576,-2.76940326825985,-4.95646171879311],[-3.36054951998222,7.87387964830355,8.82206420057397],[4.33488356321323,5.27002306897618,8.72322671473095],[3.02739543238264,-3.97911577677033,9.80829220408211],[10.1107072124289,3.58750277707366,-2.8276058242921],[-4.61997879252189,-6.30207542663727,-10.3658366695675],[-1.51707146589611,-1.08069590621049,-2.86296795873428],[2.59111178229022,5.9865779898774,-12.450484435323],[8.45205264311575,6.75840546449465,1.58423853916959],[-5.05723210519714,6.41076916787157,8.74783205385001],[4.55303492578636,1.31540404712521,-9.63038063155462],[0.742700842452061,-8.78342759073825,0.541440329458184],[-0.0135957267697698,-0.968619510431853,-10.948881381629],[10.1893923925034,-0.575612276393815,-0.0200788490420113],[0.607324167813033,-8.54009878137764,0.0784670250401469],[0.256242104021745,-4.07879946290301,-0.235410989058271],[-4.5366314609878,-6.58943573785037,-2.60747082874642],[-4.48008936513683,-5.04770250957705,-2.71374508360479],[-1.29793906153842,-7.3144421623914,-0.70970274449041],[0.609053455206831,-3.50349395272766,11.2177469332605],[1.4149266932456,2.47471878933717,-2.44866524998472],[2.99441026815034,5.91225795641739,7.06596816498384],[2.26505903451773,6.15166516113975,8.75364801281212],[2.89133589242119,-8.58555832306971,-1.64747875032193],[9.94328850960535,2.35000225649875,-1.91459732005504],[2.6017859412817,6.35235429244772,9.00991316245307],[3.61586346946356,5.19650963001932,9.23122558371702],[-5.84778591681451,8.38451392137501,7.50279541514471],[-5.81687614648597,-2.97697473125372,-5.01899221959246],[2.79610610089234,4.21576522259836,7.66116323746092],[2.36909753050309,-8.44760931052784,2.65750548138624],[-1.40976674151286,-2.28760751923439,-3.94998187629574],[0.349212839664282,3.29123177857598,-7.07092600992492],[2.96474472118156,-9.52231985550883,0.0905230376868494],[-5.981922860643,8.28241073808707,7.98240107879605],[-2.78286082226823,-0.449339801493267,-4.92921296826538],[1.34161672990848,0.526151772622243,3.79720605818428],[0.230739439095888,-8.7224117055819,1.56340962695966],[1.91339759803346,-2.5907336139216,-7.98490051944691],[3.17755293815332,4.99634580769823,7.76495336597879],[2.89383856260067,-8.72460269195989,-1.9786380087125],[9.11912866434178,2.81006957267303,-1.8136234429139],[-5.30850922848347,-6.27426110356293,-10.1854191150673],[-0.535759064805305,0.3216470844143,-2.83195555756443],[1.27401932727154,-3.50826756917233,-2.66477760413012],[-2.16376043137164,-4.68615634829028,0.144267671622921],[-7.92181645419913,-0.573494103410212,-4.68733220570656],[0.0371059819016397,0.676384808649118,-6.54449328502872],[2.07186107091257,6.0024412405226,-11.8386152493634],[2.55141071932375,-6.77306805472664,4.46668997700121],[2.66800604079015,-4.03261722756338,10.6493660241635],[-4.21395995031089,0.610544546388756,5.28526807218175],[8.96228696005153,3.78041651312126,-2.00332554810539],[-8.66107821785406,-5.99398188672515,0.888186665104767],[-1.01118040016376,-1.45402506182246,-2.60355538276644],[2.7114812509546,4.54643665444024,9.04512209762646],[8.48945123190507,5.59815792746325,-1.24298320838843],[-5.4052749915833,7.72625446030499,8.87351083543398],[-9.25093695114413,-0.727293074092544,-4.4056057541136],[1.92901938089782,-5.01143655332577,4.80622482638317],[-3.62079088839549,-1.27011285169194,3.64864065893191],[-3.90914347486946,-4.24955882893981,-1.99425340307537],[0.0555274668080012,9.20350437814037,-7.53383294313668],[1.22573544488746,10.5437688301556,-1.88236118712474],[-2.16704323104356,-3.50345903899366,-0.220979920441321],[-0.713714393651254,-7.68866833506791,-6.23657268383571],[-0.537447989283538,0.687774503909218,-7.55550897393225],[2.37342622866,-2.59322611247253,-7.21320895139152],[-2.81921425778342,3.98569122932637,-0.0418082924562038],[-4.15896706959983,2.51999364319914,-5.60980676591738],[-5.03006778227423,9.65244562628652,-4.03808369272026],[-4.86161206003947,-6.00868445564749,-9.29995926650733],[-4.27215761893806,-4.12188820260034,-1.74347958091746],[3.0251269087219,6.1257768803525,-11.5927759327482],[3.30344797188609,-9.76068977465316,-1.51738331614963],[-3.92350246574765,1.36488591867029,4.1580040230823],[-2.39537484838213,-3.54637771126657,-0.608181663327532],[1.22986665864653,1.81718733669617,-9.6672116362218],[8.0647393245602,5.82258028603291,2.50238634408636],[-9.3816169410639,0.745961521150225,-5.79201496030458],[7.0678737826388,-1.77282494228539,-10.2487709513832],[-1.25979652892667,-7.11113045315816,-0.0312515488642947],[0.932580236084763,-5.56320248329866,4.27081736759792],[0.460568948818105,-3.15974213257872,12.9005276097535],[-5.31991766798322,7.04365290675328,8.67088733802263],[0.474180201028154,-5.84171105837856,11.077777096979],[-0.556351693516374,1.08194286221763,3.77626941364401],[0.0298476423264705,-5.98806789586264,2.64808985678126],[-3.16784228914755,4.37455568716214,-7.41674148383307],[0.051257934259247,1.18526878996674,-6.76487289579563],[1.09325515480743,2.57600016482007,-2.91517839164089],[-3.79730763466163,0.997907021506538,1.94879976196382],[-3.33354823828045,0.829710367258332,2.92416527715126],[-3.32546213900339,-3.68568756805793,-0.974620703813573],[-3.50015086735541,7.81465501994706,8.69740568132206],[0.172255719981438,-8.61018616986265,1.79623149376685],[6.71407830276038,-0.920991387253435,-10.5112629873654],[1.43673405521922,-3.64133529704048,11.6043323367162],[2.25793570759539,-6.63462304794344,4.430578005977],[-4.29954822362722,-0.56483124014223,2.21187034935836],[-5.71258933330194,8.61833707338318,-3.86088349626736],[-2.38162110477891,4.85639047115003,-6.88375141777073],[-4.78068737635596,-5.95658418334267,-1.11865132908216],[1.95656967897714,6.55434980873273,-11.3081706126983],[-6.80571258942691,-6.66476896611941,0.731778752280896],[-6.68537225099499,2.99705769006708,-4.25104935635971],[-5.13133138245571,-0.17743617152514,-0.298129581838999],[-3.99866837388657,2.4356977204979,-6.72772355278976],[0.566872280627845,-5.93689485928912,3.47441681960143],[1.80710238545709,10.8691526105415,-3.29411847412253],[3.83197873129264,-5.89123842318779,-1.63998468834665],[9.22571151332073,1.56065429404548,-0.993591138909772],[3.34652628077722,4.20194131315381,8.22226167920025],[-6.44053833351332,8.49020967191969,8.08073099684544],[-2.39488086233959,4.545155120971,-7.45838912493646],[1.65953397452943,-9.80724361888527,1.30863176158008],[-2.40462756127525,4.71918990771842,-7.18651911845007],[-4.08317487024288,0.3728262227104,5.4730566509745],[-4.52119002949826,5.07414339289898,-0.0729693201815059],[-0.580768058002951,1.01562407944111,3.89156422770818],[0.412940006984263,-9.25941706387462,2.02864385818846],[-6.85213119365983,2.91370887367431,-4.0290436999682],[0.396646915251852,-9.2448998740319,0.93401902148685],[-2.88740315381727,-0.879252622583793,-3.98548110279252],[-7.145572616242,-6.36727261035501,-0.011113318936046],[-4.61509764033658,-4.63182330853649,-1.51928163752748],[-5.87545527322325,-5.36252059747625,7.76835386245872],[5.06681646668167,-1.98554267227818,-6.7794149191427],[0.868287023305552,-3.17830806281425,13.039157998143],[-0.567081420639933,0.636510239836454,3.17043681552033],[1.91110996824541,-3.66268859953746,12.666497667073],[-0.969976405270588,0.653601741364837,3.73290395663314],[7.35607656603574,-1.55642030105761,-10.9465488812108],[1.33782660882088,-9.50115438848009,1.91125559237815],[-1.63651707648855,7.54623936797519,-7.1541111924711],[-4.69254433844479,-0.875116864311986,3.88514396968228],[-6.15223024248826,8.46938892326538,-3.82101672986023],[-4.8036694172247,0.429309345034603,3.06734591657898],[-3.79611580189067,-5.74668517105895,-2.00788392310025],[1.07998951661322,-4.61613881602525,11.360229805716],[8.82133531343483,-4.35498750146141,-1.10823846575897],[3.90171812061445,-4.69994466157597,-1.6494353030873],[7.9919720713145,6.2522483620071,1.11659844880206],[-5.80531923393236,-3.04845205446755,-4.96250281559579],[4.58188256813143,1.96339083208236,-9.74318637907058],[1.91708213369881,-3.24166549324876,-7.55570919277358],[-2.53960824213376,-2.8182608701837,-8.79013047564677],[-4.67013203414698,1.73933504225164,4.21023571052028],[-0.818330509687471,-1.67870775460246,-4.61944876586237],[-2.32797800236271,-4.65604308222934,0.0925318045570186],[-9.71209178213863,0.146257061100523,-5.82551599325759],[-4.32776287597109,-4.0729295186633,-1.29371524450184],[1.00491611649244,-9.47297915395816,1.13241930350553],[-4.90024923376907,-0.856417970933556,2.23154739262056],[2.78476273455565,6.21165105255054,8.60583368082911],[-1.67803339534598,6.30731109878684,-1.16329180508399],[-6.17504889385634,3.36312227399462,-5.98037939229126],[-5.3829106767499,8.50935546465564,-3.84062575355754],[-1.705656286003,-7.14971796724067,1.45386307576817],[4.02578853285284,1.01863980032787,-9.1991752319422],[-3.35997028955711,4.05893708493943,-7.08068142601497],[-3.76740461099146,-3.53017966379351,-7.89388644021999],[-3.46394725450075,-5.5149015615434,-1.67743539449248],[5.52340524099789,1.36417465054877,5.19885353849575],[0.0381379923291054,3.81085755083278,-8.59565864863332],[1.58592186948771,-4.25279967278625,0.442997474930143],[-7.10224212638912,2.58080362311805,-5.02740252313206],[1.23827290246961,-4.30042408489079,2.59692743551989],[1.56074293420237,-2.69279914444115,-7.71036934997908],[2.40268926733339,-8.8964744142954,2.50382536898696],[3.15955431972314,0.624584826587091,-8.72916908041787],[0.977154404599537,3.96547240681054,-8.50414676061532],[-2.53622879490421,-2.77877153851589,-5.87305823047142],[-3.26562216094121,4.04723524099326,0.287607017632089],[1.4437861815584,2.73794962613226,-4.14030185667359],[-5.38053540838653,-2.76748531025293,-9.09639127268385],[-2.71486061422025,6.58540086954557,-0.204457954836359],[-4.82212567085217,-6.80119235252891,-9.22258319333794],[3.72807510619917,1.87767027775848,-10.1556502370073],[-0.304123313176394,2.40712506640778,-5.49655036051821],[0.508544392164459,-8.10754181494502,0.994463155047644],[2.78400716557153,6.04412265528941,8.19152551508912],[-4.75211593793356,1.072497559178,3.36478979606216],[7.27355289544538,3.64258432817607,-0.699522467047477],[-2.90231864510605,5.66626592901279,-0.707649154319244],[1.33552624617079,-5.23142284504802,11.5099777298438],[2.34214299516651,6.33682288364953,-12.2079713663657],[-5.68670889807369,-3.23047153267438,-4.80125221233453],[10.4791234057889,4.90159872356414,-1.10796423462583],[0.304327255969261,-8.3143951712511,0.090256052141701],[4.27401780478259,5.75406483123732,8.14618101224166],[-4.57110997021869,4.92610646861415,-0.158530540927964],[-0.283195607113962,3.23009096586886,-8.67476554055317],[9.19664472075208,-3.93420352145738,-2.12051806224362],[-4.88140845843416,7.23504514845169,8.92613775422129],[-4.85585755263492,-6.18872626847751,-9.52590548184001],[-8.56023123734417,-6.14648375972535,1.12620163855189],[4.04035337815394,5.4416674403957,8.71273447853984],[11.687150539298,-0.221360753657601,1.0442879070349],[5.2776635541943,1.37689318780754,5.53221185752983],[6.18543707338713,-0.655651027499766,-10.0629336585696],[2.29505518549499,-9.97037673292775,1.44381137785897],[8.77504380516129,-3.8362067770544,-1.84295900295866],[-1.69995735514776,0.423424725038791,3.51467697324574],[-9.33267409228957,0.387600560583391,-6.2111109755356],[1.72724417130972,4.05475274513556,-6.26929007094576],[2.57188957030875,-8.0528572346546,3.43180164790711],[-3.27623507112764,0.127785030274915,5.8365474906178],[7.64460798757631,-2.80614009816123,-4.90008498259752],[-5.49894334078326,8.38910603511449,-4.64488132624492],[1.70697226252127,-3.06061058355246,-7.80892002352778],[2.02750149845986,-6.03539685428652,-0.175644483360874],[-0.406049110787552,-8.45835070239741,0.764799800953739],[-7.5329088867972,-5.78233281079658,0.193856089089615],[2.63893101869811,4.70924194857692,8.25434567727022],[1.16137432356927,-4.20490609703002,12.1491162130495],[1.9330567968908,1.68892557697291,-10.2337169542525],[-4.23811223060272,-0.587356960170886,3.29800313772434],[-1.77635047658517,-0.724700573362284,-4.39968682059992],[-0.311514321870159,4.6037029400373,-2.17639977062963],[0.316024731343446,-3.85860036507764,10.7781826617454],[-2.04467866075299,1.56089189607651,-2.20593779715703],[2.34729704318649,-9.24565842868255,1.81079716959666],[9.60156334723331,-4.84612787137561,-5.08832917322015],[-1.43906374646484,-3.40125677600514,-1.15923350797163],[3.65428200894205,-5.0563746020737,-4.8587274034316],[-5.6509676751845,-3.32224735405334,-5.40172027377489],[4.27567605270473,-5.69167637171583,-1.13521708931137],[-0.753609862863935,4.00349402012882,-2.82937437324115],[1.87107715894218,-10.0508848960272,0.174167334330057],[-4.91026862357495,-6.07499648385396,-9.57449942160523],[2.50129775396368,6.66984956469161,8.17446752984773],[1.09439793803615,-2.65395487102948,-11.4488139639909],[0.703731487245849,0.255639073134265,-2.63975622325815],[1.78319412880542,-2.12193282379164,-5.87409041812572],[7.5728475317293,3.40450695542066,-0.330740768065157],[2.42166039090591,-8.06639884714065,3.30553913099592],[1.83494561526192,6.26031447423219,-12.2707860295141],[0.149927318590081,-2.82045655196265,9.98727055976288],[1.05708294262335,-5.55071808520512,2.56759844334601],[3.76080673827048,6.38445498162706,8.1315527796072],[-2.30042501427566,-0.691419147874154,1.20654977525904],[0.551142467269282,-9.11682857693307,2.22330711668189],[9.07030309219076,-3.93065855066263,-1.96018993755689],[3.36731825630024,-2.03794369548215,-4.60665841629941],[3.44720730512961,-5.66629829038821,-1.39235848757019],[-4.29059147116354,-5.23286706902107,-1.08114802100809],[-3.50034378605568,-6.35544089156991,6.72403445325943],[-2.02089818060435,-3.9159392552818,-1.33839015967209],[3.25932310221203,-3.4580092578415,-10.4738546035308],[1.29078002114742,0.797999081008472,3.74564446424659],[5.34455262947887,-2.79926211390219,-4.0162153837951],[2.3580977334707,2.51323483062092,1.17803492353121],[1.90649530406701,3.68730832420166,-5.43591339006085],[8.95899208175169,0.816340658890449,-1.75676073356875],[-1.61345890336036,-1.98305453957202,0.862559554209134],[0.031996042808134,-2.50031909390156,-4.83767430860524],[1.03243263161444,-6.96910416946713,0.47052706884381],[8.30064656855881,4.57787222615934,-0.544639199410644],[-1.76362261739508,-1.59165221664674,-3.29216369343161],[2.30321050533343,3.27687153669613,0.342484239785057],[-3.02589122281895,-1.07404013239261,2.19403965472502],[-4.26722435599237,6.44317920480567,9.09622110747451],[9.56059982437213,0.917862506873571,-0.985636158637764],[-2.88416441568351,6.55362826211591,-0.191223014016319],[1.47387797311011,12.0465166473854,-1.72708139655597],[-3.42045427864836,6.01567599544688,-0.994991403196143],[-0.167986088727577,-5.64872568787281,2.51418957223],[2.72818832726602,6.16674307040754,6.75352091858478],[0.472191093218536,7.04265259876428,-6.12731175397659],[-3.55243854528433,5.75294994524315,0.843984179219431],[4.37463040665418,-1.43591548029462,-3.14411758098673],[-3.49625647721215,1.00658113557815,2.54027664275638],[1.35295861715664,0.155253015932055,3.67992101040265],[0.11368134435681,-2.85602290496676,11.5314922847785],[-0.196027554368483,0.898720891404258,-7.80532091046134],[-4.22538049948721,1.29053346582491,2.34082849710207],[10.5575052215624,4.92895500359129,-1.98710400695941],[1.38236377494357,3.33853088555921,-6.71022949673791],[0.111665600481498,-7.7168183831595,0.223067915310806],[3.00977193981128,4.72871934940284,7.82943660210306],[-5.07394233434919,6.3750429003368,8.15406752791228],[9.29075844527613,2.49051609228769,-1.78792025400936],[-0.742147641203544,-1.56931342599849,0.214257483323828],[-6.62343877008323,2.96306672595248,-4.01135877870671],[1.13772882212653,-8.89233895532713,0.349217609708649],[0.264963522848165,-7.86911206532505,1.80383529150379],[1.11157862229835,-6.48840723453179,3.9041024720601],[1.80184604224167,-9.12291171334517,-0.605226741597603],[-4.64208811402565,6.78276494044233,-5.10388071143187],[1.58328118803252,6.87064998511149,8.19677076729973],[-2.96850556608642,-2.91257477862427,-0.300162834783379],[3.10367351086994,-0.0698587176586691,-12.5821739032783],[-0.999841141140904,2.10820775598655,-1.82712055469329],[2.63530828173019,-5.57955691778234,-0.681064994750547],[-4.68783191258958,-0.161963962061541,4.09495345254086],[-4.93043753369977,8.48470090434469,8.19081608040423],[10.9812446313406,-1.90061931159446,-1.14499908585002],[-6.74496883078329,1.83705399616088,-9.08355325973729],[0.509075544338537,-5.45468002994375,4.38753512196526],[2.81450468401119,11.3308666758301,-1.68290923213995],[-3.14696822447532,-0.176089412369747,2.98032429942515],[-4.68254408193528,5.32314232493024,-4.1142836047791],[0.673808570491535,-4.83924211157107,10.7836242153894],[-3.70810430356373,1.2925121631149,-6.27372422189163],[3.83820599985527,6.27832560444721,8.28016253299764],[-4.77678432523046,-6.4549182637535,-0.891280800563963],[-3.07740739283159,-4.16601207400393,6.89953006071775],[-4.30556290443911,6.80250524423793,-5.15058617485855],[0.880311810031938,-5.39156487263177,-0.936420280083264],[-3.28994014321463,-3.87885508645262,-1.00397703350736],[-7.79087523066501,-5.91328359133821,-0.013103711535998],[-3.6976245772044,-1.73668451974103,4.72985562075175],[-0.570311606392897,1.87575505880972,1.10785483815489],[-0.302285591563843,-7.67968869130562,-6.19696970784476],[-2.75505914639306,4.82527466585676,-7.35967169508696],[0.551570665951248,-5.65205684345296,1.73878617466],[-4.22351866770206,-5.84374612702693,-1.18558194695392],[1.41018326452161,6.14975552479574,6.6177184478119],[-5.42514164011143,8.66000816641856,-4.42132870238617],[0.369019223340026,-7.84440360947969,1.72856024713551],[-0.723487482094686,-3.33869681374086,-1.2846013005308],[-3.27962738085993,-4.86821934344771,-1.68644102189403],[-4.61490400261371,-2.31924269296195,-4.94481549539782],[-7.46806031547416,-5.92200858371274,1.95254591878168],[-0.510657325934479,-0.437659951584151,-8.16504537031031],[10.5631293755512,3.9413949920733,-1.82027233873364],[-0.443588947159457,-7.37189759444606,-6.12002140692815],[2.35977732343077,-4.44627184701263,12.2983678347861],[3.39222060375122,5.88659374365735,6.40624069836337],[2.65585561807598,6.26965994691172,8.62748473940724],[-1.6384047045367,3.11734886281552,-1.95777194483835],[3.79565615483888,3.69498813797139,0.853621743282299],[1.41082338619045,0.0372695058227094,3.28150729272005],[1.68271152378234,12.1850021418421,-1.98568092690577],[4.18312029023582,-5.81383199644139,-1.36957079299566],[0.807253863873793,-3.02752378829044,12.5528813693003],[-4.67343350449852,-5.81653068913831,-2.97673553005594],[3.62694426638924,-4.61899303581622,-5.11284091712147],[1.62617474724402,-5.63043432169585,2.68491165616861],[1.8694466068201,-7.60552868157689,-10.3370081599875],[-4.87341463799143,-1.08196373086658,3.22044148216901],[0.90643211304127,-3.71978203403271,-1.68000632538562],[-3.09589398229852,-3.42571504263249,-1.78059748435372],[1.8438012760281,2.8392758714219,-2.90261681196575],[-6.2666348164105,3.543248881905,-4.01779925715542],[-1.34539759981969,2.53231407958547,-2.11161253757637],[-5.15031621962164,-4.98801023054207,-1.49516506887431],[-1.96847711217129,-1.65082568356329,-4.1562703096931],[1.55947159243921,-0.721526076289383,-4.38684563509467],[4.36743668300154,6.21934796554704,8.19643031564847],[1.78685412734307,-3.06446919190075,12.2234309782705],[1.45929068781452,-7.11628578426099,0.102487396957949],[0.734007597023643,-8.08485972141644,1.34843043083844],[2.95157386032626,6.68383942148052,8.68761182700167],[1.76690507601117,-7.98185321897718,2.20144463024682],[-5.81295432048911,-4.51332142959188,-4.07616566996878],[0.953233705084802,-4.55262614711573,4.28832525120885],[3.13916241935662,5.460531053375,8.33609048119742],[1.05997745704429,-2.36572282592905,-10.9860122300795],[-2.20415806810959,-3.4471808580078,-9.82560233770757],[2.92374706089321,-10.0931094258122,-0.740749557107494],[-4.65278972209727,-0.623469317746747,3.71613983447186],[-1.8427041978856,-3.87461808395159,0.291616820438745],[3.28315887757544,6.16794386798306,7.94459956211337],[-0.372926518567403,3.39470261935012,-8.78745970263706],[2.83518464568881,4.93182923562671,9.27358786274714],[2.58837296066477,5.70571210366207,-10.9648761209396],[-5.37865752662337,6.84710615950421,9.275540997608],[-2.17391844687842,-4.17308977099411,-0.981489121666553],[9.19593354140196,-3.72037543127917,-4.93250785177802],[-0.723854168284517,-7.38889097774089,-5.63917758980681],[-4.53873231919256,7.36864557365439,8.28133813172935],[0.997547897802342,-3.4615602052788,12.6855165244357],[-0.319024983178192,0.907250802299304,-7.58856772661751],[-3.4394730418012,-2.40736087490651,-3.86275101746805],[1.70847199606491,-8.23545744136452,1.80564288660545],[-4.85791798340141,-0.956841034894109,2.17884018823098],[7.07732987616794,4.09994998733609,-0.764741401619693],[2.35080740401057,6.00378836787533,7.22460686525922],[-0.275804160858653,0.952234676724649,-7.60062824673493],[-5.95747889721234,-3.26251302345561,-5.28054501448772],[-9.2471496419387,0.74164922354167,-5.74896512196499],[-1.54562580527015,5.43473670767828,-2.94971868891791],[7.64715282542412,-1.56338392392314,-10.8576143860949],[3.96476801217824,2.16815460199423,-10.2194905309696],[-2.96535473471876,-0.643402389973722,2.87730830853099],[-3.71081663616385,5.64633300435282,-0.165536328691604],[0.115851512729503,-3.19417388641451,-1.1668399094116],[-3.114641295019,-3.08312207849167,-0.46974914252101],[3.16033647122971,6.39098824384461,7.3835482681195],[3.42184492324586,-2.37685951187828,-6.56937451515875],[-0.114135971000244,-2.3850716731885,-4.8524635814748],[-6.76186777992806,3.02312617634683,-4.14724365250874],[8.35687181982777,0.780059282106941,-1.70013969873788],[1.83425131466484,6.02399458050769,-11.1287659784426],[-4.73622368701536,-1.46078472903637,2.96562987394527],[3.01633277550062,-5.70656681561703,-6.10949501651994],[-4.62623992726028,6.53838995390783,8.84977588168503],[4.98437485342872,2.89184308039276,2.07520913103003],[1.27899960178966,-8.97572911201948,1.29505283990764],[-4.98707597157627,-5.73763524884175,-2.28164695507742],[3.72324257623776,1.46238753730253,-10.1977243043029],[-6.24764102356644,3.1585820267442,-5.53753763609952],[2.82930010790955,6.40284556926338,8.39050875647685],[2.50744955791287,-0.1356941220651,-10.1171253889227],[-0.0588513023535341,-3.34050705450314,-10.8608361750706],[-5.41989203463064,-2.86362183718752,-9.09044731408003],[-7.05517595595804,-5.87081766025475,7.14059197653096],[-4.38638856018579,-0.162330239712185,4.63287110430611],[-6.98475472210107,3.13658114822901,-5.48282130963398],[-4.23368960272968,0.0720961335840051,-0.821542625782023],[-4.92281940292035,0.341423295748072,-1.00063606233755],[-4.65026893865551,0.766971662944137,4.60759226491343],[-3.7105886844076,12.3270834853785,4.20408026231359],[0.274937193533278,3.07038345249723,-7.54904275495277],[-2.40324758997615,-0.977728955054262,-1.73931343806555],[-6.82134348940064,2.89317664608673,-5.43956416655474],[1.01450185102136,-3.10835195055945,11.305778704569],[9.10775750999421,-3.42754901482749,-4.35981557580032],[0.401738219058819,-3.91907580317963,10.8909397789115],[1.71135243094798,-5.72447268301246,10.956429336637],[0.586089964696448,6.30160318211859,7.47159500362564],[-2.00835150830291,0.0329485940491387,-4.86562573227413],[11.3432262720893,2.76932051217416,-2.19081978504907],[2.28978849525975,3.94802006102221,8.16342364681872],[-4.66764820380436,-0.00713082570347989,-0.0524952385859133],[9.88864141875547,1.69518112708528,-1.81456203567901],[3.88396259188515,-8.90166981698556,-0.263566697528661],[3.83730355509795,-0.611812994024401,-2.55820539620553],[-2.36474626037892,-5.13624329996431,-3.10905923364825],[-2.97814265125143,-4.70625747502575,-7.74252135534897],[7.49586170618693,4.99068266731351,-0.897921076926542],[4.18128842488194,1.94095234491057,-10.6948742857676],[-7.12356103549651,-5.93784660886425,-0.0949508031259572],[-7.76566979301705,-0.147112673246675,-8.80608662351379],[-6.47370588438652,3.39413947501521,-5.10702911885028],[-1.58906720014289,3.39000966422197,-6.99214179522138],[-3.22148952901109,4.32186216748581,-7.33982415169096],[2.6586530146991,0.045854716223292,-11.8740887899883],[-1.98064532839633,-4.96763485703951,1.36187911379204],[-5.33141549099628,-0.93351663603393,-1.27322352164007],[-3.86416617731314,1.3701720494506,2.13661586434749],[-8.03176541366045,-6.7405455782928,1.3327922225077],[-4.18980197129863,8.29981033953339,-7.0455924187415],[1.48721329527241,-5.76433720564283,4.04917798295396],[-4.37815927878153,7.6506902005629,-5.51514570995267],[0.197586953471512,-9.18002601459525,1.93926706693974],[2.89255020763749,-0.388616275500257,-11.9085669663751],[0.494656562916654,-6.12559122995754,3.45288831468623],[3.55187854857942,3.61779761853978,8.81151298833868],[0.733124460369009,-4.29529582032038,-5.81890974990971],[-0.196425020930099,-8.03876868749917,1.65170634297286],[0.991775735212624,-3.66703577723022,10.3646833036897],[-7.86623382795198,-6.65196743510236,0.0313364596383535],[0.737701517751397,3.72525606784366,-8.96940398352342],[-1.51425662148999,0.657602503518498,3.08383059406221],[1.16889754479139,-8.74981043833745,-0.125003046624337],[3.79204548892911,-7.99729486235472,-1.56671581577801],[3.16896040867556,11.1378179627596,-1.84823591175522],[2.5989895012221,-10.0440731452394,-1.78233287459378],[7.68883366652572,-2.81269325592436,-4.93145042374449],[0.270315895183299,-4.89738333715927,3.74344409762149],[1.1521700890869,0.305591668042625,3.37538897535704],[1.17720402086249,1.7251363879571,-9.90832909319985],[-4.68070004068579,5.85371015634368,8.53377817891494],[1.34614426321614,-1.92971958721032,-10.3080566323701],[1.36002123897372,-3.10708996955098,-7.71381682372569],[3.86592049893506,-5.95250275773866,-1.96185244850274],[2.8612773517666,5.93799922188515,7.51229916890153],[1.29385877076866,3.6550251287923,-5.79173094625119],[0.534552081175365,-8.78295294411685,-0.127179287472499],[-2.60755862713396,5.04456634930814,-2.71845495707203],[1.36631169144617,1.57259791407727,-8.99232669622157],[-5.0724397331534,-6.52957838571697,-9.71262970107822],[1.74067983155972,0.23800621298411,2.99643721823189],[-2.10954438078784,-0.274807723277664,-0.129369439414592],[2.19377502753985,6.03256967184305,-12.0463169287417],[1.79031587387328,-4.47892496403117,0.356620610987774],[-6.68552391016388,-6.34282731274728,-0.647365861759717],[2.05235064151776,-2.03257236140835,-7.82208339899035],[8.8715334893857,2.44663792954358,-2.16339089341063],[7.37863419213112,3.77656442261262,-1.60819138286455],[-1.82375158036333,5.66251577655958,-2.11878338659371],[-6.17920280556026,11.3814268451188,-4.23242366980059],[0.808276558278037,5.89071453149378,8.52819744887703],[2.10762728848581,-0.0399751621296723,3.78183303816387],[-5.06826546692655,1.58298162665667,4.10490379316848],[8.54671191979572,-4.14455552668892,-2.56460092949761],[2.39083651296354,-3.07073633305496,-7.2323075654123],[2.41705570899653,6.38433393646783,8.41137999969562],[0.721002730971797,-7.41602528075551,2.83606858546763],[-1.38981163452255,-4.65067289539909,-2.89471093657713],[7.35872412913178,3.62881608159752,-0.779904610619361],[-6.7802072480541,3.08613442285623,-4.41978298366595],[10.3851432944166,4.31093052885426,-0.728940041157019],[-2.92761787436638,-5.83268049265095,5.32648685164298],[-2.36898780741631,-3.39555234184219,6.49475817923129],[4.56291533754293,2.26985218321193,-10.1329539746926],[3.18730432939755,-8.33943137794168,-2.11920758020984],[2.3265707484507,-3.03171247751887,11.1583019506012],[-4.91370290254708,7.54227924796651,8.86109360217438],[2.62868575614619,-3.83494581427204,11.5747673933267],[-4.5618869636443,-6.0924186811426,-2.41844391854431],[1.24845457218728,2.0627747138874,-1.96608173156675],[-2.34612852958427,4.47845284292674,-6.0407647038718],[-5.79512677921973,11.1251239418371,-4.63167929486265],[-5.40817517655978,0.961403314053016,4.25908908153289],[1.25509481873409,11.8622213866312,-1.56958187218428],[3.77196359058717,3.70783975461722,0.925356922870909],[-7.70715226160608,-5.68925203906297,6.96506784469911],[-1.49649436066333,-4.69982917859458,-1.21337575965169],[1.47758076534979,-5.46511464481129,11.3017243360449],[0.868220664417858,3.28415642517143,-7.8025995098854],[10.1337923063399,0.0576922391248248,-0.703367626123433],[7.28271784961964,3.53811890308949,-1.28936001242095],[-7.23552642231387,-5.60548488861932,6.77924000644396],[1.77706616865428,4.66858594153589,8.41423048450756],[1.10210887581591,2.44669850144333,-2.96966424656966],[9.61367876028638,-4.35004217053229,-4.13199555680765],[-7.96640079288171,-5.58412207689256,0.176977271664281],[-6.49389805022151,3.29200478447651,-4.06025817386396],[-8.53471595300393,-0.679101019070997,-5.17754919828584],[-6.55978680351874,7.62131038792031,8.03987485906601],[1.01616405054454,-4.34986502391975,2.72759171793658],[-2.7405490160068,-3.44837280131647,-7.98564575422739],[4.01032421663545,-0.567065579506568,-6.28549507164359],[0.794407038363004,0.405282047642516,4.34410844161105],[2.35265268255043,6.09499831154824,-11.0917058497468],[2.08287540381307,4.8649170892356,8.77268212694468],[3.25390258028529,-5.38519251751341,-5.50334870747817],[2.86480646000154,6.8014132801559,8.26736909015551],[-3.15357243040266,-5.01745843598419,-1.20295374938289],[-2.61354949677531,-2.89718984229385,-6.70116532796467],[-9.63069889683245,-0.741105894734806,-4.7619416564615],[2.36300101668451,6.05779698889776,7.72964451243015],[-2.29187950505879,5.08175204860768,-7.06036734858522],[-7.67258429544914,0.460332814228389,-7.03038604604697],[1.80798215263493,6.33354439850453,7.09188376889717],[-0.106609245104735,-6.87503350038804,-6.03443353899106],[-5.35423924654715,-5.01422898756161,-1.10947779320076],[1.68588306989183,-1.14805991622508,-6.11484998906992],[-5.22584161477135,1.32837815359744,4.83665360490181],[10.5225623096048,4.16150041413316,-2.06605335964367],[-1.34259357904546,-4.10008413768231,-1.59096417084774],[2.42530388073651,11.0792176341138,-2.49400239536452],[0.168529095710462,-7.72374132944921,1.80606137673725],[0.985820121628157,-3.15761335561262,12.4845139211397],[0.932769499868975,-4.31421935746191,4.06959394223701],[2.69028818615562,4.92713379563875,9.03673935399993],[9.57224939137027,3.25733258161266,-2.6159638812612],[2.75872073810066,-2.81182090813868,-7.12988556784502],[1.6276200755801,5.56242710986302,8.66645970650325],[-0.519474946923726,0.696352038926087,3.26774058239184],[-2.13519153959426,0.0358788578720237,-4.22471518034658],[-3.1187958827675,12.0025728392148,3.68084083395409],[-5.44617444310538,3.88391386063195,-6.2207881297081],[3.09156467702356,12.0910351505359,-2.89757818208362],[-6.77049117004134,-7.12658657360186,1.44303550844119],[2.48073730131302,0.00688226567774308,3.68791617356477],[2.82221296862046,5.95099466685363,-12.3457949530564],[-6.43404955097372,-3.88009090222068,-4.28940879108621],[-0.102125256664675,-1.33402796617689,-11.1284840410622],[2.9473768710162,-9.68567931549618,0.656913979688167],[0.536261691907646,2.78564934082709,-3.23064442650797],[7.05510615284136,5.18119169722278,0.866869106137948],[1.58666391707749,6.18247848273179,7.19465516928902],[8.9807985557344,0.372778194799783,-1.42317792885109],[-4.05705261631345,0.853866946553945,3.42335990132088],[2.95490449594099,-1.72206216304207,-4.21072429692973],[0.680450755384199,-8.97033341073231,2.31757423670389],[4.20686447866553,5.5681750031645,8.84030713834553],[3.8120828800926,-1.14155111708766,-3.85673991842291],[2.00158152126007,0.965874081079511,2.72996079096307],[0.399154689297188,5.88037676721775,8.47758444081466],[-4.99529651564863,1.78438242686449,4.34043546224544],[9.07873198085064,2.69247151158145,-2.86938805410039],[0.187340568612284,-2.58935332963444,12.5411347739408],[7.66560019764929,3.63938709831648,-0.557967322199504],[2.2539790606665,4.05691237958875,7.33920041783387],[1.84349538261651,6.36055837119474,-11.5351062923025],[8.9449009043191,-4.36030243984514,-0.889018773442472],[2.95645923861843,10.5561478151297,-2.89722194690397],[2.34694668993661,6.34576159795855,-11.9290393588812],[-4.89479159168968,-6.79532658901291,-10.2824244842439],[8.99976361193556,3.39983155310335,-1.46012465262745],[-3.97646570153001,0.842322163571239,3.07050442660368],[-7.39884341962076,-6.52674483029359,1.08977783341364],[3.58682233079857,-6.27724140546608,-1.67996667143963],[3.01220698383869,3.77006328317769,7.64300860491623],[-9.0750718350283,-0.966201624691235,-5.18204644878841],[1.48913046895512,2.55967934628886,-3.4012577839227],[-5.06347613599395,-5.76445995740391,-2.6064855975743],[9.68435152636849,-5.07688057683344,-5.18740936664683],[-5.057015104547,-5.59959914039937,-2.01598328391116],[-4.60382619110499,5.16795690358186,-4.12222805794752],[3.02344594725959,-4.19500606993593,9.90051182878915],[-2.57885045061914,-0.832469423945145,-3.96370369688079],[3.59888074954178,-3.29392921044672,12.0189331589066],[1.83257655215601,6.60669341394108,6.539617406417],[-5.35331473486524,-5.70255750668029,-2.04219529623731],[8.49019428288249,-2.96771086927752,-2.72170583256303],[3.13599517319625,5.7467132367044,-12.0442396234146],[-1.80106403557835,5.18963538003088,-3.3178142120444],[4.25183201966255,6.2131379810783,8.91899094312077],[-3.90610573238918,6.51648835386241,-0.474495570563098],[-0.663870041271322,6.36126421513535,9.18717752648707],[-4.59633692502956,1.3774225939798,2.85768625998599],[-8.31816155548748,-6.57558374639352,1.12460806418008],[2.27372841379903,-9.45617633749188,-1.82709150534476],[-2.30197859331037,7.04090766149808,-0.896540890658265],[-6.38936674901399,-5.47435408600304,7.64515602268427],[-5.42217424024125,-1.38978386083246,-6.70493430419524],[-8.72448943129421,-6.64926537267898,0.520245678318574],[-2.08341857293552,-3.04375433583304,-2.67945006184545],[2.95032553764663,-4.61133402820112,10.9707795127607],[1.88378219440477,4.41170383454134,8.22924230549021],[-5.12671020421028,9.64848742270686,-7.39755552883162],[-2.30059605680516,-4.48467900899929,0.0469421823405111],[2.11212759496292,0.494537752264475,3.89675429339132],[-3.50031474772941,0.10592282655926,5.19572792438318],[-2.65951119326382,4.7039693198942,-2.68184080683728],[2.78102609037619,5.76322489742934,8.56937722859117],[3.80485837133615,-1.94047884347674,-3.28983488803876],[-4.90147350633435,1.09098867817442,2.30239869733992],[1.0818712941385,0.240186414036656,3.88889305331467],[2.42396091492877,-2.96359062216098,10.8782979835316],[2.04018428395591,-8.74335874033742,0.809433193063133],[1.93623336011502,-8.10238633191167,4.05995759225618],[-2.56698086616128,5.28371914536792,0.874007760786273],[-2.96063663561157,-4.55715180985882,-8.7665279332883],[4.15370783406628,3.3626605507932,1.22483733651844],[2.61114719788904,6.0809441478764,7.60045278729093],[3.90930015887493,-6.38237063860493,-1.50033721885292],[-0.670556156154405,-4.4037372381327,-4.10834516037402],[2.16588655533547,0.359815987138592,3.27871796285465],[3.09108924699005,5.97759872772769,8.16891600262187],[-3.91073360807722,0.655724201965417,5.02196603162961],[-9.43112229633309,1.20341256005547,-6.16595986256063],[-4.12619919465054,-3.44135053655493,-9.0226330805535],[-2.18504532133901,1.45004830470854,3.55641897444237],[-0.783389552285384,-0.0289040768411569,-1.12222119897312],[7.33471829089887,-1.59952898706436,-10.6102553831211],[-3.47563715269842,0.272307575598259,4.29447287506158],[-5.85643818649144,8.18845538075771,8.28574230193577],[2.24537921449855,10.3391446166509,-1.41261415130437],[-1.24663405545242,4.65484472510238,-0.449528557468137],[7.85667386794931,5.41263824051066,2.52619818564598],[-3.89642412323318,-5.90302112763451,-2.17581605966869],[1.62249427694537,-5.01887261359645,4.6259671710911],[1.29064004016096,-4.38297071102317,-5.03837566373837],[-2.77675688585021,0.336687914845753,-0.624046590789113],[-0.428503473308307,0.112844298625801,3.01685686481411],[2.37836320051473,6.00602810891561,-11.2892339677126],[0.510272946855272,-2.93058376145828,13.1000874803513],[0.78819361026339,-0.248472609590191,3.18914401716356],[-5.40056196690065,3.42520059027468,-6.66629984505318],[4.1315925686207,-5.66575744970914,-1.90592598743795],[12.4509820902666,4.57907493753926,-0.930207984023356],[-6.43662395429743,-3.28835043185079,-4.5772243411255],[-4.49642835165217,6.30568380954496,-5.15731932202295],[-2.62615901010092,-0.219713643793021,-0.570901752547455],[-4.35949365772684,7.73859588752326,7.74677630469652],[12.445808946885,0.682412348222831,0.102296843116467],[-0.520422903665902,6.3221085915632,8.94897475936975],[-6.9559877037343,-6.19096583304984,-0.456661786321757],[-8.11453690323043,-7.24962814550597,1.4219721933242],[-4.57695574707632,-6.35933853165935,-9.62203855783882],[0.453782140958645,-5.24334621383171,4.08368259667967],[11.1886559749429,2.53707135254213,-1.62314414277849],[5.10451764912099,1.39071576795903,5.99926921600081],[-3.02301498389344,11.1577097867871,3.25985808322363],[-4.22624526829498,-6.15494103654772,-2.78999647006298],[2.13463867826331,3.67072988468508,0.488153377423107],[-9.66674188167112,0.115613788610559,-5.51622297434723],[4.48187151036416,-0.189616186896441,-3.47217302377601],[9.04079922843389,3.6025390926341,-3.06633194133987],[-2.5543649386143,-0.440513437362589,-0.779710946276999],[-5.96403743733276,7.96863468489691,8.841984459503],[-4.07876858216811,3.51452838635419,-6.80376426627762],[0.950252596263751,-5.13056619937335,-5.10183086313766],[-5.98681070620002,-2.6543061348824,-4.49101343345395],[2.07980679254754,-8.12012763611319,-11.0373003872132],[5.00712010828812,-3.02450031718293,-4.21950182039749],[-8.05135717784004,-6.86849919245666,1.3607587677327],[-3.75677661725678,0.069647716504426,4.11715126513643],[-2.82981629059444,-1.71449136103802,-5.24436261297183],[0.869882274338343,-6.22887707695207,0.322293636904788],[8.34688220265668,2.55460772222408,-1.42071846218501],[-4.76978051497348,4.07008681541257,-6.44745198847078],[-6.31537481360878,-7.10151683623316,1.44197611045055],[-3.45041602386404,0.302589460920028,1.96182525915729],[11.0410094079322,1.12181698051396,-0.947678398742557],[-6.216006130818,-3.6135648182952,-4.16851151158297],[10.0592910914158,-1.8106069831996,0.48007614946692],[1.76421788543484,-9.95492356154068,0.57164675584478],[-3.24322459396815,-4.22092753744325,-1.82498555720893],[8.54983460985194,4.3196907181599,-1.67638547079854],[-2.71986843296507,4.89212570758808,-4.27769946297773],[8.20243434830424,3.13874339077306,-1.53656575433945],[-4.14679890868868,2.72958926030888,4.58238812273078],[0.705722848863362,-7.84637597260141,0.772419823892508],[2.54887176874861,-9.04709845915002,-1.3163219020169],[1.16983023551872,-4.94478982558676,-5.03957946730265],[-0.172781980351972,-8.47887813077111,1.52569251487562],[-3.088524410797,4.04877041352018,-0.316411523713172],[1.40866612376784,-5.63998155961744,-1.10055676411783],[-3.23508013089748,4.19331654826987,0.912453218055677],[2.26807614731033,-3.41286672241151,10.5895574520262],[2.88250552522078,-9.23770994395914,-0.494285588743692],[-1.77808094527217,1.4352976287014,-7.10658100921947],[-0.401458411409401,-7.64921236074424,1.92761803855737],[1.3747533815171,-0.885400702029488,-6.18513547558825],[-2.65103300906331,7.46962288087025,-0.390673450452297],[2.34204983324142,6.27141975464542,7.93573811183422],[1.87363364368129,3.69139786657004,-6.4590685490993],[5.3128699682878,1.21611169313654,6.27898370092799],[3.79611226590253,-8.97186817520015,-0.627024249456428],[2.88123709924456,11.6810159675329,-1.23772821296256],[1.90440080343454,3.78483691441945,-6.09464847103196],[3.64991083503041,4.90694576416966,9.08082478831849],[11.3614562875703,-0.461233481326924,1.14224032911416],[-0.0457780856256272,-3.16509815454575,-11.5900145502222],[-2.32805986846868,5.36740908747187,-2.91360398427753],[-6.42386177015229,-3.87939221868382,-3.47430869557614],[2.56514307700183,-9.14817028472876,0.368644870482427],[-4.86476581679079,-6.6058976199601,-1.88839751604133],[1.6541292993777,-4.47478029253644,0.318852103629071],[1.60306475437335,-9.42871704849862,1.76931964608316],[-2.50782458763444,0.796674885506419,-1.34137916268863],[-3.66695876225828,7.40996474260806,9.05468223375536],[0.626565035218865,7.07793594572355,-6.07964859705743],[2.78326297283959,5.70632637602241,7.2583395603543],[3.15276463608685,5.69120853248621,7.04011489732408],[3.88741022275398,10.4581812110376,-1.4550469091227],[1.3444382166066,-7.86618671364592,2.21854067225797],[9.11631948281681,-4.34730572491757,-1.05020298320315],[0.0789849136781838,0.139527081998186,-2.67470202704171],[1.17734165437911,-9.71970293800032,0.881425184921322],[1.07718652287222,-4.84463670664197,11.0659164528993],[-3.97379374348675,1.86818557404765,3.18193400442204],[-4.90363490465156,-4.23980622039483,-2.08239449310431],[3.26379585291237,-8.96105162038828,-0.892863760867246],[4.45314494216565,2.17763604073864,-9.99901334118257],[0.993604692036788,-4.66627658815723,2.06468922881647],[-5.84636966317189,-3.46724983363498,4.61146702015683],[4.7429695635732,1.88948685473236,-8.55392897029919],[-4.19397467389564,-0.304108266146925,3.39841148562118],[4.09069236270368,-5.68594188517027,-1.43930089219379],[1.88535399553258,3.46968040998112,0.136086713886859],[12.0290232147273,3.51783904421796,-1.11816559797282],[-1.28846287957011,9.52938057725458,3.15101601008898],[9.07538682102467,4.43572193653492,-2.67452645509525],[-3.3979580300271,0.90600659482293,3.86638610024358],[-3.56951248067531,1.02180247911684,2.24951097063517],[8.09999750369367,6.26043729259284,1.6385956623727],[0.342654100611066,-3.67914351299429,2.83785508552082],[-9.72130574965706,0.761535229599396,-5.96403002630791],[0.296018664316872,7.19912413284209,-6.44497929026097],[1.48886101936095,-2.76184504020675,10.9164038635742],[-3.03730951041992,7.2220455561288,-1.31442127256069],[-1.82682993586544,9.11120471968669,3.02619586015694],[-0.0969772961930626,-2.85909120847105,-9.94186306274196],[1.32013313450207,-3.5848818916531,11.5168719054372],[-3.62471532048426,0.157387251832387,4.99764044821517],[-2.57485598861247,-3.0386310205013,-7.0224232314704],[0.94916304360021,-2.9506271306878,13.0010714700587],[-1.8437272214605,-0.225451541803115,-4.62308030926375],[-4.84959437937143,-1.24673770968651,2.83107451837664],[-5.84199657135386,-1.11974827170358,-1.00050432049975],[-0.281061641638994,-1.08754725684222,-13.7747669960487],[-1.81646257047819,-3.07092504548908,-9.75660050073587],[1.8571058012239,-1.57601842780964,-6.56039558821652],[-5.71487207242611,6.82660918967705,8.3230271504899],[1.78098982482933,-7.84771961254158,3.80779056243351],[0.893220341970516,-5.18114261859374,3.40260341512818],[-0.97982008266067,4.43350230052947,-3.29983183026597],[1.69752972964624,-3.29548233640296,12.5021034309077],[8.03823787538927,2.97169526739878,-1.01930976487822],[1.59281811181236,-2.8413324511435,-7.49888966274438],[-3.71114676020305,-2.8168036281798,-1.89252728312234],[2.51327168828077,-8.4206253805097,2.02141096234779],[-4.17051417779374,-6.85039752274497,-1.89328412128526],[2.25485890181876,0.319092269234965,3.36542600826749],[1.9765634084241,6.10989166282415,9.71821892376153],[3.35214707168384,-9.01894662603181,-0.624368845290984],[-5.01225646069612,-5.27613470472368,-1.9104806907506],[11.0874172020961,2.12832304150291,-2.26053761662868],[-3.00761208528681,-0.483071839405004,3.81566642591999],[-5.46279729369944,-3.61792949179122,-4.89700767031304],[-3.33853272937924,-3.57674155082017,-1.89974794080008],[-1.3549228544947,4.80563965833684,-1.19151036832573],[7.50941254330041,-1.51313154852131,-10.8915843299404],[3.17365658296713,6.03717675139682,6.93992940279996],[2.83637896482265,4.38526331251101,8.23405738181091],[0.504445866449841,-1.48249860627986,-10.9876989127187],[-4.50346252254364,-5.79700589432039,-2.76058784281983],[-4.36607804434837,9.99793604017681,-6.31460991508754],[-2.71147619717851,9.09112533642823,-5.81432740959131],[2.07643691299434,-6.97272154630946,3.99771632575141],[-0.216190545922121,-4.66475705948962,-0.710544436494658],[-3.93772124023224,-0.273945976392787,2.20615208660912],[1.85603810224147,-3.01165744527633,12.4502247451149],[1.65757817408916,-7.01262927406286,2.66167563644368],[-3.05985494613271,-0.871022032200334,1.34081128541102],[-0.203504409029471,4.79583348598319,-1.97703747138318],[-5.37902759542364,-0.836103415851003,-1.30809174800824],[-1.99224838687734,-6.31596285975791,-0.980836489955501],[2.43462735196337,6.38394988818583,-11.2200999498993],[-5.12684927173501,-6.27588961849578,-2.23580920496943],[0.424883040979398,7.15681735283008,-6.17020394038666],[-1.7229914307163,0.712115738405862,3.06742962098747],[-0.814250494967907,2.01259686312672,-6.79972598109628],[1.39968451747922,-3.91773572946701,13.0575302384623],[-1.06403725939159,-6.39381356005876,-1.75859491066731],[2.51660981029504,6.69835467299902,-11.2373145173254],[8.86607313231205,-2.04250673043246,-3.33099913976368],[3.44048969092933,6.40822997142685,7.71345747190031],[-5.93291115090317,7.43019159149429,8.03793252812982],[-8.94554871977211,-6.20511755195868,0.800835760951172],[-3.6726983036594,-3.98190357952478,-3.281282977024],[0.980658080973048,-5.81324691617637,10.61487912213],[3.07188490878355,11.8828377120396,-3.00095994193145],[-4.01812135215233,2.48866222216704,5.35952380210732],[0.160959861937805,3.01437331444729,-1.8425902011753],[-4.96339694659789,-6.66008399458831,-2.89338816044914],[-5.5035747378005,1.56195963337901,3.22476165509327],[-1.47335903885073,4.85403425938165,-0.934226417263148],[-3.62038043370942,-0.192209806232424,2.77453013516026],[11.1066513668554,1.00948358528642,-1.74592498162796],[3.91166092123568,-6.76232011431208,-2.26140961137813],[2.8847064354201,-0.00056494832673204,-12.2140527865142],[1.19485072619363,-5.02427698530885,-5.05163981855135],[-3.92844916583328,-2.32496811730084,4.45117460212182],[1.33733726364458,-7.06579062952311,1.97909463181186],[1.35367240471156,-3.20347162615237,13.3538590510799],[-4.02323680689603,2.69456211305859,-5.72350372450058],[1.95666927050667,-6.75592292490015,3.35810835667886],[-4.8408249002005,-6.2306145508631,-2.35405513237366],[-4.52234652019345,-6.86866726755405,-9.31361845504553],[-1.91276974126443,-3.1354011250994,-9.64181306868806],[-4.40732179094913,-7.1260635791852,-2.19807154873512],[2.78732055242431,-3.99611294425714,9.99673053817381],[-0.989530615372313,-6.77457391186285,0.829883860840532],[-4.94828875440802,-6.24708762848349,-10.2056854544203],[-8.30520454151622,-5.66138896149127,0.083760568452521],[-5.55988574029194,-6.37098131812597,-1.63195201136913],[3.88647277941167,11.7504756342016,-2.5981906776873],[-5.40843378818863,-1.37289624234773,-6.685795756276],[4.11548008572073,-1.87598391125212,-3.39404925087747],[-3.85489675131633,0.408520349121357,4.42791060768737],[-2.24173197588462,2.95448418103946,-2.61304787047505],[-5.11905002200231,7.00448425840879,7.84539627226886],[2.33798345402051,6.2021086608347,-12.5393376140508],[0.0471801218176978,-0.0907670837127026,3.39191707949526],[-4.27069742702397,6.2528033346606,0.0623926515676865],[-4.16064951013156,0.878111186811538,3.74645777423106],[2.75870328775565,-9.27095246104197,-1.76192852728659],[-5.60417423588208,7.14016258377129,8.25164714976195],[1.97519612516742,5.41635383577042,7.18526555077433],[-0.96368018712878,4.59644174247624,-0.437683556732683],[2.99680736048208,4.93344554033363,8.64721672973426],[1.49418868172925,-2.2961127550039,12.8473804187757],[-5.00696392541364,-0.490078328961063,-1.83123942309947],[2.5730742138983,5.4698935026353,9.39003182243157],[1.86027010261883,-7.53730405944468,-10.7183338055929],[2.25674204417892,0.409011180471443,3.92679788376528],[1.79308806261619,-3.04634219821996,-7.45004574889968],[0.2961718180348,-3.35234990649219,12.4239397278976],[2.91176396642289,4.2668813141717,8.23840327230767],[-4.42728430207284,-6.68369136824291,7.3880465011547],[-4.81788963132894,-7.12250243250607,-9.60070865759612],[1.22850311791479,3.6509932803396,-6.50569041639913],[2.43112382874843,5.78370030579843,6.43380918105537],[-5.17550290670745,6.28953809468412,8.63033899674846],[-2.30211938573554,5.08896261917291,-7.24803804860923],[1.22253237027775,-6.07127716426142,4.52389586887917],[-5.21765222630765,-6.66657178914691,-10.1342604670086],[2.96322397936223,6.0978819085633,6.72089660012239],[-1.92028516166327,-0.798937121626522,0.971854969589963],[0.526502741977258,-3.43499288061129,9.80011355163921],[-1.4343783457293,-3.50134372800603,-0.721736217984641],[0.333853034347283,-9.45475980019586,1.02966342897384],[-3.7417870028438,-2.1949671159605,3.91653616039174],[7.16666874028982,5.10709559129509,0.099753767883198],[1.90896175653578,6.48232812211097,7.19508090443916],[-2.61210654759944,-0.814081947312929,-3.44675250297457],[-3.76190816554658,7.96072213056238,8.12044804697714],[-3.60491019022987,-5.43078073207378,7.53496998621269],[5.50661157592768,2.59486038412692,2.56736002122872],[-3.16133710021908,-0.906240055154907,-3.88654520841643],[1.23180799266676,-4.27344809810962,-0.587402947033925],[-2.73089183399656,4.8373359220318,0.233029355083779],[-2.47136977747717,9.39245525199783,-5.63330172707936],[-5.72731193195166,-4.8937832255665,-3.9083690390988],[1.68975059420815,6.45501099111002,9.40286567204023],[0.9444362516801,-4.28891310203453,-2.24404081822985],[1.19472172032471,-5.3891208370729,0.632334805469103],[0.0685409977630359,-1.80725081238869,1.24582981367168],[-3.98876661160576,1.13669125297941,4.31885621581868],[2.18787906493341,0.757058903524822,3.59889015609476],[3.96180335740742,5.82921673557345,8.08436413379308],[9.46068143837551,2.48852072559792,0.585608915213723],[-0.267492080590765,0.906137074807406,-2.22916873824911],[1.26516810670141,4.20067064073535,-5.83540880157649],[-0.134637375995772,-5.46026837436965,1.66499465652238],[2.40831821265347,5.87626395675536,6.79617049681955],[0.740480810042233,-4.05719066179356,-2.40956924423805],[1.08941487494564,-2.85623229299024,12.6941430906109],[1.66543658302377,-5.44516193189477,10.8590695598849],[-4.33089795994415,2.7052401489646,-5.05897328775079],[3.67437345982801,11.0458144089966,-1.33561337735758],[2.09016081880333,6.3331946632988,8.99961667095587],[-6.50324285204761,8.25326351289574,-3.83519655446802],[0.726359859789345,-3.26537545847558,-5.07097291893546],[8.91263911982973,-3.92986964202961,-1.17782250718779],[-3.41519169139422,0.986904289384782,-5.91380787108605],[4.30270645872062,-5.12480739587522,-2.85402313699532],[-2.05851521518762,6.77931423472113,-1.2469257217633],[-3.53861754425541,6.70773677145023,-1.32262580915914],[-4.65343396798656,0.0195881417688317,-1.75607478280842],[8.57212415207975,-4.63194567948147,-1.03215755320763],[3.1388948513534,4.71223934488644,9.37024031976846],[-4.50309193222955,5.19356964893161,-4.33699382568135],[8.35209554228143,6.41962416398608,2.07719903304218],[1.13054259322113,2.70517197727031,-3.82814045674819],[0.285774435080253,-7.14855171268567,-0.487971178260418],[1.37990689943184,-4.42264822863605,-4.94818845308218],[1.85896941988161,-5.18431055595545,2.30212328086008],[-4.28428931311042,4.8662712265015,0.0512067220018316],[1.49272225080008,-0.0243145586135981,3.7452896881403],[9.98834118852924,2.42448730616472,-2.20933771416975],[3.91791013872746,-6.13985520133398,-1.16759086066035],[1.40641289094965,5.5793077230273,8.68314574100481],[1.70328158763738,-7.92452247673606,2.45003619757877],[-6.17103935769327,8.56765417184529,-3.85359830178343],[-1.79915363534924,-1.23222141482287,-3.50910008719393],[-2.54758185108506,-0.889066471003402,-3.47391660479791],[-0.0282852330227483,-7.39468546243108,0.624823675628504],[0.77363369091243,3.85660406667237,-6.82802453134381],[-4.73997425549107,0.0582323867216137,-1.88026182689622],[-3.72291216520455,-1.18470439355756,2.90470941614275],[8.05919451416956,3.6009420382121,-1.90810497149159],[-1.77882595800634,3.15735733095868,-2.16276826816808],[4.27544686984701,4.71372792042737,8.96356149747148],[-2.94401496511452,0.303654561489638,2.67021892865704],[2.68984115536198,3.51897060232919,0.997737441423843],[-6.24157424609007,7.36085224106216,8.08298184302124],[1.68115924786293,5.39907085854585,8.43885713081142],[3.27890503593552,5.80596944581191,8.25835685890806],[-2.60516923975101,4.58267644495637,-7.02693338689605],[2.23526631174403,0.155052293576975,3.43122351986678],[-4.43718641583037,7.90646643128596,9.32352978337932],[3.61184735128648,4.38088032823859,8.87313882583067],[3.57373378446735,5.55687194320319,7.85616142110622],[2.1413669715853,4.47661018771892,7.7893432551181],[3.19243977466974,11.9204937459813,-3.05056429355719],[1.30343950435793,-8.36014092406821,2.72340313498055],[2.30720129914575,5.23909892613957,8.43283543342961],[0.974992370333092,3.51775407117067,-8.38951611375039],[-4.81535976340046,-5.98869375518583,-10.485263676547],[-0.052250826179876,-1.75356953604145,-11.4046950556093],[0.616593520868886,-2.93734291704749,-2.47587651206576],[-4.51242498467176,-0.861619766427974,3.44751687968828],[-4.47132190373631,-0.857111027564664,1.7155613623732],[1.58556088361428,11.26080518937,-2.72417289675734],[3.38867750814068,-5.53361356642817,-5.35754652487444],[-5.29878660355874,-0.160197836152044,4.71268719248631],[0.681432556386234,-7.16430021724363,1.00027685552827],[-5.51219809105524,-1.36706818367664,-0.81692064378303],[0.230928796133353,-7.18262577588786,1.3946563538372],[-1.08353957624857,1.80431921582148,1.84035073104367],[0.819978354880054,-7.11317747152243,2.5974651649782],[-4.59746568160294,-4.00946128879552,-1.51501809004934],[-2.20058196200989,6.72518035237399,-1.74393192335857],[0.874534648436359,-4.95134279696922,3.61350781107132],[-5.00681871849604,9.60207646128444,-7.32910845626695],[-3.34879050038707,6.82313949070336,-0.727992375887884],[7.55660344711875,-2.19629423770212,-10.4615160261835],[-4.83796858013385,5.35104345825879,-0.191652246692586],[0.907145392385831,-8.0437227835975,3.19355242673291],[1.43896752205746,-3.69125710110818,12.2393259510643],[8.9061177286013,-3.86780767129939,-4.85479765920817],[-6.0512504675071,-4.07005284726888,-4.5320722648625],[1.7586325234512,6.48790685608816,7.03916349965816],[-2.66794296592699,-2.74294510342305,-6.41666421135368],[-1.19835102331045,-6.85889170571107,-1.37205928703825],[-5.44770635454597,-6.18920527950092,7.67350957648959],[1.56876653893176,-2.14781304197515,-8.21334533405105],[-2.38318404606356,-3.70559577837412,-9.75159761699036],[2.72825461010166,3.66016501273105,0.983442163079946],[3.88854567196609,-4.69989188478185,-1.19797117005799],[-1.67049579808339,-4.90955905289829,1.56643015291175],[-7.3543402606642,-5.63309621634159,7.15773865071941],[-2.45051860842582,-3.21133548411343,-7.11965557146119],[-4.57596454989285,-6.23539965574972,-2.76341490871898],[4.41665167346837,1.10668212487036,-9.09761654027273],[9.17526724029536,-4.32636453456299,-5.61671847342747],[-2.06933681025719,-3.82899776534585,0.210532968281478],[-4.81259094221196,1.96878245262155,5.15017894043908],[-4.45102262405617,0.12282271923438,4.13384774522376],[-3.02913756043329,-2.94577755804108,-7.01672903976517],[1.21228237633754,-3.93287925421814,-2.40134284012208],[9.03769879359402,-3.58514525949873,-1.74866612156331],[2.21423222895815,1.39625850565315,-9.96242596420339],[-3.3771143390594,0.391571433088671,2.32300940115742],[-3.71025984262031,-3.94648193340802,-8.55544297226828],[1.93620263864629,-4.67893233313911,2.49126020399775],[2.00839779944759,6.53696591623091,6.89945729365227],[3.2308088860439,-2.48814892650779,-6.70091289681971],[3.69210515495884,-0.366105848629264,-10.0967808161619],[-6.72699750124202,2.74437574208391,-3.93810583193116],[7.26554540602987,-1.34748064502329,-10.8839790291089],[7.12544515220837,4.29000855073556,-0.660313349798314],[1.61049355332904,-6.13660065866272,2.4985895160131],[3.93201825711493,-6.3186659068284,-0.976849209207156],[1.17112928840762,-3.50030577510554,11.0305672688392],[-3.86083690714985,-5.61909456968358,-1.60186095309053],[-4.45951059557268,5.74500089844957,-1.23623465306337],[3.56048783876805,-6.32654765243829,-1.5521583943799],[3.28184114815232,4.30542751652596,8.53196961788475],[1.52710479450014,-5.16768320397707,11.2771206886202],[3.42408722804122,5.26463137462471,7.08301176389101],[-1.95491815655145,-1.9984575064997,-8.74510892335179],[9.13852885879287,-4.32539078205119,-1.05402398225085],[-3.46991245474855,3.6738718964977,5.733811595168],[3.39797402097117,5.61617096354495,8.52359089056303],[4.10815513452389,5.09695537548943,8.00990219308061],[3.00888972057966,5.82403656463913,7.50453851253445],[-2.25879294180318,0.258470488651088,-4.76394302894411],[7.24982064380473,-1.93393942174433,-10.3912368570658],[1.0721850610452,12.0683852816924,-2.10771551105324],[1.92316147501501,-0.18707742235157,3.81342764131589],[-3.82115686317936,1.6228235315417,4.22664493632215],[-4.7369425760035,-1.92328599291814,-4.64047909554131],[-1.49941826428703,-8.26245144877904,-5.56075098817545],[-3.55255556836972,3.54075177231216,-6.52746193737694],[5.04148490197839,-2.94983250241042,-3.92784735716413],[4.51411035044236,5.66961395626243,8.79419813300857],[-7.27311138367571,0.720028731910748,-7.55746245585337],[-3.13144503626701,2.55979694578815,-5.55668555300165],[3.55125744548482,-0.420081069126147,-3.46769436821777],[0.92925238055294,-5.09079678670821,4.92686168719107],[-5.1984584553349,9.24670409749322,-7.21232757300544],[-6.12463085268175,-3.80882821585905,-4.6100806215425],[-2.5362612567723,7.10313081359864,-1.03802666199434],[-8.5087000635665,-6.5293242995915,1.5008201897427],[0.335791745102623,0.64208474674407,3.31254680455816],[0.68563571697463,-5.95597534525891,2.34415170813559],[-3.31165702411697,6.15578580510076,-0.972314604696172],[3.90948985993315,-3.07301784259363,-4.2743515211817],[2.49833862664498,10.71480351404,-2.12729997882426],[-6.16303907736961,8.10293345642193,7.85249798727995],[-1.74457273231385,-6.74013062308287,-1.53398600396976],[1.63994602726456,6.08909637352365,7.39305700950453],[-5.09335574936387,-5.76217075000165,-2.31442231524293],[-4.18725165977597,1.61933122229323,2.44262538936842],[-3.04333262340246,-4.46414579950672,-8.843107388702],[5.00542043544835,-2.8608860382582,-4.01162580522582],[2.48805575210643,-3.97702851158112,10.6733182103797],[5.44101008731201,1.37460840959864,5.14749339991419],[3.37812215146136,-5.18008727897948,-5.67910351447344],[-0.225958190637243,-0.858368263070413,-11.1303122564934],[5.18183852430014,1.31194468220192,5.13555864087878],[-2.58755540406939,9.07050709001295,-5.60087623652525],[-3.8198562131769,-5.46801093882518,-1.82527953463495],[-3.27284285122294,-0.788408366488648,3.6802670220933],[-3.60271669707571,-1.99119987342081,2.33869289475049],[-6.8090152181018,-6.11695727383529,7.19577016490131],[-2.05063254131196,4.68474943329163,-6.27581841628131],[-1.04779251523271,3.2802170656749,-2.11157233325281],[1.23367145343806,-2.05839658653351,-10.5645307764349],[3.72359810949492,6.25258776774638,8.49050589462073],[2.1033490990297,-7.74225365218871,3.2973427398717],[-6.73324202573179,8.91405077221254,-4.14630570641082],[-0.284359458733969,-7.59956055979627,1.706036862088],[-4.08087433564913,1.85557762282735,3.84572311792968],[0.315068009215378,0.757838868778907,3.90659241256492],[-3.07361189419198,7.31677492597684,-0.476627569804957],[-4.96662510926406,3.04109623866474,-6.44789674374474],[-7.57058132696275,0.514196144318576,-7.33912181644013],[9.3974918670121,-4.50117624600011,-5.88772231132197],[0.985421807210904,-3.19474065865069,-11.8598602771408],[-3.69496619398928,11.9968238503698,3.9831269269868],[-3.75391320916017,6.60433947098037,-0.232847473689077],[5.15362442609227,-1.79809117260564,-2.84046288464409],[-1.41389443800546,9.20632731011798,2.56281433827437],[-2.8688100133568,-1.88674987818425,-4.49410430998208],[-0.792268234322126,0.636412427423261,-2.94582351186893],[2.62332126946268,-6.15323461325205,4.59319155949639],[3.67590742165811,5.07908436370735,7.92255744186537],[1.44191300361532,-0.214331912548851,3.67166983206686],[0.975285627404293,0.667778976688232,3.50685135668482],[-2.64917503864905,-3.77700280697155,0.2478794296456],[-0.900328192494225,1.32236962840319,-2.72892201293031],[-9.12335768029703,0.296199100757167,-6.09413334107289],[-2.5328770286135,5.88371625205272,0.721870294302116],[0.828558770994499,3.6203635547572,-4.28947709483727],[3.16313123560525,-8.96483304283284,-1.06802452791254],[-5.03908345254513,-5.4543578694384,-2.40289000181772],[0.391422423678964,-1.40335575910195,-9.60141710167689],[-4.56813929101331,0.741695861675897,2.61411713919668],[-1.7611901156544,-3.12436654072394,-9.71102632318506],[0.808092076397093,-4.68148557534542,3.36961630282741],[1.06779895226585,-5.65881769600573,11.1013099562294],[2.83815505296699,-10.1565300049229,-0.628766229296571],[12.1715469353111,0.823076514936044,-0.670865254737995],[2.88173035807695,5.60045470085326,8.96222073287871],[3.85549339903478,5.62990028580093,7.82590601667598],[-8.49623205597312,-6.83669068139335,1.60161390985394],[9.46154881286229,5.42347265664003,-0.812652258252243],[-1.88282045552724,-2.26095661873668,-12.0061192431562],[0.469580212375566,-2.69470273071734,10.4697234690572],[-2.25436985971795,-0.229791766934233,-0.16252494596203],[-3.00107542499279,4.31010469355951,-7.30314486371205],[1.23061280597856,1.9572542004853,-2.42426419193569],[8.45555743000386,-4.39145747756754,-2.00519519523846],[3.16472903271858,-3.22710734235219,11.5581491720761],[-3.59685854704974,5.21449667185443,-0.375974044126529],[7.05009367696767,3.65840451631303,-0.340294329681558],[-3.52603999558539,12.6908731525174,4.41571415955413],[3.16783311099329,11.7281931734425,-3.28105528190454],[-5.87922884867184,-0.286605778511125,-1.35739950908444],[4.22952049004851,-1.41537362885238,-6.66755075173875],[0.217592178255754,-0.706495897696908,-13.2242481295101],[-3.93602871617104,0.0428700095111345,3.65642870959667],[-2.9601439744872,0.46338484908491,-0.0615376000002777],[-3.14953264015819,11.5762794345588,3.15336310467385],[1.12194077994249,-4.69437552209976,10.6648385925773],[3.9283747228871,10.4811039649538,-1.38623600882167],[-6.82326420729661,8.73395308930762,-4.29183503160821],[1.79137804391322,4.20118410432532,-5.66720133500221],[2.54278443038617,-1.281820387269,-7.44883930964707],[-3.31543423199191,7.10649644969649,-1.03423556447185],[-6.00657833187712,-3.75728156342704,-4.72008852555276],[-2.03711055302086,5.1992006083855,-1.32895997519422],[-4.3469091000562,9.69640203459224,-4.50142792305616],[-4.87769009160251,-5.86847703594439,-1.66479870981625],[3.48900371212492,6.05240457756792,7.15870487439611],[-0.509241794641863,6.20317249586678,9.09274393124303],[1.37000670663917,-5.55858705954625,10.8209624916841],[4.87111806099176,-2.72377172031817,-6.92404360246999],[-4.40608033419735,6.53073636342673,-4.96943051587023],[11.0385006595251,3.04477659689464,-1.28996562321854],[3.03255338236326,4.20196203203186,7.67159438532536],[2.91044129815073,4.51589793690789,7.81853833517041],[0.161959629795192,6.31887396465909,8.39160108980832],[-3.2839167650111,-2.50998741868358,4.73673407756404],[7.04124111465097,-1.22474005226452,-10.6774061961872],[-2.4285376091263,-4.33528590720634,-0.519523835509267],[-8.70989288997968,-6.70030609950933,0.187314878275089],[2.47499571533019,4.94637970873723,8.80198619291494],[3.33503743747647,10.9134840944809,-1.72849827336097],[-6.35558785757018,8.66649615219922,-4.0258131628726],[-4.86046178836778,-5.78949295821672,-10.0298417145296],[-3.92777243541341,0.888080603203303,2.01067080303417],[1.94025307084886,-10.5645914883173,0.363764802805985],[6.96737456215257,4.46036295921051,-0.128631919414231],[-0.897712010495554,-7.27010226974251,0.425971230169739],[-3.88625985640879,0.466590670622086,4.97613916243097],[-3.10671656691927,6.48880982802239,0.0027689043237179],[9.70051498510259,2.55880254530941,-2.83902321758202],[9.90016764135331,0.332984739308106,-0.737396856008249],[1.62032386609792,6.60090256255141,7.31527194545555],[2.30056097604423,11.0030654930861,-1.39556363666852],[-5.59810597365264,8.34382287046339,7.8161163379958],[1.64967296615487,6.31141967128941,9.1091124320155],[0.520819097656384,-3.38731561314432,-11.9595989545233],[1.10552922066249,0.747667542152071,3.81328134256801],[2.3526393004764,6.28418396732441,7.18434125631467],[0.184754048539028,-9.00391658809328,1.06933424154616],[2.88872746185705,11.3394587009499,-1.46020211803558],[5.11529175175249,-1.61305694079,-2.74315325092695],[2.3652754865278,5.36844845471747,7.35295725004574],[-3.50500276215167,6.18687131598767,0.480236304847523],[-3.0042824440063,10.848967428637,3.24727668585413],[2.83306894067474,-9.2362070869057,-2.46500852825692],[-0.967972484890715,2.02976484803318,-1.91437740554187],[1.30965718289601,-5.05380529444271,-2.14382580465466],[1.44578551064552,-8.02791911812014,-10.4922267939026],[2.14389896895394,-3.42924412209128,11.951426405106],[-6.00076122275919,3.82458712826891,-5.55808201743025],[-4.73466653693966,4.25004876635703,-6.440163900321],[9.19768040959497,-3.7278641265654,-5.27969407681767],[2.69623349869329,-9.38915374052481,2.19974875938172],[2.84098621751451,6.08267473458328,-11.9551819905133],[-0.188059962027904,0.912470458512733,-7.82160435899345],[-4.52998429100557,1.00554096831721,4.65464061768248],[3.35105189085587,10.0901855233621,-2.39829681149746],[3.06024537525582,5.98108522490658,-11.9487285315331],[-2.49913496872071,-5.32050736785904,-8.05195732368392],[-4.71129764227588,0.627364741490401,3.02981222829206],[5.06730719567089,-2.9832723831112,-4.12397719839576],[0.445176205489773,-2.60717036720024,9.23022742439802],[0.953298032563632,6.4387747929618,8.4989207544935],[-4.2378322721899,8.64031329278984,-7.12359537206872],[0.592362072506827,-4.69205852650071,3.71012207408407],[-4.81629873930112,-6.99835916036441,-9.94413202967839],[6.88824253394703,4.18349451445029,0.413679846484193],[-5.79118646058534,-6.02715695593207,-0.864761244660331],[-0.00823346266298153,1.10924874180227,-5.60067099057639],[-2.77714396792967,-4.77392106423118,-8.6983494248276],[0.445578105647776,-2.62157308268527,-0.577992693667919],[3.25161539300515,5.72726816332019,7.48917197908363],[-2.99129115006191,-3.58637427402179,-0.298402682025773],[1.68764724181417,11.2265457479606,-2.37975769449022],[2.30419755736938,-7.20243514643373,4.58014477540477],[-2.86873981009716,-1.95545482881968,-4.41101814139721],[-2.95511830406412,-4.47444455521149,-8.89513006879712],[-3.78389334007391,5.04570710631993,-0.68397994447329],[2.1963611792049,-5.69714698352437,5.06892503194837],[3.42186449225172,-9.54232829607365,-0.896367533369103],[-4.65199016988711,6.38381415793133,8.84147882963819],[0.841151490058333,-5.24714324355022,-5.12163405420223],[-4.23398126139417,-3.50266359459118,-11.2213572479114],[3.10467044772481,6.09640984251847,7.07311191108912],[1.4679095462712,12.0795756761045,-1.32730859874171],[2.72071421732214,-3.11611731956943,11.3897037260429],[9.57197935115206,-3.97859614825299,-4.67314265383156],[3.12421868744922,3.13665861182153,8.17832736580594],[-4.43619913658464,0.764274906942113,2.90873254050341],[7.63768604960102,3.09915495219742,-2.0077957111975],[-1.04804860311623,-0.0677803187885679,-7.22233111393151],[-8.25338099537888,-6.20258164441999,0.0221795289419761],[1.99389820128843,-8.20351018922277,1.89299004666855],[0.204329791838272,-1.85901153069676,1.25573260862019],[3.47225112705569,6.50713791171912,8.34331180608423],[-3.81230474830458,1.25858869086417,3.13658193206733],[2.46448573477387,-2.21361350551992,-7.10962932786963],[-3.48578714216336,-6.36357751635503,6.56266585696722],[-3.86100913645195,5.65265968666525,-0.581007999484973],[-0.564037295722061,0.612979730582519,-7.48384730063323],[-2.82557527244555,-3.25635709166078,-1.19928481809659],[4.18691842083719,11.2442525119677,-1.88615410879398],[0.172224914049477,-0.672046139274639,-13.2223909586839],[-2.04201443371828,-1.89172466144012,-3.07119914423718],[1.73061272939053,6.47959106993759,6.90867797069784],[-5.24605539747941,8.67736024577996,8.01200693766154],[-2.06533570250298,2.67334474709311,-2.12636029869462],[1.46595295430507,-8.86240094048319,2.88853057635742],[-0.368333650386219,-7.00076847494398,-5.96999952552248],[-4.96151300332651,-5.81566338270633,-2.06538644535794],[-6.40170854422617,3.32308153446634,-6.21986609037578],[-2.71667148442062,2.12433953312476,-6.94754405095268],[-5.32585896371581,7.50222836485155,8.64737927905106],[2.75948250308898,-2.4442140303658,-6.90722751647621],[-1.67307239488855,-6.92223152678852,-1.20486642093883],[-4.79154929034717,-1.09817576518763,1.91936419618366],[0.196044590353447,-4.83512446009232,3.43380664056295],[0.712644409223645,-0.0260928598151113,3.15637178810741],[-5.36233544115874,-6.2693347349729,-2.00455110439405],[1.6764753699603,-0.541522330733954,-9.77709772242819],[3.18012648880916,-8.97263712429507,-0.918464187924252],[0.458702053644822,-4.70341406725145,10.8624749260292],[0.990289933601539,-5.72225366697579,10.9006479287321],[2.83115291227052,5.79136154384654,7.62713777598889],[-6.04148839938704,3.44610043072871,-6.61810451783327],[-5.93969288077659,-3.66271479924638,-4.36468448547734],[-1.82054248019759,-7.08261734593964,1.40459971420389],[2.56637696176937,6.37535833957767,-12.3263111369283],[-8.7117188494275,-5.55566075924971,0.81779387688477],[1.09797486123325,-9.35272397544631,1.96980018305951],[1.2920162646569,-4.6203867560457,-4.91432726042396],[-5.31495548488049,-2.67898358230636,-9.04295819681321],[4.05880004626104,-5.82633672776199,-1.49891794715673],[2.88207052058339,12.0272154606234,-0.962334957416678],[4.16051549428328,1.75608574277613,-10.0888136252809],[0.899371146534605,-3.66401738817996,13.0214913649884],[1.07448170314313,-5.69976511483078,5.15350284412807],[3.62293322756775,2.86636501472105,2.75397681190895],[2.62651468095539,-3.78527360026273,10.0979625799011],[3.16100920819613,-0.221944376362968,-12.6228210270443],[4.90968156110802,2.72707010425541,2.54791988880853],[2.98748120064974,2.00069813205,1.30797593609316],[-3.8660049661155,3.32815407386685,5.31537798714951],[2.98830544135147,11.0637752222316,-1.36393061914271],[4.53123225592477,2.53630799504879,-10.0206016797944],[3.29069272403648,-2.33013534595613,-6.59881968607814],[-0.919161071583294,-6.10381314092067,-1.72741900823224],[-3.89532830144938,8.04791301558498,8.35885823037024],[-2.56523024678379,-0.344738079398266,-0.00327292823011222],[1.73321250207343,3.51892532464131,-5.59928358535487],[-2.79346397232834,-3.2573431179773,-2.34497959204936],[1.00408430480357,-0.56104967920803,-6.30358434050255],[-2.51363770041918,5.83862014814339,-1.24156993320502],[2.41142762390266,5.99434329312828,9.31724804758131],[-3.49304935497218,1.01895928993586,2.62441164798331],[-7.51041549833863,-6.19130177999884,-0.188400932736112],[-2.58228048522428,-3.97143313279289,-0.346174812154085],[1.78779679831776,6.24608651626188,-12.1087610905628],[1.43339712577454,-8.09221159967875,-10.5241271245791],[2.78689866293841,-3.39513719923346,-10.9672042977911],[1.90581769140511,6.56075305831463,7.71002420375569],[1.79085172887743,-8.28758844871792,2.18443847522982],[4.07691980446159,-8.77184754288257,-0.501249034163116],[-1.9346069901851,5.70682146213969,-2.51111897942411],[1.29006449699014,-3.05002900537979,12.0267680673908],[1.30750762883978,-5.84706262953017,4.96190124840592],[-5.2273723319074,1.48015208773521,3.42621674424672],[-5.27685476464693,-2.56009328743304,4.41772418452226],[-5.11745588803023,7.58979462740653,7.96696907403718],[-5.52190409676731,8.14146972508605,8.34347921707448],[-1.43033238611235,-2.2419703789649,-3.92105080672965],[1.47577167937103,-6.46361074077142,2.77009448565583],[-2.5564128870252,4.03464176833946,-2.50994085180285],[11.7625085937847,2.50893905378739,-1.86013687561077],[-4.22717776304011,10.0419472421275,-4.9237998108629],[4.05468995433326,10.8827620405952,-0.90447404596738],[2.6828181422918,12.1083833498625,-2.36019351218756],[0.441389612531426,-7.0111091627242,-0.0367488420082919],[-5.21984562976713,1.45470051432578,4.48340130081388],[-0.314349426176201,-1.83795888616427,-2.76568954207686],[-1.13422429777466,3.4194608686294,-2.63746714604583],[1.49795158743857,-6.39230824083728,-0.392687306952329],[-3.1298984174517,3.26202698458868,-7.09283703756241],[-2.61726514581988,-2.93504751701458,-2.95833529513151],[-5.23166412884698,3.208724999464,-6.81535817596697],[-6.09749303702726,-3.18973521890542,4.82763676354745],[1.48440053183719,-0.21355279292799,3.39168388923379],[1.43955470504666,-5.96095625316611,3.56491365269879],[-2.95145152569758,1.02020381353485,3.87259193163712],[-4.40221692094726,0.466268057779211,4.77492164064488],[-4.20937309129668,-3.50811179598527,-11.2702108683756],[3.67938538819218,-5.42313611916052,-5.19814052039386],[8.45318563797134,3.92436062104043,-1.25993822628341],[-6.7620727513642,8.38201818300032,-3.92813749545868],[0.756768640120047,0.461382596651805,3.25492798905934],[-0.767950335689116,-5.71456128799336,2.15140122106265],[2.68574221294974,6.66418629405101,7.33208321844102],[-6.41002464777311,11.1743208264304,-4.12211742531519],[-2.50037036034333,-3.27946027604858,-1.06235456701172],[-0.786982964239858,0.434897433993681,-7.45565887915978],[3.78006675231579,11.9633086812063,-2.73554175360068],[3.21375403262254,-4.26886546743963,-1.22314314222577],[4.42413893485118,-5.55775450180105,-1.45706613078741],[-2.17737626541577,9.06712792852777,3.63837906362152],[-0.269298964447475,3.11395272117243,-8.38379577907703],[1.67576177596108,-9.15142161183274,-0.998160293132275],[1.50532854058135,3.9251889980477,-5.99936368872844],[1.38430885335169,-6.66579400591873,4.24039972434428],[2.48830220368753,-3.84081750347582,10.9751789147053],[-3.81111079849382,5.36370952462277,-0.874658023008932],[-2.73418753596903,-3.98439974803208,-0.0261618371152515],[1.43257239137415,-2.69198192077783,-7.47405734675307],[2.08038551370047,-5.09113179998414,1.9520987447442],[-3.82881373832327,8.12202206348036,-5.52163326657236],[1.60519826408958,-3.22826811943292,12.3510367684774],[-8.08950207371093,-0.457851633519517,-8.24171503664955],[-8.77945395120954,-1.40515593558736,-4.49088085608725],[2.12308900837782,-5.25205488522512,2.21324169122526],[-3.14103273877002,0.841706036385684,2.64903955483037],[-3.47194431736564,11.2195837560941,3.31155602547899],[-5.37995297157499,7.08864466315812,9.10453169054468],[1.3874330713516,3.20266709723068,-4.02452242672667],[1.27857921578184,4.23966594375753,-6.15436881399249],[3.05971195201514,-8.72663753155347,0.246229136928438],[1.92877043100895,-7.32107991598576,-10.3943961715546],[-3.6515677206142,1.13660727424263,2.30476158178802],[-7.05858339827508,-6.41318622570553,0.339586699342419],[-4.67968468998783,6.94377916109829,9.1975525051625],[0.884123403239738,0.658034994964025,3.02888804907116],[-2.29948510034813,-4.68568848777473,-0.176545604953314],[9.31367810942172,0.99569174979507,-1.29056804613471],[9.2547506164241,3.631822859596,-1.87028004025396],[0.126806910978074,-2.86453310501402,11.9645752064517],[9.86605223105506,-5.01315413559512,-5.13334491781757],[-5.925046238205,-6.25453451587055,-1.55179335204384],[-0.0135301389033771,-0.886913749125646,-10.9113237969383],[0.836199478970366,-8.58410951301758,2.45547161916545],[1.61859120402479,0.861700459893927,3.52671122289502],[2.62293767646499,4.09687156437567,8.41872062661775],[-3.58809458793266,0.572586148304813,4.88787075678437],[2.04617435459046,-7.15842153846462,3.27283453496108],[3.32324800851054,11.7786794968631,-0.956035790610482],[1.3855965015263,-5.62595212998547,-0.748089337015354],[8.79812907069876,1.99001061312382,-1.37944976262125],[0.828089495358554,-4.80516267453284,10.9204155659459],[1.23704473279229,2.14187290762129,-2.76395110857184],[4.51498246022885,1.25415878369673,-9.31111029054802],[1.37897455136857,3.55158782090769,-3.61385087041915],[-1.96886885409464,-2.64097930845003,-3.11019524354291],[0.860814994732688,0.853808212619014,-3.48217182535573],[-2.06902394772764,-2.61376432139123,-3.83958307084459],[3.18030790860074,-2.75865688384267,-3.69315383516707],[9.97237505052745,4.46805891577083,-2.37814700842981],[2.11592658208418,-2.5900166474982,-7.39504818423817],[2.01338917906847,-8.90526037354809,2.64494848462298],[-8.78547380369484,-5.86740533386655,0.333302549795338],[2.19534035771946,6.52888126262421,-12.137214152903],[-2.02019034857932,-6.69252308403878,1.09966886906427],[-1.86664539836302,-2.11294625698018,-8.72982998616637],[-0.00943456158122602,-8.26187409254539,0.313609571724734],[0.620908759334492,7.43660642735533,-6.26718431162471],[1.0522434065483,-8.86516884836178,-0.169012870217201],[-8.28296155224194,-0.402337042286623,-4.99601613452052],[3.81890432362916,3.29216548616334,1.94217601397239],[-4.05402326070638,-4.88898586883109,-2.67451400831226],[2.64515642753713,-9.51823568702488,0.146150283989157],[-5.68198393007694,-3.16661037777338,-5.15430533547848],[1.07265373999894,-9.08056491016816,1.76176214847922],[3.00357083903798,6.07527449622779,-12.1457812364701],[-2.3366348568877,5.07939649015888,-6.86317306079104],[-5.51101197186166,3.69170355131302,-6.01750536178445],[0.258293262125354,-3.1073742161357,-1.11414672597209],[3.48980276941161,-5.76148324138579,-4.82533956868188],[-4.16345030805516,1.79410116628832,-4.60678966887932],[-5.53684937955128,-5.75912280280592,-1.71256043057972],[-6.02027373075871,-5.20586302633091,7.70630173056601],[2.44471463959553,5.55133966095244,8.46882917975259],[-0.87506265263417,6.08163683400355,-8.45772089868637],[-5.76143564133844,-3.46728062116522,-4.89698462857212],[12.0767693276282,0.167081763750029,0.644114131777384],[-8.99342071574188,-5.94632971040563,0.682267432334261],[-5.84016077497036,1.49020691297542,4.36981655268154],[-2.48010008740193,7.21126548435382,-1.16234529512906],[2.05103080388716,11.5480930374954,-2.52130528400776],[-4.38856121495871,0.46355913447657,2.50390458381307],[0.143072634919991,9.13110694393255,-7.542099113381],[-4.30749576878841,0.892280973727055,3.85220493454852],[-1.43745181490412,3.28915635115213,-2.24496753107581],[2.95419672220782,-5.77352299457075,-0.876835114362277],[-2.69721249944412,6.94448394947588,-1.42573583459855],[3.8278611375437,10.8272405270493,-1.29408187392766],[-5.69839749992429,8.32995397013723,-4.67126976684507],[-2.75565430044447,-4.88828943405135,-7.32243888278108],[1.25098006858553,-6.82214759476004,0.361699052818591],[0.369520135272176,6.18942736358964,8.69722203564478],[-5.60108862355573,-1.00829777595056,-0.156020639710233],[-5.07951434244371,8.33688679276523,-7.05645557280122],[1.36611593739224,-4.8819872369192,10.4500401142538],[-5.74039816597315,7.86715898959119,8.54418155656277],[-0.269306414929065,5.60090186833942,8.55722254706665],[-5.02968583669475,1.90276558973644,3.3876123123171],[0.0623749814760898,-7.75335417489752,1.0252419248056],[11.1416172035891,4.59623065192921,-1.72674217041993],[4.40171134223097,-6.41118791057701,-2.06218020328175],[2.61837192135309,-3.78264455676463,10.7906648775854],[0.892368185313856,1.30359398509342,-9.23569974985744],[-7.00630576024293,-6.51467217020544,0.457849890647128],[9.40221117117111,1.93210433326224,-1.30120487547762],[1.57870998123682,-7.3236588676029,3.85350829258152],[4.40312461480012,-7.64394214827862,-2.68994096308937],[1.44132321800399,10.7718885373981,-1.62658573013604],[-2.91548925186391,-2.01605810169209,-3.44607910552265],[-3.86529958267927,1.2342310068665,4.80201562797572],[-3.66107017217482,0.810492869059402,2.0834441792448],[9.28866886129462,1.72955627909012,-1.45973442892073],[-1.76385772462534,-6.08664660858653,-1.52363934336274],[-1.69119525405245,4.91452762422479,-3.19087661234996],[4.03649458552151,-8.61897742533814,-0.636121243366988],[10.0004698763905,5.24419970225019,-1.5371244006476],[-5.44820552896432,-1.55784342373401,-0.824326290913684],[-3.70808220570001,5.56313818750406,-2.47927294170352],[-1.21840479806574,-6.20817652854381,-1.94976189866108],[3.25130530946768,5.00683756677831,9.14424305914729],[-3.37762204097144,-3.28696691175077,-2.09927998944968],[1.5841633253839,-3.80052006667114,12.2398023428962],[3.05534431915607,0.102434688152069,-12.1698013096637],[3.10360540110782,5.50441823704447,6.73156752588665],[-9.43672480156152,0.881600750307982,-6.27779146695406],[3.31777954296351,10.7453256484964,-1.80997370707897],[9.62813960837472,3.42842736751705,-2.90250982301407],[2.41932345825732,6.07456940973537,6.94744935159236],[2.43358251320519,-4.3003510290201,9.84667570478653],[0.54173426123734,-9.46217162822209,1.07696713732107],[1.58162319830625,-4.701793749984,-0.952326794905275],[0.524516210819267,-8.03550937815663,0.867124473154759],[-5.5278776175095,1.34459955052535,2.50946725900069],[1.10727322058548,-2.78482184300585,10.3897307085841],[-7.7171207147083,-6.18333725054256,-0.0928508895844131],[-6.62869144649565,-7.17510685308434,1.54399363688446],[1.2878460288921,5.45586495629438,8.52465424356484],[-3.86187640736032,8.05332972206843,-5.90447596853866],[1.07960019903076,-2.30741610100677,12.6021834155199],[-3.56969252001377,5.89696980173151,-1.08385903140103],[-7.97636634731858,-6.03149589820497,-0.0410335124909706],[3.3822501870288,-7.76350229867014,-1.72849845865702],[-6.99936752506901,-6.95582340118048,1.25998791351583],[1.51577628728278,3.71138487007655,-6.51537094176214],[-8.73126116882025,-6.57018197276218,0.501844026074062],[-4.05438621755667,-3.21218082296823,-8.16857865718009],[0.156002688319081,-6.72921221214628,-6.0443397238924],[-5.94822866475852,-3.12825168323447,4.8423834949629],[-4.91338522555404,-0.678966848892748,4.30859488345437],[-3.58519153948205,-1.14128563146373,2.92161052159976],[3.61920086743595,3.32371639231331,8.52018989665518],[2.55828396303411,5.94722802519691,7.64316613400395],[-1.86753425397488,-4.54238043314729,-0.478758169744652],[-6.12295947157216,7.61093955651127,8.33758862642065],[1.72230283179133,-4.45946674385792,1.50791458737884],[-2.92955277990003,4.84175576427514,-0.872078435124964],[9.89579713122166,-0.641677867018252,-0.048963169548935],[-1.61835795148784,-8.31217684996107,-5.54869558955504],[2.65425106529397,10.9553895716551,-2.69121547549562],[2.62018704507907,0.155643099888674,-11.6724871190204],[-3.62414356804344,5.68921347379268,0.663108679119733],[2.90337868099625,5.25838186038061,6.58790078843637],[9.79987445437148,3.65344050566554,-2.73642164609483],[3.32378034027987,-7.4921867766976,-1.91516725966982],[-6.02727377421844,-6.17279727427136,7.32383111882536],[8.51552853031455,-3.89832471303985,-1.53625568556188],[2.24436932913158,-3.73137849406793,11.8940364087659],[-7.79691263349644,-5.99711802525582,0.0692821835450516],[-2.62835122795964,-3.09221960310571,-7.24206861556722],[8.00234193102898,3.55916521626361,-2.11977825883512],[8.54041529939542,3.34035708324887,-1.71385151599741],[2.74554517136633,0.166730236358844,-11.7760434286815],[-5.24785624397162,0.842482626926987,4.17839604066747],[0.554402762228752,-0.867060000087002,-8.62834022091954],[12.5196985492114,1.01695928690712,-0.212658553115518],[4.19239522518979,-0.02281452959332,-3.82461744757601],[2.21340575067775,-9.83014969134369,-0.148487491688801],[1.87778031755273,-7.87364876961284,3.82565150467053],[-3.93042328634213,0.168180520596427,2.65285368769996],[1.07347242070328,-8.87964929930216,2.43772895365062],[-4.08216422994908,6.50393703824463,9.13115474360684],[7.27858549481462,-1.89511931042528,-10.3349546115941],[4.16193494373491,5.35022321733992,2.65076484250207],[-1.34280107263544,10.2758530480859,2.51577871532433],[2.17592149332315,-5.35353534324532,4.96155977464891],[-3.38330330712561,11.5415418622722,3.06282527177946],[-2.39587399842006,6.20594220259025,0.274298934953678],[0.954944026354478,3.83661324883607,-8.61507752193119],[7.27732395769781,3.75455302048148,0.0589362777781173],[-4.97519813074368,-6.50658302005154,-2.61152748356283],[9.95790758874266,0.634878796130702,-1.1656024904057],[8.87620436131596,-3.55427441961571,-1.93060055974444],[1.97340188250834,-5.30879770043186,11.1595199513506],[0.565240500813652,-8.82720973304598,1.80688022107557],[9.81280180227882,-5.06296071452349,-4.93474598616301],[-5.36751552599695,8.68878009178379,-7.3095195334365],[3.0676300074827,6.20524066685739,8.47196147048406],[9.22168598194061,3.00116707483739,-1.90536862381383],[-0.768426664588152,-6.79182812749142,1.64891705358077],[9.82768839884358,2.60960270271781,-1.78972713581483],[1.41741188379183,6.34435283886815,6.53920704664701],[8.24484991650938,2.62639541234755,-2.03940448524855],[3.78376018187402,5.53005876367627,6.9577455160309],[2.9260939363213,-2.32557032867293,-6.45566993929171],[0.170632379591646,9.40352561208581,-7.61332833956351],[-4.26610351978853,-2.32167313382989,4.19328919031116],[2.38698017614068,-5.94328764938439,4.19328545278586],[8.58620130202002,2.07392858250314,-2.32574849423788],[-2.91454100401216,-4.08451940489821,-0.448427226023873],[1.99226666577731,-5.51634066471014,-6.17147673146358],[2.37148312012193,-7.03742897405932,3.63077320988229],[-5.8308441083711,1.10589537553652,4.51130543191613],[3.25925148008766,-9.38380186300532,-0.367582765232476],[-1.54520848663713,3.49546010427907,-2.56676686694317],[4.93031804072452,-1.2850178075316,-2.73983284400453],[-2.67119235973492,4.05838929507298,-0.00152374990723048],[1.30703584328607,-3.5152994969053,12.7116554166184],[-8.97429423494784,0.158900459132941,-5.44119618790033],[-1.1353646862326,-7.4309035786052,-0.226036779061216],[-2.51566984740434,6.95526071986488,-0.713384002274005],[-3.84178167732432,12.2688449470497,4.01961176314271],[-2.33641763982201,2.93273836976803,2.85920419823758],[1.74975623969643,3.6944034114157,-5.85606493195016],[0.727866694586375,0.62870776313943,3.32149498335772],[-3.88415166816457,8.3019208804111,8.50332934013491],[1.56751577061703,-3.9183151555359,12.4768557014661],[-3.23196478935845,11.6403919596104,3.14319458814653],[0.546741119121482,-3.12057683490299,11.8320723994611],[3.35066509622789,11.9701663838378,-3.31983698110986],[-4.78868493353842,-6.81318035083474,-9.67008831679878],[-2.88101603199407,-4.25093260596958,-1.01582949000374],[-2.13740040645151,4.26675583036933,-2.55775108652229],[0.636238223615228,-5.30137090682433,4.71257042787717],[3.51097012346919,3.58104227528191,0.425993202830156],[0.895426989687565,2.13479201096334,-3.63154352729792],[-3.14806603512546,-4.09048147218316,-9.07047035262817],[0.664238225304371,-2.89786241100576,11.3691637746708],[-4.62460379648239,-6.63891400845072,-1.54571052408655],[1.08858779451859,1.53697451475111,-1.14214074338408],[-4.16405770281353,-0.859529297358186,2.09894651941422],[1.71521741748217,0.430124203551128,3.30491628512687],[1.47209731568025,-5.5432341817102,10.5869519199989],[11.7075692095652,2.16234725460201,-1.36532335377525],[1.43361120272504,-3.91652512461164,12.2712587077295],[1.96315106967398,-6.76607806886552,2.68224486360702],[2.00478787188404,-4.91573106388193,4.98701699411225],[2.38409732377937,0.508787691592483,3.51579815498026],[-2.34659529903297,-3.75155948818166,1.97857415494301],[-3.54707598360935,12.494805839797,3.87081211236154],[-0.213947730748661,0.93619032264009,-6.85882074529288],[2.41027746383617,5.79795217193645,8.2658193494146],[-4.80270079885795,1.28277057952435,2.80386578374101],[-5.91188719110266,-1.3114104905453,-3.98021539459547],[1.62245107326263,-6.85441836037405,-0.396435476859359],[2.45138776509633,6.90448464297666,-11.5762830836164],[0.133880077387659,-0.859240463961661,-13.5649312420971],[-3.04175734754819,-4.9317499410726,-7.5285528509829],[-1.88511041544349,-2.23706500046167,-12.0801585220741],[0.664374412717394,-2.63672354960995,-11.7095407985313],[-1.77726282685464,-1.9317601641444,-4.23112212617549],[0.824336504564192,-0.997952808133492,-2.54845106571859],[-3.9389370524931,-2.9085623449889,-7.64866723916406],[-9.18547453503465,1.56996681176888,-6.47769663617283],[-4.49167206041554,0.874781156958696,4.08941413284136],[0.370124496147112,0.199667670128225,-7.42038048074135],[-5.13899796432704,-0.468455222875558,0.550472731108981],[-1.29937327057797,-7.78501734590275,-5.70662583796364],[10.4337266522899,2.69438510552979,-1.3724152766409],[4.27029909947791,5.67748172018246,8.38204572677827],[1.07985645109625,-3.00490778611173,12.817434934593],[-1.48120229329644,2.53720683495478,-1.87611973098595],[-4.1579493095699,10.0346271222404,-4.84958991056148],[-6.81200527539862,-4.99529026803179,7.69715827242273],[2.43822232922025,-9.81249129309058,1.20311622130373],[-4.34318244479319,10.3515780318501,-5.54122026708105],[-6.46803892556264,-5.68071861174849,7.30029523043887],[-9.04826394070461,-1.50014845314602,-3.37062115017455],[1.37110716024274,-3.97180616746747,-0.01071339865067],[8.46190377697536,1.6357243196973,-1.2361245135501],[-2.64256258131222,10.3268585112096,-6.23166110926582],[1.9794354942906,-5.09659964255331,3.64998983635631],[-2.88456819537015,-1.88025543353976,-4.50086423823418],[3.81800622076441,0.635577480283573,-8.57422256654133],[-2.01817929556445,-0.540933865153526,-0.131751491265731],[3.81688185287347,-7.55045261993438,-1.85807252014112],[0.556184732402725,-2.94396094429798,-12.0180984171487],[8.04478002884903,-3.81081775304889,-3.47758179677648],[-9.61662304648878,1.0001491978078,-6.36157275639117],[8.86031020793389,4.00842379889504,-0.651253642617246],[2.64879441272182,6.05671160192881,5.97413280899892],[-2.59753249984329,-2.11829554254338,-3.58716788278534],[10.1973037037132,3.57409679737098,-1.64143232321029],[3.33529122292525,5.67286864811695,7.69640201390381],[0.70639972224532,-5.37252086704633,-5.39910377991978],[-8.85164782278262,-1.10448655870613,-3.55820003563174],[-1.74323245845213,7.2350498874866,-7.36809950982422],[-4.70238171838799,-6.2510147995335,-9.88254706025751],[1.34285655436787,-4.33266172548513,2.42973279148518],[-2.14686619928993,4.05457665918869,0.559879347687303],[-9.46533230806429,0.979694969185196,-5.79722685107162],[4.77610790156697,-1.38564899214041,-6.63822552411641],[-4.16262594861429,0.606913282483742,5.33789503857552],[-0.572236327812581,0.695293006743368,3.36268802606451],[-1.2233223933169,9.57177656802575,2.49622364966241],[-3.43332477190572,5.60555946317551,0.56884121854971],[4.05380307452597,-0.345510700821308,-6.14402125794544],[3.86488433633356,10.9055753810079,-1.72279581801602],[-5.70177750032478,-3.24195504111249,-5.03508236609103],[1.65878207173472,-7.06790325077353,-10.3394179387533],[-6.65833305298761,8.79560146677811,-4.08093205308634],[2.80320859710396,4.84112791713539,8.0303471692333],[-5.37916703699675,6.99176159805828,9.1755265627441],[2.76236896955324,-5.71276720191035,4.08641515732359],[-6.93566446568729,2.9744294604611,-4.87154191033914],[-3.79924760264484,-3.48119503285452,-8.05253648255526],[-4.94046204516862,-6.91241364198588,-9.94070154097039],[2.84921664875962,-9.41608420370418,-2.1523102273177],[8.80741194843398,6.57288486489464,-0.138044098876182],[-2.91513845835019,4.38082146809973,-2.44009525866471],[-4.11312392800081,6.31939199158593,-0.173042503599575],[1.65160756835138,4.09586319267054,-5.8906220520642],[-6.24045024881405,-2.60522888724545,-4.75513140472234],[8.78250251062959,-3.88652834046587,-1.26056467937894],[-3.21616805401777,4.94361876862162,0.341908952368933],[2.18901566347998,6.3175643585799,-11.7845001028565],[0.687095911887203,-5.11166256968281,4.06393477449847],[2.10336553858682,5.74749988672613,9.46953128067461],[3.62474828220808,0.455173211549568,-8.59532793307122],[1.23677131738015,1.5246253389408,-9.09865061130811],[-4.96276076834502,-0.371211019588934,4.43825042534424],[-2.25630195622465,-3.72192275226927,-9.64988918193139],[-0.313067276828098,-0.780559378498861,-13.6388712077149],[-3.94558739905417,0.675412716308699,4.9371991172511],[-3.67683363462388,-4.59858412269478,-1.74269669234081],[1.99911268088785,0.404923902608456,3.99696944062904],[1.1926378911974,-7.77557943674833,2.70666887167431],[-3.33682727657231,6.54570075840817,0.362181721483117],[-1.72116438543424,4.46297092887044,0.581721207835371],[1.27884430073605,-7.30504371542534,0.666370534947274],[-0.213742851032131,-3.78728028204955,11.7330779473136],[-0.285872905243816,-2.88547236366692,-1.24313762003317],[0.861339590681306,-2.41074841779886,12.8730637290155],[-4.79273094336452,6.35770044101624,8.85054769840652],[9.45664619158583,1.98454024423063,-1.2356810895771],[7.63414845624083,-1.5666478143099,-10.7803218498059],[-6.55199886285379,8.24626853997025,-4.12332301653231],[-1.37166693737048,2.91113684501338,-2.05902072918794],[2.07970355508352,5.99873703650819,7.66786298385741],[1.11052605432059,-2.92815831880631,12.9504387503414],[-4.30017957706401,1.36892804933023,2.98196253140728],[-8.10535862170853,-0.817787824129373,-5.21547592363822],[-4.27847603069901,0.752837804200655,3.46891092387905],[-4.92534585239175,-5.56170349280662,-2.47685764664492],[3.70177306643284,11.3953616046644,-1.8836054315373],[10.0625513523109,3.57081571532211,-2.13716099098522],[-9.117016352095,-0.36896784025879,-5.36187766006136],[10.6743854767154,0.559483456045847,-0.539829311208517],[-8.49410968524311,-6.4931213325276,1.71190544234054],[-2.60898116626749,4.69735243722419,-7.73834275289899],[8.1772434659063,2.13057415824491,-0.77442573385532],[-3.11384996669717,-0.592725625158895,3.05682348351902],[1.53085280620611,-8.99988135109677,3.18117474863387],[2.27614083301932,-7.76645850846718,3.70874858679629],[1.68694027013709,-0.115010428396795,4.22675573583562],[-2.6762425103184,-3.75936643243495,0.345216546270576],[-4.05770500126496,-4.29050332329406,-1.63395132710747],[3.46590116683042,-6.08711643717888,-4.70967579781422],[-4.95978351224357,-3.52033660397711,-1.75836700428045],[0.0193859369221998,0.900840202106424,4.27564906968233],[-1.30612989034095,4.56481798540446,0.559088902879583],[-4.39834823189038,1.75093124560595,4.51641323575514],[-2.24714259287881,0.0651083503062641,-1.1063434016217],[-3.87629554070964,-4.81592803760173,-11.2048560819268],[2.40332779262345,-0.0976085884303324,-10.1581569927343],[-5.05648081373253,-1.29657459237049,1.44246383652656],[0.814367506995075,-5.08049152813042,-5.57371292255173],[2.35758777949065,-4.26288180975649,12.2556784538474],[1.87862139325479,3.55020658162432,-4.01448677715229],[1.79637692877641,-2.21902925101783,-7.2825396636933],[2.80666345060814,5.963301586193,-11.2423776095298],[0.845073023051553,-3.64647174437706,10.1241375464801],[0.270298592561849,-4.53256710680457,3.10236548468144],[1.6024884252083,6.07963799914399,9.50137046363506],[8.42842035524255,4.88442939926321,-1.82126259057296],[3.38317320408274,11.2412374069378,-1.09847473279337],[1.39283566215125,11.0441756508849,-1.94216401754115],[-4.35895475199913,2.79484119099635,5.65952600298906],[8.15186363138151,5.46368754049662,3.07679436929385],[8.42537140505017,0.991398999723451,-1.59157753622438],[-4.86013288158031,-0.61631644687234,3.22487092298096],[0.549749684900745,-8.50755441159038,0.347682627630305],[-6.3433568204307,-6.41413930842813,-0.540361006010849],[-9.35415154272116,-0.469985205348136,-5.42582925059878],[-7.34973378112619,-6.78502319610242,0.748937781322536],[-4.73441936539586,1.8084063498115,3.61765344755513],[11.6866977063228,5.44874546865822,-1.14522845673297],[0.773302880603846,-2.9470905245782,13.4845248312812],[-1.79531220917452,-0.932100957342048,0.444206959795763],[3.87992609033302,6.3267179216094,8.38539676488612],[-1.89834990140706,3.53759304997125,-1.99136614256872],[1.46589955027022,-3.92549815293363,12.2905188742243],[-5.72094342314198,3.185904464492,-6.36760941615476],[7.86458353775601,-2.8509891248123,-4.82399529013803],[3.39291051883131,-5.64907601964072,-5.63031025923186],[1.97764682625821,-5.24572164151698,3.36407029576392],[12.0026344714748,2.82314930363365,-1.2036968425055],[2.48609536998727,-1.96920161399968,-7.7259388936448],[-3.78140512378194,7.76182060044329,8.94215002869441],[-4.73146442906545,-2.80770588983865,-3.33861199516432],[0.315280803062091,-3.61100408457135,-0.531990009912789],[1.06115655984728,-7.74292685835961,4.02962219264711],[-4.18845549643757,0.674028255274438,3.80589263565617],[-5.70415840520022,-0.202799941330191,-0.994186683269044],[4.09736171447547,2.55099337355577,1.47764670987978],[-2.55281597826069,4.75816586660989,-7.5592722202509],[4.32622018027408,5.14336375622649,8.8444103022158],[-9.55642257039521,-1.03871603870326,-4.38494031464834],[2.56869418075445,5.63092930943824,-11.5287535419926],[-0.111342705523663,9.20028191000546,-7.62299045590442],[-5.93018955409324,-3.63029480221517,-5.0790990903853],[1.55065466310516,6.0153605727625,7.84682755889407],[9.22484255122264,-4.36355791348207,-5.57564573352558],[1.3366289932604,3.94990687625025,-5.89310499226214],[1.47193473050713,1.4416327063502,-9.78014504063365],[2.24842524276405,-9.43112540904407,-0.371769660174529],[-3.67002143269809,-5.46470233725479,-2.2607827725091],[-2.82689005997487,3.96296198411601,0.738466175203537],[-5.98296937475487,-3.5124383071632,-1.70147718672611],[-0.323211969847921,3.07812798548571,-8.62298219661648],[2.38284628533006,-5.36559013514177,-5.52422155630056],[-9.70989085444648,-0.834731219623413,-3.97893950475428],[-2.62936007190088,-0.118860280220951,2.65533564003142],[-4.65132837111917,-0.528553763876315,2.91532807200132],[-3.07188837031278,0.786282061671844,3.40040663818542],[-6.9423204883474,-5.50132891030631,7.40857419116015],[-4.77684012127717,-0.534366692603125,2.81920195059404],[3.36556644650689,5.97561298089694,6.48763733300767],[-2.96839102173719,12.1775688977739,3.61092874776243],[10.3822273146786,1.36139421667318,-0.48177253647896],[1.82431679720251,6.3036257370357,8.02517364011143],[-3.20130383719449,0.299802151417449,1.54302547682319],[1.79872358718016,-3.13266437781503,-7.73614078814761],[0.383577540622261,-6.44468255334176,-5.39026242440633],[-1.25501351965152,0.283471759038738,-7.06719810524873],[-4.65444604526799,-5.746564435686,-9.46629835218184],[1.98494657991177,-2.27510478596675,-5.77195797622453],[-6.73214283258724,3.09298594767521,-4.44052614505476],[-6.02551566311738,7.83703217292736,7.71939801039684],[-4.82268636011046,0.0828961701350382,-1.51782145759555],[2.84985799096491,-6.27683455801653,-1.51835127189608],[1.32932840420924,-8.90405238800912,0.458998120507348],[2.33462100419476,0.323405515863903,3.32173098689203],[-3.30137904485386,-2.8009741278791,2.02795864445502],[8.32977616189202,2.89472482000012,-2.11066117281624],[0.56972229254958,-0.170857205578302,3.21828456965691],[0.0679417066508774,0.641599965900252,2.94655334235299],[-3.09088723451508,0.366871385524001,4.73042170862541],[-5.24442916140179,-6.44421824377604,-2.61184011501027],[1.62315627750482,-9.60031643528656,0.346750660757187],[0.970251372780039,0.250752855264907,3.05705808116122],[3.39694708540447,4.40981650981911,8.03551891163663],[-0.57902253212209,6.25728919193727,8.7618950742286],[-4.47459487587752,6.08258261252714,-0.9118655323699],[-3.39014122357452,-4.37081315756987,-1.61910060226268],[1.24764460586009,1.6466429664152,-9.44666202405724],[2.92111452644534,6.34260896738103,8.71056108678926],[3.58907819187048,-0.1527887377677,-3.34950555388575],[-3.30601778047667,5.83737439821909,-1.32379245913001],[-5.42782640052989,-6.64930905418549,-1.50263985780355],[-6.01306650782838,-3.40214508929709,4.70720859115588],[-2.10279218996846,4.43569725249976,0.777409739307141],[0.615470018568615,3.54723278093724,-8.68438475835563],[2.5314756173963,-7.41589964390584,3.94879066673986],[-2.52323876821959,10.0749031341313,-6.08696614863232],[7.67451419150753,-1.83140450743946,-10.4771724564283],[3.71968045354115,-5.59270112586346,-5.32134162274844],[1.68452003826302,6.49288367889676,-11.3962649879666],[-2.64129446268601,-4.00261363452921,-1.00517370884517],[-3.52032192033929,-4.17639428743458,-2.04690988720593],[2.18971911998983,-3.08562490123518,-7.38858644501832],[8.06108533809524,3.16940578776315,-2.45479569581495],[-5.70785417533814,-3.48434965394088,4.22849563231704],[-4.15093913315052,-6.11177322015947,7.43306267167244],[0.116628642782154,-3.01372800206096,10.4967605227004],[-4.26418788234666,0.121161768762995,4.20644959713898],[-4.87575488690692,1.49621284393648,3.38867571772276],[8.48687913748484,-4.09891068279825,-1.64718798314419],[0.743352239222357,-9.17945223673092,1.20358730089534],[3.90227962292642,6.40986244622983,7.74259879389493],[-1.44511522886468,10.0488991568915,3.01287332848971],[-2.72990568121336,-1.75890894031289,-6.1487314078321],[2.58163260079371,-8.93839187109615,-1.72219954458063],[1.77856047527656,-5.09687427774033,4.43206023801756],[-4.9936123931601,-3.07417555465794,-9.31280855558127],[1.84677116364316,-9.51644981700037,-0.539150147945352],[-0.210819669012485,-8.30768024532496,1.1565469423197],[1.5302241102359,3.58719376722327,-4.0879790428902],[-0.219081192521166,-1.35095452167336,-13.5530828386353],[-3.65586907131389,12.3127997051688,3.88984217285731],[3.10641001429213,-3.52304558370709,9.59291975903309],[2.43947680479722,2.78380077773684,1.07904140837829],[-9.12872282013578,-1.82682802417074,-4.19200800287167],[-4.28971453486818,6.22706149944769,8.76394319253336],[-0.314304529269437,-6.1613107570664,2.9438931373426],[4.99593749213033,1.89106238793428,4.58684551094926],[-0.00626989065488992,9.1005995853058,-7.24224695111855],[1.52122776629772,-6.47880792329369,-0.164449697670272],[-0.173562578012116,-0.689613525606944,3.18092118360821],[1.12142054978108,-9.05420560458026,1.19804129382538],[8.40226187999285,-4.11701960302987,-1.45892217208606],[2.91508425759413,-1.75485696903549,-4.37380164104911],[3.16813304590512,5.81765632456623,8.89024431782415],[-2.75276432281984,-3.36294995817858,-7.87349022636696],[2.69275159100651,11.3112784904308,-2.92296235507581],[1.08118943066453,-9.41942707898583,0.684671238211852],[-4.27925876441113,5.9078113487152,-1.15979811787449],[-1.81204421291956,-3.25997475904646,-0.95855189427053],[1.71818841772593,-3.52899723232264,12.6326450459478],[10.9037022993507,1.6962943512287,-2.07246433497037],[0.929366677720586,-5.55290667512177,3.89577692640225],[-8.24351468688878,-6.59886722235147,0.809479363647068],[2.85637750618597,6.19516222528116,7.68195031842891],[-3.80377666047759,1.19949724287316,2.93080872584552],[2.25157475402132,4.04001284751714,-5.18549962641666],[3.83661539539404,5.49035311112519,6.97814220120992],[-5.51468156855965,-1.31911300839992,0.314568334494212],[-5.23640652648685,-0.591003267694853,-1.42939426689649],[1.60344562348647,-9.13361727665706,2.61509956936008],[2.8235869452641,4.64576466065291,8.14911880150245],[2.3400335963931,-10.2874978215743,-0.330645113882866],[8.12846014977132,5.64332082855038,-0.678826581214986],[4.3321217409553,1.92997552293074,-9.56184716104011],[3.57063108577293,6.30535571428918,7.66651533217408],[-2.64650033294931,-4.79286041795633,-8.87157238136581],[1.7222472424777,-4.95735863482004,-1.26056767132497],[-5.22607672789922,9.28636661270694,-6.8549238918717],[-0.225104921064606,-3.27848647954809,-1.36953631123183],[6.04050443844766,2.40291111986071,2.25701927472095],[-5.79845410967069,-3.59527250485361,-4.23921975371081],[-5.2098475907854,0.831114748258549,4.16010587918741],[-2.94910845189913,6.39188478332156,-1.2088727229228],[-1.10494888852411,1.02259437008464,-2.67857041683215],[-6.41325874177894,10.5021411718078,-4.32303064002735],[-5.4484458385504,-4.75770205011317,-2.32562367689951],[-5.49616756004511,-3.18630218571188,-5.03790329934762],[3.82577262948704,-6.48711564840982,-1.34723469528535],[1.60144872553354,3.51675650162819,-3.82779143434426],[-9.63227132558836,0.518290021095204,-6.04585950018581],[2.77933916557323,-10.0925564624056,-0.749582063127401],[2.41746833111313,6.8664380008362,7.97065409822947],[-5.76844009176575,1.35987717258175,3.6501184304646],[2.29808361030569,-9.1341683795053,-0.154802510776667],[8.52253325182303,6.80005161770627,2.02574138813519],[1.66195314227629,-2.93525443733069,10.7831054597299],[-3.12918268642806,7.04784103885066,8.35790803484744],[1.30843020473029,10.5192333864323,-2.38019937991376],[-5.58552308131475,-1.39983776775738,-0.947564722114191],[7.51153347546764,3.20894764803636,-0.75563489804932],[2.72417177404211,-6.13845052754611,4.61847115844711],[0.864001423955479,-7.74313635976196,1.73402129340868],[1.39896660937284,3.82644624162896,-4.11053951924117],[8.42102538045512,-4.46210855016159,-1.76621510815022],[0.100617940237776,1.25811934706244,-5.32726459968657],[-9.00115416803357,-0.770546462325461,-4.56709218935967],[-4.76795592708617,-0.340979700096336,0.879393409688148],[3.28740700683939,6.26414476853531,7.46644903135472],[3.79828071193552,-4.54105230299445,-1.48634731163288],[-6.3079284643536,-3.82260790695793,-4.16911571922289],[-4.51221640625285,6.44077917038052,-5.18492665747909],[-0.719181625088998,4.41481942072796,-1.77332891972324],[3.36610492147849,-8.57226262211007,-2.18940934589477],[6.4447219239791,-0.756423685746299,-10.2854873134232],[3.70366625967678,2.73326447461346,2.91795892240342],[3.19676688341921,11.1529056811838,-2.443251734784],[-3.12021549184489,11.5257314793284,3.19910011015323],[1.80692568021057,6.69618110605132,6.87291799846447],[1.51292163636081,5.97092932643558,7.51304669592925],[0.59471415639122,7.17406517425131,-6.11335268017866],[8.9519456012976,-2.42222236249078,-3.50717636502981],[8.64620496824269,1.20504731642831,-0.966834863630192],[2.94815941606974,2.69647112816355,2.7086930123762],[4.5915491177087,5.69034249450735,8.35649480770745],[1.83164136564561,-7.30742764403545,-0.507646825990127],[-3.92534045509285,-5.35793015532472,-1.57727021272938],[4.08864913455058,2.38232363787916,-10.4975579569689],[2.89793311327554,-3.08214150020835,-3.42268661609476],[2.0230502358171,-10.1584858425749,-0.0794848596930383],[-0.805365196551305,6.19484575756989,-8.46064781895905],[2.95464301202313,-3.01975503455,9.57752451902904],[-1.69087048407489,4.77965127642572,-3.07602990387391],[-4.62653976589666,0.229490933443458,2.71253166163788],[-3.3001029026895,6.30689070161527,-0.790981219668715],[-4.75702745942998,-6.5948513665118,-2.59274854645476],[-3.53198083094184,12.0341989148631,3.28181658131036],[-4.72539627510317,-5.54220115456664,-9.67874431758138],[2.65959550973084,-7.86070557222618,2.76676230539752],[-6.6444423269109,3.38188848461861,-5.01210696202794],[-4.46040249544534,1.46031769462259,4.26555744098455],[-3.12828677251111,2.69914602627638,-5.67890270897422],[3.48827202038935,-3.33538017956484,-10.2388721581874],[2.16687483538821,12.1167019547613,-1.69403485521471],[-8.49660829067668,-5.91558941175722,0.50396755143216],[3.73595155218899,2.11332425600174,-9.65535545236945],[-0.326711563699864,-3.19503435358187,-1.16417378900039],[-5.73290546476193,-1.3811121051565,-0.10366520799583],[2.82544236664845,6.31906891370923,6.8507238023003],[-2.454016274663,0.0845335308814398,-1.14924425696133],[-6.37918562151054,-4.21880720567018,-4.31046504221942],[7.72210564630666,3.92635079840955,-1.3935296608451],[-3.69773405596685,1.22473467573426,1.7528505989162],[-5.00763277136603,-5.45076423368444,-1.6287872470346],[-1.51546519145347,9.43307347686723,2.29299983594174],[-2.57789661044538,4.82708047621519,-7.62097697162841],[2.97752721792672,6.26781038802616,8.31786093020089],[-3.77103181059788,6.00070604842976,8.5806816172262],[9.68398582858783,2.63273779323368,-2.48124868653967],[8.51738754801166,6.80415333731972,0.936497155256241],[-3.29857729669787,0.638527717099692,2.73585920076719],[2.42430178938104,6.00348577894865,8.14879342406445],[-2.5421889032191,6.80138732343504,-0.817772930046195],[0.0790499355460025,-8.30899590451181,1.12515873680069],[-2.88470071617866,4.94091553409614,-6.66935655371847],[-4.65932514583007,-0.660663975147459,3.99269330721177],[-4.09670037436875,2.85843776169976,5.52447166570021],[2.52675117805973,10.8915308891211,-2.08171903147799],[3.71966368973582,5.68553276280847,6.80759900240536],[1.49188715829203,-4.53448286515867,2.44362559241124],[1.45469880481738,-6.02593202748266,0.581629118848929],[0.304965254775308,0.235810909174652,-2.92384628860243],[3.21685353649725,-2.15893251961255,-4.67600797123157],[3.26346436909148,-4.96217049580608,11.0036259969755],[-1.3584627135968,1.23288953521154,-6.97738036247396],[2.38086276320575,-5.89517573081419,-0.693062237472359],[-5.50692955157414,-2.63046041903518,-9.09388470519133],[-0.293349806795724,0.341256374175345,-2.62572019196989],[-4.81980509389804,1.98898744771405,4.95470604642517],[1.62154869707881,-6.08023115216891,3.35499524914968],[4.71839055457356,1.90007472815461,-8.60636217711856],[-0.0895534996650501,-7.14462041105404,-5.88439057690501],[0.194400025464041,8.82392261978105,-7.19761890051308],[3.61849823892231,-5.92940023624359,-5.17027780748537],[1.08916651155191,0.356987751095535,2.97174148317999],[3.67211602798133,-7.71151896949146,-2.38011458978438],[2.27272429810368,-4.00050267916734,10.117428646841],[-0.487387831753447,-3.0392857512512,-1.59375573860215],[-4.40562090957594,-5.79335553164069,-2.75593888081694],[1.46289202452258,-9.07373679186931,2.42674305577708],[-2.71189906081377,4.71414848159405,-7.40613593678259],[1.53164554011022,-2.94909821243595,12.4244450974167],[1.32567437002649,0.566107607435899,3.97108061940044],[0.103327577514126,-1.81769026535321,1.22293766752492],[-3.6456541298248,4.23130704144022,0.471447875219253],[1.84641933161777,5.87962757191354,7.56321257783536],[-3.63217454061531,-2.48663390433538,4.84185529932268],[3.09053518483082,-3.56156016215103,-10.7070036631405],[7.58869900228642,-1.86335077628862,-10.6084900432059],[2.92113915669988,12.1317715490502,-1.42402476167445],[1.2996365950374,-5.81363285683428,4.82311773990572],[-4.06454405789166,0.943463846810713,4.46017889640662],[4.05042574136202,3.92454648468337,1.01984052389018],[1.89283354974315,-8.98436402399827,-1.37464793327434],[2.36528668046791,3.81383499509589,-5.784782143519],[-4.06742171094688,7.08271184129091,-5.88512503367646],[1.78745375537925,-3.55678378478698,10.6775780206523],[-1.21149784558033,9.91300209649712,3.3061447034514],[-3.08224572944606,5.67737113518331,-2.82298683084357],[2.36069942105819,4.49075692133279,8.35862529869715],[-0.64777281656828,-7.77741997482021,0.802658925795684],[3.56225531905592,9.94589640612771,-1.55776725082197],[3.34088769956038,-8.29662450923795,-1.92879175019461],[-1.02379788426627,-3.7464265290879,-1.61012566090238],[-0.991189115671332,-3.07027735638158,-1.86477829619665],[1.03087482367521,-3.40612237421521,-0.435395613438902],[2.28592237483412,-4.8505653735779,-5.30688696020621],[2.33496747452126,-4.24465566738177,-1.50547799775841],[0.254246575084546,0.902624324046754,-3.24122830009484],[4.47379888860272,3.13395568026116,3.50819261359662],[10.2554874355044,1.91995477843951,-0.954099344847874],[3.87318479659865,5.2334713923094,7.33161298193152],[-4.50303389146073,5.13571925351633,-0.542535366690379],[-4.56026994733356,7.60225236672975,9.26915287555144],[-1.73991759341725,10.3683083442981,3.33039319667679],[2.30033408910772,6.02248787359208,6.08830408882236],[-2.29143616393717,6.19749021032506,-1.14185163737407],[-3.92658850248409,1.31177797989045,-6.09416408297411],[0.431164924959219,-8.02712506095292,0.790226375400488],[2.37656782881349,6.35680440971483,6.32469990081925],[4.24031360408416,-6.76693975298051,-2.12710228462707],[-4.49134537768877,0.935853765929834,3.08068427739982],[3.58759421821997,-8.74678807332351,-0.723471400706351],[-3.67515562300414,-0.972549446379902,4.07497526801759],[-1.20452577166627,-7.85362151735702,-6.18593504068262],[-3.2564283107627,7.17769558690536,-1.21289675231384],[3.68371401590639,-3.54873490055614,-4.23095326160612],[-2.8857202360392,-6.36070821790557,-1.98622180163741],[-4.55595352620016,6.83549286225782,9.22107623890766],[2.08779486081389,-4.64532416040094,-5.60256770481122],[-4.43599177900107,-6.50114723293609,7.39476173109402],[9.12834100108955,3.45872051017985,-0.665174314041205],[-6.94165409711222,-5.74466015073308,6.85927251376573],[-7.37429109705854,-0.523846556593428,-4.38988230713293],[-4.96194271773841,0.929058357386087,5.26987359691522],[-6.15262380173176,-3.6981749655542,-4.5896649317342],[-2.48528985125182,6.55323591768465,-0.0306833079535885],[4.15351235798673,5.19088386852587,2.7377344832212],[1.38602855634089,5.1462885660707,7.83194926724419],[2.33007895447571,3.6082043611839,8.12781252584686],[-6.27979273674219,-3.11240596972332,-5.29652171417723],[-0.0487406748515045,-8.9135553130814,1.64009391600335],[-3.28624232459684,-5.44057899895899,-1.28789916334535],[2.44478179391941,-3.75385134842148,11.1154540042519],[3.59664730231546,-6.72960093506206,-1.79637967776642],[-1.72251904983172,0.386015151075795,3.0444892571167],[-3.40302127211101,12.0545135584895,3.8752606214636],[10.4786655092828,3.27168711795056,-2.15840506057991],[2.90675707536262,-10.1225834469715,0.205896411950085],[1.04878979130421,-5.48261185011597,4.81035174891869],[0.478932648980857,3.61165796977829,-6.13707726432358],[-0.0155713916992067,-4.58752097331315,-1.57393285654865],[-4.84037486148142,3.80811609269138,-6.69144579832103],[3.12505568860137,6.47620632225738,8.069705948995],[-5.87363735241431,6.81928001704425,8.51847325306198],[4.10761733924863,5.72860000234863,7.94038604670664],[-3.88258852524688,-6.18341581863862,-1.761249848418],[1.52783930777181,-9.6225702263575,0.97660391518227],[9.29361434045044,1.50204341771274,-2.06332277800453],[0.550266854144402,-5.86414028916865,4.29023827100838],[-6.82750438741918,2.99848770553858,-4.26773365507998],[-2.84063182530422,2.2660869037946,-5.42364225621846],[1.66932627338894,-6.19373291223835,4.40708711418463],[2.88560446134518,-1.7352402509612,-4.30010067747754],[-4.13591987554781,7.44497447196278,9.19902172253274],[9.81237083521873,1.46157595389168,-0.112618069471358],[-6.00480244497795,-2.65959835219093,-5.61081340324082],[-3.78735707625288,5.48439558665546,-2.31250173163196],[-7.74598844905733,-6.19439614328184,0.211093412677128],[8.8085016458839,2.63961438439615,-1.86157481617779],[8.64073526076677,-0.00255475774883607,-1.26314857452129],[1.01461375204239,-3.94465917381664,-2.70523646297698],[2.67686522551232,3.42957842894194,0.75798169036181],[-3.40504837741551,12.4262100887218,3.7913233015539],[1.26547163033835,-3.41889526570108,11.4149177972262],[4.08620352171277,3.3984577327372,1.7349561712563],[2.07544658427565,-7.85515695151298,3.88802373816369],[1.36872699937927,-6.40974883189636,1.62621142544998],[2.932104429601,-5.92342209314206,-4.60136356618095],[8.94052771690064,-3.79960749554496,-1.23312745148049],[0.265617673037495,-2.33785100864381,13.2058647435039],[3.24763685461684,-9.28467766601599,0.268767142141505],[2.49492764238366,5.95845313235565,8.37006328650035],[-6.39759501507648,-4.06263861777194,-4.2399086954363],[2.2781629162931,6.24320853698672,9.59141329753547],[0.271674531790235,-7.69868477700089,1.58507449862591],[1.95947685205326,-3.48264675196959,-11.4951727922611],[4.15977805068534,-4.78660167177895,-2.22649832449475],[-5.35176678532957,-2.96619402548508,-4.78023797127163],[2.22383475725288,-4.90337103173316,11.0024791754708],[4.38664358775695,-0.368524599647252,-3.69808791645814],[3.20009033813826,4.35970633339588,8.90350609947305],[-5.21458804153839,-1.61579255022337,-6.185525666739],[-5.16263255704312,8.13169442327811,7.93245124932126],[-0.283215238081835,9.25761338303778,-7.23417329319784],[-4.89393659231113,-0.5130365882326,-0.0128404888583314],[-1.22078375261345,8.10427519650694,-6.75281779541373],[2.66080315780609,3.89020943576271,7.81771421287014],[-4.53673807953775,-3.02439680877637,-8.99968275374955],[-3.64183082800228,0.603670190736295,2.17757174141035],[-5.17858233837884,-0.634571714416447,0.173813022397982],[1.94161695557124,4.13066978559913,8.69905295668542],[4.99396176233932,-0.487157453692629,-2.88146829496815],[-4.88806623096574,3.92294471502033,-6.49707485636169],[3.04493027681498,6.62800141401272,7.45871774272236],[3.76300240460902,-9.16824965959937,-0.191023968344162],[-5.10073069951489,0.853805043029118,4.23722807021707],[-7.95887347749434,-5.77549186054612,0.0023022852290624],[-1.32758952597096,-2.67044655595037,-12.0924472603189],[-2.18945782013483,4.54316578375577,-6.436436997594],[9.192533902141,1.0936853074782,-2.06038416442755],[2.5381275225381,5.91534948190886,6.35158841093045],[-1.12527167406917,-0.246521487221171,4.16899374125899],[1.87855000114701,6.53055002105937,-12.1279277059783],[4.05450735367666,5.0311063503708,2.51079996224985],[2.17476319334154,-0.399321450134208,-7.27892103412254],[-2.4507625666163,-0.472947008238421,-0.792664688648999],[4.13305745037987,6.37583661542535,8.57709734351013],[0.982254488262765,-4.08000318607623,-1.48184786650927],[-8.62909493032078,-6.17224894975956,0.417141817027346],[-2.22618292044016,-1.59540100268542,-3.38994153893336],[3.15945707593923,10.1566393752397,-1.87862180896303],[7.34748476728881,5.19150420300496,-0.218278904013287],[1.20904771143116,3.91794798096767,-6.26071163875872],[-4.06739202613823,1.67477440531579,4.97825262806961],[-4.93728700668836,-6.1837034110694,-0.889533118683905],[8.76354936035228,3.83906555856596,-2.16901124435235],[4.08112005264664,6.43825833012765,8.59997114264194],[3.51918414902518,-5.96373612415,-1.11940041941146],[-4.54772967789677,-5.4940625510209,-10.1142435866375],[-7.38397782859728,-5.84478706134234,0.160990946331251],[10.9587504976701,-0.487698931514227,0.76827487085832],[-3.04325922815948,-0.644308745711707,3.49891376766372],[3.07631660184819,-7.74411701963367,-1.59631624315023],[-2.73291766798114,-2.78693635076417,-2.92778587688995],[1.1952465345929,-8.395912055442,-0.258768645612558],[-2.23016918438493,4.49051652880827,-7.32926257547078],[2.95047682347446,-4.05886677019434,11.22065560391],[0.527507784863843,0.314259929169789,-3.15945096671665],[-4.67661350995444,-6.24424045762135,-9.63755910163706],[3.53021246417429,5.9722456138552,6.6726653457384],[2.96947614871659,7.00075062573479,7.63218702414799],[1.41067755066203,-7.42859588231309,-10.4261162027018],[3.69252072632069,4.66670324162827,8.45922016570297],[3.3789674119605,11.3031075823832,-2.07428098155571],[-9.31995960483311,-1.26356671880504,-4.67889840942462],[-3.35881180280405,-4.2738604210844,-8.86312193341051],[2.63216202102327,-2.50872815730267,-7.47298107532399],[-2.06982886749325,5.54922288261891,-2.91898368992084],[3.94476696326042,5.60676689053666,7.40690142330792],[-1.27650624748542,6.48858048461694,8.923223019042],[-4.27497885535389,5.52807002601037,-1.81153442340372],[2.34034921356236,-0.138791081314389,-9.98467276671856],[-9.66608561081883,0.226026388497306,-5.44156195484604],[-2.18065692750012,-4.60311769208711,-0.465402371076728],[-9.19403765563085,-1.61693287365803,-3.67644164883236],[-4.70713063207475,-4.84322278193714,-2.09210086710957],[-6.14082747905379,-2.59720337848968,-4.96183858859318],[-0.310135063051476,4.68715641738421,-1.06140106104408],[9.2707195780529,-3.77250200210085,-5.25903197180691],[1.24736392536067,-7.62694067494171,3.85432761396445],[-4.41818001978354,-7.33274645806601,-2.37089451285096],[11.243999891389,0.239226500570964,-0.534653731020019],[1.65045327116173,-4.11899482991899,-0.247298953311318],[-5.93072466258392,-4.7949428378273,-3.82959661671625],[2.75374796407531,11.2676326982976,-1.49950656990082],[1.83018577263228,-5.08934817404373,10.8806531357428],[-5.77250285416863,8.31730108276475,7.58061561372246],[-7.06346660613018,-4.92408322182813,7.45653944660776],[8.86324173368253,3.61759543520619,-2.29642012490105],[0.846785639944614,2.38513987533242,-3.23074690976559],[0.763706434782369,-9.30305903776298,0.776452259682683],[3.0056520267131,-0.105437863825502,-12.4680840818179],[3.20613192178737,-9.01351947334146,-1.7388890863253],[-4.85151101679635,0.975910437041576,4.42520882531667],[3.60139981735426,-6.98403950975657,-2.17978528303066],[1.55548480987088,-4.18523495612189,-0.0758788559180483],[-1.8733736437891,0.510252055193878,3.74902197219779],[11.8478431341463,3.43025985427851,-1.29784886681359],[0.936724226521028,-9.36251356902553,1.0907293714281],[0.874800747567153,-2.58964489186413,12.8574053347963],[8.58856599909897,-3.17952352979558,-4.59478959035668],[-5.92659881614481,9.16719124064954,-4.09547192603154],[3.93989265842495,1.88389073555184,-9.98311048001779],[3.10894615084887,-8.63456771178998,-1.33659799068347],[4.01846246631291,-5.30135987529908,-1.41676161354443],[2.04650436089217,-8.04840820022345,3.25827955175609],[8.24972725616926,-3.87988104274135,-3.41022488734713],[-0.198630385168698,-2.52969128600507,10.2942258134348],[1.75268106842318,-3.11084305349235,12.5701667337993],[-2.65686127027427,0.77568218572183,-1.12759383158654],[-4.83932563903984,-5.04647195393221,-2.30188433760351],[1.74622945432598,-3.27055784450801,-7.52660847115258],[-5.88594950869663,-1.66892057633073,3.85021767004496],[0.658806282477632,-6.51793068832158,3.88707389234935],[3.53496471848923,10.9431672276315,-1.86034036875603],[-1.67899175211952,-3.30976876393664,0.0499212952793541],[2.08565923527426,10.5514105488837,-3.36561539876112],[2.93312505717467,-5.21856111338124,-5.31364102729207],[3.58370517050823,4.86874006740901,8.09567658866341],[2.63308924825454,0.0613970492997062,-10.2116549632258],[10.1847034186895,3.13153824319302,-2.76408755011148],[-8.80934265533453,-1.01620428793203,-4.74247874206592],[-5.00780690164388,0.856801655879767,2.75390424861703],[-3.85969580670409,-3.24534092589211,-7.64138672613638],[0.188970641698566,-2.95376430355546,12.5359258284028],[2.97708168622277,-3.64743961077898,-10.8063995215831],[0.426099459375085,-1.58092609016316,-13.3969366944766],[-2.74283127471667,-0.0391951311231793,-0.176252504218708],[1.83389690008544,-3.30739262029958,11.9107058340784],[0.0773910574242277,9.33976157310255,-7.58530046979767],[-4.47047230097711,5.63908352850448,-0.585139184696321],[7.23241851437538,5.48372241317143,-0.253616872475484],[-2.40269298479406,4.86411685988037,-7.87508293962764],[-4.15720328416648,1.34043311625852,3.80803290268288],[2.15849546199105,-6.17631190430712,3.90805286644443],[8.67318169087213,1.1857016357759,-1.28771219107928],[-4.83466783056188,-5.55161164468277,-2.68145265071208],[-3.03818968013161,4.18399533170873,-0.0160060410832348],[-9.0247525463059,-1.64502567173567,-3.43617340842886],[-4.45437541402512,0.752524667582833,5.39959095859433],[-4.99522703877502,-6.74286034587058,-9.78062978179543],[2.16093445789854,-3.49650039335233,-11.3618194413476],[-7.65050787166857,-5.90882825059829,6.5230535553157],[3.38344596606245,-3.91952990866976,10.0472413407687],[2.85727348399252,5.6287351079888,7.02019946076545],[-4.49471351350332,0.434212088874983,1.93437019069358],[2.69479971527668,6.01486083441371,8.52696860775464],[1.1698628445486,-5.85079085015691,10.9572013626994],[5.7906072658401,-0.271277261628032,-9.84065227585529],[-1.998624154201,-3.82158059767069,0.314304046906401],[-0.454062637369503,4.6218931052356,-0.944434577895387],[-4.20634865639738,-1.29100442719029,1.95386391770158],[2.96141165807405,11.820393780305,-0.658585956622866],[3.8108763180942,5.34022277622655,7.02261935711333],[7.41846040795163,-1.10817013797403,-10.6083789385177],[7.38918919301298,4.19493115838235,-0.0143334859867299],[-0.206483301387604,1.32223484406429,-1.54303656007404],[-5.91422554793034,7.86538629625414,8.5403861807489],[-2.8683249232817,11.8444856431356,3.63414548537328],[-4.30972324583487,0.207475604107337,3.25960192704999],[0.613679504970149,-3.09299771978941,13.1316812642584],[-4.76966106371511,-0.359483821322064,-0.903338439926099],[1.00876323394034,-2.99276916639682,-11.6852139348753],[2.77680036173765,6.09045303342341,7.06692497985955],[-1.39280485802068,3.47572324473307,-2.53812184186751],[8.77344156323882,-2.39012530665013,-2.71185562112088],[-0.149454168917911,-0.0671990189027216,-1.97200637957091],[2.62826341831518,6.4033460602694,8.1732015471988],[-6.79335633689775,8.41433666810749,-3.82228246024627],[-0.581215726985193,-7.37428299578675,-6.18095621909777],[3.0350673782628,-8.88913967899589,-1.84310140012121],[10.2880889870966,2.7123213104151,-1.71858520676126],[1.95335916943843,-7.61768346929842,-1.06388771388318],[-3.94781954985524,7.06769347728004,-1.19532497692302],[-5.59357447987079,-5.35654765411661,-0.401569670959],[3.93493828049832,-5.20354447836022,-1.86486927641328],[0.879125102646951,-4.20217266156147,-2.11650284354134],[3.33826610402825,-5.53397320798725,-1.87945241177576],[9.13124526784455,3.17760038620673,-1.68695762483347],[10.0738302867271,3.82025858778688,-1.58153529805808],[0.91950976720145,-2.81791624262732,-11.4313173529126],[2.44370694573014,10.9649182475258,-1.77773783250419],[-3.75302637940048,-3.28232098287412,-7.09887862711546],[-9.10470763498135,-1.54950949004718,-4.88525763894512],[-5.20893731474674,-5.44941272074061,7.85685678079339],[-3.51803953816026,-3.41766991244232,-7.97370193464011],[-2.33396143524223,-3.82612773512052,-0.722842056112846],[-3.39424367372622,-3.9211352113584,6.41847066470491],[-3.04397921383245,0.242298766967405,4.72612521800873],[4.10079043591751,11.1127140024667,-1.59159670587567],[-2.75014641713256,-1.91180812142388,-3.77738270078653],[-2.37739358978156,6.60715942494096,-1.30947305572342],[1.59279261974659,5.67821015400748,7.33892424574318],[-2.04645496559714,4.59141180361711,-2.97819186833892],[10.0150647471026,0.523688626899181,-1.39208579288806],[-0.99539783718008,-0.659376571111095,3.0134979438153],[-1.60719831681326,-5.22536564660314,2.08342324998206],[-1.85395594182344,6.39214355873568,-0.261216385072954],[2.12792215073574,6.46134104278848,-11.9436852000947],[-9.49615743771402,-1.704008234359,-3.4443055347439],[2.38625559193482,0.374496045161482,3.44682613904163],[1.91852190950559,6.29907070477708,8.64939422741854],[-5.25755017600034,7.42374267940562,8.57637126797743],[1.85587038164404,-2.99346442505869,12.3479786336388],[-3.90495154770917,0.722019137665261,2.33397800130541],[-5.54505149375982,-0.724835447803441,-1.62172478456555],[-1.48050593020965,0.119215487367713,-2.75943990190097],[4.43379155293588,5.88637216651146,8.22172545221078],[10.9206801649665,3.05461519627557,-1.44288591985527],[3.13797180484038,4.00056727263206,8.26642961254007],[2.03885535453614,5.77515988385607,8.64720332649493],[3.87221449739148,-4.6546617409588,-2.57571326079829],[-5.25550870464775,6.76849373136327,8.52291192941599],[-3.63691632809946,4.12654355556322,0.398257137903853],[1.73345245030777,-2.6546472222339,-8.06538371240786],[-5.23500131546652,1.33636079863806,2.56620739564027],[-3.1286433995236,7.16857151445611,-0.328480410620542],[0.638123197218358,-1.56667682771142,-4.65165236163896],[3.36970768305018,-3.64007097819607,-10.4776158350855],[1.73561890615251,6.147466757469,8.55009031918446],[2.40970301628698,-8.07580920155831,-1.47789020979311],[8.46607049946391,1.16534457590301,0.736752589601317],[-5.45107693139894,-0.926047471640532,0.970946706462496],[-1.46415706947929,3.20905950522326,-2.1292862869421],[-2.19644234689834,-4.16151699050511,-0.162537768266811],[-7.55597247236636,0.110011167556795,-8.22229492188162],[2.83291865133481,-8.80668790371194,-1.92150718318619],[-1.89165204526551,-6.32453871699064,-1.19484670164466],[3.90197321482942,-8.81990326080052,-0.386348571095097],[1.07827167929677,0.526553330196444,3.2796119521108],[2.45369702048896,10.6281013189804,-2.09610962603183],[-3.26599947480084,-0.273350626956026,2.02738489705266],[2.8481798988717,0.505797419029178,-11.641837606774],[1.81068472909371,-1.31205437576852,-6.3434011912229],[2.69819286329725,-4.68635473932983,11.0589078154211],[-5.48118372765201,1.06990235625334,2.68835359960898],[6.78334297130291,4.66088082944899,0.618627536959788],[-0.227405871618306,8.99404106142221,-7.54292020789778],[-2.35868925471009,5.44407993847875,-3.25902292188433],[-3.82864934734674,0.640705483093187,4.82516149045683],[-8.39869158598868,-5.99434408738401,0.75686542807716],[2.53644946373068,-6.00018615978911,4.63992291810244],[-2.64128969426478,-1.47136923893107,0.989725936506015],[-2.7363375450863,6.34944105441329,-0.35148663326001],[2.63892488554386,11.8672420681442,-2.38007387189308],[2.8702229161813,5.99576193254366,6.51421654638563],[11.1225219379651,4.61122150576248,-0.970734253300347],[3.95647427518705,3.5816137311279,1.65896025207981],[9.43053932604373,2.85062733359803,0.395916001012009],[1.71689171719358,-2.77120665234512,-7.72924703066518],[-0.944716201291946,4.1367088677888,-3.15123229565037],[-1.70336266102992,4.4728262902302,-2.72407541338574],[0.107102181908015,-2.41618315076655,12.6497310597994],[4.42697233266956,-3.2106946976386,-3.96952403062026],[-7.91443981871015,-6.26795692079478,-0.206915004300504],[-5.43812431470128,-2.81286385195641,-9.26452994802166],[-0.271058565300593,3.23010712360046,-3.11876304434562],[-5.12816992962461,-0.00302940347238956,3.25642635028371],[2.2399484869641,-7.50748499029983,-10.8093107082209],[4.29112677137061,11.302233977342,-1.71486384249853],[-3.78922821031308,1.22615870849825,3.86261992386507],[1.91947077392637,-9.89961566243616,1.70947552920453],[2.61438742846294,6.49637932100457,7.13968244902595],[3.50383685136483,5.9138942391469,7.2777327900512],[1.6342681993087,2.23988907981947,-2.38277189683145],[4.47496252323837,1.89466429402939,-8.71212049767546],[-4.78172741496669,-0.535289056523585,2.65166367940209],[1.6293238970026,-7.90785600649845,2.65117386521122],[-9.06575375839134,-1.76001868767935,-3.2145646846988],[2.9227721471994,4.50153606649292,7.86128989447403],[3.71639917664067,6.21488445757807,7.51773163736076],[-4.86088748789869,-1.2403378484984,3.71934747983758],[0.0510061269141868,-8.14876019245745,1.01767489412378],[-4.50054740213603,-5.93713429085193,-10.0177783458276],[2.11047067610551,-9.76337159423161,-0.642393387054649],[7.78472739986306,-2.88750323042655,-4.93998317497886],[-2.54752705108133,-3.07734279215346,-6.60912150818147],[0.449607585034091,-3.25998048621391,13.00774367336],[2.34401325612185,-3.42145135748845,-4.14042330647612],[-3.76582358556416,0.350782896002024,4.8449511828275],[-1.56210870599351,-6.47445794500109,-0.342757305015879],[-3.53350796849686,-1.93468392131873,4.15892645895461],[1.22615415370371,3.74193960834608,-4.14164837623899],[-4.04607452586426,7.58304195548914,9.35023795275627],[-7.90379656876974,-0.294101540287253,-8.78825763145405],[-4.60165175969521,5.5264430037238,-0.547649098614971],[-2.62161121292123,4.82701000495848,-7.55132592768011],[-2.32685466219752,4.82197122180093,-6.74359045810139],[-3.25836694894889,2.53106827918556,-5.37568013960541],[2.07308190446247,-10.498687002069,-0.37090664857298],[-0.195974947376406,-4.8319714480137,2.82060157512646],[2.13311252676352,-2.84228062547569,10.5905261791278],[2.14972607487846,-9.21916525289309,-0.396080464094388],[4.3799365318566,3.45647622527025,1.88917782709893],[-2.89241806328881,-2.4455569352766,-4.85046261637287],[3.62833415011683,11.8812414385954,-2.95138512276615],[-0.812093307441188,-6.63079571042442,1.32347506231767],[-4.58956395461694,3.7468442117853,-6.77943134019942],[2.01767327298835,-5.51622231056273,2.37476418901151],[1.4101871291195,11.6529312417633,-2.01648983952127],[-2.42336139881483,-3.10766189510538,-2.44829138555286],[-9.20887940367,-1.45928457799243,-3.37254863153535],[-1.65853373404431,4.62196485663819,-2.86860967325686],[-5.83580783821959,-5.94283682076396,-1.13714972351658],[7.3614168323724,-1.74084619259618,-10.637117582954],[-2.18953363524315,-3.41301031715192,0.235684911403101],[-0.778433679091392,4.49555709825744,-0.267241463502391],[-3.31251470442999,3.61383007068244,5.62244156803927],[1.4050112467578,-4.1331817704613,11.9573726713847],[-2.50192224149186,6.09536252433557,-2.15555889760025],[9.26212850232309,-4.21117086922926,-4.92408575684034],[-0.0310794443899367,4.76200974186675,-1.53862962395714],[-7.00086152587493,-5.79068072020199,7.17900048099235],[8.76261842780881,-4.38595469200936,-0.946464023245254],[-5.84347682614343,-4.11353149709194,-3.95125040770418],[-3.80161239056284,4.16047562190976,0.490264115877911],[3.26626971112025,4.65153943006229,8.50588838354885],[0.571750754138867,-8.28142067378485,0.413541035967288],[3.60413915634652,3.56046389978803,0.686956106550812],[-4.16640668195854,-0.0405838194706315,4.25497679282354],[-6.0869681170932,-2.72700163194236,-5.11848989497621],[-9.22273009436958,-5.85783095216973,0.920542634298814],[0.703139128245735,0.441731534485271,-2.81009421173988],[5.27690351895991,1.51745984030964,5.04132001407083],[-4.48051008065317,-2.27409379570903,-0.656649594617673],[-0.0164897240867986,1.01459340932816,-5.39150319583338],[7.57168303340015,-1.95056878480705,-10.5723369479411],[1.24069666435429,-3.69771063847328,12.6070231841383],[1.90533996701604,-9.64352047255917,1.10601980022863],[1.29618009937492,-9.11101576342758,1.92140435933322],[-9.35990309431795,-0.349734107794083,-5.46222666006551],[1.1220192566654,3.75747745260245,-6.00207719308147],[2.60876946794932,6.22666981934956,-11.177948217161],[3.30897656705047,4.3101722165107,8.09179166242882],[7.95691012121795,-2.77307790493381,-4.7957064384106],[2.81504301700362,6.85386278597617,7.25301110355657],[-0.0876715965219262,-3.21433356773875,11.7660674103357],[-1.92279202796607,5.98600322842369,-2.12828804088214],[9.84818774811335,1.69884802866081,-1.98175820825607],[0.51604012500443,0.122713130361837,-7.51979229808168],[0.984641166730601,-3.76385078284144,-0.484010743762427],[-0.449227240355713,-2.51380233669085,-1.79772417773578],[-1.61043737753219,7.30972949052459,-7.21987435042935],[-0.0850044093100381,-5.20195717427215,2.87120390169842],[-4.28408179596422,5.56675769070691,-0.349312576856982],[3.11902821344773,3.36004781330948,7.96689932392252],[-1.37781051563203,-4.92704976901495,1.39977176920258],[2.50165801974862,-1.66861538414152,-7.31570094812203],[-5.47507295999357,-3.22742911867184,-4.13674083115652],[-3.96407735982213,5.81559459747413,8.76562210115823],[2.59465730646043,-2.18466703435802,-4.38526062660617],[1.77997202067166,4.29129255823134,8.89834285601042],[2.20500685894338,-9.04180968529136,0.825292909350536],[-5.91437092101802,-3.05011954652837,-5.21555469387261],[-5.68120796553939,3.29173301812672,-6.61307892883376],[-2.59622494460583,-2.98448245125117,-2.63826622525287],[0.173348206264361,9.17946931925846,-7.61866410305051],[-2.54407009630225,4.85009713638968,-7.28076089826242],[3.37079633180688,0.219248481010534,-10.4408683605847],[1.79976367751846,-9.27955833586875,2.37778203436456],[1.66191214230701,0.511894715640349,3.25767483610078],[-4.47639714181344,4.31921339015601,-6.4880431396368],[-3.12153889678931,-3.40184286626284,-0.953188067079059],[1.35937264980136,-6.00214193764462,4.765155291447],[8.91095014803505,-4.11675046123066,-1.45852648264008],[-3.43582080445047,1.35969447079202,2.45429439751628],[-4.84316283739851,6.2056478478739,9.01984616624262],[10.1769149903513,-1.50996336682145,1.05058884966076],[0.377528660942753,-3.07928834220623,12.7942319990285],[-5.18662115599662,2.46207927465825,-5.87740738183214],[1.96615989535791,0.628526893756566,3.41951340123621],[-0.595194922933722,-5.67577669836707,3.65097263592753],[2.88641813161972,4.3137671068378,7.83756722252966],[-4.68265685434245,0.401197012493693,2.79344733520315],[1.08697694488389,-4.70633197698582,2.13175186229059],[1.37118108061226,6.42903849301021,8.49895783582175],[1.6401549674939,-7.32132566904509,3.91677892331247],[2.88894102082128,-8.7867263250531,-1.1111616779055],[11.5893243601545,2.86799131262921,-1.43071244967662],[10.2743085008475,2.75717110288412,-2.41531880867197],[4.36115827939882,5.29499901584729,8.83790453671012],[4.32090318033509,-1.4173430404942,-11.2672277504395],[1.95085967958516,4.52371255944964,7.7552081723757],[-6.57995908989269,-4.21390922828142,-3.81388723702312],[-5.13254741312274,-6.76645147789201,-10.2776302855879],[1.42966821621553,-7.88431315183058,2.12724900006863],[-8.68830166119416,-5.83672223820437,0.499097466246477],[0.800745805297962,0.375188609244511,3.1202903004354],[2.14160548806727,-4.92600048039042,1.61823647923714],[2.94928879317421,-2.93117070359851,-6.95486754331513],[5.1777253902625,-2.52392035142081,-3.48466177113452],[-3.34357520031964,-1.72235682691055,4.27449324151297],[-4.55899873791422,8.59829716214694,-5.73858237117836],[4.62690882419456,2.68902328132105,3.91845594422192],[-0.305280023161185,-7.39010777858797,-5.76079768706273],[2.73402328729355,0.229056128159866,-12.1210851359607],[-4.26829820675757,-6.81379166027962,-3.04381014241062],[0.324405375565589,-4.96537837307129,4.08985189380996],[7.35279249092749,-1.7553518373474,-10.3143654513661],[1.28588778291745,-3.78488484714801,0.164163024261615],[-5.74716350462662,-3.27539862219413,4.29822517249479],[8.28325241080313,2.10387053161606,-2.00279195476948],[1.74056323840302,0.681202468252248,3.08112505087273],[0.0422002644226585,0.29209972692591,4.54096252326911],[-5.15935700630483,-0.0748482733719964,-1.64280235394668],[4.49868568320862,6.073251664529,2.89174259306842],[1.39647307817038,3.74886351921743,-6.07310732599313],[1.40435985974673,3.47552013292252,-5.80078823477936],[-2.85786232658262,3.96030864303669,-0.0883020138888083],[1.1554774792265,4.19691332216261,-5.95175266348749],[2.50901263251746,-1.21010054686422,-7.64672316050249],[-5.64508576701574,-5.99323974624768,7.48751163921431],[12.1857144288064,0.229608741765208,0.651993426572752],[2.40612437958742,-5.44697916807276,-6.28100728159867],[2.25093041472023,-4.49623845341019,12.1032792446627],[1.97113626181538,-6.33606401367911,2.7539708261929],[1.73559183683998,12.3174551766218,-1.6488430993757],[0.71469903203754,1.77706827120717,-3.07669830546672],[-1.58737335064732,-1.16314931476913,0.840127353029029],[-3.67429444222826,0.980119964785348,4.18264913579969],[-3.46679024257012,6.57539781269627,-0.296772913346533],[-0.845878651825725,3.97301003298829,-2.55395135127658],[4.28001453190555,5.35001402047278,2.86004278874925],[3.391093892521,6.02316253244574,7.8089898497816],[2.12323862730931,-0.120169687341709,3.75322428009073],[-3.01433827918721,4.10576559505439,-7.30836251048224],[7.58420018652632,-1.58706617821061,-10.8945036934999],[-1.95616182492436,0.575094095634089,-1.87438076289594],[2.81442601806856,6.14744839958809,-11.8517243954258],[2.05996534607733,10.779708312468,-2.15010088223134],[1.49565135886129,-2.52979032634472,10.4603285672847],[-4.89820727004898,-6.28217321514623,-2.00386507784009],[11.5518873464392,4.12062249632972,-0.964452758088549],[2.39085766378242,11.2936189789119,-2.12504604113427],[-5.53075198746575,-6.46081490507925,7.37966672180191],[9.69620546066443,4.25326781475741,-2.63677943356634],[5.19171628671141,1.30528706411891,5.77219583867028],[2.0625762303013,5.66023080107127,6.90304863379863],[1.99985783325884,2.48535621483867,0.824576747353357],[1.55571977334048,-9.98874748387755,0.532904173003],[0.981504033619982,-5.84856701665774,10.9153879349189],[-3.82513754470261,-3.89292174010999,-1.7879029141971],[1.42584496632686,-5.64465223033296,10.9364292348111],[-1.85493104727738,-6.80891815191334,1.54479669642694],[7.21906994721079,4.8905728365031,-0.347786645492039],[-1.23444923282278,-7.19880725955118,0.0730275750207133],[3.33703162780831,11.53391764195,-2.40499805967378],[2.04108247694295,-4.71203975669971,0.0201019273990832],[-5.85725496279761,9.48266899047379,-4.15823578766788],[-6.55178112463105,-5.76550288298513,7.45918591324589],[-2.48063089430042,-0.703463568356287,-0.919039482359966],[-2.75454302593814,4.69391937862321,-7.8950893126736],[10.5559207855631,1.97201491241125,-2.33754384330162],[11.7906946513547,5.59385096872498,-0.923268993515603],[-4.04979488333856,2.95818184236804,5.36158870457547],[2.88160403401117,5.01765628887634,9.07470849454586],[0.0534950640147597,-3.95918323103754,-1.45877580299306],[2.64873303788104,11.7318719611139,-0.989542727902274],[-2.74236801822322,-2.87534930048923,-6.86973037599218],[10.8477471119138,3.37149238171229,-0.997986764938889],[3.3272106727907,-4.85095744663949,10.9674619354493],[1.32590183329723,5.41995740402855,8.4195567360507],[-7.70446816765848,0.0579562042208647,-8.56339649326027],[2.48797934055343,9.93020027644942,-2.1557510092137],[-4.03644169644519,1.13063572510567,3.2060793524637],[-4.91207677865908,8.36164739359003,8.72212889107365],[-2.33175756960755,0.0968922058576112,-0.48763371876371],[-3.99072656982258,0.473661270362487,3.51764216308061],[3.87255982963007,6.25278151686752,8.4602847089085],[-2.92874087421458,3.98949009065356,-0.257354564367753],[-4.58033633823776,4.15819184565613,-6.56829172839954],[-6.28750209945266,7.81868424653834,8.01066519443549],[3.3160875060256,-9.03253811223534,-1.53206924391461],[2.77649485862778,-8.5589625487285,-1.57099621883587],[-0.438900463310309,0.998376403041645,4.51105263660775],[6.80822034316757,5.63206471647482,0.673831059507766],[0.212785338600197,-7.68484407782938,0.559716364304696],[1.83424641507909,-3.08437592447393,12.4779759718456],[-4.58224097038345,6.48678339858001,9.21886082162737],[2.47656649460169,-9.68310148112274,-0.99383858977015],[-5.39533871046275,-6.72862217003182,-1.92778359407796],[5.66089931191176,2.5594428902985,1.95589454131095],[1.27537373436479,5.76952311632288,7.16170694162548],[-0.465393003400552,1.00710495592073,4.30965605355873],[3.17927125002391,10.2781699508089,-2.28938919361637],[4.58929799016853,1.89548717038373,-9.88909152855261],[-0.887031772703648,0.594936081351198,-7.4445278806069],[-3.71369543485486,5.70420608895766,-2.5421796102167],[-3.03617744024421,-0.804141543301111,3.52132468454648],[-5.2599617187613,-3.86771307518169,-2.35057910390101],[2.46255952577807,-4.82414935477786,-1.42661150963199],[-0.852488452003102,-7.68579818283003,-5.46810499078436],[1.83753403561862,-8.83043256823539,2.90291080558765],[3.84304321790176,4.48245830090314,2.13014270865877],[2.17677545929463,-3.45924872126522,12.0184783668972],[9.25382250768129,2.69396598296639,-2.02416276514202],[2.38168558718756,4.14448231165663,7.62646139397042],[9.72630543733728,-0.171905851270591,-0.532735869939758],[-1.96087240039059,0.00174471461959602,-4.65539149063354],[0.143899214516563,-1.26477435328719,0.645099803961527],[0.658191103334908,-0.372620478278876,-12.8493783715202],[3.04431469729652,-9.7970914147334,-0.668407654859679],[-5.21224479738114,-6.96703798304028,-1.7289075658677],[1.28154171154542,-8.94969794299323,2.92279426870812],[3.85486124813962,5.96283189807716,7.58825012808275],[1.30313931292748,-5.23489796362825,11.491352695824],[2.84789713494449,-8.57776167470556,-1.58367203125315],[2.45897933552863,-9.32562887137463,1.71879233414831],[2.38196615010192,-2.75739281358039,-7.5384768883706],[-4.05561291360907,4.88686302370197,-2.68618728256681],[-2.40313765129333,4.59217935384648,-7.13979234432195],[-4.69370527523577,0.498322193297736,3.53580953723734],[-9.82766768533671,0.79296672653411,-5.92310688698553],[2.03033694202525,5.8852439537808,9.333979733955],[1.29951598636131,4.10476217621632,-6.22106889113346],[2.37072079437665,5.24594014934572,7.80483240434228],[-6.02606803013824,3.75595090325714,-4.81917489588861],[-4.7827071212595,0.290656572969484,2.6256034391796],[2.27513350144227,-7.80042265183608,3.28016056440738],[2.88195674514117,0.260259516098485,-11.6869500074287],[1.68696894299926,-1.46790085393189,-6.58705252613032],[11.8322263949877,1.51122161176064,-1.60176752708085],[-4.38474547114177,-5.7058943854969,-10.1344932344123],[-4.0601785345129,1.78161551100153,3.68064998661972],[2.2554373598939,0.615487044861518,3.33929815215453],[0.675318975962603,2.28215595245107,-6.7807413717734],[4.5428792582715,-3.16310348450037,-4.21760539669826],[-4.22222722556429,6.93450850743228,8.9544847996337],[-1.37641651631444,-8.08920210914495,-5.72375335303087],[-4.58646264977481,-6.8348463980023,-2.77359896569697],[-5.958421022103,3.62741309755105,-5.80946632405389],[3.58141317667808,6.09587896844761,7.96882334933989],[0.765800325689635,-8.34271144369551,0.832597704832354],[11.6421584843109,0.518762933372124,-0.587855511470761],[-4.50707607634019,0.775420707262894,4.96724847717731],[-2.50482914081392,-0.198224509104757,-0.380970238687117],[-2.94013808145529,-3.31729243605655,-0.622092167321839],[8.86124393428057,-3.24735824747522,-3.50418746747649],[-1.73496987789396,6.26168248481663,-1.63377032661046],[2.63736749885416,-10.1974265460993,-0.825943073940027],[-2.01782822210507,-6.14796811922928,-1.6033481641125],[2.0400572220017,-8.87066257337099,-1.01495070440483],[4.78099617844469,1.84852207658093,-8.57448948473069],[1.90211141348763,-3.53789989449508,10.6949915606135],[4.06237258069655,-8.39427707184847,-0.919812195528444],[7.86133952913671,-2.78692098866665,-4.93066922120428],[9.11585607666335,4.5871488422517,-2.38366839722179],[2.01021351081966,-8.8067958214078,2.20404363581609],[0.316817111953197,5.47353804015424,8.39417369153106],[2.95557075897317,-9.89634549350948,-0.939783829346595],[0.0335178208433872,0.624091267865309,3.08000271768063],[-4.34498015670581,5.13956507629555,-0.160204547852685],[-5.28280776122905,-0.835018924247735,-1.26140224735351],[3.14074223849867,-3.52279489375945,10.5147199364968],[-1.27877438780161,0.834779753439715,-1.69891164412685],[-3.28370840408325,-3.60258891284027,-3.06344802645624],[-3.97522878189542,1.53370500498576,2.62126980063853],[0.435030672976997,1.08862036674175,3.76634669371567],[0.940958402082957,0.182718264552243,-2.36420735272748],[4.10017824867964,10.6469715560466,-1.97617816782482],[1.098372668929,3.3975111577884,-6.73709079400103],[-1.62670196632002,-3.53191799693333,-0.189488691336243],[4.30064599355546,-1.05474470633356,-6.525695114205],[2.55567119518252,11.6061342422432,-0.977652295310005],[2.11531377963986,-9.98227213821514,0.487355676850696],[-2.16412171780241,-3.79441845374797,-1.24712184461637],[-1.22506856597319,4.58388894568118,0.0349445616639846],[-3.70419444832905,1.95293271614,3.48581022465463],[3.29117523004774,11.9590964639236,-2.10902359235586],[7.69286387180306,4.51771859407996,-1.28591040743965],[-4.50806917028476,-1.32396864139495,-1.40483576603571],[10.499263208077,2.53277155741069,-2.39654625640078],[1.79147196112873,-1.26134152397929,-6.48304319235561],[0.800579653987678,-6.06429187541085,1.63982898350558],[-6.07475863108667,7.79484931122604,8.98116965846626],[-0.235701585200921,8.95770830906218,-7.61276833559813],[-3.99134802948849,0.869159755002108,4.35898645548106],[-0.563795533206144,2.97248549319859,-8.62808128710014],[2.68469268835497,6.41201721004631,7.58853235497623],[-8.65466124976695,-0.642691244185567,-4.37144883175627],[-6.43266447017587,7.53124322235314,8.64543860457938],[-5.61196485620555,-6.4697104388275,7.47187762765259],[3.5594034255289,6.07818224051449,8.24939514944527],[-5.09585353520395,-6.90654445728958,-10.0004049937462],[3.95696686192609,11.6691401785811,-1.67202180791785],[0.82525481149749,3.72568522145579,-8.92914126888301],[2.69098034918062,-9.64815521243167,1.71917948286702],[-5.2215672263561,-0.158278428098299,-1.74066640910835],[-3.43687549684966,-0.0395848257636701,2.42883863337734],[-3.46926730699703,-4.88509815835302,-1.85338793468437],[4.22869609857516,5.24053090310991,8.5174188077521],[2.61794681074125,6.22086971646315,6.44278429630279],[-0.242083606831008,-1.18208588705815,-13.6389725077724],[2.96566496158914,6.02444573506839,-11.7397802413451],[-0.478801440130802,-5.11400512186691,1.89594769085366],[-3.02862718105302,7.35213016303401,-0.46902129101221],[3.02228375679367,-4.15365569176675,-5.02323469372418],[-4.78346432282779,-0.200439424432854,-0.718169081106249],[2.40156483918472,-2.52396865512486,-7.48455481851844],[8.8025297134568,3.28634718477805,-2.45551057983082],[1.55266073508449,1.88458604145132,-4.64148879768631],[-5.4583192011301,1.29327218617551,4.12306124380992],[4.72640373761696,0.0694938192472829,-3.34550534058974],[7.36648432910261,-1.73620489543552,-10.5064308056966],[-5.00515951165731,-6.31360457180212,-1.04020558269541],[1.40467164973269,-2.72243286865471,-7.76581319372395],[-2.43029319212309,-0.415190470103064,-4.03937083106544],[-5.17706164182915,-1.93911620570938,-0.730793399627871],[-8.17942712574306,-0.572747419603465,-8.04028752428289],[7.5966833540381,-1.37224960161947,-10.7456675695619],[-3.66705060580776,0.698770407403066,-1.83323416230438],[-4.46464296116967,-6.41055668125573,-3.09214513899743],[-3.89355479331886,1.45527353481118,-6.26888984090695],[1.89344694532676,5.93669465885354,8.6875781007315],[-2.78971081126534,-1.85911779485029,-6.26217339495519],[-2.95640768295847,-1.65365984262384,-3.54366945777815],[-2.75635928826571,4.16154816474677,-7.10427099319105],[0.378273198909678,-4.59844005596542,3.63851370425485],[2.69272552053567,0.303114141159597,-11.7946538922707],[-0.926739726624713,-4.98080583961969,-3.5133734501734],[-6.40958063607511,8.56461944912483,-4.49789804030786],[-5.03838450592222,2.89608396520417,-5.30164463810144],[0.739760607185111,-3.63556935509575,-5.41024695285442],[10.0210079041133,1.06451366897057,-1.12603318571592],[-5.15436554088539,-1.34955787103287,1.23197478463758],[2.49237063255442,-7.64920455074968,3.97107077309122],[-5.94427985954954,7.27072115691472,8.93865614426443],[-0.352634077391999,-7.51363181295103,0.403461111481594],[-3.63803641585316,-0.809504507963376,2.77791009401514],[0.12520059461927,-6.65801798445792,-6.13673713319108],[-5.63047730489705,-3.03025986599513,-4.16792674291952],[-6.32797509069221,-4.31986847625212,-4.01316373344232],[7.70312847949989,-1.54404719030785,-10.6987123174137],[2.27610058384267,-3.07928558178113,10.8404666417774],[1.51309933820212,1.51309610286609,-10.0761320677498],[7.93359810756594,-3.01012692641455,-5.0496825594936],[10.9008686799722,0.43511201021106,-1.22365281090116],[4.00402772477948,3.52624031508545,0.65346603446671],[-3.42716000362532,12.7470339261809,4.35719140046583],[4.28726611278681,4.96564525040005,2.97675716582798],[1.09382233333935,-2.85091369895922,12.8456432015225],[-6.08340241085529,-4.40212188483856,-3.91417180811441],[1.21976042541853,-7.99066420941891,3.67280667557605],[0.978457524253323,-4.55899053832018,-5.07615063228251],[-0.34741325038686,-2.42386284378497,-1.65130898443494],[0.991730525585958,-5.17940527995012,4.83642427516587],[2.29908968455471,6.53972389031269,-12.4518004653988],[-7.69763821054051,-0.632431271461673,-4.54025581398924],[2.51765454183216,-10.2838202673225,-0.0811068236223783],[-5.63381204638083,1.12043980607833,4.13297151727178],[-4.05861668070803,1.08302140853125,4.23449429230973],[-2.81160087539365,6.94665790331705,-0.538589330037029],[0.997208202047428,-6.79552659662772,0.104237780209797],[-1.35220448209682,6.48933535444856,8.47068509289787],[1.22086386744573,4.21357837036068,-5.67739070127172],[-2.68786102760353,4.51359879811903,0.276116103818894],[3.13722670002672,10.0084864178103,-1.22116844068999],[-4.83258590793643,-2.00914007932319,-4.64092353225351],[1.30052279865425,1.73345987084299,-4.75360294297507],[-4.2262451837227,2.02271307114114,4.91301079167827],[1.66986250700312,-5.79972930472806,3.77780529815757],[1.79014693087877,-3.40492788826446,12.0341893915943],[-6.20032623098681,-2.69338578445482,-5.30053818404793],[-3.14923306505721,11.7586382030173,3.30273418528138],[-5.62391351414151,3.1290960830201,-6.71073257466371],[0.521229375331972,-5.40276512552337,4.70596107592826],[3.22728605660157,6.43512029866966,7.28688336609159],[9.76218165826278,-4.78496513687422,-4.85914724148344],[1.34983965564239,-3.65165179495533,12.5554434511248],[2.47945115721377,6.90014869157632,-11.1745379127265],[-9.67680910824377,0.147808423117498,-5.64110934032108],[2.11264112491052,6.13774080036697,-10.9296245164685],[5.90976612406032,-0.366715834562326,-10.0121889496414],[-4.72223127918057,-6.12414044629185,-10.0818390390665],[0.942537182547294,1.71954372447889,-2.63689561971569],[1.12440812806475,-8.88747278344066,1.33890834317474],[2.11390805816414,11.5222578143913,-1.73692935600984],[1.45523662629789,1.66499311643042,-10.190652685428],[3.34194320755622,3.56439928848235,0.355294576015197],[-5.8418464442849,1.47696383406522,4.38991532651745],[-3.78599115125494,1.0977321455703,2.10886120370273],[-3.96155269589535,0.112568470165465,3.59414688598447],[-0.0135565611071224,0.453765160870745,-0.417685853229931],[0.429829821757364,0.554856343082928,2.86527928230127],[-4.64073282126491,1.41038883802599,3.14189046941471],[-5.59565545131717,6.664000123982,8.44103531349768],[1.63396180763787,5.79919374010127,7.86882980978259],[-4.05172368160844,-7.14666552859411,-2.29674023886241],[0.0549015738184029,-2.83976606517591,-9.91560756952167],[-8.36959816514605,-6.50434675410751,0.554914160804302],[0.664177423263081,-5.64407878273751,3.49524005858262],[1.84373668538857,-3.63253993161808,11.1554616592972],[-4.68211003882064,-0.69112305686086,3.0847902228721],[2.51131223567188,-2.91898433157136,9.53516994138272],[0.193475763632369,-8.3132726248768,0.690573924114865],[-1.73796015470009,7.63139820143597,-6.34229904554103],[1.51283677447619,2.25439811591495,-2.08051627190226],[2.90425505429946,-4.03432055809674,-2.16828904999429],[0.812692351311264,-6.04898843582384,11.1452681466804],[-9.39229872779552,0.913007594193581,-6.29281373277322],[9.41072557409393,0.958787630391216,-1.5516596317682],[7.23976850741208,-1.20421005510929,-10.7276806314116],[1.64331079339922,11.3290253640409,-2.27091270502687],[-3.79011949827874,6.85254442258768,-0.158706434198602],[1.94869712140853,-3.4009889728693,12.4997952346894],[-0.231884071347738,1.65815896000296,-4.65132089814302],[-2.40494879384586,4.44219495207218,0.117085839700243],[10.2489158529008,2.22697360869702,-2.68698483388762],[-8.02077712358653,-7.08378248349564,1.57146731497537],[2.49214214214933,-2.02241110795608,-6.4347829168746],[2.74138047584434,6.11794082417326,-11.9566403609568],[2.46990759596688,6.13182625581576,7.30717177250912],[4.01654240161239,-3.26451430772052,-4.12653563707713],[1.53332067166155,6.30970697334256,9.34550161465753],[3.75717555273718,-8.84609548692294,-0.977664116343897],[1.7902860526574,-7.44003732651492,0.971015866386256],[0.570327923951314,0.204572896015341,-3.13305421474388],[0.525438265167452,-5.69758271794426,4.22514407408094],[-3.28949715933714,11.739822546815,3.4544103272557],[-1.62389180965015,3.23878597966224,-2.53202069622583],[-1.8994523720295,-2.20458882523385,-12.0962546561135],[3.09828346209312,-4.51991431682004,10.4597571046331],[-4.65575959382741,-1.4680296503005,0.977112126016798],[-4.43375446228824,0.571350426829931,3.63658594724035],[0.489807676120906,7.31017222866156,-6.22974735152124],[0.547075057357757,-5.24319793385082,-0.922703184298936],[0.857734552902885,-8.0718336440204,0.80419546186547],[3.01017703300608,5.46234939685977,6.89195905939686],[8.73334882895995,-4.42456680638847,-1.25503323600857],[3.9787611508463,-5.10405564808531,-1.33419266261692],[-3.97167343663029,0.00261356794320333,4.9382255495883],[10.0909703362619,1.60892440920503,-1.69658500414651],[-2.77313270869139,2.33335994807831,-5.31905768771037],[2.60985807985158,6.34999965446521,7.26936728623651],[-2.15179694252026,5.82670852363749,0.279035821789783],[-4.0684759198866,1.45492763514259,3.90019303961334],[2.28034690626923,6.01599994443284,6.18212418458638],[0.835324524977261,-8.24175002486562,1.48131978790248],[1.42894847142815,6.31699764185988,9.20784873867318],[2.95525893268835,-4.62101879845604,11.1734367797754],[-2.84992439389499,10.7782775951828,3.33066259400323],[3.22068886253302,-4.08868195152315,9.81220060798142],[1.52576403052282,6.51325974585223,7.69301825962716],[-2.31872217591708,4.6269224153185,0.561280031318257],[9.49143555516575,-4.68434558001136,-5.21833130593808],[2.722890130181,-9.96336013701871,-1.28935262418691],[1.18169435509735,-4.22732213847788,10.6611179231923],[-5.32319302560221,-0.642316554928882,-1.74725325830213],[-4.45711603053872,1.72991634223621,4.62351074539718],[7.76384536344151,3.03429536522499,-1.70684855246811],[1.32983062283272,-4.24535222128327,10.5200671482944],[-4.01948642074133,1.55473086328139,3.830105541529],[0.852660798471104,-5.38602593261087,3.37925572498799],[0.393934850300496,0.461162715850131,-6.52807001354413],[0.658455698677981,-3.43242349463013,10.6228381492309],[-1.45498265838528,-4.9395513115811,1.37671628572136],[-6.20762458745515,3.57908955147526,-4.56152549570169],[0.818645500820096,6.10979168650327,7.04624924896448],[0.989975735236987,-3.59838623759891,-5.23964419010358],[1.28116758963778,1.32788689707609,-9.84366763712465],[-4.73722032095746,-2.62932548635575,-4.05640024480278],[-1.23630339158378,1.13189726768045,-2.67032318896059],[1.75370220287069,-1.67504449445988,-6.75446188275661],[-6.73181707145601,-5.48933574393059,7.05618449911829],[-9.64104619375034,0.257583156391538,-5.72931223511425],[1.69535865218307,6.09056624553775,7.79004800879935],[4.22125155559326,-5.59573394548363,-1.35418636240562],[3.87727427344625,-6.53290785598352,-1.85060726296027],[-3.60204617870315,-6.04644084733351,-1.59530621515142],[1.92113208108059,-1.70331045456278,-6.74360524378346],[2.59147497493561,3.66892652344461,7.86765077328308],[-1.25468777121426,-7.33088835887327,-0.373127017092773],[-5.96057941500672,-6.11735828668763,0.280564168746969],[2.89923823070699,-7.50427120449997,-1.77176962224142],[3.75244229510014,-3.25561711261661,-9.91896468646502],[0.322873028471143,0.337656864762859,2.85740546585882],[7.74055124397249,4.73496078188795,-0.0776782523404094],[-3.47876046852006,-5.645884271401,-2.06320012753332],[-3.70865255985558,0.998494923985665,2.5677932866827],[-3.80873392976803,5.94095650258069,-1.63932898462435],[2.17036287710464,-6.01926730481894,4.35814905707053],[-3.11824032117228,7.6989197380804,8.47409396249181],[-5.2123178981773,-0.252275223738488,0.653884670387422],[-2.01823225707517,-2.13499315850883,-8.79725082971545],[-8.80902676172635,-1.10254483142396,-4.56709950863525],[1.54368511491168,-4.4349852207159,-0.198139490813361],[1.78381121350755,-4.90228596413851,2.29758328140364],[8.92643730633241,5.45264606764912,-1.06321333395839],[9.56185110511721,4.50143562695174,-2.26477268600677],[2.02458045611865,1.01256584172234,-6.68583247788318],[-2.34807039392907,6.69270345200569,-0.556580906170249],[-3.17716054953154,8.86800404016634,-5.71481094835216],[-2.32995724204323,4.42064855948338,0.985633457728604],[3.54667531845586,10.9976074640339,-2.13817741717603],[-1.84181362644903,9.79792380292761,3.47102868582802],[-4.00189356134687,8.40770970649625,8.29950829513272],[2.50496972859793,5.66592146704515,-11.856126509852],[9.21750989181143,0.931019108209968,-1.26265472020087],[4.08517975018163,5.48855521799028,7.29913462226069],[8.84858868870275,-4.24499832362663,-1.76381413621355],[-6.91809638325473,2.64157931617647,-5.16527017057887],[2.73778061269261,-9.52713341538029,0.285920185747478],[-2.50918030761924,-4.14887016335843,0.249055421234895],[-2.78660036980295,0.188654107425484,0.633292911941611],[2.80487688420486,6.1257718721605,6.90042589609428],[2.27330129333364,5.86197746448076,9.33736769979524],[-6.49887471624947,7.94922960787285,8.5524345146067],[2.57553918783827,9.76051205690479,-1.65396281002537],[5.02770046433092,-2.85776038197273,-3.81616255198457],[2.43904182097571,-1.54309795923821,-7.47074019468802],[4.22370979286357,-6.77441090936883,-1.08182504647009],[-5.69406649328996,-3.68134864778085,-4.67931522546382],[-0.202530586223073,-2.69100854176143,10.8652003421604],[-5.64114770440064,-3.64925791949102,-4.27748561442879],[-3.31833681317724,-2.71269012351209,-0.772282066362851],[1.20170053712678,-4.64140275381362,-5.03039154604039],[-3.66963383143495,5.61878726056918,-2.54757952100845],[3.2697622609068,-5.86714853711445,-4.67896115213541],[-4.38569703119663,-5.87900425726172,7.81411312616965],[-3.68588822443912,1.18245737419807,2.26055203378583],[2.35461781510106,11.9473904140805,-1.64264463300225],[8.37772688163289,3.46510245485312,-1.53723499287875],[-0.989061321256931,-3.27287250725582,-1.14354649213309],[9.09798557194134,-4.34704546893123,-5.31495370392614],[0.68415280544522,-7.48088213737007,2.39440240098089],[4.1680537736483,3.70475629462671,0.822085060336814],[4.38112328463775,5.81269030430958,8.35261719375205],[2.2849040174271,5.79161431589606,8.80235044037065],[0.645333948406472,7.18079775941366,-6.10400900388603],[4.5117675703999,2.61546230080652,3.5561631125527],[-2.20846828426184,-2.74398156375702,-0.298329073273159],[-0.474448732188787,-1.16450218612111,-13.8855209918074],[1.87873764564972,-4.52642382709954,-0.208261119920404],[-1.57935161612641,5.23155896697284,-3.32465886783643],[-4.79726040544813,-3.09676780019081,-4.14046365117256],[1.55695276704449,12.0676275739846,-2.46541715202016],[-7.70224898727782,-0.615006210099275,-4.49539035950478],[-4.2464897977295,6.88489198187512,-0.557669799560006],[2.0476615311166,-9.34233379223904,0.961431858467758],[-5.50508142362622,-0.818174210810685,-1.29210055449088],[-4.39130864429779,0.605333794064404,5.48271340895397],[-2.02207500895526,-4.71743336778812,2.0382506408533],[1.64235398010693,3.73526573471027,-4.30316270721065],[3.75940761856442,3.22494697056389,2.12206446662845],[10.2923426476112,-1.21411836786873,1.07005753478188],[-2.33102175417412,0.106266669119469,-1.15969134807192],[-3.86677912716226,0.764178356424707,3.13454668990634],[4.3129036520945,4.69510316939075,3.09231476339557],[3.45703319038349,-8.61569783960801,-1.43838821110423],[9.1886855157974,-4.39706173175664,-5.80242212452639],[1.86135727594837,-7.41104638443195,-0.321221326907008],[-3.82733801724025,4.53177825991603,0.104725422339688],[1.64184451801051,0.314166344835195,3.27082097345419],[-4.38179150889165,-6.12388794182201,7.24814135059823],[0.933572793246348,-8.44294557786944,2.00509287226993],[0.716755534362508,-0.15955851322088,-12.6904509005934],[-2.63730558187564,3.78509153104391,-6.58154155331277],[-3.91612274717403,-0.0354732694823754,4.34141767312633],[-4.73458496989049,1.23499337510865,4.30766832596989],[2.27716282364739,11.072668458684,-1.97389658448318],[2.80239662650199,-9.39313942136315,-1.26070418669681],[4.30762227875018,11.3619398332927,-1.34985297546695],[-4.49749788380954,-0.309182080476127,2.71453703850894],[-5.65848980318012,3.12491290609682,-5.91607825451741],[-0.78266071810879,9.51351847631051,3.79747110292324],[-2.75011364057138,7.20976405889401,-0.775632097764353],[-3.34535243916587,-5.60609871932579,-1.39400550601715],[8.9479747049728,2.41241091837804,-2.33202216035556],[-1.43605539606676,7.60938115524034,-7.00255872964539],[3.60835516213172,-8.90621948272523,0.0479791806087085],[-5.11310508765749,2.1291757275808,5.19759967376205],[1.33885573500267,4.33604570645273,-3.99604927266329],[-0.00396297831945047,-5.4631152874089,-2.65339971336411],[1.91411289234609,5.85125071409332,9.35547945353932],[-3.9597315270627,7.36300404290199,9.13477122838698],[-4.63539294065757,1.65952487568679,4.91163784157859],[2.8728748625483,-0.134424027997596,-11.69879340935],[-4.23143088713568,-5.53841284775762,-9.46945273421701],[-5.84724520546037,-3.30669056029082,-4.67114656412741],[-9.9260900611784,0.869445543107407,-6.1626337823323],[2.25519215550569,-5.33608087240203,11.2617459329218],[0.679869526261797,-7.2023834894737,0.8958513319197],[-4.42647177438337,1.34729888682181,2.38845560585512],[-9.04296679440788,-1.47614074486423,-3.43758536070707],[-8.4771661163448,-6.80781026596362,0.343930381792625],[2.72705913587556,-8.70341349736865,-0.00469334311165892],[2.22859791262064,-0.209650640326136,-9.81712578377583],[-2.86582666798212,-1.6543189099165,-4.05482459051593],[-0.713678938306647,6.32831226653976,-8.38322092561599],[-1.69342634244775,4.896995520074,-3.21649940526074],[2.68911315792378,6.31884405105886,6.39721598106861],[-4.32761046516917,-5.61723369926514,-2.60071679263785],[1.18461374571867,12.0100774777272,-1.25534199951024],[1.37580450578474,0.817456348882081,3.34977655435742],[-1.70313226696825,10.2637141756289,3.54622859114861],[1.96842508067403,-4.65722276114396,10.2547732284468],[0.12751859189298,-3.96156242722025,1.88973879471779],[3.76916019044378,-5.74698539341512,-0.873245212194126],[9.8482354638045,2.41996297309678,-1.54687840872753],[-2.98740643943302,10.1541188204369,-6.36560930480221],[-1.65419877829762,4.10860039402409,-2.72897312277602],[3.71116081306948,3.78750376612916,0.791765616287209],[4.11967291482086,3.61405308794417,1.97115627984107],[1.75400215053891,-5.46136261724726,10.9734604894586],[2.63727496259969,-9.80244387156275,-1.99823270088688],[-7.66627708183095,-7.04055112768793,1.52073529578965],[-6.92251153677747,3.17358355280509,-6.03232186935609],[-6.03236019092476,11.1124336180538,-4.50883024773985],[-6.24890498124292,6.94773334793933,8.70393148798758],[-3.66193673694216,6.9763197480537,0.0141626823814076],[-8.74719708464496,-1.02295729242967,-5.38455110320001],[2.62475751198905,-6.14188478148905,4.84451924737206],[2.12823761096171,-6.74954330730721,-0.703417549249818],[-4.31326768323717,5.60928226568977,-1.19301843318696],[0.969342152624675,-6.70525549787141,0.0533204597306204],[0.169574861010541,-2.60352559758921,11.8413234624814],[7.05708473838265,5.65371557446395,0.73271365999839],[-3.68663584070336,5.17105475506591,-2.10928428713334],[-5.07886879022836,-0.420405099194691,2.66159656705189],[0.656446649218949,-6.79488263319474,3.72195656626973],[12.1358542846381,2.84334539226953,-1.04118213587235],[4.00183338551747,2.08991914178539,-10.4289240644619],[4.2883219823367,5.73969560277486,8.81357763435227],[-6.12696886324089,3.3647200258323,-6.33915888086006],[0.460664241621771,5.65039027763417,8.6376839153928],[11.7280973165784,-0.188970652346917,1.05331804183992],[-4.82622604999884,1.55719548460973,3.48116118494264],[0.474542568466791,-5.08509971027225,4.0557278426819],[2.11307338948337,-0.0167422737624146,3.40237094545454],[9.04481806367886,-3.90598312511021,-1.41517378660144],[-7.27618499237231,-5.80979629533433,-0.198688327281946],[-4.88996444834054,-5.74947809146648,-1.81327057126426],[9.96726299040627,0.584658751965263,-1.49559744452865],[3.06222045308936,4.4713424232238,7.83819749289301],[0.661771567400957,5.63558042121564,8.87415707610379],[7.49469894002396,-1.66326574478196,-10.7028410779748],[1.16905849827328,-5.61603487235269,2.98960807923825],[-7.03284205513574,-5.81583569624989,6.50753854079147],[3.08043379866526,-6.90293683122689,-2.0060615273051],[3.64174760394264,3.83158109022679,1.27790438314473],[9.29934317338214,3.63096319623428,-1.74544063119078],[-2.69916969106892,0.0886466523610038,-0.0538601007176934],[-0.628422478146038,0.482922954842307,-2.85704194981476],[2.31685246223353,-8.60251783311738,3.37427588167099],[1.86113465200996,5.20155611318524,8.58933031280234],[-6.39720440268338,8.45165927382545,8.17106454139207],[0.620852827594766,-8.98591707694585,1.54036953251999],[-1.93614967526443,10.669270106055,3.48756746838245],[11.0625566204624,2.58847971377129,-2.18091478263538],[-3.49398532373204,7.28091989919975,8.56762645608163],[9.35546258411044,-4.20184728815827,-3.98244361928219],[2.88156368491754,9.72698983923598,-1.7475010036454],[4.09375731059527,4.11619395041641,2.70498010104492],[-6.39316975433583,2.13374920405353,-5.70918312094946],[-7.46542388468039,-6.0194799736995,-0.220106525385762],[1.53743866695072,-4.61888609324218,2.68390187655593],[2.20190089679283,-3.38010284905432,-4.03106653750776],[-2.49577789344407,-0.145863200270936,-0.482551837072594],[2.43059717097472,-2.21371148299801,-6.82030973611092],[-2.4429045340162,-4.75550082347801,-1.76583556383102],[2.18509063055027,11.8390649188044,-1.52204984739641],[-4.42356465529067,-6.13241997706946,-9.30453504727821],[-1.43362730893162,3.04424885021311,-2.04213476128366],[-0.246095355899577,0.569238609138219,3.61292757078288],[-4.97814854729197,8.04893732755319,8.14733103837187],[-3.55447703559177,7.08095954548374,-0.868888817300538],[-3.25372996492691,-2.80792849971551,-7.94000600407249],[2.4559255308163,3.71627097772589,-6.27626120586391],[-4.86596966324423,8.81940438785318,-7.07642770158766],[2.97775953462927,-3.28819844983502,-10.6173061658586],[11.6000899213563,1.12423128462921,-0.955362493173752],[1.29119339766884,6.47729098133614,7.91799287237376],[3.16541756923024,-9.60392292939921,-0.228724533029741],[-4.32325310628677,7.22553527560997,-5.39865157793747],[-4.68035685950541,-1.06061397552619,0.830933223515533],[-5.12026967946463,-3.90204642897151,-1.92488943831546],[-2.97387955833933,0.739380169978469,2.7186179082292],[0.0778763673699381,-3.08117574780171,2.38931834665282],[-2.36826029966281,-4.85546559279149,-0.562912723057498],[-3.02475038028301,4.32245186149876,-7.7217195000975],[1.91393427062611,6.48552559027657,-12.3420171182107],[0.573694086248506,0.0850795906831238,-2.79137588956804],[-9.54957589115745,1.02602637058439,-6.19430706772714],[2.58574065022467,-6.00447532115353,4.75117880656137],[10.2994501145996,2.9018648603097,-1.34525076092502],[1.29721211803952,5.73295743908405,6.72371635885373],[-3.76324848051882,-0.185630437217436,2.46402493442365],[1.53798040390079,-7.15789184511419,2.52903564023628],[2.61811566140464,11.2507554671742,-2.00976835289491],[4.52395245107163,-6.10853219142314,-1.94792973442815],[-6.84698884633553,-6.2706274580224,-0.2060986751679],[-5.48318640083266,-1.55093655575654,0.40846408594994],[7.76692967842799,5.70097943552128,-0.745571839023168],[1.06376416020396,-8.81160080353921,-0.360628474500955],[-3.97939017693314,0.919291866423611,2.97761486255263],[0.53580218973841,7.2361230427039,-6.19627278724925],[0.88061731905107,-2.82375418423433,-11.7781147477187],[-8.90185475401903,-0.306927660985846,-5.0337829250954],[-2.65853531642548,5.11357471812129,-7.81571431139003],[1.42258526309057,6.22868214905395,8.32610439439934],[-5.04899891332405,7.32369491999687,8.29345556518301],[-0.548943702172175,-2.01979491907275,-2.42537218962173],[-3.85589565118826,-3.95625422027683,-1.86881513893193],[2.37146939459038,-9.24333034090756,-2.25726162818934],[2.18547870332028,6.63753824341757,-11.4770560171703],[-6.18610492779852,2.88664936311936,-6.60322952251301],[-8.98610523339222,-6.26049394959886,1.1851089145205],[-4.53493085948023,-0.922780832599011,-1.34921488367833],[-2.29802922057007,7.25201823123075,-1.28128773327386],[-0.506508702117853,-4.29833257192536,-0.878527622829706],[-3.50780905566267,0.664237236665932,2.46606598613226],[2.28031677830793,-1.18971253144536,-7.63196206457284],[-4.46999888823353,-6.10958828303819,-9.44543492649939],[3.79524287473094,-8.38323777916177,-1.15749903889071],[-5.07006715006516,-6.27193363688926,-2.17584654742437],[9.53458389858869,3.16579518060936,-1.56231716069106],[-1.22859505149499,3.30059973495713,-2.3565243532443],[9.7028742982742,-4.84665295836994,-4.63179385718281],[-3.880812255595,12.2371419389785,4.24371175812967],[0.532508406109884,-4.95479842841036,3.62230823439768],[2.83570031285786,-0.00859553159191184,-12.1876950039214],[-2.28740866363738,-5.42000750722252,-8.34537198870708],[-6.19371281242833,8.4097289391509,7.6844890073655],[-1.9702465489534,4.58906633934112,-6.87823850280316],[-2.45547508293294,-0.395319927165556,-0.147596721182786],[1.46662798717364,5.53575736061796,7.35107787781233],[0.683194759321288,-2.90814770739894,-0.602406556051317],[1.84362353369391,-5.02954587710055,4.06975520197921],[3.9437493115804,6.01544955598693,8.08926674199206],[-5.69383674954552,-6.1979331253095,-1.27675783176188],[-5.63999833996208,-6.64673907969553,-1.57135628644376],[-4.37463472790093,5.07504088322787,-4.42871938385638],[4.20363965284807,6.43540139633216,8.39572285657631],[2.67483712489232,6.53812445501253,7.81049818924461],[-5.33716268550775,-5.72880438131429,-1.67121758745577],[3.4683938773764,-5.46307775132828,-4.75758317960241],[0.295365995340248,-7.52817110628949,0.993251343416164],[-2.20159588624631,6.67349463362599,-1.7918683028084],[1.01793747705144,-9.17417412989778,1.56986789078343],[1.46817137013025,3.72080662140414,-6.2575505145236],[3.6113077089211,10.4615935269907,-2.0802926355821],[1.03857708256857,1.36665119161842,-8.99963843265727],[1.30378560033393,-5.01120242146314,10.8489340028015],[1.94293399739866,-5.82103981187012,1.30487637077991],[-3.54388545176749,1.44933294890904,2.06663776366553],[-9.81697662641726,-0.46757484873989,-4.74322209903993],[1.02671756416355,-4.76936574309265,-5.34089513012644],[2.09628203471438,0.670912413731537,-6.96393224669863],[-3.80367965985108,4.69641133115076,-0.320005211251382],[2.85846483785979,5.83797487091522,8.78169854927681],[1.25972489800163,2.18099121334627,-2.09942869970728],[-3.76961739394982,1.28863649647478,-6.23150696212315],[-0.798605560733123,-5.50994240436067,3.37136242918081],[0.00436991536040432,-2.67817226264311,-9.65873702667892],[-2.59502206211488,6.41513722378219,-0.619220520568582],[-4.17687398656398,5.05974568304732,-0.573349420712154],[-1.73647593374859,-6.51256323626117,-0.679135276862355],[-0.121108586597986,-1.01656372842067,-13.754869158661],[-1.71382734239758,5.91533088119011,-0.256112855854294],[-3.80898939535526,-5.76259293891298,7.86209566202635],[10.072219374958,1.97250069670646,-1.76352025024266],[1.71004489277393,-7.96735377983924,-10.7088372512359],[-3.02463682442928,-0.873029505479961,3.32227044267575],[-1.34616096248586,-8.01678539992568,-5.76567964512939],[1.73990776579333,-7.09427397351745,-0.407654618378239],[4.23195056572792,-8.10261588115745,-1.0600800458625],[-2.75127001115595,9.22513705619265,-5.76760999725572],[-6.92785618455163,-6.2337768950121,-0.373751543234284],[5.17413711653594,1.16603440904092,6.00315221979993],[3.03363425374155,-9.2442554518078,-2.12783577235162],[7.25740248860825,3.66779561773537,-0.0450189913908203],[-2.16807485222664,-2.40925201296541,9.27218863445709],[1.80159028064884,-5.67560535662609,4.02600677853981],[-2.976974516358,4.68924596349228,-6.94699982477724],[1.32095318611035,-9.50370820560932,0.325901425595091],[-2.07642285226255,-3.94418712285174,-9.49278544623032],[1.65021261399237,-6.88234165694214,0.236212947689697],[2.86625830636289,3.57727409811957,8.15943666137076],[0.799438704039219,-4.83170564567743,-5.07418492012224],[3.72722776017779,-5.25190555023006,-1.23895651081963],[-9.49872272079193,-1.24647966877585,-4.34967600619577],[1.12377852263624,3.47396204631968,-7.04080369282465],[2.95448393012347,-4.39020842272645,-1.23951838234026],[4.07065986419476,-6.20099632039886,-1.33312358501585],[-4.97036955915078,7.74201233239372,8.14195881868127],[0.299538280965379,-9.17090751405937,0.501196837698585],[-9.30316431366995,-1.86707683128185,-3.89365323865312],[1.75208959404707,-7.41870588822878,3.80303186760792],[2.1120759881904,-5.30764607348405,2.94968186084857],[8.30568745985833,2.86709690421619,-2.41391286820759],[1.36149517482905,-2.48560701810204,12.0720394010252],[1.75229142170214,3.78876834829819,-6.19873415741897],[10.1968637484289,2.84610034015323,-1.76443881857322],[1.81770910840337,3.91868566096344,-3.97810576226812],[2.61689979033289,-8.46285400278492,-1.09628221981934],[-7.99628989999753,-6.98281527676668,1.71902589728483],[3.08695819491573,-7.67035113912199,-10.0006827131346],[0.316189986447546,-7.54673503300615,0.152202186900085],[2.13190871214603,5.44708858898372,7.27415511998859],[1.65398041433141,-3.46289880158922,12.8954787555267],[2.58681962256783,11.0519354028969,-1.16456968315071],[2.40208463699083,6.84654457039716,7.69023189077682],[-2.69769352006642,-2.67634880617358,-6.27900705509883],[-5.12352851849904,-6.80971373962582,-10.1120543547837],[-5.71267415022931,-0.87151014716106,-0.683635414956833],[-7.7942744053138,-5.8732220337085,6.77651600552422],[2.06761919837132,-9.37817362906294,2.15987273327011],[2.90903387526336,0.200138697893143,-11.5518952086365],[1.87479794309057,-3.85847114289084,12.1646045817186],[0.83730183810727,-2.81010800369483,-11.7676096712497],[-7.05484683667854,-5.60998332510708,7.22087306702628],[2.44894742575924,5.62696308032708,7.57990746142823],[4.01002506577206,5.84576776803137,7.22741123404059],[-2.96802155437847,0.202416538800412,5.475522265256],[1.95278546709073,5.36621800483909,9.29207211238435],[9.64510651064987,5.33050511266313,-1.35540409250264],[0.249000271511438,-8.43758913335338,0.793160996687089],[-3.33573442038719,-0.24323616752433,2.99960684967133],[-1.12033361942891,-5.6613591763847,1.99018099545127],[-8.69091336537414,-6.65781977914922,0.896699102572895],[-3.33314301111104,7.27017847991188,-0.18616142068603],[-6.61286962628304,3.04678984145304,-6.00826239704973],[4.3994849027665,2.30341050484214,-10.056713253498],[-1.26162730495359,-7.28250094045026,-0.442373488977211],[3.56632884004007,6.13936467147388,8.22890488920575],[2.88816269679877,11.1585106576438,-1.740742988261],[-3.27239032280642,-3.48109668775306,-7.75277177720823],[1.13769495732123,-8.70322027191614,2.52351538102347],[2.18221316584566,-4.83592359215879,11.2537063657085],[1.71903433735937,1.51309694586726,-9.07518601603652],[-1.24073298380536,4.78452026366571,-3.29092993843753],[6.89630786617052,5.70794762734265,0.550022455447372],[-4.76287569233297,-0.979024564547154,3.81405675544148],[2.17421701285557,-5.6608507224641,1.04419870496556],[1.67602664222213,-1.28740304314552,-6.4603507177805],[-8.27548686808813,-5.56570328309245,0.430745190843588],[1.03288764730451,-4.60064199260665,-1.9110974106503],[0.172363372020936,-1.17996841515854,-13.2812674938384],[-4.51761014873046,8.30866474396011,8.72834060592807],[-4.9421669478644,-5.84745666908837,-2.6244469312928],[0.517288163138415,-3.84488536514917,11.1014052851499],[5.11881104800944,-1.81903048417056,-6.78650157059739],[-1.53961655963055,3.00394226308543,-2.37821623863404],[-1.2478430513711,-7.24678224955214,-0.753748199927421],[9.18992972942173,3.37110562898857,-2.24973082376875],[6.72681370031446,4.95008437596104,-0.094298574467385],[8.94473963226506,3.89305084656345,-1.59111410665936],[-4.15622349130163,1.58439409977533,3.45408412466791],[10.4921931216283,3.30129495824557,-0.921721094081785],[2.27648072396667,-9.19924042667433,1.51254640952567],[0.790214334611769,-6.03510138790561,3.21297507682856],[8.8431969181976,-0.0859050340079617,-1.05923144845707],[12.6642771008242,1.33053505434798,-0.250612237417619],[-2.32414429208446,-4.61884804897769,-2.30327670190544],[-2.00320823159509,-3.34522723308964,-9.71622029146796],[-0.811179805998637,-4.28373662479122,11.4008008656242],[1.96669571152566,4.9582528168479,7.41705495519538],[3.05399419004384,11.1987114272476,-2.82124848742814],[-0.80091052899932,-6.55457058950112,-1.29812969474033],[-4.93551641743456,-2.72092263676967,-9.46709028211132],[-1.69650823599049,5.39112085811879,-2.79675908618126],[1.78487990185227,-3.24361815527133,11.8683878996373],[-4.60157579536673,-0.256787503871704,-0.562536492486329],[1.20657580191765,0.151298796465765,3.70726342072086],[4.72164573349519,-1.600209130494,-3.01676255313236],[2.69963329814919,9.81277513313038,-1.82851278424986],[2.88593948051447,-8.4403917512179,-0.201932759073195],[-0.963419536642404,9.69104337708739,2.53178760928187],[7.80154015999279,3.0467069627507,-2.23812897344615],[-7.68570991548311,-5.77255391770914,6.45511231888845],[1.18025349865689,3.36563892927511,-3.72139059393861],[0.920581163320888,0.552159103023556,2.92703380087885],[3.96545295991516,-3.38304203138899,-4.16507118143642],[-1.53920295619191,-0.988415141686819,-1.94060563353745],[8.74152275493811,4.40192510927714,-1.7350087082616],[-8.80709351330829,-0.609506909818569,-5.28546186301629],[1.64889620331553,-4.01898131872522,-0.121317667578342],[1.93450546632662,-7.13060298647912,3.31222021146655],[1.33974343477956,10.6670499486663,-2.13437676285869],[3.38672981800833,5.82411467346404,7.90382169983438],[-6.17410539485862,-3.07118404252922,-5.25762901151265],[3.69274935555372,4.72721121566776,8.43036389060207],[2.46033141396784,11.0384007127075,-1.97854337512356],[-5.4616888434593,-6.41095041224457,-2.27290662246206],[-0.0251228565417915,-2.33271017195245,1.73191434284362],[1.82388008983401,-7.31107885520018,4.56902595406502],[-0.929519854384972,1.28781736611388,-1.86194904844844],[-6.26566247950132,3.15615036117889,-5.91303141828],[-6.43480712825059,7.84011539179611,8.22521278035851],[-5.76856022674788,7.72686288356979,8.60046803835452],[6.07127937474059,-0.32519361794832,-10.0686295304347],[-7.17696488173802,-7.11752539248879,1.21428026598757],[-2.36201351599507,-2.81626127505607,0.0207854422837914],[2.81916559742278,-2.84051824549514,9.41950315584805],[-2.10272239574463,-2.84134037747728,-3.77775171341899],[-1.77521319754102,1.7138187720073,-1.98813479825691],[3.16737450477832,3.60971402708321,8.07929088361477],[0.0337241240759726,6.00148755087812,9.02808944452024],[-5.28136420897412,-5.61984584938156,-2.07477281274033],[-5.38250925658287,-4.57346125800684,-2.85893466519894],[7.92557836697574,4.30889773060705,-1.1848159221848],[0.676922039763188,-9.27132596836316,1.26061599767574],[-6.39868080405329,-2.08738849717975,3.86544841987253],[-4.27878417348794,1.3806919569475,4.90420755922766],[1.10415510301323,4.2230929419561,-5.90089095895785],[-0.69202271518469,9.38026830938725,3.9405418107831],[-6.84732520275602,-5.20453817372203,7.55130610195815],[1.45819023021123,-2.2826559578691,-10.5548910869114],[-6.29718208521547,8.552134936695,-4.4088711577343],[1.04567897594546,2.10374841397142,-2.63817237890328],[3.1933373858966,11.3255685528966,-2.18571040134469],[-4.26417856795902,-5.20581651892578,-2.198572781228],[3.39436190442057,-3.0317658746852,-6.77944420922705],[-0.7719771172322,9.71440165158783,2.77360988007967],[-1.95622585335189,0.424158446665266,-2.86277158945249],[-5.48564522672233,-3.40181446058727,-4.6927646781931],[9.80342138827775,3.05237753136086,-1.3104797647772],[3.93509551100039,11.0106307635289,-2.02951528647011],[-3.69305152282203,-2.19398053518014,4.1290243514046],[-6.02900675297842,8.40857062987495,-4.30878737589084],[1.62990704101874,-5.28324507197722,2.66549322578978],[-3.28242898992652,5.61000194996345,-2.65862600573233],[-0.175168806932967,-7.44737342159181,0.53650449298814],[-5.00320627687347,-6.75727106831973,-1.5515333178695],[2.94583248908459,3.96832112135536,8.06926690737352],[-5.66831187471448,1.39323355623012,5.01848634386179],[-5.67991312796205,-5.80480187269528,-1.48080122260958],[-0.360873323643567,6.14010080620733,9.26222585768165],[-0.520487625137086,0.713335177818879,-7.70463031613685],[1.86584406329898,1.57728553727677,-9.96832647155375],[1.58476133976739,4.25748733299756,-4.29804288680381],[1.27290214379013,-8.30118733372093,0.497422181013461],[1.81983660951213,5.59360465143707,7.07093179586574],[3.51976239873378,-3.44036485173924,-10.3212617808506],[1.33327282864253,-5.22814256103325,10.9030651567827],[4.59967820554765,1.27695357835474,-9.57016765261475],[9.62943554129952,2.65212891086955,-1.79719987294225],[-4.6726384525858,2.99782681307425,-6.46601625516499],[8.53038040040333,2.80488302707997,-1.34313207385702],[-5.62927724641269,8.11053281500761,7.73335096616513],[0.65045484224797,4.25305737781625,-4.05522957639664],[2.94293763688986,10.9406568339528,-2.50255173612184],[0.143146950033774,9.30667821249911,-7.13941941452435],[-5.15461130810357,-5.70625332186386,-1.95816037608863],[1.21737274548683,-3.45833493972614,12.4793339532988],[-3.51998776922974,-2.15633817036343,4.47477906985151],[-3.61480434886736,-5.97498848457922,-1.80718767560611],[-3.79967696546071,6.04751446798613,-0.479212554156729],[3.29264261696596,-3.82034809577553,9.9803487017253],[-4.52090884685402,-6.57192850811822,-9.85833565351714],[-4.63575397681738,6.61199579692686,8.50021145799085],[2.49163400283755,6.24853863499732,8.21417650190636],[2.82564732727872,-2.74110047571998,-7.0690078601826],[9.12677659889476,-4.20456637709771,-2.40802787250742],[1.73212567703067,2.6985994939562,-2.42870394397539],[3.21067455708267,11.5088939373856,-2.85034449974183],[2.6857854814014,6.52734220271092,7.94229620228532],[-9.53351529848765,1.0037453448242,-6.0742686748285],[-4.27744605326383,-0.804474588805138,2.45129757332022],[-0.332627457170091,-0.380710713938685,3.0880570373637],[-9.23384447377573,0.819020274541008,-5.33475035885821],[-1.85869750905553,6.5148693317028,-1.24410641896899],[-4.91042990171961,-3.96804295581285,-3.01130978736099],[2.05932697240406,-9.44830920815862,-0.958587934994123],[9.41580197739492,0.540866389149745,-0.329458586977991],[1.39156110550618,12.0607061061881,-1.84314781109339],[-4.20687852221169,-5.16782016219661,-9.31503245442598],[-0.832472302118347,1.21604703742823,-2.4162199567046],[1.93810887859443,5.95550269897457,-12.0161936172711],[2.77734486181541,1.17526438097505,-8.2282323586501],[-0.345216362847017,-3.95132751148904,-1.19510261639926],[-3.02726926208427,-2.69193257327592,-0.414000497350032],[-2.52829243909215,0.488370075691267,-1.18785712507418],[1.38527676469976,-9.15734888708014,2.23957972530789],[-0.381822081060273,0.727250311080214,3.9882661074514],[7.6392219652103,-2.0761292122022,-10.4229071356992],[-3.06597792475945,0.16530941167684,2.41267754441139],[2.96097924958282,6.42212106306244,6.86038152126422],[-3.95963092870958,1.17728621972877,2.91487537461682],[7.60198274395773,5.78863538705358,-0.562653342164674],[-3.24962278403834,4.46022939038277,-7.17625816802401],[4.17558356491947,10.7648610554637,-0.789996898379632],[-2.70352354976821,-2.45431989080541,-0.571400654588758],[3.2836492257187,4.88083698348265,7.03689591977013],[1.8273318610326,5.99188535354428,7.8295810372387],[3.66372643066652,4.95555040006189,7.62914396134882],[0.94292411707696,-4.69343457156564,-5.22318832218715],[3.27851141564298,5.6709203034675,8.87360960237225],[-6.22284269109627,-3.91105918806522,-3.01831070613416],[0.208579179998989,0.287744055161406,-2.82269132985996],[-3.89632793150163,-1.26239269767916,2.07541259956052],[-4.57439770637805,-3.20083487510118,-9.05876513458699],[2.91534674945069,-9.63454432724711,0.0872307372333946],[1.46543617314556,0.0238247943043599,3.48960530723568],[-2.10696468180538,-2.43933254923579,9.17275095431343],[-5.12326483139831,-4.31016661018566,-2.10559515173056],[-4.68359139607042,7.49436170076353,8.9158859760261],[-0.43283295111651,0.92603150517949,3.72412628628827],[-2.46952103428637,-0.249418687375047,0.328698116835965],[1.23931398376162,12.261530266889,-1.08211336484936],[3.53085761013596,10.2355224990653,-1.73047953677226],[0.517591033194379,1.62239450368313,-2.55573046270146],[0.0378970228827171,9.37722275626676,-7.53560205734681],[-3.65966149553685,-4.65365450398935,-9.18418877512362],[-6.20167472144749,-4.47870404786018,-4.23231132610524],[3.30312038191854,6.96468826028179,7.81577113487776],[10.5349415943642,1.8657516146066,-2.55321739509021],[2.84304508939928,5.49326767093141,8.66118400918354],[2.77672741181875,10.1288293132464,-2.51281986075628],[3.56568805111678,-0.229551213861057,-3.44241714767813],[1.01849426585518,-6.86877391317839,3.44466768913733],[0.933449110302664,6.09638475240901,9.30987362073862],[1.64420306608424,-5.87388107294227,2.76896095606404],[4.62587806410899,-1.5040954917323,-2.75380545501079],[-0.226355898285064,-3.98803218126391,11.48390035967],[2.62942861933241,11.6741919252613,-1.58348479378359],[1.14488427979018,-4.64694557970656,10.8042509739372],[-8.82695899812796,-0.266103744069043,-5.24089981221364],[-3.96792029354797,11.9923335190328,3.94064292997223],[1.64775991084581,-3.17668829518781,12.0219108718917],[-0.749555289927391,-7.82760354038917,-6.09701427535587],[-3.1332847078418,-2.94833596512473,-1.13488062284039],[-5.82638021213739,3.07556641363841,-6.58924417720908],[-5.51536330261714,-2.82056340594466,-9.22965344010466],[-0.556227086391381,-2.88908634514464,9.98727064663412],[0.305822266175862,8.79897496242631,-7.85446310631278],[-0.246671689647803,1.76673780059868,-4.56173044771902],[-1.52353963879094,-1.40108831381023,-8.33774370096288],[-5.41876563524913,-2.81862077952102,-9.16881752211192],[-1.28134329385175,-5.47650059715598,1.49773819217551],[-4.73843961028373,-6.60623887872635,-2.30655890509887],[2.0995668889342,-4.6238303056194,10.3266758809997],[-2.34610378600742,6.82063238195648,-1.74299936479608],[-0.916406544490239,0.186446818386618,-7.34550663852804],[1.49616284610613,-3.28547506055245,11.9715898099327],[2.84771629239451,-10.3478721040019,-0.130847970788354],[-5.39109401424465,-2.3513351970784,4.19674181664413],[1.68130463933683,-8.48753322262572,2.76672191658244],[-8.00611140264569,-6.84164737778839,1.66866181672225],[1.94160194022481,1.66736866821139,-10.0830026611509],[-3.21440799488273,6.4846612245207,-0.290546111374229],[-8.74953481843367,-0.523222263792239,-5.57736972674074],[-6.10729144497941,8.83979291692597,-3.76034045588004],[-6.32823593736074,7.76090730750071,8.59400848155373],[-3.76873951911098,12.0085669395448,3.70947116187731],[2.16398343143951,6.18558858335694,9.4444461007995],[1.15890076460112,-5.39878611000249,11.06428249453],[1.83398447697391,3.88509571517524,-6.30554112273052],[4.00599387667069,4.56449965714343,8.27333917162972],[11.3843079221581,2.27198711706207,-1.76243178367308],[2.83724729341207,-0.679820077631592,-12.315884829858],[1.81052948268686,11.9704635225322,-2.20774478394482],[3.5041704414742,3.84797653694733,8.24427863700619],[1.70351048726982,0.0286199616214218,4.57471362605834],[8.8827278625137,6.73225869193956,-0.0771212194865214],[-5.45746401773443,8.76188473697143,-3.97895918910836],[-6.81991389400214,-5.70463733721366,7.33920142332807],[2.49184311338823,6.68836588321636,7.66889186948317],[9.39840252469779,2.71587121567896,-0.691453053771176],[-1.00909894949905,-2.85605302082667,-12.066367618466],[1.64453335247697,10.9170766172871,-2.13596624786908],[-2.66636648917591,6.26527292978437,-0.134146923757055],[-3.82169743285762,-6.56522212814628,-1.5109816069529],[-5.12320023586898,-6.93042983037992,-2.26363092927298],[-5.28247852038027,6.28678716647908,8.73598462273758],[-5.75465218431693,-2.85662269779699,4.28582678662849],[-6.45012547004778,-4.01540092141568,-3.1855844202799],[-3.76004265757059,1.01656324194304,2.79711661808117],[0.51483282115298,-3.17764072638581,11.2484376579968],[2.3942769457426,-2.61177269201029,-7.59873629943158],[2.98673620259774,10.6284385464124,-2.18115459719469],[5.22398889781313,1.2453026889589,5.94012739203309],[2.20321726540943,0.316828185544813,3.56950975185901],[2.63033916995563,10.9033223141073,-2.20357752259353],[-2.51379207098619,-2.6167010058229,-0.148076986503834],[1.80590865990939,-7.98946676545387,-10.6933115184856],[-5.1504671503187,6.68736549246863,8.65580793661167],[2.7703594276718,-10.1134756857911,-1.4918288117388],[-3.33139241916237,4.39443141631935,-7.52412931758783],[-4.88490848232978,8.11064922890948,-4.53582558665864],[4.37796066255535,2.95991997377948,2.55616491026266],[1.16748348157386,-4.52352041621403,-2.3925733708975],[9.28192100218303,2.86981354398287,-2.34098587797181],[7.77709608096685,5.83193608615898,1.61147329176304],[-3.73675067678177,5.24752984450406,-0.732609031117239],[3.46186995820055,-6.94571237918704,-1.7874078495125],[2.21233291875493,-5.50546879135581,-0.766799644683543],[2.55922092555778,-9.14022682327576,-1.69443793420763],[10.4809810352076,1.51358935054702,-2.14054636357048],[-2.79598971887566,4.93186899574913,-6.90063415369278],[-4.5063991494806,1.19267267979178,3.68623350587387],[-4.69956959373276,-3.33096117051689,-8.98816352306145],[4.89862488800656,3.00517910982693,2.06357793517054],[-5.27923194716911,7.23912890331029,8.6971205253276],[-7.33029520822522,-5.88648510842144,6.05610898483109],[-3.3396638084282,6.16979233380736,-1.26457744023875],[-0.741185410848065,-5.00507356986078,-3.44342278543952],[-3.06204653013405,4.57946400461005,-1.52245884317828],[0.176454642422593,9.08287533339004,-7.11287824144649],[-4.48220577254604,-0.637485449806279,2.91357364155881],[-5.28309742266329,9.24786168043957,-4.12101891746906],[2.03858740188825,-9.58136094800464,0.969278249131556],[0.872537565939285,-7.24554053802093,1.01406409775763],[0.489012727806528,7.54624734857678,-6.43088267386888],[-5.34281018183968,7.17842491759595,8.78100029355676],[0.928551006220362,0.388293358270467,4.45328492756933],[-8.95587195823907,-5.87370970443639,0.892641377142973],[11.0279368070472,4.09079014766974,-1.29262373951656],[0.651150198451523,5.48949264599066,7.98212928424969],[0.310114927371309,-3.66398633017716,11.462119094693],[2.6511191360579,-2.19640410176412,-6.63784969493153],[-4.59849121233352,-2.07428019681726,-0.636104716539297],[-4.85873029867939,0.564248887960518,3.62621538440227],[-3.16409590629975,-4.73275374095364,7.04478235211001],[-7.65929534340255,-6.03561998620686,0.497969979388735],[2.83786759787781,11.4269978166249,-1.80734217363043],[-4.40986166602251,1.11338378173672,3.3539996023615],[4.16826806589633,1.52040898240044,-9.12598884458967],[-4.33167767528279,5.06821860420516,0.23714585162413],[1.56867819500663,-4.64212368982094,-5.0264189019515],[2.97502924257027,-10.0024725297649,-1.22182771951777],[-4.11362336366107,-0.543048674418832,2.53400784541441],[-2.51605791254309,-0.783747657585687,-1.40626831044123],[-3.308196400027,8.16289704341864,-6.14300981944452],[-2.98017673350665,3.95319207925708,-7.08331641128122],[1.77721931767072,3.96377717865204,-5.66486127933667],[3.28199839589812,-5.72108111142479,-5.0772895815198],[-4.67648659955511,-0.0784389926858582,-1.56369779644733],[1.36074643769953,-3.62503956077606,12.4878148912896],[-3.54860159697245,-4.79820190606636,-2.20110940043255],[1.51577902939691,-10.1302677119892,0.71506210941406],[0.972194430542376,-7.27378630053439,3.94547818799501],[-0.0686781711782126,-2.64110216807336,-9.63312124523504],[1.40970740541848,-3.08588972067793,11.9822348902052],[3.99552369067634,4.74441087162209,9.27720057078343],[1.91400232789445,4.26835508165941,8.18887944926821],[4.63649498320686,-2.99346893683902,-4.02350817403626],[-3.62656938248108,-2.28438314948229,3.85730841059358],[0.927085448025098,-0.430250065004276,-6.44424082063757],[-4.01816942293729,6.8631962382097,-0.550307871279855],[-6.10535805937245,7.55213110979539,7.9967416155141],[0.983685845281174,-6.71221079713823,3.95683298638243],[2.40837673617452,5.0052101735345,8.69276424474461],[3.51298046845201,11.4119733935432,-2.14905046338531],[-5.34906499121912,-1.32451768824452,-6.76938552250482],[9.26796782919583,4.65677531118806,-2.29709798859197],[-4.94879255668172,8.07869906604124,8.35454378196382],[-2.69019434291519,9.87587390675485,-5.94743998114901],[1.33334087752395,5.7673829385599,8.32023021710685],[0.929396608020766,1.87223621970368,-3.28734068912952],[3.24387000070094,6.33740609700178,7.07584875194675],[2.40612317841119,-6.34480997884237,3.03993877250892],[-5.39039630634383,-2.92939875811965,-3.93645254223999],[7.49496671750417,5.47522044823868,0.892789816774823],[2.5729316607038,-9.00997804520265,-0.237065181897722],[-2.68117853356221,6.95092596136347,-1.10977929470646],[11.3195303205752,-2.13174980450778,-1.21579140587862],[1.04992205528535,-4.5421648274831,-2.24196794972408],[-3.36870010564044,-2.83512530298745,1.87064794425104],[-2.8074097441887,-0.448332134003782,-0.370737473424401],[-4.75985656992953,-6.72433564701872,-10.2190373178916],[10.9893778756016,-1.59462446665001,-1.82968930104359],[-2.37721956898985,4.52281318378381,-2.68676119481126],[-4.96017748191351,-1.12975665369,3.71564614854061],[2.13212368381997,-8.95497913209075,1.71091587698718],[-3.25949966506964,4.60057052887662,-7.23661720636932],[6.92940101365453,5.1004626901137,0.0994008330496728],[1.65736139956807,-7.40260803719995,-0.807453998161476],[2.77170600198737,0.221056003142225,-11.5787231594965],[2.44555074367987,-10.4707235535747,-1.05403974452359],[1.06212174035909,12.3472514695391,-1.10011139344208],[-5.42206477965191,6.75795778165895,9.09871363788651],[-4.93710331214916,3.61267977959032,-6.73522631476299],[3.21918756258228,11.8125487111852,-1.77095762179542],[-6.25280367912426,2.83018745714861,-6.06492753522131],[1.77460911230718,-3.5633954581452,12.3878354770412],[7.54849188499584,2.75102082300543,-2.12631022943995],[-3.09321298314981,-4.87960185350752,-8.96435145860893],[-1.98260619975025,-4.00913423583193,0.0363441480162356],[-3.42687892549962,-5.36636299224932,7.6068556632296],[-0.485153683923398,2.07475513873455,-4.8909020005214],[0.554776952985653,-7.97645119325513,2.74360828292023],[-2.87092162746564,7.03285397972088,-1.36411085914021],[-3.84457587130991,-0.10932104006129,3.52835484365772],[1.7196037139691,-10.0370189695683,0.255434474326789],[0.146261544756864,-8.60889667240094,0.837690144716511],[-8.12645105102161,-0.470018548226759,-7.87979963269511],[3.07384070261152,-8.14786841773206,-0.828940682695274],[-2.95482324154748,-4.69836055938761,-7.69326877230261],[-2.43951596430819,4.778410509154,-7.34864663050963],[-5.03851807706104,0.747075008592491,5.25004898523023],[2.30901735165938,-1.96875404637116,-6.80421739326051],[4.18473078001055,5.37605683628602,8.39153688607555],[1.73604336990504,-8.89831300609412,2.36261190624764],[-4.52981259624923,0.438571134753425,3.6624983717341],[-2.98350377886695,-4.61511144171996,-8.74051164466542],[-1.69514514163184,9.1379067984788,2.74973550805053],[-0.671819553686201,0.350546020124501,-0.00263614253588168],[1.34040164899551,-5.80640189002382,11.1188985135451],[-0.938139171737811,6.40645586114197,9.18102627503836],[-4.90956752897901,-5.95706494948183,-2.38348896791735],[-4.13458047636539,-5.77305596139889,-1.77870515960979],[-5.77256774484646,-3.92673182158592,-4.6305752515818],[1.7791688594949,-7.03816570036517,0.895701785712044],[-0.482378971025417,0.880360051237131,-7.68708452736765],[-4.28785000085601,5.0482265999962,-0.104517466463956],[0.894587880545894,-4.33008666121901,-2.05102615769198],[2.56092991765661,6.01961730107952,8.13765106317329],[-3.95539779082416,0.259246687564186,5.13927711463524],[-0.0846651616315867,-3.10031350631647,-10.9539540280309],[2.71705169201341,-2.30644618505466,-6.61650776052671],[-3.34305003318223,0.927678488406633,2.17543837995102],[2.19410544309098,-4.69713704806843,-0.037076331589975],[-1.71438645267788,5.85222215516514,-0.165408181929756],[2.95094318767915,0.232183030715181,-11.4396837358556],[-1.06495244549266,0.384820787986176,3.44407213210687],[2.11978074117824,4.23999662369334,7.51958572337844],[-4.36504250635824,8.01052670202054,-5.76382350777868],[-9.36249667848737,0.825416450330505,-6.3928919673265],[2.18363263264267,-5.06022857383501,10.7550188633006],[-3.76574979089243,12.0273658613435,3.89448982401046],[-3.78293362298384,-1.90401483728132,4.2357808058252],[1.03724670300097,-8.22321611066686,0.395634889576756],[11.3568252512692,3.17070380072328,-2.09616594342945],[3.07069053962212,11.4277083014869,-1.95220899077089],[1.36353636273211,-2.85820977306404,-7.52108227918351],[0.626294141805723,-3.26312204774142,-11.8946067625267],[-2.42108893384469,-2.60521615928592,9.24074353693936],[1.92135388760882,-3.51547728599027,11.0290978121738],[1.97225095330542,-8.68355167173305,0.729888585706357],[1.66689371869243,-4.83092708331828,4.79211107934023],[9.18416309864005,-4.36973670725902,-3.67890516738891],[-3.52311521254123,12.533528685527,3.82791665621067],[8.5883626276687,-4.36735717136344,-1.79537205114675],[3.94831471244333,5.96698193846464,7.61973089306289],[-8.73199615430075,-1.21631774640239,-4.67377396238517],[0.842710512755299,-6.72547023015821,2.94782131147016],[-7.82908116069034,-5.72791469785607,6.6840875416355],[1.71909782016957,-7.46970122497643,2.68840128308164],[-0.778330670011452,4.34501941933008,-1.07591948125657],[-5.44787643266858,6.55800089489169,8.91749351627495],[-0.0912689289289698,4.14916211324555,-3.27997355765827],[-2.106264686819,-2.20242824372268,-3.60502095292647],[2.42789887913866,-5.37877183155551,2.43087188859153],[-1.10437420459564,10.0854148202829,3.18661620953568],[1.38672674212966,10.6111641888544,-1.81270227037316],[-2.72911869053466,5.53675553165731,-0.686641580754818],[-4.72215100402024,8.10259394039937,-6.24198628701855],[3.58429857655253,-5.26966459695438,-5.23065580816341],[-1.94470054610448,-5.49397758714327,-2.20170278153926],[2.98630163871924,6.5907179789947,8.52614038314752],[-5.15863579972481,0.842594981514277,3.19492342744808],[-4.63238279007409,-0.041827475156217,0.398130041463197],[3.86394154477465,-8.45351593692326,0.187662391224903],[3.67697513594462,5.39173493889724,9.22797116059537],[8.82410020838192,7.22563199298509,0.657881217022995],[-5.06822917969831,1.17743166194556,2.58212654561887],[-3.29634549512037,-1.32087431303707,-8.17388526322282],[1.53292176597366,-6.32109208057725,3.57834492735741],[0.366263506130565,-4.78578371651264,3.54615142862696],[-9.37053850833352,-0.788325481539901,-4.63432945171652],[8.45264682232176,1.25689609949006,-0.88657231358603],[-2.70233380758319,-1.8118326769021,-4.19199550483714],[-5.90734282398466,1.23045305320681,4.76447767054955],[7.86291236359486,3.5920256633036,-0.739128332903936],[0.823143017267619,4.09509994062166,-8.55424241056149],[-5.82431471665815,-2.46347012026419,-4.66353145528872],[10.1492637211098,0.551457986928713,-0.676871425202705],[-0.120254836132193,-0.999801254669429,-10.9341086751907],[2.19603239451857,6.10368256638483,8.38963904342236],[3.15154785248535,11.2519864590857,-2.76701981347948],[-3.11226927723136,0.488158767529811,5.06081189348915],[5.61159158983726,2.81111126363146,2.09412374520159],[3.80403124160524,11.5729527204786,-1.50471849463724],[3.91041558386769,11.5027977220077,-1.9258239542844],[2.03971211310901,6.51837216840558,9.17201947568018],[1.09607843838817,-8.46117689823705,3.10277598894643],[4.51461785478454,5.1904439524586,3.28209198286916],[3.33570370807024,12.1236353377525,-1.94021429139111],[-4.23681562967684,2.74727663914884,5.40360228639581],[-9.29363129329038,-1.6930149393607,-3.44002463598101],[-3.78460075237682,12.1364087990285,3.7035911085558],[7.25928532386473,4.56750581543549,0.0267739606518102],[0.732248800162799,-4.03564957998606,-1.31350966010306],[12.1762787250988,1.81588536801596,-1.43072236878241],[-2.03419209276769,-3.01376801013167,-0.648274685104765],[-0.679495918242305,-7.94956325730238,-0.237901253929518],[8.35495677822115,6.37594072434283,2.18056795615644],[0.819832240588997,1.63513776193149,-2.37678074554871],[2.34365280420863,11.033258689508,-1.00073071153561],[-4.4261676310335,-6.21902460921187,7.05379183193149],[-1.92435788931704,-6.08549974207278,-1.73227298920013],[4.62776429588536,2.38261416875391,3.82760329654223],[4.06003774127516,6.11665597151809,7.90718981722106],[0.365380339959127,-4.33242302716187,-1.42099284896807],[-4.3563020902934,6.24334704129324,-0.327028853784693],[2.42455178124621,4.37774882198141,8.24424044867949],[-2.58236225422435,-3.06767528010865,-0.0726842658193966],[9.68629235357891,3.10916779523145,-1.55326008943038],[4.00781089456129,11.8424843084982,-1.87810086636836],[0.0204751774737303,8.23659341321562,-6.88734661272426],[-2.33943170632726,0.180551217204996,3.38280092277688],[-1.87657629200901,5.39512220866531,-2.70423742387253],[-4.23954584965914,0.991981298712597,2.5641007012779],[1.75566211582589,3.89464101858595,-6.62180760443974],[-4.10933760552013,1.39798144159733,3.22273903786568],[2.4480941513167,-4.18467455278453,10.2157839886135],[3.39511626984961,11.0406882402116,-0.908134664214005],[9.48190921088992,-4.78281427798754,-5.76242516789723],[7.18295253368343,-1.47405723518994,-10.6893207494147],[2.77481428530008,5.94494389624454,-11.5559305320058],[2.9397212333669,-5.38877601323781,-0.98365673158416],[-2.09874499861393,6.88801131665759,8.55312807279671],[3.08056316384699,-7.66163256078852,-9.97127574791954],[3.6359201604838,11.0367078223759,-1.29161064973055],[-4.76172392644682,-0.202090830498401,-1.5425747691738],[9.26186202714281,3.0683877738555,-1.27588953641097],[-6.51680801548692,2.86574423223564,-5.80113098780294],[-2.52885406922053,-0.371063663633768,0.903134749859415],[-3.60054002164637,-2.56612427838056,4.72008248379386],[1.22385121499003,4.23975475951285,-5.50826680423425],[-1.81605853894239,3.95677048989758,-2.7392943999913],[0.6698718064798,-5.29574975948191,4.2978499524135],[12.1118939505903,0.748148275727571,-0.588178624996494],[2.61661846318393,5.57505653235007,8.70443851935078],[3.46252516520955,5.49245336903368,9.16832029646914],[2.65273476583335,-8.97454660314341,0.0444172399444915],[9.7060819745842,-4.91874574794944,-5.825341015351],[2.40448417100631,-3.11785914969273,-7.70694025055695],[11.7571402826995,1.59097527711628,-1.71724401275178],[-3.07573476409639,4.25323291368884,0.368963551987145],[3.39400005195628,0.636898724115416,-8.65107498296049],[0.393886458594943,-8.92129495000506,2.19942699244513],[-5.87285365417037,-3.15129293054509,-5.3783800712245],[-6.12412243276024,-3.39984352826957,-1.68882143307781],[4.55527447740796,-2.92082851193426,-3.73724391412278],[1.03633111242693,-7.67024055857374,0.929304255737542],[-4.54302848718772,-7.32211991746955,-2.34511085519302],[0.311859825828106,0.755565628436715,3.35253285746192],[-2.33310050425549,-3.81616335586729,1.95370947216931],[0.887398527902828,-7.25017995813352,3.18441782492678],[-3.25944535328412,4.15990272832659,0.713562833653257],[3.46748183134566,-4.67697497433192,-1.97373066208191],[0.950203212055109,2.86382030695373,-7.41553980757861],[0.628857276633092,-2.94438864935904,12.2261552054984],[1.53367635258797,0.0746985200247361,3.36674804619143],[0.784588298909657,-3.36200010795839,13.2580968638054],[2.12065307900962,-4.042818818576,12.0388234415481],[1.23010169031846,5.68017066921022,8.87203934863737],[-3.49474313614021,-3.72573135243979,-3.19041489820175],[1.62217890609214,10.8988824508934,-2.13056015491849],[2.17542987078773,-9.82412031057794,-0.393847170102164],[3.55415995747902,-8.50471209554794,-0.558672375141888],[9.59817188899955,-4.69826447753252,-5.88977858487944],[1.47944237492234,-8.59096115178466,3.05632182264004],[0.975458122016504,3.97334457691962,-8.68881161961539],[3.62512846941435,11.028805136157,-3.31334312055523],[-3.99991721129388,3.32970670296762,5.64212551321646],[-1.17601798806033,0.326999519739762,3.37189677212001],[-4.79919055591423,-1.41807511176508,0.936934668500074],[3.77030179510103,5.10225052606128,7.7172741488154],[1.53079873781929,11.971004589707,-1.70126574530802],[3.50381278481182,-5.14607454186635,-0.95485209083241],[-1.87722448588078,6.17695365807552,-1.54653338832745],[-0.0849654136530208,-1.64795554366042,-13.3957050848988],[-5.93118315409987,3.84258610805398,-5.16321330124835],[-3.16761435235608,3.65019874451835,-6.10863476030169],[3.50328811310051,11.0485871820108,-1.9125686818571],[-3.2525012767539,5.72448477488119,-1.92914987984258],[3.23001117763237,-4.04622802329419,9.94392882084041],[1.30050759677887,4.22976149236059,-5.49345303693029],[-8.79815027507219,-5.90525994469131,0.596303193010678],[-6.36826668975121,2.77219340666639,-4.66086516215011],[2.18383217445515,-9.28636286741651,2.04357875936034],[-4.30012466878031,2.50703374665236,-5.6110031548683],[-3.9169420261328,-5.21513675910767,-1.21782260151186],[1.30704124034903,5.49392033672195,8.73685244307272],[-0.203128922796954,9.09311436974995,-7.30062453920047],[-2.0862591597465,0.0421467839520069,-5.27000388106261],[-0.829772747913183,0.487084896900634,-7.31711693298884],[1.36171846825706,3.26883821099025,-3.99734572000225],[-0.463923249320592,-0.956866366186774,-13.8527512767686],[-2.47263134888784,-4.5458609280137,-0.582052878895693],[3.64658115859809,3.41399195590722,0.497106305506638],[-3.54376372668276,-2.27574945098076,-3.97181454962223],[1.09806931297681,-2.12679174350382,-7.76120470505941],[-5.28522862038916,-5.8578379319742,7.72998909845675],[-5.37204934827508,9.68219570436108,-3.95153003335173],[-0.559448307935958,0.357463949656712,4.4775472563177],[1.89053507740549,-9.09684069205146,2.45542847848974],[4.220771892277,-1.62814216841127,-2.54270797330699],[-4.84633222005852,0.526210338956322,3.09345815435456],[-5.0005836798405,0.581196008928355,3.22410794425018],[-6.43848139165066,-7.13638282935315,1.4492722435455],[3.6997688759778,-4.23480772838337,-1.37434035707957],[-1.85689430306867,-4.64292974336537,1.71073837421043],[-0.953093538956914,-8.00262149471282,-5.91342618005115],[2.06616657414344,-4.96020495513983,1.45800570189546],[4.3315869726926,4.6806407086695,8.31451944505324],[-3.95357898004383,1.97369430434114,4.84463184090668],[2.02531459499304,-7.55646038920466,1.61366179948872],[-9.87047226103627,0.4356495787526,-5.65528548467203],[-6.47222279377426,7.19038974108211,8.71451489033007],[-3.75071099079454,-5.20796930662969,-1.41016942247802],[-8.10198980012674,-5.48535445646944,0.581049056285604],[3.07823702611869,0.368884174213883,-11.599778090412],[2.9905572420758,0.183545575134968,-6.55696584915394],[-1.5615972316894,2.64706821623853,-2.26323412943538],[-3.95743009636463,-2.23778588126472,-4.20878081629362],[-2.44773489507515,-2.61080455265207,9.36361765498575],[2.10067790185172,-3.41574035209054,10.9122539108602],[-4.23815680328566,2.9325296738725,5.45517178571193],[-2.81794699083581,-2.69129972561832,-3.11396274149789],[-4.15583685003333,2.79379047884313,-5.28247707024049],[1.55485888127646,-2.55332417712329,12.9174481078052],[0.274263633389334,0.180127570865314,-2.57718787614528],[-0.121502225992201,-3.01555897091417,-1.37656725337982],[2.42737043021918,-10.641790350589,0.0654781423699199],[-2.56716490050959,3.80157875907814,-6.04906807711377],[-4.46120221579204,5.15531556328224,0.25365448278436],[-2.09238387529311,3.18983261158972,-2.55832215114573],[-2.31472177025516,-1.71940314567614,-3.48668059599798],[1.78662350482906,-5.37867948181619,-6.25302984659054],[-7.83767070051735,-6.67471720933442,0.706110414566063],[-2.61166083131825,4.20117636684831,-7.28715780860626],[2.37273902221916,-1.46191934718856,-7.69751568901091],[-5.19716181254526,-0.909410500685929,-0.222152746433935],[-3.85429105972159,6.0398215928065,8.69547397361227],[1.46077677048663,-5.34293497286245,3.98328429372702],[1.06426587531681,-5.42865256527328,4.15599285518431],[2.26284368419988,-9.22500989385932,-0.99692617225803],[-4.42831870401862,4.90822706899715,-2.33376763948745],[-2.86475458455809,0.372956800408674,0.299884274014084],[-0.382581085490983,-1.02988311198985,-13.7057214629275],[-5.41712218357478,7.99848383610416,8.64839396780157],[1.65656291713626,-2.94677988253315,-7.46015938800209],[4.20571917091324,-6.2484509879745,-1.34040444599802],[0.489073325400206,-2.90226240452066,11.1332065426544],[1.8194274306722,-6.63066784098951,3.19878428783617],[2.64481773274559,-9.00454187886712,-1.38734399757041],[-4.84127656087898,1.86343886980963,2.7146190068473],[-1.18327677686213,-5.84402000343994,1.29456297574584],[-2.67342361582283,-3.44683154569868,-9.36057656541001],[0.606812177895859,-5.91330474617966,4.74881371388678],[3.5369384482874,-5.57706133379048,-4.6748985127573],[2.3291280940929,6.18330286060019,8.46467853897243],[-4.62243903380631,8.25034606537282,8.78742773587944],[8.26148890654951,-3.26784852212392,-4.97884041289733],[1.7787585811139,1.47459151882302,-9.71052157814745],[1.94592756712602,6.77093250097787,6.72757492043996],[2.04139913816023,-7.40283919029808,2.84071619775624],[2.48860058149532,-3.84925874350774,11.0663754217222],[3.33128963159754,4.07307956310523,8.2623864312443],[2.36434729683504,-3.99959659403932,10.7105842440726],[0.637182356578651,-5.29351680981934,2.46920180346169],[0.939214849594268,-8.36829068698464,0.246315086760882],[9.82442507187207,2.7661663238535,-2.83054819252895],[-0.234371989612152,-6.87388153308409,1.47282054762665],[3.48510537544399,-9.58896947947023,-0.905596372394772],[-2.94311253022097,-2.33140542692053,-3.70815936751486],[8.9331596268802,3.29715592204384,-1.53834313189042],[-5.20645389707553,-5.36561318705186,-1.88345596608803],[-1.57063124353828,7.3420983878517,-7.11899357249124],[9.41102452043763,-4.08859510353154,-5.09424079058403],[-4.81336834322299,1.79227321645987,2.82847394599108],[-4.81194878394086,9.0487898956835,-4.23348594120125],[4.23268413936376,4.71952507245823,3.08277198041277],[-5.61925960943272,1.58004076679606,3.27816113201835],[3.40558956761442,11.0496945934961,-0.902217381996499],[3.23934402035218,-9.15260576491336,-1.84772593551159],[-2.64206682271667,0.573796099886844,-0.860171610128966],[1.44234913268971,-7.85299015650469,1.79329338376829],[0.504962004618359,2.74534675506926,-6.4547567016254],[-2.32488308472412,-3.47524005200742,-1.13905824198498],[9.37772234708609,-3.67029573958416,-5.27813944411206],[2.5170411900872,6.18284802236371,7.12968204341718],[-1.82348048768458,4.72182561655424,-1.8000280061195],[-2.21901668970449,0.0121334555469274,-4.88314326196894],[-0.0464535067808705,9.25820804092949,-7.43604866995717],[-5.03882083902295,-6.26693784778323,7.47461425816648],[-2.6550823358873,7.15342699091329,-0.419013420576955],[1.50716338880311,-7.59784145570982,-10.32660889451],[2.02876898790656,6.13381811972223,7.8837513949991],[1.37105564984476,-5.81251648380404,3.94127107532661],[-1.57247378045882,-2.48371857197956,-11.9633771431022],[-3.78250943600235,0.816260242125039,2.87491564289017],[-4.97018359354348,8.24750988657568,7.8343862329645],[3.5083153707448,10.6563476015142,-1.86093943217903],[1.50775186248034,-3.5892650315472,13.1915709075902],[2.9912575793769,6.53355384284669,8.52766007507124],[-5.19378952551773,1.04967343122049,3.8560889842947],[0.0460212258572471,-5.12698500897685,1.57667322791499],[-5.99350257186642,-3.42608975847865,4.65023798212696],[0.788665073374077,-3.23133069178334,-12.0242608438564],[-6.72073759109871,9.10336072313372,-4.32225027189034],[9.45432753717254,-4.65795414325385,-5.71201708736175],[1.47860558613076,-5.82018639742962,3.51794567362395],[1.46509391800797,-0.235108987228677,3.41361043145696],[1.47316722326764,-10.0481968263439,1.21562300595556],[-2.64989353414212,7.04252684316679,0.0582111306726312],[0.837026274750905,-7.5246472559618,1.87550022432445],[4.00771141396829,6.09556873406761,7.21402046915953],[-5.3098629368845,7.17633983152469,9.33268853117113],[-2.01033113632806,-4.27914951188929,2.04063781072891],[0.764592471128031,3.09064565730503,-6.82244513063201],[-3.52683458363437,1.66726444393412,2.61207828414847],[8.97707526036457,5.02219022764935,-1.34917818014485],[-9.52202490482203,0.86966973885401,-6.36022757976138],[9.41410599574802,-4.54078750576308,-5.58221591782563],[-5.19075246210064,-2.20876083895983,-4.59095769757589],[-0.578346066789247,-6.83744717705062,1.634199479775],[1.12581405746013,-0.814371622384964,-9.60673979630788],[1.91070143710034,4.81145666239399,7.65753313899451],[-6.60400339763066,9.53614464871467,-4.04016970688557],[4.14759243108033,-7.71974720973752,-2.25594686561578],[4.23134584030597,3.62562970291133,0.76878645277517],[0.835577503425439,3.99749437954016,-8.52542528634785],[-4.47312361033647,7.04863759152195,-5.35412194101715],[-2.6813467165562,7.07279366719264,-0.587957158300347],[8.58942701765288,3.33638536621345,-2.459067568744],[1.84464193803739,2.32976703130543,0.690938287596897],[-1.50818794836498,-8.27873648177009,-5.79953608703229],[2.35758573603359,6.42165174297323,6.86011378090072],[-3.15385677501683,0.429746159735192,4.7995834864425],[1.44278207126579,-5.1767618901887,4.07568157266669],[1.58887971187826,-9.33032216936956,1.81436625718656],[2.59260933658885,5.71582264117133,8.834723154086],[3.68442969919785,6.29998191274365,8.3788095140413],[-4.74152249852306,-6.28531244215961,-9.81945375736799],[3.53315446210364,6.38929339971677,7.26670556845919],[-0.165580104566243,4.43090901085075,-3.33154763439429],[3.92769119356235,-0.473614169649314,-6.17586168328439],[1.34248703847483,-2.96278208743614,12.0732151065291],[-4.59070417570449,-6.80092238183766,-9.72829754397643],[4.11795152045387,2.89486808862642,2.60696922783678],[-5.90844730537529,8.39570218743012,-4.77466634365682],[0.870948601696496,-8.20818347390763,0.664841125470173],[0.191384162898878,-3.19008203127431,12.6473996265302],[-7.87131666336537,-5.96273494605571,-0.0383835249522174],[3.210749688196,11.9881651202201,-1.28154985872996],[-5.1612922239511,-2.75879322096224,-3.62336033646191],[-5.33538259563075,3.86449520764325,-6.02638757649646],[4.81290019838125,2.34732192292951,3.8259132273289],[-5.5944714152252,6.55304295394482,8.63896082615406],[-1.38606516031439,-2.71971425625083,9.47502127818034],[1.79382500663372,-8.2588161781387,3.50302862141706],[-4.41885979293135,6.89324093430425,8.07196559751762],[-2.27227776873659,3.40171584070762,-2.34349745758979],[3.13821621657021,5.29620036446213,9.01903864394442],[1.90927164718508,-7.86598130593341,-10.7311117315504],[1.78007327782586,-6.61050546918136,4.10931858345667],[1.58141504040629,3.72415218809778,-6.85029820052442],[-3.88060713326121,-5.66763760790572,-1.11238239558735],[-4.79226910586329,8.22050760316416,-7.19635318366296],[9.72342262415279,3.16371395404899,-1.23051757034091],[-1.53342912931477,3.032377375901,-1.14259788673932],[2.3201751277393,-9.34885245196015,1.0037857920507],[-4.9363203531325,-3.07143856722383,-3.55960836406801],[0.981603471226181,3.02097099386826,-7.35797709849849],[7.0878047285821,-1.67972429253733,-10.2451405112712],[-2.02296268823476,-4.86670988147181,1.98665109119221],[2.94750959962772,0.168264635611809,-12.3478630568908],[3.99578174527512,-7.77393920294933,-1.79920196243944],[0.100950648970702,0.0588041785812218,3.13021295073106],[4.51097040636094,-5.50789860327724,-1.71596821352409],[-3.5011832782014,6.0804570139397,0.28179095315903],[-2.92362966651285,2.29194068299867,-5.2913813534634],[1.49412103788263,11.7591957232224,-2.12079032555917],[1.04326651613674,-9.03233731187513,1.37174076438184],[2.38194202083149,4.9940962242448,8.9590997665376],[11.4527563986506,0.514033224231665,-0.68254926348888],[-1.85368196538332,0.441331043229478,-3.14453188619869],[-2.32510669169075,4.60627394871662,-6.72165304037028],[3.62630401970981,-8.41864463902286,-1.74510527317355],[1.12761204459314,-9.12489352461968,2.34939248538738],[-0.0408012012879136,-7.70661857857486,1.32057953510483],[0.905989572536125,-4.94120788885022,-5.2382921979378],[8.58330338181117,-3.62424678543913,-1.83207192937688],[3.55521194545318,11.7334977983805,-1.94129829449169],[0.307342780368141,-0.437302338739399,-13.1521897336531],[3.6306937683217,6.08305888191551,8.58797076722098],[-4.43260097373786,1.68463842489355,5.25834056148243],[-3.85121025843738,6.07771105526853,0.0554456576145012],[-4.13846223051696,-3.50815218071648,-8.78411018327269],[2.19144878284562,-4.08564180423506,10.9269147623524],[1.29104485106,-5.95131772830129,4.08857789743346],[2.65063585798113,3.63402513535187,7.56288839570707],[0.0112135359128581,-1.64256031765639,-13.2500047214945],[4.28288778230728,-5.92618402989531,-1.88401514668819],[3.34814482648158,6.04593024143836,8.05224954107108],[2.02510925275236,-3.37752054784919,11.7101337164632],[2.65927606611542,6.53307777928851,8.72706478398459],[-3.19991870339352,-6.12130131248658,-1.55432410247869],[3.88989133345054,1.86198090051682,-10.3551429372979],[4.44564790569791,-2.61553019915765,-3.50583184132985],[4.04162555108828,-6.58601164805976,-2.12834239277827],[1.72476531004782,-9.57840609991691,2.61553310127802],[-3.99712397517664,4.46934397244661,0.353500919405538],[-4.80970669182044,3.41446329505745,-6.75596324576195],[-3.71112005627851,-1.86787674096241,3.53486017540792],[2.62845367337688,4.19623857167754,8.46742086793349],[-3.9106708675028,-6.00058240541267,-1.73809926133465],[-1.8240363634718,-1.91684913994655,-8.62942567856807],[8.85488686629545,-2.39507213913427,-3.50960834126491],[9.87939228021111,3.61220132781584,-0.726944298065306],[-3.44837364335087,-0.316120916491123,-0.211131354515934],[-1.54080239418519,5.30021299045639,0.870240193923301],[10.2929406612036,3.20238675749895,-0.989048642453431],[-8.4803916177807,-5.69232332147243,1.06431194333319],[-5.00111563530362,7.37406861861889,8.97936458685433],[-2.77841801272915,2.26703348230452,-7.01308885350708],[-5.08902468356865,-0.622201861920194,-1.41943647252803],[-2.69798755032633,6.82905939820788,-1.52993756306362],[9.00261208181826,-2.06354628854148,-3.52110056330631],[-4.72464198615898,-6.07732321792376,-9.40090997055945],[1.12285459349266,0.87685518423631,3.09752668611713],[-2.03351064971466,5.56693640364313,0.175650747897298],[3.39524559277874,6.73613504109297,8.54941779352972],[7.6924469277513,5.00987791495889,-1.33017460209216],[-0.109330198384067,3.57932479574904,-8.45400511221665],[-6.38745898630273,2.79124508999005,-6.36126399129101],[-8.19113224162875,-5.62242771508997,0.569430598303231],[-9.37195167351865,-1.52372891762833,-3.30254265855486],[2.75436235543737,3.50612888457815,0.747700008475416],[-6.79430487604329,2.42067537076116,-5.03245847931729],[-2.89142880938065,-4.77029223026323,-8.53630539203091],[8.68952573184568,-4.17846319949939,-1.5503766426117],[-5.23619833974768,-1.67300911414832,-0.626031589754009],[2.62291251260104,6.4837006320843,-11.7520008995912],[9.17893038475518,7.07221795523453,0.00737056329184244],[10.187503966471,5.17397225201179,-1.51727456299913],[-9.15278492020851,-5.9783117779356,1.12786148603144],[-5.87624185959704,3.8300735927961,-4.49563900701233],[1.38273091254972,-7.83130807128325,1.17095647044706],[0.240561665722414,9.27716540245367,-7.9016736432331],[-7.66176182057993,-6.28077829908793,-0.166972017317328],[-0.0679914572596646,1.45596062995577,-6.93422459328407],[-5.63401140628914,8.5603476560545,-3.90971562749596],[0.96024019738936,-3.31286350226743,11.8624748078309],[1.08612953697059,-3.10900379882059,-12.0252707578905],[-8.66960158529738,-6.98308558114852,1.18959299381938],[1.77686525828707,6.08718684358672,7.21751699081965],[-5.58658946726926,-2.65476455610527,4.59023550531755],[0.456824157086943,-6.15290607620828,-5.86124212538811],[0.883069636127186,5.93268818817104,8.31117897619679],[-5.50190285180306,1.32892875082338,4.6942396170206],[-4.39012059118742,0.377250026664164,4.98324747933988],[-3.36049286196223,-2.93156114233265,-7.41578158135337],[-4.52357132097375,6.24929594007125,8.62673620049292],[-8.73199509508476,-6.7578151714224,0.772335688101614],[-3.87105374198599,-1.58992350621767,2.97690192634786],[1.2462056048976,-6.23854917498624,2.95228659304518],[0.581080739688069,0.335246321467363,-2.71890621279338],[0.36525697526485,-3.15039312598155,-1.15738598705439],[1.93913780774326,-6.78408696416577,4.16294911452504],[-5.39476252902129,-1.45768696627271,-6.61825693722524],[1.63614480394531,-9.30346338846845,1.61241995752014],[2.00443888641215,4.03576874436072,-4.18130133718782],[-5.50593447461015,1.19122753650682,4.63191530479805],[-3.98540273580818,11.7680410077605,3.82527137354454],[-5.05610497986401,-5.84230741499647,-2.32295637939057],[1.01778147017396,-5.66765843239735,4.81442314068183],[-5.04340375156471,-0.0521637200158217,-1.63363514015412],[2.51008102404189,-10.2538453181249,0.32284697794893],[-5.07733022997455,6.73125581570939,8.64031608839505],[-3.81377112418396,12.5962458423359,4.44181310491374],[-2.14754953999248,0.299952097445682,-2.93143389088901],[-4.85258290551929,-1.35717784151154,2.02120284788494],[-2.76000057373743,12.4917964833361,4.66824554851096],[1.6667747462861,2.04014388401479,-2.89585667900322],[4.34053081674897,2.09038395455328,7.26432051293181],[-4.10623323581006,6.28933479549184,-0.782316807289126],[2.0337470967489,5.80532221430031,8.13739493570072],[3.1846850157018,-4.08042497522098,9.9644060921366],[-2.47310887483588,0.0887079287179683,3.73283429947678],[7.97342891639006,5.42262013821404,2.83959303887613],[0.684227827339089,-4.60220027606167,10.8471720481618],[9.42912104264821,-3.94470125879735,-5.57702605642962],[1.88289416537215,-5.3189674651268,4.32012702645557],[3.20033862458352,0.0700727498921762,-11.6938228476933],[1.07596338858342,11.7845739078834,-1.82435272526306],[2.45146556515155,6.34007959064345,9.39267015343175],[1.75173480257754,-5.65902687500955,1.74993976535888],[-4.60568206652222,-2.97370506777311,-9.24386691033903],[2.24125214273543,-6.39561591921358,4.84471179999551],[-4.28485831212531,-5.41495910517723,-2.42748512621195],[-2.96436331487221,0.543967289374695,3.88277732297156],[-2.9024248641661,-4.67607949209909,-7.99439921336824],[-7.2945572220651,-5.99266627583692,-0.294278517124097],[-3.74289678172603,-0.867991424496136,2.46401674495538],[0.399387365367439,-4.35517420038421,3.69937149048675],[2.19990546133309,4.12402198331912,-5.1709816550019],[0.718240485297314,-5.21704027354676,4.19431530950207],[-1.22265445875188,5.02623680424165,0.392811567545934],[2.91711227891219,12.0276544667407,-2.9385086587908],[3.56202336508805,-0.525938126524254,-3.41591903883312],[0.878773352633662,-3.30955300612971,-11.9731693000976],[-3.77684934786849,-6.41214262162318,-1.58413122138335],[1.21988332379838,-9.13524353910237,2.12722876131194],[-5.67610669643496,8.48852548949478,-3.78650656694281],[-8.36374182739627,-5.84183863029864,1.4832316858878],[4.21742386672297,-1.35996191809821,-2.47248901629402],[4.07226631484203,-6.70939934593359,-2.08613809176494],[4.21630980509517,6.13550520556226,7.6782362009178],[-2.06817115504041,-4.39544812644349,-0.0118992810646151],[-4.61008544678453,-5.10393168070358,-2.20700196580882],[-4.10081713648404,0.596574955395986,3.73328745128071],[-4.81168219981377,-0.642720082692097,-1.95813936535469],[-4.29081730424718,9.17883976213243,-6.04496414571117],[-1.48291749000968,-5.07700921271582,-3.22866137883383],[2.29827543099903,-5.01843514004808,2.82880631841344],[1.62206479145118,6.10208840701455,8.54191040626169],[1.59102201139403,-8.70057294131131,3.22946205886657],[-5.86861438090216,-3.04872520175648,-5.27921734010869],[-0.724921267941897,4.22230805862664,-3.1193231326793],[-6.47457430868903,-5.53664491714927,7.53607059111782],[1.21731834072577,-8.63263730287016,1.66581216981346],[-3.32538069059311,5.66849469758317,-2.11678335507152],[2.10709962768041,-3.95883887856404,10.0474929741198],[-6.39724850338288,-3.34283993844987,4.68077052762324],[-4.7941482570475,-6.75269982735772,-9.56997581987528],[1.85821339241827,-5.82647154672931,2.02102868576961],[2.43124490741218,4.52039101143269,8.36693911929434],[3.14833721696668,0.0813362459325544,-11.3865235025981],[-5.12544086154232,7.70323278969869,7.95046060214068],[-4.48599178411833,-0.8804752049089,3.50675483809887],[1.46465578306813,-3.75474044779969,12.728968762163],[-1.46569545838643,-2.63139647020618,9.44015315544756],[2.82103592856249,5.97535210904349,8.96741132684607],[-7.65537489543462,-6.30625444253879,1.06750920109802],[0.983702742827928,-3.42954840394867,12.7303922816887],[-4.78498033613923,-2.79638589941607,-3.50108079299371],[-1.17247362767769,2.36014022937174,-2.01844490204297],[1.95375730457749,0.243200419647282,3.82972773263729],[-5.03612301071969,-6.96062307506097,-10.026468502872],[-4.88576243024947,8.08229209299979,-6.76433505136081],[2.09106184509514,6.94720207281687,8.34483674744487],[-4.69213896737952,-7.02963790481178,-9.6459581277856],[-7.39948357941518,-5.94303654792143,6.76351624862435],[-2.46628389133032,-1.54592648709874,-3.51488300895762],[-1.51678196435485,3.03056990483401,-2.08293856534716],[-2.41798358220776,-0.383135778542528,0.249474402915793],[8.70210071173536,5.25527024575211,-0.983367633848841],[-2.84699487029343,-2.05690697607501,-6.25039190805734],[-4.58423555070719,4.27333298312914,-6.36391553429977],[0.706987643801681,-0.250948761648776,-2.30219146765059],[-4.92242796026335,-5.79742305592269,-2.47063655920777],[2.93445864970105,-10.0556678117145,-0.385690512308094],[-4.69101716696042,8.51711978147238,8.16334351727571],[2.77824728597108,-10.5155219411362,0.0564132179251464],[10.5422451969457,2.58040480309235,-1.36610104358823],[1.66177680045739,-9.09322110396232,1.2901336640928],[2.13150799890243,5.73202960201461,8.9429474706896],[0.573587602221286,-5.87246994372172,11.09408124959],[0.671292649258189,-2.60595578169906,12.4297943891799],[0.407998337326955,-3.08463797859456,-12.0681896323174],[-4.26933401624109,-6.43103122034062,7.56346765813246],[8.16187235726202,5.89886600041402,2.43292536725276],[3.8584404641056,-9.26956591964206,-0.419276640285281],[-0.135359626329474,-6.33300584014896,-1.33362882796707],[-4.24274363726863,0.876260737196833,3.16878307735746],[-2.09139830889208,-2.45156913106943,9.21372492751738],[4.17241631185528,1.94958512304198,-10.3746008284751],[3.98981193658725,10.7578237780367,-1.89835611414326],[-2.25342744212943,0.0651606185958716,-2.28317211782109],[4.31865467533177,11.3247322809379,-1.6044509105638],[5.98537674568884,2.60518918020281,2.06260926230007],[-2.83030136967905,-3.92523096545188,-9.22713562611518],[2.88054315888427,-9.94819986202001,-0.0646049563424288],[-5.04854397698503,7.74232194570208,8.68933277083839],[4.23950074379222,3.54638891785395,1.53587682169216],[3.66005204100052,2.76984214938167,8.19680685659701],[-3.02707017430384,6.22812749065604,-2.05211620306583],[2.46330950018319,-9.74799145985519,-0.607769745776518],[7.81401107592774,-2.05798144686359,-10.3190848266297],[4.11736237051396,1.79429699296163,-8.89986474198699],[-2.1301147881268,4.4977130304902,-7.44653931644858],[4.18339086848674,3.25566852787755,2.32470386693691],[3.47505067115169,5.66425188696567,7.38634709689073],[-5.97747912728932,7.78335931935144,8.43928049207907],[7.72904093102322,-2.15621779627331,-10.5245600661953],[0.934603851737909,0.950543252087821,-3.94746795843109],[-3.5651978093523,-2.37803153902591,3.79643064809219],[3.10833438741269,-0.0690660644646219,-12.6278013543152],[-0.425381557020952,4.71609709736724,-1.58497872763548],[2.18177730514998,-8.97045829082457,2.88515615646665],[3.31988154566458,-6.75279501886469,-1.63528720495529],[8.97762572097698,-3.96230467902721,-1.22849023964718],[3.48341779379674,-3.10766467079676,-3.51445881957015],[8.5491289067353,3.11064426913952,-2.44805058882154],[-0.526273236256562,-0.113933277533725,-8.04087082558653],[9.33415067991411,2.72505347093152,-1.83776907632658],[8.73192119899158,-3.80302610085549,-1.39190460114856],[8.95352165071195,-3.42703166455118,-1.87823127331097],[-5.48601918895874,-1.64756187289931,-0.636158695210077],[1.81994136105254,-4.97339666078559,10.8206026504215],[8.1462531472337,2.3965734382507,-2.18962699804127],[-5.09372598378934,-5.73825840829516,-2.8573447378861],[2.70316057112053,-4.33593859753359,10.3296038957829],[-5.71693944155306,7.62581577998998,8.4469694775475],[-4.04334994422265,-5.62677321000765,-1.82491268670204],[-0.816311593610249,1.07618650811514,3.86124056724088],[-3.65359978485362,11.5361694635626,3.75188385472335],[3.20321856727387,-4.80054814273659,11.084878902007],[-2.32137596682293,11.6483450721496,3.58303405610801],[-5.10116699361361,-6.65001786997322,7.37179843468064],[-4.18318379869262,-6.04947739841746,7.56249023802524],[1.21713993173092,-4.99608999677351,10.7209943023072],[4.01983220285873,6.3881407757747,8.76844506809861],[-4.21111725358377,-1.70942791931157,3.916628843038],[-4.1327371981707,8.33311541168644,-5.59137367317771],[-1.80543872646091,3.3816152084907,-2.13844192115427],[1.19026685875496,-4.28693008109222,-2.4963365738553],[0.0806072945465108,-4.12231605106075,-1.30058534352755],[2.80801337508297,11.5007244034009,-1.80634415701955],[2.2388363632106,-8.83228108383946,-0.774322341000204],[-3.01147047797237,7.21041421488682,-0.860342660611006],[-4.75613593977514,0.971895443032416,3.76688306947028],[-5.72970138665896,7.6769606635932,8.37261084569661],[-6.35620407823208,-2.6962330533396,-5.0564080425626],[-5.55017357671841,-3.27194145081405,-5.31271718209702],[0.809165836897495,-8.76780143520361,2.51977708079626],[-4.03124423939857,0.982192314289711,2.46424170841756],[-5.37099349817368,-4.77963184058162,-3.66617703426111],[2.02145532477732,-4.97638389838768,1.62131303417463],[1.29662048165093,-8.35790923239674,2.64136183267027],[1.69476251309917,-8.5264825859108,1.91516657803244],[2.28791750300586,5.77937324727427,7.24296056081371],[1.8887562635054,-9.65186598988763,2.31242741779827],[-8.85275952777354,0.890488964728529,-6.07881294613075],[-5.47948240256475,-3.64611913398973,-5.0084141217114],[3.50451029966965,10.2523381780556,-1.23005883551496],[4.60151795804325,-5.47724649122056,-1.49019986434203],[3.28958462767993,4.67937841478641,8.32970832855073],[-0.155521295080752,1.05564226328637,4.04012398562412],[3.66279526361346,11.6644359868205,-1.3022740789641],[2.42973001962992,6.29466259391558,8.05342625665109],[0.543477982278479,0.363042895117077,-2.07019191881278],[2.37396217085051,-7.6904612237509,-0.841533466203873],[1.63076377367355,-10.1888290774667,0.738602063189364],[2.44576553620429,-3.19063451440423,-4.58602696476894],[4.0855714438355,-5.99745139293515,-1.13611903119898],[1.6434382947253,0.589631262920427,2.94666562206276],[-6.22087211358851,6.89220560455015,8.62240488502905],[2.18772985869229,-9.3984251541488,-1.61768404422731],[-6.34868066265293,10.9393955691088,-4.21989602381024],[-6.24422501693501,10.5874068222861,-4.21398105151063],[0.524284263604941,-4.97964682976195,4.52990242254731],[-1.97311299492634,6.76967197349384,-1.33704966869214],[0.877228881638087,-2.75905263938665,11.875943318016],[-4.36797545802101,-0.86778715387508,2.46567734389401],[2.73255350962236,3.48117062875242,0.716554746850972],[-3.64868487145758,-1.19307362749785,2.08472485686218],[-4.53893880364798,-0.437726687355623,2.12897724711836],[-2.05625874552994,-3.99472053054796,2.02895352601355],[-5.78790743500336,7.24003427610258,8.42312519111435],[8.60961485633829,3.53710219839918,-1.74295455471625],[11.8511822092585,3.15224309446459,-1.20227601393424],[3.46562229382422,-9.0268105403768,-0.509899434662687],[-1.47902069370027,1.87545609016335,2.44777357461837],[3.64832315238054,6.06277214673535,8.59833695677158],[2.25716574263909,-8.84278703740851,3.17695315173905],[1.38266404751447,-2.22293130334405,-10.6700838296457],[-3.8989385985957,2.256946659456,3.97867890497173],[2.01090466831658,6.20335903123473,7.04326741417188],[0.782559714603817,-6.44836977740611,2.15978685752152],[-5.25930199098596,-0.686090807599027,-0.462456337448006],[-0.28280427129898,0.111994426491867,3.16522302601352],[-9.47500865857927,-1.91664222077731,-3.70745665822177],[-0.220355008490032,2.60454581937541,-6.75226778189525],[3.68191339335663,-8.98357318606232,-0.756985917110391],[3.98730476766403,10.3033298935151,-0.720433215383746],[-1.96424443897816,-1.15243488441719,-3.53326132441918],[-1.49237506908433,-6.22151678094703,-1.78885985657853],[-2.65479853249564,-3.60881056218975,0.321895959540057],[9.24509691204675,2.68742278245268,-2.95840780690324],[1.28383471219431,-3.66897353915104,13.1867975136661],[8.62767022817608,-3.97616686241193,-2.80062456190251],[-4.08943969228226,0.0883945663830575,-1.55908747019678],[0.531387324812843,5.40251680097056,7.98455284641774],[1.294483422842,5.22787526926454,7.71820237113092],[2.55270021859965,-4.23970825735655,10.3076549347259],[-3.90097199955426,0.00716584800059528,4.03119663087387],[2.03734591363591,-8.93676786558305,-0.581928031147682],[-4.27974909674301,2.35024614037058,4.55723355700829],[3.28606003168118,6.46187533803759,7.37693215213319],[2.57802455323519,5.35372365818173,7.8690293139989],[1.95819289097974,-3.38191005461081,-11.3758285456271],[-4.59327379516931,1.06228987231152,4.90976945113011],[0.326778903245605,4.06886386684866,-3.65500923340211],[2.16578210579505,-5.45681434274417,3.16713634705926],[-1.67897544868868,5.46649590314032,0.035650658485688],[-4.31300966993722,3.23002803917249,5.02684676157199],[-2.93164258560137,6.60088627354367,-0.200415416309261],[-8.27425291839073,-6.84679207245712,1.49986243898775],[2.99707927855363,-6.61857825047048,-1.06707208179582],[-9.31565093235051,-1.34126446113388,-3.76578729163678],[-5.73276380438967,1.18423190598311,3.35925194887706],[2.09241067630615,-10.0808800027483,0.64995540262314],[2.80492054649122,-5.47674540999726,-0.241719813663151],[4.25420890879228,3.43961254450474,0.854511778062633],[1.90707788893236,-3.90741654194672,-4.8166597688665],[-4.70069500876674,-0.0173569477775679,-0.707789481856012],[-4.38834388387354,-6.67556469419562,-9.47619646108319],[-2.60935375782549,-3.24425083724156,-0.588906595386837],[-0.522621234384009,-6.4222364763517,-1.32937188863853],[0.473734091353226,-9.45799603075601,1.42012602065694],[3.61348896173644,-4.79211209532309,-1.29929059427334],[-9.49931806562516,0.681147209212416,-5.87957568449608],[-6.0048858386564,-3.42100352703749,-4.89733199124826],[1.74331357208372,-9.20774423288811,2.4098122860978],[-1.75043017053995,10.3473247840745,3.00824586839728],[-0.798350962308585,0.602535752511587,-7.29838398776468],[-3.65674374489235,-5.44986236641135,7.67699690684183],[3.54230680869745,5.97619373705051,8.85583336998019],[0.396329461564881,-9.52717762951642,1.17411173112154],[-6.91119526117479,2.87771678708585,-5.059200351547],[0.117166091037281,-5.26451701457233,1.95080071659516],[-1.78882828588205,-3.01496661677751,-9.77582901403465],[2.69046340041671,-6.9398225494917,2.47259286415407],[2.67992762293147,-5.49451603008011,-1.60952677059844],[-2.28442191166765,-3.57420998755981,-9.70801913014576],[-1.38622267131945,3.5635236868162,-2.40668182279981],[-4.32011514498755,6.87194466639903,7.76651942033807],[-7.94375386444199,-5.7431944288186,0.268005796619074],[2.62985331334574,6.63261840346831,-11.3633552402275],[-2.48773770903989,-0.497188548290158,-0.952748953697158],[2.19432800902405,-5.28581131970106,3.29954112153982],[-0.460758440687858,1.87049338591633,-4.75206082328329],[-3.94172862001582,0.342961460802302,5.20974152480175],[-2.93216328829477,-4.96951883112071,-7.43986629667472],[1.96888636906093,4.74686517907295,7.19421074828394],[1.51899571298378,-3.83961555226757,-1.66698845044997],[-8.73946382847811,-0.987337193212887,-5.50091988888541],[-5.56163603383092,-1.9408512678904,4.02520409965992],[1.53339519073971,-2.56939578112921,12.1669543657514],[-2.15902424554552,-0.802098407574555,2.3274709510404],[-6.69446710487816,-6.12650551747089,-0.238336625922554],[-5.69524714727761,6.73146973001998,9.01053901192732],[2.61806254677373,6.49722249163379,7.93726109415591],[-9.12289771547506,-1.56645986248762,-3.72075066551891],[1.76900505410307,-5.7339515473014,4.09699659628984],[-1.01188893002677,4.25996982675507,0.285836642512534],[-7.5794567169981,-6.85308516012122,1.35965742884882],[1.31363122027944,0.907996481290771,3.88607264781434],[0.407422669385391,-3.00731174652288,-0.935289506280006],[-2.57512917942015,4.80325906257644,-7.74719770209253],[-3.22931037342242,-1.89929212086892,-0.928410419088678],[-3.01387760891378,-4.86813750449867,-1.30679370284971],[0.182548403110045,-1.09948239259872,-13.6097795218144],[1.94836317933332,6.39376038131434,9.27964245859556],[1.35659024577162,-8.36394425816651,1.87138720852436],[3.20869684804821,-9.00316677324431,0.872466692801227],[4.38889146305319,5.38722060411686,8.18582412669557],[-0.447004107011839,-1.13378791176047,-13.8477794576532],[9.54676035687029,2.42508484330284,-1.54465258384615],[-1.35650303095633,10.0640399189617,2.42419508594572],[-5.90760322482768,7.85184708538911,7.78494006266382],[2.00486245347392,-3.0419821332274,11.1851020730885],[-3.53555682982962,0.359302588460781,2.51471155200767],[2.72561114659619,0.127093074072249,-12.1193742570173],[-1.23688671301565,-4.67335459563178,1.86771935132164],[4.91254566929241,-2.92198828806726,-4.01551445815654],[1.02941255520233,-3.98791104336097,12.2690050616184],[-5.75645401602526,10.7483951430851,-4.82818200150345],[1.7763362859997,12.1219359588208,-1.79992402755965],[-0.231792731029297,-2.25828179033853,-2.37614447539614],[2.9292637604639,-3.13781886694092,11.3763665830056],[-4.64589464485251,2.28181486404432,5.05739935912835],[-5.01337513158589,7.01187682673782,8.86911992251107],[3.02400604361905,5.9466983595922,7.94275446837221],[1.95455405722621,-8.88072669358866,-0.372337329228937],[10.2957882550348,3.50992006651285,-1.94827348072777],[-2.08816086870019,-0.717253709361415,2.56307122421986],[1.68181880146597,-5.58774781936513,4.04826172417923],[-8.83900324097773,-5.93977801736517,0.976663780054612],[2.42447419878149,6.35655057683244,7.29303279550624],[1.84039959557279,-5.39925843439269,10.7915293932225],[-2.83887797808528,10.3275678125803,3.68748721493666],[-2.82377944052208,-2.26887005969777,-3.54143375328079],[-8.11136936007083,-6.90548778878031,1.46926054199151],[1.72307139816379,0.0527589922384071,3.26985026758454],[-7.09175893858884,-5.27956487634477,7.45076508436717],[2.22260386704556,0.183134988615754,4.08068196055955],[-2.3886084124641,0.104819892591779,2.88209988489529],[4.22119493590612,-3.21537883529545,-4.46245028478473],[2.12854156195657,0.654754475525886,-7.06991660263478],[-2.62313940499765,-3.79033617929343,-9.15798930289871],[-0.593442894614286,0.0807103452069264,3.34610619313584],[0.523372336323112,-7.9723641892892,1.82069391285414],[-1.72816949405319,2.85459316601689,-2.46348195031077],[1.40251076737974,2.22094006216378,-2.42355131405251],[-3.45348329278153,6.98589896014617,-1.09382857167313],[-4.32187178211069,-0.890765813662483,2.33665742347333],[9.14141702442654,-4.44815900523512,-4.26281028699617],[3.1358606167596,10.8259960967397,-1.04411335561602],[2.21529303459566,-4.49260750551845,11.9996615829486],[-4.47819758963404,1.42342967375131,3.72026668079285],[-5.70983265912459,-3.18202483870324,-5.19274498209514],[-5.57818996890929,-5.72045058665902,-1.44387949057733],[-5.64726454917637,3.54265487414469,-5.20541002107798],[9.30045966736658,3.65469126814074,-2.68104769416419],[3.45662460396191,-6.01722105270448,-5.22480989830432],[-5.49170640744753,-1.14337103972125,-1.36517185232681],[2.08893183780641,3.94727408414507,8.8980235420165],[-4.62540791821244,5.38550887073248,-0.585866765155559],[-7.15425009495595,-6.13266817954182,-0.585783118611565],[2.09004724679258,6.66722376024985,8.08366864758883],[-3.67650672393527,0.682564501332865,3.27631008088397],[1.94555792345545,-0.354511406272569,-9.86347618009412],[-2.29413442428738,6.92609011985826,-0.270361252125682],[-5.34967218061017,8.13547242679851,7.55088111949846],[-9.25346615699473,-0.185203597446602,-5.46013653429555],[3.58423633205247,-8.30965353346806,-0.134138610204901],[-1.81350149609977,-0.544501303689517,-4.50022431234475],[-4.54789752867056,9.32492954428992,-4.16776144008497],[-2.87243866477274,-4.65264764190687,-8.74304791913817],[-3.80822159842303,6.38548914415082,-1.34450127273269],[0.732752755198977,-3.00714187481647,13.1250625661405],[5.04938251903124,-3.00289855472437,-4.02443936428681],[8.63708073191716,4.04966750492939,-2.71804145875794],[2.0683092578861,6.21097150821594,8.70946224670196],[-1.74395549035019,3.71450721872966,-2.68417461846063],[-6.24427818366617,-6.03067708096443,-0.996157513014228],[-7.90946239636208,-7.01110135810189,1.37706769157881],[-4.77783561292879,1.06935520263225,2.74906757721413],[-2.06585757710773,6.34337714519388,-1.73534372894212],[2.86532899339513,0.134287386802339,-11.7669602071561],[-4.91647336622251,-2.55057698090981,-4.50316226680635],[1.64443638246349,-8.52333865360389,1.86136487659747],[9.32263361233464,3.04349387002349,-1.31190478194815],[0.547578449643983,-0.710843306742814,-12.9887731519136],[-0.35842534239211,3.68733706967579,-8.83117499446562],[2.21094832828526,2.7547254655542,2.41937495751032],[-4.38543057417836,0.287023500770052,4.09525249810583],[0.586065918850375,-2.52516904530178,13.3785226962098],[3.59939017739375,-0.65961248386606,-2.94329659551834],[2.69300437679433,-6.21789023457527,4.59417736396877],[-6.3048385353501,-6.47070557930964,-0.797644514336245],[10.027861383478,2.84040501921514,-1.49751223580636],[-8.75761825304686,-5.99254893744926,1.08814223914022],[3.55177537452842,-3.34929734474916,-10.2401472247504],[1.33442366607176,-5.02440054285774,11.3888728799066],[1.51380946163547,0.742952212441516,2.88460577056529],[2.77083867870099,-8.50744092557071,0.263990466845588],[3.38950281162808,-7.92641887402616,-1.9007658512357],[0.0771064272410433,-8.33642530598594,1.45432891548192],[4.1094896585598,-7.01162850147198,-1.72742300031247],[-3.44250533796837,6.35508109712398,0.227127919067283],[0.874264021008493,-8.97283453296877,2.39944117491414],[2.56291177661547,-3.94531135111903,11.795340267169],[1.79439993592118,-8.95964075566109,-0.66805059172458],[9.72694012562144,3.84185247492899,-1.69785494783388],[-4.21005504263081,-5.64459113282539,7.72900579574065],[1.41101654992887,-9.14417996515609,1.88971805041098],[-4.563537446267,-0.65419968904424,3.99084617872286],[-3.87021678788287,3.07813677865064,5.55360166159049],[0.870332835452497,-4.00928917221162,11.1482576632613],[2.93967134413537,-10.1942921765824,0.00290502372770385],[-0.620565136423741,-1.66876081597305,-2.56892999837042],[4.46003375005717,2.34601260307291,-9.87191352340163],[2.34476130536583,-7.89690434233944,-0.975165454769579],[1.97393496385226,-3.47107298184332,11.0418216490654],[-1.10357759833877,6.29391160450444,8.77380291815996],[-4.91879353118936,-6.2521339335478,-2.0185420777527],[3.37870884373121,-8.22090154447419,-1.90921247125034],[-2.82146370486879,0.449100845839562,-0.51962883903756],[-0.0426638759590493,6.06249239516209,9.05395144470283],[7.79990307002282,5.68650089720333,2.00847882307712],[2.70710182805804,-5.86461730741726,-4.71429860763392],[-2.79144978371901,-1.22906521745895,-3.79123993737575],[-6.01716232347556,-2.60801057072134,-4.31782897649008],[1.36657209751783,-9.65629104945362,2.22024018761358],[-2.16364279280869,5.00514888758548,-6.73502431498844],[3.54851448653695,3.54835945880763,1.65923824182952],[4.20282636863236,1.92859994496516,-9.70988427375023],[1.13895150168377,-4.72272995883042,-1.98698298864768],[10.2218344422743,2.57307216823369,-1.38892412197799],[1.35233172136243,-3.95586098173591,-0.120555783233853],[4.39727629020677,-4.88150009840758,-1.55807437123001],[-4.86758933757669,-1.14806336804428,3.90596415282296],[2.31252665836235,-8.0617430304336,2.6368259357223],[7.50568990577308,4.38445150435594,-0.122462166053907],[1.31063961086726,-3.51909607930345,12.3320509966539],[0.476798061748191,-6.87896522672703,2.88452906409873],[1.54835414258199,-7.52275661840179,3.70028148867514],[3.15929304672006,-7.69950484969792,-1.74189221395269],[3.67980848366627,11.062674019698,-1.39140976994599],[2.58049639156738,-10.1038385152514,-0.521275380665455],[2.19114329010183,5.7867719738554,8.86281511824521],[4.00898346901217,-4.77393608058951,-1.36882864654034],[0.883002781598703,-2.86684577913092,12.605337444254],[4.23528178636352,-6.80672805605508,-1.82539059228889],[1.10523644405494,-2.93760803080592,12.1484793958246],[-1.99125885911246,-3.31929712591133,-9.90730705026243],[-3.35212327599445,-0.853221243494394,3.61784535427916],[2.11001512465314,6.39082296686164,7.18881843613959],[2.71213711782466,6.06869154034416,9.1162127854358],[-3.20848336657635,-2.89066917652894,-0.519352015164766],[1.31486410950443,-2.36880576733884,12.1767769998057],[-2.82703034544738,0.262069424070988,-0.29974619491113],[1.30224613295648,-4.79625683293368,3.35777713881016],[1.96522441928671,-7.79041150734638,1.37339835293999],[3.26987502640831,0.51266113664832,-8.83223256947208],[-2.14396930319205,3.55523559116553,-2.53255139580275],[4.68895998092488,1.68379917534169,-9.45374885085234],[1.02492390433694,-5.75306812360474,3.45859282443607],[-2.6780021970469,-4.05040219199104,0.152443073826779],[9.96601257692907,-0.908816128521478,0.182390179981],[2.26559848032419,-3.57397115829489,10.91121455355],[-1.6158954649508,-0.205214231527562,-4.50005552660579],[1.61241057201832,11.3496361198436,-2.05510747389557],[1.15192433469864,-0.836683303496581,-6.34720918217143],[1.78662199201263,-5.86454757333222,2.87083200764866],[4.16013160969014,-0.817393209206764,-2.31229753024595],[-3.2486686285289,-5.44866387253008,-1.79051993924379],[1.22883959131347,-9.47955071236787,1.64264747712581],[2.60203690549444,-9.29734957159711,-1.01959507769223],[0.598965663800255,7.13948757012245,-6.06143904519466],[-4.57600600408769,-5.43339811164981,-1.15897299954558],[-6.04177427604376,-3.55587201055279,-1.6661240170007],[-7.01282428170498,-5.9483690724203,0.246645822104374],[9.93474667498874,3.49489824110169,-1.72852302871139],[0.244584416780901,-2.80164195187195,11.1139614995112],[1.8372285869219,-4.33200361877162,-0.283591554072291],[-0.464292399111392,2.86491075411987,-8.3338169563414],[1.93503806021225,12.2786682416431,-1.47165048177472],[-3.36848554183727,-0.86274550096696,3.46821525097983],[-3.95572435212277,1.49054626707549,3.59549878950564],[0.200861281970391,4.26927626893211,-1.88836766709624],[-5.00921974112618,-0.93676187708657,3.68550572155027],[-1.63238471802049,3.19113032152782,-2.03896700172707],[4.08442788969156,4.48872743464274,2.67820637055642],[1.84586647681775,4.59844633651185,7.27810149481531],[4.18003487241639,1.95980044740807,-9.27045878069026],[-5.41311444956217,9.14077759533316,-7.61630245389278],[2.93010400351472,-3.99608145904137,10.373731799102],[9.52301889697336,4.01261914126957,-2.6602809731892],[1.82548268393565,-6.44454556226423,3.4485454829839],[-4.2537313900392,5.60063911697422,7.87350536236553],[-2.83900886310133,4.74105586693732,-6.76904604447242],[9.89523195788754,-5.18670217456972,-4.96788905013632],[-6.87172281840178,2.48344849156285,-6.09633072961675],[-0.946852936131104,-1.39987386279372,-2.75279179909775],[-6.31907071727504,8.55959210419136,-4.30831232542594],[-2.98814783830412,4.46676940577871,-7.56018687598884],[-2.71476548735499,6.68102054050335,-1.29048827532111],[2.84751894212534,4.29594237424201,7.32078170217216],[-4.61567683872604,-6.518989526018,7.07723342033303],[-4.54808691422827,6.56234657098836,8.56861244556481],[-2.86791250745238,0.110031535333299,0.689923093819491],[-3.06023908601219,-1.21060817102205,3.66746488809522],[2.88950235830909,-4.52443090465611,10.7805250172966],[-1.34221225404461,1.81463833197877,2.12481815157568],[0.805383771839374,-4.89905189232551,10.7638096171005],[-8.13228494224447,-5.65718069797881,0.307218413344818],[0.487073799891548,1.00305220321577,3.3212586242156],[2.05803515745792,5.70978987277118,7.49366410619077],[11.2131302153541,-1.76099535486222,-1.75776043502877],[-6.59611435249308,8.62536850254021,-4.13784409255523],[2.10931382188506,-5.00999868581452,3.07952783242141],[2.93549436609545,6.53733978531292,8.66824012833631],[3.1878973679386,-8.20874349366735,-1.46302879736097],[-0.245538900984188,8.14468343995069,-7.61554156736019],[-1.33697051335388,-2.78580672708997,9.56900154336701],[-5.12136347299317,-6.02649927475131,-2.24488017539339],[-1.9376621135626,-3.0852596006794,-2.35591011418312],[0.798485499096092,-5.36604648894204,4.95295778992099],[0.449363523451341,3.3759097673815,-8.35286286084695],[-4.43496275551528,2.98251150599451,5.67007544111116],[0.31109143871038,-4.41476020629039,-1.62454864258183],[-7.23670840822087,-0.695187500334723,-4.31468100439967],[3.82677632893569,2.15591129943116,-10.5347625808179],[-4.51005312060883,0.756501152446434,4.88125696007244],[-5.33086097250659,1.24520016298867,3.84899996601858],[2.20406533038065,-8.61099391659705,0.328849954373132],[3.14939889164419,5.86847482269347,7.85858219345705],[-1.03014645299922,-2.83313941491506,-11.9274152277719],[-4.63788580504705,0.767352971047966,4.52264716216226],[-4.83832043371009,-0.635082310186744,-1.09910969652389],[-7.20632540316224,-5.610956907155,6.92096099843351],[0.172578325042311,-2.89123026277316,11.2761444253824],[2.91107616230368,-4.06425651593411,10.5310277873415],[0.478501935511317,-5.81574053502047,-5.66943816396987],[-0.203954325158356,4.20074632900118,-3.38837445177183],[-4.93760757732043,-6.15762194120556,-10.3057733072974],[1.72968415821237,-8.36527225139905,1.91105618199518],[2.2215426921092,-5.45485436097464,1.42249854348979],[8.27536108311327,2.3333140594497,-1.26689410415344],[-1.97585212349506,-3.39114942815025,-9.58677453429729],[-3.57095868668468,2.54509907090126,-5.4419317929496],[7.98351523871734,5.90128203580229,2.02265390855775],[-1.80093577074724,-6.16868489178244,-0.75607975044553],[-0.731229828192253,-5.51650554672943,3.53272498278785],[3.9560799711174,4.5015508160405,9.10537446310796],[-1.60353168914038,7.28034771580643,-7.20786450004447],[0.152478603173499,-3.91837148002217,-1.29647472558699],[1.78544592626262,-5.72212439326763,1.9182904443127],[-1.20043524344878,3.31494032109668,-2.55710206992784],[-1.98236129735497,0.516457259164549,-3.57558690275156],[2.05247785588911,5.97747439324273,8.78343284907787],[2.30219139976909,-6.65675430660663,4.63240881636673],[-4.9445361445075,-0.586120547158929,-1.26743076087737],[-4.59258619304476,-0.261289314613705,2.54470620074045],[4.20321190802421,2.02005393995903,-10.2080630948285],[-0.582896204720604,-2.66762730562268,9.86607190707534],[-4.14463557091252,-6.43828792796094,7.5826188367404],[-0.341408667782165,1.76538044060222,-4.66694022142932],[0.0203277345512414,8.66930884224613,-7.50188723635398],[1.76133946634945,-3.24060675981327,13.4592878966312],[2.82519395885806,-2.3508539756513,-6.5985385640542],[9.03475603220428,4.01318498848582,-2.37915555883134],[-0.234602702674117,-7.12256579778331,-5.9932639853522],[-5.51428765319641,-2.83918348352844,4.49953625750136],[-2.02859466077205,-2.85355071414609,-0.108975146712019],[-5.75594233415064,7.09871802880364,8.15271364669695],[2.62934388078805,6.20478434554542,7.54645017164003],[3.12138861054756,5.91387943007283,7.27065582956591],[-4.71657733447738,0.375171862786697,4.51265155809716],[0.842162378918598,3.84628584996098,-6.58146083989232],[1.83966705575539,5.73411399857548,7.28386345166076],[1.4347848990144,-9.11459880485483,2.10931925949374],[3.70571443177653,10.8189191370303,-0.561246577923873],[-2.3570936653648,4.07962530380057,-7.36627784781343],[4.68014494999706,2.57666388790884,3.9371799227772],[-5.8464137246958,-3.57274836410217,4.63605745975991],[-1.94985125110959,4.28292227165795,-2.88201695159566],[3.74111303654632,5.8509532241046,7.30380400137071],[4.28386564623008,-7.33614298594079,-1.30969345127149],[-2.30272936357049,3.44393550489268,-2.21169471130825],[-5.96704194529151,3.37336756820332,-6.48614320898444],[2.09418062797321,6.05949658513221,7.08706461125663],[8.56212991904714,2.55125927412421,-1.37366182947077],[4.00176903299522,10.0841137803036,-1.03410259554186],[-5.44258475148144,-4.42938443770689,-2.74092994591645],[1.75606995443259,4.13406363488136,-5.71058695728978],[-4.67330225275144,-0.0338120501565381,-0.313713690544689],[-2.87734490300538,0.373595425138493,4.18240741146988],[-0.161249506714929,0.0381697300963311,2.99083192958734],[-3.52139960994937,-4.83565690536196,-1.02946468968542],[1.16132170965976,3.44577087798949,-6.0806053381497],[-2.38303238280704,-3.83507592320142,1.9877617288936],[-1.38857636169448,-5.17296928994615,-2.13664453249134],[9.56040762277386,3.28764051229269,-2.94027802681318],[-4.93343634044777,7.51784935022485,9.34519948538952],[1.65610237598461,11.991430974347,-1.06841300294108],[-1.52600206640945,9.09896308500267,2.61363391633243],[-1.87280582559714,-6.42390192189235,-0.868982583941883],[-7.0595565018549,2.91884432067011,-4.32850869362151],[-2.17560092908762,5.35916156845999,-0.233224567886648],[9.2370973949235,3.05990477337919,-2.41250446723113],[-2.51782768964016,9.57322346032093,-5.82193442084788],[3.29603607816679,6.04378171553268,8.62364315314304],[1.92925387766838,-8.87223165167971,3.01440822333147],[-0.674990671917625,-7.34701504490766,-6.08726469035513],[5.29667523569027,1.33102570425869,5.47240895954053],[9.01365674609137,2.0700671681279,-1.88726744893864],[-2.85226414005774,4.99774353722346,-7.34854555820968],[2.96475639309585,11.0058946722187,-0.69986626062086],[-9.37123230299961,-0.557093724083985,-5.31411679152772],[2.58729417672133,12.1259705647388,-2.24675666384091],[-2.22176933148736,-2.51937582797307,-3.29201150982606],[8.47600876477751,3.69627244257119,-2.41976751508604],[3.15115046137545,9.76402331023426,-1.70664815721228],[2.19439253480618,-3.86139689368546,12.6101417311878],[1.06414919868618,-2.69884719889382,-11.922474074332],[4.49822718540082,5.39375632760641,8.81156071585581],[-0.155145564060106,9.46316593783063,-7.52562371343978],[-1.65280862739622,5.57901727499078,-3.02515656615091],[-4.18846809527959,0.416281491847245,5.33036635671995],[-5.05881134904025,7.52664241224304,7.84273272212278],[-5.21554967897084,8.05234095998515,8.4942545634968],[3.51791271733609,5.77154367526838,7.94185609521829],[-2.65638850927663,-2.21501328548507,-4.73814614531783],[1.6392354235809,6.27767837164968,7.03042793404791],[-3.20304801619677,11.8797259487209,3.59687356569916],[-2.23073801134431,4.92027106913652,-3.19455463953771],[2.79514826261745,-2.87654074529018,-3.22863400652862],[-4.77451017542096,0.648487130707028,4.45595460138712],[-6.21727219489986,11.1027968976842,-4.33031072935154],[2.46041261033243,6.64777918456311,-12.0537151682458],[-3.80443096264687,2.24636090174005,-6.71112117268435],[-4.3648925507714,-5.88100306729135,-1.79512365594023],[8.188727622076,-2.99116798390653,-4.81756773274621],[2.5412643794184,-1.77586839960162,-6.43215983525563],[3.00427056473728,11.338608902882,-2.48737018011883],[2.74134055752172,11.8464629192855,-2.68115404310843],[-5.11695380629184,1.10685085315544,4.0423068574119],[-3.38921606333438,-5.96144379116932,-1.6735626989165],[2.15079002876095,-2.6164069910266,11.0035447267824],[-0.77549995295191,-7.83023420439133,-6.0221135798027],[-4.2712779539493,9.38646642875627,-4.44701909160565],[1.12816405308402,-6.98355918267691,3.29725729710427],[-0.0275744846608101,-6.7143436303877,-0.940350549014459],[0.11356108868241,0.810733251408228,4.51548879520546],[-0.778508680346313,0.417621800583083,-6.84302990397496],[1.84222622978759,1.19830055745792,-5.45369389110587],[3.11962662886459,-4.30629889558676,10.1631832836705],[2.70793761996992,-5.06687132874312,-5.26338291668796],[-5.04196407352921,1.68701753053671,3.29429062541057],[-4.85116174800949,6.77170700341104,8.72766285111314],[-2.64903204869754,0.434268750455302,3.04405499798941],[0.246280748639974,-3.20410042316425,11.2762215840556],[0.754684710624433,-2.585799410374,12.5402411675313],[-2.41710998585479,-0.152540559808696,-1.20089017296861],[3.50456411426147,2.117224470956,-10.3044686094967],[1.26233532242171,-4.34567871335105,-5.63697643732301],[-2.83537921676742,4.72144331603572,-7.43407255467403],[-2.38503079791363,4.45536146133889,-7.54851296784532],[2.63055389079185,-2.80185891090749,-4.40806321683433],[1.72388588675207,-3.25407911703639,11.3566569026765],[1.23498149252003,0.46797218481982,3.20047850149136],[1.04956597339061,-1.86091067371576,-10.9990810968973],[9.43481064996837,-0.323014843256304,-0.349133568904222],[-4.82591128059445,-5.89193933279984,-10.1471036597942],[-4.95490430915971,-6.08763119112905,-9.61822445758804],[-4.79685662479968,6.17320348200479,8.2365342724613],[2.49280300727674,-8.46356300902453,-0.282562098219594],[-4.48362458470432,-1.23956421379554,3.13924289330896],[2.1776650167819,-9.54205553179687,1.76702696925508],[-0.450878751279408,1.7771449809528,-1.70151943629252],[7.02158099159289,5.02699413574844,-0.231316172947289],[7.92284395672949,5.64964307998516,-0.841344473162148],[-9.53315564728948,0.551662855087573,-6.4354272766147],[-6.50350343016066,8.32812735206335,-4.1895673545508],[-6.11876817153211,2.9798515771291,-6.31031336849877],[-2.17702443307118,-4.24946930661442,-0.682909625989594],[-3.23509520358711,6.38752402414221,-1.32539158603445],[-4.80786815563558,-7.02029019887782,-2.80311467405575],[-3.58837980254917,0.204294137647895,5.39381417939858],[-4.93651134923384,-6.45499168706814,-2.00721984318116],[0.869899048190537,-3.21371633920312,12.3639303400192],[-0.46530497400223,-6.12262941828615,1.62997370596656],[1.15569393778729,-3.0762168894426,10.960530967268],[-4.80307338801743,1.12771425757933,3.0952586795393],[-3.09845197051803,7.0849953976827,-0.81706351781694],[-2.2467798621779,6.82865549282928,-0.436279221806099],[1.65821644027995,12.1325008785021,-2.18275704556905],[9.098258491972,-3.90193648653786,-4.00455679638687],[-4.35695935850238,-5.54918852553419,7.84943242551958],[-7.66834294421529,-6.0624412234307,-0.111428919488596],[1.29857790277474,4.94408727614947,8.62135629824104],[0.538015897388518,-0.14385565398085,-2.68136185450762],[4.2820835168687,3.21390985710215,3.0771558089505],[-1.58407818761357,-7.22891480026791,1.07128945999799],[2.84674665549536,-0.137195028764002,-12.0401887096635],[3.84789369909793,3.66933593571781,1.82765910932052],[1.9017789535193,5.86897317522876,8.75965690524022],[0.83631357382235,-2.82731511129635,12.49097214338],[4.07551219629402,0.0196867302631577,-3.77519735886263],[-2.06184996078613,-0.228987814827894,-0.908180647261078],[-4.36771674276951,-0.294082410642024,3.32361096879558],[3.13038677067858,5.65976019789109,8.61153400179463],[9.54182708032959,3.68574909648792,-2.388169746455],[-0.377922189881096,0.43577616335353,3.8581636735335],[-5.03923464636959,1.18159004965244,3.08708568751354],[-1.17583665641861,-7.67664859769672,-5.46751815344662],[1.86738410559659,-7.63034979860636,-1.05350956874085],[0.532015225831315,-4.50620819861681,-5.71898132505113],[-1.88627701239577,3.72239149659339,-2.26159530031636],[-5.41378038313402,-0.602474440243517,0.185025933271425],[8.23820066030035,5.84327153895755,2.89298040738737],[-0.432294109857513,4.25962654774565,-0.120040716648204],[-4.59230245578286,-6.02960820539962,-10.0327207917031],[3.57765735627652,-5.13317351420486,-5.38023330238216],[1.67139336084028,10.7103593406126,-1.58886881537835],[2.28764315545075,6.06865682685803,7.80732108358661],[11.8279071089084,2.44839032487751,-1.09714534102617],[2.71310179797755,5.74008476589232,8.36553068802893],[1.13432850290731,6.17958431335876,6.96545360139774],[1.05455538488212,-9.62665534561117,1.41469189552556],[1.89272316759994,1.30170089352048,-5.28755575665156],[-5.48056066146611,-1.81152783732059,-0.750450481027583],[3.43433599908075,3.20821508865271,0.103602482498648],[8.49151699441459,1.33600473776004,-1.75640522548058],[1.78466213450121,-1.52289446800322,-6.72009546258562],[9.5060292833237,-4.4474198789869,-4.13309760168047],[-3.88084360607364,12.4721301271003,4.40325080237881],[1.24656179526157,-6.56408156896132,4.52082922560578],[-1.53121317961863,-6.61368275752701,-1.44514008553792],[-1.41778917468044,2.79344077879905,-1.84921426387059],[-6.43015862866846,8.1644920021609,-3.84925449419458],[-1.45245614972145,-3.59143444154955,-1.1914464098],[1.20536382477888,3.83358763431835,-3.91342305073102],[-9.6850415683942,0.899424655884703,-5.94754366916593],[9.60105724742841,-4.46907939232512,-5.1108620394309],[-8.15768726910609,-5.4547369433941,0.327457139443634],[3.52695435183343,-3.07685731928401,11.5398308380174],[-0.00556323056306574,1.03240261446701,3.71652500887433],[2.11195683414914,6.34431960068969,-11.5579175384664],[2.65257477747973,0.175224022297415,-12.0853241533844],[-2.93269239009058,4.5123325696426,-7.146708565605],[2.33466840712614,-8.11106446369803,2.68062055488442],[2.11885375202261,6.56492242334071,-11.1581824530637],[-2.83203260024347,7.19762781522868,-0.744125046401297],[2.81133925218198,5.72502804014271,7.04392042563094],[2.01440791137916,-10.5255531810352,0.797634810072845],[9.18076149332421,-2.20797832980794,-3.35540115517954],[1.57581349695977,4.62086199333599,8.88422273653877],[-9.67809259602288,-0.767032570493527,-4.16731548484554],[3.70463888153724,-7.7349508706802,-2.25783438546165],[-0.289043495738932,-7.42433529700754,0.950270039723306],[-5.85257668362368,-3.36273150435767,-5.21599938797085],[-0.111784810147841,0.538896368110308,4.57354268971992],[2.74529867884193,-9.88849306189559,0.733938607661527],[-2.56487600458501,-2.11601882443072,-5.45410858293442],[-4.60793197955402,-0.300745923710217,-0.283510355274966],[-3.23812107815046,1.26898236786763,2.30762548079029],[-3.60390314655912,5.22177411762909,-2.29607496088276],[-0.921348451850463,4.67512001148956,-1.03424313629366],[-2.89366053278425,-3.70797287603146,-9.22248356228566],[0.70531082924439,-3.51775020791391,11.5181332948169],[-2.14964628162132,-3.57345694026943,-0.302233684264866],[8.28003973858306,3.06333082235115,-2.25788962576146],[3.60863365347356,6.63234270543688,7.99459793823575],[-1.83239063306331,10.5341928424657,2.93524633857526],[-3.56973018271784,5.42825902672178,-0.371543595201603],[-4.92894125361667,-1.15498867244541,4.09204025427766],[-5.29954973007452,-0.136251931792877,0.796172073213338],[-4.34853106973531,5.35346904897028,0.467751519843401],[2.56028599733604,4.63925669088627,7.53046781157095],[6.76524834178021,-0.93135235716498,-10.4927531140584],[-5.2072155315271,7.72573879913034,7.59069612391761],[-3.69159246428254,7.87162487303421,7.82317061873742],[-5.1405987397556,0.496071690605334,4.48327415976201],[1.88838253709478,-8.88720871715899,3.0630642068542],[1.11581647649929,-7.27189833278006,3.7417781427834],[-3.39881442642514,-2.49894510382416,4.52192298201202],[2.92013528530532,5.40661200367666,7.09421263513442],[-5.14137077562123,-6.71840588822303,-10.2260060210819],[-6.4928401465843,3.55256490388276,-4.75353579036773],[1.52176174587206,-8.75752002081378,-0.91835568892553],[1.90666109014919,-4.77135349559895,0.375620384206219],[4.30418604716884,-6.42213421427016,-1.5765488011977],[-3.16073295725227,-3.48982672653793,-2.91766017549017],[9.83424231542849,2.57511431982073,-2.26167564231458],[7.3298551576671,-1.93239661349235,-10.3951995853036],[-4.65448430153461,0.271587061434478,2.69636283778625],[2.22863044580576,-5.70893656719685,1.86864405706195],[-6.17805588064889,-4.33319804821156,-3.08728511389386],[-4.16583039502568,6.9758613458147,8.67207692748599],[-4.12130128000532,1.66975592854848,-4.45324290556251],[1.09830102182848,5.61429029222301,8.39338253976762],[8.59797187592386,5.22908352512411,-1.35974938634858],[-2.20568920957819,-4.15305639421223,-0.424148311367764],[-2.62098717482084,-1.20976674621451,-5.31404988773371],[1.97832057183137,-7.66020829980774,-1.10078259698454],[11.5723463464174,2.7607376536428,-2.12101052016254],[-4.31419159621995,8.19727776621465,8.37873432542693],[1.10811259727486,3.70483272589574,-6.74786454668948],[2.62951168021698,-7.47767973640045,-1.28078128521469],[3.28028281069577,11.8964195257794,-2.97923044031636],[-1.75362033894668,5.05673470506534,-2.44512075999785],[4.81518932657455,1.68613316576594,-8.5610332685482],[3.46122626864462,3.41022466199416,1.47042636563367],[-8.89505654742934,-1.82650547064774,-2.75980769502596],[-4.05480451659498,3.09965718318822,4.82860785436042],[-4.44185315816888,7.81210915301186,7.90797450003533],[3.45470783840072,-7.75400148228878,-1.80323724329874],[9.40782099507055,-4.04431119351789,-4.29828231805155],[2.94589207382316,-3.54733745033242,-10.8485498684909],[-2.00316968364029,5.87063403805639,0.481463237842268],[2.08433203357265,-4.39332307502805,10.1818308758825],[-8.82344644429686,0.222145641342946,-6.27372030009094],[2.2838718394347,-10.113836787271,-1.42291142982294],[8.84833496796933,0.966262935541148,-1.14298495760903],[0.794287361985512,-5.66108210497075,11.0685059891163],[4.61594865916988,2.35899398100008,-10.1527174425431],[-4.08639401671358,6.80800822517188,7.91160562033808],[3.36645536868255,-5.79228980910213,-5.32880075491993],[-6.37342593098952,-4.226553048422,-4.18598679384097],[-1.07708821902583,-7.84942074324238,-5.71560137112483],[-6.43823830914455,8.56251462535334,-4.11321995807435],[3.71415154795502,5.5955815154215,9.05182603394193],[2.56536761153713,-8.94950563922167,1.82334691491175],[-1.88999342245608,5.02147976183626,0.345854979446762],[-2.35198134919241,-3.40614039398822,-0.731438280015611],[1.67868426586779,-7.15285029197025,3.67735056962584],[-3.43255909587459,-5.19671399575596,-1.19645865069088],[10.344440785087,1.4918317349667,-2.28193902254858],[12.567440970221,1.73940389868131,-0.764276088986973],[3.97177840681839,3.72298740653185,0.56863723922229],[2.56791769304012,-3.41623457491316,-11.0643188294894],[3.58486936498551,2.83653798054877,2.92234605417613],[-0.0132363978978391,-2.66490936499246,11.3978087293831],[-4.22736683075695,6.26141557797941,9.08006062017266],[-3.29835893175335,-2.4998277844167,2.09463846661337],[1.7855385799549,-5.5898053517798,2.21592611858595],[-1.16048792840159,3.61499067087001,-2.47236685863605],[-8.70476427811255,-1.43253222984658,-3.65066387613881],[1.68598529128767,-4.90130465634722,2.9960594580905],[0.801653045802519,-2.97416129938872,-11.915383867857],[2.49443449273009,5.73125699599541,7.08517822877526],[2.45949084754668,6.28175845373437,-12.5212437620373],[8.2121654591376,6.40577386440757,1.77340389714106],[-0.407826950331656,2.84274869646083,-7.37902433632596],[-3.24631580339934,0.492887667949985,5.32508118899112],[-4.33688360908793,3.83933838050548,-6.16354126017598],[-4.5501621018533,-6.21479779043611,-2.4989758966328],[0.987687120759269,-6.73413629745268,2.40947369126666],[-5.2929373614467,-3.99180710727758,-1.82215556814832],[4.57391135088733,-1.91373025924035,-6.69237923418281],[-2.92308060742224,0.25001469805289,0.409737933252933],[2.30282485728898,-5.44483953794852,3.27571534609653],[-1.77831757660001,-6.17101681809044,-1.92263383023582],[-3.84092137716382,0.518976195798028,2.48052925285447],[4.48215990616795,2.0165647095391,-9.62886024421998],[-5.00459866069747,-0.294249881002641,2.23887609988662],[-3.11796163399331,11.0743072781832,3.49297679906939],[2.6174448945055,5.3048342479447,7.85279707750831],[2.30550143885559,-9.76322882661748,-1.61454570900745],[-4.72930073735437,1.61765857978291,3.22584391980436],[0.359965215762409,-2.5047372350838,12.253153731586],[-5.74510929457445,-1.66432090365319,3.88746247579543],[-6.15009973006174,2.54163671129142,-6.40232592331285],[-2.92221289104131,-3.76053515243811,-2.26369443830439],[-4.1180100331643,8.31363561616647,8.18764087054762],[-3.795629053069,8.28678155680459,-6.73172513462489],[11.7367028265357,-0.128970619787288,0.918348946623432],[3.376914458513,-6.35180595168279,-1.38217657967165],[2.8147917134298,6.93989311728456,7.7617661946222],[-5.6523942983376,7.11397743525417,9.11284001717381],[2.57979523137915,-9.5543973534485,1.68877611833113],[-5.37412230436217,-1.04557570017006,0.61147918349009],[-0.988483690879987,1.5933608357026,-2.02833991544671],[-0.478014537120707,2.84921054371192,-8.3849552766426],[1.66298349337684,-9.72357754236144,0.942702538571301],[1.59093978874995,-8.61814280089636,-0.472455131545763],[1.18423838724686,-6.28738745770754,3.66382291675046],[-6.09742834179462,-3.16921712581846,-5.1211747337599],[3.44554585838298,6.17040247172803,9.12437836622933],[1.73452578741701,-5.90410927016215,2.27055992889293],[-3.54094488057348,-2.63823763469125,4.69835129095281],[-3.1372840626008,-2.41138158919258,-3.57349744256269],[3.77194604098383,5.94361059624149,8.0748763610508],[1.74886091798107,-9.24478599397762,2.72256403751012],[7.13544477976905,-1.47325070283742,-10.4566275433829],[0.453524654262374,1.87321414048186,-2.32901091798086],[2.18886185767885,-5.07013849712385,-2.05268555123088],[-2.34952524329646,4.71152710164359,-7.64808602541898],[-2.6825411228009,3.99371549478177,-7.32944702804476],[1.56048683179683,-6.66155570826487,3.39161992343582],[-3.75742171023432,2.94528571836342,-5.97006316985607],[0.386759697325197,2.91676764619489,-3.47797472377601],[1.32199765652341,3.76825019443299,-3.74227520810469],[11.6449065919252,1.23030412842341,-1.07618213815217],[-2.61963594735327,-2.92009163031899,-6.382485267471],[-4.89077169110692,-6.71768116530399,-9.8888764879671],[2.78359733040893,-3.3315127345883,-11.0169998338013],[-2.54660920210481,-0.885897297514392,-1.82876568092865],[-5.63765405920274,-2.60899686834314,-9.25469573344406],[-0.849656400742897,1.89247569553305,1.49201834079567],[3.61048436148728,-0.60544316876016,-11.3436032511077],[-8.2725712800469,-0.897145062506865,-4.84395415458635],[8.77254527776332,3.47563263068097,-1.18151949981816],[1.92899363638097,-3.29798078566022,12.5396780907627],[-3.57952585312137,-1.99217297767121,4.00531984562079],[4.09464616650531,5.40845484578344,8.66130011222966],[-3.40906558558473,0.104792535793459,6.03921971338558],[-3.2082586512247,1.24041425107544,2.63712946605824],[0.741030541169265,-3.6800465064601,8.68878546974233],[10.8085800066465,4.94360034296246,-1.45814330308689],[4.29640555698952,3.59649239553599,0.92467503774591],[0.622045403248743,-9.0609921390772,1.59410400795297],[-3.26606126485023,-3.46952778457274,-8.60348682272785],[7.59679812959912,4.26961426115205,-1.2548342949609],[3.65002304368413,-8.03462949728614,-2.06638410389967],[1.23753924540293,0.402357935709639,4.17799578821608],[-3.63662520041894,4.85951073013771,-2.16828540459633],[0.556874449501206,-3.00123871147075,11.0876720895846],[0.459709050435762,-2.7274266081782,11.9826626156664],[-1.60897065953238,-4.57581832291721,-0.251996059226836],[-2.92182371550334,2.50120723671394,-5.45273065387211],[3.814699582717,11.5274198789004,-3.13517451302029],[3.95268700303912,3.32953890715438,0.593920951520388],[-3.32759387946271,7.62822410950621,8.51481932289154],[2.15304958592434,6.27571186707767,-11.1030473810558],[-1.52307450491796,4.08979083566308,-2.94573389844322],[-2.26196365977567,4.90944888022687,-6.15642753799861],[-6.21627124749228,-3.64874426891219,-4.36081860823802],[0.0411092372572871,-4.32428071314152,-1.56645491318773],[-4.51948630154066,-1.49242239108281,1.59405300367172],[-4.67018770880017,0.708985719207434,4.54529032414458],[4.10621270715518,5.20141323273843,2.50404020548933],[-2.3162989991537,-3.43324941009781,6.40908912773264],[4.11033783980101,-4.42854868199719,-1.46697109403706],[3.11728704105263,-2.55833280322941,-6.80987886460859],[2.61493737714812,-4.9560864414745,11.2120552887567],[-3.10348146110385,10.361874035438,-6.39163037426924],[-5.85752473297333,3.73071831457159,-4.98230654167514],[-2.36885229306605,-2.38344500202526,9.03239307138508],[1.64313685688044,12.3999284225129,-2.34992865896843],[1.7450251926008,-8.70786273373817,2.2043509957732],[0.994213298087201,-9.11977469851715,1.06410340404935],[-0.0140079405043325,-1.6778820173491,-13.2969325880102],[1.01798894397198,-3.52136374555399,9.8797431203417],[0.448105316579774,-0.611685746037864,-12.9708568042574],[1.7947797198423,-5.45904160532339,10.8085391737324],[-4.10938018265968,6.34963397114481,8.97247233062495],[-8.19506780643835,-6.2148163765121,0.137215866469562],[2.98911908431356,5.83021604573643,-12.2171355236325],[9.76915302818073,2.91361599772421,-0.202654888990122],[-6.37797269872769,-4.26131438583814,-3.49183014677171],[1.1937970288536,-0.141075947401251,-7.21850282483098],[1.68523206581251,12.4649014395117,-2.31787841558185],[2.78306568914674,-9.19752634920313,1.03293434425219],[-2.93631700168574,-2.15750944524665,-3.61310897537884],[0.211470109359997,-7.68731584020998,0.981165756139033],[1.83526628590771,3.86281604891671,-6.24350014947836],[2.21722454016476,-3.96067175592284,11.2403484770113],[-4.01872236482412,0.822944653530352,3.08905838094],[1.28272389396039,-5.67161947512082,3.6910274440678],[-1.7309620104243,-3.21922251437998,-0.356620423857921],[2.84010106393977,-10.3003931329719,-0.925817058338304],[-3.74733785779114,5.28211919887899,0.311071255739726],[-4.44436420056282,-0.72370425780439,2.71253149157439],[-8.75218934765737,-0.916765019694591,-4.12457654590988],[-5.37210094426035,6.91916920923848,8.72563708114933],[-3.04305434412213,7.34673870060951,-0.651934818566327],[-0.309712552212842,-5.6383257616966,2.77408279471961],[-4.12518291824532,0.394640560912664,5.616985190321],[-4.94114085273119,9.80607457522248,-7.53689897477733],[-2.40014955985435,11.7659893390177,3.63395915345174],[1.13161466521336,-2.63723214445958,-7.97915398936481],[0.188988611516836,-5.43206120211934,2.5009341660822],[10.7957210204603,2.17474973910284,-2.33176542710229],[-4.98404630326552,0.0263317326210493,2.84766682737104],[-1.81785092527024,2.95295076613757,-2.41088824519804],[0.559446011042251,3.44820014468939,-8.63210300815049],[1.24267711899064,-5.44376054769568,4.96561268258448],[3.31364078434326,6.36401828469048,7.11519347988846],[-3.2405352475371,-4.29295312916318,-8.61648574351544],[-3.83859841741154,12.5914045702498,4.57824459240407],[1.74176998899772,-5.06878762554162,2.215460444694],[2.26703727974579,0.314341115039834,3.71137267118434],[9.51635237188002,2.86696136337242,-0.680254166382932],[-3.94899259157497,12.6091496862463,4.57218383655315],[2.61559792020315,5.93761419120181,8.92620125794951],[0.00110515310055992,-2.81544437928848,2.11724378990303],[1.69264860470572,0.535142609021435,3.50070160874079],[2.02409181768076,-8.67519966059686,1.96583863975513],[-2.88566861456897,-4.36484641403868,-7.85452363618649],[4.40279683388759,-6.67483768803686,-1.56027278784872],[2.6290795832007,10.5510381377275,-2.43388708056738],[-3.10128334143403,6.8795197317825,-1.35289746800846],[-3.22845384318909,4.8739729366541,0.496983670951844],[8.65277482813377,-3.92891661244622,-3.38512712702025],[-3.21403084553608,5.12765970837729,0.244081146537647],[-3.21810023508702,0.780188138556983,3.03740838902447],[-5.00662528705937,-6.01017251339512,-9.8681240607996],[0.438812833952304,0.281558505664824,-3.07369928454688],[-5.05912606221315,8.98462401065742,-3.92634414182068],[-1.98519415985478,-0.573174129526661,0.872440382534544],[3.12901781186601,-0.596567263005055,-12.0077784155381],[-6.43606102131549,8.61071282854919,-4.07763099193552],[-1.94682435689119,-4.05589004758847,0.361772463654907],[1.74800453208606,-7.04175713087338,0.462392219267019],[2.71403617778185,12.1633261261119,-3.13847776674965],[2.22314970959291,6.30342277947208,7.49853522792033],[3.19438838054881,10.8968771280231,-1.42968916850219],[1.48093294809158,-6.93794476178638,4.44426122138653],[1.05260826358474,-5.58894723018918,3.93146083535416],[2.59439171087184,5.51679968322554,-11.5734236166651],[-6.54034573915675,7.76417698113009,8.57700478540715],[3.10263878988591,-8.73968583283208,-2.47462485578737],[0.846753060294946,-0.648864361175628,-8.5270105351927],[2.59695216558736,-5.21758979355841,2.88812587317499],[8.00037360609432,-3.05755604805378,-4.85934984469015],[3.09330081117727,-8.92236125084263,-0.904133324589854],[-5.89461851679114,2.88649310540577,-5.86028878363703],[-3.18240326973452,11.160728533522,3.34148774471813],[-1.59707635658903,2.88062349524204,-1.97359361889118],[4.04231576668706,-0.94874819800487,-6.49723200653076],[-4.29495844080963,1.96039377633268,3.69770669162746],[0.933081559011463,-7.59964376793759,0.760413431176739],[1.92942700128137,-5.79863336840176,2.20455647882431],[-7.89999019651851,-0.42575447383129,-4.6822578086797],[-2.75410581871051,-3.21581902255585,-7.50576063211572],[-6.20727202353437,-3.59341351428399,-4.57846008383199],[3.40980728240396,-8.23975424603884,-1.70024240005857],[1.90204200861008,3.53817070163959,-6.2565673499637],[3.22637617373996,-2.40452854644135,-4.66675863465708],[1.59980276554759,-8.44014317079798,2.13691819797171],[-5.34716806017487,-0.444950423987833,-0.0301882424249802],[2.78708526563496,-3.77724377205124,-11.0175350138747],[-3.66198818177536,0.742177551942622,3.09825690621017],[1.82087492600994,4.35030129549502,6.96560981636804],[-4.93809668881736,-6.24639849534395,-10.0335355642796],[-4.93646994960417,-0.747990465774112,2.00842461115456],[-5.56213278841222,-5.11468233134679,-3.73401361166095],[2.75499250524373,-3.67987534718129,-10.9705866001499],[-4.865985093786,6.39954364541357,9.04920210306656],[-4.15883260044556,5.94237483051233,8.4907650348812],[-5.05888611080818,-6.15379615911912,7.94087519237223],[-4.60269848610564,7.16766083487628,8.3940607500475],[-5.7381343718825,1.39198093134383,3.8611113893199],[3.55549654289487,6.16377643416274,8.92826352011385],[-5.85949774247017,6.34016087900607,8.91540442970681],[-2.64365767438583,-4.19142668381906,-2.27933420933996],[-2.73823489752211,3.94501978220553,-6.80262988048145],[1.94834507837425,-1.69605767023556,-6.94149392555865],[-6.64938649782815,8.59279717964487,-3.76920330846856],[1.46257580540895,-6.66553625391947,0.062541436854233],[1.58316633505545,-8.87946180430781,2.86753145051353],[-4.12763224002475,-2.52155586804226,-1.38037359957495],[2.19425844589973,4.06075970534263,-5.32841496618239],[-4.96816510678036,7.42613964131157,8.28892256227376],[-3.76312322509701,5.47918680686269,-0.284700448732292],[4.09851529653569,4.20671501531446,2.75595813763808],[-3.49304820434928,6.81944803974004,0.035092467874389],[-9.03950132468063,-1.8413183582548,-3.92565087749517],[-6.54838794046983,9.16775118476578,-4.60917179074963],[-1.29906924689596,0.371011178758517,3.0173574699443],[-4.48452898070196,8.50075627864402,-6.24794229505473],[-3.54377106287417,-0.592938804499693,2.54837720664258],[1.89483279943843,11.0328786677246,-1.69953597897565],[-4.44293263521101,5.22933064447183,-0.100810417170995],[-6.25118859419209,-6.49258361818397,-1.01553333418153],[-4.65819180215151,1.28961989078228,2.94422957402026],[4.2906895715384,-8.10728788846853,-0.762839598983529],[4.18462749510593,5.54667357139044,7.72668190749847],[-2.95326705175999,7.93400545369757,-6.08199366319651],[3.11411567396728,-8.47362026129883,-0.77835796799591],[3.84844245465301,-5.09833743010365,-1.84193416655421],[-4.44219687350219,-3.37014669430228,-8.9593477430914],[-4.36779978639684,-0.0668473852459504,4.46915150272771],[-4.30268233437612,2.69214210157564,5.29366946680694],[-2.14238253581691,4.58693473720337,-2.38093701446729],[3.37734484853602,5.23792558444504,6.62305827208705],[1.53341065564959,-9.22179826675915,1.91945084810201],[1.81918856529333,0.337089105685918,3.48694104005026],[-3.92273694733637,7.0518095696513,-0.121373482064868],[-4.61173130671891,5.35954983345775,0.0950911372026278],[0.957873219199258,2.46654942218029,-2.66339872254332],[2.20024016717936,12.0010491051051,-2.48013743632326],[1.67457879860935,10.7662130968337,-2.21676340943433],[1.33872338117961,-2.77066110260701,10.6119520311386],[-2.869699021306,-1.89448159677614,-4.3061105779179],[-6.13055932112544,7.75870548182956,8.64069944732148],[1.70126442109115,-3.84477424098752,13.2007877853209],[0.802473040120619,-4.99596679799319,4.44148583719374],[1.11152910412079,3.70201519793436,-6.59528140664779],[0.332567501562346,0.904635836651661,-6.64409803074535],[1.82594027425731,-3.95114525355933,9.70391433759898],[0.839032160723218,-5.46649922258748,3.9775779453374],[3.53456130717096,10.3988089615767,-1.81635442459159],[2.06097120950728,-7.56068160705162,-0.10399520864378],[-3.86340243974306,4.32999743362443,-6.22361141545852],[-7.79051573612055,-5.91580678542405,0.0112220450119686],[2.89059036838426,-4.47204260530852,11.1077813133639],[2.08306602293731,6.13004317247626,-11.6632235649129],[1.14699082311279,-7.03932965201328,-0.115378901823278],[3.73879143128368,1.29760488740647,-10.0427633587324],[-2.50378647767176,-0.617749377816298,1.19894660289333],[-3.84105454295193,2.21690408199815,4.5217017215006],[3.20088696614985,-0.110198738366516,-12.6371810895345],[3.665801250067,5.09098117177771,7.04725351557208],[-2.47983974952862,6.88887813771674,-0.575010208939942],[3.50392834240413,-0.35003692880863,-2.88680044816511],[-2.18223241001588,-1.07340595541219,0.912589074563916],[-4.45256243287379,1.16302059353078,2.30142789234792],[-2.30468240203277,-0.536174080934466,-4.03357236122655],[-0.359001995718374,-4.98265380903642,2.8859783861913],[-1.86795315858007,-0.737352838174882,-1.74694203703793],[0.985802006915228,-6.44613581511334,3.76010378361112],[-6.20657079880633,8.97547584708216,-4.10171307535098],[2.14898417590856,-9.39927402896756,-0.423230913631362],[-1.00707321673412,-7.04708307735396,0.714866462108301],[1.82602661551432,-4.53555564210963,2.90957757196827],[-5.09006297712568,8.0346658502237,-5.07227480931164],[-0.294110861494382,-8.38671576041974,1.14984918626471],[-1.22414166714293,10.0908203230763,3.26094469703136],[0.353021849030211,-5.46671665636475,1.41832225337724],[1.62548806873157,-6.36560053626894,2.94645986511581],[-1.09502508146181,-1.3940295538026,-2.63580634682609],[1.78782829932047,-4.70527488770864,2.46247471901884],[0.61154696519688,-5.72542175827663,1.54677436026779],[-3.3193179602784,-0.840460586628194,0.297947025632784],[3.12331193418792,-8.54614939400501,-1.80603930740575],[0.388108579771878,1.96263695062364,-4.04402239250678],[-6.22620233854842,2.63342564977583,-4.98759904444874],[3.06145042322076,5.88238768272792,8.54655905801342],[2.36911319919753,10.7041758335258,-2.00724413244443],[8.49335466651512,2.71167024815294,-2.18949253989858],[-2.09083759652104,-6.10032827316992,-1.63846389072649],[1.24917938789225,-5.66676758462613,2.7714632780117],[0.973433917311236,-5.05587195866008,-1.31868069837973],[4.8473416645164,1.76921101102531,-8.49915649724409],[4.59367502850778,5.64475253013871,7.97254724465857],[-0.112193622600347,-2.87215415035888,10.2947288191615],[-3.00796869205083,-0.697921248695503,-3.79622649396208],[-2.02347998188045,8.97331411074922,3.11869434744514],[1.57095171774642,-8.71595318853776,3.18448143284405],[3.00690035164823,5.44296791176208,8.97684277615648],[1.44979063383856,-8.77835548007725,2.32868543369865],[-4.13865569798507,5.3689112083423,-1.92160792918818],[0.878272841265574,-3.29607322564749,12.5245023292691],[1.99003722529244,-8.86600837554873,-0.18838053576514],[6.63636734656879,4.8727042310404,0.442480539666499],[-3.99705150374872,-5.39082016244254,-1.76932026621348],[-4.99275676069206,0.0107138840121015,-0.196154709126251],[-0.890857761320859,9.91273458057152,2.52841204303129],[-4.87796818578674,-5.96694037221072,-2.65031757692933],[9.24348448370015,-4.51691675849111,-5.67624865575286],[2.35979540596006,10.8192566924537,-3.35196809410025],[0.327677593780391,-7.845930826829,1.50818040065513],[-9.38850537840913,-0.947970433076445,-4.02717403478465],[-4.13035150851453,5.87589096712419,-0.0530713144677146],[-0.318376829427648,-2.88466416825457,-1.46902738091151],[3.39818526716398,6.00453650610951,8.38781406416971],[-5.59217793255687,-0.387822970796645,-1.38548908363539],[-7.73284944642534,-6.96370500136189,1.34571259998922],[2.99421173570108,6.47879490792642,8.52617533358693],[2.73101401046532,-6.46047711860556,-1.4698697015827],[-5.14976123298937,7.20171271699818,8.27492252333036],[-6.30541564602126,-1.61655101420844,3.7564922845234],[-0.0375314397489022,-2.99720591886996,10.3674207975611],[-0.763765686130611,-7.76502297600934,-6.18934489634952],[-2.07206305620982,0.147632323943947,-4.99927244963514],[1.44494565232042,-3.61469235285171,11.628035590715],[-4.86337049385525,8.75395330377383,-7.46952273009422],[3.64567615622956,-5.20039689978711,-5.47094983845872],[-2.97782529445004,5.73524282402136,-2.4370036658448],[2.33790033311678,-3.17770090100633,11.0770616906119],[-2.38528145040468,6.00924477506343,0.300208967513272],[3.68404893756617,-4.31698308498311,-1.48129927331073],[-4.13639339035792,1.3694647413324,3.68968442462315],[2.94826855419888,5.40054167690525,7.2233606302018],[-0.589441306693775,-1.87227781256566,-2.63383385075472],[-2.00552523499929,-4.35154683482559,-0.277162123813507],[-5.5389058264173,8.53327233682679,8.07793768239261],[-3.17973193646798,6.41277592705537,-0.329952755213128],[-3.6349217587436,0.56996960055183,2.97855520505897],[-1.55617547980801,-6.02166092169631,-2.04121369848214],[-7.47023601689644,-5.71079609366798,-0.367812092173068],[-2.84791846373832,6.08722257545374,-0.62461139312507],[1.60222590537891,-5.46862246076561,3.35041814180664],[-1.99451878746855,-0.805429838470992,1.0874282084546],[-3.91584048869115,0.429957540757437,5.66596574710454],[-4.98561628723099,-5.7031945715958,7.97672848950679],[-6.62473739824687,2.80492680941541,-4.25349974371663],[-6.80441845430849,3.02508713252138,-5.52011737495096],[-2.51627859930101,-3.55025321875892,0.252558747266768],[-4.76023821318768,-1.05237533771872,3.01509150065851],[3.53604935995489,4.13433039676976,9.07010774623385],[-6.40637935924897,-3.87038580679852,-4.23334334116637],[-6.11036508983061,8.08248100763656,-4.34262116241274],[1.70044243659644,-7.34288831243208,2.85997734503237],[-3.91488889254457,-0.318252985730165,-0.36099907682782],[3.74291869297092,-3.43902452737022,-4.17765711464055],[-1.5761737830431,1.65046578503567,2.45701209517883],[3.11014007984509,11.1420483604326,-2.23729921413374],[1.78614443146046,3.57309090827825,-6.15974860441451],[11.7962383701567,0.821638348972799,-1.06720048486578],[-4.62855185201049,6.70673393900879,8.67030908763625],[3.07222501820995,6.77205071400299,8.41721472629249],[-5.58790478813666,-3.49943001475654,4.38369374423361],[-2.86250372485878,-0.827690233235394,2.89507218863767],[9.00779739538206,-4.26200318458946,-3.7635685489863],[1.00758859800446,-6.17646016293048,2.73964799014526],[-8.26712005877689,-6.51461649232705,0.888494454799746],[-1.99020843361388,4.21598911161719,0.282691654512754],[-0.106526735907505,2.20822320018594,-5.46854306058776],[1.18775157588117,1.8864630512021,-1.92412645834553],[-5.40572243114112,-2.71560256756207,-3.64257066722665],[1.2338509858433,-4.6460498202199,-4.98115110468594],[4.78647487872744,1.82390196286613,-8.57846637228393],[-5.43472052301838,0.863592716208018,3.8115131778712],[-3.56108022344922,3.47017230368932,5.50416681659904],[3.61657516229369,-0.604709325790113,-2.78347533060677],[-2.33260923006046,6.34255024874377,-1.83961817598169],[7.20104884874396,-1.49042869038478,-10.5905772957911],[4.037080403481,11.1918451568849,-1.21016292489918],[1.57811670434009,-5.6795017818981,10.9552368496183],[-3.90708578664667,-5.95399554131534,7.22893719593151],[-0.33976689572704,-6.42505800194822,-1.1113875731224],[3.85215661454673,10.2907055382421,-0.87247668016711],[3.7579735768081,-8.0570118575165,-1.84757650141364],[-5.74760520667775,-0.61584164644485,-1.58455481514307],[0.123112835352664,-3.2052233784616,-10.6756177989281],[0.614098218389554,-7.5897273654596,0.567244820996918],[2.36595549283966,6.32937016719648,6.93654052853666],[-0.342284454161955,0.170173349164364,4.31035880103058],[8.1655424134615,2.1816157149236,-1.51456193973546],[2.03431551058545,5.25567072463927,9.27180527940253],[0.692643894893586,-4.86194813898598,-5.61661530309583],[2.87106752920902,11.2755028645369,-1.57507345712766],[-2.30069285950378,-0.271415946240378,0.299440210050852],[1.2953924538073,4.42661316686018,8.50791204556774],[-1.30012103571565,-7.83590086325651,-5.57042922652749],[1.80765178627057,6.44874694115176,-11.8311715660989],[-4.57459908102217,7.9950698726508,8.93174622297594],[-4.13790670086759,-5.34875635857321,7.67731083838875],[2.18602648548881,-5.8462721731282,2.45086572911476],[10.4591406562024,3.93309190291381,-1.64859982296964],[2.06150402686703,4.80286487982218,8.92961645021542],[2.68374970510028,4.48591400569985,7.82980054099758],[2.37105855573148,11.6728528643833,-1.35390292528466],[-2.50176324494078,-3.50969050217825,-0.22310749951446],[3.76657292945938,2.30531810366146,-10.376125236282],[-0.383860188018392,-5.32901247687483,1.74959647738367],[-4.2656590272524,-6.19758234775478,-1.34321084175833],[2.010531301864,-7.43658968993834,1.85908981171207],[-5.40641113362198,8.93380599681272,-7.04716755633788],[-5.72314744690276,1.30815895573533,4.1397765137252],[-4.31267112984951,6.40679055673024,8.37441620125609],[1.17557425152293,-3.34259417264232,9.3168456715341],[-4.17999706809426,1.25443970461363,2.1154172171413],[1.60372652628571,10.7511870783167,-2.30673039138865],[3.91060056110287,5.43325095144161,8.0767871153895],[-7.90288177065263,-0.288192828166256,-8.23434545576921],[4.03479784668547,5.83058621075473,0.332296720755808],[-3.62908722320089,-3.10763607950044,-1.75996939380772],[9.78560680886267,3.710146784999,-2.12674628886575],[3.35686561166129,-7.66215130090685,-2.17725657059094],[1.95543100608267,6.06469567546933,6.73813238527146],[3.62362947216893,-9.62746349801722,-0.7617862427969],[3.11512365232131,5.66571864549332,7.24492501608022],[-5.54424035344941,-0.774601568867057,-1.63370537299591],[-1.67988367378526,-3.20856806224892,-1.45483284116922],[-2.77638032791112,3.87323945215372,0.418525831299943],[-1.55316371010917,4.5261982435674,0.573040158191397],[-2.64344301758676,-0.00437080408518231,-0.742393598433505],[1.41325943200824,-7.61400241017967,-10.3859230180062],[2.1438384297355,-9.10154337348318,2.67556476669655],[0.975047081635067,6.02483119280523,7.54785522111135],[-1.6790711313501,-2.56356831503909,9.23848087553153],[3.51840271261265,-0.663307203147613,-3.37176672688536],[3.85984709106752,0.840989176887407,-8.5992111700704],[-4.97923079553163,1.25798107756872,4.27211257262122],[-0.21806125493595,3.02598508180519,-8.33632893755572],[-5.95018411675183,-3.10291118152866,-5.02235431824489],[3.2480452166472,-9.15188348480691,0.0883806639348675],[-8.63436971113335,-0.0866947166601517,-4.67195331642116],[4.08393654034656,-0.123772739165788,-3.57532446470829],[4.46632064409033,-0.792805394027606,-3.0688337412035],[8.40654940584491,-3.55694278448895,-4.64254681091745],[-3.43646905424786,-2.19375525317647,4.4524458614371],[3.45347974458312,10.5556701913831,-1.41946601687014],[1.28795985818252,-5.8455670699386,-1.47876010101155],[7.45556108748201,3.72354948470774,-0.275661980052654],[-9.31703855051326,-1.48266713122622,-3.12015669418142],[-6.05891429462348,-6.23103678698717,-1.09081124594553],[1.85297047714704,-5.44010993341378,10.7410886688502],[-5.94591728451117,-4.15180823340398,-2.44090333630477],[2.98373366549267,11.5837610537481,-1.87797091167873],[4.57439761252208,-0.00179105354644382,-3.56572823758391],[-5.74918390172773,7.63943442275575,8.71206290966554],[0.688532852255428,1.57735070232838,-6.69948817761783],[-0.76724162691897,-5.69369649936039,3.54568090808198],[-2.07193922457777,-0.503962606356799,-4.02973614222585],[-4.46851904347858,-6.65323527759106,-1.96761514543823],[-6.04482715111761,-4.13040242644306,-4.20845547641184],[-8.74983625000765,-1.69696518571603,-2.98052418610857],[2.07297562169734,-4.96792252072896,3.41634255005825],[1.72115796904623,-7.22078402441275,4.59652166195316],[1.96946608048176,6.70722637986189,7.15035687413858],[4.2319604548683,4.49456345954667,2.91329188299892],[-9.14087141379406,-1.87767461221664,-3.73376285328396],[1.93520774832054,1.73499861563443,-10.3491516811016],[-3.81782617297688,-4.80691293907739,-11.4999669104053],[3.82208736901281,-6.30545433327758,-1.48394290779973],[-0.256039602989345,-2.72685052832671,10.1520827296278],[9.19288153380448,-3.82520230259192,-4.94716784229158],[-6.4011985609562,3.58967820608803,-4.04627373029697],[3.70214005226693,6.50980540604741,8.90493142828984],[-4.17749228717027,7.67634711209623,7.99668951059338],[0.114773562359271,0.667045200179633,2.85600198809522],[2.60365234180074,6.69728917207295,-11.4417991050652],[1.52153516385991,4.87387354261602,8.20992346005029],[1.69480337585728,-4.36146451499807,-4.82218078182092],[-3.05123645201854,6.86328690066127,8.96200749619494],[-1.98225420869458,-2.7353629214159,-0.882100302901736],[-1.38583122628374,4.32146858312215,-1.29807554302891],[-3.57673694489464,5.45561351399638,0.192316084108792],[9.34103396138861,0.76174869229717,-1.80012256366778],[-2.8451027266705,6.66766164279125,-1.66579681868546],[0.816679396821181,0.245123891651538,-2.4660323014501],[-5.99501431460297,7.14041347456648,8.00490053253424],[2.38714767079704,6.70180031372272,7.61176248940841],[-3.94168603726574,6.49751917759976,8.71327102042964],[-4.91016458369432,-5.85547763795169,-10.2698278335288],[2.61727645728195,-9.2645556822403,-1.83952848528909],[0.746109347910672,-3.30776175810833,-2.74908062915357],[-5.91811023770466,-5.87808741671782,7.53340904183855],[3.11089846379132,-2.89878877436667,-3.21736898213057],[0.485545323056529,-8.06843713064679,1.24576627595082],[1.6667174662507,-5.9632785468485,4.94276443174979],[-0.513214505062288,3.18735419541769,-6.68832735328628],[-4.75188163413907,1.63729996619905,3.02220515578115],[3.39311961053379,5.81965945650394,9.0203466359409],[-3.61150535013693,1.57791605351767,-6.00844370205323],[9.28843470187604,-4.12001892296466,-4.56619713920233],[-8.55136578096572,-6.10647188904085,0.786470710293733],[-3.96407946149641,0.954996380252917,2.40063786646644],[4.19651366002429,1.84944120635918,-9.79961488446568],[-0.613790820249347,6.22327783853904,9.05572131713701],[0.693500932713424,-5.63213684567786,4.60988393445195],[2.43064257166593,-8.74344531798479,1.11477124842512],[1.58462239117531,5.71780607500957,9.04216211718239],[-4.65069051759238,-6.769701295408,-10.251305544978],[-4.45680558162716,-0.810246179050182,4.04078797647339],[-2.60126676723114,6.9357096650991,-0.380793056779393],[-0.512388954516863,-7.2255888711362,-5.95415969717068],[2.79816513759965,-1.27031877144597,-7.49037973738252],[0.428544344129764,-2.93634256979598,-11.8090303817671],[1.27203920857267,-4.23821570281285,-2.57004612622168],[-3.68867141466678,-1.88122301730916,3.65681464444079],[3.13398315687745,-3.90853331797526,11.1857776274635],[-3.48683865378452,6.83727773164387,-1.04643803561888],[-0.989899095274638,2.03892490860595,-1.74306107425543],[1.4684966971292,-9.96496899325445,0.670173766488092],[3.73265388078055,-0.977108922469748,-3.15504615614004],[4.11442662434981,2.10660405289705,-9.67803673579331],[-4.51380004850672,1.69311661371481,5.27935487520187],[-3.02899968101454,-1.8840123571685,-4.29149871757175],[8.37262936945542,6.1723667352195,2.55854382413273],[-4.70932667418671,-6.42730462428509,-2.07629481535147],[0.734623932576914,-5.96877961875574,11.0527847528269],[-4.65300828371851,-0.592838697050031,-1.63964845717556],[1.11202461182032,3.36890669851894,-5.86057714912152],[-5.06271629128354,1.11075384423449,2.45889042091121],[-9.16091879990806,-6.24986788482296,0.829477110129539],[1.6441330314675,2.94279777970503,-2.95596440805194],[-2.42280669439712,-3.33157734892681,0.287679955233322],[9.46586360058031,2.39870828326201,-1.11063663743757],[-9.45623211877329,-1.79318126082232,-3.96625326667523],[-0.0325549052420888,4.43299693163424,-3.38486177408796],[-6.33859543945324,10.8103319797406,-4.20026535358695],[-2.90143189243437,6.48060207208555,-1.09337252011454],[-4.43496436042027,-2.84024035585753,-2.8849073382282],[1.09552175131291,-8.73397558983618,-0.233871077840838],[-7.57074352627056,-5.64977566965489,1.98718212448285],[2.73525401012287,6.62915281694675,7.72726713072282],[8.99942539692094,-3.67708755794272,-5.29882567950958],[3.84625271619067,4.49818614743252,9.15948744768844],[-5.43801624410765,9.4519251069445,-7.22823106355362],[3.73122415023483,-0.693735567979965,-6.34732181835876],[2.97363644552873,-2.19290910083074,-6.69134125528403],[-5.42703498654927,-1.54433869230061,0.592596347244774],[-4.04355561895205,0.110942905131467,2.58816098384518],[1.58891734004424,5.57312092088262,8.11019795185047],[0.0811438285679785,-5.2021209935111,2.22771400877814],[-3.67452862988468,-3.01232291986844,-7.33911628281577],[2.09734602715955,5.08274537291615,9.17435233367042],[-4.87842829912002,2.12027191897133,5.51604004944846],[1.83217582444489,6.56362680563127,-11.6973372223389],[2.48510672306944,-3.48747103182307,-11.1514508210595],[2.16750993172342,6.35484565082001,8.8424240962905],[9.96599677680185,2.48137554385292,-2.72844782138666],[0.152636229337972,1.28591540107135,-5.93615405317939],[-2.1033022136029,5.3486391898108,-3.21283946744537],[0.992190466918593,-5.15480806728598,11.2109000056082],[-3.00103200412502,3.55671001050188,-6.46326300623407],[1.82322549664026,-0.147543345028587,3.62991147951727],[-3.71210672536747,0.986583244219817,3.42813651834694],[-5.11433919958969,1.18535081172651,4.02128732938079],[-4.53959725205878,6.03534155392264,-0.757260822171681],[7.89037899149671,5.88482100987083,1.781672138444],[-5.87343034745554,-0.118830314478191,-1.13249201233312],[1.19568913166082,-4.22194056062946,-0.510519952129392],[2.3566235246594,-9.0840351632973,-0.296563575464353],[-5.10844026502528,0.865144659581031,4.61863401865701],[-0.202979003312627,0.595762786234749,-0.228533565476501],[0.440325965386745,-8.41179347336067,1.24453018803222],[0.141109358466634,-2.53284314537968,-9.60593500448576],[0.652367396452705,-3.80345144804677,-1.6514504493678],[-0.879792207286444,-7.93308187215102,-6.175711894714],[-0.489631373647953,-2.85455605096368,9.85836983942843],[3.18898457623724,12.1998797272983,-2.98232151070944],[-4.88985422721568,-0.486757144634426,4.83771136998669],[-6.20934962467097,-4.06931815798198,-4.28414667963592],[-7.47896133693231,-0.660687873408216,-4.57853514745664],[9.52301641413429,2.59687326825865,-1.95818473044785],[4.08946820304263,5.66953153027019,2.25453091825535],[-3.62544018777717,3.67483878207294,5.64018504271342],[1.71607223039279,-4.41981764791454,1.49206039292129],[0.92360140317917,-3.4993207032148,10.1908871537352],[1.06951675100849,-4.98367095185943,4.5540940368617],[-5.9245694759428,7.33325215026453,8.05822621589355],[-0.102619390817357,3.79425299789268,-8.67301273101318],[1.92626398422482,5.0889981903429,8.47431520699549],[6.29833373556033,-0.589710391640848,-10.2846164012095],[-5.17393791580393,-6.4921086449425,-1.17580082433483],[4.32985433027516,0.139183528012834,-3.71614408714385],[9.65116889542342,0.197487163378778,-1.01098346498543],[-1.73058407217973,-1.79093129223565,-8.64871545600795],[7.57150935811507,-2.09840501566422,-10.472746621224],[-5.64249597376529,2.78170866468544,-6.7955494907395],[7.4872339893529,-1.40989876147389,-10.8205385455807],[-2.99530627917716,0.546438589466638,3.21268784925272],[-6.24568225945918,11.2917484782135,-4.28652914303759],[-7.65010684170098,-0.537010545575672,-4.58243973998423],[3.13472513800195,-9.54464596333079,-1.74664593767035],[-6.59549823227604,3.11641654191375,-6.08099134717892],[5.60978376802594,2.57418655243656,2.53581672676785],[0.818248387434092,-5.37602020618381,10.7778729623284],[-2.7714649977783,0.567555608741284,4.00458606277934],[-3.20013107334054,4.32005353754298,-7.68872253569891],[-4.40590602130094,-6.11136644900171,-2.1776419033914],[2.12780448618156,-2.01270531292235,-7.77828513530026],[-1.58262697468832,9.8553891309431,3.57176015496519],[-4.37722712028832,-6.482670416565,-2.06298090376449],[2.69912050962108,-7.16080539033279,3.79643730103209],[-0.31620008060508,0.955303754244116,-7.57432170724095],[2.81212444344183,-3.96290175722087,9.93337472770572],[-3.04842561427599,-4.78214788553328,-8.40870566889534],[-3.83736723606234,-1.34102182824608,0.982398537721014],[-1.41127258384767,-4.04976181946229,-0.81484476877366],[-6.43586056455453,-3.25304124953227,-1.47387091156843],[-5.12147946944019,7.10067875409348,9.15444218744673],[-4.09123249838721,4.02299136127647,-6.96628489172372],[3.36076238761546,5.35716252974287,7.42434707176512],[-4.55337994684185,-1.43734655204149,3.94327349103858],[2.00405822676923,-3.06776035827528,10.9249414923217],[-2.33452673353289,4.88791409219158,-7.01112440789867],[2.83207807830469,7.04228831994118,-11.4229145251476],[-3.05282357940424,4.89041385480251,-7.1225089081015],[-7.23602976752614,-5.7599036806204,6.94694976934335],[-1.04931062599206,6.07745081022561,8.75543750775924],[-1.71184192836136,5.73101769621573,-0.0419108621862857],[8.8596935822798,7.07367768472603,0.485801739244254],[0.212780028587315,3.01537753703379,-7.36254857004606],[-2.55410576111974,0.265553005227224,3.83603755648957],[-4.22704932166528,-0.510403893542709,3.34646326234082],[-4.84136360972491,0.321515288416876,3.98311198534196],[-2.4712723807452,-3.35855163526913,-9.13465931191784],[1.88955891027479,-7.01794444930535,1.85360130631183],[0.363279615342593,-8.7499962637954,1.42550886753095],[-1.38801698039198,7.116517787889,-7.21301010767885],[2.85510212004846,-8.58396015109137,0.295918679138671],[1.80569192942171,-9.19703319082321,1.40271657847054],[-5.83250393806484,6.82615750726011,8.53183305158182],[3.03370290575386,10.3117055810673,-1.95806192362436],[-0.301570998429502,-7.85184406915483,0.823055453457844],[-8.28436777351378,-5.73488679144492,0.757363703378544],[2.8288833979918,6.34921258544402,-12.0392556426883],[0.356904141499369,-3.27921893066915,-12.180527998205],[3.07047284333519,-2.40443507005947,-6.55537118792076],[-4.32138904850976,1.2084880295299,2.31299489903159],[-5.31026354639921,0.214607780752794,4.57208468043012],[-2.88232040804873,-0.694386784509543,3.55170826041657],[-0.564070088036833,2.78437658660763,-8.15588436519287],[1.82604929238926,-5.41607450124821,2.36643244901005],[9.80122791920497,3.02683155425508,-0.729977914044314],[-2.79054031175509,6.79620292763013,-0.76163558770427],[-3.27330052409401,-1.72266817565171,3.69898010509772],[-1.85940080819188,-4.84582567506843,-0.494021238574834],[2.06885787282846,5.69448611415854,8.18259384115393],[4.88315150913801,2.14419249278623,4.2599336904657],[-5.58959234447309,-3.52760758004399,-5.43495251571234],[-3.73496366665397,0.16689712903147,4.6939876824922],[-3.73952411476526,-3.42715956432179,-7.73020803237588],[-1.90354149793867,-3.22366822689459,-0.391005450427633],[-3.90054660760518,0.397443097877872,3.84972515187461],[1.29713723925155,-7.28664541125242,0.440309171651754],[2.52350261565174,12.1175567043153,-1.08687085517274],[3.24601158846627,4.54559801329214,8.05599105080509],[-5.3850907691029,2.49017649981224,-6.14116375943556],[-4.53445630582786,7.77748424888706,7.53542324777275],[-1.20531459967441,10.0704428455729,3.33063479798096],[-9.2551116755136,-1.45150072532396,-4.24389918260072],[-3.57003763419076,-3.41411620687982,-1.21790933662477],[-0.0491645553065109,-2.58964209665951,-9.63350066066625],[3.46746969216009,-9.26046135891136,-1.08733576088932],[0.932859655602104,-6.304149280252,0.448970525499852],[4.27316395938332,11.3559727389101,-1.28735382715382],[-2.34196151261395,4.04693190228883,0.383151652634524],[2.99858410077788,0.140404044706774,-11.800718855847],[3.18136896842801,3.86458601622484,7.87752652934646],[0.935099691730939,-7.38447701579329,2.26402249191428],[-1.88255713895097,-0.412307137508846,-4.75884170049359],[2.1209062917883,-4.1348049018555,11.5031588300926],[0.543505962016512,3.72330987782086,-5.8766751798179],[0.589668126962009,-8.99101287756297,-0.0299684814142436],[10.5529171317815,2.43798069995461,-2.54248592855439],[1.4620920995803,-2.80811627416797,-7.60205747389688],[-4.99789607474833,-6.87787012263331,-1.89562333636544],[-0.741739253745238,0.74675995052024,-7.02522277894422],[-4.41948928338608,-3.83012885996012,-1.62284568572936],[4.65790324383516,2.008847106048,-10.0762267700272],[10.4488501604466,2.20885643638724,-2.40284601185514],[3.33269338893794,-3.23683583843441,11.6817218547777],[3.39308636315557,2.75227601932037,3.02756633163595],[5.82508614944333,-0.417575464867183,-10.0199443822863],[0.554380018511002,-9.23945072292169,1.38944143496178],[0.139809913999692,8.9650896911001,-7.74505832933193],[-2.63001542689421,-2.72487610643046,0.0587645566983211],[1.62001600091777,10.7094613664197,-2.18750813233993],[1.00151125697715,11.8946057742313,-1.69243795218634],[-0.205671783285237,-2.52493110158013,12.5489233688768],[3.76162854281979,0.482917599955158,-8.7398189159365],[1.99723616960618,1.73760600502009,-9.16511215065674],[1.76770336870769,-8.55943140822233,0.363728131258368],[-5.65345549871508,-6.56266553388599,-1.94658854767322],[2.23436344006471,-9.42311306472029,-2.19740282686258],[1.79717452880633,-5.27104226289135,-6.14848985506661],[2.11759120028681,-2.28374745388558,-5.81748385699151],[3.19123872881805,11.4959767968168,-1.4195503728747],[-9.14814913180642,-0.678213731571088,-4.53381817997774],[0.958712842479829,3.82561412324592,-2.9897168370628],[2.18828934671626,-10.3111189473752,0.110731203133399],[-2.08259805353915,5.66534648221493,0.610288897465762],[-9.47940333866344,-1.83872148123201,-4.21612437225723],[9.24259463205717,-2.57276410752135,-3.58890696196922],[-2.39330117345202,-3.4448180462961,6.64813461594214],[-6.70993113080068,8.81748127701579,-4.14919834866659],[-9.26059703545004,1.15224445217216,-6.22934990791792],[-8.9389575316592,-6.14833196343792,1.12953979536136],[-8.94172260007779,-0.755203549284118,-5.57944422794755],[1.28958146083249,-1.06324907909578,-6.88366264492594],[2.29855201614778,-0.274264222654717,-9.82955535705064],[1.0166150119522,3.87228539205081,-8.67296431498677],[-0.944043341589202,-7.12126545486935,-0.946578931373393],[0.697763617365888,-5.59562393672154,10.8753874409185],[-9.53146016735455,-1.16142354365879,-4.3071151800925],[-4.83253775718871,1.18050254375583,2.44974845500513],[1.86399095006993,0.293960307235723,3.49620204149793],[-3.46929043855923,8.31618036513814,-6.00336696485337],[-0.914064207408817,0.584809520775409,4.18878780692552],[3.30405739105571,-8.2006090410524,-1.71299188234996],[-4.99182129123188,-1.35789045926294,1.56719997247593],[0.266991523176223,-6.76492858131231,-1.34335280810871],[-2.69783013684054,-0.919433620506639,3.59663966867999],[-6.01208419450941,2.72228122245371,-6.56955419103014],[-4.16895220938403,5.3599474562537,0.512720185545263],[3.20248483514639,6.23323824055036,6.89533114679615],[-3.79700230181903,6.03294488273773,8.52233266340413],[-5.92740913707398,-3.4143022513563,4.73766069879329],[-2.87946739604096,-2.83957378786341,-0.807278256081833],[8.16875853431474,-3.79520700349987,-3.42915501753574],[2.63284572960423,-7.87279253891206,-1.47547118995471],[3.13389875559439,-8.6621146778966,-1.40688820822294],[-6.55087736790432,8.58622992204994,-4.57074072499875],[7.46909351456031,-1.94692955807592,-10.5152570854579],[0.545355660574624,-4.15685560078776,10.6617490683231],[1.61668475108958,3.04228918369603,-3.02776751081768],[-5.29193507845357,0.90103233417486,3.26255974996785],[1.79753334107078,-0.0440781971054859,3.80010761266716],[-6.09413618180026,6.63676038244472,8.58641177888045],[1.21809958552124,-5.82644651545615,11.1011288522737],[4.2819043647336,-5.4879915367933,-1.23190604162697],[-4.3168994227019,1.0211751787644,3.6164401840197],[0.876282201827871,3.77285406022421,-8.73317517152092],[1.89495050707746,-4.87828562105814,10.5643865651715],[3.90770794800659,11.7346308992958,-1.62587893328408],[-1.57726109033535,-3.26238539664624,-0.78461308416511],[1.99061564816432,-9.09297684280338,2.03216077200211],[3.03437381086919,-3.40914460929526,-10.7573115196729],[1.16588011605066,-4.77890066876301,10.2498903064321],[4.39743532308631,10.6963318858681,-1.68720014085934],[3.80607597059539,10.9552109037225,-2.350529384628],[2.28956368891709,1.38613378895949,-10.4569288977878],[0.584541698516871,-2.43253063362078,-2.71259561520065],[2.79937211657036,3.29096579850526,7.94179885321503],[6.76462677408138,5.17205911988627,0.174909176574075],[-0.282609976820398,-7.76128064956634,1.06743412227591],[0.778619716734851,0.77158073453555,3.79529554780248],[9.44838402113862,-4.6947691384768,-6.13077270043246],[3.3810153393553,11.4900711561134,-1.63096998101934],[1.86667957559768,0.439826889189654,3.69405408101351],[-9.49698314317477,1.00796746255953,-5.79853463665208],[-2.71343731294242,4.12635554265324,0.822523969649018],[-3.61407113065888,6.67482278835237,-0.303763405890116],[1.8630407183004,11.0158802384435,-1.72181936058504],[1.54355304242822,6.56894465803189,8.03978203173331],[-2.45589858550088,0.342294304776843,-1.30132168544344],[-1.45437567406271,2.95858289426918,-2.38240548599156],[2.91109217964635,-5.88131172011913,-1.60715888774004],[2.38566600264014,6.69020734654659,-11.8453235689435],[0.595356145235312,6.30411339195298,8.77633959209514],[1.17166383444157,-2.81720972776007,10.5618525370416],[-3.53186748246803,-3.18577906215646,-7.85236361926973],[2.1950522972746,5.52884532409079,6.56535836157693],[-3.39653905055446,6.45497553773907,-1.14454301910859],[-4.582373543114,-4.10131712325194,-1.4041414245195],[2.71433035994244,-9.85920256110848,-1.87278270240866],[-0.970633065543726,-7.11331792688542,-0.592866169909878],[1.33061796650946,-5.50906614666833,3.97850117537803],[-3.83119907034066,0.17330260507048,1.79370875144954],[0.27585354497319,-8.78340045757166,0.925187865756804],[1.75762046972657,6.68477687321321,8.11652033822359],[10.6233640067593,1.83719745357624,-1.92208132008951],[-6.34224748036361,3.33759688354468,-4.4507438597219],[-5.24140898889561,1.14190966946622,5.18038255911106],[3.14743093162788,-4.42718201768035,10.196687301016],[2.49552871770302,-9.29688047744579,-0.301587427269656],[-6.76540940314686,8.58198454068645,-3.82935122736033],[2.04368539664673,0.0920633199158232,3.52595217207441],[2.7524503998032,-3.52733549011888,-10.9532063733288],[1.369003214535,12.0893419841806,-1.50328788092048],[-2.66520514359663,-3.84435180269059,-9.6628372244142],[3.18245037426385,4.38817582417161,7.81792218324906],[-2.29387034027688,-3.53551968447777,-9.59209386680438],[3.16134965378446,12.2996377192975,-0.772088562488608],[9.46837074656376,-4.49342419730081,-5.51360251037654],[-9.33171245520341,-1.3090398255516,-3.6229825928236],[-3.38461198080726,-6.27890297580095,6.63905299945989],[-5.36808192176476,-5.66518913193389,-0.700155054326295],[0.967019927630992,-2.68111602588256,12.8964840850386],[0.388187961574283,7.26145234984627,-6.19647051226857],[2.66382812508197,6.72612144329508,7.53515316022442],[2.05767930705115,-3.23890189812536,-4.74990756886625],[2.30246768721549,3.25140743073319,0.527773107421683],[4.31791152137283,2.41599065144531,-10.3217287695534],[-1.65348051095323,-2.89495768421087,-2.35603235062011],[2.41700727741509,3.95649333324536,7.82016712747767],[-9.09275633568433,-1.23601304463269,-3.58205460658893],[3.95207328213976,4.98721719396497,8.50938733451243],[0.666699357770718,-6.53294336536675,3.45722096031416],[4.94789300980502,2.00283380203008,4.47888061927125],[3.1340351593767,-5.20360668033247,11.1029331200111],[-1.80161990243808,-5.22310639852336,1.97386266629621],[3.45609108896214,-9.41708998505725,-2.04074471409133],[2.42241966930385,6.19993835182922,9.4663011518673],[-7.03975329209971,-5.74572929747107,6.9363226728427],[4.12667222502187,-6.15409262616679,-1.48473288966068],[2.21376791341095,-5.92063387333497,4.90162121227542],[-6.24912388365494,10.8561427623184,-4.34335300966748],[2.02706196944854,-2.75008073034029,10.3865526292991],[0.379395137469705,-4.70704162253987,4.18957556401985],[-2.50548250538244,-0.15006010739465,-1.03879702961411],[1.52608495122825,-6.95734523633689,4.11330296808265],[2.47850960828747,3.77439230951863,7.64006780321916],[1.23074394849115,-0.760759366416282,-6.24273116511195],[2.24708118426397,-7.19280427115498,1.73061307986234],[4.49537213272771,5.06545593085699,8.05667559571627],[-4.02312130584187,3.25895257927296,5.7623841799939],[3.4453974200995,5.73616018231244,7.69866247864289],[3.63048660077961,5.73823217386518,6.81178449276394],[-6.27244396305803,3.13804215975018,-6.20154813874084],[1.99422111046471,5.97849624231286,7.683362921893],[-6.31178090950008,7.42679254109532,8.73503832357639],[9.76925931407741,1.0059683716338,-1.37590234027082],[-9.44236658252227,0.256240931462863,-5.59644346435696],[3.50686482319781,-7.06597226351933,-1.10893690474101],[-2.79794898233181,-2.19828093002858,-6.26637891820753],[3.04107312447527,-9.1509063537186,-1.31587947697271],[-5.82351720601099,-0.935737903003022,-0.828876234206333],[-4.62185202576416,-0.0324754248488845,5.05292668808182],[2.77826419523505,-2.87783613764518,9.39495569475234],[2.41121971800642,-10.3554830429316,-0.711135454143171],[3.0335271349577,11.1194058337198,-1.96325764142723],[-2.27525899758608,5.01442427438463,-6.9784220391295],[-2.25314329559236,6.59727106670771,-1.51735308078251],[3.10332087806187,5.91822163674553,8.43811222906835],[1.19926375423344,-6.06248897683745,11.2434228086899],[-4.92420187723737,-6.37428101038503,-9.61624908822107],[-3.01502081021532,6.76411212974253,-0.935036977387047],[1.90981948784576,-8.01708292552228,-10.8030569085591],[3.11852264926631,-3.50969310210435,11.6810866341651],[8.88891493984583,-4.30253056212336,-1.66537988866202],[-3.87136250444047,-4.12651914774684,-3.04060020894398],[-9.52735017988799,1.26471036425851,-6.12299283894238],[-3.20957916760818,-0.434024928721191,1.64644161039604],[-1.89685534858472,-4.29758383878536,2.06855089947015],[-4.70498777061398,1.58469091638074,2.89190433386071],[-4.74523830553486,-5.91686467820657,-3.02913328333233],[2.82249014099043,12.2423967115331,-2.50010604751196],[-3.84114409831769,1.0026001173264,4.13746363759337],[1.27643807119776,12.1269836410513,-1.17396052564144],[-1.974058867585,-4.8955835170161,1.86706996759078],[-4.76135684464863,-6.63037594282084,-2.27914647751988],[-4.01491719060768,-0.643367342814259,-0.403919251048264],[8.7721278626402,6.89014259442318,0.395028158419491],[-4.73530272824099,0.0777893245342591,1.99295929263517],[-1.50019766432006,-7.79298064596072,-5.61369595520456],[-2.15095470849334,0.704661930848343,2.86416143136929],[2.90829942440585,7.02574412411148,-11.2648936181767],[4.54465955418719,1.22398082688274,-9.09782557005603],[2.07541640346309,-4.47501253019328,-0.486089316665489],[1.32289420986273,-3.62436507383707,-0.424752688378763],[3.23549955530614,-4.92859410678238,-1.10116425858825],[-5.58382142463094,8.00323512695262,8.94423895352549],[0.963061575907367,-9.41162638495438,1.99194537126173],[2.42373849074687,-9.72680714102816,0.569379067010946],[-5.0484198227856,-6.34547564269119,-10.1790904578098],[9.82090764364369,3.02266201445154,-2.49956853147467],[-3.68489614023183,-6.21630829956076,-1.64244682241732],[2.88781906471141,11.1881946581439,-1.87449655437115],[-3.14260053487471,-2.56074825283749,4.7597516809499],[-0.598959496686691,0.197013331742845,-7.55112779766264],[4.29570470468558,-8.71159243744588,-0.325535845568641],[-6.47576793981707,-2.72190316159751,-4.60084051271177],[2.26160418995678,5.91768880516891,9.49635554455402],[-3.55000380472985,-5.22478611316095,-1.47792402629742],[-6.36780030353101,-4.27016629834895,-3.1638769028305],[1.58274962918321,3.40820757656677,-3.71549652951309],[2.04010713990158,5.54043458153554,7.2836414554621],[-4.93076088826663,0.381181403440413,4.43607350493094],[-3.45825167089171,0.400541564303157,-2.1475989099023],[-4.97701901524139,-6.78554194679921,-10.3671216501278],[1.89181795345491,-8.09917854580061,1.63806570442219],[9.25912454686253,-3.45992631160665,-4.91306852056323],[-1.91519905154586,8.74329277929683,3.08944547745552],[0.379701971939134,-5.18907800708871,3.84667122559231],[2.1215023637183,-4.70479847782266,11.2055483382084],[0.585184125773882,-3.06248427653024,11.5579938729522],[2.4572986519647,-2.96004539866647,-4.42610098522504],[3.30180447012107,-9.31066334243052,-0.369774020622849],[-3.96561296847148,0.294235582826875,4.54139333417538],[-3.84271371199726,1.42621834634025,2.34027242792491],[1.70154796632058,1.53903468637384,-5.10490638792211],[-0.531644205114619,0.744000320731809,3.19239252014575],[-1.051932658499,-7.27612615184209,0.104616455124849],[3.50900072589209,5.95436364202504,7.53772990258437],[3.052109649332,-5.83781028757874,-4.41636862992541],[1.66982916683691,1.51475132036578,-10.1472186837106],[-2.5988424221775,5.60642661430312,-2.40146402192417],[-5.34939308762165,0.123132148874133,-1.18681960644876],[-2.83109936416851,-0.642708984746788,2.88784154597422],[1.38414648684322,3.87161130883921,-4.53824628291034],[4.10962804727375,-5.38452524570842,-1.48559902569467],[3.44072849425917,6.18260474429417,7.48437085892774],[3.28396349683588,5.82584790229672,9.08810375842545],[-3.41570584447427,6.69953837592003,-1.43554801663895],[-2.4138559248315,5.90428443529647,0.419868008702198],[2.2278657559441,6.24627029518161,7.69537674825211],[2.95817780041151,0.366028707026167,-10.8867605797718],[3.74526473812874,5.58496972354197,9.08056822077224],[-1.20808476873861,4.27578560388252,0.115867777152575],[0.0532196930471228,-3.49149477931699,10.8566944114909],[-5.54788458661237,-0.857897401127621,-0.63883217717716],[-2.59785393369017,-1.22081891109237,-3.74774884921932],[-5.51709107834973,1.37969013153414,4.28600813082764],[-5.64965142443384,-3.37571341001103,4.40577120365988],[2.51972159304911,5.99954185177338,8.38266868536622],[-4.88677421954452,-2.78719802255178,-3.64222133544785],[2.64443831539372,-2.61874115578652,-7.06796005251282],[0.70822756088344,-2.17878967282002,-2.01031468860888],[-2.827317221413,6.03959143007371,-2.4611679695197],[-1.9275304839212,3.217130612649,-2.16192808704984],[-5.17279443899041,-1.50960903778138,4.50605945007097],[-3.9022224779175,-1.46310757873255,0.795501367720012],[0.262850681840901,0.194690118974912,3.76250680264885],[3.49299509458825,-5.50498166042167,-5.1832265673197],[0.910660304781407,-6.6656371297256,3.08571000299239],[9.33097019661967,2.75078564395679,-2.59472342552427],[-4.91434476862476,-6.00258993436555,7.3012728650132],[11.2574088353488,2.33796162533329,-1.31610935987938],[-2.26653554808064,5.00561295384398,-7.48160300064022],[-2.31868104226722,1.4002281432732,3.73035910153446],[-4.68648384950638,1.27416437419985,3.95357674618303],[-6.32414656544582,7.41641435131186,8.72108515862631],[2.56791533757956,6.37965875677174,8.98778850501477],[1.31658615031913,-8.0358221531466,3.58575927424113],[-1.33313962147894,3.09764414393135,-2.2394832812409],[2.92766788800892,-4.53628715267329,10.7677096100705],[-5.18651035522246,8.09732538041252,7.55894199202191],[-3.20006555724496,4.90959563848419,0.44529935934792],[2.75974624659367,-4.00266203989747,10.2292624910158],[1.64240456153276,-4.28557695171887,0.167615769050935],[2.84489591165671,4.38089635875667,8.73206205685352],[3.75635078243902,6.6074499797309,8.5917872734162],[-3.32987065424427,11.5128963317873,3.51012458343195],[-0.141178770351988,1.46631936153668,-6.57428622335991],[-4.22299478612205,1.18424681679798,2.53688126047369],[2.32236656584649,6.46719770878887,7.18562402883784],[-2.13586901581316,9.42940160341835,3.4961904110572],[3.74337898190026,6.41360891242682,7.85404171698507],[-5.38176658781737,6.8192836559953,9.05672150301227],[-5.21262618537515,1.59010953702743,3.77832000663838],[4.05305417149717,-1.60852278482653,-2.85172238622916],[-6.05145400966621,11.1813600441145,-4.42849764016814],[2.14917518990542,10.3372571827497,-1.98653825046193],[-5.28308708569846,6.92582905686093,9.11658857090449],[-2.71032063015881,-2.08301670111468,-3.79525218280526],[1.49093210401985,1.60603302500483,-9.81687089200104],[8.5680696447523,0.690596898839155,-1.13052563902676],[1.99993624909613,-2.81307877888088,-8.03163478982955],[-5.99387148787465,-3.71564849518557,-1.8019566380116],[0.362908115219441,0.598924199389745,4.53039809877279],[2.50738857794095,-6.27009886050909,4.4473795175255],[3.01018487778781,6.31102984250765,7.83925676759479],[2.06587061642147,6.12150907935955,8.60455236288085],[1.29365669081671,-5.0110068970769,10.9031550653985],[-2.99533556514711,2.45502231037777,-5.51965938051358],[1.16345173036979,-3.21580627978086,11.3080646644958],[-2.14047593275952,4.65449118908214,-7.2922183850438],[4.00913164331908,5.76279632650228,7.20550241636529],[-6.84087196337927,2.57317782083022,-5.75266490723943],[1.58587607862865,-4.12937274824426,-0.401006871158331],[3.41886110042057,5.83856500940277,8.66481617134273],[-4.51468648570407,-0.0109992867595052,0.658723793572891],[-3.34524901040274,-1.473731891788,-8.23954725846615],[0.89274416446757,-3.56548179818458,11.937986007856],[-4.6415064940748,5.23180591222663,-4.24816793286441],[0.855910375963408,0.0913257943540455,-7.35054641554626],[1.34869474052476,-3.54158169363522,12.2882638752599],[-9.38559664310425,-1.20734201712093,-4.03937140525592],[-3.80697116659797,-4.83394507175419,-9.47777790669887],[2.66667690468361,11.6025628327442,-2.02926567126027],[-9.41508963540819,-2.06314252134634,-3.90122346546653],[3.84994879580031,5.01610200145219,8.05723428019434],[-2.06475218621973,3.46973816581872,-2.50277295699062],[3.53829305791164,11.1344105577952,-1.41505847519222],[4.2102736282711,-5.53018414091284,-1.17049479486884],[1.26567373431304,3.70616640899727,-6.62895114623314],[1.41890579170429,-5.23132883579714,-2.12025791049872],[-3.66902454812775,6.71197301743907,-1.45008339537866],[-3.21836428841378,0.752205231025892,2.22747271030481],[2.03023676232521,6.7026621643252,7.12700794834579],[-6.91789526482693,3.10567794277499,-5.27598761404026],[1.79506096389068,-3.30915347247357,12.4735676693952],[-6.16828623441682,3.66681306964212,-4.633024100737],[1.07864210676489,0.439637500429189,2.89070854377775],[-2.10227048363042,5.92973179182003,-2.13663652676603],[2.93422302731392,11.2468613697199,-1.27320380131668],[-6.73649525307271,3.17228186569874,-5.3217350718123],[-2.83544121784996,4.57814449716756,0.586067351276787],[0.887916549456807,-2.46835700519445,11.4528157067262],[-0.523961442081027,-7.52921753603129,-0.187353497361614],[1.46129133023613,-5.99957535756425,3.48063227446681],[0.113084471253401,-3.34390965032387,-10.9724991698598],[1.2001263812008,-2.72348792828031,12.6755356087361],[0.351480604612816,-2.98733966467976,-0.694843367859478],[-3.19460946647928,-2.489071025098,2.01340938164012],[-0.673979265105725,-3.24280441834671,-1.51759641631915],[3.43264792896394,3.52280763364869,1.27888382539534],[9.43624909384558,2.56990935762236,-0.951691824918978],[0.541105985527537,-3.06118334737446,-11.6503337608513],[2.48250067560279,0.19740454236257,3.44665403333647],[8.54961667518879,-3.74384958447664,-1.56809636227439],[-0.0449327635191112,9.05313976448938,-7.42118214433738],[2.48384711039687,9.72831708805828,-1.90717278768949],[-0.037878019994585,6.15225366980211,7.64178861455813],[-2.77319418723471,6.3987129352303,-1.50151839761035],[9.4637806106209,3.1875255512256,-2.32368883244351],[-3.62934103567772,10.1099199380455,-6.43984361767268],[-4.71125156630515,7.53500933797117,9.06473505085158],[0.577253101428836,-3.50635823809887,12.0639954974778],[3.73016619172117,-6.80028123807801,-2.23368157312261],[9.41651171736337,2.81293332041653,-1.21753550808125],[0.126672229508423,-1.61830994871812,-13.0515042781854],[0.857584520416824,-4.98510674432552,4.19188980595172],[1.30783713141113,-0.787154814735071,-9.68267809976966],[-6.09422188713257,3.14551666617516,-4.27443901893453],[1.641267829464,6.20180304534877,9.15069240300308],[-3.99116039336517,0.867913313099491,2.75386149749207],[-6.03190838207335,7.04105926494662,8.95110098226584],[2.46759001043662,5.13782734220355,8.75115781629483],[-2.07914254565324,4.8168711369932,-3.12100171451574],[-1.17476104925856,0.609876914742958,3.11884270922583],[-0.506424103025468,-1.69017236911279,0.602232599948771],[-5.77747211833304,7.87142827149846,8.26338624516166],[-6.82175529116018,8.75412980315409,-4.15244466561919],[-7.5932377422939,-6.15995594047264,-0.0710735159683505],[-1.88001790183169,0.417771097418534,3.30017196199258],[-6.38171421489133,7.37593748375272,8.70466491739144],[4.01036690465545,-5.79215237681893,-0.944837139682529],[-3.92446701697558,12.61013517314,4.650146910826],[1.33333923976033,12.4086021067033,-1.52815528282109],[-1.47273429400017,3.20225034368439,-2.48118736039538],[3.4747621788106,11.8580450872658,-2.39506762467959],[-6.74276025775657,-6.15204736384145,-0.522766256460904],[10.6201051625486,3.74204450555002,-0.745852444272015],[9.00882693598122,3.53200332435589,-2.08808616547083],[3.15808236575702,5.87302250842003,6.15445455975009],[1.55784462742937,-5.05916116869137,4.50359820712632],[-1.75542091626643,-4.48719963839827,-0.52297191543589],[-2.59363244577873,4.89848780647782,-7.70039527609729],[-0.346981600458647,-5.19134595599397,2.67777727304683],[3.38002271867972,-5.63429273054292,-4.58745044281295],[1.3671722822144,-8.10067023227039,1.73226670860509],[1.51072021877592,10.7242764746168,-2.48576799535643],[-8.50848323854824,-5.76574548313518,0.628684141819081],[-4.93616044588583,0.835439509318508,4.24412184789576],[2.80021580952929,-6.85355974290563,0.0565450170203153],[-1.13499763251908,3.41074799508329,-2.43581860493141],[-1.85349460802344,-4.08259707069957,-0.528479127007622],[9.58388199299539,-3.9077070435416,-5.1131507241626],[1.7856000784946,-4.72200848511049,0.871703255493166],[-4.95490200363583,-0.268141644609208,1.97017661894864],[-4.29820108194303,10.2533607761797,-5.47646632816719],[2.95498418090411,6.03437300573305,7.06105983639436],[4.03644504251875,-8.95980377128806,-0.322920066613681],[3.83534907194741,6.07436627692917,7.96993009174241],[2.79389583920121,4.38556762637107,8.11281968785982],[-5.78184320060037,-3.42344726334681,-5.0306059717789],[1.45279176245009,-9.18165421068304,1.12127232492925],[3.78369532464304,5.44189183337304,9.23323345375662],[1.54318904023527,10.8792298544109,-1.93088036597071],[2.84871783070641,6.54926829282215,-11.7258750495155],[4.50568759438261,-6.05635584480249,-2.91636685921135],[9.26145221009312,2.80566209982417,-1.37425814671227],[-4.01894406044939,12.2948736450036,4.00884681497509],[0.251109715699786,-7.84543697063546,2.01107753780784],[0.668982683133232,5.74496947105278,8.75761228938607],[-4.61821144460576,-3.86728154486526,-1.5209765881283],[-1.52929654530296,4.5151237040805,0.497645023844014],[4.96922180006576,1.76088758965506,4.6966596177915],[5.31798910033071,2.74828047904322,2.15019619747764],[8.95477247113465,-3.55423503937748,-1.60937213765679],[-1.0688584781685,0.148629476651968,-6.83329799567834],[3.5558564528869,11.8056157529316,-1.47531975047953],[3.52809022963026,-3.61608794786737,-10.3318902830848],[-8.6302663020597,-0.775653847744847,-5.16055465652878],[-3.14225182006029,7.17306779878542,-1.22225410909631],[-3.51867975626029,6.9565632738601,-0.508010561220478],[1.26976191146572,-7.46774775291961,2.68226615610323],[-2.49132922521602,-2.20942184048815,-3.78993838381006],[5.24011008751873,-2.74587681487191,-3.81856100145371],[1.4810451564572,-3.69051437825286,10.9646990472266],[-3.86177087099381,2.8393709091114,-5.85724865786626],[1.33455701410148,-4.27330391723067,11.7359872689163],[-9.05448700543416,-1.70763212595665,-3.66744641777946],[1.46364008265384,10.6131578182482,-1.87669257232122],[-8.785041644457,-1.37030475872644,-5.08427349616425],[-5.06038373044659,1.37977691311234,4.34326627991809],[-4.30634721178614,10.1455508404473,-5.30043493318231],[3.19164538110853,3.57945973309965,1.3830797055668],[-2.44086540171388,10.1221041826592,3.59798782070412],[-2.10892582807044,-2.49719687044577,9.29404297938308],[1.41315382744778,-7.11173692845734,3.01022991173468],[-8.13015862491587,-0.192873255635666,-5.09688361439621],[1.74809533732946,6.12539824856902,8.00072931270468],[-5.16535102959149,-0.82741429528742,-0.949011424350325],[-2.27947231316866,-3.38856354955236,-9.74014955763751],[-3.08983080112019,7.24055228714678,-1.00626717305306],[3.81119025205998,-0.825532930555128,-3.88571566085395],[3.5184005867752,-6.4625492164655,-1.83030327603697],[-7.28495686900093,-6.12219777446632,-0.575198969421225],[2.88806020942172,-4.69191654021068,11.0181877137537],[2.0921470686544,-5.59768940505503,4.47092283218143],[2.20040508656734,2.87681607388166,0.58902136959936],[-5.96826976116344,7.88701797785121,8.79907719731639],[2.56224774593753,-9.93400698913067,1.21120780426759],[7.88213765917179,1.61749191984196,-1.37936712857893],[-9.28156287939348,1.08643878912574,-6.34688493674206],[-3.47135451173632,-2.75663262955582,4.87798344938308],[-7.23455850791399,-6.05462304305599,-0.186077281592402],[-2.25258727432997,5.30959133810751,1.17000863939623],[-3.387456371043,6.93217135940622,-0.731665910306557],[0.10192128963486,-3.20759136750388,-1.09908816528765],[2.84194824969125,5.3954757533006,7.45211430870273],[1.26951512682791,-4.59965319104738,9.85180696239265],[-0.157790301936854,0.163167557274312,-1.87297723865572],[-5.26001126505962,-0.297814218271457,-0.394567532784084],[-4.55368313950532,-6.39474090826641,-9.15403937121048],[9.11113422129054,-3.86870761308379,-4.18048363730633],[-9.31709476856258,1.52067437908569,-6.55349533789514],[3.14161605399736,-3.76470440671127,11.8390152397932],[-3.22302489372998,7.22007616330656,-0.829109929202595],[9.42016336903992,3.78058114424527,-2.62281676647646],[0.296049115699708,-6.44015070519769,3.91900435762586],[-4.91105425384542,6.14279636796362,9.37977822819256],[1.86620332340722,-5.18811405143927,-6.13335852324916],[9.71829615377679,-4.47986844347931,-4.26266763081471],[-0.133574081055367,-0.890236810306293,-13.4385488071423],[2.17804777127028,-9.50012548915717,1.96524570534102],[-4.91734096488132,-6.06187287014006,-10.2734152310408],[-4.2727825160773,0.610901101795836,5.27783690948335],[-2.53254501795831,-0.524082054251716,-3.31710758755779],[-1.42326780848199,-7.10623286640924,-0.276319041089048],[-0.200864889534003,-6.94980727215849,-5.99393226996927],[-5.67911587924618,-6.50944097273761,7.24939607861017],[-3.10201203716041,5.14364970639702,-2.59342999298689],[2.33354508646341,4.18884050816977,8.33945477886313],[-6.60797183274275,2.90821915066511,-4.00854821885839],[-5.24362086630159,8.34575910595439,8.55394017066186],[2.95529713583544,-9.39046113407084,-0.132924697955766],[-3.79582249906411,4.9194017150272,-5.16086157540287],[-4.69207753558697,8.14714661865912,7.52685280111914],[-5.7433435454605,-0.996769226998208,-0.266941251597332],[-4.42874112107709,8.14956984081135,8.45462296621326],[1.31444266838908,-7.69218945148406,3.43329858020649],[-0.692523993299735,-2.96646324844675,2.06104959083806],[11.7862015582407,3.58437754997607,-1.57379416828362],[8.59322883428104,-4.55582226558877,-1.5963148386018],[3.80542204303084,10.5274840364976,-3.37765620944833],[-0.304649490943324,-7.85152442065919,1.02571148549619],[2.28691891815345,6.19084855711879,7.17290192074359],[3.10127827018638,11.4304293145013,-1.74413055237594],[9.30291169565212,5.59704082328129,-1.18086068662278],[3.45100638494027,-4.66092530202451,11.256235852366],[-1.78970552279276,3.96744580138967,-2.6520479300186],[-3.67517359766322,3.51846688261722,5.83959407062012],[1.26755899723932,-9.23223344264171,0.352955800591043],[-0.504716303368379,1.04501124469497,3.47984531069151],[-3.74906171278571,-1.88336072371797,-4.53153416763199],[2.26037589053398,6.68582284738155,-11.6378961369102],[3.7091877312111,11.3000978002228,-1.01188089271451],[-5.92407007705685,-3.30926442880699,-4.75601822724904],[3.01334588002062,-9.51773254274639,0.387666132663966],[1.70827234403603,0.287249090827725,4.12425889450106],[-4.9446504057271,-6.49450232621927,-9.81001442809782],[2.73774338716987,6.78031867640064,-11.4119967457351],[3.94864877434971,11.1238308159405,-1.67088277006485],[7.21471496092016,-2.65670672460231,-4.68268046043623],[-2.86301875578033,12.5607072116863,4.69657730178137],[1.74786703835262,-0.00112131313158659,3.15737210882941],[0.0583701824634376,0.518200453071805,3.77212290312191],[2.04976251110697,-5.33433518595255,4.80662763562801],[2.08801092310512,-5.26683687335671,1.81902817537772],[-0.0031407947421771,0.4527572362611,4.20324618946958],[-3.71079934297211,-4.27215888989619,-3.09392697080446],[-3.92780505178201,8.26865243763462,-5.90868440022471],[-4.93179988977821,7.32629429290592,9.00386034908051],[11.8901913687562,1.76793138000439,-1.42763843113178],[-3.3344786068326,0.454682413324677,2.77499331421051],[-2.56392925744637,-4.9913080864615,-8.03246790082242],[1.31394831732425,-8.12687233102183,2.63498367279321],[3.14320717478548,-5.576176347345,-1.78336022662413],[3.13575922051298,-7.70791887992276,-1.74046431774668],[-1.31555043751172,-7.65952045571343,-5.38884471710285],[-0.138427879501661,-8.42479935389839,0.464961661426183],[-3.91564101253267,-6.9815600010553,-2.50130767780753],[2.59309886204167,-7.64153799029502,-10.2941452266854],[1.29666911268003,12.0928806961314,-1.66551824285554],[1.33393751534742,-3.58111973935493,-2.40967278845331],[2.9798614775148,-4.32843571035252,11.5016329046895],[-5.41258519396458,3.71608052591056,-6.59397495358154],[0.464701469605717,3.38305140651286,-6.57357282288834],[-0.256328791057556,0.438427842297938,-2.61799709943184],[0.910698979680679,-0.0894696992078163,-3.22384743970093],[-4.83206301273864,-0.156601060255709,0.265808788040049],[-4.38174428274754,0.635573114578809,5.16650729565095],[-2.69733401921812,6.45266294558987,0.0579642269575009],[2.4017637688534,6.21908007500971,9.11835340627128],[3.17701555579423,-2.45473813921676,-6.66036132486455],[3.25058458794404,5.16225439638456,9.02689674510686],[-8.70779493805191,-6.80582073430058,0.732723261260381],[-4.39077471890757,-3.05988485869601,-2.90647180503884],[4.03965509070043,5.23639692348159,8.11016868236576],[3.33278592305148,10.4475030819153,-1.33518355875283],[-3.98066918582024,3.29359088318233,5.56540964529502],[1.6557417162974,2.80503941400352,-3.22834516854709],[2.04421178182289,-7.64711350788591,-10.911245189459],[-3.97771033112334,9.48338018312619,-6.91708943198945],[-2.73514969758252,-3.32690461613233,-1.68572770047952],[-1.38037187073415,1.79977527440068,-2.38581121793074],[2.47587422813864,4.48829324049151,8.79535394131531],[-2.5019927565146,4.05015098278939,0.712270339886743],[-4.6787936139851,-1.1350015142809,3.01245238743993],[-5.48831630656125,-1.71811179194478,-6.36792467930418],[3.1295326456459,11.7642180055651,-0.640050128431267],[8.48088514736937,-4.17036693575214,-1.02703542889602],[-3.82750031873909,0.492149230260285,5.5560239859602],[3.25199450313473,4.36319025467389,8.4508817892228],[-4.57677693310866,-3.2681413033023,-8.9194279625565],[1.02612748355038,3.77442602163818,-6.22073237239411],[0.871975378982365,3.48238019192525,-6.66899777844041],[-2.06360962608499,8.44437010370199,2.83998204420402],[0.715485882860727,-5.47202715526315,4.53170752225358],[0.613259134676414,-5.31818231682905,-5.39064743778323],[1.5290832866054,-7.94975919333485,1.73063334197726],[-4.5065521085146,6.28073282580587,8.02830599796223],[-7.6265437972442,-6.27060245670203,-0.338060162805362],[0.74242253637465,0.110189329070577,-2.41488837998177],[3.99996113464723,4.17948275861321,2.54235198305522],[-4.86027535435945,-0.24918178140099,-0.791763493393622],[2.66027663136123,-10.0066056845333,-1.32688085164143],[3.54128232176355,0.421785149588694,-8.60015508572608],[2.23891816066273,-5.26456387121828,-5.9469106375191],[4.49911679642184,-6.00994808109706,-1.63509526972543],[1.88892062273294,-3.3475804552514,12.0952988298407],[10.1070166266317,2.9415816465131,-2.70790697445741],[2.05353510358128,11.5945161219536,-2.54554808202117],[10.4380394637411,1.09651232921683,-1.46838731232414],[-6.40058290623483,-5.88583812349171,7.42455265496503],[-3.29219504753717,1.11754002643689,1.79390382736901],[-3.23344546826428,10.1751275999579,-6.63061722322351],[1.37460691058223,3.44068601021054,-3.75312120462081],[-0.259536158464613,-7.62519837807347,0.863455020695483],[0.986304831223404,-2.49004648947651,12.578554944069],[3.02398501095636,4.21770036011226,7.37981705249205],[8.5908390886745,2.90333484138171,-2.56756495149868],[4.37938473598523,2.34522679152901,-9.53880619999804],[1.85253631767914,5.72321821350821,9.00373391470834],[0.564939647863919,-2.6705956524376,12.6002827746526],[1.72357105422783,5.93256625051691,7.87534425902049],[-9.76584270002213,0.626533831302936,-6.09366937745431],[-1.68212481177548,0.689675158383801,3.08044949054834],[2.12477236680298,3.49574749989959,7.6472606726085],[-0.133825353147378,-9.01360188126278,1.19981133237876],[7.23894398528115,-1.24904372962023,-10.7135541936482],[-4.02422041791004,-2.97645297414005,-2.4154660543981],[-3.59987282711641,1.12035925321301,4.79231245254716],[-0.890569450776582,-5.71919341798059,1.0637335870794],[-0.0425932305354331,-0.0867121436923584,-0.939575081894745],[-2.53398048468623,-4.31115822978255,-2.28446159776681],[2.53728848639025,10.1649070112259,-2.14364081466324],[1.01419219671952,-5.20501741409189,-5.51707275613612],[10.0852235610947,2.28672298788618,-2.93155868650035],[0.0906200639860567,-3.62001935042144,3.01667303272782],[3.68761255095197,-9.52546340373392,-1.29082380244734],[1.65314150409864,3.45483625932262,-3.60614653425953],[-2.28490716802511,5.86140049953855,-2.53865305389739],[2.99902159781927,6.01067198251124,8.34111910320531],[-1.41715198424055,-4.89684671523004,-1.48568616695221],[3.03261101464595,-9.87550927724943,-1.27415740306989],[2.9795417939611,-2.10499964999854,-6.50769091882679],[1.89275956284854,-8.67631571736507,0.996903467356748],[3.94324846587167,5.79875568770531,8.78568685975176],[-2.92155783384123,-0.809529058886086,3.18857353054838],[3.98104326744713,3.61965974230022,0.626753123884816],[3.13415023458601,4.13455404197184,8.14606255809347],[3.60626175623491,-6.15883548721693,-1.87044291089174],[10.8179484851629,1.54174848007485,-1.24692908392946],[-2.74543833786566,6.08100091552916,-0.735368428125626],[8.77810731502957,-4.10117988060441,-2.34979620557235],[-5.85021423798525,-6.17377054791894,-1.2397813374184],[9.31203413606368,0.794583755069065,-1.94531152906105],[1.06131818936554,-4.10807875785321,-0.720948864716567],[3.56962939930456,5.54624470917072,9.19613459147648],[-3.67627557148816,-6.6555126569346,-2.87139851618139],[2.45082535026953,3.7336484852594,7.78468854558379],[6.77505914739119,4.91942258509863,-0.0980348420479835],[-8.73519775827264,-1.56394467900002,-4.23044907732161],[2.07981623730134,6.08838958073913,6.66191202039744],[-9.61426159982342,1.23986847424028,-5.77390974325688],[-5.38490106916326,-3.99204483889075,-1.9280255690888],[3.44280833340294,-5.7128150305213,-1.01124079459143],[-7.86558216845526,-6.81957633964599,1.41462907382865],[-2.8325566209724,5.30492007169026,-2.50061135007046],[-5.68260738787498,6.48334221757846,8.78865832977238],[1.5444589680362,-4.39757550686992,10.1150626763272],[2.08079404448569,-4.75489759843082,10.1664787128981],[1.29995762241611,-8.4714796466863,0.409450288978368],[1.3573777312605,-7.20870079560403,3.20899957176673],[-9.82694541918672,0.888440980591978,-6.00593183429132],[-4.44608608584793,-0.196840355743949,2.25836143618338],[1.75399199516963,-2.13991603596396,-5.61443091050919],[0.957825057721794,-4.97285238088011,4.86784942908753],[-2.88056766936851,-3.76870038509456,-9.26746392921041],[-4.86101349720034,8.15514910361991,9.0425582325354],[-4.6477224019591,1.03267881686256,3.79691177986499],[0.086128711261402,8.79252300746463,-7.66454207893691],[1.64020085080225,-6.93596267739528,4.65250073755797],[3.59650557337175,-3.39720133884708,11.747314668271],[1.06111885530972,-3.06623156431943,-11.7812831576262],[1.27756104539315,-3.85041428593531,-1.44844439025126],[1.54010623776379,3.77355632427519,-4.1231098771192],[3.54409162611738,-9.12922709098123,-1.72934367612396],[8.63923568503454,5.46749928638681,-0.963923231174782],[-1.52530543064905,-4.77019411958837,1.47429979402759],[-3.58743570550813,6.31257164804295,-0.0347137104048651],[1.84282298055821,-8.05061180232181,2.14538899936823],[-0.165013494268553,-3.13461716988098,2.52531734820092],[-1.77668062733815,-4.09297963643446,-0.0868638595164349],[0.174740732682343,-3.16378664194615,-10.7872824483557],[2.40536784303663,6.23780417626121,7.13862270814692],[-4.81705339264051,0.978798927391761,3.4667602795955],[-2.35816749824797,-4.38703918794317,-0.0111367135676473],[-9.22922294707779,-1.54992531645465,-3.49116997555149],[-5.22247966443346,6.5240755333128,8.39738931492808],[3.40060778123821,10.4190010060967,-1.58619255736039],[-4.80866850543814,8.47505453779437,7.94223495433492],[3.25516536209995,3.47849120395663,0.433286928946707],[3.60472513049454,-6.82827417467162,-1.96123781893619],[-1.55051544239161,4.3850000242777,-0.221290485148081],[-3.38983820407646,-4.96883919960769,-9.09186953086726],[1.23388932723856,2.2666765856469,-2.62427977183998],[2.27482699221614,-10.224316069008,-1.38805126422395],[-3.68387550180707,-3.19939083467738,-7.25518816871333],[-3.07355592059072,-3.30762655316267,-1.47468301336528],[-6.19194110758954,-6.23382971927248,-0.807239861814984],[-5.46405549159197,-1.16319550530099,-0.118372515699842],[-4.05859494567756,0.996114132186926,5.34561970724614],[2.07962933122908,0.555650233009045,2.97800283153884],[-2.95629754503616,11.224184394724,3.52394762541644],[0.902782411719751,-3.34074809539168,11.728606373934],[-0.543278773192118,-2.72887548372097,-1.40219527135373],[-4.72614233277569,3.56318709774918,-6.87528105977445],[1.14803175414206,0.817673323493618,4.00346543682264],[11.3782105499118,1.92505356386283,-1.95829335384331],[10.2306107978397,2.75877679901567,-1.12225126524001],[2.07116721667078,-9.5784640261174,1.10324558550574],[1.98225244841833,0.395130697887201,3.95574316976977],[0.661550212075709,0.0846889077889449,3.07151720987885],[0.801291210437348,-3.31874347339272,-2.45282342932788],[-5.75270012381666,-3.14907021370635,-5.52980271856609],[0.307600574482782,-2.74460967393187,-4.90589666110495],[-3.01150923169877,0.593874650157537,4.45913928323526],[0.869566834819863,-9.02301481144894,2.36954555801096],[-0.848402272291403,0.596105376029782,-7.20606265822416],[-4.23140504330355,-5.48078066139091,-9.63813769913093],[3.28271002756438,6.44257698147662,7.97928022131646],[2.77803520151672,1.20787108213992,-8.3915942740694],[-2.26614096111249,0.379186791777771,4.84015757352515],[2.56515300410782,-6.51379577776558,1.57348064060403],[-6.254369209163,3.53584184370016,-5.23776701159691],[0.341850803644852,-4.84512135885485,4.13558115510147],[1.62099785279783,7.01536614984222,8.3232316258917],[1.52891219179204,-9.24719232507421,1.37534157079064],[1.9970515951448,-5.29775195979722,2.1962211555295],[0.734513887098181,-3.78211484541717,10.1264267082565],[-6.21359083996358,-3.56637394744321,-5.07083191576036],[0.615220636390473,-3.56028131699862,-5.67601542465053],[2.19829048654733,0.135625635374903,-6.988928109181],[-7.51350219652472,-0.741506590475466,-4.66381252224053],[1.53877954210461,-3.55864806261163,12.8291636717744],[-4.77000683940339,-1.10811583813246,3.43281687729879],[0.379100862658035,-8.45247770943518,-0.0473219874254492],[0.901108798073927,-4.0722465871778,-2.53307957448871],[8.74930562420074,3.70596662030422,-1.0939822332487],[-2.68425268295951,-2.47748688019775,-3.16145572684482],[-1.20438399266013,3.11240640694871,-2.2439315496392],[1.01482652767413,-4.63813052802859,-2.1326981996411],[9.95367568669769,-0.100532960898623,-0.516585215924539],[-1.42758189641241,3.98705961878105,-2.73709883222453],[-2.59810909141206,0.676802342989308,-1.32761006545368],[1.96000736552315,10.6264859002353,-3.13027384190676],[0.486363506534877,-5.08897703957587,2.47501437808559],[-0.103927984726747,-2.90884371037226,11.4323335858327],[1.89560285437821,-6.50656392991393,3.17626712874063],[-4.11571258526638,5.2760581177278,-2.2460447682877],[3.76016409235458,6.4407506302577,8.76659567221692],[-0.954740244065101,0.353177443591699,-6.88776003276831],[4.1065721366629,-2.68154942767044,-6.99899953889805],[-3.35871267886909,8.13062838817745,-6.3924565158744],[4.50240663323404,-1.49119471607384,-11.4040620534304],[2.8868405245418,5.90738182187649,7.09798698708022],[2.24693520252745,5.28648909224528,6.9962333500116],[-8.64518998275193,-5.49330220581884,0.445887107183265],[2.52562113827013,6.21860956801622,7.91685861761835],[1.72226503320213,6.49731762259257,6.7952061984466],[3.57348978764364,2.88779952721952,2.96344093901361],[0.599475028851927,-0.334673008458807,-12.8458297161613],[-2.48821344633564,2.21478783905463,3.39318606661001],[1.81261598478429,0.463626549079645,3.8262474848643],[3.02008893034319,-8.99583821992976,0.67748733736819],[4.19609306782025,5.78603638443357,2.57811545708307],[-6.22477641978672,7.63601738195395,8.37470573588949],[-9.29867320462427,0.243620147215323,-5.84981787187212],[-2.78943123474533,-4.8660522628969,-8.73893999681595],[2.41072462534516,5.92393435263399,-11.2391598548395],[0.625090015854875,1.5589411874087,-2.51696482935558],[2.02698312712551,3.90277680005895,-5.60948504810957],[-2.00063262923954,5.95221980286276,-2.62238914255682],[-9.348927318583,1.39903258733852,-6.25601182264935],[1.27895507202648,1.63724052395217,-1.2871011465965],[0.683976440768536,-3.05413247170517,-12.0552118328099],[0.110814327399272,-6.69665190434227,-1.34540373543022],[-0.312139206325466,-0.79900596341528,-13.5884609739012],[2.94886160869436,4.20341762502824,7.97856467152718],[1.88925398570194,6.65050260089368,8.41795000130178],[2.96284244134005,6.19968758106326,7.79697685124178],[0.851751530998961,-4.72322585319515,2.87188643968388],[3.1954000490625,11.8521970102821,-2.13708011536376],[4.10593941872611,6.03279228817058,7.95021395018936],[-3.06990590685577,11.0841738971439,3.34782467201692],[1.61236067535107,-3.00716437347408,11.0134628338549],[-3.50473040788614,-5.79106111602797,7.65926405724205],[2.70712276819168,-9.70055939989305,-2.23758475886259],[3.76295633013368,6.03317571735916,8.61603414613983],[3.00834560663387,-8.43042321428582,-1.85654183801939],[2.42017847793687,5.95391755311177,7.70316204432576],[0.976256440228243,-3.7791772134498,-1.44210707719982],[-2.54462537437635,-4.27056088588707,-0.0397916392693592],[0.8579230711106,3.40005762593521,-7.34500340949248],[-3.74144121301499,5.17663701897204,-0.0841857777428065],[9.76962088945622,-4.85435904458115,-4.30246837180474],[2.78872051746974,-9.67130092354921,-1.91411845614008],[-4.80970076501099,6.07140362725717,-0.207035713378084],[-4.66891338308359,-5.46201020711846,-1.58336017305581],[-0.168217815375087,0.196859263548157,3.19256663695236],[2.50868180430692,9.92394345484695,-1.57522458358061],[-2.70361822846241,12.6370109771397,4.91601807861312],[3.83500465831832,4.3357612053405,9.257058349177],[-6.03646627274185,7.95639299438485,7.78080317160533],[5.86469666332233,-0.379724931633195,-9.91468433966927],[-5.67065332817381,3.35617966596783,-6.52635731101883],[2.58898138315594,6.86433180268578,8.37071782966913],[3.63744131545331,-8.09873536680205,-2.03156711119464],[2.91391184286611,-6.25408397590344,-0.822735105075601],[-2.87122723365051,12.3425664607999,4.43714003796169],[1.19434377611782,-2.08248060202606,-7.79710478678873],[3.91087282000664,-5.3552903520521,-1.73348391022711],[-0.333656595445193,-7.3018462725803,-6.18003356547565],[3.20162810012881,-5.7526468520535,-5.09499950825488],[2.09700158530985,-5.38855195881373,1.49357073525791],[1.34170825722264,2.49336513032322,-7.50641408599444],[-3.79909911705604,-0.579778274487612,2.40759763298244],[12.0582213774046,2.46868724028805,-1.21725288726825],[3.17180675354298,11.9282406127349,-2.92204549225033],[-5.16985762759175,-5.29370563016828,-2.11200123776532],[4.45256723347772,5.91018300034125,2.85642802194697],[0.842031013560929,-5.42038374426135,3.37462286511278],[0.200180463909854,0.38617378934873,-2.70404408747484],[8.24825529847397,-3.07055688446202,-4.60877509586242],[-5.31028969404135,8.27137858698855,8.52567909028773],[-5.0471685295321,-7.03348699895395,-10.1394402122644],[-4.66342673952435,-7.09171300570241,-9.45435911028184],[1.47258290332834,-6.8603213931798,0.16618096248212],[-4.69511332889756,-6.21003415989564,-1.2050153450465],[5.3695251115183,1.40793530134256,5.43772102528999],[-3.77157085160489,4.31850596106501,-7.00793624310278],[-0.0637235973518261,-2.48007872947574,12.6958383721609],[1.97362214487169,-8.923876725448,0.236559359289488],[8.78322012816213,7.04519491652526,0.702264232028493],[-1.45213166826268,-1.10571197210013,-8.1705337866253],[1.50675963469693,-10.2388550366925,0.759957811590592],[0.913027363800269,-6.56762925864856,3.38860945476197],[-3.00098032353303,11.2179022606226,3.20442632152941],[1.98543487091523,0.207770981109624,3.29881963814358],[4.85960139315393,1.76048359104528,-8.74421084526498],[2.50291744083576,10.6152187867897,-1.80105200486555],[-3.2286762303642,11.9059499744576,3.51635711746235],[-0.344004454684471,-1.21659369401087,-13.7421939937443],[-6.27158636261642,7.9429624196604,8.0560915737306],[-6.13020521457699,-4.59339661078993,-3.56782292337377],[4.29239068159531,-1.30693937141022,-6.62459955255328],[1.86764131734074,-2.82293830444419,-7.92345163426348],[-4.70482083546717,8.25381552527155,-7.0794579461203],[2.09214029390275,-4.85890531425852,0.821365014427727],[-3.22370849536796,0.334599384951351,4.37549463070019],[-3.67049633510043,5.27179773408879,-0.68222432543696],[-8.90404555064816,-6.19225493738117,1.0249966157964],[2.32593548622346,-3.41455592663629,10.9013641182103],[2.74092966091998,6.40503755139977,9.05859496862298],[0.039977557527662,8.90973091518645,-7.3644823110608],[-5.25378231964286,-6.02186841063332,-1.55607008563423],[-2.74306930206064,-0.0135482212331607,-0.68011352552013],[-1.39331025663022,4.41488451598979,0.647226210693277],[-2.83936858667892,-4.00356601792528,6.77939233414931],[-5.0055212399511,-0.162771349457688,2.2794111411499],[3.89143350259149,-6.43808506693486,-1.98886701884031],[-1.54613608054716,0.848558731037631,2.8916917519931],[-0.617150823386629,-3.09906759739296,-1.58400717813147],[-3.56058939382534,-6.45858359729257,-2.43497518563356],[3.84047475469158,11.0432651658558,-1.28968268098769],[-3.44857930418387,0.311643831085159,2.07034466533909],[2.48661515713565,-4.48285001725512,10.2063536392598],[-9.13951170876008,-1.66840538996146,-3.24762008926137],[1.87975708163435,-3.32427603128858,12.3272931928793],[2.0116976534156,-7.71588236950048,-0.696339651756282],[8.67431964678393,-2.21541340753672,-3.75877821053427],[1.25111470978861,2.76223225569697,-3.2993505533202],[-3.51394022453153,2.91587677995688,-7.00571338887294],[2.8870931948106,0.438374523897091,-11.580675190846],[-0.516822569731107,-2.78669275692855,9.85399686759613],[7.52050380434668,2.25490380354192,-1.25274756271312],[-5.9284184941141,-4.19235885841235,-4.62608885107354],[-3.37562653812847,0.947802982479489,2.74668716986224],[3.31607362225939,9.69569177943619,-1.16140055799524],[1.6963486062447,6.38960388586288,-11.8870106140268],[1.96739821171221,-7.13172076621696,2.28862628978661],[-3.50698403548334,-5.67503961618599,7.62049544508312],[-7.8404402614574,-6.30518250771826,0.0104157178694143],[3.18692779519563,-4.46895283346303,10.3555713211786],[3.02627448021885,12.1085905743067,-2.86214494079272],[-5.21249405411614,8.52125960922067,-7.38409162000552],[2.71000175999436,5.15149658296267,8.40434872869462],[3.39618699860597,5.36144163692882,7.45713806788007],[3.41068695453139,-9.0694329559282,-0.304310598391512],[-5.55110780450011,-2.88433227403247,-5.19853126561278],[-0.468399879309524,1.0313871247781,4.13654350735622],[-2.85287957996876,-4.83375469748978,-8.04893927203546],[3.16152055979163,2.33889685763615,1.2357306378025],[8.19425272115255,6.0947228845248,2.35859060881892],[-6.22179589208272,-3.85036946855636,-3.25691065138698],[1.05981635983513,1.76175501566093,-3.04991462710392],[-5.32574524589888,-6.38735761022045,7.50536598256448],[-4.58851308459055,0.616984894341172,3.03174122371056],[-3.50584216934783,-0.360758466453861,2.41833830583286],[-4.83269311068462,0.111503438833484,-1.180666773328],[-2.10779890479725,5.17490095950921,-2.84006855032087],[-3.4820873456668,0.916707457171383,1.88109977449042],[1.4720533710663,-7.56269023454713,3.82474496057199],[9.39691680495378,2.68208487922781,-3.10762955448221],[-6.74985343025261,3.13010363687302,-5.85900659822911],[2.47019594353656,-5.61976284465917,-1.59782870413752],[1.85130304675626,-9.02546276687987,0.686347445152364],[0.678580513092263,-4.38136039438723,3.68041631334551],[2.27044583417707,-9.90945817687792,-0.681012638433363],[-6.8592756989191,2.91083260032034,-5.10906650255182],[-0.585710327987636,-7.13257112663979,-5.77703587897355],[2.92247044964483,-6.01174790237767,-4.47547266238014],[1.0822626334105,2.84715040983266,-7.18893451802752],[0.422371064197078,-4.57786798352766,3.50166830946437],[-0.738705409271682,-2.7272608341926,-1.70868277161941],[-5.90645434266211,-1.83905653572132,3.86564996503143],[4.42998214491491,1.97500769798764,-9.38175562101994],[-2.97977382598124,-4.54867492630676,-0.357538892261226],[0.928547193470167,-2.97454921550891,12.3537552945255],[2.95906043525348,11.0207519477396,-3.30940691352068],[-2.21329462712826,-3.94128454241053,-0.305210312820374],[-1.49320665986717,-2.15219714411919,-4.18639161640215],[3.56886096754594,12.1315435831922,-2.53523591684865],[-3.17280548928823,6.88222546668614,0.195481771414177],[2.36168376049582,11.9453168859813,-2.7515819852224],[9.12605632200352,0.10956885629629,-1.24298756632489],[5.5910498298743,-0.172700531722367,-9.7478073524544],[9.20232233762759,-4.11843304810447,-1.26336885486114],[-4.38405268737603,-0.708474826658096,2.00149381014099],[-9.30496262179989,-0.119654787702927,-5.39171236545971],[1.83313018878809,6.15601986054272,9.06194712834473],[1.54707517137778,-6.96586323918344,3.87471980635945],[2.28191015088421,-0.11930885019704,-7.10220441880814],[1.21274407400723,-8.17958838108476,2.64911392023897],[-4.94569229474271,-6.47919232903982,-1.60124099221249],[1.65412008038779,11.0669204161501,-2.18981173509378],[-3.44242757954025,8.4062002800668,-6.57375246542173],[-2.41546267681731,3.65900689349457,-2.31581095989833],[3.33021825420701,5.84087315140198,8.75234539379489],[8.82588960872073,2.09657974709149,-2.46578778415274],[-6.43706605388068,-2.66170749227886,-5.33220763091169],[-2.00195005305463,-3.16924946888473,-0.75058921101138],[-0.861331141522212,1.08619791970098,-2.68741248197971],[-5.9309773406147,6.89860795423857,8.77594310654314],[-4.69930746812665,7.58169732596463,-5.2477262283952],[-8.69258625903932,-6.73727093624988,0.420451700167548],[-4.38778665781411,0.662403095790775,3.05335067955322],[4.77719481951844,1.92203999412632,-9.75678033931152],[1.95731389742705,-8.81446082283487,1.27822778656433],[2.80566076952058,-2.24379878227036,-4.55347354613456],[-4.87160765972606,1.61854602342009,5.24136237890616],[1.48397621560452,-9.16692829377708,1.1590577047644],[2.04294642505531,6.2652409602506,7.65693863151829],[-3.86976499613203,1.87417340844528,4.03605946003389],[3.29824557427741,-8.99717612374063,-0.3314020975291],[-3.59127523826039,12.6705783483832,4.03544795624709],[2.60810336159688,-9.03593832505456,0.304993502568674],[0.732540573062202,0.156178909617005,-2.62340168833832],[-2.93966499929611,0.757019094175124,3.33702700349086],[2.33576778917002,3.79651475842528,-6.19013539623361],[2.63596876819435,3.24336282899936,0.722091251962523],[1.45990616617672,5.50516807273233,7.6051631897891],[9.06851152847685,3.31867996714695,-1.45318161802968],[-3.64279916058515,7.14700613961636,-1.19750704929479],[4.45514145352055,4.89695492440612,2.94022617251102],[-4.89340964373934,6.92664198636319,7.43347758288528],[0.140041525244782,-6.94728909717592,-5.90127744426774],[8.73201434529912,-2.29621145653586,-4.01057771285846],[1.76808664230686,-3.32572008864347,12.3291038558811],[1.21398845110035,-3.81664598521532,10.3852892844201],[-4.41357190622055,-6.33920275528,-2.00694830052678],[1.89473905609412,11.7609599423982,-2.10258731185772],[2.42361253310703,-9.49193085178652,-2.2413852745384],[-6.20389073486982,-2.7954566437649,-5.22406914947718],[-1.30239704879318,1.59089601613892,-2.41491337854972],[3.0346935171974,10.9495530689351,-2.15360199091045],[1.52005275420605,-10.1364474855797,1.16277279130171],[1.94622074616364,-3.59252085730302,11.3642240583697],[-4.51085401871917,-5.62952429940539,-1.52920226948914],[2.32644879418122,-6.88369349385832,-2.15654848670822],[-9.01129518049088,-6.63049696565082,0.753597438197909],[-4.41957397559574,-6.0513962857305,-9.22504219200347],[-2.09998963092252,-0.951987663884343,1.00015533385101],[-6.25887174776277,2.63140997791811,-5.28421243333513],[-7.33899843968027,-5.54352748057627,7.04293019162321],[8.66920342454805,1.14271918364903,-1.08208314471133],[0.556877285051843,-2.85810996040473,10.9790479767697],[0.784608137026522,-2.89402198366861,12.1809593178926],[-4.34613879896079,-1.0121859098031,2.11039081552246],[2.25765722648396,-4.52853005016963,12.4800748493744],[-0.510187903734583,-7.35315008530035,1.73236343139641],[11.5893458558811,-0.332474796394255,1.17321462165823],[-5.82377545938041,6.75105995506325,8.77894974477785],[3.69706855503239,6.11617067165363,8.30573321021858],[-3.67464844949552,7.13265965804489,9.04439882918699],[1.91343416059143,-4.29194775759765,10.8226678716641],[2.83378524961662,-4.07195416718117,11.3416996793093],[-3.65214785724986,5.64254344224222,-2.00421917044386],[2.18056903456052,6.76990977730855,7.2606234231005],[-3.58261687993259,5.65371518490386,0.185418438908026],[1.23928247733765,-4.19373918777448,10.5440823376516],[-4.75159229208384,7.74632827175827,-6.52892298247035],[4.06698593278437,4.50231543622291,8.46281163494033],[-4.78287138174086,-2.18153130991979,-4.56743648891029],[7.07118112169281,4.85742860224977,-0.356321192841677],[-4.65778638145214,-0.513395401756592,4.79814345315874],[-5.6891772886446,-3.17827958493748,4.47602258732797],[0.472660281017957,-8.58274537509856,0.48036749474217],[0.996699881194969,-4.62682513033819,10.7046860745485],[2.69036535110346,11.2381360661746,-2.21128945792814],[-4.94642661776515,-0.47915177253431,1.11576164605975],[-4.78870909188356,-0.810424339350565,4.36289180234261],[-2.77073632858903,5.57268400307711,-3.03740219935312],[-2.70139155114001,6.8171931018773,-0.0545874436353674],[7.5551056654174,4.49978502287921,-1.07127049176883],[-2.11898806347375,5.08697445092585,-3.15591733133972],[3.42449715624253,-9.78722205720096,-0.958220423378713],[0.043204189725085,8.56658054090462,-7.48717899204392],[-1.15685142240173,-6.72617994967463,-1.35210660668528],[4.56520658869554,2.02698767839376,-9.66742715836129],[-5.76209376338408,-4.6294177947076,-4.01639538475943],[3.16492282149686,-3.17179612346663,-10.4549221301523],[3.70160931461868,2.08950492000495,-10.422406239906],[-4.64056468733137,-2.83498532286603,-3.19948272709759],[-7.10753998715,-5.90657401082507,-0.439103331542769],[0.113728432655716,4.07659570007743,-3.53143062626385],[-3.77617240682152,-2.86785991406448,-1.84518210077356],[-2.75363763659259,2.27028559567808,-5.35025001010256],[1.10586077777044,2.19294457341001,-2.94963685391703],[-2.71864542973563,4.59865627099265,0.349968285540564],[-5.57548790191135,6.80678175462046,8.61505087025055],[10.1105927300802,4.15366619995364,-2.42203815175103],[-4.80344977654695,-3.72055833600334,-1.79530802836719],[-2.66252755112979,-3.94331946592429,0.540422034764767],[2.38764043509104,5.82646252422364,7.7707779246031],[-5.16108502451025,-0.23851719829235,-1.70144191555211],[-4.5010781508463,-3.31524164676985,-8.81952942740915],[-2.88099000821429,-2.65851887794655,-7.17482546347399],[-1.93358524356191,6.62846800644143,-1.29334863773508],[-3.32194532694521,7.03196087148711,-0.337367577642865],[-2.52937146661248,4.79835621348874,-7.39223800840039],[-4.96278672026319,-5.68972802358847,7.89200720721095],[8.38929667401725,-3.0400990543521,-4.68122398092379],[2.3649491468834,-2.79798979530534,9.74787857991986],[-5.70841314219882,6.82622800828508,8.66600379908239],[-2.57297036366755,0.335949727347673,3.47609321191644],[-6.15569988545692,7.6524655183151,8.52119995721471],[3.90770544728265,-6.95010224451628,-1.83613544434003],[-0.835835531003197,-4.32842858869948,11.4677496672161],[-2.91255189211807,-2.46646967614906,-0.503153160660233],[-4.42916048614686,9.33649827833741,-4.49901538730829],[-4.72712801110744,-6.05653909911815,-2.49111531941332],[1.05036781067133,-2.97367409846373,-11.9338136900389],[1.35754650096842,-0.725432475006643,-9.62298333097149],[-2.02116064826202,8.97490864112858,3.28608349479298],[-5.43707879476104,-5.61121062434761,-0.871600901193548],[2.20797958931914,-8.69771573499082,-0.401002207280678],[-2.34587756164128,5.50491999941915,-2.80630490796708],[-0.0310560074626738,0.310947097482986,-2.60593583617304],[1.95782848067452,-1.7564185391882,-6.63926846509877],[-1.08358985437407,-7.48975775390878,-5.62715344431159],[1.98447333611317,0.34170387915913,3.97381882714747],[10.0131303379676,2.67716729170438,-1.54293977936981],[2.63005949905758,-7.64055252583108,-1.65094481153279],[-3.33234058701291,-2.43068893621514,4.60623901318887],[-1.52940946601647,-6.90456427901253,-1.2463792080459],[4.00790830149288,10.8163943888879,-2.07124358610091],[0.59272289111876,-4.6856879619784,-5.62881677035597],[-4.38859070053287,6.59434568413386,9.15306434815646],[-2.84378026447894,-2.52180483571901,-4.66017302302093],[9.6009676290538,-4.83011838037267,-4.09514873379763],[-2.79424601276489,3.57404925175568,-6.42176940741634],[3.47847228059281,-6.13407016963115,-4.74607403671483],[-0.591910407427334,0.211737478287541,-1.97575611984032],[-4.74583808045884,5.86468343531521,-0.570005756793435],[-3.01339356418572,-3.07779730420156,-2.74802115698827],[0.747098425317754,-5.56983632465442,10.8359545219747],[1.15127639832128,-7.29050426700196,3.70135868611214],[-1.4846969746874,1.10113123680468,-1.7981221304793],[3.11542475273874,11.4353323708736,-1.00054435250881],[-1.54587948354435,3.07558838257916,-2.16232681629201],[8.47663613158107,4.01510137633214,-2.25744476210085],[0.945569857223493,3.09606852596363,-6.86034045210789],[-7.13441601135548,2.79510692437363,-4.76322653470186],[9.87230927425075,-5.06403008406027,-5.33189296717613],[2.64640191668531,6.75031981980951,7.19239671318105],[-2.05318944948402,6.57831485604644,-0.939858775712589],[-2.87099909513867,0.0699322360144841,1.60347246941634],[3.67984859167043,6.00263527088861,7.58821693263819],[-6.96579636353549,-5.0800138575422,7.43682279291502],[2.25116160927523,2.5158235484872,0.934675905664351],[-3.61417063651103,1.52993784403447,3.68397334159835],[2.09416707077709,6.01920707092687,7.30341486343392],[-4.08154950000709,-0.388043389052341,3.86477250184042],[0.0354357725620648,-2.70419848623527,-1.03049076951239],[6.1467491199879,-0.600052795970788,-10.1091777995786],[-3.16459070047969,4.3844527851484,0.699221529053412],[0.989949499123219,-5.60268440700442,4.34107764711558],[-4.12577931042753,0.129901522580226,4.62692799638453],[-5.34376071658525,-3.30747132724025,-4.90288594056424],[0.875813118684214,-7.94203532855617,1.27903700950836],[1.16943564907093,2.37445219388482,-3.72975317379498],[2.98751678465537,-2.99373104837082,11.0282151162451],[-3.49252716433423,-1.48837695285089,3.93439857925907],[-8.08177454796455,-6.93207723811148,1.58513082764386],[-5.1380466515518,-1.60126098471978,-0.895891226982467],[-1.2513469474158,3.29878869570376,-2.6016284406384],[-4.43491143854731,-6.99167840536408,-2.34048674462858],[3.04050662194592,-9.570470991125,-0.951113336950361],[-2.10204415529436,8.71902028265365,2.89710608669684],[3.87479988785776,-8.34694902770065,0.192033498408799],[1.15637216203673,3.71868915593915,-4.13621219407701],[-1.95743392757518,-3.19515808566106,-0.377031022760517],[0.842161895766056,-5.72711680835526,4.49741555081956],[3.78525616403392,-8.5375821182822,-0.371522200903343],[-2.13502284061158,-3.27197797125234,-0.404478193275388],[4.12415150667474,-6.38245320784813,-2.07631447221413],[-6.7371522825417,2.66584437720685,-5.07946149016244],[-1.74778921591105,-1.19267395026188,0.980832468928135],[3.07110277851271,11.440926507632,-2.71415096857535],[-7.97861166063135,-6.85945676317037,1.77273258516018],[-4.73447913879334,5.72198568889842,8.64306790143618],[4.13708499447645,-0.449313064490897,-6.19988349113734],[3.09043513361726,11.3027552944977,-1.10151291787437],[11.2061595174125,1.40648045277677,-1.93392100659843],[-4.68069189870529,0.0286647938720428,-1.25155440737502],[2.75962315806638,-6.21673525023854,-0.552742855400846],[-9.37087662073626,0.085647198157995,-5.29192205493788],[3.12814667620166,-2.80102486056533,-6.83796852283239],[1.9801657553376,4.52867553188176,8.05344849461684],[3.22276280996241,11.9624611687052,-2.19514265847739],[9.63204040473016,2.57181787370568,0.31927837362682],[-2.88295418647632,-4.74154878998667,-8.79839148174633],[-3.44845811335398,12.6194626656209,4.08467129573499],[-2.86832902445002,4.62800731751814,-7.74962324986342],[-0.202487584721767,-2.32545121360662,11.3831552649811],[8.8826903014075,2.87867229138733,-2.07778129325122],[2.03312145092906,-8.31139235758214,0.264472752794191],[4.80775438277778,-0.628700962187152,-2.95081832199536],[3.23432062416014,11.2280133749775,-1.94469605829437],[2.78113525572685,-10.190958543427,-1.18094729781049],[3.89039976409537,10.5964731496733,-0.901804737758963],[0.369847158686194,-9.26802528759113,1.73365086434665],[1.23246969233161,-9.42382021141833,2.39929779620954],[-1.38620384095578,-6.30338729566394,-0.393624226348516],[10.1754668743246,4.25663356966444,-1.50380942739596],[-5.60256307862179,-4.02207550476519,-4.16205733569114],[-6.76198468905867,-5.73603965938265,7.38374704635753],[-4.17331761744024,6.20404363929906,9.18878581361601],[1.61799243595815,6.27552894659539,6.95105559309161],[2.26676635779115,-10.4103473876868,-1.07524096245963],[-5.20228289425494,0.890957570481299,4.66413198674036],[-4.77020856587565,9.21458654500474,-7.60149688431556],[2.93749618467969,0.389265354340183,-11.6163184535361],[-8.1931231131166,-6.87391676094134,1.2008797240215],[7.32030253298499,-1.33017428775799,-10.8806632839034],[-0.966086872317322,1.80175629234939,1.67526823991856],[-3.61768428319478,5.17358550014116,0.234698079950362],[3.77410130927975,2.21999795621514,-10.3178298854953],[-1.28740212939129,-7.12295151367501,-0.308431850415698],[0.728330000161778,-0.0000559004339523161,3.08821296147322],[4.38238281268289,-5.84026134368651,-1.54878538916457],[-0.178947525293862,8.81360056272024,-7.70093324007582],[1.47950376614657,0.467878909366341,3.30364241838506],[3.77697849618677,10.5017645557537,-2.03542613189248],[-6.37967385950506,9.23656310390685,-4.68079826039111],[-3.98539821144678,5.08492291541822,-2.84409137116415],[9.82552044763338,2.6086639118341,-2.34664204850556],[-9.34378669756667,-0.545710481100209,-5.17408613478519],[3.99467981710241,5.70594543457168,2.09451324866378],[2.85623034466113,-3.72582260870548,-10.9267769282011],[3.33601560755441,10.8193889844536,-1.22901319221502],[0.957942144098058,-4.92216382445044,-5.13134478492846],[-4.65062216243599,-5.83952010531592,7.46376738286702],[10.2620192356069,3.85716570132257,-2.7444298768027],[-1.73230804219358,-5.37851734260385,1.96146209255897],[-5.26184018027478,-3.00291864115058,-4.70590093693115],[4.40418866485188,2.34150621210731,-10.3132187359504],[1.48585381697294,-3.9463337366416,-1.43087266157512],[3.6295632767569,6.44625534535574,7.05647718594487],[-8.87081511950581,-5.88072912799454,1.12778089634433],[-4.85622748861295,-2.89758360409899,-3.65844292544458],[-3.05894814266188,-3.90605666948494,-8.92332733940939],[-2.50576392276602,-5.10998890319873,-8.40601644915016],[-3.48711725720866,0.884552755133215,4.8353203328342],[3.42219857400675,-3.2985981081022,10.6924948936982],[6.63942996827797,-0.658535982648538,-10.53289519971],[3.41513270261218,-4.42989291687456,-1.83709538233016],[2.3686626582082,-8.75188163745652,-0.348817926133847],[-4.99548445717425,-5.02691931772427,-1.80623163964143],[-5.16759583927727,6.89687457822855,8.52254253758349],[-7.00194342862113,-5.84383444468776,6.45706722993905],[10.9064165942904,5.56066703588846,-1.45259989882381],[8.07006997075646,2.99353847361044,-0.985403470493114],[-2.70805613250989,-3.03526178469449,0.00876309881682535],[0.0258709317602438,-2.15233361278222,1.54166832618362],[2.40469594871412,0.477554751344829,3.72541880360628],[0.399580367793113,0.829165679210076,-2.59087730701279],[3.75496795761331,3.4497957411179,8.83606446706022],[3.64552177469426,4.50675049974425,1.86947331638891],[-9.018439833731,-1.2022071315098,-3.93536936577343],[5.27876285616045,-2.80649019144936,-3.79810144336271],[1.96413399096821,-4.63119266053916,-0.479159303082621],[-0.454533711786487,6.92616763168082,-8.48720772424957],[2.26458726160326,-2.46849922201254,-8.11171209192249],[-2.55045059971761,6.78147118522483,8.40077911559116],[2.66578038121778,-2.63564686424493,9.31650567476197],[5.11580960219244,1.57839944219063,5.19105432305924],[-3.59133913264234,-2.32525471690636,3.55230839405345],[2.6302397354218,5.06277362339166,7.01381908912545],[2.25359859740309,-10.3966122664872,-0.365453964823538],[-2.16581933669784,-5.02388254873775,-2.36091254933367],[-5.48567671650368,9.99800896411119,-7.12873382873746],[0.837796809632252,-5.33714118691538,-5.26145609328228],[-5.0052838942639,-1.11076317990824,2.24892110501486],[-2.06045247951333,-3.46251130125746,-0.902949880965509],[-2.70063819207073,1.0727897183881,3.59882188471708],[-3.05943444167532,6.85271677291065,-0.867232129943609],[1.01783146209529,0.0851386287042282,3.3309230363471],[2.96757158124249,2.72436359697795,2.96590138412714],[7.18340460135068,-1.45906239094578,-10.6451819118401],[-3.24880803123323,0.992171456632373,3.50794767651624],[-3.60302702082845,4.8575116208892,-5.34968032875245],[1.62908647517879,-7.77514942415162,3.75857275075884],[-4.39342870381156,6.72999885178013,-4.99844906799998],[-6.86857130443554,-5.61633469920369,7.50706930272642],[-6.2075165861583,3.42765856742185,-5.6418396569455],[1.68256392178834,-5.18486823848982,3.32830708169089],[1.04001691191563,-6.72075224377101,4.22170658586429],[0.0899040463596438,-3.32450149683604,-0.629792104497576],[-2.21034318100873,-3.30854242733837,-9.67715815006404],[-2.73541842325763,-3.64451256627998,-8.39685021236171],[1.67376106901567,-5.68415832183674,11.3985859404347],[-0.242056425833304,-7.20755935085192,1.16135894990619],[5.64216491682,2.89468557380031,2.10540707089015],[-2.97225112817173,6.91526878469582,0.134252171822681],[0.00535956592348985,1.08948359784273,4.14431509743878],[-2.9279980043614,4.81902227903471,-2.8631692421114],[3.55933577991875,5.78688758075538,8.83915307783797],[-2.50101041015843,-4.38805627028878,0.102486716628324],[-4.27714246362866,-5.88508133203771,-9.18706639198374],[1.98767593436285,-5.02026611879701,4.47202567367149],[2.71936724731927,-1.86517137162222,-7.2605295318238],[-3.7701705317596,-0.0278182086720303,2.97498743731893],[1.96711121144837,-8.11822952721269,3.85436339608142],[-4.66402798697467,-3.01021322636828,-3.23116088545098],[-0.103968931532519,0.348376992020513,3.65486199349287],[-4.80768553192961,-0.61329087683229,2.15979499290654],[8.86706500352662,-4.12244831851774,-4.17488114609827],[4.04412150853415,5.90494283049402,8.35104436939045],[-4.77954068015622,-0.272684353703411,-0.942417769426254],[2.61287861629399,-10.45985752253,-0.0827907462320588],[3.7624424102291,10.7709984188689,-1.90879987927231],[-2.2326408455721,0.136640967419461,-4.79673077564232],[-5.2980896298493,6.76160942508797,8.9988196746539],[-5.70313235908765,-1.09644705110969,-1.36450177919667],[-2.00354063679756,-4.85912253233272,2.21347327034712],[9.06110099951523,-2.45832492209992,-3.16881362077677],[-4.66514813733462,-6.65013858801573,-2.40510334253173],[-6.31470415013207,2.60977182254118,-5.56778349078481],[1.37139589531463,2.35515572812325,-3.50084173308166],[-4.49265173262976,-0.729369373789274,1.72083857462693],[3.21790550832092,-6.43917693911991,-1.16463675326557],[4.01483024331686,-7.93014973068647,-0.564097684962563],[-4.50887400716875,0.66684346685911,3.17251441030786],[-8.87142687235603,0.290684996635021,-5.6814431959318],[-4.90994232870818,-1.50862114271566,4.23581735404491],[2.50777368017356,-3.6918669937509,-11.1823350027588],[0.151044310882939,9.36351865710349,-7.39594217127707],[2.67601467490939,-4.19276114147344,-1.43933814909322],[3.44673068092785,11.5293034034533,-2.24322882313051],[-5.00623155033182,-5.59662110442098,7.70610666492048],[3.11798840581121,6.63618464978944,7.5222609060823],[-3.08736649753414,-3.54688485251274,-1.01427019567392],[1.40588433253783,-8.92285784732155,2.70018267807765],[-2.0871680984243,0.79700480742255,3.04160653599519],[2.6363731694073,6.18398021945659,-11.5758551175722],[2.73269217492172,-8.86020064378253,2.20734100661932],[4.01448826849071,1.25063831152768,-9.69388246603545],[1.50136714818517,-4.48486302783233,-1.3521431249941],[2.84893300780321,0.112972212642448,-12.1154188910476],[4.19433404959111,10.9064085399777,-2.24740388650078],[3.20513112168626,-4.59589801050459,10.3498004495265],[-2.58033666751216,-3.42644930468091,6.53207106902296],[2.9034274581411,9.92620577022028,-1.45370225468376],[1.12835995748831,-5.86342749984094,4.97179900295201],[0.885265200341549,-8.07318803798758,3.17718628894917],[1.29920289314344,-3.0853264483149,12.4092568650613],[3.52224021655857,11.656515737072,-1.16896540971749],[-2.87326181570384,0.304156080345887,5.46529004654071],[2.10920043219083,6.66448047214355,7.64500514202395],[1.48860319873702,2.87818314583233,-3.18956380896285],[0.205689369316665,0.275256611972857,-6.50905634813767],[9.49713224915201,-4.56212460653708,-5.97471098320224],[-3.48498401058446,5.85449763931157,-2.08774697096346],[-2.99480826419108,-3.40481242279455,-7.97147556551466],[2.08351488331683,3.94957183176568,-5.72314616536492],[-1.32048157422739,-2.70685764787492,-12.1364888053818],[-5.81174602324365,-0.52230196150271,-1.4960608582402],[-2.97807148390783,6.12479999727176,-0.377989881522311],[1.47969048191275,-9.47970615931717,1.73183799193594],[8.14895394476555,5.90559465998928,2.25420600861921],[-6.72839119933668,9.57372094199457,-4.36526778444852],[3.93575309415146,-0.178913835929339,-2.91695139461396],[-2.636005460846,-0.36013551388772,1.85754411231364],[8.71162403917442,-2.06097198877611,-3.30528984521909],[-2.71298598496089,0.916217453512791,-1.01632475561818],[-5.55029619251257,-6.118523648141,7.45009573308581],[3.16596433223046,-0.594928149838225,-12.1366088090896],[-4.27231229661718,1.93945052807838,5.28754334679086],[1.37342226563211,-3.87797657014672,12.6445646258973],[3.07506641340132,-9.31845369364664,0.645035531737234],[1.4358002255403,-3.88638212081063,-0.0215629987694723],[-4.08666650151673,-5.31436909537033,-2.17502855735802],[-4.34052577328218,5.80724093043751,-0.802208222748851],[7.76013569332618,5.36767598264192,2.63235366427929],[4.60005478400815,5.19888805735679,8.93536003906438],[-4.68308428241567,-0.543639579504243,2.13460223912331],[-0.377778186501427,1.00720644347313,4.33811983903963],[-2.70631059020264,-2.62534713262943,0.0511819278046136],[2.42153433261096,-0.320187260035731,-7.14578798173668],[1.59791590997676,5.77315706022444,7.1865600117594],[3.47503772566419,-5.47124517550888,-1.14767239212753],[-3.69581830736703,0.440745453209191,2.76869319497783],[3.14672622511248,12.1546611808075,-2.37230267337326],[-7.67430174472933,-5.56462327868048,1.8622479727549],[2.66460159509287,4.02612034377158,7.74459358521865],[-0.424960110562173,-7.53975655150728,-6.05074581152523],[0.931090959266896,-3.52988391439011,9.29981900559608],[4.5456956566773,-0.043266562931056,-3.46944051087562],[3.63178148070817,4.51649749548904,8.83851718591144],[-5.18170082125769,-3.95467243701997,-1.84007952263509],[3.22765313208591,-7.40615250103388,-0.264139944629626],[2.00635678832012,1.45430192999788,-10.1199883919541],[7.52168979783641,-1.69794788177551,-10.6786325938038],[-0.988563450633848,0.392168895157571,-7.15570528309707],[-3.71313568581371,6.11526729748663,-0.922715031140559],[2.46077404238149,4.1959158894506,8.36035489500383],[3.15887021549375,4.43414298477012,8.0322880770923],[1.08552298131081,2.09964304180286,-2.84214102712385],[2.74402054776611,11.2554211425263,-2.63894142316482],[10.5278978923402,3.4440855560069,-2.18578865231275],[-4.89423018065678,8.3902953952264,-5.04667312721336],[-1.87169045384196,-5.04342750561935,1.77130613987119],[-5.36937287615361,-5.99504333126853,7.70225818842864],[-2.8812585319832,-4.15941494773488,-0.204715468514852],[0.62768285334423,2.75680346267232,-6.62437048383961],[0.598110475115304,-9.62890416555188,1.48998738101245],[3.98044878939648,0.576631667902407,-8.81819541359807],[-6.07762640692881,-3.43727254527718,-1.55837672345339],[7.14561802022581,4.79982719733959,-0.457668870918454],[-1.90810754959436,-3.88130094666201,0.123016924424113],[-3.28650001641069,-3.94005850163595,-1.4018316083924],[-1.62852533575847,3.65526321583492,-2.62212944005222],[-5.45282403258285,2.72696160572344,-4.75799740650137],[2.35003874370554,-9.7832931510266,1.87818305483883],[-3.39545610521057,0.00511096761482421,5.78542167813919],[-4.21194089235004,8.49749585759064,-7.25338564324033],[-6.65733797524527,8.88930659828659,-4.66744783011158],[2.51747640089848,-10.3116473788386,-1.14405824887937],[-6.45963906026569,-4.27774065937095,-3.40340426895286],[1.09275086716415,-3.77008379033758,9.88519408730314],[1.814627267646,11.2575022129731,-2.06867022785329],[-0.224806282104749,-8.70012920538564,1.1637936820726],[4.45750236475774,5.34332970728593,8.12450926308131],[2.88072892761945,-4.06936886767804,-2.06626764732085],[-6.0920921909633,-3.55794312121223,4.69310642281759],[-3.26196479325291,0.448829455659255,5.13110495603356],[-6.73793670673387,3.33637300966339,-4.49843515506213],[3.05126413050654,6.68855909036806,8.10772520005966],[4.25247986176533,-5.4007378952961,-1.89544017882853],[2.17385845057714,-7.82757456887723,-10.9661604324307],[3.73761471656107,0.112300567335089,-9.7019354866297],[8.18853150022452,4.27558519743492,-1.43991347099736],[-1.34103601722842,3.15714684047905,-2.35191591442964],[0.865007490855933,-5.40219942658218,4.21628069111379],[-3.95805238698421,12.5713248183515,4.35538954239312],[-3.888050839889,6.24203666762417,-1.35770942059024],[8.84104678791855,0.356678960875702,-1.25941616598928],[3.12647261987141,6.02313845605051,7.78301416289397],[2.45352946367419,5.92090732359687,-11.950810928373],[1.83373659925602,4.9783338763784,7.24644698191164],[-3.8206926999178,7.89713059124916,8.43501320681556],[1.70301807343481,0.256764104415707,4.39418682472249],[9.4477755134429,3.32304522329712,-3.42905706256911],[1.21134442484442,2.05870510646206,-2.8332241334983],[11.1589537848045,2.10652500300253,-1.38690661493099],[-5.21023277248018,-6.48551790897869,7.55633188451236],[-4.92446531955109,-3.57804137442796,-1.65951042526995],[3.03469506262655,-5.17938202624549,11.0107499703002],[1.37559042501702,-8.44829134396598,3.26352862464315],[2.10214108410174,4.06842659627737,7.79313339940427],[-7.39580842761495,-6.82969514545758,1.36283584411453],[-6.21300691784351,-4.55933295183601,-4.07212958857401],[-4.54688799962254,7.47175022309551,8.20192367644697],[1.86566618065005,3.48379696006963,-5.97726692459452],[11.7127578476017,0.776083121242948,-0.964486355290048],[2.03640736275194,5.99450552071308,8.44978031923357],[-3.41092935757662,0.643349595841071,4.63975401243442],[0.648888500333962,-0.345060153809204,-6.41547868317602],[3.17406375876849,4.10462033655169,8.74185852735444],[10.2673736243711,2.71205352677787,-2.2351786560691],[2.36770368602603,-0.659311601242885,-7.48138473438925],[1.1162363340541,12.4741878801569,-1.50916364200404],[2.73214331234267,-10.5094206064245,-0.930702835150392],[3.86397070835321,-4.66879689940439,-2.51778561256531],[-0.679935191748379,6.34534006047733,9.11781796062316],[-3.6086415765966,6.80307164873804,-0.141319448873618],[2.84601029971392,0.0794509500647718,-11.4787133720163],[3.4784933360249,11.3371549537509,-2.60906253072763],[-4.10240665552117,1.5199462583691,3.27934595482895],[2.44072257244187,6.32477626053617,8.2467396385936],[3.45574204124374,-4.39233750814125,-1.82746048521287],[3.43453172396362,10.3496813122665,-1.79031691791041],[0.625096052073061,-5.80572164245908,4.15115912985608],[3.44050137138226,1.90358046733947,-10.2416836463712],[2.84909181751262,12.1572532099245,-1.50186465472164],[-4.42310388175218,-7.20072823910634,-1.89684446570778],[-0.0660787737760946,4.16792989642257,-2.80377517726732],[-5.85856464286117,-0.433784036245219,-1.13204801500077],[4.22381623794294,1.44688616783646,2.50450825060818],[1.75558655520271,3.96265356829991,-4.14585103283392],[-3.09574201992984,-6.16401274472438,5.86358749340901],[5.37328531722969,2.90894766552901,2.08277081560762],[-7.04424390651217,-6.42003031415549,0.254322818354719],[-4.44058074538095,-4.89107990970354,-1.77616221748703],[-6.84529925706076,-5.24506932111702,7.1361215434598],[-9.34107234093145,-1.86576189959339,-3.80108496283057],[1.59230319685337,-5.66180143958804,11.0210840658172],[-4.7350173968069,6.90012237732209,8.28590832222118],[0.868205421825882,2.49222231248757,-3.27003231064416],[9.04570617840403,1.78479976473994,1.48231408487689],[-9.67510576573333,1.17854826561765,-6.44991071111834],[8.64344933745484,7.03611818094613,1.10552244881694],[3.35317105635234,-8.43268560427893,-1.23855435083887],[-0.766881681583552,4.30762464457609,-2.02375548022316],[0.567977085734991,0.607417848742532,3.16448987066278],[-4.7696373570849,0.844780069787622,4.51821546287599],[1.4036763806453,6.52355909090547,7.44461616770783],[-6.05141350089974,3.44756142671151,-6.17595117035244],[0.891405930137011,-8.26837685866534,1.58780979962998],[-1.37838638385857,-1.3718656547427,0.684319916637058],[2.43461932276672,-4.84252167127997,10.5444483596652],[8.09457795622069,1.9791452088998,-1.25821406864655],[4.38501124143546,1.72332903989444,-9.49590801431042],[0.763730539194174,-4.16483092057162,-2.22033202050606],[1.48779050048312,-4.20057620330684,12.4913817488131],[-1.68418339474684,5.58779467624006,-0.832492617742752],[-3.65155988156489,12.6232736710019,4.35867958643131],[1.44378202622097,-7.05231805481969,4.61048583975055],[-1.7300977453101,-4.88604716637407,-1.75335005949518],[9.78605122388735,4.19945084849411,-2.39767994608354],[1.18512633070654,-5.18258217146857,10.8552334822798],[1.60009087807949,-5.49563537099532,3.73985591477494],[-5.73612862513688,-6.46033697960705,-1.56645644003731],[-4.33675593145609,6.78732344940093,8.22363220910639],[-6.37432561686695,-1.87236759753937,3.83041924027565],[-0.311577465167004,0.941145528210487,3.73221604876646],[-0.696638783823411,-7.66861708998413,0.850603724742318],[2.93299762124373,6.16647650550533,6.96262546862263],[1.06982880110244,-4.49517195629055,3.73684523366294],[1.20167461706216,2.95927178750428,-3.91943430570244],[-8.4295907552258,-5.49456662377085,0.521163721475644],[-6.66748111537345,-7.04310346985021,1.20248735754852],[0.106285619895481,-1.70884763163755,-11.2146834457277],[5.9910629974037,-0.475083845382883,-10.0437584284015],[7.71609049369321,-1.91588226254717,-10.9633501054395],[2.6000718133631,6.50887839291321,-11.5704589913293],[2.46355794062965,4.69491849131079,8.2943597120167],[6.99795373197359,4.13642436132571,0.284304930794686],[-5.0170449017431,-1.34425257138223,1.58006319333252],[2.69835649830085,-3.31768716340901,-11.0164904687263],[11.05446061299,4.14347201876555,-1.9857809540324],[0.991961171605729,-4.31770818782065,2.35014947340753],[-2.08572586606179,8.7473304103198,3.34203706137435],[0.568147983167679,-4.99710876052122,10.8297711457504],[2.8808768823556,6.30079007772926,-11.2286792936546],[-4.70730876843356,3.41700327002183,-6.5253179764354],[-5.0201936751329,-2.98049793616922,-3.73796928165886],[-6.66348835853846,3.24303322047748,-4.39948495588701],[1.45585039652654,-2.38947577755764,-8.08328553252595],[1.77240376258898,5.25646979079878,8.30751039383385],[-6.43468890090093,7.32389500342653,9.04399940909028],[1.34229678207515,-7.38683533130823,1.66531431258408],[-3.61171431087177,-3.92197089218104,-3.30794026267406],[-5.80125346555353,6.73970799513317,8.89104662601327],[1.3708962674714,3.81089980865925,-7.17170219735917],[-4.97013204674363,-6.54586075112425,7.65589082559166],[-1.22673690971994,-3.73908156150851,-1.03364927788355],[-3.62656989193777,11.7894971296723,3.6336185118904],[1.27549408712827,-6.31588021999425,3.8215346900511],[-9.77874018516576,0.728223242225969,-5.70312344002569],[-4.14223153191369,2.16875937524266,4.22668477906602],[1.33244023496376,-3.83810666531203,12.7175534364698],[1.66380228212981,10.9500218072325,-2.42551350947287],[8.60134091498326,-3.19616300561044,-4.20778853680821],[-2.81141560657336,6.2525210088073,0.16038388354059],[-6.35672736591563,7.03913200190554,8.54050525394357],[2.6588093525301,10.7137081622159,-1.33187456399417],[-8.21517877066699,-6.12765169914194,0.274816961294195],[-4.7317617183601,-4.22536459572781,-1.70895911686042],[-4.1936843218511,1.01141992832877,2.78188649823686],[2.68917713673331,6.08670435386247,9.49315675443456],[9.4269363007263,-4.69266006650362,-5.89035894288146],[-2.61561750632585,-3.8134057974649,6.64173440276128],[4.23992805130123,-6.44892591841623,-1.66958407755623],[1.39315410231833,-2.12555544864004,-8.16341750559771],[11.2245612200321,2.23589355511599,-2.26177963382131],[-5.97883503120926,-3.52638478278002,4.4009150932631],[7.68713253917975,5.32557043469508,2.47473181624262],[-2.35592870827397,-3.58661604178314,0.321695083215811],[3.22050576243245,-4.30623217908085,10.1544542861402],[2.94819924382865,-5.87400621742398,-5.56297739652583],[-2.94871400225121,6.62766473531932,0.313470869685058],[1.6249762258223,4.01894933152136,-6.42830382586517],[2.35838430786356,-8.99465955417041,-0.223385848943321],[3.68004501504634,-3.0314326229333,-3.63165823522515],[1.36846336016067,-9.02681868605054,1.8707434149881],[-6.30541478594591,3.44063705540208,-4.91385182608294],[-7.2379702051457,-5.96508181475403,-0.395258747824854],[-7.66098526371399,-0.0583140143306394,-8.60651682759507],[1.25592450113839,-5.59714996566994,-6.05298750428456],[2.76404810315123,-2.00544614034157,-7.30858909975989],[4.52740707037824,5.60073813188135,8.89487343076824],[1.43434975247349,-6.8751753669306,-0.21039558477633],[2.11811130327522,0.267078556305521,3.40804912264655],[2.7570695280734,6.25160392037421,-11.3330880326238],[3.68064224608703,-4.73736808117329,-1.2354571066718],[3.33050947225394,11.3716684693119,-0.799813164124516],[0.0704946725109284,-7.2081037733325,1.09654062698315],[2.60115079065659,6.35321389468724,7.94252004457331],[4.58880488231045,2.13782430310269,-9.40497819818083],[2.95926349736974,11.8786127719682,-2.49888967251578],[1.52366141756113,-4.20646322842293,0.0294773000119999],[7.18586715237011,-2.83200422945707,-4.28629579327445],[-0.0345760933418797,0.705285072397917,3.83575098913847],[-6.45220422002009,-4.12155140959121,-3.7733848739151],[2.20820952072508,-2.85240363967424,-7.58993930453982],[1.73394824096271,-5.44451686175101,0.299637704833411],[1.87038088706853,11.3388846154056,-2.73123909806243],[1.60852842070232,-6.53838415283847,-1.15400175847279],[-4.30253951691614,-4.33548118205247,-1.23003528729058],[0.38480391683012,-8.07867699522959,1.44189427180352],[0.838547430356187,-0.198959945857429,3.17121022819902],[3.51923576501363,5.6790074294643,8.09677204492667],[3.25710042179745,-2.64855300027871,-6.69779285322643],[-3.74948483868001,1.81514360085467,-6.26875300679936],[1.72150175663734,4.41761742595061,7.48984135486527],[3.18393742193077,-9.69604332008227,-0.609917218790318],[-2.36991655636138,6.1448862495682,0.315251925262405],[3.98241706056398,5.76817229662901,7.70372416725677],[3.00923525682199,-6.9196590665358,-1.32101033430675],[-0.585676834883464,-5.83421689495864,3.82251682969076],[-3.58820429153535,4.89049679860891,-2.51894032022439],[3.56284612243178,11.0736527725885,-1.26325183537734],[-1.9520978693558,0.471314967696613,-2.75232854617478],[1.26429653516101,2.28766957046294,-3.27964287111375],[9.14921269612675,-3.8904275076345,-1.96049857571128],[11.7975858035843,3.29336571303793,-1.68770862862921],[1.59873169010518,1.6995054515855,-4.92753194061669],[2.38416057096731,-7.41734504186564,-10.7816237002217],[3.20832460613798,-3.76927823248274,11.7757066041533],[1.37017641615355,-8.81477583424324,3.16528168154127],[1.85069269639046,-6.17775284988511,3.24938835477244],[0.341101643648989,0.549420048596972,3.11550877935852],[2.35008610780643,6.14611160467549,7.41583089686336],[-9.76708636303349,0.0450889165678862,-5.518083284867],[-5.47699474337043,6.92866252021437,8.7239804471488],[-4.96300414138034,8.13021330478012,-7.14423039344649],[2.76709404775184,-9.37962726354554,-0.782392046782517],[-4.62831013125466,-0.378397164742253,-1.66171353031066],[0.238816999886014,-2.29258789693552,1.55583786946108],[-5.92171811523993,-2.88919896738735,-4.66100007946959],[1.7189723634138,-8.40417074047799,2.32592028733785],[-4.7926599243341,-6.78091087146116,-9.99684336974327],[1.09535113196588,-8.83821560112612,0.262259128323374],[1.6396239937944,6.45657280667829,6.56693377953786],[-4.12926392213307,3.037910069321,5.74989420185301],[1.55838698254548,-4.84724343946209,-0.192887418505989],[0.331557302224659,-2.42006603084712,13.2309461501726],[1.22547008544655,-5.57623330466445,3.62749528332667],[-2.99795784550868,4.87351776163333,-7.46548564973052],[1.87555097203504,-5.37482007882588,4.07112467640165],[-2.01163560732221,0.551338017908753,-2.82187491436261],[1.5608681899881,0.972814963498303,3.27860320952393],[-8.21112708567205,-6.75290788313959,1.62011533949942],[-8.92776440866148,-5.8501286603932,1.01362623640661],[-0.165861234883665,0.582272579620354,3.16133037715918],[-9.60699108511177,1.41405823956648,-6.34762492286678],[2.1943657497364,0.703851474188623,3.05294971396281],[4.39582531478311,-1.36567519639773,-11.4902470317828],[-5.01117223800682,-0.611521957147577,1.27544358539238],[-4.22000845369447,-5.63856947853104,8.11791357190774],[-6.28131611978225,8.30188588714637,-4.08913662381864],[0.978947567708032,-7.30668956591903,0.978414993951778],[3.76293730084673,5.06336379924626,8.56533991502327],[0.342877530915234,-2.67970169835713,12.2508141046179],[-2.87136154986256,6.10217985702392,-1.00276463873926],[1.58129565713151,-5.21847593240297,-6.25544520089306],[0.909033309553319,-3.42390514622642,12.9724348819661],[-5.61099916901301,-2.53470591054029,4.65879564268897],[-4.55672357269545,6.11994984572066,-1.04301860389862],[8.2690016080472,5.46524296563268,-1.09074855302559],[-3.99796394046801,1.9488828165063,3.83755626166473],[7.11679638946867,-1.42447087875992,-10.4790813366745],[1.03775932701043,-3.0466285773641,11.4672930729655],[-5.51510619503103,-1.21459601238858,-1.40691493702817],[-8.37977558289118,-6.48518775550961,0.141431331142719],[1.3413609656436,-7.84795631435945,3.10979541334402],[-0.544871179076384,-7.28820286822897,-5.95982937227157],[2.45830828722957,-9.88756741965537,0.847459581216504],[4.36193759756834,5.92062163098806,8.43374075052602],[0.670660749770022,-3.4668298165075,11.6277831627593],[9.12089606787995,2.73936688251709,-2.93902685644918],[-3.00455154571078,3.77899519106854,-6.67338175727924],[-4.17426243007635,0.942266366626009,2.49956861229282],[2.1138051551951,-8.57362316459709,2.80076865451187],[2.42100481447453,6.08843773912781,7.04422778351407],[-4.78528140311386,0.121427300383622,-1.3999255017447],[8.74548514542921,3.32018467963733,-1.91477380974258],[-3.87704179347933,0.632864349417831,2.76666764436048],[1.55192225787199,5.77323194019023,8.92651351045372],[-8.78305748449716,-6.13179864208302,0.751721759399839],[-3.38346110538148,5.95257562521785,-0.080576562404032],[0.402757889652497,-2.64676820832414,-0.568585095879978],[2.60818563224723,6.42827771393577,-12.1133702347592],[1.34409145970039,-8.81802459459824,1.30709497898658],[1.69841910441143,6.87895134472353,8.30370784908072],[1.71002973548923,1.63183611952233,-10.3524711430874],[10.6731598370607,5.18303009201831,-1.08727002222623],[-9.48435752717099,0.696006580007001,-5.88707558218795],[2.00788201660329,6.10896630396895,9.52823608514706],[-0.481305089771714,4.44640838084444,-3.21512925995325],[2.75626425792144,-2.48518564168845,-7.18206473634142],[-5.92423443729467,2.5382269884707,-6.28886814056086],[-0.444829589091187,-2.45858544426397,11.2874281599604],[0.247773268158531,7.93109148738742,-6.62927585632323],[-7.69638556006738,-6.10146871613345,-0.0554816079512657],[3.07624843614706,4.92413397204908,9.01317773630956],[9.66344610175896,5.04020654621531,-1.58468682920962],[-2.2782331029243,1.33347780379335,3.6745473297477],[-4.18472505796636,6.29491112442533,8.5796584590983],[1.86070623844353,-6.22047439959009,0.352535343926728],[3.23494840888725,-8.80747931165908,0.489548809542802],[1.75655646681281,3.84613439783214,-6.43996387959296],[-4.68371827083058,9.55592752801952,-7.61424655467395],[2.62943421156544,-9.42883331505233,0.900537362992091],[-7.50823449109888,-0.679433279332627,-4.50267539544942],[-2.70706277424854,-0.23263765473422,-3.26361349782472],[-9.42015659891578,-1.28892127340123,-3.76024821930829],[2.56044803591037,6.82608162711362,-11.2254790718982],[9.46457875552029,2.02167599305476,-2.12511986066171],[1.31362662248358,-2.81832320016814,13.0765866597469],[4.44032862711763,4.55994272620346,3.3603061554291],[3.59805846393255,5.37669827572743,7.70198994975584],[1.00494879465327,-8.14481321236834,0.379159902475285],[3.41674481604952,11.6782143036628,-2.5168497928641],[-3.75828164122021,-0.545174991186594,3.09368536583849],[-2.84932331849712,-5.43016871704833,-2.01445160684753],[-4.19955482560316,-5.8147108927826,7.17475298067348],[1.55395303819195,1.3663560740978,2.27183143682397],[-4.08933417385843,-1.40468077238032,1.9796847248203],[8.78229533173074,2.5635997079785,-2.76537900862277],[0.741706375552668,-6.3129272302001,-1.38883685392165],[-4.20880279748834,-5.50869463278977,-9.8312797791533],[1.82048027225609,-6.96222730032035,-0.0960418939923584],[3.40571480456457,6.46889297502055,8.02541137168343],[-3.16163094011263,4.99116151845576,0.60003812102354],[3.65331617522058,5.9699206029645,7.29434309219139],[-6.31264107205851,8.56023241352351,-3.95941338087508],[-4.81164401744625,7.81228325633362,9.14073725969848],[-1.6528417005864,3.64834998378511,-2.87532634769705],[-0.331085885126861,-0.630069348725084,-10.9307247740585],[2.21298967366202,0.153473550725439,3.60060029894013],[1.36387065854575,-9.3200065602817,1.30854113289631],[3.50104136958771,6.45004363168783,8.17056091130645],[2.96215464661037,11.7707534925193,-2.49344297668129],[3.24900367553225,5.69861793120516,9.04927828771564],[1.96074126495668,-5.49380590620117,1.68249738630195],[-2.55994197083817,-3.84906237969514,-9.24494936311467],[10.846105305626,3.55618863605927,-1.45947454010533],[1.05199758654549,-3.70962245601473,10.3037204697209],[-3.75302489486542,0.486492306100876,3.92534729952387],[0.60717730291803,-3.04969102706557,-11.9959025074262],[2.09959989548147,3.9834085230078,7.98942702676185],[-0.656260889940886,2.76181734134988,-7.97207983288804],[2.96926235217722,-8.58884444550973,1.68255859952701],[1.83874660791944,1.55124797955595,-10.1910935239817],[-5.73950218518276,1.57041489703774,5.1490987663161],[-8.73670177016215,-1.1547196038189,-5.58108691625394],[4.15181071686792,11.0356262687861,-1.36794566225757],[2.93360790139753,-2.79293935894488,-4.22199037610799],[-5.62558962457141,7.54358894607115,9.14268607020951],[2.19762886574639,-5.03111105970748,4.35633977215683],[4.48602303123058,-1.43229781589616,-11.4492659205618],[2.9305492620024,-6.6631099782686,-1.24325175928994],[-5.75773703637172,7.69324361722537,7.67071698356847],[3.72654019736692,5.53740596209344,8.53960297257854],[1.37171804055837,1.73070811921009,-8.93092690584586],[-5.7281397966404,3.27162870068099,-5.37550693277383],[-5.28933186032819,-0.538969270600144,0.109085110577971],[-1.96404410135349,0.252364308623681,-2.70496323956926],[1.72819537171436,6.30954068958198,7.46560008559383],[-4.01251711445174,-6.11700619138034,-1.94906005432134],[3.46725802274733,-8.87815533931903,-2.11644782083625],[0.223442624555969,-2.61560014387917,12.1107655794394],[4.47169692142113,-1.00850435188137,-3.20125791271947],[9.15748078341217,4.26526798454842,-1.58363993689337],[-0.442188755440817,-3.15269846704722,-1.45868164945145],[-3.38165015890155,0.191841382658362,4.05192351476852],[-5.08624695032716,7.28545794807272,9.11938738758236],[1.70359431443512,3.3112240829275,-3.80030080217359],[8.34523349437557,3.50107200064049,-2.62575261618542],[2.72924686096809,10.9881749662832,-1.06807641168755],[-4.24547042709731,4.6749421364222,-0.606468823682417],[-2.52693611965833,-1.18880741270285,3.30228056822644],[3.52189578935367,-6.67854249008335,-1.52028554390511],[-4.50179180598516,-5.65557641016052,-2.11530014709389],[0.490989402696387,-5.95059015219662,2.16712349804943],[8.35575166495857,6.22265357860063,2.39113838501806],[1.9200721583593,-0.32137674475563,3.6012709288538],[-3.87486213898887,-2.08672583992107,4.23593124974253],[0.752450580570965,2.78663979156112,-3.52387753196029],[-4.08718971933482,4.87230915324508,0.178823469997718],[2.7429665120133,6.28394637258431,8.65697503382622],[-3.38538522049447,7.26619111676846,-0.384813584351773],[-1.12039632982885,-6.24424811046554,1.31058507507944],[-3.60996396493101,-5.81660215859888,7.54506423531707],[12.2243141153521,5.26775236430332,-0.866802250651378],[2.84142062071676,11.8033896647597,-3.06773737994861],[10.1163100911764,4.82522485942794,-1.25930344443155],[3.50559571399556,5.57455613661736,8.05947687692293],[-6.90880369907035,2.9837292632945,-4.81119423521002],[-2.75552724376654,-5.1866862800038,-8.30801663892818],[-4.51034291501367,-1.72269774703425,-4.51409106277624],[-3.35640111073442,4.31777682430307,-0.0348941770508256],[-4.9825256119658,-0.25232964503956,-1.8788455104164],[-4.63889521269142,7.34002658348046,7.64426193583791],[-4.58661690105924,-5.34583575909229,-1.72236767740388],[-0.901708409059197,-7.5109444368669,-5.81413955731563],[-2.2770051590956,5.99447004854331,-0.622149551895748],[-7.21394691083859,-5.84428531169947,6.79718124463394],[-5.48495609994101,-6.66776538273034,-1.17337157957055],[-6.12229323171648,8.22538729149226,7.70281051229143],[1.80136760836487,0.321096543076797,4.35332372277358],[1.26151507553502,2.30305173514943,-2.62584884010083],[0.523888019698968,3.85447138235298,-8.69465146826649],[-5.95640813636041,-3.11395347775341,-5.34016371058592],[-1.28756996052177,-2.74868341814304,-12.0162681229118],[2.84250176914341,-4.58708595900293,10.6580524052502],[-2.96870591499405,6.99238143347983,-1.27028167300065],[2.04506047441085,-5.12102671854781,2.57138102404946],[-9.46402165011839,0.754669094897707,-6.28910469115749],[2.18703308156756,3.91474974472084,7.67403336024726],[-2.86239696182743,-0.934661156181954,2.37000768069255],[-3.55531735043909,-1.67036542283647,4.13516024754326],[-4.50216693029032,6.57688457042763,8.88823612709824],[-1.04987488710315,0.468121395988772,-7.10396874149526],[-2.00012849375665,-4.93113076479993,1.93581979427755],[-4.72522585548449,-6.20762411303565,7.2340348697856],[-2.40813833030264,4.45235964039035,-2.42341327688575],[2.04117219984523,-8.71109421176716,-1.14194321302525],[2.46288925363798,6.34022547707159,6.44715672119544],[3.95282950545765,3.48715613870828,0.667460477844622],[3.98169990345684,-9.19149757009668,-0.501047366273388],[-2.98111054475573,-2.16208733012166,-4.74941438500842],[-2.26201251007387,5.0168582303168,-6.85218331329608],[3.22561392725806,-5.36816449863807,-5.42083638224273],[-0.0492891902162303,0.00740773618997659,3.69805959318326],[-5.75075426471397,-3.20862993325572,4.73805393486074],[2.77849936414743,-7.40250287737567,0.251700464373948],[-1.75510196991479,-0.992131104094434,-2.03141183020142],[1.80262263125533,-7.6435314761371,1.65104182761252],[7.43212641850933,-1.5766804291821,-10.796423436296],[-2.9820888481821,0.311836369782458,5.2723261965532],[-2.05749834510188,-2.99348040502182,-1.00173967269833],[-7.2334398784167,-4.86871680722337,7.43940817634766],[-4.02117586241097,7.87041359427844,8.95400237932232],[-6.12426689280077,-3.43223774891583,-1.66320593059878],[-3.85026952141479,-4.20705982087014,-1.4804076403835],[-8.70771462723181,-5.68665966674228,0.779250904980349],[1.47672848973644,-3.28652719589433,-11.610858602998],[-0.847137951048988,-7.51415671202518,-5.87967786613825],[-5.56011251677212,7.7878331604417,8.3087535034059],[-9.34837102882698,-0.0301640864435117,-5.45157528688203],[2.50391783131845,6.85539738360788,-11.0590044829911],[0.9997565064511,-4.06218130266548,-1.37655708292304],[-2.7845764886557,-0.820558015008888,3.09461276465894],[-3.84446891965661,2.52545570144868,5.42630117062275],[2.79002445786241,3.22848004664252,1.09539904831268],[2.1067919098698,-7.45855520248074,-10.4895851412025],[0.527637111280307,-5.2490797832397,4.15578658621598],[1.39380134666046,-5.95727633576964,11.0519256179428],[0.594193350104912,-3.31533696199642,-12.1241376969962],[-4.78383736055748,1.13363873560994,2.89329928945599],[0.93851342445665,-2.96009938158442,11.5008276640837],[0.233952155904394,-2.54306553284985,11.6770779147194],[3.27715099062363,-9.33888421980599,0.0641544660488319],[0.233015097339156,8.79097593790098,-7.88919848587181],[0.683101828670937,-5.15916014043861,10.7820303426487],[-0.0878721690725329,-2.79499153558743,10.9769433744969],[-0.0296666713551162,-7.28370596952125,1.13604202118064],[1.08063555049631,-3.84347614762091,12.2760760111862],[9.37800691253588,2.93799322927427,-1.55794101492666],[-4.37748535599443,-2.26049983188946,4.41613160087632],[-4.98262250595381,-2.85949867465864,-9.06902711659721],[0.376539185901726,1.96159107036711,-6.74627173120901],[0.850439278479841,-4.80930936751848,-2.02140990634163],[4.2986749129277,-8.81902844733658,-0.228910675912277],[-2.91928262839261,-2.42892736160563,2.06258243842076],[1.33423317646041,-2.51997787553285,13.1193064386948],[-1.38199553485171,3.18586165397461,-2.18537363559574],[4.93176382434177,2.03012517051376,4.39987219939043],[1.59645622752424,-6.86843857488238,2.55158894138827],[2.98738989415993,-9.04093561288256,0.275283136518487],[-4.79774955826833,-3.17078630294577,-3.19090501508706],[3.08942445273262,-9.68085277345127,-0.795043159323356],[-2.27926107282277,4.23048076388229,-2.6920691463302],[-4.52034594512197,-6.46710907891436,-2.86625656370052],[-4.46949621479514,-5.68295766624242,-2.73196052151722],[-1.83285577048174,-2.94766626993251,-0.658613716182793],[-1.86817260050554,4.45426171313479,-2.7568371013052],[5.10632901707917,2.78777443558076,1.92792227512441],[2.21533645222941,6.6873147753978,7.39020502620354],[-2.49043563159968,-3.48985110381764,-9.231992073053],[-2.63005111777655,6.63361025791503,-0.84471842026371],[1.07933409698571,-8.80599362358819,2.502114912471],[-3.65645654280312,-1.03011723205409,3.22638639327327],[-3.66069379495739,-1.06317463626043,2.36154402733014],[2.01971271867019,11.1664169439375,-2.94032095998219],[2.46469274495741,-6.84384975236913,4.64484461054683],[1.68897336339485,10.9659819758393,-1.95539787833215],[2.46778013656947,11.7641102687533,-1.26176991212997],[-2.57384001613825,-3.50238349311173,6.33152862798401],[-5.95136706142561,-2.85012242778808,-4.98589856702734],[7.74942841045917,-1.72911915360495,-10.4431574608307],[-0.123087566785148,-6.73845325339278,-0.895441167849211],[-4.30367393792727,5.47553027599994,-0.324069204941988],[7.91373032207715,3.16024161523323,-0.943936615611193],[-2.6720519667308,-4.53726112565553,-8.53311138593429],[-1.73815483949557,6.76059555952321,-1.01221007870457],[3.12093694028143,-8.30050814763757,-1.53932780723654],[1.39308367278122,-6.77784472176414,0.40701335982499],[-6.82120400101046,-5.73249901508518,6.19790387559232],[3.88280082412359,4.57452334820943,9.25940079300085],[-4.10095667592897,6.39244381746117,8.80125604878759],[-5.25436971884755,1.28670078614776,3.01735814656909],[1.07561227387702,3.78797517849704,-3.20116587466999],[2.07400101740791,-8.82101134918882,-0.362226941563429],[-4.05573444094166,2.42908186448449,4.30121354032521],[-4.05123235886824,1.950386496587,5.3501973841591],[1.49704872655968,-9.51593921199905,1.89416840901801],[1.31396508467594,-4.4762666067366,2.65895926834184],[0.767181096191914,-4.71459710262773,4.24110650471699],[-3.41213402915807,-2.94467020174234,-7.70606782914647],[-2.03703712405325,6.4148034277681,-1.69717271990737],[1.60308364729223,3.70793382705718,-6.29959610721669],[-3.68460745801468,1.22798796014676,4.37644300034278],[5.91760704858155,2.59011781574441,2.14330250601115],[2.78520606450665,6.72370901556926,-11.724066900214],[11.2042470743056,-1.71466198447807,-1.89069944633096],[11.5639672511016,1.81372668366194,-1.19710662219531],[-4.29248827939857,0.844984831396109,1.8494794715825],[-1.68979297193133,-7.02644090793377,-1.56564838968588],[8.70008477419028,3.99312742636914,-2.05045677848448],[-2.69149901101942,0.784618576001901,-1.2948518486427],[3.69262629525961,-4.97338769765592,-1.04536738924885],[8.93043950793811,0.113055579198105,-1.0612176025486],[3.62598836749149,-6.69566982426178,-0.970724698912681],[-4.56873314236234,-0.994137459193772,3.54573439705133],[-4.48366448984282,-0.00230469812589595,-1.18387967018041],[2.46900729689451,-9.82967984091856,-1.22737903361911],[3.22456097029284,-3.61243127574465,11.7784653409624],[8.3129514043909,-3.15503765090895,-2.5052537555397],[-3.81706388706823,0.627050294574252,4.64725447735788],[-2.55128283890306,6.77400843120291,-1.50052427735531],[9.21586204853314,0.913744397487272,-1.67203710777419],[-0.457925692986191,-5.89935691985884,2.49314246775286],[-5.46551255966723,-1.79176773721735,-6.21635797570797],[3.01917979231498,-5.8010934006173,-5.04727502226406],[-4.27461403387343,4.01502588156836,-6.78852058081049],[2.34763434026071,6.20191217204204,6.49007991895129],[-0.818702400448034,1.7432709071752,1.46123437763917],[1.40879465983516,-0.710969329213283,-9.74931830126062],[-7.62333186991876,-0.766169217850152,-4.89680282042873],[-4.81380035464447,-3.07739128489807,-8.95131635027832],[-1.91774403495356,4.94677949019919,-3.11290370738645],[11.0047178961343,0.877256711070077,-0.924620576273214],[1.201738358649,-8.24415584458223,2.1968276165113],[1.81435909375673,1.15267026836586,-5.87639603750695],[3.46291730115938,-8.94607388960714,-0.130033136077401],[1.77890535283225,-4.8792612709877,3.54451409954806],[2.80640586214508,6.59107901854905,-11.132178020322],[2.8574000022016,11.2875563831948,-2.86266895695509],[-4.85722606404857,-5.62187455411483,7.24862664160709],[-1.88043340653172,-0.705756424121937,-4.12128347979402],[-6.36320467080081,-4.31296492267215,-3.65458456690705],[-6.05330888543856,2.9864275066191,-5.64745085509375],[0.898092275815652,-8.01249844847926,1.12539935421167],[1.69750275340415,-9.07235747776292,1.2293158562448],[3.34344446580137,10.7766535752716,-3.4040176039311],[3.13539961608986,12.2638801801617,-1.11592510650342],[-4.25375120837602,1.72864087621501,2.61231557095835],[2.59457294531612,-2.31514786204891,-6.40190600822094],[-1.36279049746897,-1.16557871844671,0.551448234046951],[2.71198186803907,-7.4587603329877,-1.1960573379392],[3.86217238795807,6.10230295440743,-0.127905444667934],[-4.42067075043645,1.71239566485092,4.58760509676212],[-6.39468437495703,-6.36480358340447,0.0396891339567991],[1.95080397273641,-5.15988757073884,-0.2021286467231],[-4.84122522598953,2.31358304031385,5.28321270719275],[4.34579426819269,3.39605434206618,2.7019420061479],[2.53667843599238,-2.83061917156721,-7.05851327442388],[3.30004816727464,-3.57038343502788,10.3664333610519],[2.47300128560303,11.5536269155427,-2.77464986871884],[9.63063304568584,-4.77737241468817,-5.19773310231116],[4.02467751134484,4.1441911564971,2.24402509213481],[-3.97013005054781,1.62167571971435,3.15111742153181],[1.50700858842234,-3.78462564337413,12.9286904866481],[2.78212892513161,10.4603110598391,-1.90643485989698],[3.14229570436578,-8.46202066297895,-1.13038883717576],[-8.96903588780235,-0.98226771665023,-5.06776746593565],[-5.59821554633171,7.25245269237141,8.88203707177329],[1.52178855560255,5.90742392393285,6.92136555070885],[1.53261781164062,-5.62027997509361,4.83990114367625],[-1.80461464701232,-8.25825992176327,-5.55619438174356],[-2.09914333569121,0.162577400330412,-4.70827262054003],[-4.26382748154428,-1.13846689729065,2.11162725841581],[1.84437607219951,2.36064452681933,0.606811978134631],[0.765013459390743,0.343980340414035,3.43100773943875],[-5.67355079852038,7.32843359243796,8.96420448829081],[1.72372563866995,-3.44887411052634,12.1165179691223],[-9.38531799210663,-0.447805074557223,-4.83358270744138],[0.258472835006722,-4.52022365986409,10.7420465351258],[4.22377939135438,-5.51700122904382,-1.37257833969699],[2.26269396513483,-0.161434589096232,-9.98951603812552],[5.0458461161095,-1.60139199509118,-6.70603148271769],[-4.00529785821966,-1.80110494656758,3.94444255214017],[3.5693382494702,5.7022811703209,7.55677249755848],[2.10369444944807,-2.85833933546295,10.3837624644561],[2.00503502610252,-4.95189232708609,2.3579950242543],[2.84040869680666,4.33638632459457,7.25509651661147],[-1.60147020631859,-6.67493931557827,-1.47915133911587],[-5.5857245145841,7.23842272185128,7.71065283009206],[-0.161715306784715,-3.28352031941058,11.6804994048193],[-4.71742339737494,-1.24606091943798,4.44594391742142],[-7.25909449706871,-5.89724017260765,7.00376904016957],[-2.86122861145376,7.65737025294357,-0.461580295432309],[-3.96689516752354,5.41444673798156,-0.383095144213763],[-1.5779404105429,7.55807500551303,-6.66365919308299],[3.86352989948455,-0.705591553866268,-2.3361942101636],[-6.26287769524115,9.39653242155199,-3.97926742237874],[3.32929342683467,3.34174176585017,8.63754643004009],[3.00755390032962,-0.0719187780438721,-12.6229875536414],[-5.6044876949283,-2.66461323138532,-9.20340395591905],[2.52684867217426,-9.23393758872763,1.77463663470234],[-5.43120321399363,-6.6005840886105,-1.44346935323389],[1.70194114560241,10.7184406581883,-1.77709406746353],[-6.0415288124054,6.98352578411996,8.61139819676854],[-0.891327559460262,1.85180965652113,-2.04957675625586],[1.27427762079698,-8.87535063935174,1.55134003788814],[-4.5787000581412,9.50077303385619,-4.08127560678852],[-3.11694686740655,3.93077692474064,-6.91893816976636],[-8.13244303993952,-6.62324905850006,1.49759650836454],[1.52121520088877,1.63132654194102,-9.988799985405],[7.48427759972417,4.4345362401949,0.0405972302727521],[2.31390159210958,0.165809882940576,3.66003634391234],[-3.3931228035739,-5.64390327929706,-1.94073867365511],[7.70501299862869,-2.21911898552624,-10.2877151162309],[0.879418787892003,-4.04352760095837,-1.61973365646768],[-3.80230926657668,4.3069022478774,0.300223645168369],[1.51214754360174,-9.80677800454256,0.464731155500966],[-5.73368942869014,7.9807331731654,8.05567834929536],[-3.73079058549544,-4.49048542580095,-1.70219781658604],[-3.62396241612504,-4.81466748145479,-1.38139749806453],[-6.05085864020337,-5.53378739649716,7.72791898675474],[-5.07790546628364,1.42615035299058,2.5528120450179],[0.564645117535793,0.807191274988265,3.68634965910501],[-2.44258669551945,-1.0189251738095,0.734850326034521],[3.97301237284787,5.15402851272466,9.04667611033549],[3.81520594860738,0.0329346515687311,-9.60967098774342],[-6.0870277133352,10.9691767464421,-4.50026884122718],[4.19301080511333,-0.427262475813267,-6.227267041414],[3.87157690583078,4.07315928479779,9.05577129457219],[1.64058391881061,4.47262263007652,8.23605094327691],[3.15792973260811,0.720016746013643,-10.7008896445319],[1.54259313846397,1.57494417652371,-10.0165906174607],[8.95741550572986,3.27927538124173,0.0226957165492121],[8.67678195289022,1.30918386796817,-1.65120742298599],[-3.73490081396714,0.502559145496782,4.28998093665617],[-9.23000144569121,-0.459629286602062,-4.9875291692264],[-2.36584092606884,6.62891424549519,-1.21374378886543],[1.7726277832446,-7.82745406702793,1.75562091661062],[4.22790513328702,2.31841899629959,2.42379041377694],[3.54041699077239,-5.60732633260357,-4.93958092901254],[-3.40712218967006,6.27505277856452,-0.704502693374552],[-0.0324137689862916,-8.16497498410992,0.912081784525091],[2.02084501524696,-10.1467758806995,-0.902081369379353],[1.46493249598519,-5.15102958278241,3.55842163146085],[3.16001115789417,-3.81730323200728,11.8104885079857],[-7.56259908252015,-5.78604650009459,1.95314855150167],[10.2607470012836,1.765618600903,-0.475903702468995],[2.04578366197364,-9.43505009364478,2.89435273406538],[1.83367448671075,-6.05244833868258,1.70659600986641],[-4.06747251951309,-3.69160773184606,-10.9661282733293],[1.71856039356757,-5.30844603508511,10.9913621427605],[-4.70334086776556,-5.68523275878617,-2.86915055305801],[3.961239379401,-6.94325820147116,-2.23588554106333],[-5.01746894734194,9.64613191797498,-7.51481500244298],[-4.51719620517626,5.26942453921016,0.326521987473463],[-3.42812631439953,0.624709841586382,4.54531535351181],[-0.621222377267429,0.726878280362025,3.77961907388235],[11.2508962849676,-1.93819242683234,-1.35057458514312],[2.96218676156858,12.0391732037247,-2.3908408215483],[-6.43774486057106,-2.8834715827366,-4.94017594885742],[1.5763978124525,2.1984578506542,0.434717853604207],[-5.06829503621902,1.31541224937157,3.52127158431215],[-2.6340675182606,-3.22082594834276,0.11152158234358],[-0.155315577098694,0.968727323382575,-5.97593543290933],[1.58353124845551,-3.02184906547202,12.4993287034248],[2.86988964655856,11.3237020808746,-1.9673396748378],[2.86702595494339,4.83760791837328,7.89349630191627],[-5.84816420974148,-2.95713040936203,-5.12632626857561],[-3.94493139979902,2.18936485865322,4.13630527599419],[1.67375293532696,-7.34042045544615,-0.10422758185531],[2.34931058464961,10.4457602397538,-3.37253297453997],[2.2566603900229,-7.42743162872428,-10.6487717728378],[-3.53293036051118,6.07031575587565,0.542395872092747],[-1.63936893012718,-6.71340374956793,-0.919487073124311],[9.92239459737971,-4.96108188757984,-4.78945830759248],[2.50064133564862,-8.35800209580109,-1.68224730286246],[0.851613429629806,-5.54911525964965,11.3373555395071],[1.49732403476078,11.6665373962057,-1.95362239087235],[2.82473529210853,-9.41853035874303,-2.23133950367506],[-8.06766850392583,-6.00694271736395,-0.224526011324687],[0.962056112193203,-4.96019361658987,-2.04848045205402],[-6.40853913871078,-6.08231222328391,-0.896733496122494],[6.78395177593635,-1.01905695017822,-10.5352551528808],[-2.52534015194126,-0.22739403341388,-3.33642496279552],[-2.67216994178747,6.31965043756615,-0.800400552970661],[-1.23399891308953,-6.11596278465271,-1.65333596084036],[-7.93240512754134,-6.25948575994633,0.0332368027575534],[-3.35583704896347,4.08836777855208,0.0253981038457146],[1.17116436809598,-7.53520746674918,0.56584845981157],[7.87950091575507,-2.88418469561042,-4.15559566046332],[3.17540681696091,12.0733769992966,-1.55139832797384],[-1.91518364375107,4.345449897433,-6.02079269528539],[2.31319186044787,-4.38987346181798,-1.3423726341893],[2.78342101087203,-5.86301828629053,-1.44992009471452],[2.31520717832537,-2.77098802492221,-7.12124803612132],[-3.44602898252279,0.629356736731066,2.3201051820365],[2.52901173743198,-0.0464952443333868,-12.0372631900072],[0.922298386027411,-6.82271031406047,1.7762188365395],[2.91684977554548,6.06389952826249,-11.8827942175562],[0.0211888403394257,-4.04289909619087,11.6324177457876],[1.61973733791813,-5.08668259027009,10.8652178641986],[-4.66097957703159,2.70614870307429,-6.60031072295596],[-2.50316155083013,-2.5954962873388,-8.80360909294845],[-4.93528427154502,1.71080273172891,2.36984365145092],[-2.74132484281078,7.16476174668356,-0.321810959703909],[0.705488367633806,-2.98335771744661,-4.97984983527711],[2.45129306759572,-10.2132162152034,-0.710123284436304],[4.91009455273235,-0.141845589361692,-3.29539506861433],[-4.63995315659957,1.60858409046714,5.17104494921756],[9.53421158886695,4.18786728913428,-2.47943087123909],[-4.54459183351723,-7.1888646294919,-2.57342485894627],[9.89737559496381,6.6108369129728,-0.782905586177953],[-4.06542831715466,0.891268641845809,3.82612684558589],[10.4671488944791,2.90101920390772,-2.11406920922862],[-4.27707343592354,0.0699477876051259,5.10400553891777],[2.01758707060376,6.12442910485541,8.10730248333997],[-2.29670288462888,4.70649562556584,-6.86137556675476],[-3.35879423423018,7.05187508953894,8.54199007047762],[-4.84463063539532,4.03692111193595,-6.51429421171206],[-2.64618815987063,-0.335397141309893,0.44924285493017],[-5.53231208327116,3.50180822950314,-6.30115802214661],[0.716535774847245,-4.56718234472273,-5.57518070781204],[-5.29196896242891,-0.983394812065067,1.66495479189983],[3.54689313976506,-9.42565156131519,-0.998907599446804],[4.06291530395681,-8.77539496980377,-0.318977318222381],[1.99018466009698,-10.2307581124631,0.899414741572643],[-2.05239306166203,4.53628598581567,-7.48587690270055],[-0.277240830936975,-0.742691703413705,3.05424644431426],[0.603356465233072,-4.42354088148506,11.5408208335838],[1.07071449839981,11.9771828501941,-1.65438458226124],[-5.24919906413787,-3.97975777553178,-2.03212046399389],[-4.06175087303089,-5.2267722088502,-1.19855208485522],[3.95099005521379,10.5561549076927,-1.47740402788221],[-5.93459032623539,-1.46151070877619,3.84606799898444],[-3.82206733347133,0.178601894913774,3.0425034080973],[-3.50484407804979,0.916108001577004,2.07219087701033],[10.847912744949,2.04579314777796,-1.90706457774497],[1.07633401181944,2.03088177374642,-1.1263159813239],[0.905379720568368,-2.80561952860444,12.5270493342171],[9.56328424547491,-4.79263144322786,-5.68629806458115],[-3.75968508865748,1.16869293862598,4.1604108649145],[-2.99836008582082,-0.0656881806729466,0.207601707682698],[-2.16472077849898,6.37944493662852,-1.02463745060762],[1.73271803717116,2.80886422713133,-3.18210337906563],[-1.26506750376875,-0.354521030305888,3.23859624786654],[0.692786478350081,1.52587041768683,-2.24432202738903],[2.74989147378568,-3.88039299199078,-4.49507932812346],[-0.185250814715161,-4.29773299551489,-1.58344190170976],[8.12556972852033,2.49520678872479,-1.833409213023],[0.174398997749254,9.20238724163458,-7.65516371110849],[2.47148036038345,10.6893222106617,-1.82329980360346],[1.76500800418593,6.43597417719921,-12.0086982796732],[-0.90095675423362,-2.67428775143867,9.80419337647342],[4.14794146865596,4.32318002534378,2.8465441197393],[-5.45704336526473,-1.20440645650641,0.52175854752672],[0.527206179891099,-3.88571388208747,-1.38466918520524],[1.18930665451546,-5.93677096705685,3.1372783385435],[-6.70083634791109,2.41930488165555,-5.28415628969516],[4.45901985491349,-2.62178798352105,-6.7769333536339],[-8.2383833485725,-5.77038245141504,0.948161276244835],[3.98812717124645,2.49995143090062,-10.3890781229467],[3.49555817018081,4.83963803615186,9.11878133921687],[-2.15906204596078,-4.42925432263088,0.123625949423507],[3.10101155713144,-2.56048345561798,-6.49134451219596],[-3.88229303002522,6.95938142099025,8.81918286393824],[8.53384307467952,5.01167470988004,-1.17066264810634],[-6.89671990669418,-6.02855900410363,7.07815288167391],[11.806870340332,2.97303252915815,-1.84189862032884],[4.35527836664473,-7.97411747207522,-2.57537947206055],[2.92353892634892,0.219272043924061,-11.7170399971294],[3.82455078799065,10.2222047139739,-3.22496366434965],[-4.79873031207153,-6.06369979441149,7.67978787855734],[1.94058794368354,4.15428988928928,-5.39458629471297],[1.74067483688525,-9.67599824060676,0.444807059365335],[2.98643317494712,5.78733673336653,-11.8729318082068],[2.5629821096024,-3.38158927329435,10.2461469613209],[8.51020281948905,1.86786868272943,-2.23878467484138],[7.78637218987794,5.55737350580604,2.48249988084137],[-6.08575147592551,-3.43600492886422,-4.87794254986055],[-4.1261923421446,-5.45219731693286,-1.21916659822799],[-3.98066717812572,3.4880337409169,5.33819180869113],[3.67991438540336,-5.51161466146807,-5.26256638257765],[10.4092224978139,-1.8333359451342,-0.383984397731976],[-3.06454169840013,-0.987867615448638,3.30111739378123],[1.02098322025368,-5.99759561418364,11.1934256183216],[3.44204905010146,-9.35141671459518,-0.735171370494828],[1.34045774185319,-2.47201862958637,13.2769679130812],[7.30106791427704,4.65222089527779,-0.457199807876699],[-6.09813292667,-3.65430424696111,-4.87125014038802],[3.06487779186782,6.2845894848234,8.48964533908519],[1.537744997764,6.30883381175239,9.11434581305283],[-4.94205509817056,-0.487685241701515,-0.647767420484823],[-5.87273164034811,-2.93714181301866,-5.3050487802068],[1.52234945750835,0.779145966802953,3.00179110609606],[5.23863925407065,1.38914002062867,5.7536123619513],[-3.1314144921413,5.34530699082504,0.686427716636826],[1.78104631547082,-8.39630899016816,0.398937277633114],[2.55585750992479,-9.99137419780844,-0.571732416170975],[-7.23976590993795,-6.73042475518718,0.796266882575618],[-3.51725773671013,5.94103038223291,-1.15073057952571],[-3.45987101382154,-4.94913077797979,-1.46143404749582],[0.515410309310838,7.42403334672381,-6.27798985648027],[0.736812737027909,-2.69810320275177,12.1727519835154],[-1.26422274001834,1.71318144056818,-2.68052645806332],[3.51590735759314,-6.54696579060518,-1.86095391596037],[9.70918897487947,5.43106984893867,-1.38750235670628],[-6.91425590622878,2.74695215000196,-5.62652483366156],[-4.4694925549326,-5.37003226863657,-9.49406281204642],[0.638006912351615,-5.98984970680299,3.46471144782449],[2.86595530844881,6.75161603034974,8.24753576050124],[-0.340378832619296,-1.27464727040878,-13.7037871553765],[4.59423681401664,5.64280554958612,8.90528825845281],[-6.84135393622638,-5.87466350575039,-0.222114395359593],[1.5135137942713,-5.88089541651361,3.47070582978173],[3.70973659471931,11.7272587584754,-1.81464493448313],[0.890427991777712,-3.20237531428517,10.9878492052459],[1.02474823262531,-5.661789853026,4.86193263329954],[3.46932061812948,4.76432262342844,8.25352409808548],[2.46960374196647,6.39569415900101,8.22615436885484],[0.0509985925036009,4.2360119554325,-3.81319610080639],[0.404999904887576,-8.12952204033681,0.694404640512771],[-9.52120796289207,1.07168889660708,-6.0870521078257],[3.10791048961488,5.26116092320944,7.07447378614501],[3.71990051276203,-6.75233093128627,-1.62545638492419],[-4.06963302270006,0.628276939657254,2.67828543911263],[2.71397899434777,-9.29881990632062,2.00481279892217],[1.67652936030582,-8.0393314947308,3.17596932261513],[-6.37022337949072,7.20839800189052,8.2288266992787],[0.245331007571259,-2.69934939251747,-4.90277683162432],[1.47940551858481,-6.54747095247455,1.28947297601298],[0.874436324167591,-2.91120653474182,-11.751619979296],[-9.20658009395205,0.451034445993943,-6.2083404097598],[3.18676569901588,0.378058331767959,-9.63701237178579],[2.8219805392542,-6.44408207760788,4.47048204857682],[-3.29804152546931,-4.91934482744324,-1.2025782322727],[9.05683251302108,-4.12484287314215,-2.43460784795062],[2.88064655055255,-3.13429321340084,-3.56428531604073],[0.946475965724485,-7.06284890674744,3.00793225013482],[2.59420343897668,5.63430653378062,8.18294020329694],[7.93662862969083,3.00415715722681,-2.29972089154632],[-4.95861327390628,-6.95417384999706,-9.65386275204085],[5.1826075062768,-1.70340244601537,-6.75894905601643],[-4.9841970920022,-0.878056051311723,1.43575870115164],[0.181195389283481,7.93388351127581,-6.62130864373991],[-7.3283732750031,-5.09975404388871,7.11551697055286],[1.03586352825455,-7.5561540093825,1.54127364428578],[1.65929632490138,-5.06245309521067,11.5651721818485],[-9.72617404017389,0.980552540087825,-5.79815254622538],[8.73541935262755,-4.55701747875117,-0.911489573870866],[-3.68497214786887,11.5801642594322,3.51694684395098],[4.29512784046151,1.51739702207543,-9.32896120801765],[2.62229572198166,4.69800407071728,8.30351214537424],[-5.36516011294973,-4.59139564289291,-1.79122699262586],[-3.19076917437082,0.566995795344079,5.74352415381104],[-4.17540158104571,5.01030674021877,-4.70203682023681],[5.32989034314538,-2.74117847251634,-3.80215064981775],[-7.28879709043758,0.62844302487813,-7.89718210141776],[-0.039764829941356,-0.923660987866229,-13.5317093239215],[-2.92895736959215,5.3793336598986,-3.09855755913804],[2.75513366547904,-4.68281093468792,11.0111368391823],[-3.86608479056858,1.15077285106385,2.77369998374329],[-4.26662778545979,5.35194863030088,-2.01436171309944],[-2.33486751820972,-4.33133238156756,-0.405800934946051],[-5.04677725384686,-0.853005231654368,-1.82861043345945],[-5.29448509359801,-6.25449118948344,7.67744917463927],[3.70130684506284,1.01118490468111,-9.20157418677431],[-4.8324196922223,-4.82918825690864,-2.15511701289656],[-0.504625676498413,2.89826661596473,-8.48787464196625],[3.72138640039841,5.33944339988777,8.08675639726591],[0.312393657218247,-8.1705951590355,0.518094941445486],[11.2553869203815,4.70743586820716,-1.6953659624246],[-4.61520039848192,-0.553836089137065,4.04757477630311],[1.35133289198219,-9.24886455208981,1.40357451052606],[2.95012651448488,-3.48297279728123,11.3708740392697],[1.88907198627187,-2.87665671689223,-7.93749270105511],[-1.52472789460113,1.58681987982575,-1.63111328770647],[-2.66542928913944,-3.88971611299838,-0.336922810245848],[0.205331844195799,-0.965046015830364,-13.2723546024244],[3.93857629500297,-7.05859670478878,-1.80317202229356],[-7.28497812843721,-5.22065516533139,7.4167933057236],[-1.13973327072581,9.97203564455166,3.21146739505796],[3.42268961596527,10.4290750837363,-2.43140344585836],[-2.38260502397338,6.85797077070065,-0.794827434917379],[0.797209428841696,1.8877753572291,-2.50269606962554],[2.30688776104748,-6.05726277613259,4.60197572234457],[-3.74329773347183,3.44500539112655,5.67035992751759],[-2.15172902303818,-4.58233504668466,-2.21447458143765],[3.74376504976864,6.27396113519942,8.38706937551042],[0.261006004233529,-6.24364776017039,-5.96064824792111],[1.3718642159879,-5.18983665691416,4.07527850788138],[3.90206992843647,10.5668903871544,-0.867238067451833],[-3.53516394237337,0.0583137939488108,4.72153323651322],[0.789083999397658,5.53809550043211,7.58942128378644],[1.35845441270367,-5.4334123864215,4.51804329832104],[1.04589991548203,-5.11877370011897,-5.07496254209879],[-5.32998783932333,-6.6004191419876,7.52305183451372],[0.928375724434478,2.36553231909929,-0.491790458311896],[-4.97524368541216,9.49739593110616,-4.10887355765814],[-3.82150131189729,1.58835575701871,3.82484649621458],[2.21267058184132,-5.51807739790992,-5.92416642320558],[3.1130668818197,4.50484169649371,7.69098590918893],[2.64259719469321,10.8061748118476,-1.95176178547143],[8.74474332178582,4.50939462422901,-1.13911447657132],[-2.80919681417177,-2.83672059624494,-2.93207659974967],[-3.80154706743894,-1.25864514842787,1.08985298486284],[2.44927341584227,3.24009535356463,0.656331504535555],[8.7288712202741,3.37875389720334,-2.49108830667702],[-3.46593219724598,-3.89764693005656,-1.77792965020797],[-1.94664597669546,5.17691352219751,-2.64150442535375],[0.488447705326788,-7.76667813279404,1.03655312228973],[-3.2496331525524,4.78456283157468,0.472118809024219],[2.66832495725841,4.4270596388695,9.187820525834],[-4.65597111443139,-0.325600622037091,2.38021298132526],[-2.34732418497622,-0.0963845688489187,-0.785686070628297],[-3.61141476678797,0.439746841067447,1.99239028819921],[-4.50557393715077,0.471339582209135,3.19247570831158],[-5.47941081758608,-6.14932345227529,-1.97031637262921],[-5.77130406987898,8.20343539328146,7.91780743237259],[-9.22628380794638,-0.846734709763221,-5.47776720863939],[9.4529732433605,-3.94700083831949,-5.85496564080976],[2.99125044454098,6.25982424728617,6.62158152426727],[-6.12063197481602,8.86438387945337,-3.89188476979112],[-9.55314154701014,-0.786149421082099,-3.99975272433115],[1.11562145426508,-2.77284624665632,12.4865320767115],[0.634762824109952,-1.00788199591563,-12.7453365788381],[1.38000357528207,-0.113471313178549,3.42604374323057],[2.11606292388088,-5.15884125669238,4.60505121926474],[-3.58818254168087,-2.21353374279562,4.17567273989098],[0.387938072099301,-2.85940221989585,13.2454011409147],[2.44446709472075,5.90247403356063,7.88628340184865],[-1.74406373417553,1.96244597471232,-1.27696184183965],[-1.83225136224159,4.70583029396701,-3.15821298258607],[1.45148565764209,2.96911708452903,-4.5265714673122],[-5.1177298529299,-2.89982111172056,-9.3252253542922],[-3.89228556887933,6.52417364436097,-0.893878433266184],[0.246220191362598,-7.72169855868913,1.78296652815136],[6.13231545913404,-0.619153509838795,-10.0740114551499],[-5.50794756520895,1.54728149961832,3.15525215167414],[-3.3395366033091,0.219800298350061,5.82035515733741],[1.13727142855834,-5.09331481136999,-5.15030537181938],[-9.73530305895008,-0.757046675097583,-4.43892710725643],[-5.58572187424993,7.13658491928484,8.3291657265276],[2.31097828147195,-9.85398701333327,-0.0465172557376093],[-4.94557668041275,-6.44432866619522,-1.90941963594268],[-4.0111941139986,6.19218694520471,-0.309052363483341],[-4.42011903859635,9.96623567283332,-5.59971120786088],[1.08732430942613,-3.34377875983805,13.2558318955898],[-0.130115762367397,-1.66003860314154,-13.448067834921],[-5.71149746827519,3.91397569264864,-4.74518807235695],[-2.47945999035973,0.136525916726279,-0.994115143143431],[-6.69943968303356,-7.20197653113191,1.5702406643211],[0.561970863413135,1.99596037700652,-2.33520925822599],[-4.45960201965956,9.52026655027808,-4.1589272060899],[1.60233788677286,-5.17256032237256,11.4527203066953],[1.23903644357698,0.522140444448502,3.00782980829433],[-2.6893470022633,4.53290400624283,-7.23723357150861],[1.51748295723788,-7.49925958507564,3.35292578288952],[-4.99884499609112,6.24824034328886,8.80384953356817],[3.54782203745125,10.9592774617272,-0.935325852640162],[9.70256547935444,-4.77428025924566,-4.4196678034229],[2.56455710726152,4.64110156573237,7.38842895914733],[-0.707011181057243,2.78402923982227,-8.47660971697159],[-0.597240876127471,0.517306015388254,-2.56786690988423],[8.90494986143736,-3.24670987087795,-4.85117622531593],[3.48076007310531,-5.86138308322904,-4.87411955693163],[4.14196812294301,4.82187357616824,8.90642120766921],[-1.25109826676291,4.80549749909502,0.778866576655579],[-1.61529834803907,2.14950745764293,-2.01355855774846],[0.534437575941519,-6.80084819106472,3.12512480071413],[-5.45779201542493,-6.18669939639078,7.21465183674743],[0.43423136600662,-2.84373192731772,-4.96949098975984],[-4.15491259766131,6.04589359291901,-0.74225566818906],[-9.51074150675102,-0.000367163199562204,-5.14280223773064],[-3.57731669532696,0.378006280139948,5.30368859863219],[2.51999160782388,-6.2524915185187,-0.623728164972272],[3.91301915850196,-0.763882168477151,-6.37886654375169],[-5.16558769164375,-6.12902809043515,7.3894071746075],[-2.51180211904075,-0.512999080504443,-3.18179430297981],[-2.39083151078438,2.78787880307966,2.94208759106226],[0.426330884189832,-3.60774542483771,12.311565003486],[-3.69273378691107,1.6166060154123,2.58179948792263],[-2.93893163038466,-4.63906913319394,-7.44184725754453],[-7.00932666735024,-5.15587958349434,7.48550879666612],[-4.75293510933358,1.02693931028749,3.27931335695153],[7.80679288268483,4.90797285534727,-1.04155925610806],[-4.60288819090701,-6.48899655438359,-2.372668515901],[0.792746769182546,-3.21780713857151,10.6750069844275],[3.22390566922656,-6.85657225183842,-1.51628401585368],[0.527058369037669,0.498447611389739,-2.91481377029218],[1.80277484032627,-7.25727462027722,-10.6485064325545],[-4.31417941625543,2.70331482957182,-5.04265510656568],[-5.35510588968667,2.59565940760708,-5.22430013063761],[3.90334770231516,-3.2406835607804,-3.85316692410957],[-0.232303026260805,0.0288370766210913,2.79308706087494],[-3.00009176414668,7.27015068695922,-0.490952507704907],[2.59754362158858,-10.1613648689155,-1.22217806744065],[1.5410915311023,3.81862030450345,-5.73396223357765],[-0.310645668895826,0.08636324734765,3.62519056182527],[0.0529736308961126,-7.44664154890821,1.10279927785984],[1.3961203092573,4.09816938622294,-6.11900150632685],[2.16592978719205,-7.54235573752258,-10.7543062444931],[1.56006779688136,-7.54400537610019,-10.3249543709313],[2.12354346607296,5.68501921983765,-11.3882777846975],[-2.88497033506272,-4.72018634376937,-7.75514790690315],[4.45828097807672,-8.47898882138188,-0.245150222432411],[-2.1007180153213,-0.261314362810285,-0.646837441991984],[-5.59137109446538,8.10288672340432,7.78593925874021],[-4.10551694318998,-0.327977910855958,3.18866666884566],[2.92920359787348,6.25277360679905,7.46888667634791],[-4.30701378834342,8.33343547443726,8.54507466163409],[-4.39920707899422,-5.93469732728807,7.34092236265391],[4.06958525690106,10.744228827247,-1.7820663873892],[9.81360422534691,2.53214192279552,-1.70913588224998],[-6.28935112481547,11.0444991638523,-4.33076619844996],[-4.11282968763781,1.61909247396606,2.14617462695535],[2.29693326556147,9.85743700437026,-2.05903134867594],[11.1247742050534,4.66922772517988,-1.22678074289341],[2.65986891024094,4.74104755000767,7.78790544154515],[0.707450263858833,2.2199108602776,-2.64909787328349],[-0.921185435879855,4.64885749300731,-1.49313426143488],[-4.03741372310609,6.91335908521407,0.101282615015227],[0.992819982570118,-8.7243576828862,-0.279316633457079],[-0.235500914946851,-2.83308841251322,10.6494370507054],[1.63052563910075,-9.20391831615073,2.64014564061505],[2.15301855763314,-9.72908884275729,0.875001766724751],[1.42809578454388,-2.627334370812,12.1489108283296],[-3.22145282203467,-2.30523169998537,2.07991698186032],[-1.32080117778258,1.29248877275976,-2.7039971887592],[2.49358293653051,6.60357651563636,6.68184103754552],[11.8501279038907,1.28482676939595,-0.950695493179088],[2.55581418492756,5.02302888091839,7.81466996785334],[-4.52358225444937,-1.90178794532836,-4.41370874511755],[3.3297146279349,10.2932428755229,-1.50873911917873],[-5.60436307555876,-2.50510476212901,-9.10415868762259],[-8.44393610164959,-5.45956191085749,0.805203865152563],[1.44046950128263,4.11245401356291,-4.08540312318109],[0.255391138610713,-3.09577984669645,12.3239146635663],[0.481370212711437,-2.88797680964187,13.2788439155392],[-1.89969355664095,-2.36471754158956,-3.69058847706472],[-4.88318346047271,4.15752283335537,-5.88288274288638],[-6.21812402858358,-4.28939916549316,-3.86030867093211],[4.21603547303841,10.7950283550517,-1.00433255943586],[-3.10768846347063,-4.83190032896005,-1.16112248042063],[1.52942508814188,-8.87103805014629,0.653543398389188],[3.45738094884855,-7.26800417588623,-1.3295206625112],[3.55949539590518,3.93326468045468,8.25339492170544],[1.97630113212487,-1.20487227712024,-5.02466554642328],[-4.05824585438107,-6.40916476376688,7.46078423298855],[7.20351300871457,3.93987465085235,-1.48975148603902],[3.30732017698976,3.50334903441791,8.6773436653645],[-0.217086089101177,-2.48420859973696,10.9166716842505],[4.12399285119697,-7.49646914923626,-1.9235313255433],[-4.66490749294506,-6.79693910725203,-2.40320909141444],[-5.77445468792625,-2.58489231740576,-4.38875856981686],[-2.95682314210126,-0.671132290795456,1.84498934183597],[-3.63749381859097,6.90132879950842,-1.13373662541486],[-7.32389978442833,-6.70666025370549,0.883610608804378],[-4.58031490933477,1.54554160072891,4.26659046140928],[-5.24627121483065,1.60167294845492,5.10984870287957],[3.33768808621668,12.020919801546,-1.53752013044948],[3.66857153592043,11.8224561574442,-2.8634606590443],[-4.19608997978038,-6.19525791310949,-1.12847220895197],[3.36282807606478,-3.69307775561763,11.6049495764893],[1.09506111850677,3.061013936948,-3.79473427677236],[2.80348212247665,3.77176279593408,0.826653094782384],[-3.80281932852034,0.760927625718364,4.44587442874562],[2.28034276110022,6.4959564422919,8.89761740931757],[3.55961172847151,-5.88274138957406,-5.0541191009328],[0.298686554856243,-2.73035416354131,11.9233553958824],[3.87418927051762,10.7185285288295,-1.37126881877294],[-2.93595098520502,-3.53264313279725,-0.832509529777128],[0.430518441974448,-1.33901200733791,-2.25880835920763],[1.83990479867241,-7.37877592379682,-9.86933019844524],[1.10227946172795,0.694855525236315,3.90233586521395],[-2.61437973509598,-3.82254756612215,-1.22112422955178],[3.84252847552326,-7.18568371820578,-1.70545297301594],[-1.68597973007851,-1.56208157332394,-8.39748144179421],[-4.70848568459414,2.33073194043803,4.1656382092263],[-8.63816625127207,0.64525965371716,-5.55378969761623],[0.953821794045301,-7.23667117886263,3.74691339440504],[1.20604334523341,-8.13098318223891,1.7579063295256],[-9.58721650193357,-1.17214860155438,-4.57619462633875],[-1.61312963807177,0.432228134953604,3.22205468489092],[-0.76064445398121,4.26379647553846,0.00610345230784232],[-1.82026517027767,6.32204781891809,-0.289642195008645],[2.30261813530887,-3.17593354932333,10.9303060650021],[-2.6123606400195,5.14357957164036,-3.01179415506007],[3.50198739899018,-9.55668529482003,-1.65840382071583],[-4.04764862081644,-1.36910887497043,4.22604115301857],[-2.7379023936991,4.56074200863475,-0.0255009668988068],[2.44703546867434,5.23206948539158,9.0324066299168],[4.52154613064512,-6.24502340241628,-2.90047252184803],[-5.4995398249151,-5.95316376839322,-1.83219474667691],[8.34080013100841,3.13086156050025,-2.44902456470718],[3.63316000649389,0.091609445571,-9.79775121306023],[-7.70730756337199,-5.86413704477454,6.57686339524252],[-1.99671739629937,6.22268491807386,-0.288629676963766],[9.49851986431726,-4.50842025901151,-4.18768825789626],[-1.56189183516927,2.67112118330915,-1.16975392725961],[3.75935049988115,5.00655029368307,7.45451906021619],[-5.31741956101859,7.62897119259591,8.70670271331463],[2.22155174326644,11.7423224385946,-1.51610901421084],[0.66237328654802,-2.65703243752632,12.1307083086561],[-3.14071735868125,10.4205736992327,-6.47087424547903],[3.59188731514875,6.09160179535602,9.14227380503191],[-5.31642554305029,3.71971788328028,-6.57558140663204],[2.77852042432057,5.49573619485798,8.85893077169737],[-5.41263931382138,6.83029779728103,8.25513916779157],[2.2925048467288,5.5808603969121,7.22081005842062],[-4.23013621893189,1.91858978793634,4.99798270080549],[0.946558331747661,-5.15937257294087,-0.3765152268984],[-4.79516297982801,3.71630098943599,-6.77877564191582],[-4.85208455638671,6.83022351179817,8.08354049402899],[10.3538531406655,0.782497725839028,-1.34232535816707],[-1.25094842956155,2.5065892392585,-2.33349499748135],[-4.77348613344299,-6.29881816387282,7.7136637593265],[1.13489893922632,-6.13343735601743,4.45310598451533],[-6.64250805583833,3.45757381361806,-5.06768867969195],[2.83647535011352,6.14224939472124,8.01726181531476],[3.75125825573861,11.697926471249,-1.12161936371848],[-1.5968849658587,-1.98665666138212,1.83757791330266],[2.14793069075521,6.4447418998775,6.58463126907979],[-5.06556668257058,1.23867752518281,3.3268453301599],[-4.01260257025957,0.343182054061554,4.86637025860208],[-4.54515708978674,0.388159540048145,4.90226201434603],[1.68680690150219,5.21355038934574,7.39988986742299],[-7.99734865276355,-0.815342594799171,-4.60377263089004],[5.87731188899924,2.61828645405553,1.92926662396316],[2.15799687879744,3.85408172219605,-6.3680898938944],[1.79853118996985,4.63058277081078,7.60046370694213],[2.39071639874645,6.3619703819855,-11.4613000425394],[1.40563749459215,4.36288192567228,8.27284824186578],[3.17775782204517,-6.57424540969242,-1.09801299696429],[3.64533386259765,-7.20413225102544,-1.67834112655856],[1.48102574296603,5.39427973992492,8.33278892702119],[1.47042539775678,-7.55481124657181,2.1764070007041],[-0.611248634047973,-0.761049855035523,-13.9436028212088],[3.63861011573374,-7.01654665664384,-2.13474195562636],[-3.94736941226296,0.450647609322954,1.34427700971124],[2.38891592965886,-10.172530073806,-1.23842242988088],[-1.66359448987802,-2.71085528283671,-2.73315173638292],[3.34988329980645,5.41312982688031,7.14944541151621],[3.94886386282108,2.15019276063452,-10.4728435800923],[0.636734274398495,-2.59366602192263,11.299153079905],[-0.351333766901009,0.694280007002118,-7.51244977707663],[2.58077120784236,6.28784804252703,-11.2362277065786],[-4.96256286517985,8.97715865197812,-7.60354363461795],[-0.506031604426985,2.83663986802582,-7.91333865494098],[-0.619056914548455,1.50248722125687,-2.07385119052895],[2.47352876910644,-2.29243564003935,-7.20467375691269],[-1.20160458698715,-0.66763731679977,2.99047342520792],[1.84891397546509,-10.218775785103,0.358252261139104],[1.64064513702923,-6.70097217397216,-1.33144210162539],[-3.90938971289454,-3.80765863817885,-10.7500695102009],[1.86516730912578,5.07841747203846,7.91894674142927],[-2.17508677354518,-0.558617871818119,0.30800945579712],[2.50986313256161,-10.1565791685465,-0.416783683902271],[1.99413716015361,-6.04953811656907,1.18546677824333],[8.44814555133186,5.1056787711113,-0.75833631774904],[-3.57230635903521,1.66328877727974,-6.13348266842688],[-2.62663685566297,11.1220896842149,3.68943997426188],[1.01258390748995,-5.91364290168577,4.20824985093168],[-3.50452975606559,-0.80607764953561,2.58128813611169],[-3.3220439301558,4.56850148719471,-0.768479885122995],[2.3290461224904,6.46565720194139,8.10047234238599],[2.30696628433492,-5.30653983258788,4.58783151735397],[-5.65529962011226,-5.85839949929525,-1.60680524209453],[1.46703703024193,12.0232492164431,-2.22289283546867],[3.79784259523577,-4.4322705648591,-1.45471989078885],[3.26294237426839,-4.32396638370828,10.2729812342403],[-3.74820379927418,4.53228592312433,0.804622497493296],[3.51280928718812,-8.58100317457584,-1.67025090915998],[1.20025443933465,-6.15353509444735,-0.462203989105717],[1.37906667147288,2.67123520077259,-3.2166352981198],[-6.78612707354228,8.45917058161713,-4.30924182148096],[-3.88756049245611,-5.97437945152216,-1.8134377741082],[1.97817204318977,6.55625732720716,8.31471380279289],[2.43785102435021,-5.82597549129413,-6.13691504690801],[1.86586564825874,10.9533271346381,-1.7563257893932],[8.81551707930524,-4.50094072396944,-0.857660958450013],[3.54726029367831,11.3528535803439,-2.8868047426743],[6.92404421816845,-1.09109621894415,-10.3092222121691],[-4.33850630396858,0.784804812328755,3.4572032851149],[-5.41628937828583,-3.04282158062603,4.42711420747699],[-4.42390825283149,6.78201871097334,9.01205510158123],[8.68345120213672,0.233969847432147,-1.38678143422561],[1.10906509823073,6.0000963332525,6.89217645490741],[-1.75327801135786,3.28080406843704,-2.09674427397248],[9.74876743061454,-4.60417753084598,-4.27663341902683],[-6.845922510759,3.17354684868769,-5.38542405367725],[0.955614828218247,-2.73316659874839,-11.6925559863987],[-2.87839554859179,7.02207173636401,-0.177725614967294],[1.90026049266288,6.1376445051414,7.80587851473695],[-3.4690617101152,-2.45295176557635,4.70099742171038],[0.22292194171569,-8.60564880363417,0.44414692588763],[3.40506994882577,-3.27777299985502,-10.3373102614909],[0.570346784579518,1.07587834339682,-3.08610072296121],[2.92065700480714,4.60154111625049,8.93840196502176],[2.11074475500554,10.488536567108,-1.51976775615777],[0.821476653859807,-4.65952021579364,11.2267241255866],[-2.28063552172403,5.42942300785252,-0.448683449890083],[-5.12921990769131,-2.54932072909959,-8.90553901558738],[7.43657661647487,-1.46735793266057,-10.7240214424538],[2.39583472215485,12.0596495171138,-2.41637542627887],[-4.69312426703699,-0.380306614462232,2.40072203477957],[3.24454613354794,-4.48250264342617,10.6553423755939],[-1.42470260491579,-2.35969631035115,-11.8902794878255],[1.92184742421767,12.2369790172357,-1.26529910476595],[2.28247036871771,6.29190732445513,-11.7414775834772],[9.30607423556784,-4.49652215383254,-4.12732935747455],[9.54045686234744,2.75911986445404,-2.00052959109432],[4.37124505829884,-5.02141985480944,-1.57652417273773],[-0.787310574643896,-2.63176227477019,9.77444321613657],[-5.13558872283913,-5.97203272741247,-2.37059774933948],[3.82961339797832,0.185948133419517,-8.98484469991813],[-7.14808544429371,-5.92026315595132,6.61307720038841],[3.00015090020542,-9.96603611723331,0.562129340179946],[-6.50686973503407,3.15219545213376,-6.21592360089896],[-0.536546119015506,-2.81607678911859,9.95835651299552],[-7.60099633616056,-6.9311979736477,1.60592430694512],[-5.93078714387859,7.80478203511778,7.96051501477697],[1.09292685703532,-3.0977108480557,12.9919698592054],[-4.3186535106551,7.50159302482397,9.09971167690107],[2.42196583830102,3.88568165173391,8.53584401291288],[-4.82345425969106,0.307854521449058,4.29203040342672],[-3.14005417471145,4.15954214514954,-0.329804763087634],[-1.59432983118275,3.18764837190026,-2.85288887252566],[2.61035743992586,-9.50317785187254,-0.765801818858366],[1.62350237548849,6.4560933136642,-11.9418439800416],[2.64432866881172,-9.16779127122787,-0.172123635358046],[2.82853601162075,-9.86021054600368,-0.193828945338481],[-3.46088595840116,-3.65887812681832,-3.42320427506312],[-1.6518676797092,5.45102663565533,-0.18065461898209],[-6.3353111999371,7.13316940973299,8.80784859673062],[-4.04824994527705,4.60576778733089,-0.0990294948652865],[-5.99959471333904,-3.34259484215957,4.54631812397555],[-5.7859025753613,-3.17103444510841,-5.29104044898003],[-2.74929275114626,-3.89690795240786,6.70064144370121],[1.42425996251989,-2.97775654296168,12.695456187201],[9.64594914890836,-3.80712864298874,-5.21315969670389],[-6.98984532065124,9.14197536397017,-3.96354570267371],[-4.72556709012558,-5.34600303044242,-2.56498614355209],[-6.84428603889003,3.10511770229844,-4.14173395424086],[2.35157560274457,-8.95797684112413,2.67941746627836],[4.13703297314474,-6.69846504546326,-1.90312157396877],[-3.34159514327379,4.05754047117836,-7.09004670414092],[9.32366196972025,5.72351547963801,-1.43032567771767],[-4.73483441802508,-1.02359099851172,2.17568137754409],[-5.12289988685891,1.50930502608687,5.22601193133038],[-1.22380894147731,9.960575377606,3.2310676430057],[-9.01293684667143,-1.29632709665626,-5.1747903260455],[1.16415181892049,4.27415079194717,-6.17066141659858],[9.47351622645365,0.766519942038039,-1.75598787847231],[-4.0736976954132,0.164058318840393,1.5689835338196],[6.90699060405372,5.2601072045467,0.848304714594138],[-1.46302732329062,-7.75244723980684,-5.43389845952849],[1.79610753931811,5.60661214600353,9.01887843898514],[1.3688827553746,1.71173655293079,-9.2133297202361],[-4.88311593749472,1.33344191267889,2.93512744686443],[-1.54290336081241,-2.03322362383431,-3.96948053489094],[0.638646478129156,-2.39925630744595,12.6387381067797],[0.84621857258461,0.260955664578561,2.8897233746777],[2.82986077135699,-2.48863971901229,-6.73096014989546],[-1.7487226382256,3.17881024388313,-2.29848430858573],[1.56394334988484,-5.46742122266431,-6.31961369097758],[4.60871602455935,4.73862698833395,3.49124966239246],[3.35590452661383,5.79188786231047,8.19510806899142],[8.00612798241572,-3.04066224419868,-4.75050067730394],[-1.49481984159319,2.64716622722776,-0.907311923579229],[-5.5635886950349,7.2676545229949,9.02842017912742],[1.32881101807852,6.26878009434646,9.30355831695621],[-2.89691110694717,-3.67564091378263,-1.99128837021149],[3.09457149547092,5.62136023489793,8.52458397398172],[-1.78124356739713,-8.08681195428697,-5.41185280776237],[-3.96239513120825,8.14895306220642,-6.11083751253402],[2.07415763486416,6.30667011679301,-12.2301733130068],[3.99571464496853,-4.72208561340665,-1.14831681582234],[3.80922199562312,10.3674993244882,-3.49569721144505],[0.320739528886553,-3.00548730547346,-10.6948057178506],[-3.137488984087,-1.56030550754562,-7.85289955350552],[2.70144817585558,10.2364347769251,-1.87097142099662],[-3.09302469139304,4.43692801214327,-7.46498821353217],[3.80275123246095,-8.41159723515458,-1.04414221076288],[-3.96074145533838,0.671808422005992,4.86685116229865],[-5.09329463148767,8.32908831478843,-4.79670398425498],[-2.23579196209695,0.286501279175002,-4.00223968370973],[2.02382350150192,6.33044254810331,8.60014504515982],[-6.82736362796897,9.01504974269164,-4.33909097275901],[2.2859722134848,11.186495224511,-2.07138688589631],[-2.54858525453996,-3.22130997033641,-7.6111932261272],[-1.79977124609679,-3.11776614848564,-0.477914295524726],[-3.34256275963511,0.226802510376765,4.97019580226834],[-5.37470895724881,2.78790438218385,-6.22309770229279],[-6.44597460001941,7.06724998965767,8.41442645839784],[3.36150198965986,6.61944019207015,8.5174105318767],[-3.492990591815,-2.78249600057385,-1.91731719231662],[-2.59320996790575,0.232139932709978,-0.6217753799363],[-4.61764305661521,-5.98765620346044,-2.68795006900385],[-1.07462255263822,1.63355358463474,-2.33588635921216],[-1.96905153465253,-4.90938823320626,1.94949568315121],[-1.65443706876927,-2.18574403988097,-4.00534211167801],[-2.07092625879803,-0.0329094045399722,-4.11138639337187],[4.19093571259475,1.8181918121057,2.62217381205266],[-5.75736938268959,-2.79908206559958,-5.11773812818609],[-5.12020604863779,-0.4161133046099,0.324990649080886],[-4.46790626216363,0.039611639081445,2.89559593671653],[11.0198124456934,4.70253245676798,-1.26830799116219],[2.71790212000401,11.2595856292445,-2.90542507438871],[8.68983192534637,4.74516881867006,-0.479344695969997],[0.529735999236035,-5.53163578323645,11.0995729838487],[-3.23757563452063,-2.5961916304359,4.75405727077268],[7.50820796080317,4.10920339549197,-1.55252769712434],[-2.55781715377149,-3.11427906136257,-0.29869722131736],[1.74902631206062,-5.19261682126398,-2.16548143636068],[2.16814806074529,4.20097283467897,7.44827142176265],[-1.39328896423587,-2.03485181005258,-2.935178923674],[5.16643178089543,-1.80226571770975,-6.73613991049401],[11.1214844242173,3.61637266463519,-1.19262519887476],[-4.78574251424279,-0.305340431184881,-1.13296055934475],[-4.36695041792743,-0.426031915249329,2.04283255162092],[0.953099962943362,1.93082168767954,-3.14198316637707],[3.37897405463387,-4.26207377776747,-1.29838422440949],[3.88902661322756,11.3206115639034,-1.3471023021745],[1.01740066985077,-4.28533552652481,9.84380334115098],[3.12901471813413,-5.88855009386242,-4.89798507243301],[1.01488232101963,2.83366308327389,-6.92105356843896],[-3.15731133680342,0.568758491336189,1.88175481990105],[-4.1014613208692,5.92781743289428,-1.27737371889235],[-5.05595323706954,6.59691726865183,8.35307085528057],[4.27739534038302,-5.65688508636202,-1.26955441963691],[4.1280364761361,10.6886867526415,-1.31337330953894],[2.63373728992576,6.24199317414448,-11.5361614657602],[-4.7593976431354,7.72568935779241,7.99557641375363],[-3.13273524384694,-3.02874131591911,-1.08825456682836],[-4.11932804501606,0.780313108305744,1.82659974723351],[2.05324687001891,-7.73393180205704,-10.7845986915121],[2.23974303343588,-5.72695676573161,5.04277925753057],[-0.041569885456619,-6.78584401689308,1.68055362131405],[1.7714726277917,1.86985376029438,-10.3147626612198],[3.67071826050405,-5.77939947631608,-4.77204932512483],[1.24889209797949,-8.82724869533796,1.77397768798961],[9.52585228171332,2.87282747514432,-2.24145568671835],[4.25315065032061,5.28795053666185,8.06656740549669],[-4.88519102788315,6.66646242802285,8.44960826300952],[1.46678511032264,-10.1971926579522,0.482382870429014],[2.84843880068839,3.49794182093571,8.10325537315877],[3.42931173847744,10.7545433177515,-0.804974297474268],[1.20371358472764,11.9099299359101,-1.33918172753957],[-2.60403879655416,-0.0447153747774771,-0.54444947107989],[1.15838399902256,-8.87489259810003,0.0532253310554743],[3.28758302958688,-3.66369919412765,11.4455974663576],[2.7510483969599,6.4544134978613,7.21966762942428],[3.3467570676562,5.19258327500473,6.63877074221602],[8.08155135649158,4.54067604935785,-1.3467001585978],[4.190829669313,1.58200380624056,2.51743435057952],[-2.71365650811707,6.78933966366639,-1.00747063642833],[-3.55383877940713,6.709431402292,0.136214954179222],[-6.16022815308717,3.41076977635105,-3.79016234089452],[-5.65485672764351,-1.59531486589302,-0.723945204926489],[9.4115613299497,2.86003869137838,-1.71223290797151],[8.61054420980105,-4.19244162104251,-1.22836832975431],[2.82283074975956,6.04466327366945,7.36733083752076],[-0.874831990014128,-6.28919274292238,-1.49285390232331],[0.382381012169348,9.06551034545835,-7.54035959681847],[2.9507406413043,-2.28129882630981,-6.60299984758593],[3.13595564001052,0.676034041129313,-8.78633794207052],[10.3168327145565,1.57007618104949,-1.38991214014053],[3.24596198825217,-8.11790440818687,-1.84110206125992],[1.08391477426254,-8.64985548913054,1.34032986740442],[1.4549173093475,6.26050225057948,6.97298829327972],[2.45677115172419,-5.7697886984942,4.56739702272826],[2.43677979885397,5.94263627324419,7.86191910144926],[2.85134629850123,-3.36085279091676,10.1324887721998],[2.29471241325514,11.7898274373283,-2.7683171641709],[-3.05933273897431,-4.85482619667366,-7.75298241148811],[-8.06353449594897,-6.58080210361974,-0.0648865255291096],[7.03172299530584,-1.42993599734312,-10.295377957922],[-0.374751420270401,-0.804602934883123,-11.178296873607],[-4.84882666487183,-0.653632863959601,2.37478197128645],[8.90537732159265,2.25928182233245,-1.27949912474439],[2.42553372225944,11.0585836767742,-1.42229713746844],[0.152453228446532,-6.49034923060064,-5.84336987325453],[10.3912050523481,-1.16471614652868,1.13040694295728],[-3.70496585479979,6.90161425666556,0.0185394831571786],[0.212252782379212,-6.40945582218357,-6.0196306474928],[-4.87301036648634,-1.1655865141647,2.04774569134692],[8.31635798846315,3.51202462792708,-2.5058016164583],[-6.21828174623132,-3.47800727656726,-1.69924291346537],[-4.51959082185427,1.97249877546591,3.01372403408467],[1.48078047916326,-5.8132983786288,3.89036021000756],[-4.25987995319995,7.2501954938792,8.60679344570098],[2.26705124245689,6.57585976970918,6.48434247333432],[1.39425853378062,-6.95700606319338,-0.436359470876648],[-3.71401373755248,5.92420317694225,-0.0551733269514065],[2.7009818298749,10.5069214242141,-1.17926110313195],[-4.79390540509493,7.9088482887104,9.13736772691793],[-2.25138880314083,6.62460994640113,-0.969747895818173],[8.92229128154473,-3.01343137731153,-4.38641151163408],[2.98542751251029,4.01083557421708,7.78910847106026],[4.0609741018633,3.89322680341014,1.23538862288098],[-5.57631054920948,-0.930414845737656,-1.48699176384664],[2.00834012676674,6.31927428451574,-11.7866812306539],[2.93863065461144,4.5365214182555,8.08071710109097],[3.51625020193055,5.78408804308692,7.69918384646972],[-9.52144944577986,-1.2297929819853,-3.5503641730981],[0.995391000108333,-4.27008773812789,11.0378825147133],[7.83429946751975,-2.93104406147676,-4.58670432229119],[3.9804983960887,2.94046249877915,2.80350553560051],[1.67940007664254,3.76601133507392,-6.9793431012514],[-6.97660800432194,9.11154565545431,-4.08861945404395],[-2.73320485940216,-0.981606073332584,-3.82137276103566],[9.36801389578746,4.74544230496306,-1.61395781916042],[1.07553075783488,1.76756004083478,-2.47978255969243],[-0.0888654239662505,9.19764628230761,-7.4017197279864],[3.36647268829214,0.555955271228696,-9.12522787321518],[-3.227558183356,4.46193042555706,-6.91167700658043],[8.86881639318292,1.2227039045072,-1.38956003904335],[-9.08017466353434,-6.05564246331462,0.910893510438243],[2.73514445396017,-4.00868001494726,10.6356654894633],[7.998620506738,5.9963781962768,1.2925764366598],[0.69325675026488,-3.24770658255287,-12.0405218016459],[-3.97146873264256,-5.41805000764426,-1.64284328031346],[-7.65227076843243,-6.49567608012444,0.902990838929395],[-5.88220008109901,-3.14732580910685,-4.75030315303497],[-9.72410324741266,0.600133995498706,-5.60569285796433],[-5.21098100816198,-0.128582536263421,1.57973273144547],[-3.90512965510624,-6.22823093702197,7.69748015030623],[5.39429396620212,-2.61701359022745,-3.62969696411319],[2.47844423927987,0.38817190804264,3.59322402922616],[2.83501108810258,10.7499281735982,-1.99114877147379],[0.591434193141909,-7.66827608290083,1.54415701992931],[1.04199379598007,12.1996098885498,-1.36610596352465],[2.01826780343604,-7.0830199116953,-1.66870613850517],[0.593828961761703,-3.32676921712035,-11.9993998849212],[0.585045701947509,0.826471171399844,2.85688983286251],[4.0008361824759,1.82024675352586,-10.1278318292682],[-3.82712284007849,-4.87399193632205,-1.98984481738426],[4.03133274333343,-1.52763945605519,-2.87911146058523],[-2.03122123867603,-5.89596393122398,-1.57870671421109],[-2.7410935284831,12.4983929259923,4.74299566297648],[2.65146672166281,-8.04349207584774,-2.03465624609413],[-4.76754568024484,-6.1097995392147,-2.87536460444054],[1.95515217740931,6.18556038854043,6.79855533235462],[-7.58496442001128,-6.63945562026526,0.145139364691353],[8.9591112547052,7.00105526502444,0.236872920649941],[-4.20152037689562,1.8888980363791,-4.75015833401486],[-0.36061889285219,-2.70238295407527,10.5281371855621],[0.984357350244696,-4.96978435783811,11.3101146652628],[4.25820434614032,3.46488172516402,1.12146886831461],[-0.0234213063853402,-2.51452947110302,-9.52922844156728],[3.06844743935044,0.457664242911981,-11.3529268239186],[9.34745087978603,4.17189944610226,-2.10688671193953],[-2.2501126557932,-4.04570820641838,1.87368274996712],[0.155225404697399,0.976985092617553,2.71829653834613],[4.11863818835846,10.8869270563845,-1.63819123717751],[-2.46550367177434,5.26355094491692,-3.08587098129354],[-0.79809652596172,-1.8719155151347,0.69579464048871],[-5.47176485225134,-1.62057499555873,-6.47172831181179],[5.3403301111247,-2.67093439780615,-3.68677138497838],[-3.7208608595456,-4.59174333952843,-1.6326756065344],[11.0084672063514,2.88106623973547,-2.21611268538716],[-9.14886922786602,-0.951402625717022,-4.87213104502034],[4.08844743060307,5.16603547895435,7.39821878355897],[-6.50913002211141,-6.08437142633878,-0.948381814404165],[-4.0027616074157,-6.62465607156274,-2.45280216371912],[8.73530608599925,1.92678254121703,-1.90356647704602],[3.81317590343964,-4.84600537596228,-1.27477833625108],[0.878561357629078,-4.86831424925684,3.09841296494615],[2.34482353532379,-3.43076900895283,9.93660220890606],[-2.56021492729644,3.90697251825179,0.315943239951213],[-2.01314898921525,8.99764811517796,2.88336255809844],[1.22227156888061,4.2765607048713,-3.88663879583024],[11.665322970164,1.92186398729949,-1.36911768404075],[1.67864580963602,-5.02548561775368,-0.228519229474176],[-4.31247223974247,1.63832847948356,-4.48138684540513],[0.81523040858284,-9.51476668362247,0.869403101868372],[1.73204726891588,-9.26249741000903,-0.143431548329439],[0.262478604516928,-3.0294080614929,11.8112718440426],[1.0865669672262,-5.58552912597945,-0.986260972165611],[0.19766361711549,-7.88534347913437,0.863604502261218],[1.14376138404265,-6.79318982515969,1.90915121776964],[-4.85863599506182,-0.296340397927627,2.37358847565319],[-5.64396202817271,-3.19450634405403,4.72188487029543],[2.86067927905242,6.30817413592624,7.75011719058232],[-0.821267873829152,6.42175655595535,8.89114899045403],[-5.23852819158861,6.7725916534867,7.74430997002913],[1.3641661818791,3.45850938960626,-5.66269672261734],[2.01162721669228,-3.67237005180217,-4.22711712298691],[0.524581816122813,-9.23554641004194,1.32714463256864],[3.1192503313951,-4.59535036494961,10.5837905120906],[-3.10626744346746,6.74518784065445,-0.621027022506865],[0.790510285589099,-5.89293073103018,4.29090655668608],[-2.00029509999454,1.63698836158192,-6.90571824440344],[-5.02713848921371,6.77625087944181,8.12566094745942],[3.83400521132879,6.35808495725722,7.93856439839584],[-0.927486242121065,0.615338883116545,-7.28237652939162],[4.08537769776676,4.82245322839508,9.05244020892026],[-2.12824942938297,-3.41804046844041,0.214376949187482],[-4.62411845687928,-5.96738446201227,-10.1889804765942],[-4.66986938069517,-4.29946708538007,-1.99337185423564],[-3.64244307917663,5.04202552693095,0.725795416251887],[3.66348246360028,-7.25247939052721,-1.81687266953427],[1.2427363130336,4.21594694916319,-5.4973548237645],[2.03674952511181,-6.55346865022077,3.26109424399815],[-8.14079197390408,-0.757374404643389,-5.04961294973927],[2.29701629515994,10.5919516820922,-1.47611983610298],[0.889703145790862,-7.77877911323999,1.55846660622357],[-3.87132510371965,7.7702268856179,8.90025798611712],[0.95120996075381,-3.29536692609337,-2.54725543593594],[1.20552887559845,-5.4789392752944,4.46412165113118],[-2.00158327353225,10.6277465155942,3.35790093495305],[5.13286866961015,2.72486584735489,2.37347927227642],[8.40450804951038,-2.58129682455247,-2.52021567019962],[4.22706545067931,4.43141488689193,8.3514282067951],[-2.36844773983166,-2.55389939947554,9.05895068649739],[1.43046485216888,2.33581512655948,-2.34282533892644],[-2.50395831624948,4.78986174429315,-2.38112164762333],[2.18721847867269,6.68862544334274,8.50425489600075],[8.15437780860419,-3.63448452305285,-3.33432782445006],[-2.09181385423526,-1.03898764312039,-3.49405949550503],[-3.10224093628759,-2.91150233440915,-3.49330725713718],[-1.65600577282018,-6.17109326438774,-1.75171355291648],[-6.26286976388507,-3.26449651892527,4.84577227816723],[-3.57706362578786,-2.9470163390799,-1.95948254607018],[-1.868902883598,2.39727326609786,1.59537991265927],[-1.69613693922742,-3.04883323007103,-2.25420449579255],[-4.9144192398363,-2.9509723047687,-3.89007770505767],[1.18830014674471,3.91837138830787,-6.04341992187574],[-2.38982573113532,-1.09262675997255,2.26965508212809],[1.59105030698535,11.9477498086786,-2.07819711268375],[4.63912427395331,-1.29999507020769,-6.57686008046334],[-6.2678894262247,3.28682226169373,-3.95522620843865],[0.587332557491375,-8.02290252427389,1.5139183550752],[4.38395082765635,1.60677561525889,-8.81906524792518],[-3.98231935802707,1.36177802105653,2.2962268526088],[1.97264860768769,-5.2993532093797,1.71015064957017],[0.544532167843778,-4.73884180477934,2.71383148495607],[1.60760645014529,3.90041536806944,-4.13013809640147],[0.864814334508216,-8.69457750841764,0.369523180279857],[2.13436546987004,-8.53601902905772,0.0868852382853819],[1.6076907116781,1.22176413387958,-4.98936827754515],[0.235397747518657,-2.67596679884278,-0.643737847900441],[-1.83033019853588,-4.29302849685782,-0.268766267962114],[5.01289325223939,1.6442849589504,5.2569847752427],[-9.75407726913545,0.756464292677815,-6.10259263669031],[1.25346420005,-8.03388470060922,-10.3634616198345],[-3.08282307678145,4.98552217869636,-2.63194756558733],[1.58521001471838,-5.01905352610898,3.19544317997343],[3.59450416294429,11.8523821551827,-2.44560410034624],[1.13559671261259,-6.66427811079887,3.35806390571331],[1.6264445585356,1.40732699096048,-4.72910791721503],[11.2421770451723,-2.0907132324425,-1.12004278673773],[-5.23825213240511,9.72368220216656,-7.46923280000807],[-2.63405482583047,-1.86045987433593,-5.82004413310386],[-1.99870660446438,0.0097548617513169,-4.90357532190036],[4.58050253119625,-5.69939644368382,-1.17912939060384],[-2.86521734912458,0.827856156130618,3.69639029350793],[3.40517066629679,5.12589935621977,8.35390207738338],[2.41333213347717,6.18629138527162,8.74357132338297],[-8.40679735762144,-0.993996181068811,-4.28211970725997],[-4.1725727128619,-5.29814009374803,-1.42720361868865],[-2.06117675826851,-0.718736017088975,-3.77122438990584],[0.896308532034658,-4.43145300757746,2.26192015044491],[8.40368620583685,-4.64732050004181,-1.55449874515539],[-4.27938149468995,-4.2167870686544,-1.22297860134893],[-0.188519641608248,-2.81604466816447,-1.11309252815548],[1.39475735164307,1.47937145769806,-10.0971624650952],[-1.92276702363713,1.61016339245358,-6.98152226361643],[-2.3589603478435,6.62446696582134,-6.59232386431629],[2.51380867694788,5.48140075640392,9.43533435895048],[1.43884568594874,-9.05447533662498,0.228918440676372],[2.69298224816818,-8.82404657133814,-0.764076172352008],[-8.17580974784332,-6.10265160843234,0.666914268582685],[0.21917346053848,-6.18401939772324,1.54629049066379],[-4.23534161681456,-3.41062493300363,-11.3437425964182],[0.757404192394585,-4.61568063872348,3.77295215429882],[0.887662337937056,-9.53437750330036,1.8987376278313],[0.0136886890474549,0.0624303072954185,2.52670762960699],[-3.93016022910864,7.92846575842174,8.54685922880995],[1.49165180551908,-4.5472274308714,3.88695110026011],[2.50621238412195,-4.41327439100916,10.6390791478004],[-4.08138066702865,5.19930429066924,-2.77396540557398],[3.92348030025939,1.71524168386367,-8.9384974061839],[-3.1077468929849,12.0384514857019,3.95779229856698],[-7.00622680152077,3.19774642876275,-4.81112631891452],[1.61797803432222,1.49311318448768,-10.4448426113203],[-5.22694972010286,3.7880817749376,-6.52982192272271],[-5.41564026342917,-5.97110039487071,-1.4289122791707],[-9.10353696408525,-1.83551347814247,-3.57139627618698],[-5.45895120816038,-1.1962793062887,-1.26573526816389],[-2.48666701712567,-0.187653556128794,-0.891213493294701],[1.95276221489311,-5.01215919277249,10.8930748565233],[1.97493470031489,-8.10700605196557,-10.7840104135221],[-2.99827620852157,11.816799028021,3.69746837050246],[3.00007465822412,-0.540083935004108,-11.9011130216485],[-6.17099360624763,-6.24994075038972,-1.40349030878494],[-2.56182213166163,-1.2446673527111,3.38315462678778],[3.91115207373927,11.0245657700467,-2.35451718512695],[-2.96754715108983,-3.84539059296594,-2.05599228477876],[9.60925953832886,3.42738458447101,-3.08544836177751],[-5.45000723726593,7.59150744227385,9.38844975974515],[-2.91055662190481,5.21179368278798,-2.9894917082765],[4.58089453698896,-5.18535831615875,-1.79048431343549],[-1.67094430866513,-1.6518256219603,-8.49391703019392],[-3.45574124657644,-5.7374402010694,7.26352070448445],[9.05971441046939,4.16101365497562,-1.39624599833775],[2.09441351108547,-7.9175460322001,3.65619114657888],[-3.98532549591294,-1.94119782371873,4.46020206778517],[-9.07226114311078,-1.17351032549015,-3.65726648605351],[-8.53683967827628,-6.45093605687279,1.10304358752055],[-4.31285719235484,-5.53091519201886,-1.25665080487515],[7.39632137084297,-1.44360568074786,-10.960011009992],[-6.02715848694026,6.99156946556767,8.50148898757009],[2.04074837671282,-8.9352717957997,0.332186780631242],[5.90653404477891,-0.391118768106745,-9.99157008598924],[-3.59307921133939,12.2472567558871,4.37293113575971],[3.96168297792065,6.23240134024882,8.52053444260554],[2.07181798284005,10.852495254915,-1.9863731812522],[0.701435227450868,1.62468234861996,-2.28480676536941],[0.2511873930959,-3.0109562665669,10.419766449045],[1.42171706357401,-4.96290172831917,3.86888978267814],[-1.22570435991996,2.48124587195356,-1.76700526355206],[2.6268522277946,-8.1099943030441,0.17492983986994],[3.72677608711029,6.06132562264994,8.94090475247217],[-3.25863796008886,-0.107111680218386,2.88271166365693],[-2.01644587929417,6.57739341363449,8.44497508257667],[-5.83611262431516,7.26919570844062,8.6080159305616],[-8.6140500287899,-0.514048130235531,-5.13844159403625],[-0.663434105009801,0.0170409207573237,-0.848315567307491],[1.76995755930423,-5.26897767121107,4.05563354868659],[-6.40884701580656,3.40576273815909,-5.59529460494098],[-1.72050683791078,-2.30220640876577,-11.9571862208244],[1.96262033733616,5.96216787352696,7.22071095183711],[-3.31103519600215,6.17502584620333,-1.68566493078396],[7.22488742135525,5.19982245782404,-0.261354881409887],[-1.48096635447246,-4.06093161475746,-0.185822388807062],[-6.68794613740315,8.97644434768905,-4.07157236002957],[4.31847123643668,4.73563159790083,3.15680793259601],[2.86683580500314,12.1786149248733,-1.4280674354514],[0.513309175050531,-3.52646744594805,12.2311298746989],[1.5239387464034,-8.17832447177898,1.80309069745281],[-6.13491269710723,2.48405117110466,-6.19291397276151],[-0.0239827685593523,4.464659626461,-2.83091991239855],[-6.72596630010997,-5.35402639125645,7.47913829504704],[-4.7344858805713,-6.22165379432465,7.87962258773501],[0.137249684081183,9.07402641347766,-7.82252007086337],[4.14213737987062,5.65961214110076,7.92929268626125],[-4.53058043317906,-6.8977203607084,-9.73981016281405],[-4.05584234195371,1.51777584194867,2.41937457940109],[-9.64350226594961,-0.47510783891065,-4.57325337388593],[4.54938870528775,5.10278267803881,3.35510442244536],[-0.447843778317614,6.35890069420216,8.98797213721861],[0.518929106554461,-8.75867823862189,1.86401638050858],[-4.03156115615324,2.79241440305745,-6.6062829278227],[4.38364539338511,-5.06038373234995,-1.50040408028449],[3.61636946869956,5.27404617355585,8.15004389230878],[0.0307401526095851,1.07712975971697,-6.64753898580932],[-3.69536949339298,0.443098520095963,4.99788693219058],[-2.25339121440806,5.10422846159881,-6.52391176496131],[1.88874146289665,-6.02150498044643,3.73357399433658],[-1.15918338531689,0.407339239727912,3.83881145958279],[-0.439612277385107,0.633730839046665,3.98684888539207],[-5.54817495227692,1.38041938560329,5.12431151623422],[-0.534492522534328,0.0155748766309215,-1.80160706053571],[2.21500906416127,5.77966737223813,6.65667758105294],[-4.54975325962969,1.59894874052964,4.6503996257598],[2.69984465554872,-6.62690947298288,4.1896844638545],[-1.99726864457366,4.54180409654597,-0.0159794269067889],[-4.1868561121204,2.31032485680398,5.07796138306302],[2.11618359028215,-5.02578018766636,-0.383901805305073],[-4.16461216387724,1.32299822357857,4.16185221734378],[11.2102520445662,-2.01442129778621,-1.23751944752577],[-4.50498651667474,-5.32517685303106,-2.61059803408345],[-5.86183918499564,-3.68342100297718,-5.00601223349556],[-5.71495353296101,6.95153638214509,8.27444766253695],[-2.65794416085316,-3.66189111090533,-9.17926764617108],[-4.00809597128734,2.82145162626894,5.37801448829357],[-6.00289932243856,-6.13962902246474,-0.140338584252982],[-3.71502680800935,-5.97788013014199,-1.23018085070147],[9.6280500514856,-4.05876509743985,-4.83595975468683],[3.2691726936292,12.0183465267855,-2.12856930005406],[1.3449023720041,-3.9234491315226,2.01512536136911],[-2.34068285990891,-2.41816023436182,9.14769674793982],[1.21918372325301,6.32556617121018,-11.5350438672197],[2.61710020764527,-9.41881424851706,0.345385993185648],[0.0115744758200556,-0.187528715680938,-1.86777662076752],[-7.71645551565585,-5.76136257919049,6.65039071274356],[-0.97234564726412,-7.7110417614586,-5.96034457006272],[-3.1146654115562,-2.89322712193164,-3.47802501666838],[0.19174255192554,-6.25723922589345,2.00682100504367],[-7.9930928984004,-5.71002663532898,1.85375271187323],[3.57335180758113,-4.84374523380605,-5.34898913772675],[8.16102084122322,5.9838566520767,2.32809583650352],[-6.81458540884714,2.81328079287402,-4.38306937733832],[-3.90544893841669,4.75211558544778,0.222184137340776],[2.40705195596565,-2.72369617805389,-7.666018118634],[2.04224608991801,-4.87965659335017,2.1382990185319],[-5.87881798857411,9.08402754205281,-4.27988180031565],[-5.94304952521168,-2.71838036699207,-5.18526753644375],[-4.97258405292751,0.988327973588308,4.10380648327431],[3.01292273009945,5.55920553048031,9.06226969572597],[-4.14961957026157,3.15006754171127,5.4851779339953],[10.5711751751631,1.87742719770982,-0.923861416797868],[3.07404531743089,-9.06159944413663,-0.598843519811867],[0.936557824063832,-2.56518600501737,-2.49183820732773],[0.423966377181921,4.2743865493622,-3.22053601991166],[-2.16125466435563,6.25354626201244,0.105236772203912],[5.08936557168361,1.20662956469613,5.28579549127652],[2.46819555090471,4.20752646741612,8.14430894796633],[0.942897008917525,-7.99522290374565,1.43091999989095],[2.06384748223395,-3.79551268268278,11.9099265262211],[-0.113019385159867,0.98268576438498,-1.83854930100923],[1.37538833715482,-5.4792496372105,2.07384545934643],[2.46760274429767,-4.01627973274997,-1.6349608151627],[1.10634417207242,6.2611286704672,9.54897387047165],[0.434760470660631,-3.85584169242248,11.9809544985959],[-4.42062447875184,6.93507700563281,8.54819509425559],[-5.96277778868477,-6.52341320382957,-1.2589253779831],[11.3566926157828,-0.554743602448052,1.32056871607475],[0.0926845954096013,-3.60637642028248,10.4333789065252],[2.41095725300271,-8.27688791111103,-0.875927731980579],[2.09824964397687,-7.70529832943678,-10.8865362577152],[1.27014673851538,-5.57610902722522,2.6249663107224],[1.23582717401056,-3.58649948629214,12.2297634696089],[-4.48556643095343,-6.02094930388772,-2.80248127622548],[1.5939322729146,-4.82312222402483,3.16185835626364],[-7.41323361675109,-5.91434647094756,6.83803063179916],[-0.176168990817322,-5.61707935690001,2.85557554965249],[-4.63205236404463,-7.16226483706696,-2.62864848475043],[-6.82102861495601,3.20242590260183,-4.16446634000855],[-3.9546828684235,5.9902279276407,8.51027277631895],[-5.69476135474631,-3.53565965001107,-5.31045921264639],[3.57749093908185,-6.44551464290397,-1.42971302087075],[-8.67888938449926,-1.28358696871118,-3.6124792520145],[-1.18117061675672,1.26430259999643,-2.80017028858648],[-5.00775216816242,-4.23653352756354,-1.81800024289854],[-4.06464312822019,0.277076064341716,4.17371862045061],[-1.49227700361921,3.21337229939539,1.92276550807725],[3.08817734064368,10.2735885890428,-2.23650662792911],[3.17359637569618,12.0366609562297,-2.70363715761967],[2.82549239194399,6.25139965002441,7.84188400751356],[-9.55352301662846,1.26738632214649,-6.20228944839546],[-9.2474920875185,1.04245533057506,-5.97080535089429],[-4.87075008664872,8.03156915572858,-6.69103576290905],[3.6808244708723,-7.52280439875488,-2.11454900901469],[4.00879963522384,-0.644847346800274,-2.51472910784903],[-2.96434512243808,6.38197764382035,-1.49157166126937],[-5.89998224514934,-3.26505466408433,-4.86607059372088],[0.604343935078703,0.243641016761529,-7.42099736139424],[2.34042271728638,-7.44330781107445,-1.49087131328135],[-1.32719419906294,3.70367884267126,-2.66927007312311],[-0.34518633784095,2.49379499654294,-5.43803650207144],[1.26459772270745,-3.57021357507347,10.1975190543426],[-3.11516168342297,4.0848165008576,0.743165116005421],[2.23796974096055,5.54091122761086,7.86625631980759],[-1.23523109804309,9.94546332276639,3.19316594510228],[0.34440919466276,-2.78185301895677,-4.89141939971109],[-4.57929207805175,-1.17945692516895,2.46178534240752],[-4.06522458528198,-6.51102331625931,-1.91057923113336],[-7.9895341912079,-0.757415421418598,-5.10948692503674],[8.07454457040253,2.4232138723958,-0.809018978516677],[2.39434983028743,-2.61621830199863,-4.45221534433281],[-2.78942676581139,-3.78410583324498,-9.37551220330924],[3.06403704057358,-2.836110989508,-3.37589302759012],[-0.918006548102032,0.446911418377243,-7.19485621800707],[2.46660142707401,1.4342189220288,-10.2947289246467],[-1.00298124893081,-7.06945511111601,0.362971248324659],[0.38293484313008,-3.07668003451619,12.8715750951984],[2.52661320344639,0.338074331804978,-11.623985091485],[-7.24247313677004,-6.11490694052816,-0.341334433453633],[-5.45432523924603,-5.74559379423361,-1.70261754905004],[4.95010291013006,-2.51342146651841,-6.94797015183491],[0.379277253696257,-4.67800413714117,10.5478724935904],[2.13176741693958,-8.96096855654895,1.43511404163831],[2.21012446004495,11.876247147424,-1.66290573159543],[-3.42550177152049,1.25695050084071,1.91602405820602],[-0.382870047518758,-2.84977726677672,10.0512483769516],[-0.551271578318542,9.12958995992641,-7.55077081823036],[-3.87966120449634,1.09971353892364,3.87786124451119],[-5.37590332098777,7.00026941618213,8.81189518882821],[4.21609898162911,-7.03221914098452,-1.29030891303426],[-4.23159531282152,-6.00595367408336,-0.909557522395225],[8.85527629140926,-4.39545430082663,-1.10206478784924],[-5.01053903240206,-6.28696977992891,7.19150736747883],[-1.05938276908035,10.049772547833,3.16606336897641],[3.28920795223655,6.37687968171687,8.90411070146984],[-2.79112487391876,-0.774788488113513,-3.51474627770525],[12.4715367498113,0.816938129549529,-0.0695092939426249],[-4.55255565885219,-5.8826998747517,-3.12419441001295],[3.04019473051779,4.93373469597109,7.75196272901599],[-8.12305790938084,-6.31908925313673,0.626055404718133],[-3.61171553717135,0.775986935496553,2.24271141475518],[2.13039002391447,-5.81002120372998,1.67131263541699],[-3.41075017063667,-1.88366795339784,-8.27787416925206],[3.9326897945201,2.60582750110071,8.01434313774025],[0.401750597520411,0.86056813901253,3.8792922180931],[-0.4231959518207,1.85660240181323,-4.71734355726183],[-2.15884641576327,-4.76692645870445,-0.218416554658368],[1.55813712005487,-3.41889274407139,11.6770113195423],[-4.28495756580745,0.976375168714921,2.92662263288165],[3.34107052137636,11.9601751770554,-2.64007468437771],[-2.63952216437271,-1.24411739899271,3.48353315725902],[-5.39029465807959,3.31404952095459,-6.43871698091797],[0.288298471963232,-3.3139937463678,-12.0219852169674],[-3.93452097563686,2.42048375491598,5.25270089388371],[7.34261022809691,5.31219485887614,1.68813935770916],[-4.49217324613124,-6.50316009287546,-2.346221032229],[9.67696563130597,-4.51439974419314,-5.13468650890242],[0.311495965278335,9.35962526146515,-7.16117529081237],[2.09848885289729,-7.17697532341889,2.35217519324888],[-1.01958930153499,-7.45347098499736,0.318222296826521],[1.91506272593753,-4.92357403225106,4.93872194337484],[1.78651868214424,-8.7356780780807,2.94832592129467],[1.573842376035,-7.49664773963103,-1.50399643591161],[9.12179847746495,3.42936037525683,-2.73178541828083],[-2.62016228099872,0.107275865931488,-0.684074323314094],[-0.83606455301953,-0.452110875539901,3.12296856004645],[4.75285867811708,-2.11092975955925,-3.18144418521116],[1.79416356632458,4.62765451746521,9.16823744939204],[2.2587273585243,-2.89397989371191,-7.77576954009783],[-4.94290869862632,1.23018685950466,2.81941297867982],[-8.38838331648603,-6.15979125921629,0.706980432338724],[2.47703359594536,-10.2591234096108,-1.94609412406524],[-5.12903424440097,1.34606598159025,3.00316467935489],[-0.132567755590819,-7.61976053683481,-5.88015136622281],[-1.29688041481641,3.70026968017877,-2.50410387291413],[-3.74762793114473,1.34252134413491,-6.33107059181933],[0.287176068399866,0.170909764429661,-2.63333098085645],[-5.44139329223875,-0.770079573038593,-1.35330356857521],[-1.38489847087496,5.04647325574632,-0.823392206053666],[4.23228187128119,5.66909556499627,7.8707340609024],[3.45245350151994,1.20831717597078,-10.1645281893409],[-2.17207805195086,-4.13694063300972,-0.336136547844172],[-4.15529010812922,-6.80862317982988,-1.77506124625488],[3.49193837273,11.5712033971529,-1.88122112258893],[-1.46451486431659,10.3640500052212,3.42370377875949],[8.46222628108597,-4.3799082938381,-2.70414238905483],[-9.28350429022421,-0.188517991756349,-5.86419150823214],[-1.8396723360311,4.56917823343224,-5.39768132093137],[0.639839763022085,-2.16988038731099,-1.80656954399488],[2.20956127839627,6.26455146222099,-11.8878415527401],[0.513273270467952,-3.57562515535132,12.5434409310464],[-5.69519309859207,-3.32180999565202,-5.31127728451892],[5.02749161027642,-2.93993259367334,-4.22543648699979],[-6.38494950259041,7.37774637988453,8.56507282340957],[-0.799276408274111,0.969660477504074,3.40127026106659],[0.750760764656113,-8.44459985460734,-0.373965186814942],[6.62232031287791,-0.915405335514357,-10.4209805743612],[2.06485484404974,1.55515340586942,-8.99735161319874],[-3.5812142619354,1.75686918393865,5.51143402740926],[-1.35483316166062,4.37606640951473,-2.91683350069569],[1.18409837349727,4.1139654514692,-6.50609058231631],[2.63520590136367,-6.72355874651571,1.77613281654131],[2.32501191733043,-9.188152348984,-1.15023614444109],[2.11162387175355,-0.0426990402415055,3.40594638213597],[1.78649949769228,11.9874375405982,-1.84053004702028],[0.262357031636733,-2.46345946761834,1.91027401798721],[-5.94469551681028,-3.42553475354789,4.83480019855047],[-5.32022345984261,2.88791919427114,-6.03607241653564],[1.07929884687776,2.33773753882465,-1.73612774141697],[-4.70013213631378,-5.01425835093136,-2.59678497923533],[-3.42006712831355,4.67441456941251,-0.439548063592119],[3.17416255163665,5.99198465029315,6.96491167323611],[1.76389699546397,6.36886202894514,7.0323823416393],[-0.531432003568004,1.10900480540735,-2.22924607486506],[0.619166409340693,0.485058125383194,4.37186267100737],[-3.82416598591078,-4.94430439176313,-1.0338340025466],[-6.34607017591908,8.77911818353151,-4.93229305181916],[1.68643375931273,-7.75893552318346,4.27022710042841],[1.21396859474226,6.16299030549828,9.20662666129132],[-3.81261245368863,0.289579627873961,5.21088580629765],[-2.73230856947518,4.21066393057288,0.587537562533544],[-0.147365548616213,9.19614670861428,-7.37083735956986],[-4.79428360525262,-6.53030156265205,-9.05253796314613],[1.40629969411531,-5.44490718656326,-6.06436424662548],[4.18893053722983,5.55237727645622,2.7144665309986],[-4.41747947620101,6.40835313189995,-5.06523317864772],[-2.89617964100641,3.84936749152946,-6.43658747688933],[-4.66289121566758,6.56111033913153,8.48883501586746],[1.590792705834,-3.73600793186447,12.3610619316012],[-5.80378427930807,-3.02628348155394,-5.4646121258847],[-3.2085639079557,6.90282372240343,-0.991065895709188],[-5.70611169752625,3.64404812963555,-6.03908516357115],[-0.678470501037343,2.70903653400715,-8.09876134455196],[0.698225121013245,-4.56017980236842,-5.56271432720315],[2.31287158950435,5.71151003155726,8.65943798458848],[1.97934336361532,-9.8577603891111,0.380030216731508],[-6.28286064277845,-2.69674809893505,-4.91829611449809],[1.21884736810482,2.46781293822918,-3.048686472529],[-9.45850599940007,0.738423738952264,-6.17736566607376],[-5.47503965642845,10.0020959344041,-7.25082696928667],[3.8607787520162,10.1964652526402,-1.06247348425307],[4.02904169682383,5.74221136060156,8.22477652832982],[0.949665236006603,-3.11635719222882,11.5539625445588],[-6.73105025835314,3.12042458735098,-4.77538886615051],[4.14947421112038,1.00800623127388,-9.50832964396834],[0.0590590383433064,-3.72163498164852,10.3600050571788],[-6.35864627233418,-3.81769435547063,-2.96093915650517],[0.058512900563721,-8.06093649683024,1.5039876033568],[1.35582452605794,-2.11930421016471,-10.5244337701494],[-4.37315555221168,-6.63501329604128,7.50567713768019],[3.35405720610045,-8.10402588224906,-1.46219620973936],[0.219575937242964,-3.22157686639456,-12.05547454279],[-4.74861252525882,1.73591309143418,3.27858194147666],[2.32062491372603,10.635979669837,-3.46506866139069],[1.98712041006557,1.4170974445318,-9.48016993207897],[1.51178654599447,-2.47863419305932,12.597005525009],[-4.76833937550587,-0.242941031860245,2.70159961605123],[0.191352286582047,0.201950938684848,3.00494158121362],[2.81563498665868,4.29903430072313,7.94024760377523],[-4.43733066094037,-6.75595303211108,-9.65181509357381],[2.58038506683189,6.02130885636036,6.36229862907975],[2.29635497437432,-10.0526021632736,-0.981815696186672],[-0.000198074138383797,-0.164023217532844,-1.90337797338857],[-5.67009858817972,-3.46207331737335,-4.84403495898511],[-5.40851364707078,1.17681836155605,3.94079873731342],[-3.89632024488793,2.76554250772641,5.47164840241994],[1.60962164396878,6.25987075816248,7.82915726370075],[-1.88252066016682,3.04388815054134,-2.40625220910079],[2.40376342419539,11.0797106996066,-1.78796408884071],[1.99980665350882,5.24862926766664,8.19147847809189],[-4.16400506390853,0.645852975537948,3.0358329207495],[-4.80106901560181,1.3858886624901,3.1532817187625],[3.24978668880139,5.11409626135505,8.93743614821222],[-2.61744388356976,0.0990432964673783,1.76086670535097],[1.34306873450482,6.48462802764789,9.05372450789887],[-2.71616912745836,5.09552069776986,-7.61684444827601],[2.22986624978145,-5.58993740134469,5.1513487773035],[4.58655273464047,-5.46742605095358,-2.57472639662163],[3.22483790498277,-3.36577218146637,11.6292260519629],[10.8455037517517,2.81535916761965,-1.68472277195501],[2.66325784540874,-10.3490754142185,-1.3215696449111],[-1.49505549319091,-6.71259898229351,-0.201401372510511],[-5.04472619871234,1.49059882653998,5.53374033211257],[4.36006430742773,5.3762599323898,8.67351408428808],[-2.99875644952197,-0.476797874427743,0.728323371873384],[-4.04992978859109,0.969538954153935,-3.76149564510337],[-4.15817774923814,1.58775568728101,2.9244485374964],[2.75767476379204,-4.87754632256804,-1.63565445370045],[1.15297613312441,-6.34871130977791,0.126842591214821],[-0.122751632971612,-3.48320955545555,10.7647151197953],[2.60627691581435,-9.29498497412249,-0.198524429006596],[1.48406894506015,-6.01266592348201,4.60828320370496],[-2.6410320512716,4.53845309935526,-2.66140816822048],[-2.10298581760478,-2.23628994879389,-8.66241980534339],[-0.339172134803431,3.73945531843455,-8.89371317350287],[-6.25110097471002,8.68223488686917,8.23907742767298],[1.49757296952779,-0.591858359270348,-9.7420856899896],[-4.93086160254563,-5.89900458728366,-9.71921321441635],[1.38703886961048,-4.12764766068803,-0.0502577214579069],[-4.91690293227174,0.865786222965854,3.09762901567416],[-3.17434886130609,4.67340912011232,-7.01122250981766],[-6.83358659658518,2.2824077692112,-5.60685019254878],[-1.20696799493092,-7.6223173406492,-5.65922833791859],[-4.33680271819014,2.42902585042125,4.05896393596208],[-1.63536996859583,3.4463043316707,-2.69053656506038],[2.44997736888868,6.30657067541484,7.0823809971929],[3.05504614216431,0.614398989159377,-11.1815300287862],[2.0935481164953,-7.96507289682158,-11.0246073345364],[2.65118386087337,-1.00812998859685,-7.35295949306793],[-4.59307100251606,-5.41653439391509,-2.35962689763659],[1.62084437706899,-4.1436120748085,-0.158320170033126],[0.299482663116702,-9.44532237805319,1.39159323667268],[7.43282145243564,-1.74340656238909,-10.4985217806986],[1.72446237974563,5.35535443637462,8.83026951900714],[0.93765006939195,-4.68481516567316,4.24869984504005],[-5.151827999585,9.04349317718297,-7.65641979060435],[-4.4893085419395,-0.648276838360623,4.57915402955686],[-4.52131822714213,-1.24891582477964,2.68057010920917],[-8.12245139603849,-6.76824527151772,1.69179551449017],[0.719387307723193,5.55944307720441,8.47943348184257],[7.52483606608918,2.97463490223729,-1.33112866791464],[1.6286465683509,5.35703177592149,7.48452799549053],[1.1735068507423,-8.69924025629289,1.40576766395539],[3.62408452707545,-0.578150308543667,-2.80179721066064],[-3.15139679665494,0.666660816035342,3.96746324360683],[-6.14380173688749,8.22548889099316,7.84572170335928],[2.06451112541372,-7.23488979317127,3.11359428965417],[3.03711406784026,-10.2461420487954,-0.626606773116021],[1.17088723080424,-9.1856539676067,1.97212191613352],[-3.0898821926071,6.54051728508959,-0.631693475709974],[0.255819771653333,5.69487640639246,8.29098491793158],[2.52547042770019,6.69723398450281,7.03616134213378],[2.8136841190162,12.0952545902991,-1.64400717927251],[4.2176722573365,10.318091272769,-0.660639717041168],[8.23722004635753,-3.2152943228412,-4.64788924067975],[1.38897557438477,-2.86602397108485,12.3779625820434],[-0.387469887797891,-1.28645758321098,-13.8117506492112],[-4.28931970154733,-0.226127368951948,-1.79050030926329],[1.40008731563616,5.76473630771129,7.92180256311157],[-2.71106780935635,7.11763428934404,-1.14998102579264],[2.96524122570877,-2.77590777972004,-6.87293098232895],[4.65057121137957,-5.85933495811388,-1.53297172502471],[-6.74829762457529,8.6837486474264,-4.27579274574299],[-2.74991222686504,-2.53669852784295,-0.289531847512489],[-3.86907401548839,8.34294023124199,-5.83678057864862],[2.38349124909027,10.4426252026622,-3.53015099860436],[-9.24014026066675,-1.19053062863762,-3.52939615814661],[1.6685012011352,-8.22975215246263,1.60803860172312],[0.327368834355533,4.26827702600089,-3.70254532695798],[-7.36504238121735,-5.8437921539212,-0.0575915776009744],[0.0953787287519965,9.00044952631985,-7.70229306679478],[-5.47533964448536,-1.51767676342761,-6.55144631588513],[2.62899057364424,-3.33631882806502,10.6436364710551],[-4.89193858037029,-5.58748841602053,-1.36300749486429],[-2.33859154217161,-3.77894013979001,0.090559431902331],[-0.0754859625168185,-3.11888290036733,10.9986749435601],[-3.4568358254218,7.42441313909221,9.09734213776102],[2.11444269864288,1.0490596186797,-6.67151159655475],[4.12333068107473,3.83945563955433,2.73097015127874],[2.00223608720764,-4.07928993065671,12.3693258946601],[-3.729326212419,-4.21388500915264,-3.12617408525299],[1.22747585552404,1.54786812410587,-4.96980746032702],[-2.85436563186653,12.5929779966299,4.81014474228031],[-4.9141364705237,7.69517583288612,7.68381788813353],[-2.9527515786229,10.8998434021353,3.77056173000555],[-4.71298984867051,2.17914444674889,4.44252152503185],[2.48871342378899,4.14282478653047,7.86305166550763],[3.25948702016579,11.8594416670802,-0.762225710332534],[1.68201310184435,4.03850637885889,-4.56668665242833],[2.34761170007107,-9.96694302354504,1.19957660950546],[-2.37292775955815,-3.78144526819623,-9.15011117950593],[3.09177110350008,0.343851377740071,-11.2876447375285],[1.8649757469229,5.74502849451864,7.64745182653511],[3.1490068238039,6.63049614748506,8.16761582520185],[1.35739940588211,5.47043544372697,8.20668536433647],[1.63016099040695,-3.36250841432493,11.5757117946017],[-2.65577611549411,7.32388811706529,-0.602828275676021],[-5.14115961403061,5.98378520060312,8.54767594884158],[-2.57546468029873,-1.05384328955205,3.5909090613543],[2.29241472354939,-4.92715784698852,2.2548806245973],[-4.68960580062397,6.35923000753111,8.16351152671828],[1.42720109152279,-4.43588163007257,3.07641931918018],[-5.0458842653185,-7.10819310167183,-10.0478992996229],[1.3939669927392,-6.6356766540469,0.272096223996363],[-4.11051676023788,3.23601860673248,-6.39651470885436],[-1.43994982190228,-6.51626377559466,-0.819438865586096],[0.41485250581452,-8.36277186677107,0.541178958655192],[-8.81372030182954,-6.11792309159719,0.831144759375875],[-4.8492722192021,-6.32304730120208,-2.07366615643669],[-2.38773625959418,6.65598559703056,-0.533061971091958],[-4.96600617661292,1.26014521351825,2.58301520668884],[1.64242493799945,11.6072731135951,-2.59341058043814],[-0.0191857287828918,-7.83120121939041,0.673099097821829],[-3.39231274696503,0.696064329755766,4.30305347562421],[1.62773073354386,-5.42372022966523,11.2216225205299],[10.2157469638208,3.43487626168183,-1.804089326418],[1.88217824331938,-3.48412251423159,12.6678011233713],[-2.1589604245209,-0.40101058278144,2.89030095913012],[4.0909576777563,10.6277104882639,-1.34574124810043],[8.04289588613704,5.58962590372826,2.91039052980884],[-5.41795288518111,1.41132118728854,4.228180957818],[-0.749397651522196,-5.01048994843733,1.92822358097792],[3.99618325776035,5.99498851858987,0.144993845739455],[0.0416686952464141,-2.8298160754784,10.715205453613],[2.38731956103302,6.87204152785807,-11.5183745880076],[1.13375664105984,3.02192514854814,-6.95104565544793],[-2.31866719772927,4.57416078833875,-6.85940195157419],[0.454015685117657,-2.95362010883543,-4.88909015498348],[-2.21776572734873,-2.1217354919373,9.39671906447579],[-2.1802073279553,2.73760637479757,-2.15320872053112],[-3.41250515930644,-5.3711915442849,-1.68027047920103],[-8.7779388158897,-0.283937243159698,-5.36615834239358],[1.58739966632171,-0.554741381596559,-9.81900443113879],[2.20287640829748,-10.6474802379753,-0.489815481569922],[1.03878512275873,6.28722281797457,7.25672807677745],[-4.92100883516519,-5.87349937585464,-1.29380356121119],[-3.36733814677826,1.03341251149075,3.22938776946138],[-5.99203668528599,-3.36065236319001,-5.03555201719381],[4.33943111705051,5.35563934176721,7.95525725425209],[-4.69293868988126,5.71618896618016,-0.515962881601326],[1.6219504802354,-3.4379087204702,12.8165952121307],[-2.57831473311771,4.50131429577863,-7.86640535761503],[0.0498564409917998,-1.37944167120257,-11.2008817609171],[2.49736173995602,5.39864605648371,8.66417987795521],[-3.45109579135195,-3.9612734014339,-1.87250996526284],[0.618293872665152,4.25273601034064,-3.67783703060857],[0.569854335446172,-4.37161603225388,3.44258945013072],[-5.83762958683248,-4.14572495313865,-4.43083397303144],[-2.14471686882107,6.62048917221696,-0.490936234896755],[-7.84026445313278,-0.561777843065659,-5.18504756801254],[-5.40974720951125,7.13186026512422,8.19246225441824],[5.80868200864616,-0.605767742204967,-9.99016147897939],[-9.2731409892749,0.445954359548392,-6.30287039369759],[1.74705790278427,0.648943607581297,3.8909098097612],[1.27123771715027,-9.59046280600904,1.82446535608301],[-4.98646672323374,-1.24941676531733,2.34741180428591],[1.57280115798851,-6.73909250779506,3.6667218890522],[6.54095532999479,-0.931568230138804,-10.302138830061],[2.57965503458838,11.2858754859071,-2.70267445336728],[-2.28073537839416,6.88927646509224,-0.558813208484124],[2.01754389017387,-9.66595924654781,1.23208330135916],[1.45672617109478,3.50580257629319,-6.51338114964647],[10.229143419753,3.98766379662821,-2.81417690811374],[1.63448011837806,6.2521956700077,6.25740371505802],[3.81132930361617,10.9342833751255,-1.99275854955832],[-4.21189573157143,1.33342971288508,4.62792240447953],[-1.89057145527964,-5.15488505856373,2.07348896314446],[0.685562244029541,-3.71486908083681,-2.67312256456476],[0.968450556453844,0.619828843335895,-3.06167327361355],[-1.03529887211301,6.41159158079495,8.98595662872857],[2.7057098879866,-9.42878073103648,-0.656512150426836],[-0.0441591131403669,-0.940366794733902,-13.5423095306442],[-5.10009914926435,7.61753497628674,7.57114431016372],[1.79162469282155,3.9429312996633,-6.38628010557711],[4.8424205880313,-0.512000036782366,-2.95223622894632],[-3.28703728882522,-1.57179783505092,-8.3504930650224],[4.72515083255966,2.25037302710507,-8.84859134888263],[1.01107556096733,-6.97383601092079,-1.34307205180451],[-1.49863946149861,-1.30337989206046,-2.71082343435231],[-3.67018623483753,5.42628947130356,-2.41098815869213],[1.79029852276863,4.51215742792526,7.7361639147858],[-5.21964252276004,-0.180449499239844,-0.905140858878478],[3.17088436125199,5.12582526589181,9.11928013457881],[4.40673700291083,3.43262822338532,1.57387746073428],[-5.95638469631967,-3.16361953449617,-5.26126803672542],[1.83772208590868,-4.61897425389224,0.753560407823565],[0.0358572539272768,-2.59358009940371,-9.57975279743838],[1.58043253193615,12.2222264043393,-1.43338922648551],[-3.46387370334952,-1.53482704109332,-8.18899443191458],[-2.99001376137778,6.07562212722508,-0.5203813106156],[3.72069978448465,-0.473377235710729,-3.71431330516412],[-3.94664337991159,1.38101451163458,3.65568741252863],[-1.71206956743674,-4.8839152231175,-1.16034140190768],[-2.29089014339444,10.7015958312802,3.34088285827101],[0.627506752108009,-6.42016397989195,4.00003682363116],[-3.43033153612355,4.85897373642659,0.573710244776665],[-4.25338617703853,1.05934502632718,4.09229715060171],[-3.26898217323401,5.04457865355268,-2.21927566995295],[2.48224237837936,10.7491981633865,-1.24014600036476],[-0.239260496013987,-1.3267720719102,-13.494030372032],[-1.78952409633681,3.9117807252423,-2.40801544483425],[-4.55126183208724,5.27845733562544,-3.8098009645296],[3.35688458873439,9.85998644713198,-1.29138763429418],[1.68040226626926,6.8416206604819,8.26851574531296],[-2.8557979286956,-5.06213920117503,-7.15991050901042],[-2.88157143463529,-1.85861147448782,-4.43973936928791],[3.87032608590222,4.69657647980589,2.0484820584894],[2.85279083339461,-9.65027295536534,0.883650327132034],[0.990421327227966,-8.28058519367382,2.14178362369763],[1.29631136996215,-2.64613411473031,12.2701652381147],[2.30649518595371,6.37666972012129,7.67306542972214],[-4.86919508294806,-1.97820694368004,4.07125413089406],[0.892240370916392,-5.25402929922809,4.56844967208175],[1.17480153235406,2.5045248137161,-3.55449205046352],[1.22817178733235,-5.86424734615536,3.28788424011716],[1.26249852854011,-4.87400301038087,-1.98462802977586],[1.39274331995511,-4.46312686766703,-5.07336668124399],[-2.06011230678365,-0.0343001734335107,-5.119100978298],[-5.9593449939632,6.84447664409667,8.63468433341356],[1.83845858287412,3.8883294929667,-5.18772643696752],[1.87356237129478,-7.33506314586451,3.72624177345965],[-5.10590657684361,1.88679562654846,3.21027326808992],[6.86522841330796,-1.46870364344314,-10.413713180662],[1.50283700979695,-2.87712306759207,12.3820612270048],[-4.54430854759558,5.88687833522862,8.86229088238932],[-2.72635133583013,-3.70040167433462,-0.2580341335713],[2.35099096382295,-4.54267303171398,12.2683148501647],[-4.56012247113518,0.223058167173231,4.00791519084499],[-2.35205149568871,-0.435266891393888,-5.16741194165411],[-5.48067431142852,-3.41642352631495,-4.57527648952972],[3.16911220033369,11.3186000900365,-2.8195525660611],[2.8033328330281,-6.76789208587766,4.23093272841911],[3.53465457093761,-1.53911759622911,-6.72865283118568],[-6.34573676601499,7.81806470962326,8.16513517831044],[0.577502125852663,-4.66017988752649,3.44143032764405],[-2.92110708345331,-1.32667837101772,3.57398229961414],[4.32330609976991,-4.94060501905566,-1.8338574987427],[9.32333576814874,4.64426351343432,-0.824247583747247],[-7.70964421590055,-0.014385796422842,-8.03299310673491],[1.80190397360028,-8.83374423331202,1.4964749038686],[-2.96375494130455,-4.79001834794304,-8.60583686161885],[1.01407074751301,3.96085621076271,-8.53726410095458],[-3.3577352522023,4.68025717954631,0.821294138343069],[3.13324399862757,-4.76410941986913,11.2897350437202],[-2.85447929436515,4.89785057847775,-6.84117595148817],[11.1919762503881,4.28561351142244,-1.9112017970137],[-4.74522753530136,-6.02986505421867,-9.60913440055177],[-6.74310888639028,-2.77324617550634,-4.86222282368143],[-2.32603797565668,4.64386547847331,-2.22925790668213],[-5.72350629629448,-3.81463716310232,-4.83457348159383],[2.70473654376471,-8.16174798661011,-1.35099045747956],[0.859182886807004,-2.81123342815037,-2.59648225585916],[0.910235370628836,0.186548983156982,4.27428564839765],[2.13692699724544,-7.16286930307789,3.16951697336916],[1.76818054873207,-6.65549185560616,0.286129492231939],[-6.45556851353199,-4.07316143211646,-3.82557331791707],[7.43568856726021,-1.73908563601122,-10.8463238214378],[3.17106609388762,-3.07519553927718,11.6184487915742],[1.65103687605901,-9.18426610876672,2.67532017894021],[-4.64773674619314,-3.23263269912167,-9.03070545842472],[-2.91274090655056,6.64658841195261,-0.223122009836346],[-1.04610704541436,0.629717456311918,4.43052185453049],[8.76734460972641,7.14892798433202,0.851853192036123],[3.02187616359663,11.3660872434337,-1.22694180397644],[9.2163388894576,0.812904986641599,-1.39156834802731],[2.26495193505526,-5.98583050711421,4.80878343048468],[3.17198947258811,0.148784965584769,-11.6213651999888],[-5.66670337398407,-2.80361411540401,-4.36976577446698],[2.84874956825417,-9.30154615089401,0.621643454212431],[-5.15195000690528,1.17933129094236,4.05397620943253],[3.67952664200892,6.31522930704423,7.55681280381711],[-5.32356658754995,7.36801886061647,9.03462773261763],[1.21174324598683,-3.30010987747284,13.288308993553],[-6.37569530859189,7.58942565508178,7.83894504043304],[9.73490534466089,2.75980038128155,-2.01820113851761],[-4.29764808907131,-6.03905141247252,-2.56338418691012],[0.75280755586469,-2.73769565107251,11.7448856949554],[2.41301423419801,5.69402551046143,6.50930343681799],[-4.89703066673141,-6.29582476023382,7.16485113560114],[9.97243435422932,4.68129509300191,-1.02520396414469],[-2.48568918139932,9.12760819691772,-5.5301371558022],[-6.62844587585644,8.24643589310285,-3.74875039195909],[1.53508520429256,-5.33172982822743,2.48176730394661],[-3.5410443561531,4.02308206693826,-6.50551070069777],[-5.53344381868163,-5.47401823252968,7.59054908463503],[-1.81000100352561,-0.0655851152229983,-5.18764677434709],[3.44804489432321,10.7226807896379,-1.73778392579307],[-4.70200958461202,-6.18280087994079,-9.61004184937432],[3.00351890040044,-6.04315712793389,-1.65500853608769],[3.91914936849333,2.21272312827004,-10.4454232037338],[2.84419705469159,6.15274494053878,8.5281349939677],[1.3066098468089,1.833725404226,-2.35571586177834],[9.23903536537795,2.58946398778385,-1.7510746274872],[0.92645208381368,-0.396903032137548,-6.23779188907699],[-4.98007527041398,0.883283065674703,4.13272992677875],[0.900336909386764,3.3454385098013,-6.71070017329108],[2.51878386625759,-3.51763032591821,11.4185708605506],[-5.84007128885158,7.1675398786311,8.27900524640076],[-2.17109728896393,4.95151693264262,-7.2877795918215],[2.60777071912423,-4.12991516746641,10.268650138357],[3.52420244248762,-9.01616421445248,-0.654459723200709],[-4.00408660330063,7.1972776030805,-5.87512464239113],[-3.72004151876998,1.12971098081712,2.46867479347535],[2.0330066320258,5.77579177485183,7.77665589798457],[-7.85496631641301,-7.13073284234772,1.79087936241245],[0.808732112443029,7.37049117918096,-6.23942074264195],[0.705719126174808,3.28803585748822,-3.48226998131996],[3.90228406742045,6.16689393815913,7.05985318730401],[2.55161842036835,-3.56249066668545,11.8884974624855],[-3.75102063404867,-4.79071235076473,-11.5274202118766],[1.43459333005159,2.83578913492875,-3.57354638130391],[1.29568111041097,-3.99003464092743,-2.56846771130404],[-2.69800382492305,6.44954213682948,-1.77113600572863],[7.04864725634203,-1.20412746968574,-10.7048787996738],[2.22830687318185,-5.48474764341164,1.781562016414],[-3.35208127260517,-4.23937700521495,6.94626739120157],[4.24052481803052,1.85534231884819,-9.08805559145375],[-6.15918934521517,8.03214616513263,8.87346294498246],[1.92857235999812,10.8695426170188,-2.78599491206896],[4.7510524282871,-1.68343196319202,-6.72773222148793],[8.17848262703523,2.90322591562889,-1.96468781016748],[1.14019403566646,-3.49783871581119,12.8217778043505],[2.89859588627419,-6.9192423184645,0.364517272714287],[3.21100671674085,-7.28208020044416,-1.71481829585258],[-6.97698998539426,9.38611731638286,-4.03742623405615],[2.12443340834085,-4.97875233421361,1.97422369216924],[0.315420097232033,0.0237105523204295,4.41433328623507],[-7.64243403511294,-0.0475844806047421,-8.78985714412753],[-4.33684347430228,-1.6851759284926,4.03701658430093],[8.68390556301588,-4.21671200524553,-1.01455154385916],[-4.96897923429796,1.38867732524181,2.42257379503979],[9.6238766310209,-0.201816034013151,-0.442723352392351],[2.08112638394374,5.87105446446611,8.23153312733897],[4.21886353501181,1.57840227156378,-8.84081831151783],[-4.184647366895,0.86321007507422,2.2905603692747],[2.80484658735401,6.29131241088354,6.94108338987066],[-1.48284361030446,-3.59485461052861,-0.847785176512735],[7.48068198576807,3.51696937501473,-1.53283676181372],[-5.04264981678421,-7.03805804090932,-9.59930896479495],[-4.21090927446246,1.83983983304315,-6.32015627552058],[9.88625384051927,0.495859278241382,-1.21836531574665],[-2.74744337485079,6.31086606944143,-1.36698239296122],[-5.21872659816364,-5.69528841428676,-3.03557415119506],[0.779264849973513,-6.1877633026504,1.60724881987124],[-3.34485966154089,0.701796821607649,3.71960032769837],[2.72511098868778,-6.4842177042257,-1.98345098867754],[-4.34364473177288,-0.439148157588829,3.03246473075341],[-5.91625123673917,1.19101677987463,4.03942406628871],[10.6126924529111,-0.506705029599733,0.267432779148355],[-4.46883912328456,0.581590699022348,4.01954130015031],[-4.94114445047234,5.90255287379587,8.67408438383059],[-1.83914302954949,-2.4283118956249,-3.54896521725594],[4.21198631258491,1.59546249434014,2.47821858417985],[-0.510189233810069,-8.10515888077607,0.824420190006839],[-3.16630314402417,8.04671420968317,-5.93793630804775],[0.338152366760977,6.25492592021923,7.50425550041114],[2.43976619436232,-7.48744300876638,-10.8430221110206],[1.96798315952879,-4.64955388954292,-0.408974808883737],[11.7910575529079,3.38678079061901,-1.65958840935012],[-5.64482524260201,0.921415119433824,4.04713023586721],[-3.64774594221201,1.11449980022317,2.61639187236127],[-4.45053383630973,8.0916189002412,8.05654737647328],[-1.89556236552386,3.26572551079742,-2.5136705031578],[-4.8785759054391,-0.987788886505123,4.07689180383778],[-4.70663866157907,6.66301512497273,8.8754464325958],[-2.47634106213217,0.723163956141636,2.63604458199522],[1.29954659047294,-6.70070603595328,0.537043602824169],[2.24444069498362,-9.75989688321642,-0.572815466483971],[-0.879037497388039,1.45153365164658,-2.2214550317656],[-3.14405706757761,-3.83764155273937,-8.6296349423601],[-3.09406048646494,7.14055412529952,-0.46895997610001],[3.00910858068525,11.1572955305792,-1.98802140217937],[2.7331116352796,-2.77074874244349,-6.75737347582784],[3.38887529283429,6.24258354212882,6.77984752211475],[-5.39383335172919,7.34432432671232,8.93619122162715],[4.23068181713177,4.60927955944971,3.07963314329647],[3.06184383809895,0.304999533857158,-11.6399118057865],[0.963844372315831,3.44728315319966,-6.56778561028322],[2.14326637990401,-0.0630634261569325,3.66929989059924],[2.67323979801551,5.66033174910535,6.68368279720389],[-4.17203970346857,0.221909207843376,-0.726757979590699],[1.20133487511849,-9.08875671609879,1.99394311030352],[-2.46696261330619,4.73635721472263,-7.68444421758791],[-5.99479189314816,1.43748486770832,4.60376304704478],[-2.43927385936177,4.86180891761888,-7.29230248138571],[-2.22422839851556,-2.57846285358047,9.30219789625315],[-3.6628643891621,6.27841567981968,0.408721431349779],[1.57669737909824,-5.23116537253386,4.33964873830566],[-6.18772100656488,11.2599207197697,-4.36357901485384],[7.77857589723105,-2.89012605131131,-4.65771781169806],[1.64062022791399,5.91316450350752,7.05117042385853],[3.75207412918971,-2.99455452259416,-6.7288065362527],[-0.607382174066603,3.57158963710707,-2.19892784081404],[-4.33698155875487,1.00036252552588,3.24079503553884],[-4.64150281378063,-1.10181339428115,3.35829627101503],[9.1117922234303,-2.56109524526307,-3.46433305240534],[-2.50767201134318,6.49819724861152,-0.799719724483207],[1.94660990486037,-3.9866104057193,9.96058352208116],[-4.79255234441833,-0.0919311063496666,-1.84013878445131],[2.8999190366872,4.04763597735484,9.08575031290711],[-0.654602660416479,-5.73440499891552,3.37746417810186],[7.16554537928529,-1.49215070398365,-10.395204828247],[1.6988086660665,-3.76849238884249,11.4026132172315],[-0.120878974078425,9.3441167337987,-7.42917473072561],[2.36547455780853,4.51920974901706,8.32627711420684],[7.66240676002891,-2.73000619243468,-5.00997392426042],[0.23355219725105,-4.70099930112057,3.87870597981733],[3.75760976269977,-8.0613191309658,-1.12836332925523],[4.37362870346492,11.166855440256,-1.86834764961833],[-4.44746753647801,5.04567748815272,-2.24789282477375],[-1.76346308078329,-6.18272407610314,-1.85307327353571],[-2.38356157455259,-3.49110796286687,6.5505527388065],[2.54056491004612,-10.002170790505,-1.33337275294051],[2.00389706252181,6.24641832972298,-12.170213614609],[-4.99503570481409,-5.96371462728269,-2.58716816194278],[-2.49149714998387,-0.0974062787626422,-0.0141556887307667],[-4.70868354303724,-5.71425237582281,-9.64146430978083],[-5.93606862612239,8.41036394660576,7.58808635444701],[0.0674805496404516,9.06632581468699,-7.49684636827172],[0.393981345948667,2.8304045261644,-6.37752075837688],[-5.60501876208129,2.7759267203837,-5.56348602818728],[-1.58093143297319,-2.52305121193163,-3.30958184356516],[-6.65541556246664,3.09853954227863,-5.38357535053155],[-1.87824585205409,6.47145083897416,-1.25558491456442],[1.70892060434164,-5.11425673757926,-1.65580137732108],[4.51156371897739,3.05253087043216,3.48313007794988],[-5.43252838393297,1.5528305286695,3.29703842719999],[-5.83417101761916,-2.80245639060394,-4.59364410124052],[-4.9390864239223,1.49804631196144,3.33559484153259],[-6.21206177801787,7.59862315544684,8.67628694202318],[1.20424146009484,-5.57877916778787,10.7072586523749],[-4.42327062740077,-6.83252789349838,-1.97808525666266],[-6.45957579423254,-6.17421219619405,-0.945940626145446],[-3.7241732314418,0.143622651963812,4.06692927869747],[1.70278509196549,-6.78323949203279,2.74503906210967],[6.88148040362911,3.99201787303993,-0.0469182944326084],[-1.37748173526093,3.20505095470692,-2.58287267966018],[-3.91366040625178,4.47525304880037,-0.232280974235593],[-4.24414261498065,0.979400342798358,5.56854547257608],[3.28055035926335,3.3682822426733,1.30763177878937],[-3.54489092862933,4.92275326148285,-2.43302674078345],[1.21903563321017,-7.9818527928166,2.4463529109152],[0.651844497502786,-9.22574432969488,2.10961089647045],[-6.27333948895425,10.722256717826,-4.27686948732234],[-1.29178332396418,1.82176221701243,2.12785032647506],[-3.62667726502819,-3.17053412384432,-7.21287401629309],[-0.391360470327441,0.844407441608609,-7.4868554845367],[4.13799045971906,-6.43857358259893,-1.85555544352054],[2.20898564116354,-3.44238580366482,11.4952362082009],[0.979748944632238,0.559545423891726,-0.745267319127522],[-1.98780938937788,6.9585810226766,-0.804804328650672],[1.68827166958385,-5.63261895637505,4.49013608380053],[-8.72038712577007,-5.73595044174299,0.759298113740487],[-5.62300180067742,-3.54167481016448,-4.87041689658513],[-5.2393449836488,-5.65545269095193,-2.19918491701822],[3.13918129454568,6.60817398147921,8.60321854846583],[1.25417751757811,12.3910206659663,-2.2006460636102],[10.1484525267439,-1.49683574184134,1.12732670890864],[2.48679131150117,-9.71032758094915,-1.59562057962184],[-4.30096429606914,1.06371104443107,4.79209959301078],[-4.69092390020048,5.68325271771281,-0.0842649792917326],[1.24463801637159,-4.66467377862062,2.59014094999913],[-3.76245193867798,-1.951799694957,-1.04892449429484],[-5.97467886937884,6.81425518080919,9.19896861916231],[4.08942745645543,4.88143525073323,8.41403306325287],[4.47898613988343,5.84590882841709,8.17979617254726],[-4.60625193533319,2.8675116363889,-5.28724764781165],[-3.65324596904499,-5.33454104124866,7.53157985639225],[2.65320601944078,-8.82123258488301,-1.15804877168597],[-6.21997510855715,-4.47447381998755,-3.2679288937025],[-2.14764504868476,-2.63308005926875,-3.39217123345471],[-2.50301878327111,0.26314383264797,-1.36207661363705],[3.45601274352324,-8.52511333062271,-1.75418700627343],[2.54254082322563,-3.43828905943026,-11.0931964955331],[1.87432596339929,-9.74154304923258,-0.305862162077063],[-3.25755235751836,5.23867812050339,-2.03270823333182],[-3.769428467112,0.918537042220264,3.86669278311962],[1.8733953231791,-4.79018058152663,4.61160448270109],[-8.55810741738616,-6.26892373068838,1.36129239398609],[1.96371086888165,2.35976918559878,0.691460650684656],[0.726168678976345,-7.58878142035361,2.15212989502041],[0.143095868342178,0.481394309329893,2.94158067331493],[3.9750819022518,5.50713764086935,2.15466307120013],[1.14020649289322,3.65520025065077,-6.147564605145],[1.17106536261751,-7.57827912069849,3.45683246975625],[2.12055204410191,5.848901739324,7.04306017115605],[-4.21900690017439,-6.44272511068694,-1.94128766623158],[2.51177766571529,6.69314048707365,-11.7827570914157],[9.84554444414169,4.21302905580239,-1.9912878510655],[10.8564864826656,-0.487261758340679,0.514671860432589],[5.04893026921702,1.82068611112801,4.77691096009621],[2.87340336884816,-5.65013081885445,-5.94723595569212],[3.74983992054477,5.88973609752005,7.14086809254992],[0.334435704783332,-8.39474153396391,0.58928924325953],[-2.4399323534047,-0.442442471495093,-5.33133638143207],[-1.56317941753225,-6.93869711392591,-1.1641340314969],[-2.52120920500237,6.42918586251128,-0.933665142399751],[-4.37122835427363,-5.87262544115078,-9.31161720440011],[1.24760530128245,-8.74906352307045,2.93850641424569],[1.81006973009024,-8.96009209586346,1.53856089443672],[-4.44472386756645,-0.0790380675769606,-0.543476288450662],[2.94015340658058,-9.41153540980684,0.279851112293175],[2.38554494750215,-2.44924959504468,-7.65023876302388],[3.17456543797422,11.5433156682052,-1.70790829625483],[-3.69216389777851,2.35635756576398,4.96365721341305],[0.382986955540643,-5.9573514809147,4.40125313360941],[-4.18200355617946,5.66307950479837,8.42216994351352],[9.46438183092802,-4.08984390490706,-5.97011161690031],[1.34789270852304,11.6115625743097,-2.14064124090709],[-3.71508155490639,-3.71976775063635,-8.30854759985535],[4.20390049681345,1.67360824348075,-9.12273087449102],[1.06062688691361,-4.66025139555105,3.74515850002708],[-2.23688527459242,-3.80322159217043,-9.68065543509425],[3.31800170243124,12.1881292541891,-1.53700751770303],[-4.73767094189221,6.53083945159582,8.62445919455618],[3.77395751511673,11.9481470451171,-1.49328331019861],[-4.30514026769908,6.92022607905389,-5.16470594260153],[-1.25065806967604,-2.36353512478781,-3.47635485264558],[1.91634539543819,-4.80636283380876,3.30913943062226],[-4.82646590743421,1.94853896339724,3.68078795026098],[2.3252342902371,-10.1525603555924,-1.26984917629869],[1.69135010692546,6.00402366668869,8.48152164001752],[0.987180019818092,-6.10390308913226,1.54383162687942],[-4.1206513962333,7.87042746063103,9.11072932908101],[0.815042898249246,-3.73808080586796,9.93590315397389],[-4.70745815448856,7.34255708627921,7.87138239056477],[-0.157672193632249,-0.0944628414988304,-1.96541237738889],[-4.9669202387234,-3.19876404375677,-8.84983001637812],[-0.460390805976118,-3.32795168409022,-1.54711514181],[0.118074136570114,-5.74767202141355,1.80185318238392],[-0.796645715778276,-3.86325996650755,-1.58163516075079],[2.89375321537542,-3.31442425392621,11.355336105856],[4.04173020359611,10.6926630458141,-1.45211877808663],[-6.83345018956764,1.75744126603234,-9.13305080886741],[-6.01661076142705,7.65764703798159,7.94399995369009],[-4.59072460508167,8.25882195817866,-4.94776152426126],[1.28729389224586,2.11489348897621,-2.22290188345042],[1.84115395354995,5.1993631882869,8.33231150642501],[-0.608326673064575,4.31655757092794,-0.100725133594275],[-3.48850474854531,6.09680335281566,-0.807168728355973],[2.94191491450847,-9.00365326578768,-1.20419522335735],[-3.55088756058737,1.11358233374101,2.32696398809465],[-4.82180291830331,1.51532811284602,2.50437206344953],[-2.14372227218486,-1.43330478379607,-4.40324759007938],[-6.43524797956484,2.42787350384636,-4.9770310531076],[9.39414955918294,7.09638295044974,-0.0996432407773329],[-0.776457120590918,6.15783369331657,-8.44891321211598],[-4.59694825582319,-0.407516775696565,0.652252620703042],[1.98747779386679,-6.8461143938948,3.4621084122487],[-8.32574913549541,-5.59734295531758,0.702412741001369],[-5.06525148746426,-5.00938169918608,-1.60618015170532],[3.19744480523612,5.76969959897812,6.91928382582361],[3.52288480173359,4.41541931974385,8.06741407348932],[-3.67209120931237,7.56620388938132,8.35821893586672],[-9.49632036759331,0.661135334812573,-6.32246907368381],[-3.51161350470635,0.846917435568394,-1.50918956656115],[-2.43408416215974,6.56797628230188,-0.798535561331847],[1.93003947348378,-3.22670100444526,-7.5255744665993],[-5.59394859809495,-3.27892061550701,-5.30535298375998],[7.66768934272606,-2.01200717124339,-10.7061625294297],[2.16717833622934,-9.12098409647396,2.07880792134106],[-3.81749132594207,-4.76584241197899,-11.1231906379408],[-0.479938916406552,-2.96863559605263,9.98316822068837],[4.75282747612374,-3.02117146305482,-4.16175638675629],[3.09237474203776,5.28220071279074,7.57925479665867],[1.80628962696318,-5.27600293367642,-0.173354759700829],[8.66066149062365,2.67259325578482,-1.75646438249219],[4.80832025282904,-2.20650230037854,-6.83613630527442],[-8.24747800691609,-5.91145337280233,0.504722594837033],[2.65164554752227,-2.94101967848692,-7.35574107814961],[-2.63463947191747,11.0707884344719,3.17471568250116],[2.40199180509672,6.32480687062991,-12.1091282511018],[2.61031066492981,-1.21669493539558,-7.52413865791328],[2.59658230161857,-9.40589222244839,1.16239415975246],[2.31880232124577,-7.8016437572668,-1.60055073819204],[-0.176396735726666,0.322872395261398,4.15207028020512],[1.25570261577153,3.87526284236631,-5.86774519956716],[4.3894298366117,-4.94393339564566,-2.08221307376069],[2.9544525274283,-9.2176689745731,-0.184735582010701],[-6.02928611742425,7.53767542497453,7.87293597945053],[-3.22262950860932,6.29541237518546,-1.81219611333327],[1.53372292972564,1.37868350164956,-9.3807573448428],[-0.76046357097214,-3.05020287531099,-1.75418719989144],[7.21885243449027,-1.55831897143588,-10.6834587598232],[-5.21786677910998,3.07053133591349,-6.52871799599469],[-3.126969750305,-2.97947204622095,-1.0977764198744],[-5.90597403262016,-0.773498549670635,-1.16703310411487],[1.98610772687158,0.830257819332064,-6.97018341703776],[2.28115918367619,-4.26700998908437,12.1840314732969],[1.42463037968002,-3.81199109759917,10.9238393865538],[-4.36196008374349,5.03589983452848,-0.648842694063909],[0.883087620216508,-3.64429691588024,-5.35640282339132],[-7.31675859032418,-5.63809151852559,7.06037129935681],[2.19365808781735,6.9154568575232,8.41092792907241],[-5.7647669067632,-3.58350916658217,-4.63041173673377],[3.99822998652621,-1.09225298010525,-6.56477628436043],[9.62332689967814,3.71987333165528,-1.66553707489924],[8.45021352626493,-4.56411505249114,-2.13984931488893],[1.30530395714773,6.14224474671092,8.0923782173475],[2.05572039781855,5.32356550808837,9.39160145300818],[0.300404771438703,4.1598248968467,-3.39735373853566],[-3.95485761947759,7.01805185607999,9.27327797084181],[1.29503926907591,-5.11158053908029,-2.07944428262435],[-1.63027223971644,5.06245140034677,-3.10199606363225],[-1.52340083759846,7.25317962676695,-7.28765431573427],[-3.64892358932575,8.26140050214896,-5.73235357425015],[1.12955115461965,-3.3573598499535,-11.7909354187713],[0.349153058102969,-6.534528415844,-5.84527991138121],[-1.17483673598294,0.902686461191617,3.68405137600939],[0.575789693922367,-7.33393887609918,3.03855063634803],[-1.7697119074674,-0.752223605913206,2.68629240016057],[2.11832874616266,5.57111021431067,6.73505700269392],[3.0482579253937,-5.78826335097211,-4.78316321727749],[-3.00822217379912,4.46756229303212,-7.74206122712835],[4.44709347773784,5.45670898923504,3.08795509516252],[-3.12075753554796,-3.41432792372122,-3.26279235363929],[4.85996778130739,-3.07233865131664,-4.00610112880216],[3.73900904299076,5.8521275949589,7.02533841002051],[-4.72365610895824,-0.449024112553982,-0.827089011919169],[0.58710385487577,1.50965437918187,-3.07546553865096],[1.06273476009028,-4.71488443106086,2.8269536722062],[-2.61102302075806,4.89470055802855,-7.69212414890581],[-5.85689126818593,3.43984121946448,-5.97814260488572],[4.17268210010473,6.1691741622489,8.20833163689061],[3.12458956550206,-9.31313895760905,0.991746699859083],[3.8587074984892,5.95155476551773,7.76288456476472],[-2.73650667364232,4.66833569609066,-6.95704247804803],[2.32633276893101,-3.98892124105369,10.8351760224935],[-0.18674840392168,-7.34453060403313,-6.00873210510871],[9.23834813258396,3.5475800616955,-0.65555265547597],[6.98051299943841,-1.84178086904996,-9.61799723892989],[-6.39915690893956,8.29821784201497,-4.26772083917259],[-3.31912520609574,-5.77679202527409,-1.54558391800538],[-7.32521409275793,-5.99911905924083,1.41701531345401],[0.885457814348877,-8.4262999784156,0.904610080134468],[0.673848565981034,-2.56326808390597,13.2396932836738],[3.78756685910014,10.6265043651749,-1.69700659452982],[-0.681999019091844,-6.0184844458475,1.72189199166141],[0.910937529333272,-7.532333980162,1.24244234247702],[-4.72338320453562,4.07867302130288,-6.4230256791044],[8.56564511425586,1.73974527161075,-1.98519748945185],[-4.1735492399009,7.96709096901947,-6.19350616389534],[9.32460925023885,1.22941234059964,-1.93255638018998],[3.88761102649987,-0.629107689359939,-2.49545733440884],[1.24560184501176,-8.05400426795673,-10.3727191762478],[1.93402094704479,-3.59058010234082,12.1975569401863],[-1.99519848625909,-0.867004030371593,0.877908798651993],[1.30437725689401,1.95014011047284,-1.4309298454028],[1.20590625773483,-9.0284279516942,1.80844960636519],[4.00156779713576,5.97408811564424,0.186328211629673],[-3.77310127606184,5.74133164298468,-1.83261762754133],[3.46613438011904,-5.46994615860679,-5.56291987754743],[-3.8431155111008,1.58954041054937,-6.39909804907235],[-7.12406469371448,-0.598547663733432,-4.5869840075546],[-2.74074092940838,5.19572672735343,-7.28929507261327],[1.44505683165108,-2.42443056852364,-8.00083741740068],[0.469847831380267,-4.98355884618486,4.1626660792716],[8.53177240776941,3.70447596864279,-2.35473808507699],[0.864986736511352,-3.43838309601879,-11.9818272208592],[-2.38099398186494,6.54714884968364,-1.15744280811788],[-0.925723918975537,0.317125422286038,4.11798030897609],[-8.8465092560657,-1.47702101111273,-3.75019451527915],[2.16319767662957,3.88597920200706,-5.62341090130447],[-4.26912261876853,2.24714754602605,5.45771209280517],[1.63324994292691,-6.92432317545025,-0.145184484228464],[8.72628659237086,-3.9334636205695,-2.51966889405857],[-1.22290509977978,9.32263065613866,2.45448891938473],[1.26864960148428,-4.20318057608574,12.2085076244037],[3.15912570139389,5.12699390196095,8.92753371975672],[1.59931484055231,3.68722156361433,-3.82952500654705],[4.00905535693893,-8.01222339915043,-0.700426622112812],[-2.72365022467595,0.410016849070323,0.337804638588972],[9.45073511708805,2.30615919325685,0.145708443035781],[10.6821639536731,0.327993533744175,-0.709031794463744],[3.31282936503403,12.5312868599405,-2.10569640349212],[3.39733968752543,11.4871591335669,-3.11201438339381],[-6.42557597854714,9.0350293173925,-4.03573684082428],[0.207066277613278,-7.05831326032656,2.05629746900908],[0.796702060390317,7.36329218102762,-6.32485058380232],[2.48339394716586,6.08319134002101,8.45891808428438],[2.40120593933754,6.64994772162745,6.68935512046296],[-5.48227087803603,7.79764518353494,8.63844268364418],[8.98701812478674,2.56485838528094,-1.30319755700728],[0.747049451676541,-5.10573620540497,4.66755712400093],[3.48113758937251,4.23522719755086,8.87489618030487],[1.86823347937655,-9.29045411572141,0.801486732175419],[-5.14310624377295,-6.76521397391712,-2.17094998413285],[10.028566318241,2.78471031492194,-3.00189986950827],[-3.52195563537761,0.273483155379322,5.00981099512084],[-0.115537430526184,-2.46347272634381,-4.8357272079494],[-0.869463846756963,1.02785879135263,-2.49241007237977],[-3.13947478403923,6.8697629829312,-0.0413269421200266],[-3.09637510312678,-3.39742247729732,-8.99114820279981],[-4.63140361940098,-5.87267477051873,-9.73447632112031],[3.58451750975932,-3.56616980471839,11.8504649858709],[9.44164452670824,2.90385917836668,-3.05010053175634],[3.24382015585162,10.5419981971387,-2.29794976478497],[2.03297696970859,-4.4333049397435,-0.315206257887542],[9.54132657599074,-4.58072703847678,-5.89061989329617],[0.00250853811206186,-6.9391327309336,-6.29367279837773],[12.6564058236472,3.41081411984544,-0.895548828400501],[-3.63379859781983,-3.78183968690164,-3.32663879214104],[-4.69127203018966,-2.76660439335307,-3.25169610398757],[1.96018992609685,5.90277283355951,6.7380406885939],[1.53700832466766,-8.0318931560105,-10.5739003630176],[1.13558596770011,-4.29148204309089,-2.39358361135972],[-4.55565686142128,-0.578777269918799,4.3422120575863],[4.29965858939748,5.6552002356363,8.12574827558356],[1.78890011585392,6.24665126044792,7.75883274989295],[0.197881398212048,-7.81222175123966,1.62887889314636],[-6.49043380084548,2.54105328993249,-6.29095368488745],[2.29465822143643,0.267485041086385,3.36281547773614],[-2.77286934306588,-5.04598925983821,-7.44925056336575],[-0.644989887277918,6.50932561019644,8.96119841180708],[1.19921933003929,-2.47319245887165,12.7424153562531],[8.39574085484623,6.10125651946937,2.71448604191773],[4.18061466806097,6.27611421948995,7.72125994113222],[12.3986451635343,4.91816848193067,-0.875378414860555],[0.488126585541422,-9.30426056785255,1.10305784615262],[-4.91832505987264,6.30140344294922,8.72511922724974],[9.7095377204615,2.76691523594662,-1.87228217087737],[-9.05165713337832,-0.504249982891428,-5.72961219379413],[8.87304561595445,3.09316139632202,-2.95596573288433],[-0.823917942809077,-7.57230151473613,-6.23628267321641],[-5.58308574483492,-0.395691998258444,-1.54140209921854],[-5.4913665812401,-6.22151644197195,7.43418521440638],[11.0853007742378,1.64534206364223,-1.63534348883016],[-1.0917377641656,0.70674537604552,3.11178347100588],[-0.0457585576881315,1.06995385394049,-7.90912445241996],[-1.22434876249265,1.00762475584322,-1.95290683151178],[-5.69105170525198,-3.64591921547859,-4.74288145751561],[2.98489057712706,5.97793061434168,7.96582050811453],[-0.592042896958029,1.00600144540203,-7.70140969658867],[8.68229228995232,1.95785975120906,-1.80618802181226],[-1.52845182248285,-8.19245503123904,-5.75740735637751],[2.52285110378613,10.927789506009,-1.9159438884478],[3.39329949282688,-2.49818389738512,-4.43426633291211],[1.61958850868207,-9.45738694587791,2.04805869038941],[-3.63169357220837,3.68032125176369,-6.95550100533992],[2.11464371155313,-10.5858955724317,0.0463736281207396],[-4.34314923717155,1.58563718223223,4.58598492629479],[-4.87864569514803,-6.01665538843652,-2.80875415340455],[1.43459056997832,1.81867600639369,-9.26865322470056],[-0.233358757680152,4.06151374701205,-3.07511358020341],[-2.95728388591551,-4.14120272288419,-1.47670840484656],[-2.05073387896669,4.68318685469143,-6.40708058775933],[3.31401722745731,-5.90148134809104,-4.98833975235208],[-0.406928741758301,-7.15260889175787,0.951057084272434],[-5.30355073303732,-0.838409004084095,-0.988904948935439],[-4.88381275494199,-4.80498347931098,6.99590606795598],[-1.654638205202,7.20030089572065,-7.33355846413847],[3.06491523532028,10.3201123767951,-1.69938943206653],[2.69509364910338,5.89224100859099,-12.5038916589304],[-2.39768554800176,4.55782598485535,-1.59759123405217],[1.39919328350589,6.40527221290036,7.30832642016128],[8.67820814182692,7.15330760676551,1.32970524790556],[-1.81456750726121,3.27851700151142,-2.26735986238193],[2.02481360731619,-3.13153524650027,-7.43366359608925],[-4.21560047491727,-0.682619782733019,2.97857481569101],[-1.74498865777044,4.95213814220215,-3.14239065910556],[-6.30815713223837,-3.13866893331703,-5.01533360995272],[1.69016932913386,-5.53087036365258,-2.12239784331765],[2.60432054152768,5.58686546970422,9.3829853840392],[-6.85173784531478,-5.33188718718889,7.66854354923645],[0.825765353721387,-2.28109449219392,12.7416412867583],[0.277507093315583,-5.17720384595817,3.40277370230419],[-6.22244200445764,3.11618969825123,-6.27474667561237],[4.09998535366378,2.52328242762596,1.66408316309103],[11.9882387875187,0.957084449763972,-0.972569186653259],[3.56758031336384,11.751558687955,-1.49084245546241],[0.911834926367833,-8.99989230283341,-0.355118997905543],[2.82167183330487,-3.42493225791138,11.3482229232352],[2.39510740606532,5.53227375606672,7.44175161041932],[-3.04503318908639,0.881116581915565,3.55871568530517],[2.61387215986871,-6.87324825606485,4.05075156936332],[-4.13097019581138,5.29741690409424,-0.265174414166275],[1.91187983971922,-2.02310478275913,-7.951388534676],[0.188041484941033,-4.14371485353224,3.33146099650614],[3.40436987286079,-5.1581958829085,-5.15979699559923],[4.85735882922192,1.99997219320735,4.66899890934987],[-5.06740909413489,3.16069835061299,-6.75850282208448],[-3.23553415957891,-3.74012439728474,-8.31254791306902],[3.44601175908525,0.637426696046853,-8.78303998964688],[4.00527068706674,5.39282367603805,9.20961443136819],[1.46387658365875,-6.93970353582742,3.83266481016302],[-3.15884418217495,4.76297533728708,-0.00529480601469762],[9.27354613764338,-3.60998766072255,-5.30216969545295],[1.2371852080303,-3.38043817474371,-2.68941185012404],[3.52010347140351,-5.28330247735641,-4.94586213619949],[3.38159726906603,3.35827957347724,1.34001710086058],[3.69395484568378,5.68503992029957,8.15766535017543],[-2.19453637399732,-4.92240085627687,-0.60143190104161],[0.0630525555976821,0.763158071233066,-2.09114510469156],[0.866182529323684,-3.01978136810467,-11.7252202234362],[3.17130533301034,-3.96019631390716,11.2849435321345],[-4.9609563652274,7.27825373237928,9.38563606574993],[2.08458118654549,3.71809409384173,-6.64654004102371],[-3.21616933609408,5.29325209399753,-2.40103052391141],[-7.58504189544729,-0.438161521582985,-4.47599194234248],[2.45039832248348,11.6832851559984,-2.43532681539071],[3.75683915557034,-7.81060250606579,-1.00309142384095],[-2.92468857411959,-0.8227358355104,3.5209498548331],[-5.41213565708892,3.53648161544454,-6.50852517862708],[-4.27974025560112,6.51113978731436,8.47506539016086],[-2.08739679723213,-1.99588193326388,-3.88304194524391],[3.99970939622411,-8.6695140919392,-0.393878505872063],[10.4273282524038,2.36121206482215,-2.46520624549895],[4.98056882962294,-2.94110061675102,-3.93749151772849],[-6.01029304302684,8.28475763338439,7.74090636717639],[2.45232524414836,6.61790056677655,7.65779716599331],[1.45735509200094,6.50094246963513,-12.023447319048],[-5.02590528408996,-1.30944141323868,4.2635160392211],[2.32750338710292,6.21122993702749,7.85080966768959],[4.00247702087357,10.3180592301802,-1.45351464465232],[4.13238601239086,4.0980317412347,1.11440832665879],[4.44888368983008,-2.45938694492276,-6.7847062944447],[-1.04167457598608,-5.98887953732209,0.811460025573306],[2.44317246907391,6.05602426571931,7.18449971450772],[-4.59383580960793,-0.606270316653956,0.804058166726626],[-6.33358416112767,-3.35066446381907,-1.55858301903759],[8.52424236662577,3.49181475964679,-2.3410408806104],[-5.30149915760883,1.20511358970586,2.74809650067286],[2.34741559333837,10.9658499535175,-3.02380568619962],[3.58518087061855,-4.79996622136797,-1.44414749047607],[0.233300588729436,3.75007762143739,-3.46528117835972],[9.25488351076843,2.44847154300308,-1.36439654697335],[3.99428480064454,5.7926412968351,2.0433697608166],[1.92958376370497,5.76827114304535,7.18227686195378],[-3.87448326144253,1.71835617345181,5.0759261591438],[2.2555780850649,5.49837065807423,8.93278267655097],[-3.8898717752578,4.38337931581207,0.289328866884781],[-3.26050097586298,-1.92258997698788,2.03671373940753],[2.64844832522422,-8.80042258931039,0.344920014636039],[-4.46359110064504,-6.0899154578679,-9.3584272936395],[-4.40442865186958,1.17866297463406,4.68911305152087],[1.6612958707707,-9.26460373357856,-0.266340937159516],[9.81211012996025,2.14288820308618,-2.25539345635492],[-5.13320734412501,-0.329403407321534,4.49887072335192],[0.255904341299891,-6.1063762814517,-5.75013257384112],[1.68933532238356,5.23247545255184,8.61293273234071],[0.117856727467377,1.23758075453722,-6.01592111455383],[9.38909013603672,-4.15360241436988,-5.47994544453414],[2.22629471459487,-5.3929080643165,2.20299266149817],[1.26507163764795,-7.31138510925321,3.64736981206729],[2.05124879839419,-8.4745578947816,-1.22581368178059],[0.466085358740905,0.203296409157389,-2.31613649849772],[1.36830924257476,10.5921094385177,-2.32740864153048],[-6.34969530422176,3.15576649327102,-6.35844444246602],[-3.65932282026781,0.855556829965548,4.66141225007283],[-3.15844510355808,-2.03733905976568,2.08811716580035],[-3.05206278937145,-0.615070124272749,3.08407923498034],[-0.152514828450903,-2.3741666927868,11.3970814759239],[-2.42600576482566,-5.12988380873009,-8.38380366595293],[2.21776743837697,-5.35299914802308,1.24247072412332],[-4.7465823628542,0.969209694840253,3.78821569155546],[-3.78527931190674,4.83942228581069,-2.57849061028211],[-3.65234674352943,6.60474855609664,8.01629455582043],[2.22403577493349,2.96061782599152,0.372970980108365],[-1.19091065484657,1.15625343843104,-1.59960022534509],[2.94895684626634,5.94279334392964,8.63848149231008],[0.646709850780234,-2.91742292321081,11.7890901219511],[-2.6599499087854,-0.390370569310277,1.57678730804635],[0.798300632537485,6.15474152438737,7.20357935750503],[1.77338618830241,-8.2592584654576,0.037331872409907],[-5.69265250997005,-0.485789743513858,-1.17137394878174],[2.91438396403368,2.67478044007309,2.81447036405156],[8.71655275321592,3.84709174724387,-3.13686772310979],[-5.25598923588798,-5.51865748128107,-1.78621876543958],[-0.144573100920247,-7.70196397646051,1.28285046516036],[-5.58499934363386,8.30126359324865,-4.28480233825347],[1.31192763629496,-8.67350904564802,2.41582521688991],[-3.14345480006173,5.35852381902535,-2.25066185144913],[9.68990516788585,3.83146408510864,-2.28487638415822],[1.54680662248612,-3.73748920452131,12.3913450967187],[4.04090198840213,11.1173075437024,-2.2743114553741],[1.2279759595816,-5.28382540203123,0.280123715477264],[2.07753846192587,5.60140072156171,7.5863720126365],[-0.109293428415918,0.386995526616202,3.31901348779512],[3.1368932058479,-9.78913859077053,0.250092353995845],[-4.10659922294933,-6.49188666866496,-2.49839549326516],[8.09497522685691,1.83019817565034,-0.838274217349123],[-4.71896675529744,-5.38806210087839,-1.61200408869243],[-1.98773264530758,-4.79911640114493,-0.442078437794639],[8.07558442722204,3.38175510040815,-2.17947810172032],[10.7254829140146,3.15194995109573,-1.85927099783647],[0.658064927002446,-0.516184731276095,-12.7991952848137],[1.01269263798805,3.98627619935344,-6.32691766842194],[2.76681215133276,-10.1048058300513,-0.742287266600699],[-1.41112823832601,-3.48596051684567,-1.13543862297347],[0.619772194308706,0.746887368249554,3.34011489782717],[4.49710755654641,-3.14897760608394,-4.11630099079548],[3.58197417350406,5.01740594601821,8.71715050671882],[1.02513463158957,-5.65739634756171,10.9311578320423],[4.87796298375346,-2.3839837834665,-7.01936644187761],[-2.88092429096557,0.480039806949687,2.1508348852385],[1.66280682401889,-7.7775077120032,2.07259065292333],[2.88371193480268,-3.39359459528521,9.41598714876616],[-4.61845119058156,5.35710290795707,-0.410186895788648],[8.26551884049079,6.26208856586108,2.20837020893576],[-1.76897948488184,-6.24004990872129,-1.88561334898837],[-4.22745307337778,5.19614379997205,-0.651224335558245],[7.59564197778341,-2.23165681761081,-10.449815535384],[1.65035493485611,-5.56409303202159,10.8882609428455],[-4.60361167620263,1.00000714957798,4.49388513557216],[-2.35027200244113,6.58714171614263,-0.872647121890398],[1.06577256574682,11.4398812326722,-1.57709494328268],[-2.27151182088832,-3.76436868518907,0.150858379308725],[-0.608315765132325,-3.0348822223421,1.86988294780515],[-2.52548768946933,7.17292472961633,-0.946024716276018],[2.71813342271629,3.43693504330851,0.9404309201464],[-2.82713274800245,-3.58801017082918,-8.24591060346197],[-7.21351775589477,-5.94274417905831,6.17600481555557],[1.73776972115699,6.20873711624585,6.44218842633378],[3.44373924004665,9.88379262281888,-1.66995461715583],[-3.69356154586647,0.9433354195176,3.68613712700427],[0.154259597145723,-8.18992905931417,1.50719196679152],[-4.24065153213301,0.627265328792732,3.84186919993999],[-5.56057997539727,-3.1746410392036,-5.33088466194852],[4.17242693557298,1.18708554028542,-9.44560229430111],[-2.83730139509937,5.34537845436598,-2.67062244491373],[-3.94269449091981,2.56272039203402,5.35757704438962],[-5.00718311674754,-6.6503275967449,-10.0095071687573],[3.47922878315238,11.1757899607365,-1.63018944347162],[9.40084146671025,3.76752766156027,-2.36668371742207],[-2.41528272031193,0.989137513546207,3.72242548485834],[-6.4097305922467,2.86239928260766,-5.32912448377172],[-6.45751257886289,8.37098713804694,-4.90567056319172],[0.943402015237246,-9.65560579260139,1.49317831842285],[5.18238468551813,1.27694588804453,5.74873986641379],[1.59986228919399,-9.27883796337421,2.54565385340552],[-3.90271985232573,5.93155268372734,0.258207807913266],[-7.49093056876906,-5.3199736513251,7.02504108134158],[-4.65354622272259,-0.0819087993186807,-1.38188963980078],[0.00126155159070995,0.0379685227875955,-1.85804083246241],[-2.88802275358033,-3.27283108264119,-0.567339652682604],[1.36605064202699,-4.63714479547742,10.4292473194357],[2.70950410861139,10.7857067388732,-1.5111486294063],[2.06469599905789,5.29540954212391,8.40650023908825],[1.47811075348455,-5.36682415103078,3.7602110395669],[2.39409996714064,4.78956186382453,9.27114867571644],[8.76471009257886,3.80431295166679,-2.16855523472912],[2.08015805218629,-4.7684713816385,10.675497389156],[1.00127958005634,0.188629194088103,3.07520513539942],[-4.92346165842383,-5.87952833774452,-10.216029347891],[0.65916216334537,-4.26564679374304,3.71910722075551],[-3.71072662135325,-5.3915153377468,7.55993520760876],[-4.45550348252855,-6.48589692375768,7.17205036519837],[1.68281016945276,-0.437065037560481,-9.81407308376599],[-7.06419966253538,2.64418180293064,-4.63922503921988],[2.23394380213137,1.59924869889918,-9.3286923990155],[2.04195853960163,-4.3871843528366,12.5380213756434],[-3.8852104294737,-2.06509292687184,-1.27912464276119],[2.7533191821678,-5.98085137074397,-0.975061398068362],[1.43517407399752,-6.14901689777263,2.81864985102566],[0.736512579838345,3.84459707274047,-6.3205295419151],[1.10958777204048,-9.33551201489941,2.46474818335592],[1.96752895470311,0.680155316863793,-7.11705742887777],[-4.89655433979343,0.254635070087018,2.58389827642778],[-4.82375536017862,-6.58483970315607,-2.18864527436333],[-10.0165281125114,0.486727231113321,-5.53930286045087],[8.17120457383388,6.25897472242347,1.64302687329698],[2.26762997980235,-10.0431586884874,-1.24865816654104],[9.42055538848156,3.38236836147453,-2.53464614518877],[1.74281611149491,-6.22329701609525,-10.4183272919865],[3.32882939807735,-2.53781498571085,-6.7562767945315],[-2.01308017026259,-0.0503114279802852,-5.04262526478439],[1.862311744059,-5.31317910593214,3.60463291605937],[2.26942411559605,-9.37347085785825,-1.51310902459817],[1.76974851034194,-3.93700799143753,-1.62121654843787],[2.54981948187865,-8.66266954324281,-0.369302692089861],[2.44592325906697,6.53024003940359,6.83790598996163],[7.43537410734289,-1.58346408548616,-10.6878101596136],[2.44456539850371,-9.66068054488537,-0.39997643386217],[1.69529634241588,-6.65871448226986,0.953095806570863],[-6.82415386899059,3.02521193213988,-4.82827973996044],[-6.66279923595246,3.04629932049053,-4.36567110320722],[-4.22395727373548,4.8513724978854,0.271905750167998],[2.41562940134884,6.03557332354063,8.22536868840762],[2.79585521324663,1.45814465110141,-10.2251606743859],[-0.287522741749984,-5.39458257883128,1.92397563330407],[-2.40384118888276,0.183330029999333,-1.04533818082843],[2.61978699547868,4.40862192980338,8.59741353205314],[-3.18574323765517,11.6923270097427,3.20991637065033],[2.10830911917439,-6.99272523441029,2.03998917346068],[-3.9773222868615,0.63806720729345,3.35863831580252],[-5.80592565257079,-3.02362377824161,-5.12565753434236],[-5.15171019218184,-6.47531396648687,-2.58690050003621],[1.5632627803901,11.1021452109407,-2.89954538245657],[-4.55471330863777,-6.9317406925415,-2.21481632798813],[0.931946740802682,-3.57806936702325,-5.37015905975504],[-5.4485692252664,3.24486892906507,-6.09290739285023],[-2.85281891481172,-2.49942705535954,-3.36208656905356],[-0.242270762298067,4.74327024489873,-1.95830524067935],[2.32597080840271,-10.0003547499252,0.574344564541441],[0.721999849507485,-9.53519775571243,0.906675770056992],[1.57164792004397,-5.32451852726425,4.25464007579036],[1.55022719247561,-6.60965897427633,2.63421873298334],[-0.135358179336428,-3.20816235028005,-1.32370953075782],[-4.88061109268082,-0.727417057147385,3.63151450499755],[1.00055530104055,-2.5390184430856,-7.89169807634534],[3.62278490835972,10.2614019959601,-1.36112303805772],[2.21856450637007,5.99263985191442,6.98337776091602],[-6.25892012243021,8.57032681815626,8.29582952512442],[-2.30467305416816,-0.602058822442989,-3.84565599534789],[-0.551027738148086,1.20660674763168,-2.1874741378445],[-1.8654875654546,5.62282868496858,-2.79999138608568],[1.27693145823046,-5.3675802075687,11.2083176965961],[-0.169784611198585,-8.44194334713347,1.11618553206476],[4.12438684650094,4.55964864941788,8.015702502918],[-0.13584479432859,-5.27359559968044,2.71624820379341],[-1.47310337944728,5.34704191792223,-0.981868670885918],[1.49934942165072,-3.15989596460787,12.3495894046867],[-5.25563397973375,-6.45584046880981,-2.7147755613861],[7.02483385822378,-2.59461802932542,-4.53690221654229],[-2.12287486287542,-3.02212344133597,-0.361444663716054],[1.61639255116422,-4.87395600565342,0.202316688287156],[3.17481571213351,-10.1733050845717,0.038729577893544],[8.56405809730861,3.19387931959885,-2.55641869392034],[-0.0191153171637842,1.04474847234316,-5.37200370375499],[-7.05706029245816,-0.595737999904615,-4.54219222812484],[2.25791143763669,0.60047897487348,3.49991110398277],[-1.74600350813613,10.6666595427985,3.16704759596483],[-7.33947762187158,-5.90512609130911,6.39720971815507],[3.49415321015203,4.17836678531684,7.91448624782327],[2.61412459155461,6.23836620990299,-11.0707821395957],[4.4007949932505,5.74216106173806,2.88963441604837],[-3.67498069653632,1.05712410875503,2.61889664262258],[1.15039441848707,5.64548491765383,7.37382368206663],[1.77763065262482,-7.09873519237658,-1.40867356470908],[-1.60050201790158,-1.24394874160573,0.600180116306491],[6.11719430138092,2.40378174102592,2.47625114506609],[-8.89267998741152,-0.420776118450497,-5.6950417078402],[-3.9663352294151,3.408312830899,5.72542540745612],[-7.12026527781186,2.66098955132878,-4.88006242175542],[0.616014034070439,0.209740962969535,2.842065464069],[10.6072752121863,3.27523871694146,-2.09458284684302],[1.51078837300005,-4.69292054436714,-0.95213049964927],[0.422490708466545,-3.830241241878,11.820764298217],[9.10851201063119,4.29452772216379,-1.43688447160982],[1.69883410160806,-4.31968402325919,10.221086758268],[3.73968996298917,10.250098771665,-2.26826971547675],[11.868384947497,1.70671761403476,-0.851288478180315],[-6.35946377923347,-0.879374950343037,-4.23766246702245],[3.52240911900272,2.99972962186408,8.43832889815486],[-4.55974268470516,-0.480867436425517,-1.85488618729855],[1.89688042994106,-6.31071508080704,3.12830168930405],[-4.7361902638935,-0.697359009539422,4.2871880295746],[-5.16236945470884,9.57304835844101,-4.02022860016893],[1.6174395469285,-9.23630629424484,3.02104903614483],[10.4862508664101,5.98878641847616,-1.21075049044487],[3.96910363733723,4.37914971156181,8.48963733658096],[-1.02725282002789,6.20540590811892,8.74656266741521],[1.24720843935759,-8.09712214762762,1.1193270846174],[2.66957985944855,-10.409770829539,-0.575584625146797],[-1.7462194811645,-8.1854385802466,-5.61982205725875],[-4.70691258675213,-0.052935379588203,1.49575736141113],[-1.47824768043458,4.70377483328245,0.82426845746882],[0.647120129698307,7.27381831498013,-6.16156526270587],[2.61273395903328,-3.35837187465093,-11.019548235375],[8.54614702843121,5.28011428483286,-0.702431908835001],[5.49296439786466,1.43920238341012,5.13882837555308],[0.546716340408069,-4.28422313780405,-1.44573911980102],[-2.51805392125848,-3.89604856845805,0.296077188691766],[1.69931580789736,-6.03675273725391,4.46168642194672],[8.99968212230259,2.981066326993,-1.11452784289062],[-2.74039612109749,4.43258933247525,-7.45961181706783],[2.29887356193833,-3.41684863473932,-3.89465049651529],[-5.78705609130486,8.26729605058851,8.22915414314851],[2.59693339981621,6.94016162080964,7.37903989768564],[-1.72192014718279,7.33952717849004,-7.25532921213291],[9.55132717008136,-4.82362679191031,-5.61101751989724],[2.33746999893182,-2.65121265809036,10.2131426404953],[-4.81374755691605,-5.7180531095821,-0.920216331101156],[1.11664053695026,-2.44081761312128,-10.9940440936881],[10.3371083089959,1.26054720572897,-2.21459546024329],[-4.43978930234595,8.64498730485544,-7.59766654375434],[3.04214479759359,-9.72531922422486,-1.48027308030322],[-5.34984892141948,-1.62568193831417,0.471827866476767],[-6.05831826679456,-3.25707412651128,4.64104277815767],[-8.50868582380027,-6.65064564164326,1.14532179149538],[-3.34594255854999,-1.64558591699969,-8.26690142603591],[-3.48249658033556,-3.89249969786067,-3.1275838378793],[7.6362407324187,-1.54075356114793,-10.6469075366315],[1.44036978629486,-4.6865430430671,-4.88682370699871],[-4.88344036871875,-6.75038390084123,-9.52628506136358],[2.23475513657335,-2.89568086161842,-7.50160623055602],[-2.06546336910953,-0.110773423091087,-4.48160148861691],[-5.72161392504205,7.88740301409735,8.20005331772747],[11.5441029722557,-0.314211842107482,1.10363521447167],[3.16887420475315,10.2710737975928,-1.57899023322587],[1.87887058846048,0.80168360405843,2.6804655435829],[1.99129891210585,3.61523418996443,-6.14497519362339],[-4.77373259686919,-6.03873685198735,7.97267403515451],[-4.85742089504473,6.598070385145,9.00153237836462],[-2.73916383812941,-5.04593262077832,-8.01098204813938],[1.12333994421378,-8.29428830739442,1.84479156354934],[0.0217778116511,-7.32884275178953,0.580621358467605],[0.291500776900276,0.764407890385843,2.92152166250896],[10.2081859113559,6.14570122121004,-1.14900427958679],[-1.52153199030185,-3.39083832698759,-0.468460809661888],[1.5959835211569,-3.67957058432335,13.0823208095253],[1.15282882451488,2.90397932606137,-3.15747045667366],[3.2747850353914,11.8396575703278,-2.70645974701477],[-3.6837417020781,6.90648806194179,-0.388875524991009],[-5.75867435732046,3.58162884620467,-6.13234082963526],[0.0792415924031363,-5.35984664564595,1.55207756186117],[-7.55086944225132,-0.901608692078633,-4.35749576928365],[1.91792309755058,-5.45155279057348,10.8593706248776],[-9.37424169315483,1.49965759749104,-6.4322862793983],[-4.88234376859568,-6.34597639839333,-9.42522113380937],[1.77728677888615,6.36433929644076,9.2603971063579],[-5.86014989458099,6.97881281424822,8.27171545344293],[-5.18685261787782,-1.51964707346348,2.21828260825804],[1.03381877545221,-5.44669478140945,10.5011775948539],[-6.41146494258499,-3.93057123694023,-4.27757761441005],[-9.26182107123087,1.25391159462892,-6.51131042610132],[4.19520582266356,4.98797964316905,7.9307802933468],[-6.96644973871581,3.02822624036195,-5.47088884557174],[1.49678238825958,-7.62056748504649,-10.5249059858349],[1.76730544385315,3.95772111457351,-3.95050344517725],[1.41542084093262,-7.65407964571369,2.67223490615963],[2.17815186248645,-5.88613792407293,1.44847732301203],[1.57903482508744,-1.20928962450064,-6.65883525773773],[2.18104850736435,-5.11843315981028,4.86470847897716],[0.347409355519169,8.92395115801055,-7.92761092944255],[2.6095530819236,3.61788131608895,1.10254083658475],[-5.10441696190689,-5.50245679193618,-2.77373829569638],[0.426613276660494,-3.30402307692681,-0.71561074003285],[-1.89177387884447,-0.40595339398811,3.22306860821502],[-0.730547939617168,6.28030799557302,9.20020142520159],[-4.48583243723418,2.87411786343971,5.79628673216344],[2.40291921574949,-8.78487623852373,-1.77542150432089],[4.04550168242895,6.16871202079018,8.7437180745662],[1.8629511667697,6.65107187700129,7.34322479247365],[-4.31026656180083,-5.65168978659038,-2.87537895059834],[-1.35103124775941,-7.52057262245623,1.38168071922194],[-8.67754303645554,-6.38185690512772,1.22674520228885],[1.46943657181953,3.23305762144091,-3.36383544011228],[2.5509804857722,4.27151574819402,7.66898938385564],[9.56040283269663,-4.25989517318997,-5.8541300755204],[-5.48975114603003,-2.51912937492836,4.48407032684376],[-8.61172470313669,-0.471512263120031,-5.10705595014562],[-3.45418673568143,6.33227138756107,8.4234630468086],[-1.10847551443584,6.48766986793149,8.79579024896918],[-1.5230407530012,3.60655088917765,-2.41963454159924],[-3.1111063280885,-1.89649273385692,2.09528894509949],[11.2224836516938,3.03734629309799,-1.86858878104001],[-3.54467724934781,1.13250366756294,-1.80251541388049],[-6.14811516206498,8.26594181948544,7.54643183662334],[0.220392428203573,9.34857060564971,-7.54612921662282],[9.37855788635394,-3.74341337099137,-4.5999728804491],[-0.223996190797831,-0.875443565264341,-11.0132962754919],[8.22831955788967,3.49732999586074,-0.560275442807543],[-0.197386128798798,9.51907735887557,-7.20141817480612],[10.254613836976,0.625408304278922,-1.35883807528792],[0.635033753349555,4.27630611465189,-3.57320217875583],[2.55176436453453,-1.92084476621422,-7.49277800326032],[-5.19302043421219,1.20325423930724,4.44450241419349],[-5.24612366047502,7.68871448955392,8.31075914849409],[3.61852122317123,10.1624743964647,-1.65272463014407],[-4.23509887515767,1.17374813725078,4.20030732291749],[10.8681928100635,-0.839552485675341,1.29692407547021],[-4.67671403248353,1.61532667812236,3.15249505547251],[-4.61016623004056,7.44444373337883,9.10469736057557],[-2.30301141527812,6.87705929963048,-1.12260336164904],[-4.19215076238892,-1.44132707750848,3.81459302446667],[1.49734500838632,6.54715512962012,8.45414711374769],[-4.55041260169254,-5.93179454304171,7.56997081915512],[1.39770273840796,-9.6356933448376,0.318880631868542],[9.03596519218807,-3.60249722051389,-1.62033139188151],[-1.15146179155192,2.84135997975035,-1.90364145700785],[7.28654603427472,5.59619401111075,0.541446547470361],[1.86335262368428,-4.889579321563,3.72216988337057],[-4.81181071314258,-5.5530048871444,7.63199087104235],[-3.10496219319411,-2.72496615779229,-0.935943174323859],[1.49794812830134,5.43187458080207,8.3094540431714],[0.848193675096188,-5.29185432198593,-5.28975720375447],[8.53311688218253,-4.54565611983866,-1.06459096209021],[2.11738193832497,-10.3555578586208,0.661867141977441],[-4.61632934104133,9.27140027946866,-7.64535807517309],[-4.91881849309408,-5.15514946110479,-2.31547163828239],[1.16870604275114,-5.02086794834738,2.41301388232374],[1.43364312388311,6.41842520933234,7.53360402746153],[-0.123924896394132,-2.41522926077795,-9.46310029475225],[-1.93750810647039,-0.335582343944496,-4.90130249775679],[1.02071687370133,1.95576325635451,0.0351094388659638],[0.0266980376184458,-7.70687753664424,0.836237158089009],[1.25263235780814,-1.86703042349279,-10.1125463117287],[-3.53544208985111,-3.33479203039726,-8.06507949867651],[4.54813762057805,-5.95951279268704,-1.7518867501152],[2.861846669684,11.4698353796791,-1.45283644441461],[-2.01770418727612,5.97636273087134,-2.25510575935117],[-4.4605495131486,-5.59024208808819,-0.951487677852934],[-1.95857448190531,10.5948703403796,3.36609717360879],[-4.61684030841268,-6.47934493227303,-3.0100906797832],[-5.37582608502322,7.25180378288969,8.49849907688016],[3.10995521625087,-4.31529157971886,10.3782369898466],[-0.329643710220752,0.970468673046366,-7.55163663232532],[1.78960805898863,-9.67515243546515,0.850369476627828],[2.64333762955975,-7.79333982333115,2.94708711490733],[-0.963282138849404,1.74088782650752,-2.30323020961863],[-3.9030783156602,-5.92824158058267,-2.10603216897604],[-5.43050230591357,-5.59890945550708,-2.49284589933101],[-0.617511554912001,-2.59515876321736,9.99656126181433],[7.48605717441313,-2.35694499019781,-10.4431454702874],[11.0456033890477,0.315834032461372,-0.517137772412092],[4.48051865711098,-2.28323496553186,-6.74894096347366],[-4.57575719061576,-0.499644270840072,3.80952734255705],[1.75580856695058,4.69933451090953,8.02087797398906],[-1.79482915605704,-8.17839218918485,-5.54672944376398],[2.82274395036487,4.18937725208266,9.10778042747299],[0.252766934235418,-5.94949894943256,-5.88222566988087],[-1.360943372211,-2.59569862296797,9.52829074133197],[-2.32198578268618,-0.48144214507787,-4.09817420016378],[-2.82133860405031,7.08136455159014,-0.501869726167776],[2.26570291318154,-8.49884449445216,2.05118966740543],[1.96557711375411,3.5269389610693,0.215632291620572],[-8.35881589093902,-6.04430940226253,0.58097923723152],[-4.21040081699133,1.70425821344138,-4.4354947910141],[0.837568186154207,-6.70922169258678,-0.0444603110523333],[2.76274084996035,10.3525016743304,-2.1453406410687],[0.838175843384219,-8.54951660357166,0.314871307760917],[-3.08059160140407,6.42595619360962,-1.08765467093911],[1.36922335639154,-3.29890776152563,-11.6949401158941],[8.87235442368338,-2.25657693920209,-3.03402068147677],[3.64930978995105,-3.34180007226742,-10.1490780398037],[-5.72465874668764,-4.31218363018586,-2.4448849558253],[7.64088638630507,5.46291003334846,0.849255912599346],[11.3823691549665,3.15890006744938,-2.27841984825377],[9.78467570125562,-0.553613303405968,-0.446255524676103],[-4.96318310571701,-0.187746950511603,4.22637111594401],[5.93029548917411,2.70396988549782,2.38351883124839],[0.191559936061797,1.68171754264875,-6.81283966079249],[2.60819075165742,-9.83299526446712,0.213814181131422],[0.150375361178488,-1.40050073773023,0.760694523774343],[0.935067634042545,-6.0677647263932,2.74008792715201],[2.31983306997038,5.81937599173152,7.42614357996374],[-4.90132455670802,7.77148037461408,7.82127186502469],[1.56167836352416,-6.59331677875738,2.29747621366524],[9.58786049355532,2.15502876175634,-1.40054733881658],[-3.29160225562945,-1.48248685598859,-8.1625265968985],[0.820671533496473,-2.54061442706319,11.61561145423],[7.0021815890404,3.32013670749551,-0.875544574256365],[-8.88080317260694,-1.48669674107975,-3.78458464250287],[1.74297362649544,5.9984028466778,7.60852988925531],[2.57536318583985,11.5618174207849,-2.54740063406923],[4.22274180564639,5.61828945751952,2.64470946592897],[-2.39033374992864,-4.3356234338705,0.41967182098251],[2.42107768911516,6.28181015876217,-11.2724601165215],[-7.18257989765536,-5.91755260672577,7.00477215675267],[3.06989634385593,-4.77201383345149,-1.51970797700227],[-6.85969215577927,2.61285042917912,-5.74719432556574],[0.541959433184481,-3.08619927127203,12.2144430442471],[0.236404469261525,1.00353222344981,3.95076608546869],[-2.23574438892272,-3.4749317180552,-0.678989410794201],[-5.48371845339522,6.32269386254603,8.94300694277214],[-3.82801638885654,6.20750383521622,-1.96106848436605],[-4.93437424034788,8.58113737313646,-7.29759092740373],[-3.22409102963143,-5.10239274109495,-1.39625698467053],[-4.01656196215368,5.13325688524689,-3.22687478366929],[0.879133554143971,-8.34403334144518,0.946359707889878],[7.70297848861896,-1.58908465084802,-10.7292027322697],[1.99656780640617,-5.5061036124202,0.310430214487732],[-3.11489592956827,-0.179760504591416,2.96004136125462],[0.897642501057877,3.13030369664926,-7.45536885119198],[10.8547479699397,2.80513266199496,-0.991849491115144],[10.2984180008748,2.39355195592349,-2.47949176463638],[-3.53337827255499,1.14495983320035,4.27238391553385],[-4.40710810530183,-1.68618421555273,2.59987181826276],[2.52432458045297,6.16433524732424,8.1820090996186],[-8.00442964010862,-6.2754897359745,0.066644686682538],[1.30505917697123,0.225025375660217,3.84823737801618],[0.0341692654464312,-3.51562666576433,2.94227980327126],[-7.63307455027582,-6.03177991058383,0.032429460162534],[-6.48724351890043,2.38799016876532,-6.13275237590383],[4.01807000344543,11.1463334520723,-2.22723510675172],[-0.71147866425079,2.01939483531933,-1.2594310396571],[1.46091893320851,2.80572227210613,-2.78084951948289],[2.49709445136632,6.90551101178858,-11.7714008703024],[-2.93891543471937,-4.73477982828407,-8.67392883345444],[1.91439059748397,0.960702791677083,-6.80930135597007],[-3.89928411228958,4.36245958873892,0.019259614390459],[1.1555041075232,5.99846046044219,9.49678123482035],[2.90314325416604,11.3155112508848,-1.52399068830862],[1.40479778268462,-8.75830955198888,2.27857381344585],[-3.73759741091519,1.19750942519563,-6.12910165871327],[-5.4816852126033,-1.29502053135653,0.141885923932243],[8.32077807907429,4.00279495904922,-2.11355482686725],[-4.91549089504038,0.915377829237018,5.35500589946629],[2.5359960291254,-8.46849876819481,3.08117461457927],[4.11330332088463,6.3072183675164,7.5733068000237],[5.23389809320691,-2.73984506391875,-3.735337368609],[1.21379577299237,-6.44934820191303,4.60549250222715],[2.300817810453,-2.77204306993533,11.0442134373536],[-5.91238297841269,8.63609831461797,8.39575333445449],[4.48561858808435,-2.9654794845075,-3.80950470901545],[2.3368034260469,10.7662330198349,-2.02907529213802],[-3.06335357053503,2.51535326815413,-5.50737355208745],[-5.7600669445027,-5.44866307080179,7.49716629592899],[-2.86132219269727,-2.34549433477018,-6.85728231653747],[1.33252118829731,5.43747231314323,7.97216220697567],[0.162001567470486,8.89258186403878,-7.71839005484637],[-2.85669111961153,-2.12304741437177,-6.39875646782148],[-6.75982104462154,8.88460589933831,-4.12242179300604],[-4.47956252874843,0.958374498961061,4.66275228375454],[0.418840667804612,-3.19191683001598,-11.8305266116585],[-8.34135011586787,-6.24559793220633,0.597436148493179],[1.24528040184568,-7.22702486210796,3.3497331858128],[-2.81017610267465,-3.48187424020234,0.238892674580046],[1.67440488209637,-4.3919875733102,0.326260603608325],[-3.80624100350399,6.77300001038623,-0.73620243418076],[2.05010112912166,-2.73790518925828,-7.73664802173841],[0.605109055404901,-3.40043225380566,9.78347989638921],[-0.49312803839402,9.16697557420142,-7.39358073144518],[-5.86711313992675,-6.18367692602129,-1.18669896722757],[-4.05345163992524,-5.45619929567119,7.76340741899916],[-6.27963186374561,7.49586865644433,8.91135432750555],[2.85151837781988,-9.38790750520987,-1.36466860933209],[1.04482571904023,-5.77410133311956,2.92290470933599],[1.2680754050748,-9.15349749007274,1.72051966333458],[2.38263330549257,-10.1009073151325,0.0267987561761835],[4.45558680729348,2.71490131226074,3.34871274675781],[0.585650426821718,0.222515588859235,-2.69534008831755],[-2.24958129160409,5.13799802457098,-2.57696891157259],[-2.92030000713534,-1.79318781457459,-4.44555278508598],[0.0441114058611223,-6.28527142969829,1.96498096735008],[1.23865980476329,-6.40292498611065,3.85106102416162],[0.0523422814526194,-2.61975601631281,11.4554500761989],[0.168807001837468,-0.0581106172058568,-1.21476877895623],[1.49999093141514,6.30193334586807,6.67439723695172],[-1.7549714480394,-6.64669560751054,-0.769690563060802],[2.21625537939257,-9.68847175516576,-1.85016554491264],[-4.91736581512079,7.65398302271501,8.73786252427312],[-4.69318408183789,8.63960188217763,-5.91894328833229],[-5.94882249295386,3.28104777711094,-6.50276550069168],[-3.06848580161785,-4.67726800480642,-8.77577703819716],[3.79730829487557,-4.6967311846194,-1.27086581953948],[2.63081464698735,5.57691839865297,9.43174458502786],[1.72151787058149,-7.13004369530662,-0.434367815997906],[2.92635466435742,-0.305473184004055,-11.8386790038826],[1.23168080368202,0.39127585999286,3.79639610876122],[1.29334058057697,-6.97929852007493,4.68490067719023],[8.45093384252861,1.12337468819051,0.609635261496291],[3.36645216663994,3.68716439542773,1.65876984644783],[4.64633310447524,-1.13955590319236,-6.58327107431932],[1.11682294216994,-9.50045369002301,1.57272470788505],[-2.22634355564361,-4.20959861822975,-1.21736045659253],[-4.83815959521544,7.68941685287458,9.39601821477795],[-2.03637723434273,3.80339050192048,-2.31304963878594],[-2.95727947520516,-3.30243125189013,-7.70265209761406],[1.95552828620617,6.26945485129636,7.976116302419],[9.84865014868966,4.13028596497345,-2.55986388471946],[1.04914687532043,-4.55826574819168,-1.99928437452881],[3.99836520738691,-7.26246881949554,-1.32898763192007],[4.8493103871956,-0.375209344948967,-2.84532331633738],[0.450474044549684,0.980897425767023,-2.58016942224859],[-6.08079001800334,3.83596977232416,-5.52295708634593],[-4.10216649335366,1.33912404655897,4.91310426006699],[1.56797888564432,6.20451936577043,9.33383944825496],[-7.23853894110624,-7.13385230897505,1.43161000747103],[6.42071218667564,-0.892904202268209,-10.2228344540414],[0.779939604580927,-9.39865530526929,1.44627611247888],[-7.71150077921577,-6.05443130936772,0.192722250944959],[-6.31526424884276,-3.77932191570882,-4.48607308187524],[-3.96408492136487,6.31537166648908,8.88002791340665],[-5.10444629297221,7.47055626366076,9.09268010834394],[-2.86723526697636,0.994262884530492,4.29016521250568],[0.933669086909366,2.45533888619068,-3.68696511659301],[3.84194142753634,-7.5762016988914,-2.11973743568818],[-9.34627029290488,-1.25549665146596,-4.67678420532439],[2.7415931364112,-8.31520789201233,-1.63900654833547],[-4.75568460341151,-0.843165126100874,3.31846730614342],[3.47736073317464,12.2354883515112,-2.51411895250717],[-0.0732310350781821,9.53179903557637,-7.77309714484729],[-0.624158605805283,-4.43957270551256,-1.47687085056465],[-2.40275062896003,0.171561598142656,-0.965730417958863],[2.02101784093267,-6.71038102021077,4.25534063417906],[0.94158033532062,-2.84689834880626,11.2175956960647],[-6.40466665884026,8.65364749048223,-4.26899223298818],[5.22898138092662,1.24398476472228,6.19749539873905],[-6.22928743880971,7.83639455298997,8.85659702507629],[2.65397809737849,3.74168764548334,7.96193299698996],[-5.01755510676055,-4.63796706323459,-2.21060508701372],[3.11029602953146,12.1190416541999,-0.898767361684291],[9.69225680601962,2.47401308953968,-2.09078508709529],[-8.28865498468634,-5.81045377950175,0.583330055831732],[-0.747051157878727,-4.71291622117595,-3.74495461464183],[9.52228991136555,0.81599230787019,-0.692001346934076],[-3.43545737350857,5.36890682574122,-2.48547836371787],[-0.102289386188969,-6.65659372647342,-0.596025974340192],[1.54025600764846,-4.27017240108569,-0.35221886808257],[1.29324788379463,6.23073689208911,7.01665612540323],[3.96707277313914,-5.5710165456375,-1.2964103000019],[-3.97065606762107,5.17563202929426,0.637530642285889],[1.19767703433426,-5.94669283250617,-1.12438077415936],[10.754792793079,3.33802983900982,-2.20067717195093],[1.66022399397571,3.99391954908526,-6.02628986576237],[2.29727240904262,6.8942852608585,-11.2666383300126],[0.667317628954818,3.60894398960569,-8.49910289536762],[6.94524711856446,5.17516961482731,-0.130090222663841],[-0.314958762722462,0.883511594016904,-7.77649036215093],[4.11002340976082,-8.08966221882221,-1.26628868221887],[3.67544000978888,-7.9539041163498,-0.936614165837391],[3.28318593423094,6.79907021740828,7.18259453787532],[-7.1473532385179,-5.7322208596139,7.02045407068291],[-3.01648366270232,7.33577502174731,-0.0809430203644996],[2.76362821243295,3.66665349609898,8.14956914332558],[0.0659231545783883,-8.50747868514332,0.505608609895984],[-2.17053505842279,3.6728807342045,-2.56791436245745],[3.59015683811484,5.73577098595487,7.84360488743362],[-6.09465096032105,-2.81286864853459,-4.66124798226953],[-5.03352011673227,9.83652635596061,-6.88322758729294],[3.53701302437114,6.0784055846761,7.37631990904225],[2.22619788874415,-8.39932365714157,0.389337013644899],[1.59448520725613,-8.81089850080189,1.86395267934556],[-4.37971496175299,0.0469096752202997,2.3645070282501],[2.74936288362118,-3.83772447884953,11.3302658874346],[-5.54068146753159,8.11864884644922,7.79355560385185],[-5.07792639860165,1.15640877698673,5.04312506474121],[-2.79828453284504,-0.160688434444599,1.39959361453055],[-6.53657665002535,2.82734231699231,-5.90577385945404],[-5.88841751443304,7.74487776956419,7.81043101467899],[0.317308700257259,-2.79502428201453,-1.69108757959894],[-6.1114596396421,3.59862213699294,-4.83044964621672],[-2.3858751035776,-4.55473660186154,-0.398676235458891],[1.15214247180658,1.61043819932525,-4.97499424174163],[9.22611440477921,-0.067786681917849,-1.31023300784041],[8.55146781733152,5.32572610983588,-0.732753378913353],[0.97517691175705,-5.47640283249065,10.9681471096307],[2.58678094803485,5.76349469467295,-12.1743203490987],[8.74071082022796,-3.43748631813084,-2.03484109700686],[0.216709430729675,-0.970955582796304,-13.2611480221973],[10.456457672215,-1.93387307886262,-0.28896389310435],[2.15531919304993,-10.2867786934643,1.50943384321855],[-9.23928265955367,-1.40641266830693,-4.32736362690771],[1.71379401877208,3.99055799489809,-5.28729267791266],[8.2692848599859,4.71547925176771,-1.8570773305145],[-2.92868184268412,-1.94517321894229,-4.54915987968275],[-5.28841992649606,1.62689295389114,2.71892920303427],[-5.02640444854924,-0.0732490258775851,-0.400869994542795],[0.746716768072669,-9.72847076698694,1.31289330716345],[2.52538187342307,6.71387230013003,7.3335219177861],[2.6061221221595,-8.97474400131722,-1.3861230073873],[3.19652178790008,5.77625169147937,8.42437012694235],[1.96977146832868,0.136682753964062,3.39041707842169],[-2.75322199731873,-3.47409058986232,-7.59252220357975],[-2.6959801120098,7.09922811958014,8.84945935660849],[-0.0453251631340122,-7.74039286849431,0.617713378994133],[3.74003786763803,10.916533147238,-2.13324973770914],[-3.08998679531755,6.99357231987726,8.88599119603008],[4.70343577525211,-1.99115923767795,-6.67710259029434],[-4.49670690585693,-6.19192404469792,7.84703445021784],[-4.86705694869105,-6.90501749317722,-9.74286554758545],[-2.91165613965297,6.66466041731023,0.439699370387793],[2.48058021201331,-9.03164358851066,-0.844857713448121],[-5.50533214871415,-0.946362209568274,-1.25382210261209],[3.59316591002638,11.0137184961879,-0.382826095189386],[-0.519310833153593,1.54339429756624,-1.85370960176251],[-5.21006629613214,-1.30043800212865,-0.375029949844594],[1.46151929035122,-4.29432150686445,-0.451278070684052],[-0.104376161851037,-3.42384962824838,-10.9435282602002],[0.381695162074556,-9.43187707813287,1.13477469315177],[2.55556055526116,4.47947534325512,8.80804857089513],[0.469436432941326,0.970582515699787,-3.21832539909811],[3.2625720450811,11.6474857755486,-2.68893034083233],[9.80179001823767,4.01125480551996,-1.95035497365576],[-1.3962759667523,3.49019726719409,-2.61770171059535],[-5.73878169051621,-3.05639249500996,4.47465816340005],[2.46557489833115,4.68367445903855,7.76816897221055],[-4.62583305222266,5.91923751414736,8.84769536895717],[-1.29101012560511,-2.52841928767367,9.49525449427849],[0.414610402719488,9.13225893390116,-7.27609605936416],[-0.234981500485027,9.13207339537408,-7.11269918190229],[8.8976655138752,-4.69126931981166,-1.79697029869455],[-3.45059960391899,0.0463559561079497,3.04061351849485],[3.14761643782174,6.12708160674227,7.6406497248458],[4.62900603425911,-2.73565240947497,-6.9692197406561],[-0.170457351803266,-7.97899771210027,0.412756807576905],[0.491331056666797,-7.44322285762783,2.25268428334815],[2.91071301392112,12.1723965976152,-2.45496938397333],[-5.62704617117864,1.26027402507211,3.49950652286389],[-2.1390985892758,4.4967092713337,-1.26352412519306],[1.94707822119241,-4.83397320087939,-0.415644603048311],[-5.04074909262125,0.460852913898645,4.28508172695814],[10.6023293559366,4.68682253977031,-1.04096044325944],[1.70973613688971,-4.95041510392891,-0.192347073618883],[2.56749587395258,-6.99448172047321,2.90479185781468],[2.50175644398695,-10.3033161091776,-1.16351505488716],[3.27532693386813,6.14304838764359,6.91671343762736],[2.12860046448759,6.40574259311913,7.4573114407372],[10.27580457211,2.17734055964856,-2.58374538188796],[2.93161640373281,3.54101178046341,0.869543417238934],[3.11602187272695,6.67261223462484,8.35653124955923],[2.90463085305872,11.3512117437305,-0.784192877245843],[-2.7151401601608,-1.03124307782298,3.56824083931407],[1.00754315220933,3.18678988167351,-7.25822501647185],[1.99012563794624,-5.35473934824396,2.74714836173888],[1.64461739787707,3.48774136904249,-3.69698021758472],[-8.45925127842606,-6.09510203865683,0.75721340449101],[3.55464755653783,-4.27409623951807,-1.49104259908256],[-6.42399890064114,3.10023248405736,-3.97596682629946],[-6.06721885279392,-2.72219106975122,-4.84380993743323],[2.02372517966598,-2.23224571118347,-5.74356973141068],[-4.59209240695116,-7.05229460784488,-2.75967290942013],[-4.82876065699645,0.844559660129544,4.10057993055183],[-1.74499068038175,-6.27180399748373,-1.45325645530591],[1.83011491298664,6.44285786111221,-11.4312285335882],[2.30640974594184,-0.120352848032212,-7.02976466696932],[-1.88482574388791,3.10479135115639,-1.25816524661571],[-3.74542576039907,-1.49266703396513,4.01121714241544],[1.85090373458527,5.67786329809445,6.95093125336707],[-5.36988131896474,7.12358240458888,9.10506358953849],[0.462833716906046,-3.26367464041541,-11.9687309914148],[-6.96164159314357,3.12205654254558,-4.77882753019707],[8.94009445692644,-2.70286549518633,-3.43071573240807],[3.41052103921112,3.49476572948716,0.34117081893148],[3.51209118874238,6.54881631741416,6.53101690889345],[-2.2958499954821,-3.39545820256371,-9.42823992735785],[7.76764380755218,-2.95065039781438,-4.49887076413693],[-7.32524297535278,-5.77735488732477,7.26185715807522],[-2.35560616646678,-0.808080767129681,-5.05894551114018],[-5.47042513400267,1.06941494929259,4.08964388419506],[1.44565129822777,-8.25945644198687,2.17643105114567],[-6.70931094278608,-6.2934664771932,-0.0730877935566404],[-1.96727003303422,-3.02561454526259,-0.47715899749565],[4.12316334827759,1.83663459479253,2.58292671647496],[-6.3780397642732,-3.10346260595606,-4.99702386000321],[8.09328753329162,6.12301241339082,1.99533346567354],[3.2651416233628,-2.10470609220143,-4.00358047144793],[-2.73443033396194,4.19977863745465,-7.54808995482086],[1.96696538556049,-2.72071205158942,-7.60877826050195],[1.77294642810405,-3.60311611671641,11.2939016344594],[8.67353959112521,-3.89936144229777,-1.998070246451],[-0.44049289849261,1.06748681739716,-7.58666000463834],[3.32696215639577,5.6279912232599,8.94851530262597],[4.82546434247431,1.79047842283604,-8.76768856521609],[-7.54029707071639,-6.02046946960904,-0.430364918544391],[4.57479795122303,-3.07002202074173,-3.8975812938564],[0.709180884928815,-7.39278617033299,1.77899461832236],[2.36398980437651,-5.48491504869545,4.39232395030692],[7.37415035368263,-2.05078972788836,-10.2563602943061],[-4.41412006459924,-6.03244372959365,7.80975490007083],[-3.96711201904647,-2.00754240930051,-0.0960792173443095],[-2.71089609530459,-1.56849593724498,-5.73058473553748],[2.2233600941374,5.65098580354619,8.61850708013545],[-1.4701533722313,-2.59953864291147,-12.1035986345581],[2.53284293144332,11.3593590857861,-2.41133498441649],[-7.59464872602965,-7.04271177769875,1.44766966362792],[-0.217172533892659,-5.6803357232221,2.5931140006578],[0.882493329709576,-8.94853329799921,0.271506580855],[2.65800044634753,-4.14309398375669,-1.26456777455905],[3.33571026782331,-9.43219510173528,-0.662226440030706],[3.0569979404134,-9.69991096868208,-1.02084121179746],[4.36643608314659,5.03715869738097,3.08359369996817],[-8.56841120729578,-0.966487556227033,-5.66930819627783],[1.57939316120171,-4.55882863295884,0.122333346274817],[3.34363997758995,6.4899194475278,7.63132485282253],[1.66930309652532,-7.18063354518223,1.92043106931931],[-2.87301253501536,4.8335834829777,-7.31528079305302],[-4.62453087969722,5.46773638095828,-0.0646300975717331],[7.87226789148612,-3.09161599269493,-4.02710463362824],[-3.83838605856094,-3.89874849817843,-10.5479751826852],[1.78331227725248,6.46288288506303,8.02526429907025],[3.86577821290161,10.4135717093376,-0.886011388323841],[-4.55605174244017,6.70301408744658,-5.32532393910692],[9.44099708393042,2.33145511092109,-1.53206994957256],[2.30815816262617,-2.68702661767622,-7.08019200215798],[4.20916210878254,2.07742007700327,1.61193217319501],[2.42084837535898,-8.51049470179028,-1.91747023702331],[-1.26525987955459,-0.617248894868264,2.90008068965759],[-1.40832829455101,1.51311238384774,-2.57936027515838],[2.53646951588304,-8.23259308758989,2.37456593677425],[1.21140498777585,-4.41768504300952,2.16717231115812],[-0.589443761415645,4.2783063898975,-0.0132830046569775],[-0.368008033375026,6.63677350445718,-7.7595473581343],[1.6465853829951,-1.08296249893764,-6.26250376605913],[1.52536898458553,-6.81993932570523,0.875656341308412],[-5.19482447783493,9.35296211702359,-6.91424818241006],[11.6340529389962,1.90509884639652,-1.88352596431606],[2.34663069381805,3.59528132086069,0.574734226468464],[0.54914651353231,-5.54275189785776,-5.51574405716555],[1.74868926766194,6.06499470934568,9.66160155170336],[3.99823833142459,10.805255588462,-0.752198721369401],[-3.70399711687799,1.17951377248494,3.40927451247877],[-2.88142341675019,1.07708034074888,3.76771598906707],[-5.39759375964189,-6.52358468056979,7.43531018032531],[4.00315288430364,-0.663155508075937,-3.72148474298838],[-0.878150272058177,0.983857805369647,4.45612897678373],[-5.4479472310419,3.14855287592381,-6.56695067832381],[-1.70675811792098,4.2301035367719,0.304180343246537],[2.79845023277113,-9.66955731942168,0.0364894784634019],[1.44761103309585,6.23940343126016,9.06211545112392],[3.79887104215106,-9.17761395119247,-1.61075530327759],[7.91025038390867,5.82088633338991,2.07945316225187],[-0.525097092883504,-6.93419956441135,-5.65351438885329],[8.39472489297675,3.93952381771449,-2.40222516842637],[-6.71355750200165,2.48623018525537,-6.12720466662734],[3.29724204371426,-3.6851330918262,11.6509509089176],[9.31645666920622,2.88319154829411,-1.14798892283913],[-6.00682513466374,-3.90097102874403,-4.76350767325177],[-8.94245143978759,-0.814212601583154,-4.91883120956505],[3.35355140092261,-0.252269885833747,-12.4514901484944],[-3.29324323322934,11.9385010722006,3.54280745074729],[9.16243888182763,-4.27732190741126,-5.34179116705361],[0.711665996002726,-3.07085076160504,12.7784019657901],[-2.899894810376,-3.50476323466214,0.33186069778218],[1.63547319922047,1.61000116169682,-9.31654788472772],[7.92492962362639,-2.85954031318524,-4.80989849610349],[1.43915586488612,-3.52519125688112,12.5081609870492],[-0.424648417583001,-4.65360409297393,1.93890738228545],[-9.44634336520006,0.801420760320128,-6.07188247285772],[-3.26531162718108,-2.62577374042362,4.63727597800985],[-4.37180539603389,0.967868336888417,2.73459920545127],[-7.03104569837205,-5.68069982696829,6.35448983586351],[1.08073155618432,-3.11115346008105,12.5850296775652],[2.01994781066907,-4.06143543914006,12.0695545569438],[2.8764945494843,-8.13994241743155,-1.76519288492564],[7.56393377505856,-1.54432425084963,-10.8818559273846],[-0.236910443320401,9.13485562292379,-7.33954922838348],[2.23563309328422,-10.1904901312159,0.188528188280716],[8.92559229592659,3.23012735845365,-2.77076568283332],[-5.95501830813148,7.95341376489789,9.03994036088174],[-3.4926371086465,0.533648160855364,4.66028658986677],[-7.0459233065868,-5.37724468531596,7.63710210942109],[1.46336985976993,0.447019670927747,3.78180858854935],[-3.51901880579812,6.93904414904061,-0.95794368383555],[2.02574872478767,11.4385190888928,-1.85047389468762],[-0.378309681861475,0.990423939558585,-7.57645806533518],[1.48113392531657,-5.34999455976551,4.49556216995253],[1.34466973628706,-2.38458552723984,12.5135865637633],[1.12427132269242,-3.87844380007702,10.0994579115894],[2.63364832788875,11.3098586988451,-1.1367983133152],[-8.71156296905165,-0.405157093296503,-5.22288191470234],[-2.77581376300932,-3.01244817647103,-7.14035060124008],[1.69787528332666,6.00155587130569,7.71230837891831],[1.74336979684788,-9.39455043629242,2.05417570975501],[-4.1177510717013,6.97957574070183,8.87712984636383],[-2.86262255982088,0.125208664533547,0.561069500914543],[-2.51429668728462,-2.47630325269522,-3.85246477382016],[-5.59187370735119,2.85502442385433,-5.66741260051002],[1.54633371525305,-10.0777269001255,1.16784676119129],[3.33517729848742,-3.39199980228263,11.7345368316598],[-1.0860282880358,-3.92889581033999,-1.35067014792559],[-3.3322257633006,1.6777103383127,2.0870998585242],[-3.23430988846988,-4.48688712812434,-0.972557966886404],[2.89207066142412,-8.39964602013008,-0.284659104914125],[3.07824292187978,-8.39127515450395,-1.88658313236203],[2.88968129158923,-2.35925983467243,-6.61539564969536],[-6.1291089544401,7.58229581354663,8.32466443197442],[2.96903344023063,-3.15017086003551,10.8482077250527],[8.69282219697047,-3.05997556981494,-3.77189871707852],[2.30252639511906,5.66331680016569,-12.3814014022618],[-4.64210607042317,2.17941246855078,4.55629718185882],[3.07912976401033,11.2631470662016,-1.86530385118748],[-3.78650392320894,3.21184539719027,5.02377739756056],[-1.68250367294875,3.00873764366367,1.91650156032351],[2.21599168415871,-6.00948982795528,0.997305835694858],[2.47032087604303,-10.1345241760085,-0.545752102661117],[1.64245292298479,5.54239391642599,8.200704731521],[1.47515814194484,4.15388717052722,-6.35271376276628],[4.09560404558087,5.79197110897115,8.77845588496457],[-3.99810979762586,5.76385469205795,-2.0185789337873],[-3.62799928716132,0.251271353005932,4.31551181600993],[2.87530814404913,6.66856323836714,8.25952010533766],[2.28371412257707,6.59735192289484,6.8840649383958],[1.27005151608423,-5.65203798707395,11.0695553290682],[-3.65494583730257,6.45670842995516,-1.07372156193448],[1.57495763548181,-5.75701364332973,3.65031787306902],[-5.23757344102558,-6.61667952581918,-1.95053972506217],[1.94760241887051,-7.20915149050923,-1.69073860417308],[1.63874660033852,3.97626482952046,-4.16262341206849],[3.76744136867363,-4.68895552684387,-1.36576886585894],[8.92777606970786,-4.43092348938397,-0.699759892779094],[3.20495282499177,4.94361928927764,8.12850744820296],[-0.510051296499047,5.7966427692915,8.40963738978191],[1.14336404563307,-2.40730909405441,-7.7720298663091],[2.16065746857105,6.20869031523687,7.6964790893908],[-2.48041954579848,4.02234575822208,-6.96313069594746],[3.48272945790314,-5.47650653628307,-5.45824273570475],[0.160616222773916,-5.67665088535611,1.72026915901936],[3.38972191738521,-9.58627725560629,-0.566131825315292],[7.71605043896692,5.71040330162717,0.944389813075335],[-2.52433464026451,4.21111471182554,-7.67857565530823],[-6.00686783356698,-4.08662471840172,-4.30784065627787],[-9.38668813911744,-1.15602295472873,-3.67700228027069],[-6.70720182874323,3.02338795916946,-3.94336449674993],[-3.93649666594349,-5.67811687389341,-1.66526147036569],[0.0761135731686515,-0.26082944189948,-0.6398721639978],[1.36005026375479,-4.71296212303695,-2.26165717879618],[-1.22953104556171,9.40313241111496,2.36423884903144],[-3.50991775689601,-2.66799587502187,-1.85640110541002],[10.9799353685292,1.37696897433745,-1.96534118341112],[-3.61895525021232,1.14561757050274,5.11450503122068],[1.85024922033852,0.299166680880713,3.19360054595276],[3.59938651292505,11.8662042824824,-2.04557233289744],[3.95167636916621,2.15430899992515,-10.5648244138454],[1.14209717061444,-2.27270688988182,12.915855909408],[-4.81434889955827,-0.376328947796829,4.64265944391797],[-4.42108466624672,5.30933686253105,-0.0310430726634487],[-4.71301638687851,0.341204795289583,3.3423258242897],[7.99837534643988,-2.1062685660191,-10.5848900892232],[-0.14887132352752,0.431650645182288,4.08228286460246],[-3.01329714635153,4.10081927786509,-7.22421273538199],[-5.36105808546476,-2.77353654226994,-9.19291126210923],[0.813851533526201,-6.2040349760385,4.52037872090804],[1.76253553481359,-7.19552610441578,3.68208144611315],[1.52699542820037,4.98743920689095,7.64555546293203],[2.66315573270411,-10.365711651724,0.141658131312801],[9.76099439705195,-4.83054627231839,-5.00513265167389],[0.863142097628365,-2.64434500598004,13.3271903720554],[-4.2400387326816,0.303973755656068,4.54412563745873],[-3.51581464800802,11.4834000927233,3.54168989640062],[2.60273232625981,5.67825157577296,7.8746689320227],[2.69403515165893,6.79415698437137,8.31879760065996],[-4.60130760397529,1.33183776808717,4.5984497947574],[-3.79604653103789,6.64878182558971,8.76736042382075],[-5.07550236347955,8.41996705547348,-7.31279050475296],[-6.53017308874246,8.81102515410498,-4.00618799924615],[-4.88362701617355,-0.531288780230565,2.40403922540496],[8.45103192767256,2.88423643119068,-1.68177430168027],[0.237303696102231,-4.70925923588483,3.27655742260817],[-3.49740212587178,-0.707354137720891,0.690358897608317],[1.22368729784076,-8.13386345625083,-0.948993083724111],[4.05913980102479,10.3437571333035,-0.455308109363415],[-6.66198914558638,2.18779605797256,-5.79077653611881],[2.74529335127017,11.9221752253117,-0.716346324417317],[-2.53110423075949,-2.69641667432663,9.41185307722856],[1.90442560012374,1.75839087209483,-10.2165535284658],[-4.3065320799191,10.242660947723,-5.6055278744949],[2.59341210719457,3.45026694354654,-6.40691704964876],[1.80577913826127,-9.0127991909089,0.502776328105545],[-1.44410627801751,1.80399521110759,2.3138118475507],[-3.10744604047657,7.0990246848324,-0.527529759292019],[-0.944864735253025,3.80845578081372,-1.88554382376248],[-4.84176781983296,1.15272741010788,3.11029528419288],[-0.146056391011966,-2.62252841714337,11.4625437573383],[8.67413123955693,-4.4235102782274,-1.03776884636617],[-4.53453309462554,-5.60556840510721,7.92553439648195],[1.03388214784158,0.206575705267313,3.41823996567713],[-6.35149278988318,3.64598990712029,-4.8527519252763],[-3.17357141352467,-2.77197311279448,-0.731046033619165],[2.74559488147254,-2.85294125895949,9.5767532872478],[-5.00156065011378,-0.711214973777407,1.43179932486108],[-5.98883576625871,-4.50615157301074,-3.93873585460582],[0.371124389073835,3.45491161075885,-6.22534470562232],[2.25929809195462,4.06105011960882,7.33003643395535],[11.0649545352144,0.358013939685473,-0.716199349951491],[2.84120214624423,10.7863053956446,-2.95267024939765],[9.53414466337967,3.4987046569402,-2.70847625396137],[-6.1502178260942,8.28107961567275,-3.96240138200623],[4.11654022362315,11.308662603207,-1.37413209358483],[2.86225807750292,5.97864186066568,7.02765208095176],[-5.88507421683017,8.14972411234427,7.6906854571831],[3.11248467581034,-7.31493673246127,-1.1264578875697],[2.06515476405192,3.76652314291908,-5.90583091387376],[2.98561952897669,6.86384305923418,8.12523532831799],[-2.55126620214753,-3.48228227515355,-9.33641892638619],[3.87299986274494,5.36681004299729,6.54168785656772],[1.59441795177368,3.40859831271867,-3.55924003233599],[-6.78256791721528,-0.760194031155267,-4.39401513507298],[0.901753539330134,-2.08517465525915,-7.70256831861768],[-2.88389791486423,-0.858861310461989,3.46564800992343],[-0.994318540514865,-7.80769662643513,0.301079885972409],[3.57616489983669,-9.42604742944257,0.165325339737381],[-1.31281108195589,1.80589460948006,2.14416545796817],[-0.0302593632942322,-6.38648168524568,-5.71995661668982],[-4.42136832502444,1.48174141276035,2.58676256425749],[-3.84753374308493,1.21677043772956,3.5203645618043],[-2.4677723659628,-0.225958172178689,0.603270309518529],[2.67323648016309,5.75446864934854,-12.2742006549509],[6.91071573695825,3.77615025866693,-1.01826023717883],[-2.75735318571196,6.06498980070972,-0.0879884057733514],[0.0756095076913735,-8.04342432116611,1.2998152210285],[9.57882963759834,-4.08719115515405,-5.24319996479099],[-6.74454816931579,1.88960992806491,-9.19613277523538],[3.6612279133848,10.8370374874365,-1.56957160934075],[-5.41043931083852,0.713036503775956,4.2827327522452],[-7.18234443976048,-5.58376681779824,1.48440951975992],[3.43016392377248,-9.10118996729891,-1.35488798755578],[1.03756813562812,-6.98041131796768,4.18598969732926],[-1.9664137845753,-2.12262320119133,-12.07181351671],[-2.22248550248105,4.84964193375097,-7.45225533525174],[-1.13805296593621,-8.00302760294064,-6.22301804055272],[-0.0696115871801514,-7.84602559007742,1.55010640860863],[3.28139856636885,-7.53373712602507,-1.97534371972123],[3.35956867795326,6.61396955010971,7.93954588596672],[1.74900018704686,1.50301157148507,-9.94000760314056],[0.67207004639539,-2.88018771599402,-11.842400888588],[2.22774977914556,6.59679683849678,8.53729012778898],[-3.60539366280027,0.366262692420568,4.84274194676211],[2.13279748562184,11.2488643387454,-2.54768193004701],[-4.58782923727124,-3.08161682758134,-9.2849060578787],[3.44411319941653,5.87076227240589,7.56721965890006],[6.00375691120075,2.69793580270329,2.42707592736671],[2.02041250323065,-7.30155661772454,3.91952987416979],[2.54603226074282,-3.20378961615873,-4.43598197815519],[-3.82115866864737,4.3258040121436,-0.00412780366076254],[1.49174325136514,-5.86334098139451,2.6819844104733],[2.88803504272694,-4.56831414373437,10.7161332307162],[0.781190397907215,-5.04835450523143,-5.38294961217039],[2.11295227689501,5.47143591510277,8.78348001997726],[-5.02095196091332,9.51263397551634,-7.48512398264178],[0.918652569841298,-4.42686850025566,11.347425015043],[-7.94469873544817,-0.58782036407875,-4.48403062593671],[-4.68530174818825,-7.21655214207075,-2.49134669983477],[-0.423613937965585,0.384148001851116,-2.28592177323771],[1.33839549626717,5.21896358542745,8.76116817095231],[3.63524212412122,-4.59509241637916,-4.85069507756958],[-6.01532181754075,3.82478927336708,-4.79141001735078],[-5.31782296118087,9.34751554938022,-4.36127656304599],[0.719935585657869,-2.91521977998412,12.3559533578745],[1.18581496841315,-3.86642121226957,-1.58099386103628],[-4.53171308099987,-6.24425899150971,-1.80722160055992],[-3.37036463840369,6.91297814218139,-0.95247857051014],[-3.82550366234586,1.07882237904393,3.39911717571992],[7.93759851317282,3.38498075119117,-1.52481016336571],[-9.59511388201185,1.17513593478828,-6.32733997440867],[-7.76092142276634,-0.160615081573828,-8.55288934880861],[-6.42219474571655,3.5977096219807,-5.82670136579628],[-3.86994011461805,2.69074247214882,5.43345657210383],[-3.61052951350904,7.11785641447178,-0.613031222693324],[-5.0092858146469,7.05412941442178,8.24392359714413],[-0.429760513193676,-0.942607339259919,-13.8535078919251],[0.157223310780928,-3.14825852216936,-1.13347445497235],[-2.51214183295984,9.07603456943938,-5.67505846816252],[-2.83503446106947,5.0071725600374,-7.44848964223608],[-4.86158639647788,1.08921529298308,3.19910441086418],[3.2826872629291,-4.46535775965428,10.2195674515462],[-2.64462105114421,0.725859684230428,-0.911617288027106],[-8.68555712699237,-0.806566260196312,-4.79971479431523],[-2.45857788451108,10.1962386377889,3.57264884137252],[9.37704965434696,-4.04093185647512,-5.31787992539518],[2.99813161899585,-9.7541542173125,-0.858476646351537],[2.42343582086732,-7.84266469773123,-1.78121554194944],[-2.49956480665598,-2.98433159190422,-0.401164875605827],[-4.44365366070275,2.41035633076516,5.09282869396182],[0.864918836815231,0.216239568926052,-2.52309251136412],[9.5158097577985,4.97363278595067,-1.36261110906065],[-2.31545758518431,5.20883617556159,-2.3768070505327],[8.34413373584999,-4.32785106819349,-1.61980726765921],[2.64228523806498,-3.31836861479784,9.79924783688874],[0.86305379134385,-9.15924309452234,2.21157628847156],[-0.951818653755606,-1.72049012262372,0.617556571542999],[1.6718113266897,10.8851783961481,-2.55002484762164],[5.18081874492607,1.43739402756698,5.40904959530111],[3.95164110876659,10.3727742434457,-1.52492163759906],[7.45557513120841,-1.84317872794466,-10.7994391426202],[2.07075405746479,-7.56725913358571,-1.36114362455338],[0.0821818259171273,-8.00227383561782,0.938168248295584],[-4.95199484826149,-5.72214392758371,7.51211629462912],[4.26837889620974,-7.59330096505836,-1.57233958724097],[-4.14632308568285,0.699609126427391,3.51128310013957],[0.812657681114754,-7.77324653059034,1.69905951325446],[1.05033607746347,-6.06886648275231,5.02810906687256],[-2.50238063175983,4.94211921368769,-7.71959508979147],[-3.53867760681057,-6.02721019566031,-1.74224989221392],[-0.438735107671267,-6.39157166301106,1.79802341559001],[-3.77632302181333,4.31689617054256,-6.97783298535876],[2.01468954632706,6.02731645623819,8.271829837885],[1.77325125138072,2.72157703578386,-2.72043174480696],[9.24292161398892,3.60770010222824,-1.8973002015989],[-2.21806430739424,-2.84710372896143,-2.6163911925413],[-4.3744923369958,6.22139702570274,8.51149312219284],[-3.89221376599139,8.3519366889256,8.36433630947514],[0.871886115195516,4.11635503459162,-6.52408042177794],[-7.85042115789815,-6.87376743738791,1.18326026373273],[-1.12424460875209,0.645177840709405,3.16351956850643],[-4.95769676714198,8.20038424586815,-6.66782497654202],[-2.07875000194599,-1.42933202777628,1.93159310676635],[-8.64749382861196,-5.37505168276353,0.829852908240905],[5.20735310588051,1.51199585561223,5.23581956383673],[3.56066908593075,10.394848587432,-1.83764493739141],[-0.24050618972019,0.585616062746113,4.31727697926504],[-3.99866528994182,-1.04762567692263,2.14825589819033],[1.18034208312438,3.5758394541718,-2.86149820667944],[-2.94548077302946,-2.48393664781806,-3.43391453716881],[3.38110133825969,6.38733946619989,8.09962121267511],[-2.50699845501905,4.3325728814586,-6.91006202325845],[-4.70823014342936,-7.0387815830218,-2.5936598104524],[-4.70530864544516,0.41697699784501,2.71684015079404],[3.51462002653683,-7.77530326183909,-2.26867512759461],[-3.82960002518238,-1.87501552456476,-4.39850883514218],[-6.03346398036403,-3.43375783195747,-5.22392801186079],[-6.64762201168606,-0.750713530630967,-4.4465592264445],[-3.73707790949693,0.820332845693906,3.82378077643288],[8.96488983315038,-2.75640544727633,-2.63460492846444],[-3.75172036515721,-2.10863684511105,4.10610389190513],[-3.91132055858227,1.12051028601615,4.84279316387697],[1.25343598276664,0.870423908324519,3.75153536564724],[-6.13955928056803,3.35114540151443,-5.50289697012376],[-5.83526281052644,-4.6897683991845,-3.58997810740884],[-2.7613539976288,-4.80590178597738,-8.66229323077716],[-5.23026315659916,1.95861721414033,4.84551727180422],[1.99471757837113,-4.49478484740527,10.3563816114151],[1.74531386738269,2.26619258056324,0.674934528913115],[2.70106157174215,-7.83746485047331,0.839031267005597],[2.22912974869921,6.62165374143116,7.2118778259124],[-2.56224065144457,4.38299715635413,-2.17388788373524],[2.89055208683718,11.9248407567295,-2.3985018298493],[-2.2992053300275,4.2866125215282,-2.24709675042651],[-5.17938777783628,-6.44907705508248,-10.2274980387494],[-6.89516561853589,3.02056004699891,-5.73135118801372],[-4.58262560963248,0.871667915841013,4.26870006540079],[-5.92824837116029,-0.824301890119624,-0.701978849053126],[-6.7221226313774,-6.00212949687232,7.14533462245822],[-5.28086433989002,1.05788617913845,3.79236610048204],[0.963214924426905,3.19363983220171,-7.0360804823307],[1.79351696332402,6.14420063910139,9.49950588053978],[-5.54960010199735,2.96478883141312,-6.81493937849578],[0.460111030288672,3.9751330907224,-3.334609786545],[0.26208820164812,-2.18483040941867,1.51544294566219],[-2.45837043357627,-3.54277116727792,-0.535200708022095],[-2.35956323134532,6.28099190864479,0.109557515737164],[1.00064204029592,-7.94858352945646,1.56666629803819],[-2.26405711955731,-4.58159793217287,-0.537625332570348],[1.88290515235891,-7.13626327359671,-0.105039388264037],[-0.136666744725256,-0.922558606385619,-11.0062293788534],[-2.80099997178579,-2.97863348373675,-0.242553325639682],[1.05168856721305,2.9624617994924,-7.02257700501029],[-5.37136103984861,9.02494920020038,-3.7561280094956],[-4.2596236579683,5.29360426728694,-0.795429269786038],[-0.144414273233039,-0.778626582103559,-1.69075416453236],[2.5925257527251,6.0986056132826,-11.8925557327498],[-5.36712736428141,1.20885594962496,4.71620352086881],[-2.40512409029424,0.133710478219402,-0.542224922165819],[-4.46666353131424,-2.20247039092307,4.37487034210507],[-5.83471064691463,6.52284262172015,9.03157387022709],[5.81800434022276,2.75381475480744,2.08079703804833],[2.90149112753718,6.06838646503433,7.14162772373768],[-4.40912455699598,-6.41699834545298,-9.94765998499441],[9.16614163379599,2.97863630626746,-1.05728845201084],[1.35244594513047,-2.88067891141558,-7.68830852769627],[1.35643799788469,-5.14827156778797,-1.14361662429829],[1.06400789778317,3.17349198703637,-7.37678608132423],[2.09290201844028,6.46140364302717,9.50570719104608],[1.52608131717281,-5.0148814552015,2.20613132378692],[2.03408401323969,6.33876831101869,7.17100421809],[-5.21339462070916,-0.548950976997973,1.94797304445437],[3.34578891969884,4.67668410722129,8.64353885391632],[1.19665684958057,2.69715779235316,-3.45991714746116],[2.57391109364578,-9.34915814828033,-0.327867623724497],[-2.84526498623015,-3.88157302913466,-2.18172822355425],[-4.02054432281848,0.348196765935386,2.63792900560886],[3.07411478177737,-0.331088385877678,-11.9772544434841],[3.17279215461976,-5.44082579489345,-1.89885231774485],[1.7351440659387,-5.89462689875001,-10.4034749510154],[4.0269846776122,5.57221866294215,8.96904342314136],[-5.09108780763224,1.50675056068836,3.07384723950615],[3.88389977077834,-1.8816720352043,-6.72837034267599],[-4.19090194423358,-5.63859215841591,7.68062689165281],[-3.54871991961186,-6.43306532008086,6.64417030978133],[-2.5157985296208,-3.50036809596963,-9.3562933845061],[9.29191464187426,3.7985220178739,-1.84383679326471],[0.477111076654519,-3.00698403668189,-12.1006069236771],[-2.91081098291802,3.82017894939915,-7.22930802757148],[1.50555112942036,-7.37677712299209,3.34590412182474],[7.70204747724974,-2.90128155373802,-4.7492833287675],[0.107980527697325,-2.69727144967925,11.3887605231974],[2.32277781029933,10.3507559385334,-1.80218362213498],[-5.24023548923713,-6.37445850482792,-2.755482557021],[-5.38394956759231,1.340303573293,4.59062090995058],[-5.06752139498953,-6.05189841436184,-0.804321710917593],[1.85951605675657,-5.03046336597173,0.521390272349894],[-5.55610921894293,1.13241524110645,4.10989895573178],[-6.00129188946004,-3.21108552892435,4.72637589009551],[2.04923518453664,5.86330045886146,8.25015522442384],[-4.89482712242922,1.33041338184315,2.83965521672687],[3.12475378878492,6.11034630060291,7.23785863982906],[-3.75376227049946,11.9577857762173,3.86143118145658],[1.30036012684952,10.6773536335545,-2.03541901101339],[9.16512352792367,1.69797491195855,-1.88974809844832],[-1.79406145649974,6.58897599339285,-0.903546865406899],[-3.90603726552245,5.95638378382599,0.44412984191721],[3.16989931284826,11.7183077138984,-1.76545741225532],[-6.15775568956663,2.67698099134725,-6.10874883481284],[9.88881606199161,-4.85280067752802,-5.3523206386994],[-5.92707170246652,-3.07132686106236,4.73230718865753],[2.29705058507343,10.7005049457651,-3.12039824982912],[-4.05132690500217,0.854193207497407,3.46797454253074],[5.79321372234864,-0.332174578122697,-9.88321087218404],[-4.31464841266828,1.3896675283165,5.37796276026019],[1.87558314042807,-5.44292092817854,2.64371380305439],[-5.37792654945185,-4.96215439498557,-1.64100228953643],[4.13380116158487,3.3796552745212,2.57301439691154],[12.4106354491339,4.85570752140792,-0.876112810550291],[10.0074056294904,-1.22765721523882,-0.499191938580358],[-9.60436502155419,1.09818745465824,-6.20614677332572],[2.13243208737057,0.214579192381364,3.14131481212274],[2.17065790745675,-10.1950423061077,-0.167451527340599],[-0.0825714578779816,-2.7756069995476,10.5736658249278],[2.24158443610014,5.69815606852383,7.32609033095498],[3.95393345522462,-4.57828366830949,-1.4106010848782],[-3.38483118494761,-4.2997189810069,-1.05967011315195],[0.242427075501941,-3.02514177258753,11.9623174802774],[-5.75328584876905,6.980144952323,8.41666722410807],[3.00815639734015,0.310004362842853,-11.3967475488047],[1.23246612601811,0.63411160848595,3.78615448931285],[-4.79050842883827,-6.71355450417242,-10.0432692527618],[0.523377497277083,-3.00351152032275,-11.9284427177965],[-9.21603806328141,-1.3799672658103,-3.72865836868979],[-2.74305079151321,4.60149633435617,-7.72469174197756],[-2.74710117063973,-4.09007791523755,6.78261777733214],[1.17177111158307,-4.77666842869095,-2.15549435499044],[-3.7350895631007,-0.787710793226053,2.53333190259001],[-5.71225592371464,8.47972924696852,7.69301691021865],[-7.62198975023921,-0.0209456107709378,-8.62549873445897],[2.94598764482402,11.8981805930103,-2.79387492464372],[11.0888406737989,-1.8227876950127,-1.33735161953277],[-4.84188307826444,-6.9144870684211,-9.58678041505815],[2.86665003670504,3.64835975228121,8.41538830532285],[9.98427981403263,4.8538701016588,-1.53774739220971],[1.55356470737993,1.81362909518047,-9.30550777076292],[1.03375495870993,-2.3653533357668,-11.0884850752978],[8.95962603388812,0.211108555334879,-1.18032729481248],[1.24693984362049,1.77995510658761,-2.47243738049792],[0.00709136586740311,-1.54894268539997,-13.3744588219767],[1.21884642599668,0.0428030469691546,3.23401324524909],[-4.26005623444492,1.10301610121978,2.35909957962053],[-2.8476088558934,4.25743271840695,-7.01674501907098],[-6.0087464122885,-5.49367941446541,-0.563213639213847],[-4.591575777293,-0.506381903772306,2.81475945734579],[2.29350565132075,-7.66097444010688,-0.256895009258134],[1.14447301605196,-4.7090740187478,3.83810957007924],[8.87882834860773,-2.0720040997653,-3.44016408870155],[-4.0662077286635,-3.91376916680918,-1.19712167947371],[-8.83921237137129,-0.579763252885896,-5.12507684270197],[4.37180171786834,5.3788468384537,2.98527669289599],[-7.02350509685006,8.65107536189081,-4.09539510312423],[2.06657788773481,-5.26106371880855,-0.346650742776778],[-9.41710706042899,-1.48751981009885,-4.30791885740252],[2.08593221069634,2.50733468885818,0.780944188839977],[-4.86599955288162,7.45022881915998,7.90856588912316],[1.6615983462486,-8.96651560760064,2.18988027993303],[-4.52438173569134,0.709851019336991,2.74770685266252],[2.06250693703134,-7.43000393103763,-1.47550801393218],[-5.15556482123483,-5.97296036497493,-2.12196295397595],[-4.98929450296786,-0.215041912804307,-1.81455777278124],[-2.65498870500245,-4.35939595627999,-1.04495429809411],[2.27450280719489,-9.78087777794871,-1.10610629013624],[0.550558059170366,-6.04408750900738,1.95430411992508],[-4.46356286662174,-5.02086237444318,-2.04975402709721],[-5.18373156491518,0.992112065748088,3.1114560822885],[0.96168676918421,-9.63369852805576,1.56950798713904],[-1.09834485391689,4.79791051871974,-1.43283190303453],[-6.09674337571784,-2.67095126047987,-5.33410330132816],[9.51478220478017,-4.68512342170693,-5.20996935527112],[-1.86844961526716,-0.590399361128449,-4.92801541067635],[0.505194379198947,0.593403567085778,3.17569858482042],[3.35660692092536,6.34469149491817,8.95914072021781],[1.79272516970728,3.96809031239145,-6.42101974365461],[8.44018937862051,-4.35569382390553,-1.12841446366552],[-0.20296191903488,-6.26856776092822,2.0043149862542],[0.0163128029511771,-2.86693968394695,-0.968377720296067],[2.33085630955846,3.77580916501731,-6.15832809431654],[2.58054788357504,10.4031990295833,-1.76774652418647],[3.23098149428192,-9.11878559146324,-1.01542160296148],[-2.89790875988947,-0.990875866481353,3.57270169251962],[-4.72062048134036,-5.93062639925276,-2.56852888869879],[2.49350864639233,6.20065092450209,6.78332022426523],[4.27824978968672,-7.71367332130546,-1.2366195032403],[2.56025868093992,6.11507955355492,-11.7371451092288],[3.19557943829678,-10.0359063899455,-0.788925603341166],[8.95196614109192,3.64266247917726,-0.913662613917541],[1.06859654987216,12.2102545388884,-1.66906763310154],[3.90598609736175,-0.684458199141516,-2.54724825823106],[11.817813082309,1.05227399469529,-0.936833852614054],[-5.54494860100662,-3.34068526434654,-5.15966760247328],[-9.42596909676999,-0.338349049432224,-5.05386799781346],[2.55591129787323,11.7874163694165,-1.71820307356676],[-4.85119257045777,-7.13418332445632,-9.79573608564808],[0.473548525954228,-3.41238761206532,12.7137404772142],[1.60954433694322,12.4877196721645,-1.48133318371985],[3.54120930681839,11.687063121332,-3.08280501811927],[1.71996203476727,1.25253612488889,-5.4311032757119],[3.91111041596829,-8.54715643303807,0.132569317717727],[0.686154832752501,2.75981435416644,-6.80537850788079],[-3.79177528957648,6.84046061883994,-1.01739091979993],[1.6081323810417,-2.4170577703805,11.0317001917862],[-2.74128740398362,2.56613337566324,-7.11453629091053],[-0.135112844008319,0.998045911677732,-7.8012349114071],[1.24064911337503,-8.39191253639996,0.743467869126299],[-2.38745107190654,-3.28105194294917,0.0900501702888942],[-5.38600610833612,-6.23650028751001,7.66272066834389],[-0.122040958779491,-6.66189881041733,-5.93959034632211],[3.97205481728995,5.82054431487878,8.45354421320647],[3.97211409087786,6.00148571375076,8.40102076714857],[-4.49026650449508,0.677602730670057,5.3527165788312],[1.37631459954715,-7.65072724833767,3.67449950379848],[2.56305525074447,-8.00004193985834,2.97284030903792],[2.39597846072183,3.78149631970829,-6.08485348243505],[-6.20137378779257,6.99471650432482,8.55794091497756],[-5.90770621965762,8.16460233407592,8.38435272836898],[0.688705805585132,-4.00729810188396,-2.22784826713629],[-5.17561753355447,-6.99513682576915,-2.36153446276843],[-3.58263561993521,-4.17580039868783,-9.5357104920541],[-2.57966263671192,4.36734750486061,-2.01091781357326],[-2.05655153345944,-6.26499022307325,-1.18247113189457],[-0.0883191790955965,-0.553525181962589,-0.364716957552986],[-4.99513674912911,-1.84490443738324,-0.99944470369225],[0.469841046719573,-8.0035047700506,0.492579979512125],[-3.80086066419956,2.05378687135382,4.38943680900261],[5.31401852592711,2.7807871728465,2.02914252335355],[1.46793432934316,-2.39871750883281,12.7778531324685],[-2.08655706491451,5.55555546753324,-2.84785773691586],[3.63509801632833,-0.0426751782237165,-10.0708428549504],[1.35507561781901,-3.68222865173104,12.7660523282439],[-4.35710544230413,1.82725039594473,4.44962930991037],[-2.65260124465649,-0.459922644038265,1.52676260458776],[-4.98316109966004,6.64896488831823,8.25406962038304],[2.01625611827569,6.19798045902258,-11.5311547225207],[-2.67582947582423,0.257807358253038,-0.372377746000086],[-8.48842986308008,-5.4855615187147,0.546156550379373],[-3.57291292784566,6.08631575177291,-1.13142263123338],[-1.44130301251381,-2.58568677336943,9.54790981139173],[9.64419016325207,-4.20841304121874,-5.75617592349889],[-1.31005587586486,3.41814390927167,-2.16675827109898],[4.06221643919439,-8.43865870634189,-0.300237409822527],[3.07302233203088,-9.57372411008221,-1.27823960284447],[-5.75340301346081,-5.97257852384704,-1.3529855778356],[-4.58630650451227,-5.8126581244665,8.10532960603863],[1.71261869905903,-6.10584216351398,-10.391689123751],[7.73651404432964,5.49019503949589,2.03591140471083],[-4.81727345194223,4.11732503301835,-6.28502632305659],[0.0465360705223749,4.6727490959129,-2.58381082215489],[-1.82812611482329,-1.80241881469746,-4.23982037460385],[-2.04263120953703,-0.758699967766062,2.71249591407772],[-5.75200431237017,6.94501697634324,8.15361986795681],[-4.40962884323785,1.75262262704329,3.64220792111446],[-5.18057100725419,1.5504142920758,3.46004634721717],[-2.77529167715665,2.3933764851903,-5.31585108745625],[5.78668701190238,-0.341157293459721,-9.90099931690205],[8.82467494022472,-2.18902151178045,-2.87992571199151],[-2.85914513588848,0.639946620495006,4.08865337017888],[-4.14904925683025,-5.27756125355476,-9.78447978594273],[0.267923682186541,0.386651465974934,-3.24893462410529],[1.52500886024171,-2.67520253288963,-7.6640355613345],[-2.93516207378669,5.36009974068641,-2.74905359325967],[8.6271413836187,3.32628763507099,-2.08547037116068],[-4.7235460979048,8.96036174936539,-7.91406823735296],[-8.22007488223814,-6.33470743699116,0.522828085541333],[6.48506020911193,-0.992678111530106,-10.1862517689681],[0.288618427581092,-8.18668052237125,1.18105265571856],[2.74530551063751,0.0749102995850892,-12.3189251033453],[1.73990936562548,2.71701837451216,-2.40758922528109],[-5.68337039755968,-6.12184237164249,-1.99023986607631],[0.617322957616325,-6.15596986889162,1.72097876231696],[-3.27858061713664,-3.82723684026375,-3.19313740712201],[-4.66715420602157,-6.27730715220697,-2.62225083178555],[1.0323018428471,-2.69015659609287,11.9796060151299],[4.50508735587595,1.72718355793703,-9.65046762522352],[1.47677629694074,-7.56609389315806,-10.4905530550281],[-6.66978587771126,3.45901643578906,-4.38137088358429],[0.144670688014568,-1.7960905655571,-12.9342266042555],[2.57529212463613,-4.57754684506216,10.4310717572161],[-8.83032681589797,-0.926973771039993,-4.93774836319375],[-0.569174631299979,-2.72369930837223,10.0513606636476],[1.70029351902974,-2.86285339082051,-7.92487184296069],[-2.368343927608,0.0823743877587826,-0.46089441950068],[-0.294544681198501,-1.91250678789249,-11.5322521824146],[1.99283904710788,3.74215480794571,8.4761710088296],[9.82582395856198,3.45922844898786,-2.96520705609321],[4.35639317254441,11.5409833300685,-1.22356176314648],[-4.63902400120918,0.443546781187095,4.53960317956186],[-5.65515593667186,-3.05453788975284,-4.98701237523129],[-1.48408604069453,7.24606429908712,-7.23451228466566],[2.27716078295831,11.0524883363828,-2.05745745516387],[9.65091212837294,2.2177051103644,-1.8747434734253],[4.78946650957391,-1.82082589883544,-6.73959051548021],[-5.45206271420979,0.0904413037470677,-1.19071617258812],[-4.05708303501373,-2.24549290114447,-1.40493987402633],[2.52754587672192,-9.92331414400757,-1.47267920961002],[1.49581672519504,6.21925047421963,7.12255315410466],[-7.33824009633574,0.542740164871141,-8.04665090685162],[-2.32915859950046,6.8475727566323,0.0410678942270101],[-3.59356153743009,4.69068961810641,-2.72275518881771],[-5.22631312607849,-2.93415759667591,-3.86602481052303],[-4.71437359006114,8.14828303166605,8.30133132778403],[1.66191468864514,-4.22734413200486,12.7896544192542],[3.28390029316149,10.2712575903276,-1.6543848852591],[11.2262618063573,0.605984096790058,-1.01782792647613],[4.09706868307818,4.32811906890176,9.07885063050735],[-5.44383712039648,-3.48027282489934,-4.93406529150353],[2.65571740055752,6.16135566502467,9.57335473427933],[3.57659275957218,3.7189162757092,0.272029291850672],[-4.52129233323504,-6.80106451773041,-1.75698076748545],[3.31481265413795,6.28372616352059,6.81464389684931],[-0.622178013772333,10.0128581687055,2.95713808480835],[-5.3839842103812,-1.14145901641505,1.83051167898855],[-2.34525215080705,-0.661489928760041,-3.95234577165567],[2.36485997556451,10.994738676184,-1.98142178059447],[-1.29896801721778,-7.1546345547099,-0.597943453994183],[-7.1301021738101,2.98162483114925,-5.04932556864376],[-2.06594691306053,-0.824687872632515,1.259460477387],[0.0407692629643286,-3.16825755273306,-0.966309532504511],[-3.48070374579421,-0.805453829816321,2.6096889378474],[1.1622748083221,12.1109670149574,-1.58807932270659],[4.4111933603865,-1.40034210840518,-11.1658576041876],[0.977173233143095,3.10973120333308,-7.25802521467665],[9.63922699596317,0.639116138103605,-1.28945178261961],[-1.54722911560358,-6.46321965542226,-1.66425322337936],[0.161334624176859,-2.67863527798611,11.3007799541971],[3.15971539093724,0.269720407107111,-9.15681181005196],[0.966213104127006,0.718552823574225,3.92607654263327],[-4.16576719821063,5.89332925625492,-0.83147027127047],[2.22439197136312,10.4958431708409,-3.11823657291543],[0.853824586842079,5.34618798277455,8.03278254534206],[3.43848803148871,9.96839203540805,-1.61281226129235],[2.21696771871729,11.2918625545524,-3.22955484463101],[-6.630295867486,3.08550995704181,-4.02763414487991],[-4.25541746714443,8.18700903333403,8.28315479679023],[-2.08896621465153,-3.58303997934695,-0.499518092563654],[-3.30312694560599,5.84994419194927,-1.83381193559516],[0.783789826357876,-9.12206913964154,2.37510925302564],[9.41946168845843,4.09414022842995,-1.96332089877108],[-1.99708263216392,-0.591955797559825,-4.65990934379631],[0.0447850460358743,-8.40179288474174,0.979171195369326],[-0.0863279509460049,-0.29920572198351,-1.56982955738925],[5.25522133146136,-3.03400212254874,-3.86057529932334],[1.27747035953518,-4.05904559550554,-2.56431014535796],[-3.5250167125747,7.9817249879545,8.64455307157233],[-5.35229120521553,0.723446527902784,5.11301634859657],[-0.57306858549376,1.40019081266471,-2.3475842676246],[0.800029061435913,-5.92406909848276,1.07180394293421],[-0.15783444691032,-2.96864697081124,2.27497300229268],[-6.16411238272977,-3.31052135419369,-4.83635262219593],[-0.130397747609566,-6.39201631695857,-5.77207224737729],[-1.6699433741847,-6.62997988838018,-0.600724937912372],[1.15801109305644,2.07220253501017,-2.70066198174801],[-2.87006681786735,-2.17062560749725,-4.7066852769571],[2.33603369107859,-7.43597780382531,3.58568659566161],[1.03346863545943,-7.61567071611015,3.95460812670439],[-4.15624518583329,-6.92830992174668,-2.09281013094639],[3.96580133192875,5.75653050384596,8.0492787113225],[1.78958895549556,-6.76790299620957,0.712566832092413],[-1.804053248265,-1.01280601495702,-1.94749304048057],[-3.26196572815501,0.586531538877218,4.03659813214235],[8.8438388053745,-4.352680495177,-2.0176232864532],[0.417364324916855,-6.18459672915865,4.01359531893038],[0.954001529952953,-4.33111480771432,-1.79666232445911],[-1.59211722824137,-7.06824882845744,-0.994969190431676],[0.699578515333794,7.21166417759458,-6.13934216108358],[-4.94877041065568,-0.933820000262525,3.43503922055088],[0.430209266415712,-6.03806182533084,4.1125222199891],[-5.12464833294231,-6.24696671320355,7.73102263761527],[-3.66733966549046,0.715099695138018,5.25503417500462],[-3.46712909962317,5.63933985478522,-2.21187651278008],[10.3112835127907,-1.25265942027036,1.06575679127107],[-2.05075410357098,0.897830863138635,2.75540019497184],[-3.36211970763139,0.533097776254171,3.38971721323244],[-3.52306583525848,-5.34865850047543,-1.60846105878067],[-4.90127329864456,1.55958687120022,3.58215037245401],[4.71579972973492,1.35685792185949,-9.53908514105696],[-0.706865410981064,6.29805254687428,-8.53879303744836],[-5.28577749282284,-0.467094052258376,-1.62864683136559],[3.74038897959686,5.46179149206575,8.39163947576038],[3.28445085180902,-3.61056948369863,11.0105579618967],[-5.15634753442793,1.51750459645249,4.96062123458142],[-0.867966301623083,-7.60261443556988,-5.51197696171137],[-1.88346034232668,-3.66940023921563,-0.288267451066958],[2.82766173572144,0.071309367936345,-12.4230316064642],[-5.21718609211639,-2.87104656288407,-3.76691260690654],[1.55720819353102,6.36599910934277,-11.6247951641074],[-5.09885820633004,-2.92416046516884,-3.77711944263514],[4.08955984918136,5.99327566159892,7.80827000354249],[-2.79981059514362,-1.62798317657643,-4.35420748641357],[3.07718305703423,5.75491444654843,9.30848425257992],[1.97119663828691,5.7749372881757,6.10841415884187],[-3.95826138236499,1.99933362120907,4.17209681542079],[-4.78123085259029,-4.31654250450139,-1.26281413393878],[3.99372668041571,10.8730034322527,-2.37011974038788],[9.26382202052314,-3.88438544460126,-4.47668089829223],[-0.826503271585634,4.72800377409374,-1.55150197107755],[-0.363999395348655,-7.65189919365247,0.699798342638519],[2.53565528741182,-8.25854152685913,3.23446722525672],[-1.72743673198351,-2.36921301065601,-12.0668337009792],[-2.90585148871543,-0.791690754186392,3.49354344507227],[-3.44963899857712,1.59631458815264,3.22893852068807],[4.05195888110035,4.91510434434833,2.31559791739205],[-2.19990673105365,-3.17168648186907,-0.117577383900838],[-5.03836068165307,6.49790752508086,9.00048162856611],[7.90445054055287,-2.89795991609116,-4.9074067681939],[-1.25291806271821,7.24071424759897,-6.26088039020692],[-5.50383650588895,3.87859238202896,-5.80027054652022],[1.45485386712615,3.85345457111464,-4.03456764703017],[-0.84243490375518,6.59321746079141,8.82889493391092],[7.02566021924387,4.7410820553249,-0.677528618269284],[1.65519079308641,-6.70917083106721,0.708566745626435],[3.00152466107441,5.28418525035683,8.11846802005648],[-3.70866552682206,-2.3749579224839,-2.10353065370748],[-3.66427032531474,1.21930392922631,3.36665370300575],[7.57562391883589,5.23780862602738,-0.319709273145308],[2.07543148184495,-8.80362203366395,-0.255350877629048],[1.09769514244153,12.3270301103754,-1.28260740596125],[1.76548350794949,-10.2082161519094,1.16083375838932],[-4.99923170529138,1.42971542256004,4.28529606763236],[-3.9526225660234,1.11580109435003,5.34845056087514],[-1.45975216637377,6.55821439549354,8.69047229711882],[0.336385200873358,0.222203325481741,-7.37703022392996],[2.74472049063958,-6.02811070908318,4.61029754536422],[-1.99217573662223,5.04215054088891,-2.64371376646751],[1.9538854860245,3.9638857323054,7.90838780812373],[-1.67159855003842,-1.5853895112161,-8.41418538807065],[-7.59740100790286,-6.45227382132589,1.36575346302978],[-4.93221381244306,-6.63561272017389,-10.0743315306988],[-4.97741944408791,-6.7064385311768,-10.0043570299464],[1.41464827219659,-2.93263297464168,12.1027551831831],[1.10211163562345,-5.80115982252262,3.23417561519353],[4.48641801517566,-5.93620867508926,-1.7947385876651],[-7.5544966653316,-5.5313047926266,1.91981217464751],[-2.73472649790896,-0.178851885170349,-5.02853164069677],[-2.55447959077907,-5.03870875520751,-8.53316825460534],[-5.22142168752669,-1.43051910661961,-0.889347604626615],[12.1706292379425,1.72659936370853,-0.935110836997071],[3.80318094810991,-3.13653851293796,-6.64380733719886],[-4.06946665977644,5.48521064484252,-1.88041058341139],[2.75595498350753,-7.12047377474802,-1.09162559918415],[0.192803020761083,0.99372889544481,-8.07503392912577],[-6.5666329688257,2.52646757349847,-4.16458549076289],[2.42505487325426,10.5266700971273,-3.1896093416197],[-0.314078215088176,-5.51852298549261,2.12341612996618],[-0.0185249865195219,0.197940791835715,-2.65521358970136],[-4.22173581538983,2.9412907997048,5.12662329842079],[2.67117932670996,5.76135146801688,7.53068825407567],[0.75078185214059,-2.86717200132393,-11.6926162662908],[3.44204990779648,4.68744088232703,8.40799633324482],[5.20512488722021,-2.09405172867962,-6.80384288123727],[-1.57572100844571,-7.25397092938412,1.30212022264983],[2.11956602325027,11.0545179325031,-2.72611949982544],[-4.7601340938449,-5.05937740341524,-2.7103669913122],[1.83131526523026,-9.1961119245727,0.597104787104691],[-2.93792616897487,-2.06557079810215,-4.5178045060577],[1.6533447485371,3.86354765732919,-5.87158708639433],[-6.38346409480161,2.8961309406879,-5.75202767327668],[3.32343666918338,6.45424055587771,8.80919278807181],[0.270670717513826,-6.56043888689,-1.36501677323376],[2.08424631032133,-4.34515694732161,11.5306309242249],[2.54814172384597,5.28245716289175,8.65850727825504],[-6.20265119189476,-5.71774499519738,7.4882413952518],[-4.89796958945938,-7.1646794650907,-1.97495091500284],[-1.71641120918085,-7.86691410690826,-5.38261334086381],[0.97187037171229,-5.0157340922569,4.70285872360368],[-3.07966187772947,-3.85011402913721,-8.8125486185331],[9.58849462450486,5.46857252002841,-1.24906250562343],[1.17778039401205,-5.41395809909525,10.7910518871718],[1.24816621528786,-4.66993939349157,-5.28253481942173],[2.48980436920215,-5.64173921427099,4.63704462844091],[8.72995517435064,-3.8581064465279,-1.14263150389152],[-2.77790622542938,-1.7573739739043,1.69078631696667],[3.7876238361936,3.46905736300113,1.92593939793406],[3.15523376660036,-8.31867625504647,-1.42719836460874],[-0.0704885817154347,-6.74893105702305,-6.07373812621667],[9.01955173692145,-4.31362229081433,-1.85518827628134],[11.4752422740337,3.72420576022295,-1.92997053486576],[-2.61691623723782,-3.42429947497305,-9.34035550653375],[1.83580918384481,-6.0274990581049,1.77756785445284],[2.8795188133711,-7.89110689024062,-1.32358562023358],[3.09047978259054,11.6197723107308,-1.66512358545471],[2.90306321905232,-9.82267283858538,-0.479584430761288],[1.96061719043347,-8.72692226947845,1.98400932209193],[0.278934056918059,-1.5045474338009,-13.4674628565406],[-3.15834367321625,5.01530563452197,-0.21975065769429],[3.70881047812136,-5.19009526838692,-5.40719592752898],[2.84371516807661,6.55222668468451,8.46172033063464],[4.4766461175448,-5.32594007446039,-2.79422913754892],[-4.56568459553714,-1.88616704496302,-4.60509314485034],[1.12199691033807,-5.73749823030489,4.42433444681061],[-4.80726574930908,1.41629950925595,2.95156257694453],[-6.4723984402279,7.23418315814834,8.1363994578805],[5.48244349506223,-2.64755570229256,-3.65189813887981],[0.922781896854022,-6.85484083566627,-0.160004633542634],[0.533915712533516,-7.90262460376847,0.837591206939966],[-6.77784420642833,2.99790556713165,-5.19662924088885],[8.24155003412247,5.17820179999903,-1.47456543929385],[-2.35517495266083,3.84778687455081,-2.58922827442279],[6.55540580610854,4.41338254901647,0.68508292861181],[12.3902619080414,1.59107081297773,-1.03660353893646],[-3.98113836083911,0.129174270465364,2.95370885581107],[-6.09131582488993,-5.67495800956199,7.30654015532387],[3.37878060732715,6.06219895839897,7.34925591351396],[-6.75732653987904,-6.92781888440628,1.14685085458414],[3.28415953096531,-8.40968761214377,-0.228932218817177],[1.32087530707431,3.31392129512308,-3.52914673426862],[0.814981185580717,0.819647376974918,3.8791598272029],[4.40116324807743,6.00702750815966,8.75716349487676],[-5.89398217661777,7.41408268893602,8.42086621370268],[-1.82581583662132,0.592167176338425,2.96846337788786],[10.8505728740053,0.725139349496512,-0.961422439898594],[-5.39634224723909,-2.88555667422368,-9.29695754689322],[1.8037794820138,-5.09812219715414,3.18982068035813],[-1.80679203593727,-0.361473323370511,3.01573057042872],[-5.90723065328425,7.57993892380748,8.31750949990984],[0.93480518766453,-9.0012190971725,2.09977329035215],[2.9076681752507,-2.62358654644638,-7.03514737017955],[3.58890369343604,-8.5795671064025,-1.42081924696199],[-2.78097298835941,9.81165135523469,-5.87119233303898],[-2.10877665133617,6.92910677342752,-1.40805998572611],[-5.47546945909607,-6.43859711770168,-1.41574177514461],[0.136188997386449,-5.07809247688418,-1.12472270592842],[9.22036227691023,-3.9937705539807,-5.24726234004897],[2.66461432590787,-7.69045194125023,3.79430323479832],[3.89290036435361,10.141391783474,-0.518883318862863],[-1.41518473856799,-3.21250700647064,-1.81474785204916],[9.05271048039414,1.80259556879338,1.46584849844079],[-3.48011930893464,0.332361048806794,3.95687964341167],[1.66709921743816,6.13931734324812,8.50417259368406],[-3.48854988836954,-1.0379839086188,2.23759977780807],[3.72089480779447,-0.919681871944738,-3.85643490960418],[-4.17727219010031,1.36134205878874,3.69540748650754],[2.23768925218706,-8.51670274641824,2.44113872300576],[-3.9220260345046,12.0389887045446,3.93459777732864],[0.0647217313212709,1.27036732130737,-5.37644471114474],[-0.0262351975331254,1.0341796574037,-6.67387244394157],[2.61411956762355,3.31166558514704,7.83065498738664],[8.58340592697584,4.07380885876009,-1.91294667658924],[3.69630788252033,-7.41161704171134,-1.96477739163182],[2.60379643063931,-4.92140778947426,2.30932815725022],[-4.81940504209575,-6.12447584449266,-2.76946178731743],[-3.97012922464497,-5.57576655497584,-2.06314239954708],[2.52120465814815,-2.96517904951723,9.57605143228502],[2.93380440423825,4.34035893203606,8.75862525051325],[-1.65732000402441,-0.672355085564019,-0.783815943919054],[-9.66955670693056,1.03859457671376,-5.81661975774444],[-2.36750904133532,-4.646753728274,-0.660152000673179],[-0.298362977377223,10.0016752311616,2.75629559558609],[1.41938803532685,6.28102297347194,8.95475509987896],[3.15887493989923,-0.0781121211999236,-11.6277196937323],[1.95289946656921,1.70565440660492,-10.2029097668477],[0.0512775488062784,3.18021651942155,-8.4596091003988],[5.10525093642257,1.4338882576056,6.22925146698352],[2.8828477653691,5.30178620525586,8.53143761818288],[-3.24850345268755,1.52026677587645,-1.85854007699907],[0.98535274159521,-9.30340443956878,1.67938366420333],[1.0263432612924,-3.23185601261204,13.1497384717295],[-8.43937466599677,-0.415865586013244,-4.40073775469635],[-8.51331730370519,-5.51230792290292,0.563345920732484],[-3.64633827618344,10.2312357211321,-6.44758982311807],[-6.79500006957541,-0.9639505891867,-4.32125096866621],[-1.85759355852392,6.0784315347201,-1.63970843530604],[2.55162990854715,6.62072281735237,7.1412746013881],[1.81147225879525,11.2910611969256,-2.78642475619229],[-1.54056541968284,-6.69028134218375,-0.667606644443342],[-3.97753721795026,5.06164057785432,-2.57131557123411],[0.890582924701415,-5.07335891751606,4.68215756850192],[3.42176162804326,-5.89585113804772,-4.75030778431513],[-2.95924371136145,-3.10970728315116,-7.08953407491909],[-6.40964182255317,8.40438171005183,-3.89007925495497],[-3.92099016182569,0.688871412650922,4.36738078816668],[3.13780355528881,0.719320515542721,-8.80514693608494],[2.58283491314221,-8.70980630436266,-0.649371091855307],[2.4651980698957,-9.12276747437617,1.27685965173544],[2.93458857694048,10.980448104551,-1.18106309294825],[8.72710409751332,2.21527378263729,-1.79086427166527],[2.19626721089669,1.02701334139956,-8.7519503933078],[-0.354035830284655,-2.95934778349685,-1.07620714496246],[-3.56234550448866,0.276047850684619,1.73024514974933],[-5.10423831113683,-4.63131818197508,-1.69993458472121],[6.63939123471473,-1.0299554632532,-10.3624650186036],[2.18962785419481,6.03669188291069,6.24194889501782],[3.34360201758288,-3.58151151113313,11.8222989946358],[-6.32791002308126,10.8650673117217,-4.29096219305942],[-4.07782438364492,-0.327443842620629,3.56182546086707],[4.07314832088244,2.51852839148069,3.17026268579946],[3.93530938627331,-8.8577729867694,-0.40516821609977],[11.4267935749164,1.3418582480317,-1.32985391167764],[0.609653998558039,-4.13622759303686,-1.51613560452013],[3.57803148260666,-3.6857863943454,11.5353766129629],[-7.29169059432137,-5.75721336840066,6.95328241237707],[-1.24643920401659,10.3742733025608,3.49485092098322],[3.46661382747985,-5.84966065571289,-4.56241432796678],[4.30073381377041,-5.08526599034037,-1.64528246701325],[2.88647377574615,-9.68866278737192,-1.14750760733432],[0.854396087261516,-4.66462416593231,3.80806458911207],[1.56796716701142,-6.73849129578188,3.9803230133603],[-0.215303220716071,-6.13343946569973,2.51015252385778],[-5.18533858163085,-6.52654714932563,-1.71716161671358],[-4.5527911238903,9.11319153832164,-7.58877762317579],[-4.65076072021502,0.939409209181781,3.91731815596211],[-3.98638113841254,0.86541225938138,4.72538016799726],[-5.47147268734072,7.00955774928159,8.42724020577114],[1.52443470417075,-3.59793287654424,12.9108911004095],[2.3936895360363,5.85938800231197,7.20472225394567],[-2.15142502578493,-4.09836727590497,0.130266273139022],[2.45833896469636,-0.0929857168461625,-9.88057393988568],[-2.01429257361778,4.53056808144497,-7.53151454985777],[3.05823344420133,5.44646897747486,8.03785921359369],[1.23562583071448,3.41381498069737,-6.78688040300736],[-0.761529281769315,1.9478459660675,-1.39389806814262],[-6.16754493760604,-3.39285437652824,-5.1606749258257],[1.79214097729301,12.1394294878404,-1.54306382496394],[0.944538602238201,0.408169897054728,4.19968573114315],[2.87591913731211,1.11771077430824,-8.36510420923049],[3.06925421515201,-6.04298201199882,-1.06606359728888],[-9.05678418839941,-1.84424464555701,-3.6221809921706],[-7.06520831344077,2.67459432168832,-4.87415353326915],[-8.68710966364883,-5.79122256266969,0.878891711491603],[2.36675438472846,3.94476659573888,8.70414380095433],[-0.211216066743132,-1.00885988616017,-11.129371968849],[9.84217986826972,5.59968527811024,-1.38257235329849],[9.63021415460284,-4.72671256944092,-3.95146954273748],[8.32666122127701,6.44963449951066,2.08394741521279],[-8.64300949809045,-0.90392265430217,-4.19669976930112],[-4.50463661160178,5.45569197596979,-0.609146011153044],[-3.15634536559332,4.14318572317939,-7.44225422117659],[-7.79932402923616,-6.18483809001644,-0.261813445098648],[8.89373971225464,4.2777493329109,-2.40599665418438],[9.15690180798334,3.26499318149173,-0.590710576416698],[1.34500227313937,-8.86135301483269,1.27683454585565],[1.78385037147021,-6.54261016447488,-10.3651759497148],[2.87083342323472,11.4264825415481,-2.9161239909718],[10.3321447121658,3.32065917493811,-2.00814893833747],[4.23591219490952,1.87829545836604,-9.34934609183133],[4.29482112622656,5.47467138868045,9.01917442495945],[2.38432941672694,-4.97950003506714,10.9435671067203],[-4.27705362878964,-0.222635781149236,0.477771936222605],[-0.448013082808523,-8.42213576927886,1.26119693911027],[-4.76996950983181,-5.27681588716417,-1.29415006581865],[-2.75070299298067,-1.04944012365382,3.55729339086837],[-6.20558323071189,-2.90498901561033,-4.80947165750972],[-6.48562946698667,2.96490632305977,-3.60732171958499],[1.09690262232348,-8.05967200691526,3.26484619732356],[0.835206523384706,5.43164645597729,8.18235933207595],[-5.31584404960095,-1.08126992945045,1.55636522237868],[-4.43566508388457,-0.497634434459707,2.18063308176939],[-3.22219738063752,-4.09609506073518,-0.699807014956859],[-4.80734391150609,-3.87626376994949,-1.73606810929959],[3.2999824562431,6.29607419755989,7.64227090423889],[1.91680675055719,5.97623845218054,8.83030333201609],[2.11250593565822,5.54766057812484,7.2247986139432],[-5.56541489067259,-0.760744698066439,-1.6448486451197],[-4.16653005159762,-4.84863446112522,-1.46071818410525],[2.54834692565513,9.8885066228497,-2.15849513808645],[-1.15318755778982,-6.99020777384684,-0.964585453793977],[-2.24938121207943,8.09966520959245,-6.48946268145861],[2.05671012560858,6.41274971530099,7.41786565139323],[7.33991598309205,-1.36945802053041,-10.5730324036769],[2.96715258216459,-4.96474255885825,-0.924706519372561],[-2.85263316213798,-2.54748606562281,-3.18401624500795],[0.38130979768507,-6.51581057031159,2.51167837288479],[6.87644122822427,5.04938690932662,0.104833274248877],[4.22996187647307,10.7765581455436,-1.12565567865573],[1.80729653157246,-7.9055024748902,-10.7518049430734],[3.84557212391782,11.4527298708946,-1.93961931308837],[-5.94305420091521,2.76004334614999,-4.06202019564911],[8.39211829305468,2.95028445739913,-2.56975947722848],[-0.0485119156358829,-2.60987872978818,-9.61233843902856],[1.67819357946483,1.92815185642864,-4.4504413049361],[2.08830826264099,6.32379483328665,6.8761658608448],[2.49147530843099,6.38318508496554,-12.0669897831255],[8.06178342937823,4.42677564386603,-0.369025937397102],[2.54004676642473,10.0227393930615,-1.88522126676106],[2.05398500940476,-4.38180625904338,12.0971339766031],[0.925354543361511,2.20137247656452,-2.86696881730016],[-5.25987186869309,-6.12277839169141,-9.81164890733603],[8.61214516655183,-3.33444637802862,-4.61315830720014],[9.69172792863799,-4.47487196057985,-5.85723840610315],[4.45466077139501,5.35563856264046,8.96265153622655],[-2.03374960980504,6.50036011336569,-1.28640349252495],[1.89329759962022,-7.92303543474201,3.35368261966106],[2.2948593902139,-7.30056073491762,-1.42676298791586],[-1.2483445006547,5.1468287997217,-0.151322531974362],[-4.54365018659375,-7.2773029356039,-2.53679618442088],[-7.01038136422712,-0.706741598906419,-4.39662266425286],[11.5543678569314,0.0925239493940798,-0.0573704092494666],[-0.000333979372002302,-4.40640798451917,3.29824931594285],[2.84019207232644,-8.18118453565482,-0.852539840248911],[-5.7009485558775,-3.4626033021997,4.45640378879279],[3.12964697592751,6.02009396919285,-11.8370945687923],[0.0977249227696736,2.98911592745796,-6.83554469164879],[1.36579330560271,-2.7550182313203,12.5322499694894],[-6.13660621439389,-3.21766793476672,4.96269591747603],[3.65424929177858,-6.42810589322175,-2.15060009140123],[-5.16755073394643,-0.957697493374267,1.82894164563069],[4.26080466860672,-6.06072305222496,-1.82713122265848],[-2.45323064710185,-3.46413665985632,6.63939214493644],[-5.8973920173352,6.82328054191814,8.55744965974892],[-1.87449316899369,-6.24442751546304,-0.6705226852614],[1.91481980493212,6.47698951910443,7.90183770768767],[3.27867223502268,2.41353864834151,1.26372003752714],[2.9965161644344,-2.11125096477495,-6.85961550127872],[8.66481958030963,6.91512416513387,1.12233146937589],[-4.26259276940025,4.77307627243546,0.43921603400744],[2.76027475475245,-7.49462392005883,-1.52792444581651],[-2.85293773971443,5.02744708403947,-7.20205150096819],[-7.07295929148884,-7.13336396492913,1.29471092984352],[2.13385209127829,-7.82430975750854,-10.8992224590841],[-6.53352092456894,3.00190435910254,-3.84851393920472],[9.39513314477175,-4.07394145320924,-4.70264622494316],[4.02272116311428,2.05374683548501,-9.87136406966116],[-4.36873841976374,7.30942019250417,8.75454665998736],[-1.96271418979561,-3.14922416809368,-0.583741340483557],[-2.60722673877757,9.9212271064991,3.67733503256469],[-7.39714801418883,-0.418321536015219,-4.71806650567174],[-0.192514910205177,-1.150708264581,-11.1792497931102],[2.1430020530512,4.49390285473441,8.348894692751],[1.99881115493027,-8.85291302473048,-0.438262279886022],[9.14876132087058,2.01356266422948,1.27440426200174],[-1.80126752913828,-0.40858820906202,2.97439369098308],[3.59442621540162,10.6411517671242,-1.19692357276252],[-3.53292908370639,-5.23111375133594,7.45388273480384],[-3.81892937792748,6.3940712990603,8.81982069654533],[-4.21884486077906,9.96484809137703,-5.06514954927182],[-4.86830574559781,1.66961473255259,2.4412200101095],[1.13428416368634,-6.7510754600512,1.51238485339922],[-3.42232789608334,0.453680154735251,5.37112525530282],[-5.44558974681168,-2.70968700478999,-4.05945464802465],[7.75875974209185,2.74014598615857,-0.938837257946],[-4.31006802430234,-0.0764265896179044,3.40527863015619],[8.58341056816639,-4.05270892630379,-1.28385298369322],[3.25623828980708,0.568110916748929,-8.60150545376721],[3.01094914779826,-9.45635008775129,-2.34154134403759],[7.10835192097316,-1.29808648088732,-10.6167133064984],[-2.35114837036178,-3.25797567522008,-1.01340662983081],[9.34139944072735,4.35387327764362,-2.87109653062245],[-7.66787924440564,-0.148393518856657,-8.70131817773937],[-4.44155302856084,-4.15769810401967,-1.29478749152383],[0.121242782089718,1.48574350114658,-6.62217512645723],[1.35631469747917,-4.53662296488093,2.7378215203533],[4.56325367836047,5.23208167147378,3.33563204525362],[-3.94292222659451,-2.19091565941433,3.88016329607495],[-2.01558798445891,-2.62371061389317,-3.46096229982179],[3.19673414788791,-0.175508396001015,-12.7644185296066],[-5.12388713658828,-6.60687939985069,-1.53102493785724],[2.59401147295528,6.42308652288623,-12.0079123738697],[2.61653691199786,-2.40917394096719,-6.85594125613966],[-4.07472755351332,0.712233127379821,5.12205972973342],[-2.06471812808856,-0.176243240070671,-5.09480148464782],[0.799990466681589,-8.87446018894912,0.73614208622163],[0.990269149934748,-6.09359027602868,3.07793496206055],[-3.78965151449598,-5.61720927985125,-1.89710103366674],[-3.19096016556772,-0.561868627376958,2.99413172692758],[2.18880184979241,-10.3635721357921,0.403118115138411],[-3.1006604746195,4.17422785553961,0.409107876235634],[2.60915968789527,-7.00282361484281,-0.771310318315518],[-6.26693510021583,-3.14706814976052,4.97907883715247],[-4.58383273712813,-0.39458253586094,3.76829579934554],[-4.43352718999868,-0.353883446009165,3.95561379054822],[3.7000861248548,6.67716251032484,7.82164893022059],[6.81156947713711,-0.921951499454122,-10.6097783967967],[0.76590095725197,-3.72674666858185,-2.78798948628219],[1.87241297077886,-3.00380886567407,12.4763020317855],[3.70021117847785,-5.58605817272428,-5.65067847223906],[2.64772857834263,0.1320594225578,-12.3584672814019],[1.28597647761078,-8.81958728730586,1.81048354801203],[4.20999968304797,1.93307996602883,-9.28322688088973],[8.98279689971525,-3.46093944409947,-5.11510431272836],[2.55432263081639,-7.44684179955986,2.19385634969895],[-1.90520468289182,3.4252288511265,-2.51119472611074],[9.41264618529437,0.850419628974564,-1.32520450638462],[-6.2541994936313,10.6843067119449,-4.24497220617026],[8.69387607679105,-4.17051694929037,-1.33381518512803],[2.60948255195775,5.59836912893989,8.54542819722666],[3.78033678997196,11.1711862927998,-1.81199998762506],[1.93101608432444,-8.82056148765069,-0.944658442174096],[0.0202363039450582,6.35669777486694,9.00950276715599],[0.831883160327695,-8.5324496570545,0.608347176134043],[2.18997953908501,-7.85585607199691,3.79449256922831],[-1.38234242525867,2.55389568281626,-1.67542971989249],[-1.76267967450154,3.0449256627095,-2.43595725165349],[1.74167233238699,10.1707742822523,-2.17151155132475],[1.65525174500069,-6.88808708622279,2.9774689019783],[0.60525430980517,0.377723842864851,4.21964843129767],[-2.12182907687186,-5.54926615491183,-1.70189515234674],[3.08149034883472,12.1193919257007,-1.53315617013581],[-5.31297411304536,8.14143633747827,8.99138847553277],[-1.00830617069864,-2.90571005579477,-12.0056256583425],[2.52749219298816,-2.91401115755913,10.4262224162876],[-6.88576935278075,3.06380521905855,-4.4791917570835],[2.67221685371451,6.85336709886898,-11.5656468175788],[-3.75383103508793,1.36963001658701,-6.2272162173106],[10.4855818233604,2.58279845116639,-2.68012596234541],[0.508955668794512,-1.07936186642743,-12.8734819291974],[-0.391454382649195,-0.534214240775775,-10.8934001287506],[-2.37799208907682,5.0127024768844,-7.23475877524891],[4.55250065819161,-1.06069578981186,-3.04848452317982],[-4.02068525780063,-4.92739642728782,-10.9641544439735],[-1.46982807288623,-6.68210278656766,-1.47643612306501],[3.43585845183158,-8.58198315643131,0.314295802342754],[10.0151497039005,1.60697667461735,-2.37628533535194],[-3.13898970350088,4.49423246649146,-7.09682080826896],[1.10299005502605,-3.19459480411318,12.9559876590213],[3.09203890122816,-3.42317273651995,11.3361427908873],[3.27689799938291,10.0942936472938,-1.3293323479763],[3.24812896873216,11.8106474425108,-1.24660400071998],[9.8859923708309,5.30697452634038,-0.966948515057732],[3.83239099644635,-6.78938899410451,-1.37826860642962],[8.16459513510804,4.18672009238294,-0.0450684035007584],[-6.81729585581234,1.71591466272619,-9.08419474998111],[-4.47524588102432,-0.0638415292815302,4.73604367095227],[2.22445410489419,-4.17333571426916,12.1134114262124],[1.20961910510669,-8.85048197191738,1.82287920332017],[-8.95419893416692,-6.57573422983316,0.39710245360442],[4.44667061383437,3.84789628923359,3.49313142102538],[0.103345048687507,-8.09147692551584,0.145479361925803],[-0.383433645636998,8.84794598623984,-7.19020316192413],[4.33897449679191,-5.72420661413387,-1.02689025339199],[-7.51039430155027,-0.750617474977687,-4.35708776173639],[-4.74946005999503,-6.48282086833624,7.68562451275597],[7.94557333083443,4.26746598797317,-2.30721156543156],[2.31510301912536,-9.84546774597088,-0.992607255214332],[-4.57389910765746,-0.097102151229838,-1.51654499759033],[-0.219631751472645,-6.15326700455482,1.8862687494945],[-2.14463012430783,6.98666268851985,-1.04771512390053],[2.51471944333759,6.67094086346584,7.374814350597],[-2.31913037415595,-5.30303746162309,-8.47701851589495],[-4.51564835771665,8.25440745556812,7.94760180336982],[-4.88589407256706,-6.07776436787521,7.84552289230232],[0.0986736567555296,-2.37014055315115,11.4431451094221],[3.8266322502203,3.52158814249131,1.56693205081863],[2.93911415687811,-8.7272106439513,-0.634345202510528],[-6.68814671513209,2.6503651870191,-6.05440203134083],[7.31526090270429,-1.57373593827198,-10.6965026203661],[-2.68417989132656,-3.74314382395349,-1.62926033485837],[9.44652270739224,-4.25490343521382,-5.51286231230584],[1.50640576961197,-7.79426336783981,-10.396173483818],[10.0606347431598,3.40171316086513,-1.97290694115354],[3.53515399276348,5.16886483518956,8.52808635804643],[-4.43101645142373,-1.21944799684562,2.003113419998],[-5.21888243983639,-0.0027543772550781,-1.08985759613225],[-5.18059997302336,-6.692408017592,7.23669205402065],[0.307939651590841,0.115880803285863,-2.55187257749445],[-3.08173045768875,6.86584959252042,-1.10155696315112],[-4.97034483623773,-6.8659325231198,-2.69310585600299],[12.0307337493755,3.77334061201626,-1.34411891257689],[-5.4419088024427,7.02618567609067,8.41206993020445],[11.287882347896,3.95401112664462,-1.70451663951673],[3.24235422715784,4.35317598539648,8.21271328853739],[-4.92485173557807,-6.31279833154405,-2.40522576380883],[-0.0827964642971845,-6.78906579679392,-1.22962560587627],[1.39735574580559,6.14652946922668,9.29456380062519],[-1.97428473423647,-3.60813238694894,-0.0213463502766684],[3.99197558917269,11.6659198238105,-1.40501304636406],[-5.3386512305048,7.19058886854174,9.0629882133495],[-1.26687235646032,2.59791311122223,-2.19568829174175],[1.0819756938601,-3.78526607930306,12.8598619027393],[-7.25287355779256,-5.65063196655211,7.21352037166358],[0.932835120988064,-5.58315323268616,10.9781780152985],[4.27337591847065,10.5126028848087,-1.40093920872592],[-0.724705228941167,-5.94991591116285,1.82430741830038],[0.182570007579573,-1.58226231052189,-13.2552115433138],[-3.22854528924578,-1.3534812106512,-8.10049245174489],[1.51216026805914,-3.90507444560384,12.4406104252821],[1.4378035335927,-8.01310973706832,2.45060219246301],[-5.46064857152312,-0.631716230281432,1.09097763331386],[2.59851670486066,5.21277132122146,7.74639794348722],[9.85917779114421,-1.12592669174814,-0.795501958072132],[1.7436303925665,0.537544502786901,-6.94379741792103],[0.307087465456677,-3.16336722438227,12.3798979725967],[1.37138663827491,-9.07845012097199,0.13449816523734],[4.05768851264026,10.7130828668607,-1.82422279335039],[3.16505261581007,6.45955241927019,8.10058824066524],[3.19782258738555,-5.88739415135894,-4.58362817419738],[10.8521435499405,5.98028145445105,-1.13778863035873],[0.889806590366497,-5.2055465607475,11.0871148679809],[0.394757261327018,-6.56990043437977,-5.76791148255313],[7.72788983873915,-1.83403115221184,-10.5964931923847],[-3.02210214309652,4.3184606903563,0.130952418126045],[-4.51656137578127,8.26218657095166,8.15969355829858],[1.75606157231534,6.33926730237218,7.21780533701138],[2.29411046115915,-1.96790743779863,-7.7092933373599],[2.60800131811171,11.2672975295903,-1.87084736543172],[1.66005307826261,-7.05570220640434,1.81856199782448],[2.10508061535338,5.972377816093,6.42271379251061],[4.03075969348861,5.18459123036585,9.13973948810301],[4.463521705534,1.00308971641476,-9.24495777657307],[-5.42429781631759,7.04685285771822,8.61386110786399],[2.87404268411648,6.37905288139319,-11.6413692061235],[-3.94600435629236,8.27474325898383,-6.77986081760162],[9.39596846478323,3.72362222275662,-2.1385972897338],[0.929862633235061,2.24101165824113,-3.0082002080372],[2.0550468630425,-6.30358451647345,3.7841021885298],[1.10525848472322,-2.36633317187956,-7.77829451477334],[0.817264162059947,-8.46163142227528,0.119693294281868],[-3.81784675818854,0.923625129927742,3.00409069863886],[1.61882873054707,-3.27333304885872,13.3660749146527],[-3.78024729196069,12.0262681561394,3.62950871877294],[5.46376399934596,1.22318241312651,5.70459833485851],[-5.11179663256301,8.45966831502749,-6.77048790885615],[0.358135449044547,-9.3702729000939,1.66090824781255],[9.37024010106178,-4.57814398143238,-6.00097541657935],[1.89800076490842,-8.34343543915224,3.198665387582],[2.66040299620948,12.0926455706055,-2.84206966782461],[-4.98976773302568,3.88661639791678,-6.28846500722399],[0.549293474752975,-5.90567149109543,2.26646801629712],[2.72702261044944,-1.14549101597887,-7.467385609035],[3.56267990874766,10.4388793721971,-1.93637274473879],[-0.984066611546621,1.66892526135882,-2.55025650972584],[-4.55348401942908,-6.35149019638683,7.65236410723938],[3.16014533819299,11.5490086513253,-2.20254216460143],[5.22217728418006,1.3472199439313,5.67462925464547],[1.86509568062144,4.46540057752842,8.59102880148655],[-4.92404433580215,8.99582173365484,-6.42631811045744],[-3.78182110566584,0.496250215371837,5.14059397888291],[1.06607984272159,-7.99212369478421,2.13937920827855],[-7.4472708500126,-6.85458753081202,0.938499270139564],[2.6695185714349,5.32446610197507,8.85501088945434],[-1.75010389072898,0.781171317993451,3.07930848238157],[-5.30341949627655,1.60748295630667,4.15319838439536],[-5.67922091630018,6.52996219792432,8.18641296607029],[3.31787584067243,-9.08706572326819,-0.352387345439441],[1.59911559774437,2.90545043151925,-3.72844179137621],[1.33476121462731,6.51143585841256,7.75725327587166],[2.31133671418679,-6.07983837993952,4.92093880508325],[3.41325847831554,12.1902888283699,-2.26443531473961],[-6.43254034192425,-3.166425330226,-4.69698699463014],[-1.41719823175851,7.42795850675503,-6.85133590580771],[-2.63847243923884,-1.05693328680258,-3.75340725746248],[-5.87870589605866,-4.44565548391094,-4.19129057004631],[-3.53314069880918,-4.14847812594168,-1.67187471882186],[-1.64859657701816,-6.89447219804307,-0.818766663917408],[-3.94161466898118,12.0850410189909,4.00363240067258],[7.86164088217455,3.13712158997749,-1.34095839112037],[-6.28771149651743,7.47740724990438,8.0723324302442],[2.47126575968644,10.7162300637592,-1.0613728943585],[-3.41631339977319,5.4889855491497,-2.6916293851458],[-3.19036265933298,-4.46082560435678,-1.12581519161719],[9.73269705158118,-4.32443439797578,-5.45478984745894],[-4.20033627724903,0.689926692064619,5.40959165123761],[-5.31007852250611,-0.946768558505563,0.752491909806896],[4.40171926083824,5.33803846194821,8.66012893071211],[0.982324069308691,2.14203344466934,-1.54920824567919],[2.22808873014556,-9.32737281759558,2.40872917634833],[2.05307001148649,-10.0123880175326,1.29313128590044],[4.15652524889685,5.19419891253743,2.77912689336311],[11.9257761163514,1.02002877806324,-1.05618412589944],[10.8892515995439,-1.41980100666663,-2.02018875991737],[-1.30792497868515,-4.05136779851161,-0.429328931224514],[-4.84489253534777,1.04062720157205,3.00332807817708],[3.92362003932698,-6.12493115483432,-1.71764863833913],[-6.24759933434282,7.13690632730554,8.81544737964265],[1.39003796039835,-3.78272576966169,10.2768011258408],[4.11196385338703,-5.20495371407363,-5.08955745585882],[-4.89653793750217,-6.73517991296616,-9.9076340991968],[3.75523591525641,1.96754352460895,-10.2849932017758],[4.10884703865999,6.06816397811177,8.65236278495149],[-4.85010635254544,-5.9716000764127,-2.29276055018033],[0.552599929351747,3.66891705719277,-6.70522747762921],[3.21790157994143,5.20939381193183,9.03605699602415],[3.88743527178459,-2.11786299242556,-3.02075228502884],[-3.87035009489162,9.63825706255832,-6.81951657745204],[1.91146944004566,-2.77344007048262,9.77232743363149],[-4.42931022009769,-0.274704077731313,3.29364437590313],[-3.34346037359946,4.56829394364635,-0.703527250044098],[-1.88004171992769,3.80046764568051,-2.7389846156578],[1.26141990024454,5.80398573448156,7.05538144424582],[1.26043449345657,11.4106732580536,-1.71775807761314],[2.85257080399684,-9.99735199930771,-0.899298354394308],[-2.52834230076668,4.57421046151597,-7.13694553960895],[1.09898496951358,-4.10675129663653,12.5748924154151],[0.765814738905051,0.257923739260618,-2.8603821001265],[4.38151867958238,-5.83717040843875,-1.71608590737161],[2.97798532632109,-3.41895737057059,9.49109130486139],[-0.944997419246842,0.967305470010623,4.65534924241463],[9.00193435469641,3.70854541107916,-1.30497866353979],[1.74848642439736,-3.7597995322992,12.5528144594581],[1.46397298116233,12.5404354867347,-2.4602926458581],[-8.96542061045232,0.00526994880640241,-5.10273632899708],[2.42491054371196,5.84610187480504,8.30433656833897],[-2.84264665578986,4.64589256821193,-6.99089836198932],[2.89947010545745,-8.42378373386492,2.44513638723054],[-2.67616421223292,5.28558168897721,-2.47619768308976],[1.82897806595251,-5.57538315870328,11.0990177002105],[2.27565080323879,-3.49669007024159,11.1049465891171],[-1.78682500188616,-2.42724302491337,9.48853790584358],[1.66893743192688,-6.3597962791639,-10.3535267816828],[3.7024444218627,6.12282530812803,7.43594041372042],[-1.91099933009802,5.4123780749824,-0.493905227324183],[1.82803359737784,-2.48612304403883,-8.34368740466352],[3.08456645356704,-3.8660905492648,11.6169746900803],[0.275390063813153,-8.34295595904915,1.09419364116982],[-3.61768855547592,5.54460761027876,-2.68307081620229],[-5.5163731745774,7.60375229668197,8.40245664694138],[2.92442812186078,-4.08038588582976,-1.6881728526124],[1.32574620855219,0.240228127325653,2.83903554107063],[2.61963268303666,-5.51491859109664,3.37458983992148],[2.09526416009395,-4.19165144187933,10.0204796621997],[2.03032895838205,6.35359473861498,7.54663184329327],[-2.15836642793848,-2.70939057177849,0.265552577582528],[1.21708283451892,5.67917678737895,8.23447108116608],[2.56354746807087,-9.17008437547381,1.45419100628928],[-5.90812169544879,-3.15951476738386,-5.39759599021487],[-4.51250964108594,-5.99912530316544,-9.65032114465102],[8.69180045079935,0.238235632837781,-1.42398651495532],[0.111399372486721,4.06442863271268,-3.27247646767489],[-0.060370646268645,6.1575957368623,8.31419873384488],[-1.9530428312724,0.0761369409628385,3.18542512710399],[1.49955839347308,4.22885580337798,-5.53683343174087],[-3.62310642261316,-4.3985614289322,-1.03395774690467],[-4.75531594782334,9.91397007970156,-4.15541432875885],[3.14735111246218,-5.89108953295502,-4.84077150180086],[0.835632006778668,-4.50398952060393,3.75510837270843],[-4.85763240397205,-1.24499344972118,4.20849419102342],[-3.18647896469472,11.0564992170655,3.45383224136084],[5.04716239059842,3.33082474938823,2.07879501141038],[-4.2095587643777,2.62946609209773,4.66002331174084],[1.56320057714852,-3.68908298280985,9.95803226353055],[-4.54877313527744,-6.15794642213635,-9.25853706046431],[2.07075318094395,-5.7131735485019,0.697002398988623],[-5.15923677830246,8.47515994754627,8.62899397961421],[2.31333704163551,0.694641842166987,-7.16645011340894],[-4.82877270622273,7.02940118184967,8.9416847239285],[0.803939744110201,-5.71260306407003,4.78787892857175],[-5.45736751443771,-0.384631603556849,-0.836450308407131],[-3.38647722222768,-5.67590580519807,-1.43262344043374],[-4.35240970660551,-5.67839230796441,8.0354832148339],[4.20979100989137,-6.04563287146826,-1.13052284626987],[4.44129198166577,6.08279637176322,2.70590890278053],[1.07633659981443,1.72518460602951,-4.97463152217853],[1.70642811799917,-4.39733128021703,12.3751192667382],[0.447132831226141,5.55191149063017,8.01666924051085],[3.64102707003704,5.46794043996259,7.16376079407055],[1.4162527274138,0.314314399281606,3.60045207708289],[-2.47964305534411,-3.59189452290232,-1.05170277079433],[2.64307808571827,10.8074559140221,-2.29530402630991],[-5.15557101232841,-6.40828999819822,-2.18056354986295],[2.1524134899179,-3.03891904776273,12.2370424987866],[-2.87902057146997,-1.15930157319143,3.96743011198952],[8.06001342898615,2.29009937096548,-1.02384618235415],[1.91205043131697,5.81594587113167,8.48042813766267],[-5.40913482257471,-7.010044260849,-10.0657835212195],[-6.09619164728008,-2.9775030802814,-4.71432219081655],[-4.44685004774135,-1.13059866414424,4.08340348866633],[2.80474160124215,-3.51299199797973,11.4810747481483],[3.59556176639636,-7.77536975730115,-1.62381267726234],[4.16809170854715,-4.99656482401704,-1.46925663553641],[1.1786352147466,-1.89412228864713,-10.31121037649],[-3.59758370798456,3.55045787356096,5.51633705984592],[2.00952914347602,6.05514099281205,6.33396567595963],[-4.77639982251915,1.20805950625913,2.85729714775979],[0.732567134501323,-4.11224808898265,-2.50229026957945],[-8.18538091245501,-5.74852006895118,0.282469438935315],[-1.97528270663699,0.906301574118076,-2.40589558803609],[-6.13486071571603,2.89138087910475,-3.69088096549228],[-5.41486950206212,-6.06301142061176,-1.17896204163203],[4.25234294302634,-5.72375423248115,-1.5703272378619],[4.32522047421422,11.2483243593034,-1.7742650073656],[-3.61237731496281,12.3964087434303,3.62692779632038],[1.52877432965461,-4.71735065894364,4.76547364420031],[0.830938292199659,3.75433782564083,-8.18085695749321],[3.20428441089414,-3.58698839401847,10.5913284714532],[1.84944131999983,10.777287411706,-1.44458970662996],[3.41711588127188,5.81573554563886,6.69076464608934],[-5.02450360707515,-6.43727403971767,-9.65842480497751],[0.431250345192267,2.21384579987933,-2.75132344043967],[3.14611049983192,9.91486983830561,-1.98731090645159],[1.86426477119433,-3.0610368108034,12.035489089563],[9.18117232900842,3.43195836858018,-0.556511309204126],[-2.96171972950893,-4.59731457306622,-8.63005585919785],[-2.77572579628301,-2.51310593955342,-4.7616288875187],[7.87821682660926,5.86833608148895,2.10025793781203],[2.40749530773526,-5.15051402615495,2.92312018345188],[2.87940345580914,-3.75967428154974,-4.59413196189663],[-4.61045335214904,6.97063232293055,8.37500613451661],[-2.21877189318996,-4.39295783822061,-0.0633649251984179],[-1.24469068464932,0.556324069923156,4.63798966335816],[-6.38046862259508,-2.94462427067077,-4.39257401567925],[-3.41389393263646,0.323484124026642,4.67784311083175],[-1.38056001766717,5.20951369817004,0.638956916349446],[3.18013507167567,0.399694229393761,-11.1049039110204],[-5.09109421637894,-5.6651948216765,-2.52349973651919],[-4.0833441339472,1.86256195018103,2.62544438220765],[-4.9167007603672,-0.57228810854311,3.22413283643873],[-3.50434586353903,7.1309148246684,-0.0917056912905744],[-1.8865879005963,5.59970122598702,0.649031270822806],[1.37653100814095,-3.0224341981214,13.0797959828625],[1.17541202577641,-3.45515903388362,13.1258861172731],[-5.28540882148945,-1.58422888593665,-0.925788706201188],[3.30442259029603,-7.29428764856746,-1.41853832641378],[-4.25684217080704,5.11386981747386,0.0456044228085112],[1.4625785984989,-6.98562214044287,-0.19672027740427],[6.47519712441822,-0.6754251766879,-10.3775046658953],[0.136101492365264,-3.0645066212189,11.0613386825271],[1.83411767874463,2.98669456650447,0.277287078887227],[1.59922007740351,3.87324047385693,-4.29705659042784],[3.67964361593949,5.39286004615728,8.66281062304294],[0.45064730544812,3.99733824574087,-5.48946573340458],[3.11198675016397,4.42040851465985,8.4403063852194],[-5.02922749300444,8.88231842622476,-4.19967832282416],[1.40553893387885,-1.74672380907907,-10.0703744070005],[-1.40580682576909,-2.59397360540714,-12.132849313903],[1.0016634556549,-4.56799421215665,-2.2787056008682],[-4.01585001949872,7.93694307378288,9.18759772579347],[-0.650169130731558,-3.01890594105473,-1.74642239022506],[-5.93865570209772,-3.27889955139712,4.75542497736389],[0.862401182256499,3.44198415619963,-7.0020191237111],[2.74369498268171,-8.64262195540134,-1.90112293781899],[-4.38710021958085,4.35582338772413,-6.51070215240779],[2.76078481675425,3.69759050933284,7.59288337110813],[-0.263514693900669,-1.32747914302937,-13.4615217153799],[11.8614137754803,3.01776715958703,-1.51983767703941],[0.51544288278432,0.440303263701202,3.23301253164794],[0.445424899761617,-4.32987310129496,3.92415383065882],[2.37423805581981,-2.28771626611551,-6.71628808709516],[-1.81665929939953,3.06552458732236,-1.86680058150865],[-6.0463687478348,6.87156029443265,8.40712337632481],[-2.77028213046784,-0.365366421592968,-0.675353550542462],[7.36784100946039,-1.77370279825844,-10.6706063529389],[4.32873357719983,2.374616712056,-9.75907694413977],[2.15744151500543,11.2101856970242,-2.51263823053728],[1.22834148791817,0.872778730651604,3.04444141402354],[-3.50944770653232,3.89652854710345,-6.69916880110993],[-9.65750603502953,0.931343760889821,-5.75808792933883],[-3.90942405525081,4.91805282723949,-0.428249753216979],[3.28444132581436,10.6553439067646,-2.22139470345504],[3.56197002199687,-3.79742677334688,11.4811458573695],[-4.03703419864824,0.696061580092038,3.7546911303747],[3.42504175508488,-7.90892089646942,-0.917567883182243],[-4.36637794713588,0.0841167992963238,-1.45369844447169],[0.729723432707398,-3.15550442311974,11.3095215376344],[1.67898546235727,-6.4918072350286,4.3576090594182],[-3.39763176482988,-5.28391890113658,7.35133027861278],[-5.74359968127961,-3.15087837411389,-5.32973898464003],[-3.16383438090905,0.510166429784152,1.8369127120133],[1.83880083743316,-4.92771629923632,2.72987136346105],[2.11749550968461,11.4316183334588,-2.13266119612939],[2.27589189950893,-7.77674615552203,3.25170754874797],[-5.79245779640492,7.53377080256875,7.76936413568618],[1.06687793354825,-6.54230136802289,3.68630198883889],[2.86285789918882,2.77470869589521,2.75581479772362],[-4.0418266966891,-4.34461982839998,-1.47457410309804],[0.663422947152014,-5.30079644996987,4.64090257992259],[3.61470617098415,-8.25315554162246,-1.51654058302213],[-5.31675818786661,-1.54662320700207,-0.509596662975945],[2.07071806490228,-4.54922031097725,10.0011231911352],[4.27940676489411,-5.75081556536426,-1.66422177417251],[1.09468587731612,-4.63578306733046,-5.1923064369112],[-4.48461286775069,-5.64238198939985,-9.76612672618014],[-6.30844609106935,-2.86034975660625,-5.19463552487355],[-2.15189322832763,-2.58664068553047,-0.383879633905465],[-2.91736609823552,9.03119538521631,-5.86697502358396],[4.33953604699331,-7.53690901221589,-1.11504937441109],[-9.20891313258701,0.0715047900879624,-5.98862574656207],[3.95830326286943,2.00847079300696,-10.4662304316928],[-5.15220642281412,-6.89020045339394,-9.80230143404073],[2.15719820785538,6.76019219208179,-11.9954199143763],[0.573141138975468,-8.76551331033635,-0.348391981414308],[-1.57508318807183,3.10537643872335,-2.49075168552445],[-4.67716863421515,8.47783439171435,7.83710642617182],[0.0431109907585181,9.25094854721388,-7.38632857347002],[-3.4318736578712,4.95729490302004,-0.635959019472648],[3.35288791921493,-2.02728740125341,-4.17671384504951],[-2.18408244222055,-0.184693289732906,-0.457469881147159],[2.44681500332684,-5.9299052530218,4.58706559975577],[2.64086125652269,-6.50142081697693,4.49173060277042],[9.3456058093635,3.98125116073603,-2.50056266581596],[11.2527970296431,3.79027577344122,-1.7194682234766],[4.15545199724699,11.2135442185743,-1.34378626086633],[0.819920349659832,0.266097476491044,-2.87687757888991],[-3.56929364632969,0.0952842267648752,-1.74432862228637],[8.8687419213914,3.89879807075907,-0.827880529028867],[3.43747786543092,11.5585111199615,-2.71271090693958],[-4.76179313267902,-5.81519131190106,8.18731256992612],[1.68798153708764,6.04430245425797,6.40358723493232],[8.10710598503918,4.83808826425777,-0.822685226788953],[1.19377261469829,-3.78062046426239,12.8324607297555],[0.0157551597780768,9.07041714647719,-7.16121416243605],[1.50091307926808,0.123740775747019,3.19201216775504],[1.06460848401099,3.61409252679489,-7.10584812007401],[-4.45366545356374,-6.04763474438624,-9.38300826828012],[8.4274952927809,-4.37874712570405,-2.08396854935066],[-6.96777927394726,-5.51117571572596,7.4048093385839],[-3.81360720558244,1.42502406059629,-6.30550959626614],[0.546759776423326,1.54350796040758,-6.70980891204146],[9.31841773259336,-4.63756885351538,-6.17099583404892],[-2.81547462442328,-3.88248189328194,-0.280868084889856],[-2.1472398669505,9.17800365488999,3.56013645671527],[-3.31045930360589,0.219564467223048,3.98885280421026],[-3.37439874470252,-3.82058429632187,-8.42284396290447],[1.55909153504878,6.60025755094248,7.22222574712716],[-4.21387371643459,6.075666512436,-0.708066630990851],[4.39315900269073,-5.90626686212742,-1.93526035524154],[-5.74507933651902,3.08771550888005,-6.71999716388099],[1.67131979564738,-8.37159390698553,0.997343013732741],[0.225275858255346,0.64602330380335,3.5268031441344],[-7.05707020238841,2.42479557634249,-5.57538778310318],[-6.81293611928996,9.1804132567117,-4.00735287582028],[0.949905000979123,-2.78058512267984,13.2232689750695],[-8.68955745293559,-6.07956571607121,0.443996837378464],[8.97605878439327,-4.28635849957437,-0.886399275265018],[9.60022240091213,-4.31703149536563,-4.52224255274439],[3.85230814188058,11.2738921339241,-1.97335327498456],[1.45649853652099,6.19975560320656,8.7277894048476],[-0.686319689568535,6.45709910254647,-8.34891400560834],[2.1810316318116,-3.05353347679057,10.5250751213188],[-7.12130910751004,-6.07107362326102,-0.611757633310953],[2.09351897013937,4.49203128131073,9.19397052188013],[1.65526433235636,-4.03112602115665,11.0373231439356],[1.66898866045731,-8.42373570897554,0.705685224816076],[9.86009856294902,0.305801173273962,-1.02188874165402],[-4.19134594343672,6.62484020155468,9.04468889037794],[-4.18229386036679,0.694223323425426,3.1297247333056],[-2.84532122706926,-2.30274717796059,-3.37388769673284],[-4.33744027968908,2.11248618158428,3.4433811663254],[-4.65234229702859,-6.71328399125973,-2.77677036924077],[-6.08934663592429,3.48105500694545,-6.10463134897943],[11.1790185295287,3.76918463791142,-1.84388378165687],[0.517361055675598,0.218746998884964,-6.389549373207],[3.47241273951205,5.44791923798595,7.23966933416533],[-5.02020210528237,-3.5557160089617,-3.36733300442496],[-1.05079252380125,0.995346518040701,4.43277844194239],[-6.78692256439323,2.8890567656233,-5.43406761116852],[0.53645703037533,-4.93527439103863,4.3544135994083],[2.90430320479544,-6.65222398742547,-1.29586120186236],[-4.26492905159543,2.02068484992965,-4.91527989285713],[-0.289476021124038,0.20512872532181,-2.11272629018152],[-6.14836140333771,-3.12004150657339,-5.10234143377352],[-1.98396852123567,10.3108909616184,3.11717783908308],[-2.9540302350992,-1.76586232911039,-4.17621827464084],[-5.12359107714108,7.06812177457925,8.61418564840262],[-2.54803098828212,0.151931079121695,-1.00586850966464],[3.59919290789032,-4.59056148106743,-1.12993331962104],[1.16760890054655,2.43394922782365,-3.29731205605717],[2.56375451520914,3.42436310336111,8.16592168863694],[4.30898405991596,-6.14638208089999,-1.86130419986972],[-2.89298546801709,4.50700063810704,-6.81782938277403],[-2.37913591806413,-0.774306325659204,-4.01684864784852],[-0.663346961891368,0.702532191730731,4.74972865494784],[-5.62436623304635,-6.08427369997089,-1.44647473406546],[-2.18412452088352,7.19807159665278,-0.736437463214414],[0.678593849449152,0.193232550789663,-2.57568685765142],[0.911044538787158,-7.04051683319852,3.08355378927238],[2.42567445692577,6.42008794294053,8.38979314943941],[-5.16741872331839,-6.25606927890536,-10.2794213570962],[-3.95681737429273,1.45444975076276,5.403818199623],[0.885943387641785,0.297339808135121,2.9746923991604],[0.886444251434006,-8.24871107658046,0.686791831790523],[-4.49335715992401,6.82390471592216,8.14746425420191],[2.71481998841081,6.5359387005156,7.66433108251036],[-0.364654834445957,-4.96621795332741,2.28621122200286],[-2.028808893504,-3.74079985225936,-9.36461007925274],[7.52905183105171,-1.72176209769616,-10.8009774127179],[-3.10439438838978,-5.48184746469414,-1.65304306503262],[4.19868697337277,5.92390631727651,9.00605437997271],[-7.92201678354921,-6.73926516879057,0.912459382173677],[1.78163959680919,6.77585308817965,7.95002962691071],[-2.5910364987479,5.12128354674561,-3.08069373212388],[-7.04115412248691,-5.7625569775044,7.22484544000346],[2.34938508273223,5.61020193597512,-11.4261011664027],[7.80877986181836,2.77162600146825,-0.920276207779116],[-4.69634460518812,-6.28449448154189,-9.83224510104351],[0.444041597981299,-2.66173430104727,-0.242448798279766],[-3.36360386892784,-0.16799588568809,3.29009082542037],[1.50168693560943,-0.530059893173112,-9.54021303399208],[0.984370820339608,-9.8050234049182,0.888278751536659],[-1.89541702700805,-2.00566531842812,-8.71797844823318],[8.05067533350077,6.1304389738564,1.10743923441182],[3.31383469454292,10.089411753984,-1.54701347467521],[-2.57548350773407,-3.94598670266502,0.27134986518943],[3.43619917168014,5.95577909056193,7.30560181976939],[9.18480874002354,-3.43485389960997,-4.73124475370935],[0.0285527608369409,-1.22074166018857,-11.0476344530318],[-2.4224383298077,-2.9846480739301,0.255123471297741],[2.58624951539204,0.157039584024615,-11.9773450112992],[11.4332012912616,2.79569865962082,-2.07249397086299],[-5.28264356366013,3.43162801905986,-6.86593829831539],[-6.28486349313581,-6.48445558248448,-0.819938587947933],[1.29432356310196,3.79579029734908,-6.00796022425727],[3.74522528785745,3.7620343976418,0.710950233239028],[1.24921178097153,-3.02958877500158,12.2498466752137],[3.25210065077868,-7.61867364585674,-1.41906600844677],[-9.60439707849765,-0.756633824257114,-4.58916952872567],[-3.8806153913181,6.94758708642398,-0.443480187292444],[1.77699280551412,6.36437612018561,8.20506256848245],[1.48172178126196,5.56848304763292,7.8411146487493],[1.33456460870201,-8.73089573366592,1.26400138875429],[8.30472944924929,4.53229079827129,-1.05338635226902],[-1.35821892489369,9.37601905179418,2.7129205230436],[0.703819320703633,3.44975455283378,-6.64922734173427],[3.77851197470915,-4.81957547501926,-1.90088823752455],[3.73260526221317,5.03319098449568,8.29492338470912],[-1.40515823954407,1.41834760011125,-1.74115729169803],[3.71204319135825,-9.10738118657882,-0.899919251533757],[-5.46986060366574,-6.26938347176358,-1.93203133935117],[-1.72871978129188,3.50506802072352,-2.57608626624214],[2.3078810447307,6.195408757979,9.28796683883139],[9.40844886854028,5.4916703595743,-1.45948395361294],[4.17002979827542,-6.708655002689,-1.21004776566728],[8.09604505225097,4.92623523329202,-1.70082360085396],[-2.22103241016635,4.30050508150492,0.885252008923321],[8.47893814392004,6.83981556355565,1.40999237412808],[1.4154312346997,-7.85660961406716,-10.4062867975018],[0.142262339615386,9.11716540159915,-7.51047092776273],[-4.97416238420969,0.47087240735037,4.81391645618816],[-3.82026699541894,-1.27647324472851,3.59155176739002],[0.969612671003586,-3.46398530236263,10.3991613615376],[-0.246771159330764,4.37736054361575,-3.33089136904415],[-5.31905878635779,-1.81345675621231,-0.633736101724941],[3.65106482041523,-2.78058575848303,-6.67856928051696],[3.14075269126858,3.83908859810317,8.02781038538144],[-1.08429886442368,6.41762895278332,8.57820086439256],[2.89136003333107,5.78082455334879,8.10394465897381],[-1.88866960594659,-0.453385805774734,-4.14688141381233],[-1.07472518311416,1.44367685226727,-2.35343286407784],[0.793008400422152,5.4953495507694,8.53761434882414],[-1.42384124938195,-7.14566874823841,-0.605643553066839],[-2.15243832553777,-4.93065118858036,-2.39270939404091],[-8.12568632881499,-6.01206385747816,0.834329775270699],[4.19905671422296,11.1102814143103,-2.23303431778029],[-5.33414515476263,3.60135288662397,-6.56489312808599],[1.96384792814804,-2.77564446502256,-7.36770292824329],[-4.63935936329291,-6.9013859375356,-2.5186113243985],[-8.31135242297599,-6.55362935138555,0.803292743924997],[9.25317372624989,-3.94904728835664,-4.15876036621564],[0.158940279920046,-1.0625538688269,-13.4172385340485],[-6.8291359317916,2.65516881690183,-6.01922515040258],[-2.08988836843311,0.0124988812976377,-2.72371422946708],[-7.04464276085352,-0.660316342185026,-4.41015359960347],[1.77062923491387,-7.17461184731799,1.3812157827073],[-5.69406823482815,7.25350456242796,7.8448993143822],[3.41809698935283,-3.28100642039269,10.4154398499528],[3.25934659254444,-9.28060170950724,-0.531227026465062],[-0.567921737745553,0.416103991209081,-2.76176600692477],[1.21517610608772,2.32022006095017,-2.69053933083313],[2.01705424601274,3.93466332473815,-6.31345726187455],[8.76083024103376,-4.02367011277996,-2.78094505811569],[9.04206540446942,3.6219273806461,-1.31569249084513],[1.12860448218246,11.3554222505172,-1.88727964176853],[4.68197623094106,-5.97587457122059,-1.62658713360439],[9.90121874394967,-0.0568696639449687,-0.635271234658319],[-6.50124330327381,2.99755751164022,-4.07371436876906],[-0.253669303791144,-1.56236896323508,-11.3599548957894],[2.01675054485462,6.0372742894539,8.5938491637514],[-5.77926382475494,7.35943322660086,9.2704783882085],[3.68574002332814,-2.76883971895041,-6.66589411341025],[3.56018913675122,-0.819246325010626,-3.27756588124676],[-9.17710887282623,-1.74342449167918,-3.62399793233264],[-5.61873568773519,-6.63140813168898,-1.38065546750471],[-5.36470210731366,-4.280977680183,-2.09268355947632],[-2.67581339958008,1.97584638047028,-6.89551792426279],[2.00295955619292,-4.85861422756761,0.122603694271268],[-9.2688164287917,-1.49916900402105,-3.58522063786011],[-1.64171212281541,10.4427341618072,2.57737777516078],[-4.09121735697147,1.5002134147846,4.4762882119792],[0.248234072677471,-4.31823109713859,10.7637222726457],[-4.8128133187201,6.69200832707892,8.75044396596855],[4.41063614197361,5.54833263028827,8.45324950784776],[0.84527568238573,-2.70415340127338,-2.47196217143606],[11.0476791568773,2.18983030156028,-0.97521745787965],[11.0077871220347,-2.05394871869704,-0.873480118871549],[2.58982900981453,-2.36206907325484,-6.59516467759649],[1.47193066485722,3.68612347344358,-6.11522383217908],[9.09556215773092,2.87469425175564,-2.22238519749196],[3.53905204135928,-6.00793536817597,-1.98308355278704],[5.18368295476736,1.30219981607528,6.14385578225623],[3.10589938932549,10.980057888437,-1.87592291462202],[0.625767954739069,-3.19120437393364,-11.7641318717386],[3.62005445535457,3.71385387041098,1.90147403023491],[1.52299028439126,11.5018893430015,-2.62065483200642],[-2.43849454236968,0.695958070246543,3.26323472159662],[-0.293565282323767,0.585117785876671,-3.2643921416984],[1.86211213874728,-4.63143028722994,10.5350904517533],[-0.201681774165425,-7.3006562394719,0.914447913910359],[3.00649232975944,10.5128827018038,-1.84201072997437],[0.556971756329919,1.26982895656149,-2.23176907629759],[1.25216511688357,6.32136546736857,-11.1691685786934],[1.82805286418527,-3.11355519422083,12.4152914156327],[-2.61219907225286,4.80912972956122,-6.91248590414493],[1.27791152020363,-3.66432327270416,-1.60874304004571],[-3.35082459329391,0.958021189550573,3.2947401827877],[-4.9914316780303,1.97583287545729,4.75600132088115],[9.12288346476952,-3.59123379820734,-5.36109642161364],[-5.70993813035152,-1.82688684887008,3.9226935079102],[1.38809312608232,-2.87853597495792,13.1976732480411],[2.70261069062135,-8.43310326950607,1.67631283549288],[1.82310697211159,10.3021390112029,-1.45096761903011],[-0.235773467419541,-6.86608108705022,-1.24768994710221],[3.30396405922357,5.94319991692114,8.33914443660532],[-1.8043708211423,4.11649029902522,-2.98647669369477],[-3.961370111669,2.21690549362934,-6.67882053650625],[1.67207264542971,-4.91361688952865,4.29743036103532],[-3.62137467674183,5.23706443687435,0.131229250803757],[-3.12010765508944,-2.79639176748363,-0.885748176191035],[1.90322211576462,5.52458577786916,8.72653519798743],[-5.56254429329869,-3.08997303150538,4.55333619699126],[2.06974780431204,6.09285610019262,9.32168135950302],[-3.44244431468797,5.39199375180173,0.466576296314439],[3.82067171319053,5.60768090779532,7.38018033150372],[0.0989019500961792,-6.86158265594468,-6.32224427940857],[3.32100084127596,-6.82001747235159,-1.50812159138662],[-4.13773276629879,0.638495148661458,5.17978082909545],[3.20746177992632,6.33754047092303,8.87927861104286],[2.2115796539062,-0.163624502471175,-9.9829861551084],[3.65816696019186,5.9422695226578,8.13004651417234],[-3.29247362642584,2.73491500784684,-5.66703335616263],[-2.2392958440875,-2.96916660840826,-0.688915042556022],[-3.31912748246163,6.97828600005321,-0.944336485618597],[-2.11819419987611,4.52085477968446,-1.5920025390664],[-1.25215108824651,-8.06968557462165,-5.86696716454215],[5.33916721431604,1.23607623035197,6.29317499545266],[-3.14655028569459,6.87199619247975,-1.16049750288773],[1.43900329996884,-8.82794220263464,2.63101191798089],[1.18456312709299,3.24351894353412,-7.33632757562768],[-1.7566193588716,-0.970622396086228,-1.97237921284398],[8.74082685608433,4.10695316072014,-0.506290545219722],[2.31886718564542,0.038444521413732,-9.91303551896197],[9.4123773884282,5.35507253376944,-1.95672636750993],[-5.57038689802121,-6.10132167339659,7.55075290463602],[-4.00152901311831,4.84387375729764,-2.42899389428542],[1.39685644585597,12.1814859022165,-1.69848359825735],[-5.29537397815358,-0.305176512085394,4.13777782128313],[3.23678132861166,5.4021933450175,6.86267615891368],[-4.77733923402715,1.10741352463556,4.39699388768491],[-3.33174719043732,4.49954993431249,0.560884322941939],[-2.64541180333113,-2.82070619265577,-6.60398695947693],[4.48093214517645,1.41987524200451,-9.86475133521055],[-2.10828259635503,-2.73056205667817,9.2386345772631],[7.976882355223,5.71320286021364,-0.976422782701135],[9.19822134229942,3.19588636638264,-0.0447838565218819],[0.571363665094501,-8.5527353977398,0.368879979324836],[-4.20304958140118,-6.28730540159314,-1.18754857825594],[1.45350222839298,5.42542249503834,8.64249201259903],[4.91114941659523,1.83880578901614,4.68773891413988],[-7.4600882130543,-7.03846883492233,1.23942221069978],[-1.2458603486339,-6.27065373089984,-1.65068222057289],[-1.85721026210187,-2.98429160728928,-9.98424914646983],[-0.752600821435291,0.434987991154562,-2.48915571255855],[-2.73273309510772,-3.88964944054845,-1.55034583094101],[0.0112582778874778,-0.985301706517489,-13.7457875959182],[0.443366987771989,-3.72433622835702,-5.64519310263664],[-5.26896366833682,-0.97670124608959,0.786930698804294],[2.13729538318736,-9.81857986280762,-1.9632774892404],[-3.9391901941709,4.19669565029826,-6.94382023053141],[-9.57427247610629,0.551583914805615,-5.59674904034824],[-1.49433026591938,-3.01759037878097,-1.81886215621243],[-5.21841494602867,7.06400385491809,9.25614125443592],[0.864483113160711,5.9740951792893,7.57631625074457],[-3.99694579176504,0.791618185031863,4.79843029203579],[-3.67698896992591,6.55922688261976,-1.23020529968676],[-1.91846756183595,-1.92677675563351,-8.48372904963366],[-0.0442620541590634,-2.3978457297041,12.704792332508],[-6.27097757257541,-3.19558667330375,-4.97008612919964],[1.5391333729337,-7.40138595364561,3.97492187787764],[2.03652957536992,1.56454115035508,-9.0235184828206],[-3.42471389970083,7.09404251300766,-0.630816508011685],[1.01483860370134,1.89422685123934,-4.69360308202574],[1.6221728449606,-9.29226653383308,0.176974853316788],[8.12899545773869,6.01153226362038,2.17607936662828],[-2.6184717842738,-2.47366532189821,-4.53342613051218],[8.61362485084272,-2.84317069821725,-4.2990037450676],[1.3261180630461,-7.17809064066354,4.13785408191752],[2.32919748809664,10.8893167492356,-3.3282982748454],[-2.18075123336767,6.95153255885011,0.0559894141264646],[-4.93671510544673,-7.08592749703561,-10.276695653176],[11.2212268937837,0.787938157287361,-0.827896322302875],[0.555224818527192,-8.95502624794713,2.50400207543696],[-1.38759276407156,6.35579543247344,8.69146220993489],[0.929189817877803,-8.38502545816257,1.52569827110022],[1.76087173249828,6.5771566884413,7.37048226027727],[-4.49463961757076,-0.081473016562478,3.89207886598872],[2.09363107959576,6.06191120703165,6.39387017058584],[-3.9699570731838,-0.695575922577688,0.506710488680885],[1.31361103790702,-4.73741389855828,-2.43020212738761],[-1.61531510286361,-5.45675107041731,1.89735689153235],[-4.74981447998182,-0.71120375217262,2.49626707244532],[4.02904284136644,-2.13616218389735,-3.09967246318067],[11.477577533928,2.27302898406615,-1.57510502551279],[3.06233045659536,-0.178713481861233,-12.0069785823002],[9.61360570620092,-4.49196555087087,-5.53770435692064],[-3.95364958516632,0.904261780305636,5.12206979459229],[7.43775291283014,-1.58029268038545,-10.7839054005301],[3.60724093002588,4.26911209909576,8.06447530128851],[0.327237642134091,9.20435177695364,-7.80806061730915],[-4.77662932097502,1.94171018665298,5.01503093496129],[-3.2165159309155,0.163314461516435,2.91512688956053],[3.12695811426064,-2.85177012301793,-3.65854805233868],[4.21878152483505,-8.81894418592949,-0.638208288250197],[1.38676248123054,1.63666358170358,-9.84116312882482],[1.12886667518497,10.3975272279699,-1.89074354932885],[2.2904287147687,-9.23931723230844,1.11993361699301],[-4.17162231151884,6.94469924840172,7.86137393763218],[-1.57453988087835,5.28683771403538,0.625561143647721],[2.84689910151579,11.619302298166,-2.45678943488703],[3.17647631613893,5.9706855631753,8.06820815007123],[-2.59318960356974,-4.28067780065062,-0.834858860514957],[-2.18109430546026,-3.42440777102205,-0.304901030538294],[0.349545179389394,-5.46413494842849,10.9730221096664],[1.70985174949743,-9.77832219529876,1.3662776348081],[4.05436697198099,-6.54988590985586,-1.16422402612713],[-8.21000395737233,-6.45604630958421,-0.0739847856979445],[-5.55117586870722,-6.08293752817845,-1.91106508440727],[-5.48387394732557,8.24033699221985,7.59761626539162],[-4.33616281509846,-0.00926480564498389,0.949619951474803],[0.873293105590899,2.21975534412247,-3.35147478814642],[-3.5390677534856,6.12141012441624,-0.102058894916372],[-2.28629358922779,3.76109931467162,-2.51850184515815],[0.755273464035745,-5.14489583589903,-5.35743885637348],[-6.75070086576925,1.89435472691694,-9.20650395490282],[2.10425929370207,4.45668470726546,8.51683122023516],[0.662770541686435,-6.2611813288728,2.9402972180185],[-3.87047513174795,0.852352122710059,3.12927636665867],[1.14196320460374,-4.94161283388251,-1.83942529034519],[-1.57479258328004,-6.56967967924257,-0.353157345779935],[2.69868035948451,5.28476792782797,8.89916221078367],[3.45361935966547,6.36963895844828,8.74368307664603],[-2.42696840354884,-3.94002058498952,0.0180304724752048],[-5.56372540155879,0.279672558387013,3.20216350985535],[-6.81628097119501,2.58738500217294,-6.05867715089909],[1.30415092597958,-6.49781938746722,3.4937503104928],[3.0322272760889,-0.14077399684345,-11.6290770282856],[10.9380599988152,4.19499113673447,-1.88078241042951],[-4.76352234851973,8.17720646515911,8.20855207558888],[-6.07909822684748,8.58878247202396,-3.96329529507106],[2.36216004148965,-4.36101706504859,10.8234477347979],[0.819489951460435,0.26459160288068,-2.24013832390356],[1.40563812808454,-10.0091063818371,0.774999744113554],[1.47232559142385,-4.77945508909157,-2.3290447199734],[0.220002228984443,-6.54116738544464,-6.00953361271692],[-1.84804392912965,-3.59043848110113,0.426966968365504],[-2.18279310431186,-4.11878350107725,-0.0243942105570144],[-1.97225951933672,-6.345697965961,-1.18523972572577],[-4.25689164059546,-0.0937308183703143,0.677521689850194],[-1.95297307867052,10.9159869560077,2.89368992448514],[-7.62425625636855,-6.6077083101908,0.877229970469597],[1.75768570508451,1.88932917943799,-9.00427902226512],[-3.43304556935294,-4.35491412696768,-0.849133874706885],[1.95090787961944,-10.3263654263882,0.0642233005751751],[-2.47407401440879,-3.64627405502015,-0.104175192087411],[-4.76237216711986,-6.20274844495121,-10.157777715961],[-2.74434349933185,0.816996025646291,2.67343250575965],[1.69322647273305,-7.7757294209919,3.46102560311136],[-3.92802658707199,-0.138758307148883,0.888520684388984],[1.79624861642996,-5.91074955886054,4.50535573301946],[0.0474008108991142,-2.69310346875995,12.6260555473996],[-6.97627372833519,2.63704062576884,-5.99054684788286],[-2.30493917526633,-3.10777847444609,-9.30488938482308],[3.10925176393804,6.37606030735387,7.58465047138142],[-2.96636852860145,3.24239898538484,-7.1342697919843],[-7.23757208815138,-1.18104943493862,-4.18992855868874],[7.35637103028346,-1.85259354630986,-10.3223971120361],[0.985585406041624,-8.14769629793161,2.40570643183137],[-6.83247156224105,-5.75135396990634,6.25390237690297],[1.48296531419754,1.46989669409956,-9.20494032118585],[1.79894893588236,4.10473921500983,8.64720275499351],[-3.81043631875925,6.30719607559932,0.128039235983508],[-1.954314442418,-3.11287415137996,-9.71780703042706],[-1.97912228368562,4.90307229987006,-2.76860473636398],[0.744922995077691,-7.45598498324702,0.847870528617606],[2.151151323433,1.37409198269653,-9.48444736860547],[1.26281983730955,0.270861822868782,4.3424439376413],[0.372242643304325,-3.90113077327794,-5.84474637405323],[0.281408494795522,-4.0759264191819,-1.82092691481562],[-3.98564909975893,-3.60811645800609,-10.9780347298964],[-8.80980468972183,-6.07725747891258,0.646457791811868],[0.809212554346079,-6.20236699117229,1.36337333650684],[-0.638841196779997,0.424974266767128,-6.94106659075212],[0.233117052552856,-1.84779706893453,-13.0479945609657],[2.66186035826823,6.90005764469952,-11.4228124308004],[-0.303616201861746,-8.66994802116772,0.745579291485966],[-3.57177626966933,0.981689315214794,2.48410073131514],[2.18396381010024,-5.46355644306384,-5.62909295453767],[7.12209961884443,-2.07562344031138,-10.1603194185657],[-5.12068089129972,-4.97611298292549,-2.30660162091765],[0.317201354420348,0.562731603045124,2.89710882755693],[-4.19469675362221,1.67262368822762,2.49332930386161],[2.8390289105276,-7.58140501864474,-1.82873845062538],[-1.35023503503978,3.24046323868459,-2.04599372658352],[-1.91881808992776,-1.45722406429248,0.746227199661208],[-6.78508320830189,2.81941329783458,-5.97782662541171],[-2.6185508642063,-0.0535441931408798,-5.06532048025719],[3.09718144574124,6.95018132340521,7.98106725063272],[-2.70884666084844,-3.18472788138962,-7.11774976432861],[-3.11288968547452,5.58813821283383,-2.80547873974439],[-3.38553985808336,4.45145638958062,0.156761644798128],[-1.12638359480841,1.81255951501026,-2.12570258934632],[7.90315178428436,-2.94210998601919,-4.89356859271935],[0.923436139355349,-3.54162355268443,-2.56547487132043],[2.27429124592693,-4.63691480402843,-0.41085660663183],[-6.3324829764228,-6.19645764782809,-0.685595703693735],[-4.55981235698349,-5.93787107005866,-10.4723007777441],[1.01461534517885,3.10229794651398,-7.17293271821637],[1.87840198632784,-2.99529617979226,12.0148906149995],[-3.35273613892953,-4.42434601252288,6.88596403606924],[-0.196471494950221,-3.03415634918609,-1.34376940173199],[0.0325345914469838,8.96734396035588,-7.62354397163858],[-2.13918537831497,-4.07203972039179,-0.180751378131788],[3.84998329480063,-1.59811228858793,-3.01637220288475],[0.390385266838008,-4.90710983975976,2.61149719413152],[-4.96879460953923,-6.77832241324379,-2.46757146418816],[4.3630836829327,2.8742589166647,2.62505250987561],[-9.14792974293263,-2.0610451572555,-3.5556932587817],[0.61647913437128,-6.87365730576992,1.82003370153504],[0.710382799999189,6.39057500642683,8.45605788566968],[1.74495805639865,-3.70707715180321,-4.37957819525292],[-0.716870302196981,-0.51321047440514,-0.143874914215851],[9.53828233494982,2.41713762593391,-0.967859519962719],[-5.07878870539442,1.21698781980626,2.79817128348375],[-4.73884962616945,8.05000716897184,8.03163778480283],[-5.03904862010849,4.14298145905331,-5.97825773198228],[1.48562870337462,-8.10581578735295,0.381439340823959],[-4.44155341236334,3.81094527574899,-6.99069747164174],[0.772781315958114,-8.19493278482335,0.915143712498329],[-3.88987616923011,0.99852514569931,3.0145825446672],[-2.16031129256413,4.84562454832939,-6.79597067081772],[4.45321697668325,2.91634819004146,3.4679082008783],[0.79991175057643,-9.26861388985331,1.95562447498615],[1.95374688330414,12.0387973900546,-2.24574100420975],[-8.86912621904329,-1.47625360027728,-4.51805135994953],[-4.035058081989,0.347599477077566,3.11066006004932],[-7.58397531395317,-6.83868893405303,1.42989375976086],[-4.93462720820512,-6.67381221713134,-10.2165898827248],[0.703171606526938,-5.25672598153118,-1.2027723371074],[-4.19347521181102,8.4071645383189,-6.90516971706452],[-5.2787049231173,7.26413669039418,9.12340030460072],[-1.46187325276173,-6.93805999924024,-1.42241158407087],[3.08687302425783,11.9460311796816,-2.39414587953937],[-6.6398933138156,8.38750286910891,-4.05862243590446],[1.45681246367054,0.253089339527135,3.11830899837009],[1.01704381080956,-9.12705765806568,2.92121977467579],[2.53195180365414,5.92039448389985,8.28736781922875],[5.97149810216598,-0.426470422521158,-9.97859003844318],[11.0091095108604,1.37308466157435,-2.22347066253224],[1.56399518092486,-6.3400648005134,4.21407997165868],[2.14302299030185,10.5836820832637,-3.11315330041743],[1.26708674581601,-4.60934624188607,4.41732887952244],[1.62973077191965,-6.95333572271714,0.556463270694755],[3.33023943505954,6.62023180083475,7.35649501312537],[-2.79124196367464,2.2236280957355,-6.99739839287508],[-1.83187418232431,-0.341691043450459,-4.77398765622739],[-4.79065169823704,-2.82518126547558,-3.44795319740391],[2.08508326925819,5.3615164089501,7.93711985774765],[9.06463055736994,3.46138685687574,-1.93912270627971],[1.23173862137688,-4.97129329315522,3.16153315261188],[-2.40595593677537,4.68613559718693,-6.67437807754106],[4.06498265194071,5.45176427502306,7.63208544937408],[0.365812011363046,-9.33407135123236,1.39012354240751],[2.56991148718854,6.78198786690537,-12.0235080895724],[2.15785346533235,5.69274622041009,6.51890790393944],[-0.131335180364812,0.47779025310018,-3.06882999823746],[3.62406983706932,5.66465297826896,6.74982701155866],[-3.83711659053665,-6.07391172704777,-2.19250995891091],[-2.98261577163343,-0.932497815729274,3.35980654052185],[-4.33036036438435,4.17044903949212,-6.54100532750039],[-3.93965329721176,-2.09018409572829,-1.28646055207768],[-3.19452460806661,5.4268189849172,-2.22547477336614],[2.70774532613965,6.40640513339221,7.10770653841337],[-3.77525904739682,-5.48916439800322,-1.12242915639173],[3.01395273605822,11.3271175323753,-1.19348325717077],[-0.561442796383861,6.31034859412713,8.89280941940735],[-5.65393959800558,7.09549112625681,7.93706785485259],[-2.16351218521922,0.264277230738168,-4.54878747010463],[3.9753985423508,5.74165821801315,6.79389152583539],[-4.12284631045988,6.87997326154445,-0.409816592959677],[3.53844244603535,6.21984624903635,7.07262521694839],[1.37200237633857,-4.93113103522627,-2.23152258725844],[-1.31904545460538,-5.62493817190185,1.88148137579996],[-3.10668607553697,4.58979338531889,-7.53675451098048],[0.945571526842614,-3.99752823865629,-2.28730688023689],[-6.90696915351694,8.33049871068232,-4.13322619782292],[2.25445174260535,-8.88643243492211,0.841041105343715],[-4.12679342941452,0.415443369528733,4.07485989595859],[2.52220805475422,6.133431478198,9.47439351938464],[-4.36478128950294,-4.99959868892227,5.20649044525213],[1.61416752167664,10.6160696975072,-1.66905736109327],[3.22693228942575,-6.19625694396258,-1.8454379481592],[-8.2420205774896,-6.77227898602899,0.712404092075741],[9.84603870218103,2.92635600524548,-1.73389500833912],[4.47049743342357,-5.31894079554426,-2.82960434879407],[1.20882358014267,-8.8529905264297,-0.434961392949986],[0.250061743715422,-7.29159070519797,2.00455620534064],[0.832821430120726,-2.83342763318247,12.1329320586139],[0.51544222213523,7.19465277862933,-6.18655902148447],[-4.95402118000038,-5.20265826921671,-2.24898231499702],[-5.06009918739755,-0.946681143651676,1.55123429599493],[3.30478026964349,11.6859461446169,-2.94827018320256],[10.9540076899532,3.76666203573655,-0.815948178446943],[3.98743698037854,10.9208886582703,-2.17490441432251],[-5.18860422242384,1.07166495140087,2.42393387483593],[3.02686406808599,11.9383664127444,-1.96203541168093],[-8.52244713435238,-0.10991124623014,-4.07434496446019],[7.56131845425193,-1.44100291891725,-10.7377054051337],[2.96401416980893,-8.83669681676036,-1.28846706257872],[-0.311633560051398,-8.26825222948846,1.43329842300811],[1.8444995904102,-7.1457893645907,3.58823131804228],[1.33968942606379,-0.651579458144262,-9.65792098164778],[-4.27459044608354,-4.416921555444,-1.15490602240207],[1.52728272527291,11.7482064108289,-1.50318614363573],[10.9287695421814,2.56784600142181,-1.93660356281614],[-2.85203862977333,-0.693062457643421,3.09819295451218],[-3.67030225884717,5.23478036517101,-1.00237868755677],[-9.17572898607224,-1.58912147923487,-3.19373607575528],[2.41692383147359,-0.0259581101698353,3.81207432544329],[-0.813640631248916,2.20070634641029,-1.4476948702878],[-0.256896532144578,-6.67288650217364,-5.93125663174926],[-5.13295362268163,-0.036295936294196,-1.17739715131616],[4.28111269940292,5.12644594987978,2.94867333690956],[2.28530002603249,0.779050910637347,-7.03799797239138],[-5.08860136243372,7.89719759018477,8.2282405607597],[1.4214362491003,-4.74347172362883,-5.03588221401035],[1.82887266678867,0.245339468042462,3.30000284981763],[-4.28753880484498,-0.201832278519514,4.82409700775646],[2.09317914768091,-6.12472050898682,-0.168931239149938],[-3.97242336058951,2.6648734376546,5.51754924842647],[2.01166342293449,-10.0558519771325,-1.01398784558029],[-6.92451420698866,3.12593766087014,-4.81283006549894],[-3.18148011619606,0.482542356457674,4.46437865229711],[2.5040813533113,10.3795720348455,-1.92603209790448],[3.42271582346284,5.79192772474373,8.13334938074597],[2.69613671193749,-2.046568157793,-7.27404161481179],[2.45430950562696,-10.4474222182021,0.0338470912824143],[2.44755751240026,0.683382486686288,-7.11325297550774],[8.5704847588996,-4.10777226955981,-1.33608126035392],[1.98621603501839,5.745609762167,7.1020286075138],[-5.26222424581004,6.70914750523061,9.00446031898845],[1.36831686184294,-3.55836544146778,12.7468089442464],[1.48124543611202,-5.56301660101676,10.6465635209827],[-4.60286231295532,-6.96350676215588,-2.10692913460431],[2.50692321332781,-9.24353835483469,2.6780803020048],[-1.24433774359297,1.45116345990104,-1.75459928841417],[-3.17658515489481,0.781592539781529,3.55953363056416],[-9.79851012542805,0.79291508278406,-5.78007221991084],[-4.18613114563381,1.80737135111533,3.93801467175343],[-5.02068536850586,2.88023725525023,-6.68181140275474],[3.11824400602324,11.0021699079085,-1.97756129460301],[-2.62738741816892,-0.98735633104786,1.06697993376095],[0.845995107714042,-4.63167705216408,-1.76111141727065],[1.86936322015105,-8.65829095476928,-0.893105251657025],[1.31636695073273,2.26474301702009,-3.14325808502449],[10.6999264288667,-1.98466718346677,-0.589608222842958],[-3.87468372372234,-5.55412963670436,7.74471993797973],[-2.44091675270976,0.245866461000071,-0.226910632419617],[-3.06055649518205,0.258931497857097,5.51592186480328],[0.0159655280419083,4.65147229847056,-1.51137486919214],[-5.0568986072778,7.34594259012615,8.75577579047357],[0.466215138834665,7.72207644423044,-6.32792630849569],[8.02373011272518,2.24462310040417,-2.14513417817381],[-6.22891239174881,-3.36450421074122,-1.58445545839435],[-6.22105828501296,8.46761567736116,-3.7640834985254],[-0.178905814602376,-6.56816994557891,-0.933035181147622],[-4.4176968686491,-6.55250928981772,7.56997156070795],[3.04129088379174,5.9185366784161,8.60351934872427],[-4.72788096980294,-0.342404473583007,-1.42157965273771],[-5.05338978073325,-6.61836809566017,-1.40534541652434],[2.85087184334077,5.65052920068048,6.04188689795678],[1.26251626468516,-2.5419780670874,12.3458301309822],[8.8576890833779,-3.60051783000831,-1.67514394301647],[0.274670686759682,-3.38359525669103,11.2380160780325],[0.667690177518338,-8.17300852687677,2.45633745827148],[8.58765867611807,3.61677909461324,-2.77268561854215],[2.93537727087249,6.38768756203781,7.00909280400194],[1.77008564591323,-5.45011778375966,10.5944509338943],[8.88237889117109,-3.50664574790638,-5.19809933358725],[-3.01809438152545,4.45811981620256,-7.68227831573734],[-6.15954473536963,7.07733641336085,7.94536053840305],[-2.71214095390822,4.71983850029988,-0.474802938396513],[1.24089331264873,-3.93254698784348,10.1446696128844],[0.668646414360678,0.359054466194031,4.47329597695575],[0.287976092987896,-2.50433703455034,-0.847231365237204],[-2.22902809613287,-5.4759470855622,-8.45629612176189],[2.73583349324034,5.45067074969806,9.59662918005329],[8.90505388961743,3.9898998036735,-1.65337940225268],[-3.85317431931518,3.01805490493279,5.48292324819571],[-3.87051157324513,1.0731294855725,5.24331428647843],[-3.8692022080828,-3.6736137964017,-10.8749453928041],[-0.279069179092271,-1.16951778667755,-13.7542117919331],[2.31725398061244,0.376328990487759,3.84091571186345],[2.25188037819659,9.61681483102108,-1.89182402296987],[3.41174979527452,6.00199373875038,7.26003663977726],[10.4033580733588,1.00500827423564,-0.945921043355002],[2.57733447335285,0.0438939312193588,-12.4078289918186],[-2.60985496549905,-3.24932981942591,0.0305890596729379],[-4.30184076236591,5.9440238400677,8.84816886241377],[-3.84914636764569,-4.8260430804869,-11.2949929729129],[-5.37173806904811,-0.00719303179733843,-0.608856038200571],[-2.65877347185433,-2.61966872150052,-3.10387456187579],[-4.74046740717718,-6.25240264419291,-2.13665730563162],[0.993769890733377,0.517396616965963,3.30512883394936],[2.53383759775866,11.5310536744682,-1.94799484528383],[1.54056514617908,-3.39397147414239,13.0834476764872],[-6.46311408676011,2.97420028375672,-6.31820188239242],[8.7977315550206,1.96145418898108,-2.07404470961864],[11.5582225728995,2.03652822234625,-1.5854526094326],[9.99193432790586,2.40741143697494,-1.19652393481259],[3.61226765072922,-5.84220642294089,-5.39038505742532],[2.23108810694086,6.04194055950684,6.93246740007838],[1.74987646567375,4.20871305466061,-4.13739637470804],[-0.310797455325012,1.76298216222502,-4.55032095873209],[-0.520338331212,8.86996109817682,-7.28036863340198],[-6.03623357940953,-3.3510502208808,4.61683001599009],[-0.371549437358441,-7.07179473229977,2.1908973031714],[4.23940170388043,5.8720298464648,7.72166750424557],[1.69593836289543,-5.22451172026036,11.5839482472356],[3.74920578478106,5.87329972006882,9.05010184250406],[2.22723957967154,-5.05674042815985,2.73141579786581],[1.80710336582927,-10.2452281991977,1.03162214378371],[0.776709496415199,-8.74286131444152,0.0776892020556263],[-2.8168131381899,3.41662402248962,-7.26826102862926],[-2.99637674222458,6.90548781078852,-1.38241667942831],[0.939924728829897,-2.5463979801665,-11.0943385955677],[-5.36008740889173,-0.4358266735252,-0.335063399134298],[3.39709835724764,5.41630503609834,7.86224467611994],[1.38773018766924,-5.52302760344595,10.6203192410691],[0.482699686019313,-8.49983398815688,1.66835441248885],[-4.7109849908981,-2.96554554366922,-9.42069501326055],[9.84651249723517,0.233236388690238,-0.701390446299652],[2.91043580294345,11.7317514939152,-2.86855225881318],[0.948030507713849,5.01076302779681,8.48069411966993],[2.50679458154143,-0.809038152673478,-7.53724114673129],[-3.80009937467679,-0.853792099137817,2.32830464660679],[-4.79409108630456,-6.26404457831029,-2.68656078696437],[-1.59405145511362,-1.66749453994417,0.964535417986048],[-5.15927125133588,1.68638136105572,2.89788197473667],[-3.63496702220074,5.89725065443838,-0.991429567113369],[3.55635683883463,4.38359979766386,8.93901346351627],[-0.602932679095036,-2.13775711464111,-2.63847135780425],[-5.5671902174073,-1.1780023778207,0.263537850616047],[11.9587309736929,1.48206885303119,-1.47960952048207],[4.00053169530296,-6.6956837568111,-1.45933481525363],[-3.39772381498937,-3.00900968591353,-8.60242632821658],[0.411204347337273,-5.31194755323902,-5.49587917778267],[-1.33880451117364,-2.63976602965887,9.56349326250096],[-7.0793219862854,2.92238360509275,-5.614633564548],[-4.44950860110676,-6.53818271973816,-9.73014206178556],[-5.80722109903646,8.58462623518844,8.0048392578301],[1.26498001369678,0.130869332031769,3.19514680207417],[-0.109094374460976,1.15104641179909,-1.46371838990339],[-4.5865285907507,5.15097128875274,-0.0415533185273803],[-0.960867252202362,0.171660588583344,3.76475108299109],[1.83328279867563,-3.41493658148283,11.9881345485919],[-9.27588507169695,1.47770571512067,-6.49141142732601],[9.88466539339182,6.74995872358634,-0.684059589593943],[-3.83124835827568,6.4467534935068,-0.683714783499735],[0.378500287849744,0.715970576868386,-2.9279681087319],[-4.86327867482997,-5.70340055337077,-2.6822925021612],[1.41683878726363,-6.73284619431098,3.7891357779165],[3.63074633992596,4.61162425845284,8.170216410853],[-4.92565469340213,-2.7762536081393,-3.53839538051509],[-3.88482718772913,-6.7543945595687,-2.64621626434485],[-3.50571950753185,-1.26579244483282,3.92275468914032],[5.1116343182516,1.23747797342974,6.2107601847776],[-1.6693688934007,3.61586240770303,-2.68742584536369],[-4.2793728530892,7.86556688735789,8.22932863451013],[1.15708026993018,3.40834101965189,-3.97535707902247],[9.25743450719219,4.97909183984296,-1.03463782787275],[-3.05386592248491,-0.852690358572817,2.36431391803966],[-2.11583230394317,-4.47039696961463,0.0237731624961121],[2.49499570020492,-10.387566342424,-0.50636468609742],[-6.05751368054912,1.38515408441422,4.43868420315992],[-2.24913099377905,-1.32501949683178,-3.62116891980612],[-0.00314205161584724,-0.0457892397300292,-1.34527261234592],[3.56309366171018,10.9747103205919,-1.86144331435499],[0.327368582490432,0.286104074955098,-7.48153397053754],[-2.43039521148145,-3.79345150563063,-9.48334015922983],[0.994828172877219,-4.50669298245232,2.99397531468776],[0.583594765961129,0.344260900660327,2.53359900845389],[3.19613140390964,-2.64331962861064,-6.58844803622468],[11.981377451066,0.614593897635815,-0.652444939123415],[-4.40905393113177,10.1339006313414,-5.49090203367994],[-4.95507388807306,-7.05980745445635,-2.29775872607366],[-3.90276654396795,5.87847020602566,-0.915372225751418],[-2.90502086371779,5.5705092764733,-2.32461773451802],[0.809697472724807,-4.93398168885194,-5.5142969476345],[-2.09928058412209,4.92943233129392,-6.97645069874643],[-3.69533157370493,0.529059311138867,4.15878336804246],[3.39986407546333,-8.94596163264952,-1.57172523215083],[1.46392525905563,6.21484954098793,6.61695737766613],[-4.98146815161221,4.07673867296144,-5.95196744155315],[7.53513013574616,5.40984091644018,1.67214225480131],[2.51266518088155,5.24263682838582,7.13952779446123],[9.19234565884292,0.676500479112015,-1.34285116191916],[2.74067931960548,6.37495614864239,-12.2337278241486],[1.93485206925602,-5.39190530443183,0.268408181483726],[-0.0672013317227502,0.124304768933172,-1.82289344019184],[3.92341329888973,4.34477698962957,8.72013766879681],[-0.612517260693332,-2.758699225503,-1.7335869310038],[3.45499921657559,6.00303994906211,7.65940370453718],[3.43995280969303,5.41838931103897,7.63053580420362],[-6.08232765596373,-3.39039341738685,4.75218960521046],[1.6018935578961,-4.07829536878028,10.1108301407691],[2.14368245479475,0.424976564689728,4.04106572152832],[2.29842854734791,-7.54369917597343,3.17790916994492],[0.472582680555352,-7.50197864144967,2.32572389508499],[-4.88091965245766,0.919006056159137,3.59068113017371],[0.585881574921742,-2.49421013931952,-0.163729328933511],[-9.31276242819099,1.28624298949942,-6.3474962182334],[-4.59437486794731,-6.02767260976108,7.45902617185162],[0.414150581903576,-6.46971643660208,-1.43766734207021],[1.06496707722609,3.94251755538586,-8.90658942686507],[0.0580858474175167,-6.68175015143067,-6.16141469536131],[-5.82839963397649,9.30599385713684,-3.77334432318879],[3.50387717480196,-8.29612825575121,-1.39633860425059],[-2.56184502618074,7.31967224007742,-0.791408744448689],[-3.13609580427817,0.222401268218465,4.38262526973274],[2.84860583235937,-9.68251872397796,-0.00862532161079216],[-2.74432613812556,-2.18657815875089,-4.6659931162372],[2.71369838110565,-2.90550899522297,-7.49841601555528],[-5.0976647542536,-6.47734684701283,-1.06893321239579],[-2.3982137071277,-0.305852567539478,-5.15057473792447],[9.11756814182158,2.88765516916653,-2.30342526794191],[2.90296985416327,-8.49271646683383,-2.60243474185124],[-4.94542566205225,0.88356038002003,3.46510241693385],[2.15266386243255,0.818297362003473,3.1873290915461],[-3.6564228825237,-3.31307677693001,-7.61327293550156],[3.06260983304547,-9.96024508594408,-0.454654935236446],[-0.146838244937173,-5.69195369916792,2.40848028928122],[0.799782763006426,-0.367709250254716,-6.27187267081535],[-3.90833720544816,5.59241149328746,-2.22567487597786],[7.22807220963304,-2.80801204065917,-4.38850032563093],[-2.76621119404775,5.51760355902685,0.853564388491616],[-2.75573845938106,0.175900860080082,-0.451498195868294],[2.69148666741905,-9.69714265088421,-0.782147573131996],[3.1995481246287,-4.60494373432297,-1.13713889717426],[-0.411886722244224,4.70609977019166,-1.6393055813353],[1.2752938535664,4.42807107620078,-4.13419468041558],[0.66373215362429,-0.530078780459852,-12.7968118742487],[10.4592220496807,3.22229548220231,-2.59875308831551],[-2.56769688198936,-2.69101212569513,-0.824985204072635],[-5.18523946279367,9.25449322186391,-4.07232102756686],[3.01980422113656,3.95814301999604,8.57372083991055],[10.4622898494661,2.18251562945864,-1.89505260906763],[1.26332605588942,-2.86728897302957,-7.96691824196497],[0.28249249440391,-8.07419569911909,0.67014756537693],[-4.15963808339743,5.03369110124767,-2.6130007009168],[-5.32061328498289,7.62102019989777,8.394669411117],[-4.05374679775368,2.51618574610711,4.1612443537574],[2.49556940409153,5.45442692613892,7.80397540385696],[1.34733875615123,3.38781320024778,-2.74962151736441],[10.9789195937589,1.30004989597862,-1.36636025441324],[-4.36672810775728,4.85638714761852,-0.265313801048219],[2.57160082708693,6.26666641977138,7.647472276136],[1.67966508519968,6.24676487526989,9.05886194074121],[-5.48884055977352,0.86080026723886,3.97947194184212],[-3.33285271371318,5.5695563328219,-0.702116116300966],[0.19423656855268,-2.44207946774438,12.8884434663217],[1.95687969037036,-4.47741687945438,11.858600260504],[7.91289292406413,5.45484059953703,2.6785818494414],[-5.24723921591433,9.77531478004141,-7.2354949436052],[2.4835991526221,-3.71596749322137,10.0893957542799],[3.03462256266484,-1.9916879440153,-6.93539717736792],[-1.20386881184744,9.75270549879469,2.52079232763753],[0.811631940533413,-8.67221757585775,0.588430820622774],[-6.54686430244249,-5.96702552537999,0.155483055585144],[-3.65770675445655,5.50586726831423,-1.72852549906381],[8.82521888494847,2.62759138386255,-2.53597730468702],[1.0907096339776,-5.59449073338809,10.7687850269456],[0.937424540456005,2.826413766426,-6.75548080510219],[9.25137392643405,2.06166225287871,-1.76972080069783],[-1.61580059249416,-0.908036516014566,0.213816969449967],[-4.70021901588687,-0.787717928361708,3.69977150121573],[-4.53168607869152,4.14313437598334,-6.57293175160645],[8.79801201507415,2.60191033613182,-1.7686667460298],[0.537028251621127,-6.88269840812452,3.93184106222033],[-6.07495474461384,-3.68560742407641,-4.96861500804267],[2.18854375957106,-7.00980668820502,3.36631253092224],[2.88535944547028,3.83917983333183,8.55453945689103],[3.07975262384412,0.0044385226683028,-11.7744028258826],[-6.27943131268734,2.87515414339763,-6.35375143498902],[3.22002216669248,-8.28133204867785,-1.68969324904547],[3.0286712199395,5.44043805958884,7.30612849794815],[-3.94596414336929,-6.54054988456944,-2.36374423963719],[4.01619593035417,1.94501774151607,-9.92552849761516],[-2.25798281842709,-3.73959908646843,2.00589113910768],[1.67614774783146,-7.73130564037197,-10.5067858427576],[1.32024729191373,-9.21864225216667,2.13883652510509],[1.63013921654723,11.3349719411923,-1.78189232938054],[-3.92263185344866,7.08443271861157,8.36712514049203],[-4.39311831529283,0.228547790603948,3.10636554914636],[-5.04024586023007,-6.58991008292094,-10.0056994920328],[0.020564445945529,9.14654262331394,-7.47225924783903],[-5.048154751623,0.811364659891771,3.55005064369237],[2.13798586238294,-5.1031588913065,10.8441771050731],[-0.653988640866766,-7.66286205808022,0.367926054277822],[-3.8224866453705,-0.688778440981532,2.86308178182987],[-3.81902551016351,1.80706134185221,4.5450846607758],[3.13402067357489,12.3392987130278,-2.41174133915879],[-2.2524555278873,-2.65896879470995,9.54401385767292],[2.95342246449641,5.59196123752204,9.3887067180252],[-6.13757163668709,6.88765675488418,8.29309705261539],[0.208235983781148,-2.79821612240178,-1.13876219736699],[3.92819226672167,-4.58893159061137,-1.95930200168563],[1.72183162272451,1.46607407618962,-5.16874407606485],[-2.45324226943286,-3.05815357161105,-6.74650394998969],[-6.45493890730111,3.20092512361186,-3.89661014608693],[-6.0092758129702,-3.52572584078255,-4.95609285275441],[2.20201701866125,-2.86546148525775,-7.39886008395912],[-2.68683907228837,4.59231875322074,-7.68693366732867],[-7.1324723834243,-5.84311007051675,6.85989235823527],[1.47034416844842,-3.38911853607293,12.700146157108],[2.39180064974069,11.0960026921914,-2.05204590531947],[3.30064404954921,10.8181596747022,-0.867233454984675],[1.73702861872042,-4.26985458158445,-0.129483263692344],[2.72750876471548,-2.1823872496609,-7.04547025878113],[-2.77854743725258,6.90253645184937,-0.492348628055568],[0.827059753023738,-5.94381773551711,3.06563747462172],[1.60475844973676,-6.65853620388809,4.15257116722726],[0.922500477938431,-6.24197681080121,0.732391252351834],[-3.49966379002454,0.174562332314543,3.28254483807882],[-3.21978908317009,11.9342789085387,3.428343993003],[10.499863691237,5.09620235917527,-1.68339864105066],[1.12395318908221,-6.88002496918508,-0.304746461405282],[8.63868776622092,-4.81411814785149,-1.78048660133093],[1.20399817944416,-9.54985162397443,1.2603944203722],[-5.14667839834588,-1.48699217551735,1.37822089250615],[1.25801366406592,-2.29306394228497,-10.7336425857945],[9.54470935733085,0.0638446377891857,-0.566529599304538],[-0.216362810731739,-2.75927680851071,-11.8426136048176],[3.80397332619136,0.00625750219267829,-9.36547761976472],[-0.982975025235958,6.37665747941067,9.11472876474133],[5.17327295626507,1.27993562797424,6.13725001498726],[2.44968210575421,5.93298045674628,-12.0247009265796],[1.99501529352599,-3.57422822966601,-4.75717725490687],[0.475770623302457,-2.77219551558647,12.6249889961256],[-3.04853797998717,0.376213880855266,2.42850100370396],[2.91551379729701,-9.53965497043638,-1.31702586632658],[1.7644051143544,5.9805722125365,9.32117425792986],[-4.28053928261474,7.15426010049993,9.41230437591998],[8.09184258628294,2.7753029127612,-0.998353618629284],[1.36212349177826,-2.88749450166874,-7.38651159717279],[-2.606296416577,5.11463395066472,-7.08709321988634],[-6.65809912296649,-6.41502278159595,-0.242343156753526],[7.41770384387743,4.46009976258687,-0.749160743547262],[4.60591871308261,-5.29315315963647,-1.79212326224673],[3.37637047372558,-4.66653274702305,-5.18698550197913],[-3.87016863616759,2.57256340260122,5.08208305335638],[1.72121258865836,2.57565148916038,-3.10548818416108],[3.22647048955192,-7.63358055942036,-1.41507366856114],[7.15596962293323,-1.04465398907074,-10.7103570620049],[1.87705826586835,-3.00216552916683,-7.61258792425629],[1.85353643303512,-0.0355029669532519,3.86525450091141],[3.4941720564781,11.2908398477078,-1.6745774855711],[3.72329924388283,12.0124946167536,-2.61554477486858],[-4.71858520305426,-6.34710497586894,-1.08980378453001],[9.88503896158183,2.77978176424996,-1.90563603877907],[-2.89745568843141,9.14310693171835,-5.66795466580123],[-2.86397631653305,-3.962333748409,-8.96102847735632],[-3.78682476543774,1.55701188245204,3.55841441932748],[-8.76920739771415,-6.09759848518697,0.77392477110573],[-3.71943456611182,-4.92691764715678,-2.19744750511651],[2.32836324431885,-8.36414200682491,0.98754604306701],[2.52103434535794,10.5026726123972,-1.27009114423757],[1.44360663299793,-5.34707264713061,10.3120791350455],[2.00531836230746,11.7165756285718,-2.50670879550624],[-3.6498057287084,-5.11493137564409,7.67708090376117],[1.84128287094146,0.641030382774382,3.56945354674681],[-5.13646390667134,0.877850019149219,3.79140586416685],[-2.36387423719298,-3.37381392318424,-0.598687627611257],[4.02277301853486,1.16622765464749,-9.22007561059826],[0.425553667252424,1.50079995568187,-2.25993844441927],[5.9865781432479,-0.735312101613747,-10.05168066864],[-0.0288746470439885,-8.56841847766767,1.62159179545988],[3.55521945530175,-5.18664370599431,-5.40696414666388],[-5.63328246826372,-5.76909249919107,-1.63299511627027],[-4.6472300435569,-6.39560276906744,-2.67011049644563],[1.96742940775093,-6.30808716056633,-1.32383050908183],[-2.65043249303387,-0.620739589170068,1.17868796892472],[2.33994421499713,-10.3800843058989,-0.165105330128999],[-2.97477035176241,5.45155551826,-0.889058688839102],[-5.83555167228691,7.76520041293346,8.95433450663729],[-3.71879674054173,0.407498028589176,4.37149690062082],[0.305423087922243,-5.23574932310891,2.93523201824662],[0.196948986018017,-6.73313041961295,-5.91489389449012],[1.79013247395971,-7.05535005730918,0.27475805991948],[-9.57337559610369,0.0455068906197076,-5.58235722076529],[-4.68376862174305,-2.93092870474655,-3.1663791685983],[-1.37859783092209,3.59096488394317,-2.2542108491525],[3.09529742378956,9.79800857655393,-1.28708928795569],[2.90235563309848,-8.7428196025777,-0.739083159091201],[1.72635173291961,1.13611180759205,-5.46317968293727],[-8.27416211918222,-6.13186172471231,0.502084298436521],[1.80319499685775,5.61960849160985,7.35307575057283],[3.82327772541652,10.9305933916602,-1.58205525293026],[3.42039537398995,-7.5553673247537,-1.32344792506952],[2.81072394959648,6.38733215395167,7.40035072241604],[2.19618642254328,-5.18782556148018,1.54851720780804],[2.98149833551937,-5.01695147921523,-1.75379666076539],[-9.20454531907433,0.704590776958828,-5.56450167997685],[-6.12285168384008,-3.36604220502204,-4.44824989271757],[0.346076736617962,9.31604815429993,-7.42974183259764],[-3.23854333359049,7.04653484267168,0.117318100651289],[-6.20394266262212,-2.90089567088703,-4.60427281120824],[-6.36900153962449,3.23767163659392,-4.06967396825836],[1.91353588149541,-3.94900701655356,-1.53287873461786],[-2.47949447760059,-3.85708949219548,-9.46258901899331],[2.36820327090708,-3.26770673721808,10.8055408610378],[3.48135701100145,-3.35681809160483,11.7895951477448],[3.44228008164963,-3.50040390801041,-10.3502853715426],[-5.33858862042526,-6.84306694360556,-1.35729545419959],[-5.09430485736852,7.69902560797914,8.14462925482882],[-2.18350593852276,11.116668834215,3.07914222252015],[1.34850494068964,-6.53033008558598,4.2623795498212],[3.46369300277202,3.71201389864661,8.15945433422011],[-6.51051643984288,-5.71584815290904,0.647643184346449],[1.64345092704558,-4.71024413994756,1.97328669560861],[2.08276471018378,-7.79189711373469,-10.869316568436],[-4.99879388627776,7.48494905824933,8.98402971361174],[2.7154780574595,-6.77060197796587,3.78083331551593],[6.6949537206075,4.8518309881317,0.24515768243228],[-2.76234217987321,4.67770597209651,1.01013802486341],[-2.06607451648901,-2.89491063044132,-0.337431482066573],[-5.4198463495783,-0.926199777510631,0.367060893787951],[0.63079945712561,-9.34644916215795,1.32662223286568],[-2.39183554252692,6.55700514206812,-0.474973852407784],[-0.795389412697709,-4.80140363941619,-3.87648850776411],[-4.09510123789115,5.33894263447335,-2.56387474606226],[9.80561630023269,-4.91519431352005,-5.29230826281307],[-4.4746498924583,8.3043078139171,-6.55693718551276],[-4.11984235500179,8.0269463153499,8.35524227188307],[-6.21861185387334,-3.31403016750511,-5.0833775646153],[-4.41742089271434,-4.17426536831204,-1.45273464828573],[-6.1856336222307,7.64307955308965,8.3155323208429],[9.76006957750456,-5.03579854637481,-5.2208625939016],[-1.83985899293112,-4.39963599732808,2.08828646259876],[2.46231045180448,6.33505433192936,7.80083068847705],[-2.89348925810245,3.79422463688934,0.312088350049632],[-6.88107838091234,2.70268997019431,-5.1932649328813],[1.97920861844788,-10.2381738103703,-0.780282100137077],[-3.67148146999523,0.717346263356028,2.40597260683803],[-2.0675632841627,-1.62888601919005,1.30818467859591],[3.41845066883711,10.8563424647182,-1.56133648259008],[2.14920697479555,6.29281895185537,8.05450987313665],[-3.40806587028986,6.76935943664083,-0.574110439468488],[3.92540399194688,5.27749476502263,7.54171327381927],[-2.38243649629164,4.77306033311108,-7.41196998370891],[-0.187804062504928,-8.7386070103182,0.497212566127778],[3.8161261102547,10.8276989416085,-1.87891147088936],[-4.11020449655939,0.270122744151931,3.40539674073123],[2.77465368816639,-6.97712598484351,-0.942457591586489],[1.66703458783629,10.5655270091431,-2.75147442985267],[0.757816165503032,-4.67390411751389,-1.66313423816315],[0.749282584716112,-5.00942792746889,3.0766371809831],[4.19735331474653,5.73234038353883,7.47189937379872],[-5.50472650092073,-5.93115645269913,-2.36818350111268],[8.79218769102874,-3.60703597271065,-1.67594442214816],[1.77933267126334,-5.06562586390261,1.00638600170451],[-2.90612552084369,3.84111405633619,-7.39648535096272],[-3.10030092768362,1.33349436955084,2.26639901953377],[-2.31993791864,-4.28080869267349,-0.156248698170741],[4.10966256143051,2.15140481201034,-10.1881672708244],[-2.50674405942083,-4.32203135287525,-0.534821992436066],[-2.56666535808122,-3.48100765256905,0.222103024116636],[1.14989210177211,-5.2031580911215,-1.57232391740293],[3.17010614746415,-0.355319247486436,-12.1572714442013],[0.694280052724436,-7.02750804355247,1.34508246074924],[-0.99443838607324,4.46864493252067,0.403663719775667],[4.62385355785631,-5.78598480529504,-1.7697137945392],[-5.74708972630994,6.75078232984514,8.85626536680923],[3.20260018834328,-8.14570491694068,-2.19485513754609],[-3.2230015463837,-3.35364441851202,-3.19377538335218],[-3.79924225583456,6.93933566095237,-0.94886725139074],[-0.714908256628446,-4.89370002446923,-3.71765031069824],[1.54757533101894,-9.38634204821175,0.970688644011363],[-5.03349265114431,-5.7170432042966,7.62644959224829],[-2.64375562737344,0.325043189168552,-1.18397629506158],[4.40677323431366,-1.42557151999229,-11.5353465699763],[-4.17964506077504,3.00492154709534,4.98727122977928],[1.5390983304393,0.691542481734728,2.99562706490969],[-1.67274122387746,4.91282576557888,-2.70656353969433],[-5.44472722055041,-1.5600141699074,0.513188158249403],[0.803470692410414,-7.83547971016853,0.048039457105513],[-5.330685639241,1.4926613676184,3.1224307390574],[2.44174631503706,-8.80473931138637,2.72820456977286],[-2.97177697877083,5.62140808760298,-1.65367902141642],[10.204500719777,3.10297894131107,-2.30320123831723],[2.46639104374639,6.78884354915774,-11.7894782769895],[-4.40648381106696,6.97501050804894,8.35850235291547],[0.892551566761732,-4.43392615554584,2.68160503360735],[0.891885102706054,-2.45993489628112,12.9054275071445],[-7.60309972096401,-5.59966755037708,6.85659744216101],[-5.3423487069362,0.00221914504754794,-0.554336965007765],[-0.71205021243938,-5.39835776454169,2.23060150438981],[2.11290192476925,-9.69033986689712,-0.202868975613199],[-0.36215555364441,-0.0495417579148816,3.23451803246533],[3.45944445227403,11.7921769597874,-2.84236737566006],[-4.08038386737003,3.00946530329412,5.44766552328521],[11.0036169830083,1.46338955655822,-1.04696006282902],[-6.13730322395232,7.08855099551417,8.73175602523663],[1.2180501433075,3.44658917726447,-3.82236501176893],[-5.99338876608765,-5.07796850502961,7.60673557087561],[4.09002777410344,6.03164882852949,8.59441662396582],[1.21918866005704,6.13027374022722,6.84283449095583],[-8.64022550538603,-5.91443293162992,0.473678920376955],[2.14937036546434,-6.5888211697841,4.26770917666212],[0.337260129271966,-4.65964471499353,10.6047046307968],[-6.51980295396897,8.48337561297513,-4.098359841813],[0.917754375348732,-4.81459460159819,-5.27128189199061],[-2.54569401625404,4.11408204378255,-6.94068201098723],[0.3460196494483,-3.13527411987727,11.5352220235914],[-4.42709892278041,-6.55441254633796,-9.5979174676896],[-2.29588510908154,-3.45180000414653,0.219255306288209],[0.110545053909473,-3.66362598532911,2.81342206803847],[-4.12020985201993,2.33787213232037,4.6619008249074],[-3.63656100114719,1.99603202545992,4.14114994222286],[-0.382950165716588,-2.19005346521444,-2.09815384671669],[-6.12949123301439,-5.86347108122983,7.39932346579927],[-3.93771513733018,5.76624325393522,-0.0709246555120994],[8.45324862737112,-2.57721113060793,-2.63516724259488],[-0.736668356932985,0.519338176785246,-2.84263313845919],[2.90705428515831,4.16089401322004,7.74339728325135],[1.34874061913291,-6.87989341652961,4.55201767329595],[-4.39241468944383,1.50328935990591,2.54418357811782],[-4.94083174899974,1.95655061033107,5.03372468362649],[2.29218764706248,-5.37122669459622,2.01258755934241],[-4.12130717508486,5.93329969862689,-1.5706502488727],[3.79567580280617,10.4865055704695,-1.10494550763926],[0.335046180806317,-2.04682581410769,-11.3989588296512],[-3.04266567826535,7.28259529534124,-0.362598035501894],[-1.91542795432742,5.38477126824542,-1.15819617595587],[0.120608709427531,-2.95194991251094,-10.4684530218879],[2.53186870822007,-3.30218732695722,9.72792829974148],[1.43355644369489,-5.10985797984945,3.83101075905312],[7.73260338199954,4.41735064956592,-1.19950761907443],[2.87834347792698,4.11667403282327,8.25036879250814],[2.13503798199979,-4.39001348601326,12.0535199058884],[-0.0737408948025193,-5.29222349293143,2.03893516904445],[3.68680559877087,0.541950978776103,-8.7061507231772],[0.280300767225507,-5.76833764464505,1.27889495588378],[4.2453978543878,10.7181148467194,-1.53577506924538],[2.09832363841778,-3.75740480780522,11.404364152739],[-2.34749472869624,-0.078281012115738,-4.03552726675054],[-6.06721930560825,-2.73909370968557,-5.02713302292857],[-5.88929530916776,7.53767326306441,8.05175574542164],[3.92690304406906,11.9118965519071,-2.0135228544277],[1.58394765079525,5.5407338961097,7.31574237364384],[5.04694351970367,-1.87654581665944,-6.75463738694503],[3.68329862292445,11.0462958786559,-1.38393706242014],[1.98386814375137,-10.4283225932699,0.160896023166034],[2.21479721510403,3.38285482675098,0.491406894982738],[-1.08087600325481,0.939215756810562,3.85312738300636],[3.25046687555663,-8.15199409358272,-2.30568448448253],[-8.73738501103086,-1.36378330228059,-4.12056787559126],[0.83093168845118,-5.84612090543548,3.81280661583724],[-5.82807549029935,-3.36339736593491,-4.77948141192261],[-6.81899426041716,2.5470787837265,-5.58216355510968],[-1.96719149980829,-3.74912956574423,-9.23549309412157],[1.15965319375476,3.8383104649351,-8.39136738649093],[-4.54120098390382,-5.62991874599667,-2.10460702982198],[7.73852473635137,-1.99500986628564,-10.5685145260169],[1.65963497957819,0.368707163727258,3.33039730001197],[3.15835074705288,4.7394041490344,7.28990985538114],[0.100969658195193,1.84756735559777,-6.57815587120264],[8.67376521578258,3.11447420980789,-1.3638605240397],[2.54538764276934,-10.4468551604672,-0.541849155814979],[1.70627631740887,6.38421079529261,7.70009039975011],[0.507717876393992,3.48931853236339,-6.55343258478289],[3.12569590722058,5.58050000963845,7.01918075646004],[-4.06339557002397,1.85064134729139,3.23173432401893],[-4.73717627117047,8.96921462023474,-7.72460527656835],[5.26394162009731,1.27747254838839,5.8445274818602],[-6.33702108381722,8.08408185969384,8.17472779700938],[2.849651140292,6.1764935994991,6.60256029335815],[-4.66492324098689,8.05708864155575,-6.97764999062828],[-3.70170296069505,1.26776253943591,-6.15433977647178],[2.99475289691604,11.2631806701861,-2.22728590135067],[-5.76010716841333,-2.74811083700426,4.81738027060872],[2.61722570358833,-10.4646599295453,-0.998813774070164],[4.14463310669343,2.24687133672474,-9.49547374759164],[-3.35975292408828,-1.64115253490428,-8.31001492829999],[0.977879023091393,0.744797609748233,-3.06987173233474],[-6.07153392618147,7.56601368195599,9.16678185060494],[-2.2622761489027,-2.51753437410899,-0.3929440619819],[-5.37324543626862,-0.429367254848958,-1.23030498303222],[1.63223462949093,-5.61529790500683,2.49090689568398],[-4.49464934459059,-6.14304003737336,-2.07817280904009],[-0.699345783305876,-7.65803906030253,-6.28912793752259],[-2.96827838330391,-1.19356884773413,3.43367287385244],[-1.17437881477556,6.4875907818407,8.99388272673762],[-1.99048304989844,-2.18463325144051,-8.82721190041154],[3.05325086345366,5.96229902841463,-11.9787785518806],[3.70298554964354,4.45615739874351,8.62380851307082],[4.08341288486896,4.54827575750647,8.19213006106811],[-1.9022731294461,4.81066035107252,-1.95158723574105],[-0.43863232201445,-7.48668848125142,-6.10915589310018],[4.39448992760243,4.85199052043014,3.24135022960516],[-4.95850583632661,-5.78899328529042,-2.87871387663663],[0.168855997120708,0.384859577721769,-2.41440784177151],[-4.23401408515341,6.97709600752294,-0.446594444181529],[-5.31799883895318,-2.9907499767457,-4.81220148395814],[-4.42227976755438,-5.38534574749479,-9.63972035147639],[-8.56636875050077,-0.353348102469219,-5.27797285814511],[4.21986626904887,4.98765850650348,8.05104863541609],[2.32165359110333,5.83237094904413,7.00971595431605],[1.50750081839095,-3.11339596354452,10.8556461873879],[-5.92359795717769,3.04746866898929,-6.32083477065618],[-0.205508278959828,4.70064675220364,-1.72436364170731],[1.7732959950239,-3.68708402388735,12.3999395347448],[-5.33115663807752,7.55719457057689,8.74165873841103],[4.00860708344843,6.00553884154522,0.12806869078273],[-2.88088089257091,-1.66387912734869,-4.01298970729397],[3.73465438672471,-6.77755948053096,-1.67027477848775],[-0.556730445189382,4.62079445959972,-2.55026021645765],[-0.878290903798258,0.178053726492892,4.22704049627753],[-0.0434216280066477,-6.64692934199418,-0.855979657322219],[-4.37931573852148,2.56044394152155,5.45570844176613],[-3.03333862535278,-4.06222780984151,-9.32515554675157],[8.07815772975849,2.16251163372659,-2.15339358617751],[1.15088500037286,10.2859943830052,-1.91674171566006],[-5.19253029083041,7.41772596573865,8.07070898018025],[11.5321305510159,3.1979979417819,-1.49022270477203],[-1.04423067051796,3.1876811959587,-2.51139609168188],[-1.6431909675424,2.37271110217636,-1.25195138516536],[-4.96145069542293,-0.592924933750411,4.2339699033957],[-1.89852491465911,10.2390145812157,3.61892438552202],[-4.82146162721857,-4.1540406531781,-1.83359680105211],[9.56282047605199,2.50548945967557,-2.06001264353659],[-2.61979549647709,-2.90544625310023,-0.0720143211369371],[9.74305089945485,1.25502099050255,-0.917324113274157],[0.534880436039645,-4.97661385759705,10.7004390463339],[0.12934838438538,-2.79109386514998,-9.80902213907743],[1.1112137536541,11.8225343374352,-1.68544378179201],[1.47870726179385,-5.58899608180821,10.7743360183333],[-6.33697956851083,7.89858262031083,8.27175350094659],[4.48694638612119,2.04511644104249,-10.0697543502062],[-8.88660143135217,-1.00034466371226,-4.76777817214005],[-4.70098887045858,5.87106189814464,8.88033737643595],[1.35023825285299,-2.02867355099456,-10.2662275325756],[2.84322528598047,6.1987607455461,6.96178829183567],[-3.8704901949275,6.09202501608804,-1.35631421329492],[-1.95434609252111,-3.70710000063573,-0.139362042729563],[-5.07450040058407,-0.662264573577307,3.08895745599635],[1.41986543891058,-7.16135297201355,3.81182332637508],[-3.26041092499761,5.4325512250581,-2.82375468551367],[11.0356187289794,-1.52144759097275,-2.107334217034],[2.84799840482746,-4.14506667708504,-1.30544877796687],[-6.46873165178123,7.0326156123992,8.54564573529633],[1.13195812187025,-6.41145144733964,0.601473186236303],[-7.74980003129682,-0.141559800606993,-8.43624400798794],[-3.90241165134412,1.02510775671864,4.87423440433135],[-1.93758081409803,-3.8968173101055,-0.148407425536444],[-4.9248376610229,-4.79349311334606,7.18799030651391],[-9.84178846509697,0.521537130184446,-5.80373124186839],[-0.600341724148558,2.99266715596458,-8.43150065311763],[2.92773069077009,10.7927884877193,-1.69345079171029],[-4.39998715072876,1.42166804399672,4.20851814194884],[-5.79583448612792,0.00187366937102684,-1.64338005024793],[0.882289231544494,-0.905288235703893,-2.56262828863525],[-3.40229578566386,2.62445552642695,-5.55905363147893],[3.49079426146972,-5.5952438329486,-4.76965809683018],[-2.44207306259074,5.0256568495883,-7.69565342499817],[1.55220388649369,-9.13499550001459,-0.79202328210974],[9.18431469899242,-4.07381866591145,-1.65971806561208],[-3.99332171699067,7.93278639586397,8.82089871036275],[-6.20424525084035,2.94913235824148,-6.1828576144112],[-3.60975481178714,-5.99357216301448,-1.70667031814353],[0.403965239671497,-8.24949232353856,1.53300869104268],[2.99563854125936,4.05902390950736,7.80697436772753],[1.67176608658494,-8.55736458425712,1.67408377436736],[3.98181317139279,10.4097092671837,-0.717034611747968],[-5.09385564855289,6.79754630597424,8.66656446730122],[0.796371115361962,-5.42711471141146,-0.926640471979763],[-4.52589035511627,-1.74598252285724,-4.53049017262987],[1.8789388048011,6.45276202979206,-11.5410212740148],[-2.87854379053224,-2.02073493153959,-4.72045844534951],[1.23802273972886,6.1249193978093,7.39365139738712],[-4.0722293875093,0.0544465465397007,2.1200882298164],[1.37661144392554,2.4322192717559,-3.40730903547326],[0.571796016178621,-8.50944118394107,0.173613376673243],[-3.45031568117153,1.07228037564658,2.28711647969231],[-6.41839436768478,-7.09899443624745,1.41847628679224],[-4.24045250341973,1.44466093744851,2.4432661419026],[4.3420535106215,-6.01449568111173,-1.21172523855615],[2.17143658260959,-7.99561626186641,3.9756230408126],[-4.5607786725457,-5.61689972445772,-2.63673273097383],[1.39820933916557,11.7151208742735,-1.75144662823944],[1.77945892433794,5.96896439218891,7.96113226683087],[-3.58004802382824,5.18304317279726,-2.41428708836366],[4.49356308070345,-3.05670640899984,-3.90343665672751],[-4.467383754256,-0.11310529733255,-1.05621392126158],[1.67113373289422,1.67707090521772,-4.68539970654361],[1.46657124411899,-7.75878268938979,-10.4358576766203],[-3.98841204052098,0.191846784247301,5.28033263669045],[1.35273545407013,-6.20871048579668,-6.02295376376655],[10.2989360564556,3.44611558206532,-0.522275079180947],[1.45098866685946,-1.05211595867782,-6.53357893076434],[3.35758904117288,6.52233524045905,8.65602083106647],[1.63288334442273,-4.27342034596487,-5.05403667867898],[-4.7644256069016,6.61061187803283,9.02095400219395],[1.36617368511839,-9.13632066562795,1.99593540397773],[-1.11371669505046,-5.03563838478648,1.79343014468233],[-3.44862651574137,4.40213511322718,-7.04550870521131],[4.12213749196361,11.1596854388851,-1.2227746477427],[-5.43059238938331,4.04587444701328,-5.45549892092335],[3.46644853071176,3.52625179146166,0.496846631754417],[2.27896542006578,6.6274200375194,-12.1095928651063],[8.19678751091325,5.58565569429964,3.04589026830797],[3.77661096090098,5.46282583252857,9.15366508182834],[2.89856064511154,-4.40798393354355,11.5833876581998],[3.14688857255944,-3.41104537175719,10.5907998702096],[0.603196081951838,-3.31037584522124,9.89301538630923],[1.93533143414372,11.5155039199736,-2.60907068633632],[1.47683298071483,-8.72012986894538,1.61521586863904],[2.80576134710759,6.70842640112284,-11.4145656087253],[3.87291524655601,-8.80585365205845,-0.0238052782512452],[3.23483460811843,-4.43749315879823,10.4753776485897],[-1.12317079473839,-5.38268194542033,-2.00750205048165],[11.6432404063166,2.94310430614444,-1.60840674950291],[-0.641556672808207,-6.83588005494139,1.77666102721267],[-4.73188427274758,0.374367863057233,-1.10544010665619],[-6.39420482261098,3.34028979322168,-6.21281774679761],[3.66388213297169,-5.0382127541513,-5.43921436304222],[2.95025449740408,6.61832459900483,6.80878157923185],[3.13132733205855,-9.59520205404841,-0.30408355881166],[2.88110848717567,-1.77880778529039,-4.66953376325664],[1.40481006136687,0.0242641469706331,3.79206164838397],[2.39365450843759,6.08451611003251,7.29636996433055],[-4.67898515272937,-7.13214005467102,-9.84186147538115],[0.742733569117732,-3.41661489611224,12.8516500708568],[-4.88140874545976,7.45460117992524,9.29831237438727],[-1.44753003007994,7.35982272516786,-7.04280500115325],[1.93469617623798,-6.52625362442177,1.63630017900416],[9.87096252066721,3.12752906802026,-1.91733916678735],[-6.08637774982669,3.78526672731234,-4.69295958670943],[-1.82605251078217,3.37648571585578,-2.49473987012458],[8.82908602275955,-4.76120911002087,-0.813610454381687],[-6.44799073670619,10.0152811311212,-4.20681285762723],[-0.00980294527136649,-7.31663844569372,-5.87104104630671],[5.10237216985891,1.92135959990949,4.74137177118063],[5.25074563341927,-3.02593721738594,-4.14465941562526],[3.86617584959914,4.25691521901395,2.12972549914952],[9.46834097844481,-4.07894622703728,-4.43885709429667],[3.61491248283084,11.8856491390045,-1.72110768769235],[-1.96051780780243,-0.700763372891098,-4.69164161018048],[9.86202911838594,1.68154341338141,-1.65636707739478],[10.1519152996243,3.81445867019178,-0.805858313596703],[-3.62698413569463,0.32886704995546,5.13970694968198],[-0.733960099725038,-1.31395007340215,0.1214103104363],[3.29283840750947,4.65660923295025,9.13662907545421],[-3.38270204276251,-3.65548186009166,-1.32713890505829],[-0.490753706125182,5.92331636773648,8.60078361488019],[0.753399467261758,-2.70774625018454,12.7635295027016],[9.36123867911593,-3.83652482371018,-5.56321385711487],[3.20302541026529,5.83149535587719,9.07878033635381],[3.11990517265694,-4.32696130535721,9.96079749518181],[2.0365825150932,-7.17831805327784,1.64693809123476],[2.19246415242224,5.23927254562171,7.44667952481508],[-0.731771915742819,6.29070096761854,-8.50835540724099],[3.89146302853895,2.86413518013191,2.99679373299516],[-6.2281283907158,7.45685282380591,8.7632721957628],[8.34975675746571,-3.97120388236435,-1.31122179180104],[2.28799140236496,5.9490261190698,-11.5270166460896],[-4.96194532909425,-6.16898528460947,-0.757216497313216],[-0.55934394012514,6.27619167807537,9.09799125167141],[-1.7874507964908,4.47865439510734,-2.80706105312763],[-7.7567503898395,0.528956412832182,-6.68896181421465],[1.53977750757838,0.333306878839014,-7.3500321422862],[-7.01360557148715,2.81654452506906,-5.26466445291282],[0.958200662039767,-6.851316858187,2.04349272407616],[1.18320855741009,-9.14953492291732,0.897630795492494],[4.46841247806055,4.73412090471214,3.33509059658508],[-3.51214893213489,0.338042205930414,4.63757182110956],[2.51682773622963,-10.1540589779122,-0.398387658733751],[-4.81087892673288,6.76690409931778,8.39819369271086],[1.36419545487689,-9.7179472502995,1.4886751563364],[-3.45538939444964,11.7210124450716,3.33624717979671],[-8.49281555125004,-6.62475548801364,1.18982293951693],[2.95852121972774,6.29897978144137,-11.7518846978955],[-3.53028547971163,0.31530023985815,4.04746627299852],[-6.9271487087146,8.92299609413418,-3.89346189005818],[1.79247142271468,0.578536251405585,3.30909198300431],[9.45222296301145,-4.27115424339523,-3.98398151172992],[9.42205371692581,0.920671192078104,-1.45768621355039],[0.408450968329081,-9.02924049656853,2.06139920008228],[3.27071599273707,5.90341652539345,8.97137512796822],[-3.1476718669731,5.65456260769765,-2.77577600387337],[-0.194455737383726,-4.67414699599462,-0.807412055646288],[-7.70177362480501,-6.41946138488813,-0.0293523396416956],[10.1173014404483,-1.59906999866504,-0.126576892057131],[5.14890011527195,-2.91119216207312,-3.9730848980477],[-1.90880152611365,-0.353584342988249,-4.71291865712527],[1.95634182008549,-5.5313521303958,1.0551679698447],[1.92707406103629,-4.04998226196552,10.7684112112888],[2.70953610937741,-4.82582139611133,10.9191359673026],[3.92525385021541,4.69337177416397,8.38797113371281],[-2.93341624963636,5.74792639347174,-2.92990407757088],[5.07484569683262,1.94815464501463,4.41155467694107],[-5.40631600285066,-6.1878629716872,7.73419116891871],[1.70743071727391,6.05619969946897,7.21045397543156],[2.88793244744931,5.26299557706317,8.76091318960409],[1.26100047876239,-2.77653998319638,10.4711577845392],[1.8255695639264,0.343381459628195,3.26319824429342],[-1.24756158148884,-0.524132292763405,3.06421842939603],[-1.86077850347565,5.34111714224885,-2.71917277047006],[-6.3353542202882,3.3777455687225,-4.91614946186873],[-3.6222457978727,7.04105299331939,-0.268348036219795],[4.55009543104554,-6.1334609252454,-2.47105054269982],[3.63731512660257,-0.281654309207626,-3.34613089843254],[-0.18909958782225,-1.88821359857943,-11.4778231022947],[-6.24213272824839,-3.07504652386074,-4.98076375248275],[-1.68398927430088,-2.08793896887069,-4.11929497151128],[2.52008602989682,5.89931928856085,9.45133742183038],[3.60615874261122,-7.8629173695226,-1.69764123692906],[1.58346853010442,-8.94605159593388,1.56154897889467],[-7.21346395210789,-6.14858273264485,-0.495939921181639],[-3.52719980267225,0.171923874159463,5.16168928612608],[0.603003213794476,-4.0364719548723,10.011396006681],[4.51768392012968,-6.57930154767932,-1.67602586493741],[5.15983538263424,1.39048278183883,5.76040200579967],[4.38515084433094,-3.01079285681471,-4.11470415885272],[-1.87202795247541,-8.25567633620419,-5.59867002256418],[11.0820172461201,1.00338146907194,-1.70250778132852],[7.62682136798222,5.41357267029951,2.39763338631174],[-5.84569455011509,8.53916471921756,7.82356421330003],[7.67662989153105,5.64002456603564,2.07367594283599],[-4.12810362718816,2.95937803098847,5.7517769199227],[8.637799834665,-4.24111176719487,-1.60692767439295],[-9.23865417405858,-0.355379890315312,-5.37463034645424],[-4.21237435987942,-4.51079463503885,-1.50048101083138],[3.34851222695283,6.44877387230707,6.75263606795131],[-3.73214833769728,-1.91703293849771,-1.16803796456436],[-2.31138412119964,-5.46263541445935,-8.29241973249665],[8.159190364731,4.07137388872682,0.0917913363000357],[4.36231260953732,-5.51559879887775,-1.22630812971054],[-7.1518373072568,-5.92636306229157,-0.0356817601319915],[-3.94157480385612,1.59919732250906,5.31637118970227],[3.03825536128537,-9.22565136078855,0.97334042458253],[3.78579173776488,5.56840064535915,8.95142267972997],[1.57104745572223,-9.5419582947494,1.58496213177404],[3.89953944784111,5.62831984075975,7.03708770940323],[1.71691016210204,1.51180432074003,-10.3398449267631],[0.322996755965843,-2.61016952616257,-0.959989337743773],[7.28041291116279,-1.09430182882276,-10.9640979722466],[1.2865128924891,-3.8272315682309,-1.65175996949969],[3.0397159534764,11.6781242804413,-3.10114993894062],[3.69459746225824,6.14710354629049,7.9905690745095],[4.81024311860488,1.51158962860418,-8.40276712789958],[-3.07810932203977,4.75644473208809,-2.35309635439195],[3.84131492426576,4.91603771685987,8.86541917154454],[3.03150898952285,-0.16525590783838,-11.5418673968094],[-9.07249136621401,-2.0026389292992,-3.64493980134758],[-5.75039023051598,3.85162402930742,-6.33165592585548],[-3.93302690044908,-2.1161565403671,-1.22407380627298],[2.63572436479343,6.41373633883998,6.9131219940496],[1.75037805525519,6.72132038478559,7.58091980993089],[-7.42958476575755,-6.61029485724176,0.21471532855564],[2.34877338811546,-10.3701659254033,-0.201465630010176],[-3.23013824399227,-1.54173846061654,1.77011796033225],[-2.52796960215942,5.85810793927223,-0.399194665927042],[-6.11072034671272,2.67756753902125,-6.47352197581862],[2.62214440173637,-10.0065578948784,-0.756189990372275],[7.92837936713282,1.97542315830332,-1.40421095099238],[1.04926770302433,0.344786816945269,3.73975169045043],[-2.56134225367079,5.02190288362554,-2.09295056083884],[1.43225102171887,1.63175471772229,-9.7041676554804],[-9.69692925935837,1.04671748969701,-6.11079247117011],[-2.57948842232398,0.553535509914667,-0.940576322632344],[-5.28486312880343,8.01414406823435,8.932651765537],[-7.10855869225432,-0.552529472913696,-4.56713898687273],[1.0003774607752,-3.20436331741853,-11.959904744215],[1.49555977622404,-3.65409301275535,11.7383531247443],[0.6485435376835,-3.78984959921321,11.8754874829882],[3.65693624073341,6.15244840469749,6.98938981866756],[-5.73283954559246,6.84997339749435,9.06352114802174],[3.19040454194249,2.87639114033234,2.92979461564227],[-5.7105435602739,-5.81293525843485,-1.11279233414429],[3.85394709297507,11.5028149303591,-1.65220561180106],[-0.0443202614444971,-1.06848732458161,0.774652376445632],[2.49667860504398,6.49609614259636,8.82708674246394],[-1.61207778312788,-1.90891895326198,-4.25424826820239],[-3.08870438879897,6.68234136917774,-0.52951505864201],[-0.197180848307479,0.417756787878525,2.91040958941972],[1.81525934414168,12.300064183064,-1.33027093220395],[3.55609932273803,-5.43333425088408,-5.42948009036829],[0.947349546033567,5.45491522965423,7.91333072966614],[5.38585844395405,1.32486356937889,5.54481435537402],[1.23213550999139,-9.59852458531333,2.11840768128265],[8.01037429663415,5.53361436740576,2.67876327409971],[3.03446274848089,-0.898106554812801,-12.2020594279509],[0.671091765539131,4.27388671772968,-3.82462451030119],[2.67026912703832,11.2478395138293,-3.16464625261797],[-0.74980852874681,-7.66248633614047,-6.02558596431636],[11.5971264600164,1.94540319371657,-1.27225959870404],[1.02653115991757,1.80613548790316,-3.42357957897828],[8.01278180299426,5.39853626078812,-1.26136647001413],[-5.01827666591471,-6.44179856060379,-3.08974185837845],[-5.07268057145456,9.38788556307138,-3.77934002169209],[2.42876419149073,3.70339737254376,-6.04871703751508],[3.86250717282245,-8.81729910506853,-0.130521778877109],[3.06530687454089,6.6059570557186,7.32965220850965],[-5.40106190116268,-1.36824738574027,-6.72579675930905],[-0.959255967613628,6.29888586385028,9.1904296536321],[-4.21877993930758,-5.15430156625134,-2.3544366862155],[-5.41616279686739,-5.65647641147086,7.87567672589561],[1.48444670147349,1.63470813999199,-9.91932800697762],[-4.85547066418274,2.03551337216323,5.36865960202974],[0.149447017431878,-1.6748877917154,1.06604398222409],[1.90811296406182,0.396838877959869,3.03281865002956],[11.5040215633628,4.40118805172946,-1.35866284556009],[0.314143172978478,0.791334650705451,3.62084600085622],[-4.20897989423625,-5.64286602284733,-9.49916558937336],[3.32235363528952,-4.61235983349025,-1.09414099194636],[2.72526797276658,6.00600242270107,6.50189400467704],[-0.235486659282346,-0.0414601708276019,-1.06209206775084],[-2.33558659848472,2.68238672840697,3.01708365236633],[0.743873892482122,-4.44673794148217,3.59808572113279],[-0.401479778225846,-0.674321543762604,3.20200992119979],[1.89506391982644,-8.13581556421102,-0.179592494261813],[2.37323159533805,12.3236772835404,-2.47387243417312],[0.715349149743973,-2.79636994359353,-0.183829974208543],[-0.0372803001627765,-5.08514011660517,3.12194007016219],[1.99046619472132,-4.9855032304354,-0.249508701620894],[-1.80104327795853,-0.966473417862701,0.902574102990628],[1.25460652276461,4.22361856031708,-5.1840709050044],[-3.68399351729159,-1.39759979507517,1.8975073064662],[-4.48457575583048,6.21124962717648,8.45643963182962],[1.85250352318175,-0.46440040556202,-9.80222766007178],[-6.02437124317816,-3.86418625519634,-4.18676867030231],[-2.30567808953589,5.08102588806533,-7.0560427609814],[-4.62026322426709,0.11012938733479,3.53076316394321],[0.21690655673145,-1.67844178610299,-12.9774040731779],[-4.85876529746264,-0.133976768901832,0.759263371046825],[4.34544214935733,5.38001892683775,8.52216459657412],[2.93432811945535,-7.98924305481956,-1.87551230843793],[-3.22611875851658,0.825345291953363,-0.980184578368179],[-4.23017808499237,6.23131234530225,-0.833822393086694],[2.59150935822636,-9.91093265745852,-0.425939365249765],[-5.25651082141879,0.677702174368753,3.83453326506341],[8.89496428210464,-3.77036184691905,-1.47365887733735],[-4.26495930585751,0.880187504808461,3.27008184408601],[8.72926213775538,4.90016520726136,-2.01015632892361],[1.40777574670713,-5.58979139773067,2.62858305621239],[-5.4411074991912,2.94400734409652,-6.5703305133101],[-5.09412712578858,6.14421233278933,8.6423539548371],[3.98779854851371,4.64757950776403,8.7904251992266],[0.324770548333504,9.10246084719767,-7.84108259893014],[2.72191432745638,0.258751806799954,-11.9381316253276],[8.75247524481738,-3.61243683106098,-1.47277397746926],[-5.62612267336923,-3.15421012033444,-5.01552023049563],[-3.63601239666036,-5.05918738221792,-1.35666393885226],[3.59059468422068,-0.360246159931639,-2.92141577542326],[-6.40993347268281,7.47804165912256,8.34744869597422],[2.80750838131366,-1.83629882690705,-4.4560903319786],[-2.55850786596279,5.22790804114527,0.709402221099186],[1.5207277179001,5.9308436020895,6.86418451603892],[-6.03446711823065,7.06917984585662,9.05176623015876],[2.55698699213324,-7.08029091431651,-1.90308459780357],[5.07523597910558,-2.172302970941,-6.82521980557211],[2.75127323584631,-9.67701860544052,-0.0939072525701574],[3.74171959835434,10.9405094961675,-1.94894286741147],[2.87119807860492,12.3732340519475,-2.064410161137],[-2.65182375604969,-0.172576696126468,3.08095243929034],[8.95807786455394,4.17298380049144,-1.01537037847997],[2.25470612285609,6.14037022770917,8.02851421879996],[-1.71171651530625,0.28054190722614,-2.53270826982716],[10.1280125394944,2.5631546223075,-2.21048832982696],[-2.74621796531658,6.18953911947741,-1.40631071773965],[-5.27007194094066,-5.28742840514422,-3.71905065104473],[-5.61653279372052,-1.42048090140594,-0.957344809574899],[2.90897182612374,-9.20510531034202,0.488555027570922],[-3.81372801747438,-5.69916490255527,-2.11667158632304],[-4.91947737672496,0.0739731048919254,-0.428666900704301],[0.462334931997233,-4.8499452313152,2.58619709710659],[-8.84313650711538,-6.73189015539112,0.818166158005356],[1.31125110978103,-3.45494527490755,11.7182323987616],[-2.11795757481169,6.70675655193259,-0.226859543692563],[1.29227408620073,-3.76176988818326,-1.58229571997701],[-3.98467815726956,-1.04016242311246,2.12272962197372],[4.15795111115497,10.6147737464687,-2.27886372182792],[-3.89746958876425,1.13319874746955,3.44335857878105],[-2.93298270620816,-3.01353266582441,-1.00137944157139],[-1.86381026208214,3.58296172820481,-2.46490059445372],[3.55045462897138,5.87268361926,6.71551319824254],[-5.65445414948157,-2.84940360792478,-4.6447463547334],[-0.108287918509239,-7.06603040645566,-6.09595365808919],[2.48754781236577,3.48877659096868,7.98957572733092],[-5.98767722575226,-3.60324558271615,4.66131092453801],[-7.05419904399493,2.62644172694397,-5.0390831363944],[-4.98312184650318,-6.92874194843017,-9.79644056011515],[-4.12427900399136,2.06385849617098,-6.49200252733598],[-2.40486378616266,4.57938220409342,-6.82637110554215],[0.886479118492979,0.159773370045665,-2.48239613879415],[-4.7575313267054,7.61384390121091,8.6880405254373],[3.31227826589817,5.66375954251783,6.78983948809414],[3.26123206892835,5.84242622102037,6.82457318606849],[-3.3390076994224,8.17287584809425,-5.86090703421894],[1.1079936912487,4.19710999755925,-3.88665504489939],[-7.47606691400145,-0.742640700244952,-4.36650250122153],[-5.16366077492091,-6.04857603309445,-10.0634471724532],[2.93745200021171,6.81154323143313,-11.5586369206275],[3.91536012585745,-6.94040634122857,-2.14828097832102],[-1.99462443721127,5.15122582417031,-2.60333113896709],[0.763591011985135,3.52412297802913,-7.0627276289778],[2.79608198332871,10.4598213766111,-1.79474284639364],[2.72274663469544,-3.06118472343257,11.4507358903387],[-5.20552853266186,-2.12050261980561,-4.62327006541031],[2.08051977139947,0.39965096414091,3.62697899225408],[-4.6340590724327,-6.41182743762811,-10.1370229080111],[-9.45176281403,0.965391848517488,-6.2646325274115],[-0.185570305580008,-0.799759290307585,-10.981924090748],[-3.13721098951781,-6.01050986403036,6.36735042243394],[4.00977797985935,5.88752737667755,0.269310973172752],[-7.29790975310492,-5.77540441770606,-0.0853878623977773],[9.04169256524481,6.70999562064566,-0.239696133870304],[7.80443965388799,4.40043662482508,-1.2891359675207],[-3.39103218776022,6.07519367519949,0.446177616454124],[2.83229423141521,-8.13946191891266,-1.8208698210619],[0.720929137964423,1.1781989260301,3.72714457508556],[6.95507033860919,5.33017524109713,0.0985851984450818],[-4.33600868584331,4.92336609328846,-2.52706374272669],[-3.70061244927766,11.5694003016963,3.82097724096242],[4.54135066247295,-1.60747360969818,-11.2835430067478],[-4.1548940832959,-3.60251227588398,-11.1537241090569],[-4.84684608783867,-6.06408544393196,-2.63199717186543],[1.45977914468221,-7.5393982073262,0.233431759986603],[0.587467975425866,-9.0607488603933,1.93176314765624],[-4.01519658878967,1.2920508094389,3.48074123969744],[1.27773817857503,3.94265404258207,-4.19101730875326],[-2.16918005605626,0.806790168113135,-0.798126668083981],[1.73419354147619,-8.72924281381905,-1.24069517308424],[0.72727065162666,-2.57105738498576,12.7086821477137],[1.39600905367308,-2.02268726928778,-10.4259590880578],[1.13111602569708,-3.58829736670712,12.6258434270222],[-3.82161342521617,0.669262500298438,2.54097107389775],[1.40090301644799,-5.16382803788109,3.74129262941276],[3.92354518987515,-0.0991379697981472,-3.66082862444816],[-2.9470839445892,-0.984689227060255,-3.60263954208725],[-4.37813042500714,4.93274788432032,0.327744590228456],[-3.88058195579401,3.26840587451524,5.56080415369436],[-5.4594138383085,-1.3217830596762,-0.879084214455452],[-4.97189622044099,-2.92509254593012,-4.04101263164483],[1.21367162920548,3.49261396857826,-6.28186899331827],[-3.34426571689107,0.353728952883437,5.12515085795544],[1.94647706904874,11.5995840984621,-2.67062135434797],[-6.57933262712723,-3.60504928718291,-4.27386012401461],[-3.68111083396153,0.976940168252926,2.29561489961249],[2.80794551487435,6.10449600569249,-11.6018868413368],[2.92182144145571,11.4812059453695,-2.85023712599724],[-3.82929676731845,6.51555591353585,7.94097396445436],[2.70196590565133,0.206125340922289,-11.2565255651233],[-1.26565994035617,-2.75994951546834,9.62660471742747],[3.37485917095992,6.21001553384332,8.01881617922926],[-0.121312889750357,-8.44023910000028,0.897953582797542],[-2.25320305348245,-5.36523809717515,-8.39965133487173],[-6.51788858125527,-5.73927141140005,0.62118414051895],[-4.96216241496096,-6.06399716150644,7.76853229136309],[-7.20301486117331,-5.34851866502649,7.26103959576877],[1.89360249359459,1.1935012012238,3.43234563414733],[9.46480166872893,0.791298605591418,-0.303274752534351],[1.85728578237123,-8.22477711305108,1.93452233172448],[-4.42024069851314,-0.0583013284379162,-0.492929220587715],[-6.14212987847634,-2.80056143215569,-5.34310537244305],[-4.77621117150655,7.02861564563923,9.04465748129245],[0.751832857516288,3.69999269850094,-8.80532361759166],[-0.0586038029042771,-7.19054302338351,-5.8612424617176],[-0.83269447574784,0.922444972204196,4.17485996717966],[-2.42454197652197,-3.17512516229656,-7.11665996138118],[-5.98021781875699,7.7898200241021,8.32520674312816],[-6.60768356704415,3.0171202667087,-4.06182846892676],[0.075898244568316,-6.11180582611218,3.29026927302951],[-3.13938649320294,10.3009742544127,-6.46976847967398],[4.44123874586011,-6.17342517153818,-1.84794957491337],[-0.0387480686921698,0.343331930309484,3.28426909429416],[1.64720552551395,-9.24254042685332,2.47509727537995],[-1.44608438726574,0.382526609642272,-1.80965395977552],[-3.06919811172302,-1.15045942019199,3.38994265435904],[-4.03228357782417,4.78673143012412,-2.54340188613371],[-2.9126812943706,4.66558917714938,-6.71309638919463],[-3.77540407522353,4.23166700625475,-7.30239427569393],[2.48095738608523,5.96041851556701,7.65272894510489],[2.62678211090126,-4.7095764449974,10.0875985174925],[1.90068949542516,6.29995658778465,6.52900839359159],[2.63792694659744,-8.87445398355418,2.57481074185876],[2.0108472582915,11.3734756208933,-2.31634321488759],[0.52516710017786,-8.48019038011018,0.158562953656519],[-4.17818573670144,6.07781276816066,-5.02771443699341],[1.0472039129512,6.40133986330095,8.96934755718584],[-2.61253911276772,0.996224536503764,-1.15835188480742],[0.880694505558237,-5.51635136213709,3.29978391326265],[-3.46061505077761,-6.0558598199595,-1.82982160919772],[-5.30480010304743,0.720830060972506,4.64752603677915],[-3.95095355000899,0.41438731486883,4.48897735532113],[-4.89779802032027,-5.94586443241788,-9.54485556537597],[-7.93203792832729,-5.88751614719091,0.189642944380816],[10.4217490885507,0.273463423238099,-1.04428162223302],[3.71982102514769,-5.43161283667545,-4.96132852161551],[-2.23854337061731,-0.434692938829114,-3.12695560484795],[3.63592182388765,-2.66366127037623,-6.68407530190325],[-6.72403827816976,8.98436764423345,-3.82151307796476],[-3.69309581497549,6.56363246376933,-0.280789934886044],[0.696729165298575,1.75969340110788,1.0569930378529],[-5.84183237267508,9.20445495804915,-3.94948304179096],[1.13255138415045,11.9689844367941,-1.79747376368355],[-3.06173120801566,-1.5399125054208,3.5834203613471],[0.0866125373254154,-7.02876143206397,1.83956849821146],[4.11249534536535,3.48814102602172,2.08798589093129],[-1.85977043710757,-0.35724120484956,-4.8547028210149],[2.1851458882489,-1.5677578995748,-7.57724624685072],[9.76432726128383,-0.378015165042181,-0.47587606930879],[1.95345243235311,-5.47547741829806,3.23511595792789],[0.788178296109808,2.83672772844766,-7.08877380598945],[3.43074787758808,-5.5498171360058,-1.71869789511257],[1.7951863279643,6.20903867720445,7.74177225820454],[-4.84260499703378,0.538671283934149,4.25771956573332],[-6.40303184919451,7.14181026014806,8.15031570485741],[-1.11873671496807,-0.102444983652701,3.39741023928979],[1.5272256091167,0.122144797457658,4.43684716689544],[-3.23930441987517,5.27588195588013,-2.64206982194609],[0.824183965738231,0.293993280149025,-2.55705839354086],[-4.55246058943329,1.71380158930997,3.12278844971211],[0.656636411799876,4.14279738135848,-3.61016635914076],[2.69380424237233,-8.98119422013982,2.34830164057791],[-1.92240734846291,3.67211710079871,-2.56059256658937],[2.32903080458542,4.68530221158286,8.05132321137623],[4.35164654851478,-6.10225963166579,-2.12937191889436],[8.395240412954,-4.55386096245756,-1.9624204533062],[3.47586137167774,-9.85134814799659,-0.947807028817096],[0.44398688519208,-2.86463821375083,-0.82441967804358],[-3.8957611583726,2.7549518317551,5.26455023611859],[-3.32268461098951,5.36545672576803,-2.6113374668097],[-1.34282393592669,-2.6499738591341,9.46121132460492],[1.43835212665699,-7.15372843192641,2.37863548461755],[-6.04339458838796,-2.88301115740632,-4.64941859793836],[0.800679305715334,0.0559998338796401,4.33763176233982],[0.829760326907238,1.66256432329622,-3.24428673320885],[-6.06751148895588,-3.33458074901758,4.70712940284057],[-1.66847653378122,4.59613194455608,0.681510907056712],[2.71356974964158,-8.31771248827717,-0.516307287468577],[0.834721416303691,1.92205246833793,-2.31858931726242],[-5.0659957143913,-5.87931587248217,-1.16305259340111],[-1.4001879792012,-4.03955914406549,-0.0570678665509706],[5.28949851061389,-2.96727539372239,-4.18579237932062],[-1.75095336889746,-2.13426389776036,1.5102660896607],[11.2417606010154,1.54904243867863,-0.935817882612413],[-4.45878290248432,1.36296599306432,2.96679217337607],[1.6543583495068,6.25079929684671,7.92000890462206],[2.2213259383127,6.69791992066755,-11.8167849584277],[-4.35999094285548,8.89963984783784,-7.39536996710397],[0.592096596704464,-7.80650503745241,1.47098779997109],[9.9178250525686,1.47227866381683,-1.04919233448279],[1.9741132074996,-4.54432753657361,11.075663444025],[-0.345708993102083,9.48228010105335,-7.43927736411701],[-2.5090450522398,10.159807363315,-6.18005474781266],[2.16104251708304,-5.74700678626604,1.94896758266672],[-4.35034308940631,0.610613410690112,4.97640852043139],[9.32267741520483,-3.9522200806704,-4.63451617303323],[-4.04530294406803,1.14961138674564,3.58836122447835],[-0.288214854958959,-1.27712025462153,-13.7335183407591],[1.66213063676732,12.0042455082906,-2.00184458037571],[3.90852750526232,10.5213449806373,-3.31189591362564],[-5.40230661364506,-1.14820044263901,-0.186039755220292],[2.35461317046436,-8.57283516409895,-0.224849917519379],[-2.32306947483085,11.5789690214786,3.23849376649228],[0.877344064895203,3.64576521776511,-6.90577529499166],[0.0121007271342748,-7.12384031395045,-0.863489174857671],[-3.66280192412554,4.5729623983922,0.435048232238995],[1.40148462055619,3.82696758850016,-6.11057370731094],[2.74546331693217,10.2937482927391,-1.75830763831979],[-1.52701346473199,-7.01136815724609,1.63686301725466],[1.93321299471,-9.29303014320958,1.50127826660489],[-5.52996243237617,2.8832855454308,-4.6311589684511],[-3.20286699643388,6.41872576198489,-0.625761663569013],[4.84137822980493,-2.41505724484443,-6.86404012149492],[1.63267939421329,6.97588699610484,8.40983863889181],[3.18156260389129,10.8464041340754,-1.44962780541476],[2.79229208199899,3.88956203739079,8.2820141955098],[2.18460524609611,-7.5892448171994,-10.8365106061706],[-5.73369666237238,-6.25780654319695,7.57900017786086],[5.14383984470555,-2.0016932020881,-6.81569542751209],[1.71510826110351,-8.48161392848555,1.12547309256352],[0.57539143252374,-6.7103752147827,3.97121249729578],[-0.388536002997279,-5.68373545355791,1.71179963234685],[-2.43357187441034,6.09889486864562,-1.57904130677209],[-3.157849848413,2.72424595669601,-5.64550381040694],[-4.68397666895188,1.7335469241581,2.39191460536853],[0.508467569875579,-7.23373487025458,2.15848693135768],[0.576686416224459,2.17618885284556,-6.46485572980999],[0.0826412181723311,6.25194766093815,9.0432929319821],[9.71753867348504,-5.02196521958254,-4.24149722167081],[-0.658372790293585,-4.0410014222815,-1.09613853035201],[-5.28764985920785,6.28136589566829,8.56527510239652],[-7.70030956596903,-0.45729235390483,-5.53899479501922],[1.37480922941956,-8.94759343103428,2.1694925771031],[-6.98977978236553,2.76958752056681,-5.00929633474483],[1.0827812945416,-2.30229386227573,-7.85904777962146],[-3.95287614540113,6.47734832588485,-0.235865994671313],[-7.6370476432058,-6.9453237439262,1.23018849583625],[-2.43021662738998,-2.49508121766988,9.28144634363506],[-3.35324308080535,-1.60742597869678,-8.23064834497475],[2.29670509420162,-3.31911830934066,-11.2002826688309],[-5.78989397192926,-3.31367406222828,4.66945956153872],[2.5912835902948,4.59577368722093,7.49735749853302],[7.31650820665932,5.61532400803678,-0.0214649776438943],[-5.23204370453978,7.96883513162516,8.49543328725983],[-3.99856709358792,3.32367893649792,5.78278223211237],[1.10693438628944,1.96690773386698,-1.21267818322067],[0.339111635237543,1.64475554216906,-6.59421297382988],[-4.27314865378514,1.26267254067821,4.19039741431864],[0.953835614822419,-4.80972156883838,10.88174880521],[1.23523287357435,3.84405293912325,-3.28585547278502],[3.54048991747997,5.78207572922195,7.99649258815218],[-4.8155179071531,3.22190129744507,-6.46728049322684],[1.58447617670182,-4.19052596573747,-0.340344696380439],[0.950262523070805,3.82357497874641,-6.68201141269508],[-1.09303903753152,6.37391602639175,8.69327706408954],[-8.42351266854791,-0.0738551634547744,-4.6136534342258],[4.35699049726568,11.4930965123305,-1.78726716701274],[7.15535970399013,-1.87411862848046,-10.6346017435654],[0.630790143024489,0.272497083319496,-7.38769994350725],[-3.49343005651839,3.76222740982436,5.85466870516543],[1.74894730417247,6.40310946442361,9.19978549601552],[-3.99277074375518,-5.79824553194345,-1.49704054303023],[-4.17450192196923,-1.22770026034257,1.36861592520106],[11.2006863650431,1.28558129862728,-1.73664937632248],[-2.84614038429159,6.80611552718521,-1.50807387891391],[-3.15850824836799,6.64258751906005,-0.393340987860076],[2.81696811291377,6.03346547457123,-12.0544474218731],[3.73236791995581,-3.4885945453693,-10.0438389976364],[2.93123285987717,-9.2071067688409,0.935617338904957],[-5.60878342994123,8.0714055055082,8.45852708898354],[3.03817503737622,6.02071290669664,8.34044326625678],[2.38004548005402,-10.0362605948583,-1.14955104332622],[2.04025010954059,3.84903062852973,-5.37789170998613],[1.50229823359319,5.88669203886177,7.18431658332986],[-3.7327839031067,0.0170385046984087,2.65039152238798],[-2.43337775674194,5.65130984224912,-1.15763715435516],[-9.27111285925539,-1.84101600931686,-3.91459995855487],[-9.54022239148489,0.513755796162751,-6.02822005804143],[-1.85851178582258,-7.96608711120759,-5.36357337843919],[10.3327751917671,-1.95568961906502,-0.0675064268675354],[-3.3589594823793,0.178160541871445,5.77016695600285],[-3.25062715922203,4.2181055881737,0.653565393864327],[-5.70449586325816,7.17762236212495,8.20726205123909],[8.74133878590435,7.02015809938388,0.734294802827232],[8.88163134184867,-2.53224380640331,-3.85523148481723],[-4.38392105395564,0.967605450027621,4.1784755320918],[10.0117437349364,2.60290319548431,-1.27203465377747],[-2.31918062133961,0.435075383190872,4.29217333463936],[1.45227074831004,-6.53777172433903,2.44820278237761],[1.66444855179202,10.9199062780784,-2.23407591754798],[-5.09226735354984,-0.0783937470244955,-0.844329402755147],[-3.9264310247516,-5.24219005490162,-1.93739011402649],[-2.19025058017856,-2.1828471814904,9.38986073160196],[1.35023095886823,10.5087628368255,-1.94402616081603],[3.37504490374698,-5.77435896270696,-4.61179475362719],[-6.12401691583635,-1.85529934981768,3.86250279091414],[9.43911369265824,1.6949208611527,-1.22597758114171],[3.23308607864045,-9.04580122360374,0.107492198550631],[2.35361954715114,4.56608467390798,8.55447495943379],[3.61364484219881,5.52889027430093,6.92602627004748],[-0.410010538948556,-5.36183325087542,1.80845501097976],[-4.92250245088308,-7.00528434126997,-9.98499144541613],[-6.94652794311842,-6.0371931741433,-0.657507486732723],[-2.95785663639593,2.3652622890193,-5.54010553618284],[-0.496872418519564,0.648719293471294,3.11068398106522],[-0.575907375902189,2.95050371105647,-8.56762656088564],[3.75849209332914,5.96316398723705,8.35975950744862],[1.73197311879947,0.759148955372801,3.71204511435545],[1.90223554936849,-1.52717930560185,-7.74233164695521],[2.30882857616331,10.6124382493736,-3.510810826577],[-3.57284087440681,0.648744988465566,3.17871433462511],[2.87685942823263,0.257896171029516,-11.3433953128738],[6.85352809244394,4.09507883685663,0.389108027664645],[-7.84246103923179,0.283876189868836,-6.65371972826237],[3.74589293787736,-5.4094881866488,-1.40501452847606],[0.680819177640549,-4.35794903645899,10.8649536572262],[2.60974602069879,5.67703050985066,7.89410934364685],[0.796293014744789,-4.05046716899641,9.8844731993013],[-2.56143137846361,4.8355673578467,-6.63028781290788],[2.49074144400691,6.19146015772048,6.32844774233664],[3.72208487933797,6.31744354402458,8.90216995535356],[0.901782938723542,-3.7682645491316,12.5183128672002],[1.4500188372271,-8.91050825524254,1.93996020208155],[-5.53672922419383,1.10542328813355,3.77702584245121],[4.17141651348374,-0.942430780658704,-11.585382958892],[1.98255322582311,-7.04482545794845,-10.5616166417786],[1.41814931751115,-5.19881352227542,3.36410731382847],[0.409146395407678,-6.40597426765947,1.86849135310032],[-2.47197347475756,1.24039165067791,3.57396873364512],[3.76231490128773,-8.04819827571464,-1.58910585937326],[-1.58541032410878,-7.78855697507509,-5.36899783266116],[-3.20948078991842,6.39805653506679,-0.300950518496662],[2.46687246167442,-9.95189749203576,0.944360446220602],[-6.59652857386443,3.306761050022,-4.20090300356527],[-5.3869273967733,-1.86535349795749,-0.609027648658814],[3.82673013479995,5.55679241145266,8.92025150371894],[-5.33942600063593,8.44337836852479,8.1060912620426],[-0.229500866266566,-7.61440601495877,0.995191004744841],[-2.4641993069428,-0.572011156185113,-3.58049329631995],[1.01028312049205,-8.20886066947597,1.02834218505429],[-3.74324699625616,5.1673665659251,-1.96446075449066],[-2.72798963913759,-4.94474307575992,-8.41431408805718],[0.0331728110176139,-7.67472510189345,0.919432276220893],[1.69947302505279,-7.79595341737041,2.37007803070228],[0.146329031087522,-7.36462632492594,1.52847985474577],[0.102025412572261,-2.99332300503306,10.8015864209549],[-9.90290116049345,0.599323272293367,-5.7994909380177],[-0.107967224845353,-7.22232848012469,1.49231266768591],[9.3886827255504,-4.18958920973041,-3.92675359662537],[1.7375120968644,-7.42797916035534,3.54955387715763],[-7.46057574105293,-5.8030638395392,6.2325558648953],[-0.474729304086701,1.41769961407078,-1.74343635394282],[-7.92697178366303,-5.49216305948262,0.376392593972863],[-4.7522912960741,-6.15751599938722,-2.77211421843823],[2.31033729734499,-4.45052215329823,12.3826372086829],[0.122692313488176,-2.96558318541059,-10.3655913729321],[3.91088041809498,-6.36711254450636,-2.10530615439182],[-5.97749448735041,-3.15260200181257,4.52116108106532],[2.25273730306418,6.40686171311123,7.08455387903891],[-4.60751885239593,-0.13223445815022,2.36697423236787],[-2.76056397347697,-3.03069020009531,-2.80667696517858],[3.53700604741693,4.69983372617966,8.724949205495],[8.49355267691862,-3.32327079423222,-4.80729189994292],[1.85364580725323,-4.80432381989638,10.4904452859199],[-2.61278680039937,4.59638061579783,-7.90434152841582],[3.21384179050103,6.3404888146822,8.70508626294642],[8.5133635102483,3.4530878889708,-0.0432695024420798],[-4.14850678354976,-5.91320964905465,7.58067416902602],[0.436850229953079,-4.78343278871838,2.68720029113449],[-3.76517734524415,0.418268134675392,4.25697689437329],[0.504371212145917,-6.57422062783159,3.83952365946196],[1.61597430596363,-1.13829204736395,-6.32836015837116],[-6.11218054248373,-3.52862887484865,4.69922456817962],[2.78207866357565,1.21707030426863,-8.30046099501526],[-0.438513814382561,-3.0110332020432,2.05157556138967],[0.615106698686248,-6.85695540485384,0.505379038579987],[0.89117522421254,-4.61510869466074,4.46715263102096],[1.00224441791268,-6.26669628793529,4.90153328763509],[0.594023080561443,-2.9752082391157,12.5515504593927],[0.169522587206647,-7.98458289609383,1.80300354068331],[-2.84269962945287,5.4706855082107,0.671249034370497],[-5.16238049832715,-1.85690425074946,-0.898235922659843],[1.90406619726488,-8.47259874184207,1.71712429600035],[-0.0250945356326677,-2.71967087443616,11.6205523315717],[-6.04079514802856,-2.78234963098182,-5.26853962680159],[2.37897457943361,-4.82302307626042,10.6576096282896],[-3.77266295382631,-5.84249451250142,-1.67338893762385],[-4.45945989175789,5.46115947504543,0.447649819265506],[-3.59041055968278,1.34972777451004,2.57205549083594],[-4.79065513814179,6.9680496298303,9.24845930611561],[1.78246487736888,12.0241370919062,-2.68846670657789],[-6.10970460890812,7.84186054869209,8.26534840862079],[2.7072068805664,6.50063627190012,-11.5930701375171],[-3.06538455420801,8.70294753454692,-5.7054940194163],[-5.44523570272467,-3.81483987216153,-1.86028439466098],[-1.30575576784318,9.98618264381523,3.36697829931454],[9.86453248820518,5.09078928887334,-1.22101543422509],[-5.39426280269433,6.98470640905153,8.30137114618687],[-2.09690913652619,-4.42021006081617,2.09510450403183],[3.91149002904023,6.22339524786884,7.86006336867713],[3.4137677824397,10.557587992275,-1.37759583300478],[0.0903323657561222,0.0680513901689536,3.33576548431108],[-3.96661437219614,0.208317430923564,4.21022102305611],[1.92390978533625,5.52471363509864,7.8785563733861],[-5.13884464708017,-3.00171659382604,-9.04875959641266],[1.89105758738611,-0.414481705180406,-9.78636599038833],[-3.56455932682791,-4.42993478180883,-1.0188617232435],[-3.67873079767555,4.96766105635112,-2.84171265611751],[-5.9740286075419,-3.54312730272795,-1.64042813412423],[-4.1486184550012,3.13926223941688,5.74145260494247],[0.986667133795893,-7.83334533725619,0.943391573207512],[8.89673339038343,-3.55341028453552,-2.10002152527313],[7.15231227792451,4.64613678856887,-0.691752051807381],[-5.53952430904791,1.42460026866657,4.00256027103661],[-2.98220595266217,6.69226428470076,8.87882524715221],[-6.08443274736119,3.68416589487894,-5.98537868735896],[-3.92578530588432,1.6295002726934,3.4975048983301],[0.567639039275423,-0.62491496355912,-12.9087322314181],[-2.80941452772389,4.79231946855073,-0.291325685553971],[0.0869281042316747,-2.96214304378177,11.0941816231549],[2.23498369932461,6.04119980542642,9.23440674388284],[-5.95814773145833,-3.80757411075435,-4.35831168285622],[-8.25313648347663,-5.82453307348129,0.990380598956632],[-3.4740613530227,7.45289559836247,8.87889142274047],[1.94409901832291,-7.57504571725238,-1.51185590317424],[3.26056484175957,4.26102984413231,8.39236871010018],[-1.76658676788642,-3.40624667441489,-1.33802580157357],[-6.31366890593364,-5.83426047297131,7.45649805594402],[1.0750490543615,-5.14581332304273,-1.47865590699273],[-1.32720324263251,0.6195698259636,3.2445932384037],[-3.82713441710163,1.64314092655224,5.33212414819689],[-2.23774738688087,4.53245876187554,-7.09301465000959],[-4.66806137785481,4.0896748465447,-6.34758708719315],[3.56650953628346,-9.18315143328624,-0.0390814761423364],[7.48692229577167,-1.99295615488527,-10.4936776617182],[0.400233858670362,-2.58251215962115,9.18264204894455],[2.9785508090001,5.69327137359418,-10.8126962891705],[-4.74343001206144,-5.74634994169791,-9.80597947083496],[1.92992677550825,-8.08261293213712,1.431657458368],[-3.3902972509963,7.08652436513348,-0.846867294593168],[-6.14719883913403,-3.21257969662422,4.79961224130667],[3.95125061841131,6.36431912412315,8.01367039249704],[2.84249021290447,-8.44342871335049,1.67875781682742],[2.14487145522667,6.32248463371695,7.37627485166243],[-2.7119498566189,2.83760651559368,-7.1803368566673],[-0.356657183087015,-7.2558581521646,-6.05229716133277],[0.271007034598441,-0.121054842466309,2.79994722224646],[1.03812102100944,5.76384663856237,7.07818865438619],[1.96048355999164,-10.340822551205,1.04788706794734],[3.54882749220643,10.3218109441183,-1.66376630093151],[2.0514664061261,11.2934608654237,-2.93823317867465],[12.1214446781732,0.606266871729457,-0.565449984267055],[-7.34539433602864,-5.90415916887981,6.87896595406305],[2.95598707825376,-4.1672921032009,-1.37249368712372],[1.43098798255557,-10.0975874758095,0.835492717149308],[1.12674091718029,-8.34607168689791,1.09680159836259],[2.01720153254496,6.8951079209572,8.24856421809269],[-8.68760949600547,-0.0913478145045179,-4.64165544876801],[-9.6463045844722,1.03574967324664,-6.37506451392272],[4.12451682480256,1.75213830156226,-9.43468252505943],[1.6586115867266,6.06592214614981,7.69202239178351],[-2.95408067164986,-4.0467238264428,6.81929864096248],[-4.60938026578833,-5.0311560455115,5.72986464800413],[-3.22723150918419,-1.22221944724364,2.16152206692158],[1.29588561686356,-6.83502743236521,4.20350213347129],[3.17543233089774,5.60367591894657,7.66705781634686],[4.39010424030313,4.85738865732623,8.62277235452256],[-4.42023715361738,-0.0408052884178436,1.18829222638809],[-6.30038457964029,-3.4119384536525,-4.65504150834228],[7.61814184740185,-2.30425492834716,-10.2542040365657],[3.21361658836556,-4.56534283309914,10.4680929566472],[2.46986229754242,-2.21422608947977,-6.82132312814551],[2.47651419836974,5.01119605093048,9.11417517616268],[-2.16829983319394,-3.11063999383973,-0.605217817824554],[2.04939058665121,-8.36894575031038,-1.21019464548029],[-2.84557370486976,5.52779746283954,-3.09119163779317],[-2.40674377056611,-0.509641590630481,-3.96082889680562],[0.901584796638022,-6.40339081171288,2.98705786617999],[9.02838293461503,-3.95420371992462,-4.38013176241862],[-2.13507315593225,-6.21692000529026,-1.24217513028307],[-1.07359102940768,-1.88081914020092,-2.85803717649767],[-4.79445245795605,0.938997288478745,2.35069657510414],[2.79021758292641,-2.44514316091912,-6.82288095931581],[0.655066706429237,-3.17122442085231,-12.0111300334406],[0.222909207445795,-6.41067783203188,-1.38751700317531],[0.679568104552239,2.22390958799166,-3.1347588012951],[2.04728323346255,-7.98073502775688,3.54483600362712],[1.13532635878492,-3.91420428419582,12.1852575506991],[2.99786197765871,-2.20133718147147,-6.73165015699759],[1.61184648842734,-4.68901229898507,11.2443687492833],[1.65506450172414,4.04110804468558,-4.33779974920348],[-3.04781240280604,5.50070418820767,-1.13367052958916],[-0.966902559119371,0.524924396360305,-7.33305656733315],[-2.02808310581741,-4.76224367357647,-0.226555832525063],[2.69047427831918,-4.74242168974172,10.5601114770356],[2.65655908586894,-9.67833795815772,-1.88784305874789],[0.797400644245969,-2.66557623094296,12.7637689718541],[0.686861819931961,-7.61476012675879,0.139846202352525],[3.30197283848186,-3.37855459505231,-10.4544876469616],[-1.55382921757336,-7.16539104413705,1.57573459780211],[-4.47753477734935,1.05893653589134,2.74868376434461],[-2.38892166977099,-4.4867653918926,-0.42086908868604],[1.7744931801628,-1.59246708392281,-6.45944785411595],[-5.26008875581544,6.69057085773068,8.42656007323926],[1.73176309741924,6.01406804545436,8.89647979038814],[-6.71710590814822,-4.84685698977021,7.74708969099557],[-8.04260228817589,-6.71372120078085,1.27910736348316],[11.0373030215282,1.03216102712965,-1.84218851605223],[-4.60482374291519,1.02166525688901,3.93821055789789],[2.85773615747268,-2.43782087110324,-6.62398015697906],[-2.72179323219937,-4.09420801383722,-0.980044216238235],[3.7776914559977,-4.72683791742761,-1.32201898780351],[-4.22710153339207,-0.742138155951708,2.54888890024094],[4.76234532807447,-2.2461529587979,-6.74043000332423],[-5.52240456145675,1.46630814508871,3.91550066655439],[9.05086946490791,-3.60459403030092,-2.04984751169291],[-0.696290278245143,-7.11422220054571,1.41350878037028],[-3.33770615997165,0.913431354815906,-1.31820330899735],[-5.66210892979348,7.38134497349421,8.71504635933599],[-1.44729827501884,-2.18035977085103,1.29853808729096],[0.201478223335447,1.64773153481866,-6.81806635726254],[7.54533877645968,-2.94642084815051,-4.35608351551177],[3.24409490476238,6.5013064642844,8.54314465310616],[-3.81542067576801,12.103350790482,3.82762671697832],[-4.41251223482545,-0.0552104948140824,4.8493630160166],[-4.27829390999466,5.83603878211384,-0.771710763993005],[0.392921648069969,3.8545944863049,-3.38884721628685],[0.825100471486815,3.84842610087668,-8.98293635278187],[-5.57605434641301,-4.71205721147655,-3.68325635497553],[-0.0597816923678895,8.97523415801603,-7.28662960876114],[4.14710425241371,5.82419245053234,8.6834543756682],[-0.0345198580576862,-5.12503473469741,-1.9093166357179],[-2.95386994480777,7.15144569973792,-1.16865842800448],[-1.8568346633786,-1.38024405729212,0.846316311072337],[1.76350461534118,-7.18306586986354,1.80129072182626],[8.84618059625227,2.51301958652032,-1.47409096879122],[2.98826574323009,-6.7661475453003,-2.14739822324032],[-0.811429954052891,-3.53327930087582,-1.49781199350178],[-2.54395298033465,5.44218984132351,-1.09945117523003],[-0.8048091916683,1.45304612166468,-2.25706401514496],[10.1681797093373,-1.50201610219372,1.0761328070054],[-6.07281395462107,3.38247277974749,-3.82828869462369],[2.19713269759966,6.61371882808943,-11.3544405647567],[0.95435529494934,-3.14795860385431,-11.9415529367314],[0.935287481328132,3.71804287329083,-8.35140870717181],[1.82347640802421,0.555006719487075,3.65245081949952],[2.73284736632817,-3.7554922955807,-10.9998795687874],[2.14731859529987,10.2221478080553,-1.92383039746221],[1.1152951687102,1.52519077331303,-2.89393227207364],[1.45881978687041,-3.97747330176238,-1.51529947565558],[0.986530585489149,3.90177643841707,-8.62179235391023],[-5.37669928226048,7.36992561806859,9.10388703783331],[3.92618558528423,-5.67304706042577,-1.33460104266726],[-3.01654108436488,7.02121289568246,-0.629137496339024],[2.74071484011325,6.13525645593709,7.44805942882414],[3.88006214278998,6.57866810731531,7.92517043748563],[-1.61537592200548,9.34270518032233,2.90905156260499],[-8.73317464807205,-6.36590206091058,1.23056232731948],[-0.810299187818932,-7.59755210922324,1.42549856422198],[1.37086890040611,-4.03724136127584,0.125963039602199],[-2.6205739777747,-3.79474629448596,6.68929733407373],[2.2985215947817,0.55728746414958,3.04880584638599],[-7.79190713384151,-6.44091548932675,0.0893813806629973],[0.0583486194837171,-3.18658403669781,11.9145587534637],[1.38292043074251,-7.38478832223134,4.11937396623291],[2.70288961367757,-5.97121527705894,-1.15915418761582],[8.093209292927,4.49430318871061,-1.23003226997424],[0.0857898968364629,-6.25840241702015,2.12113957502688],[1.38932479000665,-8.41390426408368,2.40320102332575],[-5.56474177916244,-0.231975414412537,-0.496089487180464],[1.13141796171897,11.739891281552,-1.95451558465614],[-6.0964268999927,-1.67961668649255,3.78093467222516],[8.42786060024239,4.44367021429398,-1.88283637828754],[1.83352465208605,-7.26384015646628,4.25670196837987],[-4.62460872851381,-6.16005776894688,-3.06659676737997],[-3.71603573674574,0.340901542215456,2.61700785715168],[-0.48770229291704,3.41000274141107,-2.5700581544844],[4.28849469412483,3.17341720876375,1.43032071521842],[-3.21384946316164,-6.06032063445371,6.50684541685835],[-0.0288084105298635,4.34520638998622,-4.0277667972027],[1.76324177151427,-8.96815945281889,0.422381680665796],[-6.33656190963311,-6.87398291210785,1.10075287580729],[-4.88939298847922,1.12118070392626,2.09717325233764],[3.33746294826849,11.4155152223458,-0.707067283967172],[1.68133916383257,0.104816002135472,4.48883820661495],[0.501422454711306,-3.66793315820896,10.4601270991016],[-8.53989941307919,-1.12138212565195,-5.42769218234948],[1.02575133327866,6.33117366397324,8.98348554040605],[1.32078729339672,-4.80079363818636,10.474726548063],[-5.18150054230885,-2.82941781935588,-3.83816926316435],[-2.90659809508713,3.7488222498437,-6.59097134040267],[-4.76035434246218,0.492948226121235,3.76571475812187],[-9.3736903085595,1.00446079278043,-6.48438422358574],[3.72135461190771,6.11288593008026,8.42715545908932],[-1.72412470162463,3.13363250079275,-2.02386991807701],[4.32059074767084,-5.73689712251272,-1.91574383109976],[-8.16110200447577,-0.340325856460874,-7.65132921434315],[1.31555251824279,-3.92628037037494,12.7301172030175],[-5.35533628926802,-7.02749348410475,-2.07340903142679],[4.14805512638464,10.8223687382824,-1.42424286902835],[1.08262910443703,-3.07901637925212,11.2363683430812],[-4.4925162595652,0.533492876132624,2.88644766637056],[-6.65830639298746,3.11961969324508,-4.68641632191175],[0.131787332562577,1.15296434143324,-5.41062421582157],[9.65357287814559,-4.53909829045993,-5.37428017048473],[2.34320498514631,-3.95732098799509,11.1282149559553],[-5.92216864725556,-2.90896162597237,-5.04415492018327],[-5.23666848843708,-1.83431069768143,-0.784225253894811],[2.06691184048451,5.1187667066458,7.5659269980164],[-4.67933286737944,-6.91198172254942,-1.91742530109174],[9.27185605537501,-3.9816108506714,-5.34065065283399],[3.72325873621003,5.5326909342671,9.21814468411207],[3.43521009816493,-9.29047437807709,-0.170464230618758],[-2.74998176225305,-3.49554521192968,-1.68128242127712],[0.990057971039068,-5.03598348097303,-5.16133907182697],[-5.39205890377273,-3.97047301841428,-5.18311979967884],[-2.02351187237597,-3.25167341072094,-0.838568951248439],[-0.322753545052541,-6.80679903240357,0.0543770327279373],[1.26216769949237,-5.25904451475522,-5.90599092516159],[-4.93479738237255,6.97409514277994,7.53761535210251],[3.12624474049108,5.32833360568839,8.56625016701412],[9.52054501042187,3.55012634852585,-1.44475900816442],[4.07101633737504,4.08022854849251,2.77005337583371],[2.48200383067525,-3.78297478915783,10.7585506568589],[-9.22938592261545,0.00275717783122997,-6.07498164687777],[1.07516953238936,2.22561851793948,-3.00460412381447],[3.82443224160272,3.75465150591322,0.992617487965087],[-3.93790209251338,-4.51468024086101,-1.23921270751965],[-5.65493428363876,2.99258919006718,-6.73083249662527],[3.38262332001296,6.87683745392538,7.83925069070298],[2.08843495971875,2.55708879469516,0.7792996103654],[3.14749170921791,1.51069554754044,-9.55951310239841],[1.32947908638453,1.66268357900605,-9.93341902645851],[-4.62374814612284,8.8948539466609,-7.31248546494225],[0.689951251164271,-0.12546519770589,3.25493981613335],[7.30473630368731,4.39344806404918,-0.856154177950257],[12.0929623487793,3.21292560277194,-1.51247997129218],[-3.55516913276908,6.08241974583113,-0.659294414756176],[1.59970122006326,2.93919351532426,-3.70287754708928],[2.50264259600537,9.65843920383245,-1.92804295527402],[1.14167059175907,-6.22234378881033,-1.15180199934143],[-0.446853329488389,-0.886832908104008,-0.594380216219928],[1.63323752275221,6.45741058816588,9.06003488826673],[4.56330313140657,-0.930495155440539,-3.08183903505885],[4.64155972189313,1.4148925094317,-9.67750483475565],[5.15967083553019,-2.07616080011714,-3.02969726849192],[2.12879843032189,-8.44497577815973,2.37958955580618],[-3.22208907570088,6.84131759367181,-0.852511796814089],[1.05312135858275,-6.1472780373444,4.26969851193561],[-3.56901142134869,-0.000852584242326926,3.19418658499915],[0.362686610720369,-4.73997675152239,3.19553649478023],[-0.585429316477299,-0.26487544632803,-8.00384665502162],[-3.69993092240515,1.2827185818883,2.15677204953646],[3.43126171008837,11.3797120053311,-2.38464533390796],[-6.82904425409043,-6.16095521150803,-0.150238065058871],[-3.60451884028316,-6.24287196069487,-2.28028129864879],[4.30289498297692,-5.38485614855721,-2.9550477853215],[4.39744890103419,5.87796017680832,7.83015798137451],[9.99607662043544,2.68524741501024,-2.13063991292483],[-5.21263716385133,9.74960773615345,-7.48327613040185],[-7.82107009507251,-6.43771059573166,0.310924743514755],[0.646162318957607,-6.2312652605404,0.85107387262016],[-3.27619278219685,0.768820476617161,3.5145164135315],[-4.34445433742736,9.85518395074064,-5.18412276790941],[-4.11582098820871,-6.16163839594147,8.01499291826145],[-0.00462223140124218,9.32177351122775,-7.34694491652908],[-0.677111557330205,-6.32891601668797,-1.65459628217535],[0.317062290391916,1.42615286186054,-2.58358056228683],[-5.72040367569017,-3.69049550298864,-4.52380743464611],[-6.11412090055604,-3.23672767861328,4.88345845552163],[-6.29851836880186,10.9765104151687,-4.25625797397568],[3.97614500470186,5.03241980475948,2.16786118493588],[1.80812905748836,6.62560033869299,7.79938747188447],[3.30530349924847,-2.3697510980385,-6.77476803918081],[-1.74538317467164,-6.46430901001353,-1.80141869686289],[2.76448000006281,5.81394819912998,7.1850316866587],[1.84687906053143,-4.93571253535611,11.1932735759282],[-0.0794091249353908,-5.31989097570504,2.74444493672887],[-5.04042937704314,-1.35781554730542,3.87706175082851],[3.27468544617355,5.31333166593039,7.38122418287211],[-1.47479790987957,10.3930360820054,3.22360319778844],[10.516035768604,-0.802689360302023,1.01582115768334],[-6.54149757779199,9.02040458085383,-4.39283786135826],[-3.45286060239909,5.21781974840783,0.364182223385572],[-7.97493176098781,-6.31185290754201,1.35004225555808],[2.76797819361757,-0.497820878728548,-12.309803803834],[-4.65770630050302,-0.405986694385392,3.98558017883684],[2.16990766401932,6.55976691194532,7.58746854901512],[3.76688590730992,5.66035129011608,8.84849109291158],[2.71533988026176,6.59296020564093,8.55776052625066],[1.98840419792001,-7.52319349244362,3.94726128387316],[-5.64085739744994,-2.82321208855476,-4.79847714626683],[1.51819526006743,-3.26686839994877,12.5912139574308],[-4.7545688692093,6.74803687956222,8.93707052550922],[2.82458593632157,5.91096083423007,-11.8298563275379],[1.97706988091839,6.5174353714844,6.84331573989814],[0.14606808827553,3.76568550267347,-8.34690331473712],[-8.06185807824824,-6.8792159386196,1.85807331909515],[4.81396337721387,-2.61559723053469,-7.02755403843563],[-3.97768458889533,-5.08113242136656,-1.56537049776475],[2.4236275036019,6.09560903158272,8.04921177016161],[2.44798547925052,11.5816702215064,-2.76849619579065],[-3.49358735738296,6.9990144413165,8.17117246050565],[3.49351191883936,11.2874364214235,-0.950642982187355],[1.18057860570892,-3.0933316916201,13.0087301094983],[1.1925975313593,-8.34266641306775,1.26806994667354],[1.3846351340193,-5.32660000297382,3.69384010942088],[1.96021373452155,5.73355655182818,7.05315645036444],[10.4692896456677,0.327295317751255,-0.515250733265046],[-1.29958252339848,1.44647617274651,-2.56131979313945],[-4.64526507371327,-1.63890902918872,4.32197441078558],[1.50624470092925,-7.50196658912979,4.48461890292291],[5.84069396597771,-0.33661268391578,-9.90277807426073],[-3.01396492237363,-1.97762314533301,-4.40718240531456],[0.548738820169472,-4.5775138549483,4.38767584138469],[-4.93900011371572,8.50100380653857,-6.99040710328477],[-4.82701471801933,-6.68970289397434,-1.63165459592603],[2.47910599402086,5.66360843786247,-12.0708106795683],[2.10275083142308,-1.55885338386738,-7.79541300153764],[1.6381934705554,-5.92720732172522,3.59945081367667],[1.90933264726233,-5.02216949008098,2.32866083331275],[-1.48964885907661,-8.07372461948217,-5.62905786142047],[1.36655809804111,-7.50526453352277,1.73681103656643],[11.2441931965053,4.90787888068713,-1.63299576902238],[5.17907601229785,-2.01191575103491,-6.79846134743777],[9.55466121146179,3.19640888204721,-0.758351874996894],[9.24304916591332,-3.9239714215706,-1.9472553739782],[-2.30748106749166,0.290155409307487,3.19533772558874],[2.27262839316198,0.784182170759158,3.17245909752993],[-2.61488986064302,4.91675660463711,-7.64121100268395],[-2.35908565018712,-5.42085748033072,-8.56544492392427],[11.621575923685,2.22324662800227,-1.45282166962472],[-3.90143986919814,1.14352437265291,4.49601285370633],[1.15549853477497,3.03915602354605,-3.98106422937051],[3.82015034863888,-7.15496608581841,-1.68076984730474],[4.24227377829767,5.8806429215738,8.13279071623444],[1.33119403035839,0.936758927392698,3.85901598165776],[1.31017535358252,-4.76862451573695,4.2601960338282],[2.92208786436622,-4.57711924138272,-5.36992187353508],[1.00759035306096,-5.48443473670484,10.9844556516359],[0.74113972956155,-5.70801373690494,3.68187718610117],[-3.40622278331463,-0.28210396209453,4.14821765663983],[1.50955849188717,-7.53723463013106,2.40880260607766],[-5.89658169190963,7.22646115340934,8.38027039379492],[0.745545665502694,-8.84041732329062,1.36744724323519],[1.41996871159593,-9.82243866935483,1.24652247853759],[10.1121799937688,0.721821654112582,-1.42441592070644],[10.9733207924278,-0.10355816189018,-0.0605261980065411],[-0.226306349187465,0.575356208625672,3.20304710751464],[10.0700081765696,2.92818755093069,-2.54187567561457],[-3.3047449448474,0.769397514121473,-5.79251858796237],[2.24679640735435,-1.84964231414119,-6.68395256129989],[-6.25330496917288,3.50396425619861,-5.75387573091247],[-3.7597615223354,5.53542698351075,-0.424536589348269],[-1.05438401449793,1.95638009629893,-2.33097550667915],[0.446514164123338,-4.2627589035254,-5.81594698914401],[0.00814750812807929,-2.89672364762524,-0.309638291021883],[1.93544214240796,-10.1558823660651,0.861708592876156],[-4.18278517414449,-5.61061017511755,-9.43513300465105],[6.33311795458399,-0.806178678243791,-10.2465241278059],[3.28631510655946,-5.85905914111953,-2.02813904081868],[9.11219429171604,0.690877916679915,-1.5659566714961],[2.28529840312074,-4.57459265312011,10.3548463347803],[2.71348624554959,6.16057887242073,-11.0937981817801],[-7.36834692135104,-5.65709019651934,1.57115337816667],[-5.94682171099347,3.03580708374757,-5.68940341784994],[9.64653122284509,2.91672519010417,-1.24958908649453],[-1.43850873916238,7.35459911349407,-7.12149464902178],[3.71426737996228,6.24462125153814,7.99771656945922],[-3.8149850518247,-2.30506176780303,4.45992312997167],[3.39164739156447,5.80620492452472,6.67734718468884],[-4.52390488516795,-7.27376220598007,-2.05390138094088],[3.33084046074165,6.06099397589921,8.34635460848257],[1.42811320762218,-4.32581148530951,12.4605044740299],[2.76897200475208,4.36305585344677,8.05603645043237],[0.189666081115831,-7.41491944567685,1.70503733562936],[1.27149739382502,-6.23293060842753,4.32616732920282],[1.29614932190187,-8.82405260906857,2.25567899627155],[2.36445553563494,4.45640361755523,7.87144069674352],[-9.55754543813918,0.0469107632970491,-5.76076066239738],[-7.46667430041316,0.169851075584298,-8.4998768875262],[0.141224603429221,-7.01764872924873,0.630116278460835],[4.02974058361621,1.91564202023615,-10.2211455636977],[1.72633725593365,1.74935128002552,-9.20035426558031],[0.455523100869032,-2.81810522070768,-0.610213962133176],[-2.13241358970557,4.92231801222223,-6.92229352263824],[1.60163081759433,3.53722680131647,-3.96846907319792],[-0.688477031639176,-6.15866698417268,-1.32097352462853],[9.75832276347864,1.81441531193784,-1.08573039795333],[-1.80959295741067,-5.69994255100391,-2.00486648813127],[-5.06188628075474,-2.99674682898506,-3.90056221720601],[0.534200628763062,-7.71683642169104,1.9286192130151],[3.78785203277539,6.23592512978746,7.9783234864109],[-5.02024318840691,-6.45921905020183,-2.19784894318733],[2.75895602383386,-3.48205578939453,-10.631159129007],[2.7966718293256,11.1614248400834,-0.916272500831893],[5.12614525364309,2.80619731651495,2.03027843965099],[2.2060915958976,-9.32595290831549,0.840772433598649],[1.85488947258084,0.527696095093137,3.34355468805741],[4.24404848719459,3.58291581805009,2.95436925991588],[0.501383541895902,-8.58890126998442,0.863040848594948],[-3.18287686873634,-1.22658077318048,1.9486180213565],[3.35528394170624,4.72540421694106,8.72045104082549],[-1.61736645390467,0.459410326641327,3.08743540491905],[-6.05246490371771,7.28518700619576,8.86991434395475],[0.108695990229271,-1.32313713436392,-11.0760179562503],[2.46733137129125,6.66103438944923,8.94635088626878],[2.24686187020525,-3.38745593453382,-11.2515123880665],[-0.112107137047277,-1.21247533015908,-11.1388684785075],[-5.48950395225148,9.21001561232961,-7.34152639799739],[-0.190507422654682,0.557676013525062,3.36125274740462],[-0.389676105980631,-0.619096038969155,-10.9560186106899],[-2.010704832902,10.7223709131916,3.3327680789421],[-4.68102954530419,1.30812209946658,4.66169247740371],[-6.28274836705956,-5.06320750464745,7.73259532725577],[-7.13741694673532,-6.29151632027064,-0.527168287125975],[1.72595048111414,1.76650828565972,-9.0552442042962],[0.928209832537109,-8.04699570405879,0.865801016295924],[2.56913270164918,12.1903942416785,-2.65770531118986],[-1.42127602239378,-5.8627540928865,-2.24475863642795],[-5.98156222832036,-3.54720820720203,4.60297260711123],[-4.83932337085096,0.733180727003639,4.71310496328957],[3.1392939444038,6.79845202047531,7.43362582405287],[-4.58532403249863,1.33134894083165,2.31461274605229],[2.71537477470836,-2.85927374671043,-3.3517227998266],[-2.79151274856304,-2.13237629386908,-6.74459456005119],[4.18984726751774,2.9180171068678,2.86931789051797],[-1.64922878701678,3.66050088108784,-2.23773550344573],[-5.18622539358913,-0.528492894171106,2.23005675046321],[2.89341282553435,6.13326372296719,-11.9892374800161],[-0.274819746744779,-4.01861592598209,-1.21218471749098],[-4.36141860135014,1.54945183665463,5.06458165766599],[-2.19618521792567,2.09611661677234,3.23082941695652],[-1.72727918985522,3.52545595167445,-2.69404627372754],[-2.72940082608485,6.22360379236304,-0.018824444127406],[0.66180792576077,-3.09293355359069,12.4028325213473],[-6.29142558075922,11.2600914596995,-4.36496206417183],[1.6652884313452,2.95111490784301,-3.07512519240836],[-2.83449069271601,-0.742153340326911,3.75683851534414],[3.72473135951884,-5.54829149592527,-5.29257014587231],[-4.17382920249675,0.710210029364268,2.46335772350039],[8.62455175076914,0.852696900203912,-1.74021379120558],[-2.38492673248259,-3.62075605193048,-9.37026526335497],[1.67354157964442,-6.81416640794364,4.68255407143791],[1.77908778916611,3.64968219457682,-6.27819748058564],[-5.21236484039471,-0.296847570815829,0.367504947480503],[7.98535448025006,2.48153690291326,-1.39842185642509],[-2.68566893874973,9.39753422414228,-5.79218769750773],[4.27492972265414,5.79841736136811,9.24967413655058],[-9.02767004653681,-1.46646848821927,-3.06439049505703],[-4.4315393866714,-6.11783075415724,-9.90036927262499],[1.0136576914096,1.50246185646797,-9.23002553936071],[5.26129559247447,1.3322582696688,5.41553834174315],[-2.65152227960288,5.01502598632104,-7.15814913820803],[1.98174327225695,6.45655309844075,-12.2046004191228],[2.90516862199116,5.82519597828948,-12.0193351406786],[2.80608545916267,-0.165477401845942,-12.176794244203],[2.60296817038695,-3.71143320115855,-11.1227820318104],[-3.46808633973727,-3.03722511406437,-7.36408096810225],[2.4746988921307,-6.84484581922387,-1.2341170095598],[-3.72605285118685,6.85168183585835,-0.051900832083041],[3.84391278721544,-7.36664231231586,-2.19434879929489],[0.584423978571627,-1.56702394583603,-2.35724016559765],[-2.18261122559963,-4.45337189363504,-0.162020108748877],[2.63021471204426,-8.834501719468,-1.351371277466],[0.0291993672167699,-0.441626555870603,-1.89064628629299],[2.14312236773273,-5.22192587041472,4.479820650442],[10.8389532378504,3.18005160672371,-1.96306329182679],[0.653058368193119,6.07596527387459,8.52012600882711],[-1.8013638736611,0.303149702079268,-3.41149019563486],[2.12343800205353,6.43854594385734,8.62937227923993],[-3.1610206454429,5.34879708019531,-0.614305131206731],[4.52939584273335,-6.362604257992,-2.84048400198459],[9.59722508819315,3.10099687176884,-1.13274722297641],[-2.88233065556024,-3.24328181927497,-2.02767138495674],[-5.75291479423957,7.60469574713898,8.93611639923219],[3.33870727787701,5.61871293819592,8.64600346765122],[2.30423222883617,6.03261053584977,-12.1426835028874],[-6.30144500196169,-1.68463002433677,3.73819998834696],[1.9423059070459,-3.6638876448125,-11.3782832400555],[1.48204603400686,-4.72951316025912,4.58915474891018],[1.31978065444375,-5.9614607959303,4.57934709303475],[-5.19256486636245,1.83453817110922,4.29500755171127],[3.39701781327163,11.0126397811525,-1.66218630898622],[7.28622626048753,-2.19526581645729,-10.526693736945],[8.15303686543622,5.23621399282586,-1.02293712789927],[6.90341022743653,-1.87253017263498,-10.120198004997],[-2.50907640818822,-4.28340276345017,-0.399706008434387],[3.7387600414013,6.40832957749428,7.90442590710157],[0.899381344144721,5.46275310890098,8.06775658090246],[1.49227990430243,-7.19152390803775,4.7751514008725],[5.22685656406344,1.2897764298607,5.96039567598065],[-0.800312095178401,0.319172046550404,3.66779914125222],[-4.54346643822724,-5.29088755630154,-2.43516504035347],[-4.89489977896285,-6.52587173143755,-10.1606374780251],[-5.02478150430954,-6.27209728600249,-10.2141529320909],[1.50723122919389,12.0824697309226,-1.42546499867259],[2.05518951772779,-9.00600030405041,-0.0889387848225787],[1.95525094474904,-2.9774294770403,12.7411645405291],[-2.82042539824566,4.44547504268768,-7.45473987516588],[-4.17677001194773,4.26194705089926,-6.79976255164202],[-2.24362445934454,-3.4805964693227,-9.29279147194739],[-1.98636372313665,-0.590193113245826,2.7472057450438],[2.97264899105272,5.59097985643362,8.36117740538153],[-0.757199324710456,1.93606944488712,-1.95082942728316],[4.3714384695577,4.09143639804811,3.32725360812506],[-3.89633487930452,1.28205374221832,2.72958033251453],[-6.32625959854495,2.75253540424243,-6.59755309191838],[-1.9700186610032,0.0129599370203474,-4.98038967538258],[-3.08844266123208,-3.45842697310559,-3.146983868335],[-2.07708158087711,-5.81266418144326,-1.6698616799928],[9.52734943924535,2.46545599262949,-1.2813536155276],[3.58433071749082,4.14011360345314,8.5291658596671],[3.76823168330786,-7.78881623119333,-1.0239429952868],[10.7266633169274,2.98234458333443,-1.51684260359105],[0.125516876430047,-1.68082525187342,-11.2874212039635],[3.31604055026361,10.7972564752135,-2.20024773729538],[3.41325565290693,-9.62348439981841,-0.983909178566267],[11.7823006142221,0.506398291535773,-0.498604706209392],[-2.07773157503276,-3.66760362625066,-0.0491071330421055],[-6.3949265817949,2.854273057995,-3.73751144906589],[10.7992759345278,0.619138680262534,-0.79810324973263],[-1.93032414150519,-4.97145253064857,2.10655535397405],[0.111466812177859,-3.20334646736238,-11.9637621281437],[0.699083294137624,-5.90233471110472,11.3872340315471],[8.88575610995769,-4.45299745142699,-1.03894991774224],[-5.4287384001271,0.962392011099475,4.39138143057814],[-0.225691761208897,9.1431503385861,-7.47522759417222],[1.3354148248837,2.09239203564966,-3.7021608133793],[1.4239384430384,1.35506030717812,-9.6350570076085],[3.33072743362716,11.4502630117354,-1.16782556937971],[7.55748737730883,-1.85623112058988,-10.7358808809832],[1.79530282811092,-7.12194116262838,3.28669814606707],[-3.75680394626325,6.2497704333858,8.26222235213751],[-4.86157874990322,0.0784559619685435,-0.406130239563592],[-2.96335114777589,-3.61747407094004,-0.149342723310448],[-2.71348243649326,-2.87990037167778,-3.05517017226194],[-5.2103272647425,-5.99410975832358,-2.59091679148402],[1.3046365099827,-5.60902362837165,11.0735796139947],[3.12495661206186,5.05733167872815,9.08671033136359],[4.7678816405043,-3.1391627418069,-4.21990821961861],[-4.26205750053544,-1.53107453944146,3.6275718745817],[-0.559263168437309,-7.63544449341463,-5.97495399521827],[3.02981471922916,-4.06046503539731,11.7844655085322],[0.432067037151146,3.48978168156897,-8.76100080533588],[-4.75032447634047,8.01605762877376,7.530398699239],[2.65056357889152,1.40289148369487,-8.22027223342172],[-2.94294454675699,-0.79560518831393,3.42260740268824],[-1.73664322988552,-5.54306025386556,1.89654475809381],[1.81171233280319,-4.7023266657584,-0.143286069252154],[-0.708783796045412,-7.11399123213756,-5.73870473580553],[-7.36991855644808,0.634390063862604,-7.44084010769058],[-4.33466925721337,0.453916798814016,3.08361421912901],[-3.93610326900303,1.67915254164767,2.35430384522253],[2.27892155193633,11.2993299268264,-2.02082919613725],[-3.89886296374347,8.17258275716168,-6.4181692048726],[-4.68709786649598,-0.4856810863239,2.85701980265141],[2.79876636814846,10.9376427865502,-0.920492049455078],[1.36492224104892,-6.37145417029012,4.43288453482149],[4.50585579208976,4.67701581608287,3.40544049349852],[1.71517386319563,-9.89995457858646,-0.786842405541088],[0.999862261552962,-5.28982283948763,11.6606397795777],[1.12376719512257,1.71392450382183,-10.0311176112621],[2.38611910700604,-9.32575900961615,-0.770032265340153],[4.3368639808634,-6.01669229600382,-1.46294711568652],[1.63099480072548,-7.06817465512287,3.42127560055032],[2.83150318100352,-6.11883066935578,4.43135105093443],[1.4001664196823,6.31637646622764,-11.34122490371],[9.37703294155716,2.43818599791264,-0.908054882223144],[-2.5951654899168,-0.427345320378996,-0.74462886253675],[10.4206730868668,0.667704581014926,-0.781403089014469],[-3.52781181984768,4.06745960090794,-7.29649779395011],[-4.79346621142897,1.77669388609765,4.46823667917859],[2.34366908032652,-7.73590357360081,-11.1051177337656],[-0.0073051498258474,8.12743567004405,-6.78464645508437],[0.980230046987595,-3.20585971383694,12.4381768963774],[8.45906254593903,2.30434403022265,-1.46295358564395],[2.13450580016551,5.83984223431129,8.53274566555368],[-8.76818209077983,-5.66931692137942,0.970890755142584],[-3.71801598374524,8.32376897866035,-6.53568875662289],[2.67638849049504,-8.04173173858286,-1.17918068524036],[0.691153116245782,-7.02674289271869,2.33370042959569],[8.60648547376666,6.89687027636664,0.831149128134531],[-1.67240964916784,-5.03067976614202,1.61631267216313],[1.64202932574342,-6.89232942866309,3.6088342219544],[-2.69654014876551,-0.225776613727301,0.515018469172176],[3.08140400100053,-4.53617312819877,-1.2918904425694],[1.75599537599524,-1.48719025214228,-6.78934093773099],[8.67625859183867,1.32058430155445,-1.60161678722887],[9.49031342074782,-0.681861068586109,-0.842437268518101],[2.73567958517607,-4.58548960944555,10.1053027545591],[2.90764686414783,6.28644808270904,-12.0806478450189],[-6.00569056173287,8.07755345502022,8.14882641069375],[-5.66256499700319,-3.07407183041783,-5.09479004486592],[1.62897190888321,-4.82675558313368,3.56169144924632],[-5.69293219887563,7.08106834862119,8.94120751758681],[-5.86941511171633,2.59873605619479,-6.28323502653457],[2.60370550067123,5.26418174605585,9.02032171383366],[3.23607787080399,-4.64522212953591,-1.20617595917917],[2.07418940433883,4.94532922803595,8.74345607011411],[-5.77222754479996,2.66181955867675,-5.98364912582024],[4.44487612083705,4.12331998731851,3.40045687537926],[-4.47441212884538,-5.61256445725534,-2.98257473668465],[-5.88002924856192,-0.485907449331618,-1.41332722289973],[-1.50319760849166,7.21749030767704,-7.12290826314535],[5.26658424197836,1.41570665086674,5.09526167922105],[0.922000018754746,-7.80535577814237,1.53962423030684],[3.21640099951238,-4.39809837961496,-1.50354557666412],[-3.58995487747851,1.48584288343533,2.91170751321213],[0.923372778308198,-8.72190695980148,2.66176526432444],[3.49603470086731,4.32663699318497,8.60101592916251],[8.28348618488459,3.82788239667335,-2.33377751945927],[2.5573307789242,6.20396232250381,8.23813555378536],[2.86261554030413,4.14698446034806,8.79246958069715],[1.19053652878119,3.60293799052242,-3.87689340323547],[-6.30859898627522,3.74787395347331,-5.30518853123812],[-5.8459972939378,-3.32359165571257,4.72420163723557],[10.5373006171983,-0.698342692741345,0.681235131911902],[-3.97304205881948,1.53777513592444,4.787760143584],[-4.00925941839198,1.13419128663084,3.49768686474783],[1.11186307285283,-6.86958632778193,-0.194383530441207],[0.905108392040629,-3.91957432108472,-1.66630911717397],[-5.44839854272502,7.0654171348068,7.9660736110775],[-1.91696137052375,-2.76718781956739,-2.58616133701451],[-2.54267471520854,0.689115806504021,-1.19965800111914],[-5.74080406625297,8.18941357980382,-4.27399549106374],[-4.34133983237437,-6.04147149602256,7.88058062513224],[-5.1604920220158,3.65530881783908,-6.69144167440447],[-0.42706474386804,-2.62464933122876,10.1840516548414],[1.74533620772921,-7.42244319293687,2.33856845718773],[0.852898710804768,-6.95955395792368,2.22927462225401],[1.44151689617418,-6.15022940404353,4.87451839566532],[-4.12515657019248,2.7015720537447,-5.43447151744571],[-3.91157642763616,3.32094672125419,-6.68187780968264],[9.57570364338563,-4.4223337371649,-6.04122601485144],[-0.379951613750725,1.67233181126674,-4.5189639669707],[-4.46382003587776,-6.19736461124827,-2.80093284084547],[-4.14184636740116,0.471536165012388,3.85195656591902],[-4.79046994456095,6.90422985882093,9.25165997176448],[0.853858693514212,3.98808063265308,-8.64877758552185],[-2.71592285708705,-0.0507095963876321,0.475086196104325],[0.028894379465354,-7.46955655046732,1.8921693012053],[-0.166474848464807,-1.09125489654546,-13.5443923299291],[1.74862605023176,-3.19820104651592,12.3610634402115],[5.03651239235123,1.70717358463261,5.0726690670335],[-1.61034617190078,5.10176936412097,-3.54408903531533],[11.9665438592302,3.9600244000828,-1.23500074089675],[2.22741557628085,5.9391314537515,-12.0746110264088],[-9.26901237171322,-0.276247461061678,-5.24178520731402],[-9.08714847031734,0.0458004467398921,-5.65800499725068],[0.975158396402586,2.02553726198687,-2.90140259202327],[1.01361130509574,-3.18121275727687,12.7314064251306],[4.19676474652763,-6.27337721122954,-1.40404667278684],[1.19783331785133,-6.21121325011561,3.13615496922648],[1.89831953249103,-7.86797844427894,2.21731529996532],[2.14647614249489,-7.60203713687558,2.51791021995997],[-3.97763070713716,1.24052438028279,2.4081681140245],[1.58664596976969,4.11870709727098,-4.49442913687135],[-1.03706693014065,-7.52257481536484,0.236253466270192],[2.73686025699784,-9.89184048830354,-0.0927224214707303],[3.22349054254828,5.57796855164327,6.39090069837614],[4.1655061432382,1.02733564846968,-9.13997604335034],[1.94375630341412,-10.5952624939058,0.0872857087428461],[1.75430048414883,-3.16632456392421,12.3715454572405],[2.13460865521155,5.8565181198006,-11.9908564782878],[-4.01319918783242,-1.12557231246381,1.94720476831168],[-3.15736624828169,5.1346156222157,-2.15978871752756],[-4.79553378957224,5.9548577994973,8.79411392828533],[4.46868193502931,-7.87153415678099,-2.82499561917787],[0.410611434796629,0.844835939473022,2.59632934830764],[1.22388492571237,10.1591278107754,-1.94278401690703],[-2.77490813508495,4.66964810457717,-7.46611193766434],[-0.401396609973762,0.833338858958043,3.64787263943924],[3.63610879649962,5.79003317048287,9.47652338687972],[4.95678529772349,1.6401914075398,5.84908604755918],[2.00972390610202,-8.60523031267786,1.19274188875745],[7.60974130134282,-2.02124978198653,-10.7183576481349],[1.86426885031306,12.2591511093443,-2.28144889510017],[-5.53418038316533,-3.11988225233904,-4.95263160013037],[0.183193433074781,7.81734775783703,-6.61925233156823],[-3.93566483169332,0.126365214138194,3.40264753921431],[2.41916348598502,4.32760051680642,7.87363104308535],[-2.93252604178054,2.24290168697582,-5.40023955161455],[1.57237036211775,-5.39798071154642,10.9415475358221],[1.07187403783673,3.15985455674228,-3.83442539243451],[0.0656052309720693,-8.17705827824264,0.959191613842649],[3.20325106493589,12.0008693202736,-2.2900332601027],[-3.76539548899238,1.47625056735731,1.94917311389821]],"plotType":"shapeCloud","colorBy":"categories","colorVar":["Bone_Marrow_Mesenchyme","MammaryGland.Involution","Testis","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Heart","Embryonic-Mesenchyme","Brain","Embryonic-Mesenchyme","Bone-Marrow","Lung","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Testis","Embryonic-Stem-Cell","Fetal_Brain","Embryonic-Stem-Cell","Fetal_Intestine","Small-Intestine","Trophoblast-Stem-Cell","Neonatal-Calvaria","Placenta","Trophoblast-Stem-Cell","Liver","Thymus","Kidney","Neonatal-Heart","Neonatal-Skin","Neonatal-Muscle","Neonatal-Skin","Mesenchymal-Stem-Cell-Cultured","Uterus","Bone-Marrow_c-kit","Neonatal-Calvaria","Stomach","Neonatal-Rib","Neonatal-Rib","Brain","Placenta","Liver","Neonatal-Muscle","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Small-Intestine","Thymus","Ovary","Peripheral_Blood","Bone-Marrow","Neonatal-Rib","Bone-Marrow_c-kit","Fetal_Stomache","Pancreas","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Neonatal-Skin","MammaryGland.Virgin","Fetal_Stomache","Liver","Trophoblast-Stem-Cell","Testis","Testis","Lung","Bone-Marrow_c-kit","Bone-Marrow","MammaryGland.Virgin","Bone-Marrow","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Bone-Marrow","Fetal_Intestine","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Placenta","Bone-Marrow_c-kit","Neonatal-Heart","Small-Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Pancreas","Placenta","Fetal_Lung","Fetal_Intestine","Pancreas","Liver","Trophoblast-Stem-Cell","Lung","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Bone-Marrow","Neonatal-Skin","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Fetal_Brain","Prostate","Fetal_Stomache","Bone-Marrow_c-kit","Testis","Bone-Marrow","Liver","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Fetal_Intestine","Bone_Marrow_Mesenchyme","Testis","Bone-Marrow_c-kit","Kidney","Lung","Kidney","Bone_Marrow_Mesenchyme","Small-Intestine","Fetal_Stomache","Fetal_Stomache","Fetal_Lung","Embryonic-Stem-Cell","Pancreas","Small-Intestine","MammaryGland.Lactation","Trophoblast-Stem-Cell","Testis","Brain","MammaryGland.Lactation","Embryonic-Stem-Cell","Placenta","Testis","MammaryGland.Virgin","Bone-Marrow","Placenta","Small-Intestine","Neonatal-Calvaria","Fetal_Stomache","Bone-Marrow_c-kit","Testis","MammaryGland.Lactation","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Muscle","Trophoblast-Stem-Cell","Bladder","Neonatal-Heart","Thymus","Ovary","Ovary","Bone-Marrow_c-kit","Neonatal-Muscle","Placenta","Uterus","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Neonatal-Heart","Trophoblast-Stem-Cell","Bladder","Trophoblast-Stem-Cell","Thymus","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Pancreas","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Liver","Embryonic-Stem-Cell","Fetal_Stomache","Lung","MammaryGland.Lactation","Bone-Marrow_c-kit","Liver","Neonatal-Calvaria","Neonatal-Rib","Liver","Bone-Marrow_c-kit","Testis","Testis","Neonatal-Rib","Lung","Bone-Marrow_c-kit","Prostate","Pancreas","Testis","Uterus","Kidney","Neonatal-Rib","Trophoblast-Stem-Cell","Fetal-Liver","Bone-Marrow_c-kit","Fetal-Liver","Trophoblast-Stem-Cell","Neonatal-Skin","Lung","MammaryGland.Pregnancy","Small-Intestine","Thymus","Neonatal-Skin","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Placenta","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Involution","Bone-Marrow","Fetal_Brain","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Muscle","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","Liver","Uterus","Uterus","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Brain","Neonatal-Muscle","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Peripheral_Blood","Bone-Marrow_c-kit","Lung","Fetal_Intestine","Bladder","Bone-Marrow","Liver","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone-Marrow_c-kit","Liver","Fetal_Stomache","Kidney","Neonatal-Heart","Bone_Marrow_Mesenchyme","Embryonic-Mesenchyme","Peripheral_Blood","Liver","Fetal_Lung","Bone-Marrow_c-kit","Prostate","Embryonic-Stem-Cell","Lung","Trophoblast-Stem-Cell","Small-Intestine","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Ovary","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Ovary","Bone-Marrow_c-kit","Fetal_Brain","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Virgin","Spleen","MammaryGland.Lactation","Brain","Fetal_Brain","MammaryGland.Pregnancy","Prostate","Neonatal-Calvaria","Ovary","Bone_Marrow_Mesenchyme","Small-Intestine","Fetal-Liver","Fetal_Lung","Trophoblast-Stem-Cell","Testis","Bone-Marrow_c-kit","Testis","Fetal_Brain","Uterus","MammaryGland.Involution","Bone-Marrow","Placenta","MammaryGland.Lactation","MammaryGland.Lactation","Thymus","Trophoblast-Stem-Cell","Fetal-Liver","MammaryGland.Lactation","Fetal_Brain","Fetal_Stomache","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Pancreas","Fetal-Liver","Bone-Marrow_c-kit","Fetal_Stomache","Stomach","Bone_Marrow_Mesenchyme","Placenta","Lung","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Placenta","MammaryGland.Virgin","MammaryGland.Virgin","MammaryGland.Lactation","Brain","Bone-Marrow_c-kit","Placenta","Neonatal-Heart","Fetal_Intestine","Testis","Placenta","Placenta","Lung","Placenta","Fetal_Intestine","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Prostate","Fetal_Stomache","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","Brain","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Pancreas","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Small-Intestine","Stomach","Testis","Neonatal-Calvaria","Testis","Neonatal-Skin","MammaryGland.Involution","Peripheral_Blood","Neonatal-Rib","Bone-Marrow","Fetal-Liver","MammaryGland.Lactation","Testis","Brain","Kidney","Placenta","Neonatal-Rib","Trophoblast-Stem-Cell","Neonatal-Muscle","Bone-Marrow_c-kit","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Peripheral_Blood","Embryonic-Stem-Cell","Neonatal-Calvaria","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Small-Intestine","Neonatal-Rib","Fetal_Lung","Ovary","MammaryGland.Involution","Neonatal-Calvaria","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Neonatal-Skin","MammaryGland.Involution","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Heart","MammaryGland.Involution","Peripheral_Blood","Fetal_Stomache","Stomach","Fetal-Liver","MammaryGland.Lactation","MammaryGland.Pregnancy","Ovary","Trophoblast-Stem-Cell","Lung","Neonatal-Calvaria","Muscle","Bone-Marrow","Neonatal-Calvaria","Neonatal-Calvaria","Fetal_Lung","Fetal_Brain","Bone-Marrow_c-kit","Fetal_Lung","Fetal_Lung","Bone-Marrow_c-kit","Bone-Marrow","Brain","MammaryGland.Lactation","Fetal_Lung","Fetal_Brain","Neonatal-Calvaria","Fetal_Stomache","Testis","Spleen","MammaryGland.Lactation","Spleen","Fetal_Stomache","Testis","Bone-Marrow_c-kit","Neonatal-Calvaria","Liver","Fetal-Liver","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Bone-Marrow","Testis","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Muscle","Bone-Marrow_c-kit","Pancreas","MammaryGland.Pregnancy","MammaryGland.Lactation","Neonatal-Calvaria","Bone-Marrow_c-kit","Bladder","Uterus","Bone_Marrow_Mesenchyme","Kidney","Fetal_Stomache","Neonatal-Calvaria","Fetal_Lung","Pancreas","Bone-Marrow","Bone-Marrow_c-kit","Bladder","Fetal_Stomache","MammaryGland.Involution","Ovary","Embryonic-Mesenchyme","Neonatal-Heart","Lung","Fetal_Intestine","Neonatal-Muscle","Neonatal-Rib","Bone-Marrow_c-kit","Fetal_Lung","Kidney","Peripheral_Blood","Bone-Marrow_c-kit","Thymus","Embryonic-Stem-Cell","Neonatal-Rib","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Intestine","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Muscle","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Lung","Neonatal-Muscle","Peripheral_Blood","Fetal_Lung","Bone-Marrow_c-kit","MammaryGland.Lactation","Ovary","Small-Intestine","Neonatal-Heart","Fetal_Intestine","Neonatal-Heart","Testis","Liver","Embryonic-Stem-Cell","Small-Intestine","Trophoblast-Stem-Cell","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bone-Marrow","Embryonic-Stem-Cell","MammaryGland.Lactation","MammaryGland.Lactation","Spleen","Bone_Marrow_Mesenchyme","Peripheral_Blood","Embryonic-Stem-Cell","Liver","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Prostate","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Rib","MammaryGland.Lactation","Brain","Spleen","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Skin","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow_c-kit","Ovary","Brain","Trophoblast-Stem-Cell","Placenta","Pancreas","Bone_Marrow_Mesenchyme","Bone-Marrow","Peripheral_Blood","Testis","Mesenchymal-Stem-Cell-Cultured","Placenta","Testis","Uterus","Testis","Fetal_Brain","Placenta","Neonatal-Muscle","Fetal_Lung","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Embryonic-Mesenchyme","Embryonic-Mesenchyme","Pancreas","Fetal_Intestine","Trophoblast-Stem-Cell","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Ovary","Fetal-Liver","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Peripheral_Blood","Uterus","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Lactation","Testis","MammaryGland.Lactation","Fetal_Brain","MammaryGland.Pregnancy","Placenta","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Lung","Pancreas","Ovary","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Lactation","Muscle","Fetal-Liver","Neonatal-Calvaria","Fetal_Intestine","Placenta","Small-Intestine","Peripheral_Blood","Fetal-Liver","Testis","Trophoblast-Stem-Cell","Peripheral_Blood","Trophoblast-Stem-Cell","MammaryGland.Involution","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bladder","Placenta","Bone-Marrow_c-kit","Uterus","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Thymus","Trophoblast-Stem-Cell","Fetal_Lung","Bone-Marrow_c-kit","Neonatal-Skin","Neonatal-Heart","Stomach","Small-Intestine","Thymus","Ovary","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Testis","Testis","Ovary","Trophoblast-Stem-Cell","Fetal_Intestine","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Ovary","MammaryGland.Pregnancy","Peripheral_Blood","MammaryGland.Lactation","Neonatal-Muscle","Embryonic-Stem-Cell","Muscle","Testis","Lung","Neonatal-Heart","Uterus","Spleen","Ovary","Testis","Spleen","Stomach","Placenta","Neonatal-Skin","Ovary","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Testis","Bone-Marrow","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Placenta","Bone-Marrow_c-kit","Ovary","Testis","Bone-Marrow_c-kit","Neonatal-Heart","Liver","Neonatal-Calvaria","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Calvaria","Bone-Marrow_c-kit","Neonatal-Calvaria","Small-Intestine","Fetal_Intestine","Bone-Marrow_c-kit","Fetal_Stomache","Fetal_Brain","MammaryGland.Pregnancy","MammaryGland.Lactation","Testis","Placenta","Fetal-Liver","Fetal-Liver","Bone-Marrow_c-kit","Lung","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Rib","Bone-Marrow_c-kit","Pancreas","MammaryGland.Lactation","Small-Intestine","Lung","Kidney","Trophoblast-Stem-Cell","MammaryGland.Lactation","Lung","Fetal_Lung","Bone-Marrow","MammaryGland.Pregnancy","Peripheral_Blood","Kidney","Neonatal-Skin","Neonatal-Heart","Bone-Marrow_c-kit","Fetal_Intestine","MammaryGland.Lactation","Bone-Marrow_c-kit","MammaryGland.Virgin","Prostate","MammaryGland.Lactation","MammaryGland.Involution","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Lung","Small-Intestine","Small-Intestine","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Neonatal-Heart","Bone-Marrow","Fetal_Stomache","Bone-Marrow_c-kit","Peripheral_Blood","Neonatal-Rib","MammaryGland.Involution","Bone-Marrow","Peripheral_Blood","Bone_Marrow_Mesenchyme","Fetal_Brain","Kidney","Liver","MammaryGland.Lactation","Bone-Marrow_c-kit","Peripheral_Blood","MammaryGland.Involution","Neonatal-Calvaria","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Lung","Bone_Marrow_Mesenchyme","Brain","Bone-Marrow_c-kit","Peripheral_Blood","MammaryGland.Pregnancy","MammaryGland.Pregnancy","Neonatal-Calvaria","Uterus","MammaryGland.Lactation","Testis","Trophoblast-Stem-Cell","Fetal_Stomache","Testis","Embryonic-Stem-Cell","Fetal-Liver","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Heart","MammaryGland.Virgin","MammaryGland.Lactation","Fetal-Liver","Stomach","Neonatal-Rib","Testis","Fetal_Intestine","Trophoblast-Stem-Cell","Neonatal-Heart","Neonatal-Heart","Bone-Marrow_c-kit","MammaryGland.Pregnancy","MammaryGland.Lactation","MammaryGland.Lactation","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow_c-kit","Fetal_Intestine","Prostate","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow","Thymus","Testis","Bone-Marrow_c-kit","Lung","MammaryGland.Lactation","Small-Intestine","Peripheral_Blood","MammaryGland.Lactation","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Stomache","Uterus","MammaryGland.Lactation","Thymus","Fetal_Stomache","Testis","Bone-Marrow_c-kit","Placenta","Small-Intestine","MammaryGland.Lactation","MammaryGland.Virgin","Bone-Marrow_c-kit","Placenta","Bone_Marrow_Mesenchyme","Fetal_Lung","Liver","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Ovary","Bladder","Bone-Marrow_c-kit","MammaryGland.Involution","Lung","MammaryGland.Pregnancy","Neonatal-Heart","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Bladder","Neonatal-Calvaria","MammaryGland.Lactation","MammaryGland.Virgin","Ovary","Fetal_Intestine","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow","MammaryGland.Involution","Trophoblast-Stem-Cell","Neonatal-Muscle","Trophoblast-Stem-Cell","MammaryGland.Involution","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Testis","MammaryGland.Lactation","Neonatal-Skin","MammaryGland.Pregnancy","MammaryGland.Lactation","Neonatal-Heart","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Pancreas","Peripheral_Blood","Small-Intestine","Fetal_Intestine","Testis","Uterus","Neonatal-Skin","Fetal_Brain","Neonatal-Calvaria","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Uterus","Peripheral_Blood","Testis","Ovary","Testis","Peripheral_Blood","Pancreas","Fetal_Brain","Fetal_Brain","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Calvaria","Peripheral_Blood","MammaryGland.Virgin","Trophoblast-Stem-Cell","Neonatal-Rib","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Neonatal-Heart","Fetal_Intestine","MammaryGland.Lactation","Lung","Fetal_Lung","Stomach","Spleen","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Testis","Small-Intestine","Brain","Stomach","Bladder","Testis","Neonatal-Rib","Fetal-Liver","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Prostate","Neonatal-Calvaria","Testis","Trophoblast-Stem-Cell","Fetal_Brain","Fetal_Lung","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Neonatal-Muscle","Neonatal-Rib","Thymus","Testis","Uterus","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Thymus","Bone-Marrow_c-kit","Fetal_Stomache","Prostate","Bone-Marrow","Bone-Marrow_c-kit","Neonatal-Muscle","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Brain","Trophoblast-Stem-Cell","Testis","MammaryGland.Involution","Pancreas","Small-Intestine","Neonatal-Calvaria","MammaryGland.Lactation","MammaryGland.Lactation","Bone-Marrow","MammaryGland.Lactation","Brain","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Placenta","Testis","Small-Intestine","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Ovary","Trophoblast-Stem-Cell","Fetal-Liver","Uterus","Bone-Marrow_c-kit","Lung","Neonatal-Muscle","Fetal-Liver","Peripheral_Blood","Trophoblast-Stem-Cell","Testis","MammaryGland.Virgin","MammaryGland.Lactation","Liver","Bone-Marrow_c-kit","Uterus","MammaryGland.Pregnancy","Fetal_Stomache","MammaryGland.Lactation","MammaryGland.Pregnancy","MammaryGland.Involution","Trophoblast-Stem-Cell","Neonatal-Heart","Neonatal-Muscle","Bone-Marrow","Bone-Marrow_c-kit","Lung","Peripheral_Blood","Fetal_Stomache","Kidney","Testis","Muscle","Liver","Trophoblast-Stem-Cell","Brain","Lung","Embryonic-Stem-Cell","Pancreas","Placenta","MammaryGland.Involution","Bone-Marrow","Trophoblast-Stem-Cell","Testis","Fetal_Lung","Neonatal-Calvaria","Pancreas","Testis","Fetal_Intestine","Thymus","Trophoblast-Stem-Cell","Ovary","MammaryGland.Virgin","Thymus","Trophoblast-Stem-Cell","MammaryGland.Lactation","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Uterus","Bone-Marrow_c-kit","Uterus","Bone-Marrow_c-kit","Bone-Marrow","Brain","Neonatal-Rib","Fetal_Lung","Bone-Marrow_c-kit","Placenta","Small-Intestine","Stomach","Lung","Neonatal-Rib","Fetal_Stomache","Embryonic-Stem-Cell","Peripheral_Blood","Muscle","Testis","Neonatal-Rib","Fetal-Liver","Lung","Liver","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Uterus","Bone-Marrow_c-kit","Neonatal-Rib","MammaryGland.Involution","MammaryGland.Lactation","Neonatal-Calvaria","Spleen","Prostate","Thymus","Peripheral_Blood","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Fetal_Brain","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Lung","Fetal_Intestine","Liver","Bone-Marrow_c-kit","Fetal_Brain","Bone-Marrow_c-kit","Testis","Ovary","Neonatal-Calvaria","Bone-Marrow_c-kit","Lung","Pancreas","Liver","Bone-Marrow_c-kit","Fetal_Stomache","Kidney","MammaryGland.Lactation","Bone-Marrow","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Neonatal-Rib","Fetal_Stomache","Testis","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Testis","Pancreas","Peripheral_Blood","Testis","Kidney","Lung","Lung","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Neonatal-Calvaria","Kidney","Bone_Marrow_Mesenchyme","Testis","Brain","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Testis","Trophoblast-Stem-Cell","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Calvaria","Placenta","Testis","Fetal-Liver","Trophoblast-Stem-Cell","Peripheral_Blood","Bone-Marrow_c-kit","Uterus","Bone-Marrow_c-kit","Fetal_Stomache","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Placenta","Uterus","Peripheral_Blood","Fetal_Lung","Neonatal-Heart","Neonatal-Heart","Testis","Trophoblast-Stem-Cell","Ovary","Fetal_Brain","Bladder","Peripheral_Blood","Neonatal-Calvaria","Fetal_Lung","Trophoblast-Stem-Cell","Bone-Marrow","Liver","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Neonatal-Calvaria","MammaryGland.Virgin","Neonatal-Skin","MammaryGland.Involution","Small-Intestine","MammaryGland.Virgin","Brain","Bone-Marrow_c-kit","Lung","Trophoblast-Stem-Cell","MammaryGland.Lactation","Embryonic-Stem-Cell","MammaryGland.Lactation","Peripheral_Blood","Neonatal-Rib","Trophoblast-Stem-Cell","Small-Intestine","Small-Intestine","Bone-Marrow","Ovary","Fetal_Lung","Bone-Marrow_c-kit","Thymus","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal_Stomache","Trophoblast-Stem-Cell","Lung","Neonatal-Skin","Bone-Marrow_c-kit","Neonatal-Heart","Trophoblast-Stem-Cell","Fetal_Brain","MammaryGland.Lactation","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Prostate","Neonatal-Muscle","Neonatal-Skin","Trophoblast-Stem-Cell","Brain","MammaryGland.Lactation","Trophoblast-Stem-Cell","Neonatal-Muscle","Ovary","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Virgin","Testis","Fetal_Lung","Fetal_Stomache","Neonatal-Calvaria","Testis","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Stomach","MammaryGland.Lactation","Embryonic-Stem-Cell","Lung","Uterus","MammaryGland.Lactation","Neonatal-Rib","Fetal_Stomache","Embryonic-Stem-Cell","MammaryGland.Virgin","Fetal_Lung","Fetal_Stomache","Bladder","Trophoblast-Stem-Cell","Fetal_Stomache","Lung","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Pancreas","Liver","Liver","Embryonic-Stem-Cell","Prostate","Spleen","Ovary","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Virgin","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Fetal_Intestine","Neonatal-Rib","Fetal_Stomache","Testis","Spleen","Embryonic-Mesenchyme","MammaryGland.Lactation","Neonatal-Calvaria","MammaryGland.Lactation","MammaryGland.Lactation","Ovary","Thymus","Bone-Marrow_c-kit","Neonatal-Calvaria","Kidney","Testis","Bone-Marrow_c-kit","Neonatal-Calvaria","Neonatal-Rib","Lung","Bone_Marrow_Mesenchyme","Fetal_Lung","Small-Intestine","Embryonic-Stem-Cell","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Pancreas","Lung","Trophoblast-Stem-Cell","Kidney","Mesenchymal-Stem-Cell-Cultured","Ovary","Mesenchymal-Stem-Cell-Cultured","Stomach","MammaryGland.Virgin","Uterus","Fetal_Stomache","MammaryGland.Virgin","Fetal_Stomache","Prostate","Trophoblast-Stem-Cell","Uterus","Bone-Marrow","Placenta","Neonatal-Heart","Embryonic-Stem-Cell","Neonatal-Muscle","Trophoblast-Stem-Cell","Testis","Mesenchymal-Stem-Cell-Cultured","Fetal_Lung","Peripheral_Blood","MammaryGland.Pregnancy","Fetal_Lung","Embryonic-Stem-Cell","MammaryGland.Lactation","Stomach","Neonatal-Rib","Neonatal-Skin","Liver","Lung","Fetal_Intestine","Testis","Bone-Marrow","Bone-Marrow_c-kit","Neonatal-Calvaria","Testis","Embryonic-Stem-Cell","Fetal_Intestine","MammaryGland.Virgin","Neonatal-Calvaria","Embryonic-Stem-Cell","Neonatal-Muscle","Brain","Lung","Bone-Marrow_c-kit","Spleen","Fetal_Brain","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal-Liver","Fetal_Lung","Trophoblast-Stem-Cell","Thymus","Bone-Marrow","Brain","Trophoblast-Stem-Cell","Fetal_Brain","Neonatal-Heart","Bone-Marrow_c-kit","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","Neonatal-Rib","Trophoblast-Stem-Cell","Fetal_Lung","Fetal_Stomache","Pancreas","Bone-Marrow","Bone-Marrow_c-kit","Fetal_Brain","Bone-Marrow","Lung","Embryonic-Stem-Cell","Brain","Bladder","MammaryGland.Involution","Bone-Marrow","Small-Intestine","Fetal_Stomache","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Uterus","Spleen","Fetal_Lung","Uterus","Neonatal-Muscle","Bone-Marrow","Bone-Marrow","Fetal_Stomache","Trophoblast-Stem-Cell","MammaryGland.Lactation","Fetal_Stomache","Bone-Marrow","Bone-Marrow_c-kit","Kidney","Thymus","Neonatal-Rib","Bone-Marrow_c-kit","Pancreas","Uterus","Neonatal-Heart","MammaryGland.Lactation","Lung","Neonatal-Skin","Embryonic-Stem-Cell","Lung","Neonatal-Muscle","Peripheral_Blood","Stomach","Testis","Bone-Marrow_c-kit","Bone-Marrow","Testis","Bone-Marrow_c-kit","Peripheral_Blood","Neonatal-Skin","Peripheral_Blood","Trophoblast-Stem-Cell","MammaryGland.Lactation","MammaryGland.Virgin","Bone-Marrow_c-kit","Testis","Embryonic-Stem-Cell","Liver","Bone-Marrow","Fetal_Intestine","Bone-Marrow_c-kit","Neonatal-Calvaria","Placenta","Testis","Peripheral_Blood","Thymus","Small-Intestine","Lung","Testis","Small-Intestine","Stomach","Lung","Fetal_Lung","Fetal_Intestine","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Small-Intestine","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","Uterus","Bone-Marrow_c-kit","Neonatal-Muscle","Testis","Liver","Lung","Testis","Bone-Marrow","Prostate","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","MammaryGland.Virgin","Trophoblast-Stem-Cell","Neonatal-Heart","Embryonic-Stem-Cell","Neonatal-Rib","Small-Intestine","MammaryGland.Lactation","Testis","Bladder","Lung","Bladder","Bone_Marrow_Mesenchyme","Testis","Testis","MammaryGland.Pregnancy","MammaryGland.Lactation","Prostate","Peripheral_Blood","Spleen","Testis","Ovary","Neonatal-Rib","Embryonic-Mesenchyme","Pancreas","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","Trophoblast-Stem-Cell","Prostate","Trophoblast-Stem-Cell","MammaryGland.Involution","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Spleen","Ovary","Embryonic-Mesenchyme","Liver","Stomach","Bone-Marrow_c-kit","Stomach","Lung","Neonatal-Calvaria","MammaryGland.Involution","MammaryGland.Lactation","Bone-Marrow","Lung","Bone-Marrow","Trophoblast-Stem-Cell","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","Kidney","Embryonic-Stem-Cell","Small-Intestine","MammaryGland.Virgin","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Liver","Bone-Marrow_c-kit","Brain","Small-Intestine","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Fetal_Lung","Bone-Marrow_c-kit","Peripheral_Blood","MammaryGland.Pregnancy","Uterus","Testis","Neonatal-Muscle","Neonatal-Heart","Bladder","Neonatal-Rib","Fetal_Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Kidney","Neonatal-Rib","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Testis","Bone-Marrow_c-kit","MammaryGland.Virgin","Peripheral_Blood","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Thymus","Trophoblast-Stem-Cell","Bone-Marrow","Fetal_Lung","Trophoblast-Stem-Cell","Testis","Liver","Brain","Fetal_Brain","Thymus","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","Bone-Marrow","Neonatal-Rib","Neonatal-Calvaria","Small-Intestine","Neonatal-Rib","Bone-Marrow_c-kit","Uterus","MammaryGland.Lactation","Testis","Ovary","Neonatal-Skin","Small-Intestine","Bone-Marrow_c-kit","Fetal_Lung","Liver","Testis","Fetal_Lung","Bone-Marrow","Placenta","Trophoblast-Stem-Cell","Testis","Neonatal-Calvaria","Neonatal-Skin","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Peripheral_Blood","Kidney","Muscle","Embryonic-Stem-Cell","Brain","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","MammaryGland.Lactation","Fetal_Lung","MammaryGland.Involution","MammaryGland.Pregnancy","Fetal_Lung","Peripheral_Blood","MammaryGland.Lactation","MammaryGland.Virgin","Kidney","Neonatal-Calvaria","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Neonatal-Calvaria","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Involution","Peripheral_Blood","Lung","Neonatal-Skin","Neonatal-Rib","Small-Intestine","Testis","Mesenchymal-Stem-Cell-Cultured","Prostate","Uterus","Fetal_Stomache","Thymus","Neonatal-Calvaria","Embryonic-Stem-Cell","Stomach","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Fetal_Intestine","Testis","Small-Intestine","Small-Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Involution","Bone_Marrow_Mesenchyme","Testis","Kidney","Neonatal-Muscle","Neonatal-Calvaria","Bone-Marrow","Ovary","Embryonic-Stem-Cell","Neonatal-Rib","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Peripheral_Blood","Bladder","Fetal_Stomache","MammaryGland.Virgin","Peripheral_Blood","Neonatal-Heart","Neonatal-Skin","MammaryGland.Lactation","Neonatal-Calvaria","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Fetal_Brain","Bladder","Trophoblast-Stem-Cell","Bone-Marrow","Neonatal-Calvaria","Fetal_Stomache","Neonatal-Skin","Neonatal-Rib","Thymus","Embryonic-Mesenchyme","Testis","Fetal_Stomache","Peripheral_Blood","Embryonic-Stem-Cell","Fetal_Lung","MammaryGland.Virgin","MammaryGland.Involution","Peripheral_Blood","Uterus","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","MammaryGland.Lactation","MammaryGland.Pregnancy","MammaryGland.Lactation","Bladder","Neonatal-Calvaria","Neonatal-Skin","Neonatal-Muscle","Peripheral_Blood","Bone-Marrow","MammaryGland.Involution","Liver","MammaryGland.Lactation","Neonatal-Rib","Placenta","Brain","Uterus","Embryonic-Stem-Cell","Ovary","Bone-Marrow_c-kit","Neonatal-Heart","Lung","Thymus","Bone-Marrow_c-kit","Thymus","Fetal_Stomache","Bone-Marrow_c-kit","Testis","Neonatal-Heart","Prostate","Peripheral_Blood","Embryonic-Stem-Cell","Neonatal-Heart","MammaryGland.Virgin","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Testis","Trophoblast-Stem-Cell","Kidney","Pancreas","Embryonic-Stem-Cell","MammaryGland.Lactation","Bone-Marrow","Neonatal-Calvaria","Kidney","Bone-Marrow_c-kit","Fetal_Intestine","Fetal_Lung","Peripheral_Blood","Trophoblast-Stem-Cell","Bone-Marrow","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Testis","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Testis","Kidney","Ovary","MammaryGland.Virgin","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Rib","Bone_Marrow_Mesenchyme","Neonatal-Rib","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Neonatal-Muscle","MammaryGland.Involution","Bone-Marrow_c-kit","Neonatal-Rib","MammaryGland.Lactation","Placenta","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Trophoblast-Stem-Cell","Placenta","Placenta","Neonatal-Skin","Bone-Marrow_c-kit","Peripheral_Blood","Muscle","Brain","Neonatal-Calvaria","Bone-Marrow_c-kit","Neonatal-Muscle","MammaryGland.Virgin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Peripheral_Blood","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Ovary","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Bladder","Ovary","Ovary","Embryonic-Stem-Cell","Testis","Kidney","Trophoblast-Stem-Cell","Lung","Trophoblast-Stem-Cell","Fetal_Brain","Neonatal-Calvaria","Embryonic-Stem-Cell","Embryonic-Mesenchyme","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Lung","Fetal_Intestine","Embryonic-Stem-Cell","MammaryGland.Lactation","MammaryGland.Lactation","Embryonic-Mesenchyme","Peripheral_Blood","MammaryGland.Virgin","Fetal_Intestine","MammaryGland.Lactation","Bone-Marrow","Lung","Muscle","Trophoblast-Stem-Cell","Neonatal-Rib","Neonatal-Calvaria","Uterus","Testis","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Peripheral_Blood","Peripheral_Blood","MammaryGland.Lactation","Stomach","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Placenta","Thymus","Embryonic-Stem-Cell","Pancreas","MammaryGland.Lactation","Small-Intestine","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Lung","Small-Intestine","Testis","Peripheral_Blood","Testis","Small-Intestine","Liver","Bone-Marrow_c-kit","Neonatal-Rib","Bone_Marrow_Mesenchyme","Bone-Marrow","Bone-Marrow","Bone-Marrow","Neonatal-Skin","Peripheral_Blood","Trophoblast-Stem-Cell","Neonatal-Muscle","Neonatal-Heart","Peripheral_Blood","Fetal_Brain","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Trophoblast-Stem-Cell","Brain","Bone-Marrow_c-kit","Stomach","Fetal_Brain","Lung","Bladder","Bone-Marrow_c-kit","Testis","Bone-Marrow_c-kit","Fetal_Brain","Bone-Marrow_c-kit","Peripheral_Blood","Fetal_Stomache","Liver","Fetal_Intestine","Liver","Trophoblast-Stem-Cell","Placenta","Brain","Bone_Marrow_Mesenchyme","MammaryGland.Involution","Liver","MammaryGland.Lactation","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Testis","Neonatal-Muscle","Peripheral_Blood","Pancreas","Trophoblast-Stem-Cell","Neonatal-Heart","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Involution","Thymus","Fetal_Stomache","Neonatal-Skin","MammaryGland.Virgin","Bone-Marrow","Bladder","Trophoblast-Stem-Cell","Lung","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Liver","Trophoblast-Stem-Cell","MammaryGland.Lactation","Testis","Trophoblast-Stem-Cell","Testis","Testis","Neonatal-Calvaria","Neonatal-Rib","Fetal_Intestine","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Rib","Bone-Marrow","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Calvaria","MammaryGland.Lactation","Small-Intestine","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Thymus","Bone-Marrow_c-kit","Peripheral_Blood","Testis","Bone-Marrow_c-kit","MammaryGland.Virgin","Embryonic-Stem-Cell","Fetal_Lung","Neonatal-Heart","Testis","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Peripheral_Blood","Uterus","Fetal_Intestine","Testis","Fetal_Intestine","Neonatal-Rib","Ovary","Peripheral_Blood","Embryonic-Stem-Cell","Stomach","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Pancreas","Brain","Peripheral_Blood","Neonatal-Calvaria","MammaryGland.Lactation","Fetal_Intestine","MammaryGland.Virgin","Placenta","Fetal_Lung","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow","MammaryGland.Virgin","Fetal_Stomache","Bone-Marrow_c-kit","Lung","Fetal_Lung","Trophoblast-Stem-Cell","Neonatal-Calvaria","Fetal_Stomache","Embryonic-Stem-Cell","Fetal_Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Brain","Fetal_Intestine","Neonatal-Heart","Neonatal-Skin","Fetal_Stomache","Liver","Trophoblast-Stem-Cell","MammaryGland.Involution","Ovary","Brain","MammaryGland.Involution","Trophoblast-Stem-Cell","Neonatal-Rib","Neonatal-Calvaria","Prostate","MammaryGland.Lactation","Peripheral_Blood","MammaryGland.Lactation","Neonatal-Calvaria","Trophoblast-Stem-Cell","Kidney","Lung","Neonatal-Rib","Neonatal-Muscle","Bone-Marrow_c-kit","Small-Intestine","Fetal_Brain","Fetal_Lung","Neonatal-Calvaria","Trophoblast-Stem-Cell","MammaryGland.Virgin","Liver","MammaryGland.Lactation","Small-Intestine","Stomach","Testis","Placenta","Fetal_Intestine","Neonatal-Calvaria","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Trophoblast-Stem-Cell","Neonatal-Heart","Placenta","Lung","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Bone-Marrow_c-kit","Placenta","Stomach","MammaryGland.Lactation","MammaryGland.Lactation","Fetal_Brain","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","Embryonic-Stem-Cell","Neonatal-Rib","Bone-Marrow_c-kit","Neonatal-Calvaria","Testis","Peripheral_Blood","Peripheral_Blood","Brain","Bone-Marrow","Peripheral_Blood","Peripheral_Blood","Embryonic-Stem-Cell","Brain","MammaryGland.Lactation","Small-Intestine","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Lung","Testis","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Brain","Testis","Ovary","MammaryGland.Pregnancy","Lung","Bone-Marrow_c-kit","Fetal_Intestine","Fetal_Brain","Embryonic-Stem-Cell","Fetal_Lung","Embryonic-Stem-Cell","Pancreas","Fetal_Intestine","Neonatal-Rib","Bone-Marrow_c-kit","MammaryGland.Lactation","Testis","Neonatal-Skin","Testis","Bone-Marrow","Fetal_Lung","Bone-Marrow_c-kit","Bone-Marrow","Bone-Marrow","MammaryGland.Lactation","Testis","Trophoblast-Stem-Cell","Neonatal-Calvaria","MammaryGland.Involution","Ovary","Neonatal-Muscle","Embryonic-Stem-Cell","Neonatal-Calvaria","Ovary","Bone-Marrow","Bladder","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Fetal_Brain","Bone-Marrow_c-kit","Small-Intestine","Neonatal-Heart","Neonatal-Rib","Fetal_Intestine","MammaryGland.Pregnancy","Peripheral_Blood","Peripheral_Blood","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Testis","Thymus","MammaryGland.Pregnancy","Small-Intestine","Bone-Marrow_c-kit","Testis","Bone-Marrow_c-kit","Ovary","Small-Intestine","Neonatal-Skin","Testis","Bone-Marrow_c-kit","Small-Intestine","Peripheral_Blood","Fetal-Liver","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Testis","Testis","Peripheral_Blood","Small-Intestine","Fetal_Lung","Peripheral_Blood","Peripheral_Blood","Bladder","Liver","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Kidney","Bone-Marrow_c-kit","Fetal_Brain","Uterus","Trophoblast-Stem-Cell","Bone-Marrow","Pancreas","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Kidney","Mesenchymal-Stem-Cell-Cultured","Pancreas","Neonatal-Heart","MammaryGland.Involution","Neonatal-Calvaria","Bone-Marrow","Bone_Marrow_Mesenchyme","Bone-Marrow","MammaryGland.Lactation","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Fetal_Brain","Neonatal-Muscle","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow","Embryonic-Stem-Cell","Small-Intestine","Trophoblast-Stem-Cell","Neonatal-Rib","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","MammaryGland.Virgin","Bone-Marrow_c-kit","Small-Intestine","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Bladder","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","Bone-Marrow_c-kit","Liver","Embryonic-Stem-Cell","Liver","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Kidney","Fetal_Intestine","Liver","Peripheral_Blood","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Lung","Peripheral_Blood","Neonatal-Calvaria","Small-Intestine","MammaryGland.Involution","Neonatal-Calvaria","MammaryGland.Pregnancy","Neonatal-Muscle","Bone-Marrow_c-kit","Liver","MammaryGland.Lactation","Prostate","Placenta","Bone-Marrow_c-kit","Fetal_Intestine","Placenta","Bone-Marrow","MammaryGland.Involution","Embryonic-Stem-Cell","Fetal_Stomache","Lung","Fetal_Lung","MammaryGland.Lactation","MammaryGland.Lactation","Bone-Marrow_c-kit","Kidney","Bone-Marrow","Lung","Kidney","Uterus","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Testis","Testis","Peripheral_Blood","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Fetal_Stomache","Embryonic-Stem-Cell","Liver","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Calvaria","Lung","Brain","MammaryGland.Pregnancy","Neonatal-Calvaria","Bone-Marrow","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Placenta","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Calvaria","Small-Intestine","Bone-Marrow","Neonatal-Skin","Trophoblast-Stem-Cell","Pancreas","Neonatal-Calvaria","MammaryGland.Lactation","Small-Intestine","Bone_Marrow_Mesenchyme","MammaryGland.Involution","Liver","Embryonic-Stem-Cell","Testis","Bone-Marrow_c-kit","Fetal_Brain","MammaryGland.Involution","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Heart","Neonatal-Heart","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Placenta","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Ovary","Fetal_Intestine","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Thymus","Neonatal-Rib","MammaryGland.Pregnancy","MammaryGland.Lactation","Neonatal-Calvaria","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Ovary","MammaryGland.Virgin","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Placenta","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Testis","Uterus","Bone-Marrow_c-kit","Pancreas","Bone-Marrow","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","MammaryGland.Virgin","Trophoblast-Stem-Cell","Neonatal-Heart","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Lung","Bone-Marrow_c-kit","Uterus","Ovary","Liver","Stomach","Bladder","Trophoblast-Stem-Cell","Ovary","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Uterus","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","Embryonic-Mesenchyme","Testis","Bone-Marrow_c-kit","Liver","Embryonic-Stem-Cell","Kidney","Trophoblast-Stem-Cell","Lung","Neonatal-Calvaria","Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Involution","Lung","Brain","Bone-Marrow","Trophoblast-Stem-Cell","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Fetal_Lung","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow_c-kit","Uterus","Peripheral_Blood","Neonatal-Calvaria","Lung","Fetal_Intestine","Bone_Marrow_Mesenchyme","MammaryGland.Involution","MammaryGland.Virgin","MammaryGland.Involution","Ovary","Kidney","Trophoblast-Stem-Cell","Lung","Kidney","Neonatal-Heart","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Heart","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Stomach","MammaryGland.Lactation","Neonatal-Rib","Testis","Neonatal-Skin","Bone-Marrow_c-kit","Neonatal-Muscle","Neonatal-Skin","Brain","Fetal_Stomache","Placenta","Fetal-Liver","Bone-Marrow_c-kit","MammaryGland.Lactation","MammaryGland.Pregnancy","Neonatal-Calvaria","Uterus","Lung","Small-Intestine","Neonatal-Heart","Trophoblast-Stem-Cell","Neonatal-Muscle","Ovary","Liver","Neonatal-Calvaria","Neonatal-Calvaria","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Neonatal-Rib","Peripheral_Blood","Neonatal-Skin","Stomach","Pancreas","Embryonic-Mesenchyme","Kidney","Neonatal-Heart","Fetal_Stomache","Trophoblast-Stem-Cell","Neonatal-Muscle","MammaryGland.Lactation","Neonatal-Skin","Bone-Marrow_c-kit","MammaryGland.Involution","Fetal-Liver","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","Testis","Neonatal-Muscle","Embryonic-Mesenchyme","Prostate","Neonatal-Calvaria","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Peripheral_Blood","Bone-Marrow_c-kit","Lung","Bone-Marrow_c-kit","Placenta","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Liver","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Brain","Testis","Placenta","Fetal_Intestine","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Lactation","MammaryGland.Involution","Small-Intestine","Liver","Fetal_Intestine","Prostate","MammaryGland.Pregnancy","Brain","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal_Intestine","Trophoblast-Stem-Cell","Pancreas","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Pancreas","Pancreas","Small-Intestine","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Small-Intestine","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Placenta","Testis","MammaryGland.Virgin","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Pancreas","Fetal_Intestine","Neonatal-Heart","Fetal_Intestine","Neonatal-Calvaria","Neonatal-Calvaria","Liver","Fetal_Stomache","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow","Trophoblast-Stem-Cell","Brain","Ovary","Liver","Trophoblast-Stem-Cell","Fetal-Liver","Bone-Marrow_c-kit","Small-Intestine","MammaryGland.Virgin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","MammaryGland.Involution","MammaryGland.Lactation","Fetal-Liver","Fetal_Brain","Trophoblast-Stem-Cell","Thymus","MammaryGland.Lactation","Neonatal-Heart","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Fetal_Brain","Bone-Marrow_c-kit","Fetal_Lung","Lung","Testis","Pancreas","Trophoblast-Stem-Cell","MammaryGland.Virgin","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Kidney","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Muscle","Bone-Marrow","Liver","MammaryGland.Lactation","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","MammaryGland.Lactation","Fetal-Liver","Fetal_Intestine","Neonatal-Skin","Small-Intestine","Thymus","Neonatal-Heart","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Thymus","Small-Intestine","MammaryGland.Pregnancy","Liver","Neonatal-Calvaria","Placenta","MammaryGland.Lactation","Embryonic-Stem-Cell","Bone-Marrow","Bladder","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Thymus","Neonatal-Calvaria","Stomach","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Placenta","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow_c-kit","Testis","Pancreas","Pancreas","Bone-Marrow_c-kit","Neonatal-Rib","Fetal_Intestine","Bone-Marrow","Fetal_Brain","Fetal-Liver","Neonatal-Calvaria","Small-Intestine","Liver","MammaryGland.Virgin","Fetal_Brain","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Virgin","Bone-Marrow","Neonatal-Calvaria","Testis","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Small-Intestine","Neonatal-Heart","Bone_Marrow_Mesenchyme","Fetal_Stomache","Lung","Bone-Marrow","MammaryGland.Lactation","Embryonic-Stem-Cell","Neonatal-Muscle","Small-Intestine","MammaryGland.Virgin","Trophoblast-Stem-Cell","Placenta","Neonatal-Calvaria","Fetal_Stomache","Brain","Ovary","Fetal_Lung","Neonatal-Heart","Fetal_Stomache","Bone-Marrow","Stomach","Mesenchymal-Stem-Cell-Cultured","Thymus","Bone_Marrow_Mesenchyme","Bone-Marrow","Testis","Bone-Marrow","Fetal-Liver","Fetal_Intestine","Neonatal-Calvaria","Embryonic-Stem-Cell","Neonatal-Muscle","Thymus","Fetal_Lung","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","Neonatal-Heart","Bone-Marrow","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Brain","Placenta","Placenta","Neonatal-Heart","Liver","MammaryGland.Lactation","Trophoblast-Stem-Cell","Fetal-Liver","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone-Marrow","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Neonatal-Calvaria","Placenta","Small-Intestine","Bone-Marrow_c-kit","MammaryGland.Involution","Embryonic-Stem-Cell","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Kidney","Brain","Embryonic-Mesenchyme","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Fetal-Liver","Pancreas","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Stomach","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Neonatal-Skin","Bone-Marrow","Trophoblast-Stem-Cell","MammaryGland.Lactation","Small-Intestine","Kidney","Trophoblast-Stem-Cell","MammaryGland.Virgin","Bone-Marrow_c-kit","Thymus","Testis","Kidney","Bone-Marrow","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Peripheral_Blood","MammaryGland.Involution","Bone-Marrow","Bone-Marrow","MammaryGland.Lactation","Fetal_Stomache","Uterus","Bone-Marrow","Small-Intestine","Ovary","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Neonatal-Heart","Bone-Marrow","MammaryGland.Pregnancy","Placenta","MammaryGland.Virgin","Bone-Marrow_c-kit","Neonatal-Heart","MammaryGland.Lactation","Bone-Marrow","Trophoblast-Stem-Cell","Fetal_Lung","Bone-Marrow_c-kit","Fetal_Brain","Bone-Marrow_c-kit","Neonatal-Heart","Bone-Marrow_c-kit","Lung","Neonatal-Calvaria","Trophoblast-Stem-Cell","Bladder","Testis","Trophoblast-Stem-Cell","Fetal_Brain","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Small-Intestine","Bone-Marrow_c-kit","Peripheral_Blood","Testis","Neonatal-Calvaria","MammaryGland.Lactation","Testis","Bone-Marrow_c-kit","MammaryGland.Lactation","Small-Intestine","Neonatal-Calvaria","Peripheral_Blood","MammaryGland.Lactation","Liver","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Testis","Small-Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Involution","Pancreas","Pancreas","Small-Intestine","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Liver","Thymus","Testis","Neonatal-Calvaria","Uterus","MammaryGland.Lactation","Lung","MammaryGland.Lactation","Pancreas","Bone-Marrow_c-kit","Neonatal-Calvaria","Spleen","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Neonatal-Muscle","Mesenchymal-Stem-Cell-Cultured","Lung","Neonatal-Calvaria","Fetal_Intestine","Embryonic-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Prostate","Embryonic-Stem-Cell","Stomach","MammaryGland.Lactation","Neonatal-Muscle","Bone-Marrow_c-kit","Bone-Marrow","Placenta","Thymus","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Lung","Testis","Neonatal-Skin","Ovary","Testis","Neonatal-Heart","Bone-Marrow_c-kit","Lung","Embryonic-Stem-Cell","Bone-Marrow","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Embryonic-Mesenchyme","MammaryGland.Lactation","Uterus","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Small-Intestine","Fetal_Lung","Neonatal-Heart","Bone-Marrow_c-kit","Neonatal-Heart","Muscle","Trophoblast-Stem-Cell","Liver","Embryonic-Stem-Cell","MammaryGland.Lactation","Liver","Fetal_Lung","Bone_Marrow_Mesenchyme","Small-Intestine","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Spleen","Neonatal-Skin","Embryonic-Stem-Cell","Uterus","Embryonic-Stem-Cell","Neonatal-Skin","Fetal_Lung","Liver","Neonatal-Rib","MammaryGland.Lactation","Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Small-Intestine","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Small-Intestine","Trophoblast-Stem-Cell","Fetal_Stomache","MammaryGland.Lactation","Kidney","Small-Intestine","Uterus","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Bone-Marrow","Bone_Marrow_Mesenchyme","Testis","Uterus","Pancreas","Small-Intestine","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Muscle","Testis","Testis","Bone-Marrow_c-kit","Neonatal-Rib","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Involution","Liver","Testis","Neonatal-Muscle","Trophoblast-Stem-Cell","Testis","Lung","Ovary","Fetal_Intestine","MammaryGland.Virgin","Embryonic-Stem-Cell","Testis","Bone-Marrow","Testis","Peripheral_Blood","Placenta","Liver","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Involution","Testis","Testis","Neonatal-Calvaria","Testis","Embryonic-Mesenchyme","Neonatal-Muscle","Trophoblast-Stem-Cell","Neonatal-Calvaria","MammaryGland.Lactation","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Neonatal-Heart","Bone-Marrow_c-kit","Kidney","Trophoblast-Stem-Cell","Small-Intestine","Liver","MammaryGland.Lactation","Liver","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Lactation","Thymus","MammaryGland.Lactation","MammaryGland.Involution","Thymus","Embryonic-Stem-Cell","MammaryGland.Lactation","Trophoblast-Stem-Cell","Testis","Embryonic-Mesenchyme","Neonatal-Calvaria","Neonatal-Heart","Bladder","Bone-Marrow_c-kit","Ovary","MammaryGland.Lactation","Neonatal-Calvaria","Testis","Peripheral_Blood","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Thymus","Bone-Marrow_c-kit","Ovary","Fetal_Brain","Neonatal-Calvaria","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bone-Marrow_c-kit","Stomach","Fetal_Intestine","Embryonic-Stem-Cell","Neonatal-Calvaria","Neonatal-Muscle","Trophoblast-Stem-Cell","Peripheral_Blood","Bone-Marrow_c-kit","Neonatal-Muscle","Testis","Placenta","Neonatal-Calvaria","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Lung","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow","Lung","Bone-Marrow_c-kit","MammaryGland.Involution","Bone-Marrow","Neonatal-Rib","Neonatal-Muscle","Trophoblast-Stem-Cell","Peripheral_Blood","Pancreas","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Stomache","MammaryGland.Lactation","Fetal_Brain","Bone_Marrow_Mesenchyme","Testis","Neonatal-Rib","Liver","Neonatal-Rib","Embryonic-Mesenchyme","Neonatal-Calvaria","Pancreas","Neonatal-Skin","Small-Intestine","MammaryGland.Pregnancy","Lung","Uterus","Bone-Marrow_c-kit","Fetal_Lung","Fetal_Intestine","Peripheral_Blood","Ovary","Fetal_Stomache","Bone-Marrow_c-kit","Fetal_Intestine","Neonatal-Muscle","MammaryGland.Lactation","Pancreas","Thymus","Bone-Marrow","Liver","Bone-Marrow","Testis","Ovary","Pancreas","Peripheral_Blood","Bone_Marrow_Mesenchyme","Fetal-Liver","MammaryGland.Lactation","Liver","Brain","MammaryGland.Pregnancy","Neonatal-Muscle","Fetal_Stomache","Neonatal-Muscle","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Rib","Neonatal-Rib","Prostate","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bladder","Bladder","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Small-Intestine","Small-Intestine","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Neonatal-Muscle","MammaryGland.Involution","Kidney","Testis","Neonatal-Calvaria","Neonatal-Calvaria","Bone-Marrow_c-kit","Fetal_Intestine","Small-Intestine","Fetal_Brain","MammaryGland.Pregnancy","Testis","Neonatal-Calvaria","Lung","Fetal_Stomache","Neonatal-Rib","Neonatal-Calvaria","Uterus","Bone_Marrow_Mesenchyme","Fetal_Lung","Neonatal-Muscle","Testis","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Testis","Embryonic-Mesenchyme","Lung","Testis","Fetal_Lung","Testis","Fetal-Liver","Small-Intestine","Bone-Marrow_c-kit","Placenta","Bone-Marrow_c-kit","Neonatal-Skin","MammaryGland.Involution","Bladder","Liver","Embryonic-Stem-Cell","Fetal_Intestine","Fetal_Lung","MammaryGland.Involution","Fetal_Brain","Pancreas","Ovary","Bone-Marrow_c-kit","Testis","Neonatal-Muscle","MammaryGland.Involution","Lung","Prostate","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","Neonatal-Heart","Bone-Marrow_c-kit","Testis","Lung","Kidney","Fetal_Intestine","Small-Intestine","Uterus","Stomach","MammaryGland.Virgin","Embryonic-Stem-Cell","Testis","Neonatal-Rib","Trophoblast-Stem-Cell","Neonatal-Calvaria","Lung","MammaryGland.Involution","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bladder","Peripheral_Blood","Lung","Stomach","Bone-Marrow","Fetal_Intestine","Bone-Marrow","Trophoblast-Stem-Cell","Fetal_Lung","Ovary","Fetal_Lung","MammaryGland.Pregnancy","Fetal_Intestine","Bone_Marrow_Mesenchyme","Testis","Brain","Bone_Marrow_Mesenchyme","Placenta","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Peripheral_Blood","Fetal-Liver","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow","Testis","Stomach","Small-Intestine","Neonatal-Skin","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal-Liver","Trophoblast-Stem-Cell","Fetal_Stomache","Peripheral_Blood","Neonatal-Heart","Lung","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Small-Intestine","MammaryGland.Lactation","Brain","MammaryGland.Lactation","Testis","Neonatal-Rib","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Ovary","Fetal_Stomache","Fetal-Liver","Lung","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","MammaryGland.Virgin","MammaryGland.Lactation","Lung","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Liver","Placenta","Fetal_Intestine","Neonatal-Heart","Pancreas","Neonatal-Rib","Kidney","Fetal_Lung","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Bone_Marrow_Mesenchyme","Thymus","Bladder","Neonatal-Calvaria","Embryonic-Stem-Cell","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Brain","Testis","Testis","Peripheral_Blood","Kidney","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Lactation","Fetal_Intestine","Neonatal-Skin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone-Marrow","Peripheral_Blood","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bladder","Trophoblast-Stem-Cell","Neonatal-Rib","Trophoblast-Stem-Cell","Lung","Testis","MammaryGland.Lactation","Trophoblast-Stem-Cell","Neonatal-Muscle","Small-Intestine","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Placenta","Bone-Marrow_c-kit","Embryonic-Stem-Cell","MammaryGland.Involution","Embryonic-Mesenchyme","Bone-Marrow","Ovary","Peripheral_Blood","MammaryGland.Lactation","Neonatal-Muscle","Peripheral_Blood","Fetal_Stomache","Uterus","Fetal_Intestine","Bone-Marrow_c-kit","Neonatal-Calvaria","Testis","Fetal_Intestine","Thymus","Neonatal-Heart","Lung","Trophoblast-Stem-Cell","Kidney","Neonatal-Rib","Placenta","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Neonatal-Calvaria","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Virgin","Lung","MammaryGland.Virgin","Neonatal-Muscle","Bone-Marrow","Neonatal-Rib","MammaryGland.Involution","Trophoblast-Stem-Cell","Lung","Fetal_Stomache","Fetal_Lung","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Prostate","Embryonic-Mesenchyme","Neonatal-Calvaria","Neonatal-Calvaria","MammaryGland.Involution","MammaryGland.Pregnancy","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Fetal_Stomache","Fetal_Intestine","Lung","Brain","Bone-Marrow_c-kit","Prostate","Lung","Testis","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Prostate","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Liver","Bone-Marrow_c-kit","Bone-Marrow","Pancreas","Trophoblast-Stem-Cell","MammaryGland.Virgin","Fetal_Brain","Fetal-Liver","Neonatal-Skin","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Bone-Marrow","Peripheral_Blood","Spleen","Bone-Marrow","Embryonic-Stem-Cell","Kidney","Fetal_Stomache","Neonatal-Skin","Bone_Marrow_Mesenchyme","Placenta","Prostate","MammaryGland.Lactation","MammaryGland.Virgin","Uterus","MammaryGland.Lactation","Bone-Marrow","Lung","Small-Intestine","Lung","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Ovary","Fetal_Stomache","Testis","Small-Intestine","Ovary","Small-Intestine","MammaryGland.Lactation","MammaryGland.Lactation","Peripheral_Blood","MammaryGland.Virgin","Small-Intestine","Neonatal-Calvaria","Prostate","Fetal_Intestine","Fetal_Lung","Embryonic-Stem-Cell","Bone-Marrow","MammaryGland.Involution","MammaryGland.Involution","Bone-Marrow","Bone-Marrow_c-kit","Neonatal-Muscle","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Placenta","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Ovary","Mesenchymal-Stem-Cell-Cultured","Lung","Fetal_Stomache","Bone-Marrow_c-kit","Neonatal-Skin","MammaryGland.Pregnancy","Prostate","Placenta","Bone-Marrow_c-kit","Kidney","MammaryGland.Lactation","Thymus","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Fetal-Liver","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Fetal_Stomache","Pancreas","Bone-Marrow_c-kit","Fetal_Lung","Prostate","Testis","Fetal_Brain","Bone-Marrow","Fetal_Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Muscle","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Placenta","Testis","Trophoblast-Stem-Cell","Ovary","Fetal_Stomache","MammaryGland.Pregnancy","MammaryGland.Involution","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Muscle","Lung","Lung","Thymus","Small-Intestine","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Testis","Bone_Marrow_Mesenchyme","Stomach","Testis","Mesenchymal-Stem-Cell-Cultured","Testis","MammaryGland.Virgin","Neonatal-Muscle","Neonatal-Skin","MammaryGland.Pregnancy","Lung","Pancreas","Testis","MammaryGland.Pregnancy","MammaryGland.Involution","Bladder","Thymus","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Brain","Fetal_Lung","Uterus","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Brain","Lung","Neonatal-Rib","Neonatal-Rib","Embryonic-Mesenchyme","Testis","Pancreas","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Brain","Bone-Marrow_c-kit","Peripheral_Blood","MammaryGland.Lactation","Bone-Marrow_c-kit","Neonatal-Calvaria","Testis","Embryonic-Mesenchyme","Testis","MammaryGland.Lactation","Brain","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Muscle","Fetal_Stomache","MammaryGland.Lactation","Bone-Marrow","Neonatal-Calvaria","Uterus","Stomach","Pancreas","Kidney","Testis","Testis","Thymus","Neonatal-Calvaria","Neonatal-Heart","Bone-Marrow_c-kit","Testis","Fetal_Stomache","Placenta","Fetal_Stomache","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Neonatal-Heart","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Neonatal-Muscle","Bone-Marrow","Neonatal-Heart","Testis","Fetal_Intestine","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Uterus","Embryonic-Stem-Cell","Bone-Marrow","Trophoblast-Stem-Cell","Neonatal-Calvaria","Spleen","Fetal_Lung","Neonatal-Calvaria","Kidney","Mesenchymal-Stem-Cell-Cultured","Fetal-Liver","Small-Intestine","Fetal-Liver","Neonatal-Rib","Lung","Bone-Marrow_c-kit","Fetal_Intestine","Trophoblast-Stem-Cell","Thymus","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Intestine","Embryonic-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Virgin","Neonatal-Calvaria","Testis","Neonatal-Skin","Neonatal-Calvaria","Embryonic-Stem-Cell","Brain","Embryonic-Stem-Cell","MammaryGland.Lactation","MammaryGland.Involution","Placenta","MammaryGland.Lactation","Fetal_Stomache","Thymus","Lung","Neonatal-Muscle","Fetal_Stomache","Trophoblast-Stem-Cell","Placenta","MammaryGland.Lactation","Fetal_Lung","Muscle","Neonatal-Rib","Embryonic-Stem-Cell","Bone-Marrow","MammaryGland.Involution","Small-Intestine","MammaryGland.Virgin","Fetal_Stomache","Lung","Small-Intestine","Trophoblast-Stem-Cell","MammaryGland.Lactation","Trophoblast-Stem-Cell","Fetal-Liver","Small-Intestine","Lung","MammaryGland.Lactation","Bone-Marrow_c-kit","Liver","MammaryGland.Lactation","Kidney","Neonatal-Skin","Placenta","Stomach","Neonatal-Muscle","MammaryGland.Lactation","Testis","Prostate","Testis","Bone-Marrow_c-kit","Bladder","Ovary","Bone-Marrow_c-kit","Neonatal-Heart","MammaryGland.Lactation","MammaryGland.Lactation","Lung","Bladder","Embryonic-Mesenchyme","Placenta","Bone-Marrow_c-kit","MammaryGland.Involution","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Testis","Lung","Trophoblast-Stem-Cell","Thymus","Neonatal-Muscle","Liver","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Small-Intestine","Embryonic-Stem-Cell","Neonatal-Muscle","Peripheral_Blood","Fetal_Lung","MammaryGland.Virgin","Pancreas","Trophoblast-Stem-Cell","Fetal_Lung","MammaryGland.Lactation","Fetal-Liver","Fetal_Intestine","Small-Intestine","Placenta","Testis","Pancreas","Fetal_Intestine","Trophoblast-Stem-Cell","Brain","Kidney","MammaryGland.Virgin","Testis","Thymus","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Testis","Testis","Muscle","Bladder","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow","Testis","Embryonic-Mesenchyme","Testis","Embryonic-Stem-Cell","Brain","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Stomach","Neonatal-Calvaria","Bone-Marrow_c-kit","MammaryGland.Lactation","Ovary","Lung","Embryonic-Mesenchyme","Bladder","Fetal_Stomache","Ovary","Bone-Marrow_c-kit","Kidney","Trophoblast-Stem-Cell","MammaryGland.Lactation","Fetal-Liver","Fetal_Brain","Bone-Marrow_c-kit","Neonatal-Calvaria","Testis","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Fetal_Brain","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Lung","Small-Intestine","MammaryGland.Pregnancy","Fetal_Lung","Bone-Marrow","Ovary","Bone-Marrow_c-kit","Fetal_Lung","Bone-Marrow_c-kit","Thymus","Placenta","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Small-Intestine","Fetal_Brain","Neonatal-Skin","Neonatal-Calvaria","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Pancreas","Peripheral_Blood","Small-Intestine","Bone-Marrow_c-kit","MammaryGland.Virgin","Trophoblast-Stem-Cell","Fetal_Brain","Fetal_Lung","Kidney","Brain","Muscle","Bladder","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Small-Intestine","Pancreas","Brain","Thymus","Bone-Marrow_c-kit","Fetal_Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Lactation","Neonatal-Heart","Peripheral_Blood","Embryonic-Stem-Cell","MammaryGland.Lactation","Embryonic-Stem-Cell","MammaryGland.Lactation","Neonatal-Rib","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Pancreas","Neonatal-Calvaria","Neonatal-Rib","Kidney","Pancreas","MammaryGland.Virgin","Small-Intestine","Neonatal-Calvaria","Lung","Lung","Prostate","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow_c-kit","Fetal_Intestine","Spleen","Neonatal-Calvaria","Bone-Marrow","Testis","MammaryGland.Involution","MammaryGland.Pregnancy","Small-Intestine","Brain","Testis","Prostate","Embryonic-Mesenchyme","Muscle","Placenta","Bone-Marrow_c-kit","Fetal_Stomache","Fetal-Liver","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Fetal_Lung","Testis","Testis","Fetal_Stomache","Spleen","Fetal_Lung","Neonatal-Rib","Embryonic-Mesenchyme","Neonatal-Muscle","Embryonic-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Fetal_Stomache","Trophoblast-Stem-Cell","Thymus","Kidney","Fetal_Lung","Testis","Mesenchymal-Stem-Cell-Cultured","Kidney","Trophoblast-Stem-Cell","Testis","Fetal-Liver","Bone-Marrow","Bone-Marrow","Fetal-Liver","Testis","MammaryGland.Pregnancy","MammaryGland.Pregnancy","Fetal_Stomache","Testis","Placenta","Neonatal-Rib","Bone-Marrow","Neonatal-Muscle","MammaryGland.Lactation","MammaryGland.Virgin","Trophoblast-Stem-Cell","Prostate","MammaryGland.Involution","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow","Fetal_Stomache","Embryonic-Mesenchyme","Neonatal-Heart","Testis","MammaryGland.Virgin","Fetal-Liver","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Liver","Trophoblast-Stem-Cell","Uterus","MammaryGland.Involution","Bone-Marrow_c-kit","Neonatal-Skin","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Thymus","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Lung","MammaryGland.Lactation","Small-Intestine","MammaryGland.Involution","Thymus","Prostate","Lung","Ovary","Fetal_Lung","Peripheral_Blood","Placenta","Bone_Marrow_Mesenchyme","Bone-Marrow","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Virgin","Neonatal-Heart","Lung","Small-Intestine","Placenta","Bone-Marrow_c-kit","Muscle","Testis","Peripheral_Blood","Spleen","Trophoblast-Stem-Cell","Fetal_Lung","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Neonatal-Heart","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Uterus","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Uterus","Embryonic-Mesenchyme","Neonatal-Calvaria","Neonatal-Rib","Fetal_Brain","Fetal_Brain","Bone-Marrow_c-kit","Neonatal-Calvaria","MammaryGland.Involution","Bone-Marrow_c-kit","Peripheral_Blood","Placenta","Trophoblast-Stem-Cell","Pancreas","MammaryGland.Pregnancy","Neonatal-Muscle","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Embryonic-Mesenchyme","MammaryGland.Involution","Kidney","Ovary","Lung","Fetal_Lung","Bone-Marrow_c-kit","MammaryGland.Virgin","Testis","MammaryGland.Involution","Small-Intestine","Prostate","Embryonic-Stem-Cell","Neonatal-Muscle","Bone-Marrow_c-kit","Ovary","Stomach","Fetal_Lung","MammaryGland.Virgin","Bone-Marrow_c-kit","MammaryGland.Virgin","Bone-Marrow_c-kit","Neonatal-Rib","Small-Intestine","Embryonic-Stem-Cell","Neonatal-Rib","MammaryGland.Virgin","Prostate","Small-Intestine","Stomach","Brain","Bone-Marrow_c-kit","Fetal_Intestine","Bone-Marrow_c-kit","MammaryGland.Virgin","Fetal_Lung","Embryonic-Stem-Cell","Testis","Fetal_Stomache","Kidney","Spleen","Mesenchymal-Stem-Cell-Cultured","Liver","MammaryGland.Virgin","MammaryGland.Lactation","Neonatal-Calvaria","Ovary","Liver","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Kidney","Embryonic-Stem-Cell","Fetal_Intestine","Trophoblast-Stem-Cell","Ovary","Pancreas","Neonatal-Calvaria","Testis","MammaryGland.Lactation","Small-Intestine","Neonatal-Heart","Embryonic-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Uterus","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Rib","Embryonic-Mesenchyme","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Peripheral_Blood","Fetal_Intestine","Embryonic-Stem-Cell","Testis","MammaryGland.Pregnancy","MammaryGland.Lactation","Embryonic-Stem-Cell","Testis","Fetal_Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Calvaria","Uterus","Ovary","Testis","Brain","Bone-Marrow_c-kit","Fetal_Brain","Small-Intestine","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Spleen","Neonatal-Heart","Fetal_Intestine","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Kidney","Embryonic-Stem-Cell","Stomach","Fetal_Lung","Fetal_Intestine","Peripheral_Blood","Neonatal-Calvaria","Spleen","MammaryGland.Pregnancy","Thymus","Pancreas","Bone-Marrow_c-kit","Neonatal-Rib","Fetal_Lung","Testis","Testis","Bone-Marrow_c-kit","Embryonic-Mesenchyme","MammaryGland.Lactation","Neonatal-Rib","Embryonic-Mesenchyme","Fetal_Stomache","Testis","Fetal_Lung","Bone-Marrow","MammaryGland.Pregnancy","Testis","MammaryGland.Virgin","MammaryGland.Lactation","Neonatal-Heart","Bladder","Testis","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Fetal_Intestine","Uterus","Lung","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Fetal_Intestine","Uterus","Small-Intestine","Trophoblast-Stem-Cell","Neonatal-Calvaria","Neonatal-Rib","Prostate","Prostate","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Pancreas","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow_c-kit","Spleen","Small-Intestine","Small-Intestine","Neonatal-Rib","Bone-Marrow_c-kit","Fetal_Lung","Embryonic-Mesenchyme","Kidney","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Spleen","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bone-Marrow","MammaryGland.Virgin","Lung","Peripheral_Blood","MammaryGland.Lactation","Trophoblast-Stem-Cell","Fetal_Intestine","Neonatal-Skin","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Lung","Liver","Trophoblast-Stem-Cell","MammaryGland.Lactation","MammaryGland.Lactation","Thymus","Neonatal-Rib","Fetal_Intestine","Ovary","Fetal-Liver","Fetal_Lung","Fetal-Liver","Fetal-Liver","Brain","Bone-Marrow_c-kit","Pancreas","Neonatal-Skin","Fetal-Liver","Testis","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Testis","Fetal_Stomache","MammaryGland.Involution","Fetal_Lung","Fetal_Lung","Stomach","Spleen","Neonatal-Rib","Embryonic-Stem-Cell","Bone-Marrow","Bone_Marrow_Mesenchyme","Peripheral_Blood","Ovary","Testis","Trophoblast-Stem-Cell","Spleen","Neonatal-Muscle","Pancreas","Fetal_Brain","Bone-Marrow_c-kit","Liver","Trophoblast-Stem-Cell","Bone-Marrow","Muscle","MammaryGland.Lactation","Bone-Marrow","Fetal_Lung","Testis","Small-Intestine","Embryonic-Mesenchyme","Testis","Bone-Marrow_c-kit","Placenta","Neonatal-Muscle","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Placenta","Trophoblast-Stem-Cell","Neonatal-Calvaria","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Stomache","Liver","Lung","Neonatal-Muscle","MammaryGland.Lactation","Embryonic-Stem-Cell","Fetal_Stomache","Lung","Neonatal-Calvaria","Fetal_Brain","Placenta","Mesenchymal-Stem-Cell-Cultured","Ovary","Liver","Peripheral_Blood","Bone-Marrow_c-kit","Ovary","MammaryGland.Virgin","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Bone-Marrow","Lung","Trophoblast-Stem-Cell","Placenta","Bone-Marrow","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Fetal_Brain","Trophoblast-Stem-Cell","Neonatal-Muscle","Neonatal-Skin","Small-Intestine","Embryonic-Mesenchyme","Neonatal-Calvaria","Lung","Kidney","Trophoblast-Stem-Cell","Fetal_Lung","Bone-Marrow","Neonatal-Calvaria","Kidney","Prostate","Neonatal-Calvaria","Bone-Marrow_c-kit","Lung","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","MammaryGland.Involution","Peripheral_Blood","Peripheral_Blood","Thymus","Trophoblast-Stem-Cell","Neonatal-Heart","Embryonic-Mesenchyme","Neonatal-Skin","Uterus","Small-Intestine","MammaryGland.Involution","Liver","Trophoblast-Stem-Cell","Peripheral_Blood","Bone_Marrow_Mesenchyme","Bone-Marrow","Brain","Pancreas","Fetal_Stomache","Bone_Marrow_Mesenchyme","Lung","Testis","Bone-Marrow_c-kit","Small-Intestine","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Neonatal-Muscle","Small-Intestine","Peripheral_Blood","Liver","Brain","Peripheral_Blood","Spleen","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Lactation","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Uterus","Kidney","Bone-Marrow_c-kit","Fetal_Lung","Kidney","Bone_Marrow_Mesenchyme","Stomach","Bone-Marrow","MammaryGland.Lactation","Bone-Marrow_c-kit","Neonatal-Skin","Trophoblast-Stem-Cell","Neonatal-Rib","Testis","Neonatal-Heart","MammaryGland.Involution","Fetal_Brain","Neonatal-Skin","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Bone-Marrow","Bone-Marrow_c-kit","Placenta","Muscle","Ovary","Trophoblast-Stem-Cell","Fetal_Intestine","Embryonic-Stem-Cell","Small-Intestine","Neonatal-Rib","MammaryGland.Involution","Fetal_Intestine","Fetal_Lung","Bone-Marrow_c-kit","Brain","Embryonic-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Virgin","Thymus","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Spleen","Trophoblast-Stem-Cell","Small-Intestine","Uterus","Neonatal-Rib","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Stomache","Testis","Liver","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","MammaryGland.Involution","Embryonic-Mesenchyme","Fetal_Intestine","Thymus","Uterus","Trophoblast-Stem-Cell","MammaryGland.Lactation","Lung","Uterus","MammaryGland.Virgin","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Lung","Trophoblast-Stem-Cell","Testis","Bone_Marrow_Mesenchyme","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Ovary","Fetal-Liver","Neonatal-Calvaria","Bone-Marrow_c-kit","Pancreas","Brain","MammaryGland.Pregnancy","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Lactation","Prostate","Neonatal-Rib","Small-Intestine","Placenta","Prostate","Bone-Marrow_c-kit","Bone-Marrow","Trophoblast-Stem-Cell","Small-Intestine","Bone_Marrow_Mesenchyme","Kidney","MammaryGland.Involution","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Stomach","Neonatal-Heart","Fetal_Lung","Uterus","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow","Bone-Marrow","Testis","Fetal_Intestine","Testis","Embryonic-Mesenchyme","Bone-Marrow","Fetal_Intestine","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Fetal_Lung","Pancreas","Trophoblast-Stem-Cell","Neonatal-Rib","MammaryGland.Lactation","Neonatal-Calvaria","Placenta","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Embryonic-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Virgin","Embryonic-Stem-Cell","Fetal_Lung","Bone-Marrow_c-kit","Small-Intestine","Spleen","Lung","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Fetal_Lung","Bone-Marrow_c-kit","MammaryGland.Lactation","Lung","Bone-Marrow_c-kit","Stomach","Fetal_Lung","Embryonic-Stem-Cell","Fetal_Intestine","Pancreas","Small-Intestine","Spleen","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Muscle","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Lung","Brain","Neonatal-Muscle","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Rib","Trophoblast-Stem-Cell","MammaryGland.Virgin","Fetal_Lung","Pancreas","Neonatal-Muscle","Bone-Marrow","Embryonic-Stem-Cell","Lung","Bone_Marrow_Mesenchyme","Brain","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Testis","Neonatal-Calvaria","Bone-Marrow","Testis","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Brain","Lung","Uterus","MammaryGland.Pregnancy","MammaryGland.Involution","Spleen","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Bone-Marrow","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow_c-kit","Placenta","Fetal_Lung","MammaryGland.Lactation","Kidney","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Prostate","Small-Intestine","MammaryGland.Pregnancy","Bladder","MammaryGland.Involution","Testis","Pancreas","Neonatal-Skin","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Neonatal-Muscle","Testis","Fetal_Lung","Muscle","Fetal-Liver","MammaryGland.Virgin","Liver","Placenta","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Ovary","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow","Bone_Marrow_Mesenchyme","Small-Intestine","Trophoblast-Stem-Cell","Pancreas","Bone-Marrow_c-kit","MammaryGland.Virgin","Fetal_Brain","Fetal_Lung","Bone-Marrow","Bone-Marrow","Muscle","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Brain","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Pancreas","Fetal-Liver","MammaryGland.Lactation","Fetal-Liver","Thymus","Pancreas","Fetal_Intestine","Bone-Marrow_c-kit","Muscle","Testis","MammaryGland.Involution","Lung","Neonatal-Muscle","MammaryGland.Lactation","Trophoblast-Stem-Cell","Fetal_Stomache","Bone-Marrow","Lung","Testis","Neonatal-Calvaria","Bone-Marrow_c-kit","Liver","Embryonic-Stem-Cell","Testis","Bone-Marrow_c-kit","Stomach","MammaryGland.Involution","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Pancreas","Muscle","Neonatal-Muscle","Neonatal-Calvaria","Neonatal-Rib","Muscle","Neonatal-Rib","Liver","Thymus","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Testis","Neonatal-Muscle","Neonatal-Muscle","Lung","Bone-Marrow_c-kit","Testis","Embryonic-Stem-Cell","Testis","Lung","Kidney","Peripheral_Blood","Brain","Fetal_Lung","Peripheral_Blood","Neonatal-Calvaria","Testis","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","MammaryGland.Lactation","Testis","Kidney","Spleen","Testis","Ovary","MammaryGland.Involution","Bone-Marrow_c-kit","Neonatal-Calvaria","Spleen","Embryonic-Stem-Cell","Fetal_Brain","MammaryGland.Virgin","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Involution","Embryonic-Stem-Cell","Spleen","Kidney","Kidney","Small-Intestine","Neonatal-Rib","Testis","Bone-Marrow_c-kit","Prostate","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Muscle","MammaryGland.Pregnancy","Fetal_Brain","Bone-Marrow_c-kit","Fetal_Lung","Trophoblast-Stem-Cell","Testis","MammaryGland.Lactation","MammaryGland.Lactation","Stomach","Fetal_Stomache","Lung","Brain","Bone-Marrow","Kidney","Lung","Bone-Marrow_c-kit","Thymus","Neonatal-Calvaria","Lung","Fetal-Liver","Fetal_Lung","Neonatal-Calvaria","Placenta","Fetal_Lung","MammaryGland.Involution","Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Uterus","Brain","Testis","Fetal_Stomache","Thymus","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Ovary","MammaryGland.Lactation","MammaryGland.Lactation","Testis","Pancreas","Trophoblast-Stem-Cell","Muscle","MammaryGland.Virgin","Uterus","Testis","MammaryGland.Lactation","Neonatal-Skin","Placenta","Fetal_Intestine","MammaryGland.Virgin","Trophoblast-Stem-Cell","Uterus","Fetal_Lung","Neonatal-Heart","Embryonic-Stem-Cell","Ovary","MammaryGland.Lactation","MammaryGland.Virgin","Embryonic-Stem-Cell","Neonatal-Skin","Stomach","Peripheral_Blood","Peripheral_Blood","MammaryGland.Lactation","MammaryGland.Lactation","Liver","Pancreas","Neonatal-Rib","Kidney","Peripheral_Blood","Bone-Marrow","Fetal_Brain","Bone-Marrow_c-kit","Fetal_Stomache","Fetal_Stomache","Stomach","Testis","Neonatal-Rib","Bone-Marrow","Bone-Marrow_c-kit","Bone-Marrow","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Fetal_Lung","MammaryGland.Involution","Trophoblast-Stem-Cell","Fetal_Intestine","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Thymus","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Neonatal-Heart","Small-Intestine","Neonatal-Calvaria","Fetal_Intestine","Fetal_Intestine","MammaryGland.Lactation","Fetal_Brain","Bone-Marrow_c-kit","Testis","Liver","Liver","Thymus","Embryonic-Stem-Cell","MammaryGland.Lactation","Neonatal-Heart","Fetal_Stomache","Muscle","MammaryGland.Virgin","Bone-Marrow_c-kit","Neonatal-Heart","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Testis","MammaryGland.Pregnancy","Testis","Trophoblast-Stem-Cell","Neonatal-Muscle","Fetal_Stomache","MammaryGland.Virgin","Embryonic-Mesenchyme","Neonatal-Calvaria","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Thymus","Testis","Fetal-Liver","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Small-Intestine","Testis","Testis","Lung","Neonatal-Rib","Neonatal-Calvaria","Bone-Marrow","Pancreas","Uterus","Fetal_Brain","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal_Stomache","Trophoblast-Stem-Cell","Fetal_Intestine","Testis","Embryonic-Stem-Cell","Fetal_Intestine","Prostate","Bone-Marrow_c-kit","Bone-Marrow","Embryonic-Mesenchyme","MammaryGland.Lactation","Small-Intestine","Pancreas","Peripheral_Blood","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Spleen","MammaryGland.Virgin","Trophoblast-Stem-Cell","Neonatal-Muscle","MammaryGland.Virgin","Embryonic-Stem-Cell","Pancreas","Neonatal-Rib","MammaryGland.Virgin","Embryonic-Mesenchyme","Testis","Liver","Mesenchymal-Stem-Cell-Cultured","Fetal-Liver","Fetal-Liver","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Neonatal-Heart","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow","MammaryGland.Involution","Prostate","Liver","Neonatal-Rib","Embryonic-Stem-Cell","MammaryGland.Lactation","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Muscle","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Virgin","MammaryGland.Lactation","Neonatal-Rib","Embryonic-Stem-Cell","Fetal_Stomache","MammaryGland.Lactation","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Bone-Marrow","MammaryGland.Lactation","Bone-Marrow_c-kit","Pancreas","Liver","Uterus","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Neonatal-Rib","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Pancreas","Brain","Testis","Thymus","Neonatal-Calvaria","Small-Intestine","Peripheral_Blood","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Trophoblast-Stem-Cell","Uterus","Testis","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Kidney","MammaryGland.Pregnancy","Stomach","Uterus","MammaryGland.Lactation","Liver","Bone-Marrow_c-kit","Small-Intestine","Embryonic-Mesenchyme","Testis","Placenta","Bone-Marrow","MammaryGland.Virgin","Neonatal-Heart","Lung","Neonatal-Skin","Testis","Small-Intestine","Brain","Bone-Marrow","Peripheral_Blood","Neonatal-Calvaria","Fetal_Stomache","Embryonic-Stem-Cell","Neonatal-Rib","MammaryGland.Involution","Small-Intestine","Neonatal-Calvaria","Bone-Marrow_c-kit","MammaryGland.Virgin","Peripheral_Blood","Embryonic-Stem-Cell","Liver","Testis","Bone-Marrow_c-kit","Ovary","Trophoblast-Stem-Cell","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Testis","Small-Intestine","MammaryGland.Involution","Trophoblast-Stem-Cell","Brain","Liver","Neonatal-Skin","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal-Liver","Trophoblast-Stem-Cell","Fetal_Intestine","Fetal_Brain","Neonatal-Muscle","Placenta","MammaryGland.Virgin","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Small-Intestine","Prostate","Small-Intestine","Spleen","Fetal_Brain","Neonatal-Rib","Neonatal-Calvaria","Bone-Marrow","Spleen","Placenta","Lung","Fetal_Lung","Neonatal-Calvaria","Uterus","Testis","MammaryGland.Lactation","Fetal_Stomache","Embryonic-Stem-Cell","Neonatal-Calvaria","Thymus","Testis","Fetal_Intestine","Neonatal-Rib","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","MammaryGland.Virgin","MammaryGland.Virgin","Bone-Marrow_c-kit","Embryonic-Mesenchyme","MammaryGland.Involution","Testis","Liver","Bone_Marrow_Mesenchyme","Fetal_Stomache","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Spleen","Neonatal-Calvaria","Thymus","Embryonic-Stem-Cell","MammaryGland.Involution","Testis","Fetal_Brain","Bone-Marrow_c-kit","Brain","Bladder","MammaryGland.Lactation","Bladder","Fetal_Lung","MammaryGland.Lactation","Testis","Lung","Stomach","Neonatal-Muscle","Bone-Marrow_c-kit","Neonatal-Muscle","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Stomach","Spleen","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Neonatal-Calvaria","Fetal_Lung","Bone-Marrow","Small-Intestine","Bone-Marrow","MammaryGland.Lactation","Bone-Marrow","Neonatal-Heart","Ovary","MammaryGland.Pregnancy","Fetal_Lung","Pancreas","Trophoblast-Stem-Cell","Neonatal-Rib","Liver","Embryonic-Stem-Cell","Fetal_Lung","Fetal_Lung","Stomach","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Placenta","Uterus","Neonatal-Muscle","Neonatal-Heart","Small-Intestine","Embryonic-Stem-Cell","Uterus","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Rib","Bladder","Liver","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Fetal_Lung","Fetal_Lung","Ovary","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Placenta","Neonatal-Muscle","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Lactation","Testis","Fetal_Stomache","Bone-Marrow_c-kit","Small-Intestine","Peripheral_Blood","Embryonic-Stem-Cell","Neonatal-Calvaria","Embryonic-Stem-Cell","Fetal_Intestine","Neonatal-Calvaria","Bone-Marrow_c-kit","Testis","Kidney","Bladder","Uterus","Testis","Fetal_Brain","Prostate","Embryonic-Stem-Cell","Prostate","Uterus","Trophoblast-Stem-Cell","Kidney","Fetal_Intestine","Fetal_Stomache","Bone_Marrow_Mesenchyme","Neonatal-Skin","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Stomach","MammaryGland.Lactation","Liver","Testis","Neonatal-Skin","Testis","Stomach","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Skin","Lung","Pancreas","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Rib","Trophoblast-Stem-Cell","Fetal_Brain","Testis","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Intestine","MammaryGland.Involution","Bone-Marrow","Fetal_Intestine","Neonatal-Muscle","Neonatal-Calvaria","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Lung","Brain","Embryonic-Stem-Cell","Testis","Embryonic-Stem-Cell","Kidney","MammaryGland.Lactation","Fetal-Liver","Embryonic-Mesenchyme","Fetal_Brain","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","MammaryGland.Virgin","Testis","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Fetal_Stomache","Prostate","Neonatal-Muscle","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","Fetal_Intestine","Prostate","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone-Marrow","Kidney","Bone-Marrow_c-kit","Fetal_Brain","Ovary","MammaryGland.Virgin","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Prostate","Bladder","Peripheral_Blood","MammaryGland.Involution","Fetal_Stomache","Fetal_Lung","Small-Intestine","MammaryGland.Involution","Brain","Fetal_Intestine","Embryonic-Stem-Cell","Small-Intestine","MammaryGland.Lactation","MammaryGland.Lactation","Fetal_Stomache","MammaryGland.Virgin","Liver","Neonatal-Heart","MammaryGland.Lactation","Peripheral_Blood","Liver","Trophoblast-Stem-Cell","Small-Intestine","Bone_Marrow_Mesenchyme","Bone-Marrow","Fetal_Brain","Fetal-Liver","Placenta","Fetal_Brain","Liver","Lung","Fetal_Intestine","Bone-Marrow_c-kit","Liver","MammaryGland.Lactation","Neonatal-Calvaria","Neonatal-Calvaria","Peripheral_Blood","Stomach","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Neonatal-Rib","Bone_Marrow_Mesenchyme","Testis","MammaryGland.Lactation","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Uterus","Small-Intestine","Lung","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Peripheral_Blood","Pancreas","MammaryGland.Lactation","Neonatal-Rib","Stomach","Bone-Marrow_c-kit","Bone-Marrow","Bone-Marrow","Neonatal-Rib","Lung","Bone-Marrow_c-kit","MammaryGland.Pregnancy","MammaryGland.Pregnancy","MammaryGland.Virgin","Fetal-Liver","Small-Intestine","Spleen","Prostate","Testis","Fetal_Intestine","Embryonic-Stem-Cell","Bladder","Fetal_Intestine","Bone-Marrow","Small-Intestine","Testis","Lung","Peripheral_Blood","Placenta","MammaryGland.Virgin","Bone-Marrow_c-kit","Fetal_Intestine","Peripheral_Blood","MammaryGland.Lactation","Neonatal-Muscle","Fetal_Stomache","MammaryGland.Lactation","Bone-Marrow","Bladder","Neonatal-Heart","Embryonic-Stem-Cell","Neonatal-Skin","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Kidney","Neonatal-Calvaria","Fetal-Liver","Neonatal-Calvaria","MammaryGland.Virgin","Testis","MammaryGland.Lactation","MammaryGland.Lactation","MammaryGland.Lactation","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Heart","Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Calvaria","MammaryGland.Lactation","Pancreas","Testis","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Kidney","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Small-Intestine","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Kidney","Peripheral_Blood","MammaryGland.Lactation","Neonatal-Muscle","Trophoblast-Stem-Cell","MammaryGland.Lactation","Thymus","Testis","Uterus","Lung","Trophoblast-Stem-Cell","Testis","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Neonatal-Muscle","Bone-Marrow_c-kit","Neonatal-Muscle","Fetal_Stomache","Neonatal-Muscle","Fetal_Lung","Fetal_Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Placenta","Trophoblast-Stem-Cell","MammaryGland.Involution","Trophoblast-Stem-Cell","Fetal_Stomache","MammaryGland.Virgin","Kidney","Trophoblast-Stem-Cell","Fetal_Intestine","Small-Intestine","Neonatal-Heart","Bone-Marrow_c-kit","Fetal_Intestine","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Neonatal-Rib","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","MammaryGland.Virgin","Brain","Fetal_Stomache","Kidney","Stomach","Neonatal-Heart","Lung","Mesenchymal-Stem-Cell-Cultured","Embryonic-Mesenchyme","Neonatal-Rib","Thymus","Bone_Marrow_Mesenchyme","Liver","Brain","Fetal_Intestine","Lung","Brain","Fetal_Lung","Stomach","MammaryGland.Lactation","Bone-Marrow_c-kit","Testis","MammaryGland.Lactation","Uterus","Testis","Bone_Marrow_Mesenchyme","Fetal_Lung","Fetal_Intestine","Fetal_Brain","Bone_Marrow_Mesenchyme","Testis","Uterus","Kidney","Testis","Fetal_Stomache","Bone-Marrow","Bone-Marrow","Testis","Embryonic-Stem-Cell","Testis","Testis","Neonatal-Calvaria","Placenta","Bone-Marrow_c-kit","Neonatal-Heart","Neonatal-Heart","Neonatal-Skin","Stomach","Embryonic-Stem-Cell","Muscle","Mesenchymal-Stem-Cell-Cultured","Testis","Neonatal-Heart","Fetal-Liver","Peripheral_Blood","Trophoblast-Stem-Cell","Liver","Liver","Bone-Marrow","Placenta","Uterus","Neonatal-Rib","Kidney","Thymus","Ovary","Bone-Marrow_c-kit","Neonatal-Skin","Small-Intestine","Neonatal-Skin","Trophoblast-Stem-Cell","Fetal_Stomache","Neonatal-Rib","Kidney","Peripheral_Blood","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Testis","MammaryGland.Lactation","MammaryGland.Virgin","Bone-Marrow_c-kit","Fetal_Brain","Embryonic-Stem-Cell","Fetal_Intestine","Liver","Bone-Marrow_c-kit","Neonatal-Rib","MammaryGland.Lactation","MammaryGland.Lactation","MammaryGland.Virgin","Placenta","MammaryGland.Lactation","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","MammaryGland.Lactation","Neonatal-Skin","Fetal_Stomache","MammaryGland.Lactation","Fetal-Liver","MammaryGland.Lactation","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Fetal_Lung","Trophoblast-Stem-Cell","MammaryGland.Involution","Fetal_Lung","Lung","Testis","Pancreas","Liver","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Neonatal-Rib","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Small-Intestine","Testis","Testis","Peripheral_Blood","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Bladder","Bone-Marrow_c-kit","Uterus","Fetal_Lung","Neonatal-Heart","Liver","Trophoblast-Stem-Cell","Brain","Neonatal-Skin","Lung","Placenta","Ovary","Neonatal-Muscle","MammaryGland.Involution","Testis","Kidney","MammaryGland.Lactation","Fetal_Lung","Peripheral_Blood","Fetal-Liver","Pancreas","Neonatal-Heart","Fetal_Stomache","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Brain","Neonatal-Heart","Small-Intestine","Fetal_Lung","Kidney","Trophoblast-Stem-Cell","MammaryGland.Involution","Muscle","Trophoblast-Stem-Cell","Uterus","Peripheral_Blood","Peripheral_Blood","Ovary","Bone-Marrow_c-kit","Neonatal-Muscle","Fetal_Brain","MammaryGland.Involution","Bone-Marrow","Stomach","Bone_Marrow_Mesenchyme","Brain","Bone-Marrow","Bone-Marrow_c-kit","Fetal-Liver","Small-Intestine","Placenta","Neonatal-Rib","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Peripheral_Blood","Small-Intestine","Thymus","Uterus","Placenta","Lung","Uterus","Trophoblast-Stem-Cell","Fetal_Stomache","Fetal_Intestine","Lung","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","Trophoblast-Stem-Cell","Lung","Bone-Marrow_c-kit","Bone-Marrow","Testis","Neonatal-Heart","Neonatal-Muscle","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow","Fetal_Intestine","Fetal_Intestine","Prostate","Ovary","MammaryGland.Virgin","Pancreas","Mesenchymal-Stem-Cell-Cultured","Uterus","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Small-Intestine","Neonatal-Skin","Trophoblast-Stem-Cell","MammaryGland.Virgin","Placenta","MammaryGland.Virgin","Bone-Marrow","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Peripheral_Blood","Bladder","MammaryGland.Pregnancy","Brain","Brain","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Trophoblast-Stem-Cell","Brain","Bone-Marrow_c-kit","Liver","Fetal-Liver","Bone_Marrow_Mesenchyme","Uterus","Stomach","Neonatal-Rib","Thymus","MammaryGland.Lactation","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Kidney","Stomach","Peripheral_Blood","Testis","Testis","Stomach","Fetal_Lung","Embryonic-Stem-Cell","Neonatal-Calvaria","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","Neonatal-Muscle","Fetal_Brain","Fetal_Brain","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow","Neonatal-Muscle","Liver","Embryonic-Mesenchyme","Testis","Neonatal-Calvaria","Bone-Marrow_c-kit","Muscle","Small-Intestine","Bone-Marrow_c-kit","Bladder","Embryonic-Mesenchyme","Thymus","Neonatal-Muscle","Small-Intestine","Liver","Bone-Marrow_c-kit","Fetal_Brain","Testis","Liver","Lung","Fetal_Lung","Lung","Placenta","Embryonic-Stem-Cell","Fetal_Intestine","Fetal_Lung","Peripheral_Blood","Embryonic-Stem-Cell","Fetal_Lung","Fetal_Intestine","Ovary","Fetal_Intestine","Bone-Marrow_c-kit","Lung","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Rib","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Ovary","Kidney","Neonatal-Calvaria","Fetal_Stomache","Neonatal-Rib","Lung","Bone-Marrow","Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Brain","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Lung","Fetal_Lung","Small-Intestine","MammaryGland.Involution","Liver","Testis","Neonatal-Heart","Fetal-Liver","Liver","Bone-Marrow_c-kit","Peripheral_Blood","Neonatal-Skin","Uterus","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bladder","Neonatal-Rib","Trophoblast-Stem-Cell","Fetal_Stomache","MammaryGland.Involution","Embryonic-Stem-Cell","Neonatal-Skin","Thymus","Bone-Marrow_c-kit","Testis","Ovary","Neonatal-Calvaria","Neonatal-Calvaria","Placenta","Liver","Placenta","Bone-Marrow_c-kit","Testis","Fetal_Stomache","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Pancreas","Embryonic-Stem-Cell","Fetal_Lung","Fetal_Stomache","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Small-Intestine","Fetal_Stomache","Testis","Fetal_Intestine","Bone-Marrow","MammaryGland.Lactation","Bone-Marrow","Neonatal-Muscle","Bone-Marrow_c-kit","Fetal_Brain","Kidney","Lung","Peripheral_Blood","Fetal_Stomache","Neonatal-Muscle","MammaryGland.Lactation","Fetal_Lung","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow","Fetal_Lung","Small-Intestine","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Peripheral_Blood","Fetal_Brain","Bone-Marrow","MammaryGland.Pregnancy","Testis","Neonatal-Muscle","MammaryGland.Lactation","Small-Intestine","Neonatal-Skin","MammaryGland.Involution","Bladder","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","MammaryGland.Involution","Peripheral_Blood","Bone-Marrow","Fetal_Lung","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal-Liver","MammaryGland.Pregnancy","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Skin","Bone-Marrow_c-kit","Neonatal-Rib","Kidney","Neonatal-Heart","Embryonic-Stem-Cell","MammaryGland.Involution","Small-Intestine","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Lung","Placenta","MammaryGland.Virgin","Testis","MammaryGland.Lactation","Testis","Kidney","Neonatal-Heart","Ovary","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","MammaryGland.Virgin","MammaryGland.Lactation","Embryonic-Stem-Cell","Fetal_Intestine","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Neonatal-Calvaria","Neonatal-Calvaria","Trophoblast-Stem-Cell","Testis","Thymus","Trophoblast-Stem-Cell","Fetal_Lung","Embryonic-Stem-Cell","Prostate","Embryonic-Stem-Cell","Bone-Marrow","Thymus","Placenta","Bone-Marrow","Kidney","Testis","Ovary","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Rib","Testis","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Small-Intestine","Lung","Neonatal-Calvaria","Fetal_Lung","Bone-Marrow","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","MammaryGland.Involution","Bone-Marrow_c-kit","Brain","Bone_Marrow_Mesenchyme","Bone-Marrow","Trophoblast-Stem-Cell","Neonatal-Rib","MammaryGland.Lactation","Small-Intestine","Embryonic-Mesenchyme","MammaryGland.Lactation","Uterus","Lung","Neonatal-Rib","Lung","Bone_Marrow_Mesenchyme","Small-Intestine","Lung","Ovary","Embryonic-Stem-Cell","MammaryGland.Lactation","Liver","Bone-Marrow_c-kit","Neonatal-Heart","Trophoblast-Stem-Cell","Fetal_Intestine","Testis","MammaryGland.Lactation","Fetal_Stomache","Fetal_Lung","Testis","MammaryGland.Virgin","MammaryGland.Virgin","Trophoblast-Stem-Cell","Testis","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Bladder","Small-Intestine","Bone-Marrow_c-kit","MammaryGland.Involution","Small-Intestine","Neonatal-Muscle","Trophoblast-Stem-Cell","Bladder","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Testis","Trophoblast-Stem-Cell","Pancreas","Embryonic-Mesenchyme","Fetal-Liver","MammaryGland.Virgin","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal_Brain","Fetal_Intestine","Prostate","Fetal_Brain","Neonatal-Calvaria","Testis","Bone-Marrow_c-kit","Lung","Bone-Marrow","MammaryGland.Involution","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Testis","Testis","Lung","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow","Bone-Marrow","Neonatal-Calvaria","Bone-Marrow_c-kit","Prostate","Uterus","Testis","Ovary","Uterus","Testis","Trophoblast-Stem-Cell","MammaryGland.Lactation","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Peripheral_Blood","Testis","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Lactation","Embryonic-Mesenchyme","MammaryGland.Involution","Trophoblast-Stem-Cell","Testis","Testis","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Lung","Bone-Marrow_c-kit","Fetal_Stomache","Stomach","Liver","Bone-Marrow_c-kit","MammaryGland.Involution","Ovary","Brain","Embryonic-Stem-Cell","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Testis","MammaryGland.Lactation","Trophoblast-Stem-Cell","Fetal_Lung","Neonatal-Skin","MammaryGland.Virgin","Thymus","Fetal_Stomache","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Neonatal-Muscle","MammaryGland.Lactation","Kidney","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Lung","Fetal_Intestine","Brain","Small-Intestine","Uterus","Stomach","Peripheral_Blood","Brain","Fetal_Lung","Placenta","Bone_Marrow_Mesenchyme","Testis","Kidney","Neonatal-Rib","MammaryGland.Virgin","Lung","Bone-Marrow","MammaryGland.Pregnancy","Placenta","Trophoblast-Stem-Cell","MammaryGland.Involution","Thymus","Neonatal-Skin","Lung","Bone-Marrow","Bone_Marrow_Mesenchyme","Neonatal-Skin","Bone-Marrow_c-kit","Fetal_Lung","Prostate","Bone-Marrow_c-kit","Testis","Peripheral_Blood","Trophoblast-Stem-Cell","MammaryGland.Involution","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Testis","Trophoblast-Stem-Cell","Thymus","Trophoblast-Stem-Cell","Testis","Liver","MammaryGland.Virgin","Bone-Marrow_c-kit","Fetal_Intestine","MammaryGland.Pregnancy","Uterus","Neonatal-Heart","Fetal_Lung","Thymus","Lung","Embryonic-Stem-Cell","Lung","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Muscle","Bone-Marrow","Peripheral_Blood","Liver","Bone_Marrow_Mesenchyme","Fetal_Lung","Bone-Marrow","Fetal-Liver","Fetal_Brain","Neonatal-Rib","Fetal_Intestine","Neonatal-Muscle","Bone-Marrow_c-kit","Pancreas","Prostate","Testis","Lung","Kidney","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Testis","Neonatal-Calvaria","Embryonic-Stem-Cell","Fetal_Intestine","Embryonic-Stem-Cell","Fetal_Stomache","Embryonic-Stem-Cell","Bone-Marrow","MammaryGland.Virgin","Peripheral_Blood","Fetal_Lung","Brain","Fetal_Brain","Testis","Trophoblast-Stem-Cell","Fetal_Brain","Trophoblast-Stem-Cell","Neonatal-Skin","Peripheral_Blood","Embryonic-Stem-Cell","Small-Intestine","Stomach","Peripheral_Blood","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Liver","Peripheral_Blood","Lung","Trophoblast-Stem-Cell","Testis","Embryonic-Stem-Cell","MammaryGland.Lactation","Testis","MammaryGland.Lactation","Fetal_Brain","Bone-Marrow_c-kit","Uterus","Fetal_Brain","Peripheral_Blood","Ovary","MammaryGland.Lactation","Neonatal-Calvaria","Lung","MammaryGland.Lactation","Fetal_Brain","Testis","Pancreas","MammaryGland.Involution","Spleen","Trophoblast-Stem-Cell","Fetal_Intestine","Lung","Ovary","Testis","Pancreas","Trophoblast-Stem-Cell","Peripheral_Blood","Testis","Liver","Fetal_Intestine","Bone-Marrow_c-kit","Testis","Testis","Testis","Peripheral_Blood","Neonatal-Calvaria","Peripheral_Blood","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Peripheral_Blood","Kidney","Thymus","Peripheral_Blood","Testis","Fetal-Liver","Embryonic-Stem-Cell","Ovary","Fetal_Brain","Neonatal-Heart","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Fetal_Stomache","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Fetal-Liver","Neonatal-Muscle","Placenta","Placenta","Ovary","Neonatal-Muscle","Fetal_Stomache","Uterus","Liver","Testis","Neonatal-Calvaria","Testis","Thymus","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Stomache","MammaryGland.Lactation","Bone-Marrow","Prostate","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","Bone-Marrow","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Uterus","Thymus","MammaryGland.Lactation","Neonatal-Rib","Bone-Marrow","Peripheral_Blood","Embryonic-Mesenchyme","Peripheral_Blood","Kidney","Liver","MammaryGland.Lactation","Neonatal-Calvaria","Bone-Marrow_c-kit","Neonatal-Calvaria","Muscle","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Rib","Fetal-Liver","Small-Intestine","Embryonic-Mesenchyme","Thymus","MammaryGland.Lactation","Fetal_Brain","Testis","Small-Intestine","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Brain","Neonatal-Muscle","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow","Prostate","Trophoblast-Stem-Cell","Testis","Bone_Marrow_Mesenchyme","Fetal_Stomache","Fetal_Lung","Testis","Fetal_Lung","Bone-Marrow_c-kit","Neonatal-Muscle","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","MammaryGland.Pregnancy","Neonatal-Muscle","Fetal-Liver","MammaryGland.Virgin","Neonatal-Rib","Stomach","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Testis","Liver","MammaryGland.Lactation","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow","MammaryGland.Lactation","Fetal_Stomache","Bone_Marrow_Mesenchyme","Kidney","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal_Lung","Fetal-Liver","Neonatal-Heart","Mesenchymal-Stem-Cell-Cultured","Lung","Testis","Prostate","Small-Intestine","Thymus","MammaryGland.Virgin","Muscle","Kidney","Embryonic-Stem-Cell","Small-Intestine","Fetal_Brain","Bone-Marrow_c-kit","Neonatal-Calvaria","Trophoblast-Stem-Cell","Peripheral_Blood","MammaryGland.Lactation","Fetal_Lung","Embryonic-Stem-Cell","MammaryGland.Virgin","Trophoblast-Stem-Cell","Fetal_Intestine","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Brain","Prostate","Thymus","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone-Marrow_c-kit","Pancreas","Uterus","Fetal_Intestine","Trophoblast-Stem-Cell","Neonatal-Calvaria","Lung","Stomach","Fetal_Intestine","Lung","Lung","Neonatal-Heart","Kidney","Small-Intestine","Liver","MammaryGland.Virgin","Stomach","Testis","Testis","Fetal_Lung","Prostate","Bone-Marrow","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Small-Intestine","Lung","Lung","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Lung","Fetal_Lung","Testis","Stomach","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Lung","Bone-Marrow_c-kit","Neonatal-Heart","Peripheral_Blood","MammaryGland.Lactation","Fetal_Stomache","Small-Intestine","Testis","Bone-Marrow_c-kit","Fetal-Liver","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Brain","Testis","Fetal-Liver","Placenta","Bone-Marrow","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Bone-Marrow","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Brain","Testis","Neonatal-Calvaria","Liver","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Muscle","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Placenta","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Neonatal-Rib","Thymus","Small-Intestine","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Liver","Bone-Marrow_c-kit","Stomach","MammaryGland.Lactation","Bone-Marrow_c-kit","Neonatal-Muscle","Peripheral_Blood","Testis","MammaryGland.Lactation","Peripheral_Blood","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Bone-Marrow","Bone-Marrow","Spleen","MammaryGland.Involution","MammaryGland.Lactation","Embryonic-Stem-Cell","MammaryGland.Lactation","MammaryGland.Lactation","Placenta","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Neonatal-Calvaria","Bone-Marrow_c-kit","Stomach","Prostate","Placenta","Bone-Marrow_c-kit","Embryonic-Stem-Cell","MammaryGland.Lactation","Lung","MammaryGland.Virgin","Bone-Marrow_c-kit","Neonatal-Muscle","Fetal_Intestine","Placenta","Lung","Neonatal-Muscle","Ovary","Uterus","Bone-Marrow_c-kit","Fetal-Liver","Peripheral_Blood","MammaryGland.Pregnancy","Small-Intestine","Bone-Marrow","Bone_Marrow_Mesenchyme","Prostate","Bone-Marrow_c-kit","Fetal_Intestine","Neonatal-Heart","Trophoblast-Stem-Cell","Fetal_Intestine","Muscle","Bone-Marrow_c-kit","Pancreas","Neonatal-Muscle","Fetal_Intestine","Testis","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Virgin","Peripheral_Blood","Neonatal-Calvaria","Neonatal-Muscle","Neonatal-Calvaria","Trophoblast-Stem-Cell","Fetal_Intestine","MammaryGland.Lactation","Lung","Neonatal-Muscle","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Prostate","Thymus","MammaryGland.Pregnancy","MammaryGland.Lactation","Neonatal-Heart","MammaryGland.Virgin","MammaryGland.Lactation","Bone-Marrow","MammaryGland.Lactation","Bone-Marrow","Neonatal-Skin","MammaryGland.Lactation","Fetal_Intestine","Neonatal-Muscle","Neonatal-Calvaria","MammaryGland.Virgin","Thymus","Brain","Bone-Marrow","Neonatal-Rib","Fetal_Stomache","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Kidney","Peripheral_Blood","Lung","Bone-Marrow_c-kit","Neonatal-Heart","Bone-Marrow","Bone-Marrow_c-kit","Peripheral_Blood","MammaryGland.Lactation","Testis","Placenta","Prostate","Fetal_Stomache","Bladder","Bone-Marrow_c-kit","Fetal_Stomache","Neonatal-Rib","Prostate","Testis","Peripheral_Blood","Kidney","Spleen","Ovary","MammaryGland.Lactation","Bone-Marrow_c-kit","MammaryGland.Lactation","Testis","Small-Intestine","Neonatal-Muscle","Kidney","Bladder","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Neonatal-Calvaria","Liver","Trophoblast-Stem-Cell","Fetal_Intestine","Trophoblast-Stem-Cell","Bone-Marrow","Bladder","Pancreas","Thymus","MammaryGland.Lactation","Lung","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow","Small-Intestine","Bone-Marrow","MammaryGland.Lactation","Fetal_Brain","Bone-Marrow_c-kit","Stomach","Neonatal-Calvaria","Embryonic-Stem-Cell","Uterus","Fetal_Intestine","Brain","MammaryGland.Involution","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow_c-kit","Fetal_Brain","Uterus","MammaryGland.Involution","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Stomach","Fetal_Lung","Trophoblast-Stem-Cell","Lung","Uterus","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Neonatal-Heart","Bone-Marrow_c-kit","Thymus","Fetal_Brain","Neonatal-Calvaria","Ovary","MammaryGland.Lactation","Testis","Trophoblast-Stem-Cell","Small-Intestine","MammaryGland.Pregnancy","Neonatal-Rib","Uterus","Mesenchymal-Stem-Cell-Cultured","Brain","Small-Intestine","Fetal_Stomache","MammaryGland.Lactation","Embryonic-Mesenchyme","Bone-Marrow","Neonatal-Heart","Trophoblast-Stem-Cell","Bladder","Neonatal-Rib","Trophoblast-Stem-Cell","Placenta","Prostate","Neonatal-Skin","Testis","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Testis","Neonatal-Muscle","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Neonatal-Rib","Peripheral_Blood","Fetal_Stomache","MammaryGland.Virgin","Bone-Marrow_c-kit","Fetal_Stomache","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Pancreas","Bone-Marrow","Bone-Marrow","Fetal-Liver","Neonatal-Calvaria","Fetal_Brain","Thymus","MammaryGland.Lactation","Uterus","Muscle","Small-Intestine","Uterus","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Neonatal-Heart","Neonatal-Heart","MammaryGland.Lactation","Bladder","Placenta","Trophoblast-Stem-Cell","Uterus","Embryonic-Stem-Cell","Kidney","Bone-Marrow","Trophoblast-Stem-Cell","MammaryGland.Lactation","Embryonic-Stem-Cell","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","MammaryGland.Virgin","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Thymus","Neonatal-Calvaria","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Brain","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Brain","Neonatal-Rib","Fetal-Liver","Bone-Marrow","Bone-Marrow_c-kit","Neonatal-Rib","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Stomache","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow","Embryonic-Stem-Cell","Neonatal-Calvaria","Peripheral_Blood","Small-Intestine","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Ovary","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Testis","Neonatal-Rib","Bone-Marrow_c-kit","Fetal_Intestine","Bone-Marrow","Neonatal-Calvaria","Fetal_Stomache","Testis","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Kidney","Pancreas","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Neonatal-Calvaria","Fetal_Lung","Testis","Fetal_Stomache","Fetal-Liver","Fetal_Intestine","Fetal_Intestine","Placenta","Bone-Marrow_c-kit","Bone-Marrow","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Brain","Fetal_Brain","Fetal_Lung","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Neonatal-Calvaria","Embryonic-Stem-Cell","Neonatal-Calvaria","Embryonic-Stem-Cell","Liver","MammaryGland.Lactation","Neonatal-Skin","Neonatal-Calvaria","MammaryGland.Lactation","Lung","Lung","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Bone-Marrow_c-kit","Testis","Bone-Marrow","Liver","Bone_Marrow_Mesenchyme","Thymus","MammaryGland.Lactation","Embryonic-Stem-Cell","Fetal_Intestine","Placenta","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Pancreas","MammaryGland.Lactation","MammaryGland.Virgin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Virgin","Bone-Marrow","Neonatal-Heart","Bone-Marrow","Neonatal-Rib","Fetal_Intestine","MammaryGland.Lactation","Testis","Lung","MammaryGland.Lactation","Uterus","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Fetal_Brain","Bone-Marrow_c-kit","Thymus","MammaryGland.Pregnancy","Pancreas","Bone-Marrow_c-kit","Stomach","MammaryGland.Lactation","Neonatal-Muscle","Neonatal-Calvaria","Fetal_Stomache","Ovary","Spleen","Placenta","Brain","Fetal_Stomache","Bone-Marrow_c-kit","Fetal_Lung","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Ovary","Trophoblast-Stem-Cell","Fetal_Intestine","MammaryGland.Virgin","Lung","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Fetal_Intestine","Lung","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Muscle","Ovary","Bone-Marrow","Bladder","Testis","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Peripheral_Blood","Kidney","Mesenchymal-Stem-Cell-Cultured","Ovary","Uterus","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Kidney","Spleen","Bone-Marrow_c-kit","Testis","Neonatal-Skin","Bone-Marrow_c-kit","Fetal-Liver","Fetal_Brain","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Testis","Small-Intestine","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Muscle","Small-Intestine","Neonatal-Calvaria","Bone-Marrow_c-kit","Testis","Prostate","MammaryGland.Virgin","Kidney","Prostate","Liver","Placenta","Neonatal-Calvaria","Bone-Marrow_c-kit","Uterus","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Neonatal-Heart","Fetal_Stomache","Bone_Marrow_Mesenchyme","Pancreas","Testis","Embryonic-Mesenchyme","Peripheral_Blood","MammaryGland.Lactation","Neonatal-Calvaria","Lung","Bone_Marrow_Mesenchyme","Brain","Small-Intestine","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","MammaryGland.Lactation","Peripheral_Blood","Peripheral_Blood","Bladder","Peripheral_Blood","Fetal_Brain","MammaryGland.Involution","Neonatal-Calvaria","MammaryGland.Lactation","Embryonic-Stem-Cell","Small-Intestine","Prostate","Fetal_Lung","Lung","Embryonic-Stem-Cell","MammaryGland.Virgin","Kidney","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Testis","Bone_Marrow_Mesenchyme","Prostate","MammaryGland.Lactation","MammaryGland.Lactation","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Trophoblast-Stem-Cell","Ovary","Trophoblast-Stem-Cell","Neonatal-Skin","Trophoblast-Stem-Cell","Neonatal-Rib","Bone-Marrow_c-kit","Lung","Lung","Peripheral_Blood","Placenta","Lung","Liver","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Bone-Marrow_c-kit","Testis","Ovary","Bone_Marrow_Mesenchyme","Pancreas","Fetal_Intestine","Embryonic-Mesenchyme","Liver","Embryonic-Stem-Cell","Peripheral_Blood","Trophoblast-Stem-Cell","Kidney","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Testis","Placenta","Neonatal-Calvaria","Prostate","Lung","Neonatal-Heart","Uterus","Kidney","Trophoblast-Stem-Cell","Small-Intestine","Neonatal-Muscle","Fetal_Lung","Neonatal-Calvaria","MammaryGland.Lactation","Small-Intestine","Small-Intestine","MammaryGland.Involution","Neonatal-Muscle","Liver","Embryonic-Mesenchyme","Fetal_Lung","Embryonic-Mesenchyme","Testis","Fetal_Lung","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Brain","Bladder","MammaryGland.Virgin","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Ovary","MammaryGland.Virgin","Bone-Marrow_c-kit","Ovary","Neonatal-Rib","Bone-Marrow_c-kit","Peripheral_Blood","Liver","MammaryGland.Pregnancy","Pancreas","Bladder","Bone-Marrow_c-kit","Bone-Marrow","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Fetal_Brain","Testis","Prostate","Neonatal-Muscle","Small-Intestine","Fetal_Lung","Prostate","MammaryGland.Virgin","Bone-Marrow_c-kit","MammaryGland.Involution","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Kidney","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Testis","Kidney","Neonatal-Rib","Kidney","MammaryGland.Involution","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Liver","Ovary","Neonatal-Calvaria","Fetal_Intestine","MammaryGland.Involution","Stomach","Lung","Neonatal-Heart","MammaryGland.Lactation","Neonatal-Rib","Fetal_Stomache","Fetal_Intestine","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Intestine","Embryonic-Mesenchyme","Ovary","Fetal_Lung","Fetal-Liver","Prostate","MammaryGland.Lactation","MammaryGland.Lactation","Prostate","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Neonatal-Calvaria","Bone-Marrow","Pancreas","Testis","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Fetal_Stomache","Bladder","Neonatal-Muscle","Fetal_Stomache","Bone-Marrow_c-kit","Lung","Embryonic-Mesenchyme","Neonatal-Skin","Trophoblast-Stem-Cell","Thymus","Bone-Marrow","Thymus","Peripheral_Blood","Embryonic-Stem-Cell","Fetal_Lung","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Small-Intestine","Lung","Bone-Marrow_c-kit","Small-Intestine","Testis","Brain","Muscle","Testis","Fetal_Stomache","Brain","Fetal_Brain","Fetal_Lung","Fetal_Brain","Peripheral_Blood","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Involution","Fetal_Lung","Testis","Fetal_Lung","Bone-Marrow","Testis","Testis","MammaryGland.Lactation","MammaryGland.Lactation","MammaryGland.Involution","MammaryGland.Pregnancy","Neonatal-Rib","MammaryGland.Lactation","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","MammaryGland.Lactation","Neonatal-Calvaria","Embryonic-Stem-Cell","Testis","Bone-Marrow_c-kit","Pancreas","Bone_Marrow_Mesenchyme","Neonatal-Skin","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Kidney","Lung","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Embryonic-Mesenchyme","Brain","Embryonic-Stem-Cell","Ovary","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Placenta","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Lung","Testis","Liver","Testis","Small-Intestine","Fetal_Stomache","Testis","Neonatal-Calvaria","Fetal_Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Lung","Testis","Ovary","MammaryGland.Involution","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","Liver","Bone-Marrow_c-kit","MammaryGland.Virgin","MammaryGland.Involution","MammaryGland.Lactation","MammaryGland.Involution","Bone_Marrow_Mesenchyme","Small-Intestine","MammaryGland.Lactation","Fetal_Lung","Fetal_Stomache","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Rib","MammaryGland.Lactation","MammaryGland.Lactation","Ovary","Neonatal-Calvaria","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","MammaryGland.Involution","Liver","MammaryGland.Involution","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Stomache","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Prostate","Bone-Marrow_c-kit","Bone-Marrow","Bone-Marrow","Brain","Thymus","Trophoblast-Stem-Cell","MammaryGland.Involution","MammaryGland.Involution","Bone-Marrow_c-kit","Neonatal-Heart","Embryonic-Stem-Cell","Neonatal-Muscle","Trophoblast-Stem-Cell","Neonatal-Skin","Small-Intestine","Fetal-Liver","Neonatal-Calvaria","Small-Intestine","Lung","Testis","Fetal_Stomache","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Muscle","Fetal_Intestine","MammaryGland.Virgin","Trophoblast-Stem-Cell","Neonatal-Rib","Fetal-Liver","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","MammaryGland.Virgin","Fetal-Liver","Embryonic-Mesenchyme","Peripheral_Blood","Fetal_Intestine","Trophoblast-Stem-Cell","Stomach","Neonatal-Muscle","Fetal_Brain","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Placenta","Fetal_Lung","Bone-Marrow_c-kit","MammaryGland.Lactation","Small-Intestine","Neonatal-Muscle","Peripheral_Blood","Fetal_Lung","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Rib","Pancreas","Neonatal-Calvaria","Fetal_Brain","Fetal-Liver","MammaryGland.Lactation","Thymus","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Brain","Neonatal-Rib","Embryonic-Mesenchyme","Lung","Bone-Marrow","Embryonic-Stem-Cell","Lung","Fetal_Intestine","MammaryGland.Virgin","Testis","Brain","MammaryGland.Lactation","Neonatal-Skin","Spleen","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Testis","Testis","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Placenta","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Lung","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Stomache","Neonatal-Skin","Neonatal-Calvaria","MammaryGland.Virgin","Neonatal-Rib","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Uterus","Peripheral_Blood","Fetal_Lung","Bone-Marrow_c-kit","Kidney","Lung","Bone-Marrow_c-kit","MammaryGland.Virgin","Bone-Marrow_c-kit","Neonatal-Calvaria","Trophoblast-Stem-Cell","Thymus","Lung","Lung","Uterus","Trophoblast-Stem-Cell","Placenta","Neonatal-Skin","Mesenchymal-Stem-Cell-Cultured","Lung","Ovary","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Kidney","Trophoblast-Stem-Cell","Thymus","MammaryGland.Involution","Lung","MammaryGland.Pregnancy","MammaryGland.Virgin","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Pregnancy","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","MammaryGland.Lactation","Neonatal-Calvaria","Kidney","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow","MammaryGland.Lactation","MammaryGland.Virgin","Trophoblast-Stem-Cell","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Small-Intestine","Trophoblast-Stem-Cell","Prostate","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Testis","Neonatal-Skin","Brain","Testis","Bone-Marrow_c-kit","Fetal_Intestine","Trophoblast-Stem-Cell","Lung","Trophoblast-Stem-Cell","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Lung","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Bone-Marrow_c-kit","Muscle","MammaryGland.Lactation","MammaryGland.Pregnancy","Neonatal-Rib","Placenta","Liver","Neonatal-Rib","Fetal_Brain","Neonatal-Calvaria","Fetal_Brain","Bone-Marrow_c-kit","Testis","Lung","Small-Intestine","Fetal_Lung","Testis","Fetal_Stomache","MammaryGland.Virgin","Trophoblast-Stem-Cell","Bone-Marrow","Neonatal-Rib","Bone-Marrow","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Intestine","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","Trophoblast-Stem-Cell","Neonatal-Skin","Small-Intestine","Testis","Neonatal-Rib","Neonatal-Rib","MammaryGland.Pregnancy","Placenta","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Neonatal-Heart","Thymus","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Bone-Marrow_c-kit","Neonatal-Muscle","MammaryGland.Lactation","MammaryGland.Virgin","Trophoblast-Stem-Cell","MammaryGland.Virgin","Thymus","Bone-Marrow","Kidney","Lung","MammaryGland.Pregnancy","Lung","Fetal_Intestine","Testis","Neonatal-Skin","Trophoblast-Stem-Cell","Testis","MammaryGland.Virgin","Bone-Marrow_c-kit","Bladder","Neonatal-Heart","Muscle","Trophoblast-Stem-Cell","Placenta","MammaryGland.Involution","MammaryGland.Lactation","Kidney","Fetal_Stomache","Small-Intestine","Trophoblast-Stem-Cell","Fetal_Brain","Bone-Marrow","Pancreas","Neonatal-Muscle","Spleen","Small-Intestine","Placenta","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Peripheral_Blood","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Skin","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Testis","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Testis","Fetal_Lung","Pancreas","Testis","Fetal_Stomache","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","Bladder","Peripheral_Blood","Bone-Marrow","Trophoblast-Stem-Cell","MammaryGland.Lactation","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Small-Intestine","Fetal_Lung","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","Ovary","Placenta","Fetal_Lung","Lung","Neonatal-Muscle","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Bone-Marrow","Embryonic-Stem-Cell","Fetal-Liver","Small-Intestine","Testis","Bone-Marrow_c-kit","MammaryGland.Virgin","Neonatal-Heart","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Testis","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Bone-Marrow_c-kit","Neonatal-Skin","Neonatal-Calvaria","Fetal_Lung","Trophoblast-Stem-Cell","Uterus","Liver","Ovary","Fetal_Brain","Kidney","Small-Intestine","Bone-Marrow_c-kit","Fetal_Brain","Neonatal-Muscle","MammaryGland.Lactation","Neonatal-Muscle","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Lung","Embryonic-Stem-Cell","Neonatal-Heart","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","MammaryGland.Lactation","Neonatal-Calvaria","Neonatal-Heart","Lung","Neonatal-Skin","Neonatal-Calvaria","Bone-Marrow_c-kit","Neonatal-Muscle","Brain","Placenta","Kidney","Fetal_Lung","Bone-Marrow_c-kit","Uterus","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Bone-Marrow","Bone-Marrow_c-kit","Fetal_Lung","MammaryGland.Involution","Neonatal-Rib","Neonatal-Heart","Neonatal-Heart","Trophoblast-Stem-Cell","Placenta","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Heart","Trophoblast-Stem-Cell","Peripheral_Blood","Neonatal-Skin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Fetal_Stomache","Neonatal-Muscle","Kidney","Embryonic-Stem-Cell","Fetal_Stomache","Spleen","Fetal_Stomache","Pancreas","Trophoblast-Stem-Cell","Thymus","Trophoblast-Stem-Cell","Small-Intestine","Embryonic-Mesenchyme","Neonatal-Muscle","Small-Intestine","Fetal_Intestine","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Spleen","Bone_Marrow_Mesenchyme","Ovary","Bone_Marrow_Mesenchyme","Peripheral_Blood","Peripheral_Blood","MammaryGland.Involution","Brain","Neonatal-Rib","Fetal_Lung","Fetal_Lung","Neonatal-Rib","Fetal_Intestine","Neonatal-Rib","Trophoblast-Stem-Cell","Fetal_Stomache","Bone-Marrow","Kidney","Testis","Testis","Small-Intestine","MammaryGland.Lactation","Small-Intestine","Lung","Brain","Neonatal-Muscle","Embryonic-Stem-Cell","Bladder","Neonatal-Calvaria","Liver","MammaryGland.Lactation","Liver","Bone-Marrow_c-kit","Small-Intestine","Embryonic-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Skin","Bone-Marrow","MammaryGland.Lactation","Testis","Thymus","Bone_Marrow_Mesenchyme","Thymus","Small-Intestine","Small-Intestine","Embryonic-Stem-Cell","Prostate","Testis","Bone_Marrow_Mesenchyme","Prostate","Uterus","Fetal_Stomache","Prostate","Bone-Marrow_c-kit","Placenta","Lung","Embryonic-Stem-Cell","Neonatal-Heart","Uterus","Bone_Marrow_Mesenchyme","Kidney","Testis","Fetal_Lung","Uterus","Neonatal-Rib","Trophoblast-Stem-Cell","Pancreas","Bone-Marrow_c-kit","Fetal_Intestine","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Heart","Trophoblast-Stem-Cell","Kidney","Lung","Fetal_Stomache","MammaryGland.Lactation","MammaryGland.Involution","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Embryonic-Stem-Cell","Neonatal-Rib","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Peripheral_Blood","MammaryGland.Virgin","Neonatal-Calvaria","Neonatal-Heart","Bone-Marrow_c-kit","Fetal_Stomache","MammaryGland.Lactation","Peripheral_Blood","Small-Intestine","Thymus","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Muscle","MammaryGland.Virgin","Neonatal-Calvaria","Neonatal-Heart","Fetal_Lung","Bone-Marrow","Brain","Neonatal-Calvaria","Small-Intestine","Fetal_Lung","Testis","Kidney","Peripheral_Blood","MammaryGland.Involution","Fetal_Stomache","Peripheral_Blood","Peripheral_Blood","Uterus","Kidney","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Placenta","Muscle","Testis","Trophoblast-Stem-Cell","Fetal_Stomache","Placenta","MammaryGland.Virgin","Neonatal-Rib","Testis","Neonatal-Calvaria","Embryonic-Stem-Cell","Testis","Pancreas","Bone-Marrow_c-kit","MammaryGland.Virgin","Neonatal-Heart","Testis","Fetal_Intestine","Embryonic-Mesenchyme","Pancreas","Liver","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Thymus","Embryonic-Stem-Cell","Small-Intestine","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Stomach","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Testis","Fetal_Intestine","Prostate","Liver","Kidney","Small-Intestine","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal_Lung","Trophoblast-Stem-Cell","Lung","Bone-Marrow_c-kit","MammaryGland.Virgin","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow","Kidney","Fetal_Stomache","Fetal_Lung","Bone_Marrow_Mesenchyme","Placenta","Testis","Thymus","Embryonic-Stem-Cell","Neonatal-Rib","MammaryGland.Virgin","Liver","Bone_Marrow_Mesenchyme","Testis","Trophoblast-Stem-Cell","Spleen","Small-Intestine","MammaryGland.Lactation","Neonatal-Rib","Neonatal-Skin","Lung","Placenta","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Rib","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Rib","Brain","Neonatal-Skin","Placenta","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Virgin","Thymus","Uterus","Neonatal-Calvaria","Testis","Fetal_Stomache","Testis","Placenta","Lung","Small-Intestine","MammaryGland.Pregnancy","Fetal_Intestine","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Fetal_Intestine","Trophoblast-Stem-Cell","Bladder","Lung","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Placenta","MammaryGland.Lactation","Brain","MammaryGland.Involution","MammaryGland.Lactation","Testis","Peripheral_Blood","Bone-Marrow_c-kit","Brain","Bone-Marrow","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Ovary","MammaryGland.Lactation","Fetal_Brain","Embryonic-Stem-Cell","Embryonic-Mesenchyme","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Neonatal-Heart","Peripheral_Blood","Muscle","Embryonic-Stem-Cell","Fetal_Stomache","Neonatal-Calvaria","Neonatal-Rib","Liver","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Rib","Neonatal-Rib","Bone_Marrow_Mesenchyme","Fetal_Lung","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Ovary","Neonatal-Heart","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Ovary","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Peripheral_Blood","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Involution","Uterus","Bone-Marrow_c-kit","Peripheral_Blood","MammaryGland.Involution","MammaryGland.Involution","Trophoblast-Stem-Cell","Fetal_Stomache","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Bone-Marrow","Small-Intestine","Testis","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Testis","Liver","Bone-Marrow","Testis","Testis","Neonatal-Calvaria","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal-Liver","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Peripheral_Blood","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Fetal_Lung","Prostate","Fetal-Liver","MammaryGland.Involution","Neonatal-Rib","Placenta","Neonatal-Calvaria","Fetal_Stomache","Bone-Marrow_c-kit","Testis","Bone-Marrow","Bone-Marrow_c-kit","Neonatal-Muscle","Testis","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Brain","Placenta","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Neonatal-Skin","Bone-Marrow_c-kit","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Muscle","Prostate","MammaryGland.Virgin","Embryonic-Stem-Cell","Fetal_Stomache","Pancreas","Neonatal-Muscle","Ovary","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Involution","Testis","Trophoblast-Stem-Cell","Bone-Marrow","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Neonatal-Heart","Trophoblast-Stem-Cell","Neonatal-Skin","Bone-Marrow","Bone_Marrow_Mesenchyme","Thymus","Prostate","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Embryonic-Mesenchyme","Testis","Testis","MammaryGland.Virgin","Lung","Fetal_Stomache","Ovary","Fetal_Lung","Liver","Ovary","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Brain","Kidney","Bone-Marrow_c-kit","Testis","Thymus","Small-Intestine","Bladder","Embryonic-Stem-Cell","Neonatal-Rib","Testis","MammaryGland.Lactation","Fetal_Intestine","Thymus","Pancreas","Thymus","Trophoblast-Stem-Cell","Lung","Lung","Neonatal-Muscle","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Kidney","Embryonic-Stem-Cell","Neonatal-Skin","Bone-Marrow_c-kit","Embryonic-Stem-Cell","MammaryGland.Virgin","Kidney","Trophoblast-Stem-Cell","Fetal_Stomache","Small-Intestine","MammaryGland.Virgin","Neonatal-Heart","Trophoblast-Stem-Cell","Fetal_Stomache","Neonatal-Muscle","Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Fetal_Stomache","MammaryGland.Virgin","Bone-Marrow_c-kit","Neonatal-Heart","Trophoblast-Stem-Cell","Prostate","MammaryGland.Lactation","Bone-Marrow","Neonatal-Calvaria","Testis","Trophoblast-Stem-Cell","Lung","Testis","Fetal_Intestine","Fetal_Lung","Peripheral_Blood","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Rib","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Liver","Fetal_Lung","Fetal-Liver","MammaryGland.Lactation","Bone-Marrow_c-kit","MammaryGland.Virgin","Trophoblast-Stem-Cell","Neonatal-Skin","Ovary","Trophoblast-Stem-Cell","Muscle","Trophoblast-Stem-Cell","Neonatal-Calvaria","Neonatal-Muscle","Liver","Bone-Marrow_c-kit","MammaryGland.Virgin","Testis","Bone-Marrow_c-kit","Bone-Marrow","Fetal_Intestine","Fetal_Stomache","Testis","Neonatal-Skin","MammaryGland.Involution","Trophoblast-Stem-Cell","Bladder","MammaryGland.Lactation","Lung","Muscle","Trophoblast-Stem-Cell","Fetal_Intestine","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Liver","Neonatal-Calvaria","Trophoblast-Stem-Cell","Lung","Mesenchymal-Stem-Cell-Cultured","Placenta","MammaryGland.Virgin","Trophoblast-Stem-Cell","Stomach","Fetal_Intestine","Spleen","MammaryGland.Involution","Bone-Marrow","Lung","Bone-Marrow","Kidney","Lung","MammaryGland.Involution","Neonatal-Rib","Bone-Marrow","Neonatal-Calvaria","Bone-Marrow","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Prostate","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Spleen","Bone-Marrow","Bone-Marrow_c-kit","Prostate","Small-Intestine","Neonatal-Rib","Small-Intestine","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Fetal-Liver","Prostate","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Prostate","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Kidney","Neonatal-Heart","Spleen","Placenta","Testis","MammaryGland.Virgin","Bone-Marrow","Fetal_Stomache","Fetal-Liver","Bone-Marrow_c-kit","Neonatal-Skin","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Small-Intestine","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Brain","Bone-Marrow_c-kit","Fetal_Lung","Placenta","Ovary","Bone-Marrow","MammaryGland.Lactation","Testis","Fetal-Liver","Fetal_Stomache","Fetal_Lung","Lung","Bone_Marrow_Mesenchyme","Fetal_Lung","Neonatal-Calvaria","Kidney","Liver","Testis","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Kidney","Bladder","Fetal_Stomache","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Fetal_Lung","MammaryGland.Lactation","MammaryGland.Virgin","Bone-Marrow","Fetal-Liver","MammaryGland.Pregnancy","Testis","Fetal_Stomache","Bone-Marrow_c-kit","Testis","Fetal-Liver","Fetal_Lung","Bone-Marrow_c-kit","Fetal_Intestine","Fetal_Brain","Small-Intestine","Neonatal-Calvaria","Ovary","Testis","Brain","MammaryGland.Lactation","Neonatal-Calvaria","Bone-Marrow_c-kit","Neonatal-Skin","Small-Intestine","MammaryGland.Lactation","MammaryGland.Lactation","MammaryGland.Lactation","Neonatal-Muscle","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Peripheral_Blood","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Bone-Marrow_c-kit","Placenta","Bone-Marrow_c-kit","Brain","Bone-Marrow_c-kit","Small-Intestine","Small-Intestine","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Bone-Marrow","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Brain","Peripheral_Blood","Fetal_Brain","Trophoblast-Stem-Cell","Liver","Embryonic-Stem-Cell","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Peripheral_Blood","Bone_Marrow_Mesenchyme","Fetal_Stomache","Embryonic-Mesenchyme","Testis","MammaryGland.Lactation","Testis","Bone-Marrow_c-kit","Stomach","Trophoblast-Stem-Cell","Fetal_Intestine","MammaryGland.Lactation","Fetal-Liver","Bone_Marrow_Mesenchyme","Bladder","Testis","Liver","Peripheral_Blood","Peripheral_Blood","Liver","MammaryGland.Lactation","Placenta","Trophoblast-Stem-Cell","Kidney","Bone-Marrow","Pancreas","Neonatal-Skin","Pancreas","Testis","Bone-Marrow_c-kit","Bone-Marrow","Kidney","Embryonic-Stem-Cell","MammaryGland.Lactation","Testis","Fetal_Lung","Peripheral_Blood","Fetal_Stomache","Neonatal-Skin","Fetal_Brain","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Fetal_Lung","Pancreas","Embryonic-Stem-Cell","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Thymus","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Rib","Testis","Trophoblast-Stem-Cell","Uterus","Neonatal-Skin","Mesenchymal-Stem-Cell-Cultured","Thymus","Small-Intestine","Kidney","Brain","Fetal_Lung","Trophoblast-Stem-Cell","Small-Intestine","Kidney","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Kidney","Trophoblast-Stem-Cell","Liver","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","MammaryGland.Virgin","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow_c-kit","Bone-Marrow","Kidney","Liver","Stomach","Bone-Marrow_c-kit","Small-Intestine","MammaryGland.Lactation","Neonatal-Rib","Uterus","Trophoblast-Stem-Cell","MammaryGland.Involution","Brain","Fetal_Lung","Neonatal-Muscle","Trophoblast-Stem-Cell","Placenta","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Bone-Marrow_c-kit","Uterus","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Prostate","Testis","MammaryGland.Pregnancy","Fetal_Brain","Neonatal-Skin","Embryonic-Stem-Cell","Peripheral_Blood","MammaryGland.Virgin","Kidney","Trophoblast-Stem-Cell","Kidney","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Brain","MammaryGland.Lactation","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone-Marrow","Uterus","Peripheral_Blood","Liver","Mesenchymal-Stem-Cell-Cultured","Neonatal-Heart","Bone-Marrow","Neonatal-Calvaria","Neonatal-Skin","Liver","Mesenchymal-Stem-Cell-Cultured","Embryonic-Mesenchyme","Liver","Mesenchymal-Stem-Cell-Cultured","Kidney","Trophoblast-Stem-Cell","Testis","Neonatal-Rib","Lung","Thymus","Liver","Trophoblast-Stem-Cell","Placenta","Fetal_Stomache","Trophoblast-Stem-Cell","Fetal_Stomache","Peripheral_Blood","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Small-Intestine","MammaryGland.Virgin","Neonatal-Rib","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","MammaryGland.Lactation","Thymus","Mesenchymal-Stem-Cell-Cultured","Pancreas","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Ovary","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Peripheral_Blood","MammaryGland.Virgin","Neonatal-Rib","Liver","Ovary","MammaryGland.Lactation","Liver","MammaryGland.Lactation","Peripheral_Blood","Neonatal-Muscle","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Fetal_Intestine","Kidney","Bone_Marrow_Mesenchyme","Small-Intestine","Neonatal-Skin","Spleen","Trophoblast-Stem-Cell","Neonatal-Heart","Lung","Lung","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Fetal-Liver","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Heart","MammaryGland.Lactation","Bone-Marrow_c-kit","Neonatal-Calvaria","Stomach","Neonatal-Heart","Stomach","Liver","Pancreas","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Testis","MammaryGland.Pregnancy","Fetal_Brain","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bladder","Liver","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Fetal_Lung","Bone-Marrow","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Kidney","Thymus","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Kidney","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Lung","Neonatal-Rib","Brain","Trophoblast-Stem-Cell","Fetal_Brain","Small-Intestine","MammaryGland.Lactation","Kidney","Thymus","Neonatal-Skin","Bone-Marrow","Neonatal-Muscle","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Lung","Stomach","Lung","MammaryGland.Virgin","Trophoblast-Stem-Cell","Small-Intestine","Ovary","Bone-Marrow_c-kit","Lung","Peripheral_Blood","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Thymus","Bladder","Ovary","Neonatal-Muscle","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Liver","Fetal_Lung","Neonatal-Skin","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Fetal_Intestine","MammaryGland.Virgin","Neonatal-Muscle","Testis","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow","Testis","Lung","Bone-Marrow","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Placenta","Neonatal-Muscle","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Neonatal-Heart","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Fetal_Intestine","Neonatal-Heart","Peripheral_Blood","MammaryGland.Virgin","Testis","Fetal_Lung","Fetal_Intestine","Thymus","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Brain","Kidney","Bone-Marrow","Trophoblast-Stem-Cell","MammaryGland.Virgin","Embryonic-Stem-Cell","Neonatal-Rib","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Lung","Trophoblast-Stem-Cell","Small-Intestine","Placenta","Bone-Marrow_c-kit","Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Virgin","Fetal_Intestine","Brain","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Prostate","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bone-Marrow_c-kit","Lung","Kidney","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Neonatal-Heart","Thymus","MammaryGland.Involution","MammaryGland.Lactation","Neonatal-Heart","Testis","Fetal_Brain","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Kidney","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bladder","Fetal_Stomache","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Fetal_Lung","Lung","Neonatal-Muscle","Prostate","Brain","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone-Marrow","Fetal-Liver","MammaryGland.Virgin","Stomach","Bone_Marrow_Mesenchyme","Peripheral_Blood","Fetal-Liver","Small-Intestine","Testis","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","MammaryGland.Virgin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","MammaryGland.Lactation","Thymus","Testis","Trophoblast-Stem-Cell","Liver","Embryonic-Stem-Cell","Lung","Peripheral_Blood","Embryonic-Mesenchyme","Lung","Uterus","Neonatal-Rib","Neonatal-Muscle","Thymus","Muscle","Liver","Testis","Uterus","Fetal_Stomache","MammaryGland.Lactation","MammaryGland.Virgin","Bone-Marrow","MammaryGland.Lactation","Neonatal-Rib","Trophoblast-Stem-Cell","Fetal_Lung","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Uterus","Testis","Fetal_Intestine","Brain","MammaryGland.Lactation","Bone-Marrow","Stomach","Bone-Marrow_c-kit","Testis","Mesenchymal-Stem-Cell-Cultured","Liver","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Testis","Bone-Marrow_c-kit","Muscle","MammaryGland.Lactation","Bone-Marrow_c-kit","MammaryGland.Virgin","Ovary","Mesenchymal-Stem-Cell-Cultured","Neonatal-Skin","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Fetal_Lung","Embryonic-Mesenchyme","Fetal_Lung","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Testis","Peripheral_Blood","Neonatal-Muscle","Fetal_Lung","Pancreas","Neonatal-Rib","Bone_Marrow_Mesenchyme","Bone-Marrow","MammaryGland.Involution","Fetal_Intestine","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal_Brain","Testis","Bone-Marrow","Testis","Trophoblast-Stem-Cell","Neonatal-Heart","Lung","Neonatal-Rib","Bone-Marrow","Bone-Marrow","Fetal_Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Lung","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","Bone-Marrow_c-kit","MammaryGland.Virgin","Bladder","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Bone-Marrow","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Testis","Fetal_Lung","Testis","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Testis","Ovary","Brain","Bladder","Neonatal-Muscle","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Brain","Small-Intestine","Kidney","Neonatal-Skin","Peripheral_Blood","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Testis","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Prostate","Embryonic-Stem-Cell","Placenta","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Prostate","Bone-Marrow_c-kit","Neonatal-Heart","Spleen","Fetal_Stomache","Trophoblast-Stem-Cell","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Liver","Neonatal-Calvaria","Peripheral_Blood","Bone_Marrow_Mesenchyme","Bladder","MammaryGland.Lactation","Fetal_Lung","MammaryGland.Virgin","Liver","Stomach","Brain","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Trophoblast-Stem-Cell","MammaryGland.Lactation","Trophoblast-Stem-Cell","Fetal_Stomache","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Brain","Uterus","Bone-Marrow","MammaryGland.Virgin","Trophoblast-Stem-Cell","Lung","Spleen","Kidney","MammaryGland.Lactation","Neonatal-Rib","Placenta","Trophoblast-Stem-Cell","Neonatal-Muscle","Neonatal-Muscle","MammaryGland.Virgin","Fetal_Lung","Bone-Marrow_c-kit","Peripheral_Blood","Fetal_Brain","Neonatal-Rib","Neonatal-Skin","Bone-Marrow_c-kit","Small-Intestine","Fetal_Brain","Trophoblast-Stem-Cell","Small-Intestine","MammaryGland.Lactation","Lung","Bone-Marrow_c-kit","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Lactation","Lung","Brain","Neonatal-Rib","Lung","Neonatal-Rib","Small-Intestine","MammaryGland.Pregnancy","Thymus","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Liver","Fetal_Stomache","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow","Trophoblast-Stem-Cell","Neonatal-Skin","Testis","Neonatal-Skin","Bone-Marrow_c-kit","Neonatal-Skin","Fetal-Liver","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow","Bone-Marrow","Testis","Neonatal-Rib","Neonatal-Calvaria","Ovary","Kidney","Bone-Marrow_c-kit","Ovary","Neonatal-Muscle","Neonatal-Muscle","Trophoblast-Stem-Cell","MammaryGland.Virgin","Neonatal-Calvaria","Neonatal-Muscle","Thymus","Bone-Marrow_c-kit","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Pancreas","Embryonic-Stem-Cell","Fetal_Brain","Fetal_Stomache","Neonatal-Calvaria","Peripheral_Blood","Kidney","Kidney","Trophoblast-Stem-Cell","Lung","Fetal_Stomache","Embryonic-Mesenchyme","Testis","Fetal_Lung","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Neonatal-Heart","Embryonic-Stem-Cell","Pancreas","Fetal_Stomache","Neonatal-Muscle","Bone-Marrow","Neonatal-Calvaria","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","MammaryGland.Virgin","Uterus","Testis","Bone-Marrow_c-kit","MammaryGland.Involution","Testis","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Testis","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Lung","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow","MammaryGland.Virgin","Fetal_Brain","Peripheral_Blood","Placenta","Small-Intestine","Bone-Marrow_c-kit","Fetal_Stomache","Neonatal-Skin","Bone-Marrow_c-kit","Small-Intestine","Trophoblast-Stem-Cell","Fetal_Lung","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Brain","Trophoblast-Stem-Cell","Fetal_Intestine","Bone_Marrow_Mesenchyme","Uterus","Ovary","Peripheral_Blood","Bone-Marrow_c-kit","Liver","Lung","Uterus","Bone-Marrow","MammaryGland.Lactation","MammaryGland.Involution","Neonatal-Calvaria","Bone-Marrow_c-kit","Fetal_Stomache","MammaryGland.Lactation","Fetal_Intestine","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Testis","Pancreas","Neonatal-Calvaria","Testis","Neonatal-Muscle","Neonatal-Calvaria","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Uterus","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Thymus","Testis","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Liver","Testis","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Placenta","Thymus","Uterus","Bone-Marrow","MammaryGland.Lactation","Ovary","Peripheral_Blood","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Small-Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow","Fetal_Lung","Bone-Marrow_c-kit","Testis","MammaryGland.Involution","MammaryGland.Virgin","Fetal_Intestine","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Spleen","Trophoblast-Stem-Cell","Fetal-Liver","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Muscle","Trophoblast-Stem-Cell","Neonatal-Rib","Neonatal-Rib","Bone-Marrow_c-kit","Testis","Neonatal-Rib","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Neonatal-Rib","Kidney","Fetal_Intestine","Ovary","Neonatal-Rib","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Ovary","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bone-Marrow_c-kit","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Pancreas","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Kidney","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Liver","Thymus","Fetal_Lung","Fetal_Brain","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Lung","Fetal_Stomache","Prostate","Fetal_Stomache","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Peripheral_Blood","Fetal_Stomache","Bone-Marrow_c-kit","Pancreas","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Lung","Liver","Bone_Marrow_Mesenchyme","Peripheral_Blood","Bone-Marrow_c-kit","Neonatal-Calvaria","Neonatal-Heart","Fetal_Intestine","Ovary","Brain","Embryonic-Stem-Cell","Lung","Embryonic-Stem-Cell","Neonatal-Skin","Neonatal-Rib","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Muscle","Small-Intestine","Kidney","Bone-Marrow_c-kit","Liver","Testis","Liver","MammaryGland.Lactation","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Placenta","Bone-Marrow","Neonatal-Calvaria","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","MammaryGland.Involution","Thymus","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Virgin","MammaryGland.Virgin","Neonatal-Heart","Ovary","Thymus","Trophoblast-Stem-Cell","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Stomach","Brain","Bone-Marrow_c-kit","Prostate","Bone-Marrow_c-kit","Bladder","Bone-Marrow","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Testis","Fetal-Liver","Fetal_Lung","Fetal_Intestine","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Liver","Lung","MammaryGland.Virgin","Prostate","Fetal_Lung","Pancreas","Peripheral_Blood","Testis","Bone-Marrow_c-kit","Muscle","Brain","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Placenta","Uterus","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Liver","Bone_Marrow_Mesenchyme","Peripheral_Blood","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Embryonic-Mesenchyme","Neonatal-Muscle","Neonatal-Rib","Trophoblast-Stem-Cell","Peripheral_Blood","Small-Intestine","Testis","Bone-Marrow_c-kit","Lung","Neonatal-Calvaria","Fetal_Lung","Fetal_Lung","Bone-Marrow","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Liver","Fetal_Lung","MammaryGland.Virgin","Bone-Marrow","Lung","Testis","Bone-Marrow_c-kit","Brain","Peripheral_Blood","Embryonic-Stem-Cell","Neonatal-Muscle","Kidney","Neonatal-Rib","Thymus","Lung","MammaryGland.Virgin","Trophoblast-Stem-Cell","Neonatal-Skin","Thymus","Stomach","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Liver","Fetal_Intestine","Fetal_Lung","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Virgin","Bone-Marrow","MammaryGland.Involution","Testis","Bone_Marrow_Mesenchyme","Uterus","Pancreas","MammaryGland.Lactation","Lung","Small-Intestine","Fetal_Intestine","Bone-Marrow_c-kit","MammaryGland.Pregnancy","MammaryGland.Involution","Fetal_Brain","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Small-Intestine","Testis","Fetal_Intestine","Embryonic-Stem-Cell","Neonatal-Rib","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Muscle","Neonatal-Skin","Thymus","Neonatal-Rib","Bone_Marrow_Mesenchyme","Lung","Neonatal-Rib","Bone_Marrow_Mesenchyme","Liver","Testis","Small-Intestine","Brain","MammaryGland.Lactation","MammaryGland.Virgin","Ovary","Bone-Marrow_c-kit","Embryonic-Stem-Cell","MammaryGland.Lactation","MammaryGland.Lactation","Liver","Bone_Marrow_Mesenchyme","MammaryGland.Involution","Bone-Marrow_c-kit","Testis","Lung","Thymus","Small-Intestine","Trophoblast-Stem-Cell","Neonatal-Calvaria","Small-Intestine","Small-Intestine","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Fetal_Lung","Stomach","Bone-Marrow","MammaryGland.Lactation","Neonatal-Calvaria","Bone-Marrow_c-kit","Ovary","Peripheral_Blood","Bone-Marrow_c-kit","Thymus","Embryonic-Stem-Cell","Kidney","Lung","Pancreas","Neonatal-Skin","Lung","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Bone-Marrow_c-kit","Fetal_Stomache","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Lung","Kidney","Ovary","Placenta","Bone-Marrow_c-kit","Embryonic-Mesenchyme","MammaryGland.Pregnancy","Uterus","MammaryGland.Pregnancy","Ovary","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Heart","Brain","Bone_Marrow_Mesenchyme","Neonatal-Heart","Uterus","Neonatal-Skin","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Kidney","MammaryGland.Pregnancy","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone-Marrow","Testis","Pancreas","Small-Intestine","Thymus","MammaryGland.Pregnancy","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Liver","Thymus","MammaryGland.Lactation","Lung","Trophoblast-Stem-Cell","Fetal_Brain","Bone-Marrow_c-kit","Peripheral_Blood","Ovary","Fetal_Lung","MammaryGland.Virgin","Fetal_Intestine","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Lung","Uterus","Bone-Marrow_c-kit","Small-Intestine","Trophoblast-Stem-Cell","Neonatal-Rib","Trophoblast-Stem-Cell","MammaryGland.Virgin","Testis","Brain","Fetal_Brain","Fetal_Lung","Small-Intestine","Testis","Kidney","Peripheral_Blood","Bone-Marrow","Bone_Marrow_Mesenchyme","Neonatal-Skin","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Kidney","MammaryGland.Lactation","Fetal_Brain","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Muscle","Bone-Marrow_c-kit","Liver","Neonatal-Calvaria","MammaryGland.Lactation","Trophoblast-Stem-Cell","Placenta","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Prostate","MammaryGland.Involution","Fetal_Brain","Fetal_Stomache","Fetal_Stomache","Small-Intestine","Neonatal-Calvaria","Bone-Marrow_c-kit","Lung","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Neonatal-Heart","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone-Marrow_c-kit","Testis","Fetal_Intestine","Neonatal-Calvaria","Brain","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Brain","Fetal_Intestine","Fetal_Intestine","MammaryGland.Pregnancy","Pancreas","Neonatal-Calvaria","Trophoblast-Stem-Cell","Testis","Neonatal-Muscle","Neonatal-Heart","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bladder","Neonatal-Muscle","Stomach","Peripheral_Blood","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","Neonatal-Muscle","Lung","MammaryGland.Virgin","Neonatal-Muscle","Embryonic-Mesenchyme","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Stomach","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Embryonic-Stem-Cell","MammaryGland.Involution","Bone-Marrow_c-kit","Neonatal-Calvaria","Embryonic-Mesenchyme","MammaryGland.Lactation","Bone-Marrow","Bone-Marrow_c-kit","Neonatal-Calvaria","Neonatal-Rib","Fetal_Intestine","Neonatal-Calvaria","Liver","Testis","Ovary","Bone-Marrow_c-kit","Testis","Fetal_Lung","Bladder","Bladder","Neonatal-Calvaria","Neonatal-Calvaria","Lung","Brain","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Small-Intestine","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Virgin","Brain","Mesenchymal-Stem-Cell-Cultured","Pancreas","Uterus","Peripheral_Blood","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Fetal_Intestine","Testis","Neonatal-Calvaria","Peripheral_Blood","Bone-Marrow_c-kit","Thymus","Fetal_Lung","Neonatal-Calvaria","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Rib","Bone-Marrow","Embryonic-Stem-Cell","Neonatal-Muscle","Uterus","Liver","Trophoblast-Stem-Cell","Neonatal-Rib","Trophoblast-Stem-Cell","Testis","Neonatal-Muscle","Trophoblast-Stem-Cell","Testis","Fetal-Liver","Fetal_Brain","Stomach","MammaryGland.Involution","Trophoblast-Stem-Cell","Neonatal-Muscle","MammaryGland.Virgin","Stomach","Fetal_Lung","Neonatal-Calvaria","Placenta","MammaryGland.Involution","Bone-Marrow","Testis","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Prostate","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Testis","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Trophoblast-Stem-Cell","Testis","Bone-Marrow_c-kit","MammaryGland.Lactation","Pancreas","Pancreas","Fetal_Brain","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","MammaryGland.Involution","MammaryGland.Pregnancy","Fetal_Intestine","Fetal_Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Ovary","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Lactation","MammaryGland.Virgin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Stomach","Trophoblast-Stem-Cell","Fetal-Liver","Peripheral_Blood","MammaryGland.Virgin","Neonatal-Rib","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Rib","Embryonic-Stem-Cell","Pancreas","Pancreas","Thymus","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Kidney","Bone-Marrow","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Intestine","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Virgin","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Small-Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow","Liver","Neonatal-Skin","Peripheral_Blood","Uterus","Uterus","Fetal_Brain","Small-Intestine","Placenta","Neonatal-Skin","Neonatal-Muscle","Bone-Marrow_c-kit","Liver","Mesenchymal-Stem-Cell-Cultured","Brain","Neonatal-Skin","Fetal_Lung","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Uterus","Embryonic-Stem-Cell","Spleen","Bone-Marrow","Thymus","Fetal_Stomache","Liver","Embryonic-Stem-Cell","Lung","Stomach","Peripheral_Blood","Ovary","Trophoblast-Stem-Cell","Testis","Bone-Marrow_c-kit","Kidney","Peripheral_Blood","Neonatal-Muscle","Kidney","Small-Intestine","Neonatal-Heart","Bone_Marrow_Mesenchyme","Neonatal-Rib","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Pancreas","Small-Intestine","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","Kidney","Embryonic-Stem-Cell","Thymus","Fetal_Intestine","Bone-Marrow_c-kit","Testis","Brain","Neonatal-Calvaria","Testis","Bone-Marrow_c-kit","Kidney","Fetal_Brain","Bone-Marrow_c-kit","MammaryGland.Virgin","Liver","Bone-Marrow_c-kit","Bone-Marrow","Muscle","Brain","Neonatal-Heart","Trophoblast-Stem-Cell","MammaryGland.Involution","Muscle","Peripheral_Blood","Liver","Bone-Marrow","Brain","Peripheral_Blood","Bone_Marrow_Mesenchyme","Bladder","Liver","Bone_Marrow_Mesenchyme","Testis","Bone-Marrow_c-kit","Lung","Trophoblast-Stem-Cell","Neonatal-Calvaria","Liver","MammaryGland.Virgin","Kidney","Bone-Marrow_c-kit","Kidney","MammaryGland.Lactation","Muscle","Mesenchymal-Stem-Cell-Cultured","Spleen","Bladder","Ovary","MammaryGland.Virgin","Fetal-Liver","MammaryGland.Virgin","Fetal_Lung","Small-Intestine","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Bone-Marrow_c-kit","Pancreas","Bladder","Kidney","MammaryGland.Lactation","Bone-Marrow","Prostate","Fetal_Intestine","MammaryGland.Virgin","Spleen","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Stomach","Embryonic-Stem-Cell","Neonatal-Calvaria","Ovary","MammaryGland.Involution","Bone-Marrow_c-kit","Testis","Pancreas","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Brain","Bone-Marrow","Trophoblast-Stem-Cell","Neonatal-Muscle","Stomach","MammaryGland.Lactation","Neonatal-Rib","MammaryGland.Virgin","Bladder","Bone-Marrow_c-kit","Spleen","Fetal_Lung","Ovary","MammaryGland.Lactation","Bone-Marrow","Neonatal-Skin","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Fetal_Lung","Kidney","Bone-Marrow_c-kit","Fetal_Intestine","Kidney","Thymus","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","MammaryGland.Involution","Small-Intestine","Testis","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Lung","Peripheral_Blood","Lung","Neonatal-Heart","Bone-Marrow","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Uterus","Brain","Fetal-Liver","Bone-Marrow_c-kit","Fetal_Stomache","Bone_Marrow_Mesenchyme","Spleen","Testis","Fetal_Stomache","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Testis","MammaryGland.Lactation","Testis","Embryonic-Stem-Cell","Pancreas","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Peripheral_Blood","Testis","MammaryGland.Lactation","Fetal_Intestine","MammaryGland.Pregnancy","Peripheral_Blood","Thymus","MammaryGland.Virgin","Neonatal-Rib","Thymus","Testis","Liver","Thymus","Bone-Marrow_c-kit","Lung","Fetal_Brain","Testis","Thymus","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Pancreas","Trophoblast-Stem-Cell","Fetal_Lung","Spleen","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Muscle","Trophoblast-Stem-Cell","Fetal_Brain","Fetal_Brain","Ovary","Thymus","Bone-Marrow_c-kit","Fetal_Intestine","Uterus","Trophoblast-Stem-Cell","Kidney","Fetal_Brain","Embryonic-Stem-Cell","Testis","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Neonatal-Calvaria","MammaryGland.Involution","MammaryGland.Lactation","Trophoblast-Stem-Cell","Neonatal-Skin","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Bladder","Trophoblast-Stem-Cell","Testis","Bone-Marrow_c-kit","Neonatal-Calvaria","Pancreas","Testis","Neonatal-Heart","Bone-Marrow","MammaryGland.Involution","Fetal_Stomache","Embryonic-Mesenchyme","Bone-Marrow","Fetal_Brain","Bone-Marrow_c-kit","Neonatal-Skin","Mesenchymal-Stem-Cell-Cultured","Testis","Bone-Marrow_c-kit","Fetal_Stomache","Trophoblast-Stem-Cell","Neonatal-Muscle","Fetal_Lung","Pancreas","Ovary","Uterus","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Intestine","Neonatal-Skin","Testis","Spleen","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Fetal_Brain","Testis","Embryonic-Stem-Cell","Pancreas","Ovary","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Uterus","Fetal_Stomache","Trophoblast-Stem-Cell","Prostate","MammaryGland.Lactation","Lung","Liver","MammaryGland.Lactation","Bone-Marrow_c-kit","Neonatal-Heart","Testis","MammaryGland.Involution","Uterus","Uterus","MammaryGland.Lactation","Neonatal-Heart","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Muscle","Testis","Brain","MammaryGland.Pregnancy","Fetal_Intestine","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Fetal_Brain","Fetal_Intestine","Embryonic-Stem-Cell","Peripheral_Blood","MammaryGland.Virgin","Fetal_Intestine","Fetal-Liver","Small-Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal-Liver","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Pancreas","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Fetal_Lung","Trophoblast-Stem-Cell","Lung","MammaryGland.Lactation","Bone-Marrow","Neonatal-Muscle","Embryonic-Stem-Cell","MammaryGland.Virgin","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Small-Intestine","Bone_Marrow_Mesenchyme","Pancreas","Testis","Uterus","Kidney","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Stomach","Uterus","Brain","MammaryGland.Lactation","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Lung","Embryonic-Stem-Cell","Uterus","Testis","Stomach","Uterus","Testis","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Thymus","Fetal_Intestine","Neonatal-Heart","Fetal_Intestine","MammaryGland.Virgin","Bladder","Fetal_Lung","Fetal_Intestine","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Small-Intestine","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Bone-Marrow","Embryonic-Stem-Cell","Fetal_Intestine","Uterus","Trophoblast-Stem-Cell","Brain","Testis","Kidney","MammaryGland.Lactation","Pancreas","Trophoblast-Stem-Cell","Kidney","Placenta","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Fetal-Liver","Neonatal-Heart","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Fetal_Lung","Peripheral_Blood","Thymus","MammaryGland.Pregnancy","Ovary","MammaryGland.Virgin","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Calvaria","Fetal_Intestine","Neonatal-Muscle","Peripheral_Blood","Prostate","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Peripheral_Blood","Neonatal-Heart","Fetal_Stomache","Neonatal-Rib","Testis","MammaryGland.Lactation","Bone-Marrow_c-kit","Brain","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Placenta","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Lung","Fetal_Lung","Bone-Marrow","Pancreas","Fetal_Lung","Spleen","Neonatal-Heart","MammaryGland.Lactation","Bone-Marrow_c-kit","Liver","Ovary","MammaryGland.Lactation","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Muscle","Ovary","Trophoblast-Stem-Cell","Testis","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bone-Marrow_c-kit","MammaryGland.Virgin","Bone-Marrow","Neonatal-Muscle","Embryonic-Stem-Cell","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Thymus","Embryonic-Stem-Cell","Testis","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Stomach","Liver","Fetal_Lung","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Lung","MammaryGland.Lactation","MammaryGland.Lactation","Fetal_Stomache","Bone-Marrow_c-kit","MammaryGland.Lactation","MammaryGland.Virgin","Kidney","Bone-Marrow_c-kit","Bone-Marrow","Bone-Marrow_c-kit","Fetal_Stomache","Muscle","Bone-Marrow_c-kit","Bone-Marrow","Testis","Bone-Marrow","Fetal_Intestine","Ovary","Neonatal-Heart","MammaryGland.Involution","MammaryGland.Involution","Muscle","Neonatal-Rib","Brain","Neonatal-Calvaria","Thymus","Bone-Marrow_c-kit","Fetal_Intestine","Fetal_Lung","Small-Intestine","Prostate","Bone-Marrow","Bone_Marrow_Mesenchyme","Uterus","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Testis","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Testis","Bone-Marrow_c-kit","Fetal-Liver","Embryonic-Stem-Cell","Kidney","Uterus","MammaryGland.Pregnancy","Bone-Marrow","Fetal-Liver","Fetal_Stomache","Neonatal-Skin","Neonatal-Calvaria","Placenta","Trophoblast-Stem-Cell","Neonatal-Muscle","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Virgin","Liver","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Involution","Testis","Trophoblast-Stem-Cell","Testis","MammaryGland.Pregnancy","Neonatal-Rib","Pancreas","Embryonic-Stem-Cell","Fetal_Stomache","Fetal_Stomache","Bone-Marrow","Neonatal-Heart","Liver","Neonatal-Muscle","Trophoblast-Stem-Cell","Kidney","Neonatal-Muscle","Fetal-Liver","Uterus","Neonatal-Skin","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow_c-kit","Peripheral_Blood","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Neonatal-Calvaria","Small-Intestine","Thymus","Bone-Marrow_c-kit","Fetal_Lung","MammaryGland.Involution","Trophoblast-Stem-Cell","Testis","MammaryGland.Lactation","Lung","Mesenchymal-Stem-Cell-Cultured","Neonatal-Heart","Fetal_Intestine","Testis","MammaryGland.Lactation","MammaryGland.Lactation","Fetal_Lung","Fetal-Liver","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Virgin","Testis","MammaryGland.Lactation","Neonatal-Muscle","Fetal_Lung","Bone-Marrow","Brain","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","MammaryGland.Lactation","Embryonic-Mesenchyme","Neonatal-Calvaria","Bone-Marrow","Testis","Trophoblast-Stem-Cell","Neonatal-Rib","Fetal-Liver","Bone-Marrow_c-kit","Peripheral_Blood","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Lung","Bone-Marrow_c-kit","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","Lung","Uterus","Prostate","Bone-Marrow_c-kit","Neonatal-Muscle","Ovary","Trophoblast-Stem-Cell","Bone-Marrow","Lung","Kidney","Neonatal-Muscle","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Trophoblast-Stem-Cell","Neonatal-Skin","Small-Intestine","Bone_Marrow_Mesenchyme","Lung","Peripheral_Blood","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Testis","MammaryGland.Virgin","Neonatal-Calvaria","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Testis","Bone-Marrow","Brain","MammaryGland.Involution","Embryonic-Stem-Cell","Neonatal-Muscle","Bladder","Fetal_Intestine","Fetal_Lung","Neonatal-Muscle","Fetal_Lung","Testis","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Uterus","Bone-Marrow","Trophoblast-Stem-Cell","Bladder","MammaryGland.Virgin","Testis","Testis","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","MammaryGland.Lactation","Liver","Neonatal-Skin","Fetal_Stomache","MammaryGland.Involution","Neonatal-Muscle","Placenta","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Fetal_Intestine","Fetal_Lung","Fetal_Intestine","Testis","Neonatal-Muscle","Neonatal-Muscle","Brain","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Brain","Lung","Lung","MammaryGland.Lactation","Bone-Marrow_c-kit","Lung","Fetal_Brain","MammaryGland.Involution","MammaryGland.Involution","Brain","Bone-Marrow","Liver","MammaryGland.Pregnancy","Fetal_Intestine","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Muscle","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Calvaria","Bone-Marrow","Trophoblast-Stem-Cell","Bladder","Embryonic-Mesenchyme","Neonatal-Calvaria","Peripheral_Blood","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Lung","MammaryGland.Virgin","MammaryGland.Virgin","Bone-Marrow_c-kit","MammaryGland.Virgin","Prostate","MammaryGland.Lactation","Fetal_Brain","Bone-Marrow_c-kit","Neonatal-Calvaria","Fetal_Brain","Stomach","Kidney","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow","Ovary","Embryonic-Stem-Cell","MammaryGland.Lactation","Fetal_Lung","Fetal_Lung","Trophoblast-Stem-Cell","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Virgin","Fetal_Lung","Fetal_Intestine","Testis","Peripheral_Blood","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Fetal-Liver","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Lung","Liver","Trophoblast-Stem-Cell","Lung","MammaryGland.Pregnancy","Stomach","Placenta","Uterus","Trophoblast-Stem-Cell","Fetal_Intestine","MammaryGland.Lactation","Fetal_Intestine","Brain","Fetal_Stomache","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Fetal_Lung","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Intestine","Trophoblast-Stem-Cell","Testis","Peripheral_Blood","Neonatal-Rib","Testis","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Fetal_Lung","Embryonic-Stem-Cell","Kidney","Testis","Bone-Marrow","Fetal-Liver","Bone-Marrow_c-kit","Fetal_Intestine","Peripheral_Blood","Thymus","Stomach","Neonatal-Rib","Peripheral_Blood","Neonatal-Skin","Trophoblast-Stem-Cell","Uterus","MammaryGland.Involution","Testis","Fetal_Lung","Neonatal-Rib","Neonatal-Calvaria","Fetal_Intestine","Kidney","Bone-Marrow","Embryonic-Mesenchyme","Neonatal-Calvaria","Kidney","Bone-Marrow_c-kit","MammaryGland.Lactation","Thymus","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Liver","Mesenchymal-Stem-Cell-Cultured","Testis","Neonatal-Muscle","Testis","MammaryGland.Lactation","Kidney","MammaryGland.Lactation","Pancreas","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Testis","Bone-Marrow_c-kit","Bone-Marrow","Stomach","Fetal_Intestine","Bone-Marrow_c-kit","Spleen","Brain","Peripheral_Blood","MammaryGland.Lactation","Trophoblast-Stem-Cell","Ovary","Neonatal-Heart","Uterus","Bone-Marrow_c-kit","Fetal_Brain","Peripheral_Blood","Neonatal-Skin","Fetal_Intestine","Trophoblast-Stem-Cell","Brain","Small-Intestine","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","Liver","MammaryGland.Lactation","Bone-Marrow","MammaryGland.Lactation","Bone-Marrow_c-kit","Liver","Bone-Marrow_c-kit","Uterus","Neonatal-Muscle","Liver","Bone-Marrow","Bone-Marrow","MammaryGland.Pregnancy","Prostate","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow","Stomach","Fetal_Lung","Fetal_Intestine","MammaryGland.Lactation","MammaryGland.Pregnancy","MammaryGland.Virgin","Neonatal-Calvaria","Bladder","Fetal_Lung","Ovary","Fetal-Liver","Fetal_Brain","Peripheral_Blood","MammaryGland.Virgin","Thymus","Trophoblast-Stem-Cell","Fetal_Intestine","Spleen","Bone-Marrow_c-kit","Thymus","Neonatal-Calvaria","Bone-Marrow_c-kit","Neonatal-Skin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Peripheral_Blood","Liver","Pancreas","Trophoblast-Stem-Cell","Neonatal-Rib","Fetal_Lung","MammaryGland.Pregnancy","Neonatal-Muscle","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Testis","Small-Intestine","Brain","Fetal_Stomache","Bone-Marrow_c-kit","Fetal-Liver","Liver","Bone_Marrow_Mesenchyme","Lung","MammaryGland.Involution","Peripheral_Blood","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Neonatal-Skin","Fetal_Stomache","MammaryGland.Lactation","Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Peripheral_Blood","Fetal_Intestine","Small-Intestine","Stomach","Lung","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Peripheral_Blood","Fetal_Brain","Small-Intestine","Thymus","Bone-Marrow_c-kit","Testis","Bone-Marrow","Fetal_Brain","Fetal-Liver","MammaryGland.Involution","Small-Intestine","Fetal_Stomache","Bone-Marrow","Fetal_Brain","Bone-Marrow_c-kit","Fetal_Brain","Fetal_Stomache","Fetal_Intestine","Pancreas","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Lung","Uterus","Testis","Neonatal-Calvaria","Fetal_Stomache","Ovary","Fetal_Brain","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Fetal_Brain","MammaryGland.Lactation","Bone-Marrow","Fetal_Intestine","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Testis","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Bone-Marrow","Lung","Fetal_Intestine","Neonatal-Heart","Fetal_Intestine","Testis","Mesenchymal-Stem-Cell-Cultured","Neonatal-Heart","Trophoblast-Stem-Cell","Brain","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Uterus","Bone_Marrow_Mesenchyme","Ovary","Embryonic-Stem-Cell","Bone-Marrow","Uterus","Testis","Neonatal-Rib","Fetal_Lung","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Lung","Fetal_Intestine","Small-Intestine","Peripheral_Blood","Peripheral_Blood","Fetal_Stomache","Bone-Marrow_c-kit","Neonatal-Skin","MammaryGland.Lactation","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Ovary","Neonatal-Heart","Embryonic-Stem-Cell","Neonatal-Muscle","Fetal_Brain","Testis","Liver","Neonatal-Skin","Small-Intestine","MammaryGland.Lactation","Bone-Marrow_c-kit","Neonatal-Rib","Peripheral_Blood","Testis","Trophoblast-Stem-Cell","Peripheral_Blood","Trophoblast-Stem-Cell","Lung","Fetal_Intestine","Neonatal-Calvaria","Fetal_Stomache","Bone_Marrow_Mesenchyme","Brain","MammaryGland.Virgin","MammaryGland.Pregnancy","Fetal-Liver","Fetal_Lung","Fetal_Stomache","Bone-Marrow","MammaryGland.Involution","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow","Fetal_Stomache","Bone-Marrow","Small-Intestine","Neonatal-Skin","Placenta","Bladder","Neonatal-Calvaria","Trophoblast-Stem-Cell","Testis","Embryonic-Mesenchyme","Bone-Marrow","Bone_Marrow_Mesenchyme","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Placenta","Fetal_Intestine","Embryonic-Stem-Cell","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Kidney","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","Liver","Peripheral_Blood","Neonatal-Calvaria","Lung","Bladder","Fetal_Stomache","Ovary","Fetal_Intestine","Liver","Bone-Marrow_c-kit","Testis","Neonatal-Muscle","Small-Intestine","Embryonic-Stem-Cell","Fetal_Stomache","Fetal_Brain","Trophoblast-Stem-Cell","Fetal_Stomache","Neonatal-Calvaria","Placenta","Neonatal-Skin","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Calvaria","Stomach","MammaryGland.Lactation","Neonatal-Muscle","Neonatal-Heart","Bone-Marrow_c-kit","Bone-Marrow","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Testis","Bladder","Bone-Marrow_c-kit","Testis","Bone-Marrow","Testis","Embryonic-Stem-Cell","Liver","Testis","Peripheral_Blood","Bone-Marrow_c-kit","Pancreas","Lung","Stomach","Fetal-Liver","Neonatal-Muscle","Thymus","Small-Intestine","Bone-Marrow","Neonatal-Rib","Placenta","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Fetal-Liver","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","MammaryGland.Pregnancy","Neonatal-Calvaria","Small-Intestine","Small-Intestine","Uterus","MammaryGland.Lactation","MammaryGland.Lactation","Small-Intestine","Trophoblast-Stem-Cell","Lung","Trophoblast-Stem-Cell","Neonatal-Muscle","Bladder","Muscle","MammaryGland.Lactation","Testis","Neonatal-Calvaria","Neonatal-Muscle","MammaryGland.Lactation","Neonatal-Calvaria","Trophoblast-Stem-Cell","Neonatal-Heart","MammaryGland.Lactation","Uterus","Placenta","Neonatal-Calvaria","Liver","Fetal_Intestine","Thymus","MammaryGland.Involution","Fetal_Intestine","Testis","Bone-Marrow","Neonatal-Rib","Testis","Small-Intestine","Pancreas","Fetal_Brain","Bone-Marrow_c-kit","Small-Intestine","Embryonic-Mesenchyme","Bone-Marrow","Placenta","Neonatal-Skin","Bladder","Brain","Spleen","Thymus","Pancreas","Bladder","Small-Intestine","Small-Intestine","Fetal_Intestine","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Placenta","MammaryGland.Involution","Small-Intestine","Fetal-Liver","Neonatal-Calvaria","Ovary","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Lung","Fetal_Stomache","MammaryGland.Lactation","Stomach","Neonatal-Muscle","Testis","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Bone-Marrow","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Placenta","Neonatal-Muscle","Small-Intestine","MammaryGland.Lactation","Bone-Marrow_c-kit","Lung","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Neonatal-Heart","MammaryGland.Involution","Peripheral_Blood","Trophoblast-Stem-Cell","Ovary","Bone-Marrow_c-kit","Fetal_Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Ovary","Bone-Marrow_c-kit","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Neonatal-Rib","Neonatal-Calvaria","Fetal_Lung","MammaryGland.Lactation","Prostate","MammaryGland.Pregnancy","Pancreas","Lung","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","MammaryGland.Virgin","Neonatal-Calvaria","Kidney","MammaryGland.Lactation","Neonatal-Calvaria","Neonatal-Rib","Bone-Marrow_c-kit","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Brain","Embryonic-Stem-Cell","Neonatal-Rib","MammaryGland.Involution","Bone-Marrow","Brain","Bone-Marrow","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Small-Intestine","Liver","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Kidney","Pancreas","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","MammaryGland.Involution","Trophoblast-Stem-Cell","Neonatal-Muscle","Trophoblast-Stem-Cell","Testis","Bone_Marrow_Mesenchyme","Fetal_Intestine","Testis","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Testis","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Small-Intestine","Trophoblast-Stem-Cell","Spleen","Peripheral_Blood","Prostate","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Placenta","Bone-Marrow_c-kit","Prostate","MammaryGland.Lactation","Testis","Neonatal-Heart","Bone-Marrow_c-kit","Fetal_Intestine","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Ovary","Neonatal-Heart","Prostate","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Spleen","Fetal-Liver","Placenta","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Testis","Lung","Kidney","Peripheral_Blood","Small-Intestine","Stomach","Testis","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Placenta","Fetal_Stomache","Neonatal-Skin","Kidney","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Peripheral_Blood","Muscle","MammaryGland.Lactation","MammaryGland.Lactation","Peripheral_Blood","Small-Intestine","MammaryGland.Virgin","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Neonatal-Rib","Embryonic-Stem-Cell","Testis","Fetal_Stomache","Bone_Marrow_Mesenchyme","Fetal_Intestine","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Thymus","Fetal_Intestine","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","MammaryGland.Involution","Neonatal-Skin","Bone-Marrow","Peripheral_Blood","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Fetal_Stomache","Peripheral_Blood","Fetal_Stomache","MammaryGland.Pregnancy","Testis","Bone-Marrow_c-kit","Fetal_Lung","MammaryGland.Virgin","Testis","Fetal_Intestine","Bone_Marrow_Mesenchyme","Brain","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Peripheral_Blood","Bone-Marrow_c-kit","Neonatal-Heart","Thymus","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Testis","Fetal_Stomache","Testis","Trophoblast-Stem-Cell","Bone-Marrow","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Thymus","Fetal_Lung","Neonatal-Heart","Neonatal-Rib","Bladder","MammaryGland.Virgin","Bladder","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow_c-kit","Testis","Lung","Placenta","Testis","Fetal_Intestine","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Lactation","Small-Intestine","Placenta","Prostate","Bone-Marrow_c-kit","Bone-Marrow","Lung","Neonatal-Calvaria","Fetal_Intestine","Thymus","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Testis","Bone-Marrow","Testis","Neonatal-Heart","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Placenta","Trophoblast-Stem-Cell","Fetal_Stomache","Neonatal-Rib","Bone-Marrow_c-kit","Lung","Embryonic-Stem-Cell","Neonatal-Heart","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Fetal_Stomache","Thymus","Neonatal-Rib","MammaryGland.Virgin","Pancreas","Neonatal-Skin","Bone-Marrow_c-kit","Embryonic-Mesenchyme","MammaryGland.Involution","Neonatal-Rib","Peripheral_Blood","Trophoblast-Stem-Cell","Lung","Testis","Neonatal-Rib","Bone-Marrow_c-kit","Neonatal-Muscle","Bone-Marrow","Prostate","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Placenta","MammaryGland.Virgin","Neonatal-Skin","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","MammaryGland.Virgin","Testis","Neonatal-Rib","Pancreas","Peripheral_Blood","Neonatal-Calvaria","Bladder","Stomach","Bone-Marrow_c-kit","Lung","Bone-Marrow_c-kit","Uterus","Lung","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","MammaryGland.Virgin","Uterus","Peripheral_Blood","Fetal_Intestine","Uterus","Lung","Fetal_Stomache","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Prostate","Embryonic-Stem-Cell","Neonatal-Rib","Testis","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Testis","MammaryGland.Lactation","Fetal_Intestine","Embryonic-Stem-Cell","Small-Intestine","Prostate","Neonatal-Rib","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Intestine","Bone-Marrow","Placenta","MammaryGland.Lactation","Trophoblast-Stem-Cell","Neonatal-Skin","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Neonatal-Calvaria","Neonatal-Calvaria","Fetal_Intestine","Testis","Trophoblast-Stem-Cell","Placenta","Neonatal-Muscle","Trophoblast-Stem-Cell","Placenta","Bone-Marrow","Bone-Marrow_c-kit","Neonatal-Muscle","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Pancreas","Bone-Marrow","Bone_Marrow_Mesenchyme","Kidney","Fetal_Brain","Neonatal-Rib","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Kidney","Small-Intestine","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Lung","Thymus","Kidney","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Thymus","Bladder","Thymus","Bone-Marrow","Pancreas","Bone-Marrow","Stomach","Fetal_Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Virgin","Bone-Marrow_c-kit","Spleen","Trophoblast-Stem-Cell","MammaryGland.Involution","Trophoblast-Stem-Cell","Neonatal-Rib","Brain","Trophoblast-Stem-Cell","Uterus","Bone-Marrow_c-kit","Lung","Ovary","Fetal_Stomache","Trophoblast-Stem-Cell","Testis","Kidney","Brain","MammaryGland.Lactation","Neonatal-Muscle","Trophoblast-Stem-Cell","MammaryGland.Lactation","Fetal-Liver","Fetal_Intestine","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Brain","Prostate","Placenta","Neonatal-Rib","Neonatal-Rib","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Thymus","Bone-Marrow_c-kit","Fetal-Liver","Liver","Testis","Testis","Neonatal-Calvaria","Trophoblast-Stem-Cell","Pancreas","MammaryGland.Lactation","Pancreas","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Testis","Fetal_Brain","Neonatal-Rib","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Testis","Embryonic-Stem-Cell","Peripheral_Blood","MammaryGland.Lactation","Neonatal-Skin","Liver","Prostate","Fetal_Stomache","Neonatal-Rib","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Ovary","MammaryGland.Virgin","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Muscle","MammaryGland.Virgin","Bone-Marrow_c-kit","Lung","MammaryGland.Lactation","Thymus","Neonatal-Rib","Testis","Lung","MammaryGland.Lactation","Spleen","Neonatal-Calvaria","MammaryGland.Pregnancy","Fetal_Brain","Bone-Marrow_c-kit","Neonatal-Muscle","Prostate","Stomach","Bone-Marrow_c-kit","Kidney","Liver","Fetal_Brain","Bone-Marrow_c-kit","MammaryGland.Lactation","Kidney","Bone-Marrow","Trophoblast-Stem-Cell","Thymus","Testis","Bone-Marrow_c-kit","Testis","MammaryGland.Lactation","Muscle","Neonatal-Skin","Small-Intestine","Fetal_Intestine","Bone-Marrow","Fetal_Lung","MammaryGland.Lactation","Brain","Testis","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Lung","Trophoblast-Stem-Cell","Fetal_Intestine","Trophoblast-Stem-Cell","Testis","Brain","Fetal_Lung","Trophoblast-Stem-Cell","Stomach","Fetal_Intestine","MammaryGland.Lactation","Fetal_Intestine","Fetal_Lung","Small-Intestine","Peripheral_Blood","Bone-Marrow","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Neonatal-Calvaria","Testis","Bone-Marrow","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Muscle","Brain","Pancreas","Neonatal-Rib","Testis","Bone-Marrow","Prostate","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Neonatal-Heart","Testis","Brain","Kidney","MammaryGland.Involution","Testis","Lung","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","MammaryGland.Lactation","Embryonic-Stem-Cell","Fetal-Liver","Fetal_Stomache","Testis","Peripheral_Blood","Neonatal-Skin","Pancreas","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Brain","Fetal_Intestine","Trophoblast-Stem-Cell","Neonatal-Muscle","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Placenta","Trophoblast-Stem-Cell","MammaryGland.Lactation","Lung","Lung","Bone-Marrow_c-kit","MammaryGland.Involution","Trophoblast-Stem-Cell","Kidney","Trophoblast-Stem-Cell","Peripheral_Blood","Kidney","Fetal_Stomache","Bone-Marrow_c-kit","Neonatal-Rib","Trophoblast-Stem-Cell","Fetal_Lung","Neonatal-Rib","Fetal_Lung","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Calvaria","Bone-Marrow_c-kit","Fetal_Lung","MammaryGland.Involution","Bone_Marrow_Mesenchyme","Lung","MammaryGland.Involution","Bladder","Bone-Marrow_c-kit","Neonatal-Heart","MammaryGland.Involution","Bone-Marrow_c-kit","Uterus","Bone-Marrow_c-kit","MammaryGland.Involution","Testis","Trophoblast-Stem-Cell","Testis","Ovary","Trophoblast-Stem-Cell","Peripheral_Blood","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow","Bone-Marrow_c-kit","Ovary","Small-Intestine","Embryonic-Stem-Cell","Brain","Neonatal-Rib","Ovary","Bone-Marrow_c-kit","MammaryGland.Lactation","Kidney","Bone-Marrow_c-kit","Bone-Marrow","Testis","Neonatal-Skin","Bone-Marrow_c-kit","Uterus","Brain","Fetal_Lung","Fetal_Stomache","Thymus","Prostate","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Liver","Neonatal-Calvaria","Fetal_Intestine","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Placenta","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Rib","MammaryGland.Lactation","MammaryGland.Virgin","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Ovary","Prostate","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Kidney","Fetal_Stomache","Embryonic-Stem-Cell","Placenta","Fetal_Lung","Fetal_Brain","Neonatal-Calvaria","Trophoblast-Stem-Cell","Bone-Marrow","Bone_Marrow_Mesenchyme","Peripheral_Blood","Bone-Marrow","Bone-Marrow","Neonatal-Skin","Bone-Marrow_c-kit","Pancreas","Testis","MammaryGland.Lactation","Bone-Marrow","Peripheral_Blood","Fetal_Brain","Trophoblast-Stem-Cell","Testis","Neonatal-Rib","Uterus","Fetal-Liver","Kidney","Brain","Bone-Marrow","Bone-Marrow","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Heart","Bone-Marrow","Bladder","Peripheral_Blood","Bone-Marrow_c-kit","Fetal_Stomache","Bone_Marrow_Mesenchyme","Testis","Placenta","Neonatal-Muscle","Embryonic-Stem-Cell","Kidney","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Lung","Brain","Bone-Marrow","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Fetal_Lung","Testis","MammaryGland.Lactation","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","MammaryGland.Lactation","Neonatal-Rib","Bladder","MammaryGland.Virgin","Peripheral_Blood","Fetal_Lung","Neonatal-Calvaria","Fetal_Brain","Fetal_Stomache","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Neonatal-Rib","Bone-Marrow","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","Bladder","Bone-Marrow_c-kit","Neonatal-Muscle","Bone-Marrow_c-kit","Thymus","Uterus","Brain","Neonatal-Calvaria","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Stomache","Trophoblast-Stem-Cell","Brain","Trophoblast-Stem-Cell","Fetal_Brain","Testis","Kidney","Muscle","Peripheral_Blood","MammaryGland.Pregnancy","MammaryGland.Pregnancy","Embryonic-Mesenchyme","Neonatal-Calvaria","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Neonatal-Muscle","Neonatal-Calvaria","Kidney","Spleen","Bone-Marrow_c-kit","Neonatal-Calvaria","MammaryGland.Lactation","Bone-Marrow_c-kit","Embryonic-Stem-Cell","MammaryGland.Lactation","Uterus","Neonatal-Calvaria","Neonatal-Heart","Testis","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Bone-Marrow_c-kit","Thymus","Neonatal-Heart","Lung","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Peripheral_Blood","Testis","Muscle","MammaryGland.Lactation","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Prostate","MammaryGland.Pregnancy","Small-Intestine","Bone-Marrow","Embryonic-Stem-Cell","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Placenta","Bone_Marrow_Mesenchyme","Small-Intestine","Bone-Marrow_c-kit","Uterus","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Neonatal-Muscle","Neonatal-Calvaria","Placenta","Placenta","Fetal_Lung","Pancreas","Neonatal-Rib","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Fetal_Intestine","MammaryGland.Lactation","Neonatal-Skin","MammaryGland.Lactation","Bone-Marrow","Fetal-Liver","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Testis","Bone-Marrow","Neonatal-Muscle","Stomach","Small-Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Uterus","Mesenchymal-Stem-Cell-Cultured","Prostate","Neonatal-Muscle","Stomach","Lung","Fetal_Intestine","Neonatal-Rib","Bone_Marrow_Mesenchyme","Testis","Thymus","Bone-Marrow","Liver","Pancreas","Fetal_Lung","Bone-Marrow","Stomach","Fetal-Liver","Embryonic-Mesenchyme","Fetal-Liver","Neonatal-Muscle","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Trophoblast-Stem-Cell","Neonatal-Calvaria","MammaryGland.Lactation","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Ovary","Neonatal-Skin","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bone-Marrow_c-kit","Liver","Lung","Lung","MammaryGland.Lactation","Stomach","Fetal_Stomache","Brain","Trophoblast-Stem-Cell","Bone-Marrow","Neonatal-Muscle","Fetal_Intestine","Kidney","Bladder","Pancreas","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Liver","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Fetal_Intestine","Pancreas","MammaryGland.Virgin","Embryonic-Stem-Cell","Prostate","Embryonic-Mesenchyme","Neonatal-Muscle","Trophoblast-Stem-Cell","Fetal_Intestine","Brain","Spleen","Testis","Testis","Fetal_Stomache","Trophoblast-Stem-Cell","Small-Intestine","Bone-Marrow_c-kit","Bladder","Trophoblast-Stem-Cell","Prostate","Bone-Marrow_c-kit","Spleen","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Fetal_Intestine","Kidney","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Peripheral_Blood","MammaryGland.Involution","Ovary","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","MammaryGland.Virgin","Fetal_Intestine","Bone-Marrow_c-kit","Fetal_Intestine","Bone_Marrow_Mesenchyme","Neonatal-Muscle","MammaryGland.Lactation","Neonatal-Calvaria","Embryonic-Stem-Cell","Testis","Bone-Marrow","MammaryGland.Lactation","Fetal_Intestine","Peripheral_Blood","Ovary","Bone_Marrow_Mesenchyme","Prostate","Bone-Marrow","MammaryGland.Involution","MammaryGland.Pregnancy","Kidney","Fetal_Lung","MammaryGland.Lactation","Embryonic-Stem-Cell","MammaryGland.Lactation","Testis","Small-Intestine","Bone-Marrow","Bone-Marrow","MammaryGland.Involution","Peripheral_Blood","Placenta","Bone-Marrow_c-kit","Lung","Peripheral_Blood","MammaryGland.Lactation","Thymus","Testis","Neonatal-Muscle","Neonatal-Calvaria","Testis","Prostate","Testis","Neonatal-Calvaria","Small-Intestine","Neonatal-Rib","Bone-Marrow_c-kit","Fetal_Lung","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Kidney","Bone-Marrow","Fetal_Intestine","Placenta","Liver","MammaryGland.Virgin","Brain","Bone-Marrow_c-kit","Testis","Small-Intestine","Testis","Thymus","Muscle","Testis","Bone-Marrow_c-kit","Lung","Kidney","Embryonic-Stem-Cell","MammaryGland.Lactation","Embryonic-Stem-Cell","Fetal_Stomache","Fetal_Intestine","Neonatal-Muscle","Peripheral_Blood","Small-Intestine","Lung","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Neonatal-Rib","Placenta","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","Fetal-Liver","MammaryGland.Lactation","Trophoblast-Stem-Cell","Testis","Bone-Marrow_c-kit","Pancreas","Trophoblast-Stem-Cell","Testis","Neonatal-Skin","Stomach","Fetal_Lung","Fetal_Intestine","Fetal_Lung","Bone_Marrow_Mesenchyme","Testis","Ovary","Peripheral_Blood","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Virgin","Bone-Marrow_c-kit","Testis","Fetal_Brain","Peripheral_Blood","Bone_Marrow_Mesenchyme","Embryonic-Mesenchyme","Embryonic-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Uterus","MammaryGland.Virgin","Thymus","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","Neonatal-Heart","Trophoblast-Stem-Cell","Fetal_Intestine","Trophoblast-Stem-Cell","Lung","Fetal-Liver","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Heart","Embryonic-Stem-Cell","Peripheral_Blood","Placenta","Kidney","Lung","Spleen","Kidney","Fetal_Brain","Fetal-Liver","Trophoblast-Stem-Cell","MammaryGland.Lactation","Peripheral_Blood","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Ovary","Ovary","Neonatal-Calvaria","Bone-Marrow_c-kit","Fetal_Brain","Bone_Marrow_Mesenchyme","Fetal_Lung","Small-Intestine","Fetal_Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Lung","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Fetal_Intestine","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Fetal_Brain","MammaryGland.Virgin","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow","Fetal-Liver","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","MammaryGland.Involution","Stomach","Placenta","Trophoblast-Stem-Cell","Neonatal-Calvaria","Trophoblast-Stem-Cell","Lung","Testis","Uterus","Bone-Marrow","Trophoblast-Stem-Cell","MammaryGland.Virgin","Fetal_Brain","Trophoblast-Stem-Cell","Neonatal-Heart","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Pancreas","Liver","Fetal_Lung","MammaryGland.Virgin","Testis","Embryonic-Mesenchyme","Lung","Bone-Marrow","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Kidney","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Peripheral_Blood","Prostate","Fetal_Stomache","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Lung","Ovary","Neonatal-Rib","Pancreas","Kidney","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Ovary","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Ovary","Bone-Marrow_c-kit","Lung","Neonatal-Calvaria","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow","Fetal_Intestine","Lung","Embryonic-Stem-Cell","Peripheral_Blood","MammaryGland.Involution","Bone-Marrow_c-kit","Lung","MammaryGland.Pregnancy","Uterus","Uterus","Pancreas","Stomach","Bone-Marrow_c-kit","Fetal_Intestine","Testis","Thymus","Neonatal-Muscle","Testis","Fetal-Liver","Thymus","Fetal-Liver","Kidney","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","Muscle","MammaryGland.Pregnancy","Neonatal-Heart","Testis","Bone-Marrow","Bone-Marrow","Bladder","Pancreas","Placenta","Bone-Marrow","Neonatal-Calvaria","Bone-Marrow_c-kit","MammaryGland.Virgin","Bone-Marrow_c-kit","Neonatal-Calvaria","Thymus","Fetal_Lung","Testis","Ovary","Kidney","Small-Intestine","Neonatal-Skin","Neonatal-Calvaria","Fetal_Lung","Bone-Marrow_c-kit","MammaryGland.Virgin","Lung","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Fetal_Lung","Fetal_Intestine","Neonatal-Heart","Ovary","MammaryGland.Virgin","MammaryGland.Lactation","Neonatal-Rib","MammaryGland.Lactation","Neonatal-Muscle","Neonatal-Heart","Neonatal-Calvaria","Fetal_Intestine","Ovary","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Small-Intestine","Peripheral_Blood","MammaryGland.Involution","Peripheral_Blood","MammaryGland.Involution","Small-Intestine","Thymus","Bone-Marrow","Stomach","MammaryGland.Involution","Embryonic-Stem-Cell","Lung","Testis","MammaryGland.Virgin","Fetal_Stomache","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Thymus","MammaryGland.Lactation","Bone-Marrow","Fetal-Liver","Prostate","MammaryGland.Lactation","Neonatal-Calvaria","Testis","Fetal_Intestine","Testis","Lung","Bone-Marrow","Testis","Embryonic-Stem-Cell","Fetal_Intestine","Fetal_Lung","Liver","MammaryGland.Involution","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Fetal_Lung","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Thymus","MammaryGland.Lactation","Testis","Lung","Lung","Mesenchymal-Stem-Cell-Cultured","Ovary","Neonatal-Muscle","Stomach","Brain","Neonatal-Skin","Brain","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone-Marrow_c-kit","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Calvaria","Neonatal-Rib","Fetal_Stomache","Bone-Marrow_c-kit","Pancreas","Fetal_Stomache","Fetal_Stomache","MammaryGland.Lactation","Bone-Marrow_c-kit","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Small-Intestine","MammaryGland.Lactation","Trophoblast-Stem-Cell","Kidney","Placenta","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Testis","MammaryGland.Virgin","MammaryGland.Lactation","Neonatal-Calvaria","Lung","Placenta","MammaryGland.Virgin","Fetal_Intestine","Peripheral_Blood","Bone-Marrow_c-kit","Neonatal-Rib","Testis","Fetal-Liver","Fetal_Stomache","MammaryGland.Lactation","Fetal_Intestine","Embryonic-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Involution","Bladder","Liver","Ovary","Bone-Marrow_c-kit","Ovary","Embryonic-Stem-Cell","MammaryGland.Lactation","Neonatal-Rib","Placenta","Stomach","Bone-Marrow_c-kit","Fetal_Brain","Trophoblast-Stem-Cell","Small-Intestine","Testis","Trophoblast-Stem-Cell","Neonatal-Calvaria","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Rib","Brain","Bone-Marrow_c-kit","Placenta","Neonatal-Heart","MammaryGland.Lactation","Bone-Marrow_c-kit","Stomach","Neonatal-Muscle","Prostate","Fetal_Lung","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Small-Intestine","Bone-Marrow_c-kit","Liver","Bone_Marrow_Mesenchyme","Ovary","MammaryGland.Lactation","MammaryGland.Lactation","Spleen","Brain","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Neonatal-Rib","Spleen","Bone-Marrow_c-kit","Neonatal-Skin","Fetal_Lung","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Rib","Thymus","Thymus","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Prostate","Trophoblast-Stem-Cell","Neonatal-Rib","MammaryGland.Involution","Testis","Fetal_Stomache","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Ovary","Bone-Marrow","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Fetal_Intestine","Lung","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Calvaria","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Thymus","Neonatal-Muscle","Embryonic-Stem-Cell","Neonatal-Heart","Neonatal-Muscle","Fetal_Brain","MammaryGland.Involution","Peripheral_Blood","Bone-Marrow","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Kidney","Liver","Placenta","Fetal_Lung","Thymus","Pancreas","MammaryGland.Lactation","Testis","Embryonic-Stem-Cell","Testis","Fetal_Intestine","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Kidney","MammaryGland.Lactation","Bone-Marrow_c-kit","Lung","Mesenchymal-Stem-Cell-Cultured","Uterus","Bone-Marrow_c-kit","Fetal_Brain","Neonatal-Rib","Bone-Marrow_c-kit","Stomach","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Bone-Marrow_c-kit","MammaryGland.Lactation","Testis","Embryonic-Stem-Cell","Fetal_Intestine","Liver","Neonatal-Muscle","MammaryGland.Lactation","Fetal_Lung","Spleen","Trophoblast-Stem-Cell","MammaryGland.Involution","Neonatal-Rib","Kidney","Trophoblast-Stem-Cell","Kidney","MammaryGland.Lactation","Trophoblast-Stem-Cell","Fetal_Lung","Peripheral_Blood","Embryonic-Stem-Cell","Neonatal-Rib","Embryonic-Stem-Cell","MammaryGland.Virgin","Trophoblast-Stem-Cell","Thymus","Trophoblast-Stem-Cell","Small-Intestine","Prostate","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Neonatal-Heart","Bone-Marrow_c-kit","Fetal-Liver","Embryonic-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Lactation","Pancreas","Small-Intestine","Bone-Marrow","Trophoblast-Stem-Cell","Brain","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bladder","Testis","Testis","MammaryGland.Pregnancy","MammaryGland.Lactation","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Calvaria","MammaryGland.Involution","Neonatal-Skin","Neonatal-Muscle","Ovary","Trophoblast-Stem-Cell","Bladder","Neonatal-Skin","Muscle","Neonatal-Heart","Thymus","Testis","MammaryGland.Virgin","MammaryGland.Involution","MammaryGland.Lactation","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Neonatal-Muscle","Fetal_Stomache","Kidney","MammaryGland.Involution","Bone-Marrow_c-kit","Fetal_Stomache","Liver","Neonatal-Calvaria","MammaryGland.Virgin","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Pancreas","MammaryGland.Virgin","Testis","Fetal_Stomache","Trophoblast-Stem-Cell","Fetal_Brain","Pancreas","Small-Intestine","Trophoblast-Stem-Cell","Lung","Testis","Bone-Marrow_c-kit","Fetal_Lung","Liver","Neonatal-Calvaria","Peripheral_Blood","MammaryGland.Lactation","MammaryGland.Pregnancy","Testis","Neonatal-Muscle","Small-Intestine","Kidney","Lung","Fetal_Stomache","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Thymus","MammaryGland.Virgin","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","MammaryGland.Virgin","Trophoblast-Stem-Cell","Neonatal-Rib","Uterus","Thymus","MammaryGland.Lactation","Placenta","Liver","Fetal_Stomache","Trophoblast-Stem-Cell","Fetal-Liver","Testis","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Skin","Ovary","Bone_Marrow_Mesenchyme","Testis","Neonatal-Calvaria","MammaryGland.Lactation","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Stomach","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Peripheral_Blood","Neonatal-Heart","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Placenta","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Spleen","Neonatal-Muscle","Neonatal-Heart","Bone-Marrow","Neonatal-Skin","MammaryGland.Pregnancy","Embryonic-Mesenchyme","MammaryGland.Virgin","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Liver","Testis","Trophoblast-Stem-Cell","Neonatal-Calvaria","Peripheral_Blood","Bone-Marrow_c-kit","Neonatal-Rib","Peripheral_Blood","Peripheral_Blood","MammaryGland.Involution","Prostate","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Muscle","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal_Lung","Neonatal-Calvaria","Bone-Marrow_c-kit","Prostate","Neonatal-Muscle","Uterus","Bone-Marrow_c-kit","Prostate","Neonatal-Skin","Ovary","Mesenchymal-Stem-Cell-Cultured","Kidney","MammaryGland.Pregnancy","Liver","Brain","MammaryGland.Lactation","Bone-Marrow_c-kit","Bladder","MammaryGland.Lactation","Small-Intestine","MammaryGland.Virgin","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone-Marrow","MammaryGland.Lactation","Trophoblast-Stem-Cell","Kidney","Testis","Testis","Embryonic-Stem-Cell","Liver","Bone-Marrow","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Heart","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Small-Intestine","Ovary","Muscle","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Virgin","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal-Liver","Small-Intestine","Testis","MammaryGland.Lactation","Embryonic-Stem-Cell","Peripheral_Blood","MammaryGland.Lactation","Lung","Bone-Marrow_c-kit","Ovary","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Lactation","Fetal_Brain","Bone-Marrow","Spleen","Testis","Ovary","Fetal_Intestine","Muscle","Brain","Thymus","Trophoblast-Stem-Cell","MammaryGland.Lactation","MammaryGland.Lactation","Lung","MammaryGland.Lactation","Spleen","Neonatal-Calvaria","Fetal_Brain","Neonatal-Heart","Uterus","Neonatal-Heart","Neonatal-Calvaria","Bone-Marrow_c-kit","Neonatal-Rib","Testis","Mesenchymal-Stem-Cell-Cultured","Pancreas","MammaryGland.Lactation","Stomach","Embryonic-Mesenchyme","Brain","Trophoblast-Stem-Cell","Fetal_Stomache","Trophoblast-Stem-Cell","Fetal-Liver","Spleen","Fetal_Brain","Fetal_Intestine","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Brain","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Trophoblast-Stem-Cell","Neonatal-Calvaria","Fetal_Intestine","Embryonic-Stem-Cell","Neonatal-Skin","Lung","Pancreas","Uterus","Fetal_Intestine","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bone-Marrow_c-kit","Pancreas","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Trophoblast-Stem-Cell","Fetal-Liver","Testis","MammaryGland.Lactation","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Ovary","Neonatal-Rib","MammaryGland.Involution","Small-Intestine","Neonatal-Rib","Fetal_Stomache","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Uterus","Mesenchymal-Stem-Cell-Cultured","Liver","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Heart","Peripheral_Blood","MammaryGland.Involution","MammaryGland.Pregnancy","Neonatal-Heart","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Uterus","Fetal-Liver","MammaryGland.Involution","Lung","Uterus","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Pancreas","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Ovary","Bone-Marrow_c-kit","Fetal_Brain","Testis","Small-Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Stomach","Bone-Marrow","Liver","Testis","Trophoblast-Stem-Cell","Bone-Marrow","Fetal_Stomache","Kidney","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Heart","Brain","Fetal_Stomache","Trophoblast-Stem-Cell","MammaryGland.Lactation","MammaryGland.Virgin","Bone-Marrow","Placenta","Trophoblast-Stem-Cell","Spleen","Fetal_Lung","Neonatal-Skin","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Kidney","Bone-Marrow_c-kit","Bladder","Bone-Marrow_c-kit","Placenta","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Testis","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Neonatal-Rib","Neonatal-Heart","Trophoblast-Stem-Cell","Neonatal-Rib","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Fetal_Intestine","Neonatal-Rib","Neonatal-Skin","Bone-Marrow_c-kit","Stomach","Neonatal-Calvaria","MammaryGland.Involution","Trophoblast-Stem-Cell","Kidney","MammaryGland.Involution","Neonatal-Skin","Peripheral_Blood","Fetal_Intestine","Trophoblast-Stem-Cell","Peripheral_Blood","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Lung","Testis","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Skin","Testis","Bone-Marrow","Neonatal-Rib","Embryonic-Stem-Cell","Testis","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Small-Intestine","Neonatal-Muscle","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Fetal_Lung","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow","Embryonic-Stem-Cell","Ovary","Neonatal-Rib","Stomach","Peripheral_Blood","MammaryGland.Lactation","Liver","MammaryGland.Lactation","MammaryGland.Lactation","Neonatal-Calvaria","Peripheral_Blood","MammaryGland.Pregnancy","Fetal_Lung","Fetal_Lung","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Small-Intestine","MammaryGland.Lactation","Fetal_Brain","Stomach","Neonatal-Heart","Neonatal-Muscle","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Brain","Neonatal-Skin","Neonatal-Calvaria","Uterus","Brain","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow","MammaryGland.Lactation","MammaryGland.Lactation","Ovary","Trophoblast-Stem-Cell","MammaryGland.Lactation","Ovary","Neonatal-Calvaria","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Small-Intestine","Bone-Marrow","Thymus","Embryonic-Stem-Cell","Fetal_Brain","Liver","Uterus","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Bone-Marrow","Testis","Stomach","Neonatal-Calvaria","Neonatal-Heart","Neonatal-Calvaria","Brain","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Placenta","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow","Fetal_Lung","Neonatal-Muscle","Stomach","Fetal_Intestine","Thymus","Placenta","Liver","Bone-Marrow_c-kit","Ovary","Testis","Bone-Marrow","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bladder","Fetal_Stomache","MammaryGland.Involution","Fetal-Liver","Fetal_Brain","Trophoblast-Stem-Cell","Lung","Fetal_Intestine","Bone-Marrow_c-kit","Thymus","Ovary","Kidney","Small-Intestine","Brain","MammaryGland.Pregnancy","MammaryGland.Lactation","Bone-Marrow_c-kit","MammaryGland.Lactation","Peripheral_Blood","MammaryGland.Lactation","Testis","Neonatal-Heart","Fetal_Lung","Peripheral_Blood","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Thymus","Fetal_Stomache","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Testis","Uterus","Placenta","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","MammaryGland.Lactation","Lung","Testis","Neonatal-Rib","Testis","Lung","Liver","Small-Intestine","Lung","Neonatal-Muscle","MammaryGland.Virgin","Fetal_Lung","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","MammaryGland.Lactation","Uterus","Fetal_Stomache","Neonatal-Heart","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Fetal_Stomache","Uterus","MammaryGland.Pregnancy","Fetal_Intestine","Kidney","Fetal_Lung","Thymus","MammaryGland.Lactation","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Bladder","MammaryGland.Involution","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Testis","Neonatal-Muscle","Fetal_Brain","Brain","MammaryGland.Involution","Trophoblast-Stem-Cell","Small-Intestine","Neonatal-Rib","Bone-Marrow_c-kit","Pancreas","Prostate","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Virgin","Testis","MammaryGland.Lactation","Brain","Neonatal-Calvaria","Neonatal-Muscle","MammaryGland.Involution","MammaryGland.Lactation","Pancreas","Bone-Marrow","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Bone-Marrow","Prostate","Fetal_Brain","Neonatal-Skin","Kidney","Small-Intestine","MammaryGland.Lactation","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Neonatal-Skin","Bone-Marrow_c-kit","Neonatal-Calvaria","Testis","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Placenta","Neonatal-Calvaria","Testis","Trophoblast-Stem-Cell","Pancreas","Fetal_Intestine","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Muscle","Fetal_Lung","Fetal-Liver","Trophoblast-Stem-Cell","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Kidney","Kidney","Fetal_Lung","MammaryGland.Lactation","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Peripheral_Blood","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow","MammaryGland.Pregnancy","MammaryGland.Lactation","Trophoblast-Stem-Cell","Neonatal-Rib","Bone-Marrow_c-kit","Fetal_Lung","Neonatal-Heart","Lung","Neonatal-Calvaria","Liver","MammaryGland.Virgin","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Bladder","Neonatal-Muscle","MammaryGland.Lactation","Fetal_Lung","Neonatal-Rib","Liver","Bone-Marrow_c-kit","Neonatal-Skin","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Neonatal-Heart","Bone-Marrow_c-kit","Fetal_Lung","Bone-Marrow_c-kit","Fetal_Stomache","Peripheral_Blood","Trophoblast-Stem-Cell","Stomach","Trophoblast-Stem-Cell","MammaryGland.Involution","Fetal_Intestine","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Bone-Marrow","Bone-Marrow_c-kit","Bone-Marrow","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Lung","Neonatal-Skin","Small-Intestine","Fetal_Lung","MammaryGland.Lactation","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Thymus","Testis","Small-Intestine","Ovary","MammaryGland.Pregnancy","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow","Neonatal-Muscle","Pancreas","Lung","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","MammaryGland.Virgin","Neonatal-Rib","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Liver","MammaryGland.Lactation","MammaryGland.Virgin","Ovary","Fetal_Brain","Neonatal-Rib","Brain","Bladder","Thymus","Embryonic-Mesenchyme","MammaryGland.Involution","Thymus","Testis","Placenta","Ovary","Ovary","Stomach","Fetal_Brain","Ovary","Fetal_Stomache","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Uterus","Fetal_Lung","Lung","Neonatal-Muscle","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Rib","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Placenta","Trophoblast-Stem-Cell","Fetal_Lung","Bone-Marrow","Fetal_Stomache","Bone-Marrow","Bladder","Fetal_Intestine","MammaryGland.Pregnancy","Testis","Placenta","Trophoblast-Stem-Cell","Peripheral_Blood","Trophoblast-Stem-Cell","Fetal_Lung","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","Fetal_Intestine","MammaryGland.Lactation","Fetal_Intestine","Trophoblast-Stem-Cell","Neonatal-Rib","Bone-Marrow_c-kit","Neonatal-Rib","Placenta","Placenta","Pancreas","Trophoblast-Stem-Cell","Spleen","MammaryGland.Lactation","Neonatal-Calvaria","Bone-Marrow_c-kit","Testis","Neonatal-Skin","Neonatal-Rib","Fetal-Liver","Thymus","Neonatal-Rib","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Fetal_Brain","Fetal_Intestine","Bone-Marrow","Bone_Marrow_Mesenchyme","Small-Intestine","Bone-Marrow","MammaryGland.Lactation","MammaryGland.Involution","Lung","MammaryGland.Virgin","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Thymus","Small-Intestine","Kidney","Liver","Testis","Testis","Embryonic-Stem-Cell","Testis","Fetal_Lung","Trophoblast-Stem-Cell","Placenta","Trophoblast-Stem-Cell","Fetal_Intestine","Fetal_Intestine","Lung","MammaryGland.Virgin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Brain","Brain","Bone-Marrow_c-kit","Neonatal-Heart","Neonatal-Calvaria","Testis","MammaryGland.Involution","Neonatal-Calvaria","Fetal_Lung","Fetal-Liver","Fetal_Intestine","Bone-Marrow_c-kit","Neonatal-Skin","Bone-Marrow_c-kit","Neonatal-Muscle","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Bone-Marrow_c-kit","Neonatal-Skin","Neonatal-Calvaria","Trophoblast-Stem-Cell","MammaryGland.Involution","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Peripheral_Blood","Fetal_Lung","Pancreas","Neonatal-Calvaria","MammaryGland.Pregnancy","Neonatal-Rib","Stomach","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Neonatal-Heart","Bone_Marrow_Mesenchyme","Uterus","Peripheral_Blood","Brain","Bone-Marrow_c-kit","Uterus","Neonatal-Rib","MammaryGland.Lactation","Liver","Spleen","Bone-Marrow","Trophoblast-Stem-Cell","Neonatal-Skin","Testis","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Neonatal-Rib","Fetal_Stomache","Fetal_Lung","Trophoblast-Stem-Cell","Fetal_Intestine","Muscle","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Fetal_Intestine","Embryonic-Stem-Cell","Small-Intestine","Peripheral_Blood","Bladder","Spleen","Fetal_Lung","Neonatal-Heart","Small-Intestine","Trophoblast-Stem-Cell","Neonatal-Muscle","Testis","MammaryGland.Lactation","Fetal_Brain","Bone-Marrow","Fetal_Brain","Neonatal-Heart","Small-Intestine","MammaryGland.Lactation","Placenta","Kidney","Fetal_Lung","Bone-Marrow_c-kit","Bladder","Bone-Marrow","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Neonatal-Skin","Testis","Neonatal-Muscle","MammaryGland.Lactation","Kidney","Fetal_Brain","Testis","MammaryGland.Lactation","Lung","MammaryGland.Involution","Trophoblast-Stem-Cell","Testis","Fetal_Intestine","Bone-Marrow","MammaryGland.Lactation","Prostate","Lung","MammaryGland.Lactation","Bone-Marrow_c-kit","Kidney","Fetal_Intestine","MammaryGland.Lactation","Fetal_Stomache","Bone-Marrow_c-kit","Uterus","Ovary","Bone-Marrow_c-kit","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Liver","Neonatal-Calvaria","Testis","Embryonic-Stem-Cell","Liver","Trophoblast-Stem-Cell","Neonatal-Rib","Embryonic-Stem-Cell","Fetal_Lung","Fetal_Brain","Neonatal-Calvaria","Liver","Bone-Marrow_c-kit","Neonatal-Muscle","Testis","Trophoblast-Stem-Cell","Small-Intestine","Bone-Marrow_c-kit","Lung","Small-Intestine","Trophoblast-Stem-Cell","Bladder","Peripheral_Blood","Fetal_Lung","Neonatal-Muscle","Bone-Marrow","Small-Intestine","Small-Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Stomache","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow_c-kit","Small-Intestine","Neonatal-Skin","MammaryGland.Pregnancy","Fetal_Intestine","Bone-Marrow_c-kit","Ovary","Bone-Marrow_c-kit","Ovary","Pancreas","Liver","Neonatal-Calvaria","Bone-Marrow_c-kit","Placenta","Kidney","MammaryGland.Lactation","Testis","Neonatal-Calvaria","Bone-Marrow_c-kit","Embryonic-Stem-Cell","MammaryGland.Involution","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Neonatal-Heart","Fetal_Stomache","Bone-Marrow_c-kit","Neonatal-Muscle","Fetal-Liver","Neonatal-Heart","Fetal_Stomache","Placenta","MammaryGland.Involution","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Kidney","Bone-Marrow_c-kit","Fetal_Lung","Trophoblast-Stem-Cell","Neonatal-Heart","Fetal_Stomache","Peripheral_Blood","Brain","Kidney","Bone-Marrow","MammaryGland.Lactation","Fetal_Lung","Fetal_Lung","Neonatal-Calvaria","Neonatal-Calvaria","Trophoblast-Stem-Cell","Fetal-Liver","Ovary","Testis","MammaryGland.Involution","Embryonic-Stem-Cell","Fetal_Lung","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Involution","Peripheral_Blood","Pancreas","Bone-Marrow_c-kit","Ovary","Trophoblast-Stem-Cell","Neonatal-Heart","Liver","Neonatal-Muscle","MammaryGland.Lactation","Small-Intestine","Trophoblast-Stem-Cell","Neonatal-Skin","MammaryGland.Virgin","Bone-Marrow_c-kit","Thymus","Prostate","Fetal_Stomache","Small-Intestine","Neonatal-Calvaria","Bone-Marrow_c-kit","Placenta","Thymus","Neonatal-Rib","Lung","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Skin","Fetal_Intestine","Trophoblast-Stem-Cell","MammaryGland.Virgin","Fetal-Liver","Fetal_Intestine","Trophoblast-Stem-Cell","Neonatal-Rib","Pancreas","Bone-Marrow","Embryonic-Mesenchyme","Testis","Trophoblast-Stem-Cell","Neonatal-Calvaria","Fetal_Intestine","MammaryGland.Lactation","Fetal_Stomache","Bone-Marrow","Fetal_Brain","Trophoblast-Stem-Cell","Fetal-Liver","Brain","Neonatal-Rib","Testis","Kidney","Neonatal-Calvaria","Peripheral_Blood","Trophoblast-Stem-Cell","Fetal_Lung","Neonatal-Rib","Bone-Marrow","Fetal_Stomache","Fetal_Brain","Bone-Marrow_c-kit","Neonatal-Muscle","Bone-Marrow_c-kit","Fetal-Liver","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Small-Intestine","Neonatal-Heart","Fetal_Lung","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Lung","Fetal_Intestine","Fetal_Stomache","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Testis","MammaryGland.Lactation","MammaryGland.Lactation","Kidney","Neonatal-Calvaria","Neonatal-Rib","Neonatal-Rib","Trophoblast-Stem-Cell","Peripheral_Blood","Liver","MammaryGland.Pregnancy","Testis","Lung","Trophoblast-Stem-Cell","Fetal_Stomache","Bone_Marrow_Mesenchyme","Muscle","Neonatal-Calvaria","Testis","Bone-Marrow","Fetal_Lung","Fetal_Stomache","Lung","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Calvaria","Embryonic-Stem-Cell","Fetal_Brain","Lung","Fetal_Stomache","Embryonic-Stem-Cell","Neonatal-Calvaria","Stomach","Bone-Marrow_c-kit","Neonatal-Heart","Trophoblast-Stem-Cell","Neonatal-Heart","Bone-Marrow_c-kit","Spleen","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Lung","Placenta","Bone-Marrow","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","MammaryGland.Lactation","MammaryGland.Lactation","Placenta","Mesenchymal-Stem-Cell-Cultured","Bladder","Mesenchymal-Stem-Cell-Cultured","Neonatal-Heart","Uterus","Pancreas","Kidney","Bone-Marrow","Testis","Testis","Bone-Marrow","Uterus","Trophoblast-Stem-Cell","Prostate","Muscle","Bone-Marrow","MammaryGland.Lactation","Liver","Neonatal-Calvaria","Brain","MammaryGland.Lactation","Prostate","Peripheral_Blood","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Fetal_Intestine","Brain","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Bone_Marrow_Mesenchyme","Fetal_Lung","Trophoblast-Stem-Cell","Muscle","Bone-Marrow_c-kit","Bladder","Bone-Marrow","Liver","Neonatal-Calvaria","Prostate","Testis","Brain","Testis","Fetal_Stomache","Bone-Marrow_c-kit","Lung","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Lung","Liver","Bladder","Testis","Fetal_Intestine","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Neonatal-Heart","Placenta","Small-Intestine","Bone-Marrow_c-kit","Embryonic-Stem-Cell","MammaryGland.Involution","Placenta","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Testis","Small-Intestine","Bone-Marrow","Trophoblast-Stem-Cell","Fetal_Lung","Bone_Marrow_Mesenchyme","Fetal_Stomache","Pancreas","Thymus","Neonatal-Muscle","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Pancreas","MammaryGland.Lactation","Neonatal-Rib","Bone-Marrow_c-kit","Lung","MammaryGland.Virgin","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Lung","Trophoblast-Stem-Cell","Testis","Embryonic-Stem-Cell","Testis","Bone-Marrow","Kidney","Testis","Spleen","Neonatal-Heart","Small-Intestine","MammaryGland.Virgin","Bone-Marrow_c-kit","Lung","Pancreas","Kidney","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Heart","Placenta","Lung","Liver","Liver","Bone-Marrow_c-kit","Fetal_Lung","Kidney","Trophoblast-Stem-Cell","Fetal_Lung","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Liver","MammaryGland.Lactation","Fetal_Stomache","Placenta","Embryonic-Stem-Cell","Neonatal-Calvaria","Lung","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Neonatal-Rib","Fetal-Liver","Mesenchymal-Stem-Cell-Cultured","Embryonic-Mesenchyme","Ovary","Neonatal-Rib","MammaryGland.Involution","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Muscle","MammaryGland.Lactation","Fetal_Stomache","Bladder","Fetal_Lung","Bone-Marrow","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","MammaryGland.Virgin","Fetal_Intestine","Trophoblast-Stem-Cell","Fetal-Liver","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Spleen","Fetal_Stomache","Fetal_Lung","Bone-Marrow","Bone-Marrow_c-kit","Fetal_Lung","Peripheral_Blood","Prostate","Testis","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Fetal-Liver","MammaryGland.Virgin","Embryonic-Stem-Cell","Testis","Testis","Ovary","Placenta","Placenta","Testis","Pancreas","Uterus","Embryonic-Mesenchyme","Fetal_Intestine","Neonatal-Calvaria","Placenta","Peripheral_Blood","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Involution","Trophoblast-Stem-Cell","MammaryGland.Virgin","Ovary","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Brain","Bone-Marrow_c-kit","Small-Intestine","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Bladder","Bone-Marrow_c-kit","Prostate","Embryonic-Stem-Cell","Small-Intestine","MammaryGland.Virgin","Neonatal-Calvaria","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Virgin","Peripheral_Blood","Fetal-Liver","Fetal-Liver","Peripheral_Blood","MammaryGland.Pregnancy","Brain","Uterus","Placenta","Neonatal-Rib","Bone-Marrow_c-kit","Neonatal-Rib","Testis","Bone-Marrow_c-kit","MammaryGland.Involution","Bone-Marrow_c-kit","Peripheral_Blood","Stomach","Peripheral_Blood","Fetal_Intestine","MammaryGland.Virgin","Liver","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Lung","MammaryGland.Lactation","Fetal_Intestine","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Neonatal-Rib","Liver","Testis","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Fetal_Intestine","Fetal_Intestine","MammaryGland.Involution","Bone-Marrow","Small-Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Placenta","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Testis","Fetal_Intestine","Neonatal-Heart","Testis","Bone-Marrow_c-kit","Muscle","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Placenta","Thymus","MammaryGland.Involution","Trophoblast-Stem-Cell","Liver","Brain","Pancreas","Small-Intestine","Spleen","Fetal_Lung","Bladder","Neonatal-Muscle","Pancreas","Small-Intestine","Neonatal-Calvaria","MammaryGland.Pregnancy","Prostate","Bone-Marrow","Fetal_Intestine","Neonatal-Rib","Neonatal-Calvaria","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Brain","Neonatal-Calvaria","Trophoblast-Stem-Cell","Bone-Marrow","Bone_Marrow_Mesenchyme","Fetal_Lung","MammaryGland.Lactation","Bone-Marrow","Bone-Marrow_c-kit","Prostate","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Placenta","Small-Intestine","Placenta","Lung","Small-Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Lung","Trophoblast-Stem-Cell","Peripheral_Blood","Fetal_Lung","Kidney","Trophoblast-Stem-Cell","Thymus","Neonatal-Rib","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Placenta","Placenta","Neonatal-Muscle","Bone-Marrow","Fetal_Brain","Liver","Bone-Marrow_c-kit","Liver","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Calvaria","Testis","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Bladder","Bone-Marrow_c-kit","Spleen","Pancreas","MammaryGland.Lactation","Fetal_Lung","Fetal-Liver","MammaryGland.Virgin","Neonatal-Heart","MammaryGland.Virgin","MammaryGland.Lactation","Bone-Marrow_c-kit","Stomach","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal_Stomache","Bone_Marrow_Mesenchyme","Kidney","Fetal_Intestine","Peripheral_Blood","MammaryGland.Lactation","Pancreas","Peripheral_Blood","MammaryGland.Lactation","MammaryGland.Pregnancy","Fetal_Brain","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Peripheral_Blood","Fetal_Stomache","MammaryGland.Virgin","Peripheral_Blood","MammaryGland.Involution","Ovary","Stomach","MammaryGland.Involution","Neonatal-Rib","Fetal_Intestine","Testis","Ovary","Placenta","Fetal_Stomache","Fetal_Brain","Bone-Marrow_c-kit","MammaryGland.Involution","Fetal_Stomache","Neonatal-Skin","Bone-Marrow_c-kit","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Embryonic-Stem-Cell","Muscle","Bladder","Trophoblast-Stem-Cell","Fetal_Brain","Placenta","Fetal_Intestine","MammaryGland.Involution","MammaryGland.Involution","Fetal_Lung","Neonatal-Skin","Embryonic-Stem-Cell","Peripheral_Blood","Uterus","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Spleen","Testis","Lung","Fetal_Stomache","Thymus","Thymus","Neonatal-Muscle","Placenta","Peripheral_Blood","Embryonic-Stem-Cell","Fetal_Intestine","Trophoblast-Stem-Cell","Kidney","Trophoblast-Stem-Cell","Bone-Marrow","Neonatal-Skin","Neonatal-Muscle","Lung","MammaryGland.Lactation","MammaryGland.Pregnancy","Lung","Bone-Marrow","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Testis","MammaryGland.Lactation","Placenta","Testis","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Fetal_Lung","Pancreas","Embryonic-Stem-Cell","Fetal_Intestine","Uterus","Fetal-Liver","Thymus","Neonatal-Calvaria","Fetal-Liver","Bone-Marrow","Embryonic-Stem-Cell","Bone-Marrow","MammaryGland.Involution","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Kidney","Trophoblast-Stem-Cell","Thymus","Fetal_Lung","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Fetal_Lung","Uterus","Bone_Marrow_Mesenchyme","Bone-Marrow","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Testis","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Bone-Marrow_c-kit","Ovary","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","Liver","Neonatal-Calvaria","Neonatal-Rib","Bone-Marrow_c-kit","Liver","Small-Intestine","Embryonic-Stem-Cell","Thymus","Fetal_Brain","MammaryGland.Involution","Testis","MammaryGland.Lactation","Prostate","Neonatal-Rib","MammaryGland.Lactation","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Neonatal-Muscle","Small-Intestine","Uterus","Testis","Bone-Marrow_c-kit","Thymus","Placenta","Neonatal-Heart","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Fetal_Intestine","Embryonic-Stem-Cell","MammaryGland.Involution","MammaryGland.Involution","Thymus","Testis","MammaryGland.Virgin","Fetal-Liver","Muscle","Fetal_Stomache","Fetal_Lung","MammaryGland.Lactation","Bone-Marrow_c-kit","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","MammaryGland.Involution","Thymus","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Muscle","Trophoblast-Stem-Cell","Neonatal-Rib","Bone-Marrow_c-kit","Kidney","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Liver","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow_c-kit","Kidney","Liver","Neonatal-Skin","Small-Intestine","Testis","Pancreas","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Bone-Marrow_c-kit","Liver","Trophoblast-Stem-Cell","Stomach","Neonatal-Calvaria","Lung","Testis","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Virgin","Kidney","Uterus","Fetal_Lung","Muscle","Mesenchymal-Stem-Cell-Cultured","Uterus","MammaryGland.Involution","Embryonic-Stem-Cell","Neonatal-Calvaria","Bone-Marrow_c-kit","Thymus","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Fetal_Lung","Neonatal-Muscle","Ovary","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Testis","Neonatal-Rib","Uterus","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow","Bone-Marrow","Liver","Embryonic-Stem-Cell","Fetal_Lung","Bladder","Thymus","MammaryGland.Lactation","Testis","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Neonatal-Heart","Fetal_Intestine","Muscle","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Thymus","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Testis","Bone-Marrow","Embryonic-Stem-Cell","Pancreas","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Testis","Brain","Ovary","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Brain","Placenta","Testis","Fetal_Stomache","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","Testis","Bone-Marrow_c-kit","Small-Intestine","Brain","Neonatal-Rib","Testis","Bone-Marrow_c-kit","Testis","Peripheral_Blood","Trophoblast-Stem-Cell","Pancreas","Testis","Neonatal-Muscle","Fetal_Intestine","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Peripheral_Blood","Pancreas","Pancreas","Trophoblast-Stem-Cell","Fetal_Lung","Small-Intestine","Brain","Testis","MammaryGland.Involution","Bone-Marrow_c-kit","Neonatal-Heart","Bone-Marrow","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Bone-Marrow_c-kit","Lung","Fetal-Liver","Fetal_Stomache","Fetal_Stomache","MammaryGland.Virgin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Spleen","Fetal_Intestine","Testis","Testis","Embryonic-Mesenchyme","Fetal_Stomache","Trophoblast-Stem-Cell","Kidney","MammaryGland.Lactation","Embryonic-Stem-Cell","Testis","Neonatal-Muscle","Thymus","Bone-Marrow_c-kit","Small-Intestine","Ovary","Kidney","Fetal_Intestine","Bladder","Bone_Marrow_Mesenchyme","Placenta","Neonatal-Calvaria","Neonatal-Heart","Neonatal-Calvaria","Embryonic-Stem-Cell","MammaryGland.Lactation","Fetal_Intestine","Embryonic-Stem-Cell","Pancreas","MammaryGland.Lactation","Bone-Marrow","Fetal_Intestine","MammaryGland.Lactation","Pancreas","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","MammaryGland.Lactation","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Brain","Bone-Marrow","MammaryGland.Virgin","Trophoblast-Stem-Cell","Testis","Bone_Marrow_Mesenchyme","MammaryGland.Involution","Bone-Marrow_c-kit","MammaryGland.Lactation","Placenta","Testis","MammaryGland.Lactation","Kidney","MammaryGland.Lactation","Neonatal-Skin","MammaryGland.Pregnancy","Testis","Bone-Marrow","Bone-Marrow_c-kit","Thymus","Trophoblast-Stem-Cell","MammaryGland.Virgin","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Bone-Marrow","Neonatal-Rib","Embryonic-Mesenchyme","Bladder","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Involution","MammaryGland.Lactation","Fetal_Stomache","Small-Intestine","Testis","Bone-Marrow_c-kit","Fetal-Liver","Peripheral_Blood","Small-Intestine","Neonatal-Heart","MammaryGland.Lactation","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Pancreas","Fetal_Intestine","Fetal_Lung","Placenta","Neonatal-Calvaria","MammaryGland.Lactation","Small-Intestine","Lung","Bone-Marrow","Trophoblast-Stem-Cell","Thymus","Stomach","Lung","Kidney","MammaryGland.Virgin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Liver","Bone_Marrow_Mesenchyme","Testis","Bone-Marrow_c-kit","Neonatal-Calvaria","Kidney","Peripheral_Blood","Spleen","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow_c-kit","Neonatal-Heart","Kidney","Fetal-Liver","Pancreas","MammaryGland.Virgin","Thymus","Neonatal-Rib","MammaryGland.Lactation","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Spleen","Small-Intestine","Trophoblast-Stem-Cell","Neonatal-Rib","Bone-Marrow","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Testis","Placenta","Bone-Marrow","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Stomache","Fetal_Intestine","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","Fetal_Lung","Testis","Testis","MammaryGland.Lactation","Thymus","Neonatal-Rib","Testis","Fetal_Stomache","Bone-Marrow","Fetal_Lung","Neonatal-Skin","Ovary","Prostate","Peripheral_Blood","Trophoblast-Stem-Cell","Fetal_Lung","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Fetal_Intestine","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Testis","Brain","Trophoblast-Stem-Cell","Neonatal-Rib","Uterus","Bone-Marrow_c-kit","Neonatal-Muscle","Neonatal-Muscle","Fetal_Lung","Neonatal-Calvaria","Testis","Liver","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Peripheral_Blood","Small-Intestine","MammaryGland.Pregnancy","Kidney","Testis","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Fetal_Lung","Ovary","Fetal_Brain","Thymus","Fetal_Lung","Neonatal-Muscle","Ovary","Kidney","MammaryGland.Virgin","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Calvaria","Neonatal-Heart","Lung","Neonatal-Heart","Thymus","Bladder","Testis","Bone-Marrow_c-kit","Prostate","Testis","Small-Intestine","Ovary","Neonatal-Heart","Embryonic-Stem-Cell","Lung","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Testis","Neonatal-Muscle","Ovary","Testis","MammaryGland.Virgin","Bone-Marrow","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone-Marrow_c-kit","Fetal_Lung","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Neonatal-Skin","Fetal_Brain","Embryonic-Stem-Cell","Testis","Neonatal-Rib","Fetal_Lung","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Rib","Brain","Testis","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Liver","Trophoblast-Stem-Cell","MammaryGland.Lactation","Prostate","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow","Neonatal-Rib","Ovary","Trophoblast-Stem-Cell","Testis","Fetal_Lung","Spleen","Bone-Marrow_c-kit","Neonatal-Muscle","MammaryGland.Involution","Trophoblast-Stem-Cell","Lung","Trophoblast-Stem-Cell","Testis","Fetal_Lung","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Stomache","Fetal_Lung","Bone-Marrow_c-kit","MammaryGland.Involution","Fetal_Intestine","Brain","Peripheral_Blood","Bone-Marrow_c-kit","Fetal_Intestine","Bladder","Neonatal-Rib","Fetal_Brain","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Fetal-Liver","Testis","Bladder","Fetal_Intestine","MammaryGland.Pregnancy","Neonatal-Calvaria","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bladder","Embryonic-Stem-Cell","MammaryGland.Lactation","Embryonic-Stem-Cell","Prostate","Brain","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Lung","Fetal_Lung","MammaryGland.Pregnancy","Neonatal-Calvaria","MammaryGland.Virgin","Liver","MammaryGland.Lactation","Bone-Marrow_c-kit","Placenta","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","MammaryGland.Virgin","MammaryGland.Virgin","Kidney","Thymus","Fetal_Stomache","Neonatal-Calvaria","Bone-Marrow","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Small-Intestine","Embryonic-Stem-Cell","Neonatal-Rib","Lung","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal-Liver","Fetal_Intestine","Small-Intestine","Bone-Marrow","Brain","Small-Intestine","MammaryGland.Virgin","Neonatal-Muscle","Fetal_Stomache","Embryonic-Stem-Cell","MammaryGland.Virgin","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Neonatal-Calvaria","Neonatal-Skin","Testis","Fetal_Lung","Bone-Marrow_c-kit","Neonatal-Rib","Embryonic-Stem-Cell","MammaryGland.Virgin","MammaryGland.Virgin","Bone-Marrow_c-kit","Brain","Neonatal-Skin","MammaryGland.Lactation","MammaryGland.Lactation","Trophoblast-Stem-Cell","Neonatal-Muscle","Fetal_Stomache","MammaryGland.Involution","Testis","Trophoblast-Stem-Cell","Thymus","Bone-Marrow_c-kit","Small-Intestine","Embryonic-Stem-Cell","Bladder","Fetal_Brain","Pancreas","Mesenchymal-Stem-Cell-Cultured","Testis","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Neonatal-Calvaria","Neonatal-Rib","MammaryGland.Lactation","Spleen","Bone-Marrow","Small-Intestine","Neonatal-Calvaria","Ovary","Bone-Marrow","Testis","Bone-Marrow_c-kit","MammaryGland.Lactation","MammaryGland.Lactation","Neonatal-Skin","Fetal_Brain","Peripheral_Blood","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Neonatal-Rib","Trophoblast-Stem-Cell","Peripheral_Blood","Bone-Marrow","MammaryGland.Lactation","MammaryGland.Lactation","Bone-Marrow_c-kit","Brain","MammaryGland.Lactation","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Kidney","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Liver","Bone-Marrow_c-kit","MammaryGland.Involution","Neonatal-Muscle","Trophoblast-Stem-Cell","Lung","Brain","Neonatal-Skin","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Fetal-Liver","Bone-Marrow_c-kit","Lung","Trophoblast-Stem-Cell","Testis","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Fetal-Liver","Fetal_Brain","Testis","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Brain","Bone-Marrow","Bone-Marrow_c-kit","Brain","Neonatal-Muscle","MammaryGland.Lactation","Fetal_Brain","Trophoblast-Stem-Cell","Stomach","MammaryGland.Lactation","MammaryGland.Lactation","Neonatal-Heart","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Fetal_Stomache","Bone-Marrow_c-kit","Prostate","Liver","Mesenchymal-Stem-Cell-Cultured","Uterus","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Muscle","Brain","Ovary","MammaryGland.Lactation","Testis","Peripheral_Blood","Fetal_Stomache","Neonatal-Rib","Placenta","Bone-Marrow","Liver","Fetal_Intestine","Bone-Marrow_c-kit","Ovary","MammaryGland.Involution","MammaryGland.Lactation","Pancreas","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Neonatal-Heart","Fetal_Stomache","Ovary","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Bladder","Lung","MammaryGland.Lactation","Uterus","Neonatal-Skin","Neonatal-Skin","Placenta","Trophoblast-Stem-Cell","Neonatal-Heart","Testis","Neonatal-Heart","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Testis","Neonatal-Calvaria","MammaryGland.Virgin","Liver","Fetal_Lung","Bone-Marrow","Pancreas","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Neonatal-Skin","Trophoblast-Stem-Cell","Muscle","Testis","Bone-Marrow_c-kit","Kidney","Bone-Marrow_c-kit","Ovary","Neonatal-Heart","MammaryGland.Lactation","Trophoblast-Stem-Cell","Stomach","Ovary","Ovary","Lung","Pancreas","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Lung","Embryonic-Stem-Cell","Placenta","Placenta","Bone-Marrow","Thymus","Bladder","Bone-Marrow_c-kit","Fetal_Lung","Neonatal-Heart","Bone_Marrow_Mesenchyme","Testis","Bone-Marrow","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","MammaryGland.Pregnancy","Stomach","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Muscle","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Liver","Testis","Bone-Marrow_c-kit","Fetal_Intestine","Peripheral_Blood","Neonatal-Muscle","MammaryGland.Involution","Neonatal-Muscle","Prostate","Lung","Bone_Marrow_Mesenchyme","Fetal_Lung","Neonatal-Rib","Brain","Bone-Marrow_c-kit","Lung","Testis","MammaryGland.Pregnancy","Neonatal-Rib","Trophoblast-Stem-Cell","Peripheral_Blood","Placenta","Bone-Marrow_c-kit","Fetal_Lung","Neonatal-Calvaria","MammaryGland.Lactation","Neonatal-Calvaria","Thymus","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Involution","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Rib","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Embryonic-Mesenchyme","Neonatal-Rib","Kidney","Pancreas","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Liver","MammaryGland.Virgin","Placenta","Thymus","Liver","Trophoblast-Stem-Cell","MammaryGland.Lactation","Trophoblast-Stem-Cell","Spleen","Small-Intestine","Neonatal-Skin","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bladder","Bone-Marrow_c-kit","Fetal_Intestine","Trophoblast-Stem-Cell","Lung","Kidney","MammaryGland.Involution","Neonatal-Muscle","Testis","Trophoblast-Stem-Cell","Fetal_Brain","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Pancreas","Stomach","MammaryGland.Pregnancy","Fetal_Lung","Testis","Thymus","Ovary","Neonatal-Rib","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","Embryonic-Stem-Cell","Placenta","Kidney","Pancreas","Bone-Marrow_c-kit","MammaryGland.Virgin","MammaryGland.Pregnancy","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","Fetal-Liver","Bone-Marrow_c-kit","Neonatal-Skin","Testis","Thymus","Trophoblast-Stem-Cell","Placenta","Pancreas","Fetal_Intestine","Embryonic-Stem-Cell","Testis","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow","Stomach","Bone-Marrow","Kidney","Fetal_Brain","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Kidney","Neonatal-Muscle","Testis","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Fetal_Lung","Testis","Bone-Marrow","MammaryGland.Involution","Bone-Marrow_c-kit","Neonatal-Rib","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Thymus","MammaryGland.Lactation","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Fetal_Lung","MammaryGland.Involution","Bone-Marrow","Neonatal-Heart","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Peripheral_Blood","Trophoblast-Stem-Cell","Lung","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Muscle","Stomach","Fetal_Lung","Bladder","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Muscle","Liver","MammaryGland.Involution","Fetal_Lung","MammaryGland.Involution","Fetal_Stomache","Testis","Neonatal-Heart","Testis","Small-Intestine","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Thymus","Bone-Marrow_c-kit","Testis","MammaryGland.Involution","Trophoblast-Stem-Cell","Fetal_Intestine","Lung","Fetal-Liver","Fetal_Brain","Fetal_Intestine","Embryonic-Mesenchyme","Bone-Marrow","Trophoblast-Stem-Cell","MammaryGland.Virgin","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Fetal_Lung","MammaryGland.Lactation","Testis","Thymus","Ovary","Neonatal-Skin","Testis","Trophoblast-Stem-Cell","Lung","Testis","Trophoblast-Stem-Cell","Placenta","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow_c-kit","Peripheral_Blood","Neonatal-Calvaria","Stomach","Peripheral_Blood","Testis","Prostate","MammaryGland.Lactation","MammaryGland.Lactation","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow","Bone-Marrow_c-kit","Pancreas","MammaryGland.Involution","Embryonic-Stem-Cell","Ovary","Fetal_Stomache","Bone-Marrow_c-kit","MammaryGland.Involution","Fetal_Lung","Testis","Liver","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone-Marrow","Peripheral_Blood","Uterus","Mesenchymal-Stem-Cell-Cultured","Liver","Neonatal-Rib","Kidney","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Uterus","Thymus","Bone_Marrow_Mesenchyme","Peripheral_Blood","Fetal_Lung","Placenta","Neonatal-Skin","Brain","Bone-Marrow","Small-Intestine","Small-Intestine","Neonatal-Rib","Spleen","Bone-Marrow_c-kit","Neonatal-Heart","MammaryGland.Virgin","Fetal_Brain","Neonatal-Heart","MammaryGland.Lactation","Thymus","Embryonic-Stem-Cell","Peripheral_Blood","Liver","Embryonic-Stem-Cell","Ovary","MammaryGland.Lactation","Fetal_Intestine","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Muscle","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Bone-Marrow","Neonatal-Rib","Peripheral_Blood","Small-Intestine","Neonatal-Rib","Stomach","Neonatal-Muscle","Bone-Marrow_c-kit","Neonatal-Rib","Fetal_Brain","Bone-Marrow","Trophoblast-Stem-Cell","Lung","Spleen","Neonatal-Rib","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Placenta","Trophoblast-Stem-Cell","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Peripheral_Blood","Small-Intestine","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Fetal_Lung","Uterus","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","MammaryGland.Lactation","Bone-Marrow_c-kit","Liver","Lung","Pancreas","Neonatal-Calvaria","Neonatal-Skin","MammaryGland.Lactation","MammaryGland.Pregnancy","Small-Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Prostate","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Pancreas","Lung","Neonatal-Calvaria","Fetal_Intestine","Thymus","Neonatal-Rib","Trophoblast-Stem-Cell","Peripheral_Blood","Fetal_Intestine","Peripheral_Blood","Lung","Embryonic-Stem-Cell","Neonatal-Calvaria","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bone-Marrow_c-kit","Neonatal-Skin","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Brain","Neonatal-Muscle","Bone-Marrow_c-kit","Fetal_Lung","Neonatal-Skin","Small-Intestine","MammaryGland.Involution","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Lung","Trophoblast-Stem-Cell","Liver","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Ovary","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow_c-kit","Fetal_Stomache","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Liver","Ovary","Liver","Kidney","Embryonic-Stem-Cell","Fetal_Lung","MammaryGland.Lactation","Placenta","MammaryGland.Virgin","MammaryGland.Virgin","Embryonic-Stem-Cell","Spleen","Spleen","Peripheral_Blood","Trophoblast-Stem-Cell","MammaryGland.Virgin","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Lung","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Testis","Ovary","Fetal_Intestine","Testis","Small-Intestine","MammaryGland.Virgin","Fetal_Intestine","MammaryGland.Lactation","MammaryGland.Involution","Lung","Neonatal-Muscle","Fetal_Lung","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","MammaryGland.Virgin","Neonatal-Rib","Bone-Marrow","Ovary","Mesenchymal-Stem-Cell-Cultured","Fetal-Liver","MammaryGland.Lactation","Embryonic-Mesenchyme","Lung","Neonatal-Calvaria","Brain","Ovary","Placenta","Embryonic-Stem-Cell","Fetal_Brain","MammaryGland.Lactation","Bone-Marrow","Lung","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Testis","Fetal_Lung","Fetal_Brain","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Calvaria","Lung","Neonatal-Rib","Spleen","Bone-Marrow_c-kit","Neonatal-Calvaria","Placenta","Lung","Kidney","Ovary","Embryonic-Stem-Cell","Kidney","Peripheral_Blood","Trophoblast-Stem-Cell","Fetal_Brain","Trophoblast-Stem-Cell","Placenta","Bone-Marrow_c-kit","Ovary","Lung","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Neonatal-Heart","Bone-Marrow_c-kit","Testis","Small-Intestine","Placenta","Mesenchymal-Stem-Cell-Cultured","Placenta","Pancreas","Prostate","Embryonic-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Peripheral_Blood","Bone-Marrow_c-kit","Neonatal-Skin","Bone-Marrow","MammaryGland.Virgin","Neonatal-Rib","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Placenta","Fetal_Lung","MammaryGland.Lactation","Peripheral_Blood","Bone-Marrow","Bone-Marrow_c-kit","Peripheral_Blood","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Thymus","Trophoblast-Stem-Cell","Placenta","Bone-Marrow_c-kit","Bladder","Embryonic-Stem-Cell","Kidney","Mesenchymal-Stem-Cell-Cultured","Lung","Fetal_Intestine","Muscle","Embryonic-Stem-Cell","Peripheral_Blood","Small-Intestine","Peripheral_Blood","Fetal_Intestine","Trophoblast-Stem-Cell","Fetal_Lung","Testis","Neonatal-Heart","Neonatal-Calvaria","Kidney","Lung","Small-Intestine","Testis","Testis","Neonatal-Rib","Thymus","MammaryGland.Involution","Embryonic-Stem-Cell","MammaryGland.Involution","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Fetal_Stomache","Spleen","Brain","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Bone-Marrow","Prostate","Lung","Bone-Marrow","Neonatal-Muscle","Peripheral_Blood","Trophoblast-Stem-Cell","Fetal_Lung","Bone-Marrow_c-kit","MammaryGland.Lactation","Uterus","Fetal_Lung","Neonatal-Rib","Lung","Brain","Trophoblast-Stem-Cell","Neonatal-Heart","Trophoblast-Stem-Cell","Fetal-Liver","Testis","Trophoblast-Stem-Cell","Testis","Embryonic-Stem-Cell","Fetal_Brain","Bone-Marrow_c-kit","Kidney","Bone_Marrow_Mesenchyme","Ovary","MammaryGland.Virgin","Neonatal-Heart","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Neonatal-Skin","Neonatal-Skin","Fetal_Intestine","Neonatal-Calvaria","Liver","Ovary","Neonatal-Heart","Thymus","Embryonic-Mesenchyme","MammaryGland.Pregnancy","Muscle","Uterus","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Small-Intestine","MammaryGland.Lactation","Stomach","Neonatal-Skin","Testis","Kidney","MammaryGland.Pregnancy","Lung","Testis","Testis","Fetal_Lung","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","Fetal_Stomache","Fetal_Brain","Fetal-Liver","Placenta","Testis","Fetal_Stomache","MammaryGland.Pregnancy","Bone-Marrow","Bone-Marrow_c-kit","Neonatal-Muscle","MammaryGland.Lactation","Bone-Marrow","Bladder","MammaryGland.Pregnancy","Placenta","Testis","Lung","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Peripheral_Blood","MammaryGland.Pregnancy","Bone-Marrow","MammaryGland.Lactation","MammaryGland.Involution","Bone-Marrow_c-kit","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","MammaryGland.Lactation","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Placenta","Fetal_Lung","Testis","Small-Intestine","Fetal_Stomache","Neonatal-Rib","Brain","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Neonatal-Skin","Bone-Marrow_c-kit","Testis","Ovary","Liver","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Lung","Kidney","MammaryGland.Involution","Bone_Marrow_Mesenchyme","Neonatal-Rib","Trophoblast-Stem-Cell","Lung","Bone-Marrow_c-kit","Fetal_Stomache","Spleen","Fetal_Brain","Embryonic-Stem-Cell","MammaryGland.Virgin","Fetal_Lung","Trophoblast-Stem-Cell","Peripheral_Blood","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal-Liver","Neonatal-Calvaria","Trophoblast-Stem-Cell","MammaryGland.Lactation","Fetal_Brain","Uterus","Ovary","Bladder","Placenta","Kidney","Brain","Testis","MammaryGland.Lactation","Trophoblast-Stem-Cell","Prostate","Bone_Marrow_Mesenchyme","Thymus","Small-Intestine","Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Pancreas","MammaryGland.Pregnancy","Neonatal-Muscle","Kidney","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Virgin","Bone-Marrow_c-kit","MammaryGland.Lactation","MammaryGland.Pregnancy","Peripheral_Blood","MammaryGland.Lactation","Testis","Trophoblast-Stem-Cell","Muscle","Kidney","Small-Intestine","Trophoblast-Stem-Cell","Fetal_Lung","Trophoblast-Stem-Cell","Small-Intestine","Neonatal-Calvaria","Bone-Marrow_c-kit","Neonatal-Muscle","MammaryGland.Lactation","Small-Intestine","Fetal_Brain","Bone-Marrow","Bone-Marrow_c-kit","Thymus","Small-Intestine","Fetal_Lung","Fetal_Intestine","Embryonic-Mesenchyme","Neonatal-Muscle","Peripheral_Blood","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Small-Intestine","Testis","Uterus","Lung","Testis","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","Testis","Embryonic-Mesenchyme","Testis","Peripheral_Blood","Pancreas","Embryonic-Stem-Cell","Neonatal-Skin","Bone-Marrow_c-kit","Brain","Bone-Marrow_c-kit","Lung","Testis","MammaryGland.Lactation","Testis","Pancreas","Uterus","Testis","Bone-Marrow_c-kit","Fetal_Brain","Testis","Trophoblast-Stem-Cell","Fetal_Stomache","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal-Liver","Trophoblast-Stem-Cell","Fetal_Lung","Bone_Marrow_Mesenchyme","Bone-Marrow","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Neonatal-Rib","Testis","Liver","Neonatal-Rib","Neonatal-Muscle","Neonatal-Muscle","Trophoblast-Stem-Cell","Neonatal-Rib","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Testis","Lung","Bone-Marrow_c-kit","Neonatal-Muscle","MammaryGland.Lactation","Muscle","Ovary","Bone-Marrow_c-kit","MammaryGland.Virgin","Bone-Marrow_c-kit","Fetal_Lung","Bone-Marrow_c-kit","Fetal_Intestine","Small-Intestine","Fetal_Lung","Ovary","Prostate","Fetal_Lung","Small-Intestine","Brain","MammaryGland.Lactation","Fetal_Intestine","MammaryGland.Lactation","Bone-Marrow_c-kit","Neonatal-Skin","Pancreas","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow","Lung","Trophoblast-Stem-Cell","Brain","Brain","Small-Intestine","MammaryGland.Involution","Small-Intestine","Liver","Fetal_Lung","Fetal_Brain","Bone-Marrow_c-kit","Testis","Ovary","Embryonic-Stem-Cell","Fetal-Liver","Mesenchymal-Stem-Cell-Cultured","Lung","MammaryGland.Involution","Ovary","Bone-Marrow_c-kit","Fetal_Intestine","Bladder","MammaryGland.Involution","MammaryGland.Lactation","Brain","Bone-Marrow","Bone-Marrow","Fetal_Brain","Placenta","Testis","Kidney","Liver","Bone-Marrow_c-kit","Kidney","Trophoblast-Stem-Cell","Placenta","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Neonatal-Rib","Peripheral_Blood","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Testis","Bone-Marrow_c-kit","Fetal_Brain","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Fetal_Intestine","Fetal_Intestine","Testis","Liver","Neonatal-Muscle","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Neonatal-Calvaria","Ovary","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Placenta","Embryonic-Mesenchyme","MammaryGland.Involution","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Lung","Bone-Marrow","Trophoblast-Stem-Cell","Neonatal-Calvaria","Trophoblast-Stem-Cell","MammaryGland.Lactation","Ovary","Neonatal-Rib","MammaryGland.Involution","Fetal_Stomache","Brain","Neonatal-Calvaria","Fetal_Stomache","Pancreas","Fetal_Intestine","Neonatal-Muscle","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Brain","Trophoblast-Stem-Cell","MammaryGland.Lactation","Embryonic-Stem-Cell","Testis","Placenta","Neonatal-Muscle","Peripheral_Blood","Lung","Neonatal-Calvaria","Fetal_Intestine","Bone-Marrow_c-kit","Testis","Bone-Marrow","Fetal_Brain","Bone-Marrow","Trophoblast-Stem-Cell","Small-Intestine","Embryonic-Stem-Cell","Fetal_Lung","Uterus","Fetal_Intestine","Thymus","Trophoblast-Stem-Cell","Lung","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow","Testis","Bone-Marrow_c-kit","Fetal_Intestine","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Rib","Embryonic-Stem-Cell","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Kidney","Pancreas","Fetal_Stomache","MammaryGland.Virgin","Prostate","Liver","Neonatal-Heart","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Testis","Bone-Marrow_c-kit","Neonatal-Calvaria","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Neonatal-Calvaria","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Neonatal-Muscle","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Placenta","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Testis","Bone-Marrow_c-kit","Brain","Fetal_Lung","Neonatal-Calvaria","Neonatal-Muscle","Fetal_Intestine","MammaryGland.Involution","MammaryGland.Lactation","MammaryGland.Involution","MammaryGland.Pregnancy","Bone-Marrow","Trophoblast-Stem-Cell","Fetal_Lung","Neonatal-Skin","Brain","Neonatal-Calvaria","Testis","Lung","Pancreas","Mesenchymal-Stem-Cell-Cultured","Ovary","Embryonic-Mesenchyme","Lung","Ovary","Trophoblast-Stem-Cell","Placenta","Pancreas","Testis","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Thymus","Testis","Neonatal-Rib","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Rib","Bone-Marrow_c-kit","Neonatal-Calvaria","Trophoblast-Stem-Cell","Fetal_Stomache","MammaryGland.Lactation","Neonatal-Rib","Neonatal-Calvaria","Testis","Liver","Mesenchymal-Stem-Cell-Cultured","Brain","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Embryonic-Stem-Cell","MammaryGland.Involution","Bone-Marrow_c-kit","Bone-Marrow","Ovary","Small-Intestine","Neonatal-Calvaria","Neonatal-Heart","Testis","Testis","Small-Intestine","Trophoblast-Stem-Cell","Fetal_Intestine","Fetal_Intestine","MammaryGland.Lactation","MammaryGland.Virgin","Embryonic-Stem-Cell","Peripheral_Blood","Fetal_Lung","Thymus","Thymus","Testis","Bone_Marrow_Mesenchyme","Brain","Neonatal-Skin","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Testis","MammaryGland.Pregnancy","Liver","Trophoblast-Stem-Cell","MammaryGland.Involution","Trophoblast-Stem-Cell","Bladder","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Placenta","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Heart","MammaryGland.Lactation","Neonatal-Heart","Thymus","Testis","Kidney","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Uterus","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Lung","Bladder","Bone-Marrow_c-kit","Placenta","Fetal_Lung","Bone-Marrow_c-kit","MammaryGland.Virgin","Ovary","Testis","MammaryGland.Pregnancy","Testis","MammaryGland.Lactation","MammaryGland.Virgin","Fetal_Brain","MammaryGland.Lactation","Brain","Testis","Placenta","Neonatal-Heart","Peripheral_Blood","Fetal_Stomache","MammaryGland.Lactation","Testis","Testis","Fetal_Stomache","Uterus","Bone-Marrow_c-kit","Bone-Marrow","Fetal_Brain","Neonatal-Calvaria","MammaryGland.Involution","Spleen","Neonatal-Muscle","Peripheral_Blood","Brain","Trophoblast-Stem-Cell","Muscle","Embryonic-Stem-Cell","Neonatal-Calvaria","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow","Brain","Trophoblast-Stem-Cell","Uterus","Testis","MammaryGland.Lactation","Fetal_Intestine","Ovary","Testis","Neonatal-Heart","Peripheral_Blood","Embryonic-Stem-Cell","Lung","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Lung","Fetal_Lung","Neonatal-Calvaria","Fetal_Brain","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Prostate","Neonatal-Calvaria","Kidney","Testis","Fetal-Liver","Pancreas","Trophoblast-Stem-Cell","MammaryGland.Involution","Fetal_Brain","Peripheral_Blood","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Bone-Marrow","Bladder","Peripheral_Blood","Ovary","Testis","Neonatal-Muscle","MammaryGland.Pregnancy","Fetal_Intestine","Trophoblast-Stem-Cell","MammaryGland.Virgin","MammaryGland.Lactation","Uterus","Bone-Marrow_c-kit","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Brain","Lung","Ovary","Trophoblast-Stem-Cell","Fetal_Lung","Bone-Marrow_c-kit","Thymus","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Testis","Embryonic-Stem-Cell","MammaryGland.Lactation","Testis","Fetal_Lung","Thymus","Neonatal-Skin","Bladder","MammaryGland.Lactation","Thymus","Bone_Marrow_Mesenchyme","Fetal_Intestine","Bone_Marrow_Mesenchyme","Testis","Pancreas","Neonatal-Heart","Ovary","Neonatal-Muscle","Bone-Marrow","Bone-Marrow","Neonatal-Rib","MammaryGland.Pregnancy","Testis","Peripheral_Blood","Brain","Fetal_Intestine","Stomach","Bladder","MammaryGland.Lactation","Peripheral_Blood","Bone-Marrow_c-kit","Stomach","Bladder","Fetal_Intestine","Trophoblast-Stem-Cell","MammaryGland.Lactation","MammaryGland.Involution","MammaryGland.Pregnancy","Bone-Marrow","Neonatal-Heart","Bone-Marrow_c-kit","Peripheral_Blood","MammaryGland.Lactation","Fetal_Intestine","Trophoblast-Stem-Cell","Thymus","Prostate","MammaryGland.Lactation","Prostate","Bone-Marrow","Bone_Marrow_Mesenchyme","Testis","Liver","Small-Intestine","Neonatal-Heart","Neonatal-Heart","MammaryGland.Involution","Ovary","Neonatal-Skin","Neonatal-Heart","Bone-Marrow_c-kit","Peripheral_Blood","Fetal_Lung","Bone-Marrow_c-kit","Bone-Marrow","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Placenta","MammaryGland.Lactation","Bone-Marrow","Ovary","Trophoblast-Stem-Cell","Peripheral_Blood","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Bone-Marrow_c-kit","Lung","Bone-Marrow","Small-Intestine","Muscle","Testis","Neonatal-Rib","Peripheral_Blood","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Thymus","Neonatal-Calvaria","Fetal_Stomache","Trophoblast-Stem-Cell","Neonatal-Skin","Fetal_Lung","Muscle","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Skin","Small-Intestine","Testis","Bone-Marrow_c-kit","Neonatal-Rib","Neonatal-Muscle","Ovary","Peripheral_Blood","Peripheral_Blood","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","MammaryGland.Lactation","Testis","Lung","Spleen","Prostate","Testis","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Bone-Marrow_c-kit","Pancreas","Testis","Bone-Marrow_c-kit","Peripheral_Blood","MammaryGland.Virgin","MammaryGland.Virgin","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Muscle","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow","Testis","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Involution","Neonatal-Skin","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","Fetal_Brain","Bone-Marrow_c-kit","Neonatal-Heart","Trophoblast-Stem-Cell","Bone-Marrow","Testis","Lung","Neonatal-Muscle","Bone-Marrow","Spleen","Liver","Neonatal-Heart","Prostate","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal_Stomache","Testis","Thymus","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","Mesenchymal-Stem-Cell-Cultured","Liver","Bone-Marrow_c-kit","Fetal_Stomache","MammaryGland.Virgin","MammaryGland.Involution","Embryonic-Stem-Cell","Peripheral_Blood","Small-Intestine","Uterus","Neonatal-Heart","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Kidney","Lung","Peripheral_Blood","Prostate","Bone-Marrow_c-kit","Fetal_Lung","Peripheral_Blood","Uterus","Testis","Liver","Uterus","Bone-Marrow_c-kit","Bone-Marrow","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Fetal_Brain","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Neonatal-Skin","Neonatal-Muscle","Fetal_Lung","Embryonic-Mesenchyme","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Uterus","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Lung","Kidney","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","Prostate","Thymus","Bone_Marrow_Mesenchyme","Fetal-Liver","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow","Testis","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Fetal_Lung","Neonatal-Calvaria","Fetal_Brain","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Uterus","Thymus","MammaryGland.Virgin","Brain","Neonatal-Heart","MammaryGland.Lactation","Fetal_Brain","MammaryGland.Lactation","Fetal_Brain","Uterus","Bone-Marrow_c-kit","Uterus","Fetal_Stomache","Kidney","Fetal_Intestine","MammaryGland.Virgin","MammaryGland.Lactation","Ovary","Peripheral_Blood","Testis","MammaryGland.Pregnancy","MammaryGland.Involution","Neonatal-Heart","Lung","Fetal_Stomache","Small-Intestine","Spleen","Liver","Spleen","Bone-Marrow_c-kit","Fetal_Stomache","Trophoblast-Stem-Cell","Neonatal-Rib","Bone_Marrow_Mesenchyme","Kidney","Bone-Marrow_c-kit","MammaryGland.Involution","Bone_Marrow_Mesenchyme","Lung","Spleen","Placenta","Neonatal-Muscle","Bone-Marrow","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Neonatal-Heart","Bone-Marrow_c-kit","MammaryGland.Involution","Neonatal-Skin","Lung","Neonatal-Calvaria","Neonatal-Muscle","Lung","Neonatal-Calvaria","Lung","MammaryGland.Involution","Neonatal-Skin","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Lung","Testis","Neonatal-Calvaria","MammaryGland.Lactation","Prostate","MammaryGland.Pregnancy","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Calvaria","Neonatal-Skin","Ovary","Mesenchymal-Stem-Cell-Cultured","Lung","Thymus","Trophoblast-Stem-Cell","Testis","Placenta","Uterus","Bone-Marrow_c-kit","Ovary","Fetal_Intestine","Liver","Neonatal-Skin","Peripheral_Blood","Embryonic-Mesenchyme","Ovary","Kidney","Neonatal-Heart","Bone-Marrow","Bone-Marrow_c-kit","Thymus","Trophoblast-Stem-Cell","MammaryGland.Lactation","Uterus","Fetal_Stomache","MammaryGland.Involution","Neonatal-Calvaria","MammaryGland.Lactation","Neonatal-Rib","Bone-Marrow_c-kit","Ovary","Peripheral_Blood","Small-Intestine","MammaryGland.Pregnancy","Bone-Marrow","Neonatal-Rib","Bone-Marrow","Lung","Trophoblast-Stem-Cell","Pancreas","Neonatal-Muscle","Neonatal-Heart","Testis","Bone-Marrow_c-kit","Prostate","MammaryGland.Lactation","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Lung","Bone-Marrow_c-kit","Ovary","Small-Intestine","Bone-Marrow","Spleen","Brain","Peripheral_Blood","Pancreas","Fetal_Brain","Small-Intestine","Placenta","Neonatal-Skin","Testis","Fetal-Liver","Small-Intestine","Bone-Marrow_c-kit","Testis","Bone-Marrow_c-kit","Placenta","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Testis","Neonatal-Calvaria","Embryonic-Stem-Cell","Neonatal-Calvaria","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Virgin","Neonatal-Calvaria","Small-Intestine","Fetal_Lung","Fetal_Brain","MammaryGland.Lactation","Uterus","Fetal_Lung","Testis","Neonatal-Skin","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Testis","Fetal-Liver","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Kidney","Trophoblast-Stem-Cell","MammaryGland.Virgin","Bladder","Neonatal-Rib","Bone-Marrow","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Testis","Fetal_Lung","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Fetal_Lung","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Peripheral_Blood","Brain","Kidney","Peripheral_Blood","MammaryGland.Virgin","Thymus","Fetal_Intestine","Embryonic-Mesenchyme","Small-Intestine","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","MammaryGland.Virgin","Trophoblast-Stem-Cell","Kidney","Bone-Marrow_c-kit","Spleen","MammaryGland.Virgin","MammaryGland.Pregnancy","Thymus","Bladder","Testis","Small-Intestine","MammaryGland.Lactation","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Rib","Placenta","Fetal_Brain","Embryonic-Stem-Cell","Bone-Marrow","MammaryGland.Lactation","MammaryGland.Virgin","Small-Intestine","Bone-Marrow_c-kit","Bladder","Fetal_Stomache","Peripheral_Blood","MammaryGland.Virgin","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Neonatal-Rib","MammaryGland.Virgin","MammaryGland.Involution","Neonatal-Heart","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Muscle","Trophoblast-Stem-Cell","Pancreas","Lung","Bone-Marrow_c-kit","Fetal_Intestine","Peripheral_Blood","Trophoblast-Stem-Cell","Neonatal-Muscle","Trophoblast-Stem-Cell","Prostate","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Ovary","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Uterus","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Fetal_Stomache","Testis","Trophoblast-Stem-Cell","Uterus","MammaryGland.Pregnancy","Liver","Neonatal-Rib","Uterus","MammaryGland.Involution","Fetal_Lung","Neonatal-Calvaria","Peripheral_Blood","MammaryGland.Virgin","Trophoblast-Stem-Cell","Neonatal-Heart","Small-Intestine","Bone_Marrow_Mesenchyme","Testis","Prostate","Fetal_Stomache","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Placenta","Bone-Marrow_c-kit","MammaryGland.Involution","MammaryGland.Involution","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Lung","Pancreas","Lung","Brain","Fetal_Stomache","Bone_Marrow_Mesenchyme","Fetal-Liver","Fetal-Liver","Fetal_Intestine","Stomach","Neonatal-Skin","Fetal_Brain","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Ovary","MammaryGland.Lactation","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Involution","Testis","Trophoblast-Stem-Cell","Fetal-Liver","Testis","Bone-Marrow_c-kit","Small-Intestine","MammaryGland.Involution","Lung","Testis","MammaryGland.Involution","Thymus","Liver","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Bladder","Bone-Marrow_c-kit","Neonatal-Rib","Fetal_Lung","Thymus","Kidney","Bone-Marrow_c-kit","Kidney","Bone-Marrow_c-kit","Bladder","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Small-Intestine","Bone-Marrow_c-kit","MammaryGland.Lactation","Thymus","Neonatal-Skin","Fetal_Brain","Bone-Marrow_c-kit","Peripheral_Blood","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Ovary","Bone-Marrow_c-kit","Fetal_Brain","Uterus","Mesenchymal-Stem-Cell-Cultured","Pancreas","Neonatal-Heart","Peripheral_Blood","Trophoblast-Stem-Cell","Neonatal-Skin","Bone-Marrow_c-kit","Neonatal-Rib","Uterus","Lung","Fetal_Brain","Fetal_Intestine","Prostate","Bone-Marrow","Thymus","Neonatal-Heart","Testis","Testis","Neonatal-Rib","Kidney","Trophoblast-Stem-Cell","Fetal_Brain","Embryonic-Mesenchyme","Ovary","Neonatal-Heart","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Liver","Testis","Bone_Marrow_Mesenchyme","Testis","Brain","Brain","MammaryGland.Involution","Bone-Marrow","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","MammaryGland.Virgin","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Kidney","Fetal_Intestine","Embryonic-Stem-Cell","Placenta","Brain","Spleen","MammaryGland.Lactation","Neonatal-Skin","Testis","Testis","Brain","Trophoblast-Stem-Cell","Neonatal-Muscle","Ovary","Thymus","Bone_Marrow_Mesenchyme","Liver","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Lung","Neonatal-Heart","Fetal_Brain","Prostate","Trophoblast-Stem-Cell","Small-Intestine","Trophoblast-Stem-Cell","Peripheral_Blood","Lung","Liver","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Liver","Trophoblast-Stem-Cell","Small-Intestine","Thymus","Neonatal-Heart","Fetal_Intestine","Testis","Spleen","Embryonic-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","Neonatal-Heart","Trophoblast-Stem-Cell","Fetal_Brain","Uterus","Stomach","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Thymus","Fetal_Brain","Prostate","MammaryGland.Pregnancy","Pancreas","Bone-Marrow_c-kit","Neonatal-Muscle","Testis","Trophoblast-Stem-Cell","Testis","Fetal_Lung","Small-Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Small-Intestine","Neonatal-Rib","Trophoblast-Stem-Cell","Fetal_Intestine","Testis","MammaryGland.Lactation","Testis","Trophoblast-Stem-Cell","Prostate","Ovary","Embryonic-Stem-Cell","Prostate","Lung","Testis","Embryonic-Mesenchyme","Thymus","Bone-Marrow","Trophoblast-Stem-Cell","Liver","Neonatal-Muscle","MammaryGland.Virgin","Ovary","MammaryGland.Involution","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Lung","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Virgin","Ovary","Prostate","Neonatal-Rib","Trophoblast-Stem-Cell","Neonatal-Calvaria","Trophoblast-Stem-Cell","Fetal_Lung","Thymus","Bone-Marrow_c-kit","Neonatal-Calvaria","Brain","MammaryGland.Pregnancy","Thymus","MammaryGland.Virgin","MammaryGland.Lactation","Trophoblast-Stem-Cell","Kidney","Spleen","Fetal_Brain","Embryonic-Mesenchyme","Neonatal-Rib","Trophoblast-Stem-Cell","Small-Intestine","Fetal_Lung","Fetal_Brain","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Calvaria","Lung","Placenta","Trophoblast-Stem-Cell","Bone-Marrow","MammaryGland.Involution","Fetal_Brain","Trophoblast-Stem-Cell","Fetal_Intestine","Liver","Lung","Embryonic-Mesenchyme","Fetal-Liver","Uterus","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Neonatal-Calvaria","Testis","Peripheral_Blood","Bone-Marrow_c-kit","Small-Intestine","Fetal_Stomache","Embryonic-Mesenchyme","Prostate","MammaryGland.Lactation","Fetal_Brain","Bone_Marrow_Mesenchyme","Bone-Marrow","Testis","MammaryGland.Pregnancy","Kidney","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Testis","Trophoblast-Stem-Cell","Thymus","Thymus","Lung","Bone-Marrow_c-kit","Testis","Placenta","Stomach","MammaryGland.Virgin","Placenta","Liver","Small-Intestine","Testis","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Small-Intestine","MammaryGland.Pregnancy","Bladder","Small-Intestine","Thymus","Fetal_Stomache","Lung","Bone-Marrow_c-kit","Testis","Bone_Marrow_Mesenchyme","Thymus","Fetal_Stomache","Testis","MammaryGland.Pregnancy","Testis","Bone-Marrow_c-kit","MammaryGland.Virgin","Testis","Bone_Marrow_Mesenchyme","Testis","Fetal_Intestine","Bone-Marrow_c-kit","Bone-Marrow","Small-Intestine","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone-Marrow","Neonatal-Calvaria","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Neonatal-Heart","Neonatal-Calvaria","Trophoblast-Stem-Cell","Neonatal-Skin","Placenta","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Neonatal-Skin","Trophoblast-Stem-Cell","Testis","Pancreas","Neonatal-Rib","MammaryGland.Pregnancy","Bone-Marrow","MammaryGland.Virgin","Bone-Marrow","Bone-Marrow_c-kit","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Virgin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Ovary","Neonatal-Muscle","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal_Lung","Peripheral_Blood","Bone-Marrow_c-kit","MammaryGland.Involution","Bone-Marrow_c-kit","Fetal_Stomache","MammaryGland.Pregnancy","Fetal_Lung","Bone-Marrow","Placenta","Testis","Stomach","Testis","Fetal_Brain","Fetal_Lung","Testis","Fetal-Liver","Liver","MammaryGland.Virgin","MammaryGland.Lactation","Neonatal-Calvaria","Stomach","Pancreas","MammaryGland.Lactation","Embryonic-Mesenchyme","Lung","MammaryGland.Lactation","MammaryGland.Involution","Fetal_Stomache","Fetal_Stomache","Pancreas","Lung","Neonatal-Heart","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Rib","MammaryGland.Lactation","Testis","Neonatal-Heart","Muscle","Bone-Marrow_c-kit","Peripheral_Blood","Fetal_Brain","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Virgin","Testis","Fetal_Lung","MammaryGland.Pregnancy","MammaryGland.Virgin","Neonatal-Calvaria","Uterus","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Pancreas","MammaryGland.Virgin","Kidney","Kidney","Bone-Marrow_c-kit","Bone-Marrow","Fetal_Intestine","MammaryGland.Lactation","Bone-Marrow","Fetal_Intestine","Neonatal-Calvaria","Fetal-Liver","Bone-Marrow_c-kit","Prostate","MammaryGland.Virgin","MammaryGland.Involution","Fetal_Brain","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Bone-Marrow","Prostate","Ovary","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Thymus","MammaryGland.Involution","MammaryGland.Lactation","Embryonic-Stem-Cell","Fetal_Intestine","Neonatal-Calvaria","MammaryGland.Virgin","Fetal_Lung","Neonatal-Calvaria","Embryonic-Mesenchyme","Testis","Bone-Marrow","Bladder","Small-Intestine","Fetal_Intestine","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Bone-Marrow","MammaryGland.Involution","Lung","Lung","Peripheral_Blood","MammaryGland.Lactation","Bone-Marrow_c-kit","Lung","Thymus","MammaryGland.Virgin","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Small-Intestine","Fetal_Stomache","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Prostate","Embryonic-Mesenchyme","Neonatal-Calvaria","Fetal_Stomache","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Neonatal-Calvaria","Trophoblast-Stem-Cell","MammaryGland.Lactation","Fetal-Liver","Trophoblast-Stem-Cell","Bladder","Fetal_Brain","Neonatal-Heart","MammaryGland.Lactation","Trophoblast-Stem-Cell","Brain","Lung","Neonatal-Skin","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Lung","Trophoblast-Stem-Cell","Fetal_Stomache","MammaryGland.Lactation","Peripheral_Blood","Bone-Marrow_c-kit","Fetal_Stomache","Testis","Trophoblast-Stem-Cell","Uterus","Mesenchymal-Stem-Cell-Cultured","Brain","Placenta","MammaryGland.Involution","Bone-Marrow","Neonatal-Calvaria","Kidney","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Stomache","Fetal_Stomache","Fetal_Brain","Trophoblast-Stem-Cell","Testis","Neonatal-Rib","Neonatal-Skin","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Lactation","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Kidney","Small-Intestine","Ovary","Bone_Marrow_Mesenchyme","Muscle","Neonatal-Calvaria","Neonatal-Calvaria","Fetal-Liver","Ovary","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Testis","Neonatal-Muscle","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","Neonatal-Calvaria","Embryonic-Mesenchyme","Testis","Peripheral_Blood","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Kidney","Uterus","MammaryGland.Involution","Bone-Marrow_c-kit","Neonatal-Skin","Fetal-Liver","Fetal_Stomache","Testis","Neonatal-Rib","Trophoblast-Stem-Cell","Fetal_Intestine","Placenta","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Skin","Lung","Pancreas","MammaryGland.Virgin","Fetal_Stomache","Fetal_Lung","Embryonic-Stem-Cell","Small-Intestine","Fetal_Stomache","Bone-Marrow","Fetal-Liver","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Peripheral_Blood","Neonatal-Calvaria","Bone-Marrow_c-kit","Kidney","Neonatal-Calvaria","Uterus","Neonatal-Calvaria","Bone-Marrow_c-kit","MammaryGland.Lactation","Ovary","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Lung","Bone-Marrow","Brain","Neonatal-Heart","Lung","Placenta","Bone-Marrow","Bone-Marrow","Brain","Lung","MammaryGland.Virgin","MammaryGland.Virgin","Ovary","Spleen","Fetal_Intestine","Fetal_Stomache","Lung","Bone-Marrow","Ovary","Uterus","Fetal_Lung","Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Heart","Small-Intestine","Bone_Marrow_Mesenchyme","Uterus","Testis","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Lactation","MammaryGland.Virgin","Neonatal-Calvaria","Peripheral_Blood","Trophoblast-Stem-Cell","MammaryGland.Lactation","Trophoblast-Stem-Cell","Lung","Ovary","Fetal_Lung","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bladder","Uterus","Embryonic-Stem-Cell","Fetal_Brain","Fetal_Intestine","MammaryGland.Pregnancy","Small-Intestine","Bone_Marrow_Mesenchyme","Small-Intestine","Trophoblast-Stem-Cell","Liver","Bone_Marrow_Mesenchyme","Small-Intestine","Bone-Marrow_c-kit","Kidney","MammaryGland.Pregnancy","Neonatal-Calvaria","Thymus","Fetal_Brain","Bone-Marrow_c-kit","Neonatal-Calvaria","Small-Intestine","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Virgin","Fetal_Lung","Lung","Small-Intestine","MammaryGland.Lactation","Placenta","Small-Intestine","Pancreas","Placenta","Kidney","Peripheral_Blood","Fetal_Stomache","Fetal_Stomache","Brain","Neonatal-Rib","Neonatal-Rib","Pancreas","Trophoblast-Stem-Cell","Bone-Marrow","Kidney","Bone-Marrow_c-kit","Fetal_Intestine","Fetal_Brain","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Liver","Ovary","Pancreas","Stomach","Neonatal-Calvaria","Small-Intestine","Stomach","Brain","Neonatal-Muscle","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Stomache","Fetal_Brain","Spleen","Neonatal-Rib","Liver","Neonatal-Calvaria","Neonatal-Muscle","Bone-Marrow","MammaryGland.Involution","Lung","Fetal_Lung","Lung","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Thymus","Testis","Pancreas","MammaryGland.Lactation","Embryonic-Mesenchyme","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Ovary","MammaryGland.Lactation","Neonatal-Calvaria","Testis","Stomach","Embryonic-Stem-Cell","Fetal-Liver","Neonatal-Heart","Pancreas","Fetal_Stomache","Fetal_Stomache","Stomach","MammaryGland.Lactation","Embryonic-Stem-Cell","Kidney","Neonatal-Skin","Neonatal-Heart","Neonatal-Calvaria","MammaryGland.Pregnancy","Neonatal-Rib","Kidney","MammaryGland.Virgin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Heart","Kidney","Testis","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Intestine","Uterus","Peripheral_Blood","Thymus","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Kidney","Lung","Fetal_Lung","Bone-Marrow_c-kit","Testis","Bone-Marrow_c-kit","Fetal_Stomache","Neonatal-Calvaria","Testis","Testis","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Pancreas","Fetal_Brain","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Small-Intestine","Trophoblast-Stem-Cell","Neonatal-Calvaria","Stomach","Bone-Marrow","Neonatal-Rib","Bone-Marrow","Bladder","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Ovary","Bone-Marrow_c-kit","Prostate","Uterus","Fetal_Intestine","Embryonic-Stem-Cell","Prostate","Lung","Fetal_Lung","Small-Intestine","MammaryGland.Lactation","Trophoblast-Stem-Cell","Kidney","Bone-Marrow_c-kit","Lung","Testis","MammaryGland.Virgin","Neonatal-Muscle","Lung","Muscle","Trophoblast-Stem-Cell","MammaryGland.Virgin","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Brain","Lung","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Lung","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Lactation","Ovary","Trophoblast-Stem-Cell","Fetal_Lung","Testis","MammaryGland.Virgin","Thymus","Bone-Marrow_c-kit","Neonatal-Muscle","Trophoblast-Stem-Cell","Fetal_Lung","Neonatal-Heart","Brain","Neonatal-Calvaria","Uterus","Peripheral_Blood","Embryonic-Stem-Cell","Pancreas","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Bone-Marrow_c-kit","Small-Intestine","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Neonatal-Heart","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow_c-kit","Fetal_Brain","MammaryGland.Virgin","Lung","Bone-Marrow_c-kit","MammaryGland.Lactation","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Fetal-Liver","Prostate","Thymus","Bone-Marrow_c-kit","Small-Intestine","Lung","Bone-Marrow","Embryonic-Stem-Cell","MammaryGland.Involution","MammaryGland.Lactation","Bone-Marrow_c-kit","Placenta","MammaryGland.Lactation","Bladder","Placenta","Placenta","Fetal_Intestine","Embryonic-Stem-Cell","MammaryGland.Involution","Neonatal-Heart","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Embryonic-Mesenchyme","Neonatal-Skin","MammaryGland.Virgin","Neonatal-Heart","Neonatal-Calvaria","Trophoblast-Stem-Cell","Fetal_Lung","Thymus","Peripheral_Blood","Prostate","Bladder","Pancreas","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Rib","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Lung","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Bone-Marrow","Neonatal-Rib","Testis","Kidney","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Fetal_Intestine","Bone-Marrow_c-kit","Neonatal-Rib","Bone-Marrow","Bone_Marrow_Mesenchyme","MammaryGland.Involution","Bone_Marrow_Mesenchyme","Fetal_Stomache","Fetal_Brain","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Fetal_Stomache","Lung","Small-Intestine","Testis","Kidney","Fetal_Brain","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Kidney","MammaryGland.Virgin","MammaryGland.Involution","Embryonic-Stem-Cell","Bone-Marrow","Bone-Marrow","Stomach","Neonatal-Skin","Bone-Marrow_c-kit","Neonatal-Skin","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Calvaria","Spleen","Neonatal-Heart","Bone-Marrow_c-kit","Kidney","MammaryGland.Lactation","Liver","Liver","Bone-Marrow_c-kit","Fetal_Lung","Stomach","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Neonatal-Skin","Bone-Marrow_c-kit","Bladder","Fetal_Lung","Thymus","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Spleen","Testis","Testis","MammaryGland.Lactation","Ovary","MammaryGland.Virgin","Pancreas","Bone-Marrow_c-kit","Fetal_Brain","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow","Embryonic-Stem-Cell","Peripheral_Blood","Testis","MammaryGland.Lactation","Neonatal-Muscle","MammaryGland.Involution","Neonatal-Muscle","MammaryGland.Virgin","Neonatal-Muscle","MammaryGland.Involution","Small-Intestine","Testis","Neonatal-Heart","Bone-Marrow_c-kit","Thymus","Prostate","Fetal_Lung","Lung","Bone-Marrow_c-kit","MammaryGland.Involution","Bone-Marrow_c-kit","Liver","Placenta","MammaryGland.Virgin","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Prostate","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Peripheral_Blood","Small-Intestine","Bone_Marrow_Mesenchyme","MammaryGland.Involution","Brain","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","MammaryGland.Pregnancy","Testis","Thymus","Fetal_Intestine","Neonatal-Calvaria","Embryonic-Stem-Cell","Fetal_Lung","MammaryGland.Involution","Fetal_Lung","Neonatal-Rib","Bone-Marrow","Neonatal-Calvaria","Embryonic-Stem-Cell","Kidney","Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Lung","Kidney","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Fetal_Lung","Bone-Marrow_c-kit","Testis","Peripheral_Blood","MammaryGland.Lactation","Uterus","Thymus","Testis","Peripheral_Blood","Muscle","Embryonic-Stem-Cell","Uterus","Fetal_Intestine","Fetal_Lung","Testis","Bone-Marrow","Neonatal-Rib","Bone-Marrow_c-kit","Testis","Fetal-Liver","Neonatal-Rib","Bone-Marrow","Trophoblast-Stem-Cell","MammaryGland.Involution","MammaryGland.Lactation","Bladder","Trophoblast-Stem-Cell","Liver","Embryonic-Stem-Cell","Testis","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow","Bone-Marrow_c-kit","Fetal_Lung","MammaryGland.Lactation","Thymus","Thymus","Trophoblast-Stem-Cell","Kidney","MammaryGland.Lactation","Neonatal-Calvaria","Thymus","Bone-Marrow","Thymus","Neonatal-Skin","Thymus","Lung","Small-Intestine","Fetal_Stomache","Fetal_Stomache","Fetal_Lung","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Neonatal-Calvaria","Testis","Small-Intestine","Embryonic-Stem-Cell","Bladder","Neonatal-Calvaria","Trophoblast-Stem-Cell","Testis","Bone-Marrow","Brain","Ovary","MammaryGland.Lactation","Thymus","Lung","Testis","Testis","Bladder","Fetal_Stomache","Lung","Testis","Small-Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Lung","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Uterus","Placenta","Stomach","Bone-Marrow_c-kit","Stomach","Neonatal-Calvaria","Neonatal-Skin","Testis","MammaryGland.Involution","Testis","Ovary","MammaryGland.Lactation","Bone-Marrow_c-kit","Ovary","Kidney","Trophoblast-Stem-Cell","Testis","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","Testis","Trophoblast-Stem-Cell","Neonatal-Heart","MammaryGland.Involution","Fetal_Intestine","Bone-Marrow_c-kit","Testis","Spleen","Small-Intestine","Bone-Marrow_c-kit","Fetal_Intestine","Bone-Marrow","Neonatal-Rib","Small-Intestine","Neonatal-Calvaria","MammaryGland.Lactation","Liver","Bone-Marrow_c-kit","Neonatal-Calvaria","Stomach","Embryonic-Mesenchyme","Neonatal-Skin","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Stomach","MammaryGland.Lactation","Embryonic-Stem-Cell","Lung","Peripheral_Blood","Neonatal-Rib","Bone-Marrow_c-kit","Placenta","Neonatal-Muscle","Lung","MammaryGland.Lactation","Peripheral_Blood","Neonatal-Muscle","Fetal_Lung","Fetal_Brain","MammaryGland.Lactation","Testis","MammaryGland.Lactation","Bone-Marrow","Bone-Marrow_c-kit","Fetal_Brain","Fetal_Lung","Stomach","Neonatal-Skin","Trophoblast-Stem-Cell","Fetal_Lung","Liver","Bone-Marrow_c-kit","Prostate","Pancreas","Lung","Pancreas","Pancreas","MammaryGland.Involution","Neonatal-Muscle","Lung","Liver","Fetal_Lung","Ovary","Fetal_Stomache","Small-Intestine","Testis","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Rib","Kidney","Brain","Bone-Marrow_c-kit","Kidney","Brain","Liver","Bone-Marrow","Testis","Kidney","Bone-Marrow_c-kit","Brain","MammaryGland.Pregnancy","Fetal_Lung","Bone-Marrow","Pancreas","Ovary","Liver","Testis","Trophoblast-Stem-Cell","Uterus","Testis","Trophoblast-Stem-Cell","Small-Intestine","Liver","Uterus","Lung","Bone-Marrow_c-kit","Neonatal-Calvaria","Liver","Neonatal-Heart","Fetal_Intestine","Fetal_Brain","Stomach","Neonatal-Calvaria","Neonatal-Heart","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Bladder","Kidney","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Bone_Marrow_Mesenchyme","Lung","Lung","Bone-Marrow_c-kit","Testis","Neonatal-Rib","Neonatal-Calvaria","Neonatal-Skin","MammaryGland.Pregnancy","Ovary","Neonatal-Calvaria","Prostate","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Involution","Uterus","Fetal_Stomache","Lung","Pancreas","Fetal_Lung","MammaryGland.Virgin","Fetal_Brain","Bone-Marrow_c-kit","Neonatal-Calvaria","Neonatal-Calvaria","Bone-Marrow_c-kit","MammaryGland.Lactation","Peripheral_Blood","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Testis","Uterus","Kidney","Neonatal-Rib","Trophoblast-Stem-Cell","MammaryGland.Lactation","Fetal_Lung","Liver","Fetal_Intestine","MammaryGland.Virgin","Embryonic-Stem-Cell","Testis","Liver","Testis","Thymus","Bone_Marrow_Mesenchyme","Testis","Fetal_Lung","Bone-Marrow_c-kit","Bone-Marrow","Fetal_Brain","MammaryGland.Virgin","MammaryGland.Virgin","Small-Intestine","Peripheral_Blood","Fetal_Brain","Neonatal-Calvaria","Fetal_Stomache","Embryonic-Mesenchyme","Lung","Lung","Fetal_Stomache","Small-Intestine","MammaryGland.Lactation","Neonatal-Muscle","Neonatal-Heart","Prostate","MammaryGland.Lactation","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Fetal_Intestine","Testis","Testis","Fetal_Stomache","Bone-Marrow_c-kit","Thymus","Liver","Thymus","Fetal_Lung","Testis","MammaryGland.Lactation","Fetal_Lung","Trophoblast-Stem-Cell","Neonatal-Rib","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Ovary","Small-Intestine","Bone-Marrow_c-kit","Testis","Neonatal-Heart","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Lung","Fetal-Liver","Placenta","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Liver","Prostate","MammaryGland.Involution","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Ovary","Neonatal-Skin","Uterus","Bone-Marrow_c-kit","Peripheral_Blood","Neonatal-Calvaria","Uterus","Neonatal-Skin","Small-Intestine","Liver","Embryonic-Mesenchyme","Fetal_Stomache","Fetal_Intestine","Brain","Fetal_Stomache","Trophoblast-Stem-Cell","Stomach","Testis","Trophoblast-Stem-Cell","Fetal_Stomache","Neonatal-Heart","Small-Intestine","MammaryGland.Pregnancy","Lung","Neonatal-Heart","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Fetal-Liver","Bone-Marrow","Bone-Marrow_c-kit","Fetal_Brain","Fetal_Intestine","Testis","Embryonic-Mesenchyme","Fetal_Brain","Embryonic-Mesenchyme","MammaryGland.Virgin","Bone-Marrow_c-kit","Fetal_Brain","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Calvaria","MammaryGland.Involution","Uterus","Trophoblast-Stem-Cell","Small-Intestine","Neonatal-Calvaria","MammaryGland.Virgin","Fetal_Stomache","Neonatal-Calvaria","Neonatal-Skin","Bone-Marrow","Kidney","Uterus","Small-Intestine","Prostate","Spleen","MammaryGland.Virgin","Neonatal-Heart","Testis","Fetal_Intestine","Brain","MammaryGland.Lactation","Fetal_Stomache","Fetal_Lung","Ovary","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Stomach","Lung","Bone-Marrow","Bone-Marrow","Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Muscle","Pancreas","Stomach","MammaryGland.Lactation","Placenta","Liver","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Placenta","MammaryGland.Involution","Peripheral_Blood","Fetal_Brain","Bone-Marrow_c-kit","Ovary","Small-Intestine","Trophoblast-Stem-Cell","Lung","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Calvaria","Peripheral_Blood","MammaryGland.Lactation","Testis","Bone-Marrow_c-kit","Thymus","Trophoblast-Stem-Cell","Fetal_Lung","Neonatal-Skin","Trophoblast-Stem-Cell","Fetal_Lung","Fetal-Liver","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Testis","MammaryGland.Involution","Trophoblast-Stem-Cell","Lung","Peripheral_Blood","Kidney","Peripheral_Blood","Placenta","MammaryGland.Pregnancy","Fetal_Stomache","Neonatal-Calvaria","Neonatal-Muscle","Kidney","MammaryGland.Virgin","MammaryGland.Pregnancy","Bone-Marrow","Neonatal-Muscle","Liver","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow_c-kit","Testis","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Fetal-Liver","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Muscle","Ovary","Neonatal-Muscle","Liver","Fetal_Stomache","Trophoblast-Stem-Cell","Peripheral_Blood","MammaryGland.Pregnancy","Kidney","Neonatal-Calvaria","Peripheral_Blood","Uterus","Placenta","Embryonic-Stem-Cell","Stomach","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Virgin","Ovary","Testis","Placenta","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Peripheral_Blood","MammaryGland.Involution","Small-Intestine","Bone-Marrow_c-kit","MammaryGland.Pregnancy","MammaryGland.Lactation","Neonatal-Rib","Fetal_Stomache","Neonatal-Calvaria","MammaryGland.Virgin","Stomach","Lung","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Fetal_Stomache","Bone_Marrow_Mesenchyme","Pancreas","Embryonic-Stem-Cell","Thymus","MammaryGland.Virgin","Peripheral_Blood","Fetal-Liver","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","MammaryGland.Pregnancy","Testis","Fetal_Lung","MammaryGland.Virgin","Stomach","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Testis","Testis","Fetal_Lung","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Fetal_Stomache","Fetal_Stomache","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Muscle","Small-Intestine","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Lung","Neonatal-Muscle","Fetal_Intestine","Bone-Marrow","MammaryGland.Pregnancy","Small-Intestine","MammaryGland.Involution","Small-Intestine","Embryonic-Mesenchyme","Bone-Marrow","MammaryGland.Lactation","Peripheral_Blood","MammaryGland.Involution","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Fetal_Brain","Fetal-Liver","Neonatal-Calvaria","Trophoblast-Stem-Cell","Fetal_Intestine","Pancreas","Uterus","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Fetal_Intestine","Placenta","Bone-Marrow","Neonatal-Skin","Kidney","MammaryGland.Lactation","Stomach","Neonatal-Rib","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Peripheral_Blood","Peripheral_Blood","Peripheral_Blood","Peripheral_Blood","Small-Intestine","Bone-Marrow","Neonatal-Muscle","Placenta","Testis","Trophoblast-Stem-Cell","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Stomach","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow","Fetal_Lung","Bone-Marrow_c-kit","Fetal_Intestine","Small-Intestine","Neonatal-Calvaria","Small-Intestine","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Brain","Testis","Brain","Liver","Fetal_Intestine","MammaryGland.Pregnancy","Neonatal-Calvaria","Placenta","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Peripheral_Blood","MammaryGland.Lactation","Bone-Marrow","Fetal_Intestine","Stomach","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Skin","Peripheral_Blood","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","MammaryGland.Virgin","Bone-Marrow_c-kit","Testis","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Testis","MammaryGland.Pregnancy","Neonatal-Rib","Thymus","Testis","Testis","Bone-Marrow","Placenta","Stomach","MammaryGland.Lactation","Placenta","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Small-Intestine","Ovary","MammaryGland.Lactation","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Pancreas","Muscle","MammaryGland.Pregnancy","MammaryGland.Lactation","Small-Intestine","Trophoblast-Stem-Cell","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Embryonic-Mesenchyme","Uterus","Trophoblast-Stem-Cell","Lung","Fetal_Lung","Fetal_Stomache","Trophoblast-Stem-Cell","Small-Intestine","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Intestine","Thymus","Pancreas","Bone_Marrow_Mesenchyme","Testis","Trophoblast-Stem-Cell","Fetal_Brain","Prostate","Placenta","Neonatal-Heart","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Peripheral_Blood","Thymus","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Testis","Neonatal-Skin","Fetal_Lung","Peripheral_Blood","Testis","Trophoblast-Stem-Cell","Bone-Marrow","Lung","Thymus","Testis","Fetal_Lung","Bone-Marrow","MammaryGland.Virgin","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Neonatal-Muscle","Lung","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bladder","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Liver","Lung","Neonatal-Heart","Neonatal-Rib","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Rib","Lung","Liver","Spleen","Liver","MammaryGland.Pregnancy","MammaryGland.Pregnancy","Neonatal-Calvaria","Ovary","Bone-Marrow_c-kit","MammaryGland.Virgin","Testis","Bone-Marrow","MammaryGland.Pregnancy","Embryonic-Stem-Cell","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Brain","Testis","Neonatal-Muscle","Bone-Marrow_c-kit","Bladder","Bone-Marrow_c-kit","Fetal_Intestine","Bone-Marrow","Bone-Marrow","Fetal_Brain","Testis","Bone-Marrow_c-kit","MammaryGland.Lactation","Ovary","Kidney","MammaryGland.Involution","Bone-Marrow_c-kit","Bone-Marrow","Bone-Marrow_c-kit","Ovary","MammaryGland.Lactation","MammaryGland.Lactation","Embryonic-Mesenchyme","MammaryGland.Involution","Neonatal-Heart","Fetal_Stomache","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Peripheral_Blood","Embryonic-Stem-Cell","Small-Intestine","Trophoblast-Stem-Cell","Lung","Testis","Liver","Fetal_Lung","Lung","MammaryGland.Lactation","Pancreas","Pancreas","Embryonic-Mesenchyme","MammaryGland.Lactation","MammaryGland.Involution","Neonatal-Calvaria","Testis","Bone_Marrow_Mesenchyme","Fetal_Lung","Bone-Marrow_c-kit","Testis","MammaryGland.Involution","Neonatal-Calvaria","Liver","Fetal_Intestine","Lung","Pancreas","Brain","MammaryGland.Lactation","Trophoblast-Stem-Cell","Fetal_Stomache","Trophoblast-Stem-Cell","MammaryGland.Lactation","Uterus","Spleen","Neonatal-Calvaria","Fetal_Lung","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Uterus","Testis","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Stomach","Fetal_Stomache","MammaryGland.Lactation","Fetal-Liver","Pancreas","Trophoblast-Stem-Cell","Neonatal-Rib","Ovary","Neonatal-Muscle","Trophoblast-Stem-Cell","Kidney","Small-Intestine","Bone-Marrow_c-kit","Testis","Bone-Marrow","Neonatal-Calvaria","Neonatal-Muscle","Bone-Marrow","Bone-Marrow_c-kit","Bone-Marrow","Testis","Testis","Pancreas","Embryonic-Stem-Cell","Lung","Liver","Brain","Lung","MammaryGland.Involution","Brain","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Uterus","Neonatal-Calvaria","Trophoblast-Stem-Cell","Neonatal-Rib","Testis","Fetal_Brain","Bone-Marrow_c-kit","Neonatal-Calvaria","Prostate","Liver","Fetal_Brain","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Fetal_Lung","Fetal-Liver","Placenta","Trophoblast-Stem-Cell","Testis","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Muscle","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Neonatal-Heart","Fetal_Lung","Neonatal-Calvaria","Neonatal-Heart","Pancreas","Trophoblast-Stem-Cell","Bone-Marrow","Testis","Fetal_Stomache","Neonatal-Rib","Peripheral_Blood","Liver","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Brain","Embryonic-Stem-Cell","Fetal_Stomache","Bladder","Neonatal-Heart","MammaryGland.Lactation","Fetal_Lung","Testis","MammaryGland.Involution","Neonatal-Rib","Fetal_Lung","Thymus","Bone-Marrow_c-kit","Fetal-Liver","Neonatal-Calvaria","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Testis","Placenta","Testis","Neonatal-Heart","Neonatal-Rib","Neonatal-Rib","MammaryGland.Lactation","Small-Intestine","Thymus","Lung","Neonatal-Muscle","Fetal_Intestine","Bladder","Embryonic-Stem-Cell","Fetal_Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Muscle","MammaryGland.Pregnancy","Fetal_Stomache","Bone-Marrow_c-kit","Liver","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Stomache","Bone-Marrow_c-kit","Lung","Bone-Marrow_c-kit","Ovary","Lung","MammaryGland.Lactation","Small-Intestine","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Fetal_Intestine","Neonatal-Muscle","Mesenchymal-Stem-Cell-Cultured","Liver","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Placenta","Brain","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Spleen","Liver","Neonatal-Rib","MammaryGland.Involution","Uterus","MammaryGland.Virgin","Neonatal-Calvaria","Fetal_Intestine","MammaryGland.Lactation","Neonatal-Rib","Ovary","Neonatal-Calvaria","Brain","Ovary","MammaryGland.Pregnancy","Neonatal-Calvaria","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Placenta","Fetal_Intestine","MammaryGland.Pregnancy","Thymus","Neonatal-Muscle","Placenta","Muscle","Neonatal-Muscle","Uterus","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Liver","Neonatal-Skin","Prostate","Trophoblast-Stem-Cell","Ovary","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Rib","Testis","Ovary","Bone-Marrow","MammaryGland.Involution","Uterus","Bone-Marrow_c-kit","Neonatal-Calvaria","Trophoblast-Stem-Cell","Bone-Marrow","Neonatal-Heart","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","MammaryGland.Involution","MammaryGland.Involution","Bone_Marrow_Mesenchyme","Kidney","Bone-Marrow_c-kit","Fetal_Brain","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","Bone-Marrow_c-kit","Ovary","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Testis","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Fetal_Brain","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Fetal_Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow","Bone-Marrow_c-kit","Testis","Testis","Trophoblast-Stem-Cell","Bladder","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Lung","Bone-Marrow_c-kit","Thymus","Fetal_Brain","Bone-Marrow_c-kit","Neonatal-Heart","Small-Intestine","Fetal_Intestine","Kidney","Placenta","Small-Intestine","Bladder","MammaryGland.Virgin","Bone-Marrow_c-kit","Uterus","Bone-Marrow","Fetal_Stomache","Testis","Fetal_Brain","Fetal_Brain","Fetal-Liver","Placenta","Neonatal-Skin","Neonatal-Skin","Neonatal-Calvaria","Neonatal-Skin","Neonatal-Heart","Brain","Testis","Small-Intestine","MammaryGland.Lactation","Bone-Marrow","Embryonic-Stem-Cell","Neonatal-Muscle","Fetal_Intestine","Fetal_Intestine","Neonatal-Calvaria","Neonatal-Rib","Placenta","Trophoblast-Stem-Cell","Fetal_Brain","Bone_Marrow_Mesenchyme","Uterus","Placenta","Prostate","Embryonic-Stem-Cell","MammaryGland.Lactation","MammaryGland.Virgin","Testis","Embryonic-Stem-Cell","Brain","Testis","Placenta","Trophoblast-Stem-Cell","Placenta","Bone-Marrow_c-kit","MammaryGland.Lactation","Peripheral_Blood","MammaryGland.Lactation","Bone-Marrow_c-kit","Testis","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow","Kidney","Brain","Fetal_Intestine","Bone_Marrow_Mesenchyme","Testis","Testis","Fetal_Stomache","Trophoblast-Stem-Cell","Peripheral_Blood","Embryonic-Stem-Cell","Lung","Testis","MammaryGland.Lactation","Trophoblast-Stem-Cell","Liver","Embryonic-Stem-Cell","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Fetal_Lung","Fetal_Intestine","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Bone-Marrow","Fetal_Brain","Testis","Bone-Marrow_c-kit","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","MammaryGland.Virgin","Placenta","Trophoblast-Stem-Cell","Fetal_Brain","Embryonic-Stem-Cell","MammaryGland.Involution","MammaryGland.Involution","Neonatal-Rib","Fetal_Lung","Uterus","Bone-Marrow","Small-Intestine","Bone-Marrow_c-kit","Placenta","MammaryGland.Lactation","Testis","Trophoblast-Stem-Cell","Testis","MammaryGland.Involution","Fetal-Liver","Pancreas","Bone-Marrow_c-kit","MammaryGland.Virgin","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow","Bone-Marrow_c-kit","Neonatal-Heart","Neonatal-Rib","Bone_Marrow_Mesenchyme","Fetal_Intestine","Liver","Trophoblast-Stem-Cell","Neonatal-Skin","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Fetal_Intestine","Bone-Marrow_c-kit","Bladder","Neonatal-Heart","Testis","Lung","Fetal_Lung","Fetal_Brain","Neonatal-Skin","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Testis","Fetal_Stomache","Fetal_Stomache","MammaryGland.Virgin","Ovary","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Pregnancy","MammaryGland.Lactation","Peripheral_Blood","Ovary","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Brain","Neonatal-Calvaria","Fetal_Lung","MammaryGland.Lactation","Neonatal-Rib","MammaryGland.Virgin","Fetal_Lung","Fetal_Brain","Neonatal-Muscle","Embryonic-Stem-Cell","Neonatal-Skin","Peripheral_Blood","Neonatal-Heart","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Peripheral_Blood","Neonatal-Calvaria","Fetal_Intestine","Embryonic-Stem-Cell","Testis","Muscle","Testis","Neonatal-Heart","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Fetal_Intestine","Neonatal-Skin","Trophoblast-Stem-Cell","Liver","Mesenchymal-Stem-Cell-Cultured","Brain","Trophoblast-Stem-Cell","Lung","Embryonic-Stem-Cell","Neonatal-Skin","Bone-Marrow_c-kit","Fetal-Liver","Fetal_Lung","MammaryGland.Virgin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Pancreas","Prostate","Bone-Marrow_c-kit","Neonatal-Calvaria","Small-Intestine","Fetal-Liver","Neonatal-Heart","Testis","Neonatal-Muscle","Fetal_Intestine","Small-Intestine","Uterus","Peripheral_Blood","Neonatal-Heart","Uterus","Fetal-Liver","Liver","Uterus","Neonatal-Rib","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Lung","Uterus","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bladder","MammaryGland.Involution","Kidney","Bone_Marrow_Mesenchyme","Small-Intestine","Testis","Fetal_Stomache","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Fetal_Stomache","Small-Intestine","MammaryGland.Pregnancy","MammaryGland.Pregnancy","Uterus","MammaryGland.Lactation","Uterus","Ovary","Testis","Placenta","Stomach","Placenta","MammaryGland.Lactation","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Small-Intestine","MammaryGland.Involution","Bone-Marrow_c-kit","Prostate","Liver","Bone-Marrow_c-kit","Fetal_Intestine","Fetal_Stomache","Neonatal-Calvaria","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Skin","Neonatal-Calvaria","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Neonatal-Muscle","Fetal_Intestine","Bone-Marrow_c-kit","MammaryGland.Lactation","MammaryGland.Pregnancy","Stomach","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Ovary","MammaryGland.Lactation","Prostate","Liver","Prostate","Uterus","Lung","Neonatal-Muscle","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Uterus","Placenta","Fetal_Intestine","Fetal_Lung","Embryonic-Mesenchyme","Muscle","Fetal_Brain","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Peripheral_Blood","Pancreas","Thymus","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal_Stomache","MammaryGland.Lactation","Bone-Marrow_c-kit","Placenta","Neonatal-Muscle","Muscle","MammaryGland.Lactation","Liver","Testis","Uterus","Embryonic-Stem-Cell","Neonatal-Calvaria","MammaryGland.Lactation","Neonatal-Muscle","Neonatal-Calvaria","Testis","Thymus","Neonatal-Heart","Prostate","Trophoblast-Stem-Cell","Small-Intestine","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Muscle","Bone-Marrow_c-kit","Stomach","Neonatal-Rib","Pancreas","MammaryGland.Lactation","Embryonic-Mesenchyme","Fetal_Lung","MammaryGland.Involution","Peripheral_Blood","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Ovary","Bone-Marrow","Fetal_Lung","Testis","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Neonatal-Calvaria","Fetal_Stomache","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Lactation","Stomach","MammaryGland.Lactation","Trophoblast-Stem-Cell","Neonatal-Calvaria","Ovary","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal-Liver","Fetal_Intestine","Testis","MammaryGland.Lactation","Fetal_Lung","Bone-Marrow_c-kit","Neonatal-Heart","MammaryGland.Lactation","Bone-Marrow","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Small-Intestine","Uterus","MammaryGland.Virgin","Neonatal-Rib","Neonatal-Heart","Neonatal-Calvaria","Liver","Trophoblast-Stem-Cell","Bone-Marrow","Bone-Marrow_c-kit","Peripheral_Blood","Neonatal-Heart","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Thymus","Bone-Marrow","Pancreas","Fetal_Brain","Testis","Spleen","Fetal_Lung","Neonatal-Calvaria","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Fetal_Lung","Lung","Liver","Bone-Marrow","Bone-Marrow_c-kit","Testis","Testis","Uterus","Neonatal-Calvaria","Kidney","Neonatal-Calvaria","Embryonic-Stem-Cell","Stomach","Mesenchymal-Stem-Cell-Cultured","Prostate","Testis","Trophoblast-Stem-Cell","Ovary","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Spleen","Fetal_Intestine","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Small-Intestine","Neonatal-Heart","Peripheral_Blood","MammaryGland.Pregnancy","MammaryGland.Lactation","MammaryGland.Pregnancy","MammaryGland.Virgin","Small-Intestine","Neonatal-Rib","Small-Intestine","Brain","Fetal_Lung","Embryonic-Stem-Cell","Testis","Spleen","Ovary","Bone-Marrow_c-kit","Placenta","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Virgin","Placenta","Peripheral_Blood","Pancreas","Bone-Marrow","Neonatal-Rib","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Liver","Neonatal-Calvaria","Bone-Marrow_c-kit","Fetal-Liver","Fetal_Intestine","Bone-Marrow_c-kit","Neonatal-Muscle","Placenta","Testis","Fetal_Stomache","Fetal_Stomache","Placenta","Bone-Marrow","Ovary","Bone-Marrow_c-kit","Neonatal-Calvaria","Embryonic-Mesenchyme","Brain","Bone-Marrow_c-kit","Pancreas","Bone_Marrow_Mesenchyme","Fetal_Stomache","Fetal_Intestine","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Fetal_Intestine","Bone_Marrow_Mesenchyme","Stomach","Neonatal-Calvaria","Peripheral_Blood","Testis","Uterus","Bone-Marrow_c-kit","Fetal_Intestine","Neonatal-Rib","Bone-Marrow","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","Bladder","Lung","MammaryGland.Pregnancy","Liver","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Lung","Liver","Thymus","Bone-Marrow_c-kit","Lung","Brain","MammaryGland.Pregnancy","Neonatal-Rib","Trophoblast-Stem-Cell","MammaryGland.Virgin","Embryonic-Stem-Cell","Fetal_Brain","Stomach","MammaryGland.Lactation","Neonatal-Rib","Bone-Marrow","Testis","Kidney","Neonatal-Rib","Placenta","Placenta","MammaryGland.Lactation","Bone-Marrow_c-kit","Thymus","Bone_Marrow_Mesenchyme","Kidney","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Liver","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Calvaria","Bone-Marrow_c-kit","MammaryGland.Lactation","Testis","Neonatal-Rib","Fetal_Intestine","Bone-Marrow_c-kit","Testis","MammaryGland.Involution","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Testis","Fetal_Lung","Bone-Marrow_c-kit","Fetal_Brain","Ovary","Thymus","MammaryGland.Virgin","Testis","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Uterus","Bone-Marrow_c-kit","Brain","Peripheral_Blood","Placenta","Testis","Fetal_Intestine","Neonatal-Muscle","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Stomach","Testis","Mesenchymal-Stem-Cell-Cultured","Ovary","Embryonic-Stem-Cell","Placenta","Bone_Marrow_Mesenchyme","Thymus","Bone-Marrow_c-kit","Small-Intestine","Fetal_Stomache","Neonatal-Heart","Peripheral_Blood","Embryonic-Stem-Cell","Lung","Neonatal-Rib","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Lung","Neonatal-Skin","Kidney","Pancreas","Testis","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Kidney","Embryonic-Mesenchyme","Peripheral_Blood","Fetal_Intestine","Fetal-Liver","Spleen","Bone_Marrow_Mesenchyme","Prostate","Neonatal-Muscle","Liver","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","Fetal_Lung","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Peripheral_Blood","Thymus","Fetal_Lung","Testis","Bone-Marrow_c-kit","Fetal_Lung","MammaryGland.Virgin","Pancreas","Liver","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow","Prostate","Bone_Marrow_Mesenchyme","Thymus","Fetal-Liver","Neonatal-Calvaria","Bone-Marrow","Fetal_Intestine","Neonatal-Heart","Lung","Peripheral_Blood","MammaryGland.Virgin","Testis","Neonatal-Rib","Ovary","Stomach","Bone-Marrow_c-kit","Bladder","Lung","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Fetal_Intestine","Trophoblast-Stem-Cell","Peripheral_Blood","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Virgin","MammaryGland.Involution","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Virgin","Small-Intestine","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone-Marrow_c-kit","Neonatal-Skin","Embryonic-Stem-Cell","Uterus","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Lung","Liver","Small-Intestine","Bladder","Neonatal-Calvaria","Trophoblast-Stem-Cell","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Pancreas","Neonatal-Calvaria","Neonatal-Calvaria","Bone-Marrow_c-kit","Pancreas","Neonatal-Calvaria","Brain","Testis","Bladder","Fetal_Lung","Small-Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Kidney","Peripheral_Blood","Placenta","Bone-Marrow","Testis","MammaryGland.Lactation","Peripheral_Blood","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Small-Intestine","Bone-Marrow","Liver","Neonatal-Skin","Bone-Marrow","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Liver","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Testis","MammaryGland.Lactation","Neonatal-Skin","Testis","Neonatal-Muscle","Bone-Marrow","Thymus","Bladder","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Lactation","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Lung","Lung","Fetal_Stomache","Brain","Bone-Marrow_c-kit","Bladder","MammaryGland.Lactation","Pancreas","Brain","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Testis","Bone-Marrow_c-kit","Fetal_Lung","Bone-Marrow_c-kit","Thymus","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","MammaryGland.Involution","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Lung","Bone-Marrow_c-kit","MammaryGland.Lactation","Uterus","Neonatal-Rib","Testis","Fetal_Stomache","Peripheral_Blood","Neonatal-Heart","Thymus","Bone-Marrow_c-kit","Pancreas","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Virgin","MammaryGland.Lactation","Neonatal-Heart","Neonatal-Rib","Bone-Marrow_c-kit","Testis","Testis","Testis","Fetal_Intestine","Testis","Bone-Marrow","Bone-Marrow_c-kit","Testis","Testis","Peripheral_Blood","Lung","MammaryGland.Lactation","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow","Lung","Neonatal-Rib","MammaryGland.Lactation","Fetal-Liver","Fetal_Brain","Small-Intestine","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Stomach","Testis","Brain","Neonatal-Muscle","Fetal_Brain","Small-Intestine","Fetal-Liver","Testis","Liver","Bone-Marrow","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Virgin","Fetal-Liver","Bone-Marrow","Neonatal-Rib","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Uterus","Thymus","Peripheral_Blood","MammaryGland.Lactation","MammaryGland.Involution","Neonatal-Rib","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Involution","Bladder","Testis","Bone-Marrow_c-kit","Fetal_Stomache","Fetal_Lung","Neonatal-Skin","Stomach","Brain","Pancreas","Kidney","Neonatal-Muscle","Embryonic-Stem-Cell","MammaryGland.Virgin","Neonatal-Heart","Stomach","Neonatal-Rib","MammaryGland.Pregnancy","Testis","Embryonic-Stem-Cell","Fetal_Stomache","Kidney","Bone-Marrow_c-kit","Neonatal-Rib","Bone-Marrow_c-kit","MammaryGland.Virgin","Trophoblast-Stem-Cell","Fetal_Intestine","MammaryGland.Involution","Trophoblast-Stem-Cell","Uterus","Uterus","Neonatal-Rib","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Pancreas","MammaryGland.Lactation","MammaryGland.Involution","Testis","Bone_Marrow_Mesenchyme","Testis","Mesenchymal-Stem-Cell-Cultured","Neonatal-Skin","Embryonic-Stem-Cell","MammaryGland.Involution","MammaryGland.Virgin","MammaryGland.Lactation","Fetal_Intestine","Peripheral_Blood","Neonatal-Calvaria","MammaryGland.Lactation","Lung","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Neonatal-Heart","Ovary","Neonatal-Muscle","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Liver","Fetal_Lung","Embryonic-Mesenchyme","Liver","Neonatal-Calvaria","MammaryGland.Virgin","Bone-Marrow_c-kit","Testis","Embryonic-Stem-Cell","Lung","Neonatal-Rib","Prostate","Bone_Marrow_Mesenchyme","Peripheral_Blood","MammaryGland.Virgin","Fetal_Intestine","Bone-Marrow_c-kit","Fetal_Brain","Uterus","Fetal_Intestine","Trophoblast-Stem-Cell","Fetal_Lung","Testis","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","MammaryGland.Virgin","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Small-Intestine","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Neonatal-Muscle","Embryonic-Mesenchyme","Lung","Bone-Marrow_c-kit","Fetal_Brain","MammaryGland.Lactation","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Fetal_Lung","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Neonatal-Muscle","MammaryGland.Involution","Lung","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Testis","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Small-Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Small-Intestine","MammaryGland.Lactation","Embryonic-Stem-Cell","MammaryGland.Lactation","Liver","Stomach","MammaryGland.Lactation","Small-Intestine","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Lung","MammaryGland.Lactation","MammaryGland.Involution","Neonatal-Muscle","Lung","Lung","Bone-Marrow_c-kit","MammaryGland.Virgin","MammaryGland.Lactation","Neonatal-Calvaria","MammaryGland.Involution","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Intestine","Bone-Marrow_c-kit","Thymus","Uterus","Neonatal-Calvaria","Liver","Kidney","Mesenchymal-Stem-Cell-Cultured","Stomach","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Skin","Trophoblast-Stem-Cell","Testis","Bladder","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Brain","Testis","Kidney","Brain","Trophoblast-Stem-Cell","Testis","Pancreas","Embryonic-Stem-Cell","Neonatal-Calvaria","Peripheral_Blood","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","MammaryGland.Pregnancy","Fetal_Lung","MammaryGland.Lactation","Neonatal-Heart","Embryonic-Stem-Cell","Placenta","Fetal_Brain","Embryonic-Stem-Cell","MammaryGland.Virgin","Bladder","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Kidney","Placenta","Bone-Marrow","Testis","Testis","Neonatal-Calvaria","Bone-Marrow","Bone-Marrow","Bone-Marrow","Testis","Bone_Marrow_Mesenchyme","Fetal_Lung","Lung","Placenta","Mesenchymal-Stem-Cell-Cultured","Brain","Neonatal-Calvaria","MammaryGland.Involution","Neonatal-Rib","MammaryGland.Involution","Fetal_Stomache","Kidney","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Thymus","Testis","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Heart","Muscle","Fetal_Stomache","Brain","Thymus","Embryonic-Stem-Cell","Fetal_Intestine","MammaryGland.Virgin","Neonatal-Calvaria","Small-Intestine","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Embryonic-Mesenchyme","Kidney","Bone_Marrow_Mesenchyme","Neonatal-Skin","Small-Intestine","Fetal-Liver","MammaryGland.Lactation","MammaryGland.Virgin","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Pancreas","MammaryGland.Lactation","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Small-Intestine","Fetal_Stomache","Neonatal-Heart","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Testis","Mesenchymal-Stem-Cell-Cultured","Kidney","Trophoblast-Stem-Cell","Neonatal-Muscle","Trophoblast-Stem-Cell","Bone-Marrow","MammaryGland.Pregnancy","Testis","Bone-Marrow_c-kit","Neonatal-Calvaria","Testis","Bone-Marrow_c-kit","Fetal_Stomache","Embryonic-Mesenchyme","Lung","Testis","Neonatal-Rib","Fetal_Stomache","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Testis","Bone-Marrow_c-kit","Bladder","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Testis","Lung","Peripheral_Blood","Brain","Neonatal-Calvaria","Bone-Marrow_c-kit","Neonatal-Calvaria","Fetal_Stomache","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Liver","Bone-Marrow_c-kit","Lung","Bone_Marrow_Mesenchyme","Fetal_Intestine","Neonatal-Heart","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Stomache","Lung","Stomach","Muscle","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Involution","Peripheral_Blood","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Uterus","Neonatal-Calvaria","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Intestine","Pancreas","Neonatal-Heart","Fetal_Lung","Bone-Marrow","Neonatal-Calvaria","Bladder","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Kidney","Liver","MammaryGland.Lactation","Stomach","Fetal_Stomache","Bone-Marrow_c-kit","Testis","Embryonic-Stem-Cell","Neonatal-Heart","Pancreas","MammaryGland.Lactation","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Ovary","Stomach","Ovary","Trophoblast-Stem-Cell","Liver","Bone-Marrow_c-kit","Brain","Bone-Marrow_c-kit","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","MammaryGland.Virgin","Bone-Marrow_c-kit","Stomach","Embryonic-Stem-Cell","Neonatal-Calvaria","Kidney","Small-Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Intestine","Fetal_Stomache","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","Fetal_Lung","Lung","Bone-Marrow","Bone-Marrow_c-kit","Liver","Testis","Brain","Fetal_Intestine","Testis","Neonatal-Muscle","MammaryGland.Pregnancy","Testis","Pancreas","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Placenta","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Placenta","Embryonic-Stem-Cell","Fetal_Intestine","Liver","Stomach","Testis","Peripheral_Blood","Testis","Peripheral_Blood","Bone-Marrow_c-kit","Testis","Neonatal-Muscle","Embryonic-Stem-Cell","Brain","Bone-Marrow_c-kit","Placenta","Trophoblast-Stem-Cell","Spleen","Neonatal-Calvaria","Trophoblast-Stem-Cell","Spleen","Testis","Embryonic-Stem-Cell","MammaryGland.Involution","Embryonic-Mesenchyme","Neonatal-Rib","Fetal_Lung","Neonatal-Skin","Fetal_Lung","MammaryGland.Lactation","Embryonic-Stem-Cell","Ovary","Uterus","Prostate","Bone-Marrow","Trophoblast-Stem-Cell","Bladder","Embryonic-Stem-Cell","Fetal-Liver","Testis","Bone_Marrow_Mesenchyme","Fetal_Stomache","Fetal_Intestine","Neonatal-Skin","Neonatal-Rib","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Ovary","Neonatal-Heart","Testis","Neonatal-Calvaria","MammaryGland.Virgin","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Uterus","Small-Intestine","Bone-Marrow_c-kit","MammaryGland.Virgin","Fetal_Brain","Fetal-Liver","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone-Marrow","Neonatal-Skin","MammaryGland.Lactation","Fetal_Brain","MammaryGland.Lactation","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Virgin","Embryonic-Stem-Cell","Bone-Marrow","Bone-Marrow","Ovary","Bone-Marrow_c-kit","Neonatal-Skin","Embryonic-Stem-Cell","Fetal_Intestine","Embryonic-Mesenchyme","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow","Neonatal-Calvaria","Pancreas","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Neonatal-Calvaria","MammaryGland.Lactation","Neonatal-Skin","Thymus","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","Trophoblast-Stem-Cell","MammaryGland.Involution","MammaryGland.Involution","MammaryGland.Involution","Neonatal-Muscle","Pancreas","Spleen","Placenta","MammaryGland.Pregnancy","Neonatal-Heart","Brain","Kidney","Fetal_Brain","Bone-Marrow_c-kit","Small-Intestine","Fetal_Lung","Fetal_Intestine","Thymus","Bone-Marrow","Bone-Marrow","Small-Intestine","Bone-Marrow","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow_c-kit","Liver","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Thymus","Bladder","Ovary","Neonatal-Rib","MammaryGland.Pregnancy","MammaryGland.Lactation","MammaryGland.Lactation","Fetal_Lung","MammaryGland.Involution","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Neonatal-Muscle","Peripheral_Blood","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Neonatal-Rib","Bone-Marrow_c-kit","Small-Intestine","Thymus","Bone_Marrow_Mesenchyme","Neonatal-Heart","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Bone-Marrow","Bone-Marrow_c-kit","Neonatal-Rib","Fetal_Stomache","Pancreas","Mesenchymal-Stem-Cell-Cultured","Neonatal-Heart","Peripheral_Blood","MammaryGland.Lactation","Bone-Marrow","Bone-Marrow","Fetal_Lung","Bone-Marrow_c-kit","Lung","Bone-Marrow_c-kit","Small-Intestine","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Ovary","Uterus","Trophoblast-Stem-Cell","Bone-Marrow","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Uterus","Testis","MammaryGland.Virgin","Uterus","Ovary","Fetal_Lung","Kidney","Placenta","Fetal_Intestine","Embryonic-Stem-Cell","Peripheral_Blood","Fetal_Intestine","Bone-Marrow_c-kit","Neonatal-Skin","Peripheral_Blood","Ovary","Trophoblast-Stem-Cell","Neonatal-Calvaria","MammaryGland.Virgin","MammaryGland.Involution","Brain","Neonatal-Calvaria","Bladder","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Pancreas","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","MammaryGland.Lactation","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow_c-kit","Fetal_Stomache","Pancreas","Kidney","Ovary","Bone-Marrow_c-kit","Fetal_Brain","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Neonatal-Skin","Fetal_Lung","Testis","Liver","Ovary","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Lung","Trophoblast-Stem-Cell","Kidney","Muscle","Placenta","Neonatal-Muscle","Kidney","Neonatal-Calvaria","Testis","Placenta","Small-Intestine","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Lung","Trophoblast-Stem-Cell","Neonatal-Rib","Neonatal-Heart","MammaryGland.Lactation","Lung","Placenta","Kidney","Bone-Marrow_c-kit","MammaryGland.Lactation","Thymus","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","Placenta","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Trophoblast-Stem-Cell","Bladder","Bone-Marrow","Neonatal-Skin","Spleen","Kidney","Testis","Neonatal-Calvaria","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Neonatal-Skin","Uterus","Bone-Marrow","Bladder","Peripheral_Blood","Embryonic-Mesenchyme","Bone-Marrow","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Bone-Marrow","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Small-Intestine","Ovary","Embryonic-Stem-Cell","Pancreas","Trophoblast-Stem-Cell","Fetal_Intestine","Neonatal-Calvaria","Lung","MammaryGland.Lactation","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Pancreas","Peripheral_Blood","Trophoblast-Stem-Cell","MammaryGland.Lactation","Trophoblast-Stem-Cell","Peripheral_Blood","MammaryGland.Involution","Small-Intestine","Bone-Marrow","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Fetal_Intestine","Trophoblast-Stem-Cell","Peripheral_Blood","Lung","Ovary","Testis","Fetal_Lung","Neonatal-Calvaria","Testis","Thymus","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Fetal-Liver","Neonatal-Calvaria","Ovary","Lung","Fetal_Brain","Neonatal-Calvaria","Trophoblast-Stem-Cell","Testis","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Thymus","Liver","Placenta","Bone_Marrow_Mesenchyme","Lung","Ovary","Fetal-Liver","Prostate","Testis","Testis","Thymus","Bone_Marrow_Mesenchyme","Bone-Marrow","MammaryGland.Involution","Thymus","Uterus","Kidney","MammaryGland.Lactation","Pancreas","Thymus","Trophoblast-Stem-Cell","Fetal_Intestine","Small-Intestine","Trophoblast-Stem-Cell","Fetal_Intestine","Fetal_Intestine","Lung","Mesenchymal-Stem-Cell-Cultured","Thymus","Fetal_Stomache","Bone-Marrow_c-kit","Neonatal-Muscle","Peripheral_Blood","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Neonatal-Muscle","Fetal_Intestine","Stomach","MammaryGland.Virgin","Bone-Marrow_c-kit","Fetal-Liver","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Stomach","Neonatal-Rib","Fetal_Stomache","Stomach","Neonatal-Muscle","Trophoblast-Stem-Cell","Neonatal-Calvaria","Trophoblast-Stem-Cell","MammaryGland.Lactation","Embryonic-Mesenchyme","Testis","MammaryGland.Lactation","Ovary","Bone-Marrow_c-kit","Bladder","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Lung","Bone-Marrow_c-kit","MammaryGland.Involution","Embryonic-Mesenchyme","Lung","Thymus","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Neonatal-Skin","Bone-Marrow_c-kit","Neonatal-Calvaria","Embryonic-Stem-Cell","Small-Intestine","Pancreas","Peripheral_Blood","Bone-Marrow_c-kit","Kidney","Thymus","Small-Intestine","Peripheral_Blood","Trophoblast-Stem-Cell","Spleen","Lung","Fetal_Intestine","Fetal-Liver","Kidney","Peripheral_Blood","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Neonatal-Rib","Brain","Bone-Marrow_c-kit","Neonatal-Rib","MammaryGland.Lactation","Fetal_Stomache","Lung","Bone-Marrow","Trophoblast-Stem-Cell","Bladder","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","MammaryGland.Lactation","MammaryGland.Lactation","Trophoblast-Stem-Cell","Thymus","MammaryGland.Lactation","MammaryGland.Pregnancy","Neonatal-Rib","Fetal_Brain","Lung","Kidney","Trophoblast-Stem-Cell","Lung","Brain","Uterus","Neonatal-Rib","Fetal_Intestine","Testis","Lung","Bone_Marrow_Mesenchyme","Neonatal-Muscle","MammaryGland.Involution","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Lactation","MammaryGland.Lactation","Pancreas","Brain","Testis","Bone-Marrow_c-kit","Peripheral_Blood","Fetal_Lung","MammaryGland.Lactation","MammaryGland.Involution","Embryonic-Stem-Cell","Ovary","Embryonic-Stem-Cell","Placenta","Lung","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Placenta","Trophoblast-Stem-Cell","Neonatal-Rib","Bone-Marrow","Uterus","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Placenta","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Uterus","Neonatal-Muscle","Fetal_Stomache","Bladder","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone-Marrow","Ovary","Small-Intestine","Testis","Bladder","Testis","Ovary","Ovary","Fetal-Liver","MammaryGland.Lactation","Testis","MammaryGland.Involution","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","Fetal_Brain","Stomach","MammaryGland.Lactation","Stomach","Brain","Brain","MammaryGland.Lactation","Trophoblast-Stem-Cell","Fetal_Intestine","Kidney","Neonatal-Rib","Peripheral_Blood","Peripheral_Blood","Embryonic-Stem-Cell","Bone-Marrow","Neonatal-Calvaria","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Fetal_Lung","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Liver","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Bone-Marrow","Trophoblast-Stem-Cell","Fetal_Brain","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Muscle","Bone-Marrow","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Kidney","Kidney","Bone-Marrow_c-kit","Neonatal-Calvaria","MammaryGland.Lactation","Fetal_Stomache","Placenta","Embryonic-Mesenchyme","Fetal_Stomache","Fetal-Liver","Mesenchymal-Stem-Cell-Cultured","Testis","Testis","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Pancreas","Fetal_Lung","Trophoblast-Stem-Cell","Bone-Marrow","Fetal-Liver","Embryonic-Mesenchyme","Liver","Neonatal-Skin","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Uterus","Bone-Marrow_c-kit","Spleen","Testis","MammaryGland.Lactation","Ovary","Fetal-Liver","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","Fetal_Stomache","Bone-Marrow_c-kit","Fetal_Intestine","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Pancreas","Fetal_Intestine","Neonatal-Muscle","Bone-Marrow_c-kit","Neonatal-Calvaria","Fetal_Lung","Neonatal-Calvaria","Thymus","Bone-Marrow","Liver","Fetal_Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Placenta","Small-Intestine","Fetal-Liver","Lung","Spleen","Peripheral_Blood","Bone-Marrow_c-kit","Peripheral_Blood","Liver","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Stomach","Uterus","Brain","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Lung","Bone-Marrow_c-kit","Bone-Marrow","Lung","Neonatal-Muscle","Mesenchymal-Stem-Cell-Cultured","Thymus","Prostate","Fetal_Lung","Bone-Marrow_c-kit","Neonatal-Muscle","Fetal_Intestine","Lung","Trophoblast-Stem-Cell","Peripheral_Blood","Liver","Fetal_Stomache","MammaryGland.Lactation","Fetal_Brain","Thymus","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Liver","Bone-Marrow_c-kit","Neonatal-Calvaria","Thymus","Fetal_Brain","Peripheral_Blood","Bone_Marrow_Mesenchyme","Muscle","Peripheral_Blood","Pancreas","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow","Trophoblast-Stem-Cell","Pancreas","Testis","Stomach","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Fetal_Lung","Bladder","Bone-Marrow_c-kit","Small-Intestine","MammaryGland.Lactation","Kidney","Embryonic-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Testis","Fetal_Brain","Bone-Marrow_c-kit","Thymus","Trophoblast-Stem-Cell","MammaryGland.Lactation","Stomach","Uterus","Thymus","Fetal_Brain","Brain","Fetal_Brain","Fetal_Intestine","Small-Intestine","Bladder","Lung","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Neonatal-Rib","Neonatal-Muscle","Neonatal-Calvaria","Fetal_Stomache","Ovary","Embryonic-Stem-Cell","MammaryGland.Lactation","Fetal_Intestine","MammaryGland.Pregnancy","MammaryGland.Involution","Bone_Marrow_Mesenchyme","Testis","Small-Intestine","Fetal-Liver","Trophoblast-Stem-Cell","Neonatal-Calvaria","Thymus","Trophoblast-Stem-Cell","Fetal_Intestine","Lung","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Liver","Bone-Marrow_c-kit","MammaryGland.Involution","Kidney","Lung","Neonatal-Calvaria","MammaryGland.Lactation","Small-Intestine","Testis","Trophoblast-Stem-Cell","Neonatal-Rib","MammaryGland.Virgin","Thymus","Fetal_Lung","Neonatal-Calvaria","Bladder","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Testis","Pancreas","Neonatal-Muscle","Placenta","Fetal_Stomache","MammaryGland.Lactation","Small-Intestine","Bone-Marrow","Thymus","Testis","Thymus","Pancreas","MammaryGland.Lactation","Fetal_Brain","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Calvaria","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Testis","Brain","Bone-Marrow_c-kit","Fetal_Stomache","Fetal_Intestine","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow","MammaryGland.Involution","Bone-Marrow_c-kit","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Virgin","Bone-Marrow","Fetal_Stomache","Trophoblast-Stem-Cell","Testis","Small-Intestine","Uterus","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Placenta","MammaryGland.Involution","Bone-Marrow_c-kit","Testis","Peripheral_Blood","Peripheral_Blood","Fetal_Stomache","Bone-Marrow_c-kit","Testis","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow","Bone-Marrow","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Peripheral_Blood","MammaryGland.Lactation","Peripheral_Blood","MammaryGland.Lactation","Lung","Fetal_Intestine","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Virgin","MammaryGland.Lactation","Fetal_Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Virgin","Neonatal-Rib","MammaryGland.Involution","Bone-Marrow_c-kit","Spleen","Testis","MammaryGland.Lactation","MammaryGland.Involution","Embryonic-Stem-Cell","Neonatal-Heart","Bone-Marrow","Small-Intestine","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Virgin","Peripheral_Blood","Uterus","Thymus","Testis","MammaryGland.Lactation","Bone-Marrow","Neonatal-Skin","Embryonic-Stem-Cell","Fetal_Lung","Fetal_Lung","Neonatal-Heart","Fetal_Stomache","Neonatal-Rib","Placenta","Trophoblast-Stem-Cell","MammaryGland.Virgin","Kidney","MammaryGland.Lactation","Testis","Bone-Marrow","Neonatal-Rib","Bone_Marrow_Mesenchyme","Ovary","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Kidney","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Trophoblast-Stem-Cell","Brain","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","Fetal_Lung","MammaryGland.Lactation","Embryonic-Mesenchyme","MammaryGland.Lactation","Thymus","Fetal_Brain","Trophoblast-Stem-Cell","Testis","Kidney","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Virgin","MammaryGland.Lactation","MammaryGland.Involution","Spleen","Bone-Marrow_c-kit","Neonatal-Skin","Fetal_Intestine","Peripheral_Blood","Liver","MammaryGland.Involution","Embryonic-Mesenchyme","Fetal_Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Pancreas","Fetal_Lung","Fetal-Liver","Brain","MammaryGland.Lactation","MammaryGland.Lactation","Small-Intestine","Neonatal-Rib","Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Testis","Lung","Bone_Marrow_Mesenchyme","Testis","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Uterus","Peripheral_Blood","Bone-Marrow_c-kit","Neonatal-Rib","Neonatal-Muscle","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal-Liver","Fetal_Lung","MammaryGland.Involution","MammaryGland.Lactation","Brain","Neonatal-Muscle","MammaryGland.Involution","MammaryGland.Lactation","Neonatal-Heart","Testis","Small-Intestine","Fetal_Stomache","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Stomache","Neonatal-Skin","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Placenta","Fetal_Stomache","Neonatal-Muscle","Trophoblast-Stem-Cell","Peripheral_Blood","Neonatal-Rib","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Testis","Embryonic-Stem-Cell","Bladder","Neonatal-Skin","Embryonic-Mesenchyme","Embryonic-Mesenchyme","Embryonic-Mesenchyme","Spleen","Neonatal-Skin","Fetal-Liver","Bone-Marrow","Testis","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Stomach","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Testis","Kidney","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Small-Intestine","Placenta","Testis","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Liver","Embryonic-Stem-Cell","Uterus","Testis","Embryonic-Stem-Cell","MammaryGland.Lactation","Pancreas","Trophoblast-Stem-Cell","MammaryGland.Involution","Neonatal-Rib","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Brain","Trophoblast-Stem-Cell","Stomach","Neonatal-Rib","Small-Intestine","Fetal_Intestine","Kidney","Prostate","Bone_Marrow_Mesenchyme","Peripheral_Blood","Ovary","Neonatal-Heart","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Fetal_Intestine","Peripheral_Blood","MammaryGland.Lactation","Small-Intestine","Kidney","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Brain","MammaryGland.Involution","Neonatal-Muscle","MammaryGland.Lactation","Small-Intestine","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Embryonic-Mesenchyme","MammaryGland.Lactation","MammaryGland.Lactation","Embryonic-Mesenchyme","MammaryGland.Involution","Small-Intestine","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Small-Intestine","MammaryGland.Lactation","Embryonic-Mesenchyme","Pancreas","Testis","Lung","Lung","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow_c-kit","Neonatal-Rib","Testis","Testis","Liver","Kidney","Bone_Marrow_Mesenchyme","Spleen","Neonatal-Calvaria","MammaryGland.Involution","Embryonic-Mesenchyme","Thymus","MammaryGland.Lactation","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal_Lung","Neonatal-Calvaria","Neonatal-Calvaria","Embryonic-Stem-Cell","Ovary","Brain","Thymus","Trophoblast-Stem-Cell","Neonatal-Muscle","Placenta","Muscle","Bladder","Placenta","Trophoblast-Stem-Cell","MammaryGland.Lactation","Small-Intestine","Fetal-Liver","Fetal_Stomache","Trophoblast-Stem-Cell","Testis","Embryonic-Mesenchyme","Fetal_Lung","Small-Intestine","Bone-Marrow","Small-Intestine","Neonatal-Rib","Fetal_Lung","Testis","Neonatal-Calvaria","Lung","Small-Intestine","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Testis","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Muscle","Fetal-Liver","Placenta","Testis","Neonatal-Heart","Ovary","Stomach","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Rib","Kidney","Peripheral_Blood","Neonatal-Muscle","Liver","Ovary","Thymus","MammaryGland.Lactation","Fetal_Brain","Prostate","Bladder","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Prostate","Neonatal-Calvaria","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Ovary","Trophoblast-Stem-Cell","Liver","Peripheral_Blood","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Fetal_Brain","Bone-Marrow_c-kit","Lung","Fetal-Liver","Fetal_Lung","Neonatal-Rib","Neonatal-Calvaria","Lung","MammaryGland.Lactation","Peripheral_Blood","Testis","Trophoblast-Stem-Cell","Stomach","Neonatal-Calvaria","Fetal_Stomache","Fetal_Stomache","Neonatal-Calvaria","Trophoblast-Stem-Cell","Uterus","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","Bone-Marrow_c-kit","Bone-Marrow","Fetal_Intestine","Trophoblast-Stem-Cell","Lung","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone-Marrow","Bone-Marrow","MammaryGland.Virgin","Testis","Uterus","Fetal_Lung","Bone-Marrow","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Testis","Peripheral_Blood","Lung","Bone-Marrow_c-kit","Testis","Mesenchymal-Stem-Cell-Cultured","Neonatal-Skin","Bone-Marrow","Embryonic-Stem-Cell","Neonatal-Rib","MammaryGland.Pregnancy","Placenta","Liver","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Ovary","Pancreas","Neonatal-Calvaria","MammaryGland.Lactation","Liver","Bone-Marrow_c-kit","Testis","MammaryGland.Lactation","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","MammaryGland.Pregnancy","Small-Intestine","Kidney","Trophoblast-Stem-Cell","Bone-Marrow","Neonatal-Calvaria","Peripheral_Blood","Bone-Marrow","Peripheral_Blood","Testis","Testis","Placenta","Pancreas","Placenta","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","Bone-Marrow","Neonatal-Rib","Liver","Bone-Marrow_c-kit","Pancreas","Trophoblast-Stem-Cell","Prostate","Testis","Neonatal-Skin","Embryonic-Mesenchyme","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","Bone-Marrow_c-kit","MammaryGland.Virgin","Neonatal-Heart","Fetal_Stomache","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Stomache","MammaryGland.Involution","Fetal_Lung","Stomach","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Lung","MammaryGland.Lactation","Fetal_Stomache","Bone_Marrow_Mesenchyme","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Kidney","Testis","Bone-Marrow","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Fetal_Lung","Neonatal-Rib","Neonatal-Skin","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Intestine","Uterus","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Uterus","Neonatal-Muscle","Bone-Marrow","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Neonatal-Muscle","Testis","Lung","Lung","Pancreas","Fetal_Intestine","Lung","Embryonic-Mesenchyme","Bladder","Liver","Testis","MammaryGland.Lactation","Fetal_Stomache","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Fetal_Lung","MammaryGland.Lactation","Testis","Placenta","Bone-Marrow_c-kit","Lung","Testis","Bone-Marrow_c-kit","Fetal_Brain","Neonatal-Rib","MammaryGland.Lactation","MammaryGland.Lactation","Spleen","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Placenta","Mesenchymal-Stem-Cell-Cultured","Prostate","Neonatal-Muscle","Neonatal-Rib","MammaryGland.Pregnancy","Peripheral_Blood","Fetal_Lung","Fetal_Intestine","Placenta","Brain","Bone-Marrow","Neonatal-Heart","MammaryGland.Lactation","Kidney","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Pancreas","MammaryGland.Lactation","Pancreas","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Thymus","Prostate","Testis","MammaryGland.Pregnancy","Ovary","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Uterus","Bone-Marrow_c-kit","Neonatal-Skin","MammaryGland.Lactation","Fetal_Lung","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow_c-kit","Neonatal-Calvaria","Fetal_Stomache","Liver","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Bone-Marrow_c-kit","Fetal_Stomache","Kidney","Stomach","Neonatal-Heart","Bone-Marrow_c-kit","Testis","Fetal_Intestine","Neonatal-Rib","Neonatal-Skin","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Lung","Stomach","Bone-Marrow","Fetal_Brain","Testis","Stomach","Trophoblast-Stem-Cell","Fetal-Liver","Fetal_Brain","Bone-Marrow_c-kit","Lung","Peripheral_Blood","Embryonic-Stem-Cell","Neonatal-Calvaria","Neonatal-Calvaria","Ovary","Neonatal-Calvaria","Fetal_Intestine","Lung","Neonatal-Muscle","Kidney","Fetal_Lung","Bladder","Kidney","Peripheral_Blood","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Prostate","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Lung","Bone-Marrow_c-kit","Ovary","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Stomach","Neonatal-Rib","Neonatal-Heart","Fetal_Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Liver","Lung","MammaryGland.Pregnancy","Bone-Marrow","Neonatal-Skin","Small-Intestine","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Pancreas","Fetal_Lung","Trophoblast-Stem-Cell","Lung","Fetal_Stomache","MammaryGland.Pregnancy","Pancreas","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Brain","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Bone_Marrow_Mesenchyme","Neonatal-Heart","Kidney","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Muscle","Neonatal-Skin","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Placenta","Neonatal-Calvaria","Liver","Kidney","Embryonic-Mesenchyme","Kidney","Fetal_Stomache","Embryonic-Stem-Cell","Neonatal-Calvaria","Thymus","Fetal_Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Kidney","Bone-Marrow","Peripheral_Blood","Lung","Fetal_Intestine","Fetal_Intestine","Neonatal-Rib","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Brain","Neonatal-Calvaria","Neonatal-Calvaria","Neonatal-Muscle","Embryonic-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Lactation","Brain","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Bone-Marrow_c-kit","Neonatal-Skin","Neonatal-Heart","MammaryGland.Lactation","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Thymus","MammaryGland.Lactation","Prostate","Bone-Marrow_c-kit","MammaryGland.Involution","Fetal_Stomache","Fetal_Intestine","Bladder","Trophoblast-Stem-Cell","Neonatal-Calvaria","Small-Intestine","Fetal_Intestine","Fetal_Lung","Uterus","Bone-Marrow_c-kit","Fetal-Liver","Bone-Marrow_c-kit","Kidney","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow","Kidney","Bone-Marrow_c-kit","Stomach","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow","Fetal-Liver","Bone-Marrow","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","MammaryGland.Lactation","MammaryGland.Involution","Stomach","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Rib","MammaryGland.Lactation","Peripheral_Blood","Testis","Peripheral_Blood","Fetal_Lung","Stomach","MammaryGland.Virgin","Ovary","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Liver","Neonatal-Calvaria","Peripheral_Blood","Trophoblast-Stem-Cell","Fetal-Liver","Thymus","Trophoblast-Stem-Cell","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","MammaryGland.Lactation","Small-Intestine","MammaryGland.Virgin","MammaryGland.Lactation","Kidney","Small-Intestine","Neonatal-Calvaria","MammaryGland.Lactation","Neonatal-Calvaria","Bone-Marrow","Fetal_Intestine","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Spleen","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Fetal_Lung","Bone-Marrow","Thymus","Neonatal-Calvaria","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Embryonic-Mesenchyme","Brain","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Spleen","Fetal_Stomache","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Kidney","Bone-Marrow","Fetal-Liver","Small-Intestine","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Neonatal-Skin","Testis","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Fetal_Stomache","Fetal_Lung","Ovary","Bone-Marrow","Thymus","Neonatal-Calvaria","Neonatal-Skin","Neonatal-Muscle","MammaryGland.Pregnancy","Small-Intestine","MammaryGland.Pregnancy","Fetal_Intestine","Fetal_Intestine","Small-Intestine","Neonatal-Calvaria","Uterus","Embryonic-Stem-Cell","MammaryGland.Lactation","Brain","Peripheral_Blood","Embryonic-Stem-Cell","Bone-Marrow","Fetal-Liver","Pancreas","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Brain","Testis","Trophoblast-Stem-Cell","Small-Intestine","Embryonic-Stem-Cell","Fetal_Intestine","Trophoblast-Stem-Cell","Small-Intestine","Prostate","Mesenchymal-Stem-Cell-Cultured","Brain","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Peripheral_Blood","MammaryGland.Involution","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow_c-kit","Kidney","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Fetal_Lung","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Liver","Placenta","MammaryGland.Involution","Testis","Bone-Marrow","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal-Liver","Peripheral_Blood","Neonatal-Calvaria","Neonatal-Calvaria","Embryonic-Mesenchyme","Bladder","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Lactation","Small-Intestine","MammaryGland.Pregnancy","Fetal_Intestine","Neonatal-Skin","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Liver","Small-Intestine","Small-Intestine","Ovary","Fetal_Intestine","Embryonic-Stem-Cell","Bone-Marrow","Testis","Liver","Thymus","MammaryGland.Lactation","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","MammaryGland.Involution","Peripheral_Blood","MammaryGland.Pregnancy","Liver","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Placenta","Liver","Uterus","Lung","Peripheral_Blood","MammaryGland.Lactation","Ovary","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Prostate","Trophoblast-Stem-Cell","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Neonatal-Rib","Neonatal-Calvaria","Testis","Neonatal-Calvaria","Neonatal-Muscle","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Lung","Bone-Marrow","Peripheral_Blood","Brain","Small-Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Skin","Fetal_Lung","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Ovary","Thymus","Fetal_Lung","MammaryGland.Involution","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Lung","Fetal_Stomache","Neonatal-Calvaria","Small-Intestine","Neonatal-Heart","Pancreas","Bone-Marrow","Fetal_Stomache","MammaryGland.Lactation","Neonatal-Calvaria","Neonatal-Calvaria","Bone-Marrow_c-kit","Small-Intestine","MammaryGland.Virgin","Fetal_Intestine","Brain","Testis","MammaryGland.Virgin","MammaryGland.Lactation","Fetal-Liver","Neonatal-Skin","Fetal_Lung","Thymus","Neonatal-Muscle","Spleen","Testis","Liver","Neonatal-Rib","Kidney","Neonatal-Calvaria","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Thymus","Trophoblast-Stem-Cell","Ovary","Trophoblast-Stem-Cell","Kidney","Neonatal-Heart","Neonatal-Heart","Fetal_Lung","Fetal_Lung","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Lung","Trophoblast-Stem-Cell","Fetal_Intestine","Prostate","Pancreas","Trophoblast-Stem-Cell","Testis","Neonatal-Muscle","Neonatal-Rib","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Fetal_Brain","Fetal_Intestine","Fetal_Intestine","Neonatal-Calvaria","Testis","Fetal-Liver","Bone-Marrow","Bone-Marrow_c-kit","Fetal_Intestine","Muscle","Bone-Marrow_c-kit","Pancreas","Peripheral_Blood","Small-Intestine","MammaryGland.Lactation","Embryonic-Stem-Cell","Fetal_Stomache","MammaryGland.Pregnancy","Liver","Testis","Placenta","Fetal_Lung","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Trophoblast-Stem-Cell","Uterus","Peripheral_Blood","Small-Intestine","Testis","Lung","Uterus","Bone_Marrow_Mesenchyme","Uterus","Fetal_Intestine","Kidney","Liver","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Placenta","MammaryGland.Lactation","Fetal_Stomache","Bone_Marrow_Mesenchyme","Spleen","Neonatal-Heart","Stomach","Peripheral_Blood","Bone-Marrow","Uterus","MammaryGland.Lactation","Lung","Fetal_Intestine","Peripheral_Blood","Uterus","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Fetal_Stomache","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Prostate","Bone_Marrow_Mesenchyme","Brain","Trophoblast-Stem-Cell","Neonatal-Calvaria","Testis","Neonatal-Skin","Embryonic-Mesenchyme","Fetal_Stomache","Fetal_Intestine","Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Uterus","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Thymus","Prostate","Pancreas","Neonatal-Heart","Fetal_Lung","Fetal_Intestine","Fetal_Lung","Neonatal-Skin","Bone-Marrow_c-kit","Testis","Neonatal-Calvaria","Fetal_Stomache","Spleen","Trophoblast-Stem-Cell","Placenta","MammaryGland.Pregnancy","Fetal_Intestine","Lung","Peripheral_Blood","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Stomach","Liver","MammaryGland.Virgin","Pancreas","Peripheral_Blood","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Neonatal-Calvaria","Bladder","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Virgin","MammaryGland.Lactation","Neonatal-Skin","Bone-Marrow_c-kit","Testis","Neonatal-Heart","MammaryGland.Virgin","MammaryGland.Involution","Peripheral_Blood","MammaryGland.Involution","Testis","MammaryGland.Lactation","Placenta","Uterus","Bone-Marrow_c-kit","MammaryGland.Involution","MammaryGland.Virgin","Embryonic-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Lactation","MammaryGland.Involution","Uterus","Bone-Marrow_c-kit","MammaryGland.Virgin","Bone-Marrow","Small-Intestine","Neonatal-Heart","Embryonic-Stem-Cell","Liver","Neonatal-Rib","Bone-Marrow_c-kit","Neonatal-Calvaria","Liver","Ovary","Brain","Kidney","Liver","Thymus","Liver","Neonatal-Heart","Lung","Neonatal-Skin","Bone-Marrow","MammaryGland.Lactation","Liver","Fetal_Lung","Fetal_Brain","Kidney","Fetal_Brain","Bone-Marrow","Fetal_Lung","Bone-Marrow","Fetal_Lung","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Intestine","MammaryGland.Virgin","Ovary","Bone-Marrow","Bone-Marrow_c-kit","Kidney","Uterus","MammaryGland.Lactation","Neonatal-Muscle","Fetal_Stomache","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Peripheral_Blood","Embryonic-Mesenchyme","Neonatal-Skin","MammaryGland.Lactation","Embryonic-Stem-Cell","Peripheral_Blood","Bone-Marrow_c-kit","Pancreas","MammaryGland.Lactation","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Uterus","Fetal-Liver","Trophoblast-Stem-Cell","Testis","Bone-Marrow","Fetal_Brain","Ovary","Embryonic-Stem-Cell","Fetal_Brain","Liver","Neonatal-Calvaria","Neonatal-Calvaria","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Neonatal-Rib","Bone-Marrow","Prostate","Trophoblast-Stem-Cell","MammaryGland.Lactation","Lung","Trophoblast-Stem-Cell","Neonatal-Calvaria","Peripheral_Blood","Bone-Marrow","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","Bone_Marrow_Mesenchyme","Fetal_Intestine","MammaryGland.Lactation","Bone-Marrow_c-kit","Kidney","Fetal_Brain","Pancreas","Embryonic-Stem-Cell","Lung","Trophoblast-Stem-Cell","Lung","Embryonic-Stem-Cell","Ovary","Liver","Brain","Thymus","MammaryGland.Lactation","MammaryGland.Virgin","Trophoblast-Stem-Cell","Small-Intestine","Placenta","MammaryGland.Involution","Peripheral_Blood","Trophoblast-Stem-Cell","Liver","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Placenta","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow","Trophoblast-Stem-Cell","Brain","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Kidney","MammaryGland.Lactation","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Heart","Peripheral_Blood","Trophoblast-Stem-Cell","Fetal_Intestine","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Testis","Liver","Bone-Marrow","Lung","Bone-Marrow_c-kit","Fetal-Liver","Fetal_Stomache","MammaryGland.Lactation","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Trophoblast-Stem-Cell","MammaryGland.Lactation","Lung","Neonatal-Calvaria","Bladder","MammaryGland.Lactation","Ovary","MammaryGland.Virgin","Liver","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Fetal_Lung","MammaryGland.Involution","Embryonic-Stem-Cell","Fetal_Intestine","Embryonic-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Involution","Fetal-Liver","Testis","Fetal_Lung","Small-Intestine","Fetal_Intestine","Prostate","MammaryGland.Virgin","Bone-Marrow","Bone-Marrow","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Lung","Testis","Peripheral_Blood","Embryonic-Stem-Cell","Fetal_Intestine","Bladder","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Spleen","MammaryGland.Pregnancy","Neonatal-Muscle","Trophoblast-Stem-Cell","Fetal_Stomache","Neonatal-Muscle","Lung","Bone-Marrow_c-kit","Ovary","Stomach","Bone-Marrow_c-kit","MammaryGland.Lactation","MammaryGland.Lactation","Small-Intestine","Bone-Marrow_c-kit","Fetal_Intestine","Fetal_Lung","Neonatal-Muscle","Fetal_Brain","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Small-Intestine","Uterus","Neonatal-Rib","Fetal-Liver","Fetal_Lung","Neonatal-Muscle","Bone-Marrow","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Calvaria","Neonatal-Calvaria","Trophoblast-Stem-Cell","MammaryGland.Involution","Trophoblast-Stem-Cell","Neonatal-Calvaria","MammaryGland.Lactation","Fetal-Liver","MammaryGland.Involution","Fetal_Intestine","Fetal_Stomache","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Neonatal-Heart","Muscle","Neonatal-Rib","Neonatal-Rib","Fetal_Stomache","Fetal_Intestine","Fetal_Stomache","Small-Intestine","Bone-Marrow","Testis","Brain","Testis","Bone_Marrow_Mesenchyme","Embryonic-Mesenchyme","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Rib","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","MammaryGland.Lactation","Bone-Marrow","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Stomach","Neonatal-Calvaria","Fetal_Lung","Trophoblast-Stem-Cell","Stomach","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Fetal_Lung","Small-Intestine","Kidney","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Uterus","Uterus","Testis","Neonatal-Heart","Uterus","Fetal_Brain","Bone-Marrow","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Lung","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Ovary","MammaryGland.Lactation","Liver","Lung","Embryonic-Stem-Cell","Liver","Trophoblast-Stem-Cell","Neonatal-Rib","Embryonic-Stem-Cell","Bone-Marrow","Neonatal-Skin","Bone-Marrow","Neonatal-Calvaria","Fetal_Intestine","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Fetal_Brain","Neonatal-Calvaria","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","MammaryGland.Lactation","Bone-Marrow","Bone-Marrow_c-kit","Pancreas","MammaryGland.Lactation","Peripheral_Blood","Embryonic-Mesenchyme","Peripheral_Blood","Placenta","Testis","Pancreas","Fetal_Brain","Ovary","MammaryGland.Involution","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Calvaria","Testis","Kidney","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Peripheral_Blood","Testis","Pancreas","Bone-Marrow_c-kit","Lung","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Neonatal-Rib","Fetal_Brain","Fetal-Liver","Mesenchymal-Stem-Cell-Cultured","Kidney","Thymus","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Stomach","Embryonic-Stem-Cell","Neonatal-Rib","Embryonic-Stem-Cell","MammaryGland.Virgin","Testis","Testis","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Spleen","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Thymus","Fetal_Intestine","Bone-Marrow_c-kit","Neonatal-Rib","Spleen","Ovary","Bone-Marrow","Fetal_Stomache","Kidney","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Prostate","Muscle","Testis","Stomach","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Peripheral_Blood","Neonatal-Calvaria","Placenta","Placenta","Ovary","MammaryGland.Involution","Embryonic-Stem-Cell","Pancreas","Liver","Neonatal-Calvaria","Neonatal-Calvaria","Bone-Marrow_c-kit","MammaryGland.Virgin","Small-Intestine","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Liver","Embryonic-Stem-Cell","Liver","Fetal_Lung","Kidney","Placenta","Stomach","MammaryGland.Lactation","Bone-Marrow","Liver","Trophoblast-Stem-Cell","Fetal-Liver","Lung","Neonatal-Calvaria","Small-Intestine","Peripheral_Blood","Thymus","MammaryGland.Lactation","Bone-Marrow_c-kit","Placenta","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Testis","Liver","Fetal_Intestine","Thymus","Neonatal-Calvaria","Neonatal-Calvaria","Peripheral_Blood","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Rib","Fetal-Liver","Lung","Ovary","Liver","MammaryGland.Lactation","Neonatal-Calvaria","Testis","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Ovary","Pancreas","Bone-Marrow_c-kit","Lung","Fetal_Brain","Ovary","Bone-Marrow_c-kit","Small-Intestine","Brain","Neonatal-Rib","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Fetal-Liver","Testis","Ovary","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Testis","MammaryGland.Lactation","Neonatal-Rib","Fetal_Intestine","Bone-Marrow_c-kit","Fetal_Brain","MammaryGland.Pregnancy","Prostate","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Fetal_Brain","Lung","Prostate","Embryonic-Stem-Cell","Ovary","Stomach","Fetal_Brain","Fetal_Brain","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Brain","MammaryGland.Virgin","Kidney","Mesenchymal-Stem-Cell-Cultured","Testis","Fetal_Intestine","Lung","Bone-Marrow_c-kit","Bone-Marrow","Peripheral_Blood","Small-Intestine","Bone-Marrow_c-kit","Peripheral_Blood","Bladder","Embryonic-Stem-Cell","Bone-Marrow","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Neonatal-Skin","Neonatal-Muscle","Neonatal-Heart","Fetal_Stomache","Embryonic-Mesenchyme","Neonatal-Calvaria","Trophoblast-Stem-Cell","Neonatal-Heart","Trophoblast-Stem-Cell","Thymus","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Fetal_Intestine","Neonatal-Muscle","Bladder","Kidney","Spleen","Neonatal-Rib","Trophoblast-Stem-Cell","Neonatal-Calvaria","Fetal_Stomache","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Ovary","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Lung","Neonatal-Skin","Neonatal-Skin","Stomach","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Thymus","Neonatal-Muscle","Placenta","Fetal-Liver","Bone-Marrow_c-kit","MammaryGland.Involution","Small-Intestine","Bone-Marrow","MammaryGland.Lactation","Testis","Embryonic-Stem-Cell","Testis","Brain","Fetal_Intestine","Kidney","Neonatal-Muscle","Bone-Marrow_c-kit","MammaryGland.Lactation","Trophoblast-Stem-Cell","Testis","MammaryGland.Involution","Trophoblast-Stem-Cell","MammaryGland.Lactation","Trophoblast-Stem-Cell","Liver","Fetal_Brain","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Uterus","MammaryGland.Pregnancy","Fetal_Intestine","Bone-Marrow","Fetal_Stomache","Bone-Marrow","Embryonic-Stem-Cell","Small-Intestine","Testis","Fetal-Liver","Bone-Marrow_c-kit","Neonatal-Muscle","Neonatal-Rib","Trophoblast-Stem-Cell","Spleen","Peripheral_Blood","Neonatal-Heart","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Lung","Placenta","Trophoblast-Stem-Cell","Bone-Marrow","Testis","Neonatal-Calvaria","Ovary","MammaryGland.Virgin","Testis","Bone-Marrow","Trophoblast-Stem-Cell","MammaryGland.Virgin","Trophoblast-Stem-Cell","Testis","Liver","Trophoblast-Stem-Cell","Liver","MammaryGland.Involution","Peripheral_Blood","Thymus","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Liver","Fetal_Lung","Neonatal-Heart","Bone-Marrow_c-kit","Lung","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","MammaryGland.Involution","Bone-Marrow_c-kit","MammaryGland.Lactation","Pancreas","Peripheral_Blood","Neonatal-Muscle","Bone-Marrow","Testis","Bone-Marrow","Neonatal-Calvaria","Bone-Marrow_c-kit","Fetal_Stomache","Spleen","Pancreas","Trophoblast-Stem-Cell","Fetal_Intestine","Spleen","Liver","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Placenta","Peripheral_Blood","Neonatal-Calvaria","Lung","Neonatal-Muscle","Bone-Marrow_c-kit","Lung","MammaryGland.Virgin","Thymus","Fetal_Lung","Fetal_Intestine","Fetal_Brain","Stomach","MammaryGland.Lactation","Peripheral_Blood","Bone_Marrow_Mesenchyme","Fetal_Brain","Testis","Testis","Bone-Marrow_c-kit","Fetal_Brain","Fetal_Intestine","Bone-Marrow","MammaryGland.Pregnancy","Small-Intestine","Embryonic-Mesenchyme","Bone-Marrow_c-kit","MammaryGland.Involution","Lung","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Embryonic-Mesenchyme","Bone-Marrow","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","MammaryGland.Pregnancy","Small-Intestine","Neonatal-Heart","Liver","MammaryGland.Lactation","Fetal_Stomache","Bone-Marrow_c-kit","Bone-Marrow","Testis","MammaryGland.Involution","Neonatal-Rib","Bone-Marrow","Testis","Neonatal-Rib","Fetal_Stomache","Embryonic-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow","Neonatal-Rib","Trophoblast-Stem-Cell","MammaryGland.Involution","Neonatal-Heart","Kidney","Bladder","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Thymus","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Placenta","Pancreas","Embryonic-Mesenchyme","Fetal_Brain","Bone-Marrow_c-kit","Placenta","Mesenchymal-Stem-Cell-Cultured","Liver","Lung","Prostate","Neonatal-Muscle","Neonatal-Skin","Neonatal-Rib","Liver","Neonatal-Muscle","Pancreas","Peripheral_Blood","Pancreas","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Stomach","MammaryGland.Lactation","Brain","Bone-Marrow","Trophoblast-Stem-Cell","Bone-Marrow","Trophoblast-Stem-Cell","Peripheral_Blood","Spleen","Neonatal-Skin","Neonatal-Calvaria","Ovary","Bone-Marrow","Neonatal-Calvaria","MammaryGland.Virgin","Fetal_Intestine","Embryonic-Stem-Cell","Stomach","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Uterus","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Bone-Marrow","Bone-Marrow","Stomach","Neonatal-Heart","Bone-Marrow","Small-Intestine","Small-Intestine","Bone-Marrow_c-kit","Neonatal-Skin","Fetal_Lung","Testis","Embryonic-Stem-Cell","MammaryGland.Virgin","Placenta","Bone-Marrow_c-kit","Neonatal-Muscle","Ovary","Mesenchymal-Stem-Cell-Cultured","Lung","Lung","Bone-Marrow_c-kit","Peripheral_Blood","Placenta","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Bone-Marrow_c-kit","Testis","Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Stomach","Fetal_Brain","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Stomach","Pancreas","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","Neonatal-Heart","Neonatal-Heart","Kidney","Peripheral_Blood","Embryonic-Mesenchyme","Neonatal-Calvaria","Thymus","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Involution","MammaryGland.Virgin","Fetal_Stomache","Neonatal-Calvaria","Brain","Fetal_Lung","Bone-Marrow","Fetal_Intestine","Peripheral_Blood","Peripheral_Blood","Embryonic-Stem-Cell","Fetal_Stomache","MammaryGland.Lactation","Liver","MammaryGland.Lactation","Bone-Marrow_c-kit","Ovary","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Bladder","MammaryGland.Lactation","Testis","MammaryGland.Pregnancy","Fetal_Lung","Embryonic-Stem-Cell","Prostate","Bone-Marrow_c-kit","Brain","Thymus","MammaryGland.Lactation","Embryonic-Stem-Cell","Kidney","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Fetal_Brain","Lung","Placenta","Testis","MammaryGland.Pregnancy","Neonatal-Muscle","Brain","Fetal_Stomache","Fetal_Stomache","Fetal-Liver","Neonatal-Rib","Fetal_Lung","Bone-Marrow","Testis","Bone_Marrow_Mesenchyme","Bone-Marrow","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow","Bone_Marrow_Mesenchyme","Small-Intestine","Small-Intestine","Neonatal-Skin","Bone-Marrow_c-kit","Peripheral_Blood","Fetal_Stomache","MammaryGland.Virgin","Spleen","MammaryGland.Lactation","Embryonic-Stem-Cell","Peripheral_Blood","MammaryGland.Involution","Embryonic-Stem-Cell","Neonatal-Calvaria","Embryonic-Stem-Cell","Testis","Uterus","Ovary","Fetal_Stomache","Liver","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Heart","Bone-Marrow_c-kit","MammaryGland.Virgin","Embryonic-Stem-Cell","Kidney","Neonatal-Rib","Trophoblast-Stem-Cell","Testis","MammaryGland.Pregnancy","Peripheral_Blood","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Kidney","Thymus","Fetal_Lung","MammaryGland.Involution","Bone-Marrow_c-kit","Small-Intestine","Fetal_Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow_c-kit","Stomach","Bone-Marrow_c-kit","Neonatal-Muscle","Embryonic-Mesenchyme","Neonatal-Skin","Placenta","Trophoblast-Stem-Cell","Testis","Neonatal-Calvaria","Placenta","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Ovary","MammaryGland.Lactation","MammaryGland.Lactation","Peripheral_Blood","Embryonic-Stem-Cell","Bone-Marrow","MammaryGland.Pregnancy","Neonatal-Rib","Embryonic-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Lactation","Spleen","Bone-Marrow","Thymus","Lung","Fetal_Lung","Bone_Marrow_Mesenchyme","Brain","Testis","MammaryGland.Lactation","MammaryGland.Lactation","Fetal_Stomache","MammaryGland.Lactation","Bone-Marrow_c-kit","Testis","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","MammaryGland.Lactation","Neonatal-Rib","Trophoblast-Stem-Cell","Neonatal-Calvaria","MammaryGland.Lactation","Kidney","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Testis","Fetal_Stomache","Fetal_Stomache","Bone-Marrow_c-kit","MammaryGland.Lactation","Embryonic-Stem-Cell","Fetal_Stomache","Fetal_Stomache","Neonatal-Rib","Neonatal-Calvaria","Testis","Neonatal-Rib","Bone-Marrow","MammaryGland.Involution","Bone-Marrow","MammaryGland.Involution","MammaryGland.Pregnancy","Pancreas","MammaryGland.Involution","MammaryGland.Pregnancy","Thymus","Neonatal-Rib","Muscle","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Testis","Peripheral_Blood","Spleen","Trophoblast-Stem-Cell","Fetal-Liver","Lung","Lung","Neonatal-Calvaria","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Brain","Ovary","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","MammaryGland.Lactation","MammaryGland.Virgin","Kidney","MammaryGland.Virgin","Pancreas","Lung","Stomach","MammaryGland.Virgin","Bone-Marrow_c-kit","Neonatal-Rib","Neonatal-Muscle","Neonatal-Heart","Small-Intestine","Fetal_Brain","Testis","Bone-Marrow","Fetal_Intestine","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Brain","Ovary","Bone_Marrow_Mesenchyme","Small-Intestine","Neonatal-Muscle","Neonatal-Calvaria","MammaryGland.Virgin","MammaryGland.Lactation","Bone-Marrow_c-kit","Neonatal-Rib","Embryonic-Stem-Cell","Neonatal-Rib","Testis","Neonatal-Skin","Bone_Marrow_Mesenchyme","Ovary","Trophoblast-Stem-Cell","Neonatal-Calvaria","Fetal_Lung","Trophoblast-Stem-Cell","Brain","Placenta","Fetal_Stomache","Trophoblast-Stem-Cell","Fetal_Stomache","Peripheral_Blood","Uterus","Neonatal-Calvaria","Bone-Marrow_c-kit","Fetal_Stomache","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Neonatal-Muscle","MammaryGland.Lactation","Fetal_Stomache","Thymus","Fetal-Liver","Neonatal-Rib","MammaryGland.Virgin","Bone-Marrow","Stomach","Bone-Marrow","Neonatal-Muscle","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow","Bone_Marrow_Mesenchyme","Fetal_Intestine","Embryonic-Stem-Cell","Thymus","Mesenchymal-Stem-Cell-Cultured","Neonatal-Heart","Embryonic-Stem-Cell","Testis","Fetal-Liver","Bone-Marrow","Liver","Neonatal-Heart","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Testis","Lung","Stomach","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Testis","Bone-Marrow","Small-Intestine","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Testis","MammaryGland.Pregnancy","Brain","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Intestine","Kidney","Bladder","Thymus","Uterus","Embryonic-Mesenchyme","Neonatal-Calvaria","MammaryGland.Involution","Bone-Marrow_c-kit","Fetal_Brain","Peripheral_Blood","MammaryGland.Involution","Fetal_Brain","Embryonic-Stem-Cell","Kidney","Neonatal-Rib","Testis","Liver","Placenta","Pancreas","Embryonic-Stem-Cell","Small-Intestine","Brain","Testis","Bone-Marrow_c-kit","MammaryGland.Pregnancy","MammaryGland.Involution","Peripheral_Blood","Trophoblast-Stem-Cell","Thymus","MammaryGland.Pregnancy","Lung","Lung","Fetal_Stomache","MammaryGland.Lactation","Uterus","Peripheral_Blood","Bone-Marrow_c-kit","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Brain","Testis","Testis","Peripheral_Blood","Fetal-Liver","Fetal_Brain","Neonatal-Muscle","Trophoblast-Stem-Cell","Placenta","Liver","Small-Intestine","Bone-Marrow","MammaryGland.Pregnancy","Neonatal-Heart","Trophoblast-Stem-Cell","MammaryGland.Lactation","Placenta","Fetal_Stomache","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Peripheral_Blood","Kidney","Small-Intestine","Fetal_Stomache","Peripheral_Blood","Embryonic-Mesenchyme","Neonatal-Calvaria","Embryonic-Mesenchyme","Placenta","Uterus","Fetal_Lung","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Kidney","Brain","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Peripheral_Blood","Lung","Lung","MammaryGland.Lactation","Bone-Marrow_c-kit","Placenta","Neonatal-Calvaria","Fetal_Brain","Neonatal-Rib","Trophoblast-Stem-Cell","Spleen","Lung","Bone-Marrow_c-kit","Neonatal-Heart","Fetal_Stomache","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Fetal_Brain","Fetal_Lung","Ovary","Trophoblast-Stem-Cell","Fetal-Liver","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bladder","Mesenchymal-Stem-Cell-Cultured","Fetal-Liver","Bone-Marrow_c-kit","Ovary","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Fetal_Intestine","Bone-Marrow","Bone-Marrow_c-kit","Fetal_Stomache","Liver","Fetal_Stomache","Pancreas","MammaryGland.Involution","Peripheral_Blood","Embryonic-Stem-Cell","Brain","Trophoblast-Stem-Cell","MammaryGland.Virgin","Bone-Marrow_c-kit","Fetal_Intestine","Prostate","Bone-Marrow_c-kit","MammaryGland.Virgin","Bone-Marrow","Bladder","Embryonic-Stem-Cell","MammaryGland.Lactation","Brain","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Neonatal-Muscle","Neonatal-Heart","Ovary","Neonatal-Calvaria","Lung","Neonatal-Skin","Pancreas","Fetal-Liver","Neonatal-Calvaria","Bone-Marrow_c-kit","Testis","Kidney","Small-Intestine","Fetal_Stomache","Ovary","Embryonic-Mesenchyme","Brain","Bladder","Fetal_Intestine","MammaryGland.Lactation","Bone-Marrow_c-kit","Peripheral_Blood","Spleen","Neonatal-Calvaria","Testis","Trophoblast-Stem-Cell","Fetal_Lung","Fetal_Brain","MammaryGland.Virgin","Neonatal-Heart","Trophoblast-Stem-Cell","Bone-Marrow","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Thymus","Trophoblast-Stem-Cell","Small-Intestine","MammaryGland.Lactation","Small-Intestine","Trophoblast-Stem-Cell","MammaryGland.Virgin","Bone-Marrow","Uterus","Uterus","MammaryGland.Involution","Neonatal-Calvaria","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Muscle","Embryonic-Stem-Cell","Testis","Kidney","Bone-Marrow_c-kit","Brain","Spleen","Neonatal-Skin","Bone-Marrow_c-kit","MammaryGland.Involution","Uterus","Testis","Spleen","MammaryGland.Virgin","Neonatal-Rib","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Kidney","Kidney","Bone-Marrow_c-kit","MammaryGland.Pregnancy","MammaryGland.Lactation","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Muscle","Fetal_Stomache","Fetal_Intestine","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Peripheral_Blood","Bladder","Kidney","Testis","Neonatal-Rib","Bone-Marrow_c-kit","Stomach","Neonatal-Calvaria","Testis","Trophoblast-Stem-Cell","Prostate","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Testis","Neonatal-Muscle","Testis","Brain","Peripheral_Blood","MammaryGland.Lactation","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Thymus","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Neonatal-Skin","Testis","Trophoblast-Stem-Cell","Fetal_Stomache","Neonatal-Heart","Trophoblast-Stem-Cell","Testis","Neonatal-Heart","Embryonic-Stem-Cell","Bone-Marrow","Muscle","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bladder","Embryonic-Stem-Cell","Fetal_Stomache","Trophoblast-Stem-Cell","Peripheral_Blood","Embryonic-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Involution","Embryonic-Stem-Cell","Peripheral_Blood","Neonatal-Rib","Fetal-Liver","Placenta","Neonatal-Muscle","Brain","Placenta","Thymus","Peripheral_Blood","Neonatal-Rib","Liver","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Testis","Liver","Testis","Bone-Marrow","Neonatal-Rib","Fetal_Brain","Fetal_Intestine","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Fetal-Liver","MammaryGland.Lactation","Testis","MammaryGland.Virgin","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Calvaria","Stomach","Bone-Marrow_c-kit","Spleen","Testis","MammaryGland.Lactation","Bone-Marrow","Thymus","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","Fetal_Brain","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Muscle","Thymus","Thymus","Pancreas","Uterus","Uterus","Prostate","Trophoblast-Stem-Cell","Testis","Fetal_Lung","Pancreas","Testis","Bone-Marrow_c-kit","Stomach","MammaryGland.Lactation","Prostate","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","Neonatal-Heart","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Neonatal-Skin","Brain","Peripheral_Blood","Stomach","Bone-Marrow_c-kit","Liver","Fetal_Intestine","MammaryGland.Lactation","Embryonic-Stem-Cell","Ovary","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Thymus","Peripheral_Blood","Fetal_Lung","Trophoblast-Stem-Cell","Ovary","Brain","Bone-Marrow","Neonatal-Heart","Testis","Fetal_Stomache","Testis","Spleen","MammaryGland.Lactation","Small-Intestine","Neonatal-Calvaria","Neonatal-Skin","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Thymus","Liver","Small-Intestine","Neonatal-Heart","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Brain","Prostate","Bone-Marrow","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Involution","Embryonic-Stem-Cell","Bone-Marrow","Ovary","Fetal_Brain","MammaryGland.Pregnancy","Neonatal-Heart","Bone-Marrow","Embryonic-Stem-Cell","Bone-Marrow","Spleen","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Neonatal-Heart","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Bone-Marrow","Neonatal-Calvaria","Trophoblast-Stem-Cell","Bone-Marrow","Bone_Marrow_Mesenchyme","Neonatal-Rib","Embryonic-Stem-Cell","Neonatal-Rib","Neonatal-Muscle","Ovary","Testis","Neonatal-Muscle","Bladder","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow","Fetal_Brain","Trophoblast-Stem-Cell","Liver","Mesenchymal-Stem-Cell-Cultured","Kidney","Bone-Marrow","Fetal_Lung","Neonatal-Muscle","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Muscle","Neonatal-Rib","Fetal_Brain","Thymus","Thymus","Fetal_Brain","Liver","Fetal_Brain","Bladder","Fetal_Stomache","Brain","Kidney","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Calvaria","Small-Intestine","MammaryGland.Lactation","Fetal_Stomache","Neonatal-Calvaria","Testis","Fetal_Intestine","Uterus","MammaryGland.Lactation","Fetal-Liver","Thymus","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Lactation","Testis","Bone_Marrow_Mesenchyme","Fetal_Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal-Liver","Testis","Fetal_Lung","Trophoblast-Stem-Cell","Thymus","Neonatal-Calvaria","Muscle","Prostate","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Uterus","Testis","Liver","Trophoblast-Stem-Cell","Neonatal-Rib","Neonatal-Heart","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","MammaryGland.Virgin","Thymus","Trophoblast-Stem-Cell","Testis","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Bone-Marrow","Neonatal-Skin","Kidney","Bone-Marrow_c-kit","Liver","Ovary","Liver","Prostate","Testis","MammaryGland.Lactation","Placenta","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Fetal_Stomache","Peripheral_Blood","Brain","Neonatal-Calvaria","Fetal_Stomache","Testis","Peripheral_Blood","Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Calvaria","Trophoblast-Stem-Cell","Kidney","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Pancreas","Fetal_Brain","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow","Lung","Testis","MammaryGland.Lactation","Fetal_Intestine","Pancreas","Trophoblast-Stem-Cell","Neonatal-Skin","Bone-Marrow","Uterus","Fetal_Intestine","Liver","Embryonic-Stem-Cell","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bladder","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Uterus","Bone_Marrow_Mesenchyme","Fetal_Lung","Neonatal-Muscle","Trophoblast-Stem-Cell","Peripheral_Blood","Peripheral_Blood","MammaryGland.Lactation","Small-Intestine","Testis","Peripheral_Blood","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Testis","Embryonic-Stem-Cell","Neonatal-Calvaria","Fetal_Lung","Bone-Marrow","MammaryGland.Involution","Bone-Marrow_c-kit","Testis","Fetal_Brain","Fetal_Intestine","Neonatal-Muscle","Neonatal-Calvaria","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bone-Marrow_c-kit","Brain","Testis","Embryonic-Stem-Cell","Testis","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Lung","MammaryGland.Pregnancy","Neonatal-Calvaria","Fetal-Liver","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Virgin","Small-Intestine","Neonatal-Calvaria","Brain","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Neonatal-Muscle","Neonatal-Muscle","MammaryGland.Pregnancy","Pancreas","MammaryGland.Lactation","Neonatal-Calvaria","Bone-Marrow","Liver","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Bone-Marrow","Brain","Neonatal-Rib","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Placenta","Bone-Marrow_c-kit","Brain","Bone_Marrow_Mesenchyme","Small-Intestine","Fetal_Intestine","Fetal_Stomache","Bone-Marrow_c-kit","Fetal-Liver","Bone-Marrow_c-kit","Uterus","Embryonic-Mesenchyme","Peripheral_Blood","Brain","Mesenchymal-Stem-Cell-Cultured","Uterus","Peripheral_Blood","Thymus","Pancreas","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Liver","Prostate","Spleen","Fetal_Lung","Fetal_Intestine","Placenta","Bladder","Bone-Marrow","MammaryGland.Lactation","Pancreas","Fetal_Lung","MammaryGland.Lactation","MammaryGland.Lactation","Bone-Marrow_c-kit","MammaryGland.Involution","MammaryGland.Lactation","MammaryGland.Lactation","Bone-Marrow_c-kit","MammaryGland.Lactation","Testis","Fetal_Intestine","Lung","Neonatal-Skin","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Stomache","MammaryGland.Lactation","Neonatal-Rib","Placenta","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Neonatal-Rib","MammaryGland.Virgin","MammaryGland.Involution","Peripheral_Blood","Neonatal-Rib","Placenta","Trophoblast-Stem-Cell","Lung","Neonatal-Calvaria","Bone-Marrow_c-kit","Fetal_Stomache","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Brain","MammaryGland.Pregnancy","Uterus","Bone-Marrow_c-kit","Neonatal-Calvaria","Testis","Lung","Neonatal-Calvaria","Bone-Marrow","Bone-Marrow_c-kit","Brain","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Fetal_Lung","Neonatal-Rib","Bone-Marrow_c-kit","Fetal_Lung","Fetal_Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Lung","Neonatal-Calvaria","Neonatal-Skin","Fetal_Intestine","Placenta","Prostate","Testis","Testis","Fetal_Lung","Bone-Marrow_c-kit","Testis","Embryonic-Mesenchyme","Bone-Marrow","Testis","Bone-Marrow","Fetal_Stomache","Fetal-Liver","Bone-Marrow_c-kit","MammaryGland.Lactation","Ovary","Fetal_Intestine","Neonatal-Calvaria","Testis","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Small-Intestine","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Lung","Liver","Lung","Neonatal-Rib","Testis","Bone-Marrow_c-kit","Neonatal-Muscle","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Prostate","Embryonic-Stem-Cell","Brain","MammaryGland.Involution","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Fetal_Lung","Neonatal-Heart","Fetal_Intestine","Bone-Marrow","Placenta","Fetal_Intestine","Thymus","Bone-Marrow","Fetal_Intestine","Placenta","Neonatal-Heart","MammaryGland.Lactation","Embryonic-Stem-Cell","Ovary","Placenta","Fetal_Lung","MammaryGland.Lactation","Embryonic-Stem-Cell","Bone-Marrow","Liver","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Small-Intestine","MammaryGland.Virgin","Embryonic-Mesenchyme","Placenta","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Liver","MammaryGland.Lactation","Bone-Marrow","Lung","Neonatal-Heart","Fetal_Stomache","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Fetal_Stomache","Brain","Neonatal-Calvaria","Neonatal-Calvaria","Liver","Small-Intestine","Kidney","Trophoblast-Stem-Cell","Bladder","Lung","Bone-Marrow_c-kit","MammaryGland.Virgin","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Bone-Marrow_c-kit","Kidney","Bone_Marrow_Mesenchyme","Thymus","Uterus","Testis","Fetal_Brain","Peripheral_Blood","Uterus","Peripheral_Blood","Neonatal-Calvaria","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Spleen","Spleen","Brain","Fetal_Lung","Fetal_Brain","Fetal_Intestine","Trophoblast-Stem-Cell","Kidney","Kidney","Neonatal-Heart","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bladder","Uterus","Testis","Testis","Fetal_Intestine","Liver","Neonatal-Calvaria","Bone-Marrow_c-kit","Placenta","Small-Intestine","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Thymus","Testis","Bone-Marrow_c-kit","Bone-Marrow","Lung","MammaryGland.Lactation","MammaryGland.Involution","Bone-Marrow_c-kit","Kidney","Neonatal-Calvaria","Embryonic-Mesenchyme","Fetal_Brain","Testis","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Placenta","Fetal_Lung","Spleen","Neonatal-Muscle","MammaryGland.Lactation","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Fetal_Intestine","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bladder","Neonatal-Calvaria","Bone-Marrow_c-kit","Ovary","Bone-Marrow","MammaryGland.Lactation","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Thymus","Peripheral_Blood","Thymus","Uterus","Neonatal-Rib","Neonatal-Calvaria","Bone-Marrow_c-kit","Thymus","Neonatal-Calvaria","Bone-Marrow_c-kit","Ovary","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow","Bone-Marrow","Neonatal-Heart","Fetal_Lung","Bladder","Bone-Marrow_c-kit","Prostate","MammaryGland.Lactation","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Lung","Fetal_Lung","Neonatal-Calvaria","Small-Intestine","Bone-Marrow_c-kit","Small-Intestine","Fetal_Stomache","Testis","MammaryGland.Involution","Testis","Fetal_Stomache","Testis","Fetal_Stomache","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Fetal_Intestine","Bone_Marrow_Mesenchyme","Small-Intestine","Fetal_Stomache","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Fetal_Brain","MammaryGland.Lactation","Embryonic-Stem-Cell","MammaryGland.Involution","Peripheral_Blood","Embryonic-Stem-Cell","Fetal_Stomache","Fetal_Intestine","Fetal_Lung","Testis","Neonatal-Muscle","MammaryGland.Lactation","Ovary","Fetal_Stomache","Embryonic-Mesenchyme","Neonatal-Calvaria","Neonatal-Muscle","Embryonic-Mesenchyme","Neonatal-Muscle","Small-Intestine","Peripheral_Blood","Testis","MammaryGland.Involution","Embryonic-Stem-Cell","Prostate","MammaryGland.Lactation","Placenta","Fetal_Lung","Peripheral_Blood","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Neonatal-Heart","Thymus","MammaryGland.Involution","Trophoblast-Stem-Cell","Spleen","Neonatal-Heart","Mesenchymal-Stem-Cell-Cultured","Testis","Brain","Testis","Muscle","Bladder","Embryonic-Stem-Cell","Brain","Neonatal-Skin","Bone-Marrow_c-kit","Prostate","MammaryGland.Lactation","Testis","Testis","MammaryGland.Pregnancy","Spleen","Fetal_Lung","Small-Intestine","Testis","Fetal_Lung","MammaryGland.Lactation","Bone-Marrow_c-kit","MammaryGland.Lactation","Testis","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal-Liver","MammaryGland.Pregnancy","Fetal_Brain","Placenta","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Thymus","Neonatal-Calvaria","Peripheral_Blood","MammaryGland.Involution","MammaryGland.Lactation","Neonatal-Rib","Bone-Marrow","Testis","Bone_Marrow_Mesenchyme","Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Pancreas","Trophoblast-Stem-Cell","Thymus","Bone-Marrow_c-kit","Embryonic-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Muscle","Bone-Marrow_c-kit","Liver","Trophoblast-Stem-Cell","Bone-Marrow","Fetal_Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Bone-Marrow_c-kit","Pancreas","Liver","Kidney","Bone-Marrow_c-kit","Spleen","Ovary","Small-Intestine","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","Lung","Neonatal-Heart","Fetal_Stomache","MammaryGland.Involution","Brain","Bone-Marrow_c-kit","MammaryGland.Lactation","Liver","Ovary","Stomach","MammaryGland.Virgin","Trophoblast-Stem-Cell","MammaryGland.Virgin","Embryonic-Mesenchyme","Bone_Marrow_Mesenchyme","Small-Intestine","Liver","Pancreas","Neonatal-Rib","MammaryGland.Lactation","Fetal_Stomache","Neonatal-Rib","MammaryGland.Virgin","Fetal-Liver","Brain","MammaryGland.Virgin","MammaryGland.Involution","Neonatal-Skin","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Testis","Fetal_Stomache","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Heart","Neonatal-Calvaria","Spleen","Pancreas","Peripheral_Blood","Brain","Stomach","Embryonic-Stem-Cell","Neonatal-Calvaria","Neonatal-Muscle","Bone-Marrow","Fetal_Intestine","Bone-Marrow","Trophoblast-Stem-Cell","Small-Intestine","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Fetal_Stomache","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Small-Intestine","Brain","Neonatal-Rib","Kidney","Fetal_Lung","Small-Intestine","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Testis","MammaryGland.Involution","Fetal_Intestine","Placenta","Testis","MammaryGland.Virgin","Neonatal-Rib","Bone-Marrow_c-kit","Neonatal-Calvaria","Trophoblast-Stem-Cell","Fetal_Intestine","Embryonic-Mesenchyme","Fetal_Lung","Fetal_Stomache","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Liver","Ovary","Trophoblast-Stem-Cell","Kidney","Liver","MammaryGland.Lactation","Pancreas","Fetal_Intestine","Bone-Marrow_c-kit","Fetal_Intestine","MammaryGland.Lactation","Trophoblast-Stem-Cell","Neonatal-Rib","Neonatal-Rib","Neonatal-Muscle","Lung","Neonatal-Calvaria","Bone-Marrow_c-kit","Uterus","Fetal_Lung","Embryonic-Mesenchyme","Small-Intestine","Liver","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","MammaryGland.Virgin","Neonatal-Calvaria","Kidney","MammaryGland.Lactation","Pancreas","Bone_Marrow_Mesenchyme","Fetal_Stomache","Thymus","Neonatal-Muscle","Kidney","MammaryGland.Lactation","Fetal_Brain","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Ovary","Trophoblast-Stem-Cell","Neonatal-Skin","Neonatal-Muscle","Ovary","Small-Intestine","Trophoblast-Stem-Cell","Neonatal-Calvaria","Neonatal-Rib","Bone-Marrow_c-kit","Brain","Small-Intestine","Neonatal-Calvaria","Liver","Embryonic-Mesenchyme","Bone-Marrow","Neonatal-Heart","Brain","Ovary","Embryonic-Mesenchyme","MammaryGland.Lactation","Fetal_Lung","Lung","Brain","Fetal_Lung","Testis","MammaryGland.Involution","MammaryGland.Lactation","Bone-Marrow","Neonatal-Muscle","Bladder","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Small-Intestine","Embryonic-Mesenchyme","Neonatal-Calvaria","Bone-Marrow_c-kit","Neonatal-Skin","Embryonic-Mesenchyme","Bone-Marrow","Neonatal-Skin","Bladder","Bladder","Prostate","Lung","Bone-Marrow","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Brain","Embryonic-Stem-Cell","Testis","Kidney","Fetal_Lung","Embryonic-Stem-Cell","Testis","Trophoblast-Stem-Cell","Neonatal-Muscle","Neonatal-Calvaria","Neonatal-Calvaria","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Fetal_Stomache","Neonatal-Rib","Trophoblast-Stem-Cell","Testis","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Lung","Thymus","Neonatal-Muscle","MammaryGland.Lactation","MammaryGland.Lactation","Bladder","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Spleen","Bone-Marrow_c-kit","Bone-Marrow","Trophoblast-Stem-Cell","Neonatal-Heart","Brain","Testis","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow","MammaryGland.Virgin","MammaryGland.Pregnancy","Fetal_Intestine","Neonatal-Calvaria","Thymus","Fetal_Lung","Fetal_Intestine","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Peripheral_Blood","MammaryGland.Lactation","Neonatal-Muscle","Placenta","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Small-Intestine","MammaryGland.Lactation","Embryonic-Stem-Cell","MammaryGland.Virgin","Neonatal-Rib","Kidney","Fetal_Brain","MammaryGland.Virgin","Bone-Marrow","Lung","Fetal_Intestine","Liver","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Liver","Fetal_Brain","Neonatal-Calvaria","Neonatal-Calvaria","MammaryGland.Lactation","Neonatal-Rib","Bone-Marrow_c-kit","Fetal_Stomache","Neonatal-Calvaria","Trophoblast-Stem-Cell","Muscle","MammaryGland.Virgin","Testis","Kidney","Brain","Neonatal-Calvaria","Ovary","Neonatal-Calvaria","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","MammaryGland.Lactation","Kidney","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Testis","Neonatal-Rib","Brain","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Fetal_Lung","Trophoblast-Stem-Cell","Fetal_Intestine","Fetal_Intestine","Fetal_Stomache","Trophoblast-Stem-Cell","Liver","Placenta","Neonatal-Skin","Trophoblast-Stem-Cell","Prostate","Trophoblast-Stem-Cell","Bone-Marrow","Bone-Marrow","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Pancreas","Bone-Marrow","Fetal_Intestine","Bone-Marrow_c-kit","MammaryGland.Virgin","Trophoblast-Stem-Cell","MammaryGland.Involution","MammaryGland.Lactation","Ovary","Prostate","Kidney","Neonatal-Skin","Neonatal-Rib","Neonatal-Heart","Fetal_Intestine","Bone-Marrow_c-kit","Bone-Marrow","Lung","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow_c-kit","Bone-Marrow","Testis","Bone_Marrow_Mesenchyme","Stomach","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Neonatal-Calvaria","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Virgin","Embryonic-Stem-Cell","Peripheral_Blood","MammaryGland.Lactation","Neonatal-Calvaria","Bone-Marrow","Bone-Marrow_c-kit","Neonatal-Muscle","Kidney","MammaryGland.Virgin","Trophoblast-Stem-Cell","Small-Intestine","Embryonic-Stem-Cell","Ovary","Embryonic-Stem-Cell","Uterus","Fetal_Stomache","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Testis","Trophoblast-Stem-Cell","Neonatal-Rib","Ovary","Bone_Marrow_Mesenchyme","Pancreas","Neonatal-Calvaria","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow_c-kit","Pancreas","Neonatal-Muscle","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","MammaryGland.Lactation","Neonatal-Calvaria","Lung","Uterus","Embryonic-Stem-Cell","Fetal_Stomache","MammaryGland.Lactation","Pancreas","Embryonic-Stem-Cell","Prostate","Ovary","Testis","Peripheral_Blood","MammaryGland.Lactation","MammaryGland.Virgin","Kidney","Brain","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Thymus","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Fetal_Stomache","Neonatal-Calvaria","Neonatal-Rib","Bone-Marrow_c-kit","Prostate","Bone-Marrow_c-kit","Bone-Marrow","MammaryGland.Virgin","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Fetal_Stomache","MammaryGland.Pregnancy","Brain","MammaryGland.Lactation","Ovary","Kidney","MammaryGland.Involution","Bone_Marrow_Mesenchyme","Bone-Marrow","Bone-Marrow","Bone_Marrow_Mesenchyme","Testis","Fetal_Stomache","Fetal_Intestine","Stomach","Liver","Neonatal-Skin","Testis","Fetal_Lung","Testis","Small-Intestine","Trophoblast-Stem-Cell","Uterus","Fetal_Lung","MammaryGland.Involution","MammaryGland.Lactation","Fetal_Brain","Neonatal-Heart","Neonatal-Rib","Small-Intestine","Placenta","Trophoblast-Stem-Cell","Ovary","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Spleen","Trophoblast-Stem-Cell","Small-Intestine","Kidney","Prostate","Bone-Marrow","Embryonic-Stem-Cell","Pancreas","Lung","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow","Fetal_Lung","Kidney","Uterus","Trophoblast-Stem-Cell","Kidney","Embryonic-Stem-Cell","Lung","Peripheral_Blood","Embryonic-Mesenchyme","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Muscle","Fetal_Lung","MammaryGland.Involution","Neonatal-Rib","Bone-Marrow_c-kit","MammaryGland.Virgin","MammaryGland.Virgin","Placenta","MammaryGland.Pregnancy","Embryonic-Mesenchyme","Fetal_Stomache","Testis","Embryonic-Stem-Cell","Testis","MammaryGland.Lactation","Fetal_Intestine","Testis","Peripheral_Blood","Bone-Marrow","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Heart","Testis","Fetal-Liver","Fetal_Lung","Neonatal-Muscle","Bone-Marrow","Embryonic-Stem-Cell","MammaryGland.Lactation","Small-Intestine","Neonatal-Skin","Fetal_Lung","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Embryonic-Stem-Cell","Prostate","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Virgin","Fetal_Lung","Bladder","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Uterus","Small-Intestine","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Fetal_Lung","Bone-Marrow_c-kit","MammaryGland.Lactation","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Testis","Placenta","Neonatal-Calvaria","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Fetal-Liver","Testis","Ovary","Trophoblast-Stem-Cell","Bone-Marrow","MammaryGland.Involution","Neonatal-Heart","Muscle","Testis","Bone-Marrow","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Peripheral_Blood","Trophoblast-Stem-Cell","MammaryGland.Lactation","Embryonic-Stem-Cell","Lung","Thymus","Uterus","Pancreas","Fetal_Intestine","Testis","Embryonic-Stem-Cell","Small-Intestine","Testis","Neonatal-Calvaria","Small-Intestine","Fetal_Lung","Testis","Uterus","Fetal_Lung","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Calvaria","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Ovary","Trophoblast-Stem-Cell","Placenta","Fetal-Liver","Prostate","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Liver","MammaryGland.Lactation","Ovary","Placenta","Neonatal-Skin","Kidney","MammaryGland.Involution","Testis","Neonatal-Muscle","MammaryGland.Involution","MammaryGland.Involution","Bone_Marrow_Mesenchyme","Testis","Thymus","MammaryGland.Lactation","Testis","Pancreas","Spleen","Thymus","MammaryGland.Pregnancy","Liver","Fetal_Stomache","Brain","Small-Intestine","Fetal_Brain","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow","Pancreas","Fetal_Brain","MammaryGland.Virgin","MammaryGland.Involution","Small-Intestine","Bone-Marrow_c-kit","Stomach","Bone-Marrow","MammaryGland.Virgin","Trophoblast-Stem-Cell","Thymus","Testis","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","MammaryGland.Lactation","Placenta","Pancreas","Bladder","Testis","Muscle","Fetal_Brain","Embryonic-Stem-Cell","Neonatal-Rib","Fetal-Liver","MammaryGland.Pregnancy","Small-Intestine","MammaryGland.Virgin","Testis","Liver","Trophoblast-Stem-Cell","Thymus","Peripheral_Blood","Testis","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Calvaria","Stomach","Neonatal-Rib","Testis","Bone-Marrow","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow","Fetal_Stomache","Fetal_Stomache","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Neonatal-Skin","Small-Intestine","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","MammaryGland.Involution","Trophoblast-Stem-Cell","Spleen","Lung","Peripheral_Blood","Neonatal-Calvaria","Peripheral_Blood","Neonatal-Skin","Bone-Marrow_c-kit","Liver","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Bone-Marrow_c-kit","Stomach","Placenta","Ovary","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Muscle","Neonatal-Rib","Trophoblast-Stem-Cell","Ovary","Uterus","Uterus","Bone-Marrow_c-kit","Fetal_Stomache","Muscle","Neonatal-Calvaria","MammaryGland.Pregnancy","MammaryGland.Pregnancy","Neonatal-Skin","Fetal_Brain","Embryonic-Stem-Cell","Neonatal-Heart","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","MammaryGland.Virgin","Fetal_Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Muscle","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Muscle","Peripheral_Blood","Spleen","Placenta","Liver","Bladder","Neonatal-Rib","Bone-Marrow","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Muscle","Testis","Kidney","Lung","MammaryGland.Virgin","Peripheral_Blood","Fetal_Intestine","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Liver","Spleen","MammaryGland.Involution","Bone-Marrow_c-kit","Ovary","Spleen","Peripheral_Blood","Uterus","Bone_Marrow_Mesenchyme","Liver","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Thymus","Bone-Marrow_c-kit","Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Muscle","MammaryGland.Lactation","Neonatal-Rib","MammaryGland.Virgin","Stomach","Bone_Marrow_Mesenchyme","Uterus","Bone_Marrow_Mesenchyme","MammaryGland.Involution","Liver","Fetal-Liver","Fetal_Intestine","MammaryGland.Lactation","Bladder","Stomach","Bladder","MammaryGland.Virgin","Fetal_Lung","Embryonic-Stem-Cell","Bone-Marrow","Testis","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Bone-Marrow","Lung","Brain","Testis","Bone-Marrow_c-kit","Fetal_Intestine","Liver","Thymus","Peripheral_Blood","Uterus","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Uterus","Stomach","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Neonatal-Muscle","MammaryGland.Lactation","Bone-Marrow_c-kit","Neonatal-Rib","Bone-Marrow","Trophoblast-Stem-Cell","Fetal_Lung","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Liver","Fetal_Stomache","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Pancreas","Trophoblast-Stem-Cell","Neonatal-Calvaria","Testis","Peripheral_Blood","Fetal_Kidney","Placenta","Embryonic-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Neonatal-Rib","Brain","Brain","MammaryGland.Involution","Trophoblast-Stem-Cell","Lung","Fetal_Lung","Liver","Placenta","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Skin","Fetal_Intestine","Bone_Marrow_Mesenchyme","Bone-Marrow","Embryonic-Mesenchyme","Fetal_Brain","Fetal_Intestine","Neonatal-Muscle","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow_c-kit","Neonatal-Calvaria","Fetal_Intestine","Peripheral_Blood","Fetal_Lung","Testis","MammaryGland.Involution","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Lung","Embryonic-Mesenchyme","Thymus","Peripheral_Blood","Ovary","Embryonic-Stem-Cell","Muscle","MammaryGland.Lactation","Prostate","Bone-Marrow_c-kit","Neonatal-Rib","Brain","Small-Intestine","MammaryGland.Involution","Bone-Marrow_c-kit","Thymus","Small-Intestine","Testis","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Neonatal-Heart","Bone-Marrow_c-kit","Kidney","MammaryGland.Pregnancy","Fetal_Lung","Trophoblast-Stem-Cell","Fetal_Intestine","Testis","Bone-Marrow_c-kit","Muscle","Neonatal-Rib","Neonatal-Calvaria","Placenta","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Muscle","Bone-Marrow_c-kit","Bone-Marrow","Trophoblast-Stem-Cell","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Virgin","Testis","MammaryGland.Lactation","Bone-Marrow_c-kit","Bladder","Bone-Marrow_c-kit","MammaryGland.Lactation","MammaryGland.Involution","Bone-Marrow_c-kit","Brain","Bone-Marrow_c-kit","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","Bone-Marrow","Liver","Neonatal-Rib","Peripheral_Blood","Embryonic-Mesenchyme","Neonatal-Calvaria","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Liver","Liver","Kidney","Peripheral_Blood","Small-Intestine","Neonatal-Calvaria","MammaryGland.Pregnancy","Ovary","Bone-Marrow","Neonatal-Rib","Neonatal-Skin","MammaryGland.Lactation","Neonatal-Calvaria","Trophoblast-Stem-Cell","Stomach","Small-Intestine","Fetal_Stomache","Spleen","Liver","Testis","Small-Intestine","Lung","Small-Intestine","MammaryGland.Involution","Uterus","Bone-Marrow_c-kit","MammaryGland.Lactation","Bladder","Thymus","MammaryGland.Involution","Neonatal-Heart","MammaryGland.Lactation","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Fetal_Lung","MammaryGland.Lactation","MammaryGland.Virgin","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Peripheral_Blood","Ovary","Brain","Stomach","Trophoblast-Stem-Cell","MammaryGland.Involution","Testis","MammaryGland.Involution","Trophoblast-Stem-Cell","Thymus","Fetal_Lung","Bone-Marrow_c-kit","Lung","Trophoblast-Stem-Cell","Fetal_Brain","Neonatal-Muscle","Spleen","MammaryGland.Lactation","Fetal_Lung","Embryonic-Stem-Cell","Fetal_Lung","Bone_Marrow_Mesenchyme","Pancreas","Fetal_Intestine","Testis","MammaryGland.Virgin","Ovary","MammaryGland.Involution","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow","Testis","Fetal_Stomache","Fetal_Brain","Small-Intestine","Trophoblast-Stem-Cell","Neonatal-Heart","Fetal_Lung","Thymus","Bone-Marrow_c-kit","Fetal_Lung","Small-Intestine","Neonatal-Rib","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Fetal-Liver","Neonatal-Calvaria","Trophoblast-Stem-Cell","Muscle","MammaryGland.Virgin","Peripheral_Blood","Embryonic-Stem-Cell","Stomach","Ovary","Liver","Neonatal-Rib","Muscle","Prostate","MammaryGland.Lactation","MammaryGland.Pregnancy","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Bone-Marrow_c-kit","Uterus","Uterus","Fetal_Intestine","Neonatal-Rib","Neonatal-Skin","Bone-Marrow","Bone-Marrow_c-kit","Fetal_Brain","Embryonic-Stem-Cell","Neonatal-Rib","Fetal_Stomache","Bone_Marrow_Mesenchyme","Neonatal-Muscle","MammaryGland.Virgin","Neonatal-Calvaria","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Rib","Fetal_Brain","Spleen","Kidney","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Neonatal-Calvaria","MammaryGland.Involution","Lung","Small-Intestine","Placenta","Kidney","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","MammaryGland.Pregnancy","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Neonatal-Skin","Small-Intestine","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Neonatal-Muscle","Liver","Kidney","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","MammaryGland.Involution","MammaryGland.Lactation","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Pancreas","Brain","Bone-Marrow","Pancreas","Fetal_Lung","Embryonic-Stem-Cell","Uterus","MammaryGland.Lactation","Fetal_Stomache","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Lung","Trophoblast-Stem-Cell","Bone-Marrow","Neonatal-Rib","MammaryGland.Pregnancy","Fetal_Intestine","Fetal_Intestine","Trophoblast-Stem-Cell","Neonatal-Rib","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Intestine","Fetal_Lung","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Muscle","MammaryGland.Lactation","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Intestine","Trophoblast-Stem-Cell","Fetal_Intestine","Bone_Marrow_Mesenchyme","Fetal_Lung","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Rib","Lung","Neonatal-Muscle","Mesenchymal-Stem-Cell-Cultured","Lung","Lung","Peripheral_Blood","Fetal_Lung","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Small-Intestine","Fetal_Lung","Neonatal-Rib","Trophoblast-Stem-Cell","Bladder","Bladder","Neonatal-Heart","MammaryGland.Involution","Bone-Marrow","Bone-Marrow_c-kit","Uterus","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Kidney","Fetal_Stomache","Fetal_Stomache","Thymus","Trophoblast-Stem-Cell","Testis","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Small-Intestine","Embryonic-Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Calvaria","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Ovary","MammaryGland.Lactation","Pancreas","Fetal-Liver","Trophoblast-Stem-Cell","Neonatal-Calvaria","Neonatal-Heart","Peripheral_Blood","Kidney","Spleen","Kidney","Embryonic-Stem-Cell","Liver","Bone-Marrow_c-kit","Neonatal-Muscle","Thymus","MammaryGland.Involution","MammaryGland.Pregnancy","MammaryGland.Lactation","Peripheral_Blood","Spleen","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Uterus","Placenta","MammaryGland.Lactation","MammaryGland.Virgin","Neonatal-Rib","Stomach","Mesenchymal-Stem-Cell-Cultured","Stomach","Fetal_Lung","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Neonatal-Rib","Bone-Marrow_c-kit","Lung","Bladder","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Fetal_Lung","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Lung","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Thymus","MammaryGland.Involution","Neonatal-Calvaria","Fetal_Lung","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Mesenchyme","MammaryGland.Lactation","Testis","MammaryGland.Lactation","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Testis","Fetal_Intestine","Bone-Marrow_c-kit","Placenta","MammaryGland.Lactation","Prostate","Neonatal-Skin","Bone_Marrow_Mesenchyme","Small-Intestine","MammaryGland.Lactation","Neonatal-Rib","Peripheral_Blood","Liver","Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Virgin","Fetal_Intestine","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Neonatal-Calvaria","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Pancreas","Trophoblast-Stem-Cell","Peripheral_Blood","Neonatal-Rib","Neonatal-Rib","MammaryGland.Pregnancy","Neonatal-Calvaria","Liver","Mesenchymal-Stem-Cell-Cultured","Uterus","Liver","Fetal_Brain","Bone-Marrow_c-kit","Fetal_Stomache","Peripheral_Blood","Uterus","Embryonic-Stem-Cell","Neonatal-Calvaria","Bone-Marrow_c-kit","Neonatal-Skin","Testis","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Fetal_Lung","Bone-Marrow","Bone-Marrow_c-kit","Neonatal-Muscle","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Pancreas","Mesenchymal-Stem-Cell-Cultured","Neonatal-Skin","Small-Intestine","Lung","MammaryGland.Pregnancy","Bone-Marrow","Spleen","Neonatal-Rib","Trophoblast-Stem-Cell","Fetal-Liver","Trophoblast-Stem-Cell","Placenta","MammaryGland.Pregnancy","Bone-Marrow","Pancreas","Embryonic-Stem-Cell","Lung","Neonatal-Calvaria","Small-Intestine","Fetal_Lung","Spleen","Stomach","Bone-Marrow_c-kit","Neonatal-Calvaria","Fetal_Intestine","Neonatal-Rib","Embryonic-Stem-Cell","Pancreas","Neonatal-Rib","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Lung","Brain","Placenta","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Trophoblast-Stem-Cell","Fetal_Stomache","Bone-Marrow_c-kit","Neonatal-Muscle","Bone-Marrow_c-kit","Bone-Marrow","Small-Intestine","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Neonatal-Skin","Bone-Marrow_c-kit","Fetal_Lung","Uterus","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","MammaryGland.Lactation","Fetal_Stomache","Lung","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Heart","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Fetal_Lung","Peripheral_Blood","Testis","Liver","Bone-Marrow_c-kit","Lung","Neonatal-Skin","Neonatal-Calvaria","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Testis","Lung","MammaryGland.Pregnancy","Neonatal-Rib","MammaryGland.Pregnancy","Peripheral_Blood","Bone-Marrow_c-kit","Fetal_Brain","Bone-Marrow","Bone-Marrow","MammaryGland.Pregnancy","Uterus","MammaryGland.Lactation","Bone-Marrow_c-kit","Lung","Neonatal-Calvaria","Fetal_Brain","Testis","Embryonic-Stem-Cell","Testis","Bone-Marrow_c-kit","Bladder","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Fetal_Stomache","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Testis","Peripheral_Blood","MammaryGland.Lactation","Trophoblast-Stem-Cell","Brain","Testis","Kidney","Kidney","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Brain","MammaryGland.Involution","Embryonic-Stem-Cell","Lung","Bone-Marrow","MammaryGland.Involution","Trophoblast-Stem-Cell","Neonatal-Muscle","Testis","Neonatal-Heart","Fetal_Stomache","Neonatal-Skin","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Bone-Marrow_c-kit","Kidney","Fetal_Lung","Trophoblast-Stem-Cell","Thymus","MammaryGland.Involution","Neonatal-Muscle","Trophoblast-Stem-Cell","MammaryGland.Lactation","Lung","Neonatal-Muscle","Bone-Marrow","Neonatal-Calvaria","Uterus","Bone-Marrow_c-kit","Brain","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Neonatal-Heart","Testis","MammaryGland.Lactation","Bone-Marrow","Bone-Marrow","Kidney","Bone-Marrow","Fetal_Brain","Liver","Fetal_Stomache","Ovary","Fetal_Lung","Testis","Trophoblast-Stem-Cell","MammaryGland.Virgin","Fetal_Lung","Trophoblast-Stem-Cell","Peripheral_Blood","Testis","Lung","Bone_Marrow_Mesenchyme","Testis","Neonatal-Calvaria","MammaryGland.Involution","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow","Fetal_Stomache","Fetal_Intestine","Testis","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Virgin","Placenta","Bone-Marrow_c-kit","Kidney","Trophoblast-Stem-Cell","Bladder","Bone-Marrow","Testis","Fetal_Intestine","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Rib","Lung","Neonatal-Calvaria","Embryonic-Stem-Cell","Neonatal-Heart","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Placenta","Bladder","Neonatal-Skin","Fetal_Brain","Trophoblast-Stem-Cell","Fetal-Liver","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Fetal_Intestine","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Neonatal-Calvaria","Bone-Marrow_c-kit","Kidney","Ovary","Trophoblast-Stem-Cell","Neonatal-Heart","Neonatal-Rib","Fetal_Lung","Fetal_Stomache","Ovary","Neonatal-Calvaria","MammaryGland.Lactation","Fetal-Liver","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Uterus","MammaryGland.Lactation","MammaryGland.Involution","Trophoblast-Stem-Cell","Ovary","Bone-Marrow_c-kit","Bone-Marrow","Embryonic-Stem-Cell","Neonatal-Rib","Peripheral_Blood","Brain","Bone-Marrow_c-kit","Prostate","MammaryGland.Virgin","Fetal_Intestine","Lung","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Neonatal-Skin","Bone_Marrow_Mesenchyme","Bladder","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Bone-Marrow","Placenta","Fetal_Lung","MammaryGland.Pregnancy","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Spleen","MammaryGland.Virgin","Fetal_Intestine","Bone-Marrow_c-kit","Testis","Neonatal-Rib","Neonatal-Calvaria","Fetal_Intestine","Placenta","Neonatal-Rib","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Kidney","Embryonic-Mesenchyme","Lung","Uterus","Bone-Marrow","MammaryGland.Lactation","Muscle","Neonatal-Calvaria","Bone-Marrow_c-kit","Thymus","MammaryGland.Pregnancy","MammaryGland.Virgin","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Testis","Bone-Marrow_c-kit","Fetal_Stomache","Neonatal-Calvaria","Bone-Marrow_c-kit","Muscle","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Brain","Bone-Marrow","MammaryGland.Pregnancy","Bladder","Fetal_Intestine","Peripheral_Blood","Pancreas","Bone-Marrow_c-kit","Neonatal-Rib","Fetal_Stomache","Bone-Marrow_c-kit","Thymus","Placenta","Bone-Marrow_c-kit","Fetal_Brain","Placenta","Neonatal-Skin","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Peripheral_Blood","Prostate","Testis","Testis","Placenta","Small-Intestine","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Lung","Bone-Marrow_c-kit","Neonatal-Calvaria","Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal-Liver","Bone-Marrow_c-kit","Neonatal-Heart","Embryonic-Stem-Cell","Fetal_Intestine","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Ovary","Embryonic-Stem-Cell","Lung","MammaryGland.Virgin","Bone-Marrow_c-kit","Lung","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Kidney","MammaryGland.Virgin","Bone-Marrow_c-kit","Fetal_Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Lung","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Embryonic-Stem-Cell","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Kidney","Neonatal-Muscle","Trophoblast-Stem-Cell","Neonatal-Calvaria","Neonatal-Calvaria","Bone-Marrow_c-kit","Fetal_Intestine","Fetal_Lung","MammaryGland.Involution","Bone_Marrow_Mesenchyme","Testis","MammaryGland.Pregnancy","Fetal-Liver","Peripheral_Blood","Thymus","Peripheral_Blood","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Liver","Neonatal-Rib","Neonatal-Calvaria","Neonatal-Heart","MammaryGland.Pregnancy","Uterus","Bone-Marrow_c-kit","Lung","MammaryGland.Lactation","Small-Intestine","Trophoblast-Stem-Cell","Bone-Marrow","Testis","Neonatal-Heart","Thymus","Neonatal-Heart","Stomach","Prostate","Neonatal-Heart","Bone-Marrow_c-kit","Bone-Marrow","Fetal_Brain","Neonatal-Skin","Muscle","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Uterus","Spleen","Uterus","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","Fetal-Liver","Bladder","MammaryGland.Lactation","MammaryGland.Lactation","Neonatal-Calvaria","Small-Intestine","Brain","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Neonatal-Heart","Testis","Ovary","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Neonatal-Rib","Uterus","Kidney","Pancreas","Small-Intestine","Fetal_Brain","Bone-Marrow_c-kit","Fetal_Brain","Trophoblast-Stem-Cell","Small-Intestine","Bone_Marrow_Mesenchyme","Placenta","Neonatal-Muscle","Small-Intestine","Trophoblast-Stem-Cell","Fetal-Liver","Neonatal-Muscle","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Small-Intestine","Testis","Uterus","Kidney","Peripheral_Blood","Thymus","Bone-Marrow_c-kit","MammaryGland.Lactation","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Testis","Kidney","Testis","Small-Intestine","Bladder","MammaryGland.Lactation","Fetal_Stomache","Neonatal-Muscle","Bone-Marrow_c-kit","Placenta","Neonatal-Calvaria","Small-Intestine","Bone_Marrow_Mesenchyme","Liver","Bone_Marrow_Mesenchyme","Neonatal-Heart","Bone-Marrow_c-kit","Testis","Pancreas","Neonatal-Calvaria","Fetal_Brain","Liver","Neonatal-Skin","Fetal_Intestine","Bone-Marrow_c-kit","Ovary","Stomach","MammaryGland.Lactation","Trophoblast-Stem-Cell","Neonatal-Muscle","Bone-Marrow_c-kit","Fetal_Stomache","Testis","Testis","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Kidney","Bone-Marrow_c-kit","MammaryGland.Involution","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Virgin","Testis","Fetal_Intestine","Small-Intestine","Neonatal-Rib","Neonatal-Calvaria","Lung","Lung","MammaryGland.Lactation","Testis","Embryonic-Stem-Cell","Bone-Marrow","Ovary","Small-Intestine","Testis","MammaryGland.Involution","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Bladder","Peripheral_Blood","Fetal_Stomache","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Fetal_Brain","Lung","Trophoblast-Stem-Cell","MammaryGland.Lactation","Testis","Trophoblast-Stem-Cell","Testis","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Testis","Liver","Testis","Small-Intestine","Fetal-Liver","Brain","Testis","Fetal_Brain","Uterus","Neonatal-Rib","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Uterus","Testis","Small-Intestine","Embryonic-Stem-Cell","Small-Intestine","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Fetal_Intestine","MammaryGland.Involution","Uterus","Neonatal-Rib","Peripheral_Blood","Bone_Marrow_Mesenchyme","Small-Intestine","Bone-Marrow_c-kit","Fetal-Liver","Brain","Uterus","Embryonic-Stem-Cell","Prostate","Neonatal-Muscle","Trophoblast-Stem-Cell","Testis","Neonatal-Rib","Neonatal-Heart","Fetal_Stomache","Neonatal-Rib","MammaryGland.Pregnancy","Bone-Marrow","Trophoblast-Stem-Cell","Brain","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Placenta","Testis","Embryonic-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Lactation","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow_c-kit","Neonatal-Calvaria","Neonatal-Heart","Muscle","Small-Intestine","Placenta","Bone_Marrow_Mesenchyme","Lung","MammaryGland.Virgin","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Calvaria","Ovary","Bone-Marrow","Small-Intestine","Placenta","Trophoblast-Stem-Cell","Spleen","Neonatal-Rib","Pancreas","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Neonatal-Skin","Neonatal-Rib","Liver","Embryonic-Stem-Cell","Bone-Marrow","Fetal_Lung","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Bladder","Bone-Marrow_c-kit","Testis","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Prostate","Fetal_Stomache","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Placenta","Neonatal-Heart","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal-Liver","Uterus","Testis","Fetal_Lung","Embryonic-Stem-Cell","Bone-Marrow","Neonatal-Muscle","Testis","Placenta","Trophoblast-Stem-Cell","Fetal_Intestine","Trophoblast-Stem-Cell","Neonatal-Calvaria","Fetal_Stomache","Bone-Marrow_c-kit","Lung","Fetal_Intestine","Bone-Marrow_c-kit","Testis","Fetal_Stomache","Small-Intestine","Trophoblast-Stem-Cell","Neonatal-Muscle","Ovary","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Muscle","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Fetal_Intestine","Embryonic-Mesenchyme","Fetal_Lung","MammaryGland.Lactation","Lung","Peripheral_Blood","Fetal_Lung","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Placenta","Neonatal-Rib","Trophoblast-Stem-Cell","MammaryGland.Lactation","Fetal_Stomache","Trophoblast-Stem-Cell","Bone-Marrow","Fetal-Liver","Placenta","Testis","Liver","Bone-Marrow_c-kit","Kidney","Bone-Marrow_c-kit","Neonatal-Rib","Testis","MammaryGland.Lactation","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Brain","Bone-Marrow_c-kit","Peripheral_Blood","Testis","MammaryGland.Virgin","Spleen","Testis","Testis","Pancreas","Neonatal-Skin","Bone-Marrow_c-kit","Peripheral_Blood","Fetal_Brain","Small-Intestine","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Heart","Fetal_Stomache","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Calvaria","Testis","Peripheral_Blood","Neonatal-Calvaria","Uterus","MammaryGland.Lactation","Fetal_Intestine","Neonatal-Calvaria","Embryonic-Stem-Cell","Spleen","Fetal-Liver","Neonatal-Calvaria","Placenta","Lung","Brain","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Fetal_Lung","Bone-Marrow_c-kit","Fetal_Intestine","MammaryGland.Pregnancy","MammaryGland.Involution","Neonatal-Rib","Fetal_Intestine","Lung","Embryonic-Stem-Cell","Testis","Fetal_Intestine","Bone_Marrow_Mesenchyme","Kidney","Bone-Marrow_c-kit","Placenta","Bone-Marrow_c-kit","Neonatal-Calvaria","Brain","Fetal-Liver","Neonatal-Rib","MammaryGland.Virgin","MammaryGland.Lactation","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","MammaryGland.Lactation","Fetal_Brain","Lung","Bone-Marrow_c-kit","Brain","Brain","Lung","Bone_Marrow_Mesenchyme","Uterus","MammaryGland.Lactation","Muscle","Peripheral_Blood","Bone-Marrow_c-kit","Neonatal-Skin","Bone-Marrow_c-kit","Bladder","Fetal_Lung","MammaryGland.Virgin","Liver","Testis","Bone-Marrow_c-kit","Testis","Bladder","Neonatal-Heart","MammaryGland.Involution","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow","Trophoblast-Stem-Cell","Uterus","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Trophoblast-Stem-Cell","Uterus","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Stomach","Bone-Marrow_c-kit","Fetal_Lung","MammaryGland.Pregnancy","MammaryGland.Virgin","Embryonic-Stem-Cell","Peripheral_Blood","Small-Intestine","Bone_Marrow_Mesenchyme","Uterus","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Peripheral_Blood","Fetal_Stomache","Neonatal-Heart","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Uterus","Neonatal-Rib","Neonatal-Rib","MammaryGland.Lactation","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Calvaria","MammaryGland.Lactation","MammaryGland.Virgin","Ovary","Peripheral_Blood","Bone-Marrow","Bone-Marrow_c-kit","Testis","Neonatal-Muscle","Liver","Fetal_Brain","Stomach","Brain","Trophoblast-Stem-Cell","Prostate","Placenta","Fetal_Lung","Trophoblast-Stem-Cell","Bone-Marrow","Fetal_Stomache","Placenta","Liver","Fetal_Lung","Bone_Marrow_Mesenchyme","Embryonic-Mesenchyme","Testis","Bone-Marrow","MammaryGland.Lactation","Testis","MammaryGland.Lactation","Embryonic-Stem-Cell","Testis","Liver","Trophoblast-Stem-Cell","Fetal-Liver","Bone-Marrow","Fetal_Stomache","Kidney","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Small-Intestine","Fetal_Stomache","Neonatal-Calvaria","MammaryGland.Involution","Pancreas","Testis","Placenta","Peripheral_Blood","Spleen","Peripheral_Blood","Testis","Bone_Marrow_Mesenchyme","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Uterus","Ovary","MammaryGland.Lactation","Peripheral_Blood","Pancreas","Testis","Kidney","Bone-Marrow_c-kit","Fetal_Lung","Fetal_Stomache","Thymus","Lung","MammaryGland.Virgin","Uterus","Small-Intestine","Lung","Neonatal-Heart","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Testis","Embryonic-Stem-Cell","Neonatal-Calvaria","Neonatal-Skin","Brain","Mesenchymal-Stem-Cell-Cultured","Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Brain","Testis","Peripheral_Blood","MammaryGland.Lactation","Neonatal-Muscle","Embryonic-Stem-Cell","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Liver","MammaryGland.Lactation","Liver","Lung","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","MammaryGland.Lactation","MammaryGland.Pregnancy","Liver","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bladder","Neonatal-Muscle","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Heart","Bone-Marrow_c-kit","MammaryGland.Involution","Placenta","MammaryGland.Involution","Peripheral_Blood","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Involution","Bone-Marrow_c-kit","Thymus","Neonatal-Muscle","Trophoblast-Stem-Cell","Ovary","Fetal_Stomache","Liver","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Neonatal-Rib","Fetal_Lung","Testis","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Ovary","Pancreas","Testis","MammaryGland.Involution","Testis","Neonatal-Rib","Neonatal-Heart","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Fetal_Stomache","Testis","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Fetal_Stomache","Trophoblast-Stem-Cell","Brain","Bone-Marrow_c-kit","Ovary","Neonatal-Rib","Testis","Bone-Marrow_c-kit","Brain","MammaryGland.Virgin","Trophoblast-Stem-Cell","Small-Intestine","Ovary","Bone-Marrow_c-kit","Kidney","MammaryGland.Virgin","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Pancreas","MammaryGland.Virgin","Placenta","Bone-Marrow_c-kit","Pancreas","Lung","Bone-Marrow","Embryonic-Stem-Cell","Neonatal-Rib","Spleen","Stomach","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Uterus","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Rib","Spleen","MammaryGland.Virgin","MammaryGland.Lactation","Uterus","Testis","Neonatal-Heart","Fetal_Stomache","Trophoblast-Stem-Cell","Small-Intestine","Trophoblast-Stem-Cell","Small-Intestine","MammaryGland.Lactation","MammaryGland.Pregnancy","Neonatal-Calvaria","Bone-Marrow_c-kit","Placenta","Thymus","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Calvaria","Pancreas","Ovary","Pancreas","Bladder","Testis","Testis","Testis","Fetal_Stomache","Placenta","Neonatal-Skin","Bone-Marrow_c-kit","Fetal-Liver","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Testis","Lung","MammaryGland.Lactation","Testis","Liver","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Placenta","Spleen","Prostate","Brain","Peripheral_Blood","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Fetal_Brain","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Kidney","Spleen","Neonatal-Rib","Bone-Marrow_c-kit","Uterus","Bone-Marrow","Fetal_Lung","Neonatal-Skin","Testis","Testis","Fetal_Intestine","Fetal_Intestine","Trophoblast-Stem-Cell","Thymus","Fetal_Brain","Fetal-Liver","Thymus","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Neonatal-Calvaria","Neonatal-Muscle","Prostate","Lung","Bladder","Neonatal-Calvaria","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Fetal_Stomache","Testis","Fetal_Intestine","Bone-Marrow","Trophoblast-Stem-Cell","Small-Intestine","Bone-Marrow_c-kit","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Brain","Lung","Trophoblast-Stem-Cell","MammaryGland.Involution","Lung","Kidney","Fetal_Intestine","Pancreas","Thymus","Bone-Marrow_c-kit","MammaryGland.Virgin","Bone-Marrow_c-kit","Neonatal-Calvaria","Neonatal-Heart","MammaryGland.Lactation","MammaryGland.Virgin","MammaryGland.Involution","Brain","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Placenta","Neonatal-Muscle","Neonatal-Rib","Brain","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Kidney","Bone_Marrow_Mesenchyme","Lung","Peripheral_Blood","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bladder","Fetal_Brain","Bone-Marrow_c-kit","Testis","Placenta","Neonatal-Heart","Bone-Marrow_c-kit","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","Lung","Trophoblast-Stem-Cell","Testis","Bone-Marrow_c-kit","Bone-Marrow","Small-Intestine","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Fetal_Intestine","Trophoblast-Stem-Cell","Thymus","Uterus","Bone-Marrow_c-kit","Thymus","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Embryonic-Mesenchyme","Neonatal-Muscle","Peripheral_Blood","Liver","Bone-Marrow","Fetal_Stomache","Embryonic-Stem-Cell","MammaryGland.Involution","Peripheral_Blood","Fetal_Lung","Bone-Marrow_c-kit","MammaryGland.Lactation","Kidney","Placenta","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","MammaryGland.Involution","Embryonic-Stem-Cell","Testis","Thymus","Uterus","Testis","Neonatal-Rib","Bone-Marrow_c-kit","Bone-Marrow","Trophoblast-Stem-Cell","Bone-Marrow","Neonatal-Calvaria","Bone-Marrow_c-kit","Testis","Neonatal-Skin","Prostate","Neonatal-Skin","Testis","Uterus","Peripheral_Blood","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Brain","Neonatal-Calvaria","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Rib","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Kidney","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Lung","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","Fetal-Liver","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Muscle","Bone_Marrow_Mesenchyme","Spleen","Neonatal-Rib","Testis","Testis","MammaryGland.Lactation","Prostate","Ovary","Pancreas","Testis","Bone-Marrow_c-kit","Liver","Neonatal-Skin","Testis","Brain","Fetal_Lung","Fetal_Stomache","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow","Trophoblast-Stem-Cell","Fetal_Brain","Lung","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Neonatal-Heart","Brain","Lung","Neonatal-Calvaria","Bone-Marrow_c-kit","Fetal-Liver","Embryonic-Stem-Cell","Neonatal-Rib","Fetal-Liver","Bone-Marrow","Pancreas","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Muscle","Embryonic-Stem-Cell","Testis","Neonatal-Rib","Fetal_Stomache","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","MammaryGland.Involution","MammaryGland.Involution","Ovary","Fetal_Lung","Trophoblast-Stem-Cell","Neonatal-Heart","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Fetal_Intestine","Neonatal-Calvaria","Bone-Marrow","Fetal_Intestine","Testis","Bone-Marrow","Bone-Marrow","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Testis","Placenta","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Fetal_Lung","Neonatal-Skin","Bone-Marrow_c-kit","Neonatal-Muscle","Thymus","Peripheral_Blood","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Neonatal-Heart","MammaryGland.Virgin","Fetal_Stomache","Bone-Marrow","Prostate","Neonatal-Heart","Neonatal-Calvaria","Fetal_Intestine","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Pancreas","Bone_Marrow_Mesenchyme","Ovary","Placenta","Trophoblast-Stem-Cell","Lung","Ovary","Brain","Lung","Fetal_Intestine","Bone-Marrow_c-kit","Thymus","Peripheral_Blood","Placenta","MammaryGland.Pregnancy","Testis","Small-Intestine","Bone_Marrow_Mesenchyme","Neonatal-Heart","MammaryGland.Lactation","Ovary","Uterus","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Thymus","Small-Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Uterus","Brain","Fetal-Liver","Lung","Trophoblast-Stem-Cell","Pancreas","Embryonic-Stem-Cell","Thymus","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Placenta","Liver","Peripheral_Blood","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Ovary","Lung","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Kidney","Testis","Neonatal-Heart","Placenta","Bone-Marrow","Fetal_Brain","Neonatal-Rib","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Calvaria","MammaryGland.Pregnancy","Neonatal-Heart","Bone-Marrow_c-kit","Kidney","Testis","Placenta","Small-Intestine","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Fetal_Lung","Fetal_Intestine","Brain","Small-Intestine","Fetal_Brain","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Testis","Small-Intestine","Testis","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Testis","MammaryGland.Pregnancy","Liver","Bladder","Stomach","Ovary","MammaryGland.Lactation","Spleen","Uterus","Ovary","MammaryGland.Lactation","Bone-Marrow_c-kit","Liver","Fetal_Intestine","Fetal_Lung","Brain","MammaryGland.Lactation","MammaryGland.Lactation","Bone-Marrow","Uterus","MammaryGland.Involution","Bone-Marrow_c-kit","Testis","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","Brain","Fetal_Brain","Neonatal-Calvaria","Embryonic-Stem-Cell","Uterus","Bone-Marrow_c-kit","MammaryGland.Lactation","MammaryGland.Lactation","Embryonic-Stem-Cell","Liver","Lung","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","MammaryGland.Lactation","Peripheral_Blood","Fetal_Lung","Spleen","Bone-Marrow","Bone-Marrow","Neonatal-Heart","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Ovary","Prostate","Fetal_Intestine","Embryonic-Stem-Cell","Fetal_Intestine","Neonatal-Calvaria","Bone-Marrow","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Skin","Trophoblast-Stem-Cell","Neonatal-Rib","Fetal_Stomache","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","Neonatal-Calvaria","Bone-Marrow_c-kit","MammaryGland.Virgin","Bone-Marrow","Neonatal-Muscle","Bone-Marrow","Ovary","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Heart","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Small-Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Testis","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Liver","Bone_Marrow_Mesenchyme","Spleen","Fetal-Liver","Peripheral_Blood","Stomach","Muscle","Testis","Fetal_Intestine","Fetal_Brain","Embryonic-Stem-Cell","MammaryGland.Involution","MammaryGland.Lactation","Fetal_Stomache","Neonatal-Calvaria","Fetal_Stomache","Uterus","Embryonic-Mesenchyme","Bone_Marrow_Mesenchyme","Lung","Bone-Marrow_c-kit","Peripheral_Blood","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Ovary","MammaryGland.Lactation","Fetal_Intestine","Stomach","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Kidney","Kidney","Fetal_Intestine","Testis","Bone-Marrow_c-kit","Fetal-Liver","Peripheral_Blood","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","MammaryGland.Lactation","Uterus","Kidney","Neonatal-Skin","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Neonatal-Calvaria","Neonatal-Rib","Fetal_Lung","MammaryGland.Lactation","Ovary","Brain","Fetal_Brain","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","MammaryGland.Lactation","Fetal_Stomache","MammaryGland.Pregnancy","Neonatal-Skin","Trophoblast-Stem-Cell","Testis","Embryonic-Stem-Cell","Testis","Kidney","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Neonatal-Skin","Trophoblast-Stem-Cell","Lung","Trophoblast-Stem-Cell","Neonatal-Muscle","Liver","Neonatal-Heart","Fetal_Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Small-Intestine","Fetal_Lung","Fetal_Lung","Fetal_Lung","Prostate","Testis","Neonatal-Calvaria","Bone-Marrow_c-kit","Ovary","Fetal-Liver","Embryonic-Stem-Cell","Fetal_Intestine","Thymus","Peripheral_Blood","Bone-Marrow_c-kit","Pancreas","Bone_Marrow_Mesenchyme","Small-Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Uterus","Pancreas","Trophoblast-Stem-Cell","Fetal_Intestine","Embryonic-Stem-Cell","Lung","Trophoblast-Stem-Cell","Placenta","Bone-Marrow_c-kit","Small-Intestine","Neonatal-Calvaria","Bone-Marrow_c-kit","MammaryGland.Lactation","Small-Intestine","Trophoblast-Stem-Cell","Kidney","MammaryGland.Lactation","Liver","MammaryGland.Virgin","Neonatal-Muscle","Trophoblast-Stem-Cell","Small-Intestine","Bone_Marrow_Mesenchyme","Kidney","MammaryGland.Lactation","Peripheral_Blood","Peripheral_Blood","Neonatal-Calvaria","Fetal_Lung","Testis","Liver","Liver","Bone_Marrow_Mesenchyme","Fetal_Intestine","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Pancreas","Peripheral_Blood","Kidney","Bone_Marrow_Mesenchyme","Fetal_Lung","MammaryGland.Lactation","Fetal_Brain","Liver","Stomach","Ovary","Bone-Marrow_c-kit","Peripheral_Blood","Peripheral_Blood","Fetal_Intestine","Neonatal-Muscle","Testis","Neonatal-Rib","Ovary","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal-Liver","Embryonic-Stem-Cell","Placenta","Embryonic-Stem-Cell","Uterus","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Brain","Bone-Marrow","Fetal_Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Spleen","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Neonatal-Skin","Testis","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Neonatal-Skin","Thymus","Fetal_Intestine","Kidney","Fetal_Lung","Thymus","Placenta","Embryonic-Stem-Cell","Fetal_Brain","Embryonic-Mesenchyme","Neonatal-Rib","Uterus","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","Fetal_Lung","Bone-Marrow","MammaryGland.Pregnancy","MammaryGland.Pregnancy","Liver","Fetal_Lung","Ovary","Fetal_Stomache","Fetal_Intestine","Fetal_Brain","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Lung","Fetal_Lung","MammaryGland.Lactation","Placenta","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Rib","Embryonic-Stem-Cell","Neonatal-Rib","Lung","Bone_Marrow_Mesenchyme","Fetal_Intestine","Fetal-Liver","Brain","Fetal_Intestine","Neonatal-Skin","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Neonatal-Rib","Neonatal-Muscle","Peripheral_Blood","Neonatal-Calvaria","Bone-Marrow_c-kit","Peripheral_Blood","Bone-Marrow_c-kit","Pancreas","MammaryGland.Virgin","Neonatal-Skin","Kidney","Neonatal-Calvaria","Neonatal-Muscle","Prostate","Fetal_Lung","Embryonic-Mesenchyme","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Placenta","Trophoblast-Stem-Cell","Lung","Testis","Neonatal-Heart","Bone-Marrow","Neonatal-Skin","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Lung","Trophoblast-Stem-Cell","Neonatal-Muscle","Bone-Marrow_c-kit","Muscle","Fetal_Lung","Bladder","Bone-Marrow","Bladder","Trophoblast-Stem-Cell","Fetal_Lung","Neonatal-Heart","Brain","Brain","Lung","Testis","Pancreas","Bone_Marrow_Mesenchyme","Bone-Marrow","Ovary","MammaryGland.Lactation","Embryonic-Stem-Cell","MammaryGland.Virgin","Fetal_Intestine","Peripheral_Blood","Peripheral_Blood","Fetal_Intestine","Fetal_Stomache","Trophoblast-Stem-Cell","Fetal_Lung","Trophoblast-Stem-Cell","Stomach","Embryonic-Stem-Cell","Testis","Neonatal-Calvaria","Neonatal-Calvaria","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Ovary","Fetal_Stomache","Embryonic-Stem-Cell","Fetal_Lung","Uterus","Fetal_Intestine","Bone-Marrow_c-kit","Bladder","Placenta","Testis","Testis","Liver","Fetal_Brain","Bone-Marrow_c-kit","MammaryGland.Lactation","Trophoblast-Stem-Cell","Peripheral_Blood","Peripheral_Blood","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Bladder","Fetal_Brain","Lung","Pancreas","Liver","Bone_Marrow_Mesenchyme","Brain","Bone-Marrow","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Liver","Embryonic-Stem-Cell","Testis","Lung","Trophoblast-Stem-Cell","Testis","Uterus","Pancreas","Testis","Neonatal-Muscle","Pancreas","Fetal_Brain","Fetal_Lung","Bone_Marrow_Mesenchyme","Uterus","Fetal_Lung","Bone-Marrow","Bone-Marrow_c-kit","Ovary","Spleen","Liver","Placenta","Kidney","Bone-Marrow","Liver","Placenta","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Fetal_Lung","Bone-Marrow","MammaryGland.Virgin","Fetal-Liver","Peripheral_Blood","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Virgin","Fetal_Stomache","Bone-Marrow_c-kit","Neonatal-Calvaria","MammaryGland.Pregnancy","Ovary","MammaryGland.Involution","Fetal_Brain","Trophoblast-Stem-Cell","Neonatal-Skin","Ovary","Bone-Marrow_c-kit","Peripheral_Blood","Neonatal-Skin","Embryonic-Stem-Cell","Bone-Marrow","Fetal_Lung","MammaryGland.Virgin","Trophoblast-Stem-Cell","Bone-Marrow","Prostate","Bone-Marrow","Testis","Embryonic-Stem-Cell","Small-Intestine","Testis","MammaryGland.Pregnancy","Liver","Embryonic-Stem-Cell","Lung","MammaryGland.Lactation","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Neonatal-Muscle","Bone-Marrow_c-kit","Neonatal-Skin","Neonatal-Calvaria","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Uterus","Bone-Marrow_c-kit","MammaryGland.Virgin","Brain","Small-Intestine","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Stomache","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Skin","Mesenchymal-Stem-Cell-Cultured","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","MammaryGland.Virgin","Lung","Neonatal-Muscle","Bone-Marrow_c-kit","Fetal-Liver","Fetal-Liver","Bone-Marrow_c-kit","Fetal_Intestine","Placenta","MammaryGland.Lactation","Neonatal-Rib","Small-Intestine","MammaryGland.Lactation","Fetal_Intestine","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Prostate","Fetal_Intestine","Thymus","Neonatal-Calvaria","MammaryGland.Lactation","Ovary","Neonatal-Rib","Peripheral_Blood","Bone-Marrow","MammaryGland.Involution","Brain","Bladder","Testis","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","MammaryGland.Involution","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","Fetal_Lung","Bone_Marrow_Mesenchyme","Uterus","Ovary","Embryonic-Mesenchyme","Lung","Neonatal-Muscle","Neonatal-Heart","Neonatal-Rib","Testis","Kidney","Thymus","Uterus","Bone-Marrow_c-kit","Bladder","Neonatal-Muscle","MammaryGland.Virgin","Bone-Marrow_c-kit","MammaryGland.Virgin","MammaryGland.Virgin","MammaryGland.Lactation","MammaryGland.Involution","Bladder","Bone_Marrow_Mesenchyme","Pancreas","MammaryGland.Lactation","Liver","MammaryGland.Lactation","Neonatal-Heart","Fetal_Intestine","Pancreas","Trophoblast-Stem-Cell","Testis","Embryonic-Stem-Cell","Fetal_Stomache","MammaryGland.Pregnancy","Uterus","Embryonic-Stem-Cell","Testis","Neonatal-Heart","Fetal_Stomache","Muscle","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Liver","Neonatal-Calvaria","Neonatal-Rib","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Embryonic-Stem-Cell","Testis","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Placenta","Peripheral_Blood","Trophoblast-Stem-Cell","Stomach","Fetal_Stomache","MammaryGland.Involution","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Fetal_Lung","Peripheral_Blood","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Bladder","Neonatal-Skin","Testis","Bone-Marrow","MammaryGland.Lactation","Lung","Fetal_Brain","Neonatal-Calvaria","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Neonatal-Rib","Bone-Marrow_c-kit","Testis","MammaryGland.Virgin","Bone-Marrow_c-kit","Neonatal-Muscle","Small-Intestine","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","Neonatal-Rib","Bone-Marrow_c-kit","Fetal-Liver","MammaryGland.Pregnancy","Small-Intestine","Bone-Marrow_c-kit","Neonatal-Muscle","Brain","Bone-Marrow","Bone-Marrow_c-kit","Peripheral_Blood","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal-Liver","Fetal_Intestine","Ovary","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Virgin","Fetal_Stomache","Bone-Marrow_c-kit","Brain","Fetal_Stomache","Neonatal-Rib","Testis","Fetal_Intestine","Fetal_Lung","Spleen","Fetal_Intestine","MammaryGland.Involution","MammaryGland.Pregnancy","Fetal-Liver","Trophoblast-Stem-Cell","MammaryGland.Lactation","Fetal_Stomache","Small-Intestine","MammaryGland.Virgin","Bladder","MammaryGland.Pregnancy","Prostate","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Brain","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Intestine","Peripheral_Blood","Embryonic-Stem-Cell","Ovary","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Pancreas","Fetal_Lung","Fetal_Lung","Placenta","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Ovary","Placenta","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Trophoblast-Stem-Cell","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Muscle","Fetal_Intestine","Testis","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Fetal_Intestine","Fetal_Intestine","Trophoblast-Stem-Cell","Ovary","Bone-Marrow_c-kit","Neonatal-Rib","Trophoblast-Stem-Cell","Lung","Thymus","Lung","Lung","MammaryGland.Lactation","Bone-Marrow","Bone-Marrow","Thymus","MammaryGland.Pregnancy","Lung","Fetal-Liver","Testis","Neonatal-Heart","Neonatal-Rib","Peripheral_Blood","Uterus","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Muscle","Fetal_Intestine","Trophoblast-Stem-Cell","Pancreas","Trophoblast-Stem-Cell","Neonatal-Heart","Bone-Marrow_c-kit","Embryonic-Stem-Cell","MammaryGland.Involution","Bone-Marrow_c-kit","Brain","Neonatal-Skin","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Bone-Marrow","MammaryGland.Lactation","Trophoblast-Stem-Cell","Brain","MammaryGland.Virgin","Small-Intestine","Bone-Marrow_c-kit","Lung","Testis","MammaryGland.Lactation","Small-Intestine","Bone-Marrow_c-kit","Ovary","Fetal-Liver","Placenta","Bone-Marrow_c-kit","Small-Intestine","Ovary","Testis","Lung","Bone-Marrow","Bone-Marrow","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Pancreas","Neonatal-Calvaria","Small-Intestine","Trophoblast-Stem-Cell","Muscle","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Testis","Neonatal-Rib","Testis","Testis","Fetal_Lung","Brain","Trophoblast-Stem-Cell","Thymus","Bone-Marrow_c-kit","Neonatal-Muscle","Fetal_Brain","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Testis","Lung","Bone-Marrow_c-kit","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Neonatal-Heart","Bone-Marrow_c-kit","Kidney","Neonatal-Calvaria","MammaryGland.Virgin","Bone-Marrow","Ovary","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Peripheral_Blood","Testis","Fetal_Lung","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Small-Intestine","Fetal_Stomache","Bone-Marrow_c-kit","Stomach","Neonatal-Muscle","Neonatal-Skin","Trophoblast-Stem-Cell","Testis","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Virgin","Spleen","MammaryGland.Lactation","Trophoblast-Stem-Cell","Fetal_Brain","Liver","Thymus","Stomach","Trophoblast-Stem-Cell","Bladder","Uterus","Neonatal-Skin","Placenta","Trophoblast-Stem-Cell","Neonatal-Rib","Bone-Marrow_c-kit","MammaryGland.Lactation","Liver","Thymus","Kidney","Liver","Neonatal-Calvaria","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Rib","Bone-Marrow_c-kit","Small-Intestine","Lung","Kidney","Fetal_Stomache","Muscle","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Testis","Uterus","Peripheral_Blood","Fetal_Stomache","MammaryGland.Involution","Uterus","Trophoblast-Stem-Cell","MammaryGland.Lactation","Kidney","Fetal_Stomache","Placenta","Bone-Marrow_c-kit","Testis","Peripheral_Blood","MammaryGland.Lactation","Brain","Stomach","Small-Intestine","Bone-Marrow","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Virgin","Kidney","Fetal_Stomache","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Trophoblast-Stem-Cell","Peripheral_Blood","Lung","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Neonatal-Skin","Neonatal-Calvaria","MammaryGland.Pregnancy","Embryonic-Stem-Cell","Fetal_Brain","Bone_Marrow_Mesenchyme","Peripheral_Blood","Liver","Bone_Marrow_Mesenchyme","Thymus","Trophoblast-Stem-Cell","Pancreas","Testis","Ovary","Testis","Liver","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Thymus","Testis","Testis","Bone-Marrow_c-kit","Bladder","Embryonic-Stem-Cell","Testis","MammaryGland.Virgin","Trophoblast-Stem-Cell","MammaryGland.Lactation","Fetal_Stomache","Bone-Marrow_c-kit","Peripheral_Blood","Fetal_Lung","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Lung","Fetal_Lung","MammaryGland.Virgin","Peripheral_Blood","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal-Liver","Spleen","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Uterus","Trophoblast-Stem-Cell","Uterus","Bone-Marrow","MammaryGland.Involution","Bone-Marrow_c-kit","Testis","Embryonic-Stem-Cell","Bladder","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Testis","Pancreas","Neonatal-Muscle","Trophoblast-Stem-Cell","Prostate","Testis","Embryonic-Stem-Cell","MammaryGland.Lactation","Neonatal-Muscle","Lung","Ovary","Ovary","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Calvaria","MammaryGland.Virgin","Liver","Testis","Bone-Marrow_c-kit","Bone-Marrow","Fetal_Intestine","Prostate","Neonatal-Skin","MammaryGland.Lactation","Fetal_Stomache","Spleen","Fetal_Stomache","Bone-Marrow","Brain","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Placenta","Neonatal-Heart","Testis","Neonatal-Calvaria","Bone-Marrow","Bone_Marrow_Mesenchyme","Thymus","Bladder","Bone_Marrow_Mesenchyme","Ovary","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Stomach","Liver","Pancreas","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Testis","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Brain","Mesenchymal-Stem-Cell-Cultured","Kidney","Fetal_Lung","Bone-Marrow","Fetal_Stomache","MammaryGland.Pregnancy","Testis","Fetal_Intestine","Ovary","MammaryGland.Virgin","Muscle","Uterus","Peripheral_Blood","Testis","Liver","Spleen","Neonatal-Skin","Bone-Marrow_c-kit","Placenta","Fetal_Stomache","MammaryGland.Involution","Bladder","MammaryGland.Virgin","Prostate","Neonatal-Heart","Fetal_Intestine","MammaryGland.Virgin","Bone-Marrow_c-kit","Bone-Marrow","Spleen","Fetal_Lung","Peripheral_Blood","Neonatal-Calvaria","Bone-Marrow","Fetal_Stomache","Fetal_Stomache","Fetal_Stomache","Trophoblast-Stem-Cell","Uterus","Bone-Marrow","MammaryGland.Lactation","Small-Intestine","Bladder","Bone-Marrow_c-kit","MammaryGland.Virgin","Ovary","Bone-Marrow","Neonatal-Rib","Testis","Kidney","Ovary","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Rib","Neonatal-Rib","Embryonic-Stem-Cell","Bone-Marrow","Fetal_Brain","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Pancreas","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Prostate","Bone_Marrow_Mesenchyme","Testis","Pancreas","Pancreas","Bone_Marrow_Mesenchyme","Small-Intestine","Lung","Bone-Marrow","Bone-Marrow_c-kit","Testis","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","MammaryGland.Lactation","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Testis","Peripheral_Blood","Testis","Fetal-Liver","Fetal_Stomache","MammaryGland.Lactation","Bone-Marrow_c-kit","Thymus","Placenta","Bone-Marrow_c-kit","MammaryGland.Involution","Bone-Marrow","Liver","Brain","Testis","Bone-Marrow_c-kit","Fetal-Liver","Bone-Marrow_c-kit","Neonatal-Calvaria","Trophoblast-Stem-Cell","Lung","Mesenchymal-Stem-Cell-Cultured","Brain","MammaryGland.Lactation","Placenta","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Uterus","MammaryGland.Virgin","Ovary","Bladder","Testis","Trophoblast-Stem-Cell","Fetal_Stomache","Fetal-Liver","Brain","Neonatal-Muscle","Neonatal-Calvaria","MammaryGland.Virgin","Testis","Mesenchymal-Stem-Cell-Cultured","Testis","Trophoblast-Stem-Cell","MammaryGland.Virgin","Peripheral_Blood","Trophoblast-Stem-Cell","Peripheral_Blood","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Neonatal-Rib","MammaryGland.Lactation","Brain","MammaryGland.Lactation","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Pancreas","Lung","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Stomache","Trophoblast-Stem-Cell","Testis","Brain","MammaryGland.Lactation","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Small-Intestine","Testis","MammaryGland.Lactation","Small-Intestine","Uterus","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Neonatal-Heart","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Prostate","Kidney","Testis","Neonatal-Muscle","Bone-Marrow","Neonatal-Heart","Bone-Marrow_c-kit","Fetal_Lung","MammaryGland.Lactation","Stomach","Placenta","Kidney","Bone-Marrow_c-kit","Ovary","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Neonatal-Heart","Embryonic-Stem-Cell","Neonatal-Rib","Brain","Embryonic-Stem-Cell","Placenta","Trophoblast-Stem-Cell","Kidney","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Thymus","Trophoblast-Stem-Cell","Fetal_Intestine","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Neonatal-Muscle","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Uterus","Neonatal-Rib","MammaryGland.Pregnancy","MammaryGland.Virgin","Bone-Marrow_c-kit","Stomach","Testis","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Neonatal-Rib","Spleen","Ovary","Fetal_Intestine","Fetal_Lung","Trophoblast-Stem-Cell","Neonatal-Muscle","Bone-Marrow","Bone-Marrow_c-kit","Placenta","Testis","Testis","MammaryGland.Involution","Fetal_Lung","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Small-Intestine","Lung","MammaryGland.Involution","Trophoblast-Stem-Cell","MammaryGland.Virgin","Neonatal-Skin","Trophoblast-Stem-Cell","Small-Intestine","Kidney","MammaryGland.Lactation","Fetal_Intestine","Neonatal-Calvaria","Neonatal-Rib","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Neonatal-Muscle","Bone-Marrow","MammaryGland.Lactation","Fetal_Brain","Testis","MammaryGland.Lactation","Embryonic-Stem-Cell","Liver","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow","Neonatal-Rib","MammaryGland.Lactation","MammaryGland.Lactation","MammaryGland.Lactation","Bladder","Trophoblast-Stem-Cell","Neonatal-Calvaria","Neonatal-Heart","MammaryGland.Lactation","Bone-Marrow_c-kit","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Fetal_Intestine","Bone-Marrow_c-kit","MammaryGland.Lactation","Trophoblast-Stem-Cell","Peripheral_Blood","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Lung","Testis","Neonatal-Muscle","Trophoblast-Stem-Cell","Fetal_Brain","Neonatal-Skin","Spleen","Kidney","Small-Intestine","Bone-Marrow_c-kit","Fetal_Stomache","Stomach","Placenta","Fetal_Lung","MammaryGland.Lactation","Lung","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Bladder","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Fetal-Liver","Spleen","Brain","Bone-Marrow_c-kit","Placenta","Neonatal-Rib","MammaryGland.Lactation","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","MammaryGland.Virgin","Embryonic-Stem-Cell","MammaryGland.Virgin","MammaryGland.Lactation","Fetal_Lung","Testis","Trophoblast-Stem-Cell","Lung","MammaryGland.Pregnancy","Fetal_Stomache","MammaryGland.Lactation","Bone-Marrow","Bone-Marrow","Pancreas","Fetal_Intestine","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow_c-kit","Thymus","Neonatal-Rib","Bone_Marrow_Mesenchyme","MammaryGland.Virgin","Bone-Marrow","Embryonic-Stem-Cell","Stomach","Bone-Marrow_c-kit","Neonatal-Muscle","MammaryGland.Lactation","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Lung","Neonatal-Muscle","Embryonic-Stem-Cell","MammaryGland.Lactation","Testis","Lung","Brain","Testis","Bone-Marrow_c-kit","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Fetal_Brain","MammaryGland.Pregnancy","Embryonic-Mesenchyme","Neonatal-Calvaria","Bladder","MammaryGland.Virgin","Fetal_Lung","Fetal_Stomache","Neonatal-Calvaria","Neonatal-Calvaria","MammaryGland.Lactation","MammaryGland.Lactation","Fetal-Liver","Bone-Marrow","Neonatal-Calvaria","Bone-Marrow_c-kit","Uterus","MammaryGland.Lactation","Placenta","Neonatal-Muscle","Trophoblast-Stem-Cell","Neonatal-Skin","Trophoblast-Stem-Cell","Kidney","Pancreas","Pancreas","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Fetal_Stomache","Neonatal-Skin","Peripheral_Blood","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Pancreas","Testis","Fetal_Brain","Bone-Marrow_c-kit","Neonatal-Heart","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","Uterus","MammaryGland.Virgin","Embryonic-Stem-Cell","Fetal_Brain","Bone_Marrow_Mesenchyme","Liver","Neonatal-Calvaria","Embryonic-Stem-Cell","MammaryGland.Lactation","Fetal_Lung","Bone-Marrow","Fetal-Liver","MammaryGland.Lactation","Bone-Marrow_c-kit","Brain","MammaryGland.Pregnancy","Fetal_Lung","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Placenta","Spleen","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal-Liver","MammaryGland.Lactation","Bone-Marrow","Small-Intestine","Lung","MammaryGland.Pregnancy","Peripheral_Blood","Kidney","Bone-Marrow","Liver","MammaryGland.Involution","Lung","Prostate","Bone-Marrow_c-kit","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Neonatal-Calvaria","Small-Intestine","Fetal_Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Testis","Testis","Embryonic-Stem-Cell","Neonatal-Muscle","Neonatal-Muscle","Testis","Embryonic-Stem-Cell","Brain","Trophoblast-Stem-Cell","Testis","MammaryGland.Lactation","MammaryGland.Involution","Fetal_Brain","Neonatal-Skin","Lung","Ovary","Brain","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Ovary","Spleen","Stomach","Fetal_Stomache","Lung","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bone-Marrow","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Fetal_Brain","Bone_Marrow_Mesenchyme","Kidney","MammaryGland.Lactation","Thymus","Ovary","Ovary","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","MammaryGland.Lactation","Thymus","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Testis","Mesenchymal-Stem-Cell-Cultured","Fetal_Lung","Uterus","Fetal_Lung","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Testis","Neonatal-Heart","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Fetal_Brain","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Peripheral_Blood","Bone_Marrow_Mesenchyme","Neonatal-Muscle","MammaryGland.Pregnancy","Stomach","Brain","Mesenchymal-Stem-Cell-Cultured","Embryonic-Mesenchyme","Bone-Marrow","Neonatal-Muscle","Trophoblast-Stem-Cell","Peripheral_Blood","Bone_Marrow_Mesenchyme","Uterus","Fetal_Brain","MammaryGland.Involution","Neonatal-Calvaria","Neonatal-Muscle","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Lung","Fetal_Stomache","Fetal_Brain","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Lung","Uterus","Peripheral_Blood","Trophoblast-Stem-Cell","Thymus","Trophoblast-Stem-Cell","Neonatal-Rib","Brain","Prostate","Testis","Lung","Muscle","Fetal_Lung","Lung","Bone-Marrow_c-kit","Lung","Testis","Embryonic-Stem-Cell","Spleen","Trophoblast-Stem-Cell","Ovary","Pancreas","Spleen","Bladder","Testis","Bone_Marrow_Mesenchyme","Thymus","Neonatal-Skin","Placenta","MammaryGland.Lactation","Bone-Marrow","Liver","Neonatal-Calvaria","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Testis","Stomach","Neonatal-Skin","Bone-Marrow","Trophoblast-Stem-Cell","Neonatal-Rib","Peripheral_Blood","MammaryGland.Virgin","Neonatal-Rib","Trophoblast-Stem-Cell","Testis","Bone-Marrow","Testis","Neonatal-Calvaria","Testis","Bladder","MammaryGland.Involution","Fetal_Stomache","Fetal_Stomache","MammaryGland.Lactation","Neonatal-Rib","Fetal-Liver","Neonatal-Heart","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Involution","Neonatal-Rib","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow","Thymus","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Neonatal-Heart","Peripheral_Blood","Thymus","Ovary","Pancreas","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Liver","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","Bone-Marrow_c-kit","Neonatal-Muscle","Neonatal-Muscle","Neonatal-Skin","Ovary","Testis","Embryonic-Stem-Cell","Peripheral_Blood","Testis","Bone_Marrow_Mesenchyme","Pancreas","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Neonatal-Heart","Small-Intestine","Liver","MammaryGland.Virgin","MammaryGland.Virgin","Bone_Marrow_Mesenchyme","Bone-Marrow","Liver","Stomach","Fetal_Stomache","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Muscle","Testis","Testis","Neonatal-Heart","Neonatal-Skin","Testis","Bone-Marrow","Placenta","Embryonic-Stem-Cell","Pancreas","Placenta","Embryonic-Stem-Cell","Fetal_Stomache","Neonatal-Muscle","MammaryGland.Lactation","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Neonatal-Muscle","Prostate","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Peripheral_Blood","Fetal_Lung","Fetal_Intestine","Ovary","Fetal_Stomache","MammaryGland.Lactation","Bone-Marrow","Embryonic-Stem-Cell","Peripheral_Blood","Trophoblast-Stem-Cell","Neonatal-Rib","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Neonatal-Calvaria","MammaryGland.Virgin","Trophoblast-Stem-Cell","Fetal_Stomache","Trophoblast-Stem-Cell","Neonatal-Calvaria","Trophoblast-Stem-Cell","Small-Intestine","Bone-Marrow","Fetal_Lung","Trophoblast-Stem-Cell","Lung","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Peripheral_Blood","Neonatal-Calvaria","Neonatal-Rib","Small-Intestine","Placenta","Neonatal-Calvaria","Bone-Marrow_c-kit","Neonatal-Skin","Fetal-Liver","Testis","Lung","Testis","Brain","Neonatal-Rib","Embryonic-Stem-Cell","Fetal_Stomache","Trophoblast-Stem-Cell","Fetal_Lung","Neonatal-Calvaria","Lung","MammaryGland.Involution","MammaryGland.Lactation","Testis","Testis","Bone-Marrow_c-kit","Peripheral_Blood","Trophoblast-Stem-Cell","Placenta","Thymus","Bone-Marrow_c-kit","Lung","Neonatal-Muscle","Peripheral_Blood","Pancreas","Small-Intestine","Fetal_Lung","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Liver","MammaryGland.Involution","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Embryonic-Mesenchyme","Neonatal-Calvaria","Lung","MammaryGland.Lactation","MammaryGland.Pregnancy","Muscle","Uterus","Neonatal-Calvaria","Neonatal-Rib","Bone-Marrow_c-kit","Testis","MammaryGland.Virgin","Ovary","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Neonatal-Calvaria","Lung","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Fetal_Stomache","Trophoblast-Stem-Cell","Fetal_Intestine","Bone-Marrow","Bone-Marrow_c-kit","Fetal_Stomache","Small-Intestine","Testis","Bladder","Ovary","Fetal_Lung","Uterus","Trophoblast-Stem-Cell","MammaryGland.Involution","Fetal_Intestine","Fetal_Lung","Small-Intestine","Bone-Marrow","Uterus","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Spleen","Peripheral_Blood","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow","Thymus","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Fetal_Lung","Neonatal-Muscle","Neonatal-Calvaria","Neonatal-Rib","Small-Intestine","Fetal-Liver","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Spleen","Fetal_Intestine","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bladder","Testis","Mesenchymal-Stem-Cell-Cultured","Kidney","MammaryGland.Lactation","Neonatal-Muscle","Bone-Marrow_c-kit","Bone-Marrow","Small-Intestine","Peripheral_Blood","Spleen","Bone-Marrow_c-kit","Fetal_Stomache","Stomach","Thymus","Uterus","MammaryGland.Virgin","Bone-Marrow_c-kit","Peripheral_Blood","Lung","Fetal_Intestine","Bone-Marrow_c-kit","Fetal_Lung","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Lung","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Liver","Uterus","Bone-Marrow_c-kit","Brain","Uterus","Trophoblast-Stem-Cell","Neonatal-Calvaria","Lung","Neonatal-Rib","Bone-Marrow_c-kit","Uterus","Fetal_Brain","Small-Intestine","Thymus","Lung","Thymus","Bone-Marrow_c-kit","MammaryGland.Involution","Pancreas","Prostate","Bone-Marrow_c-kit","Fetal_Lung","Small-Intestine","Uterus","MammaryGland.Involution","Fetal_Brain","Fetal_Lung","Bone-Marrow","Neonatal-Rib","Fetal-Liver","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Lung","Neonatal-Rib","Neonatal-Calvaria","Neonatal-Rib","Ovary","Bone-Marrow_c-kit","Bone-Marrow","Thymus","Lung","Neonatal-Skin","MammaryGland.Lactation","Brain","Peripheral_Blood","MammaryGland.Involution","Spleen","Small-Intestine","Bone-Marrow_c-kit","MammaryGland.Virgin","Placenta","Liver","Bone-Marrow","Trophoblast-Stem-Cell","Small-Intestine","Fetal_Stomache","Testis","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Bone-Marrow","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Fetal_Lung","Bone_Marrow_Mesenchyme","Placenta","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Liver","Fetal_Intestine","Thymus","Lung","Peripheral_Blood","Kidney","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Kidney","Fetal_Brain","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Uterus","Testis","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","MammaryGland.Involution","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","Testis","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Prostate","Trophoblast-Stem-Cell","Neonatal-Muscle","Trophoblast-Stem-Cell","Peripheral_Blood","Fetal_Lung","Bone_Marrow_Mesenchyme","Muscle","Neonatal-Rib","Trophoblast-Stem-Cell","Peripheral_Blood","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Virgin","Trophoblast-Stem-Cell","Neonatal-Calvaria","Trophoblast-Stem-Cell","Bone-Marrow","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Kidney","Bone-Marrow_c-kit","Fetal_Stomache","Trophoblast-Stem-Cell","Brain","Embryonic-Stem-Cell","Bone-Marrow","Thymus","Testis","Muscle","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","MammaryGland.Virgin","MammaryGland.Virgin","Fetal_Stomache","Embryonic-Stem-Cell","Testis","Embryonic-Stem-Cell","Fetal_Lung","Embryonic-Stem-Cell","Liver","Uterus","Bone-Marrow","Bone-Marrow_c-kit","Bone-Marrow","Lung","Spleen","Embryonic-Stem-Cell","Testis","Fetal_Lung","Neonatal-Calvaria","Liver","Fetal_Brain","Neonatal-Calvaria","Small-Intestine","Fetal-Liver","Placenta","Bladder","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Fetal_Brain","Fetal_Stomache","Bone-Marrow","Fetal_Intestine","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Fetal_Intestine","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Heart","Bone-Marrow_c-kit","Bladder","Ovary","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Lactation","MammaryGland.Lactation","Peripheral_Blood","Bone-Marrow_c-kit","Neonatal-Rib","Fetal_Intestine","Liver","Fetal_Intestine","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Fetal-Liver","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Muscle","Testis","Brain","Fetal_Intestine","Embryonic-Mesenchyme","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Testis","Uterus","Kidney","Bone-Marrow_c-kit","Brain","Trophoblast-Stem-Cell","Fetal-Liver","Peripheral_Blood","Trophoblast-Stem-Cell","MammaryGland.Lactation","Ovary","MammaryGland.Lactation","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","MammaryGland.Lactation","Ovary","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Neonatal-Calvaria","MammaryGland.Lactation","Fetal_Brain","Peripheral_Blood","Lung","Trophoblast-Stem-Cell","Testis","Fetal_Stomache","Fetal_Intestine","Lung","Pancreas","Fetal_Brain","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Testis","Bladder","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Lung","Fetal_Lung","MammaryGland.Pregnancy","MammaryGland.Virgin","Fetal_Brain","Embryonic-Stem-Cell","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Testis","Testis","Testis","Small-Intestine","Trophoblast-Stem-Cell","Neonatal-Muscle","Neonatal-Muscle","MammaryGland.Virgin","Fetal_Stomache","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Pancreas","Fetal_Stomache","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Lung","Testis","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Heart","Embryonic-Mesenchyme","MammaryGland.Virgin","Fetal-Liver","Fetal_Lung","Neonatal-Calvaria","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Stomache","Testis","Peripheral_Blood","Lung","Small-Intestine","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Lung","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Neonatal-Calvaria","Neonatal-Calvaria","Embryonic-Mesenchyme","MammaryGland.Lactation","Liver","Testis","Neonatal-Calvaria","Neonatal-Muscle","MammaryGland.Involution","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","MammaryGland.Virgin","Fetal_Stomache","Placenta","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Testis","Embryonic-Mesenchyme","MammaryGland.Virgin","Bone-Marrow_c-kit","Fetal_Intestine","Uterus","Fetal_Lung","Embryonic-Stem-Cell","Ovary","Lung","Bone-Marrow_c-kit","Fetal_Brain","Neonatal-Heart","Testis","Kidney","MammaryGland.Involution","Neonatal-Calvaria","Neonatal-Rib","Small-Intestine","Bone_Marrow_Mesenchyme","Fetal_Intestine","Bone-Marrow","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Testis","Trophoblast-Stem-Cell","Testis","Prostate","Bone-Marrow","Neonatal-Rib","Trophoblast-Stem-Cell","Placenta","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Stomache","MammaryGland.Lactation","Fetal_Brain","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Lung","Muscle","Liver","Brain","Bone-Marrow","Neonatal-Skin","Small-Intestine","Kidney","Bone-Marrow","Neonatal-Calvaria","Embryonic-Mesenchyme","Bone-Marrow","Brain","Neonatal-Heart","Spleen","Lung","Testis","Bone-Marrow","Fetal_Stomache","Neonatal-Calvaria","Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Heart","Neonatal-Rib","Ovary","Neonatal-Calvaria","Fetal_Stomache","Bone-Marrow_c-kit","Bone-Marrow","Neonatal-Calvaria","Neonatal-Rib","Pancreas","Testis","Peripheral_Blood","Kidney","Trophoblast-Stem-Cell","Testis","Neonatal-Heart","Bone-Marrow_c-kit","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Fetal_Lung","Trophoblast-Stem-Cell","Neonatal-Rib","Testis","Neonatal-Calvaria","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Stomache","Neonatal-Calvaria","MammaryGland.Lactation","MammaryGland.Lactation","Testis","Kidney","MammaryGland.Lactation","Neonatal-Heart","Stomach","Bone-Marrow_c-kit","Thymus","Neonatal-Rib","Testis","MammaryGland.Lactation","Neonatal-Skin","Testis","Fetal_Lung","Fetal_Stomache","Bone_Marrow_Mesenchyme","Testis","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bladder","Bone_Marrow_Mesenchyme","Peripheral_Blood","Trophoblast-Stem-Cell","MammaryGland.Virgin","MammaryGland.Virgin","Fetal-Liver","Bladder","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Fetal_Stomache","Lung","MammaryGland.Involution","Fetal_Stomache","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Intestine","Fetal_Intestine","Embryonic-Stem-Cell","MammaryGland.Lactation","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Peripheral_Blood","Neonatal-Muscle","Lung","Bone_Marrow_Mesenchyme","MammaryGland.Pregnancy","Neonatal-Heart","Bone_Marrow_Mesenchyme","Brain","MammaryGland.Lactation","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow","Neonatal-Heart","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Lung","Stomach","Testis","Bone-Marrow_c-kit","Ovary","Bone-Marrow_c-kit","Fetal_Lung","Pancreas","Testis","Pancreas","Kidney","Trophoblast-Stem-Cell","Placenta","Prostate","Small-Intestine","MammaryGland.Lactation","Fetal_Intestine","Peripheral_Blood","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Testis","Neonatal-Heart","Bone_Marrow_Mesenchyme","Thymus","Testis","Bone-Marrow","Small-Intestine","Fetal_Intestine","Neonatal-Muscle","Bone-Marrow_c-kit","Uterus","Neonatal-Heart","Fetal_Brain","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Peripheral_Blood","Testis","Kidney","Lung","Fetal_Lung","Thymus","MammaryGland.Virgin","Bone-Marrow_c-kit","Embryonic-Stem-Cell","MammaryGland.Lactation","Embryonic-Stem-Cell","Brain","Fetal_Brain","Fetal_Intestine","Peripheral_Blood","MammaryGland.Virgin","Neonatal-Muscle","Uterus","Bone-Marrow_c-kit","Small-Intestine","MammaryGland.Involution","MammaryGland.Virgin","Bone-Marrow","Fetal-Liver","Bone-Marrow_c-kit","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","Liver","MammaryGland.Pregnancy","Neonatal-Rib","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Muscle","Thymus","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Bone-Marrow","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow","Liver","MammaryGland.Pregnancy","MammaryGland.Involution","Neonatal-Calvaria","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","Peripheral_Blood","Lung","MammaryGland.Lactation","MammaryGland.Lactation","Pancreas","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Stomach","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Thymus","Bone-Marrow_c-kit","Bladder","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Testis","Neonatal-Calvaria","Peripheral_Blood","Fetal_Stomache","Bone-Marrow_c-kit","Neonatal-Calvaria","Uterus","Neonatal-Rib","Ovary","Kidney","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","Spleen","Mesenchymal-Stem-Cell-Cultured","Ovary","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Fetal_Lung","Fetal-Liver","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Calvaria","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Fetal_Stomache","Bone-Marrow","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Virgin","Ovary","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Fetal_Lung","Spleen","MammaryGland.Involution","Spleen","MammaryGland.Virgin","Bone-Marrow","Bladder","Bone-Marrow_c-kit","Neonatal-Calvaria","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","MammaryGland.Virgin","Neonatal-Calvaria","Uterus","Bone-Marrow_c-kit","Brain","Fetal_Intestine","Bladder","Fetal_Lung","Fetal_Brain","Neonatal-Rib","Fetal_Lung","Muscle","Fetal_Lung","Bone-Marrow_c-kit","Neonatal-Rib","Testis","Prostate","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","MammaryGland.Lactation","Brain","Fetal_Stomache","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Intestine","Embryonic-Stem-Cell","Fetal_Stomache","Testis","Mesenchymal-Stem-Cell-Cultured","Neonatal-Muscle","Brain","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Thymus","Bone-Marrow_c-kit","MammaryGland.Lactation","Kidney","Small-Intestine","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Lung","Peripheral_Blood","Fetal-Liver","Fetal_Intestine","Fetal_Intestine","Bone-Marrow_c-kit","Brain","Neonatal-Calvaria","Ovary","Neonatal-Muscle","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Fetal_Lung","Fetal_Intestine","Bone-Marrow_c-kit","Neonatal-Calvaria","Embryonic-Stem-Cell","Pancreas","Neonatal-Calvaria","Neonatal-Calvaria","Pancreas","MammaryGland.Lactation","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","MammaryGland.Involution","Bone-Marrow_c-kit","Embryonic-Stem-Cell","MammaryGland.Lactation","Uterus","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Heart","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Placenta","Fetal_Brain","Bone-Marrow","Liver","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","Lung","Neonatal-Skin","MammaryGland.Virgin","Uterus","Fetal_Brain","Trophoblast-Stem-Cell","Neonatal-Skin","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Skin","Trophoblast-Stem-Cell","Fetal_Lung","Kidney","Placenta","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Kidney","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Fetal_Stomache","Bone-Marrow_c-kit","MammaryGland.Virgin","Lung","Neonatal-Muscle","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Fetal-Liver","Bone-Marrow_c-kit","Peripheral_Blood","Small-Intestine","Fetal_Lung","Trophoblast-Stem-Cell","Lung","Prostate","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Rib","Small-Intestine","Placenta","MammaryGland.Virgin","Neonatal-Muscle","Neonatal-Calvaria","MammaryGland.Pregnancy","Lung","Liver","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Placenta","Brain","Bone-Marrow","Neonatal-Rib","Fetal_Brain","Bone-Marrow","Fetal_Intestine","Lung","Testis","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Testis","Neonatal-Rib","Neonatal-Calvaria","Fetal_Stomache","Stomach","Peripheral_Blood","Testis","MammaryGland.Virgin","Testis","MammaryGland.Lactation","Pancreas","Embryonic-Stem-Cell","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Involution","Liver","Mesenchymal-Stem-Cell-Cultured","Pancreas","Trophoblast-Stem-Cell","Neonatal-Calvaria","Peripheral_Blood","Fetal_Stomache","Bone-Marrow_c-kit","Neonatal-Rib","Testis","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","Liver","Fetal_Intestine","Spleen","Brain","Liver","Neonatal-Skin","Embryonic-Stem-Cell","Fetal_Intestine","Fetal-Liver","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Small-Intestine","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Ovary","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Peripheral_Blood","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Peripheral_Blood","MammaryGland.Pregnancy","Prostate","Brain","Trophoblast-Stem-Cell","Fetal_Lung","Neonatal-Muscle","Bone-Marrow_c-kit","Fetal_Lung","Thymus","Fetal_Lung","Bone-Marrow","Bone-Marrow_c-kit","MammaryGland.Involution","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Rib","Small-Intestine","Fetal-Liver","Neonatal-Muscle","Bladder","Fetal_Stomache","Small-Intestine","Testis","Neonatal-Heart","Trophoblast-Stem-Cell","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Placenta","Prostate","Testis","Trophoblast-Stem-Cell","MammaryGland.Lactation","MammaryGland.Lactation","MammaryGland.Lactation","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Prostate","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow","Testis","Bone-Marrow_c-kit","Fetal-Liver","Bone_Marrow_Mesenchyme","Small-Intestine","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Small-Intestine","Fetal_Brain","Trophoblast-Stem-Cell","Lung","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Uterus","Bone-Marrow","Testis","Bone_Marrow_Mesenchyme","Neonatal-Rib","Ovary","Kidney","Small-Intestine","Placenta","Small-Intestine","Placenta","Ovary","Embryonic-Stem-Cell","MammaryGland.Involution","Testis","Testis","Fetal_Stomache","Fetal-Liver","Trophoblast-Stem-Cell","MammaryGland.Involution","Trophoblast-Stem-Cell","MammaryGland.Lactation","Ovary","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Placenta","Mesenchymal-Stem-Cell-Cultured","Ovary","Prostate","Peripheral_Blood","Trophoblast-Stem-Cell","Neonatal-Rib","Liver","Lung","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Placenta","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Stomach","Thymus","Prostate","Fetal_Stomache","Kidney","Fetal_Brain","Ovary","Testis","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Neonatal-Rib","Bone-Marrow","Thymus","Testis","Small-Intestine","MammaryGland.Involution","Bone-Marrow","MammaryGland.Lactation","MammaryGland.Lactation","Trophoblast-Stem-Cell","Neonatal-Rib","Placenta","Brain","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","Fetal_Brain","Fetal_Intestine","Neonatal-Rib","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Muscle","Small-Intestine","Pancreas","MammaryGland.Pregnancy","MammaryGland.Virgin","Trophoblast-Stem-Cell","Bone-Marrow","Bone-Marrow_c-kit","Thymus","Embryonic-Mesenchyme","MammaryGland.Lactation","Peripheral_Blood","Placenta","Small-Intestine","Small-Intestine","Testis","Testis","Mesenchymal-Stem-Cell-Cultured","Testis","Fetal_Intestine","Ovary","Liver","Peripheral_Blood","Trophoblast-Stem-Cell","Muscle","Lung","Testis","Bone-Marrow","Thymus","Fetal_Stomache","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Uterus","Peripheral_Blood","Uterus","Peripheral_Blood","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Neonatal-Rib","Trophoblast-Stem-Cell","Bladder","Liver","Bone_Marrow_Mesenchyme","Muscle","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Thymus","Bone-Marrow_c-kit","Fetal_Lung","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Testis","Fetal_Brain","Neonatal-Rib","Uterus","Liver","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Liver","Pancreas","MammaryGland.Lactation","MammaryGland.Lactation","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Placenta","MammaryGland.Virgin","Embryonic-Stem-Cell","Neonatal-Rib","Trophoblast-Stem-Cell","MammaryGland.Involution","Neonatal-Calvaria","Fetal_Brain","Embryonic-Stem-Cell","Small-Intestine","Trophoblast-Stem-Cell","Placenta","Bone-Marrow_c-kit","Testis","Bladder","Neonatal-Rib","Embryonic-Stem-Cell","Small-Intestine","Testis","Neonatal-Muscle","Testis","MammaryGland.Involution","Kidney","Neonatal-Skin","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Trophoblast-Stem-Cell","MammaryGland.Virgin","Brain","Uterus","Fetal_Lung","Fetal-Liver","Fetal_Brain","Testis","Fetal_Brain","Lung","Bone-Marrow","Trophoblast-Stem-Cell","Fetal-Liver","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Fetal_Brain","Bone-Marrow","Embryonic-Stem-Cell","Muscle","Bone-Marrow_c-kit","Bone-Marrow","Fetal_Intestine","Neonatal-Skin","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","Lung","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","Fetal_Stomache","Pancreas","Fetal_Stomache","Trophoblast-Stem-Cell","Bone-Marrow","Neonatal-Rib","Neonatal-Calvaria","Bone-Marrow_c-kit","Fetal_Stomache","Ovary","Fetal_Intestine","Testis","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","MammaryGland.Involution","Bladder","Ovary","MammaryGland.Pregnancy","MammaryGland.Virgin","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Small-Intestine","Neonatal-Calvaria","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Neonatal-Heart","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Testis","Trophoblast-Stem-Cell","Neonatal-Muscle","Testis","Neonatal-Calvaria","MammaryGland.Pregnancy","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Peripheral_Blood","Fetal-Liver","Bone-Marrow_c-kit","Thymus","MammaryGland.Lactation","Neonatal-Calvaria","Peripheral_Blood","Embryonic-Mesenchyme","Embryonic-Stem-Cell","Fetal_Stomache","MammaryGland.Virgin","Neonatal-Rib","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Small-Intestine","Trophoblast-Stem-Cell","Fetal_Stomache","Bone_Marrow_Mesenchyme","Lung","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Kidney","Neonatal-Rib","Liver","Lung","Prostate","Bone-Marrow","Neonatal-Rib","Neonatal-Skin","Embryonic-Stem-Cell","MammaryGland.Lactation","MammaryGland.Pregnancy","Fetal_Brain","Lung","Liver","Pancreas","Brain","Placenta","Thymus","Testis","Testis","Neonatal-Calvaria","Bone-Marrow","Fetal_Brain","Testis","Neonatal-Rib","Stomach","Bladder","Lung","MammaryGland.Virgin","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Intestine","Neonatal-Muscle","Fetal_Brain","Bone-Marrow_c-kit","MammaryGland.Lactation","Pancreas","MammaryGland.Lactation","Fetal_Lung","Bone-Marrow_c-kit","Small-Intestine","Ovary","Neonatal-Calvaria","Fetal_Lung","Fetal-Liver","MammaryGland.Pregnancy","Neonatal-Skin","Fetal_Stomache","Embryonic-Stem-Cell","MammaryGland.Pregnancy","Fetal_Lung","Prostate","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bladder","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Lung","Thymus","Brain","Brain","Fetal_Brain","Testis","Bone-Marrow_c-kit","Fetal-Liver","MammaryGland.Pregnancy","Mesenchymal-Stem-Cell-Cultured","Neonatal-Skin","Small-Intestine","Fetal_Brain","Lung","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Kidney","Bone-Marrow","Fetal_Brain","Bone-Marrow_c-kit","Neonatal-Rib","Fetal_Lung","Neonatal-Rib","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Kidney","Trophoblast-Stem-Cell","Neonatal-Rib","Bone-Marrow_c-kit","Peripheral_Blood","Fetal_Stomache","Fetal_Stomache","Lung","Thymus","Testis","Small-Intestine","Ovary","Neonatal-Heart","Kidney","Neonatal-Calvaria","Neonatal-Rib","Kidney","Embryonic-Stem-Cell","Fetal_Stomache","Bone-Marrow_c-kit","Placenta","MammaryGland.Involution","Neonatal-Heart","Testis","Bone-Marrow_c-kit","Neonatal-Skin","Bone-Marrow","Trophoblast-Stem-Cell","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Fetal_Brain","Fetal_Brain","Neonatal-Rib","Neonatal-Muscle","Fetal_Lung","Neonatal-Rib","Bone-Marrow_c-kit","Neonatal-Rib","Trophoblast-Stem-Cell","Muscle","Ovary","Bone-Marrow_c-kit","Peripheral_Blood","Fetal_Intestine","Neonatal-Rib","MammaryGland.Lactation","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Fetal_Brain","Neonatal-Muscle","Fetal_Stomache","Neonatal-Calvaria","Bone-Marrow_c-kit","Neonatal-Muscle","MammaryGland.Virgin","Spleen","Small-Intestine","Fetal-Liver","Testis","Fetal_Lung","Trophoblast-Stem-Cell","Prostate","Kidney","Bone-Marrow_c-kit","Testis","MammaryGland.Lactation","MammaryGland.Involution","Kidney","Bone-Marrow_c-kit","Fetal_Stomache","Ovary","Fetal_Lung","Pancreas","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Fetal_Stomache","Bone-Marrow_c-kit","Stomach","Neonatal-Skin","Bone-Marrow","Neonatal-Calvaria","Neonatal-Skin","Embryonic-Stem-Cell","Fetal-Liver","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Neonatal-Heart","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Trophoblast-Stem-Cell","Bladder","Brain","Neonatal-Heart","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone_Marrow_Mesenchyme","Fetal_Lung","Bone-Marrow_c-kit","Neonatal-Skin","Trophoblast-Stem-Cell","Ovary","Spleen","Mesenchymal-Stem-Cell-Cultured","Liver","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Neonatal-Heart","Neonatal-Calvaria","Thymus","MammaryGland.Lactation","Lung","Pancreas","Fetal_Stomache","Trophoblast-Stem-Cell","Testis","Mesenchymal-Stem-Cell-Cultured","Fetal_Intestine","Neonatal-Muscle","Neonatal-Skin","Fetal_Lung","MammaryGland.Lactation","Neonatal-Rib","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Bone-Marrow","Neonatal-Skin","Trophoblast-Stem-Cell","Liver","Embryonic-Stem-Cell","Uterus","Ovary","Fetal_Lung","Trophoblast-Stem-Cell","Peripheral_Blood","Fetal_Stomache","Testis","Neonatal-Calvaria","Neonatal-Calvaria","Prostate","Pancreas","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Skin","Trophoblast-Stem-Cell","Fetal_Stomache","Neonatal-Rib","Liver","Liver","Small-Intestine","Testis","Embryonic-Mesenchyme","Neonatal-Calvaria","Mesenchymal-Stem-Cell-Cultured","Testis","Ovary","Fetal_Intestine","Testis","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Fetal-Liver","MammaryGland.Virgin","MammaryGland.Lactation","Embryonic-Stem-Cell","Small-Intestine","Fetal_Stomache","Testis","Bone-Marrow","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Lung","Thymus","Bone_Marrow_Mesenchyme","Fetal_Brain","Neonatal-Skin","Trophoblast-Stem-Cell","Fetal_Brain","Neonatal-Heart","Embryonic-Stem-Cell","Fetal_Lung","Bladder","Testis","Liver","Bone-Marrow","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Intestine","Bladder","Bladder","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Bone-Marrow","Small-Intestine","Neonatal-Calvaria","Bone-Marrow_c-kit","Bone_Marrow_Mesenchyme","Fetal-Liver","Trophoblast-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Ovary","Bone-Marrow_c-kit","Neonatal-Rib","Lung","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Liver","Bone-Marrow_c-kit","Ovary","Bone-Marrow","Brain","Neonatal-Rib","Thymus","MammaryGland.Virgin","MammaryGland.Lactation","Pancreas","Peripheral_Blood","Fetal_Stomache","Trophoblast-Stem-Cell","Fetal_Lung","MammaryGland.Virgin","Trophoblast-Stem-Cell","Ovary","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Testis","Brain","Bone-Marrow_c-kit","Fetal_Stomache","Bone-Marrow_c-kit","Neonatal-Heart","Fetal_Stomache","Bone_Marrow_Mesenchyme","Fetal-Liver","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone-Marrow_c-kit","Neonatal-Calvaria","Fetal-Liver","Bone-Marrow_c-kit","MammaryGland.Lactation","MammaryGland.Pregnancy","MammaryGland.Lactation","MammaryGland.Virgin","Neonatal-Calvaria","Fetal_Lung","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Prostate","Kidney","MammaryGland.Virgin","Stomach","Testis","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Embryonic-Mesenchyme","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Lung","Lung","Peripheral_Blood","Neonatal-Rib","Uterus","Fetal_Lung","Bone-Marrow_c-kit","Ovary","Testis","Fetal_Intestine","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Fetal_Lung","Pancreas","Neonatal-Calvaria","MammaryGland.Lactation","Trophoblast-Stem-Cell","MammaryGland.Pregnancy","Thymus","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Trophoblast-Stem-Cell","Peripheral_Blood","Brain","Bone-Marrow_c-kit","Fetal_Brain","Fetal_Intestine","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Bone-Marrow_c-kit","Uterus","MammaryGland.Lactation","Prostate","Lung","Bone-Marrow_c-kit","Neonatal-Calvaria","Fetal_Stomache","Trophoblast-Stem-Cell","Peripheral_Blood","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Small-Intestine","Embryonic-Mesenchyme","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Embryonic-Stem-Cell","Testis","Brain","Neonatal-Rib","Bone-Marrow_c-kit","Bone-Marrow","Trophoblast-Stem-Cell","Liver","Liver","MammaryGland.Involution","Trophoblast-Stem-Cell","Brain","Brain","Embryonic-Mesenchyme","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Fetal_Lung","MammaryGland.Pregnancy","Uterus","MammaryGland.Lactation","Neonatal-Heart","Trophoblast-Stem-Cell","MammaryGland.Virgin","Bone-Marrow_c-kit","Neonatal-Rib","Uterus","Bone-Marrow_c-kit","Ovary","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Lung","Neonatal-Heart","Pancreas","Bone-Marrow","Neonatal-Muscle","Bone-Marrow_c-kit","MammaryGland.Lactation","Neonatal-Heart","MammaryGland.Lactation","Neonatal-Muscle","Neonatal-Calvaria","MammaryGland.Involution","Spleen","MammaryGland.Lactation","Bone-Marrow","MammaryGland.Lactation","Bone-Marrow_c-kit","Pancreas","Bone-Marrow_c-kit","Fetal_Lung","Spleen","Neonatal-Heart","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Brain","Thymus","Testis","Fetal_Lung","Neonatal-Heart","Spleen","Bone-Marrow","Fetal_Stomache","Neonatal-Heart","Fetal_Stomache","Ovary","Bone-Marrow_c-kit","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Fetal-Liver","Neonatal-Skin","Ovary","Trophoblast-Stem-Cell","Stomach","Fetal_Intestine","Neonatal-Calvaria","Neonatal-Rib","Neonatal-Skin","MammaryGland.Pregnancy","MammaryGland.Involution","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Neonatal-Calvaria","Fetal-Liver","Bone-Marrow_c-kit","Testis","Peripheral_Blood","Peripheral_Blood","Neonatal-Calvaria","Neonatal-Rib","Testis","Bone_Marrow_Mesenchyme","Prostate","Pancreas","Neonatal-Skin","Fetal_Brain","Pancreas","Embryonic-Stem-Cell","Neonatal-Muscle","Peripheral_Blood","Neonatal-Skin","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow","Neonatal-Calvaria","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Stomach","Thymus","Bone-Marrow_c-kit","Peripheral_Blood","Brain","Fetal_Brain","Thymus","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow","Testis","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Stomache","Embryonic-Stem-Cell","Fetal_Stomache","Testis","Bone-Marrow_c-kit","MammaryGland.Virgin","Fetal_Lung","Neonatal-Rib","Placenta","Brain","Neonatal-Muscle","Bone-Marrow_c-kit","Thymus","Fetal_Lung","Embryonic-Stem-Cell","Fetal_Brain","MammaryGland.Lactation","Liver","Trophoblast-Stem-Cell","MammaryGland.Lactation","MammaryGland.Pregnancy","Bone_Marrow_Mesenchyme","Fetal_Stomache","Liver","Trophoblast-Stem-Cell","Neonatal-Rib","Peripheral_Blood","Liver","MammaryGland.Lactation","MammaryGland.Virgin","Embryonic-Stem-Cell","MammaryGland.Lactation","Fetal_Lung","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Ovary","MammaryGland.Lactation","MammaryGland.Pregnancy","Fetal-Liver","Trophoblast-Stem-Cell","Peripheral_Blood","Ovary","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Virgin","Small-Intestine","MammaryGland.Pregnancy","Spleen","Bone-Marrow_c-kit","Small-Intestine","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Testis","Placenta","MammaryGland.Lactation","Liver","Neonatal-Muscle","Placenta","Spleen","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Placenta","Bone_Marrow_Mesenchyme","Uterus","Kidney","Fetal_Brain","Testis","Testis","Neonatal-Calvaria","Neonatal-Muscle","Embryonic-Stem-Cell","Bone-Marrow","Fetal-Liver","Trophoblast-Stem-Cell","Small-Intestine","MammaryGland.Involution","Small-Intestine","Bone-Marrow_c-kit","Neonatal-Calvaria","Bone-Marrow_c-kit","Fetal_Lung","Bone-Marrow_c-kit","Bladder","Fetal_Lung","Embryonic-Stem-Cell","Thymus","Spleen","Muscle","Trophoblast-Stem-Cell","Testis","Kidney","Thymus","Bone-Marrow_c-kit","Fetal_Intestine","Kidney","Brain","MammaryGland.Involution","Bone-Marrow","Neonatal-Muscle","MammaryGland.Pregnancy","Fetal_Stomache","Kidney","Placenta","Trophoblast-Stem-Cell","Neonatal-Heart","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Stomache","Trophoblast-Stem-Cell","Stomach","Testis","Kidney","Neonatal-Calvaria","Thymus","Bladder","Fetal_Stomache","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Pregnancy","MammaryGland.Lactation","Mesenchymal-Stem-Cell-Cultured","Prostate","Trophoblast-Stem-Cell","Neonatal-Muscle","Thymus","Neonatal-Heart","Peripheral_Blood","Trophoblast-Stem-Cell","Embryonic-Stem-Cell","Mesenchymal-Stem-Cell-Cultured","Embryonic-Stem-Cell","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","Neonatal-Rib","Fetal_Stomache","Bone-Marrow_c-kit","Uterus","Brain","Bone-Marrow_c-kit","Kidney","MammaryGland.Virgin","Prostate","Neonatal-Heart","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Small-Intestine","Bone-Marrow_c-kit","Testis","Neonatal-Heart","Testis","Ovary","Fetal_Brain","Fetal_Brain","Bone_Marrow_Mesenchyme","Lung","Testis","Fetal_Stomache","Neonatal-Muscle","Peripheral_Blood","Trophoblast-Stem-Cell","Fetal_Brain","Bone-Marrow_c-kit","Small-Intestine","MammaryGland.Lactation","Bone-Marrow_c-kit","Fetal_Lung","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Testis","Testis","Fetal_Intestine","Testis","Bone_Marrow_Mesenchyme","Neonatal-Heart","Bone_Marrow_Mesenchyme","Neonatal-Calvaria","Neonatal-Rib","Small-Intestine","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Lung","Uterus","Peripheral_Blood","Testis","MammaryGland.Lactation","Prostate","Thymus","Bone_Marrow_Mesenchyme","Testis","Uterus","Trophoblast-Stem-Cell","Fetal_Intestine","Trophoblast-Stem-Cell","MammaryGland.Virgin","Trophoblast-Stem-Cell","MammaryGland.Lactation","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Liver","Liver","Bone-Marrow_c-kit","MammaryGland.Involution","Uterus","Peripheral_Blood","Bone_Marrow_Mesenchyme","Neonatal-Muscle","Bone-Marrow","Testis","Bone-Marrow_c-kit","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Virgin","Pancreas","Embryonic-Stem-Cell","Placenta","Bone-Marrow_c-kit","Fetal_Brain","Placenta","Bone-Marrow_c-kit","Fetal_Brain","Trophoblast-Stem-Cell","Fetal_Brain","Mesenchymal-Stem-Cell-Cultured","Pancreas","Trophoblast-Stem-Cell","Pancreas","Pancreas","Kidney","Fetal_Brain","Pancreas","Stomach","Fetal_Lung","Brain","Thymus","Uterus","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Bone-Marrow","Fetal_Stomache","Fetal_Stomache","Trophoblast-Stem-Cell","Fetal_Lung","Small-Intestine","Lung","Placenta","Neonatal-Rib","Fetal_Stomache","Prostate","Peripheral_Blood","Fetal_Stomache","Embryonic-Mesenchyme","Neonatal-Rib","Neonatal-Calvaria","MammaryGland.Lactation","Kidney","Neonatal-Muscle","Fetal_Lung","Small-Intestine","Fetal_Lung","Testis","Lung","Bone-Marrow_c-kit","Neonatal-Skin","Fetal_Lung","Testis","Kidney","Trophoblast-Stem-Cell","Liver","Lung","Uterus","Placenta","Bone_Marrow_Mesenchyme","Prostate","Prostate","Bladder","Pancreas","Lung","Bone-Marrow","Neonatal-Calvaria","Peripheral_Blood","Neonatal-Rib","Spleen","Bone-Marrow_c-kit","Neonatal-Rib","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","Neonatal-Muscle","Trophoblast-Stem-Cell","Neonatal-Muscle","Muscle","Testis","MammaryGland.Virgin","Mesenchymal-Stem-Cell-Cultured","Trophoblast-Stem-Cell","Prostate","Fetal_Stomache","Pancreas","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Fetal_Intestine","Embryonic-Stem-Cell","Uterus","Testis","Uterus","Spleen","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Placenta","Fetal_Brain","Spleen","Lung","Lung","Embryonic-Stem-Cell","Bone-Marrow_c-kit","MammaryGland.Lactation","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Lung","Fetal_Brain","Trophoblast-Stem-Cell","Neonatal-Rib","Placenta","Fetal_Intestine","Bone_Marrow_Mesenchyme","MammaryGland.Involution","MammaryGland.Involution","Bone-Marrow_c-kit","Testis","Trophoblast-Stem-Cell","Bone-Marrow_c-kit","Testis","Pancreas","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Testis","Spleen","Bone_Marrow_Mesenchyme","Testis","Bone-Marrow_c-kit","Pancreas","MammaryGland.Lactation","Ovary","Fetal_Intestine","MammaryGland.Involution","Neonatal-Muscle","Uterus","Embryonic-Stem-Cell","Uterus","Bone-Marrow","Mesenchymal-Stem-Cell-Cultured","Fetal-Liver","Spleen","MammaryGland.Virgin","MammaryGland.Virgin","MammaryGland.Lactation","Trophoblast-Stem-Cell","Small-Intestine","Fetal_Stomache","Small-Intestine","MammaryGland.Lactation","Neonatal-Skin","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Fetal_Lung","Bone-Marrow_c-kit","Bone-Marrow","Small-Intestine","Liver","Fetal_Stomache","Fetal_Lung","Embryonic-Stem-Cell","Kidney","Fetal_Intestine","Embryonic-Stem-Cell","Bone-Marrow_c-kit","Placenta","Bone-Marrow_c-kit","MammaryGland.Lactation","Uterus","Bone-Marrow_c-kit","Bone-Marrow","Bone-Marrow","Bone-Marrow_c-kit","Prostate","Testis","Fetal_Stomache","Testis","Bone_Marrow_Mesenchyme","Fetal_Intestine","Bladder","MammaryGland.Involution","MammaryGland.Lactation","Testis","Trophoblast-Stem-Cell","Thymus","Kidney","Bone-Marrow","Bone-Marrow_c-kit","Testis","Bone-Marrow","Bone-Marrow_c-kit","Fetal_Intestine","Peripheral_Blood","Neonatal-Heart","Testis","Testis","MammaryGland.Lactation","Prostate","Mesenchymal-Stem-Cell-Cultured","MammaryGland.Pregnancy","Bone-Marrow_c-kit","Mesenchymal-Stem-Cell-Cultured","Bone_Marrow_Mesenchyme","Trophoblast-Stem-Cell","Bone-Marrow","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","Placenta","MammaryGland.Involution","Fetal-Liver","Uterus","Placenta","Bone-Marrow_c-kit","Bone-Marrow","Fetal_Lung","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","Testis","Trophoblast-Stem-Cell","Trophoblast-Stem-Cell","Neonatal-Muscle","Bone_Marrow_Mesenchyme","Fetal_Stomache","Testis","Fetal_Intestine","Fetal_Intestine","Bone-Marrow_c-kit","Peripheral_Blood","Mesenchymal-Stem-Cell-Cultured","Bone-Marrow_c-kit","Embryonic-Mesenchyme","Kidney","Brain","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Bone-Marrow_c-kit","Bone-Marrow","Bone-Marrow","Bone_Marrow_Mesenchyme","Bone_Marrow_Mesenchyme","Ovary","Neonatal-Muscle","MammaryGland.Virgin","Fetal_Stomache","Mesenchymal-Stem-Cell-Cultured","Neonatal-Skin","Fetal_Intestine","Bone-Marrow_c-kit","Pancreas","MammaryGland.Lactation","Placenta","Neonatal-Rib","Testis","Prostate","Liver","Liver","Neonatal-Muscle","MammaryGland.Lactation","Bone-Marrow","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Bone-Marrow","Fetal_Lung","Neonatal-Muscle","Bone-Marrow_c-kit","Bone-Marrow_c-kit","Trophoblast-Stem-Cell","MammaryGland.Virgin","Bone-Marrow_c-kit","MammaryGland.Lactation","Prostate","Embryonic-Mesenchyme","Neonatal-Rib","Mesenchymal-Stem-Cell-Cultured","Muscle","Fetal_Brain","Embryonic-Stem-Cell","Bone_Marrow_Mesenchyme","Fetal_Brain","Trophoblast-Stem-Cell","Placenta","Bone-Marrow_c-kit","Uterus","Embryonic-Stem-Cell","MammaryGland.Pregnancy","MammaryGland.Involution","Fetal_Stomache","Trophoblast-Stem-Cell","Bone_Marrow_Mesenchyme","MammaryGland.Lactation","Neonatal-Muscle","Bone-Marrow_c-kit","Embryonic-Stem-Cell","Fetal_Lung"],"size":1.5,"colorScale":"Dark2","showLegend":false,"fontSize":10,"fontColor":"black","legendTitle":"Tissue","legendTitleFontSize":16,"showAxes":[false,false,false],"axisLabels":["X","Y","Z"],"axisColors":["#666666","#666666","#666666"],"tickBreaks":[2,2,2],"showTickLines":[[false,false],[false,false],[false,false]],"tickLineColors":[["#aaaaaa","#aaaaaa"],["#aaaaaa","#aaaaaa"],["#aaaaaa","#aaaaaa"]],"folded":false,"foldedEmbedding":null,"foldAnimDelay":100,"foldAnimDuration":null, "shape": "cone", "shading": true}],"turntable":false,"rotationRate":0.01,"colnames":null,"rownames":null,"labels":[],"backgroundColor":"#ffffdd"} \ No newline at end of file diff --git a/index.html b/index.html index 5be77dc..8e2b534 100644 --- a/index.html +++ b/index.html @@ -8,6 +8,7 @@ +